diff --git a/frontend/build/asset-manifest.json b/frontend/build/asset-manifest.json new file mode 100644 index 000000000..dda2c5167 --- /dev/null +++ b/frontend/build/asset-manifest.json @@ -0,0 +1,17 @@ +{ + "files": { + "main.css": "/static/css/main.edcdbd9f.css", + "main.js": "/static/js/main.d74ed89f.js", + "static/js/488.8edbc83a.chunk.js": "/static/js/488.8edbc83a.chunk.js", + "static/media/logo.png": "/static/media/logo.e44efe3246aecc6d6219.png", + "static/media/index.cjs": "/static/media/index.d64cca1358b36db061fb.cjs", + "index.html": "/index.html", + "main.edcdbd9f.css.map": "/static/css/main.edcdbd9f.css.map", + "main.d74ed89f.js.map": "/static/js/main.d74ed89f.js.map", + "488.8edbc83a.chunk.js.map": "/static/js/488.8edbc83a.chunk.js.map" + }, + "entrypoints": [ + "static/css/main.edcdbd9f.css", + "static/js/main.d74ed89f.js" + ] +} \ No newline at end of file diff --git a/frontend/build/index.html b/frontend/build/index.html new file mode 100644 index 000000000..ed0a08f53 --- /dev/null +++ b/frontend/build/index.html @@ -0,0 +1 @@ +OptiNiSt
\ No newline at end of file diff --git a/frontend/build/static/css/main.edcdbd9f.css b/frontend/build/static/css/main.edcdbd9f.css new file mode 100644 index 000000000..3cfc31806 --- /dev/null +++ b/frontend/build/static/css/main.edcdbd9f.css @@ -0,0 +1,2 @@ +body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.toolbar .ctrl_btn{margin-left:10px}.maplibregl-map{-webkit-tap-highlight-color:rgb(0 0 0/0);font:12px/20px Helvetica Neue,Arial,Helvetica,sans-serif;overflow:hidden;position:relative}.maplibregl-canvas{left:0;position:absolute;top:0}.maplibregl-map:-webkit-full-screen{height:100%;width:100%}.maplibregl-map:fullscreen{height:100%;width:100%}.maplibregl-ctrl-group button.maplibregl-ctrl-compass{touch-action:none}.maplibregl-canvas-container.maplibregl-interactive,.maplibregl-ctrl-group button.maplibregl-ctrl-compass{cursor:grab;-webkit-user-select:none;user-select:none}.maplibregl-canvas-container.maplibregl-interactive.maplibregl-track-pointer{cursor:pointer}.maplibregl-canvas-container.maplibregl-interactive:active,.maplibregl-ctrl-group button.maplibregl-ctrl-compass:active{cursor:grabbing}.maplibregl-canvas-container.maplibregl-touch-zoom-rotate,.maplibregl-canvas-container.maplibregl-touch-zoom-rotate .maplibregl-canvas{touch-action:pan-x pan-y}.maplibregl-canvas-container.maplibregl-touch-drag-pan,.maplibregl-canvas-container.maplibregl-touch-drag-pan .maplibregl-canvas{touch-action:pinch-zoom}.maplibregl-canvas-container.maplibregl-touch-zoom-rotate.maplibregl-touch-drag-pan,.maplibregl-canvas-container.maplibregl-touch-zoom-rotate.maplibregl-touch-drag-pan .maplibregl-canvas{touch-action:none}.maplibregl-canvas-container.maplibregl-touch-drag-pan.maplibregl-cooperative-gestures,.maplibregl-canvas-container.maplibregl-touch-drag-pan.maplibregl-cooperative-gestures .maplibregl-canvas{touch-action:pan-x pan-y}.maplibregl-ctrl-bottom-left,.maplibregl-ctrl-bottom-right,.maplibregl-ctrl-top-left,.maplibregl-ctrl-top-right{pointer-events:none;position:absolute;z-index:2}.maplibregl-ctrl-top-left{left:0;top:0}.maplibregl-ctrl-top-right{right:0;top:0}.maplibregl-ctrl-bottom-left{bottom:0;left:0}.maplibregl-ctrl-bottom-right{bottom:0;right:0}.maplibregl-ctrl{clear:both;pointer-events:auto;transform:translate(0)}.maplibregl-ctrl-top-left .maplibregl-ctrl{float:left;margin:10px 0 0 10px}.maplibregl-ctrl-top-right .maplibregl-ctrl{float:right;margin:10px 10px 0 0}.maplibregl-ctrl-bottom-left .maplibregl-ctrl{float:left;margin:0 0 10px 10px}.maplibregl-ctrl-bottom-right .maplibregl-ctrl{float:right;margin:0 10px 10px 0}.maplibregl-ctrl-group{background:#fff;border-radius:4px}.maplibregl-ctrl-group:not(:empty){box-shadow:0 0 0 2px #0000001a}@media (forced-colors:active){.maplibregl-ctrl-group:not(:empty){box-shadow:0 0 0 2px ButtonText}}.maplibregl-ctrl-group button{background-color:initial;border:0;box-sizing:border-box;cursor:pointer;display:block;height:29px;outline:none;padding:0;width:29px}.maplibregl-ctrl-group button+button{border-top:1px solid #ddd}.maplibregl-ctrl button .maplibregl-ctrl-icon{background-position:50%;background-repeat:no-repeat;display:block;height:100%;width:100%}@media (forced-colors:active){.maplibregl-ctrl-icon{background-color:initial}.maplibregl-ctrl-group button+button{border-top:1px solid ButtonText}}.maplibregl-ctrl button::-moz-focus-inner{border:0;padding:0}.maplibregl-ctrl-attrib-button:focus,.maplibregl-ctrl-group button:focus{box-shadow:0 0 2px 2px #0096ff}.maplibregl-ctrl button:disabled{cursor:not-allowed}.maplibregl-ctrl button:disabled .maplibregl-ctrl-icon{opacity:.25}.maplibregl-ctrl button:not(:disabled):hover{background-color:#0000000d}.maplibregl-ctrl-group button:focus:focus-visible{box-shadow:0 0 2px 2px #0096ff}.maplibregl-ctrl-group button:focus:not(:focus-visible){box-shadow:none}.maplibregl-ctrl-group button:focus:first-child{border-radius:4px 4px 0 0}.maplibregl-ctrl-group button:focus:last-child{border-radius:0 0 4px 4px}.maplibregl-ctrl-group button:focus:only-child{border-radius:inherit}.maplibregl-ctrl button.maplibregl-ctrl-zoom-out .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23333'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13z'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-zoom-in .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23333'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5'/%3E%3C/svg%3E")}@media (forced-colors:active){.maplibregl-ctrl button.maplibregl-ctrl-zoom-out .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23fff'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13z'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-zoom-in .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23fff'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5'/%3E%3C/svg%3E")}}@media (forced-colors:active) and (prefers-color-scheme:light){.maplibregl-ctrl button.maplibregl-ctrl-zoom-out .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13z'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-zoom-in .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5'/%3E%3C/svg%3E")}}.maplibregl-ctrl button.maplibregl-ctrl-fullscreen .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23333'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1z'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-shrink .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1z'/%3E%3C/svg%3E")}@media (forced-colors:active){.maplibregl-ctrl button.maplibregl-ctrl-fullscreen .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23fff'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1z'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-shrink .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23fff'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1z'/%3E%3C/svg%3E")}}@media (forced-colors:active) and (prefers-color-scheme:light){.maplibregl-ctrl button.maplibregl-ctrl-fullscreen .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1z'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-shrink .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1z'/%3E%3C/svg%3E")}}.maplibregl-ctrl button.maplibregl-ctrl-compass .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23333'%3E%3Cpath d='m10.5 14 4-8 4 8z'/%3E%3Cpath fill='%23ccc' d='m10.5 16 4 8 4-8z'/%3E%3C/svg%3E")}@media (forced-colors:active){.maplibregl-ctrl button.maplibregl-ctrl-compass .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23fff'%3E%3Cpath d='m10.5 14 4-8 4 8z'/%3E%3Cpath fill='%23ccc' d='m10.5 16 4 8 4-8z'/%3E%3C/svg%3E")}}@media (forced-colors:active) and (prefers-color-scheme:light){.maplibregl-ctrl button.maplibregl-ctrl-compass .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29'%3E%3Cpath d='m10.5 14 4-8 4 8z'/%3E%3Cpath fill='%23ccc' d='m10.5 16 4 8 4-8z'/%3E%3C/svg%3E")}}.maplibregl-ctrl button.maplibregl-ctrl-terrain .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' fill='%23333'%3E%3Cpath d='m1.754 13.406 4.453-4.851 3.09 3.09 3.281 3.277.969-.969-3.309-3.312 3.844-4.121 6.148 6.886h1.082v-.855l-7.207-8.07-4.84 5.187L6.169 6.57l-5.48 5.965v.871ZM.688 16.844h20.625v1.375H.688Zm0 0'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-terrain-enabled .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' fill='%2333b5e5'%3E%3Cpath d='m1.754 13.406 4.453-4.851 3.09 3.09 3.281 3.277.969-.969-3.309-3.312 3.844-4.121 6.148 6.886h1.082v-.855l-7.207-8.07-4.84 5.187L6.169 6.57l-5.48 5.965v.871ZM.688 16.844h20.625v1.375H.688Zm0 0'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23333' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate:disabled .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23aaa' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3Cpath fill='red' d='m14 5 1 1-9 9-1-1z'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-active .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%2333b5e5' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-active-error .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23e58978' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-background .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%2333b5e5' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-background-error .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23e54e33' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-waiting .maplibregl-ctrl-icon{animation:maplibregl-spin 2s linear infinite}@media (forced-colors:active){.maplibregl-ctrl button.maplibregl-ctrl-geolocate .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23fff' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate:disabled .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23999' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3Cpath fill='red' d='m14 5 1 1-9 9-1-1z'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-active .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%2333b5e5' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-active-error .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23e58978' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-background .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%2333b5e5' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-background-error .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23e54e33' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3C/svg%3E")}}@media (forced-colors:active) and (prefers-color-scheme:light){.maplibregl-ctrl button.maplibregl-ctrl-geolocate .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate:disabled .maplibregl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23666' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3Cpath fill='red' d='m14 5 1 1-9 9-1-1z'/%3E%3C/svg%3E")}}@keyframes maplibregl-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}a.maplibregl-ctrl-logo{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='88' height='23' fill='none'%3E%3Cpath fill='%23000' fill-opacity='.4' fill-rule='evenodd' d='M17.408 16.796h-1.827l2.501-12.095h.198l3.324 6.533.988 2.19.988-2.19 3.258-6.533h.181l2.6 12.095h-1.81l-1.218-5.644-.362-1.71-.658 1.71-2.929 5.644h-.098l-2.914-5.644-.757-1.71-.345 1.71zm1.958-3.42-.726 3.663a1.255 1.255 0 0 1-1.232 1.011h-1.827a1.255 1.255 0 0 1-1.229-1.509l2.501-12.095a1.255 1.255 0 0 1 1.23-1.001h.197a1.25 1.25 0 0 1 1.12.685l3.19 6.273 3.125-6.263a1.25 1.25 0 0 1 1.123-.695h.181a1.255 1.255 0 0 1 1.227.991l1.443 6.71a5 5 0 0 1 .314-.787l.009-.016a4.6 4.6 0 0 1 1.777-1.887c.782-.46 1.668-.667 2.611-.667a4.6 4.6 0 0 1 1.7.32l.306.134c.21-.16.474-.256.759-.256h1.694a1.255 1.255 0 0 1 1.212.925 1.255 1.255 0 0 1 1.212-.925h1.711c.284 0 .545.094.755.252.613-.3 1.312-.45 2.075-.45 1.356 0 2.557.445 3.482 1.4q.47.48.763 1.064V4.701a1.255 1.255 0 0 1 1.255-1.255h1.86A1.255 1.255 0 0 1 54.44 4.7v9.194h2.217c.19 0 .37.043.532.118v-4.77c0-.356.147-.678.385-.906a2.42 2.42 0 0 1-.682-1.71c0-.665.267-1.253.735-1.7a2.45 2.45 0 0 1 1.722-.674 2.43 2.43 0 0 1 1.705.675q.318.302.504.683V4.7a1.255 1.255 0 0 1 1.255-1.255h1.744A1.255 1.255 0 0 1 65.812 4.7v3.335a4.8 4.8 0 0 1 1.526-.246c.938 0 1.817.214 2.59.69a4.47 4.47 0 0 1 1.67 1.743v-.98a1.255 1.255 0 0 1 1.256-1.256h1.777c.233 0 .451.064.639.174a3.4 3.4 0 0 1 1.567-.372c.346 0 .861.02 1.285.232a1.25 1.25 0 0 1 .689 1.004 4.7 4.7 0 0 1 .853-.588c.795-.44 1.675-.647 2.61-.647 1.385 0 2.65.39 3.525 1.396.836.938 1.168 2.173 1.168 3.528q-.001.515-.056 1.051a1.255 1.255 0 0 1-.947 1.09l.408.952a1.255 1.255 0 0 1-.477 1.552c-.418.268-.92.463-1.458.612-.613.171-1.304.244-2.049.244-1.06 0-2.043-.207-2.886-.698l-.015-.008c-.798-.48-1.419-1.135-1.818-1.963l-.004-.008a5.8 5.8 0 0 1-.548-2.512q0-.429.053-.843a1.3 1.3 0 0 1-.333-.086l-.166-.004c-.223 0-.426.062-.643.228-.03.024-.142.139-.142.59v3.883a1.255 1.255 0 0 1-1.256 1.256h-1.777a1.255 1.255 0 0 1-1.256-1.256V15.69l-.032.057a4.8 4.8 0 0 1-1.86 1.833 5.04 5.04 0 0 1-2.484.634 4.5 4.5 0 0 1-1.935-.424 1.25 1.25 0 0 1-.764.258h-1.71a1.255 1.255 0 0 1-1.256-1.255V7.687a2.4 2.4 0 0 1-.428.625c.253.23.412.561.412.93v7.553a1.255 1.255 0 0 1-1.256 1.255h-1.843a1.25 1.25 0 0 1-.894-.373c-.228.23-.544.373-.894.373H51.32a1.255 1.255 0 0 1-1.256-1.255v-1.251l-.061.117a4.7 4.7 0 0 1-1.782 1.884 4.77 4.77 0 0 1-2.485.67 5.6 5.6 0 0 1-1.485-.188l.009 2.764a1.255 1.255 0 0 1-1.255 1.259h-1.729a1.255 1.255 0 0 1-1.255-1.255v-3.537a1.255 1.255 0 0 1-1.167.793h-1.679a1.25 1.25 0 0 1-.77-.263 4.5 4.5 0 0 1-1.945.429c-.885 0-1.724-.21-2.495-.632l-.017-.01a5 5 0 0 1-1.081-.836 1.255 1.255 0 0 1-1.254 1.312h-1.81a1.255 1.255 0 0 1-1.228-.99l-.782-3.625-2.044 3.939a1.25 1.25 0 0 1-1.115.676h-.098a1.25 1.25 0 0 1-1.116-.68l-2.061-3.994zM35.92 16.63l.207-.114.223-.15q.493-.356.735-.785l.061-.118.033 1.332h1.678V9.242h-1.694l-.033 1.267q-.133-.329-.526-.658l-.032-.028a3.2 3.2 0 0 0-.668-.428l-.27-.12a3.3 3.3 0 0 0-1.235-.23q-1.136-.001-1.974.493a3.36 3.36 0 0 0-1.3 1.382q-.445.89-.444 2.074 0 1.2.51 2.107a3.8 3.8 0 0 0 1.382 1.381 3.9 3.9 0 0 0 1.893.477q.795 0 1.455-.33zm-2.789-5.38q-.576.675-.575 1.762 0 1.102.559 1.794.576.675 1.645.675a2.25 2.25 0 0 0 .934-.19 2.2 2.2 0 0 0 .468-.29l.178-.161a2.2 2.2 0 0 0 .397-.561q.244-.5.244-1.15v-.115q0-.708-.296-1.267l-.043-.077a2.2 2.2 0 0 0-.633-.709l-.13-.086-.047-.028a2.1 2.1 0 0 0-1.073-.285q-1.052 0-1.629.692zm2.316 2.706c.163-.17.28-.407.28-.83v-.114c0-.292-.06-.508-.15-.68a.96.96 0 0 0-.353-.389.85.85 0 0 0-.464-.127c-.4 0-.56.114-.664.239l-.01.012c-.148.174-.275.45-.275.945 0 .506.122.801.27.99.097.11.266.224.68.224.303 0 .504-.09.687-.269zm7.545 1.705a2.6 2.6 0 0 0 .331.423q.319.33.755.548l.173.074q.65.255 1.49.255 1.02 0 1.844-.493a3.45 3.45 0 0 0 1.316-1.4q.493-.904.493-2.089 0-1.909-.988-2.913-.988-1.02-2.584-1.02-.898 0-1.575.347a3 3 0 0 0-.415.262l-.199.166a3.4 3.4 0 0 0-.64.82V9.242h-1.712v11.553h1.729l-.017-5.134zm.53-1.138q.206.29.48.5l.155.11.053.034q.51.296 1.119.297 1.07 0 1.645-.675.577-.69.576-1.762 0-1.119-.576-1.777-.558-.675-1.645-.675-.435 0-.835.16a2 2 0 0 0-.284.136 2 2 0 0 0-.363.254 2.2 2.2 0 0 0-.46.569l-.082.162a2.6 2.6 0 0 0-.213 1.072v.115q0 .707.296 1.267l.135.211zm.964-.818a1.1 1.1 0 0 0 .367.385.94.94 0 0 0 .476.118c.423 0 .59-.117.687-.23.159-.194.28-.478.28-.95 0-.53-.133-.8-.266-.952l-.021-.025c-.078-.094-.231-.221-.68-.221a1 1 0 0 0-.503.135l-.012.007a.86.86 0 0 0-.335.343c-.073.133-.132.324-.132.614v.115a1.4 1.4 0 0 0 .14.66zm15.7-6.222q.347-.346.346-.856a1.05 1.05 0 0 0-.345-.79 1.18 1.18 0 0 0-.84-.329q-.51 0-.855.33a1.05 1.05 0 0 0-.346.79q0 .51.346.855.345.346.856.346.51 0 .839-.346zm4.337 9.314.033-1.332q.191.403.59.747l.098.081a4 4 0 0 0 .316.224l.223.122a3.2 3.2 0 0 0 1.44.322 3.8 3.8 0 0 0 1.875-.477 3.5 3.5 0 0 0 1.382-1.366q.527-.89.526-2.09 0-1.184-.444-2.073a3.24 3.24 0 0 0-1.283-1.399q-.823-.51-1.942-.51a3.5 3.5 0 0 0-1.527.344l-.086.043-.165.09a3 3 0 0 0-.33.214q-.432.315-.656.707a2 2 0 0 0-.099.198l.082-1.283V4.701h-1.744v12.095zm.473-2.509a2.5 2.5 0 0 0 .566.7q.117.098.245.18l.144.08a2.1 2.1 0 0 0 .975.232q1.07 0 1.645-.675.576-.69.576-1.778 0-1.102-.576-1.777-.56-.691-1.645-.692a2.2 2.2 0 0 0-1.015.235q-.22.113-.415.282l-.15.142a2.1 2.1 0 0 0-.42.594q-.223.479-.223 1.1v.115q0 .705.293 1.26zm2.616-.293c.157-.191.28-.479.28-.967 0-.51-.13-.79-.276-.961l-.021-.026c-.082-.1-.232-.225-.67-.225a.87.87 0 0 0-.681.279l-.012.011c-.154.155-.274.38-.274.807v.115c0 .285.057.499.144.669a1.1 1.1 0 0 0 .367.405c.137.082.28.123.455.123.423 0 .59-.118.686-.23zm8.266-3.013q.345-.13.724-.14l.069-.002q.493 0 .642.099l.247-1.794q-.196-.099-.717-.099a2.3 2.3 0 0 0-.545.063 2 2 0 0 0-.411.148 2.2 2.2 0 0 0-.4.249 2.5 2.5 0 0 0-.485.499 2.7 2.7 0 0 0-.32.581l-.05.137v-1.48h-1.778v7.553h1.777v-3.884q0-.546.159-.943a1.5 1.5 0 0 1 .466-.636 2.5 2.5 0 0 1 .399-.253 2 2 0 0 1 .224-.099zm9.784 2.656.05-.922q0-1.743-.856-2.698-.838-.97-2.584-.97-1.119-.001-2.007.493a3.46 3.46 0 0 0-1.4 1.382q-.493.906-.493 2.106 0 1.07.428 1.975.428.89 1.332 1.432.906.526 2.255.526.973 0 1.668-.185l.044-.012.135-.04q.613-.184.984-.421l-.542-1.267q-.3.162-.642.274l-.297.087q-.51.131-1.3.131-.954 0-1.497-.444a1.6 1.6 0 0 1-.192-.193q-.366-.44-.512-1.234l-.004-.021zm-5.427-1.256-.003.022h3.752v-.138q-.011-.727-.288-1.118a1 1 0 0 0-.156-.176q-.46-.428-1.316-.428-.986 0-1.494.604-.379.45-.494 1.234zm-27.053 2.77V4.7h-1.86v12.095h5.333V15.15zm7.103-5.908v7.553h-1.843V9.242h1.843z'/%3E%3Cpath fill='%23fff' d='m19.63 11.151-.757-1.71-.345 1.71-1.12 5.644h-1.827L18.083 4.7h.197l3.325 6.533.988 2.19.988-2.19L26.839 4.7h.181l2.6 12.095h-1.81l-1.218-5.644-.362-1.71-.658 1.71-2.93 5.644h-.098l-2.913-5.644zm14.836 5.81q-1.02 0-1.893-.478a3.8 3.8 0 0 1-1.381-1.382q-.51-.906-.51-2.106 0-1.185.444-2.074a3.36 3.36 0 0 1 1.3-1.382q.839-.494 1.974-.494a3.3 3.3 0 0 1 1.234.231 3.3 3.3 0 0 1 .97.575q.396.33.527.659l.033-1.267h1.694v7.553H37.18l-.033-1.332q-.279.593-1.02 1.053a3.17 3.17 0 0 1-1.662.444zm.296-1.482q.938 0 1.58-.642.642-.66.642-1.711v-.115q0-.708-.296-1.267a2.2 2.2 0 0 0-.807-.872 2.1 2.1 0 0 0-1.119-.313q-1.053 0-1.629.692-.575.675-.575 1.76 0 1.103.559 1.795.577.675 1.645.675zm6.521-6.237h1.711v1.4q.906-1.597 2.83-1.597 1.596 0 2.584 1.02.988 1.005.988 2.914 0 1.185-.493 2.09a3.46 3.46 0 0 1-1.316 1.399 3.5 3.5 0 0 1-1.844.493q-.954 0-1.662-.329a2.67 2.67 0 0 1-1.086-.97l.017 5.134h-1.728zm4.048 6.22q1.07 0 1.645-.674.577-.69.576-1.762 0-1.119-.576-1.777-.558-.675-1.645-.675-.592 0-1.12.296-.51.28-.822.823-.296.527-.296 1.234v.115q0 .708.296 1.267.313.543.823.855.51.296 1.119.297z'/%3E%3Cpath fill='%23e1e3e9' d='M51.325 4.7h1.86v10.45h3.473v1.646h-5.333zm7.12 4.542h1.843v7.553h-1.843zm.905-1.415a1.16 1.16 0 0 1-.856-.346 1.17 1.17 0 0 1-.346-.856 1.05 1.05 0 0 1 .346-.79q.346-.329.856-.329.494 0 .839.33a1.05 1.05 0 0 1 .345.79 1.16 1.16 0 0 1-.345.855q-.33.346-.84.346zm7.875 9.133a3.17 3.17 0 0 1-1.662-.444q-.723-.46-1.004-1.053l-.033 1.332h-1.71V4.701h1.743v4.657l-.082 1.283q.279-.658 1.086-1.119a3.5 3.5 0 0 1 1.778-.477q1.119 0 1.942.51a3.24 3.24 0 0 1 1.283 1.4q.445.888.444 2.072 0 1.201-.526 2.09a3.5 3.5 0 0 1-1.382 1.366 3.8 3.8 0 0 1-1.876.477zm-.296-1.481q1.069 0 1.645-.675.577-.69.577-1.778 0-1.102-.577-1.776-.56-.691-1.645-.692a2.12 2.12 0 0 0-1.58.659q-.642.641-.642 1.694v.115q0 .71.296 1.267a2.4 2.4 0 0 0 .807.872 2.1 2.1 0 0 0 1.119.313zm5.927-6.237h1.777v1.481q.263-.757.856-1.217a2.14 2.14 0 0 1 1.349-.46q.527 0 .724.098l-.247 1.794q-.149-.099-.642-.099-.774 0-1.416.494-.626.493-.626 1.58v3.883h-1.777V9.242zm9.534 7.718q-1.35 0-2.255-.526-.904-.543-1.332-1.432a4.6 4.6 0 0 1-.428-1.975q0-1.2.493-2.106a3.46 3.46 0 0 1 1.4-1.382q.889-.495 2.007-.494 1.744 0 2.584.97.855.956.856 2.7 0 .444-.05.92h-5.43q.18 1.005.708 1.45.542.443 1.497.443.79 0 1.3-.131a4 4 0 0 0 .938-.362l.542 1.267q-.411.263-1.119.46-.708.198-1.711.197zm1.596-4.558q.016-1.02-.444-1.432-.46-.428-1.316-.428-1.728 0-1.991 1.86z'/%3E%3Cpath d='M5.074 15.948a.484.657 0 0 0-.486.659v1.84a.484.657 0 0 0 .486.659h4.101a.484.657 0 0 0 .486-.659v-1.84a.484.657 0 0 0-.486-.659zm3.56 1.16H5.617v.838h3.017z' style='fill:%23fff;fill-rule:evenodd;stroke-width:1.03600001'/%3E%3Cg style='stroke-width:1.12603545'%3E%3Cpath d='M-9.408-1.416c-3.833-.025-7.056 2.912-7.08 6.615-.02 3.08 1.653 4.832 3.107 6.268.903.892 1.721 1.74 2.32 2.902l-.525-.004c-.543-.003-.992.304-1.24.639a1.87 1.87 0 0 0-.362 1.121l-.011 1.877c-.003.402.104.787.347 1.125.244.338.688.653 1.23.656l4.142.028c.542.003.99-.306 1.238-.641a1.87 1.87 0 0 0 .363-1.121l.012-1.875a1.87 1.87 0 0 0-.348-1.127c-.243-.338-.688-.653-1.23-.656l-.518-.004c.597-1.145 1.425-1.983 2.348-2.87 1.473-1.414 3.18-3.149 3.2-6.226-.016-3.59-2.923-6.684-6.993-6.707m-.006 1.1v.002c3.274.02 5.92 2.532 5.9 5.6-.017 2.706-1.39 4.026-2.863 5.44-1.034.994-2.118 2.033-2.814 3.633-.018.041-.052.055-.075.065q-.013.004-.02.01a.34.34 0 0 1-.226.084.34.34 0 0 1-.224-.086l-.092-.077c-.699-1.615-1.768-2.669-2.781-3.67-1.454-1.435-2.797-2.762-2.78-5.478.02-3.067 2.7-5.545 5.975-5.523m-.02 2.826c-1.62-.01-2.944 1.315-2.955 2.96-.01 1.646 1.295 2.988 2.916 2.999h.002c1.621.01 2.943-1.316 2.953-2.961.011-1.646-1.294-2.988-2.916-2.998m-.005 1.1c1.017.006 1.829.83 1.822 1.89s-.83 1.874-1.848 1.867c-1.018-.006-1.829-.83-1.822-1.89s.83-1.874 1.848-1.868m-2.155 11.857 4.14.025c.271.002.49.305.487.676l-.013 1.875c-.003.37-.224.67-.495.668l-4.14-.025c-.27-.002-.487-.306-.485-.676l.012-1.875c.003-.37.224-.67.494-.668' style='color:%23000;font-style:normal;font-variant:normal;font-weight:400;font-stretch:normal;font-size:medium;line-height:normal;font-family:sans-serif;font-variant-ligatures:normal;font-variant-position:normal;font-variant-caps:normal;font-variant-numeric:normal;font-variant-alternates:normal;font-feature-settings:normal;text-indent:0;text-align:start;text-decoration:none;text-decoration-line:none;text-decoration-style:solid;text-decoration-color:%23000;letter-spacing:normal;word-spacing:normal;text-transform:none;writing-mode:lr-tb;direction:ltr;text-orientation:mixed;dominant-baseline:auto;baseline-shift:baseline;text-anchor:start;white-space:normal;shape-padding:0;clip-rule:evenodd;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:%23000;solid-opacity:1;vector-effect:none;fill:%23000;fill-opacity:.4;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto' transform='translate(15.553 2.85) scale(.88807)'/%3E%3Cpath d='M-9.415-.316C-12.69-.338-15.37 2.14-15.39 5.207c-.017 2.716 1.326 4.041 2.78 5.477 1.013 1 2.081 2.055 2.78 3.67l.092.076a.34.34 0 0 0 .225.086.34.34 0 0 0 .227-.083l.019-.01c.022-.009.057-.024.074-.064.697-1.6 1.78-2.64 2.814-3.634 1.473-1.414 2.847-2.733 2.864-5.44.02-3.067-2.627-5.58-5.901-5.601m-.057 8.784c1.621.011 2.944-1.315 2.955-2.96.01-1.646-1.295-2.988-2.916-2.999-1.622-.01-2.945 1.315-2.955 2.96s1.295 2.989 2.916 3' style='clip-rule:evenodd;fill:%23e1e3e9;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:.4' transform='translate(15.553 2.85) scale(.88807)'/%3E%3Cpath d='M-11.594 15.465c-.27-.002-.492.297-.494.668l-.012 1.876c-.003.371.214.673.485.675l4.14.027c.271.002.492-.298.495-.668l.012-1.877c.003-.37-.215-.672-.485-.674z' style='clip-rule:evenodd;fill:%23fff;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:.4' transform='translate(15.553 2.85) scale(.88807)'/%3E%3C/g%3E%3C/svg%3E");background-repeat:no-repeat;cursor:pointer;display:block;height:23px;margin:0 0 -4px -4px;overflow:hidden;width:88px}a.maplibregl-ctrl-logo.maplibregl-compact{width:14px}@media (forced-colors:active){a.maplibregl-ctrl-logo{background-color:initial;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='88' height='23' fill='none'%3E%3Cpath fill='%23000' fill-opacity='.4' fill-rule='evenodd' d='M17.408 16.796h-1.827l2.501-12.095h.198l3.324 6.533.988 2.19.988-2.19 3.258-6.533h.181l2.6 12.095h-1.81l-1.218-5.644-.362-1.71-.658 1.71-2.929 5.644h-.098l-2.914-5.644-.757-1.71-.345 1.71zm1.958-3.42-.726 3.663a1.255 1.255 0 0 1-1.232 1.011h-1.827a1.255 1.255 0 0 1-1.229-1.509l2.501-12.095a1.255 1.255 0 0 1 1.23-1.001h.197a1.25 1.25 0 0 1 1.12.685l3.19 6.273 3.125-6.263a1.25 1.25 0 0 1 1.123-.695h.181a1.255 1.255 0 0 1 1.227.991l1.443 6.71a5 5 0 0 1 .314-.787l.009-.016a4.6 4.6 0 0 1 1.777-1.887c.782-.46 1.668-.667 2.611-.667a4.6 4.6 0 0 1 1.7.32l.306.134c.21-.16.474-.256.759-.256h1.694a1.255 1.255 0 0 1 1.212.925 1.255 1.255 0 0 1 1.212-.925h1.711c.284 0 .545.094.755.252.613-.3 1.312-.45 2.075-.45 1.356 0 2.557.445 3.482 1.4q.47.48.763 1.064V4.701a1.255 1.255 0 0 1 1.255-1.255h1.86A1.255 1.255 0 0 1 54.44 4.7v9.194h2.217c.19 0 .37.043.532.118v-4.77c0-.356.147-.678.385-.906a2.42 2.42 0 0 1-.682-1.71c0-.665.267-1.253.735-1.7a2.45 2.45 0 0 1 1.722-.674 2.43 2.43 0 0 1 1.705.675q.318.302.504.683V4.7a1.255 1.255 0 0 1 1.255-1.255h1.744A1.255 1.255 0 0 1 65.812 4.7v3.335a4.8 4.8 0 0 1 1.526-.246c.938 0 1.817.214 2.59.69a4.47 4.47 0 0 1 1.67 1.743v-.98a1.255 1.255 0 0 1 1.256-1.256h1.777c.233 0 .451.064.639.174a3.4 3.4 0 0 1 1.567-.372c.346 0 .861.02 1.285.232a1.25 1.25 0 0 1 .689 1.004 4.7 4.7 0 0 1 .853-.588c.795-.44 1.675-.647 2.61-.647 1.385 0 2.65.39 3.525 1.396.836.938 1.168 2.173 1.168 3.528q-.001.515-.056 1.051a1.255 1.255 0 0 1-.947 1.09l.408.952a1.255 1.255 0 0 1-.477 1.552c-.418.268-.92.463-1.458.612-.613.171-1.304.244-2.049.244-1.06 0-2.043-.207-2.886-.698l-.015-.008c-.798-.48-1.419-1.135-1.818-1.963l-.004-.008a5.8 5.8 0 0 1-.548-2.512q0-.429.053-.843a1.3 1.3 0 0 1-.333-.086l-.166-.004c-.223 0-.426.062-.643.228-.03.024-.142.139-.142.59v3.883a1.255 1.255 0 0 1-1.256 1.256h-1.777a1.255 1.255 0 0 1-1.256-1.256V15.69l-.032.057a4.8 4.8 0 0 1-1.86 1.833 5.04 5.04 0 0 1-2.484.634 4.5 4.5 0 0 1-1.935-.424 1.25 1.25 0 0 1-.764.258h-1.71a1.255 1.255 0 0 1-1.256-1.255V7.687a2.4 2.4 0 0 1-.428.625c.253.23.412.561.412.93v7.553a1.255 1.255 0 0 1-1.256 1.255h-1.843a1.25 1.25 0 0 1-.894-.373c-.228.23-.544.373-.894.373H51.32a1.255 1.255 0 0 1-1.256-1.255v-1.251l-.061.117a4.7 4.7 0 0 1-1.782 1.884 4.77 4.77 0 0 1-2.485.67 5.6 5.6 0 0 1-1.485-.188l.009 2.764a1.255 1.255 0 0 1-1.255 1.259h-1.729a1.255 1.255 0 0 1-1.255-1.255v-3.537a1.255 1.255 0 0 1-1.167.793h-1.679a1.25 1.25 0 0 1-.77-.263 4.5 4.5 0 0 1-1.945.429c-.885 0-1.724-.21-2.495-.632l-.017-.01a5 5 0 0 1-1.081-.836 1.255 1.255 0 0 1-1.254 1.312h-1.81a1.255 1.255 0 0 1-1.228-.99l-.782-3.625-2.044 3.939a1.25 1.25 0 0 1-1.115.676h-.098a1.25 1.25 0 0 1-1.116-.68l-2.061-3.994zM35.92 16.63l.207-.114.223-.15q.493-.356.735-.785l.061-.118.033 1.332h1.678V9.242h-1.694l-.033 1.267q-.133-.329-.526-.658l-.032-.028a3.2 3.2 0 0 0-.668-.428l-.27-.12a3.3 3.3 0 0 0-1.235-.23q-1.136-.001-1.974.493a3.36 3.36 0 0 0-1.3 1.382q-.445.89-.444 2.074 0 1.2.51 2.107a3.8 3.8 0 0 0 1.382 1.381 3.9 3.9 0 0 0 1.893.477q.795 0 1.455-.33zm-2.789-5.38q-.576.675-.575 1.762 0 1.102.559 1.794.576.675 1.645.675a2.25 2.25 0 0 0 .934-.19 2.2 2.2 0 0 0 .468-.29l.178-.161a2.2 2.2 0 0 0 .397-.561q.244-.5.244-1.15v-.115q0-.708-.296-1.267l-.043-.077a2.2 2.2 0 0 0-.633-.709l-.13-.086-.047-.028a2.1 2.1 0 0 0-1.073-.285q-1.052 0-1.629.692zm2.316 2.706c.163-.17.28-.407.28-.83v-.114c0-.292-.06-.508-.15-.68a.96.96 0 0 0-.353-.389.85.85 0 0 0-.464-.127c-.4 0-.56.114-.664.239l-.01.012c-.148.174-.275.45-.275.945 0 .506.122.801.27.99.097.11.266.224.68.224.303 0 .504-.09.687-.269zm7.545 1.705a2.6 2.6 0 0 0 .331.423q.319.33.755.548l.173.074q.65.255 1.49.255 1.02 0 1.844-.493a3.45 3.45 0 0 0 1.316-1.4q.493-.904.493-2.089 0-1.909-.988-2.913-.988-1.02-2.584-1.02-.898 0-1.575.347a3 3 0 0 0-.415.262l-.199.166a3.4 3.4 0 0 0-.64.82V9.242h-1.712v11.553h1.729l-.017-5.134zm.53-1.138q.206.29.48.5l.155.11.053.034q.51.296 1.119.297 1.07 0 1.645-.675.577-.69.576-1.762 0-1.119-.576-1.777-.558-.675-1.645-.675-.435 0-.835.16a2 2 0 0 0-.284.136 2 2 0 0 0-.363.254 2.2 2.2 0 0 0-.46.569l-.082.162a2.6 2.6 0 0 0-.213 1.072v.115q0 .707.296 1.267l.135.211zm.964-.818a1.1 1.1 0 0 0 .367.385.94.94 0 0 0 .476.118c.423 0 .59-.117.687-.23.159-.194.28-.478.28-.95 0-.53-.133-.8-.266-.952l-.021-.025c-.078-.094-.231-.221-.68-.221a1 1 0 0 0-.503.135l-.012.007a.86.86 0 0 0-.335.343c-.073.133-.132.324-.132.614v.115a1.4 1.4 0 0 0 .14.66zm15.7-6.222q.347-.346.346-.856a1.05 1.05 0 0 0-.345-.79 1.18 1.18 0 0 0-.84-.329q-.51 0-.855.33a1.05 1.05 0 0 0-.346.79q0 .51.346.855.345.346.856.346.51 0 .839-.346zm4.337 9.314.033-1.332q.191.403.59.747l.098.081a4 4 0 0 0 .316.224l.223.122a3.2 3.2 0 0 0 1.44.322 3.8 3.8 0 0 0 1.875-.477 3.5 3.5 0 0 0 1.382-1.366q.527-.89.526-2.09 0-1.184-.444-2.073a3.24 3.24 0 0 0-1.283-1.399q-.823-.51-1.942-.51a3.5 3.5 0 0 0-1.527.344l-.086.043-.165.09a3 3 0 0 0-.33.214q-.432.315-.656.707a2 2 0 0 0-.099.198l.082-1.283V4.701h-1.744v12.095zm.473-2.509a2.5 2.5 0 0 0 .566.7q.117.098.245.18l.144.08a2.1 2.1 0 0 0 .975.232q1.07 0 1.645-.675.576-.69.576-1.778 0-1.102-.576-1.777-.56-.691-1.645-.692a2.2 2.2 0 0 0-1.015.235q-.22.113-.415.282l-.15.142a2.1 2.1 0 0 0-.42.594q-.223.479-.223 1.1v.115q0 .705.293 1.26zm2.616-.293c.157-.191.28-.479.28-.967 0-.51-.13-.79-.276-.961l-.021-.026c-.082-.1-.232-.225-.67-.225a.87.87 0 0 0-.681.279l-.012.011c-.154.155-.274.38-.274.807v.115c0 .285.057.499.144.669a1.1 1.1 0 0 0 .367.405c.137.082.28.123.455.123.423 0 .59-.118.686-.23zm8.266-3.013q.345-.13.724-.14l.069-.002q.493 0 .642.099l.247-1.794q-.196-.099-.717-.099a2.3 2.3 0 0 0-.545.063 2 2 0 0 0-.411.148 2.2 2.2 0 0 0-.4.249 2.5 2.5 0 0 0-.485.499 2.7 2.7 0 0 0-.32.581l-.05.137v-1.48h-1.778v7.553h1.777v-3.884q0-.546.159-.943a1.5 1.5 0 0 1 .466-.636 2.5 2.5 0 0 1 .399-.253 2 2 0 0 1 .224-.099zm9.784 2.656.05-.922q0-1.743-.856-2.698-.838-.97-2.584-.97-1.119-.001-2.007.493a3.46 3.46 0 0 0-1.4 1.382q-.493.906-.493 2.106 0 1.07.428 1.975.428.89 1.332 1.432.906.526 2.255.526.973 0 1.668-.185l.044-.012.135-.04q.613-.184.984-.421l-.542-1.267q-.3.162-.642.274l-.297.087q-.51.131-1.3.131-.954 0-1.497-.444a1.6 1.6 0 0 1-.192-.193q-.366-.44-.512-1.234l-.004-.021zm-5.427-1.256-.003.022h3.752v-.138q-.011-.727-.288-1.118a1 1 0 0 0-.156-.176q-.46-.428-1.316-.428-.986 0-1.494.604-.379.45-.494 1.234zm-27.053 2.77V4.7h-1.86v12.095h5.333V15.15zm7.103-5.908v7.553h-1.843V9.242h1.843z'/%3E%3Cpath fill='%23fff' d='m19.63 11.151-.757-1.71-.345 1.71-1.12 5.644h-1.827L18.083 4.7h.197l3.325 6.533.988 2.19.988-2.19L26.839 4.7h.181l2.6 12.095h-1.81l-1.218-5.644-.362-1.71-.658 1.71-2.93 5.644h-.098l-2.913-5.644zm14.836 5.81q-1.02 0-1.893-.478a3.8 3.8 0 0 1-1.381-1.382q-.51-.906-.51-2.106 0-1.185.444-2.074a3.36 3.36 0 0 1 1.3-1.382q.839-.494 1.974-.494a3.3 3.3 0 0 1 1.234.231 3.3 3.3 0 0 1 .97.575q.396.33.527.659l.033-1.267h1.694v7.553H37.18l-.033-1.332q-.279.593-1.02 1.053a3.17 3.17 0 0 1-1.662.444zm.296-1.482q.938 0 1.58-.642.642-.66.642-1.711v-.115q0-.708-.296-1.267a2.2 2.2 0 0 0-.807-.872 2.1 2.1 0 0 0-1.119-.313q-1.053 0-1.629.692-.575.675-.575 1.76 0 1.103.559 1.795.577.675 1.645.675zm6.521-6.237h1.711v1.4q.906-1.597 2.83-1.597 1.596 0 2.584 1.02.988 1.005.988 2.914 0 1.185-.493 2.09a3.46 3.46 0 0 1-1.316 1.399 3.5 3.5 0 0 1-1.844.493q-.954 0-1.662-.329a2.67 2.67 0 0 1-1.086-.97l.017 5.134h-1.728zm4.048 6.22q1.07 0 1.645-.674.577-.69.576-1.762 0-1.119-.576-1.777-.558-.675-1.645-.675-.592 0-1.12.296-.51.28-.822.823-.296.527-.296 1.234v.115q0 .708.296 1.267.313.543.823.855.51.296 1.119.297z'/%3E%3Cpath fill='%23e1e3e9' d='M51.325 4.7h1.86v10.45h3.473v1.646h-5.333zm7.12 4.542h1.843v7.553h-1.843zm.905-1.415a1.16 1.16 0 0 1-.856-.346 1.17 1.17 0 0 1-.346-.856 1.05 1.05 0 0 1 .346-.79q.346-.329.856-.329.494 0 .839.33a1.05 1.05 0 0 1 .345.79 1.16 1.16 0 0 1-.345.855q-.33.346-.84.346zm7.875 9.133a3.17 3.17 0 0 1-1.662-.444q-.723-.46-1.004-1.053l-.033 1.332h-1.71V4.701h1.743v4.657l-.082 1.283q.279-.658 1.086-1.119a3.5 3.5 0 0 1 1.778-.477q1.119 0 1.942.51a3.24 3.24 0 0 1 1.283 1.4q.445.888.444 2.072 0 1.201-.526 2.09a3.5 3.5 0 0 1-1.382 1.366 3.8 3.8 0 0 1-1.876.477zm-.296-1.481q1.069 0 1.645-.675.577-.69.577-1.778 0-1.102-.577-1.776-.56-.691-1.645-.692a2.12 2.12 0 0 0-1.58.659q-.642.641-.642 1.694v.115q0 .71.296 1.267a2.4 2.4 0 0 0 .807.872 2.1 2.1 0 0 0 1.119.313zm5.927-6.237h1.777v1.481q.263-.757.856-1.217a2.14 2.14 0 0 1 1.349-.46q.527 0 .724.098l-.247 1.794q-.149-.099-.642-.099-.774 0-1.416.494-.626.493-.626 1.58v3.883h-1.777V9.242zm9.534 7.718q-1.35 0-2.255-.526-.904-.543-1.332-1.432a4.6 4.6 0 0 1-.428-1.975q0-1.2.493-2.106a3.46 3.46 0 0 1 1.4-1.382q.889-.495 2.007-.494 1.744 0 2.584.97.855.956.856 2.7 0 .444-.05.92h-5.43q.18 1.005.708 1.45.542.443 1.497.443.79 0 1.3-.131a4 4 0 0 0 .938-.362l.542 1.267q-.411.263-1.119.46-.708.198-1.711.197zm1.596-4.558q.016-1.02-.444-1.432-.46-.428-1.316-.428-1.728 0-1.991 1.86z'/%3E%3Cpath d='M5.074 15.948a.484.657 0 0 0-.486.659v1.84a.484.657 0 0 0 .486.659h4.101a.484.657 0 0 0 .486-.659v-1.84a.484.657 0 0 0-.486-.659zm3.56 1.16H5.617v.838h3.017z' style='fill:%23fff;fill-rule:evenodd;stroke-width:1.03600001'/%3E%3Cg style='stroke-width:1.12603545'%3E%3Cpath d='M-9.408-1.416c-3.833-.025-7.056 2.912-7.08 6.615-.02 3.08 1.653 4.832 3.107 6.268.903.892 1.721 1.74 2.32 2.902l-.525-.004c-.543-.003-.992.304-1.24.639a1.87 1.87 0 0 0-.362 1.121l-.011 1.877c-.003.402.104.787.347 1.125.244.338.688.653 1.23.656l4.142.028c.542.003.99-.306 1.238-.641a1.87 1.87 0 0 0 .363-1.121l.012-1.875a1.87 1.87 0 0 0-.348-1.127c-.243-.338-.688-.653-1.23-.656l-.518-.004c.597-1.145 1.425-1.983 2.348-2.87 1.473-1.414 3.18-3.149 3.2-6.226-.016-3.59-2.923-6.684-6.993-6.707m-.006 1.1v.002c3.274.02 5.92 2.532 5.9 5.6-.017 2.706-1.39 4.026-2.863 5.44-1.034.994-2.118 2.033-2.814 3.633-.018.041-.052.055-.075.065q-.013.004-.02.01a.34.34 0 0 1-.226.084.34.34 0 0 1-.224-.086l-.092-.077c-.699-1.615-1.768-2.669-2.781-3.67-1.454-1.435-2.797-2.762-2.78-5.478.02-3.067 2.7-5.545 5.975-5.523m-.02 2.826c-1.62-.01-2.944 1.315-2.955 2.96-.01 1.646 1.295 2.988 2.916 2.999h.002c1.621.01 2.943-1.316 2.953-2.961.011-1.646-1.294-2.988-2.916-2.998m-.005 1.1c1.017.006 1.829.83 1.822 1.89s-.83 1.874-1.848 1.867c-1.018-.006-1.829-.83-1.822-1.89s.83-1.874 1.848-1.868m-2.155 11.857 4.14.025c.271.002.49.305.487.676l-.013 1.875c-.003.37-.224.67-.495.668l-4.14-.025c-.27-.002-.487-.306-.485-.676l.012-1.875c.003-.37.224-.67.494-.668' style='color:%23000;font-style:normal;font-variant:normal;font-weight:400;font-stretch:normal;font-size:medium;line-height:normal;font-family:sans-serif;font-variant-ligatures:normal;font-variant-position:normal;font-variant-caps:normal;font-variant-numeric:normal;font-variant-alternates:normal;font-feature-settings:normal;text-indent:0;text-align:start;text-decoration:none;text-decoration-line:none;text-decoration-style:solid;text-decoration-color:%23000;letter-spacing:normal;word-spacing:normal;text-transform:none;writing-mode:lr-tb;direction:ltr;text-orientation:mixed;dominant-baseline:auto;baseline-shift:baseline;text-anchor:start;white-space:normal;shape-padding:0;clip-rule:evenodd;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:%23000;solid-opacity:1;vector-effect:none;fill:%23000;fill-opacity:.4;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto' transform='translate(15.553 2.85) scale(.88807)'/%3E%3Cpath d='M-9.415-.316C-12.69-.338-15.37 2.14-15.39 5.207c-.017 2.716 1.326 4.041 2.78 5.477 1.013 1 2.081 2.055 2.78 3.67l.092.076a.34.34 0 0 0 .225.086.34.34 0 0 0 .227-.083l.019-.01c.022-.009.057-.024.074-.064.697-1.6 1.78-2.64 2.814-3.634 1.473-1.414 2.847-2.733 2.864-5.44.02-3.067-2.627-5.58-5.901-5.601m-.057 8.784c1.621.011 2.944-1.315 2.955-2.96.01-1.646-1.295-2.988-2.916-2.999-1.622-.01-2.945 1.315-2.955 2.96s1.295 2.989 2.916 3' style='clip-rule:evenodd;fill:%23e1e3e9;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:.4' transform='translate(15.553 2.85) scale(.88807)'/%3E%3Cpath d='M-11.594 15.465c-.27-.002-.492.297-.494.668l-.012 1.876c-.003.371.214.673.485.675l4.14.027c.271.002.492-.298.495-.668l.012-1.877c.003-.37-.215-.672-.485-.674z' style='clip-rule:evenodd;fill:%23fff;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:.4' transform='translate(15.553 2.85) scale(.88807)'/%3E%3C/g%3E%3C/svg%3E")}}@media (forced-colors:active) and (prefers-color-scheme:light){a.maplibregl-ctrl-logo{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='88' height='23' fill='none'%3E%3Cpath fill='%23000' fill-opacity='.4' fill-rule='evenodd' d='M17.408 16.796h-1.827l2.501-12.095h.198l3.324 6.533.988 2.19.988-2.19 3.258-6.533h.181l2.6 12.095h-1.81l-1.218-5.644-.362-1.71-.658 1.71-2.929 5.644h-.098l-2.914-5.644-.757-1.71-.345 1.71zm1.958-3.42-.726 3.663a1.255 1.255 0 0 1-1.232 1.011h-1.827a1.255 1.255 0 0 1-1.229-1.509l2.501-12.095a1.255 1.255 0 0 1 1.23-1.001h.197a1.25 1.25 0 0 1 1.12.685l3.19 6.273 3.125-6.263a1.25 1.25 0 0 1 1.123-.695h.181a1.255 1.255 0 0 1 1.227.991l1.443 6.71a5 5 0 0 1 .314-.787l.009-.016a4.6 4.6 0 0 1 1.777-1.887c.782-.46 1.668-.667 2.611-.667a4.6 4.6 0 0 1 1.7.32l.306.134c.21-.16.474-.256.759-.256h1.694a1.255 1.255 0 0 1 1.212.925 1.255 1.255 0 0 1 1.212-.925h1.711c.284 0 .545.094.755.252.613-.3 1.312-.45 2.075-.45 1.356 0 2.557.445 3.482 1.4q.47.48.763 1.064V4.701a1.255 1.255 0 0 1 1.255-1.255h1.86A1.255 1.255 0 0 1 54.44 4.7v9.194h2.217c.19 0 .37.043.532.118v-4.77c0-.356.147-.678.385-.906a2.42 2.42 0 0 1-.682-1.71c0-.665.267-1.253.735-1.7a2.45 2.45 0 0 1 1.722-.674 2.43 2.43 0 0 1 1.705.675q.318.302.504.683V4.7a1.255 1.255 0 0 1 1.255-1.255h1.744A1.255 1.255 0 0 1 65.812 4.7v3.335a4.8 4.8 0 0 1 1.526-.246c.938 0 1.817.214 2.59.69a4.47 4.47 0 0 1 1.67 1.743v-.98a1.255 1.255 0 0 1 1.256-1.256h1.777c.233 0 .451.064.639.174a3.4 3.4 0 0 1 1.567-.372c.346 0 .861.02 1.285.232a1.25 1.25 0 0 1 .689 1.004 4.7 4.7 0 0 1 .853-.588c.795-.44 1.675-.647 2.61-.647 1.385 0 2.65.39 3.525 1.396.836.938 1.168 2.173 1.168 3.528q-.001.515-.056 1.051a1.255 1.255 0 0 1-.947 1.09l.408.952a1.255 1.255 0 0 1-.477 1.552c-.418.268-.92.463-1.458.612-.613.171-1.304.244-2.049.244-1.06 0-2.043-.207-2.886-.698l-.015-.008c-.798-.48-1.419-1.135-1.818-1.963l-.004-.008a5.8 5.8 0 0 1-.548-2.512q0-.429.053-.843a1.3 1.3 0 0 1-.333-.086l-.166-.004c-.223 0-.426.062-.643.228-.03.024-.142.139-.142.59v3.883a1.255 1.255 0 0 1-1.256 1.256h-1.777a1.255 1.255 0 0 1-1.256-1.256V15.69l-.032.057a4.8 4.8 0 0 1-1.86 1.833 5.04 5.04 0 0 1-2.484.634 4.5 4.5 0 0 1-1.935-.424 1.25 1.25 0 0 1-.764.258h-1.71a1.255 1.255 0 0 1-1.256-1.255V7.687a2.4 2.4 0 0 1-.428.625c.253.23.412.561.412.93v7.553a1.255 1.255 0 0 1-1.256 1.255h-1.843a1.25 1.25 0 0 1-.894-.373c-.228.23-.544.373-.894.373H51.32a1.255 1.255 0 0 1-1.256-1.255v-1.251l-.061.117a4.7 4.7 0 0 1-1.782 1.884 4.77 4.77 0 0 1-2.485.67 5.6 5.6 0 0 1-1.485-.188l.009 2.764a1.255 1.255 0 0 1-1.255 1.259h-1.729a1.255 1.255 0 0 1-1.255-1.255v-3.537a1.255 1.255 0 0 1-1.167.793h-1.679a1.25 1.25 0 0 1-.77-.263 4.5 4.5 0 0 1-1.945.429c-.885 0-1.724-.21-2.495-.632l-.017-.01a5 5 0 0 1-1.081-.836 1.255 1.255 0 0 1-1.254 1.312h-1.81a1.255 1.255 0 0 1-1.228-.99l-.782-3.625-2.044 3.939a1.25 1.25 0 0 1-1.115.676h-.098a1.25 1.25 0 0 1-1.116-.68l-2.061-3.994zM35.92 16.63l.207-.114.223-.15q.493-.356.735-.785l.061-.118.033 1.332h1.678V9.242h-1.694l-.033 1.267q-.133-.329-.526-.658l-.032-.028a3.2 3.2 0 0 0-.668-.428l-.27-.12a3.3 3.3 0 0 0-1.235-.23q-1.136-.001-1.974.493a3.36 3.36 0 0 0-1.3 1.382q-.445.89-.444 2.074 0 1.2.51 2.107a3.8 3.8 0 0 0 1.382 1.381 3.9 3.9 0 0 0 1.893.477q.795 0 1.455-.33zm-2.789-5.38q-.576.675-.575 1.762 0 1.102.559 1.794.576.675 1.645.675a2.25 2.25 0 0 0 .934-.19 2.2 2.2 0 0 0 .468-.29l.178-.161a2.2 2.2 0 0 0 .397-.561q.244-.5.244-1.15v-.115q0-.708-.296-1.267l-.043-.077a2.2 2.2 0 0 0-.633-.709l-.13-.086-.047-.028a2.1 2.1 0 0 0-1.073-.285q-1.052 0-1.629.692zm2.316 2.706c.163-.17.28-.407.28-.83v-.114c0-.292-.06-.508-.15-.68a.96.96 0 0 0-.353-.389.85.85 0 0 0-.464-.127c-.4 0-.56.114-.664.239l-.01.012c-.148.174-.275.45-.275.945 0 .506.122.801.27.99.097.11.266.224.68.224.303 0 .504-.09.687-.269zm7.545 1.705a2.6 2.6 0 0 0 .331.423q.319.33.755.548l.173.074q.65.255 1.49.255 1.02 0 1.844-.493a3.45 3.45 0 0 0 1.316-1.4q.493-.904.493-2.089 0-1.909-.988-2.913-.988-1.02-2.584-1.02-.898 0-1.575.347a3 3 0 0 0-.415.262l-.199.166a3.4 3.4 0 0 0-.64.82V9.242h-1.712v11.553h1.729l-.017-5.134zm.53-1.138q.206.29.48.5l.155.11.053.034q.51.296 1.119.297 1.07 0 1.645-.675.577-.69.576-1.762 0-1.119-.576-1.777-.558-.675-1.645-.675-.435 0-.835.16a2 2 0 0 0-.284.136 2 2 0 0 0-.363.254 2.2 2.2 0 0 0-.46.569l-.082.162a2.6 2.6 0 0 0-.213 1.072v.115q0 .707.296 1.267l.135.211zm.964-.818a1.1 1.1 0 0 0 .367.385.94.94 0 0 0 .476.118c.423 0 .59-.117.687-.23.159-.194.28-.478.28-.95 0-.53-.133-.8-.266-.952l-.021-.025c-.078-.094-.231-.221-.68-.221a1 1 0 0 0-.503.135l-.012.007a.86.86 0 0 0-.335.343c-.073.133-.132.324-.132.614v.115a1.4 1.4 0 0 0 .14.66zm15.7-6.222q.347-.346.346-.856a1.05 1.05 0 0 0-.345-.79 1.18 1.18 0 0 0-.84-.329q-.51 0-.855.33a1.05 1.05 0 0 0-.346.79q0 .51.346.855.345.346.856.346.51 0 .839-.346zm4.337 9.314.033-1.332q.191.403.59.747l.098.081a4 4 0 0 0 .316.224l.223.122a3.2 3.2 0 0 0 1.44.322 3.8 3.8 0 0 0 1.875-.477 3.5 3.5 0 0 0 1.382-1.366q.527-.89.526-2.09 0-1.184-.444-2.073a3.24 3.24 0 0 0-1.283-1.399q-.823-.51-1.942-.51a3.5 3.5 0 0 0-1.527.344l-.086.043-.165.09a3 3 0 0 0-.33.214q-.432.315-.656.707a2 2 0 0 0-.099.198l.082-1.283V4.701h-1.744v12.095zm.473-2.509a2.5 2.5 0 0 0 .566.7q.117.098.245.18l.144.08a2.1 2.1 0 0 0 .975.232q1.07 0 1.645-.675.576-.69.576-1.778 0-1.102-.576-1.777-.56-.691-1.645-.692a2.2 2.2 0 0 0-1.015.235q-.22.113-.415.282l-.15.142a2.1 2.1 0 0 0-.42.594q-.223.479-.223 1.1v.115q0 .705.293 1.26zm2.616-.293c.157-.191.28-.479.28-.967 0-.51-.13-.79-.276-.961l-.021-.026c-.082-.1-.232-.225-.67-.225a.87.87 0 0 0-.681.279l-.012.011c-.154.155-.274.38-.274.807v.115c0 .285.057.499.144.669a1.1 1.1 0 0 0 .367.405c.137.082.28.123.455.123.423 0 .59-.118.686-.23zm8.266-3.013q.345-.13.724-.14l.069-.002q.493 0 .642.099l.247-1.794q-.196-.099-.717-.099a2.3 2.3 0 0 0-.545.063 2 2 0 0 0-.411.148 2.2 2.2 0 0 0-.4.249 2.5 2.5 0 0 0-.485.499 2.7 2.7 0 0 0-.32.581l-.05.137v-1.48h-1.778v7.553h1.777v-3.884q0-.546.159-.943a1.5 1.5 0 0 1 .466-.636 2.5 2.5 0 0 1 .399-.253 2 2 0 0 1 .224-.099zm9.784 2.656.05-.922q0-1.743-.856-2.698-.838-.97-2.584-.97-1.119-.001-2.007.493a3.46 3.46 0 0 0-1.4 1.382q-.493.906-.493 2.106 0 1.07.428 1.975.428.89 1.332 1.432.906.526 2.255.526.973 0 1.668-.185l.044-.012.135-.04q.613-.184.984-.421l-.542-1.267q-.3.162-.642.274l-.297.087q-.51.131-1.3.131-.954 0-1.497-.444a1.6 1.6 0 0 1-.192-.193q-.366-.44-.512-1.234l-.004-.021zm-5.427-1.256-.003.022h3.752v-.138q-.011-.727-.288-1.118a1 1 0 0 0-.156-.176q-.46-.428-1.316-.428-.986 0-1.494.604-.379.45-.494 1.234zm-27.053 2.77V4.7h-1.86v12.095h5.333V15.15zm7.103-5.908v7.553h-1.843V9.242h1.843z'/%3E%3Cpath fill='%23fff' d='m19.63 11.151-.757-1.71-.345 1.71-1.12 5.644h-1.827L18.083 4.7h.197l3.325 6.533.988 2.19.988-2.19L26.839 4.7h.181l2.6 12.095h-1.81l-1.218-5.644-.362-1.71-.658 1.71-2.93 5.644h-.098l-2.913-5.644zm14.836 5.81q-1.02 0-1.893-.478a3.8 3.8 0 0 1-1.381-1.382q-.51-.906-.51-2.106 0-1.185.444-2.074a3.36 3.36 0 0 1 1.3-1.382q.839-.494 1.974-.494a3.3 3.3 0 0 1 1.234.231 3.3 3.3 0 0 1 .97.575q.396.33.527.659l.033-1.267h1.694v7.553H37.18l-.033-1.332q-.279.593-1.02 1.053a3.17 3.17 0 0 1-1.662.444zm.296-1.482q.938 0 1.58-.642.642-.66.642-1.711v-.115q0-.708-.296-1.267a2.2 2.2 0 0 0-.807-.872 2.1 2.1 0 0 0-1.119-.313q-1.053 0-1.629.692-.575.675-.575 1.76 0 1.103.559 1.795.577.675 1.645.675zm6.521-6.237h1.711v1.4q.906-1.597 2.83-1.597 1.596 0 2.584 1.02.988 1.005.988 2.914 0 1.185-.493 2.09a3.46 3.46 0 0 1-1.316 1.399 3.5 3.5 0 0 1-1.844.493q-.954 0-1.662-.329a2.67 2.67 0 0 1-1.086-.97l.017 5.134h-1.728zm4.048 6.22q1.07 0 1.645-.674.577-.69.576-1.762 0-1.119-.576-1.777-.558-.675-1.645-.675-.592 0-1.12.296-.51.28-.822.823-.296.527-.296 1.234v.115q0 .708.296 1.267.313.543.823.855.51.296 1.119.297z'/%3E%3Cpath fill='%23e1e3e9' d='M51.325 4.7h1.86v10.45h3.473v1.646h-5.333zm7.12 4.542h1.843v7.553h-1.843zm.905-1.415a1.16 1.16 0 0 1-.856-.346 1.17 1.17 0 0 1-.346-.856 1.05 1.05 0 0 1 .346-.79q.346-.329.856-.329.494 0 .839.33a1.05 1.05 0 0 1 .345.79 1.16 1.16 0 0 1-.345.855q-.33.346-.84.346zm7.875 9.133a3.17 3.17 0 0 1-1.662-.444q-.723-.46-1.004-1.053l-.033 1.332h-1.71V4.701h1.743v4.657l-.082 1.283q.279-.658 1.086-1.119a3.5 3.5 0 0 1 1.778-.477q1.119 0 1.942.51a3.24 3.24 0 0 1 1.283 1.4q.445.888.444 2.072 0 1.201-.526 2.09a3.5 3.5 0 0 1-1.382 1.366 3.8 3.8 0 0 1-1.876.477zm-.296-1.481q1.069 0 1.645-.675.577-.69.577-1.778 0-1.102-.577-1.776-.56-.691-1.645-.692a2.12 2.12 0 0 0-1.58.659q-.642.641-.642 1.694v.115q0 .71.296 1.267a2.4 2.4 0 0 0 .807.872 2.1 2.1 0 0 0 1.119.313zm5.927-6.237h1.777v1.481q.263-.757.856-1.217a2.14 2.14 0 0 1 1.349-.46q.527 0 .724.098l-.247 1.794q-.149-.099-.642-.099-.774 0-1.416.494-.626.493-.626 1.58v3.883h-1.777V9.242zm9.534 7.718q-1.35 0-2.255-.526-.904-.543-1.332-1.432a4.6 4.6 0 0 1-.428-1.975q0-1.2.493-2.106a3.46 3.46 0 0 1 1.4-1.382q.889-.495 2.007-.494 1.744 0 2.584.97.855.956.856 2.7 0 .444-.05.92h-5.43q.18 1.005.708 1.45.542.443 1.497.443.79 0 1.3-.131a4 4 0 0 0 .938-.362l.542 1.267q-.411.263-1.119.46-.708.198-1.711.197zm1.596-4.558q.016-1.02-.444-1.432-.46-.428-1.316-.428-1.728 0-1.991 1.86z'/%3E%3Cpath d='M5.074 15.948a.484.657 0 0 0-.486.659v1.84a.484.657 0 0 0 .486.659h4.101a.484.657 0 0 0 .486-.659v-1.84a.484.657 0 0 0-.486-.659zm3.56 1.16H5.617v.838h3.017z' style='fill:%23fff;fill-rule:evenodd;stroke-width:1.03600001'/%3E%3Cg style='stroke-width:1.12603545'%3E%3Cpath d='M-9.408-1.416c-3.833-.025-7.056 2.912-7.08 6.615-.02 3.08 1.653 4.832 3.107 6.268.903.892 1.721 1.74 2.32 2.902l-.525-.004c-.543-.003-.992.304-1.24.639a1.87 1.87 0 0 0-.362 1.121l-.011 1.877c-.003.402.104.787.347 1.125.244.338.688.653 1.23.656l4.142.028c.542.003.99-.306 1.238-.641a1.87 1.87 0 0 0 .363-1.121l.012-1.875a1.87 1.87 0 0 0-.348-1.127c-.243-.338-.688-.653-1.23-.656l-.518-.004c.597-1.145 1.425-1.983 2.348-2.87 1.473-1.414 3.18-3.149 3.2-6.226-.016-3.59-2.923-6.684-6.993-6.707m-.006 1.1v.002c3.274.02 5.92 2.532 5.9 5.6-.017 2.706-1.39 4.026-2.863 5.44-1.034.994-2.118 2.033-2.814 3.633-.018.041-.052.055-.075.065q-.013.004-.02.01a.34.34 0 0 1-.226.084.34.34 0 0 1-.224-.086l-.092-.077c-.699-1.615-1.768-2.669-2.781-3.67-1.454-1.435-2.797-2.762-2.78-5.478.02-3.067 2.7-5.545 5.975-5.523m-.02 2.826c-1.62-.01-2.944 1.315-2.955 2.96-.01 1.646 1.295 2.988 2.916 2.999h.002c1.621.01 2.943-1.316 2.953-2.961.011-1.646-1.294-2.988-2.916-2.998m-.005 1.1c1.017.006 1.829.83 1.822 1.89s-.83 1.874-1.848 1.867c-1.018-.006-1.829-.83-1.822-1.89s.83-1.874 1.848-1.868m-2.155 11.857 4.14.025c.271.002.49.305.487.676l-.013 1.875c-.003.37-.224.67-.495.668l-4.14-.025c-.27-.002-.487-.306-.485-.676l.012-1.875c.003-.37.224-.67.494-.668' style='color:%23000;font-style:normal;font-variant:normal;font-weight:400;font-stretch:normal;font-size:medium;line-height:normal;font-family:sans-serif;font-variant-ligatures:normal;font-variant-position:normal;font-variant-caps:normal;font-variant-numeric:normal;font-variant-alternates:normal;font-feature-settings:normal;text-indent:0;text-align:start;text-decoration:none;text-decoration-line:none;text-decoration-style:solid;text-decoration-color:%23000;letter-spacing:normal;word-spacing:normal;text-transform:none;writing-mode:lr-tb;direction:ltr;text-orientation:mixed;dominant-baseline:auto;baseline-shift:baseline;text-anchor:start;white-space:normal;shape-padding:0;clip-rule:evenodd;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:%23000;solid-opacity:1;vector-effect:none;fill:%23000;fill-opacity:.4;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto' transform='translate(15.553 2.85) scale(.88807)'/%3E%3Cpath d='M-9.415-.316C-12.69-.338-15.37 2.14-15.39 5.207c-.017 2.716 1.326 4.041 2.78 5.477 1.013 1 2.081 2.055 2.78 3.67l.092.076a.34.34 0 0 0 .225.086.34.34 0 0 0 .227-.083l.019-.01c.022-.009.057-.024.074-.064.697-1.6 1.78-2.64 2.814-3.634 1.473-1.414 2.847-2.733 2.864-5.44.02-3.067-2.627-5.58-5.901-5.601m-.057 8.784c1.621.011 2.944-1.315 2.955-2.96.01-1.646-1.295-2.988-2.916-2.999-1.622-.01-2.945 1.315-2.955 2.96s1.295 2.989 2.916 3' style='clip-rule:evenodd;fill:%23e1e3e9;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:.4' transform='translate(15.553 2.85) scale(.88807)'/%3E%3Cpath d='M-11.594 15.465c-.27-.002-.492.297-.494.668l-.012 1.876c-.003.371.214.673.485.675l4.14.027c.271.002.492-.298.495-.668l.012-1.877c.003-.37-.215-.672-.485-.674z' style='clip-rule:evenodd;fill:%23fff;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:.4' transform='translate(15.553 2.85) scale(.88807)'/%3E%3C/g%3E%3C/svg%3E")}}.maplibregl-ctrl.maplibregl-ctrl-attrib{background-color:#ffffff80;margin:0;padding:0 5px}@media screen{.maplibregl-ctrl-attrib.maplibregl-compact{background-color:#fff;border-radius:12px;box-sizing:initial;color:#000;margin:10px;min-height:20px;padding:2px 24px 2px 0;position:relative}.maplibregl-ctrl-attrib.maplibregl-compact-show{padding:2px 28px 2px 8px;visibility:visible}.maplibregl-ctrl-bottom-left>.maplibregl-ctrl-attrib.maplibregl-compact-show,.maplibregl-ctrl-top-left>.maplibregl-ctrl-attrib.maplibregl-compact-show{border-radius:12px;padding:2px 8px 2px 28px}.maplibregl-ctrl-attrib.maplibregl-compact .maplibregl-ctrl-attrib-inner{display:none}.maplibregl-ctrl-attrib-button{background-color:#ffffff80;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill-rule='evenodd' viewBox='0 0 20 20'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E");border:0;border-radius:12px;box-sizing:border-box;cursor:pointer;display:none;height:24px;outline:none;position:absolute;right:0;top:0;width:24px}.maplibregl-ctrl-attrib summary.maplibregl-ctrl-attrib-button{-webkit-appearance:none;appearance:none;list-style:none}.maplibregl-ctrl-attrib summary.maplibregl-ctrl-attrib-button::-webkit-details-marker{display:none}.maplibregl-ctrl-bottom-left .maplibregl-ctrl-attrib-button,.maplibregl-ctrl-top-left .maplibregl-ctrl-attrib-button{left:0}.maplibregl-ctrl-attrib.maplibregl-compact .maplibregl-ctrl-attrib-button,.maplibregl-ctrl-attrib.maplibregl-compact-show .maplibregl-ctrl-attrib-inner{display:block}.maplibregl-ctrl-attrib.maplibregl-compact-show .maplibregl-ctrl-attrib-button{background-color:#0000000d}.maplibregl-ctrl-bottom-right>.maplibregl-ctrl-attrib.maplibregl-compact:after{bottom:0;right:0}.maplibregl-ctrl-top-right>.maplibregl-ctrl-attrib.maplibregl-compact:after{right:0;top:0}.maplibregl-ctrl-top-left>.maplibregl-ctrl-attrib.maplibregl-compact:after{left:0;top:0}.maplibregl-ctrl-bottom-left>.maplibregl-ctrl-attrib.maplibregl-compact:after{bottom:0;left:0}}@media screen and (forced-colors:active){.maplibregl-ctrl-attrib.maplibregl-compact:after{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='%23fff' fill-rule='evenodd' viewBox='0 0 20 20'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E")}}@media screen and (forced-colors:active) and (prefers-color-scheme:light){.maplibregl-ctrl-attrib.maplibregl-compact:after{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill-rule='evenodd' viewBox='0 0 20 20'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E")}}.maplibregl-ctrl-attrib a{color:#000000bf;text-decoration:none}.maplibregl-ctrl-attrib a:hover{color:inherit;text-decoration:underline}.maplibregl-attrib-empty{display:none}.maplibregl-ctrl-scale{background-color:#ffffffbf;border:2px solid #333;border-top:#333;box-sizing:border-box;color:#333;font-size:10px;padding:0 5px}.maplibregl-popup{display:flex;left:0;pointer-events:none;position:absolute;top:0;will-change:transform}.maplibregl-popup-anchor-top,.maplibregl-popup-anchor-top-left,.maplibregl-popup-anchor-top-right{flex-direction:column}.maplibregl-popup-anchor-bottom,.maplibregl-popup-anchor-bottom-left,.maplibregl-popup-anchor-bottom-right{flex-direction:column-reverse}.maplibregl-popup-anchor-left{flex-direction:row}.maplibregl-popup-anchor-right{flex-direction:row-reverse}.maplibregl-popup-tip{border:10px solid #0000;height:0;width:0;z-index:1}.maplibregl-popup-anchor-top .maplibregl-popup-tip{align-self:center;border-bottom-color:#fff;border-top:none}.maplibregl-popup-anchor-top-left .maplibregl-popup-tip{align-self:flex-start;border-bottom-color:#fff;border-left:none;border-top:none}.maplibregl-popup-anchor-top-right .maplibregl-popup-tip{align-self:flex-end;border-bottom-color:#fff;border-right:none;border-top:none}.maplibregl-popup-anchor-bottom .maplibregl-popup-tip{align-self:center;border-bottom:none;border-top-color:#fff}.maplibregl-popup-anchor-bottom-left .maplibregl-popup-tip{align-self:flex-start;border-bottom:none;border-left:none;border-top-color:#fff}.maplibregl-popup-anchor-bottom-right .maplibregl-popup-tip{align-self:flex-end;border-bottom:none;border-right:none;border-top-color:#fff}.maplibregl-popup-anchor-left .maplibregl-popup-tip{align-self:center;border-left:none;border-right-color:#fff}.maplibregl-popup-anchor-right .maplibregl-popup-tip{align-self:center;border-left-color:#fff;border-right:none}.maplibregl-popup-close-button{background-color:initial;border:0;border-radius:0 3px 0 0;cursor:pointer;position:absolute;right:0;top:0}.maplibregl-popup-close-button:hover{background-color:#0000000d}.maplibregl-popup-content{background:#fff;border-radius:3px;box-shadow:0 1px 2px #0000001a;padding:15px 10px;pointer-events:auto;position:relative}.maplibregl-popup-anchor-top-left .maplibregl-popup-content{border-top-left-radius:0}.maplibregl-popup-anchor-top-right .maplibregl-popup-content{border-top-right-radius:0}.maplibregl-popup-anchor-bottom-left .maplibregl-popup-content{border-bottom-left-radius:0}.maplibregl-popup-anchor-bottom-right .maplibregl-popup-content{border-bottom-right-radius:0}.maplibregl-popup-track-pointer{display:none}.maplibregl-popup-track-pointer *{pointer-events:none;-webkit-user-select:none;user-select:none}.maplibregl-map:hover .maplibregl-popup-track-pointer{display:flex}.maplibregl-map:active .maplibregl-popup-track-pointer{display:none}.maplibregl-marker{left:0;position:absolute;top:0;transition:opacity .2s;will-change:transform}.maplibregl-user-location-dot,.maplibregl-user-location-dot:before{background-color:#1da1f2;border-radius:50%;height:15px;width:15px}.maplibregl-user-location-dot:before{animation:maplibregl-user-location-dot-pulse 2s infinite;content:"";position:absolute}.maplibregl-user-location-dot:after{border:2px solid #fff;border-radius:50%;box-shadow:0 0 3px #00000059;box-sizing:border-box;content:"";height:19px;left:-2px;position:absolute;top:-2px;width:19px}@keyframes maplibregl-user-location-dot-pulse{0%{opacity:1;transform:scale(1)}70%{opacity:0;transform:scale(3)}to{opacity:0;transform:scale(1)}}.maplibregl-user-location-dot-stale{background-color:#aaa}.maplibregl-user-location-dot-stale:after{display:none}.maplibregl-user-location-accuracy-circle{background-color:#1da1f233;border-radius:100%;height:1px;width:1px}.maplibregl-crosshair,.maplibregl-crosshair .maplibregl-interactive,.maplibregl-crosshair .maplibregl-interactive:active{cursor:crosshair}.maplibregl-boxzoom{background:#fff;border:2px dotted #202020;height:0;left:0;opacity:.5;position:absolute;top:0;width:0}.maplibregl-cooperative-gesture-screen{align-items:center;background:#0006;color:#fff;display:flex;font-size:1.4em;inset:0;justify-content:center;line-height:1.2;opacity:0;padding:1rem;pointer-events:none;position:absolute;transition:opacity 1s ease 1s;z-index:99999}.maplibregl-cooperative-gesture-screen.maplibregl-show{opacity:1;transition:opacity .05s}.maplibregl-cooperative-gesture-screen .maplibregl-mobile-message{display:none}@media (hover:none),(max-width:480px){.maplibregl-cooperative-gesture-screen .maplibregl-desktop-message{display:none}.maplibregl-cooperative-gesture-screen .maplibregl-mobile-message{display:block}}.maplibregl-pseudo-fullscreen{height:100%!important;left:0!important;position:fixed!important;top:0!important;width:100%!important;z-index:99999}.react-flow{direction:ltr}.react-flow__container{height:100%;left:0;position:absolute;top:0;width:100%}.react-flow__pane{cursor:grab;z-index:1}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:grabbing}.react-flow__viewport{pointer-events:none;transform-origin:0 0;z-index:2}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{overflow:visible;pointer-events:none}.react-flow__connection-path,.react-flow__edge-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{cursor:pointer;pointer-events:visibleStroke}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{box-sizing:border-box;cursor:grab;pointer-events:all;position:absolute;transform-origin:0 0;-webkit-user-select:none;user-select:none}.react-flow__node.dragging{cursor:grabbing}.react-flow__nodesselection{pointer-events:none;transform-origin:left top;z-index:3}.react-flow__nodesselection-rect{cursor:grab;pointer-events:all;position:absolute}.react-flow__handle{background:#1a192b;border:1px solid #fff;border-radius:100%;height:6px;min-height:5px;min-width:5px;pointer-events:none;position:absolute;width:6px}.react-flow__handle.connectionindicator{cursor:crosshair;pointer-events:all}.react-flow__handle-bottom{bottom:-4px;left:50%;top:auto;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{left:-4px;top:50%;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{margin:15px;position:absolute;z-index:5}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translateX(-50%)}.react-flow__attribution{background:#ffffff80;font-size:10px;margin:0;padding:2px 3px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{height:100%;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none;width:100%}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-group,.react-flow__node-input,.react-flow__node-output{background-color:#fff;border:1px solid #1a192b;border-radius:3px;color:#222;font-size:12px;padding:10px;text-align:center;width:150px}.react-flow__node-default.selectable:hover,.react-flow__node-group.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted #0059dccc}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{align-items:center;background:#fefefe;border:none;border-bottom:1px solid #eee;box-sizing:initial;cursor:pointer;display:flex;height:16px;justify-content:center;padding:5px;-webkit-user-select:none;user-select:none;width:16px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{max-height:12px;max-width:12px;width:100%}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.bottom,.react-flow__resize-control.top{cursor:ns-resize}.react-flow__resize-control.bottom.right,.react-flow__resize-control.top.left{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{background-color:#3367d9;border:1px solid #fff;border-radius:1px;height:4px;transform:translate(-50%,-50%);width:4px}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.bottom.left,.react-flow__resize-control.handle.top.left{left:0}.react-flow__resize-control.handle.bottom.right,.react-flow__resize-control.handle.top.right{left:100%}.react-flow__resize-control.line{border:0 solid #3367d9}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{height:100%;top:0;transform:translate(-50%);width:1px}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.bottom,.react-flow__resize-control.line.top{height:1px;left:0;transform:translateY(-50%);width:100%}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.flow{display:flex;flex-direction:column;height:100%}.flow aside{background:#fcfcfc;border-right:1px solid #eee;font-size:12px;padding:15px 10px}.flow aside>*{cursor:grab;margin-bottom:10px}.flow .reactflow-wrapper{flex-grow:1;height:100%}@media screen and (min-width:768px){.flow{flex-direction:row}.flow aside{max-width:180px;width:20%}}.outputkey{margin-left:auto;margin-right:auto;width:8em}.selectFilePath{max-width:95%}.algoName,.selectFilePath{display:inline-block;overflow:hidden;text-overflow:ellipsis;text-underline-offset:3px;white-space:nowrap;word-break:break-all}.algoName{max-width:85%}.flowbutton{background:#eee;border:1px solid #fff;border-radius:50%;cursor:pointer;font-size:20px;height:25px;line-height:1;width:25px}.flowbutton:hover{box-shadow:0 0 6px 2px #00000014}.flowbutton-foreignobject body{align-items:center;background:#0000;display:flex;height:50px;justify-content:center;min-height:40px;width:50px}.controls-wrapper .ap{background-color:#fff;border:1px solid #4374ad;border-radius:50%;box-sizing:border-box;cursor:pointer;display:inline-block;flex:none;margin-top:-2px;position:relative}.controls-wrapper .ap .apc{bottom:0;top:0}.controls-wrapper .ap .apc,.controls-wrapper .ap .aph{left:0;margin:auto;position:absolute;right:0;width:6px}.controls-wrapper .ap .aph{background-color:#4374ad;border-radius:50%;cursor:pointer;display:inline-block;height:6px;top:4px}.controls-wrapper .ai{align-items:center;background:#f2f2f2;display:flex;flex:1 1;justify-content:space-around;margin:0 12px}.controls-wrapper .ai input{background:inherit;border:none;color:#0c0c09;text-align:center;width:48px}.controls-wrapper .ai span{color:#000;cursor:pointer;font-size:14px;padding:5px;-webkit-user-select:none;user-select:none}.cs{background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAARCAQAAABzuJQIAAAABGdBTUEAALGPC/xhBQAAACBjSFJNAAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAAAmJLR0QA/4ePzL8AAAB7SURBVCjP3c7BDQMhDETRP4gyUlb6SEphe9w+JgdArIMPm2uGizV6MpbpERgBzGb0tuZcLvTbDSoHrMUMQmFrY/IaaOeKB7yE+1yTz43irZNXbXcCFosuXqFt9g0cyZICT7LkrU+b62vGeVv4IX+Phc+tfABZK3xj5cgHC29ECUeufxkAAAAldEVYdGRhdGU6Y3JlYXRlADIwMTctMDUtMzFUMTg6NDE6MzIrMDI6MDD31tLGAAAAJXRFWHRkYXRlOm1vZGlmeQAyMDE3LTA1LTMxVDE4OjQxOjMyKzAyOjAwhotqegAAABl0RVh0U29mdHdhcmUAQWRvYmUgSW1hZ2VSZWFkeXHJZTwAAAAASUVORK5CYII=) 100%;cursor:pointer;height:17px;width:11px}.cs,.cs div{position:absolute}.cs div{height:7px;left:2px;top:8px;width:7px}.cs .active{background-position:0}.cp div{box-sizing:border-box;cursor:pointer;display:inline-block;height:16px;width:16px}.cp div:hover{border:1px solid #fff}.gp{align-items:center;display:flex;flex-direction:column}.gp .gp-flat{box-shadow:none!important;margin:0 auto;padding:10px 0 0!important;transform:none!important}.type-picker-wrapper{display:inline-flex;margin-right:16px}.type-picker-wrapper .type-picker{border:1px solid #eee;cursor:pointer;filter:grayscale(1);height:24px;margin-right:8px;transition:all .2s ease;width:24px}.type-picker-wrapper .type-picker.active{border:1px solid #4374ad;filter:grayscale(0)}.type-picker-wrapper .type-picker.lg{background:linear-gradient(270deg,#ddd,#4374ad)}.type-picker-wrapper .type-picker.rg{background:radial-gradient(circle,#fff 0,#4374ad 100%)}.gpw{padding:20px}.gpw .trigger{background:#fff;border-radius:1px;box-shadow:0 0 0 1px #0000001a;cursor:pointer;display:inline-block;padding:5px}.gpw .trigger .inner{border-radius:2px;height:14px;width:36px}.gpw .popover{background-color:#fff;border-radius:4px;box-shadow:0 0 0 1px #00000026,0 8px 16px #00000026;margin-top:6px;padding:12px;position:absolute;z-index:2}.gpw .overlay{bottom:0;left:0;position:fixed;right:0;top:0}.gpw .controls-wrapper{display:flex;flex-wrap:wrap;margin:0 -10px 10px;padding:6px 0 0 10px;position:relative}.gpw .controls-wrapper.with-angle{align-items:center;justify-content:space-around} +/*# sourceMappingURL=main.edcdbd9f.css.map*/ \ No newline at end of file diff --git a/frontend/build/static/css/main.edcdbd9f.css.map b/frontend/build/static/css/main.edcdbd9f.css.map new file mode 100644 index 000000000..ebb8583c7 --- /dev/null +++ b/frontend/build/static/css/main.edcdbd9f.css.map @@ -0,0 +1 @@ +{"version":3,"file":"static/css/main.edcdbd9f.css","mappings":"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","sources":["index.css","../node_modules/maplibre-gl/dist/maplibre-gl.css","../node_modules/reactflow/dist/style.css","style/flow.css","style/flowbutton.css","../react-linear-gradient-picker/src/components/AnglePicker/index.scss","../react-linear-gradient-picker/src/components/ColorStop/index.scss","../react-linear-gradient-picker/src/components/ColorPicker/index.scss","../react-linear-gradient-picker/src/components/GradientPicker/index.scss","../react-linear-gradient-picker/src/components/GradientTypePicker/index.scss","../react-linear-gradient-picker/src/components/GradientPickerPopover/index.scss"],"sourcesContent":["body {\n margin: 0;\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", \"Roboto\", \"Oxygen\",\n \"Ubuntu\", \"Cantarell\", \"Fira Sans\", \"Droid Sans\", \"Helvetica Neue\",\n sans-serif;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n}\n\ncode {\n font-family: source-code-pro, Menlo, Monaco, Consolas, \"Courier New\",\n monospace;\n}\n\n.toolbar .ctrl_btn {\n margin-left: 10px;\n}\n",".maplibregl-map{font:12px/20px Helvetica Neue,Arial,Helvetica,sans-serif;overflow:hidden;position:relative;-webkit-tap-highlight-color:rgb(0 0 0/0)}.maplibregl-canvas{left:0;position:absolute;top:0}.maplibregl-map:fullscreen{height:100%;width:100%}.maplibregl-ctrl-group button.maplibregl-ctrl-compass{touch-action:none}.maplibregl-canvas-container.maplibregl-interactive,.maplibregl-ctrl-group button.maplibregl-ctrl-compass{cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none}.maplibregl-canvas-container.maplibregl-interactive.maplibregl-track-pointer{cursor:pointer}.maplibregl-canvas-container.maplibregl-interactive:active,.maplibregl-ctrl-group button.maplibregl-ctrl-compass:active{cursor:grabbing}.maplibregl-canvas-container.maplibregl-touch-zoom-rotate,.maplibregl-canvas-container.maplibregl-touch-zoom-rotate .maplibregl-canvas{touch-action:pan-x pan-y}.maplibregl-canvas-container.maplibregl-touch-drag-pan,.maplibregl-canvas-container.maplibregl-touch-drag-pan .maplibregl-canvas{touch-action:pinch-zoom}.maplibregl-canvas-container.maplibregl-touch-zoom-rotate.maplibregl-touch-drag-pan,.maplibregl-canvas-container.maplibregl-touch-zoom-rotate.maplibregl-touch-drag-pan .maplibregl-canvas{touch-action:none}.maplibregl-canvas-container.maplibregl-touch-drag-pan.maplibregl-cooperative-gestures,.maplibregl-canvas-container.maplibregl-touch-drag-pan.maplibregl-cooperative-gestures .maplibregl-canvas{touch-action:pan-x pan-y}.maplibregl-ctrl-bottom-left,.maplibregl-ctrl-bottom-right,.maplibregl-ctrl-top-left,.maplibregl-ctrl-top-right{pointer-events:none;position:absolute;z-index:2}.maplibregl-ctrl-top-left{left:0;top:0}.maplibregl-ctrl-top-right{right:0;top:0}.maplibregl-ctrl-bottom-left{bottom:0;left:0}.maplibregl-ctrl-bottom-right{bottom:0;right:0}.maplibregl-ctrl{clear:both;pointer-events:auto;transform:translate(0)}.maplibregl-ctrl-top-left .maplibregl-ctrl{float:left;margin:10px 0 0 10px}.maplibregl-ctrl-top-right .maplibregl-ctrl{float:right;margin:10px 10px 0 0}.maplibregl-ctrl-bottom-left .maplibregl-ctrl{float:left;margin:0 0 10px 10px}.maplibregl-ctrl-bottom-right .maplibregl-ctrl{float:right;margin:0 10px 10px 0}.maplibregl-ctrl-group{background:#fff;border-radius:4px}.maplibregl-ctrl-group:not(:empty){box-shadow:0 0 0 2px rgba(0,0,0,.1)}@media (forced-colors:active){.maplibregl-ctrl-group:not(:empty){box-shadow:0 0 0 2px ButtonText}}.maplibregl-ctrl-group button{background-color:transparent;border:0;box-sizing:border-box;cursor:pointer;display:block;height:29px;outline:none;padding:0;width:29px}.maplibregl-ctrl-group button+button{border-top:1px solid #ddd}.maplibregl-ctrl button .maplibregl-ctrl-icon{background-position:50%;background-repeat:no-repeat;display:block;height:100%;width:100%}@media (forced-colors:active){.maplibregl-ctrl-icon{background-color:transparent}.maplibregl-ctrl-group button+button{border-top:1px solid ButtonText}}.maplibregl-ctrl button::-moz-focus-inner{border:0;padding:0}.maplibregl-ctrl-attrib-button:focus,.maplibregl-ctrl-group button:focus{box-shadow:0 0 2px 2px #0096ff}.maplibregl-ctrl button:disabled{cursor:not-allowed}.maplibregl-ctrl button:disabled .maplibregl-ctrl-icon{opacity:.25}.maplibregl-ctrl button:not(:disabled):hover{background-color:rgb(0 0 0/5%)}.maplibregl-ctrl-group button:focus:focus-visible{box-shadow:0 0 2px 2px #0096ff}.maplibregl-ctrl-group button:focus:not(:focus-visible){box-shadow:none}.maplibregl-ctrl-group button:focus:first-child{border-radius:4px 4px 0 0}.maplibregl-ctrl-group button:focus:last-child{border-radius:0 0 4px 4px}.maplibregl-ctrl-group button:focus:only-child{border-radius:inherit}.maplibregl-ctrl button.maplibregl-ctrl-zoom-out .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13z'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-zoom-in .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5'/%3E%3C/svg%3E\")}@media (forced-colors:active){.maplibregl-ctrl button.maplibregl-ctrl-zoom-out .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13z'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-zoom-in .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5'/%3E%3C/svg%3E\")}}@media (forced-colors:active) and (prefers-color-scheme:light){.maplibregl-ctrl button.maplibregl-ctrl-zoom-out .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13z'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-zoom-in .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5'/%3E%3C/svg%3E\")}}.maplibregl-ctrl button.maplibregl-ctrl-fullscreen .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1z'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-shrink .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1z'/%3E%3C/svg%3E\")}@media (forced-colors:active){.maplibregl-ctrl button.maplibregl-ctrl-fullscreen .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1z'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-shrink .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1z'/%3E%3C/svg%3E\")}}@media (forced-colors:active) and (prefers-color-scheme:light){.maplibregl-ctrl button.maplibregl-ctrl-fullscreen .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1z'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-shrink .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1z'/%3E%3C/svg%3E\")}}.maplibregl-ctrl button.maplibregl-ctrl-compass .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='m10.5 14 4-8 4 8z'/%3E%3Cpath fill='%23ccc' d='m10.5 16 4 8 4-8z'/%3E%3C/svg%3E\")}@media (forced-colors:active){.maplibregl-ctrl button.maplibregl-ctrl-compass .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='m10.5 14 4-8 4 8z'/%3E%3Cpath fill='%23ccc' d='m10.5 16 4 8 4-8z'/%3E%3C/svg%3E\")}}@media (forced-colors:active) and (prefers-color-scheme:light){.maplibregl-ctrl button.maplibregl-ctrl-compass .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' viewBox='0 0 29 29'%3E%3Cpath d='m10.5 14 4-8 4 8z'/%3E%3Cpath fill='%23ccc' d='m10.5 16 4 8 4-8z'/%3E%3C/svg%3E\")}}.maplibregl-ctrl button.maplibregl-ctrl-terrain .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' fill='%23333' viewBox='0 0 22 22'%3E%3Cpath d='m1.754 13.406 4.453-4.851 3.09 3.09 3.281 3.277.969-.969-3.309-3.312 3.844-4.121 6.148 6.886h1.082v-.855l-7.207-8.07-4.84 5.187L6.169 6.57l-5.48 5.965v.871ZM.688 16.844h20.625v1.375H.688Zm0 0'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-terrain-enabled .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' fill='%2333b5e5' viewBox='0 0 22 22'%3E%3Cpath d='m1.754 13.406 4.453-4.851 3.09 3.09 3.281 3.277.969-.969-3.309-3.312 3.844-4.121 6.148 6.886h1.082v-.855l-7.207-8.07-4.84 5.187L6.169 6.57l-5.48 5.965v.871ZM.688 16.844h20.625v1.375H.688Zm0 0'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23333' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate:disabled .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23aaa' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3Cpath fill='red' d='m14 5 1 1-9 9-1-1z'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-active .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%2333b5e5' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-active-error .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23e58978' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-background .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%2333b5e5' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-background-error .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23e54e33' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-waiting .maplibregl-ctrl-icon{animation:maplibregl-spin 2s linear infinite}@media (forced-colors:active){.maplibregl-ctrl button.maplibregl-ctrl-geolocate .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23fff' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate:disabled .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23999' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3Cpath fill='red' d='m14 5 1 1-9 9-1-1z'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-active .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%2333b5e5' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-active-error .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23e58978' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-background .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%2333b5e5' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-background-error .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23e54e33' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3C/svg%3E\")}}@media (forced-colors:active) and (prefers-color-scheme:light){.maplibregl-ctrl button.maplibregl-ctrl-geolocate .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E\")}.maplibregl-ctrl button.maplibregl-ctrl-geolocate:disabled .maplibregl-ctrl-icon{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='29' height='29' fill='%23666' viewBox='0 0 20 20'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1m0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3Cpath fill='red' d='m14 5 1 1-9 9-1-1z'/%3E%3C/svg%3E\")}}@keyframes maplibregl-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}a.maplibregl-ctrl-logo{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='88' height='23' fill='none'%3E%3Cpath fill='%23000' fill-opacity='.4' fill-rule='evenodd' d='M17.408 16.796h-1.827l2.501-12.095h.198l3.324 6.533.988 2.19.988-2.19 3.258-6.533h.181l2.6 12.095h-1.81l-1.218-5.644-.362-1.71-.658 1.71-2.929 5.644h-.098l-2.914-5.644-.757-1.71-.345 1.71zm1.958-3.42-.726 3.663a1.255 1.255 0 0 1-1.232 1.011h-1.827a1.255 1.255 0 0 1-1.229-1.509l2.501-12.095a1.255 1.255 0 0 1 1.23-1.001h.197a1.25 1.25 0 0 1 1.12.685l3.19 6.273 3.125-6.263a1.25 1.25 0 0 1 1.123-.695h.181a1.255 1.255 0 0 1 1.227.991l1.443 6.71a5 5 0 0 1 .314-.787l.009-.016a4.6 4.6 0 0 1 1.777-1.887c.782-.46 1.668-.667 2.611-.667a4.6 4.6 0 0 1 1.7.32l.306.134c.21-.16.474-.256.759-.256h1.694a1.255 1.255 0 0 1 1.212.925 1.255 1.255 0 0 1 1.212-.925h1.711c.284 0 .545.094.755.252.613-.3 1.312-.45 2.075-.45 1.356 0 2.557.445 3.482 1.4q.47.48.763 1.064V4.701a1.255 1.255 0 0 1 1.255-1.255h1.86A1.255 1.255 0 0 1 54.44 4.7v9.194h2.217c.19 0 .37.043.532.118v-4.77c0-.356.147-.678.385-.906a2.42 2.42 0 0 1-.682-1.71c0-.665.267-1.253.735-1.7a2.45 2.45 0 0 1 1.722-.674 2.43 2.43 0 0 1 1.705.675q.318.302.504.683V4.7a1.255 1.255 0 0 1 1.255-1.255h1.744A1.255 1.255 0 0 1 65.812 4.7v3.335a4.8 4.8 0 0 1 1.526-.246c.938 0 1.817.214 2.59.69a4.47 4.47 0 0 1 1.67 1.743v-.98a1.255 1.255 0 0 1 1.256-1.256h1.777c.233 0 .451.064.639.174a3.4 3.4 0 0 1 1.567-.372c.346 0 .861.02 1.285.232a1.25 1.25 0 0 1 .689 1.004 4.7 4.7 0 0 1 .853-.588c.795-.44 1.675-.647 2.61-.647 1.385 0 2.65.39 3.525 1.396.836.938 1.168 2.173 1.168 3.528q-.001.515-.056 1.051a1.255 1.255 0 0 1-.947 1.09l.408.952a1.255 1.255 0 0 1-.477 1.552c-.418.268-.92.463-1.458.612-.613.171-1.304.244-2.049.244-1.06 0-2.043-.207-2.886-.698l-.015-.008c-.798-.48-1.419-1.135-1.818-1.963l-.004-.008a5.8 5.8 0 0 1-.548-2.512q0-.429.053-.843a1.3 1.3 0 0 1-.333-.086l-.166-.004c-.223 0-.426.062-.643.228-.03.024-.142.139-.142.59v3.883a1.255 1.255 0 0 1-1.256 1.256h-1.777a1.255 1.255 0 0 1-1.256-1.256V15.69l-.032.057a4.8 4.8 0 0 1-1.86 1.833 5.04 5.04 0 0 1-2.484.634 4.5 4.5 0 0 1-1.935-.424 1.25 1.25 0 0 1-.764.258h-1.71a1.255 1.255 0 0 1-1.256-1.255V7.687a2.4 2.4 0 0 1-.428.625c.253.23.412.561.412.93v7.553a1.255 1.255 0 0 1-1.256 1.255h-1.843a1.25 1.25 0 0 1-.894-.373c-.228.23-.544.373-.894.373H51.32a1.255 1.255 0 0 1-1.256-1.255v-1.251l-.061.117a4.7 4.7 0 0 1-1.782 1.884 4.77 4.77 0 0 1-2.485.67 5.6 5.6 0 0 1-1.485-.188l.009 2.764a1.255 1.255 0 0 1-1.255 1.259h-1.729a1.255 1.255 0 0 1-1.255-1.255v-3.537a1.255 1.255 0 0 1-1.167.793h-1.679a1.25 1.25 0 0 1-.77-.263 4.5 4.5 0 0 1-1.945.429c-.885 0-1.724-.21-2.495-.632l-.017-.01a5 5 0 0 1-1.081-.836 1.255 1.255 0 0 1-1.254 1.312h-1.81a1.255 1.255 0 0 1-1.228-.99l-.782-3.625-2.044 3.939a1.25 1.25 0 0 1-1.115.676h-.098a1.25 1.25 0 0 1-1.116-.68l-2.061-3.994zM35.92 16.63l.207-.114.223-.15q.493-.356.735-.785l.061-.118.033 1.332h1.678V9.242h-1.694l-.033 1.267q-.133-.329-.526-.658l-.032-.028a3.2 3.2 0 0 0-.668-.428l-.27-.12a3.3 3.3 0 0 0-1.235-.23q-1.136-.001-1.974.493a3.36 3.36 0 0 0-1.3 1.382q-.445.89-.444 2.074 0 1.2.51 2.107a3.8 3.8 0 0 0 1.382 1.381 3.9 3.9 0 0 0 1.893.477q.795 0 1.455-.33zm-2.789-5.38q-.576.675-.575 1.762 0 1.102.559 1.794.576.675 1.645.675a2.25 2.25 0 0 0 .934-.19 2.2 2.2 0 0 0 .468-.29l.178-.161a2.2 2.2 0 0 0 .397-.561q.244-.5.244-1.15v-.115q0-.708-.296-1.267l-.043-.077a2.2 2.2 0 0 0-.633-.709l-.13-.086-.047-.028a2.1 2.1 0 0 0-1.073-.285q-1.052 0-1.629.692zm2.316 2.706c.163-.17.28-.407.28-.83v-.114c0-.292-.06-.508-.15-.68a.96.96 0 0 0-.353-.389.85.85 0 0 0-.464-.127c-.4 0-.56.114-.664.239l-.01.012c-.148.174-.275.45-.275.945 0 .506.122.801.27.99.097.11.266.224.68.224.303 0 .504-.09.687-.269zm7.545 1.705a2.6 2.6 0 0 0 .331.423q.319.33.755.548l.173.074q.65.255 1.49.255 1.02 0 1.844-.493a3.45 3.45 0 0 0 1.316-1.4q.493-.904.493-2.089 0-1.909-.988-2.913-.988-1.02-2.584-1.02-.898 0-1.575.347a3 3 0 0 0-.415.262l-.199.166a3.4 3.4 0 0 0-.64.82V9.242h-1.712v11.553h1.729l-.017-5.134zm.53-1.138q.206.29.48.5l.155.11.053.034q.51.296 1.119.297 1.07 0 1.645-.675.577-.69.576-1.762 0-1.119-.576-1.777-.558-.675-1.645-.675-.435 0-.835.16a2 2 0 0 0-.284.136 2 2 0 0 0-.363.254 2.2 2.2 0 0 0-.46.569l-.082.162a2.6 2.6 0 0 0-.213 1.072v.115q0 .707.296 1.267l.135.211zm.964-.818a1.1 1.1 0 0 0 .367.385.94.94 0 0 0 .476.118c.423 0 .59-.117.687-.23.159-.194.28-.478.28-.95 0-.53-.133-.8-.266-.952l-.021-.025c-.078-.094-.231-.221-.68-.221a1 1 0 0 0-.503.135l-.012.007a.86.86 0 0 0-.335.343c-.073.133-.132.324-.132.614v.115a1.4 1.4 0 0 0 .14.66zm15.7-6.222q.347-.346.346-.856a1.05 1.05 0 0 0-.345-.79 1.18 1.18 0 0 0-.84-.329q-.51 0-.855.33a1.05 1.05 0 0 0-.346.79q0 .51.346.855.345.346.856.346.51 0 .839-.346zm4.337 9.314.033-1.332q.191.403.59.747l.098.081a4 4 0 0 0 .316.224l.223.122a3.2 3.2 0 0 0 1.44.322 3.8 3.8 0 0 0 1.875-.477 3.5 3.5 0 0 0 1.382-1.366q.527-.89.526-2.09 0-1.184-.444-2.073a3.24 3.24 0 0 0-1.283-1.399q-.823-.51-1.942-.51a3.5 3.5 0 0 0-1.527.344l-.086.043-.165.09a3 3 0 0 0-.33.214q-.432.315-.656.707a2 2 0 0 0-.099.198l.082-1.283V4.701h-1.744v12.095zm.473-2.509a2.5 2.5 0 0 0 .566.7q.117.098.245.18l.144.08a2.1 2.1 0 0 0 .975.232q1.07 0 1.645-.675.576-.69.576-1.778 0-1.102-.576-1.777-.56-.691-1.645-.692a2.2 2.2 0 0 0-1.015.235q-.22.113-.415.282l-.15.142a2.1 2.1 0 0 0-.42.594q-.223.479-.223 1.1v.115q0 .705.293 1.26zm2.616-.293c.157-.191.28-.479.28-.967 0-.51-.13-.79-.276-.961l-.021-.026c-.082-.1-.232-.225-.67-.225a.87.87 0 0 0-.681.279l-.012.011c-.154.155-.274.38-.274.807v.115c0 .285.057.499.144.669a1.1 1.1 0 0 0 .367.405c.137.082.28.123.455.123.423 0 .59-.118.686-.23zm8.266-3.013q.345-.13.724-.14l.069-.002q.493 0 .642.099l.247-1.794q-.196-.099-.717-.099a2.3 2.3 0 0 0-.545.063 2 2 0 0 0-.411.148 2.2 2.2 0 0 0-.4.249 2.5 2.5 0 0 0-.485.499 2.7 2.7 0 0 0-.32.581l-.05.137v-1.48h-1.778v7.553h1.777v-3.884q0-.546.159-.943a1.5 1.5 0 0 1 .466-.636 2.5 2.5 0 0 1 .399-.253 2 2 0 0 1 .224-.099zm9.784 2.656.05-.922q0-1.743-.856-2.698-.838-.97-2.584-.97-1.119-.001-2.007.493a3.46 3.46 0 0 0-1.4 1.382q-.493.906-.493 2.106 0 1.07.428 1.975.428.89 1.332 1.432.906.526 2.255.526.973 0 1.668-.185l.044-.012.135-.04q.613-.184.984-.421l-.542-1.267q-.3.162-.642.274l-.297.087q-.51.131-1.3.131-.954 0-1.497-.444a1.6 1.6 0 0 1-.192-.193q-.366-.44-.512-1.234l-.004-.021zm-5.427-1.256-.003.022h3.752v-.138q-.011-.727-.288-1.118a1 1 0 0 0-.156-.176q-.46-.428-1.316-.428-.986 0-1.494.604-.379.45-.494 1.234zm-27.053 2.77V4.7h-1.86v12.095h5.333V15.15zm7.103-5.908v7.553h-1.843V9.242h1.843z'/%3E%3Cpath fill='%23fff' d='m19.63 11.151-.757-1.71-.345 1.71-1.12 5.644h-1.827L18.083 4.7h.197l3.325 6.533.988 2.19.988-2.19L26.839 4.7h.181l2.6 12.095h-1.81l-1.218-5.644-.362-1.71-.658 1.71-2.93 5.644h-.098l-2.913-5.644zm14.836 5.81q-1.02 0-1.893-.478a3.8 3.8 0 0 1-1.381-1.382q-.51-.906-.51-2.106 0-1.185.444-2.074a3.36 3.36 0 0 1 1.3-1.382q.839-.494 1.974-.494a3.3 3.3 0 0 1 1.234.231 3.3 3.3 0 0 1 .97.575q.396.33.527.659l.033-1.267h1.694v7.553H37.18l-.033-1.332q-.279.593-1.02 1.053a3.17 3.17 0 0 1-1.662.444zm.296-1.482q.938 0 1.58-.642.642-.66.642-1.711v-.115q0-.708-.296-1.267a2.2 2.2 0 0 0-.807-.872 2.1 2.1 0 0 0-1.119-.313q-1.053 0-1.629.692-.575.675-.575 1.76 0 1.103.559 1.795.577.675 1.645.675zm6.521-6.237h1.711v1.4q.906-1.597 2.83-1.597 1.596 0 2.584 1.02.988 1.005.988 2.914 0 1.185-.493 2.09a3.46 3.46 0 0 1-1.316 1.399 3.5 3.5 0 0 1-1.844.493q-.954 0-1.662-.329a2.67 2.67 0 0 1-1.086-.97l.017 5.134h-1.728zm4.048 6.22q1.07 0 1.645-.674.577-.69.576-1.762 0-1.119-.576-1.777-.558-.675-1.645-.675-.592 0-1.12.296-.51.28-.822.823-.296.527-.296 1.234v.115q0 .708.296 1.267.313.543.823.855.51.296 1.119.297z'/%3E%3Cpath fill='%23e1e3e9' d='M51.325 4.7h1.86v10.45h3.473v1.646h-5.333zm7.12 4.542h1.843v7.553h-1.843zm.905-1.415a1.16 1.16 0 0 1-.856-.346 1.17 1.17 0 0 1-.346-.856 1.05 1.05 0 0 1 .346-.79q.346-.329.856-.329.494 0 .839.33a1.05 1.05 0 0 1 .345.79 1.16 1.16 0 0 1-.345.855q-.33.346-.84.346zm7.875 9.133a3.17 3.17 0 0 1-1.662-.444q-.723-.46-1.004-1.053l-.033 1.332h-1.71V4.701h1.743v4.657l-.082 1.283q.279-.658 1.086-1.119a3.5 3.5 0 0 1 1.778-.477q1.119 0 1.942.51a3.24 3.24 0 0 1 1.283 1.4q.445.888.444 2.072 0 1.201-.526 2.09a3.5 3.5 0 0 1-1.382 1.366 3.8 3.8 0 0 1-1.876.477zm-.296-1.481q1.069 0 1.645-.675.577-.69.577-1.778 0-1.102-.577-1.776-.56-.691-1.645-.692a2.12 2.12 0 0 0-1.58.659q-.642.641-.642 1.694v.115q0 .71.296 1.267a2.4 2.4 0 0 0 .807.872 2.1 2.1 0 0 0 1.119.313zm5.927-6.237h1.777v1.481q.263-.757.856-1.217a2.14 2.14 0 0 1 1.349-.46q.527 0 .724.098l-.247 1.794q-.149-.099-.642-.099-.774 0-1.416.494-.626.493-.626 1.58v3.883h-1.777V9.242zm9.534 7.718q-1.35 0-2.255-.526-.904-.543-1.332-1.432a4.6 4.6 0 0 1-.428-1.975q0-1.2.493-2.106a3.46 3.46 0 0 1 1.4-1.382q.889-.495 2.007-.494 1.744 0 2.584.97.855.956.856 2.7 0 .444-.05.92h-5.43q.18 1.005.708 1.45.542.443 1.497.443.79 0 1.3-.131a4 4 0 0 0 .938-.362l.542 1.267q-.411.263-1.119.46-.708.198-1.711.197zm1.596-4.558q.016-1.02-.444-1.432-.46-.428-1.316-.428-1.728 0-1.991 1.86z'/%3E%3Cpath d='M5.074 15.948a.484.657 0 0 0-.486.659v1.84a.484.657 0 0 0 .486.659h4.101a.484.657 0 0 0 .486-.659v-1.84a.484.657 0 0 0-.486-.659zm3.56 1.16H5.617v.838h3.017z' style='fill:%23fff;fill-rule:evenodd;stroke-width:1.03600001'/%3E%3Cg style='stroke-width:1.12603545'%3E%3Cpath d='M-9.408-1.416c-3.833-.025-7.056 2.912-7.08 6.615-.02 3.08 1.653 4.832 3.107 6.268.903.892 1.721 1.74 2.32 2.902l-.525-.004c-.543-.003-.992.304-1.24.639a1.87 1.87 0 0 0-.362 1.121l-.011 1.877c-.003.402.104.787.347 1.125.244.338.688.653 1.23.656l4.142.028c.542.003.99-.306 1.238-.641a1.87 1.87 0 0 0 .363-1.121l.012-1.875a1.87 1.87 0 0 0-.348-1.127c-.243-.338-.688-.653-1.23-.656l-.518-.004c.597-1.145 1.425-1.983 2.348-2.87 1.473-1.414 3.18-3.149 3.2-6.226-.016-3.59-2.923-6.684-6.993-6.707m-.006 1.1v.002c3.274.02 5.92 2.532 5.9 5.6-.017 2.706-1.39 4.026-2.863 5.44-1.034.994-2.118 2.033-2.814 3.633-.018.041-.052.055-.075.065q-.013.004-.02.01a.34.34 0 0 1-.226.084.34.34 0 0 1-.224-.086l-.092-.077c-.699-1.615-1.768-2.669-2.781-3.67-1.454-1.435-2.797-2.762-2.78-5.478.02-3.067 2.7-5.545 5.975-5.523m-.02 2.826c-1.62-.01-2.944 1.315-2.955 2.96-.01 1.646 1.295 2.988 2.916 2.999h.002c1.621.01 2.943-1.316 2.953-2.961.011-1.646-1.294-2.988-2.916-2.998m-.005 1.1c1.017.006 1.829.83 1.822 1.89s-.83 1.874-1.848 1.867c-1.018-.006-1.829-.83-1.822-1.89s.83-1.874 1.848-1.868m-2.155 11.857 4.14.025c.271.002.49.305.487.676l-.013 1.875c-.003.37-.224.67-.495.668l-4.14-.025c-.27-.002-.487-.306-.485-.676l.012-1.875c.003-.37.224-.67.494-.668' style='color:%23000;font-style:normal;font-variant:normal;font-weight:400;font-stretch:normal;font-size:medium;line-height:normal;font-family:sans-serif;font-variant-ligatures:normal;font-variant-position:normal;font-variant-caps:normal;font-variant-numeric:normal;font-variant-alternates:normal;font-feature-settings:normal;text-indent:0;text-align:start;text-decoration:none;text-decoration-line:none;text-decoration-style:solid;text-decoration-color:%23000;letter-spacing:normal;word-spacing:normal;text-transform:none;writing-mode:lr-tb;direction:ltr;text-orientation:mixed;dominant-baseline:auto;baseline-shift:baseline;text-anchor:start;white-space:normal;shape-padding:0;clip-rule:evenodd;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:%23000;solid-opacity:1;vector-effect:none;fill:%23000;fill-opacity:.4;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto' transform='translate(15.553 2.85)scale(.88807)'/%3E%3Cpath d='M-9.415-.316C-12.69-.338-15.37 2.14-15.39 5.207c-.017 2.716 1.326 4.041 2.78 5.477 1.013 1 2.081 2.055 2.78 3.67l.092.076a.34.34 0 0 0 .225.086.34.34 0 0 0 .227-.083l.019-.01c.022-.009.057-.024.074-.064.697-1.6 1.78-2.64 2.814-3.634 1.473-1.414 2.847-2.733 2.864-5.44.02-3.067-2.627-5.58-5.901-5.601m-.057 8.784c1.621.011 2.944-1.315 2.955-2.96.01-1.646-1.295-2.988-2.916-2.999-1.622-.01-2.945 1.315-2.955 2.96s1.295 2.989 2.916 3' style='clip-rule:evenodd;fill:%23e1e3e9;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:.4' transform='translate(15.553 2.85)scale(.88807)'/%3E%3Cpath d='M-11.594 15.465c-.27-.002-.492.297-.494.668l-.012 1.876c-.003.371.214.673.485.675l4.14.027c.271.002.492-.298.495-.668l.012-1.877c.003-.37-.215-.672-.485-.674z' style='clip-rule:evenodd;fill:%23fff;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:.4' transform='translate(15.553 2.85)scale(.88807)'/%3E%3C/g%3E%3C/svg%3E\");background-repeat:no-repeat;cursor:pointer;display:block;height:23px;margin:0 0 -4px -4px;overflow:hidden;width:88px}a.maplibregl-ctrl-logo.maplibregl-compact{width:14px}@media (forced-colors:active){a.maplibregl-ctrl-logo{background-color:transparent;background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='88' height='23' fill='none'%3E%3Cpath fill='%23000' fill-opacity='.4' fill-rule='evenodd' d='M17.408 16.796h-1.827l2.501-12.095h.198l3.324 6.533.988 2.19.988-2.19 3.258-6.533h.181l2.6 12.095h-1.81l-1.218-5.644-.362-1.71-.658 1.71-2.929 5.644h-.098l-2.914-5.644-.757-1.71-.345 1.71zm1.958-3.42-.726 3.663a1.255 1.255 0 0 1-1.232 1.011h-1.827a1.255 1.255 0 0 1-1.229-1.509l2.501-12.095a1.255 1.255 0 0 1 1.23-1.001h.197a1.25 1.25 0 0 1 1.12.685l3.19 6.273 3.125-6.263a1.25 1.25 0 0 1 1.123-.695h.181a1.255 1.255 0 0 1 1.227.991l1.443 6.71a5 5 0 0 1 .314-.787l.009-.016a4.6 4.6 0 0 1 1.777-1.887c.782-.46 1.668-.667 2.611-.667a4.6 4.6 0 0 1 1.7.32l.306.134c.21-.16.474-.256.759-.256h1.694a1.255 1.255 0 0 1 1.212.925 1.255 1.255 0 0 1 1.212-.925h1.711c.284 0 .545.094.755.252.613-.3 1.312-.45 2.075-.45 1.356 0 2.557.445 3.482 1.4q.47.48.763 1.064V4.701a1.255 1.255 0 0 1 1.255-1.255h1.86A1.255 1.255 0 0 1 54.44 4.7v9.194h2.217c.19 0 .37.043.532.118v-4.77c0-.356.147-.678.385-.906a2.42 2.42 0 0 1-.682-1.71c0-.665.267-1.253.735-1.7a2.45 2.45 0 0 1 1.722-.674 2.43 2.43 0 0 1 1.705.675q.318.302.504.683V4.7a1.255 1.255 0 0 1 1.255-1.255h1.744A1.255 1.255 0 0 1 65.812 4.7v3.335a4.8 4.8 0 0 1 1.526-.246c.938 0 1.817.214 2.59.69a4.47 4.47 0 0 1 1.67 1.743v-.98a1.255 1.255 0 0 1 1.256-1.256h1.777c.233 0 .451.064.639.174a3.4 3.4 0 0 1 1.567-.372c.346 0 .861.02 1.285.232a1.25 1.25 0 0 1 .689 1.004 4.7 4.7 0 0 1 .853-.588c.795-.44 1.675-.647 2.61-.647 1.385 0 2.65.39 3.525 1.396.836.938 1.168 2.173 1.168 3.528q-.001.515-.056 1.051a1.255 1.255 0 0 1-.947 1.09l.408.952a1.255 1.255 0 0 1-.477 1.552c-.418.268-.92.463-1.458.612-.613.171-1.304.244-2.049.244-1.06 0-2.043-.207-2.886-.698l-.015-.008c-.798-.48-1.419-1.135-1.818-1.963l-.004-.008a5.8 5.8 0 0 1-.548-2.512q0-.429.053-.843a1.3 1.3 0 0 1-.333-.086l-.166-.004c-.223 0-.426.062-.643.228-.03.024-.142.139-.142.59v3.883a1.255 1.255 0 0 1-1.256 1.256h-1.777a1.255 1.255 0 0 1-1.256-1.256V15.69l-.032.057a4.8 4.8 0 0 1-1.86 1.833 5.04 5.04 0 0 1-2.484.634 4.5 4.5 0 0 1-1.935-.424 1.25 1.25 0 0 1-.764.258h-1.71a1.255 1.255 0 0 1-1.256-1.255V7.687a2.4 2.4 0 0 1-.428.625c.253.23.412.561.412.93v7.553a1.255 1.255 0 0 1-1.256 1.255h-1.843a1.25 1.25 0 0 1-.894-.373c-.228.23-.544.373-.894.373H51.32a1.255 1.255 0 0 1-1.256-1.255v-1.251l-.061.117a4.7 4.7 0 0 1-1.782 1.884 4.77 4.77 0 0 1-2.485.67 5.6 5.6 0 0 1-1.485-.188l.009 2.764a1.255 1.255 0 0 1-1.255 1.259h-1.729a1.255 1.255 0 0 1-1.255-1.255v-3.537a1.255 1.255 0 0 1-1.167.793h-1.679a1.25 1.25 0 0 1-.77-.263 4.5 4.5 0 0 1-1.945.429c-.885 0-1.724-.21-2.495-.632l-.017-.01a5 5 0 0 1-1.081-.836 1.255 1.255 0 0 1-1.254 1.312h-1.81a1.255 1.255 0 0 1-1.228-.99l-.782-3.625-2.044 3.939a1.25 1.25 0 0 1-1.115.676h-.098a1.25 1.25 0 0 1-1.116-.68l-2.061-3.994zM35.92 16.63l.207-.114.223-.15q.493-.356.735-.785l.061-.118.033 1.332h1.678V9.242h-1.694l-.033 1.267q-.133-.329-.526-.658l-.032-.028a3.2 3.2 0 0 0-.668-.428l-.27-.12a3.3 3.3 0 0 0-1.235-.23q-1.136-.001-1.974.493a3.36 3.36 0 0 0-1.3 1.382q-.445.89-.444 2.074 0 1.2.51 2.107a3.8 3.8 0 0 0 1.382 1.381 3.9 3.9 0 0 0 1.893.477q.795 0 1.455-.33zm-2.789-5.38q-.576.675-.575 1.762 0 1.102.559 1.794.576.675 1.645.675a2.25 2.25 0 0 0 .934-.19 2.2 2.2 0 0 0 .468-.29l.178-.161a2.2 2.2 0 0 0 .397-.561q.244-.5.244-1.15v-.115q0-.708-.296-1.267l-.043-.077a2.2 2.2 0 0 0-.633-.709l-.13-.086-.047-.028a2.1 2.1 0 0 0-1.073-.285q-1.052 0-1.629.692zm2.316 2.706c.163-.17.28-.407.28-.83v-.114c0-.292-.06-.508-.15-.68a.96.96 0 0 0-.353-.389.85.85 0 0 0-.464-.127c-.4 0-.56.114-.664.239l-.01.012c-.148.174-.275.45-.275.945 0 .506.122.801.27.99.097.11.266.224.68.224.303 0 .504-.09.687-.269zm7.545 1.705a2.6 2.6 0 0 0 .331.423q.319.33.755.548l.173.074q.65.255 1.49.255 1.02 0 1.844-.493a3.45 3.45 0 0 0 1.316-1.4q.493-.904.493-2.089 0-1.909-.988-2.913-.988-1.02-2.584-1.02-.898 0-1.575.347a3 3 0 0 0-.415.262l-.199.166a3.4 3.4 0 0 0-.64.82V9.242h-1.712v11.553h1.729l-.017-5.134zm.53-1.138q.206.29.48.5l.155.11.053.034q.51.296 1.119.297 1.07 0 1.645-.675.577-.69.576-1.762 0-1.119-.576-1.777-.558-.675-1.645-.675-.435 0-.835.16a2 2 0 0 0-.284.136 2 2 0 0 0-.363.254 2.2 2.2 0 0 0-.46.569l-.082.162a2.6 2.6 0 0 0-.213 1.072v.115q0 .707.296 1.267l.135.211zm.964-.818a1.1 1.1 0 0 0 .367.385.94.94 0 0 0 .476.118c.423 0 .59-.117.687-.23.159-.194.28-.478.28-.95 0-.53-.133-.8-.266-.952l-.021-.025c-.078-.094-.231-.221-.68-.221a1 1 0 0 0-.503.135l-.012.007a.86.86 0 0 0-.335.343c-.073.133-.132.324-.132.614v.115a1.4 1.4 0 0 0 .14.66zm15.7-6.222q.347-.346.346-.856a1.05 1.05 0 0 0-.345-.79 1.18 1.18 0 0 0-.84-.329q-.51 0-.855.33a1.05 1.05 0 0 0-.346.79q0 .51.346.855.345.346.856.346.51 0 .839-.346zm4.337 9.314.033-1.332q.191.403.59.747l.098.081a4 4 0 0 0 .316.224l.223.122a3.2 3.2 0 0 0 1.44.322 3.8 3.8 0 0 0 1.875-.477 3.5 3.5 0 0 0 1.382-1.366q.527-.89.526-2.09 0-1.184-.444-2.073a3.24 3.24 0 0 0-1.283-1.399q-.823-.51-1.942-.51a3.5 3.5 0 0 0-1.527.344l-.086.043-.165.09a3 3 0 0 0-.33.214q-.432.315-.656.707a2 2 0 0 0-.099.198l.082-1.283V4.701h-1.744v12.095zm.473-2.509a2.5 2.5 0 0 0 .566.7q.117.098.245.18l.144.08a2.1 2.1 0 0 0 .975.232q1.07 0 1.645-.675.576-.69.576-1.778 0-1.102-.576-1.777-.56-.691-1.645-.692a2.2 2.2 0 0 0-1.015.235q-.22.113-.415.282l-.15.142a2.1 2.1 0 0 0-.42.594q-.223.479-.223 1.1v.115q0 .705.293 1.26zm2.616-.293c.157-.191.28-.479.28-.967 0-.51-.13-.79-.276-.961l-.021-.026c-.082-.1-.232-.225-.67-.225a.87.87 0 0 0-.681.279l-.012.011c-.154.155-.274.38-.274.807v.115c0 .285.057.499.144.669a1.1 1.1 0 0 0 .367.405c.137.082.28.123.455.123.423 0 .59-.118.686-.23zm8.266-3.013q.345-.13.724-.14l.069-.002q.493 0 .642.099l.247-1.794q-.196-.099-.717-.099a2.3 2.3 0 0 0-.545.063 2 2 0 0 0-.411.148 2.2 2.2 0 0 0-.4.249 2.5 2.5 0 0 0-.485.499 2.7 2.7 0 0 0-.32.581l-.05.137v-1.48h-1.778v7.553h1.777v-3.884q0-.546.159-.943a1.5 1.5 0 0 1 .466-.636 2.5 2.5 0 0 1 .399-.253 2 2 0 0 1 .224-.099zm9.784 2.656.05-.922q0-1.743-.856-2.698-.838-.97-2.584-.97-1.119-.001-2.007.493a3.46 3.46 0 0 0-1.4 1.382q-.493.906-.493 2.106 0 1.07.428 1.975.428.89 1.332 1.432.906.526 2.255.526.973 0 1.668-.185l.044-.012.135-.04q.613-.184.984-.421l-.542-1.267q-.3.162-.642.274l-.297.087q-.51.131-1.3.131-.954 0-1.497-.444a1.6 1.6 0 0 1-.192-.193q-.366-.44-.512-1.234l-.004-.021zm-5.427-1.256-.003.022h3.752v-.138q-.011-.727-.288-1.118a1 1 0 0 0-.156-.176q-.46-.428-1.316-.428-.986 0-1.494.604-.379.45-.494 1.234zm-27.053 2.77V4.7h-1.86v12.095h5.333V15.15zm7.103-5.908v7.553h-1.843V9.242h1.843z'/%3E%3Cpath fill='%23fff' d='m19.63 11.151-.757-1.71-.345 1.71-1.12 5.644h-1.827L18.083 4.7h.197l3.325 6.533.988 2.19.988-2.19L26.839 4.7h.181l2.6 12.095h-1.81l-1.218-5.644-.362-1.71-.658 1.71-2.93 5.644h-.098l-2.913-5.644zm14.836 5.81q-1.02 0-1.893-.478a3.8 3.8 0 0 1-1.381-1.382q-.51-.906-.51-2.106 0-1.185.444-2.074a3.36 3.36 0 0 1 1.3-1.382q.839-.494 1.974-.494a3.3 3.3 0 0 1 1.234.231 3.3 3.3 0 0 1 .97.575q.396.33.527.659l.033-1.267h1.694v7.553H37.18l-.033-1.332q-.279.593-1.02 1.053a3.17 3.17 0 0 1-1.662.444zm.296-1.482q.938 0 1.58-.642.642-.66.642-1.711v-.115q0-.708-.296-1.267a2.2 2.2 0 0 0-.807-.872 2.1 2.1 0 0 0-1.119-.313q-1.053 0-1.629.692-.575.675-.575 1.76 0 1.103.559 1.795.577.675 1.645.675zm6.521-6.237h1.711v1.4q.906-1.597 2.83-1.597 1.596 0 2.584 1.02.988 1.005.988 2.914 0 1.185-.493 2.09a3.46 3.46 0 0 1-1.316 1.399 3.5 3.5 0 0 1-1.844.493q-.954 0-1.662-.329a2.67 2.67 0 0 1-1.086-.97l.017 5.134h-1.728zm4.048 6.22q1.07 0 1.645-.674.577-.69.576-1.762 0-1.119-.576-1.777-.558-.675-1.645-.675-.592 0-1.12.296-.51.28-.822.823-.296.527-.296 1.234v.115q0 .708.296 1.267.313.543.823.855.51.296 1.119.297z'/%3E%3Cpath fill='%23e1e3e9' d='M51.325 4.7h1.86v10.45h3.473v1.646h-5.333zm7.12 4.542h1.843v7.553h-1.843zm.905-1.415a1.16 1.16 0 0 1-.856-.346 1.17 1.17 0 0 1-.346-.856 1.05 1.05 0 0 1 .346-.79q.346-.329.856-.329.494 0 .839.33a1.05 1.05 0 0 1 .345.79 1.16 1.16 0 0 1-.345.855q-.33.346-.84.346zm7.875 9.133a3.17 3.17 0 0 1-1.662-.444q-.723-.46-1.004-1.053l-.033 1.332h-1.71V4.701h1.743v4.657l-.082 1.283q.279-.658 1.086-1.119a3.5 3.5 0 0 1 1.778-.477q1.119 0 1.942.51a3.24 3.24 0 0 1 1.283 1.4q.445.888.444 2.072 0 1.201-.526 2.09a3.5 3.5 0 0 1-1.382 1.366 3.8 3.8 0 0 1-1.876.477zm-.296-1.481q1.069 0 1.645-.675.577-.69.577-1.778 0-1.102-.577-1.776-.56-.691-1.645-.692a2.12 2.12 0 0 0-1.58.659q-.642.641-.642 1.694v.115q0 .71.296 1.267a2.4 2.4 0 0 0 .807.872 2.1 2.1 0 0 0 1.119.313zm5.927-6.237h1.777v1.481q.263-.757.856-1.217a2.14 2.14 0 0 1 1.349-.46q.527 0 .724.098l-.247 1.794q-.149-.099-.642-.099-.774 0-1.416.494-.626.493-.626 1.58v3.883h-1.777V9.242zm9.534 7.718q-1.35 0-2.255-.526-.904-.543-1.332-1.432a4.6 4.6 0 0 1-.428-1.975q0-1.2.493-2.106a3.46 3.46 0 0 1 1.4-1.382q.889-.495 2.007-.494 1.744 0 2.584.97.855.956.856 2.7 0 .444-.05.92h-5.43q.18 1.005.708 1.45.542.443 1.497.443.79 0 1.3-.131a4 4 0 0 0 .938-.362l.542 1.267q-.411.263-1.119.46-.708.198-1.711.197zm1.596-4.558q.016-1.02-.444-1.432-.46-.428-1.316-.428-1.728 0-1.991 1.86z'/%3E%3Cpath d='M5.074 15.948a.484.657 0 0 0-.486.659v1.84a.484.657 0 0 0 .486.659h4.101a.484.657 0 0 0 .486-.659v-1.84a.484.657 0 0 0-.486-.659zm3.56 1.16H5.617v.838h3.017z' style='fill:%23fff;fill-rule:evenodd;stroke-width:1.03600001'/%3E%3Cg style='stroke-width:1.12603545'%3E%3Cpath d='M-9.408-1.416c-3.833-.025-7.056 2.912-7.08 6.615-.02 3.08 1.653 4.832 3.107 6.268.903.892 1.721 1.74 2.32 2.902l-.525-.004c-.543-.003-.992.304-1.24.639a1.87 1.87 0 0 0-.362 1.121l-.011 1.877c-.003.402.104.787.347 1.125.244.338.688.653 1.23.656l4.142.028c.542.003.99-.306 1.238-.641a1.87 1.87 0 0 0 .363-1.121l.012-1.875a1.87 1.87 0 0 0-.348-1.127c-.243-.338-.688-.653-1.23-.656l-.518-.004c.597-1.145 1.425-1.983 2.348-2.87 1.473-1.414 3.18-3.149 3.2-6.226-.016-3.59-2.923-6.684-6.993-6.707m-.006 1.1v.002c3.274.02 5.92 2.532 5.9 5.6-.017 2.706-1.39 4.026-2.863 5.44-1.034.994-2.118 2.033-2.814 3.633-.018.041-.052.055-.075.065q-.013.004-.02.01a.34.34 0 0 1-.226.084.34.34 0 0 1-.224-.086l-.092-.077c-.699-1.615-1.768-2.669-2.781-3.67-1.454-1.435-2.797-2.762-2.78-5.478.02-3.067 2.7-5.545 5.975-5.523m-.02 2.826c-1.62-.01-2.944 1.315-2.955 2.96-.01 1.646 1.295 2.988 2.916 2.999h.002c1.621.01 2.943-1.316 2.953-2.961.011-1.646-1.294-2.988-2.916-2.998m-.005 1.1c1.017.006 1.829.83 1.822 1.89s-.83 1.874-1.848 1.867c-1.018-.006-1.829-.83-1.822-1.89s.83-1.874 1.848-1.868m-2.155 11.857 4.14.025c.271.002.49.305.487.676l-.013 1.875c-.003.37-.224.67-.495.668l-4.14-.025c-.27-.002-.487-.306-.485-.676l.012-1.875c.003-.37.224-.67.494-.668' style='color:%23000;font-style:normal;font-variant:normal;font-weight:400;font-stretch:normal;font-size:medium;line-height:normal;font-family:sans-serif;font-variant-ligatures:normal;font-variant-position:normal;font-variant-caps:normal;font-variant-numeric:normal;font-variant-alternates:normal;font-feature-settings:normal;text-indent:0;text-align:start;text-decoration:none;text-decoration-line:none;text-decoration-style:solid;text-decoration-color:%23000;letter-spacing:normal;word-spacing:normal;text-transform:none;writing-mode:lr-tb;direction:ltr;text-orientation:mixed;dominant-baseline:auto;baseline-shift:baseline;text-anchor:start;white-space:normal;shape-padding:0;clip-rule:evenodd;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:%23000;solid-opacity:1;vector-effect:none;fill:%23000;fill-opacity:.4;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto' transform='translate(15.553 2.85)scale(.88807)'/%3E%3Cpath d='M-9.415-.316C-12.69-.338-15.37 2.14-15.39 5.207c-.017 2.716 1.326 4.041 2.78 5.477 1.013 1 2.081 2.055 2.78 3.67l.092.076a.34.34 0 0 0 .225.086.34.34 0 0 0 .227-.083l.019-.01c.022-.009.057-.024.074-.064.697-1.6 1.78-2.64 2.814-3.634 1.473-1.414 2.847-2.733 2.864-5.44.02-3.067-2.627-5.58-5.901-5.601m-.057 8.784c1.621.011 2.944-1.315 2.955-2.96.01-1.646-1.295-2.988-2.916-2.999-1.622-.01-2.945 1.315-2.955 2.96s1.295 2.989 2.916 3' style='clip-rule:evenodd;fill:%23e1e3e9;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:.4' transform='translate(15.553 2.85)scale(.88807)'/%3E%3Cpath d='M-11.594 15.465c-.27-.002-.492.297-.494.668l-.012 1.876c-.003.371.214.673.485.675l4.14.027c.271.002.492-.298.495-.668l.012-1.877c.003-.37-.215-.672-.485-.674z' style='clip-rule:evenodd;fill:%23fff;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:.4' transform='translate(15.553 2.85)scale(.88807)'/%3E%3C/g%3E%3C/svg%3E\")}}@media (forced-colors:active) and (prefers-color-scheme:light){a.maplibregl-ctrl-logo{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='88' height='23' fill='none'%3E%3Cpath fill='%23000' fill-opacity='.4' fill-rule='evenodd' d='M17.408 16.796h-1.827l2.501-12.095h.198l3.324 6.533.988 2.19.988-2.19 3.258-6.533h.181l2.6 12.095h-1.81l-1.218-5.644-.362-1.71-.658 1.71-2.929 5.644h-.098l-2.914-5.644-.757-1.71-.345 1.71zm1.958-3.42-.726 3.663a1.255 1.255 0 0 1-1.232 1.011h-1.827a1.255 1.255 0 0 1-1.229-1.509l2.501-12.095a1.255 1.255 0 0 1 1.23-1.001h.197a1.25 1.25 0 0 1 1.12.685l3.19 6.273 3.125-6.263a1.25 1.25 0 0 1 1.123-.695h.181a1.255 1.255 0 0 1 1.227.991l1.443 6.71a5 5 0 0 1 .314-.787l.009-.016a4.6 4.6 0 0 1 1.777-1.887c.782-.46 1.668-.667 2.611-.667a4.6 4.6 0 0 1 1.7.32l.306.134c.21-.16.474-.256.759-.256h1.694a1.255 1.255 0 0 1 1.212.925 1.255 1.255 0 0 1 1.212-.925h1.711c.284 0 .545.094.755.252.613-.3 1.312-.45 2.075-.45 1.356 0 2.557.445 3.482 1.4q.47.48.763 1.064V4.701a1.255 1.255 0 0 1 1.255-1.255h1.86A1.255 1.255 0 0 1 54.44 4.7v9.194h2.217c.19 0 .37.043.532.118v-4.77c0-.356.147-.678.385-.906a2.42 2.42 0 0 1-.682-1.71c0-.665.267-1.253.735-1.7a2.45 2.45 0 0 1 1.722-.674 2.43 2.43 0 0 1 1.705.675q.318.302.504.683V4.7a1.255 1.255 0 0 1 1.255-1.255h1.744A1.255 1.255 0 0 1 65.812 4.7v3.335a4.8 4.8 0 0 1 1.526-.246c.938 0 1.817.214 2.59.69a4.47 4.47 0 0 1 1.67 1.743v-.98a1.255 1.255 0 0 1 1.256-1.256h1.777c.233 0 .451.064.639.174a3.4 3.4 0 0 1 1.567-.372c.346 0 .861.02 1.285.232a1.25 1.25 0 0 1 .689 1.004 4.7 4.7 0 0 1 .853-.588c.795-.44 1.675-.647 2.61-.647 1.385 0 2.65.39 3.525 1.396.836.938 1.168 2.173 1.168 3.528q-.001.515-.056 1.051a1.255 1.255 0 0 1-.947 1.09l.408.952a1.255 1.255 0 0 1-.477 1.552c-.418.268-.92.463-1.458.612-.613.171-1.304.244-2.049.244-1.06 0-2.043-.207-2.886-.698l-.015-.008c-.798-.48-1.419-1.135-1.818-1.963l-.004-.008a5.8 5.8 0 0 1-.548-2.512q0-.429.053-.843a1.3 1.3 0 0 1-.333-.086l-.166-.004c-.223 0-.426.062-.643.228-.03.024-.142.139-.142.59v3.883a1.255 1.255 0 0 1-1.256 1.256h-1.777a1.255 1.255 0 0 1-1.256-1.256V15.69l-.032.057a4.8 4.8 0 0 1-1.86 1.833 5.04 5.04 0 0 1-2.484.634 4.5 4.5 0 0 1-1.935-.424 1.25 1.25 0 0 1-.764.258h-1.71a1.255 1.255 0 0 1-1.256-1.255V7.687a2.4 2.4 0 0 1-.428.625c.253.23.412.561.412.93v7.553a1.255 1.255 0 0 1-1.256 1.255h-1.843a1.25 1.25 0 0 1-.894-.373c-.228.23-.544.373-.894.373H51.32a1.255 1.255 0 0 1-1.256-1.255v-1.251l-.061.117a4.7 4.7 0 0 1-1.782 1.884 4.77 4.77 0 0 1-2.485.67 5.6 5.6 0 0 1-1.485-.188l.009 2.764a1.255 1.255 0 0 1-1.255 1.259h-1.729a1.255 1.255 0 0 1-1.255-1.255v-3.537a1.255 1.255 0 0 1-1.167.793h-1.679a1.25 1.25 0 0 1-.77-.263 4.5 4.5 0 0 1-1.945.429c-.885 0-1.724-.21-2.495-.632l-.017-.01a5 5 0 0 1-1.081-.836 1.255 1.255 0 0 1-1.254 1.312h-1.81a1.255 1.255 0 0 1-1.228-.99l-.782-3.625-2.044 3.939a1.25 1.25 0 0 1-1.115.676h-.098a1.25 1.25 0 0 1-1.116-.68l-2.061-3.994zM35.92 16.63l.207-.114.223-.15q.493-.356.735-.785l.061-.118.033 1.332h1.678V9.242h-1.694l-.033 1.267q-.133-.329-.526-.658l-.032-.028a3.2 3.2 0 0 0-.668-.428l-.27-.12a3.3 3.3 0 0 0-1.235-.23q-1.136-.001-1.974.493a3.36 3.36 0 0 0-1.3 1.382q-.445.89-.444 2.074 0 1.2.51 2.107a3.8 3.8 0 0 0 1.382 1.381 3.9 3.9 0 0 0 1.893.477q.795 0 1.455-.33zm-2.789-5.38q-.576.675-.575 1.762 0 1.102.559 1.794.576.675 1.645.675a2.25 2.25 0 0 0 .934-.19 2.2 2.2 0 0 0 .468-.29l.178-.161a2.2 2.2 0 0 0 .397-.561q.244-.5.244-1.15v-.115q0-.708-.296-1.267l-.043-.077a2.2 2.2 0 0 0-.633-.709l-.13-.086-.047-.028a2.1 2.1 0 0 0-1.073-.285q-1.052 0-1.629.692zm2.316 2.706c.163-.17.28-.407.28-.83v-.114c0-.292-.06-.508-.15-.68a.96.96 0 0 0-.353-.389.85.85 0 0 0-.464-.127c-.4 0-.56.114-.664.239l-.01.012c-.148.174-.275.45-.275.945 0 .506.122.801.27.99.097.11.266.224.68.224.303 0 .504-.09.687-.269zm7.545 1.705a2.6 2.6 0 0 0 .331.423q.319.33.755.548l.173.074q.65.255 1.49.255 1.02 0 1.844-.493a3.45 3.45 0 0 0 1.316-1.4q.493-.904.493-2.089 0-1.909-.988-2.913-.988-1.02-2.584-1.02-.898 0-1.575.347a3 3 0 0 0-.415.262l-.199.166a3.4 3.4 0 0 0-.64.82V9.242h-1.712v11.553h1.729l-.017-5.134zm.53-1.138q.206.29.48.5l.155.11.053.034q.51.296 1.119.297 1.07 0 1.645-.675.577-.69.576-1.762 0-1.119-.576-1.777-.558-.675-1.645-.675-.435 0-.835.16a2 2 0 0 0-.284.136 2 2 0 0 0-.363.254 2.2 2.2 0 0 0-.46.569l-.082.162a2.6 2.6 0 0 0-.213 1.072v.115q0 .707.296 1.267l.135.211zm.964-.818a1.1 1.1 0 0 0 .367.385.94.94 0 0 0 .476.118c.423 0 .59-.117.687-.23.159-.194.28-.478.28-.95 0-.53-.133-.8-.266-.952l-.021-.025c-.078-.094-.231-.221-.68-.221a1 1 0 0 0-.503.135l-.012.007a.86.86 0 0 0-.335.343c-.073.133-.132.324-.132.614v.115a1.4 1.4 0 0 0 .14.66zm15.7-6.222q.347-.346.346-.856a1.05 1.05 0 0 0-.345-.79 1.18 1.18 0 0 0-.84-.329q-.51 0-.855.33a1.05 1.05 0 0 0-.346.79q0 .51.346.855.345.346.856.346.51 0 .839-.346zm4.337 9.314.033-1.332q.191.403.59.747l.098.081a4 4 0 0 0 .316.224l.223.122a3.2 3.2 0 0 0 1.44.322 3.8 3.8 0 0 0 1.875-.477 3.5 3.5 0 0 0 1.382-1.366q.527-.89.526-2.09 0-1.184-.444-2.073a3.24 3.24 0 0 0-1.283-1.399q-.823-.51-1.942-.51a3.5 3.5 0 0 0-1.527.344l-.086.043-.165.09a3 3 0 0 0-.33.214q-.432.315-.656.707a2 2 0 0 0-.099.198l.082-1.283V4.701h-1.744v12.095zm.473-2.509a2.5 2.5 0 0 0 .566.7q.117.098.245.18l.144.08a2.1 2.1 0 0 0 .975.232q1.07 0 1.645-.675.576-.69.576-1.778 0-1.102-.576-1.777-.56-.691-1.645-.692a2.2 2.2 0 0 0-1.015.235q-.22.113-.415.282l-.15.142a2.1 2.1 0 0 0-.42.594q-.223.479-.223 1.1v.115q0 .705.293 1.26zm2.616-.293c.157-.191.28-.479.28-.967 0-.51-.13-.79-.276-.961l-.021-.026c-.082-.1-.232-.225-.67-.225a.87.87 0 0 0-.681.279l-.012.011c-.154.155-.274.38-.274.807v.115c0 .285.057.499.144.669a1.1 1.1 0 0 0 .367.405c.137.082.28.123.455.123.423 0 .59-.118.686-.23zm8.266-3.013q.345-.13.724-.14l.069-.002q.493 0 .642.099l.247-1.794q-.196-.099-.717-.099a2.3 2.3 0 0 0-.545.063 2 2 0 0 0-.411.148 2.2 2.2 0 0 0-.4.249 2.5 2.5 0 0 0-.485.499 2.7 2.7 0 0 0-.32.581l-.05.137v-1.48h-1.778v7.553h1.777v-3.884q0-.546.159-.943a1.5 1.5 0 0 1 .466-.636 2.5 2.5 0 0 1 .399-.253 2 2 0 0 1 .224-.099zm9.784 2.656.05-.922q0-1.743-.856-2.698-.838-.97-2.584-.97-1.119-.001-2.007.493a3.46 3.46 0 0 0-1.4 1.382q-.493.906-.493 2.106 0 1.07.428 1.975.428.89 1.332 1.432.906.526 2.255.526.973 0 1.668-.185l.044-.012.135-.04q.613-.184.984-.421l-.542-1.267q-.3.162-.642.274l-.297.087q-.51.131-1.3.131-.954 0-1.497-.444a1.6 1.6 0 0 1-.192-.193q-.366-.44-.512-1.234l-.004-.021zm-5.427-1.256-.003.022h3.752v-.138q-.011-.727-.288-1.118a1 1 0 0 0-.156-.176q-.46-.428-1.316-.428-.986 0-1.494.604-.379.45-.494 1.234zm-27.053 2.77V4.7h-1.86v12.095h5.333V15.15zm7.103-5.908v7.553h-1.843V9.242h1.843z'/%3E%3Cpath fill='%23fff' d='m19.63 11.151-.757-1.71-.345 1.71-1.12 5.644h-1.827L18.083 4.7h.197l3.325 6.533.988 2.19.988-2.19L26.839 4.7h.181l2.6 12.095h-1.81l-1.218-5.644-.362-1.71-.658 1.71-2.93 5.644h-.098l-2.913-5.644zm14.836 5.81q-1.02 0-1.893-.478a3.8 3.8 0 0 1-1.381-1.382q-.51-.906-.51-2.106 0-1.185.444-2.074a3.36 3.36 0 0 1 1.3-1.382q.839-.494 1.974-.494a3.3 3.3 0 0 1 1.234.231 3.3 3.3 0 0 1 .97.575q.396.33.527.659l.033-1.267h1.694v7.553H37.18l-.033-1.332q-.279.593-1.02 1.053a3.17 3.17 0 0 1-1.662.444zm.296-1.482q.938 0 1.58-.642.642-.66.642-1.711v-.115q0-.708-.296-1.267a2.2 2.2 0 0 0-.807-.872 2.1 2.1 0 0 0-1.119-.313q-1.053 0-1.629.692-.575.675-.575 1.76 0 1.103.559 1.795.577.675 1.645.675zm6.521-6.237h1.711v1.4q.906-1.597 2.83-1.597 1.596 0 2.584 1.02.988 1.005.988 2.914 0 1.185-.493 2.09a3.46 3.46 0 0 1-1.316 1.399 3.5 3.5 0 0 1-1.844.493q-.954 0-1.662-.329a2.67 2.67 0 0 1-1.086-.97l.017 5.134h-1.728zm4.048 6.22q1.07 0 1.645-.674.577-.69.576-1.762 0-1.119-.576-1.777-.558-.675-1.645-.675-.592 0-1.12.296-.51.28-.822.823-.296.527-.296 1.234v.115q0 .708.296 1.267.313.543.823.855.51.296 1.119.297z'/%3E%3Cpath fill='%23e1e3e9' d='M51.325 4.7h1.86v10.45h3.473v1.646h-5.333zm7.12 4.542h1.843v7.553h-1.843zm.905-1.415a1.16 1.16 0 0 1-.856-.346 1.17 1.17 0 0 1-.346-.856 1.05 1.05 0 0 1 .346-.79q.346-.329.856-.329.494 0 .839.33a1.05 1.05 0 0 1 .345.79 1.16 1.16 0 0 1-.345.855q-.33.346-.84.346zm7.875 9.133a3.17 3.17 0 0 1-1.662-.444q-.723-.46-1.004-1.053l-.033 1.332h-1.71V4.701h1.743v4.657l-.082 1.283q.279-.658 1.086-1.119a3.5 3.5 0 0 1 1.778-.477q1.119 0 1.942.51a3.24 3.24 0 0 1 1.283 1.4q.445.888.444 2.072 0 1.201-.526 2.09a3.5 3.5 0 0 1-1.382 1.366 3.8 3.8 0 0 1-1.876.477zm-.296-1.481q1.069 0 1.645-.675.577-.69.577-1.778 0-1.102-.577-1.776-.56-.691-1.645-.692a2.12 2.12 0 0 0-1.58.659q-.642.641-.642 1.694v.115q0 .71.296 1.267a2.4 2.4 0 0 0 .807.872 2.1 2.1 0 0 0 1.119.313zm5.927-6.237h1.777v1.481q.263-.757.856-1.217a2.14 2.14 0 0 1 1.349-.46q.527 0 .724.098l-.247 1.794q-.149-.099-.642-.099-.774 0-1.416.494-.626.493-.626 1.58v3.883h-1.777V9.242zm9.534 7.718q-1.35 0-2.255-.526-.904-.543-1.332-1.432a4.6 4.6 0 0 1-.428-1.975q0-1.2.493-2.106a3.46 3.46 0 0 1 1.4-1.382q.889-.495 2.007-.494 1.744 0 2.584.97.855.956.856 2.7 0 .444-.05.92h-5.43q.18 1.005.708 1.45.542.443 1.497.443.79 0 1.3-.131a4 4 0 0 0 .938-.362l.542 1.267q-.411.263-1.119.46-.708.198-1.711.197zm1.596-4.558q.016-1.02-.444-1.432-.46-.428-1.316-.428-1.728 0-1.991 1.86z'/%3E%3Cpath d='M5.074 15.948a.484.657 0 0 0-.486.659v1.84a.484.657 0 0 0 .486.659h4.101a.484.657 0 0 0 .486-.659v-1.84a.484.657 0 0 0-.486-.659zm3.56 1.16H5.617v.838h3.017z' style='fill:%23fff;fill-rule:evenodd;stroke-width:1.03600001'/%3E%3Cg style='stroke-width:1.12603545'%3E%3Cpath d='M-9.408-1.416c-3.833-.025-7.056 2.912-7.08 6.615-.02 3.08 1.653 4.832 3.107 6.268.903.892 1.721 1.74 2.32 2.902l-.525-.004c-.543-.003-.992.304-1.24.639a1.87 1.87 0 0 0-.362 1.121l-.011 1.877c-.003.402.104.787.347 1.125.244.338.688.653 1.23.656l4.142.028c.542.003.99-.306 1.238-.641a1.87 1.87 0 0 0 .363-1.121l.012-1.875a1.87 1.87 0 0 0-.348-1.127c-.243-.338-.688-.653-1.23-.656l-.518-.004c.597-1.145 1.425-1.983 2.348-2.87 1.473-1.414 3.18-3.149 3.2-6.226-.016-3.59-2.923-6.684-6.993-6.707m-.006 1.1v.002c3.274.02 5.92 2.532 5.9 5.6-.017 2.706-1.39 4.026-2.863 5.44-1.034.994-2.118 2.033-2.814 3.633-.018.041-.052.055-.075.065q-.013.004-.02.01a.34.34 0 0 1-.226.084.34.34 0 0 1-.224-.086l-.092-.077c-.699-1.615-1.768-2.669-2.781-3.67-1.454-1.435-2.797-2.762-2.78-5.478.02-3.067 2.7-5.545 5.975-5.523m-.02 2.826c-1.62-.01-2.944 1.315-2.955 2.96-.01 1.646 1.295 2.988 2.916 2.999h.002c1.621.01 2.943-1.316 2.953-2.961.011-1.646-1.294-2.988-2.916-2.998m-.005 1.1c1.017.006 1.829.83 1.822 1.89s-.83 1.874-1.848 1.867c-1.018-.006-1.829-.83-1.822-1.89s.83-1.874 1.848-1.868m-2.155 11.857 4.14.025c.271.002.49.305.487.676l-.013 1.875c-.003.37-.224.67-.495.668l-4.14-.025c-.27-.002-.487-.306-.485-.676l.012-1.875c.003-.37.224-.67.494-.668' style='color:%23000;font-style:normal;font-variant:normal;font-weight:400;font-stretch:normal;font-size:medium;line-height:normal;font-family:sans-serif;font-variant-ligatures:normal;font-variant-position:normal;font-variant-caps:normal;font-variant-numeric:normal;font-variant-alternates:normal;font-feature-settings:normal;text-indent:0;text-align:start;text-decoration:none;text-decoration-line:none;text-decoration-style:solid;text-decoration-color:%23000;letter-spacing:normal;word-spacing:normal;text-transform:none;writing-mode:lr-tb;direction:ltr;text-orientation:mixed;dominant-baseline:auto;baseline-shift:baseline;text-anchor:start;white-space:normal;shape-padding:0;clip-rule:evenodd;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:%23000;solid-opacity:1;vector-effect:none;fill:%23000;fill-opacity:.4;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto' transform='translate(15.553 2.85)scale(.88807)'/%3E%3Cpath d='M-9.415-.316C-12.69-.338-15.37 2.14-15.39 5.207c-.017 2.716 1.326 4.041 2.78 5.477 1.013 1 2.081 2.055 2.78 3.67l.092.076a.34.34 0 0 0 .225.086.34.34 0 0 0 .227-.083l.019-.01c.022-.009.057-.024.074-.064.697-1.6 1.78-2.64 2.814-3.634 1.473-1.414 2.847-2.733 2.864-5.44.02-3.067-2.627-5.58-5.901-5.601m-.057 8.784c1.621.011 2.944-1.315 2.955-2.96.01-1.646-1.295-2.988-2.916-2.999-1.622-.01-2.945 1.315-2.955 2.96s1.295 2.989 2.916 3' style='clip-rule:evenodd;fill:%23e1e3e9;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:.4' transform='translate(15.553 2.85)scale(.88807)'/%3E%3Cpath d='M-11.594 15.465c-.27-.002-.492.297-.494.668l-.012 1.876c-.003.371.214.673.485.675l4.14.027c.271.002.492-.298.495-.668l.012-1.877c.003-.37-.215-.672-.485-.674z' style='clip-rule:evenodd;fill:%23fff;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2.47727823;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:.4' transform='translate(15.553 2.85)scale(.88807)'/%3E%3C/g%3E%3C/svg%3E\")}}.maplibregl-ctrl.maplibregl-ctrl-attrib{background-color:hsla(0,0%,100%,.5);margin:0;padding:0 5px}@media screen{.maplibregl-ctrl-attrib.maplibregl-compact{background-color:#fff;border-radius:12px;box-sizing:content-box;color:#000;margin:10px;min-height:20px;padding:2px 24px 2px 0;position:relative}.maplibregl-ctrl-attrib.maplibregl-compact-show{padding:2px 28px 2px 8px;visibility:visible}.maplibregl-ctrl-bottom-left>.maplibregl-ctrl-attrib.maplibregl-compact-show,.maplibregl-ctrl-top-left>.maplibregl-ctrl-attrib.maplibregl-compact-show{border-radius:12px;padding:2px 8px 2px 28px}.maplibregl-ctrl-attrib.maplibregl-compact .maplibregl-ctrl-attrib-inner{display:none}.maplibregl-ctrl-attrib-button{background-color:hsla(0,0%,100%,.5);background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill-rule='evenodd' viewBox='0 0 20 20'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E\");border:0;border-radius:12px;box-sizing:border-box;cursor:pointer;display:none;height:24px;outline:none;position:absolute;right:0;top:0;width:24px}.maplibregl-ctrl-attrib summary.maplibregl-ctrl-attrib-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;list-style:none}.maplibregl-ctrl-attrib summary.maplibregl-ctrl-attrib-button::-webkit-details-marker{display:none}.maplibregl-ctrl-bottom-left .maplibregl-ctrl-attrib-button,.maplibregl-ctrl-top-left .maplibregl-ctrl-attrib-button{left:0}.maplibregl-ctrl-attrib.maplibregl-compact .maplibregl-ctrl-attrib-button,.maplibregl-ctrl-attrib.maplibregl-compact-show .maplibregl-ctrl-attrib-inner{display:block}.maplibregl-ctrl-attrib.maplibregl-compact-show .maplibregl-ctrl-attrib-button{background-color:rgb(0 0 0/5%)}.maplibregl-ctrl-bottom-right>.maplibregl-ctrl-attrib.maplibregl-compact:after{bottom:0;right:0}.maplibregl-ctrl-top-right>.maplibregl-ctrl-attrib.maplibregl-compact:after{right:0;top:0}.maplibregl-ctrl-top-left>.maplibregl-ctrl-attrib.maplibregl-compact:after{left:0;top:0}.maplibregl-ctrl-bottom-left>.maplibregl-ctrl-attrib.maplibregl-compact:after{bottom:0;left:0}}@media screen and (forced-colors:active){.maplibregl-ctrl-attrib.maplibregl-compact:after{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='%23fff' fill-rule='evenodd' viewBox='0 0 20 20'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E\")}}@media screen and (forced-colors:active) and (prefers-color-scheme:light){.maplibregl-ctrl-attrib.maplibregl-compact:after{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill-rule='evenodd' viewBox='0 0 20 20'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E\")}}.maplibregl-ctrl-attrib a{color:rgba(0,0,0,.75);text-decoration:none}.maplibregl-ctrl-attrib a:hover{color:inherit;text-decoration:underline}.maplibregl-attrib-empty{display:none}.maplibregl-ctrl-scale{background-color:hsla(0,0%,100%,.75);border:2px solid #333;border-top:#333;box-sizing:border-box;color:#333;font-size:10px;padding:0 5px}.maplibregl-popup{display:flex;left:0;pointer-events:none;position:absolute;top:0;will-change:transform}.maplibregl-popup-anchor-top,.maplibregl-popup-anchor-top-left,.maplibregl-popup-anchor-top-right{flex-direction:column}.maplibregl-popup-anchor-bottom,.maplibregl-popup-anchor-bottom-left,.maplibregl-popup-anchor-bottom-right{flex-direction:column-reverse}.maplibregl-popup-anchor-left{flex-direction:row}.maplibregl-popup-anchor-right{flex-direction:row-reverse}.maplibregl-popup-tip{border:10px solid transparent;height:0;width:0;z-index:1}.maplibregl-popup-anchor-top .maplibregl-popup-tip{align-self:center;border-bottom-color:#fff;border-top:none}.maplibregl-popup-anchor-top-left .maplibregl-popup-tip{align-self:flex-start;border-bottom-color:#fff;border-left:none;border-top:none}.maplibregl-popup-anchor-top-right .maplibregl-popup-tip{align-self:flex-end;border-bottom-color:#fff;border-right:none;border-top:none}.maplibregl-popup-anchor-bottom .maplibregl-popup-tip{align-self:center;border-bottom:none;border-top-color:#fff}.maplibregl-popup-anchor-bottom-left .maplibregl-popup-tip{align-self:flex-start;border-bottom:none;border-left:none;border-top-color:#fff}.maplibregl-popup-anchor-bottom-right .maplibregl-popup-tip{align-self:flex-end;border-bottom:none;border-right:none;border-top-color:#fff}.maplibregl-popup-anchor-left .maplibregl-popup-tip{align-self:center;border-left:none;border-right-color:#fff}.maplibregl-popup-anchor-right .maplibregl-popup-tip{align-self:center;border-left-color:#fff;border-right:none}.maplibregl-popup-close-button{background-color:transparent;border:0;border-radius:0 3px 0 0;cursor:pointer;position:absolute;right:0;top:0}.maplibregl-popup-close-button:hover{background-color:rgb(0 0 0/5%)}.maplibregl-popup-content{background:#fff;border-radius:3px;box-shadow:0 1px 2px rgba(0,0,0,.1);padding:15px 10px;pointer-events:auto;position:relative}.maplibregl-popup-anchor-top-left .maplibregl-popup-content{border-top-left-radius:0}.maplibregl-popup-anchor-top-right .maplibregl-popup-content{border-top-right-radius:0}.maplibregl-popup-anchor-bottom-left .maplibregl-popup-content{border-bottom-left-radius:0}.maplibregl-popup-anchor-bottom-right .maplibregl-popup-content{border-bottom-right-radius:0}.maplibregl-popup-track-pointer{display:none}.maplibregl-popup-track-pointer *{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.maplibregl-map:hover .maplibregl-popup-track-pointer{display:flex}.maplibregl-map:active .maplibregl-popup-track-pointer{display:none}.maplibregl-marker{left:0;position:absolute;top:0;transition:opacity .2s;will-change:transform}.maplibregl-user-location-dot,.maplibregl-user-location-dot:before{background-color:#1da1f2;border-radius:50%;height:15px;width:15px}.maplibregl-user-location-dot:before{animation:maplibregl-user-location-dot-pulse 2s infinite;content:\"\";position:absolute}.maplibregl-user-location-dot:after{border:2px solid #fff;border-radius:50%;box-shadow:0 0 3px rgba(0,0,0,.35);box-sizing:border-box;content:\"\";height:19px;left:-2px;position:absolute;top:-2px;width:19px}@keyframes maplibregl-user-location-dot-pulse{0%{opacity:1;transform:scale(1)}70%{opacity:0;transform:scale(3)}to{opacity:0;transform:scale(1)}}.maplibregl-user-location-dot-stale{background-color:#aaa}.maplibregl-user-location-dot-stale:after{display:none}.maplibregl-user-location-accuracy-circle{background-color:#1da1f233;border-radius:100%;height:1px;width:1px}.maplibregl-crosshair,.maplibregl-crosshair .maplibregl-interactive,.maplibregl-crosshair .maplibregl-interactive:active{cursor:crosshair}.maplibregl-boxzoom{background:#fff;border:2px dotted #202020;height:0;left:0;opacity:.5;position:absolute;top:0;width:0}.maplibregl-cooperative-gesture-screen{align-items:center;background:rgba(0,0,0,.4);color:#fff;display:flex;font-size:1.4em;inset:0;justify-content:center;line-height:1.2;opacity:0;padding:1rem;pointer-events:none;position:absolute;transition:opacity 1s ease 1s;z-index:99999}.maplibregl-cooperative-gesture-screen.maplibregl-show{opacity:1;transition:opacity .05s}.maplibregl-cooperative-gesture-screen .maplibregl-mobile-message{display:none}@media (hover:none),(width <= 480px){.maplibregl-cooperative-gesture-screen .maplibregl-desktop-message{display:none}.maplibregl-cooperative-gesture-screen .maplibregl-mobile-message{display:block}}.maplibregl-pseudo-fullscreen{height:100%!important;left:0!important;position:fixed!important;top:0!important;width:100%!important;z-index:99999}","/* this gets exported as style.css and can be used for the default theming */\n/* these are the necessary styles for React Flow, they get used by base.css and style.css */\n.react-flow {\n direction: ltr;\n}\n.react-flow__container {\n position: absolute;\n width: 100%;\n height: 100%;\n top: 0;\n left: 0;\n}\n.react-flow__pane {\n z-index: 1;\n cursor: -webkit-grab;\n cursor: grab;\n}\n.react-flow__pane.selection {\n cursor: pointer;\n }\n.react-flow__pane.dragging {\n cursor: -webkit-grabbing;\n cursor: grabbing;\n }\n.react-flow__viewport {\n transform-origin: 0 0;\n z-index: 2;\n pointer-events: none;\n}\n.react-flow__renderer {\n z-index: 4;\n}\n.react-flow__selection {\n z-index: 6;\n}\n.react-flow__nodesselection-rect:focus,\n.react-flow__nodesselection-rect:focus-visible {\n outline: none;\n}\n.react-flow .react-flow__edges {\n pointer-events: none;\n overflow: visible;\n}\n.react-flow__edge-path,\n.react-flow__connection-path {\n stroke: #b1b1b7;\n stroke-width: 1;\n fill: none;\n}\n.react-flow__edge {\n pointer-events: visibleStroke;\n cursor: pointer;\n}\n.react-flow__edge.animated path {\n stroke-dasharray: 5;\n -webkit-animation: dashdraw 0.5s linear infinite;\n animation: dashdraw 0.5s linear infinite;\n }\n.react-flow__edge.animated path.react-flow__edge-interaction {\n stroke-dasharray: none;\n -webkit-animation: none;\n animation: none;\n }\n.react-flow__edge.inactive {\n pointer-events: none;\n }\n.react-flow__edge.selected,\n .react-flow__edge:focus,\n .react-flow__edge:focus-visible {\n outline: none;\n }\n.react-flow__edge.selected .react-flow__edge-path,\n .react-flow__edge:focus .react-flow__edge-path,\n .react-flow__edge:focus-visible .react-flow__edge-path {\n stroke: #555;\n }\n.react-flow__edge-textwrapper {\n pointer-events: all;\n }\n.react-flow__edge-textbg {\n fill: white;\n }\n.react-flow__edge .react-flow__edge-text {\n pointer-events: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n }\n.react-flow__connection {\n pointer-events: none;\n}\n.react-flow__connection .animated {\n stroke-dasharray: 5;\n -webkit-animation: dashdraw 0.5s linear infinite;\n animation: dashdraw 0.5s linear infinite;\n }\n.react-flow__connectionline {\n z-index: 1001;\n}\n.react-flow__nodes {\n pointer-events: none;\n transform-origin: 0 0;\n}\n.react-flow__node {\n position: absolute;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n pointer-events: all;\n transform-origin: 0 0;\n box-sizing: border-box;\n cursor: -webkit-grab;\n cursor: grab;\n}\n.react-flow__node.dragging {\n cursor: -webkit-grabbing;\n cursor: grabbing;\n }\n.react-flow__nodesselection {\n z-index: 3;\n transform-origin: left top;\n pointer-events: none;\n}\n.react-flow__nodesselection-rect {\n position: absolute;\n pointer-events: all;\n cursor: -webkit-grab;\n cursor: grab;\n }\n.react-flow__handle {\n position: absolute;\n pointer-events: none;\n min-width: 5px;\n min-height: 5px;\n width: 6px;\n height: 6px;\n background: #1a192b;\n border: 1px solid white;\n border-radius: 100%;\n}\n.react-flow__handle.connectionindicator {\n pointer-events: all;\n cursor: crosshair;\n }\n.react-flow__handle-bottom {\n top: auto;\n left: 50%;\n bottom: -4px;\n transform: translate(-50%, 0);\n }\n.react-flow__handle-top {\n left: 50%;\n top: -4px;\n transform: translate(-50%, 0);\n }\n.react-flow__handle-left {\n top: 50%;\n left: -4px;\n transform: translate(0, -50%);\n }\n.react-flow__handle-right {\n right: -4px;\n top: 50%;\n transform: translate(0, -50%);\n }\n.react-flow__edgeupdater {\n cursor: move;\n pointer-events: all;\n}\n.react-flow__panel {\n position: absolute;\n z-index: 5;\n margin: 15px;\n}\n.react-flow__panel.top {\n top: 0;\n }\n.react-flow__panel.bottom {\n bottom: 0;\n }\n.react-flow__panel.left {\n left: 0;\n }\n.react-flow__panel.right {\n right: 0;\n }\n.react-flow__panel.center {\n left: 50%;\n transform: translateX(-50%);\n }\n.react-flow__attribution {\n font-size: 10px;\n background: rgba(255, 255, 255, 0.5);\n padding: 2px 3px;\n margin: 0;\n}\n.react-flow__attribution a {\n text-decoration: none;\n color: #999;\n }\n@-webkit-keyframes dashdraw {\n from {\n stroke-dashoffset: 10;\n }\n}\n@keyframes dashdraw {\n from {\n stroke-dashoffset: 10;\n }\n}\n.react-flow__edgelabel-renderer {\n position: absolute;\n width: 100%;\n height: 100%;\n pointer-events: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n}\n.react-flow__edge.updating .react-flow__edge-path {\n stroke: #777;\n }\n.react-flow__edge-text {\n font-size: 10px;\n }\n.react-flow__node.selectable:focus,\n .react-flow__node.selectable:focus-visible {\n outline: none;\n }\n.react-flow__node-default,\n.react-flow__node-input,\n.react-flow__node-output,\n.react-flow__node-group {\n padding: 10px;\n border-radius: 3px;\n width: 150px;\n font-size: 12px;\n color: #222;\n text-align: center;\n border-width: 1px;\n border-style: solid;\n border-color: #1a192b;\n background-color: white;\n}\n.react-flow__node-default.selectable:hover, .react-flow__node-input.selectable:hover, .react-flow__node-output.selectable:hover, .react-flow__node-group.selectable:hover {\n box-shadow: 0 1px 4px 1px rgba(0, 0, 0, 0.08);\n }\n.react-flow__node-default.selectable.selected,\n .react-flow__node-default.selectable:focus,\n .react-flow__node-default.selectable:focus-visible,\n .react-flow__node-input.selectable.selected,\n .react-flow__node-input.selectable:focus,\n .react-flow__node-input.selectable:focus-visible,\n .react-flow__node-output.selectable.selected,\n .react-flow__node-output.selectable:focus,\n .react-flow__node-output.selectable:focus-visible,\n .react-flow__node-group.selectable.selected,\n .react-flow__node-group.selectable:focus,\n .react-flow__node-group.selectable:focus-visible {\n box-shadow: 0 0 0 0.5px #1a192b;\n }\n.react-flow__node-group {\n background-color: rgba(240, 240, 240, 0.25);\n}\n.react-flow__nodesselection-rect,\n.react-flow__selection {\n background: rgba(0, 89, 220, 0.08);\n border: 1px dotted rgba(0, 89, 220, 0.8);\n}\n.react-flow__nodesselection-rect:focus,\n .react-flow__nodesselection-rect:focus-visible,\n .react-flow__selection:focus,\n .react-flow__selection:focus-visible {\n outline: none;\n }\n.react-flow__controls {\n box-shadow: 0 0 2px 1px rgba(0, 0, 0, 0.08);\n}\n.react-flow__controls-button {\n border: none;\n background: #fefefe;\n border-bottom: 1px solid #eee;\n box-sizing: content-box;\n display: flex;\n justify-content: center;\n align-items: center;\n width: 16px;\n height: 16px;\n cursor: pointer;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n padding: 5px;\n }\n.react-flow__controls-button:hover {\n background: #f4f4f4;\n }\n.react-flow__controls-button svg {\n width: 100%;\n max-width: 12px;\n max-height: 12px;\n }\n.react-flow__controls-button:disabled {\n pointer-events: none;\n }\n.react-flow__controls-button:disabled svg {\n fill-opacity: 0.4;\n }\n.react-flow__minimap {\n background-color: #fff;\n}\n.react-flow__minimap svg {\n display: block;\n}\n.react-flow__resize-control {\n position: absolute;\n}\n.react-flow__resize-control.left,\n.react-flow__resize-control.right {\n cursor: ew-resize;\n}\n.react-flow__resize-control.top,\n.react-flow__resize-control.bottom {\n cursor: ns-resize;\n}\n.react-flow__resize-control.top.left,\n.react-flow__resize-control.bottom.right {\n cursor: nwse-resize;\n}\n.react-flow__resize-control.bottom.left,\n.react-flow__resize-control.top.right {\n cursor: nesw-resize;\n}\n/* handle styles */\n.react-flow__resize-control.handle {\n width: 4px;\n height: 4px;\n border: 1px solid #fff;\n border-radius: 1px;\n background-color: #3367d9;\n transform: translate(-50%, -50%);\n}\n.react-flow__resize-control.handle.left {\n left: 0;\n top: 50%;\n}\n.react-flow__resize-control.handle.right {\n left: 100%;\n top: 50%;\n}\n.react-flow__resize-control.handle.top {\n left: 50%;\n top: 0;\n}\n.react-flow__resize-control.handle.bottom {\n left: 50%;\n top: 100%;\n}\n.react-flow__resize-control.handle.top.left {\n left: 0;\n}\n.react-flow__resize-control.handle.bottom.left {\n left: 0;\n}\n.react-flow__resize-control.handle.top.right {\n left: 100%;\n}\n.react-flow__resize-control.handle.bottom.right {\n left: 100%;\n}\n/* line styles */\n.react-flow__resize-control.line {\n border-color: #3367d9;\n border-width: 0;\n border-style: solid;\n}\n.react-flow__resize-control.line.left,\n.react-flow__resize-control.line.right {\n width: 1px;\n transform: translate(-50%, 0);\n top: 0;\n height: 100%;\n}\n.react-flow__resize-control.line.left {\n left: 0;\n border-left-width: 1px;\n}\n.react-flow__resize-control.line.right {\n left: 100%;\n border-right-width: 1px;\n}\n.react-flow__resize-control.line.top,\n.react-flow__resize-control.line.bottom {\n height: 1px;\n transform: translate(0, -50%);\n left: 0;\n width: 100%;\n}\n.react-flow__resize-control.line.top {\n top: 0;\n border-top-width: 1px;\n}\n.react-flow__resize-control.line.bottom {\n border-bottom-width: 1px;\n top: 100%;\n}\n",".flow {\n flex-direction: column;\n display: flex;\n height: 100%;\n}\n\n.flow aside {\n border-right: 1px solid #eee;\n padding: 15px 10px;\n font-size: 12px;\n background: #fcfcfc;\n}\n\n.flow aside > * {\n margin-bottom: 10px;\n cursor: grab;\n}\n\n.flow .reactflow-wrapper {\n flex-grow: 1;\n height: 100%;\n}\n\n@media screen and (min-width: 768px) {\n .flow {\n flex-direction: row;\n }\n\n .flow aside {\n width: 20%;\n max-width: 180px;\n }\n}\n\n.outputkey {\n margin-left: auto;\n margin-right: auto;\n width: 8em;\n}\n\n.selectFilePath {\n text-underline-offset: 3px;\n word-break: break-all;\n display: inline-block;\n max-width: 95%;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n.algoName {\n text-underline-offset: 3px;\n word-break: break-all;\n display: inline-block;\n max-width: 85%;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n",".flowbutton {\n width: 25px;\n height: 25px;\n background: #eee;\n border: 1px solid #fff;\n cursor: pointer;\n border-radius: 50%;\n font-size: 20px;\n line-height: 1;\n}\n\n.flowbutton:hover {\n box-shadow: 0 0 6px 2px rgba(0, 0, 0, 0.08);\n}\n\n.flowbutton-foreignobject body {\n background: transparent;\n width: 50px;\n height: 50px;\n display: flex;\n justify-content: center;\n align-items: center;\n min-height: 40px;\n}\n",".controls-wrapper {\n .ap {\n flex: none;\n box-sizing: border-box;\n background-color: #fff;\n border: 1px solid #4374AD;\n border-radius: 50%;\n display: inline-block;\n position: relative;\n cursor: pointer;\n margin-top: -2px;\n\n .apc {\n width: 6px;\n position: absolute;\n left: 0;\n right: 0;\n top: 0;\n bottom: 0;\n margin: auto;\n }\n\n .aph {\n width: 6px;\n height: 6px;\n background-color: #4374AD;\n display: inline-block;\n border-radius: 50%;\n position: absolute;\n left: 0;\n right: 0;\n top: 4px;\n margin: auto;\n cursor: pointer;\n }\n }\n\n .ai {\n background: #f2f2f2;\n display: flex;\n flex: 1;\n margin: 0 12px;\n justify-content: space-around;\n align-items: center;\n\n input {\n border: none;\n text-align: center;\n width: 48px;\n color: #0C0C09;\n background: inherit;\n }\n\n span {\n padding: 5px;\n color: black;\n cursor: pointer;\n user-select: none;\n font-size: 14px;\n }\n }\n}\n",".cs {\n height: 17px;\n position: absolute;\n width: 11px;\n cursor: pointer;\n background: url(./ColorStop.png) right center;\n\n div {\n height: 7px;\n left: 2px;\n width: 7px;\n position: absolute;\n top: 8px;\n }\n\n .active {\n background-position: left center;\n }\n}\n",".cp {\n div {\n box-sizing: border-box;\n cursor: pointer;\n display: inline-block;\n height: 16px;\n width: 16px;\n\n &:hover {\n border: 1px solid #fff;\n }\n }\n}\n",".gp {\n display: flex;\n flex-direction: column;\n align-items: center;\n\n .gp-flat {\n margin: 0 auto;\n padding: 10px 0 0!important;\n box-shadow: none!important;\n transform: none!important;\n }\n}\n",".type-picker-wrapper {\n display: inline-flex;\n margin-right: 16px;\n\n .type-picker {\n height: 24px;\n width: 24px;\n border: 1px solid rgb(238, 238, 238);\n filter: grayscale(1);\n margin-right: 8px;\n cursor: pointer;\n transition: all 0.2s ease;\n\n &.active {\n border: 1px solid #4374AD;\n filter: grayscale(0);\n }\n\n &.lg {\n background: linear-gradient(270deg, #ddd, #4374AD);\n }\n\n &.rg {\n background: radial-gradient(circle, #fff 0, #4374AD 100%);\n }\n }\n}\n",".gpw {\n padding: 20px;\n\n .trigger {\n padding: 5px;\n background: rgb(255, 255, 255);\n border-radius: 1px;\n box-shadow: rgba(0, 0, 0, 0.1) 0 0 0 1px;\n display: inline-block;\n cursor: pointer;\n\n .inner {\n width: 36px;\n height: 14px;\n border-radius: 2px;\n }\n }\n\n .popover {\n z-index: 2;\n margin-top: 6px;\n box-shadow: rgba(0, 0, 0, 0.15) 0 0 0 1px,\n rgba(0, 0, 0, 0.15) 0 8px 16px;\n background-color: white;\n padding: 12px;\n border-radius: 4px;\n position: absolute;\n }\n\n .overlay {\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n }\n\n .controls-wrapper {\n margin: 0 -10px 10px;\n padding: 6px 0 0 10px;\n display: flex;\n flex-wrap: wrap;\n position: relative;\n\n &.with-angle {\n justify-content: space-around;\n align-items: center;\n }\n }\n}\n\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/frontend/build/static/js/488.8edbc83a.chunk.js b/frontend/build/static/js/488.8edbc83a.chunk.js new file mode 100644 index 000000000..7c1afdb44 --- /dev/null +++ b/frontend/build/static/js/488.8edbc83a.chunk.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkoptinist=self.webpackChunkoptinist||[]).push([[488],{2488:(e,n,t)=>{t.r(n),t.d(n,{CLSThresholds:()=>I,FCPThresholds:()=>S,FIDThresholds:()=>N,INPThresholds:()=>G,LCPThresholds:()=>X,TTFBThresholds:()=>$,getCLS:()=>F,getFCP:()=>P,getFID:()=>R,getINP:()=>W,getLCP:()=>Z,getTTFB:()=>ne,onCLS:()=>F,onFCP:()=>P,onFID:()=>R,onINP:()=>W,onLCP:()=>Z,onTTFB:()=>ne});var r,i,o,a,c,u=-1,s=function(e){addEventListener("pageshow",(function(n){n.persisted&&(u=n.timeStamp,e(n))}),!0)},f=function(){return window.performance&&performance.getEntriesByType&&performance.getEntriesByType("navigation")[0]},d=function(){var e=f();return e&&e.activationStart||0},l=function(e,n){var t=f(),r="navigate";return u>=0?r="back-forward-cache":t&&(document.prerendering||d()>0?r="prerender":document.wasDiscarded?r="restore":t.type&&(r=t.type.replace(/_/g,"-"))),{name:e,value:void 0===n?-1:n,rating:"good",delta:0,entries:[],id:"v3-".concat(Date.now(),"-").concat(Math.floor(8999999999999*Math.random())+1e12),navigationType:r}},p=function(e,n,t){try{if(PerformanceObserver.supportedEntryTypes.includes(e)){var r=new PerformanceObserver((function(e){Promise.resolve().then((function(){n(e.getEntries())}))}));return r.observe(Object.assign({type:e,buffered:!0},t||{})),r}}catch(e){}},v=function(e,n,t,r){var i,o;return function(a){n.value>=0&&(a||r)&&((o=n.value-(i||0))||void 0===i)&&(i=n.value,n.delta=o,n.rating=function(e,n){return e>n[1]?"poor":e>n[0]?"needs-improvement":"good"}(n.value,t),e(n))}},m=function(e){requestAnimationFrame((function(){return requestAnimationFrame((function(){return e()}))}))},h=function(e){var n=function(n){"pagehide"!==n.type&&"hidden"!==document.visibilityState||e(n)};addEventListener("visibilitychange",n,!0),addEventListener("pagehide",n,!0)},g=function(e){var n=!1;return function(t){n||(e(t),n=!0)}},T=-1,y=function(){return"hidden"!==document.visibilityState||document.prerendering?1/0:0},C=function(e){"hidden"===document.visibilityState&&T>-1&&(T="visibilitychange"===e.type?e.timeStamp:0,L())},E=function(){addEventListener("visibilitychange",C,!0),addEventListener("prerenderingchange",C,!0)},L=function(){removeEventListener("visibilitychange",C,!0),removeEventListener("prerenderingchange",C,!0)},w=function(){return T<0&&(T=y(),E(),s((function(){setTimeout((function(){T=y(),E()}),0)}))),{get firstHiddenTime(){return T}}},b=function(e){document.prerendering?addEventListener("prerenderingchange",(function(){return e()}),!0):e()},S=[1800,3e3],P=function(e,n){n=n||{},b((function(){var t,r=w(),i=l("FCP"),o=p("paint",(function(e){e.forEach((function(e){"first-contentful-paint"===e.name&&(o.disconnect(),e.startTimer.value&&(r.value=i,r.entries=o,t())},c=p("layout-shift",a);c&&(t=v(e,r,I,n.reportAllChanges),h((function(){a(c.takeRecords()),t(!0)})),s((function(){i=0,r=l("CLS",0),t=v(e,r,I,n.reportAllChanges),m((function(){return t()}))})),setTimeout(t,0))})))},A={passive:!0,capture:!0},k=new Date,D=function(e,n){r||(r=n,i=e,o=new Date,x(removeEventListener),M())},M=function(){if(i>=0&&i1e12?new Date:performance.now())-e.timeStamp;"pointerdown"==e.type?function(e,n){var t=function(){D(e,n),i()},r=function(){i()},i=function(){removeEventListener("pointerup",t,A),removeEventListener("pointercancel",r,A)};addEventListener("pointerup",t,A),addEventListener("pointercancel",r,A)}(n,e):D(n,e)}},x=function(e){["mousedown","keydown","touchstart","pointerdown"].forEach((function(n){return e(n,B,A)}))},N=[100,300],R=function(e,n){n=n||{},b((function(){var t,o=w(),c=l("FID"),u=function(e){e.startTimen.latency){if(t)t.entries.push(e),t.latency=Math.max(t.latency,e.duration);else{var r={id:e.interactionId,latency:e.duration,entries:[e]};U[r.id]=r,Q.push(r)}Q.sort((function(e,n){return n.latency-e.latency})),Q.splice(10).forEach((function(e){delete U[e.id]}))}},W=function(e,n){n=n||{},b((function(){var t;z();var r,i=l("INP"),o=function(e){e.forEach((function(e){e.interactionId&&V(e),"first-input"===e.entryType&&!Q.some((function(n){return n.entries.some((function(n){return e.duration===n.duration&&e.startTime===n.startTime}))}))&&V(e)}));var n,t=(n=Math.min(Q.length-1,Math.floor(K()/50)),Q[n]);t&&t.latency!==i.value&&(i.value=t.latency,i.entries=t.entries,r())},a=p("event",o,{durationThreshold:null!==(t=n.durationThreshold)&&void 0!==t?t:40});r=v(e,i,G,n.reportAllChanges),a&&("PerformanceEventTiming"in window&&"interactionId"in PerformanceEventTiming.prototype&&a.observe({type:"first-input",buffered:!0}),h((function(){o(a.takeRecords()),i.value<0&&K()>0&&(i.value=0,i.entries=[]),r(!0)})),s((function(){Q=[],J=_(),i=l("INP"),r=v(e,i,G,n.reportAllChanges)})))}))},X=[2500,4e3],Y={},Z=function(e,n){n=n||{},b((function(){var t,r=w(),i=l("LCP"),o=function(e){var n=e[e.length-1];n&&n.startTimeperformance.now())return;t.value=Math.max(o-d(),0),t.entries=[i],r(!0),s((function(){t=l("TTFB",0),(r=v(e,t,$,n.reportAllChanges))(!0)}))}}))}}}]); +//# sourceMappingURL=488.8edbc83a.chunk.js.map \ No newline at end of file diff --git a/frontend/build/static/js/488.8edbc83a.chunk.js.map b/frontend/build/static/js/488.8edbc83a.chunk.js.map new file mode 100644 index 000000000..c7fc4f9e4 --- /dev/null +++ b/frontend/build/static/js/488.8edbc83a.chunk.js.map @@ -0,0 +1 @@ +{"version":3,"file":"static/js/488.8edbc83a.chunk.js","mappings":"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","sources":["../node_modules/web-vitals/dist/web-vitals.js"],"sourcesContent":["var e,n,t,i,r,a=-1,o=function(e){addEventListener(\"pageshow\",(function(n){n.persisted&&(a=n.timeStamp,e(n))}),!0)},c=function(){return window.performance&&performance.getEntriesByType&&performance.getEntriesByType(\"navigation\")[0]},u=function(){var e=c();return e&&e.activationStart||0},f=function(e,n){var t=c(),i=\"navigate\";a>=0?i=\"back-forward-cache\":t&&(document.prerendering||u()>0?i=\"prerender\":document.wasDiscarded?i=\"restore\":t.type&&(i=t.type.replace(/_/g,\"-\")));return{name:e,value:void 0===n?-1:n,rating:\"good\",delta:0,entries:[],id:\"v3-\".concat(Date.now(),\"-\").concat(Math.floor(8999999999999*Math.random())+1e12),navigationType:i}},s=function(e,n,t){try{if(PerformanceObserver.supportedEntryTypes.includes(e)){var i=new PerformanceObserver((function(e){Promise.resolve().then((function(){n(e.getEntries())}))}));return i.observe(Object.assign({type:e,buffered:!0},t||{})),i}}catch(e){}},d=function(e,n,t,i){var r,a;return function(o){n.value>=0&&(o||i)&&((a=n.value-(r||0))||void 0===r)&&(r=n.value,n.delta=a,n.rating=function(e,n){return e>n[1]?\"poor\":e>n[0]?\"needs-improvement\":\"good\"}(n.value,t),e(n))}},l=function(e){requestAnimationFrame((function(){return requestAnimationFrame((function(){return e()}))}))},p=function(e){var n=function(n){\"pagehide\"!==n.type&&\"hidden\"!==document.visibilityState||e(n)};addEventListener(\"visibilitychange\",n,!0),addEventListener(\"pagehide\",n,!0)},v=function(e){var n=!1;return function(t){n||(e(t),n=!0)}},m=-1,h=function(){return\"hidden\"!==document.visibilityState||document.prerendering?1/0:0},g=function(e){\"hidden\"===document.visibilityState&&m>-1&&(m=\"visibilitychange\"===e.type?e.timeStamp:0,T())},y=function(){addEventListener(\"visibilitychange\",g,!0),addEventListener(\"prerenderingchange\",g,!0)},T=function(){removeEventListener(\"visibilitychange\",g,!0),removeEventListener(\"prerenderingchange\",g,!0)},E=function(){return m<0&&(m=h(),y(),o((function(){setTimeout((function(){m=h(),y()}),0)}))),{get firstHiddenTime(){return m}}},C=function(e){document.prerendering?addEventListener(\"prerenderingchange\",(function(){return e()}),!0):e()},L=[1800,3e3],w=function(e,n){n=n||{},C((function(){var t,i=E(),r=f(\"FCP\"),a=s(\"paint\",(function(e){e.forEach((function(e){\"first-contentful-paint\"===e.name&&(a.disconnect(),e.startTimei.value&&(i.value=r,i.entries=a,t())},u=s(\"layout-shift\",c);u&&(t=d(e,i,b,n.reportAllChanges),p((function(){c(u.takeRecords()),t(!0)})),o((function(){r=0,i=f(\"CLS\",0),t=d(e,i,b,n.reportAllChanges),l((function(){return t()}))})),setTimeout(t,0))})))},A={passive:!0,capture:!0},I=new Date,P=function(i,r){e||(e=r,n=i,t=new Date,k(removeEventListener),F())},F=function(){if(n>=0&&n1e12?new Date:performance.now())-e.timeStamp;\"pointerdown\"==e.type?function(e,n){var t=function(){P(e,n),r()},i=function(){r()},r=function(){removeEventListener(\"pointerup\",t,A),removeEventListener(\"pointercancel\",i,A)};addEventListener(\"pointerup\",t,A),addEventListener(\"pointercancel\",i,A)}(n,e):P(n,e)}},k=function(e){[\"mousedown\",\"keydown\",\"touchstart\",\"pointerdown\"].forEach((function(n){return e(n,M,A)}))},D=[100,300],x=function(t,r){r=r||{},C((function(){var a,c=E(),u=f(\"FID\"),l=function(e){e.startTimen.latency){if(t)t.entries.push(e),t.latency=Math.max(t.latency,e.duration);else{var i={id:e.interactionId,latency:e.duration,entries:[e]};J[i.id]=i,G.push(i)}G.sort((function(e,n){return n.latency-e.latency})),G.splice(10).forEach((function(e){delete J[e.id]}))}},Q=function(e,n){n=n||{},C((function(){var t;q();var i,r=f(\"INP\"),a=function(e){e.forEach((function(e){(e.interactionId&&K(e),\"first-input\"===e.entryType)&&(!G.some((function(n){return n.entries.some((function(n){return e.duration===n.duration&&e.startTime===n.startTime}))}))&&K(e))}));var n,t=(n=Math.min(G.length-1,Math.floor(z()/50)),G[n]);t&&t.latency!==r.value&&(r.value=t.latency,r.entries=t.entries,i())},c=s(\"event\",a,{durationThreshold:null!==(t=n.durationThreshold)&&void 0!==t?t:40});i=d(e,r,j,n.reportAllChanges),c&&(\"PerformanceEventTiming\"in window&&\"interactionId\"in PerformanceEventTiming.prototype&&c.observe({type:\"first-input\",buffered:!0}),p((function(){a(c.takeRecords()),r.value<0&&z()>0&&(r.value=0,r.entries=[]),i(!0)})),o((function(){G=[],_=O(),r=f(\"INP\"),i=d(e,r,j,n.reportAllChanges)})))}))},U=[2500,4e3],V={},W=function(e,n){n=n||{},C((function(){var t,i=E(),r=f(\"LCP\"),a=function(e){var n=e[e.length-1];n&&n.startTimeperformance.now())return;t.value=Math.max(a-u(),0),t.entries=[r],i(!0),o((function(){t=f(\"TTFB\",0),(i=d(e,t,X,n.reportAllChanges))(!0)}))}}))};export{b as CLSThresholds,L as FCPThresholds,D as FIDThresholds,j as INPThresholds,U as LCPThresholds,X as TTFBThresholds,S as getCLS,w as getFCP,x as getFID,Q as getINP,W as getLCP,Z as getTTFB,S as onCLS,w as onFCP,x as onFID,Q as onINP,W as onLCP,Z as onTTFB};\n"],"names":["e","n","t","i","r","a","o","addEventListener","persisted","timeStamp","c","window","performance","getEntriesByType","u","activationStart","f","document","prerendering","wasDiscarded","type","replace","name","value","rating","delta","entries","id","concat","Date","now","Math","floor","random","navigationType","s","PerformanceObserver","supportedEntryTypes","includes","Promise","resolve","then","getEntries","observe","Object","assign","buffered","d","l","requestAnimationFrame","p","visibilityState","v","m","h","g","T","y","removeEventListener","E","setTimeout","firstHiddenTime","C","L","w","forEach","disconnect","startTime","max","push","reportAllChanges","b","S","hadRecentInput","length","takeRecords","A","passive","capture","I","P","k","F","entryType","target","cancelable","processingStart","M","D","x","B","R","H","N","interactionId","min","O","interactionCount","q","durationThreshold","j","_","z","G","J","K","duration","latency","sort","splice","Q","some","PerformanceEventTiming","prototype","U","V","W","X","Y","readyState","Z","responseStart"],"sourceRoot":""} \ No newline at end of file diff --git a/frontend/build/static/js/main.d74ed89f.js b/frontend/build/static/js/main.d74ed89f.js new file mode 100644 index 000000000..2f6971af5 --- /dev/null +++ b/frontend/build/static/js/main.d74ed89f.js @@ -0,0 +1,221 @@ +/*! For license information please see main.d74ed89f.js.LICENSE.txt */ +(()=>{var e={93803:(e,t,r)=>{"use strict";r.d(t,{A:()=>ie});var n=function(){function e(e){var t=this;this._insertTag=function(e){var r;r=0===t.tags.length?t.insertionPoint?t.insertionPoint.nextSibling:t.prepend?t.container.firstChild:t.before:t.tags[t.tags.length-1].nextSibling,t.container.insertBefore(e,r),t.tags.push(e)},this.isSpeedy=void 0===e.speedy||e.speedy,this.tags=[],this.ctr=0,this.nonce=e.nonce,this.key=e.key,this.container=e.container,this.prepend=e.prepend,this.insertionPoint=e.insertionPoint,this.before=null}var t=e.prototype;return t.hydrate=function(e){e.forEach(this._insertTag)},t.insert=function(e){this.ctr%(this.isSpeedy?65e3:1)===0&&this._insertTag(function(e){var t=document.createElement("style");return t.setAttribute("data-emotion",e.key),void 0!==e.nonce&&t.setAttribute("nonce",e.nonce),t.appendChild(document.createTextNode("")),t.setAttribute("data-s",""),t}(this));var t=this.tags[this.tags.length-1];if(this.isSpeedy){var r=function(e){if(e.sheet)return e.sheet;for(var t=0;t0?u(b,--v):0,g--,10===x&&(g=1,m--),x}function S(){return x=v2||C(x)>3?"":" "}function R(e,t){for(;--t&&S()&&!(x<48||x>102||x>57&&x<65||x>70&&x<97););return M(e,T()+(t<6&&32==A()&&32==S()))}function L(e){for(;S();)switch(x){case e:return v;case 34:case 39:34!==e&&39!==e&&L(x);break;case 40:41===e&&L(e);break;case 92:S()}return v}function D(e,t){for(;S()&&e+x!==57&&(e+x!==84||47!==A()););return"/*"+M(t,v-1)+"*"+o(47===e?e:S())}function z(e){for(;!C(A());)S();return M(e,v)}var j="-ms-",F="-moz-",N="-webkit-",B="comm",V="rule",U="decl",H="@keyframes";function $(e,t){for(var r="",n=p(e),i=0;i0&&h(F)-y&&f(x>32?Z(F+";",n,r,y-1):Z(l(F," ","")+";",n,r,y-2),p);break;case 59:F+=";";default:if(f(j=Y(F,t,r,m,g,i,d,E,I=[],L=[],y),a),123===C)if(0===g)G(F,t,j,j,I,a,y,d,L);else switch(99===v&&110===u(F,3)?100:v){case 100:case 108:case 109:case 115:G(e,j,j,n&&f(Y(e,j,j,0,0,i,d,E,i,I=[],y),L),i,L,y,d,n?I:L);break;default:G(F,j,j,j,[""],L,0,d,L)}}m=g=x=0,_=M=1,E=F="",y=s;break;case 58:y=1+h(F),x=b;default:if(_<1)if(123==C)--_;else if(125==C&&0==_++&&125==k())continue;switch(F+=o(C),C*_){case 38:M=g>0?1:(F+="\f",-1);break;case 44:d[m++]=(h(F)-1)*M,M=1;break;case 64:45===A()&&(F+=P(S())),v=A(),g=y=h(E=F+=z(T())),C++;break;case 45:45===b&&2==h(F)&&(_=0)}}return a}function Y(e,t,r,n,o,a,c,u,h,f,m){for(var g=o-1,y=0===o?a:[""],v=p(y),x=0,b=0,w=0;x0?y[k]+" "+S:l(S,/&\f/g,y[k])))&&(h[w++]=A);return _(e,t,r,0===o?V:u,h,f,m)}function X(e,t,r){return _(e,t,r,B,o(x),d(e,2,-2),0)}function Z(e,t,r,n){return _(e,t,r,U,d(e,0,n),d(e,n+1,-1),n)}var K=function(e,t,r){for(var n=0,i=0;n=i,i=A(),38===n&&12===i&&(t[r]=1),!C(i);)S();return M(e,v)},J=function(e,t){return I(function(e,t){var r=-1,n=44;do{switch(C(n)){case 0:38===n&&12===A()&&(t[r]=1),e[r]+=K(v-1,t,r);break;case 2:e[r]+=P(n);break;case 4:if(44===n){e[++r]=58===A()?"&\f":"",t[r]=e[r].length;break}default:e[r]+=o(n)}}while(n=S());return e}(E(e),t))},Q=new WeakMap,ee=function(e){if("rule"===e.type&&e.parent&&!(e.length<1)){for(var t=e.value,r=e.parent,n=e.column===r.column&&e.line===r.line;"rule"!==r.type;)if(!(r=r.parent))return;if((1!==e.props.length||58===t.charCodeAt(0)||Q.get(r))&&!n){Q.set(e,!0);for(var i=[],o=J(t,i),a=r.props,s=0,l=0;s6)switch(u(e,t+1)){case 109:if(45!==u(e,t+4))break;case 102:return l(e,/(.+:)(.+)-([^]+)/,"$1"+N+"$2-$3$1"+F+(108==u(e,t+3)?"$3":"$2-$3"))+e;case 115:return~c(e,"stretch")?re(l(e,"stretch","fill-available"),t)+e:e}break;case 4949:if(115!==u(e,t+1))break;case 6444:switch(u(e,h(e)-3-(~c(e,"!important")&&10))){case 107:return l(e,":",":"+N)+e;case 101:return l(e,/(.+:)([^;!]+)(;|!.+)?/,"$1"+N+(45===u(e,14)?"inline-":"")+"box$3$1"+N+"$2$3$1"+j+"$2box$3")+e}break;case 5936:switch(u(e,t+11)){case 114:return N+e+j+l(e,/[svh]\w+-[tblr]{2}/,"tb")+e;case 108:return N+e+j+l(e,/[svh]\w+-[tblr]{2}/,"tb-rl")+e;case 45:return N+e+j+l(e,/[svh]\w+-[tblr]{2}/,"lr")+e}return N+e+j+e+e}return e}var ne=[function(e,t,r,n){if(e.length>-1&&!e.return)switch(e.type){case U:e.return=re(e.value,e.length);break;case H:return $([w(e,{value:l(e.value,"@","@"+N)})],n);case V:if(e.length)return function(e,t){return e.map(t).join("")}(e.props,(function(t){switch(function(e,t){return(e=t.exec(e))?e[0]:e}(t,/(::plac\w+|:read-\w+)/)){case":read-only":case":read-write":return $([w(e,{props:[l(t,/:(read-\w+)/,":-moz-$1")]})],n);case"::placeholder":return $([w(e,{props:[l(t,/:(plac\w+)/,":"+N+"input-$1")]}),w(e,{props:[l(t,/:(plac\w+)/,":-moz-$1")]}),w(e,{props:[l(t,/:(plac\w+)/,j+"input-$1")]})],n)}return""}))}}],ie=function(e){var t=e.key;if("css"===t){var r=document.querySelectorAll("style[data-emotion]:not([data-s])");Array.prototype.forEach.call(r,(function(e){-1!==e.getAttribute("data-emotion").indexOf(" ")&&(document.head.appendChild(e),e.setAttribute("data-s",""))}))}var i,o,a=e.stylisPlugins||ne,s={},l=[];i=e.container||document.head,Array.prototype.forEach.call(document.querySelectorAll('style[data-emotion^="'+t+' "]'),(function(e){for(var t=e.getAttribute("data-emotion").split(" "),r=1;r{"use strict";function n(e){var t=Object.create(null);return function(r){return void 0===t[r]&&(t[r]=e(r)),t[r]}}r.d(t,{A:()=>n})},84575:(e,t,r)=>{"use strict";r.d(t,{C:()=>a,T:()=>l,w:()=>s});var n=r(65043),i=r(93803),o=(r(99002),r(69436),n.createContext("undefined"!==typeof HTMLElement?(0,i.A)({key:"css"}):null)),a=o.Provider,s=function(e){return(0,n.forwardRef)((function(t,r){var i=(0,n.useContext)(o);return e(t,i,r)}))},l=n.createContext({})},83290:(e,t,r)=>{"use strict";r.d(t,{AH:()=>c,i7:()=>u,mL:()=>l});var n=r(84575),i=r(65043),o=r(81722),a=r(69436),s=r(99002),l=(r(93803),r(80219),(0,n.w)((function(e,t){var r=e.styles,l=(0,s.J)([r],void 0,i.useContext(n.T)),c=i.useRef();return(0,a.i)((function(){var e=t.key+"-global",r=new t.sheet.constructor({key:e,nonce:t.sheet.nonce,container:t.sheet.container,speedy:t.sheet.isSpeedy}),n=!1,i=document.querySelector('style[data-emotion="'+e+" "+l.name+'"]');return t.sheet.tags.length&&(r.before=t.sheet.tags[0]),null!==i&&(n=!0,i.setAttribute("data-emotion",e),r.hydrate([i])),c.current=[r,n],function(){r.flush()}}),[t]),(0,a.i)((function(){var e=c.current,r=e[0];if(e[1])e[1]=!1;else{if(void 0!==l.next&&(0,o.sk)(t,l.next,!0),r.tags.length){var n=r.tags[r.tags.length-1].nextElementSibling;r.before=n,r.flush()}t.insert("",l,r,!1)}}),[t,l.name]),null})));function c(){for(var e=arguments.length,t=new Array(e),r=0;r{"use strict";r.d(t,{J:()=>g});var n={animationIterationCount:1,aspectRatio:1,borderImageOutset:1,borderImageSlice:1,borderImageWidth:1,boxFlex:1,boxFlexGroup:1,boxOrdinalGroup:1,columnCount:1,columns:1,flex:1,flexGrow:1,flexPositive:1,flexShrink:1,flexNegative:1,flexOrder:1,gridRow:1,gridRowEnd:1,gridRowSpan:1,gridRowStart:1,gridColumn:1,gridColumnEnd:1,gridColumnSpan:1,gridColumnStart:1,msGridRow:1,msGridRowSpan:1,msGridColumn:1,msGridColumnSpan:1,fontWeight:1,lineHeight:1,opacity:1,order:1,orphans:1,scale:1,tabSize:1,widows:1,zIndex:1,zoom:1,WebkitLineClamp:1,fillOpacity:1,floodOpacity:1,stopOpacity:1,strokeDasharray:1,strokeDashoffset:1,strokeMiterlimit:1,strokeOpacity:1,strokeWidth:1},i=r(30918),o=!1,a=/[A-Z]|^ms/g,s=/_EMO_([^_]+?)_([^]*?)_EMO_/g,l=function(e){return 45===e.charCodeAt(1)},c=function(e){return null!=e&&"boolean"!==typeof e},u=(0,i.A)((function(e){return l(e)?e:e.replace(a,"-$&").toLowerCase()})),d=function(e,t){switch(e){case"animation":case"animationName":if("string"===typeof t)return t.replace(s,(function(e,t,r){return f={name:t,styles:r,next:f},t}))}return 1===n[e]||l(e)||"number"!==typeof t||0===t?t:t+"px"},h="Component selectors can only be used in conjunction with @emotion/babel-plugin, the swc Emotion plugin, or another Emotion-aware compiler transform.";function p(e,t,r){if(null==r)return"";var n=r;if(void 0!==n.__emotion_styles)return n;switch(typeof r){case"boolean":return"";case"object":var i=r;if(1===i.anim)return f={name:i.name,styles:i.styles,next:f},i.name;var a=r;if(void 0!==a.styles){var s=a.next;if(void 0!==s)for(;void 0!==s;)f={name:s.name,styles:s.styles,next:f},s=s.next;return a.styles+";"}return function(e,t,r){var n="";if(Array.isArray(r))for(var i=0;i=4;++n,i-=4)t=1540483477*(65535&(t=255&e.charCodeAt(n)|(255&e.charCodeAt(++n))<<8|(255&e.charCodeAt(++n))<<16|(255&e.charCodeAt(++n))<<24))+(59797*(t>>>16)<<16),r=1540483477*(65535&(t^=t>>>24))+(59797*(t>>>16)<<16)^1540483477*(65535&r)+(59797*(r>>>16)<<16);switch(i){case 3:r^=(255&e.charCodeAt(n+2))<<16;case 2:r^=(255&e.charCodeAt(n+1))<<8;case 1:r=1540483477*(65535&(r^=255&e.charCodeAt(n)))+(59797*(r>>>16)<<16)}return(((r=1540483477*(65535&(r^=r>>>13))+(59797*(r>>>16)<<16))^r>>>15)>>>0).toString(36)}(i)+l;return{name:c,styles:i,next:f}}},69436:(e,t,r)=>{"use strict";var n;r.d(t,{i:()=>s,s:()=>a});var i=r(65043),o=!!(n||(n=r.t(i,2))).useInsertionEffect&&(n||(n=r.t(i,2))).useInsertionEffect,a=o||function(e){return e()},s=o||i.useLayoutEffect},81722:(e,t,r)=>{"use strict";r.d(t,{Rk:()=>n,SF:()=>i,sk:()=>o});function n(e,t,r){var n="";return r.split(" ").forEach((function(r){void 0!==e[r]?t.push(e[r]+";"):r&&(n+=r+" ")})),n}var i=function(e,t,r){var n=e.key+"-"+t.name;!1===r&&void 0===e.registered[n]&&(e.registered[n]=t.styles)},o=function(e,t,r){i(e,t,r);var n=e.key+"-"+t.name;if(void 0===e.inserted[t.name]){var o=t;do{e.insert(t===o?"."+n:"",o,e.sheet,!0),o=o.next}while(void 0!==o)}}},54371:(e,t,r)=>{"use strict";var n,i=Object.assign||function(e){for(var t=1;t=0||Object.prototype.hasOwnProperty.call(e,n)&&(r[n]=e[n]);return r}(e,["fill","width","height","style"]);return a.default.createElement("svg",i({viewBox:"0 0 24 24",style:i({fill:r,width:o,height:l},u)},d),a.default.createElement("path",{d:"M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"}))}},29128:(e,t,r)=>{"use strict";var n,i=Object.assign||function(e){for(var t=1;t=0||Object.prototype.hasOwnProperty.call(e,n)&&(r[n]=e[n]);return r}(e,["fill","width","height","style"]);return a.default.createElement("svg",i({viewBox:"0 0 24 24",style:i({fill:r,width:o,height:l},u)},d),a.default.createElement("path",{d:"M12,18.17L8.83,15L7.42,16.41L12,21L16.59,16.41L15.17,15M12,5.83L15.17,9L16.58,7.59L12,3L7.41,7.59L8.83,9L12,5.83Z"}))}},39089:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m0 4c1.93 0 3.5 1.57 3.5 3.5S13.93 13 12 13s-3.5-1.57-3.5-3.5S10.07 6 12 6m0 14c-2.03 0-4.43-.82-6.14-2.88C7.55 15.8 9.68 15 12 15s4.45.8 6.14 2.12C16.43 19.18 14.03 20 12 20"}),"AccountCircle")},32125:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M22 11V3h-7v3H9V3H2v8h7V8h2v10h4v3h7v-8h-7v3h-2V8h2v3z"}),"AccountTree")},22505:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6z"}),"Add")},32993:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M8 11h8v2H8zm12.1 1H22c0-2.76-2.24-5-5-5h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7c-2.76 0-5 2.24-5 5s2.24 5 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1M19 12h-2v3h-3v2h3v3h2v-3h3v-2h-3z"}),"AddLink")},4951:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M19 7v2.99s-1.99.01-2 0V7h-3s.01-1.99 0-2h3V2h2v3h3v2zm-3 4V8h-3V5H5c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2v-8zM5 19l3-4 2 3 3-4 4 5z"}),"AddPhotoAlternate")},75114:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2M9 17H7v-5h2zm4 0h-2v-3h2zm0-5h-2v-2h2zm4 5h-2V7h2z"}),"Analytics")},40430:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"m7 10 5 5 5-5z"}),"ArrowDropDown")},72126:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M12 6v3l4-4-4-4v3c-4.42 0-8 3.58-8 8 0 1.57.46 3.03 1.24 4.26L6.7 14.8c-.45-.83-.7-1.79-.7-2.8 0-3.31 2.69-6 6-6m6.76 1.74L17.3 9.2c.44.84.7 1.79.7 2.8 0 3.31-2.69 6-6 6v-3l-4 4 4 4v-3c4.42 0 8-3.58 8-8 0-1.57-.46-3.03-1.24-4.26"}),"Autorenew")},83723:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2M4 12c0-4.42 3.58-8 8-8 1.85 0 3.55.63 4.9 1.69L5.69 16.9C4.63 15.55 4 13.85 4 12m8 8c-1.85 0-3.55-.63-4.9-1.69L18.31 7.1C19.37 8.45 20 10.15 20 12c0 4.42-3.58 8-8 8"}),"Block")},85502:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2m5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12z"}),"Cancel")},95382:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M9 16.17 4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z"}),"Check")},27385:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2M9.29 16.29 5.7 12.7a.9959.9959 0 0 1 0-1.41c.39-.39 1.02-.39 1.41 0L10 14.17l6.88-6.88c.39-.39 1.02-.39 1.41 0 .39.39.39 1.02 0 1.41l-7.59 7.59c-.38.39-1.02.39-1.41 0"}),"CheckCircleRounded")},2194:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M11 7H2v2h9zm0 8H2v2h9zm5.34-4L12.8 7.46l1.41-1.41 2.12 2.12 4.24-4.24L22 5.34zm0 8-3.54-3.54 1.41-1.41 2.12 2.12 4.24-4.24L22 13.34z"}),"ChecklistRtl")},91707:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M10 6 8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z"}),"ChevronRight")},74802:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"}),"Close")},58094:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M3 13h8V3H3zm0 8h8v-6H3zm10 0h8V11h-8zm0-18v6h8V3z"}),"Dashboard")},63471:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6zM19 4h-3.5l-1-1h-5l-1 1H5v2h14z"}),"Delete")},10697:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6zM8 9h8v10H8zm7.5-5-1-1h-5l-1 1H5v2h14V4z"}),"DeleteOutline")},67500:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z"}),"Done")},95540:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M3 17.25V21h3.75L17.81 9.94l-3.75-3.75zM20.71 7.04c.39-.39.39-1.02 0-1.41l-2.34-2.34a.9959.9959 0 0 0-1.41 0l-1.83 1.83 3.75 3.75z"}),"Edit")},1528:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m1 15h-2v-2h2zm0-4h-2V7h2z"}),"Error")},37948:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2M12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8"}),"ErrorOutline")},75342:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M10.09 15.59 11.5 17l5-5-5-5-1.41 1.41L12.67 11H3v2h9.67zM19 3H5c-1.11 0-2 .9-2 2v4h2V5h14v14H5v-4H3v4c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2"}),"ExitToApp")},21337:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M16.59 8.59 12 13.17 7.41 8.59 6 10l6 6 6-6z"}),"ExpandMore")},39244:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M10 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2h-8z"}),"Folder")},90136:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M12 12.75c1.63 0 3.07.39 4.24.9 1.08.48 1.76 1.56 1.76 2.73V18H6v-1.61c0-1.18.68-2.26 1.76-2.73 1.17-.52 2.61-.91 4.24-.91M4 13c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2m1.13 1.1c-.37-.06-.74-.1-1.13-.1-.99 0-1.93.21-2.78.58C.48 14.9 0 15.62 0 16.43V18h4.5v-1.61c0-.83.23-1.61.63-2.29M20 13c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2m4 3.43c0-.81-.48-1.53-1.22-1.85-.85-.37-1.79-.58-2.78-.58-.39 0-.76.04-1.13.1.4.68.63 1.46.63 2.29V18H24zM12 6c1.66 0 3 1.34 3 3s-1.34 3-3 3-3-1.34-3-3 1.34-3 3-3"}),"Groups")},47574:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{fillRule:"evenodd",d:"M4 11h16v2H4z"}),"HorizontalRule")},99641:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8zM6 20V4h7v5h5v11z"}),"InsertDriveFileOutlined")},54536:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M7.41 8.59 12 13.17l4.59-4.58L18 10l-6 6-6-6z"}),"KeyboardArrowDown")},65037:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M7.41 15.41 12 10.83l4.59 4.58L18 14l-6-6-6 6z"}),"KeyboardArrowUp")},1702:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"m17 7-1.41 1.41L18.17 11H8v2h10.17l-2.58 2.58L17 17l5-5zM4 5h8V3H4c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h8v-2H4z"}),"Logout")},62647:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)([(0,o.jsx)("circle",{cx:"10",cy:"8",r:"4"},"0"),(0,o.jsx)("path",{d:"M10.67 13.02c-.22-.01-.44-.02-.67-.02-2.42 0-4.68.67-6.61 1.82-.88.52-1.39 1.5-1.39 2.53V20h9.26c-.79-1.13-1.26-2.51-1.26-4 0-1.07.25-2.07.67-2.98M20.75 16c0-.22-.03-.42-.06-.63l1.14-1.01-1-1.73-1.45.49c-.32-.27-.68-.48-1.08-.63L18 11h-2l-.3 1.49c-.4.15-.76.36-1.08.63l-1.45-.49-1 1.73 1.14 1.01c-.03.21-.06.41-.06.63s.03.42.06.63l-1.14 1.01 1 1.73 1.45-.49c.32.27.68.48 1.08.63L16 21h2l.3-1.49c.4-.15.76-.36 1.08-.63l1.45.49 1-1.73-1.14-1.01c.03-.21.06-.41.06-.63M17 18c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2"},"1")],"ManageAccounts")},89611:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M3 18h18v-2H3zm0-5h18v-2H3zm0-7v2h18V6z"}),"Menu")},28147:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M12 12.25c1.24 0 2.25-1.01 2.25-2.25S13.24 7.75 12 7.75 9.75 8.76 9.75 10s1.01 2.25 2.25 2.25m4.5 4c0-1.5-3-2.25-4.5-2.25s-4.5.75-4.5 2.25V17h9zM19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2m0 16H5V5h14z"}),"Portrait")},8611:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M12 5V1L7 6l5 5V7c3.31 0 6 2.69 6 6s-2.69 6-6 6-6-2.69-6-6H4c0 4.42 3.58 8 8 8s8-3.58 8-8-3.58-8-8-8"}),"Replay")},28222:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M10 9V5l-7 7 7 7v-4.1c5 0 8.5 1.6 11 5.1-1-5-4-10-11-11"}),"Reply")},61783:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M19 15.18V7c0-2.21-1.79-4-4-4s-4 1.79-4 4v10c0 1.1-.9 2-2 2s-2-.9-2-2V8.82C8.16 8.4 9 7.3 9 6c0-1.66-1.34-3-3-3S3 4.34 3 6c0 1.3.84 2.4 2 2.82V17c0 2.21 1.79 4 4 4s4-1.79 4-4V7c0-1.1.9-2 2-2s2 .9 2 2v8.18c-1.16.41-2 1.51-2 2.82 0 1.66 1.34 3 3 3s3-1.34 3-3c0-1.3-.84-2.4-2-2.82"}),"Route")},92577:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M19.14 12.94c.04-.3.06-.61.06-.94 0-.32-.02-.64-.07-.94l2.03-1.58c.18-.14.23-.41.12-.61l-1.92-3.32c-.12-.22-.37-.29-.59-.22l-2.39.96c-.5-.38-1.03-.7-1.62-.94l-.36-2.54c-.04-.24-.24-.41-.48-.41h-3.84c-.24 0-.43.17-.47.41l-.36 2.54c-.59.24-1.13.57-1.62.94l-2.39-.96c-.22-.08-.47 0-.59.22L2.74 8.87c-.12.21-.08.47.12.61l2.03 1.58c-.05.3-.09.63-.09.94s.02.64.07.94l-2.03 1.58c-.18.14-.23.41-.12.61l1.92 3.32c.12.22.37.29.59.22l2.39-.96c.5.38 1.03.7 1.62.94l.36 2.54c.05.24.24.41.48.41h3.84c.24 0 .44-.17.47-.41l.36-2.54c.59-.24 1.13-.56 1.62-.94l2.39.96c.22.08.47 0 .59-.22l1.92-3.32c.12-.22.07-.47-.12-.61zM12 15.6c-1.98 0-3.6-1.62-3.6-3.6s1.62-3.6 3.6-3.6 3.6 1.62 3.6 3.6-1.62 3.6-3.6 3.6"}),"Settings")},20689:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)([(0,o.jsx)("path",{d:"M18 2h-8L4 8v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2m0 2v16H6V8.83L10.83 4z"},"0"),(0,o.jsx)("path",{d:"m16 13-4 4-4-4 1.41-1.41L11 13.17V9.02L13 9v4.17l1.59-1.59z"},"1")],"SimCardDownloadOutlined")},86974:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M3 17v2h6v-2zM3 5v2h10V5zm10 16v-2h8v-2h-8v-2h-2v6zM7 9v2H3v2h4v2h2V9zm14 4v-2H11v2zm-6-4h2V7h4V5h-4V3h-2z"}),"Tune")},47260:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5M12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5m0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3"}),"Visibility")},72819:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M12 7c2.76 0 5 2.24 5 5 0 .65-.13 1.26-.36 1.83l2.92 2.92c1.51-1.26 2.7-2.89 3.43-4.75-1.73-4.39-6-7.5-11-7.5-1.4 0-2.74.25-3.98.7l2.16 2.16C10.74 7.13 11.35 7 12 7M2 4.27l2.28 2.28.46.46C3.08 8.3 1.78 10.02 1 12c1.73 4.39 6 7.5 11 7.5 1.55 0 3.03-.3 4.38-.84l.42.42L19.73 22 21 20.73 3.27 3zM7.53 9.8l1.55 1.55c-.05.21-.08.43-.08.65 0 1.66 1.34 3 3 3 .22 0 .44-.03.65-.08l1.55 1.55c-.67.33-1.41.53-2.2.53-2.76 0-5-2.24-5-5 0-.79.2-1.53.53-2.2m4.31-.78 3.15 3.15.02-.16c0-1.66-1.34-3-3-3z"}),"VisibilityOff")},9626:(e,t,r)=>{"use strict";var n=r(24994);t.A=void 0;var i=n(r(40039)),o=r(70579);t.A=(0,i.default)((0,o.jsx)("path",{d:"M12 5.99 19.53 19H4.47zM2.74 18c-.77 1.33.19 3 1.73 3h15.06c1.54 0 2.5-1.67 1.73-3L13.73 4.99c-.77-1.33-2.69-1.33-3.46 0zM11 11v2c0 .55.45 1 1 1s1-.45 1-1v-2c0-.55-.45-1-1-1s-1 .45-1 1m0 5h2v2h-2z"}),"WarningAmberRounded")},40039:(e,t,r)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"default",{enumerable:!0,get:function(){return n.createSvgIcon}});var n=r(4421)},98206:(e,t,r)=>{"use strict";r.d(t,{b:()=>i});r(65043);var n=r(13654);r(70579);function i(e){return(0,n.b)(e)}},50147:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n={50:"#e8f5e9",100:"#c8e6c9",200:"#a5d6a7",300:"#81c784",400:"#66bb6a",500:"#4caf50",600:"#43a047",700:"#388e3c",800:"#2e7d32",900:"#1b5e20",A100:"#b9f6ca",A200:"#69f0ae",A400:"#00e676",A700:"#00c853"}},74681:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n={50:"#fafafa",100:"#f5f5f5",200:"#eeeeee",300:"#e0e0e0",400:"#bdbdbd",500:"#9e9e9e",600:"#757575",700:"#616161",800:"#424242",900:"#212121",A100:"#f5f5f5",A200:"#eeeeee",A400:"#bdbdbd",A700:"#616161"}},29864:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n={50:"#fff3e0",100:"#ffe0b2",200:"#ffcc80",300:"#ffb74d",400:"#ffa726",500:"#ff9800",600:"#fb8c00",700:"#f57c00",800:"#ef6c00",900:"#e65100",A100:"#ffd180",A200:"#ffab40",A400:"#ff9100",A700:"#ff6d00"}},53612:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n={50:"#f3e5f5",100:"#e1bee7",200:"#ce93d8",300:"#ba68c8",400:"#ab47bc",500:"#9c27b0",600:"#8e24aa",700:"#7b1fa2",800:"#6a1b9a",900:"#4a148c",A100:"#ea80fc",A200:"#e040fb",A400:"#d500f9",A700:"#aa00ff"}},64851:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n={50:"#ffebee",100:"#ffcdd2",200:"#ef9a9a",300:"#e57373",400:"#ef5350",500:"#f44336",600:"#e53935",700:"#d32f2f",800:"#c62828",900:"#b71c1c",A100:"#ff8a80",A200:"#ff5252",A400:"#ff1744",A700:"#d50000"}},40688:(e,t,r)=>{"use strict";r.d(t,{A:()=>L});var n=r(58168),i=r(98587),o=r(17868),a=r(19172),s=r(37758),l=r(58812),c=r(18280);var u=r(67266);const d={black:"#000",white:"#fff"};var h=r(74681),p=r(53612),f=r(64851),m=r(29864);const g={50:"#e3f2fd",100:"#bbdefb",200:"#90caf9",300:"#64b5f6",400:"#42a5f5",500:"#2196f3",600:"#1e88e5",700:"#1976d2",800:"#1565c0",900:"#0d47a1",A100:"#82b1ff",A200:"#448aff",A400:"#2979ff",A700:"#2962ff"},y={50:"#e1f5fe",100:"#b3e5fc",200:"#81d4fa",300:"#4fc3f7",400:"#29b6f6",500:"#03a9f4",600:"#039be5",700:"#0288d1",800:"#0277bd",900:"#01579b",A100:"#80d8ff",A200:"#40c4ff",A400:"#00b0ff",A700:"#0091ea"};var v=r(50147);const x=["mode","contrastThreshold","tonalOffset"],b={text:{primary:"rgba(0, 0, 0, 0.87)",secondary:"rgba(0, 0, 0, 0.6)",disabled:"rgba(0, 0, 0, 0.38)"},divider:"rgba(0, 0, 0, 0.12)",background:{paper:d.white,default:d.white},action:{active:"rgba(0, 0, 0, 0.54)",hover:"rgba(0, 0, 0, 0.04)",hoverOpacity:.04,selected:"rgba(0, 0, 0, 0.08)",selectedOpacity:.08,disabled:"rgba(0, 0, 0, 0.26)",disabledBackground:"rgba(0, 0, 0, 0.12)",disabledOpacity:.38,focus:"rgba(0, 0, 0, 0.12)",focusOpacity:.12,activatedOpacity:.12}},_={text:{primary:d.white,secondary:"rgba(255, 255, 255, 0.7)",disabled:"rgba(255, 255, 255, 0.5)",icon:"rgba(255, 255, 255, 0.5)"},divider:"rgba(255, 255, 255, 0.12)",background:{paper:"#121212",default:"#121212"},action:{active:d.white,hover:"rgba(255, 255, 255, 0.08)",hoverOpacity:.08,selected:"rgba(255, 255, 255, 0.16)",selectedOpacity:.16,disabled:"rgba(255, 255, 255, 0.3)",disabledBackground:"rgba(255, 255, 255, 0.12)",disabledOpacity:.38,focus:"rgba(255, 255, 255, 0.12)",focusOpacity:.12,activatedOpacity:.24}};function w(e,t,r,n){const i=n.light||n,o=n.dark||1.5*n;e[t]||(e.hasOwnProperty(r)?e[t]=e[r]:"light"===t?e.light=(0,u.a)(e.main,i):"dark"===t&&(e.dark=(0,u.e$)(e.main,o)))}function k(e){const{mode:t="light",contrastThreshold:r=3,tonalOffset:s=.2}=e,l=(0,i.A)(e,x),c=e.primary||function(){return"dark"===(arguments.length>0&&void 0!==arguments[0]?arguments[0]:"light")?{main:g[200],light:g[50],dark:g[400]}:{main:g[700],light:g[400],dark:g[800]}}(t),k=e.secondary||function(){return"dark"===(arguments.length>0&&void 0!==arguments[0]?arguments[0]:"light")?{main:p.A[200],light:p.A[50],dark:p.A[400]}:{main:p.A[500],light:p.A[300],dark:p.A[700]}}(t),S=e.error||function(){return"dark"===(arguments.length>0&&void 0!==arguments[0]?arguments[0]:"light")?{main:f.A[500],light:f.A[300],dark:f.A[700]}:{main:f.A[700],light:f.A[400],dark:f.A[800]}}(t),A=e.info||function(){return"dark"===(arguments.length>0&&void 0!==arguments[0]?arguments[0]:"light")?{main:y[400],light:y[300],dark:y[700]}:{main:y[700],light:y[500],dark:y[900]}}(t),T=e.success||function(){return"dark"===(arguments.length>0&&void 0!==arguments[0]?arguments[0]:"light")?{main:v.A[400],light:v.A[300],dark:v.A[700]}:{main:v.A[800],light:v.A[500],dark:v.A[900]}}(t),M=e.warning||function(){return"dark"===(arguments.length>0&&void 0!==arguments[0]?arguments[0]:"light")?{main:m.A[400],light:m.A[300],dark:m.A[700]}:{main:"#ed6c02",light:m.A[500],dark:m.A[900]}}(t);function C(e){return(0,u.eM)(e,_.text.primary)>=r?_.text.primary:b.text.primary}const E=e=>{let{color:t,name:r,mainShade:i=500,lightShade:a=300,darkShade:l=700}=e;if(t=(0,n.A)({},t),!t.main&&t[i]&&(t.main=t[i]),!t.hasOwnProperty("main"))throw new Error((0,o.A)(11,r?` (${r})`:"",i));if("string"!==typeof t.main)throw new Error((0,o.A)(12,r?` (${r})`:"",JSON.stringify(t.main)));return w(t,"light",a,s),w(t,"dark",l,s),t.contrastText||(t.contrastText=C(t.main)),t},I={dark:_,light:b};return(0,a.A)((0,n.A)({common:(0,n.A)({},d),mode:t,primary:E({color:c,name:"primary"}),secondary:E({color:k,name:"secondary",mainShade:"A400",lightShade:"A200",darkShade:"A700"}),error:E({color:S,name:"error"}),warning:E({color:M,name:"warning"}),info:E({color:A,name:"info"}),success:E({color:T,name:"success"}),grey:h.A,contrastThreshold:r,getContrastText:C,augmentColor:E,tonalOffset:s},I[t]),l)}const S=["fontFamily","fontSize","fontWeightLight","fontWeightRegular","fontWeightMedium","fontWeightBold","htmlFontSize","allVariants","pxToRem"];const A={textTransform:"uppercase"},T='"Roboto", "Helvetica", "Arial", sans-serif';function M(e,t){const r="function"===typeof t?t(e):t,{fontFamily:o=T,fontSize:s=14,fontWeightLight:l=300,fontWeightRegular:c=400,fontWeightMedium:u=500,fontWeightBold:d=700,htmlFontSize:h=16,allVariants:p,pxToRem:f}=r,m=(0,i.A)(r,S);const g=s/14,y=f||(e=>e/h*g+"rem"),v=(e,t,r,i,a)=>{return(0,n.A)({fontFamily:o,fontWeight:e,fontSize:y(t),lineHeight:r},o===T?{letterSpacing:(s=i/t,Math.round(1e5*s)/1e5)+"em"}:{},a,p);var s},x={h1:v(l,96,1.167,-1.5),h2:v(l,60,1.2,-.5),h3:v(c,48,1.167,0),h4:v(c,34,1.235,.25),h5:v(c,24,1.334,0),h6:v(u,20,1.6,.15),subtitle1:v(c,16,1.75,.15),subtitle2:v(u,14,1.57,.1),body1:v(c,16,1.5,.15),body2:v(c,14,1.43,.15),button:v(u,14,1.75,.4,A),caption:v(c,12,1.66,.4),overline:v(c,12,2.66,1,A),inherit:{fontFamily:"inherit",fontWeight:"inherit",fontSize:"inherit",lineHeight:"inherit",letterSpacing:"inherit"}};return(0,a.A)((0,n.A)({htmlFontSize:h,pxToRem:y,fontFamily:o,fontSize:s,fontWeightLight:l,fontWeightRegular:c,fontWeightMedium:u,fontWeightBold:d},x),m,{clone:!1})}function C(){return[`${arguments.length<=0?void 0:arguments[0]}px ${arguments.length<=1?void 0:arguments[1]}px ${arguments.length<=2?void 0:arguments[2]}px ${arguments.length<=3?void 0:arguments[3]}px rgba(0,0,0,0.2)`,`${arguments.length<=4?void 0:arguments[4]}px ${arguments.length<=5?void 0:arguments[5]}px ${arguments.length<=6?void 0:arguments[6]}px ${arguments.length<=7?void 0:arguments[7]}px rgba(0,0,0,0.14)`,`${arguments.length<=8?void 0:arguments[8]}px ${arguments.length<=9?void 0:arguments[9]}px ${arguments.length<=10?void 0:arguments[10]}px ${arguments.length<=11?void 0:arguments[11]}px rgba(0,0,0,0.12)`].join(",")}const E=["none",C(0,2,1,-1,0,1,1,0,0,1,3,0),C(0,3,1,-2,0,2,2,0,0,1,5,0),C(0,3,3,-2,0,3,4,0,0,1,8,0),C(0,2,4,-1,0,4,5,0,0,1,10,0),C(0,3,5,-1,0,5,8,0,0,1,14,0),C(0,3,5,-1,0,6,10,0,0,1,18,0),C(0,4,5,-2,0,7,10,1,0,2,16,1),C(0,5,5,-3,0,8,10,1,0,3,14,2),C(0,5,6,-3,0,9,12,1,0,3,16,2),C(0,6,6,-3,0,10,14,1,0,4,18,3),C(0,6,7,-4,0,11,15,1,0,4,20,3),C(0,7,8,-4,0,12,17,2,0,5,22,4),C(0,7,8,-4,0,13,19,2,0,5,24,4),C(0,7,9,-4,0,14,21,2,0,5,26,4),C(0,8,9,-5,0,15,22,2,0,6,28,5),C(0,8,10,-5,0,16,24,2,0,6,30,5),C(0,8,11,-5,0,17,26,2,0,6,32,5),C(0,9,11,-5,0,18,28,2,0,7,34,6),C(0,9,12,-6,0,19,29,2,0,7,36,6),C(0,10,13,-6,0,20,31,3,0,8,38,7),C(0,10,13,-6,0,21,33,3,0,8,40,7),C(0,10,14,-6,0,22,35,3,0,8,42,7),C(0,11,14,-7,0,23,36,3,0,9,44,8),C(0,11,15,-7,0,24,38,3,0,9,46,8)];var I=r(14318);const P={mobileStepper:1e3,fab:1050,speedDial:1050,appBar:1100,drawer:1200,modal:1300,snackbar:1400,tooltip:1500},O=["breakpoints","mixins","spacing","palette","transitions","typography","shape"];function R(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const{mixins:t={},palette:r={},transitions:u={},typography:d={}}=e,h=(0,i.A)(e,O);if(e.vars)throw new Error((0,o.A)(18));const p=k(r),f=(0,c.A)(e);let m=(0,a.A)(f,{mixins:(g=f.breakpoints,y=t,(0,n.A)({toolbar:{minHeight:56,[g.up("xs")]:{"@media (orientation: landscape)":{minHeight:48}},[g.up("sm")]:{minHeight:64}}},y)),palette:p,shadows:E.slice(),typography:M(p,d),transitions:(0,I.Ay)(u),zIndex:(0,n.A)({},P)});var g,y;m=(0,a.A)(m,h);for(var v=arguments.length,x=new Array(v>1?v-1:0),b=1;b(0,a.A)(e,t)),m),m.unstable_sxConfig=(0,n.A)({},s.A,null==h?void 0:h.unstable_sxConfig),m.unstable_sx=function(e){return(0,l.A)({sx:e,theme:this})},m}const L=R},14318:(e,t,r)=>{"use strict";r.d(t,{Ay:()=>u,p0:()=>s});var n=r(98587),i=r(58168);const o=["duration","easing","delay"],a={easeInOut:"cubic-bezier(0.4, 0, 0.2, 1)",easeOut:"cubic-bezier(0.0, 0, 0.2, 1)",easeIn:"cubic-bezier(0.4, 0, 1, 1)",sharp:"cubic-bezier(0.4, 0, 0.6, 1)"},s={shortest:150,shorter:200,short:250,standard:300,complex:375,enteringScreen:225,leavingScreen:195};function l(e){return`${Math.round(e)}ms`}function c(e){if(!e)return 0;const t=e/36;return Math.round(10*(4+15*t**.25+t/5))}function u(e){const t=(0,i.A)({},a,e.easing),r=(0,i.A)({},s,e.duration);return(0,i.A)({getAutoHeightDuration:c,create:function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:["all"],i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{duration:a=r.standard,easing:s=t.easeInOut,delay:c=0}=i;(0,n.A)(i,o);return(Array.isArray(e)?e:[e]).map((e=>`${e} ${"string"===typeof a?a:l(a)} ${s} ${"string"===typeof c?c:l(c)}`)).join(",")}},e,{easing:t,duration:r})}},15170:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=(0,r(40688).A)()},13375:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n="$$material"},61475:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(47123);const i=e=>(0,n.A)(e)&&"classes"!==e},47123:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e){return"ownerState"!==e&&"theme"!==e&&"sx"!==e&&"as"!==e}},34535:(e,t,r)=>{"use strict";r.d(t,{Ay:()=>s});var n=r(38052),i=r(15170),o=r(13375),a=r(61475);const s=(0,n.Ay)({themeId:o.A,defaultTheme:i.A,rootShouldForwardProp:a.A})},6803:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=r(67598).A},59662:(e,t,r)=>{"use strict";r.d(t,{A:()=>x});var n=r(58168),i=r(65043),o=r(98587),a=r(58387),s=r(98610),l=r(6803),c=r(98206),u=r(34535),d=r(92532),h=r(72372);function p(e){return(0,h.Ay)("MuiSvgIcon",e)}(0,d.A)("MuiSvgIcon",["root","colorPrimary","colorSecondary","colorAction","colorError","colorDisabled","fontSizeInherit","fontSizeSmall","fontSizeMedium","fontSizeLarge"]);var f=r(70579);const m=["children","className","color","component","fontSize","htmlColor","inheritViewBox","titleAccess","viewBox"],g=(0,u.Ay)("svg",{name:"MuiSvgIcon",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,"inherit"!==r.color&&t[`color${(0,l.A)(r.color)}`],t[`fontSize${(0,l.A)(r.fontSize)}`]]}})((e=>{let{theme:t,ownerState:r}=e;var n,i,o,a,s,l,c,u,d,h,p,f,m;return{userSelect:"none",width:"1em",height:"1em",display:"inline-block",fill:r.hasSvgAsChild?void 0:"currentColor",flexShrink:0,transition:null==(n=t.transitions)||null==(i=n.create)?void 0:i.call(n,"fill",{duration:null==(o=t.transitions)||null==(o=o.duration)?void 0:o.shorter}),fontSize:{inherit:"inherit",small:(null==(a=t.typography)||null==(s=a.pxToRem)?void 0:s.call(a,20))||"1.25rem",medium:(null==(l=t.typography)||null==(c=l.pxToRem)?void 0:c.call(l,24))||"1.5rem",large:(null==(u=t.typography)||null==(d=u.pxToRem)?void 0:d.call(u,35))||"2.1875rem"}[r.fontSize],color:null!=(h=null==(p=(t.vars||t).palette)||null==(p=p[r.color])?void 0:p.main)?h:{action:null==(f=(t.vars||t).palette)||null==(f=f.action)?void 0:f.active,disabled:null==(m=(t.vars||t).palette)||null==(m=m.action)?void 0:m.disabled,inherit:void 0}[r.color]}})),y=i.forwardRef((function(e,t){const r=(0,c.b)({props:e,name:"MuiSvgIcon"}),{children:u,className:d,color:h="inherit",component:y="svg",fontSize:v="medium",htmlColor:x,inheritViewBox:b=!1,titleAccess:_,viewBox:w="0 0 24 24"}=r,k=(0,o.A)(r,m),S=i.isValidElement(u)&&"svg"===u.type,A=(0,n.A)({},r,{color:h,component:y,fontSize:v,instanceFontSize:e.fontSize,inheritViewBox:b,viewBox:w,hasSvgAsChild:S}),T={};b||(T.viewBox=w);const M=(e=>{const{color:t,fontSize:r,classes:n}=e,i={root:["root","inherit"!==t&&`color${(0,l.A)(t)}`,`fontSize${(0,l.A)(r)}`]};return(0,s.A)(i,p,n)})(A);return(0,f.jsxs)(g,(0,n.A)({as:y,className:(0,a.A)(M.root,d),focusable:"false",color:x,"aria-hidden":!_||void 0,role:_?"img":void 0,ref:t},T,k,S&&u.props,{ownerState:A,children:[S?u.props.children:u,_?(0,f.jsx)("title",{children:_}):null]}))}));y.muiName="SvgIcon";const v=y;function x(e,t){function r(r,i){return(0,f.jsx)(v,(0,n.A)({"data-testid":`${t}Icon`,ref:i},r,{children:e}))}return r.muiName=v.muiName,i.memo(i.forwardRef(r))}},80950:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=r(83468).A},4421:(e,t,r)=>{"use strict";r.r(t),r.d(t,{capitalize:()=>i.A,createChainedFunction:()=>o,createSvgIcon:()=>a.A,debounce:()=>s.A,deprecatedPropType:()=>l,isMuiElement:()=>c.A,ownerDocument:()=>u.A,ownerWindow:()=>d.A,requirePropFactory:()=>h,setRef:()=>p,unstable_ClassNameGenerator:()=>_,unstable_useEnhancedEffect:()=>f.A,unstable_useId:()=>m.A,unsupportedProp:()=>g,useControlled:()=>y.A,useEventCallback:()=>v.A,useForkRef:()=>x.A,useIsFocusVisible:()=>b.A});var n=r(79386),i=r(6803);const o=r(42456).A;var a=r(59662),s=r(80950);const l=function(e,t){return()=>null};var c=r(27328),u=r(22427),d=r(36078);r(58168);const h=function(e,t){return()=>null};const p=r(26564).A;var f=r(55013),m=r(45879);const g=function(e,t,r,n,i){return null};var y=r(54516),v=r(93319),x=r(95849),b=r(87844);const _={configure:e=>{n.A.configure(e)}}},27328:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(65043);const i=function(e,t){var r,i;return n.isValidElement(e)&&-1!==t.indexOf(null!=(r=e.type.muiName)?r:null==(i=e.type)||null==(i=i._payload)||null==(i=i.value)?void 0:i.muiName)}},22427:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=r(31668).A},36078:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=r(63940).A},54516:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=r(51052).A},55013:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=r(84440).A},93319:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=r(31782).A},95849:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=r(63462).A},45879:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=r(5844).A},87844:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=r(49640).A},70869:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});r(65043);var n=r(83290),i=r(70579);function o(e){const{styles:t,defaultTheme:r={}}=e,o="function"===typeof t?e=>{return t(void 0===(n=e)||null===n||0===Object.keys(n).length?r:e);var n}:t;return(0,i.jsx)(n.mL,{styles:o})}},82030:(e,t,r)=>{"use strict";r.r(t),r.d(t,{GlobalStyles:()=>k.A,StyledEngineProvider:()=>w,ThemeContext:()=>l.T,css:()=>v.AH,default:()=>S,internal_processStyles:()=>A,keyframes:()=>v.i7});var n=r(58168),i=r(65043),o=r(30918),a=/^((children|dangerouslySetInnerHTML|key|ref|autoFocus|defaultValue|defaultChecked|innerHTML|suppressContentEditableWarning|suppressHydrationWarning|valueLink|abbr|accept|acceptCharset|accessKey|action|allow|allowUserMedia|allowPaymentRequest|allowFullScreen|allowTransparency|alt|async|autoComplete|autoPlay|capture|cellPadding|cellSpacing|challenge|charSet|checked|cite|classID|className|cols|colSpan|content|contentEditable|contextMenu|controls|controlsList|coords|crossOrigin|data|dateTime|decoding|default|defer|dir|disabled|disablePictureInPicture|disableRemotePlayback|download|draggable|encType|enterKeyHint|fetchpriority|fetchPriority|form|formAction|formEncType|formMethod|formNoValidate|formTarget|frameBorder|headers|height|hidden|high|href|hrefLang|htmlFor|httpEquiv|id|inputMode|integrity|is|keyParams|keyType|kind|label|lang|list|loading|loop|low|marginHeight|marginWidth|max|maxLength|media|mediaGroup|method|min|minLength|multiple|muted|name|nonce|noValidate|open|optimum|pattern|placeholder|playsInline|poster|preload|profile|radioGroup|readOnly|referrerPolicy|rel|required|reversed|role|rows|rowSpan|sandbox|scope|scoped|scrolling|seamless|selected|shape|size|sizes|slot|span|spellCheck|src|srcDoc|srcLang|srcSet|start|step|style|summary|tabIndex|target|title|translate|type|useMap|value|width|wmode|wrap|about|datatype|inlist|prefix|property|resource|typeof|vocab|autoCapitalize|autoCorrect|autoSave|color|incremental|fallback|inert|itemProp|itemScope|itemType|itemID|itemRef|on|option|results|security|unselectable|accentHeight|accumulate|additive|alignmentBaseline|allowReorder|alphabetic|amplitude|arabicForm|ascent|attributeName|attributeType|autoReverse|azimuth|baseFrequency|baselineShift|baseProfile|bbox|begin|bias|by|calcMode|capHeight|clip|clipPathUnits|clipPath|clipRule|colorInterpolation|colorInterpolationFilters|colorProfile|colorRendering|contentScriptType|contentStyleType|cursor|cx|cy|d|decelerate|descent|diffuseConstant|direction|display|divisor|dominantBaseline|dur|dx|dy|edgeMode|elevation|enableBackground|end|exponent|externalResourcesRequired|fill|fillOpacity|fillRule|filter|filterRes|filterUnits|floodColor|floodOpacity|focusable|fontFamily|fontSize|fontSizeAdjust|fontStretch|fontStyle|fontVariant|fontWeight|format|from|fr|fx|fy|g1|g2|glyphName|glyphOrientationHorizontal|glyphOrientationVertical|glyphRef|gradientTransform|gradientUnits|hanging|horizAdvX|horizOriginX|ideographic|imageRendering|in|in2|intercept|k|k1|k2|k3|k4|kernelMatrix|kernelUnitLength|kerning|keyPoints|keySplines|keyTimes|lengthAdjust|letterSpacing|lightingColor|limitingConeAngle|local|markerEnd|markerMid|markerStart|markerHeight|markerUnits|markerWidth|mask|maskContentUnits|maskUnits|mathematical|mode|numOctaves|offset|opacity|operator|order|orient|orientation|origin|overflow|overlinePosition|overlineThickness|panose1|paintOrder|pathLength|patternContentUnits|patternTransform|patternUnits|pointerEvents|points|pointsAtX|pointsAtY|pointsAtZ|preserveAlpha|preserveAspectRatio|primitiveUnits|r|radius|refX|refY|renderingIntent|repeatCount|repeatDur|requiredExtensions|requiredFeatures|restart|result|rotate|rx|ry|scale|seed|shapeRendering|slope|spacing|specularConstant|specularExponent|speed|spreadMethod|startOffset|stdDeviation|stemh|stemv|stitchTiles|stopColor|stopOpacity|strikethroughPosition|strikethroughThickness|string|stroke|strokeDasharray|strokeDashoffset|strokeLinecap|strokeLinejoin|strokeMiterlimit|strokeOpacity|strokeWidth|surfaceScale|systemLanguage|tableValues|targetX|targetY|textAnchor|textDecoration|textRendering|textLength|to|transform|u1|u2|underlinePosition|underlineThickness|unicode|unicodeBidi|unicodeRange|unitsPerEm|vAlphabetic|vHanging|vIdeographic|vMathematical|values|vectorEffect|version|vertAdvY|vertOriginX|vertOriginY|viewBox|viewTarget|visibility|widths|wordSpacing|writingMode|x|xHeight|x1|x2|xChannelSelector|xlinkActuate|xlinkArcrole|xlinkHref|xlinkRole|xlinkShow|xlinkTitle|xlinkType|xmlBase|xmlns|xmlnsXlink|xmlLang|xmlSpace|y|y1|y2|yChannelSelector|z|zoomAndPan|for|class|autofocus)|(([Dd][Aa][Tt][Aa]|[Aa][Rr][Ii][Aa]|x)-.*))$/,s=(0,o.A)((function(e){return a.test(e)||111===e.charCodeAt(0)&&110===e.charCodeAt(1)&&e.charCodeAt(2)<91})),l=r(84575),c=r(81722),u=r(99002),d=r(69436),h=s,p=function(e){return"theme"!==e},f=function(e){return"string"===typeof e&&e.charCodeAt(0)>96?h:p},m=function(e,t,r){var n;if(t){var i=t.shouldForwardProp;n=e.__emotion_forwardProp&&i?function(t){return e.__emotion_forwardProp(t)&&i(t)}:i}return"function"!==typeof n&&r&&(n=e.__emotion_forwardProp),n},g=function(e){var t=e.cache,r=e.serialized,n=e.isStringTag;return(0,c.SF)(t,r,n),(0,d.s)((function(){return(0,c.sk)(t,r,n)})),null},y=function e(t,r){var o,a,s=t.__emotion_real===t,d=s&&t.__emotion_base||t;void 0!==r&&(o=r.label,a=r.target);var h=m(t,r,s),p=h||f(d),y=!p("as");return function(){var v=arguments,x=s&&void 0!==t.__emotion_styles?t.__emotion_styles.slice(0):[];if(void 0!==o&&x.push("label:"+o+";"),null==v[0]||void 0===v[0].raw)x.push.apply(x,v);else{x.push(v[0][0]);for(var b=v.length,_=1;_{Array.isArray(e.__emotion_styles)&&(e.__emotion_styles=t(e.__emotion_styles))}},67266:(e,t,r)=>{"use strict";var n=r(24994);t.X4=p,t.e$=f,t.eM=function(e,t){const r=h(e),n=h(t);return(Math.max(r,n)+.05)/(Math.min(r,n)+.05)},t.a=m;var i=n(r(10457)),o=n(r(6531));function a(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1;return(0,o.default)(e,t,r)}function s(e){e=e.slice(1);const t=new RegExp(`.{1,${e.length>=6?2:1}}`,"g");let r=e.match(t);return r&&1===r[0].length&&(r=r.map((e=>e+e))),r?`rgb${4===r.length?"a":""}(${r.map(((e,t)=>t<3?parseInt(e,16):Math.round(parseInt(e,16)/255*1e3)/1e3)).join(", ")})`:""}function l(e){if(e.type)return e;if("#"===e.charAt(0))return l(s(e));const t=e.indexOf("("),r=e.substring(0,t);if(-1===["rgb","rgba","hsl","hsla","color"].indexOf(r))throw new Error((0,i.default)(9,e));let n,o=e.substring(t+1,e.length-1);if("color"===r){if(o=o.split(" "),n=o.shift(),4===o.length&&"/"===o[3].charAt(0)&&(o[3]=o[3].slice(1)),-1===["srgb","display-p3","a98-rgb","prophoto-rgb","rec-2020"].indexOf(n))throw new Error((0,i.default)(10,n))}else o=o.split(",");return o=o.map((e=>parseFloat(e))),{type:r,values:o,colorSpace:n}}const c=e=>{const t=l(e);return t.values.slice(0,3).map(((e,r)=>-1!==t.type.indexOf("hsl")&&0!==r?`${e}%`:e)).join(" ")};function u(e){const{type:t,colorSpace:r}=e;let{values:n}=e;return-1!==t.indexOf("rgb")?n=n.map(((e,t)=>t<3?parseInt(e,10):e)):-1!==t.indexOf("hsl")&&(n[1]=`${n[1]}%`,n[2]=`${n[2]}%`),n=-1!==t.indexOf("color")?`${r} ${n.join(" ")}`:`${n.join(", ")}`,`${t}(${n})`}function d(e){e=l(e);const{values:t}=e,r=t[0],n=t[1]/100,i=t[2]/100,o=n*Math.min(i,1-i),a=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:(e+r/30)%12;return i-o*Math.max(Math.min(t-3,9-t,1),-1)};let s="rgb";const c=[Math.round(255*a(0)),Math.round(255*a(8)),Math.round(255*a(4))];return"hsla"===e.type&&(s+="a",c.push(t[3])),u({type:s,values:c})}function h(e){let t="hsl"===(e=l(e)).type||"hsla"===e.type?l(d(e)).values:e.values;return t=t.map((t=>("color"!==e.type&&(t/=255),t<=.03928?t/12.92:((t+.055)/1.055)**2.4))),Number((.2126*t[0]+.7152*t[1]+.0722*t[2]).toFixed(3))}function p(e,t){return e=l(e),t=a(t),"rgb"!==e.type&&"hsl"!==e.type||(e.type+="a"),"color"===e.type?e.values[3]=`/${t}`:e.values[3]=t,u(e)}function f(e,t){if(e=l(e),t=a(t),-1!==e.type.indexOf("hsl"))e.values[2]*=1-t;else if(-1!==e.type.indexOf("rgb")||-1!==e.type.indexOf("color"))for(let r=0;r<3;r+=1)e.values[r]*=1-t;return u(e)}function m(e,t){if(e=l(e),t=a(t),-1!==e.type.indexOf("hsl"))e.values[2]+=(100-e.values[2])*t;else if(-1!==e.type.indexOf("rgb"))for(let r=0;r<3;r+=1)e.values[r]+=(255-e.values[r])*t;else if(-1!==e.type.indexOf("color"))for(let r=0;r<3;r+=1)e.values[r]+=(1-e.values[r])*t;return u(e)}function g(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:.15;return h(e)>.5?f(e,t):m(e,t)}},38052:(e,t,r)=>{"use strict";var n=r(24994);t.Ay=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const{themeId:t,defaultTheme:r=m,rootShouldForwardProp:n=f,slotShouldForwardProp:l=f}=e,u=e=>(0,c.default)((0,i.default)({},e,{theme:y((0,i.default)({},e,{defaultTheme:r,themeId:t}))}));return u.__mui_systemSx=!0,function(e){let c=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};(0,a.internal_processStyles)(e,(e=>e.filter((e=>!(null!=e&&e.__mui_systemSx)))));const{name:d,slot:p,skipVariantsResolver:m,skipSx:b,overridesResolver:_=v(g(p))}=c,w=(0,o.default)(c,h),k=void 0!==m?m:p&&"Root"!==p&&"root"!==p||!1,S=b||!1;let A=f;"Root"===p||"root"===p?A=n:p?A=l:function(e){return"string"===typeof e&&e.charCodeAt(0)>96}(e)&&(A=void 0);const T=(0,a.default)(e,(0,i.default)({shouldForwardProp:A,label:undefined},w)),M=e=>"function"===typeof e&&e.__emotion_real!==e||(0,s.isPlainObject)(e)?n=>x(e,(0,i.default)({},n,{theme:y({theme:n.theme,defaultTheme:r,themeId:t})})):e,C=function(n){let o=M(n);for(var a=arguments.length,s=new Array(a>1?a-1:0),l=1;l{const n=y((0,i.default)({},e,{defaultTheme:r,themeId:t}));if(!n.components||!n.components[d]||!n.components[d].styleOverrides)return null;const o=n.components[d].styleOverrides,a={};return Object.entries(o).forEach((t=>{let[r,o]=t;a[r]=x(o,(0,i.default)({},e,{theme:n}))})),_(e,a)})),d&&!k&&c.push((e=>{var n;const o=y((0,i.default)({},e,{defaultTheme:r,themeId:t}));return x({variants:null==o||null==(n=o.components)||null==(n=n[d])?void 0:n.variants},(0,i.default)({},e,{theme:o}))})),S||c.push(u);const h=c.length-s.length;if(Array.isArray(n)&&h>0){const e=new Array(h).fill("");o=[...n,...e],o.raw=[...n.raw,...e]}const p=T(o,...c);return e.muiName&&(p.muiName=e.muiName),p};return T.withConfig&&(C.withConfig=T.withConfig),C}};var i=n(r(94634)),o=n(r(54893)),a=function(e,t){if(!t&&e&&e.__esModule)return e;if(null===e||"object"!=typeof e&&"function"!=typeof e)return{default:e};var r=p(t);if(r&&r.has(e))return r.get(e);var n={__proto__:null},i=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var o in e)if("default"!==o&&Object.prototype.hasOwnProperty.call(e,o)){var a=i?Object.getOwnPropertyDescriptor(e,o):null;a&&(a.get||a.set)?Object.defineProperty(n,o,a):n[o]=e[o]}return n.default=e,r&&r.set(e,n),n}(r(82030)),s=r(19482),l=(n(r(87918)),n(r(83382)),n(r(24989))),c=n(r(73234));const u=["ownerState"],d=["variants"],h=["name","slot","skipVariantsResolver","skipSx","overridesResolver"];function p(e){if("function"!=typeof WeakMap)return null;var t=new WeakMap,r=new WeakMap;return(p=function(e){return e?r:t})(e)}function f(e){return"ownerState"!==e&&"theme"!==e&&"sx"!==e&&"as"!==e}const m=(0,l.default)(),g=e=>e?e.charAt(0).toLowerCase()+e.slice(1):e;function y(e){let{defaultTheme:t,theme:r,themeId:n}=e;return i=r,0===Object.keys(i).length?t:r[n]||r;var i}function v(e){return e?(t,r)=>r[e]:null}function x(e,t){let{ownerState:r}=t,n=(0,o.default)(t,u);const a="function"===typeof e?e((0,i.default)({ownerState:r},n)):e;if(Array.isArray(a))return a.flatMap((e=>x(e,(0,i.default)({ownerState:r},n))));if(a&&"object"===typeof a&&Array.isArray(a.variants)){const{variants:e=[]}=a;let t=(0,o.default)(a,d);return e.forEach((e=>{let o=!0;"function"===typeof e.props?o=e.props((0,i.default)({ownerState:r},n,r)):Object.keys(e.props).forEach((t=>{(null==r?void 0:r[t])!==e.props[t]&&n[t]!==e.props[t]&&(o=!1)})),o&&(Array.isArray(t)||(t=[t]),t.push("function"===typeof e.style?e.style((0,i.default)({ownerState:r},n,r)):e.style))})),t}return a}},13654:(e,t,r)=>{"use strict";r.d(t,{A:()=>l,b:()=>s});var n=r(65043),i=r(13030),o=r(70579);const a=n.createContext(void 0);function s(e){let{props:t,name:r}=e;return function(e){const{theme:t,name:r,props:n}=e;if(!t||!t.components||!t.components[r])return n;const o=t.components[r];return o.defaultProps?(0,i.A)(o.defaultProps,n):o.styleOverrides||o.variants?n:(0,i.A)(o,n)}({props:t,name:r,theme:{components:n.useContext(a)}})}const l=function(e){let{value:t,children:r}=e;return(0,o.jsx)(a.Provider,{value:t,children:r})}},89751:(e,t,r)=>{"use strict";r.d(t,{EU:()=>s,NI:()=>a,iZ:()=>c,kW:()=>u,vf:()=>l,zu:()=>i});var n=r(19172);const i={xs:0,sm:600,md:900,lg:1200,xl:1536},o={keys:["xs","sm","md","lg","xl"],up:e=>`@media (min-width:${i[e]}px)`};function a(e,t,r){const n=e.theme||{};if(Array.isArray(t)){const e=n.breakpoints||o;return t.reduce(((n,i,o)=>(n[e.up(e.keys[o])]=r(t[o]),n)),{})}if("object"===typeof t){const e=n.breakpoints||o;return Object.keys(t).reduce(((n,o)=>{if(-1!==Object.keys(e.values||i).indexOf(o)){n[e.up(o)]=r(t[o],o)}else{const e=o;n[e]=t[e]}return n}),{})}return r(t)}function s(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};var t;return(null==(t=e.keys)?void 0:t.reduce(((t,r)=>(t[e.up(r)]={},t)),{}))||{}}function l(e,t){return e.reduce(((e,t)=>{const r=e[t];return(!r||0===Object.keys(r).length)&&delete e[t],e}),t)}function c(e){const t=s(e);for(var r=arguments.length,i=new Array(r>1?r-1:0),o=1;o(0,n.A)(e,t)),{});return l(Object.keys(t),a)}function u(e){let{values:t,breakpoints:r,base:n}=e;const i=n||function(e,t){if("object"!==typeof e)return{};const r={},n=Object.keys(t);return Array.isArray(e)?n.forEach(((t,n)=>{n{null!=e[t]&&(r[t]=!0)})),r}(t,r),o=Object.keys(i);if(0===o.length)return t;let a;return o.reduce(((e,r,n)=>(Array.isArray(t)?(e[r]=null!=t[n]?t[n]:t[a],a=n):"object"===typeof t?(e[r]=null!=t[r]?t[r]:t[a],a=r):e[r]=t,e)),{})}},89703:(e,t,r)=>{"use strict";function n(e,t){const r=this;if(r.vars&&"function"===typeof r.getColorSchemeSelector){const n=r.getColorSchemeSelector(e).replace(/(\[[^\]]+\])/,"*:where($1)");return{[n]:t}}return r.palette.mode===e?t:{}}r.d(t,{A:()=>n})},34853:(e,t,r)=>{"use strict";r.d(t,{A:()=>s});var n=r(98587),i=r(58168);const o=["values","unit","step"],a=e=>{const t=Object.keys(e).map((t=>({key:t,val:e[t]})))||[];return t.sort(((e,t)=>e.val-t.val)),t.reduce(((e,t)=>(0,i.A)({},e,{[t.key]:t.val})),{})};function s(e){const{values:t={xs:0,sm:600,md:900,lg:1200,xl:1536},unit:r="px",step:s=5}=e,l=(0,n.A)(e,o),c=a(t),u=Object.keys(c);function d(e){return`@media (min-width:${"number"===typeof t[e]?t[e]:e}${r})`}function h(e){return`@media (max-width:${("number"===typeof t[e]?t[e]:e)-s/100}${r})`}function p(e,n){const i=u.indexOf(n);return`@media (min-width:${"number"===typeof t[e]?t[e]:e}${r}) and (max-width:${(-1!==i&&"number"===typeof t[u[i]]?t[u[i]]:n)-s/100}${r})`}return(0,i.A)({keys:u,values:c,up:d,down:h,between:p,only:function(e){return u.indexOf(e)+1{"use strict";r.d(t,{A:()=>p});var n=r(58168),i=r(98587),o=r(19172),a=r(34853);const s={borderRadius:4};var l=r(28604);var c=r(58812),u=r(37758),d=r(89703);const h=["breakpoints","palette","spacing","shape"];const p=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const{breakpoints:t={},palette:r={},spacing:p,shape:f={}}=e,m=(0,i.A)(e,h),g=(0,a.A)(t),y=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:8;if(e.mui)return e;const t=(0,l.LX)({spacing:e}),r=function(){for(var e=arguments.length,r=new Array(e),n=0;n{const r=t(e);return"number"===typeof r?`${r}px`:r})).join(" ")};return r.mui=!0,r}(p);let v=(0,o.A)({breakpoints:g,direction:"ltr",components:{},palette:(0,n.A)({mode:"light"},r),spacing:y,shape:(0,n.A)({},s,f)},m);v.applyStyles=d.A;for(var x=arguments.length,b=new Array(x>1?x-1:0),_=1;_(0,o.A)(e,t)),v),v.unstable_sxConfig=(0,n.A)({},u.A,null==m?void 0:m.unstable_sxConfig),v.unstable_sx=function(e){return(0,c.A)({sx:e,theme:this})},v}},24989:(e,t,r)=>{"use strict";r.r(t),r.d(t,{default:()=>n.A,private_createBreakpoints:()=>i.A,unstable_applyStyles:()=>o.A});var n=r(18280),i=r(34853),o=r(89703)},13815:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(19172);const i=function(e,t){return t?(0,n.A)(e,t,{clone:!1}):e}},28604:(e,t,r)=>{"use strict";r.d(t,{LX:()=>f,MA:()=>p,_W:()=>m,Lc:()=>v,Ms:()=>x});var n=r(89751),i=r(17162),o=r(13815);const a={m:"margin",p:"padding"},s={t:"Top",r:"Right",b:"Bottom",l:"Left",x:["Left","Right"],y:["Top","Bottom"]},l={marginX:"mx",marginY:"my",paddingX:"px",paddingY:"py"},c=function(e){const t={};return r=>(void 0===t[r]&&(t[r]=e(r)),t[r])}((e=>{if(e.length>2){if(!l[e])return[e];e=l[e]}const[t,r]=e.split(""),n=a[t],i=s[r]||"";return Array.isArray(i)?i.map((e=>n+e)):[n+i]})),u=["m","mt","mr","mb","ml","mx","my","margin","marginTop","marginRight","marginBottom","marginLeft","marginX","marginY","marginInline","marginInlineStart","marginInlineEnd","marginBlock","marginBlockStart","marginBlockEnd"],d=["p","pt","pr","pb","pl","px","py","padding","paddingTop","paddingRight","paddingBottom","paddingLeft","paddingX","paddingY","paddingInline","paddingInlineStart","paddingInlineEnd","paddingBlock","paddingBlockStart","paddingBlockEnd"],h=[...u,...d];function p(e,t,r,n){var o;const a=null!=(o=(0,i.Yn)(e,t,!1))?o:r;return"number"===typeof a?e=>"string"===typeof e?e:a*e:Array.isArray(a)?e=>"string"===typeof e?e:a[e]:"function"===typeof a?a:()=>{}}function f(e){return p(e,"spacing",8)}function m(e,t){if("string"===typeof t||null==t)return t;const r=e(Math.abs(t));return t>=0?r:"number"===typeof r?-r:`-${r}`}function g(e,t,r,i){if(-1===t.indexOf(r))return null;const o=function(e,t){return r=>e.reduce(((e,n)=>(e[n]=m(t,r),e)),{})}(c(r),i),a=e[r];return(0,n.NI)(e,a,o)}function y(e,t){const r=f(e.theme);return Object.keys(e).map((n=>g(e,t,n,r))).reduce(o.A,{})}function v(e){return y(e,u)}function x(e){return y(e,d)}function b(e){return y(e,h)}v.propTypes={},v.filterProps=u,x.propTypes={},x.filterProps=d,b.propTypes={},b.filterProps=h},17162:(e,t,r)=>{"use strict";r.d(t,{Ay:()=>s,BO:()=>a,Yn:()=>o});var n=r(67598),i=r(89751);function o(e,t){let r=!(arguments.length>2&&void 0!==arguments[2])||arguments[2];if(!t||"string"!==typeof t)return null;if(e&&e.vars&&r){const r=`vars.${t}`.split(".").reduce(((e,t)=>e&&e[t]?e[t]:null),e);if(null!=r)return r}return t.split(".").reduce(((e,t)=>e&&null!=e[t]?e[t]:null),e)}function a(e,t,r){let n,i=arguments.length>3&&void 0!==arguments[3]?arguments[3]:r;return n="function"===typeof e?e(r):Array.isArray(e)?e[r]||i:o(e,r)||i,t&&(n=t(n,i,e)),n}const s=function(e){const{prop:t,cssProperty:r=e.prop,themeKey:s,transform:l}=e,c=e=>{if(null==e[t])return null;const c=e[t],u=o(e.theme,s)||{};return(0,i.NI)(e,c,(e=>{let i=a(u,l,e);return e===i&&"string"===typeof e&&(i=a(u,l,`${t}${"default"===e?"":(0,n.A)(e)}`,e)),!1===r?i:{[r]:i}}))};return c.propTypes={},c.filterProps=[t],c}},37758:(e,t,r)=>{"use strict";r.d(t,{A:()=>L});var n=r(28604),i=r(17162),o=r(13815);const a=function(){for(var e=arguments.length,t=new Array(e),r=0;r(t.filterProps.forEach((r=>{e[r]=t})),e)),{}),i=e=>Object.keys(e).reduce(((t,r)=>n[r]?(0,o.A)(t,n[r](e)):t),{});return i.propTypes={},i.filterProps=t.reduce(((e,t)=>e.concat(t.filterProps)),[]),i};var s=r(89751);function l(e){return"number"!==typeof e?e:`${e}px solid`}function c(e,t){return(0,i.Ay)({prop:e,themeKey:"borders",transform:t})}const u=c("border",l),d=c("borderTop",l),h=c("borderRight",l),p=c("borderBottom",l),f=c("borderLeft",l),m=c("borderColor"),g=c("borderTopColor"),y=c("borderRightColor"),v=c("borderBottomColor"),x=c("borderLeftColor"),b=c("outline",l),_=c("outlineColor"),w=e=>{if(void 0!==e.borderRadius&&null!==e.borderRadius){const t=(0,n.MA)(e.theme,"shape.borderRadius",4,"borderRadius"),r=e=>({borderRadius:(0,n._W)(t,e)});return(0,s.NI)(e,e.borderRadius,r)}return null};w.propTypes={},w.filterProps=["borderRadius"];a(u,d,h,p,f,m,g,y,v,x,w,b,_);const k=e=>{if(void 0!==e.gap&&null!==e.gap){const t=(0,n.MA)(e.theme,"spacing",8,"gap"),r=e=>({gap:(0,n._W)(t,e)});return(0,s.NI)(e,e.gap,r)}return null};k.propTypes={},k.filterProps=["gap"];const S=e=>{if(void 0!==e.columnGap&&null!==e.columnGap){const t=(0,n.MA)(e.theme,"spacing",8,"columnGap"),r=e=>({columnGap:(0,n._W)(t,e)});return(0,s.NI)(e,e.columnGap,r)}return null};S.propTypes={},S.filterProps=["columnGap"];const A=e=>{if(void 0!==e.rowGap&&null!==e.rowGap){const t=(0,n.MA)(e.theme,"spacing",8,"rowGap"),r=e=>({rowGap:(0,n._W)(t,e)});return(0,s.NI)(e,e.rowGap,r)}return null};A.propTypes={},A.filterProps=["rowGap"];a(k,S,A,(0,i.Ay)({prop:"gridColumn"}),(0,i.Ay)({prop:"gridRow"}),(0,i.Ay)({prop:"gridAutoFlow"}),(0,i.Ay)({prop:"gridAutoColumns"}),(0,i.Ay)({prop:"gridAutoRows"}),(0,i.Ay)({prop:"gridTemplateColumns"}),(0,i.Ay)({prop:"gridTemplateRows"}),(0,i.Ay)({prop:"gridTemplateAreas"}),(0,i.Ay)({prop:"gridArea"}));function T(e,t){return"grey"===t?t:e}a((0,i.Ay)({prop:"color",themeKey:"palette",transform:T}),(0,i.Ay)({prop:"bgcolor",cssProperty:"backgroundColor",themeKey:"palette",transform:T}),(0,i.Ay)({prop:"backgroundColor",themeKey:"palette",transform:T}));function M(e){return e<=1&&0!==e?100*e+"%":e}const C=(0,i.Ay)({prop:"width",transform:M}),E=e=>{if(void 0!==e.maxWidth&&null!==e.maxWidth){const t=t=>{var r,n;const i=(null==(r=e.theme)||null==(r=r.breakpoints)||null==(r=r.values)?void 0:r[t])||s.zu[t];return i?"px"!==(null==(n=e.theme)||null==(n=n.breakpoints)?void 0:n.unit)?{maxWidth:`${i}${e.theme.breakpoints.unit}`}:{maxWidth:i}:{maxWidth:M(t)}};return(0,s.NI)(e,e.maxWidth,t)}return null};E.filterProps=["maxWidth"];const I=(0,i.Ay)({prop:"minWidth",transform:M}),P=(0,i.Ay)({prop:"height",transform:M}),O=(0,i.Ay)({prop:"maxHeight",transform:M}),R=(0,i.Ay)({prop:"minHeight",transform:M}),L=((0,i.Ay)({prop:"size",cssProperty:"width",transform:M}),(0,i.Ay)({prop:"size",cssProperty:"height",transform:M}),a(C,E,I,P,O,R,(0,i.Ay)({prop:"boxSizing"})),{border:{themeKey:"borders",transform:l},borderTop:{themeKey:"borders",transform:l},borderRight:{themeKey:"borders",transform:l},borderBottom:{themeKey:"borders",transform:l},borderLeft:{themeKey:"borders",transform:l},borderColor:{themeKey:"palette"},borderTopColor:{themeKey:"palette"},borderRightColor:{themeKey:"palette"},borderBottomColor:{themeKey:"palette"},borderLeftColor:{themeKey:"palette"},outline:{themeKey:"borders",transform:l},outlineColor:{themeKey:"palette"},borderRadius:{themeKey:"shape.borderRadius",style:w},color:{themeKey:"palette",transform:T},bgcolor:{themeKey:"palette",cssProperty:"backgroundColor",transform:T},backgroundColor:{themeKey:"palette",transform:T},p:{style:n.Ms},pt:{style:n.Ms},pr:{style:n.Ms},pb:{style:n.Ms},pl:{style:n.Ms},px:{style:n.Ms},py:{style:n.Ms},padding:{style:n.Ms},paddingTop:{style:n.Ms},paddingRight:{style:n.Ms},paddingBottom:{style:n.Ms},paddingLeft:{style:n.Ms},paddingX:{style:n.Ms},paddingY:{style:n.Ms},paddingInline:{style:n.Ms},paddingInlineStart:{style:n.Ms},paddingInlineEnd:{style:n.Ms},paddingBlock:{style:n.Ms},paddingBlockStart:{style:n.Ms},paddingBlockEnd:{style:n.Ms},m:{style:n.Lc},mt:{style:n.Lc},mr:{style:n.Lc},mb:{style:n.Lc},ml:{style:n.Lc},mx:{style:n.Lc},my:{style:n.Lc},margin:{style:n.Lc},marginTop:{style:n.Lc},marginRight:{style:n.Lc},marginBottom:{style:n.Lc},marginLeft:{style:n.Lc},marginX:{style:n.Lc},marginY:{style:n.Lc},marginInline:{style:n.Lc},marginInlineStart:{style:n.Lc},marginInlineEnd:{style:n.Lc},marginBlock:{style:n.Lc},marginBlockStart:{style:n.Lc},marginBlockEnd:{style:n.Lc},displayPrint:{cssProperty:!1,transform:e=>({"@media print":{display:e}})},display:{},overflow:{},textOverflow:{},visibility:{},whiteSpace:{},flexBasis:{},flexDirection:{},flexWrap:{},justifyContent:{},alignItems:{},alignContent:{},order:{},flex:{},flexGrow:{},flexShrink:{},alignSelf:{},justifyItems:{},justifySelf:{},gap:{style:k},rowGap:{style:A},columnGap:{style:S},gridColumn:{},gridRow:{},gridAutoFlow:{},gridAutoColumns:{},gridAutoRows:{},gridTemplateColumns:{},gridTemplateRows:{},gridTemplateAreas:{},gridArea:{},position:{},zIndex:{themeKey:"zIndex"},top:{},right:{},bottom:{},left:{},boxShadow:{themeKey:"shadows"},width:{transform:M},maxWidth:{style:E},minWidth:{transform:M},height:{transform:M},maxHeight:{transform:M},minHeight:{transform:M},boxSizing:{},fontFamily:{themeKey:"typography"},fontSize:{themeKey:"typography"},fontStyle:{themeKey:"typography"},fontWeight:{themeKey:"typography"},letterSpacing:{},textTransform:{},lineHeight:{},textAlign:{},typography:{cssProperty:!1,themeKey:"typography"}})},18698:(e,t,r)=>{"use strict";r.d(t,{A:()=>c});var n=r(58168),i=r(98587),o=r(19172),a=r(37758);const s=["sx"],l=e=>{var t,r;const n={systemProps:{},otherProps:{}},i=null!=(t=null==e||null==(r=e.theme)?void 0:r.unstable_sxConfig)?t:a.A;return Object.keys(e).forEach((t=>{i[t]?n.systemProps[t]=e[t]:n.otherProps[t]=e[t]})),n};function c(e){const{sx:t}=e,r=(0,i.A)(e,s),{systemProps:a,otherProps:c}=l(r);let u;return u=Array.isArray(t)?[a,...t]:"function"===typeof t?function(){const e=t(...arguments);return(0,o.Q)(e)?(0,n.A)({},a,e):a}:(0,n.A)({},a,t),(0,n.A)({},c,{sx:u})}},73234:(e,t,r)=>{"use strict";r.r(t),r.d(t,{default:()=>n.A,extendSxProp:()=>i.A,unstable_createStyleFunctionSx:()=>n.k,unstable_defaultSxConfig:()=>o.A});var n=r(58812),i=r(18698),o=r(37758)},58812:(e,t,r)=>{"use strict";r.d(t,{A:()=>u,k:()=>l});var n=r(67598),i=r(13815),o=r(17162),a=r(89751),s=r(37758);function l(){function e(e,t,r,i){const s={[e]:t,theme:r},l=i[e];if(!l)return{[e]:t};const{cssProperty:c=e,themeKey:u,transform:d,style:h}=l;if(null==t)return null;if("typography"===u&&"inherit"===t)return{[e]:t};const p=(0,o.Yn)(r,u)||{};if(h)return h(s);return(0,a.NI)(s,t,(t=>{let r=(0,o.BO)(p,d,t);return t===r&&"string"===typeof t&&(r=(0,o.BO)(p,d,`${e}${"default"===t?"":(0,n.A)(t)}`,t)),!1===c?r:{[c]:r}}))}return function t(r){var n;const{sx:o,theme:l={}}=r||{};if(!o)return null;const c=null!=(n=l.unstable_sxConfig)?n:s.A;function u(r){let n=r;if("function"===typeof r)n=r(l);else if("object"!==typeof r)return r;if(!n)return null;const o=(0,a.EU)(l.breakpoints),s=Object.keys(o);let u=o;return Object.keys(n).forEach((r=>{const o=(s=n[r],d=l,"function"===typeof s?s(d):s);var s,d;if(null!==o&&void 0!==o)if("object"===typeof o)if(c[r])u=(0,i.A)(u,e(r,o,l,c));else{const e=(0,a.NI)({theme:l},o,(e=>({[r]:e})));!function(){for(var e=arguments.length,t=new Array(e),r=0;re.concat(Object.keys(t))),[]),i=new Set(n);return t.every((e=>i.size===Object.keys(e).length))}(e,o)?u=(0,i.A)(u,e):u[r]=t({sx:o,theme:l})}else u=(0,i.A)(u,e(r,o,l,c))})),(0,a.vf)(s,u)}return Array.isArray(o)?o.map(u):u(o)}}const c=l();c.filterProps=["sx"];const u=c},92374:(e,t,r)=>{"use strict";t.A=void 0;var n=function(e,t){if(!t&&e&&e.__esModule)return e;if(null===e||"object"!=typeof e&&"function"!=typeof e)return{default:e};var r=o(t);if(r&&r.has(e))return r.get(e);var n={__proto__:null},i=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var a in e)if("default"!==a&&Object.prototype.hasOwnProperty.call(e,a)){var s=i?Object.getOwnPropertyDescriptor(e,a):null;s&&(s.get||s.set)?Object.defineProperty(n,a,s):n[a]=e[a]}return n.default=e,r&&r.set(e,n),n}(r(65043)),i=r(82030);function o(e){if("function"!=typeof WeakMap)return null;var t=new WeakMap,r=new WeakMap;return(o=function(e){return e?r:t})(e)}t.A=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null;const t=n.useContext(i.ThemeContext);return t&&(r=t,0!==Object.keys(r).length)?t:e;var r}},79386:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});const n=e=>e,i=(()=>{let e=n;return{configure(t){e=t},generate:t=>e(t),reset(){e=n}}})()},67598:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(17868);function i(e){if("string"!==typeof e)throw new Error((0,n.A)(7));return e.charAt(0).toUpperCase()+e.slice(1)}},87918:(e,t,r)=>{"use strict";r.r(t),r.d(t,{default:()=>n.A});var n=r(67598)},11188:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:Number.MIN_SAFE_INTEGER,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:Number.MAX_SAFE_INTEGER;return Math.max(t,Math.min(e,r))}},6531:(e,t,r)=>{"use strict";r.r(t),r.d(t,{default:()=>n.A});var n=r(11188)},98610:(e,t,r)=>{"use strict";function n(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0;const n={};return Object.keys(e).forEach((i=>{n[i]=e[i].reduce(((e,n)=>{if(n){const i=t(n);""!==i&&e.push(i),r&&r[n]&&e.push(r[n])}return e}),[]).join(" ")})),n}r.d(t,{A:()=>n})},42456:(e,t,r)=>{"use strict";function n(){for(var e=arguments.length,t=new Array(e),r=0;rnull==t?e:function(){for(var r=arguments.length,n=new Array(r),i=0;i{}))}r.d(t,{A:()=>n})},83468:(e,t,r)=>{"use strict";function n(e){let t,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:166;function n(){for(var n=arguments.length,i=new Array(n),o=0;o{e.apply(this,i)}),r)}return n.clear=()=>{clearTimeout(t)},n}r.d(t,{A:()=>n})},19172:(e,t,r)=>{"use strict";r.d(t,{A:()=>a,Q:()=>i});var n=r(58168);function i(e){if("object"!==typeof e||null===e)return!1;const t=Object.getPrototypeOf(e);return(null===t||t===Object.prototype||null===Object.getPrototypeOf(t))&&!(Symbol.toStringTag in e)&&!(Symbol.iterator in e)}function o(e){if(!i(e))return e;const t={};return Object.keys(e).forEach((r=>{t[r]=o(e[r])})),t}function a(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{clone:!0};const s=r.clone?(0,n.A)({},e):e;return i(e)&&i(t)&&Object.keys(t).forEach((n=>{i(t[n])&&Object.prototype.hasOwnProperty.call(e,n)&&i(e[n])?s[n]=a(e[n],t[n],r):r.clone?s[n]=i(t[n])?o(t[n]):t[n]:s[n]=t[n]})),s}},19482:(e,t,r)=>{"use strict";r.r(t),r.d(t,{default:()=>n.A,isPlainObject:()=>n.Q});var n=r(19172)},17868:(e,t,r)=>{"use strict";function n(e){let t="https://mui.com/production-error/?code="+e;for(let r=1;rn})},10457:(e,t,r)=>{"use strict";r.r(t),r.d(t,{default:()=>n.A});var n=r(17868)},72372:(e,t,r)=>{"use strict";r.d(t,{Ay:()=>o});var n=r(79386);const i={active:"active",checked:"checked",completed:"completed",disabled:"disabled",error:"error",expanded:"expanded",focused:"focused",focusVisible:"focusVisible",open:"open",readOnly:"readOnly",required:"required",selected:"selected"};function o(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"Mui";const o=i[t];return o?`${r}-${o}`:`${n.A.generate(e)}-${t}`}},92532:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(72372);function i(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"Mui";const i={};return t.forEach((t=>{i[t]=(0,n.Ay)(e,t,r)})),i}},83382:(e,t,r)=>{"use strict";r.r(t),r.d(t,{default:()=>l,getFunctionName:()=>o});var n=r(2086);const i=/^\s*function(?:\s|\s*\/\*.*\*\/\s*)+([^(\s/]*)\s*/;function o(e){const t=`${e}`.match(i);return t&&t[1]||""}function a(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"";return e.displayName||e.name||o(e)||t}function s(e,t,r){const n=a(t);return e.displayName||(""!==n?`${r}(${n})`:r)}function l(e){if(null!=e){if("string"===typeof e)return e;if("function"===typeof e)return a(e,"Component");if("object"===typeof e)switch(e.$$typeof){case n.ForwardRef:return s(e,e.render,"ForwardRef");case n.Memo:return s(e,e.type,"memo");default:return}}}},31668:(e,t,r)=>{"use strict";function n(e){return e&&e.ownerDocument||document}r.d(t,{A:()=>n})},63940:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(31668);function i(e){return(0,n.A)(e).defaultView||window}},13030:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(58168);function i(e,t){const r=(0,n.A)({},t);return Object.keys(e).forEach((o=>{if(o.toString().match(/^(components|slots)$/))r[o]=(0,n.A)({},e[o],r[o]);else if(o.toString().match(/^(componentsProps|slotProps)$/)){const a=e[o]||{},s=t[o];r[o]={},s&&Object.keys(s)?a&&Object.keys(a)?(r[o]=(0,n.A)({},s),Object.keys(a).forEach((e=>{r[o][e]=i(a[e],s[e])}))):r[o]=s:r[o]=a}else void 0===r[o]&&(r[o]=e[o])})),r}},26564:(e,t,r)=>{"use strict";function n(e,t){"function"===typeof e?e(t):e&&(e.current=t)}r.d(t,{A:()=>n})},51052:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(65043);function i(e){let{controlled:t,default:r,name:i,state:o="value"}=e;const{current:a}=n.useRef(void 0!==t),[s,l]=n.useState(r);return[a?t:s,n.useCallback((e=>{a||l(e)}),[])]}},84440:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(65043);const i="undefined"!==typeof window?n.useLayoutEffect:n.useEffect},31782:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=r(65043),i=r(84440);const o=function(e){const t=n.useRef(e);return(0,i.A)((()=>{t.current=e})),n.useRef((function(){return(0,t.current)(...arguments)})).current}},63462:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=r(65043),i=r(26564);function o(){for(var e=arguments.length,t=new Array(e),r=0;rt.every((e=>null==e))?null:e=>{t.forEach((t=>{(0,i.A)(t,e)}))}),t)}},5844:(e,t,r)=>{"use strict";var n;r.d(t,{A:()=>s});var i=r(65043);let o=0;const a=(n||(n=r.t(i,2)))["useId".toString()];function s(e){if(void 0!==a){const t=a();return null!=e?e:t}return function(e){const[t,r]=i.useState(e),n=e||t;return i.useEffect((()=>{null==t&&(o+=1,r(`mui-${o}`))}),[t]),n}(e)}},49640:(e,t,r)=>{"use strict";r.d(t,{A:()=>p});var n=r(65043),i=r(99303);let o=!0,a=!1;const s=new i.E,l={text:!0,search:!0,url:!0,tel:!0,email:!0,password:!0,number:!0,date:!0,month:!0,week:!0,time:!0,datetime:!0,"datetime-local":!0};function c(e){e.metaKey||e.altKey||e.ctrlKey||(o=!0)}function u(){o=!1}function d(){"hidden"===this.visibilityState&&a&&(o=!0)}function h(e){const{target:t}=e;try{return t.matches(":focus-visible")}catch(r){}return o||function(e){const{type:t,tagName:r}=e;return!("INPUT"!==r||!l[t]||e.readOnly)||"TEXTAREA"===r&&!e.readOnly||!!e.isContentEditable}(t)}function p(){const e=n.useCallback((e=>{var t;null!=e&&((t=e.ownerDocument).addEventListener("keydown",c,!0),t.addEventListener("mousedown",u,!0),t.addEventListener("pointerdown",u,!0),t.addEventListener("touchstart",u,!0),t.addEventListener("visibilitychange",d,!0))}),[]),t=n.useRef(!1);return{isFocusVisibleRef:t,onFocus:function(e){return!!h(e)&&(t.current=!0,!0)},onBlur:function(){return!!t.current&&(a=!0,s.start(100,(()=>{a=!1})),t.current=!1,!0)},ref:e}}},99303:(e,t,r)=>{"use strict";r.d(t,{E:()=>a,A:()=>s});var n=r(65043);const i={};const o=[];class a{constructor(){this.currentId=null,this.clear=()=>{null!==this.currentId&&(clearTimeout(this.currentId),this.currentId=null)},this.disposeEffect=()=>this.clear}static create(){return new a}start(e,t){this.clear(),this.currentId=setTimeout((()=>{this.currentId=null,t()}),e)}}function s(){const e=function(e,t){const r=n.useRef(i);return r.current===i&&(r.current=e(t)),r}(a.create).current;var t;return t=e.disposeEffect,n.useEffect(t,o),e}},33428:(e,t,r)=>{"use strict";r.r(t),r.d(t,{sankeyCenter:()=>h,sankeyCircular:()=>I,sankeyJustify:()=>d,sankeyLeft:()=>c,sankeyRight:()=>u});var n=r(35529),i=r(59010),o=r(84279),a=r(17994),s=r.n(a);function l(e){return e.target.depth}function c(e){return e.depth}function u(e,t){return t-1-e.height}function d(e,t){return e.sourceLinks.length?e.depth:t-1}function h(e){return e.targetLinks.length?e.depth:e.sourceLinks.length?(0,n.jk)(e.sourceLinks,l)-1:0}function p(e){return function(){return e}}var f="function"===typeof Symbol&&"symbol"===typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"===typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e};function m(e,t){return y(e.source,t.source)||e.index-t.index}function g(e,t){return y(e.target,t.target)||e.index-t.index}function y(e,t){return e.partOfCycle===t.partOfCycle?e.y0-t.y0:"top"===e.circularLinkType||"bottom"===t.circularLinkType?-1:1}function v(e){return e.value}function x(e){return(e.y0+e.y1)/2}function b(e){return x(e.source)}function _(e){return x(e.target)}function w(e){return e.index}function k(e){return e.nodes}function S(e){return e.links}function A(e,t){var r=e.get(t);if(!r)throw new Error("missing: "+t);return r}function T(e,t){return t(e)}var M=25,C=10,E=.3;function I(){var e,t,r=0,o=0,a=1,l=1,c=24,u=w,h=d,T=k,I=S,O=32,L=2,D=null;function j(){var d={nodes:T.apply(null,arguments),links:I.apply(null,arguments)};!function(e){e.nodes.forEach((function(e,t){e.index=t,e.sourceLinks=[],e.targetLinks=[]}));var t=(0,i.Tj)(e.nodes,u);e.links.forEach((function(e,r){e.index=r;var n=e.source,i=e.target;"object"!==("undefined"===typeof n?"undefined":f(n))&&(n=e.source=A(t,n)),"object"!==("undefined"===typeof i?"undefined":f(i))&&(i=e.target=A(t,i)),n.sourceLinks.push(e),i.targetLinks.push(e)}))}(d),function(e,t,r){var n=0;if(null===r){for(var i=[],o=0;o0;--f)g(p*=.99,d),w();function m(i){if(t){var u=1/0;h.forEach((function(e){var r=l*t/(e.length+1);u=r0?t+M+C:t,bottom:r=r>0?r+M+C:r,left:o=o>0?o+M+C:o,right:i=i>0?i+M+C:i}}(s),f=function(e,t){var i=(0,n.T9)(e.nodes,(function(e){return e.column})),s=a-r,u=l-o,d=s+t.right+t.left,h=u+t.top+t.bottom,p=s/d,f=u/h;return r=r*p+t.left,a=0==t.right?a:a*p,o=o*f+t.top,l*=f,e.nodes.forEach((function(e){e.x0=r+e.column*((a-r-c)/i),e.x1=e.x0+c})),f}(s,p);d*=f,s.links.forEach((function(e){e.width=e.value*d})),h.forEach((function(e){var t=e.length;e.forEach((function(e,r){e.depth==h.length-1&&1==t||0==e.depth&&1==t?(e.y0=l/2-e.value*d,e.y1=e.y0+e.value*d):e.partOfCycle?0==R(e,i)?(e.y0=l/2+r,e.y1=e.y0+e.value*d):"top"==e.circularLinkType?(e.y0=o+r,e.y1=e.y0+e.value*d):(e.y0=l-e.value*d-r,e.y1=e.y0+e.value*d):0==p.top||0==p.bottom?(e.y0=(l-o)/t*r,e.y1=e.y0+e.value*d):(e.y0=(l-o)/2-t/2+r,e.y1=e.y0+e.value*d)}))}))}function g(e,t){var r=h.length;h.forEach((function(i){var o=i.length,a=i[0].depth;i.forEach((function(i){var s;if(i.sourceLinks.length||i.targetLinks.length)if(i.partOfCycle&&R(i,t)>0);else if(0==a&&1==o)s=i.y1-i.y0,i.y0=l/2-s/2,i.y1=l/2+s/2;else if(a==r-1&&1==o)s=i.y1-i.y0,i.y0=l/2-s/2,i.y1=l/2+s/2;else{var c=(0,n.i2)(i.sourceLinks,_),u=(0,n.i2)(i.targetLinks,b),d=((c&&u?(c+u)/2:c||u)-x(i))*e;i.y0+=d,i.y1+=d}}))}))}function w(){h.forEach((function(t){var r,n,i,a=o,s=t.length;for(t.sort(y),i=0;i0&&(r.y0+=n,r.y1+=n),a=r.y1+e;if((n=a-e-l)>0)for(a=r.y0-=n,r.y1-=n,i=s-2;i>=0;--i)(n=(r=t[i]).y1+e-a)>0&&(r.y0-=n,r.y1-=n),a=r.y0}))}}(d,O,u),F(d);for(var p=0;p<4;p++)X(d,l,u),Z(d,l,u),q(d,o,l,u),X(d,l,u),Z(d,l,u);return function(e,t,r){var i=e.nodes,o=e.links,a=!1,s=!1;if(o.forEach((function(e){"top"==e.circularLinkType?a=!0:"bottom"==e.circularLinkType&&(s=!0)})),0==a||0==s){var l=(0,n.jk)(i,(function(e){return e.y0})),c=(r-t)/((0,n.T9)(i,(function(e){return e.y1}))-l);i.forEach((function(e){var t=(e.y1-e.y0)*c;e.y0=(e.y0-l)*c,e.y1=e.y0+t})),o.forEach((function(e){e.y0=(e.y0-l)*c,e.y1=(e.y1-l)*c,e.width=e.width*c}))}}(d,o,l),z(d,L,l,u),d}function F(e){e.nodes.forEach((function(e){e.sourceLinks.sort(g),e.targetLinks.sort(m)})),e.nodes.forEach((function(e){var t=e.y0,r=t,n=e.y1,i=n;e.sourceLinks.forEach((function(e){e.circular?(e.y0=n-e.width/2,n-=e.width):(e.y0=t+e.width/2,t+=e.width)})),e.targetLinks.forEach((function(e){e.circular?(e.y1=i-e.width/2,i-=e.width):(e.y1=r+e.width/2,r+=e.width)}))}))}return j.nodeId=function(e){return arguments.length?(u="function"===typeof e?e:p(e),j):u},j.nodeAlign=function(e){return arguments.length?(h="function"===typeof e?e:p(e),j):h},j.nodeWidth=function(e){return arguments.length?(c=+e,j):c},j.nodePadding=function(t){return arguments.length?(e=+t,j):e},j.nodes=function(e){return arguments.length?(T="function"===typeof e?e:p(e),j):T},j.links=function(e){return arguments.length?(I="function"===typeof e?e:p(e),j):I},j.size=function(e){return arguments.length?(r=o=0,a=+e[0],l=+e[1],j):[a-r,l-o]},j.extent=function(e){return arguments.length?(r=+e[0][0],a=+e[1][0],o=+e[0][1],l=+e[1][1],j):[[r,o],[a,l]]},j.iterations=function(e){return arguments.length?(O=+e,j):O},j.circularLinkGap=function(e){return arguments.length?(L=+e,j):L},j.nodePaddingRatio=function(e){return arguments.length?(t=+e,j):t},j.sortNodes=function(e){return arguments.length?(D=e,j):D},j.update=function(e){return P(e,u),F(e),e.links.forEach((function(e){e.circular&&(e.circularLinkType=e.y0+e.y11||i>1)}function D(e,t,r){return e.sort(j),e.forEach((function(n,i){var o,a,s=0;if(Q(n,r)&&L(n))n.circularPathData.verticalBuffer=s+n.width/2;else{for(var l=0;la.source.column)){var c=e[l].circularPathData.verticalBuffer+e[l].width/2+t;s=c>s?c:s}n.circularPathData.verticalBuffer=s+n.width/2}})),e}function z(e,t,r,i){var a=(0,n.jk)(e.links,(function(e){return e.source.y0}));e.links.forEach((function(e){e.circular&&(e.circularPathData={})})),D(e.links.filter((function(e){return"top"==e.circularLinkType})),t,i),D(e.links.filter((function(e){return"bottom"==e.circularLinkType})),t,i),e.links.forEach((function(n){if(n.circular){if(n.circularPathData.arcRadius=n.width+C,n.circularPathData.leftNodeBuffer=5,n.circularPathData.rightNodeBuffer=5,n.circularPathData.sourceWidth=n.source.x1-n.source.x0,n.circularPathData.sourceX=n.source.x0+n.circularPathData.sourceWidth,n.circularPathData.targetX=n.target.x0,n.circularPathData.sourceY=n.y0,n.circularPathData.targetY=n.y1,Q(n,i)&&L(n))n.circularPathData.leftSmallArcRadius=C+n.width/2,n.circularPathData.leftLargeArcRadius=C+n.width/2,n.circularPathData.rightSmallArcRadius=C+n.width/2,n.circularPathData.rightLargeArcRadius=C+n.width/2,"bottom"==n.circularLinkType?(n.circularPathData.verticalFullExtent=n.source.y1+M+n.circularPathData.verticalBuffer,n.circularPathData.verticalLeftInnerExtent=n.circularPathData.verticalFullExtent-n.circularPathData.leftLargeArcRadius,n.circularPathData.verticalRightInnerExtent=n.circularPathData.verticalFullExtent-n.circularPathData.rightLargeArcRadius):(n.circularPathData.verticalFullExtent=n.source.y0-M-n.circularPathData.verticalBuffer,n.circularPathData.verticalLeftInnerExtent=n.circularPathData.verticalFullExtent+n.circularPathData.leftLargeArcRadius,n.circularPathData.verticalRightInnerExtent=n.circularPathData.verticalFullExtent+n.circularPathData.rightLargeArcRadius);else{var s=n.source.column,l=n.circularLinkType,c=e.links.filter((function(e){return e.source.column==s&&e.circularLinkType==l}));"bottom"==n.circularLinkType?c.sort(N):c.sort(F);var u=0;c.forEach((function(e,r){e.circularLinkID==n.circularLinkID&&(n.circularPathData.leftSmallArcRadius=C+n.width/2+u,n.circularPathData.leftLargeArcRadius=C+n.width/2+r*t+u),u+=e.width})),s=n.target.column,c=e.links.filter((function(e){return e.target.column==s&&e.circularLinkType==l})),"bottom"==n.circularLinkType?c.sort(V):c.sort(B),u=0,c.forEach((function(e,r){e.circularLinkID==n.circularLinkID&&(n.circularPathData.rightSmallArcRadius=C+n.width/2+u,n.circularPathData.rightLargeArcRadius=C+n.width/2+r*t+u),u+=e.width})),"bottom"==n.circularLinkType?(n.circularPathData.verticalFullExtent=Math.max(r,n.source.y1,n.target.y1)+M+n.circularPathData.verticalBuffer,n.circularPathData.verticalLeftInnerExtent=n.circularPathData.verticalFullExtent-n.circularPathData.leftLargeArcRadius,n.circularPathData.verticalRightInnerExtent=n.circularPathData.verticalFullExtent-n.circularPathData.rightLargeArcRadius):(n.circularPathData.verticalFullExtent=a-M-n.circularPathData.verticalBuffer,n.circularPathData.verticalLeftInnerExtent=n.circularPathData.verticalFullExtent+n.circularPathData.leftLargeArcRadius,n.circularPathData.verticalRightInnerExtent=n.circularPathData.verticalFullExtent+n.circularPathData.rightLargeArcRadius)}n.circularPathData.leftInnerExtent=n.circularPathData.sourceX+n.circularPathData.leftNodeBuffer,n.circularPathData.rightInnerExtent=n.circularPathData.targetX-n.circularPathData.rightNodeBuffer,n.circularPathData.leftFullExtent=n.circularPathData.sourceX+n.circularPathData.leftLargeArcRadius+n.circularPathData.leftNodeBuffer,n.circularPathData.rightFullExtent=n.circularPathData.targetX-n.circularPathData.rightLargeArcRadius-n.circularPathData.rightNodeBuffer}if(n.circular)n.path=function(e){var t="";t="top"==e.circularLinkType?"M"+e.circularPathData.sourceX+" "+e.circularPathData.sourceY+" L"+e.circularPathData.leftInnerExtent+" "+e.circularPathData.sourceY+" A"+e.circularPathData.leftLargeArcRadius+" "+e.circularPathData.leftSmallArcRadius+" 0 0 0 "+e.circularPathData.leftFullExtent+" "+(e.circularPathData.sourceY-e.circularPathData.leftSmallArcRadius)+" L"+e.circularPathData.leftFullExtent+" "+e.circularPathData.verticalLeftInnerExtent+" A"+e.circularPathData.leftLargeArcRadius+" "+e.circularPathData.leftLargeArcRadius+" 0 0 0 "+e.circularPathData.leftInnerExtent+" "+e.circularPathData.verticalFullExtent+" L"+e.circularPathData.rightInnerExtent+" "+e.circularPathData.verticalFullExtent+" A"+e.circularPathData.rightLargeArcRadius+" "+e.circularPathData.rightLargeArcRadius+" 0 0 0 "+e.circularPathData.rightFullExtent+" "+e.circularPathData.verticalRightInnerExtent+" L"+e.circularPathData.rightFullExtent+" "+(e.circularPathData.targetY-e.circularPathData.rightSmallArcRadius)+" A"+e.circularPathData.rightLargeArcRadius+" "+e.circularPathData.rightSmallArcRadius+" 0 0 0 "+e.circularPathData.rightInnerExtent+" "+e.circularPathData.targetY+" L"+e.circularPathData.targetX+" "+e.circularPathData.targetY:"M"+e.circularPathData.sourceX+" "+e.circularPathData.sourceY+" L"+e.circularPathData.leftInnerExtent+" "+e.circularPathData.sourceY+" A"+e.circularPathData.leftLargeArcRadius+" "+e.circularPathData.leftSmallArcRadius+" 0 0 1 "+e.circularPathData.leftFullExtent+" "+(e.circularPathData.sourceY+e.circularPathData.leftSmallArcRadius)+" L"+e.circularPathData.leftFullExtent+" "+e.circularPathData.verticalLeftInnerExtent+" A"+e.circularPathData.leftLargeArcRadius+" "+e.circularPathData.leftLargeArcRadius+" 0 0 1 "+e.circularPathData.leftInnerExtent+" "+e.circularPathData.verticalFullExtent+" L"+e.circularPathData.rightInnerExtent+" "+e.circularPathData.verticalFullExtent+" A"+e.circularPathData.rightLargeArcRadius+" "+e.circularPathData.rightLargeArcRadius+" 0 0 1 "+e.circularPathData.rightFullExtent+" "+e.circularPathData.verticalRightInnerExtent+" L"+e.circularPathData.rightFullExtent+" "+(e.circularPathData.targetY+e.circularPathData.rightSmallArcRadius)+" A"+e.circularPathData.rightLargeArcRadius+" "+e.circularPathData.rightSmallArcRadius+" 0 0 1 "+e.circularPathData.rightInnerExtent+" "+e.circularPathData.targetY+" L"+e.circularPathData.targetX+" "+e.circularPathData.targetY;return t}(n);else{var d=(0,o.pq)().source((function(e){return[e.source.x0+(e.source.x1-e.source.x0),e.y0]})).target((function(e){return[e.target.x0,e.y1]}));n.path=d(n)}}))}function j(e,t){return U(e)==U(t)?"bottom"==e.circularLinkType?N(e,t):F(e,t):U(t)-U(e)}function F(e,t){return e.y0-t.y0}function N(e,t){return t.y0-e.y0}function B(e,t){return e.y1-t.y1}function V(e,t){return t.y1-e.y1}function U(e){return e.target.column-e.source.column}function H(e){return e.target.x0-e.source.x1}function $(e,t){var r=O(e),n=H(t)/Math.tan(r);return"up"==J(e)?e.y1+n:e.y1-n}function W(e,t){var r=O(e),n=H(t)/Math.tan(r);return"up"==J(e)?e.y1-n:e.y1+n}function q(e,t,r,n){e.links.forEach((function(i){if(!i.circular&&i.target.column-i.source.column>1){var o=i.source.column+1,a=i.target.column-1,s=1,l=a-o+1;for(s=1;o<=a;o++,s++)e.nodes.forEach((function(a){if(a.column==o){var c,u=s/(l+1),d=Math.pow(1-u,3),h=3*u*Math.pow(1-u,2),p=3*Math.pow(u,2)*(1-u),f=Math.pow(u,3),m=d*i.y0+h*i.y0+p*i.y1+f*i.y1,g=m-i.width/2,y=m+i.width/2;g>a.y0&&ga.y0&&ya.y1)&&(c=y-a.y0+10,a=Y(a,c,t,r),e.nodes.forEach((function(e){T(e,n)!=T(a,n)&&e.column==a.column&&e.y0a.y1&&Y(e,c,t,r)})))}}))}}))}function G(e,t){return e.y0>t.y0&&e.y0t.y0&&e.y1t.y1)}function Y(e,t,r,n){return e.y0+t>=r&&e.y1+t<=n&&(e.y0=e.y0+t,e.y1=e.y1+t,e.targetLinks.forEach((function(e){e.y1=e.y1+t})),e.sourceLinks.forEach((function(e){e.y0=e.y0+t}))),e}function X(e,t,r,n){e.nodes.forEach((function(i){n&&i.y+(i.y1-i.y0)>t&&(i.y=i.y-(i.y+(i.y1-i.y0)-t));var o=e.links.filter((function(e){return T(e.source,r)==T(i,r)})),a=o.length;a>1&&o.sort((function(e,t){if(!e.circular&&!t.circular){if(e.target.column==t.target.column)return e.y1-t.y1;if(!K(e,t))return e.y1-t.y1;if(e.target.column>t.target.column){var r=W(t,e);return e.y1-r}if(t.target.column>e.target.column)return W(e,t)-t.y1}return e.circular&&!t.circular?"top"==e.circularLinkType?-1:1:t.circular&&!e.circular?"top"==t.circularLinkType?1:-1:e.circular&&t.circular?e.circularLinkType===t.circularLinkType&&"top"==e.circularLinkType?e.target.column===t.target.column?e.target.y1-t.target.y1:t.target.column-e.target.column:e.circularLinkType===t.circularLinkType&&"bottom"==e.circularLinkType?e.target.column===t.target.column?t.target.y1-e.target.y1:e.target.column-t.target.column:"top"==e.circularLinkType?-1:1:void 0}));var s=i.y0;o.forEach((function(e){e.y0=s+e.width/2,s+=e.width})),o.forEach((function(e,t){if("bottom"==e.circularLinkType){for(var r=t+1,n=0;r1&&n.sort((function(e,t){if(!e.circular&&!t.circular){if(e.source.column==t.source.column)return e.y0-t.y0;if(!K(e,t))return e.y0-t.y0;if(t.source.column0?"up":"down"}function Q(e,t){return T(e.source,t)==T(e.target,t)}},40293:(e,t,r)=>{"use strict";r.r(t),r.d(t,{sankey:()=>w,sankeyCenter:()=>c,sankeyJustify:()=>l,sankeyLeft:()=>a,sankeyLinkHorizontal:()=>T,sankeyRight:()=>s});var n=r(35529),i=r(59010);function o(e){return e.target.depth}function a(e){return e.depth}function s(e,t){return t-1-e.height}function l(e,t){return e.sourceLinks.length?e.depth:t-1}function c(e){return e.targetLinks.length?e.depth:e.sourceLinks.length?(0,n.jk)(e.sourceLinks,o)-1:0}function u(e){return function(){return e}}function d(e,t){return p(e.source,t.source)||e.index-t.index}function h(e,t){return p(e.target,t.target)||e.index-t.index}function p(e,t){return e.y0-t.y0}function f(e){return e.value}function m(e){return(e.y0+e.y1)/2}function g(e){return m(e.source)*e.value}function y(e){return m(e.target)*e.value}function v(e){return e.index}function x(e){return e.nodes}function b(e){return e.links}function _(e,t){var r=e.get(t);if(!r)throw new Error("missing: "+t);return r}function w(){var e=0,t=0,r=1,o=1,a=24,s=8,c=v,w=l,k=x,S=b,A=32,T=2/3;function M(){var l={nodes:k.apply(null,arguments),links:S.apply(null,arguments)};return function(e){e.nodes.forEach((function(e,t){e.index=t,e.sourceLinks=[],e.targetLinks=[]}));var t=(0,i.Tj)(e.nodes,c);e.links.forEach((function(e,r){e.index=r;var n=e.source,i=e.target;"object"!==typeof n&&(n=e.source=_(t,n)),"object"!==typeof i&&(i=e.target=_(t,i)),n.sourceLinks.push(e),i.targetLinks.push(e)}))}(l),function(e){e.nodes.forEach((function(e){e.value=Math.max((0,n.cz)(e.sourceLinks,f),(0,n.cz)(e.targetLinks,f))}))}(l),function(t){var n,i,o;for(n=t.nodes,i=[],o=0;n.length;++o,n=i,i=[])n.forEach((function(e){e.depth=o,e.sourceLinks.forEach((function(e){i.indexOf(e.target)<0&&i.push(e.target)}))}));for(n=t.nodes,i=[],o=0;n.length;++o,n=i,i=[])n.forEach((function(e){e.height=o,e.targetLinks.forEach((function(e){i.indexOf(e.source)<0&&i.push(e.source)}))}));var s=(r-e-a)/(o-1);t.nodes.forEach((function(t){t.x1=(t.x0=e+Math.max(0,Math.min(o-1,Math.floor(w.call(null,t,o))))*s)+a}))}(l),function(e){var r=(0,i.$I)().key((function(e){return e.x0})).sortKeys(n.V_).entries(e.nodes).map((function(e){return e.values}));c(),h();for(var a=1,l=A;l>0;--l)d(a*=.99),h(),u(a),h();function c(){var i=(0,n.T9)(r,(function(e){return e.length})),a=T*(o-t)/(i-1);s>a&&(s=a);var l=(0,n.jk)(r,(function(e){return(o-t-(e.length-1)*s)/(0,n.cz)(e,f)}));r.forEach((function(e){e.forEach((function(e,t){e.y1=(e.y0=t)+e.value*l}))})),e.links.forEach((function(e){e.width=e.value*l}))}function u(e){r.forEach((function(t){t.forEach((function(t){if(t.targetLinks.length){var r=((0,n.cz)(t.targetLinks,g)/(0,n.cz)(t.targetLinks,f)-m(t))*e;t.y0+=r,t.y1+=r}}))}))}function d(e){r.slice().reverse().forEach((function(t){t.forEach((function(t){if(t.sourceLinks.length){var r=((0,n.cz)(t.sourceLinks,y)/(0,n.cz)(t.sourceLinks,f)-m(t))*e;t.y0+=r,t.y1+=r}}))}))}function h(){r.forEach((function(e){var r,n,i,a=t,l=e.length;for(e.sort(p),i=0;i0&&(r.y0+=n,r.y1+=n),a=r.y1+s;if((n=a-s-o)>0)for(a=r.y0-=n,r.y1-=n,i=l-2;i>=0;--i)(n=(r=e[i]).y1+s-a)>0&&(r.y0-=n,r.y1-=n),a=r.y0}))}}(l),C(l),l}function C(e){e.nodes.forEach((function(e){e.sourceLinks.sort(h),e.targetLinks.sort(d)})),e.nodes.forEach((function(e){var t=e.y0,r=t;e.sourceLinks.forEach((function(e){e.y0=t+e.width/2,t+=e.width})),e.targetLinks.forEach((function(e){e.y1=r+e.width/2,r+=e.width}))}))}return M.update=function(e){return C(e),e},M.nodeId=function(e){return arguments.length?(c="function"===typeof e?e:u(e),M):c},M.nodeAlign=function(e){return arguments.length?(w="function"===typeof e?e:u(e),M):w},M.nodeWidth=function(e){return arguments.length?(a=+e,M):a},M.nodePadding=function(e){return arguments.length?(s=+e,M):s},M.nodes=function(e){return arguments.length?(k="function"===typeof e?e:u(e),M):k},M.links=function(e){return arguments.length?(S="function"===typeof e?e:u(e),M):S},M.size=function(n){return arguments.length?(e=t=0,r=+n[0],o=+n[1],M):[r-e,o-t]},M.extent=function(n){return arguments.length?(e=+n[0][0],r=+n[1][0],t=+n[0][1],o=+n[1][1],M):[[e,t],[r,o]]},M.iterations=function(e){return arguments.length?(A=+e,M):A},M}var k=r(84279);function S(e){return[e.source.x1,e.y0]}function A(e){return[e.target.x0,e.y1]}function T(){return(0,k.pq)().source(S).target(A)}},41871:(e,t,r)=>{var n,i;(function(){var o={version:"3.8.2"},a=[].slice,s=function(e){return a.call(e)},l=self.document;function c(e){return e&&(e.ownerDocument||e.document||e).documentElement}function u(e){return e&&(e.ownerDocument&&e.ownerDocument.defaultView||e.document&&e||e.defaultView)}if(l)try{s(l.documentElement.childNodes)[0].nodeType}catch(go){s=function(e){for(var t=e.length,r=new Array(t);t--;)r[t]=e[t];return r}}if(Date.now||(Date.now=function(){return+new Date}),l)try{l.createElement("DIV").style.setProperty("opacity",0,"")}catch(yo){var d=this.Element.prototype,h=d.setAttribute,p=d.setAttributeNS,f=this.CSSStyleDeclaration.prototype,m=f.setProperty;d.setAttribute=function(e,t){h.call(this,e,t+"")},d.setAttributeNS=function(e,t,r){p.call(this,e,t,r+"")},f.setProperty=function(e,t,r){m.call(this,e,t+"",r)}}function g(e,t){return et?1:e>=t?0:NaN}function y(e){return null===e?NaN:+e}function v(e){return!isNaN(e)}function x(e){return{left:function(t,r,n,i){for(arguments.length<3&&(n=0),arguments.length<4&&(i=t.length);n>>1;e(t[o],r)<0?n=o+1:i=o}return n},right:function(t,r,n,i){for(arguments.length<3&&(n=0),arguments.length<4&&(i=t.length);n>>1;e(t[o],r)>0?i=o:n=o+1}return n}}}o.ascending=g,o.descending=function(e,t){return te?1:t>=e?0:NaN},o.min=function(e,t){var r,n,i=-1,o=e.length;if(1===arguments.length){for(;++i=n){r=n;break}for(;++in&&(r=n)}else{for(;++i=n){r=n;break}for(;++in&&(r=n)}return r},o.max=function(e,t){var r,n,i=-1,o=e.length;if(1===arguments.length){for(;++i=n){r=n;break}for(;++ir&&(r=n)}else{for(;++i=n){r=n;break}for(;++ir&&(r=n)}return r},o.extent=function(e,t){var r,n,i,o=-1,a=e.length;if(1===arguments.length){for(;++o=n){r=i=n;break}for(;++on&&(r=n),i=n){r=i=n;break}for(;++on&&(r=n),i1)return a/(l-1)},o.deviation=function(){var e=o.variance.apply(this,arguments);return e?Math.sqrt(e):e};var b=x(g);function _(e){return e.length}o.bisectLeft=b.left,o.bisect=o.bisectRight=b.right,o.bisector=function(e){return x(1===e.length?function(t,r){return g(e(t),r)}:e)},o.shuffle=function(e,t,r){(o=arguments.length)<3&&(r=e.length,o<2&&(t=0));for(var n,i,o=r-t;o;)i=Math.random()*o--|0,n=e[o+t],e[o+t]=e[i+t],e[i+t]=n;return e},o.permute=function(e,t){for(var r=t.length,n=new Array(r);r--;)n[r]=e[t[r]];return n},o.pairs=function(e){for(var t=0,r=e.length-1,n=e[0],i=new Array(r<0?0:r);t=0;)for(t=(n=e[i]).length;--t>=0;)r[--a]=n[t];return r};var w=Math.abs;function k(e,t){for(var r in t)Object.defineProperty(e.prototype,r,{value:t[r],enumerable:!1})}function S(){this._=Object.create(null)}o.range=function(e,t,r){if(arguments.length<3&&(r=1,arguments.length<2&&(t=e,e=0)),(t-e)/r===1/0)throw new Error("infinite range");var n,i=[],o=function(e){var t=1;for(;e*t%1;)t*=10;return t}(w(r)),a=-1;if(e*=o,t*=o,(r*=o)<0)for(;(n=e+r*++a)>t;)i.push(n/o);else for(;(n=e+r*++a)=n.length)return t?t.call(r,o):e?o.sort(e):o;for(var l,c,u,d,h=-1,p=o.length,f=n[s++],m=new S;++h=n.length)return e;var r=[],o=i[t++];return e.forEach((function(e,n){r.push({key:e,values:s(n,t)})})),o?r.sort((function(e,t){return o(e.key,t.key)})):r}return r.map=function(e,t){return a(t,e,0)},r.entries=function(e){return s(a(o.map,e,0),0)},r.key=function(e){return n.push(e),r},r.sortKeys=function(e){return i[n.length-1]=e,r},r.sortValues=function(t){return e=t,r},r.rollup=function(e){return t=e,r},r},o.set=function(e){var t=new O;if(e)for(var r=0,n=e.length;r=0&&(n=e.slice(r+1),e=e.slice(0,r)),e)return arguments.length<2?this[e].on(n):this[e].on(n,t);if(2===arguments.length){if(null==t)for(e in this)this.hasOwnProperty(e)&&this[e].on(n,null);return this}},o.event=null,o.requote=function(e){return e.replace(H,"\\$&")};var H=/[\\\^\$\*\+\?\|\[\]\(\)\.\{\}]/g,$={}.__proto__?function(e,t){e.__proto__=t}:function(e,t){for(var r in t)e[r]=t[r]};function W(e){return $(e,X),e}var q=function(e,t){return t.querySelector(e)},G=function(e,t){return t.querySelectorAll(e)},Y=function(e,t){var r=e.matches||e[D(e,"matchesSelector")];return Y=function(e,t){return r.call(e,t)},Y(e,t)};"function"===typeof Sizzle&&(q=function(e,t){return Sizzle(e,t)[0]||null},G=Sizzle,Y=Sizzle.matchesSelector),o.selection=function(){return o.select(l.documentElement)};var X=o.selection.prototype=[];function Z(e){return"function"===typeof e?e:function(){return q(e,this)}}function K(e){return"function"===typeof e?e:function(){return G(e,this)}}X.select=function(e){var t,r,n,i,o=[];e=Z(e);for(var a=-1,s=this.length;++a=0&&"xmlns"!==(r=e.slice(0,t))&&(e=e.slice(t+1)),Q.hasOwnProperty(r)?{space:Q[r],local:e}:e}},X.attr=function(e,t){if(arguments.length<2){if("string"===typeof e){var r=this.node();return(e=o.ns.qualify(e)).local?r.getAttributeNS(e.space,e.local):r.getAttribute(e)}for(t in e)this.each(ee(t,e[t]));return this}return this.each(ee(e,t))},X.classed=function(e,t){if(arguments.length<2){if("string"===typeof e){var r=this.node(),n=(e=ne(e)).length,i=-1;if(t=r.classList){for(;++i=0;)(r=n[i])&&(o&&o!==r.nextSibling&&o.parentNode.insertBefore(r,o),o=r);return this},X.sort=function(e){e=he.apply(this,arguments);for(var t=-1,r=this.length;++t0&&(e=e.slice(0,i));var l=ye.get(e);function c(){var t=this[n];t&&(this.removeEventListener(e,t,t.$),delete this[n])}return l&&(e=l,a=xe),i?t?function(){var i=a(t,s(arguments));c.call(this),this.addEventListener(e,this[n]=i,i.$=r),i._=t}:c:t?j:function(){var t,r=new RegExp("^__on([^.]+)"+o.requote(e)+"$");for(var n in this)if(t=n.match(r)){var i=this[n];this.removeEventListener(t[1],i,i.$),delete this[n]}}}o.selection.enter=fe,o.selection.enter.prototype=me,me.append=X.append,me.empty=X.empty,me.node=X.node,me.call=X.call,me.size=X.size,me.select=function(e){for(var t,r,n,i,o,a=[],s=-1,l=this.length;++s=t&&(t=i+1);!(a=s[t])&&++t1?Pe:e<-1?-Pe:Math.asin(e)}function De(e){return((e=Math.exp(e))+1/e)/2}var ze=Math.SQRT2;o.interpolateZoom=function(e,t){var r,n,i=e[0],o=e[1],a=e[2],s=t[0],l=t[1],c=t[2],u=s-i,d=l-o,h=u*u+d*d;if(h0&&(e=e.transition().duration(m)),e.call(w.event)}function M(){s&&s.domain(a.range().map((function(e){return(e-h.x)/h.k})).map(a.invert)),d&&d.domain(c.range().map((function(e){return(e-h.y)/h.k})).map(c.invert))}function C(e){g++||e({type:"zoomstart"})}function E(e){M(),e({type:"zoom",scale:h.k,translate:[h.x,h.y]})}function I(e){--g||(e({type:"zoomend"}),t=null)}function P(){var e=this,t=_.of(e,arguments),r=0,n=o.select(u(e)).on(v,(function(){r=1,A(o.mouse(e),i),E(t)})).on(x,(function(){n.on(v,null).on(x,null),a(r),I(t)})),i=k(o.mouse(e)),a=we(e);Zi.call(e),C(t)}function O(){var e,t=this,r=_.of(t,arguments),n={},a=0,s=".zoom-"+o.event.changedTouches[0].identifier,l="touchmove"+s,c="touchend"+s,u=[],d=o.select(t),p=we(t);function f(){var r=o.touches(t);return e=h.k,r.forEach((function(e){e.identifier in n&&(n[e.identifier]=k(e))})),r}function m(){var e=o.event.target;o.select(e).on(l,g).on(c,v),u.push(e);for(var r=o.event.changedTouches,s=0,d=r.length;s1){y=p[0];var x=p[1],b=y[0]-x[0],_=y[1]-x[1];a=b*b+_*_}}function g(){var s,l,c,u,d=o.touches(t);Zi.call(t);for(var h=0,p=d.length;h360?e-=360:e<0&&(e+=360),e<60?n+(i-n)*e/60:e<180?i:e<240?n+(i-n)*(240-e)/60:n}(e))}return e=isNaN(e)?0:(e%=360)<0?e+360:e,t=isNaN(t)||t<0?0:t>1?1:t,n=2*(r=r<0?0:r>1?1:r)-(i=r<=.5?r*(1+t):r+t-r*t),new it(o(e+120),o(e),o(e-120))}function $e(e,t,r){return this instanceof $e?(this.h=+e,this.c=+t,void(this.l=+r)):arguments.length<2?e instanceof $e?new $e(e.h,e.c,e.l):et(e instanceof Ge?e.l:(e=dt((e=o.rgb(e)).r,e.g,e.b)).l,e.a,e.b):new $e(e,t,r)}Ue.brighter=function(e){return e=Math.pow(.7,arguments.length?e:1),new Ve(this.h,this.s,this.l/e)},Ue.darker=function(e){return e=Math.pow(.7,arguments.length?e:1),new Ve(this.h,this.s,e*this.l)},Ue.rgb=function(){return He(this.h,this.s,this.l)},o.hcl=$e;var We=$e.prototype=new Be;function qe(e,t,r){return isNaN(e)&&(e=0),isNaN(t)&&(t=0),new Ge(r,Math.cos(e*=Oe)*t,Math.sin(e)*t)}function Ge(e,t,r){return this instanceof Ge?(this.l=+e,this.a=+t,void(this.b=+r)):arguments.length<2?e instanceof Ge?new Ge(e.l,e.a,e.b):e instanceof $e?qe(e.h,e.c,e.l):dt((e=it(e)).r,e.g,e.b):new Ge(e,t,r)}We.brighter=function(e){return new $e(this.h,this.c,Math.min(100,this.l+Ye*(arguments.length?e:1)))},We.darker=function(e){return new $e(this.h,this.c,Math.max(0,this.l-Ye*(arguments.length?e:1)))},We.rgb=function(){return qe(this.h,this.c,this.l).rgb()},o.lab=Ge;var Ye=18,Xe=.95047,Ze=1,Ke=1.08883,Je=Ge.prototype=new Be;function Qe(e,t,r){var n=(e+16)/116,i=n+t/500,o=n-r/200;return new it(nt(3.2404542*(i=tt(i)*Xe)-1.5371385*(n=tt(n)*Ze)-.4985314*(o=tt(o)*Ke)),nt(-.969266*i+1.8760108*n+.041556*o),nt(.0556434*i-.2040259*n+1.0572252*o))}function et(e,t,r){return e>0?new $e(Math.atan2(r,t)*Re,Math.sqrt(t*t+r*r),e):new $e(NaN,NaN,e)}function tt(e){return e>.206893034?e*e*e:(e-4/29)/7.787037}function rt(e){return e>.008856?Math.pow(e,1/3):7.787037*e+4/29}function nt(e){return Math.round(255*(e<=.00304?12.92*e:1.055*Math.pow(e,1/2.4)-.055))}function it(e,t,r){return this instanceof it?(this.r=~~e,this.g=~~t,void(this.b=~~r)):arguments.length<2?e instanceof it?new it(e.r,e.g,e.b):ct(""+e,it,He):new it(e,t,r)}function ot(e){return new it(e>>16,e>>8&255,255&e)}function at(e){return ot(e)+""}Je.brighter=function(e){return new Ge(Math.min(100,this.l+Ye*(arguments.length?e:1)),this.a,this.b)},Je.darker=function(e){return new Ge(Math.max(0,this.l-Ye*(arguments.length?e:1)),this.a,this.b)},Je.rgb=function(){return Qe(this.l,this.a,this.b)},o.rgb=it;var st=it.prototype=new Be;function lt(e){return e<16?"0"+Math.max(0,e).toString(16):Math.min(255,e).toString(16)}function ct(e,t,r){var n,i,o,a=0,s=0,l=0;if(n=/([a-z]+)\((.*)\)/.exec(e=e.toLowerCase()))switch(i=n[2].split(","),n[1]){case"hsl":return r(parseFloat(i[0]),parseFloat(i[1])/100,parseFloat(i[2])/100);case"rgb":return t(pt(i[0]),pt(i[1]),pt(i[2]))}return(o=ft.get(e))?t(o.r,o.g,o.b):(null==e||"#"!==e.charAt(0)||isNaN(o=parseInt(e.slice(1),16))||(4===e.length?(a=(3840&o)>>4,a|=a>>4,s=240&o,s|=s>>4,l=15&o,l|=l<<4):7===e.length&&(a=(16711680&o)>>16,s=(65280&o)>>8,l=255&o)),t(a,s,l))}function ut(e,t,r){var n,i,o=Math.min(e/=255,t/=255,r/=255),a=Math.max(e,t,r),s=a-o,l=(a+o)/2;return s?(i=l<.5?s/(a+o):s/(2-a-o),n=e==a?(t-r)/s+(t0&&l<1?0:n),new Ve(n,i,l)}function dt(e,t,r){var n=rt((.4124564*(e=ht(e))+.3575761*(t=ht(t))+.1804375*(r=ht(r)))/Xe),i=rt((.2126729*e+.7151522*t+.072175*r)/Ze);return Ge(116*i-16,500*(n-i),200*(i-rt((.0193339*e+.119192*t+.9503041*r)/Ke)))}function ht(e){return(e/=255)<=.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)}function pt(e){var t=parseFloat(e);return"%"===e.charAt(e.length-1)?Math.round(2.55*t):t}st.brighter=function(e){e=Math.pow(.7,arguments.length?e:1);var t=this.r,r=this.g,n=this.b,i=30;return t||r||n?(t&&t=200&&t<300||304===t){try{e=r.call(i,c)}catch(go){return void a.error.call(i,go)}a.load.call(i,e)}else a.error.call(i,c)}return self.XDomainRequest&&!("withCredentials"in c)&&/^(http(s)?:)?\/\//.test(e)&&(c=new XDomainRequest),"onload"in c?c.onload=c.onerror=d:c.onreadystatechange=function(){c.readyState>3&&d()},c.onprogress=function(e){var t=o.event;o.event=e;try{a.progress.call(i,c)}finally{o.event=t}},i.header=function(e,t){return e=(e+"").toLowerCase(),arguments.length<2?l[e]:(null==t?delete l[e]:l[e]=t+"",i)},i.mimeType=function(e){return arguments.length?(t=null==e?null:e+"",i):t},i.responseType=function(e){return arguments.length?(u=e,i):u},i.response=function(e){return r=e,i},["get","post"].forEach((function(e){i[e]=function(){return i.send.apply(i,[e].concat(s(arguments)))}})),i.send=function(r,n,o){if(2===arguments.length&&"function"===typeof n&&(o=n,n=null),c.open(r,e,!0),null==t||"accept"in l||(l.accept=t+",*/*"),c.setRequestHeader)for(var s in l)c.setRequestHeader(s,l[s]);return null!=t&&c.overrideMimeType&&c.overrideMimeType(t),null!=u&&(c.responseType=u),null!=o&&i.on("error",o).on("load",(function(e){o(null,e)})),a.beforesend.call(i,c),c.send(null==n?null:n),i},i.abort=function(){return c.abort(),i},o.rebind(i,a,"on"),null==n?i:i.get(function(e){return 1===e.length?function(t,r){e(null==t?r:null)}:e}(n))}ft.forEach((function(e,t){ft.set(e,ot(t))})),o.functor=mt,o.xhr=gt(R),o.dsv=function(e,t){var r=new RegExp('["'+e+"\n]"),n=e.charCodeAt(0);function i(e,r,n){arguments.length<3&&(n=r,r=null);var i=yt(e,t,null==r?o:a(r),n);return i.row=function(e){return arguments.length?i.response(null==(r=e)?o:a(e)):r},i}function o(e){return i.parse(e.responseText)}function a(e){return function(t){return i.parse(t.responseText,e)}}function s(t){return t.map(l).join(e)}function l(e){return r.test(e)?'"'+e.replace(/\"/g,'""')+'"':e}return i.parse=function(e,t){var r;return i.parseRows(e,(function(e,n){if(r)return r(e,n-1);var i=function(t){for(var r={},n=e.length,i=0;i=l)return a;if(i)return i=!1,o;var t=c;if(34===e.charCodeAt(t)){for(var r=t;r++24?(isFinite(t)&&(clearTimeout(_t),_t=setTimeout(St,t)),bt=0):(bt=1,wt(St))}function At(){for(var e=Date.now(),t=vt;t;)e>=t.t&&t.c(e-t.t)&&(t.c=null),t=t.n;return e}function Tt(){for(var e,t=vt,r=1/0;t;)t.c?(t.t1&&(t=e[o[a-2]],r=e[o[a-1]],n=e[s],(r[0]-t[0])*(n[1]-t[1])-(r[1]-t[1])*(n[0]-t[0])<=0);)--a;o[a++]=s}return o.slice(0,a)}function It(e,t){return e[0]-t[0]||e[1]-t[1]}o.timer=function(){kt.apply(this,arguments)},o.timer.flush=function(){At(),Tt()},o.round=function(e,t){return t?Math.round(e*(t=Math.pow(10,t)))/t:Math.round(e)},o.geom={},o.geom.hull=function(e){var t=Mt,r=Ct;if(arguments.length)return n(e);function n(e){if(e.length<3)return[];var n,i=mt(t),o=mt(r),a=e.length,s=[],l=[];for(n=0;n=0;--n)p.push(e[s[c[n]][2]]);for(n=+d;nTe)s=s.L;else{if(!((i=o-Yt(s,a))>Te)){n>-Te?(t=s.P,r=s):i>-Te?(t=s,r=s.N):t=r=s;break}if(!s.R){t=s;break}s=s.R}var l=Ht(e);if(jt.insert(t,l),t||r){if(t===r)return Qt(t),r=Ht(t.site),jt.insert(l,r),l.edge=r.edge=rr(t.site,l.site),Jt(t),void Jt(r);if(r){Qt(t),Qt(r);var c=t.site,u=c.x,d=c.y,h=e.x-u,p=e.y-d,f=r.site,m=f.x-u,g=f.y-d,y=2*(h*g-p*m),v=h*h+p*p,x=m*m+g*g,b={x:(g*v-p*x)/y+u,y:(h*x-m*v)/y+d};ir(r.edge,c,f,b),l.edge=rr(c,e,null,b),r.edge=rr(e,f,null,b),Jt(t),Jt(r)}else l.edge=rr(t.site,l.site)}}function Gt(e,t){var r=e.site,n=r.x,i=r.y,o=i-t;if(!o)return n;var a=e.P;if(!a)return-1/0;var s=(r=a.site).x,l=r.y,c=l-t;if(!c)return s;var u=s-n,d=1/o-1/c,h=u/c;return d?(-h+Math.sqrt(h*h-2*d*(u*u/(-2*c)-l+c/2+i-o/2)))/d+n:(n+s)/2}function Yt(e,t){var r=e.N;if(r)return Gt(r,t);var n=e.site;return n.y===t?n.x:1/0}function Xt(e){this.site=e,this.edges=[]}function Zt(e,t){return t.angle-e.angle}function Kt(){sr(this),this.x=this.y=this.arc=this.site=this.cy=null}function Jt(e){var t=e.P,r=e.N;if(t&&r){var n=t.site,i=e.site,o=r.site;if(n!==o){var a=i.x,s=i.y,l=n.x-a,c=n.y-s,u=o.x-a,d=2*(l*(g=o.y-s)-c*u);if(!(d>=-Me)){var h=l*l+c*c,p=u*u+g*g,f=(g*h-c*p)/d,m=(l*p-u*h)/d,g=m+s,y=Vt.pop()||new Kt;y.arc=e,y.site=i,y.x=f+a,y.y=g+Math.sqrt(f*f+m*m),y.cy=g,e.circle=y;for(var v=null,x=Nt._;x;)if(y.y=s)return;if(h>f){if(o){if(o.y>=c)return}else o={x:g,y:l};r={x:g,y:c}}else{if(o){if(o.y1)if(h>f){if(o){if(o.y>=c)return}else o={x:(l-i)/n,y:l};r={x:(c-i)/n,y:c}}else{if(o){if(o.y=s)return}else o={x:a,y:n*a+i};r={x:s,y:n*s+i}}else{if(o){if(o.x0)){if(t/=h,h<0){if(t0){if(t>d)return;t>u&&(u=t)}if(t=i-l,h||!(t<0)){if(t/=h,h<0){if(t>d)return;t>u&&(u=t)}else if(h>0){if(t0)){if(t/=p,p<0){if(t0){if(t>d)return;t>u&&(u=t)}if(t=o-c,p||!(t<0)){if(t/=p,p<0){if(t>d)return;t>u&&(u=t)}else if(p>0){if(t0&&(e.a={x:l+u*h,y:c+u*p}),d<1&&(e.b={x:l+d*h,y:c+d*p}),e}}}}}),l=a.length;l--;)(!er(t=a[l],e)||!s(t)||w(t.a.x-t.b.x)Te||w(i-r)>Te)&&(s.splice(a,0,new or(nr(o.site,u,w(n-d)Te?{x:d,y:w(t-d)Te?{x:w(r-f)Te?{x:h,y:w(t-h)Te?{x:w(r-p)=r&&c.x<=i&&c.y>=n&&c.y<=a?[[r,a],[i,a],[i,n],[r,n]]:[]).point=e[s]})),t}function s(e){return e.map((function(e,t){return{x:Math.round(n(e,t)/Te)*Te,y:Math.round(i(e,t)/Te)*Te,i:t}}))}return a.links=function(e){return dr(s(e)).edges.filter((function(e){return e.l&&e.r})).map((function(t){return{source:e[t.l.i],target:e[t.r.i]}}))},a.triangles=function(e){var t=[];return dr(s(e)).cells.forEach((function(r,n){for(var i,o,a,s,l=r.site,c=r.edges.sort(Zt),u=-1,d=c.length,h=c[d-1].edge,p=h.l===l?h.r:h.l;++uo&&(i=t.slice(o,i),s[a]?s[a]+=i:s[++a]=i),(r=r[0])===(n=n[0])?s[a]?s[a]+=n:s[++a]=n:(s[++a]=null,l.push({i:a,x:xr(r,n)})),o=wr.lastIndex;return om&&(m=l.x),l.y>g&&(g=l.y),c.push(l.x),u.push(l.y);else for(d=0;dm&&(m=x),b>g&&(g=b),c.push(x),u.push(b)}var _=m-p,k=g-f;function S(e,t,r,n,i,o,a,s){if(!isNaN(r)&&!isNaN(n))if(e.leaf){var l=e.x,c=e.y;if(null!=l)if(w(l-r)+w(c-n)<.01)A(e,t,r,n,i,o,a,s);else{var u=e.point;e.x=e.y=e.point=null,A(e,u,l,c,i,o,a,s),A(e,t,r,n,i,o,a,s)}else e.x=r,e.y=n,e.point=t}else A(e,t,r,n,i,o,a,s)}function A(e,t,r,n,i,o,a,s){var l=.5*(i+a),c=.5*(o+s),u=r>=l,d=n>=c,h=d<<1|u;e.leaf=!1,u?i=l:a=l,d?o=c:s=c,S(e=e.nodes[h]||(e.nodes[h]={leaf:!0,nodes:[],point:null,x:null,y:null}),t,r,n,i,o,a,s)}_>k?g=f+_:m=p+k;var T={leaf:!0,nodes:[],point:null,x:null,y:null,add:function(e){S(T,e,+y(e,++d),+v(e,d),p,f,m,g)}};if(T.visit=function(e){gr(e,T,p,f,m,g)},T.find=function(e){return function(e,t,r,n,i,o,a){var s,l=1/0;return function e(c,u,d,h,p){if(!(u>o||d>a||h=_)<<1|t>=b,k=w+4;w=0&&!(r=o.interpolators[n](e,t)););return r}function Sr(e,t){var r,n=[],i=[],o=e.length,a=t.length,s=Math.min(e.length,t.length);for(r=0;r=1)return 1;var t=e*e,r=t*e;return 4*(e<.5?r:3*(e-t)+r-.75)}function Rr(e){return 1-Math.cos(e*Pe)}function Lr(e){return Math.pow(2,10*(e-1))}function Dr(e){return 1-Math.sqrt(1-e*e)}function zr(e){return e<1/2.75?7.5625*e*e:e<2/2.75?7.5625*(e-=1.5/2.75)*e+.75:e<2.5/2.75?7.5625*(e-=2.25/2.75)*e+.9375:7.5625*(e-=2.625/2.75)*e+.984375}function jr(e,t){return t-=e,function(r){return Math.round(e+t*r)}}function Fr(e){var t,r,n,i=[e.a,e.b],o=[e.c,e.d],a=Br(i),s=Nr(i,o),l=Br(((t=o)[0]+=(n=-s)*(r=i)[0],t[1]+=n*r[1],t))||0;i[0]*o[1]=0?e.slice(0,r):e,i=r>=0?e.slice(r+1):"in";return n=Tr.get(n)||Ar,i=Mr.get(i)||R,t=i(n.apply(null,a.call(arguments,1))),function(e){return e<=0?0:e>=1?1:t(e)}},o.interpolateHcl=function(e,t){e=o.hcl(e),t=o.hcl(t);var r=e.h,n=e.c,i=e.l,a=t.h-r,s=t.c-n,l=t.l-i;isNaN(s)&&(s=0,n=isNaN(n)?t.c:n);isNaN(a)?(a=0,r=isNaN(r)?t.h:r):a>180?a-=360:a<-180&&(a+=360);return function(e){return qe(r+a*e,n+s*e,i+l*e)+""}},o.interpolateHsl=function(e,t){e=o.hsl(e),t=o.hsl(t);var r=e.h,n=e.s,i=e.l,a=t.h-r,s=t.s-n,l=t.l-i;isNaN(s)&&(s=0,n=isNaN(n)?t.s:n);isNaN(a)?(a=0,r=isNaN(r)?t.h:r):a>180?a-=360:a<-180&&(a+=360);return function(e){return He(r+a*e,n+s*e,i+l*e)+""}},o.interpolateLab=function(e,t){e=o.lab(e),t=o.lab(t);var r=e.l,n=e.a,i=e.b,a=t.l-r,s=t.a-n,l=t.b-i;return function(e){return Qe(r+a*e,n+s*e,i+l*e)+""}},o.interpolateRound=jr,o.transform=function(e){var t=l.createElementNS(o.ns.prefix.svg,"g");return(o.transform=function(e){if(null!=e){t.setAttribute("transform",e);var r=t.transform.baseVal.consolidate()}return new Fr(r?r.matrix:Vr)})(e)},Fr.prototype.toString=function(){return"translate("+this.translate+")rotate("+this.rotate+")skewX("+this.skew+")scale("+this.scale+")"};var Vr={a:1,b:0,c:0,d:1,e:0,f:0};function Ur(e){return e.length?e.pop()+",":""}function Hr(e,t){var r=[],n=[];return e=o.transform(e),t=o.transform(t),function(e,t,r,n){if(e[0]!==t[0]||e[1]!==t[1]){var i=r.push("translate(",null,",",null,")");n.push({i:i-4,x:xr(e[0],t[0])},{i:i-2,x:xr(e[1],t[1])})}else(t[0]||t[1])&&r.push("translate("+t+")")}(e.translate,t.translate,r,n),function(e,t,r,n){e!==t?(e-t>180?t+=360:t-e>180&&(e+=360),n.push({i:r.push(Ur(r)+"rotate(",null,")")-2,x:xr(e,t)})):t&&r.push(Ur(r)+"rotate("+t+")")}(e.rotate,t.rotate,r,n),function(e,t,r,n){e!==t?n.push({i:r.push(Ur(r)+"skewX(",null,")")-2,x:xr(e,t)}):t&&r.push(Ur(r)+"skewX("+t+")")}(e.skew,t.skew,r,n),function(e,t,r,n){if(e[0]!==t[0]||e[1]!==t[1]){var i=r.push(Ur(r)+"scale(",null,",",null,")");n.push({i:i-4,x:xr(e[0],t[0])},{i:i-2,x:xr(e[1],t[1])})}else 1===t[0]&&1===t[1]||r.push(Ur(r)+"scale("+t+")")}(e.scale,t.scale,r,n),e=t=null,function(e){for(var t,i=-1,o=n.length;++i0?r=t:(e.c=null,e.t=NaN,e=null,l.end({type:"end",alpha:r=0})):t>0&&(l.start({type:"start",alpha:r=t}),e=kt(s.tick)),s):r},s.start=function(){var e,t,r,o=y.length,l=v.length,u=c[0],f=c[1];for(e=0;e=0;)r.push(i[n])}function on(e,t){for(var r=[e],n=[];null!=(e=r.pop());)if(n.push(e),(o=e.children)&&(i=o.length))for(var i,o,a=-1;++a=0;)a.push(u=c[l]),u.parent=o,u.depth=o.depth+1;r&&(o.value=0),o.children=c}else r&&(o.value=+r.call(n,o,o.depth)||0),delete o.children;return on(i,(function(t){var n,i;e&&(n=t.children)&&n.sort(e),r&&(i=t.parent)&&(i.value+=t.value)})),s}return n.sort=function(t){return arguments.length?(e=t,n):e},n.children=function(e){return arguments.length?(t=e,n):t},n.value=function(e){return arguments.length?(r=e,n):r},n.revalue=function(e){return r&&(nn(e,(function(e){e.children&&(e.value=0)})),on(e,(function(e){var t;e.children||(e.value=+r.call(n,e,e.depth)||0),(t=e.parent)&&(t.value+=e.value)}))),e},n},o.layout.partition=function(){var e=o.layout.hierarchy(),t=[1,1];function r(e,t,n,i){var o=e.children;if(e.x=t,e.y=e.depth*i,e.dx=n,e.dy=i,o&&(a=o.length)){var a,s,l,c=-1;for(n=e.value?n/e.value:0;++cs&&(s=n),a.push(n)}for(r=0;ri&&(n=r,i=t);return n}function xn(e){return e.reduce(bn,0)}function bn(e,t){return e+t[1]}function _n(e,t){return wn(e,Math.ceil(Math.log(t.length)/Math.LN2+1))}function wn(e,t){for(var r=-1,n=+e[0],i=(e[1]-n)/t,o=[];++r<=t;)o[r]=i*r+n;return o}function kn(e){return[o.min(e),o.max(e)]}function Sn(e,t){return e.value-t.value}function An(e,t){var r=e._pack_next;e._pack_next=t,t._pack_prev=e,t._pack_next=r,r._pack_prev=t}function Tn(e,t){e._pack_next=t,t._pack_prev=e}function Mn(e,t){var r=t.x-e.x,n=t.y-e.y,i=e.r+t.r;return.999*i*i>r*r+n*n}function Cn(e){if((t=e.children)&&(l=t.length)){var t,r,n,i,o,a,s,l,c=1/0,u=-1/0,d=1/0,h=-1/0;if(t.forEach(En),(r=t[0]).x=-r.r,r.y=0,x(r),l>1&&((n=t[1]).x=n.r,n.y=0,x(n),l>2))for(On(r,n,i=t[2]),x(i),An(r,i),r._pack_prev=i,An(i,n),n=r._pack_next,o=3;o0)for(a=-1;++a=d[0]&&l<=d[1]&&((s=c[o.bisect(h,l,1,f)-1]).y+=m,s.push(i[a]));return c}return i.value=function(e){return arguments.length?(t=e,i):t},i.range=function(e){return arguments.length?(r=mt(e),i):r},i.bins=function(e){return arguments.length?(n="number"===typeof e?function(t){return wn(t,e)}:mt(e),i):n},i.frequency=function(t){return arguments.length?(e=!!t,i):e},i},o.layout.pack=function(){var e,t=o.layout.hierarchy().sort(Sn),r=0,n=[1,1];function i(i,o){var a=t.call(this,i,o),s=a[0],l=n[0],c=n[1],u=null==e?Math.sqrt:"function"===typeof e?e:function(){return e};if(s.x=s.y=0,on(s,(function(e){e.r=+u(e.value)})),on(s,Cn),r){var d=r*(e?1:Math.max(2*s.r/l,2*s.r/c))/2;on(s,(function(e){e.r+=d})),on(s,Cn),on(s,(function(e){e.r-=d}))}return Pn(s,l/2,c/2,e?1:1/Math.max(2*s.r/l,2*s.r/c)),a}return i.size=function(e){return arguments.length?(n=e,i):n},i.radius=function(t){return arguments.length?(e=null==t||"function"===typeof t?t:+t,i):e},i.padding=function(e){return arguments.length?(r=+e,i):r},rn(i,t)},o.layout.tree=function(){var e=o.layout.hierarchy().sort(null).value(null),t=Rn,r=[1,1],n=null;function i(i,o){var c=e.call(this,i,o),u=c[0],d=function(e){var t,r={A:null,children:[e]},n=[r];for(;null!=(t=n.pop());)for(var i,o=t.children,a=0,s=o.length;ap.x&&(p=e),e.depth>f.depth&&(f=e)}));var m=t(h,p)/2-h.x,g=r[0]/(p.x+t(p,h)/2+m),y=r[1]/(f.depth||1);nn(u,(function(e){e.x=(e.x+m)*g,e.y=e.depth*y}))}return c}function a(e){var r=e.children,n=e.parent.children,i=e.i?n[e.i-1]:null;if(r.length){!function(e){var t,r=0,n=0,i=e.children,o=i.length;for(;--o>=0;)(t=i[o]).z+=r,t.m+=r,r+=t.s+(n+=t.c)}(e);var o=(r[0].z+r[r.length-1].z)/2;i?(e.z=i.z+t(e._,i._),e.m=e.z-o):e.z=o}else i&&(e.z=i.z+t(e._,i._));e.parent.A=function(e,r,n){if(r){for(var i,o=e,a=e,s=r,l=o.parent.children[0],c=o.m,u=a.m,d=s.m,h=l.m;s=Dn(s),o=Ln(o),s&&o;)l=Ln(l),(a=Dn(a)).a=e,(i=s.z+d-o.z-c+t(s._,o._))>0&&(zn(jn(s,e,n),e,i),c+=i,u+=i),d+=s.m,c+=o.m,h+=l.m,u+=a.m;s&&!Dn(a)&&(a.t=s,a.m+=d-u),o&&!Ln(l)&&(l.t=o,l.m+=c-h,n=e)}return n}(e,i,e.parent.A||n[0])}function s(e){e._.x=e.z+e.parent.m,e.m+=e.parent.m}function l(e){e.x*=r[0],e.y=e.depth*r[1]}return i.separation=function(e){return arguments.length?(t=e,i):t},i.size=function(e){return arguments.length?(n=null==(r=e)?l:null,i):n?null:r},i.nodeSize=function(e){return arguments.length?(n=null==(r=e)?null:l,i):n?r:null},rn(i,e)},o.layout.cluster=function(){var e=o.layout.hierarchy().sort(null).value(null),t=Rn,r=[1,1],n=!1;function i(i,a){var s,l=e.call(this,i,a),c=l[0],u=0;on(c,(function(e){var r=e.children;r&&r.length?(e.x=function(e){return e.reduce((function(e,t){return e+t.x}),0)/e.length}(r),e.y=function(e){return 1+o.max(e,(function(e){return e.y}))}(r)):(e.x=s?u+=t(e,s):0,e.y=0,s=e)}));var d=Fn(c),h=Nn(c),p=d.x-t(d,h)/2,f=h.x+t(h,d)/2;return on(c,n?function(e){e.x=(e.x-c.x)*r[0],e.y=(c.y-e.y)*r[1]}:function(e){e.x=(e.x-p)/(f-p)*r[0],e.y=(1-(c.y?e.y/c.y:1))*r[1]}),l}return i.separation=function(e){return arguments.length?(t=e,i):t},i.size=function(e){return arguments.length?(n=null==(r=e),i):n?null:r},i.nodeSize=function(e){return arguments.length?(n=null!=(r=e),i):n?r:null},rn(i,e)},o.layout.treemap=function(){var e,t=o.layout.hierarchy(),r=Math.round,n=[1,1],i=null,a=Bn,s=!1,l="squarify",c=.5*(1+Math.sqrt(5));function u(e,t){for(var r,n,i=-1,o=e.length;++i0;)s.push(r=c[i-1]),s.area+=r.area,"squarify"!==l||(n=p(s,m))<=h?(c.pop(),h=n):(s.area-=s.pop().area,f(s,m,o,!1),m=Math.min(o.dx,o.dy),s.length=s.area=0,h=1/0);s.length&&(f(s,m,o,!0),s.length=s.area=0),t.forEach(d)}}function h(e){var t=e.children;if(t&&t.length){var r,n=a(e),i=t.slice(),o=[];for(u(i,n.dx*n.dy/e.value),o.area=0;r=i.pop();)o.push(r),o.area+=r.area,null!=r.z&&(f(o,r.z?n.dx:n.dy,n,!i.length),o.length=o.area=0);t.forEach(h)}}function p(e,t){for(var r,n=e.area,i=0,o=1/0,a=-1,s=e.length;++ai&&(i=r));return t*=t,(n*=n)?Math.max(t*i*c/n,n/(t*o*c)):1/0}function f(e,t,n,i){var o,a=-1,s=e.length,l=n.x,c=n.y,u=t?r(e.area/t):0;if(t==n.dx){for((i||u>n.dy)&&(u=n.dy);++an.dx)&&(u=n.dx);++a1);return e+t*r*Math.sqrt(-2*Math.log(i)/i)}},logNormal:function(){var e=o.random.normal.apply(o,arguments);return function(){return Math.exp(e())}},bates:function(e){var t=o.random.irwinHall(e);return function(){return t()/e}},irwinHall:function(e){return function(){for(var t=0,r=0;r2?Yn:$n,l=n?Wr:$r;return i=a(e,t,l,r),o=a(t,e,l,kr),s}function s(e){return i(e)}return s.invert=function(e){return o(e)},s.domain=function(t){return arguments.length?(e=t.map(Number),a()):e},s.range=function(e){return arguments.length?(t=e,a()):t},s.rangeRound=function(e){return s.range(e).interpolate(jr)},s.clamp=function(e){return arguments.length?(n=e,a()):n},s.interpolate=function(e){return arguments.length?(r=e,a()):r},s.ticks=function(t){return Qn(e,t)},s.tickFormat=function(t,r){return d3_scale_linearTickFormat(e,t,r)},s.nice=function(t){return Kn(e,t),a()},s.copy=function(){return Xn(e,t,r,n)},a()}function Zn(e,t){return o.rebind(e,t,"range","rangeRound","interpolate","clamp")}function Kn(e,t){return Wn(e,qn(Jn(e,t)[2])),Wn(e,qn(Jn(e,t)[2])),e}function Jn(e,t){null==t&&(t=10);var r=Un(e),n=r[1]-r[0],i=Math.pow(10,Math.floor(Math.log(n/t)/Math.LN10)),o=t/n*i;return o<=.15?i*=10:o<=.35?i*=5:o<=.75&&(i*=2),r[0]=Math.ceil(r[0]/i)*i,r[1]=Math.floor(r[1]/i)*i+.5*i,r[2]=i,r}function Qn(e,t){return o.range.apply(o,Jn(e,t))}o.scale.linear=function(){return Xn([0,1],[0,1],kr,!1)};function ei(e,t,r,n){function i(e){return(r?Math.log(e<0?0:e):-Math.log(e>0?0:-e))/Math.log(t)}function o(e){return r?Math.pow(t,e):-Math.pow(t,-e)}function a(t){return e(i(t))}return a.invert=function(t){return o(e.invert(t))},a.domain=function(t){return arguments.length?(r=t[0]>=0,e.domain((n=t.map(Number)).map(i)),a):n},a.base=function(r){return arguments.length?(t=+r,e.domain(n.map(i)),a):t},a.nice=function(){var t=Wn(n.map(i),r?Math:ti);return e.domain(t),n=t.map(o),a},a.ticks=function(){var e=Un(n),a=[],s=e[0],l=e[1],c=Math.floor(i(s)),u=Math.ceil(i(l)),d=t%1?2:t;if(isFinite(u-c)){if(r){for(;c0;h--)a.push(o(c)*h);for(c=0;a[c]l;u--);a=a.slice(c,u)}return a},a.copy=function(){return ei(e.copy(),t,r,n)},Zn(a,e)}o.scale.log=function(){return ei(o.scale.linear().domain([0,1]),10,!0,[1,10])};var ti={floor:function(e){return-Math.ceil(-e)},ceil:function(e){return-Math.floor(-e)}};function ri(e,t,r){var n=ni(t),i=ni(1/t);function o(t){return e(n(t))}return o.invert=function(t){return i(e.invert(t))},o.domain=function(t){return arguments.length?(e.domain((r=t.map(Number)).map(n)),o):r},o.ticks=function(e){return Qn(r,e)},o.tickFormat=function(e,t){return d3_scale_linearTickFormat(r,e,t)},o.nice=function(e){return o.domain(Kn(r,e))},o.exponent=function(a){return arguments.length?(n=ni(t=a),i=ni(1/t),e.domain(r.map(n)),o):t},o.copy=function(){return ri(e.copy(),t,r)},Zn(o,e)}function ni(e){return function(t){return t<0?-Math.pow(-t,e):Math.pow(t,e)}}function ii(e,t){var r,n,i;function a(i){return n[((r.get(i)||("range"===t.t?r.set(i,e.push(i)):NaN))-1)%n.length]}function s(t,r){return o.range(e.length).map((function(e){return t+r*e}))}return a.domain=function(n){if(!arguments.length)return e;e=[],r=new S;for(var i,o=-1,s=n.length;++o0?r[n-1]:e[0],nd?0:1;if(c=Ie)return l(c,p)+(s?l(s,1-p):"")+"Z";var f,m,g,y,v,x,b,_,w,k,S,A,T=0,M=0,C=[];if((y=(+a.apply(this,arguments)||0)/2)&&(g=n===fi?Math.sqrt(s*s+c*c):+n.apply(this,arguments),p||(M*=-1),c&&(M=Le(g/c*Math.sin(y))),s&&(T=Le(g/s*Math.sin(y)))),c){v=c*Math.cos(u+M),x=c*Math.sin(u+M),b=c*Math.cos(d-M),_=c*Math.sin(d-M);var E=Math.abs(d-u-2*M)<=Ce?0:1;if(M&&bi(v,x,b,_)===p^E){var I=(u+d)/2;v=c*Math.cos(I),x=c*Math.sin(I),b=_=null}}else v=x=0;if(s){w=s*Math.cos(d-T),k=s*Math.sin(d-T),S=s*Math.cos(u+T),A=s*Math.sin(u+T);var P=Math.abs(u-d+2*T)<=Ce?0:1;if(T&&bi(w,k,S,A)===1-p^P){var O=(u+d)/2;w=s*Math.cos(O),k=s*Math.sin(O),S=A=null}}else w=k=0;if(h>Te&&(f=Math.min(Math.abs(c-s)/2,+r.apply(this,arguments)))>.001){m=s0?0:1}function _i(e,t,r,n,i){var o=e[0]-t[0],a=e[1]-t[1],s=(i?n:-n)/Math.sqrt(o*o+a*a),l=s*a,c=-s*o,u=e[0]+l,d=e[1]+c,h=t[0]+l,p=t[1]+c,f=(u+h)/2,m=(d+p)/2,g=h-u,y=p-d,v=g*g+y*y,x=r-n,b=u*p-h*d,_=(y<0?-1:1)*Math.sqrt(Math.max(0,x*x*v-b*b)),w=(b*y-g*_)/v,k=(-b*g-y*_)/v,S=(b*y+g*_)/v,A=(-b*g+y*_)/v,T=w-f,M=k-m,C=S-f,E=A-m;return T*T+M*M>C*C+E*E&&(w=S,k=A),[[w-l,k-c],[w*r/x,k*r/x]]}function wi(){return!0}function ki(e){var t=Mt,r=Ct,n=wi,i=Ai,o=i.key,a=.7;function s(o){var s,l=[],c=[],u=-1,d=o.length,h=mt(t),p=mt(r);function f(){l.push("M",i(e(c),a))}for(;++u1&&i.push("H",n[0]);return i.join("")},"step-before":Mi,"step-after":Ci,basis:Pi,"basis-open":function(e){if(e.length<4)return Ai(e);var t,r=[],n=-1,i=e.length,o=[0],a=[0];for(;++n<3;)t=e[n],o.push(t[0]),a.push(t[1]);r.push(Oi(Di,o)+","+Oi(Di,a)),--n;for(;++n9&&(i=3*t/Math.sqrt(i),a[s]=i*r,a[s+1]=i*n);s=-1;for(;++s<=l;)i=(e[Math.min(l,s+1)][0]-e[Math.max(0,s-1)][0])/(6*(1+a[s]*a[s])),o.push([i||0,a[s]*i||0]);return o}(e))}});function Ai(e){return e.length>1?e.join("L"):e+"Z"}function Ti(e){return e.join("L")+"Z"}function Mi(e){for(var t=0,r=e.length,n=e[0],i=[n[0],",",n[1]];++t1){s=t[1],o=e[l],l++,n+="C"+(i[0]+a[0])+","+(i[1]+a[1])+","+(o[0]-s[0])+","+(o[1]-s[1])+","+o[0]+","+o[1];for(var c=2;cCe)+",1 "+t}function l(e,t,r,n){return"Q 0,0 "+n}return o.radius=function(e){return arguments.length?(r=mt(e),o):r},o.source=function(t){return arguments.length?(e=mt(t),o):e},o.target=function(e){return arguments.length?(t=mt(e),o):t},o.startAngle=function(e){return arguments.length?(n=mt(e),o):n},o.endAngle=function(e){return arguments.length?(i=mt(e),o):i},o},o.svg.diagonal=function(){var e=Bi,t=Vi,r=Hi;function n(n,i){var o=e.call(this,n,i),a=t.call(this,n,i),s=(o.y+a.y)/2,l=[o,{x:o.x,y:s},{x:a.x,y:s},a];return"M"+(l=l.map(r))[0]+"C"+l[1]+" "+l[2]+" "+l[3]}return n.source=function(t){return arguments.length?(e=mt(t),n):e},n.target=function(e){return arguments.length?(t=mt(e),n):t},n.projection=function(e){return arguments.length?(r=e,n):r},n},o.svg.diagonal.radial=function(){var e=o.svg.diagonal(),t=Hi,r=e.projection;return e.projection=function(e){return arguments.length?r(function(e){return function(){var t=e.apply(this,arguments),r=t[0],n=t[1]-Pe;return[r*Math.cos(n),r*Math.sin(n)]}}(t=e)):t},e},o.svg.symbol=function(){var e=Wi,t=$i;function r(r,n){return(Gi.get(e.call(this,r,n))||qi)(t.call(this,r,n))}return r.type=function(t){return arguments.length?(e=mt(t),r):e},r.size=function(e){return arguments.length?(t=mt(e),r):t},r};var Gi=o.map({circle:qi,cross:function(e){var t=Math.sqrt(e/5)/2;return"M"+-3*t+","+-t+"H"+-t+"V"+-3*t+"H"+t+"V"+-t+"H"+3*t+"V"+t+"H"+t+"V"+3*t+"H"+-t+"V"+t+"H"+-3*t+"Z"},diamond:function(e){var t=Math.sqrt(e/(2*Xi)),r=t*Xi;return"M0,"+-t+"L"+r+",0 0,"+t+" "+-r+",0Z"},square:function(e){var t=Math.sqrt(e)/2;return"M"+-t+","+-t+"L"+t+","+-t+" "+t+","+t+" "+-t+","+t+"Z"},"triangle-down":function(e){var t=Math.sqrt(e/Yi),r=t*Yi/2;return"M0,"+r+"L"+t+","+-r+" "+-t+","+-r+"Z"},"triangle-up":function(e){var t=Math.sqrt(e/Yi),r=t*Yi/2;return"M0,"+-r+"L"+t+","+r+" "+-t+","+r+"Z"}});o.svg.symbolTypes=Gi.keys();var Yi=Math.sqrt(3),Xi=Math.tan(30*Oe);X.transition=function(e){for(var t,r,n=Qi||++ro,i=oo(e),o=[],a=eo||{time:Date.now(),ease:Or,delay:0,duration:250},s=-1,l=this.length;++s0;)c[--h].call(e,a);if(o>=1)return d.event&&d.event.end.call(e,e.__data__,t),--u.count?delete u[n]:delete e[r],1}d||(o=i.time,a=kt((function(e){var t=d.delay;if(a.t=t+o,t<=e)return h(e-t);a.c=h}),0,o),d=u[n]={tween:new S,time:o,timer:a,delay:i.delay,duration:i.duration,ease:i.ease,index:t},i=null,++u.count)}to.call=X.call,to.empty=X.empty,to.node=X.node,to.size=X.size,o.transition=function(e,t){return e&&e.transition?Qi?e.transition(t):e:o.selection().transition(e)},o.transition.prototype=to,to.select=function(e){var t,r,n,i=this.id,o=this.namespace,a=[];e=Z(e);for(var s=-1,l=this.length;++srect,.s>rect").attr("width",a[1]-a[0])}function m(e){e.select(".extent").attr("y",s[0]),e.selectAll(".extent,.e>rect,.w>rect").attr("height",s[1]-s[0])}function g(){var d,g,y=this,v=o.select(o.event.target),x=r.of(y,arguments),b=o.select(y),_=v.datum(),w=!/^(n|s)$/.test(_)&&n,k=!/^(e|w)$/.test(_)&&i,S=v.classed("extent"),A=we(y),T=o.mouse(y),M=o.select(u(y)).on("keydown.brush",(function(){32==o.event.keyCode&&(S||(d=null,T[0]-=a[1],T[1]-=s[1],S=2),B())})).on("keyup.brush",(function(){32==o.event.keyCode&&2==S&&(T[0]+=a[1],T[1]+=s[1],S=0,B())}));if(o.event.changedTouches?M.on("touchmove.brush",I).on("touchend.brush",O):M.on("mousemove.brush",I).on("mouseup.brush",O),b.interrupt().selectAll("*").interrupt(),S)T[0]=a[0]-T[0],T[1]=s[0]-T[1];else if(_){var C=+/w$/.test(_),E=+/^n/.test(_);g=[a[1-C]-T[0],s[1-E]-T[1]],T[0]=a[C],T[1]=s[E]}else o.event.altKey&&(d=T.slice());function I(){var e=o.mouse(y),t=!1;g&&(e[0]+=g[0],e[1]+=g[1]),S||(o.event.altKey?(d||(d=[(a[0]+a[1])/2,(s[0]+s[1])/2]),T[0]=a[+(e[0](n=1))return n;for(;ro?r=i:n=i,i=.5*(n-r)+r}return i},i.prototype.solve=function(e,t){return this.sampleCurveY(this.solveCurveX(e,t))};var o=a;function a(e,t){this.x=e,this.y=t}a.prototype={clone:function(){return new a(this.x,this.y)},add:function(e){return this.clone()._add(e)},sub:function(e){return this.clone()._sub(e)},multByPoint:function(e){return this.clone()._multByPoint(e)},divByPoint:function(e){return this.clone()._divByPoint(e)},mult:function(e){return this.clone()._mult(e)},div:function(e){return this.clone()._div(e)},rotate:function(e){return this.clone()._rotate(e)},rotateAround:function(e,t){return this.clone()._rotateAround(e,t)},matMult:function(e){return this.clone()._matMult(e)},unit:function(){return this.clone()._unit()},perp:function(){return this.clone()._perp()},round:function(){return this.clone()._round()},mag:function(){return Math.sqrt(this.x*this.x+this.y*this.y)},equals:function(e){return this.x===e.x&&this.y===e.y},dist:function(e){return Math.sqrt(this.distSqr(e))},distSqr:function(e){var t=e.x-this.x,r=e.y-this.y;return t*t+r*r},angle:function(){return Math.atan2(this.y,this.x)},angleTo:function(e){return Math.atan2(this.y-e.y,this.x-e.x)},angleWith:function(e){return this.angleWithSep(e.x,e.y)},angleWithSep:function(e,t){return Math.atan2(this.x*t-this.y*e,this.x*e+this.y*t)},_matMult:function(e){var t=e[0]*this.x+e[1]*this.y,r=e[2]*this.x+e[3]*this.y;return this.x=t,this.y=r,this},_add:function(e){return this.x+=e.x,this.y+=e.y,this},_sub:function(e){return this.x-=e.x,this.y-=e.y,this},_mult:function(e){return this.x*=e,this.y*=e,this},_div:function(e){return this.x/=e,this.y/=e,this},_multByPoint:function(e){return this.x*=e.x,this.y*=e.y,this},_divByPoint:function(e){return this.x/=e.x,this.y/=e.y,this},_unit:function(){return this._div(this.mag()),this},_perp:function(){var e=this.y;return this.y=this.x,this.x=-e,this},_rotate:function(e){var t=Math.cos(e),r=Math.sin(e),n=t*this.x-r*this.y,i=r*this.x+t*this.y;return this.x=n,this.y=i,this},_rotateAround:function(e,t){var r=Math.cos(e),n=Math.sin(e),i=t.x+r*(this.x-t.x)-n*(this.y-t.y),o=t.y+n*(this.x-t.x)+r*(this.y-t.y);return this.x=i,this.y=o,this},_round:function(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this}},a.convert=function(e){return e instanceof a?e:Array.isArray(e)?new a(e[0],e[1]):e};var s="undefined"!==typeof self?self:{};function l(e,t){if(Array.isArray(e)){if(!Array.isArray(t)||e.length!==t.length)return!1;for(var r=0;r=1)return 1;var t=e*e,r=t*e;return 4*(e<.5?r:3*(e-t)+r-.75)}function d(e,t,r,i){var o=new n(e,t,r,i);return function(e){return o.solve(e)}}var h=d(.25,.1,.25,1);function p(e,t,r){return Math.min(r,Math.max(t,e))}function f(e,t,r){var n=r-t,i=((e-t)%n+n)%n+t;return i===t?r:i}function m(e,t,r){if(!e.length)return r(null,[]);var n=e.length,i=new Array(e.length),o=null;e.forEach((function(e,a){t(e,(function(e,t){e&&(o=e),i[a]=t,0===--n&&r(o,i)}))}))}function g(e){var t=[];for(var r in e)t.push(e[r]);return t}function y(e,t){var r=[];for(var n in e)n in t||r.push(n);return r}function v(e){for(var t=[],r=arguments.length-1;r-- >0;)t[r]=arguments[r+1];for(var n=0,i=t;n>t/4).toString(16):([1e7]+-[1e3]+-4e3+-8e3+-1e11).replace(/[018]/g,e)}return e()}function k(e){return e<=1?1:Math.pow(2,Math.ceil(Math.log(e)/Math.LN2))}function S(e){return!!e&&/^[0-9a-f]{8}-[0-9a-f]{4}-[4][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i.test(e)}function A(e,t){e.forEach((function(e){t[e]&&(t[e]=t[e].bind(t))}))}function T(e,t){return-1!==e.indexOf(t,e.length-t.length)}function M(e,t,r){var n={};for(var i in e)n[i]=t.call(r||this,e[i],i,e);return n}function C(e,t,r){var n={};for(var i in e)t.call(r||this,e[i],i,e)&&(n[i]=e[i]);return n}function E(e){return Array.isArray(e)?e.map(E):"object"===typeof e&&e?M(e,E):e}function I(e,t){for(var r=0;r=0)return!0;return!1}var P={};function O(e){P[e]||("undefined"!==typeof console&&console.warn(e),P[e]=!0)}function R(e,t,r){return(r.y-e.y)*(t.x-e.x)>(t.y-e.y)*(r.x-e.x)}function L(e){for(var t=0,r=0,n=e.length,i=n-1,o=void 0,a=void 0;r@\,;\:\\"\/\[\]\?\=\{\}\x7F]+)(?:\=(?:([^\x00-\x20\(\)<>@\,;\:\\"\/\[\]\?\=\{\}\x7F]+)|(?:\"((?:[^"\\]|\\.)*)\")))?/g,r={};if(e.replace(t,(function(e,t,n,i){var o=n||i;return r[t]=!o||o.toLowerCase(),""})),r["max-age"]){var n=parseInt(r["max-age"],10);isNaN(n)?delete r["max-age"]:r["max-age"]=n}return r}var F=null;function N(e){if(null==F){var t=e.navigator?e.navigator.userAgent:null;F=!!e.safari||!(!t||!(/\b(iPad|iPhone|iPod)\b/.test(t)||t.match("Safari")&&!t.match("Chrome")))}return F}function B(e){try{var t=s[e];return t.setItem("_mapbox_test_",1),t.removeItem("_mapbox_test_"),!0}catch(r){return!1}}function V(e){return s.btoa(encodeURIComponent(e).replace(/%([0-9A-F]{2})/g,(function(e,t){return String.fromCharCode(Number("0x"+t))})))}function U(e){return decodeURIComponent(s.atob(e).split("").map((function(e){return"%"+("00"+e.charCodeAt(0).toString(16)).slice(-2)})).join(""))}var H,$,W,q,G=s.performance&&s.performance.now?s.performance.now.bind(s.performance):Date.now.bind(Date),Y=s.requestAnimationFrame||s.mozRequestAnimationFrame||s.webkitRequestAnimationFrame||s.msRequestAnimationFrame,X=s.cancelAnimationFrame||s.mozCancelAnimationFrame||s.webkitCancelAnimationFrame||s.msCancelAnimationFrame,Z={now:G,frame:function(e){var t=Y(e);return{cancel:function(){return X(t)}}},getImageData:function(e,t){void 0===t&&(t=0);var r=s.document.createElement("canvas"),n=r.getContext("2d");if(!n)throw new Error("failed to create canvas 2d context");return r.width=e.width,r.height=e.height,n.drawImage(e,0,0,e.width,e.height),n.getImageData(-t,-t,e.width+2*t,e.height+2*t)},resolveURL:function(e){return H||(H=s.document.createElement("a")),H.href=e,H.href},hardwareConcurrency:s.navigator&&s.navigator.hardwareConcurrency||4,get devicePixelRatio(){return s.devicePixelRatio},get prefersReducedMotion(){return!!s.matchMedia&&(null==$&&($=s.matchMedia("(prefers-reduced-motion: reduce)")),$.matches)}},K={API_URL:"https://api.mapbox.com",get EVENTS_URL(){return this.API_URL?0===this.API_URL.indexOf("https://api.mapbox.cn")?"https://events.mapbox.cn/events/v2":0===this.API_URL.indexOf("https://api.mapbox.com")?"https://events.mapbox.com/events/v2":null:null},FEEDBACK_URL:"https://apps.mapbox.com/feedback",REQUIRE_ACCESS_TOKEN:!0,ACCESS_TOKEN:null,MAX_PARALLEL_IMAGE_REQUESTS:16},J={supported:!1,testSupport:te},Q=!1,ee=!1;function te(e){!Q&&q&&(ee?re(e):W=e)}function re(e){var t=e.createTexture();e.bindTexture(e.TEXTURE_2D,t);try{if(e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,q),e.isContextLost())return;J.supported=!0}catch(r){}e.deleteTexture(t),Q=!0}s.document&&((q=s.document.createElement("img")).onload=function(){W&&re(W),W=null,ee=!0},q.onerror=function(){Q=!0,W=null},q.src="data:image/webp;base64,UklGRh4AAABXRUJQVlA4TBEAAAAvAQAAAAfQ//73v/+BiOh/AAA=");var ne="01";function ie(){for(var e="1",t="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ",r="",n=0;n<10;n++)r+=t[Math.floor(62*Math.random())];var i=432e5;return{token:[e,ne,r].join(""),tokenExpiresAt:Date.now()+i}}var oe=function(e,t){this._transformRequestFn=e,this._customAccessToken=t,this._createSkuToken()};function ae(e){return 0===e.indexOf("mapbox:")}oe.prototype._createSkuToken=function(){var e=ie();this._skuToken=e.token,this._skuTokenExpiresAt=e.tokenExpiresAt},oe.prototype._isSkuTokenExpired=function(){return Date.now()>this._skuTokenExpiresAt},oe.prototype.transformRequest=function(e,t){return this._transformRequestFn&&this._transformRequestFn(e,t)||{url:e}},oe.prototype.normalizeStyleURL=function(e,t){if(!ae(e))return e;var r=he(e);return r.path="/styles/v1"+r.path,this._makeAPIURL(r,this._customAccessToken||t)},oe.prototype.normalizeGlyphsURL=function(e,t){if(!ae(e))return e;var r=he(e);return r.path="/fonts/v1"+r.path,this._makeAPIURL(r,this._customAccessToken||t)},oe.prototype.normalizeSourceURL=function(e,t){if(!ae(e))return e;var r=he(e);return r.path="/v4/"+r.authority+".json",r.params.push("secure"),this._makeAPIURL(r,this._customAccessToken||t)},oe.prototype.normalizeSpriteURL=function(e,t,r,n){var i=he(e);return ae(e)?(i.path="/styles/v1"+i.path+"/sprite"+t+r,this._makeAPIURL(i,this._customAccessToken||n)):(i.path+=""+t+r,pe(i))},oe.prototype.normalizeTileURL=function(e,t){if(this._isSkuTokenExpired()&&this._createSkuToken(),e&&!ae(e))return e;var r=he(e),n=/(\.(png|jpg)\d*)(?=$)/,i=/^.+\/v4\//,o=Z.devicePixelRatio>=2||512===t?"@2x":"",a=J.supported?".webp":"$1";r.path=r.path.replace(n,""+o+a),r.path=r.path.replace(i,"/"),r.path="/v4"+r.path;var s=this._customAccessToken||ue(r.params)||K.ACCESS_TOKEN;return K.REQUIRE_ACCESS_TOKEN&&s&&this._skuToken&&r.params.push("sku="+this._skuToken),this._makeAPIURL(r,s)},oe.prototype.canonicalizeTileURL=function(e,t){var r="/v4/",n=/\.[\w]+$/,i=he(e);if(!i.path.match(/(^\/v4\/)/)||!i.path.match(n))return e;var o="mapbox://tiles/";o+=i.path.replace(r,"");var a=i.params;return t&&(a=a.filter((function(e){return!e.match(/^access_token=/)}))),a.length&&(o+="?"+a.join("&")),o},oe.prototype.canonicalizeTileset=function(e,t){for(var r=!!t&&ae(t),n=[],i=0,o=e.tiles||[];i=0&&e.params.splice(i,1)}if("/"!==n.path&&(e.path=""+n.path+e.path),!K.REQUIRE_ACCESS_TOKEN)return pe(e);if(!(t=t||K.ACCESS_TOKEN))throw new Error("An API access token is required to use Mapbox GL. "+r);if("s"===t[0])throw new Error("Use a public access token (pk.*) with Mapbox GL, not a secret access token (sk.*). "+r);return e.params=e.params.filter((function(e){return-1===e.indexOf("access_token")})),e.params.push("access_token="+t),pe(e)};var se=/^((https?:)?\/\/)?([^\/]+\.)?mapbox\.c(n|om)(\/|\?|$)/i;function le(e){return se.test(e)}function ce(e){return e.indexOf("sku=")>0&&le(e)}function ue(e){for(var t=0,r=e;t=1&&s.localStorage.setItem(t,JSON.stringify(this.eventData))}catch(n){O("Unable to write to LocalStorage")}},ge.prototype.processRequests=function(e){},ge.prototype.postEvent=function(e,t,n,i){var o=this;if(K.EVENTS_URL){var a=he(K.EVENTS_URL);a.params.push("access_token="+(i||K.ACCESS_TOKEN||""));var s={event:this.type,created:new Date(e).toISOString(),sdkIdentifier:"mapbox-gl-js",sdkVersion:r,skuId:ne,userId:this.anonId},l=t?v(s,t):s,c={url:pe(a),headers:{"Content-Type":"text/plain"},body:JSON.stringify([l])};this.pendingRequest=Ke(c,(function(e){o.pendingRequest=null,n(e),o.saveEventData(),o.processRequests(i)}))}},ge.prototype.queueRequest=function(e,t){this.queue.push(e),this.processRequests(t)};var ye,ve,xe=function(e){function t(){e.call(this,"map.load"),this.success={},this.skuToken=""}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.postMapLoadEvent=function(e,t,r,n){this.skuToken=r,(K.EVENTS_URL&&n||K.ACCESS_TOKEN&&Array.isArray(e)&&e.some((function(e){return ae(e)||le(e)})))&&this.queueRequest({id:t,timestamp:Date.now()},n)},t.prototype.processRequests=function(e){var t=this;if(!this.pendingRequest&&0!==this.queue.length){var r=this.queue.shift(),n=r.id,i=r.timestamp;n&&this.success[n]||(this.anonId||this.fetchEventData(),S(this.anonId)||(this.anonId=w()),this.postEvent(i,{skuToken:this.skuToken},(function(e){e||n&&(t.success[n]=!0)}),e))}},t}(ge),be=function(e){function t(t){e.call(this,"appUserTurnstile"),this._customAccessToken=t}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.postTurnstileEvent=function(e,t){K.EVENTS_URL&&K.ACCESS_TOKEN&&Array.isArray(e)&&e.some((function(e){return ae(e)||le(e)}))&&this.queueRequest(Date.now(),t)},t.prototype.processRequests=function(e){var t=this;if(!this.pendingRequest&&0!==this.queue.length){this.anonId&&this.eventData.lastSuccess&&this.eventData.tokenU||this.fetchEventData();var r=me(K.ACCESS_TOKEN),n=r?r.u:K.ACCESS_TOKEN,i=n!==this.eventData.tokenU;S(this.anonId)||(this.anonId=w(),i=!0);var o=this.queue.shift();if(this.eventData.lastSuccess){var a=new Date(this.eventData.lastSuccess),s=new Date(o),l=(o-this.eventData.lastSuccess)/864e5;i=i||l>=1||l<-1||a.getDate()!==s.getDate()}else i=!0;if(!i)return this.processRequests();this.postEvent(o,{"enabled.telemetry":!1},(function(e){e||(t.eventData.lastSuccess=o,t.eventData.tokenU=n)}),e)}},t}(ge),_e=new be,we=_e.postTurnstileEvent.bind(_e),ke=new xe,Se=ke.postMapLoadEvent.bind(ke),Ae="mapbox-tiles",Te=500,Me=50,Ce=42e4;function Ee(){s.caches&&!ye&&(ye=s.caches.open(Ae))}function Ie(e,t){if(void 0===ve)try{new Response(new ReadableStream),ve=!0}catch(r){ve=!1}ve?t(e.body):e.blob().then(t)}function Pe(e,t,r){if(Ee(),ye){var n={status:t.status,statusText:t.statusText,headers:new s.Headers};t.headers.forEach((function(e,t){return n.headers.set(t,e)}));var i=j(t.headers.get("Cache-Control")||"");i["no-store"]||(i["max-age"]&&n.headers.set("Expires",new Date(r+1e3*i["max-age"]).toUTCString()),new Date(n.headers.get("Expires")).getTime()-rDate.now()&&!r["no-cache"]}var De,ze=1/0;function je(e){++ze>Me&&(e.getActor().send("enforceCacheSizeLimit",Te),ze=0)}function Fe(e){Ee(),ye&&ye.then((function(t){t.keys().then((function(r){for(var n=0;n=200&&r.status<300||0===r.status)&&null!==r.response){var n=r.response;if("json"===e.type)try{n=JSON.parse(r.response)}catch(i){return t(i)}t(null,n,r.getResponseHeader("Cache-Control"),r.getResponseHeader("Expires"))}else t(new He(r.statusText,r.status,e.url))},r.send(e.body),{cancel:function(){return r.abort()}}}var Ye=function(e,t){if(!We(e.url)){if(s.fetch&&s.Request&&s.AbortController&&s.Request.prototype.hasOwnProperty("signal"))return qe(e,t);if(z()&&self.worker&&self.worker.actor){var r=!0;return self.worker.actor.send("getResource",e,t,void 0,r)}}return Ge(e,t)},Xe=function(e,t){return Ye(v(e,{type:"json"}),t)},Ze=function(e,t){return Ye(v(e,{type:"arrayBuffer"}),t)},Ke=function(e,t){return Ye(v(e,{method:"POST"}),t)};function Je(e){var t=s.document.createElement("a");return t.href=e,t.protocol===s.document.location.protocol&&t.host===s.document.location.host}var Qe,et,tt="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAC0lEQVQYV2NgAAIAAAUAAarVyFEAAAAASUVORK5CYII=";function rt(e,t,r,n){var i=new s.Image,o=s.URL;i.onload=function(){t(null,i),o.revokeObjectURL(i.src),i.onload=null,s.requestAnimationFrame((function(){i.src=tt}))},i.onerror=function(){return t(new Error("Could not load image. Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported."))};var a=new s.Blob([new Uint8Array(e)],{type:"image/png"});i.cacheControl=r,i.expires=n,i.src=e.byteLength?o.createObjectURL(a):tt}function nt(e,t){var r=new s.Blob([new Uint8Array(e)],{type:"image/png"});s.createImageBitmap(r).then((function(e){t(null,e)})).catch((function(e){t(new Error("Could not load image because of "+e.message+". Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported."))}))}Qe=[],et=0;var it=function(e,t){if(J.supported&&(e.headers||(e.headers={}),e.headers.accept="image/webp,*/*"),et>=K.MAX_PARALLEL_IMAGE_REQUESTS){var r={requestParameters:e,callback:t,cancelled:!1,cancel:function(){this.cancelled=!0}};return Qe.push(r),r}et++;var n=!1,i=function(){if(!n)for(n=!0,et--;Qe.length&&et0||this._oneTimeListeners&&this._oneTimeListeners[e]&&this._oneTimeListeners[e].length>0||this._eventedParent&&this._eventedParent.listens(e)},ut.prototype.setEventedParent=function(e,t){return this._eventedParent=e,this._eventedParentData=t,this};var dt={$version:8,$root:{version:{required:!0,type:"enum",values:[8]},name:{type:"string"},metadata:{type:"*"},center:{type:"array",value:"number"},zoom:{type:"number"},bearing:{type:"number",default:0,period:360,units:"degrees"},pitch:{type:"number",default:0,units:"degrees"},light:{type:"light"},sources:{required:!0,type:"sources"},sprite:{type:"string"},glyphs:{type:"string"},transition:{type:"transition"},layers:{required:!0,type:"array",value:"layer"}},sources:{"*":{type:"source"}},source:["source_vector","source_raster","source_raster_dem","source_geojson","source_video","source_image"],source_vector:{type:{required:!0,type:"enum",values:{vector:{}}},url:{type:"string"},tiles:{type:"array",value:"string"},bounds:{type:"array",value:"number",length:4,default:[-180,-85.051129,180,85.051129]},scheme:{type:"enum",values:{xyz:{},tms:{}},default:"xyz"},minzoom:{type:"number",default:0},maxzoom:{type:"number",default:22},attribution:{type:"string"},promoteId:{type:"promoteId"},volatile:{type:"boolean",default:!1},"*":{type:"*"}},source_raster:{type:{required:!0,type:"enum",values:{raster:{}}},url:{type:"string"},tiles:{type:"array",value:"string"},bounds:{type:"array",value:"number",length:4,default:[-180,-85.051129,180,85.051129]},minzoom:{type:"number",default:0},maxzoom:{type:"number",default:22},tileSize:{type:"number",default:512,units:"pixels"},scheme:{type:"enum",values:{xyz:{},tms:{}},default:"xyz"},attribution:{type:"string"},volatile:{type:"boolean",default:!1},"*":{type:"*"}},source_raster_dem:{type:{required:!0,type:"enum",values:{"raster-dem":{}}},url:{type:"string"},tiles:{type:"array",value:"string"},bounds:{type:"array",value:"number",length:4,default:[-180,-85.051129,180,85.051129]},minzoom:{type:"number",default:0},maxzoom:{type:"number",default:22},tileSize:{type:"number",default:512,units:"pixels"},attribution:{type:"string"},encoding:{type:"enum",values:{terrarium:{},mapbox:{}},default:"mapbox"},volatile:{type:"boolean",default:!1},"*":{type:"*"}},source_geojson:{type:{required:!0,type:"enum",values:{geojson:{}}},data:{type:"*"},maxzoom:{type:"number",default:18},attribution:{type:"string"},buffer:{type:"number",default:128,maximum:512,minimum:0},filter:{type:"*"},tolerance:{type:"number",default:.375},cluster:{type:"boolean",default:!1},clusterRadius:{type:"number",default:50,minimum:0},clusterMaxZoom:{type:"number"},clusterMinPoints:{type:"number"},clusterProperties:{type:"*"},lineMetrics:{type:"boolean",default:!1},generateId:{type:"boolean",default:!1},promoteId:{type:"promoteId"}},source_video:{type:{required:!0,type:"enum",values:{video:{}}},urls:{required:!0,type:"array",value:"string"},coordinates:{required:!0,type:"array",length:4,value:{type:"array",length:2,value:"number"}}},source_image:{type:{required:!0,type:"enum",values:{image:{}}},url:{required:!0,type:"string"},coordinates:{required:!0,type:"array",length:4,value:{type:"array",length:2,value:"number"}}},layer:{id:{type:"string",required:!0},type:{type:"enum",values:{fill:{},line:{},symbol:{},circle:{},heatmap:{},"fill-extrusion":{},raster:{},hillshade:{},background:{}},required:!0},metadata:{type:"*"},source:{type:"string"},"source-layer":{type:"string"},minzoom:{type:"number",minimum:0,maximum:24},maxzoom:{type:"number",minimum:0,maximum:24},filter:{type:"filter"},layout:{type:"layout"},paint:{type:"paint"}},layout:["layout_fill","layout_line","layout_circle","layout_heatmap","layout_fill-extrusion","layout_symbol","layout_raster","layout_hillshade","layout_background"],layout_background:{visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},layout_fill:{"fill-sort-key":{type:"number",expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},layout_circle:{"circle-sort-key":{type:"number",expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},layout_heatmap:{visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},"layout_fill-extrusion":{visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},layout_line:{"line-cap":{type:"enum",values:{butt:{},round:{},square:{}},default:"butt",expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"line-join":{type:"enum",values:{bevel:{},round:{},miter:{}},default:"miter",expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"line-miter-limit":{type:"number",default:2,requires:[{"line-join":"miter"}],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"line-round-limit":{type:"number",default:1.05,requires:[{"line-join":"round"}],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"line-sort-key":{type:"number",expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},layout_symbol:{"symbol-placement":{type:"enum",values:{point:{},line:{},"line-center":{}},default:"point",expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"symbol-spacing":{type:"number",default:250,minimum:1,units:"pixels",requires:[{"symbol-placement":"line"}],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"symbol-avoid-edges":{type:"boolean",default:!1,expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"symbol-sort-key":{type:"number",expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"symbol-z-order":{type:"enum",values:{auto:{},"viewport-y":{},source:{}},default:"auto",expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-allow-overlap":{type:"boolean",default:!1,requires:["icon-image"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-ignore-placement":{type:"boolean",default:!1,requires:["icon-image"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-optional":{type:"boolean",default:!1,requires:["icon-image","text-field"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-rotation-alignment":{type:"enum",values:{map:{},viewport:{},auto:{}},default:"auto",requires:["icon-image"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-size":{type:"number",default:1,minimum:0,units:"factor of the original icon size",requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-text-fit":{type:"enum",values:{none:{},width:{},height:{},both:{}},default:"none",requires:["icon-image","text-field"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-text-fit-padding":{type:"array",value:"number",length:4,default:[0,0,0,0],units:"pixels",requires:["icon-image","text-field",{"icon-text-fit":["both","width","height"]}],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"icon-image":{type:"resolvedImage",tokens:!0,expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-rotate":{type:"number",default:0,period:360,units:"degrees",requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-padding":{type:"number",default:2,minimum:0,units:"pixels",requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"icon-keep-upright":{type:"boolean",default:!1,requires:["icon-image",{"icon-rotation-alignment":"map"},{"symbol-placement":["line","line-center"]}],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-offset":{type:"array",value:"number",length:2,default:[0,0],requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-anchor":{type:"enum",values:{center:{},left:{},right:{},top:{},bottom:{},"top-left":{},"top-right":{},"bottom-left":{},"bottom-right":{}},default:"center",requires:["icon-image"],expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-pitch-alignment":{type:"enum",values:{map:{},viewport:{},auto:{}},default:"auto",requires:["icon-image"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-pitch-alignment":{type:"enum",values:{map:{},viewport:{},auto:{}},default:"auto",requires:["text-field"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-rotation-alignment":{type:"enum",values:{map:{},viewport:{},auto:{}},default:"auto",requires:["text-field"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-field":{type:"formatted",default:"",tokens:!0,expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-font":{type:"array",value:"string",default:["Open Sans Regular","Arial Unicode MS Regular"],requires:["text-field"],expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-size":{type:"number",default:16,minimum:0,units:"pixels",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-max-width":{type:"number",default:10,minimum:0,units:"ems",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-line-height":{type:"number",default:1.2,units:"ems",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"text-letter-spacing":{type:"number",default:0,units:"ems",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-justify":{type:"enum",values:{auto:{},left:{},center:{},right:{}},default:"center",requires:["text-field"],expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-radial-offset":{type:"number",units:"ems",default:0,requires:["text-field"],"property-type":"data-driven",expression:{interpolated:!0,parameters:["zoom","feature"]}},"text-variable-anchor":{type:"array",value:"enum",values:{center:{},left:{},right:{},top:{},bottom:{},"top-left":{},"top-right":{},"bottom-left":{},"bottom-right":{}},requires:["text-field",{"symbol-placement":["point"]}],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-anchor":{type:"enum",values:{center:{},left:{},right:{},top:{},bottom:{},"top-left":{},"top-right":{},"bottom-left":{},"bottom-right":{}},default:"center",requires:["text-field",{"!":"text-variable-anchor"}],expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-max-angle":{type:"number",default:45,units:"degrees",requires:["text-field",{"symbol-placement":["line","line-center"]}],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"text-writing-mode":{type:"array",value:"enum",values:{horizontal:{},vertical:{}},requires:["text-field",{"symbol-placement":["point"]}],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-rotate":{type:"number",default:0,period:360,units:"degrees",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-padding":{type:"number",default:2,minimum:0,units:"pixels",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"text-keep-upright":{type:"boolean",default:!0,requires:["text-field",{"text-rotation-alignment":"map"},{"symbol-placement":["line","line-center"]}],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-transform":{type:"enum",values:{none:{},uppercase:{},lowercase:{}},default:"none",requires:["text-field"],expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-offset":{type:"array",value:"number",units:"ems",length:2,default:[0,0],requires:["text-field",{"!":"text-radial-offset"}],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-allow-overlap":{type:"boolean",default:!1,requires:["text-field"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-ignore-placement":{type:"boolean",default:!1,requires:["text-field"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-optional":{type:"boolean",default:!1,requires:["text-field","icon-image"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},layout_raster:{visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},layout_hillshade:{visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},filter:{type:"array",value:"*"},filter_operator:{type:"enum",values:{"==":{},"!=":{},">":{},">=":{},"<":{},"<=":{},in:{},"!in":{},all:{},any:{},none:{},has:{},"!has":{},within:{}}},geometry_type:{type:"enum",values:{Point:{},LineString:{},Polygon:{}}},function:{expression:{type:"expression"},stops:{type:"array",value:"function_stop"},base:{type:"number",default:1,minimum:0},property:{type:"string",default:"$zoom"},type:{type:"enum",values:{identity:{},exponential:{},interval:{},categorical:{}},default:"exponential"},colorSpace:{type:"enum",values:{rgb:{},lab:{},hcl:{}},default:"rgb"},default:{type:"*",required:!1}},function_stop:{type:"array",minimum:0,maximum:24,value:["number","color"],length:2},expression:{type:"array",value:"*",minimum:1},light:{anchor:{type:"enum",default:"viewport",values:{map:{},viewport:{}},"property-type":"data-constant",transition:!1,expression:{interpolated:!1,parameters:["zoom"]}},position:{type:"array",default:[1.15,210,30],length:3,value:"number","property-type":"data-constant",transition:!0,expression:{interpolated:!0,parameters:["zoom"]}},color:{type:"color","property-type":"data-constant",default:"#ffffff",expression:{interpolated:!0,parameters:["zoom"]},transition:!0},intensity:{type:"number","property-type":"data-constant",default:.5,minimum:0,maximum:1,expression:{interpolated:!0,parameters:["zoom"]},transition:!0}},paint:["paint_fill","paint_line","paint_circle","paint_heatmap","paint_fill-extrusion","paint_symbol","paint_raster","paint_hillshade","paint_background"],paint_fill:{"fill-antialias":{type:"boolean",default:!0,expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"fill-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-color":{type:"color",default:"#000000",transition:!0,requires:[{"!":"fill-pattern"}],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-outline-color":{type:"color",transition:!0,requires:[{"!":"fill-pattern"},{"fill-antialias":!0}],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"fill-translate-anchor":{type:"enum",values:{map:{},viewport:{}},default:"map",requires:["fill-translate"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"fill-pattern":{type:"resolvedImage",transition:!0,expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"cross-faded-data-driven"}},"paint_fill-extrusion":{"fill-extrusion-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"fill-extrusion-color":{type:"color",default:"#000000",transition:!0,requires:[{"!":"fill-extrusion-pattern"}],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"fill-extrusion-translate-anchor":{type:"enum",values:{map:{},viewport:{}},default:"map",requires:["fill-extrusion-translate"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"fill-extrusion-pattern":{type:"resolvedImage",transition:!0,expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"cross-faded-data-driven"},"fill-extrusion-height":{type:"number",default:0,minimum:0,units:"meters",transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-base":{type:"number",default:0,minimum:0,units:"meters",transition:!0,requires:["fill-extrusion-height"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-vertical-gradient":{type:"boolean",default:!0,transition:!1,expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"}},paint_line:{"line-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-color":{type:"color",default:"#000000",transition:!0,requires:[{"!":"line-pattern"}],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"line-translate-anchor":{type:"enum",values:{map:{},viewport:{}},default:"map",requires:["line-translate"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"line-width":{type:"number",default:1,minimum:0,transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-gap-width":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-offset":{type:"number",default:0,transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-blur":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-dasharray":{type:"array",value:"number",minimum:0,transition:!0,units:"line widths",requires:[{"!":"line-pattern"}],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"cross-faded"},"line-pattern":{type:"resolvedImage",transition:!0,expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"cross-faded-data-driven"},"line-gradient":{type:"color",transition:!1,requires:[{"!":"line-dasharray"},{"!":"line-pattern"},{source:"geojson",has:{lineMetrics:!0}}],expression:{interpolated:!0,parameters:["line-progress"]},"property-type":"color-ramp"}},paint_circle:{"circle-radius":{type:"number",default:5,minimum:0,transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-color":{type:"color",default:"#000000",transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-blur":{type:"number",default:0,transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"circle-translate-anchor":{type:"enum",values:{map:{},viewport:{}},default:"map",requires:["circle-translate"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"circle-pitch-scale":{type:"enum",values:{map:{},viewport:{}},default:"map",expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"circle-pitch-alignment":{type:"enum",values:{map:{},viewport:{}},default:"viewport",expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"circle-stroke-width":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-stroke-color":{type:"color",default:"#000000",transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-stroke-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"}},paint_heatmap:{"heatmap-radius":{type:"number",default:30,minimum:1,transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"heatmap-weight":{type:"number",default:1,minimum:0,transition:!1,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"heatmap-intensity":{type:"number",default:1,minimum:0,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"heatmap-color":{type:"color",default:["interpolate",["linear"],["heatmap-density"],0,"rgba(0, 0, 255, 0)",.1,"royalblue",.3,"cyan",.5,"lime",.7,"yellow",1,"red"],transition:!1,expression:{interpolated:!0,parameters:["heatmap-density"]},"property-type":"color-ramp"},"heatmap-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_symbol:{"icon-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-color":{type:"color",default:"#000000",transition:!0,requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-color":{type:"color",default:"rgba(0, 0, 0, 0)",transition:!0,requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-width":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-blur":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"icon-translate-anchor":{type:"enum",values:{map:{},viewport:{}},default:"map",requires:["icon-image","icon-translate"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-color":{type:"color",default:"#000000",transition:!0,overridable:!0,requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-color":{type:"color",default:"rgba(0, 0, 0, 0)",transition:!0,requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-width":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-blur":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"text-translate-anchor":{type:"enum",values:{map:{},viewport:{}},default:"map",requires:["text-field","text-translate"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"}},paint_raster:{"raster-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-hue-rotate":{type:"number",default:0,period:360,transition:!0,units:"degrees",expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-brightness-min":{type:"number",default:0,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-brightness-max":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-saturation":{type:"number",default:0,minimum:-1,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-contrast":{type:"number",default:0,minimum:-1,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-resampling":{type:"enum",values:{linear:{},nearest:{}},default:"linear",expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"raster-fade-duration":{type:"number",default:300,minimum:0,transition:!1,units:"milliseconds",expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_hillshade:{"hillshade-illumination-direction":{type:"number",default:335,minimum:0,maximum:359,transition:!1,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-illumination-anchor":{type:"enum",values:{map:{},viewport:{}},default:"viewport",expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-exaggeration":{type:"number",default:.5,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-shadow-color":{type:"color",default:"#000000",transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-highlight-color":{type:"color",default:"#FFFFFF",transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-accent-color":{type:"color",default:"#000000",transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_background:{"background-color":{type:"color",default:"#000000",transition:!0,requires:[{"!":"background-pattern"}],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"background-pattern":{type:"resolvedImage",transition:!0,expression:{interpolated:!1,parameters:["zoom"]},"property-type":"cross-faded"},"background-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},transition:{duration:{type:"number",default:300,minimum:0,units:"milliseconds"},delay:{type:"number",default:0,minimum:0,units:"milliseconds"}},"property-type":{"data-driven":{type:"property-type"},"cross-faded":{type:"property-type"},"cross-faded-data-driven":{type:"property-type"},"color-ramp":{type:"property-type"},"data-constant":{type:"property-type"},constant:{type:"property-type"}},promoteId:{"*":{type:"string"}}},ht=function(e,t,r,n){this.message=(e?e+": ":"")+r,n&&(this.identifier=n),null!==t&&void 0!==t&&t.__line__&&(this.line=t.__line__)};function pt(e){var t=e.key,r=e.value;return r?[new ht(t,r,"constants have been deprecated as of v8")]:[]}function ft(e){for(var t=[],r=arguments.length-1;r-- >0;)t[r]=arguments[r+1];for(var n=0,i=t;n":"value"===e.itemType.kind?"array":"array<"+t+">"}return e.kind}var Ot=[xt,bt,_t,wt,kt,Ct,St,It(At),Et];function Rt(e,t){if("error"===t.kind)return null;if("array"===e.kind){if("array"===t.kind&&(0===t.N&&"value"===t.itemType.kind||!Rt(e.itemType,t.itemType))&&("number"!==typeof e.N||e.N===t.N))return null}else{if(e.kind===t.kind)return null;if("value"===e.kind)for(var r=0,n=Ot;r255?255:e}function i(e){return e<0?0:e>1?1:e}function o(e){return"%"===e[e.length-1]?n(parseFloat(e)/100*255):n(parseInt(e))}function a(e){return"%"===e[e.length-1]?i(parseFloat(e)/100):i(parseFloat(e))}function s(e,t,r){return r<0?r+=1:r>1&&(r-=1),6*r<1?e+(t-e)*r*6:2*r<1?t:3*r<2?e+(t-e)*(2/3-r)*6:e}function l(e){var t,i=e.replace(/ /g,"").toLowerCase();if(i in r)return r[i].slice();if("#"===i[0])return 4===i.length?(t=parseInt(i.substr(1),16))>=0&&t<=4095?[(3840&t)>>4|(3840&t)>>8,240&t|(240&t)>>4,15&t|(15&t)<<4,1]:null:7===i.length&&(t=parseInt(i.substr(1),16))>=0&&t<=16777215?[(16711680&t)>>16,(65280&t)>>8,255&t,1]:null;var l=i.indexOf("("),c=i.indexOf(")");if(-1!==l&&c+1===i.length){var u=i.substr(0,l),d=i.substr(l+1,c-(l+1)).split(","),h=1;switch(u){case"rgba":if(4!==d.length)return null;h=a(d.pop());case"rgb":return 3!==d.length?null:[o(d[0]),o(d[1]),o(d[2]),h];case"hsla":if(4!==d.length)return null;h=a(d.pop());case"hsl":if(3!==d.length)return null;var p=(parseFloat(d[0])%360+360)%360/360,f=a(d[1]),m=a(d[2]),g=m<=.5?m*(f+1):m+f-m*f,y=2*m-g;return[n(255*s(y,g,p+1/3)),n(255*s(y,g,p)),n(255*s(y,g,p-1/3)),h];default:return null}}return null}try{t.parseCSSColor=l}catch(c){}})),jt=zt.parseCSSColor,Ft=function(e,t,r,n){void 0===n&&(n=1),this.r=e,this.g=t,this.b=r,this.a=n};Ft.parse=function(e){if(e){if(e instanceof Ft)return e;if("string"===typeof e){var t=jt(e);if(t)return new Ft(t[0]/255*t[3],t[1]/255*t[3],t[2]/255*t[3],t[3])}}},Ft.prototype.toString=function(){var e=this.toArray(),t=e[0],r=e[1],n=e[2],i=e[3];return"rgba("+Math.round(t)+","+Math.round(r)+","+Math.round(n)+","+i+")"},Ft.prototype.toArray=function(){var e=this,t=e.r,r=e.g,n=e.b,i=e.a;return 0===i?[0,0,0,0]:[255*t/i,255*r/i,255*n/i,i]},Ft.black=new Ft(0,0,0,1),Ft.white=new Ft(1,1,1,1),Ft.transparent=new Ft(0,0,0,0),Ft.red=new Ft(1,0,0,1);var Nt=function(e,t,r){this.sensitivity=e?t?"variant":"case":t?"accent":"base",this.locale=r,this.collator=new Intl.Collator(this.locale?this.locale:[],{sensitivity:this.sensitivity,usage:"search"})};Nt.prototype.compare=function(e,t){return this.collator.compare(e,t)},Nt.prototype.resolvedLocale=function(){return new Intl.Collator(this.locale?this.locale:[]).resolvedOptions().locale};var Bt=function(e,t,r,n,i){this.text=e,this.image=t,this.scale=r,this.fontStack=n,this.textColor=i},Vt=function(e){this.sections=e};Vt.fromString=function(e){return new Vt([new Bt(e,null,null,null,null)])},Vt.prototype.isEmpty=function(){return 0===this.sections.length||!this.sections.some((function(e){return 0!==e.text.length||e.image&&0!==e.image.name.length}))},Vt.factory=function(e){return e instanceof Vt?e:Vt.fromString(e)},Vt.prototype.toString=function(){return 0===this.sections.length?"":this.sections.map((function(e){return e.text})).join("")},Vt.prototype.serialize=function(){for(var e=["format"],t=0,r=this.sections;t=0&&e<=255&&"number"===typeof t&&t>=0&&t<=255&&"number"===typeof r&&r>=0&&r<=255?"undefined"===typeof n||"number"===typeof n&&n>=0&&n<=1?null:"Invalid rgba value ["+[e,t,r,n].join(", ")+"]: 'a' must be between 0 and 1.":"Invalid rgba value ["+("number"===typeof n?[e,t,r,n]:[e,t,r]).join(", ")+"]: 'r', 'g', and 'b' must be between 0 and 255."}function $t(e){if(null===e)return!0;if("string"===typeof e)return!0;if("boolean"===typeof e)return!0;if("number"===typeof e)return!0;if(e instanceof Ft)return!0;if(e instanceof Nt)return!0;if(e instanceof Vt)return!0;if(e instanceof Ut)return!0;if(Array.isArray(e)){for(var t=0,r=e;t2){var s=e[1];if("string"!==typeof s||!(s in Xt)||"object"===s)return t.error('The item type argument of "array" must be one of string, number, boolean',1);o=Xt[s],n++}else o=At;if(e.length>3){if(null!==e[2]&&("number"!==typeof e[2]||e[2]<0||e[2]!==Math.floor(e[2])))return t.error('The length argument to "array" must be a positive integer literal',2);a=e[2],n++}r=It(o,a)}else r=Xt[i];for(var l=[];n1)&&t.push(n)}}return t.concat(this.args.map((function(e){return e.serialize()})))};var Kt=function(e){this.type=Ct,this.sections=e};Kt.parse=function(e,t){if(e.length<2)return t.error("Expected at least one argument.");var r=e[1];if(!Array.isArray(r)&&"object"===typeof r)return t.error("First argument must be an image or text section.");for(var n=[],i=!1,o=1;o<=e.length-1;++o){var a=e[o];if(i&&"object"===typeof a&&!Array.isArray(a)){i=!1;var s=null;if(a["font-scale"]&&!(s=t.parse(a["font-scale"],1,bt)))return null;var l=null;if(a["text-font"]&&!(l=t.parse(a["text-font"],1,It(_t))))return null;var c=null;if(a["text-color"]&&!(c=t.parse(a["text-color"],1,kt)))return null;var u=n[n.length-1];u.scale=s,u.font=l,u.textColor=c}else{var d=t.parse(e[o],1,At);if(!d)return null;var h=d.type.kind;if("string"!==h&&"value"!==h&&"null"!==h&&"resolvedImage"!==h)return t.error("Formatted text type must be 'string', 'value', 'image' or 'null'.");i=!0,n.push({content:d,scale:null,font:null,textColor:null})}}return new Kt(n)},Kt.prototype.evaluate=function(e){var t=function(t){var r=t.content.evaluate(e);return Wt(r)===Et?new Bt("",r,null,null,null):new Bt(qt(r),null,t.scale?t.scale.evaluate(e):null,t.font?t.font.evaluate(e).join(","):null,t.textColor?t.textColor.evaluate(e):null)};return new Vt(this.sections.map(t))},Kt.prototype.eachChild=function(e){for(var t=0,r=this.sections;t-1),r},Jt.prototype.eachChild=function(e){e(this.input)},Jt.prototype.outputDefined=function(){return!1},Jt.prototype.serialize=function(){return["image",this.input.serialize()]};var Qt={"to-boolean":wt,"to-color":kt,"to-number":bt,"to-string":_t},er=function(e,t){this.type=e,this.args=t};er.parse=function(e,t){if(e.length<2)return t.error("Expected at least one argument.");var r=e[0];if(("to-boolean"===r||"to-string"===r)&&2!==e.length)return t.error("Expected one argument.");for(var n=Qt[r],i=[],o=1;o4?"Invalid rbga value "+JSON.stringify(t)+": expected an array containing either three or four numeric values.":Ht(t[0],t[1],t[2],t[3])))return new Ft(t[0]/255,t[1]/255,t[2]/255,t[3])}throw new Yt(r||"Could not parse color from value '"+("string"===typeof t?t:String(JSON.stringify(t)))+"'")}if("number"===this.type.kind){for(var a=null,s=0,l=this.args;s=t[2])&&!(e[1]<=t[1])&&!(e[3]>=t[3])}function dr(e,t){var r=lr(e[0]),n=cr(e[1]),i=Math.pow(2,t.z);return[Math.round(r*i*ar),Math.round(n*i*ar)]}function hr(e,t,r){var n=e[0]-t[0],i=e[1]-t[1],o=e[0]-r[0],a=e[1]-r[1];return n*a-o*i===0&&n*o<=0&&i*a<=0}function pr(e,t,r){return t[1]>e[1]!==r[1]>e[1]&&e[0]<(r[0]-t[0])*(e[1]-t[1])/(r[1]-t[1])+t[0]}function fr(e,t){for(var r=!1,n=0,i=t.length;n0&&d<0||u<0&&d>0}function vr(e,t,r,n){var i=[t[0]-e[0],t[1]-e[1]];return 0!==gr([n[0]-r[0],n[1]-r[1]],i)&&!(!yr(e,t,r,n)||!yr(r,n,e,t))}function xr(e,t,r){for(var n=0,i=r;nr[2]){var i=.5*n,o=e[0]-r[0]>i?-n:r[0]-e[0]>i?n:0;0===o&&(o=e[0]-r[2]>i?-n:r[2]-e[0]>i?n:0),e[0]+=o}sr(t,e)}function Ar(e){e[0]=e[1]=1/0,e[2]=e[3]=-1/0}function Tr(e,t,r,n){for(var i=Math.pow(2,n.z)*ar,o=[n.x*ar,n.y*ar],a=[],s=0,l=e;s=0)return!1;var r=!0;return e.eachChild((function(e){r&&!Rr(e,t)&&(r=!1)})),r}Ir.parse=function(e,t){if(2!==e.length)return t.error("'within' expression requires exactly one argument, but found "+(e.length-1)+" instead.");if($t(e[1])){var r=e[1];if("FeatureCollection"===r.type)for(var n=0;nt))throw new Yt("Input is not a number.");a=s-1}return 0}Dr.prototype.parse=function(e,t,r,n,i){return void 0===i&&(i={}),t?this.concat(t,r,n)._parse(e,i):this._parse(e,i)},Dr.prototype._parse=function(e,t){function r(e,t,r){return"assert"===r?new Zt(t,[e]):"coerce"===r?new er(t,[e]):e}if(null!==e&&"string"!==typeof e&&"boolean"!==typeof e&&"number"!==typeof e||(e=["literal",e]),Array.isArray(e)){if(0===e.length)return this.error('Expected an array with at least one element. If you wanted a literal array, use ["literal", []].');var n=e[0];if("string"!==typeof n)return this.error("Expression name must be a string, but found "+typeof n+' instead. If you wanted a literal array, use ["literal", [...]].',0),null;var i=this.registry[n];if(i){var o=i.parse(e,this);if(!o)return null;if(this.expectedType){var a=this.expectedType,s=o.type;if("string"!==a.kind&&"number"!==a.kind&&"boolean"!==a.kind&&"object"!==a.kind&&"array"!==a.kind||"value"!==s.kind)if("color"!==a.kind&&"formatted"!==a.kind&&"resolvedImage"!==a.kind||"value"!==s.kind&&"string"!==s.kind){if(this.checkSubtype(a,s))return null}else o=r(o,a,t.typeAnnotation||"coerce");else o=r(o,a,t.typeAnnotation||"assert")}if(!(o instanceof Gt)&&"resolvedImage"!==o.type.kind&&zr(o)){var l=new rr;try{o=new Gt(o.type,o.evaluate(l))}catch(c){return this.error(c.message),null}}return o}return this.error('Unknown expression "'+n+'". If you wanted a literal array, use ["literal", [...]].',0)}return"undefined"===typeof e?this.error("'undefined' value invalid. Use null instead."):"object"===typeof e?this.error('Bare objects invalid. Use ["literal", {...}] instead.'):this.error("Expected an array, but found "+typeof e+" instead.")},Dr.prototype.concat=function(e,t,r){var n="number"===typeof e?this.path.concat(e):this.path,i=r?this.scope.concat(r):this.scope;return new Dr(this.registry,n,t||null,i,this.errors)},Dr.prototype.error=function(e){for(var t=[],r=arguments.length-1;r-- >0;)t[r]=arguments[r+1];var n=""+this.key+t.map((function(e){return"["+e+"]"})).join("");this.errors.push(new yt(n,e))},Dr.prototype.checkSubtype=function(e,t){var r=Rt(e,t);return r&&this.error(r),r};var Fr=function(e,t,r){this.type=e,this.input=t,this.labels=[],this.outputs=[];for(var n=0,i=r;n=a)return t.error('Input/output pairs for "step" expressions must be arranged with input values in strictly ascending order.',l);var u=t.parse(s,c,i);if(!u)return null;i=i||u.type,n.push([a,u])}return new Fr(i,r,n)},Fr.prototype.evaluate=function(e){var t=this.labels,r=this.outputs;if(1===t.length)return r[0].evaluate(e);var n=this.input.evaluate(e);if(n<=t[0])return r[0].evaluate(e);var i=t.length;return n>=t[i-1]?r[i-1].evaluate(e):r[jr(t,n)].evaluate(e)},Fr.prototype.eachChild=function(e){e(this.input);for(var t=0,r=this.outputs;t0&&e.push(this.labels[t]),e.push(this.outputs[t].serialize());return e};var Ur=Object.freeze({__proto__:null,number:Nr,color:Br,array:Vr}),Hr=.95047,$r=1,Wr=1.08883,qr=4/29,Gr=6/29,Yr=3*Gr*Gr,Xr=Gr*Gr*Gr,Zr=Math.PI/180,Kr=180/Math.PI;function Jr(e){return e>Xr?Math.pow(e,1/3):e/Yr+qr}function Qr(e){return e>Gr?e*e*e:Yr*(e-qr)}function en(e){return 255*(e<=.0031308?12.92*e:1.055*Math.pow(e,1/2.4)-.055)}function tn(e){return(e/=255)<=.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)}function rn(e){var t=tn(e.r),r=tn(e.g),n=tn(e.b),i=Jr((.4124564*t+.3575761*r+.1804375*n)/Hr),o=Jr((.2126729*t+.7151522*r+.072175*n)/$r);return{l:116*o-16,a:500*(i-o),b:200*(o-Jr((.0193339*t+.119192*r+.9503041*n)/Wr)),alpha:e.a}}function nn(e){var t=(e.l+16)/116,r=isNaN(e.a)?t:t+e.a/500,n=isNaN(e.b)?t:t-e.b/200;return t=$r*Qr(t),r=Hr*Qr(r),n=Wr*Qr(n),new Ft(en(3.2404542*r-1.5371385*t-.4985314*n),en(-.969266*r+1.8760108*t+.041556*n),en(.0556434*r-.2040259*t+1.0572252*n),e.alpha)}function on(e,t,r){return{l:Nr(e.l,t.l,r),a:Nr(e.a,t.a,r),b:Nr(e.b,t.b,r),alpha:Nr(e.alpha,t.alpha,r)}}function an(e){var t=rn(e),r=t.l,n=t.a,i=t.b,o=Math.atan2(i,n)*Kr;return{h:o<0?o+360:o,c:Math.sqrt(n*n+i*i),l:r,alpha:e.a}}function sn(e){var t=e.h*Zr,r=e.c;return nn({l:e.l,a:Math.cos(t)*r,b:Math.sin(t)*r,alpha:e.alpha})}function ln(e,t,r){var n=t-e;return e+r*(n>180||n<-180?n-360*Math.round(n/360):n)}function cn(e,t,r){return{h:ln(e.h,t.h,r),c:Nr(e.c,t.c,r),l:Nr(e.l,t.l,r),alpha:Nr(e.alpha,t.alpha,r)}}var un={forward:rn,reverse:nn,interpolate:on},dn={forward:an,reverse:sn,interpolate:cn},hn=Object.freeze({__proto__:null,lab:un,hcl:dn}),pn=function(e,t,r,n,i){this.type=e,this.operator=t,this.interpolation=r,this.input=n,this.labels=[],this.outputs=[];for(var o=0,a=i;o1})))return t.error("Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.",1);n={name:"cubic-bezier",controlPoints:s}}if(e.length-1<4)return t.error("Expected at least 4 arguments, but found only "+(e.length-1)+".");if((e.length-1)%2!==0)return t.error("Expected an even number of arguments.");if(!(i=t.parse(i,2,bt)))return null;var l=[],c=null;"interpolate-hcl"===r||"interpolate-lab"===r?c=kt:t.expectedType&&"value"!==t.expectedType.kind&&(c=t.expectedType);for(var u=0;u=d)return t.error('Input/output pairs for "interpolate" expressions must be arranged with input values in strictly ascending order.',p);var m=t.parse(h,f,c);if(!m)return null;c=c||m.type,l.push([d,m])}return"number"===c.kind||"color"===c.kind||"array"===c.kind&&"number"===c.itemType.kind&&"number"===typeof c.N?new pn(c,r,n,i,l):t.error("Type "+Pt(c)+" is not interpolatable.")},pn.prototype.evaluate=function(e){var t=this.labels,r=this.outputs;if(1===t.length)return r[0].evaluate(e);var n=this.input.evaluate(e);if(n<=t[0])return r[0].evaluate(e);var i=t.length;if(n>=t[i-1])return r[i-1].evaluate(e);var o=jr(t,n),a=t[o],s=t[o+1],l=pn.interpolationFactor(this.interpolation,n,a,s),c=r[o].evaluate(e),u=r[o+1].evaluate(e);return"interpolate"===this.operator?Ur[this.type.kind.toLowerCase()](c,u,l):"interpolate-hcl"===this.operator?dn.reverse(dn.interpolate(dn.forward(c),dn.forward(u),l)):un.reverse(un.interpolate(un.forward(c),un.forward(u),l))},pn.prototype.eachChild=function(e){e(this.input);for(var t=0,r=this.outputs;t=r.length)throw new Yt("Array index out of bounds: "+t+" > "+(r.length-1)+".");if(t!==Math.floor(t))throw new Yt("Array index must be an integer, but found "+t+" instead.");return r[t]},yn.prototype.eachChild=function(e){e(this.index),e(this.input)},yn.prototype.outputDefined=function(){return!1},yn.prototype.serialize=function(){return["at",this.index.serialize(),this.input.serialize()]};var vn=function(e,t){this.type=wt,this.needle=e,this.haystack=t};vn.parse=function(e,t){if(3!==e.length)return t.error("Expected 2 arguments, but found "+(e.length-1)+" instead.");var r=t.parse(e[1],1,At),n=t.parse(e[2],2,At);return r&&n?Lt(r.type,[wt,_t,bt,xt,At])?new vn(r,n):t.error("Expected first argument to be of type boolean, string, number or null, but found "+Pt(r.type)+" instead"):null},vn.prototype.evaluate=function(e){var t=this.needle.evaluate(e),r=this.haystack.evaluate(e);if(!r)return!1;if(!Dt(t,["boolean","string","number","null"]))throw new Yt("Expected first argument to be of type boolean, string, number or null, but found "+Pt(Wt(t))+" instead.");if(!Dt(r,["string","array"]))throw new Yt("Expected second argument to be of type array or string, but found "+Pt(Wt(r))+" instead.");return r.indexOf(t)>=0},vn.prototype.eachChild=function(e){e(this.needle),e(this.haystack)},vn.prototype.outputDefined=function(){return!0},vn.prototype.serialize=function(){return["in",this.needle.serialize(),this.haystack.serialize()]};var xn=function(e,t,r){this.type=bt,this.needle=e,this.haystack=t,this.fromIndex=r};xn.parse=function(e,t){if(e.length<=2||e.length>=5)return t.error("Expected 3 or 4 arguments, but found "+(e.length-1)+" instead.");var r=t.parse(e[1],1,At),n=t.parse(e[2],2,At);if(!r||!n)return null;if(!Lt(r.type,[wt,_t,bt,xt,At]))return t.error("Expected first argument to be of type boolean, string, number or null, but found "+Pt(r.type)+" instead");if(4===e.length){var i=t.parse(e[3],3,bt);return i?new xn(r,n,i):null}return new xn(r,n)},xn.prototype.evaluate=function(e){var t=this.needle.evaluate(e),r=this.haystack.evaluate(e);if(!Dt(t,["boolean","string","number","null"]))throw new Yt("Expected first argument to be of type boolean, string, number or null, but found "+Pt(Wt(t))+" instead.");if(!Dt(r,["string","array"]))throw new Yt("Expected second argument to be of type array or string, but found "+Pt(Wt(r))+" instead.");if(this.fromIndex){var n=this.fromIndex.evaluate(e);return r.indexOf(t,n)}return r.indexOf(t)},xn.prototype.eachChild=function(e){e(this.needle),e(this.haystack),this.fromIndex&&e(this.fromIndex)},xn.prototype.outputDefined=function(){return!1},xn.prototype.serialize=function(){if(null!=this.fromIndex&&void 0!==this.fromIndex){var e=this.fromIndex.serialize();return["index-of",this.needle.serialize(),this.haystack.serialize(),e]}return["index-of",this.needle.serialize(),this.haystack.serialize()]};var bn=function(e,t,r,n,i,o){this.inputType=e,this.type=t,this.input=r,this.cases=n,this.outputs=i,this.otherwise=o};bn.parse=function(e,t){if(e.length<5)return t.error("Expected at least 4 arguments, but found only "+(e.length-1)+".");if(e.length%2!==1)return t.error("Expected an even number of arguments.");var r,n;t.expectedType&&"value"!==t.expectedType.kind&&(n=t.expectedType);for(var i={},o=[],a=2;aNumber.MAX_SAFE_INTEGER)return c.error("Branch labels must be integers no larger than "+Number.MAX_SAFE_INTEGER+".");if("number"===typeof h&&Math.floor(h)!==h)return c.error("Numeric branch labels must be integer values.");if(r){if(c.checkSubtype(r,Wt(h)))return null}else r=Wt(h);if("undefined"!==typeof i[String(h)])return c.error("Branch labels must be unique.");i[String(h)]=o.length}var p=t.parse(l,a,n);if(!p)return null;n=n||p.type,o.push(p)}var f=t.parse(e[1],1,At);if(!f)return null;var m=t.parse(e[e.length-1],e.length-1,n);return m?"value"!==f.type.kind&&t.concat(1).checkSubtype(r,f.type)?null:new bn(r,n,f,i,o,m):null},bn.prototype.evaluate=function(e){var t=this.input.evaluate(e);return(Wt(t)===this.inputType&&this.outputs[this.cases[t]]||this.otherwise).evaluate(e)},bn.prototype.eachChild=function(e){e(this.input),this.outputs.forEach(e),e(this.otherwise)},bn.prototype.outputDefined=function(){return this.outputs.every((function(e){return e.outputDefined()}))&&this.otherwise.outputDefined()},bn.prototype.serialize=function(){for(var e=this,t=["match",this.input.serialize()],r=[],n={},i=0,o=Object.keys(this.cases).sort();ir}function Cn(e,t,r){return t<=r}function En(e,t,r){return t>=r}function In(e,t,r,n){return 0===n.compare(t,r)}function Pn(e,t,r,n){return!In(e,t,r,n)}function On(e,t,r,n){return n.compare(t,r)<0}function Rn(e,t,r,n){return n.compare(t,r)>0}function Ln(e,t,r,n){return n.compare(t,r)<=0}function Dn(e,t,r,n){return n.compare(t,r)>=0}function zn(e,t,r){var n="=="!==e&&"!="!==e;return function(){function i(e,t,r){this.type=wt,this.lhs=e,this.rhs=t,this.collator=r,this.hasUntypedArgument="value"===e.type.kind||"value"===t.type.kind}return i.parse=function(e,t){if(3!==e.length&&4!==e.length)return t.error("Expected two or three arguments.");var r=e[0],o=t.parse(e[1],1,At);if(!o)return null;if(!kn(r,o.type))return t.concat(1).error('"'+r+"\" comparisons are not supported for type '"+Pt(o.type)+"'.");var a=t.parse(e[2],2,At);if(!a)return null;if(!kn(r,a.type))return t.concat(2).error('"'+r+"\" comparisons are not supported for type '"+Pt(a.type)+"'.");if(o.type.kind!==a.type.kind&&"value"!==o.type.kind&&"value"!==a.type.kind)return t.error("Cannot compare types '"+Pt(o.type)+"' and '"+Pt(a.type)+"'.");n&&("value"===o.type.kind&&"value"!==a.type.kind?o=new Zt(a.type,[o]):"value"!==o.type.kind&&"value"===a.type.kind&&(a=new Zt(o.type,[a])));var s=null;if(4===e.length){if("string"!==o.type.kind&&"string"!==a.type.kind&&"value"!==o.type.kind&&"value"!==a.type.kind)return t.error("Cannot use collator to compare non-string types.");if(!(s=t.parse(e[3],3,Mt)))return null}return new i(o,a,s)},i.prototype.evaluate=function(i){var o=this.lhs.evaluate(i),a=this.rhs.evaluate(i);if(n&&this.hasUntypedArgument){var s=Wt(o),l=Wt(a);if(s.kind!==l.kind||"string"!==s.kind&&"number"!==s.kind)throw new Yt('Expected arguments for "'+e+'" to be (string, string) or (number, number), but found ('+s.kind+", "+l.kind+") instead.")}if(this.collator&&!n&&this.hasUntypedArgument){var c=Wt(o),u=Wt(a);if("string"!==c.kind||"string"!==u.kind)return t(i,o,a)}return this.collator?r(i,o,a,this.collator.evaluate(i)):t(i,o,a)},i.prototype.eachChild=function(e){e(this.lhs),e(this.rhs),this.collator&&e(this.collator)},i.prototype.outputDefined=function(){return!0},i.prototype.serialize=function(){var t=[e];return this.eachChild((function(e){t.push(e.serialize())})),t},i}()}wn.parse=function(e,t){if(e.length<=2||e.length>=5)return t.error("Expected 3 or 4 arguments, but found "+(e.length-1)+" instead.");var r=t.parse(e[1],1,At),n=t.parse(e[2],2,bt);if(!r||!n)return null;if(!Lt(r.type,[It(At),_t,At]))return t.error("Expected first argument to be of type array or string, but found "+Pt(r.type)+" instead");if(4===e.length){var i=t.parse(e[3],3,bt);return i?new wn(r.type,r,n,i):null}return new wn(r.type,r,n)},wn.prototype.evaluate=function(e){var t=this.input.evaluate(e),r=this.beginIndex.evaluate(e);if(!Dt(t,["string","array"]))throw new Yt("Expected first argument to be of type array or string, but found "+Pt(Wt(t))+" instead.");if(this.endIndex){var n=this.endIndex.evaluate(e);return t.slice(r,n)}return t.slice(r)},wn.prototype.eachChild=function(e){e(this.input),e(this.beginIndex),this.endIndex&&e(this.endIndex)},wn.prototype.outputDefined=function(){return!1},wn.prototype.serialize=function(){if(null!=this.endIndex&&void 0!==this.endIndex){var e=this.endIndex.serialize();return["slice",this.input.serialize(),this.beginIndex.serialize(),e]}return["slice",this.input.serialize(),this.beginIndex.serialize()]};var jn=zn("==",Sn,In),Fn=zn("!=",An,Pn),Nn=zn("<",Tn,On),Bn=zn(">",Mn,Rn),Vn=zn("<=",Cn,Ln),Un=zn(">=",En,Dn),Hn=function(e,t,r,n,i){this.type=_t,this.number=e,this.locale=t,this.currency=r,this.minFractionDigits=n,this.maxFractionDigits=i};Hn.parse=function(e,t){if(3!==e.length)return t.error("Expected two arguments.");var r=t.parse(e[1],1,bt);if(!r)return null;var n=e[2];if("object"!==typeof n||Array.isArray(n))return t.error("NumberFormat options argument must be an object.");var i=null;if(n.locale&&!(i=t.parse(n.locale,1,_t)))return null;var o=null;if(n.currency&&!(o=t.parse(n.currency,1,_t)))return null;var a=null;if(n["min-fraction-digits"]&&!(a=t.parse(n["min-fraction-digits"],1,bt)))return null;var s=null;return n["max-fraction-digits"]&&!(s=t.parse(n["max-fraction-digits"],1,bt))?null:new Hn(r,i,o,a,s)},Hn.prototype.evaluate=function(e){return new Intl.NumberFormat(this.locale?this.locale.evaluate(e):[],{style:this.currency?"currency":"decimal",currency:this.currency?this.currency.evaluate(e):void 0,minimumFractionDigits:this.minFractionDigits?this.minFractionDigits.evaluate(e):void 0,maximumFractionDigits:this.maxFractionDigits?this.maxFractionDigits.evaluate(e):void 0}).format(this.number.evaluate(e))},Hn.prototype.eachChild=function(e){e(this.number),this.locale&&e(this.locale),this.currency&&e(this.currency),this.minFractionDigits&&e(this.minFractionDigits),this.maxFractionDigits&&e(this.maxFractionDigits)},Hn.prototype.outputDefined=function(){return!1},Hn.prototype.serialize=function(){var e={};return this.locale&&(e.locale=this.locale.serialize()),this.currency&&(e.currency=this.currency.serialize()),this.minFractionDigits&&(e["min-fraction-digits"]=this.minFractionDigits.serialize()),this.maxFractionDigits&&(e["max-fraction-digits"]=this.maxFractionDigits.serialize()),["number-format",this.number.serialize(),e]};var $n=function(e){this.type=bt,this.input=e};$n.parse=function(e,t){if(2!==e.length)return t.error("Expected 1 argument, but found "+(e.length-1)+" instead.");var r=t.parse(e[1],1);return r?"array"!==r.type.kind&&"string"!==r.type.kind&&"value"!==r.type.kind?t.error("Expected argument of type string or array, but found "+Pt(r.type)+" instead."):new $n(r):null},$n.prototype.evaluate=function(e){var t=this.input.evaluate(e);if("string"===typeof t)return t.length;if(Array.isArray(t))return t.length;throw new Yt("Expected value to be of type string or array, but found "+Pt(Wt(t))+" instead.")},$n.prototype.eachChild=function(e){e(this.input)},$n.prototype.outputDefined=function(){return!1},$n.prototype.serialize=function(){var e=["length"];return this.eachChild((function(t){e.push(t.serialize())})),e};var Wn={"==":jn,"!=":Fn,">":Bn,"<":Nn,">=":Un,"<=":Vn,array:Zt,at:yn,boolean:Zt,case:_n,coalesce:mn,collator:or,format:Kt,image:Jt,in:vn,"index-of":xn,interpolate:pn,"interpolate-hcl":pn,"interpolate-lab":pn,length:$n,let:gn,literal:Gt,match:bn,number:Zt,"number-format":Hn,object:Zt,slice:wn,step:Fr,string:Zt,"to-boolean":er,"to-color":er,"to-number":er,"to-string":er,var:Lr,within:Ir};function qn(e,t){var r=t[0],n=t[1],i=t[2],o=t[3];r=r.evaluate(e),n=n.evaluate(e),i=i.evaluate(e);var a=o?o.evaluate(e):1,s=Ht(r,n,i,a);if(s)throw new Yt(s);return new Ft(r/255*a,n/255*a,i/255*a,a)}function Gn(e,t){return e in t}function Yn(e,t){var r=t[e];return"undefined"===typeof r?null:r}function Xn(e,t,r,n){for(;r<=n;){var i=r+n>>1;if(t[i]===e)return!0;t[i]>e?n=i-1:r=i+1}return!1}function Zn(e){return{type:e}}function Kn(e){return{result:"success",value:e}}function Jn(e){return{result:"error",value:e}}function Qn(e){return"data-driven"===e["property-type"]||"cross-faded-data-driven"===e["property-type"]}function ei(e){return!!e.expression&&e.expression.parameters.indexOf("zoom")>-1}function ti(e){return!!e.expression&&e.expression.interpolated}function ri(e){return e instanceof Number?"number":e instanceof String?"string":e instanceof Boolean?"boolean":Array.isArray(e)?"array":null===e?"null":typeof e}function ni(e){return"object"===typeof e&&null!==e&&!Array.isArray(e)}function ii(e){return e}function oi(e,t){var r,n,i,o="color"===t.type,a=e.stops&&"object"===typeof e.stops[0][0],s=a||void 0!==e.property,l=a||!s,c=e.type||(ti(t)?"exponential":"interval");if(o&&((e=ft({},e)).stops&&(e.stops=e.stops.map((function(e){return[e[0],Ft.parse(e[1])]}))),e.default?e.default=Ft.parse(e.default):e.default=Ft.parse(t.default)),e.colorSpace&&"rgb"!==e.colorSpace&&!hn[e.colorSpace])throw new Error("Unknown color space: "+e.colorSpace);if("exponential"===c)r=ci;else if("interval"===c)r=li;else if("categorical"===c){r=si,n=Object.create(null);for(var u=0,d=e.stops;u=e.stops[n-1][0])return e.stops[n-1][1];var i=jr(e.stops.map((function(e){return e[0]})),r);return e.stops[i][1]}function ci(e,t,r){var n=void 0!==e.base?e.base:1;if("number"!==ri(r))return ai(e.default,t.default);var i=e.stops.length;if(1===i)return e.stops[0][1];if(r<=e.stops[0][0])return e.stops[0][1];if(r>=e.stops[i-1][0])return e.stops[i-1][1];var o=jr(e.stops.map((function(e){return e[0]})),r),a=di(r,n,e.stops[o][0],e.stops[o+1][0]),s=e.stops[o][1],l=e.stops[o+1][1],c=Ur[t.type]||ii;if(e.colorSpace&&"rgb"!==e.colorSpace){var u=hn[e.colorSpace];c=function(e,t){return u.reverse(u.interpolate(u.forward(e),u.forward(t),a))}}return"function"===typeof s.evaluate?{evaluate:function(){for(var e=[],t=arguments.length;t--;)e[t]=arguments[t];var r=s.evaluate.apply(void 0,e),n=l.evaluate.apply(void 0,e);if(void 0!==r&&void 0!==n)return c(r,n,a)}}:c(s,l,a)}function ui(e,t,r){return"color"===t.type?r=Ft.parse(r):"formatted"===t.type?r=Vt.fromString(r.toString()):"resolvedImage"===t.type?r=Ut.fromString(r.toString()):ri(r)===t.type||"enum"===t.type&&t.values[r]||(r=void 0),ai(r,e.default,t.default)}function di(e,t,r,n){var i=n-r,o=e-r;return 0===i?0:1===t?o/i:(Math.pow(t,o)-1)/(Math.pow(t,i)-1)}nr.register(Wn,{error:[Tt,[_t],function(e,t){var r=t[0];throw new Yt(r.evaluate(e))}],typeof:[_t,[At],function(e,t){return Pt(Wt(t[0].evaluate(e)))}],"to-rgba":[It(bt,4),[kt],function(e,t){return t[0].evaluate(e).toArray()}],rgb:[kt,[bt,bt,bt],qn],rgba:[kt,[bt,bt,bt,bt],qn],has:{type:wt,overloads:[[[_t],function(e,t){return Gn(t[0].evaluate(e),e.properties())}],[[_t,St],function(e,t){var r=t[0],n=t[1];return Gn(r.evaluate(e),n.evaluate(e))}]]},get:{type:At,overloads:[[[_t],function(e,t){return Yn(t[0].evaluate(e),e.properties())}],[[_t,St],function(e,t){var r=t[0],n=t[1];return Yn(r.evaluate(e),n.evaluate(e))}]]},"feature-state":[At,[_t],function(e,t){return Yn(t[0].evaluate(e),e.featureState||{})}],properties:[St,[],function(e){return e.properties()}],"geometry-type":[_t,[],function(e){return e.geometryType()}],id:[At,[],function(e){return e.id()}],zoom:[bt,[],function(e){return e.globals.zoom}],"heatmap-density":[bt,[],function(e){return e.globals.heatmapDensity||0}],"line-progress":[bt,[],function(e){return e.globals.lineProgress||0}],accumulated:[At,[],function(e){return void 0===e.globals.accumulated?null:e.globals.accumulated}],"+":[bt,Zn(bt),function(e,t){for(var r=0,n=0,i=t;n":[wt,[_t,At],function(e,t){var r=t[0],n=t[1],i=e.properties()[r.value],o=n.value;return typeof i===typeof o&&i>o}],"filter-id->":[wt,[At],function(e,t){var r=t[0],n=e.id(),i=r.value;return typeof n===typeof i&&n>i}],"filter-<=":[wt,[_t,At],function(e,t){var r=t[0],n=t[1],i=e.properties()[r.value],o=n.value;return typeof i===typeof o&&i<=o}],"filter-id-<=":[wt,[At],function(e,t){var r=t[0],n=e.id(),i=r.value;return typeof n===typeof i&&n<=i}],"filter->=":[wt,[_t,At],function(e,t){var r=t[0],n=t[1],i=e.properties()[r.value],o=n.value;return typeof i===typeof o&&i>=o}],"filter-id->=":[wt,[At],function(e,t){var r=t[0],n=e.id(),i=r.value;return typeof n===typeof i&&n>=i}],"filter-has":[wt,[At],function(e,t){return t[0].value in e.properties()}],"filter-has-id":[wt,[],function(e){return null!==e.id()&&void 0!==e.id()}],"filter-type-in":[wt,[It(_t)],function(e,t){return t[0].value.indexOf(e.geometryType())>=0}],"filter-id-in":[wt,[It(At)],function(e,t){return t[0].value.indexOf(e.id())>=0}],"filter-in-small":[wt,[_t,It(At)],function(e,t){var r=t[0];return t[1].value.indexOf(e.properties()[r.value])>=0}],"filter-in-large":[wt,[_t,It(At)],function(e,t){var r=t[0],n=t[1];return Xn(e.properties()[r.value],n.value,0,n.value.length-1)}],all:{type:wt,overloads:[[[wt,wt],function(e,t){var r=t[0],n=t[1];return r.evaluate(e)&&n.evaluate(e)}],[Zn(wt),function(e,t){for(var r=0,n=t;r0&&"string"===typeof e[0]&&e[0]in Wn}function fi(e,t){var r=new Dr(Wn,[],t?_i(t):void 0),n=r.parse(e,void 0,void 0,void 0,t&&"string"===t.type?{typeAnnotation:"coerce"}:void 0);return n?Kn(new hi(n,t)):Jn(r.errors)}hi.prototype.evaluateWithoutErrorHandling=function(e,t,r,n,i,o){return this._evaluator.globals=e,this._evaluator.feature=t,this._evaluator.featureState=r,this._evaluator.canonical=n,this._evaluator.availableImages=i||null,this._evaluator.formattedSection=o,this.expression.evaluate(this._evaluator)},hi.prototype.evaluate=function(e,t,r,n,i,o){this._evaluator.globals=e,this._evaluator.feature=t||null,this._evaluator.featureState=r||null,this._evaluator.canonical=n,this._evaluator.availableImages=i||null,this._evaluator.formattedSection=o||null;try{var a=this.expression.evaluate(this._evaluator);if(null===a||void 0===a||"number"===typeof a&&a!==a)return this._defaultValue;if(this._enumValues&&!(a in this._enumValues))throw new Yt("Expected value to be one of "+Object.keys(this._enumValues).map((function(e){return JSON.stringify(e)})).join(", ")+", but found "+JSON.stringify(a)+" instead.");return a}catch(s){return this._warningHistory[s.message]||(this._warningHistory[s.message]=!0,"undefined"!==typeof console&&console.warn(s.message)),this._defaultValue}};var mi=function(e,t){this.kind=e,this._styleExpression=t,this.isStateDependent="constant"!==e&&!Or(t.expression)};mi.prototype.evaluateWithoutErrorHandling=function(e,t,r,n,i,o){return this._styleExpression.evaluateWithoutErrorHandling(e,t,r,n,i,o)},mi.prototype.evaluate=function(e,t,r,n,i,o){return this._styleExpression.evaluate(e,t,r,n,i,o)};var gi=function(e,t,r,n){this.kind=e,this.zoomStops=r,this._styleExpression=t,this.isStateDependent="camera"!==e&&!Or(t.expression),this.interpolationType=n};function yi(e,t){if("error"===(e=fi(e,t)).result)return e;var r=e.value.expression,n=Pr(r);if(!n&&!Qn(t))return Jn([new yt("","data expressions not supported")]);var i=Rr(r,["zoom"]);if(!i&&!ei(t))return Jn([new yt("","zoom expressions not supported")]);var o=bi(r);if(!o&&!i)return Jn([new yt("",'"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.')]);if(o instanceof yt)return Jn([o]);if(o instanceof pn&&!ti(t))return Jn([new yt("",'"interpolate" expressions cannot be used with this property')]);if(!o)return Kn(new mi(n?"constant":"source",e.value));var a=o instanceof pn?o.interpolation:void 0;return Kn(new gi(n?"camera":"composite",e.value,o.labels,a))}gi.prototype.evaluateWithoutErrorHandling=function(e,t,r,n,i,o){return this._styleExpression.evaluateWithoutErrorHandling(e,t,r,n,i,o)},gi.prototype.evaluate=function(e,t,r,n,i,o){return this._styleExpression.evaluate(e,t,r,n,i,o)},gi.prototype.interpolationFactor=function(e,t,r){return this.interpolationType?pn.interpolationFactor(this.interpolationType,e,t,r):0};var vi=function(e,t){this._parameters=e,this._specification=t,ft(this,oi(this._parameters,this._specification))};function xi(e,t){if(ni(e))return new vi(e,t);if(pi(e)){var r=yi(e,t);if("error"===r.result)throw new Error(r.value.map((function(e){return e.key+": "+e.message})).join(", "));return r.value}var n=e;return"string"===typeof e&&"color"===t.type&&(n=Ft.parse(e)),{kind:"constant",evaluate:function(){return n}}}function bi(e){var t=null;if(e instanceof gn)t=bi(e.result);else if(e instanceof mn)for(var r=0,n=e.args;rn.maximum?[new ht(t,r,r+" is greater than the maximum value "+n.maximum)]:[]}function Ti(e){var t,r,n,i=e.valueSpec,o=mt(e.value.type),a={},s="categorical"!==o&&void 0===e.value.property,l=!s,c="array"===ri(e.value.stops)&&"array"===ri(e.value.stops[0])&&"object"===ri(e.value.stops[0][0]),u=ki({key:e.key,value:e.value,valueSpec:e.styleSpec.function,style:e.style,styleSpec:e.styleSpec,objectElementValidators:{stops:d,default:f}});return"identity"===o&&s&&u.push(new ht(e.key,e.value,'missing required property "property"')),"identity"===o||e.value.stops||u.push(new ht(e.key,e.value,'missing required property "stops"')),"exponential"===o&&e.valueSpec.expression&&!ti(e.valueSpec)&&u.push(new ht(e.key,e.value,"exponential functions not supported")),e.styleSpec.$version>=8&&(l&&!Qn(e.valueSpec)?u.push(new ht(e.key,e.value,"property functions not supported")):s&&!ei(e.valueSpec)&&u.push(new ht(e.key,e.value,"zoom functions not supported"))),"categorical"!==o&&!c||void 0!==e.value.property||u.push(new ht(e.key,e.value,'"property" property is required')),u;function d(e){if("identity"===o)return[new ht(e.key,e.value,'identity function may not have a "stops" property')];var t=[],r=e.value;return t=t.concat(Si({key:e.key,value:r,valueSpec:e.valueSpec,style:e.style,styleSpec:e.styleSpec,arrayElementValidator:h})),"array"===ri(r)&&0===r.length&&t.push(new ht(e.key,r,"array must have at least one stop")),t}function h(e){var t=[],o=e.value,s=e.key;if("array"!==ri(o))return[new ht(s,o,"array expected, "+ri(o)+" found")];if(2!==o.length)return[new ht(s,o,"array length 2 expected, length "+o.length+" found")];if(c){if("object"!==ri(o[0]))return[new ht(s,o,"object expected, "+ri(o[0])+" found")];if(void 0===o[0].zoom)return[new ht(s,o,"object stop key must have zoom")];if(void 0===o[0].value)return[new ht(s,o,"object stop key must have value")];if(n&&n>mt(o[0].zoom))return[new ht(s,o[0].zoom,"stop zoom values must appear in ascending order")];mt(o[0].zoom)!==n&&(n=mt(o[0].zoom),r=void 0,a={}),t=t.concat(ki({key:s+"[0]",value:o[0],valueSpec:{zoom:{}},style:e.style,styleSpec:e.styleSpec,objectElementValidators:{zoom:Ai,value:p}}))}else t=t.concat(p({key:s+"[0]",value:o[0],valueSpec:{},style:e.style,styleSpec:e.styleSpec},o));return pi(gt(o[1]))?t.concat([new ht(s+"[1]",o[1],"expressions are not allowed in function stops.")]):t.concat(ro({key:s+"[1]",value:o[1],valueSpec:i,style:e.style,styleSpec:e.styleSpec}))}function p(e,n){var s=ri(e.value),l=mt(e.value),c=null!==e.value?e.value:n;if(t){if(s!==t)return[new ht(e.key,c,s+" stop domain type must match previous stop domain type "+t)]}else t=s;if("number"!==s&&"string"!==s&&"boolean"!==s)return[new ht(e.key,c,"stop domain value must be a number, string, or boolean")];if("number"!==s&&"categorical"!==o){var u="number expected, "+s+" found";return Qn(i)&&void 0===o&&(u+='\nIf you intended to use a categorical function, specify `"type": "categorical"`.'),[new ht(e.key,c,u)]}return"categorical"!==o||"number"!==s||isFinite(l)&&Math.floor(l)===l?"categorical"!==o&&"number"===s&&void 0!==r&&l=2&&"$id"!==e[1]&&"$type"!==e[1];case"in":return e.length>=3&&("string"!==typeof e[1]||Array.isArray(e[2]));case"!in":case"!has":case"none":return!1;case"==":case"!=":case">":case">=":case"<":case"<=":return 3!==e.length||Array.isArray(e[1])||Array.isArray(e[2]);case"any":case"all":for(var t=0,r=e.slice(1);tt?1:0}function Di(e){if(!Array.isArray(e))return!1;if("within"===e[0])return!0;for(var t=1;t"===t||"<="===t||">="===t?ji(e[1],e[2],t):"any"===t?Fi(e.slice(1)):"all"===t?["all"].concat(e.slice(1).map(zi)):"none"===t?["all"].concat(e.slice(1).map(zi).map(Vi)):"in"===t?Ni(e[1],e.slice(2)):"!in"===t?Vi(Ni(e[1],e.slice(2))):"has"===t?Bi(e[1]):"!has"===t?Vi(Bi(e[1])):"within"!==t||e}function ji(e,t,r){switch(e){case"$type":return["filter-type-"+r,t];case"$id":return["filter-id-"+r,t];default:return["filter-"+r,e,t]}}function Fi(e){return["any"].concat(e.map(zi))}function Ni(e,t){if(0===t.length)return!1;switch(e){case"$type":return["filter-type-in",["literal",t]];case"$id":return["filter-id-in",["literal",t]];default:return t.length>200&&!t.some((function(e){return typeof e!==typeof t[0]}))?["filter-in-large",e,["literal",t.sort(Li)]]:["filter-in-small",e,["literal",t]]}}function Bi(e){switch(e){case"$type":return!0;case"$id":return["filter-has-id"];default:return["filter-has",e]}}function Vi(e){return["!",e]}function Ui(e){return Pi(gt(e.value))?Mi(ft({},e,{expressionContext:"filter",valueSpec:{value:"boolean"}})):Hi(e)}function Hi(e){var t=e.value,r=e.key;if("array"!==ri(t))return[new ht(r,t,"array expected, "+ri(t)+" found")];var n,i=e.styleSpec,o=[];if(t.length<1)return[new ht(r,t,"filter array must have at least 1 element")];switch(o=o.concat(Ii({key:r+"[0]",value:t[0],valueSpec:i.filter_operator,style:e.style,styleSpec:e.styleSpec})),mt(t[0])){case"<":case"<=":case">":case">=":t.length>=2&&"$type"===mt(t[1])&&o.push(new ht(r,t,'"$type" cannot be use with operator "'+t[0]+'"'));case"==":case"!=":3!==t.length&&o.push(new ht(r,t,'filter array for operator "'+t[0]+'" must have 3 elements'));case"in":case"!in":t.length>=2&&"string"!==(n=ri(t[1]))&&o.push(new ht(r+"[1]",t[1],"string expected, "+n+" found"));for(var a=2;a=u[p+0]&&n>=u[p+1])?(a[h]=!0,o.push(c[h])):a[h]=!1}}},mo.prototype._forEachCell=function(e,t,r,n,i,o,a,s){for(var l=this._convertToCellCoord(e),c=this._convertToCellCoord(t),u=this._convertToCellCoord(r),d=this._convertToCellCoord(n),h=l;h<=u;h++)for(var p=c;p<=d;p++){var f=this.d*p+h;if((!s||s(this._convertFromCellCoord(h),this._convertFromCellCoord(p),this._convertFromCellCoord(h+1),this._convertFromCellCoord(p+1)))&&i.call(this,e,t,r,n,f,o,a,s))return}},mo.prototype._convertFromCellCoord=function(e){return(e-this.padding)/this.scale},mo.prototype._convertToCellCoord=function(e){return Math.max(0,Math.min(this.d-1,Math.floor(e*this.scale)+this.padding))},mo.prototype.toArrayBuffer=function(){if(this.arrayBuffer)return this.arrayBuffer;for(var e=this.cells,t=fo+this.cells.length+1+1,r=0,n=0;n=0)){var d=e[u];c[u]=vo[l].shallow.indexOf(u)>=0?d:ko(d,t)}e instanceof Error&&(c.message=e.message)}if(c.$name)throw new Error("$name property is reserved for worker serialization logic.");return"Object"!==l&&(c.$name=l),c}throw new Error("can't serialize object of type "+typeof e)}function So(e){if(null===e||void 0===e||"boolean"===typeof e||"number"===typeof e||"string"===typeof e||e instanceof Boolean||e instanceof Number||e instanceof String||e instanceof Date||e instanceof RegExp||_o(e)||wo(e)||ArrayBuffer.isView(e)||e instanceof go)return e;if(Array.isArray(e))return e.map(So);if("object"===typeof e){var t=e.$name||"Object",r=vo[t].klass;if(!r)throw new Error("can't deserialize unregistered class "+t);if(r.deserialize)return r.deserialize(e);for(var n=Object.create(r.prototype),i=0,o=Object.keys(e);i=0?s:So(s)}}return n}throw new Error("can't deserialize object of type "+typeof e)}var Ao=function(){this.first=!0};Ao.prototype.update=function(e,t){var r=Math.floor(e);return this.first?(this.first=!1,this.lastIntegerZoom=r,this.lastIntegerZoomTime=0,this.lastZoom=e,this.lastFloorZoom=r,!0):(this.lastFloorZoom>r?(this.lastIntegerZoom=r+1,this.lastIntegerZoomTime=t):this.lastFloorZoom=128&&e<=255},Arabic:function(e){return e>=1536&&e<=1791},"Arabic Supplement":function(e){return e>=1872&&e<=1919},"Arabic Extended-A":function(e){return e>=2208&&e<=2303},"Hangul Jamo":function(e){return e>=4352&&e<=4607},"Unified Canadian Aboriginal Syllabics":function(e){return e>=5120&&e<=5759},Khmer:function(e){return e>=6016&&e<=6143},"Unified Canadian Aboriginal Syllabics Extended":function(e){return e>=6320&&e<=6399},"General Punctuation":function(e){return e>=8192&&e<=8303},"Letterlike Symbols":function(e){return e>=8448&&e<=8527},"Number Forms":function(e){return e>=8528&&e<=8591},"Miscellaneous Technical":function(e){return e>=8960&&e<=9215},"Control Pictures":function(e){return e>=9216&&e<=9279},"Optical Character Recognition":function(e){return e>=9280&&e<=9311},"Enclosed Alphanumerics":function(e){return e>=9312&&e<=9471},"Geometric Shapes":function(e){return e>=9632&&e<=9727},"Miscellaneous Symbols":function(e){return e>=9728&&e<=9983},"Miscellaneous Symbols and Arrows":function(e){return e>=11008&&e<=11263},"CJK Radicals Supplement":function(e){return e>=11904&&e<=12031},"Kangxi Radicals":function(e){return e>=12032&&e<=12255},"Ideographic Description Characters":function(e){return e>=12272&&e<=12287},"CJK Symbols and Punctuation":function(e){return e>=12288&&e<=12351},Hiragana:function(e){return e>=12352&&e<=12447},Katakana:function(e){return e>=12448&&e<=12543},Bopomofo:function(e){return e>=12544&&e<=12591},"Hangul Compatibility Jamo":function(e){return e>=12592&&e<=12687},Kanbun:function(e){return e>=12688&&e<=12703},"Bopomofo Extended":function(e){return e>=12704&&e<=12735},"CJK Strokes":function(e){return e>=12736&&e<=12783},"Katakana Phonetic Extensions":function(e){return e>=12784&&e<=12799},"Enclosed CJK Letters and Months":function(e){return e>=12800&&e<=13055},"CJK Compatibility":function(e){return e>=13056&&e<=13311},"CJK Unified Ideographs Extension A":function(e){return e>=13312&&e<=19903},"Yijing Hexagram Symbols":function(e){return e>=19904&&e<=19967},"CJK Unified Ideographs":function(e){return e>=19968&&e<=40959},"Yi Syllables":function(e){return e>=40960&&e<=42127},"Yi Radicals":function(e){return e>=42128&&e<=42191},"Hangul Jamo Extended-A":function(e){return e>=43360&&e<=43391},"Hangul Syllables":function(e){return e>=44032&&e<=55215},"Hangul Jamo Extended-B":function(e){return e>=55216&&e<=55295},"Private Use Area":function(e){return e>=57344&&e<=63743},"CJK Compatibility Ideographs":function(e){return e>=63744&&e<=64255},"Arabic Presentation Forms-A":function(e){return e>=64336&&e<=65023},"Vertical Forms":function(e){return e>=65040&&e<=65055},"CJK Compatibility Forms":function(e){return e>=65072&&e<=65103},"Small Form Variants":function(e){return e>=65104&&e<=65135},"Arabic Presentation Forms-B":function(e){return e>=65136&&e<=65279},"Halfwidth and Fullwidth Forms":function(e){return e>=65280&&e<=65519}};function Mo(e){for(var t=0,r=e;t=65097&&e<=65103)||!!To["CJK Compatibility Ideographs"](e)||!!To["CJK Compatibility"](e)||!!To["CJK Radicals Supplement"](e)||!!To["CJK Strokes"](e)||!(!To["CJK Symbols and Punctuation"](e)||e>=12296&&e<=12305||e>=12308&&e<=12319||12336===e)||!!To["CJK Unified Ideographs Extension A"](e)||!!To["CJK Unified Ideographs"](e)||!!To["Enclosed CJK Letters and Months"](e)||!!To["Hangul Compatibility Jamo"](e)||!!To["Hangul Jamo Extended-A"](e)||!!To["Hangul Jamo Extended-B"](e)||!!To["Hangul Jamo"](e)||!!To["Hangul Syllables"](e)||!!To.Hiragana(e)||!!To["Ideographic Description Characters"](e)||!!To.Kanbun(e)||!!To["Kangxi Radicals"](e)||!!To["Katakana Phonetic Extensions"](e)||!(!To.Katakana(e)||12540===e)||!(!To["Halfwidth and Fullwidth Forms"](e)||65288===e||65289===e||65293===e||e>=65306&&e<=65310||65339===e||65341===e||65343===e||e>=65371&&e<=65503||65507===e||e>=65512&&e<=65519)||!(!To["Small Form Variants"](e)||e>=65112&&e<=65118||e>=65123&&e<=65126)||!!To["Unified Canadian Aboriginal Syllabics"](e)||!!To["Unified Canadian Aboriginal Syllabics Extended"](e)||!!To["Vertical Forms"](e)||!!To["Yijing Hexagram Symbols"](e)||!!To["Yi Syllables"](e)||!!To["Yi Radicals"](e))}function Oo(e){return!(!To["Latin-1 Supplement"](e)||167!==e&&169!==e&&174!==e&&177!==e&&188!==e&&189!==e&&190!==e&&215!==e&&247!==e)||!(!To["General Punctuation"](e)||8214!==e&&8224!==e&&8225!==e&&8240!==e&&8241!==e&&8251!==e&&8252!==e&&8258!==e&&8263!==e&&8264!==e&&8265!==e&&8273!==e)||!!To["Letterlike Symbols"](e)||!!To["Number Forms"](e)||!(!To["Miscellaneous Technical"](e)||!(e>=8960&&e<=8967||e>=8972&&e<=8991||e>=8996&&e<=9e3||9003===e||e>=9085&&e<=9114||e>=9150&&e<=9165||9167===e||e>=9169&&e<=9179||e>=9186&&e<=9215))||!(!To["Control Pictures"](e)||9251===e)||!!To["Optical Character Recognition"](e)||!!To["Enclosed Alphanumerics"](e)||!!To["Geometric Shapes"](e)||!(!To["Miscellaneous Symbols"](e)||e>=9754&&e<=9759)||!(!To["Miscellaneous Symbols and Arrows"](e)||!(e>=11026&&e<=11055||e>=11088&&e<=11097||e>=11192&&e<=11243))||!!To["CJK Symbols and Punctuation"](e)||!!To.Katakana(e)||!!To["Private Use Area"](e)||!!To["CJK Compatibility Forms"](e)||!!To["Small Form Variants"](e)||!!To["Halfwidth and Fullwidth Forms"](e)||8734===e||8756===e||8757===e||e>=9984&&e<=10087||e>=10102&&e<=10131||65532===e||65533===e}function Ro(e){return!(Po(e)||Oo(e))}function Lo(e){return To.Arabic(e)||To["Arabic Supplement"](e)||To["Arabic Extended-A"](e)||To["Arabic Presentation Forms-A"](e)||To["Arabic Presentation Forms-B"](e)}function Do(e){return e>=1424&&e<=2303||To["Arabic Presentation Forms-A"](e)||To["Arabic Presentation Forms-B"](e)}function zo(e,t){return!(!t&&Do(e))&&!(e>=2304&&e<=3583||e>=3840&&e<=4255||To.Khmer(e))}function jo(e){for(var t=0,r=e;t-1&&(Vo=No.error),Bo&&Bo(e)};function $o(){Wo.fire(new lt("pluginStateChange",{pluginStatus:Vo,pluginURL:Uo}))}var Wo=new ut,qo=function(){return Vo},Go=function(e){return e({pluginStatus:Vo,pluginURL:Uo}),Wo.on("pluginStateChange",e),e},Yo=function(e,t,r){if(void 0===r&&(r=!1),Vo===No.deferred||Vo===No.loading||Vo===No.loaded)throw new Error("setRTLTextPlugin cannot be called multiple times.");Uo=Z.resolveURL(e),Vo=No.deferred,Bo=t,$o(),r||Xo()},Xo=function(){if(Vo!==No.deferred||!Uo)throw new Error("rtl-text-plugin cannot be downloaded unless a pluginURL is specified");Vo=No.loading,$o(),Uo&&Ze({url:Uo},(function(e){e?Ho(e):(Vo=No.loaded,$o())}))},Zo={applyArabicShaping:null,processBidirectionalText:null,processStyledBidirectionalText:null,isLoaded:function(){return Vo===No.loaded||null!=Zo.applyArabicShaping},isLoading:function(){return Vo===No.loading},setState:function(e){Vo=e.pluginStatus,Uo=e.pluginURL},isParsed:function(){return null!=Zo.applyArabicShaping&&null!=Zo.processBidirectionalText&&null!=Zo.processStyledBidirectionalText},getPluginURL:function(){return Uo}},Ko=function(){Zo.isLoading()||Zo.isLoaded()||"deferred"!==qo()||Xo()},Jo=function(e,t){this.zoom=e,t?(this.now=t.now,this.fadeDuration=t.fadeDuration,this.zoomHistory=t.zoomHistory,this.transition=t.transition):(this.now=0,this.fadeDuration=0,this.zoomHistory=new Ao,this.transition={})};Jo.prototype.isSupportedScript=function(e){return Fo(e,Zo.isLoaded())},Jo.prototype.crossFadingFactor=function(){return 0===this.fadeDuration?1:Math.min((this.now-this.zoomHistory.lastIntegerZoomTime)/this.fadeDuration,1)},Jo.prototype.getCrossfadeParameters=function(){var e=this.zoom,t=e-Math.floor(e),r=this.crossFadingFactor();return e>this.zoomHistory.lastIntegerZoom?{fromScale:2,toScale:1,t:t+(1-t)*r}:{fromScale:.5,toScale:1,t:1-(1-r)*t}};var Qo=function(e,t){this.property=e,this.value=t,this.expression=xi(void 0===t?e.specification.default:t,e.specification)};Qo.prototype.isDataDriven=function(){return"source"===this.expression.kind||"composite"===this.expression.kind},Qo.prototype.possiblyEvaluate=function(e,t,r){return this.property.possiblyEvaluate(this,e,t,r)};var ea=function(e){this.property=e,this.value=new Qo(e,void 0)};ea.prototype.transitioned=function(e,t){return new ra(this.property,this.value,t,v({},e.transition,this.transition),e.now)},ea.prototype.untransitioned=function(){return new ra(this.property,this.value,null,{},0)};var ta=function(e){this._properties=e,this._values=Object.create(e.defaultTransitionablePropertyValues)};ta.prototype.getValue=function(e){return E(this._values[e].value.value)},ta.prototype.setValue=function(e,t){this._values.hasOwnProperty(e)||(this._values[e]=new ea(this._values[e].property)),this._values[e].value=new Qo(this._values[e].property,null===t?void 0:E(t))},ta.prototype.getTransition=function(e){return E(this._values[e].transition)},ta.prototype.setTransition=function(e,t){this._values.hasOwnProperty(e)||(this._values[e]=new ea(this._values[e].property)),this._values[e].transition=E(t)||void 0},ta.prototype.serialize=function(){for(var e={},t=0,r=Object.keys(this._values);tthis.end)return this.prior=null,i;if(this.value.isDataDriven())return this.prior=null,i;if(nn.zoomHistory.lastIntegerZoom?{from:e,to:t}:{from:r,to:t}},t.prototype.interpolate=function(e){return e},t}(la),ua=function(e){this.specification=e};ua.prototype.possiblyEvaluate=function(e,t,r,n){if(void 0!==e.value){if("constant"===e.expression.kind){var i=e.expression.evaluate(t,null,{},r,n);return this._calculate(i,i,i,t)}return this._calculate(e.expression.evaluate(new Jo(Math.floor(t.zoom-1),t)),e.expression.evaluate(new Jo(Math.floor(t.zoom),t)),e.expression.evaluate(new Jo(Math.floor(t.zoom+1),t)),t)}},ua.prototype._calculate=function(e,t,r,n){return n.zoom>n.zoomHistory.lastIntegerZoom?{from:e,to:t}:{from:r,to:t}},ua.prototype.interpolate=function(e){return e};var da=function(e){this.specification=e};da.prototype.possiblyEvaluate=function(e,t,r,n){return!!e.expression.evaluate(t,null,{},r,n)},da.prototype.interpolate=function(){return!1};var ha=function(e){for(var t in this.properties=e,this.defaultPropertyValues={},this.defaultTransitionablePropertyValues={},this.defaultTransitioningPropertyValues={},this.defaultPossiblyEvaluatedValues={},this.overridableProperties=[],e){var r=e[t];r.specification.overridable&&this.overridableProperties.push(t);var n=this.defaultPropertyValues[t]=new Qo(r,void 0),i=this.defaultTransitionablePropertyValues[t]=new ea(r);this.defaultTransitioningPropertyValues[t]=i.untransitioned(),this.defaultPossiblyEvaluatedValues[t]=n.possiblyEvaluate({})}};xo("DataDrivenProperty",la),xo("DataConstantProperty",sa),xo("CrossFadedDataDrivenProperty",ca),xo("CrossFadedProperty",ua),xo("ColorRampProperty",da);var pa="-transition",fa=function(e){function t(t,r){if(e.call(this),this.id=t.id,this.type=t.type,this._featureFilter={filter:function(){return!0},needGeometry:!1},"custom"!==t.type&&(this.metadata=t.metadata,this.minzoom=t.minzoom,this.maxzoom=t.maxzoom,"background"!==t.type&&(this.source=t.source,this.sourceLayer=t["source-layer"],this.filter=t.filter),r.layout&&(this._unevaluatedLayout=new ia(r.layout)),r.paint)){for(var n in this._transitionablePaint=new ta(r.paint),t.paint)this.setPaintProperty(n,t.paint[n],{validate:!1});for(var i in t.layout)this.setLayoutProperty(i,t.layout[i],{validate:!1});this._transitioningPaint=this._transitionablePaint.untransitioned(),this.paint=new aa(r.paint)}}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.getCrossfadeParameters=function(){return this._crossfadeParameters},t.prototype.getLayoutProperty=function(e){return"visibility"===e?this.visibility:this._unevaluatedLayout.getValue(e)},t.prototype.setLayoutProperty=function(e,t,r){if(void 0===r&&(r={}),null!==t&&void 0!==t){var n="layers."+this.id+".layout."+e;if(this._validate(uo,n,e,t,r))return}"visibility"!==e?this._unevaluatedLayout.setValue(e,t):this.visibility=t},t.prototype.getPaintProperty=function(e){return T(e,pa)?this._transitionablePaint.getTransition(e.slice(0,-pa.length)):this._transitionablePaint.getValue(e)},t.prototype.setPaintProperty=function(e,t,r){if(void 0===r&&(r={}),null!==t&&void 0!==t){var n="layers."+this.id+".paint."+e;if(this._validate(co,n,e,t,r))return!1}if(T(e,pa))return this._transitionablePaint.setTransition(e.slice(0,-pa.length),t||void 0),!1;var i=this._transitionablePaint._values[e],o="cross-faded-data-driven"===i.property.specification["property-type"],a=i.value.isDataDriven(),s=i.value;this._transitionablePaint.setValue(e,t),this._handleSpecialPaintPropertyUpdate(e);var l=this._transitionablePaint._values[e].value;return l.isDataDriven()||a||o||this._handleOverridablePaintPropertyUpdate(e,s,l)},t.prototype._handleSpecialPaintPropertyUpdate=function(e){},t.prototype._handleOverridablePaintPropertyUpdate=function(e,t,r){return!1},t.prototype.isHidden=function(e){return!!(this.minzoom&&e=this.maxzoom)||"none"===this.visibility},t.prototype.updateTransitions=function(e){this._transitioningPaint=this._transitionablePaint.transitioned(e,this._transitioningPaint)},t.prototype.hasTransition=function(){return this._transitioningPaint.hasTransition()},t.prototype.recalculate=function(e,t){e.getCrossfadeParameters&&(this._crossfadeParameters=e.getCrossfadeParameters()),this._unevaluatedLayout&&(this.layout=this._unevaluatedLayout.possiblyEvaluate(e,void 0,t)),this.paint=this._transitioningPaint.possiblyEvaluate(e,void 0,t)},t.prototype.serialize=function(){var e={id:this.id,type:this.type,source:this.source,"source-layer":this.sourceLayer,metadata:this.metadata,minzoom:this.minzoom,maxzoom:this.maxzoom,filter:this.filter,layout:this._unevaluatedLayout&&this._unevaluatedLayout.serialize(),paint:this._transitionablePaint&&this._transitionablePaint.serialize()};return this.visibility&&(e.layout=e.layout||{},e.layout.visibility=this.visibility),C(e,(function(e,t){return void 0!==e&&!("layout"===t&&!Object.keys(e).length)&&!("paint"===t&&!Object.keys(e).length)}))},t.prototype._validate=function(e,t,r,n,i){return void 0===i&&(i={}),(!i||!1!==i.validate)&&ho(this,e.call(so,{key:t,layerType:this.type,objectKey:r,value:n,styleSpec:dt,style:{glyphs:!0,sprite:!0}}))},t.prototype.is3D=function(){return!1},t.prototype.isTileClipped=function(){return!1},t.prototype.hasOffscreenPass=function(){return!1},t.prototype.resize=function(){},t.prototype.isStateDependent=function(){for(var e in this.paint._values){var t=this.paint.get(e);if(t instanceof oa&&Qn(t.property.specification)&&("source"===t.value.kind||"composite"===t.value.kind)&&t.value.isStateDependent)return!0}return!1},t}(ut),ma={Int8:Int8Array,Uint8:Uint8Array,Int16:Int16Array,Uint16:Uint16Array,Int32:Int32Array,Uint32:Uint32Array,Float32:Float32Array},ga=function(e,t){this._structArray=e,this._pos1=t*this.size,this._pos2=this._pos1/2,this._pos4=this._pos1/4,this._pos8=this._pos1/8},ya=128,va=5,xa=function(){this.isTransferred=!1,this.capacity=-1,this.resize(0)};function ba(e,t){void 0===t&&(t=1);var r=0,n=0;return{members:e.map((function(e){var i=_a(e.type),o=r=wa(r,Math.max(t,i)),a=e.components||1;return n=Math.max(n,i),r+=i*a,{name:e.name,type:e.type,components:a,offset:o}})),size:wa(r,Math.max(n,t)),alignment:t}}function _a(e){return ma[e].BYTES_PER_ELEMENT}function wa(e,t){return Math.ceil(e/t)*t}xa.serialize=function(e,t){return e._trim(),t&&(e.isTransferred=!0,t.push(e.arrayBuffer)),{length:e.length,arrayBuffer:e.arrayBuffer}},xa.deserialize=function(e){var t=Object.create(this.prototype);return t.arrayBuffer=e.arrayBuffer,t.length=e.length,t.capacity=e.arrayBuffer.byteLength/t.bytesPerElement,t._refreshViews(),t},xa.prototype._trim=function(){this.length!==this.capacity&&(this.capacity=this.length,this.arrayBuffer=this.arrayBuffer.slice(0,this.length*this.bytesPerElement),this._refreshViews())},xa.prototype.clear=function(){this.length=0},xa.prototype.resize=function(e){this.reserve(e),this.length=e},xa.prototype.reserve=function(e){if(e>this.capacity){this.capacity=Math.max(e,Math.floor(this.capacity*va),ya),this.arrayBuffer=new ArrayBuffer(this.capacity*this.bytesPerElement);var t=this.uint8;this._refreshViews(),t&&this.uint8.set(t)}},xa.prototype._refreshViews=function(){throw new Error("_refreshViews() must be implemented by each concrete StructArray layout")};var ka=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t){var r=this.length;return this.resize(r+1),this.emplace(r,e,t)},t.prototype.emplace=function(e,t,r){var n=2*e;return this.int16[n+0]=t,this.int16[n+1]=r,e},t}(xa);ka.prototype.bytesPerElement=4,xo("StructArrayLayout2i4",ka);var Sa=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r,n){var i=this.length;return this.resize(i+1),this.emplace(i,e,t,r,n)},t.prototype.emplace=function(e,t,r,n,i){var o=4*e;return this.int16[o+0]=t,this.int16[o+1]=r,this.int16[o+2]=n,this.int16[o+3]=i,e},t}(xa);Sa.prototype.bytesPerElement=8,xo("StructArrayLayout4i8",Sa);var Aa=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r,n,i,o){var a=this.length;return this.resize(a+1),this.emplace(a,e,t,r,n,i,o)},t.prototype.emplace=function(e,t,r,n,i,o,a){var s=6*e;return this.int16[s+0]=t,this.int16[s+1]=r,this.int16[s+2]=n,this.int16[s+3]=i,this.int16[s+4]=o,this.int16[s+5]=a,e},t}(xa);Aa.prototype.bytesPerElement=12,xo("StructArrayLayout2i4i12",Aa);var Ta=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r,n,i,o){var a=this.length;return this.resize(a+1),this.emplace(a,e,t,r,n,i,o)},t.prototype.emplace=function(e,t,r,n,i,o,a){var s=4*e,l=8*e;return this.int16[s+0]=t,this.int16[s+1]=r,this.uint8[l+4]=n,this.uint8[l+5]=i,this.uint8[l+6]=o,this.uint8[l+7]=a,e},t}(xa);Ta.prototype.bytesPerElement=8,xo("StructArrayLayout2i4ub8",Ta);var Ma=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t){var r=this.length;return this.resize(r+1),this.emplace(r,e,t)},t.prototype.emplace=function(e,t,r){var n=2*e;return this.float32[n+0]=t,this.float32[n+1]=r,e},t}(xa);Ma.prototype.bytesPerElement=8,xo("StructArrayLayout2f8",Ma);var Ca=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r,n,i,o,a,s,l,c){var u=this.length;return this.resize(u+1),this.emplace(u,e,t,r,n,i,o,a,s,l,c)},t.prototype.emplace=function(e,t,r,n,i,o,a,s,l,c,u){var d=10*e;return this.uint16[d+0]=t,this.uint16[d+1]=r,this.uint16[d+2]=n,this.uint16[d+3]=i,this.uint16[d+4]=o,this.uint16[d+5]=a,this.uint16[d+6]=s,this.uint16[d+7]=l,this.uint16[d+8]=c,this.uint16[d+9]=u,e},t}(xa);Ca.prototype.bytesPerElement=20,xo("StructArrayLayout10ui20",Ca);var Ea=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r,n,i,o,a,s,l,c,u,d){var h=this.length;return this.resize(h+1),this.emplace(h,e,t,r,n,i,o,a,s,l,c,u,d)},t.prototype.emplace=function(e,t,r,n,i,o,a,s,l,c,u,d,h){var p=12*e;return this.int16[p+0]=t,this.int16[p+1]=r,this.int16[p+2]=n,this.int16[p+3]=i,this.uint16[p+4]=o,this.uint16[p+5]=a,this.uint16[p+6]=s,this.uint16[p+7]=l,this.int16[p+8]=c,this.int16[p+9]=u,this.int16[p+10]=d,this.int16[p+11]=h,e},t}(xa);Ea.prototype.bytesPerElement=24,xo("StructArrayLayout4i4ui4i24",Ea);var Ia=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r){var n=this.length;return this.resize(n+1),this.emplace(n,e,t,r)},t.prototype.emplace=function(e,t,r,n){var i=3*e;return this.float32[i+0]=t,this.float32[i+1]=r,this.float32[i+2]=n,e},t}(xa);Ia.prototype.bytesPerElement=12,xo("StructArrayLayout3f12",Ia);var Pa=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.uint32=new Uint32Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e){var t=this.length;return this.resize(t+1),this.emplace(t,e)},t.prototype.emplace=function(e,t){var r=1*e;return this.uint32[r+0]=t,e},t}(xa);Pa.prototype.bytesPerElement=4,xo("StructArrayLayout1ul4",Pa);var Oa=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer),this.uint32=new Uint32Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r,n,i,o,a,s,l){var c=this.length;return this.resize(c+1),this.emplace(c,e,t,r,n,i,o,a,s,l)},t.prototype.emplace=function(e,t,r,n,i,o,a,s,l,c){var u=10*e,d=5*e;return this.int16[u+0]=t,this.int16[u+1]=r,this.int16[u+2]=n,this.int16[u+3]=i,this.int16[u+4]=o,this.int16[u+5]=a,this.uint32[d+3]=s,this.uint16[u+8]=l,this.uint16[u+9]=c,e},t}(xa);Oa.prototype.bytesPerElement=20,xo("StructArrayLayout6i1ul2ui20",Oa);var Ra=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r,n,i,o){var a=this.length;return this.resize(a+1),this.emplace(a,e,t,r,n,i,o)},t.prototype.emplace=function(e,t,r,n,i,o,a){var s=6*e;return this.int16[s+0]=t,this.int16[s+1]=r,this.int16[s+2]=n,this.int16[s+3]=i,this.int16[s+4]=o,this.int16[s+5]=a,e},t}(xa);Ra.prototype.bytesPerElement=12,xo("StructArrayLayout2i2i2i12",Ra);var La=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r,n,i){var o=this.length;return this.resize(o+1),this.emplace(o,e,t,r,n,i)},t.prototype.emplace=function(e,t,r,n,i,o){var a=4*e,s=8*e;return this.float32[a+0]=t,this.float32[a+1]=r,this.float32[a+2]=n,this.int16[s+6]=i,this.int16[s+7]=o,e},t}(xa);La.prototype.bytesPerElement=16,xo("StructArrayLayout2f1f2i16",La);var Da=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r,n){var i=this.length;return this.resize(i+1),this.emplace(i,e,t,r,n)},t.prototype.emplace=function(e,t,r,n,i){var o=12*e,a=3*e;return this.uint8[o+0]=t,this.uint8[o+1]=r,this.float32[a+1]=n,this.float32[a+2]=i,e},t}(xa);Da.prototype.bytesPerElement=12,xo("StructArrayLayout2ub2f12",Da);var za=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r){var n=this.length;return this.resize(n+1),this.emplace(n,e,t,r)},t.prototype.emplace=function(e,t,r,n){var i=3*e;return this.uint16[i+0]=t,this.uint16[i+1]=r,this.uint16[i+2]=n,e},t}(xa);za.prototype.bytesPerElement=6,xo("StructArrayLayout3ui6",za);var ja=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer),this.uint32=new Uint32Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r,n,i,o,a,s,l,c,u,d,h,p,f,m,g){var y=this.length;return this.resize(y+1),this.emplace(y,e,t,r,n,i,o,a,s,l,c,u,d,h,p,f,m,g)},t.prototype.emplace=function(e,t,r,n,i,o,a,s,l,c,u,d,h,p,f,m,g,y){var v=24*e,x=12*e,b=48*e;return this.int16[v+0]=t,this.int16[v+1]=r,this.uint16[v+2]=n,this.uint16[v+3]=i,this.uint32[x+2]=o,this.uint32[x+3]=a,this.uint32[x+4]=s,this.uint16[v+10]=l,this.uint16[v+11]=c,this.uint16[v+12]=u,this.float32[x+7]=d,this.float32[x+8]=h,this.uint8[b+36]=p,this.uint8[b+37]=f,this.uint8[b+38]=m,this.uint32[x+10]=g,this.int16[v+22]=y,e},t}(xa);ja.prototype.bytesPerElement=48,xo("StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48",ja);var Fa=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer),this.uint32=new Uint32Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r,n,i,o,a,s,l,c,u,d,h,p,f,m,g,y,v,x,b,_,w,k,S,A,T,M){var C=this.length;return this.resize(C+1),this.emplace(C,e,t,r,n,i,o,a,s,l,c,u,d,h,p,f,m,g,y,v,x,b,_,w,k,S,A,T,M)},t.prototype.emplace=function(e,t,r,n,i,o,a,s,l,c,u,d,h,p,f,m,g,y,v,x,b,_,w,k,S,A,T,M,C){var E=34*e,I=17*e;return this.int16[E+0]=t,this.int16[E+1]=r,this.int16[E+2]=n,this.int16[E+3]=i,this.int16[E+4]=o,this.int16[E+5]=a,this.int16[E+6]=s,this.int16[E+7]=l,this.uint16[E+8]=c,this.uint16[E+9]=u,this.uint16[E+10]=d,this.uint16[E+11]=h,this.uint16[E+12]=p,this.uint16[E+13]=f,this.uint16[E+14]=m,this.uint16[E+15]=g,this.uint16[E+16]=y,this.uint16[E+17]=v,this.uint16[E+18]=x,this.uint16[E+19]=b,this.uint16[E+20]=_,this.uint16[E+21]=w,this.uint16[E+22]=k,this.uint32[I+12]=S,this.float32[I+13]=A,this.float32[I+14]=T,this.float32[I+15]=M,this.float32[I+16]=C,e},t}(xa);Fa.prototype.bytesPerElement=68,xo("StructArrayLayout8i15ui1ul4f68",Fa);var Na=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e){var t=this.length;return this.resize(t+1),this.emplace(t,e)},t.prototype.emplace=function(e,t){var r=1*e;return this.float32[r+0]=t,e},t}(xa);Na.prototype.bytesPerElement=4,xo("StructArrayLayout1f4",Na);var Ba=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r){var n=this.length;return this.resize(n+1),this.emplace(n,e,t,r)},t.prototype.emplace=function(e,t,r,n){var i=3*e;return this.int16[i+0]=t,this.int16[i+1]=r,this.int16[i+2]=n,e},t}(xa);Ba.prototype.bytesPerElement=6,xo("StructArrayLayout3i6",Ba);var Va=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.uint32=new Uint32Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r){var n=this.length;return this.resize(n+1),this.emplace(n,e,t,r)},t.prototype.emplace=function(e,t,r,n){var i=2*e,o=4*e;return this.uint32[i+0]=t,this.uint16[o+2]=r,this.uint16[o+3]=n,e},t}(xa);Va.prototype.bytesPerElement=8,xo("StructArrayLayout1ul2ui8",Va);var Ua=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t){var r=this.length;return this.resize(r+1),this.emplace(r,e,t)},t.prototype.emplace=function(e,t,r){var n=2*e;return this.uint16[n+0]=t,this.uint16[n+1]=r,e},t}(xa);Ua.prototype.bytesPerElement=4,xo("StructArrayLayout2ui4",Ua);var Ha=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e){var t=this.length;return this.resize(t+1),this.emplace(t,e)},t.prototype.emplace=function(e,t){var r=1*e;return this.uint16[r+0]=t,e},t}(xa);Ha.prototype.bytesPerElement=2,xo("StructArrayLayout1ui2",Ha);var $a=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._refreshViews=function(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)},t.prototype.emplaceBack=function(e,t,r,n){var i=this.length;return this.resize(i+1),this.emplace(i,e,t,r,n)},t.prototype.emplace=function(e,t,r,n,i){var o=4*e;return this.float32[o+0]=t,this.float32[o+1]=r,this.float32[o+2]=n,this.float32[o+3]=i,e},t}(xa);$a.prototype.bytesPerElement=16,xo("StructArrayLayout4f16",$a);var Wa=function(e){function t(){e.apply(this,arguments)}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var r={anchorPointX:{configurable:!0},anchorPointY:{configurable:!0},x1:{configurable:!0},y1:{configurable:!0},x2:{configurable:!0},y2:{configurable:!0},featureIndex:{configurable:!0},sourceLayerIndex:{configurable:!0},bucketIndex:{configurable:!0},anchorPoint:{configurable:!0}};return r.anchorPointX.get=function(){return this._structArray.int16[this._pos2+0]},r.anchorPointY.get=function(){return this._structArray.int16[this._pos2+1]},r.x1.get=function(){return this._structArray.int16[this._pos2+2]},r.y1.get=function(){return this._structArray.int16[this._pos2+3]},r.x2.get=function(){return this._structArray.int16[this._pos2+4]},r.y2.get=function(){return this._structArray.int16[this._pos2+5]},r.featureIndex.get=function(){return this._structArray.uint32[this._pos4+3]},r.sourceLayerIndex.get=function(){return this._structArray.uint16[this._pos2+8]},r.bucketIndex.get=function(){return this._structArray.uint16[this._pos2+9]},r.anchorPoint.get=function(){return new o(this.anchorPointX,this.anchorPointY)},Object.defineProperties(t.prototype,r),t}(ga);Wa.prototype.size=20;var qa=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.get=function(e){return new Wa(this,e)},t}(Oa);xo("CollisionBoxArray",qa);var Ga=function(e){function t(){e.apply(this,arguments)}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var r={anchorX:{configurable:!0},anchorY:{configurable:!0},glyphStartIndex:{configurable:!0},numGlyphs:{configurable:!0},vertexStartIndex:{configurable:!0},lineStartIndex:{configurable:!0},lineLength:{configurable:!0},segment:{configurable:!0},lowerSize:{configurable:!0},upperSize:{configurable:!0},lineOffsetX:{configurable:!0},lineOffsetY:{configurable:!0},writingMode:{configurable:!0},placedOrientation:{configurable:!0},hidden:{configurable:!0},crossTileID:{configurable:!0},associatedIconIndex:{configurable:!0}};return r.anchorX.get=function(){return this._structArray.int16[this._pos2+0]},r.anchorY.get=function(){return this._structArray.int16[this._pos2+1]},r.glyphStartIndex.get=function(){return this._structArray.uint16[this._pos2+2]},r.numGlyphs.get=function(){return this._structArray.uint16[this._pos2+3]},r.vertexStartIndex.get=function(){return this._structArray.uint32[this._pos4+2]},r.lineStartIndex.get=function(){return this._structArray.uint32[this._pos4+3]},r.lineLength.get=function(){return this._structArray.uint32[this._pos4+4]},r.segment.get=function(){return this._structArray.uint16[this._pos2+10]},r.lowerSize.get=function(){return this._structArray.uint16[this._pos2+11]},r.upperSize.get=function(){return this._structArray.uint16[this._pos2+12]},r.lineOffsetX.get=function(){return this._structArray.float32[this._pos4+7]},r.lineOffsetY.get=function(){return this._structArray.float32[this._pos4+8]},r.writingMode.get=function(){return this._structArray.uint8[this._pos1+36]},r.placedOrientation.get=function(){return this._structArray.uint8[this._pos1+37]},r.placedOrientation.set=function(e){this._structArray.uint8[this._pos1+37]=e},r.hidden.get=function(){return this._structArray.uint8[this._pos1+38]},r.hidden.set=function(e){this._structArray.uint8[this._pos1+38]=e},r.crossTileID.get=function(){return this._structArray.uint32[this._pos4+10]},r.crossTileID.set=function(e){this._structArray.uint32[this._pos4+10]=e},r.associatedIconIndex.get=function(){return this._structArray.int16[this._pos2+22]},Object.defineProperties(t.prototype,r),t}(ga);Ga.prototype.size=48;var Ya=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.get=function(e){return new Ga(this,e)},t}(ja);xo("PlacedSymbolArray",Ya);var Xa=function(e){function t(){e.apply(this,arguments)}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var r={anchorX:{configurable:!0},anchorY:{configurable:!0},rightJustifiedTextSymbolIndex:{configurable:!0},centerJustifiedTextSymbolIndex:{configurable:!0},leftJustifiedTextSymbolIndex:{configurable:!0},verticalPlacedTextSymbolIndex:{configurable:!0},placedIconSymbolIndex:{configurable:!0},verticalPlacedIconSymbolIndex:{configurable:!0},key:{configurable:!0},textBoxStartIndex:{configurable:!0},textBoxEndIndex:{configurable:!0},verticalTextBoxStartIndex:{configurable:!0},verticalTextBoxEndIndex:{configurable:!0},iconBoxStartIndex:{configurable:!0},iconBoxEndIndex:{configurable:!0},verticalIconBoxStartIndex:{configurable:!0},verticalIconBoxEndIndex:{configurable:!0},featureIndex:{configurable:!0},numHorizontalGlyphVertices:{configurable:!0},numVerticalGlyphVertices:{configurable:!0},numIconVertices:{configurable:!0},numVerticalIconVertices:{configurable:!0},useRuntimeCollisionCircles:{configurable:!0},crossTileID:{configurable:!0},textBoxScale:{configurable:!0},textOffset0:{configurable:!0},textOffset1:{configurable:!0},collisionCircleDiameter:{configurable:!0}};return r.anchorX.get=function(){return this._structArray.int16[this._pos2+0]},r.anchorY.get=function(){return this._structArray.int16[this._pos2+1]},r.rightJustifiedTextSymbolIndex.get=function(){return this._structArray.int16[this._pos2+2]},r.centerJustifiedTextSymbolIndex.get=function(){return this._structArray.int16[this._pos2+3]},r.leftJustifiedTextSymbolIndex.get=function(){return this._structArray.int16[this._pos2+4]},r.verticalPlacedTextSymbolIndex.get=function(){return this._structArray.int16[this._pos2+5]},r.placedIconSymbolIndex.get=function(){return this._structArray.int16[this._pos2+6]},r.verticalPlacedIconSymbolIndex.get=function(){return this._structArray.int16[this._pos2+7]},r.key.get=function(){return this._structArray.uint16[this._pos2+8]},r.textBoxStartIndex.get=function(){return this._structArray.uint16[this._pos2+9]},r.textBoxEndIndex.get=function(){return this._structArray.uint16[this._pos2+10]},r.verticalTextBoxStartIndex.get=function(){return this._structArray.uint16[this._pos2+11]},r.verticalTextBoxEndIndex.get=function(){return this._structArray.uint16[this._pos2+12]},r.iconBoxStartIndex.get=function(){return this._structArray.uint16[this._pos2+13]},r.iconBoxEndIndex.get=function(){return this._structArray.uint16[this._pos2+14]},r.verticalIconBoxStartIndex.get=function(){return this._structArray.uint16[this._pos2+15]},r.verticalIconBoxEndIndex.get=function(){return this._structArray.uint16[this._pos2+16]},r.featureIndex.get=function(){return this._structArray.uint16[this._pos2+17]},r.numHorizontalGlyphVertices.get=function(){return this._structArray.uint16[this._pos2+18]},r.numVerticalGlyphVertices.get=function(){return this._structArray.uint16[this._pos2+19]},r.numIconVertices.get=function(){return this._structArray.uint16[this._pos2+20]},r.numVerticalIconVertices.get=function(){return this._structArray.uint16[this._pos2+21]},r.useRuntimeCollisionCircles.get=function(){return this._structArray.uint16[this._pos2+22]},r.crossTileID.get=function(){return this._structArray.uint32[this._pos4+12]},r.crossTileID.set=function(e){this._structArray.uint32[this._pos4+12]=e},r.textBoxScale.get=function(){return this._structArray.float32[this._pos4+13]},r.textOffset0.get=function(){return this._structArray.float32[this._pos4+14]},r.textOffset1.get=function(){return this._structArray.float32[this._pos4+15]},r.collisionCircleDiameter.get=function(){return this._structArray.float32[this._pos4+16]},Object.defineProperties(t.prototype,r),t}(ga);Xa.prototype.size=68;var Za=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.get=function(e){return new Xa(this,e)},t}(Fa);xo("SymbolInstanceArray",Za);var Ka=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.getoffsetX=function(e){return this.float32[1*e+0]},t}(Na);xo("GlyphOffsetArray",Ka);var Ja=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.getx=function(e){return this.int16[3*e+0]},t.prototype.gety=function(e){return this.int16[3*e+1]},t.prototype.gettileUnitDistanceFromAnchor=function(e){return this.int16[3*e+2]},t}(Ba);xo("SymbolLineVertexArray",Ja);var Qa=function(e){function t(){e.apply(this,arguments)}e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t;var r={featureIndex:{configurable:!0},sourceLayerIndex:{configurable:!0},bucketIndex:{configurable:!0}};return r.featureIndex.get=function(){return this._structArray.uint32[this._pos4+0]},r.sourceLayerIndex.get=function(){return this._structArray.uint16[this._pos2+2]},r.bucketIndex.get=function(){return this._structArray.uint16[this._pos2+3]},Object.defineProperties(t.prototype,r),t}(ga);Qa.prototype.size=8;var es=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.get=function(e){return new Qa(this,e)},t}(Va);xo("FeatureIndexArray",es);var ts=ba([{name:"a_pos",components:2,type:"Int16"}],4).members,rs=function(e){void 0===e&&(e=[]),this.segments=e};function ns(e,t){return 256*(e=p(Math.floor(e),0,255))+(t=p(Math.floor(t),0,255))}rs.prototype.prepareSegment=function(e,t,r,n){var i=this.segments[this.segments.length-1];return e>rs.MAX_VERTEX_ARRAY_LENGTH&&O("Max vertices per segment is "+rs.MAX_VERTEX_ARRAY_LENGTH+": bucket requested "+e),(!i||i.vertexLength+e>rs.MAX_VERTEX_ARRAY_LENGTH||i.sortKey!==n)&&(i={vertexOffset:t.length,primitiveOffset:r.length,vertexLength:0,primitiveLength:0},void 0!==n&&(i.sortKey=n),this.segments.push(i)),i},rs.prototype.get=function(){return this.segments},rs.prototype.destroy=function(){for(var e=0,t=this.segments;e>>16)*a&65535)<<16)&4294967295)<<15|l>>>17))*s+(((l>>>16)*s&65535)<<16)&4294967295)<<13|i>>>19))+((5*(i>>>16)&65535)<<16)&4294967295))+((58964+(o>>>16)&65535)<<16);switch(l=0,r){case 3:l^=(255&e.charCodeAt(c+2))<<16;case 2:l^=(255&e.charCodeAt(c+1))<<8;case 1:i^=l=(65535&(l=(l=(65535&(l^=255&e.charCodeAt(c)))*a+(((l>>>16)*a&65535)<<16)&4294967295)<<15|l>>>17))*s+(((l>>>16)*s&65535)<<16)&4294967295}return i^=e.length,i=2246822507*(65535&(i^=i>>>16))+((2246822507*(i>>>16)&65535)<<16)&4294967295,i=3266489909*(65535&(i^=i>>>13))+((3266489909*(i>>>16)&65535)<<16)&4294967295,(i^=i>>>16)>>>0}e.exports=t})),as=t((function(e){function t(e,t){for(var r,n=e.length,i=t^n,o=0;n>=4;)r=1540483477*(65535&(r=255&e.charCodeAt(o)|(255&e.charCodeAt(++o))<<8|(255&e.charCodeAt(++o))<<16|(255&e.charCodeAt(++o))<<24))+((1540483477*(r>>>16)&65535)<<16),i=1540483477*(65535&i)+((1540483477*(i>>>16)&65535)<<16)^(r=1540483477*(65535&(r^=r>>>24))+((1540483477*(r>>>16)&65535)<<16)),n-=4,++o;switch(n){case 3:i^=(255&e.charCodeAt(o+2))<<16;case 2:i^=(255&e.charCodeAt(o+1))<<8;case 1:i=1540483477*(65535&(i^=255&e.charCodeAt(o)))+((1540483477*(i>>>16)&65535)<<16)}return i=1540483477*(65535&(i^=i>>>13))+((1540483477*(i>>>16)&65535)<<16),(i^=i>>>15)>>>0}e.exports=t})),ss=os,ls=os,cs=as;ss.murmur3=ls,ss.murmur2=cs;var us=function(){this.ids=[],this.positions=[],this.indexed=!1};us.prototype.add=function(e,t,r,n){this.ids.push(hs(e)),this.positions.push(t,r,n)},us.prototype.getPositions=function(e){for(var t=hs(e),r=0,n=this.ids.length-1;r>1;this.ids[i]>=t?n=i:r=i+1}for(var o=[];this.ids[r]===t;){var a=this.positions[3*r],s=this.positions[3*r+1],l=this.positions[3*r+2];o.push({index:a,start:s,end:l}),r++}return o},us.serialize=function(e,t){var r=new Float64Array(e.ids),n=new Uint32Array(e.positions);return ps(r,n,0,r.length-1),t&&t.push(r.buffer,n.buffer),{ids:r,positions:n}},us.deserialize=function(e){var t=new us;return t.ids=e.ids,t.positions=e.positions,t.indexed=!0,t};var ds=Math.pow(2,53)-1;function hs(e){var t=+e;return!isNaN(t)&&t<=ds?t:ss(String(e))}function ps(e,t,r,n){for(;r>1],o=r-1,a=n+1;;){do{o++}while(e[o]i);if(o>=a)break;fs(e,o,a),fs(t,3*o,3*a),fs(t,3*o+1,3*a+1),fs(t,3*o+2,3*a+2)}a-ra.x+1||la.y+1)&&O("Geometry exceeds allowed extent, reduce your vector tile buffer size")}return r}function Bs(e,t){return{type:e.type,id:e.id,properties:e.properties,geometry:t?Ns(e):[]}}function Vs(e,t,r,n,i){e.emplaceBack(2*t+(n+1)/2,2*r+(i+1)/2)}var Us=function(e){this.zoom=e.zoom,this.overscaling=e.overscaling,this.layers=e.layers,this.layerIds=this.layers.map((function(e){return e.id})),this.index=e.index,this.hasPattern=!1,this.layoutVertexArray=new ka,this.indexArray=new za,this.segments=new rs,this.programConfigurations=new Ps(e.layers,e.zoom),this.stateDependentLayerIds=this.layers.filter((function(e){return e.isStateDependent()})).map((function(e){return e.id}))};function Hs(e,t){for(var r=0;r=3)for(var o=0;o1){if(Ys(e,t))return!0;for(var n=0;n1?e.distSqr(r):e.distSqr(r.sub(t)._mult(i)._add(t))}function Js(e,t){for(var r,n,i,o=!1,a=0;at.y!==i.y>t.y&&t.x<(i.x-n.x)*(t.y-n.y)/(i.y-n.y)+n.x&&(o=!o);return o}function Qs(e,t){for(var r=!1,n=0,i=e.length-1;nt.y!==a.y>t.y&&t.x<(a.x-o.x)*(t.y-o.y)/(a.y-o.y)+o.x&&(r=!r)}return r}function el(e,t,r,n,i){for(var a=0,s=e;a=l.x&&i>=l.y)return!0}var c=[new o(t,r),new o(t,i),new o(n,i),new o(n,r)];if(e.length>2)for(var u=0,d=c;ui.x&&t.x>i.x||e.yi.y&&t.y>i.y)return!1;var o=R(e,t,r[0]);return o!==R(e,t,r[1])||o!==R(e,t,r[2])||o!==R(e,t,r[3])}function rl(e,t,r){var n=t.paint.get(e).value;return"constant"===n.kind?n.value:r.programConfigurations.get(t.id).getMaxValue(e)}function nl(e){return Math.sqrt(e[0]*e[0]+e[1]*e[1])}function il(e,t,r,n,i){if(!t[0]&&!t[1])return e;var a=o.convert(t)._mult(i);"viewport"===r&&a._rotate(-n);for(var s=[],l=0;l=Ds||u<0||u>=Ds)){var d=this.segments.prepareSegment(4,this.layoutVertexArray,this.indexArray,e.sortKey),h=d.vertexLength;Vs(this.layoutVertexArray,c,u,-1,-1),Vs(this.layoutVertexArray,c,u,1,-1),Vs(this.layoutVertexArray,c,u,1,1),Vs(this.layoutVertexArray,c,u,-1,1),this.indexArray.emplaceBack(h,h+1,h+2),this.indexArray.emplaceBack(h,h+3,h+2),d.vertexLength+=4,d.primitiveLength+=2}}this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length,e,r,{},n)},xo("CircleBucket",Us,{omit:["layers"]});var ol=new ha({"circle-sort-key":new la(dt.layout_circle["circle-sort-key"])}),al={paint:new ha({"circle-radius":new la(dt.paint_circle["circle-radius"]),"circle-color":new la(dt.paint_circle["circle-color"]),"circle-blur":new la(dt.paint_circle["circle-blur"]),"circle-opacity":new la(dt.paint_circle["circle-opacity"]),"circle-translate":new sa(dt.paint_circle["circle-translate"]),"circle-translate-anchor":new sa(dt.paint_circle["circle-translate-anchor"]),"circle-pitch-scale":new sa(dt.paint_circle["circle-pitch-scale"]),"circle-pitch-alignment":new sa(dt.paint_circle["circle-pitch-alignment"]),"circle-stroke-width":new la(dt.paint_circle["circle-stroke-width"]),"circle-stroke-color":new la(dt.paint_circle["circle-stroke-color"]),"circle-stroke-opacity":new la(dt.paint_circle["circle-stroke-opacity"])}),layout:ol},sl="undefined"!==typeof Float32Array?Float32Array:Array;function ll(){var e=new sl(4);return sl!=Float32Array&&(e[1]=0,e[2]=0),e[0]=1,e[3]=1,e}function cl(e,t,r){var n=t[0],i=t[1],o=t[2],a=t[3],s=Math.sin(r),l=Math.cos(r);return e[0]=n*l+o*s,e[1]=i*l+a*s,e[2]=n*-s+o*l,e[3]=i*-s+a*l,e}function ul(){var e=new sl(9);return sl!=Float32Array&&(e[1]=0,e[2]=0,e[3]=0,e[5]=0,e[6]=0,e[7]=0),e[0]=1,e[4]=1,e[8]=1,e}function dl(e,t){var r=Math.sin(t),n=Math.cos(t);return e[0]=n,e[1]=r,e[2]=0,e[3]=-r,e[4]=n,e[5]=0,e[6]=0,e[7]=0,e[8]=1,e}function hl(){var e=new sl(16);return sl!=Float32Array&&(e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[11]=0,e[12]=0,e[13]=0,e[14]=0),e[0]=1,e[5]=1,e[10]=1,e[15]=1,e}function pl(e){var t=new sl(16);return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[4]=e[4],t[5]=e[5],t[6]=e[6],t[7]=e[7],t[8]=e[8],t[9]=e[9],t[10]=e[10],t[11]=e[11],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15],t}function fl(e){return e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=1,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=1,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function ml(e,t){var r=t[0],n=t[1],i=t[2],o=t[3],a=t[4],s=t[5],l=t[6],c=t[7],u=t[8],d=t[9],h=t[10],p=t[11],f=t[12],m=t[13],g=t[14],y=t[15],v=r*s-n*a,x=r*l-i*a,b=r*c-o*a,_=n*l-i*s,w=n*c-o*s,k=i*c-o*l,S=u*m-d*f,A=u*g-h*f,T=u*y-p*f,M=d*g-h*m,C=d*y-p*m,E=h*y-p*g,I=v*E-x*C+b*M+_*T-w*A+k*S;return I?(I=1/I,e[0]=(s*E-l*C+c*M)*I,e[1]=(i*C-n*E-o*M)*I,e[2]=(m*k-g*w+y*_)*I,e[3]=(h*w-d*k-p*_)*I,e[4]=(l*T-a*E-c*A)*I,e[5]=(r*E-i*T+o*A)*I,e[6]=(g*b-f*k-y*x)*I,e[7]=(u*k-h*b+p*x)*I,e[8]=(a*C-s*T+c*S)*I,e[9]=(n*T-r*C-o*S)*I,e[10]=(f*w-m*b+y*v)*I,e[11]=(d*b-u*w-p*v)*I,e[12]=(s*A-a*M-l*S)*I,e[13]=(r*M-n*A+i*S)*I,e[14]=(m*x-f*_-g*v)*I,e[15]=(u*_-d*x+h*v)*I,e):null}function gl(e,t,r){var n=t[0],i=t[1],o=t[2],a=t[3],s=t[4],l=t[5],c=t[6],u=t[7],d=t[8],h=t[9],p=t[10],f=t[11],m=t[12],g=t[13],y=t[14],v=t[15],x=r[0],b=r[1],_=r[2],w=r[3];return e[0]=x*n+b*s+_*d+w*m,e[1]=x*i+b*l+_*h+w*g,e[2]=x*o+b*c+_*p+w*y,e[3]=x*a+b*u+_*f+w*v,x=r[4],b=r[5],_=r[6],w=r[7],e[4]=x*n+b*s+_*d+w*m,e[5]=x*i+b*l+_*h+w*g,e[6]=x*o+b*c+_*p+w*y,e[7]=x*a+b*u+_*f+w*v,x=r[8],b=r[9],_=r[10],w=r[11],e[8]=x*n+b*s+_*d+w*m,e[9]=x*i+b*l+_*h+w*g,e[10]=x*o+b*c+_*p+w*y,e[11]=x*a+b*u+_*f+w*v,x=r[12],b=r[13],_=r[14],w=r[15],e[12]=x*n+b*s+_*d+w*m,e[13]=x*i+b*l+_*h+w*g,e[14]=x*o+b*c+_*p+w*y,e[15]=x*a+b*u+_*f+w*v,e}function yl(e,t,r){var n,i,o,a,s,l,c,u,d,h,p,f,m=r[0],g=r[1],y=r[2];return t===e?(e[12]=t[0]*m+t[4]*g+t[8]*y+t[12],e[13]=t[1]*m+t[5]*g+t[9]*y+t[13],e[14]=t[2]*m+t[6]*g+t[10]*y+t[14],e[15]=t[3]*m+t[7]*g+t[11]*y+t[15]):(n=t[0],i=t[1],o=t[2],a=t[3],s=t[4],l=t[5],c=t[6],u=t[7],d=t[8],h=t[9],p=t[10],f=t[11],e[0]=n,e[1]=i,e[2]=o,e[3]=a,e[4]=s,e[5]=l,e[6]=c,e[7]=u,e[8]=d,e[9]=h,e[10]=p,e[11]=f,e[12]=n*m+s*g+d*y+t[12],e[13]=i*m+l*g+h*y+t[13],e[14]=o*m+c*g+p*y+t[14],e[15]=a*m+u*g+f*y+t[15]),e}function vl(e,t,r){var n=r[0],i=r[1],o=r[2];return e[0]=t[0]*n,e[1]=t[1]*n,e[2]=t[2]*n,e[3]=t[3]*n,e[4]=t[4]*i,e[5]=t[5]*i,e[6]=t[6]*i,e[7]=t[7]*i,e[8]=t[8]*o,e[9]=t[9]*o,e[10]=t[10]*o,e[11]=t[11]*o,e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e}function xl(e,t,r){var n=Math.sin(r),i=Math.cos(r),o=t[4],a=t[5],s=t[6],l=t[7],c=t[8],u=t[9],d=t[10],h=t[11];return t!==e&&(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]),e[4]=o*i+c*n,e[5]=a*i+u*n,e[6]=s*i+d*n,e[7]=l*i+h*n,e[8]=c*i-o*n,e[9]=u*i-a*n,e[10]=d*i-s*n,e[11]=h*i-l*n,e}function bl(e,t,r){var n=Math.sin(r),i=Math.cos(r),o=t[0],a=t[1],s=t[2],l=t[3],c=t[4],u=t[5],d=t[6],h=t[7];return t!==e&&(e[8]=t[8],e[9]=t[9],e[10]=t[10],e[11]=t[11],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]),e[0]=o*i+c*n,e[1]=a*i+u*n,e[2]=s*i+d*n,e[3]=l*i+h*n,e[4]=c*i-o*n,e[5]=u*i-a*n,e[6]=d*i-s*n,e[7]=h*i-l*n,e}function _l(e,t,r,n,i){var o,a=1/Math.tan(t/2);return e[0]=a/r,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=a,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[11]=-1,e[12]=0,e[13]=0,e[15]=0,null!=i&&i!==1/0?(o=1/(n-i),e[10]=(i+n)*o,e[14]=2*i*n*o):(e[10]=-1,e[14]=-2*n),e}function wl(e,t,r,n,i,o,a){var s=1/(t-r),l=1/(n-i),c=1/(o-a);return e[0]=-2*s,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=-2*l,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=2*c,e[11]=0,e[12]=(t+r)*s,e[13]=(i+n)*l,e[14]=(a+o)*c,e[15]=1,e}Math.hypot||(Math.hypot=function(){for(var e=arguments,t=0,r=arguments.length;r--;)t+=e[r]*e[r];return Math.sqrt(t)});var kl=gl;function Sl(){var e=new sl(3);return sl!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0),e}function Al(e){var t=new sl(3);return t[0]=e[0],t[1]=e[1],t[2]=e[2],t}function Tl(e,t,r){return e[0]=t[0]+r[0],e[1]=t[1]+r[1],e[2]=t[2]+r[2],e}function Ml(e,t,r){return e[0]=t[0]-r[0],e[1]=t[1]-r[1],e[2]=t[2]-r[2],e}function Cl(e,t,r){return e[0]=t[0]*r,e[1]=t[1]*r,e[2]=t[2]*r,e}function El(e,t){var r=t[0],n=t[1],i=t[2],o=r*r+n*n+i*i;return o>0&&(o=1/Math.sqrt(o)),e[0]=t[0]*o,e[1]=t[1]*o,e[2]=t[2]*o,e}function Il(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]}function Pl(e,t,r){var n=t[0],i=t[1],o=t[2],a=r[0],s=r[1],l=r[2];return e[0]=i*l-o*s,e[1]=o*a-n*l,e[2]=n*s-i*a,e}function Ol(e,t,r){var n=t[0],i=t[1],o=t[2];return e[0]=n*r[0]+i*r[3]+o*r[6],e[1]=n*r[1]+i*r[4]+o*r[7],e[2]=n*r[2]+i*r[5]+o*r[8],e}var Rl=Ml;function Ll(){var e=new sl(4);return sl!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0,e[3]=0),e}function Dl(e,t,r){return e[0]=t[0]*r,e[1]=t[1]*r,e[2]=t[2]*r,e[3]=t[3]*r,e}function zl(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]+e[3]*t[3]}function jl(e,t,r){var n=t[0],i=t[1],o=t[2],a=t[3];return e[0]=r[0]*n+r[4]*i+r[8]*o+r[12]*a,e[1]=r[1]*n+r[5]*i+r[9]*o+r[13]*a,e[2]=r[2]*n+r[6]*i+r[10]*o+r[14]*a,e[3]=r[3]*n+r[7]*i+r[11]*o+r[15]*a,e}function Fl(){var e=new sl(2);return sl!=Float32Array&&(e[0]=0,e[1]=0),e}function Nl(e){var t=e[0],r=e[1];return t*t+r*r}Sl(),Ll();var Bl=Nl,Vl=(Fl(),function(e){function t(t){e.call(this,t,al)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.createBucket=function(e){return new Us(e)},t.prototype.queryRadius=function(e){var t=e;return rl("circle-radius",this,t)+rl("circle-stroke-width",this,t)+nl(this.paint.get("circle-translate"))},t.prototype.queryIntersectsFeature=function(e,t,r,n,i,o,a,s){for(var l=il(e,this.paint.get("circle-translate"),this.paint.get("circle-translate-anchor"),o.angle,a),c=this.paint.get("circle-radius").evaluate(t,r)+this.paint.get("circle-stroke-width").evaluate(t,r),u="map"===this.paint.get("circle-pitch-alignment"),d=u?l:Hl(l,s),h=u?c*a:c,p=0,f=n;pe.width||i.height>e.height||r.x>e.width-i.width||r.y>e.height-i.height)throw new RangeError("out of range source coordinates for image copy");if(i.width>t.width||i.height>t.height||n.x>t.width-i.width||n.y>t.height-i.height)throw new RangeError("out of range destination coordinates for image copy");for(var a=e.data,s=t.data,l=0;l80*r){n=o=e[0],i=a=e[1];for(var f=r;fo&&(o=s),l>a&&(a=l);c=0!==(c=Math.max(o-n,a-i))?1/c:0}return sc(h,p,r,n,i,c),p}function oc(e,t,r,n,i){var o,a;if(i===Dc(e,t,r,n)>0)for(o=t;o=t;o-=n)a=Oc(o,e[o],e[o+1],a);return a&&Sc(a,a.next)&&(Rc(a),a=a.next),a}function ac(e,t){if(!e)return e;t||(t=e);var r,n=e;do{if(r=!1,n.steiner||!Sc(n,n.next)&&0!==kc(n.prev,n,n.next))n=n.next;else{if(Rc(n),(n=t=n.prev)===n.next)break;r=!0}}while(r||n!==t);return t}function sc(e,t,r,n,i,o,a){if(e){!a&&o&&yc(e,n,i,o);for(var s,l,c=e;e.prev!==e.next;)if(s=e.prev,l=e.next,o?cc(e,n,i,o):lc(e))t.push(s.i/r),t.push(e.i/r),t.push(l.i/r),Rc(e),e=l.next,c=l.next;else if((e=l)===c){a?1===a?sc(e=uc(ac(e),t,r),t,r,n,i,o,2):2===a&&dc(e,t,r,n,i,o):sc(ac(e),t,r,n,i,o,1);break}}}function lc(e){var t=e.prev,r=e,n=e.next;if(kc(t,r,n)>=0)return!1;for(var i=e.next.next;i!==e.prev;){if(_c(t.x,t.y,r.x,r.y,n.x,n.y,i.x,i.y)&&kc(i.prev,i,i.next)>=0)return!1;i=i.next}return!0}function cc(e,t,r,n){var i=e.prev,o=e,a=e.next;if(kc(i,o,a)>=0)return!1;for(var s=i.xo.x?i.x>a.x?i.x:a.x:o.x>a.x?o.x:a.x,u=i.y>o.y?i.y>a.y?i.y:a.y:o.y>a.y?o.y:a.y,d=xc(s,l,t,r,n),h=xc(c,u,t,r,n),p=e.prevZ,f=e.nextZ;p&&p.z>=d&&f&&f.z<=h;){if(p!==e.prev&&p!==e.next&&_c(i.x,i.y,o.x,o.y,a.x,a.y,p.x,p.y)&&kc(p.prev,p,p.next)>=0)return!1;if(p=p.prevZ,f!==e.prev&&f!==e.next&&_c(i.x,i.y,o.x,o.y,a.x,a.y,f.x,f.y)&&kc(f.prev,f,f.next)>=0)return!1;f=f.nextZ}for(;p&&p.z>=d;){if(p!==e.prev&&p!==e.next&&_c(i.x,i.y,o.x,o.y,a.x,a.y,p.x,p.y)&&kc(p.prev,p,p.next)>=0)return!1;p=p.prevZ}for(;f&&f.z<=h;){if(f!==e.prev&&f!==e.next&&_c(i.x,i.y,o.x,o.y,a.x,a.y,f.x,f.y)&&kc(f.prev,f,f.next)>=0)return!1;f=f.nextZ}return!0}function uc(e,t,r){var n=e;do{var i=n.prev,o=n.next.next;!Sc(i,o)&&Ac(i,n,n.next,o)&&Ec(i,o)&&Ec(o,i)&&(t.push(i.i/r),t.push(n.i/r),t.push(o.i/r),Rc(n),Rc(n.next),n=e=o),n=n.next}while(n!==e);return ac(n)}function dc(e,t,r,n,i,o){var a=e;do{for(var s=a.next.next;s!==a.prev;){if(a.i!==s.i&&wc(a,s)){var l=Pc(a,s);return a=ac(a,a.next),l=ac(l,l.next),sc(a,t,r,n,i,o),void sc(l,t,r,n,i,o)}s=s.next}a=a.next}while(a!==e)}function hc(e,t,r,n){var i,o,a,s=[];for(i=0,o=t.length;i=n.next.y&&n.next.y!==n.y){var s=n.x+(o-n.y)*(n.next.x-n.x)/(n.next.y-n.y);if(s<=i&&s>a){if(a=s,s===i){if(o===n.y)return n;if(o===n.next.y)return n.next}r=n.x=n.x&&n.x>=u&&i!==n.x&&_c(or.x||n.x===r.x&&gc(r,n)))&&(r=n,h=l)),n=n.next}while(n!==c);return r}function gc(e,t){return kc(e.prev,e,t.prev)<0&&kc(t.next,e,e.next)<0}function yc(e,t,r,n){var i=e;do{null===i.z&&(i.z=xc(i.x,i.y,t,r,n)),i.prevZ=i.prev,i.nextZ=i.next,i=i.next}while(i!==e);i.prevZ.nextZ=null,i.prevZ=null,vc(i)}function vc(e){var t,r,n,i,o,a,s,l,c=1;do{for(r=e,e=null,o=null,a=0;r;){for(a++,n=r,s=0,t=0;t0||l>0&&n;)0!==s&&(0===l||!n||r.z<=n.z)?(i=r,r=r.nextZ,s--):(i=n,n=n.nextZ,l--),o?o.nextZ=i:e=i,i.prevZ=o,o=i;r=n}o.nextZ=null,c*=2}while(a>1);return e}function xc(e,t,r,n,i){return(e=1431655765&((e=858993459&((e=252645135&((e=16711935&((e=32767*(e-r)*i)|e<<8))|e<<4))|e<<2))|e<<1))|(t=1431655765&((t=858993459&((t=252645135&((t=16711935&((t=32767*(t-n)*i)|t<<8))|t<<4))|t<<2))|t<<1))<<1}function bc(e){var t=e,r=e;do{(t.x=0&&(e-a)*(n-s)-(r-a)*(t-s)>=0&&(r-a)*(o-s)-(i-a)*(n-s)>=0}function wc(e,t){return e.next.i!==t.i&&e.prev.i!==t.i&&!Cc(e,t)&&(Ec(e,t)&&Ec(t,e)&&Ic(e,t)&&(kc(e.prev,e,t.prev)||kc(e,t.prev,t))||Sc(e,t)&&kc(e.prev,e,e.next)>0&&kc(t.prev,t,t.next)>0)}function kc(e,t,r){return(t.y-e.y)*(r.x-t.x)-(t.x-e.x)*(r.y-t.y)}function Sc(e,t){return e.x===t.x&&e.y===t.y}function Ac(e,t,r,n){var i=Mc(kc(e,t,r)),o=Mc(kc(e,t,n)),a=Mc(kc(r,n,e)),s=Mc(kc(r,n,t));return i!==o&&a!==s||!(0!==i||!Tc(e,r,t))||!(0!==o||!Tc(e,n,t))||!(0!==a||!Tc(r,e,n))||!(0!==s||!Tc(r,t,n))}function Tc(e,t,r){return t.x<=Math.max(e.x,r.x)&&t.x>=Math.min(e.x,r.x)&&t.y<=Math.max(e.y,r.y)&&t.y>=Math.min(e.y,r.y)}function Mc(e){return e>0?1:e<0?-1:0}function Cc(e,t){var r=e;do{if(r.i!==e.i&&r.next.i!==e.i&&r.i!==t.i&&r.next.i!==t.i&&Ac(r,r.next,e,t))return!0;r=r.next}while(r!==e);return!1}function Ec(e,t){return kc(e.prev,e,e.next)<0?kc(e,t,e.next)>=0&&kc(e,e.prev,t)>=0:kc(e,t,e.prev)<0||kc(e,e.next,t)<0}function Ic(e,t){var r=e,n=!1,i=(e.x+t.x)/2,o=(e.y+t.y)/2;do{r.y>o!==r.next.y>o&&r.next.y!==r.y&&i<(r.next.x-r.x)*(o-r.y)/(r.next.y-r.y)+r.x&&(n=!n),r=r.next}while(r!==e);return n}function Pc(e,t){var r=new Lc(e.i,e.x,e.y),n=new Lc(t.i,t.x,t.y),i=e.next,o=t.prev;return e.next=t,t.prev=e,r.next=i,i.prev=r,n.next=r,r.prev=n,o.next=n,n.prev=o,n}function Oc(e,t,r,n){var i=new Lc(e,t,r);return n?(i.next=n.next,i.prev=n,n.next.prev=i,n.next=i):(i.prev=i,i.next=i),i}function Rc(e){e.next.prev=e.prev,e.prev.next=e.next,e.prevZ&&(e.prevZ.nextZ=e.nextZ),e.nextZ&&(e.nextZ.prevZ=e.prevZ)}function Lc(e,t,r){this.i=e,this.x=t,this.y=r,this.prev=null,this.next=null,this.z=null,this.prevZ=null,this.nextZ=null,this.steiner=!1}function Dc(e,t,r,n){for(var i=0,o=t,a=r-n;or;){if(n-r>600){var o=n-r+1,a=t-r+1,s=Math.log(o),l=.5*Math.exp(2*s/3),c=.5*Math.sqrt(s*l*(o-l)/o)*(a-o/2<0?-1:1);jc(e,t,Math.max(r,Math.floor(t-a*l/o+c)),Math.min(n,Math.floor(t+(o-a)*l/o+c)),i)}var u=e[t],d=r,h=n;for(Fc(e,r,t),i(e[n],u)>0&&Fc(e,r,n);d0;)h--}0===i(e[r],u)?Fc(e,r,h):Fc(e,++h,n),h<=t&&(r=h+1),t<=h&&(n=h-1)}}function Fc(e,t,r){var n=e[t];e[t]=e[r],e[r]=n}function Nc(e,t){return et?1:0}function Bc(e,t){var r=e.length;if(r<=1)return[e];for(var n,i,o=[],a=0;a1)for(var l=0;l0&&(n+=e[i-1].length,r.holes.push(n))}return r},rc.default=nc;var $c=500,Wc=function(e){this.zoom=e.zoom,this.overscaling=e.overscaling,this.layers=e.layers,this.layerIds=this.layers.map((function(e){return e.id})),this.index=e.index,this.hasPattern=!1,this.patternFeatures=[],this.layoutVertexArray=new ka,this.indexArray=new za,this.indexArray2=new Ua,this.programConfigurations=new Ps(e.layers,e.zoom),this.segments=new rs,this.segments2=new rs,this.stateDependentLayerIds=this.layers.filter((function(e){return e.isStateDependent()})).map((function(e){return e.id}))};Wc.prototype.populate=function(e,t,r){this.hasPattern=Uc("fill",this.layers,t);for(var n=this.layers[0].layout.get("fill-sort-key"),i=[],o=0,a=e;o>3}if(i--,1===n||2===n)a+=e.readSVarint(),s+=e.readSVarint(),1===n&&(t&&l.push(t),t=[]),t.push(new o(a,s));else{if(7!==n)throw new Error("unknown command "+n);t&&t.push(t[0].clone())}}return t&&l.push(t),l},Kc.prototype.bbox=function(){var e=this._pbf;e.pos=this._geometry;for(var t=e.readVarint()+e.pos,r=1,n=0,i=0,o=0,a=1/0,s=-1/0,l=1/0,c=-1/0;e.pos>3}if(n--,1===r||2===r)(i+=e.readSVarint())s&&(s=i),(o+=e.readSVarint())c&&(c=o);else if(7!==r)throw new Error("unknown command "+r)}return[a,l,s,c]},Kc.prototype.toGeoJSON=function(e,t,r){var n,i,o=this.extent*Math.pow(2,r),a=this.extent*e,s=this.extent*t,l=this.loadGeometry(),c=Kc.types[this.type];function u(e){for(var t=0;t>3;t=1===n?e.readString():2===n?e.readFloat():3===n?e.readDouble():4===n?e.readVarint64():5===n?e.readVarint():6===n?e.readSVarint():7===n?e.readBoolean():null}return t}function au(e,t){this.layers=e.readFields(su,{},t)}function su(e,t,r){if(3===e){var n=new ru(r,r.readVarint()+r.pos);n.length&&(t[n.name]=n)}}nu.prototype.feature=function(e){if(e<0||e>=this._features.length)throw new Error("feature index out of bounds");this._pbf.pos=this._features[e];var t=this._pbf.readVarint()+this._pbf.pos;return new Zc(this._pbf,t,this.extent,this._keys,this._values)};var lu={VectorTile:au,VectorTileFeature:Zc,VectorTileLayer:ru},cu=lu.VectorTileFeature.types,uu=500,du=Math.pow(2,13);function hu(e,t,r,n,i,o,a,s){e.emplaceBack(t,r,2*Math.floor(n*du)+a,i*du*2,o*du*2,Math.round(s))}var pu=function(e){this.zoom=e.zoom,this.overscaling=e.overscaling,this.layers=e.layers,this.layerIds=this.layers.map((function(e){return e.id})),this.index=e.index,this.hasPattern=!1,this.layoutVertexArray=new Aa,this.indexArray=new za,this.programConfigurations=new Ps(e.layers,e.zoom),this.segments=new rs,this.stateDependentLayerIds=this.layers.filter((function(e){return e.isStateDependent()})).map((function(e){return e.id}))};function fu(e,t){return e.x===t.x&&(e.x<0||e.x>Ds)||e.y===t.y&&(e.y<0||e.y>Ds)}function mu(e){return e.every((function(e){return e.x<0}))||e.every((function(e){return e.x>Ds}))||e.every((function(e){return e.y<0}))||e.every((function(e){return e.y>Ds}))}pu.prototype.populate=function(e,t,r){this.features=[],this.hasPattern=Uc("fill-extrusion",this.layers,t);for(var n=0,i=e;n=1){var v=f[g-1];if(!fu(y,v)){d.vertexLength+4>rs.MAX_VERTEX_ARRAY_LENGTH&&(d=this.segments.prepareSegment(4,this.layoutVertexArray,this.indexArray));var x=y.sub(v)._perp()._unit(),b=v.dist(y);m+b>32768&&(m=0),hu(this.layoutVertexArray,y.x,y.y,x.x,x.y,0,0,m),hu(this.layoutVertexArray,y.x,y.y,x.x,x.y,0,1,m),m+=b,hu(this.layoutVertexArray,v.x,v.y,x.x,x.y,0,0,m),hu(this.layoutVertexArray,v.x,v.y,x.x,x.y,0,1,m);var _=d.vertexLength;this.indexArray.emplaceBack(_,_+2,_+1),this.indexArray.emplaceBack(_+1,_+2,_+3),d.vertexLength+=4,d.primitiveLength+=2}}}}if(d.vertexLength+l>rs.MAX_VERTEX_ARRAY_LENGTH&&(d=this.segments.prepareSegment(l,this.layoutVertexArray,this.indexArray)),"Polygon"===cu[e.type]){for(var w=[],k=[],S=d.vertexLength,A=0,T=s;A=2&&e[l-1].equals(e[l-2]);)l--;for(var c=0;c0;if(k&&y>c){var A=u.dist(p);if(A>2*d){var T=u.sub(u.sub(p)._mult(d/A)._round());this.updateDistance(p,T),this.addCurrentVertex(T,m,0,0,h),p=T}}var M=p&&f,C=M?r:s?"butt":n;if(M&&"round"===C&&(_i&&(C="bevel"),"bevel"===C&&(_>2&&(C="flipbevel"),_100)v=g.mult(-1);else{var E=_*m.add(g).mag()/m.sub(g).mag();v._perp()._mult(E*(S?-1:1))}this.addCurrentVertex(u,v,0,0,h),this.addCurrentVertex(u,v.mult(-1),0,0,h)}else if("bevel"===C||"fakeround"===C){var I=-Math.sqrt(_*_-1),P=S?I:0,O=S?0:I;if(p&&this.addCurrentVertex(u,m,P,O,h),"fakeround"===C)for(var R=Math.round(180*w/Math.PI/Eu),L=1;L2*d){var B=u.add(f.sub(u)._mult(d/N)._round());this.updateDistance(u,B),this.addCurrentVertex(B,g,0,0,h),u=B}}}}},Ru.prototype.addCurrentVertex=function(e,t,r,n,i,o){void 0===o&&(o=!1);var a=t.x+t.y*r,s=t.y-t.x*r,l=-t.x+t.y*n,c=-t.y-t.x*n;this.addHalfVertex(e,a,s,o,!1,r,i),this.addHalfVertex(e,l,c,o,!0,-n,i),this.distance>Ou/2&&0===this.totalDistance&&(this.distance=0,this.addCurrentVertex(e,t,r,n,i,o))},Ru.prototype.addHalfVertex=function(e,t,r,n,i,o,a){var s=e.x,l=e.y,c=(this.lineClips?this.scaledDistance*(Ou-1):this.scaledDistance)*Pu;if(this.layoutVertexArray.emplaceBack((s<<1)+(n?1:0),(l<<1)+(i?1:0),Math.round(Tu*t)+128,Math.round(Tu*r)+128,1+(0===o?0:o<0?-1:1)|(63&c)<<2,c>>6),this.lineClips){var u=(this.scaledDistance-this.lineClips.start)/(this.lineClips.end-this.lineClips.start);this.layoutVertexArray2.emplaceBack(u,this.lineClipsArray.length)}var d=a.vertexLength++;this.e1>=0&&this.e2>=0&&(this.indexArray.emplaceBack(this.e1,this.e2,d),a.primitiveLength++),i?this.e2=d:this.e1=d},Ru.prototype.updateScaledDistance=function(){this.scaledDistance=this.lineClips?this.lineClips.start+(this.lineClips.end-this.lineClips.start)*this.distance/this.totalDistance:this.distance},Ru.prototype.updateDistance=function(e,t){this.distance+=e.dist(t),this.updateScaledDistance()},xo("LineBucket",Ru,{omit:["layers","patternFeatures"]});var Lu=new ha({"line-cap":new sa(dt.layout_line["line-cap"]),"line-join":new la(dt.layout_line["line-join"]),"line-miter-limit":new sa(dt.layout_line["line-miter-limit"]),"line-round-limit":new sa(dt.layout_line["line-round-limit"]),"line-sort-key":new la(dt.layout_line["line-sort-key"])}),Du={paint:new ha({"line-opacity":new la(dt.paint_line["line-opacity"]),"line-color":new la(dt.paint_line["line-color"]),"line-translate":new sa(dt.paint_line["line-translate"]),"line-translate-anchor":new sa(dt.paint_line["line-translate-anchor"]),"line-width":new la(dt.paint_line["line-width"]),"line-gap-width":new la(dt.paint_line["line-gap-width"]),"line-offset":new la(dt.paint_line["line-offset"]),"line-blur":new la(dt.paint_line["line-blur"]),"line-dasharray":new ua(dt.paint_line["line-dasharray"]),"line-pattern":new ca(dt.paint_line["line-pattern"]),"line-gradient":new da(dt.paint_line["line-gradient"])}),layout:Lu},zu=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.possiblyEvaluate=function(t,r){return r=new Jo(Math.floor(r.zoom),{now:r.now,fadeDuration:r.fadeDuration,zoomHistory:r.zoomHistory,transition:r.transition}),e.prototype.possiblyEvaluate.call(this,t,r)},t.prototype.evaluate=function(t,r,n,i){return r=v({},r,{zoom:Math.floor(r.zoom)}),e.prototype.evaluate.call(this,t,r,n,i)},t}(la),ju=new zu(Du.paint.properties["line-width"].specification);ju.useIntegerZoom=!0;var Fu=function(e){function t(t){e.call(this,t,Du),this.gradientVersion=0}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype._handleSpecialPaintPropertyUpdate=function(e){if("line-gradient"===e){var t=this._transitionablePaint._values["line-gradient"].value.expression;this.stepInterpolant=t._styleExpression.expression instanceof Fr,this.gradientVersion=(this.gradientVersion+1)%c}},t.prototype.gradientExpression=function(){return this._transitionablePaint._values["line-gradient"].value.expression},t.prototype.recalculate=function(t,r){e.prototype.recalculate.call(this,t,r),this.paint._values["line-floorwidth"]=ju.possiblyEvaluate(this._transitioningPaint._values["line-width"].value,t)},t.prototype.createBucket=function(e){return new Ru(e)},t.prototype.queryRadius=function(e){var t=e,r=Nu(rl("line-width",this,t),rl("line-gap-width",this,t)),n=rl("line-offset",this,t);return r/2+Math.abs(n)+nl(this.paint.get("line-translate"))},t.prototype.queryIntersectsFeature=function(e,t,r,n,i,o,a){var s=il(e,this.paint.get("line-translate"),this.paint.get("line-translate-anchor"),o.angle,a),l=a/2*Nu(this.paint.get("line-width").evaluate(t,r),this.paint.get("line-gap-width").evaluate(t,r)),c=this.paint.get("line-offset").evaluate(t,r);return c&&(n=Bu(n,c*a)),qs(s,n,l)},t.prototype.isTileClipped=function(){return!0},t}(fa);function Nu(e,t){return t>0?t+2*e:e}function Bu(e,t){for(var r=[],n=new o(0,0),i=0;i":"\ufe40","?":"\ufe16","@":"\uff20","[":"\ufe47","\\":"\uff3c","]":"\ufe48","^":"\uff3e",_:"\ufe33","`":"\uff40","{":"\ufe37","|":"\u2015","}":"\ufe38","~":"\uff5e","\xa2":"\uffe0","\xa3":"\uffe1","\xa5":"\uffe5","\xa6":"\uffe4","\xac":"\uffe2","\xaf":"\uffe3","\u2013":"\ufe32","\u2014":"\ufe31","\u2018":"\ufe43","\u2019":"\ufe44","\u201c":"\ufe41","\u201d":"\ufe42","\u2026":"\ufe19","\u2027":"\u30fb","\u20a9":"\uffe6","\u3001":"\ufe11","\u3002":"\ufe12","\u3008":"\ufe3f","\u3009":"\ufe40","\u300a":"\ufe3d","\u300b":"\ufe3e","\u300c":"\ufe41","\u300d":"\ufe42","\u300e":"\ufe43","\u300f":"\ufe44","\u3010":"\ufe3b","\u3011":"\ufe3c","\u3014":"\ufe39","\u3015":"\ufe3a","\u3016":"\ufe17","\u3017":"\ufe18","\uff01":"\ufe15","\uff08":"\ufe35","\uff09":"\ufe36","\uff0c":"\ufe10","\uff0d":"\ufe32","\uff0e":"\u30fb","\uff1a":"\ufe13","\uff1b":"\ufe14","\uff1c":"\ufe3f","\uff1e":"\ufe40","\uff1f":"\ufe16","\uff3b":"\ufe47","\uff3d":"\ufe48","\uff3f":"\ufe33","\uff5b":"\ufe37","\uff5c":"\u2015","\uff5d":"\ufe38","\uff5f":"\ufe35","\uff60":"\ufe36","\uff61":"\ufe12","\uff62":"\ufe41","\uff63":"\ufe42"};function Zu(e){for(var t="",r=0;r>1,u=-7,d=r?i-1:0,h=r?-1:1,p=e[t+d];for(d+=h,o=p&(1<<-u)-1,p>>=-u,u+=s;u>0;o=256*o+e[t+d],d+=h,u-=8);for(a=o&(1<<-u)-1,o>>=-u,u+=n;u>0;a=256*a+e[t+d],d+=h,u-=8);if(0===o)o=1-c;else{if(o===l)return a?NaN:1/0*(p?-1:1);a+=Math.pow(2,n),o-=c}return(p?-1:1)*a*Math.pow(2,o-n)},write:function(e,t,r,n,i,o){var a,s,l,c=8*o-i-1,u=(1<>1,h=23===i?Math.pow(2,-24)-Math.pow(2,-77):0,p=n?0:o-1,f=n?1:-1,m=t<0||0===t&&1/t<0?1:0;for(t=Math.abs(t),isNaN(t)||t===1/0?(s=isNaN(t)?1:0,a=u):(a=Math.floor(Math.log(t)/Math.LN2),t*(l=Math.pow(2,-a))<1&&(a--,l*=2),(t+=a+d>=1?h/l:h*Math.pow(2,1-d))*l>=2&&(a++,l/=2),a+d>=u?(s=0,a=u):a+d>=1?(s=(t*l-1)*Math.pow(2,i),a+=d):(s=t*Math.pow(2,d-1)*Math.pow(2,i),a=0));i>=8;e[r+p]=255&s,p+=f,s/=256,i-=8);for(a=a<0;e[r+p]=255&a,p+=f,a/=256,c-=8);e[r+p-f]|=128*m}},Qu=ed;function ed(e){this.buf=ArrayBuffer.isView&&ArrayBuffer.isView(e)?e:new Uint8Array(e||0),this.pos=0,this.type=0,this.length=this.buf.length}ed.Varint=0,ed.Fixed64=1,ed.Bytes=2,ed.Fixed32=5;var td=4294967296,rd=1/td,nd=12,id="undefined"===typeof TextDecoder?null:new TextDecoder("utf8");function od(e,t,r){var n,i,o=r.buf;if(n=(112&(i=o[r.pos++]))>>4,i<128)return sd(e,n,t);if(n|=(127&(i=o[r.pos++]))<<3,i<128)return sd(e,n,t);if(n|=(127&(i=o[r.pos++]))<<10,i<128)return sd(e,n,t);if(n|=(127&(i=o[r.pos++]))<<17,i<128)return sd(e,n,t);if(n|=(127&(i=o[r.pos++]))<<24,i<128)return sd(e,n,t);if(n|=(1&(i=o[r.pos++]))<<31,i<128)return sd(e,n,t);throw new Error("Expected varint not more than 10 bytes")}function ad(e){return e.type===ed.Bytes?e.readVarint()+e.pos:e.pos+1}function sd(e,t,r){return r?4294967296*t+(e>>>0):4294967296*(t>>>0)+(e>>>0)}function ld(e,t){var r,n;if(e>=0?(r=e%4294967296|0,n=e/4294967296|0):(n=~(-e/4294967296),4294967295^(r=~(-e%4294967296))?r=r+1|0:(r=0,n=n+1|0)),e>=0x10000000000000000||e<-0x10000000000000000)throw new Error("Given varint doesn't fit into 10 bytes");t.realloc(10),cd(r,n,t),ud(n,t)}function cd(e,t,r){r.buf[r.pos++]=127&e|128,e>>>=7,r.buf[r.pos++]=127&e|128,e>>>=7,r.buf[r.pos++]=127&e|128,e>>>=7,r.buf[r.pos++]=127&e|128,e>>>=7,r.buf[r.pos]=127&e}function ud(e,t){var r=(7&e)<<4;t.buf[t.pos++]|=r|((e>>>=3)?128:0),e&&(t.buf[t.pos++]=127&e|((e>>>=7)?128:0),e&&(t.buf[t.pos++]=127&e|((e>>>=7)?128:0),e&&(t.buf[t.pos++]=127&e|((e>>>=7)?128:0),e&&(t.buf[t.pos++]=127&e|((e>>>=7)?128:0),e&&(t.buf[t.pos++]=127&e)))))}function dd(e,t,r){var n=t<=16383?1:t<=2097151?2:t<=268435455?3:Math.floor(Math.log(t)/(7*Math.LN2));r.realloc(n);for(var i=r.pos-1;i>=e;i--)r.buf[i+n]=r.buf[i]}function hd(e,t){for(var r=0;r>>8,e[r+2]=t>>>16,e[r+3]=t>>>24}function kd(e,t){return(e[t]|e[t+1]<<8|e[t+2]<<16)+(e[t+3]<<24)}function Sd(e,t,r){for(var n="",i=t;i239?4:l>223?3:l>191?2:1;if(i+u>r)break;1===u?l<128&&(c=l):2===u?128===(192&(o=e[i+1]))&&(c=(31&l)<<6|63&o)<=127&&(c=null):3===u?(o=e[i+1],a=e[i+2],128===(192&o)&&128===(192&a)&&((c=(15&l)<<12|(63&o)<<6|63&a)<=2047||c>=55296&&c<=57343)&&(c=null)):4===u&&(o=e[i+1],a=e[i+2],s=e[i+3],128===(192&o)&&128===(192&a)&&128===(192&s)&&((c=(15&l)<<18|(63&o)<<12|(63&a)<<6|63&s)<=65535||c>=1114112)&&(c=null)),null===c?(c=65533,u=1):c>65535&&(c-=65536,n+=String.fromCharCode(c>>>10&1023|55296),c=56320|1023&c),n+=String.fromCharCode(c),i+=u}return n}function Ad(e,t,r){return id.decode(e.subarray(t,r))}function Td(e,t,r){for(var n,i,o=0;o55295&&n<57344){if(!i){n>56319||o+1===t.length?(e[r++]=239,e[r++]=191,e[r++]=189):i=n;continue}if(n<56320){e[r++]=239,e[r++]=191,e[r++]=189,i=n;continue}n=i-55296<<10|n-56320|65536,i=null}else i&&(e[r++]=239,e[r++]=191,e[r++]=189,i=null);n<128?e[r++]=n:(n<2048?e[r++]=n>>6|192:(n<65536?e[r++]=n>>12|224:(e[r++]=n>>18|240,e[r++]=n>>12&63|128),e[r++]=n>>6&63|128),e[r++]=63&n|128)}return r}ed.prototype={destroy:function(){this.buf=null},readFields:function(e,t,r){for(r=r||this.length;this.pos>3,o=this.pos;this.type=7&n,e(i,t,this),this.pos===o&&this.skip(n)}return t},readMessage:function(e,t){return this.readFields(e,t,this.readVarint()+this.pos)},readFixed32:function(){var e=_d(this.buf,this.pos);return this.pos+=4,e},readSFixed32:function(){var e=kd(this.buf,this.pos);return this.pos+=4,e},readFixed64:function(){var e=_d(this.buf,this.pos)+_d(this.buf,this.pos+4)*td;return this.pos+=8,e},readSFixed64:function(){var e=_d(this.buf,this.pos)+kd(this.buf,this.pos+4)*td;return this.pos+=8,e},readFloat:function(){var e=Ju.read(this.buf,this.pos,!0,23,4);return this.pos+=4,e},readDouble:function(){var e=Ju.read(this.buf,this.pos,!0,52,8);return this.pos+=8,e},readVarint:function(e){var t,r,n=this.buf;return t=127&(r=n[this.pos++]),r<128?t:(t|=(127&(r=n[this.pos++]))<<7,r<128?t:(t|=(127&(r=n[this.pos++]))<<14,r<128?t:(t|=(127&(r=n[this.pos++]))<<21,r<128?t:od(t|=(15&(r=n[this.pos]))<<28,e,this))))},readVarint64:function(){return this.readVarint(!0)},readSVarint:function(){var e=this.readVarint();return e%2===1?(e+1)/-2:e/2},readBoolean:function(){return Boolean(this.readVarint())},readString:function(){var e=this.readVarint()+this.pos,t=this.pos;return this.pos=e,e-t>=nd&&id?Ad(this.buf,t,e):Sd(this.buf,t,e)},readBytes:function(){var e=this.readVarint()+this.pos,t=this.buf.subarray(this.pos,e);return this.pos=e,t},readPackedVarint:function(e,t){if(this.type!==ed.Bytes)return e.push(this.readVarint(t));var r=ad(this);for(e=e||[];this.pos127;);else if(t===ed.Bytes)this.pos=this.readVarint()+this.pos;else if(t===ed.Fixed32)this.pos+=4;else{if(t!==ed.Fixed64)throw new Error("Unimplemented type: "+t);this.pos+=8}},writeTag:function(e,t){this.writeVarint(e<<3|t)},realloc:function(e){for(var t=this.length||16;t268435455||e<0?ld(e,this):(this.realloc(4),this.buf[this.pos++]=127&e|(e>127?128:0),e<=127||(this.buf[this.pos++]=127&(e>>>=7)|(e>127?128:0),e<=127||(this.buf[this.pos++]=127&(e>>>=7)|(e>127?128:0),e<=127||(this.buf[this.pos++]=e>>>7&127))))},writeSVarint:function(e){this.writeVarint(e<0?2*-e-1:2*e)},writeBoolean:function(e){this.writeVarint(Boolean(e))},writeString:function(e){e=String(e),this.realloc(4*e.length),this.pos++;var t=this.pos;this.pos=Td(this.buf,e,this.pos);var r=this.pos-t;r>=128&&dd(t,r,this),this.pos=t-1,this.writeVarint(r),this.pos+=r},writeFloat:function(e){this.realloc(4),Ju.write(this.buf,e,this.pos,!0,23,4),this.pos+=4},writeDouble:function(e){this.realloc(8),Ju.write(this.buf,e,this.pos,!0,52,8),this.pos+=8},writeBytes:function(e){var t=e.length;this.writeVarint(t),this.realloc(t);for(var r=0;r=128&&dd(r,n,this),this.pos=r-1,this.writeVarint(n),this.pos+=n},writeMessage:function(e,t,r){this.writeTag(e,ed.Bytes),this.writeRawMessage(t,r)},writePackedVarint:function(e,t){t.length&&this.writeMessage(e,hd,t)},writePackedSVarint:function(e,t){t.length&&this.writeMessage(e,pd,t)},writePackedBoolean:function(e,t){t.length&&this.writeMessage(e,gd,t)},writePackedFloat:function(e,t){t.length&&this.writeMessage(e,fd,t)},writePackedDouble:function(e,t){t.length&&this.writeMessage(e,md,t)},writePackedFixed32:function(e,t){t.length&&this.writeMessage(e,yd,t)},writePackedSFixed32:function(e,t){t.length&&this.writeMessage(e,vd,t)},writePackedFixed64:function(e,t){t.length&&this.writeMessage(e,xd,t)},writePackedSFixed64:function(e,t){t.length&&this.writeMessage(e,bd,t)},writeBytesField:function(e,t){this.writeTag(e,ed.Bytes),this.writeBytes(t)},writeFixed32Field:function(e,t){this.writeTag(e,ed.Fixed32),this.writeFixed32(t)},writeSFixed32Field:function(e,t){this.writeTag(e,ed.Fixed32),this.writeSFixed32(t)},writeFixed64Field:function(e,t){this.writeTag(e,ed.Fixed64),this.writeFixed64(t)},writeSFixed64Field:function(e,t){this.writeTag(e,ed.Fixed64),this.writeSFixed64(t)},writeVarintField:function(e,t){this.writeTag(e,ed.Varint),this.writeVarint(t)},writeSVarintField:function(e,t){this.writeTag(e,ed.Varint),this.writeSVarint(t)},writeStringField:function(e,t){this.writeTag(e,ed.Bytes),this.writeString(t)},writeFloatField:function(e,t){this.writeTag(e,ed.Fixed32),this.writeFloat(t)},writeDoubleField:function(e,t){this.writeTag(e,ed.Fixed64),this.writeDouble(t)},writeBooleanField:function(e,t){this.writeVarintField(e,Boolean(t))}};var Md=3;function Cd(e,t,r){1===e&&r.readMessage(Ed,t)}function Ed(e,t,r){if(3===e){var n=r.readMessage(Id,{}),i=n.id,o=n.bitmap,a=n.width,s=n.height,l=n.left,c=n.top,u=n.advance;t.push({id:i,bitmap:new Yl({width:a+2*Md,height:s+2*Md},o),metrics:{width:a,height:s,left:l,top:c,advance:u}})}}function Id(e,t,r){1===e?t.id=r.readVarint():2===e?t.bitmap=r.readBytes():3===e?t.width=r.readVarint():4===e?t.height=r.readVarint():5===e?t.left=r.readSVarint():6===e?t.top=r.readSVarint():7===e&&(t.advance=r.readVarint())}function Pd(e){return new Qu(e).readFields(Cd,[])}var Od=Md;function Rd(e){for(var t=0,r=0,n=0,i=e;n=0;h--){var p=a[h];if(!(d.w>p.w||d.h>p.h)){if(d.x=p.x,d.y=p.y,l=Math.max(l,d.y+d.h),s=Math.max(s,d.x+d.w),d.w===p.w&&d.h===p.h){var f=a.pop();h=0&&n>=e&&Gd[this.text.charCodeAt(n)];n--)r--;this.text=this.text.substring(e,r),this.sectionIndex=this.sectionIndex.slice(e,r)},$d.prototype.substring=function(e,t){var r=new $d;return r.text=this.text.substring(e,t),r.sectionIndex=this.sectionIndex.slice(e,t),r.sections=this.sections,r},$d.prototype.toString=function(){return this.text},$d.prototype.getMaxScale=function(){var e=this;return this.sectionIndex.reduce((function(t,r){return Math.max(t,e.sections[r].scale)}),0)},$d.prototype.addTextSection=function(e,t){this.text+=e.text,this.sections.push(Hd.forText(e.scale,e.fontStack||t));for(var r=this.sections.length-1,n=0;n=Ud?null:++this.imageSectionID:(this.imageSectionID=Vd,this.imageSectionID)};var Gd={9:!0,10:!0,11:!0,12:!0,13:!0,32:!0},Yd={};function Xd(e,t,r,n,i,o){if(t.imageName){var a=n[t.imageName];return a?a.displaySize[0]*t.scale*Ku/o+i:0}var s=r[t.fontStack],l=s&&s[e];return l?l.metrics.advance*t.scale+i:0}function Zd(e,t,r,n,i,o){for(var a=0,s=0;s=0,u=0,d=0;d0&&F>A&&(A=F)}else{var N=r[M.fontStack],B=N&&N[E];if(B&&B.rect)O=B.rect,P=B.metrics;else{var V=t[M.fontStack],U=V&&V[E];if(!U)continue;P=U.metrics}I=(_-M.scale)*Ku}D?(e.verticalizable=!0,S.push({glyph:E,imageName:R,x:h,y:p+I,vertical:D,scale:M.scale,fontStack:M.fontStack,sectionIndex:C,metrics:P,rect:O}),h+=L*M.scale+c):(S.push({glyph:E,imageName:R,x:h,y:p+I,vertical:D,scale:M.scale,fontStack:M.fontStack,sectionIndex:C,metrics:P,rect:O}),h+=P.advance*M.scale+c)}if(0!==S.length){var H=h-c;f=Math.max(H,f),ih(S,0,S.length-1,g,A)}h=0;var $=o*_+A;k.lineOffset=Math.max(A,w),p+=$,m=Math.max($,m),++y}else p+=o,++y}var W=p-Nd,q=rh(a),G=q.horizontalAlign,Y=q.verticalAlign;oh(e.positionedLines,g,G,Y,f,m,o,W,i.length),e.top+=-Y*W,e.bottom=e.top+W,e.left+=-G*f,e.right=e.left+f}function ih(e,t,r,n,i){if(n||i)for(var o=e[r],a=o.metrics.advance*o.scale,s=(e[r].x+a)*n,l=t;l<=r;l++)e[l].x-=s,e[l].y+=i}function oh(e,t,r,n,i,o,a,s,l){var c=(t-r)*i,u=0;u=o!==a?-s*n-Nd:(-n*l+.5)*a;for(var d=0,h=e;d-r/2;){if(--a<0)return!1;s-=e[a].dist(o),o=e[a]}s+=e[a].dist(e[a+1]),a++;for(var l=[],c=0;sn;)c-=l.shift().angleDelta;if(c>i)return!1;a++,s+=d.dist(h)}return!0}function mh(e){for(var t=0,r=0;rc){var f=(c-l)/p,m=Nr(d.x,h.x,f),g=Nr(d.y,h.y,f),y=new lh(m,g,h.angleTo(d),u);return y._round(),!a||fh(e,y,s,a,t)?y:void 0}l+=p}}function xh(e,t,r,n,i,o,a,s,l){var c=gh(n,o,a),u=yh(n,i),d=u*a,h=0===e[0].x||e[0].x===l||0===e[0].y||e[0].y===l;return t-d=0&&b=0&&_=0&&h+c<=u){var w=new lh(b,_,v,f);w._round(),n&&!fh(e,w,o,n,i)||p.push(w)}}d+=y}return s||p.length||a||(p=bh(e,d/2,r,n,i,o,a,!0,l)),p}function _h(e,t,r,n,i){for(var a=[],s=0;s=n&&h.x>=n||(d.x>=n?d=new o(n,d.y+(h.y-d.y)*((n-d.x)/(h.x-d.x)))._round():h.x>=n&&(h=new o(n,d.y+(h.y-d.y)*((n-d.x)/(h.x-d.x)))._round()),d.y>=i&&h.y>=i||(d.y>=i?d=new o(d.x+(h.x-d.x)*((i-d.y)/(h.y-d.y)),i)._round():h.y>=i&&(h=new o(d.x+(h.x-d.x)*((i-d.y)/(h.y-d.y)),i)._round()),c&&d.equals(c[c.length-1])||(c=[d],a.push(c)),c.push(h)))))}return a}var wh=Ld;function kh(e,t,r,n){var i=[],a=e.image,s=a.pixelRatio,l=a.paddedRect.w-2*wh,c=a.paddedRect.h-2*wh,u=e.right-e.left,d=e.bottom-e.top,h=a.stretchX||[[0,l]],p=a.stretchY||[[0,c]],f=function(e,t){return e+t[1]-t[0]},m=h.reduce(f,0),g=p.reduce(f,0),y=l-m,v=c-g,x=0,b=m,_=0,w=g,k=0,S=y,A=0,T=v;if(a.content&&n){var M=a.content;x=Sh(h,0,M[0]),_=Sh(p,0,M[1]),b=Sh(h,M[0],M[2]),w=Sh(p,M[1],M[3]),k=M[0]-x,A=M[1]-_,S=M[2]-M[0]-b,T=M[3]-M[1]-w}var C=function(n,i,l,c){var h=Th(n.stretch-x,b,u,e.left),p=Mh(n.fixed-k,S,n.stretch,m),f=Th(i.stretch-_,w,d,e.top),y=Mh(i.fixed-A,T,i.stretch,g),v=Th(l.stretch-x,b,u,e.left),M=Mh(l.fixed-k,S,l.stretch,m),C=Th(c.stretch-_,w,d,e.top),E=Mh(c.fixed-A,T,c.stretch,g),I=new o(h,f),P=new o(v,f),O=new o(v,C),R=new o(h,C),L=new o(p/s,y/s),D=new o(M/s,E/s),z=t*Math.PI/180;if(z){var j=Math.sin(z),F=Math.cos(z),N=[F,-j,j,F];I._matMult(N),P._matMult(N),R._matMult(N),O._matMult(N)}var B=n.stretch+n.fixed,V=l.stretch+l.fixed,U=i.stretch+i.fixed,H=c.stretch+c.fixed;return{tl:I,tr:P,bl:R,br:O,tex:{x:a.paddedRect.x+wh+B,y:a.paddedRect.y+wh+U,w:V-B,h:H-U},writingMode:void 0,glyphOffset:[0,0],sectionIndex:0,pixelOffsetTL:L,pixelOffsetBR:D,minFontScaleX:S/s/u,minFontScaleY:T/s/d,isSDF:r}};if(n&&(a.stretchX||a.stretchY))for(var E=Ah(h,y,m),I=Ah(p,v,g),P=0;P0&&(f=Math.max(10,f),this.circleDiameter=f)}else{var m=a.top*s-l,g=a.bottom*s+l,y=a.left*s-l,v=a.right*s+l,x=a.collisionPadding;if(x&&(y-=x[0]*s,m-=x[1]*s,v+=x[2]*s,g+=x[3]*s),u){var b=new o(y,m),_=new o(v,m),w=new o(y,g),k=new o(v,g),S=u*Math.PI/180;b._rotate(S),_._rotate(S),w._rotate(S),k._rotate(S),y=Math.min(b.x,_.x,w.x,k.x),v=Math.max(b.x,_.x,w.x,k.x),m=Math.min(b.y,_.y,w.y,k.y),g=Math.max(b.y,_.y,w.y,k.y)}e.emplaceBack(t.x,t.y,y,m,v,g,r,n,i)}this.boxEndIndex=e.length},Ih=function(e,t){if(void 0===e&&(e=[]),void 0===t&&(t=Ph),this.data=e,this.length=this.data.length,this.compare=t,this.length>0)for(var r=(this.length>>1)-1;r>=0;r--)this._down(r)};function Ph(e,t){return et?1:0}function Oh(e,t,r){void 0===t&&(t=1),void 0===r&&(r=!1);for(var n=1/0,i=1/0,a=-1/0,s=-1/0,l=e[0],c=0;ca)&&(a=u.x),(!c||u.y>s)&&(s=u.y)}var d=a-n,h=s-i,p=Math.min(d,h),f=p/2,m=new Ih([],Rh);if(0===p)return new o(n,i);for(var g=n;gv.d||!v.d)&&(v=b,r&&console.log("found best %d after %d probes",Math.round(1e4*b.d)/1e4,x)),b.max-v.d<=t||(f=b.h/2,m.push(new Lh(b.p.x-f,b.p.y-f,f,e)),m.push(new Lh(b.p.x+f,b.p.y-f,f,e)),m.push(new Lh(b.p.x-f,b.p.y+f,f,e)),m.push(new Lh(b.p.x+f,b.p.y+f,f,e)),x+=4)}return r&&(console.log("num probes: "+x),console.log("best distance: "+v.d)),v.p}function Rh(e,t){return t.max-e.max}function Lh(e,t,r,n){this.p=new o(e,t),this.h=r,this.d=Dh(this.p,n),this.max=this.d+this.h*Math.SQRT2}function Dh(e,t){for(var r=!1,n=1/0,i=0;ie.y!==u.y>e.y&&e.x<(u.x-c.x)*(e.y-c.y)/(u.y-c.y)+c.x&&(r=!r),n=Math.min(n,Ks(e,c,u))}return(r?1:-1)*Math.sqrt(n)}function zh(e){for(var t=0,r=0,n=0,i=e[0],o=0,a=i.length,s=a-1;o0&&(this.data[0]=t,this._down(0)),e}},Ih.prototype.peek=function(){return this.data[0]},Ih.prototype._up=function(e){for(var t=this,r=t.data,n=t.compare,i=r[e];e>0;){var o=e-1>>1,a=r[o];if(n(i,a)>=0)break;r[e]=a,e=o}r[e]=i},Ih.prototype._down=function(e){for(var t=this,r=t.data,n=t.compare,i=this.length>>1,o=r[e];e=0)break;r[e]=s,e=a}r[e]=o};var jh=7,Fh=Number.POSITIVE_INFINITY;function Nh(e,t){function r(e,t){var r=0,n=0;t<0&&(t=0);var i=t/Math.sqrt(2);switch(e){case"top-right":case"top-left":n=i-jh;break;case"bottom-right":case"bottom-left":n=-i+jh;break;case"bottom":n=-t+jh;break;case"top":n=t-jh}switch(e){case"top-right":case"bottom-right":r=-i;break;case"top-left":case"bottom-left":r=i;break;case"left":r=t;break;case"right":r=-t}return[r,n]}function n(e,t,r){var n=0,i=0;switch(t=Math.abs(t),r=Math.abs(r),e){case"top-right":case"top-left":case"top":i=r-jh;break;case"bottom-right":case"bottom-left":case"bottom":i=-r+jh}switch(e){case"top-right":case"bottom-right":case"right":n=-t;break;case"top-left":case"bottom-left":case"left":n=t}return[n,i]}return t[1]!==Fh?n(e,t[0],t[1]):r(e,t[0])}function Bh(e,t,r,n,i,o,a){e.createArrays();var s=512*e.overscaling;e.tilePixelRatio=Ds/s,e.compareText={},e.iconsNeedLinear=!1;var l=e.layers[0].layout,c=e.layers[0]._unevaluatedLayout._values,u={};if("composite"===e.textSizeData.kind){var d=e.textSizeData,h=d.minZoom,p=d.maxZoom;u.compositeTextSizes=[c["text-size"].possiblyEvaluate(new Jo(h),a),c["text-size"].possiblyEvaluate(new Jo(p),a)]}if("composite"===e.iconSizeData.kind){var f=e.iconSizeData,m=f.minZoom,g=f.maxZoom;u.compositeIconSizes=[c["icon-size"].possiblyEvaluate(new Jo(m),a),c["icon-size"].possiblyEvaluate(new Jo(g),a)]}u.layoutTextSize=c["text-size"].possiblyEvaluate(new Jo(e.zoom+1),a),u.layoutIconSize=c["icon-size"].possiblyEvaluate(new Jo(e.zoom+1),a),u.textMaxSize=c["text-size"].possiblyEvaluate(new Jo(18));for(var y=l.get("text-line-height")*Ku,v="map"===l.get("text-rotation-alignment")&&"point"!==l.get("symbol-placement"),x=l.get("text-keep-upright"),b=l.get("text-size"),_=function(){var o=k[w],s=l.get("text-font").evaluate(o,{},a).join(","),c=b.evaluate(o,{},a),d=u.layoutTextSize.evaluate(o,{},a),h=u.layoutIconSize.evaluate(o,{},a),p={horizontal:{},vertical:void 0},f=o.text,m=[0,0];if(f){var g=f.toString(),_=l.get("text-letter-spacing").evaluate(o,{},a)*Ku,S=Co(g)?_:0,A=l.get("text-anchor").evaluate(o,{},a),T=l.get("text-variable-anchor");if(!T){var M=l.get("text-radial-offset").evaluate(o,{},a);m=M?Nh(A,[M*Ku,Fh]):l.get("text-offset").evaluate(o,{},a).map((function(e){return e*Ku}))}var C=v?"center":l.get("text-justify").evaluate(o,{},a),E=l.get("symbol-placement"),I="point"===E?l.get("text-max-width").evaluate(o,{},a)*Ku:0,P=function(){e.allowVerticalPlacement&&Mo(g)&&(p.vertical=qd(f,t,r,i,s,I,y,A,"left",S,m,Fd.vertical,!0,E,d,c))};if(!v&&T){for(var R="auto"===C?T.map((function(e){return Vh(e)})):[C],L=!1,D=0;D=Ds||d.y<0||d.y>=Ds||Gh(e,d,s,r,n,i,h,e.layers[0],e.collisionBoxArray,t.index,t.sourceLayerIndex,e.index,v,w,A,l,b,k,T,f,t,o,c,u,a)};if("line"===M)for(var P=0,O=_h(t.geometry,0,0,Ds,Ds);P1){var B=vh(N,S,r.vertical||m,n,g,x);B&&I(N,B)}}else if("Polygon"===t.type)for(var V=0,U=Bc(t.geometry,0);V$h&&O(e.layerIds[0]+': Value for "text-size" is >= '+Hh+'. Reduce your "text-size".'):"composite"===g.kind&&((y=[ch*p.compositeTextSizes[0].evaluate(a,{},f),ch*p.compositeTextSizes[1].evaluate(a,{},f)])[0]>$h||y[1]>$h)&&O(e.layerIds[0]+': Value for "text-size" is >= '+Hh+'. Reduce your "text-size".'),e.addSymbols(e.text,m,y,s,o,a,c,t,l.lineStartIndex,l.lineLength,h,f);for(var v=0,x=u;v$h&&O(e.layerIds[0]+': Value for "icon-size" is >= '+Hh+'. Reduce your "icon-size".'):"composite"===Y.kind&&((X=[ch*_.compositeIconSizes[0].evaluate(b,{},k),ch*_.compositeIconSizes[1].evaluate(b,{},k)])[0]>$h||X[1]>$h)&&O(e.layerIds[0]+': Value for "icon-size" is >= '+Hh+'. Reduce your "icon-size".'),e.addSymbols(e.icon,q,X,x,v,b,!1,t,I.lineStartIndex,I.lineLength,-1,k),z=e.icon.placedSymbolArray.length-1,G&&(R=4*G.length,e.addSymbols(e.icon,G,X,x,v,b,Fd.vertical,t,I.lineStartIndex,I.lineLength,-1,k),j=e.icon.placedSymbolArray.length-1)}for(var Z in n.horizontal){var K=n.horizontal[Z];if(!T){N=ss(K.text);var J=s.layout.get("text-rotate").evaluate(b,{},k);T=new Eh(l,t,c,u,d,K,h,p,f,J)}var Q=1===K.positionedLines.length;if(L+=Wh(e,t,K,o,s,f,b,m,I,n.vertical?Fd.horizontal:Fd.horizontalOnly,Q?Object.keys(n.horizontal):[Z],F,z,_,k),Q)break}n.vertical&&(D+=Wh(e,t,n.vertical,o,s,f,b,m,I,Fd.vertical,["vertical"],F,j,_,k));var ee=T?T.boxStartIndex:e.collisionBoxArray.length,te=T?T.boxEndIndex:e.collisionBoxArray.length,re=C?C.boxStartIndex:e.collisionBoxArray.length,ne=C?C.boxEndIndex:e.collisionBoxArray.length,ie=M?M.boxStartIndex:e.collisionBoxArray.length,oe=M?M.boxEndIndex:e.collisionBoxArray.length,ae=E?E.boxStartIndex:e.collisionBoxArray.length,se=E?E.boxEndIndex:e.collisionBoxArray.length,le=-1,ce=function(e,t){return e&&e.circleDiameter?Math.max(e.circleDiameter,t):t};le=ce(T,le),le=ce(C,le),le=ce(M,le);var ue=(le=ce(E,le))>-1?1:0;ue&&(le*=S/Ku),e.glyphOffsetArray.length>=rp.MAX_GLYPHS&&O("Too many glyphs being rendered in a tile. See https://github.com/mapbox/mapbox-gl-js/issues/2907"),void 0!==b.sortKey&&e.addToSortKeyRanges(e.symbolInstances.length,b.sortKey),e.symbolInstances.emplaceBack(t.x,t.y,F.right>=0?F.right:-1,F.center>=0?F.center:-1,F.left>=0?F.left:-1,F.vertical||-1,z,j,N,ee,te,re,ne,ie,oe,ae,se,c,L,D,P,R,ue,0,h,B,V,le)}function Yh(e,t,r,n){var i=e.compareText;if(t in i){for(var o=i[t],a=o.length-1;a>=0;a--)if(n.dist(o[a])0)&&("constant"!==o.value.kind||o.value.value.length>0),c="constant"!==s.value.kind||!!s.value.value||Object.keys(s.parameters).length>0,u=i.get("symbol-sort-key");if(this.features=[],l||c){for(var d=t.iconDependencies,h=t.glyphDependencies,p=t.availableImages,f=new Jo(this.zoom),m=0,g=e;m=0;for(var R=0,L=S.sections;R=0;s--)o[s]={x:t[s].x,y:t[s].y,tileUnitDistanceFromAnchor:i},s>0&&(i+=t[s-1].dist(t[s]));for(var l=0;l0},rp.prototype.hasIconData=function(){return this.icon.segments.get().length>0},rp.prototype.hasDebugData=function(){return this.textCollisionBox&&this.iconCollisionBox},rp.prototype.hasTextCollisionBoxData=function(){return this.hasDebugData()&&this.textCollisionBox.segments.get().length>0},rp.prototype.hasIconCollisionBoxData=function(){return this.hasDebugData()&&this.iconCollisionBox.segments.get().length>0},rp.prototype.addIndicesForPlacedSymbol=function(e,t){for(var r=e.placedSymbolArray.get(t),n=r.vertexStartIndex+4*r.numGlyphs,i=r.vertexStartIndex;i1||this.icon.segments.get().length>1)){this.symbolInstanceIndexes=this.getSortedSymbolIndexes(e),this.sortedAngle=e,this.text.indexArray.clear(),this.icon.indexArray.clear(),this.featureSortOrder=[];for(var r=0,n=this.symbolInstanceIndexes;r=0&&n.indexOf(e)===r&&t.addIndicesForPlacedSymbol(t.text,e)})),o.verticalPlacedTextSymbolIndex>=0&&this.addIndicesForPlacedSymbol(this.text,o.verticalPlacedTextSymbolIndex),o.placedIconSymbolIndex>=0&&this.addIndicesForPlacedSymbol(this.icon,o.placedIconSymbolIndex),o.verticalPlacedIconSymbolIndex>=0&&this.addIndicesForPlacedSymbol(this.icon,o.verticalPlacedIconSymbolIndex)}this.text.indexBuffer&&this.text.indexBuffer.updateData(this.text.indexArray),this.icon.indexBuffer&&this.icon.indexBuffer.updateData(this.icon.indexArray)}},xo("SymbolBucket",rp,{omit:["layers","collisionBoxArray","features","compareText"]}),rp.MAX_GLYPHS=65535,rp.addDynamicAttributes=Jh;var ip=new ha({"symbol-placement":new sa(dt.layout_symbol["symbol-placement"]),"symbol-spacing":new sa(dt.layout_symbol["symbol-spacing"]),"symbol-avoid-edges":new sa(dt.layout_symbol["symbol-avoid-edges"]),"symbol-sort-key":new la(dt.layout_symbol["symbol-sort-key"]),"symbol-z-order":new sa(dt.layout_symbol["symbol-z-order"]),"icon-allow-overlap":new sa(dt.layout_symbol["icon-allow-overlap"]),"icon-ignore-placement":new sa(dt.layout_symbol["icon-ignore-placement"]),"icon-optional":new sa(dt.layout_symbol["icon-optional"]),"icon-rotation-alignment":new sa(dt.layout_symbol["icon-rotation-alignment"]),"icon-size":new la(dt.layout_symbol["icon-size"]),"icon-text-fit":new sa(dt.layout_symbol["icon-text-fit"]),"icon-text-fit-padding":new sa(dt.layout_symbol["icon-text-fit-padding"]),"icon-image":new la(dt.layout_symbol["icon-image"]),"icon-rotate":new la(dt.layout_symbol["icon-rotate"]),"icon-padding":new sa(dt.layout_symbol["icon-padding"]),"icon-keep-upright":new sa(dt.layout_symbol["icon-keep-upright"]),"icon-offset":new la(dt.layout_symbol["icon-offset"]),"icon-anchor":new la(dt.layout_symbol["icon-anchor"]),"icon-pitch-alignment":new sa(dt.layout_symbol["icon-pitch-alignment"]),"text-pitch-alignment":new sa(dt.layout_symbol["text-pitch-alignment"]),"text-rotation-alignment":new sa(dt.layout_symbol["text-rotation-alignment"]),"text-field":new la(dt.layout_symbol["text-field"]),"text-font":new la(dt.layout_symbol["text-font"]),"text-size":new la(dt.layout_symbol["text-size"]),"text-max-width":new la(dt.layout_symbol["text-max-width"]),"text-line-height":new sa(dt.layout_symbol["text-line-height"]),"text-letter-spacing":new la(dt.layout_symbol["text-letter-spacing"]),"text-justify":new la(dt.layout_symbol["text-justify"]),"text-radial-offset":new la(dt.layout_symbol["text-radial-offset"]),"text-variable-anchor":new sa(dt.layout_symbol["text-variable-anchor"]),"text-anchor":new la(dt.layout_symbol["text-anchor"]),"text-max-angle":new sa(dt.layout_symbol["text-max-angle"]),"text-writing-mode":new sa(dt.layout_symbol["text-writing-mode"]),"text-rotate":new la(dt.layout_symbol["text-rotate"]),"text-padding":new sa(dt.layout_symbol["text-padding"]),"text-keep-upright":new sa(dt.layout_symbol["text-keep-upright"]),"text-transform":new la(dt.layout_symbol["text-transform"]),"text-offset":new la(dt.layout_symbol["text-offset"]),"text-allow-overlap":new sa(dt.layout_symbol["text-allow-overlap"]),"text-ignore-placement":new sa(dt.layout_symbol["text-ignore-placement"]),"text-optional":new sa(dt.layout_symbol["text-optional"])}),op={paint:new ha({"icon-opacity":new la(dt.paint_symbol["icon-opacity"]),"icon-color":new la(dt.paint_symbol["icon-color"]),"icon-halo-color":new la(dt.paint_symbol["icon-halo-color"]),"icon-halo-width":new la(dt.paint_symbol["icon-halo-width"]),"icon-halo-blur":new la(dt.paint_symbol["icon-halo-blur"]),"icon-translate":new sa(dt.paint_symbol["icon-translate"]),"icon-translate-anchor":new sa(dt.paint_symbol["icon-translate-anchor"]),"text-opacity":new la(dt.paint_symbol["text-opacity"]),"text-color":new la(dt.paint_symbol["text-color"],{runtimeType:kt,getOverride:function(e){return e.textColor},hasOverride:function(e){return!!e.textColor}}),"text-halo-color":new la(dt.paint_symbol["text-halo-color"]),"text-halo-width":new la(dt.paint_symbol["text-halo-width"]),"text-halo-blur":new la(dt.paint_symbol["text-halo-blur"]),"text-translate":new sa(dt.paint_symbol["text-translate"]),"text-translate-anchor":new sa(dt.paint_symbol["text-translate-anchor"])}),layout:ip},ap=function(e){this.type=e.property.overrides?e.property.overrides.runtimeType:xt,this.defaultValue=e};ap.prototype.evaluate=function(e){if(e.formattedSection){var t=this.defaultValue.property.overrides;if(t&&t.hasOverride(e.formattedSection))return t.getOverride(e.formattedSection)}return e.feature&&e.featureState?this.defaultValue.evaluate(e.feature,e.featureState):this.defaultValue.property.specification.default},ap.prototype.eachChild=function(e){this.defaultValue.isConstant()||e(this.defaultValue.value._styleExpression.expression)},ap.prototype.outputDefined=function(){return!1},ap.prototype.serialize=function(){return null},xo("FormatSectionOverride",ap,{omit:["defaultValue"]});var sp=function(e){function t(t){e.call(this,t,op)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.recalculate=function(t,r){if(e.prototype.recalculate.call(this,t,r),"auto"===this.layout.get("icon-rotation-alignment")&&("point"!==this.layout.get("symbol-placement")?this.layout._values["icon-rotation-alignment"]="map":this.layout._values["icon-rotation-alignment"]="viewport"),"auto"===this.layout.get("text-rotation-alignment")&&("point"!==this.layout.get("symbol-placement")?this.layout._values["text-rotation-alignment"]="map":this.layout._values["text-rotation-alignment"]="viewport"),"auto"===this.layout.get("text-pitch-alignment")&&(this.layout._values["text-pitch-alignment"]=this.layout.get("text-rotation-alignment")),"auto"===this.layout.get("icon-pitch-alignment")&&(this.layout._values["icon-pitch-alignment"]=this.layout.get("icon-rotation-alignment")),"point"===this.layout.get("symbol-placement")){var n=this.layout.get("text-writing-mode");if(n){for(var i=[],o=0,a=n;o",targetMapId:n,sourceMapId:o.mapId})}}},kp.prototype.receive=function(e){var t=e.data,r=t.id;if(r&&(!t.targetMapId||this.mapId===t.targetMapId))if(""===t.type){delete this.tasks[r];var n=this.cancelCallbacks[r];delete this.cancelCallbacks[r],n&&n()}else z()||t.mustQueue?(this.tasks[r]=t,this.taskQueue.push(r),this.invoker.trigger()):this.processTask(r,t)},kp.prototype.process=function(){if(this.taskQueue.length){var e=this.taskQueue.shift(),t=this.tasks[e];delete this.tasks[e],this.taskQueue.length&&this.invoker.trigger(),t&&this.processTask(e,t)}},kp.prototype.processTask=function(e,t){var r=this;if(""===t.type){var n=this.callbacks[e];delete this.callbacks[e],n&&(t.error?n(So(t.error)):n(null,So(t.data)))}else{var i=!1,o=N(this.globalScope)?void 0:[],a=t.hasCallback?function(t,n){i=!0,delete r.cancelCallbacks[e],r.target.postMessage({id:e,type:"",sourceMapId:r.mapId,error:t?ko(t):null,data:ko(n,o)},o)}:function(e){i=!0},s=null,l=So(t.data);if(this.parent[t.type])s=this.parent[t.type](t.sourceMapId,l,a);else if(this.parent.getWorkerSource){var c=t.type.split(".");s=this.parent.getWorkerSource(t.sourceMapId,c[0],l.source)[c[1]](l,a)}else a(new Error("Could not find function "+t.type));!i&&s&&s.cancel&&(this.cancelCallbacks[e]=s.cancel)}},kp.prototype.remove=function(){this.invoker.remove(),this.target.removeEventListener("message",this.receive,!1)};var Tp=function(e,t){e&&(t?this.setSouthWest(e).setNorthEast(t):4===e.length?this.setSouthWest([e[0],e[1]]).setNorthEast([e[2],e[3]]):this.setSouthWest(e[0]).setNorthEast(e[1]))};Tp.prototype.setNorthEast=function(e){return this._ne=e instanceof Cp?new Cp(e.lng,e.lat):Cp.convert(e),this},Tp.prototype.setSouthWest=function(e){return this._sw=e instanceof Cp?new Cp(e.lng,e.lat):Cp.convert(e),this},Tp.prototype.extend=function(e){var t,r,n=this._sw,i=this._ne;if(e instanceof Cp)t=e,r=e;else{if(!(e instanceof Tp)){if(Array.isArray(e)){if(4===e.length||e.every(Array.isArray)){var o=e;return this.extend(Tp.convert(o))}var a=e;return this.extend(Cp.convert(a))}return this}if(t=e._sw,r=e._ne,!t||!r)return this}return n||i?(n.lng=Math.min(t.lng,n.lng),n.lat=Math.min(t.lat,n.lat),i.lng=Math.max(r.lng,i.lng),i.lat=Math.max(r.lat,i.lat)):(this._sw=new Cp(t.lng,t.lat),this._ne=new Cp(r.lng,r.lat)),this},Tp.prototype.getCenter=function(){return new Cp((this._sw.lng+this._ne.lng)/2,(this._sw.lat+this._ne.lat)/2)},Tp.prototype.getSouthWest=function(){return this._sw},Tp.prototype.getNorthEast=function(){return this._ne},Tp.prototype.getNorthWest=function(){return new Cp(this.getWest(),this.getNorth())},Tp.prototype.getSouthEast=function(){return new Cp(this.getEast(),this.getSouth())},Tp.prototype.getWest=function(){return this._sw.lng},Tp.prototype.getSouth=function(){return this._sw.lat},Tp.prototype.getEast=function(){return this._ne.lng},Tp.prototype.getNorth=function(){return this._ne.lat},Tp.prototype.toArray=function(){return[this._sw.toArray(),this._ne.toArray()]},Tp.prototype.toString=function(){return"LngLatBounds("+this._sw.toString()+", "+this._ne.toString()+")"},Tp.prototype.isEmpty=function(){return!(this._sw&&this._ne)},Tp.prototype.contains=function(e){var t=Cp.convert(e),r=t.lng,n=t.lat,i=this._sw.lat<=n&&n<=this._ne.lat,o=this._sw.lng<=r&&r<=this._ne.lng;return this._sw.lng>this._ne.lng&&(o=this._sw.lng>=r&&r>=this._ne.lng),i&&o},Tp.convert=function(e){return!e||e instanceof Tp?e:new Tp(e)};var Mp=6371008.8,Cp=function(e,t){if(isNaN(e)||isNaN(t))throw new Error("Invalid LngLat object: ("+e+", "+t+")");if(this.lng=+e,this.lat=+t,this.lat>90||this.lat<-90)throw new Error("Invalid LngLat latitude value: must be between -90 and 90")};Cp.prototype.wrap=function(){return new Cp(f(this.lng,-180,180),this.lat)},Cp.prototype.toArray=function(){return[this.lng,this.lat]},Cp.prototype.toString=function(){return"LngLat("+this.lng+", "+this.lat+")"},Cp.prototype.distanceTo=function(e){var t=Math.PI/180,r=this.lat*t,n=e.lat*t,i=Math.sin(r)*Math.sin(n)+Math.cos(r)*Math.cos(n)*Math.cos((e.lng-this.lng)*t);return Mp*Math.acos(Math.min(i,1))},Cp.prototype.toBounds=function(e){void 0===e&&(e=0);var t=360*e/40075017,r=t/Math.cos(Math.PI/180*this.lat);return new Tp(new Cp(this.lng-r,this.lat-t),new Cp(this.lng+r,this.lat+t))},Cp.convert=function(e){if(e instanceof Cp)return e;if(Array.isArray(e)&&(2===e.length||3===e.length))return new Cp(Number(e[0]),Number(e[1]));if(!Array.isArray(e)&&"object"===typeof e&&null!==e)return new Cp(Number("lng"in e?e.lng:e.lon),Number(e.lat));throw new Error("`LngLatLike` argument must be specified as a LngLat instance, an object {lng: , lat: }, an object {lon: , lat: }, or an array of [, ]")};var Ep=2*Math.PI*Mp;function Ip(e){return Ep*Math.cos(e*Math.PI/180)}function Pp(e){return(180+e)/360}function Op(e){return(180-180/Math.PI*Math.log(Math.tan(Math.PI/4+e*Math.PI/360)))/360}function Rp(e,t){return e/Ip(t)}function Lp(e){return 360*e-180}function Dp(e){var t=180-360*e;return 360/Math.PI*Math.atan(Math.exp(t*Math.PI/180))-90}function zp(e,t){return e*Ip(Dp(t))}function jp(e){return 1/Math.cos(e*Math.PI/180)}var Fp=function(e,t,r){void 0===r&&(r=0),this.x=+e,this.y=+t,this.z=+r};Fp.fromLngLat=function(e,t){void 0===t&&(t=0);var r=Cp.convert(e);return new Fp(Pp(r.lng),Op(r.lat),Rp(t,r.lat))},Fp.prototype.toLngLat=function(){return new Cp(Lp(this.x),Dp(this.y))},Fp.prototype.toAltitude=function(){return zp(this.z,this.y)},Fp.prototype.meterInMercatorCoordinateUnits=function(){return 1/Ep*jp(Dp(this.y))};var Np=function(e,t,r){this.z=e,this.x=t,this.y=r,this.key=Up(0,e,e,t,r)};Np.prototype.equals=function(e){return this.z===e.z&&this.x===e.x&&this.y===e.y},Np.prototype.url=function(e,t){var r=Sp(this.x,this.y,this.z),n=Hp(this.z,this.x,this.y);return e[(this.x+this.y)%e.length].replace("{prefix}",(this.x%16).toString(16)+(this.y%16).toString(16)).replace("{z}",String(this.z)).replace("{x}",String(this.x)).replace("{y}",String("tms"===t?Math.pow(2,this.z)-this.y-1:this.y)).replace("{quadkey}",n).replace("{bbox-epsg-3857}",r)},Np.prototype.getTilePoint=function(e){var t=Math.pow(2,this.z);return new o((e.x*t-this.x)*Ds,(e.y*t-this.y)*Ds)},Np.prototype.toString=function(){return this.z+"/"+this.x+"/"+this.y};var Bp=function(e,t){this.wrap=e,this.canonical=t,this.key=Up(e,t.z,t.z,t.x,t.y)},Vp=function(e,t,r,n,i){this.overscaledZ=e,this.wrap=t,this.canonical=new Np(r,+n,+i),this.key=Up(t,e,r,n,i)};function Up(e,t,r,n,i){(e*=2)<0&&(e=-1*e-1);var o=1<0;o--)i+=(t&(n=1<this.canonical.z?new Vp(e,this.wrap,this.canonical.z,this.canonical.x,this.canonical.y):new Vp(e,this.wrap,e,this.canonical.x>>t,this.canonical.y>>t)},Vp.prototype.calculateScaledKey=function(e,t){var r=this.canonical.z-e;return e>this.canonical.z?Up(this.wrap*+t,e,this.canonical.z,this.canonical.x,this.canonical.y):Up(this.wrap*+t,e,e,this.canonical.x>>r,this.canonical.y>>r)},Vp.prototype.isChildOf=function(e){if(e.wrap!==this.wrap)return!1;var t=this.canonical.z-e.canonical.z;return 0===e.overscaledZ||e.overscaledZ>t&&e.canonical.y===this.canonical.y>>t},Vp.prototype.children=function(e){if(this.overscaledZ>=e)return[new Vp(this.overscaledZ+1,this.wrap,this.canonical.z,this.canonical.x,this.canonical.y)];var t=this.canonical.z+1,r=2*this.canonical.x,n=2*this.canonical.y;return[new Vp(t,this.wrap,t,r,n),new Vp(t,this.wrap,t,r+1,n),new Vp(t,this.wrap,t,r,n+1),new Vp(t,this.wrap,t,r+1,n+1)]},Vp.prototype.isLessThan=function(e){return this.wrape.wrap)&&(this.overscaledZe.overscaledZ)&&(this.canonical.xe.canonical.x)&&this.canonical.y=this.dim+1||t<-1||t>=this.dim+1)throw new RangeError("out of range source coordinates for DEM data");return(t+1)*this.stride+(e+1)},$p.prototype._unpackMapbox=function(e,t,r){return(256*e*256+256*t+r)/10-1e4},$p.prototype._unpackTerrarium=function(e,t,r){return 256*e+t+r/256-32768},$p.prototype.getPixels=function(){return new Xl({width:this.stride,height:this.stride},new Uint8Array(this.data.buffer))},$p.prototype.backfillBorder=function(e,t,r){if(this.dim!==e.dim)throw new Error("dem dimension mismatch");var n=t*this.dim,i=t*this.dim+this.dim,o=r*this.dim,a=r*this.dim+this.dim;switch(t){case-1:n=i-1;break;case 1:i=n+1}switch(r){case-1:o=a-1;break;case 1:a=o+1}for(var s=-t*this.dim,l=-r*this.dim,c=o;c=0&&u[3]>=0&&s.insert(a,u[0],u[1],u[2],u[3])}},Zp.prototype.loadVTLayers=function(){return this.vtLayers||(this.vtLayers=new lu.VectorTile(new Qu(this.rawTileData)).layers,this.sourceLayerCoder=new qp(this.vtLayers?Object.keys(this.vtLayers).sort():["_geojsonTileLayer"])),this.vtLayers},Zp.prototype.query=function(e,t,r,n){var i=this;this.loadVTLayers();for(var o=e.params||{},a=Ds/e.tileSize/e.scale,s=Ri(o.filter),l=e.queryGeometry,c=e.queryPadding*a,u=Jp(l),d=this.grid.query(u.minX-c,u.minY-c,u.maxX+c,u.maxY+c),h=Jp(e.cameraQueryGeometry),p=0,f=this.grid3D.query(h.minX-c,h.minY-c,h.maxX+c,h.maxY+c,(function(t,r,n,i){return el(e.cameraQueryGeometry,t-c,r-c,n+c,i+c)}));pn)i=!1;else if(t)if(this.expirationTime=C.maxzoom||"none"!==C.visibility&&(l(M,this.zoom,n),(m[C.id]=C.createBucket({index:u.bucketLayerIDs.length,layers:M,zoom:this.zoom,pixelRatio:this.pixelRatio,overscaling:this.overscaling,collisionBoxArray:this.collisionBoxArray,sourceLayerIndex:b,sourceID:this.source})).populate(_,g,this.tileID.canonical),u.bucketLayerIDs.push(M.map((function(e){return e.id}))))}}}var E=e.mapObject(g.glyphDependencies,(function(e){return Object.keys(e).map(Number)}));Object.keys(E).length?i.send("getGlyphs",{uid:this.uid,stacks:E},(function(e,t){d||(d=e,h=t,O.call(s))})):h={};var I=Object.keys(g.iconDependencies);I.length?i.send("getImages",{icons:I,source:this.source,tileID:this.tileID,type:"icons"},(function(e,t){d||(d=e,p=t,O.call(s))})):p={};var P=Object.keys(g.patternDependencies);function O(){if(d)return o(d);if(h&&p&&f){var t=new a(h),r=new e.ImageAtlas(p,f);for(var i in m){var s=m[i];s instanceof e.SymbolBucket?(l(s.layers,this.zoom,n),e.performSymbolLayout(s,h,t.positions,p,r.iconPositions,this.showCollisionBoxes,this.tileID.canonical)):s.hasPattern&&(s instanceof e.LineBucket||s instanceof e.FillBucket||s instanceof e.FillExtrusionBucket)&&(l(s.layers,this.zoom,n),s.addFeatures(g,this.tileID.canonical,r.patternPositions))}this.status="done",o(null,{buckets:e.values(m).filter((function(e){return!e.isEmpty()})),featureIndex:u,collisionBoxArray:this.collisionBoxArray,glyphAtlasImage:t.image,imageAtlas:r,glyphMap:this.returnDependencies?h:null,iconMap:this.returnDependencies?p:null,glyphPositions:this.returnDependencies?t.positions:null})}}P.length?i.send("getImages",{icons:P,source:this.source,tileID:this.tileID,type:"patterns"},(function(e,t){d||(d=e,f=t,O.call(s))})):f={},O.call(this)};var u=function(e,t,r,n){this.actor=e,this.layerIndex=t,this.availableImages=r,this.loadVectorData=n||c,this.loading={},this.loaded={}};u.prototype.loadTile=function(t,r){var n=this,i=t.uid;this.loading||(this.loading={});var o=!!(t&&t.request&&t.request.collectResourceTiming)&&new e.RequestPerformance(t.request),a=this.loading[i]=new s(t);a.abort=this.loadVectorData(t,(function(t,s){if(delete n.loading[i],t||!s)return a.status="done",n.loaded[i]=a,r(t);var l=s.rawData,c={};s.expires&&(c.expires=s.expires),s.cacheControl&&(c.cacheControl=s.cacheControl);var u={};if(o){var d=o.finish();d&&(u.resourceTiming=JSON.parse(JSON.stringify(d)))}a.vectorTile=s.vectorTile,a.parse(s.vectorTile,n.layerIndex,n.availableImages,n.actor,(function(t,n){if(t||!n)return r(t);r(null,e.extend({rawTileData:l.slice(0)},n,c,u))})),n.loaded=n.loaded||{},n.loaded[i]=a}))},u.prototype.reloadTile=function(e,t){var r=this,n=this.loaded,i=e.uid,o=this;if(n&&n[i]){var a=n[i];a.showCollisionBoxes=e.showCollisionBoxes;var s=function(e,n){var i=a.reloadCallback;i&&(delete a.reloadCallback,a.parse(a.vectorTile,o.layerIndex,r.availableImages,o.actor,i)),t(e,n)};"parsing"===a.status?a.reloadCallback=s:"done"===a.status&&(a.vectorTile?a.parse(a.vectorTile,this.layerIndex,this.availableImages,this.actor,s):s())}},u.prototype.abortTile=function(e,t){var r=this.loading,n=e.uid;r&&r[n]&&r[n].abort&&(r[n].abort(),delete r[n]),t()},u.prototype.removeTile=function(e,t){var r=this.loaded,n=e.uid;r&&r[n]&&delete r[n],t()};var d=e.window.ImageBitmap,h=function(){this.loaded={}};h.prototype.loadTile=function(t,r){var n=t.uid,i=t.encoding,o=t.rawImageData,a=d&&o instanceof d?this.getImageData(o):o,s=new e.DEMData(n,a,i);this.loaded=this.loaded||{},this.loaded[n]=s,r(null,s)},h.prototype.getImageData=function(t){this.offscreenCanvas&&this.offscreenCanvasContext||(this.offscreenCanvas=new OffscreenCanvas(t.width,t.height),this.offscreenCanvasContext=this.offscreenCanvas.getContext("2d")),this.offscreenCanvas.width=t.width,this.offscreenCanvas.height=t.height,this.offscreenCanvasContext.drawImage(t,0,0,t.width,t.height);var r=this.offscreenCanvasContext.getImageData(-1,-1,t.width+2,t.height+2);return this.offscreenCanvasContext.clearRect(0,0,this.offscreenCanvas.width,this.offscreenCanvas.height),new e.RGBAImage({width:r.width,height:r.height},r.data)},h.prototype.removeTile=function(e){var t=this.loaded,r=e.uid;t&&t[r]&&delete t[r]};var p=f;function f(e,t){var r,n=e&&e.type;if("FeatureCollection"===n)for(r=0;r=0!==!!t&&e.reverse()}var y=e.vectorTile.VectorTileFeature.prototype.toGeoJSON,v=function(t){this._feature=t,this.extent=e.EXTENT,this.type=t.type,this.properties=t.tags,"id"in t&&!isNaN(t.id)&&(this.id=parseInt(t.id,10))};v.prototype.loadGeometry=function(){if(1===this._feature.type){for(var t=[],r=0,n=this._feature.geometry;r>31}function z(e,t){for(var r=e.loadGeometry(),n=e.type,i=0,o=0,a=r.length,s=0;s>1;N(e,t,a,n,i,o%2),F(e,t,r,n,a-1,o+1),F(e,t,r,a+1,i,o+1)}}function N(e,t,r,n,i,o){for(;i>n;){if(i-n>600){var a=i-n+1,s=r-n+1,l=Math.log(a),c=.5*Math.exp(2*l/3),u=.5*Math.sqrt(l*c*(a-c)/a)*(s-a/2<0?-1:1);N(e,t,r,Math.max(n,Math.floor(r-s*c/a+u)),Math.min(i,Math.floor(r+(a-s)*c/a+u)),o)}var d=t[2*r+o],h=n,p=i;for(B(e,t,n,r),t[2*i+o]>d&&B(e,t,n,i);hd;)p--}t[2*n+o]===d?B(e,t,n,p):B(e,t,++p,i),p<=r&&(n=p+1),r<=p&&(i=p-1)}}function B(e,t,r,n){V(e,r,n),V(t,2*r,2*n),V(t,2*r+1,2*n+1)}function V(e,t,r){var n=e[t];e[t]=e[r],e[r]=n}function U(e,t,r,n,i,o,a){for(var s,l,c=[0,e.length-1,0],u=[];c.length;){var d=c.pop(),h=c.pop(),p=c.pop();if(h-p<=a)for(var f=p;f<=h;f++)s=t[2*f],l=t[2*f+1],s>=r&&s<=i&&l>=n&&l<=o&&u.push(e[f]);else{var m=Math.floor((p+h)/2);s=t[2*m],l=t[2*m+1],s>=r&&s<=i&&l>=n&&l<=o&&u.push(e[m]);var g=(d+1)%2;(0===d?r<=s:n<=l)&&(c.push(p),c.push(m-1),c.push(g)),(0===d?i>=s:o>=l)&&(c.push(m+1),c.push(h),c.push(g))}}return u}function H(e,t,r,n,i,o){for(var a=[0,e.length-1,0],s=[],l=i*i;a.length;){var c=a.pop(),u=a.pop(),d=a.pop();if(u-d<=o)for(var h=d;h<=u;h++)$(t[2*h],t[2*h+1],r,n)<=l&&s.push(e[h]);else{var p=Math.floor((d+u)/2),f=t[2*p],m=t[2*p+1];$(f,m,r,n)<=l&&s.push(e[p]);var g=(c+1)%2;(0===c?r-i<=f:n-i<=m)&&(a.push(d),a.push(p-1),a.push(g)),(0===c?r+i>=f:n+i>=m)&&(a.push(p+1),a.push(u),a.push(g))}}return s}function $(e,t,r,n){var i=e-r,o=t-n;return i*i+o*o}S.fromVectorTileJs=A,S.fromGeojsonVt=T,S.GeoJSONWrapper=M;var W=function(e){return e[0]},q=function(e){return e[1]},G=function(e,t,r,n,i){void 0===t&&(t=W),void 0===r&&(r=q),void 0===n&&(n=64),void 0===i&&(i=Float64Array),this.nodeSize=n,this.points=e;for(var o=e.length<65536?Uint16Array:Uint32Array,a=this.ids=new o(e.length),s=this.coords=new i(2*e.length),l=0;l=1e4?Math.round(t/1e3)+"k":t>=1e3?Math.round(t/100)/10+"k":t;return ie(ie({},e.properties),{cluster:!0,cluster_id:e.id,point_count:t,point_count_abbreviated:r})}function ee(e){return e/360+.5}function te(e){var t=Math.sin(e*Math.PI/180),r=.5-.25*Math.log((1+t)/(1-t))/Math.PI;return r<0?0:r>1?1:r}function re(e){return 360*(e-.5)}function ne(e){var t=(180-360*e)*Math.PI/180;return 360*Math.atan(Math.exp(t))/Math.PI-90}function ie(e,t){for(var r in t)e[r]=t[r];return e}function oe(e){return e.x}function ae(e){return e.y}function se(e,t,r,n){for(var i,o=n,a=r-t>>1,s=r-t,l=e[t],c=e[t+1],u=e[r],d=e[r+1],h=t+3;ho)i=h,o=p;else if(p===o){var f=Math.abs(h-a);fn&&(i-t>3&&se(e,t,i,n),e[i+2]=o,r-i>3&&se(e,i,r,n))}function le(e,t,r,n,i,o){var a=i-r,s=o-n;if(0!==a||0!==s){var l=((e-r)*a+(t-n)*s)/(a*a+s*s);l>1?(r=i,n=o):l>0&&(r+=a*l,n+=s*l)}return(a=e-r)*a+(s=t-n)*s}function ce(e,t,r,n){var i={id:"undefined"===typeof e?null:e,type:t,geometry:r,tags:n,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0};return ue(i),i}function ue(e){var t=e.geometry,r=e.type;if("Point"===r||"MultiPoint"===r||"LineString"===r)de(e,t);else if("Polygon"===r||"MultiLineString"===r)for(var n=0;n0&&(a+=n?(i*c-l*o)/2:Math.sqrt(Math.pow(l-i,2)+Math.pow(c-o,2))),i=l,o=c}var u=t.length-3;t[2]=1,se(t,0,u,r),t[u+2]=1,t.size=Math.abs(a),t.start=0,t.end=t.size}function ge(e,t,r,n){for(var i=0;i1?1:r}function xe(e,t,r,n,i,o,a,s){if(n/=t,o>=(r/=t)&&a=n)return null;for(var l=[],c=0;c=r&&f=n)){var m=[];if("Point"===h||"MultiPoint"===h)be(d,m,r,n,i);else if("LineString"===h)_e(d,m,r,n,i,!1,s.lineMetrics);else if("MultiLineString"===h)ke(d,m,r,n,i,!1);else if("Polygon"===h)ke(d,m,r,n,i,!0);else if("MultiPolygon"===h)for(var g=0;g=r&&a<=n&&(t.push(e[o]),t.push(e[o+1]),t.push(e[o+2]))}}function _e(e,t,r,n,i,o,a){for(var s,l,c=we(e),u=0===i?Ae:Te,d=e.start,h=0;hr&&(l=u(c,p,f,g,y,r),a&&(c.start=d+s*l)):v>n?x=r&&(l=u(c,p,f,g,y,r),b=!0),x>n&&v<=n&&(l=u(c,p,f,g,y,n),b=!0),!o&&b&&(a&&(c.end=d+s*l),t.push(c),c=we(e)),a&&(d+=s)}var _=e.length-3;p=e[_],f=e[_+1],m=e[_+2],(v=0===i?p:f)>=r&&v<=n&&Se(c,p,f,m),_=c.length-3,o&&_>=3&&(c[_]!==c[0]||c[_+1]!==c[1])&&Se(c,c[0],c[1],c[2]),c.length&&t.push(c)}function we(e){var t=[];return t.size=e.size,t.start=e.start,t.end=e.end,t}function ke(e,t,r,n,i,o){for(var a=0;aa.maxX&&(a.maxX=u),d>a.maxY&&(a.maxY=d)}return a}function Re(e,t,r,n){var i=t.geometry,o=t.type,a=[];if("Point"===o||"MultiPoint"===o)for(var s=0;s0&&t.size<(i?a:n))r.numPoints+=t.length/3;else{for(var s=[],l=0;la)&&(r.numSimplified++,s.push(t[l]),s.push(t[l+1])),r.numPoints++;i&&De(s,o),e.push(s)}}function De(e,t){for(var r=0,n=0,i=e.length,o=i-2;n0===t)for(n=0,i=e.length;n24)throw new Error("maxZoom should be in the 0-24 range");if(t.promoteId&&t.generateId)throw new Error("promoteId and generateId cannot be used together.");var n=he(e,t);this.tiles={},this.tileCoords=[],r&&(console.timeEnd("preprocess data"),console.log("index: maxZoom: %d, maxPoints: %d",t.indexMaxZoom,t.indexMaxPoints),console.time("generate tiles"),this.stats={},this.total=0),(n=Me(n,t)).length&&this.splitTile(n,0,0,0),r&&(n.length&&console.log("features: %d, points: %d",this.tiles[0].numFeatures,this.tiles[0].numPoints),console.timeEnd("generate tiles"),console.log("tiles generated:",this.total,JSON.stringify(this.stats)))}function Fe(e,t,r){return 32*((1<=n;c--){var u=+Date.now();s=this._cluster(s,c),this.trees[c]=new G(s,oe,ae,o,Float32Array),r&&console.log("z%d: %d clusters in %dms",c,s.length,+Date.now()-u)}return r&&console.timeEnd("total time"),this},X.prototype.getClusters=function(e,t){var r=((e[0]+180)%360+360)%360-180,n=Math.max(-90,Math.min(90,e[1])),i=180===e[2]?180:((e[2]+180)%360+360)%360-180,o=Math.max(-90,Math.min(90,e[3]));if(e[2]-e[0]>=360)r=-180,i=180;else if(r>i){var a=this.getClusters([r,n,180,o],t),s=this.getClusters([-180,n,i,o],t);return a.concat(s)}for(var l=this.trees[this._limitZoom(t)],c=[],u=0,d=l.range(ee(r),te(o),ee(i),te(n));ut&&(f+=v.numPoints||1)}if(f>=s){for(var x=u.x*p,b=u.y*p,_=a&&p>1?this._map(u,!0):null,w=(c<<5)+(t+1)+this.points.length,k=0,S=h;k1)for(var C=0,E=h;C>5},X.prototype._getOriginZoom=function(e){return(e-this.points.length)%32},X.prototype._map=function(e,t){if(e.numPoints)return t?ie({},e.properties):e.properties;var r=this.points[e.index].properties,n=this.options.map(r);return t&&n===r?ie({},n):n},je.prototype.options={maxZoom:14,indexMaxZoom:5,indexMaxPoints:1e5,tolerance:3,extent:4096,buffer:64,lineMetrics:!1,promoteId:null,generateId:!1,debug:0},je.prototype.splitTile=function(e,t,r,n,i,o,a){for(var s=[e,t,r,n],l=this.options,c=l.debug;s.length;){n=s.pop(),r=s.pop(),t=s.pop(),e=s.pop();var u=1<1&&console.time("creation"),h=this.tiles[d]=Oe(e,t,r,n,l),this.tileCoords.push({z:t,x:r,y:n}),c)){c>1&&(console.log("tile z%d-%d-%d (features: %d, points: %d, simplified: %d)",t,r,n,h.numFeatures,h.numPoints,h.numSimplified),console.timeEnd("creation"));var p="z"+t;this.stats[p]=(this.stats[p]||0)+1,this.total++}if(h.source=e,i){if(t===l.maxZoom||t===i)continue;var f=1<1&&console.time("clipping");var m,g,y,v,x,b,_=.5*l.buffer/l.extent,w=.5-_,k=.5+_,S=1+_;m=g=y=v=null,x=xe(e,u,r-_,r+k,0,h.minX,h.maxX,l),b=xe(e,u,r+w,r+S,0,h.minX,h.maxX,l),e=null,x&&(m=xe(x,u,n-_,n+k,1,h.minY,h.maxY,l),g=xe(x,u,n+w,n+S,1,h.minY,h.maxY,l),x=null),b&&(y=xe(b,u,n-_,n+k,1,h.minY,h.maxY,l),v=xe(b,u,n+w,n+S,1,h.minY,h.maxY,l),b=null),c>1&&console.timeEnd("clipping"),s.push(m||[],t+1,2*r,2*n),s.push(g||[],t+1,2*r,2*n+1),s.push(y||[],t+1,2*r+1,2*n),s.push(v||[],t+1,2*r+1,2*n+1)}}},je.prototype.getTile=function(e,t,r){var n=this.options,i=n.extent,o=n.debug;if(e<0||e>24)return null;var a=1<1&&console.log("drilling down to z%d-%d-%d",e,t,r);for(var l,c=e,u=t,d=r;!l&&c>0;)c--,u=Math.floor(u/2),d=Math.floor(d/2),l=this.tiles[Fe(c,u,d)];return l&&l.source?(o>1&&console.log("found parent tile z%d-%d-%d",c,u,d),o>1&&console.time("drilling down"),this.splitTile(l.source,c,u,d,e,t,r),o>1&&console.timeEnd("drilling down"),this.tiles[s]?Ie(this.tiles[s],i):null):null};var Ve=function(t){function r(e,r,n,i){t.call(this,e,r,n,Be),i&&(this.loadGeoJSON=i)}return t&&(r.__proto__=t),r.prototype=Object.create(t&&t.prototype),r.prototype.constructor=r,r.prototype.loadData=function(e,t){this._pendingCallback&&this._pendingCallback(null,{abandoned:!0}),this._pendingCallback=t,this._pendingLoadDataParams=e,this._state&&"Idle"!==this._state?this._state="NeedsLoadData":(this._state="Coalescing",this._loadData())},r.prototype._loadData=function(){var t=this;if(this._pendingCallback&&this._pendingLoadDataParams){var r=this._pendingCallback,n=this._pendingLoadDataParams;delete this._pendingCallback,delete this._pendingLoadDataParams;var i=!!(n&&n.request&&n.request.collectResourceTiming)&&new e.RequestPerformance(n.request);this.loadGeoJSON(n,(function(o,a){if(o||!a)return r(o);if("object"!==typeof a)return r(new Error("Input data given to '"+n.source+"' is not a valid GeoJSON object."));p(a,!0);try{if(n.filter){var s=e.createExpression(n.filter,{type:"boolean","property-type":"data-driven",overridable:!1,transition:!1});if("error"===s.result)throw new Error(s.value.map((function(e){return e.key+": "+e.message})).join(", "));var l=a.features.filter((function(e){return s.value.evaluate({zoom:0},e)}));a={type:"FeatureCollection",features:l}}t._geoJSONIndex=n.cluster?new X(Ue(n)).load(a.features):ze(a,n.geojsonVtOptions)}catch(o){return r(o)}t.loaded={};var c={};if(i){var u=i.finish();u&&(c.resourceTiming={},c.resourceTiming[n.source]=JSON.parse(JSON.stringify(u)))}r(null,c)}))}},r.prototype.coalesce=function(){"Coalescing"===this._state?this._state="Idle":"NeedsLoadData"===this._state&&(this._state="Coalescing",this._loadData())},r.prototype.reloadTile=function(e,r){var n=this.loaded,i=e.uid;return n&&n[i]?t.prototype.reloadTile.call(this,e,r):this.loadTile(e,r)},r.prototype.loadGeoJSON=function(t,r){if(t.request)e.getJSON(t.request,r);else{if("string"!==typeof t.data)return r(new Error("Input data given to '"+t.source+"' is not a valid GeoJSON object."));try{return r(null,JSON.parse(t.data))}catch(n){return r(new Error("Input data given to '"+t.source+"' is not a valid GeoJSON object."))}}},r.prototype.removeSource=function(e,t){this._pendingCallback&&this._pendingCallback(null,{abandoned:!0}),t()},r.prototype.getClusterExpansionZoom=function(e,t){try{t(null,this._geoJSONIndex.getClusterExpansionZoom(e.clusterId))}catch(r){t(r)}},r.prototype.getClusterChildren=function(e,t){try{t(null,this._geoJSONIndex.getChildren(e.clusterId))}catch(r){t(r)}},r.prototype.getClusterLeaves=function(e,t){try{t(null,this._geoJSONIndex.getLeaves(e.clusterId,e.limit,e.offset))}catch(r){t(r)}},r}(u);function Ue(t){var r=t.superclusterOptions,n=t.clusterProperties;if(!n||!r)return r;for(var i={},o={},a={accumulated:null,zoom:0},s={properties:null},l=Object.keys(n),c=0,u=l;c1?"@2x":"",l=e.getJSON(r.transformRequest(r.normalizeSpriteURL(t,s,".json"),e.ResourceType.SpriteJSON),(function(e,t){l=null,a||(a=e,i=t,u())})),c=e.getImage(r.transformRequest(r.normalizeSpriteURL(t,s,".png"),e.ResourceType.SpriteImage),(function(e,t){c=null,a||(a=e,o=t,u())}));function u(){if(a)n(a);else if(i&&o){var t=e.browser.getImageData(o),r={};for(var s in i){var l=i[s],c=l.width,u=l.height,d=l.x,h=l.y,p=l.sdf,f=l.pixelRatio,m=l.stretchX,g=l.stretchY,y=l.content,v=new e.RGBAImage({width:c,height:u});e.RGBAImage.copy(t,v,{x:d,y:h},{x:0,y:0},{width:c,height:u}),r[s]={data:v,pixelRatio:f,sdf:p,stretchX:m,stretchY:g,content:y}}n(null,r)}}return{cancel:function(){l&&(l.cancel(),l=null),c&&(c.cancel(),c=null)}}}function h(e){var t=e.userImage;return!!(t&&t.render&&t.render())&&(e.data.replace(new Uint8Array(t.data.buffer)),!0)}r.suppressClick=function(){e.window.addEventListener("click",u,!0),e.window.setTimeout((function(){e.window.removeEventListener("click",u,!0)}),0)},r.mousePos=function(t,r){var n=t.getBoundingClientRect();return new e.Point(r.clientX-n.left-t.clientLeft,r.clientY-n.top-t.clientTop)},r.touchPos=function(t,r){for(var n=t.getBoundingClientRect(),i=[],o=0;o=0?0:t.button},r.remove=function(e){e.parentNode&&e.parentNode.removeChild(e)};var p=1,f=function(t){function r(){t.call(this),this.images={},this.updatedImages={},this.callbackDispatchedThisFrame={},this.loaded=!1,this.requestors=[],this.patterns={},this.atlasImage=new e.RGBAImage({width:1,height:1}),this.dirty=!0}return t&&(r.__proto__=t),r.prototype=Object.create(t&&t.prototype),r.prototype.constructor=r,r.prototype.isLoaded=function(){return this.loaded},r.prototype.setLoaded=function(e){if(this.loaded!==e&&(this.loaded=e,e)){for(var t=0,r=this.requestors;t=0?1.2:1))}function b(e,t,r,n,i,o,a){for(var s=0;s65535)t(new Error("glyphs > 65535 not supported"));else if(o.ranges[s])t(null,{stack:r,id:i,glyph:a});else{var l=o.requests[s];l||(l=o.requests[s]=[],w.loadGlyphRange(r,s,n.url,n.requestManager,(function(e,t){if(t){for(var r in t)n._doesCharSupportLocalGlyph(+r)||(o.glyphs[+r]=t[+r]);o.ranges[s]=!0}for(var i=0,a=l;i1&&(l=e[++s]);var u=Math.abs(c-l.left),d=Math.abs(c-l.right),h=Math.min(u,d),p=void 0,f=i/r*(n+1);if(l.isDash){var m=n-Math.abs(f);p=Math.sqrt(h*h+m*m)}else p=n-Math.sqrt(h*h+f*f);this.data[a+c]=Math.max(0,Math.min(255,p+128))}},M.prototype.addRegularDash=function(e){for(var t=e.length-1;t>=0;--t){var r=e[t],n=e[t+1];r.zeroLength?e.splice(t,1):n&&n.isDash===r.isDash&&(n.left=r.left,e.splice(t,1))}var i=e[0],o=e[e.length-1];i.isDash===o.isDash&&(i.left=o.left-this.width,o.right=i.right+this.width);for(var a=this.width*this.nextRow,s=0,l=e[s],c=0;c1&&(l=e[++s]);var u=Math.abs(c-l.left),d=Math.abs(c-l.right),h=Math.min(u,d),p=l.isDash?h:-h;this.data[a+c]=Math.max(0,Math.min(255,p+128))}},M.prototype.addDash=function(t,r){var n=r?7:0,i=2*n+1;if(this.nextRow+i>this.height)return e.warnOnce("LineAtlas out of space"),null;for(var o=0,a=0;a=n.minX&&t.x=n.minY&&t.y0&&(l[new e.OverscaledTileID(t.overscaledZ,o,r.z,i,r.y-1).key]={backfilled:!1},l[new e.OverscaledTileID(t.overscaledZ,t.wrap,r.z,r.x,r.y-1).key]={backfilled:!1},l[new e.OverscaledTileID(t.overscaledZ,s,r.z,a,r.y-1).key]={backfilled:!1}),r.y+10&&(n.resourceTiming=t._resourceTiming,t._resourceTiming=[]),t.fire(new e.Event("data",n))}}))},r.prototype.onAdd=function(e){this.map=e,this.load()},r.prototype.setData=function(t){var r=this;return this._data=t,this.fire(new e.Event("dataloading",{dataType:"source"})),this._updateWorkerData((function(t){if(t)r.fire(new e.ErrorEvent(t));else{var n={dataType:"source",sourceDataType:"content"};r._collectResourceTiming&&r._resourceTiming&&r._resourceTiming.length>0&&(n.resourceTiming=r._resourceTiming,r._resourceTiming=[]),r.fire(new e.Event("data",n))}})),this},r.prototype.getClusterExpansionZoom=function(e,t){return this.actor.send("geojson.getClusterExpansionZoom",{clusterId:e,source:this.id},t),this},r.prototype.getClusterChildren=function(e,t){return this.actor.send("geojson.getClusterChildren",{clusterId:e,source:this.id},t),this},r.prototype.getClusterLeaves=function(e,t,r,n){return this.actor.send("geojson.getClusterLeaves",{source:this.id,clusterId:e,limit:t,offset:r},n),this},r.prototype._updateWorkerData=function(t){var r=this;this._loaded=!1;var n=e.extend({},this.workerOptions),i=this._data;"string"===typeof i?(n.request=this.map._requestManager.transformRequest(e.browser.resolveURL(i),e.ResourceType.Source),n.request.collectResourceTiming=this._collectResourceTiming):n.data=JSON.stringify(i),this.actor.send(this.type+".loadData",n,(function(e,i){r._removed||i&&i.abandoned||(r._loaded=!0,i&&i.resourceTiming&&i.resourceTiming[r.id]&&(r._resourceTiming=i.resourceTiming[r.id].slice(0)),r.actor.send(r.type+".coalesce",{source:n.source},null),t(e))}))},r.prototype.loaded=function(){return this._loaded},r.prototype.loadTile=function(t,r){var n=this,i=t.actor?"reloadTile":"loadTile";t.actor=this.actor;var o={type:this.type,uid:t.uid,tileID:t.tileID,zoom:t.tileID.overscaledZ,maxZoom:this.maxzoom,tileSize:this.tileSize,source:this.id,pixelRatio:e.browser.devicePixelRatio,showCollisionBoxes:this.map.showCollisionBoxes,promoteId:this.promoteId};t.request=this.actor.send(i,o,(function(e,o){return delete t.request,t.unloadVectorData(),t.aborted?r(null):e?r(e):(t.loadVectorData(o,n.map.painter,"reloadTile"===i),r(null))}))},r.prototype.abortTile=function(e){e.request&&(e.request.cancel(),delete e.request),e.aborted=!0},r.prototype.unloadTile=function(e){e.unloadVectorData(),this.actor.send("removeTile",{uid:e.uid,type:this.type,source:this.id})},r.prototype.onRemove=function(){this._removed=!0,this.actor.send("removeSource",{type:this.type,source:this.id})},r.prototype.serialize=function(){return e.extend({},this._options,{type:this.type,data:this._data})},r.prototype.hasTransition=function(){return!1},r}(e.Evented),D=e.createLayout([{name:"a_pos",type:"Int16",components:2},{name:"a_texture_pos",type:"Int16",components:2}]),z=function(t){function r(e,r,n,i){t.call(this),this.id=e,this.dispatcher=n,this.coordinates=r.coordinates,this.type="image",this.minzoom=0,this.maxzoom=22,this.tileSize=512,this.tiles={},this._loaded=!1,this.setEventedParent(i),this.options=r}return t&&(r.__proto__=t),r.prototype=Object.create(t&&t.prototype),r.prototype.constructor=r,r.prototype.load=function(t,r){var n=this;this._loaded=!1,this.fire(new e.Event("dataloading",{dataType:"source"})),this.url=this.options.url,e.getImage(this.map._requestManager.transformRequest(this.url,e.ResourceType.Image),(function(i,o){n._loaded=!0,i?n.fire(new e.ErrorEvent(i)):o&&(n.image=o,t&&(n.coordinates=t),r&&r(),n._finishLoading())}))},r.prototype.loaded=function(){return this._loaded},r.prototype.updateImage=function(e){var t=this;return this.image&&e.url?(this.options.url=e.url,this.load(e.coordinates,(function(){t.texture=null})),this):this},r.prototype._finishLoading=function(){this.map&&(this.setCoordinates(this.coordinates),this.fire(new e.Event("data",{dataType:"source",sourceDataType:"metadata"})))},r.prototype.onAdd=function(e){this.map=e,this.load()},r.prototype.setCoordinates=function(t){var r=this;this.coordinates=t;var n=t.map(e.MercatorCoordinate.fromLngLat);this.tileID=j(n),this.minzoom=this.maxzoom=this.tileID.z;var i=n.map((function(e){return r.tileID.getTilePoint(e)._round()}));return this._boundsArray=new e.StructArrayLayout4i8,this._boundsArray.emplaceBack(i[0].x,i[0].y,0,0),this._boundsArray.emplaceBack(i[1].x,i[1].y,e.EXTENT,0),this._boundsArray.emplaceBack(i[3].x,i[3].y,0,e.EXTENT),this._boundsArray.emplaceBack(i[2].x,i[2].y,e.EXTENT,e.EXTENT),this.boundsBuffer&&(this.boundsBuffer.destroy(),delete this.boundsBuffer),this.fire(new e.Event("data",{dataType:"source",sourceDataType:"content"})),this},r.prototype.prepare=function(){if(0!==Object.keys(this.tiles).length&&this.image){var t=this.map.painter.context,r=t.gl;for(var n in this.boundsBuffer||(this.boundsBuffer=t.createVertexBuffer(this._boundsArray,D.members)),this.boundsSegments||(this.boundsSegments=e.SegmentVector.simpleSegment(0,0,4,2)),this.texture||(this.texture=new e.Texture(t,this.image,r.RGBA),this.texture.bind(r.LINEAR,r.CLAMP_TO_EDGE)),this.tiles){var i=this.tiles[n];"loaded"!==i.state&&(i.state="loaded",i.texture=this.texture)}}},r.prototype.loadTile=function(e,t){this.tileID&&this.tileID.equals(e.tileID.canonical)?(this.tiles[String(e.tileID.wrap)]=e,e.buckets={},t(null)):(e.state="errored",t(null))},r.prototype.serialize=function(){return{type:"image",url:this.options.url,coordinates:this.coordinates}},r.prototype.hasTransition=function(){return!1},r}(e.Evented);function j(t){for(var r=1/0,n=1/0,i=-1/0,o=-1/0,a=0,s=t;ar.end(0)?this.fire(new e.ErrorEvent(new e.ValidationError("sources."+this.id,null,"Playback for this video can be set only between the "+r.start(0)+" and "+r.end(0)+"-second mark."))):this.video.currentTime=t}},r.prototype.getVideo=function(){return this.video},r.prototype.onAdd=function(e){this.map||(this.map=e,this.load(),this.video&&(this.video.play(),this.setCoordinates(this.coordinates)))},r.prototype.prepare=function(){if(!(0===Object.keys(this.tiles).length||this.video.readyState<2)){var t=this.map.painter.context,r=t.gl;for(var n in this.boundsBuffer||(this.boundsBuffer=t.createVertexBuffer(this._boundsArray,D.members)),this.boundsSegments||(this.boundsSegments=e.SegmentVector.simpleSegment(0,0,4,2)),this.texture?this.video.paused||(this.texture.bind(r.LINEAR,r.CLAMP_TO_EDGE),r.texSubImage2D(r.TEXTURE_2D,0,0,0,r.RGBA,r.UNSIGNED_BYTE,this.video)):(this.texture=new e.Texture(t,this.video,r.RGBA),this.texture.bind(r.LINEAR,r.CLAMP_TO_EDGE)),this.tiles){var i=this.tiles[n];"loaded"!==i.state&&(i.state="loaded",i.texture=this.texture)}}},r.prototype.serialize=function(){return{type:"video",urls:this.urls,coordinates:this.coordinates}},r.prototype.hasTransition=function(){return this.video&&!this.video.paused},r}(z),N=function(t){function r(r,n,i,o){t.call(this,r,n,i,o),n.coordinates?Array.isArray(n.coordinates)&&4===n.coordinates.length&&!n.coordinates.some((function(e){return!Array.isArray(e)||2!==e.length||e.some((function(e){return"number"!==typeof e}))}))||this.fire(new e.ErrorEvent(new e.ValidationError("sources."+r,null,'"coordinates" property must be an array of 4 longitude/latitude array pairs'))):this.fire(new e.ErrorEvent(new e.ValidationError("sources."+r,null,'missing required property "coordinates"'))),n.animate&&"boolean"!==typeof n.animate&&this.fire(new e.ErrorEvent(new e.ValidationError("sources."+r,null,'optional "animate" property must be a boolean value'))),n.canvas?"string"===typeof n.canvas||n.canvas instanceof e.window.HTMLCanvasElement||this.fire(new e.ErrorEvent(new e.ValidationError("sources."+r,null,'"canvas" must be either a string representing the ID of the canvas element from which to read, or an HTMLCanvasElement instance'))):this.fire(new e.ErrorEvent(new e.ValidationError("sources."+r,null,'missing required property "canvas"'))),this.options=n,this.animate=void 0===n.animate||n.animate}return t&&(r.__proto__=t),r.prototype=Object.create(t&&t.prototype),r.prototype.constructor=r,r.prototype.load=function(){this._loaded=!0,this.canvas||(this.canvas=this.options.canvas instanceof e.window.HTMLCanvasElement?this.options.canvas:e.window.document.getElementById(this.options.canvas)),this.width=this.canvas.width,this.height=this.canvas.height,this._hasInvalidDimensions()?this.fire(new e.ErrorEvent(new Error("Canvas dimensions cannot be less than or equal to zero."))):(this.play=function(){this._playing=!0,this.map.triggerRepaint()},this.pause=function(){this._playing&&(this.prepare(),this._playing=!1)},this._finishLoading())},r.prototype.getCanvas=function(){return this.canvas},r.prototype.onAdd=function(e){this.map=e,this.load(),this.canvas&&this.animate&&this.play()},r.prototype.onRemove=function(){this.pause()},r.prototype.prepare=function(){var t=!1;if(this.canvas.width!==this.width&&(this.width=this.canvas.width,t=!0),this.canvas.height!==this.height&&(this.height=this.canvas.height,t=!0),!this._hasInvalidDimensions()&&0!==Object.keys(this.tiles).length){var r=this.map.painter.context,n=r.gl;for(var i in this.boundsBuffer||(this.boundsBuffer=r.createVertexBuffer(this._boundsArray,D.members)),this.boundsSegments||(this.boundsSegments=e.SegmentVector.simpleSegment(0,0,4,2)),this.texture?(t||this._playing)&&this.texture.update(this.canvas,{premultiply:!0}):this.texture=new e.Texture(r,this.canvas,n.RGBA,{premultiply:!0}),this.tiles){var o=this.tiles[i];"loaded"!==o.state&&(o.state="loaded",o.texture=this.texture)}}},r.prototype.serialize=function(){return{type:"canvas",coordinates:this.coordinates}},r.prototype.hasTransition=function(){return this._playing},r.prototype._hasInvalidDimensions=function(){for(var e=0,t=[this.canvas.width,this.canvas.height];ethis.max){var a=this._getAndRemoveByKey(this.order[0]);a&&this.onRemove(a)}return this},K.prototype.has=function(e){return e.wrapped().key in this.data},K.prototype.getAndRemove=function(e){return this.has(e)?this._getAndRemoveByKey(e.wrapped().key):null},K.prototype._getAndRemoveByKey=function(e){var t=this.data[e].shift();return t.timeout&&clearTimeout(t.timeout),0===this.data[e].length&&delete this.data[e],this.order.splice(this.order.indexOf(e),1),t.value},K.prototype.getByKey=function(e){var t=this.data[e];return t?t[0].value:null},K.prototype.get=function(e){return this.has(e)?this.data[e.wrapped().key][0].value:null},K.prototype.remove=function(e,t){if(!this.has(e))return this;var r=e.wrapped().key,n=void 0===t?0:this.data[r].indexOf(t),i=this.data[r][n];return this.data[r].splice(n,1),i.timeout&&clearTimeout(i.timeout),0===this.data[r].length&&delete this.data[r],this.onRemove(i.value),this.order.splice(this.order.indexOf(r),1),this},K.prototype.setMaxSize=function(e){for(this.max=e;this.order.length>this.max;){var t=this._getAndRemoveByKey(this.order[0]);t&&this.onRemove(t)}return this},K.prototype.filter=function(e){var t=[];for(var r in this.data)for(var n=0,i=this.data[r];n1||(Math.abs(r)>1&&(1===Math.abs(r+i)?r+=i:1===Math.abs(r-i)&&(r-=i)),t.dem&&e.dem&&(e.dem.backfillBorder(t.dem,r,n),e.neighboringTiles&&e.neighboringTiles[o]&&(e.neighboringTiles[o].backfilled=!0)))}},r.prototype.getTile=function(e){return this.getTileByID(e.key)},r.prototype.getTileByID=function(e){return this._tiles[e]},r.prototype._retainLoadedChildren=function(e,t,r,n){for(var i in this._tiles){var o=this._tiles[i];if(!(n[i]||!o.hasData()||o.tileID.overscaledZ<=t||o.tileID.overscaledZ>r)){for(var a=o.tileID;o&&o.tileID.overscaledZ>t+1;){var s=o.tileID.scaledTo(o.tileID.overscaledZ-1);(o=this._tiles[s.key])&&o.hasData()&&(a=s)}for(var l=a;l.overscaledZ>t;)if(e[(l=l.scaledTo(l.overscaledZ-1)).key]){n[a.key]=a;break}}}},r.prototype.findLoadedParent=function(e,t){if(e.key in this._loadedParentTiles){var r=this._loadedParentTiles[e.key];return r&&r.tileID.overscaledZ>=t?r:null}for(var n=e.overscaledZ-1;n>=t;n--){var i=e.scaledTo(n),o=this._getLoadedTile(i);if(o)return o}},r.prototype._getLoadedTile=function(e){var t=this._tiles[e.key];return t&&t.hasData()?t:this._cache.getByKey(e.wrapped().key)},r.prototype.updateCacheSize=function(e){var t=(Math.ceil(e.width/this._source.tileSize)+1)*(Math.ceil(e.height/this._source.tileSize)+1),r=5,n=Math.floor(t*r),i="number"===typeof this._maxTileCacheSize?Math.min(this._maxTileCacheSize,n):n;this._cache.setMaxSize(i)},r.prototype.handleWrapJump=function(e){var t=(e-(void 0===this._prevLng?e:this._prevLng))/360,r=Math.round(t);if(this._prevLng=e,r){var n={};for(var i in this._tiles){var o=this._tiles[i];o.tileID=o.tileID.unwrapTo(o.tileID.wrap+r),n[o.tileID.key]=o}for(var a in this._tiles=n,this._timers)clearTimeout(this._timers[a]),delete this._timers[a];for(var s in this._tiles){var l=this._tiles[s];this._setTileReloadTimer(s,l)}}},r.prototype.update=function(t){var n=this;if(this.transform=t,this._sourceLoaded&&!this._paused){var i;this.updateCacheSize(t),this.handleWrapJump(this.transform.center.lng),this._coveredTiles={},this.used?this._source.tileID?i=t.getVisibleUnwrappedCoordinates(this._source.tileID).map((function(t){return new e.OverscaledTileID(t.canonical.z,t.wrap,t.canonical.z,t.canonical.x,t.canonical.y)})):(i=t.coveringTiles({tileSize:this._source.tileSize,minzoom:this._source.minzoom,maxzoom:this._source.maxzoom,roundZoom:this._source.roundZoom,reparseOverscaled:this._source.reparseOverscaled}),this._source.hasTile&&(i=i.filter((function(e){return n._source.hasTile(e)})))):i=[];var o=t.coveringZoomLevel(this._source),a=Math.max(o-r.maxOverzooming,this._source.minzoom),s=Math.max(o+r.maxUnderzooming,this._source.minzoom),l=this._updateRetainedTiles(i,o);if(Je(this._source.type)){for(var c={},u={},d=0,h=Object.keys(l);dthis._source.maxzoom){var g=f.children(this._source.maxzoom)[0],y=this.getTile(g);if(y&&y.hasData()){n[g.key]=g;continue}}else{var v=f.children(this._source.maxzoom);if(n[v[0].key]&&n[v[1].key]&&n[v[2].key]&&n[v[3].key])continue}for(var x=m.wasRequested(),b=f.overscaledZ-1;b>=o;--b){var _=f.scaledTo(b);if(i[_.key])break;if(i[_.key]=!0,!(m=this.getTile(_))&&x&&(m=this._addTile(_)),m&&(n[_.key]=_,x=m.wasRequested(),m.hasData()))break}}}return n},r.prototype._updateLoadedParentTileCache=function(){for(var e in this._loadedParentTiles={},this._tiles){for(var t=[],r=void 0,n=this._tiles[e].tileID;n.overscaledZ>0;){if(n.key in this._loadedParentTiles){r=this._loadedParentTiles[n.key];break}t.push(n.key);var i=n.scaledTo(n.overscaledZ-1);if(r=this._getLoadedTile(i))break;n=i}for(var o=0,a=t;o0||(t.hasData()&&"reloading"!==t.state?this._cache.add(t.tileID,t,t.getExpiryTimeout()):(t.aborted=!0,this._abortTile(t),this._unloadTile(t))))},r.prototype.clearTiles=function(){for(var e in this._shouldReloadOnResume=!1,this._paused=!1,this._tiles)this._removeTile(e);this._cache.reset()},r.prototype.tilesIn=function(t,r,n){var i=this,o=[],a=this.transform;if(!a)return o;for(var s=n?a.getCameraQueryGeometry(t):t,l=t.map((function(e){return a.pointCoordinate(e)})),c=s.map((function(e){return a.pointCoordinate(e)})),u=this.getIds(),d=1/0,h=1/0,p=-1/0,f=-1/0,m=0,g=c;m=0&&y[1].y+g>=0){var v=l.map((function(e){return s.getTilePoint(e)})),x=c.map((function(e){return s.getTilePoint(e)}));o.push({tile:n,tileID:s,queryGeometry:v,cameraQueryGeometry:x,scale:m})}}},x=0;x=e.browser.now())return!0}return!1},r.prototype.setFeatureState=function(e,t,r){e=e||"_geojsonTileLayer",this._state.updateState(e,t,r)},r.prototype.removeFeatureState=function(e,t,r){e=e||"_geojsonTileLayer",this._state.removeFeatureState(e,t,r)},r.prototype.getFeatureState=function(e,t){return e=e||"_geojsonTileLayer",this._state.getState(e,t)},r.prototype.setDependencies=function(e,t,r){var n=this._tiles[e];n&&n.setDependencies(t,r)},r.prototype.reloadTilesForDependencies=function(e,t){for(var r in this._tiles)this._tiles[r].hasDependency(e,t)&&this._reloadTile(r,"reloading");this._cache.filter((function(r){return!r.hasDependency(e,t)}))},r}(e.Evented);function Ke(e,t){var r=Math.abs(2*e.wrap)-+(e.wrap<0),n=Math.abs(2*t.wrap)-+(t.wrap<0);return e.overscaledZ-t.overscaledZ||n-r||t.canonical.y-e.canonical.y||t.canonical.x-e.canonical.x}function Je(e){return"raster"===e||"image"===e||"video"===e}function Qe(){return new e.window.Worker(fs.workerUrl)}Ze.maxOverzooming=10,Ze.maxUnderzooming=3;var et="mapboxgl_preloaded_worker_pool",tt=function(){this.active={}};tt.prototype.acquire=function(e){if(!this.workers)for(this.workers=[];this.workers.length0?(i-a)/s:0;return this.points[o].mult(1-l).add(this.points[r].mult(l))};var wt=function(e,t,r){var n=this.boxCells=[],i=this.circleCells=[];this.xCellCount=Math.ceil(e/r),this.yCellCount=Math.ceil(t/r);for(var o=0;o=-t[0]&&r<=t[0]&&n>=-t[1]&&n<=t[1]}function Ct(t,r,n,i,o,a,s,l){var c=i?t.textSizeData:t.iconSizeData,u=e.evaluateSizeForZoom(c,n.transform.zoom),d=[256/n.width*2+1,256/n.height*2+1],h=i?t.text.dynamicLayoutVertexArray:t.icon.dynamicLayoutVertexArray;h.clear();for(var p=t.lineVertexArray,f=i?t.text.placedSymbolArray:t.icon.placedSymbolArray,m=n.transform.width/n.transform.height,g=!1,y=0;yMath.abs(n.x-r.x)*i?{useVertical:!0}:(t===e.WritingMode.vertical?r.yn.x)?{needsFlipping:!0}:null}function Pt(t,r,n,i,o,a,s,l,c,u,d,h,p,f){var m,g=r/24,y=t.lineOffsetX*g,v=t.lineOffsetY*g;if(t.numGlyphs>1){var x=t.glyphStartIndex+t.numGlyphs,b=t.lineStartIndex,_=t.lineStartIndex+t.lineLength,w=Et(g,l,y,v,n,d,h,t,c,a,p);if(!w)return{notEnoughRoom:!0};var k=At(w.first.point,s).point,S=At(w.last.point,s).point;if(i&&!n){var A=It(t.writingMode,k,S,f);if(A)return A}m=[w.first];for(var T=t.glyphStartIndex+1;T0?I.point:Ot(h,E,M,1,o),O=It(t.writingMode,M,P,f);if(O)return O}var R=Rt(g*l.getoffsetX(t.glyphStartIndex),y,v,n,d,h,t.segment,t.lineStartIndex,t.lineStartIndex+t.lineLength,c,a,p);if(!R)return{notEnoughRoom:!0};m=[R]}for(var L=0,D=m;L0?1:-1,m=0;i&&(f*=-1,m=Math.PI),f<0&&(m+=Math.PI);for(var g=f>0?l+s:l+s+1,y=o,v=o,x=0,b=0,_=Math.abs(p),w=[];x+b<=_;){if((g+=f)=c)return null;if(v=y,w.push(y),void 0===(y=h[g])){var k=new e.Point(u.getx(g),u.gety(g)),S=At(k,d);if(S.signedDistanceFromCamera>0)y=h[g]=S.point;else{var A=g-f;y=Ot(0===x?a:new e.Point(u.getx(A),u.gety(A)),k,v,_-x+1,d)}}x+=b,b=v.dist(y)}var T=(_-x)/b,M=y.sub(v),C=M.mult(T)._add(v);C._add(M._unit()._perp()._mult(n*f));var E=m+Math.atan2(y.y-v.y,y.x-v.x);return w.push(C),{point:C,angle:E,path:w}}wt.prototype.keysLength=function(){return this.boxKeys.length+this.circleKeys.length},wt.prototype.insert=function(e,t,r,n,i){this._forEachCell(t,r,n,i,this._insertBoxCell,this.boxUid++),this.boxKeys.push(e),this.bboxes.push(t),this.bboxes.push(r),this.bboxes.push(n),this.bboxes.push(i)},wt.prototype.insertCircle=function(e,t,r,n){this._forEachCell(t-n,r-n,t+n,r+n,this._insertCircleCell,this.circleUid++),this.circleKeys.push(e),this.circles.push(t),this.circles.push(r),this.circles.push(n)},wt.prototype._insertBoxCell=function(e,t,r,n,i,o){this.boxCells[i].push(o)},wt.prototype._insertCircleCell=function(e,t,r,n,i,o){this.circleCells[i].push(o)},wt.prototype._query=function(e,t,r,n,i,o){if(r<0||e>this.width||n<0||t>this.height)return!i&&[];var a=[];if(e<=0&&t<=0&&this.width<=r&&this.height<=n){if(i)return!0;for(var s=0;s0:a},wt.prototype._queryCircle=function(e,t,r,n,i){var o=e-r,a=e+r,s=t-r,l=t+r;if(a<0||o>this.width||l<0||s>this.height)return!n&&[];var c=[],u={hitTest:n,circle:{x:e,y:t,radius:r},seenUids:{box:{},circle:{}}};return this._forEachCell(o,s,a,l,this._queryCellCircle,c,u,i),n?c.length>0:c},wt.prototype.query=function(e,t,r,n,i){return this._query(e,t,r,n,!1,i)},wt.prototype.hitTest=function(e,t,r,n,i){return this._query(e,t,r,n,!0,i)},wt.prototype.hitTestCircle=function(e,t,r,n){return this._queryCircle(e,t,r,!0,n)},wt.prototype._queryCell=function(e,t,r,n,i,o,a,s){var l=a.seenUids,c=this.boxCells[i];if(null!==c)for(var u=this.bboxes,d=0,h=c;d=u[f+0]&&n>=u[f+1]&&(!s||s(this.boxKeys[p]))){if(a.hitTest)return o.push(!0),!0;o.push({key:this.boxKeys[p],x1:u[f],y1:u[f+1],x2:u[f+2],y2:u[f+3]})}}}var m=this.circleCells[i];if(null!==m)for(var g=this.circles,y=0,v=m;ya*a+s*s},wt.prototype._circleAndRectCollide=function(e,t,r,n,i,o,a){var s=(o-n)/2,l=Math.abs(e-(n+s));if(l>s+r)return!1;var c=(a-i)/2,u=Math.abs(t-(i+c));if(u>c+r)return!1;if(l<=s||u<=c)return!0;var d=l-s,h=u-c;return d*d+h*h<=r*r};var Lt=new Float32Array([-1/0,-1/0,0,-1/0,-1/0,0,-1/0,-1/0,0,-1/0,-1/0,0]);function Dt(e,t){for(var r=0;r=1;O--)P.push(E.path[O]);for(var R=1;R0){for(var j=P[0].clone(),F=P[0].clone(),N=1;N=T.x&&F.x<=M.x&&j.y>=T.y&&F.y<=M.y?[P]:F.xM.x||F.yM.y?[]:e.clipLine([P],T.x,T.y,M.x,M.y)}for(var B=0,V=z;B=this.screenRightBoundary||nthis.screenBottomBoundary},Ft.prototype.isInsideGrid=function(e,t,r,n){return r>=0&&e=0&&t0?(this.prevPlacement&&this.prevPlacement.variableOffsets[d.crossTileID]&&this.prevPlacement.placements[d.crossTileID]&&this.prevPlacement.placements[d.crossTileID].text&&(m=this.prevPlacement.variableOffsets[d.crossTileID].anchor),this.variableOffsets[d.crossTileID]={textOffset:g,width:r,height:n,anchor:e,textBoxScale:i,prevAnchor:m},this.markUsedJustification(h,e,d,p),h.allowVerticalPlacement&&(this.markUsedOrientation(h,p,d),this.placedOrientations[d.crossTileID]=p),{shift:y,placedGlyphBoxes:v}):void 0},Yt.prototype.placeLayerBucketPart=function(t,r,n){var i=this,o=t.parameters,a=o.bucket,s=o.layout,l=o.posMatrix,c=o.textLabelPlaneMatrix,u=o.labelToScreenMatrix,d=o.textPixelRatio,h=o.holdingForFade,p=o.collisionBoxArray,f=o.partiallyEvaluatedTextSize,m=o.collisionGroup,g=s.get("text-optional"),y=s.get("icon-optional"),v=s.get("text-allow-overlap"),x=s.get("icon-allow-overlap"),b="map"===s.get("text-rotation-alignment"),_="map"===s.get("text-pitch-alignment"),w="none"!==s.get("icon-text-fit"),k="viewport-y"===s.get("symbol-z-order"),S=v&&(x||!a.hasIconData()||y),A=x&&(v||!a.hasTextData()||g);!a.collisionArrays&&p&&a.deserializeCollisionBoxes(p);var T=function(t,o){if(!r[t.crossTileID])if(h)i.placements[t.crossTileID]=new Ut(!1,!1,!1);else{var p=!1,k=!1,T=!0,M=null,C={box:null,offscreen:null},E={box:null,offscreen:null},I=null,P=null,O=null,R=0,L=0,D=0;o.textFeatureIndex?R=o.textFeatureIndex:t.useRuntimeCollisionCircles&&(R=t.featureIndex),o.verticalTextFeatureIndex&&(L=o.verticalTextFeatureIndex);var z=o.textBox;if(z){var j=function(r){var n=e.WritingMode.horizontal;if(a.allowVerticalPlacement&&!r&&i.prevPlacement){var o=i.prevPlacement.placedOrientations[t.crossTileID];o&&(i.placedOrientations[t.crossTileID]=o,n=o,i.markUsedOrientation(a,n,t))}return n},F=function(r,n){if(a.allowVerticalPlacement&&t.numVerticalGlyphVertices>0&&o.verticalTextBox)for(var i=0,s=a.writingModes;i0&&(N=N.filter((function(e){return e!==B.anchor}))).unshift(B.anchor)}var V=function(e,r,n){for(var o=e.x2-e.x1,s=e.y2-e.y1,c=t.textBoxScale,u=w&&!x?r:null,h={box:[],offscreen:!1},f=v?2*N.length:N.length,g=0;g=N.length,S=i.attemptAnchorPlacement(y,e,o,s,c,b,_,d,l,m,k,t,a,n,u);if(S&&(h=S.placedGlyphBoxes)&&h.box&&h.box.length){p=!0,M=S.shift;break}}return h};F((function(){return V(z,o.iconBox,e.WritingMode.horizontal)}),(function(){var r=o.verticalTextBox,n=C&&C.box&&C.box.length;return a.allowVerticalPlacement&&!n&&t.numVerticalGlyphVertices>0&&r?V(r,o.verticalIconBox,e.WritingMode.vertical):{box:null,offscreen:null}})),C&&(p=C.box,T=C.offscreen);var U=j(C&&C.box);if(!p&&i.prevPlacement){var H=i.prevPlacement.variableOffsets[t.crossTileID];H&&(i.variableOffsets[t.crossTileID]=H,i.markUsedJustification(a,H.anchor,t,U))}}else{var $=function(e,r){var n=i.collisionIndex.placeCollisionBox(e,v,d,l,m.predicate);return n&&n.box&&n.box.length&&(i.markUsedOrientation(a,r,t),i.placedOrientations[t.crossTileID]=r),n};F((function(){return $(z,e.WritingMode.horizontal)}),(function(){var r=o.verticalTextBox;return a.allowVerticalPlacement&&t.numVerticalGlyphVertices>0&&r?$(r,e.WritingMode.vertical):{box:null,offscreen:null}})),j(C&&C.box&&C.box.length)}}if(p=(I=C)&&I.box&&I.box.length>0,T=I&&I.offscreen,t.useRuntimeCollisionCircles){var W=a.text.placedSymbolArray.get(t.centerJustifiedTextSymbolIndex),q=e.evaluateSizeForFeature(a.textSizeData,f,W),G=s.get("text-padding"),Y=t.collisionCircleDiameter;P=i.collisionIndex.placeCollisionCircles(v,W,a.lineVertexArray,a.glyphOffsetArray,q,l,c,u,n,_,m.predicate,Y,G),p=v||P.circles.length>0&&!P.collisionDetected,T=T&&P.offscreen}if(o.iconFeatureIndex&&(D=o.iconFeatureIndex),o.iconBox){var X=function(e){var t=w&&M?Gt(e,M.x,M.y,b,_,i.transform.angle):e;return i.collisionIndex.placeCollisionBox(t,x,d,l,m.predicate)};k=E&&E.box&&E.box.length&&o.verticalIconBox?(O=X(o.verticalIconBox)).box.length>0:(O=X(o.iconBox)).box.length>0,T=T&&O.offscreen}var Z=g||0===t.numHorizontalGlyphVertices&&0===t.numVerticalGlyphVertices,K=y||0===t.numIconVertices;if(Z||K?K?Z||(k=k&&p):p=k&&p:k=p=k&&p,p&&I&&I.box&&(E&&E.box&&L?i.collisionIndex.insertCollisionBox(I.box,s.get("text-ignore-placement"),a.bucketInstanceId,L,m.ID):i.collisionIndex.insertCollisionBox(I.box,s.get("text-ignore-placement"),a.bucketInstanceId,R,m.ID)),k&&O&&i.collisionIndex.insertCollisionBox(O.box,s.get("icon-ignore-placement"),a.bucketInstanceId,D,m.ID),P&&(p&&i.collisionIndex.insertCollisionCircles(P.circles,s.get("text-ignore-placement"),a.bucketInstanceId,R,m.ID),n)){var J=a.bucketInstanceId,Q=i.collisionCircleArrays[J];void 0===Q&&(Q=i.collisionCircleArrays[J]=new Ht);for(var ee=0;ee=0;--C){var E=M[C];T(a.symbolInstances.get(E),a.collisionArrays[E])}else for(var I=t.symbolInstanceStart;I=0&&(t.text.placedSymbolArray.get(c).crossTileID=o>=0&&c!==o?0:n.crossTileID)}},Yt.prototype.markUsedOrientation=function(t,r,n){for(var i=r===e.WritingMode.horizontal||r===e.WritingMode.horizontalOnly?r:0,o=r===e.WritingMode.vertical?r:0,a=0,s=[n.leftJustifiedTextSymbolIndex,n.centerJustifiedTextSymbolIndex,n.rightJustifiedTextSymbolIndex];a0||l>0,x=o.numIconVertices>0,b=i.placedOrientations[o.crossTileID],_=b===e.WritingMode.vertical,w=b===e.WritingMode.horizontal||b===e.WritingMode.horizontalOnly;if(v){var k=nr(y.text),S=_?ir:k;f(t.text,s,S);var A=w?ir:k;f(t.text,l,A);var T=y.text.isHidden();[o.rightJustifiedTextSymbolIndex,o.centerJustifiedTextSymbolIndex,o.leftJustifiedTextSymbolIndex].forEach((function(e){e>=0&&(t.text.placedSymbolArray.get(e).hidden=T||_?1:0)})),o.verticalPlacedTextSymbolIndex>=0&&(t.text.placedSymbolArray.get(o.verticalPlacedTextSymbolIndex).hidden=T||w?1:0);var M=i.variableOffsets[o.crossTileID];M&&i.markUsedJustification(t,M.anchor,o,b);var C=i.placedOrientations[o.crossTileID];C&&(i.markUsedJustification(t,"left",o,C),i.markUsedOrientation(t,C,o))}if(x){var E=nr(y.icon),I=!(h&&o.verticalPlacedIconSymbolIndex&&_);if(o.placedIconSymbolIndex>=0){var P=I?E:ir;f(t.icon,o.numIconVertices,P),t.icon.placedSymbolArray.get(o.placedIconSymbolIndex).hidden=y.icon.isHidden()}if(o.verticalPlacedIconSymbolIndex>=0){var O=I?ir:E;f(t.icon,o.numVerticalIconVertices,O),t.icon.placedSymbolArray.get(o.verticalPlacedIconSymbolIndex).hidden=y.icon.isHidden()}}if(t.hasIconCollisionBoxData()||t.hasTextCollisionBoxData()){var R=t.collisionArrays[n];if(R){var L=new e.Point(0,0);if(R.textBox||R.verticalTextBox){var D=!0;if(c){var z=i.variableOffsets[m];z?(L=qt(z.anchor,z.width,z.height,z.textOffset,z.textBoxScale),u&&L._rotate(d?i.transform.angle:-i.transform.angle)):D=!1}R.textBox&&Xt(t.textCollisionBox.collisionVertexArray,y.text.placed,!D||_,L.x,L.y),R.verticalTextBox&&Xt(t.textCollisionBox.collisionVertexArray,y.text.placed,!D||w,L.x,L.y)}var j=Boolean(!w&&R.verticalIconBox);R.iconBox&&Xt(t.iconCollisionBox.collisionVertexArray,y.icon.placed,j,h?L.x:0,h?L.y:0),R.verticalIconBox&&Xt(t.iconCollisionBox.collisionVertexArray,y.icon.placed,!j,h?L.x:0,h?L.y:0)}}},g=0;ge},Yt.prototype.setStale=function(){this.stale=!0};var Zt=Math.pow(2,25),Kt=Math.pow(2,24),Jt=Math.pow(2,17),Qt=Math.pow(2,16),er=Math.pow(2,9),tr=Math.pow(2,8),rr=Math.pow(2,1);function nr(e){if(0===e.opacity&&!e.placed)return 0;if(1===e.opacity&&e.placed)return 4294967295;var t=e.placed?1:0,r=Math.floor(127*e.opacity);return r*Zt+t*Kt+r*Jt+t*Qt+r*er+t*tr+r*rr+t}var ir=0,or=function(e){this._sortAcrossTiles="viewport-y"!==e.layout.get("symbol-z-order")&&void 0!==e.layout.get("symbol-sort-key").constantOr(1),this._currentTileIndex=0,this._currentPartIndex=0,this._seenCrossTileIDs={},this._bucketParts=[]};or.prototype.continuePlacement=function(e,t,r,n,i){for(var o=this._bucketParts;this._currentTileIndex2};this._currentPlacementIndex>=0;){var s=r[t[this._currentPlacementIndex]],l=this.placement.collisionIndex.transform.zoom;if("symbol"===s.type&&(!s.minzoom||s.minzoom<=l)&&(!s.maxzoom||s.maxzoom>l)){if(this._inProgressLayer||(this._inProgressLayer=new or(s)),this._inProgressLayer.continuePlacement(n[s.source],this.placement,this._showCollisionBoxes,s,a))return;delete this._inProgressLayer}this._currentPlacementIndex--}this._done=!0},ar.prototype.commit=function(e){return this.placement.commit(e),this.placement};var sr=512/e.EXTENT/2,lr=function(e,t,r){this.tileID=e,this.indexedSymbolInstances={},this.bucketInstanceId=r;for(var n=0;ne.overscaledZ)for(var s in a){var l=a[s];l.tileID.isChildOf(e)&&l.findMatches(t.symbolInstances,e,i)}else{var c=a[e.scaledTo(Number(o)).key];c&&c.findMatches(t.symbolInstances,e,i)}}for(var u=0;u0)throw new Error("Unimplemented: "+i.map((function(e){return e.command})).join(", ")+".");return n.forEach((function(e){"setTransition"!==e.command&&r[e.command].apply(r,e.args)})),this.stylesheet=t,!0},r.prototype.addImage=function(t,r){if(this.getImage(t))return this.fire(new e.ErrorEvent(new Error("An image with this name already exists.")));this.imageManager.addImage(t,r),this._afterImageUpdated(t)},r.prototype.updateImage=function(e,t){this.imageManager.updateImage(e,t)},r.prototype.getImage=function(e){return this.imageManager.getImage(e)},r.prototype.removeImage=function(t){if(!this.getImage(t))return this.fire(new e.ErrorEvent(new Error("No image with this name exists.")));this.imageManager.removeImage(t),this._afterImageUpdated(t)},r.prototype._afterImageUpdated=function(t){this._availableImages=this.imageManager.listImages(),this._changedImages[t]=!0,this._changed=!0,this.dispatcher.broadcast("setImages",this._availableImages),this.fire(new e.Event("data",{dataType:"style"}))},r.prototype.listImages=function(){return this._checkLoaded(),this.imageManager.listImages()},r.prototype.addSource=function(t,r,n){var i=this;if(void 0===n&&(n={}),this._checkLoaded(),void 0!==this.sourceCaches[t])throw new Error("There is already a source with this ID");if(!r.type)throw new Error("The type property must be defined, but only the following properties were given: "+Object.keys(r).join(", ")+".");if(!(["vector","raster","geojson","video","image"].indexOf(r.type)>=0)||!this._validate(e.validateStyle.source,"sources."+t,r,null,n)){this.map&&this.map._collectResourceTiming&&(r.collectResourceTiming=!0);var o=this.sourceCaches[t]=new Ze(t,r,this.dispatcher);o.style=this,o.setEventedParent(this,(function(){return{isSourceLoaded:i.loaded(),source:o.serialize(),sourceId:t}})),o.onAdd(this.map),this._changed=!0}},r.prototype.removeSource=function(t){if(this._checkLoaded(),void 0===this.sourceCaches[t])throw new Error("There is no source with this ID");for(var r in this._layers)if(this._layers[r].source===t)return this.fire(new e.ErrorEvent(new Error('Source "'+t+'" cannot be removed while layer "'+r+'" is using it.')));var n=this.sourceCaches[t];delete this.sourceCaches[t],delete this._updatedSources[t],n.fire(new e.Event("data",{sourceDataType:"metadata",dataType:"source",sourceId:t})),n.setEventedParent(null),n.clearTiles(),n.onRemove&&n.onRemove(this.map),this._changed=!0},r.prototype.setGeoJSONSourceData=function(e,t){this._checkLoaded(),this.sourceCaches[e].getSource().setData(t),this._changed=!0},r.prototype.getSource=function(e){return this.sourceCaches[e]&&this.sourceCaches[e].getSource()},r.prototype.addLayer=function(t,r,n){void 0===n&&(n={}),this._checkLoaded();var i=t.id;if(this.getLayer(i))this.fire(new e.ErrorEvent(new Error('Layer with id "'+i+'" already exists on this map')));else{var o;if("custom"===t.type){if(hr(this,e.validateCustomStyleLayer(t)))return;o=e.createStyleLayer(t)}else{if("object"===typeof t.source&&(this.addSource(i,t.source),t=e.clone$1(t),t=e.extend(t,{source:i})),this._validate(e.validateStyle.layer,"layers."+i,t,{arrayIndex:-1},n))return;o=e.createStyleLayer(t),this._validateLayer(o),o.setEventedParent(this,{layer:{id:i}}),this._serializedLayers[o.id]=o.serialize()}var a=r?this._order.indexOf(r):this._order.length;if(r&&-1===a)this.fire(new e.ErrorEvent(new Error('Layer with id "'+r+'" does not exist on this map.')));else{if(this._order.splice(a,0,i),this._layerOrderChanged=!0,this._layers[i]=o,this._removedLayers[i]&&o.source&&"custom"!==o.type){var s=this._removedLayers[i];delete this._removedLayers[i],s.type!==o.type?this._updatedSources[o.source]="clear":(this._updatedSources[o.source]="reload",this.sourceCaches[o.source].pause())}this._updateLayer(o),o.onAdd&&o.onAdd(this.map)}}},r.prototype.moveLayer=function(t,r){if(this._checkLoaded(),this._changed=!0,this._layers[t]){if(t!==r){var n=this._order.indexOf(t);this._order.splice(n,1);var i=r?this._order.indexOf(r):this._order.length;r&&-1===i?this.fire(new e.ErrorEvent(new Error('Layer with id "'+r+'" does not exist on this map.'))):(this._order.splice(i,0,t),this._layerOrderChanged=!0)}}else this.fire(new e.ErrorEvent(new Error("The layer '"+t+"' does not exist in the map's style and cannot be moved.")))},r.prototype.removeLayer=function(t){this._checkLoaded();var r=this._layers[t];if(r){r.setEventedParent(null);var n=this._order.indexOf(t);this._order.splice(n,1),this._layerOrderChanged=!0,this._changed=!0,this._removedLayers[t]=r,delete this._layers[t],delete this._serializedLayers[t],delete this._updatedLayers[t],delete this._updatedPaintProps[t],r.onRemove&&r.onRemove(this.map)}else this.fire(new e.ErrorEvent(new Error("The layer '"+t+"' does not exist in the map's style and cannot be removed.")))},r.prototype.getLayer=function(e){return this._layers[e]},r.prototype.hasLayer=function(e){return e in this._layers},r.prototype.setLayerZoomRange=function(t,r,n){this._checkLoaded();var i=this.getLayer(t);i?i.minzoom===r&&i.maxzoom===n||(null!=r&&(i.minzoom=r),null!=n&&(i.maxzoom=n),this._updateLayer(i)):this.fire(new e.ErrorEvent(new Error("The layer '"+t+"' does not exist in the map's style and cannot have zoom extent.")))},r.prototype.setFilter=function(t,r,n){void 0===n&&(n={}),this._checkLoaded();var i=this.getLayer(t);if(i){if(!e.deepEqual(i.filter,r))return null===r||void 0===r?(i.filter=void 0,void this._updateLayer(i)):void(this._validate(e.validateStyle.filter,"layers."+i.id+".filter",r,null,n)||(i.filter=e.clone$1(r),this._updateLayer(i)))}else this.fire(new e.ErrorEvent(new Error("The layer '"+t+"' does not exist in the map's style and cannot be filtered.")))},r.prototype.getFilter=function(t){return e.clone$1(this.getLayer(t).filter)},r.prototype.setLayoutProperty=function(t,r,n,i){void 0===i&&(i={}),this._checkLoaded();var o=this.getLayer(t);o?e.deepEqual(o.getLayoutProperty(r),n)||(o.setLayoutProperty(r,n,i),this._updateLayer(o)):this.fire(new e.ErrorEvent(new Error("The layer '"+t+"' does not exist in the map's style and cannot be styled.")))},r.prototype.getLayoutProperty=function(t,r){var n=this.getLayer(t);if(n)return n.getLayoutProperty(r);this.fire(new e.ErrorEvent(new Error("The layer '"+t+"' does not exist in the map's style.")))},r.prototype.setPaintProperty=function(t,r,n,i){void 0===i&&(i={}),this._checkLoaded();var o=this.getLayer(t);o?e.deepEqual(o.getPaintProperty(r),n)||(o.setPaintProperty(r,n,i)&&this._updateLayer(o),this._changed=!0,this._updatedPaintProps[t]=!0):this.fire(new e.ErrorEvent(new Error("The layer '"+t+"' does not exist in the map's style and cannot be styled.")))},r.prototype.getPaintProperty=function(e,t){return this.getLayer(e).getPaintProperty(t)},r.prototype.setFeatureState=function(t,r){this._checkLoaded();var n=t.source,i=t.sourceLayer,o=this.sourceCaches[n];if(void 0!==o){var a=o.getSource().type;"geojson"===a&&i?this.fire(new e.ErrorEvent(new Error("GeoJSON sources cannot have a sourceLayer parameter."))):"vector"!==a||i?(void 0===t.id&&this.fire(new e.ErrorEvent(new Error("The feature id parameter must be provided."))),o.setFeatureState(i,t.id,r)):this.fire(new e.ErrorEvent(new Error("The sourceLayer parameter must be provided for vector source types.")))}else this.fire(new e.ErrorEvent(new Error("The source '"+n+"' does not exist in the map's style.")))},r.prototype.removeFeatureState=function(t,r){this._checkLoaded();var n=t.source,i=this.sourceCaches[n];if(void 0!==i){var o=i.getSource().type,a="vector"===o?t.sourceLayer:void 0;"vector"!==o||a?r&&"string"!==typeof t.id&&"number"!==typeof t.id?this.fire(new e.ErrorEvent(new Error("A feature id is required to remove its specific state property."))):i.removeFeatureState(a,t.id,r):this.fire(new e.ErrorEvent(new Error("The sourceLayer parameter must be provided for vector source types.")))}else this.fire(new e.ErrorEvent(new Error("The source '"+n+"' does not exist in the map's style.")))},r.prototype.getFeatureState=function(t){this._checkLoaded();var r=t.source,n=t.sourceLayer,i=this.sourceCaches[r];if(void 0!==i){if("vector"!==i.getSource().type||n)return void 0===t.id&&this.fire(new e.ErrorEvent(new Error("The feature id parameter must be provided."))),i.getFeatureState(n,t.id);this.fire(new e.ErrorEvent(new Error("The sourceLayer parameter must be provided for vector source types.")))}else this.fire(new e.ErrorEvent(new Error("The source '"+r+"' does not exist in the map's style.")))},r.prototype.getTransition=function(){return e.extend({duration:300,delay:0},this.stylesheet&&this.stylesheet.transition)},r.prototype.serialize=function(){return e.filterObject({version:this.stylesheet.version,name:this.stylesheet.name,metadata:this.stylesheet.metadata,light:this.stylesheet.light,center:this.stylesheet.center,zoom:this.stylesheet.zoom,bearing:this.stylesheet.bearing,pitch:this.stylesheet.pitch,sprite:this.stylesheet.sprite,glyphs:this.stylesheet.glyphs,transition:this.stylesheet.transition,sources:e.mapObject(this.sourceCaches,(function(e){return e.serialize()})),layers:this._serializeLayers(this._order)},(function(e){return void 0!==e}))},r.prototype._updateLayer=function(e){this._updatedLayers[e.id]=!0,e.source&&!this._updatedSources[e.source]&&"raster"!==this.sourceCaches[e.source].getSource().type&&(this._updatedSources[e.source]="reload",this.sourceCaches[e.source].pause()),this._changed=!0},r.prototype._flattenAndSortRenderedFeatures=function(e){for(var t=this,r=function(e){return"fill-extrusion"===t._layers[e].type},n={},i=[],o=this._order.length-1;o>=0;o--){var a=this._order[o];if(r(a)){n[a]=o;for(var s=0,l=e;s=0;f--){var m=this._order[f];if(r(m))for(var g=i.length-1;g>=0;g--){var y=i[g].feature;if(n[y.layer.id] 0.5) {gl_FragColor=vec4(0.0,0.0,1.0,0.5)*alpha;}if (v_notUsed > 0.5) {gl_FragColor*=.1;}}",Pr="attribute vec2 a_pos;attribute vec2 a_anchor_pos;attribute vec2 a_extrude;attribute vec2 a_placed;attribute vec2 a_shift;uniform mat4 u_matrix;uniform vec2 u_extrude_scale;uniform float u_camera_to_center_distance;varying float v_placed;varying float v_notUsed;void main() {vec4 projectedPoint=u_matrix*vec4(a_anchor_pos,0,1);highp float camera_to_anchor_distance=projectedPoint.w;highp float collision_perspective_ratio=clamp(0.5+0.5*(u_camera_to_center_distance/camera_to_anchor_distance),0.0,4.0);gl_Position=u_matrix*vec4(a_pos,0.0,1.0);gl_Position.xy+=(a_extrude+a_shift)*u_extrude_scale*gl_Position.w*collision_perspective_ratio;v_placed=a_placed.x;v_notUsed=a_placed.y;}",Or="varying float v_radius;varying vec2 v_extrude;varying float v_perspective_ratio;varying float v_collision;void main() {float alpha=0.5*min(v_perspective_ratio,1.0);float stroke_radius=0.9*max(v_perspective_ratio,1.0);float distance_to_center=length(v_extrude);float distance_to_edge=abs(distance_to_center-v_radius);float opacity_t=smoothstep(-stroke_radius,0.0,-distance_to_edge);vec4 color=mix(vec4(0.0,0.0,1.0,0.5),vec4(1.0,0.0,0.0,1.0),v_collision);gl_FragColor=color*alpha*opacity_t;}",Rr="attribute vec2 a_pos;attribute float a_radius;attribute vec2 a_flags;uniform mat4 u_matrix;uniform mat4 u_inv_matrix;uniform vec2 u_viewport_size;uniform float u_camera_to_center_distance;varying float v_radius;varying vec2 v_extrude;varying float v_perspective_ratio;varying float v_collision;vec3 toTilePosition(vec2 screenPos) {vec4 rayStart=u_inv_matrix*vec4(screenPos,-1.0,1.0);vec4 rayEnd =u_inv_matrix*vec4(screenPos, 1.0,1.0);rayStart.xyz/=rayStart.w;rayEnd.xyz /=rayEnd.w;highp float t=(0.0-rayStart.z)/(rayEnd.z-rayStart.z);return mix(rayStart.xyz,rayEnd.xyz,t);}void main() {vec2 quadCenterPos=a_pos;float radius=a_radius;float collision=a_flags.x;float vertexIdx=a_flags.y;vec2 quadVertexOffset=vec2(mix(-1.0,1.0,float(vertexIdx >=2.0)),mix(-1.0,1.0,float(vertexIdx >=1.0 && vertexIdx <=2.0)));vec2 quadVertexExtent=quadVertexOffset*radius;vec3 tilePos=toTilePosition(quadCenterPos);vec4 clipPos=u_matrix*vec4(tilePos,1.0);highp float camera_to_anchor_distance=clipPos.w;highp float collision_perspective_ratio=clamp(0.5+0.5*(u_camera_to_center_distance/camera_to_anchor_distance),0.0,4.0);float padding_factor=1.2;v_radius=radius;v_extrude=quadVertexExtent*padding_factor;v_perspective_ratio=collision_perspective_ratio;v_collision=collision;gl_Position=vec4(clipPos.xyz/clipPos.w,1.0)+vec4(quadVertexExtent*padding_factor/u_viewport_size*2.0,0.0,0.0);}",Lr="uniform highp vec4 u_color;uniform sampler2D u_overlay;varying vec2 v_uv;void main() {vec4 overlay_color=texture2D(u_overlay,v_uv);gl_FragColor=mix(u_color,overlay_color,overlay_color.a);}",Dr="attribute vec2 a_pos;varying vec2 v_uv;uniform mat4 u_matrix;uniform float u_overlay_scale;void main() {v_uv=a_pos/8192.0;gl_Position=u_matrix*vec4(a_pos*u_overlay_scale,0,1);}",zr="#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float opacity\ngl_FragColor=color*opacity;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",jr="attribute vec2 a_pos;uniform mat4 u_matrix;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float opacity\ngl_Position=u_matrix*vec4(a_pos,0,1);}",Fr="varying vec2 v_pos;\n#pragma mapbox: define highp vec4 outline_color\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize highp vec4 outline_color\n#pragma mapbox: initialize lowp float opacity\nfloat dist=length(v_pos-gl_FragCoord.xy);float alpha=1.0-smoothstep(0.0,1.0,dist);gl_FragColor=outline_color*(alpha*opacity);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",Nr="attribute vec2 a_pos;uniform mat4 u_matrix;uniform vec2 u_world;varying vec2 v_pos;\n#pragma mapbox: define highp vec4 outline_color\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize highp vec4 outline_color\n#pragma mapbox: initialize lowp float opacity\ngl_Position=u_matrix*vec4(a_pos,0,1);v_pos=(gl_Position.xy/gl_Position.w+1.0)/2.0*u_world;}",Br="uniform vec2 u_texsize;uniform sampler2D u_image;uniform float u_fade;varying vec2 v_pos_a;varying vec2 v_pos_b;varying vec2 v_pos;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(pattern_tl_a/u_texsize,pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(pattern_tl_b/u_texsize,pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);float dist=length(v_pos-gl_FragCoord.xy);float alpha=1.0-smoothstep(0.0,1.0,dist);gl_FragColor=mix(color1,color2,u_fade)*alpha*opacity;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",Vr="uniform mat4 u_matrix;uniform vec2 u_world;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform vec3 u_scale;attribute vec2 a_pos;varying vec2 v_pos_a;varying vec2 v_pos_b;varying vec2 v_pos;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\n#pragma mapbox: define lowp float pixel_ratio_from\n#pragma mapbox: define lowp float pixel_ratio_to\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\n#pragma mapbox: initialize lowp float pixel_ratio_from\n#pragma mapbox: initialize lowp float pixel_ratio_to\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;gl_Position=u_matrix*vec4(a_pos,0,1);vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,fromScale*display_size_a,tileRatio,a_pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,toScale*display_size_b,tileRatio,a_pos);v_pos=(gl_Position.xy/gl_Position.w+1.0)/2.0*u_world;}",Ur="uniform vec2 u_texsize;uniform float u_fade;uniform sampler2D u_image;varying vec2 v_pos_a;varying vec2 v_pos_b;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(pattern_tl_a/u_texsize,pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(pattern_tl_b/u_texsize,pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);gl_FragColor=mix(color1,color2,u_fade)*opacity;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",Hr="uniform mat4 u_matrix;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform vec3 u_scale;attribute vec2 a_pos;varying vec2 v_pos_a;varying vec2 v_pos_b;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\n#pragma mapbox: define lowp float pixel_ratio_from\n#pragma mapbox: define lowp float pixel_ratio_to\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\n#pragma mapbox: initialize lowp float pixel_ratio_from\n#pragma mapbox: initialize lowp float pixel_ratio_to\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileZoomRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;gl_Position=u_matrix*vec4(a_pos,0,1);v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,fromScale*display_size_a,tileZoomRatio,a_pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,toScale*display_size_b,tileZoomRatio,a_pos);}",$r="varying vec4 v_color;void main() {gl_FragColor=v_color;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",Wr="uniform mat4 u_matrix;uniform vec3 u_lightcolor;uniform lowp vec3 u_lightpos;uniform lowp float u_lightintensity;uniform float u_vertical_gradient;uniform lowp float u_opacity;attribute vec2 a_pos;attribute vec4 a_normal_ed;varying vec4 v_color;\n#pragma mapbox: define highp float base\n#pragma mapbox: define highp float height\n#pragma mapbox: define highp vec4 color\nvoid main() {\n#pragma mapbox: initialize highp float base\n#pragma mapbox: initialize highp float height\n#pragma mapbox: initialize highp vec4 color\nvec3 normal=a_normal_ed.xyz;base=max(0.0,base);height=max(0.0,height);float t=mod(normal.x,2.0);gl_Position=u_matrix*vec4(a_pos,t > 0.0 ? height : base,1);float colorvalue=color.r*0.2126+color.g*0.7152+color.b*0.0722;v_color=vec4(0.0,0.0,0.0,1.0);vec4 ambientlight=vec4(0.03,0.03,0.03,1.0);color+=ambientlight;float directional=clamp(dot(normal/16384.0,u_lightpos),0.0,1.0);directional=mix((1.0-u_lightintensity),max((1.0-colorvalue+u_lightintensity),1.0),directional);if (normal.y !=0.0) {directional*=((1.0-u_vertical_gradient)+(u_vertical_gradient*clamp((t+base)*pow(height/150.0,0.5),mix(0.7,0.98,1.0-u_lightintensity),1.0)));}v_color.r+=clamp(color.r*directional*u_lightcolor.r,mix(0.0,0.3,1.0-u_lightcolor.r),1.0);v_color.g+=clamp(color.g*directional*u_lightcolor.g,mix(0.0,0.3,1.0-u_lightcolor.g),1.0);v_color.b+=clamp(color.b*directional*u_lightcolor.b,mix(0.0,0.3,1.0-u_lightcolor.b),1.0);v_color*=u_opacity;}",qr="uniform vec2 u_texsize;uniform float u_fade;uniform sampler2D u_image;varying vec2 v_pos_a;varying vec2 v_pos_b;varying vec4 v_lighting;\n#pragma mapbox: define lowp float base\n#pragma mapbox: define lowp float height\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\n#pragma mapbox: define lowp float pixel_ratio_from\n#pragma mapbox: define lowp float pixel_ratio_to\nvoid main() {\n#pragma mapbox: initialize lowp float base\n#pragma mapbox: initialize lowp float height\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\n#pragma mapbox: initialize lowp float pixel_ratio_from\n#pragma mapbox: initialize lowp float pixel_ratio_to\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(pattern_tl_a/u_texsize,pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(pattern_tl_b/u_texsize,pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);vec4 mixedColor=mix(color1,color2,u_fade);gl_FragColor=mixedColor*v_lighting;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",Gr="uniform mat4 u_matrix;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform float u_height_factor;uniform vec3 u_scale;uniform float u_vertical_gradient;uniform lowp float u_opacity;uniform vec3 u_lightcolor;uniform lowp vec3 u_lightpos;uniform lowp float u_lightintensity;attribute vec2 a_pos;attribute vec4 a_normal_ed;varying vec2 v_pos_a;varying vec2 v_pos_b;varying vec4 v_lighting;\n#pragma mapbox: define lowp float base\n#pragma mapbox: define lowp float height\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\n#pragma mapbox: define lowp float pixel_ratio_from\n#pragma mapbox: define lowp float pixel_ratio_to\nvoid main() {\n#pragma mapbox: initialize lowp float base\n#pragma mapbox: initialize lowp float height\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\n#pragma mapbox: initialize lowp float pixel_ratio_from\n#pragma mapbox: initialize lowp float pixel_ratio_to\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;vec3 normal=a_normal_ed.xyz;float edgedistance=a_normal_ed.w;vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;base=max(0.0,base);height=max(0.0,height);float t=mod(normal.x,2.0);float z=t > 0.0 ? height : base;gl_Position=u_matrix*vec4(a_pos,z,1);vec2 pos=normal.x==1.0 && normal.y==0.0 && normal.z==16384.0\n? a_pos\n: vec2(edgedistance,z*u_height_factor);v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,fromScale*display_size_a,tileRatio,pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,toScale*display_size_b,tileRatio,pos);v_lighting=vec4(0.0,0.0,0.0,1.0);float directional=clamp(dot(normal/16383.0,u_lightpos),0.0,1.0);directional=mix((1.0-u_lightintensity),max((0.5+u_lightintensity),1.0),directional);if (normal.y !=0.0) {directional*=((1.0-u_vertical_gradient)+(u_vertical_gradient*clamp((t+base)*pow(height/150.0,0.5),mix(0.7,0.98,1.0-u_lightintensity),1.0)));}v_lighting.rgb+=clamp(directional*u_lightcolor,mix(vec3(0.0),vec3(0.3),1.0-u_lightcolor),vec3(1.0));v_lighting*=u_opacity;}",Yr="#ifdef GL_ES\nprecision highp float;\n#endif\nuniform sampler2D u_image;varying vec2 v_pos;uniform vec2 u_dimension;uniform float u_zoom;uniform vec4 u_unpack;float getElevation(vec2 coord,float bias) {vec4 data=texture2D(u_image,coord)*255.0;data.a=-1.0;return dot(data,u_unpack)/4.0;}void main() {vec2 epsilon=1.0/u_dimension;float a=getElevation(v_pos+vec2(-epsilon.x,-epsilon.y),0.0);float b=getElevation(v_pos+vec2(0,-epsilon.y),0.0);float c=getElevation(v_pos+vec2(epsilon.x,-epsilon.y),0.0);float d=getElevation(v_pos+vec2(-epsilon.x,0),0.0);float e=getElevation(v_pos,0.0);float f=getElevation(v_pos+vec2(epsilon.x,0),0.0);float g=getElevation(v_pos+vec2(-epsilon.x,epsilon.y),0.0);float h=getElevation(v_pos+vec2(0,epsilon.y),0.0);float i=getElevation(v_pos+vec2(epsilon.x,epsilon.y),0.0);float exaggerationFactor=u_zoom < 2.0 ? 0.4 : u_zoom < 4.5 ? 0.35 : 0.3;float exaggeration=u_zoom < 15.0 ? (u_zoom-15.0)*exaggerationFactor : 0.0;vec2 deriv=vec2((c+f+f+i)-(a+d+d+g),(g+h+h+i)-(a+b+b+c))/pow(2.0,exaggeration+(19.2562-u_zoom));gl_FragColor=clamp(vec4(deriv.x/2.0+0.5,deriv.y/2.0+0.5,1.0,1.0),0.0,1.0);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",Xr="uniform mat4 u_matrix;uniform vec2 u_dimension;attribute vec2 a_pos;attribute vec2 a_texture_pos;varying vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);highp vec2 epsilon=1.0/u_dimension;float scale=(u_dimension.x-2.0)/u_dimension.x;v_pos=(a_texture_pos/8192.0)*scale+epsilon;}",Zr="uniform sampler2D u_image;varying vec2 v_pos;uniform vec2 u_latrange;uniform vec2 u_light;uniform vec4 u_shadow;uniform vec4 u_highlight;uniform vec4 u_accent;\n#define PI 3.141592653589793\nvoid main() {vec4 pixel=texture2D(u_image,v_pos);vec2 deriv=((pixel.rg*2.0)-1.0);float scaleFactor=cos(radians((u_latrange[0]-u_latrange[1])*(1.0-v_pos.y)+u_latrange[1]));float slope=atan(1.25*length(deriv)/scaleFactor);float aspect=deriv.x !=0.0 ? atan(deriv.y,-deriv.x) : PI/2.0*(deriv.y > 0.0 ? 1.0 :-1.0);float intensity=u_light.x;float azimuth=u_light.y+PI;float base=1.875-intensity*1.75;float maxValue=0.5*PI;float scaledSlope=intensity !=0.5 ? ((pow(base,slope)-1.0)/(pow(base,maxValue)-1.0))*maxValue : slope;float accent=cos(scaledSlope);vec4 accent_color=(1.0-accent)*u_accent*clamp(intensity*2.0,0.0,1.0);float shade=abs(mod((aspect+azimuth)/PI+0.5,2.0)-1.0);vec4 shade_color=mix(u_shadow,u_highlight,shade)*sin(scaledSlope)*clamp(intensity*2.0,0.0,1.0);gl_FragColor=accent_color*(1.0-shade_color.a)+shade_color;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",Kr="uniform mat4 u_matrix;attribute vec2 a_pos;attribute vec2 a_texture_pos;varying vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);v_pos=a_texture_pos/8192.0;}",Jr="uniform lowp float u_device_pixel_ratio;varying vec2 v_width2;varying vec2 v_normal;varying float v_gamma_scale;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\nfloat dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);gl_FragColor=color*(alpha*opacity);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",Qr="\n#define scale 0.015873016\nattribute vec2 a_pos_normal;attribute vec4 a_data;uniform mat4 u_matrix;uniform mediump float u_ratio;uniform vec2 u_units_to_pixels;uniform lowp float u_device_pixel_ratio;varying vec2 v_normal;varying vec2 v_width2;varying float v_gamma_scale;varying highp float v_linesofar;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define mediump float gapwidth\n#pragma mapbox: define lowp float offset\n#pragma mapbox: define mediump float width\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump float gapwidth\n#pragma mapbox: initialize lowp float offset\n#pragma mapbox: initialize mediump float width\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;v_linesofar=(floor(a_data.z/4.0)+a_data.w*64.0)*2.0;vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;float extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;v_width2=vec2(outset,inset);}",en="uniform lowp float u_device_pixel_ratio;uniform sampler2D u_image;varying vec2 v_width2;varying vec2 v_normal;varying float v_gamma_scale;varying highp vec2 v_uv;\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\nfloat dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);vec4 color=texture2D(u_image,v_uv);gl_FragColor=color*(alpha*opacity);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",tn="\n#define scale 0.015873016\nattribute vec2 a_pos_normal;attribute vec4 a_data;attribute float a_uv_x;attribute float a_split_index;uniform mat4 u_matrix;uniform mediump float u_ratio;uniform lowp float u_device_pixel_ratio;uniform vec2 u_units_to_pixels;uniform float u_image_height;varying vec2 v_normal;varying vec2 v_width2;varying float v_gamma_scale;varying highp vec2 v_uv;\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define mediump float gapwidth\n#pragma mapbox: define lowp float offset\n#pragma mapbox: define mediump float width\nvoid main() {\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump float gapwidth\n#pragma mapbox: initialize lowp float offset\n#pragma mapbox: initialize mediump float width\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;highp float texel_height=1.0/u_image_height;highp float half_texel_height=0.5*texel_height;v_uv=vec2(a_uv_x,a_split_index*texel_height-half_texel_height);vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;float extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;v_width2=vec2(outset,inset);}",rn="uniform lowp float u_device_pixel_ratio;uniform vec2 u_texsize;uniform float u_fade;uniform mediump vec3 u_scale;uniform sampler2D u_image;varying vec2 v_normal;varying vec2 v_width2;varying float v_linesofar;varying float v_gamma_scale;varying float v_width;\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\n#pragma mapbox: define lowp float pixel_ratio_from\n#pragma mapbox: define lowp float pixel_ratio_to\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\n#pragma mapbox: initialize lowp float pixel_ratio_from\n#pragma mapbox: initialize lowp float pixel_ratio_to\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileZoomRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;vec2 pattern_size_a=vec2(display_size_a.x*fromScale/tileZoomRatio,display_size_a.y);vec2 pattern_size_b=vec2(display_size_b.x*toScale/tileZoomRatio,display_size_b.y);float aspect_a=display_size_a.y/v_width;float aspect_b=display_size_b.y/v_width;float dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);float x_a=mod(v_linesofar/pattern_size_a.x*aspect_a,1.0);float x_b=mod(v_linesofar/pattern_size_b.x*aspect_b,1.0);float y=0.5*v_normal.y+0.5;vec2 texel_size=1.0/u_texsize;vec2 pos_a=mix(pattern_tl_a*texel_size-texel_size,pattern_br_a*texel_size+texel_size,vec2(x_a,y));vec2 pos_b=mix(pattern_tl_b*texel_size-texel_size,pattern_br_b*texel_size+texel_size,vec2(x_b,y));vec4 color=mix(texture2D(u_image,pos_a),texture2D(u_image,pos_b),u_fade);gl_FragColor=color*alpha*opacity;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",nn="\n#define scale 0.015873016\n#define LINE_DISTANCE_SCALE 2.0\nattribute vec2 a_pos_normal;attribute vec4 a_data;uniform mat4 u_matrix;uniform vec2 u_units_to_pixels;uniform mediump float u_ratio;uniform lowp float u_device_pixel_ratio;varying vec2 v_normal;varying vec2 v_width2;varying float v_linesofar;varying float v_gamma_scale;varying float v_width;\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp float offset\n#pragma mapbox: define mediump float gapwidth\n#pragma mapbox: define mediump float width\n#pragma mapbox: define lowp float floorwidth\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\n#pragma mapbox: define lowp float pixel_ratio_from\n#pragma mapbox: define lowp float pixel_ratio_to\nvoid main() {\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize lowp float offset\n#pragma mapbox: initialize mediump float gapwidth\n#pragma mapbox: initialize mediump float width\n#pragma mapbox: initialize lowp float floorwidth\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\n#pragma mapbox: initialize lowp float pixel_ratio_from\n#pragma mapbox: initialize lowp float pixel_ratio_to\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;float a_linesofar=(floor(a_data.z/4.0)+a_data.w*64.0)*LINE_DISTANCE_SCALE;vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;float extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;v_linesofar=a_linesofar;v_width2=vec2(outset,inset);v_width=floorwidth;}",on="uniform lowp float u_device_pixel_ratio;uniform sampler2D u_image;uniform float u_sdfgamma;uniform float u_mix;varying vec2 v_normal;varying vec2 v_width2;varying vec2 v_tex_a;varying vec2 v_tex_b;varying float v_gamma_scale;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define mediump float width\n#pragma mapbox: define lowp float floorwidth\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump float width\n#pragma mapbox: initialize lowp float floorwidth\nfloat dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);float sdfdist_a=texture2D(u_image,v_tex_a).a;float sdfdist_b=texture2D(u_image,v_tex_b).a;float sdfdist=mix(sdfdist_a,sdfdist_b,u_mix);alpha*=smoothstep(0.5-u_sdfgamma/floorwidth,0.5+u_sdfgamma/floorwidth,sdfdist);gl_FragColor=color*(alpha*opacity);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",an="\n#define scale 0.015873016\n#define LINE_DISTANCE_SCALE 2.0\nattribute vec2 a_pos_normal;attribute vec4 a_data;uniform mat4 u_matrix;uniform mediump float u_ratio;uniform lowp float u_device_pixel_ratio;uniform vec2 u_patternscale_a;uniform float u_tex_y_a;uniform vec2 u_patternscale_b;uniform float u_tex_y_b;uniform vec2 u_units_to_pixels;varying vec2 v_normal;varying vec2 v_width2;varying vec2 v_tex_a;varying vec2 v_tex_b;varying float v_gamma_scale;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define mediump float gapwidth\n#pragma mapbox: define lowp float offset\n#pragma mapbox: define mediump float width\n#pragma mapbox: define lowp float floorwidth\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump float gapwidth\n#pragma mapbox: initialize lowp float offset\n#pragma mapbox: initialize mediump float width\n#pragma mapbox: initialize lowp float floorwidth\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;float a_linesofar=(floor(a_data.z/4.0)+a_data.w*64.0)*LINE_DISTANCE_SCALE;vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;float extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;v_tex_a=vec2(a_linesofar*u_patternscale_a.x/floorwidth,normal.y*u_patternscale_a.y+u_tex_y_a);v_tex_b=vec2(a_linesofar*u_patternscale_b.x/floorwidth,normal.y*u_patternscale_b.y+u_tex_y_b);v_width2=vec2(outset,inset);}",sn="uniform float u_fade_t;uniform float u_opacity;uniform sampler2D u_image0;uniform sampler2D u_image1;varying vec2 v_pos0;varying vec2 v_pos1;uniform float u_brightness_low;uniform float u_brightness_high;uniform float u_saturation_factor;uniform float u_contrast_factor;uniform vec3 u_spin_weights;void main() {vec4 color0=texture2D(u_image0,v_pos0);vec4 color1=texture2D(u_image1,v_pos1);if (color0.a > 0.0) {color0.rgb=color0.rgb/color0.a;}if (color1.a > 0.0) {color1.rgb=color1.rgb/color1.a;}vec4 color=mix(color0,color1,u_fade_t);color.a*=u_opacity;vec3 rgb=color.rgb;rgb=vec3(dot(rgb,u_spin_weights.xyz),dot(rgb,u_spin_weights.zxy),dot(rgb,u_spin_weights.yzx));float average=(color.r+color.g+color.b)/3.0;rgb+=(average-rgb)*u_saturation_factor;rgb=(rgb-0.5)*u_contrast_factor+0.5;vec3 u_high_vec=vec3(u_brightness_low,u_brightness_low,u_brightness_low);vec3 u_low_vec=vec3(u_brightness_high,u_brightness_high,u_brightness_high);gl_FragColor=vec4(mix(u_high_vec,u_low_vec,rgb)*color.a,color.a);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",ln="uniform mat4 u_matrix;uniform vec2 u_tl_parent;uniform float u_scale_parent;uniform float u_buffer_scale;attribute vec2 a_pos;attribute vec2 a_texture_pos;varying vec2 v_pos0;varying vec2 v_pos1;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);v_pos0=(((a_texture_pos/8192.0)-0.5)/u_buffer_scale )+0.5;v_pos1=(v_pos0*u_scale_parent)+u_tl_parent;}",cn="uniform sampler2D u_texture;varying vec2 v_tex;varying float v_fade_opacity;\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\nlowp float alpha=opacity*v_fade_opacity;gl_FragColor=texture2D(u_texture,v_tex)*alpha;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",un="const float PI=3.141592653589793;attribute vec4 a_pos_offset;attribute vec4 a_data;attribute vec4 a_pixeloffset;attribute vec3 a_projected_pos;attribute float a_fade_opacity;uniform bool u_is_size_zoom_constant;uniform bool u_is_size_feature_constant;uniform highp float u_size_t;uniform highp float u_size;uniform highp float u_camera_to_center_distance;uniform highp float u_pitch;uniform bool u_rotate_symbol;uniform highp float u_aspect_ratio;uniform float u_fade_change;uniform mat4 u_matrix;uniform mat4 u_label_plane_matrix;uniform mat4 u_coord_matrix;uniform bool u_is_text;uniform bool u_pitch_with_map;uniform vec2 u_texsize;varying vec2 v_tex;varying float v_fade_opacity;\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\nvec2 a_pos=a_pos_offset.xy;vec2 a_offset=a_pos_offset.zw;vec2 a_tex=a_data.xy;vec2 a_size=a_data.zw;float a_size_min=floor(a_size[0]*0.5);vec2 a_pxoffset=a_pixeloffset.xy;vec2 a_minFontScale=a_pixeloffset.zw/256.0;highp float segment_angle=-a_projected_pos[2];float size;if (!u_is_size_zoom_constant && !u_is_size_feature_constant) {size=mix(a_size_min,a_size[1],u_size_t)/128.0;} else if (u_is_size_zoom_constant && !u_is_size_feature_constant) {size=a_size_min/128.0;} else {size=u_size;}vec4 projectedPoint=u_matrix*vec4(a_pos,0,1);highp float camera_to_anchor_distance=projectedPoint.w;highp float distance_ratio=u_pitch_with_map ?\ncamera_to_anchor_distance/u_camera_to_center_distance :\nu_camera_to_center_distance/camera_to_anchor_distance;highp float perspective_ratio=clamp(0.5+0.5*distance_ratio,0.0,4.0);size*=perspective_ratio;float fontScale=u_is_text ? size/24.0 : size;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetProjectedPoint=u_matrix*vec4(a_pos+vec2(1,0),0,1);vec2 a=projectedPoint.xy/projectedPoint.w;vec2 b=offsetProjectedPoint.xy/offsetProjectedPoint.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}highp float angle_sin=sin(segment_angle+symbol_rotation);highp float angle_cos=cos(segment_angle+symbol_rotation);mat2 rotation_matrix=mat2(angle_cos,-1.0*angle_sin,angle_sin,angle_cos);vec4 projected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy,0.0,1.0);gl_Position=u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+rotation_matrix*(a_offset/32.0*max(a_minFontScale,fontScale)+a_pxoffset/16.0),0.0,1.0);v_tex=a_tex/u_texsize;vec2 fade_opacity=unpack_opacity(a_fade_opacity);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;v_fade_opacity=max(0.0,min(1.0,fade_opacity[0]+fade_change));}",dn="#define SDF_PX 8.0\nuniform bool u_is_halo;uniform sampler2D u_texture;uniform highp float u_gamma_scale;uniform lowp float u_device_pixel_ratio;uniform bool u_is_text;varying vec2 v_data0;varying vec3 v_data1;\n#pragma mapbox: define highp vec4 fill_color\n#pragma mapbox: define highp vec4 halo_color\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp float halo_width\n#pragma mapbox: define lowp float halo_blur\nvoid main() {\n#pragma mapbox: initialize highp vec4 fill_color\n#pragma mapbox: initialize highp vec4 halo_color\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize lowp float halo_width\n#pragma mapbox: initialize lowp float halo_blur\nfloat EDGE_GAMMA=0.105/u_device_pixel_ratio;vec2 tex=v_data0.xy;float gamma_scale=v_data1.x;float size=v_data1.y;float fade_opacity=v_data1[2];float fontScale=u_is_text ? size/24.0 : size;lowp vec4 color=fill_color;highp float gamma=EDGE_GAMMA/(fontScale*u_gamma_scale);lowp float buff=(256.0-64.0)/256.0;if (u_is_halo) {color=halo_color;gamma=(halo_blur*1.19/SDF_PX+EDGE_GAMMA)/(fontScale*u_gamma_scale);buff=(6.0-halo_width/fontScale)/SDF_PX;}lowp float dist=texture2D(u_texture,tex).a;highp float gamma_scaled=gamma*gamma_scale;highp float alpha=smoothstep(buff-gamma_scaled,buff+gamma_scaled,dist);gl_FragColor=color*(alpha*opacity*fade_opacity);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",hn="const float PI=3.141592653589793;attribute vec4 a_pos_offset;attribute vec4 a_data;attribute vec4 a_pixeloffset;attribute vec3 a_projected_pos;attribute float a_fade_opacity;uniform bool u_is_size_zoom_constant;uniform bool u_is_size_feature_constant;uniform highp float u_size_t;uniform highp float u_size;uniform mat4 u_matrix;uniform mat4 u_label_plane_matrix;uniform mat4 u_coord_matrix;uniform bool u_is_text;uniform bool u_pitch_with_map;uniform highp float u_pitch;uniform bool u_rotate_symbol;uniform highp float u_aspect_ratio;uniform highp float u_camera_to_center_distance;uniform float u_fade_change;uniform vec2 u_texsize;varying vec2 v_data0;varying vec3 v_data1;\n#pragma mapbox: define highp vec4 fill_color\n#pragma mapbox: define highp vec4 halo_color\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp float halo_width\n#pragma mapbox: define lowp float halo_blur\nvoid main() {\n#pragma mapbox: initialize highp vec4 fill_color\n#pragma mapbox: initialize highp vec4 halo_color\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize lowp float halo_width\n#pragma mapbox: initialize lowp float halo_blur\nvec2 a_pos=a_pos_offset.xy;vec2 a_offset=a_pos_offset.zw;vec2 a_tex=a_data.xy;vec2 a_size=a_data.zw;float a_size_min=floor(a_size[0]*0.5);vec2 a_pxoffset=a_pixeloffset.xy;highp float segment_angle=-a_projected_pos[2];float size;if (!u_is_size_zoom_constant && !u_is_size_feature_constant) {size=mix(a_size_min,a_size[1],u_size_t)/128.0;} else if (u_is_size_zoom_constant && !u_is_size_feature_constant) {size=a_size_min/128.0;} else {size=u_size;}vec4 projectedPoint=u_matrix*vec4(a_pos,0,1);highp float camera_to_anchor_distance=projectedPoint.w;highp float distance_ratio=u_pitch_with_map ?\ncamera_to_anchor_distance/u_camera_to_center_distance :\nu_camera_to_center_distance/camera_to_anchor_distance;highp float perspective_ratio=clamp(0.5+0.5*distance_ratio,0.0,4.0);size*=perspective_ratio;float fontScale=u_is_text ? size/24.0 : size;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetProjectedPoint=u_matrix*vec4(a_pos+vec2(1,0),0,1);vec2 a=projectedPoint.xy/projectedPoint.w;vec2 b=offsetProjectedPoint.xy/offsetProjectedPoint.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}highp float angle_sin=sin(segment_angle+symbol_rotation);highp float angle_cos=cos(segment_angle+symbol_rotation);mat2 rotation_matrix=mat2(angle_cos,-1.0*angle_sin,angle_sin,angle_cos);vec4 projected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy,0.0,1.0);gl_Position=u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+rotation_matrix*(a_offset/32.0*fontScale+a_pxoffset),0.0,1.0);float gamma_scale=gl_Position.w;vec2 fade_opacity=unpack_opacity(a_fade_opacity);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;float interpolated_fade_opacity=max(0.0,min(1.0,fade_opacity[0]+fade_change));v_data0=a_tex/u_texsize;v_data1=vec3(gamma_scale,size,interpolated_fade_opacity);}",pn="#define SDF_PX 8.0\n#define SDF 1.0\n#define ICON 0.0\nuniform bool u_is_halo;uniform sampler2D u_texture;uniform sampler2D u_texture_icon;uniform highp float u_gamma_scale;uniform lowp float u_device_pixel_ratio;varying vec4 v_data0;varying vec4 v_data1;\n#pragma mapbox: define highp vec4 fill_color\n#pragma mapbox: define highp vec4 halo_color\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp float halo_width\n#pragma mapbox: define lowp float halo_blur\nvoid main() {\n#pragma mapbox: initialize highp vec4 fill_color\n#pragma mapbox: initialize highp vec4 halo_color\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize lowp float halo_width\n#pragma mapbox: initialize lowp float halo_blur\nfloat fade_opacity=v_data1[2];if (v_data1.w==ICON) {vec2 tex_icon=v_data0.zw;lowp float alpha=opacity*fade_opacity;gl_FragColor=texture2D(u_texture_icon,tex_icon)*alpha;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\nreturn;}vec2 tex=v_data0.xy;float EDGE_GAMMA=0.105/u_device_pixel_ratio;float gamma_scale=v_data1.x;float size=v_data1.y;float fontScale=size/24.0;lowp vec4 color=fill_color;highp float gamma=EDGE_GAMMA/(fontScale*u_gamma_scale);lowp float buff=(256.0-64.0)/256.0;if (u_is_halo) {color=halo_color;gamma=(halo_blur*1.19/SDF_PX+EDGE_GAMMA)/(fontScale*u_gamma_scale);buff=(6.0-halo_width/fontScale)/SDF_PX;}lowp float dist=texture2D(u_texture,tex).a;highp float gamma_scaled=gamma*gamma_scale;highp float alpha=smoothstep(buff-gamma_scaled,buff+gamma_scaled,dist);gl_FragColor=color*(alpha*opacity*fade_opacity);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}",fn="const float PI=3.141592653589793;attribute vec4 a_pos_offset;attribute vec4 a_data;attribute vec3 a_projected_pos;attribute float a_fade_opacity;uniform bool u_is_size_zoom_constant;uniform bool u_is_size_feature_constant;uniform highp float u_size_t;uniform highp float u_size;uniform mat4 u_matrix;uniform mat4 u_label_plane_matrix;uniform mat4 u_coord_matrix;uniform bool u_is_text;uniform bool u_pitch_with_map;uniform highp float u_pitch;uniform bool u_rotate_symbol;uniform highp float u_aspect_ratio;uniform highp float u_camera_to_center_distance;uniform float u_fade_change;uniform vec2 u_texsize;uniform vec2 u_texsize_icon;varying vec4 v_data0;varying vec4 v_data1;\n#pragma mapbox: define highp vec4 fill_color\n#pragma mapbox: define highp vec4 halo_color\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp float halo_width\n#pragma mapbox: define lowp float halo_blur\nvoid main() {\n#pragma mapbox: initialize highp vec4 fill_color\n#pragma mapbox: initialize highp vec4 halo_color\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize lowp float halo_width\n#pragma mapbox: initialize lowp float halo_blur\nvec2 a_pos=a_pos_offset.xy;vec2 a_offset=a_pos_offset.zw;vec2 a_tex=a_data.xy;vec2 a_size=a_data.zw;float a_size_min=floor(a_size[0]*0.5);float is_sdf=a_size[0]-2.0*a_size_min;highp float segment_angle=-a_projected_pos[2];float size;if (!u_is_size_zoom_constant && !u_is_size_feature_constant) {size=mix(a_size_min,a_size[1],u_size_t)/128.0;} else if (u_is_size_zoom_constant && !u_is_size_feature_constant) {size=a_size_min/128.0;} else {size=u_size;}vec4 projectedPoint=u_matrix*vec4(a_pos,0,1);highp float camera_to_anchor_distance=projectedPoint.w;highp float distance_ratio=u_pitch_with_map ?\ncamera_to_anchor_distance/u_camera_to_center_distance :\nu_camera_to_center_distance/camera_to_anchor_distance;highp float perspective_ratio=clamp(0.5+0.5*distance_ratio,0.0,4.0);size*=perspective_ratio;float fontScale=size/24.0;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetProjectedPoint=u_matrix*vec4(a_pos+vec2(1,0),0,1);vec2 a=projectedPoint.xy/projectedPoint.w;vec2 b=offsetProjectedPoint.xy/offsetProjectedPoint.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}highp float angle_sin=sin(segment_angle+symbol_rotation);highp float angle_cos=cos(segment_angle+symbol_rotation);mat2 rotation_matrix=mat2(angle_cos,-1.0*angle_sin,angle_sin,angle_cos);vec4 projected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy,0.0,1.0);gl_Position=u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+rotation_matrix*(a_offset/32.0*fontScale),0.0,1.0);float gamma_scale=gl_Position.w;vec2 fade_opacity=unpack_opacity(a_fade_opacity);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;float interpolated_fade_opacity=max(0.0,min(1.0,fade_opacity[0]+fade_change));v_data0.xy=a_tex/u_texsize;v_data0.zw=a_tex/u_texsize_icon;v_data1=vec4(gamma_scale,size,interpolated_fade_opacity,is_sdf);}",mn=Vn("#ifdef GL_ES\nprecision mediump float;\n#else\n#if !defined(lowp)\n#define lowp\n#endif\n#if !defined(mediump)\n#define mediump\n#endif\n#if !defined(highp)\n#define highp\n#endif\n#endif","#ifdef GL_ES\nprecision highp float;\n#else\n#if !defined(lowp)\n#define lowp\n#endif\n#if !defined(mediump)\n#define mediump\n#endif\n#if !defined(highp)\n#define highp\n#endif\n#endif\nvec2 unpack_float(const float packedValue) {int packedIntValue=int(packedValue);int v0=packedIntValue/256;return vec2(v0,packedIntValue-v0*256);}vec2 unpack_opacity(const float packedOpacity) {int intOpacity=int(packedOpacity)/2;return vec2(float(intOpacity)/127.0,mod(packedOpacity,2.0));}vec4 decode_color(const vec2 encodedColor) {return vec4(unpack_float(encodedColor[0])/255.0,unpack_float(encodedColor[1])/255.0\n);}float unpack_mix_vec2(const vec2 packedValue,const float t) {return mix(packedValue[0],packedValue[1],t);}vec4 unpack_mix_color(const vec4 packedColors,const float t) {vec4 minColor=decode_color(vec2(packedColors[0],packedColors[1]));vec4 maxColor=decode_color(vec2(packedColors[2],packedColors[3]));return mix(minColor,maxColor,t);}vec2 get_pattern_pos(const vec2 pixel_coord_upper,const vec2 pixel_coord_lower,const vec2 pattern_size,const float tile_units_to_pixels,const vec2 pos) {vec2 offset=mod(mod(mod(pixel_coord_upper,pattern_size)*256.0,pattern_size)*256.0+pixel_coord_lower,pattern_size);return (tile_units_to_pixels*pos+offset)/pattern_size;}"),gn=Vn(vr,xr),yn=Vn(br,_r),vn=Vn(wr,kr),xn=Vn(Sr,Ar),bn=Vn(Tr,Mr),_n=Vn(Cr,Er),wn=Vn(Ir,Pr),kn=Vn(Or,Rr),Sn=Vn(Lr,Dr),An=Vn(zr,jr),Tn=Vn(Fr,Nr),Mn=Vn(Br,Vr),Cn=Vn(Ur,Hr),En=Vn($r,Wr),In=Vn(qr,Gr),Pn=Vn(Yr,Xr),On=Vn(Zr,Kr),Rn=Vn(Jr,Qr),Ln=Vn(en,tn),Dn=Vn(rn,nn),zn=Vn(on,an),jn=Vn(sn,ln),Fn=Vn(cn,un),Nn=Vn(dn,hn),Bn=Vn(pn,fn);function Vn(e,t){var r=/#pragma mapbox: ([\w]+) ([\w]+) ([\w]+) ([\w]+)/g,n=t.match(/attribute ([\w]+) ([\w]+)/g),i=e.match(/uniform ([\w]+) ([\w]+)([\s]*)([\w]*)/g),o=t.match(/uniform ([\w]+) ([\w]+)([\s]*)([\w]*)/g),a=o?o.concat(i):i,s={};return{fragmentSource:e=e.replace(r,(function(e,t,r,n,i){return s[i]=!0,"define"===t?"\n#ifndef HAS_UNIFORM_u_"+i+"\nvarying "+r+" "+n+" "+i+";\n#else\nuniform "+r+" "+n+" u_"+i+";\n#endif\n":"\n#ifdef HAS_UNIFORM_u_"+i+"\n "+r+" "+n+" "+i+" = u_"+i+";\n#endif\n"})),vertexSource:t=t.replace(r,(function(e,t,r,n,i){var o="float"===n?"vec2":"vec4",a=i.match(/color/)?"color":o;return s[i]?"define"===t?"\n#ifndef HAS_UNIFORM_u_"+i+"\nuniform lowp float u_"+i+"_t;\nattribute "+r+" "+o+" a_"+i+";\nvarying "+r+" "+n+" "+i+";\n#else\nuniform "+r+" "+n+" u_"+i+";\n#endif\n":"vec4"===a?"\n#ifndef HAS_UNIFORM_u_"+i+"\n "+i+" = a_"+i+";\n#else\n "+r+" "+n+" "+i+" = u_"+i+";\n#endif\n":"\n#ifndef HAS_UNIFORM_u_"+i+"\n "+i+" = unpack_mix_"+a+"(a_"+i+", u_"+i+"_t);\n#else\n "+r+" "+n+" "+i+" = u_"+i+";\n#endif\n":"define"===t?"\n#ifndef HAS_UNIFORM_u_"+i+"\nuniform lowp float u_"+i+"_t;\nattribute "+r+" "+o+" a_"+i+";\n#else\nuniform "+r+" "+n+" u_"+i+";\n#endif\n":"vec4"===a?"\n#ifndef HAS_UNIFORM_u_"+i+"\n "+r+" "+n+" "+i+" = a_"+i+";\n#else\n "+r+" "+n+" "+i+" = u_"+i+";\n#endif\n":"\n#ifndef HAS_UNIFORM_u_"+i+"\n "+r+" "+n+" "+i+" = unpack_mix_"+a+"(a_"+i+", u_"+i+"_t);\n#else\n "+r+" "+n+" "+i+" = u_"+i+";\n#endif\n"})),staticAttributes:n,staticUniforms:a}}var Un=Object.freeze({__proto__:null,prelude:mn,background:gn,backgroundPattern:yn,circle:vn,clippingMask:xn,heatmap:bn,heatmapTexture:_n,collisionBox:wn,collisionCircle:kn,debug:Sn,fill:An,fillOutline:Tn,fillOutlinePattern:Mn,fillPattern:Cn,fillExtrusion:En,fillExtrusionPattern:In,hillshadePrepare:Pn,hillshade:On,line:Rn,lineGradient:Ln,linePattern:Dn,lineSDF:zn,raster:jn,symbolIcon:Fn,symbolSDF:Nn,symbolTextAndIcon:Bn}),Hn=function(){this.boundProgram=null,this.boundLayoutVertexBuffer=null,this.boundPaintVertexBuffers=[],this.boundIndexBuffer=null,this.boundVertexOffset=null,this.boundDynamicVertexBuffer=null,this.vao=null};function $n(e){for(var t=[],r=0;r>16,s>>16],u_pixel_coord_lower:[65535&a,65535&s]}}function Gn(e,t,r,n){var i=r.imageManager.getPattern(e.from.toString()),o=r.imageManager.getPattern(e.to.toString()),a=r.imageManager.getPixelSize(),s=a.width,l=a.height,c=Math.pow(2,n.tileID.overscaledZ),u=n.tileSize*Math.pow(2,r.transform.tileZoom)/c,d=u*(n.tileID.canonical.x+n.tileID.wrap*c),h=u*n.tileID.canonical.y;return{u_image:0,u_pattern_tl_a:i.tl,u_pattern_br_a:i.br,u_pattern_tl_b:o.tl,u_pattern_br_b:o.br,u_texsize:[s,l],u_mix:t.t,u_pattern_size_a:i.displaySize,u_pattern_size_b:o.displaySize,u_scale_a:t.fromScale,u_scale_b:t.toScale,u_tile_units_to_pixels:1/Nt(n,1,r.transform.tileZoom),u_pixel_coord_upper:[d>>16,h>>16],u_pixel_coord_lower:[65535&d,65535&h]}}Wn.prototype.draw=function(e,t,r,n,i,o,a,s,l,c,u,d,h,p,f,m){var g,y=e.gl;if(!this.failedToCreate){for(var v in e.program.set(this.program),e.setDepthMode(r),e.setStencilMode(n),e.setColorMode(i),e.setCullFace(o),this.fixedUniforms)this.fixedUniforms[v].set(a[v]);p&&p.setUniforms(e,this.binderUniforms,d,{zoom:h});for(var x=(g={},g[y.LINES]=2,g[y.TRIANGLES]=3,g[y.LINE_STRIP]=1,g)[t],b=0,_=u.get();b<_.length;b+=1){var w=_[b],k=w.vaos||(w.vaos={});(k[s]||(k[s]=new Hn)).bind(e,this,l,p?p.getPaintVertexBuffers():[],c,w.vertexOffset,f,m),y.drawElements(t,w.primitiveLength*x,y.UNSIGNED_SHORT,w.primitiveOffset*x*2)}}};var Yn=function(t,r,n,i){var o=r.style.light,a=o.properties.get("position"),s=[a.x,a.y,a.z],l=e.create$1();"viewport"===o.properties.get("anchor")&&e.fromRotation(l,-r.transform.angle),e.transformMat3(s,s,l);var c=o.properties.get("color");return{u_matrix:t,u_lightpos:s,u_lightintensity:o.properties.get("intensity"),u_lightcolor:[c.r,c.g,c.b],u_vertical_gradient:+n,u_opacity:i}},Xn=function(t,r,n,i,o,a,s){return e.extend(Yn(t,r,n,i),qn(a,r,s),{u_height_factor:-Math.pow(2,o.overscaledZ)/s.tileSize/8})},Zn=function(e){return{u_matrix:e}},Kn=function(t,r,n,i){return e.extend(Zn(t),qn(n,r,i))},Jn=function(e,t){return{u_matrix:e,u_world:t}},Qn=function(t,r,n,i,o){return e.extend(Kn(t,r,n,i),{u_world:o})},ei=function(t,r,n,i){var o,a,s=t.transform;if("map"===i.paint.get("circle-pitch-alignment")){var l=Nt(n,1,s.zoom);o=!0,a=[l,l]}else o=!1,a=s.pixelsToGLUnits;return{u_camera_to_center_distance:s.cameraToCenterDistance,u_scale_with_map:+("map"===i.paint.get("circle-pitch-scale")),u_matrix:t.translatePosMatrix(r.posMatrix,n,i.paint.get("circle-translate"),i.paint.get("circle-translate-anchor")),u_pitch_with_map:+o,u_device_pixel_ratio:e.browser.devicePixelRatio,u_extrude_scale:a}},ti=function(e,t,r){var n=Nt(r,1,t.zoom),i=Math.pow(2,t.zoom-r.tileID.overscaledZ),o=r.tileID.overscaleFactor();return{u_matrix:e,u_camera_to_center_distance:t.cameraToCenterDistance,u_pixels_to_tile_units:n,u_extrude_scale:[t.pixelsToGLUnits[0]/(n*i),t.pixelsToGLUnits[1]/(n*i)],u_overscale_factor:o}},ri=function(e,t,r){return{u_matrix:e,u_inv_matrix:t,u_camera_to_center_distance:r.cameraToCenterDistance,u_viewport_size:[r.width,r.height]}},ni=function(e,t,r){return void 0===r&&(r=1),{u_matrix:e,u_color:t,u_overlay:0,u_overlay_scale:r}},ii=function(e){return{u_matrix:e}},oi=function(e,t,r,n){return{u_matrix:e,u_extrude_scale:Nt(t,1,r),u_intensity:n}},ai=function(t,r,n,i){var o=e.create();e.ortho(o,0,t.width,t.height,0,0,1);var a=t.context.gl;return{u_matrix:o,u_world:[a.drawingBufferWidth,a.drawingBufferHeight],u_image:n,u_color_ramp:i,u_opacity:r.paint.get("heatmap-opacity")}},si=function(e,t,r){var n=r.paint.get("hillshade-shadow-color"),i=r.paint.get("hillshade-highlight-color"),o=r.paint.get("hillshade-accent-color"),a=r.paint.get("hillshade-illumination-direction")*(Math.PI/180);"viewport"===r.paint.get("hillshade-illumination-anchor")&&(a-=e.transform.angle);var s=!e.options.moving;return{u_matrix:e.transform.calculatePosMatrix(t.tileID.toUnwrapped(),s),u_image:0,u_latrange:ci(e,t.tileID),u_light:[r.paint.get("hillshade-exaggeration"),a],u_shadow:n,u_highlight:i,u_accent:o}},li=function(t,r){var n=r.stride,i=e.create();return e.ortho(i,0,e.EXTENT,-e.EXTENT,0,0,1),e.translate(i,i,[0,-e.EXTENT,0]),{u_matrix:i,u_image:1,u_dimension:[n,n],u_zoom:t.overscaledZ,u_unpack:r.getUnpackVector()}};function ci(t,r){var n=Math.pow(2,r.canonical.z),i=r.canonical.y;return[new e.MercatorCoordinate(0,i/n).toLngLat().lat,new e.MercatorCoordinate(0,(i+1)/n).toLngLat().lat]}var ui=function(t,r,n){var i=t.transform;return{u_matrix:mi(t,r,n),u_ratio:1/Nt(r,1,i.zoom),u_device_pixel_ratio:e.browser.devicePixelRatio,u_units_to_pixels:[1/i.pixelsToGLUnits[0],1/i.pixelsToGLUnits[1]]}},di=function(t,r,n,i){return e.extend(ui(t,r,n),{u_image:0,u_image_height:i})},hi=function(t,r,n,i){var o=t.transform,a=fi(r,o);return{u_matrix:mi(t,r,n),u_texsize:r.imageAtlasTexture.size,u_ratio:1/Nt(r,1,o.zoom),u_device_pixel_ratio:e.browser.devicePixelRatio,u_image:0,u_scale:[a,i.fromScale,i.toScale],u_fade:i.t,u_units_to_pixels:[1/o.pixelsToGLUnits[0],1/o.pixelsToGLUnits[1]]}},pi=function(t,r,n,i,o){var a=t.transform,s=t.lineAtlas,l=fi(r,a),c="round"===n.layout.get("line-cap"),u=s.getDash(i.from,c),d=s.getDash(i.to,c),h=u.width*o.fromScale,p=d.width*o.toScale;return e.extend(ui(t,r,n),{u_patternscale_a:[l/h,-u.height/2],u_patternscale_b:[l/p,-d.height/2],u_sdfgamma:s.width/(256*Math.min(h,p)*e.browser.devicePixelRatio)/2,u_image:0,u_tex_y_a:u.y,u_tex_y_b:d.y,u_mix:o.t})};function fi(e,t){return 1/Nt(e,1,t.tileZoom)}function mi(e,t,r){return e.translatePosMatrix(t.tileID.posMatrix,t,r.paint.get("line-translate"),r.paint.get("line-translate-anchor"))}var gi=function(e,t,r,n,i){return{u_matrix:e,u_tl_parent:t,u_scale_parent:r,u_buffer_scale:1,u_fade_t:n.mix,u_opacity:n.opacity*i.paint.get("raster-opacity"),u_image0:0,u_image1:1,u_brightness_low:i.paint.get("raster-brightness-min"),u_brightness_high:i.paint.get("raster-brightness-max"),u_saturation_factor:xi(i.paint.get("raster-saturation")),u_contrast_factor:vi(i.paint.get("raster-contrast")),u_spin_weights:yi(i.paint.get("raster-hue-rotate"))}};function yi(e){e*=Math.PI/180;var t=Math.sin(e),r=Math.cos(e);return[(2*r+1)/3,(-Math.sqrt(3)*t-r+1)/3,(Math.sqrt(3)*t-r+1)/3]}function vi(e){return e>0?1/(1-e):1+e}function xi(e){return e>0?1-1/(1.001-e):-e}var bi,_i=function(e,t,r,n,i,o,a,s,l,c){var u=i.transform;return{u_is_size_zoom_constant:+("constant"===e||"source"===e),u_is_size_feature_constant:+("constant"===e||"camera"===e),u_size_t:t?t.uSizeT:0,u_size:t?t.uSize:0,u_camera_to_center_distance:u.cameraToCenterDistance,u_pitch:u.pitch/360*2*Math.PI,u_rotate_symbol:+r,u_aspect_ratio:u.width/u.height,u_fade_change:i.options.fadeDuration?i.symbolFadeChange:1,u_matrix:o,u_label_plane_matrix:a,u_coord_matrix:s,u_is_text:+l,u_pitch_with_map:+n,u_texsize:c,u_texture:0}},wi=function(t,r,n,i,o,a,s,l,c,u,d){var h=o.transform;return e.extend(_i(t,r,n,i,o,a,s,l,c,u),{u_gamma_scale:i?Math.cos(h._pitch)*h.cameraToCenterDistance:1,u_device_pixel_ratio:e.browser.devicePixelRatio,u_is_halo:+d})},ki=function(t,r,n,i,o,a,s,l,c,u){return e.extend(wi(t,r,n,i,o,a,s,l,!0,c,!0),{u_texsize_icon:u,u_texture_icon:1})},Si=function(e,t,r){return{u_matrix:e,u_opacity:t,u_color:r}},Ai=function(t,r,n,i,o,a){return e.extend(Gn(i,a,n,o),{u_matrix:t,u_opacity:r})},Ti={fillExtrusion:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_lightpos:new e.Uniform3f(t,r.u_lightpos),u_lightintensity:new e.Uniform1f(t,r.u_lightintensity),u_lightcolor:new e.Uniform3f(t,r.u_lightcolor),u_vertical_gradient:new e.Uniform1f(t,r.u_vertical_gradient),u_opacity:new e.Uniform1f(t,r.u_opacity)}},fillExtrusionPattern:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_lightpos:new e.Uniform3f(t,r.u_lightpos),u_lightintensity:new e.Uniform1f(t,r.u_lightintensity),u_lightcolor:new e.Uniform3f(t,r.u_lightcolor),u_vertical_gradient:new e.Uniform1f(t,r.u_vertical_gradient),u_height_factor:new e.Uniform1f(t,r.u_height_factor),u_image:new e.Uniform1i(t,r.u_image),u_texsize:new e.Uniform2f(t,r.u_texsize),u_pixel_coord_upper:new e.Uniform2f(t,r.u_pixel_coord_upper),u_pixel_coord_lower:new e.Uniform2f(t,r.u_pixel_coord_lower),u_scale:new e.Uniform3f(t,r.u_scale),u_fade:new e.Uniform1f(t,r.u_fade),u_opacity:new e.Uniform1f(t,r.u_opacity)}},fill:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix)}},fillPattern:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_image:new e.Uniform1i(t,r.u_image),u_texsize:new e.Uniform2f(t,r.u_texsize),u_pixel_coord_upper:new e.Uniform2f(t,r.u_pixel_coord_upper),u_pixel_coord_lower:new e.Uniform2f(t,r.u_pixel_coord_lower),u_scale:new e.Uniform3f(t,r.u_scale),u_fade:new e.Uniform1f(t,r.u_fade)}},fillOutline:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_world:new e.Uniform2f(t,r.u_world)}},fillOutlinePattern:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_world:new e.Uniform2f(t,r.u_world),u_image:new e.Uniform1i(t,r.u_image),u_texsize:new e.Uniform2f(t,r.u_texsize),u_pixel_coord_upper:new e.Uniform2f(t,r.u_pixel_coord_upper),u_pixel_coord_lower:new e.Uniform2f(t,r.u_pixel_coord_lower),u_scale:new e.Uniform3f(t,r.u_scale),u_fade:new e.Uniform1f(t,r.u_fade)}},circle:function(t,r){return{u_camera_to_center_distance:new e.Uniform1f(t,r.u_camera_to_center_distance),u_scale_with_map:new e.Uniform1i(t,r.u_scale_with_map),u_pitch_with_map:new e.Uniform1i(t,r.u_pitch_with_map),u_extrude_scale:new e.Uniform2f(t,r.u_extrude_scale),u_device_pixel_ratio:new e.Uniform1f(t,r.u_device_pixel_ratio),u_matrix:new e.UniformMatrix4f(t,r.u_matrix)}},collisionBox:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_camera_to_center_distance:new e.Uniform1f(t,r.u_camera_to_center_distance),u_pixels_to_tile_units:new e.Uniform1f(t,r.u_pixels_to_tile_units),u_extrude_scale:new e.Uniform2f(t,r.u_extrude_scale),u_overscale_factor:new e.Uniform1f(t,r.u_overscale_factor)}},collisionCircle:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_inv_matrix:new e.UniformMatrix4f(t,r.u_inv_matrix),u_camera_to_center_distance:new e.Uniform1f(t,r.u_camera_to_center_distance),u_viewport_size:new e.Uniform2f(t,r.u_viewport_size)}},debug:function(t,r){return{u_color:new e.UniformColor(t,r.u_color),u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_overlay:new e.Uniform1i(t,r.u_overlay),u_overlay_scale:new e.Uniform1f(t,r.u_overlay_scale)}},clippingMask:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix)}},heatmap:function(t,r){return{u_extrude_scale:new e.Uniform1f(t,r.u_extrude_scale),u_intensity:new e.Uniform1f(t,r.u_intensity),u_matrix:new e.UniformMatrix4f(t,r.u_matrix)}},heatmapTexture:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_world:new e.Uniform2f(t,r.u_world),u_image:new e.Uniform1i(t,r.u_image),u_color_ramp:new e.Uniform1i(t,r.u_color_ramp),u_opacity:new e.Uniform1f(t,r.u_opacity)}},hillshade:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_image:new e.Uniform1i(t,r.u_image),u_latrange:new e.Uniform2f(t,r.u_latrange),u_light:new e.Uniform2f(t,r.u_light),u_shadow:new e.UniformColor(t,r.u_shadow),u_highlight:new e.UniformColor(t,r.u_highlight),u_accent:new e.UniformColor(t,r.u_accent)}},hillshadePrepare:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_image:new e.Uniform1i(t,r.u_image),u_dimension:new e.Uniform2f(t,r.u_dimension),u_zoom:new e.Uniform1f(t,r.u_zoom),u_unpack:new e.Uniform4f(t,r.u_unpack)}},line:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_ratio:new e.Uniform1f(t,r.u_ratio),u_device_pixel_ratio:new e.Uniform1f(t,r.u_device_pixel_ratio),u_units_to_pixels:new e.Uniform2f(t,r.u_units_to_pixels)}},lineGradient:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_ratio:new e.Uniform1f(t,r.u_ratio),u_device_pixel_ratio:new e.Uniform1f(t,r.u_device_pixel_ratio),u_units_to_pixels:new e.Uniform2f(t,r.u_units_to_pixels),u_image:new e.Uniform1i(t,r.u_image),u_image_height:new e.Uniform1f(t,r.u_image_height)}},linePattern:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_texsize:new e.Uniform2f(t,r.u_texsize),u_ratio:new e.Uniform1f(t,r.u_ratio),u_device_pixel_ratio:new e.Uniform1f(t,r.u_device_pixel_ratio),u_image:new e.Uniform1i(t,r.u_image),u_units_to_pixels:new e.Uniform2f(t,r.u_units_to_pixels),u_scale:new e.Uniform3f(t,r.u_scale),u_fade:new e.Uniform1f(t,r.u_fade)}},lineSDF:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_ratio:new e.Uniform1f(t,r.u_ratio),u_device_pixel_ratio:new e.Uniform1f(t,r.u_device_pixel_ratio),u_units_to_pixels:new e.Uniform2f(t,r.u_units_to_pixels),u_patternscale_a:new e.Uniform2f(t,r.u_patternscale_a),u_patternscale_b:new e.Uniform2f(t,r.u_patternscale_b),u_sdfgamma:new e.Uniform1f(t,r.u_sdfgamma),u_image:new e.Uniform1i(t,r.u_image),u_tex_y_a:new e.Uniform1f(t,r.u_tex_y_a),u_tex_y_b:new e.Uniform1f(t,r.u_tex_y_b),u_mix:new e.Uniform1f(t,r.u_mix)}},raster:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_tl_parent:new e.Uniform2f(t,r.u_tl_parent),u_scale_parent:new e.Uniform1f(t,r.u_scale_parent),u_buffer_scale:new e.Uniform1f(t,r.u_buffer_scale),u_fade_t:new e.Uniform1f(t,r.u_fade_t),u_opacity:new e.Uniform1f(t,r.u_opacity),u_image0:new e.Uniform1i(t,r.u_image0),u_image1:new e.Uniform1i(t,r.u_image1),u_brightness_low:new e.Uniform1f(t,r.u_brightness_low),u_brightness_high:new e.Uniform1f(t,r.u_brightness_high),u_saturation_factor:new e.Uniform1f(t,r.u_saturation_factor),u_contrast_factor:new e.Uniform1f(t,r.u_contrast_factor),u_spin_weights:new e.Uniform3f(t,r.u_spin_weights)}},symbolIcon:function(t,r){return{u_is_size_zoom_constant:new e.Uniform1i(t,r.u_is_size_zoom_constant),u_is_size_feature_constant:new e.Uniform1i(t,r.u_is_size_feature_constant),u_size_t:new e.Uniform1f(t,r.u_size_t),u_size:new e.Uniform1f(t,r.u_size),u_camera_to_center_distance:new e.Uniform1f(t,r.u_camera_to_center_distance),u_pitch:new e.Uniform1f(t,r.u_pitch),u_rotate_symbol:new e.Uniform1i(t,r.u_rotate_symbol),u_aspect_ratio:new e.Uniform1f(t,r.u_aspect_ratio),u_fade_change:new e.Uniform1f(t,r.u_fade_change),u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_label_plane_matrix:new e.UniformMatrix4f(t,r.u_label_plane_matrix),u_coord_matrix:new e.UniformMatrix4f(t,r.u_coord_matrix),u_is_text:new e.Uniform1i(t,r.u_is_text),u_pitch_with_map:new e.Uniform1i(t,r.u_pitch_with_map),u_texsize:new e.Uniform2f(t,r.u_texsize),u_texture:new e.Uniform1i(t,r.u_texture)}},symbolSDF:function(t,r){return{u_is_size_zoom_constant:new e.Uniform1i(t,r.u_is_size_zoom_constant),u_is_size_feature_constant:new e.Uniform1i(t,r.u_is_size_feature_constant),u_size_t:new e.Uniform1f(t,r.u_size_t),u_size:new e.Uniform1f(t,r.u_size),u_camera_to_center_distance:new e.Uniform1f(t,r.u_camera_to_center_distance),u_pitch:new e.Uniform1f(t,r.u_pitch),u_rotate_symbol:new e.Uniform1i(t,r.u_rotate_symbol),u_aspect_ratio:new e.Uniform1f(t,r.u_aspect_ratio),u_fade_change:new e.Uniform1f(t,r.u_fade_change),u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_label_plane_matrix:new e.UniformMatrix4f(t,r.u_label_plane_matrix),u_coord_matrix:new e.UniformMatrix4f(t,r.u_coord_matrix),u_is_text:new e.Uniform1i(t,r.u_is_text),u_pitch_with_map:new e.Uniform1i(t,r.u_pitch_with_map),u_texsize:new e.Uniform2f(t,r.u_texsize),u_texture:new e.Uniform1i(t,r.u_texture),u_gamma_scale:new e.Uniform1f(t,r.u_gamma_scale),u_device_pixel_ratio:new e.Uniform1f(t,r.u_device_pixel_ratio),u_is_halo:new e.Uniform1i(t,r.u_is_halo)}},symbolTextAndIcon:function(t,r){return{u_is_size_zoom_constant:new e.Uniform1i(t,r.u_is_size_zoom_constant),u_is_size_feature_constant:new e.Uniform1i(t,r.u_is_size_feature_constant),u_size_t:new e.Uniform1f(t,r.u_size_t),u_size:new e.Uniform1f(t,r.u_size),u_camera_to_center_distance:new e.Uniform1f(t,r.u_camera_to_center_distance),u_pitch:new e.Uniform1f(t,r.u_pitch),u_rotate_symbol:new e.Uniform1i(t,r.u_rotate_symbol),u_aspect_ratio:new e.Uniform1f(t,r.u_aspect_ratio),u_fade_change:new e.Uniform1f(t,r.u_fade_change),u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_label_plane_matrix:new e.UniformMatrix4f(t,r.u_label_plane_matrix),u_coord_matrix:new e.UniformMatrix4f(t,r.u_coord_matrix),u_is_text:new e.Uniform1i(t,r.u_is_text),u_pitch_with_map:new e.Uniform1i(t,r.u_pitch_with_map),u_texsize:new e.Uniform2f(t,r.u_texsize),u_texsize_icon:new e.Uniform2f(t,r.u_texsize_icon),u_texture:new e.Uniform1i(t,r.u_texture),u_texture_icon:new e.Uniform1i(t,r.u_texture_icon),u_gamma_scale:new e.Uniform1f(t,r.u_gamma_scale),u_device_pixel_ratio:new e.Uniform1f(t,r.u_device_pixel_ratio),u_is_halo:new e.Uniform1i(t,r.u_is_halo)}},background:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_opacity:new e.Uniform1f(t,r.u_opacity),u_color:new e.UniformColor(t,r.u_color)}},backgroundPattern:function(t,r){return{u_matrix:new e.UniformMatrix4f(t,r.u_matrix),u_opacity:new e.Uniform1f(t,r.u_opacity),u_image:new e.Uniform1i(t,r.u_image),u_pattern_tl_a:new e.Uniform2f(t,r.u_pattern_tl_a),u_pattern_br_a:new e.Uniform2f(t,r.u_pattern_br_a),u_pattern_tl_b:new e.Uniform2f(t,r.u_pattern_tl_b),u_pattern_br_b:new e.Uniform2f(t,r.u_pattern_br_b),u_texsize:new e.Uniform2f(t,r.u_texsize),u_mix:new e.Uniform1f(t,r.u_mix),u_pattern_size_a:new e.Uniform2f(t,r.u_pattern_size_a),u_pattern_size_b:new e.Uniform2f(t,r.u_pattern_size_b),u_scale_a:new e.Uniform1f(t,r.u_scale_a),u_scale_b:new e.Uniform1f(t,r.u_scale_b),u_pixel_coord_upper:new e.Uniform2f(t,r.u_pixel_coord_upper),u_pixel_coord_lower:new e.Uniform2f(t,r.u_pixel_coord_lower),u_tile_units_to_pixels:new e.Uniform1f(t,r.u_tile_units_to_pixels)}}};function Mi(t,r,n,i,o,a,s){for(var l=t.context,c=l.gl,u=t.useProgram("collisionBox"),d=[],h=0,p=0,f=0;f0){var _=e.create(),w=v;e.mul(_,y.placementInvProjMatrix,t.transform.glCoordMatrix),e.mul(_,_,y.placementViewportMatrix),d.push({circleArray:b,circleOffset:p,transform:w,invTransform:_}),p=h+=b.length/4}x&&u.draw(l,c.LINES,Fe.disabled,Ve.disabled,t.colorModeForRenderPass(),Ye.disabled,ti(v,t.transform,g),n.id,x.layoutVertexBuffer,x.indexBuffer,x.segments,null,t.transform.zoom,null,null,x.collisionVertexBuffer)}}if(s&&d.length){var k=t.useProgram("collisionCircle"),S=new e.StructArrayLayout2f1f2i16;S.resize(4*h),S._trim();for(var A=0,T=0,M=d;T=0&&(m[y.associatedIconIndex]={shiftedAnchor:M,angle:C})}else Dt(y.numGlyphs,p)}if(d){f.clear();for(var I=t.icon.placedSymbolArray,P=0;P0){var s=e.browser.now(),l=(s-t.timeAdded)/a,c=r?(s-r.timeAdded)/a:-1,u=n.getSource(),d=o.coveringZoomLevel({tileSize:u.tileSize,roundZoom:u.roundZoom}),h=!r||Math.abs(r.tileID.overscaledZ-d)>Math.abs(t.tileID.overscaledZ-d),p=h&&t.refreshedUponExpiration?1:e.clamp(h?l:1-c,0,1);return t.refreshedUponExpiration&&l>=1&&(t.refreshedUponExpiration=!1),r?{opacity:1,mix:1-p}:{opacity:p,mix:0}}return{opacity:1,mix:0}}function Ji(e,t,r){var n=r.paint.get("background-color"),i=r.paint.get("background-opacity");if(0!==i){var o=e.context,a=o.gl,s=e.transform,l=s.tileSize,c=r.paint.get("background-pattern");if(!e.isPatternMissing(c)){var u=!c&&1===n.a&&1===i&&e.opaquePassEnabledForLayer()?"opaque":"translucent";if(e.renderPass===u){var d=Ve.disabled,h=e.depthModeForSublayer(0,"opaque"===u?Fe.ReadWrite:Fe.ReadOnly),p=e.colorModeForRenderPass(),f=e.useProgram(c?"backgroundPattern":"background"),m=s.coveringTiles({tileSize:l});c&&(o.activeTexture.set(a.TEXTURE0),e.imageManager.bind(e.context));for(var g=r.getCrossfadeParameters(),y=0,v=m;y "+n.overscaledZ),ho(t,y+" "+f+"kb"),s.draw(i,o.TRIANGLES,l,c,We.alphaBlended,Ye.disabled,ni(a,e.Color.transparent,g),d,t.debugBuffer,t.quadTriangleIndexBuffer,t.debugSegments)}function ho(e,t){e.initDebugOverlayCanvas();var r=e.debugOverlayCanvas,n=e.context.gl,i=e.debugOverlayCanvas.getContext("2d");i.clearRect(0,0,r.width,r.height),i.shadowColor="white",i.shadowBlur=2,i.lineWidth=1.5,i.strokeStyle="white",i.textBaseline="top",i.font="bold 36px Open Sans, sans-serif",i.fillText(t,5,5),i.strokeText(t,5,5),e.debugOverlayTexture.update(r),e.debugOverlayTexture.bind(n.LINEAR,n.CLAMP_TO_EDGE)}function po(e,t,r){var n=e.context,i=r.implementation;if("offscreen"===e.renderPass){var o=i.prerender;o&&(e.setCustomLayerDefaults(),n.setColorMode(e.colorModeForRenderPass()),o.call(i,n.gl,e.transform.customLayerMatrix()),n.setDirty(),e.setBaseState())}else if("translucent"===e.renderPass){e.setCustomLayerDefaults(),n.setColorMode(e.colorModeForRenderPass()),n.setStencilMode(Ve.disabled);var a="3d"===i.renderingMode?new Fe(e.context.gl.LEQUAL,Fe.ReadWrite,e.depthRangeFor3D):e.depthModeForSublayer(0,Fe.ReadOnly);n.setDepthMode(a),i.render(n.gl,e.transform.customLayerMatrix()),n.setDirty(),e.setBaseState(),n.bindFramebuffer.set(null)}}var fo={symbol:Ii,circle:ji,heatmap:Fi,line:Ui,fill:Hi,"fill-extrusion":Wi,hillshade:Gi,raster:Zi,background:Ji,debug:co,custom:po},mo=function(e,t){this.context=new Xe(e),this.transform=t,this._tileTextures={},this.setup(),this.numSublayers=Ze.maxUnderzooming+Ze.maxOverzooming+1,this.depthEpsilon=1/Math.pow(2,16),this.crossTileSymbolIndex=new dr,this.gpuTimers={}};mo.prototype.resize=function(t,r){if(this.width=t*e.browser.devicePixelRatio,this.height=r*e.browser.devicePixelRatio,this.context.viewport.set([0,0,this.width,this.height]),this.style)for(var n=0,i=this.style._order;n256&&this.clearStencil(),r.setColorMode(We.disabled),r.setDepthMode(Fe.disabled);var i=this.useProgram("clippingMask");this._tileClippingMaskIDs={};for(var o=0,a=t;o256&&this.clearStencil();var e=this.nextStencilID++,t=this.context.gl;return new Ve({func:t.NOTEQUAL,mask:255},e,255,t.KEEP,t.KEEP,t.REPLACE)},mo.prototype.stencilModeForClipping=function(e){var t=this.context.gl;return new Ve({func:t.EQUAL,mask:255},this._tileClippingMaskIDs[e.key],0,t.KEEP,t.KEEP,t.REPLACE)},mo.prototype.stencilConfigForOverlap=function(e){var t,r=this.context.gl,n=e.sort((function(e,t){return t.overscaledZ-e.overscaledZ})),i=n[n.length-1].overscaledZ,o=n[0].overscaledZ-i+1;if(o>1){this.currentStencilSource=void 0,this.nextStencilID+o>256&&this.clearStencil();for(var a={},s=0;s=0;this.currentLayer--){var w=this.style._layers[i[this.currentLayer]],k=o[w.source],S=u[w.source];this._renderTileClippingMasks(w,S),this.renderLayer(this,k,w,S)}for(this.renderPass="translucent",this.currentLayer=0;this.currentLayer0?t.pop():null},mo.prototype.isPatternMissing=function(e){if(!e)return!1;if(!e.from||!e.to)return!0;var t=this.imageManager.getPattern(e.from.toString()),r=this.imageManager.getPattern(e.to.toString());return!t||!r},mo.prototype.useProgram=function(e,t){this.cache=this.cache||{};var r=""+e+(t?t.cacheKey:"")+(this._showOverdrawInspector?"/overdraw":"");return this.cache[r]||(this.cache[r]=new Wn(this.context,e,Un[e],t,Ti[e],this._showOverdrawInspector)),this.cache[r]},mo.prototype.setCustomLayerDefaults=function(){this.context.unbindVAO(),this.context.cullFace.setDefault(),this.context.activeTexture.setDefault(),this.context.pixelStoreUnpack.setDefault(),this.context.pixelStoreUnpackPremultiplyAlpha.setDefault(),this.context.pixelStoreUnpackFlipY.setDefault()},mo.prototype.setBaseState=function(){var e=this.context.gl;this.context.cullFace.set(!1),this.context.viewport.set([0,0,this.width,this.height]),this.context.blendEquation.set(e.FUNC_ADD)},mo.prototype.initDebugOverlayCanvas=function(){if(null==this.debugOverlayCanvas){this.debugOverlayCanvas=e.window.document.createElement("canvas"),this.debugOverlayCanvas.width=512,this.debugOverlayCanvas.height=512;var t=this.context.gl;this.debugOverlayTexture=new e.Texture(this.context,this.debugOverlayCanvas,t.RGBA)}},mo.prototype.destroy=function(){this.emptyTexture.destroy(),this.debugOverlayTexture&&this.debugOverlayTexture.destroy()};var go=function(e,t){this.points=e,this.planes=t};go.fromInvProjectionMatrix=function(t,r,n){var i=[[-1,1,-1,1],[1,1,-1,1],[1,-1,-1,1],[-1,-1,-1,1],[-1,1,1,1],[1,1,1,1],[1,-1,1,1],[-1,-1,1,1]],o=Math.pow(2,n),a=i.map((function(r){return e.transformMat4([],r,t)})).map((function(t){return e.scale$1([],t,1/t[3]/r*o)})),s=[[0,1,2],[6,5,4],[0,3,7],[2,1,5],[3,2,6],[0,4,5]].map((function(t){var r=e.sub([],a[t[0]],a[t[1]]),n=e.sub([],a[t[2]],a[t[1]]),i=e.normalize([],e.cross([],r,n)),o=-e.dot(i,a[t[1]]);return i.concat(o)}));return new go(a,s)};var yo=function(t,r){this.min=t,this.max=r,this.center=e.scale$2([],e.add([],this.min,this.max),.5)};yo.prototype.quadrant=function(t){for(var r=[t%2===0,t<2],n=e.clone$2(this.min),i=e.clone$2(this.max),o=0;o=0;if(0===a)return 0;a!==r.length&&(n=!1)}if(n)return 2;for(var l=0;l<3;l++){for(var c=Number.MAX_VALUE,u=-Number.MAX_VALUE,d=0;dthis.max[l]-this.min[l])return 0}return 1};var vo=function(e,t,r,n){if(void 0===e&&(e=0),void 0===t&&(t=0),void 0===r&&(r=0),void 0===n&&(n=0),isNaN(e)||e<0||isNaN(t)||t<0||isNaN(r)||r<0||isNaN(n)||n<0)throw new Error("Invalid value for edge-insets, top, bottom, left and right must all be numbers");this.top=e,this.bottom=t,this.left=r,this.right=n};vo.prototype.interpolate=function(t,r,n){return null!=r.top&&null!=t.top&&(this.top=e.number(t.top,r.top,n)),null!=r.bottom&&null!=t.bottom&&(this.bottom=e.number(t.bottom,r.bottom,n)),null!=r.left&&null!=t.left&&(this.left=e.number(t.left,r.left,n)),null!=r.right&&null!=t.right&&(this.right=e.number(t.right,r.right,n)),this},vo.prototype.getCenter=function(t,r){var n=e.clamp((this.left+t-this.right)/2,0,t),i=e.clamp((this.top+r-this.bottom)/2,0,r);return new e.Point(n,i)},vo.prototype.equals=function(e){return this.top===e.top&&this.bottom===e.bottom&&this.left===e.left&&this.right===e.right},vo.prototype.clone=function(){return new vo(this.top,this.bottom,this.left,this.right)},vo.prototype.toJSON=function(){return{top:this.top,bottom:this.bottom,left:this.left,right:this.right}};var xo=function(t,r,n,i,o){this.tileSize=512,this.maxValidLatitude=85.051129,this._renderWorldCopies=void 0===o||o,this._minZoom=t||0,this._maxZoom=r||22,this._minPitch=void 0===n||null===n?0:n,this._maxPitch=void 0===i||null===i?60:i,this.setMaxBounds(),this.width=0,this.height=0,this._center=new e.LngLat(0,0),this.zoom=0,this.angle=0,this._fov=.6435011087932844,this._pitch=0,this._unmodified=!0,this._edgeInsets=new vo,this._posMatrixCache={},this._alignedPosMatrixCache={}},bo={minZoom:{configurable:!0},maxZoom:{configurable:!0},minPitch:{configurable:!0},maxPitch:{configurable:!0},renderWorldCopies:{configurable:!0},worldSize:{configurable:!0},centerOffset:{configurable:!0},size:{configurable:!0},bearing:{configurable:!0},pitch:{configurable:!0},fov:{configurable:!0},zoom:{configurable:!0},center:{configurable:!0},padding:{configurable:!0},centerPoint:{configurable:!0},unmodified:{configurable:!0},point:{configurable:!0}};function _o(e,t){var r=!1,n=null,i=function(){n=null,r&&(e(),n=setTimeout(i,t),r=!1)};return function(){return r=!0,n||i(),n}}xo.prototype.clone=function(){var e=new xo(this._minZoom,this._maxZoom,this._minPitch,this.maxPitch,this._renderWorldCopies);return e.tileSize=this.tileSize,e.latRange=this.latRange,e.width=this.width,e.height=this.height,e._center=this._center,e.zoom=this.zoom,e.angle=this.angle,e._fov=this._fov,e._pitch=this._pitch,e._unmodified=this._unmodified,e._edgeInsets=this._edgeInsets.clone(),e._calcMatrices(),e},bo.minZoom.get=function(){return this._minZoom},bo.minZoom.set=function(e){this._minZoom!==e&&(this._minZoom=e,this.zoom=Math.max(this.zoom,e))},bo.maxZoom.get=function(){return this._maxZoom},bo.maxZoom.set=function(e){this._maxZoom!==e&&(this._maxZoom=e,this.zoom=Math.min(this.zoom,e))},bo.minPitch.get=function(){return this._minPitch},bo.minPitch.set=function(e){this._minPitch!==e&&(this._minPitch=e,this.pitch=Math.max(this.pitch,e))},bo.maxPitch.get=function(){return this._maxPitch},bo.maxPitch.set=function(e){this._maxPitch!==e&&(this._maxPitch=e,this.pitch=Math.min(this.pitch,e))},bo.renderWorldCopies.get=function(){return this._renderWorldCopies},bo.renderWorldCopies.set=function(e){void 0===e?e=!0:null===e&&(e=!1),this._renderWorldCopies=e},bo.worldSize.get=function(){return this.tileSize*this.scale},bo.centerOffset.get=function(){return this.centerPoint._sub(this.size._div(2))},bo.size.get=function(){return new e.Point(this.width,this.height)},bo.bearing.get=function(){return-this.angle/Math.PI*180},bo.bearing.set=function(t){var r=-e.wrap(t,-180,180)*Math.PI/180;this.angle!==r&&(this._unmodified=!1,this.angle=r,this._calcMatrices(),this.rotationMatrix=e.create$2(),e.rotate(this.rotationMatrix,this.rotationMatrix,this.angle))},bo.pitch.get=function(){return this._pitch/Math.PI*180},bo.pitch.set=function(t){var r=e.clamp(t,this.minPitch,this.maxPitch)/180*Math.PI;this._pitch!==r&&(this._unmodified=!1,this._pitch=r,this._calcMatrices())},bo.fov.get=function(){return this._fov/Math.PI*180},bo.fov.set=function(e){e=Math.max(.01,Math.min(60,e)),this._fov!==e&&(this._unmodified=!1,this._fov=e/180*Math.PI,this._calcMatrices())},bo.zoom.get=function(){return this._zoom},bo.zoom.set=function(e){var t=Math.min(Math.max(e,this.minZoom),this.maxZoom);this._zoom!==t&&(this._unmodified=!1,this._zoom=t,this.scale=this.zoomScale(t),this.tileZoom=Math.floor(t),this.zoomFraction=t-this.tileZoom,this._constrain(),this._calcMatrices())},bo.center.get=function(){return this._center},bo.center.set=function(e){e.lat===this._center.lat&&e.lng===this._center.lng||(this._unmodified=!1,this._center=e,this._constrain(),this._calcMatrices())},bo.padding.get=function(){return this._edgeInsets.toJSON()},bo.padding.set=function(e){this._edgeInsets.equals(e)||(this._unmodified=!1,this._edgeInsets.interpolate(this._edgeInsets,e,1),this._calcMatrices())},bo.centerPoint.get=function(){return this._edgeInsets.getCenter(this.width,this.height)},xo.prototype.isPaddingEqual=function(e){return this._edgeInsets.equals(e)},xo.prototype.interpolatePadding=function(e,t,r){this._unmodified=!1,this._edgeInsets.interpolate(e,t,r),this._constrain(),this._calcMatrices()},xo.prototype.coveringZoomLevel=function(e){var t=(e.roundZoom?Math.round:Math.floor)(this.zoom+this.scaleZoom(this.tileSize/e.tileSize));return Math.max(0,t)},xo.prototype.getVisibleUnwrappedCoordinates=function(t){var r=[new e.UnwrappedTileID(0,t)];if(this._renderWorldCopies)for(var n=this.pointCoordinate(new e.Point(0,0)),i=this.pointCoordinate(new e.Point(this.width,0)),o=this.pointCoordinate(new e.Point(this.width,this.height)),a=this.pointCoordinate(new e.Point(0,this.height)),s=Math.floor(Math.min(n.x,i.x,o.x,a.x)),l=Math.floor(Math.max(n.x,i.x,o.x,a.x)),c=1,u=s-c;u<=l+c;u++)0!==u&&r.push(new e.UnwrappedTileID(u,t));return r},xo.prototype.coveringTiles=function(t){var r=this.coveringZoomLevel(t),n=r;if(void 0!==t.minzoom&&rt.maxzoom&&(r=t.maxzoom);var i=e.MercatorCoordinate.fromLngLat(this.center),o=Math.pow(2,r),a=[o*i.x,o*i.y,0],s=go.fromInvProjectionMatrix(this.invProjMatrix,this.worldSize,r),l=t.minzoom||0;this.pitch<=60&&this._edgeInsets.top<.1&&(l=r);var c=3,u=function(e){return{aabb:new yo([e*o,0,0],[(e+1)*o,o,0]),zoom:0,x:0,y:0,wrap:e,fullyVisible:!1}},d=[],h=[],p=r,f=t.reparseOverscaled?n:r;if(this._renderWorldCopies)for(var m=1;m<=3;m++)d.push(u(-m)),d.push(u(m));for(d.push(u(0));d.length>0;){var g=d.pop(),y=g.x,v=g.y,x=g.fullyVisible;if(!x){var b=g.aabb.intersects(s);if(0===b)continue;x=2===b}var _=g.aabb.distanceX(a),w=g.aabb.distanceY(a),k=Math.max(Math.abs(_),Math.abs(w)),S=c+(1<S&&g.zoom>=l)h.push({tileID:new e.OverscaledTileID(g.zoom===p?f:g.zoom,g.wrap,g.zoom,y,v),distanceSq:e.sqrLen([a[0]-.5-y,a[1]-.5-v])});else for(var A=0;A<4;A++){var T=(y<<1)+A%2,M=(v<<1)+(A>>1);d.push({aabb:g.aabb.quadrant(A),zoom:g.zoom+1,x:T,y:M,wrap:g.wrap,fullyVisible:x})}}return h.sort((function(e,t){return e.distanceSq-t.distanceSq})).map((function(e){return e.tileID}))},xo.prototype.resize=function(e,t){this.width=e,this.height=t,this.pixelsToGLUnits=[2/e,-2/t],this._constrain(),this._calcMatrices()},bo.unmodified.get=function(){return this._unmodified},xo.prototype.zoomScale=function(e){return Math.pow(2,e)},xo.prototype.scaleZoom=function(e){return Math.log(e)/Math.LN2},xo.prototype.project=function(t){var r=e.clamp(t.lat,-this.maxValidLatitude,this.maxValidLatitude);return new e.Point(e.mercatorXfromLng(t.lng)*this.worldSize,e.mercatorYfromLat(r)*this.worldSize)},xo.prototype.unproject=function(t){return new e.MercatorCoordinate(t.x/this.worldSize,t.y/this.worldSize).toLngLat()},bo.point.get=function(){return this.project(this.center)},xo.prototype.setLocationAtPoint=function(t,r){var n=this.pointCoordinate(r),i=this.pointCoordinate(this.centerPoint),o=this.locationCoordinate(t),a=new e.MercatorCoordinate(o.x-(n.x-i.x),o.y-(n.y-i.y));this.center=this.coordinateLocation(a),this._renderWorldCopies&&(this.center=this.center.wrap())},xo.prototype.locationPoint=function(e){return this.coordinatePoint(this.locationCoordinate(e))},xo.prototype.pointLocation=function(e){return this.coordinateLocation(this.pointCoordinate(e))},xo.prototype.locationCoordinate=function(t){return e.MercatorCoordinate.fromLngLat(t)},xo.prototype.coordinateLocation=function(e){return e.toLngLat()},xo.prototype.pointCoordinate=function(t){var r=0,n=[t.x,t.y,0,1],i=[t.x,t.y,1,1];e.transformMat4(n,n,this.pixelMatrixInverse),e.transformMat4(i,i,this.pixelMatrixInverse);var o=n[3],a=i[3],s=n[0]/o,l=i[0]/a,c=n[1]/o,u=i[1]/a,d=n[2]/o,h=i[2]/a,p=d===h?0:(r-d)/(h-d);return new e.MercatorCoordinate(e.number(s,l,p)/this.worldSize,e.number(c,u,p)/this.worldSize)},xo.prototype.coordinatePoint=function(t){var r=[t.x*this.worldSize,t.y*this.worldSize,0,1];return e.transformMat4(r,r,this.pixelMatrix),new e.Point(r[0]/r[3],r[1]/r[3])},xo.prototype.getBounds=function(){return(new e.LngLatBounds).extend(this.pointLocation(new e.Point(0,0))).extend(this.pointLocation(new e.Point(this.width,0))).extend(this.pointLocation(new e.Point(this.width,this.height))).extend(this.pointLocation(new e.Point(0,this.height)))},xo.prototype.getMaxBounds=function(){return this.latRange&&2===this.latRange.length&&this.lngRange&&2===this.lngRange.length?new e.LngLatBounds([this.lngRange[0],this.latRange[0]],[this.lngRange[1],this.latRange[1]]):null},xo.prototype.setMaxBounds=function(e){e?(this.lngRange=[e.getWest(),e.getEast()],this.latRange=[e.getSouth(),e.getNorth()],this._constrain()):(this.lngRange=null,this.latRange=[-this.maxValidLatitude,this.maxValidLatitude])},xo.prototype.calculatePosMatrix=function(t,r){void 0===r&&(r=!1);var n=t.key,i=r?this._alignedPosMatrixCache:this._posMatrixCache;if(i[n])return i[n];var o=t.canonical,a=this.worldSize/this.zoomScale(o.z),s=o.x+Math.pow(2,o.z)*t.wrap,l=e.identity(new Float64Array(16));return e.translate(l,l,[s*a,o.y*a,0]),e.scale(l,l,[a/e.EXTENT,a/e.EXTENT,1]),e.multiply(l,r?this.alignedProjMatrix:this.projMatrix,l),i[n]=new Float32Array(l),i[n]},xo.prototype.customLayerMatrix=function(){return this.mercatorMatrix.slice()},xo.prototype._constrain=function(){if(this.center&&this.width&&this.height&&!this._constraining){this._constraining=!0;var t,r,n,i,o=-90,a=90,s=-180,l=180,c=this.size,u=this._unmodified;if(this.latRange){var d=this.latRange;o=e.mercatorYfromLat(d[1])*this.worldSize,t=(a=e.mercatorYfromLat(d[0])*this.worldSize)-oa&&(i=a-g)}if(this.lngRange){var y=p.x,v=c.x/2;y-vl&&(n=l-v)}void 0===n&&void 0===i||(this.center=this.unproject(new e.Point(void 0!==n?n:p.x,void 0!==i?i:p.y))),this._unmodified=u,this._constraining=!1}},xo.prototype._calcMatrices=function(){if(this.height){var t=this._fov/2,r=this.centerOffset;this.cameraToCenterDistance=.5/Math.tan(t)*this.height;var n=Math.PI/2+this._pitch,i=this._fov*(.5+r.y/this.height),o=Math.sin(i)*this.cameraToCenterDistance/Math.sin(e.clamp(Math.PI-n-i,.01,Math.PI-.01)),a=this.point,s=a.x,l=a.y,c=1.01*(Math.cos(Math.PI/2-this._pitch)*o+this.cameraToCenterDistance),u=this.height/50,d=new Float64Array(16);e.perspective(d,this._fov,this.width/this.height,u,c),d[8]=2*-r.x/this.width,d[9]=2*r.y/this.height,e.scale(d,d,[1,-1,1]),e.translate(d,d,[0,0,-this.cameraToCenterDistance]),e.rotateX(d,d,this._pitch),e.rotateZ(d,d,this.angle),e.translate(d,d,[-s,-l,0]),this.mercatorMatrix=e.scale([],d,[this.worldSize,this.worldSize,this.worldSize]),e.scale(d,d,[1,1,e.mercatorZfromAltitude(1,this.center.lat)*this.worldSize,1]),this.projMatrix=d,this.invProjMatrix=e.invert([],this.projMatrix);var h=this.width%2/2,p=this.height%2/2,f=Math.cos(this.angle),m=Math.sin(this.angle),g=s-Math.round(s)+f*h+m*p,y=l-Math.round(l)+f*p+m*h,v=new Float64Array(d);if(e.translate(v,v,[g>.5?g-1:g,y>.5?y-1:y,0]),this.alignedProjMatrix=v,d=e.create(),e.scale(d,d,[this.width/2,-this.height/2,1]),e.translate(d,d,[1,-1,0]),this.labelPlaneMatrix=d,d=e.create(),e.scale(d,d,[1,-1,1]),e.translate(d,d,[-1,-1,0]),e.scale(d,d,[2/this.width,2/this.height,1]),this.glCoordMatrix=d,this.pixelMatrix=e.multiply(new Float64Array(16),this.labelPlaneMatrix,this.projMatrix),!(d=e.invert(new Float64Array(16),this.pixelMatrix)))throw new Error("failed to invert matrix");this.pixelMatrixInverse=d,this._posMatrixCache={},this._alignedPosMatrixCache={}}},xo.prototype.maxPitchScaleFactor=function(){if(!this.pixelMatrixInverse)return 1;var t=this.pointCoordinate(new e.Point(0,0)),r=[t.x*this.worldSize,t.y*this.worldSize,0,1];return e.transformMat4(r,r,this.pixelMatrix)[3]/this.cameraToCenterDistance},xo.prototype.getCameraPoint=function(){var t=this._pitch,r=Math.tan(t)*(this.cameraToCenterDistance||1);return this.centerPoint.add(new e.Point(0,r))},xo.prototype.getCameraQueryGeometry=function(t){var r=this.getCameraPoint();if(1===t.length)return[t[0],r];for(var n=r.x,i=r.y,o=r.x,a=r.y,s=0,l=t;s=3&&!e.some((function(e){return isNaN(e)}))){var t=this._map.dragRotate.isEnabled()&&this._map.touchZoomRotate.isEnabled()?+(e[3]||0):this._map.getBearing();return this._map.jumpTo({center:[+e[2],+e[1]],zoom:+e[0],bearing:t,pitch:+(e[4]||0)}),!0}return!1},wo.prototype._updateHashUnthrottled=function(){var t=e.window.location.href.replace(/(#.+)?$/,this.getHashString());try{e.window.history.replaceState(e.window.history.state,null,t)}catch(r){}};var ko={linearity:.3,easing:e.bezier(0,0,.3,1)},So=e.extend({deceleration:2500,maxSpeed:1400},ko),Ao=e.extend({deceleration:20,maxSpeed:1400},ko),To=e.extend({deceleration:1e3,maxSpeed:360},ko),Mo=e.extend({deceleration:1e3,maxSpeed:90},ko),Co=function(e){this._map=e,this.clear()};function Eo(e,t){(!e.duration||e.duration0&&r-t[0].time>n;)t.shift()},Co.prototype._onMoveEnd=function(t){if(this._drainInertiaBuffer(),!(this._inertiaBuffer.length<2)){for(var r={zoom:0,bearing:0,pitch:0,pan:new e.Point(0,0),pinchAround:void 0,around:void 0},n=0,i=this._inertiaBuffer;n=this._clickTolerance||this._map.fire(new Po(e.type,this._map,e))},Lo.prototype.dblclick=function(e){return this._firePreventable(new Po(e.type,this._map,e))},Lo.prototype.mouseover=function(e){this._map.fire(new Po(e.type,this._map,e))},Lo.prototype.mouseout=function(e){this._map.fire(new Po(e.type,this._map,e))},Lo.prototype.touchstart=function(e){return this._firePreventable(new Oo(e.type,this._map,e))},Lo.prototype.touchmove=function(e){this._map.fire(new Oo(e.type,this._map,e))},Lo.prototype.touchend=function(e){this._map.fire(new Oo(e.type,this._map,e))},Lo.prototype.touchcancel=function(e){this._map.fire(new Oo(e.type,this._map,e))},Lo.prototype._firePreventable=function(e){if(this._map.fire(e),e.defaultPrevented)return{}},Lo.prototype.isEnabled=function(){return!0},Lo.prototype.isActive=function(){return!1},Lo.prototype.enable=function(){},Lo.prototype.disable=function(){};var Do=function(e){this._map=e};Do.prototype.reset=function(){this._delayContextMenu=!1,delete this._contextMenuEvent},Do.prototype.mousemove=function(e){this._map.fire(new Po(e.type,this._map,e))},Do.prototype.mousedown=function(){this._delayContextMenu=!0},Do.prototype.mouseup=function(){this._delayContextMenu=!1,this._contextMenuEvent&&(this._map.fire(new Po("contextmenu",this._map,this._contextMenuEvent)),delete this._contextMenuEvent)},Do.prototype.contextmenu=function(e){this._delayContextMenu?this._contextMenuEvent=e:this._map.fire(new Po(e.type,this._map,e)),this._map.listens("contextmenu")&&e.preventDefault()},Do.prototype.isEnabled=function(){return!0},Do.prototype.isActive=function(){return!1},Do.prototype.enable=function(){},Do.prototype.disable=function(){};var zo=function(e,t){this._map=e,this._el=e.getCanvasContainer(),this._container=e.getContainer(),this._clickTolerance=t.clickTolerance||1};function jo(e,t){for(var r={},n=0;nthis.numTouches)&&(this.aborted=!0),this.aborted||(void 0===this.startTime&&(this.startTime=e.timeStamp),r.length===this.numTouches&&(this.centroid=Fo(t),this.touches=jo(r,t)))},Uo.prototype.touchmove=function(e,t,r){if(!this.aborted&&this.centroid){var n=jo(r,t);for(var i in this.touches){var o=this.touches[i],a=n[i];(!a||a.dist(o)>Vo)&&(this.aborted=!0)}}},Uo.prototype.touchend=function(e,t,r){if((!this.centroid||e.timeStamp-this.startTime>Bo)&&(this.aborted=!0),0===r.length){var n=!this.aborted&&this.centroid;if(this.reset(),n)return n}};var Ho=function(e){this.singleTap=new Uo(e),this.numTaps=e.numTaps,this.reset()};Ho.prototype.reset=function(){this.lastTime=1/0,delete this.lastTap,this.count=0,this.singleTap.reset()},Ho.prototype.touchstart=function(e,t,r){this.singleTap.touchstart(e,t,r)},Ho.prototype.touchmove=function(e,t,r){this.singleTap.touchmove(e,t,r)},Ho.prototype.touchend=function(e,t,r){var n=this.singleTap.touchend(e,t,r);if(n){var i=e.timeStamp-this.lastTime0&&(this._active=!0);var i=jo(n,r),o=new e.Point(0,0),a=new e.Point(0,0),s=0;for(var l in i){var c=i[l],u=this._touches[l];u&&(o._add(c),a._add(c.sub(u)),s++,i[l]=c)}if(this._touches=i,!(sMath.abs(e.x)}var ca=100,ua=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.reset=function(){e.prototype.reset.call(this),this._valid=void 0,delete this._firstMove,delete this._lastPoints},t.prototype._start=function(e){this._lastPoints=e,la(e[0].sub(e[1]))&&(this._valid=!1)},t.prototype._move=function(e,t,r){var n=e[0].sub(this._lastPoints[0]),i=e[1].sub(this._lastPoints[1]);if(this._valid=this.gestureBeginsVertically(n,i,r.timeStamp),this._valid)return this._lastPoints=e,this._active=!0,{pitchDelta:(n.y+i.y)/2*-.5}},t.prototype.gestureBeginsVertically=function(e,t,r){if(void 0!==this._valid)return this._valid;var n=2,i=e.mag()>=n,o=t.mag()>=n;if(i||o){if(!i||!o)return void 0===this._firstMove&&(this._firstMove=r),r-this._firstMove0===t.y>0;return la(e)&&la(t)&&a}},t}(ea),da={panStep:100,bearingStep:15,pitchStep:10},ha=function(){var e=da;this._panStep=e.panStep,this._bearingStep=e.bearingStep,this._pitchStep=e.pitchStep,this._rotationDisabled=!1};function pa(e){return e*(2-e)}ha.prototype.reset=function(){this._active=!1},ha.prototype.keydown=function(e){var t=this;if(!(e.altKey||e.ctrlKey||e.metaKey)){var r=0,n=0,i=0,o=0,a=0;switch(e.keyCode){case 61:case 107:case 171:case 187:r=1;break;case 189:case 109:case 173:r=-1;break;case 37:e.shiftKey?n=-1:(e.preventDefault(),o=-1);break;case 39:e.shiftKey?n=1:(e.preventDefault(),o=1);break;case 38:e.shiftKey?i=1:(e.preventDefault(),a=-1);break;case 40:e.shiftKey?i=-1:(e.preventDefault(),a=1);break;default:return}return this._rotationDisabled&&(n=0,i=0),{cameraAnimation:function(s){var l=s.getZoom();s.easeTo({duration:300,easeId:"keyboardHandler",easing:pa,zoom:r?Math.round(l)+r*(e.shiftKey?2:1):l,bearing:s.getBearing()+n*t._bearingStep,pitch:s.getPitch()+i*t._pitchStep,offset:[-o*t._panStep,-a*t._panStep],center:s.getCenter()},{originalEvent:e})}}}},ha.prototype.enable=function(){this._enabled=!0},ha.prototype.disable=function(){this._enabled=!1,this.reset()},ha.prototype.isEnabled=function(){return this._enabled},ha.prototype.isActive=function(){return this._active},ha.prototype.disableRotation=function(){this._rotationDisabled=!0},ha.prototype.enableRotation=function(){this._rotationDisabled=!1};var fa=4.000244140625,ma=.01,ga=1/450,ya=2,va=function(t,r){this._map=t,this._el=t.getCanvasContainer(),this._handler=r,this._delta=0,this._defaultZoomRate=ma,this._wheelZoomRate=ga,e.bindAll(["_onTimeout"],this)};va.prototype.setZoomRate=function(e){this._defaultZoomRate=e},va.prototype.setWheelZoomRate=function(e){this._wheelZoomRate=e},va.prototype.isEnabled=function(){return!!this._enabled},va.prototype.isActive=function(){return!!this._active||void 0!==this._finishTimeout},va.prototype.isZooming=function(){return!!this._zooming},va.prototype.enable=function(e){this.isEnabled()||(this._enabled=!0,this._aroundCenter=e&&"center"===e.around)},va.prototype.disable=function(){this.isEnabled()&&(this._enabled=!1)},va.prototype.wheel=function(t){if(this.isEnabled()){var r=t.deltaMode===e.window.WheelEvent.DOM_DELTA_LINE?40*t.deltaY:t.deltaY,n=e.browser.now(),i=n-(this._lastWheelEventTime||0);this._lastWheelEventTime=n,0!==r&&r%fa===0?this._type="wheel":0!==r&&Math.abs(r)<4?this._type="trackpad":i>400?(this._type=null,this._lastValue=r,this._timeout=setTimeout(this._onTimeout,40,t)):this._type||(this._type=Math.abs(i*r)<200?"trackpad":"wheel",this._timeout&&(clearTimeout(this._timeout),this._timeout=null,r+=this._lastValue)),t.shiftKey&&r&&(r/=4),this._type&&(this._lastWheelEvent=t,this._delta-=r,this._active||this._start(t)),t.preventDefault()}},va.prototype._onTimeout=function(e){this._type="wheel",this._delta-=this._lastValue,this._active||this._start(e)},va.prototype._start=function(t){if(this._delta){this._frameId&&(this._frameId=null),this._active=!0,this.isZooming()||(this._zooming=!0),this._finishTimeout&&(clearTimeout(this._finishTimeout),delete this._finishTimeout);var n=r.mousePos(this._el,t);this._around=e.LngLat.convert(this._aroundCenter?this._map.getCenter():this._map.unproject(n)),this._aroundPoint=this._map.transform.locationPoint(this._around),this._frameId||(this._frameId=!0,this._handler._triggerRenderFrame())}},va.prototype.renderFrame=function(){var t=this;if(this._frameId&&(this._frameId=null,this.isActive())){var r=this._map.transform;if(0!==this._delta){var n="wheel"===this._type&&Math.abs(this._delta)>fa?this._wheelZoomRate:this._defaultZoomRate,i=ya/(1+Math.exp(-Math.abs(this._delta*n)));this._delta<0&&0!==i&&(i=1/i);var o="number"===typeof this._targetZoom?r.zoomScale(this._targetZoom):r.scale;this._targetZoom=Math.min(r.maxZoom,Math.max(r.minZoom,r.scaleZoom(o*i))),"wheel"===this._type&&(this._startZoom=r.zoom,this._easing=this._smoothOutEasing(200)),this._delta=0}var a,s="number"===typeof this._targetZoom?this._targetZoom:r.zoom,l=this._startZoom,c=this._easing,u=!1;if("wheel"===this._type&&l&&c){var d=Math.min((e.browser.now()-this._lastWheelEventTime)/200,1),h=c(d);a=e.number(l,s,h),d<1?this._frameId||(this._frameId=!0):u=!0}else a=s,u=!0;return this._active=!0,u&&(this._active=!1,this._finishTimeout=setTimeout((function(){t._zooming=!1,t._handler._triggerRenderFrame(),delete t._targetZoom,delete t._finishTimeout}),200)),{noInertia:!0,needsRenderFrame:!u,zoomDelta:a-r.zoom,around:this._aroundPoint,originalEvent:this._lastWheelEvent}}},va.prototype._smoothOutEasing=function(t){var r=e.ease;if(this._prevEase){var n=this._prevEase,i=(e.browser.now()-n.start)/n.duration,o=n.easing(i+.01)-n.easing(i),a=.27/Math.sqrt(o*o+1e-4)*.01,s=Math.sqrt(.0729-a*a);r=e.bezier(a,s,.25,1)}return this._prevEase={start:e.browser.now(),duration:t,easing:r},r},va.prototype.reset=function(){this._active=!1};var xa=function(e,t){this._clickZoom=e,this._tapZoom=t};xa.prototype.enable=function(){this._clickZoom.enable(),this._tapZoom.enable()},xa.prototype.disable=function(){this._clickZoom.disable(),this._tapZoom.disable()},xa.prototype.isEnabled=function(){return this._clickZoom.isEnabled()&&this._tapZoom.isEnabled()},xa.prototype.isActive=function(){return this._clickZoom.isActive()||this._tapZoom.isActive()};var ba=function(){this.reset()};ba.prototype.reset=function(){this._active=!1},ba.prototype.dblclick=function(e,t){return e.preventDefault(),{cameraAnimation:function(r){r.easeTo({duration:300,zoom:r.getZoom()+(e.shiftKey?-1:1),around:r.unproject(t)},{originalEvent:e})}}},ba.prototype.enable=function(){this._enabled=!0},ba.prototype.disable=function(){this._enabled=!1,this.reset()},ba.prototype.isEnabled=function(){return this._enabled},ba.prototype.isActive=function(){return this._active};var _a=function(){this._tap=new Ho({numTouches:1,numTaps:1}),this.reset()};_a.prototype.reset=function(){this._active=!1,delete this._swipePoint,delete this._swipeTouch,delete this._tapTime,this._tap.reset()},_a.prototype.touchstart=function(e,t,r){this._swipePoint||(this._tapTime&&e.timeStamp-this._tapTime>No&&this.reset(),this._tapTime?r.length>0&&(this._swipePoint=t[0],this._swipeTouch=r[0].identifier):this._tap.touchstart(e,t,r))},_a.prototype.touchmove=function(e,t,r){if(this._tapTime){if(this._swipePoint){if(r[0].identifier!==this._swipeTouch)return;var n=t[0],i=n.y-this._swipePoint.y;return this._swipePoint=n,e.preventDefault(),this._active=!0,{zoomDelta:i/128}}}else this._tap.touchmove(e,t,r)},_a.prototype.touchend=function(e,t,r){this._tapTime?this._swipePoint&&0===r.length&&this.reset():this._tap.touchend(e,t,r)&&(this._tapTime=e.timeStamp)},_a.prototype.touchcancel=function(){this.reset()},_a.prototype.enable=function(){this._enabled=!0},_a.prototype.disable=function(){this._enabled=!1,this.reset()},_a.prototype.isEnabled=function(){return this._enabled},_a.prototype.isActive=function(){return this._active};var wa=function(e,t,r){this._el=e,this._mousePan=t,this._touchPan=r};wa.prototype.enable=function(e){this._inertiaOptions=e||{},this._mousePan.enable(),this._touchPan.enable(),this._el.classList.add("mapboxgl-touch-drag-pan")},wa.prototype.disable=function(){this._mousePan.disable(),this._touchPan.disable(),this._el.classList.remove("mapboxgl-touch-drag-pan")},wa.prototype.isEnabled=function(){return this._mousePan.isEnabled()&&this._touchPan.isEnabled()},wa.prototype.isActive=function(){return this._mousePan.isActive()||this._touchPan.isActive()};var ka=function(e,t,r){this._pitchWithRotate=e.pitchWithRotate,this._mouseRotate=t,this._mousePitch=r};ka.prototype.enable=function(){this._mouseRotate.enable(),this._pitchWithRotate&&this._mousePitch.enable()},ka.prototype.disable=function(){this._mouseRotate.disable(),this._mousePitch.disable()},ka.prototype.isEnabled=function(){return this._mouseRotate.isEnabled()&&(!this._pitchWithRotate||this._mousePitch.isEnabled())},ka.prototype.isActive=function(){return this._mouseRotate.isActive()||this._mousePitch.isActive()};var Sa=function(e,t,r,n){this._el=e,this._touchZoom=t,this._touchRotate=r,this._tapDragZoom=n,this._rotationDisabled=!1,this._enabled=!0};Sa.prototype.enable=function(e){this._touchZoom.enable(e),this._rotationDisabled||this._touchRotate.enable(e),this._tapDragZoom.enable(),this._el.classList.add("mapboxgl-touch-zoom-rotate")},Sa.prototype.disable=function(){this._touchZoom.disable(),this._touchRotate.disable(),this._tapDragZoom.disable(),this._el.classList.remove("mapboxgl-touch-zoom-rotate")},Sa.prototype.isEnabled=function(){return this._touchZoom.isEnabled()&&(this._rotationDisabled||this._touchRotate.isEnabled())&&this._tapDragZoom.isEnabled()},Sa.prototype.isActive=function(){return this._touchZoom.isActive()||this._touchRotate.isActive()||this._tapDragZoom.isActive()},Sa.prototype.disableRotation=function(){this._rotationDisabled=!0,this._touchRotate.disable()},Sa.prototype.enableRotation=function(){this._rotationDisabled=!1,this._touchZoom.isEnabled()&&this._touchRotate.enable()};var Aa=function(e){return e.zoom||e.drag||e.pitch||e.rotate},Ta=function(e){function t(){e.apply(this,arguments)}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t}(e.Event);function Ma(e){return e.panDelta&&e.panDelta.mag()||e.zoomDelta||e.bearingDelta||e.pitchDelta}var Ca=function(t,n){this._map=t,this._el=this._map.getCanvasContainer(),this._handlers=[],this._handlersById={},this._changes=[],this._inertia=new Co(t),this._bearingSnap=n.bearingSnap,this._previousActiveHandlers={},this._eventsInProgress={},this._addDefaultHandlers(n),e.bindAll(["handleEvent","handleWindowEvent"],this);var i=this._el;this._listeners=[[i,"touchstart",{passive:!0}],[i,"touchmove",{passive:!1}],[i,"touchend",void 0],[i,"touchcancel",void 0],[i,"mousedown",void 0],[i,"mousemove",void 0],[i,"mouseup",void 0],[e.window.document,"mousemove",{capture:!0}],[e.window.document,"mouseup",void 0],[i,"mouseover",void 0],[i,"mouseout",void 0],[i,"dblclick",void 0],[i,"click",void 0],[i,"keydown",{capture:!1}],[i,"keyup",void 0],[i,"wheel",{passive:!1}],[i,"contextmenu",void 0],[e.window,"blur",void 0]];for(var o=0,a=this._listeners;oo?Math.min(2,_):Math.max(.5,_),w=Math.pow(g,1-t),k=i.unproject(x.add(b.mult(t*w)).mult(m));i.setLocationAtPoint(i.renderWorldCopies?k.wrap():k,f)}n._fireMoveEvents(r)}),(function(e){n._afterEase(r,e)}),t),this},r.prototype._prepareEase=function(t,r,n){void 0===n&&(n={}),this._moving=!0,r||n.moving||this.fire(new e.Event("movestart",t)),this._zooming&&!n.zooming&&this.fire(new e.Event("zoomstart",t)),this._rotating&&!n.rotating&&this.fire(new e.Event("rotatestart",t)),this._pitching&&!n.pitching&&this.fire(new e.Event("pitchstart",t))},r.prototype._fireMoveEvents=function(t){this.fire(new e.Event("move",t)),this._zooming&&this.fire(new e.Event("zoom",t)),this._rotating&&this.fire(new e.Event("rotate",t)),this._pitching&&this.fire(new e.Event("pitch",t))},r.prototype._afterEase=function(t,r){if(!this._easeId||!r||this._easeId!==r){delete this._easeId;var n=this._zooming,i=this._rotating,o=this._pitching;this._moving=!1,this._zooming=!1,this._rotating=!1,this._pitching=!1,this._padding=!1,n&&this.fire(new e.Event("zoomend",t)),i&&this.fire(new e.Event("rotateend",t)),o&&this.fire(new e.Event("pitchend",t)),this.fire(new e.Event("moveend",t))}},r.prototype.flyTo=function(t,r){var n=this;if(!t.essential&&e.browser.prefersReducedMotion){var i=e.pick(t,["center","zoom","bearing","pitch","around"]);return this.jumpTo(i,r)}this.stop(),t=e.extend({offset:[0,0],speed:1.2,curve:1.42,easing:e.ease},t);var o=this.transform,a=this.getZoom(),s=this.getBearing(),l=this.getPitch(),c=this.getPadding(),u="zoom"in t?e.clamp(+t.zoom,o.minZoom,o.maxZoom):a,d="bearing"in t?this._normalizeBearing(t.bearing,s):s,h="pitch"in t?+t.pitch:l,p="padding"in t?t.padding:o.padding,f=o.zoomScale(u-a),m=e.Point.convert(t.offset),g=o.centerPoint.add(m),y=o.pointLocation(g),v=e.LngLat.convert(t.center||y);this._normalizeCenter(v);var x=o.project(y),b=o.project(v).sub(x),_=t.curve,w=Math.max(o.width,o.height),k=w/f,S=b.mag();if("minZoom"in t){var A=e.clamp(Math.min(t.minZoom,a,u),o.minZoom,o.maxZoom),T=w/o.zoomScale(A-a);_=Math.sqrt(T/S*2)}var M=_*_;function C(e){var t=(k*k-w*w+(e?-1:1)*M*M*S*S)/(2*(e?k:w)*M*S);return Math.log(Math.sqrt(t*t+1)-t)}function E(e){return(Math.exp(e)-Math.exp(-e))/2}function I(e){return(Math.exp(e)+Math.exp(-e))/2}function P(e){return E(e)/I(e)}var O=C(0),R=function(e){return I(O)/I(O+_*e)},L=function(e){return w*((I(O)*P(O+_*e)-E(O))/M)/S},D=(C(1)-O)/_;if(Math.abs(S)<1e-6||!isFinite(D)){if(Math.abs(w-k)<1e-6)return this.easeTo(t,r);var z=kt.maxDuration&&(t.duration=0),this._zooming=!0,this._rotating=s!==d,this._pitching=h!==l,this._padding=!o.isPaddingEqual(p),this._prepareEase(r,!1),this._ease((function(t){var i=t*D,f=1/R(i);o.zoom=1===t?u:a+o.scaleZoom(f),n._rotating&&(o.bearing=e.number(s,d,t)),n._pitching&&(o.pitch=e.number(l,h,t)),n._padding&&(o.interpolatePadding(c,p,t),g=o.centerPoint.add(m));var y=1===t?v:o.unproject(x.add(b.mult(L(i))).mult(f));o.setLocationAtPoint(o.renderWorldCopies?y.wrap():y,g),n._fireMoveEvents(r)}),(function(){return n._afterEase(r)}),t),this},r.prototype.isEasing=function(){return!!this._easeFrameId},r.prototype.stop=function(){return this._stop()},r.prototype._stop=function(e,t){if(this._easeFrameId&&(this._cancelRenderFrame(this._easeFrameId),delete this._easeFrameId,delete this._onEaseFrame),this._onEaseEnd){var r=this._onEaseEnd;delete this._onEaseEnd,r.call(this,t)}if(!e){var n=this.handlers;n&&n.stop(!1)}return this},r.prototype._ease=function(t,r,n){!1===n.animate||0===n.duration?(t(1),r()):(this._easeStart=e.browser.now(),this._easeOptions=n,this._onEaseFrame=t,this._onEaseEnd=r,this._easeFrameId=this._requestRenderFrame(this._renderFrameCallback))},r.prototype._renderFrameCallback=function(){var t=Math.min((e.browser.now()-this._easeStart)/this._easeOptions.duration,1);this._onEaseFrame(this._easeOptions.easing(t)),t<1?this._easeFrameId=this._requestRenderFrame(this._renderFrameCallback):this.stop()},r.prototype._normalizeBearing=function(t,r){t=e.wrap(t,-180,180);var n=Math.abs(t-r);return Math.abs(t-360-r)180?-360:r<-180?360:0}},r}(e.Evented),Ia=function(t){void 0===t&&(t={}),this.options=t,e.bindAll(["_toggleAttribution","_updateEditLink","_updateData","_updateCompact"],this)};Ia.prototype.getDefaultPosition=function(){return"bottom-right"},Ia.prototype.onAdd=function(e){var t=this.options&&this.options.compact;return this._map=e,this._container=r.create("div","mapboxgl-ctrl mapboxgl-ctrl-attrib"),this._compactButton=r.create("button","mapboxgl-ctrl-attrib-button",this._container),this._compactButton.addEventListener("click",this._toggleAttribution),this._setElementTitle(this._compactButton,"ToggleAttribution"),this._innerContainer=r.create("div","mapboxgl-ctrl-attrib-inner",this._container),this._innerContainer.setAttribute("role","list"),t&&this._container.classList.add("mapboxgl-compact"),this._updateAttributions(),this._updateEditLink(),this._map.on("styledata",this._updateData),this._map.on("sourcedata",this._updateData),this._map.on("moveend",this._updateEditLink),void 0===t&&(this._map.on("resize",this._updateCompact),this._updateCompact()),this._container},Ia.prototype.onRemove=function(){r.remove(this._container),this._map.off("styledata",this._updateData),this._map.off("sourcedata",this._updateData),this._map.off("moveend",this._updateEditLink),this._map.off("resize",this._updateCompact),this._map=void 0,this._attribHTML=void 0},Ia.prototype._setElementTitle=function(e,t){var r=this._map._getUIString("AttributionControl."+t);e.title=r,e.setAttribute("aria-label",r)},Ia.prototype._toggleAttribution=function(){this._container.classList.contains("mapboxgl-compact-show")?(this._container.classList.remove("mapboxgl-compact-show"),this._compactButton.setAttribute("aria-pressed","false")):(this._container.classList.add("mapboxgl-compact-show"),this._compactButton.setAttribute("aria-pressed","true"))},Ia.prototype._updateEditLink=function(){var t=this._editLink;t||(t=this._editLink=this._container.querySelector(".mapbox-improve-map"));var r=[{key:"owner",value:this.styleOwner},{key:"id",value:this.styleId},{key:"access_token",value:this._map._requestManager._customAccessToken||e.config.ACCESS_TOKEN}];if(t){var n=r.reduce((function(e,t,n){return t.value&&(e+=t.key+"="+t.value+(n=0)return!1;return!0}))).join(" | ");a!==this._attribHTML&&(this._attribHTML=a,e.length?(this._innerContainer.innerHTML=a,this._container.classList.remove("mapboxgl-attrib-empty")):this._container.classList.add("mapboxgl-attrib-empty"),this._editLink=null)}},Ia.prototype._updateCompact=function(){this._map.getCanvasContainer().offsetWidth<=640?this._container.classList.add("mapboxgl-compact"):this._container.classList.remove("mapboxgl-compact","mapboxgl-compact-show")};var Pa=function(){e.bindAll(["_updateLogo"],this),e.bindAll(["_updateCompact"],this)};Pa.prototype.onAdd=function(e){this._map=e,this._container=r.create("div","mapboxgl-ctrl");var t=r.create("a","mapboxgl-ctrl-logo");return t.target="_blank",t.rel="noopener nofollow",t.href="https://www.mapbox.com/",t.setAttribute("aria-label",this._map._getUIString("LogoControl.Title")),t.setAttribute("rel","noopener nofollow"),this._container.appendChild(t),this._container.style.display="none",this._map.on("sourcedata",this._updateLogo),this._updateLogo(),this._map.on("resize",this._updateCompact),this._updateCompact(),this._container},Pa.prototype.onRemove=function(){r.remove(this._container),this._map.off("sourcedata",this._updateLogo),this._map.off("resize",this._updateCompact)},Pa.prototype.getDefaultPosition=function(){return"bottom-left"},Pa.prototype._updateLogo=function(e){e&&"metadata"!==e.sourceDataType||(this._container.style.display=this._logoRequired()?"block":"none")},Pa.prototype._logoRequired=function(){if(this._map.style){var e=this._map.style.sourceCaches;for(var t in e)if(e[t].getSource().mapbox_logo)return!0;return!1}},Pa.prototype._updateCompact=function(){var e=this._container.children;if(e.length){var t=e[0];this._map.getCanvasContainer().offsetWidth<250?t.classList.add("mapboxgl-compact"):t.classList.remove("mapboxgl-compact")}};var Oa=function(){this._queue=[],this._id=0,this._cleared=!1,this._currentlyRunning=!1};Oa.prototype.add=function(e){var t=++this._id;return this._queue.push({callback:e,id:t,cancelled:!1}),t},Oa.prototype.remove=function(e){for(var t=this._currentlyRunning,r=0,n=t?this._queue.concat(t):this._queue;rt.maxZoom)throw new Error("maxZoom must be greater than or equal to minZoom");if(null!=t.minPitch&&null!=t.maxPitch&&t.minPitch>t.maxPitch)throw new Error("maxPitch must be greater than or equal to minPitch");if(null!=t.minPitch&&t.minPitchBa)throw new Error("maxPitch must be less than or equal to "+Ba);var i=new xo(t.minZoom,t.maxZoom,t.minPitch,t.maxPitch,t.renderWorldCopies);if(n.call(this,i,t),this._interactive=t.interactive,this._maxTileCacheSize=t.maxTileCacheSize,this._failIfMajorPerformanceCaveat=t.failIfMajorPerformanceCaveat,this._preserveDrawingBuffer=t.preserveDrawingBuffer,this._antialias=t.antialias,this._trackResize=t.trackResize,this._bearingSnap=t.bearingSnap,this._refreshExpiredTiles=t.refreshExpiredTiles,this._fadeDuration=t.fadeDuration,this._crossSourceCollisions=t.crossSourceCollisions,this._crossFadingFactor=1,this._collectResourceTiming=t.collectResourceTiming,this._renderTaskQueue=new Oa,this._controls=[],this._mapId=e.uniqueId(),this._locale=e.extend({},Ra,t.locale),this._clickTolerance=t.clickTolerance,this._requestManager=new e.RequestManager(t.transformRequest,t.accessToken),"string"===typeof t.container){if(this._container=e.window.document.getElementById(t.container),!this._container)throw new Error("Container '"+t.container+"' not found.")}else{if(!(t.container instanceof Da))throw new Error("Invalid type: 'container' must be a String or HTMLElement.");this._container=t.container}if(t.maxBounds&&this.setMaxBounds(t.maxBounds),e.bindAll(["_onWindowOnline","_onWindowResize","_onMapScroll","_contextLost","_contextRestored"],this),this._setupContainer(),this._setupPainter(),void 0===this.painter)throw new Error("Failed to initialize WebGL.");this.on("move",(function(){return r._update(!1)})),this.on("moveend",(function(){return r._update(!1)})),this.on("zoom",(function(){return r._update(!0)})),"undefined"!==typeof e.window&&(e.window.addEventListener("online",this._onWindowOnline,!1),e.window.addEventListener("resize",this._onWindowResize,!1),e.window.addEventListener("orientationchange",this._onWindowResize,!1)),this.handlers=new Ca(this,t);var o="string"===typeof t.hash&&t.hash||void 0;this._hash=t.hash&&new wo(o).addTo(this),this._hash&&this._hash._onHashChange()||(this.jumpTo({center:t.center,zoom:t.zoom,bearing:t.bearing,pitch:t.pitch}),t.bounds&&(this.resize(),this.fitBounds(t.bounds,e.extend({},t.fitBoundsOptions,{duration:0})))),this.resize(),this._localIdeographFontFamily=t.localIdeographFontFamily,t.style&&this.setStyle(t.style,{localIdeographFontFamily:t.localIdeographFontFamily}),t.attributionControl&&this.addControl(new Ia({customAttribution:t.customAttribution})),this.addControl(new Pa,t.logoPosition),this.on("style.load",(function(){r.transform.unmodified&&r.jumpTo(r.style.stylesheet)})),this.on("data",(function(t){r._update("style"===t.dataType),r.fire(new e.Event(t.dataType+"data",t))})),this.on("dataloading",(function(t){r.fire(new e.Event(t.dataType+"dataloading",t))}))}n&&(i.__proto__=n),i.prototype=Object.create(n&&n.prototype),i.prototype.constructor=i;var o={showTileBoundaries:{configurable:!0},showPadding:{configurable:!0},showCollisionBoxes:{configurable:!0},showOverdrawInspector:{configurable:!0},repaint:{configurable:!0},vertices:{configurable:!0},version:{configurable:!0}};return i.prototype._getMapId=function(){return this._mapId},i.prototype.addControl=function(t,r){if(void 0===r&&(r=t.getDefaultPosition?t.getDefaultPosition():"top-right"),!t||!t.onAdd)return this.fire(new e.ErrorEvent(new Error("Invalid argument to map.addControl(). Argument must be a control with onAdd and onRemove methods.")));var n=t.onAdd(this);this._controls.push(t);var i=this._controlPositions[r];return-1!==r.indexOf("bottom")?i.insertBefore(n,i.firstChild):i.appendChild(n),this},i.prototype.removeControl=function(t){if(!t||!t.onRemove)return this.fire(new e.ErrorEvent(new Error("Invalid argument to map.removeControl(). Argument must be a control with onAdd and onRemove methods.")));var r=this._controls.indexOf(t);return r>-1&&this._controls.splice(r,1),t.onRemove(this),this},i.prototype.hasControl=function(e){return this._controls.indexOf(e)>-1},i.prototype.resize=function(t){var r=this._containerDimensions(),n=r[0],i=r[1];this._resizeCanvas(n,i),this.transform.resize(n,i),this.painter.resize(n,i);var o=!this._moving;return o&&(this.stop(),this.fire(new e.Event("movestart",t)).fire(new e.Event("move",t))),this.fire(new e.Event("resize",t)),o&&this.fire(new e.Event("moveend",t)),this},i.prototype.getBounds=function(){return this.transform.getBounds()},i.prototype.getMaxBounds=function(){return this.transform.getMaxBounds()},i.prototype.setMaxBounds=function(t){return this.transform.setMaxBounds(e.LngLatBounds.convert(t)),this._update()},i.prototype.setMinZoom=function(e){if((e=null===e||void 0===e?ja:e)>=ja&&e<=this.transform.maxZoom)return this.transform.minZoom=e,this._update(),this.getZoom()=this.transform.minZoom)return this.transform.maxZoom=e,this._update(),this.getZoom()>e&&this.setZoom(e),this;throw new Error("maxZoom must be greater than the current minZoom")},i.prototype.getMaxZoom=function(){return this.transform.maxZoom},i.prototype.setMinPitch=function(e){if((e=null===e||void 0===e?Na:e)=Na&&e<=this.transform.maxPitch)return this.transform.minPitch=e,this._update(),this.getPitch()Ba)throw new Error("maxPitch must be less than or equal to "+Ba);if(e>=this.transform.minPitch)return this.transform.maxPitch=e,this._update(),this.getPitch()>e&&this.setPitch(e),this;throw new Error("maxPitch must be greater than the current minPitch")},i.prototype.getMaxPitch=function(){return this.transform.maxPitch},i.prototype.getRenderWorldCopies=function(){return this.transform.renderWorldCopies},i.prototype.setRenderWorldCopies=function(e){return this.transform.renderWorldCopies=e,this._update()},i.prototype.project=function(t){return this.transform.locationPoint(e.LngLat.convert(t))},i.prototype.unproject=function(t){return this.transform.pointLocation(e.Point.convert(t))},i.prototype.isMoving=function(){return this._moving||this.handlers.isMoving()},i.prototype.isZooming=function(){return this._zooming||this.handlers.isZooming()},i.prototype.isRotating=function(){return this._rotating||this.handlers.isRotating()},i.prototype._createDelegatedListener=function(e,t,r){var n,i=this;if("mouseenter"===e||"mouseover"===e){var o=!1,a=function(n){var a=i.getLayer(t)?i.queryRenderedFeatures(n.point,{layers:[t]}):[];a.length?o||(o=!0,r.call(i,new Po(e,i,n.originalEvent,{features:a}))):o=!1};return{layer:t,listener:r,delegates:{mousemove:a,mouseout:function(){o=!1}}}}if("mouseleave"===e||"mouseout"===e){var s=!1,l=function(n){(i.getLayer(t)?i.queryRenderedFeatures(n.point,{layers:[t]}):[]).length?s=!0:s&&(s=!1,r.call(i,new Po(e,i,n.originalEvent)))},c=function(t){s&&(s=!1,r.call(i,new Po(e,i,t.originalEvent)))};return{layer:t,listener:r,delegates:{mousemove:l,mouseout:c}}}var u=function(e){var n=i.getLayer(t)?i.queryRenderedFeatures(e.point,{layers:[t]}):[];n.length&&(e.features=n,r.call(i,e),delete e.features)};return{layer:t,listener:r,delegates:(n={},n[e]=u,n)}},i.prototype.on=function(e,t,r){if(void 0===r)return n.prototype.on.call(this,e,t);var i=this._createDelegatedListener(e,t,r);for(var o in this._delegatedListeners=this._delegatedListeners||{},this._delegatedListeners[e]=this._delegatedListeners[e]||[],this._delegatedListeners[e].push(i),i.delegates)this.on(o,i.delegates[o]);return this},i.prototype.once=function(e,t,r){if(void 0===r)return n.prototype.once.call(this,e,t);var i=this._createDelegatedListener(e,t,r);for(var o in i.delegates)this.once(o,i.delegates[o]);return this},i.prototype.off=function(e,t,r){var i=this;if(void 0===r)return n.prototype.off.call(this,e,t);var o=function(n){for(var o=n[e],a=0;a180;){var s=n.locationPoint(t);if(s.x>=0&&s.y>=0&&s.x<=n.width&&s.y<=n.height)break;t.lng>n.center.lng?t.lng-=360:t.lng+=360}return t}qa.prototype.down=function(e,t){this.mouseRotate.mousedown(e,t),this.mousePitch&&this.mousePitch.mousedown(e,t),r.disableDrag()},qa.prototype.move=function(e,t){var r=this.map,n=this.mouseRotate.mousemoveWindow(e,t);if(n&&n.bearingDelta&&r.setBearing(r.getBearing()+n.bearingDelta),this.mousePitch){var i=this.mousePitch.mousemoveWindow(e,t);i&&i.pitchDelta&&r.setPitch(r.getPitch()+i.pitchDelta)}},qa.prototype.off=function(){var e=this.element;r.removeEventListener(e,"mousedown",this.mousedown),r.removeEventListener(e,"touchstart",this.touchstart,{passive:!1}),r.removeEventListener(e,"touchmove",this.touchmove),r.removeEventListener(e,"touchend",this.touchend),r.removeEventListener(e,"touchcancel",this.reset),this.offTemp()},qa.prototype.offTemp=function(){r.enableDrag(),r.removeEventListener(e.window,"mousemove",this.mousemove),r.removeEventListener(e.window,"mouseup",this.mouseup)},qa.prototype.mousedown=function(t){this.down(e.extend({},t,{ctrlKey:!0,preventDefault:function(){return t.preventDefault()}}),r.mousePos(this.element,t)),r.addEventListener(e.window,"mousemove",this.mousemove),r.addEventListener(e.window,"mouseup",this.mouseup)},qa.prototype.mousemove=function(e){this.move(e,r.mousePos(this.element,e))},qa.prototype.mouseup=function(e){this.mouseRotate.mouseupWindow(e),this.mousePitch&&this.mousePitch.mouseupWindow(e),this.offTemp()},qa.prototype.touchstart=function(e){1!==e.targetTouches.length?this.reset():(this._startPos=this._lastPos=r.touchPos(this.element,e.targetTouches)[0],this.down({type:"mousedown",button:0,ctrlKey:!0,preventDefault:function(){return e.preventDefault()}},this._startPos))},qa.prototype.touchmove=function(e){1!==e.targetTouches.length?this.reset():(this._lastPos=r.touchPos(this.element,e.targetTouches)[0],this.move({preventDefault:function(){return e.preventDefault()}},this._lastPos))},qa.prototype.touchend=function(e){0===e.targetTouches.length&&this._startPos&&this._lastPos&&this._startPos.dist(this._lastPos)=r}this._isDragging&&(this._pos=t.point.sub(this._positionDelta),this._lngLat=this._map.unproject(this._pos),this.setLngLat(this._lngLat),this._element.style.pointerEvents="none","pending"===this._state&&(this._state="active",this.fire(new e.Event("dragstart"))),this.fire(new e.Event("drag")))},n.prototype._onUp=function(){this._element.style.pointerEvents="auto",this._positionDelta=null,this._pointerdownPos=null,this._isDragging=!1,this._map.off("mousemove",this._onMove),this._map.off("touchmove",this._onMove),"active"===this._state&&this.fire(new e.Event("dragend")),this._state="inactive"},n.prototype._addDragHandler=function(e){this._element.contains(e.originalEvent.target)&&(e.preventDefault(),this._positionDelta=e.point.sub(this._pos).add(this._offset),this._pointerdownPos=e.point,this._state="pending",this._map.on("mousemove",this._onMove),this._map.on("touchmove",this._onMove),this._map.once("mouseup",this._onUp),this._map.once("touchend",this._onUp))},n.prototype.setDraggable=function(e){return this._draggable=!!e,this._map&&(e?(this._map.on("mousedown",this._addDragHandler),this._map.on("touchstart",this._addDragHandler)):(this._map.off("mousedown",this._addDragHandler),this._map.off("touchstart",this._addDragHandler))),this},n.prototype.isDraggable=function(){return this._draggable},n.prototype.setRotation=function(e){return this._rotation=e||0,this._update(),this},n.prototype.getRotation=function(){return this._rotation},n.prototype.setRotationAlignment=function(e){return this._rotationAlignment=e||"auto",this._update(),this},n.prototype.getRotationAlignment=function(){return this._rotationAlignment},n.prototype.setPitchAlignment=function(e){return this._pitchAlignment=e&&"auto"!==e?e:this._rotationAlignment,this._update(),this},n.prototype.getPitchAlignment=function(){return this._pitchAlignment},n}(e.Evented),Ja={positionOptions:{enableHighAccuracy:!1,maximumAge:0,timeout:6e3},fitBoundsOptions:{maxZoom:15},trackUserLocation:!1,showAccuracyCircle:!0,showUserLocation:!0};function Qa(t){void 0!==Za?t(Za):void 0!==e.window.navigator.permissions?e.window.navigator.permissions.query({name:"geolocation"}).then((function(e){Za="denied"!==e.state,t(Za)})):(Za=!!e.window.navigator.geolocation,t(Za))}var es=0,ts=!1,rs=function(t){function n(r){t.call(this),this.options=e.extend({},Ja,r),e.bindAll(["_onSuccess","_onError","_onZoom","_finish","_setupUI","_updateCamera","_updateMarker"],this)}return t&&(n.__proto__=t),n.prototype=Object.create(t&&t.prototype),n.prototype.constructor=n,n.prototype.onAdd=function(e){return this._map=e,this._container=r.create("div","mapboxgl-ctrl mapboxgl-ctrl-group"),Qa(this._setupUI),this._container},n.prototype.onRemove=function(){void 0!==this._geolocationWatchID&&(e.window.navigator.geolocation.clearWatch(this._geolocationWatchID),this._geolocationWatchID=void 0),this.options.showUserLocation&&this._userLocationDotMarker&&this._userLocationDotMarker.remove(),this.options.showAccuracyCircle&&this._accuracyCircleMarker&&this._accuracyCircleMarker.remove(),r.remove(this._container),this._map.off("zoom",this._onZoom),this._map=void 0,es=0,ts=!1},n.prototype._isOutOfMapMaxBounds=function(e){var t=this._map.getMaxBounds(),r=e.coords;return t&&(r.longitudet.getEast()||r.latitudet.getNorth())},n.prototype._setErrorState=function(){switch(this._watchState){case"WAITING_ACTIVE":this._watchState="ACTIVE_ERROR",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active-error");break;case"ACTIVE_LOCK":this._watchState="ACTIVE_ERROR",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active-error"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting");break;case"BACKGROUND":this._watchState="BACKGROUND_ERROR",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background-error"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting")}},n.prototype._onSuccess=function(t){if(this._map){if(this._isOutOfMapMaxBounds(t))return this._setErrorState(),this.fire(new e.Event("outofmaxbounds",t)),this._updateMarker(),void this._finish();if(this.options.trackUserLocation)switch(this._lastKnownPosition=t,this._watchState){case"WAITING_ACTIVE":case"ACTIVE_LOCK":case"ACTIVE_ERROR":this._watchState="ACTIVE_LOCK",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active-error"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active");break;case"BACKGROUND":case"BACKGROUND_ERROR":this._watchState="BACKGROUND",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background-error"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background")}this.options.showUserLocation&&"OFF"!==this._watchState&&this._updateMarker(t),this.options.trackUserLocation&&"ACTIVE_LOCK"!==this._watchState||this._updateCamera(t),this.options.showUserLocation&&this._dotElement.classList.remove("mapboxgl-user-location-dot-stale"),this.fire(new e.Event("geolocate",t)),this._finish()}},n.prototype._updateCamera=function(t){var r=new e.LngLat(t.coords.longitude,t.coords.latitude),n=t.coords.accuracy,i=this._map.getBearing(),o=e.extend({bearing:i},this.options.fitBoundsOptions);this._map.fitBounds(r.toBounds(n),o,{geolocateSource:!0})},n.prototype._updateMarker=function(t){if(t){var r=new e.LngLat(t.coords.longitude,t.coords.latitude);this._accuracyCircleMarker.setLngLat(r).addTo(this._map),this._userLocationDotMarker.setLngLat(r).addTo(this._map),this._accuracy=t.coords.accuracy,this.options.showUserLocation&&this.options.showAccuracyCircle&&this._updateCircleRadius()}else this._userLocationDotMarker.remove(),this._accuracyCircleMarker.remove()},n.prototype._updateCircleRadius=function(){var e=this._map._container.clientHeight/2,t=this._map.unproject([0,e]),r=this._map.unproject([1,e]),n=t.distanceTo(r),i=Math.ceil(2*this._accuracy/n);this._circleElement.style.width=i+"px",this._circleElement.style.height=i+"px"},n.prototype._onZoom=function(){this.options.showUserLocation&&this.options.showAccuracyCircle&&this._updateCircleRadius()},n.prototype._onError=function(t){if(this._map){if(this.options.trackUserLocation)if(1===t.code){this._watchState="OFF",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active-error"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background-error"),this._geolocateButton.disabled=!0;var r=this._map._getUIString("GeolocateControl.LocationNotAvailable");this._geolocateButton.title=r,this._geolocateButton.setAttribute("aria-label",r),void 0!==this._geolocationWatchID&&this._clearWatch()}else{if(3===t.code&&ts)return;this._setErrorState()}"OFF"!==this._watchState&&this.options.showUserLocation&&this._dotElement.classList.add("mapboxgl-user-location-dot-stale"),this.fire(new e.Event("error",t)),this._finish()}},n.prototype._finish=function(){this._timeoutId&&clearTimeout(this._timeoutId),this._timeoutId=void 0},n.prototype._setupUI=function(t){var n=this;if(this._container.addEventListener("contextmenu",(function(e){return e.preventDefault()})),this._geolocateButton=r.create("button","mapboxgl-ctrl-geolocate",this._container),r.create("span","mapboxgl-ctrl-icon",this._geolocateButton).setAttribute("aria-hidden",!0),this._geolocateButton.type="button",!1===t){e.warnOnce("Geolocation support is not available so the GeolocateControl will be disabled.");var i=this._map._getUIString("GeolocateControl.LocationNotAvailable");this._geolocateButton.disabled=!0,this._geolocateButton.title=i,this._geolocateButton.setAttribute("aria-label",i)}else{var o=this._map._getUIString("GeolocateControl.FindMyLocation");this._geolocateButton.title=o,this._geolocateButton.setAttribute("aria-label",o)}this.options.trackUserLocation&&(this._geolocateButton.setAttribute("aria-pressed","false"),this._watchState="OFF"),this.options.showUserLocation&&(this._dotElement=r.create("div","mapboxgl-user-location-dot"),this._userLocationDotMarker=new Ka(this._dotElement),this._circleElement=r.create("div","mapboxgl-user-location-accuracy-circle"),this._accuracyCircleMarker=new Ka({element:this._circleElement,pitchAlignment:"map"}),this.options.trackUserLocation&&(this._watchState="OFF"),this._map.on("zoom",this._onZoom)),this._geolocateButton.addEventListener("click",this.trigger.bind(this)),this._setup=!0,this.options.trackUserLocation&&this._map.on("movestart",(function(t){var r=t.originalEvent&&"resize"===t.originalEvent.type;t.geolocateSource||"ACTIVE_LOCK"!==n._watchState||r||(n._watchState="BACKGROUND",n._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background"),n._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"),n.fire(new e.Event("trackuserlocationend")))}))},n.prototype.trigger=function(){if(!this._setup)return e.warnOnce("Geolocate control triggered before added to a map"),!1;if(this.options.trackUserLocation){switch(this._watchState){case"OFF":this._watchState="WAITING_ACTIVE",this.fire(new e.Event("trackuserlocationstart"));break;case"WAITING_ACTIVE":case"ACTIVE_LOCK":case"ACTIVE_ERROR":case"BACKGROUND_ERROR":es--,ts=!1,this._watchState="OFF",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active-error"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background-error"),this.fire(new e.Event("trackuserlocationend"));break;case"BACKGROUND":this._watchState="ACTIVE_LOCK",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background"),this._lastKnownPosition&&this._updateCamera(this._lastKnownPosition),this.fire(new e.Event("trackuserlocationstart"))}switch(this._watchState){case"WAITING_ACTIVE":this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active");break;case"ACTIVE_LOCK":this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active");break;case"ACTIVE_ERROR":this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active-error");break;case"BACKGROUND":this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background");break;case"BACKGROUND_ERROR":this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background-error")}if("OFF"===this._watchState&&void 0!==this._geolocationWatchID)this._clearWatch();else if(void 0===this._geolocationWatchID){var t;this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.setAttribute("aria-pressed","true"),++es>1?(t={maximumAge:6e5,timeout:0},ts=!0):(t=this.options.positionOptions,ts=!1),this._geolocationWatchID=e.window.navigator.geolocation.watchPosition(this._onSuccess,this._onError,t)}}else e.window.navigator.geolocation.getCurrentPosition(this._onSuccess,this._onError,this.options.positionOptions),this._timeoutId=setTimeout(this._finish,1e4);return!0},n.prototype._clearWatch=function(){e.window.navigator.geolocation.clearWatch(this._geolocationWatchID),this._geolocationWatchID=void 0,this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.setAttribute("aria-pressed","false"),this.options.showUserLocation&&this._updateMarker(null)},n}(e.Evented),ns={maxWidth:100,unit:"metric"},is=function(t){this.options=e.extend({},ns,t),e.bindAll(["_onMove","setUnit"],this)};function os(e,t,r){var n=r&&r.maxWidth||100,i=e._container.clientHeight/2,o=e.unproject([0,i]),a=e.unproject([n,i]),s=o.distanceTo(a);if(r&&"imperial"===r.unit){var l=3.2808*s;l>5280?as(t,n,l/5280,e._getUIString("ScaleControl.Miles")):as(t,n,l,e._getUIString("ScaleControl.Feet"))}else r&&"nautical"===r.unit?as(t,n,s/1852,e._getUIString("ScaleControl.NauticalMiles")):s>=1e3?as(t,n,s/1e3,e._getUIString("ScaleControl.Kilometers")):as(t,n,s,e._getUIString("ScaleControl.Meters"))}function as(e,t,r,n){var i=ls(r),o=i/r;e.style.width=t*o+"px",e.innerHTML=i+" "+n}function ss(e){var t=Math.pow(10,Math.ceil(-Math.log(e)/Math.LN10));return Math.round(e*t)/t}function ls(e){var t=Math.pow(10,(""+Math.floor(e)).length-1),r=e/t;return t*(r=r>=10?10:r>=5?5:r>=3?3:r>=2?2:r>=1?1:ss(r))}is.prototype.getDefaultPosition=function(){return"bottom-left"},is.prototype._onMove=function(){os(this._map,this._container,this.options)},is.prototype.onAdd=function(e){return this._map=e,this._container=r.create("div","mapboxgl-ctrl mapboxgl-ctrl-scale",e.getContainer()),this._map.on("move",this._onMove),this._onMove(),this._container},is.prototype.onRemove=function(){r.remove(this._container),this._map.off("move",this._onMove),this._map=void 0},is.prototype.setUnit=function(e){this.options.unit=e,os(this._map,this._container,this.options)};var cs=function(t){this._fullscreen=!1,t&&t.container&&(t.container instanceof e.window.HTMLElement?this._container=t.container:e.warnOnce("Full screen control 'container' must be a DOM element.")),e.bindAll(["_onClickFullscreen","_changeIcon"],this),"onfullscreenchange"in e.window.document?this._fullscreenchange="fullscreenchange":"onmozfullscreenchange"in e.window.document?this._fullscreenchange="mozfullscreenchange":"onwebkitfullscreenchange"in e.window.document?this._fullscreenchange="webkitfullscreenchange":"onmsfullscreenchange"in e.window.document&&(this._fullscreenchange="MSFullscreenChange")};cs.prototype.onAdd=function(t){return this._map=t,this._container||(this._container=this._map.getContainer()),this._controlContainer=r.create("div","mapboxgl-ctrl mapboxgl-ctrl-group"),this._checkFullscreenSupport()?this._setupUI():(this._controlContainer.style.display="none",e.warnOnce("This device does not support fullscreen mode.")),this._controlContainer},cs.prototype.onRemove=function(){r.remove(this._controlContainer),this._map=null,e.window.document.removeEventListener(this._fullscreenchange,this._changeIcon)},cs.prototype._checkFullscreenSupport=function(){return!!(e.window.document.fullscreenEnabled||e.window.document.mozFullScreenEnabled||e.window.document.msFullscreenEnabled||e.window.document.webkitFullscreenEnabled)},cs.prototype._setupUI=function(){var t=this._fullscreenButton=r.create("button","mapboxgl-ctrl-fullscreen",this._controlContainer);r.create("span","mapboxgl-ctrl-icon",t).setAttribute("aria-hidden",!0),t.type="button",this._updateTitle(),this._fullscreenButton.addEventListener("click",this._onClickFullscreen),e.window.document.addEventListener(this._fullscreenchange,this._changeIcon)},cs.prototype._updateTitle=function(){var e=this._getTitle();this._fullscreenButton.setAttribute("aria-label",e),this._fullscreenButton.title=e},cs.prototype._getTitle=function(){return this._map._getUIString(this._isFullscreen()?"FullscreenControl.Exit":"FullscreenControl.Enter")},cs.prototype._isFullscreen=function(){return this._fullscreen},cs.prototype._changeIcon=function(){(e.window.document.fullscreenElement||e.window.document.mozFullScreenElement||e.window.document.webkitFullscreenElement||e.window.document.msFullscreenElement)===this._container!==this._fullscreen&&(this._fullscreen=!this._fullscreen,this._fullscreenButton.classList.toggle("mapboxgl-ctrl-shrink"),this._fullscreenButton.classList.toggle("mapboxgl-ctrl-fullscreen"),this._updateTitle())},cs.prototype._onClickFullscreen=function(){this._isFullscreen()?e.window.document.exitFullscreen?e.window.document.exitFullscreen():e.window.document.mozCancelFullScreen?e.window.document.mozCancelFullScreen():e.window.document.msExitFullscreen?e.window.document.msExitFullscreen():e.window.document.webkitCancelFullScreen&&e.window.document.webkitCancelFullScreen():this._container.requestFullscreen?this._container.requestFullscreen():this._container.mozRequestFullScreen?this._container.mozRequestFullScreen():this._container.msRequestFullscreen?this._container.msRequestFullscreen():this._container.webkitRequestFullscreen&&this._container.webkitRequestFullscreen()};var us={closeButton:!0,closeOnClick:!0,focusAfterOpen:!0,className:"",maxWidth:"240px"},ds=["a[href]","[tabindex]:not([tabindex='-1'])","[contenteditable]:not([contenteditable='false'])","button:not([disabled])","input:not([disabled])","select:not([disabled])","textarea:not([disabled])"].join(", "),hs=function(t){function n(r){t.call(this),this.options=e.extend(Object.create(us),r),e.bindAll(["_update","_onClose","remove","_onMouseMove","_onMouseUp","_onDrag"],this)}return t&&(n.__proto__=t),n.prototype=Object.create(t&&t.prototype),n.prototype.constructor=n,n.prototype.addTo=function(t){return this._map&&this.remove(),this._map=t,this.options.closeOnClick&&this._map.on("click",this._onClose),this.options.closeOnMove&&this._map.on("move",this._onClose),this._map.on("remove",this.remove),this._update(),this._focusFirstElement(),this._trackPointer?(this._map.on("mousemove",this._onMouseMove),this._map.on("mouseup",this._onMouseUp),this._container&&this._container.classList.add("mapboxgl-popup-track-pointer"),this._map._canvasContainer.classList.add("mapboxgl-track-pointer")):this._map.on("move",this._update),this.fire(new e.Event("open")),this},n.prototype.isOpen=function(){return!!this._map},n.prototype.remove=function(){return this._content&&r.remove(this._content),this._container&&(r.remove(this._container),delete this._container),this._map&&(this._map.off("move",this._update),this._map.off("move",this._onClose),this._map.off("click",this._onClose),this._map.off("remove",this.remove),this._map.off("mousemove",this._onMouseMove),this._map.off("mouseup",this._onMouseUp),this._map.off("drag",this._onDrag),delete this._map),this.fire(new e.Event("close")),this},n.prototype.getLngLat=function(){return this._lngLat},n.prototype.setLngLat=function(t){return this._lngLat=e.LngLat.convert(t),this._pos=null,this._trackPointer=!1,this._update(),this._map&&(this._map.on("move",this._update),this._map.off("mousemove",this._onMouseMove),this._container&&this._container.classList.remove("mapboxgl-popup-track-pointer"),this._map._canvasContainer.classList.remove("mapboxgl-track-pointer")),this},n.prototype.trackPointer=function(){return this._trackPointer=!0,this._pos=null,this._update(),this._map&&(this._map.off("move",this._update),this._map.on("mousemove",this._onMouseMove),this._map.on("drag",this._onDrag),this._container&&this._container.classList.add("mapboxgl-popup-track-pointer"),this._map._canvasContainer.classList.add("mapboxgl-track-pointer")),this},n.prototype.getElement=function(){return this._container},n.prototype.setText=function(t){return this.setDOMContent(e.window.document.createTextNode(t))},n.prototype.setHTML=function(t){var r,n=e.window.document.createDocumentFragment(),i=e.window.document.createElement("body");for(i.innerHTML=t;r=i.firstChild;)n.appendChild(r);return this.setDOMContent(n)},n.prototype.getMaxWidth=function(){return this._container&&this._container.style.maxWidth},n.prototype.setMaxWidth=function(e){return this.options.maxWidth=e,this._update(),this},n.prototype.setDOMContent=function(e){if(this._content)for(;this._content.hasChildNodes();)this._content.firstChild&&this._content.removeChild(this._content.firstChild);else this._content=r.create("div","mapboxgl-popup-content",this._container);return this._content.appendChild(e),this._createCloseButton(),this._update(),this._focusFirstElement(),this},n.prototype.addClassName=function(e){this._container&&this._container.classList.add(e)},n.prototype.removeClassName=function(e){this._container&&this._container.classList.remove(e)},n.prototype.setOffset=function(e){return this.options.offset=e,this._update(),this},n.prototype.toggleClassName=function(e){if(this._container)return this._container.classList.toggle(e)},n.prototype._createCloseButton=function(){this.options.closeButton&&(this._closeButton=r.create("button","mapboxgl-popup-close-button",this._content),this._closeButton.type="button",this._closeButton.setAttribute("aria-label","Close popup"),this._closeButton.innerHTML="×",this._closeButton.addEventListener("click",this._onClose))},n.prototype._onMouseUp=function(e){this._update(e.point)},n.prototype._onMouseMove=function(e){this._update(e.point)},n.prototype._onDrag=function(e){this._update(e.point)},n.prototype._update=function(e){var t=this,n=this._lngLat||this._trackPointer;if(this._map&&n&&this._content&&(this._container||(this._container=r.create("div","mapboxgl-popup",this._map.getContainer()),this._tip=r.create("div","mapboxgl-popup-tip",this._container),this._container.appendChild(this._content),this.options.className&&this.options.className.split(" ").forEach((function(e){return t._container.classList.add(e)})),this._trackPointer&&this._container.classList.add("mapboxgl-popup-track-pointer")),this.options.maxWidth&&this._container.style.maxWidth!==this.options.maxWidth&&(this._container.style.maxWidth=this.options.maxWidth),this._map.transform.renderWorldCopies&&!this._trackPointer&&(this._lngLat=Ga(this._lngLat,this._pos,this._map.transform)),!this._trackPointer||e)){var i=this._pos=this._trackPointer&&e?e:this._map.project(this._lngLat),o=this.options.anchor,a=ps(this.options.offset);if(!o){var s,l=this._container.offsetWidth,c=this._container.offsetHeight;s=i.y+a.bottom.ythis._map.transform.height-c?["bottom"]:[],i.xthis._map.transform.width-l/2&&s.push("right"),o=0===s.length?"bottom":s.join("-")}var u=i.add(a[o]).round();r.setTransform(this._container,Ya[o]+" translate("+u.x+"px,"+u.y+"px)"),Xa(this._container,o,"popup")}},n.prototype._focusFirstElement=function(){if(this.options.focusAfterOpen&&this._container){var e=this._container.querySelector(ds);e&&e.focus()}},n.prototype._onClose=function(){this.remove()},n}(e.Evented);function ps(t){if(t){if("number"===typeof t){var r=Math.round(Math.sqrt(.5*Math.pow(t,2)));return{center:new e.Point(0,0),top:new e.Point(0,t),"top-left":new e.Point(r,r),"top-right":new e.Point(-r,r),bottom:new e.Point(0,-t),"bottom-left":new e.Point(r,-r),"bottom-right":new e.Point(-r,-r),left:new e.Point(t,0),right:new e.Point(-t,0)}}if(t instanceof e.Point||Array.isArray(t)){var n=e.Point.convert(t);return{center:n,top:n,"top-left":n,"top-right":n,bottom:n,"bottom-left":n,"bottom-right":n,left:n,right:n}}return{center:e.Point.convert(t.center||[0,0]),top:e.Point.convert(t.top||[0,0]),"top-left":e.Point.convert(t["top-left"]||[0,0]),"top-right":e.Point.convert(t["top-right"]||[0,0]),bottom:e.Point.convert(t.bottom||[0,0]),"bottom-left":e.Point.convert(t["bottom-left"]||[0,0]),"bottom-right":e.Point.convert(t["bottom-right"]||[0,0]),left:e.Point.convert(t.left||[0,0]),right:e.Point.convert(t.right||[0,0])}}return ps(new e.Point(0,0))}var fs={version:e.version,supported:t,setRTLTextPlugin:e.setRTLTextPlugin,getRTLTextPluginStatus:e.getRTLTextPluginStatus,Map:Ua,NavigationControl:Wa,GeolocateControl:rs,AttributionControl:Ia,ScaleControl:is,FullscreenControl:cs,Popup:hs,Marker:Ka,Style:gr,LngLat:e.LngLat,LngLatBounds:e.LngLatBounds,Point:e.Point,MercatorCoordinate:e.MercatorCoordinate,Evented:e.Evented,config:e.config,prewarm:ot,clearPrewarmedResources:at,get accessToken(){return e.config.ACCESS_TOKEN},set accessToken(t){e.config.ACCESS_TOKEN=t},get baseApiUrl(){return e.config.API_URL},set baseApiUrl(t){e.config.API_URL=t},get workerCount(){return tt.workerCount},set workerCount(e){tt.workerCount=e},get maxParallelImageRequests(){return e.config.MAX_PARALLEL_IMAGE_REQUESTS},set maxParallelImageRequests(t){e.config.MAX_PARALLEL_IMAGE_REQUESTS=t},clearStorage:function(t){e.clearTileCache(t)},workerUrl:""};return fs})),r}()},2210:(e,t,r)=>{"use strict";e.exports=r(18731)},18731:(e,t,r)=>{"use strict";const n=r(41264),i=r(9187),o=r(72972),a=r(57929),s=r(92472),l=r(63085),c=r(67014),u=r(16140),d=r(12156),h=r(62773);function p(e,t){let[r,n,o,a]=t,s=1/(o-r),l=1/(a-n),c=new Array(e.length);for(let u=0,d=e.length/2;u>>1;t.dtype||(t.dtype="array"),"string"===typeof t.dtype?f=new(d(t.dtype))(g):t.dtype&&(f=t.dtype,Array.isArray(f)&&(f.length=g));for(let n=0;nr||s>1073741824){for(let e=0;er+i||S>l||A=M)return;if(a===s)return;let c=y[o];void 0===s&&(s=c.length);for(let y=a;y=f&&r<=g&&n>=m&&n<=_&&C.push(t)}let u=v[o],d=u[4*a+0],h=u[4*a+1],p=u[4*a+2],x=u[4*a+3],b=function(e,t){let r=null,n=0;for(;null===r;)if(r=e[4*t+n],n++,n>e.length)return null;return r}(u,a+1),w=.5*i,E=o+1;t(r,n,w,E,d,h||p||x||b),t(r,n+w,w,E,h,p||x||b),t(r+w,n,w,E,p,x||b),t(r+w,n+w,w,E,x,b)}(0,0,1,0,0,1),C},f;function w(e,t,r){let n=1,i=.5,o=.5,a=.5;for(let s=0;s{e.exports=function(e){var t=0,r=0,n=0,i=0;return e.map((function(e){var o=(e=e.slice())[0],a=o.toUpperCase();if(o!=a)switch(e[0]=a,o){case"a":e[6]+=n,e[7]+=i;break;case"v":e[1]+=i;break;case"h":e[1]+=n;break;default:for(var s=1;s{"use strict";e.exports=function(e,t){if(!e||null==e.length)throw Error("Argument should be an array");t=null==t?1:Math.floor(t);for(var r=Array(2*t),n=0;ni&&(i=e[a]),e[a]{"use strict";e.exports=function(e,t,r){if("function"===typeof Array.prototype.findIndex)return e.findIndex(t,r);if("function"!==typeof t)throw new TypeError("predicate must be a function");var n=Object(e),i=n.length;if(0===i)return-1;for(var o=0;o{"use strict";var n=r(57929);e.exports=function(e,t,r){if(!e||null==e.length)throw Error("Argument should be an array");null==t&&(t=1);null==r&&(r=n(e,t));for(var i=0;i{e.exports=function(e,t){var r="number"===typeof e,n="number"===typeof t;r&&!n?(t=e,e=0):r||n||(e=0,t=0);var i=(t|=0)-(e|=0);if(i<0)throw new Error("array length must be positive");for(var o=new Array(i),a=0,s=e;a{"use strict";function n(e){return n="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},n(e)}function i(e,t){for(var r=0;r1?r-1:0),i=1;i1?r-1:0),i=1;i1?r-1:0),i=1;i1?r-1:0),i=1;i{"use strict";function n(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function i(e){for(var t=1;te.length)&&(r=e.length),e.substring(r-t.length,r)===t}var x="",b="",_="",w="",k={deepStrictEqual:"Expected values to be strictly deep-equal:",strictEqual:"Expected values to be strictly equal:",strictEqualObject:'Expected "actual" to be reference-equal to "expected":',deepEqual:"Expected values to be loosely deep-equal:",equal:"Expected values to be loosely equal:",notDeepStrictEqual:'Expected "actual" not to be strictly deep-equal to:',notStrictEqual:'Expected "actual" to be strictly unequal to:',notStrictEqualObject:'Expected "actual" not to be reference-equal to "expected":',notDeepEqual:'Expected "actual" not to be loosely deep-equal to:',notEqual:'Expected "actual" to be loosely unequal to:',notIdentical:"Values identical but not reference-equal:"};function S(e){var t=Object.keys(e),r=Object.create(Object.getPrototypeOf(e));return t.forEach((function(t){r[t]=e[t]})),Object.defineProperty(r,"message",{value:e.message}),r}function A(e){return g(e,{compact:!1,customInspect:!1,depth:1e3,maxArrayLength:1/0,showHidden:!1,breakLength:1/0,showProxy:!1,sorted:!0,getters:!0})}function T(e,t,r){var n="",i="",o=0,a="",s=!1,l=A(e),c=l.split("\n"),u=A(t).split("\n"),d=0,h="";if("strictEqual"===r&&"object"===m(e)&&"object"===m(t)&&null!==e&&null!==t&&(r="strictEqualObject"),1===c.length&&1===u.length&&c[0]!==u[0]){var p=c[0].length+u[0].length;if(p<=10){if(("object"!==m(e)||null===e)&&("object"!==m(t)||null===t)&&(0!==e||0!==t))return"".concat(k[r],"\n\n")+"".concat(c[0]," !== ").concat(u[0],"\n")}else if("strictEqualObject"!==r){if(p<(process.stderr&&process.stderr.isTTY?process.stderr.columns:80)){for(;c[0][d]===u[0][d];)d++;d>2&&(h="\n ".concat(function(e,t){if(t=Math.floor(t),0==e.length||0==t)return"";var r=e.length*t;for(t=Math.floor(Math.log(t)/Math.log(2));t;)e+=e,t--;return e+e.substring(0,r-e.length)}(" ",d),"^"),d=0)}}}for(var f=c[c.length-1],g=u[u.length-1];f===g&&(d++<2?a="\n ".concat(f).concat(a):n=f,c.pop(),u.pop(),0!==c.length&&0!==u.length);)f=c[c.length-1],g=u[u.length-1];var y=Math.max(c.length,u.length);if(0===y){var S=l.split("\n");if(S.length>30)for(S[26]="".concat(x,"...").concat(w);S.length>27;)S.pop();return"".concat(k.notIdentical,"\n\n").concat(S.join("\n"),"\n")}d>3&&(a="\n".concat(x,"...").concat(w).concat(a),s=!0),""!==n&&(a="\n ".concat(n).concat(a),n="");var T=0,M=k[r]+"\n".concat(b,"+ actual").concat(w," ").concat(_,"- expected").concat(w),C=" ".concat(x,"...").concat(w," Lines skipped");for(d=0;d1&&d>2&&(E>4?(i+="\n".concat(x,"...").concat(w),s=!0):E>3&&(i+="\n ".concat(u[d-2]),T++),i+="\n ".concat(u[d-1]),T++),o=d,n+="\n".concat(_,"-").concat(w," ").concat(u[d]),T++;else if(u.length1&&d>2&&(E>4?(i+="\n".concat(x,"...").concat(w),s=!0):E>3&&(i+="\n ".concat(c[d-2]),T++),i+="\n ".concat(c[d-1]),T++),o=d,i+="\n".concat(b,"+").concat(w," ").concat(c[d]),T++;else{var I=u[d],P=c[d],O=P!==I&&(!v(P,",")||P.slice(0,-1)!==I);O&&v(I,",")&&I.slice(0,-1)===P&&(O=!1,P+=","),O?(E>1&&d>2&&(E>4?(i+="\n".concat(x,"...").concat(w),s=!0):E>3&&(i+="\n ".concat(c[d-2]),T++),i+="\n ".concat(c[d-1]),T++),o=d,i+="\n".concat(b,"+").concat(w," ").concat(P),n+="\n".concat(_,"-").concat(w," ").concat(I),T+=2):(i+=n,n="",1!==E&&0!==d||(i+="\n ".concat(P),T++))}if(T>20&&d30)for(p[26]="".concat(x,"...").concat(w);p.length>27;)p.pop();t=1===p.length?s.call(this,"".concat(h," ").concat(p[0])):s.call(this,"".concat(h,"\n\n").concat(p.join("\n"),"\n"))}else{var f=A(o),g="",v=k[n];"notDeepEqual"===n||"notEqual"===n?(f="".concat(k[n],"\n\n").concat(f)).length>1024&&(f="".concat(f.slice(0,1021),"...")):(g="".concat(A(a)),f.length>512&&(f="".concat(f.slice(0,509),"...")),g.length>512&&(g="".concat(g.slice(0,509),"...")),"deepEqual"===n||"equal"===n?f="".concat(v,"\n\n").concat(f,"\n\nshould equal\n\n"):g=" ".concat(n," ").concat(g)),t=s.call(this,"".concat(f).concat(g))}return Error.stackTraceLimit=d,t.generatedMessage=!r,Object.defineProperty(c(t),"name",{value:"AssertionError [ERR_ASSERTION]",enumerable:!1,writable:!0,configurable:!0}),t.code="ERR_ASSERTION",t.actual=o,t.expected=a,t.operator=n,Error.captureStackTrace&&Error.captureStackTrace(c(t),i),t.stack,t.name="AssertionError",l(t)}return r=u,(n=[{key:"toString",value:function(){return"".concat(this.name," [").concat(this.code,"]: ").concat(this.message)}},{key:t,value:function(e,t){return g(this,i(i({},t),{},{customInspect:!1,depth:0}))}}])&&a(r.prototype,n),o&&a(r,o),Object.defineProperty(r,"prototype",{writable:!1}),u}(u(Error),g.custom);e.exports=M},66608:(e,t,r)=>{"use strict";function n(e){return n="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},n(e)}function i(e,t){for(var r=0;r2?"one of ".concat(t," ").concat(e.slice(0,r-1).join(", "),", or ")+e[r-1]:2===r?"one of ".concat(t," ").concat(e[0]," or ").concat(e[1]):"of ".concat(t," ").concat(e[0])}return"of ".concat(t," ").concat(String(e))}h("ERR_AMBIGUOUS_ARGUMENT",'The "%s" argument is ambiguous. %s',TypeError),h("ERR_INVALID_ARG_TYPE",(function(e,t,i){var o,a,s,l;if(void 0===c&&(c=r(2539)),c("string"===typeof e,"'name' must be a string"),"string"===typeof t&&(a="not ",t.substr(!s||s<0?0:+s,a.length)===a)?(o="must not be",t=t.replace(/^not /,"")):o="must be",function(e,t,r){return(void 0===r||r>e.length)&&(r=e.length),e.substring(r-t.length,r)===t}(e," argument"))l="The ".concat(e," ").concat(o," ").concat(p(t,"type"));else{var u=function(e,t,r){return"number"!==typeof r&&(r=0),!(r+t.length>e.length)&&-1!==e.indexOf(t,r)}(e,".")?"property":"argument";l='The "'.concat(e,'" ').concat(u," ").concat(o," ").concat(p(t,"type"))}return l+=". Received type ".concat(n(i))}),TypeError),h("ERR_INVALID_ARG_VALUE",(function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"is invalid";void 0===u&&(u=r(86494));var i=u.inspect(t);return i.length>128&&(i="".concat(i.slice(0,128),"...")),"The argument '".concat(e,"' ").concat(n,". Received ").concat(i)}),TypeError,RangeError),h("ERR_INVALID_RETURN_VALUE",(function(e,t,r){var i;return i=r&&r.constructor&&r.constructor.name?"instance of ".concat(r.constructor.name):"type ".concat(n(r)),"Expected ".concat(e,' to be returned from the "').concat(t,'"')+" function but got ".concat(i,".")}),TypeError),h("ERR_MISSING_ARGS",(function(){for(var e=arguments.length,t=new Array(e),n=0;n0,"At least one arg needs to be specified");var i="The ",o=t.length;switch(t=t.map((function(e){return'"'.concat(e,'"')})),o){case 1:i+="".concat(t[0]," argument");break;case 2:i+="".concat(t[0]," and ").concat(t[1]," arguments");break;default:i+=t.slice(0,o-1).join(", "),i+=", and ".concat(t[o-1]," arguments")}return"".concat(i," must be specified")}),TypeError),e.exports.codes=d},46062:(e,t,r)=>{"use strict";function n(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,i,o,a,s=[],l=!0,c=!1;try{if(o=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;l=!1}else for(;!(l=(n=o.call(r)).done)&&(s.push(n.value),s.length!==t);l=!0);}catch(e){c=!0,i=e}finally{try{if(!l&&null!=r.return&&(a=r.return(),Object(a)!==a))return}finally{if(c)throw i}}return s}}(e,t)||function(e,t){if(!e)return;if("string"===typeof e)return i(e,t);var r=Object.prototype.toString.call(e).slice(8,-1);"Object"===r&&e.constructor&&(r=e.constructor.name);if("Map"===r||"Set"===r)return Array.from(e);if("Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r))return i(e,t)}(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function i(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=new Array(t);r10)return!0;for(var t=0;t57)return!0}return 10===e.length&&e>=Math.pow(2,32)}function R(e){return Object.keys(e).filter(O).concat(u(e).filter(Object.prototype.propertyIsEnumerable.bind(e)))}function L(e,t){if(e===t)return 0;for(var r=e.length,n=t.length,i=0,o=Math.min(r,n);i{"use strict";r.r(t),r.d(t,{decode:()=>s,encode:()=>a});for(var n="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",i="undefined"===typeof Uint8Array?[]:new Uint8Array(256),o=0;o<64;o++)i[n.charCodeAt(o)]=o;var a=function(e){var t,r=new Uint8Array(e),i=r.length,o="";for(t=0;t>2],o+=n[(3&r[t])<<4|r[t+1]>>4],o+=n[(15&r[t+1])<<2|r[t+2]>>6],o+=n[63&r[t+2]];return i%3===2?o=o.substring(0,o.length-1)+"=":i%3===1&&(o=o.substring(0,o.length-2)+"=="),o},s=function(e){var t,r,n,o,a,s=.75*e.length,l=e.length,c=0;"="===e[e.length-1]&&(s--,"="===e[e.length-2]&&s--);var u=new ArrayBuffer(s),d=new Uint8Array(u);for(t=0;t>4,d[c++]=(15&n)<<4|o>>2,d[c++]=(3&o)<<6|63&a;return u}},34445:(e,t)=>{"use strict";t.byteLength=function(e){var t=s(e),r=t[0],n=t[1];return 3*(r+n)/4-n},t.toByteArray=function(e){var t,r,o=s(e),a=o[0],l=o[1],c=new i(function(e,t,r){return 3*(t+r)/4-r}(0,a,l)),u=0,d=l>0?a-4:a;for(r=0;r>16&255,c[u++]=t>>8&255,c[u++]=255&t;2===l&&(t=n[e.charCodeAt(r)]<<2|n[e.charCodeAt(r+1)]>>4,c[u++]=255&t);1===l&&(t=n[e.charCodeAt(r)]<<10|n[e.charCodeAt(r+1)]<<4|n[e.charCodeAt(r+2)]>>2,c[u++]=t>>8&255,c[u++]=255&t);return c},t.fromByteArray=function(e){for(var t,n=e.length,i=n%3,o=[],a=16383,s=0,c=n-i;sc?c:s+a));1===i?(t=e[n-1],o.push(r[t>>2]+r[t<<4&63]+"==")):2===i&&(t=(e[n-2]<<8)+e[n-1],o.push(r[t>>10]+r[t>>4&63]+r[t<<2&63]+"="));return o.join("")};for(var r=[],n=[],i="undefined"!==typeof Uint8Array?Uint8Array:Array,o="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",a=0;a<64;++a)r[a]=o[a],n[o.charCodeAt(a)]=a;function s(e){var t=e.length;if(t%4>0)throw new Error("Invalid string. Length must be a multiple of 4");var r=e.indexOf("=");return-1===r&&(r=t),[r,r===t?0:4-r%4]}function l(e,t,n){for(var i,o,a=[],s=t;s>18&63]+r[o>>12&63]+r[o>>6&63]+r[63&o]);return a.join("")}n["-".charCodeAt(0)]=62,n["_".charCodeAt(0)]=63},41264:e=>{"use strict";function t(e,t,r,n,i){for(var o=i+1;n<=i;){var a=n+i>>>1,s=e[a];(void 0!==r?r(s,t):s-t)>=0?(o=a,i=a-1):n=a+1}return o}function r(e,t,r,n,i){for(var o=i+1;n<=i;){var a=n+i>>>1,s=e[a];(void 0!==r?r(s,t):s-t)>0?(o=a,i=a-1):n=a+1}return o}function n(e,t,r,n,i){for(var o=n-1;n<=i;){var a=n+i>>>1,s=e[a];(void 0!==r?r(s,t):s-t)<0?(o=a,n=a+1):i=a-1}return o}function i(e,t,r,n,i){for(var o=n-1;n<=i;){var a=n+i>>>1,s=e[a];(void 0!==r?r(s,t):s-t)<=0?(o=a,n=a+1):i=a-1}return o}function o(e,t,r,n,i){for(;n<=i;){var o=n+i>>>1,a=e[o],s=void 0!==r?r(a,t):a-t;if(0===s)return o;s<=0?n=o+1:i=o-1}return-1}function a(e,t,r,n,i,o){return"function"===typeof r?o(e,t,r,void 0===n?0:0|n,void 0===i?e.length-1:0|i):o(e,t,void 0,void 0===r?0:0|r,void 0===n?e.length-1:0|n)}e.exports={ge:function(e,r,n,i,o){return a(e,r,n,i,o,t)},gt:function(e,t,n,i,o){return a(e,t,n,i,o,r)},lt:function(e,t,r,i,o){return a(e,t,r,i,o,n)},le:function(e,t,r,n,o){return a(e,t,r,n,o,i)},eq:function(e,t,r,n,i){return a(e,t,r,n,i,o)}}},62890:(e,t)=>{"use strict";function r(e){var t=32;return(e&=-e)&&t--,65535&e&&(t-=16),16711935&e&&(t-=8),252645135&e&&(t-=4),858993459&e&&(t-=2),1431655765&e&&(t-=1),t}t.INT_BITS=32,t.INT_MAX=2147483647,t.INT_MIN=-1<<31,t.sign=function(e){return(e>0)-(e<0)},t.abs=function(e){var t=e>>31;return(e^t)-t},t.min=function(e,t){return t^(e^t)&-(e65535)<<4,t|=r=((e>>>=t)>255)<<3,t|=r=((e>>>=r)>15)<<2,(t|=r=((e>>>=r)>3)<<1)|(e>>>=r)>>1},t.log10=function(e){return e>=1e9?9:e>=1e8?8:e>=1e7?7:e>=1e6?6:e>=1e5?5:e>=1e4?4:e>=1e3?3:e>=100?2:e>=10?1:0},t.popCount=function(e){return 16843009*((e=(858993459&(e-=e>>>1&1431655765))+(e>>>2&858993459))+(e>>>4)&252645135)>>>24},t.countTrailingZeros=r,t.nextPow2=function(e){return e+=0===e,--e,e|=e>>>1,e|=e>>>2,e|=e>>>4,e|=e>>>8,(e|=e>>>16)+1},t.prevPow2=function(e){return e|=e>>>1,e|=e>>>2,e|=e>>>4,e|=e>>>8,(e|=e>>>16)-(e>>>1)},t.parity=function(e){return e^=e>>>16,e^=e>>>8,e^=e>>>4,27030>>>(e&=15)&1};var n=new Array(256);!function(e){for(var t=0;t<256;++t){var r=t,n=t,i=7;for(r>>>=1;r;r>>>=1)n<<=1,n|=1&r,--i;e[t]=n<>>8&255]<<16|n[e>>>16&255]<<8|n[e>>>24&255]},t.interleave2=function(e,t){return(e=1431655765&((e=858993459&((e=252645135&((e=16711935&((e&=65535)|e<<8))|e<<4))|e<<2))|e<<1))|(t=1431655765&((t=858993459&((t=252645135&((t=16711935&((t&=65535)|t<<8))|t<<4))|t<<2))|t<<1))<<1},t.deinterleave2=function(e,t){return(e=65535&((e=16711935&((e=252645135&((e=858993459&((e=e>>>t&1431655765)|e>>>1))|e>>>2))|e>>>4))|e>>>16))<<16>>16},t.interleave3=function(e,t,r){return e=1227133513&((e=3272356035&((e=251719695&((e=4278190335&((e&=1023)|e<<16))|e<<8))|e<<4))|e<<2),(e|=(t=1227133513&((t=3272356035&((t=251719695&((t=4278190335&((t&=1023)|t<<16))|t<<8))|t<<4))|t<<2))<<1)|(r=1227133513&((r=3272356035&((r=251719695&((r=4278190335&((r&=1023)|r<<16))|r<<8))|r<<4))|r<<2))<<2},t.deinterleave3=function(e,t){return(e=1023&((e=4278190335&((e=251719695&((e=3272356035&((e=e>>>t&1227133513)|e>>>2))|e>>>4))|e>>>8))|e>>>16))<<22>>22},t.nextCombination=function(e){var t=e|e-1;return t+1|(~t&-~t)-1>>>r(e)+1}},32913:e=>{"use strict";e.exports=function(e,n){n||(n={});var i,o,a,s,l,c,u,d,h,p,f,m=null==n.cutoff?.25:n.cutoff,g=null==n.radius?8:n.radius,y=n.channel||0;if(ArrayBuffer.isView(e)||Array.isArray(e)){if(!n.width||!n.height)throw Error("For raw data width and height should be provided by options");i=n.width,o=n.height,s=e,c=n.stride?n.stride:Math.floor(e.length/i/o)}else window.HTMLCanvasElement&&e instanceof window.HTMLCanvasElement?(u=(d=e).getContext("2d"),i=d.width,o=d.height,s=(h=u.getImageData(0,0,i,o)).data,c=4):window.CanvasRenderingContext2D&&e instanceof window.CanvasRenderingContext2D?(u=e,i=(d=e.canvas).width,o=d.height,s=(h=u.getImageData(0,0,i,o)).data,c=4):window.ImageData&&e instanceof window.ImageData&&(h=e,i=e.width,o=e.height,s=h.data,c=4);if(a=Math.max(i,o),window.Uint8ClampedArray&&s instanceof window.Uint8ClampedArray||window.Uint8Array&&s instanceof window.Uint8Array)for(l=s,s=Array(i*o),p=0,f=Math.floor(l.length/c);p{"use strict";const n=r(34445),i=r(6900),o="function"===typeof Symbol&&"function"===typeof Symbol.for?Symbol.for("nodejs.util.inspect.custom"):null;t.Buffer=l,t.SlowBuffer=function(e){+e!=e&&(e=0);return l.alloc(+e)},t.INSPECT_MAX_BYTES=50;const a=2147483647;function s(e){if(e>a)throw new RangeError('The value "'+e+'" is invalid for option "size"');const t=new Uint8Array(e);return Object.setPrototypeOf(t,l.prototype),t}function l(e,t,r){if("number"===typeof e){if("string"===typeof t)throw new TypeError('The "string" argument must be of type string. Received type number');return d(e)}return c(e,t,r)}function c(e,t,r){if("string"===typeof e)return function(e,t){"string"===typeof t&&""!==t||(t="utf8");if(!l.isEncoding(t))throw new TypeError("Unknown encoding: "+t);const r=0|m(e,t);let n=s(r);const i=n.write(e,t);i!==r&&(n=n.slice(0,i));return n}(e,t);if(ArrayBuffer.isView(e))return function(e){if(X(e,Uint8Array)){const t=new Uint8Array(e);return p(t.buffer,t.byteOffset,t.byteLength)}return h(e)}(e);if(null==e)throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof e);if(X(e,ArrayBuffer)||e&&X(e.buffer,ArrayBuffer))return p(e,t,r);if("undefined"!==typeof SharedArrayBuffer&&(X(e,SharedArrayBuffer)||e&&X(e.buffer,SharedArrayBuffer)))return p(e,t,r);if("number"===typeof e)throw new TypeError('The "value" argument must not be of type number. Received type number');const n=e.valueOf&&e.valueOf();if(null!=n&&n!==e)return l.from(n,t,r);const i=function(e){if(l.isBuffer(e)){const t=0|f(e.length),r=s(t);return 0===r.length||e.copy(r,0,0,t),r}if(void 0!==e.length)return"number"!==typeof e.length||Z(e.length)?s(0):h(e);if("Buffer"===e.type&&Array.isArray(e.data))return h(e.data)}(e);if(i)return i;if("undefined"!==typeof Symbol&&null!=Symbol.toPrimitive&&"function"===typeof e[Symbol.toPrimitive])return l.from(e[Symbol.toPrimitive]("string"),t,r);throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof e)}function u(e){if("number"!==typeof e)throw new TypeError('"size" argument must be of type number');if(e<0)throw new RangeError('The value "'+e+'" is invalid for option "size"')}function d(e){return u(e),s(e<0?0:0|f(e))}function h(e){const t=e.length<0?0:0|f(e.length),r=s(t);for(let n=0;n=a)throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x"+a.toString(16)+" bytes");return 0|e}function m(e,t){if(l.isBuffer(e))return e.length;if(ArrayBuffer.isView(e)||X(e,ArrayBuffer))return e.byteLength;if("string"!==typeof e)throw new TypeError('The "string" argument must be one of type string, Buffer, or ArrayBuffer. Received type '+typeof e);const r=e.length,n=arguments.length>2&&!0===arguments[2];if(!n&&0===r)return 0;let i=!1;for(;;)switch(t){case"ascii":case"latin1":case"binary":return r;case"utf8":case"utf-8":return q(e).length;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return 2*r;case"hex":return r>>>1;case"base64":return G(e).length;default:if(i)return n?-1:q(e).length;t=(""+t).toLowerCase(),i=!0}}function g(e,t,r){let n=!1;if((void 0===t||t<0)&&(t=0),t>this.length)return"";if((void 0===r||r>this.length)&&(r=this.length),r<=0)return"";if((r>>>=0)<=(t>>>=0))return"";for(e||(e="utf8");;)switch(e){case"hex":return I(this,t,r);case"utf8":case"utf-8":return T(this,t,r);case"ascii":return C(this,t,r);case"latin1":case"binary":return E(this,t,r);case"base64":return A(this,t,r);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return P(this,t,r);default:if(n)throw new TypeError("Unknown encoding: "+e);e=(e+"").toLowerCase(),n=!0}}function y(e,t,r){const n=e[t];e[t]=e[r],e[r]=n}function v(e,t,r,n,i){if(0===e.length)return-1;if("string"===typeof r?(n=r,r=0):r>2147483647?r=2147483647:r<-2147483648&&(r=-2147483648),Z(r=+r)&&(r=i?0:e.length-1),r<0&&(r=e.length+r),r>=e.length){if(i)return-1;r=e.length-1}else if(r<0){if(!i)return-1;r=0}if("string"===typeof t&&(t=l.from(t,n)),l.isBuffer(t))return 0===t.length?-1:x(e,t,r,n,i);if("number"===typeof t)return t&=255,"function"===typeof Uint8Array.prototype.indexOf?i?Uint8Array.prototype.indexOf.call(e,t,r):Uint8Array.prototype.lastIndexOf.call(e,t,r):x(e,[t],r,n,i);throw new TypeError("val must be string, number or Buffer")}function x(e,t,r,n,i){let o,a=1,s=e.length,l=t.length;if(void 0!==n&&("ucs2"===(n=String(n).toLowerCase())||"ucs-2"===n||"utf16le"===n||"utf-16le"===n)){if(e.length<2||t.length<2)return-1;a=2,s/=2,l/=2,r/=2}function c(e,t){return 1===a?e[t]:e.readUInt16BE(t*a)}if(i){let n=-1;for(o=r;os&&(r=s-l),o=r;o>=0;o--){let r=!0;for(let n=0;ni&&(n=i):n=i;const o=t.length;let a;for(n>o/2&&(n=o/2),a=0;a>8,i=r%256,o.push(i),o.push(n);return o}(t,e.length-r),e,r,n)}function A(e,t,r){return 0===t&&r===e.length?n.fromByteArray(e):n.fromByteArray(e.slice(t,r))}function T(e,t,r){r=Math.min(e.length,r);const n=[];let i=t;for(;i239?4:t>223?3:t>191?2:1;if(i+a<=r){let r,n,s,l;switch(a){case 1:t<128&&(o=t);break;case 2:r=e[i+1],128===(192&r)&&(l=(31&t)<<6|63&r,l>127&&(o=l));break;case 3:r=e[i+1],n=e[i+2],128===(192&r)&&128===(192&n)&&(l=(15&t)<<12|(63&r)<<6|63&n,l>2047&&(l<55296||l>57343)&&(o=l));break;case 4:r=e[i+1],n=e[i+2],s=e[i+3],128===(192&r)&&128===(192&n)&&128===(192&s)&&(l=(15&t)<<18|(63&r)<<12|(63&n)<<6|63&s,l>65535&&l<1114112&&(o=l))}}null===o?(o=65533,a=1):o>65535&&(o-=65536,n.push(o>>>10&1023|55296),o=56320|1023&o),n.push(o),i+=a}return function(e){const t=e.length;if(t<=M)return String.fromCharCode.apply(String,e);let r="",n=0;for(;nn.length?(l.isBuffer(t)||(t=l.from(t)),t.copy(n,i)):Uint8Array.prototype.set.call(n,t,i);else{if(!l.isBuffer(t))throw new TypeError('"list" argument must be an Array of Buffers');t.copy(n,i)}i+=t.length}return n},l.byteLength=m,l.prototype._isBuffer=!0,l.prototype.swap16=function(){const e=this.length;if(e%2!==0)throw new RangeError("Buffer size must be a multiple of 16-bits");for(let t=0;tr&&(e+=" ... "),""},o&&(l.prototype[o]=l.prototype.inspect),l.prototype.compare=function(e,t,r,n,i){if(X(e,Uint8Array)&&(e=l.from(e,e.offset,e.byteLength)),!l.isBuffer(e))throw new TypeError('The "target" argument must be one of type Buffer or Uint8Array. Received type '+typeof e);if(void 0===t&&(t=0),void 0===r&&(r=e?e.length:0),void 0===n&&(n=0),void 0===i&&(i=this.length),t<0||r>e.length||n<0||i>this.length)throw new RangeError("out of range index");if(n>=i&&t>=r)return 0;if(n>=i)return-1;if(t>=r)return 1;if(this===e)return 0;let o=(i>>>=0)-(n>>>=0),a=(r>>>=0)-(t>>>=0);const s=Math.min(o,a),c=this.slice(n,i),u=e.slice(t,r);for(let l=0;l>>=0,isFinite(r)?(r>>>=0,void 0===n&&(n="utf8")):(n=r,r=void 0)}const i=this.length-t;if((void 0===r||r>i)&&(r=i),e.length>0&&(r<0||t<0)||t>this.length)throw new RangeError("Attempt to write outside buffer bounds");n||(n="utf8");let o=!1;for(;;)switch(n){case"hex":return b(this,e,t,r);case"utf8":case"utf-8":return _(this,e,t,r);case"ascii":case"latin1":case"binary":return w(this,e,t,r);case"base64":return k(this,e,t,r);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return S(this,e,t,r);default:if(o)throw new TypeError("Unknown encoding: "+n);n=(""+n).toLowerCase(),o=!0}},l.prototype.toJSON=function(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};const M=4096;function C(e,t,r){let n="";r=Math.min(e.length,r);for(let i=t;in)&&(r=n);let i="";for(let o=t;or)throw new RangeError("Trying to access beyond buffer length")}function R(e,t,r,n,i,o){if(!l.isBuffer(e))throw new TypeError('"buffer" argument must be a Buffer instance');if(t>i||te.length)throw new RangeError("Index out of range")}function L(e,t,r,n,i){U(t,n,i,e,r,7);let o=Number(t&BigInt(4294967295));e[r++]=o,o>>=8,e[r++]=o,o>>=8,e[r++]=o,o>>=8,e[r++]=o;let a=Number(t>>BigInt(32)&BigInt(4294967295));return e[r++]=a,a>>=8,e[r++]=a,a>>=8,e[r++]=a,a>>=8,e[r++]=a,r}function D(e,t,r,n,i){U(t,n,i,e,r,7);let o=Number(t&BigInt(4294967295));e[r+7]=o,o>>=8,e[r+6]=o,o>>=8,e[r+5]=o,o>>=8,e[r+4]=o;let a=Number(t>>BigInt(32)&BigInt(4294967295));return e[r+3]=a,a>>=8,e[r+2]=a,a>>=8,e[r+1]=a,a>>=8,e[r]=a,r+8}function z(e,t,r,n,i,o){if(r+n>e.length)throw new RangeError("Index out of range");if(r<0)throw new RangeError("Index out of range")}function j(e,t,r,n,o){return t=+t,r>>>=0,o||z(e,0,r,4),i.write(e,t,r,n,23,4),r+4}function F(e,t,r,n,o){return t=+t,r>>>=0,o||z(e,0,r,8),i.write(e,t,r,n,52,8),r+8}l.prototype.slice=function(e,t){const r=this.length;(e=~~e)<0?(e+=r)<0&&(e=0):e>r&&(e=r),(t=void 0===t?r:~~t)<0?(t+=r)<0&&(t=0):t>r&&(t=r),t>>=0,t>>>=0,r||O(e,t,this.length);let n=this[e],i=1,o=0;for(;++o>>=0,t>>>=0,r||O(e,t,this.length);let n=this[e+--t],i=1;for(;t>0&&(i*=256);)n+=this[e+--t]*i;return n},l.prototype.readUint8=l.prototype.readUInt8=function(e,t){return e>>>=0,t||O(e,1,this.length),this[e]},l.prototype.readUint16LE=l.prototype.readUInt16LE=function(e,t){return e>>>=0,t||O(e,2,this.length),this[e]|this[e+1]<<8},l.prototype.readUint16BE=l.prototype.readUInt16BE=function(e,t){return e>>>=0,t||O(e,2,this.length),this[e]<<8|this[e+1]},l.prototype.readUint32LE=l.prototype.readUInt32LE=function(e,t){return e>>>=0,t||O(e,4,this.length),(this[e]|this[e+1]<<8|this[e+2]<<16)+16777216*this[e+3]},l.prototype.readUint32BE=l.prototype.readUInt32BE=function(e,t){return e>>>=0,t||O(e,4,this.length),16777216*this[e]+(this[e+1]<<16|this[e+2]<<8|this[e+3])},l.prototype.readBigUInt64LE=J((function(e){H(e>>>=0,"offset");const t=this[e],r=this[e+7];void 0!==t&&void 0!==r||$(e,this.length-8);const n=t+256*this[++e]+65536*this[++e]+this[++e]*2**24,i=this[++e]+256*this[++e]+65536*this[++e]+r*2**24;return BigInt(n)+(BigInt(i)<>>=0,"offset");const t=this[e],r=this[e+7];void 0!==t&&void 0!==r||$(e,this.length-8);const n=t*2**24+65536*this[++e]+256*this[++e]+this[++e],i=this[++e]*2**24+65536*this[++e]+256*this[++e]+r;return(BigInt(n)<>>=0,t>>>=0,r||O(e,t,this.length);let n=this[e],i=1,o=0;for(;++o=i&&(n-=Math.pow(2,8*t)),n},l.prototype.readIntBE=function(e,t,r){e>>>=0,t>>>=0,r||O(e,t,this.length);let n=t,i=1,o=this[e+--n];for(;n>0&&(i*=256);)o+=this[e+--n]*i;return i*=128,o>=i&&(o-=Math.pow(2,8*t)),o},l.prototype.readInt8=function(e,t){return e>>>=0,t||O(e,1,this.length),128&this[e]?-1*(255-this[e]+1):this[e]},l.prototype.readInt16LE=function(e,t){e>>>=0,t||O(e,2,this.length);const r=this[e]|this[e+1]<<8;return 32768&r?4294901760|r:r},l.prototype.readInt16BE=function(e,t){e>>>=0,t||O(e,2,this.length);const r=this[e+1]|this[e]<<8;return 32768&r?4294901760|r:r},l.prototype.readInt32LE=function(e,t){return e>>>=0,t||O(e,4,this.length),this[e]|this[e+1]<<8|this[e+2]<<16|this[e+3]<<24},l.prototype.readInt32BE=function(e,t){return e>>>=0,t||O(e,4,this.length),this[e]<<24|this[e+1]<<16|this[e+2]<<8|this[e+3]},l.prototype.readBigInt64LE=J((function(e){H(e>>>=0,"offset");const t=this[e],r=this[e+7];void 0!==t&&void 0!==r||$(e,this.length-8);const n=this[e+4]+256*this[e+5]+65536*this[e+6]+(r<<24);return(BigInt(n)<>>=0,"offset");const t=this[e],r=this[e+7];void 0!==t&&void 0!==r||$(e,this.length-8);const n=(t<<24)+65536*this[++e]+256*this[++e]+this[++e];return(BigInt(n)<>>=0,t||O(e,4,this.length),i.read(this,e,!0,23,4)},l.prototype.readFloatBE=function(e,t){return e>>>=0,t||O(e,4,this.length),i.read(this,e,!1,23,4)},l.prototype.readDoubleLE=function(e,t){return e>>>=0,t||O(e,8,this.length),i.read(this,e,!0,52,8)},l.prototype.readDoubleBE=function(e,t){return e>>>=0,t||O(e,8,this.length),i.read(this,e,!1,52,8)},l.prototype.writeUintLE=l.prototype.writeUIntLE=function(e,t,r,n){if(e=+e,t>>>=0,r>>>=0,!n){R(this,e,t,r,Math.pow(2,8*r)-1,0)}let i=1,o=0;for(this[t]=255&e;++o>>=0,r>>>=0,!n){R(this,e,t,r,Math.pow(2,8*r)-1,0)}let i=r-1,o=1;for(this[t+i]=255&e;--i>=0&&(o*=256);)this[t+i]=e/o&255;return t+r},l.prototype.writeUint8=l.prototype.writeUInt8=function(e,t,r){return e=+e,t>>>=0,r||R(this,e,t,1,255,0),this[t]=255&e,t+1},l.prototype.writeUint16LE=l.prototype.writeUInt16LE=function(e,t,r){return e=+e,t>>>=0,r||R(this,e,t,2,65535,0),this[t]=255&e,this[t+1]=e>>>8,t+2},l.prototype.writeUint16BE=l.prototype.writeUInt16BE=function(e,t,r){return e=+e,t>>>=0,r||R(this,e,t,2,65535,0),this[t]=e>>>8,this[t+1]=255&e,t+2},l.prototype.writeUint32LE=l.prototype.writeUInt32LE=function(e,t,r){return e=+e,t>>>=0,r||R(this,e,t,4,4294967295,0),this[t+3]=e>>>24,this[t+2]=e>>>16,this[t+1]=e>>>8,this[t]=255&e,t+4},l.prototype.writeUint32BE=l.prototype.writeUInt32BE=function(e,t,r){return e=+e,t>>>=0,r||R(this,e,t,4,4294967295,0),this[t]=e>>>24,this[t+1]=e>>>16,this[t+2]=e>>>8,this[t+3]=255&e,t+4},l.prototype.writeBigUInt64LE=J((function(e){return L(this,e,arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,BigInt(0),BigInt("0xffffffffffffffff"))})),l.prototype.writeBigUInt64BE=J((function(e){return D(this,e,arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,BigInt(0),BigInt("0xffffffffffffffff"))})),l.prototype.writeIntLE=function(e,t,r,n){if(e=+e,t>>>=0,!n){const n=Math.pow(2,8*r-1);R(this,e,t,r,n-1,-n)}let i=0,o=1,a=0;for(this[t]=255&e;++i>>=0,!n){const n=Math.pow(2,8*r-1);R(this,e,t,r,n-1,-n)}let i=r-1,o=1,a=0;for(this[t+i]=255&e;--i>=0&&(o*=256);)e<0&&0===a&&0!==this[t+i+1]&&(a=1),this[t+i]=(e/o|0)-a&255;return t+r},l.prototype.writeInt8=function(e,t,r){return e=+e,t>>>=0,r||R(this,e,t,1,127,-128),e<0&&(e=255+e+1),this[t]=255&e,t+1},l.prototype.writeInt16LE=function(e,t,r){return e=+e,t>>>=0,r||R(this,e,t,2,32767,-32768),this[t]=255&e,this[t+1]=e>>>8,t+2},l.prototype.writeInt16BE=function(e,t,r){return e=+e,t>>>=0,r||R(this,e,t,2,32767,-32768),this[t]=e>>>8,this[t+1]=255&e,t+2},l.prototype.writeInt32LE=function(e,t,r){return e=+e,t>>>=0,r||R(this,e,t,4,2147483647,-2147483648),this[t]=255&e,this[t+1]=e>>>8,this[t+2]=e>>>16,this[t+3]=e>>>24,t+4},l.prototype.writeInt32BE=function(e,t,r){return e=+e,t>>>=0,r||R(this,e,t,4,2147483647,-2147483648),e<0&&(e=4294967295+e+1),this[t]=e>>>24,this[t+1]=e>>>16,this[t+2]=e>>>8,this[t+3]=255&e,t+4},l.prototype.writeBigInt64LE=J((function(e){return L(this,e,arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))})),l.prototype.writeBigInt64BE=J((function(e){return D(this,e,arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))})),l.prototype.writeFloatLE=function(e,t,r){return j(this,e,t,!0,r)},l.prototype.writeFloatBE=function(e,t,r){return j(this,e,t,!1,r)},l.prototype.writeDoubleLE=function(e,t,r){return F(this,e,t,!0,r)},l.prototype.writeDoubleBE=function(e,t,r){return F(this,e,t,!1,r)},l.prototype.copy=function(e,t,r,n){if(!l.isBuffer(e))throw new TypeError("argument should be a Buffer");if(r||(r=0),n||0===n||(n=this.length),t>=e.length&&(t=e.length),t||(t=0),n>0&&n=this.length)throw new RangeError("Index out of range");if(n<0)throw new RangeError("sourceEnd out of bounds");n>this.length&&(n=this.length),e.length-t>>=0,r=void 0===r?this.length:r>>>0,e||(e=0),"number"===typeof e)for(i=t;i=n+4;r-=3)t=`_${e.slice(r-3,r)}${t}`;return`${e.slice(0,r)}${t}`}function U(e,t,r,n,i,o){if(e>r||e3?0===t||t===BigInt(0)?`>= 0${n} and < 2${n} ** ${8*(o+1)}${n}`:`>= -(2${n} ** ${8*(o+1)-1}${n}) and < 2 ** ${8*(o+1)-1}${n}`:`>= ${t}${n} and <= ${r}${n}`,new N.ERR_OUT_OF_RANGE("value",i,e)}!function(e,t,r){H(t,"offset"),void 0!==e[t]&&void 0!==e[t+r]||$(t,e.length-(r+1))}(n,i,o)}function H(e,t){if("number"!==typeof e)throw new N.ERR_INVALID_ARG_TYPE(t,"number",e)}function $(e,t,r){if(Math.floor(e)!==e)throw H(e,r),new N.ERR_OUT_OF_RANGE(r||"offset","an integer",e);if(t<0)throw new N.ERR_BUFFER_OUT_OF_BOUNDS;throw new N.ERR_OUT_OF_RANGE(r||"offset",`>= ${r?1:0} and <= ${t}`,e)}B("ERR_BUFFER_OUT_OF_BOUNDS",(function(e){return e?`${e} is outside of buffer bounds`:"Attempt to access memory outside buffer bounds"}),RangeError),B("ERR_INVALID_ARG_TYPE",(function(e,t){return`The "${e}" argument must be of type number. Received type ${typeof t}`}),TypeError),B("ERR_OUT_OF_RANGE",(function(e,t,r){let n=`The value of "${e}" is out of range.`,i=r;return Number.isInteger(r)&&Math.abs(r)>2**32?i=V(String(r)):"bigint"===typeof r&&(i=String(r),(r>BigInt(2)**BigInt(32)||r<-(BigInt(2)**BigInt(32)))&&(i=V(i)),i+="n"),n+=` It must be ${t}. Received ${i}`,n}),RangeError);const W=/[^+/0-9A-Za-z-_]/g;function q(e,t){let r;t=t||1/0;const n=e.length;let i=null;const o=[];for(let a=0;a55295&&r<57344){if(!i){if(r>56319){(t-=3)>-1&&o.push(239,191,189);continue}if(a+1===n){(t-=3)>-1&&o.push(239,191,189);continue}i=r;continue}if(r<56320){(t-=3)>-1&&o.push(239,191,189),i=r;continue}r=65536+(i-55296<<10|r-56320)}else i&&(t-=3)>-1&&o.push(239,191,189);if(i=null,r<128){if((t-=1)<0)break;o.push(r)}else if(r<2048){if((t-=2)<0)break;o.push(r>>6|192,63&r|128)}else if(r<65536){if((t-=3)<0)break;o.push(r>>12|224,r>>6&63|128,63&r|128)}else{if(!(r<1114112))throw new Error("Invalid code point");if((t-=4)<0)break;o.push(r>>18|240,r>>12&63|128,r>>6&63|128,63&r|128)}}return o}function G(e){return n.toByteArray(function(e){if((e=(e=e.split("=")[0]).trim().replace(W,"")).length<2)return"";for(;e.length%4!==0;)e+="=";return e}(e))}function Y(e,t,r,n){let i;for(i=0;i=t.length||i>=e.length);++i)t[i+r]=e[i];return i}function X(e,t){return e instanceof t||null!=e&&null!=e.constructor&&null!=e.constructor.name&&e.constructor.name===t.name}function Z(e){return e!==e}const K=function(){const e="0123456789abcdef",t=new Array(256);for(let r=0;r<16;++r){const n=16*r;for(let i=0;i<16;++i)t[n+i]=e[r]+e[i]}return t}();function J(e){return"undefined"===typeof BigInt?Q:e}function Q(){throw new Error("BigInt not supported")}},12028:(e,t,r)=>{"use strict";var n=r(60002),i=r(61712),o=i(n("String.prototype.indexOf"));e.exports=function(e,t){var r=n(e,!!t);return"function"===typeof r&&o(e,".prototype.")>-1?i(r):r}},61712:(e,t,r)=>{"use strict";var n=r(63864),i=r(60002),o=r(75438),a=r(54902),s=i("%Function.prototype.apply%"),l=i("%Function.prototype.call%"),c=i("%Reflect.apply%",!0)||n.call(l,s),u=r(82090),d=i("%Math.max%");e.exports=function(e){if("function"!==typeof e)throw new a("a function is required");var t=c(n,l,arguments);return o(t,1+d(0,e.length-(arguments.length-1)),!0)};var h=function(){return c(n,s,arguments)};u?u(e.exports,"apply",{value:h}):e.exports.apply=h},9187:e=>{e.exports=function(e,t,r){return tr?r:e:et?t:e}},53999:(e,t,r)=>{"use strict";var n=r(9187);function i(e,t){null==t&&(t=!0);var r=e[0],i=e[1],o=e[2],a=e[3];return null==a&&(a=t?1:255),t&&(r*=255,i*=255,o*=255,a*=255),16777216*(r=255&n(r,0,255))+((i=255&n(i,0,255))<<16)+((o=255&n(o,0,255))<<8)+(a=255&n(a,0,255))}e.exports=i,e.exports.to=i,e.exports.from=function(e,t){var r=(e=+e)>>>24,n=(16711680&e)>>>16,i=(65280&e)>>>8,o=255&e;return!1===t?[r,n,i,o]:[r/255,n/255,i/255,o/255]}},38301:e=>{"use strict";e.exports={aliceblue:[240,248,255],antiquewhite:[250,235,215],aqua:[0,255,255],aquamarine:[127,255,212],azure:[240,255,255],beige:[245,245,220],bisque:[255,228,196],black:[0,0,0],blanchedalmond:[255,235,205],blue:[0,0,255],blueviolet:[138,43,226],brown:[165,42,42],burlywood:[222,184,135],cadetblue:[95,158,160],chartreuse:[127,255,0],chocolate:[210,105,30],coral:[255,127,80],cornflowerblue:[100,149,237],cornsilk:[255,248,220],crimson:[220,20,60],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgoldenrod:[184,134,11],darkgray:[169,169,169],darkgreen:[0,100,0],darkgrey:[169,169,169],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkseagreen:[143,188,143],darkslateblue:[72,61,139],darkslategray:[47,79,79],darkslategrey:[47,79,79],darkturquoise:[0,206,209],darkviolet:[148,0,211],deeppink:[255,20,147],deepskyblue:[0,191,255],dimgray:[105,105,105],dimgrey:[105,105,105],dodgerblue:[30,144,255],firebrick:[178,34,34],floralwhite:[255,250,240],forestgreen:[34,139,34],fuchsia:[255,0,255],gainsboro:[220,220,220],ghostwhite:[248,248,255],gold:[255,215,0],goldenrod:[218,165,32],gray:[128,128,128],green:[0,128,0],greenyellow:[173,255,47],grey:[128,128,128],honeydew:[240,255,240],hotpink:[255,105,180],indianred:[205,92,92],indigo:[75,0,130],ivory:[255,255,240],khaki:[240,230,140],lavender:[230,230,250],lavenderblush:[255,240,245],lawngreen:[124,252,0],lemonchiffon:[255,250,205],lightblue:[173,216,230],lightcoral:[240,128,128],lightcyan:[224,255,255],lightgoldenrodyellow:[250,250,210],lightgray:[211,211,211],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightsalmon:[255,160,122],lightseagreen:[32,178,170],lightskyblue:[135,206,250],lightslategray:[119,136,153],lightslategrey:[119,136,153],lightsteelblue:[176,196,222],lightyellow:[255,255,224],lime:[0,255,0],limegreen:[50,205,50],linen:[250,240,230],magenta:[255,0,255],maroon:[128,0,0],mediumaquamarine:[102,205,170],mediumblue:[0,0,205],mediumorchid:[186,85,211],mediumpurple:[147,112,219],mediumseagreen:[60,179,113],mediumslateblue:[123,104,238],mediumspringgreen:[0,250,154],mediumturquoise:[72,209,204],mediumvioletred:[199,21,133],midnightblue:[25,25,112],mintcream:[245,255,250],mistyrose:[255,228,225],moccasin:[255,228,181],navajowhite:[255,222,173],navy:[0,0,128],oldlace:[253,245,230],olive:[128,128,0],olivedrab:[107,142,35],orange:[255,165,0],orangered:[255,69,0],orchid:[218,112,214],palegoldenrod:[238,232,170],palegreen:[152,251,152],paleturquoise:[175,238,238],palevioletred:[219,112,147],papayawhip:[255,239,213],peachpuff:[255,218,185],peru:[205,133,63],pink:[255,192,203],plum:[221,160,221],powderblue:[176,224,230],purple:[128,0,128],rebeccapurple:[102,51,153],red:[255,0,0],rosybrown:[188,143,143],royalblue:[65,105,225],saddlebrown:[139,69,19],salmon:[250,128,114],sandybrown:[244,164,96],seagreen:[46,139,87],seashell:[255,245,238],sienna:[160,82,45],silver:[192,192,192],skyblue:[135,206,235],slateblue:[106,90,205],slategray:[112,128,144],slategrey:[112,128,144],snow:[255,250,250],springgreen:[0,255,127],steelblue:[70,130,180],tan:[210,180,140],teal:[0,128,128],thistle:[216,191,216],tomato:[255,99,71],turquoise:[64,224,208],violet:[238,130,238],wheat:[245,222,179],white:[255,255,255],whitesmoke:[245,245,245],yellow:[255,255,0],yellowgreen:[154,205,50]}},91229:(e,t,r)=>{"use strict";var n=r(45480),i=r(12156);e.exports=function(e,t){"float"!==t&&t||(t="array"),"uint"===t&&(t="uint8"),"uint_clamped"===t&&(t="uint8_clamped");var r=new(i(t))(4),o="uint8"!==t&&"uint8_clamped"!==t;return e.length&&"string"!==typeof e||((e=n(e))[0]/=255,e[1]/=255,e[2]/=255),function(e){return e instanceof Uint8Array||e instanceof Uint8ClampedArray||!!(Array.isArray(e)&&(e[0]>1||0===e[0])&&(e[1]>1||0===e[1])&&(e[2]>1||0===e[2])&&(!e[3]||e[3]>1))}(e)?(r[0]=e[0],r[1]=e[1],r[2]=e[2],r[3]=null!=e[3]?e[3]:255,o&&(r[0]/=255,r[1]/=255,r[2]/=255,r[3]/=255),r):(o?(r[0]=e[0],r[1]=e[1],r[2]=e[2],r[3]=null!=e[3]?e[3]:1):(r[0]=Math.min(Math.max(Math.floor(255*e[0]),0),255),r[1]=Math.min(Math.max(Math.floor(255*e[1]),0),255),r[2]=Math.min(Math.max(Math.floor(255*e[2]),0),255),r[3]=null==e[3]?255:Math.min(Math.max(Math.floor(255*e[3]),0),255)),r)}},93457:(e,t,r)=>{"use strict";var n=r(38301);e.exports=function(e){var t,r,o=[],a=1;if("string"===typeof e)if(e=e.toLowerCase(),n[e])o=n[e].slice(),r="rgb";else if("transparent"===e)a=0,r="rgb",o=[0,0,0];else if(/^#[A-Fa-f0-9]+$/.test(e)){var s=e.slice(1);a=1,(u=s.length)<=4?(o=[parseInt(s[0]+s[0],16),parseInt(s[1]+s[1],16),parseInt(s[2]+s[2],16)],4===u&&(a=parseInt(s[3]+s[3],16)/255)):(o=[parseInt(s[0]+s[1],16),parseInt(s[2]+s[3],16),parseInt(s[4]+s[5],16)],8===u&&(a=parseInt(s[6]+s[7],16)/255)),o[0]||(o[0]=0),o[1]||(o[1]=0),o[2]||(o[2]=0),r="rgb"}else if(t=/^((?:rgb|hs[lvb]|hwb|cmyk?|xy[zy]|gray|lab|lchu?v?|[ly]uv|lms)a?)\s*\(([^\)]*)\)/.exec(e)){var l=t[1],c="rgb"===l;r=s=l.replace(/a$/,"");var u="cmyk"===s?4:"gray"===s?1:3;o=t[2].trim().split(/\s*[,\/]\s*|\s+/).map((function(e,t){if(/%$/.test(e))return t===u?parseFloat(e)/100:"rgb"===s?255*parseFloat(e)/100:parseFloat(e);if("h"===s[t]){if(/deg$/.test(e))return parseFloat(e);if(void 0!==i[e])return i[e]}return parseFloat(e)})),l===s&&o.push(1),a=c||void 0===o[u]?1:o[u],o=o.slice(0,u)}else e.length>10&&/[0-9](?:\s|\/)/.test(e)&&(o=e.match(/([0-9]+)/g).map((function(e){return parseFloat(e)})),r=e.match(/([a-z])/gi).join("").toLowerCase());else isNaN(e)?Array.isArray(e)||e.length?(o=[e[0],e[1],e[2]],r="rgb",a=4===e.length?e[3]:1):e instanceof Object&&(null!=e.r||null!=e.red||null!=e.R?(r="rgb",o=[e.r||e.red||e.R||0,e.g||e.green||e.G||0,e.b||e.blue||e.B||0]):(r="hsl",o=[e.h||e.hue||e.H||0,e.s||e.saturation||e.S||0,e.l||e.lightness||e.L||e.b||e.brightness]),a=e.a||e.alpha||e.opacity||1,null!=e.opacity&&(a/=100)):(r="rgb",o=[e>>>16,(65280&e)>>>8,255&e]);return{space:r,values:o,alpha:a}};var i={red:0,orange:60,yellow:120,green:180,blue:240,purple:300}},45480:(e,t,r)=>{"use strict";var n=r(93457);e.exports=function(e){var t;Array.isArray(e)&&e.raw&&(e=String.raw.apply(null,arguments));var r=n(e);if(!r.space)return[];var i=[0,0,0],o="h"===r.space[0]?[360,100,100]:[255,255,255];return(t=Array(3))[0]=Math.min(Math.max(r.values[0],i[0]),o[0]),t[1]=Math.min(Math.max(r.values[1],i[1]),o[1]),t[2]=Math.min(Math.max(r.values[2],i[2]),o[2]),"h"===r.space[0]&&(t=function(e){var t,r,n,i,o,a=e[0]/360,s=e[1]/100,l=e[2]/100,c=0;if(0===s)return o=255*l,[o,o,o];for(t=2*l-(r=l<.5?l*(1+s):l+s-l*s),i=[0,0,0];c<3;)(n=a+1/3*-(c-1))<0?n++:n>1&&n--,o=6*n<1?t+6*(r-t)*n:2*n<1?r:3*n<2?t+(r-t)*(2/3-n)*6:t,i[c++]=255*o;return i}(t)),t.push(Math.min(Math.max(r.alpha,0),1)),t}},80652:e=>{e.exports={jet:[{index:0,rgb:[0,0,131]},{index:.125,rgb:[0,60,170]},{index:.375,rgb:[5,255,255]},{index:.625,rgb:[255,255,0]},{index:.875,rgb:[250,0,0]},{index:1,rgb:[128,0,0]}],hsv:[{index:0,rgb:[255,0,0]},{index:.169,rgb:[253,255,2]},{index:.173,rgb:[247,255,2]},{index:.337,rgb:[0,252,4]},{index:.341,rgb:[0,252,10]},{index:.506,rgb:[1,249,255]},{index:.671,rgb:[2,0,253]},{index:.675,rgb:[8,0,253]},{index:.839,rgb:[255,0,251]},{index:.843,rgb:[255,0,245]},{index:1,rgb:[255,0,6]}],hot:[{index:0,rgb:[0,0,0]},{index:.3,rgb:[230,0,0]},{index:.6,rgb:[255,210,0]},{index:1,rgb:[255,255,255]}],spring:[{index:0,rgb:[255,0,255]},{index:1,rgb:[255,255,0]}],summer:[{index:0,rgb:[0,128,102]},{index:1,rgb:[255,255,102]}],autumn:[{index:0,rgb:[255,0,0]},{index:1,rgb:[255,255,0]}],winter:[{index:0,rgb:[0,0,255]},{index:1,rgb:[0,255,128]}],bone:[{index:0,rgb:[0,0,0]},{index:.376,rgb:[84,84,116]},{index:.753,rgb:[169,200,200]},{index:1,rgb:[255,255,255]}],copper:[{index:0,rgb:[0,0,0]},{index:.804,rgb:[255,160,102]},{index:1,rgb:[255,199,127]}],greys:[{index:0,rgb:[0,0,0]},{index:1,rgb:[255,255,255]}],yignbu:[{index:0,rgb:[8,29,88]},{index:.125,rgb:[37,52,148]},{index:.25,rgb:[34,94,168]},{index:.375,rgb:[29,145,192]},{index:.5,rgb:[65,182,196]},{index:.625,rgb:[127,205,187]},{index:.75,rgb:[199,233,180]},{index:.875,rgb:[237,248,217]},{index:1,rgb:[255,255,217]}],greens:[{index:0,rgb:[0,68,27]},{index:.125,rgb:[0,109,44]},{index:.25,rgb:[35,139,69]},{index:.375,rgb:[65,171,93]},{index:.5,rgb:[116,196,118]},{index:.625,rgb:[161,217,155]},{index:.75,rgb:[199,233,192]},{index:.875,rgb:[229,245,224]},{index:1,rgb:[247,252,245]}],yiorrd:[{index:0,rgb:[128,0,38]},{index:.125,rgb:[189,0,38]},{index:.25,rgb:[227,26,28]},{index:.375,rgb:[252,78,42]},{index:.5,rgb:[253,141,60]},{index:.625,rgb:[254,178,76]},{index:.75,rgb:[254,217,118]},{index:.875,rgb:[255,237,160]},{index:1,rgb:[255,255,204]}],bluered:[{index:0,rgb:[0,0,255]},{index:1,rgb:[255,0,0]}],rdbu:[{index:0,rgb:[5,10,172]},{index:.35,rgb:[106,137,247]},{index:.5,rgb:[190,190,190]},{index:.6,rgb:[220,170,132]},{index:.7,rgb:[230,145,90]},{index:1,rgb:[178,10,28]}],picnic:[{index:0,rgb:[0,0,255]},{index:.1,rgb:[51,153,255]},{index:.2,rgb:[102,204,255]},{index:.3,rgb:[153,204,255]},{index:.4,rgb:[204,204,255]},{index:.5,rgb:[255,255,255]},{index:.6,rgb:[255,204,255]},{index:.7,rgb:[255,153,255]},{index:.8,rgb:[255,102,204]},{index:.9,rgb:[255,102,102]},{index:1,rgb:[255,0,0]}],rainbow:[{index:0,rgb:[150,0,90]},{index:.125,rgb:[0,0,200]},{index:.25,rgb:[0,25,255]},{index:.375,rgb:[0,152,255]},{index:.5,rgb:[44,255,150]},{index:.625,rgb:[151,255,0]},{index:.75,rgb:[255,234,0]},{index:.875,rgb:[255,111,0]},{index:1,rgb:[255,0,0]}],portland:[{index:0,rgb:[12,51,131]},{index:.25,rgb:[10,136,186]},{index:.5,rgb:[242,211,56]},{index:.75,rgb:[242,143,56]},{index:1,rgb:[217,30,30]}],blackbody:[{index:0,rgb:[0,0,0]},{index:.2,rgb:[230,0,0]},{index:.4,rgb:[230,210,0]},{index:.7,rgb:[255,255,255]},{index:1,rgb:[160,200,255]}],earth:[{index:0,rgb:[0,0,130]},{index:.1,rgb:[0,180,180]},{index:.2,rgb:[40,210,40]},{index:.4,rgb:[230,230,50]},{index:.6,rgb:[120,70,20]},{index:1,rgb:[255,255,255]}],electric:[{index:0,rgb:[0,0,0]},{index:.15,rgb:[30,0,100]},{index:.4,rgb:[120,0,100]},{index:.6,rgb:[160,90,0]},{index:.8,rgb:[230,200,0]},{index:1,rgb:[255,250,220]}],alpha:[{index:0,rgb:[255,255,255,0]},{index:1,rgb:[255,255,255,1]}],viridis:[{index:0,rgb:[68,1,84]},{index:.13,rgb:[71,44,122]},{index:.25,rgb:[59,81,139]},{index:.38,rgb:[44,113,142]},{index:.5,rgb:[33,144,141]},{index:.63,rgb:[39,173,129]},{index:.75,rgb:[92,200,99]},{index:.88,rgb:[170,220,50]},{index:1,rgb:[253,231,37]}],inferno:[{index:0,rgb:[0,0,4]},{index:.13,rgb:[31,12,72]},{index:.25,rgb:[85,15,109]},{index:.38,rgb:[136,34,106]},{index:.5,rgb:[186,54,85]},{index:.63,rgb:[227,89,51]},{index:.75,rgb:[249,140,10]},{index:.88,rgb:[249,201,50]},{index:1,rgb:[252,255,164]}],magma:[{index:0,rgb:[0,0,4]},{index:.13,rgb:[28,16,68]},{index:.25,rgb:[79,18,123]},{index:.38,rgb:[129,37,129]},{index:.5,rgb:[181,54,122]},{index:.63,rgb:[229,80,100]},{index:.75,rgb:[251,135,97]},{index:.88,rgb:[254,194,135]},{index:1,rgb:[252,253,191]}],plasma:[{index:0,rgb:[13,8,135]},{index:.13,rgb:[75,3,161]},{index:.25,rgb:[125,3,168]},{index:.38,rgb:[168,34,150]},{index:.5,rgb:[203,70,121]},{index:.63,rgb:[229,107,93]},{index:.75,rgb:[248,148,65]},{index:.88,rgb:[253,195,40]},{index:1,rgb:[240,249,33]}],warm:[{index:0,rgb:[125,0,179]},{index:.13,rgb:[172,0,187]},{index:.25,rgb:[219,0,170]},{index:.38,rgb:[255,0,130]},{index:.5,rgb:[255,63,74]},{index:.63,rgb:[255,123,0]},{index:.75,rgb:[234,176,0]},{index:.88,rgb:[190,228,0]},{index:1,rgb:[147,255,0]}],cool:[{index:0,rgb:[125,0,179]},{index:.13,rgb:[116,0,218]},{index:.25,rgb:[98,74,237]},{index:.38,rgb:[68,146,231]},{index:.5,rgb:[0,204,197]},{index:.63,rgb:[0,247,146]},{index:.75,rgb:[0,255,88]},{index:.88,rgb:[40,255,8]},{index:1,rgb:[147,255,0]}],"rainbow-soft":[{index:0,rgb:[125,0,179]},{index:.1,rgb:[199,0,180]},{index:.2,rgb:[255,0,121]},{index:.3,rgb:[255,108,0]},{index:.4,rgb:[222,194,0]},{index:.5,rgb:[150,255,0]},{index:.6,rgb:[0,255,55]},{index:.7,rgb:[0,246,150]},{index:.8,rgb:[50,167,222]},{index:.9,rgb:[103,51,235]},{index:1,rgb:[124,0,186]}],bathymetry:[{index:0,rgb:[40,26,44]},{index:.13,rgb:[59,49,90]},{index:.25,rgb:[64,76,139]},{index:.38,rgb:[63,110,151]},{index:.5,rgb:[72,142,158]},{index:.63,rgb:[85,174,163]},{index:.75,rgb:[120,206,163]},{index:.88,rgb:[187,230,172]},{index:1,rgb:[253,254,204]}],cdom:[{index:0,rgb:[47,15,62]},{index:.13,rgb:[87,23,86]},{index:.25,rgb:[130,28,99]},{index:.38,rgb:[171,41,96]},{index:.5,rgb:[206,67,86]},{index:.63,rgb:[230,106,84]},{index:.75,rgb:[242,149,103]},{index:.88,rgb:[249,193,135]},{index:1,rgb:[254,237,176]}],chlorophyll:[{index:0,rgb:[18,36,20]},{index:.13,rgb:[25,63,41]},{index:.25,rgb:[24,91,59]},{index:.38,rgb:[13,119,72]},{index:.5,rgb:[18,148,80]},{index:.63,rgb:[80,173,89]},{index:.75,rgb:[132,196,122]},{index:.88,rgb:[175,221,162]},{index:1,rgb:[215,249,208]}],density:[{index:0,rgb:[54,14,36]},{index:.13,rgb:[89,23,80]},{index:.25,rgb:[110,45,132]},{index:.38,rgb:[120,77,178]},{index:.5,rgb:[120,113,213]},{index:.63,rgb:[115,151,228]},{index:.75,rgb:[134,185,227]},{index:.88,rgb:[177,214,227]},{index:1,rgb:[230,241,241]}],"freesurface-blue":[{index:0,rgb:[30,4,110]},{index:.13,rgb:[47,14,176]},{index:.25,rgb:[41,45,236]},{index:.38,rgb:[25,99,212]},{index:.5,rgb:[68,131,200]},{index:.63,rgb:[114,156,197]},{index:.75,rgb:[157,181,203]},{index:.88,rgb:[200,208,216]},{index:1,rgb:[241,237,236]}],"freesurface-red":[{index:0,rgb:[60,9,18]},{index:.13,rgb:[100,17,27]},{index:.25,rgb:[142,20,29]},{index:.38,rgb:[177,43,27]},{index:.5,rgb:[192,87,63]},{index:.63,rgb:[205,125,105]},{index:.75,rgb:[216,162,148]},{index:.88,rgb:[227,199,193]},{index:1,rgb:[241,237,236]}],oxygen:[{index:0,rgb:[64,5,5]},{index:.13,rgb:[106,6,15]},{index:.25,rgb:[144,26,7]},{index:.38,rgb:[168,64,3]},{index:.5,rgb:[188,100,4]},{index:.63,rgb:[206,136,11]},{index:.75,rgb:[220,174,25]},{index:.88,rgb:[231,215,44]},{index:1,rgb:[248,254,105]}],par:[{index:0,rgb:[51,20,24]},{index:.13,rgb:[90,32,35]},{index:.25,rgb:[129,44,34]},{index:.38,rgb:[159,68,25]},{index:.5,rgb:[182,99,19]},{index:.63,rgb:[199,134,22]},{index:.75,rgb:[212,171,35]},{index:.88,rgb:[221,210,54]},{index:1,rgb:[225,253,75]}],phase:[{index:0,rgb:[145,105,18]},{index:.13,rgb:[184,71,38]},{index:.25,rgb:[186,58,115]},{index:.38,rgb:[160,71,185]},{index:.5,rgb:[110,97,218]},{index:.63,rgb:[50,123,164]},{index:.75,rgb:[31,131,110]},{index:.88,rgb:[77,129,34]},{index:1,rgb:[145,105,18]}],salinity:[{index:0,rgb:[42,24,108]},{index:.13,rgb:[33,50,162]},{index:.25,rgb:[15,90,145]},{index:.38,rgb:[40,118,137]},{index:.5,rgb:[59,146,135]},{index:.63,rgb:[79,175,126]},{index:.75,rgb:[120,203,104]},{index:.88,rgb:[193,221,100]},{index:1,rgb:[253,239,154]}],temperature:[{index:0,rgb:[4,35,51]},{index:.13,rgb:[23,51,122]},{index:.25,rgb:[85,59,157]},{index:.38,rgb:[129,79,143]},{index:.5,rgb:[175,95,130]},{index:.63,rgb:[222,112,101]},{index:.75,rgb:[249,146,66]},{index:.88,rgb:[249,196,65]},{index:1,rgb:[232,250,91]}],turbidity:[{index:0,rgb:[34,31,27]},{index:.13,rgb:[65,50,41]},{index:.25,rgb:[98,69,52]},{index:.38,rgb:[131,89,57]},{index:.5,rgb:[161,112,59]},{index:.63,rgb:[185,140,66]},{index:.75,rgb:[202,174,88]},{index:.88,rgb:[216,209,126]},{index:1,rgb:[233,246,171]}],"velocity-blue":[{index:0,rgb:[17,32,64]},{index:.13,rgb:[35,52,116]},{index:.25,rgb:[29,81,156]},{index:.38,rgb:[31,113,162]},{index:.5,rgb:[50,144,169]},{index:.63,rgb:[87,173,176]},{index:.75,rgb:[149,196,189]},{index:.88,rgb:[203,221,211]},{index:1,rgb:[254,251,230]}],"velocity-green":[{index:0,rgb:[23,35,19]},{index:.13,rgb:[24,64,38]},{index:.25,rgb:[11,95,45]},{index:.38,rgb:[39,123,35]},{index:.5,rgb:[95,146,12]},{index:.63,rgb:[152,165,18]},{index:.75,rgb:[201,186,69]},{index:.88,rgb:[233,216,137]},{index:1,rgb:[255,253,205]}],cubehelix:[{index:0,rgb:[0,0,0]},{index:.07,rgb:[22,5,59]},{index:.13,rgb:[60,4,105]},{index:.2,rgb:[109,1,135]},{index:.27,rgb:[161,0,147]},{index:.33,rgb:[210,2,142]},{index:.4,rgb:[251,11,123]},{index:.47,rgb:[255,29,97]},{index:.53,rgb:[255,54,69]},{index:.6,rgb:[255,85,46]},{index:.67,rgb:[255,120,34]},{index:.73,rgb:[255,157,37]},{index:.8,rgb:[241,191,57]},{index:.87,rgb:[224,220,93]},{index:.93,rgb:[218,241,142]},{index:1,rgb:[227,253,198]}]}},20355:(e,t,r)=>{"use strict";var n=r(80652),i=r(91657);function o(e){return[e[0]/255,e[1]/255,e[2]/255,e[3]]}function a(e){for(var t,r="#",n=0;n<3;++n)r+=("00"+(t=(t=e[n]).toString(16))).substr(t.length);return r}function s(e){return"rgba("+e.join(",")+")"}e.exports=function(e){var t,r,l,c,u,d,h,p,f,m;e||(e={});p=(e.nshades||72)-1,h=e.format||"hex",(d=e.colormap)||(d="jet");if("string"===typeof d){if(d=d.toLowerCase(),!n[d])throw Error(d+" not a supported colorscale");u=n[d]}else{if(!Array.isArray(d))throw Error("unsupported colormap option",d);u=d.slice()}if(u.length>p+1)throw new Error(d+" map requires nshades to be at least size "+u.length);f=Array.isArray(e.alpha)?2!==e.alpha.length?[1,1]:e.alpha.slice():"number"===typeof e.alpha?[e.alpha,e.alpha]:[1,1];t=u.map((function(e){return Math.round(e.index*p)})),f[0]=Math.min(Math.max(f[0],0),1),f[1]=Math.min(Math.max(f[1],0),1);var g=u.map((function(e,t){var r=u[t].index,n=u[t].rgb.slice();return 4===n.length&&n[3]>=0&&n[3]<=1||(n[3]=f[0]+(f[1]-f[0])*r),n})),y=[];for(m=0;m{e.exports={AFG:"afghan",ALA:"\\b\\wland",ALB:"albania",DZA:"algeria",ASM:"^(?=.*americ).*samoa",AND:"andorra",AGO:"angola",AIA:"anguill?a",ATA:"antarctica",ATG:"antigua",ARG:"argentin",ARM:"armenia",ABW:"^(?!.*bonaire).*\\baruba",AUS:"australia",AUT:"^(?!.*hungary).*austria|\\baustri.*\\bemp",AZE:"azerbaijan",BHS:"bahamas",BHR:"bahrain",BGD:"bangladesh|^(?=.*east).*paki?stan",BRB:"barbados",BLR:"belarus|byelo",BEL:"^(?!.*luxem).*belgium",BLZ:"belize|^(?=.*british).*honduras",BEN:"benin|dahome",BMU:"bermuda",BTN:"bhutan",BOL:"bolivia",BES:"^(?=.*bonaire).*eustatius|^(?=.*carib).*netherlands|\\bbes.?islands",BIH:"herzegovina|bosnia",BWA:"botswana|bechuana",BVT:"bouvet",BRA:"brazil",IOT:"british.?indian.?ocean",BRN:"brunei",BGR:"bulgaria",BFA:"burkina|\\bfaso|upper.?volta",BDI:"burundi",CPV:"verde",KHM:"cambodia|kampuchea|khmer",CMR:"cameroon",CAN:"canada",CYM:"cayman",CAF:"\\bcentral.african.republic",TCD:"\\bchad",CHL:"\\bchile",CHN:"^(?!.*\\bmac)(?!.*\\bhong)(?!.*\\btai)(?!.*\\brep).*china|^(?=.*peo)(?=.*rep).*china",CXR:"christmas",CCK:"\\bcocos|keeling",COL:"colombia",COM:"comoro",COG:"^(?!.*\\bdem)(?!.*\\bd[\\.]?r)(?!.*kinshasa)(?!.*zaire)(?!.*belg)(?!.*l.opoldville)(?!.*free).*\\bcongo",COK:"\\bcook",CRI:"costa.?rica",CIV:"ivoire|ivory",HRV:"croatia",CUB:"\\bcuba",CUW:"^(?!.*bonaire).*\\bcura(c|\xe7)ao",CYP:"cyprus",CSK:"czechoslovakia",CZE:"^(?=.*rep).*czech|czechia|bohemia",COD:"\\bdem.*congo|congo.*\\bdem|congo.*\\bd[\\.]?r|\\bd[\\.]?r.*congo|belgian.?congo|congo.?free.?state|kinshasa|zaire|l.opoldville|drc|droc|rdc",DNK:"denmark",DJI:"djibouti",DMA:"dominica(?!n)",DOM:"dominican.rep",ECU:"ecuador",EGY:"egypt",SLV:"el.?salvador",GNQ:"guine.*eq|eq.*guine|^(?=.*span).*guinea",ERI:"eritrea",EST:"estonia",ETH:"ethiopia|abyssinia",FLK:"falkland|malvinas",FRO:"faroe|faeroe",FJI:"fiji",FIN:"finland",FRA:"^(?!.*\\bdep)(?!.*martinique).*france|french.?republic|\\bgaul",GUF:"^(?=.*french).*guiana",PYF:"french.?polynesia|tahiti",ATF:"french.?southern",GAB:"gabon",GMB:"gambia",GEO:"^(?!.*south).*georgia",DDR:"german.?democratic.?republic|democratic.?republic.*germany|east.germany",DEU:"^(?!.*east).*germany|^(?=.*\\bfed.*\\brep).*german",GHA:"ghana|gold.?coast",GIB:"gibraltar",GRC:"greece|hellenic|hellas",GRL:"greenland",GRD:"grenada",GLP:"guadeloupe",GUM:"\\bguam",GTM:"guatemala",GGY:"guernsey",GIN:"^(?!.*eq)(?!.*span)(?!.*bissau)(?!.*portu)(?!.*new).*guinea",GNB:"bissau|^(?=.*portu).*guinea",GUY:"guyana|british.?guiana",HTI:"haiti",HMD:"heard.*mcdonald",VAT:"holy.?see|vatican|papal.?st",HND:"^(?!.*brit).*honduras",HKG:"hong.?kong",HUN:"^(?!.*austr).*hungary",ISL:"iceland",IND:"india(?!.*ocea)",IDN:"indonesia",IRN:"\\biran|persia",IRQ:"\\biraq|mesopotamia",IRL:"(^ireland)|(^republic.*ireland)",IMN:"^(?=.*isle).*\\bman",ISR:"israel",ITA:"italy",JAM:"jamaica",JPN:"japan",JEY:"jersey",JOR:"jordan",KAZ:"kazak",KEN:"kenya|british.?east.?africa|east.?africa.?prot",KIR:"kiribati",PRK:"^(?=.*democrat|people|north|d.*p.*.r).*\\bkorea|dprk|korea.*(d.*p.*r)",KWT:"kuwait",KGZ:"kyrgyz|kirghiz",LAO:"\\blaos?\\b",LVA:"latvia",LBN:"lebanon",LSO:"lesotho|basuto",LBR:"liberia",LBY:"libya",LIE:"liechtenstein",LTU:"lithuania",LUX:"^(?!.*belg).*luxem",MAC:"maca(o|u)",MDG:"madagascar|malagasy",MWI:"malawi|nyasa",MYS:"malaysia",MDV:"maldive",MLI:"\\bmali\\b",MLT:"\\bmalta",MHL:"marshall",MTQ:"martinique",MRT:"mauritania",MUS:"mauritius",MYT:"\\bmayotte",MEX:"\\bmexic",FSM:"fed.*micronesia|micronesia.*fed",MCO:"monaco",MNG:"mongolia",MNE:"^(?!.*serbia).*montenegro",MSR:"montserrat",MAR:"morocco|\\bmaroc",MOZ:"mozambique",MMR:"myanmar|burma",NAM:"namibia",NRU:"nauru",NPL:"nepal",NLD:"^(?!.*\\bant)(?!.*\\bcarib).*netherlands",ANT:"^(?=.*\\bant).*(nether|dutch)",NCL:"new.?caledonia",NZL:"new.?zealand",NIC:"nicaragua",NER:"\\bniger(?!ia)",NGA:"nigeria",NIU:"niue",NFK:"norfolk",MNP:"mariana",NOR:"norway",OMN:"\\boman|trucial",PAK:"^(?!.*east).*paki?stan",PLW:"palau",PSE:"palestin|\\bgaza|west.?bank",PAN:"panama",PNG:"papua|new.?guinea",PRY:"paraguay",PER:"peru",PHL:"philippines",PCN:"pitcairn",POL:"poland",PRT:"portugal",PRI:"puerto.?rico",QAT:"qatar",KOR:"^(?!.*d.*p.*r)(?!.*democrat)(?!.*people)(?!.*north).*\\bkorea(?!.*d.*p.*r)",MDA:"moldov|b(a|e)ssarabia",REU:"r(e|\xe9)union",ROU:"r(o|u|ou)mania",RUS:"\\brussia|soviet.?union|u\\.?s\\.?s\\.?r|socialist.?republics",RWA:"rwanda",BLM:"barth(e|\xe9)lemy",SHN:"helena",KNA:"kitts|\\bnevis",LCA:"\\blucia",MAF:"^(?=.*collectivity).*martin|^(?=.*france).*martin(?!ique)|^(?=.*french).*martin(?!ique)",SPM:"miquelon",VCT:"vincent",WSM:"^(?!.*amer).*samoa",SMR:"san.?marino",STP:"\\bs(a|\xe3)o.?tom(e|\xe9)",SAU:"\\bsa\\w*.?arabia",SEN:"senegal",SRB:"^(?!.*monte).*serbia",SYC:"seychell",SLE:"sierra",SGP:"singapore",SXM:"^(?!.*martin)(?!.*saba).*maarten",SVK:"^(?!.*cze).*slovak",SVN:"slovenia",SLB:"solomon",SOM:"somali",ZAF:"south.africa|s\\\\..?africa",SGS:"south.?georgia|sandwich",SSD:"\\bs\\w*.?sudan",ESP:"spain",LKA:"sri.?lanka|ceylon",SDN:"^(?!.*\\bs(?!u)).*sudan",SUR:"surinam|dutch.?guiana",SJM:"svalbard",SWZ:"swaziland",SWE:"sweden",CHE:"switz|swiss",SYR:"syria",TWN:"taiwan|taipei|formosa|^(?!.*peo)(?=.*rep).*china",TJK:"tajik",THA:"thailand|\\bsiam",MKD:"macedonia|fyrom",TLS:"^(?=.*leste).*timor|^(?=.*east).*timor",TGO:"togo",TKL:"tokelau",TON:"tonga",TTO:"trinidad|tobago",TUN:"tunisia",TUR:"turkey",TKM:"turkmen",TCA:"turks",TUV:"tuvalu",UGA:"uganda",UKR:"ukrain",ARE:"emirates|^u\\.?a\\.?e\\.?$|united.?arab.?em",GBR:"united.?kingdom|britain|^u\\.?k\\.?$",TZA:"tanzania",USA:"united.?states\\b(?!.*islands)|\\bu\\.?s\\.?a\\.?\\b|^\\s*u\\.?s\\.?\\b(?!.*islands)",UMI:"minor.?outlying.?is",URY:"uruguay",UZB:"uzbek",VUT:"vanuatu|new.?hebrides",VEN:"venezuela",VNM:"^(?!.*republic).*viet.?nam|^(?=.*socialist).*viet.?nam",VGB:"^(?=.*\\bu\\.?\\s?k).*virgin|^(?=.*brit).*virgin|^(?=.*kingdom).*virgin",VIR:"^(?=.*\\bu\\.?\\s?s).*virgin|^(?=.*states).*virgin",WLF:"futuna|wallis",ESH:"western.sahara",YEM:"^(?!.*arab)(?!.*north)(?!.*sana)(?!.*peo)(?!.*dem)(?!.*south)(?!.*aden)(?!.*\\bp\\.?d\\.?r).*yemen",YMD:"^(?=.*peo).*yemen|^(?!.*rep)(?=.*dem).*yemen|^(?=.*south).*yemen|^(?=.*aden).*yemen|^(?=.*\\bp\\.?d\\.?r).*yemen",YUG:"yugoslavia",ZMB:"zambia|northern.?rhodesia",EAZ:"zanzibar",ZWE:"zimbabwe|^(?!.*northern).*rhodesia"}},45827:(e,t,r)=>{"use strict";e.exports={parse:r(33532),stringify:r(47506)}},38379:(e,t,r)=>{"use strict";var n=r(23648);e.exports={isSize:function(e){return/^[\d\.]/.test(e)||-1!==e.indexOf("/")||-1!==n.indexOf(e)}}},33532:(e,t,r)=>{"use strict";var n=r(86021),i=r(54324),o=r(94316),a=r(99803),s=r(87486),l=r(2362),c=r(13170),u=r(38379).isSize;e.exports=h;var d=h.cache={};function h(e){if("string"!==typeof e)throw new Error("Font argument must be a string.");if(d[e])return d[e];if(""===e)throw new Error("Cannot parse an empty string.");if(-1!==o.indexOf(e))return d[e]={system:e};for(var t,r={style:"normal",variant:"normal",weight:"normal",stretch:"normal",lineHeight:"normal",size:"1rem",family:["serif"]},h=c(e,/\s+/);t=h.shift();){if(-1!==i.indexOf(t))return["style","variant","weight","stretch"].forEach((function(e){r[e]=t})),d[e]=r;if(-1===s.indexOf(t))if("normal"!==t&&"small-caps"!==t)if(-1===l.indexOf(t)){if(-1===a.indexOf(t)){if(u(t)){var f=c(t,"/");if(r.size=f[0],null!=f[1]?r.lineHeight=p(f[1]):"/"===h[0]&&(h.shift(),r.lineHeight=p(h.shift())),!h.length)throw new Error("Missing required font-family.");return r.family=c(h.join(" "),/\s*,\s*/).map(n),d[e]=r}throw new Error("Unknown or unsupported font token: "+t)}r.weight=t}else r.stretch=t;else r.variant=t;else r.style=t}throw new Error("Missing required font-size.")}function p(e){var t=parseFloat(e);return t.toString()===e?t:e}},47506:(e,t,r)=>{"use strict";var n=r(92472),i=r(38379).isSize,o=m(r(54324)),a=m(r(94316)),s=m(r(99803)),l=m(r(87486)),c=m(r(2362)),u={normal:1,"small-caps":1},d={serif:1,"sans-serif":1,monospace:1,cursive:1,fantasy:1,"system-ui":1},h="1rem",p="serif";function f(e,t){if(e&&!t[e]&&!o[e])throw Error("Unknown keyword `"+e+"`");return e}function m(e){for(var t={},r=0;r{"use strict";var n,i=r(90312),o=r(20038),a=r(84526),s=r(52412),l=r(9733),c=r(60731),u=Function.prototype.bind,d=Object.defineProperty,h=Object.prototype.hasOwnProperty;n=function(e,t,r){var n,i=o(t)&&a(t.value);return delete(n=s(t)).writable,delete n.value,n.get=function(){return!r.overwriteDefinition&&h.call(this,e)?i:(t.value=u.call(i,r.resolveContext?r.resolveContext(this):this),d(this,e,t),this[e])},n},e.exports=function(e){var t=l(arguments[1]);return i(t.resolveContext)&&a(t.resolveContext),c(e,(function(e,r){return n(r,e,t)}))}},8276:(e,t,r)=>{"use strict";var n=r(90312),i=r(37040),o=r(53692),a=r(9733),s=r(13423);(e.exports=function(e,t){var r,i,l,c,u;return arguments.length<2||"string"!==typeof e?(c=t,t=e,e=null):c=arguments[2],n(e)?(r=s.call(e,"c"),i=s.call(e,"e"),l=s.call(e,"w")):(r=l=!0,i=!1),u={value:t,configurable:r,enumerable:i,writable:l},c?o(a(c),u):u}).gs=function(e,t,r){var l,c,u,d;return"string"!==typeof e?(u=r,r=t,t=e,e=null):u=arguments[3],n(t)?i(t)?n(r)?i(r)||(u=r,r=void 0):r=void 0:(u=t,t=r=void 0):t=void 0,n(e)?(l=s.call(e,"c"),c=s.call(e,"e")):(l=!0,c=!1),d={get:t,set:r,configurable:l,enumerable:c},u?o(a(u),d):d}},35529:(e,t,r)=>{"use strict";function n(e,t){return et?1:e>=t?0:NaN}r.d(t,{V_:()=>n,T9:()=>a,i2:()=>l,Am:()=>c,jk:()=>u,y1:()=>d,cz:()=>h});var i=function(e){var t;return 1===e.length&&(t=e,e=function(e,r){return n(t(e),r)}),{left:function(t,r,n,i){for(null==n&&(n=0),null==i&&(i=t.length);n>>1;e(t[o],r)<0?n=o+1:i=o}return n},right:function(t,r,n,i){for(null==n&&(n=0),null==i&&(i=t.length);n>>1;e(t[o],r)>0?i=o:n=o+1}return n}}}(n);i.right,i.left;var o=Array.prototype;o.slice,o.map,Math.sqrt(50),Math.sqrt(10),Math.sqrt(2);function a(e,t){var r,n,i=e.length,o=-1;if(null==t){for(;++o=r)for(n=r;++on&&(n=r)}else for(;++o=r)for(n=r;++on&&(n=r);return n}function s(e){return null===e?NaN:+e}function l(e,t){var r,n=e.length,i=n,o=-1,a=0;if(null==t)for(;++o=0;)for(t=(n=e[i]).length;--t>=0;)r[--a]=n[t];return r}function u(e,t){var r,n,i=e.length,o=-1;if(null==t){for(;++o=r)for(n=r;++or&&(n=r)}else for(;++o=r)for(n=r;++or&&(n=r);return n}function d(e,t,r){e=+e,t=+t,r=(i=arguments.length)<2?(t=e,e=0,1):i<3?1:+r;for(var n=-1,i=0|Math.max(0,Math.ceil((t-e)/r)),o=new Array(i);++n{"use strict";r.d(t,{Tj:()=>a,$I:()=>s});var n="$";function i(){}function o(e,t){var r=new i;if(e instanceof i)e.each((function(e,t){r.set(t,e)}));else if(Array.isArray(e)){var n,o=-1,a=e.length;if(null==t)for(;++o=n.length)return null!=e&&r.sort(e),null!=t?t(r):r;for(var c,u,d,h=-1,p=r.length,f=n[i++],m=a(),g=s();++hn.length)return e;var o,a=i[r-1];return null!=t&&r>=n.length?o=e.entries():(o=[],e.each((function(e,t){o.push({key:t,values:s(e,r)})}))),null!=a?o.sort((function(e,t){return a(e.key,t.key)})):o}return r={object:function(e){return o(e,0,l,c)},map:function(e){return o(e,0,u,d)},entries:function(e){return s(o(e,0,u,d),0)},key:function(e){return n.push(e),r},sortKeys:function(e){return i[n.length-1]=e,r},sortValues:function(t){return e=t,r},rollup:function(e){return t=e,r}}}function l(){return{}}function c(e,t,r){e[t]=r}function u(){return a()}function d(e,t,r){e.set(t,r)}function h(){}var p=a.prototype;function f(e,t){var r=new h;if(e instanceof h)e.each((function(e){r.add(e)}));else if(e){var n=-1,i=e.length;if(null==t)for(;++n{"use strict";function n(e,t){var r;function n(){var n,i,o=r.length,a=0,s=0;for(n=0;n=(o=(m+y)/2))?m=o:y=o,(u=r>=(a=(g+v)/2))?g=a:v=a,i=p,!(p=p[d=u<<1|c]))return i[d]=f,e;if(s=+e._x.call(null,p.data),l=+e._y.call(null,p.data),t===s&&r===l)return f.next=p,i?i[d]=f:e._root=f,e;do{i=i?i[d]=new Array(4):e._root=new Array(4),(c=t>=(o=(m+y)/2))?m=o:y=o,(u=r>=(a=(g+v)/2))?g=a:v=a}while((d=u<<1|c)===(h=(l>=a)<<1|s>=o));return i[h]=p,i[d]=f,e}function s(e,t,r,n,i){this.node=e,this.x0=t,this.y0=r,this.x1=n,this.y1=i}function l(e){return e[0]}function c(e){return e[1]}function u(e,t,r){var n=new d(null==t?l:t,null==r?c:r,NaN,NaN,NaN,NaN);return null==e?n:n.addAll(e)}function d(e,t,r,n,i,o){this._x=e,this._y=t,this._x0=r,this._y0=n,this._x1=i,this._y1=o,this._root=void 0}function h(e){for(var t={data:e.data},r=t;e=e.next;)r=r.next={data:e.data};return t}r.r(t),r.d(t,{forceCenter:()=>n,forceCollide:()=>g,forceLink:()=>b,forceManyBody:()=>X,forceRadial:()=>Z,forceSimulation:()=>Y,forceX:()=>K,forceY:()=>J});var p=u.prototype=d.prototype;function f(e){return e.x+e.vx}function m(e){return e.y+e.vy}function g(e){var t,r,n=1,a=1;function s(){for(var e,i,s,c,d,h,p,g=t.length,y=0;yc+f||id+f||as.index){var m=c-l.x-l.vx,g=d-l.y-l.vy,y=m*m+g*g;ye.r&&(e.r=e[t].r)}function c(){if(t){var n,i,o=t.length;for(r=new Array(o),n=0;nd&&(d=n),ih&&(h=i));if(c>d||u>h)return this;for(this.cover(c,u).cover(d,h),r=0;re||e>=i||n>t||t>=o;)switch(s=(tp||(o=c.y0)>f||(a=c.x1)=v)<<1|e>=y)&&(c=m[m.length-1],m[m.length-1]=m[m.length-1-u],m[m.length-1-u]=c)}else{var x=e-+this._x.call(null,g.data),b=t-+this._y.call(null,g.data),_=x*x+b*b;if(_=(s=(f+g)/2))?f=s:g=s,(u=a>=(l=(m+y)/2))?m=l:y=l,t=p,!(p=p[d=u<<1|c]))return this;if(!p.length)break;(t[d+1&3]||t[d+2&3]||t[d+3&3])&&(r=t,h=d)}for(;p.data!==e;)if(n=p,!(p=p.next))return this;return(i=p.next)&&delete p.next,n?(i?n.next=i:delete n.next,this):t?(i?t[d]=i:delete t[d],(p=t[0]||t[1]||t[2]||t[3])&&p===(t[3]||t[2]||t[1]||t[0])&&!p.length&&(r?r[h]=p:this._root=p),this):(this._root=i,this)},p.removeAll=function(e){for(var t=0,r=e.length;t=0&&(t=e.slice(r+1),e=e.slice(0,r)),e&&!n.hasOwnProperty(e))throw new Error("unknown type: "+e);return{type:e,name:t}}))),a=-1,s=o.length;if(!(arguments.length<2)){if(null!=t&&"function"!==typeof t)throw new Error("invalid callback: "+t);for(;++a0)for(var r,n,i=new Array(r),o=0;o=0&&t._call.call(null,e),t=t._next;--E}()}finally{E=0,function(){var e,t,r=M,n=1/0;for(;r;)r._call?(n>r._time&&(n=r._time),e=r,r=r._next):(t=r._next,r._next=null,r=e?e._next=t:M=t);C=e,H(n)}(),R=0}}function U(){var e=D.now(),t=e-O;t>1e3&&(L-=t,O=e)}function H(e){E||(I&&(I=clearTimeout(I)),e-R>24?(e<1/0&&(I=setTimeout(V,e-D.now()-L)),P&&(P=clearInterval(P))):(P||(O=D.now(),P=setInterval(U,1e3)),E=1,z(V)))}function $(e){return e.x}function W(e){return e.y}N.prototype=B.prototype={constructor:N,restart:function(e,t,r){if("function"!==typeof e)throw new TypeError("callback is not a function");r=(null==r?j():+r)+(null==t?0:+t),this._next||C===this||(C?C._next=this:M=this,C=this),this._call=e,this._time=r,H()},stop:function(){this._call&&(this._call=null,this._time=1/0,H())}};var q=10,G=Math.PI*(3-Math.sqrt(5));function Y(e){var t,r=1,n=.001,i=1-Math.pow(n,1/300),o=0,a=.6,s=(0,y.Tj)(),l=B(u),c=T("tick","end");function u(){d(),c.call("tick",t),r1?(null==r?s.remove(e):s.set(e,p(r)),t):s.get(e)},find:function(t,r,n){var i,o,a,s,l,c=0,u=e.length;for(null==n?n=1/0:n*=n,c=0;c1?(c.on(e,r),t):c.on(e)}}}function X(){var e,t,r,n,a=i(-30),s=1,l=1/0,c=.81;function d(n){var i,o=e.length,a=u(e,$,W).visitAfter(p);for(r=n,i=0;i=l)){(e.data!==t||e.next)&&(0===d&&(f+=(d=o())*d),0===h&&(f+=(h=o())*h),f{"use strict";function n(e,t){if((r=(e=t?e.toExponential(t-1):e.toExponential()).indexOf("e"))<0)return null;var r,n=e.slice(0,r);return[n.length>1?n[0]+n.slice(2):n,+e.slice(r+1)]}r.d(t,{GP:()=>h,OE:()=>m});var i,o=/^(?:(.)?([<>=^]))?([+\-( ])?([$#])?(0)?(\d+)?(,)?(\.\d+)?(~)?([a-z%])?$/i;function a(e){if(!(t=o.exec(e)))throw new Error("invalid format: "+e);var t;return new s({fill:t[1],align:t[2],sign:t[3],symbol:t[4],zero:t[5],width:t[6],comma:t[7],precision:t[8]&&t[8].slice(1),trim:t[9],type:t[10]})}function s(e){this.fill=void 0===e.fill?" ":e.fill+"",this.align=void 0===e.align?">":e.align+"",this.sign=void 0===e.sign?"-":e.sign+"",this.symbol=void 0===e.symbol?"":e.symbol+"",this.zero=!!e.zero,this.width=void 0===e.width?void 0:+e.width,this.comma=!!e.comma,this.precision=void 0===e.precision?void 0:+e.precision,this.trim=!!e.trim,this.type=void 0===e.type?"":e.type+""}function l(e,t){var r=n(e,t);if(!r)return e+"";var i=r[0],o=r[1];return o<0?"0."+new Array(-o).join("0")+i:i.length>o+1?i.slice(0,o+1)+"."+i.slice(o+1):i+new Array(o-i.length+2).join("0")}a.prototype=s.prototype,s.prototype.toString=function(){return this.fill+this.align+this.sign+this.symbol+(this.zero?"0":"")+(void 0===this.width?"":Math.max(1,0|this.width))+(this.comma?",":"")+(void 0===this.precision?"":"."+Math.max(0,0|this.precision))+(this.trim?"~":"")+this.type};const c={"%":function(e,t){return(100*e).toFixed(t)},b:function(e){return Math.round(e).toString(2)},c:function(e){return e+""},d:function(e){return Math.abs(e=Math.round(e))>=1e21?e.toLocaleString("en").replace(/,/g,""):e.toString(10)},e:function(e,t){return e.toExponential(t)},f:function(e,t){return e.toFixed(t)},g:function(e,t){return e.toPrecision(t)},o:function(e){return Math.round(e).toString(8)},p:function(e,t){return l(100*e,t)},r:l,s:function(e,t){var r=n(e,t);if(!r)return e+"";var o=r[0],a=r[1],s=a-(i=3*Math.max(-8,Math.min(8,Math.floor(a/3))))+1,l=o.length;return s===l?o:s>l?o+new Array(s-l+1).join("0"):s>0?o.slice(0,s)+"."+o.slice(s):"0."+new Array(1-s).join("0")+n(e,Math.max(0,t+s-1))[0]},X:function(e){return Math.round(e).toString(16).toUpperCase()},x:function(e){return Math.round(e).toString(16)}};function u(e){return e}var d,h,p=Array.prototype.map,f=["y","z","a","f","p","n","\xb5","m","","k","M","G","T","P","E","Z","Y"];function m(e){var t,r,o=void 0===e.grouping||void 0===e.thousands?u:(t=p.call(e.grouping,Number),r=e.thousands+"",function(e,n){for(var i=e.length,o=[],a=0,s=t[0],l=0;i>0&&s>0&&(l+s+1>n&&(s=Math.max(1,n-l)),o.push(e.substring(i-=s,i+s)),!((l+=s+1)>n));)s=t[a=(a+1)%t.length];return o.reverse().join(r)}),s=void 0===e.currency?"":e.currency[0]+"",l=void 0===e.currency?"":e.currency[1]+"",d=void 0===e.decimal?".":e.decimal+"",h=void 0===e.numerals?u:function(e){return function(t){return t.replace(/[0-9]/g,(function(t){return e[+t]}))}}(p.call(e.numerals,String)),m=void 0===e.percent?"%":e.percent+"",g=void 0===e.minus?"-":e.minus+"",y=void 0===e.nan?"NaN":e.nan+"";function v(e){var t=(e=a(e)).fill,r=e.align,n=e.sign,u=e.symbol,p=e.zero,v=e.width,x=e.comma,b=e.precision,_=e.trim,w=e.type;"n"===w?(x=!0,w="g"):c[w]||(void 0===b&&(b=12),_=!0,w="g"),(p||"0"===t&&"="===r)&&(p=!0,t="0",r="=");var k="$"===u?s:"#"===u&&/[boxX]/.test(w)?"0"+w.toLowerCase():"",S="$"===u?l:/[%p]/.test(w)?m:"",A=c[w],T=/[defgprs%]/.test(w);function M(e){var a,s,l,c=k,u=S;if("c"===w)u=A(e)+u,e="";else{var m=(e=+e)<0||1/e<0;if(e=isNaN(e)?y:A(Math.abs(e),b),_&&(e=function(e){e:for(var t,r=e.length,n=1,i=-1;n0&&(i=0)}return i>0?e.slice(0,i)+e.slice(t+1):e}(e)),m&&0===+e&&"+"!==n&&(m=!1),c=(m?"("===n?n:g:"-"===n||"("===n?"":n)+c,u=("s"===w?f[8+i/3]:"")+u+(m&&"("===n?")":""),T)for(a=-1,s=e.length;++a(l=e.charCodeAt(a))||l>57){u=(46===l?d+e.slice(a+1):e.slice(a))+u,e=e.slice(0,a);break}}x&&!p&&(e=o(e,1/0));var M=c.length+e.length+u.length,C=M>1)+c+e+u+C.slice(M);break;default:e=C+c+e+u}return h(e)}return b=void 0===b?6:/[gprs]/.test(w)?Math.max(1,Math.min(21,b)):Math.max(0,Math.min(20,b)),M.toString=function(){return e+""},M}return{format:v,formatPrefix:function(e,t){var r,i=v(((e=a(e)).type="f",e)),o=3*Math.max(-8,Math.min(8,Math.floor((r=t,((r=n(Math.abs(r)))?r[1]:NaN)/3)))),s=Math.pow(10,-o),l=f[8+o/3];return function(e){return i(s*e)+l}}}}d=m({decimal:".",thousands:",",grouping:[3],currency:["$",""],minus:"-"}),h=d.format,d.formatPrefix},50167:(e,t,r)=>{"use strict";r.r(t),r.d(t,{geoAiry:()=>D,geoAiryRaw:()=>L,geoAitoff:()=>j,geoAitoffRaw:()=>z,geoArmadillo:()=>N,geoArmadilloRaw:()=>F,geoAugust:()=>V,geoAugustRaw:()=>B,geoBaker:()=>W,geoBakerRaw:()=>$,geoBerghaus:()=>Y,geoBerghausRaw:()=>G,geoBertin1953:()=>re,geoBertin1953Raw:()=>te,geoBoggs:()=>ue,geoBoggsRaw:()=>ce,geoBonne:()=>me,geoBonneRaw:()=>fe,geoBottomley:()=>ye,geoBottomleyRaw:()=>ge,geoBromley:()=>xe,geoBromleyRaw:()=>ve,geoChamberlin:()=>Ce,geoChamberlinAfrica:()=>Me,geoChamberlinRaw:()=>Ae,geoCollignon:()=>Ie,geoCollignonRaw:()=>Ee,geoCraig:()=>Oe,geoCraigRaw:()=>Pe,geoCraster:()=>De,geoCrasterRaw:()=>Le,geoCylindricalEqualArea:()=>je,geoCylindricalEqualAreaRaw:()=>ze,geoCylindricalStereographic:()=>Ne,geoCylindricalStereographicRaw:()=>Fe,geoEckert1:()=>Ve,geoEckert1Raw:()=>Be,geoEckert2:()=>He,geoEckert2Raw:()=>Ue,geoEckert3:()=>We,geoEckert3Raw:()=>$e,geoEckert4:()=>Ge,geoEckert4Raw:()=>qe,geoEckert5:()=>Xe,geoEckert5Raw:()=>Ye,geoEckert6:()=>Ke,geoEckert6Raw:()=>Ze,geoEisenlohr:()=>et,geoEisenlohrRaw:()=>Qe,geoFahey:()=>nt,geoFaheyRaw:()=>rt,geoFoucaut:()=>ot,geoFoucautRaw:()=>it,geoFoucautSinusoidal:()=>st,geoFoucautSinusoidalRaw:()=>at,geoGilbert:()=>ht,geoGingery:()=>gt,geoGingeryRaw:()=>pt,geoGinzburg4:()=>xt,geoGinzburg4Raw:()=>vt,geoGinzburg5:()=>_t,geoGinzburg5Raw:()=>bt,geoGinzburg6:()=>kt,geoGinzburg6Raw:()=>wt,geoGinzburg8:()=>At,geoGinzburg8Raw:()=>St,geoGinzburg9:()=>Mt,geoGinzburg9Raw:()=>Tt,geoGringorten:()=>It,geoGringortenQuincuncial:()=>oi,geoGringortenRaw:()=>Et,geoGuyou:()=>Lt,geoGuyouRaw:()=>Rt,geoHammer:()=>J,geoHammerRaw:()=>Z,geoHammerRetroazimuthal:()=>Ft,geoHammerRetroazimuthalRaw:()=>zt,geoHealpix:()=>Gt,geoHealpixRaw:()=>Ht,geoHill:()=>Xt,geoHillRaw:()=>Yt,geoHomolosine:()=>tr,geoHomolosineRaw:()=>er,geoHufnagel:()=>nr,geoHufnagelRaw:()=>rr,geoHyperelliptical:()=>sr,geoHyperellipticalRaw:()=>ar,geoInterrupt:()=>ur,geoInterruptedBoggs:()=>hr,geoInterruptedHomolosine:()=>fr,geoInterruptedMollweide:()=>gr,geoInterruptedMollweideHemispheres:()=>vr,geoInterruptedQuarticAuthalic:()=>dn,geoInterruptedSinuMollweide:()=>br,geoInterruptedSinusoidal:()=>wr,geoKavrayskiy7:()=>Sr,geoKavrayskiy7Raw:()=>kr,geoLagrange:()=>Tr,geoLagrangeRaw:()=>Ar,geoLarrivee:()=>Er,geoLarriveeRaw:()=>Cr,geoLaskowski:()=>Pr,geoLaskowskiRaw:()=>Ir,geoLittrow:()=>Rr,geoLittrowRaw:()=>Or,geoLoximuthal:()=>Dr,geoLoximuthalRaw:()=>Lr,geoMiller:()=>jr,geoMillerRaw:()=>zr,geoModifiedStereographic:()=>Xr,geoModifiedStereographicAlaska:()=>$r,geoModifiedStereographicGs48:()=>Wr,geoModifiedStereographicGs50:()=>qr,geoModifiedStereographicLee:()=>Yr,geoModifiedStereographicMiller:()=>Gr,geoModifiedStereographicRaw:()=>Fr,geoMollweide:()=>ae,geoMollweideRaw:()=>oe,geoMtFlatPolarParabolic:()=>Qr,geoMtFlatPolarParabolicRaw:()=>Jr,geoMtFlatPolarQuartic:()=>tn,geoMtFlatPolarQuarticRaw:()=>en,geoMtFlatPolarSinusoidal:()=>nn,geoMtFlatPolarSinusoidalRaw:()=>rn,geoNaturalEarth:()=>on.A,geoNaturalEarth2:()=>sn,geoNaturalEarth2Raw:()=>an,geoNaturalEarthRaw:()=>on.P,geoNellHammer:()=>cn,geoNellHammerRaw:()=>ln,geoNicolosi:()=>pn,geoNicolosiRaw:()=>hn,geoPatterson:()=>Sn,geoPattersonRaw:()=>kn,geoPeirceQuincuncial:()=>ai,geoPierceQuincuncial:()=>ai,geoPolyconic:()=>Tn,geoPolyconicRaw:()=>An,geoPolyhedral:()=>Rn,geoPolyhedralButterfly:()=>Bn,geoPolyhedralCollignon:()=>Hn,geoPolyhedralWaterman:()=>$n,geoProject:()=>Xn,geoQuantize:()=>si,geoQuincuncial:()=>ii,geoRectangularPolyconic:()=>ci,geoRectangularPolyconicRaw:()=>li,geoRobinson:()=>hi,geoRobinsonRaw:()=>di,geoSatellite:()=>fi,geoSatelliteRaw:()=>pi,geoSinuMollweide:()=>Qt,geoSinuMollweideRaw:()=>Jt,geoSinusoidal:()=>pe,geoSinusoidalRaw:()=>he,geoStitch:()=>Ri,geoTimes:()=>Di,geoTimesRaw:()=>Li,geoTwoPointAzimuthal:()=>Ni,geoTwoPointAzimuthalRaw:()=>ji,geoTwoPointAzimuthalUsa:()=>Fi,geoTwoPointEquidistant:()=>Ui,geoTwoPointEquidistantRaw:()=>Bi,geoTwoPointEquidistantUsa:()=>Vi,geoVanDerGrinten:()=>$i,geoVanDerGrinten2:()=>qi,geoVanDerGrinten2Raw:()=>Wi,geoVanDerGrinten3:()=>Yi,geoVanDerGrinten3Raw:()=>Gi,geoVanDerGrinten4:()=>Zi,geoVanDerGrinten4Raw:()=>Xi,geoVanDerGrintenRaw:()=>Hi,geoWagner:()=>Ji,geoWagner4:()=>no,geoWagner4Raw:()=>ro,geoWagner6:()=>oo,geoWagner6Raw:()=>io,geoWagner7:()=>Qi,geoWagnerRaw:()=>Ki,geoWiechel:()=>so,geoWiechelRaw:()=>ao,geoWinkel3:()=>co,geoWinkel3Raw:()=>lo});var n=r(23373),i=Math.abs,o=Math.atan,a=Math.atan2,s=(Math.ceil,Math.cos),l=Math.exp,c=Math.floor,u=Math.log,d=Math.max,h=Math.min,p=Math.pow,f=Math.round,m=Math.sign||function(e){return e>0?1:e<0?-1:0},g=Math.sin,y=Math.tan,v=1e-6,x=1e-12,b=Math.PI,_=b/2,w=b/4,k=Math.SQRT1_2,S=P(2),A=P(b),T=2*b,M=180/b,C=b/180;function E(e){return e>1?_:e<-1?-_:Math.asin(e)}function I(e){return e>1?0:e<-1?b:Math.acos(e)}function P(e){return e>0?Math.sqrt(e):0}function O(e){return(l(e)-l(-e))/2}function R(e){return(l(e)+l(-e))/2}function L(e){var t=y(e/2),r=2*u(s(e/2))/(t*t);function n(e,t){var n=s(e),i=s(t),o=g(t),a=i*n,l=-((1-a?u((1+a)/2)/(1-a):-.5)+r/(1+a));return[l*i*g(e),l*o]}return n.invert=function(t,n){var o,l=P(t*t+n*n),c=-e/2,d=50;if(!l)return[0,0];do{var h=c/2,p=s(h),f=g(h),m=f/p,y=-u(i(p));c-=o=(2/m*y-r*m-l)/(-y/(f*f)+1-r/(2*p*p))*(p<0?.7:1)}while(i(o)>v&&--d>0);var x=g(c);return[a(t*x,l*s(c)),E(n*x/l)]},n}function D(){var e=_,t=(0,n.U)(L),r=t(e);return r.radius=function(r){return arguments.length?t(e=r*C):e*M},r.scale(179.976).clipAngle(147)}function z(e,t){var r=s(t),n=function(e){return e?e/Math.sin(e):1}(I(r*s(e/=2)));return[2*r*g(e)*n,g(t)*n]}function j(){return(0,n.A)(z).scale(152.63)}function F(e){var t=g(e),r=s(e),n=e>=0?1:-1,o=y(n*e),l=(1+t-r)/2;function c(e,i){var c=s(i),u=s(e/=2);return[(1+c)*g(e),(n*i>-a(u,o)-.001?0:10*-n)+l+g(i)*r-(1+c)*t*u]}return c.invert=function(e,c){var u=0,d=0,h=50;do{var p=s(u),f=g(u),m=s(d),y=g(d),x=1+m,b=x*f-e,_=l+y*r-x*t*p-c,w=x*p/2,k=-f*y,S=t*x*f/2,A=r*m+t*p*y,T=k*S-A*w,M=(_*k-b*A)/T/2,C=(b*S-_*w)/T;i(C)>2&&(C/=2),u-=M,d-=C}while((i(M)>v||i(C)>v)&&--h>0);return n*d>-a(s(u),o)-.001?[2*u,d]:null},c}function N(){var e=20*C,t=e>=0?1:-1,r=y(t*e),i=(0,n.U)(F),o=i(e),l=o.stream;return o.parallel=function(n){return arguments.length?(r=y((t=(e=n*C)>=0?1:-1)*e),i(e)):e*M},o.stream=function(n){var i=o.rotate(),c=l(n),u=(o.rotate([0,0]),l(n)),d=o.precision();return o.rotate(i),c.sphere=function(){u.polygonStart(),u.lineStart();for(var n=-180*t;t*n<180;n+=90*t)u.point(n,90*t);if(e)for(;t*(n-=3*t*d)>=-180;)u.point(n,t*-a(s(n*C/2),r)*M);u.lineEnd(),u.polygonEnd()},c},o.scale(218.695).center([0,28.0974])}function B(e,t){var r=y(t/2),n=P(1-r*r),i=1+n*s(e/=2),o=g(e)*n/i,a=r/i,l=o*o,c=a*a;return[4/3*o*(3+l-3*c),4/3*a*(3+3*l-c)]}function V(){return(0,n.A)(B).scale(66.1603)}z.invert=function(e,t){if(!(e*e+4*t*t>b*b+v)){var r=e,n=t,o=25;do{var a,l=g(r),c=g(r/2),u=s(r/2),d=g(n),h=s(n),p=g(2*n),f=d*d,m=h*h,y=c*c,x=1-m*u*u,_=x?I(h*u)*P(a=1/x):a=0,w=2*_*h*c-e,k=_*d-t,S=a*(m*y+_*h*u*f),A=a*(.5*l*p-2*_*d*c),T=.25*a*(p*c-_*d*m*l),M=a*(f*u+_*y*h),C=A*T-M*S;if(!C)break;var E=(k*A-w*M)/C,O=(w*T-k*S)/C;r-=E,n-=O}while((i(E)>v||i(O)>v)&&--o>0);return[r,n]}},B.invert=function(e,t){if(t*=3/8,!(e*=3/8)&&i(t)>1)return null;var r=1+e*e+t*t,n=P((r-P(r*r-4*t*t))/2),o=E(n)/3,l=n?function(e){return u(e+P(e*e-1))}(i(t/n))/3:function(e){return u(e+P(e*e+1))}(i(e))/3,c=s(o),d=R(l),h=d*d-c*c;return[2*m(e)*a(O(l)*c,.25-h),2*m(t)*a(d*g(o),.25+h)]};var U=P(8),H=u(1+S);function $(e,t){var r=i(t);return rx&&--c>0);return[e/(s(a)*(U-1/g(a))),m(t)*a]};var q=r(89012);function G(e){var t=2*b/e;function r(e,r){var n=(0,q.j)(e,r);if(i(e)>_){var o=a(n[1],n[0]),l=P(n[0]*n[0]+n[1]*n[1]),c=t*f((o-_)/t)+_,u=a(g(o-=c),2-s(o));o=c+E(b/l*g(u))-u,n[0]=l*s(o),n[1]=l*g(o)}return n}return r.invert=function(e,r){var n=P(e*e+r*r);if(n>_){var i=a(r,e),l=t*f((i-_)/t)+_,c=i>l?-1:1,u=n*s(l-i),d=1/y(c*I((u-b)/P(b*(b-2*u)+n*n)));i=l+2*o((d+c*P(d*d-3))/3),e=n*s(i),r=n*g(i)}return q.j.invert(e,r)},r}function Y(){var e=5,t=(0,n.U)(G),r=t(e),i=r.stream,o=.01,l=-s(o*C),c=g(o*C);return r.lobes=function(r){return arguments.length?t(e=+r):e},r.stream=function(t){var n=r.rotate(),u=i(t),d=(r.rotate([0,0]),i(t));return r.rotate(n),u.sphere=function(){d.polygonStart(),d.lineStart();for(var t=0,r=360/e,n=2*b/e,i=90-180/e,u=_;t0&&i(n)>v);return s<0?NaN:r}function ee(e,t,r){return void 0===t&&(t=40),void 0===r&&(r=x),function(n,o,a,s){var l,c,u;a=void 0===a?0:+a,s=void 0===s?0:+s;for(var d=0;dl)a-=c/=2,s-=u/=2;else{l=m;var g=(a>0?-1:1)*r,y=(s>0?-1:1)*r,v=e(a+g,s),x=e(a,s+y),b=(v[0]-h[0])/g,_=(v[1]-h[1])/g,w=(x[0]-h[0])/y,k=(x[1]-h[1])/y,S=k*b-_*w,A=(i(S)<.5?.5:1)/S;if(a+=c=(f*w-p*k)*A,s+=u=(p*_-f*b)*A,i(c)0&&(i[1]*=1+o/1.5*i[0]*i[0]),i}return t.invert=ee(t),t}function re(){return(0,n.A)(te()).rotate([-16.5,-42]).scale(176.57).center([7.93,.09])}function ne(e,t){var r,n=e*g(t),o=30;do{t-=r=(t+g(t)-n)/(1+s(t))}while(i(r)>v&&--o>0);return t/2}function ie(e,t,r){function n(n,i){return[e*n*s(i=ne(r,i)),t*g(i)]}return n.invert=function(n,i){return i=E(i/t),[n/(e*s(i)),E((2*i+g(2*i))/r)]},n}K.invert=function(e,t){var r=2*E(t/2);return[e*s(r/2)/s(r),r]};var oe=ie(S/_,S,b);function ae(){return(0,n.A)(oe).scale(169.529)}var se=2.00276,le=1.11072;function ce(e,t){var r=ne(b,t);return[se*e/(1/s(t)+le/s(r)),(t+S*g(r))/se]}function ue(){return(0,n.A)(ce).scale(160.857)}function de(e){var t=0,r=(0,n.U)(e),i=r(t);return i.parallel=function(e){return arguments.length?r(t=e*C):t*M},i}function he(e,t){return[e*s(t),t]}function pe(){return(0,n.A)(he).scale(152.63)}function fe(e){if(!e)return he;var t=1/y(e);function r(r,n){var i=t+e-n,o=i?r*s(n)/i:i;return[i*g(o),t-i*s(o)]}return r.invert=function(r,n){var i=P(r*r+(n=t-n)*n),o=t+e-i;return[i/s(o)*a(r,n),o]},r}function me(){return de(fe).scale(123.082).center([0,26.1441]).parallel(45)}function ge(e){function t(t,r){var n=_-r,i=n?t*e*g(n)/n:n;return[n*g(i)/e,_-n*s(i)]}return t.invert=function(t,r){var n=t*e,i=_-r,o=P(n*n+i*i),s=a(n,i);return[(o?o/g(o):1)*s/e,_-o]},t}function ye(){var e=.5,t=(0,n.U)(ge),r=t(e);return r.fraction=function(r){return arguments.length?t(e=+r):e},r.scale(158.837)}ce.invert=function(e,t){var r,n,o=se*t,a=t<0?-w:w,l=25;do{n=o-S*g(a),a-=r=(g(2*a)+2*a-b*g(n))/(2*s(2*a)+2+b*s(n)*S*s(a))}while(i(r)>v&&--l>0);return n=o-S*g(a),[e*(1/s(n)+le/s(a))/se,n]},he.invert=function(e,t){return[e/s(t),t]};var ve=ie(1,4/b,b);function xe(){return(0,n.A)(ve).scale(152.63)}var be=r(78746),_e=r(27520);function we(e,t,r,n,o,l){var c,u=s(l);if(i(e)>1||i(l)>1)c=I(r*o+t*n*u);else{var d=g(e/2),h=g(l/2);c=2*E(P(d*d+t*n*h*h))}return i(c)>v?[c,a(n*g(l),t*o-r*n*u)]:[0,0]}function ke(e,t,r){return I((e*e+t*t-r*r)/(2*e*t))}function Se(e){return e-2*b*c((e+b)/(2*b))}function Ae(e,t,r){for(var n,i=[[e[0],e[1],g(e[1]),s(e[1])],[t[0],t[1],g(t[1]),s(t[1])],[r[0],r[1],g(r[1]),s(r[1])]],o=i[2],a=0;a<3;++a,o=n)n=i[a],o.v=we(n[1]-o[1],o[3],o[2],n[3],n[2],n[0]-o[0]),o.point=[0,0];var l=ke(i[0].v[0],i[2].v[0],i[1].v[0]),c=ke(i[0].v[0],i[1].v[0],i[2].v[0]),u=b-l;i[2].point[1]=0,i[0].point[0]=-(i[1].point[0]=i[0].v[0]/2);var d=[i[2].point[0]=i[0].point[0]+i[2].v[0]*s(l),2*(i[0].point[1]=i[1].point[1]=i[2].v[0]*g(l))];return function(e,t){var r,n=g(t),o=s(t),a=new Array(3);for(r=0;r<3;++r){var l=i[r];if(a[r]=we(t-l[1],l[3],l[2],o,n,e-l[0]),!a[r][0])return l.point;a[r][1]=Se(a[r][1]-l.v[1])}var h=d.slice();for(r=0;r<3;++r){var p=2==r?0:r+1,f=ke(i[r].v[0],a[r][0],a[p][0]);a[r][1]<0&&(f=-f),r?1==r?(f=c-f,h[0]-=a[r][0]*s(f),h[1]-=a[r][0]*g(f)):(f=u-f,h[0]+=a[r][0]*s(f),h[1]+=a[r][0]*g(f)):(h[0]+=a[r][0]*s(f),h[1]-=a[r][0]*g(f))}return h[0]/=3,h[1]/=3,h}}function Te(e){return e[0]*=C,e[1]*=C,e}function Me(){return Ce([0,22],[45,22],[22.5,-22]).scale(380).center([22.5,2])}function Ce(e,t,r){var i=(0,be.A)({type:"MultiPoint",coordinates:[e,t,r]}),o=[-i[0],-i[1]],a=(0,_e.A)(o),s=Ae(Te(a(e)),Te(a(t)),Te(a(r)));s.invert=ee(s);var l=(0,n.A)(s).rotate(o),c=l.center;return delete l.rotate,l.center=function(e){return arguments.length?c(a(e)):a.invert(c())},l.clipAngle(90)}function Ee(e,t){var r=P(1-g(t));return[2/A*e*r,A*(1-r)]}function Ie(){return(0,n.A)(Ee).scale(95.6464).center([0,30])}function Pe(e){var t=y(e);function r(e,r){return[e,(e?e/g(e):1)*(g(r)*s(e)-t*s(r))]}return r.invert=t?function(e,r){e&&(r*=g(e)/e);var n=s(e);return[e,2*a(P(n*n+t*t-r*r)-n,t-r)]}:function(e,t){return[e,E(e?t*y(e)/e:t)]},r}function Oe(){return de(Pe).scale(249.828).clipAngle(90)}Ee.invert=function(e,t){var r=(r=t/A-1)*r;return[r>0?e*P(b/r)/2:0,E(1-r)]};var Re=P(3);function Le(e,t){return[Re*e*(2*s(2*t/3)-1)/A,Re*A*g(t/3)]}function De(){return(0,n.A)(Le).scale(156.19)}function ze(e){var t=s(e);function r(e,r){return[e*t,g(r)/t]}return r.invert=function(e,r){return[e/t,E(r*t)]},r}function je(){return de(ze).parallel(38.58).scale(195.044)}function Fe(e){var t=s(e);function r(e,r){return[e*t,(1+t)*y(r/2)]}return r.invert=function(e,r){return[e/t,2*o(r/(1+t))]},r}function Ne(){return de(Fe).scale(124.75)}function Be(e,t){var r=P(8/(3*b));return[r*e*(1-i(t)/b),r*t]}function Ve(){return(0,n.A)(Be).scale(165.664)}function Ue(e,t){var r=P(4-3*g(i(t)));return[2/P(6*b)*e*r,m(t)*P(2*b/3)*(2-r)]}function He(){return(0,n.A)(Ue).scale(165.664)}function $e(e,t){var r=P(b*(4+b));return[2/r*e*(1+P(1-4*t*t/(b*b))),4/r*t]}function We(){return(0,n.A)($e).scale(180.739)}function qe(e,t){var r=(2+_)*g(t);t/=2;for(var n=0,o=1/0;n<10&&i(o)>v;n++){var a=s(t);t-=o=(t+g(t)*(a+2)-r)/(2*a*(1+a))}return[2/P(b*(4+b))*e*(1+s(t)),2*P(b/(4+b))*g(t)]}function Ge(){return(0,n.A)(qe).scale(180.739)}function Ye(e,t){return[e*(1+s(t))/P(2+b),2*t/P(2+b)]}function Xe(){return(0,n.A)(Ye).scale(173.044)}function Ze(e,t){for(var r=(1+_)*g(t),n=0,o=1/0;n<10&&i(o)>v;n++)t-=o=(t+g(t)-r)/(1+s(t));return r=P(2+b),[e*(1+s(t))/r,2*t/r]}function Ke(){return(0,n.A)(Ze).scale(173.044)}Le.invert=function(e,t){var r=3*E(t/(Re*A));return[A*e/(Re*(2*s(2*r/3)-1)),r]},Be.invert=function(e,t){var r=P(8/(3*b)),n=t/r;return[e/(r*(1-i(n)/b)),n]},Ue.invert=function(e,t){var r=2-i(t)/P(2*b/3);return[e*P(6*b)/(2*r),m(t)*E((4-r*r)/3)]},$e.invert=function(e,t){var r=P(b*(4+b))/2;return[e*r/(1+P(1-t*t*(4+b)/(4*b))),t*r/2]},qe.invert=function(e,t){var r=t*P((4+b)/b)/2,n=E(r),i=s(n);return[e/(2/P(b*(4+b))*(1+i)),E((n+r*(i+2))/(2+_))]},Ye.invert=function(e,t){var r=P(2+b),n=t*r/2;return[r*e/(1+s(n)),n]},Ze.invert=function(e,t){var r=1+_,n=P(r/2);return[2*e*n/(1+s(t*=n)),E((t+g(t))/r)]};var Je=3+2*S;function Qe(e,t){var r=g(e/=2),n=s(e),i=P(s(t)),a=s(t/=2),l=g(t)/(a+S*n*i),c=P(2/(1+l*l)),d=P((S*a+(n+r)*i)/(S*a+(n-r)*i));return[Je*(c*(d-1/d)-2*u(d)),Je*(c*l*(d+1/d)-2*o(l))]}function et(){return(0,n.A)(Qe).scale(62.5271)}Qe.invert=function(e,t){if(!(r=B.invert(e/1.2,1.065*t)))return null;var r,n=r[0],a=r[1],l=20;e/=Je,t/=Je;do{var c=n/2,p=a/2,f=g(c),m=s(c),y=g(p),x=s(p),b=s(a),w=P(b),A=y/(x+S*m*w),T=A*A,M=P(2/(1+T)),C=(S*x+(m+f)*w)/(S*x+(m-f)*w),E=P(C),I=E-1/E,O=E+1/E,R=M*I-2*u(E)-e,L=M*A*O-2*o(A)-t,D=y&&k*w*f*T/y,z=(S*m*x+w)/(2*(x+S*m*w)*(x+S*m*w)*w),j=-.5*A*M*M*M,F=j*D,N=j*z,V=(V=2*x+S*w*(m-f))*V*E,U=(S*m*x*w+b)/V,H=-S*f*y/(w*V),$=I*F-2*U/E+M*(U+U/C),W=I*N-2*H/E+M*(H+H/C),q=A*O*F-2*D/(1+T)+M*O*D+M*A*(U-U/C),G=A*O*N-2*z/(1+T)+M*O*z+M*A*(H-H/C),Y=W*q-G*$;if(!Y)break;var X=(L*W-R*G)/Y,Z=(R*q-L*$)/Y;n-=X,a=d(-_,h(_,a-Z))}while((i(X)>v||i(Z)>v)&&--l>0);return i(i(a)-_)n){var h=P(d),p=a(u,c),m=r*f(p/r),y=p-m,x=e*s(y),w=(e*g(y)-y*g(x))/(_-x),k=ft(y,w),S=(b-e)/mt(k,x,b);c=h;var A,T=50;do{c-=A=(e+mt(k,x,c)*S-h)/(k(c)*S)}while(i(A)>v&&--T>0);u=y*g(c),c<_&&(u-=w*(c-_));var M=g(m),C=s(m);l[0]=c*C-u*M,l[1]=c*M+u*C}return l}return o.invert=function(t,o){var l=t*t+o*o;if(l>n){var c=P(l),u=a(o,t),d=r*f(u/r),h=u-d;t=c*s(h),o=c*g(h);for(var p=t-_,m=g(t),y=o/m,v=t<_?1/0:0,w=10;;){var k=e*g(y),S=e*s(y),A=g(S),T=_-S,M=(k-y*A)/T,C=ft(y,M);if(i(v)v||i(p)>v)&&--y>0);return[f,m]},u}var vt=yt(2.8284,-1.6988,.75432,-.18071,1.76003,-.38914,.042555);function xt(){return(0,n.A)(vt).scale(149.995)}var bt=yt(2.583819,-.835827,.170354,-.038094,1.543313,-.411435,.082742);function _t(){return(0,n.A)(bt).scale(153.93)}var wt=yt(5/6*b,-.62636,-.0344,0,1.3493,-.05524,0,.045);function kt(){return(0,n.A)(wt).scale(130.945)}function St(e,t){var r=e*e,n=t*t;return[e*(1-.162388*n)*(.87-952426e-9*r*r),t*(1+n/12)]}function At(){return(0,n.A)(St).scale(131.747)}St.invert=function(e,t){var r,n=e,o=t,a=50;do{var s=o*o;o-=r=(o*(1+s/12)-t)/(1+s/4)}while(i(r)>v&&--a>0);a=50,e/=1-.162388*s;do{var l=(l=n*n)*l;n-=r=(n*(.87-952426e-9*l)-e)/(.87-.00476213*l)}while(i(r)>v&&--a>0);return[n,o]};var Tt=yt(2.6516,-.76534,.19123,-.047094,1.36289,-.13965,.031762);function Mt(){return(0,n.A)(Tt).scale(131.087)}function Ct(e){var t=e(_,0)[0]-e(-_,0)[0];function r(r,n){var i=r>0?-.5:.5,o=e(r+i*b,n);return o[0]-=i*t,o}return e.invert&&(r.invert=function(r,n){var i=r>0?-.5:.5,o=e.invert(r+i*t,n),a=o[0]-i*b;return a<-b?a+=2*b:a>b&&(a-=2*b),o[0]=a,o}),r}function Et(e,t){var r=m(e),n=m(t),o=s(t),l=s(e)*o,c=g(e)*o,u=g(n*t);e=i(a(c,u)),t=E(l),i(e-_)>v&&(e%=_);var d=function(e,t){if(t===_)return[0,0];var r,n,o=g(t),a=o*o,l=a*a,c=1+l,u=1+3*l,d=1-l,h=E(1/P(c)),p=d+a*c*h,f=(1-o)/p,m=P(f),y=f*c,x=P(y),w=m*d;if(0===e)return[0,-(w+a*x)];var k,S=s(t),A=1/S,T=2*o*S,M=(-3*a+h*u)*T,C=(-p*S-(1-o)*M)/(p*p),I=a*c*C+f*u*T,O=-A*T,R=-A*I,L=-2*A*(d*(.5*C/m)-2*a*m*T),D=4*e/b;if(e>.222*b||t.175*b){if(r=(w+a*P(y*(1+l)-w*w))/(1+l),e>b/4)return[r,r];var z=r,j=.5*r;r=.5*(j+z),n=50;do{var F=r*(L+O*P(y-r*r))+R*E(r/x)-D;if(!F)break;F<0?j=r:z=r,r=.5*(j+z)}while(i(z-j)>v&&--n>0)}else{r=v,n=25;do{var N=r*r,B=P(y-N),V=L+O*B,U=r*V+R*E(r/x)-D;r-=k=B?U/(V+(R-O*N)/B):0}while(i(k)>v&&--n>0)}return[r,-w-a*P(y-r*r)]}(e>b/4?_-e:e,t);return e>b/4&&(u=d[0],d[0]=-d[1],d[1]=-u),d[0]*=r,d[1]*=-n,d}function It(){return(0,n.A)(Ct(Et)).scale(239.75)}function Pt(e,t){var r,n,a,c,u,d;if(t=1-v)return r=(1-t)/4,a=1/(n=R(e)),[(c=((d=l(2*(d=e)))-1)/(d+1))+r*((u=n*O(e))-e)/(n*n),a-r*c*a*(u-e),a+r*c*a*(u+e),2*o(l(e))-_+r*(u-e)/n];var h=[1,0,0,0,0,0,0,0,0],p=[P(t),0,0,0,0,0,0,0,0],f=0;for(n=P(1-t),u=1;i(p[f]/h[f])>v&&f<8;)r=h[f++],p[f]=(r-n)/2,h[f]=(r+n)/2,n=P(r*n),u*=2;a=u*h[f]*e;do{a=(E(c=p[f]*g(n=a)/h[f])+a)/2}while(--f);return[g(a),c=s(a),c/s(a-n),a]}function Ot(e,t){if(!t)return e;if(1===t)return u(y(e/2+w));for(var r=1,n=P(1-t),a=P(t),s=0;i(a)>v;s++){if(e%b){var l=o(n*y(e)/r);l<0&&(l+=b),e+=l+~~(e/b)*b}else e+=e;a=(r+n)/2,n=P(r*n),a=((r=a)-n)/2}return e/(p(2,s)*r)}function Rt(e,t){var r=(S-1)/(S+1),n=P(1-r*r),c=Ot(_,n*n),d=u(y(b/4+i(t)/2)),h=l(-1*d)/P(r),p=function(e,t){var r=e*e,n=t+1,i=1-r-t*t;return[.5*((e>=0?_:-_)-a(i,2*e)),-.25*u(i*i+4*r)+.5*u(n*n+r)]}(h*s(-1*e),h*g(-1*e)),f=function(e,t,r){var n=i(e),a=O(i(t));if(n){var s=1/g(n),l=1/(y(n)*y(n)),c=-(l+r*(a*a*s*s)-1+r),u=(-c+P(c*c-(r-1)*l*4))/2;return[Ot(o(1/P(u)),r)*m(e),Ot(o(P((u/l-1)/r)),1-r)*m(t)]}return[0,Ot(o(a),1-r)*m(t)]}(p[0],p[1],n*n);return[-f[1],(t>=0?1:-1)*(.5*c-f[0])]}function Lt(){return(0,n.A)(Ct(Rt)).scale(151.496)}Et.invert=function(e,t){i(e)>1&&(e=2*m(e)-e),i(t)>1&&(t=2*m(t)-t);var r=m(e),n=m(t),o=-r*e,l=-n*t,c=l/o<1,u=function(e,t){var r=0,n=1,o=.5,a=50;for(;;){var l=o*o,c=P(o),u=E(1/P(1+l)),d=1-l+o*(1+l)*u,h=(1-c)/d,p=P(h),f=h*(1+l),m=p*(1-l),g=P(f-e*e),y=t+m+o*g;if(i(n-r)0?r=o:n=o,o=.5*(r+n)}if(!a)return null;var v=E(c),_=s(v),w=1/_,k=2*c*_,S=(-d*_-(-3*o+u*(1+3*l))*k*(1-c))/(d*d),A=.5*S/p,T=(1-l)*A-2*o*p*k;return[b/4*(e*(-2*w*T+-w*k*g)+-w*(o*(1+l)*S+h*(1+3*l)*k)*E(e/P(f))),v]}(c?l:o,c?o:l),d=u[0],h=u[1],p=s(h);return c&&(d=-_-d),[r*(a(g(d)*p,-g(h))+b),n*E(s(d)*p)]},Rt.invert=function(e,t){var r=(S-1)/(S+1),n=P(1-r*r),i=function(e,t,r){var n,i,o;return e?(n=Pt(e,r),t?(o=(i=Pt(t,1-r))[1]*i[1]+r*n[0]*n[0]*i[0]*i[0],[[n[0]*i[2]/o,n[1]*n[2]*i[0]*i[1]/o],[n[1]*i[1]/o,-n[0]*n[2]*i[0]*i[2]/o],[n[2]*i[1]*i[2]/o,-r*n[0]*n[1]*i[0]/o]]):[[n[0],0],[n[1],0],[n[2],0]]):[[0,(i=Pt(t,1-r))[0]/i[1]],[1/i[1],0],[i[2]/i[1],0]]}(.5*Ot(_,n*n)-t,-e,n*n),s=function(e,t){var r=t[0]*t[0]+t[1]*t[1];return[(e[0]*t[0]+e[1]*t[1])/r,(e[1]*t[0]-e[0]*t[1])/r]}(i[0],i[1]);return[a(s[1],s[0])/-1,2*o(l(-.5*u(r*s[0]*s[0]+r*s[1]*s[1])))-_]};var Dt=r(28236);function zt(e){var t=g(e),r=s(e),n=jt(e);function o(e,o){var a=n(e,o);e=a[0],o=a[1];var l=g(o),c=s(o),u=s(e),d=I(t*l+r*c*u),h=g(d),p=i(h)>v?d/h:1;return[p*r*g(e),(i(e)>_?p:-p)*(t*c-r*l*u)]}return n.invert=jt(-e),o.invert=function(e,r){var i=P(e*e+r*r),o=-g(i),l=s(i),c=i*l,u=-r*o,d=i*t,h=P(c*c+u*u-d*d),p=a(c*d+u*h,u*d-c*h),f=(i>_?-1:1)*a(e*o,i*s(p)*l+r*g(p)*o);return n.invert(f,p)},o}function jt(e){var t=g(e),r=s(e);return function(e,n){var i=s(n),o=s(e)*i,l=g(e)*i,c=g(n);return[a(l,o*r-c*t),E(c*r+o*t)]}}function Ft(){var e=0,t=(0,n.U)(zt),r=t(e),i=r.rotate,o=r.stream,a=(0,Dt.A)();return r.parallel=function(n){if(!arguments.length)return e*M;var i=r.rotate();return t(e=n*C).rotate(i)},r.rotate=function(t){return arguments.length?(i.call(r,[t[0],t[1]-e*M]),a.center([-t[0],-t[1]]),r):((t=i.call(r))[1]+=e*M,t)},r.stream=function(e){return(e=o(e)).sphere=function(){e.polygonStart();var t,r=a.radius(89.99)().coordinates[0],n=r.length-1,i=-1;for(e.lineStart();++i=0;)e.point((t=r[i])[0],t[1]);e.lineEnd(),e.polygonEnd()},e},r.scale(79.4187).parallel(45).clipAngle(179.999)}var Nt=r(35529),Bt=r(1082),Vt=E(1-1/3)*M,Ut=ze(0);function Ht(e){var t=Vt*C,r=Ee(b,t)[0]-Ee(-b,t)[0],n=Ut(0,t)[1],o=Ee(0,t)[1],a=A-o,s=T/e,l=4/T,u=n+a*a*4/T;function p(p,f){var m,g=i(f);if(g>t){var y=h(e-1,d(0,c((p+b)/s)));(m=Ee(p+=b*(e-1)/e-y*s,g))[0]=m[0]*T/r-T*(e-1)/(2*e)+y*T/e,m[1]=n+4*(m[1]-o)*a/T,f<0&&(m[1]=-m[1])}else m=Ut(p,f);return m[0]*=l,m[1]/=u,m}return p.invert=function(t,p){t/=l;var f=i(p*=u);if(f>n){var m=h(e-1,d(0,c((t+b)/s)));t=(t+b*(e-1)/e-m*s)*r/T;var g=Ee.invert(t,.25*(f-n)*T/a+o);return g[0]-=b*(e-1)/e-m*s,p<0&&(g[1]=-g[1]),g}return Ut.invert(t,p)},p}function $t(e,t){return[e,1&t?90-v:Vt]}function Wt(e,t){return[e,1&t?-90+v:-Vt]}function qt(e){return[e[0]*(1-v),e[1]]}function Gt(){var e=4,t=(0,n.U)(Ht),r=t(e),i=r.stream;return r.lobes=function(r){return arguments.length?t(e=+r):e},r.stream=function(t){var n=r.rotate(),o=i(t),a=(r.rotate([0,0]),i(t));return r.rotate(n),o.sphere=function(){(0,Bt.A)(function(e){var t=[].concat((0,Nt.y1)(-180,180+e/2,e).map($t),(0,Nt.y1)(180,-180-e/2,-e).map(Wt));return{type:"Polygon",coordinates:[180===e?t.map(qt):t]}}(180/e),a)},o},r.scale(239.75)}function Yt(e){var t,r=1+e,n=E(g(1/r)),o=2*P(b/(t=b+4*n*r)),l=.5*o*(r+P(e*(2+e))),c=e*e,u=r*r;function d(d,h){var p,f,m=1-g(h);if(m&&m<2){var y,v=_-h,w=25;do{var k=g(v),S=s(v),A=n+a(k,r-S),T=1+u-2*r*S;v-=y=(v-c*n-r*k+T*A-.5*m*t)/(2*r*k*A)}while(i(y)>x&&--w>0);p=o*P(T),f=d*A/b}else p=o*(e+m),f=d*n/b;return[p*g(f),l-p*s(f)]}return d.invert=function(e,i){var s=e*e+(i-=l)*i,d=(1+u-s/(o*o))/(2*r),h=I(d),p=g(h),f=n+a(p,r-d);return[E(e/P(s))*b/f,E(1-2*(h-c*n-r*p+(1+u-2*r*d)*f)/t)]},d}function Xt(){var e=1,t=(0,n.U)(Yt),r=t(e);return r.ratio=function(r){return arguments.length?t(e=+r):e},r.scale(167.774).center([0,18.67])}var Zt=.7109889596207567,Kt=.0528035274542;function Jt(e,t){return t>-Zt?((e=oe(e,t))[1]+=Kt,e):he(e,t)}function Qt(){return(0,n.A)(Jt).rotate([-20,-55]).scale(164.263).center([0,-5.4036])}function er(e,t){return i(t)>Zt?((e=oe(e,t))[1]-=t>0?Kt:-Kt,e):he(e,t)}function tr(){return(0,n.A)(er).scale(152.63)}function rr(e,t,r,n){var i=P(4*b/(2*r+(1+e-t/2)*g(2*r)+(e+t)/2*g(4*r)+t/2*g(6*r))),o=P(n*g(r)*P((1+e*s(2*r)+t*s(4*r))/(1+e+t))),a=r*c(1);function l(r){return P(1+e*s(2*r)+t*s(4*r))}function c(n){var i=n*r;return(2*i+(1+e-t/2)*g(2*i)+(e+t)/2*g(4*i)+t/2*g(6*i))/r}function u(e){return l(e)*g(e)}var d=function(e,t){var n=r*Q(c,a*g(t)/r,t/b);isNaN(n)&&(n=r*m(t));var u=i*l(n);return[u*o*e/b*s(n),u/o*g(n)]};return d.invert=function(e,t){var n=Q(u,t*o/i);return[e*b/(s(n)*i*o*l(n)),E(r*c(n/r)/a)]},0===r&&(i=P(n/b),(d=function(e,t){return[e*i,g(t)/i]}).invert=function(e,t){return[e/i,E(t*i)]}),d}function nr(){var e=1,t=0,r=45*C,i=2,o=(0,n.U)(rr),a=o(e,t,r,i);return a.a=function(n){return arguments.length?o(e=+n,t,r,i):e},a.b=function(n){return arguments.length?o(e,t=+n,r,i):t},a.psiMax=function(n){return arguments.length?o(e,t,r=+n*C,i):r*M},a.ratio=function(n){return arguments.length?o(e,t,r,i=+n):i},a.scale(180.739)}function ir(e,t,r,n,i,o,a,s,l,c,u){if(u.nanEncountered)return NaN;var d,h,p,f,m,g,y,v,x,b;if(h=e(t+.25*(d=r-t)),p=e(r-.25*d),isNaN(h))u.nanEncountered=!0;else{if(!isNaN(p))return b=((g=(f=d*(n+4*h+i)/12)+(m=d*(i+4*p+o)/12))-a)/15,c>l?(u.maxDepthCount++,g+b):Math.abs(b)e?r=n:t=n,n=t+r>>1}while(n>t);var i=c[n+1]-c[n];return i&&(i=(e-c[n+1])/i),(n+1+i)/s}var h=2*d(1)/b*a/r,f=function(e,t){var r=d(i(g(t))),o=n(r)*e;return r/=h,[o,t>=0?r:-r]};return f.invert=function(e,t){var r;return i(t*=h)<1&&(r=m(t)*E(o(i(t))*a)),[e/n(i(t)),r]},f}function sr(){var e=0,t=2.5,r=1.183136,i=(0,n.U)(ar),o=i(e,t,r);return o.alpha=function(n){return arguments.length?i(e=+n,t,r):e},o.k=function(n){return arguments.length?i(e,t=+n,r):t},o.gamma=function(n){return arguments.length?i(e,t,r=+n):r},o.scale(152.63)}function lr(e,t){return i(e[0]-t[0])o[a][2][0];++a);var l=e(r-o[a][1][0],n);return l[0]+=e(o[a][1][0],i*n>i*o[a][0][1]?o[a][0][1]:n)[0],l}r?a.invert=r(a):e.invert&&(a.invert=function(r,n){for(var i=o[+(n<0)],s=t[+(n<0)],l=0,c=i.length;l=0;--s)r=(t=e[1][s])[0][0],n=t[0][1],i=t[1][1],o=t[2][0],a=t[2][1],l.push(cr([[o-v,a-v],[o-v,i+v],[r+v,i+v],[r+v,n-v]],30));return{type:"Polygon",coordinates:[(0,Nt.Am)(l)]}}(r),t=r.map((function(e){return e.map((function(e){return[[e[0][0]*C,e[0][1]*C],[e[1][0]*C,e[1][1]*C],[e[2][0]*C,e[2][1]*C]]}))})),o=t.map((function(t){return t.map((function(t){var r,n=e(t[0][0],t[0][1])[0],i=e(t[2][0],t[2][1])[0],o=e(t[1][0],t[0][1])[1],a=e(t[1][0],t[1][1])[1];return o>a&&(r=o,o=a,a=r),[[n,o],[i,a]]}))})),s):t.map((function(e){return e.map((function(e){return[[e[0][0]*M,e[0][1]*M],[e[1][0]*M,e[1][1]*M],[e[2][0]*M,e[2][1]*M]]}))}))},null!=t&&s.lobes(t),s}Jt.invert=function(e,t){return t>-Zt?oe.invert(e,t-Kt):he.invert(e,t)},er.invert=function(e,t){return i(t)>Zt?oe.invert(e,t+(t>0?Kt:-Kt)):he.invert(e,t)};var dr=[[[[-180,0],[-100,90],[-40,0]],[[-40,0],[30,90],[180,0]]],[[[-180,0],[-160,-90],[-100,0]],[[-100,0],[-60,-90],[-20,0]],[[-20,0],[20,-90],[80,0]],[[80,0],[140,-90],[180,0]]]];function hr(){return ur(ce,dr).scale(160.857)}var pr=[[[[-180,0],[-100,90],[-40,0]],[[-40,0],[30,90],[180,0]]],[[[-180,0],[-160,-90],[-100,0]],[[-100,0],[-60,-90],[-20,0]],[[-20,0],[20,-90],[80,0]],[[80,0],[140,-90],[180,0]]]];function fr(){return ur(er,pr).scale(152.63)}var mr=[[[[-180,0],[-100,90],[-40,0]],[[-40,0],[30,90],[180,0]]],[[[-180,0],[-160,-90],[-100,0]],[[-100,0],[-60,-90],[-20,0]],[[-20,0],[20,-90],[80,0]],[[80,0],[140,-90],[180,0]]]];function gr(){return ur(oe,mr).scale(169.529)}var yr=[[[[-180,0],[-90,90],[0,0]],[[0,0],[90,90],[180,0]]],[[[-180,0],[-90,-90],[0,0]],[[0,0],[90,-90],[180,0]]]];function vr(){return ur(oe,yr).scale(169.529).rotate([20,0])}var xr=[[[[-180,35],[-30,90],[0,35]],[[0,35],[30,90],[180,35]]],[[[-180,-10],[-102,-90],[-65,-10]],[[-65,-10],[5,-90],[77,-10]],[[77,-10],[103,-90],[180,-10]]]];function br(){return ur(Jt,xr,ee).rotate([-20,-55]).scale(164.263).center([0,-5.4036])}var _r=[[[[-180,0],[-110,90],[-40,0]],[[-40,0],[0,90],[40,0]],[[40,0],[110,90],[180,0]]],[[[-180,0],[-110,-90],[-40,0]],[[-40,0],[0,-90],[40,0]],[[40,0],[110,-90],[180,0]]]];function wr(){return ur(he,_r).scale(152.63).rotate([-20,0])}function kr(e,t){return[3/T*e*P(b*b/3-t*t),t]}function Sr(){return(0,n.A)(kr).scale(158.837)}function Ar(e){function t(t,r){if(i(i(r)-_)2)return null;var o=(t/=2)*t,s=(r/=2)*r,l=2*r/(1+o+s);return l=p((1+l)/(1-l),1/e),[a(2*t,1-o-s)/e,E((l-1)/(l+1))]},t}function Tr(){var e=.5,t=(0,n.U)(Ar),r=t(e);return r.spacing=function(r){return arguments.length?t(e=+r):e},r.scale(124.75)}kr.invert=function(e,t){return[T/3*e/P(b*b/3-t*t),t]};var Mr=b/S;function Cr(e,t){return[e*(1+P(s(t)))/2,t/(s(t/2)*s(e/6))]}function Er(){return(0,n.A)(Cr).scale(97.2672)}function Ir(e,t){var r=e*e,n=t*t;return[e*(.975534+n*(-.0143059*r-.119161+-.0547009*n)),t*(1.00384+r*(.0802894+-.02855*n+199025e-9*r)+n*(.0998909+-.0491032*n))]}function Pr(){return(0,n.A)(Ir).scale(139.98)}function Or(e,t){return[g(e)/s(t),y(t)*s(e)]}function Rr(){return(0,n.A)(Or).scale(144.049).clipAngle(89.999)}function Lr(e){var t=s(e),r=y(w+e/2);function n(n,o){var a=o-e,s=i(a)=0;)h=(d=e[u])[0]+l*(i=h)-c*p,p=d[1]+l*p+c*i;return[h=l*(i=h)-c*p,p=l*p+c*i]}return r.invert=function(r,n){var l=20,c=r,u=n;do{for(var d,h=t,p=e[h],f=p[0],m=p[1],y=0,x=0;--h>=0;)y=f+c*(d=y)-u*x,x=m+c*x+u*d,f=(p=e[h])[0]+c*(d=f)-u*m,m=p[1]+c*m+u*d;var b,_,w=(y=f+c*(d=y)-u*x)*y+(x=m+c*x+u*d)*x;c-=b=((f=c*(d=f)-u*m-r)*y+(m=c*m+u*d-n)*x)/w,u-=_=(m*y-f*x)/w}while(i(b)+i(_)>v*v&&--l>0);if(l){var k=P(c*c+u*u),S=2*o(.5*k),A=g(S);return[a(c*A,k*s(S)),k?E(u*A/k):0]}},r}Cr.invert=function(e,t){var r=i(e),n=i(t),o=v,a=_;nv||i(x)>v)&&--o>0);return o&&[r,n]},Or.invert=function(e,t){var r=e*e,n=t*t+1,i=r+n,o=e?k*P((i-P(i*i-4*r))/r):1/P(n);return[E(e*o),m(t)*I(o)]},zr.invert=function(e,t){return[e,2.5*o(l(.8*t))-.625*b]};var Nr=[[.9972523,0],[.0052513,-.0041175],[.0074606,.0048125],[-.0153783,-.1968253],[.0636871,-.1408027],[.3660976,-.2937382]],Br=[[.98879,0],[0,0],[-.050909,0],[0,0],[.075528,0]],Vr=[[.984299,0],[.0211642,.0037608],[-.1036018,-.0575102],[-.0329095,-.0320119],[.0499471,.1223335],[.026046,.0899805],[7388e-7,-.1435792],[.0075848,-.1334108],[-.0216473,.0776645],[-.0225161,.0853673]],Ur=[[.9245,0],[0,0],[.01943,0]],Hr=[[.721316,0],[0,0],[-.00881625,-.00617325]];function $r(){return Xr(Nr,[152,-64]).scale(1400).center([-160.908,62.4864]).clipAngle(30).angle(7.8)}function Wr(){return Xr(Br,[95,-38]).scale(1e3).clipAngle(55).center([-96.5563,38.8675])}function qr(){return Xr(Vr,[120,-45]).scale(359.513).clipAngle(55).center([-117.474,53.0628])}function Gr(){return Xr(Ur,[-20,-18]).scale(209.091).center([20,16.7214]).clipAngle(82)}function Yr(){return Xr(Hr,[165,10]).scale(250).clipAngle(130).center([-165,-10])}function Xr(e,t){var r=(0,n.A)(Fr(e)).rotate(t).clipAngle(90),i=(0,_e.A)(t),o=r.center;return delete r.rotate,r.center=function(e){return arguments.length?o(i(e)):i.invert(o())},r}var Zr=P(6),Kr=P(7);function Jr(e,t){var r=E(7*g(t)/(3*Zr));return[Zr*e*(2*s(2*r/3)-1)/Kr,9*g(r/3)/Kr]}function Qr(){return(0,n.A)(Jr).scale(164.859)}function en(e,t){for(var r,n=(1+k)*g(t),o=t,a=0;a<25&&(o-=r=(g(o/2)+g(o)-n)/(.5*s(o/2)+s(o)),!(i(r)x&&--l>0);return[e/(.84719-.13063*(n=s*s)+(a=n*(o=n*n))*a*(.05494*n-.04515-.02326*o+.00331*a)),s]},ln.invert=function(e,t){for(var r=t/2,n=0,o=1/0;n<10&&i(o)>v;++n){var a=s(t/2);t-=o=(t-y(t/2)-r)/(1-.5/(a*a))}return[2*e/(1+s(t)),t]};var un=[[[[-180,0],[-90,90],[0,0]],[[0,0],[90,90],[180,0]]],[[[-180,0],[-90,-90],[0,0]],[[0,0],[90,-90],[180,0]]]];function dn(){return ur(Z(1/0),un).rotate([20,0]).scale(152.63)}function hn(e,t){var r=g(t),n=s(t),o=m(e);if(0===e||i(t)===_)return[0,t];if(0===t)return[e,0];if(i(e)===_)return[e*n,_*r];var a=b/(2*e)-2*e/b,l=2*t/b,c=(1-l*l)/(r-l),u=a*a,d=c*c,h=1+u/d,p=1+d/u,f=(a*r/c-a/2)/h,y=(d*r/u+c/2)/p,v=y*y-(d*r*r/u+c*r-1)/p;return[_*(f+P(f*f+n*n/h)*o),_*(y+P(v<0?0:v)*m(-t*a)*o)]}function pn(){return(0,n.A)(hn).scale(127.267)}hn.invert=function(e,t){var r=(e/=_)*e,n=r+(t/=_)*t,i=b*b;return[e?(n-1+P((1-n)*(1-n)+4*r))/(2*e)*_:0,Q((function(e){return n*(b*g(e)-2*e)*b+4*e*e*(t-g(e))+2*b*e-i*t}),0)]};var fn=1.0148,mn=.23185,gn=-.14499,yn=.02406,vn=fn,xn=5*mn,bn=7*gn,_n=9*yn,wn=1.790857183;function kn(e,t){var r=t*t;return[e,t*(fn+r*r*(mn+r*(gn+yn*r)))]}function Sn(){return(0,n.A)(kn).scale(139.319)}function An(e,t){if(i(t)wn?t=wn:t<-1.790857183&&(t=-1.790857183);var r,n=t;do{var o=n*n;n-=r=(n*(fn+o*o*(mn+o*(gn+yn*o)))-t)/(vn+o*o*(xn+o*(bn+_n*o)))}while(i(r)>v);return[e,n]},An.invert=function(e,t){if(i(t)v&&--a>0);return l=y(o),[(i(t)=0;)if(n=t[s],r[0]===n[0]&&r[1]===n[1]){if(o)return[o,r];o=r}}}(t.face,r.face),i=En(n.map(r.project),n.map(t.project));t.transform=r.transform?In(r.transform,i):i;for(var o=r.edges,a=0,s=o.length;a0?[-t[0],0]:[180-t[0],180])};var t=Nn.map((function(t){return{face:t,project:e(t)}}));return[-1,0,0,1,0,1,4,5].forEach((function(e,r){var n=t[e];n&&(n.children||(n.children=[])).push(t[r])})),Rn(t[0],(function(e,r){return t[e<-b/2?r<0?6:4:e<0?r<0?2:0:en^p>n&&r<(h-c)*(n-u)/(p-u)+c&&(i=!i)}return i}(e[0],r))return e.push(t),!0}))||e.push([t])})),ei=[],e.length?e.length>1?{type:"MultiPolygon",coordinates:e}:{type:"Polygon",coordinates:e[0]}:null}};function ii(e){var t=e(_,0)[0]-e(-_,0)[0];function r(r,n){var o=i(r)<_,a=e(o?r:r>0?r-b:r+b,n),s=(a[0]-a[1])*k,l=(a[0]+a[1])*k;if(o)return[s,l];var c=t*k,u=s>0^l>0?-1:1;return[u*s-m(l)*c,u*l-m(s)*c]}return e.invert&&(r.invert=function(r,n){var o=(r+n)*k,a=(n-r)*k,s=i(o)<.5*t&&i(a)<.5*t;if(!s){var l=t*k,c=o>0^a>0?-1:1,u=-c*r+(a>0?1:-1)*l,d=-c*n+(o>0?1:-1)*l;o=(-u-d)*k,a=(u-d)*k}var h=e.invert(o,a);return s||(h[0]+=o>0?b:-b),h}),(0,n.A)(r).rotate([-90,-90,45]).clipAngle(179.999)}function oi(){return ii(Et).scale(176.423)}function ai(){return ii(Rt).scale(111.48)}function si(e,t){if(!(0<=(t=+t)&&t<=20))throw new Error("invalid digits");function r(e){var r=e.length,n=2,i=new Array(r);for(i[0]=+e[0].toFixed(t),i[1]=+e[1].toFixed(t);n2||o[0]!=t[0]||o[1]!=t[1])&&(n.push(o),t=o)}return 1===n.length&&e.length>1&&n.push(r(e[e.length-1])),n}function o(e){return e.map(i)}function a(e){if(null==e)return e;var t;switch(e.type){case"GeometryCollection":t={type:"GeometryCollection",geometries:e.geometries.map(a)};break;case"Point":t={type:"Point",coordinates:r(e.coordinates)};break;case"MultiPoint":t={type:e.type,coordinates:n(e.coordinates)};break;case"LineString":t={type:e.type,coordinates:i(e.coordinates)};break;case"MultiLineString":case"Polygon":t={type:e.type,coordinates:o(e.coordinates)};break;case"MultiPolygon":t={type:"MultiPolygon",coordinates:e.coordinates.map(o)};break;default:return e}return null!=e.bbox&&(t.bbox=e.bbox),t}function s(e){var t={type:"Feature",properties:e.properties,geometry:a(e.geometry)};return null!=e.id&&(t.id=e.id),null!=e.bbox&&(t.bbox=e.bbox),t}if(null!=e)switch(e.type){case"Feature":return s(e);case"FeatureCollection":var l={type:"FeatureCollection",features:e.features.map(s)};return null!=e.bbox&&(l.bbox=e.bbox),l;default:return a(e)}return e}function li(e){var t=g(e);function r(r,n){var i=t?y(r*t/2)/t:r/2;if(!n)return[2*i,-e];var a=2*o(i*g(n)),l=1/y(n);return[g(a)*l,n+(1-s(a))*l-e]}return r.invert=function(r,n){if(i(n+=e)v&&--u>0);var f=r*(d=y(c)),m=y(i(n)0?_:-_)*(d+a*(f-l)/2+a*a*(f-2*d+l)/2)]}function hi(){return(0,n.A)(di).scale(152.63)}function pi(e,t){var r=function(e){function t(t,r){var n=s(r),i=(e-1)/(e-n*s(t));return[i*n*g(t),i*g(r)]}return t.invert=function(t,r){var n=t*t+r*r,i=P(n),o=(e-P(1-n*(e+1)/(e-1)))/((e-1)/i+i/(e-1));return[a(t*o,i*P(1-o*o)),i?E(r*o/i):0]},t}(e);if(!t)return r;var n=s(t),i=g(t);function o(t,o){var a=r(t,o),s=a[1],l=s*i/(e-1)+n;return[a[0]*n/l,s/l]}return o.invert=function(t,o){var a=(e-1)/(e-1-o*i);return r.invert(a*t,a*o*n)},o}function fi(){var e=2,t=0,r=(0,n.U)(pi),i=r(e,t);return i.distance=function(n){return arguments.length?r(e=+n,t):e},i.tilt=function(n){return arguments.length?r(e,t=n*C):t*M},i.scale(432.147).clipAngle(I(1/e)*M-1e-6)}ui.forEach((function(e){e[1]*=1.0144})),di.invert=function(e,t){var r=t/_,n=90*r,o=h(18,i(n/5)),a=d(0,c(o));do{var s=ui[a][1],l=ui[a+1][1],u=ui[h(19,a+2)][1],p=u-s,f=u-2*l+s,m=2*(i(r)-l)/p,g=f/p,y=m*(1-g*m*(1-2*g*m));if(y>=0||1===a){n=(t>=0?5:-5)*(y+o);var v,b=50;do{y=(o=h(18,i(n)/5))-(a=c(o)),s=ui[a][1],l=ui[a+1][1],u=ui[h(19,a+2)][1],n-=(v=(t>=0?_:-_)*(l+y*(u-s)/2+y*y*(u-2*l+s)/2)-t)*M}while(i(v)>x&&--b>0);break}}while(--a>=0);var w=ui[a][0],k=ui[a+1][0],S=ui[h(19,a+2)][0];return[e/(k+y*(S-w)/2+y*y*(S-2*k+w)/2),n*C]};var mi=1e-4,gi=1e4,yi=-180,vi=yi+mi,xi=180,bi=xi-mi,_i=-90,wi=_i+mi,ki=90,Si=ki-mi;function Ai(e){return e.length>0}function Ti(e){return e===_i||e===ki?[0,e]:[yi,(t=e,Math.floor(t*gi)/gi)];var t}function Mi(e){var t=e[0],r=e[1],n=!1;return t<=vi?(t=yi,n=!0):t>=bi&&(t=xi,n=!0),r<=wi?(r=_i,n=!0):r>=Si&&(r=ki,n=!0),n?[t,r]:e}function Ci(e){return e.map(Mi)}function Ei(e,t,r){for(var n=0,i=e.length;n=bi||u<=wi||u>=Si){o[a]=Mi(l);for(var d=a+1;dvi&&pwi&&f=s)break;r.push({index:-1,polygon:t,ring:o=o.slice(d-1)}),o[0]=Ti(o[0][1]),a=-1,s=o.length}}}}function Ii(e){var t,r,n,i,o,a,s=e.length,l={},c={};for(t=0;t0?b-l:l)*M],u=(0,n.A)(e(s)).rotate(c),d=(0,_e.A)(c),h=u.center;return delete u.rotate,u.center=function(e){return arguments.length?h(d(e)):d.invert(h())},u.clipAngle(90)}function ji(e){var t=s(e);function r(e,r){var n=(0,jn.T)(e,r);return n[0]*=t,n}return r.invert=function(e,r){return jn.T.invert(e/t,r)},r}function Fi(){return Ni([-158,21.5],[-77,39]).clipAngle(60).scale(400)}function Ni(e,t){return zi(ji,e,t)}function Bi(e){if(!(e*=2))return q.j;var t=-e/2,r=-t,n=e*e,i=y(r),o=.5/g(r);function l(i,o){var a=I(s(o)*s(i-t)),l=I(s(o)*s(i-r));return[((a*=a)-(l*=l))/(2*e),(o<0?-1:1)*P(4*n*l-(n-a+l)*(n-a+l))/(2*e)]}return l.invert=function(e,n){var l,c,u=n*n,d=s(P(u+(l=e+t)*l)),h=s(P(u+(l=e+r)*l));return[a(c=d-h,l=(d+h)*i),(n<0?-1:1)*I(P(l*l+c*c)*o)]},l}function Vi(){return Ui([-158,21.5],[-77,39]).clipAngle(130).scale(122.571)}function Ui(e,t){return zi(Bi,e,t)}function Hi(e,t){if(i(t)v&&--l>0);return[m(e)*(P(o*o+4)+o)*b/4,_*s]};var eo=4*b+3*P(3),to=2*P(2*b*P(3)/eo),ro=ie(to*P(3)/b,to,eo/6);function no(){return(0,n.A)(ro).scale(176.84)}function io(e,t){return[e*P(1-3*t*t/(b*b)),t]}function oo(){return(0,n.A)(io).scale(152.63)}function ao(e,t){var r=s(t),n=s(e)*r,i=1-n,o=s(e=a(g(e)*r,-g(t))),l=g(e);return[l*(r=P(1-n*n))-o*i,-o*r-l*i]}function so(){return(0,n.A)(ao).rotate([0,-90,45]).scale(124.75).clipAngle(179.999)}function lo(e,t){var r=z(e,t);return[(r[0]+e/_)/2,(r[1]+t)/2]}function co(){return(0,n.A)(lo).scale(158.837)}io.invert=function(e,t){return[e/P(1-3*t*t/(b*b)),t]},ao.invert=function(e,t){var r=(e*e+t*t)/-2,n=P(-r*(2+r)),i=t*r+e*n,o=e*r-t*n,s=P(o*o+i*i);return[a(n*i,s*(1+r)),s?-E(n*o/s):0]},lo.invert=function(e,t){var r=e,n=t,o=25;do{var a,l=s(n),c=g(n),u=g(2*n),d=c*c,h=l*l,p=g(r),f=s(r/2),m=g(r/2),y=m*m,x=1-h*f*f,b=x?I(l*f)*P(a=1/x):a=0,w=.5*(2*b*l*m+r/_)-e,k=.5*(b*c+n)-t,S=.5*a*(h*y+b*l*f*d)+.5/_,A=a*(p*u/4-b*c*m),T=.125*a*(u*m-b*c*h*p),M=.5*a*(d*f+b*y*l)+.5,C=A*T-M*S,E=(k*A-w*M)/C,O=(w*T-k*S)/C;r-=E,n-=O}while((i(E)>v||i(O)>v)&&--o>0);return[r,n]}},80108:(e,t,r)=>{"use strict";function n(){return new i}function i(){this.reset()}r.d(t,{A:()=>n}),i.prototype={constructor:i,reset:function(){this.s=this.t=0},add:function(e){a(o,e,this.t),a(this,o.s,this.s),this.s?this.t+=o.t:this.s=o.t},valueOf:function(){return this.s}};var o=new i;function a(e,t,r){var n=e.s=t+r,i=n-t,o=n-i;e.t=t-o+(r-i)}},71791:(e,t,r)=>{"use strict";r.d(t,{Ay:()=>x,B0:()=>h,Y7:()=>f});var n,i,o,a,s,l=r(80108),c=r(85872),u=r(77026),d=r(1082),h=(0,l.A)(),p=(0,l.A)(),f={point:u.A,lineStart:u.A,lineEnd:u.A,polygonStart:function(){h.reset(),f.lineStart=m,f.lineEnd=g},polygonEnd:function(){var e=+h;p.add(e<0?c.FA+e:e),this.lineStart=this.lineEnd=this.point=u.A},sphere:function(){p.add(c.FA)}};function m(){f.point=y}function g(){v(n,i)}function y(e,t){f.point=v,n=e,i=t,e*=c.F2,t*=c.F2,o=e,a=(0,c.gn)(t=t/2+c.gz),s=(0,c.F8)(t)}function v(e,t){e*=c.F2,t=(t*=c.F2)/2+c.gz;var r=e-o,n=r>=0?1:-1,i=n*r,l=(0,c.gn)(t),u=(0,c.F8)(t),d=s*u,p=a*l+d*(0,c.gn)(i),f=d*n*(0,c.F8)(i);h.add((0,c.FP)(f,p)),o=e,a=l,s=u}function x(e){return p.reset(),(0,d.A)(e,f),2*p}},33115:(e,t,r)=>{"use strict";r.d(t,{A:()=>I});var n,i,o,a,s,l,c,u,d,h,p=r(80108),f=r(71791),m=r(74642),g=r(85872),y=r(1082),v=(0,p.A)(),x={point:b,lineStart:w,lineEnd:k,polygonStart:function(){x.point=S,x.lineStart=A,x.lineEnd=T,v.reset(),f.Y7.polygonStart()},polygonEnd:function(){f.Y7.polygonEnd(),x.point=b,x.lineStart=w,x.lineEnd=k,f.B0<0?(n=-(o=180),i=-(a=90)):v>g.Ni?a=90:v<-g.Ni&&(i=-90),h[0]=n,h[1]=o},sphere:function(){n=-(o=180),i=-(a=90)}};function b(e,t){d.push(h=[n=e,o=e]),ta&&(a=t)}function _(e,t){var r=(0,m.jf)([e*g.F2,t*g.F2]);if(u){var l=(0,m.r8)(u,r),c=[l[1],-l[0],0],p=(0,m.r8)(c,l);(0,m.Cx)(p),p=(0,m.EV)(p);var f,y=e-s,v=y>0?1:-1,x=p[0]*g.uj*v,b=(0,g.tn)(y)>180;b^(v*sa&&(a=f):b^(v*s<(x=(x+360)%360-180)&&xa&&(a=t)),b?eM(n,o)&&(o=e):M(e,o)>M(n,o)&&(n=e):o>=n?(eo&&(o=e)):e>s?M(n,e)>M(n,o)&&(o=e):M(e,o)>M(n,o)&&(n=e)}else d.push(h=[n=e,o=e]);ta&&(a=t),u=r,s=e}function w(){x.point=_}function k(){h[0]=n,h[1]=o,x.point=b,u=null}function S(e,t){if(u){var r=e-s;v.add((0,g.tn)(r)>180?r+(r>0?360:-360):r)}else l=e,c=t;f.Y7.point(e,t),_(e,t)}function A(){f.Y7.lineStart()}function T(){S(l,c),f.Y7.lineEnd(),(0,g.tn)(v)>g.Ni&&(n=-(o=180)),h[0]=n,h[1]=o,u=null}function M(e,t){return(t-=e)<0?t+360:t}function C(e,t){return e[0]-t[0]}function E(e,t){return e[0]<=e[1]?e[0]<=t&&t<=e[1]:tM(s[0],s[1])&&(s[1]=l[1]),M(l[0],s[1])>M(s[0],s[1])&&(s[0]=l[0])):c.push(s=l);for(u=-1/0,t=0,s=c[r=c.length-1];t<=r;s=l,++t)l=c[t],(p=M(s[1],l[0]))>u&&(u=p,n=l[0],o=s[1])}return d=h=null,n===1/0||i===1/0?[[NaN,NaN],[NaN,NaN]]:[[n,i],[o,a]]}},74642:(e,t,r)=>{"use strict";r.d(t,{Cx:()=>u,EV:()=>i,W8:()=>a,ep:()=>l,jf:()=>o,ly:()=>c,r8:()=>s});var n=r(85872);function i(e){return[(0,n.FP)(e[1],e[0]),(0,n.qR)(e[2])]}function o(e){var t=e[0],r=e[1],i=(0,n.gn)(r);return[i*(0,n.gn)(t),i*(0,n.F8)(t),(0,n.F8)(r)]}function a(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]}function s(e,t){return[e[1]*t[2]-e[2]*t[1],e[2]*t[0]-e[0]*t[2],e[0]*t[1]-e[1]*t[0]]}function l(e,t){e[0]+=t[0],e[1]+=t[1],e[2]+=t[2]}function c(e,t){return[e[0]*t,e[1]*t,e[2]*t]}function u(e){var t=(0,n.RZ)(e[0]*e[0]+e[1]*e[1]+e[2]*e[2]);e[0]/=t,e[1]/=t,e[2]/=t}},78746:(e,t,r)=>{"use strict";r.d(t,{A:()=>R});var n,i,o,a,s,l,c,u,d,h,p,f,m,g,y,v,x=r(85872),b=r(77026),_=r(1082),w={sphere:b.A,point:k,lineStart:A,lineEnd:C,polygonStart:function(){w.lineStart=E,w.lineEnd=I},polygonEnd:function(){w.lineStart=A,w.lineEnd=C}};function k(e,t){e*=x.F2,t*=x.F2;var r=(0,x.gn)(t);S(r*(0,x.gn)(e),r*(0,x.F8)(e),(0,x.F8)(t))}function S(e,t,r){++n,o+=(e-o)/n,a+=(t-a)/n,s+=(r-s)/n}function A(){w.point=T}function T(e,t){e*=x.F2,t*=x.F2;var r=(0,x.gn)(t);g=r*(0,x.gn)(e),y=r*(0,x.F8)(e),v=(0,x.F8)(t),w.point=M,S(g,y,v)}function M(e,t){e*=x.F2,t*=x.F2;var r=(0,x.gn)(t),n=r*(0,x.gn)(e),o=r*(0,x.F8)(e),a=(0,x.F8)(t),s=(0,x.FP)((0,x.RZ)((s=y*a-v*o)*s+(s=v*n-g*a)*s+(s=g*o-y*n)*s),g*n+y*o+v*a);i+=s,l+=s*(g+(g=n)),c+=s*(y+(y=o)),u+=s*(v+(v=a)),S(g,y,v)}function C(){w.point=k}function E(){w.point=P}function I(){O(f,m),w.point=k}function P(e,t){f=e,m=t,e*=x.F2,t*=x.F2,w.point=O;var r=(0,x.gn)(t);g=r*(0,x.gn)(e),y=r*(0,x.F8)(e),v=(0,x.F8)(t),S(g,y,v)}function O(e,t){e*=x.F2,t*=x.F2;var r=(0,x.gn)(t),n=r*(0,x.gn)(e),o=r*(0,x.F8)(e),a=(0,x.F8)(t),s=y*a-v*o,f=v*n-g*a,m=g*o-y*n,b=(0,x.RZ)(s*s+f*f+m*m),_=(0,x.qR)(b),w=b&&-_/b;d+=w*s,h+=w*f,p+=w*m,i+=_,l+=_*(g+(g=n)),c+=_*(y+(y=o)),u+=_*(v+(v=a)),S(g,y,v)}function R(e){n=i=o=a=s=l=c=u=d=h=p=0,(0,_.A)(e,w);var t=d,r=h,f=p,m=t*t+r*r+f*f;return m{"use strict";r.d(t,{J:()=>s,A:()=>c});var n=r(74642);function i(e){return function(){return e}}var o=r(85872),a=r(27520);function s(e,t,r,i,a,s){if(r){var c=(0,o.gn)(t),u=(0,o.F8)(t),d=i*r;null==a?(a=t+i*o.FA,s=t-d/2):(a=l(c,a),s=l(c,s),(i>0?as)&&(a+=i*o.FA));for(var h,p=a;i>0?p>s:p{"use strict";r.d(t,{A:()=>o});var n=r(54155),i=r(85872);const o=(0,n.A)((function(){return!0}),(function(e){var t,r=NaN,n=NaN,o=NaN;return{lineStart:function(){e.lineStart(),t=1},point:function(a,s){var l=a>0?i.pi:-i.pi,c=(0,i.tn)(a-r);(0,i.tn)(c-i.pi)0?i.TW:-i.TW),e.point(o,n),e.lineEnd(),e.lineStart(),e.point(l,n),e.point(a,n),t=0):o!==l&&c>=i.pi&&((0,i.tn)(r-o)i.Ni?(0,i.rY)(((0,i.F8)(t)*(a=(0,i.gn)(n))*(0,i.F8)(r)-(0,i.F8)(n)*(o=(0,i.gn)(t))*(0,i.F8)(e))/(o*a*s)):(t+n)/2}(r,n,a,s),e.point(o,n),e.lineEnd(),e.lineStart(),e.point(l,n),t=0),e.point(r=a,n=s),o=l},lineEnd:function(){e.lineEnd(),r=n=NaN},clean:function(){return 2-t}}}),(function(e,t,r,n){var o;if(null==e)o=r*i.TW,n.point(-i.pi,o),n.point(0,o),n.point(i.pi,o),n.point(i.pi,0),n.point(i.pi,-o),n.point(0,-o),n.point(-i.pi,-o),n.point(-i.pi,0),n.point(-i.pi,o);else if((0,i.tn)(e[0]-t[0])>i.Ni){var a=e[0]{"use strict";r.d(t,{A:()=>i});var n=r(77026);function i(){var e,t=[];return{point:function(t,r,n){e.push([t,r,n])},lineStart:function(){t.push(e=[])},lineEnd:n.A,rejoin:function(){t.length>1&&t.push(t.pop().concat(t.shift()))},result:function(){var r=t;return t=[],e=null,r}}}},50179:(e,t,r)=>{"use strict";r.d(t,{A:()=>l});var n=r(74642),i=r(28236),o=r(85872),a=r(55511),s=r(54155);function l(e){var t=(0,o.gn)(e),r=6*o.F2,l=t>0,c=(0,o.tn)(t)>o.Ni;function u(e,r){return(0,o.gn)(e)*(0,o.gn)(r)>t}function d(e,r,i){var a=(0,n.jf)(e),s=(0,n.jf)(r),l=[1,0,0],c=(0,n.r8)(a,s),u=(0,n.W8)(c,c),d=c[0],h=u-d*d;if(!h)return!i&&e;var p=t*u/h,f=-t*d/h,m=(0,n.r8)(l,c),g=(0,n.ly)(l,p),y=(0,n.ly)(c,f);(0,n.ep)(g,y);var v=m,x=(0,n.W8)(g,v),b=(0,n.W8)(v,v),_=x*x-b*((0,n.W8)(g,g)-1);if(!(_<0)){var w=(0,o.RZ)(_),k=(0,n.ly)(v,(-x-w)/b);if((0,n.ep)(k,g),k=(0,n.EV)(k),!i)return k;var S,A=e[0],T=r[0],M=e[1],C=r[1];T0^k[1]<((0,o.tn)(k[0]-A)o.pi^(A<=k[0]&&k[0]<=T)){var P=(0,n.ly)(v,(-x+w)/b);return(0,n.ep)(P,g),[k,(0,n.EV)(P)]}}}function h(t,r){var n=l?e:o.pi-e,i=0;return t<-n?i|=1:t>n&&(i|=2),r<-n?i|=4:r>n&&(i|=8),i}return(0,s.A)(u,(function(e){var t,r,n,i,s;return{lineStart:function(){i=n=!1,s=1},point:function(p,f){var m,g=[p,f],y=u(p,f),v=l?y?0:h(p,f):y?h(p+(p<0?o.pi:-o.pi),f):0;if(!t&&(i=n=y)&&e.lineStart(),y!==n&&(!(m=d(t,g))||(0,a.A)(t,m)||(0,a.A)(g,m))&&(g[2]=1),y!==n)s=0,y?(e.lineStart(),m=d(g,t),e.point(m[0],m[1])):(m=d(t,g),e.point(m[0],m[1],2),e.lineEnd()),t=m;else if(c&&t&&l^y){var x;v&r||!(x=d(g,t,!0))||(s=0,l?(e.lineStart(),e.point(x[0][0],x[0][1]),e.point(x[1][0],x[1][1]),e.lineEnd()):(e.point(x[1][0],x[1][1]),e.lineEnd(),e.lineStart(),e.point(x[0][0],x[0][1],3)))}!y||t&&(0,a.A)(t,g)||e.point(g[0],g[1]),t=g,n=y,r=v},lineEnd:function(){n&&e.lineEnd(),t=null},clean:function(){return s|(i&&n)<<1}}}),(function(t,n,o,a){(0,i.J)(a,e,r,o,t,n)}),l?[0,-e]:[-o.pi,e-o.pi])}},54155:(e,t,r)=>{"use strict";r.d(t,{A:()=>l});var n=r(41733),i=r(89326),o=r(85872),a=r(84935),s=r(35529);function l(e,t,r,o){return function(l){var d,h,p,f=t(l),m=(0,n.A)(),g=t(m),y=!1,v={point:x,lineStart:_,lineEnd:w,polygonStart:function(){v.point=k,v.lineStart=S,v.lineEnd=A,h=[],d=[]},polygonEnd:function(){v.point=x,v.lineStart=_,v.lineEnd=w,h=(0,s.Am)(h);var e=(0,a.A)(d,o);h.length?(y||(l.polygonStart(),y=!0),(0,i.A)(h,u,e,r,l)):e&&(y||(l.polygonStart(),y=!0),l.lineStart(),r(null,null,1,l),l.lineEnd()),y&&(l.polygonEnd(),y=!1),h=d=null},sphere:function(){l.polygonStart(),l.lineStart(),r(null,null,1,l),l.lineEnd(),l.polygonEnd()}};function x(t,r){e(t,r)&&l.point(t,r)}function b(e,t){f.point(e,t)}function _(){v.point=b,f.lineStart()}function w(){v.point=x,f.lineEnd()}function k(e,t){p.push([e,t]),g.point(e,t)}function S(){g.lineStart(),p=[]}function A(){k(p[0][0],p[0][1]),g.lineEnd();var e,t,r,n,i=g.clean(),o=m.result(),a=o.length;if(p.pop(),d.push(p),p=null,a)if(1&i){if((t=(r=o[0]).length-1)>0){for(y||(l.polygonStart(),y=!0),l.lineStart(),e=0;e1&&2&i&&o.push(o.pop().concat(o.shift())),h.push(o.filter(c))}return v}}function c(e){return e.length>1}function u(e,t){return((e=e.x)[0]<0?e[1]-o.TW-o.Ni:o.TW-e[1])-((t=t.x)[0]<0?t[1]-o.TW-o.Ni:o.TW-t[1])}},18500:(e,t,r)=>{"use strict";r.d(t,{A:()=>c});var n=r(85872),i=r(41733);var o=r(89326),a=r(35529),s=1e9,l=-s;function c(e,t,r,c){function u(n,i){return e<=n&&n<=r&&t<=i&&i<=c}function d(n,i,o,a){var s=0,l=0;if(null==n||(s=h(n,o))!==(l=h(i,o))||f(n,i)<0^o>0)do{a.point(0===s||3===s?e:r,s>1?c:t)}while((s=(s+o+4)%4)!==l);else a.point(i[0],i[1])}function h(i,o){return(0,n.tn)(i[0]-e)0?0:3:(0,n.tn)(i[0]-r)0?2:1:(0,n.tn)(i[1]-t)0?1:0:o>0?3:2}function p(e,t){return f(e.x,t.x)}function f(e,t){var r=h(e,1),n=h(t,1);return r!==n?r-n:0===r?t[1]-e[1]:1===r?e[0]-t[0]:2===r?e[1]-t[1]:t[0]-e[0]}return function(n){var h,f,m,g,y,v,x,b,_,w,k,S=n,A=(0,i.A)(),T={point:M,lineStart:function(){T.point=C,f&&f.push(m=[]);w=!0,_=!1,x=b=NaN},lineEnd:function(){h&&(C(g,y),v&&_&&A.rejoin(),h.push(A.result()));T.point=M,_&&S.lineEnd()},polygonStart:function(){S=A,h=[],f=[],k=!0},polygonEnd:function(){var t=function(){for(var t=0,r=0,n=f.length;rc&&(d-i)*(c-o)>(h-o)*(e-i)&&++t:h<=c&&(d-i)*(c-o)<(h-o)*(e-i)&&--t;return t}(),r=k&&t,i=(h=(0,a.Am)(h)).length;(r||i)&&(n.polygonStart(),r&&(n.lineStart(),d(null,null,1,n),n.lineEnd()),i&&(0,o.A)(h,p,t,d,n),n.polygonEnd());S=n,h=f=m=null}};function M(e,t){u(e,t)&&S.point(e,t)}function C(n,i){var o=u(n,i);if(f&&m.push([n,i]),w)g=n,y=i,v=o,w=!1,o&&(S.lineStart(),S.point(n,i));else if(o&&_)S.point(n,i);else{var a=[x=Math.max(l,Math.min(s,x)),b=Math.max(l,Math.min(s,b))],d=[n=Math.max(l,Math.min(s,n)),i=Math.max(l,Math.min(s,i))];!function(e,t,r,n,i,o){var a,s=e[0],l=e[1],c=0,u=1,d=t[0]-s,h=t[1]-l;if(a=r-s,d||!(a>0)){if(a/=d,d<0){if(a0){if(a>u)return;a>c&&(c=a)}if(a=i-s,d||!(a<0)){if(a/=d,d<0){if(a>u)return;a>c&&(c=a)}else if(d>0){if(a0)){if(a/=h,h<0){if(a0){if(a>u)return;a>c&&(c=a)}if(a=o-l,h||!(a<0)){if(a/=h,h<0){if(a>u)return;a>c&&(c=a)}else if(h>0){if(a0&&(e[0]=s+c*d,e[1]=l+c*h),u<1&&(t[0]=s+u*d,t[1]=l+u*h),!0}}}}}(a,d,e,t,r,c)?o&&(S.lineStart(),S.point(n,i),k=!1):(_||(S.lineStart(),S.point(a[0],a[1])),S.point(d[0],d[1]),o||S.lineEnd(),k=!1)}x=n,b=i,_=o}return T}}},89326:(e,t,r)=>{"use strict";r.d(t,{A:()=>a});var n=r(55511),i=r(85872);function o(e,t,r,n){this.x=e,this.z=t,this.o=r,this.e=n,this.v=!1,this.n=this.p=null}function a(e,t,r,a,l){var c,u,d=[],h=[];if(e.forEach((function(e){if(!((t=e.length-1)<=0)){var t,r,a=e[0],s=e[t];if((0,n.A)(a,s)){if(!a[2]&&!s[2]){for(l.lineStart(),c=0;c=0;--c)l.point((f=p[c])[0],f[1]);else a(g.x,g.p.x,-1,l);g=g.p}p=(g=g.o).z,y=!y}while(!g.v);l.lineEnd()}}}function s(e){if(t=e.length){for(var t,r,n=0,i=e[0];++n{"use strict";function n(e,t){function r(r,n){return r=e(r,n),t(r[0],r[1])}return e.invert&&t.invert&&(r.invert=function(r,n){return(r=t.invert(r,n))&&e.invert(r[0],r[1])}),r}r.d(t,{A:()=>n})},69556:(e,t,r)=>{"use strict";function n(e){return e}r.d(t,{A:()=>n})},85487:(e,t,r)=>{"use strict";r.r(t),r.d(t,{geoAlbers:()=>We,geoAlbersUsa:()=>Ge,geoArea:()=>n.Ay,geoAzimuthalEqualArea:()=>Ye.A,geoAzimuthalEqualAreaRaw:()=>Ye.n,geoAzimuthalEquidistant:()=>Xe.A,geoAzimuthalEquidistantRaw:()=>Xe.j,geoBounds:()=>i.A,geoCentroid:()=>o.A,geoCircle:()=>a.A,geoClipAntimeridian:()=>s.A,geoClipCircle:()=>l.A,geoClipExtent:()=>u,geoClipRectangle:()=>c.A,geoConicConformal:()=>rt,geoConicConformalRaw:()=>tt,geoConicEqualArea:()=>$e,geoConicEqualAreaRaw:()=>He,geoConicEquidistant:()=>ot,geoConicEquidistantRaw:()=>it,geoContains:()=>z,geoDistance:()=>M,geoEqualEarth:()=>ht,geoEqualEarthRaw:()=>dt,geoEquirectangular:()=>nt.A,geoEquirectangularRaw:()=>nt.f,geoGnomonic:()=>pt.A,geoGnomonicRaw:()=>pt.T,geoGraticule:()=>B,geoGraticule10:()=>V,geoIdentity:()=>mt,geoInterpolate:()=>q.A,geoLength:()=>S,geoMercator:()=>Je,geoMercatorRaw:()=>Ke,geoNaturalEarth1:()=>gt.A,geoNaturalEarth1Raw:()=>gt.P,geoOrthographic:()=>yt.A,geoOrthographicRaw:()=>yt.x,geoPath:()=>Be,geoProjection:()=>Ve.A,geoProjectionMutator:()=>Ve.U,geoRotation:()=>Ze.A,geoStereographic:()=>bt,geoStereographicRaw:()=>xt,geoStream:()=>v.A,geoTransform:()=>ft.A,geoTransverseMercator:()=>wt,geoTransverseMercatorRaw:()=>_t});var n=r(71791),i=r(33115),o=r(78746),a=r(28236),s=r(8948),l=r(50179),c=r(18500);function u(){var e,t,r,n=0,i=0,o=960,a=500;return r={stream:function(r){return e&&t===r?e:e=(0,c.A)(n,i,o,a)(t=r)},extent:function(s){return arguments.length?(n=+s[0][0],i=+s[0][1],o=+s[1][0],a=+s[1][1],e=t=null,r):[[n,i],[o,a]]}}}var d,h,p,f=r(84935),m=r(80108),g=r(85872),y=r(77026),v=r(1082),x=(0,m.A)(),b={sphere:y.A,point:y.A,lineStart:function(){b.point=w,b.lineEnd=_},lineEnd:y.A,polygonStart:y.A,polygonEnd:y.A};function _(){b.point=b.lineEnd=y.A}function w(e,t){e*=g.F2,t*=g.F2,d=e,h=(0,g.F8)(t),p=(0,g.gn)(t),b.point=k}function k(e,t){e*=g.F2,t*=g.F2;var r=(0,g.F8)(t),n=(0,g.gn)(t),i=(0,g.tn)(e-d),o=(0,g.gn)(i),a=n*(0,g.F8)(i),s=p*r-h*n*o,l=h*r+p*n*o;x.add((0,g.FP)((0,g.RZ)(a*a+s*s),l)),d=e,h=r,p=n}function S(e){return x.reset(),(0,v.A)(e,b),+x}var A=[null,null],T={type:"LineString",coordinates:A};function M(e,t){return A[0]=e,A[1]=t,S(T)}var C={Feature:function(e,t){return I(e.geometry,t)},FeatureCollection:function(e,t){for(var r=e.features,n=-1,i=r.length;++n0&&(i=M(e[o],e[o-1]))>0&&r<=i&&n<=i&&(r+n-i)*(1-Math.pow((r-n)/i,2))g.Ni})).map(l)).concat((0,j.y1)((0,g.mk)(o/p)*p,i,p).filter((function(e){return(0,g.tn)(e%m)>g.Ni})).map(c))}return v.lines=function(){return x().map((function(e){return{type:"LineString",coordinates:e}}))},v.outline=function(){return{type:"Polygon",coordinates:[u(n).concat(d(a).slice(1),u(r).reverse().slice(1),d(s).reverse().slice(1))]}},v.extent=function(e){return arguments.length?v.extentMajor(e).extentMinor(e):v.extentMinor()},v.extentMajor=function(e){return arguments.length?(n=+e[0][0],r=+e[1][0],s=+e[0][1],a=+e[1][1],n>r&&(e=n,n=r,r=e),s>a&&(e=s,s=a,a=e),v.precision(y)):[[n,s],[r,a]]},v.extentMinor=function(r){return arguments.length?(t=+r[0][0],e=+r[1][0],o=+r[0][1],i=+r[1][1],t>e&&(r=t,t=e,e=r),o>i&&(r=o,o=i,i=r),v.precision(y)):[[t,o],[e,i]]},v.step=function(e){return arguments.length?v.stepMajor(e).stepMinor(e):v.stepMinor()},v.stepMajor=function(e){return arguments.length?(f=+e[0],m=+e[1],v):[f,m]},v.stepMinor=function(e){return arguments.length?(h=+e[0],p=+e[1],v):[h,p]},v.precision=function(h){return arguments.length?(y=+h,l=F(o,i,90),c=N(t,e,y),u=F(s,a,90),d=N(n,r,y),v):y},v.extentMajor([[-180,-90+g.Ni],[180,90-g.Ni]]).extentMinor([[-180,-80-g.Ni],[180,80+g.Ni]])}function V(){return B()()}var U,H,$,W,q=r(74867),G=r(69556),Y=(0,m.A)(),X=(0,m.A)(),Z={point:y.A,lineStart:y.A,lineEnd:y.A,polygonStart:function(){Z.lineStart=K,Z.lineEnd=ee},polygonEnd:function(){Z.lineStart=Z.lineEnd=Z.point=y.A,Y.add((0,g.tn)(X)),X.reset()},result:function(){var e=Y/2;return Y.reset(),e}};function K(){Z.point=J}function J(e,t){Z.point=Q,U=$=e,H=W=t}function Q(e,t){X.add(W*e-$*t),$=e,W=t}function ee(){Q(U,H)}const te=Z;var re,ne,ie,oe,ae=r(17365),se=0,le=0,ce=0,ue=0,de=0,he=0,pe=0,fe=0,me=0,ge={point:ye,lineStart:ve,lineEnd:_e,polygonStart:function(){ge.lineStart=we,ge.lineEnd=ke},polygonEnd:function(){ge.point=ye,ge.lineStart=ve,ge.lineEnd=_e},result:function(){var e=me?[pe/me,fe/me]:he?[ue/he,de/he]:ce?[se/ce,le/ce]:[NaN,NaN];return se=le=ce=ue=de=he=pe=fe=me=0,e}};function ye(e,t){se+=e,le+=t,++ce}function ve(){ge.point=xe}function xe(e,t){ge.point=be,ye(ie=e,oe=t)}function be(e,t){var r=e-ie,n=t-oe,i=(0,g.RZ)(r*r+n*n);ue+=i*(ie+e)/2,de+=i*(oe+t)/2,he+=i,ye(ie=e,oe=t)}function _e(){ge.point=ye}function we(){ge.point=Se}function ke(){Ae(re,ne)}function Se(e,t){ge.point=Ae,ye(re=ie=e,ne=oe=t)}function Ae(e,t){var r=e-ie,n=t-oe,i=(0,g.RZ)(r*r+n*n);ue+=i*(ie+e)/2,de+=i*(oe+t)/2,he+=i,pe+=(i=oe*e-ie*t)*(ie+e),fe+=i*(oe+t),me+=3*i,ye(ie=e,oe=t)}const Te=ge;function Me(e){this._context=e}Me.prototype={_radius:4.5,pointRadius:function(e){return this._radius=e,this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){0===this._line&&this._context.closePath(),this._point=NaN},point:function(e,t){switch(this._point){case 0:this._context.moveTo(e,t),this._point=1;break;case 1:this._context.lineTo(e,t);break;default:this._context.moveTo(e+this._radius,t),this._context.arc(e,t,this._radius,0,g.FA)}},result:y.A};var Ce,Ee,Ie,Pe,Oe,Re=(0,m.A)(),Le={point:y.A,lineStart:function(){Le.point=De},lineEnd:function(){Ce&&ze(Ee,Ie),Le.point=y.A},polygonStart:function(){Ce=!0},polygonEnd:function(){Ce=null},result:function(){var e=+Re;return Re.reset(),e}};function De(e,t){Le.point=ze,Ee=Pe=e,Ie=Oe=t}function ze(e,t){Pe-=e,Oe-=t,Re.add((0,g.RZ)(Pe*Pe+Oe*Oe)),Pe=e,Oe=t}const je=Le;function Fe(){this._string=[]}function Ne(e){return"m0,"+e+"a"+e+","+e+" 0 1,1 0,"+-2*e+"a"+e+","+e+" 0 1,1 0,"+2*e+"z"}function Be(e,t){var r,n,i=4.5;function o(e){return e&&("function"===typeof i&&n.pointRadius(+i.apply(this,arguments)),(0,v.A)(e,r(n))),n.result()}return o.area=function(e){return(0,v.A)(e,r(te)),te.result()},o.measure=function(e){return(0,v.A)(e,r(je)),je.result()},o.bounds=function(e){return(0,v.A)(e,r(ae.A)),ae.A.result()},o.centroid=function(e){return(0,v.A)(e,r(Te)),Te.result()},o.projection=function(t){return arguments.length?(r=null==t?(e=null,G.A):(e=t).stream,o):e},o.context=function(e){return arguments.length?(n=null==e?(t=null,new Fe):new Me(t=e),"function"!==typeof i&&n.pointRadius(i),o):t},o.pointRadius=function(e){return arguments.length?(i="function"===typeof e?e:(n.pointRadius(+e),+e),o):i},o.projection(e).context(t)}Fe.prototype={_radius:4.5,_circle:Ne(4.5),pointRadius:function(e){return(e=+e)!==this._radius&&(this._radius=e,this._circle=null),this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){0===this._line&&this._string.push("Z"),this._point=NaN},point:function(e,t){switch(this._point){case 0:this._string.push("M",e,",",t),this._point=1;break;case 1:this._string.push("L",e,",",t);break;default:null==this._circle&&(this._circle=Ne(this._radius)),this._string.push("M",e,",",t,this._circle)}},result:function(){if(this._string.length){var e=this._string.join("");return this._string=[],e}return null}};var Ve=r(23373);function Ue(e){var t=0,r=g.pi/3,n=(0,Ve.U)(e),i=n(t,r);return i.parallels=function(e){return arguments.length?n(t=e[0]*g.F2,r=e[1]*g.F2):[t*g.uj,r*g.uj]},i}function He(e,t){var r=(0,g.F8)(e),n=(r+(0,g.F8)(t))/2;if((0,g.tn)(n)=.12&&i<.234&&n>=-.425&&n<-.214?s:i>=.166&&i<.234&&n>=-.214&&n<-.115?l:a).invert(e)},u.stream=function(r){return e&&t===r?e:e=function(e){var t=e.length;return{point:function(r,n){for(var i=-1;++i0?t<-g.TW+g.Ni&&(t=-g.TW+g.Ni):t>g.TW-g.Ni&&(t=g.TW-g.Ni);var r=i/(0,g.n7)(et(t),n);return[r*(0,g.F8)(n*e),i-r*(0,g.gn)(n*e)]}return o.invert=function(e,t){var r=i-t,o=(0,g._S)(n)*(0,g.RZ)(e*e+r*r),a=(0,g.FP)(e,(0,g.tn)(r))*(0,g._S)(r);return r*n<0&&(a-=g.pi*(0,g._S)(e)*(0,g._S)(r)),[a/n,2*(0,g.rY)((0,g.n7)(i/o,1/n))-g.TW]},o}function rt(){return Ue(tt).scale(109.5).parallels([30,30])}Ke.invert=function(e,t){return[e,2*(0,g.rY)((0,g.oN)(t))-g.TW]};var nt=r(72888);function it(e,t){var r=(0,g.gn)(e),n=e===t?(0,g.F8)(e):(r-(0,g.gn)(t))/(t-e),i=r/n+e;if((0,g.tn)(n)2?e[2]+90:90]):[(e=r())[0],e[1],e[2]-90]},r([0,0,90]).scale(159.155)}xt.invert=(0,vt.I)((function(e){return 2*(0,g.rY)(e)})),_t.invert=function(e,t){return[-t,2*(0,g.rY)((0,g.oN)(e))-g.TW]}},74867:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(85872);function i(e,t){var r=e[0]*n.F2,i=e[1]*n.F2,o=t[0]*n.F2,a=t[1]*n.F2,s=(0,n.gn)(i),l=(0,n.F8)(i),c=(0,n.gn)(a),u=(0,n.F8)(a),d=s*(0,n.gn)(r),h=s*(0,n.F8)(r),p=c*(0,n.gn)(o),f=c*(0,n.F8)(o),m=2*(0,n.qR)((0,n.RZ)((0,n.bo)(a-i)+s*c*(0,n.bo)(o-r))),g=(0,n.F8)(m),y=m?function(e){var t=(0,n.F8)(e*=m)/g,r=(0,n.F8)(m-e)/g,i=r*d+t*p,o=r*h+t*f,a=r*l+t*u;return[(0,n.FP)(o,i)*n.uj,(0,n.FP)(a,(0,n.RZ)(i*i+o*o))*n.uj]}:function(){return[r*n.uj,i*n.uj]};return y.distance=m,y}},85872:(e,t,r)=>{"use strict";r.d(t,{$t:()=>i,F2:()=>u,F8:()=>x,FA:()=>l,FP:()=>p,HQ:()=>k,Ml:()=>w,Ni:()=>n,RZ:()=>_,Rm:()=>y,TW:()=>a,_S:()=>b,bo:()=>A,gn:()=>f,gz:()=>s,mk:()=>m,n7:()=>v,oN:()=>g,pi:()=>o,qR:()=>S,rY:()=>h,tn:()=>d,uj:()=>c});var n=1e-6,i=1e-12,o=Math.PI,a=o/2,s=o/4,l=2*o,c=180/o,u=o/180,d=Math.abs,h=Math.atan,p=Math.atan2,f=Math.cos,m=Math.ceil,g=Math.exp,y=(Math.floor,Math.log),v=Math.pow,x=Math.sin,b=Math.sign||function(e){return e>0?1:e<0?-1:0},_=Math.sqrt,w=Math.tan;function k(e){return e>1?0:e<-1?o:Math.acos(e)}function S(e){return e>1?a:e<-1?-a:Math.asin(e)}function A(e){return(e=x(e/2))*e}},77026:(e,t,r)=>{"use strict";function n(){}r.d(t,{A:()=>n})},17365:(e,t,r)=>{"use strict";r.d(t,{A:()=>l});var n=r(77026),i=1/0,o=i,a=-i,s=a;const l={point:function(e,t){ea&&(a=e);ts&&(s=t)},lineStart:n.A,lineEnd:n.A,polygonStart:n.A,polygonEnd:n.A,result:function(){var e=[[i,o],[a,s]];return a=s=-(o=i=1/0),e}}},55511:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(85872);function i(e,t){return(0,n.tn)(e[0]-t[0]){"use strict";r.d(t,{A:()=>l});var n=r(80108),i=r(74642),o=r(85872),a=(0,n.A)();function s(e){return(0,o.tn)(e[0])<=o.pi?e[0]:(0,o._S)(e[0])*(((0,o.tn)(e[0])+o.pi)%o.FA-o.pi)}function l(e,t){var r=s(t),n=t[1],l=(0,o.F8)(n),c=[(0,o.F8)(r),-(0,o.gn)(r),0],u=0,d=0;a.reset(),1===l?n=o.TW+o.Ni:-1===l&&(n=-o.TW-o.Ni);for(var h=0,p=e.length;h=0?1:-1,E=C*M,I=E>o.pi,P=x*A;if(a.add((0,o.FP)(P*C*(0,o.F8)(E),b*T+P*(0,o.gn)(E))),u+=I?M+C*o.FA:M,I^y>=r^k>=r){var O=(0,i.r8)((0,i.jf)(g),(0,i.jf)(w));(0,i.Cx)(O);var R=(0,i.r8)(c,O);(0,i.Cx)(R);var L=(I^M>=0?-1:1)*(0,o.qR)(R[2]);(n>L||n===L&&(O[0]||O[1]))&&(d+=I^M>=0?1:-1)}}return(u<-o.Ni||u{"use strict";r.d(t,{I:()=>o,c:()=>i});var n=r(85872);function i(e){return function(t,r){var i=(0,n.gn)(t),o=(0,n.gn)(r),a=e(i*o);return[a*o*(0,n.F8)(t),a*(0,n.F8)(r)]}}function o(e){return function(t,r){var i=(0,n.RZ)(t*t+r*r),o=e(i),a=(0,n.F8)(o),s=(0,n.gn)(o);return[(0,n.FP)(t*a,i*s),(0,n.qR)(i&&r*a/i)]}}},77948:(e,t,r)=>{"use strict";r.d(t,{A:()=>s,n:()=>a});var n=r(85872),i=r(39065),o=r(23373),a=(0,i.c)((function(e){return(0,n.RZ)(2/(1+e))}));function s(){return(0,o.A)(a).scale(124.75).clipAngle(179.999)}a.invert=(0,i.I)((function(e){return 2*(0,n.qR)(e/2)}))},89012:(e,t,r)=>{"use strict";r.d(t,{A:()=>s,j:()=>a});var n=r(85872),i=r(39065),o=r(23373),a=(0,i.c)((function(e){return(e=(0,n.HQ)(e))&&e/(0,n.F8)(e)}));function s(){return(0,o.A)(a).scale(79.4188).clipAngle(179.999)}a.invert=(0,i.I)((function(e){return e}))},72888:(e,t,r)=>{"use strict";r.d(t,{A:()=>o,f:()=>i});var n=r(23373);function i(e,t){return[e,t]}function o(){return(0,n.A)(i).scale(152.63)}i.invert=i},17983:(e,t,r)=>{"use strict";r.d(t,{FL:()=>c,G0:()=>l,Hv:()=>s,sp:()=>a});var n=r(1082),i=r(17365);function o(e,t,r){var o=e.clipExtent&&e.clipExtent();return e.scale(150).translate([0,0]),null!=o&&e.clipExtent(null),(0,n.A)(r,e.stream(i.A)),t(i.A.result()),null!=o&&e.clipExtent(o),e}function a(e,t,r){return o(e,(function(r){var n=t[1][0]-t[0][0],i=t[1][1]-t[0][1],o=Math.min(n/(r[1][0]-r[0][0]),i/(r[1][1]-r[0][1])),a=+t[0][0]+(n-o*(r[1][0]+r[0][0]))/2,s=+t[0][1]+(i-o*(r[1][1]+r[0][1]))/2;e.scale(150*o).translate([a,s])}),r)}function s(e,t,r){return a(e,[[0,0],t],r)}function l(e,t,r){return o(e,(function(r){var n=+t,i=n/(r[1][0]-r[0][0]),o=(n-i*(r[1][0]+r[0][0]))/2,a=-i*r[0][1];e.scale(150*i).translate([o,a])}),r)}function c(e,t,r){return o(e,(function(r){var n=+t,i=n/(r[1][1]-r[0][1]),o=-i*r[0][0],a=(n-i*(r[1][1]+r[0][1]))/2;e.scale(150*i).translate([o,a])}),r)}},4438:(e,t,r)=>{"use strict";r.d(t,{A:()=>s,T:()=>a});var n=r(85872),i=r(39065),o=r(23373);function a(e,t){var r=(0,n.gn)(t),i=(0,n.gn)(e)*r;return[r*(0,n.F8)(e)/i,(0,n.F8)(t)/i]}function s(){return(0,o.A)(a).scale(144.049).clipAngle(60)}a.invert=(0,i.I)(n.rY)},23373:(e,t,r)=>{"use strict";r.d(t,{A:()=>x,U:()=>b});var n=r(8948),i=r(50179),o=r(18500),a=r(80428),s=r(69556),l=r(85872),c=r(27520),u=r(55380),d=r(17983),h=r(74642),p=16,f=(0,l.gn)(30*l.F2);function m(e,t){return+t?function(e,t){function r(n,i,o,a,s,c,u,d,h,p,m,g,y,v){var x=u-n,b=d-i,_=x*x+b*b;if(_>4*t&&y--){var w=a+p,k=s+m,S=c+g,A=(0,l.RZ)(w*w+k*k+S*S),T=(0,l.qR)(S/=A),M=(0,l.tn)((0,l.tn)(S)-1)t||(0,l.tn)((x*P+b*O)/_-.5)>.3||a*p+s*m+c*g2?e[2]%360*l.F2:0,U()):[E*l.uj,I*l.uj,P*l.uj]},B.angle=function(e){return arguments.length?(O=e%360*l.F2,U()):O*l.uj},B.reflectX=function(e){return arguments.length?(R=e?-1:1,U()):R<0},B.reflectY=function(e){return arguments.length?(L=e?-1:1,U()):L<0},B.precision=function(e){return arguments.length?(x=m(b,N=e*e),H()):(0,l.RZ)(N)},B.fitExtent=function(e,t){return(0,d.sp)(B,e,t)},B.fitSize=function(e,t){return(0,d.Hv)(B,e,t)},B.fitWidth=function(e,t){return(0,d.G0)(B,e,t)},B.fitHeight=function(e,t){return(0,d.FL)(B,e,t)},function(){return t=e.apply(this,arguments),B.invert=t.invert&&V,U()}}},97102:(e,t,r)=>{"use strict";r.d(t,{A:()=>a,P:()=>o});var n=r(23373),i=r(85872);function o(e,t){var r=t*t,n=r*r;return[e*(.8707-.131979*r+n*(n*(.003971*r-.001529*n)-.013791)),t*(1.007226+r*(.015085+n*(.028874*r-.044475-.005916*n)))]}function a(){return(0,n.A)(o).scale(175.295)}o.invert=function(e,t){var r,n=t,o=25;do{var a=n*n,s=a*a;n-=r=(n*(1.007226+a*(.015085+s*(.028874*a-.044475-.005916*s)))-t)/(1.007226+a*(.045255+s*(.259866*a-.311325-.005916*11*s)))}while((0,i.tn)(r)>i.Ni&&--o>0);return[e/(.8707+(a=n*n)*(a*(a*a*a*(.003971-.001529*a)-.013791)-.131979)),n]}},16588:(e,t,r)=>{"use strict";r.d(t,{A:()=>s,x:()=>a});var n=r(85872),i=r(39065),o=r(23373);function a(e,t){return[(0,n.gn)(t)*(0,n.F8)(e),(0,n.F8)(t)]}function s(){return(0,o.A)(a).scale(249.5).clipAngle(90+n.Ni)}a.invert=(0,i.I)(n.qR)},27520:(e,t,r)=>{"use strict";r.d(t,{A:()=>u,y:()=>a});var n=r(80428),i=r(85872);function o(e,t){return[(0,i.tn)(e)>i.pi?e+Math.round(-e/i.FA)*i.FA:e,t]}function a(e,t,r){return(e%=i.FA)?t||r?(0,n.A)(l(e),c(t,r)):l(e):t||r?c(t,r):o}function s(e){return function(t,r){return[(t+=e)>i.pi?t-i.FA:t<-i.pi?t+i.FA:t,r]}}function l(e){var t=s(e);return t.invert=s(-e),t}function c(e,t){var r=(0,i.gn)(e),n=(0,i.F8)(e),o=(0,i.gn)(t),a=(0,i.F8)(t);function s(e,t){var s=(0,i.gn)(t),l=(0,i.gn)(e)*s,c=(0,i.F8)(e)*s,u=(0,i.F8)(t),d=u*r+l*n;return[(0,i.FP)(c*o-d*a,l*r-u*n),(0,i.qR)(d*o+c*a)]}return s.invert=function(e,t){var s=(0,i.gn)(t),l=(0,i.gn)(e)*s,c=(0,i.F8)(e)*s,u=(0,i.F8)(t),d=u*o-c*a;return[(0,i.FP)(c*o+u*a,l*r+d*n),(0,i.qR)(d*r-l*n)]},s}function u(e){function t(t){return(t=e(t[0]*i.F2,t[1]*i.F2))[0]*=i.uj,t[1]*=i.uj,t}return e=a(e[0]*i.F2,e[1]*i.F2,e.length>2?e[2]*i.F2:0),t.invert=function(t){return(t=e.invert(t[0]*i.F2,t[1]*i.F2))[0]*=i.uj,t[1]*=i.uj,t},t}o.invert=o},1082:(e,t,r)=>{"use strict";function n(e,t){e&&o.hasOwnProperty(e.type)&&o[e.type](e,t)}r.d(t,{A:()=>l});var i={Feature:function(e,t){n(e.geometry,t)},FeatureCollection:function(e,t){for(var r=e.features,i=-1,o=r.length;++i{"use strict";function n(e){return{stream:i(e)}}function i(e){return function(t){var r=new o;for(var n in e)r[n]=e[n];return r.stream=t,r}}function o(){}r.d(t,{A:()=>n,G:()=>i}),o.prototype={constructor:o,point:function(e,t){this.stream.point(e,t)},sphere:function(){this.stream.sphere()},lineStart:function(){this.stream.lineStart()},lineEnd:function(){this.stream.lineEnd()},polygonStart:function(){this.stream.polygonStart()},polygonEnd:function(){this.stream.polygonEnd()}}},28203:(e,t,r)=>{"use strict";function n(e,t){return e.parent===t.parent?1:2}function i(e,t){return e+t.x}function o(e,t){return Math.max(e,t.y)}function a(){var e=n,t=1,r=1,a=!1;function s(n){var s,l=0;n.eachAfter((function(t){var r=t.children;r?(t.x=function(e){return e.reduce(i,0)/e.length}(r),t.y=function(e){return 1+e.reduce(o,0)}(r)):(t.x=s?l+=e(t,s):0,t.y=0,s=t)}));var c=function(e){for(var t;t=e.children;)e=t[0];return e}(n),u=function(e){for(var t;t=e.children;)e=t[t.length-1];return e}(n),d=c.x-e(c,u)/2,h=u.x+e(u,c)/2;return n.eachAfter(a?function(e){e.x=(e.x-n.x)*t,e.y=(n.y-e.y)*r}:function(e){e.x=(e.x-d)/(h-d)*t,e.y=(1-(n.y?e.y/n.y:1))*r})}return s.separation=function(t){return arguments.length?(e=t,s):e},s.size=function(e){return arguments.length?(a=!1,t=+e[0],r=+e[1],s):a?null:[t,r]},s.nodeSize=function(e){return arguments.length?(a=!0,t=+e[0],r=+e[1],s):a?[t,r]:null},s}function s(e){var t=0,r=e.children,n=r&&r.length;if(n)for(;--n>=0;)t+=r[n].value;else t=1;e.value=t}function l(e,t){var r,n,i,o,a,s=new h(e),l=+e.value&&(s.value=e.value),u=[s];for(null==t&&(t=c);r=u.pop();)if(l&&(r.value=+r.data.value),(i=t(r.data))&&(a=i.length))for(r.children=new Array(a),o=a-1;o>=0;--o)u.push(n=r.children[o]=new h(i[o])),n.parent=r,n.depth=r.depth+1;return s.eachBefore(d)}function c(e){return e.children}function u(e){e.data=e.data.data}function d(e){var t=0;do{e.height=t}while((e=e.parent)&&e.height<++t)}function h(e){this.data=e,this.depth=this.height=0,this.parent=null}r.r(t),r.d(t,{cluster:()=>a,hierarchy:()=>l,pack:()=>O,packEnclose:()=>f,packSiblings:()=>M,partition:()=>F,stratify:()=>$,tree:()=>K,treemap:()=>re,treemapBinary:()=>ne,treemapDice:()=>j,treemapResquarify:()=>oe,treemapSlice:()=>J,treemapSliceDice:()=>ie,treemapSquarify:()=>te}),h.prototype=l.prototype={constructor:h,count:function(){return this.eachAfter(s)},each:function(e){var t,r,n,i,o=this,a=[o];do{for(t=a.reverse(),a=[];o=t.pop();)if(e(o),r=o.children)for(n=0,i=r.length;n=0;--r)i.push(t[r]);return this},sum:function(e){return this.eachAfter((function(t){for(var r=+e(t.data)||0,n=t.children,i=n&&n.length;--i>=0;)r+=n[i].value;t.value=r}))},sort:function(e){return this.eachBefore((function(t){t.children&&t.children.sort(e)}))},path:function(e){for(var t=this,r=function(e,t){if(e===t)return e;var r=e.ancestors(),n=t.ancestors(),i=null;e=r.pop(),t=n.pop();for(;e===t;)i=e,e=r.pop(),t=n.pop();return i}(t,e),n=[t];t!==r;)t=t.parent,n.push(t);for(var i=n.length;e!==r;)n.splice(i,0,e),e=e.parent;return n},ancestors:function(){for(var e=this,t=[e];e=e.parent;)t.push(e);return t},descendants:function(){var e=[];return this.each((function(t){e.push(t)})),e},leaves:function(){var e=[];return this.eachBefore((function(t){t.children||e.push(t)})),e},links:function(){var e=this,t=[];return e.each((function(r){r!==e&&t.push({source:r.parent,target:r})})),t},copy:function(){return l(this).eachBefore(u)}};var p=Array.prototype.slice;function f(e){for(var t,r,n=0,i=(e=function(e){for(var t,r,n=e.length;n;)r=Math.random()*n--|0,t=e[n],e[n]=e[r],e[r]=t;return e}(p.call(e))).length,o=[];n0&&r*r>n*n+i*i}function v(e,t){for(var r=0;r(a*=a)?(n=(c+a-i)/(2*c),o=Math.sqrt(Math.max(0,a/c-n*n)),r.x=e.x-n*s-o*l,r.y=e.y-n*l+o*s):(n=(c+i-a)/(2*c),o=Math.sqrt(Math.max(0,i/c-n*n)),r.x=t.x+n*s-o*l,r.y=t.y+n*l+o*s)):(r.x=t.x+r.r,r.y=t.y)}function k(e,t){var r=e.r+t.r-1e-6,n=t.x-e.x,i=t.y-e.y;return r>0&&r*r>n*n+i*i}function S(e){var t=e._,r=e.next._,n=t.r+r.r,i=(t.x*r.r+r.x*t.r)/n,o=(t.y*r.r+r.y*t.r)/n;return i*i+o*o}function A(e){this._=e,this.next=null,this.previous=null}function T(e){if(!(i=e.length))return 0;var t,r,n,i,o,a,s,l,c,u,d;if((t=e[0]).x=0,t.y=0,!(i>1))return t.r;if(r=e[1],t.x=-r.r,r.x=t.r,r.y=0,!(i>2))return t.r+r.r;w(r,t,n=e[2]),t=new A(t),r=new A(r),n=new A(n),t.next=n.previous=r,r.next=t.previous=n,n.next=r.previous=t;e:for(s=3;s0)throw new Error("cycle");return o}return r.id=function(t){return arguments.length?(e=C(t),r):e},r.parentId=function(e){return arguments.length?(t=C(e),r):t},r}function W(e,t){return e.parent===t.parent?1:2}function q(e){var t=e.children;return t?t[0]:e.t}function G(e){var t=e.children;return t?t[t.length-1]:e.t}function Y(e,t,r){var n=r/(t.i-e.i);t.c-=n,t.s+=r,e.c+=n,t.z+=r,t.m+=r}function X(e,t,r){return e.a.parent===t.parent?e.a:r}function Z(e,t){this._=e,this.parent=null,this.children=null,this.A=null,this.a=this,this.z=0,this.m=0,this.c=0,this.s=0,this.t=null,this.i=t}function K(){var e=W,t=1,r=1,n=null;function i(i){var l=function(e){for(var t,r,n,i,o,a=new Z(e,0),s=[a];t=s.pop();)if(n=t._.children)for(t.children=new Array(o=n.length),i=o-1;i>=0;--i)s.push(r=t.children[i]=new Z(n[i],i)),r.parent=t;return(a.parent=new Z(null,0)).children=[a],a}(i);if(l.eachAfter(o),l.parent.m=-l.z,l.eachBefore(a),n)i.eachBefore(s);else{var c=i,u=i,d=i;i.eachBefore((function(e){e.xu.x&&(u=e),e.depth>d.depth&&(d=e)}));var h=c===u?1:e(c,u)/2,p=h-c.x,f=t/(u.x+h+p),m=r/(d.depth||1);i.eachBefore((function(e){e.x=(e.x+p)*f,e.y=e.depth*m}))}return i}function o(t){var r=t.children,n=t.parent.children,i=t.i?n[t.i-1]:null;if(r){!function(e){for(var t,r=0,n=0,i=e.children,o=i.length;--o>=0;)(t=i[o]).z+=r,t.m+=r,r+=t.s+(n+=t.c)}(t);var o=(r[0].z+r[r.length-1].z)/2;i?(t.z=i.z+e(t._,i._),t.m=t.z-o):t.z=o}else i&&(t.z=i.z+e(t._,i._));t.parent.A=function(t,r,n){if(r){for(var i,o=t,a=t,s=r,l=o.parent.children[0],c=o.m,u=a.m,d=s.m,h=l.m;s=G(s),o=q(o),s&&o;)l=q(l),(a=G(a)).a=t,(i=s.z+d-o.z-c+e(s._,o._))>0&&(Y(X(s,t,n),t,i),c+=i,u+=i),d+=s.m,c+=o.m,h+=l.m,u+=a.m;s&&!G(a)&&(a.t=s,a.m+=d-u),o&&!q(l)&&(l.t=o,l.m+=c-h,n=t)}return n}(t,i,t.parent.A||n[0])}function a(e){e._.x=e.z+e.parent.m,e.m+=e.parent.m}function s(e){e.x*=t,e.y=e.depth*r}return i.separation=function(t){return arguments.length?(e=t,i):e},i.size=function(e){return arguments.length?(n=!1,t=+e[0],r=+e[1],i):n?null:[t,r]},i.nodeSize=function(e){return arguments.length?(n=!0,t=+e[0],r=+e[1],i):n?[t,r]:null},i}function J(e,t,r,n,i){for(var o,a=e.children,s=-1,l=a.length,c=e.value&&(i-r)/e.value;++sh&&(h=s),g=u*u*m,(p=Math.max(h/g,g/d))>f){u-=s;break}f=p}y.push(a={value:u,dice:l1?t:1)},r}(Q);function re(){var e=te,t=!1,r=1,n=1,i=[0],o=E,a=E,s=E,l=E,c=E;function u(e){return e.x0=e.y0=0,e.x1=r,e.y1=n,e.eachBefore(d),i=[0],t&&e.eachBefore(z),e}function d(t){var r=i[t.depth],n=t.x0+r,u=t.y0+r,d=t.x1-r,h=t.y1-r;d=r-1){var u=s[t];return u.x0=i,u.y0=o,u.x1=a,void(u.y1=l)}var d=c[t],h=n/2+d,p=t+1,f=r-1;for(;p>>1;c[m]l-o){var v=(i*y+a*g)/n;e(t,p,g,i,o,v,l),e(p,r,y,v,o,a,l)}else{var x=(o*y+l*g)/n;e(t,p,g,i,o,a,x),e(p,r,y,i,x,a,l)}}(0,l,e.value,t,r,n,i)}function ie(e,t,r,n,i){(1&e.depth?J:j)(e,t,r,n,i)}const oe=function e(t){function r(e,r,n,i,o){if((a=e._squarify)&&a.ratio===t)for(var a,s,l,c,u,d=-1,h=a.length,p=e.value;++d1?t:1)},r}(Q)},84279:(e,t,r)=>{"use strict";r.d(t,{pq:()=>v});var n=Math.PI,i=2*n,o=1e-6,a=i-o;function s(){this._x0=this._y0=this._x1=this._y1=null,this._=""}function l(){return new s}s.prototype=l.prototype={constructor:s,moveTo:function(e,t){this._+="M"+(this._x0=this._x1=+e)+","+(this._y0=this._y1=+t)},closePath:function(){null!==this._x1&&(this._x1=this._x0,this._y1=this._y0,this._+="Z")},lineTo:function(e,t){this._+="L"+(this._x1=+e)+","+(this._y1=+t)},quadraticCurveTo:function(e,t,r,n){this._+="Q"+ +e+","+ +t+","+(this._x1=+r)+","+(this._y1=+n)},bezierCurveTo:function(e,t,r,n,i,o){this._+="C"+ +e+","+ +t+","+ +r+","+ +n+","+(this._x1=+i)+","+(this._y1=+o)},arcTo:function(e,t,r,i,a){e=+e,t=+t,r=+r,i=+i,a=+a;var s=this._x1,l=this._y1,c=r-e,u=i-t,d=s-e,h=l-t,p=d*d+h*h;if(a<0)throw new Error("negative radius: "+a);if(null===this._x1)this._+="M"+(this._x1=e)+","+(this._y1=t);else if(p>o)if(Math.abs(h*c-u*d)>o&&a){var f=r-s,m=i-l,g=c*c+u*u,y=f*f+m*m,v=Math.sqrt(g),x=Math.sqrt(p),b=a*Math.tan((n-Math.acos((g+p-y)/(2*v*x)))/2),_=b/x,w=b/v;Math.abs(_-1)>o&&(this._+="L"+(e+_*d)+","+(t+_*h)),this._+="A"+a+","+a+",0,0,"+ +(h*f>d*m)+","+(this._x1=e+w*c)+","+(this._y1=t+w*u)}else this._+="L"+(this._x1=e)+","+(this._y1=t);else;},arc:function(e,t,r,s,l,c){e=+e,t=+t,c=!!c;var u=(r=+r)*Math.cos(s),d=r*Math.sin(s),h=e+u,p=t+d,f=1^c,m=c?s-l:l-s;if(r<0)throw new Error("negative radius: "+r);null===this._x1?this._+="M"+h+","+p:(Math.abs(this._x1-h)>o||Math.abs(this._y1-p)>o)&&(this._+="L"+h+","+p),r&&(m<0&&(m=m%i+i),m>a?this._+="A"+r+","+r+",0,1,"+f+","+(e-u)+","+(t-d)+"A"+r+","+r+",0,1,"+f+","+(this._x1=h)+","+(this._y1=p):m>o&&(this._+="A"+r+","+r+",0,"+ +(m>=n)+","+f+","+(this._x1=e+r*Math.cos(l))+","+(this._y1=t+r*Math.sin(l))))},rect:function(e,t,r,n){this._+="M"+(this._x0=this._x1=+e)+","+(this._y0=this._y1=+t)+"h"+ +r+"v"+ +n+"h"+-r+"Z"},toString:function(){return this._}};const c=l;var u=Array.prototype.slice;function d(e){return function(){return e}}function h(e){return e[0]}function p(e){return e[1]}function f(e){return e.source}function m(e){return e.target}function g(e){var t=f,r=m,n=h,i=p,o=null;function a(){var a,s=u.call(arguments),l=t.apply(this,s),d=r.apply(this,s);if(o||(o=a=c()),e(o,+n.apply(this,(s[0]=l,s)),+i.apply(this,s),+n.apply(this,(s[0]=d,s)),+i.apply(this,s)),a)return o=null,a+""||null}return a.source=function(e){return arguments.length?(t=e,a):t},a.target=function(e){return arguments.length?(r=e,a):r},a.x=function(e){return arguments.length?(n="function"===typeof e?e:d(+e),a):n},a.y=function(e){return arguments.length?(i="function"===typeof e?e:d(+e),a):i},a.context=function(e){return arguments.length?(o=null==e?null:e,a):o},a}function y(e,t,r,n,i){e.moveTo(t,r),e.bezierCurveTo(t=(t+n)/2,r,t,i,n,i)}function v(){return g(y)}},9212:(e,t,r)=>{"use strict";r.d(t,{DC:()=>f,de:()=>h,aL:()=>m});var n=r(75838),i=r(17558),o=r(5038),a=r(8966),s=r(6883),l=r(72915);function c(e){if(0<=e.y&&e.y<100){var t=new Date(-1,e.m,e.d,e.H,e.M,e.S,e.L);return t.setFullYear(e.y),t}return new Date(e.y,e.m,e.d,e.H,e.M,e.S,e.L)}function u(e){if(0<=e.y&&e.y<100){var t=new Date(Date.UTC(-1,e.m,e.d,e.H,e.M,e.S,e.L));return t.setUTCFullYear(e.y),t}return new Date(Date.UTC(e.y,e.m,e.d,e.H,e.M,e.S,e.L))}function d(e,t,r){return{y:e,m:t,d:r,H:0,M:0,S:0,L:0}}function h(e){var t=e.dateTime,r=e.date,s=e.time,l=e.periods,h=e.days,p=e.shortDays,f=e.months,m=e.shortMonths,y=w(l),v=k(l),x=w(h),b=k(h),_=w(p),te=k(p),_e=w(f),Re=k(f),Le=w(m),De=k(m),ze={a:function(e){return p[e.getDay()]},A:function(e){return h[e.getDay()]},b:function(e){return m[e.getMonth()]},B:function(e){return f[e.getMonth()]},c:null,d:$,e:$,f:X,g:ae,G:le,H:W,I:q,j:G,L:Y,m:Z,M:K,p:function(e){return l[+(e.getHours()>=12)]},q:function(e){return 1+~~(e.getMonth()/3)},Q:Pe,s:Oe,S:J,u:Q,U:ee,V:re,w:ne,W:ie,x:null,X:null,y:oe,Y:se,Z:ce,"%":Ie},je={a:function(e){return p[e.getUTCDay()]},A:function(e){return h[e.getUTCDay()]},b:function(e){return m[e.getUTCMonth()]},B:function(e){return f[e.getUTCMonth()]},c:null,d:ue,e:ue,f:me,g:Te,G:Ce,H:de,I:he,j:pe,L:fe,m:ge,M:ye,p:function(e){return l[+(e.getUTCHours()>=12)]},q:function(e){return 1+~~(e.getUTCMonth()/3)},Q:Pe,s:Oe,S:ve,u:xe,U:be,V:we,w:ke,W:Se,x:null,X:null,y:Ae,Y:Me,Z:Ee,"%":Ie},Fe={a:function(e,t,r){var n=_.exec(t.slice(r));return n?(e.w=te[n[0].toLowerCase()],r+n[0].length):-1},A:function(e,t,r){var n=x.exec(t.slice(r));return n?(e.w=b[n[0].toLowerCase()],r+n[0].length):-1},b:function(e,t,r){var n=Le.exec(t.slice(r));return n?(e.m=De[n[0].toLowerCase()],r+n[0].length):-1},B:function(e,t,r){var n=_e.exec(t.slice(r));return n?(e.m=Re[n[0].toLowerCase()],r+n[0].length):-1},c:function(e,r,n){return Ve(e,t,r,n)},d:L,e:L,f:B,g:I,G:E,H:z,I:z,j:D,L:N,m:R,M:j,p:function(e,t,r){var n=y.exec(t.slice(r));return n?(e.p=v[n[0].toLowerCase()],r+n[0].length):-1},q:O,Q:U,s:H,S:F,u:A,U:T,V:M,w:S,W:C,x:function(e,t,n){return Ve(e,r,t,n)},X:function(e,t,r){return Ve(e,s,t,r)},y:I,Y:E,Z:P,"%":V};function Ne(e,t){return function(r){var n,i,o,a=[],s=-1,l=0,c=e.length;for(r instanceof Date||(r=new Date(+r));++s53)return null;"w"in h||(h.w=1),"Z"in h?(l=(s=u(d(h.y,0,1))).getUTCDay(),s=l>4||0===l?n.rt.ceil(s):(0,n.rt)(s),s=i.A.offset(s,7*(h.V-1)),h.y=s.getUTCFullYear(),h.m=s.getUTCMonth(),h.d=s.getUTCDate()+(h.w+6)%7):(l=(s=c(d(h.y,0,1))).getDay(),s=l>4||0===l?o.By.ceil(s):(0,o.By)(s),s=a.A.offset(s,7*(h.V-1)),h.y=s.getFullYear(),h.m=s.getMonth(),h.d=s.getDate()+(h.w+6)%7)}else("W"in h||"U"in h)&&("w"in h||(h.w="u"in h?h.u%7:"W"in h?1:0),l="Z"in h?u(d(h.y,0,1)).getUTCDay():c(d(h.y,0,1)).getDay(),h.m=0,h.d="W"in h?(h.w+6)%7+7*h.W-(l+5)%7:h.w+7*h.U-(l+6)%7);return"Z"in h?(h.H+=h.Z/100|0,h.M+=h.Z%100,u(h)):c(h)}}function Ve(e,t,r,n){for(var i,o,a=0,s=t.length,l=r.length;a=l)return-1;if(37===(i=t.charCodeAt(a++))){if(i=t.charAt(a++),!(o=Fe[i in g?t.charAt(a++):i])||(n=o(e,r,n))<0)return-1}else if(i!=r.charCodeAt(n++))return-1}return n}return ze.x=Ne(r,ze),ze.X=Ne(s,ze),ze.c=Ne(t,ze),je.x=Ne(r,je),je.X=Ne(s,je),je.c=Ne(t,je),{format:function(e){var t=Ne(e+="",ze);return t.toString=function(){return e},t},parse:function(e){var t=Be(e+="",!1);return t.toString=function(){return e},t},utcFormat:function(e){var t=Ne(e+="",je);return t.toString=function(){return e},t},utcParse:function(e){var t=Be(e+="",!0);return t.toString=function(){return e},t}}}var p,f,m,g={"-":"",_:" ",0:"0"},y=/^\s*\d+/,v=/^%/,x=/[\\^$*+?|[\]().{}]/g;function b(e,t,r){var n=e<0?"-":"",i=(n?-e:e)+"",o=i.length;return n+(o68?1900:2e3),r+n[0].length):-1}function P(e,t,r){var n=/^(Z)|([+-]\d\d)(?::?(\d\d))?/.exec(t.slice(r,r+6));return n?(e.Z=n[1]?0:-(n[2]+(n[3]||"00")),r+n[0].length):-1}function O(e,t,r){var n=y.exec(t.slice(r,r+1));return n?(e.q=3*n[0]-3,r+n[0].length):-1}function R(e,t,r){var n=y.exec(t.slice(r,r+2));return n?(e.m=n[0]-1,r+n[0].length):-1}function L(e,t,r){var n=y.exec(t.slice(r,r+2));return n?(e.d=+n[0],r+n[0].length):-1}function D(e,t,r){var n=y.exec(t.slice(r,r+3));return n?(e.m=0,e.d=+n[0],r+n[0].length):-1}function z(e,t,r){var n=y.exec(t.slice(r,r+2));return n?(e.H=+n[0],r+n[0].length):-1}function j(e,t,r){var n=y.exec(t.slice(r,r+2));return n?(e.M=+n[0],r+n[0].length):-1}function F(e,t,r){var n=y.exec(t.slice(r,r+2));return n?(e.S=+n[0],r+n[0].length):-1}function N(e,t,r){var n=y.exec(t.slice(r,r+3));return n?(e.L=+n[0],r+n[0].length):-1}function B(e,t,r){var n=y.exec(t.slice(r,r+6));return n?(e.L=Math.floor(n[0]/1e3),r+n[0].length):-1}function V(e,t,r){var n=v.exec(t.slice(r,r+1));return n?r+n[0].length:-1}function U(e,t,r){var n=y.exec(t.slice(r));return n?(e.Q=+n[0],r+n[0].length):-1}function H(e,t,r){var n=y.exec(t.slice(r));return n?(e.s=+n[0],r+n[0].length):-1}function $(e,t){return b(e.getDate(),t,2)}function W(e,t){return b(e.getHours(),t,2)}function q(e,t){return b(e.getHours()%12||12,t,2)}function G(e,t){return b(1+a.A.count((0,s.A)(e),e),t,3)}function Y(e,t){return b(e.getMilliseconds(),t,3)}function X(e,t){return Y(e,t)+"000"}function Z(e,t){return b(e.getMonth()+1,t,2)}function K(e,t){return b(e.getMinutes(),t,2)}function J(e,t){return b(e.getSeconds(),t,2)}function Q(e){var t=e.getDay();return 0===t?7:t}function ee(e,t){return b(o.fz.count((0,s.A)(e)-1,e),t,2)}function te(e){var t=e.getDay();return t>=4||0===t?(0,o.dt)(e):o.dt.ceil(e)}function re(e,t){return e=te(e),b(o.dt.count((0,s.A)(e),e)+(4===(0,s.A)(e).getDay()),t,2)}function ne(e){return e.getDay()}function ie(e,t){return b(o.By.count((0,s.A)(e)-1,e),t,2)}function oe(e,t){return b(e.getFullYear()%100,t,2)}function ae(e,t){return b((e=te(e)).getFullYear()%100,t,2)}function se(e,t){return b(e.getFullYear()%1e4,t,4)}function le(e,t){var r=e.getDay();return b((e=r>=4||0===r?(0,o.dt)(e):o.dt.ceil(e)).getFullYear()%1e4,t,4)}function ce(e){var t=e.getTimezoneOffset();return(t>0?"-":(t*=-1,"+"))+b(t/60|0,"0",2)+b(t%60,"0",2)}function ue(e,t){return b(e.getUTCDate(),t,2)}function de(e,t){return b(e.getUTCHours(),t,2)}function he(e,t){return b(e.getUTCHours()%12||12,t,2)}function pe(e,t){return b(1+i.A.count((0,l.A)(e),e),t,3)}function fe(e,t){return b(e.getUTCMilliseconds(),t,3)}function me(e,t){return fe(e,t)+"000"}function ge(e,t){return b(e.getUTCMonth()+1,t,2)}function ye(e,t){return b(e.getUTCMinutes(),t,2)}function ve(e,t){return b(e.getUTCSeconds(),t,2)}function xe(e){var t=e.getUTCDay();return 0===t?7:t}function be(e,t){return b(n.Hl.count((0,l.A)(e)-1,e),t,2)}function _e(e){var t=e.getUTCDay();return t>=4||0===t?(0,n.pT)(e):n.pT.ceil(e)}function we(e,t){return e=_e(e),b(n.pT.count((0,l.A)(e),e)+(4===(0,l.A)(e).getUTCDay()),t,2)}function ke(e){return e.getUTCDay()}function Se(e,t){return b(n.rt.count((0,l.A)(e)-1,e),t,2)}function Ae(e,t){return b(e.getUTCFullYear()%100,t,2)}function Te(e,t){return b((e=_e(e)).getUTCFullYear()%100,t,2)}function Me(e,t){return b(e.getUTCFullYear()%1e4,t,4)}function Ce(e,t){var r=e.getUTCDay();return b((e=r>=4||0===r?(0,n.pT)(e):n.pT.ceil(e)).getUTCFullYear()%1e4,t,4)}function Ee(){return"+0000"}function Ie(){return"%"}function Pe(e){return+e}function Oe(e){return Math.floor(+e/1e3)}p=h({dateTime:"%x, %X",date:"%-m/%-d/%Y",time:"%-I:%M:%S %p",periods:["AM","PM"],days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]}),f=p.format,p.parse,m=p.utcFormat,p.utcParse},8966:(e,t,r)=>{"use strict";r.d(t,{A:()=>a,_:()=>s});var n=r(19063),i=r(23758),o=(0,n.A)((function(e){e.setHours(0,0,0,0)}),(function(e,t){e.setDate(e.getDate()+t)}),(function(e,t){return(t-e-(t.getTimezoneOffset()-e.getTimezoneOffset())*i.rR)/i.Nm}),(function(e){return e.getDate()-1}));const a=o;var s=o.range},23758:(e,t,r)=>{"use strict";r.d(t,{Fq:()=>s,JJ:()=>o,Nm:()=>a,Tt:()=>n,rR:()=>i});var n=1e3,i=6e4,o=36e5,a=864e5,s=6048e5},32385:(e,t,r)=>{"use strict";r.r(t),r.d(t,{timeDay:()=>y.A,timeDays:()=>y._,timeFriday:()=>v.Sh,timeFridays:()=>v.tz,timeHour:()=>m,timeHours:()=>g,timeInterval:()=>n.A,timeMillisecond:()=>o,timeMilliseconds:()=>a,timeMinute:()=>h,timeMinutes:()=>p,timeMonday:()=>v.By,timeMondays:()=>v.KP,timeMonth:()=>b,timeMonths:()=>_,timeSaturday:()=>v.kS,timeSaturdays:()=>v.t$,timeSecond:()=>c,timeSeconds:()=>u,timeSunday:()=>v.fz,timeSundays:()=>v.se,timeThursday:()=>v.dt,timeThursdays:()=>v.Q$,timeTuesday:()=>v.eQ,timeTuesdays:()=>v.yW,timeWednesday:()=>v.l3,timeWednesdays:()=>v.gf,timeWeek:()=>v.fz,timeWeeks:()=>v.se,timeYear:()=>w.A,timeYears:()=>w.V,utcDay:()=>E.A,utcDays:()=>E.o,utcFriday:()=>I.a1,utcFridays:()=>I.Zn,utcHour:()=>M,utcHours:()=>C,utcMillisecond:()=>o,utcMilliseconds:()=>a,utcMinute:()=>S,utcMinutes:()=>A,utcMonday:()=>I.rt,utcMondays:()=>I.ON,utcMonth:()=>O,utcMonths:()=>R,utcSaturday:()=>I.c8,utcSaturdays:()=>I.Xo,utcSecond:()=>c,utcSeconds:()=>u,utcSunday:()=>I.Hl,utcSundays:()=>I.aZ,utcThursday:()=>I.pT,utcThursdays:()=>I.wr,utcTuesday:()=>I.sr,utcTuesdays:()=>I.jN,utcWednesday:()=>I.z2,utcWednesdays:()=>I.G6,utcWeek:()=>I.Hl,utcWeeks:()=>I.aZ,utcYear:()=>L.A,utcYears:()=>L.j});var n=r(19063),i=(0,n.A)((function(){}),(function(e,t){e.setTime(+e+t)}),(function(e,t){return t-e}));i.every=function(e){return e=Math.floor(e),isFinite(e)&&e>0?e>1?(0,n.A)((function(t){t.setTime(Math.floor(t/e)*e)}),(function(t,r){t.setTime(+t+r*e)}),(function(t,r){return(r-t)/e})):i:null};const o=i;var a=i.range,s=r(23758),l=(0,n.A)((function(e){e.setTime(e-e.getMilliseconds())}),(function(e,t){e.setTime(+e+t*s.Tt)}),(function(e,t){return(t-e)/s.Tt}),(function(e){return e.getUTCSeconds()}));const c=l;var u=l.range,d=(0,n.A)((function(e){e.setTime(e-e.getMilliseconds()-e.getSeconds()*s.Tt)}),(function(e,t){e.setTime(+e+t*s.rR)}),(function(e,t){return(t-e)/s.rR}),(function(e){return e.getMinutes()}));const h=d;var p=d.range,f=(0,n.A)((function(e){e.setTime(e-e.getMilliseconds()-e.getSeconds()*s.Tt-e.getMinutes()*s.rR)}),(function(e,t){e.setTime(+e+t*s.JJ)}),(function(e,t){return(t-e)/s.JJ}),(function(e){return e.getHours()}));const m=f;var g=f.range,y=r(8966),v=r(5038),x=(0,n.A)((function(e){e.setDate(1),e.setHours(0,0,0,0)}),(function(e,t){e.setMonth(e.getMonth()+t)}),(function(e,t){return t.getMonth()-e.getMonth()+12*(t.getFullYear()-e.getFullYear())}),(function(e){return e.getMonth()}));const b=x;var _=x.range,w=r(6883),k=(0,n.A)((function(e){e.setUTCSeconds(0,0)}),(function(e,t){e.setTime(+e+t*s.rR)}),(function(e,t){return(t-e)/s.rR}),(function(e){return e.getUTCMinutes()}));const S=k;var A=k.range,T=(0,n.A)((function(e){e.setUTCMinutes(0,0,0)}),(function(e,t){e.setTime(+e+t*s.JJ)}),(function(e,t){return(t-e)/s.JJ}),(function(e){return e.getUTCHours()}));const M=T;var C=T.range,E=r(17558),I=r(75838),P=(0,n.A)((function(e){e.setUTCDate(1),e.setUTCHours(0,0,0,0)}),(function(e,t){e.setUTCMonth(e.getUTCMonth()+t)}),(function(e,t){return t.getUTCMonth()-e.getUTCMonth()+12*(t.getUTCFullYear()-e.getUTCFullYear())}),(function(e){return e.getUTCMonth()}));const O=P;var R=P.range,L=r(72915)},19063:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=new Date,i=new Date;function o(e,t,r,a){function s(t){return e(t=0===arguments.length?new Date:new Date(+t)),t}return s.floor=function(t){return e(t=new Date(+t)),t},s.ceil=function(r){return e(r=new Date(r-1)),t(r,1),e(r),r},s.round=function(e){var t=s(e),r=s.ceil(e);return e-t0))return a;do{a.push(o=new Date(+r)),t(r,i),e(r)}while(o=t)for(;e(t),!r(t);)t.setTime(t-1)}),(function(e,n){if(e>=e)if(n<0)for(;++n<=0;)for(;t(e,-1),!r(e););else for(;--n>=0;)for(;t(e,1),!r(e););}))},r&&(s.count=function(t,o){return n.setTime(+t),i.setTime(+o),e(n),e(i),Math.floor(r(n,i))},s.every=function(e){return e=Math.floor(e),isFinite(e)&&e>0?e>1?s.filter(a?function(t){return a(t)%e===0}:function(t){return s.count(0,t)%e===0}):s:null}),s}},17558:(e,t,r)=>{"use strict";r.d(t,{A:()=>a,o:()=>s});var n=r(19063),i=r(23758),o=(0,n.A)((function(e){e.setUTCHours(0,0,0,0)}),(function(e,t){e.setUTCDate(e.getUTCDate()+t)}),(function(e,t){return(t-e)/i.Nm}),(function(e){return e.getUTCDate()-1}));const a=o;var s=o.range},75838:(e,t,r)=>{"use strict";r.d(t,{G6:()=>g,Hl:()=>a,ON:()=>f,Xo:()=>x,Zn:()=>v,a1:()=>d,aZ:()=>p,c8:()=>h,jN:()=>m,pT:()=>u,rt:()=>s,sr:()=>l,wr:()=>y,z2:()=>c});var n=r(19063),i=r(23758);function o(e){return(0,n.A)((function(t){t.setUTCDate(t.getUTCDate()-(t.getUTCDay()+7-e)%7),t.setUTCHours(0,0,0,0)}),(function(e,t){e.setUTCDate(e.getUTCDate()+7*t)}),(function(e,t){return(t-e)/i.Fq}))}var a=o(0),s=o(1),l=o(2),c=o(3),u=o(4),d=o(5),h=o(6),p=a.range,f=s.range,m=l.range,g=c.range,y=u.range,v=d.range,x=h.range},72915:(e,t,r)=>{"use strict";r.d(t,{A:()=>o,j:()=>a});var n=r(19063),i=(0,n.A)((function(e){e.setUTCMonth(0,1),e.setUTCHours(0,0,0,0)}),(function(e,t){e.setUTCFullYear(e.getUTCFullYear()+t)}),(function(e,t){return t.getUTCFullYear()-e.getUTCFullYear()}),(function(e){return e.getUTCFullYear()}));i.every=function(e){return isFinite(e=Math.floor(e))&&e>0?(0,n.A)((function(t){t.setUTCFullYear(Math.floor(t.getUTCFullYear()/e)*e),t.setUTCMonth(0,1),t.setUTCHours(0,0,0,0)}),(function(t,r){t.setUTCFullYear(t.getUTCFullYear()+r*e)})):null};const o=i;var a=i.range},5038:(e,t,r)=>{"use strict";r.d(t,{By:()=>s,KP:()=>f,Q$:()=>y,Sh:()=>d,dt:()=>u,eQ:()=>l,fz:()=>a,gf:()=>g,kS:()=>h,l3:()=>c,se:()=>p,t$:()=>x,tz:()=>v,yW:()=>m});var n=r(19063),i=r(23758);function o(e){return(0,n.A)((function(t){t.setDate(t.getDate()-(t.getDay()+7-e)%7),t.setHours(0,0,0,0)}),(function(e,t){e.setDate(e.getDate()+7*t)}),(function(e,t){return(t-e-(t.getTimezoneOffset()-e.getTimezoneOffset())*i.rR)/i.Fq}))}var a=o(0),s=o(1),l=o(2),c=o(3),u=o(4),d=o(5),h=o(6),p=a.range,f=s.range,m=l.range,g=c.range,y=u.range,v=d.range,x=h.range},6883:(e,t,r)=>{"use strict";r.d(t,{A:()=>o,V:()=>a});var n=r(19063),i=(0,n.A)((function(e){e.setMonth(0,1),e.setHours(0,0,0,0)}),(function(e,t){e.setFullYear(e.getFullYear()+t)}),(function(e,t){return t.getFullYear()-e.getFullYear()}),(function(e){return e.getFullYear()}));i.every=function(e){return isFinite(e=Math.floor(e))&&e>0?(0,n.A)((function(t){t.setFullYear(Math.floor(t.getFullYear()/e)*e),t.setMonth(0,1),t.setHours(0,0,0,0)}),(function(t,r){t.setFullYear(t.getFullYear()+r*e)})):null};const o=i;var a=i.range},74992:(e,t,r)=>{"use strict";var n=r(82090),i=r(62557),o=r(54902),a=r(95558);e.exports=function(e,t,r){if(!e||"object"!==typeof e&&"function"!==typeof e)throw new o("`obj` must be an object or a function`");if("string"!==typeof t&&"symbol"!==typeof t)throw new o("`property` must be a string or a symbol`");if(arguments.length>3&&"boolean"!==typeof arguments[3]&&null!==arguments[3])throw new o("`nonEnumerable`, if provided, must be a boolean or null");if(arguments.length>4&&"boolean"!==typeof arguments[4]&&null!==arguments[4])throw new o("`nonWritable`, if provided, must be a boolean or null");if(arguments.length>5&&"boolean"!==typeof arguments[5]&&null!==arguments[5])throw new o("`nonConfigurable`, if provided, must be a boolean or null");if(arguments.length>6&&"boolean"!==typeof arguments[6])throw new o("`loose`, if provided, must be a boolean");var s=arguments.length>3?arguments[3]:null,l=arguments.length>4?arguments[4]:null,c=arguments.length>5?arguments[5]:null,u=arguments.length>6&&arguments[6],d=!!a&&a(e,t);if(n)n(e,t,{configurable:null===c&&d?d.configurable:!c,enumerable:null===s&&d?d.enumerable:!s,value:r,writable:null===l&&d?d.writable:!l});else{if(!u&&(s||l||c))throw new i("This environment does not support defining a property as non-configurable, non-writable, or non-enumerable.");e[t]=r}}},11779:(e,t,r)=>{"use strict";var n=r(2678),i="function"===typeof Symbol&&"symbol"===typeof Symbol("foo"),o=Object.prototype.toString,a=Array.prototype.concat,s=r(74992),l=r(12101)(),c=function(e,t,r,n){if(t in e)if(!0===n){if(e[t]===r)return}else if("function"!==typeof(i=n)||"[object Function]"!==o.call(i)||!n())return;var i;l?s(e,t,r,!0):s(e,t,r)},u=function(e,t){var r=arguments.length>2?arguments[2]:{},o=n(t);i&&(o=a.call(o,Object.getOwnPropertySymbols(t)));for(var s=0;s{"use strict";e.exports=function(){for(var e=0;e{"use strict";e.exports=n;var t=(n.canvas=document.createElement("canvas")).getContext("2d"),r=i([32,126]);function n(e,n){Array.isArray(e)&&(e=e.join(", "));var o,a={},s=16,l=.05;n&&(2===n.length&&"number"===typeof n[0]?o=i(n):Array.isArray(n)?o=n:(n.o?o=i(n.o):n.pairs&&(o=n.pairs),n.fontSize&&(s=n.fontSize),null!=n.threshold&&(l=n.threshold))),o||(o=r),t.font=s+"px "+e;for(var c=0;cs*l){var p=(h-d)/s;a[u]=1e3*p}}return a}function i(e){for(var t=[],r=e[0];r<=e[1];r++)for(var n=String.fromCharCode(r),i=e[0];i{var n=r(31529),i=r(19775),o={M:"moveTo",C:"bezierCurveTo"};e.exports=function(e,t){e.beginPath(),i(n(t)).forEach((function(t){var r=t[0],n=t.slice(1);e[o[r]].apply(e,n)})),e.closePath()}},19775:e=>{var t=Math.PI,r=s(120);function n(e,t,r,n){return["C",e,t,r,n,r,n]}function i(e,t,r,n,i,o){return["C",e/3+2/3*r,t/3+2/3*n,i/3+2/3*r,o/3+2/3*n,i,o]}function o(e,n,i,s,l,c,u,d,h,p){if(p)k=p[0],S=p[1],_=p[2],w=p[3];else{var f=a(e,n,-l);e=f.x,n=f.y;var m=(e-(d=(f=a(d,h,-l)).x))/2,g=(n-(h=f.y))/2,y=m*m/(i*i)+g*g/(s*s);y>1&&(i*=y=Math.sqrt(y),s*=y);var v=i*i,x=s*s,b=(c==u?-1:1)*Math.sqrt(Math.abs((v*x-v*g*g-x*m*m)/(v*g*g+x*m*m)));b==1/0&&(b=1);var _=b*i*g/s+(e+d)/2,w=b*-s*m/i+(n+h)/2,k=Math.asin(((n-w)/s).toFixed(9)),S=Math.asin(((h-w)/s).toFixed(9));(k=e<_?t-k:k)<0&&(k=2*t+k),(S=d<_?t-S:S)<0&&(S=2*t+S),u&&k>S&&(k-=2*t),!u&&S>k&&(S-=2*t)}if(Math.abs(S-k)>r){var A=S,T=d,M=h;S=k+r*(u&&S>k?1:-1);var C=o(d=_+i*Math.cos(S),h=w+s*Math.sin(S),i,s,l,0,u,T,M,[S,A,_,w])}var E=Math.tan((S-k)/4),I=4/3*i*E,P=4/3*s*E,O=[2*e-(e+I*Math.sin(k)),2*n-(n-P*Math.cos(k)),d+I*Math.sin(S),h-P*Math.cos(S),d,h];if(p)return O;C&&(O=O.concat(C));for(var R=0;R7&&(r.push(y.splice(0,7)),y.unshift("C"));break;case"S":var x=p,b=f;"C"!=t&&"S"!=t||(x+=x-a,b+=b-l),y=["C",x,b,y[1],y[2],y[3],y[4]];break;case"T":"Q"==t||"T"==t?(d=2*p-d,h=2*f-h):(d=p,h=f),y=i(p,f,d,h,y[1],y[2]);break;case"Q":d=y[1],h=y[2],y=i(p,f,y[1],y[2],y[3],y[4]);break;case"L":y=n(p,f,y[1],y[2]);break;case"H":y=n(p,f,y[1],f);break;case"V":y=n(p,f,p,y[1]);break;case"Z":y=n(p,f,c,u)}t=v,p=y[y.length-2],f=y[y.length-1],y.length>4?(a=y[y.length-4],l=y[y.length-3]):(a=p,l=f),r.push(y)}return r}},12156:e=>{e.exports=function(e){switch(e){case"int8":return Int8Array;case"int16":return Int16Array;case"int32":return Int32Array;case"uint8":return Uint8Array;case"uint16":return Uint16Array;case"uint32":return Uint32Array;case"float32":return Float32Array;case"float64":return Float64Array;case"array":return Array;case"uint8_clamped":return Uint8ClampedArray}}},65100:e=>{"use strict";function t(e,r,n){var i=0|e[n];if(i<=0)return[];var o,a=new Array(i);if(n===e.length-1)for(o=0;o0)return function(e,t){var r,n;for(r=new Array(e),n=0;n{"use strict";function t(e,t,n){n=n||2;var o,a,s,l,d,h,f,m=t&&t.length,g=m?t[0]*n:e.length,y=r(e,0,g,n,!0),v=[];if(!y||y.next===y.prev)return v;if(m&&(y=function(e,t,n,i){var o,a,s,l=[];for(o=0,a=t.length;o80*n){o=s=e[0],a=l=e[1];for(var x=n;xs&&(s=d),h>l&&(l=h);f=0!==(f=Math.max(s-o,l-a))?32767/f:0}return i(y,v,n,o,a,f,0),v}function r(e,t,r,n,i){var o,a;if(i===T(e,t,r,n)>0)for(o=t;o=t;o-=n)a=k(o,e[o],e[o+1],a);return a&&y(a,a.next)&&(S(a),a=a.next),a}function n(e,t){if(!e)return e;t||(t=e);var r,n=e;do{if(r=!1,n.steiner||!y(n,n.next)&&0!==g(n.prev,n,n.next))n=n.next;else{if(S(n),(n=t=n.prev)===n.next)break;r=!0}}while(r||n!==t);return t}function i(e,t,r,c,u,d,p){if(e){!p&&d&&function(e,t,r,n){var i=e;do{0===i.z&&(i.z=h(i.x,i.y,t,r,n)),i.prevZ=i.prev,i.nextZ=i.next,i=i.next}while(i!==e);i.prevZ.nextZ=null,i.prevZ=null,function(e){var t,r,n,i,o,a,s,l,c=1;do{for(r=e,e=null,o=null,a=0;r;){for(a++,n=r,s=0,t=0;t0||l>0&&n;)0!==s&&(0===l||!n||r.z<=n.z)?(i=r,r=r.nextZ,s--):(i=n,n=n.nextZ,l--),o?o.nextZ=i:e=i,i.prevZ=o,o=i;r=n}o.nextZ=null,c*=2}while(a>1)}(i)}(e,c,u,d);for(var f,m,g=e;e.prev!==e.next;)if(f=e.prev,m=e.next,d?a(e,c,u,d):o(e))t.push(f.i/r|0),t.push(e.i/r|0),t.push(m.i/r|0),S(e),e=m.next,g=m.next;else if((e=m)===g){p?1===p?i(e=s(n(e),t,r),t,r,c,u,d,2):2===p&&l(e,t,r,c,u,d):i(n(e),t,r,c,u,d,1);break}}}function o(e){var t=e.prev,r=e,n=e.next;if(g(t,r,n)>=0)return!1;for(var i=t.x,o=r.x,a=n.x,s=t.y,l=r.y,c=n.y,u=io?i>a?i:a:o>a?o:a,p=s>l?s>c?s:c:l>c?l:c,m=n.next;m!==t;){if(m.x>=u&&m.x<=h&&m.y>=d&&m.y<=p&&f(i,s,o,l,a,c,m.x,m.y)&&g(m.prev,m,m.next)>=0)return!1;m=m.next}return!0}function a(e,t,r,n){var i=e.prev,o=e,a=e.next;if(g(i,o,a)>=0)return!1;for(var s=i.x,l=o.x,c=a.x,u=i.y,d=o.y,p=a.y,m=sl?s>c?s:c:l>c?l:c,x=u>d?u>p?u:p:d>p?d:p,b=h(m,y,t,r,n),_=h(v,x,t,r,n),w=e.prevZ,k=e.nextZ;w&&w.z>=b&&k&&k.z<=_;){if(w.x>=m&&w.x<=v&&w.y>=y&&w.y<=x&&w!==i&&w!==a&&f(s,u,l,d,c,p,w.x,w.y)&&g(w.prev,w,w.next)>=0)return!1;if(w=w.prevZ,k.x>=m&&k.x<=v&&k.y>=y&&k.y<=x&&k!==i&&k!==a&&f(s,u,l,d,c,p,k.x,k.y)&&g(k.prev,k,k.next)>=0)return!1;k=k.nextZ}for(;w&&w.z>=b;){if(w.x>=m&&w.x<=v&&w.y>=y&&w.y<=x&&w!==i&&w!==a&&f(s,u,l,d,c,p,w.x,w.y)&&g(w.prev,w,w.next)>=0)return!1;w=w.prevZ}for(;k&&k.z<=_;){if(k.x>=m&&k.x<=v&&k.y>=y&&k.y<=x&&k!==i&&k!==a&&f(s,u,l,d,c,p,k.x,k.y)&&g(k.prev,k,k.next)>=0)return!1;k=k.nextZ}return!0}function s(e,t,r){var i=e;do{var o=i.prev,a=i.next.next;!y(o,a)&&v(o,i,i.next,a)&&_(o,a)&&_(a,o)&&(t.push(o.i/r|0),t.push(i.i/r|0),t.push(a.i/r|0),S(i),S(i.next),i=e=a),i=i.next}while(i!==e);return n(i)}function l(e,t,r,o,a,s){var l=e;do{for(var c=l.next.next;c!==l.prev;){if(l.i!==c.i&&m(l,c)){var u=w(l,c);return l=n(l,l.next),u=n(u,u.next),i(l,t,r,o,a,s,0),void i(u,t,r,o,a,s,0)}c=c.next}l=l.next}while(l!==e)}function c(e,t){return e.x-t.x}function u(e,t){var r=function(e,t){var r,n=t,i=e.x,o=e.y,a=-1/0;do{if(o<=n.y&&o>=n.next.y&&n.next.y!==n.y){var s=n.x+(o-n.y)*(n.next.x-n.x)/(n.next.y-n.y);if(s<=i&&s>a&&(a=s,r=n.x=n.x&&n.x>=u&&i!==n.x&&f(or.x||n.x===r.x&&d(r,n)))&&(r=n,p=l)),n=n.next}while(n!==c);return r}(e,t);if(!r)return t;var i=w(r,e);return n(i,i.next),n(r,r.next)}function d(e,t){return g(e.prev,e,t.prev)<0&&g(t.next,e,e.next)<0}function h(e,t,r,n,i){return(e=1431655765&((e=858993459&((e=252645135&((e=16711935&((e=(e-r)*i|0)|e<<8))|e<<4))|e<<2))|e<<1))|(t=1431655765&((t=858993459&((t=252645135&((t=16711935&((t=(t-n)*i|0)|t<<8))|t<<4))|t<<2))|t<<1))<<1}function p(e){var t=e,r=e;do{(t.x=(e-a)*(o-s)&&(e-a)*(n-s)>=(r-a)*(t-s)&&(r-a)*(o-s)>=(i-a)*(n-s)}function m(e,t){return e.next.i!==t.i&&e.prev.i!==t.i&&!function(e,t){var r=e;do{if(r.i!==e.i&&r.next.i!==e.i&&r.i!==t.i&&r.next.i!==t.i&&v(r,r.next,e,t))return!0;r=r.next}while(r!==e);return!1}(e,t)&&(_(e,t)&&_(t,e)&&function(e,t){var r=e,n=!1,i=(e.x+t.x)/2,o=(e.y+t.y)/2;do{r.y>o!==r.next.y>o&&r.next.y!==r.y&&i<(r.next.x-r.x)*(o-r.y)/(r.next.y-r.y)+r.x&&(n=!n),r=r.next}while(r!==e);return n}(e,t)&&(g(e.prev,e,t.prev)||g(e,t.prev,t))||y(e,t)&&g(e.prev,e,e.next)>0&&g(t.prev,t,t.next)>0)}function g(e,t,r){return(t.y-e.y)*(r.x-t.x)-(t.x-e.x)*(r.y-t.y)}function y(e,t){return e.x===t.x&&e.y===t.y}function v(e,t,r,n){var i=b(g(e,t,r)),o=b(g(e,t,n)),a=b(g(r,n,e)),s=b(g(r,n,t));return i!==o&&a!==s||(!(0!==i||!x(e,r,t))||(!(0!==o||!x(e,n,t))||(!(0!==a||!x(r,e,n))||!(0!==s||!x(r,t,n)))))}function x(e,t,r){return t.x<=Math.max(e.x,r.x)&&t.x>=Math.min(e.x,r.x)&&t.y<=Math.max(e.y,r.y)&&t.y>=Math.min(e.y,r.y)}function b(e){return e>0?1:e<0?-1:0}function _(e,t){return g(e.prev,e,e.next)<0?g(e,t,e.next)>=0&&g(e,e.prev,t)>=0:g(e,t,e.prev)<0||g(e,e.next,t)<0}function w(e,t){var r=new A(e.i,e.x,e.y),n=new A(t.i,t.x,t.y),i=e.next,o=t.prev;return e.next=t,t.prev=e,r.next=i,i.prev=r,n.next=r,r.prev=n,o.next=n,n.prev=o,n}function k(e,t,r,n){var i=new A(e,t,r);return n?(i.next=n.next,i.prev=n,n.next.prev=i,n.next=i):(i.prev=i,i.next=i),i}function S(e){e.next.prev=e.prev,e.prev.next=e.next,e.prevZ&&(e.prevZ.nextZ=e.nextZ),e.nextZ&&(e.nextZ.prevZ=e.prevZ)}function A(e,t,r){this.i=e,this.x=t,this.y=r,this.prev=null,this.next=null,this.z=0,this.prevZ=null,this.nextZ=null,this.steiner=!1}function T(e,t,r,n){for(var i=0,o=t,a=r-n;o0&&(n+=e[i-1].length,r.holes.push(n))}return r}},17994:(e,t,r)=>{var n=r(76330);e.exports=function(e,t){var r,i=[],o=[],a=[],s={},l=[];function c(e){a[e]=!1,s.hasOwnProperty(e)&&Object.keys(s[e]).forEach((function(t){delete s[e][t],a[t]&&c(t)}))}function u(e){var t,n,i=!1;for(o.push(e),a[e]=!0,t=0;t=t}))}(t);for(var r,i=n(e).components.filter((function(e){return e.length>1})),o=1/0,a=0;a{"use strict";var n=r(60002)("%Object.defineProperty%",!0)||!1;if(n)try{n({},"a",{value:1})}catch(i){n=!1}e.exports=n},79820:e=>{"use strict";e.exports=EvalError},29304:e=>{"use strict";e.exports=Error},1725:e=>{"use strict";e.exports=RangeError},75077:e=>{"use strict";e.exports=ReferenceError},62557:e=>{"use strict";e.exports=SyntaxError},54902:e=>{"use strict";e.exports=TypeError},63094:e=>{"use strict";e.exports=URIError},20404:(e,t,r)=>{"use strict";var n=r(99047);e.exports=function(){return n(this).length=0,this}},94428:(e,t,r)=>{"use strict";e.exports=r(12659)()?Array.from:r(57011)},12659:e=>{"use strict";e.exports=function(){var e,t,r=Array.from;return"function"===typeof r&&(t=r(e=["raz","dwa"]),Boolean(t&&t!==e&&"dwa"===t[1]))}},57011:(e,t,r)=>{"use strict";var n=r(99565).iterator,i=r(6697),o=r(27901),a=r(9818),s=r(89647),l=r(99047),c=r(86297),u=r(45417),d=Array.isArray,h=Function.prototype.call,p={configurable:!0,enumerable:!0,writable:!0,value:null},f=Object.defineProperty;e.exports=function(e){var t,r,m,g,y,v,x,b,_,w,k=arguments[1],S=arguments[2];if(e=Object(l(e)),c(k)&&s(k),this&&this!==Array&&o(this))t=this;else{if(!k){if(i(e))return 1!==(y=e.length)?Array.apply(null,e):((g=new Array(1))[0]=e[0],g);if(d(e)){for(g=new Array(y=e.length),r=0;r=55296&&v<=56319&&(w+=e[++r]),w=k?h.call(k,S,w,m):w,t?(p.value=w,f(g,m,p)):g[m]=w,++m;y=m}if(void 0===y)for(y=a(e.length),t&&(g=new t(y)),r=0;r{"use strict";var t=Object.prototype.toString,r=t.call(function(){return arguments}());e.exports=function(e){return t.call(e)===r}},27901:e=>{"use strict";var t=Object.prototype.toString,r=RegExp.prototype.test.bind(/^[object [A-Za-z0-9]*Function]$/);e.exports=function(e){return"function"===typeof e&&r(t.call(e))}},73116:e=>{"use strict";e.exports=function(){}},72884:(e,t,r)=>{"use strict";e.exports=r(26267)()?Math.sign:r(61051)},26267:e=>{"use strict";e.exports=function(){var e=Math.sign;return"function"===typeof e&&(1===e(10)&&-1===e(-20))}},61051:e=>{"use strict";e.exports=function(e){return e=Number(e),isNaN(e)||0===e?e:e>0?1:-1}},64449:(e,t,r)=>{"use strict";var n=r(72884),i=Math.abs,o=Math.floor;e.exports=function(e){return isNaN(e)?0:0!==(e=Number(e))&&isFinite(e)?n(e)*o(i(e)):e}},9818:(e,t,r)=>{"use strict";var n=r(64449),i=Math.max;e.exports=function(e){return i(0,n(e))}},79628:(e,t,r)=>{"use strict";var n=r(89647),i=r(99047),o=Function.prototype.bind,a=Function.prototype.call,s=Object.keys,l=Object.prototype.propertyIsEnumerable;e.exports=function(e,t){return function(r,c){var u,d=arguments[2],h=arguments[3];return r=Object(i(r)),n(c),u=s(r),h&&u.sort("function"===typeof h?o.call(h,r):void 0),"function"!==typeof e&&(e=u[e]),a.call(e,u,(function(e,n){return l.call(r,e)?a.call(c,d,r[e],e,r,n):t}))}}},53692:(e,t,r)=>{"use strict";e.exports=r(37366)()?Object.assign:r(84734)},37366:e=>{"use strict";e.exports=function(){var e,t=Object.assign;return"function"===typeof t&&(t(e={foo:"raz"},{bar:"dwa"},{trzy:"trzy"}),e.foo+e.bar+e.trzy==="razdwatrzy")}},84734:(e,t,r)=>{"use strict";var n=r(6706),i=r(99047),o=Math.max;e.exports=function(e,t){var r,a,s,l=o(arguments.length,2);for(e=Object(i(e)),s=function(n){try{e[n]=t[n]}catch(i){r||(r=i)}},a=1;a{"use strict";var n=r(94428),i=r(53692),o=r(99047);e.exports=function(e){var t=Object(o(e)),r=arguments[1],a=Object(arguments[2]);if(t!==e&&!r)return t;var s={};return r?n(r,(function(t){(a.ensure||t in e)&&(s[t]=e[t])})):i(s,e),s}},7665:(e,t,r)=>{"use strict";var n,i=Object.create;r(5132)()||(n=r(74656)),e.exports=function(){var e,t,r;return n?1!==n.level?i:(e={},t={},r={configurable:!1,enumerable:!1,writable:!0,value:void 0},Object.getOwnPropertyNames(Object.prototype).forEach((function(e){t[e]="__proto__"!==e?r:{configurable:!0,enumerable:!1,writable:!0,value:void 0}})),Object.defineProperties(e,t),Object.defineProperty(n,"nullPolyfill",{configurable:!1,enumerable:!1,writable:!1,value:e}),function(t,r){return i(null===t?e:t,r)}):i}()},86462:(e,t,r)=>{"use strict";e.exports=r(79628)("forEach")},21737:(e,t,r)=>{"use strict";var n=r(86297),i={function:!0,object:!0};e.exports=function(e){return n(e)&&i[typeof e]||!1}},86297:(e,t,r)=>{"use strict";var n=r(73116)();e.exports=function(e){return e!==n&&null!==e}},6706:(e,t,r)=>{"use strict";e.exports=r(74777)()?Object.keys:r(78213)},74777:e=>{"use strict";e.exports=function(){try{return Object.keys("primitive"),!0}catch(e){return!1}}},78213:(e,t,r)=>{"use strict";var n=r(86297),i=Object.keys;e.exports=function(e){return i(n(e)?Object(e):e)}},60731:(e,t,r)=>{"use strict";var n=r(89647),i=r(86462),o=Function.prototype.call;e.exports=function(e,t){var r={},a=arguments[2];return n(t),i(e,(function(e,n,i,s){r[n]=o.call(t,a,e,n,i,s)})),r}},9733:(e,t,r)=>{"use strict";var n=r(86297),i=Array.prototype.forEach,o=Object.create;e.exports=function(e){var t=o(null);return i.call(arguments,(function(e){n(e)&&function(e,t){var r;for(r in e)t[r]=e[r]}(Object(e),t)})),t}},4245:(e,t,r)=>{"use strict";e.exports=r(5132)()?Object.setPrototypeOf:r(74656)},5132:e=>{"use strict";var t=Object.create,r=Object.getPrototypeOf,n={};e.exports=function(){var e=Object.setPrototypeOf;return"function"===typeof e&&r(e((arguments[0]||t)(null),n))===n}},74656:(e,t,r)=>{"use strict";var n,i=r(21737),o=r(99047),a=Object.prototype.isPrototypeOf,s=Object.defineProperty,l={configurable:!0,enumerable:!1,writable:!0,value:void 0};n=function(e,t){if(o(e),null===t||i(t))return e;throw new TypeError("Prototype must be null or an object")},e.exports=function(e){var t,r;return e?(2===e.level?e.set?(r=e.set,t=function(e,t){return r.call(n(e,t),t),e}):t=function(e,t){return n(e,t).__proto__=t,e}:t=function e(t,r){var i;return n(t,r),(i=a.call(e.nullPolyfill,t))&&delete e.nullPolyfill.__proto__,null===r&&(r=e.nullPolyfill),t.__proto__=r,i&&s(e.nullPolyfill,"__proto__",l),t},Object.defineProperty(t,"level",{configurable:!1,enumerable:!1,writable:!1,value:e.level})):null}(function(){var e,t=Object.create(null),r={},n=Object.getOwnPropertyDescriptor(Object.prototype,"__proto__");if(n){try{(e=n.set).call(t,r)}catch(i){}if(Object.getPrototypeOf(t)===r)return{set:e,level:2}}return t.__proto__=r,Object.getPrototypeOf(t)===r?{level:2}:((t={}).__proto__=r,Object.getPrototypeOf(t)===r&&{level:1})}()),r(7665)},89647:e=>{"use strict";e.exports=function(e){if("function"!==typeof e)throw new TypeError(e+" is not a function");return e}},4335:(e,t,r)=>{"use strict";var n=r(21737);e.exports=function(e){if(!n(e))throw new TypeError(e+" is not an Object");return e}},99047:(e,t,r)=>{"use strict";var n=r(86297);e.exports=function(e){if(!n(e))throw new TypeError("Cannot use null or undefined");return e}},13423:(e,t,r)=>{"use strict";e.exports=r(85398)()?String.prototype.contains:r(88382)},85398:e=>{"use strict";var t="razdwatrzy";e.exports=function(){return"function"===typeof t.contains&&(!0===t.contains("dwa")&&!1===t.contains("foo"))}},88382:e=>{"use strict";var t=String.prototype.indexOf;e.exports=function(e){return t.call(this,e,arguments[1])>-1}},45417:e=>{"use strict";var t=Object.prototype.toString,r=t.call("");e.exports=function(e){return"string"===typeof e||e&&"object"===typeof e&&(e instanceof String||t.call(e)===r)||!1}},92819:e=>{"use strict";var t=Object.create(null),r=Math.random;e.exports=function(){var e;do{e=r().toString(36).slice(2)}while(t[e]);return e}},55762:(e,t,r)=>{"use strict";var n,i=r(4245),o=r(13423),a=r(8276),s=r(99565),l=r(12631),c=Object.defineProperty;n=e.exports=function(e,t){if(!(this instanceof n))throw new TypeError("Constructor requires 'new'");l.call(this,e),t=t?o.call(t,"key+value")?"key+value":o.call(t,"key")?"key":"value":"value",c(this,"__kind__",a("",t))},i&&i(n,l),delete n.prototype.constructor,n.prototype=Object.create(l.prototype,{_resolve:a((function(e){return"value"===this.__kind__?this.__list__[e]:"key+value"===this.__kind__?[e,this.__list__[e]]:e}))}),c(n.prototype,s.toStringTag,a("c","Array Iterator"))},63672:(e,t,r)=>{"use strict";var n=r(6697),i=r(89647),o=r(45417),a=r(92071),s=Array.isArray,l=Function.prototype.call,c=Array.prototype.some;e.exports=function(e,t){var r,u,d,h,p,f,m,g,y=arguments[2];if(s(e)||n(e)?r="array":o(e)?r="string":e=a(e),i(t),d=function(){h=!0},"array"!==r)if("string"!==r)for(u=e.next();!u.done;){if(l.call(t,y,u.value,d),h)return;u=e.next()}else for(f=e.length,p=0;p=55296&&g<=56319&&(m+=e[++p]),l.call(t,y,m,d),!h);++p);else c.call(e,(function(e){return l.call(t,y,e,d),h}))}},92071:(e,t,r)=>{"use strict";var n=r(6697),i=r(45417),o=r(55762),a=r(27350),s=r(45972),l=r(99565).iterator;e.exports=function(e){return"function"===typeof s(e)[l]?e[l]():n(e)?new o(e):i(e)?new a(e):new o(e)}},12631:(e,t,r)=>{"use strict";var n,i=r(20404),o=r(53692),a=r(89647),s=r(99047),l=r(8276),c=r(21665),u=r(99565),d=Object.defineProperty,h=Object.defineProperties;e.exports=n=function(e,t){if(!(this instanceof n))throw new TypeError("Constructor requires 'new'");h(this,{__list__:l("w",s(e)),__context__:l("w",t),__nextIndex__:l("w",0)}),t&&(a(t.on),t.on("_add",this._onAdd),t.on("_delete",this._onDelete),t.on("_clear",this._onClear))},delete n.prototype.constructor,h(n.prototype,o({_next:l((function(){var e;if(this.__list__)return this.__redo__&&void 0!==(e=this.__redo__.shift())?e:this.__nextIndex__=this.__nextIndex__||(++this.__nextIndex__,this.__redo__?(this.__redo__.forEach((function(t,r){t>=e&&(this.__redo__[r]=++t)}),this),this.__redo__.push(e)):d(this,"__redo__",l("c",[e])))})),_onDelete:l((function(e){var t;e>=this.__nextIndex__||(--this.__nextIndex__,this.__redo__&&(-1!==(t=this.__redo__.indexOf(e))&&this.__redo__.splice(t,1),this.__redo__.forEach((function(t,r){t>e&&(this.__redo__[r]=--t)}),this)))})),_onClear:l((function(){this.__redo__&&i.call(this.__redo__),this.__nextIndex__=0}))}))),d(n.prototype,u.iterator,l((function(){return this})))},28746:(e,t,r)=>{"use strict";var n=r(6697),i=r(86297),o=r(45417),a=r(99565).iterator,s=Array.isArray;e.exports=function(e){return!!i(e)&&(!!s(e)||(!!o(e)||(!!n(e)||"function"===typeof e[a])))}},27350:(e,t,r)=>{"use strict";var n,i=r(4245),o=r(8276),a=r(99565),s=r(12631),l=Object.defineProperty;n=e.exports=function(e){if(!(this instanceof n))throw new TypeError("Constructor requires 'new'");e=String(e),s.call(this,e),l(this,"__length__",o("",e.length))},i&&i(n,s),delete n.prototype.constructor,n.prototype=Object.create(s.prototype,{_next:o((function(){if(this.__list__)return this.__nextIndex__=55296&&t<=56319?r+this.__list__[this.__nextIndex__++]:r}))}),l(n.prototype,a.toStringTag,o("c","String Iterator"))},45972:(e,t,r)=>{"use strict";var n=r(28746);e.exports=function(e){if(!n(e))throw new TypeError(e+" is not iterable");return e}},99565:(e,t,r)=>{"use strict";e.exports=r(95860)()?r(36230).Symbol:r(85482)},95860:(e,t,r)=>{"use strict";var n=r(36230),i={object:!0,symbol:!0};e.exports=function(){var e,t=n.Symbol;if("function"!==typeof t)return!1;e=t("test symbol");try{String(e)}catch(r){return!1}return!!i[typeof t.iterator]&&(!!i[typeof t.toPrimitive]&&!!i[typeof t.toStringTag])}},6322:e=>{"use strict";e.exports=function(e){return!!e&&("symbol"===typeof e||!!e.constructor&&("Symbol"===e.constructor.name&&"Symbol"===e[e.constructor.toStringTag]))}},40172:(e,t,r)=>{"use strict";var n=r(8276),i=Object.create,o=Object.defineProperty,a=Object.prototype,s=i(null);e.exports=function(e){for(var t,r,i=0;s[e+(i||"")];)++i;return s[e+=i||""]=!0,o(a,t="@@"+e,n.gs(null,(function(e){r||(r=!0,o(this,t,n(e)),r=!1)}))),t}},27165:(e,t,r)=>{"use strict";var n=r(8276),i=r(36230).Symbol;e.exports=function(e){return Object.defineProperties(e,{hasInstance:n("",i&&i.hasInstance||e("hasInstance")),isConcatSpreadable:n("",i&&i.isConcatSpreadable||e("isConcatSpreadable")),iterator:n("",i&&i.iterator||e("iterator")),match:n("",i&&i.match||e("match")),replace:n("",i&&i.replace||e("replace")),search:n("",i&&i.search||e("search")),species:n("",i&&i.species||e("species")),split:n("",i&&i.split||e("split")),toPrimitive:n("",i&&i.toPrimitive||e("toPrimitive")),toStringTag:n("",i&&i.toStringTag||e("toStringTag")),unscopables:n("",i&&i.unscopables||e("unscopables"))})}},74111:(e,t,r)=>{"use strict";var n=r(8276),i=r(82132),o=Object.create(null);e.exports=function(e){return Object.defineProperties(e,{for:n((function(t){return o[t]?o[t]:o[t]=e(String(t))})),keyFor:n((function(e){var t;for(t in i(e),o)if(o[t]===e)return t}))})}},85482:(e,t,r)=>{"use strict";var n,i,o,a=r(8276),s=r(82132),l=r(36230).Symbol,c=r(40172),u=r(27165),d=r(74111),h=Object.create,p=Object.defineProperties,f=Object.defineProperty;if("function"===typeof l)try{String(l()),o=!0}catch(m){}else l=null;i=function(e){if(this instanceof i)throw new TypeError("Symbol is not a constructor");return n(e)},e.exports=n=function e(t){var r;if(this instanceof e)throw new TypeError("Symbol is not a constructor");return o?l(t):(r=h(i.prototype),t=void 0===t?"":String(t),p(r,{__description__:a("",t),__name__:a("",c(t))}))},u(n),d(n),p(i.prototype,{constructor:a(n),toString:a("",(function(){return this.__name__}))}),p(n.prototype,{toString:a((function(){return"Symbol ("+s(this).__description__+")"})),valueOf:a((function(){return s(this)}))}),f(n.prototype,n.toPrimitive,a("",(function(){var e=s(this);return"symbol"===typeof e?e:e.toString()}))),f(n.prototype,n.toStringTag,a("c","Symbol")),f(i.prototype,n.toStringTag,a("c",n.prototype[n.toStringTag])),f(i.prototype,n.toPrimitive,a("c",n.prototype[n.toPrimitive]))},82132:(e,t,r)=>{"use strict";var n=r(6322);e.exports=function(e){if(!n(e))throw new TypeError(e+" is not a symbol");return e}},84210:(e,t,r)=>{"use strict";e.exports=r(15065)()?WeakMap:r(49203)},15065:e=>{"use strict";e.exports=function(){var e,t;if("function"!==typeof WeakMap)return!1;try{e=new WeakMap([[t={},"one"],[{},"two"],[{},"three"]])}catch(r){return!1}return"[object WeakMap]"===String(e)&&("function"===typeof e.set&&(e.set({},1)===e&&("function"===typeof e.delete&&("function"===typeof e.has&&"one"===e.get(t)))))}},387:e=>{"use strict";e.exports="function"===typeof WeakMap&&"[object WeakMap]"===Object.prototype.toString.call(new WeakMap)},49203:(e,t,r)=>{"use strict";var n,i=r(86297),o=r(4245),a=r(4335),s=r(99047),l=r(92819),c=r(8276),u=r(92071),d=r(63672),h=r(99565).toStringTag,p=r(387),f=Array.isArray,m=Object.defineProperty,g=Object.prototype.hasOwnProperty,y=Object.getPrototypeOf;e.exports=n=function(){var e,t=arguments[0];if(!(this instanceof n))throw new TypeError("Constructor requires 'new'");return e=p&&o&&WeakMap!==n?o(new WeakMap,y(this)):this,i(t)&&(f(t)||(t=u(t))),m(e,"__weakMapData__",c("c","$weakMap$"+l())),t?(d(t,(function(t){s(t),e.set(t[0],t[1])})),e):e},p&&(o&&o(n,WeakMap),n.prototype=Object.create(WeakMap.prototype,{constructor:c(n)})),Object.defineProperties(n.prototype,{delete:c((function(e){return!!g.call(a(e),this.__weakMapData__)&&(delete e[this.__weakMapData__],!0)})),get:c((function(e){if(g.call(a(e),this.__weakMapData__))return e[this.__weakMapData__]})),has:c((function(e){return g.call(a(e),this.__weakMapData__)})),set:c((function(e,t){return m(a(e),this.__weakMapData__,c("c",t)),this})),toString:c((function(){return"[object WeakMap]"}))}),m(n.prototype,h,c("c","WeakMap"))},27284:e=>{"use strict";var t,r="object"===typeof Reflect?Reflect:null,n=r&&"function"===typeof r.apply?r.apply:function(e,t,r){return Function.prototype.apply.call(e,t,r)};t=r&&"function"===typeof r.ownKeys?r.ownKeys:Object.getOwnPropertySymbols?function(e){return Object.getOwnPropertyNames(e).concat(Object.getOwnPropertySymbols(e))}:function(e){return Object.getOwnPropertyNames(e)};var i=Number.isNaN||function(e){return e!==e};function o(){o.init.call(this)}e.exports=o,e.exports.once=function(e,t){return new Promise((function(r,n){function i(r){e.removeListener(t,o),n(r)}function o(){"function"===typeof e.removeListener&&e.removeListener("error",i),r([].slice.call(arguments))}m(e,t,o,{once:!0}),"error"!==t&&function(e,t,r){"function"===typeof e.on&&m(e,"error",t,r)}(e,i,{once:!0})}))},o.EventEmitter=o,o.prototype._events=void 0,o.prototype._eventsCount=0,o.prototype._maxListeners=void 0;var a=10;function s(e){if("function"!==typeof e)throw new TypeError('The "listener" argument must be of type Function. Received type '+typeof e)}function l(e){return void 0===e._maxListeners?o.defaultMaxListeners:e._maxListeners}function c(e,t,r,n){var i,o,a,c;if(s(r),void 0===(o=e._events)?(o=e._events=Object.create(null),e._eventsCount=0):(void 0!==o.newListener&&(e.emit("newListener",t,r.listener?r.listener:r),o=e._events),a=o[t]),void 0===a)a=o[t]=r,++e._eventsCount;else if("function"===typeof a?a=o[t]=n?[r,a]:[a,r]:n?a.unshift(r):a.push(r),(i=l(e))>0&&a.length>i&&!a.warned){a.warned=!0;var u=new Error("Possible EventEmitter memory leak detected. "+a.length+" "+String(t)+" listeners added. Use emitter.setMaxListeners() to increase limit");u.name="MaxListenersExceededWarning",u.emitter=e,u.type=t,u.count=a.length,c=u,console&&console.warn&&console.warn(c)}return e}function u(){if(!this.fired)return this.target.removeListener(this.type,this.wrapFn),this.fired=!0,0===arguments.length?this.listener.call(this.target):this.listener.apply(this.target,arguments)}function d(e,t,r){var n={fired:!1,wrapFn:void 0,target:e,type:t,listener:r},i=u.bind(n);return i.listener=r,n.wrapFn=i,i}function h(e,t,r){var n=e._events;if(void 0===n)return[];var i=n[t];return void 0===i?[]:"function"===typeof i?r?[i.listener||i]:[i]:r?function(e){for(var t=new Array(e.length),r=0;r0&&(a=t[0]),a instanceof Error)throw a;var s=new Error("Unhandled error."+(a?" ("+a.message+")":""));throw s.context=a,s}var l=o[e];if(void 0===l)return!1;if("function"===typeof l)n(l,this,t);else{var c=l.length,u=f(l,c);for(r=0;r=0;o--)if(r[o]===t||r[o].listener===t){a=r[o].listener,i=o;break}if(i<0)return this;0===i?r.shift():function(e,t){for(;t+1=0;n--)this.removeListener(e,t[n]);return this},o.prototype.listeners=function(e){return h(this,e,!0)},o.prototype.rawListeners=function(e){return h(this,e,!1)},o.listenerCount=function(e,t){return"function"===typeof e.listenerCount?e.listenerCount(t):p.call(e,t)},o.prototype.listenerCount=p,o.prototype.eventNames=function(){return this._eventsCount>0?t(this._events):[]}},24286:e=>{var t=function(){if("object"===typeof self&&self)return self;if("object"===typeof window&&window)return window;throw new Error("Unable to resolve global `this`")};e.exports=function(){if(this)return this;try{Object.defineProperty(Object.prototype,"__global__",{get:function(){return this},configurable:!0})}catch(e){return t()}try{return __global__||t()}finally{delete Object.prototype.__global__}}()},36230:(e,t,r)=>{"use strict";e.exports=r(43853)()?globalThis:r(24286)},43853:e=>{"use strict";e.exports=function(){return"object"===typeof globalThis&&(!!globalThis&&globalThis.Array===Array)}},122:e=>{"use strict";e.exports=function e(t,r){if(t===r)return!0;if(t&&r&&"object"==typeof t&&"object"==typeof r){if(t.constructor!==r.constructor)return!1;var n,i,o;if(Array.isArray(t)){if((n=t.length)!=r.length)return!1;for(i=n;0!==i--;)if(!e(t[i],r[i]))return!1;return!0}if(t.constructor===RegExp)return t.source===r.source&&t.flags===r.flags;if(t.valueOf!==Object.prototype.valueOf)return t.valueOf()===r.valueOf();if(t.toString!==Object.prototype.toString)return t.toString()===r.toString();if((n=(o=Object.keys(t)).length)!==Object.keys(r).length)return!1;for(i=n;0!==i--;)if(!Object.prototype.hasOwnProperty.call(r,o[i]))return!1;for(i=n;0!==i--;){var a=o[i];if(!e(t[a],r[a]))return!1}return!0}return t!==t&&r!==r}},22036:(e,t,r)=>{"use strict";var n=r(45665);e.exports=function(e){var t=typeof e;if("string"===t){var r=e;if(0===(e=+e)&&n(r))return!1}else if("number"!==t)return!1;return e-e<1}},67014:(e,t,r)=>{var n=r(12156);e.exports=function(e,t,r){if(!e)throw new TypeError("must specify data as first parameter");if(r=0|+(r||0),Array.isArray(e)&&e[0]&&"number"===typeof e[0][0]){var i,o,a,s,l=e[0].length,c=e.length*l;t&&"string"!==typeof t||(t=new(n(t||"float32"))(c+r));var u=t.length-r;if(c!==u)throw new Error("source length "+c+" ("+l+"x"+e.length+") does not match destination length "+u);for(i=0,a=r;i{"use strict";var n=r(47506),i=[32,126];e.exports=function(e){var t=(e=e||{}).shape?e.shape:e.canvas?[e.canvas.width,e.canvas.height]:[512,512],r=e.canvas||document.createElement("canvas"),o=e.font,a="number"===typeof e.step?[e.step,e.step]:e.step||[32,32],s=e.chars||i;o&&"string"!==typeof o&&(o=n(o));if(Array.isArray(s)){if(2===s.length&&"number"===typeof s[0]&&"number"===typeof s[1]){for(var l=[],c=s[0],u=0;c<=s[1];c++)l[u++]=String.fromCharCode(c);s=l}}else s=String(s).split("");t=t.slice(),r.width=t[0],r.height=t[1];var d=r.getContext("2d");d.fillStyle="#000",d.fillRect(0,0,r.width,r.height),d.font=o,d.textAlign="center",d.textBaseline="middle",d.fillStyle="#fff";var h=a[0]/2,p=a[1]/2;for(c=0;ct[0]-a[0]/2&&(h=a[0]/2,p+=a[1]);return r}},93272:e=>{"use strict";function t(e,o){o||(o={}),("string"===typeof e||Array.isArray(e))&&(o.family=e);var a=Array.isArray(o.family)?o.family.join(", "):o.family;if(!a)throw Error("`family` must be defined");var s=o.size||o.fontSize||o.em||48,l=o.weight||o.fontWeight||"",c=(e=[o.style||o.fontStyle||"",l,s].join(" ")+"px "+a,o.origin||"top");if(t.cache[a]&&s<=t.cache[a].em)return r(t.cache[a],c);var u=o.canvas||t.canvas,d=u.getContext("2d"),h={upper:void 0!==o.upper?o.upper:"H",lower:void 0!==o.lower?o.lower:"x",descent:void 0!==o.descent?o.descent:"p",ascent:void 0!==o.ascent?o.ascent:"h",tittle:void 0!==o.tittle?o.tittle:"i",overshoot:void 0!==o.overshoot?o.overshoot:"O"},p=Math.ceil(1.5*s);u.height=p,u.width=.5*p,d.font=e;var f="H",m={top:0};d.clearRect(0,0,p,p),d.textBaseline="top",d.fillStyle="black",d.fillText(f,0,0);var g=n(d.getImageData(0,0,p,p));d.clearRect(0,0,p,p),d.textBaseline="bottom",d.fillText(f,0,p);var y=n(d.getImageData(0,0,p,p));m.lineHeight=m.bottom=p-y+g,d.clearRect(0,0,p,p),d.textBaseline="alphabetic",d.fillText(f,0,p);var v=p-n(d.getImageData(0,0,p,p))-1+g;m.baseline=m.alphabetic=v,d.clearRect(0,0,p,p),d.textBaseline="middle",d.fillText(f,0,.5*p);var x=n(d.getImageData(0,0,p,p));m.median=m.middle=p-x-1+g-.5*p,d.clearRect(0,0,p,p),d.textBaseline="hanging",d.fillText(f,0,.5*p);var b=n(d.getImageData(0,0,p,p));m.hanging=p-b-1+g-.5*p,d.clearRect(0,0,p,p),d.textBaseline="ideographic",d.fillText(f,0,p);var _=n(d.getImageData(0,0,p,p));if(m.ideographic=p-_-1+g,h.upper&&(d.clearRect(0,0,p,p),d.textBaseline="top",d.fillText(h.upper,0,0),m.upper=n(d.getImageData(0,0,p,p)),m.capHeight=m.baseline-m.upper),h.lower&&(d.clearRect(0,0,p,p),d.textBaseline="top",d.fillText(h.lower,0,0),m.lower=n(d.getImageData(0,0,p,p)),m.xHeight=m.baseline-m.lower),h.tittle&&(d.clearRect(0,0,p,p),d.textBaseline="top",d.fillText(h.tittle,0,0),m.tittle=n(d.getImageData(0,0,p,p))),h.ascent&&(d.clearRect(0,0,p,p),d.textBaseline="top",d.fillText(h.ascent,0,0),m.ascent=n(d.getImageData(0,0,p,p))),h.descent&&(d.clearRect(0,0,p,p),d.textBaseline="top",d.fillText(h.descent,0,0),m.descent=i(d.getImageData(0,0,p,p))),h.overshoot){d.clearRect(0,0,p,p),d.textBaseline="top",d.fillText(h.overshoot,0,0);var w=i(d.getImageData(0,0,p,p));m.overshoot=w-v}for(var k in m)m[k]/=s;return m.em=s,t.cache[a]=m,r(m,c)}function r(e,t){var r={};for(var n in"string"===typeof t&&(t=e[t]),e)"em"!==n&&(r[n]=e[n]-t);return r}function n(e){for(var t=e.height,r=e.data,n=3;n0;n-=4)if(0!==r[n])return Math.floor(.25*(n-3)/t)}e.exports=t,t.canvas=document.createElement("canvas"),t.cache={}},51903:(e,t,r)=>{"use strict";var n=r(78799),i=Object.prototype.toString,o=Object.prototype.hasOwnProperty;e.exports=function(e,t,r){if(!n(t))throw new TypeError("iterator must be a function");var a;arguments.length>=3&&(a=r),"[object Array]"===i.call(e)?function(e,t,r){for(var n=0,i=e.length;n{"use strict";var t=Object.prototype.toString,r=Math.max,n=function(e,t){for(var r=[],n=0;n{"use strict";var n=r(17724);e.exports=Function.prototype.bind||n},66625:e=>{e.exports=function(e,t){if("string"!==typeof e)throw new TypeError("must specify type string");if(t=t||{},"undefined"===typeof document&&!t.canvas)return null;var r=t.canvas||document.createElement("canvas");"number"===typeof t.width&&(r.width=t.width);"number"===typeof t.height&&(r.height=t.height);var n,i=t;try{var o=[e];0===e.indexOf("webgl")&&o.push("experimental-"+e);for(var a=0;a{"use strict";var n,i=r(29304),o=r(79820),a=r(1725),s=r(75077),l=r(62557),c=r(54902),u=r(63094),d=Function,h=function(e){try{return d('"use strict"; return ('+e+").constructor;")()}catch(t){}},p=Object.getOwnPropertyDescriptor;if(p)try{p({},"")}catch(D){p=null}var f=function(){throw new c},m=p?function(){try{return f}catch(e){try{return p(arguments,"callee").get}catch(t){return f}}}():f,g=r(72108)(),y=r(80951)(),v=Object.getPrototypeOf||(y?function(e){return e.__proto__}:null),x={},b="undefined"!==typeof Uint8Array&&v?v(Uint8Array):n,_={__proto__:null,"%AggregateError%":"undefined"===typeof AggregateError?n:AggregateError,"%Array%":Array,"%ArrayBuffer%":"undefined"===typeof ArrayBuffer?n:ArrayBuffer,"%ArrayIteratorPrototype%":g&&v?v([][Symbol.iterator]()):n,"%AsyncFromSyncIteratorPrototype%":n,"%AsyncFunction%":x,"%AsyncGenerator%":x,"%AsyncGeneratorFunction%":x,"%AsyncIteratorPrototype%":x,"%Atomics%":"undefined"===typeof Atomics?n:Atomics,"%BigInt%":"undefined"===typeof BigInt?n:BigInt,"%BigInt64Array%":"undefined"===typeof BigInt64Array?n:BigInt64Array,"%BigUint64Array%":"undefined"===typeof BigUint64Array?n:BigUint64Array,"%Boolean%":Boolean,"%DataView%":"undefined"===typeof DataView?n:DataView,"%Date%":Date,"%decodeURI%":decodeURI,"%decodeURIComponent%":decodeURIComponent,"%encodeURI%":encodeURI,"%encodeURIComponent%":encodeURIComponent,"%Error%":i,"%eval%":eval,"%EvalError%":o,"%Float32Array%":"undefined"===typeof Float32Array?n:Float32Array,"%Float64Array%":"undefined"===typeof Float64Array?n:Float64Array,"%FinalizationRegistry%":"undefined"===typeof FinalizationRegistry?n:FinalizationRegistry,"%Function%":d,"%GeneratorFunction%":x,"%Int8Array%":"undefined"===typeof Int8Array?n:Int8Array,"%Int16Array%":"undefined"===typeof Int16Array?n:Int16Array,"%Int32Array%":"undefined"===typeof Int32Array?n:Int32Array,"%isFinite%":isFinite,"%isNaN%":isNaN,"%IteratorPrototype%":g&&v?v(v([][Symbol.iterator]())):n,"%JSON%":"object"===typeof JSON?JSON:n,"%Map%":"undefined"===typeof Map?n:Map,"%MapIteratorPrototype%":"undefined"!==typeof Map&&g&&v?v((new Map)[Symbol.iterator]()):n,"%Math%":Math,"%Number%":Number,"%Object%":Object,"%parseFloat%":parseFloat,"%parseInt%":parseInt,"%Promise%":"undefined"===typeof Promise?n:Promise,"%Proxy%":"undefined"===typeof Proxy?n:Proxy,"%RangeError%":a,"%ReferenceError%":s,"%Reflect%":"undefined"===typeof Reflect?n:Reflect,"%RegExp%":RegExp,"%Set%":"undefined"===typeof Set?n:Set,"%SetIteratorPrototype%":"undefined"!==typeof Set&&g&&v?v((new Set)[Symbol.iterator]()):n,"%SharedArrayBuffer%":"undefined"===typeof SharedArrayBuffer?n:SharedArrayBuffer,"%String%":String,"%StringIteratorPrototype%":g&&v?v(""[Symbol.iterator]()):n,"%Symbol%":g?Symbol:n,"%SyntaxError%":l,"%ThrowTypeError%":m,"%TypedArray%":b,"%TypeError%":c,"%Uint8Array%":"undefined"===typeof Uint8Array?n:Uint8Array,"%Uint8ClampedArray%":"undefined"===typeof Uint8ClampedArray?n:Uint8ClampedArray,"%Uint16Array%":"undefined"===typeof Uint16Array?n:Uint16Array,"%Uint32Array%":"undefined"===typeof Uint32Array?n:Uint32Array,"%URIError%":u,"%WeakMap%":"undefined"===typeof WeakMap?n:WeakMap,"%WeakRef%":"undefined"===typeof WeakRef?n:WeakRef,"%WeakSet%":"undefined"===typeof WeakSet?n:WeakSet};if(v)try{null.error}catch(D){var w=v(v(D));_["%Error.prototype%"]=w}var k=function e(t){var r;if("%AsyncFunction%"===t)r=h("async function () {}");else if("%GeneratorFunction%"===t)r=h("function* () {}");else if("%AsyncGeneratorFunction%"===t)r=h("async function* () {}");else if("%AsyncGenerator%"===t){var n=e("%AsyncGeneratorFunction%");n&&(r=n.prototype)}else if("%AsyncIteratorPrototype%"===t){var i=e("%AsyncGenerator%");i&&v&&(r=v(i.prototype))}return _[t]=r,r},S={__proto__:null,"%ArrayBufferPrototype%":["ArrayBuffer","prototype"],"%ArrayPrototype%":["Array","prototype"],"%ArrayProto_entries%":["Array","prototype","entries"],"%ArrayProto_forEach%":["Array","prototype","forEach"],"%ArrayProto_keys%":["Array","prototype","keys"],"%ArrayProto_values%":["Array","prototype","values"],"%AsyncFunctionPrototype%":["AsyncFunction","prototype"],"%AsyncGenerator%":["AsyncGeneratorFunction","prototype"],"%AsyncGeneratorPrototype%":["AsyncGeneratorFunction","prototype","prototype"],"%BooleanPrototype%":["Boolean","prototype"],"%DataViewPrototype%":["DataView","prototype"],"%DatePrototype%":["Date","prototype"],"%ErrorPrototype%":["Error","prototype"],"%EvalErrorPrototype%":["EvalError","prototype"],"%Float32ArrayPrototype%":["Float32Array","prototype"],"%Float64ArrayPrototype%":["Float64Array","prototype"],"%FunctionPrototype%":["Function","prototype"],"%Generator%":["GeneratorFunction","prototype"],"%GeneratorPrototype%":["GeneratorFunction","prototype","prototype"],"%Int8ArrayPrototype%":["Int8Array","prototype"],"%Int16ArrayPrototype%":["Int16Array","prototype"],"%Int32ArrayPrototype%":["Int32Array","prototype"],"%JSONParse%":["JSON","parse"],"%JSONStringify%":["JSON","stringify"],"%MapPrototype%":["Map","prototype"],"%NumberPrototype%":["Number","prototype"],"%ObjectPrototype%":["Object","prototype"],"%ObjProto_toString%":["Object","prototype","toString"],"%ObjProto_valueOf%":["Object","prototype","valueOf"],"%PromisePrototype%":["Promise","prototype"],"%PromiseProto_then%":["Promise","prototype","then"],"%Promise_all%":["Promise","all"],"%Promise_reject%":["Promise","reject"],"%Promise_resolve%":["Promise","resolve"],"%RangeErrorPrototype%":["RangeError","prototype"],"%ReferenceErrorPrototype%":["ReferenceError","prototype"],"%RegExpPrototype%":["RegExp","prototype"],"%SetPrototype%":["Set","prototype"],"%SharedArrayBufferPrototype%":["SharedArrayBuffer","prototype"],"%StringPrototype%":["String","prototype"],"%SymbolPrototype%":["Symbol","prototype"],"%SyntaxErrorPrototype%":["SyntaxError","prototype"],"%TypedArrayPrototype%":["TypedArray","prototype"],"%TypeErrorPrototype%":["TypeError","prototype"],"%Uint8ArrayPrototype%":["Uint8Array","prototype"],"%Uint8ClampedArrayPrototype%":["Uint8ClampedArray","prototype"],"%Uint16ArrayPrototype%":["Uint16Array","prototype"],"%Uint32ArrayPrototype%":["Uint32Array","prototype"],"%URIErrorPrototype%":["URIError","prototype"],"%WeakMapPrototype%":["WeakMap","prototype"],"%WeakSetPrototype%":["WeakSet","prototype"]},A=r(63864),T=r(34384),M=A.call(Function.call,Array.prototype.concat),C=A.call(Function.apply,Array.prototype.splice),E=A.call(Function.call,String.prototype.replace),I=A.call(Function.call,String.prototype.slice),P=A.call(Function.call,RegExp.prototype.exec),O=/[^%.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|%$))/g,R=/\\(\\)?/g,L=function(e,t){var r,n=e;if(T(S,n)&&(n="%"+(r=S[n])[0]+"%"),T(_,n)){var i=_[n];if(i===x&&(i=k(n)),"undefined"===typeof i&&!t)throw new c("intrinsic "+e+" exists, but is not available. Please file an issue!");return{alias:r,name:n,value:i}}throw new l("intrinsic "+e+" does not exist!")};e.exports=function(e,t){if("string"!==typeof e||0===e.length)throw new c("intrinsic name must be a non-empty string");if(arguments.length>1&&"boolean"!==typeof t)throw new c('"allowMissing" argument must be a boolean');if(null===P(/^%?[^%]*%?$/,e))throw new l("`%` may not be present anywhere but at the beginning and end of the intrinsic name");var r=function(e){var t=I(e,0,1),r=I(e,-1);if("%"===t&&"%"!==r)throw new l("invalid intrinsic syntax, expected closing `%`");if("%"===r&&"%"!==t)throw new l("invalid intrinsic syntax, expected opening `%`");var n=[];return E(e,O,(function(e,t,r,i){n[n.length]=r?E(i,R,"$1"):t||e})),n}(e),n=r.length>0?r[0]:"",i=L("%"+n+"%",t),o=i.name,a=i.value,s=!1,u=i.alias;u&&(n=u[0],C(r,M([0,1],u)));for(var d=1,h=!0;d=r.length){var y=p(a,f);a=(h=!!y)&&"get"in y&&!("originalValue"in y.get)?y.get:a[f]}else h=T(a,f),a=a[f];h&&!s&&(_[o]=a)}}return a}},93527:e=>{e.exports=function(e,t){var r=t[0],n=t[1],i=t[2],o=t[3],a=t[4],s=t[5],l=t[6],c=t[7],u=t[8],d=t[9],h=t[10],p=t[11],f=t[12],m=t[13],g=t[14],y=t[15];return e[0]=s*(h*y-p*g)-d*(l*y-c*g)+m*(l*p-c*h),e[1]=-(n*(h*y-p*g)-d*(i*y-o*g)+m*(i*p-o*h)),e[2]=n*(l*y-c*g)-s*(i*y-o*g)+m*(i*c-o*l),e[3]=-(n*(l*p-c*h)-s*(i*p-o*h)+d*(i*c-o*l)),e[4]=-(a*(h*y-p*g)-u*(l*y-c*g)+f*(l*p-c*h)),e[5]=r*(h*y-p*g)-u*(i*y-o*g)+f*(i*p-o*h),e[6]=-(r*(l*y-c*g)-a*(i*y-o*g)+f*(i*c-o*l)),e[7]=r*(l*p-c*h)-a*(i*p-o*h)+u*(i*c-o*l),e[8]=a*(d*y-p*m)-u*(s*y-c*m)+f*(s*p-c*d),e[9]=-(r*(d*y-p*m)-u*(n*y-o*m)+f*(n*p-o*d)),e[10]=r*(s*y-c*m)-a*(n*y-o*m)+f*(n*c-o*s),e[11]=-(r*(s*p-c*d)-a*(n*p-o*d)+u*(n*c-o*s)),e[12]=-(a*(d*g-h*m)-u*(s*g-l*m)+f*(s*h-l*d)),e[13]=r*(d*g-h*m)-u*(n*g-i*m)+f*(n*h-i*d),e[14]=-(r*(s*g-l*m)-a*(n*g-i*m)+f*(n*l-i*s)),e[15]=r*(s*h-l*d)-a*(n*h-i*d)+u*(n*l-i*s),e}},86785:e=>{e.exports=function(e){var t=new Float32Array(16);return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[4]=e[4],t[5]=e[5],t[6]=e[6],t[7]=e[7],t[8]=e[8],t[9]=e[9],t[10]=e[10],t[11]=e[11],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15],t}},65991:e=>{e.exports=function(e,t){return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e[9]=t[9],e[10]=t[10],e[11]=t[11],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e}},51514:e=>{e.exports=function(){var e=new Float32Array(16);return e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=1,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=1,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}},36907:e=>{e.exports=function(e){var t=e[0],r=e[1],n=e[2],i=e[3],o=e[4],a=e[5],s=e[6],l=e[7],c=e[8],u=e[9],d=e[10],h=e[11],p=e[12],f=e[13],m=e[14],g=e[15];return(t*a-r*o)*(d*g-h*m)-(t*s-n*o)*(u*g-h*f)+(t*l-i*o)*(u*m-d*f)+(r*s-n*a)*(c*g-h*p)-(r*l-i*a)*(c*m-d*p)+(n*l-i*s)*(c*f-u*p)}},10133:e=>{e.exports=function(e,t){var r=t[0],n=t[1],i=t[2],o=t[3],a=r+r,s=n+n,l=i+i,c=r*a,u=n*a,d=n*s,h=i*a,p=i*s,f=i*l,m=o*a,g=o*s,y=o*l;return e[0]=1-d-f,e[1]=u+y,e[2]=h-g,e[3]=0,e[4]=u-y,e[5]=1-c-f,e[6]=p+m,e[7]=0,e[8]=h+g,e[9]=p-m,e[10]=1-c-d,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}},12328:e=>{e.exports=function(e,t,r){var n,i,o,a=r[0],s=r[1],l=r[2],c=Math.sqrt(a*a+s*s+l*l);if(Math.abs(c)<1e-6)return null;return a*=c=1/c,s*=c,l*=c,n=Math.sin(t),i=Math.cos(t),o=1-i,e[0]=a*a*o+i,e[1]=s*a*o+l*n,e[2]=l*a*o-s*n,e[3]=0,e[4]=a*s*o-l*n,e[5]=s*s*o+i,e[6]=l*s*o+a*n,e[7]=0,e[8]=a*l*o+s*n,e[9]=s*l*o-a*n,e[10]=l*l*o+i,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}},84429:e=>{e.exports=function(e,t,r){var n=t[0],i=t[1],o=t[2],a=t[3],s=n+n,l=i+i,c=o+o,u=n*s,d=n*l,h=n*c,p=i*l,f=i*c,m=o*c,g=a*s,y=a*l,v=a*c;return e[0]=1-(p+m),e[1]=d+v,e[2]=h-y,e[3]=0,e[4]=d-v,e[5]=1-(u+m),e[6]=f+g,e[7]=0,e[8]=h+y,e[9]=f-g,e[10]=1-(u+p),e[11]=0,e[12]=r[0],e[13]=r[1],e[14]=r[2],e[15]=1,e}},3409:e=>{e.exports=function(e,t){return e[0]=t[0],e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=t[1],e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=t[2],e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}},53439:e=>{e.exports=function(e,t){return e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=1,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=1,e[11]=0,e[12]=t[0],e[13]=t[1],e[14]=t[2],e[15]=1,e}},83054:e=>{e.exports=function(e,t){var r=Math.sin(t),n=Math.cos(t);return e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=n,e[6]=r,e[7]=0,e[8]=0,e[9]=-r,e[10]=n,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}},52481:e=>{e.exports=function(e,t){var r=Math.sin(t),n=Math.cos(t);return e[0]=n,e[1]=0,e[2]=-r,e[3]=0,e[4]=0,e[5]=1,e[6]=0,e[7]=0,e[8]=r,e[9]=0,e[10]=n,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}},56464:e=>{e.exports=function(e,t){var r=Math.sin(t),n=Math.cos(t);return e[0]=n,e[1]=r,e[2]=0,e[3]=0,e[4]=-r,e[5]=n,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=1,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}},53282:e=>{e.exports=function(e,t,r,n,i,o,a){var s=1/(r-t),l=1/(i-n),c=1/(o-a);return e[0]=2*o*s,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=2*o*l,e[6]=0,e[7]=0,e[8]=(r+t)*s,e[9]=(i+n)*l,e[10]=(a+o)*c,e[11]=-1,e[12]=0,e[13]=0,e[14]=a*o*2*c,e[15]=0,e}},49068:e=>{e.exports=function(e){return e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=1,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=1,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}},82588:(e,t,r)=>{e.exports={create:r(51514),clone:r(86785),copy:r(65991),identity:r(49068),transpose:r(35499),invert:r(13494),adjoint:r(93527),determinant:r(36907),multiply:r(68418),translate:r(26098),scale:r(30758),rotate:r(99945),rotateX:r(61917),rotateY:r(94526),rotateZ:r(98011),fromRotation:r(12328),fromRotationTranslation:r(84429),fromScaling:r(3409),fromTranslation:r(53439),fromXRotation:r(83054),fromYRotation:r(52481),fromZRotation:r(56464),fromQuat:r(10133),frustum:r(53282),perspective:r(32946),perspectiveFromFieldOfView:r(94724),ortho:r(48706),lookAt:r(45284),str:r(56091)}},13494:e=>{e.exports=function(e,t){var r=t[0],n=t[1],i=t[2],o=t[3],a=t[4],s=t[5],l=t[6],c=t[7],u=t[8],d=t[9],h=t[10],p=t[11],f=t[12],m=t[13],g=t[14],y=t[15],v=r*s-n*a,x=r*l-i*a,b=r*c-o*a,_=n*l-i*s,w=n*c-o*s,k=i*c-o*l,S=u*m-d*f,A=u*g-h*f,T=u*y-p*f,M=d*g-h*m,C=d*y-p*m,E=h*y-p*g,I=v*E-x*C+b*M+_*T-w*A+k*S;if(!I)return null;return I=1/I,e[0]=(s*E-l*C+c*M)*I,e[1]=(i*C-n*E-o*M)*I,e[2]=(m*k-g*w+y*_)*I,e[3]=(h*w-d*k-p*_)*I,e[4]=(l*T-a*E-c*A)*I,e[5]=(r*E-i*T+o*A)*I,e[6]=(g*b-f*k-y*x)*I,e[7]=(u*k-h*b+p*x)*I,e[8]=(a*C-s*T+c*S)*I,e[9]=(n*T-r*C-o*S)*I,e[10]=(f*w-m*b+y*v)*I,e[11]=(d*b-u*w-p*v)*I,e[12]=(s*A-a*M-l*S)*I,e[13]=(r*M-n*A+i*S)*I,e[14]=(m*x-f*_-g*v)*I,e[15]=(u*_-d*x+h*v)*I,e}},45284:(e,t,r)=>{var n=r(49068);e.exports=function(e,t,r,i){var o,a,s,l,c,u,d,h,p,f,m=t[0],g=t[1],y=t[2],v=i[0],x=i[1],b=i[2],_=r[0],w=r[1],k=r[2];if(Math.abs(m-_)<1e-6&&Math.abs(g-w)<1e-6&&Math.abs(y-k)<1e-6)return n(e);d=m-_,h=g-w,p=y-k,f=1/Math.sqrt(d*d+h*h+p*p),o=x*(p*=f)-b*(h*=f),a=b*(d*=f)-v*p,s=v*h-x*d,(f=Math.sqrt(o*o+a*a+s*s))?(o*=f=1/f,a*=f,s*=f):(o=0,a=0,s=0);l=h*s-p*a,c=p*o-d*s,u=d*a-h*o,(f=Math.sqrt(l*l+c*c+u*u))?(l*=f=1/f,c*=f,u*=f):(l=0,c=0,u=0);return e[0]=o,e[1]=l,e[2]=d,e[3]=0,e[4]=a,e[5]=c,e[6]=h,e[7]=0,e[8]=s,e[9]=u,e[10]=p,e[11]=0,e[12]=-(o*m+a*g+s*y),e[13]=-(l*m+c*g+u*y),e[14]=-(d*m+h*g+p*y),e[15]=1,e}},68418:e=>{e.exports=function(e,t,r){var n=t[0],i=t[1],o=t[2],a=t[3],s=t[4],l=t[5],c=t[6],u=t[7],d=t[8],h=t[9],p=t[10],f=t[11],m=t[12],g=t[13],y=t[14],v=t[15],x=r[0],b=r[1],_=r[2],w=r[3];return e[0]=x*n+b*s+_*d+w*m,e[1]=x*i+b*l+_*h+w*g,e[2]=x*o+b*c+_*p+w*y,e[3]=x*a+b*u+_*f+w*v,x=r[4],b=r[5],_=r[6],w=r[7],e[4]=x*n+b*s+_*d+w*m,e[5]=x*i+b*l+_*h+w*g,e[6]=x*o+b*c+_*p+w*y,e[7]=x*a+b*u+_*f+w*v,x=r[8],b=r[9],_=r[10],w=r[11],e[8]=x*n+b*s+_*d+w*m,e[9]=x*i+b*l+_*h+w*g,e[10]=x*o+b*c+_*p+w*y,e[11]=x*a+b*u+_*f+w*v,x=r[12],b=r[13],_=r[14],w=r[15],e[12]=x*n+b*s+_*d+w*m,e[13]=x*i+b*l+_*h+w*g,e[14]=x*o+b*c+_*p+w*y,e[15]=x*a+b*u+_*f+w*v,e}},48706:e=>{e.exports=function(e,t,r,n,i,o,a){var s=1/(t-r),l=1/(n-i),c=1/(o-a);return e[0]=-2*s,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=-2*l,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=2*c,e[11]=0,e[12]=(t+r)*s,e[13]=(i+n)*l,e[14]=(a+o)*c,e[15]=1,e}},32946:e=>{e.exports=function(e,t,r,n,i){var o=1/Math.tan(t/2),a=1/(n-i);return e[0]=o/r,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=o,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=(i+n)*a,e[11]=-1,e[12]=0,e[13]=0,e[14]=2*i*n*a,e[15]=0,e}},94724:e=>{e.exports=function(e,t,r,n){var i=Math.tan(t.upDegrees*Math.PI/180),o=Math.tan(t.downDegrees*Math.PI/180),a=Math.tan(t.leftDegrees*Math.PI/180),s=Math.tan(t.rightDegrees*Math.PI/180),l=2/(a+s),c=2/(i+o);return e[0]=l,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=c,e[6]=0,e[7]=0,e[8]=-(a-s)*l*.5,e[9]=(i-o)*c*.5,e[10]=n/(r-n),e[11]=-1,e[12]=0,e[13]=0,e[14]=n*r/(r-n),e[15]=0,e}},99945:e=>{e.exports=function(e,t,r,n){var i,o,a,s,l,c,u,d,h,p,f,m,g,y,v,x,b,_,w,k,S,A,T,M,C=n[0],E=n[1],I=n[2],P=Math.sqrt(C*C+E*E+I*I);if(Math.abs(P)<1e-6)return null;C*=P=1/P,E*=P,I*=P,i=Math.sin(r),o=Math.cos(r),a=1-o,s=t[0],l=t[1],c=t[2],u=t[3],d=t[4],h=t[5],p=t[6],f=t[7],m=t[8],g=t[9],y=t[10],v=t[11],x=C*C*a+o,b=E*C*a+I*i,_=I*C*a-E*i,w=C*E*a-I*i,k=E*E*a+o,S=I*E*a+C*i,A=C*I*a+E*i,T=E*I*a-C*i,M=I*I*a+o,e[0]=s*x+d*b+m*_,e[1]=l*x+h*b+g*_,e[2]=c*x+p*b+y*_,e[3]=u*x+f*b+v*_,e[4]=s*w+d*k+m*S,e[5]=l*w+h*k+g*S,e[6]=c*w+p*k+y*S,e[7]=u*w+f*k+v*S,e[8]=s*A+d*T+m*M,e[9]=l*A+h*T+g*M,e[10]=c*A+p*T+y*M,e[11]=u*A+f*T+v*M,t!==e&&(e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]);return e}},61917:e=>{e.exports=function(e,t,r){var n=Math.sin(r),i=Math.cos(r),o=t[4],a=t[5],s=t[6],l=t[7],c=t[8],u=t[9],d=t[10],h=t[11];t!==e&&(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]);return e[4]=o*i+c*n,e[5]=a*i+u*n,e[6]=s*i+d*n,e[7]=l*i+h*n,e[8]=c*i-o*n,e[9]=u*i-a*n,e[10]=d*i-s*n,e[11]=h*i-l*n,e}},94526:e=>{e.exports=function(e,t,r){var n=Math.sin(r),i=Math.cos(r),o=t[0],a=t[1],s=t[2],l=t[3],c=t[8],u=t[9],d=t[10],h=t[11];t!==e&&(e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]);return e[0]=o*i-c*n,e[1]=a*i-u*n,e[2]=s*i-d*n,e[3]=l*i-h*n,e[8]=o*n+c*i,e[9]=a*n+u*i,e[10]=s*n+d*i,e[11]=l*n+h*i,e}},98011:e=>{e.exports=function(e,t,r){var n=Math.sin(r),i=Math.cos(r),o=t[0],a=t[1],s=t[2],l=t[3],c=t[4],u=t[5],d=t[6],h=t[7];t!==e&&(e[8]=t[8],e[9]=t[9],e[10]=t[10],e[11]=t[11],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]);return e[0]=o*i+c*n,e[1]=a*i+u*n,e[2]=s*i+d*n,e[3]=l*i+h*n,e[4]=c*i-o*n,e[5]=u*i-a*n,e[6]=d*i-s*n,e[7]=h*i-l*n,e}},30758:e=>{e.exports=function(e,t,r){var n=r[0],i=r[1],o=r[2];return e[0]=t[0]*n,e[1]=t[1]*n,e[2]=t[2]*n,e[3]=t[3]*n,e[4]=t[4]*i,e[5]=t[5]*i,e[6]=t[6]*i,e[7]=t[7]*i,e[8]=t[8]*o,e[9]=t[9]*o,e[10]=t[10]*o,e[11]=t[11]*o,e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e}},56091:e=>{e.exports=function(e){return"mat4("+e[0]+", "+e[1]+", "+e[2]+", "+e[3]+", "+e[4]+", "+e[5]+", "+e[6]+", "+e[7]+", "+e[8]+", "+e[9]+", "+e[10]+", "+e[11]+", "+e[12]+", "+e[13]+", "+e[14]+", "+e[15]+")"}},26098:e=>{e.exports=function(e,t,r){var n,i,o,a,s,l,c,u,d,h,p,f,m=r[0],g=r[1],y=r[2];t===e?(e[12]=t[0]*m+t[4]*g+t[8]*y+t[12],e[13]=t[1]*m+t[5]*g+t[9]*y+t[13],e[14]=t[2]*m+t[6]*g+t[10]*y+t[14],e[15]=t[3]*m+t[7]*g+t[11]*y+t[15]):(n=t[0],i=t[1],o=t[2],a=t[3],s=t[4],l=t[5],c=t[6],u=t[7],d=t[8],h=t[9],p=t[10],f=t[11],e[0]=n,e[1]=i,e[2]=o,e[3]=a,e[4]=s,e[5]=l,e[6]=c,e[7]=u,e[8]=d,e[9]=h,e[10]=p,e[11]=f,e[12]=n*m+s*g+d*y+t[12],e[13]=i*m+l*g+h*y+t[13],e[14]=o*m+c*g+p*y+t[14],e[15]=a*m+u*g+f*y+t[15]);return e}},35499:e=>{e.exports=function(e,t){if(e===t){var r=t[1],n=t[2],i=t[3],o=t[6],a=t[7],s=t[11];e[1]=t[4],e[2]=t[8],e[3]=t[12],e[4]=r,e[6]=t[9],e[7]=t[13],e[8]=n,e[9]=o,e[11]=t[14],e[12]=i,e[13]=a,e[14]=s}else e[0]=t[0],e[1]=t[4],e[2]=t[8],e[3]=t[12],e[4]=t[1],e[5]=t[5],e[6]=t[9],e[7]=t[13],e[8]=t[2],e[9]=t[6],e[10]=t[10],e[11]=t[14],e[12]=t[3],e[13]=t[7],e[14]=t[11],e[15]=t[15];return e}},78481:(e,t,r)=>{"use strict";var n=r(45827),i=r(92472),o=r(6144),a=r(66933),s=r(84210),l=r(91229),c=r(89451),u=r(33774),d=r(72972),h=r(88313),p=r(45192),f=r(77944),m=r(68222),g=r(42123),y=r(93272),v=r(67014),x=r(62890).nextPow2,b=new s,_=!1;if(document.body){var w=document.body.appendChild(document.createElement("div"));w.style.font="italic small-caps bold condensed 16px/2 cursive",getComputedStyle(w).fontStretch&&(_=!0),document.body.removeChild(w)}var k=function(e){!function(e){return"function"===typeof e&&e._gl&&e.prop&&e.texture&&e.buffer}(e)?this.gl=a(e):(e={regl:e},this.gl=e.regl._gl),this.shader=b.get(this.gl),this.shader?this.regl=this.shader.regl:this.regl=e.regl||o({gl:this.gl}),this.charBuffer=this.regl.buffer({type:"uint8",usage:"stream"}),this.sizeBuffer=this.regl.buffer({type:"float",usage:"stream"}),this.shader||(this.shader=this.createShader(),b.set(this.gl,this.shader)),this.batch=[],this.fontSize=[],this.font=[],this.fontAtlas=[],this.draw=this.shader.draw.bind(this),this.render=function(){this.regl._refresh(),this.draw(this.batch)},this.canvas=this.gl.canvas,this.update(h(e)?e:{})};k.prototype.createShader=function(){var e=this.regl,t=e({blend:{enable:!0,color:[0,0,0,1],func:{srcRGB:"src alpha",dstRGB:"one minus src alpha",srcAlpha:"one minus dst alpha",dstAlpha:"one"}},stencil:{enable:!1},depth:{enable:!1},count:e.prop("count"),offset:e.prop("offset"),attributes:{charOffset:{offset:4,stride:8,buffer:e.this("sizeBuffer")},width:{offset:0,stride:8,buffer:e.this("sizeBuffer")},char:e.this("charBuffer"),position:e.this("position")},uniforms:{atlasSize:function(e,t){return[t.atlas.width,t.atlas.height]},atlasDim:function(e,t){return[t.atlas.cols,t.atlas.rows]},atlas:function(e,t){return t.atlas.texture},charStep:function(e,t){return t.atlas.step},em:function(e,t){return t.atlas.em},color:e.prop("color"),opacity:e.prop("opacity"),viewport:e.this("viewportArray"),scale:e.this("scale"),align:e.prop("align"),baseline:e.prop("baseline"),translate:e.this("translate"),positionOffset:e.prop("positionOffset")},primitive:"points",viewport:e.this("viewport"),vert:"\n\t\t\tprecision highp float;\n\t\t\tattribute float width, charOffset, char;\n\t\t\tattribute vec2 position;\n\t\t\tuniform float fontSize, charStep, em, align, baseline;\n\t\t\tuniform vec4 viewport;\n\t\t\tuniform vec4 color;\n\t\t\tuniform vec2 atlasSize, atlasDim, scale, translate, positionOffset;\n\t\t\tvarying vec2 charCoord, charId;\n\t\t\tvarying float charWidth;\n\t\t\tvarying vec4 fontColor;\n\t\t\tvoid main () {\n\t\t\t\tvec2 offset = floor(em * (vec2(align + charOffset, baseline)\n\t\t\t\t\t+ vec2(positionOffset.x, -positionOffset.y)))\n\t\t\t\t\t/ (viewport.zw * scale.xy);\n\n\t\t\t\tvec2 position = (position + translate) * scale;\n\t\t\t\tposition += offset * scale;\n\n\t\t\t\tcharCoord = position * viewport.zw + viewport.xy;\n\n\t\t\t\tgl_Position = vec4(position * 2. - 1., 0, 1);\n\n\t\t\t\tgl_PointSize = charStep;\n\n\t\t\t\tcharId.x = mod(char, atlasDim.x);\n\t\t\t\tcharId.y = floor(char / atlasDim.x);\n\n\t\t\t\tcharWidth = width * em;\n\n\t\t\t\tfontColor = color / 255.;\n\t\t\t}",frag:"\n\t\t\tprecision highp float;\n\t\t\tuniform float fontSize, charStep, opacity;\n\t\t\tuniform vec2 atlasSize;\n\t\t\tuniform vec4 viewport;\n\t\t\tuniform sampler2D atlas;\n\t\t\tvarying vec4 fontColor;\n\t\t\tvarying vec2 charCoord, charId;\n\t\t\tvarying float charWidth;\n\n\t\t\tfloat lightness(vec4 color) {\n\t\t\t\treturn color.r * 0.299 + color.g * 0.587 + color.b * 0.114;\n\t\t\t}\n\n\t\t\tvoid main () {\n\t\t\t\tvec2 uv = gl_FragCoord.xy - charCoord + charStep * .5;\n\t\t\t\tfloat halfCharStep = floor(charStep * .5 + .5);\n\n\t\t\t\t// invert y and shift by 1px (FF expecially needs that)\n\t\t\t\tuv.y = charStep - uv.y;\n\n\t\t\t\t// ignore points outside of character bounding box\n\t\t\t\tfloat halfCharWidth = ceil(charWidth * .5);\n\t\t\t\tif (floor(uv.x) > halfCharStep + halfCharWidth ||\n\t\t\t\t\tfloor(uv.x) < halfCharStep - halfCharWidth) return;\n\n\t\t\t\tuv += charId * charStep;\n\t\t\t\tuv = uv / atlasSize;\n\n\t\t\t\tvec4 color = fontColor;\n\t\t\t\tvec4 mask = texture2D(atlas, uv);\n\n\t\t\t\tfloat maskY = lightness(mask);\n\t\t\t\t// float colorY = lightness(color);\n\t\t\t\tcolor.a *= maskY;\n\t\t\t\tcolor.a *= opacity;\n\n\t\t\t\t// color.a += .1;\n\n\t\t\t\t// antialiasing, see yiq color space y-channel formula\n\t\t\t\t// color.rgb += (1. - color.rgb) * (1. - mask.rgb);\n\n\t\t\t\tgl_FragColor = color;\n\t\t\t}"});return{regl:e,draw:t,atlas:{}}},k.prototype.update=function(e){var t=this;if("string"===typeof e)e={text:e};else if(!e)return;null!=(e=i(e,{position:"position positions coord coords coordinates",font:"font fontFace fontface typeface cssFont css-font family fontFamily",fontSize:"fontSize fontsize size font-size",text:"text texts chars characters value values symbols",align:"align alignment textAlign textbaseline",baseline:"baseline textBaseline textbaseline",direction:"dir direction textDirection",color:"color colour fill fill-color fillColor textColor textcolor",kerning:"kerning kern",range:"range dataBox",viewport:"vp viewport viewBox viewbox viewPort",opacity:"opacity alpha transparency visible visibility opaque",offset:"offset positionOffset padding shift indent indentation"},!0)).opacity&&(Array.isArray(e.opacity)?this.opacity=e.opacity.map((function(e){return parseFloat(e)})):this.opacity=parseFloat(e.opacity)),null!=e.viewport&&(this.viewport=d(e.viewport),this.viewportArray=[this.viewport.x,this.viewport.y,this.viewport.width,this.viewport.height]),null==this.viewport&&(this.viewport={x:0,y:0,width:this.gl.drawingBufferWidth,height:this.gl.drawingBufferHeight},this.viewportArray=[this.viewport.x,this.viewport.y,this.viewport.width,this.viewport.height]),null!=e.kerning&&(this.kerning=e.kerning),null!=e.offset&&("number"===typeof e.offset&&(e.offset=[e.offset,0]),this.positionOffset=v(e.offset)),e.direction&&(this.direction=e.direction),e.range&&(this.range=e.range,this.scale=[1/(e.range[2]-e.range[0]),1/(e.range[3]-e.range[1])],this.translate=[-e.range[0],-e.range[1]]),e.scale&&(this.scale=e.scale),e.translate&&(this.translate=e.translate),this.scale||(this.scale=[1/this.viewport.width,1/this.viewport.height]),this.translate||(this.translate=[0,0]),this.font.length||e.font||(e.font=k.baseFontSize+"px sans-serif");var r,o=!1,a=!1;if(e.font&&(Array.isArray(e.font)?e.font:[e.font]).forEach((function(e,r){if("string"===typeof e)try{e=n.parse(e)}catch(v){e=n.parse(k.baseFontSize+"px "+e)}else{var i=e.style,s=e.weight,l=e.stretch,c=e.variant;e=n.parse(n.stringify(e)),i&&(e.style=i),s&&(e.weight=s),l&&(e.stretch=l),c&&(e.variant=c)}var u=n.stringify({size:k.baseFontSize,family:e.family,stretch:_?e.stretch:void 0,variant:e.variant,weight:e.weight,style:e.style}),d=p(e.size),h=Math.round(d[0]*f(d[1]));if(h!==t.fontSize[r]&&(a=!0,t.fontSize[r]=h),(!t.font[r]||u!=t.font[r].baseString)&&(o=!0,t.font[r]=k.fonts[u],!t.font[r])){var m=e.family.join(", "),g=[e.style];e.style!=e.variant&&g.push(e.variant),e.variant!=e.weight&&g.push(e.weight),_&&e.weight!=e.stretch&&g.push(e.stretch),t.font[r]={baseString:u,family:m,weight:e.weight,stretch:e.stretch,style:e.style,variant:e.variant,width:{},kerning:{},metrics:y(m,{origin:"top",fontSize:k.baseFontSize,fontStyle:g.join(" ")})},k.fonts[u]=t.font[r]}})),(o||a)&&this.font.forEach((function(r,i){var o=n.stringify({size:t.fontSize[i],family:r.family,stretch:_?r.stretch:void 0,variant:r.variant,weight:r.weight,style:r.style});if(t.fontAtlas[i]=t.shader.atlas[o],!t.fontAtlas[i]){var a=r.metrics;t.shader.atlas[o]=t.fontAtlas[i]={fontString:o,step:2*Math.ceil(t.fontSize[i]*a.bottom*.5),em:t.fontSize[i],cols:0,rows:0,height:0,width:0,chars:[],ids:{},texture:t.regl.texture()}}null==e.text&&(e.text=t.text)})),"string"===typeof e.text&&e.position&&e.position.length>2){for(var s=Array(.5*e.position.length),h=0;h2){for(var w=!e.position[0].length,S=u.mallocFloat(2*this.count),A=0,T=0;A1?t.align[r]:t.align[0]:t.align;if("number"===typeof n)return n;switch(n){case"right":case"end":return-e;case"center":case"centre":case"middle":return.5*-e}return 0}))),null==this.baseline&&null==e.baseline&&(e.baseline=0),null!=e.baseline&&(this.baseline=e.baseline,Array.isArray(this.baseline)||(this.baseline=[this.baseline]),this.baselineOffset=this.baseline.map((function(e,r){var n=(t.font[r]||t.font[0]).metrics,i=0;return i+=.5*n.bottom,i+="number"===typeof e?e-n.baseline:-n[e],i*=-1}))),null!=e.color)if(e.color||(e.color="transparent"),"string"!==typeof e.color&&isNaN(e.color)){var $;if("number"===typeof e.color[0]&&e.color.length>this.counts.length){var W=e.color.length;$=u.mallocUint8(W);for(var q=(e.color.subarray||e.color.slice).bind(e.color),G=0;G4||this.baselineOffset.length>1||this.align&&this.align.length>1||this.fontAtlas.length>1||this.positionOffset.length>2){var Z=Math.max(.5*this.position.length||0,.25*this.color.length||0,this.baselineOffset.length||0,this.alignOffset.length||0,this.font.length||0,this.opacity.length||0,.5*this.positionOffset.length||0);this.batch=Array(Z);for(var K=0;K1?this.counts[K]:this.counts[0],offset:this.textOffsets.length>1?this.textOffsets[K]:this.textOffsets[0],color:this.color?this.color.length<=4?this.color:this.color.subarray(4*K,4*K+4):[0,0,0,255],opacity:Array.isArray(this.opacity)?this.opacity[K]:this.opacity,baseline:null!=this.baselineOffset[K]?this.baselineOffset[K]:this.baselineOffset[0],align:this.align?null!=this.alignOffset[K]?this.alignOffset[K]:this.alignOffset[0]:0,atlas:this.fontAtlas[K]||this.fontAtlas[0],positionOffset:this.positionOffset.length>2?this.positionOffset.subarray(2*K,2*K+2):this.positionOffset}}else this.count?this.batch=[{count:this.count,offset:0,color:this.color||[0,0,0,255],opacity:Array.isArray(this.opacity)?this.opacity[0]:this.opacity,baseline:this.baselineOffset[0],align:this.alignOffset?this.alignOffset[0]:0,atlas:this.fontAtlas[0],positionOffset:this.positionOffset}]:this.batch=[]},k.prototype.destroy=function(){},k.prototype.kerning=!0,k.prototype.position={constant:new Float32Array(2)},k.prototype.translate=null,k.prototype.scale=null,k.prototype.font=null,k.prototype.text="",k.prototype.positionOffset=[0,0],k.prototype.opacity=1,k.prototype.color=new Uint8Array([0,0,0,255]),k.prototype.alignOffset=[0,0],k.maxAtlasSize=1024,k.atlasCanvas=document.createElement("canvas"),k.atlasContext=k.atlasCanvas.getContext("2d",{alpha:!1}),k.baseFontSize=64,k.fonts={},e.exports=k},6144:function(e){e.exports=function(){"use strict";var e=function(e){return e instanceof Uint8Array||e instanceof Uint16Array||e instanceof Uint32Array||e instanceof Int8Array||e instanceof Int16Array||e instanceof Int32Array||e instanceof Float32Array||e instanceof Float64Array||e instanceof Uint8ClampedArray},t=function(e,t){for(var r=Object.keys(t),n=0;n=0&&(0|e)===e||i("invalid parameter type, ("+e+")"+a(t)+". must be a nonnegative integer")}function h(e,t,r){t.indexOf(e)<0&&i("invalid value"+a(r)+". must be one of: "+t)}var p=["gl","canvas","container","attributes","pixelRatio","extensions","optionalExtensions","profile","onDone"];function f(e){Object.keys(e).forEach((function(e){p.indexOf(e)<0&&i('invalid regl constructor argument "'+e+'". must be one of '+p)}))}function m(e,t){for(e+="";e.length0&&t.push(new v("unknown",0,e))}})),t}function k(e,t){t.forEach((function(t){var r=e[t.file];if(r){var n=r.index[t.line];if(n)return n.errors.push(t),void(r.hasErrors=!0)}e.unknown.hasErrors=!0,e.unknown.lines[0].errors.push(t)}))}function S(e,t,n,i,a){if(!e.getShaderParameter(t,e.COMPILE_STATUS)){var s=e.getShaderInfoLog(t),l=i===e.FRAGMENT_SHADER?"fragment":"vertex";P(n,"string",l+" shader source must be a string",a);var c=_(n,a),u=w(s);k(c,u),Object.keys(c).forEach((function(e){var t=c[e];if(t.hasErrors){var n=[""],i=[""];o("file number "+e+": "+t.name+"\n","color:red;text-decoration:underline;font-weight:bold"),t.lines.forEach((function(e){if(e.errors.length>0){o(m(e.number,4)+"| ","background-color:yellow; font-weight:bold"),o(e.line+r,"color:red; background-color:yellow; font-weight:bold");var t=0;e.errors.forEach((function(n){var i=n.message,a=/^\s*'(.*)'\s*:\s*(.*)$/.exec(i);if(a){var s=a[1];i=a[2],"assign"===s&&(s="="),t=Math.max(e.line.indexOf(s,t),0)}else t=0;o(m("| ",6)),o(m("^^^",t+3)+r,"font-weight:bold"),o(m("| ",6)),o(i+r,"font-weight:bold")})),o(m("| ",6)+r)}else o(m(e.number,4)+"| "),o(e.line+r,"color:red")})),"undefined"===typeof document||window.chrome?console.log(n.join("")):(i[0]=n.join("%c"),console.log.apply(console,i))}function o(e,t){n.push(e),i.push(t||"")}})),o.raise("Error compiling "+l+" shader, "+c[0].name)}}function A(e,t,n,i,a){if(!e.getProgramParameter(t,e.LINK_STATUS)){var s=e.getProgramInfoLog(t),l=_(n,a),c='Error linking program with vertex shader, "'+_(i,a)[0].name+'", and fragment shader "'+l[0].name+'"';"undefined"!==typeof document?console.log("%c"+c+r+"%c"+s,"color:red;text-decoration:underline;font-weight:bold","color:red"):console.log(c+r+s),o.raise(c)}}function T(e){e._commandRef=x()}function M(e,t,r,n){function i(e){return e?n.id(e):0}function o(e,t){Object.keys(t).forEach((function(t){e[n.id(t)]=!0}))}T(e),e._fragId=i(e.static.frag),e._vertId=i(e.static.vert);var a=e._uniformSet={};o(a,t.static),o(a,t.dynamic);var s=e._attributeSet={};o(s,r.static),o(s,r.dynamic),e._hasCount="count"in e.static||"count"in e.dynamic||"elements"in e.static||"elements"in e.dynamic}function C(e,t){var r=b();i(e+" in command "+(t||x())+("unknown"===r?"":" called from "+r))}function E(e,t,r){e||C(t,r||x())}function I(e,t,r,n){e in t||C("unknown parameter ("+e+")"+a(r)+". possible values: "+Object.keys(t).join(),n||x())}function P(e,t,r,n){c(e,t)||C("invalid parameter type"+a(r)+". expected "+t+", got "+typeof e,n||x())}function O(e){e()}function R(e,t,r){e.texture?h(e.texture._texture.internalformat,t,"unsupported texture format for attachment"):h(e.renderbuffer._renderbuffer.format,r,"unsupported renderbuffer format for attachment")}var L=33071,D=9728,z=9984,j=9985,F=9986,N=9987,B=5121,V=5122,U=5123,H=5124,$=5125,W=5126,q=32819,G=32820,Y=33635,X=34042,Z=36193,K={};function J(e,t){return e===G||e===q||e===Y?2:e===X?4:K[e]*t}function Q(e){return!(e&e-1)&&!!e}function ee(e,t,r){var n,i=t.width,a=t.height,s=t.channels;o(i>0&&i<=r.maxTextureSize&&a>0&&a<=r.maxTextureSize,"invalid texture shape"),e.wrapS===L&&e.wrapT===L||o(Q(i)&&Q(a),"incompatible wrap mode for texture, both width and height must be power of 2"),1===t.mipmask?1!==i&&1!==a&&o(e.minFilter!==z&&e.minFilter!==F&&e.minFilter!==j&&e.minFilter!==N,"min filter requires mipmap"):(o(Q(i)&&Q(a),"texture must be a square power of 2 to support mipmapping"),o(t.mipmask===(i<<1)-1,"missing or incomplete mipmap data")),t.type===W&&(r.extensions.indexOf("oes_texture_float_linear")<0&&o(e.minFilter===D&&e.magFilter===D,"filter not supported, must enable oes_texture_float_linear"),o(!e.genMipmaps,"mipmap generation not supported with float textures"));var l=t.images;for(n=0;n<16;++n)if(l[n]){var c=i>>n,u=a>>n;o(t.mipmask&1<0&&i<=n.maxTextureSize&&a>0&&a<=n.maxTextureSize,"invalid texture shape"),o(i===a,"cube map must be square"),o(t.wrapS===L&&t.wrapT===L,"wrap mode not supported by cube map");for(var l=0;l>d,f=a>>d;o(c.mipmask&1<1&&t===r&&('"'===t||"'"===t))return['"'+le(e.substr(1,e.length-2))+'"'];var n=/\[(false|true|null|\d+|'[^']*'|"[^"]*")\]/.exec(e);if(n)return ce(e.substr(0,n.index)).concat(ce(n[1])).concat(ce(e.substr(n.index+n[0].length)));var i=e.split(".");if(1===i.length)return['"'+le(e)+'"'];for(var o=[],a=0;a0,"invalid pixel ratio"))):re.raise("invalid arguments to regl"),t&&("canvas"===t.nodeName.toLowerCase()?n=t:r=t),!i){if(!n){re("undefined"!==typeof document,"must manually specify webgl context outside of DOM environments");var p=ve(r||document.body,d,c);if(!p)return null;n=p.canvas,h=p.onDestroy}void 0===a.premultipliedAlpha&&(a.premultipliedAlpha=!0),i=xe(n,a)}return i?{gl:i,canvas:n,container:r,extensions:s,optionalExtensions:l,pixelRatio:c,profile:u,onDone:d,onDestroy:h}:(h(),d("webgl not supported, try upgrading your browser or graphics drivers http://get.webgl.org"),null)}function Ae(e,t){var r={};function n(t){re.type(t,"string","extension name must be string");var n,i=t.toLowerCase();try{n=r[i]=e.getExtension(i)}catch(o){}return!!n}for(var i=0;i65535)<<4,t|=r=((e>>>=t)>255)<<3,t|=r=((e>>>=r)>15)<<2,(t|=r=((e>>>=r)>3)<<1)|(e>>>=r)>>1}function ze(){var e=Te(8,(function(){return[]}));function t(t){var r=Le(t),n=e[De(r)>>2];return n.length>0?n.pop():new ArrayBuffer(r)}function r(t){e[De(t.byteLength)>>2].push(t)}function n(e,r){var n=null;switch(e){case Me:n=new Int8Array(t(r),0,r);break;case Ce:n=new Uint8Array(t(r),0,r);break;case Ee:n=new Int16Array(t(2*r),0,r);break;case Ie:n=new Uint16Array(t(2*r),0,r);break;case Pe:n=new Int32Array(t(4*r),0,r);break;case Oe:n=new Uint32Array(t(4*r),0,r);break;case Re:n=new Float32Array(t(4*r),0,r);break;default:return null}return n.length!==r?n.subarray(0,r):n}function i(e){r(e.buffer)}return{alloc:t,free:r,allocType:n,freeType:i}}var je=ze();je.zero=ze();var Fe=3408,Ne=3410,Be=3411,Ve=3412,Ue=3413,He=3414,$e=3415,We=33901,qe=33902,Ge=3379,Ye=3386,Xe=34921,Ze=36347,Ke=36348,Je=35661,Qe=35660,et=34930,tt=36349,rt=34076,nt=34024,it=7936,ot=7937,at=7938,st=35724,lt=34047,ct=36063,ut=34852,dt=3553,ht=34067,pt=34069,ft=33984,mt=6408,gt=5126,yt=5121,vt=36160,xt=36053,bt=36064,_t=16384,wt=function(e,t){var r=1;t.ext_texture_filter_anisotropic&&(r=e.getParameter(lt));var n=1,i=1;t.webgl_draw_buffers&&(n=e.getParameter(ut),i=e.getParameter(ct));var o=!!t.oes_texture_float;if(o){var a=e.createTexture();e.bindTexture(dt,a),e.texImage2D(dt,0,mt,1,1,0,mt,gt,null);var s=e.createFramebuffer();if(e.bindFramebuffer(vt,s),e.framebufferTexture2D(vt,bt,dt,a,0),e.bindTexture(dt,null),e.checkFramebufferStatus(vt)!==xt)o=!1;else{e.viewport(0,0,1,1),e.clearColor(1,0,0,1),e.clear(_t);var l=je.allocType(gt,4);e.readPixels(0,0,1,1,mt,gt,l),e.getError()?o=!1:(e.deleteFramebuffer(s),e.deleteTexture(a),o=1===l[0]),je.freeType(l)}}var c=!0;if("undefined"===typeof navigator||!(/MSIE/.test(navigator.userAgent)||/Trident\//.test(navigator.appVersion)||/Edge/.test(navigator.userAgent))){var u=e.createTexture(),d=je.allocType(yt,36);e.activeTexture(ft),e.bindTexture(ht,u),e.texImage2D(pt,0,mt,3,3,0,mt,yt,d),je.freeType(d),e.bindTexture(ht,null),e.deleteTexture(u),c=!e.getError()}return{colorBits:[e.getParameter(Ne),e.getParameter(Be),e.getParameter(Ve),e.getParameter(Ue)],depthBits:e.getParameter(He),stencilBits:e.getParameter($e),subpixelBits:e.getParameter(Fe),extensions:Object.keys(t).filter((function(e){return!!t[e]})),maxAnisotropic:r,maxDrawbuffers:n,maxColorAttachments:i,pointSizeDims:e.getParameter(We),lineWidthDims:e.getParameter(qe),maxViewportDims:e.getParameter(Ye),maxCombinedTextureUnits:e.getParameter(Je),maxCubeMapSize:e.getParameter(rt),maxRenderbufferSize:e.getParameter(nt),maxTextureUnits:e.getParameter(et),maxTextureSize:e.getParameter(Ge),maxAttributes:e.getParameter(Xe),maxVertexUniforms:e.getParameter(Ze),maxVertexTextureUnits:e.getParameter(Qe),maxVaryingVectors:e.getParameter(Ke),maxFragmentUniforms:e.getParameter(tt),glsl:e.getParameter(st),renderer:e.getParameter(ot),vendor:e.getParameter(it),version:e.getParameter(at),readFloat:o,npotTextureCube:c}};function kt(t){return!!t&&"object"===typeof t&&Array.isArray(t.shape)&&Array.isArray(t.stride)&&"number"===typeof t.offset&&t.shape.length===t.stride.length&&(Array.isArray(t.data)||e(t.data))}var St=function(e){return Object.keys(e).map((function(t){return e[t]}))},At={shape:Pt,flatten:It};function Tt(e,t,r){for(var n=0;n0)if(Array.isArray(r[0])){s=zt(r);for(var c=1,u=1;u0)if("number"===typeof t[0]){var o=je.allocType(u.dtype,t.length);Ht(o,t),f(o,i),je.freeType(o)}else if(Array.isArray(t[0])||e(t[0])){n=zt(t);var a=Dt(t,n,u.dtype);f(a,i),je.freeType(a)}else re.raise("invalid buffer data")}else if(kt(t)){n=t.shape;var s=t.stride,l=0,c=0,h=0,p=0;1===n.length?(l=n[0],c=1,h=s[0],p=0):2===n.length?(l=n[0],c=n[1],h=s[0],p=s[1]):re.raise("invalid shape");var m=Array.isArray(t.data)?u.dtype:Ut(t.data),g=je.allocType(m,l*c);$t(g,t.data,l,c,h,p,t.offset),f(g,i),je.freeType(g)}else re.raise("invalid data for buffer subdata");return d}return a[u.id]=u,l||d(i),d._reglType="buffer",d._buffer=u,d.subdata=m,n.profile&&(d.stats=u.stats),d.destroy=function(){p(u)},d}function m(){St(a).forEach((function(e){e.buffer=t.createBuffer(),t.bindBuffer(e.type,e.buffer),t.bufferData(e.type,e.persistentData||e.byteLength,e.usage)}))}return n.profile&&(r.getTotalBufferSize=function(){var e=0;return Object.keys(a).forEach((function(t){e+=a[t].stats.size})),e}),{create:f,createStream:c,destroyStream:u,clear:function(){St(a).forEach(p),l.forEach(p)},getBuffer:function(e){return e&&e._buffer instanceof s?e._buffer:null},restore:m,_initBuffer:h}}Vt[5120]=1,Vt[5122]=2,Vt[5124]=4,Vt[5121]=1,Vt[5123]=2,Vt[5125]=4,Vt[5126]=4;var qt={points:0,point:0,lines:1,line:1,triangles:4,triangle:4,"line loop":2,"line strip":3,"triangle strip":5,"triangle fan":6},Gt=0,Yt=1,Xt=4,Zt=5120,Kt=5121,Jt=5122,Qt=5123,er=5124,tr=5125,rr=34963,nr=35040,ir=35044;function or(t,r,n,i){var o={},a=0,s={uint8:Kt,uint16:Qt};function l(e){this.id=a++,o[this.id]=this,this.buffer=e,this.primType=Xt,this.vertCount=0,this.type=0}r.oes_element_index_uint&&(s.uint32=tr),l.prototype.bind=function(){this.buffer.bind()};var c=[];function u(e){var t=c.pop();return t||(t=new l(n.create(null,rr,!0,!1)._buffer)),h(t,e,nr,-1,-1,0,0),t}function d(e){c.push(e)}function h(i,o,a,s,l,c,u){var d;if(i.buffer.bind(),o){var h=u;u||e(o)&&(!kt(o)||e(o.data))||(h=r.oes_element_index_uint?tr:Qt),n._initBuffer(i.buffer,o,a,h,3)}else t.bufferData(rr,c,a),i.buffer.dtype=d||Kt,i.buffer.usage=a,i.buffer.dimension=3,i.buffer.byteLength=c;if(d=u,!u){switch(i.buffer.dtype){case Kt:case Zt:d=Kt;break;case Qt:case Jt:d=Qt;break;case tr:case er:d=tr;break;default:re.raise("unsupported type for element array")}i.buffer.dtype=d}i.type=d,re(d!==tr||!!r.oes_element_index_uint,"32 bit element buffers not supported, enable oes_element_index_uint first");var p=l;p<0&&(p=i.buffer.byteLength,d===Qt?p>>=1:d===tr&&(p>>=2)),i.vertCount=p;var f=s;if(s<0){f=Xt;var m=i.buffer.dimension;1===m&&(f=Gt),2===m&&(f=Yt),3===m&&(f=Xt)}i.primType=f}function p(e){i.elementsCount--,re(null!==e.buffer,"must not double destroy elements"),delete o[e.id],e.buffer.destroy(),e.buffer=null}function f(t,r){var o=n.create(null,rr,!0),a=new l(o._buffer);function c(t){if(t)if("number"===typeof t)o(t),a.primType=Xt,a.vertCount=0|t,a.type=Kt;else{var r=null,n=ir,i=-1,l=-1,u=0,d=0;Array.isArray(t)||e(t)||kt(t)?r=t:(re.type(t,"object","invalid arguments for elements"),"data"in t&&(r=t.data,re(Array.isArray(r)||e(r)||kt(r),"invalid data for element buffer")),"usage"in t&&(re.parameter(t.usage,Lt,"invalid element buffer usage"),n=Lt[t.usage]),"primitive"in t&&(re.parameter(t.primitive,qt,"invalid element buffer primitive"),i=qt[t.primitive]),"count"in t&&(re("number"===typeof t.count&&t.count>=0,"invalid vertex count for elements"),l=0|t.count),"type"in t&&(re.parameter(t.type,s,"invalid buffer type"),d=s[t.type]),"length"in t?u=0|t.length:(u=l,d===Qt||d===Jt?u*=2:d!==tr&&d!==er||(u*=4))),h(a,r,n,i,l,u,d)}else o(),a.primType=Xt,a.vertCount=0,a.type=Kt;return c}return i.elementsCount++,c(t),c._reglType="elements",c._elements=a,c.subdata=function(e,t){return o.subdata(e,t),c},c.destroy=function(){p(a)},c}return{create:f,createStream:u,destroyStream:d,getElements:function(e){return"function"===typeof e&&e._elements instanceof l?e._elements:null},clear:function(){St(o).forEach(p)}}}var ar=new Float32Array(1),sr=new Uint32Array(ar.buffer),lr=5123;function cr(e){for(var t=je.allocType(lr,e.length),r=0;r>>31<<15,o=(n<<1>>>24)-127,a=n>>13&1023;if(o<-24)t[r]=i;else if(o<-14){var s=-14-o;t[r]=i+(a+1024>>s)}else t[r]=o>15?i+31744:i+(o+15<<10)+a}return t}function ur(t){return Array.isArray(t)||e(t)}var dr=function(e){return!(e&e-1)&&!!e},hr=34467,pr=3553,fr=34067,mr=34069,gr=6408,yr=6406,vr=6407,xr=6409,br=6410,_r=32854,wr=32855,kr=36194,Sr=32819,Ar=32820,Tr=33635,Mr=34042,Cr=6402,Er=34041,Ir=35904,Pr=35906,Or=36193,Rr=33776,Lr=33777,Dr=33778,zr=33779,jr=35986,Fr=35987,Nr=34798,Br=35840,Vr=35841,Ur=35842,Hr=35843,$r=36196,Wr=5121,qr=5123,Gr=5125,Yr=5126,Xr=10242,Zr=10243,Kr=10497,Jr=33071,Qr=33648,en=10240,tn=10241,rn=9728,nn=9729,on=9984,an=9985,sn=9986,ln=9987,cn=33170,un=4352,dn=4353,hn=4354,pn=34046,fn=3317,mn=37440,gn=37441,yn=37443,vn=37444,xn=33984,bn=[on,sn,an,ln],_n=[0,xr,br,vr,gr],wn={};function kn(e){return"[object "+e+"]"}wn[xr]=wn[yr]=wn[Cr]=1,wn[Er]=wn[br]=2,wn[vr]=wn[Ir]=3,wn[gr]=wn[Pr]=4;var Sn=kn("HTMLCanvasElement"),An=kn("OffscreenCanvas"),Tn=kn("CanvasRenderingContext2D"),Mn=kn("ImageBitmap"),Cn=kn("HTMLImageElement"),En=kn("HTMLVideoElement"),In=Object.keys(Ot).concat([Sn,An,Tn,Mn,Cn,En]),Pn=[];Pn[Wr]=1,Pn[Yr]=4,Pn[Or]=2,Pn[qr]=2,Pn[Gr]=4;var On=[];function Rn(e){return Array.isArray(e)&&(0===e.length||"number"===typeof e[0])}function Ln(e){return!!Array.isArray(e)&&!(0===e.length||!ur(e[0]))}function Dn(e){return Object.prototype.toString.call(e)}function zn(e){return Dn(e)===Sn}function jn(e){return Dn(e)===An}function Fn(e){return Dn(e)===Tn}function Nn(e){return Dn(e)===Mn}function Bn(e){return Dn(e)===Cn}function Vn(e){return Dn(e)===En}function Un(e){if(!e)return!1;var t=Dn(e);return In.indexOf(t)>=0||Rn(e)||Ln(e)||kt(e)}function Hn(e){return 0|Ot[Object.prototype.toString.call(e)]}function $n(e,t){var r=t.length;switch(e.type){case Wr:case qr:case Gr:case Yr:var n=je.allocType(e.type,r);n.set(t),e.data=n;break;case Or:e.data=cr(t);break;default:re.raise("unsupported texture type, must specify a typed array")}}function Wn(e,t){return je.allocType(e.type===Or?Yr:e.type,t)}function qn(e,t){e.type===Or?(e.data=cr(t),je.freeType(t)):e.data=t}function Gn(e,t,r,n,i,o){for(var a=e.width,s=e.height,l=e.channels,c=Wn(e,a*s*l),u=0,d=0;d=1;)s+=a*l*l,l/=2;return s}return a*r*n}function Xn(r,n,i,o,a,s,l){var c={"don't care":un,"dont care":un,nice:hn,fast:dn},u={repeat:Kr,clamp:Jr,mirror:Qr},d={nearest:rn,linear:nn},h=t({mipmap:ln,"nearest mipmap nearest":on,"linear mipmap nearest":an,"nearest mipmap linear":sn,"linear mipmap linear":ln},d),p={none:0,browser:vn},f={uint8:Wr,rgba4:Sr,rgb565:Tr,"rgb5 a1":Ar},m={alpha:yr,luminance:xr,"luminance alpha":br,rgb:vr,rgba:gr,rgba4:_r,"rgb5 a1":wr,rgb565:kr},g={};n.ext_srgb&&(m.srgb=Ir,m.srgba=Pr),n.oes_texture_float&&(f.float32=f.float=Yr),n.oes_texture_half_float&&(f.float16=f["half float"]=Or),n.webgl_depth_texture&&(t(m,{depth:Cr,"depth stencil":Er}),t(f,{uint16:qr,uint32:Gr,"depth stencil":Mr})),n.webgl_compressed_texture_s3tc&&t(g,{"rgb s3tc dxt1":Rr,"rgba s3tc dxt1":Lr,"rgba s3tc dxt3":Dr,"rgba s3tc dxt5":zr}),n.webgl_compressed_texture_atc&&t(g,{"rgb atc":jr,"rgba atc explicit alpha":Fr,"rgba atc interpolated alpha":Nr}),n.webgl_compressed_texture_pvrtc&&t(g,{"rgb pvrtc 4bppv1":Br,"rgb pvrtc 2bppv1":Vr,"rgba pvrtc 4bppv1":Ur,"rgba pvrtc 2bppv1":Hr}),n.webgl_compressed_texture_etc1&&(g["rgb etc1"]=$r);var y=Array.prototype.slice.call(r.getParameter(hr));Object.keys(g).forEach((function(e){var t=g[e];y.indexOf(t)>=0&&(m[e]=t)}));var v=Object.keys(m);i.textureFormats=v;var x=[];Object.keys(m).forEach((function(e){var t=m[e];x[t]=e}));var b=[];Object.keys(f).forEach((function(e){var t=f[e];b[t]=e}));var _=[];Object.keys(d).forEach((function(e){var t=d[e];_[t]=e}));var w=[];Object.keys(h).forEach((function(e){var t=h[e];w[t]=e}));var k=[];Object.keys(u).forEach((function(e){var t=u[e];k[t]=e}));var S=v.reduce((function(e,t){var r=m[t];return r===xr||r===yr||r===xr||r===br||r===Cr||r===Er||n.ext_srgb&&(r===Ir||r===Pr)?e[r]=r:r===wr||t.indexOf("rgba")>=0?e[r]=gr:e[r]=vr,e}),{});function A(){this.internalformat=gr,this.format=gr,this.type=Wr,this.compressed=!1,this.premultiplyAlpha=!1,this.flipY=!1,this.unpackAlignment=1,this.colorSpace=vn,this.width=0,this.height=0,this.channels=0}function T(e,t){e.internalformat=t.internalformat,e.format=t.format,e.type=t.type,e.compressed=t.compressed,e.premultiplyAlpha=t.premultiplyAlpha,e.flipY=t.flipY,e.unpackAlignment=t.unpackAlignment,e.colorSpace=t.colorSpace,e.width=t.width,e.height=t.height,e.channels=t.channels}function M(e,t){if("object"===typeof t&&t){if("premultiplyAlpha"in t&&(re.type(t.premultiplyAlpha,"boolean","invalid premultiplyAlpha"),e.premultiplyAlpha=t.premultiplyAlpha),"flipY"in t&&(re.type(t.flipY,"boolean","invalid texture flip"),e.flipY=t.flipY),"alignment"in t&&(re.oneOf(t.alignment,[1,2,4,8],"invalid texture unpack alignment"),e.unpackAlignment=t.alignment),"colorSpace"in t&&(re.parameter(t.colorSpace,p,"invalid colorSpace"),e.colorSpace=p[t.colorSpace]),"type"in t){var r=t.type;re(n.oes_texture_float||!("float"===r||"float32"===r),"you must enable the OES_texture_float extension in order to use floating point textures."),re(n.oes_texture_half_float||!("half float"===r||"float16"===r),"you must enable the OES_texture_half_float extension in order to use 16-bit floating point textures."),re(n.webgl_depth_texture||!("uint16"===r||"uint32"===r||"depth stencil"===r),"you must enable the WEBGL_depth_texture extension in order to use depth/stencil textures."),re.parameter(r,f,"invalid texture type"),e.type=f[r]}var o=e.width,a=e.height,s=e.channels,l=!1;"shape"in t?(re(Array.isArray(t.shape)&&t.shape.length>=2,"shape must be an array"),o=t.shape[0],a=t.shape[1],3===t.shape.length&&(s=t.shape[2],re(s>0&&s<=4,"invalid number of channels"),l=!0),re(o>=0&&o<=i.maxTextureSize,"invalid width"),re(a>=0&&a<=i.maxTextureSize,"invalid height")):("radius"in t&&(o=a=t.radius,re(o>=0&&o<=i.maxTextureSize,"invalid radius")),"width"in t&&(o=t.width,re(o>=0&&o<=i.maxTextureSize,"invalid width")),"height"in t&&(a=t.height,re(a>=0&&a<=i.maxTextureSize,"invalid height")),"channels"in t&&(s=t.channels,re(s>0&&s<=4,"invalid number of channels"),l=!0)),e.width=0|o,e.height=0|a,e.channels=0|s;var c=!1;if("format"in t){var u=t.format;re(n.webgl_depth_texture||!("depth"===u||"depth stencil"===u),"you must enable the WEBGL_depth_texture extension in order to use depth/stencil textures."),re.parameter(u,m,"invalid texture format");var d=e.internalformat=m[u];e.format=S[d],u in f&&("type"in t||(e.type=f[u])),u in g&&(e.compressed=!0),c=!0}!l&&c?e.channels=wn[e.format]:l&&!c?e.channels!==_n[e.format]&&(e.format=e.internalformat=_n[e.channels]):c&&l&&re(e.channels===wn[e.format],"number of channels inconsistent with specified format")}}function C(e){r.pixelStorei(mn,e.flipY),r.pixelStorei(gn,e.premultiplyAlpha),r.pixelStorei(yn,e.colorSpace),r.pixelStorei(fn,e.unpackAlignment)}function E(){A.call(this),this.xOffset=0,this.yOffset=0,this.data=null,this.needsFree=!1,this.element=null,this.needsCopy=!1}function I(t,r){var n=null;if(Un(r)?n=r:r&&(re.type(r,"object","invalid pixel data type"),M(t,r),"x"in r&&(t.xOffset=0|r.x),"y"in r&&(t.yOffset=0|r.y),Un(r.data)&&(n=r.data)),re(!t.compressed||n instanceof Uint8Array,"compressed texture data must be stored in a uint8array"),r.copy){re(!n,"can not specify copy and data field for the same texture");var o=a.viewportWidth,s=a.viewportHeight;t.width=t.width||o-t.xOffset,t.height=t.height||s-t.yOffset,t.needsCopy=!0,re(t.xOffset>=0&&t.xOffset=0&&t.yOffset0&&t.width<=o&&t.height>0&&t.height<=s,"copy texture read out of bounds")}else if(n){if(e(n))t.channels=t.channels||4,t.data=n,"type"in r||t.type!==Wr||(t.type=Hn(n));else if(Rn(n))t.channels=t.channels||4,$n(t,n),t.alignment=1,t.needsFree=!0;else if(kt(n)){var l=n.data;Array.isArray(l)||t.type!==Wr||(t.type=Hn(l));var c,u,d,h,p,f,m=n.shape,g=n.stride;3===m.length?(d=m[2],f=g[2]):(re(2===m.length,"invalid ndarray pixel data, must be 2 or 3D"),d=1,f=1),c=m[0],u=m[1],h=g[0],p=g[1],t.alignment=1,t.width=c,t.height=u,t.channels=d,t.format=t.internalformat=_n[d],t.needsFree=!0,Gn(t,l,h,p,f,n.offset)}else if(zn(n)||jn(n)||Fn(n))zn(n)||jn(n)?t.element=n:t.element=n.canvas,t.width=t.element.width,t.height=t.element.height,t.channels=4;else if(Nn(n))t.element=n,t.width=n.width,t.height=n.height,t.channels=4;else if(Bn(n))t.element=n,t.width=n.naturalWidth,t.height=n.naturalHeight,t.channels=4;else if(Vn(n))t.element=n,t.width=n.videoWidth,t.height=n.videoHeight,t.channels=4;else if(Ln(n)){var y=t.width||n[0].length,v=t.height||n.length,x=t.channels;x=ur(n[0][0])?x||n[0][0].length:x||1;for(var b=At.shape(n),_=1,w=0;w=0,"oes_texture_float extension not enabled"):t.type===Or&&re(i.extensions.indexOf("oes_texture_half_float")>=0,"oes_texture_half_float extension not enabled")}function P(e,t,n){var i=e.element,a=e.data,s=e.internalformat,l=e.format,c=e.type,u=e.width,d=e.height;C(e),i?r.texImage2D(t,n,l,l,c,i):e.compressed?r.compressedTexImage2D(t,n,s,u,d,0,a):e.needsCopy?(o(),r.copyTexImage2D(t,n,l,e.xOffset,e.yOffset,u,d,0)):r.texImage2D(t,n,l,u,d,0,l,c,a||null)}function O(e,t,n,i,a){var s=e.element,l=e.data,c=e.internalformat,u=e.format,d=e.type,h=e.width,p=e.height;C(e),s?r.texSubImage2D(t,a,n,i,u,d,s):e.compressed?r.compressedTexSubImage2D(t,a,n,i,c,h,p,l):e.needsCopy?(o(),r.copyTexSubImage2D(t,a,n,i,e.xOffset,e.yOffset,h,p)):r.texSubImage2D(t,a,n,i,h,p,u,d,l)}var R=[];function L(){return R.pop()||new E}function D(e){e.needsFree&&je.freeType(e.data),E.call(e),R.push(e)}function z(){A.call(this),this.genMipmaps=!1,this.mipmapHint=un,this.mipmask=0,this.images=Array(16)}function j(e,t,r){var n=e.images[0]=L();e.mipmask=1,n.width=e.width=t,n.height=e.height=r,n.channels=e.channels=4}function F(e,t){var r=null;if(Un(t))T(r=e.images[0]=L(),e),I(r,t),e.mipmask=1;else if(M(e,t),Array.isArray(t.mipmap))for(var n=t.mipmap,i=0;i>=i,r.height>>=i,I(r,n[i]),e.mipmask|=1<=0&&!("faces"in t)&&(e.genMipmaps=!0)}if("mag"in t){var n=t.mag;re.parameter(n,d),e.magFilter=d[n]}var o=e.wrapS,a=e.wrapT;if("wrap"in t){var s=t.wrap;"string"===typeof s?(re.parameter(s,u),o=a=u[s]):Array.isArray(s)&&(re.parameter(s[0],u),re.parameter(s[1],u),o=u[s[0]],a=u[s[1]])}else{if("wrapS"in t){var l=t.wrapS;re.parameter(l,u),o=u[l]}if("wrapT"in t){var p=t.wrapT;re.parameter(p,u),a=u[p]}}if(e.wrapS=o,e.wrapT=a,"anisotropic"in t){var f=t.anisotropic;re("number"===typeof f&&f>=1&&f<=i.maxAnisotropic,"aniso samples must be between 1 and "),e.anisotropic=t.anisotropic}if("mipmap"in t){var m=!1;switch(typeof t.mipmap){case"string":re.parameter(t.mipmap,c,"invalid mipmap hint"),e.mipmapHint=c[t.mipmap],e.genMipmaps=!0,m=!0;break;case"boolean":m=e.genMipmaps=t.mipmap;break;case"object":re(Array.isArray(t.mipmap),"invalid mipmap type"),e.genMipmaps=!1,m=!0;break;default:re.raise("invalid mipmap type")}m&&!("min"in t)&&(e.minFilter=on)}}function W(e,t){r.texParameteri(t,tn,e.minFilter),r.texParameteri(t,en,e.magFilter),r.texParameteri(t,Xr,e.wrapS),r.texParameteri(t,Zr,e.wrapT),n.ext_texture_filter_anisotropic&&r.texParameteri(t,pn,e.anisotropic),e.genMipmaps&&(r.hint(cn,e.mipmapHint),r.generateMipmap(t))}var q=0,G={},Y=i.maxTextureUnits,X=Array(Y).map((function(){return null}));function Z(e){A.call(this),this.mipmask=0,this.internalformat=gr,this.id=q++,this.refCount=1,this.target=e,this.texture=r.createTexture(),this.unit=-1,this.bindCount=0,this.texInfo=new H,l.profile&&(this.stats={size:0})}function K(e){r.activeTexture(xn),r.bindTexture(e.target,e.texture)}function J(){var e=X[0];e?r.bindTexture(e.target,e.texture):r.bindTexture(pr,null)}function Q(e){var t=e.texture;re(t,"must not double destroy texture");var n=e.unit,i=e.target;n>=0&&(r.activeTexture(xn+n),r.bindTexture(i,null),X[n]=null),r.deleteTexture(t),e.texture=null,e.params=null,e.pixels=null,e.refCount=0,delete G[e.id],s.textureCount--}function ee(e,t){var n=new Z(pr);function o(e,t){var r=n.texInfo;H.call(r);var a=V();return"number"===typeof e?j(a,0|e,"number"===typeof t?0|t:0|e):e?(re.type(e,"object","invalid arguments to regl.texture"),$(r,e),F(a,e)):j(a,1,1),r.genMipmaps&&(a.mipmask=(a.width<<1)-1),n.mipmask=a.mipmask,T(n,a),re.texture2D(r,a,i),n.internalformat=a.internalformat,o.width=a.width,o.height=a.height,K(n),N(a,pr),W(r,pr),J(),U(a),l.profile&&(n.stats.size=Yn(n.internalformat,n.type,a.width,a.height,r.genMipmaps,!1)),o.format=x[n.internalformat],o.type=b[n.type],o.mag=_[r.magFilter],o.min=w[r.minFilter],o.wrapS=k[r.wrapS],o.wrapT=k[r.wrapT],o}function a(e,t,r,i){re(!!e,"must specify image data");var a=0|t,s=0|r,l=0|i,c=L();return T(c,n),c.width=0,c.height=0,I(c,e),c.width=c.width||(n.width>>l)-a,c.height=c.height||(n.height>>l)-s,re(n.type===c.type&&n.format===c.format&&n.internalformat===c.internalformat,"incompatible format for texture.subimage"),re(a>=0&&s>=0&&a+c.width<=n.width&&s+c.height<=n.height,"texture.subimage write out of bounds"),re(n.mipmask&1<>s;++s){var c=i>>s,u=a>>s;if(!c||!u)break;r.texImage2D(pr,s,n.format,c,u,0,n.format,n.type,null)}return J(),l.profile&&(n.stats.size=Yn(n.internalformat,n.type,i,a,!1,!1)),o}return G[n.id]=n,s.textureCount++,o(e,t),o.subimage=a,o.resize=c,o._reglType="texture2d",o._texture=n,l.profile&&(o.stats=n.stats),o.destroy=function(){n.decRef()},o}function te(e,t,n,o,a,c){var u=new Z(fr);G[u.id]=u,s.cubeCount++;var d=new Array(6);function h(e,t,r,n,o,a){var s,c=u.texInfo;for(H.call(c),s=0;s<6;++s)d[s]=V();if("number"!==typeof e&&e)if("object"===typeof e)if(t)F(d[0],e),F(d[1],t),F(d[2],r),F(d[3],n),F(d[4],o),F(d[5],a);else if($(c,e),M(u,e),"faces"in e){var p=e.faces;for(re(Array.isArray(p)&&6===p.length,"cube faces must be a length 6 array"),s=0;s<6;++s)re("object"===typeof p[s]&&!!p[s],"invalid input for cube map face"),T(d[s],u),F(d[s],p[s])}else for(s=0;s<6;++s)F(d[s],e);else re.raise("invalid arguments to cube map");else{var f=0|e||1;for(s=0;s<6;++s)j(d[s],f,f)}for(T(u,d[0]),re.optional((function(){i.npotTextureCube||re(dr(u.width)&&dr(u.height),"your browser does not support non power or two texture dimensions")})),c.genMipmaps?u.mipmask=(d[0].width<<1)-1:u.mipmask=d[0].mipmask,re.textureCube(u,c,d,i),u.internalformat=d[0].internalformat,h.width=d[0].width,h.height=d[0].height,K(u),s=0;s<6;++s)N(d[s],mr+s);for(W(c,fr),J(),l.profile&&(u.stats.size=Yn(u.internalformat,u.type,h.width,h.height,c.genMipmaps,!0)),h.format=x[u.internalformat],h.type=b[u.type],h.mag=_[c.magFilter],h.min=w[c.minFilter],h.wrapS=k[c.wrapS],h.wrapT=k[c.wrapT],s=0;s<6;++s)U(d[s]);return h}function p(e,t,r,n,i){re(!!t,"must specify image data"),re("number"===typeof e&&e===(0|e)&&e>=0&&e<6,"invalid face");var o=0|r,a=0|n,s=0|i,l=L();return T(l,u),l.width=0,l.height=0,I(l,t),l.width=l.width||(u.width>>s)-o,l.height=l.height||(u.height>>s)-a,re(u.type===l.type&&u.format===l.format&&u.internalformat===l.internalformat,"incompatible format for texture.subimage"),re(o>=0&&a>=0&&o+l.width<=u.width&&a+l.height<=u.height,"texture.subimage write out of bounds"),re(u.mipmask&1<>i;++i)r.texImage2D(mr+n,i,u.format,t>>i,t>>i,0,u.format,u.type,null);return J(),l.profile&&(u.stats.size=Yn(u.internalformat,u.type,h.width,h.height,!1,!0)),h}}return h(e,t,n,o,a,c),h.subimage=p,h.resize=f,h._reglType="textureCube",h._texture=u,l.profile&&(h.stats=u.stats),h.destroy=function(){u.decRef()},h}function ne(){for(var e=0;e>t,e.height>>t,0,e.internalformat,e.type,null);else for(var n=0;n<6;++n)r.texImage2D(mr+n,t,e.internalformat,e.width>>t,e.height>>t,0,e.internalformat,e.type,null);W(e.texInfo,e.target)}))}function oe(){for(var e=0;e0)continue;i.unit=-1}X[n]=e,t=n;break}t>=Y&&re.raise("insufficient number of texture units"),l.profile&&s.maxTextureUnits=2,"invalid renderbuffer shape"),s=0|p[0],l=0|p[1]}else"radius"in h&&(s=l=0|h.radius),"width"in h&&(s=0|h.width),"height"in h&&(l=0|h.height);"format"in h&&(re.parameter(h.format,o,"invalid renderbuffer format"),c=o[h.format])}else"number"===typeof t?(s=0|t,l="number"===typeof n?0|n:s):t?re.raise("invalid arguments to renderbuffer constructor"):s=l=1;if(re(s>0&&l>0&&s<=r.maxRenderbufferSize&&l<=r.maxRenderbufferSize,"invalid renderbuffer size"),s!==u.width||l!==u.height||c!==u.format)return d.width=u.width=s,d.height=u.height=l,u.format=c,e.bindRenderbuffer(Zn,u.renderbuffer),e.renderbufferStorage(Zn,c,s,l),re(0===e.getError(),"invalid render buffer format"),i.profile&&(u.stats.size=li(u.format,u.width,u.height)),d.format=a[u.format],d}function h(t,n){var o=0|t,a=0|n||o;return o===u.width&&a===u.height||(re(o>0&&a>0&&o<=r.maxRenderbufferSize&&a<=r.maxRenderbufferSize,"invalid renderbuffer size"),d.width=u.width=o,d.height=u.height=a,e.bindRenderbuffer(Zn,u.renderbuffer),e.renderbufferStorage(Zn,u.format,o,a),re(0===e.getError(),"invalid render buffer format"),i.profile&&(u.stats.size=li(u.format,u.width,u.height))),d}return l[u.id]=u,n.renderbufferCount++,d(t,s),d.resize=h,d._reglType="renderbuffer",d._renderbuffer=u,i.profile&&(d.stats=u.stats),d.destroy=function(){u.decRef()},d}function h(){St(l).forEach((function(t){t.renderbuffer=e.createRenderbuffer(),e.bindRenderbuffer(Zn,t.renderbuffer),e.renderbufferStorage(Zn,t.format,t.width,t.height)})),e.bindRenderbuffer(Zn,null)}return c.prototype.decRef=function(){--this.refCount<=0&&u(this)},i.profile&&(n.getTotalRenderbufferSize=function(){var e=0;return Object.keys(l).forEach((function(t){e+=l[t].stats.size})),e}),{create:d,clear:function(){St(l).forEach(u)},restore:h}},ui=36160,di=36161,hi=3553,pi=34069,fi=36064,mi=36096,gi=36128,yi=33306,vi=36053,xi=36054,bi=36055,_i=36057,wi=36061,ki=36193,Si=5121,Ai=5126,Ti=6407,Mi=6408,Ci=6402,Ei=[Ti,Mi],Ii=[];Ii[Mi]=4,Ii[Ti]=3;var Pi=[];Pi[Si]=1,Pi[Ai]=4,Pi[ki]=2;var Oi=33189,Ri=36168,Li=34041,Di=[32854,32855,36194,35907,34842,34843,34836],zi={};function ji(e,r,n,i,o,a){var s={cur:null,next:null,dirty:!1,setFBO:null},l=["rgba"],c=["rgba4","rgb565","rgb5 a1"];r.ext_srgb&&c.push("srgba"),r.ext_color_buffer_half_float&&c.push("rgba16f","rgb16f"),r.webgl_color_buffer_float&&c.push("rgba32f");var u=["uint8"];function d(e,t,r){this.target=e,this.texture=t,this.renderbuffer=r;var n=0,i=0;t?(n=t.width,i=t.height):r&&(n=r.width,i=r.height),this.width=n,this.height=i}function h(e){e&&(e.texture&&e.texture._texture.decRef(),e.renderbuffer&&e.renderbuffer._renderbuffer.decRef())}function p(e,t,r){if(e)if(e.texture){var n=e.texture._texture,i=Math.max(1,n.width),o=Math.max(1,n.height);re(i===t&&o===r,"inconsistent width/height for supplied texture"),n.refCount+=1}else{var a=e.renderbuffer._renderbuffer;re(a.width===t&&a.height===r,"inconsistent width/height for renderbuffer"),a.refCount+=1}}function f(t,r){r&&(r.texture?e.framebufferTexture2D(ui,t,r.target,r.texture._texture.texture,0):e.framebufferRenderbuffer(ui,t,di,r.renderbuffer._renderbuffer.renderbuffer))}function m(e){var t=hi,r=null,n=null,i=e;"object"===typeof e&&(i=e.data,"target"in e&&(t=0|e.target)),re.type(i,"function","invalid attachment data");var o=i._reglType;return"texture2d"===o?(r=i,re(t===hi)):"textureCube"===o?(r=i,re(t>=pi&&t=2,"invalid shape for framebuffer"),a=P[0],h=P[1]}else"radius"in I&&(a=h=I.radius),"width"in I&&(a=I.width),"height"in I&&(h=I.height);("color"in I||"colors"in I)&&(x=I.color||I.colors,Array.isArray(x)&&re(1===x.length||r.webgl_draw_buffers,"multiple render targets not supported")),x||("colorCount"in I&&(A=0|I.colorCount,re(A>0,"invalid color buffer count")),"colorTexture"in I&&(b=!!I.colorTexture,_="rgba4"),"colorType"in I&&(k=I.colorType,b?(re(r.oes_texture_float||!("float"===k||"float32"===k),"you must enable OES_texture_float in order to use floating point framebuffer objects"),re(r.oes_texture_half_float||!("half float"===k||"float16"===k),"you must enable OES_texture_half_float in order to use 16-bit floating point framebuffer objects")):"half float"===k||"float16"===k?(re(r.ext_color_buffer_half_float,"you must enable EXT_color_buffer_half_float to use 16-bit render buffers"),_="rgba16f"):"float"!==k&&"float32"!==k||(re(r.webgl_color_buffer_float,"you must enable WEBGL_color_buffer_float in order to use 32-bit floating point renderbuffers"),_="rgba32f"),re.oneOf(k,u,"invalid color type")),"colorFormat"in I&&(_=I.colorFormat,l.indexOf(_)>=0?b=!0:c.indexOf(_)>=0?b=!1:re.optional((function(){b?re.oneOf(I.colorFormat,l,"invalid color format for texture"):re.oneOf(I.colorFormat,c,"invalid color format for renderbuffer")})))),("depthTexture"in I||"depthStencilTexture"in I)&&(E=!(!I.depthTexture&&!I.depthStencilTexture),re(!E||r.webgl_depth_texture,"webgl_depth_texture extension not supported")),"depth"in I&&("boolean"===typeof I.depth?f=I.depth:(T=I.depth,v=!1)),"stencil"in I&&("boolean"===typeof I.stencil?v=I.stencil:(M=I.stencil,f=!1)),"depthStencil"in I&&("boolean"===typeof I.depthStencil?f=v=I.depthStencil:(C=I.depthStencil,f=!1,v=!1))}else a=h=1;var O=null,R=null,L=null,D=null;if(Array.isArray(x))O=x.map(m);else if(x)O=[m(x)];else for(O=new Array(A),i=0;i=0||O[i].renderbuffer&&Di.indexOf(O[i].renderbuffer._renderbuffer.format)>=0,"framebuffer color attachment "+i+" is invalid"),O[i]&&O[i].texture){var j=Ii[O[i].texture._texture.format]*Pi[O[i].texture._texture.type];null===z?z=j:re(z===j,"all color attachments much have the same number of bits per pixel.")}return p(R,a,h),re(!R||R.texture&&R.texture._texture.format===Ci||R.renderbuffer&&R.renderbuffer._renderbuffer.format===Oi,"invalid depth attachment for framebuffer object"),p(L,a,h),re(!L||L.renderbuffer&&L.renderbuffer._renderbuffer.format===Ri,"invalid stencil attachment for framebuffer object"),p(D,a,h),re(!D||D.texture&&D.texture._texture.format===Li||D.renderbuffer&&D.renderbuffer._renderbuffer.format===Li,"invalid depth-stencil attachment for framebuffer object"),w(o),o.width=a,o.height=h,o.colorAttachments=O,o.depthAttachment=R,o.stencilAttachment=L,o.depthStencilAttachment=D,d.color=O.map(y),d.depth=y(R),d.stencil=y(L),d.depthStencil=y(D),d.width=o.width,d.height=o.height,S(o),d}function h(e,t){re(s.next!==o,"can not resize a framebuffer which is currently in use");var r=Math.max(0|e,1),n=Math.max(0|t||r,1);if(r===o.width&&n===o.height)return d;for(var i=o.colorAttachments,a=0;a=2,"invalid shape for framebuffer"),re(v[0]===v[1],"cube framebuffer must be square"),h=v[0]}else"radius"in y&&(h=0|y.radius),"width"in y?(h=0|y.width,"height"in y&&re(y.height===h,"must be square")):"height"in y&&(h=0|y.height);("color"in y||"colors"in y)&&(p=y.color||y.colors,Array.isArray(p)&&re(1===p.length||r.webgl_draw_buffers,"multiple render targets not supported")),p||("colorCount"in y&&(g=0|y.colorCount,re(g>0,"invalid color buffer count")),"colorType"in y&&(re.oneOf(y.colorType,u,"invalid color type"),m=y.colorType),"colorFormat"in y&&(f=y.colorFormat,re.oneOf(y.colorFormat,l,"invalid color format for texture"))),"depth"in y&&(d.depth=y.depth),"stencil"in y&&(d.stencil=y.stencil),"depthStencil"in y&&(d.depthStencil=y.depthStencil)}else h=1;if(p)if(Array.isArray(p))for(c=[],n=0;n0&&(d.depth=o[0].depth,d.stencil=o[0].stencil,d.depthStencil=o[0].depthStencil),o[n]?o[n](d):o[n]=A(d)}return t(a,{width:h,height:h,color:c})}function c(e){var t,r=0|e;if(re(r>0&&r<=n.maxCubeMapSize,"invalid radius for cube fbo"),r===a.width)return a;var i=a.color;for(t=0;t{for(var e=Object.keys(t),r=0;r=0,'invalid option for vao: "'+e[r]+'" valid options are '+Vi)})),re(Array.isArray(i),"attributes must be an array")}re(i.length0,"must specify at least one attribute");var u={},d=n.attributes;d.length=i.length;for(var h=0;h=g.byteLength?p.subdata(g):(p.destroy(),n.buffers[h]=null)),n.buffers[h]||(p=n.buffers[h]=o.create(f,Ni,!1,!0)),m.buffer=o.getBuffer(p),m.size=0|m.buffer.dimension,m.normalized=!1,m.type=m.buffer.dtype,m.offset=0,m.stride=0,m.divisor=0,m.state=1,u[h]=1):o.getBuffer(f)?(m.buffer=o.getBuffer(f),m.size=0|m.buffer.dimension,m.normalized=!1,m.type=m.buffer.dtype,m.offset=0,m.stride=0,m.divisor=0,m.state=1):o.getBuffer(f.buffer)?(m.buffer=o.getBuffer(f.buffer),m.size=0|(+f.size||m.buffer.dimension),m.normalized=!!f.normalized||!1,"type"in f?(re.parameter(f.type,Rt,"invalid buffer type"),m.type=Rt[f.type]):m.type=m.buffer.dtype,m.offset=0|(f.offset||0),m.stride=0|(f.stride||0),m.divisor=0|(f.divisor||0),m.state=1,re(m.size>=1&&m.size<=4,"size must be between 1 and 4"),re(m.offset>=0,"invalid offset"),re(m.stride>=0&&m.stride<=255,"stride must be between 0 and 255"),re(m.divisor>=0,"divisor must be positive"),re(!m.divisor||!!r.angle_instanced_arrays,"ANGLE_instanced_arrays must be enabled to use divisor")):"x"in f?(re(h>0,"first attribute must not be a constant"),m.x=+f.x||0,m.y=+f.y||0,m.z=+f.z||0,m.w=+f.w||0,m.state=2):re(!1,"invalid attribute spec for location "+h)}for(var y=0;y1)for(var y=0;ye&&(e=t.stats.uniformsCount)})),e},n.getMaxAttributesCount=function(){var e=0;return d.forEach((function(t){t.stats.attributesCount>e&&(e=t.stats.attributesCount)})),e}),{clear:function(){var t=e.deleteShader.bind(e);St(o).forEach(t),o={},St(a).forEach(t),a={},d.forEach((function(t){e.deleteProgram(t.program)})),d.length=0,u={},n.shaderCount=0},program:function(r,i,s,l){re.command(r>=0,"missing vertex shader",s),re.command(i>=0,"missing fragment shader",s);var c=u[i];c||(c=u[i]={});var h=c[r];if(h&&(h.refCount++,!l))return h;var m=new p(i,r);return n.shaderCount++,f(m,s,l),h||(c[r]=m),d.push(m),t(m,{destroy:function(){if(m.refCount--,m.refCount<=0){e.deleteProgram(m.program);var t=d.indexOf(m);d.splice(t,1),n.shaderCount--}c[m.vertId].refCount<=0&&(e.deleteShader(a[m.vertId]),delete a[m.vertId],delete u[m.fragId][m.vertId]),Object.keys(u[m.fragId]).length||(e.deleteShader(o[m.fragId]),delete o[m.fragId],delete u[m.fragId])}})},restore:m,shader:c,frag:-1,vert:-1}}var Xi=6408,Zi=5121,Ki=3333,Ji=5126;function Qi(t,r,n,i,o,a,s){function l(l){var c;null===r.next?(re(o.preserveDrawingBuffer,'you must create a webgl context with "preserveDrawingBuffer":true in order to read pixels from the drawing buffer'),c=Zi):(re(null!==r.next.colorAttachments[0].texture,"You cannot read from a renderbuffer"),c=r.next.colorAttachments[0].texture._texture.type,re.optional((function(){a.oes_texture_float?(re(c===Zi||c===Ji,"Reading from a framebuffer is only allowed for the types 'uint8' and 'float'"),c===Ji&&re(s.readFloat,"Reading 'float' values is not permitted in your browser. For a fallback, please see: https://www.npmjs.com/package/glsl-read-float")):re(c===Zi,"Reading from a framebuffer is only allowed for the type 'uint8'")})));var u=0,d=0,h=i.framebufferWidth,p=i.framebufferHeight,f=null;e(l)?f=l:l&&(re.type(l,"object","invalid arguments to regl.read()"),u=0|l.x,d=0|l.y,re(u>=0&&u=0&&d0&&h+u<=i.framebufferWidth,"invalid width for read pixels"),re(p>0&&p+d<=i.framebufferHeight,"invalid height for read pixels"),n();var m=h*p*4;return f||(c===Zi?f=new Uint8Array(m):c===Ji&&(f=f||new Float32Array(m))),re.isTypedArray(f,"data buffer for regl.read() must be a typedarray"),re(f.byteLength>=m,"data buffer for regl.read() too small"),t.pixelStorei(Ki,4),t.readPixels(u,d,h,p,Xi,c,f),f}function c(e){var t;return r.setFBO({framebuffer:e.framebuffer},(function(){t=l(e)})),t}function u(e){return e&&"framebuffer"in e?c(e):l(e)}return u}function eo(e){return Array.prototype.slice.call(e)}function to(e){return eo(e).join("")}function ro(){var e=0,r=[],n=[];function i(t){for(var i=0;i0&&(r.push(t,"="),r.push.apply(r,eo(arguments)),r.push(";")),t}return t(n,{def:o,toString:function(){return to([i.length>0?"var "+i.join(",")+";":"",to(r)])}})}function a(){var e=o(),r=o(),n=e.toString,i=r.toString;function a(t,n){r(t,n,"=",e.def(t,n),";")}return t((function(){e.apply(e,eo(arguments))}),{def:e.def,entry:e,exit:r,save:a,set:function(t,r,n){a(t,r),e(t,r,"=",n,";")},toString:function(){return n()+i()}})}function s(){var e=to(arguments),r=a(),n=a(),i=r.toString,o=n.toString;return t(r,{then:function(){return r.apply(r,eo(arguments)),this},else:function(){return n.apply(n,eo(arguments)),this},toString:function(){var t=o();return t&&(t="else{"+t+"}"),to(["if(",e,"){",i(),"}",t])}})}var l=o(),c={};function u(e,r){var n=[];function i(){var e="a"+n.length;return n.push(e),e}r=r||0;for(var o=0;o":516,notequal:517,"!=":517,"!==":517,gequal:518,">=":518,always:519},rs={0:0,zero:0,keep:7680,replace:7681,increment:7682,decrement:7683,"increment wrap":34055,"decrement wrap":34056,invert:5386},ns={frag:35632,vert:35633},is={cw:Va,ccw:Ua};function os(t){return Array.isArray(t)||e(t)||kt(t)}function as(e){return e.sort((function(e,t){return e===Vo?-1:t===Vo?1:e=1,n>=2,t)}if(r===ho){var i=e.data;return new ss(i.thisDep,i.contextDep,i.propDep,t)}if(r===po)return new ss(!1,!1,!1,t);if(r===fo){for(var o=!1,a=!1,s=!1,l=0;l=1&&(a=!0),u>=2&&(s=!0)}else c.type===ho&&(o=o||c.data.thisDep,a=a||c.data.contextDep,s=s||c.data.propDep)}return new ss(o,a,s,t)}return new ss(r===uo,r===co,r===lo,t)}var ds=new ss(!1,!1,!1,(function(){}));function hs(e,r,n,i,o,a,s,l,c,u,d,h,p,f,m){var g=u.Record,y={add:32774,subtract:32778,"reverse subtract":32779};n.ext_blend_minmax&&(y.min=Ha,y.max=$a);var v=n.angle_instanced_arrays,x=n.webgl_draw_buffers,b=n.oes_vertex_array_object,_={dirty:!0,profile:m.profile},w={},k=[],S={},A={};function T(e){return e.replace(".","_")}function M(e,t,r){var n=T(e);k.push(e),w[n]=_[n]=!!r,S[n]=t}function C(e,t,r){var n=T(e);k.push(e),Array.isArray(r)?(_[n]=r.slice(),w[n]=r.slice()):_[n]=w[n]=r,A[n]=t}M(mo,fa),M(go,pa),C(yo,"blendColor",[0,0,0,0]),C(vo,"blendEquationSeparate",[Xa,Xa]),C(xo,"blendFuncSeparate",[Ya,Ga,Ya,Ga]),M(bo,ga,!0),C(_o,"depthFunc",Za),C(wo,"depthRange",[0,1]),C(ko,"depthMask",!0),C(So,So,[!0,!0,!0,!0]),M(Ao,ha),C(To,"cullFace",Ba),C(Mo,Mo,Ua),C(Co,Co,1),M(Eo,va),C(Io,"polygonOffset",[0,0]),M(Po,xa),M(Oo,ba),C(Ro,"sampleCoverage",[1,!1]),M(Lo,ma),C(Do,"stencilMask",-1),C(zo,"stencilFunc",[Wa,0,-1]),C(jo,"stencilOpSeparate",[Na,qa,qa,qa]),C(Fo,"stencilOpSeparate",[Ba,qa,qa,qa]),M(No,ya),C(Bo,"scissor",[0,0,e.drawingBufferWidth,e.drawingBufferHeight]),C(Vo,Vo,[0,0,e.drawingBufferWidth,e.drawingBufferHeight]);var E={gl:e,context:p,strings:r,next:w,current:_,draw:h,elements:a,buffer:o,shader:d,attributes:u.state,vao:u,uniforms:c,framebuffer:l,extensions:n,timer:f,isBufferArgs:os},I={primTypes:qt,compareFuncs:ts,blendFuncs:Qa,blendEquations:y,stencilOps:rs,glTypes:Rt,orientationType:is};re.optional((function(){E.isArrayLike=ur})),x&&(I.backBuffer=[Ba],I.drawBuffer=Te(i.maxDrawbuffers,(function(e){return 0===e?[0]:Te(e,(function(e){return Ja+e}))})));var P=0;function O(){var e=ro(),t=e.link,n=e.global;e.id=P++,e.batchId="0";var i=t(E),o=e.shared={props:"a0"};Object.keys(E).forEach((function(e){o[e]=n.def(i,".",e)})),re.optional((function(){e.CHECK=t(re),e.commandStr=re.guessCommand(),e.command=t(e.commandStr),e.assert=function(e,r,n){e("if(!(",r,"))",this.CHECK,".commandRaise(",t(n),",",this.command,");")},I.invalidBlendCombinations=es}));var a=e.next={},s=e.current={};Object.keys(A).forEach((function(e){Array.isArray(_[e])&&(a[e]=n.def(o.next,".",e),s[e]=n.def(o.current,".",e))}));var l=e.constants={};Object.keys(I).forEach((function(e){l[e]=n.def(JSON.stringify(I[e]))})),e.invoke=function(r,n){switch(n.type){case so:var i=["this",o.context,o.props,e.batchId];return r.def(t(n.data),".call(",i.slice(0,Math.max(n.data.length+1,4)),")");case lo:return r.def(o.props,n.data);case co:return r.def(o.context,n.data);case uo:return r.def("this",n.data);case ho:return n.data.append(e,r),n.data.ref;case po:return n.data.toString();case fo:return n.data.map((function(t){return e.invoke(r,t)}))}},e.attribCache={};var c={};return e.scopeAttrib=function(e){var n=r.id(e);if(n in c)return c[n];var i=u.scope[n];return i||(i=u.scope[n]=new g),c[n]=t(i)},e}function R(e){var t,r=e.static,n=e.dynamic;if(Uo in r){var i=!!r[Uo];(t=cs((function(e,t){return i}))).enable=i}else if(Uo in n){var o=n[Uo];t=us(o,(function(e,t){return e.invoke(t,o)}))}return t}function L(e,t){var r=e.static,n=e.dynamic;if(Ho in r){var i=r[Ho];return i?(i=l.getFramebuffer(i),re.command(i,"invalid framebuffer object"),cs((function(e,t){var r=e.link(i),n=e.shared;t.set(n.framebuffer,".next",r);var o=n.context;return t.set(o,"."+ea,r+".width"),t.set(o,"."+ta,r+".height"),r}))):cs((function(e,t){var r=e.shared;t.set(r.framebuffer,".next","null");var n=r.context;return t.set(n,"."+ea,n+"."+oa),t.set(n,"."+ta,n+"."+aa),"null"}))}if(Ho in n){var o=n[Ho];return us(o,(function(e,t){var r=e.invoke(t,o),n=e.shared,i=n.framebuffer,a=t.def(i,".getFramebuffer(",r,")");re.optional((function(){e.assert(t,"!"+r+"||"+a,"invalid framebuffer object")})),t.set(i,".next",a);var s=n.context;return t.set(s,"."+ea,a+"?"+a+".width:"+s+"."+oa),t.set(s,"."+ta,a+"?"+a+".height:"+s+"."+aa),a}))}return null}function D(e,t,r){var n=e.static,i=e.dynamic;function o(e){if(e in n){var o=n[e];re.commandType(o,"object","invalid "+e,r.commandStr);var a,s,l=!0,c=0|o.x,u=0|o.y;return"width"in o?(a=0|o.width,re.command(a>=0,"invalid "+e,r.commandStr)):l=!1,"height"in o?(s=0|o.height,re.command(s>=0,"invalid "+e,r.commandStr)):l=!1,new ss(!l&&t&&t.thisDep,!l&&t&&t.contextDep,!l&&t&&t.propDep,(function(e,t){var r=e.shared.context,n=a;"width"in o||(n=t.def(r,".",ea,"-",c));var i=s;return"height"in o||(i=t.def(r,".",ta,"-",u)),[c,u,n,i]}))}if(e in i){var d=i[e],h=us(d,(function(t,r){var n=t.invoke(r,d);re.optional((function(){t.assert(r,n+"&&typeof "+n+'==="object"',"invalid "+e)}));var i=t.shared.context,o=r.def(n,".x|0"),a=r.def(n,".y|0"),s=r.def('"width" in ',n,"?",n,".width|0:","(",i,".",ea,"-",o,")"),l=r.def('"height" in ',n,"?",n,".height|0:","(",i,".",ta,"-",a,")");return re.optional((function(){t.assert(r,s+">=0&&"+l+">=0","invalid "+e)})),[o,a,s,l]}));return t&&(h.thisDep=h.thisDep||t.thisDep,h.contextDep=h.contextDep||t.contextDep,h.propDep=h.propDep||t.propDep),h}return t?new ss(t.thisDep,t.contextDep,t.propDep,(function(e,t){var r=e.shared.context;return[0,0,t.def(r,".",ea),t.def(r,".",ta)]})):null}var a=o(Vo);if(a){var s=a;a=new ss(a.thisDep,a.contextDep,a.propDep,(function(e,t){var r=s.append(e,t),n=e.shared.context;return t.set(n,"."+ra,r[2]),t.set(n,"."+na,r[3]),r}))}return{viewport:a,scissor_box:o(Bo)}}function z(e,t){var r=e.static;if("string"===typeof r[Wo]&&"string"===typeof r[$o]){if(Object.keys(t.dynamic).length>0)return null;var n=t.static,i=Object.keys(n);if(i.length>0&&"number"===typeof n[i[0]]){for(var o=[],a=0;a=0,"invalid "+e,t.commandStr),cs((function(e,t){return a&&(e.OFFSET=s),s}))}if(e in n){var u=n[e];return us(u,(function(t,r){var n=t.invoke(r,u);return a&&(t.OFFSET=n,re.optional((function(){t.assert(r,n+">=0","invalid "+e)}))),n}))}if(a){if(c)return cs((function(e,t){return e.OFFSET=0,0}));if(o)return new ss(l.thisDep,l.contextDep,l.propDep,(function(e,t){return t.def(e.shared.vao+".currentVAO?"+e.shared.vao+".currentVAO.offset:0")}))}else if(o)return new ss(l.thisDep,l.contextDep,l.propDep,(function(e,t){return t.def(e.shared.vao+".currentVAO?"+e.shared.vao+".currentVAO.instances:-1")}));return null}var m=f(Xo,!0);function g(){if(Yo in r){var e=0|r[Yo];return i.count=e,re.command("number"===typeof e&&e>=0,"invalid vertex count",t.commandStr),cs((function(){return e}))}if(Yo in n){var a=n[Yo];return us(a,(function(e,t){var r=e.invoke(t,a);return re.optional((function(){e.assert(t,"typeof "+r+'==="number"&&'+r+">=0&&"+r+"===("+r+"|0)","invalid vertex count")})),r}))}if(c){if(ls(h)){if(h)return m?new ss(m.thisDep,m.contextDep,m.propDep,(function(e,t){var r=t.def(e.ELEMENTS,".vertCount-",e.OFFSET);return re.optional((function(){e.assert(t,r+">=0","invalid vertex offset/element buffer too small")})),r})):cs((function(e,t){return t.def(e.ELEMENTS,".vertCount")}));var s=cs((function(){return-1}));return re.optional((function(){s.MISSING=!0})),s}var u=new ss(h.thisDep||m.thisDep,h.contextDep||m.contextDep,h.propDep||m.propDep,(function(e,t){var r=e.ELEMENTS;return e.OFFSET?t.def(r,"?",r,".vertCount-",e.OFFSET,":-1"):t.def(r,"?",r,".vertCount:-1")}));return re.optional((function(){u.DYNAMIC=!0})),u}if(o){var d=new ss(l.thisDep,l.contextDep,l.propDep,(function(e,t){return t.def(e.shared.vao,".currentVAO?",e.shared.vao,".currentVAO.count:-1")}));return d}return null}var y=p(),v=g(),x=f(Zo,!1);return{elements:h,primitive:y,count:v,instances:x,offset:m,vao:l,vaoActive:o,elementsActive:c,static:i}}function N(e,t){var r=e.static,n=e.dynamic,o={};return k.forEach((function(e){var a=T(e);function s(t,i){if(e in r){var s=t(r[e]);o[a]=cs((function(){return s}))}else if(e in n){var l=n[e];o[a]=us(l,(function(e,t){return i(e,t,e.invoke(t,l))}))}}switch(e){case Ao:case go:case mo:case Lo:case bo:case No:case Eo:case Po:case Oo:case ko:return s((function(r){return re.commandType(r,"boolean",e,t.commandStr),r}),(function(t,r,n){return re.optional((function(){t.assert(r,"typeof "+n+'==="boolean"',"invalid flag "+e,t.commandStr)})),n}));case _o:return s((function(r){return re.commandParameter(r,ts,"invalid "+e,t.commandStr),ts[r]}),(function(t,r,n){var i=t.constants.compareFuncs;return re.optional((function(){t.assert(r,n+" in "+i,"invalid "+e+", must be one of "+Object.keys(ts))})),r.def(i,"[",n,"]")}));case wo:return s((function(e){return re.command(ur(e)&&2===e.length&&"number"===typeof e[0]&&"number"===typeof e[1]&&e[0]<=e[1],"depth range is 2d array",t.commandStr),e}),(function(e,t,r){return re.optional((function(){e.assert(t,e.shared.isArrayLike+"("+r+")&&"+r+".length===2&&typeof "+r+'[0]==="number"&&typeof '+r+'[1]==="number"&&'+r+"[0]<="+r+"[1]","depth range must be a 2d array")})),[t.def("+",r,"[0]"),t.def("+",r,"[1]")]}));case xo:return s((function(e){re.commandType(e,"object","blend.func",t.commandStr);var r="srcRGB"in e?e.srcRGB:e.src,n="srcAlpha"in e?e.srcAlpha:e.src,i="dstRGB"in e?e.dstRGB:e.dst,o="dstAlpha"in e?e.dstAlpha:e.dst;return re.commandParameter(r,Qa,a+".srcRGB",t.commandStr),re.commandParameter(n,Qa,a+".srcAlpha",t.commandStr),re.commandParameter(i,Qa,a+".dstRGB",t.commandStr),re.commandParameter(o,Qa,a+".dstAlpha",t.commandStr),re.command(-1===es.indexOf(r+", "+i),"unallowed blending combination (srcRGB, dstRGB) = ("+r+", "+i+")",t.commandStr),[Qa[r],Qa[i],Qa[n],Qa[o]]}),(function(t,r,n){var i=t.constants.blendFuncs;function o(o,a){var s=r.def('"',o,a,'" in ',n,"?",n,".",o,a,":",n,".",o);return re.optional((function(){t.assert(r,s+" in "+i,"invalid "+e+"."+o+a+", must be one of "+Object.keys(Qa))})),s}re.optional((function(){t.assert(r,n+"&&typeof "+n+'==="object"',"invalid blend func, must be an object")}));var a=o("src","RGB"),s=o("dst","RGB");re.optional((function(){var e=t.constants.invalidBlendCombinations;t.assert(r,e+".indexOf("+a+'+", "+'+s+") === -1 ","unallowed blending combination for (srcRGB, dstRGB)")}));var l=r.def(i,"[",a,"]"),c=r.def(i,"[",o("src","Alpha"),"]");return[l,r.def(i,"[",s,"]"),c,r.def(i,"[",o("dst","Alpha"),"]")]}));case vo:return s((function(r){return"string"===typeof r?(re.commandParameter(r,y,"invalid "+e,t.commandStr),[y[r],y[r]]):"object"===typeof r?(re.commandParameter(r.rgb,y,e+".rgb",t.commandStr),re.commandParameter(r.alpha,y,e+".alpha",t.commandStr),[y[r.rgb],y[r.alpha]]):void re.commandRaise("invalid blend.equation",t.commandStr)}),(function(t,r,n){var i=t.constants.blendEquations,o=r.def(),a=r.def(),s=t.cond("typeof ",n,'==="string"');return re.optional((function(){function r(e,r,n){t.assert(e,n+" in "+i,"invalid "+r+", must be one of "+Object.keys(y))}r(s.then,e,n),t.assert(s.else,n+"&&typeof "+n+'==="object"',"invalid "+e),r(s.else,e+".rgb",n+".rgb"),r(s.else,e+".alpha",n+".alpha")})),s.then(o,"=",a,"=",i,"[",n,"];"),s.else(o,"=",i,"[",n,".rgb];",a,"=",i,"[",n,".alpha];"),r(s),[o,a]}));case yo:return s((function(e){return re.command(ur(e)&&4===e.length,"blend.color must be a 4d array",t.commandStr),Te(4,(function(t){return+e[t]}))}),(function(e,t,r){return re.optional((function(){e.assert(t,e.shared.isArrayLike+"("+r+")&&"+r+".length===4","blend.color must be a 4d array")})),Te(4,(function(e){return t.def("+",r,"[",e,"]")}))}));case Do:return s((function(e){return re.commandType(e,"number",a,t.commandStr),0|e}),(function(e,t,r){return re.optional((function(){e.assert(t,"typeof "+r+'==="number"',"invalid stencil.mask")})),t.def(r,"|0")}));case zo:return s((function(r){re.commandType(r,"object",a,t.commandStr);var n=r.cmp||"keep",i=r.ref||0,o="mask"in r?r.mask:-1;return re.commandParameter(n,ts,e+".cmp",t.commandStr),re.commandType(i,"number",e+".ref",t.commandStr),re.commandType(o,"number",e+".mask",t.commandStr),[ts[n],i,o]}),(function(e,t,r){var n=e.constants.compareFuncs;return re.optional((function(){function i(){e.assert(t,Array.prototype.join.call(arguments,""),"invalid stencil.func")}i(r+"&&typeof ",r,'==="object"'),i('!("cmp" in ',r,")||(",r,".cmp in ",n,")")})),[t.def('"cmp" in ',r,"?",n,"[",r,".cmp]",":",qa),t.def(r,".ref|0"),t.def('"mask" in ',r,"?",r,".mask|0:-1")]}));case jo:case Fo:return s((function(r){re.commandType(r,"object",a,t.commandStr);var n=r.fail||"keep",i=r.zfail||"keep",o=r.zpass||"keep";return re.commandParameter(n,rs,e+".fail",t.commandStr),re.commandParameter(i,rs,e+".zfail",t.commandStr),re.commandParameter(o,rs,e+".zpass",t.commandStr),[e===Fo?Ba:Na,rs[n],rs[i],rs[o]]}),(function(t,r,n){var i=t.constants.stencilOps;function o(o){return re.optional((function(){t.assert(r,'!("'+o+'" in '+n+")||("+n+"."+o+" in "+i+")","invalid "+e+"."+o+", must be one of "+Object.keys(rs))})),r.def('"',o,'" in ',n,"?",i,"[",n,".",o,"]:",qa)}return re.optional((function(){t.assert(r,n+"&&typeof "+n+'==="object"',"invalid "+e)})),[e===Fo?Ba:Na,o("fail"),o("zfail"),o("zpass")]}));case Io:return s((function(e){re.commandType(e,"object",a,t.commandStr);var r=0|e.factor,n=0|e.units;return re.commandType(r,"number",a+".factor",t.commandStr),re.commandType(n,"number",a+".units",t.commandStr),[r,n]}),(function(t,r,n){return re.optional((function(){t.assert(r,n+"&&typeof "+n+'==="object"',"invalid "+e)})),[r.def(n,".factor|0"),r.def(n,".units|0")]}));case To:return s((function(e){var r=0;return"front"===e?r=Na:"back"===e&&(r=Ba),re.command(!!r,a,t.commandStr),r}),(function(e,t,r){return re.optional((function(){e.assert(t,r+'==="front"||'+r+'==="back"',"invalid cull.face")})),t.def(r,'==="front"?',Na,":",Ba)}));case Co:return s((function(e){return re.command("number"===typeof e&&e>=i.lineWidthDims[0]&&e<=i.lineWidthDims[1],"invalid line width, must be a positive number between "+i.lineWidthDims[0]+" and "+i.lineWidthDims[1],t.commandStr),e}),(function(e,t,r){return re.optional((function(){e.assert(t,"typeof "+r+'==="number"&&'+r+">="+i.lineWidthDims[0]+"&&"+r+"<="+i.lineWidthDims[1],"invalid line width")})),r}));case Mo:return s((function(e){return re.commandParameter(e,is,a,t.commandStr),is[e]}),(function(e,t,r){return re.optional((function(){e.assert(t,r+'==="cw"||'+r+'==="ccw"',"invalid frontFace, must be one of cw,ccw")})),t.def(r+'==="cw"?'+Va+":"+Ua)}));case So:return s((function(e){return re.command(ur(e)&&4===e.length,"color.mask must be length 4 array",t.commandStr),e.map((function(e){return!!e}))}),(function(e,t,r){return re.optional((function(){e.assert(t,e.shared.isArrayLike+"("+r+")&&"+r+".length===4","invalid color.mask")})),Te(4,(function(e){return"!!"+r+"["+e+"]"}))}));case Ro:return s((function(e){re.command("object"===typeof e&&e,a,t.commandStr);var r="value"in e?e.value:1,n=!!e.invert;return re.command("number"===typeof r&&r>=0&&r<=1,"sample.coverage.value must be a number between 0 and 1",t.commandStr),[r,n]}),(function(e,t,r){return re.optional((function(){e.assert(t,r+"&&typeof "+r+'==="object"',"invalid sample.coverage")})),[t.def('"value" in ',r,"?+",r,".value:1"),t.def("!!",r,".invert")]}))}})),o}function B(e,t){var r=e.static,n=e.dynamic,i={};return Object.keys(r).forEach((function(e){var n,o=r[e];if("number"===typeof o||"boolean"===typeof o)n=cs((function(){return o}));else if("function"===typeof o){var a=o._reglType;"texture2d"===a||"textureCube"===a?n=cs((function(e){return e.link(o)})):"framebuffer"===a||"framebufferCube"===a?(re.command(o.color.length>0,'missing color attachment for framebuffer sent to uniform "'+e+'"',t.commandStr),n=cs((function(e){return e.link(o.color[0])}))):re.commandRaise('invalid data for uniform "'+e+'"',t.commandStr)}else ur(o)?n=cs((function(t){return t.global.def("[",Te(o.length,(function(r){return re.command("number"===typeof o[r]||"boolean"===typeof o[r],"invalid uniform "+e,t.commandStr),o[r]})),"]")})):re.commandRaise('invalid or missing data for uniform "'+e+'"',t.commandStr);n.value=o,i[e]=n})),Object.keys(n).forEach((function(e){var t=n[e];i[e]=us(t,(function(e,r){return e.invoke(r,t)}))})),i}function V(e,t){var n=e.static,i=e.dynamic,a={};return Object.keys(n).forEach((function(e){var i=n[e],s=r.id(e),l=new g;if(os(i))l.state=oo,l.buffer=o.getBuffer(o.create(i,la,!1,!0)),l.type=0;else{var c=o.getBuffer(i);if(c)l.state=oo,l.buffer=c,l.type=0;else if(re.command("object"===typeof i&&i,"invalid data for attribute "+e,t.commandStr),"constant"in i){var u=i.constant;l.buffer="null",l.state=ao,"number"===typeof u?l.x=u:(re.command(ur(u)&&u.length>0&&u.length<=4,"invalid constant for attribute "+e,t.commandStr),no.forEach((function(e,t){t=0,'invalid offset for attribute "'+e+'"',t.commandStr);var h=0|i.stride;re.command(h>=0&&h<256,'invalid stride for attribute "'+e+'", must be integer betweeen [0, 255]',t.commandStr);var p=0|i.size;re.command(!("size"in i)||p>0&&p<=4,'invalid size for attribute "'+e+'", must be 1,2,3,4',t.commandStr);var f=!!i.normalized,m=0;"type"in i&&(re.commandParameter(i.type,Rt,"invalid type for attribute "+e,t.commandStr),m=Rt[i.type]);var y=0|i.divisor;re.optional((function(){"divisor"in i&&(re.command(0===y||v,'cannot specify divisor for attribute "'+e+'", instancing not supported',t.commandStr),re.command(y>=0,'invalid divisor for attribute "'+e+'"',t.commandStr));var r=t.commandStr,n=["buffer","offset","divisor","normalized","type","size","stride"];Object.keys(i).forEach((function(t){re.command(n.indexOf(t)>=0,'unknown parameter "'+t+'" for attribute pointer "'+e+'" (valid parameters are '+n+")",r)}))})),l.buffer=c,l.state=oo,l.size=p,l.normalized=f,l.type=m||c.dtype,l.offset=d,l.stride=h,l.divisor=y}}a[e]=cs((function(e,t){var r=e.attribCache;if(s in r)return r[s];var n={isStream:!1};return Object.keys(l).forEach((function(e){n[e]=l[e]})),l.buffer&&(n.buffer=e.link(l.buffer),n.type=n.type||n.buffer+".dtype"),r[s]=n,n}))})),Object.keys(i).forEach((function(e){var t=i[e];function r(r,n){var i=r.invoke(n,t),o=r.shared,a=r.constants,s=o.isBufferArgs,l=o.buffer;re.optional((function(){r.assert(n,i+"&&(typeof "+i+'==="object"||typeof '+i+'==="function")&&('+s+"("+i+")||"+l+".getBuffer("+i+")||"+l+".getBuffer("+i+".buffer)||"+s+"("+i+'.buffer)||("constant" in '+i+"&&(typeof "+i+'.constant==="number"||'+o.isArrayLike+"("+i+".constant))))",'invalid dynamic attribute "'+e+'"')}));var c={isStream:n.def(!1)},u=new g;u.state=oo,Object.keys(u).forEach((function(e){c[e]=n.def(""+u[e])}));var d=c.buffer,h=c.type;function p(e){n(c[e],"=",i,".",e,"|0;")}return n("if(",s,"(",i,")){",c.isStream,"=true;",d,"=",l,".createStream(",la,",",i,");",h,"=",d,".dtype;","}else{",d,"=",l,".getBuffer(",i,");","if(",d,"){",h,"=",d,".dtype;",'}else if("constant" in ',i,"){",c.state,"=",ao,";","if(typeof "+i+'.constant === "number"){',c[no[0]],"=",i,".constant;",no.slice(1).map((function(e){return c[e]})).join("="),"=0;","}else{",no.map((function(e,t){return c[e]+"="+i+".constant.length>"+t+"?"+i+".constant["+t+"]:0;"})).join(""),"}}else{","if(",s,"(",i,".buffer)){",d,"=",l,".createStream(",la,",",i,".buffer);","}else{",d,"=",l,".getBuffer(",i,".buffer);","}",h,'="type" in ',i,"?",a.glTypes,"[",i,".type]:",d,".dtype;",c.normalized,"=!!",i,".normalized;"),p("size"),p("offset"),p("stride"),p("divisor"),n("}}"),n.exit("if(",c.isStream,"){",l,".destroyStream(",d,");","}"),c}a[e]=us(t,r)})),a}function U(e){var t=e.static,r=e.dynamic,n={};return Object.keys(t).forEach((function(e){var r=t[e];n[e]=cs((function(e,t){return"number"===typeof r||"boolean"===typeof r?""+r:e.link(r)}))})),Object.keys(r).forEach((function(e){var t=r[e];n[e]=us(t,(function(e,r){return e.invoke(r,t)}))})),n}function H(e,t,r,i,o){var a=e.static,s=e.dynamic;re.optional((function(){var e=[Ho,$o,Wo,qo,Go,Xo,Yo,Zo,Uo,Ko].concat(k);function t(t){Object.keys(t).forEach((function(t){re.command(e.indexOf(t)>=0,'unknown parameter "'+t+'"',o.commandStr)}))}t(a),t(s)}));var l=z(e,t),c=L(e,o),d=D(e,c,o),h=F(e,o),p=N(e,o),f=j(e,o,l);function m(e){var t=d[e];t&&(p[e]=t)}m(Vo),m(T(Bo));var g=Object.keys(p).length>0,y={framebuffer:c,draw:h,shader:f,state:p,dirty:g,scopeVAO:null,drawVAO:null,useVAO:!1,attributes:{}};if(y.profile=R(e,o),y.uniforms=B(r,o),y.drawVAO=y.scopeVAO=h.vao,!y.drawVAO&&f.program&&!l&&n.angle_instanced_arrays&&h.static.elements){var v=!0,x=f.program.attributes.map((function(e){var r=t.static[e];return v=v&&!!r,r}));if(v&&x.length>0){var b=u.getVAO(u.createVAO({attributes:x,elements:h.static.elements}));y.drawVAO=new ss(null,null,null,(function(e,t){return e.link(b)})),y.useVAO=!0}}return l?y.useVAO=!0:y.attributes=V(t,o),y.context=U(i,o),y}function $(e,t,r){var n=e.shared.context,i=e.scope();Object.keys(r).forEach((function(o){t.save(n,"."+o);var a=r[o].append(e,t);Array.isArray(a)?i(n,".",o,"=[",a.join(),"];"):i(n,".",o,"=",a,";")})),t(i)}function W(e,t,r,n){var i,o=e.shared,a=o.gl,s=o.framebuffer;x&&(i=t.def(o.extensions,".webgl_draw_buffers"));var l,c=e.constants,u=c.drawBuffer,d=c.backBuffer;l=r?r.append(e,t):t.def(s,".next"),n||t("if(",l,"!==",s,".cur){"),t("if(",l,"){",a,".bindFramebuffer(",Ka,",",l,".framebuffer);"),x&&t(i,".drawBuffersWEBGL(",u,"[",l,".colorAttachments.length]);"),t("}else{",a,".bindFramebuffer(",Ka,",null);"),x&&t(i,".drawBuffersWEBGL(",d,");"),t("}",s,".cur=",l,";"),n||t("}")}function q(e,t,r){var n=e.shared,i=n.gl,o=e.current,a=e.next,s=n.current,l=n.next,c=e.cond(s,".dirty");k.forEach((function(t){var n,u,d=T(t);if(!(d in r.state))if(d in a){n=a[d],u=o[d];var h=Te(_[d].length,(function(e){return c.def(n,"[",e,"]")}));c(e.cond(h.map((function(e,t){return e+"!=="+u+"["+t+"]"})).join("||")).then(i,".",A[d],"(",h,");",h.map((function(e,t){return u+"["+t+"]="+e})).join(";"),";"))}else{n=c.def(l,".",d);var p=e.cond(n,"!==",s,".",d);c(p),d in S?p(e.cond(n).then(i,".enable(",S[d],");").else(i,".disable(",S[d],");"),s,".",d,"=",n,";"):p(i,".",A[d],"(",n,");",s,".",d,"=",n,";")}})),0===Object.keys(r.state).length&&c(s,".dirty=false;"),t(c)}function G(e,t,r,n){var i=e.shared,o=e.current,a=i.current,s=i.gl;as(Object.keys(r)).forEach((function(i){var l=r[i];if(!n||n(l)){var c=l.append(e,t);if(S[i]){var u=S[i];ls(l)?t(s,c?".enable(":".disable(",u,");"):t(e.cond(c).then(s,".enable(",u,");").else(s,".disable(",u,");")),t(a,".",i,"=",c,";")}else if(ur(c)){var d=o[i];t(s,".",A[i],"(",c,");",c.map((function(e,t){return d+"["+t+"]="+e})).join(";"),";")}else t(s,".",A[i],"(",c,");",a,".",i,"=",c,";")}}))}function Y(e,t){v&&(e.instancing=t.def(e.shared.extensions,".angle_instanced_arrays"))}function X(e,t,r,n,i){var o,a,s,l=e.shared,c=e.stats,u=l.current,d=l.timer,h=r.profile;function p(){return"undefined"===typeof performance?"Date.now()":"performance.now()"}function m(e){e(o=t.def(),"=",p(),";"),"string"===typeof i?e(c,".count+=",i,";"):e(c,".count++;"),f&&(n?e(a=t.def(),"=",d,".getNumPendingQueries();"):e(d,".beginQuery(",c,");"))}function g(e){e(c,".cpuTime+=",p(),"-",o,";"),f&&(n?e(d,".pushScopeStats(",a,",",d,".getNumPendingQueries(),",c,");"):e(d,".endQuery();"))}function y(e){var r=t.def(u,".profile");t(u,".profile=",e,";"),t.exit(u,".profile=",r,";")}if(h){if(ls(h))return void(h.enable?(m(t),g(t.exit),y("true")):y("false"));y(s=h.append(e,t))}else s=t.def(u,".profile");var v=e.block();m(v),t("if(",s,"){",v,"}");var x=e.block();g(x),t.exit("if(",s,"){",x,"}")}function Z(e,t,r,n,i){var o=e.shared;function a(e){switch(e){case wa:case Ta:case Ia:return 2;case ka:case Ma:case Pa:return 3;case Sa:case Ca:case Oa:return 4;default:return 1}}function s(r,n,i){var a=o.gl,s=t.def(r,".location"),l=t.def(o.attributes,"[",s,"]"),c=i.state,u=i.buffer,d=[i.x,i.y,i.z,i.w],h=["buffer","normalized","offset","stride"];function p(){t("if(!",l,".buffer){",a,".enableVertexAttribArray(",s,");}");var r,o=i.type;if(r=i.size?t.def(i.size,"||",n):n,t("if(",l,".type!==",o,"||",l,".size!==",r,"||",h.map((function(e){return l+"."+e+"!=="+i[e]})).join("||"),"){",a,".bindBuffer(",la,",",u,".buffer);",a,".vertexAttribPointer(",[s,r,o,i.normalized,i.stride,i.offset],");",l,".type=",o,";",l,".size=",r,";",h.map((function(e){return l+"."+e+"="+i[e]+";"})).join(""),"}"),v){var c=i.divisor;t("if(",l,".divisor!==",c,"){",e.instancing,".vertexAttribDivisorANGLE(",[s,c],");",l,".divisor=",c,";}")}}function f(){t("if(",l,".buffer){",a,".disableVertexAttribArray(",s,");",l,".buffer=null;","}if(",no.map((function(e,t){return l+"."+e+"!=="+d[t]})).join("||"),"){",a,".vertexAttrib4f(",s,",",d,");",no.map((function(e,t){return l+"."+e+"="+d[t]+";"})).join(""),"}")}c===oo?p():c===ao?f():(t("if(",c,"===",oo,"){"),p(),t("}else{"),f(),t("}"))}n.forEach((function(n){var o,l=n.name,c=r.attributes[l];if(c){if(!i(c))return;o=c.append(e,t)}else{if(!i(ds))return;var u=e.scopeAttrib(l);re.optional((function(){e.assert(t,u+".state","missing attribute "+l)})),o={},Object.keys(new g).forEach((function(e){o[e]=t.def(u,".",e)}))}s(e.link(n),a(n.info.type),o)}))}function K(e,t,n,i,o,a){for(var s,l=e.shared,c=l.gl,u=0;u1){for(var A=[],T=[],M=0;M<_;++M)Array.isArray(d)?T.push(d[M]):T.push(t.def(d+"["+M+"]")),a&&A.push(t.def());a&&t("if(!",e.batchId,"||",A.map((function(e,t){return e+"!=="+T[t]})).join("||"),"){",A.map((function(e,t){return e+"="+T[t]+";"})).join("")),t(c,".uniform",s,"(",g,",",T.join(","),");"),a&&t("}")}else{if(re(!Array.isArray(d),"uniform value must not be an array"),a){var C=t.def();t("if(!",e.batchId,"||",C,"!==",d,"){",C,"=",d,";")}t(c,".uniform",s,"(",g,",",d,");"),a&&t("}")}}}function J(e,t,r,n){var i=e.shared,o=i.gl,a=i.draw,s=n.draw;function l(){var l,c=s.elements,u=t;return c?((c.contextDep&&n.contextDynamic||c.propDep)&&(u=r),l=c.append(e,u),s.elementsActive&&u("if("+l+")"+o+".bindBuffer("+ca+","+l+".buffer.buffer);")):(l=u.def(),u(l,"=",a,".",qo,";","if(",l,"){",o,".bindBuffer(",ca,",",l,".buffer.buffer);}","else if(",i.vao,".currentVAO){",l,"=",e.shared.elements+".getElements("+i.vao,".currentVAO.elements);",b?"":"if("+l+")"+o+".bindBuffer("+ca+","+l+".buffer.buffer);","}")),l}function c(){var i,o=s.count,l=t;return o?((o.contextDep&&n.contextDynamic||o.propDep)&&(l=r),i=o.append(e,l),re.optional((function(){o.MISSING&&e.assert(t,"false","missing vertex count"),o.DYNAMIC&&e.assert(l,i+">=0","missing vertex count")}))):(i=l.def(a,".",Yo),re.optional((function(){e.assert(l,i+">=0","missing vertex count")}))),i}var u=l();function d(i){var o=s[i];return o?o.contextDep&&n.contextDynamic||o.propDep?o.append(e,r):o.append(e,t):t.def(a,".",i)}var h,p,f=d(Go),m=d(Xo),g=c();if("number"===typeof g){if(0===g)return}else r("if(",g,"){"),r.exit("}");v&&(h=d(Zo),p=e.instancing);var y=u+".type",x=s.elements&&ls(s.elements)&&!s.vaoActive;function _(){function e(){r(p,".drawElementsInstancedANGLE(",[f,g,y,m+"<<(("+y+"-"+io+")>>1)",h],");")}function t(){r(p,".drawArraysInstancedANGLE(",[f,m,g,h],");")}u&&"null"!==u?x?e():(r("if(",u,"){"),e(),r("}else{"),t(),r("}")):t()}function w(){function e(){r(o+".drawElements("+[f,g,y,m+"<<(("+y+"-"+io+")>>1)"]+");")}function t(){r(o+".drawArrays("+[f,m,g]+");")}u&&"null"!==u?x?e():(r("if(",u,"){"),e(),r("}else{"),t(),r("}")):t()}v&&("number"!==typeof h||h>=0)?"string"===typeof h?(r("if(",h,">0){"),_(),r("}else if(",h,"<0){"),w(),r("}")):_():w()}function Q(e,t,r,n,i){var o=O(),a=o.proc("body",i);return re.optional((function(){o.commandStr=t.commandStr,o.command=o.link(t.commandStr)})),v&&(o.instancing=a.def(o.shared.extensions,".angle_instanced_arrays")),e(o,a,r,n),o.compile().body}function ee(e,t,r,n){Y(e,t),r.useVAO?r.drawVAO?t(e.shared.vao,".setVAO(",r.drawVAO.append(e,t),");"):t(e.shared.vao,".setVAO(",e.shared.vao,".targetVAO);"):(t(e.shared.vao,".setVAO(null);"),Z(e,t,r,n.attributes,(function(){return!0}))),K(e,t,r,n.uniforms,(function(){return!0}),!1),J(e,t,t,r)}function te(e,t){var r=e.proc("draw",1);Y(e,r),$(e,r,t.context),W(e,r,t.framebuffer),q(e,r,t),G(e,r,t.state),X(e,r,t,!1,!0);var n=t.shader.progVar.append(e,r);if(r(e.shared.gl,".useProgram(",n,".program);"),t.shader.program)ee(e,r,t,t.shader.program);else{r(e.shared.vao,".setVAO(null);");var i=e.global.def("{}"),o=r.def(n,".id"),a=r.def(i,"[",o,"]");r(e.cond(a).then(a,".call(this,a0);").else(a,"=",i,"[",o,"]=",e.link((function(r){return Q(ee,e,t,r,1)})),"(",n,");",a,".call(this,a0);"))}Object.keys(t.state).length>0&&r(e.shared.current,".dirty=true;"),e.shared.vao&&r(e.shared.vao,".setVAO(null);")}function ne(e,t,r,n){function i(){return!0}e.batchId="a1",Y(e,t),Z(e,t,r,n.attributes,i),K(e,t,r,n.uniforms,i,!1),J(e,t,t,r)}function ie(e,t,r,n){Y(e,t);var i=r.contextDep,o=t.def(),a="a0",s="a1",l=t.def();e.shared.props=l,e.batchId=o;var c=e.scope(),u=e.scope();function d(e){return e.contextDep&&i||e.propDep}function h(e){return!d(e)}if(t(c.entry,"for(",o,"=0;",o,"<",s,";++",o,"){",l,"=",a,"[",o,"];",u,"}",c.exit),r.needsContext&&$(e,u,r.context),r.needsFramebuffer&&W(e,u,r.framebuffer),G(e,u,r.state,d),r.profile&&d(r.profile)&&X(e,u,r,!1,!0),n)r.useVAO?r.drawVAO?d(r.drawVAO)?u(e.shared.vao,".setVAO(",r.drawVAO.append(e,u),");"):c(e.shared.vao,".setVAO(",r.drawVAO.append(e,c),");"):c(e.shared.vao,".setVAO(",e.shared.vao,".targetVAO);"):(c(e.shared.vao,".setVAO(null);"),Z(e,c,r,n.attributes,h),Z(e,u,r,n.attributes,d)),K(e,c,r,n.uniforms,h,!1),K(e,u,r,n.uniforms,d,!0),J(e,c,u,r);else{var p=e.global.def("{}"),f=r.shader.progVar.append(e,u),m=u.def(f,".id"),g=u.def(p,"[",m,"]");u(e.shared.gl,".useProgram(",f,".program);","if(!",g,"){",g,"=",p,"[",m,"]=",e.link((function(t){return Q(ne,e,r,t,2)})),"(",f,");}",g,".call(this,a0[",o,"],",o,");")}}function oe(e,t){var r=e.proc("batch",2);e.batchId="0",Y(e,r);var n=!1,i=!0;Object.keys(t.context).forEach((function(e){n=n||t.context[e].propDep})),n||($(e,r,t.context),i=!1);var o=t.framebuffer,a=!1;function s(e){return e.contextDep&&n||e.propDep}o?(o.propDep?n=a=!0:o.contextDep&&n&&(a=!0),a||W(e,r,o)):W(e,r,null),t.state.viewport&&t.state.viewport.propDep&&(n=!0),q(e,r,t),G(e,r,t.state,(function(e){return!s(e)})),t.profile&&s(t.profile)||X(e,r,t,!1,"a1"),t.contextDep=n,t.needsContext=i,t.needsFramebuffer=a;var l=t.shader.progVar;if(l.contextDep&&n||l.propDep)ie(e,r,t,null);else{var c=l.append(e,r);if(r(e.shared.gl,".useProgram(",c,".program);"),t.shader.program)ie(e,r,t,t.shader.program);else{r(e.shared.vao,".setVAO(null);");var u=e.global.def("{}"),d=r.def(c,".id"),h=r.def(u,"[",d,"]");r(e.cond(h).then(h,".call(this,a0,a1);").else(h,"=",u,"[",d,"]=",e.link((function(r){return Q(ie,e,t,r,2)})),"(",c,");",h,".call(this,a0,a1);"))}}Object.keys(t.state).length>0&&r(e.shared.current,".dirty=true;"),e.shared.vao&&r(e.shared.vao,".setVAO(null);")}function ae(e,t){var n=e.proc("scope",3);e.batchId="a2";var i=e.shared,o=i.current;function a(r){var o=t.shader[r];o&&n.set(i.shader,"."+r,o.append(e,n))}$(e,n,t.context),t.framebuffer&&t.framebuffer.append(e,n),as(Object.keys(t.state)).forEach((function(r){var o=t.state[r].append(e,n);ur(o)?o.forEach((function(t,i){n.set(e.next[r],"["+i+"]",t)})):n.set(i.next,"."+r,o)})),X(e,n,t,!0,!0),[qo,Xo,Yo,Zo,Go].forEach((function(r){var o=t.draw[r];o&&n.set(i.draw,"."+r,""+o.append(e,n))})),Object.keys(t.uniforms).forEach((function(o){var a=t.uniforms[o].append(e,n);Array.isArray(a)&&(a="["+a.join()+"]"),n.set(i.uniforms,"["+r.id(o)+"]",a)})),Object.keys(t.attributes).forEach((function(r){var i=t.attributes[r].append(e,n),o=e.scopeAttrib(r);Object.keys(new g).forEach((function(e){n.set(o,"."+e,i[e])}))})),t.scopeVAO&&n.set(i.vao,".targetVAO",t.scopeVAO.append(e,n)),a($o),a(Wo),Object.keys(t.state).length>0&&(n(o,".dirty=true;"),n.exit(o,".dirty=true;")),n("a1(",e.shared.context,",a0,",e.batchId,");")}function se(e){if("object"===typeof e&&!ur(e)){for(var t=Object.keys(e),r=0;r=0;--e){var t=I[e];t&&t(f,null,0)}n.flush(),u&&u.update()}function z(){!L&&I.length>0&&(L=me.next(D))}function j(){L&&(me.cancel(D),L=null)}function F(e){e.preventDefault(),o=!0,j(),P.forEach((function(e){e()}))}function N(e){n.getError(),o=!1,a.restore(),w.restore(),v.restore(),k.restore(),S.restore(),A.restore(),b.restore(),u&&u.restore(),T.procs.refresh(),z(),O.forEach((function(e){e()}))}function B(){I.length=0,j(),E&&(E.removeEventListener(ws,F),E.removeEventListener(ks,N)),w.clear(),A.clear(),S.clear(),b.clear(),k.clear(),x.clear(),v.clear(),u&&u.clear(),R.forEach((function(e){e()}))}function V(e){function r(e){var r=t({},e);function n(e){if(e in r){var t=r[e];delete r[e],Object.keys(t).forEach((function(n){r[e+"."+n]=t[n]}))}}return delete r.uniforms,delete r.attributes,delete r.context,delete r.vao,"stencil"in r&&r.stencil.op&&(r.stencil.opBack=r.stencil.opFront=r.stencil.op,delete r.stencil.op),n("blend"),n("depth"),n("cull"),n("stencil"),n("polygonOffset"),n("scissor"),n("sample"),"vao"in e&&(r.vao=e.vao),r}function n(e,t){var r={},n={};return Object.keys(e).forEach((function(i){var o=e[i];if(fe.isDynamic(o))n[i]=fe.unbox(o,i);else{if(t&&Array.isArray(o))for(var a=0;a0)return h.call(this,m(0|e),0|e)}else{if(!Array.isArray(e))return d.call(this,e);if(e.length)return h.call(this,e,e.length)}}return t(g,{stats:c,destroy:function(){u.destroy()}})}E&&(E.addEventListener(ws,F,!1),E.addEventListener(ks,N,!1));var U=A.setFBO=V({framebuffer:fe.define.call(null,Ss,"framebuffer")});function H(e,t){var r=0;T.procs.poll();var i=t.color;i&&(n.clearColor(+i[0]||0,+i[1]||0,+i[2]||0,+i[3]||0),r|=vs),"depth"in t&&(n.clearDepth(+t.depth),r|=xs),"stencil"in t&&(n.clearStencil(0|t.stencil),r|=bs),re(!!r,"called regl.clear with no buffer specified"),n.clear(r)}function $(e){if(re("object"===typeof e&&e,"regl.clear() takes an object as input"),"framebuffer"in e)if(e.framebuffer&&"framebufferCube"===e.framebuffer_reglType)for(var r=0;r<6;++r)U(t({framebuffer:e.framebuffer.faces[r]},e),H);else U(e,H);else H(null,e)}function W(e){function t(){var t=Ms(I,e);function r(){var e=Ms(I,r);I[e]=I[I.length-1],I.length-=1,I.length<=0&&j()}re(t>=0,"cannot cancel a frame twice"),I[t]=r}return re.type(e,"function","regl.frame() callback must be a function"),I.push(e),z(),{cancel:t}}function q(){var e=C.viewport,t=C.scissor_box;e[0]=e[1]=t[0]=t[1]=0,f.viewportWidth=f.framebufferWidth=f.drawingBufferWidth=e[2]=t[2]=n.drawingBufferWidth,f.viewportHeight=f.framebufferHeight=f.drawingBufferHeight=e[3]=t[3]=n.drawingBufferHeight}function G(){f.tick+=1,f.time=X(),q(),T.procs.poll()}function Y(){k.refresh(),q(),T.procs.refresh(),u&&u.update()}function X(){return(ge()-d)/1e3}function Z(e,t){var r;switch(re.type(t,"function","listener callback must be a function"),e){case"frame":return W(t);case"lost":r=P;break;case"restore":r=O;break;case"destroy":r=R;break;default:re.raise("invalid event, must be one of frame,lost,restore,destroy")}return r.push(t),{cancel:function(){for(var e=0;e=0},read:M,destroy:B,_gl:n,_refresh:Y,poll:function(){G(),u&&u.update()},now:X,stats:l});return r.onDone(null,K),K}return Cs}()},66933:(e,t,r)=>{"use strict";var n=r(92472);function i(e){if(e.container)if(e.container==document.body)document.body.style.width||(e.canvas.width=e.width||e.pixelRatio*r.g.innerWidth),document.body.style.height||(e.canvas.height=e.height||e.pixelRatio*r.g.innerHeight);else{var t=e.container.getBoundingClientRect();e.canvas.width=e.width||t.right-t.left,e.canvas.height=e.height||t.bottom-t.top}}function o(e){return"function"===typeof e.getContext&&"width"in e&&"height"in e}function a(){var e=document.createElement("canvas");return e.style.position="absolute",e.style.top=0,e.style.left=0,e}e.exports=function(e){var t;if(e?"string"===typeof e&&(e={container:e}):e={},o(e)?e={container:e}:e="string"===typeof(t=e).nodeName&&"function"===typeof t.appendChild&&"function"===typeof t.getBoundingClientRect?{container:e}:function(e){return"function"===typeof e.drawArrays||"function"===typeof e.drawElements}(e)?{gl:e}:n(e,{container:"container target element el canvas holder parent parentNode wrapper use ref root node",gl:"gl context webgl glContext",attrs:"attributes attrs contextAttributes",pixelRatio:"pixelRatio pxRatio px ratio pxratio pixelratio",width:"w width",height:"h height"},!0),e.pixelRatio||(e.pixelRatio=r.g.pixelRatio||1),e.gl)return e.gl;if(e.canvas&&(e.container=e.canvas.parentNode),e.container){if("string"===typeof e.container){var s=document.querySelector(e.container);if(!s)throw Error("Element "+e.container+" is not found");e.container=s}o(e.container)?(e.canvas=e.container,e.container=e.canvas.parentNode):e.canvas||(e.canvas=a(),e.container.appendChild(e.canvas),i(e))}else if(!e.canvas){if("undefined"===typeof document)throw Error("Not DOM environment. Use headless-gl.");e.container=document.body||document.documentElement,e.canvas=a(),e.container.appendChild(e.canvas),i(e)}return e.gl||["webgl","experimental-webgl","webgl-experimental"].some((function(r){try{e.gl=e.canvas.getContext(r,e.attrs)}catch(t){}return e.gl})),e.gl}},67418:e=>{e.exports=function(e){"string"===typeof e&&(e=[e]);for(var t=[].slice.call(arguments,1),r=[],n=0;n{"use strict";var n=r(60002)("%Object.getOwnPropertyDescriptor%",!0);if(n)try{n([],"length")}catch(i){n=null}e.exports=n},59283:(e,t,r)=>{"use strict";var n,i=r(73318);n="function"===typeof r.g.matchMedia?!r.g.matchMedia("(hover: none)").matches:i,e.exports=n},17390:(e,t,r)=>{"use strict";var n=r(73318);e.exports=n&&function(){var e=!1;try{var t=Object.defineProperty({},"passive",{get:function(){e=!0}});window.addEventListener("test",null,t),window.removeEventListener("test",null,t)}catch(r){e=!1}return e}()},12101:(e,t,r)=>{"use strict";var n=r(82090),i=function(){return!!n};i.hasArrayLengthDefineBug=function(){if(!n)return null;try{return 1!==n([],"length",{value:1}).length}catch(e){return!0}},e.exports=i},80951:e=>{"use strict";var t={__proto__:null,foo:{}},r=Object;e.exports=function(){return{__proto__:t}.foo===t.foo&&!(t instanceof r)}},72108:(e,t,r)=>{"use strict";var n="undefined"!==typeof Symbol&&Symbol,i=r(99534);e.exports=function(){return"function"===typeof n&&("function"===typeof Symbol&&("symbol"===typeof n("foo")&&("symbol"===typeof Symbol("bar")&&i())))}},99534:e=>{"use strict";e.exports=function(){if("function"!==typeof Symbol||"function"!==typeof Object.getOwnPropertySymbols)return!1;if("symbol"===typeof Symbol.iterator)return!0;var e={},t=Symbol("test"),r=Object(t);if("string"===typeof t)return!1;if("[object Symbol]"!==Object.prototype.toString.call(t))return!1;if("[object Symbol]"!==Object.prototype.toString.call(r))return!1;for(t in e[t]=42,e)return!1;if("function"===typeof Object.keys&&0!==Object.keys(e).length)return!1;if("function"===typeof Object.getOwnPropertyNames&&0!==Object.getOwnPropertyNames(e).length)return!1;var n=Object.getOwnPropertySymbols(e);if(1!==n.length||n[0]!==t)return!1;if(!Object.prototype.propertyIsEnumerable.call(e,t))return!1;if("function"===typeof Object.getOwnPropertyDescriptor){var i=Object.getOwnPropertyDescriptor(e,t);if(42!==i.value||!0!==i.enumerable)return!1}return!0}},64635:(e,t,r)=>{"use strict";var n=r(99534);e.exports=function(){return n()&&!!Symbol.toStringTag}},34384:(e,t,r)=>{"use strict";var n=Function.prototype.call,i=Object.prototype.hasOwnProperty,o=r(63864);e.exports=o.call(n,i)},80219:(e,t,r)=>{"use strict";var n=r(53763),i={childContextTypes:!0,contextType:!0,contextTypes:!0,defaultProps:!0,displayName:!0,getDefaultProps:!0,getDerivedStateFromError:!0,getDerivedStateFromProps:!0,mixins:!0,propTypes:!0,type:!0},o={name:!0,length:!0,prototype:!0,caller:!0,callee:!0,arguments:!0,arity:!0},a={$$typeof:!0,compare:!0,defaultProps:!0,displayName:!0,propTypes:!0,type:!0},s={};function l(e){return n.isMemo(e)?a:s[e.$$typeof]||i}s[n.ForwardRef]={$$typeof:!0,render:!0,defaultProps:!0,displayName:!0,propTypes:!0},s[n.Memo]=a;var c=Object.defineProperty,u=Object.getOwnPropertyNames,d=Object.getOwnPropertySymbols,h=Object.getOwnPropertyDescriptor,p=Object.getPrototypeOf,f=Object.prototype;e.exports=function e(t,r,n){if("string"!==typeof r){if(f){var i=p(r);i&&i!==f&&e(t,i,n)}var a=u(r);d&&(a=a.concat(d(r)));for(var s=l(t),m=l(r),g=0;g{"use strict";var r="function"===typeof Symbol&&Symbol.for,n=r?Symbol.for("react.element"):60103,i=r?Symbol.for("react.portal"):60106,o=r?Symbol.for("react.fragment"):60107,a=r?Symbol.for("react.strict_mode"):60108,s=r?Symbol.for("react.profiler"):60114,l=r?Symbol.for("react.provider"):60109,c=r?Symbol.for("react.context"):60110,u=r?Symbol.for("react.async_mode"):60111,d=r?Symbol.for("react.concurrent_mode"):60111,h=r?Symbol.for("react.forward_ref"):60112,p=r?Symbol.for("react.suspense"):60113,f=r?Symbol.for("react.suspense_list"):60120,m=r?Symbol.for("react.memo"):60115,g=r?Symbol.for("react.lazy"):60116,y=r?Symbol.for("react.block"):60121,v=r?Symbol.for("react.fundamental"):60117,x=r?Symbol.for("react.responder"):60118,b=r?Symbol.for("react.scope"):60119;function _(e){if("object"===typeof e&&null!==e){var t=e.$$typeof;switch(t){case n:switch(e=e.type){case u:case d:case o:case s:case a:case p:return e;default:switch(e=e&&e.$$typeof){case c:case h:case g:case m:case l:return e;default:return t}}case i:return t}}}function w(e){return _(e)===d}t.AsyncMode=u,t.ConcurrentMode=d,t.ContextConsumer=c,t.ContextProvider=l,t.Element=n,t.ForwardRef=h,t.Fragment=o,t.Lazy=g,t.Memo=m,t.Portal=i,t.Profiler=s,t.StrictMode=a,t.Suspense=p,t.isAsyncMode=function(e){return w(e)||_(e)===u},t.isConcurrentMode=w,t.isContextConsumer=function(e){return _(e)===c},t.isContextProvider=function(e){return _(e)===l},t.isElement=function(e){return"object"===typeof e&&null!==e&&e.$$typeof===n},t.isForwardRef=function(e){return _(e)===h},t.isFragment=function(e){return _(e)===o},t.isLazy=function(e){return _(e)===g},t.isMemo=function(e){return _(e)===m},t.isPortal=function(e){return _(e)===i},t.isProfiler=function(e){return _(e)===s},t.isStrictMode=function(e){return _(e)===a},t.isSuspense=function(e){return _(e)===p},t.isValidElementType=function(e){return"string"===typeof e||"function"===typeof e||e===o||e===d||e===s||e===a||e===p||e===f||"object"===typeof e&&null!==e&&(e.$$typeof===g||e.$$typeof===m||e.$$typeof===l||e.$$typeof===c||e.$$typeof===h||e.$$typeof===v||e.$$typeof===x||e.$$typeof===b||e.$$typeof===y)},t.typeOf=_},53763:(e,t,r)=>{"use strict";e.exports=r(54983)},6900:(e,t)=>{t.read=function(e,t,r,n,i){var o,a,s=8*i-n-1,l=(1<>1,u=-7,d=r?i-1:0,h=r?-1:1,p=e[t+d];for(d+=h,o=p&(1<<-u)-1,p>>=-u,u+=s;u>0;o=256*o+e[t+d],d+=h,u-=8);for(a=o&(1<<-u)-1,o>>=-u,u+=n;u>0;a=256*a+e[t+d],d+=h,u-=8);if(0===o)o=1-c;else{if(o===l)return a?NaN:1/0*(p?-1:1);a+=Math.pow(2,n),o-=c}return(p?-1:1)*a*Math.pow(2,o-n)},t.write=function(e,t,r,n,i,o){var a,s,l,c=8*o-i-1,u=(1<>1,h=23===i?Math.pow(2,-24)-Math.pow(2,-77):0,p=n?0:o-1,f=n?1:-1,m=t<0||0===t&&1/t<0?1:0;for(t=Math.abs(t),isNaN(t)||t===1/0?(s=isNaN(t)?1:0,a=u):(a=Math.floor(Math.log(t)/Math.LN2),t*(l=Math.pow(2,-a))<1&&(a--,l*=2),(t+=a+d>=1?h/l:h*Math.pow(2,1-d))*l>=2&&(a++,l/=2),a+d>=u?(s=0,a=u):a+d>=1?(s=(t*l-1)*Math.pow(2,i),a+=d):(s=t*Math.pow(2,d-1)*Math.pow(2,i),a=0));i>=8;e[r+p]=255&s,p+=f,s/=256,i-=8);for(a=a<0;e[r+p]=255&a,p+=f,a/=256,c-=8);e[r+p-f]|=128*m}},56329:e=>{"function"===typeof Object.create?e.exports=function(e,t){t&&(e.super_=t,e.prototype=Object.create(t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}))}:e.exports=function(e,t){if(t){e.super_=t;var r=function(){};r.prototype=t.prototype,e.prototype=new r,e.prototype.constructor=e}}},68317:(e,t,r)=>{"use strict";var n=r(64635)(),i=r(12028)("Object.prototype.toString"),o=function(e){return!(n&&e&&"object"===typeof e&&Symbol.toStringTag in e)&&"[object Arguments]"===i(e)},a=function(e){return!!o(e)||null!==e&&"object"===typeof e&&"number"===typeof e.length&&e.length>=0&&"[object Array]"!==i(e)&&"[object Function]"===i(e.callee)},s=function(){return o(arguments)}();o.isLegacyArguments=a,e.exports=s?o:a},73318:e=>{e.exports=!0},78799:e=>{"use strict";var t,r,n=Function.prototype.toString,i="object"===typeof Reflect&&null!==Reflect&&Reflect.apply;if("function"===typeof i&&"function"===typeof Object.defineProperty)try{t=Object.defineProperty({},"length",{get:function(){throw r}}),r={},i((function(){throw 42}),null,t)}catch(p){p!==r&&(i=null)}else i=null;var o=/^\s*class\b/,a=function(e){try{var t=n.call(e);return o.test(t)}catch(r){return!1}},s=function(e){try{return!a(e)&&(n.call(e),!0)}catch(t){return!1}},l=Object.prototype.toString,c="function"===typeof Symbol&&!!Symbol.toStringTag,u=!(0 in[,]),d=function(){return!1};if("object"===typeof document){var h=document.all;l.call(h)===l.call(document.all)&&(d=function(e){if((u||!e)&&("undefined"===typeof e||"object"===typeof e))try{var t=l.call(e);return("[object HTMLAllCollection]"===t||"[object HTML document.all class]"===t||"[object HTMLCollection]"===t||"[object Object]"===t)&&null==e("")}catch(r){}return!1})}e.exports=i?function(e){if(d(e))return!0;if(!e)return!1;if("function"!==typeof e&&"object"!==typeof e)return!1;try{i(e,null,t)}catch(n){if(n!==r)return!1}return!a(e)&&s(e)}:function(e){if(d(e))return!0;if(!e)return!1;if("function"!==typeof e&&"object"!==typeof e)return!1;if(c)return s(e);if(a(e))return!1;var t=l.call(e);return!("[object Function]"!==t&&"[object GeneratorFunction]"!==t&&!/^\[object HTML/.test(t))&&s(e)}},71583:(e,t,r)=>{"use strict";var n,i=Object.prototype.toString,o=Function.prototype.toString,a=/^\s*(?:function)?\*/,s=r(64635)(),l=Object.getPrototypeOf;e.exports=function(e){if("function"!==typeof e)return!1;if(a.test(o.call(e)))return!0;if(!s)return"[object GeneratorFunction]"===i.call(e);if(!l)return!1;if("undefined"===typeof n){var t=function(){if(!s)return!1;try{return Function("return function*() {}")()}catch(e){}}();n=!!t&&l(t)}return l(e)===n}},55357:e=>{"use strict";e.exports="undefined"!==typeof navigator&&(/MSIE/.test(navigator.userAgent)||/Trident\//.test(navigator.appVersion))},94561:e=>{"use strict";e.exports=i,e.exports.isMobile=i,e.exports.default=i;const t=/(android|bb\d+|meego).+mobile|armv7l|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series[46]0|samsungbrowser.*mobile|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino/i,r=/CrOS/,n=/android|ipad|playbook|silk/i;function i(e){e||(e={});let i=e.ua;if(i||"undefined"===typeof navigator||(i=navigator.userAgent),i&&i.headers&&"string"===typeof i.headers["user-agent"]&&(i=i.headers["user-agent"]),"string"!==typeof i)return!1;let o=t.test(i)&&!r.test(i)||!!e.tablet&&n.test(i);return!o&&e.tablet&&e.featureDetect&&navigator&&navigator.maxTouchPoints>1&&-1!==i.indexOf("Macintosh")&&-1!==i.indexOf("Safari")&&(o=!0),o}},68724:e=>{"use strict";e.exports=function(e){return e!==e}},22384:(e,t,r)=>{"use strict";var n=r(61712),i=r(11779),o=r(68724),a=r(77057),s=r(66607),l=n(a(),Number);i(l,{getPolyfill:a,implementation:o,shim:s}),e.exports=l},77057:(e,t,r)=>{"use strict";var n=r(68724);e.exports=function(){return Number.isNaN&&Number.isNaN(NaN)&&!Number.isNaN("a")?Number.isNaN:n}},66607:(e,t,r)=>{"use strict";var n=r(11779),i=r(77057);e.exports=function(){var e=i();return n(Number,{isNaN:e},{isNaN:function(){return Number.isNaN!==e}}),e}},16140:e=>{"use strict";e.exports=function(e){var t=typeof e;return null!==e&&("object"===t||"function"===t)}},88313:e=>{"use strict";var t=Object.prototype.toString;e.exports=function(e){var r;return"[object Object]"===t.call(e)&&(null===(r=Object.getPrototypeOf(e))||r===Object.getPrototypeOf({}))}},45665:e=>{"use strict";e.exports=function(e){for(var t,r=e.length,n=0;n13)&&32!==t&&133!==t&&160!==t&&5760!==t&&6158!==t&&(t<8192||t>8205)&&8232!==t&&8233!==t&&8239!==t&&8287!==t&&8288!==t&&12288!==t&&65279!==t)return!1;return!0}},52121:e=>{"use strict";e.exports=function(e){return"string"===typeof e&&(e=e.trim(),!!(/^[mzlhvcsqta]\s*[-+.0-9][^mlhvzcsqta]+/i.test(e)&&/[\dz]$/i.test(e)&&e.length>4))}},59849:(e,t,r)=>{"use strict";var n=r(58004);e.exports=function(e){return!!n(e)}},91657:e=>{e.exports=function(e,t,r){return e*(1-r)+t*r}},97685:(e,t,r)=>{var n=r(87937)(r(56552),"DataView");e.exports=n},98724:(e,t,r)=>{var n=r(27615),i=r(25051),o=r(72154),a=r(48734),s=r(22662);function l(e){var t=-1,r=null==e?0:e.length;for(this.clear();++t{var n=r(87563),i=r(29935),o=r(24190),a=r(51946),s=r(61714);function l(e){var t=-1,r=null==e?0:e.length;for(this.clear();++t{var n=r(87937)(r(56552),"Map");e.exports=n},64816:(e,t,r)=>{var n=r(47251),i=r(37159),o=r(80438),a=r(69394),s=r(56874);function l(e){var t=-1,r=null==e?0:e.length;for(this.clear();++t{var n=r(87937)(r(56552),"Promise");e.exports=n},72070:(e,t,r)=>{var n=r(87937)(r(56552),"Set");e.exports=n},18902:(e,t,r)=>{var n=r(64816),i=r(86179),o=r(46704);function a(e){var t=-1,r=null==e?0:e.length;for(this.__data__=new n;++t{var n=r(97160),i=r(84545),o=r(10793),a=r(27760),s=r(3892),l=r(76788);function c(e){var t=this.__data__=new n(e);this.size=t.size}c.prototype.clear=i,c.prototype.delete=o,c.prototype.get=a,c.prototype.has=s,c.prototype.set=l,e.exports=c},9812:(e,t,r)=>{var n=r(56552).Symbol;e.exports=n},22929:(e,t,r)=>{var n=r(56552).Uint8Array;e.exports=n},26600:(e,t,r)=>{var n=r(87937)(r(56552),"WeakMap");e.exports=n},80726:e=>{e.exports=function(e,t){for(var r=-1,n=null==e?0:e.length;++r{e.exports=function(e,t){for(var r=-1,n=null==e?0:e.length,i=0,o=[];++r{var n=r(3343),i=r(22777),o=r(54052),a=r(44543),s=r(69194),l=r(51268),c=Object.prototype.hasOwnProperty;e.exports=function(e,t){var r=o(e),u=!r&&i(e),d=!r&&!u&&a(e),h=!r&&!u&&!d&&l(e),p=r||u||d||h,f=p?n(e.length,String):[],m=f.length;for(var g in e)!t&&!c.call(e,g)||p&&("length"==g||d&&("offset"==g||"parent"==g)||h&&("buffer"==g||"byteLength"==g||"byteOffset"==g)||s(g,m))||f.push(g);return f}},50149:e=>{e.exports=function(e,t){for(var r=-1,n=null==e?0:e.length,i=Array(n);++r{e.exports=function(e,t){for(var r=-1,n=t.length,i=e.length;++r{e.exports=function(e,t){for(var r=-1,n=null==e?0:e.length;++r{var n=r(71775),i=r(93211),o=Object.prototype.hasOwnProperty;e.exports=function(e,t,r){var a=e[t];o.call(e,t)&&i(a,r)&&(void 0!==r||t in e)||n(e,t,r)}},61340:(e,t,r)=>{var n=r(93211);e.exports=function(e,t){for(var r=e.length;r--;)if(n(e[r][0],t))return r;return-1}},51104:(e,t,r)=>{var n=r(96614),i=r(28673);e.exports=function(e,t){return e&&n(t,i(t),e)}},55119:(e,t,r)=>{var n=r(96614),i=r(30474);e.exports=function(e,t){return e&&n(t,i(t),e)}},71775:(e,t,r)=>{var n=r(5654);e.exports=function(e,t,r){"__proto__"==t&&n?n(e,t,{configurable:!0,enumerable:!0,value:r,writable:!0}):e[t]=r}},97132:(e,t,r)=>{var n=r(5538),i=r(80726),o=r(78420),a=r(51104),s=r(55119),l=r(44353),c=r(91980),u=r(98124),d=r(29075),h=r(59395),p=r(68592),f=r(26924),m=r(38268),g=r(18630),y=r(20310),v=r(54052),x=r(44543),b=r(57887),_=r(46686),w=r(45921),k=r(28673),S=r(30474),A="[object Arguments]",T="[object Function]",M="[object Object]",C={};C[A]=C["[object Array]"]=C["[object ArrayBuffer]"]=C["[object DataView]"]=C["[object Boolean]"]=C["[object Date]"]=C["[object Float32Array]"]=C["[object Float64Array]"]=C["[object Int8Array]"]=C["[object Int16Array]"]=C["[object Int32Array]"]=C["[object Map]"]=C["[object Number]"]=C[M]=C["[object RegExp]"]=C["[object Set]"]=C["[object String]"]=C["[object Symbol]"]=C["[object Uint8Array]"]=C["[object Uint8ClampedArray]"]=C["[object Uint16Array]"]=C["[object Uint32Array]"]=!0,C["[object Error]"]=C[T]=C["[object WeakMap]"]=!1,e.exports=function e(t,r,E,I,P,O){var R,L=1&r,D=2&r,z=4&r;if(E&&(R=P?E(t,I,P,O):E(t)),void 0!==R)return R;if(!_(t))return t;var j=v(t);if(j){if(R=m(t),!L)return c(t,R)}else{var F=f(t),N=F==T||"[object GeneratorFunction]"==F;if(x(t))return l(t,L);if(F==M||F==A||N&&!P){if(R=D||N?{}:y(t),!L)return D?d(t,s(R,t)):u(t,a(R,t))}else{if(!C[F])return P?t:{};R=g(t,F,L)}}O||(O=new n);var B=O.get(t);if(B)return B;O.set(t,R),w(t)?t.forEach((function(n){R.add(e(n,r,E,n,t,O))})):b(t)&&t.forEach((function(n,i){R.set(i,e(n,r,E,i,t,O))}));var V=j?void 0:(z?D?p:h:D?S:k)(t);return i(V||t,(function(n,i){V&&(n=t[i=n]),o(R,i,e(n,r,E,i,t,O))})),R}},21817:(e,t,r)=>{var n=r(46686),i=Object.create,o=function(){function e(){}return function(t){if(!n(t))return{};if(i)return i(t);e.prototype=t;var r=new e;return e.prototype=void 0,r}}();e.exports=o},45652:(e,t,r)=>{var n=r(94664),i=r(76516)(n);e.exports=i},94258:(e,t,r)=>{var n=r(55906)();e.exports=n},94664:(e,t,r)=>{var n=r(94258),i=r(28673);e.exports=function(e,t){return e&&n(e,t,i)}},52969:(e,t,r)=>{var n=r(35324),i=r(70914);e.exports=function(e,t){for(var r=0,o=(t=n(t,e)).length;null!=e&&r{var n=r(48895),i=r(54052);e.exports=function(e,t,r){var o=t(e);return i(e)?o:n(o,r(e))}},16913:(e,t,r)=>{var n=r(9812),i=r(34552),o=r(16095),a=n?n.toStringTag:void 0;e.exports=function(e){return null==e?void 0===e?"[object Undefined]":"[object Null]":a&&a in Object(e)?i(e):o(e)}},27894:e=>{e.exports=function(e,t){return null!=e&&t in Object(e)}},15193:(e,t,r)=>{var n=r(16913),i=r(22761);e.exports=function(e){return i(e)&&"[object Arguments]"==n(e)}},26989:(e,t,r)=>{var n=r(16399),i=r(22761);e.exports=function e(t,r,o,a,s){return t===r||(null==t||null==r||!i(t)&&!i(r)?t!==t&&r!==r:n(t,r,o,a,e,s))}},16399:(e,t,r)=>{var n=r(5538),i=r(43668),o=r(69987),a=r(45752),s=r(26924),l=r(54052),c=r(44543),u=r(51268),d="[object Arguments]",h="[object Array]",p="[object Object]",f=Object.prototype.hasOwnProperty;e.exports=function(e,t,r,m,g,y){var v=l(e),x=l(t),b=v?h:s(e),_=x?h:s(t),w=(b=b==d?p:b)==p,k=(_=_==d?p:_)==p,S=b==_;if(S&&c(e)){if(!c(t))return!1;v=!0,w=!1}if(S&&!w)return y||(y=new n),v||u(e)?i(e,t,r,m,g,y):o(e,t,b,r,m,g,y);if(!(1&r)){var A=w&&f.call(e,"__wrapped__"),T=k&&f.call(t,"__wrapped__");if(A||T){var M=A?e.value():e,C=T?t.value():t;return y||(y=new n),g(M,C,r,m,y)}}return!!S&&(y||(y=new n),a(e,t,r,m,g,y))}},5791:(e,t,r)=>{var n=r(26924),i=r(22761);e.exports=function(e){return i(e)&&"[object Map]"==n(e)}},86532:(e,t,r)=>{var n=r(5538),i=r(26989);e.exports=function(e,t,r,o){var a=r.length,s=a,l=!o;if(null==e)return!s;for(e=Object(e);a--;){var c=r[a];if(l&&c[2]?c[1]!==e[c[0]]:!(c[0]in e))return!1}for(;++a{var n=r(11629),i=r(37857),o=r(46686),a=r(96996),s=/^\[object .+?Constructor\]$/,l=Function.prototype,c=Object.prototype,u=l.toString,d=c.hasOwnProperty,h=RegExp("^"+u.call(d).replace(/[\\^$.*+?()[\]{}|]/g,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");e.exports=function(e){return!(!o(e)||i(e))&&(n(e)?h:s).test(a(e))}},20449:(e,t,r)=>{var n=r(26924),i=r(22761);e.exports=function(e){return i(e)&&"[object Set]"==n(e)}},35428:(e,t,r)=>{var n=r(16913),i=r(56173),o=r(22761),a={};a["[object Float32Array]"]=a["[object Float64Array]"]=a["[object Int8Array]"]=a["[object Int16Array]"]=a["[object Int32Array]"]=a["[object Uint8Array]"]=a["[object Uint8ClampedArray]"]=a["[object Uint16Array]"]=a["[object Uint32Array]"]=!0,a["[object Arguments]"]=a["[object Array]"]=a["[object ArrayBuffer]"]=a["[object Boolean]"]=a["[object DataView]"]=a["[object Date]"]=a["[object Error]"]=a["[object Function]"]=a["[object Map]"]=a["[object Number]"]=a["[object Object]"]=a["[object RegExp]"]=a["[object Set]"]=a["[object String]"]=a["[object WeakMap]"]=!1,e.exports=function(e){return o(e)&&i(e.length)&&!!a[n(e)]}},9096:(e,t,r)=>{var n=r(39256),i=r(15029),o=r(33279),a=r(54052),s=r(63932);e.exports=function(e){return"function"==typeof e?e:null==e?o:"object"==typeof e?a(e)?i(e[0],e[1]):n(e):s(e)}},83713:(e,t,r)=>{var n=r(36140),i=r(61143),o=Object.prototype.hasOwnProperty;e.exports=function(e){if(!n(e))return i(e);var t=[];for(var r in Object(e))o.call(e,r)&&"constructor"!=r&&t.push(r);return t}},58122:(e,t,r)=>{var n=r(46686),i=r(36140),o=r(43516),a=Object.prototype.hasOwnProperty;e.exports=function(e){if(!n(e))return o(e);var t=i(e),r=[];for(var s in e)("constructor"!=s||!t&&a.call(e,s))&&r.push(s);return r}},38883:(e,t,r)=>{var n=r(45652),i=r(6571);e.exports=function(e,t){var r=-1,o=i(e)?Array(e.length):[];return n(e,(function(e,n,i){o[++r]=t(e,n,i)})),o}},39256:(e,t,r)=>{var n=r(86532),i=r(23781),o=r(91310);e.exports=function(e){var t=i(e);return 1==t.length&&t[0][2]?o(t[0][0],t[0][1]):function(r){return r===e||n(r,e,t)}}},15029:(e,t,r)=>{var n=r(26989),i=r(33097),o=r(53366),a=r(62597),s=r(9417),l=r(91310),c=r(70914);e.exports=function(e,t){return a(e)&&s(t)?l(c(e),t):function(r){var a=i(r,e);return void 0===a&&a===t?o(r,e):n(t,a,3)}}},10396:e=>{e.exports=function(e){return function(t){return null==t?void 0:t[e]}}},52866:(e,t,r)=>{var n=r(52969);e.exports=function(e){return function(t){return n(t,e)}}},3343:e=>{e.exports=function(e,t){for(var r=-1,n=Array(e);++r{var n=r(9812),i=r(50149),o=r(54052),a=r(19841),s=n?n.prototype:void 0,l=s?s.toString:void 0;e.exports=function e(t){if("string"==typeof t)return t;if(o(t))return i(t,e)+"";if(a(t))return l?l.call(t):"";var r=t+"";return"0"==r&&1/t==-1/0?"-0":r}},25193:e=>{e.exports=function(e){return function(t){return e(t)}}},58114:e=>{e.exports=function(e,t){return e.has(t)}},25111:(e,t,r)=>{var n=r(33279);e.exports=function(e){return"function"==typeof e?e:n}},35324:(e,t,r)=>{var n=r(54052),i=r(62597),o=r(14079),a=r(41069);e.exports=function(e,t){return n(e)?e:i(e,t)?[e]:o(a(e))}},61516:(e,t,r)=>{var n=r(22929);e.exports=function(e){var t=new e.constructor(e.byteLength);return new n(t).set(new n(e)),t}},44353:(e,t,r)=>{e=r.nmd(e);var n=r(56552),i=t&&!t.nodeType&&t,o=i&&e&&!e.nodeType&&e,a=o&&o.exports===i?n.Buffer:void 0,s=a?a.allocUnsafe:void 0;e.exports=function(e,t){if(t)return e.slice();var r=e.length,n=s?s(r):new e.constructor(r);return e.copy(n),n}},6806:(e,t,r)=>{var n=r(61516);e.exports=function(e,t){var r=t?n(e.buffer):e.buffer;return new e.constructor(r,e.byteOffset,e.byteLength)}},18962:e=>{var t=/\w*$/;e.exports=function(e){var r=new e.constructor(e.source,t.exec(e));return r.lastIndex=e.lastIndex,r}},11295:(e,t,r)=>{var n=r(9812),i=n?n.prototype:void 0,o=i?i.valueOf:void 0;e.exports=function(e){return o?Object(o.call(e)):{}}},38710:(e,t,r)=>{var n=r(61516);e.exports=function(e,t){var r=t?n(e.buffer):e.buffer;return new e.constructor(r,e.byteOffset,e.length)}},91980:e=>{e.exports=function(e,t){var r=-1,n=e.length;for(t||(t=Array(n));++r{var n=r(78420),i=r(71775);e.exports=function(e,t,r,o){var a=!r;r||(r={});for(var s=-1,l=t.length;++s{var n=r(96614),i=r(69621);e.exports=function(e,t){return n(e,i(e),t)}},29075:(e,t,r)=>{var n=r(96614),i=r(56326);e.exports=function(e,t){return n(e,i(e),t)}},13440:(e,t,r)=>{var n=r(56552)["__core-js_shared__"];e.exports=n},76516:(e,t,r)=>{var n=r(6571);e.exports=function(e,t){return function(r,i){if(null==r)return r;if(!n(r))return e(r,i);for(var o=r.length,a=t?o:-1,s=Object(r);(t?a--:++a{e.exports=function(e){return function(t,r,n){for(var i=-1,o=Object(t),a=n(t),s=a.length;s--;){var l=a[e?s:++i];if(!1===r(o[l],l,o))break}return t}}},5654:(e,t,r)=>{var n=r(87937),i=function(){try{var e=n(Object,"defineProperty");return e({},"",{}),e}catch(t){}}();e.exports=i},43668:(e,t,r)=>{var n=r(18902),i=r(52587),o=r(58114);e.exports=function(e,t,r,a,s,l){var c=1&r,u=e.length,d=t.length;if(u!=d&&!(c&&d>u))return!1;var h=l.get(e),p=l.get(t);if(h&&p)return h==t&&p==e;var f=-1,m=!0,g=2&r?new n:void 0;for(l.set(e,t),l.set(t,e);++f{var n=r(9812),i=r(22929),o=r(93211),a=r(43668),s=r(54160),l=r(52074),c=n?n.prototype:void 0,u=c?c.valueOf:void 0;e.exports=function(e,t,r,n,c,d,h){switch(r){case"[object DataView]":if(e.byteLength!=t.byteLength||e.byteOffset!=t.byteOffset)return!1;e=e.buffer,t=t.buffer;case"[object ArrayBuffer]":return!(e.byteLength!=t.byteLength||!d(new i(e),new i(t)));case"[object Boolean]":case"[object Date]":case"[object Number]":return o(+e,+t);case"[object Error]":return e.name==t.name&&e.message==t.message;case"[object RegExp]":case"[object String]":return e==t+"";case"[object Map]":var p=s;case"[object Set]":var f=1&n;if(p||(p=l),e.size!=t.size&&!f)return!1;var m=h.get(e);if(m)return m==t;n|=2,h.set(e,t);var g=a(p(e),p(t),n,c,d,h);return h.delete(e),g;case"[object Symbol]":if(u)return u.call(e)==u.call(t)}return!1}},45752:(e,t,r)=>{var n=r(59395),i=Object.prototype.hasOwnProperty;e.exports=function(e,t,r,o,a,s){var l=1&r,c=n(e),u=c.length;if(u!=n(t).length&&!l)return!1;for(var d=u;d--;){var h=c[d];if(!(l?h in t:i.call(t,h)))return!1}var p=s.get(e),f=s.get(t);if(p&&f)return p==t&&f==e;var m=!0;s.set(e,t),s.set(t,e);for(var g=l;++d{var n="object"==typeof r.g&&r.g&&r.g.Object===Object&&r.g;e.exports=n},59395:(e,t,r)=>{var n=r(4262),i=r(69621),o=r(28673);e.exports=function(e){return n(e,o,i)}},68592:(e,t,r)=>{var n=r(4262),i=r(56326),o=r(30474);e.exports=function(e){return n(e,o,i)}},12622:(e,t,r)=>{var n=r(70705);e.exports=function(e,t){var r=e.__data__;return n(t)?r["string"==typeof t?"string":"hash"]:r.map}},23781:(e,t,r)=>{var n=r(9417),i=r(28673);e.exports=function(e){for(var t=i(e),r=t.length;r--;){var o=t[r],a=e[o];t[r]=[o,a,n(a)]}return t}},87937:(e,t,r)=>{var n=r(36954),i=r(14657);e.exports=function(e,t){var r=i(e,t);return n(r)?r:void 0}},85990:(e,t,r)=>{var n=r(13028)(Object.getPrototypeOf,Object);e.exports=n},34552:(e,t,r)=>{var n=r(9812),i=Object.prototype,o=i.hasOwnProperty,a=i.toString,s=n?n.toStringTag:void 0;e.exports=function(e){var t=o.call(e,s),r=e[s];try{e[s]=void 0;var n=!0}catch(l){}var i=a.call(e);return n&&(t?e[s]=r:delete e[s]),i}},69621:(e,t,r)=>{var n=r(17529),i=r(57828),o=Object.prototype.propertyIsEnumerable,a=Object.getOwnPropertySymbols,s=a?function(e){return null==e?[]:(e=Object(e),n(a(e),(function(t){return o.call(e,t)})))}:i;e.exports=s},56326:(e,t,r)=>{var n=r(48895),i=r(85990),o=r(69621),a=r(57828),s=Object.getOwnPropertySymbols?function(e){for(var t=[];e;)n(t,o(e)),e=i(e);return t}:a;e.exports=s},26924:(e,t,r)=>{var n=r(97685),i=r(85204),o=r(65387),a=r(72070),s=r(26600),l=r(16913),c=r(96996),u="[object Map]",d="[object Promise]",h="[object Set]",p="[object WeakMap]",f="[object DataView]",m=c(n),g=c(i),y=c(o),v=c(a),x=c(s),b=l;(n&&b(new n(new ArrayBuffer(1)))!=f||i&&b(new i)!=u||o&&b(o.resolve())!=d||a&&b(new a)!=h||s&&b(new s)!=p)&&(b=function(e){var t=l(e),r="[object Object]"==t?e.constructor:void 0,n=r?c(r):"";if(n)switch(n){case m:return f;case g:return u;case y:return d;case v:return h;case x:return p}return t}),e.exports=b},14657:e=>{e.exports=function(e,t){return null==e?void 0:e[t]}},99057:(e,t,r)=>{var n=r(35324),i=r(22777),o=r(54052),a=r(69194),s=r(56173),l=r(70914);e.exports=function(e,t,r){for(var c=-1,u=(t=n(t,e)).length,d=!1;++c{var n=r(95575);e.exports=function(){this.__data__=n?n(null):{},this.size=0}},25051:e=>{e.exports=function(e){var t=this.has(e)&&delete this.__data__[e];return this.size-=t?1:0,t}},72154:(e,t,r)=>{var n=r(95575),i=Object.prototype.hasOwnProperty;e.exports=function(e){var t=this.__data__;if(n){var r=t[e];return"__lodash_hash_undefined__"===r?void 0:r}return i.call(t,e)?t[e]:void 0}},48734:(e,t,r)=>{var n=r(95575),i=Object.prototype.hasOwnProperty;e.exports=function(e){var t=this.__data__;return n?void 0!==t[e]:i.call(t,e)}},22662:(e,t,r)=>{var n=r(95575);e.exports=function(e,t){var r=this.__data__;return this.size+=this.has(e)?0:1,r[e]=n&&void 0===t?"__lodash_hash_undefined__":t,this}},38268:e=>{var t=Object.prototype.hasOwnProperty;e.exports=function(e){var r=e.length,n=new e.constructor(r);return r&&"string"==typeof e[0]&&t.call(e,"index")&&(n.index=e.index,n.input=e.input),n}},18630:(e,t,r)=>{var n=r(61516),i=r(6806),o=r(18962),a=r(11295),s=r(38710);e.exports=function(e,t,r){var l=e.constructor;switch(t){case"[object ArrayBuffer]":return n(e);case"[object Boolean]":case"[object Date]":return new l(+e);case"[object DataView]":return i(e,r);case"[object Float32Array]":case"[object Float64Array]":case"[object Int8Array]":case"[object Int16Array]":case"[object Int32Array]":case"[object Uint8Array]":case"[object Uint8ClampedArray]":case"[object Uint16Array]":case"[object Uint32Array]":return s(e,r);case"[object Map]":case"[object Set]":return new l;case"[object Number]":case"[object String]":return new l(e);case"[object RegExp]":return o(e);case"[object Symbol]":return a(e)}}},20310:(e,t,r)=>{var n=r(21817),i=r(85990),o=r(36140);e.exports=function(e){return"function"!=typeof e.constructor||o(e)?{}:n(i(e))}},69194:e=>{var t=/^(?:0|[1-9]\d*)$/;e.exports=function(e,r){var n=typeof e;return!!(r=null==r?9007199254740991:r)&&("number"==n||"symbol"!=n&&t.test(e))&&e>-1&&e%1==0&&e{var n=r(54052),i=r(19841),o=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,a=/^\w*$/;e.exports=function(e,t){if(n(e))return!1;var r=typeof e;return!("number"!=r&&"symbol"!=r&&"boolean"!=r&&null!=e&&!i(e))||(a.test(e)||!o.test(e)||null!=t&&e in Object(t))}},70705:e=>{e.exports=function(e){var t=typeof e;return"string"==t||"number"==t||"symbol"==t||"boolean"==t?"__proto__"!==e:null===e}},37857:(e,t,r)=>{var n=r(13440),i=function(){var e=/[^.]+$/.exec(n&&n.keys&&n.keys.IE_PROTO||"");return e?"Symbol(src)_1."+e:""}();e.exports=function(e){return!!i&&i in e}},36140:e=>{var t=Object.prototype;e.exports=function(e){var r=e&&e.constructor;return e===("function"==typeof r&&r.prototype||t)}},9417:(e,t,r)=>{var n=r(46686);e.exports=function(e){return e===e&&!n(e)}},87563:e=>{e.exports=function(){this.__data__=[],this.size=0}},29935:(e,t,r)=>{var n=r(61340),i=Array.prototype.splice;e.exports=function(e){var t=this.__data__,r=n(t,e);return!(r<0)&&(r==t.length-1?t.pop():i.call(t,r,1),--this.size,!0)}},24190:(e,t,r)=>{var n=r(61340);e.exports=function(e){var t=this.__data__,r=n(t,e);return r<0?void 0:t[r][1]}},51946:(e,t,r)=>{var n=r(61340);e.exports=function(e){return n(this.__data__,e)>-1}},61714:(e,t,r)=>{var n=r(61340);e.exports=function(e,t){var r=this.__data__,i=n(r,e);return i<0?(++this.size,r.push([e,t])):r[i][1]=t,this}},47251:(e,t,r)=>{var n=r(98724),i=r(97160),o=r(85204);e.exports=function(){this.size=0,this.__data__={hash:new n,map:new(o||i),string:new n}}},37159:(e,t,r)=>{var n=r(12622);e.exports=function(e){var t=n(this,e).delete(e);return this.size-=t?1:0,t}},80438:(e,t,r)=>{var n=r(12622);e.exports=function(e){return n(this,e).get(e)}},69394:(e,t,r)=>{var n=r(12622);e.exports=function(e){return n(this,e).has(e)}},56874:(e,t,r)=>{var n=r(12622);e.exports=function(e,t){var r=n(this,e),i=r.size;return r.set(e,t),this.size+=r.size==i?0:1,this}},54160:e=>{e.exports=function(e){var t=-1,r=Array(e.size);return e.forEach((function(e,n){r[++t]=[n,e]})),r}},91310:e=>{e.exports=function(e,t){return function(r){return null!=r&&(r[e]===t&&(void 0!==t||e in Object(r)))}}},88259:(e,t,r)=>{var n=r(15797);e.exports=function(e){var t=n(e,(function(e){return 500===r.size&&r.clear(),e})),r=t.cache;return t}},95575:(e,t,r)=>{var n=r(87937)(Object,"create");e.exports=n},61143:(e,t,r)=>{var n=r(13028)(Object.keys,Object);e.exports=n},43516:e=>{e.exports=function(e){var t=[];if(null!=e)for(var r in Object(e))t.push(r);return t}},56832:(e,t,r)=>{e=r.nmd(e);var n=r(37105),i=t&&!t.nodeType&&t,o=i&&e&&!e.nodeType&&e,a=o&&o.exports===i&&n.process,s=function(){try{var e=o&&o.require&&o.require("util").types;return e||a&&a.binding&&a.binding("util")}catch(t){}}();e.exports=s},16095:e=>{var t=Object.prototype.toString;e.exports=function(e){return t.call(e)}},13028:e=>{e.exports=function(e,t){return function(r){return e(t(r))}}},56552:(e,t,r)=>{var n=r(37105),i="object"==typeof self&&self&&self.Object===Object&&self,o=n||i||Function("return this")();e.exports=o},86179:e=>{e.exports=function(e){return this.__data__.set(e,"__lodash_hash_undefined__"),this}},46704:e=>{e.exports=function(e){return this.__data__.has(e)}},52074:e=>{e.exports=function(e){var t=-1,r=Array(e.size);return e.forEach((function(e){r[++t]=e})),r}},84545:(e,t,r)=>{var n=r(97160);e.exports=function(){this.__data__=new n,this.size=0}},10793:e=>{e.exports=function(e){var t=this.__data__,r=t.delete(e);return this.size=t.size,r}},27760:e=>{e.exports=function(e){return this.__data__.get(e)}},3892:e=>{e.exports=function(e){return this.__data__.has(e)}},76788:(e,t,r)=>{var n=r(97160),i=r(85204),o=r(64816);e.exports=function(e,t){var r=this.__data__;if(r instanceof n){var a=r.__data__;if(!i||a.length<199)return a.push([e,t]),this.size=++r.size,this;r=this.__data__=new o(a)}return r.set(e,t),this.size=r.size,this}},14079:(e,t,r)=>{var n=r(88259),i=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,o=/\\(\\)?/g,a=n((function(e){var t=[];return 46===e.charCodeAt(0)&&t.push(""),e.replace(i,(function(e,r,n,i){t.push(n?i.replace(o,"$1"):r||e)})),t}));e.exports=a},70914:(e,t,r)=>{var n=r(19841);e.exports=function(e){if("string"==typeof e||n(e))return e;var t=e+"";return"0"==t&&1/e==-1/0?"-0":t}},96996:e=>{var t=Function.prototype.toString;e.exports=function(e){if(null!=e){try{return t.call(e)}catch(r){}try{return e+""}catch(r){}}return""}},56434:(e,t,r)=>{var n=r(97132);e.exports=function(e){return n(e,5)}},93211:e=>{e.exports=function(e,t){return e===t||e!==e&&t!==t}},40840:(e,t,r)=>{var n=r(94664),i=r(25111);e.exports=function(e,t){return e&&n(e,i(t))}},33097:(e,t,r)=>{var n=r(52969);e.exports=function(e,t,r){var i=null==e?void 0:n(e,t);return void 0===i?r:i}},53366:(e,t,r)=>{var n=r(27894),i=r(99057);e.exports=function(e,t){return null!=e&&i(e,t,n)}},33279:e=>{e.exports=function(e){return e}},22777:(e,t,r)=>{var n=r(15193),i=r(22761),o=Object.prototype,a=o.hasOwnProperty,s=o.propertyIsEnumerable,l=n(function(){return arguments}())?n:function(e){return i(e)&&a.call(e,"callee")&&!s.call(e,"callee")};e.exports=l},54052:e=>{var t=Array.isArray;e.exports=t},6571:(e,t,r)=>{var n=r(11629),i=r(56173);e.exports=function(e){return null!=e&&i(e.length)&&!n(e)}},44543:(e,t,r)=>{e=r.nmd(e);var n=r(56552),i=r(60014),o=t&&!t.nodeType&&t,a=o&&e&&!e.nodeType&&e,s=a&&a.exports===o?n.Buffer:void 0,l=(s?s.isBuffer:void 0)||i;e.exports=l},11629:(e,t,r)=>{var n=r(16913),i=r(46686);e.exports=function(e){if(!i(e))return!1;var t=n(e);return"[object Function]"==t||"[object GeneratorFunction]"==t||"[object AsyncFunction]"==t||"[object Proxy]"==t}},56173:e=>{e.exports=function(e){return"number"==typeof e&&e>-1&&e%1==0&&e<=9007199254740991}},57887:(e,t,r)=>{var n=r(5791),i=r(25193),o=r(56832),a=o&&o.isMap,s=a?i(a):n;e.exports=s},46686:e=>{e.exports=function(e){var t=typeof e;return null!=e&&("object"==t||"function"==t)}},22761:e=>{e.exports=function(e){return null!=e&&"object"==typeof e}},12322:(e,t,r)=>{var n=r(16913),i=r(85990),o=r(22761),a=Function.prototype,s=Object.prototype,l=a.toString,c=s.hasOwnProperty,u=l.call(Object);e.exports=function(e){if(!o(e)||"[object Object]"!=n(e))return!1;var t=i(e);if(null===t)return!0;var r=c.call(t,"constructor")&&t.constructor;return"function"==typeof r&&r instanceof r&&l.call(r)==u}},45921:(e,t,r)=>{var n=r(20449),i=r(25193),o=r(56832),a=o&&o.isSet,s=a?i(a):n;e.exports=s},90620:(e,t,r)=>{var n=r(16913),i=r(54052),o=r(22761);e.exports=function(e){return"string"==typeof e||!i(e)&&o(e)&&"[object String]"==n(e)}},19841:(e,t,r)=>{var n=r(16913),i=r(22761);e.exports=function(e){return"symbol"==typeof e||i(e)&&"[object Symbol]"==n(e)}},51268:(e,t,r)=>{var n=r(35428),i=r(25193),o=r(56832),a=o&&o.isTypedArray,s=a?i(a):n;e.exports=s},28673:(e,t,r)=>{var n=r(73204),i=r(83713),o=r(6571);e.exports=function(e){return o(e)?n(e):i(e)}},30474:(e,t,r)=>{var n=r(73204),i=r(58122),o=r(6571);e.exports=function(e){return o(e)?n(e,!0):i(e)}},33411:(e,t,r)=>{var n=r(50149),i=r(9096),o=r(38883),a=r(54052);e.exports=function(e,t){return(a(e)?n:o)(e,i(t,3))}},15797:(e,t,r)=>{var n=r(64816);function i(e,t){if("function"!=typeof e||null!=t&&"function"!=typeof t)throw new TypeError("Expected a function");var r=function(){var n=arguments,i=t?t.apply(this,n):n[0],o=r.cache;if(o.has(i))return o.get(i);var a=e.apply(this,n);return r.cache=o.set(i,a)||o,a};return r.cache=new(i.Cache||n),r}i.Cache=n,e.exports=i},63932:(e,t,r)=>{var n=r(10396),i=r(52866),o=r(62597),a=r(70914);e.exports=function(e){return o(e)?n(a(e)):i(e)}},57828:e=>{e.exports=function(){return[]}},60014:e=>{e.exports=function(){return!1}},41069:(e,t,r)=>{var n=r(38541);e.exports=function(e){return null==e?"":n(e)}},62773:e=>{"use strict";e.exports=Math.log2||function(e){return Math.log(e)*Math.LOG2E}},86178:function(e,t,r){(e=r.nmd(e)).exports=function(){"use strict";var t,r;function n(){return t.apply(null,arguments)}function i(e){t=e}function o(e){return e instanceof Array||"[object Array]"===Object.prototype.toString.call(e)}function a(e){return null!=e&&"[object Object]"===Object.prototype.toString.call(e)}function s(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function l(e){if(Object.getOwnPropertyNames)return 0===Object.getOwnPropertyNames(e).length;var t;for(t in e)if(s(e,t))return!1;return!0}function c(e){return void 0===e}function u(e){return"number"===typeof e||"[object Number]"===Object.prototype.toString.call(e)}function d(e){return e instanceof Date||"[object Date]"===Object.prototype.toString.call(e)}function h(e,t){var r,n=[],i=e.length;for(r=0;r>>0;for(t=0;t0)for(r=0;r=0?r?"+":"":"-")+Math.pow(10,Math.max(0,i)).toString().substr(1)+n}var z=/(\[[^\[]*\])|(\\)?([Hh]mm(ss)?|Mo|MM?M?M?|Do|DDDo|DD?D?D?|ddd?d?|do?|w[o|w]?|W[o|W]?|Qo?|N{1,5}|YYYYYY|YYYYY|YYYY|YY|y{2,4}|yo?|gg(ggg?)?|GG(GGG?)?|e|E|a|A|hh?|HH?|kk?|mm?|ss?|S{1,9}|x|X|zz?|ZZ?|.)/g,j=/(\[[^\[]*\])|(\\)?(LTS|LT|LL?L?L?|l{1,4})/g,F={},N={};function B(e,t,r,n){var i=n;"string"===typeof n&&(i=function(){return this[n]()}),e&&(N[e]=i),t&&(N[t[0]]=function(){return D(i.apply(this,arguments),t[1],t[2])}),r&&(N[r]=function(){return this.localeData().ordinal(i.apply(this,arguments),e)})}function V(e){return e.match(/\[[\s\S]/)?e.replace(/^\[|\]$/g,""):e.replace(/\\/g,"")}function U(e){var t,r,n=e.match(z);for(t=0,r=n.length;t=0&&j.test(e);)e=e.replace(j,n),j.lastIndex=0,r-=1;return e}var W={LTS:"h:mm:ss A",LT:"h:mm A",L:"MM/DD/YYYY",LL:"MMMM D, YYYY",LLL:"MMMM D, YYYY h:mm A",LLLL:"dddd, MMMM D, YYYY h:mm A"};function q(e){var t=this._longDateFormat[e],r=this._longDateFormat[e.toUpperCase()];return t||!r?t:(this._longDateFormat[e]=r.match(z).map((function(e){return"MMMM"===e||"MM"===e||"DD"===e||"dddd"===e?e.slice(1):e})).join(""),this._longDateFormat[e])}var G="Invalid date";function Y(){return this._invalidDate}var X="%d",Z=/\d{1,2}/;function K(e){return this._ordinal.replace("%d",e)}var J={future:"in %s",past:"%s ago",s:"a few seconds",ss:"%d seconds",m:"a minute",mm:"%d minutes",h:"an hour",hh:"%d hours",d:"a day",dd:"%d days",w:"a week",ww:"%d weeks",M:"a month",MM:"%d months",y:"a year",yy:"%d years"};function Q(e,t,r,n){var i=this._relativeTime[r];return E(i)?i(e,t,r,n):i.replace(/%d/i,e)}function ee(e,t){var r=this._relativeTime[e>0?"future":"past"];return E(r)?r(t):r.replace(/%s/i,t)}var te={D:"date",dates:"date",date:"date",d:"day",days:"day",day:"day",e:"weekday",weekdays:"weekday",weekday:"weekday",E:"isoWeekday",isoweekdays:"isoWeekday",isoweekday:"isoWeekday",DDD:"dayOfYear",dayofyears:"dayOfYear",dayofyear:"dayOfYear",h:"hour",hours:"hour",hour:"hour",ms:"millisecond",milliseconds:"millisecond",millisecond:"millisecond",m:"minute",minutes:"minute",minute:"minute",M:"month",months:"month",month:"month",Q:"quarter",quarters:"quarter",quarter:"quarter",s:"second",seconds:"second",second:"second",gg:"weekYear",weekyears:"weekYear",weekyear:"weekYear",GG:"isoWeekYear",isoweekyears:"isoWeekYear",isoweekyear:"isoWeekYear",w:"week",weeks:"week",week:"week",W:"isoWeek",isoweeks:"isoWeek",isoweek:"isoWeek",y:"year",years:"year",year:"year"};function re(e){return"string"===typeof e?te[e]||te[e.toLowerCase()]:void 0}function ne(e){var t,r,n={};for(r in e)s(e,r)&&(t=re(r))&&(n[t]=e[r]);return n}var ie={date:9,day:11,weekday:11,isoWeekday:11,dayOfYear:4,hour:13,millisecond:16,minute:14,month:8,quarter:7,second:15,weekYear:1,isoWeekYear:1,week:5,isoWeek:5,year:1};function oe(e){var t,r=[];for(t in e)s(e,t)&&r.push({unit:t,priority:ie[t]});return r.sort((function(e,t){return e.priority-t.priority})),r}var ae,se=/\d/,le=/\d\d/,ce=/\d{3}/,ue=/\d{4}/,de=/[+-]?\d{6}/,he=/\d\d?/,pe=/\d\d\d\d?/,fe=/\d\d\d\d\d\d?/,me=/\d{1,3}/,ge=/\d{1,4}/,ye=/[+-]?\d{1,6}/,ve=/\d+/,xe=/[+-]?\d+/,be=/Z|[+-]\d\d:?\d\d/gi,_e=/Z|[+-]\d\d(?::?\d\d)?/gi,we=/[+-]?\d+(\.\d{1,3})?/,ke=/[0-9]{0,256}['a-z\u00A0-\u05FF\u0700-\uD7FF\uF900-\uFDCF\uFDF0-\uFF07\uFF10-\uFFEF]{1,256}|[\u0600-\u06FF\/]{1,256}(\s*?[\u0600-\u06FF]{1,256}){1,2}/i,Se=/^[1-9]\d?/,Ae=/^([1-9]\d|\d)/;function Te(e,t,r){ae[e]=E(t)?t:function(e,n){return e&&r?r:t}}function Me(e,t){return s(ae,e)?ae[e](t._strict,t._locale):new RegExp(Ce(e))}function Ce(e){return Ee(e.replace("\\","").replace(/\\(\[)|\\(\])|\[([^\]\[]*)\]|\\(.)/g,(function(e,t,r,n,i){return t||r||n||i})))}function Ee(e){return e.replace(/[-\/\\^$*+?.()|[\]{}]/g,"\\$&")}function Ie(e){return e<0?Math.ceil(e)||0:Math.floor(e)}function Pe(e){var t=+e,r=0;return 0!==t&&isFinite(t)&&(r=Ie(t)),r}ae={};var Oe={};function Re(e,t){var r,n,i=t;for("string"===typeof e&&(e=[e]),u(t)&&(i=function(e,r){r[t]=Pe(e)}),n=e.length,r=0;r68?1900:2e3)};var Ge,Ye=Ze("FullYear",!0);function Xe(){return ze(this.year())}function Ze(e,t){return function(r){return null!=r?(Je(this,e,r),n.updateOffset(this,t),this):Ke(this,e)}}function Ke(e,t){if(!e.isValid())return NaN;var r=e._d,n=e._isUTC;switch(t){case"Milliseconds":return n?r.getUTCMilliseconds():r.getMilliseconds();case"Seconds":return n?r.getUTCSeconds():r.getSeconds();case"Minutes":return n?r.getUTCMinutes():r.getMinutes();case"Hours":return n?r.getUTCHours():r.getHours();case"Date":return n?r.getUTCDate():r.getDate();case"Day":return n?r.getUTCDay():r.getDay();case"Month":return n?r.getUTCMonth():r.getMonth();case"FullYear":return n?r.getUTCFullYear():r.getFullYear();default:return NaN}}function Je(e,t,r){var n,i,o,a,s;if(e.isValid()&&!isNaN(r)){switch(n=e._d,i=e._isUTC,t){case"Milliseconds":return void(i?n.setUTCMilliseconds(r):n.setMilliseconds(r));case"Seconds":return void(i?n.setUTCSeconds(r):n.setSeconds(r));case"Minutes":return void(i?n.setUTCMinutes(r):n.setMinutes(r));case"Hours":return void(i?n.setUTCHours(r):n.setHours(r));case"Date":return void(i?n.setUTCDate(r):n.setDate(r));case"FullYear":break;default:return}o=r,a=e.month(),s=29!==(s=e.date())||1!==a||ze(o)?s:28,i?n.setUTCFullYear(o,a,s):n.setFullYear(o,a,s)}}function Qe(e){return E(this[e=re(e)])?this[e]():this}function et(e,t){if("object"===typeof e){var r,n=oe(e=ne(e)),i=n.length;for(r=0;r=0?(s=new Date(e+400,t,r,n,i,o,a),isFinite(s.getFullYear())&&s.setFullYear(e)):s=new Date(e,t,r,n,i,o,a),s}function xt(e){var t,r;return e<100&&e>=0?((r=Array.prototype.slice.call(arguments))[0]=e+400,t=new Date(Date.UTC.apply(null,r)),isFinite(t.getUTCFullYear())&&t.setUTCFullYear(e)):t=new Date(Date.UTC.apply(null,arguments)),t}function bt(e,t,r){var n=7+t-r;return-(7+xt(e,0,n).getUTCDay()-t)%7+n-1}function _t(e,t,r,n,i){var o,a,s=1+7*(t-1)+(7+r-n)%7+bt(e,n,i);return s<=0?a=qe(o=e-1)+s:s>qe(e)?(o=e+1,a=s-qe(e)):(o=e,a=s),{year:o,dayOfYear:a}}function wt(e,t,r){var n,i,o=bt(e.year(),t,r),a=Math.floor((e.dayOfYear()-o-1)/7)+1;return a<1?n=a+kt(i=e.year()-1,t,r):a>kt(e.year(),t,r)?(n=a-kt(e.year(),t,r),i=e.year()+1):(i=e.year(),n=a),{week:n,year:i}}function kt(e,t,r){var n=bt(e,t,r),i=bt(e+1,t,r);return(qe(e)-n+i)/7}function St(e){return wt(e,this._week.dow,this._week.doy).week}B("w",["ww",2],"wo","week"),B("W",["WW",2],"Wo","isoWeek"),Te("w",he,Se),Te("ww",he,le),Te("W",he,Se),Te("WW",he,le),Le(["w","ww","W","WW"],(function(e,t,r,n){t[n.substr(0,1)]=Pe(e)}));var At={dow:0,doy:6};function Tt(){return this._week.dow}function Mt(){return this._week.doy}function Ct(e){var t=this.localeData().week(this);return null==e?t:this.add(7*(e-t),"d")}function Et(e){var t=wt(this,1,4).week;return null==e?t:this.add(7*(e-t),"d")}function It(e,t){return"string"!==typeof e?e:isNaN(e)?"number"===typeof(e=t.weekdaysParse(e))?e:null:parseInt(e,10)}function Pt(e,t){return"string"===typeof e?t.weekdaysParse(e)%7||7:isNaN(e)?null:e}function Ot(e,t){return e.slice(t,7).concat(e.slice(0,t))}B("d",0,"do","day"),B("dd",0,0,(function(e){return this.localeData().weekdaysMin(this,e)})),B("ddd",0,0,(function(e){return this.localeData().weekdaysShort(this,e)})),B("dddd",0,0,(function(e){return this.localeData().weekdays(this,e)})),B("e",0,0,"weekday"),B("E",0,0,"isoWeekday"),Te("d",he),Te("e",he),Te("E",he),Te("dd",(function(e,t){return t.weekdaysMinRegex(e)})),Te("ddd",(function(e,t){return t.weekdaysShortRegex(e)})),Te("dddd",(function(e,t){return t.weekdaysRegex(e)})),Le(["dd","ddd","dddd"],(function(e,t,r,n){var i=r._locale.weekdaysParse(e,n,r._strict);null!=i?t.d=i:g(r).invalidWeekday=e})),Le(["d","e","E"],(function(e,t,r,n){t[n]=Pe(e)}));var Rt="Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"),Lt="Sun_Mon_Tue_Wed_Thu_Fri_Sat".split("_"),Dt="Su_Mo_Tu_We_Th_Fr_Sa".split("_"),zt=ke,jt=ke,Ft=ke;function Nt(e,t){var r=o(this._weekdays)?this._weekdays:this._weekdays[e&&!0!==e&&this._weekdays.isFormat.test(t)?"format":"standalone"];return!0===e?Ot(r,this._week.dow):e?r[e.day()]:r}function Bt(e){return!0===e?Ot(this._weekdaysShort,this._week.dow):e?this._weekdaysShort[e.day()]:this._weekdaysShort}function Vt(e){return!0===e?Ot(this._weekdaysMin,this._week.dow):e?this._weekdaysMin[e.day()]:this._weekdaysMin}function Ut(e,t,r){var n,i,o,a=e.toLocaleLowerCase();if(!this._weekdaysParse)for(this._weekdaysParse=[],this._shortWeekdaysParse=[],this._minWeekdaysParse=[],n=0;n<7;++n)o=f([2e3,1]).day(n),this._minWeekdaysParse[n]=this.weekdaysMin(o,"").toLocaleLowerCase(),this._shortWeekdaysParse[n]=this.weekdaysShort(o,"").toLocaleLowerCase(),this._weekdaysParse[n]=this.weekdays(o,"").toLocaleLowerCase();return r?"dddd"===t?-1!==(i=Ge.call(this._weekdaysParse,a))?i:null:"ddd"===t?-1!==(i=Ge.call(this._shortWeekdaysParse,a))?i:null:-1!==(i=Ge.call(this._minWeekdaysParse,a))?i:null:"dddd"===t?-1!==(i=Ge.call(this._weekdaysParse,a))||-1!==(i=Ge.call(this._shortWeekdaysParse,a))||-1!==(i=Ge.call(this._minWeekdaysParse,a))?i:null:"ddd"===t?-1!==(i=Ge.call(this._shortWeekdaysParse,a))||-1!==(i=Ge.call(this._weekdaysParse,a))||-1!==(i=Ge.call(this._minWeekdaysParse,a))?i:null:-1!==(i=Ge.call(this._minWeekdaysParse,a))||-1!==(i=Ge.call(this._weekdaysParse,a))||-1!==(i=Ge.call(this._shortWeekdaysParse,a))?i:null}function Ht(e,t,r){var n,i,o;if(this._weekdaysParseExact)return Ut.call(this,e,t,r);for(this._weekdaysParse||(this._weekdaysParse=[],this._minWeekdaysParse=[],this._shortWeekdaysParse=[],this._fullWeekdaysParse=[]),n=0;n<7;n++){if(i=f([2e3,1]).day(n),r&&!this._fullWeekdaysParse[n]&&(this._fullWeekdaysParse[n]=new RegExp("^"+this.weekdays(i,"").replace(".","\\.?")+"$","i"),this._shortWeekdaysParse[n]=new RegExp("^"+this.weekdaysShort(i,"").replace(".","\\.?")+"$","i"),this._minWeekdaysParse[n]=new RegExp("^"+this.weekdaysMin(i,"").replace(".","\\.?")+"$","i")),this._weekdaysParse[n]||(o="^"+this.weekdays(i,"")+"|^"+this.weekdaysShort(i,"")+"|^"+this.weekdaysMin(i,""),this._weekdaysParse[n]=new RegExp(o.replace(".",""),"i")),r&&"dddd"===t&&this._fullWeekdaysParse[n].test(e))return n;if(r&&"ddd"===t&&this._shortWeekdaysParse[n].test(e))return n;if(r&&"dd"===t&&this._minWeekdaysParse[n].test(e))return n;if(!r&&this._weekdaysParse[n].test(e))return n}}function $t(e){if(!this.isValid())return null!=e?this:NaN;var t=Ke(this,"Day");return null!=e?(e=It(e,this.localeData()),this.add(e-t,"d")):t}function Wt(e){if(!this.isValid())return null!=e?this:NaN;var t=(this.day()+7-this.localeData()._week.dow)%7;return null==e?t:this.add(e-t,"d")}function qt(e){if(!this.isValid())return null!=e?this:NaN;if(null!=e){var t=Pt(e,this.localeData());return this.day(this.day()%7?t:t-7)}return this.day()||7}function Gt(e){return this._weekdaysParseExact?(s(this,"_weekdaysRegex")||Zt.call(this),e?this._weekdaysStrictRegex:this._weekdaysRegex):(s(this,"_weekdaysRegex")||(this._weekdaysRegex=zt),this._weekdaysStrictRegex&&e?this._weekdaysStrictRegex:this._weekdaysRegex)}function Yt(e){return this._weekdaysParseExact?(s(this,"_weekdaysRegex")||Zt.call(this),e?this._weekdaysShortStrictRegex:this._weekdaysShortRegex):(s(this,"_weekdaysShortRegex")||(this._weekdaysShortRegex=jt),this._weekdaysShortStrictRegex&&e?this._weekdaysShortStrictRegex:this._weekdaysShortRegex)}function Xt(e){return this._weekdaysParseExact?(s(this,"_weekdaysRegex")||Zt.call(this),e?this._weekdaysMinStrictRegex:this._weekdaysMinRegex):(s(this,"_weekdaysMinRegex")||(this._weekdaysMinRegex=Ft),this._weekdaysMinStrictRegex&&e?this._weekdaysMinStrictRegex:this._weekdaysMinRegex)}function Zt(){function e(e,t){return t.length-e.length}var t,r,n,i,o,a=[],s=[],l=[],c=[];for(t=0;t<7;t++)r=f([2e3,1]).day(t),n=Ee(this.weekdaysMin(r,"")),i=Ee(this.weekdaysShort(r,"")),o=Ee(this.weekdays(r,"")),a.push(n),s.push(i),l.push(o),c.push(n),c.push(i),c.push(o);a.sort(e),s.sort(e),l.sort(e),c.sort(e),this._weekdaysRegex=new RegExp("^("+c.join("|")+")","i"),this._weekdaysShortRegex=this._weekdaysRegex,this._weekdaysMinRegex=this._weekdaysRegex,this._weekdaysStrictRegex=new RegExp("^("+l.join("|")+")","i"),this._weekdaysShortStrictRegex=new RegExp("^("+s.join("|")+")","i"),this._weekdaysMinStrictRegex=new RegExp("^("+a.join("|")+")","i")}function Kt(){return this.hours()%12||12}function Jt(){return this.hours()||24}function Qt(e,t){B(e,0,0,(function(){return this.localeData().meridiem(this.hours(),this.minutes(),t)}))}function er(e,t){return t._meridiemParse}function tr(e){return"p"===(e+"").toLowerCase().charAt(0)}B("H",["HH",2],0,"hour"),B("h",["hh",2],0,Kt),B("k",["kk",2],0,Jt),B("hmm",0,0,(function(){return""+Kt.apply(this)+D(this.minutes(),2)})),B("hmmss",0,0,(function(){return""+Kt.apply(this)+D(this.minutes(),2)+D(this.seconds(),2)})),B("Hmm",0,0,(function(){return""+this.hours()+D(this.minutes(),2)})),B("Hmmss",0,0,(function(){return""+this.hours()+D(this.minutes(),2)+D(this.seconds(),2)})),Qt("a",!0),Qt("A",!1),Te("a",er),Te("A",er),Te("H",he,Ae),Te("h",he,Se),Te("k",he,Se),Te("HH",he,le),Te("hh",he,le),Te("kk",he,le),Te("hmm",pe),Te("hmmss",fe),Te("Hmm",pe),Te("Hmmss",fe),Re(["H","HH"],Be),Re(["k","kk"],(function(e,t,r){var n=Pe(e);t[Be]=24===n?0:n})),Re(["a","A"],(function(e,t,r){r._isPm=r._locale.isPM(e),r._meridiem=e})),Re(["h","hh"],(function(e,t,r){t[Be]=Pe(e),g(r).bigHour=!0})),Re("hmm",(function(e,t,r){var n=e.length-2;t[Be]=Pe(e.substr(0,n)),t[Ve]=Pe(e.substr(n)),g(r).bigHour=!0})),Re("hmmss",(function(e,t,r){var n=e.length-4,i=e.length-2;t[Be]=Pe(e.substr(0,n)),t[Ve]=Pe(e.substr(n,2)),t[Ue]=Pe(e.substr(i)),g(r).bigHour=!0})),Re("Hmm",(function(e,t,r){var n=e.length-2;t[Be]=Pe(e.substr(0,n)),t[Ve]=Pe(e.substr(n))})),Re("Hmmss",(function(e,t,r){var n=e.length-4,i=e.length-2;t[Be]=Pe(e.substr(0,n)),t[Ve]=Pe(e.substr(n,2)),t[Ue]=Pe(e.substr(i))}));var rr=/[ap]\.?m?\.?/i,nr=Ze("Hours",!0);function ir(e,t,r){return e>11?r?"pm":"PM":r?"am":"AM"}var or,ar={calendar:R,longDateFormat:W,invalidDate:G,ordinal:X,dayOfMonthOrdinalParse:Z,relativeTime:J,months:nt,monthsShort:it,week:At,weekdays:Rt,weekdaysMin:Dt,weekdaysShort:Lt,meridiemParse:rr},sr={},lr={};function cr(e,t){var r,n=Math.min(e.length,t.length);for(r=0;r0;){if(n=pr(i.slice(0,t).join("-")))return n;if(r&&r.length>=t&&cr(i,r)>=t-1)break;t--}o++}return or}function hr(e){return!(!e||!e.match("^[^/\\\\]*$"))}function pr(t){var r=null;if(void 0===sr[t]&&e&&e.exports&&hr(t))try{r=or._abbr,Object(function(){var e=new Error("Cannot find module 'undefined'");throw e.code="MODULE_NOT_FOUND",e}()),fr(r)}catch(n){sr[t]=null}return sr[t]}function fr(e,t){var r;return e&&((r=c(t)?yr(e):mr(e,t))?or=r:"undefined"!==typeof console&&console.warn&&console.warn("Locale "+e+" not found. Did you forget to load it?")),or._abbr}function mr(e,t){if(null!==t){var r,n=ar;if(t.abbr=e,null!=sr[e])C("defineLocaleOverride","use moment.updateLocale(localeName, config) to change an existing locale. moment.defineLocale(localeName, config) should only be used for creating a new locale See http://momentjs.com/guides/#/warnings/define-locale/ for more info."),n=sr[e]._config;else if(null!=t.parentLocale)if(null!=sr[t.parentLocale])n=sr[t.parentLocale]._config;else{if(null==(r=pr(t.parentLocale)))return lr[t.parentLocale]||(lr[t.parentLocale]=[]),lr[t.parentLocale].push({name:e,config:t}),null;n=r._config}return sr[e]=new O(P(n,t)),lr[e]&&lr[e].forEach((function(e){mr(e.name,e.config)})),fr(e),sr[e]}return delete sr[e],null}function gr(e,t){if(null!=t){var r,n,i=ar;null!=sr[e]&&null!=sr[e].parentLocale?sr[e].set(P(sr[e]._config,t)):(null!=(n=pr(e))&&(i=n._config),t=P(i,t),null==n&&(t.abbr=e),(r=new O(t)).parentLocale=sr[e],sr[e]=r),fr(e)}else null!=sr[e]&&(null!=sr[e].parentLocale?(sr[e]=sr[e].parentLocale,e===fr()&&fr(e)):null!=sr[e]&&delete sr[e]);return sr[e]}function yr(e){var t;if(e&&e._locale&&e._locale._abbr&&(e=e._locale._abbr),!e)return or;if(!o(e)){if(t=pr(e))return t;e=[e]}return dr(e)}function vr(){return T(sr)}function xr(e){var t,r=e._a;return r&&-2===g(e).overflow&&(t=r[Fe]<0||r[Fe]>11?Fe:r[Ne]<1||r[Ne]>rt(r[je],r[Fe])?Ne:r[Be]<0||r[Be]>24||24===r[Be]&&(0!==r[Ve]||0!==r[Ue]||0!==r[He])?Be:r[Ve]<0||r[Ve]>59?Ve:r[Ue]<0||r[Ue]>59?Ue:r[He]<0||r[He]>999?He:-1,g(e)._overflowDayOfYear&&(tNe)&&(t=Ne),g(e)._overflowWeeks&&-1===t&&(t=$e),g(e)._overflowWeekday&&-1===t&&(t=We),g(e).overflow=t),e}var br=/^\s*((?:[+-]\d{6}|\d{4})-(?:\d\d-\d\d|W\d\d-\d|W\d\d|\d\d\d|\d\d))(?:(T| )(\d\d(?::\d\d(?::\d\d(?:[.,]\d+)?)?)?)([+-]\d\d(?::?\d\d)?|\s*Z)?)?$/,_r=/^\s*((?:[+-]\d{6}|\d{4})(?:\d\d\d\d|W\d\d\d|W\d\d|\d\d\d|\d\d|))(?:(T| )(\d\d(?:\d\d(?:\d\d(?:[.,]\d+)?)?)?)([+-]\d\d(?::?\d\d)?|\s*Z)?)?$/,wr=/Z|[+-]\d\d(?::?\d\d)?/,kr=[["YYYYYY-MM-DD",/[+-]\d{6}-\d\d-\d\d/],["YYYY-MM-DD",/\d{4}-\d\d-\d\d/],["GGGG-[W]WW-E",/\d{4}-W\d\d-\d/],["GGGG-[W]WW",/\d{4}-W\d\d/,!1],["YYYY-DDD",/\d{4}-\d{3}/],["YYYY-MM",/\d{4}-\d\d/,!1],["YYYYYYMMDD",/[+-]\d{10}/],["YYYYMMDD",/\d{8}/],["GGGG[W]WWE",/\d{4}W\d{3}/],["GGGG[W]WW",/\d{4}W\d{2}/,!1],["YYYYDDD",/\d{7}/],["YYYYMM",/\d{6}/,!1],["YYYY",/\d{4}/,!1]],Sr=[["HH:mm:ss.SSSS",/\d\d:\d\d:\d\d\.\d+/],["HH:mm:ss,SSSS",/\d\d:\d\d:\d\d,\d+/],["HH:mm:ss",/\d\d:\d\d:\d\d/],["HH:mm",/\d\d:\d\d/],["HHmmss.SSSS",/\d\d\d\d\d\d\.\d+/],["HHmmss,SSSS",/\d\d\d\d\d\d,\d+/],["HHmmss",/\d\d\d\d\d\d/],["HHmm",/\d\d\d\d/],["HH",/\d\d/]],Ar=/^\/?Date\((-?\d+)/i,Tr=/^(?:(Mon|Tue|Wed|Thu|Fri|Sat|Sun),?\s)?(\d{1,2})\s(Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)\s(\d{2,4})\s(\d\d):(\d\d)(?::(\d\d))?\s(?:(UT|GMT|[ECMP][SD]T)|([Zz])|([+-]\d{4}))$/,Mr={UT:0,GMT:0,EDT:-240,EST:-300,CDT:-300,CST:-360,MDT:-360,MST:-420,PDT:-420,PST:-480};function Cr(e){var t,r,n,i,o,a,s=e._i,l=br.exec(s)||_r.exec(s),c=kr.length,u=Sr.length;if(l){for(g(e).iso=!0,t=0,r=c;tqe(o)||0===e._dayOfYear)&&(g(e)._overflowDayOfYear=!0),r=xt(o,0,e._dayOfYear),e._a[Fe]=r.getUTCMonth(),e._a[Ne]=r.getUTCDate()),t=0;t<3&&null==e._a[t];++t)e._a[t]=a[t]=n[t];for(;t<7;t++)e._a[t]=a[t]=null==e._a[t]?2===t?1:0:e._a[t];24===e._a[Be]&&0===e._a[Ve]&&0===e._a[Ue]&&0===e._a[He]&&(e._nextDay=!0,e._a[Be]=0),e._d=(e._useUTC?xt:vt).apply(null,a),i=e._useUTC?e._d.getUTCDay():e._d.getDay(),null!=e._tzm&&e._d.setUTCMinutes(e._d.getUTCMinutes()-e._tzm),e._nextDay&&(e._a[Be]=24),e._w&&"undefined"!==typeof e._w.d&&e._w.d!==i&&(g(e).weekdayMismatch=!0)}}function Nr(e){var t,r,n,i,o,a,s,l,c;null!=(t=e._w).GG||null!=t.W||null!=t.E?(o=1,a=4,r=zr(t.GG,e._a[je],wt(Yr(),1,4).year),n=zr(t.W,1),((i=zr(t.E,1))<1||i>7)&&(l=!0)):(o=e._locale._week.dow,a=e._locale._week.doy,c=wt(Yr(),o,a),r=zr(t.gg,e._a[je],c.year),n=zr(t.w,c.week),null!=t.d?((i=t.d)<0||i>6)&&(l=!0):null!=t.e?(i=t.e+o,(t.e<0||t.e>6)&&(l=!0)):i=o),n<1||n>kt(r,o,a)?g(e)._overflowWeeks=!0:null!=l?g(e)._overflowWeekday=!0:(s=_t(r,n,i,o,a),e._a[je]=s.year,e._dayOfYear=s.dayOfYear)}function Br(e){if(e._f!==n.ISO_8601)if(e._f!==n.RFC_2822){e._a=[],g(e).empty=!0;var t,r,i,o,a,s,l,c=""+e._i,u=c.length,d=0;for(l=(i=$(e._f,e._locale).match(z)||[]).length,t=0;t0&&g(e).unusedInput.push(a),c=c.slice(c.indexOf(r)+r.length),d+=r.length),N[o]?(r?g(e).empty=!1:g(e).unusedTokens.push(o),De(o,r,e)):e._strict&&!r&&g(e).unusedTokens.push(o);g(e).charsLeftOver=u-d,c.length>0&&g(e).unusedInput.push(c),e._a[Be]<=12&&!0===g(e).bigHour&&e._a[Be]>0&&(g(e).bigHour=void 0),g(e).parsedDateParts=e._a.slice(0),g(e).meridiem=e._meridiem,e._a[Be]=Vr(e._locale,e._a[Be],e._meridiem),null!==(s=g(e).era)&&(e._a[je]=e._locale.erasConvertYear(s,e._a[je])),Fr(e),xr(e)}else Lr(e);else Cr(e)}function Vr(e,t,r){var n;return null==r?t:null!=e.meridiemHour?e.meridiemHour(t,r):null!=e.isPM?((n=e.isPM(r))&&t<12&&(t+=12),n||12!==t||(t=0),t):t}function Ur(e){var t,r,n,i,o,a,s=!1,l=e._f.length;if(0===l)return g(e).invalidFormat=!0,void(e._d=new Date(NaN));for(i=0;ithis?this:e:v()}));function Kr(e,t){var r,n;if(1===t.length&&o(t[0])&&(t=t[0]),!t.length)return Yr();for(r=t[0],n=1;nthis.clone().month(0).utcOffset()||this.utcOffset()>this.clone().month(5).utcOffset()}function wn(){if(!c(this._isDSTShifted))return this._isDSTShifted;var e,t={};return _(t,this),(t=Wr(t))._a?(e=t._isUTC?f(t._a):Yr(t._a),this._isDSTShifted=this.isValid()&&cn(t._a,e.toArray())>0):this._isDSTShifted=!1,this._isDSTShifted}function kn(){return!!this.isValid()&&!this._isUTC}function Sn(){return!!this.isValid()&&this._isUTC}function An(){return!!this.isValid()&&this._isUTC&&0===this._offset}n.updateOffset=function(){};var Tn=/^(-|\+)?(?:(\d*)[. ])?(\d+):(\d+)(?::(\d+)(\.\d*)?)?$/,Mn=/^(-|\+)?P(?:([-+]?[0-9,.]*)Y)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)W)?(?:([-+]?[0-9,.]*)D)?(?:T(?:([-+]?[0-9,.]*)H)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)S)?)?$/;function Cn(e,t){var r,n,i,o=e,a=null;return sn(e)?o={ms:e._milliseconds,d:e._days,M:e._months}:u(e)||!isNaN(+e)?(o={},t?o[t]=+e:o.milliseconds=+e):(a=Tn.exec(e))?(r="-"===a[1]?-1:1,o={y:0,d:Pe(a[Ne])*r,h:Pe(a[Be])*r,m:Pe(a[Ve])*r,s:Pe(a[Ue])*r,ms:Pe(ln(1e3*a[He]))*r}):(a=Mn.exec(e))?(r="-"===a[1]?-1:1,o={y:En(a[2],r),M:En(a[3],r),w:En(a[4],r),d:En(a[5],r),h:En(a[6],r),m:En(a[7],r),s:En(a[8],r)}):null==o?o={}:"object"===typeof o&&("from"in o||"to"in o)&&(i=Pn(Yr(o.from),Yr(o.to)),(o={}).ms=i.milliseconds,o.M=i.months),n=new an(o),sn(e)&&s(e,"_locale")&&(n._locale=e._locale),sn(e)&&s(e,"_isValid")&&(n._isValid=e._isValid),n}function En(e,t){var r=e&&parseFloat(e.replace(",","."));return(isNaN(r)?0:r)*t}function In(e,t){var r={};return r.months=t.month()-e.month()+12*(t.year()-e.year()),e.clone().add(r.months,"M").isAfter(t)&&--r.months,r.milliseconds=+t-+e.clone().add(r.months,"M"),r}function Pn(e,t){var r;return e.isValid()&&t.isValid()?(t=pn(t,e),e.isBefore(t)?r=In(e,t):((r=In(t,e)).milliseconds=-r.milliseconds,r.months=-r.months),r):{milliseconds:0,months:0}}function On(e,t){return function(r,n){var i;return null===n||isNaN(+n)||(C(t,"moment()."+t+"(period, number) is deprecated. Please use moment()."+t+"(number, period). See http://momentjs.com/guides/#/warnings/add-inverted-param/ for more info."),i=r,r=n,n=i),Rn(this,Cn(r,n),e),this}}function Rn(e,t,r,i){var o=t._milliseconds,a=ln(t._days),s=ln(t._months);e.isValid()&&(i=null==i||i,s&&ht(e,Ke(e,"Month")+s*r),a&&Je(e,"Date",Ke(e,"Date")+a*r),o&&e._d.setTime(e._d.valueOf()+o*r),i&&n.updateOffset(e,a||s))}Cn.fn=an.prototype,Cn.invalid=on;var Ln=On(1,"add"),Dn=On(-1,"subtract");function zn(e){return"string"===typeof e||e instanceof String}function jn(e){return k(e)||d(e)||zn(e)||u(e)||Nn(e)||Fn(e)||null===e||void 0===e}function Fn(e){var t,r,n=a(e)&&!l(e),i=!1,o=["years","year","y","months","month","M","days","day","d","dates","date","D","hours","hour","h","minutes","minute","m","seconds","second","s","milliseconds","millisecond","ms"],c=o.length;for(t=0;tr.valueOf():r.valueOf()9999?H(r,t?"YYYYYY-MM-DD[T]HH:mm:ss.SSS[Z]":"YYYYYY-MM-DD[T]HH:mm:ss.SSSZ"):E(Date.prototype.toISOString)?t?this.toDate().toISOString():new Date(this.valueOf()+60*this.utcOffset()*1e3).toISOString().replace("Z",H(r,"Z")):H(r,t?"YYYY-MM-DD[T]HH:mm:ss.SSS[Z]":"YYYY-MM-DD[T]HH:mm:ss.SSSZ")}function ei(){if(!this.isValid())return"moment.invalid(/* "+this._i+" */)";var e,t,r,n,i="moment",o="";return this.isLocal()||(i=0===this.utcOffset()?"moment.utc":"moment.parseZone",o="Z"),e="["+i+'("]',t=0<=this.year()&&this.year()<=9999?"YYYY":"YYYYYY",r="-MM-DD[T]HH:mm:ss.SSS",n=o+'[")]',this.format(e+t+r+n)}function ti(e){e||(e=this.isUtc()?n.defaultFormatUtc:n.defaultFormat);var t=H(this,e);return this.localeData().postformat(t)}function ri(e,t){return this.isValid()&&(k(e)&&e.isValid()||Yr(e).isValid())?Cn({to:this,from:e}).locale(this.locale()).humanize(!t):this.localeData().invalidDate()}function ni(e){return this.from(Yr(),e)}function ii(e,t){return this.isValid()&&(k(e)&&e.isValid()||Yr(e).isValid())?Cn({from:this,to:e}).locale(this.locale()).humanize(!t):this.localeData().invalidDate()}function oi(e){return this.to(Yr(),e)}function ai(e){var t;return void 0===e?this._locale._abbr:(null!=(t=yr(e))&&(this._locale=t),this)}n.defaultFormat="YYYY-MM-DDTHH:mm:ssZ",n.defaultFormatUtc="YYYY-MM-DDTHH:mm:ss[Z]";var si=A("moment().lang() is deprecated. Instead, use moment().localeData() to get the language configuration. Use moment().locale() to change languages.",(function(e){return void 0===e?this.localeData():this.locale(e)}));function li(){return this._locale}var ci=1e3,ui=60*ci,di=60*ui,hi=3506328*di;function pi(e,t){return(e%t+t)%t}function fi(e,t,r){return e<100&&e>=0?new Date(e+400,t,r)-hi:new Date(e,t,r).valueOf()}function mi(e,t,r){return e<100&&e>=0?Date.UTC(e+400,t,r)-hi:Date.UTC(e,t,r)}function gi(e){var t,r;if(void 0===(e=re(e))||"millisecond"===e||!this.isValid())return this;switch(r=this._isUTC?mi:fi,e){case"year":t=r(this.year(),0,1);break;case"quarter":t=r(this.year(),this.month()-this.month()%3,1);break;case"month":t=r(this.year(),this.month(),1);break;case"week":t=r(this.year(),this.month(),this.date()-this.weekday());break;case"isoWeek":t=r(this.year(),this.month(),this.date()-(this.isoWeekday()-1));break;case"day":case"date":t=r(this.year(),this.month(),this.date());break;case"hour":t=this._d.valueOf(),t-=pi(t+(this._isUTC?0:this.utcOffset()*ui),di);break;case"minute":t=this._d.valueOf(),t-=pi(t,ui);break;case"second":t=this._d.valueOf(),t-=pi(t,ci)}return this._d.setTime(t),n.updateOffset(this,!0),this}function yi(e){var t,r;if(void 0===(e=re(e))||"millisecond"===e||!this.isValid())return this;switch(r=this._isUTC?mi:fi,e){case"year":t=r(this.year()+1,0,1)-1;break;case"quarter":t=r(this.year(),this.month()-this.month()%3+3,1)-1;break;case"month":t=r(this.year(),this.month()+1,1)-1;break;case"week":t=r(this.year(),this.month(),this.date()-this.weekday()+7)-1;break;case"isoWeek":t=r(this.year(),this.month(),this.date()-(this.isoWeekday()-1)+7)-1;break;case"day":case"date":t=r(this.year(),this.month(),this.date()+1)-1;break;case"hour":t=this._d.valueOf(),t+=di-pi(t+(this._isUTC?0:this.utcOffset()*ui),di)-1;break;case"minute":t=this._d.valueOf(),t+=ui-pi(t,ui)-1;break;case"second":t=this._d.valueOf(),t+=ci-pi(t,ci)-1}return this._d.setTime(t),n.updateOffset(this,!0),this}function vi(){return this._d.valueOf()-6e4*(this._offset||0)}function xi(){return Math.floor(this.valueOf()/1e3)}function bi(){return new Date(this.valueOf())}function _i(){var e=this;return[e.year(),e.month(),e.date(),e.hour(),e.minute(),e.second(),e.millisecond()]}function wi(){var e=this;return{years:e.year(),months:e.month(),date:e.date(),hours:e.hours(),minutes:e.minutes(),seconds:e.seconds(),milliseconds:e.milliseconds()}}function ki(){return this.isValid()?this.toISOString():null}function Si(){return y(this)}function Ai(){return p({},g(this))}function Ti(){return g(this).overflow}function Mi(){return{input:this._i,format:this._f,locale:this._locale,isUTC:this._isUTC,strict:this._strict}}function Ci(e,t){var r,i,o,a=this._eras||yr("en")._eras;for(r=0,i=a.length;r=0)return l[n]}function Ii(e,t){var r=e.since<=e.until?1:-1;return void 0===t?n(e.since).year():n(e.since).year()+(t-e.offset)*r}function Pi(){var e,t,r,n=this.localeData().eras();for(e=0,t=n.length;e(o=kt(e,n,i))&&(t=o),Ki.call(this,e,t,r,n,i))}function Ki(e,t,r,n,i){var o=_t(e,t,r,n,i),a=xt(o.year,0,o.dayOfYear);return this.year(a.getUTCFullYear()),this.month(a.getUTCMonth()),this.date(a.getUTCDate()),this}function Ji(e){return null==e?Math.ceil((this.month()+1)/3):this.month(3*(e-1)+this.month()%3)}B("N",0,0,"eraAbbr"),B("NN",0,0,"eraAbbr"),B("NNN",0,0,"eraAbbr"),B("NNNN",0,0,"eraName"),B("NNNNN",0,0,"eraNarrow"),B("y",["y",1],"yo","eraYear"),B("y",["yy",2],0,"eraYear"),B("y",["yyy",3],0,"eraYear"),B("y",["yyyy",4],0,"eraYear"),Te("N",Fi),Te("NN",Fi),Te("NNN",Fi),Te("NNNN",Ni),Te("NNNNN",Bi),Re(["N","NN","NNN","NNNN","NNNNN"],(function(e,t,r,n){var i=r._locale.erasParse(e,n,r._strict);i?g(r).era=i:g(r).invalidEra=e})),Te("y",ve),Te("yy",ve),Te("yyy",ve),Te("yyyy",ve),Te("yo",Vi),Re(["y","yy","yyy","yyyy"],je),Re(["yo"],(function(e,t,r,n){var i;r._locale._eraYearOrdinalRegex&&(i=e.match(r._locale._eraYearOrdinalRegex)),r._locale.eraYearOrdinalParse?t[je]=r._locale.eraYearOrdinalParse(e,i):t[je]=parseInt(e,10)})),B(0,["gg",2],0,(function(){return this.weekYear()%100})),B(0,["GG",2],0,(function(){return this.isoWeekYear()%100})),Hi("gggg","weekYear"),Hi("ggggg","weekYear"),Hi("GGGG","isoWeekYear"),Hi("GGGGG","isoWeekYear"),Te("G",xe),Te("g",xe),Te("GG",he,le),Te("gg",he,le),Te("GGGG",ge,ue),Te("gggg",ge,ue),Te("GGGGG",ye,de),Te("ggggg",ye,de),Le(["gggg","ggggg","GGGG","GGGGG"],(function(e,t,r,n){t[n.substr(0,2)]=Pe(e)})),Le(["gg","GG"],(function(e,t,r,i){t[i]=n.parseTwoDigitYear(e)})),B("Q",0,"Qo","quarter"),Te("Q",se),Re("Q",(function(e,t){t[Fe]=3*(Pe(e)-1)})),B("D",["DD",2],"Do","date"),Te("D",he,Se),Te("DD",he,le),Te("Do",(function(e,t){return e?t._dayOfMonthOrdinalParse||t._ordinalParse:t._dayOfMonthOrdinalParseLenient})),Re(["D","DD"],Ne),Re("Do",(function(e,t){t[Ne]=Pe(e.match(he)[0])}));var Qi=Ze("Date",!0);function eo(e){var t=Math.round((this.clone().startOf("day")-this.clone().startOf("year"))/864e5)+1;return null==e?t:this.add(e-t,"d")}B("DDD",["DDDD",3],"DDDo","dayOfYear"),Te("DDD",me),Te("DDDD",ce),Re(["DDD","DDDD"],(function(e,t,r){r._dayOfYear=Pe(e)})),B("m",["mm",2],0,"minute"),Te("m",he,Ae),Te("mm",he,le),Re(["m","mm"],Ve);var to=Ze("Minutes",!1);B("s",["ss",2],0,"second"),Te("s",he,Ae),Te("ss",he,le),Re(["s","ss"],Ue);var ro,no,io=Ze("Seconds",!1);for(B("S",0,0,(function(){return~~(this.millisecond()/100)})),B(0,["SS",2],0,(function(){return~~(this.millisecond()/10)})),B(0,["SSS",3],0,"millisecond"),B(0,["SSSS",4],0,(function(){return 10*this.millisecond()})),B(0,["SSSSS",5],0,(function(){return 100*this.millisecond()})),B(0,["SSSSSS",6],0,(function(){return 1e3*this.millisecond()})),B(0,["SSSSSSS",7],0,(function(){return 1e4*this.millisecond()})),B(0,["SSSSSSSS",8],0,(function(){return 1e5*this.millisecond()})),B(0,["SSSSSSSSS",9],0,(function(){return 1e6*this.millisecond()})),Te("S",me,se),Te("SS",me,le),Te("SSS",me,ce),ro="SSSS";ro.length<=9;ro+="S")Te(ro,ve);function oo(e,t){t[He]=Pe(1e3*("0."+e))}for(ro="S";ro.length<=9;ro+="S")Re(ro,oo);function ao(){return this._isUTC?"UTC":""}function so(){return this._isUTC?"Coordinated Universal Time":""}no=Ze("Milliseconds",!1),B("z",0,0,"zoneAbbr"),B("zz",0,0,"zoneName");var lo=w.prototype;function co(e){return Yr(1e3*e)}function uo(){return Yr.apply(null,arguments).parseZone()}function ho(e){return e}lo.add=Ln,lo.calendar=Un,lo.clone=Hn,lo.diff=Zn,lo.endOf=yi,lo.format=ti,lo.from=ri,lo.fromNow=ni,lo.to=ii,lo.toNow=oi,lo.get=Qe,lo.invalidAt=Ti,lo.isAfter=$n,lo.isBefore=Wn,lo.isBetween=qn,lo.isSame=Gn,lo.isSameOrAfter=Yn,lo.isSameOrBefore=Xn,lo.isValid=Si,lo.lang=si,lo.locale=ai,lo.localeData=li,lo.max=Zr,lo.min=Xr,lo.parsingFlags=Ai,lo.set=et,lo.startOf=gi,lo.subtract=Dn,lo.toArray=_i,lo.toObject=wi,lo.toDate=bi,lo.toISOString=Qn,lo.inspect=ei,"undefined"!==typeof Symbol&&null!=Symbol.for&&(lo[Symbol.for("nodejs.util.inspect.custom")]=function(){return"Moment<"+this.format()+">"}),lo.toJSON=ki,lo.toString=Jn,lo.unix=xi,lo.valueOf=vi,lo.creationData=Mi,lo.eraName=Pi,lo.eraNarrow=Oi,lo.eraAbbr=Ri,lo.eraYear=Li,lo.year=Ye,lo.isLeapYear=Xe,lo.weekYear=$i,lo.isoWeekYear=Wi,lo.quarter=lo.quarters=Ji,lo.month=pt,lo.daysInMonth=ft,lo.week=lo.weeks=Ct,lo.isoWeek=lo.isoWeeks=Et,lo.weeksInYear=Yi,lo.weeksInWeekYear=Xi,lo.isoWeeksInYear=qi,lo.isoWeeksInISOWeekYear=Gi,lo.date=Qi,lo.day=lo.days=$t,lo.weekday=Wt,lo.isoWeekday=qt,lo.dayOfYear=eo,lo.hour=lo.hours=nr,lo.minute=lo.minutes=to,lo.second=lo.seconds=io,lo.millisecond=lo.milliseconds=no,lo.utcOffset=mn,lo.utc=yn,lo.local=vn,lo.parseZone=xn,lo.hasAlignedHourOffset=bn,lo.isDST=_n,lo.isLocal=kn,lo.isUtcOffset=Sn,lo.isUtc=An,lo.isUTC=An,lo.zoneAbbr=ao,lo.zoneName=so,lo.dates=A("dates accessor is deprecated. Use date instead.",Qi),lo.months=A("months accessor is deprecated. Use month instead",pt),lo.years=A("years accessor is deprecated. Use year instead",Ye),lo.zone=A("moment().zone is deprecated, use moment().utcOffset instead. http://momentjs.com/guides/#/warnings/zone/",gn),lo.isDSTShifted=A("isDSTShifted is deprecated. See http://momentjs.com/guides/#/warnings/dst-shifted/ for more information",wn);var po=O.prototype;function fo(e,t,r,n){var i=yr(),o=f().set(n,t);return i[r](o,e)}function mo(e,t,r){if(u(e)&&(t=e,e=void 0),e=e||"",null!=t)return fo(e,t,r,"month");var n,i=[];for(n=0;n<12;n++)i[n]=fo(e,n,r,"month");return i}function go(e,t,r,n){"boolean"===typeof e?(u(t)&&(r=t,t=void 0),t=t||""):(r=t=e,e=!1,u(t)&&(r=t,t=void 0),t=t||"");var i,o=yr(),a=e?o._week.dow:0,s=[];if(null!=r)return fo(t,(r+a)%7,n,"day");for(i=0;i<7;i++)s[i]=fo(t,(i+a)%7,n,"day");return s}function yo(e,t){return mo(e,t,"months")}function vo(e,t){return mo(e,t,"monthsShort")}function xo(e,t,r){return go(e,t,r,"weekdays")}function bo(e,t,r){return go(e,t,r,"weekdaysShort")}function _o(e,t,r){return go(e,t,r,"weekdaysMin")}po.calendar=L,po.longDateFormat=q,po.invalidDate=Y,po.ordinal=K,po.preparse=ho,po.postformat=ho,po.relativeTime=Q,po.pastFuture=ee,po.set=I,po.eras=Ci,po.erasParse=Ei,po.erasConvertYear=Ii,po.erasAbbrRegex=zi,po.erasNameRegex=Di,po.erasNarrowRegex=ji,po.months=lt,po.monthsShort=ct,po.monthsParse=dt,po.monthsRegex=gt,po.monthsShortRegex=mt,po.week=St,po.firstDayOfYear=Mt,po.firstDayOfWeek=Tt,po.weekdays=Nt,po.weekdaysMin=Vt,po.weekdaysShort=Bt,po.weekdaysParse=Ht,po.weekdaysRegex=Gt,po.weekdaysShortRegex=Yt,po.weekdaysMinRegex=Xt,po.isPM=tr,po.meridiem=ir,fr("en",{eras:[{since:"0001-01-01",until:1/0,offset:1,name:"Anno Domini",narrow:"AD",abbr:"AD"},{since:"0000-12-31",until:-1/0,offset:1,name:"Before Christ",narrow:"BC",abbr:"BC"}],dayOfMonthOrdinalParse:/\d{1,2}(th|st|nd|rd)/,ordinal:function(e){var t=e%10;return e+(1===Pe(e%100/10)?"th":1===t?"st":2===t?"nd":3===t?"rd":"th")}}),n.lang=A("moment.lang is deprecated. Use moment.locale instead.",fr),n.langData=A("moment.langData is deprecated. Use moment.localeData instead.",yr);var wo=Math.abs;function ko(){var e=this._data;return this._milliseconds=wo(this._milliseconds),this._days=wo(this._days),this._months=wo(this._months),e.milliseconds=wo(e.milliseconds),e.seconds=wo(e.seconds),e.minutes=wo(e.minutes),e.hours=wo(e.hours),e.months=wo(e.months),e.years=wo(e.years),this}function So(e,t,r,n){var i=Cn(t,r);return e._milliseconds+=n*i._milliseconds,e._days+=n*i._days,e._months+=n*i._months,e._bubble()}function Ao(e,t){return So(this,e,t,1)}function To(e,t){return So(this,e,t,-1)}function Mo(e){return e<0?Math.floor(e):Math.ceil(e)}function Co(){var e,t,r,n,i,o=this._milliseconds,a=this._days,s=this._months,l=this._data;return o>=0&&a>=0&&s>=0||o<=0&&a<=0&&s<=0||(o+=864e5*Mo(Io(s)+a),a=0,s=0),l.milliseconds=o%1e3,e=Ie(o/1e3),l.seconds=e%60,t=Ie(e/60),l.minutes=t%60,r=Ie(t/60),l.hours=r%24,a+=Ie(r/24),s+=i=Ie(Eo(a)),a-=Mo(Io(i)),n=Ie(s/12),s%=12,l.days=a,l.months=s,l.years=n,this}function Eo(e){return 4800*e/146097}function Io(e){return 146097*e/4800}function Po(e){if(!this.isValid())return NaN;var t,r,n=this._milliseconds;if("month"===(e=re(e))||"quarter"===e||"year"===e)switch(t=this._days+n/864e5,r=this._months+Eo(t),e){case"month":return r;case"quarter":return r/3;case"year":return r/12}else switch(t=this._days+Math.round(Io(this._months)),e){case"week":return t/7+n/6048e5;case"day":return t+n/864e5;case"hour":return 24*t+n/36e5;case"minute":return 1440*t+n/6e4;case"second":return 86400*t+n/1e3;case"millisecond":return Math.floor(864e5*t)+n;default:throw new Error("Unknown unit "+e)}}function Oo(e){return function(){return this.as(e)}}var Ro=Oo("ms"),Lo=Oo("s"),Do=Oo("m"),zo=Oo("h"),jo=Oo("d"),Fo=Oo("w"),No=Oo("M"),Bo=Oo("Q"),Vo=Oo("y"),Uo=Ro;function Ho(){return Cn(this)}function $o(e){return e=re(e),this.isValid()?this[e+"s"]():NaN}function Wo(e){return function(){return this.isValid()?this._data[e]:NaN}}var qo=Wo("milliseconds"),Go=Wo("seconds"),Yo=Wo("minutes"),Xo=Wo("hours"),Zo=Wo("days"),Ko=Wo("months"),Jo=Wo("years");function Qo(){return Ie(this.days()/7)}var ea=Math.round,ta={ss:44,s:45,m:45,h:22,d:26,w:null,M:11};function ra(e,t,r,n,i){return i.relativeTime(t||1,!!r,e,n)}function na(e,t,r,n){var i=Cn(e).abs(),o=ea(i.as("s")),a=ea(i.as("m")),s=ea(i.as("h")),l=ea(i.as("d")),c=ea(i.as("M")),u=ea(i.as("w")),d=ea(i.as("y")),h=o<=r.ss&&["s",o]||o0,h[4]=n,ra.apply(null,h)}function ia(e){return void 0===e?ea:"function"===typeof e&&(ea=e,!0)}function oa(e,t){return void 0!==ta[e]&&(void 0===t?ta[e]:(ta[e]=t,"s"===e&&(ta.ss=t-1),!0))}function aa(e,t){if(!this.isValid())return this.localeData().invalidDate();var r,n,i=!1,o=ta;return"object"===typeof e&&(t=e,e=!1),"boolean"===typeof e&&(i=e),"object"===typeof t&&(o=Object.assign({},ta,t),null!=t.s&&null==t.ss&&(o.ss=t.s-1)),n=na(this,!i,o,r=this.localeData()),i&&(n=r.pastFuture(+this,n)),r.postformat(n)}var sa=Math.abs;function la(e){return(e>0)-(e<0)||+e}function ca(){if(!this.isValid())return this.localeData().invalidDate();var e,t,r,n,i,o,a,s,l=sa(this._milliseconds)/1e3,c=sa(this._days),u=sa(this._months),d=this.asSeconds();return d?(e=Ie(l/60),t=Ie(e/60),l%=60,e%=60,r=Ie(u/12),u%=12,n=l?l.toFixed(3).replace(/\.?0+$/,""):"",i=d<0?"-":"",o=la(this._months)!==la(d)?"-":"",a=la(this._days)!==la(d)?"-":"",s=la(this._milliseconds)!==la(d)?"-":"",i+"P"+(r?o+r+"Y":"")+(u?o+u+"M":"")+(c?a+c+"D":"")+(t||e||l?"T":"")+(t?s+t+"H":"")+(e?s+e+"M":"")+(l?s+n+"S":"")):"P0D"}var ua=an.prototype;return ua.isValid=nn,ua.abs=ko,ua.add=Ao,ua.subtract=To,ua.as=Po,ua.asMilliseconds=Ro,ua.asSeconds=Lo,ua.asMinutes=Do,ua.asHours=zo,ua.asDays=jo,ua.asWeeks=Fo,ua.asMonths=No,ua.asQuarters=Bo,ua.asYears=Vo,ua.valueOf=Uo,ua._bubble=Co,ua.clone=Ho,ua.get=$o,ua.milliseconds=qo,ua.seconds=Go,ua.minutes=Yo,ua.hours=Xo,ua.days=Zo,ua.weeks=Qo,ua.months=Ko,ua.years=Jo,ua.humanize=aa,ua.toISOString=ca,ua.toString=ca,ua.toJSON=ca,ua.locale=ai,ua.localeData=li,ua.toIsoString=A("toIsoString() is deprecated. Please use toISOString() instead (notice the capitals)",ca),ua.lang=si,B("X",0,0,"unix"),B("x",0,0,"valueOf"),Te("x",xe),Te("X",we),Re("X",(function(e,t,r){r._d=new Date(1e3*parseFloat(e))})),Re("x",(function(e,t,r){r._d=new Date(Pe(e))})),n.version="2.30.1",i(Yr),n.fn=lo,n.min=Jr,n.max=Qr,n.now=en,n.utc=f,n.unix=co,n.months=yo,n.isDate=d,n.locale=fr,n.invalid=v,n.duration=Cn,n.isMoment=k,n.weekdays=xo,n.parseZone=uo,n.localeData=yr,n.isDuration=sn,n.monthsShort=vo,n.weekdaysMin=_o,n.defineLocale=mr,n.updateLocale=gr,n.locales=vr,n.weekdaysShort=bo,n.normalizeUnits=re,n.relativeTimeRounding=ia,n.relativeTimeThreshold=oa,n.calendarFormat=Vn,n.prototype=lo,n.HTML5_FMT={DATETIME_LOCAL:"YYYY-MM-DDTHH:mm",DATETIME_LOCAL_SECONDS:"YYYY-MM-DDTHH:mm:ss",DATETIME_LOCAL_MS:"YYYY-MM-DDTHH:mm:ss.SSS",DATE:"YYYY-MM-DD",TIME:"HH:mm",TIME_SECONDS:"HH:mm:ss",TIME_MS:"HH:mm:ss.SSS",WEEK:"GGGG-[W]WW",MONTH:"YYYY-MM"},n}()},96797:(e,t,r)=>{"use strict";e.exports=function(e,t){t||(t=e,e=window);var r=0,i=0,o=0,a={shift:!1,alt:!1,control:!1,meta:!1},s=!1;function l(e){var t=!1;return"altKey"in e&&(t=t||e.altKey!==a.alt,a.alt=!!e.altKey),"shiftKey"in e&&(t=t||e.shiftKey!==a.shift,a.shift=!!e.shiftKey),"ctrlKey"in e&&(t=t||e.ctrlKey!==a.control,a.control=!!e.ctrlKey),"metaKey"in e&&(t=t||e.metaKey!==a.meta,a.meta=!!e.metaKey),t}function c(e,s){var c=n.x(s),u=n.y(s);"buttons"in s&&(e=0|s.buttons),(e!==r||c!==i||u!==o||l(s))&&(r=0|e,i=c||0,o=u||0,t&&t(r,i,o,a))}function u(e){c(0,e)}function d(){(r||i||o||a.shift||a.alt||a.meta||a.control)&&(i=o=0,r=0,a.shift=a.alt=a.control=a.meta=!1,t&&t(0,0,0,a))}function h(e){l(e)&&t&&t(r,i,o,a)}function p(e){0===n.buttons(e)?c(0,e):c(r,e)}function f(e){c(r|n.buttons(e),e)}function m(e){c(r&~n.buttons(e),e)}function g(){s||(s=!0,e.addEventListener("mousemove",p),e.addEventListener("mousedown",f),e.addEventListener("mouseup",m),e.addEventListener("mouseleave",u),e.addEventListener("mouseenter",u),e.addEventListener("mouseout",u),e.addEventListener("mouseover",u),e.addEventListener("blur",d),e.addEventListener("keyup",h),e.addEventListener("keydown",h),e.addEventListener("keypress",h),e!==window&&(window.addEventListener("blur",d),window.addEventListener("keyup",h),window.addEventListener("keydown",h),window.addEventListener("keypress",h)))}g();var y={element:e};return Object.defineProperties(y,{enabled:{get:function(){return s},set:function(t){t?g():function(){if(!s)return;s=!1,e.removeEventListener("mousemove",p),e.removeEventListener("mousedown",f),e.removeEventListener("mouseup",m),e.removeEventListener("mouseleave",u),e.removeEventListener("mouseenter",u),e.removeEventListener("mouseout",u),e.removeEventListener("mouseover",u),e.removeEventListener("blur",d),e.removeEventListener("keyup",h),e.removeEventListener("keydown",h),e.removeEventListener("keypress",h),e!==window&&(window.removeEventListener("blur",d),window.removeEventListener("keyup",h),window.removeEventListener("keydown",h),window.removeEventListener("keypress",h))}()},enumerable:!0},buttons:{get:function(){return r},enumerable:!0},x:{get:function(){return i},enumerable:!0},y:{get:function(){return o},enumerable:!0},mods:{get:function(){return a},enumerable:!0}}),y};var n=r(63001)},58530:e=>{var t={left:0,top:0};e.exports=function(e,r,n){r=r||e.currentTarget||e.srcElement,Array.isArray(n)||(n=[0,0]);var i=e.clientX||0,o=e.clientY||0,a=(s=r,s===window||s===document||s===document.body?t:s.getBoundingClientRect());var s;return n[0]=i-a.left,n[1]=o-a.top,n}},63001:(e,t)=>{"use strict";function r(e){return e.target||e.srcElement||window}t.buttons=function(e){if("object"===typeof e){if("buttons"in e)return e.buttons;if("which"in e){if(2===(t=e.which))return 4;if(3===t)return 2;if(t>0)return 1<=0)return 1<{"use strict";var n=r(77944);e.exports=function(e,t,r){"function"===typeof e&&(r=!!t,t=e,e=window);var i=n("ex",e),o=function(e){r&&e.preventDefault();var n=e.deltaX||0,o=e.deltaY||0,a=e.deltaZ||0,s=1;switch(e.deltaMode){case 1:s=i;break;case 2:s=window.innerHeight}if(o*=s,a*=s,(n*=s)||o||a)return t(n,o,a,e)};return e.addEventListener("wheel",o),o}},1843:function(e,t,r){var n;!function(i,o,a){o[i]=o[i]||a(),e.exports?e.exports=o[i]:void 0===(n=function(){return o[i]}.call(t,r,t,e))||(e.exports=n)}("Promise","undefined"!=typeof r.g?r.g:this,(function(){"use strict";var e,t,r,n=Object.prototype.toString,i="undefined"!=typeof setImmediate?function(e){return setImmediate(e)}:setTimeout;try{Object.defineProperty({},"x",{}),e=function(e,t,r,n){return Object.defineProperty(e,t,{value:r,writable:!0,configurable:!1!==n})}}catch(g){e=function(e,t,r){return e[t]=r,e}}function o(e,n){r.add(e,n),t||(t=i(r.drain))}function a(e){var t,r=typeof e;return null==e||"object"!=r&&"function"!=r||(t=e.then),"function"==typeof t&&t}function s(){for(var e=0;e0&&o(s,r))}catch(g){u.call(new h(r),g)}}}function u(e){var t=this;t.triggered||(t.triggered=!0,t.def&&(t=t.def),t.msg=e,t.state=2,t.chain.length>0&&o(s,t))}function d(e,t,r,n){for(var i=0;i{"use strict";e.exports=function(e){for(var t,r=[],a=0,s=0,l=0,c=0,u=null,d=null,h=0,p=0,f=0,m=e.length;f4?(a=g[g.length-4],s=g[g.length-3]):(a=h,s=p),r.push(g)}return r};var n=r(23314);function i(e,t,r,n){return["C",e,t,r,n,r,n]}function o(e,t,r,n,i,o){return["C",e/3+2/3*r,t/3+2/3*n,i/3+2/3*r,o/3+2/3*n,i,o]}},42123:e=>{"use strict";var t=Object.getOwnPropertySymbols,r=Object.prototype.hasOwnProperty,n=Object.prototype.propertyIsEnumerable;e.exports=function(){try{if(!Object.assign)return!1;var e=new String("abc");if(e[5]="de","5"===Object.getOwnPropertyNames(e)[0])return!1;for(var t={},r=0;r<10;r++)t["_"+String.fromCharCode(r)]=r;if("0123456789"!==Object.getOwnPropertyNames(t).map((function(e){return t[e]})).join(""))return!1;var n={};return"abcdefghijklmnopqrst".split("").forEach((function(e){n[e]=e})),"abcdefghijklmnopqrst"===Object.keys(Object.assign({},n)).join("")}catch(i){return!1}}()?Object.assign:function(e,i){for(var o,a,s=function(e){if(null===e||void 0===e)throw new TypeError("Object.assign cannot be called with null or undefined");return Object(e)}(e),l=1;l{var n="function"===typeof Map&&Map.prototype,i=Object.getOwnPropertyDescriptor&&n?Object.getOwnPropertyDescriptor(Map.prototype,"size"):null,o=n&&i&&"function"===typeof i.get?i.get:null,a=n&&Map.prototype.forEach,s="function"===typeof Set&&Set.prototype,l=Object.getOwnPropertyDescriptor&&s?Object.getOwnPropertyDescriptor(Set.prototype,"size"):null,c=s&&l&&"function"===typeof l.get?l.get:null,u=s&&Set.prototype.forEach,d="function"===typeof WeakMap&&WeakMap.prototype?WeakMap.prototype.has:null,h="function"===typeof WeakSet&&WeakSet.prototype?WeakSet.prototype.has:null,p="function"===typeof WeakRef&&WeakRef.prototype?WeakRef.prototype.deref:null,f=Boolean.prototype.valueOf,m=Object.prototype.toString,g=Function.prototype.toString,y=String.prototype.match,v=String.prototype.slice,x=String.prototype.replace,b=String.prototype.toUpperCase,_=String.prototype.toLowerCase,w=RegExp.prototype.test,k=Array.prototype.concat,S=Array.prototype.join,A=Array.prototype.slice,T=Math.floor,M="function"===typeof BigInt?BigInt.prototype.valueOf:null,C=Object.getOwnPropertySymbols,E="function"===typeof Symbol&&"symbol"===typeof Symbol.iterator?Symbol.prototype.toString:null,I="function"===typeof Symbol&&"object"===typeof Symbol.iterator,P="function"===typeof Symbol&&Symbol.toStringTag&&(typeof Symbol.toStringTag===I||"symbol")?Symbol.toStringTag:null,O=Object.prototype.propertyIsEnumerable,R=("function"===typeof Reflect?Reflect.getPrototypeOf:Object.getPrototypeOf)||([].__proto__===Array.prototype?function(e){return e.__proto__}:null);function L(e,t){if(e===1/0||e===-1/0||e!==e||e&&e>-1e3&&e<1e3||w.call(/e/,t))return t;var r=/[0-9](?=(?:[0-9]{3})+(?![0-9]))/g;if("number"===typeof e){var n=e<0?-T(-e):T(e);if(n!==e){var i=String(n),o=v.call(t,i.length+1);return x.call(i,r,"$&_")+"."+x.call(x.call(o,/([0-9]{3})/g,"$&_"),/_$/,"")}}return x.call(t,r,"$&_")}var D=r(42634),z=D.custom,j=$(z)?z:null,F={__proto__:null,double:'"',single:"'"},N={__proto__:null,double:/(["\\])/g,single:/(['\\])/g};function B(e,t,r){var n=r.quoteStyle||t,i=F[n];return i+e+i}function V(e){return x.call(String(e),/"/g,""")}function U(e){return"[object Array]"===G(e)&&(!P||!("object"===typeof e&&P in e))}function H(e){return"[object RegExp]"===G(e)&&(!P||!("object"===typeof e&&P in e))}function $(e){if(I)return e&&"object"===typeof e&&e instanceof Symbol;if("symbol"===typeof e)return!0;if(!e||"object"!==typeof e||!E)return!1;try{return E.call(e),!0}catch(t){}return!1}e.exports=function e(t,n,i,s){var l=n||{};if(q(l,"quoteStyle")&&!q(F,l.quoteStyle))throw new TypeError('option "quoteStyle" must be "single" or "double"');if(q(l,"maxStringLength")&&("number"===typeof l.maxStringLength?l.maxStringLength<0&&l.maxStringLength!==1/0:null!==l.maxStringLength))throw new TypeError('option "maxStringLength", if provided, must be a positive integer, Infinity, or `null`');var m=!q(l,"customInspect")||l.customInspect;if("boolean"!==typeof m&&"symbol"!==m)throw new TypeError("option \"customInspect\", if provided, must be `true`, `false`, or `'symbol'`");if(q(l,"indent")&&null!==l.indent&&"\t"!==l.indent&&!(parseInt(l.indent,10)===l.indent&&l.indent>0))throw new TypeError('option "indent" must be "\\t", an integer > 0, or `null`');if(q(l,"numericSeparator")&&"boolean"!==typeof l.numericSeparator)throw new TypeError('option "numericSeparator", if provided, must be `true` or `false`');var b=l.numericSeparator;if("undefined"===typeof t)return"undefined";if(null===t)return"null";if("boolean"===typeof t)return t?"true":"false";if("string"===typeof t)return X(t,l);if("number"===typeof t){if(0===t)return 1/0/t>0?"0":"-0";var w=String(t);return b?L(t,w):w}if("bigint"===typeof t){var T=String(t)+"n";return b?L(t,T):T}var C="undefined"===typeof l.depth?5:l.depth;if("undefined"===typeof i&&(i=0),i>=C&&C>0&&"object"===typeof t)return U(t)?"[Array]":"[Object]";var z=function(e,t){var r;if("\t"===e.indent)r="\t";else{if(!("number"===typeof e.indent&&e.indent>0))return null;r=S.call(Array(e.indent+1)," ")}return{base:r,prev:S.call(Array(t+1),r)}}(l,i);if("undefined"===typeof s)s=[];else if(Y(s,t)>=0)return"[Circular]";function N(t,r,n){if(r&&(s=A.call(s)).push(r),n){var o={depth:l.depth};return q(l,"quoteStyle")&&(o.quoteStyle=l.quoteStyle),e(t,o,i+1,s)}return e(t,l,i+1,s)}if("function"===typeof t&&!H(t)){var W=function(e){if(e.name)return e.name;var t=y.call(g.call(e),/^function\s*([\w$]+)/);if(t)return t[1];return null}(t),Z=te(t,N);return"[Function"+(W?": "+W:" (anonymous)")+"]"+(Z.length>0?" { "+S.call(Z,", ")+" }":"")}if($(t)){var re=I?x.call(String(t),/^(Symbol\(.*\))_[^)]*$/,"$1"):E.call(t);return"object"!==typeof t||I?re:K(re)}if(function(e){if(!e||"object"!==typeof e)return!1;if("undefined"!==typeof HTMLElement&&e instanceof HTMLElement)return!0;return"string"===typeof e.nodeName&&"function"===typeof e.getAttribute}(t)){for(var ne="<"+_.call(String(t.nodeName)),ie=t.attributes||[],oe=0;oe"}if(U(t)){if(0===t.length)return"[]";var ae=te(t,N);return z&&!function(e){for(var t=0;t=0)return!1;return!0}(ae)?"["+ee(ae,z)+"]":"[ "+S.call(ae,", ")+" ]"}if(function(e){return"[object Error]"===G(e)&&(!P||!("object"===typeof e&&P in e))}(t)){var se=te(t,N);return"cause"in Error.prototype||!("cause"in t)||O.call(t,"cause")?0===se.length?"["+String(t)+"]":"{ ["+String(t)+"] "+S.call(se,", ")+" }":"{ ["+String(t)+"] "+S.call(k.call("[cause]: "+N(t.cause),se),", ")+" }"}if("object"===typeof t&&m){if(j&&"function"===typeof t[j]&&D)return D(t,{depth:C-i});if("symbol"!==m&&"function"===typeof t.inspect)return t.inspect()}if(function(e){if(!o||!e||"object"!==typeof e)return!1;try{o.call(e);try{c.call(e)}catch(ne){return!0}return e instanceof Map}catch(t){}return!1}(t)){var le=[];return a&&a.call(t,(function(e,r){le.push(N(r,t,!0)+" => "+N(e,t))})),Q("Map",o.call(t),le,z)}if(function(e){if(!c||!e||"object"!==typeof e)return!1;try{c.call(e);try{o.call(e)}catch(t){return!0}return e instanceof Set}catch(r){}return!1}(t)){var ce=[];return u&&u.call(t,(function(e){ce.push(N(e,t))})),Q("Set",c.call(t),ce,z)}if(function(e){if(!d||!e||"object"!==typeof e)return!1;try{d.call(e,d);try{h.call(e,h)}catch(ne){return!0}return e instanceof WeakMap}catch(t){}return!1}(t))return J("WeakMap");if(function(e){if(!h||!e||"object"!==typeof e)return!1;try{h.call(e,h);try{d.call(e,d)}catch(ne){return!0}return e instanceof WeakSet}catch(t){}return!1}(t))return J("WeakSet");if(function(e){if(!p||!e||"object"!==typeof e)return!1;try{return p.call(e),!0}catch(t){}return!1}(t))return J("WeakRef");if(function(e){return"[object Number]"===G(e)&&(!P||!("object"===typeof e&&P in e))}(t))return K(N(Number(t)));if(function(e){if(!e||"object"!==typeof e||!M)return!1;try{return M.call(e),!0}catch(t){}return!1}(t))return K(N(M.call(t)));if(function(e){return"[object Boolean]"===G(e)&&(!P||!("object"===typeof e&&P in e))}(t))return K(f.call(t));if(function(e){return"[object String]"===G(e)&&(!P||!("object"===typeof e&&P in e))}(t))return K(N(String(t)));if("undefined"!==typeof window&&t===window)return"{ [object Window] }";if("undefined"!==typeof globalThis&&t===globalThis||"undefined"!==typeof r.g&&t===r.g)return"{ [object globalThis] }";if(!function(e){return"[object Date]"===G(e)&&(!P||!("object"===typeof e&&P in e))}(t)&&!H(t)){var ue=te(t,N),de=R?R(t)===Object.prototype:t instanceof Object||t.constructor===Object,he=t instanceof Object?"":"null prototype",pe=!de&&P&&Object(t)===t&&P in t?v.call(G(t),8,-1):he?"Object":"",fe=(de||"function"!==typeof t.constructor?"":t.constructor.name?t.constructor.name+" ":"")+(pe||he?"["+S.call(k.call([],pe||[],he||[]),": ")+"] ":"");return 0===ue.length?fe+"{}":z?fe+"{"+ee(ue,z)+"}":fe+"{ "+S.call(ue,", ")+" }"}return String(t)};var W=Object.prototype.hasOwnProperty||function(e){return e in this};function q(e,t){return W.call(e,t)}function G(e){return m.call(e)}function Y(e,t){if(e.indexOf)return e.indexOf(t);for(var r=0,n=e.length;rt.maxStringLength){var r=e.length-t.maxStringLength,n="... "+r+" more character"+(r>1?"s":"");return X(v.call(e,0,t.maxStringLength),t)+n}var i=N[t.quoteStyle||"single"];return i.lastIndex=0,B(x.call(x.call(e,i,"\\$1"),/[\x00-\x1f]/g,Z),"single",t)}function Z(e){var t=e.charCodeAt(0),r={8:"b",9:"t",10:"n",12:"f",13:"r"}[t];return r?"\\"+r:"\\x"+(t<16?"0":"")+b.call(t.toString(16))}function K(e){return"Object("+e+")"}function J(e){return e+" { ? }"}function Q(e,t,r,n){return e+" ("+t+") {"+(n?ee(r,n):S.call(r,", "))+"}"}function ee(e,t){if(0===e.length)return"";var r="\n"+t.prev+t.base;return r+S.call(e,","+r)+"\n"+t.prev}function te(e,t){var r=U(e),n=[];if(r){n.length=e.length;for(var i=0;i{"use strict";var t=function(e){return e!==e};e.exports=function(e,r){return 0===e&&0===r?1/e===1/r:e===r||!(!t(e)||!t(r))}},52702:(e,t,r)=>{"use strict";var n=r(11779),i=r(61712),o=r(57974),a=r(3799),s=r(85289),l=i(a(),Object);n(l,{getPolyfill:a,implementation:o,shim:s}),e.exports=l},3799:(e,t,r)=>{"use strict";var n=r(57974);e.exports=function(){return"function"===typeof Object.is?Object.is:n}},85289:(e,t,r)=>{"use strict";var n=r(3799),i=r(11779);e.exports=function(){var e=n();return i(Object,{is:e},{is:function(){return Object.is!==e}}),e}},21038:(e,t,r)=>{"use strict";var n;if(!Object.keys){var i=Object.prototype.hasOwnProperty,o=Object.prototype.toString,a=r(80234),s=Object.prototype.propertyIsEnumerable,l=!s.call({toString:null},"toString"),c=s.call((function(){}),"prototype"),u=["toString","toLocaleString","valueOf","hasOwnProperty","isPrototypeOf","propertyIsEnumerable","constructor"],d=function(e){var t=e.constructor;return t&&t.prototype===e},h={$applicationCache:!0,$console:!0,$external:!0,$frame:!0,$frameElement:!0,$frames:!0,$innerHeight:!0,$innerWidth:!0,$onmozfullscreenchange:!0,$onmozfullscreenerror:!0,$outerHeight:!0,$outerWidth:!0,$pageXOffset:!0,$pageYOffset:!0,$parent:!0,$scrollLeft:!0,$scrollTop:!0,$scrollX:!0,$scrollY:!0,$self:!0,$webkitIndexedDB:!0,$webkitStorageInfo:!0,$window:!0},p=function(){if("undefined"===typeof window)return!1;for(var e in window)try{if(!h["$"+e]&&i.call(window,e)&&null!==window[e]&&"object"===typeof window[e])try{d(window[e])}catch(t){return!0}}catch(t){return!0}return!1}();n=function(e){var t=null!==e&&"object"===typeof e,r="[object Function]"===o.call(e),n=a(e),s=t&&"[object String]"===o.call(e),h=[];if(!t&&!r&&!n)throw new TypeError("Object.keys called on a non-object");var f=c&&r;if(s&&e.length>0&&!i.call(e,0))for(var m=0;m0)for(var g=0;g{"use strict";var n=Array.prototype.slice,i=r(80234),o=Object.keys,a=o?function(e){return o(e)}:r(21038),s=Object.keys;a.shim=function(){if(Object.keys){var e=function(){var e=Object.keys(arguments);return e&&e.length===arguments.length}(1,2);e||(Object.keys=function(e){return i(e)?s(n.call(e)):s(e)})}else Object.keys=a;return Object.keys||a},e.exports=a},80234:e=>{"use strict";var t=Object.prototype.toString;e.exports=function(e){var r=t.call(e),n="[object Arguments]"===r;return n||(n="[object Array]"!==r&&null!==e&&"object"===typeof e&&"number"===typeof e.length&&e.length>=0&&"[object Function]"===t.call(e.callee)),n}},95590:(e,t,r)=>{"use strict";var n=r(2678),i=r(99534)(),o=r(12028),a=Object,s=o("Array.prototype.push"),l=o("Object.prototype.propertyIsEnumerable"),c=i?Object.getOwnPropertySymbols:null;e.exports=function(e,t){if(null==e)throw new TypeError("target must be an object");var r=a(e);if(1===arguments.length)return r;for(var o=1;o{"use strict";var n=r(95590);e.exports=function(){return Object.assign?function(){if(!Object.assign)return!1;for(var e="abcdefghijklmnopqrst",t=e.split(""),r={},n=0;n{"use strict";function t(e,t){if("string"!==typeof e)return[e];var r=[e];"string"===typeof t||Array.isArray(t)?t={brackets:t}:t||(t={});var n=t.brackets?Array.isArray(t.brackets)?t.brackets:[t.brackets]:["{}","[]","()"],i=t.escape||"___",o=!!t.flat;n.forEach((function(e){var t=new RegExp(["\\",e[0],"[^\\",e[0],"\\",e[1],"]*\\",e[1]].join("")),n=[];function o(t,o,a){var s=r.push(t.slice(e[0].length,-e[1].length))-1;return n.push(s),i+s+i}r.forEach((function(e,n){for(var i,a=0;e!=i;)if(i=e,e=e.replace(t,o),a++>1e4)throw Error("References have circular dependency. Please, check them.");r[n]=e})),n=n.reverse(),r=r.map((function(t){return n.forEach((function(r){t=t.replace(new RegExp("(\\"+i+r+"\\"+i+")","g"),e[0]+"$1"+e[1])})),t}))}));var a=new RegExp("\\"+i+"([0-9]+)\\"+i);return o?r:function e(t,r,n){for(var i,o=[],s=0;i=a.exec(t);){if(s++>1e4)throw Error("Circular references in parenthesis");o.push(t.slice(0,i.index)),o.push(e(r[i[1]],r)),t=t.slice(i.index+i[0].length)}return o.push(t),o}(r[0],r)}function r(e,t){if(t&&t.flat){var r,n=t&&t.escape||"___",i=e[0];if(!i)return"";for(var o=new RegExp("\\"+n+"([0-9]+)\\"+n),a=0;i!=r;){if(a++>1e4)throw Error("Circular references in "+e);r=i,i=i.replace(o,s)}return i}return e.reduce((function e(t,r){return Array.isArray(r)&&(r=r.reduce(e,"")),t+r}),"");function s(t,r){if(null==e[r])throw Error("Reference "+r+"is undefined");return e[r]}}function n(e,n){return Array.isArray(e)?r(e,n):t(e,n)}n.parse=t,n.stringify=r,e.exports=n},72972:(e,t,r)=>{"use strict";var n=r(92472);e.exports=function(e){var t;arguments.length>1&&(e=arguments);"string"===typeof e?e=e.split(/\s/).map(parseFloat):"number"===typeof e&&(e=[e]);e.length&&"number"===typeof e[0]?t=1===e.length?{width:e[0],height:e[0],x:0,y:0}:2===e.length?{width:e[0],height:e[1],x:0,y:0}:{x:e[0],y:e[1],width:e[2]-e[0]||0,height:e[3]-e[1]||0}:e&&(t={x:(e=n(e,{left:"x l left Left",top:"y t top Top",width:"w width W Width",height:"h height W Width",bottom:"b bottom Bottom",right:"r right Right"})).left||0,y:e.top||0},null==e.width?e.right?t.width=e.right-t.x:t.width=0:t.width=e.width,null==e.height?e.bottom?t.height=e.bottom-t.y:t.height=0:t.height=e.height);return t}},24100:e=>{e.exports=function(e){var i=[];return e.replace(r,(function(e,r,o){var a=r.toLowerCase();for(o=function(e){var t=e.match(n);return t?t.map(Number):[]}(o),"m"==a&&o.length>2&&(i.push([r].concat(o.splice(0,2))),a="l",r="m"==r?"l":"L");;){if(o.length==t[a])return o.unshift(r),i.push(o);if(o.length{e.exports=function(e,t){t||(t=[0,""]),e=String(e);var r=parseFloat(e,10);return t[0]=r,t[1]=e.match(/[\d.\-\+]*\s*(.*)/)[1]||"",t}},57588:function(e){(function(){var t,r,n,i,o,a;"undefined"!==typeof performance&&null!==performance&&performance.now?e.exports=function(){return performance.now()}:"undefined"!==typeof process&&null!==process&&process.hrtime?(e.exports=function(){return(t()-o)/1e6},r=process.hrtime,i=(t=function(){var e;return 1e9*(e=r())[0]+e[1]})(),a=1e9*process.uptime(),o=i-a):Date.now?(e.exports=function(){return Date.now()-n},n=Date.now()):(e.exports=function(){return(new Date).getTime()-n},n=(new Date).getTime())}).call(this)},92472:e=>{"use strict";e.exports=function(e,t,n){var i,o,a={};if("string"===typeof t&&(t=r(t)),Array.isArray(t)){var s={};for(o=0;o{"use strict";var n=r(84468),i={"X,X div":'direction:ltr;font-family:"Open Sans",verdana,arial,sans-serif;margin:0;padding:0;',"X input,X button":'font-family:"Open Sans",verdana,arial,sans-serif;',"X input:focus,X button:focus":"outline:none;","X a":"text-decoration:none;","X a:hover":"text-decoration:none;","X .crisp":"shape-rendering:crispEdges;","X .user-select-none":"-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none;","X svg":"overflow:hidden;","X svg a":"fill:#447adb;","X svg a:hover":"fill:#3c6dc5;","X .main-svg":"position:absolute;top:0;left:0;pointer-events:none;","X .main-svg .draglayer":"pointer-events:all;","X .cursor-default":"cursor:default;","X .cursor-pointer":"cursor:pointer;","X .cursor-crosshair":"cursor:crosshair;","X .cursor-move":"cursor:move;","X .cursor-col-resize":"cursor:col-resize;","X .cursor-row-resize":"cursor:row-resize;","X .cursor-ns-resize":"cursor:ns-resize;","X .cursor-ew-resize":"cursor:ew-resize;","X .cursor-sw-resize":"cursor:sw-resize;","X .cursor-s-resize":"cursor:s-resize;","X .cursor-se-resize":"cursor:se-resize;","X .cursor-w-resize":"cursor:w-resize;","X .cursor-e-resize":"cursor:e-resize;","X .cursor-nw-resize":"cursor:nw-resize;","X .cursor-n-resize":"cursor:n-resize;","X .cursor-ne-resize":"cursor:ne-resize;","X .cursor-grab":"cursor:-webkit-grab;cursor:grab;","X .modebar":"position:absolute;top:2px;right:2px;","X .ease-bg":"-webkit-transition:background-color .3s ease 0s;-moz-transition:background-color .3s ease 0s;-ms-transition:background-color .3s ease 0s;-o-transition:background-color .3s ease 0s;transition:background-color .3s ease 0s;","X .modebar--hover>:not(.watermark)":"opacity:0;-webkit-transition:opacity .3s ease 0s;-moz-transition:opacity .3s ease 0s;-ms-transition:opacity .3s ease 0s;-o-transition:opacity .3s ease 0s;transition:opacity .3s ease 0s;","X:hover .modebar--hover .modebar-group":"opacity:1;","X .modebar-group":"float:left;display:inline-block;box-sizing:border-box;padding-left:8px;position:relative;vertical-align:middle;white-space:nowrap;","X .modebar-btn":"position:relative;font-size:16px;padding:3px 4px;height:22px;cursor:pointer;line-height:normal;box-sizing:border-box;","X .modebar-btn svg":"position:relative;top:2px;","X .modebar.vertical":"display:flex;flex-direction:column;flex-wrap:wrap;align-content:flex-end;max-height:100%;","X .modebar.vertical svg":"top:-1px;","X .modebar.vertical .modebar-group":"display:block;float:none;padding-left:0px;padding-bottom:8px;","X .modebar.vertical .modebar-group .modebar-btn":"display:block;text-align:center;","X [data-title]:before,X [data-title]:after":"position:absolute;-webkit-transform:translate3d(0, 0, 0);-moz-transform:translate3d(0, 0, 0);-ms-transform:translate3d(0, 0, 0);-o-transform:translate3d(0, 0, 0);transform:translate3d(0, 0, 0);display:none;opacity:0;z-index:1001;pointer-events:none;top:110%;right:50%;","X [data-title]:hover:before,X [data-title]:hover:after":"display:block;opacity:1;","X [data-title]:before":'content:"";position:absolute;background:rgba(0,0,0,0);border:6px solid rgba(0,0,0,0);z-index:1002;margin-top:-12px;border-bottom-color:#69738a;margin-right:-6px;',"X [data-title]:after":"content:attr(data-title);background:#69738a;color:#fff;padding:8px 10px;font-size:12px;line-height:12px;white-space:nowrap;margin-right:-18px;border-radius:2px;","X .vertical [data-title]:before,X .vertical [data-title]:after":"top:0%;right:200%;","X .vertical [data-title]:before":"border:6px solid rgba(0,0,0,0);border-left-color:#69738a;margin-top:8px;margin-right:-30px;",Y:'font-family:"Open Sans",verdana,arial,sans-serif;position:fixed;top:50px;right:20px;z-index:10000;font-size:10pt;max-width:180px;',"Y p":"margin:0;","Y .notifier-note":"min-width:180px;max-width:250px;border:1px solid #fff;z-index:3000;margin:0;background-color:#8c97af;background-color:rgba(140,151,175,.9);color:#fff;padding:10px;overflow-wrap:break-word;word-wrap:break-word;-ms-hyphens:auto;-webkit-hyphens:auto;hyphens:auto;","Y .notifier-close":"color:#fff;opacity:.8;float:right;padding:0 5px;background:none;border:none;font-size:20px;font-weight:bold;line-height:20px;","Y .notifier-close:hover":"color:#444;text-decoration:none;cursor:pointer;"};for(var o in i){var a=o.replace(/^,/," ,").replace(/X/g,".js-plotly-plot .plotly").replace(/Y/g,".plotly-notifier");n.addStyleRule(a,i[o])}},39746:(e,t,r)=>{"use strict";e.exports=r(2479)},51616:(e,t,r)=>{"use strict";e.exports=r(42541)},54674:(e,t,r)=>{"use strict";e.exports=r(51915)},21868:(e,t,r)=>{"use strict";e.exports=r(99601)},37150:(e,t,r)=>{"use strict";e.exports=r(30781)},52810:(e,t,r)=>{"use strict";e.exports=r(90195)},12406:(e,t,r)=>{"use strict";e.exports=r(57879)},10943:(e,t,r)=>{"use strict";e.exports=r(24226)},86593:(e,t,r)=>{"use strict";e.exports=r(61168)},79256:(e,t,r)=>{"use strict";e.exports=r(7257)},81986:(e,t,r)=>{"use strict";e.exports=r(15863)},29407:(e,t,r)=>{"use strict";e.exports=r(7506)},23520:(e,t,r)=>{"use strict";e.exports=r(12809)},76790:(e,t,r)=>{"use strict";e.exports=r(17521)},86279:(e,t,r)=>{"use strict";e.exports=r(36066)},6378:(e,t,r)=>{"use strict";e.exports=r(583)},59779:(e,t,r)=>{"use strict";e.exports=r(1604)},21101:(e,t,r)=>{"use strict";e.exports=r(67276)},30228:(e,t,r)=>{"use strict";e.exports=r(31189)},24251:(e,t,r)=>{"use strict";e.exports=r(24498)},68261:(e,t,r)=>{"use strict";e.exports=r(91516)},23410:(e,t,r)=>{"use strict";e.exports=r(37995)},75791:(e,t,r)=>{"use strict";e.exports=r(48182)},57913:(e,t,r)=>{"use strict";e.exports=r(78332)},93539:(e,t,r)=>{"use strict";e.exports=r(93350)},73798:(e,t,r)=>{"use strict";e.exports=r(4639)},73124:(e,t,r)=>{"use strict";e.exports=r(14717)},79009:(e,t,r)=>{"use strict";var n=r(76790);n.register([r(51616),r(21868),r(68261),r(75791),r(57913),r(93539),r(29407),r(4968),r(39216),r(21101),r(54287),r(73124),r(22103),r(89301),r(93135),r(73798),r(30228),r(71596),r(49546),r(1233),r(85195),r(28211),r(81986),r(32103),r(4462),r(10943),r(90512),r(54884),r(36758),r(23410),r(91764),r(68595),r(38584),r(79256),r(6378),r(24897),r(86593),r(86279),r(75540),r(39884),r(74353),r(12406),r(67104),r(23520),r(79663),r(52810),r(1291),r(30172),r(54674),r(79912),r(39746),r(59779),r(24251),r(12181),r(37150)]),e.exports=n},39884:(e,t,r)=>{"use strict";e.exports=r(11009)},1233:(e,t,r)=>{"use strict";e.exports=r(56876)},28211:(e,t,r)=>{"use strict";e.exports=r(56902)},79663:(e,t,r)=>{"use strict";e.exports=r(95490)},68595:(e,t,r)=>{"use strict";e.exports=r(17406)},91764:(e,t,r)=>{"use strict";e.exports=r(71049)},22103:(e,t,r)=>{"use strict";e.exports=r(326)},36758:(e,t,r)=>{"use strict";e.exports=r(93975)},75540:(e,t,r)=>{"use strict";e.exports=r(12593)},71596:(e,t,r)=>{"use strict";e.exports=r(31129)},67104:(e,t,r)=>{"use strict";e.exports=r(64649)},4462:(e,t,r)=>{"use strict";e.exports=r(69491)},90512:(e,t,r)=>{"use strict";e.exports=r(97781)},24897:(e,t,r)=>{"use strict";e.exports=r(89779)},38584:(e,t,r)=>{"use strict";e.exports=r(97321)},1291:(e,t,r)=>{"use strict";e.exports=r(54026)},30172:(e,t,r)=>{"use strict";e.exports=r(80477)},79912:(e,t,r)=>{"use strict";e.exports=r(19009)},4968:(e,t,r)=>{"use strict";e.exports=r(2945)},12181:(e,t,r)=>{"use strict";e.exports=r(55242)},54884:(e,t,r)=>{"use strict";e.exports=r(65793)},32103:(e,t,r)=>{"use strict";e.exports=r(23862)},89301:(e,t,r)=>{"use strict";e.exports=r(89004)},49546:(e,t,r)=>{"use strict";e.exports=r(34807)},74353:(e,t,r)=>{"use strict";e.exports=r(70820)},93135:(e,t,r)=>{"use strict";e.exports=r(73578)},39216:(e,t,r)=>{"use strict";e.exports=r(56461)},85195:(e,t,r)=>{"use strict";e.exports=r(34030)},54287:(e,t,r)=>{"use strict";e.exports=r(16954)},49866:(e,t,r)=>{"use strict";var n=r(60894),i=r(9187),o=r(12156);e.exports=function(e,t){"float"!==t&&t||(t="array"),"uint"===t&&(t="uint8"),"uint_clamped"===t&&(t="uint8_clamped");var r=new(o(t))(4),a="uint8"!==t&&"uint8_clamped"!==t;return e.length&&"string"!==typeof e||((e=n(e))[0]/=255,e[1]/=255,e[2]/=255),function(e){return e instanceof Uint8Array||e instanceof Uint8ClampedArray||!!(Array.isArray(e)&&(e[0]>1||0===e[0])&&(e[1]>1||0===e[1])&&(e[2]>1||0===e[2])&&(!e[3]||e[3]>1))}(e)?(r[0]=e[0],r[1]=e[1],r[2]=e[2],r[3]=null!=e[3]?e[3]:255,a&&(r[0]/=255,r[1]/=255,r[2]/=255,r[3]/=255),r):(a?(r[0]=e[0],r[1]=e[1],r[2]=e[2],r[3]=null!=e[3]?e[3]:1):(r[0]=i(Math.floor(255*e[0]),0,255),r[1]=i(Math.floor(255*e[1]),0,255),r[2]=i(Math.floor(255*e[2]),0,255),r[3]=null==e[3]?255:i(Math.floor(255*e[3]),0,255)),r)}},88487:(e,t,r)=>{"use strict";var n=r(38301);e.exports=function(e){var t,r,o=[],a=1;if("string"===typeof e)if(e=e.toLowerCase(),n[e])o=n[e].slice(),r="rgb";else if("transparent"===e)a=0,r="rgb",o=[0,0,0];else if(/^#[A-Fa-f0-9]+$/.test(e)){var s=e.slice(1);a=1,(u=s.length)<=4?(o=[parseInt(s[0]+s[0],16),parseInt(s[1]+s[1],16),parseInt(s[2]+s[2],16)],4===u&&(a=parseInt(s[3]+s[3],16)/255)):(o=[parseInt(s[0]+s[1],16),parseInt(s[2]+s[3],16),parseInt(s[4]+s[5],16)],8===u&&(a=parseInt(s[6]+s[7],16)/255)),o[0]||(o[0]=0),o[1]||(o[1]=0),o[2]||(o[2]=0),r="rgb"}else if(t=/^((?:rgb|hs[lvb]|hwb|cmyk?|xy[zy]|gray|lab|lchu?v?|[ly]uv|lms)a?)\s*\(([^\)]*)\)/.exec(e)){var l=t[1],c="rgb"===l;r=s=l.replace(/a$/,"");var u="cmyk"===s?4:"gray"===s?1:3;o=t[2].trim().split(/\s*[,\/]\s*|\s+/).map((function(e,t){if(/%$/.test(e))return t===u?parseFloat(e)/100:"rgb"===s?255*parseFloat(e)/100:parseFloat(e);if("h"===s[t]){if(/deg$/.test(e))return parseFloat(e);if(void 0!==i[e])return i[e]}return parseFloat(e)})),l===s&&o.push(1),a=c||void 0===o[u]?1:o[u],o=o.slice(0,u)}else e.length>10&&/[0-9](?:\s|\/)/.test(e)&&(o=e.match(/([0-9]+)/g).map((function(e){return parseFloat(e)})),r=e.match(/([a-z])/gi).join("").toLowerCase());else isNaN(e)?Array.isArray(e)||e.length?(o=[e[0],e[1],e[2]],r="rgb",a=4===e.length?e[3]:1):e instanceof Object&&(null!=e.r||null!=e.red||null!=e.R?(r="rgb",o=[e.r||e.red||e.R||0,e.g||e.green||e.G||0,e.b||e.blue||e.B||0]):(r="hsl",o=[e.h||e.hue||e.H||0,e.s||e.saturation||e.S||0,e.l||e.lightness||e.L||e.b||e.brightness]),a=e.a||e.alpha||e.opacity||1,null!=e.opacity&&(a/=100)):(r="rgb",o=[e>>>16,(65280&e)>>>8,255&e]);return{space:r,values:o,alpha:a}};var i={red:0,orange:60,yellow:120,green:180,blue:240,purple:300}},60894:(e,t,r)=>{"use strict";var n=r(88487);e.exports=function(e){var t;Array.isArray(e)&&e.raw&&(e=String.raw.apply(null,arguments));var r=n(e);if(!r.space)return[];var i=[0,0,0],o="h"===r.space[0]?[360,100,100]:[255,255,255];return(t=Array(3))[0]=Math.min(Math.max(r.values[0],i[0]),o[0]),t[1]=Math.min(Math.max(r.values[1],i[1]),o[1]),t[2]=Math.min(Math.max(r.values[2],i[2]),o[2]),"h"===r.space[0]&&(t=function(e){var t,r,n,i,o,a=e[0]/360,s=e[1]/100,l=e[2]/100,c=0;if(0===s)return o=255*l,[o,o,o];for(t=2*l-(r=l<.5?l*(1+s):l+s-l*s),i=[0,0,0];c<3;)(n=a+1/3*-(c-1))<0?n++:n>1&&n--,o=6*n<1?t+6*(r-t)*n:2*n<1?r:3*n<2?t+(r-t)*(2/3-n)*6:t,i[c++]=255*o;return i}(t)),t.push(Math.min(Math.max(r.alpha,0),1)),t}},17705:(e,t,r)=>{"use strict";var n=r(93266),i=r(31484),o=r(9187);e.exports=function(e){var t,r=n(e);return r.space?((t=Array(3))[0]=o(r.values[0],0,255),t[1]=o(r.values[1],0,255),t[2]=o(r.values[2],0,255),"h"===r.space[0]&&(t=i.rgb(t)),t.push(o(r.alpha,0,1)),t):[]}},93266:(e,t,r)=>{"use strict";var n=r(38301);e.exports=function(e){var t,r,o=[],a=1;if("string"===typeof e)if(e=e.toLowerCase(),n[e])o=n[e].slice(),r="rgb";else if("transparent"===e)a=0,r="rgb",o=[0,0,0];else if(/^#[A-Fa-f0-9]+$/.test(e)){var s=e.slice(1);a=1,(u=s.length)<=4?(o=[parseInt(s[0]+s[0],16),parseInt(s[1]+s[1],16),parseInt(s[2]+s[2],16)],4===u&&(a=parseInt(s[3]+s[3],16)/255)):(o=[parseInt(s[0]+s[1],16),parseInt(s[2]+s[3],16),parseInt(s[4]+s[5],16)],8===u&&(a=parseInt(s[6]+s[7],16)/255)),o[0]||(o[0]=0),o[1]||(o[1]=0),o[2]||(o[2]=0),r="rgb"}else if(t=/^((?:rgb|hs[lvb]|hwb|cmyk?|xy[zy]|gray|lab|lchu?v?|[ly]uv|lms)a?)\s*\(([^\)]*)\)/.exec(e)){var l=t[1],c="rgb"===l;r=s=l.replace(/a$/,"");var u="cmyk"===s?4:"gray"===s?1:3;o=t[2].trim().split(/\s*[,\/]\s*|\s+/).map((function(e,t){if(/%$/.test(e))return t===u?parseFloat(e)/100:"rgb"===s?255*parseFloat(e)/100:parseFloat(e);if("h"===s[t]){if(/deg$/.test(e))return parseFloat(e);if(void 0!==i[e])return i[e]}return parseFloat(e)})),l===s&&o.push(1),a=c||void 0===o[u]?1:o[u],o=o.slice(0,u)}else e.length>10&&/[0-9](?:\s|\/)/.test(e)&&(o=e.match(/([0-9]+)/g).map((function(e){return parseFloat(e)})),r=e.match(/([a-z])/gi).join("").toLowerCase());else isNaN(e)?Array.isArray(e)||e.length?(o=[e[0],e[1],e[2]],r="rgb",a=4===e.length?e[3]:1):e instanceof Object&&(null!=e.r||null!=e.red||null!=e.R?(r="rgb",o=[e.r||e.red||e.R||0,e.g||e.green||e.G||0,e.b||e.blue||e.B||0]):(r="hsl",o=[e.h||e.hue||e.H||0,e.s||e.saturation||e.S||0,e.l||e.lightness||e.L||e.b||e.brightness]),a=e.a||e.alpha||e.opacity||1,null!=e.opacity&&(a/=100)):(r="rgb",o=[e>>>16,(65280&e)>>>8,255&e]);return{space:r,values:o,alpha:a}};var i={red:0,orange:60,yellow:120,green:180,blue:240,purple:300}},31484:(e,t,r)=>{"use strict";var n=r(81840);e.exports={name:"hsl",min:[0,0,0],max:[360,100,100],channel:["hue","saturation","lightness"],alias:["HSL"],rgb:function(e){var t,r,n,i,o,a=e[0]/360,s=e[1]/100,l=e[2]/100;if(0===s)return[o=255*l,o,o];t=2*l-(r=l<.5?l*(1+s):l+s-l*s),i=[0,0,0];for(var c=0;c<3;c++)(n=a+1/3*-(c-1))<0?n++:n>1&&n--,o=6*n<1?t+6*(r-t)*n:2*n<1?r:3*n<2?t+(r-t)*(2/3-n)*6:t,i[c]=255*o;return i}},n.hsl=function(e){var t,r,n=e[0]/255,i=e[1]/255,o=e[2]/255,a=Math.min(n,i,o),s=Math.max(n,i,o),l=s-a;return s===a?t=0:n===s?t=(i-o)/l:i===s?t=2+(o-n)/l:o===s&&(t=4+(n-i)/l),(t=Math.min(60*t,360))<0&&(t+=360),r=(a+s)/2,[t,100*(s===a?0:r<=.5?l/(s+a):l/(2-s-a)),100*r]}},81840:e=>{"use strict";e.exports={name:"rgb",min:[0,0,0],max:[255,255,255],channel:["red","green","blue"],alias:["RGB"]}},32662:e=>{"use strict";e.exports=[{path:"",backoff:0},{path:"M-2.4,-3V3L0.6,0Z",backoff:.6},{path:"M-3.7,-2.5V2.5L1.3,0Z",backoff:1.3},{path:"M-4.45,-3L-1.65,-0.2V0.2L-4.45,3L1.55,0Z",backoff:1.55},{path:"M-2.2,-2.2L-0.2,-0.2V0.2L-2.2,2.2L-1.4,3L1.6,0L-1.4,-3Z",backoff:1.6},{path:"M-4.4,-2.1L-0.6,-0.2V0.2L-4.4,2.1L-4,3L2,0L-4,-3Z",backoff:2},{path:"M2,0A2,2 0 1,1 0,-2A2,2 0 0,1 2,0Z",backoff:0,noRotate:!0},{path:"M2,2V-2H-2V2Z",backoff:0,noRotate:!0}]},38467:(e,t,r)=>{"use strict";var n=r(32662),i=r(91740),o=r(93143),a=r(37091).templatedArray,s=r(54654);function l(e){return["In order for absolute positioning of the arrow to work, *a"+e+"ref* must be exactly the same as *"+e+"ref*, otherwise *a"+e+"ref* will revert to *pixel* (explained next).","For relative positioning, *a"+e+"ref* can be set to *pixel*,","in which case the *a"+e+"* value is specified in pixels","relative to *"+e+"*.","Absolute positioning is useful","for trendline annotations which should continue to indicate","the correct trend when zoomed. Relative positioning is useful","for specifying the text offset for an annotated point."].join(" ")}function c(e,t,r){return["Sets the",e,"component of the arrow tail about the arrow head.","If `a"+e+"ref` is `pixel`, a positive (negative)","component corresponds to an arrow pointing","from",r,"to",t,"("+t,"to",r+").","If `a"+e+"ref` is not `pixel` and is exactly the same as `"+e+"ref`,","this is an absolute value on that axis,","like `"+e+"`, specified in the same coordinates as `"+e+"ref`."].join(" ")}e.exports=a("annotation",{visible:{valType:"boolean",dflt:!0,editType:"calc+arraydraw",description:["Determines whether or not this annotation is visible."].join(" ")},text:{valType:"string",editType:"calc+arraydraw",description:["Sets the text associated with this annotation.","Plotly uses a subset of HTML tags to do things like","newline (
), bold (), italics (),","hyperlinks (). Tags , , , , "," are also supported."].join(" ")},textangle:{valType:"angle",dflt:0,editType:"calc+arraydraw",description:["Sets the angle at which the `text` is drawn","with respect to the horizontal."].join(" ")},font:i({editType:"calc+arraydraw",colorEditType:"arraydraw",description:"Sets the annotation text font."}),width:{valType:"number",min:1,dflt:null,editType:"calc+arraydraw",description:["Sets an explicit width for the text box. null (default) lets the","text set the box width. Wider text will be clipped.","There is no automatic wrapping; use
to start a new line."].join(" ")},height:{valType:"number",min:1,dflt:null,editType:"calc+arraydraw",description:["Sets an explicit height for the text box. null (default) lets the","text set the box height. Taller text will be clipped."].join(" ")},opacity:{valType:"number",min:0,max:1,dflt:1,editType:"arraydraw",description:"Sets the opacity of the annotation (text + arrow)."},align:{valType:"enumerated",values:["left","center","right"],dflt:"center",editType:"arraydraw",description:["Sets the horizontal alignment of the `text` within the box.","Has an effect only if `text` spans two or more lines","(i.e. `text` contains one or more
HTML tags) or if an","explicit width is set to override the text width."].join(" ")},valign:{valType:"enumerated",values:["top","middle","bottom"],dflt:"middle",editType:"arraydraw",description:["Sets the vertical alignment of the `text` within the box.","Has an effect only if an explicit height is set to override","the text height."].join(" ")},bgcolor:{valType:"color",dflt:"rgba(0,0,0,0)",editType:"arraydraw",description:"Sets the background color of the annotation."},bordercolor:{valType:"color",dflt:"rgba(0,0,0,0)",editType:"arraydraw",description:["Sets the color of the border enclosing the annotation `text`."].join(" ")},borderpad:{valType:"number",min:0,dflt:1,editType:"calc+arraydraw",description:["Sets the padding (in px) between the `text`","and the enclosing border."].join(" ")},borderwidth:{valType:"number",min:0,dflt:1,editType:"calc+arraydraw",description:["Sets the width (in px) of the border enclosing","the annotation `text`."].join(" ")},showarrow:{valType:"boolean",dflt:!0,editType:"calc+arraydraw",description:["Determines whether or not the annotation is drawn with an arrow.","If *true*, `text` is placed near the arrow's tail.","If *false*, `text` lines up with the `x` and `y` provided."].join(" ")},arrowcolor:{valType:"color",editType:"arraydraw",description:"Sets the color of the annotation arrow."},arrowhead:{valType:"integer",min:0,max:n.length,dflt:1,editType:"arraydraw",description:"Sets the end annotation arrow head style."},startarrowhead:{valType:"integer",min:0,max:n.length,dflt:1,editType:"arraydraw",description:"Sets the start annotation arrow head style."},arrowside:{valType:"flaglist",flags:["end","start"],extras:["none"],dflt:"end",editType:"arraydraw",description:"Sets the annotation arrow head position."},arrowsize:{valType:"number",min:.3,dflt:1,editType:"calc+arraydraw",description:["Sets the size of the end annotation arrow head, relative to `arrowwidth`.","A value of 1 (default) gives a head about 3x as wide as the line."].join(" ")},startarrowsize:{valType:"number",min:.3,dflt:1,editType:"calc+arraydraw",description:["Sets the size of the start annotation arrow head, relative to `arrowwidth`.","A value of 1 (default) gives a head about 3x as wide as the line."].join(" ")},arrowwidth:{valType:"number",min:.1,editType:"calc+arraydraw",description:"Sets the width (in px) of annotation arrow line."},standoff:{valType:"number",min:0,dflt:0,editType:"calc+arraydraw",description:["Sets a distance, in pixels, to move the end arrowhead away from the","position it is pointing at, for example to point at the edge of","a marker independent of zoom. Note that this shortens the arrow","from the `ax` / `ay` vector, in contrast to `xshift` / `yshift`","which moves everything by this amount."].join(" ")},startstandoff:{valType:"number",min:0,dflt:0,editType:"calc+arraydraw",description:["Sets a distance, in pixels, to move the start arrowhead away from the","position it is pointing at, for example to point at the edge of","a marker independent of zoom. Note that this shortens the arrow","from the `ax` / `ay` vector, in contrast to `xshift` / `yshift`","which moves everything by this amount."].join(" ")},ax:{valType:"any",editType:"calc+arraydraw",description:[c("x","left","right")].join(" ")},ay:{valType:"any",editType:"calc+arraydraw",description:[c("y","top","bottom")].join(" ")},axref:{valType:"enumerated",dflt:"pixel",values:["pixel",o.idRegex.x.toString()],editType:"calc",description:["Indicates in what coordinates the tail of the","annotation (ax,ay) is specified.",s.axisRefDescription("x","left","right"),l("x")].join(" ")},ayref:{valType:"enumerated",dflt:"pixel",values:["pixel",o.idRegex.y.toString()],editType:"calc",description:["Indicates in what coordinates the tail of the","annotation (ax,ay) is specified.",s.axisRefDescription("y","bottom","top"),l("y")].join(" ")},xref:{valType:"enumerated",values:["paper",o.idRegex.x.toString()],editType:"calc",description:["Sets the annotation's x coordinate axis.",s.axisRefDescription("x","left","right")].join(" ")},x:{valType:"any",editType:"calc+arraydraw",description:["Sets the annotation's x position.","If the axis `type` is *log*, then you must take the","log of your desired range.","If the axis `type` is *date*, it should be date strings,","like date data, though Date objects and unix milliseconds","will be accepted and converted to strings.","If the axis `type` is *category*, it should be numbers,","using the scale where each category is assigned a serial","number from zero in the order it appears."].join(" ")},xanchor:{valType:"enumerated",values:["auto","left","center","right"],dflt:"auto",editType:"calc+arraydraw",description:["Sets the text box's horizontal position anchor","This anchor binds the `x` position to the *left*, *center*","or *right* of the annotation.","For example, if `x` is set to 1, `xref` to *paper* and","`xanchor` to *right* then the right-most portion of the","annotation lines up with the right-most edge of the","plotting area.","If *auto*, the anchor is equivalent to *center* for","data-referenced annotations or if there is an arrow,","whereas for paper-referenced with no arrow, the anchor picked","corresponds to the closest side."].join(" ")},xshift:{valType:"number",dflt:0,editType:"calc+arraydraw",description:["Shifts the position of the whole annotation and arrow to the","right (positive) or left (negative) by this many pixels."].join(" ")},yref:{valType:"enumerated",values:["paper",o.idRegex.y.toString()],editType:"calc",description:["Sets the annotation's y coordinate axis.",s.axisRefDescription("y","bottom","top")].join(" ")},y:{valType:"any",editType:"calc+arraydraw",description:["Sets the annotation's y position.","If the axis `type` is *log*, then you must take the","log of your desired range.","If the axis `type` is *date*, it should be date strings,","like date data, though Date objects and unix milliseconds","will be accepted and converted to strings.","If the axis `type` is *category*, it should be numbers,","using the scale where each category is assigned a serial","number from zero in the order it appears."].join(" ")},yanchor:{valType:"enumerated",values:["auto","top","middle","bottom"],dflt:"auto",editType:"calc+arraydraw",description:["Sets the text box's vertical position anchor","This anchor binds the `y` position to the *top*, *middle*","or *bottom* of the annotation.","For example, if `y` is set to 1, `yref` to *paper* and","`yanchor` to *top* then the top-most portion of the","annotation lines up with the top-most edge of the","plotting area.","If *auto*, the anchor is equivalent to *middle* for","data-referenced annotations or if there is an arrow,","whereas for paper-referenced with no arrow, the anchor picked","corresponds to the closest side."].join(" ")},yshift:{valType:"number",dflt:0,editType:"calc+arraydraw",description:["Shifts the position of the whole annotation and arrow up","(positive) or down (negative) by this many pixels."].join(" ")},clicktoshow:{valType:"enumerated",values:[!1,"onoff","onout"],dflt:!1,editType:"arraydraw",description:["Makes this annotation respond to clicks on the plot.","If you click a data point that exactly matches the `x` and `y`","values of this annotation, and it is hidden (visible: false),","it will appear. In *onoff* mode, you must click the same point","again to make it disappear, so if you click multiple points,","you can show multiple annotations. In *onout* mode, a click","anywhere else in the plot (on another data point or not) will","hide this annotation.","If you need to show/hide this annotation in response to different","`x` or `y` values, you can set `xclick` and/or `yclick`. This is","useful for example to label the side of a bar. To label markers","though, `standoff` is preferred over `xclick` and `yclick`."].join(" ")},xclick:{valType:"any",editType:"arraydraw",description:["Toggle this annotation when clicking a data point whose `x` value","is `xclick` rather than the annotation's `x` value."].join(" ")},yclick:{valType:"any",editType:"arraydraw",description:["Toggle this annotation when clicking a data point whose `y` value","is `yclick` rather than the annotation's `y` value."].join(" ")},hovertext:{valType:"string",editType:"arraydraw",description:["Sets text to appear when hovering over this annotation.","If omitted or blank, no hover label will appear."].join(" ")},hoverlabel:{bgcolor:{valType:"color",editType:"arraydraw",description:["Sets the background color of the hover label.","By default uses the annotation's `bgcolor` made opaque,","or white if it was transparent."].join(" ")},bordercolor:{valType:"color",editType:"arraydraw",description:["Sets the border color of the hover label.","By default uses either dark grey or white, for maximum","contrast with `hoverlabel.bgcolor`."].join(" ")},font:i({editType:"arraydraw",description:["Sets the hover label text font.","By default uses the global hover font and size,","with color from `hoverlabel.bordercolor`."].join(" ")}),editType:"arraydraw"},captureevents:{valType:"boolean",editType:"arraydraw",description:["Determines whether the annotation text box captures mouse move","and click events, or allows those events to pass through to data","points in the plot that may be behind the annotation. By default","`captureevents` is *false* unless `hovertext` is provided.","If you use the event `plotly_clickannotation` without `hovertext`","you must explicitly enable `captureevents`."].join(" ")},editType:"calc",_deprecated:{ref:{valType:"string",editType:"calc",description:["Obsolete. Set `xref` and `yref` separately instead."].join(" ")}}})},73332:(e,t,r)=>{"use strict";var n=r(84468),i=r(85729),o=r(14984).draw;function a(e){var t=e._fullLayout;n.filterVisible(t.annotations).forEach((function(t){var r=i.getFromId(e,t.xref),n=i.getFromId(e,t.yref),o=i.getRefType(t.xref),a=i.getRefType(t.yref);t._extremes={},"range"===o&&s(t,r),"range"===a&&s(t,n)}))}function s(e,t){var r,n=t._id,o=n.charAt(0),a=e[o],s=e["a"+o],l=e[o+"ref"],c=e["a"+o+"ref"],u=e["_"+o+"padplus"],d=e["_"+o+"padminus"],h={x:1,y:-1}[o]*e[o+"shift"],p=3*e.arrowsize*e.arrowwidth||0,f=p+h,m=p-h,g=3*e.startarrowsize*e.arrowwidth||0,y=g+h,v=g-h;if(c===l){var x=i.findExtremes(t,[t.r2c(a)],{ppadplus:f,ppadminus:m}),b=i.findExtremes(t,[t.r2c(s)],{ppadplus:Math.max(u,y),ppadminus:Math.max(d,v)});r={min:[x.min[0],b.min[0]],max:[x.max[0],b.max[0]]}}else y=s?y+s:y,v=s?v-s:v,r=i.findExtremes(t,[t.r2c(a)],{ppadplus:Math.max(u,f,y),ppadminus:Math.max(d,m,v)});e._extremes[n]=r}e.exports=function(e){var t=e._fullLayout;if(n.filterVisible(t.annotations).length&&e._fullData.length)return n.syncOrAsync([o,a],e)}},10748:(e,t,r)=>{"use strict";var n=r(84468),i=r(38361),o=r(37091).arrayEditor;function a(e,t){var r,n,i,o,a,l,c,u=e._fullLayout.annotations,d=[],h=[],p=[],f=(t||[]).length;for(r=0;r0||r.explicitOff.length>0},onClick:function(e,t){var r,s,l=a(e,t),c=l.on,u=l.off.concat(l.explicitOff),d={},h=e._fullLayout.annotations;if(!c.length&&!u.length)return;for(r=0;r{"use strict";var n=r(84468),i=r(7605);e.exports=function(e,t,r,o){o("opacity");var a=o("bgcolor"),s=o("bordercolor"),l=i.opacity(s);o("borderpad");var c=o("borderwidth"),u=o("showarrow");if(o("text",u?" ":r._dfltTitle.annotation),o("textangle"),n.coerceFont(o,"font",r.font),o("width"),o("align"),o("height")&&o("valign"),u){var d,h,p=o("arrowside");-1!==p.indexOf("end")&&(d=o("arrowhead"),h=o("arrowsize")),-1!==p.indexOf("start")&&(o("startarrowhead",d),o("startarrowsize",h)),o("arrowcolor",l?t.bordercolor:i.defaultLine),o("arrowwidth",2*(l&&c||1)),o("standoff"),o("startstandoff")}var f=o("hovertext"),m=r.hoverlabel||{};if(f){var g=o("hoverlabel.bgcolor",m.bgcolor||(i.opacity(a)?i.rgb(a):i.defaultLine)),y=o("hoverlabel.bordercolor",m.bordercolor||i.contrast(g)),v=n.extendFlat({},m.font);v.color||(v.color=y),n.coerceFont(o,"hoverlabel.font",v)}o("captureevents",!!f)}},65644:(e,t,r)=>{"use strict";var n=r(22036),i=r(46396);e.exports=function(e,t,r,o){t=t||{};var a="log"===r&&"linear"===t.type,s="linear"===r&&"log"===t.type;if(a||s)for(var l,c,u=e._fullLayout.annotations,d=t._id.charAt(0),h=0;h{"use strict";var n=r(84468),i=r(85729),o=r(38851),a=r(71248),s=r(38467);function l(e,t,r){function o(r,i){return n.coerce(e,t,s,r,i)}var l=o("visible"),c=o("clicktoshow");if(l||c){a(e,t,r,o);for(var u=t.showarrow,d=["x","y"],h=[-10,-30],p={_fullLayout:r},f=0;f<2;f++){var m=d[f],g=i.coerceRef(e,t,p,m,"","paper");if("paper"!==g)i.getFromId(p,g)._annIndices.push(t._index);if(i.coercePosition(t,p,o,g,m,.5),u){var y="a"+m,v=i.coerceRef(e,t,p,y,"pixel",["pixel","paper"]);"pixel"!==v&&v!==g&&(v=t[y]="pixel");var x="pixel"===v?h[f]:.4;i.coercePosition(t,p,o,v,y,x)}o(m+"anchor"),o(m+"shift")}if(n.noneOrAll(e,t,["x","y"]),u&&n.noneOrAll(e,t,["ax","ay"]),c){var b=o("xclick"),_=o("yclick");t._xclick=void 0===b?t.x:i.cleanPosition(b,p,t.xref),t._yclick=void 0===_?t.y:i.cleanPosition(_,p,t.yref)}}}e.exports=function(e,t){o(e,t,{name:"annotations",handleItemDefaults:l})}},14984:(e,t,r)=>{"use strict";var n=r(41871),i=r(38361),o=r(68543),a=r(84468),s=a.strTranslate,l=r(85729),c=r(7605),u=r(3172),d=r(32212),h=r(13480),p=r(29454),f=r(25732),m=r(37091).arrayEditor,g=r(97583);function y(e,t){var r=e._fullLayout.annotations[t]||{},n=l.getFromId(e,r.xref),i=l.getFromId(e,r.yref);n&&n.setScale(),i&&i.setScale(),x(e,r,t,!1,n,i)}function v(e,t,r,n,i){var o=i[r],a=i[r+"ref"],s=-1!==r.indexOf("y"),c="domain"===l.getRefType(a),u=s?n.h:n.w;return e?c?o+(s?-t:t)/e._length:e.p2r(e.r2p(o)+t):o+(s?-t:t)/u}function x(e,t,r,o,y,x){var b,_,w=e._fullLayout,k=e._fullLayout._size,S=e._context.edits;o?(b="annotation-"+o,_=o+".annotations"):(b="annotation",_="annotations");var A=m(e.layout,_,t),T=A.modifyBase,M=A.modifyItem,C=A.getUpdateObj;w._infolayer.selectAll("."+b+'[data-index="'+r+'"]').remove();var E="clip"+w._uid+"_ann"+r;if(t._input&&!1!==t.visible){var I={x:{},y:{}},P=+t.textangle||0,O=w._infolayer.append("g").classed(b,!0).attr("data-index",String(r)).style("opacity",t.opacity),R=O.append("g").classed("annotation-text-g",!0),L=S[t.showarrow?"annotationTail":"annotationPosition"],D=t.captureevents||S.annotationText||L,z=R.append("g").style("pointer-events",D?"all":null).call(p,"pointer").on("click",(function(){e._dragging=!1,e.emit("plotly_clickannotation",q(n.event))}));t.hovertext&&z.on("mouseover",(function(){var r=t.hoverlabel,n=r.font,i=this.getBoundingClientRect(),o=e.getBoundingClientRect();d.loneHover({x0:i.left-o.left,x1:i.right-o.left,y:(i.top+i.bottom)/2-o.top,text:t.hovertext,color:r.bgcolor,borderColor:r.bordercolor,fontFamily:n.family,fontSize:n.size,fontColor:n.color,fontWeight:n.weight,fontStyle:n.style,fontVariant:n.variant,fontShadow:n.fontShadow,fontLineposition:n.fontLineposition,fontTextcase:n.fontTextcase},{container:w._hoverlayer.node(),outerContainer:w._paper.node(),gd:e})})).on("mouseout",(function(){d.loneUnhover(w._hoverlayer.node())}));var j=t.borderwidth,F=t.borderpad,N=j+F,B=z.append("rect").attr("class","bg").style("stroke-width",j+"px").call(c.stroke,t.bordercolor).call(c.fill,t.bgcolor),V=t.width||t.height,U=w._topclips.selectAll("#"+E).data(V?[0]:[]);U.enter().append("clipPath").classed("annclip",!0).attr("id",E).append("rect"),U.exit().remove();var H=t.font,$=w._meta?a.templateString(t.text,w._meta):t.text,W=z.append("text").classed("annotation-text",!0).text($);S.annotationText?W.call(h.makeEditable,{delegate:z,gd:e}).call(G).on("edit",(function(r){t.text=r,this.call(G),M("text",r),y&&y.autorange&&T(y._name+".autorange",!0),x&&x.autorange&&T(x._name+".autorange",!0),i.call("_guiRelayout",e,C())})):W.call(G)}else n.selectAll("#"+E).remove();function q(e){var n={index:r,annotation:t._input,fullAnnotation:t,event:e};return o&&(n.subplotId=o),n}function G(r){return r.call(u.font,H).attr({"text-anchor":{left:"start",right:"end"}[t.align]||"middle"}),h.convertToTspans(r,e,Y),r}function Y(){var r=W.selectAll("a");1===r.size()&&r.text()===W.text()&&z.insert("a",":first-child").attr({"xlink:xlink:href":r.attr("xlink:href"),"xlink:xlink:show":r.attr("xlink:show")}).style({cursor:"pointer"}).node().appendChild(B.node());var n=z.select(".annotation-text-math-group"),d=!n.empty(),m=u.bBox((d?n:W).node()),b=m.width,_=m.height,A=t.width||b,D=t.height||_,F=Math.round(A+2*N),H=Math.round(D+2*N);function $(e,t){return"auto"===t&&(t=e<1/3?"left":e>2/3?"right":"center"),{center:0,middle:0,left:.5,bottom:-.5,right:-.5,top:.5}[t]}for(var G=!1,Y=["x","y"],X=0;X1)&&(ne===re?((pe=ie.r2fraction(t["a"+te]))<0||pe>1)&&(G=!0):G=!0),Z=ie._offset+ie.r2p(t[te]),Q=.5}else{var fe="domain"===he;"x"===te?(J=t[te],Z=fe?ie._offset+ie._length*J:Z=k.l+k.w*J):(J=1-t[te],Z=fe?ie._offset+ie._length*J:Z=k.t+k.h*J),Q=t.showarrow?.5:J}if(t.showarrow){de.head=Z;var me=t["a"+te];if(ee=ae*$(.5,t.xanchor)-se*$(.5,t.yanchor),ne===re){var ge=l.getRefType(ne);"domain"===ge?("y"===te&&(me=1-me),de.tail=ie._offset+ie._length*me):"paper"===ge?"y"===te?(me=1-me,de.tail=k.t+k.h*me):de.tail=k.l+k.w*me:de.tail=ie._offset+ie.r2p(me),K=ee}else de.tail=Z+me,K=ee+me;de.text=de.tail+ee;var ye=w["x"===te?"width":"height"];if("paper"===re&&(de.head=a.constrain(de.head,1,ye-1)),"pixel"===ne){var ve=-Math.max(de.tail-3,de.text),xe=Math.min(de.tail+3,de.text)-ye;ve>0?(de.tail+=ve,de.text+=ve):xe>0&&(de.tail-=xe,de.text-=xe)}de.tail+=ue,de.head+=ue}else K=ee=le*$(Q,ce),de.text=Z+ee;de.text+=ue,ee+=ue,K+=ue,t["_"+te+"padplus"]=le/2+K,t["_"+te+"padminus"]=le/2-K,t["_"+te+"size"]=le,t["_"+te+"shift"]=ee}if(G)z.remove();else{var be=0,_e=0;if("left"!==t.align&&(be=(A-b)*("center"===t.align?.5:1)),"top"!==t.valign&&(_e=(D-_)*("middle"===t.valign?.5:1)),d)n.select("svg").attr({x:N+be-1,y:N+_e}).call(u.setClipUrl,V?E:null,e);else{var we=N+_e-m.top,ke=N+be-m.left;W.call(h.positionText,ke,we).call(u.setClipUrl,V?E:null,e)}U.select("rect").call(u.setRect,N,N,A,D),B.call(u.setRect,j/2,j/2,F-j,H-j),z.call(u.setTranslate,Math.round(I.x.text-F/2),Math.round(I.y.text-H/2)),R.attr({transform:"rotate("+P+","+I.x.text+","+I.y.text+")"});var Se,Ae=function(r,n){O.selectAll(".annotation-arrow-g").remove();var l=I.x.head,d=I.y.head,h=I.x.tail+r,p=I.y.tail+n,m=I.x.text+r,b=I.y.text+n,_=a.rotationXYMatrix(P,m,b),w=a.apply2DTransform(_),A=a.apply2DTransform2(_),E=+B.attr("width"),L=+B.attr("height"),D=m-.5*E,j=D+E,F=b-.5*L,N=F+L,V=[[D,F,D,N],[D,N,j,N],[j,N,j,F],[j,F,D,F]].map(A);if(!V.reduce((function(e,t){return e^!!a.segmentsIntersect(l,d,l+1e6,d+1e6,t[0],t[1],t[2],t[3])}),!1)){V.forEach((function(e){var t=a.segmentsIntersect(h,p,l,d,e[0],e[1],e[2],e[3]);t&&(h=t.x,p=t.y)}));var U=t.arrowwidth,H=t.arrowcolor,$=t.arrowside,W=O.append("g").style({opacity:c.opacity(H)}).classed("annotation-arrow-g",!0),q=W.append("path").attr("d","M"+h+","+p+"L"+l+","+d).style("stroke-width",U+"px").call(c.stroke,c.rgb(H));if(g(q,$,t),S.annotationPosition&&q.node().parentNode&&!o){var G=l,Y=d;if(t.standoff){var X=Math.sqrt(Math.pow(l-h,2)+Math.pow(d-p,2));G+=t.standoff*(h-l)/X,Y+=t.standoff*(p-d)/X}var Z,K,J=W.append("path").classed("annotation-arrow",!0).classed("anndrag",!0).classed("cursor-move",!0).attr({d:"M3,3H-3V-3H3ZM0,0L"+(h-G)+","+(p-Y),transform:s(G,Y)}).style("stroke-width",U+6+"px").call(c.stroke,"rgba(0,0,0,0)").call(c.fill,"rgba(0,0,0,0)");f.init({element:J.node(),gd:e,prepFn:function(){var e=u.getTranslate(z);Z=e.x,K=e.y,y&&y.autorange&&T(y._name+".autorange",!0),x&&x.autorange&&T(x._name+".autorange",!0)},moveFn:function(e,r){var n=w(Z,K),i=n[0]+e,o=n[1]+r;z.call(u.setTranslate,i,o),M("x",v(y,e,"x",k,t)),M("y",v(x,r,"y",k,t)),t.axref===t.xref&&M("ax",v(y,e,"ax",k,t)),t.ayref===t.yref&&M("ay",v(x,r,"ay",k,t)),W.attr("transform",s(e,r)),R.attr({transform:"rotate("+P+","+i+","+o+")"})},doneFn:function(){i.call("_guiRelayout",e,C());var t=document.querySelector(".js-notes-box-panel");t&&t.redraw(t.selectedObj)}})}}};if(t.showarrow&&Ae(0,0),L)f.init({element:z.node(),gd:e,prepFn:function(){Se=R.attr("transform")},moveFn:function(e,r){var n="pointer";if(t.showarrow)t.axref===t.xref?M("ax",v(y,e,"ax",k,t)):M("ax",t.ax+e),t.ayref===t.yref?M("ay",v(x,r,"ay",k.w,t)):M("ay",t.ay+r),Ae(e,r);else{if(o)return;var i,a;if(y)i=v(y,e,"x",k,t);else{var l=t._xsize/k.w,c=t.x+(t._xshift-t.xshift)/k.w-l/2;i=f.align(c+e/k.w,l,0,1,t.xanchor)}if(x)a=v(x,r,"y",k,t);else{var u=t._ysize/k.h,d=t.y-(t._yshift+t.yshift)/k.h-u/2;a=f.align(d-r/k.h,u,0,1,t.yanchor)}M("x",i),M("y",a),y&&x||(n=f.getCursor(y?.5:i,x?.5:a,t.xanchor,t.yanchor))}R.attr({transform:s(e,r)+Se}),p(z,n)},clickFn:function(r,n){t.captureevents&&e.emit("plotly_clickannotation",q(n))},doneFn:function(){p(z),i.call("_guiRelayout",e,C());var t=document.querySelector(".js-notes-box-panel");t&&t.redraw(t.selectedObj)}})}}}e.exports={draw:function(e){var t=e._fullLayout;t._infolayer.selectAll(".annotation").remove();for(var r=0;r{"use strict";var n=r(41871),i=r(7605),o=r(32662),a=r(84468),s=a.strScale,l=a.strRotate,c=a.strTranslate;e.exports=function(e,t,r){var a,u,d,h,p=e.node(),f=o[r.arrowhead||0],m=o[r.startarrowhead||0],g=(r.arrowwidth||1)*(r.arrowsize||1),y=(r.arrowwidth||1)*(r.startarrowsize||1),v=t.indexOf("start")>=0,x=t.indexOf("end")>=0,b=f.backoff*g+r.standoff,_=m.backoff*y+r.startstandoff;if("line"===p.nodeName){a={x:+e.attr("x1"),y:+e.attr("y1")},u={x:+e.attr("x2"),y:+e.attr("y2")};var w=a.x-u.x,k=a.y-u.y;if(h=(d=Math.atan2(k,w))+Math.PI,b&&_&&b+_>Math.sqrt(w*w+k*k))return void L();if(b){if(b*b>w*w+k*k)return void L();var S=b*Math.cos(d),A=b*Math.sin(d);u.x+=S,u.y+=A,e.attr({x2:u.x,y2:u.y})}if(_){if(_*_>w*w+k*k)return void L();var T=_*Math.cos(d),M=_*Math.sin(d);a.x-=T,a.y-=M,e.attr({x1:a.x,y1:a.y})}}else if("path"===p.nodeName){var C=p.getTotalLength(),E="";if(C{"use strict";var n=r(14984),i=r(10748);e.exports={moduleType:"component",name:"annotations",layoutAttributes:r(38467),supplyLayoutDefaults:r(89604),includeBasePlot:r(84381)("annotations"),calcAutorange:r(73332),draw:n.draw,drawOne:n.drawOne,drawRaw:n.drawRaw,hasClickToShow:i.hasClickToShow,onClick:i.onClick,convertCoords:r(65644)}},92674:(e,t,r)=>{"use strict";var n=r(38467),i=r(72587).overrideAll,o=r(37091).templatedArray;e.exports=i(o("annotation",{visible:n.visible,x:{valType:"any",description:["Sets the annotation's x position."].join(" ")},y:{valType:"any",description:["Sets the annotation's y position."].join(" ")},z:{valType:"any",description:["Sets the annotation's z position."].join(" ")},ax:{valType:"number",description:["Sets the x component of the arrow tail about the arrow head (in pixels)."].join(" ")},ay:{valType:"number",description:["Sets the y component of the arrow tail about the arrow head (in pixels)."].join(" ")},xanchor:n.xanchor,xshift:n.xshift,yanchor:n.yanchor,yshift:n.yshift,text:n.text,textangle:n.textangle,font:n.font,width:n.width,height:n.height,opacity:n.opacity,align:n.align,valign:n.valign,bgcolor:n.bgcolor,bordercolor:n.bordercolor,borderpad:n.borderpad,borderwidth:n.borderwidth,showarrow:n.showarrow,arrowcolor:n.arrowcolor,arrowhead:n.arrowhead,startarrowhead:n.startarrowhead,arrowside:n.arrowside,arrowsize:n.arrowsize,startarrowsize:n.startarrowsize,arrowwidth:n.arrowwidth,standoff:n.standoff,startstandoff:n.startstandoff,hovertext:n.hovertext,hoverlabel:n.hoverlabel,captureevents:n.captureevents}),"calc","from-root")},27396:(e,t,r)=>{"use strict";var n=r(84468),i=r(85729);function o(e,t){var r=t.fullSceneLayout.domain,o=t.fullLayout._size,a={pdata:null,type:"linear",autorange:!1,range:[-1/0,1/0]};e._xa={},n.extendFlat(e._xa,a),i.setConvert(e._xa),e._xa._offset=o.l+r.x[0]*o.w,e._xa.l2p=function(){return.5*(1+e._pdata[0]/e._pdata[3])*o.w*(r.x[1]-r.x[0])},e._ya={},n.extendFlat(e._ya,a),i.setConvert(e._ya),e._ya._offset=o.t+(1-r.y[1])*o.h,e._ya.l2p=function(){return.5*(1-e._pdata[1]/e._pdata[3])*o.h*(r.y[1]-r.y[0])}}e.exports=function(e){for(var t=e.fullSceneLayout.annotations,r=0;r{"use strict";var n=r(84468),i=r(85729),o=r(38851),a=r(71248),s=r(92674);function l(e,t,r,o){function l(r,i){return n.coerce(e,t,s,r,i)}function c(e){var n=e+"axis",o={_fullLayout:{}};return o._fullLayout[n]=r[n],i.coercePosition(t,o,l,e,e,.5)}l("visible")&&(a(e,t,o.fullLayout,l),c("x"),c("y"),c("z"),n.noneOrAll(e,t,["x","y","z"]),t.xref="x",t.yref="y",t.zref="z",l("xanchor"),l("yanchor"),l("xshift"),l("yshift"),t.showarrow&&(t.axref="pixel",t.ayref="pixel",l("ax",-10),l("ay",-30),n.noneOrAll(e,t,["ax","ay"])))}e.exports=function(e,t,r){o(e,t,{name:"annotations",handleItemDefaults:l,fullLayout:r.fullLayout})}},16925:(e,t,r)=>{"use strict";var n=r(14984).drawRaw,i=r(65393),o=["x","y","z"];e.exports=function(e){for(var t=e.fullSceneLayout,r=e.dataScale,a=t.annotations,s=0;s1){c=!0;break}}c?e.fullLayout._infolayer.select(".annotation-"+e.id+'[data-index="'+s+'"]').remove():(l._pdata=i(e.glplot.cameraParams,[t.xaxis.r2l(l.x)*r[0],t.yaxis.r2l(l.y)*r[1],t.zaxis.r2l(l.z)*r[2]]),n(e.graphDiv,l,s,e.id,l._xa,l._ya))}}},54235:(e,t,r)=>{"use strict";var n=r(38361),i=r(84468);e.exports={moduleType:"component",name:"annotations3d",schema:{subplots:{scene:{annotations:r(92674)}}},layoutAttributes:r(92674),handleDefaults:r(61045),includeBasePlot:function(e,t){var r=n.subplotsRegistry.gl3d;if(!r)return;for(var o=r.attrRegex,a=Object.keys(e),s=0;s{"use strict";e.exports=r(14418),r(41299),r(65388),r(34001),r(66908),r(6896),r(92044),r(51033),r(9954),r(44705),r(38193),r(47414),r(95607),r(47),r(8673),r(38864)},30781:(e,t,r)=>{"use strict";var n=r(15570),i=r(84468),o=r(65004),a=o.EPOCHJD,s=o.ONEDAY,l={valType:"enumerated",values:i.sortObjectKeys(n.calendars),editType:"calc",dflt:"gregorian"},c=function(e,t,r,n){var o={};return o[r]=l,i.coerce(e,t,o,r,n)},u="##",d={d:{0:"dd","-":"d"},e:{0:"d","-":"d"},a:{0:"D","-":"D"},A:{0:"DD","-":"DD"},j:{0:"oo","-":"o"},W:{0:"ww","-":"w"},m:{0:"mm","-":"m"},b:{0:"M","-":"M"},B:{0:"MM","-":"MM"},y:{0:"yy","-":"yy"},Y:{0:"yyyy","-":"yyyy"},U:u,w:u,c:{0:"D M d %X yyyy","-":"D M d %X yyyy"},x:{0:"mm/dd/yyyy","-":"mm/dd/yyyy"}};var h={};function p(e){var t=h[e];return t||(t=h[e]=n.instance(e))}function f(e){return i.extendFlat({},l,{description:e})}function m(e){return"Sets the calendar system to use with `"+e+"` date data."}var g={xcalendar:f(m("x"))},y=i.extendFlat({},g,{ycalendar:f(m("y"))}),v=i.extendFlat({},y,{zcalendar:f(m("z"))}),x=f(["Sets the calendar system to use for `range` and `tick0`","if this is a date axis. This does not set the calendar for","interpreting data on this axis, that's specified in the trace","or via the global `layout.calendar`"].join(" "));e.exports={moduleType:"component",name:"calendars",schema:{traces:{scatter:y,bar:y,box:y,heatmap:y,contour:y,histogram:y,histogram2d:y,histogram2dcontour:y,scatter3d:v,surface:v,mesh3d:v,scattergl:y,ohlc:g,candlestick:g},layout:{calendar:f(["Sets the default calendar system to use for interpreting and","displaying dates throughout the plot."].join(" "))},subplots:{xaxis:{calendar:x},yaxis:{calendar:x},scene:{xaxis:{calendar:x},yaxis:{calendar:x},zaxis:{calendar:x}},polar:{radialaxis:{calendar:x}}},transforms:{filter:{valuecalendar:f(["WARNING: All transforms are deprecated and may be removed from the API in next major version.","Sets the calendar system to use for `value`, if it is a date."].join(" ")),targetcalendar:f(["WARNING: All transforms are deprecated and may be removed from the API in next major version.","Sets the calendar system to use for `target`, if it is an","array of dates. If `target` is a string (eg *x*) we use the","corresponding trace attribute (eg `xcalendar`) if it exists,","even if `targetcalendar` is provided."].join(" "))}}},layoutAttributes:l,handleDefaults:c,handleTraceDefaults:function(e,t,r,n){for(var i=0;i{"use strict";t.defaults=["#1f77b4","#ff7f0e","#2ca02c","#d62728","#9467bd","#8c564b","#e377c2","#7f7f7f","#bcbd22","#17becf"],t.defaultLine="#444",t.lightLine="#eee",t.background="#fff",t.borderLine="#BEC8D9",t.lightFraction=1e3/11},7605:(e,t,r)=>{"use strict";var n=r(23498),i=r(22036),o=r(19045).isTypedArray,a=e.exports={},s=r(17992);a.defaults=s.defaults;var l=a.defaultLine=s.defaultLine;a.lightLine=s.lightLine;var c=a.background=s.background;function u(e){if(i(e)||"string"!==typeof e)return e;var t=e.trim();if("rgb"!==t.substr(0,3))return e;var r=t.match(/^rgba?\s*\(([^()]*)\)$/);if(!r)return e;var n=r[1].trim().split(/\s*[\s,]\s*/),o="a"===t.charAt(3)&&4===n.length;if(!o&&3!==n.length)return e;for(var a=0;a=0))return e;if(3===a)n[a]>1&&(n[a]=1);else if(n[a]>=1)return e}var s=Math.round(255*n[0])+", "+Math.round(255*n[1])+", "+Math.round(255*n[2]);return o?"rgba("+s+", "+n[3]+")":"rgb("+s+")"}a.tinyRGB=function(e){var t=e.toRgb();return"rgb("+Math.round(t.r)+", "+Math.round(t.g)+", "+Math.round(t.b)+")"},a.rgb=function(e){return a.tinyRGB(n(e))},a.opacity=function(e){return e?n(e).getAlpha():0},a.addOpacity=function(e,t){var r=n(e).toRgb();return"rgba("+Math.round(r.r)+", "+Math.round(r.g)+", "+Math.round(r.b)+", "+t+")"},a.combine=function(e,t){var r=n(e).toRgb();if(1===r.a)return n(e).toRgbString();var i=n(t||c).toRgb(),o=1===i.a?i:{r:255*(1-i.a)+i.r*i.a,g:255*(1-i.a)+i.g*i.a,b:255*(1-i.a)+i.b*i.a},a={r:o.r*(1-r.a)+r.r*r.a,g:o.g*(1-r.a)+r.g*r.a,b:o.b*(1-r.a)+r.b*r.a};return n(a).toRgbString()},a.interpolate=function(e,t,r){var i=n(e).toRgb(),o=n(t).toRgb(),a={r:r*i.r+(1-r)*o.r,g:r*i.g+(1-r)*o.g,b:r*i.b+(1-r)*o.b};return n(a).toRgbString()},a.contrast=function(e,t,r){var i=n(e);return 1!==i.getAlpha()&&(i=n(a.combine(e,c))),(i.isDark()?t?i.lighten(t):c:r?i.darken(r):l).toString()},a.stroke=function(e,t){var r=n(t);e.style({stroke:a.tinyRGB(r),"stroke-opacity":r.getAlpha()})},a.fill=function(e,t){var r=n(t);e.style({fill:a.tinyRGB(r),"fill-opacity":r.getAlpha()})},a.clean=function(e){if(e&&"object"===typeof e){var t,r,n,i,s=Object.keys(e);for(t=0;t{"use strict";var n=r(49080),i=r(91740),o=r(64022).extendFlat,a=r(72587).overrideAll;e.exports=a({orientation:{valType:"enumerated",values:["h","v"],dflt:"v",description:"Sets the orientation of the colorbar."},thicknessmode:{valType:"enumerated",values:["fraction","pixels"],dflt:"pixels",description:["Determines whether this color bar's thickness","(i.e. the measure in the constant color direction)","is set in units of plot *fraction* or in *pixels*.","Use `thickness` to set the value."].join(" ")},thickness:{valType:"number",min:0,dflt:30,description:["Sets the thickness of the color bar","This measure excludes the size of the padding, ticks and labels."].join(" ")},lenmode:{valType:"enumerated",values:["fraction","pixels"],dflt:"fraction",description:["Determines whether this color bar's length","(i.e. the measure in the color variation direction)","is set in units of plot *fraction* or in *pixels.","Use `len` to set the value."].join(" ")},len:{valType:"number",min:0,dflt:1,description:["Sets the length of the color bar","This measure excludes the padding of both ends.","That is, the color bar length is this length minus the","padding on both ends."].join(" ")},x:{valType:"number",description:["Sets the x position with respect to `xref` of the color bar (in plot fraction).","When `xref` is *paper*, defaults to 1.02 when `orientation` is *v* and","0.5 when `orientation` is *h*.","When `xref` is *container*, defaults to *1* when `orientation` is *v* and","0.5 when `orientation` is *h*.","Must be between *0* and *1* if `xref` is *container*","and between *-2* and *3* if `xref` is *paper*."].join(" ")},xref:{valType:"enumerated",dflt:"paper",values:["container","paper"],editType:"layoutstyle",description:["Sets the container `x` refers to.","*container* spans the entire `width` of the plot.","*paper* refers to the width of the plotting area only."].join(" ")},xanchor:{valType:"enumerated",values:["left","center","right"],description:["Sets this color bar's horizontal position anchor.","This anchor binds the `x` position to the *left*, *center*","or *right* of the color bar.","Defaults to *left* when `orientation` is *v* and","*center* when `orientation` is *h*."].join(" ")},xpad:{valType:"number",min:0,dflt:10,description:"Sets the amount of padding (in px) along the x direction."},y:{valType:"number",description:["Sets the y position with respect to `yref` of the color bar (in plot fraction).","When `yref` is *paper*, defaults to 0.5 when `orientation` is *v* and","1.02 when `orientation` is *h*.","When `yref` is *container*, defaults to 0.5 when `orientation` is *v* and","1 when `orientation` is *h*.","Must be between *0* and *1* if `yref` is *container*","and between *-2* and *3* if `yref` is *paper*."].join(" ")},yref:{valType:"enumerated",dflt:"paper",values:["container","paper"],editType:"layoutstyle",description:["Sets the container `y` refers to.","*container* spans the entire `height` of the plot.","*paper* refers to the height of the plotting area only."].join(" ")},yanchor:{valType:"enumerated",values:["top","middle","bottom"],description:["Sets this color bar's vertical position anchor","This anchor binds the `y` position to the *top*, *middle*","or *bottom* of the color bar.","Defaults to *middle* when `orientation` is *v* and","*bottom* when `orientation` is *h*."].join(" ")},ypad:{valType:"number",min:0,dflt:10,description:"Sets the amount of padding (in px) along the y direction."},outlinecolor:n.linecolor,outlinewidth:n.linewidth,bordercolor:n.linecolor,borderwidth:{valType:"number",min:0,dflt:0,description:["Sets the width (in px) or the border enclosing this color bar."].join(" ")},bgcolor:{valType:"color",dflt:"rgba(0,0,0,0)",description:"Sets the color of padded area."},tickmode:n.minor.tickmode,nticks:n.nticks,tick0:n.tick0,dtick:n.dtick,tickvals:n.tickvals,ticktext:n.ticktext,ticks:o({},n.ticks,{dflt:""}),ticklabeloverflow:o({},n.ticklabeloverflow,{description:["Determines how we handle tick labels that would overflow either the graph div or the domain of the axis.","The default value for inside tick labels is *hide past domain*.","In other cases the default is *hide past div*."].join(" ")}),ticklabelposition:{valType:"enumerated",values:["outside","inside","outside top","inside top","outside left","inside left","outside right","inside right","outside bottom","inside bottom"],dflt:"outside",description:["Determines where tick labels are drawn relative to the ticks.","Left and right options are used when `orientation` is *h*,","top and bottom when `orientation` is *v*."].join(" ")},ticklen:n.ticklen,tickwidth:n.tickwidth,tickcolor:n.tickcolor,ticklabelstep:n.ticklabelstep,showticklabels:n.showticklabels,labelalias:n.labelalias,tickfont:i({description:"Sets the color bar's tick label font"}),tickangle:n.tickangle,tickformat:n.tickformat,tickformatstops:n.tickformatstops,tickprefix:n.tickprefix,showtickprefix:n.showtickprefix,ticksuffix:n.ticksuffix,showticksuffix:n.showticksuffix,separatethousands:n.separatethousands,exponentformat:n.exponentformat,minexponent:n.minexponent,showexponent:n.showexponent,title:{text:{valType:"string",description:["Sets the title of the color bar.","Note that before the existence of `title.text`, the title's","contents used to be defined as the `title` attribute itself.","This behavior has been deprecated."].join(" ")},font:i({description:["Sets this color bar's title font.","Note that the title's font used to be set","by the now deprecated `titlefont` attribute."].join(" ")}),side:{valType:"enumerated",values:["right","top","bottom"],description:["Determines the location of color bar's title","with respect to the color bar.","Defaults to *top* when `orientation` if *v* and ","defaults to *right* when `orientation` if *h*.","Note that the title's location used to be set","by the now deprecated `titleside` attribute."].join(" ")}},_deprecated:{title:{valType:"string",description:["Deprecated in favor of color bar's `title.text`.","Note that value of color bar's `title` is no longer a simple","*string* but a set of sub-attributes."].join(" ")},titlefont:i({description:"Deprecated in favor of color bar's `title.font`."}),titleside:{valType:"enumerated",values:["right","top","bottom"],dflt:"top",description:"Deprecated in favor of color bar's `title.side`."}}},"colorbars","from-root")},22911:e=>{"use strict";e.exports={cn:{colorbar:"colorbar",cbbg:"cbbg",cbfill:"cbfill",cbfills:"cbfills",cbline:"cbline",cblines:"cblines",cbaxis:"cbaxis",cbtitleunshift:"cbtitleunshift",cbtitle:"cbtitle",cboutline:"cboutline",crisp:"crisp",jsPlaceholder:"js-placeholder"}}},97570:(e,t,r)=>{"use strict";var n=r(84468),i=r(37091),o=r(43452),a=r(3118),s=r(83193),l=r(89655),c=r(31797);e.exports=function(e,t,r){var u=i.newContainer(t,"colorbar"),d=e.colorbar||{};function h(e,t){return n.coerce(d,u,c,e,t)}var p=r.margin||{t:0,b:0,l:0,r:0},f=r.width-p.l-p.r,m=r.height-p.t-p.b,g="v"===h("orientation"),y=h("thicknessmode");h("thickness","fraction"===y?30/(g?f:m):30);var v=h("lenmode");h("len","fraction"===v?1:g?m:f);var x,b,_,w="paper"===h("yref"),k="paper"===h("xref"),S="left";g?(_="middle",S=k?"left":"right",x=k?1.02:1,b=.5):(_=w?"bottom":"top",S="center",x=.5,b=w?1.02:1),n.coerce(d,u,{x:{valType:"number",min:k?-2:0,max:k?3:1,dflt:x}},"x"),n.coerce(d,u,{y:{valType:"number",min:w?-2:0,max:w?3:1,dflt:b}},"y"),h("xanchor",S),h("xpad"),h("yanchor",_),h("ypad"),n.noneOrAll(d,u,["x","y"]),h("outlinecolor"),h("outlinewidth"),h("bordercolor"),h("borderwidth"),h("bgcolor");var A=n.coerce(d,u,{ticklabelposition:{valType:"enumerated",dflt:"outside",values:g?["outside","inside","outside top","inside top","outside bottom","inside bottom"]:["outside","inside","outside left","inside left","outside right","inside right"]}},"ticklabelposition");h("ticklabeloverflow",-1!==A.indexOf("inside")?"hide past domain":"hide past div"),o(d,u,h,"linear");var T=r.font,M={noAutotickangles:!0,noTicklabelshift:!0,noTicklabelstandoff:!0,outerTicks:!1,font:T};-1!==A.indexOf("inside")&&(M.bgColor="black"),l(d,u,h,"linear",M),s(d,u,h,"linear",M),a(d,u,h,"linear",M),h("title.text",r._dfltTitle.colorbar);var C=u.showticklabels?u.tickfont:T,E=n.extendFlat({},T,{family:C.family,size:n.bigFont(C.size)});n.coerceFont(h,"title.font",E),h("title.side",g?"top":"right")}},9446:(e,t,r)=>{"use strict";var n=r(41871),i=r(23498),o=r(68543),a=r(38361),s=r(85729),l=r(25732),c=r(84468),u=c.strTranslate,d=r(64022).extendFlat,h=r(29454),p=r(3172),f=r(7605),m=r(13701),g=r(13480),y=r(73084).flipScale,v=r(42730),x=r(44528),b=r(49080),_=r(83943),w=_.LINE_SPACING,k=_.FROM_TL,S=_.FROM_BR,A=r(22911).cn;e.exports={draw:function(e){var t=e._fullLayout._infolayer.selectAll("g."+A.colorbar).data(function(e){var t,r,n,i,o=e._fullLayout,a=e.calcdata,s=[];function l(e){return d(e,{_fillcolor:null,_line:{color:null,width:null,dash:null},_levels:{start:null,end:null,size:null},_filllevels:null,_fillgradient:null,_zrange:null})}function c(){"function"===typeof i.calc?i.calc(e,n,t):(t._fillgradient=r.reversescale?y(r.colorscale):r.colorscale,t._zrange=[r[i.min],r[i.max]])}for(var u=0;u0?n>=l:n<=l));i++)n>u&&n0?n>=l:n<=l));i++)n>r[0]&&n1){var pe=Math.pow(10,Math.floor(Math.log(he)/Math.LN10));ue*=pe*c.roundUp(he/pe,[2,5,10]),(Math.abs(q.start)/q.size+1e-6)%1<2e-6&&(le.tick0=0)}le.dtick=ue}le.domain=a?[ae+O/F.h,ae+Q-O/F.h]:[ae+P/F.w,ae+Q-P/F.w],le.setScale(),e.attr("transform",u(Math.round(F.l),Math.round(F.t)));var fe,me=e.select("."+A.cbtitleunshift).attr("transform",u(-Math.round(F.l),-Math.round(F.t))),ge=le.ticklabelposition,ye=le.title.font.size,ve=e.select("."+A.cbaxis),xe=0,be=0;function _e(n,i){var o={propContainer:le,propName:t._propPrefix+"title",traceIndex:t._traceIndex,_meta:t._meta,placeholder:j._dfltTitle.colorbar,containerGroup:e.select("."+A.cbtitle)},a="h"===n.charAt(0)?n.substr(1):"h"+n;e.selectAll("."+a+",."+a+"-math-group").remove(),m.draw(r,n,d(o,i||{}))}function we(){var e,t;(a&&ce||!a&&!ce)&&("top"===U&&(e=P+F.l+ee*R,t=O+F.t+te*(1-ae-Q)+3+.75*ye),"bottom"===U&&(e=P+F.l+ee*R,t=O+F.t+te*(1-ae)-3-.25*ye),"right"===U&&(t=O+F.t+te*L+3+.75*ye,e=P+F.l+ee*ae),_e(le._id+"title",{attributes:{x:e,y:t,"text-anchor":a?"start":"middle"}}))}function ke(){if(a&&!ce||!a&&ce){var e,i,o=le.position||0,s=le._offset+le._length/2;if("right"===U)i=s,e=F.l+ee*o+10+ye*(le.showticklabels?1:.5);else if(e=s,"bottom"===U&&(i=F.t+te*o+10+(-1===ge.indexOf("inside")?le.tickfont.size:0)+("intside"!==le.ticks&&t.ticklen||0)),"top"===U){var l=V.text.split("
").length;i=F.t+te*o+10-Z-w*ye*l}_e((a?"h":"v")+le._id+"title",{avoid:{selection:n.select(r).selectAll("g."+le._id+"tick"),side:U,offsetTop:a?0:F.t,offsetLeft:a?F.l:0,maxShift:a?j.width:j.height},attributes:{x:e,y:i,"text-anchor":"middle"},transform:{rotate:a?-90:0,offset:0}})}}function Se(){if(!a&&!ce||a&&ce){var o,l=e.select("."+A.cbtitle),d=l.select("text"),h=[-T/2,T/2],f=l.select(".h"+le._id+"title-math-group").node(),m=15.6;if(d.node()&&(m=parseInt(d.node().style.fontSize,10)*w),f?(o=p.bBox(f),be=o.width,(xe=o.height)>m&&(h[1]-=(xe-m)/2)):d.node()&&!d.classed(A.jsPlaceholder)&&(o=p.bBox(d.node()),be=o.width,xe=o.height),a){if(xe){if(xe+=5,"top"===U)le.domain[1]-=xe/F.h,h[1]*=-1;else{le.domain[0]+=xe/F.h;var y=g.lineCount(d);h[1]+=(1-y)*m}l.attr("transform",u(h[0],h[1])),le.setScale()}}else be&&("right"===U&&(le.domain[0]+=(be+ye/2)/F.w),l.attr("transform",u(h[0],h[1])),le.setScale())}e.selectAll("."+A.cbfills+",."+A.cblines).attr("transform",a?u(0,Math.round(F.h*(1-le.domain[1]))):u(Math.round(F.w*le.domain[0]),0)),ve.attr("transform",a?u(0,Math.round(-F.t)):u(Math.round(-F.l),0));var v=e.select("."+A.cbfills).selectAll("rect."+A.cbfill).attr("style","").data(Y);v.enter().append("rect").classed(A.cbfill,!0).attr("style",""),v.exit().remove();var x=H.map(le.c2p).map(Math.round).sort((function(e,t){return e-t}));v.each((function(e,o){var s=[0===o?H[0]:(Y[o]+Y[o-1])/2,o===Y.length-1?H[1]:(Y[o]+Y[o+1])/2].map(le.c2p).map(Math.round);a&&(s[1]=c.constrain(s[1]+(s[1]>s[0])?1:-1,x[0],x[1]));var l=n.select(this).attr(a?"x":"y",re).attr(a?"y":"x",n.min(s)).attr(a?"width":"height",Math.max(Z,2)).attr(a?"height":"width",Math.max(n.max(s)-n.min(s),2));if(t._fillgradient)p.gradient(l,r,t._id,a?"vertical":"horizontalreversed",t._fillgradient,"fill");else{var u=W(e).replace("e-","");l.attr("fill",i(u).toHexString())}}));var b=e.select("."+A.cblines).selectAll("path."+A.cbline).data(B.color&&B.width?X:[]);b.enter().append("path").classed(A.cbline,!0),b.exit().remove(),b.each((function(e){var t=re,r=Math.round(le.c2p(e))+B.width/2%1;n.select(this).attr("d","M"+(a?t+","+r:r+","+t)+(a?"h":"v")+Z).call(p.lineGroupStyle,B.width,$(e),B.dash)})),ve.selectAll("g."+le._id+"tick,path").remove();var _=re+Z+(T||0)/2-("outside"===t.ticks?1:0),k=s.calcTicks(le),S=s.getTickSigns(le)[2];return s.drawTicks(r,le,{vals:"inside"===le.ticks?s.clipEnds(le,k):k,layer:ve,path:s.makeTickPath(le,_,S),transFn:s.makeTransTickFn(le)}),s.drawLabels(r,le,{vals:k,layer:ve,transFn:s.makeTransTickLabelFn(le),labelFns:s.makeLabelFns(le,_)})}function Ae(){var n,s=Z+T/2;-1===ge.indexOf("inside")&&(n=p.bBox(ve.node()),s+=a?n.width:n.height),fe=me.select("text");var c=0,d=a&&"top"===U,m=!a&&"right"===U,g=0;if(fe.node()&&!fe.classed(A.jsPlaceholder)){var v,x=me.select(".h"+le._id+"title-math-group").node();x&&(a&&ce||!a&&!ce)?(c=(n=p.bBox(x)).width,v=n.height):(c=(n=p.bBox(me.node())).right-F.l-(a?re:se),v=n.bottom-F.t-(a?se:re),a||"top"!==U||(s+=n.height,g=n.height)),m&&(fe.attr("transform",u(c/2+ye/2,0)),c*=2),s=Math.max(s,a?c:v)}var b=2*(a?P:O)+s+M+T/2,w=0;!a&&V.text&&"bottom"===I&&L<=0&&(b+=w=b/2,g+=w),j._hColorbarMoveTitle=w,j._hColorbarMoveCBTitle=g;var N=M+T,B=(a?re:se)-N/2-(a?P:0),H=(a?se:re)-(a?J:O+g-w);e.select("."+A.cbbg).attr("x",B).attr("y",H).attr(a?"width":"height",Math.max(b-w,2)).attr(a?"height":"width",Math.max(J+N,2)).call(f.fill,C).call(f.stroke,t.bordercolor).style("stroke-width",M);var $=m?Math.max(c-10,0):0;e.selectAll("."+A.cboutline).attr("x",(a?re:se+P)+$).attr("y",(a?se+O-J:re)+(d?xe:0)).attr(a?"width":"height",Math.max(Z,2)).attr(a?"height":"width",Math.max(J-(a?2*O+xe:2*P+$),2)).call(f.stroke,t.outlinecolor).style({fill:"none","stroke-width":T});var W=a?ne*b:0,q=a?0:(1-ie)*b-g;if(W=z?F.l-W:-W,q=D?F.t-q:-q,e.attr("transform",u(W,q)),!a&&(M||i(C).getAlpha()&&!i.equals(j.paper_bgcolor,C))){var G=ve.selectAll("text"),Y=G[0].length,X=e.select("."+A.cbbg).node(),K=p.bBox(X),Q=p.getTranslate(e),ee=2;G.each((function(e,t){var r=0,n=Y-1;if(t===r||t===n){var i,o=p.bBox(this),a=p.getTranslate(this);if(t===n){var s=o.right+a.x;(i=K.right+Q.x+se-M-ee+R-s)>0&&(i=0)}else if(t===r){var l=o.left+a.x;(i=K.left+Q.x+se+M+ee-l)<0&&(i=0)}i&&(Y<3?this.setAttribute("transform","translate("+i+",0) "+this.getAttribute("transform")):this.setAttribute("visibility","hidden"))}}))}var te={},oe=k[E],ae=S[E],ue=k[I],de=S[I],he=b-Z;a?("pixels"===h?(te.y=L,te.t=J*ue,te.b=J*de):(te.t=te.b=0,te.yt=L+l*ue,te.yb=L-l*de),"pixels"===_?(te.x=R,te.l=b*oe,te.r=b*ae):(te.l=he*oe,te.r=he*ae,te.xl=R-y*oe,te.xr=R+y*ae)):("pixels"===h?(te.x=R,te.l=J*oe,te.r=J*ae):(te.l=te.r=0,te.xl=R+l*oe,te.xr=R-l*ae),"pixels"===_?(te.y=1-L,te.t=b*ue,te.b=b*de):(te.t=he*ue,te.b=he*de,te.yt=L-y*ue,te.yb=L+y*de));var pe=t.y<.5?"b":"t",be=t.x<.5?"l":"r";r._fullLayout._reservedMargin[t._id]={};var _e={r:j.width-B-W,l:B+te.r,b:j.height-H-q,t:H+te.b};z&&D?o.autoMargin(r,t._id,te):z?r._fullLayout._reservedMargin[t._id][pe]=_e[pe]:D||a?r._fullLayout._reservedMargin[t._id][be]=_e[be]:r._fullLayout._reservedMargin[t._id][pe]=_e[pe]}return c.syncOrAsync([o.previousPromises,we,Se,ke,o.previousPromises,Ae],r)}(r,t,e);y&&y.then&&(e._promises||[]).push(y),e._context.edits.colorbarPosition&&function(e,t,r){var n,i,o,s="v"===t.orientation,c=r._fullLayout,d=c._size;l.init({element:e.node(),gd:r,prepFn:function(){n=e.attr("transform"),h(e)},moveFn:function(r,a){e.attr("transform",n+u(r,a)),i=l.align((s?t._uFrac:t._vFrac)+r/d.w,s?t._thickFrac:t._lenFrac,0,1,t.xanchor),o=l.align((s?t._vFrac:1-t._uFrac)-a/d.h,s?t._lenFrac:t._thickFrac,0,1,t.yanchor);var c=l.getCursor(i,o,t.xanchor,t.yanchor);h(e,c)},doneFn:function(){if(h(e),void 0!==i&&void 0!==o){var n={};n[t._propPrefix+"x"]=i,n[t._propPrefix+"y"]=o,void 0!==t._traceIndex?a.call("_guiRestyle",r,n,t._traceIndex):a.call("_guiRelayout",r,n)}}})}(r,t,e)})),t.exit().each((function(t){o.autoMargin(e,t._id)})).remove(),t.order()}}},13753:(e,t,r)=>{"use strict";var n=r(84468);e.exports=function(e){return n.isPlainObject(e.colorbar)}},66222:(e,t,r)=>{"use strict";e.exports={moduleType:"component",name:"colorbar",attributes:r(31797),supplyDefaults:r(97570),draw:r(9446).draw,hasColorbar:r(13753)}},6636:(e,t,r)=>{"use strict";var n=r(31797),i=r(51195).counter,o=r(60693),a=r(28538).scales,s=o(a);function l(e){return"`"+e+"`"}e.exports=function(e,t){e=e||"";var r,o,c=(t=t||{}).cLetter||"c",u="onlyIfNumerical"in t?t.onlyIfNumerical:Boolean(e),d="noScale"in t?t.noScale:"marker.line"===e,h="showScaleDflt"in t?t.showScaleDflt:"z"===c,p="string"===typeof t.colorscaleDflt?a[t.colorscaleDflt]:null,f=t.editTypeOverride||"",m=e?e+".":"";"colorAttr"in t?(r=t.colorAttr,o=t.colorAttr):o="in "+l(m+(r={z:"z",c:"color"}[c]));var g=u?" Has an effect only if "+o+" is set to a numerical array.":"",y=c+"auto",v=c+"min",x=c+"max",b=c+"mid",_=l(m+y),w=l(m+v),k=l(m+x),S=w+" and "+k,A={};A[v]=A[x]=void 0;var T={};T[y]=!1;var M={};return"color"===r&&(M.color={valType:"color",arrayOk:!0,editType:f||"style",description:["Sets the",e,"color.","It accepts either a specific color","or an array of numbers that are mapped to the colorscale","relative to the max and min values of the array or relative to",S,"if set."].join(" ")},t.anim&&(M.color.anim=!0)),M[y]={valType:"boolean",dflt:!0,editType:"calc",impliedEdits:A,description:["Determines whether or not the color domain is computed","with respect to the input data (here "+o+") or the bounds set in",S+g,"Defaults to `false` when",S,"are set by the user."].join(" ")},M[v]={valType:"number",dflt:null,editType:f||"plot",impliedEdits:T,description:["Sets the lower bound of the color domain."+g,"Value should have the same units as",o,"and if set,",k,"must be set as well."].join(" ")},M[x]={valType:"number",dflt:null,editType:f||"plot",impliedEdits:T,description:["Sets the upper bound of the color domain."+g,"Value should have the same units as",o,"and if set,",w,"must be set as well."].join(" ")},M[b]={valType:"number",dflt:null,editType:"calc",impliedEdits:A,description:["Sets the mid-point of the color domain by scaling",w,"and/or",k,"to be equidistant to this point."+g,"Value should have the same units as",o+".","Has no effect when",_,"is `false`."].join(" ")},M.colorscale={valType:"colorscale",editType:"calc",dflt:p,impliedEdits:{autocolorscale:!1},description:["Sets the colorscale."+g,"The colorscale must be an array containing","arrays mapping a normalized value to an","rgb, rgba, hex, hsl, hsv, or named color string.","At minimum, a mapping for the lowest (0) and highest (1)","values are required. For example,","`[[0, 'rgb(0,0,255)'], [1, 'rgb(255,0,0)']]`.","To control the bounds of the colorscale in color space,","use",S+".","Alternatively, `colorscale` may be a palette name string","of the following list: "+s+"."].join(" ")},M.autocolorscale={valType:"boolean",dflt:!1!==t.autoColorDflt,editType:"calc",impliedEdits:{colorscale:void 0},description:["Determines whether the colorscale is a default palette (`autocolorscale: true`)","or the palette determined by",l(m+"colorscale")+"."+g,"In case `colorscale` is unspecified or `autocolorscale` is true, the default","palette will be chosen according to whether numbers in the `color` array are","all positive, all negative or mixed."].join(" ")},M.reversescale={valType:"boolean",dflt:!1,editType:"plot",description:["Reverses the color mapping if true."+g,"If true,",w,"will correspond to the last color","in the array and",k,"will correspond to the first color."].join(" ")},d||(M.showscale={valType:"boolean",dflt:h,editType:"calc",description:["Determines whether or not a colorbar is displayed for this trace."+g].join(" ")},M.colorbar=n),t.noColorAxis||(M.coloraxis={valType:"subplotid",regex:i("coloraxis"),dflt:null,editType:"calc",description:["Sets a reference to a shared color axis.","References to these shared color axes are *coloraxis*, *coloraxis2*, *coloraxis3*, etc.","Settings for these shared color axes are set in the layout, under","`layout.coloraxis`, `layout.coloraxis2`, etc.","Note that multiple color scales can be linked to the same color axis."].join(" ")}),M}},95500:(e,t,r)=>{"use strict";var n=r(22036),i=r(84468),o=r(73084).extractOpts;e.exports=function(e,t,r){var a,s=e._fullLayout,l=r.vals,c=r.containerStr,u=c?i.nestedProperty(t,c).get():t,d=o(u),h=!1!==d.auto,p=d.min,f=d.max,m=d.mid,g=function(){return i.aggNums(Math.min,null,l)},y=function(){return i.aggNums(Math.max,null,l)};(void 0===p?p=g():h&&(p=u._colorAx&&n(p)?Math.min(p,g()):g()),void 0===f?f=y():h&&(f=u._colorAx&&n(f)?Math.max(f,y()):y()),h&&void 0!==m&&(f-m>m-p?p=m-(f-m):f-m=0?s.colorscale.sequential:s.colorscale.sequentialminus,d._sync("colorscale",a))}},93408:(e,t,r)=>{"use strict";var n=r(84468),i=r(73084).hasColorscale,o=r(73084).extractOpts;e.exports=function(e,t){function r(e,t){var r=e["_"+t];void 0!==r&&(e[t]=r)}function a(e,i){var a=i.container?n.nestedProperty(e,i.container).get():e;if(a)if(a.coloraxis)a._colorAx=t[a.coloraxis];else{var s=o(a),l=s.auto;(l||void 0===s.min)&&r(a,i.min),(l||void 0===s.max)&&r(a,i.max),s.autocolorscale&&r(a,"colorscale")}}for(var s=0;s{"use strict";var n=r(22036),i=r(84468),o=r(13753),a=r(97570),s=r(28538).isValid,l=r(38361).traceIs;function c(e,t){var r=t.slice(0,t.length-1);return t?i.nestedProperty(e,r).get()||{}:e}e.exports=function e(t,r,u,d,h){var p=h.prefix,f=h.cLetter,m="_module"in r,g=c(t,p),y=c(r,p),v=c(r._template||{},p)||{},x=function(){return delete t.coloraxis,delete r.coloraxis,e(t,r,u,d,h)};if(m){var b=u._colorAxes||{},_=d(p+"coloraxis");if(_){var w=l(r,"contour")&&i.nestedProperty(r,"contours.coloring").get()||"heatmap",k=b[_];return void(k?(k[2].push(x),k[0]!==w&&(k[0]=!1,i.warn(["Ignoring coloraxis:",_,"setting","as it is linked to incompatible colorscales."].join(" ")))):b[_]=[w,r,[x]])}}var S=g[f+"min"],A=g[f+"max"],T=n(S)&&n(A)&&S{"use strict";var n=r(41871),i=r(23498),o=r(22036),a=r(84468),s=r(7605),l=r(28538).isValid;var c=["showscale","autocolorscale","colorscale","reversescale","colorbar"],u=["min","max","mid","auto"];function d(e){var t,r,n,i=e._colorAx,o=i||e,a={};for(r=0;r=0;n--,i++){var o=e[n];r[i]=[1-o[0],o[1]]}return r}function f(e,t){t=t||{};for(var r=e.domain,a=e.range,l=a.length,c=new Array(l),u=0;u{"use strict";var n=r(28538),i=r(73084);e.exports={moduleType:"component",name:"colorscale",attributes:r(6636),layoutAttributes:r(10247),supplyLayoutDefaults:r(14592),handleDefaults:r(16155),crossTraceDefaults:r(93408),calc:r(95500),scales:n.scales,defaultScale:n.defaultScale,getScale:n.get,isValidScale:n.isValid,hasColorscale:i.hasColorscale,extractOpts:i.extractOpts,extractScale:i.extractScale,flipScale:i.flipScale,makeColorScaleFunc:i.makeColorScaleFunc,makeColorScaleFuncFromTrace:i.makeColorScaleFuncFromTrace}},10247:(e,t,r)=>{"use strict";var n=r(64022).extendFlat,i=r(6636),o=r(28538).scales,a="Note that `autocolorscale` must be true for this attribute to work.";e.exports={editType:"calc",colorscale:{editType:"calc",sequential:{valType:"colorscale",dflt:o.Reds,editType:"calc",description:["Sets the default sequential colorscale for positive values.",a].join(" ")},sequentialminus:{valType:"colorscale",dflt:o.Blues,editType:"calc",description:["Sets the default sequential colorscale for negative values.",a].join(" ")},diverging:{valType:"colorscale",dflt:o.RdBu,editType:"calc",description:["Sets the default diverging colorscale.",a].join(" ")}},coloraxis:n({_isSubplotObj:!0,editType:"calc",description:[""].join(" ")},i("",{colorAttr:"corresponding trace color array(s)",noColorAxis:!0,showScaleDflt:!0}))}},14592:(e,t,r)=>{"use strict";var n=r(84468),i=r(37091),o=r(10247),a=r(16155);e.exports=function(e,t){function r(r,i){return n.coerce(e,t,o,r,i)}r("colorscale.sequential"),r("colorscale.sequentialminus"),r("colorscale.diverging");var s,l,c=t._colorAxes;function u(e,t){return n.coerce(s,l,o.coloraxis,e,t)}for(var d in c){var h=c[d];if(h[0])s=e[d]||{},(l=i.newContainer(t,d,"coloraxis"))._name=d,a(s,l,t,u,{prefix:"",cLetter:"c"});else{for(var p=0;p{"use strict";var n=r(23498),i={Greys:[[0,"rgb(0,0,0)"],[1,"rgb(255,255,255)"]],YlGnBu:[[0,"rgb(8,29,88)"],[.125,"rgb(37,52,148)"],[.25,"rgb(34,94,168)"],[.375,"rgb(29,145,192)"],[.5,"rgb(65,182,196)"],[.625,"rgb(127,205,187)"],[.75,"rgb(199,233,180)"],[.875,"rgb(237,248,217)"],[1,"rgb(255,255,217)"]],Greens:[[0,"rgb(0,68,27)"],[.125,"rgb(0,109,44)"],[.25,"rgb(35,139,69)"],[.375,"rgb(65,171,93)"],[.5,"rgb(116,196,118)"],[.625,"rgb(161,217,155)"],[.75,"rgb(199,233,192)"],[.875,"rgb(229,245,224)"],[1,"rgb(247,252,245)"]],YlOrRd:[[0,"rgb(128,0,38)"],[.125,"rgb(189,0,38)"],[.25,"rgb(227,26,28)"],[.375,"rgb(252,78,42)"],[.5,"rgb(253,141,60)"],[.625,"rgb(254,178,76)"],[.75,"rgb(254,217,118)"],[.875,"rgb(255,237,160)"],[1,"rgb(255,255,204)"]],Bluered:[[0,"rgb(0,0,255)"],[1,"rgb(255,0,0)"]],RdBu:[[0,"rgb(5,10,172)"],[.35,"rgb(106,137,247)"],[.5,"rgb(190,190,190)"],[.6,"rgb(220,170,132)"],[.7,"rgb(230,145,90)"],[1,"rgb(178,10,28)"]],Reds:[[0,"rgb(220,220,220)"],[.2,"rgb(245,195,157)"],[.4,"rgb(245,160,105)"],[1,"rgb(178,10,28)"]],Blues:[[0,"rgb(5,10,172)"],[.35,"rgb(40,60,190)"],[.5,"rgb(70,100,245)"],[.6,"rgb(90,120,245)"],[.7,"rgb(106,137,247)"],[1,"rgb(220,220,220)"]],Picnic:[[0,"rgb(0,0,255)"],[.1,"rgb(51,153,255)"],[.2,"rgb(102,204,255)"],[.3,"rgb(153,204,255)"],[.4,"rgb(204,204,255)"],[.5,"rgb(255,255,255)"],[.6,"rgb(255,204,255)"],[.7,"rgb(255,153,255)"],[.8,"rgb(255,102,204)"],[.9,"rgb(255,102,102)"],[1,"rgb(255,0,0)"]],Rainbow:[[0,"rgb(150,0,90)"],[.125,"rgb(0,0,200)"],[.25,"rgb(0,25,255)"],[.375,"rgb(0,152,255)"],[.5,"rgb(44,255,150)"],[.625,"rgb(151,255,0)"],[.75,"rgb(255,234,0)"],[.875,"rgb(255,111,0)"],[1,"rgb(255,0,0)"]],Portland:[[0,"rgb(12,51,131)"],[.25,"rgb(10,136,186)"],[.5,"rgb(242,211,56)"],[.75,"rgb(242,143,56)"],[1,"rgb(217,30,30)"]],Jet:[[0,"rgb(0,0,131)"],[.125,"rgb(0,60,170)"],[.375,"rgb(5,255,255)"],[.625,"rgb(255,255,0)"],[.875,"rgb(250,0,0)"],[1,"rgb(128,0,0)"]],Hot:[[0,"rgb(0,0,0)"],[.3,"rgb(230,0,0)"],[.6,"rgb(255,210,0)"],[1,"rgb(255,255,255)"]],Blackbody:[[0,"rgb(0,0,0)"],[.2,"rgb(230,0,0)"],[.4,"rgb(230,210,0)"],[.7,"rgb(255,255,255)"],[1,"rgb(160,200,255)"]],Earth:[[0,"rgb(0,0,130)"],[.1,"rgb(0,180,180)"],[.2,"rgb(40,210,40)"],[.4,"rgb(230,230,50)"],[.6,"rgb(120,70,20)"],[1,"rgb(255,255,255)"]],Electric:[[0,"rgb(0,0,0)"],[.15,"rgb(30,0,100)"],[.4,"rgb(120,0,100)"],[.6,"rgb(160,90,0)"],[.8,"rgb(230,200,0)"],[1,"rgb(255,250,220)"]],Viridis:[[0,"#440154"],[.06274509803921569,"#48186a"],[.12549019607843137,"#472d7b"],[.18823529411764706,"#424086"],[.25098039215686274,"#3b528b"],[.3137254901960784,"#33638d"],[.3764705882352941,"#2c728e"],[.4392156862745098,"#26828e"],[.5019607843137255,"#21918c"],[.5647058823529412,"#1fa088"],[.6274509803921569,"#28ae80"],[.6901960784313725,"#3fbc73"],[.7529411764705882,"#5ec962"],[.8156862745098039,"#84d44b"],[.8784313725490196,"#addc30"],[.9411764705882353,"#d8e219"],[1,"#fde725"]],Cividis:[[0,"rgb(0,32,76)"],[.058824,"rgb(0,42,102)"],[.117647,"rgb(0,52,110)"],[.176471,"rgb(39,63,108)"],[.235294,"rgb(60,74,107)"],[.294118,"rgb(76,85,107)"],[.352941,"rgb(91,95,109)"],[.411765,"rgb(104,106,112)"],[.470588,"rgb(117,117,117)"],[.529412,"rgb(131,129,120)"],[.588235,"rgb(146,140,120)"],[.647059,"rgb(161,152,118)"],[.705882,"rgb(176,165,114)"],[.764706,"rgb(192,177,109)"],[.823529,"rgb(209,191,102)"],[.882353,"rgb(225,204,92)"],[.941176,"rgb(243,219,79)"],[1,"rgb(255,233,69)"]]},o=i.RdBu;function a(e){var t=0;if(!Array.isArray(e)||e.length<2)return!1;if(!e[0]||!e[e.length-1])return!1;if(0!==+e[0][0]||1!==+e[e.length-1][0])return!1;for(var r=0;r{"use strict";e.exports=function(e,t,r,n,i){var o=(e-r)/(n-r),a=o+t/(n-r),s=(o+a)/2;return"left"===i||"bottom"===i?o:"center"===i||"middle"===i?s:"right"===i||"top"===i?a:o<2/3-s?o:a>4/3-s?a:s}},34240:(e,t,r)=>{"use strict";var n=r(84468),i=[["sw-resize","s-resize","se-resize"],["w-resize","move","e-resize"],["nw-resize","n-resize","ne-resize"]];e.exports=function(e,t,r,o){return e="left"===r?0:"center"===r?1:"right"===r?2:n.constrain(Math.floor(3*e),0,2),t="bottom"===o?0:"middle"===o?1:"top"===o?2:n.constrain(Math.floor(3*t),0,2),i[t][e]}},2705:(e,t)=>{"use strict";t.selectMode=function(e){return"lasso"===e||"select"===e},t.drawMode=function(e){return"drawclosedpath"===e||"drawopenpath"===e||"drawline"===e||"drawrect"===e||"drawcircle"===e},t.openMode=function(e){return"drawline"===e||"drawopenpath"===e},t.rectMode=function(e){return"select"===e||"drawline"===e||"drawrect"===e||"drawcircle"===e},t.freeMode=function(e){return"lasso"===e||"drawclosedpath"===e||"drawopenpath"===e},t.selectingOrDrawing=function(e){return t.freeMode(e)||t.rectMode(e)}},25732:(e,t,r)=>{"use strict";var n=r(58530),i=r(59283),o=r(17390),a=r(84468).removeElement,s=r(93143),l=e.exports={};l.align=r(17645),l.getCursor=r(34240);var c=r(1751);function u(){var e=document.createElement("div");e.className="dragcover";var t=e.style;return t.position="fixed",t.left=0,t.right=0,t.top=0,t.bottom=0,t.zIndex=999999999,t.background="none",document.body.appendChild(e),e}function d(e){return n(e.changedTouches?e.changedTouches[0]:e,document.body)}l.unhover=c.wrapped,l.unhoverRaw=c.raw,l.init=function(e){var t,r,n,c,h,p,f,m,g=e.gd,y=1,v=g._context.doubleClickDelay,x=e.element;g._mouseDownTime||(g._mouseDownTime=0),x.style.pointerEvents="all",x.onmousedown=_,o?(x._ontouchstart&&x.removeEventListener("touchstart",x._ontouchstart),x._ontouchstart=_,x.addEventListener("touchstart",_,{passive:!1})):x.ontouchstart=_;var b=e.clampFn||function(e,t,r){return Math.abs(e)v&&(y=Math.max(y-1,1)),g._dragged)e.doneFn&&e.doneFn();else if(e.clickFn&&e.clickFn(y,p),!m){var r;try{r=new MouseEvent("click",t)}catch(o){var n=d(t);(r=document.createEvent("MouseEvents")).initMouseEvent("click",t.bubbles,t.cancelable,t.view,t.detail,t.screenX,t.screenY,n[0],n[1],t.ctrlKey,t.altKey,t.shiftKey,t.metaKey,t.button,t.relatedTarget)}f.dispatchEvent(r)}g._dragging=!1,g._dragged=!1}else g._dragged=!1}},l.coverSlip=u},1751:(e,t,r)=>{"use strict";var n=r(13711),i=r(95938),o=r(51124).getGraphDiv,a=r(99961),s=e.exports={};s.wrapped=function(e,t,r){(e=o(e))._fullLayout&&i.clear(e._fullLayout._uid+a.HOVERID),s.raw(e,t,r)},s.raw=function(e,t){var r=e._fullLayout,i=e._hoverdata;t||(t={}),t.target&&!e._dragged&&!1===n.triggerHandler(e,"plotly_beforehover",t)||(r._hoverlayer.selectAll("g").remove(),r._hoverlayer.selectAll("line").remove(),r._hoverlayer.selectAll("circle").remove(),e._hoverdata=void 0,t.target&&i&&e.emit("plotly_unhover",{event:t,points:i}))}},2703:(e,t)=>{"use strict";t.T={valType:"string",values:["solid","dot","dash","longdash","dashdot","longdashdot"],dflt:"solid",editType:"style",description:["Sets the dash style of lines. Set to a dash type string","(*solid*, *dot*, *dash*, *longdash*, *dashdot*, or *longdashdot*)","or a dash length list in px (eg *5px,10px,2px,2px*)."].join(" ")},t.k={shape:{valType:"enumerated",values:["","/","\\","x","-","|","+","."],dflt:"",arrayOk:!0,editType:"style",description:["Sets the shape of the pattern fill.","By default, no pattern is used for filling the area."].join(" ")},fillmode:{valType:"enumerated",values:["replace","overlay"],dflt:"replace",editType:"style",description:["Determines whether `marker.color` should be used","as a default to `bgcolor` or a `fgcolor`."].join(" ")},bgcolor:{valType:"color",arrayOk:!0,editType:"style",description:["When there is no colorscale sets the color of background pattern fill.","Defaults to a `marker.color` background when `fillmode` is *overlay*.","Otherwise, defaults to a transparent background."].join(" ")},fgcolor:{valType:"color",arrayOk:!0,editType:"style",description:["When there is no colorscale sets the color of foreground pattern fill.","Defaults to a `marker.color` background when `fillmode` is *replace*.","Otherwise, defaults to dark grey or white","to increase contrast with the `bgcolor`."].join(" ")},fgopacity:{valType:"number",editType:"style",min:0,max:1,description:["Sets the opacity of the foreground pattern fill.","Defaults to a 0.5 when `fillmode` is *overlay*.","Otherwise, defaults to 1."].join(" ")},size:{valType:"number",min:0,dflt:8,arrayOk:!0,editType:"style",description:["Sets the size of unit squares of the pattern fill in pixels,","which corresponds to the interval of repetition of the pattern."].join(" ")},solidity:{valType:"number",min:0,max:1,dflt:.3,arrayOk:!0,editType:"style",description:["Sets the solidity of the pattern fill.","Solidity is roughly the fraction of the area filled by the pattern.","Solidity of 0 shows only the background color without pattern","and solidty of 1 shows only the foreground color without pattern."].join(" ")},editType:"style",description:["Sets the pattern within the marker."].join(" ")}},3172:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468),o=i.numberFormat,a=r(22036),s=r(23498),l=r(38361),c=r(7605),u=r(39265),d=i.strTranslate,h=r(13480),p=r(28795),f=r(83943).LINE_SPACING,m=r(64253).DESELECTDIM,g=r(31811),y=r(14204),v=r(82561).appendArrayPointValue,x=e.exports={};function b(e){return"none"===e?void 0:e}x.font=function(e,t){var r=t.variant,n=t.style,i=t.weight,o=t.color,a=t.size,s=t.family,l=t.shadow,u=t.lineposition,d=t.textcase;s&&e.style("font-family",s),a+1&&e.style("font-size",a+"px"),o&&e.call(c.fill,o),i&&e.style("font-weight",i),n&&e.style("font-style",n),r&&e.style("font-variant",r),d&&e.style("text-transform",b(function(e){return _[e]}(d))),l&&e.style("text-shadow","auto"===l?h.makeTextShadow(c.contrast(o)):b(l)),u&&e.style("text-decoration-line",b(function(e){return e.replace("under","underline").replace("over","overline").replace("through","line-through").split("+").join(" ")}(u)))};var _={normal:"none",lower:"lowercase",upper:"uppercase","word caps":"capitalize"};function w(e,t,r,n){var i=t.fillpattern,o=t.fillgradient,a=i&&x.getPatternAttr(i.shape,0,"");if(a){var s=x.getPatternAttr(i.bgcolor,0,null),l=x.getPatternAttr(i.fgcolor,0,null),u=i.fgopacity,d=x.getPatternAttr(i.size,0,8),h=x.getPatternAttr(i.solidity,0,.3),p=t.uid;x.pattern(e,"point",r,p,a,d,h,void 0,i.fillmode,s,l,u)}else if(o&&"none"!==o.type){var f,m,g=o.type,y="scatterfill-"+t.uid;if(n&&(y="legendfill-"+t.uid),n||void 0===o.start&&void 0===o.stop)"horizontal"===g&&(g+="reversed"),e.call(x.gradient,r,y,g,o.colorscale,"fill");else"horizontal"===g?(f={x:o.start,y:0},m={x:o.stop,y:0}):"vertical"===g&&(f={x:0,y:o.start},m={x:0,y:o.stop}),f.x=t._xA.c2p(void 0===f.x?t._extremes.x.min[0].val:f.x,!0),f.y=t._yA.c2p(void 0===f.y?t._extremes.y.min[0].val:f.y,!0),m.x=t._xA.c2p(void 0===m.x?t._extremes.x.max[0].val:m.x,!0),m.y=t._yA.c2p(void 0===m.y?t._extremes.y.max[0].val:m.y,!0),e.call(C,r,y,"linear",o.colorscale,"fill",f,m,!0,!1)}else t.fillcolor&&e.call(c.fill,t.fillcolor)}x.setPosition=function(e,t,r){e.attr("x",t).attr("y",r)},x.setSize=function(e,t,r){e.attr("width",t).attr("height",r)},x.setRect=function(e,t,r,n,i){e.call(x.setPosition,t,r).call(x.setSize,n,i)},x.translatePoint=function(e,t,r,n){var i=r.c2p(e.x),o=n.c2p(e.y);return!!(a(i)&&a(o)&&t.node())&&("text"===t.node().nodeName?t.attr("x",i).attr("y",o):t.attr("transform",d(i,o)),!0)},x.translatePoints=function(e,t,r){e.each((function(e){var i=n.select(this);x.translatePoint(e,i,t,r)}))},x.hideOutsideRangePoint=function(e,t,r,n,i,o){t.attr("display",r.isPtWithinRange(e,i)&&n.isPtWithinRange(e,o)?null:"none")},x.hideOutsideRangePoints=function(e,t){if(t._hasClipOnAxisFalse){var r=t.xaxis,i=t.yaxis;e.each((function(t){var o=t[0].trace,a=o.xcalendar,s=o.ycalendar,c=l.traceIs(o,"bar-like")?".bartext":".point,.textpoint";e.selectAll(c).each((function(e){x.hideOutsideRangePoint(e,n.select(this),r,i,a,s)}))}))}},x.crispRound=function(e,t,r){return t&&a(t)?e._context.staticPlot?t:t<1?1:Math.round(t):r||0},x.singleLineStyle=function(e,t,r,n,i){t.style("fill","none");var o=(((e||[])[0]||{}).trace||{}).line||{},a=r||o.width||0,s=i||o.dash||"";c.stroke(t,n||o.color),x.dashLine(t,s,a)},x.lineGroupStyle=function(e,t,r,i){e.style("fill","none").each((function(e){var o=(((e||[])[0]||{}).trace||{}).line||{},a=t||o.width||0,s=i||o.dash||"";n.select(this).call(c.stroke,r||o.color).call(x.dashLine,s,a)}))},x.dashLine=function(e,t,r){r=+r||0,t=x.dashStyle(t,r),e.style({"stroke-dasharray":t,"stroke-width":r+"px"})},x.dashStyle=function(e,t){t=+t||1;var r=Math.max(t,3);return"solid"===e?e="":"dot"===e?e=r+"px,"+r+"px":"dash"===e?e=3*r+"px,"+3*r+"px":"longdash"===e?e=5*r+"px,"+5*r+"px":"dashdot"===e?e=3*r+"px,"+r+"px,"+r+"px,"+r+"px":"longdashdot"===e&&(e=5*r+"px,"+2*r+"px,"+r+"px,"+2*r+"px"),e},x.singleFillStyle=function(e,t){var r=n.select(e.node());w(e,((r.data()[0]||[])[0]||{}).trace||{},t,!1)},x.fillGroupStyle=function(e,t,r){e.style("stroke-width",0).each((function(e){var i=n.select(this);e[0].trace&&w(i,e[0].trace,t,r)}))};var k=r(54309);x.symbolNames=[],x.symbolFuncs=[],x.symbolBackOffs=[],x.symbolNeedLines={},x.symbolNoDot={},x.symbolNoFill={},x.symbolList=[],Object.keys(k).forEach((function(e){var t=k[e],r=t.n;x.symbolList.push(r,String(r),e,r+100,String(r+100),e+"-open"),x.symbolNames[r]=e,x.symbolFuncs[r]=t.f,x.symbolBackOffs[r]=t.backoff||0,t.needLine&&(x.symbolNeedLines[r]=!0),t.noDot?x.symbolNoDot[r]=!0:x.symbolList.push(r+200,String(r+200),e+"-dot",r+300,String(r+300),e+"-open-dot"),t.noFill&&(x.symbolNoFill[r]=!0)}));var S=x.symbolNames.length;function A(e,t,r,n){var i=e%100;return x.symbolFuncs[i](t,r,n)+(e>=200?"M0,0.5L0.5,0L0,-0.5L-0.5,0Z":"")}x.symbolNumber=function(e){if(a(e))e=+e;else if("string"===typeof e){var t=0;e.indexOf("-open")>0&&(t=100,e=e.replace("-open","")),e.indexOf("-dot")>0&&(t+=200,e=e.replace("-dot","")),(e=x.symbolNames.indexOf(e))>=0&&(e+=t)}return e%100>=S||e>=400?0:Math.floor(Math.max(e,0))};var T=o("~f"),M={radial:{type:"radial"},radialreversed:{type:"radial",reversed:!0},horizontal:{type:"linear",start:{x:1,y:0},stop:{x:0,y:0}},horizontalreversed:{type:"linear",start:{x:1,y:0},stop:{x:0,y:0},reversed:!0},vertical:{type:"linear",start:{x:0,y:1},stop:{x:0,y:0}},verticalreversed:{type:"linear",start:{x:0,y:1},stop:{x:0,y:0},reversed:!0}};function C(e,t,r,o,a,l,u,d,h,p){var f,m=a.length;"linear"===o?f={node:"linearGradient",attrs:{x1:u.x,y1:u.y,x2:d.x,y2:d.y,gradientUnits:h?"userSpaceOnUse":"objectBoundingBox"},reversed:p}:"radial"===o&&(f={node:"radialGradient",reversed:p});for(var g=new Array(m),y=0;y=0&&void 0===e.i&&(e.i=a.i),t.style("opacity",n.selectedOpacityFn?n.selectedOpacityFn(e):void 0===e.mo?s.opacity:e.mo),n.ms2mrc){var u;u="various"===e.ms||"various"===s.size?3:n.ms2mrc(e.ms),e.mrc=u,n.selectedSizeFn&&(u=e.mrc=n.selectedSizeFn(e));var d=x.symbolNumber(e.mx||s.symbol)||0;e.om=d%200>=100;var h=ne(e,r),p=q(e,r);t.attr("d",A(d,u,h,p))}var f,m,g,y=!1;if(e.so)g=l.outlierwidth,m=l.outliercolor,f=s.outliercolor;else{var v=(l||{}).width;g=(e.mlw+1||v+1||(e.trace?(e.trace.marker.line||{}).width:0)+1)-1||0,m="mlc"in e?e.mlcc=n.lineScale(e.mlc):i.isArrayOrTypedArray(l.color)?c.defaultLine:l.color,i.isArrayOrTypedArray(s.color)&&(f=c.defaultLine,y=!0),f="mc"in e?e.mcc=n.markerScale(e.mc):s.color||s.colors||"rgba(0,0,0,0)",n.selectedColorFn&&(f=n.selectedColorFn(e))}if(e.om)t.call(c.stroke,f).style({"stroke-width":(g||1)+"px",fill:"none"});else{t.style("stroke-width",(e.isBlank?0:g)+"px");var b=s.gradient,_=e.mgt;_?y=!0:_=b&&b.type,i.isArrayOrTypedArray(_)&&(_=_[0],M[_]||(_=0));var w=s.pattern,k=w&&x.getPatternAttr(w.shape,e.i,"");if(_&&"none"!==_){var S=e.mgc;S?y=!0:S=b.color;var T=r.uid;y&&(T+="-"+e.i),x.gradient(t,o,T,_,[[0,S],[1,f]],"fill")}else if(k){var C=!1,E=w.fgcolor;!E&&a&&a.color&&(E=a.color,C=!0);var I=x.getPatternAttr(E,e.i,a&&a.color||null),P=x.getPatternAttr(w.bgcolor,e.i,null),O=w.fgopacity,R=x.getPatternAttr(w.size,e.i,8),L=x.getPatternAttr(w.solidity,e.i,.3);C=C||e.mcc||i.isArrayOrTypedArray(w.shape)||i.isArrayOrTypedArray(w.bgcolor)||i.isArrayOrTypedArray(w.fgcolor)||i.isArrayOrTypedArray(w.size)||i.isArrayOrTypedArray(w.solidity);var D=r.uid;C&&(D+="-"+e.i),x.pattern(t,"point",o,D,k,R,L,e.mcc,w.fillmode,P,I,O)}else i.isArrayOrTypedArray(f)?c.fill(t,f[e.i]):c.fill(t,f);g&&c.stroke(t,m)}},x.makePointStyleFns=function(e){var t={},r=e.marker;return t.markerScale=x.tryColorscale(r,""),t.lineScale=x.tryColorscale(r,"line"),l.traceIs(e,"symbols")&&(t.ms2mrc=g.isBubble(e)?y(e):function(){return(r.size||6)/2}),e.selectedpoints&&i.extendFlat(t,x.makeSelectedPointStyleFns(e)),t},x.makeSelectedPointStyleFns=function(e){var t={},r=e.selected||{},n=e.unselected||{},o=e.marker||{},a=r.marker||{},s=n.marker||{},c=o.opacity,u=a.opacity,d=s.opacity,h=void 0!==u,p=void 0!==d;(i.isArrayOrTypedArray(c)||h||p)&&(t.selectedOpacityFn=function(e){var t=void 0===e.mo?o.opacity:e.mo;return e.selected?h?u:t:p?d:m*t});var f=o.color,g=a.color,y=s.color;(g||y)&&(t.selectedColorFn=function(e){var t=e.mcc||f;return e.selected?g||t:y||t});var v=o.size,x=a.size,b=s.size,_=void 0!==x,w=void 0!==b;return l.traceIs(e,"symbols")&&(_||w)&&(t.selectedSizeFn=function(e){var t=e.mrc||v/2;return e.selected?_?x/2:t:w?b/2:t}),t},x.makeSelectedTextStyleFns=function(e){var t={},r=e.selected||{},n=e.unselected||{},i=e.textfont||{},o=r.textfont||{},a=n.textfont||{},s=i.color,l=o.color,u=a.color;return t.selectedTextColorFn=function(e){var t=e.tc||s;return e.selected?l||t:u||(l?t:c.addOpacity(t,m))},t},x.selectedPointStyle=function(e,t){if(e.size()&&t.selectedpoints){var r=x.makeSelectedPointStyleFns(t),i=t.marker||{},o=[];r.selectedOpacityFn&&o.push((function(e,t){e.style("opacity",r.selectedOpacityFn(t))})),r.selectedColorFn&&o.push((function(e,t){c.fill(e,r.selectedColorFn(t))})),r.selectedSizeFn&&o.push((function(e,n){var o=n.mx||i.symbol||0,a=r.selectedSizeFn(n);e.attr("d",A(x.symbolNumber(o),a,ne(n,t),q(n,t))),n.mrc2=a})),o.length&&e.each((function(e){for(var t=n.select(this),r=0;r0?r:0}x.textPointStyle=function(e,t,r){if(e.size()){var o;if(t.selectedpoints){var a=x.makeSelectedTextStyleFns(t);o=a.selectedTextColorFn}var s=t.texttemplate,l=r._fullLayout;e.each((function(e){var a=n.select(this),c=s?i.extractOption(e,t,"txt","texttemplate"):i.extractOption(e,t,"tx","text");if(c||0===c){if(s){var u=t._module.formatLabels,d=u?u(e,t,l):{},p={};v(p,t,e.i);var f=t._meta||{};c=i.texttemplateString(c,d,l._d3locale,p,e,f)}var m=e.tp||t.textposition,g=P(e,t),y=o?o(e):e.tc||t.textfont.color;a.call(x.font,{family:e.tf||t.textfont.family,weight:e.tw||t.textfont.weight,style:e.ty||t.textfont.style,variant:e.tv||t.textfont.variant,textcase:e.tC||t.textfont.textcase,lineposition:e.tE||t.textfont.lineposition,shadow:e.tS||t.textfont.shadow,size:g,color:y}).text(c).call(h.convertToTspans,r).call(I,m,g,e.mrc)}else a.remove()}))}},x.selectedTextStyle=function(e,t){if(e.size()&&t.selectedpoints){var r=x.makeSelectedTextStyleFns(t);e.each((function(e){var i=n.select(this),o=r.selectedTextColorFn(e),a=e.tp||t.textposition,s=P(e,t);c.fill(i,o);var u=l.traceIs(t,"bar-like");I(i,a,s,e.mrc2||e.mrc,u)}))}};var O,R;function L(e,t,r){return r&&(e=B(e)),t?z(e[1]):D(e[0])}function D(e){var t=n.round(e,2);return O=t,t}function z(e){var t=n.round(e,2);return R=t,t}function j(e,t,r,n){var i=e[0]-t[0],o=e[1]-t[1],a=r[0]-t[0],s=r[1]-t[1],l=Math.pow(i*i+o*o,.25),c=Math.pow(a*a+s*s,.25),u=(c*c*i-l*l*a)*n,d=(c*c*o-l*l*s)*n,h=3*c*(l+c),p=3*l*(l+c);return[[D(t[0]+(h&&u/h)),z(t[1]+(h&&d/h))],[D(t[0]-(p&&u/p)),z(t[1]-(p&&d/p))]]}x.smoothopen=function(e,t){if(e.length<3)return"M"+e.join("L");var r,n="M"+e[0],i=[];for(r=1;r=c||w>=d&&w<=c)&&(k<=h&&k>=u||k>=h&&k<=u)&&(e=[w,k])}return e}x.steps=function(e){var t=F[e]||N;return function(e){for(var r="M"+D(e[0][0])+","+z(e[0][1]),n=e.length,i=1;i=1e4&&(x.savedBBoxes={},V=0),r&&(x.savedBBoxes[r]=g),V++,i.extendFlat({},g)},x.setClipUrl=function(e,t,r){e.attr("clip-path",H(t,r))},x.getTranslate=function(e){var t=(e[e.attr?"attr":"getAttribute"]("transform")||"").replace(/.*\btranslate\((-?\d*\.?\d*)[^-\d]*(-?\d*\.?\d*)[^\d].*/,(function(e,t,r){return[t,r].join(" ")})).split(" ");return{x:+t[0]||0,y:+t[1]||0}},x.setTranslate=function(e,t,r){var n=e.attr?"attr":"getAttribute",i=e.attr?"attr":"setAttribute",o=e[n]("transform")||"";return t=t||0,r=r||0,o=o.replace(/(\btranslate\(.*?\);?)/,"").trim(),o=(o+=d(t,r)).trim(),e[i]("transform",o),o},x.getScale=function(e){var t=(e[e.attr?"attr":"getAttribute"]("transform")||"").replace(/.*\bscale\((\d*\.?\d*)[^\d]*(\d*\.?\d*)[^\d].*/,(function(e,t,r){return[t,r].join(" ")})).split(" ");return{x:+t[0]||1,y:+t[1]||1}},x.setScale=function(e,t,r){var n=e.attr?"attr":"getAttribute",i=e.attr?"attr":"setAttribute",o=e[n]("transform")||"";return t=t||1,r=r||1,o=o.replace(/(\bscale\(.*?\);?)/,"").trim(),o=(o+="scale("+t+","+r+")").trim(),e[i]("transform",o),o};var $=/\s*sc.*/;x.setPointGroupScale=function(e,t,r){if(t=t||1,r=r||1,e){var n=1===t&&1===r?"":"scale("+t+","+r+")";e.each((function(){var e=(this.getAttribute("transform")||"").replace($,"");e=(e+=n).trim(),this.setAttribute("transform",e)}))}};var W=/translate\([^)]*\)\s*$/;function q(e,t){var r;return e&&(r=e.mf),void 0===r&&(r=t.marker&&t.marker.standoff||0),t._geo||t._xA?r:-r}x.setTextPointsScale=function(e,t,r){e&&e.each((function(){var e,i=n.select(this),o=i.select("text");if(o.node()){var a=parseFloat(o.attr("x")||0),s=parseFloat(o.attr("y")||0),l=(i.attr("transform")||"").match(W);e=1===t&&1===r?[]:[d(a,s),"scale("+t+","+r+")",d(-a,-s)],l&&e.push(l),i.attr("transform",e.join(""))}}))},x.getMarkerStandoff=q;var G,Y,X,Z,K,J,Q=Math.atan2,ee=Math.cos,te=Math.sin;function re(e,t){var r=t[0],n=t[1];return[r*ee(e)-n*te(e),r*te(e)+n*ee(e)]}function ne(e,t){var r,n,o=e.ma;void 0===o&&((o=t.marker.angle)&&!i.isArrayOrTypedArray(o)||(o=0));var s=t.marker.angleref;if("previous"===s||"north"===s){if(t._geo){var l=t._geo.project(e.lonlat);r=l[0],n=l[1]}else{var c=t._xA,u=t._yA;if(!c||!u)return 90;r=c.c2p(e.x),n=u.c2p(e.y)}if(t._geo){var d,h=e.lonlat[0],p=e.lonlat[1],f=t._geo.project([h,p+1e-5]),m=t._geo.project([h+1e-5,p]),g=Q(m[1]-n,m[0]-r),y=Q(f[1]-n,f[0]-r);if("north"===s)d=o/180*Math.PI;else if("previous"===s){var v=h/180*Math.PI,x=p/180*Math.PI,b=G/180*Math.PI,_=Y/180*Math.PI,w=b-v,k=ee(_)*te(w),S=te(_)*ee(x)-ee(_)*te(x)*ee(w);d=-Q(k,S)-Math.PI,G=h,Y=p}var A=re(g,[ee(d),0]),T=re(y,[te(d),0]);o=Q(A[1]+T[1],A[0]+T[0])/Math.PI*180,"previous"!==s||J===t.uid&&e.i===K+1||(o=null)}if("previous"===s&&!t._geo)if(J===t.uid&&e.i===K+1&&a(r)&&a(n)){var M=r-X,C=n-Z,E=t.line&&t.line.shape||"",I=E.slice(E.length-1);"h"===I&&(C=0),"v"===I&&(M=0),o+=Q(C,M)/Math.PI*180+90}else o=null}return X=r,Z=n,K=e.i,J=t.uid,o}x.getMarkerAngle=ne},54309:(e,t,r)=>{"use strict";var n,i,o,a,s=r(24100),l=r(41871).round,c="M0,0Z",u=Math.sqrt(2),d=Math.sqrt(3),h=Math.PI,p=Math.cos,f=Math.sin;function m(e){return null===e}function g(e,t,r){if((!e||e%360===0)&&!t)return r;if(o===e&&a===t&&n===r)return i;function l(e,r){var n=p(e),i=f(e),o=r[0],a=r[1]+(t||0);return[o*n-a*i,o*i+a*n]}o=e,a=t,n=r;for(var c=e/180*h,u=0,d=0,m=s(r),g="",y=0;y{"use strict";e.exports={visible:{valType:"boolean",editType:"calc",description:["Determines whether or not this set of error bars is visible."].join(" ")},type:{valType:"enumerated",values:["percent","constant","sqrt","data"],editType:"calc",description:["Determines the rule used to generate the error bars.","If *constant`, the bar lengths are of a constant value.","Set this constant in `value`.","If *percent*, the bar lengths correspond to a percentage of","underlying data. Set this percentage in `value`.","If *sqrt*, the bar lengths correspond to the square of the","underlying data.","If *data*, the bar lengths are set with data set `array`."].join(" ")},symmetric:{valType:"boolean",editType:"calc",description:["Determines whether or not the error bars have the same length","in both direction","(top/bottom for vertical bars, left/right for horizontal bars."].join(" ")},array:{valType:"data_array",editType:"calc",description:["Sets the data corresponding the length of each error bar.","Values are plotted relative to the underlying data."].join(" ")},arrayminus:{valType:"data_array",editType:"calc",description:["Sets the data corresponding the length of each error bar in the","bottom (left) direction for vertical (horizontal) bars","Values are plotted relative to the underlying data."].join(" ")},value:{valType:"number",min:0,dflt:10,editType:"calc",description:["Sets the value of either the percentage","(if `type` is set to *percent*) or the constant","(if `type` is set to *constant*) corresponding to the lengths of","the error bars."].join(" ")},valueminus:{valType:"number",min:0,dflt:10,editType:"calc",description:["Sets the value of either the percentage","(if `type` is set to *percent*) or the constant","(if `type` is set to *constant*) corresponding to the lengths of","the error bars in the","bottom (left) direction for vertical (horizontal) bars"].join(" ")},traceref:{valType:"integer",min:0,dflt:0,editType:"style"},tracerefminus:{valType:"integer",min:0,dflt:0,editType:"style"},copy_ystyle:{valType:"boolean",editType:"plot"},copy_zstyle:{valType:"boolean",editType:"style"},color:{valType:"color",editType:"style",description:"Sets the stoke color of the error bars."},thickness:{valType:"number",min:0,dflt:2,editType:"style",description:"Sets the thickness (in px) of the error bars."},width:{valType:"number",min:0,editType:"plot",description:["Sets the width (in px) of the cross-bar at both ends","of the error bars."].join(" ")},editType:"calc",_deprecated:{opacity:{valType:"number",editType:"style",description:["Obsolete.","Use the alpha channel in error bar `color` to set the opacity."].join(" ")}}}},26997:(e,t,r)=>{"use strict";var n=r(22036),i=r(38361),o=r(85729),a=r(84468),s=r(87078);function l(e,t,r,i){var l=t["error_"+i]||{},c=[];if(l.visible&&-1!==["linear","log"].indexOf(r.type)){for(var u=s(l),d=0;d{"use strict";function t(e,t){return"percent"===e?function(e){return Math.abs(e*t/100)}:"constant"===e?function(){return Math.abs(t)}:"sqrt"===e?function(e){return Math.sqrt(Math.abs(e))}:void 0}e.exports=function(e){var r=e.type,n=e.symmetric;if("data"===r){var i=e.array||[];if(n)return function(e,t){var r=+i[t];return[r,r]};var o=e.arrayminus||[];return function(e,t){var r=+i[t],n=+o[t];return isNaN(r)&&isNaN(n)?[NaN,NaN]:[n||0,r||0]}}var a=t(r,e.value),s=t(r,e.valueminus);return n||void 0===e.valueminus?function(e){var t=a(e);return[t,t]}:function(e){return[s(e),a(e)]}}},88374:(e,t,r)=>{"use strict";var n=r(22036),i=r(38361),o=r(84468),a=r(37091),s=r(81137);e.exports=function(e,t,r,l){var c="error_"+l.axis,u=a.newContainer(t,c),d=e[c]||{};function h(e,t){return o.coerce(d,u,s,e,t)}if(!1!==h("visible",void 0!==d.array||void 0!==d.value||"sqrt"===d.type)){var p=h("type","array"in d?"data":"percent"),f=!0;"sqrt"!==p&&(f=h("symmetric",!(("data"===p?"arrayminus":"valueminus")in d))),"data"===p?(h("array"),h("traceref"),f||(h("arrayminus"),h("tracerefminus"))):"percent"!==p&&"constant"!==p||(h("value"),f||h("valueminus"));var m="copy_"+l.inherit+"style";if(l.inherit)(t["error_"+l.inherit]||{}).visible&&h(m,!(d.color||n(d.thickness)||n(d.width)));l.inherit&&u[m]||(h("color",r),h("thickness"),h("width",i.traceIs(t,"gl3d")?0:4))}}},15554:(e,t,r)=>{"use strict";var n=r(84468),i=r(72587).overrideAll,o=r(81137),a={error_x:n.extendFlat({},o),error_y:n.extendFlat({},o)};delete a.error_x.copy_zstyle,delete a.error_y.copy_zstyle,delete a.error_y.copy_ystyle;var s={error_x:n.extendFlat({},o),error_y:n.extendFlat({},o),error_z:n.extendFlat({},o)};delete s.error_x.copy_ystyle,delete s.error_y.copy_ystyle,delete s.error_z.copy_ystyle,delete s.error_z.copy_zstyle,e.exports={moduleType:"component",name:"errorbars",schema:{traces:{scatter:a,bar:a,histogram:a,scatter3d:i(s,"calc","nested"),scattergl:i(a,"calc","nested")}},supplyDefaults:r(88374),calc:r(26997),makeComputeError:r(87078),plot:r(47387),style:r(76907),hoverInfo:function(e,t,r){(t.error_y||{}).visible&&(r.yerr=e.yh-e.y,t.error_y.symmetric||(r.yerrneg=e.y-e.ys));(t.error_x||{}).visible&&(r.xerr=e.xh-e.x,t.error_x.symmetric||(r.xerrneg=e.x-e.xs))}}},47387:(e,t,r)=>{"use strict";var n=r(41871),i=r(22036),o=r(3172),a=r(31811);e.exports=function(e,t,r,s){var l=r.xaxis,c=r.yaxis,u=s&&s.duration>0,d=e._context.staticPlot;t.each((function(t){var h,p=t[0].trace,f=p.error_x||{},m=p.error_y||{};p.ids&&(h=function(e){return e.id});var g=a.hasMarkers(p)&&p.marker.maxdisplayed>0;m.visible||f.visible||(t=[]);var y=n.select(this).selectAll("g.errorbar").data(t,h);if(y.exit().remove(),t.length){f.visible||y.selectAll("path.xerror").remove(),m.visible||y.selectAll("path.yerror").remove(),y.style("opacity",1);var v=y.enter().append("g").classed("errorbar",!0);u&&v.style("opacity",0).transition().duration(s.duration).style("opacity",1),o.setClipUrl(y,r.layerClipId,e),y.each((function(e){var t=n.select(this),r=function(e,t,r){var n={x:t.c2p(e.x),y:r.c2p(e.y)};void 0!==e.yh&&(n.yh=r.c2p(e.yh),n.ys=r.c2p(e.ys),i(n.ys)||(n.noYS=!0,n.ys=r.c2p(e.ys,!0)));void 0!==e.xh&&(n.xh=t.c2p(e.xh),n.xs=t.c2p(e.xs),i(n.xs)||(n.noXS=!0,n.xs=t.c2p(e.xs,!0)));return n}(e,l,c);if(!g||e.vis){var o,a=t.select("path.yerror");if(m.visible&&i(r.x)&&i(r.yh)&&i(r.ys)){var h=m.width;o="M"+(r.x-h)+","+r.yh+"h"+2*h+"m-"+h+",0V"+r.ys,r.noYS||(o+="m-"+h+",0h"+2*h),!a.size()?a=t.append("path").style("vector-effect",d?"none":"non-scaling-stroke").classed("yerror",!0):u&&(a=a.transition().duration(s.duration).ease(s.easing)),a.attr("d",o)}else a.remove();var p=t.select("path.xerror");if(f.visible&&i(r.y)&&i(r.xh)&&i(r.xs)){var y=(f.copy_ystyle?m:f).width;o="M"+r.xh+","+(r.y-y)+"v"+2*y+"m0,-"+y+"H"+r.xs,r.noXS||(o+="m0,-"+y+"v"+2*y),!p.size()?p=t.append("path").style("vector-effect",d?"none":"non-scaling-stroke").classed("xerror",!0):u&&(p=p.transition().duration(s.duration).ease(s.easing)),p.attr("d",o)}else p.remove()}}))}}))}},76907:(e,t,r)=>{"use strict";var n=r(41871),i=r(7605);e.exports=function(e){e.each((function(e){var t=e[0].trace,r=t.error_y||{},o=t.error_x||{},a=n.select(this);a.selectAll("path.yerror").style("stroke-width",r.thickness+"px").call(i.stroke,r.color),o.copy_ystyle&&(o=r),a.selectAll("path.xerror").style("stroke-width",o.thickness+"px").call(i.stroke,o.color)}))}},25087:(e,t,r)=>{"use strict";var n=r(91740),i=r(97174).hoverlabel,o=r(64022).extendFlat;e.exports={hoverlabel:{bgcolor:o({},i.bgcolor,{arrayOk:!0,description:"Sets the background color of the hover labels for this trace"}),bordercolor:o({},i.bordercolor,{arrayOk:!0,description:"Sets the border color of the hover labels for this trace."}),font:n({arrayOk:!0,editType:"none",description:"Sets the font used in hover labels."}),align:o({},i.align,{arrayOk:!0}),namelength:o({},i.namelength,{arrayOk:!0}),editType:"none"}}},50079:(e,t,r)=>{"use strict";var n=r(84468),i=r(38361);function o(e,t,r,i){i=i||n.identity,Array.isArray(e)&&(t[0][r]=i(e))}e.exports=function(e){var t=e.calcdata,r=e._fullLayout;function a(e){return function(t){return n.coerceHoverinfo({hoverinfo:t},{_module:e._module},r)}}for(var s=0;s{"use strict";var n=r(38361),i=r(12914).hover;e.exports=function(e,t,r){var o=n.getComponentMethod("annotations","onClick")(e,e._hoverdata);function a(){e.emit("plotly_click",{points:e._hoverdata,event:t})}void 0!==r&&i(e,t,r,!0),e._hoverdata&&t&&t.target&&(o&&o.then?o.then(a):a(),t.stopImmediatePropagation&&t.stopImmediatePropagation())}},99961:e=>{"use strict";e.exports={YANGLE:60,HOVERARROWSIZE:6,HOVERTEXTPAD:3,HOVERFONTSIZE:13,HOVERFONT:"Arial, sans-serif",HOVERMINTIME:50,HOVERID:"-hover"}},62168:(e,t,r)=>{"use strict";var n=r(84468),i=r(25087),o=r(15171);e.exports=function(e,t,r,a){var s=n.extendFlat({},a.hoverlabel);t.hovertemplate&&(s.namelength=-1),o(e,t,(function(r,o){return n.coerce(e,t,i,r,o)}),s)}},82561:(e,t,r)=>{"use strict";var n=r(84468);t.getSubplot=function(e){return e.subplot||e.xaxis+e.yaxis||e.geo},t.isTraceInSubplots=function(e,r){if("splom"===e.type){for(var n=e.xaxes||[],i=e.yaxes||[],o=0;o=0&&r.index{"use strict";var n=r(41871),i=r(22036),o=r(23498),a=r(84468),s=a.pushUnique,l=a.strTranslate,c=a.strRotate,u=r(13711),d=r(13480),h=r(54015),p=r(3172),f=r(7605),m=r(25732),g=r(85729),y=r(93143).zindexSeparator,v=r(38361),x=r(82561),b=r(99961),_=r(11217),w=r(81017),k=b.YANGLE,S=Math.PI*k/180,A=1/Math.sin(S),T=Math.cos(S),M=Math.sin(S),C=b.HOVERARROWSIZE,E=b.HOVERTEXTPAD,I={box:!0,ohlc:!0,violin:!0,candlestick:!0},P={scatter:!0,scattergl:!0,splom:!0};function O(e,t){return e.distance-t.distance}function R(e){return[e.trace.index,e.index,e.x0,e.y0,e.name,e.attr,e.xa?e.xa._id:"",e.ya?e.ya._id:""].join(",")}t.hover=function(e,t,r,o){e=a.getGraphDiv(e);var l=t.target;a.throttle(e._fullLayout._uid+b.HOVERID,b.HOVERMINTIME,(function(){!function(e,t,r,o,l){r||(r="xy");"string"===typeof r&&(r=r.split(y)[0]);var c,d,p,b=Array.isArray(r)?r:[r],_=e._fullLayout,w=_.hoversubplots,k=_._plots||[],S=k[r],T=_._has("cartesian"),M=t.hovermode||_.hovermode,E="x"===(M||"").charAt(0),L="y"===(M||"").charAt(0);if(T&&(E||L)&&"axis"===w)for(var z=b.length,U=0;UZ[0]._length||_e<0||_e>K[0]._length)return m.unhoverRaw(e,t)}if(t.pointerX=be+Z[0]._offset,t.pointerY=_e+K[0]._offset,ne="xval"in t?x.flat(b,t.xval):x.p2c(Z,be),ie="yval"in t?x.flat(b,t.yval):x.p2c(K,_e),!i(ne[0])||!i(ie[0]))return a.warn("Fx.hover failed",t,e),m.unhoverRaw(e,t)}var Ae=1/0;function Te(r,n){for(ae=0;aeme&&(ge.splice(0,me),Ae=ge[0].distance),T&&0!==re&&0===ge.length){fe.distance=re,fe.index=!1;var u=le._module.hoverPoints(fe,he,pe,"closest",{hoverLayer:_._hoverlayer});if(u&&(u=u.filter((function(e){return e.spikeDistance<=re}))),u&&u.length){var d,h=u.filter((function(e){return e.xa.showspikes&&"hovered data"!==e.xa.spikesnap}));if(h.length){var p=h[0];i(p.x0)&&i(p.y0)&&(d=Ce(p),(!ve.vLinePoint||ve.vLinePoint.spikeDistance>d.spikeDistance)&&(ve.vLinePoint=d))}var m=u.filter((function(e){return e.ya.showspikes&&"hovered data"!==e.ya.spikesnap}));if(m.length){var g=m[0];i(g.x0)&&i(g.y0)&&(d=Ce(g),(!ve.hLinePoint||ve.hLinePoint.spikeDistance>d.spikeDistance)&&(ve.hLinePoint=d))}}}}}function Me(e,t,r){for(var n,i=null,o=1/0,a=0;a0&&Math.abs(e.distance)Ne-1;Be--)$e(ge[Be]);ge=Ve,Oe()}var We=e._hoverdata,qe=[],Ge=$(e),Ye=W(e);for(oe=0;oe1||ge.length>1)||"closest"===M&&xe&&ge.length>1,st=f.combine(_.plot_bgcolor||f.background,_.paper_bgcolor),lt=D(ge,{gd:e,hovermode:M,rotateLabels:at,bgColor:st,container:_._hoverlayer,outerContainer:_._paper.node(),commonLabelOpts:_.hoverlabel,hoverdistance:_.hoverdistance}),ct=lt.hoverLabels;x.isUnifiedHover(M)||(!function(e,t,r,n){var i,o,a,s,l,c,u,d=t?"xa":"ya",h=t?"ya":"xa",p=0,f=1,m=e.size(),g=new Array(m),y=0,v=n.minX,x=n.maxX,b=n.minY,_=n.maxY,w=function(e){return e*r._invScaleX},k=function(e){return e*r._invScaleY};function S(e){var t=e[0],r=e[e.length-1];if(o=t.pmin-t.pos-t.dp+t.size,a=r.pos+r.dp+r.size-t.pmax,o>.01){for(l=e.length-1;l>=0;l--)e[l].dp+=o;i=!1}if(!(a<.01)){if(o<-.01){for(l=e.length-1;l>=0;l--)e[l].dp-=a;i=!1}if(i){var n=0;for(s=0;st.pmax&&n++;for(s=e.length-1;s>=0&&!(n<=0);s--)(c=e[s]).pos>t.pmax-1&&(c.del=!0,n--);for(s=0;s=0;l--)e[l].dp-=a;for(s=e.length-1;s>=0&&!(n<=0);s--)(c=e[s]).pos+c.dp+c.size>t.pmax&&(c.del=!0,n--)}}}e.each((function(e){var n=e[d],i=e[h],o="x"===n._id.charAt(0),a=n.range;0===y&&a&&a[0]>a[1]!==o&&(f=-1);var s=0,l=o?r.width:r.height;if("x"===r.hovermode||"y"===r.hovermode){var c,u,p=j(e,t),m=e.anchor,S="end"===m?-1:1;if("middle"===m)u=(c=e.crossPos+(o?k(p.y-e.by/2):w(e.bx/2+e.tx2width/2)))+(o?k(e.by):w(e.bx));else if(o)u=(c=e.crossPos+k(C+p.y)-k(e.by/2-C))+k(e.by);else{var T=w(S*C+p.x),M=T+w(S*e.bx);c=e.crossPos+Math.min(T,M),u=e.crossPos+Math.max(T,M)}o?void 0!==b&&void 0!==_&&Math.min(u,_)-Math.max(c,b)>1&&("left"===i.side?(s=i._mainLinePosition,l=r.width):l=i._mainLinePosition):void 0!==v&&void 0!==x&&Math.min(u,x)-Math.max(c,v)>1&&("top"===i.side?(s=i._mainLinePosition,l=r.height):l=i._mainLinePosition)}g[y++]=[{datum:e,traceIndex:e.trace.index,dp:0,pos:e.pos,posref:e.posref,size:e.by*(o?A:1)/2,pmin:s,pmax:l}]})),g.sort((function(e,t){return e[0].posref-t[0].posref||f*(t[0].traceIndex-e[0].traceIndex)}));for(;!i&&p<=m;){for(p++,i=!0,s=0;s.01){for(l=M.length-1;l>=0;l--)M[l].dp+=o;for(T.push.apply(T,M),g.splice(s+1,1),u=0,l=T.length-1;l>=0;l--)u+=T[l].dp;for(a=u/T.length,l=T.length-1;l>=0;l--)T[l].dp-=a;i=!1}else s++}g.forEach(S)}for(s=g.length-1;s>=0;s--){var P=g[s];for(l=P.length-1;l>=0;l--){var O=P[l],R=O.datum;R.offset=O.dp,R.del=O.del}}}(ct,at,_,lt.commonLabelBoundingBox),F(ct,at,_._invScaleX,_._invScaleY));if(l&&l.tagName){var ut=v.getComponentMethod("annotations","hasClickToShow")(e,qe);h(n.select(l),ut?"pointer":"")}if(!l||o||!function(e,t,r){if(!r||r.length!==e._hoverdata.length)return!0;for(var n=r.length-1;n>=0;n--){var i=r[n],o=e._hoverdata[n];if(i.curveNumber!==o.curveNumber||String(i.pointNumber)!==String(o.pointNumber)||String(i.pointNumbers)!==String(o.pointNumbers))return!0}return!1}(e,0,We))return;We&&e.emit("plotly_unhover",{event:t,points:We});e.emit("plotly_hover",{event:t,points:e._hoverdata,xaxes:Z,yaxes:K,xvals:ne,yvals:ie})}(e,t,r,o,l)}))},t.loneHover=function(e,t){var r=!0;Array.isArray(e)||(r=!1,e=[e]);var i=t.gd,o=$(i),a=W(i),s=!1,l=D(e.map((function(e){var r=e._x0||e.x0||e.x||0,n=e._x1||e.x1||e.x||0,s=e._y0||e.y0||e.y||0,l=e._y1||e.y1||e.y||0,c=e.eventData;if(c){var u=Math.min(r,n),d=Math.max(r,n),h=Math.min(s,l),p=Math.max(s,l),m=e.trace;if(v.traceIs(m,"gl3d")){var g=i._fullLayout[m.scene]._scene.container,y=g.offsetLeft,x=g.offsetTop;u+=y,d+=y,h+=x,p+=x}c.bbox={x0:u+a,x1:d+a,y0:h+o,y1:p+o},t.inOut_bbox&&t.inOut_bbox.push(c.bbox)}else c=!1;return{color:e.color||f.defaultLine,x0:e.x0||e.x||0,x1:e.x1||e.x||0,y0:e.y0||e.y||0,y1:e.y1||e.y||0,xLabel:e.xLabel,yLabel:e.yLabel,zLabel:e.zLabel,text:e.text,name:e.name,idealAlign:e.idealAlign,borderColor:e.borderColor,fontFamily:e.fontFamily,fontSize:e.fontSize,fontColor:e.fontColor,fontWeight:e.fontWeight,fontStyle:e.fontStyle,fontVariant:e.fontVariant,nameLength:e.nameLength,textAlign:e.textAlign,trace:e.trace||{index:0,hoverinfo:""},xa:{_offset:0},ya:{_offset:0},index:0,hovertemplate:e.hovertemplate||!1,hovertemplateLabels:e.hovertemplateLabels||!1,eventData:c}})),{gd:i,hovermode:"closest",rotateLabels:s,bgColor:t.bgColor||f.background,container:n.select(t.container),outerContainer:t.outerContainer||t.container}).hoverLabels,c=0,u=0;return l.sort((function(e,t){return e.y0-t.y0})).each((function(e,r){var n=e.y0-e.by/2;e.offset=n-5([\s\S]*)<\/extra>/;function D(e,t){var r=t.gd,i=r._fullLayout,o=t.hovermode,s=t.rotateLabels,u=t.bgColor,h=t.container,m=t.outerContainer,g=t.commonLabelOpts||{};if(0===e.length)return[[]];var y=t.fontFamily||b.HOVERFONT,S=t.fontSize||b.HOVERFONTSIZE,A=t.fontWeight||i.font.weight,T=t.fontStyle||i.font.style,M=t.fontVariant||i.font.variant,I=t.fontTextcase||i.font.textcase,P=t.fontLineposition||i.font.lineposition,O=t.fontShadow||i.font.shadow,L=e[0],D=L.xa,j=L.ya,F=o.charAt(0),N=F+"Label",B=L[N];if(void 0===B&&"multicategory"===D.type)for(var V=0;Vi.width-k&&(R=i.width-k),t.attr("d","M"+(x-R)+",0L"+(x-R+C)+","+w+C+"H"+k+"v"+w+(2*E+_.height)+"H"+-k+"V"+w+C+"H"+(x-R-C)+"Z"),x=R,Q.minX=x-k,Q.maxX=x+k,"top"===D.side?(Q.minY=b-(2*E+_.height),Q.maxY=b-E):(Q.minY=b+E,Q.maxY=b+(2*E+_.height))}else{var z,F,N;"right"===j.side?(z="start",F=1,N="",x=D._offset+D._length):(z="end",F=-1,N="-",x=D._offset),b=j._offset+(L.y0+L.y1)/2,s.attr("text-anchor",z),t.attr("d","M0,0L"+N+C+","+C+"V"+(E+_.height/2)+"h"+N+(2*E+_.width)+"V-"+(E+_.height/2)+"H"+N+C+"V-"+C+"Z"),Q.minY=b-(E+_.height/2),Q.maxY=b+(E+_.height/2),"right"===j.side?(Q.minX=x+C,Q.maxX=x+C+(2*E+_.width)):(Q.minX=x-C-(2*E+_.width),Q.maxX=x-C);var V,U=_.height/2,$=H-_.top-U,W="clip"+i._uid+"commonlabel"+j._id;if(x<_.width+2*E+C){V="M-"+(C+E)+"-"+U+"h-"+(_.width-E)+"V"+U+"h"+(_.width-E)+"Z";var G=_.width-x+E;d.positionText(s,G,$),"end"===z&&s.selectAll("tspan").each((function(){var e=n.select(this),t=p.tester.append("text").text(e.text()).call(p.font,v),i=q(r,t.node());Math.round(i.width)=0?fe:me+ve<$&&me>=0?me:Te+ve<$?Te:fe-_e<_e-me+ve?$-ve:0,Se+=E,Ae=(he+=Me)+xe=0?he:pe+xe=0?pe:Me+xe=0,"top"!==e.idealAlign&&K||!J?K?(N+=U/2,e.anchor="start"):e.anchor="middle":(N-=U/2,e.anchor="end"),e.crossPos=N;else{if(e.pos=N,K=F+V/2+Q<=$,J=F-V/2-Q>=0,"left"!==e.idealAlign&&K||!J)if(K)F+=V/2,e.anchor="start";else{e.anchor="middle";var ee=Q/2,te=F+ee-$,re=F-ee;te>0&&(F-=te),re<0&&(F+=-re)}else F-=V/2,e.anchor="end";e.crossPos=F}w.attr("text-anchor",e.anchor),L&&R.attr("text-anchor",e.anchor),t.attr("transform",l(F,N)+(s?c(k):""))})),{hoverLabels:Ce,commonLabelBoundingBox:Q}}function z(e,t,r,n,i,o){var s="",l="";void 0!==e.nameOverride&&(e.name=e.nameOverride),e.name&&(e.trace._meta&&(e.name=a.templateString(e.name,e.trace._meta)),s=U(e.name,e.nameLength));var c=r.charAt(0),u="x"===c?"y":"x";void 0!==e.zLabel?(void 0!==e.xLabel&&(l+="x: "+e.xLabel+"
"),void 0!==e.yLabel&&(l+="y: "+e.yLabel+"
"),"choropleth"!==e.trace.type&&"choroplethmapbox"!==e.trace.type&&"choroplethmap"!==e.trace.type&&(l+=(l?"z: ":"")+e.zLabel)):t&&e[c+"Label"]===i?l=e[u+"Label"]||"":void 0===e.xLabel?void 0!==e.yLabel&&"scattercarpet"!==e.trace.type&&(l=e.yLabel):l=void 0===e.yLabel?e.xLabel:"("+e.xLabel+", "+e.yLabel+")",!e.text&&0!==e.text||Array.isArray(e.text)||(l+=(l?"
":"")+e.text),void 0!==e.extraText&&(l+=(l?"
":"")+e.extraText),o&&""===l&&!e.hovertemplate&&(""===s&&o.remove(),l=s);var d=e.hovertemplate||!1;if(d){var h=e.hovertemplateLabels||e;e[c+"Label"]!==i&&(h[c+"other"]=h[c+"Val"],h[c+"otherLabel"]=h[c+"Label"]),l=(l=a.hovertemplateString(d,h,n._d3locale,e.eventData[0]||{},e.trace._meta)).replace(L,(function(t,r){return s=U(r,e.nameLength),""}))}return[l,s]}function j(e,t){var r=0,n=e.offset;return t&&(n*=-M,r=e.offset*T),{x:r,y:n}}function F(e,t,r,i){var o=function(e){return e*r},a=function(e){return e*i};e.each((function(e){var r=n.select(this);if(e.del)return r.remove();var i=r.select("text.nums"),s=e.anchor,l="end"===s?-1:1,c=function(e){var t={start:1,end:-1,middle:0}[e.anchor],r=t*(C+E),n=r+t*(e.txwidth+E);return"middle"===e.anchor&&(r-=e.tx2width/2,n+=e.txwidth/2+E),{alignShift:t,textShiftX:r,text2ShiftX:n}}(e),u=j(e,t),h=u.x,f=u.y,m="middle"===s;r.select("path").attr("d",m?"M-"+o(e.bx/2+e.tx2width/2)+","+a(f-e.by/2)+"h"+o(e.bx)+"v"+a(e.by)+"h-"+o(e.bx)+"Z":"M0,0L"+o(l*C+h)+","+a(C+f)+"v"+a(e.by/2-C)+"h"+o(l*e.bx)+"v-"+a(e.by)+"H"+o(l*C+h)+"V"+a(f-C)+"Z");var g=h+c.textShiftX,y=f+e.ty0-e.by/2+E,v=e.textAlign||"auto";"auto"!==v&&("left"===v&&"start"!==s?(i.attr("text-anchor","start"),g=m?-e.bx/2-e.tx2width/2+E:-e.bx-E):"right"===v&&"end"!==s&&(i.attr("text-anchor","end"),g=m?e.bx/2-e.tx2width/2-E:e.bx+E)),i.call(d.positionText,o(g),a(y)),e.tx2width&&(r.select("text.name").call(d.positionText,o(c.text2ShiftX+c.alignShift*E+h),a(f+e.ty0-e.by/2+E)),r.select("rect").call(p.setRect,o(c.text2ShiftX+(c.alignShift-1)*e.tx2width/2+h),a(f-e.by/2-1),o(e.tx2width),a(e.by+2)))}))}function N(e,t){var r=e.index,n=e.trace||{},o=e.cd[0],s=e.cd[r]||{};function l(e){return e||i(e)&&0===e}var c=Array.isArray(r)?function(e,t){var i=a.castOption(o,r,e);return l(i)?i:a.extractOption({},n,"",t)}:function(e,t){return a.extractOption(s,n,e,t)};function u(t,r,n){var i=c(r,n);l(i)&&(e[t]=i)}if(u("hoverinfo","hi","hoverinfo"),u("bgcolor","hbg","hoverlabel.bgcolor"),u("borderColor","hbc","hoverlabel.bordercolor"),u("fontFamily","htf","hoverlabel.font.family"),u("fontSize","hts","hoverlabel.font.size"),u("fontColor","htc","hoverlabel.font.color"),u("fontWeight","htw","hoverlabel.font.weight"),u("fontStyle","hty","hoverlabel.font.style"),u("fontVariant","htv","hoverlabel.font.variant"),u("nameLength","hnl","hoverlabel.namelength"),u("textAlign","hta","hoverlabel.align"),e.posref="y"===t||"closest"===t&&"h"===n.orientation?e.xa._offset+(e.x0+e.x1)/2:e.ya._offset+(e.y0+e.y1)/2,e.x0=a.constrain(e.x0,0,e.xa._length),e.x1=a.constrain(e.x1,0,e.xa._length),e.y0=a.constrain(e.y0,0,e.ya._length),e.y1=a.constrain(e.y1,0,e.ya._length),void 0!==e.xLabelVal&&(e.xLabel="xLabel"in e?e.xLabel:g.hoverLabelText(e.xa,e.xLabelVal,n.xhoverformat),e.xVal=e.xa.c2d(e.xLabelVal)),void 0!==e.yLabelVal&&(e.yLabel="yLabel"in e?e.yLabel:g.hoverLabelText(e.ya,e.yLabelVal,n.yhoverformat),e.yVal=e.ya.c2d(e.yLabelVal)),void 0!==e.zLabelVal&&void 0===e.zLabel&&(e.zLabel=String(e.zLabelVal)),!isNaN(e.xerr)&&!("log"===e.xa.type&&e.xerr<=0)){var d=g.tickText(e.xa,e.xa.c2l(e.xerr),"hover").text;void 0!==e.xerrneg?e.xLabel+=" +"+d+" / -"+g.tickText(e.xa,e.xa.c2l(e.xerrneg),"hover").text:e.xLabel+=" \xb1 "+d,"x"===t&&(e.distance+=1)}if(!isNaN(e.yerr)&&!("log"===e.ya.type&&e.yerr<=0)){var h=g.tickText(e.ya,e.ya.c2l(e.yerr),"hover").text;void 0!==e.yerrneg?e.yLabel+=" +"+h+" / -"+g.tickText(e.ya,e.ya.c2l(e.yerrneg),"hover").text:e.yLabel+=" \xb1 "+h,"y"===t&&(e.distance+=1)}var p=e.hoverinfo||e.trace.hoverinfo;return p&&"all"!==p&&(-1===(p=Array.isArray(p)?p:p.split("+")).indexOf("x")&&(e.xLabel=void 0),-1===p.indexOf("y")&&(e.yLabel=void 0),-1===p.indexOf("z")&&(e.zLabel=void 0),-1===p.indexOf("text")&&(e.text=void 0),-1===p.indexOf("name")&&(e.name=void 0)),e}function B(e,t,r){var n,i,a=r.container,s=r.fullLayout,l=s._size,c=r.event,u=!!t.hLinePoint,d=!!t.vLinePoint;if(a.selectAll(".spikeline").remove(),d||u){var h=f.combine(s.plot_bgcolor,s.paper_bgcolor);if(u){var m,y,v=t.hLinePoint;n=v&&v.xa,"cursor"===(i=v&&v.ya).spikesnap?(m=c.pointerX,y=c.pointerY):(m=n._offset+v.x,y=i._offset+v.y);var x,b,_=o.readability(v.color,h)<1.5?f.contrast(h):v.color,w=i.spikemode,k=i.spikethickness,S=i.spikecolor||_,A=g.getPxPosition(e,i);if(-1!==w.indexOf("toaxis")||-1!==w.indexOf("across")){if(-1!==w.indexOf("toaxis")&&(x=A,b=m),-1!==w.indexOf("across")){var T=i._counterDomainMin,M=i._counterDomainMax;"free"===i.anchor&&(T=Math.min(T,i.position),M=Math.max(M,i.position)),x=l.l+T*l.w,b=l.l+M*l.w}a.insert("line",":first-child").attr({x1:x,x2:b,y1:y,y2:y,"stroke-width":k,stroke:S,"stroke-dasharray":p.dashStyle(i.spikedash,k)}).classed("spikeline",!0).classed("crisp",!0),a.insert("line",":first-child").attr({x1:x,x2:b,y1:y,y2:y,"stroke-width":k+2,stroke:h}).classed("spikeline",!0).classed("crisp",!0)}-1!==w.indexOf("marker")&&a.insert("circle",":first-child").attr({cx:A+("right"!==i.side?k:-k),cy:y,r:k,fill:S}).classed("spikeline",!0)}if(d){var C,E,I=t.vLinePoint;n=I&&I.xa,i=I&&I.ya,"cursor"===n.spikesnap?(C=c.pointerX,E=c.pointerY):(C=n._offset+I.x,E=i._offset+I.y);var P,O,R=o.readability(I.color,h)<1.5?f.contrast(h):I.color,L=n.spikemode,D=n.spikethickness,z=n.spikecolor||R,j=g.getPxPosition(e,n);if(-1!==L.indexOf("toaxis")||-1!==L.indexOf("across")){if(-1!==L.indexOf("toaxis")&&(P=j,O=E),-1!==L.indexOf("across")){var F=n._counterDomainMin,N=n._counterDomainMax;"free"===n.anchor&&(F=Math.min(F,n.position),N=Math.max(N,n.position)),P=l.t+(1-N)*l.h,O=l.t+(1-F)*l.h}a.insert("line",":first-child").attr({x1:C,x2:C,y1:P,y2:O,"stroke-width":D,stroke:z,"stroke-dasharray":p.dashStyle(n.spikedash,D)}).classed("spikeline",!0).classed("crisp",!0),a.insert("line",":first-child").attr({x1:C,x2:C,y1:P,y2:O,"stroke-width":D+2,stroke:h}).classed("spikeline",!0).classed("crisp",!0)}-1!==L.indexOf("marker")&&a.insert("circle",":first-child").attr({cx:C,cy:j-("top"!==n.side?D:-D),r:D,fill:z}).classed("spikeline",!0)}}}function V(e,t){return!t||(t.vLinePoint!==e._spikepoints.vLinePoint||t.hLinePoint!==e._spikepoints.hLinePoint)}function U(e,t){return d.plainText(e||"",{len:t,allowedTags:["br","sub","sup","b","i","em","s","u"]})}function H(e,t,r){var n=t[e+"a"],i=t[e+"Val"],o=t.cd[0];if("category"===n.type||"multicategory"===n.type)i=n._categoriesMap[i];else if("date"===n.type){var a=t.trace[e+"periodalignment"];if(a){var s=t.cd[t.index],l=s[e+"Start"];void 0===l&&(l=s[e]);var c=s[e+"End"];void 0===c&&(c=s[e]);var u=c-l;"end"===a?i+=u:"middle"===a&&(i+=u/2)}i=n.d2c(i)}return o&&o.t&&o.t.posLetter===n._id&&("group"!==r.boxmode&&"group"!==r.violinmode||(i+=o.t.dPos)),i}function $(e){return e.offsetTop+e.clientTop}function W(e){return e.offsetLeft+e.clientLeft}function q(e,t){var r=e._fullLayout,n=t.getBoundingClientRect(),i=n.left,o=n.top,s=i+n.width,l=o+n.height,c=a.apply3DTransform(r._invTransform)(i,o),u=a.apply3DTransform(r._invTransform)(s,l),d=c[0],h=c[1],p=u[0],f=u[1];return{x:d,y:h,width:p-d,height:f-h,top:Math.min(h,f),left:Math.min(d,p),right:Math.max(d,p),bottom:Math.max(h,f)}}},15171:(e,t,r)=>{"use strict";var n=r(84468),i=r(7605),o=r(82561).isUnifiedHover;e.exports=function(e,t,r,a){a=a||{};var s=t.legend;function l(e){a.font[e]||(a.font[e]=s?t.legend.font[e]:t.font[e])}t&&o(t.hovermode)&&(a.font||(a.font={}),l("size"),l("family"),l("color"),l("weight"),l("style"),l("variant"),s?(a.bgcolor||(a.bgcolor=i.combine(t.legend.bgcolor,t.paper_bgcolor)),a.bordercolor||(a.bordercolor=t.legend.bordercolor)):a.bgcolor||(a.bgcolor=t.paper_bgcolor)),r("hoverlabel.bgcolor",a.bgcolor),r("hoverlabel.bordercolor",a.bordercolor),r("hoverlabel.namelength",a.namelength),n.coerceFont(r,"hoverlabel.font",a.font),r("hoverlabel.align",a.align)}},71886:(e,t,r)=>{"use strict";var n=r(84468),i=r(97174);e.exports=function(e,t){function r(r,o){return void 0!==t[r]?t[r]:n.coerce(e,t,i,r,o)}return r("clickmode"),r("hoversubplots"),r("hovermode")}},32212:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468),o=r(25732),a=r(82561),s=r(97174),l=r(12914);e.exports={moduleType:"component",name:"fx",constants:r(99961),schema:{layout:s},attributes:r(25087),layoutAttributes:s,supplyLayoutGlobalDefaults:r(43465),supplyDefaults:r(62168),supplyLayoutDefaults:r(80001),calc:r(50079),getDistanceFunction:a.getDistanceFunction,getClosest:a.getClosest,inbox:a.inbox,quadrature:a.quadrature,appendArrayPointValue:a.appendArrayPointValue,castHoverOption:function(e,t,r){return i.castOption(e,t,"hoverlabel."+r)},castHoverinfo:function(e,t,r){return i.castOption(e,r,"hoverinfo",(function(r){return i.coerceHoverinfo({hoverinfo:r},{_module:e._module},t)}))},hover:l.hover,unhover:o.unhover,loneHover:l.loneHover,loneUnhover:function(e){var t=i.isD3Selection(e)?e:n.select(e);t.selectAll("g.hovertext").remove(),t.selectAll(".spikeline").remove()},click:r(84896)}},97174:(e,t,r)=>{"use strict";var n=r(99961),i=r(91740),o=i({editType:"none",description:"Sets the default hover label font used by all traces on the graph."});o.family.dflt=n.HOVERFONT,o.size.dflt=n.HOVERFONTSIZE,e.exports={clickmode:{valType:"flaglist",flags:["event","select"],dflt:"event",editType:"plot",extras:["none"],description:["Determines the mode of single click interactions.","*event* is the default value and emits the `plotly_click`","event. In addition this mode emits the `plotly_selected` event","in drag modes *lasso* and *select*, but with no event data attached","(kept for compatibility reasons).","The *select* flag enables selecting single","data points via click. This mode also supports persistent selections,","meaning that pressing Shift while clicking, adds to / subtracts from an","existing selection. *select* with `hovermode`: *x* can be confusing, consider","explicitly setting `hovermode`: *closest* when using this feature.","Selection events are sent accordingly as long as *event* flag is set as well.","When the *event* flag is missing, `plotly_click` and `plotly_selected`","events are not fired."].join(" ")},dragmode:{valType:"enumerated",values:["zoom","pan","select","lasso","drawclosedpath","drawopenpath","drawline","drawrect","drawcircle","orbit","turntable",!1],dflt:"zoom",editType:"modebar",description:["Determines the mode of drag interactions.","*select* and *lasso* apply only to scatter traces with","markers or text. *orbit* and *turntable* apply only to","3D scenes."].join(" ")},hovermode:{valType:"enumerated",values:["x","y","closest",!1,"x unified","y unified"],dflt:"closest",editType:"modebar",description:["Determines the mode of hover interactions.","If *closest*, a single hoverlabel will appear","for the *closest* point within the `hoverdistance`.","If *x* (or *y*), multiple hoverlabels will appear for multiple points","at the *closest* x- (or y-) coordinate within the `hoverdistance`,","with the caveat that no more than one hoverlabel will appear per trace.","If *x unified* (or *y unified*), a single hoverlabel will appear","multiple points at the closest x- (or y-) coordinate within the `hoverdistance`","with the caveat that no more than one hoverlabel will appear per trace.","In this mode, spikelines are enabled by default perpendicular to the specified axis.","If false, hover interactions are disabled."].join(" ")},hoversubplots:{valType:"enumerated",values:["single","overlaying","axis"],dflt:"overlaying",editType:"none",description:["Determines expansion of hover effects to other subplots","If *single* just the axis pair of the primary point is included without overlaying subplots.","If *overlaying* all subplots using the main axis and occupying the same space are included.","If *axis*, also include stacked subplots using the same axis","when `hovermode` is set to *x*, *x unified*, *y* or *y unified*."].join(" ")},hoverdistance:{valType:"integer",min:-1,dflt:20,editType:"none",description:["Sets the default distance (in pixels) to look for data","to add hover labels (-1 means no cutoff, 0 means no looking for data).","This is only a real distance for hovering on point-like objects,","like scatter points. For area-like objects (bars, scatter fills, etc)","hovering is on inside the area and off outside, but these objects","will not supersede hover on point-like objects in case of conflict."].join(" ")},spikedistance:{valType:"integer",min:-1,dflt:-1,editType:"none",description:["Sets the default distance (in pixels) to look for data to draw","spikelines to (-1 means no cutoff, 0 means no looking for data).","As with hoverdistance, distance does not apply to area-like objects.","In addition, some objects can be hovered on but will not generate","spikelines, such as scatter fills."].join(" ")},hoverlabel:{bgcolor:{valType:"color",editType:"none",description:["Sets the background color of all hover labels on graph"].join(" ")},bordercolor:{valType:"color",editType:"none",description:["Sets the border color of all hover labels on graph."].join(" ")},font:o,grouptitlefont:i({editType:"none",description:["Sets the font for group titles in hover (unified modes).","Defaults to `hoverlabel.font`."].join(" ")}),align:{valType:"enumerated",values:["left","right","auto"],dflt:"auto",editType:"none",description:["Sets the horizontal alignment of the text content within hover label box.","Has an effect only if the hover label text spans more two or more lines"].join(" ")},namelength:{valType:"integer",min:-1,dflt:15,editType:"none",description:["Sets the default length (in number of characters) of the trace name in","the hover labels for all traces. -1 shows the whole name","regardless of length. 0-3 shows the first 0-3 characters, and","an integer >3 will show the whole name if it is less than that","many characters, but if it is longer, will truncate to","`namelength - 3` characters and add an ellipsis."].join(" ")},editType:"none"},selectdirection:{valType:"enumerated",values:["h","v","d","any"],dflt:"any",description:["When `dragmode` is set to *select*, this limits the selection of the drag to","horizontal, vertical or diagonal. *h* only allows horizontal selection,","*v* only vertical, *d* only diagonal and *any* sets no limit."].join(" "),editType:"none"}}},80001:(e,t,r)=>{"use strict";var n=r(84468),i=r(97174),o=r(71886),a=r(15171);e.exports=function(e,t){function r(r,o){return n.coerce(e,t,i,r,o)}o(e,t)&&(r("hoverdistance"),r("spikedistance")),"select"===r("dragmode")&&r("selectdirection");var s=t._has("mapbox"),l=t._has("map"),c=t._has("geo"),u=t._basePlotModules.length;"zoom"===t.dragmode&&((s||l||c)&&1===u||(s||l)&&c&&2===u)&&(t.dragmode="pan"),a(e,t,r),n.coerceFont(r,"hoverlabel.grouptitlefont",t.hoverlabel.font)}},43465:(e,t,r)=>{"use strict";var n=r(84468),i=r(15171),o=r(97174);e.exports=function(e,t){i(e,t,(function(r,i){return n.coerce(e,t,o,r,i)}))}},41734:(e,t,r)=>{"use strict";var n=r(84468),i=r(51195).counter,o=r(81159).u,a=r(93143).idRegex,s=r(37091),l={rows:{valType:"integer",min:1,editType:"plot",description:["The number of rows in the grid. If you provide a 2D `subplots`","array or a `yaxes` array, its length is used as the default.","But it's also possible to have a different length, if you","want to leave a row at the end for non-cartesian subplots."].join(" ")},roworder:{valType:"enumerated",values:["top to bottom","bottom to top"],dflt:"top to bottom",editType:"plot",description:["Is the first row the top or the bottom? Note that columns","are always enumerated from left to right."].join(" ")},columns:{valType:"integer",min:1,editType:"plot",description:["The number of columns in the grid. If you provide a 2D `subplots`","array, the length of its longest row is used as the default.","If you give an `xaxes` array, its length is used as the default.","But it's also possible to have a different length, if you","want to leave a row at the end for non-cartesian subplots."].join(" ")},subplots:{valType:"info_array",freeLength:!0,dimensions:2,items:{valType:"enumerated",values:[i("xy").toString(),""],editType:"plot"},editType:"plot",description:["Used for freeform grids, where some axes may be shared across subplots","but others are not. Each entry should be a cartesian subplot id, like","*xy* or *x3y2*, or ** to leave that cell empty. You may reuse x axes","within the same column, and y axes within the same row.","Non-cartesian subplots and traces that support `domain` can place themselves","in this grid separately using the `gridcell` attribute."].join(" ")},xaxes:{valType:"info_array",freeLength:!0,items:{valType:"enumerated",values:[a.x.toString(),""],editType:"plot"},editType:"plot",description:["Used with `yaxes` when the x and y axes are shared across columns and rows.","Each entry should be an x axis id like *x*, *x2*, etc., or ** to","not put an x axis in that column. Entries other than ** must be unique.","Ignored if `subplots` is present. If missing but `yaxes` is present,","will generate consecutive IDs."].join(" ")},yaxes:{valType:"info_array",freeLength:!0,items:{valType:"enumerated",values:[a.y.toString(),""],editType:"plot"},editType:"plot",description:["Used with `yaxes` when the x and y axes are shared across columns and rows.","Each entry should be an y axis id like *y*, *y2*, etc., or ** to","not put a y axis in that row. Entries other than ** must be unique.","Ignored if `subplots` is present. If missing but `xaxes` is present,","will generate consecutive IDs."].join(" ")},pattern:{valType:"enumerated",values:["independent","coupled"],dflt:"coupled",editType:"plot",description:["If no `subplots`, `xaxes`, or `yaxes` are given but we do have `rows` and `columns`,","we can generate defaults using consecutive axis IDs, in two ways:","*coupled* gives one x axis per column and one y axis per row.","*independent* uses a new xy pair for each cell, left-to-right across each row","then iterating rows according to `roworder`."].join(" ")},xgap:{valType:"number",min:0,max:1,editType:"plot",description:["Horizontal space between grid cells, expressed as a fraction","of the total width available to one cell. Defaults to 0.1","for coupled-axes grids and 0.2 for independent grids."].join(" ")},ygap:{valType:"number",min:0,max:1,editType:"plot",description:["Vertical space between grid cells, expressed as a fraction","of the total height available to one cell. Defaults to 0.1","for coupled-axes grids and 0.3 for independent grids."].join(" ")},domain:o({name:"grid",editType:"plot",noGridCell:!0},{description:["The first and last cells end exactly at the domain","edges, with no grout around the edges."].join(" ")}),xside:{valType:"enumerated",values:["bottom","bottom plot","top plot","top"],dflt:"bottom plot",editType:"plot",description:["Sets where the x axis labels and titles go. *bottom* means","the very bottom of the grid. *bottom plot* is the lowest plot","that each x axis is used in. *top* and *top plot* are similar."].join(" ")},yside:{valType:"enumerated",values:["left","left plot","right plot","right"],dflt:"left plot",editType:"plot",description:["Sets where the y axis labels and titles go. *left* means","the very left edge of the grid. *left plot* is the leftmost plot","that each y axis is used in. *right* and *right plot* are similar."].join(" ")},editType:"plot"};function c(e,t,r){var n=t[r+"axes"],i=Object.keys((e._splomAxes||{})[r]||{});return Array.isArray(n)?n:i.length?i:void 0}function u(e,t,r,n,i,o){var a=t(e+"gap",r),s=t("domain."+e);t(e+"side",n);for(var l=new Array(i),c=s[0],u=(s[1]-c)/(i-a),d=u*(1-a),h=0;h1){if(!h&&!p&&!f)"independent"===S("pattern")&&(h=!0);g._hasSubplotGrid=h;var x,b,_="top to bottom"===S("roworder"),w=h?.2:.1,k=h?.3:.1;m&&t._splomGridDflt&&(x=t._splomGridDflt.xside,b=t._splomGridDflt.yside),g._domains={x:u("x",S,w,x,v),y:u("y",S,k,b,y,_)}}else delete t.grid}function S(e,t){return n.coerce(r,g,l,e,t)}},contentDefaults:function(e,t){var r=t.grid;if(r&&r._domains){var n,i,o,a,s,l,u,h=e.grid||{},p=t._subplots,f=r._hasSubplotGrid,m=r.rows,g=r.columns,y="independent"===r.pattern,v=r._axisMap={};if(f){var x=h.subplots||[];l=r.subplots=new Array(m);var b=1;for(n=0;n{"use strict";var n=r(93143),i=r(37091).templatedArray,o=r(54654);e.exports=i("image",{visible:{valType:"boolean",dflt:!0,editType:"arraydraw",description:["Determines whether or not this image is visible."].join(" ")},source:{valType:"string",editType:"arraydraw",description:["Specifies the URL of the image to be used.","The URL must be accessible from the domain where the","plot code is run, and can be either relative or absolute."].join(" ")},layer:{valType:"enumerated",values:["below","above"],dflt:"above",editType:"arraydraw",description:["Specifies whether images are drawn below or above traces.","When `xref` and `yref` are both set to `paper`,","image is drawn below the entire plot area."].join(" ")},sizex:{valType:"number",dflt:0,editType:"arraydraw",description:["Sets the image container size horizontally.","The image will be sized based on the `position` value.","When `xref` is set to `paper`, units are sized relative","to the plot width.","When `xref` ends with ` domain`, units are sized relative","to the axis width."].join(" ")},sizey:{valType:"number",dflt:0,editType:"arraydraw",description:["Sets the image container size vertically.","The image will be sized based on the `position` value.","When `yref` is set to `paper`, units are sized relative","to the plot height.","When `yref` ends with ` domain`, units are sized relative","to the axis height."].join(" ")},sizing:{valType:"enumerated",values:["fill","contain","stretch"],dflt:"contain",editType:"arraydraw",description:["Specifies which dimension of the image to constrain."].join(" ")},opacity:{valType:"number",min:0,max:1,dflt:1,editType:"arraydraw",description:"Sets the opacity of the image."},x:{valType:"any",dflt:0,editType:"arraydraw",description:["Sets the image's x position.","When `xref` is set to `paper`, units are sized relative","to the plot height.","See `xref` for more info"].join(" ")},y:{valType:"any",dflt:0,editType:"arraydraw",description:["Sets the image's y position.","When `yref` is set to `paper`, units are sized relative","to the plot height.","See `yref` for more info"].join(" ")},xanchor:{valType:"enumerated",values:["left","center","right"],dflt:"left",editType:"arraydraw",description:"Sets the anchor for the x position"},yanchor:{valType:"enumerated",values:["top","middle","bottom"],dflt:"top",editType:"arraydraw",description:"Sets the anchor for the y position."},xref:{valType:"enumerated",values:["paper",n.idRegex.x.toString()],dflt:"paper",editType:"arraydraw",description:["Sets the images's x coordinate axis.",o.axisRefDescription("x","left","right")].join(" ")},yref:{valType:"enumerated",values:["paper",n.idRegex.y.toString()],dflt:"paper",editType:"arraydraw",description:["Sets the images's y coordinate axis.",o.axisRefDescription("y","bottom","top")].join(" ")},editType:"arraydraw"})},15352:(e,t,r)=>{"use strict";var n=r(22036),i=r(46396);e.exports=function(e,t,r,o){t=t||{};var a="log"===r&&"linear"===t.type,s="linear"===r&&"log"===t.type;if(a||s)for(var l,c,u=e._fullLayout.images,d=t._id.charAt(0),h=0;h{"use strict";var n=r(84468),i=r(85729),o=r(38851),a=r(15951);function s(e,t,r){function o(r,i){return n.coerce(e,t,a,r,i)}var s=o("source");if(!o("visible",!!s))return t;o("layer"),o("xanchor"),o("yanchor"),o("sizex"),o("sizey"),o("sizing"),o("opacity");for(var l={_fullLayout:r},c=["x","y"],u=0;u<2;u++){var d=c[u],h=i.coerceRef(e,t,l,d,"paper",void 0);if("paper"!==h)i.getFromId(l,h)._imgIndices.push(t._index);i.coercePosition(t,l,o,h,d,0)}return t}e.exports=function(e,t){o(e,t,{name:"images",handleItemDefaults:s})}},70476:(e,t,r)=>{"use strict";var n=r(41871),i=r(3172),o=r(85729),a=r(11576),s=r(28795);e.exports=function(e){var t,r,l=e._fullLayout,c=[],u={},d=[];for(r=0;r{"use strict";e.exports={moduleType:"component",name:"images",layoutAttributes:r(15951),supplyLayoutDefaults:r(8712),includeBasePlot:r(84381)("images"),draw:r(70476),convertCoords:r(15352)}},31334:(e,t,r)=>{"use strict";var n=r(91740),i=r(17992);e.exports={_isSubplotObj:!0,visible:{valType:"boolean",dflt:!0,editType:"legend",description:["Determines whether or not this legend is visible."].join(" ")},bgcolor:{valType:"color",editType:"legend",description:["Sets the legend background color.","Defaults to `layout.paper_bgcolor`."].join(" ")},bordercolor:{valType:"color",dflt:i.defaultLine,editType:"legend",description:"Sets the color of the border enclosing the legend."},borderwidth:{valType:"number",min:0,dflt:0,editType:"legend",description:"Sets the width (in px) of the border enclosing the legend."},font:n({editType:"legend",description:"Sets the font used to text the legend items."}),grouptitlefont:n({editType:"legend",description:["Sets the font for group titles in legend.","Defaults to `legend.font` with its size increased about 10%."].join(" ")}),orientation:{valType:"enumerated",values:["v","h"],dflt:"v",editType:"legend",description:"Sets the orientation of the legend."},traceorder:{valType:"flaglist",flags:["reversed","grouped"],extras:["normal"],editType:"legend",description:["Determines the order at which the legend items are displayed.","If *normal*, the items are displayed top-to-bottom in the same","order as the input data.","If *reversed*, the items are displayed in the opposite order","as *normal*.","If *grouped*, the items are displayed in groups","(when a trace `legendgroup` is provided).","if *grouped+reversed*, the items are displayed in the opposite order","as *grouped*."].join(" ")},tracegroupgap:{valType:"number",min:0,dflt:10,editType:"legend",description:["Sets the amount of vertical space (in px) between legend groups."].join(" ")},entrywidth:{valType:"number",min:0,editType:"legend",description:["Sets the width (in px or fraction) of the legend.","Use 0 to size the entry based on the text width,","when `entrywidthmode` is set to *pixels*."].join(" ")},entrywidthmode:{valType:"enumerated",values:["fraction","pixels"],dflt:"pixels",editType:"legend",description:"Determines what entrywidth means."},indentation:{valType:"number",min:-15,dflt:0,editType:"legend",description:"Sets the indentation (in px) of the legend entries."},itemsizing:{valType:"enumerated",values:["trace","constant"],dflt:"trace",editType:"legend",description:["Determines if the legend items symbols scale with their corresponding *trace* attributes","or remain *constant* independent of the symbol size on the graph."].join(" ")},itemwidth:{valType:"number",min:30,dflt:30,editType:"legend",description:"Sets the width (in px) of the legend item symbols (the part other than the title.text)."},itemclick:{valType:"enumerated",values:["toggle","toggleothers",!1],dflt:"toggle",editType:"legend",description:["Determines the behavior on legend item click.","*toggle* toggles the visibility of the item clicked on the graph.","*toggleothers* makes the clicked item the sole visible item on the graph.","*false* disables legend item click interactions."].join(" ")},itemdoubleclick:{valType:"enumerated",values:["toggle","toggleothers",!1],dflt:"toggleothers",editType:"legend",description:["Determines the behavior on legend item double-click.","*toggle* toggles the visibility of the item clicked on the graph.","*toggleothers* makes the clicked item the sole visible item on the graph.","*false* disables legend item double-click interactions."].join(" ")},groupclick:{valType:"enumerated",values:["toggleitem","togglegroup"],dflt:"togglegroup",editType:"legend",description:["Determines the behavior on legend group item click.","*toggleitem* toggles the visibility of the individual item clicked on the graph.","*togglegroup* toggles the visibility of all items in the same legendgroup as the item clicked on the graph."].join(" ")},x:{valType:"number",editType:"legend",description:["Sets the x position with respect to `xref` (in normalized coordinates) of the legend.","When `xref` is *paper*, defaults to *1.02* for vertical legends and","defaults to *0* for horizontal legends.","When `xref` is *container*, defaults to *1* for vertical legends and","defaults to *0* for horizontal legends.","Must be between *0* and *1* if `xref` is *container*.","and between *-2* and *3* if `xref` is *paper*."].join(" ")},xref:{valType:"enumerated",dflt:"paper",values:["container","paper"],editType:"layoutstyle",description:["Sets the container `x` refers to.","*container* spans the entire `width` of the plot.","*paper* refers to the width of the plotting area only."].join(" ")},xanchor:{valType:"enumerated",values:["auto","left","center","right"],dflt:"left",editType:"legend",description:["Sets the legend's horizontal position anchor.","This anchor binds the `x` position to the *left*, *center*","or *right* of the legend.","Value *auto* anchors legends to the right for `x` values greater than or equal to 2/3,","anchors legends to the left for `x` values less than or equal to 1/3 and","anchors legends with respect to their center otherwise."].join(" ")},y:{valType:"number",editType:"legend",description:["Sets the y position with respect to `yref` (in normalized coordinates) of the legend.","When `yref` is *paper*, defaults to *1* for vertical legends,","defaults to *-0.1* for horizontal legends on graphs w/o range sliders and","defaults to *1.1* for horizontal legends on graph with one or multiple range sliders.","When `yref` is *container*, defaults to *1*.","Must be between *0* and *1* if `yref` is *container*","and between *-2* and *3* if `yref` is *paper*."].join(" ")},yref:{valType:"enumerated",dflt:"paper",values:["container","paper"],editType:"layoutstyle",description:["Sets the container `y` refers to.","*container* spans the entire `height` of the plot.","*paper* refers to the height of the plotting area only."].join(" ")},yanchor:{valType:"enumerated",values:["auto","top","middle","bottom"],editType:"legend",description:["Sets the legend's vertical position anchor","This anchor binds the `y` position to the *top*, *middle*","or *bottom* of the legend.","Value *auto* anchors legends at their bottom for `y` values less than or equal to 1/3,","anchors legends to at their top for `y` values greater than or equal to 2/3 and","anchors legends with respect to their middle otherwise."].join(" ")},uirevision:{valType:"any",editType:"none",description:["Controls persistence of legend-driven changes in trace and pie label","visibility. Defaults to `layout.uirevision`."].join(" ")},valign:{valType:"enumerated",values:["top","middle","bottom"],dflt:"middle",editType:"legend",description:["Sets the vertical alignment of the symbols with respect to their associated text."].join(" ")},title:{text:{valType:"string",dflt:"",editType:"legend",description:["Sets the title of the legend."].join(" ")},font:n({editType:"legend",description:["Sets this legend's title font.","Defaults to `legend.font` with its size increased about 20%."].join(" ")}),side:{valType:"enumerated",values:["top","left","top left","top center","top right"],editType:"legend",description:["Determines the location of legend's title","with respect to the legend items.","Defaulted to *top* with `orientation` is *h*.","Defaulted to *left* with `orientation` is *v*.","The *top left* options could be used to expand","top center and top right are for horizontal alignment","legend area in both x and y sides."].join(" ")},editType:"legend"},editType:"legend"}},76730:e=>{"use strict";e.exports={scrollBarWidth:6,scrollBarMinHeight:20,scrollBarColor:"#808BA4",scrollBarMargin:4,scrollBarEnterAttrs:{rx:20,ry:3,width:0,height:0},titlePad:2,itemGap:5}},11217:(e,t,r)=>{"use strict";var n=r(38361),i=r(84468),o=r(37091),a=r(75622),s=r(31334),l=r(98005),c=r(11990);function u(e,t,r,u){var d=t[e]||{},h=o.newContainer(r,e);function p(e,t){return i.coerce(d,h,s,e,t)}var f=i.coerceFont(p,"font",r.font);if(p("bgcolor",r.paper_bgcolor),p("bordercolor"),p("visible")){for(var m,g=function(e,t){var r=m._input,n=m;return i.coerce(r,n,a,e,t)},y=r.font||{},v=i.coerceFont(p,"grouptitlefont",y,{overrideDflt:{size:Math.round(1.1*y.size)}}),x=0,b=!1,_="normal",w=(r.shapes||[]).filter((function(e){return e.showlegend})),k=u.concat(w).filter((function(t){return e===(t.legend||"legend")})),S=0;S("legend"===e?1:0));if(!1===T&&(r[e]=void 0),(!1!==T||d.uirevision)&&(p("uirevision",r.uirevision),!1!==T)){p("borderwidth");var M,C,E,I="h"===p("orientation"),P="paper"===p("yref"),O="paper"===p("xref"),R="left";if(I?(M=0,n.getComponentMethod("rangeslider","isVisible")(t.xaxis)?P?(C=1.1,E="bottom"):(C=1,E="top"):P?(C=-.1,E="top"):(C=0,E="bottom")):(C=1,E="auto",O?M=1.02:(M=1,R="right")),i.coerce(d,h,{x:{valType:"number",editType:"legend",min:O?-2:0,max:O?3:1,dflt:M}},"x"),i.coerce(d,h,{y:{valType:"number",editType:"legend",min:P?-2:0,max:P?3:1,dflt:C}},"y"),p("traceorder",_),c.isGrouped(r[e])&&p("tracegroupgap"),p("entrywidth"),p("entrywidthmode"),p("indentation"),p("itemsizing"),p("itemwidth"),p("itemclick"),p("itemdoubleclick"),p("groupclick"),p("xanchor",R),p("yanchor",E),p("valign"),i.noneOrAll(d,h,["x","y"]),p("title.text")){p("title.side",I?"left":"top");var L=i.extendFlat({},f,{size:i.bigFont(f.size)});i.coerceFont(p,"title.font",L)}}}}e.exports=function(e,t,r){var n,o=r.slice(),a=t.shapes;if(a)for(n=0;n{"use strict";var n=r(41871),i=r(84468),o=r(68543),a=r(38361),s=r(13711),l=r(25732),c=r(3172),u=r(7605),d=r(13480),h=r(96050),p=r(76730),f=r(83943),m=f.LINE_SPACING,g=f.FROM_TL,y=f.FROM_BR,v=r(77978),x=r(44522),b=r(11990),_=/^legend[0-9]*$/;function w(e,t){var r,s,h=t||{},f=e._fullLayout,_=P(h),w=h._inHover;if(w?(s=h.layer,r="hover"):(s=f._infolayer,r=_),s){var T;if(r+=f._uid,e._legendMouseDownTime||(e._legendMouseDownTime=0),w){if(!h.entries)return;T=v(h.entries,h)}else{for(var O=(e.calcdata||[]).slice(),R=f.shapes,L=0;L1)}var j=f.hiddenlabels||[];if(!w&&(!f.showlegend||!T.length))return s.selectAll("."+_).remove(),f._topdefs.select("#"+r).remove(),o.autoMargin(e,_);var F=i.ensureSingle(s,"g",_,(function(e){w||e.attr("pointer-events","all")})),N=i.ensureSingleById(f._topdefs,"clipPath",r,(function(e){e.append("rect")})),B=i.ensureSingle(F,"rect","bg",(function(e){e.attr("shape-rendering","crispEdges")}));B.call(u.stroke,h.bordercolor).call(u.fill,h.bgcolor).style("stroke-width",h.borderwidth+"px");var V,U=i.ensureSingle(F,"g","scrollbox"),H=h.title;h._titleWidth=0,h._titleHeight=0,H.text?((V=i.ensureSingle(U,"text",_+"titletext")).attr("text-anchor","start").call(c.font,H.font).text(H.text),C(V,U,e,h,1)):U.selectAll("."+_+"titletext").remove();var $=i.ensureSingle(F,"rect","scrollbar",(function(e){e.attr(p.scrollBarEnterAttrs).call(u.fill,p.scrollBarColor)})),W=U.selectAll("g.groups").data(T);W.enter().append("g").attr("class","groups"),W.exit().remove();var q=W.selectAll("g.traces").data(i.identity);q.enter().append("g").attr("class","traces"),q.exit().remove(),q.style("opacity",(function(e){var t=e[0].trace;return a.traceIs(t,"pie-like")?-1!==j.indexOf(e[0].label)?.5:1:"legendonly"===t.visible?.5:1})).each((function(){n.select(this).call(A,e,h)})).call(x,e,h).each((function(){w||n.select(this).call(M,e,_)})),i.syncOrAsync([o.previousPromises,function(){return function(e,t,r,i){var o=e._fullLayout,a=P(i);i||(i=o[a]);var s=o._size,l=b.isVertical(i),u=b.isGrouped(i),d="fraction"===i.entrywidthmode,h=i.borderwidth,f=2*h,m=p.itemGap,g=i.indentation+i.itemwidth+2*m,y=2*(h+m),v=I(i),x=i.y<0||0===i.y&&"top"===v,_=i.y>1||1===i.y&&"bottom"===v,w=i.tracegroupgap,S={};i._maxHeight=Math.max(x||_?o.height/2:s.h,30);var A=0;i._width=0,i._height=0;var T=function(e){var t=0,r=0,n=e.title.side;n&&(-1!==n.indexOf("left")&&(t=e._titleWidth),-1!==n.indexOf("top")&&(r=e._titleHeight));return[t,r]}(i);if(l)r.each((function(e){var t=e[0].height;c.setTranslate(this,h+T[0],h+T[1]+i._height+t/2+m),i._height+=t,i._width=Math.max(i._width,e[0].width)})),A=g+i._width,i._width+=m+g+f,i._height+=y,u&&(t.each((function(e,t){c.setTranslate(this,0,t*i.tracegroupgap)})),i._height+=(i._lgroupsLength-1)*i.tracegroupgap);else{var M=E(i),C=i.x<0||0===i.x&&"right"===M,O=i.x>1||1===i.x&&"left"===M,R=_||x,L=o.width/2;i._maxWidth=Math.max(C?R&&"left"===M?s.l+s.w:L:O?R&&"right"===M?s.r+s.w:L:s.w,2*g);var D=0,z=0;r.each((function(e){var t=k(e,i,g);D=Math.max(D,t),z+=t})),A=null;var j=0;if(u){var F=0,N=0,B=0;t.each((function(){var e=0,t=0;n.select(this).selectAll("g.traces").each((function(r){var n=k(r,i,g),o=r[0].height;c.setTranslate(this,T[0],T[1]+h+m+o/2+t),t+=o,e=Math.max(e,n),S[r[0].trace.legendgroup]=e}));var r=e+m;N>0&&r+h+N>i._maxWidth?(j=Math.max(j,N),N=0,B+=F+w,F=t):F=Math.max(F,t),c.setTranslate(this,N,B),N+=r})),i._width=Math.max(j,N)+h,i._height=B+F+y}else{var V=r.size(),U=z+f+(V-1)*m=i._maxWidth&&(j=Math.max(j,q),$=0,W+=H,i._height+=H,H=0),c.setTranslate(this,T[0]+h+$,T[1]+h+W+t/2+m),q=$+r+m,$+=n,H=Math.max(H,t)})),U?(i._width=$+f,i._height=H+y):(i._width=Math.max(j,q)+f,i._height+=H+y)}}i._width=Math.ceil(Math.max(i._width+T[0],i._titleWidth+2*(h+p.titlePad))),i._height=Math.ceil(Math.max(i._height+T[1],i._titleHeight+2*(h+p.itemGap))),i._effHeight=Math.min(i._height,i._maxHeight);var G=e._context.edits,Y=G.legendText||G.legendPosition;r.each((function(e){var t=n.select(this).select("."+a+"toggle"),r=e[0].height,o=e[0].trace.legendgroup,s=k(e,i,g);u&&""!==o&&(s=S[o]);var h=Y?g:A||s;l||d||(h+=m/2),c.setRect(t,0,-r/2,h,r)}))}(e,W,q,h)},function(){var t,u,v,x,b=f._size,k=h.borderwidth,A="paper"===h.xref,T="paper"===h.yref;if(H.text&&function(e,t,r){if("top center"===t.title.side||"top right"===t.title.side){var n=t.title.font.size*m,i=0,o=e.node(),a=c.bBox(o).width;"top center"===t.title.side?i=.5*(t._width-2*r-2*p.titlePad-a):"top right"===t.title.side&&(i=t._width-2*r-2*p.titlePad-a),d.positionText(e,r+p.titlePad+i,r+n)}}(V,h,k),!w){var M,C;M=A?b.l+b.w*h.x-g[E(h)]*h._width:f.width*h.x-g[E(h)]*h._width,C=T?b.t+b.h*(1-h.y)-g[I(h)]*h._effHeight:f.height*(1-h.y)-g[I(h)]*h._effHeight;var P=function(e,t,r,n){var i=e._fullLayout,a=i[t],s=E(a),l=I(a),c="paper"===a.xref,u="paper"===a.yref;e._fullLayout._reservedMargin[t]={};var d=a.y<.5?"b":"t",h=a.x<.5?"l":"r",p={r:i.width-r,l:r+a._width,b:i.height-n,t:n+a._effHeight};if(c&&u)return o.autoMargin(e,t,{x:a.x,y:a.y,l:a._width*g[s],r:a._width*y[s],b:a._effHeight*y[l],t:a._effHeight*g[l]});c?e._fullLayout._reservedMargin[t][d]=p[d]:u||"v"===a.orientation?e._fullLayout._reservedMargin[t][h]=p[h]:e._fullLayout._reservedMargin[t][d]=p[d]}(e,_,M,C);if(P)return;if(f.margin.autoexpand){var O=M,R=C;M=A?i.constrain(M,0,f.width-h._width):O,C=T?i.constrain(C,0,f.height-h._effHeight):R,M!==O&&i.log("Constrain "+_+".x to make legend fit inside graph"),C!==R&&i.log("Constrain "+_+".y to make legend fit inside graph")}c.setTranslate(F,M,C)}if($.on(".drag",null),F.on("wheel",null),w||h._height<=h._maxHeight||e._context.staticPlot){var L=h._effHeight;w&&(L=h._height),B.attr({width:h._width-k,height:L-k,x:k/2,y:k/2}),c.setTranslate(U,0,0),N.select("rect").attr({width:h._width-2*k,height:L-2*k,x:k,y:k}),c.setClipUrl(U,r,e),c.setRect($,0,0,0,0),delete h._scrollY}else{var D,z,j,W=Math.max(p.scrollBarMinHeight,h._effHeight*h._effHeight/h._height),q=h._effHeight-W-2*p.scrollBarMargin,G=h._height-h._effHeight,Y=q/G,X=Math.min(h._scrollY||0,G);B.attr({width:h._width-2*k+p.scrollBarWidth+p.scrollBarMargin,height:h._effHeight-k,x:k/2,y:k/2}),N.select("rect").attr({width:h._width-2*k+p.scrollBarWidth+p.scrollBarMargin,height:h._effHeight-2*k,x:k,y:k+X}),c.setClipUrl(U,r,e),J(X,W,Y),F.on("wheel",(function(){J(X=i.constrain(h._scrollY+n.event.deltaY/q*G,0,G),W,Y),0!==X&&X!==G&&n.event.preventDefault()}));var Z=n.behavior.drag().on("dragstart",(function(){var e=n.event.sourceEvent;D="touchstart"===e.type?e.changedTouches[0].clientY:e.clientY,j=X})).on("drag",(function(){var e=n.event.sourceEvent;2===e.buttons||e.ctrlKey||(z="touchmove"===e.type?e.changedTouches[0].clientY:e.clientY,X=function(e,t,r){var n=(r-t)/Y+e;return i.constrain(n,0,G)}(j,D,z),J(X,W,Y))}));$.call(Z);var K=n.behavior.drag().on("dragstart",(function(){var e=n.event.sourceEvent;"touchstart"===e.type&&(D=e.changedTouches[0].clientY,j=X)})).on("drag",(function(){var e=n.event.sourceEvent;"touchmove"===e.type&&(z=e.changedTouches[0].clientY,X=function(e,t,r){var n=(t-r)/Y+e;return i.constrain(n,0,G)}(j,D,z),J(X,W,Y))}));U.call(K)}function J(t,r,n){h._scrollY=e._fullLayout[_]._scrollY=t,c.setTranslate(U,0,-t),c.setRect($,h._width,p.scrollBarMargin+t*n,p.scrollBarWidth,r),N.select("rect").attr("y",k+t)}e._context.edits.legendPosition&&(F.classed("cursor-move",!0),l.init({element:F.node(),gd:e,prepFn:function(e){if(e.target!==$.node()){var t=c.getTranslate(F);v=t.x,x=t.y}},moveFn:function(e,r){if(void 0!==v&&void 0!==x){var n=v+e,i=x+r;c.setTranslate(F,n,i),t=l.align(n,h._width,b.l,b.l+b.w,h.xanchor),u=l.align(i+h._height,-h._height,b.t+b.h,b.t,h.yanchor)}},doneFn:function(){if(void 0!==t&&void 0!==u){var r={};r[_+".x"]=t,r[_+".y"]=u,a.call("_guiRelayout",e,r)}},clickFn:function(t,r){var n=s.selectAll("g.traces").filter((function(){var e=this.getBoundingClientRect();return r.clientX>=e.left&&r.clientX<=e.right&&r.clientY>=e.top&&r.clientY<=e.bottom}));n.size()>0&&S(e,F,n,t,r)}}))}],e)}}function k(e,t,r){var n=e[0],i=n.width,o=t.entrywidthmode,a=n.trace.legendwidth||t.entrywidth;return"fraction"===o?t._maxWidth*a:r+(a||i)}function S(e,t,r,n,i){var o=r.data()[0][0].trace,l={event:i,node:r.node(),curveNumber:o.index,expandedIndex:o._expandedIndex,data:e.data,layout:e.layout,frames:e._transitionData._frames,config:e._context,fullData:e._fullData,fullLayout:e._fullLayout};o._group&&(l.group=o._group),a.traceIs(o,"pie-like")&&(l.label=r.datum()[0].label);var c=s.triggerHandler(e,"plotly_legendclick",l);if(1===n){if(!1===c)return;t._clickTimeout=setTimeout((function(){e._fullLayout&&h(r,e,n)}),e._context.doubleClickDelay)}else if(2===n){t._clickTimeout&&clearTimeout(t._clickTimeout),e._legendMouseDownTime=0,!1!==s.triggerHandler(e,"plotly_legenddoubleclick",l)&&!1!==c&&h(r,e,n)}}function A(e,t,r){var n,o,s=P(r),l=e.data()[0][0],u=l.trace,h=a.traceIs(u,"pie-like"),f=!r._inHover&&t._context.edits.legendText&&!h,m=r._maxNameLength;l.groupTitle?(n=l.groupTitle.text,o=l.groupTitle.font):(o=r.font,r.entries?n=l.text:(n=h?l.label:u.name,u._meta&&(n=i.templateString(n,u._meta))));var g=i.ensureSingle(e,"text",s+"text");g.attr("text-anchor","start").call(c.font,o).text(f?T(n,m):n);var y=r.indentation+r.itemwidth+2*p.itemGap;d.positionText(g,y,0),f?g.call(d.makeEditable,{gd:t,text:n}).call(C,e,t,r).on("edit",(function(n){this.text(T(n,m)).call(C,e,t,r);var o=l.trace._fullInput||{},s={};if(a.hasTransform(o,"groupby")){var c=a.getTransformIndices(o,"groupby"),d=c[c.length-1],h=i.keyedContainer(o,"transforms["+d+"].styles","target","value.name");h.set(l.trace._group,n),s=h.constructUpdate()}else s.name=n;return o._isShape?a.call("_guiRelayout",t,"shapes["+u.index+"].name",s.name):a.call("_guiRestyle",t,s,u.index)})):C(g,e,t,r)}function T(e,t){var r=Math.max(4,t);if(e&&e.trim().length>=r/2)return e;for(var n=r-(e=e||"").length;n>0;n--)e+=" ";return e}function M(e,t,r){var o,a=t._context.doubleClickDelay,s=1,l=i.ensureSingle(e,"rect",r+"toggle",(function(e){t._context.staticPlot||e.style("cursor","pointer").attr("pointer-events","all"),e.call(u.fill,"rgba(0,0,0,0)")}));t._context.staticPlot||(l.on("mousedown",(function(){(o=(new Date).getTime())-t._legendMouseDownTimea&&(s=Math.max(s-1,1)),S(t,i,e,s,n.event)}})))}function C(e,t,r,n,i){n._inHover&&e.attr("data-notex",!0),d.convertToTspans(e,r,(function(){!function(e,t,r,n){var i=e.data()[0][0];if(!r._inHover&&i&&!i.trace.showlegend)return void e.remove();var o=e.select("g[class*=math-group]"),a=o.node(),s=P(r);r||(r=t._fullLayout[s]);var l,u=r.borderwidth;l=1===n?r.title.font:i.groupTitle?i.groupTitle.font:r.font;var h,f,g=l.size*m;if(a){var y=c.bBox(a);h=y.height,f=y.width,1===n?c.setTranslate(o,u,u+.75*h):c.setTranslate(o,0,.25*h)}else{var v="."+s+(1===n?"title":"")+"text",x=e.select(v),b=d.lineCount(x),_=x.node();if(h=g*b,f=_?c.bBox(_).width:0,1===n)"left"===r.title.side&&(f+=2*p.itemGap),d.positionText(x,u+p.titlePad,u+g);else{var w=2*p.itemGap+r.indentation+r.itemwidth;i.groupTitle&&(w=p.itemGap,f-=r.indentation+r.itemwidth),d.positionText(x,w,-g*((b-1)/2-.3))}}1===n?(r._titleWidth=f,r._titleHeight=h):(i.lineHeight=g,i.height=Math.max(h,16)+3,i.width=f)}(t,r,n,i)}))}function E(e){return i.isRightAnchor(e)?"right":i.isCenterAnchor(e)?"center":"left"}function I(e){return i.isBottomAnchor(e)?"bottom":i.isMiddleAnchor(e)?"middle":"top"}function P(e){return e._id||"legend"}e.exports=function(e,t){if(t)w(e,t);else{var r=e._fullLayout,i=r._legends;r._infolayer.selectAll('[class^="legend"]').each((function(){var e=n.select(this),t=e.attr("class").split(" ")[0];t.match(_)&&-1===i.indexOf(t)&&e.remove()}));for(var o=0;o{"use strict";var n=r(38361),i=r(11990);e.exports=function(e,t,r){var o,a,s=t._inHover,l=i.isGrouped(t),c=i.isReversed(t),u={},d=[],h=!1,p={},f=0,m=0;function g(e,n,o){if(!1!==t.visible&&(!r||e===t._id))if(""!==n&&i.isGrouped(t))-1===d.indexOf(n)?(d.push(n),h=!0,u[n]=[o]):u[n].push(o);else{var a="~~i"+f;d.push(a),u[a]=[o],f++}}for(o=0;oM&&(T=M)}S[o][0]._groupMinRank=T,S[o][0]._preGroupSort=o}var C=function(e,t){return e.trace.legendrank-t.trace.legendrank||e._preSort-t._preSort};for(S.forEach((function(e,t){e[0]._preGroupSort=t})),S.sort((function(e,t){return e[0]._groupMinRank-t[0]._groupMinRank||e[0]._preGroupSort-t[0]._preGroupSort})),o=0;o{"use strict";var n=r(38361),i=r(84468),o=i.pushUnique,a=!0;e.exports=function(e,t,r){var s=t._fullLayout;if(!t._dragged&&!t._editing){var l,c=s.legend.itemclick,u=s.legend.itemdoubleclick,d=s.legend.groupclick;if(1===r&&"toggle"===c&&"toggleothers"===u&&a&&t.data&&t._context.showTips?(i.notifier(i._(t,"Double-click on legend to isolate one trace"),"long"),a=!1):a=!1,1===r?l=c:2===r&&(l=u),l){var h="togglegroup"===d,p=s.hiddenlabels?s.hiddenlabels.slice():[],f=e.data()[0][0];if(!f.groupTitle||!f.noClick){var m=t._fullData,g=(s.shapes||[]).filter((function(e){return e.showlegend})),y=m.concat(g),v=f.trace;v._isShape&&(v=v._fullInput);var x,b,_,w,k,S=v.legendgroup,A={},T=[],M=[],C=[],E=(s.shapes||[]).map((function(e){return e._input})),I=!1,P=v.legend,O=v._fullInput;if(!(O&&O._isShape)&&n.traceIs(v,"pie-like")){var R=f.label,L=p.indexOf(R);if("toggle"===l)-1===L?p.push(R):p.splice(L,1);else if("toggleothers"===l){var D=-1!==L,z=[];for(x=0;x{"use strict";t.isGrouped=function(e){return-1!==(e.traceorder||"").indexOf("grouped")},t.isVertical=function(e){return"h"!==e.orientation},t.isReversed=function(e){return-1!==(e.traceorder||"").indexOf("reversed")}},65463:(e,t,r)=>{"use strict";e.exports={moduleType:"component",name:"legend",layoutAttributes:r(31334),supplyLayoutDefaults:r(11217),draw:r(81017),style:r(44522)}},44522:(e,t,r)=>{"use strict";var n=r(41871),i=r(38361),o=r(84468),a=o.strTranslate,s=r(3172),l=r(7605),c=r(73084).extractOpts,u=r(31811),d=r(32100),h=r(97367).castOption,p=r(76730);function f(e,t){return(t?"radial":"horizontal")+(e?"":"reversed")}function m(e){var t=e[0].trace,r=t.contours,n=u.hasLines(t),i=u.hasMarkers(t),o=t.visible&&t.fill&&"none"!==t.fill,a=!1,s=!1;if(r){var l=r.coloring;"lines"===l?a=!0:n="none"===l||"heatmap"===l||r.showlines,"constraint"===r.type?o="="!==r._operation:"fill"!==l&&"heatmap"!==l||(s=!0)}return{showMarker:i,showLine:n,showFill:o,showGradientLine:a,showGradientFill:s,anyLine:n||a,anyFill:o||s}}function g(e,t,r){return e&&o.isArrayOrTypedArray(e)?t:e>r?r:e}e.exports=function(e,t,r){var y=t._fullLayout;r||(r=y.legend);var v="constant"===r.itemsizing,x=r.itemwidth,b=(x+2*p.itemGap)/2,_=a(b,0),w=function(e,t,r,n){var i;if(e+1)i=e;else{if(!(t&&t.width>0))return 0;i=t.width}return v?n:Math.min(i,r)};function k(e,o,a){var u=e[0].trace,d=u.marker||{},h=d.line||{},p=d.cornerradius?"M6,3a3,3,0,0,1-3,3H-3a3,3,0,0,1-3-3V-3a3,3,0,0,1,3-3H3a3,3,0,0,1,3,3Z":"M6,6H-6V-6H6Z",f=a?u.visible&&u.type===a:i.traceIs(u,"bar"),m=n.select(o).select("g.legendpoints").selectAll("path.legend"+a).data(f?[e]:[]);m.enter().append("path").classed("legend"+a,!0).attr("d",p).attr("transform",_),m.exit().remove(),m.each((function(e){var i=n.select(this),o=e[0],a=w(o.mlw,d.line,5,2);i.style("stroke-width",a+"px");var p=o.mcc;if(!r._inHover&&"mc"in o){var f=c(d),m=f.mid;void 0===m&&(m=(f.max+f.min)/2),p=s.tryColorscale(d,"")(m)}var y=p||o.mc||d.color,v=d.pattern,x=v&&s.getPatternAttr(v.shape,0,"");if(x){var b=s.getPatternAttr(v.bgcolor,0,null),_=s.getPatternAttr(v.fgcolor,0,null),k=v.fgopacity,S=g(v.size,8,10),A=g(v.solidity,.5,1),T="legend-"+u.uid;i.call(s.pattern,"legend",t,T,x,S,A,p,v.fillmode,b,_,k)}else i.call(l.fill,y);a&&l.stroke(i,o.mlc||h.color)}))}function S(e,r,a){var s=e[0],l=s.trace,c=a?l.visible&&l.type===a:i.traceIs(l,a),u=n.select(r).select("g.legendpoints").selectAll("path.legend"+a).data(c?[e]:[]);if(u.enter().append("path").classed("legend"+a,!0).attr("d","M6,6H-6V-6H6Z").attr("transform",_),u.exit().remove(),u.size()){var p=l.marker||{},f=w(h(p.line.width,s.pts),p.line,5,2),m="pieLike",g=o.minExtend(l,{marker:{line:{width:f}}},m),y=o.minExtend(s,{trace:g},m);d(u,y,g,t)}}e.each((function(e){var t=n.select(this),i=o.ensureSingle(t,"g","layers");i.style("opacity",e[0].trace.opacity);var s=r.indentation,l=r.valign,c=e[0].lineHeight,u=e[0].height;if("middle"===l&&0===s||!c||!u)i.attr("transform",null);else{var d={top:1,bottom:-1}[l]*(.5*(c-u+3))||0,h=r.indentation;i.attr("transform",a(h,d))}i.selectAll("g.legendfill").data([e]).enter().append("g").classed("legendfill",!0),i.selectAll("g.legendlines").data([e]).enter().append("g").classed("legendlines",!0);var p=i.selectAll("g.legendsymbols").data([e]);p.enter().append("g").classed("legendsymbols",!0),p.selectAll("g.legendpoints").data([e]).enter().append("g").classed("legendpoints",!0)})).each((function(e){var r,i=e[0].trace,a=[];if(i.visible)switch(i.type){case"histogram2d":case"heatmap":a=[["M-15,-2V4H15V-2Z"]],r=!0;break;case"choropleth":case"choroplethmapbox":case"choroplethmap":a=[["M-6,-6V6H6V-6Z"]],r=!0;break;case"densitymapbox":case"densitymap":a=[["M-6,0 a6,6 0 1,0 12,0 a 6,6 0 1,0 -12,0"]],r="radial";break;case"cone":a=[["M-6,2 A2,2 0 0,0 -6,6 V6L6,4Z"],["M-6,-6 A2,2 0 0,0 -6,-2 L6,-4Z"],["M-6,-2 A2,2 0 0,0 -6,2 L6,0Z"]],r=!1;break;case"streamtube":a=[["M-6,2 A2,2 0 0,0 -6,6 H6 A2,2 0 0,1 6,2 Z"],["M-6,-6 A2,2 0 0,0 -6,-2 H6 A2,2 0 0,1 6,-6 Z"],["M-6,-2 A2,2 0 0,0 -6,2 H6 A2,2 0 0,1 6,-2 Z"]],r=!1;break;case"surface":a=[["M-6,-6 A2,3 0 0,0 -6,0 H6 A2,3 0 0,1 6,-6 Z"],["M-6,1 A2,3 0 0,1 -6,6 H6 A2,3 0 0,0 6,0 Z"]],r=!0;break;case"mesh3d":a=[["M-6,6H0L-6,-6Z"],["M6,6H0L6,-6Z"],["M-6,-6H6L0,6Z"]],r=!1;break;case"volume":a=[["M-6,6H0L-6,-6Z"],["M6,6H0L6,-6Z"],["M-6,-6H6L0,6Z"]],r=!0;break;case"isosurface":a=[["M-6,6H0L-6,-6Z"],["M6,6H0L6,-6Z"],["M-6,-6 A12,24 0 0,0 6,-6 L0,6Z"]],r=!1}var u=n.select(this).select("g.legendpoints").selectAll("path.legend3dandfriends").data(a);u.enter().append("path").classed("legend3dandfriends",!0).attr("transform",_).style("stroke-miterlimit",1),u.exit().remove(),u.each((function(e,a){var u,d=n.select(this),h=c(i),p=h.colorscale,m=h.reversescale;if(p){if(!r){var g=p.length;u=0===a?p[m?g-1:0][1]:1===a?p[m?0:g-1][1]:p[Math.floor((g-1)/2)][1]}}else{var y=i.vertexcolor||i.facecolor||i.color;u=o.isArrayOrTypedArray(y)?y[a]||y[0]:y}d.attr("d",e[0]),u?d.call(l.fill,u):d.call((function(e){if(e.size()){var n="legendfill-"+i.uid;s.gradient(e,t,n,f(m,"radial"===r),p,"fill")}}))}))})).each((function(e){var t=e[0].trace,r="waterfall"===t.type;if(e[0]._distinct&&r){var i=e[0].trace[e[0].dir].marker;return e[0].mc=i.color,e[0].mlw=i.line.width,e[0].mlc=i.line.color,k(e,this,"waterfall")}var o=[];t.visible&&r&&(o=e[0].hasTotals?[["increasing","M-6,-6V6H0Z"],["totals","M6,6H0L-6,-6H-0Z"],["decreasing","M6,6V-6H0Z"]]:[["increasing","M-6,-6V6H6Z"],["decreasing","M6,6V-6H-6Z"]]);var a=n.select(this).select("g.legendpoints").selectAll("path.legendwaterfall").data(o);a.enter().append("path").classed("legendwaterfall",!0).attr("transform",_).style("stroke-miterlimit",1),a.exit().remove(),a.each((function(e){var r=n.select(this),i=t[e[0]].marker,o=w(void 0,i.line,5,2);r.attr("d",e[1]).style("stroke-width",o+"px").call(l.fill,i.color),o&&r.call(l.stroke,i.line.color)}))})).each((function(e){k(e,this,"funnel")})).each((function(e){k(e,this)})).each((function(e){var r=e[0].trace,a=n.select(this).select("g.legendpoints").selectAll("path.legendbox").data(r.visible&&i.traceIs(r,"box-violin")?[e]:[]);a.enter().append("path").classed("legendbox",!0).attr("d","M6,6H-6V-6H6Z").attr("transform",_),a.exit().remove(),a.each((function(){var e=n.select(this);if("all"!==r.boxpoints&&"all"!==r.points||0!==l.opacity(r.fillcolor)||0!==l.opacity((r.line||{}).color)){var i=w(void 0,r.line,5,2);e.style("stroke-width",i+"px").call(l.fill,r.fillcolor),i&&l.stroke(e,r.line.color)}else{var c=o.minExtend(r,{marker:{size:v?12:o.constrain(r.marker.size,2,16),sizeref:1,sizemin:1,sizemode:"diameter"}});a.call(s.pointStyle,c,t)}}))})).each((function(e){S(e,this,"funnelarea")})).each((function(e){S(e,this,"pie")})).each((function(e){var r,i,a=m(e),l=a.showFill,d=a.showLine,h=a.showGradientLine,p=a.showGradientFill,g=a.anyFill,y=a.anyLine,v=e[0],b=v.trace,_=c(b),k=_.colorscale,S=_.reversescale,A=u.hasMarkers(b)||!g?"M5,0":y?"M5,-2":"M5,-3",T=n.select(this),M=T.select(".legendfill").selectAll("path").data(l||p?[e]:[]);if(M.enter().append("path").classed("js-fill",!0),M.exit().remove(),M.attr("d",A+"h"+x+"v6h-"+x+"z").call((function(e){if(e.size())if(l)s.fillGroupStyle(e,t,!0);else{var r="legendfill-"+b.uid;s.gradient(e,t,r,f(S),k,"fill")}})),d||h){var C=w(void 0,b.line,10,5);i=o.minExtend(b,{line:{width:C}}),r=[o.minExtend(v,{trace:i})]}var E=T.select(".legendlines").selectAll("path").data(d||h?[r]:[]);E.enter().append("path").classed("js-line",!0),E.exit().remove(),E.attr("d",A+(h?"l"+x+",0.0001":"h"+x)).call(d?s.lineGroupStyle:function(e){if(e.size()){var r="legendline-"+b.uid;s.lineGroupStyle(e),s.gradient(e,t,r,f(S),k,"stroke")}})})).each((function(e){var r,i,a=m(e),l=a.anyFill,c=a.anyLine,d=a.showLine,h=a.showMarker,p=e[0],f=p.trace,g=!h&&!c&&!l&&u.hasText(f);function y(e,t,r,n){var i=o.nestedProperty(f,e).get(),a=o.isArrayOrTypedArray(i)&&t?t(i):i;if(v&&a&&void 0!==n&&(a=n),r){if(ar[1])return r[1]}return a}function x(e){return p._distinct&&p.index&&e[p.index]?e[p.index]:e[0]}if(h||g||d){var b={},w={};if(h){b.mc=y("marker.color",x),b.mx=y("marker.symbol",x),b.mo=y("marker.opacity",o.mean,[.2,1]),b.mlc=y("marker.line.color",x),b.mlw=y("marker.line.width",o.mean,[0,5],2),w.marker={sizeref:1,sizemin:1,sizemode:"diameter"};var k=y("marker.size",o.mean,[2,16],12);b.ms=k,w.marker.size=k}d&&(w.line={width:y("line.width",x,[0,10],5)}),g&&(b.tx="Aa",b.tp=y("textposition",x),b.ts=10,b.tc=y("textfont.color",x),b.tf=y("textfont.family",x),b.tw=y("textfont.weight",x),b.ty=y("textfont.style",x),b.tv=y("textfont.variant",x),b.tC=y("textfont.textcase",x),b.tE=y("textfont.lineposition",x),b.tS=y("textfont.shadow",x)),r=[o.minExtend(p,b)],(i=o.minExtend(f,w)).selectedpoints=null,i.texttemplate=null}var S=n.select(this).select("g.legendpoints"),A=S.selectAll("path.scatterpts").data(h?r:[]);A.enter().insert("path",":first-child").classed("scatterpts",!0).attr("transform",_),A.exit().remove(),A.call(s.pointStyle,i,t),h&&(r[0].mrc=3);var T=S.selectAll("g.pointtext").data(g?r:[]);T.enter().append("g").classed("pointtext",!0).append("text").attr("transform",_),T.exit().remove(),T.selectAll("text").call(s.textPointStyle,i,t)})).each((function(e){var t=e[0].trace,r=n.select(this).select("g.legendpoints").selectAll("path.legendcandle").data(t.visible&&"candlestick"===t.type?[e,e]:[]);r.enter().append("path").classed("legendcandle",!0).attr("d",(function(e,t){return t?"M-15,0H-8M-8,6V-6H8Z":"M15,0H8M8,-6V6H-8Z"})).attr("transform",_).style("stroke-miterlimit",1),r.exit().remove(),r.each((function(e,r){var i=n.select(this),o=t[r?"increasing":"decreasing"],a=w(void 0,o.line,5,2);i.style("stroke-width",a+"px").call(l.fill,o.fillcolor),a&&l.stroke(i,o.line.color)}))})).each((function(e){var t=e[0].trace,r=n.select(this).select("g.legendpoints").selectAll("path.legendohlc").data(t.visible&&"ohlc"===t.type?[e,e]:[]);r.enter().append("path").classed("legendohlc",!0).attr("d",(function(e,t){return t?"M-15,0H0M-8,-6V0":"M15,0H0M8,6V0"})).attr("transform",_).style("stroke-miterlimit",1),r.exit().remove(),r.each((function(e,r){var i=n.select(this),o=t[r?"increasing":"decreasing"],a=w(void 0,o.line,5,2);i.style("fill","none").call(s.dashLine,o.line.dash,a),a&&l.stroke(i,o.line.color)}))}))}},84529:(e,t,r)=>{"use strict";var n=r(71507);e.exports={editType:"modebar",orientation:{valType:"enumerated",values:["v","h"],dflt:"h",editType:"modebar",description:"Sets the orientation of the modebar."},bgcolor:{valType:"color",editType:"modebar",description:"Sets the background color of the modebar."},color:{valType:"color",editType:"modebar",description:"Sets the color of the icons in the modebar."},activecolor:{valType:"color",editType:"modebar",description:"Sets the color of the active or hovered on icons in the modebar."},uirevision:{valType:"any",editType:"none",description:["Controls persistence of user-driven changes related to the modebar,","including `hovermode`, `dragmode`, and `showspikes` at both the","root level and inside subplots. Defaults to `layout.uirevision`."].join(" ")},add:{valType:"string",arrayOk:!0,dflt:"",editType:"modebar",description:["Determines which predefined modebar buttons to add.","Please note that these buttons will only be shown if they are","compatible with all trace types used in a graph.","Similar to `config.modeBarButtonsToAdd` option.","This may include *"+n.backButtons.join("*, *")+"*."].join(" ")},remove:{valType:"string",arrayOk:!0,dflt:"",editType:"modebar",description:["Determines which predefined modebar buttons to remove.","Similar to `config.modeBarButtonsToRemove` option.","This may include *"+n.foreButtons.join("*, *")+"*."].join(" ")}}},57367:(e,t,r)=>{"use strict";var n=r(38361),i=r(68543),o=r(11576),a=r(1351),s=r(98820).eraseActiveShape,l=r(84468),c=l._,u=e.exports={};function d(e,t){var r,i,a=t.currentTarget,s=a.getAttribute("data-attr"),l=a.getAttribute("data-val")||!0,c=e._fullLayout,u={},d=o.list(e,null,!0),h=c._cartesianSpikesEnabled;if("zoom"===s){var p,f="in"===l?.5:2,m=(1+f)/2,g=(1-f)/2;for(i=0;i{"use strict";var n=r(57367),i=Object.keys(n),o=["drawline","drawopenpath","drawclosedpath","drawcircle","drawrect","eraseshape"],a=["v1hovermode","hoverclosest","hovercompare","togglehover","togglespikelines"].concat(o),s=[];i.forEach((function(e){!function(e){if(-1===a.indexOf(e._cat||e.name)){var t=e.name,r=(e._cat||e.name).toLowerCase();-1===s.indexOf(t)&&s.push(t),-1===s.indexOf(r)&&s.push(r)}}(n[e])})),s.sort(),e.exports={DRAW_MODES:o,backButtons:a,foreButtons:s}},2422:(e,t,r)=>{"use strict";var n=r(84468),i=r(7605),o=r(37091),a=r(84529);e.exports=function(e,t){var r=e.modebar||{},s=o.newContainer(t,"modebar");function l(e,t){return n.coerce(r,s,a,e,t)}l("orientation"),l("bgcolor",i.addOpacity(t.paper_bgcolor,.5));var c=i.contrast(i.rgb(t.modebar.bgcolor));l("color",i.addOpacity(c,.3)),l("activecolor",i.addOpacity(c,.7)),l("uirevision",t.uirevision),l("add"),l("remove")}},94082:(e,t,r)=>{"use strict";e.exports={moduleType:"component",name:"modebar",layoutAttributes:r(84529),supplyLayoutDefaults:r(2422),manage:r(81515)}},81515:(e,t,r)=>{"use strict";var n=r(11576),i=r(31811),o=r(38361),a=r(82561).isUnifiedHover,s=r(17402),l=r(57367),c=r(71507).DRAW_MODES,u=r(84468).extendDeep;e.exports=function(e){var t=e._fullLayout,r=e._context,d=t._modeBar;if(r.displayModeBar||r.watermark){if(!Array.isArray(r.modeBarButtonsToRemove))throw new Error(["*modeBarButtonsToRemove* configuration options","must be an array."].join(" "));if(!Array.isArray(r.modeBarButtonsToAdd))throw new Error(["*modeBarButtonsToAdd* configuration options","must be an array."].join(" "));var h,p=r.modeBarButtons;h=Array.isArray(p)&&p.length?function(e){for(var t=u([],e),r=0;r1?(R=["toggleHover"],L=["resetViews"]):y?(O=["zoomInGeo","zoomOutGeo"],R=["hoverClosestGeo"],L=["resetGeo"]):g?(R=["hoverClosest3d"],L=["resetCameraDefault3d","resetCameraLastSave3d"]):w?(O=["zoomInMapbox","zoomOutMapbox"],R=["toggleHover"],L=["resetViewMapbox"]):k?(O=["zoomInMap","zoomOutMap"],R=["toggleHover"],L=["resetViewMap"]):b?R=["hoverClosestGl2d"]:v?R=["hoverClosestPie"]:T?(R=["hoverClosestCartesian","hoverCompareCartesian"],L=["resetViewSankey"]):R=["toggleHover"];m&&R.push("toggleSpikelines","hoverClosestCartesian","hoverCompareCartesian");(function(e){for(var t=0;t{"use strict";var n=r(41871),i=r(22036),o=r(84468),a=r(1351),s=r(17316).version,l=new DOMParser;function c(e){this.container=e.container,this.element=document.createElement("div"),this.update(e.graphInfo,e.buttons),this.container.appendChild(this.element)}var u=c.prototype;u.update=function(e,t){this.graphInfo=e;var r=this.graphInfo._context,n=this.graphInfo._fullLayout,i="modebar-"+n._uid;this.element.setAttribute("id",i),this._uid=i,this.element.className="modebar","hover"===r.displayModeBar&&(this.element.className+=" modebar--hover ease-bg"),"v"===n.modebar.orientation&&(this.element.className+=" vertical",t=t.reverse());var a=n.modebar,s="hover"===r.displayModeBar?".js-plotly-plot .plotly:hover ":"";o.deleteRelatedStyleRule(i),o.addRelatedStyleRule(i,s+"#"+i+" .modebar-group","background-color: "+a.bgcolor),o.addRelatedStyleRule(i,"#"+i+" .modebar-btn .icon path","fill: "+a.color),o.addRelatedStyleRule(i,"#"+i+" .modebar-btn:hover .icon path","fill: "+a.activecolor),o.addRelatedStyleRule(i,"#"+i+" .modebar-btn.active .icon path","fill: "+a.activecolor);var l=!this.hasButtons(t),c=this.hasLogo!==r.displaylogo,u=this.locale!==r.locale;if(this.locale=r.locale,(l||c||u)&&(this.removeAllButtons(),this.updateButtons(t),r.watermark||r.displaylogo)){var d=this.getLogo();r.watermark&&(d.className=d.className+" watermark"),"v"===n.modebar.orientation?this.element.insertBefore(d,this.element.childNodes[0]):this.element.appendChild(d),this.hasLogo=!0}this.updateActiveButton()},u.updateButtons=function(e){var t=this;this.buttons=e,this.buttonElements=[],this.buttonsNames=[],this.buttons.forEach((function(e){var r=t.createGroup();e.forEach((function(e){var n=e.name;if(!n)throw new Error("must provide button 'name' in button config");if(-1!==t.buttonsNames.indexOf(n))throw new Error("button name '"+n+"' is taken");t.buttonsNames.push(n);var i=t.createButton(e);t.buttonElements.push(i),r.appendChild(i)})),t.element.appendChild(r)}))},u.createGroup=function(){var e=document.createElement("div");return e.className="modebar-group",e},u.createButton=function(e){var t=this,r=document.createElement("a");r.setAttribute("rel","tooltip"),r.className="modebar-btn";var i=e.title;void 0===i?i=e.name:"function"===typeof i&&(i=i(this.graphInfo)),(i||0===i)&&r.setAttribute("data-title",i),void 0!==e.attr&&r.setAttribute("data-attr",e.attr);var o=e.val;if(void 0!==o&&("function"===typeof o&&(o=o(this.graphInfo)),r.setAttribute("data-val",o)),"function"!==typeof e.click)throw new Error("must provide button 'click' function in button config");r.addEventListener("click",(function(r){e.click(t.graphInfo,r),t.updateActiveButton(r.currentTarget)})),r.setAttribute("data-toggle",e.toggle||!1),e.toggle&&n.select(r).classed("active",!0);var s=e.icon;return"function"===typeof s?r.appendChild(s()):r.appendChild(this.createIcon(s||a.question)),r.setAttribute("data-gravity",e.gravity||"n"),r},u.createIcon=function(e){var t,r=i(e.height)?Number(e.height):e.ascent-e.descent,n="http://www.w3.org/2000/svg";if(e.path){(t=document.createElementNS(n,"svg")).setAttribute("viewBox",[0,0,e.width,r].join(" ")),t.setAttribute("class","icon");var o=document.createElementNS(n,"path");o.setAttribute("d",e.path),e.transform?o.setAttribute("transform",e.transform):void 0!==e.ascent&&o.setAttribute("transform","matrix(1 0 0 -1 0 "+e.ascent+")"),t.appendChild(o)}e.svg&&(t=l.parseFromString(e.svg,"application/xml").childNodes[0]);return t.setAttribute("height","1em"),t.setAttribute("width","1em"),t},u.updateActiveButton=function(e){var t=this.graphInfo._fullLayout,r=void 0!==e?e.getAttribute("data-attr"):null;this.buttonElements.forEach((function(e){var i=e.getAttribute("data-val")||!0,a=e.getAttribute("data-attr"),s="true"===e.getAttribute("data-toggle"),l=n.select(e);if(s)a===r&&l.classed("active",!l.classed("active"));else{var c=null===a?a:o.nestedProperty(t,a).get();l.classed("active",c===i)}}))},u.hasButtons=function(e){var t=this.buttons;if(!t)return!1;if(e.length!==t.length)return!1;for(var r=0;r{"use strict";var n=r(91740),i=r(17992),o=(0,r(37091).templatedArray)("button",{visible:{valType:"boolean",dflt:!0,editType:"plot",description:"Determines whether or not this button is visible."},step:{valType:"enumerated",values:["month","year","day","hour","minute","second","all"],dflt:"month",editType:"plot",description:["The unit of measurement that the `count` value will set the range by."].join(" ")},stepmode:{valType:"enumerated",values:["backward","todate"],dflt:"backward",editType:"plot",description:["Sets the range update mode.","If *backward*, the range update shifts the start of range","back *count* times *step* milliseconds.","If *todate*, the range update shifts the start of range","back to the first timestamp from *count* times","*step* milliseconds back.","For example, with `step` set to *year* and `count` set to *1*","the range update shifts the start of the range back to","January 01 of the current year.","Month and year *todate* are currently available only","for the built-in (Gregorian) calendar."].join(" ")},count:{valType:"number",min:0,dflt:1,editType:"plot",description:["Sets the number of steps to take to update the range.","Use with `step` to specify the update interval."].join(" ")},label:{valType:"string",editType:"plot",description:"Sets the text label to appear on the button."},editType:"plot",description:["Sets the specifications for each buttons.","By default, a range selector comes with no buttons."].join(" ")});e.exports={visible:{valType:"boolean",editType:"plot",description:["Determines whether or not this range selector is visible.","Note that range selectors are only available for x axes of","`type` set to or auto-typed to *date*."].join(" ")},buttons:o,x:{valType:"number",min:-2,max:3,editType:"plot",description:"Sets the x position (in normalized coordinates) of the range selector."},xanchor:{valType:"enumerated",values:["auto","left","center","right"],dflt:"left",editType:"plot",description:["Sets the range selector's horizontal position anchor.","This anchor binds the `x` position to the *left*, *center*","or *right* of the range selector."].join(" ")},y:{valType:"number",min:-2,max:3,editType:"plot",description:"Sets the y position (in normalized coordinates) of the range selector."},yanchor:{valType:"enumerated",values:["auto","top","middle","bottom"],dflt:"bottom",editType:"plot",description:["Sets the range selector's vertical position anchor","This anchor binds the `y` position to the *top*, *middle*","or *bottom* of the range selector."].join(" ")},font:n({editType:"plot",description:"Sets the font of the range selector button text."}),bgcolor:{valType:"color",dflt:i.lightLine,editType:"plot",description:"Sets the background color of the range selector buttons."},activecolor:{valType:"color",editType:"plot",description:"Sets the background color of the active range selector button."},bordercolor:{valType:"color",dflt:i.defaultLine,editType:"plot",description:"Sets the color of the border enclosing the range selector."},borderwidth:{valType:"number",min:0,dflt:0,editType:"plot",description:"Sets the width (in px) of the border enclosing the range selector."},editType:"plot"}},85651:e=>{"use strict";e.exports={yPad:.02,minButtonWidth:30,rx:3,ry:3,lightAmount:25,darkAmount:10}},4086:(e,t,r)=>{"use strict";var n=r(84468),i=r(7605),o=r(37091),a=r(38851),s=r(47377),l=r(85651);function c(e,t,r,i){var o=i.calendar;function a(r,i){return n.coerce(e,t,s.buttons,r,i)}if(a("visible")){var l=a("step");"all"!==l&&(!o||"gregorian"===o||"month"!==l&&"year"!==l?a("stepmode"):t.stepmode="backward",a("count")),a("label")}}e.exports=function(e,t,r,u,d){var h=e.rangeselector||{},p=o.newContainer(t,"rangeselector");function f(e,t){return n.coerce(h,p,s,e,t)}if(f("visible",a(h,p,{name:"buttons",handleItemDefaults:c,calendar:d}).length>0)){var m=function(e,t,r){for(var n=r.filter((function(r){return t[r].anchor===e._id})),i=0,o=0;o{"use strict";var n=r(41871),i=r(38361),o=r(68543),a=r(7605),s=r(3172),l=r(84468),c=l.strTranslate,u=r(13480),d=r(11576),h=r(83943),p=h.LINE_SPACING,f=h.FROM_TL,m=h.FROM_BR,g=r(85651),y=r(35228);function v(e){return e._id}function x(e,t,r){var n=l.ensureSingle(e,"rect","selector-rect",(function(e){e.attr("shape-rendering","crispEdges")}));n.attr({rx:g.rx,ry:g.ry}),n.call(a.stroke,t.bordercolor).call(a.fill,function(e,t){return t._isActive||t._isHovered?e.activecolor:e.bgcolor}(t,r)).style("stroke-width",t.borderwidth+"px")}function b(e,t,r,n){l.ensureSingle(e,"text","selector-text",(function(e){e.attr("text-anchor","middle")})).call(s.font,t.font).text(function(e,t){if(e.label)return t?l.templateString(e.label,t):e.label;return"all"===e.step?"all":e.count+e.step.charAt(0)}(r,n._fullLayout._meta)).call((function(e){u.convertToTspans(e,n)}))}e.exports=function(e){var t=e._fullLayout._infolayer.selectAll(".rangeselector").data(function(e){for(var t=d.list(e,"x",!0),r=[],n=0;n{"use strict";var n=r(32385),i=r(84468).titleCase;e.exports=function(e,t){var r=e._name,o={};if("all"===t.step)o[r+".autorange"]=!0;else{var a=function(e,t){var r,o=e.range,a=new Date(e.r2l(o[1])),s=t.step,l=n["utc"+i(s)],c=t.count;switch(t.stepmode){case"backward":r=e.l2r(+l.offset(a,-c));break;case"todate":var u=l.offset(a,-c);r=e.l2r(+l.ceil(u))}var d=o[1];return[r,d]}(e,t);o[r+".range[0]"]=a[0],o[r+".range[1]"]=a[1]}return o}},89922:(e,t,r)=>{"use strict";e.exports={moduleType:"component",name:"rangeselector",schema:{subplots:{xaxis:{rangeselector:r(47377)}}},layoutAttributes:r(47377),handleDefaults:r(4086),draw:r(20954)}},97681:(e,t,r)=>{"use strict";var n=r(17992);e.exports={bgcolor:{valType:"color",dflt:n.background,editType:"plot",description:"Sets the background color of the range slider."},bordercolor:{valType:"color",dflt:n.defaultLine,editType:"plot",description:"Sets the border color of the range slider."},borderwidth:{valType:"integer",dflt:0,min:0,editType:"plot",description:"Sets the border width of the range slider."},autorange:{valType:"boolean",dflt:!0,editType:"calc",impliedEdits:{"range[0]":void 0,"range[1]":void 0},description:["Determines whether or not the range slider range is","computed in relation to the input data.","If `range` is provided, then `autorange` is set to *false*."].join(" ")},range:{valType:"info_array",items:[{valType:"any",editType:"calc",impliedEdits:{"^autorange":!1}},{valType:"any",editType:"calc",impliedEdits:{"^autorange":!1}}],editType:"calc",impliedEdits:{autorange:!1},description:["Sets the range of the range slider.","If not set, defaults to the full xaxis range.","If the axis `type` is *log*, then you must take the","log of your desired range.","If the axis `type` is *date*, it should be date strings,","like date data, though Date objects and unix milliseconds","will be accepted and converted to strings.","If the axis `type` is *category*, it should be numbers,","using the scale where each category is assigned a serial","number from zero in the order it appears."].join(" ")},thickness:{valType:"number",dflt:.15,min:0,max:1,editType:"plot",description:["The height of the range slider as a fraction of the","total plot area height."].join(" ")},visible:{valType:"boolean",dflt:!0,editType:"calc",description:["Determines whether or not the range slider will be visible.","If visible, perpendicular axes will be set to `fixedrange`"].join(" ")},editType:"calc"}},2122:(e,t,r)=>{"use strict";var n=r(11576).list,i=r(49618).getAutoRange,o=r(13299);e.exports=function(e){for(var t=n(e,"x",!0),r=0;r{"use strict";e.exports={name:"rangeslider",containerClassName:"rangeslider-container",bgClassName:"rangeslider-bg",rangePlotClassName:"rangeslider-rangeplot",maskMinClassName:"rangeslider-mask-min",maskMaxClassName:"rangeslider-mask-max",slideBoxClassName:"rangeslider-slidebox",grabberMinClassName:"rangeslider-grabber-min",grabAreaMinClassName:"rangeslider-grabarea-min",handleMinClassName:"rangeslider-handle-min",grabberMaxClassName:"rangeslider-grabber-max",grabAreaMaxClassName:"rangeslider-grabarea-max",handleMaxClassName:"rangeslider-handle-max",maskMinOppAxisClassName:"rangeslider-mask-min-opp-axis",maskMaxOppAxisClassName:"rangeslider-mask-max-opp-axis",maskColor:"rgba(0,0,0,0.4)",maskOppAxisColor:"rgba(0,0,0,0.2)",slideBoxFill:"transparent",slideBoxCursor:"ew-resize",grabAreaFill:"transparent",grabAreaCursor:"col-resize",grabAreaWidth:10,handleWidth:4,handleRadius:1,handleStrokeWidth:1,extraPad:15}},66166:(e,t,r)=>{"use strict";var n=r(84468),i=r(37091),o=r(11576),a=r(97681),s=r(75800);e.exports=function(e,t,r){var l=e[r],c=t[r];if(l.rangeslider||t._requestRangeslider[c._id]){n.isPlainObject(l.rangeslider)||(l.rangeslider={});var u,d,h=l.rangeslider,p=i.newContainer(c,"rangeslider");if(_("visible")){_("bgcolor",t.plot_bgcolor),_("bordercolor"),_("borderwidth"),_("thickness"),_("autorange",!c.isValidRange(h.range)),_("range");var f=t._subplots;if(f)for(var m=f.cartesian.filter((function(e){return e.substr(0,e.indexOf("y"))===o.name2id(r)})).map((function(e){return e.substr(e.indexOf("y"),e.length)})),g=n.simpleMap(m,o.id2name),y=0;y{"use strict";var n=r(41871),i=r(38361),o=r(68543),a=r(84468),s=a.strTranslate,l=r(3172),c=r(7605),u=r(13701),d=r(9510),h=r(11576),p=r(25732),f=r(29454),m=r(13299);function g(e){return"number"===typeof e.clientX?e.clientX:e.touches&&e.touches.length>0?e.touches[0].clientX:0}function y(e,t,r,n){var i=a.ensureSingle(e,"rect",m.bgClassName,(function(e){e.attr({x:0,y:0,"shape-rendering":"crispEdges"})})),o=n.borderwidth%2===0?n.borderwidth:n.borderwidth-1,u=-n._offsetShift,d=l.crispRound(t,n.borderwidth);i.attr({width:n._width+o,height:n._height+o,transform:s(u,u),"stroke-width":d}).call(c.stroke,n.bordercolor).call(c.fill,n.bgcolor)}function v(e,t,r,n){var i=t._fullLayout;a.ensureSingleById(i._topdefs,"clipPath",n._clipId,(function(e){e.append("rect").attr({x:0,y:0})})).select("rect").attr({width:n._width,height:n._height})}function x(e,t,r,i){var s,c=t.calcdata,u=e.selectAll("g."+m.rangePlotClassName).data(r._subplotsWith,a.identity);u.enter().append("g").attr("class",(function(e){return m.rangePlotClassName+" "+e})).call(l.setClipUrl,i._clipId,t),u.order(),u.exit().remove(),u.each((function(e,a){var l=n.select(this),u=0===a,p=h.getFromId(t,e,"y"),f=p._name,m=i[f],g={data:[],layout:{xaxis:{type:r.type,domain:[0,1],range:i.range.slice(),calendar:r.calendar},width:i._width,height:i._height,margin:{t:0,b:0,l:0,r:0}},_context:t._context};r.rangebreaks&&(g.layout.xaxis.rangebreaks=r.rangebreaks),g.layout[f]={type:p.type,domain:[0,1],range:"match"!==m.rangemode?m.range.slice():p.range.slice(),calendar:p.calendar},p.rangebreaks&&(g.layout[f].rangebreaks=p.rangebreaks),o.supplyDefaults(g);var y=g._fullLayout.xaxis,v=g._fullLayout[f];y.clearCalc(),y.setScale(),v.clearCalc(),v.setScale();var x={id:e,plotgroup:l,xaxis:y,yaxis:v,isRangePlot:!0};u?s=x:(x.mainplot="xy",x.mainplotinfo=s),d.rangePlot(t,x,function(e,t){for(var r=[],n=0;n=n.max)t=F[r+1];else if(e=n.pmax)t=F[r+1];else if(er._length||v+_<0)return;u=y+_,p=v+_;break;case l:if(b="col-resize",y+_>r._length)return;u=y+_,p=v;break;case c:if(b="col-resize",v+_<0)return;u=y,p=v+_;break;default:b="ew-resize",u=m,p=m+_}if(p{"use strict";var n=r(11576),i=r(13480),o=r(13299),a=r(83943).LINE_SPACING,s=o.name;function l(e){var t=e&&e[s];return t&&t.visible}t.isVisible=l,t.makeData=function(e){var t=n.list({_fullLayout:e},"x",!0),r=e.margin,i=[];if(!e._has("gl2d"))for(var o=0;o{"use strict";var n=r(84468),i=r(97681),o=r(75800),a=r(59459);e.exports={moduleType:"component",name:"rangeslider",schema:{subplots:{xaxis:{rangeslider:n.extendFlat({},i,{yaxis:o})}}},layoutAttributes:r(97681),handleDefaults:r(66166),calcAutorange:r(2122),draw:r(27002),isVisible:a.isVisible,makeData:a.makeData,autoMarginOpts:a.autoMarginOpts}},75800:e=>{"use strict";e.exports={_isSubplotObj:!0,rangemode:{valType:"enumerated",values:["auto","fixed","match"],dflt:"match",editType:"calc",description:["Determines whether or not the range of this axis in","the rangeslider use the same value than in the main plot","when zooming in/out.","If *auto*, the autorange will be used.","If *fixed*, the `range` is used.","If *match*, the current range of the corresponding y-axis on the main subplot is used."].join(" ")},range:{valType:"info_array",items:[{valType:"any",editType:"plot"},{valType:"any",editType:"plot"}],editType:"plot",description:["Sets the range of this axis for the rangeslider."].join(" ")},editType:"calc"}},37896:(e,t,r)=>{"use strict";var n=r(38467),i=r(22049).line,o=r(2703).T,a=r(64022).extendFlat,s=r(72587).overrideAll,l=r(37091).templatedArray,c=r(54654);e.exports=s(l("selection",{type:{valType:"enumerated",values:["rect","path"],description:["Specifies the selection type to be drawn.","If *rect*, a rectangle is drawn linking","(`x0`,`y0`), (`x1`,`y0`), (`x1`,`y1`) and (`x0`,`y1`).","If *path*, draw a custom SVG path using `path`."].join(" ")},xref:a({},n.xref,{description:["Sets the selection's x coordinate axis.",c.axisRefDescription("x","left","right")].join(" ")}),yref:a({},n.yref,{description:["Sets the selection's x coordinate axis.",c.axisRefDescription("y","bottom","top")].join(" ")}),x0:{valType:"any",description:"Sets the selection's starting x position."},x1:{valType:"any",description:"Sets the selection's end x position."},y0:{valType:"any",description:"Sets the selection's starting y position."},y1:{valType:"any",description:"Sets the selection's end y position."},path:{valType:"string",editType:"arraydraw",description:["For `type` *path* - a valid SVG path similar to `shapes.path` in data coordinates.","Allowed segments are: M, L and Z."].join(" ")},opacity:{valType:"number",min:0,max:1,dflt:.7,editType:"arraydraw",description:"Sets the opacity of the selection."},line:{color:i.color,width:a({},i.width,{min:1,dflt:1}),dash:a({},o,{dflt:"dot"})}}),"arraydraw","from-root")},93676:e=>{"use strict";e.exports={BENDPX:1.5,MINSELECT:12,SELECTDELAY:100,SELECTID:"-select"}},62527:(e,t,r)=>{"use strict";var n=r(84468),i=r(85729),o=r(38851),a=r(37896),s=r(12057);function l(e,t,r){function o(r,i){return n.coerce(e,t,a,r,i)}var l=o("path"),c="path"!==o("type",l?"path":"rect");c&&delete t.path,o("opacity"),o("line.color"),o("line.width"),o("line.dash");for(var u=["x","y"],d=0;d<2;d++){var h,p,f,m=u[d],g={_fullLayout:r},y=i.coerceRef(e,t,g,m);if((h=i.getFromId(g,y))._selectionIndices.push(t._index),f=s.rangeToShapePosition(h),p=s.shapePositionToRange(h),c){var v=m+"0",x=m+"1",b=e[v],_=e[x];e[v]=p(e[v],!0),e[x]=p(e[x],!0),i.coercePosition(t,g,o,y,v),i.coercePosition(t,g,o,y,x);var w=t[v],k=t[x];void 0!==w&&void 0!==k&&(t[v]=f(w),t[x]=f(k),e[v]=b,e[x]=_)}}c&&n.noneOrAll(e,t,["x0","x1","y0","y1"])}e.exports=function(e,t){o(e,t,{name:"selections",handleItemDefaults:l});for(var r=t.selections,n=0;n{"use strict";var n=r(36542).readPaths,i=r(77422),o=r(35473).clearOutlineControllers,a=r(7605),s=r(3172),l=r(37091).arrayEditor,c=r(12057),u=c.getPathString;function d(e){var t=e._fullLayout;for(var r in o(e),t._selectionLayer.selectAll("path").remove(),t._plots){var n=t._plots[r].selectionLayer;n&&n.selectAll("path").remove()}for(var i=0;i=0;S--){var A=r.append("path").attr(g).style("opacity",S?.1:y).call(a.stroke,x).call(a.fill,v).call(s.dashLine,S?"solid":_,S?4+b:b);if(f(A,e,o),w){var T=l(e.layout,"selections",o);A.style({cursor:"move"});var M={element:A.node(),plotinfo:p,gd:e,editHelpers:T,isActiveSelection:!0},C=n(c,e);i(C,A,M)}else A.style("pointer-events",S?"all":"none");k[S]=A}var E=k[0];k[1].node().addEventListener("click",(function(){return function(e,t){if(!h(e))return;var r=t.node(),n=+r.getAttribute("data-index");if(n>=0){if(n===e._fullLayout._activeSelectionIndex)return void m(e);e._fullLayout._activeSelectionIndex=n,e._fullLayout._deactivateSelection=m,d(e)}}(e,E)}))}(e._fullLayout._selectionLayer)}function f(e,t,r){var n=r.xref+r.yref;s.setClipUrl(e,"clip"+t._fullLayout._uid+n,t)}function m(e){h(e)&&(e._fullLayout._activeSelectionIndex>=0&&(o(e),delete e._fullLayout._activeSelectionIndex,d(e)))}e.exports={draw:d,drawOne:p,activateLastSelection:function(e){if(!h(e))return;var t=e._fullLayout.selections.length-1;e._fullLayout._activeSelectionIndex=t,e._fullLayout._deactivateSelection=m,d(e)}}},26724:(e,t,r)=>{"use strict";var n=r(2703).T,i=r(64022).extendFlat;e.exports={newselection:{mode:{valType:"enumerated",values:["immediate","gradual"],dflt:"immediate",editType:"none",description:["Describes how a new selection is created.","If `immediate`, a new selection is created after first mouse up.","If `gradual`, a new selection is not created after first mouse.","By adding to and subtracting from the initial selection,","this option allows declaring extra outlines of the selection."].join(" ")},line:{color:{valType:"color",editType:"none",description:["Sets the line color.","By default uses either dark grey or white","to increase contrast with background color."].join(" ")},width:{valType:"number",min:1,dflt:1,editType:"none",description:"Sets the line width (in px)."},dash:i({},n,{dflt:"dot",editType:"none"}),editType:"none"},editType:"none"},activeselection:{fillcolor:{valType:"color",dflt:"rgba(0,0,0,0)",editType:"none",description:"Sets the color filling the active selection' interior."},opacity:{valType:"number",min:0,max:1,dflt:.5,editType:"none",description:"Sets the opacity of the active selection."},editType:"none"}}},74163:e=>{"use strict";e.exports=function(e,t,r){r("newselection.mode"),r("newselection.line.width")&&(r("newselection.line.color"),r("newselection.line.dash")),r("activeselection.fillcolor"),r("activeselection.opacity")}},81904:(e,t,r)=>{"use strict";var n=r(2705).selectMode,i=r(35473).clearOutline,o=r(36542),a=o.readPaths,s=o.writePaths,l=o.fixDatesForPaths;e.exports=function(e,t){if(e.length){var r=e[0][0];if(r){var o=r.getAttribute("d"),c=t.gd,u=c._fullLayout.newselection,d=t.plotinfo,h=d.xaxis,p=d.yaxis,f=t.isActiveSelection,m=t.dragmode,g=(c.layout||{}).selections||[];if(!n(m)&&void 0!==f){var y=c._fullLayout._activeSelectionIndex;if(y{"use strict";var n=r(84468).strTranslate;function i(e,t){switch(e.type){case"log":return e.p2d(t);case"date":return e.p2r(t,0,e.calendar);default:return e.p2r(t)}}e.exports={p2r:i,r2p:function(e,t){switch(e.type){case"log":return e.d2p(t);case"date":return e.r2p(t,0,e.calendar);default:return e.r2p(t)}},axValue:function(e){var t="y"===e._id.charAt(0)?1:0;return function(r){return i(e,r[t])}},getTransform:function(e){return n(e.xaxis._offset,e.yaxis._offset)}}},76789:(e,t,r)=>{"use strict";var n=r(15463),i=r(82657);e.exports={moduleType:"component",name:"selections",layoutAttributes:r(37896),supplyLayoutDefaults:r(62527),supplyDrawNewSelectionDefaults:r(74163),includeBasePlot:r(84381)("selections"),draw:n.draw,drawOne:n.drawOne,reselect:i.reselect,prepSelect:i.prepSelect,clearOutline:i.clearOutline,clearSelectionsCache:i.clearSelectionsCache,selectOnClick:i.selectOnClick}},82657:(e,t,r)=>{"use strict";var n=r(72761),i=r(56734),o=r(38361),a=r(3172).dashStyle,s=r(7605),l=r(32212),c=r(82561).makeEventData,u=r(2705),d=u.freeMode,h=u.rectMode,p=u.drawMode,f=u.openMode,m=u.selectMode,g=r(12057),y=r(12833),v=r(77422),x=r(35473).clearOutline,b=r(36542),_=b.handleEllipse,w=b.readPaths,k=r(16275).newShapes,S=r(81904),A=r(15463).activateLastSelection,T=r(84468),M=T.sorterAsc,C=r(39926),E=r(95938),I=r(11576).getFromId,P=r(76574),O=r(88470).redrawReglTraces,R=r(93676),L=R.MINSELECT,D=C.filter,z=C.tester,j=r(77952),F=j.p2r,N=j.axValue,B=j.getTransform;function V(e){return void 0!==e.subplot}function U(e,t,r,n,i,o,a){var s,l,c,u,d,h,p,m,g,y=t._hoverdata,x=t._fullLayout.clickmode.indexOf("event")>-1,b=[];if(function(e){return e&&Array.isArray(e)&&!0!==e[0].hoverOnBox}(y)){q(e,t,o);var _=function(e,t){var r,n,i=e[0],o=-1,a=[];for(n=0;n0?function(e,t){var r,n,i,o=[];for(i=0;i0&&o.push(r);if(1===o.length&&o[0]===t.searchInfo&&(n=t.searchInfo.cd[0].trace).selectedpoints.length===t.pointNumbers.length){for(i=0;i1)return!1;if((n+=t.selectedpoints.length)>1)return!1}return 1===n}(s)&&(h=K(_))){for(a&&a.remove(),g=0;g=0})(i)&&i._fullLayout._deactivateShape(i),function(e){return e._fullLayout._activeSelectionIndex>=0}(i)&&i._fullLayout._deactivateSelection(i);var a=i._fullLayout._zoomlayer,s=p(r),l=m(r);if(s||l){var c,u,d=a.selectAll(".select-outline-"+n.id);if(d&&i._fullLayout._outlining)s&&(c=k(d,e)),c&&o.call("_guiRelayout",i,{shapes:c}),l&&!V(e)&&(u=S(d,e)),u&&(i._fullLayout._noEmitSelectedAtStart=!0,o.call("_guiRelayout",i,{selections:u}).then((function(){t&&A(i)}))),i._fullLayout._outlining=!1}n.selection={},n.selection.selectionDefs=e.selectionDefs=[],n.selection.mergedPolygons=e.mergedPolygons=[]}function Y(e){return e._id}function X(e,t,r,n){if(!e.calcdata)return[];var i,o,a,s=[],l=t.map(Y),c=r.map(Y);for(a=0;a0?n[0]:r;return!!t.selectedpoints&&t.selectedpoints.indexOf(i)>-1}function J(e,t,r){var n,i;for(n=0;n-1&&t;if(!o&&t){var te=ae(e,!0);if(te.length){var ne=te[0].xref,pe=te[0].yref;if(ne&&pe){var fe=ce(te);ue([I(e,ne,"x"),I(e,pe,"y")])(Q,fe)}}e._fullLayout._noEmitSelectedAtStart?e._fullLayout._noEmitSelectedAtStart=!1:ee&&de(e,Q),h._reselect=!1}if(!o&&h._deselect){var me=h._deselect;(function(e,t,r){for(var n=0;n=0)S._fullLayout._deactivateShape(S);else if(!x){var r=A.clickmode;E.done(Te).then((function(){if(E.clear(Te),2===e){for(be.remove(),K=0;K-1&&U(t,S,n.xaxes,n.yaxes,n.subplot,n,be),"event"===r&&de(S,void 0);l.click(S,t,P.id)})).catch(T.error)}},n.doneFn=function(){Se.remove(),E.done(Te).then((function(){E.clear(Te),!M&&Z&&n.selectionDefs&&(Z.subtract=xe,n.selectionDefs.push(Z),n.mergedPolygons.length=0,[].push.apply(n.mergedPolygons,Y)),(M||x)&&G(n,M),n.doneFnCompleted&&n.doneFnCompleted(Me),b&&de(S,oe)})).catch(T.error)}},clearOutline:x,clearSelectionsCache:G,selectOnClick:U}},26135:(e,t,r)=>{"use strict";var n=r(38467),i=r(91740),o=r(22049).line,a=r(2703).T,s=r(64022).extendFlat,l=r(37091).templatedArray,c=r(54654),u=r(75622),d=r(84425).LF,h=r(20236);e.exports=l("shape",{visible:s({},u.visible,{editType:"calc+arraydraw",description:["Determines whether or not this shape is visible.","If *legendonly*, the shape is not drawn,","but can appear as a legend item","(provided that the legend itself is visible)."].join(" ")}),showlegend:{valType:"boolean",dflt:!1,editType:"calc+arraydraw",description:["Determines whether or not this","shape is shown in the legend."].join(" ")},legend:s({},u.legend,{editType:"calc+arraydraw",description:["Sets the reference to a legend to show this shape in.","References to these legends are *legend*, *legend2*, *legend3*, etc.","Settings for these legends are set in the layout, under","`layout.legend`, `layout.legend2`, etc."].join(" ")}),legendgroup:s({},u.legendgroup,{editType:"calc+arraydraw",description:["Sets the legend group for this shape.","Traces and shapes part of the same legend group hide/show at the same time","when toggling legend items."].join(" ")}),legendgrouptitle:{text:s({},u.legendgrouptitle.text,{editType:"calc+arraydraw"}),font:i({editType:"calc+arraydraw",description:["Sets this legend group's title font."].join(" ")}),editType:"calc+arraydraw"},legendrank:s({},u.legendrank,{editType:"calc+arraydraw",description:["Sets the legend rank for this shape.","Items and groups with smaller ranks are presented on top/left side while","with *reversed* `legend.traceorder` they are on bottom/right side.","The default legendrank is 1000,","so that you can use ranks less than 1000 to place certain items before all unranked items,","and ranks greater than 1000 to go after all unranked items.","When having unranked or equal rank items shapes would be displayed after traces","i.e. according to their order in data and layout."].join(" ")}),legendwidth:s({},u.legendwidth,{editType:"calc+arraydraw",description:"Sets the width (in px or fraction) of the legend for this shape."}),type:{valType:"enumerated",values:["circle","rect","path","line"],editType:"calc+arraydraw",description:["Specifies the shape type to be drawn.","If *line*, a line is drawn from (`x0`,`y0`) to (`x1`,`y1`)","with respect to the axes' sizing mode.","If *circle*, a circle is drawn from","((`x0`+`x1`)/2, (`y0`+`y1`)/2))","with radius","(|(`x0`+`x1`)/2 - `x0`|, |(`y0`+`y1`)/2 -`y0`)|)","with respect to the axes' sizing mode.","If *rect*, a rectangle is drawn linking","(`x0`,`y0`), (`x1`,`y0`), (`x1`,`y1`), (`x0`,`y1`), (`x0`,`y0`)","with respect to the axes' sizing mode.","If *path*, draw a custom SVG path using `path`.","with respect to the axes' sizing mode."].join(" ")},layer:{valType:"enumerated",values:["below","above","between"],dflt:"above",editType:"arraydraw",description:["Specifies whether shapes are drawn below gridlines (*below*),","between gridlines and traces (*between*) or above traces (*above*)."].join(" ")},xref:s({},n.xref,{description:["Sets the shape's x coordinate axis.",c.axisRefDescription("x","left","right")].join(" ")}),xsizemode:{valType:"enumerated",values:["scaled","pixel"],dflt:"scaled",editType:"calc+arraydraw",description:["Sets the shapes's sizing mode along the x axis.","If set to *scaled*, `x0`, `x1` and x coordinates within `path` refer to","data values on the x axis or a fraction of the plot area's width","(`xref` set to *paper*).","If set to *pixel*, `xanchor` specifies the x position in terms","of data or plot fraction but `x0`, `x1` and x coordinates within `path`","are pixels relative to `xanchor`. This way, the shape can have","a fixed width while maintaining a position relative to data or","plot fraction."].join(" ")},xanchor:{valType:"any",editType:"calc+arraydraw",description:["Only relevant in conjunction with `xsizemode` set to *pixel*.","Specifies the anchor point on the x axis to which `x0`, `x1`","and x coordinates within `path` are relative to.","E.g. useful to attach a pixel sized shape to a certain data value.","No effect when `xsizemode` not set to *pixel*."].join(" ")},x0:{valType:"any",editType:"calc+arraydraw",description:["Sets the shape's starting x position.","See `type` and `xsizemode` for more info."].join(" ")},x1:{valType:"any",editType:"calc+arraydraw",description:["Sets the shape's end x position.","See `type` and `xsizemode` for more info."].join(" ")},x0shift:{valType:"number",dflt:0,min:-1,max:1,editType:"calc",description:["Shifts `x0` away from the center of the category when `xref` is a *category* or","*multicategory* axis. -0.5 corresponds to the start of the category and 0.5","corresponds to the end of the category."].join(" ")},x1shift:{valType:"number",dflt:0,min:-1,max:1,editType:"calc",description:["Shifts `x1` away from the center of the category when `xref` is a *category* or","*multicategory* axis. -0.5 corresponds to the start of the category and 0.5","corresponds to the end of the category."].join(" ")},yref:s({},n.yref,{description:["Sets the shape's y coordinate axis.",c.axisRefDescription("y","bottom","top")].join(" ")}),ysizemode:{valType:"enumerated",values:["scaled","pixel"],dflt:"scaled",editType:"calc+arraydraw",description:["Sets the shapes's sizing mode along the y axis.","If set to *scaled*, `y0`, `y1` and y coordinates within `path` refer to","data values on the y axis or a fraction of the plot area's height","(`yref` set to *paper*).","If set to *pixel*, `yanchor` specifies the y position in terms","of data or plot fraction but `y0`, `y1` and y coordinates within `path`","are pixels relative to `yanchor`. This way, the shape can have","a fixed height while maintaining a position relative to data or","plot fraction."].join(" ")},yanchor:{valType:"any",editType:"calc+arraydraw",description:["Only relevant in conjunction with `ysizemode` set to *pixel*.","Specifies the anchor point on the y axis to which `y0`, `y1`","and y coordinates within `path` are relative to.","E.g. useful to attach a pixel sized shape to a certain data value.","No effect when `ysizemode` not set to *pixel*."].join(" ")},y0:{valType:"any",editType:"calc+arraydraw",description:["Sets the shape's starting y position.","See `type` and `ysizemode` for more info."].join(" ")},y1:{valType:"any",editType:"calc+arraydraw",description:["Sets the shape's end y position.","See `type` and `ysizemode` for more info."].join(" ")},y0shift:{valType:"number",dflt:0,min:-1,max:1,editType:"calc",description:["Shifts `y0` away from the center of the category when `yref` is a *category* or","*multicategory* axis. -0.5 corresponds to the start of the category and 0.5","corresponds to the end of the category."].join(" ")},y1shift:{valType:"number",dflt:0,min:-1,max:1,editType:"calc",description:["Shifts `y1` away from the center of the category when `yref` is a *category* or","*multicategory* axis. -0.5 corresponds to the start of the category and 0.5","corresponds to the end of the category."].join(" ")},path:{valType:"string",editType:"calc+arraydraw",description:["For `type` *path* - a valid SVG path with the pixel values","replaced by data values in `xsizemode`/`ysizemode` being *scaled*","and taken unmodified as pixels relative to `xanchor` and `yanchor`","in case of *pixel* size mode.","There are a few restrictions / quirks","only absolute instructions, not relative. So the allowed segments","are: M, L, H, V, Q, C, T, S, and Z","arcs (A) are not allowed because radius rx and ry are relative.","In the future we could consider supporting relative commands,","but we would have to decide on how to handle date and log axes.","Note that even as is, Q and C Bezier paths that are smooth on","linear axes may not be smooth on log, and vice versa.",'no chained "polybezier" commands - specify the segment type for',"each one.","On category axes, values are numbers scaled to the serial numbers","of categories because using the categories themselves there would","be no way to describe fractional positions","On data axes: because space and T are both normal components of path","strings, we can't use either to separate date from time parts.","Therefore we'll use underscore for this purpose:","2015-02-21_13:45:56.789"].join(" ")},opacity:{valType:"number",min:0,max:1,dflt:1,editType:"arraydraw",description:"Sets the opacity of the shape."},line:{color:s({},o.color,{editType:"arraydraw"}),width:s({},o.width,{editType:"calc+arraydraw"}),dash:s({},a,{editType:"arraydraw"}),editType:"calc+arraydraw"},fillcolor:{valType:"color",dflt:"rgba(0,0,0,0)",editType:"arraydraw",description:["Sets the color filling the shape's interior. Only applies to closed shapes."].join(" ")},fillrule:{valType:"enumerated",values:["evenodd","nonzero"],dflt:"evenodd",editType:"arraydraw",description:["Determines which regions of complex paths constitute the interior.","For more info please visit https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/fill-rule"].join(" ")},editable:{valType:"boolean",dflt:!1,editType:"calc+arraydraw",description:["Determines whether the shape could be activated for edit or not.","Has no effect when the older editable shapes mode is enabled via","`config.editable` or `config.edits.shapePosition`."].join(" ")},label:{text:{valType:"string",dflt:"",editType:"arraydraw",description:["Sets the text to display with shape.","It is also used for legend item if `name` is not provided."].join(" ")},texttemplate:d({},{keys:Object.keys(h)}),font:i({editType:"calc+arraydraw",colorEditType:"arraydraw",description:"Sets the shape label text font."}),textposition:{valType:"enumerated",values:["top left","top center","top right","middle left","middle center","middle right","bottom left","bottom center","bottom right","start","middle","end"],editType:"arraydraw",description:["Sets the position of the label text relative to the shape.","Supported values for rectangles, circles and paths are","*top left*, *top center*, *top right*, *middle left*,","*middle center*, *middle right*, *bottom left*, *bottom center*,","and *bottom right*.","Supported values for lines are *start*, *middle*, and *end*.","Default: *middle center* for rectangles, circles, and paths; *middle* for lines."].join(" ")},textangle:{valType:"angle",dflt:"auto",editType:"calc+arraydraw",description:["Sets the angle at which the label text is drawn","with respect to the horizontal. For lines, angle *auto*","is the same angle as the line. For all other shapes,","angle *auto* is horizontal."].join(" ")},xanchor:{valType:"enumerated",values:["auto","left","center","right"],dflt:"auto",editType:"calc+arraydraw",description:["Sets the label's horizontal position anchor","This anchor binds the specified `textposition` to the *left*, *center*","or *right* of the label text.","For example, if `textposition` is set to *top right* and","`xanchor` to *right* then the right-most portion of the","label text lines up with the right-most edge of the","shape."].join(" ")},yanchor:{valType:"enumerated",values:["top","middle","bottom"],editType:"calc+arraydraw",description:["Sets the label's vertical position anchor","This anchor binds the specified `textposition` to the *top*, *middle*","or *bottom* of the label text.","For example, if `textposition` is set to *top right* and","`yanchor` to *top* then the top-most portion of the","label text lines up with the top-most edge of the","shape."].join(" ")},padding:{valType:"number",dflt:3,min:0,editType:"arraydraw",description:"Sets padding (in px) between edge of label and edge of shape."},editType:"arraydraw"},editType:"arraydraw"})},69984:(e,t,r)=>{"use strict";var n=r(84468),i=r(85729),o=r(12833),a=r(12057);function s(e){return c(e.line.width,e.xsizemode,e.x0,e.x1,e.path,!1)}function l(e){return c(e.line.width,e.ysizemode,e.y0,e.y1,e.path,!0)}function c(e,t,r,i,s,l){var c=e/2,u=l;if("pixel"===t){var d=s?a.extractPathCoords(s,l?o.paramIsY:o.paramIsX):[r,i],h=n.aggNums(Math.max,null,d),p=n.aggNums(Math.min,null,d),f=p<0?Math.abs(p)+c:c,m=h>0?h+c:c;return{ppad:c,ppadplus:u?f:m,ppadminus:u?m:f}}return{ppad:c}}function u(e,t,r){var n,i,s="x"===e._id.charAt(0)?"x":"y",l="category"===e.type||"multicategory"===e.type,c=0,u=0,d=l?e.r2c:e.d2c;if("scaled"===t[s+"sizemode"]?(n=t[s+"0"],i=t[s+"1"],l&&(c=t[s+"0shift"],u=t[s+"1shift"])):(n=t[s+"anchor"],i=t[s+"anchor"]),void 0!==n)return[d(n)+c,d(i)+u];if(t.path){var h,p,f,m,g=1/0,y=-1/0,v=t.path.match(o.segmentRE);for("date"===e.type&&(d=a.decodeDate(d)),h=0;hy&&(y=m)));return y>=g?[g,y]:void 0}}e.exports=function(e){var t=e._fullLayout,r=n.filterVisible(t.shapes);if(r.length&&e._fullData.length)for(var a=0;a{"use strict";e.exports={segmentRE:/[MLHVQCTSZ][^MLHVQCTSZ]*/g,paramRE:/[^\s,]+/g,paramIsX:{M:{0:!0,drawn:0},L:{0:!0,drawn:0},H:{0:!0,drawn:0},V:{},Q:{0:!0,2:!0,drawn:2},C:{0:!0,2:!0,4:!0,drawn:4},T:{0:!0,drawn:0},S:{0:!0,2:!0,drawn:2},Z:{}},paramIsY:{M:{1:!0,drawn:1},L:{1:!0,drawn:1},H:{},V:{0:!0,drawn:0},Q:{1:!0,3:!0,drawn:3},C:{1:!0,3:!0,5:!0,drawn:5},T:{1:!0,drawn:1},S:{1:!0,3:!0,drawn:5},Z:{}},numParams:{M:2,L:2,H:1,V:1,Q:4,C:6,T:2,S:4,Z:0}}},88048:(e,t,r)=>{"use strict";var n=r(84468),i=r(85729),o=r(38851),a=r(26135),s=r(12057);function l(e,t,r){function o(r,i){return n.coerce(e,t,a,r,i)}if(t._isShape=!0,o("visible")){o("showlegend")&&(o("legend"),o("legendwidth"),o("legendgroup"),o("legendgrouptitle.text"),n.coerceFont(o,"legendgrouptitle.font"),o("legendrank"));var l=o("path"),c=o("type",l?"path":"rect"),u="path"!==c;u&&delete t.path,o("editable"),o("layer"),o("opacity"),o("fillcolor"),o("fillrule"),o("line.width")&&(o("line.color"),o("line.dash"));for(var d=o("xsizemode"),h=o("ysizemode"),p=["x","y"],f=0;f<2;f++){var m,g,y,v=p[f],x=v+"anchor",b="x"===v?d:h,_={_fullLayout:r},w=i.coerceRef(e,t,_,v,void 0,"paper");if("range"===i.getRefType(w)?((m=i.getFromId(_,w))._shapeIndices.push(t._index),y=s.rangeToShapePosition(m),g=s.shapePositionToRange(m),"category"!==m.type&&"multicategory"!==m.type||(o(v+"0shift"),o(v+"1shift"))):g=y=n.identity,u){var k=v+"0",S=v+"1",A=e[k],T=e[S];e[k]=g(e[k],!0),e[S]=g(e[S],!0),"pixel"===b?(o(k,0),o(S,10)):(i.coercePosition(t,_,o,w,k,.25),i.coercePosition(t,_,o,w,S,.75)),t[k]=y(t[k]),t[S]=y(t[S]),e[k]=A,e[S]=T}if("pixel"===b){var M=e[x];e[x]=g(e[x],!0),i.coercePosition(t,_,o,w,x,.25),t[x]=y(t[x]),e[x]=M}}u&&n.noneOrAll(e,t,["x0","x1","y0","y1"]);var C,E,I="line"===c;if(u&&(C=o("label.texttemplate")),C||(E=o("label.text")),E||C){o("label.textangle");var P=o("label.textposition",I?"middle":"middle center");o("label.xanchor"),o("label.yanchor",function(e,t){return e?"bottom":-1!==t.indexOf("top")?"top":-1!==t.indexOf("bottom")?"bottom":"middle"}(I,P)),o("label.padding"),n.coerceFont(o,"label.font",r.font)}}}e.exports=function(e,t){o(e,t,{name:"shapes",handleItemDefaults:l})}},51778:(e,t,r)=>{"use strict";var n=r(84468),i=r(85729),o=r(13480),a=r(3172),s=r(36542).readPaths,l=r(12057),c=l.getPathString,u=r(20236),d=r(83943).FROM_TL;e.exports=function(e,t,r,h){if(h.selectAll(".shape-label").remove(),r.label.text||r.label.texttemplate){var p;if(r.label.texttemplate){var f={};if("path"!==r.type){var m=i.getFromId(e,r.xref),g=i.getFromId(e,r.yref);for(var y in u){var v=u[y](r,m,g);void 0!==v&&(f[y]=v)}}p=n.texttemplateStringForShapes(r.label.texttemplate,{},e._fullLayout._d3locale,f)}else p=r.label.text;var x,b,_,w,k={"data-index":t},S=r.label.font,A=h.append("g").attr(k).classed("shape-label",!0).append("text").attr({"data-notex":1}).classed("shape-label-text",!0).text(p);if(r.path){var T=c(e,r),M=s(T,e);x=1/0,_=1/0,b=-1/0,w=-1/0;for(var C=0;C=e?t-n:n-t;return-180/Math.PI*Math.atan2(i,o)}(x,_,b,w):0),A.call((function(t){return t.call(a.font,S).attr({}),o.convertToTspans(t,e),t}));var W=function(e,t,r,n,i,o,a){var s,l,c,u,h=i.label.textposition,p=i.label.textangle,f=i.label.padding,m=i.type,g=Math.PI/180*o,y=Math.sin(g),v=Math.cos(g),x=i.label.xanchor,b=i.label.yanchor;if("line"===m){"start"===h?(s=e,l=t):"end"===h?(s=r,l=n):(s=(e+r)/2,l=(t+n)/2),"auto"===x&&(x="start"===h?"auto"===p?r>e?"left":re?"right":re?"right":re?"left":r{"use strict";var n=r(84468).strTranslate,i=r(25732),o=r(2705),a=o.drawMode,s=o.selectMode,l=r(38361),c=r(7605),u=r(90706),d=u.i000,h=u.i090,p=u.i180,f=u.i270,m=r(35473).clearOutlineControllers,g=r(36542),y=g.pointsOnRectangle,v=g.pointsOnEllipse,x=g.writePaths,b=r(16275).newShapes,_=r(16275).createShapeObj,w=r(81904),k=r(51778);function S(e,t){var r,n,i,o=e[t][1],a=e[t][2],s=e.length;return n=e[r=(t+1)%s][1],i=e[r][2],n===o&&i===a&&(n=e[r=(t+2)%s][1],i=e[r][2]),[r,n,i]}e.exports=function e(t,r,o,u){u||(u=0);var g=o.gd;function A(){e(t,r,o,u++),(v(t[0])||o.hasText)&&T({redrawing:!0})}function T(e){var t={};void 0!==o.isActiveShape&&(o.isActiveShape=!1,t=b(r,o)),void 0!==o.isActiveSelection&&(o.isActiveSelection=!1,t=w(r,o),g._fullLayout._reselect=!0),Object.keys(t).length&&l.call((e||{}).redrawing?"relayout":"_guiRelayout",g,t)}var M,C,E,I,P,O=g._fullLayout._zoomlayer,R=o.dragmode,L=a(R),D=s(R);((L||D)&&(g._fullLayout._outlining=!0),m(g),r.attr("d",x(t)),u||!o.isActiveShape&&!o.isActiveSelection)||(P=function(e,t){for(var r=0;r1&&(2!==e.length||"Z"!==e[1][0])&&(0===I&&(e[0][0]="M"),t[E]=e,A(),T())}}()}}function U(e,r){!function(e,r){if(t.length)for(var n=0;n{"use strict";var n=r(41871),i=r(38361),o=r(84468),a=r(85729),s=r(36542).readPaths,l=r(77422),c=r(51778),u=r(35473).clearOutlineControllers,d=r(7605),h=r(3172),p=r(37091).arrayEditor,f=r(25732),m=r(29454),g=r(12833),y=r(12057),v=y.getPathString;function x(e){var t=e._fullLayout;for(var r in t._shapeUpperLayer.selectAll("path").remove(),t._shapeLowerLayer.selectAll("path").remove(),t._shapeUpperLayer.selectAll("text").remove(),t._shapeLowerLayer.selectAll("text").remove(),t._plots){var n=t._plots[r].shapelayer;n&&(n.selectAll("path").remove(),n.selectAll("text").remove())}for(var i=0;iz&&o>j&&!r.shiftKey?f.getCursor(a/i,1-s/o):"move";m(t,l),D=l.split("-")[0]}}function se(n){b(e)||(F&&(w=J(r.xanchor)),N&&(A=Q(r.yanchor)),"path"===r.type?L=r.path:(d=F?r.x0:J(r.x0),p=N?r.y0:Q(r.y0),x=F?r.x1:J(r.x1),_=N?r.y1:Q(r.y1)),d_?(T=p,I="y0",M=_,P="y1"):(T=_,I="y1",M=p,P="y0"),ae(n),he(l,r),fe(t,r,e),ne.moveFn="move"===D?ue:de,ne.altKey=n.altKey)}function le(){b(e)||(m(t),pe(l),k(t,e,r),i.call("_guiRelayout",e,u.getUpdateObj()))}function ce(){b(e)||pe(l)}function ue(n,i){if("path"===r.type){var o=function(e){return e},a=o,u=o;F?U("xanchor",r.xanchor=ee(w+n)):(a=function(e){return ee(J(e)+n)},$&&"date"===$.type&&(a=y.encodeDate(a))),N?U("yanchor",r.yanchor=te(A+i)):(u=function(e){return te(Q(e)+i)},q&&"date"===q.type&&(u=y.encodeDate(u))),U("path",r.path=S(L,a,u))}else F?U("xanchor",r.xanchor=ee(w+n)):(U("x0",r.x0=ee(d+n)),U("x1",r.x1=ee(x+n))),N?U("yanchor",r.yanchor=te(A+i)):(U("y0",r.y0=te(p+i)),U("y1",r.y1=te(_+i)));t.attr("d",v(e,r)),he(l,r),c(e,s,r,H)}function de(n,i){if(V){var o=function(e){return e},a=o,u=o;F?U("xanchor",r.xanchor=ee(w+n)):(a=function(e){return ee(J(e)+n)},$&&"date"===$.type&&(a=y.encodeDate(a))),N?U("yanchor",r.yanchor=te(A+i)):(u=function(e){return te(Q(e)+i)},q&&"date"===q.type&&(u=y.encodeDate(u))),U("path",r.path=S(L,a,u))}else if(B){if("resize-over-start-point"===D){var h=d+n,f=N?p-i:p+i;U("x0",r.x0=F?h:ee(h)),U("y0",r.y0=N?f:te(f))}else if("resize-over-end-point"===D){var m=x+n,g=N?_-i:_+i;U("x1",r.x1=F?m:ee(m)),U("y1",r.y1=N?g:te(g))}}else{var b=function(e){return-1!==D.indexOf(e)},k=b("n"),W=b("s"),G=b("w"),Y=b("e"),X=k?T+i:T,Z=W?M+i:M,K=G?C+n:C,re=Y?E+n:E;N&&(k&&(X=T-i),W&&(Z=M-i)),(!N&&Z-X>j||N&&X-Z>j)&&(U(I,r[I]=N?X:te(X)),U(P,r[P]=N?Z:te(Z))),re-K>z&&(U(O,r[O]=F?K:ee(K)),U(R,r[R]=F?re:ee(re)))}t.attr("d",v(e,r)),he(l,r),c(e,s,r,H)}function he(e,t){function r(){var r="path"!==t.type,n=e.selectAll(".visual-cue").data([0]),i=1;n.enter().append("path").attr({fill:"#fff","fill-rule":"evenodd",stroke:"#000","stroke-width":i}).classed("visual-cue",!0);var a=J(F?t.xanchor:o.midRange(r?[t.x0,t.x1]:y.extractPathCoords(t.path,g.paramIsX))),s=Q(N?t.yanchor:o.midRange(r?[t.y0,t.y1]:y.extractPathCoords(t.path,g.paramIsY)));if(a=y.roundPositionForSharpStrokeRendering(a,i),s=y.roundPositionForSharpStrokeRendering(s,i),F&&N){var l="M"+(a-1-i)+","+(s-1-i)+"h-8v2h8 v8h2v-8 h8v-2h-8 v-8h-2 Z";n.attr("d",l)}else if(F){var c="M"+(a-1-i)+","+(s-9-i)+"v18 h2 v-18 Z";n.attr("d",c)}else{var u="M"+(a-9-i)+","+(s-1-i)+"h18 v2 h-18 Z";n.attr("d",u)}}(F||N)&&r()}function pe(e){e.selectAll(".visual-cue").remove()}function fe(e,t,r){var n=t.xref,i=t.yref,o=a.getFromId(r,n),s=a.getFromId(r,i),l="";"paper"===n||o.autorange||(l+=n),"paper"===i||s.autorange||(l+=i),h.setClipUrl(e,l?"clip"+r._fullLayout._uid+l:null,r)}f.init(ne),re.node().onmousemove=ae}(e,j,u,t,r,D):!0===u.editable&&j.style("pointer-events",R||d.opacity(E)*C<=.5?"stroke":"all");j.node().addEventListener("click",(function(){return function(e,t){if(!_(e))return;var r=t.node(),n=+r.getAttribute("data-index");if(n>=0){if(n===e._fullLayout._activeShapeIndex)return void A(e);e._fullLayout._activeShapeIndex=n,e._fullLayout._deactivateShape=A,x(e)}}(e,j)}))}}function k(e,t,r){var n=(r.xref+r.yref).replace(/paper/g,"").replace(/[xyz][1-9]* *domain/g,"");h.setClipUrl(e,n?"clip"+t._fullLayout._uid+n:null,t)}function S(e,t,r){return e.replace(g.segmentRE,(function(e){var n=0,i=e.charAt(0),o=g.paramIsX[i],a=g.paramIsY[i],s=g.numParams[i];return i+e.substr(1).replace(g.paramRE,(function(e){return n>=s||(o[n]?e=t(e):a[n]&&(e=r(e)),n++),e}))}))}function A(e){_(e)&&(e._fullLayout._activeShapeIndex>=0&&(u(e),delete e._fullLayout._activeShapeIndex,x(e)))}e.exports={draw:x,drawOne:w,eraseActiveShape:function(e){if(!_(e))return;u(e);var t=e._fullLayout._activeShapeIndex,r=(e.layout||{}).shapes||[];if(t{"use strict";var n=r(72587).overrideAll,i=r(75622),o=r(91740),a=r(2703).T,s=r(64022).extendFlat,l=r(84425).LF,c=r(20236);e.exports=n({newshape:{visible:s({},i.visible,{description:["Determines whether or not new shape is visible.","If *legendonly*, the shape is not drawn,","but can appear as a legend item","(provided that the legend itself is visible)."].join(" ")}),showlegend:{valType:"boolean",dflt:!1,description:["Determines whether or not new","shape is shown in the legend."].join(" ")},legend:s({},i.legend,{description:["Sets the reference to a legend to show new shape in.","References to these legends are *legend*, *legend2*, *legend3*, etc.","Settings for these legends are set in the layout, under","`layout.legend`, `layout.legend2`, etc."].join(" ")}),legendgroup:s({},i.legendgroup,{description:["Sets the legend group for new shape.","Traces and shapes part of the same legend group hide/show at the same time","when toggling legend items."].join(" ")}),legendgrouptitle:{text:s({},i.legendgrouptitle.text,{}),font:o({description:["Sets this legend group's title font."].join(" ")})},legendrank:s({},i.legendrank,{description:["Sets the legend rank for new shape.","Items and groups with smaller ranks are presented on top/left side while","with *reversed* `legend.traceorder` they are on bottom/right side.","The default legendrank is 1000,","so that you can use ranks less than 1000 to place certain items before all unranked items,","and ranks greater than 1000 to go after all unranked items."].join(" ")}),legendwidth:s({},i.legendwidth,{description:"Sets the width (in px or fraction) of the legend for new shape."}),line:{color:{valType:"color",description:["Sets the line color.","By default uses either dark grey or white","to increase contrast with background color."].join(" ")},width:{valType:"number",min:0,dflt:4,description:"Sets the line width (in px)."},dash:s({},a,{dflt:"solid"})},fillcolor:{valType:"color",dflt:"rgba(0,0,0,0)",description:["Sets the color filling new shapes' interior.","Please note that if using a fillcolor with alpha greater than half,","drag inside the active shape starts moving the shape underneath,","otherwise a new shape could be started over."].join(" ")},fillrule:{valType:"enumerated",values:["evenodd","nonzero"],dflt:"evenodd",description:["Determines the path's interior.","For more info please visit https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/fill-rule"].join(" ")},opacity:{valType:"number",min:0,max:1,dflt:1,description:"Sets the opacity of new shapes."},layer:{valType:"enumerated",values:["below","above","between"],dflt:"above",description:["Specifies whether new shapes are drawn below gridlines (*below*),","between gridlines and traces (*between*) or above traces (*above*)."].join(" ")},drawdirection:{valType:"enumerated",values:["ortho","horizontal","vertical","diagonal"],dflt:"diagonal",description:["When `dragmode` is set to *drawrect*, *drawline* or *drawcircle*","this limits the drag to be horizontal, vertical or diagonal.","Using *diagonal* there is no limit e.g. in drawing lines in any direction.","*ortho* limits the draw to be either horizontal or vertical.","*horizontal* allows horizontal extend.","*vertical* allows vertical extend."].join(" ")},name:s({},i.name,{description:["Sets new shape name.","The name appears as the legend item."].join(" ")}),label:{text:{valType:"string",dflt:"",description:["Sets the text to display with the new shape.","It is also used for legend item if `name` is not provided."].join(" ")},texttemplate:l({newshape:!0},{keys:Object.keys(c)}),font:o({description:"Sets the new shape label text font."}),textposition:{valType:"enumerated",values:["top left","top center","top right","middle left","middle center","middle right","bottom left","bottom center","bottom right","start","middle","end"],description:["Sets the position of the label text relative to the new shape.","Supported values for rectangles, circles and paths are","*top left*, *top center*, *top right*, *middle left*,","*middle center*, *middle right*, *bottom left*, *bottom center*,","and *bottom right*.","Supported values for lines are *start*, *middle*, and *end*.","Default: *middle center* for rectangles, circles, and paths; *middle* for lines."].join(" ")},textangle:{valType:"angle",dflt:"auto",description:["Sets the angle at which the label text is drawn","with respect to the horizontal. For lines, angle *auto*","is the same angle as the line. For all other shapes,","angle *auto* is horizontal."].join(" ")},xanchor:{valType:"enumerated",values:["auto","left","center","right"],dflt:"auto",description:["Sets the label's horizontal position anchor","This anchor binds the specified `textposition` to the *left*, *center*","or *right* of the label text.","For example, if `textposition` is set to *top right* and","`xanchor` to *right* then the right-most portion of the","label text lines up with the right-most edge of the","new shape."].join(" ")},yanchor:{valType:"enumerated",values:["top","middle","bottom"],description:["Sets the label's vertical position anchor","This anchor binds the specified `textposition` to the *top*, *middle*","or *bottom* of the label text.","For example, if `textposition` is set to *top right* and","`yanchor` to *top* then the top-most portion of the","label text lines up with the top-most edge of the","new shape."].join(" ")},padding:{valType:"number",dflt:3,min:0,description:"Sets padding (in px) between edge of label and edge of new shape."}}},activeshape:{fillcolor:{valType:"color",dflt:"rgb(255,0,255)",description:"Sets the color filling the active shape' interior."},opacity:{valType:"number",min:0,max:1,dflt:.5,description:"Sets the opacity of the active shape."}}},"none","from-root")},90706:e=>{"use strict";e.exports={CIRCLE_SIDES:32,i000:0,i090:8,i180:16,i270:24,cos45:Math.cos(Math.PI/4),sin45:Math.sin(Math.PI/4),SQRT2:Math.sqrt(2)}},54617:(e,t,r)=>{"use strict";var n=r(7605),i=r(84468);e.exports=function(e,t,r){if(r("newshape.visible"),r("newshape.name"),r("newshape.showlegend"),r("newshape.legend"),r("newshape.legendwidth"),r("newshape.legendgroup"),r("newshape.legendgrouptitle.text"),i.coerceFont(r,"newshape.legendgrouptitle.font"),r("newshape.legendrank"),r("newshape.drawdirection"),r("newshape.layer"),r("newshape.fillcolor"),r("newshape.fillrule"),r("newshape.opacity"),r("newshape.line.width")){var o=(e||{}).plot_bgcolor||"#FFF";r("newshape.line.color",n.contrast(o)),r("newshape.line.dash")}var a="drawline"===e.dragmode,s=r("newshape.label.text"),l=r("newshape.label.texttemplate");if(s||l){r("newshape.label.textangle");var c=r("newshape.label.textposition",a?"middle":"middle center");r("newshape.label.xanchor"),r("newshape.label.yanchor",function(e,t){return e?"bottom":-1!==t.indexOf("top")?"top":-1!==t.indexOf("bottom")?"bottom":"middle"}(a,c)),r("newshape.label.padding"),i.coerceFont(r,"newshape.label.font",t.font)}r("activeshape.fillcolor"),r("activeshape.opacity")}},36542:(e,t,r)=>{"use strict";var n=r(24100),i=r(90706),o=i.CIRCLE_SIDES,a=i.SQRT2,s=r(77952),l=s.p2r,c=s.r2p,u=[0,3,4,5,6,1,2],d=[0,3,4,1,2];function h(e,t){return Math.abs(e-t)<=1e-6}function p(e,t){var r=t[1]-e[1],n=t[2]-e[2];return Math.sqrt(r*r+n*n)}t.writePaths=function(e){var t=e.length;if(!t)return"M0,0Z";for(var r="",n=0;n0&&l{"use strict";var n=r(2705),i=n.drawMode,o=n.openMode,a=r(90706),s=a.i000,l=a.i090,c=a.i180,u=a.i270,d=a.cos45,h=a.sin45,p=r(77952),f=p.p2r,m=p.r2p,g=r(35473).clearOutline,y=r(36542),v=y.readPaths,x=y.writePaths,b=y.ellipseOver,_=y.fixDatesForPaths;function w(e,t,r){var n,i=e[0][0],a=t.gd,p=i.getAttribute("d"),g=a._fullLayout.newshape,y=t.plotinfo,w=t.isActiveShape,k=y.xaxis,S=y.yaxis,A=!!y.domain||!y.xaxis,T=!!y.domain||!y.yaxis,M=o(r),C=v(p,a,y,w),E={editable:!0,visible:g.visible,name:g.name,showlegend:g.showlegend,legend:g.legend,legendwidth:g.legendwidth,legendgroup:g.legendgroup,legendgrouptitle:{text:g.legendgrouptitle.text,font:g.legendgrouptitle.font},legendrank:g.legendrank,label:g.label,xref:A?"paper":k._id,yref:T?"paper":S._id,layer:g.layer,opacity:g.opacity,line:{color:g.line.color,width:g.line.width,dash:g.line.dash}};if(M||(E.fillcolor=g.fillcolor,E.fillrule=g.fillrule),1===C.length&&(n=C[0]),n&&5===n.length&&"drawrect"===r)E.type="rect",E.x0=n[0][1],E.y0=n[0][2],E.x1=n[2][1],E.y1=n[2][2];else if(n&&"drawline"===r)E.type="line",E.x0=n[0][1],E.y0=n[0][2],E.x1=n[1][1],E.y1=n[1][2];else if(n&&"drawcircle"===r){E.type="circle";var I=n[s][1],P=n[l][1],O=n[c][1],R=n[u][1],L=n[s][2],D=n[l][2],z=n[c][2],j=n[u][2],F=y.xaxis&&("date"===y.xaxis.type||"log"===y.xaxis.type),N=y.yaxis&&("date"===y.yaxis.type||"log"===y.yaxis.type);F&&(I=m(y.xaxis,I),P=m(y.xaxis,P),O=m(y.xaxis,O),R=m(y.xaxis,R)),N&&(L=m(y.yaxis,L),D=m(y.yaxis,D),z=m(y.yaxis,z),j=m(y.yaxis,j));var B=(P+R)/2,V=(L+z)/2,U=b({x0:B,y0:V,x1:B+(R-P+O-I)/2*d,y1:V+(j-D+z-L)/2*h});F&&(U.x0=f(y.xaxis,U.x0),U.x1=f(y.xaxis,U.x1)),N&&(U.y0=f(y.yaxis,U.y0),U.y1=f(y.yaxis,U.y1)),E.x0=U.x0,E.y0=U.y0,E.x1=U.x1,E.y1=U.y1}else E.type="path",k&&S&&_(C,k,S),E.path=x(C),n=null;return E}e.exports={newShapes:function(e,t){if(e.length&&e[0][0]){var r=t.gd,n=t.isActiveShape,o=t.dragmode,a=(r.layout||{}).shapes||[];if(!i(o)&&void 0!==n){var s=r._fullLayout._activeShapeIndex;if(s{"use strict";e.exports={clearOutlineControllers:function(e){var t=e._fullLayout._zoomlayer;t&&t.selectAll(".outline-controllers").remove()},clearOutline:function(e){var t=e._fullLayout._zoomlayer;t&&t.selectAll(".select-outline").remove(),e._fullLayout._outlining=!1}}},12057:(e,t,r)=>{"use strict";var n=r(12833),i=r(84468),o=r(85729);function a(e,t){var r=0;return(t=t||0)&&e&&("category"===e.type||"multicategory"===e.type)&&(r=(e.r2p(1)-e.r2p(0))*t),r}t.rangeToShapePosition=function(e){return"log"===e.type?e.r2d:function(e){return e}},t.shapePositionToRange=function(e){return"log"===e.type?e.d2r:function(e){return e}},t.decodeDate=function(e){return function(t){return t.replace&&(t=t.replace("_"," ")),e(t)}},t.encodeDate=function(e){return function(t){return e(t).replace(" ","_")}},t.extractPathCoords=function(e,t,r){var o=[];return e.match(n.segmentRE).forEach((function(e){var a=t[e.charAt(0)].drawn;if(void 0!==a){var s=e.substr(1).match(n.paramRE);if(s&&!(s.lengthp&&(e="X"),e}));return o>p&&(f=f.replace(/[\s,]*X.*/,""),i.log("Ignoring extra params in segment "+e)),u+f}))}(r,l,u);if("pixel"===r.xsizemode){var A=l(r.xanchor);d=A+r.x0+_,h=A+r.x1+w}else d=l(r.x0)+_,h=l(r.x1)+w;if("pixel"===r.ysizemode){var T=u(r.yanchor);p=T-r.y0+k,f=T-r.y1+S}else p=u(r.y0)+k,f=u(r.y1)+S;if("line"===m)return"M"+d+","+p+"L"+h+","+f;if("rect"===m)return"M"+d+","+p+"H"+h+"V"+f+"H"+d+"Z";var M=(d+h)/2,C=(p+f)/2,E=Math.abs(M-d),I=Math.abs(C-p),P="A"+E+","+I,O=M+E+","+C;return"M"+O+P+" 0 1,1 "+(M+","+(C-I))+P+" 0 0,1 "+O+"Z"}},22172:(e,t,r)=>{"use strict";var n=r(98820);e.exports={moduleType:"component",name:"shapes",layoutAttributes:r(26135),supplyLayoutDefaults:r(88048),supplyDrawNewShapeDefaults:r(54617),includeBasePlot:r(84381)("shapes"),calcAutorange:r(69984),draw:n.draw,drawOne:n.drawOne}},20236:e=>{"use strict";function t(e,t){return t?t.d2l(e):e}function r(e,t){return t?t.l2d(e):e}function n(e){return e.x0shift||0}function i(e){return e.x1shift||0}function o(e){return e.y0shift||0}function a(e){return e.y1shift||0}function s(e,r){return t(e.x1,r)+i(e)-t(e.x0,r)-n(e)}function l(e,r,n){return t(e.y1,n)+a(e)-t(e.y0,n)-o(e)}e.exports={x0:function(e){return e.x0},x1:function(e){return e.x1},y0:function(e){return e.y0},y1:function(e){return e.y1},slope:function(e,t,r){return"line"!==e.type?void 0:l(e,0,r)/s(e,t)},dx:s,dy:l,width:function(e,t){return Math.abs(s(e,t))},height:function(e,t,r){return Math.abs(l(e,0,r))},length:function(e,t,r){return"line"!==e.type?void 0:Math.sqrt(Math.pow(s(e,t),2)+Math.pow(l(e,0,r),2))},xcenter:function(e,o){return r((t(e.x1,o)+i(e)+t(e.x0,o)+n(e))/2,o)},ycenter:function(e,n,i){return r((t(e.y1,i)+a(e)+t(e.y0,i)+o(e))/2,i)}}},86591:(e,t,r)=>{"use strict";var n=r(91740),i=r(18420),o=r(64022).extendDeepAll,a=r(72587).overrideAll,s=r(34765),l=r(37091).templatedArray,c=r(10585),u=l("step",{visible:{valType:"boolean",dflt:!0,description:["Determines whether or not this step is included in the slider."].join(" ")},method:{valType:"enumerated",values:["restyle","relayout","animate","update","skip"],dflt:"restyle",description:["Sets the Plotly method to be called when the slider value is changed.","If the `skip` method is used, the API slider will function as normal","but will perform no API calls and will not bind automatically to state","updates. This may be used to create a component interface and attach to","slider events manually via JavaScript."].join(" ")},args:{valType:"info_array",freeLength:!0,items:[{valType:"any"},{valType:"any"},{valType:"any"}],description:["Sets the arguments values to be passed to the Plotly","method set in `method` on slide."].join(" ")},label:{valType:"string",description:"Sets the text label to appear on the slider"},value:{valType:"string",description:["Sets the value of the slider step, used to refer to the step programatically.","Defaults to the slider label if not provided."].join(" ")},execute:{valType:"boolean",dflt:!0,description:["When true, the API method is executed. When false, all other behaviors are the same","and command execution is skipped. This may be useful when hooking into, for example,","the `plotly_sliderchange` method and executing the API command manually without losing","the benefit of the slider automatically binding to the state of the plot through the","specification of `method` and `args`."].join(" ")}});e.exports=a(l("slider",{visible:{valType:"boolean",dflt:!0,description:["Determines whether or not the slider is visible."].join(" ")},active:{valType:"number",min:0,dflt:0,description:["Determines which button (by index starting from 0) is","considered active."].join(" ")},steps:u,lenmode:{valType:"enumerated",values:["fraction","pixels"],dflt:"fraction",description:["Determines whether this slider length","is set in units of plot *fraction* or in *pixels.","Use `len` to set the value."].join(" ")},len:{valType:"number",min:0,dflt:1,description:["Sets the length of the slider","This measure excludes the padding of both ends.","That is, the slider's length is this length minus the","padding on both ends."].join(" ")},x:{valType:"number",min:-2,max:3,dflt:0,description:"Sets the x position (in normalized coordinates) of the slider."},pad:o(i({editType:"arraydraw"}),{description:"Set the padding of the slider component along each side."},{t:{dflt:20}}),xanchor:{valType:"enumerated",values:["auto","left","center","right"],dflt:"left",description:["Sets the slider's horizontal position anchor.","This anchor binds the `x` position to the *left*, *center*","or *right* of the range selector."].join(" ")},y:{valType:"number",min:-2,max:3,dflt:0,description:"Sets the y position (in normalized coordinates) of the slider."},yanchor:{valType:"enumerated",values:["auto","top","middle","bottom"],dflt:"top",description:["Sets the slider's vertical position anchor","This anchor binds the `y` position to the *top*, *middle*","or *bottom* of the range selector."].join(" ")},transition:{duration:{valType:"number",min:0,dflt:150,description:"Sets the duration of the slider transition"},easing:{valType:"enumerated",values:s.transition.easing.values,dflt:"cubic-in-out",description:"Sets the easing function of the slider transition"}},currentvalue:{visible:{valType:"boolean",dflt:!0,description:["Shows the currently-selected value above the slider."].join(" ")},xanchor:{valType:"enumerated",values:["left","center","right"],dflt:"left",description:["The alignment of the value readout relative to the length of the slider."].join(" ")},offset:{valType:"number",dflt:10,description:["The amount of space, in pixels, between the current value label","and the slider."].join(" ")},prefix:{valType:"string",description:"When currentvalue.visible is true, this sets the prefix of the label."},suffix:{valType:"string",description:"When currentvalue.visible is true, this sets the suffix of the label."},font:n({description:"Sets the font of the current value label text."})},font:n({description:"Sets the font of the slider step labels."}),activebgcolor:{valType:"color",dflt:c.gripBgActiveColor,description:["Sets the background color of the slider grip","while dragging."].join(" ")},bgcolor:{valType:"color",dflt:c.railBgColor,description:"Sets the background color of the slider."},bordercolor:{valType:"color",dflt:c.railBorderColor,description:"Sets the color of the border enclosing the slider."},borderwidth:{valType:"number",min:0,dflt:c.railBorderWidth,description:"Sets the width (in px) of the border enclosing the slider."},ticklen:{valType:"number",min:0,dflt:c.tickLength,description:"Sets the length in pixels of step tick marks"},tickcolor:{valType:"color",dflt:c.tickColor,description:"Sets the color of the border enclosing the slider."},tickwidth:{valType:"number",min:0,dflt:1,description:"Sets the tick width (in px)."},minorticklen:{valType:"number",min:0,dflt:c.minorTickLength,description:"Sets the length in pixels of minor step tick marks"}}),"arraydraw","from-root")},10585:e=>{"use strict";e.exports={name:"sliders",containerClassName:"slider-container",groupClassName:"slider-group",inputAreaClass:"slider-input-area",railRectClass:"slider-rail-rect",railTouchRectClass:"slider-rail-touch-rect",gripRectClass:"slider-grip-rect",tickRectClass:"slider-tick-rect",inputProxyClass:"slider-input-proxy",labelsClass:"slider-labels",labelGroupClass:"slider-label-group",labelClass:"slider-label",currentValueClass:"slider-current-value",railHeight:5,menuIndexAttrName:"slider-active-index",autoMarginIdRoot:"slider-",minWidth:30,minHeight:30,textPadX:40,arrowOffsetX:4,railRadius:2,railWidth:5,railBorder:4,railBorderWidth:1,railBorderColor:"#bec8d9",railBgColor:"#f8fafc",railInset:8,stepInset:10,gripRadius:10,gripWidth:20,gripHeight:20,gripBorder:20,gripBorderWidth:1,gripBorderColor:"#bec8d9",gripBgColor:"#f6f8fa",gripBgActiveColor:"#dbdde0",labelPadding:8,labelOffset:0,tickWidth:1,tickColor:"#333",tickOffset:25,tickLength:7,minorTickOffset:25,minorTickColor:"#333",minorTickLength:4,currentValuePadding:8,currentValueInset:0}},94904:(e,t,r)=>{"use strict";var n=r(84468),i=r(38851),o=r(86591),a=r(10585).name,s=o.steps;function l(e,t,r){function a(r,i){return n.coerce(e,t,o,r,i)}for(var s=i(e,t,{name:"steps",handleItemDefaults:c}),l=0,u=0;u{"use strict";var n=r(41871),i=r(68543),o=r(7605),a=r(3172),s=r(84468),l=s.strTranslate,c=r(13480),u=r(37091).arrayEditor,d=r(10585),h=r(83943),p=h.LINE_SPACING,f=h.FROM_TL,m=h.FROM_BR;function g(e){return d.autoMarginIdRoot+e._index}function y(e){return e._index}function v(e,t){var r=a.tester.selectAll("g."+d.labelGroupClass).data(t._visibleSteps);r.enter().append("g").classed(d.labelGroupClass,!0);var o=0,l=0;r.each((function(e){var r=_(n.select(this),{step:e},t).node();if(r){var i=a.bBox(r);l=Math.max(l,i.height),o=Math.max(o,i.width)}})),r.remove();var u=t._dims={};u.inputAreaWidth=Math.max(d.railWidth,d.gripHeight);var h=e._fullLayout._size;u.lx=h.l+h.w*t.x,u.ly=h.t+h.h*(1-t.y),"fraction"===t.lenmode?u.outerLength=Math.round(h.w*t.len):u.outerLength=t.len,u.inputAreaStart=0,u.inputAreaLength=Math.round(u.outerLength-t.pad.l-t.pad.r);var p=(u.inputAreaLength-2*d.stepInset)/(t._stepCount-1),y=o+d.labelPadding;if(u.labelStride=Math.max(1,Math.ceil(y/p)),u.labelHeight=l,u.currentValueMaxWidth=0,u.currentValueHeight=0,u.currentValueTotalHeight=0,u.currentValueMaxLines=1,t.currentvalue.visible){var v=a.tester.append("g");r.each((function(e){var r=x(v,t,e.label),n=r.node()&&a.bBox(r.node())||{width:0,height:0},i=c.lineCount(r);u.currentValueMaxWidth=Math.max(u.currentValueMaxWidth,Math.ceil(n.width)),u.currentValueHeight=Math.max(u.currentValueHeight,Math.ceil(n.height)),u.currentValueMaxLines=Math.max(u.currentValueMaxLines,i)})),u.currentValueTotalHeight=u.currentValueHeight+t.currentvalue.offset,v.remove()}u.height=u.currentValueTotalHeight+d.tickOffset+t.ticklen+d.labelOffset+u.labelHeight+t.pad.t+t.pad.b;var b="left";s.isRightAnchor(t)&&(u.lx-=u.outerLength,b="right"),s.isCenterAnchor(t)&&(u.lx-=u.outerLength/2,b="center");var w="top";s.isBottomAnchor(t)&&(u.ly-=u.height,w="bottom"),s.isMiddleAnchor(t)&&(u.ly-=u.height/2,w="middle"),u.outerLength=Math.ceil(u.outerLength),u.height=Math.ceil(u.height),u.lx=Math.round(u.lx),u.ly=Math.round(u.ly);var k={y:t.y,b:u.height*m[w],t:u.height*f[w]};"fraction"===t.lenmode?(k.l=0,k.xl=t.x-t.len*f[b],k.r=0,k.xr=t.x+t.len*m[b]):(k.x=t.x,k.l=u.outerLength*f[b],k.r=u.outerLength*m[b]),i.autoMargin(e,g(t),k)}function x(e,t,r){if(t.currentvalue.visible){var n,i,o=t._dims;switch(t.currentvalue.xanchor){case"right":n=o.inputAreaLength-d.currentValueInset-o.currentValueMaxWidth,i="left";break;case"center":n=.5*o.inputAreaLength,i="middle";break;default:n=d.currentValueInset,i="left"}var l=s.ensureSingle(e,"text",d.labelClass,(function(e){e.attr({"text-anchor":i,"data-notex":1})})),u=t.currentvalue.prefix?t.currentvalue.prefix:"";if("string"===typeof r)u+=r;else{var h=t.steps[t.active].label,f=t._gd._fullLayout._meta;f&&(h=s.templateString(h,f)),u+=h}t.currentvalue.suffix&&(u+=t.currentvalue.suffix),l.call(a.font,t.currentvalue.font).text(u).call(c.convertToTspans,t._gd);var m=c.lineCount(l),g=(o.currentValueMaxLines+1-m)*t.currentvalue.font.size*p;return c.positionText(l,n,g),l}}function b(e,t,r){s.ensureSingle(e,"rect",d.gripRectClass,(function(n){n.call(A,t,e,r).style("pointer-events","all")})).attr({width:d.gripWidth,height:d.gripHeight,rx:d.gripRadius,ry:d.gripRadius}).call(o.stroke,r.bordercolor).call(o.fill,r.bgcolor).style("stroke-width",r.borderwidth+"px")}function _(e,t,r){var n=s.ensureSingle(e,"text",d.labelClass,(function(e){e.attr({"text-anchor":"middle","data-notex":1})})),i=t.step.label,o=r._gd._fullLayout._meta;return o&&(i=s.templateString(i,o)),n.call(a.font,r.font).text(i).call(c.convertToTspans,r._gd),n}function w(e,t){var r=s.ensureSingle(e,"g",d.labelsClass),i=t._dims,o=r.selectAll("g."+d.labelGroupClass).data(i.labelSteps);o.enter().append("g").classed(d.labelGroupClass,!0),o.exit().remove(),o.each((function(e){var r=n.select(this);r.call(_,e,t),a.setTranslate(r,C(t,e.fraction),d.tickOffset+t.ticklen+t.font.size*p+d.labelOffset+i.currentValueTotalHeight)}))}function k(e,t,r,n,i){var o=Math.round(n*(r._stepCount-1)),a=r._visibleSteps[o]._index;a!==r.active&&S(e,t,r,a,!0,i)}function S(e,t,r,n,o,a){var s=r.active;r.active=n,u(e.layout,d.name,r).applyUpdate("active",n);var l=r.steps[r.active];t.call(M,r,a),t.call(x,r),e.emit("plotly_sliderchange",{slider:r,step:r.steps[r.active],interaction:o,previousActive:s}),l&&l.method&&o&&(t._nextMethod?(t._nextMethod.step=l,t._nextMethod.doCallback=o,t._nextMethod.doTransition=a):(t._nextMethod={step:l,doCallback:o,doTransition:a},t._nextMethodRaf=window.requestAnimationFrame((function(){var r=t._nextMethod.step;r.method&&(r.execute&&i.executeAPICommand(e,r.method,r.args),t._nextMethod=null,t._nextMethodRaf=null)}))))}function A(e,t,r){if(!t._context.staticPlot){var i=r.node(),a=n.select(t);e.on("mousedown",l),e.on("touchstart",l)}function s(){return r.data()[0]}function l(){var e=s();t.emit("plotly_sliderstart",{slider:e});var l=r.select("."+d.gripRectClass);n.event.stopPropagation(),n.event.preventDefault(),l.call(o.fill,e.activebgcolor);var c=E(e,n.mouse(i)[0]);function u(){var e=s(),o=E(e,n.mouse(i)[0]);k(t,r,e,o,!1)}function h(){var e=s();e._dragging=!1,l.call(o.fill,e.bgcolor),a.on("mouseup",null),a.on("mousemove",null),a.on("touchend",null),a.on("touchmove",null),t.emit("plotly_sliderend",{slider:e,step:e.steps[e.active]})}k(t,r,e,c,!0),e._dragging=!0,a.on("mousemove",u),a.on("touchmove",u),a.on("mouseup",h),a.on("touchend",h)}}function T(e,t){var r=e.selectAll("rect."+d.tickRectClass).data(t._visibleSteps),i=t._dims;r.enter().append("rect").classed(d.tickRectClass,!0),r.exit().remove(),r.attr({width:t.tickwidth+"px","shape-rendering":"crispEdges"}),r.each((function(e,r){var s=r%i.labelStride===0,l=n.select(this);l.attr({height:s?t.ticklen:t.minorticklen}).call(o.fill,t.tickcolor),a.setTranslate(l,C(t,r/(t._stepCount-1))-.5*t.tickwidth,(s?d.tickOffset:d.minorTickOffset)+i.currentValueTotalHeight)}))}function M(e,t,r){for(var n=e.select("rect."+d.gripRectClass),i=0,o=0;o0&&(s=s.transition().duration(t.transition.duration).ease(t.transition.easing)),s.attr("transform",l(a-.5*d.gripWidth,t._dims.currentValueTotalHeight))}}function C(e,t){var r=e._dims;return r.inputAreaStart+d.stepInset+(r.inputAreaLength-2*d.stepInset)*Math.min(1,Math.max(0,t))}function E(e,t){var r=e._dims;return Math.min(1,Math.max(0,(t-d.stepInset-r.inputAreaStart)/(r.inputAreaLength-2*d.stepInset-2*r.inputAreaStart)))}function I(e,t,r){var n=r._dims,i=s.ensureSingle(e,"rect",d.railTouchRectClass,(function(n){n.call(A,t,e,r).style("pointer-events","all")}));i.attr({width:n.inputAreaLength,height:Math.max(n.inputAreaWidth,d.tickOffset+r.ticklen+n.labelHeight)}).call(o.fill,r.bgcolor).attr("opacity",0),a.setTranslate(i,0,n.currentValueTotalHeight)}function P(e,t){var r=t._dims,n=r.inputAreaLength-2*d.railInset,i=s.ensureSingle(e,"rect",d.railRectClass);i.attr({width:n,height:d.railWidth,rx:d.railRadius,ry:d.railRadius,"shape-rendering":"crispEdges"}).call(o.stroke,t.bordercolor).call(o.fill,t.bgcolor).style("stroke-width",t.borderwidth+"px"),a.setTranslate(i,d.railInset,.5*(r.inputAreaWidth-d.railWidth)+r.currentValueTotalHeight)}e.exports=function(e){var t=e._context.staticPlot,r=e._fullLayout,o=function(e,t){for(var r=e[d.name],n=[],i=0;i0?[0]:[]);function l(t){t._commandObserver&&(t._commandObserver.remove(),delete t._commandObserver),i.autoMargin(e,g(t))}if(s.enter().append("g").classed(d.containerClassName,!0).style("cursor",t?null:"ew-resize"),s.exit().each((function(){n.select(this).selectAll("g."+d.groupClassName).each(l)})).remove(),0!==o.length){var c=s.selectAll("g."+d.groupClassName).data(o,y);c.enter().append("g").classed(d.groupClassName,!0),c.exit().each(l).remove();for(var u=0;u{"use strict";var n=r(10585);e.exports={moduleType:"component",name:n.name,layoutAttributes:r(86591),supplyLayoutDefaults:r(94904),draw:r(62460)}},13701:(e,t,r)=>{"use strict";var n=r(41871),i=r(22036),o=r(68543),a=r(38361),s=r(84468),l=s.strTranslate,c=r(3172),u=r(7605),d=r(13480),h=r(64253),p=r(83943).OPPOSITE_SIDE,f=/ [XY][0-9]* /;e.exports={draw:function(e,t,r){var m,g=e._fullLayout,y=r.propContainer,v=r.propName,x=r.placeholder,b=r.traceIndex,_=r.avoid||{},w=r.attributes,k=r.transform,S=r.containerGroup,A=1,T=y.title,M=(T&&T.text?T.text:"").trim(),C=!1,E=T&&T.font?T.font:{},I=E.family,P=E.size,O=E.color,R=E.weight,L=E.style,D=E.variant,z=E.textcase,j=E.lineposition,F=E.shadow,N=!!r.subtitlePropName,B=r.subtitlePlaceholder,V=(y.title||{}).subtitle||{text:"",font:{}},U=V.text.trim(),H=!1,$=1,W=V.font,q=W.family,G=W.size,Y=W.color,X=W.weight,Z=W.style,K=W.variant,J=W.textcase,Q=W.lineposition,ee=W.shadow;"title.text"===v?m="titleText":-1!==v.indexOf("axis")?m="axisTitleText":v.indexOf(!0)&&(m="colorbarTitleText");var te=e._context.edits[m];function re(e,t){return void 0!==e&&void 0!==t&&e.replace(f," % ")===t.replace(f," % ")}""===M?A=0:re(M,x)&&(te||(M=""),A=.2,C=!0),N&&(""===U?$=0:re(U,B)&&(te||(U=""),$=.2,H=!0)),r._meta?M=s.templateString(M,r._meta):g._meta&&(M=s.templateString(M,g._meta));var ne,ie=M||U||te;S||(S=s.ensureSingle(g._infolayer,"g","g-"+t),ne=g._hColorbarMoveTitle);var oe=S.selectAll("text."+t).data(ie?[0]:[]);oe.enter().append("text"),oe.text(M).attr("class",t),oe.exit().remove();var ae=null,se=t+"-subtitle",le=U||te;if(N&&le&&((ae=S.selectAll("text."+se).data(le?[0]:[])).enter().append("text"),ae.text(U).attr("class",se),ae.exit().remove()),!ie)return S;function ce(e,t){s.syncOrAsync([ue,de],{title:e,subtitle:t})}function ue(r){var i,a=r.title,h=r.subtitle;if(!k&&ne&&(k={}),k?(i="",k.rotate&&(i+="rotate("+[k.rotate,w.x,w.y]+")"),(k.offset||ne)&&(i+=l(0,(k.offset||0)-(ne||0)))):i=null,a.attr("transform",i),a.style("opacity",A*u.opacity(O)).call(c.font,{color:u.rgb(O),size:n.round(P,2),family:I,weight:R,style:L,variant:D,textcase:z,shadow:F,lineposition:j}).attr(w).call(d.convertToTspans,e,(function(e){if(e){var t=n.select(e.node().parentNode).select("."+se);if(!t.empty()){var r=e.node().getBBox();if(r.height){var i=r.y+r.height+1.6*G;t.attr("y",i)}}}})),h){var p=S.select("."+t+"-math-group"),f=a.node().getBBox(),m=p.node()?p.node().getBBox():void 0,g=m?m.y+m.height+1.6*G:f.y+f.height+1.6*G,y=s.extendFlat({},w,{y:g});h.attr("transform",i),h.style("opacity",$*u.opacity(Y)).call(c.font,{color:u.rgb(Y),size:n.round(G,2),family:q,weight:X,style:Z,variant:K,textcase:J,shadow:ee,lineposition:Q}).attr(y).call(d.convertToTspans,e)}return o.previousPromises(e)}function de(t){var r=t.title,o=n.select(r.node().parentNode);if(_&&_.selection&&_.side&&M){o.attr("transform",null);var a=p[_.side],u="left"===_.side||"top"===_.side?-1:1,d=i(_.pad)?_.pad:2,h=c.bBox(o.node()),f={t:0,b:0,l:0,r:0},m=e._fullLayout._reservedMargin;for(var v in m)for(var x in m[v]){var b=m[v][x];f[x]=Math.max(f[x],b)}var w={left:f.l,top:f.t,right:g.width-f.r,bottom:g.height-f.b},k=_.maxShift||u*(w[_.side]-h[_.side]),S=0;if(k<0)S=k;else{var A=_.offsetLeft||0,T=_.offsetTop||0;h.left-=A,h.right-=A,h.top-=T,h.bottom-=T,_.selection.each((function(){var e=c.bBox(this);s.bBoxIntersect(h,e,d)&&(S=Math.max(S,u*(e[_.side]-h[a])+d))})),S=Math.min(k,S),y._titleScoot=Math.abs(S)}if(S>0||k<0){var C={left:[-S,0],right:[S,0],top:[0,-S],bottom:[0,S]}[_.side];o.attr("transform",l(C[0],C[1]))}}}function he(e,t){e.text(t).on("mouseover.opacity",(function(){n.select(this).transition().duration(h.SHOW_PLACEHOLDER).style("opacity",1)})).on("mouseout.opacity",(function(){n.select(this).transition().duration(h.HIDE_PLACEHOLDER).style("opacity",0)}))}if(oe.call(ce,ae),te&&(M?oe.on(".opacity",null):(he(oe,x),C=!0),oe.call(d.makeEditable,{gd:e}).on("edit",(function(t){void 0!==b?a.call("_guiRestyle",e,v,t,b):a.call("_guiRelayout",e,v,t)})).on("cancel",(function(){this.text(this.attr("data-unformatted")).call(ce)})).on("input",(function(e){this.text(e||" ").call(d.positionText,w.x,w.y)})),N)){if(N&&!M){var pe=oe.node().getBBox(),fe=pe.y+pe.height+1.6*G;ae.attr("y",fe)}U?ae.on(".opacity",null):(he(ae,B),H=!0),ae.call(d.makeEditable,{gd:e}).on("edit",(function(t){a.call("_guiRelayout",e,"title.subtitle.text",t)})).on("cancel",(function(){this.text(this.attr("data-unformatted")).call(ce)})).on("input",(function(e){this.text(e||" ").call(d.positionText,ae.attr("x"),ae.attr("y"))}))}return oe.classed("js-placeholder",C),ae&&ae.classed("js-placeholder",H),S},SUBTITLE_PADDING_EM:1.6,SUBTITLE_PADDING_MATHJAX_EM:1.6}},14840:(e,t,r)=>{"use strict";var n=r(91740),i=r(17992),o=r(64022).extendFlat,a=r(72587).overrideAll,s=r(18420),l=r(37091).templatedArray,c=l("button",{visible:{valType:"boolean",description:"Determines whether or not this button is visible."},method:{valType:"enumerated",values:["restyle","relayout","animate","update","skip"],dflt:"restyle",description:["Sets the Plotly method to be called on click.","If the `skip` method is used, the API updatemenu will function as normal","but will perform no API calls and will not bind automatically to state","updates. This may be used to create a component interface and attach to","updatemenu events manually via JavaScript."].join(" ")},args:{valType:"info_array",freeLength:!0,items:[{valType:"any"},{valType:"any"},{valType:"any"}],description:["Sets the arguments values to be passed to the Plotly","method set in `method` on click."].join(" ")},args2:{valType:"info_array",freeLength:!0,items:[{valType:"any"},{valType:"any"},{valType:"any"}],description:["Sets a 2nd set of `args`,","these arguments values are passed to the Plotly","method set in `method` when clicking this button while in the active state.","Use this to create toggle buttons."].join(" ")},label:{valType:"string",dflt:"",description:"Sets the text label to appear on the button."},execute:{valType:"boolean",dflt:!0,description:["When true, the API method is executed. When false, all other behaviors are the same","and command execution is skipped. This may be useful when hooking into, for example,","the `plotly_buttonclicked` method and executing the API command manually without losing","the benefit of the updatemenu automatically binding to the state of the plot through the","specification of `method` and `args`."].join(" ")}});e.exports=a(l("updatemenu",{_arrayAttrRegexps:[/^updatemenus\[(0|[1-9][0-9]+)\]\.buttons/],visible:{valType:"boolean",description:["Determines whether or not the update menu is visible."].join(" ")},type:{valType:"enumerated",values:["dropdown","buttons"],dflt:"dropdown",description:["Determines whether the buttons are accessible via a dropdown menu","or whether the buttons are stacked horizontally or vertically"].join(" ")},direction:{valType:"enumerated",values:["left","right","up","down"],dflt:"down",description:["Determines the direction in which the buttons are laid out, whether","in a dropdown menu or a row/column of buttons. For `left` and `up`,","the buttons will still appear in left-to-right or top-to-bottom order","respectively."].join(" ")},active:{valType:"integer",min:-1,dflt:0,description:["Determines which button (by index starting from 0) is","considered active."].join(" ")},showactive:{valType:"boolean",dflt:!0,description:"Highlights active dropdown item or active button if true."},buttons:c,x:{valType:"number",min:-2,max:3,dflt:-.05,description:"Sets the x position (in normalized coordinates) of the update menu."},xanchor:{valType:"enumerated",values:["auto","left","center","right"],dflt:"right",description:["Sets the update menu's horizontal position anchor.","This anchor binds the `x` position to the *left*, *center*","or *right* of the range selector."].join(" ")},y:{valType:"number",min:-2,max:3,dflt:1,description:"Sets the y position (in normalized coordinates) of the update menu."},yanchor:{valType:"enumerated",values:["auto","top","middle","bottom"],dflt:"top",description:["Sets the update menu's vertical position anchor","This anchor binds the `y` position to the *top*, *middle*","or *bottom* of the range selector."].join(" ")},pad:o(s({editType:"arraydraw"}),{description:"Sets the padding around the buttons or dropdown menu."}),font:n({description:"Sets the font of the update menu button text."}),bgcolor:{valType:"color",description:"Sets the background color of the update menu buttons."},bordercolor:{valType:"color",dflt:i.borderLine,description:"Sets the color of the border enclosing the update menu."},borderwidth:{valType:"number",min:0,dflt:1,editType:"arraydraw",description:"Sets the width (in px) of the border enclosing the update menu."}}),"arraydraw","from-root")},12700:e=>{"use strict";e.exports={name:"updatemenus",containerClassName:"updatemenu-container",headerGroupClassName:"updatemenu-header-group",headerClassName:"updatemenu-header",headerArrowClassName:"updatemenu-header-arrow",dropdownButtonGroupClassName:"updatemenu-dropdown-button-group",dropdownButtonClassName:"updatemenu-dropdown-button",buttonClassName:"updatemenu-button",itemRectClassName:"updatemenu-item-rect",itemTextClassName:"updatemenu-item-text",menuIndexAttrName:"updatemenu-active-index",autoMarginIdRoot:"updatemenu-",blankHeaderOpts:{label:" "},minWidth:30,minHeight:30,textPadX:24,arrowPadX:16,rx:2,ry:2,textOffsetX:12,textOffsetY:3,arrowOffsetX:4,gapButtonHeader:5,gapButton:2,activeColor:"#F4FAFF",hoverColor:"#F4FAFF",arrowSymbol:{left:"\u25c4",right:"\u25ba",up:"\u25b2",down:"\u25bc"}}},2063:(e,t,r)=>{"use strict";var n=r(84468),i=r(38851),o=r(14840),a=r(12700).name,s=o.buttons;function l(e,t,r){function a(r,i){return n.coerce(e,t,o,r,i)}a("visible",i(e,t,{name:"buttons",handleItemDefaults:c}).length>0)&&(a("active"),a("direction"),a("type"),a("showactive"),a("x"),a("y"),n.noneOrAll(e,t,["x","y"]),a("xanchor"),a("yanchor"),a("pad.t"),a("pad.r"),a("pad.b"),a("pad.l"),n.coerceFont(a,"font",r.font),a("bgcolor",r.paper_bgcolor),a("bordercolor"),a("borderwidth"))}function c(e,t){function r(r,i){return n.coerce(e,t,s,r,i)}r("visible","skip"===e.method||Array.isArray(e.args))&&(r("method"),r("args"),r("args2"),r("label"),r("execute"))}e.exports=function(e,t){i(e,t,{name:a,handleItemDefaults:l})}},89783:(e,t,r)=>{"use strict";var n=r(41871),i=r(68543),o=r(7605),a=r(3172),s=r(84468),l=r(13480),c=r(37091).arrayEditor,u=r(83943).LINE_SPACING,d=r(12700),h=r(50423);function p(e){return e._index}function f(e,t){return+e.attr(d.menuIndexAttrName)===t._index}function m(e,t,r,n,i,o,a,s){t.active=a,c(e.layout,d.name,t).applyUpdate("active",a),"buttons"===t.type?y(e,n,null,null,t):"dropdown"===t.type&&(i.attr(d.menuIndexAttrName,"-1"),g(e,n,i,o,t),s||y(e,n,i,o,t))}function g(e,t,r,n,i){var o=s.ensureSingle(t,"g",d.headerClassName,(function(e){e.style("pointer-events","all")})),l=i._dims,c=i.active,u=i.buttons[c]||d.blankHeaderOpts,h={y:i.pad.t,yPad:0,x:i.pad.l,xPad:0,index:0},p={width:l.headerWidth,height:l.headerHeight};o.call(v,i,u,e).call(T,i,h,p),s.ensureSingle(t,"text",d.headerArrowClassName,(function(e){e.attr("text-anchor","end").call(a.font,i.font).text(d.arrowSymbol[i.direction])})).attr({x:l.headerWidth-d.arrowOffsetX+i.pad.l,y:l.headerHeight/2+d.textOffsetY+i.pad.t}),o.on("click",(function(){r.call(M,String(f(r,i)?-1:i._index)),y(e,t,r,n,i)})),o.on("mouseover",(function(){o.call(w)})),o.on("mouseout",(function(){o.call(k,i)})),a.setTranslate(t,l.lx,l.ly)}function y(e,t,r,o,a){r||(r=t).attr("pointer-events","all");var l=function(e){return-1===+e.attr(d.menuIndexAttrName)}(r)&&"buttons"!==a.type?[]:a.buttons,c="dropdown"===a.type?d.dropdownButtonClassName:d.buttonClassName,u=r.selectAll("g."+c).data(s.filterVisible(l)),h=u.enter().append("g").classed(c,!0),p=u.exit();"dropdown"===a.type?(h.attr("opacity","0").transition().attr("opacity","1"),p.transition().attr("opacity","0").remove()):p.remove();var f=0,g=0,y=a._dims,x=-1!==["up","down"].indexOf(a.direction);"dropdown"===a.type&&(x?g=y.headerHeight+d.gapButtonHeader:f=y.headerWidth+d.gapButtonHeader),"dropdown"===a.type&&"up"===a.direction&&(g=-d.gapButtonHeader+d.gapButton-y.openHeight),"dropdown"===a.type&&"left"===a.direction&&(f=-d.gapButtonHeader+d.gapButton-y.openWidth);var b={x:y.lx+f+a.pad.l,y:y.ly+g+a.pad.t,yPad:d.gapButton,xPad:d.gapButton,index:0},S={l:b.x+a.borderwidth,t:b.y+a.borderwidth};u.each((function(s,l){var c=n.select(this);c.call(v,a,s,e).call(T,a,b),c.on("click",(function(){n.event.defaultPrevented||(s.execute&&(s.args2&&a.active===l?(m(e,a,0,t,r,o,-1),i.executeAPICommand(e,s.method,s.args2)):(m(e,a,0,t,r,o,l),i.executeAPICommand(e,s.method,s.args))),e.emit("plotly_buttonclicked",{menu:a,button:s,active:a.active}))})),c.on("mouseover",(function(){c.call(w)})),c.on("mouseout",(function(){c.call(k,a),u.call(_,a)}))})),u.call(_,a),x?(S.w=Math.max(y.openWidth,y.headerWidth),S.h=b.y-S.t):(S.w=b.x-S.l,S.h=Math.max(y.openHeight,y.headerHeight)),S.direction=a.direction,o&&(u.size()?function(e,t,r,n,i,o){var a,s,l,c=i.direction,u="up"===c||"down"===c,h=i._dims,p=i.active;if(u)for(s=0,l=0;l0?[0]:[]);if(a.enter().append("g").classed(d.containerClassName,!0).style("cursor","pointer"),a.exit().each((function(){n.select(this).selectAll("g."+d.headerGroupClassName).each(o)})).remove(),0!==r.length){var l=a.selectAll("g."+d.headerGroupClassName).data(r,p);l.enter().append("g").classed(d.headerGroupClassName,!0);for(var c=s.ensureSingle(a,"g",d.dropdownButtonGroupClassName,(function(e){e.style("pointer-events","all")})),u=0;u{"use strict";var n=r(12700);e.exports={moduleType:"component",name:n.name,layoutAttributes:r(14840),supplyLayoutDefaults:r(2063),draw:r(89783)}},50423:(e,t,r)=>{"use strict";e.exports=s;var n=r(41871),i=r(7605),o=r(3172),a=r(84468);function s(e,t,r){this.gd=e,this.container=t,this.id=r,this.position=null,this.translateX=null,this.translateY=null,this.hbar=null,this.vbar=null,this.bg=this.container.selectAll("rect.scrollbox-bg").data([0]),this.bg.exit().on(".drag",null).on("wheel",null).remove(),this.bg.enter().append("rect").classed("scrollbox-bg",!0).style("pointer-events","all").attr({opacity:0,x:0,y:0,width:0,height:0})}s.barWidth=2,s.barLength=20,s.barRadius=2,s.barPad=1,s.barColor="#808BA4",s.prototype.enable=function(e,t,r){var a=this.gd._fullLayout,l=a.width,c=a.height;this.position=e;var u,d,h,p,f=this.position.l,m=this.position.w,g=this.position.t,y=this.position.h,v=this.position.direction,x="down"===v,b="left"===v,_="up"===v,w=m,k=y;x||b||"right"===v||_||(this.position.direction="down",x=!0),x||_?(d=(u=f)+w,x?(h=g,k=(p=Math.min(h+k,c))-h):k=(p=g+k)-(h=Math.max(p-k,0))):(p=(h=g)+k,b?w=(d=f+w)-(u=Math.max(d-w,0)):(u=f,w=(d=Math.min(u+w,l))-u)),this._box={l:u,t:h,w:w,h:k};var S=m>w,A=s.barLength+2*s.barPad,T=s.barWidth+2*s.barPad,M=f,C=g+y;C+T>c&&(C=c-T);var E=this.container.selectAll("rect.scrollbar-horizontal").data(S?[0]:[]);E.exit().on(".drag",null).remove(),E.enter().append("rect").classed("scrollbar-horizontal",!0).call(i.fill,s.barColor),S?(this.hbar=E.attr({rx:s.barRadius,ry:s.barRadius,x:M,y:C,width:A,height:T}),this._hbarXMin=M+A/2,this._hbarTranslateMax=w-A):(delete this.hbar,delete this._hbarXMin,delete this._hbarTranslateMax);var I=y>k,P=s.barWidth+2*s.barPad,O=s.barLength+2*s.barPad,R=f+m,L=g;R+P>l&&(R=l-P);var D=this.container.selectAll("rect.scrollbar-vertical").data(I?[0]:[]);D.exit().on(".drag",null).remove(),D.enter().append("rect").classed("scrollbar-vertical",!0).call(i.fill,s.barColor),I?(this.vbar=D.attr({rx:s.barRadius,ry:s.barRadius,x:R,y:L,width:P,height:O}),this._vbarYMin=L+O/2,this._vbarTranslateMax=k-O):(delete this.vbar,delete this._vbarYMin,delete this._vbarTranslateMax);var z=this.id,j=u-.5,F=I?d+P+.5:d+.5,N=h-.5,B=S?p+T+.5:p+.5,V=a._topdefs.selectAll("#"+z).data(S||I?[0]:[]);if(V.exit().remove(),V.enter().append("clipPath").attr("id",z).append("rect"),S||I?(this._clipRect=V.select("rect").attr({x:Math.floor(j),y:Math.floor(N),width:Math.ceil(F)-Math.floor(j),height:Math.ceil(B)-Math.floor(N)}),this.container.call(o.setClipUrl,z,this.gd),this.bg.attr({x:f,y:g,width:m,height:y})):(this.bg.attr({width:0,height:0}),this.container.on("wheel",null).on(".drag",null).call(o.setClipUrl,null),delete this._clipRect),S||I){var U=n.behavior.drag().on("dragstart",(function(){n.event.sourceEvent.preventDefault()})).on("drag",this._onBoxDrag.bind(this));this.container.on("wheel",null).on("wheel",this._onBoxWheel.bind(this)).on(".drag",null).call(U);var H=n.behavior.drag().on("dragstart",(function(){n.event.sourceEvent.preventDefault(),n.event.sourceEvent.stopPropagation()})).on("drag",this._onBarDrag.bind(this));S&&this.hbar.on(".drag",null).call(H),I&&this.vbar.on(".drag",null).call(H)}this.setTranslate(t,r)},s.prototype.disable=function(){(this.hbar||this.vbar)&&(this.bg.attr({width:0,height:0}),this.container.on("wheel",null).on(".drag",null).call(o.setClipUrl,null),delete this._clipRect),this.hbar&&(this.hbar.on(".drag",null),this.hbar.remove(),delete this.hbar,delete this._hbarXMin,delete this._hbarTranslateMax),this.vbar&&(this.vbar.on(".drag",null),this.vbar.remove(),delete this.vbar,delete this._vbarYMin,delete this._vbarTranslateMax)},s.prototype._onBoxDrag=function(){var e=this.translateX,t=this.translateY;this.hbar&&(e-=n.event.dx),this.vbar&&(t-=n.event.dy),this.setTranslate(e,t)},s.prototype._onBoxWheel=function(){var e=this.translateX,t=this.translateY;this.hbar&&(e+=n.event.deltaY),this.vbar&&(t+=n.event.deltaY),this.setTranslate(e,t)},s.prototype._onBarDrag=function(){var e=this.translateX,t=this.translateY;if(this.hbar){var r=e+this._hbarXMin,i=r+this._hbarTranslateMax;e=(a.constrain(n.event.x,r,i)-r)/(i-r)*(this.position.w-this._box.w)}if(this.vbar){var o=t+this._vbarYMin,s=o+this._vbarTranslateMax;t=(a.constrain(n.event.y,o,s)-o)/(s-o)*(this.position.h-this._box.h)}this.setTranslate(e,t)},s.prototype.setTranslate=function(e,t){var r=this.position.w-this._box.w,n=this.position.h-this._box.h;if(e=a.constrain(e||0,0,r),t=a.constrain(t||0,0,n),this.translateX=e,this.translateY=t,this.container.call(o.setTranslate,this._box.l-this.position.l-e,this._box.t-this.position.t-t),this._clipRect&&this._clipRect.attr({x:Math.floor(this.position.l+e-.5),y:Math.floor(this.position.t+t-.5)}),this.hbar){var i=e/r;this.hbar.call(o.setTranslate,e+i*this._hbarTranslateMax,t)}if(this.vbar){var s=t/n;this.vbar.call(o.setTranslate,e,t+s*this._vbarTranslateMax)}}},83943:e=>{"use strict";e.exports={FROM_BL:{left:0,center:.5,right:1,bottom:0,middle:.5,top:1},FROM_TL:{left:0,center:.5,right:1,bottom:1,middle:.5,top:0},FROM_BR:{left:1,center:.5,right:0,bottom:0,middle:.5,top:1},LINE_SPACING:1.3,CAP_SHIFT:.7,MID_SHIFT:.35,OPPOSITE_SIDE:{left:"right",right:"left",top:"bottom",bottom:"top"}}},54654:e=>{"use strict";e.exports={axisRefDescription:function(e,t,r){return["If set to a",e,"axis id (e.g. *"+e+"* or","*"+e+"2*), the `"+e+"` position refers to a",e,"coordinate. If set to *paper*, the `"+e+"`","position refers to the distance from the",t,"of the plotting","area in normalized coordinates where *0* (*1*) corresponds to the",t,"("+r+"). If set to a",e,"axis ID followed by","*domain* (separated by a space), the position behaves like for","*paper*, but refers to the distance in fractions of the domain","length from the",t,"of the domain of that axis: e.g.,","*"+e+"2 domain* refers to the domain of the second",e," axis and a",e,"position of 0.5 refers to the","point between the",t,"and the",r,"of the domain of the","second",e,"axis."].join(" ")}}},22876:e=>{"use strict";e.exports={INCREASING:{COLOR:"#3D9970",SYMBOL:"\u25b2"},DECREASING:{COLOR:"#FF4136",SYMBOL:"\u25bc"}}},3127:e=>{"use strict";e.exports={FORMAT_LINK:"https://github.com/d3/d3-format/tree/v1.4.5#d3-format",DATE_FORMAT_LINK:"https://github.com/d3/d3-time-format/tree/v2.2.3#locale_format"}},23605:e=>{"use strict";e.exports={COMPARISON_OPS:["=","!=","<",">=",">","<="],COMPARISON_OPS2:["=","<",">=",">","<="],INTERVAL_OPS:["[]","()","[)","(]","][",")(","](",")["],SET_OPS:["{}","}{"],CONSTRAINT_REDUCTION:{"=":"=","<":"<","<=":"<",">":">",">=":">","[]":"[]","()":"[]","[)":"[]","(]":"[]","][":"][",")(":"][","](":"][",")[":"]["}}},30915:e=>{"use strict";e.exports={solid:[[],0],dot:[[.5,1],200],dash:[[.5,1],50],longdash:[[.5,1],10],dashdot:[[.5,.625,.875,1],50],longdashdot:[[.5,.7,.8,1],10]}},10956:e=>{"use strict";e.exports={circle:"\u25cf","circle-open":"\u25cb",square:"\u25a0","square-open":"\u25a1",diamond:"\u25c6","diamond-open":"\u25c7",cross:"+",x:"\u274c"}},64253:e=>{"use strict";e.exports={SHOW_PLACEHOLDER:100,HIDE_PLACEHOLDER:1e3,DESELECTDIM:.2}},65004:e=>{"use strict";e.exports={BADNUM:void 0,FP_SAFE:1e-4*Number.MAX_VALUE,ONEMAXYEAR:316224e5,ONEAVGYEAR:315576e5,ONEMINYEAR:31536e6,ONEMAXQUARTER:79488e5,ONEAVGQUARTER:78894e5,ONEMINQUARTER:76896e5,ONEMAXMONTH:26784e5,ONEAVGMONTH:26298e5,ONEMINMONTH:24192e5,ONEWEEK:6048e5,ONEDAY:864e5,ONEHOUR:36e5,ONEMIN:6e4,ONESEC:1e3,ONEMILLI:1,ONEMICROSEC:.001,EPOCHJD:2440587.5,ALMOST_EQUAL:.999999,LOG_CLIP:10,MINUS_SIGN:"\u2212"}},44740:(e,t)=>{"use strict";t.CSS_DECLARATIONS=[["image-rendering","optimizeSpeed"],["image-rendering","-moz-crisp-edges"],["image-rendering","-o-crisp-edges"],["image-rendering","-webkit-optimize-contrast"],["image-rendering","optimize-contrast"],["image-rendering","crisp-edges"],["image-rendering","pixelated"]],t.STYLE=t.CSS_DECLARATIONS.map((function(e){return e.join(": ")+"; "})).join("")},28795:(e,t)=>{"use strict";t.xmlns="http://www.w3.org/2000/xmlns/",t.svg="http://www.w3.org/2000/svg",t.xlink="http://www.w3.org/1999/xlink",t.svgAttrs={xmlns:t.svg,"xmlns:xlink":t.xlink}},17521:(e,t,r)=>{"use strict";t.version=r(17316).version,r(1843),r(56380);for(var n=r(38361),i=t.register=n.register,o=r(30069),a=Object.keys(o),s=0;s{"use strict";e.exports={undo:{width:857.1,height:1e3,path:"m857 350q0-87-34-166t-91-137-137-92-166-34q-96 0-183 41t-147 114q-4 6-4 13t5 11l76 77q6 5 14 5 9-1 13-7 41-53 100-82t126-29q58 0 110 23t92 61 61 91 22 111-22 111-61 91-92 61-110 23q-55 0-105-20t-90-57l77-77q17-16 8-38-10-23-33-23h-250q-15 0-25 11t-11 25v250q0 24 22 33 22 10 39-8l72-72q60 57 137 88t159 31q87 0 166-34t137-92 91-137 34-166z",transform:"matrix(1 0 0 -1 0 850)"},home:{width:928.6,height:1e3,path:"m786 296v-267q0-15-11-26t-25-10h-214v214h-143v-214h-214q-15 0-25 10t-11 26v267q0 1 0 2t0 2l321 264 321-264q1-1 1-4z m124 39l-34-41q-5-5-12-6h-2q-7 0-12 3l-386 322-386-322q-7-4-13-4-7 2-12 7l-35 41q-4 5-3 13t6 12l401 334q18 15 42 15t43-15l136-114v109q0 8 5 13t13 5h107q8 0 13-5t5-13v-227l122-102q5-5 6-12t-4-13z",transform:"matrix(1 0 0 -1 0 850)"},"camera-retro":{width:1e3,height:1e3,path:"m518 386q0 8-5 13t-13 5q-37 0-63-27t-26-63q0-8 5-13t13-5 12 5 5 13q0 23 16 38t38 16q8 0 13 5t5 13z m125-73q0-59-42-101t-101-42-101 42-42 101 42 101 101 42 101-42 42-101z m-572-320h858v71h-858v-71z m643 320q0 89-62 152t-152 62-151-62-63-152 63-151 151-63 152 63 62 151z m-571 358h214v72h-214v-72z m-72-107h858v143h-462l-36-71h-360v-72z m929 143v-714q0-30-21-51t-50-21h-858q-29 0-50 21t-21 51v714q0 30 21 51t50 21h858q29 0 50-21t21-51z",transform:"matrix(1 0 0 -1 0 850)"},zoombox:{width:1e3,height:1e3,path:"m1000-25l-250 251c40 63 63 138 63 218 0 224-182 406-407 406-224 0-406-182-406-406s183-406 407-406c80 0 155 22 218 62l250-250 125 125z m-812 250l0 438 437 0 0-438-437 0z m62 375l313 0 0-312-313 0 0 312z",transform:"matrix(1 0 0 -1 0 850)"},pan:{width:1e3,height:1e3,path:"m1000 350l-187 188 0-125-250 0 0 250 125 0-188 187-187-187 125 0 0-250-250 0 0 125-188-188 186-187 0 125 252 0 0-250-125 0 187-188 188 188-125 0 0 250 250 0 0-126 187 188z",transform:"matrix(1 0 0 -1 0 850)"},zoom_plus:{width:875,height:1e3,path:"m1 787l0-875 875 0 0 875-875 0z m687-500l-187 0 0-187-125 0 0 187-188 0 0 125 188 0 0 187 125 0 0-187 187 0 0-125z",transform:"matrix(1 0 0 -1 0 850)"},zoom_minus:{width:875,height:1e3,path:"m0 788l0-876 875 0 0 876-875 0z m688-500l-500 0 0 125 500 0 0-125z",transform:"matrix(1 0 0 -1 0 850)"},autoscale:{width:1e3,height:1e3,path:"m250 850l-187 0-63 0 0-62 0-188 63 0 0 188 187 0 0 62z m688 0l-188 0 0-62 188 0 0-188 62 0 0 188 0 62-62 0z m-875-938l0 188-63 0 0-188 0-62 63 0 187 0 0 62-187 0z m875 188l0-188-188 0 0-62 188 0 62 0 0 62 0 188-62 0z m-125 188l-1 0-93-94-156 156 156 156 92-93 2 0 0 250-250 0 0-2 93-92-156-156-156 156 94 92 0 2-250 0 0-250 0 0 93 93 157-156-157-156-93 94 0 0 0-250 250 0 0 0-94 93 156 157 156-157-93-93 0 0 250 0 0 250z",transform:"matrix(1 0 0 -1 0 850)"},tooltip_basic:{width:1500,height:1e3,path:"m375 725l0 0-375-375 375-374 0-1 1125 0 0 750-1125 0z",transform:"matrix(1 0 0 -1 0 850)"},tooltip_compare:{width:1125,height:1e3,path:"m187 786l0 2-187-188 188-187 0 0 937 0 0 373-938 0z m0-499l0 1-187-188 188-188 0 0 937 0 0 376-938-1z",transform:"matrix(1 0 0 -1 0 850)"},plotlylogo:{width:1542,height:1e3,path:"m0-10h182v-140h-182v140z m228 146h183v-286h-183v286z m225 714h182v-1000h-182v1000z m225-285h182v-715h-182v715z m225 142h183v-857h-183v857z m231-428h182v-429h-182v429z m225-291h183v-138h-183v138z",transform:"matrix(1 0 0 -1 0 850)"},"z-axis":{width:1e3,height:1e3,path:"m833 5l-17 108v41l-130-65 130-66c0 0 0 38 0 39 0-1 36-14 39-25 4-15-6-22-16-30-15-12-39-16-56-20-90-22-187-23-279-23-261 0-341 34-353 59 3 60 228 110 228 110-140-8-351-35-351-116 0-120 293-142 474-142 155 0 477 22 477 142 0 50-74 79-163 96z m-374 94c-58-5-99-21-99-40 0-24 65-43 144-43 79 0 143 19 143 43 0 19-42 34-98 40v216h87l-132 135-133-135h88v-216z m167 515h-136v1c16 16 31 34 46 52l84 109v54h-230v-71h124v-1c-16-17-28-32-44-51l-89-114v-51h245v72z",transform:"matrix(1 0 0 -1 0 850)"},"3d_rotate":{width:1e3,height:1e3,path:"m922 660c-5 4-9 7-14 11-359 263-580-31-580-31l-102 28 58-400c0 1 1 1 2 2 118 108 351 249 351 249s-62 27-100 42c88 83 222 183 347 122 16-8 30-17 44-27-2 1-4 2-6 4z m36-329c0 0 64 229-88 296-62 27-124 14-175-11 157-78 225-208 249-266 8-19 11-31 11-31 2 5 6 15 11 32-5-13-8-20-8-20z m-775-239c70-31 117-50 198-32-121 80-199 346-199 346l-96-15-58-12c0 0 55-226 155-287z m603 133l-317-139c0 0 4-4 19-14 7-5 24-15 24-15s-177-147-389 4c235-287 536-112 536-112l31-22 100 299-4-1z m-298-153c6-4 14-9 24-15 0 0-17 10-24 15z",transform:"matrix(1 0 0 -1 0 850)"},camera:{width:1e3,height:1e3,path:"m500 450c-83 0-150-67-150-150 0-83 67-150 150-150 83 0 150 67 150 150 0 83-67 150-150 150z m400 150h-120c-16 0-34 13-39 29l-31 93c-6 15-23 28-40 28h-340c-16 0-34-13-39-28l-31-94c-6-15-23-28-40-28h-120c-55 0-100-45-100-100v-450c0-55 45-100 100-100h800c55 0 100 45 100 100v450c0 55-45 100-100 100z m-400-550c-138 0-250 112-250 250 0 138 112 250 250 250 138 0 250-112 250-250 0-138-112-250-250-250z m365 380c-19 0-35 16-35 35 0 19 16 35 35 35 19 0 35-16 35-35 0-19-16-35-35-35z",transform:"matrix(1 0 0 -1 0 850)"},movie:{width:1e3,height:1e3,path:"m938 413l-188-125c0 37-17 71-44 94 64 38 107 107 107 187 0 121-98 219-219 219-121 0-219-98-219-219 0-61 25-117 66-156h-115c30 33 49 76 49 125 0 103-84 187-187 187s-188-84-188-187c0-57 26-107 65-141-38-22-65-62-65-109v-250c0-70 56-126 125-126h500c69 0 125 56 125 126l188-126c34 0 62 28 62 63v375c0 35-28 63-62 63z m-750 0c-69 0-125 56-125 125s56 125 125 125 125-56 125-125-56-125-125-125z m406-1c-87 0-157 70-157 157 0 86 70 156 157 156s156-70 156-156-70-157-156-157z",transform:"matrix(1 0 0 -1 0 850)"},question:{width:857.1,height:1e3,path:"m500 82v107q0 8-5 13t-13 5h-107q-8 0-13-5t-5-13v-107q0-8 5-13t13-5h107q8 0 13 5t5 13z m143 375q0 49-31 91t-77 65-95 23q-136 0-207-119-9-14 4-24l74-55q4-4 10-4 9 0 14 7 30 38 48 51 19 14 48 14 27 0 48-15t21-33q0-21-11-34t-38-25q-35-16-65-48t-29-70v-20q0-8 5-13t13-5h107q8 0 13 5t5 13q0 10 12 27t30 28q18 10 28 16t25 19 25 27 16 34 7 45z m214-107q0-117-57-215t-156-156-215-58-216 58-155 156-58 215 58 215 155 156 216 58 215-58 156-156 57-215z",transform:"matrix(1 0 0 -1 0 850)"},disk:{width:857.1,height:1e3,path:"m214-7h429v214h-429v-214z m500 0h72v500q0 8-6 21t-11 20l-157 156q-5 6-19 12t-22 5v-232q0-22-15-38t-38-16h-322q-22 0-37 16t-16 38v232h-72v-714h72v232q0 22 16 38t37 16h465q22 0 38-16t15-38v-232z m-214 518v178q0 8-5 13t-13 5h-107q-7 0-13-5t-5-13v-178q0-8 5-13t13-5h107q7 0 13 5t5 13z m357-18v-518q0-22-15-38t-38-16h-750q-23 0-38 16t-16 38v750q0 22 16 38t38 16h517q23 0 50-12t42-26l156-157q16-15 27-42t11-49z",transform:"matrix(1 0 0 -1 0 850)"},drawopenpath:{width:70,height:70,path:"M33.21,85.65a7.31,7.31,0,0,1-2.59-.48c-8.16-3.11-9.27-19.8-9.88-41.3-.1-3.58-.19-6.68-.35-9-.15-2.1-.67-3.48-1.43-3.79-2.13-.88-7.91,2.32-12,5.86L3,32.38c1.87-1.64,11.55-9.66,18.27-6.9,2.13.87,4.75,3.14,5.17,9,.17,2.43.26,5.59.36,9.25a224.17,224.17,0,0,0,1.5,23.4c1.54,10.76,4,12.22,4.48,12.4.84.32,2.79-.46,5.76-3.59L43,80.07C41.53,81.57,37.68,85.64,33.21,85.65ZM74.81,69a11.34,11.34,0,0,0,6.09-6.72L87.26,44.5,74.72,32,56.9,38.35c-2.37.86-5.57,3.42-6.61,6L38.65,72.14l8.42,8.43ZM55,46.27a7.91,7.91,0,0,1,3.64-3.17l14.8-5.3,8,8L76.11,60.6l-.06.19a6.37,6.37,0,0,1-3,3.43L48.25,74.59,44.62,71Zm16.57,7.82A6.9,6.9,0,1,0,64.64,61,6.91,6.91,0,0,0,71.54,54.09Zm-4.05,0a2.85,2.85,0,1,1-2.85-2.85A2.86,2.86,0,0,1,67.49,54.09Zm-4.13,5.22L60.5,56.45,44.26,72.7l2.86,2.86ZM97.83,35.67,84.14,22l-8.57,8.57L89.26,44.24Zm-13.69-8,8,8-2.85,2.85-8-8Z",transform:"matrix(1 0 0 1 -15 -15)"},drawclosedpath:{width:90,height:90,path:"M88.41,21.12a26.56,26.56,0,0,0-36.18,0l-2.07,2-2.07-2a26.57,26.57,0,0,0-36.18,0,23.74,23.74,0,0,0,0,34.8L48,90.12a3.22,3.22,0,0,0,4.42,0l36-34.21a23.73,23.73,0,0,0,0-34.79ZM84,51.24,50.16,83.35,16.35,51.25a17.28,17.28,0,0,1,0-25.47,20,20,0,0,1,27.3,0l4.29,4.07a3.23,3.23,0,0,0,4.44,0l4.29-4.07a20,20,0,0,1,27.3,0,17.27,17.27,0,0,1,0,25.46ZM66.76,47.68h-33v6.91h33ZM53.35,35H46.44V68h6.91Z",transform:"matrix(1 0 0 1 -5 -5)"},lasso:{width:1031,height:1e3,path:"m1018 538c-36 207-290 336-568 286-277-48-473-256-436-463 10-57 36-108 76-151-13-66 11-137 68-183 34-28 75-41 114-42l-55-70 0 0c-2-1-3-2-4-3-10-14-8-34 5-45 14-11 34-8 45 4 1 1 2 3 2 5l0 0 113 140c16 11 31 24 45 40 4 3 6 7 8 11 48-3 100 0 151 9 278 48 473 255 436 462z m-624-379c-80 14-149 48-197 96 42 42 109 47 156 9 33-26 47-66 41-105z m-187-74c-19 16-33 37-39 60 50-32 109-55 174-68-42-25-95-24-135 8z m360 75c-34-7-69-9-102-8 8 62-16 128-68 170-73 59-175 54-244-5-9 20-16 40-20 61-28 159 121 317 333 354s407-60 434-217c28-159-121-318-333-355z",transform:"matrix(1 0 0 -1 0 850)"},selectbox:{width:1e3,height:1e3,path:"m0 850l0-143 143 0 0 143-143 0z m286 0l0-143 143 0 0 143-143 0z m285 0l0-143 143 0 0 143-143 0z m286 0l0-143 143 0 0 143-143 0z m-857-286l0-143 143 0 0 143-143 0z m857 0l0-143 143 0 0 143-143 0z m-857-285l0-143 143 0 0 143-143 0z m857 0l0-143 143 0 0 143-143 0z m-857-286l0-143 143 0 0 143-143 0z m286 0l0-143 143 0 0 143-143 0z m285 0l0-143 143 0 0 143-143 0z m286 0l0-143 143 0 0 143-143 0z",transform:"matrix(1 0 0 -1 0 850)"},drawline:{width:70,height:70,path:"M60.64,62.3a11.29,11.29,0,0,0,6.09-6.72l6.35-17.72L60.54,25.31l-17.82,6.4c-2.36.86-5.57,3.41-6.6,6L24.48,65.5l8.42,8.42ZM40.79,39.63a7.89,7.89,0,0,1,3.65-3.17l14.79-5.31,8,8L61.94,54l-.06.19a6.44,6.44,0,0,1-3,3.43L34.07,68l-3.62-3.63Zm16.57,7.81a6.9,6.9,0,1,0-6.89,6.9A6.9,6.9,0,0,0,57.36,47.44Zm-4,0a2.86,2.86,0,1,1-2.85-2.85A2.86,2.86,0,0,1,53.32,47.44Zm-4.13,5.22L46.33,49.8,30.08,66.05l2.86,2.86ZM83.65,29,70,15.34,61.4,23.9,75.09,37.59ZM70,21.06l8,8-2.84,2.85-8-8ZM87,80.49H10.67V87H87Z",transform:"matrix(1 0 0 1 -15 -15)"},drawrect:{width:80,height:80,path:"M78,22V79H21V22H78m9-9H12V88H87V13ZM68,46.22H31V54H68ZM53,32H45.22V69H53Z",transform:"matrix(1 0 0 1 -10 -10)"},drawcircle:{width:80,height:80,path:"M50,84.72C26.84,84.72,8,69.28,8,50.3S26.84,15.87,50,15.87,92,31.31,92,50.3,73.16,84.72,50,84.72Zm0-60.59c-18.6,0-33.74,11.74-33.74,26.17S31.4,76.46,50,76.46,83.74,64.72,83.74,50.3,68.6,24.13,50,24.13Zm17.15,22h-34v7.11h34Zm-13.8-13H46.24v34h7.11Z",transform:"matrix(1 0 0 1 -10 -10)"},eraseshape:{width:80,height:80,path:"M82.77,78H31.85L6,49.57,31.85,21.14H82.77a8.72,8.72,0,0,1,8.65,8.77V69.24A8.72,8.72,0,0,1,82.77,78ZM35.46,69.84H82.77a.57.57,0,0,0,.49-.6V29.91a.57.57,0,0,0-.49-.61H35.46L17,49.57Zm32.68-34.7-24,24,5,5,24-24Zm-19,.53-5,5,24,24,5-5Z",transform:"matrix(1 0 0 1 -10 -10)"},spikeline:{width:1e3,height:1e3,path:"M512 409c0-57-46-104-103-104-57 0-104 47-104 104 0 57 47 103 104 103 57 0 103-46 103-103z m-327-39l92 0 0 92-92 0z m-185 0l92 0 0 92-92 0z m370-186l92 0 0 93-92 0z m0-184l92 0 0 92-92 0z",transform:"matrix(1.5 0 0 -1.5 0 850)"},pencil:{width:1792,height:1792,path:"M491 1536l91-91-235-235-91 91v107h128v128h107zm523-928q0-22-22-22-10 0-17 7l-542 542q-7 7-7 17 0 22 22 22 10 0 17-7l542-542q7-7 7-17zm-54-192l416 416-832 832h-416v-416zm683 96q0 53-37 90l-166 166-416-416 166-165q36-38 90-38 53 0 91 38l235 234q37 39 37 91z",transform:"matrix(1 0 0 1 0 1)"},newplotlylogo:{name:"newplotlylogo",svg:["",""," ",""," plotly-logomark"," "," "," "," "," "," "," "," "," "," "," "," "," ",""].join("")}}},49553:(e,t)=>{"use strict";t.isLeftAnchor=function(e){return"left"===e.xanchor||"auto"===e.xanchor&&e.x<=1/3},t.isCenterAnchor=function(e){return"center"===e.xanchor||"auto"===e.xanchor&&e.x>1/3&&e.x<2/3},t.isRightAnchor=function(e){return"right"===e.xanchor||"auto"===e.xanchor&&e.x>=2/3},t.isTopAnchor=function(e){return"top"===e.yanchor||"auto"===e.yanchor&&e.y>=2/3},t.isMiddleAnchor=function(e){return"middle"===e.yanchor||"auto"===e.yanchor&&e.y>1/3&&e.y<2/3},t.isBottomAnchor=function(e){return"bottom"===e.yanchor||"auto"===e.yanchor&&e.y<=1/3}},32510:(e,t,r)=>{"use strict";var n=r(95260),i=n.mod,o=n.modHalf,a=Math.PI,s=2*a;function l(e){return Math.abs(e[1]-e[0])>s-1e-14}function c(e,t){return o(t-e,s)}function u(e,t){if(l(t))return!0;var r,n;t[0](n=i(n,s))&&(n+=s);var o=i(e,s),a=o+s;return o>=r&&o<=n||a>=r&&a<=n}function d(e,t,r,n,i,o,c){i=i||0,o=o||0;var u,d,h,p,f,m=l([r,n]);function g(e,t){return[e*Math.cos(t)+i,o-e*Math.sin(t)]}m?(u=0,d=a,h=s):r=i&&e<=o);var i,o},pathArc:function(e,t,r,n,i){return d(null,e,t,r,n,i,0)},pathSector:function(e,t,r,n,i){return d(null,e,t,r,n,i,1)},pathAnnulus:function(e,t,r,n,i,o){return d(e,t,r,n,i,o,1)}}},19045:(e,t,r)=>{"use strict";var n=r(12160).decode,i=r(30167),o=Array.isArray,a=ArrayBuffer,s=DataView;function l(e){return a.isView(e)&&!(e instanceof s)}function c(e){return o(e)||l(e)}t.isTypedArray=l,t.isArrayOrTypedArray=c,t.isArray1D=function(e){return!c(e[0])},t.ensureArray=function(e,t){return o(e)||(e=[]),e.length=t,e};var u={u1c:"undefined"===typeof Uint8ClampedArray?void 0:Uint8ClampedArray,i1:"undefined"===typeof Int8Array?void 0:Int8Array,u1:"undefined"===typeof Uint8Array?void 0:Uint8Array,i2:"undefined"===typeof Int16Array?void 0:Int16Array,u2:"undefined"===typeof Uint16Array?void 0:Uint16Array,i4:"undefined"===typeof Int32Array?void 0:Int32Array,u4:"undefined"===typeof Uint32Array?void 0:Uint32Array,f4:"undefined"===typeof Float32Array?void 0:Float32Array,f8:"undefined"===typeof Float64Array?void 0:Float64Array};function d(e){return e.constructor===ArrayBuffer}function h(e,t,r){if(c(e)){if(c(e[0])){for(var n=r,i=0;i{"use strict";var n=r(22036),i=r(65004).BADNUM,o=/^['"%,$#\s']+|[, ]|['"%,$#\s']+$/g;e.exports=function(e){return"string"===typeof e&&(e=e.replace(o,"")),n(e)?Number(e):i}},76574:e=>{"use strict";e.exports=function(e){var t=e._fullLayout;t._glcanvas&&t._glcanvas.size()&&t._glcanvas.each((function(e){e.regl&&e.regl.clear({color:!0,depth:!0})}))}},36250:e=>{"use strict";e.exports=function(e){e._responsiveChartHandler&&(window.removeEventListener("resize",e._responsiveChartHandler),delete e._responsiveChartHandler)}},50347:(e,t,r)=>{"use strict";var n=r(22036),i=r(23498),o=r(64022).extendFlat,a=r(75622),s=r(28538),l=r(7605),c=r(64253).DESELECTDIM,u=r(46189),d=r(51195).counter,h=r(95260).modHalf,p=r(19045).isArrayOrTypedArray,f=r(19045).isTypedArraySpec,m=r(19045).decodeTypedArraySpec;function g(e,r){var n=t.valObjectMeta[r.valType];if(r.arrayOk&&p(e))return!0;if(n.validateFunction)return n.validateFunction(e,r);var i={},o=i,a={set:function(e){o=e}};return n.coerceFunction(e,a,i,r),o!==i}t.valObjectMeta={data_array:{description:["An {array} of data.","The value must represent an {array} or it will be ignored,","but this array can be provided in several forms:","(1) a regular {array} object","(2) a typed array (e.g. Float32Array)","(3) an object with keys dtype, bdata, and optionally shape.","In this 3rd form, dtype is one of","*f8*, *f4*.","*i4*, *u4*,","*i2*, *u2*,","*i1*, *u1* or *u1c* for Uint8ClampedArray.","In addition to shorthand `dtype` above one could also use the following forms:","*float64*, *float32*,","*int32*, *uint32*,","*int16*, *uint16*,","*int8*, *uint8* or *uint8c* for Uint8ClampedArray.","`bdata` is either a base64-encoded string or the ArrayBuffer of","an integer or float typed array.","For either multi-dimensional arrays you must also","provide its dimensions separated by comma via `shape`.","For example using `dtype`: *f4* and `shape`: *5,100* you can","declare a 2-D array that has 5 rows and 100 columns","containing float32 values i.e. 4 bits per value.","`shape` is optional for one dimensional arrays."].join(" "),requiredOpts:[],otherOpts:["dflt"],coerceFunction:function(e,t,r){t.set(p(e)?e:f(e)?m(e):r)}},enumerated:{description:["Enumerated value type. The available values are listed","in `values`."].join(" "),requiredOpts:["values"],otherOpts:["dflt","coerceNumber","arrayOk"],coerceFunction:function(e,t,r,n){n.coerceNumber&&(e=+e),-1===n.values.indexOf(e)?t.set(r):t.set(e)},validateFunction:function(e,t){t.coerceNumber&&(e=+e);for(var r=t.values,n=0;ni.max?t.set(r):t.set(+e)}},integer:{description:["An integer or an integer inside a string.","When applicable, values greater (less) than `max` (`min`)","are coerced to the `dflt`."].join(" "),requiredOpts:[],otherOpts:["dflt","min","max","arrayOk","extras"],coerceFunction:function(e,t,r,i){-1===(i.extras||[]).indexOf(e)?(f(e)&&(e=m(e)),e%1||!n(e)||void 0!==i.min&&ei.max?t.set(r):t.set(+e)):t.set(e)}},string:{description:["A string value.","Numbers are converted to strings except for attributes with","`strict` set to true."].join(" "),requiredOpts:[],otherOpts:["dflt","noBlank","strict","arrayOk","values"],coerceFunction:function(e,t,r,n){if("string"!==typeof e){var i="number"===typeof e;!0!==n.strict&&i?t.set(String(e)):t.set(r)}else n.noBlank&&!e?t.set(r):t.set(e)}},color:{description:["A string describing color.","Supported formats:","- hex (e.g. '#d3d3d3')","- rgb (e.g. 'rgb(255, 0, 0)')","- rgba (e.g. 'rgb(255, 0, 0, 0.5)')","- hsl (e.g. 'hsl(0, 100%, 50%)')","- hsv (e.g. 'hsv(0, 100%, 100%)')","- named colors (full list: http://www.w3.org/TR/css3-color/#svg-color)"].join(" "),requiredOpts:[],otherOpts:["dflt","arrayOk"],coerceFunction:function(e,t,r){f(e)&&(e=m(e)),i(e).isValid()?t.set(e):t.set(r)}},colorlist:{description:["A list of colors.","Must be an {array} containing valid colors."].join(" "),requiredOpts:[],otherOpts:["dflt"],coerceFunction:function(e,t,r){Array.isArray(e)&&e.length&&e.every((function(e){return i(e).isValid()}))?t.set(e):t.set(r)}},colorscale:{description:["A Plotly colorscale either picked by a name:","(any of",Object.keys(s.scales).join(", "),")","customized as an {array} of 2-element {arrays} where","the first element is the normalized color level value","(starting at *0* and ending at *1*),","and the second item is a valid color string."].join(" "),requiredOpts:[],otherOpts:["dflt"],coerceFunction:function(e,t,r){t.set(s.get(e,r))}},angle:{description:["A number (in degree) between -180 and 180."].join(" "),requiredOpts:[],otherOpts:["dflt","arrayOk"],coerceFunction:function(e,t,r){f(e)&&(e=m(e)),"auto"===e?t.set("auto"):n(e)?t.set(h(+e,360)):t.set(r)}},subplotid:{description:["An id string of a subplot type (given by dflt), optionally","followed by an integer >1. e.g. if dflt='geo', we can have","'geo', 'geo2', 'geo3', ..."].join(" "),requiredOpts:["dflt"],otherOpts:["regex"],coerceFunction:function(e,t,r,n){var i=n.regex||d(r);"string"===typeof e&&i.test(e)?t.set(e):t.set(r)},validateFunction:function(e,t){var r=t.dflt;return e===r||"string"===typeof e&&!!d(r).test(e)}},flaglist:{description:["A string representing a combination of flags","(order does not matter here).","Combine any of the available `flags` with *+*.","(e.g. ('lines+markers')).","Values in `extras` cannot be combined."].join(" "),requiredOpts:["flags"],otherOpts:["dflt","extras","arrayOk"],coerceFunction:function(e,t,r,n){if(-1===(n.extras||[]).indexOf(e))if("string"===typeof e){for(var i=e.split("+"),o=0;o{"use strict";var n,i,o=r(9212).DC,a=r(22036),s=r(98073),l=r(95260).mod,c=r(65004),u=c.BADNUM,d=c.ONEDAY,h=c.ONEHOUR,p=c.ONEMIN,f=c.ONESEC,m=c.EPOCHJD,g=r(38361),y=r(9212).aL,v=/^\s*(-?\d\d\d\d|\d\d)(-(\d?\d)(-(\d?\d)([ Tt]([01]?\d|2[0-3])(:([0-5]\d)(:([0-5]\d(\.\d+)?))?(Z|z|[+\-]\d\d(:?\d\d)?)?)?)?)?)?\s*$/m,x=/^\s*(-?\d\d\d\d|\d\d)(-(\d?\di?)(-(\d?\d)([ Tt]([01]?\d|2[0-3])(:([0-5]\d)(:([0-5]\d(\.\d+)?))?(Z|z|[+\-]\d\d(:?\d\d)?)?)?)?)?)?\s*$/m,b=(new Date).getFullYear()-70;function _(e){return e&&g.componentsRegistry.calendars&&"string"===typeof e&&"gregorian"!==e}function w(e,t){return String(e+Math.pow(10,t)).substr(1)}t.dateTick0=function(e,r){var n=function(e,t){return _(e)?t?g.getComponentMethod("calendars","CANONICAL_SUNDAY")[e]:g.getComponentMethod("calendars","CANONICAL_TICK")[e]:t?"2000-01-02":"2000-01-01"}(e,!!r);if(r<2)return n;var i=t.dateTime2ms(n,e);return i+=d*(r-1),t.ms2DateTime(i,0,e)},t.dfltRange=function(e){return _(e)?g.getComponentMethod("calendars","DFLTRANGE")[e]:["2000-01-01","2001-01-01"]},t.isJSDate=function(e){return"object"===typeof e&&null!==e&&"function"===typeof e.getTime},t.dateTime2ms=function(e,r){if(t.isJSDate(e)){var o=e.getTimezoneOffset()*p,a=(e.getUTCMinutes()-e.getMinutes())*p+(e.getUTCSeconds()-e.getSeconds())*f+(e.getUTCMilliseconds()-e.getMilliseconds());if(a){var s=3*p;o=o-s/2+l(a-o+s/2,s)}return(e=Number(e)-o)>=n&&e<=i?e:u}if("string"!==typeof e&&"number"!==typeof e)return u;e=String(e);var c=_(r),y=e.charAt(0);!c||"G"!==y&&"g"!==y||(e=e.substr(1),r="");var w=c&&"chinese"===r.substr(0,7),k=e.match(w?x:v);if(!k)return u;var S=k[1],A=k[3]||"1",T=Number(k[5]||1),M=Number(k[7]||0),C=Number(k[9]||0),E=Number(k[11]||0);if(c){if(2===S.length)return u;var I;S=Number(S);try{var P=g.getComponentMethod("calendars","getCal")(r);if(w){var O="i"===A.charAt(A.length-1);A=parseInt(A,10),I=P.newDate(S,P.toMonthIndex(S,A,O),T)}else I=P.newDate(S,Number(A),T)}catch(L){return u}return I?(I.toJD()-m)*d+M*h+C*p+E*f:u}S=2===S.length?(Number(S)+2e3-b)%100+b:Number(S),A-=1;var R=new Date(Date.UTC(2e3,A,T,M,C));return R.setUTCFullYear(S),R.getUTCMonth()!==A||R.getUTCDate()!==T?u:R.getTime()+E*f},n=t.MIN_MS=t.dateTime2ms("-9999"),i=t.MAX_MS=t.dateTime2ms("9999-12-31 23:59:59.9999"),t.isDateTime=function(e,r){return t.dateTime2ms(e,r)!==u};var k=90*d,S=3*h,A=5*p;function T(e,t,r,n,i){if((t||r||n||i)&&(e+=" "+w(t,2)+":"+w(r,2),(n||i)&&(e+=":"+w(n,2),i))){for(var o=4;i%10===0;)o-=1,i/=10;e+="."+w(i,o)}return e}t.ms2DateTime=function(e,t,r){if("number"!==typeof e||!(e>=n&&e<=i))return u;t||(t=0);var o,a,s,c,v,x,b=Math.floor(10*l(e+.05,1)),w=Math.round(e-b/10);if(_(r)){var M=Math.floor(w/d)+m,C=Math.floor(l(e,d));try{o=g.getComponentMethod("calendars","getCal")(r).fromJD(M).formatDate("yyyy-mm-dd")}catch(E){o=y("G%Y-%m-%d")(new Date(w))}if("-"===o.charAt(0))for(;o.length<11;)o="-0"+o.substr(1);else for(;o.length<10;)o="0"+o;a=t=n+d&&e<=i-d))return u;var t=Math.floor(10*l(e+.05,1)),r=new Date(Math.round(e-t/10));return T(o("%Y-%m-%d")(r),r.getHours(),r.getMinutes(),r.getSeconds(),10*r.getUTCMilliseconds()+t)},t.cleanDate=function(e,r,n){if(e===u)return r;if(t.isJSDate(e)||"number"===typeof e&&isFinite(e)){if(_(n))return s.error("JS Dates and milliseconds are incompatible with world calendars",e),r;if(!(e=t.ms2DateTimeLocal(+e))&&void 0!==r)return r}else if(!t.isDateTime(e,n))return s.error("unrecognized date",e),r;return e};var M=/%\d?f/g,C=/%h/g,E={1:"1",2:"1",3:"2",4:"2"};function I(e,t,r,n){e=e.replace(M,(function(e){var r=Math.min(+e.charAt(1)||6,6);return(t/1e3%1+2).toFixed(r).substr(2).replace(/0+$/,"")||"0"}));var i=new Date(Math.floor(t+.05));if(e=e.replace(C,(function(){return E[r("%q")(i)]})),_(n))try{e=g.getComponentMethod("calendars","worldCalFmt")(e,t,n)}catch(o){return"Invalid"}return r(e)(i)}var P=[59,59.9,59.99,59.999,59.9999];t.formatDate=function(e,t,r,n,i,o){if(i=_(i)&&i,!t)if("y"===r)t=o.year;else if("m"===r)t=o.month;else{if("d"!==r)return function(e,t){var r=l(e+.05,d),n=w(Math.floor(r/h),2)+":"+w(l(Math.floor(r/p),60),2);if("M"!==t){a(t)||(t=0);var i=(100+Math.min(l(e/f,60),P[t])).toFixed(t).substr(1);t>0&&(i=i.replace(/0+$/,"").replace(/[\.]$/,"")),n+=":"+i}return n}(e,r)+"\n"+I(o.dayMonthYear,e,n,i);t=o.dayMonth+"\n"+o.year}return I(t,e,n,i)};var O=3*d;t.incrementMonth=function(e,t,r){r=_(r)&&r;var n=l(e,d);if(e=Math.round(e-n),r)try{var i=Math.round(e/d)+m,o=g.getComponentMethod("calendars","getCal")(r),a=o.fromJD(i);return t%12?o.add(a,t,"m"):o.add(a,t/12,"y"),(a.toJD()-m)*d+n}catch(u){s.error("invalid ms "+e+" in calendar "+r)}var c=new Date(e+O);return c.setUTCMonth(c.getUTCMonth()+t)+n-O},t.findExactDates=function(e,t){for(var r,n,i=0,o=0,s=0,l=0,c=_(t)&&g.getComponentMethod("calendars","getCal")(t),u=0;u{"use strict";var n=r(41871),i=r(98073),o=r(69975),a=r(82588);function s(e){var t=e&&e.parentNode;t&&t.removeChild(e)}function l(e,t,r){var n="plotly.js-style-"+e,o=document.getElementById(n);o||((o=document.createElement("style")).setAttribute("id",n),o.appendChild(document.createTextNode("")),document.head.appendChild(o));var a=o.sheet;a.insertRule?a.insertRule(t+"{"+r+"}",0):a.addRule?a.addRule(t,r,0):i.warn("addStyleRule failed")}function c(e){var t=window.getComputedStyle(e,null),r=t.getPropertyValue("-webkit-transform")||t.getPropertyValue("-moz-transform")||t.getPropertyValue("-ms-transform")||t.getPropertyValue("-o-transform")||t.getPropertyValue("transform");return"none"===r?null:r.replace("matrix","").replace("3d","").slice(1,-1).split(",").map((function(e){return+e}))}function u(e){for(var t=[];d(e);)t.push(e),e=e.parentNode,"function"===typeof ShadowRoot&&e instanceof ShadowRoot&&(e=e.host);return t}function d(e){return e&&(e instanceof Element||e instanceof HTMLElement)}e.exports={getGraphDiv:function(e){var t;if("string"===typeof e){if(null===(t=document.getElementById(e)))throw new Error("No DOM element with id '"+e+"' exists on the page.");return t}if(null===e||void 0===e)throw new Error("DOM element provided is null or undefined");return e},isPlotDiv:function(e){var t=n.select(e);return t.node()instanceof HTMLElement&&t.size()&&t.classed("js-plotly-plot")},removeElement:s,addStyleRule:function(e,t){l("global",e,t)},addRelatedStyleRule:l,deleteRelatedStyleRule:function(e){var t="plotly.js-style-"+e,r=document.getElementById(t);r&&s(r)},getFullTransformMatrix:function(e){var t=u(e),r=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1];return t.forEach((function(e){var t=c(e);if(t){var n=o.convertCssMatrix(t);r=a.multiply(r,r,n)}})),r},getElementTransformMatrix:c,getElementAndAncestors:u,equalDomRects:function(e,t){return e&&t&&e.top===t.top&&e.left===t.left&&e.right===t.right&&e.bottom===t.bottom}}},13711:(e,t,r)=>{"use strict";var n=r(27284).EventEmitter,i={init:function(e){if(e._ev instanceof n)return e;var t=new n,r=new n;return e._ev=t,e._internalEv=r,e.on=t.on.bind(t),e.once=t.once.bind(t),e.removeListener=t.removeListener.bind(t),e.removeAllListeners=t.removeAllListeners.bind(t),e._internalOn=r.on.bind(r),e._internalOnce=r.once.bind(r),e._removeInternalListener=r.removeListener.bind(r),e._removeAllInternalListeners=r.removeAllListeners.bind(r),e.emit=function(n,i){"undefined"!==typeof jQuery&&jQuery(e).trigger(n,i),t.emit(n,i),r.emit(n,i)},e},triggerHandler:function(e,t,r){var n,i;"undefined"!==typeof jQuery&&(n=jQuery(e).triggerHandler(t,r));var o=e._ev;if(!o)return n;var a,s=o._events[t];if(!s)return n;function l(e){return e.listener?(o.removeListener(t,e.listener),e.fired?void 0:(e.fired=!0,e.listener.apply(o,[r]))):e.apply(o,[r])}for(s=Array.isArray(s)?s:[s],a=0;a{"use strict";var n=r(30167),i=Array.isArray;function o(e,t,r,a){var s,l,c,u,d,h,p,f=e[0],m=e.length;if(2===m&&i(f)&&i(e[1])&&0===f.length){if(p=function(e,t){var r,n;for(r=0;r{"use strict";e.exports=function(e){for(var t={},r=[],n=0,i=0;i{"use strict";function t(e){return!0===e.visible}function r(e){var t=e[0].trace;return!0===t.visible&&0!==t._length}e.exports=function(e){for(var n,i=(n=e,Array.isArray(n)&&Array.isArray(n[0])&&n[0][0]&&n[0][0].trace?r:t),o=[],a=0;a{"use strict";var n=r(41871),i=r(72384),{area:o}=r(96890),{centroid:a}=r(53799),{bbox:s}=r(83772),l=r(77892),c=r(98073),u=r(30167),d=r(46189),h=r(39926),p=Object.keys(i),f={"ISO-3":l,"USA-states":l,"country names":function(e){for(var t=0;t0&&e[t+1][0]<0)return t;return null}switch(t="RUS"===s||"FJI"===s?function(e){var t;if(null===c(e))t=e;else for(t=new Array(e.length),i=0;it?r[n++]=[e[i][0]+360,e[i][1]]:i===t?(r[n++]=e[i],r[n++]=[e[i][0],-90]):r[n++]=e[i];var o=h.tester(r);o.pts.pop(),l.push(o)}:function(e){l.push(h.tester(e))},o.type){case"MultiPolygon":for(r=0;r0?u.properties.ct=function(e){var t,r=e.geometry;if("MultiPolygon"===r.type)for(var n=r.coordinates,i=0,s=0;si&&(i=c,t=l)}else t=r;return a(t).geometry.coordinates}(u):u.properties.ct=[NaN,NaN],n.fIn=e,n.fOut=u,s.push(u)}else c.log(["Location",n.loc,"does not have a valid GeoJSON geometry.","Traces with locationmode *geojson-id* only support","*Polygon* and *MultiPolygon* geometries."].join(" "))}delete i[r]}switch(r.type){case"FeatureCollection":var h=r.features;for(n=0;n100?(clearInterval(o),n("Unexpected error while fetching from "+e)):void i++}),50)}))}for(var a=0;a{"use strict";var n=r(65004).BADNUM;t.calcTraceToLineCoords=function(e){for(var t=e[0].trace.connectgaps,r=[],i=[],o=0;o0&&(r.push(i),i=[])}return i.length>0&&r.push(i),r},t.makeLine=function(e){return 1===e.length?{type:"LineString",coordinates:e[0]}:{type:"MultiLineString",coordinates:e}},t.makePolygon=function(e){if(1===e.length)return{type:"Polygon",coordinates:e};for(var t=new Array(e.length),r=0;r{"use strict";var n,i,o,a=r(95260).mod;function s(e,t,r,n,i,o,a,s){var l=r-e,c=i-e,u=a-i,d=n-t,h=o-t,p=s-o,f=l*p-u*d;if(0===f)return null;var m=(c*p-u*h)/f,g=(c*d-l*h)/f;return g<0||g>1||m<0||m>1?null:{x:e+l*m,y:t+d*m}}function l(e,t,r,n,i){var o=n*e+i*t;if(o<0)return n*n+i*i;if(o>r){var a=n-e,s=i-t;return a*a+s*s}var l=n*t-i*e;return l*l/r}t.segmentsIntersect=s,t.segmentDistance=function(e,t,r,n,i,o,a,c){if(s(e,t,r,n,i,o,a,c))return 0;var u=r-e,d=n-t,h=a-i,p=c-o,f=u*u+d*d,m=h*h+p*p,g=Math.min(l(u,d,f,i-e,o-t),l(u,d,f,a-e,c-t),l(h,p,m,e-i,t-o),l(h,p,m,r-i,n-o));return Math.sqrt(g)},t.getTextLocation=function(e,t,r,s){if(e===i&&s===o||(n={},i=e,o=s),n[r])return n[r];var l=e.getPointAtLength(a(r-s/2,t)),c=e.getPointAtLength(a(r+s/2,t)),u=Math.atan((c.y-l.y)/(c.x-l.x)),d=e.getPointAtLength(a(r,t)),h={x:(4*d.x+l.x+c.x)/6,y:(4*d.y+l.y+c.y)/6,theta:u};return n[r]=h,h},t.clearLocationCache=function(){i=null},t.getVisibleSegment=function(e,t,r){var n,i,o=t.left,a=t.right,s=t.top,l=t.bottom,c=0,u=e.getTotalLength(),d=u;function h(t){var r=e.getPointAtLength(t);0===t?n=r:t===u&&(i=r);var c=r.xa?r.x-a:0,d=r.yl?r.y-l:0;return Math.sqrt(c*c+d*d)}for(var p=h(c);p;){if((c+=p+r)>d)return;p=h(c)}for(p=h(d);p;){if(c>(d-=p+r))return;p=h(d)}return{min:c,max:d,len:d-c,total:u,isClosed:0===c&&d===u&&Math.abs(n.x-i.x)<.1&&Math.abs(n.y-i.y)<.1}},t.findPointOnPath=function(e,t,r,n){for(var i,o,a,s=(n=n||{}).pathLength||e.getTotalLength(),l=n.tolerance||.001,c=n.iterationLimit||30,u=e.getPointAtLength(0)[r]>e.getPointAtLength(s)[r]?-1:1,d=0,h=0,p=s;d0?p=i:h=i,d++}return o}},23207:(e,t,r)=>{"use strict";var n=r(22036),i=r(23498),o=r(49866),a=r(39265),s=r(17992).defaultLine,l=r(19045).isArrayOrTypedArray,c=o(s);function u(e,t){var r=e;return r[3]*=t,r}function d(e){if(n(e))return c;var t=o(e);return t.length?t:c}function h(e){return n(e)?e:1}e.exports={formatColor:function(e,t,r){var n=e.color;n&&n._inputArray&&(n=n._inputArray);var i,s,p,f,m,g=l(n),y=l(t),v=a.extractOpts(e),x=[];if(i=void 0!==v.colorscale?a.makeColorScaleFuncFromTrace(e):d,s=g?function(e,t){return void 0===e[t]?c:o(i(e[t]))}:d,p=y?function(e,t){return void 0===e[t]?1:h(e[t])}:h,g||y)for(var b=0;b{"use strict";var n=r(77892);function i(e){return[e]}e.exports={keyFun:function(e){return e.key},repeat:i,descend:n,wrap:i,unwrap:function(e){return e[0]}}},77892:e=>{"use strict";e.exports=function(e){return e}},40461:e=>{"use strict";e.exports=function(e,t){if(!t)return e;var r=1/Math.abs(t),n=r>1?(r*e+r*t)/r:e+t,i=String(n).length;if(i>16){var o=String(t).length;if(i>=String(e).length+o){var a=parseFloat(n).toPrecision(12);-1===a.indexOf("e+")&&(n=+a)}}return n}},84468:(e,t,r)=>{"use strict";var n=r(41871),i=r(9212).aL,o=r(80902).GP,a=r(22036),s=r(65004),l=s.FP_SAFE,c=-l,u=s.BADNUM,d=e.exports={};d.adjustFormat=function(e){return!e||/^\d[.]\df/.test(e)||/[.]\d%/.test(e)?e:"0.f"===e?"~f":/^\d%/.test(e)?"~%":/^\ds/.test(e)?"~s":!/^[~,.0$]/.test(e)&&/[&fps]/.test(e)?"~"+e:e};var h={};d.warnBadFormat=function(e){var t=String(e);h[t]||(h[t]=1,d.warn('encountered bad format: "'+t+'"'))},d.noFormat=function(e){return String(e)},d.numberFormat=function(e){var t;try{t=o(d.adjustFormat(e))}catch(r){return d.warnBadFormat(e),d.noFormat}return t},d.nestedProperty=r(46189),d.keyedContainer=r(30010),d.relativeAttr=r(99290),d.isPlainObject=r(30167),d.toLogRange=r(46396),d.relinkPrivateKeys=r(60143);var p=r(19045);d.isArrayBuffer=p.isArrayBuffer,d.isTypedArray=p.isTypedArray,d.isArrayOrTypedArray=p.isArrayOrTypedArray,d.isArray1D=p.isArray1D,d.ensureArray=p.ensureArray,d.concat=p.concat,d.maxRowLength=p.maxRowLength,d.minRowLength=p.minRowLength;var f=r(95260);d.mod=f.mod,d.modHalf=f.modHalf;var m=r(50347);d.valObjectMeta=m.valObjectMeta,d.coerce=m.coerce,d.coerce2=m.coerce2,d.coerceFont=m.coerceFont,d.coercePattern=m.coercePattern,d.coerceHoverinfo=m.coerceHoverinfo,d.coerceSelectionMarkerOpacity=m.coerceSelectionMarkerOpacity,d.validate=m.validate;var g=r(78765);d.dateTime2ms=g.dateTime2ms,d.isDateTime=g.isDateTime,d.ms2DateTime=g.ms2DateTime,d.ms2DateTimeLocal=g.ms2DateTimeLocal,d.cleanDate=g.cleanDate,d.isJSDate=g.isJSDate,d.formatDate=g.formatDate,d.incrementMonth=g.incrementMonth,d.dateTick0=g.dateTick0,d.dfltRange=g.dfltRange,d.findExactDates=g.findExactDates,d.MIN_MS=g.MIN_MS,d.MAX_MS=g.MAX_MS;var y=r(41222);d.findBin=y.findBin,d.sorterAsc=y.sorterAsc,d.sorterDes=y.sorterDes,d.distinctVals=y.distinctVals,d.roundUp=y.roundUp,d.sort=y.sort,d.findIndexOfMin=y.findIndexOfMin,d.sortObjectKeys=r(60693);var v=r(26423);d.aggNums=v.aggNums,d.len=v.len,d.mean=v.mean,d.geometricMean=v.geometricMean,d.median=v.median,d.midRange=v.midRange,d.variance=v.variance,d.stdev=v.stdev,d.interp=v.interp;var x=r(69975);d.init2dArray=x.init2dArray,d.transposeRagged=x.transposeRagged,d.dot=x.dot,d.translationMatrix=x.translationMatrix,d.rotationMatrix=x.rotationMatrix,d.rotationXYMatrix=x.rotationXYMatrix,d.apply3DTransform=x.apply3DTransform,d.apply2DTransform=x.apply2DTransform,d.apply2DTransform2=x.apply2DTransform2,d.convertCssMatrix=x.convertCssMatrix,d.inverseTransformMatrix=x.inverseTransformMatrix;var b=r(32510);d.deg2rad=b.deg2rad,d.rad2deg=b.rad2deg,d.angleDelta=b.angleDelta,d.angleDist=b.angleDist,d.isFullCircle=b.isFullCircle,d.isAngleInsideSector=b.isAngleInsideSector,d.isPtInsideSector=b.isPtInsideSector,d.pathArc=b.pathArc,d.pathSector=b.pathSector,d.pathAnnulus=b.pathAnnulus;var _=r(49553);d.isLeftAnchor=_.isLeftAnchor,d.isCenterAnchor=_.isCenterAnchor,d.isRightAnchor=_.isRightAnchor,d.isTopAnchor=_.isTopAnchor,d.isMiddleAnchor=_.isMiddleAnchor,d.isBottomAnchor=_.isBottomAnchor;var w=r(15624);d.segmentsIntersect=w.segmentsIntersect,d.segmentDistance=w.segmentDistance,d.getTextLocation=w.getTextLocation,d.clearLocationCache=w.clearLocationCache,d.getVisibleSegment=w.getVisibleSegment,d.findPointOnPath=w.findPointOnPath;var k=r(64022);d.extendFlat=k.extendFlat,d.extendDeep=k.extendDeep,d.extendDeepAll=k.extendDeepAll,d.extendDeepNoArrays=k.extendDeepNoArrays;var S=r(98073);d.log=S.log,d.warn=S.warn,d.error=S.error;var A=r(51195);d.counterRegex=A.counter;var T=r(95938);d.throttle=T.throttle,d.throttleDone=T.done,d.clearThrottle=T.clear;var M=r(51124);function C(e){var t={};for(var r in e)for(var n=e[r],i=0;il||e=t)&&(a(e)&&e>=0&&e%1===0)},d.noop=r(17266),d.identity=r(77892),d.repeat=function(e,t){for(var r=new Array(t),n=0;nr?Math.max(r,Math.min(t,e)):Math.max(t,Math.min(r,e))},d.bBoxIntersect=function(e,t,r){return r=r||0,e.left<=t.right+r&&t.left<=e.right+r&&e.top<=t.bottom+r&&t.top<=e.bottom+r},d.simpleMap=function(e,t,r,n,i){for(var o=e.length,a=new Array(o),s=0;s=Math.pow(2,r)?i>10?(d.warn("randstr failed uniqueness"),l):e(t,r,n,(i||0)+1):l},d.OptionControl=function(e,t){e||(e={}),t||(t="opt");var r={optionList:[],_newoption:function(n){n[t]=e,r[n.name]=n,r.optionList.push(n)}};return r["_"+t]=e,r},d.smooth=function(e,t){if((t=Math.round(t)||0)<2)return e;var r,n,i,o,a=e.length,s=2*a,l=2*t-1,c=new Array(l),u=new Array(a);for(r=0;r=s&&(i-=s*Math.floor(i/s)),i<0?i=-1-i:i>=a&&(i=s-1-i),o+=e[i]*c[n];u[r]=o}return u},d.syncOrAsync=function(e,t,r){var n;function i(){return d.syncOrAsync(e,t,r)}for(;e.length;)if((n=(0,e.splice(0,1)[0])(t))&&n.then)return n.then(i);return r&&r(t)},d.stripTrailingSlash=function(e){return"/"===e.substr(-1)?e.substr(0,e.length-1):e},d.noneOrAll=function(e,t,r){if(e){var n,i,o=!1,a=!0;for(n=0;n0?t:0}))},d.fillArray=function(e,t,r,n){if(n=n||d.identity,d.isArrayOrTypedArray(e))for(var i=0;i1?i+a[1]:"";if(o&&(a.length>1||s.length>4||r))for(;n.test(s);)s=s.replace(n,"$1"+o+"$2");return s+l},d.TEMPLATE_STRING_REGEX=/%{([^\s%{}:]*)([:|\|][^}]*)?}/g;var D=/^\w*$/;d.templateString=function(e,t){var r={};return e.replace(d.TEMPLATE_STRING_REGEX,(function(e,n){var i;return D.test(n)?i=t[n]:(r[n]=r[n]||d.nestedProperty(t,n).get,i=r[n]()),d.isValidTextValue(i)?i:""}))};var z={max:10,count:0,name:"hovertemplate"};d.hovertemplateString=function(){return V.apply(z,arguments)};var j={max:10,count:0,name:"texttemplate"};d.texttemplateString=function(){return V.apply(j,arguments)};var F=/^(\S+)([\*\/])(-?\d+(\.\d+)?)$/;var N={max:10,count:0,name:"texttemplate",parseMultDiv:!0};d.texttemplateStringForShapes=function(){return V.apply(N,arguments)};var B=/^[:|\|]/;function V(e,t,r){var n=this,o=arguments;t||(t={});var a={};return e.replace(d.TEMPLATE_STRING_REGEX,(function(e,s,l){var c="_xother"===s||"_yother"===s,u="_xother_"===s||"_yother_"===s,h="xother_"===s||"yother_"===s,p="xother"===s||"yother"===s||c||h||u,f=s;(c||u)&&(f=f.substring(1)),(h||u)&&(f=f.substring(0,f.length-1));var m,g,y,v=null,x=null;if(n.parseMultDiv){var b=function(e){var t=e.match(F);return t?{key:t[1],op:t[2],number:Number(t[3])}:{key:e,op:null,number:null}}(f);f=b.key,v=b.op,x=b.number}if(p){if(void 0===(m=t[f]))return""}else for(y=3;y=48&&a<=57,c=s>=48&&s<=57;if(l&&(n=10*n+a-48),c&&(i=10*i+s-48),!l||!c){if(n!==i)return n-i;if(a!==s)return a-s}}return i-n};var U=2e9;d.seedPseudoRandom=function(){U=2e9},d.pseudoRandom=function(){var e=U;return U=(69069*U+1)%4294967296,Math.abs(U-e)<429496729?d.pseudoRandom():U/4294967296},d.fillText=function(e,t,r){var n=Array.isArray(r)?function(e){r.push(e)}:function(e){r.text=e},i=d.extractOption(e,t,"htx","hovertext");if(d.isValidTextValue(i))return n(i);var o=d.extractOption(e,t,"tx","text");return d.isValidTextValue(o)?n(o):void 0},d.isValidTextValue=function(e){return e||0===e},d.formatPercent=function(e,t){t=t||0;for(var r=(Math.round(100*e*Math.pow(10,t))*Math.pow(.1,t)).toFixed(t)+"%",n=0;n1&&(c=1):c=0,d.strTranslate(i-c*(r+a),o-c*(n+s))+d.strScale(c)+(l?"rotate("+l+(t?"":" "+r+" "+n)+")":"")},d.setTransormAndDisplay=function(e,t){e.attr("transform",d.getTextTransform(t)),e.style("display",t.scale?null:"none")},d.ensureUniformFontSize=function(e,t){var r=d.extendFlat({},t);return r.size=Math.max(t.size,e._fullLayout.uniformtext.minsize||0),r},d.join2=function(e,t,r){var n=e.length;return n>1?e.slice(0,-1).join(t)+r+e[n-1]:e.join(t)},d.bigFont=function(e){return Math.round(1.2*e)};var H=d.getFirefoxVersion(),$=null!==H&&H<86;d.getPositionFromD3Event=function(){return $?[n.event.layerX,n.event.layerY]:[n.event.offsetX,n.event.offsetY]}},30167:e=>{"use strict";e.exports=function(e){return window&&window.process&&window.process.versions?"[object Object]"===Object.prototype.toString.call(e):"[object Object]"===Object.prototype.toString.call(e)&&Object.getPrototypeOf(e).hasOwnProperty("hasOwnProperty")}},30010:(e,t,r)=>{"use strict";var n=r(46189),i=/^\w*$/;e.exports=function(e,t,r,o){var a,s,l;r=r||"name",o=o||"value";var c={};t&&t.length?(l=n(e,t),s=l.get()):s=e,t=t||"";var u={};if(s)for(a=0;a2)return c[t]=2|c[t],h.set(e,null);if(d){for(a=t;a{"use strict";var n=r(38361);e.exports=function(e,t){for(var r=e._context.locale,i=0;i<2;i++){for(var o=e._context.locales,a=0;a<2;a++){var s=(o[r]||{}).dictionary;if(s){var l=s[t];if(l)return l}o=n.localeRegistry}var c=r.split("-")[0];if(c===r)break;r=c}return t}},98073:(e,t,r)=>{"use strict";var n=r(20075).dfltConfig,i=r(55684),o=e.exports={};o.log=function(){var e;if(n.logging>1){var t=["LOG:"];for(e=0;e1){var r=[];for(e=0;e"),"long")}},o.warn=function(){var e;if(n.logging>0){var t=["WARN:"];for(e=0;e0){var r=[];for(e=0;e"),"stick")}},o.error=function(){var e;if(n.logging>0){var t=["ERROR:"];for(e=0;e0){var r=[];for(e=0;e"),"stick")}}},1849:(e,t,r)=>{"use strict";var n=r(41871);e.exports=function(e,t,r){var i=e.selectAll("g."+r.replace(/\s/g,".")).data(t,(function(e){return e[0].trace.uid}));i.exit().remove(),i.enter().append("g").attr("class",r),i.order();var o=e.classed("rangeplot")?"nodeRangePlot3":"node3";return i.each((function(e){e[0][o]=n.select(this)})),i}},69975:(e,t,r)=>{"use strict";var n=r(82588);t.init2dArray=function(e,t){for(var r=new Array(e),n=0;n{"use strict";e.exports={mod:function(e,t){var r=e%t;return r<0?r+t:r},modHalf:function(e,t){return Math.abs(e)>t/2?e-Math.round(e/t)*t:e}}},46189:(e,t,r)=>{"use strict";var n=r(22036),i=r(19045).isArrayOrTypedArray;function o(e,t){return function(){var r,n,a,s,l,c=e;for(s=0;s{"use strict";e.exports=function(){}},55684:(e,t,r)=>{"use strict";var n=r(41871),i=r(22036),o=[];e.exports=function(e,t){if(-1===o.indexOf(e)){o.push(e);var r=1e3;i(t)?r=t:"long"===t&&(r=3e3);var a=n.select("body").selectAll(".plotly-notifier").data([0]);a.enter().append("div").classed("plotly-notifier",!0),a.selectAll(".notifier-note").data(o).enter().append("div").classed("notifier-note",!0).style("opacity",0).each((function(e){var i=n.select(this);i.append("button").classed("notifier-close",!0).html("×").on("click",(function(){i.transition().call(s)}));for(var o=i.append("p"),a=e.split(//g),l=0;l{"use strict";var n=r(29454),i="data-savedcursor";e.exports=function(e,t){var r=e.attr(i);if(t){if(!r){for(var o=(e.attr("class")||"").split(" "),a=0;a{"use strict";var n=r(69975).dot,i=r(65004).BADNUM,o=e.exports={};o.tester=function(e){var t,r=e.slice(),n=r[0][0],o=n,a=r[0][1],s=a;for(r[r.length-1][0]===r[0][0]&&r[r.length-1][1]===r[0][1]||r.push(r[0]),t=1;to||c===i||cs)&&(!t||!l(e))}:function(e,t){var l=e[0],c=e[1];if(l===i||lo||c===i||cs)return!1;var u,d,h,p,f,m=r.length,g=r[0][0],y=r[0][1],v=0;for(u=1;uMath.max(d,g)||c>Math.max(h,y)))if(cu||Math.abs(n(a,h))>i)return!0;return!1},o.filter=function(e,t){var r=[e[0]],n=0,i=0;function a(a){e.push(a);var s=r.length,l=n;r.splice(i+1);for(var c=l+1;c1&&a(e.pop());return{addPt:a,raw:e,filtered:r}}},48488:(e,t,r)=>{"use strict";var n=r(27849),i=r(32575);e.exports=function(e,t,o){var a=e._fullLayout,s=!0;return a._glcanvas.each((function(n){if(n.regl)n.regl.preloadCachedCode(o);else if(!n.pick||a._has("parcoords")){try{n.regl=i({canvas:this,attributes:{antialias:!n.pick,preserveDrawingBuffer:!0},pixelRatio:e._context.plotGlPixelRatio||r.g.devicePixelRatio,extensions:t||[],cachedCode:o||{}})}catch(l){s=!1}n.regl||(s=!1),s&&this.addEventListener("webglcontextlost",(function(t){e&&e.emit&&e.emit("plotly_webglcontextlost",{event:t,layer:n.key})}),!1)}})),s||n({container:a._glcontainer.node()}),s}},23136:(e,t,r)=>{"use strict";var n=r(22036),i=r(94561);e.exports=function(e){var t;if("string"!==typeof(t=e&&e.hasOwnProperty("userAgent")?e.userAgent:function(){var e;"undefined"!==typeof navigator&&(e=navigator.userAgent);e&&e.headers&&"string"===typeof e.headers["user-agent"]&&(e=e.headers["user-agent"]);return e}()))return!0;var r=i({ua:{headers:{"user-agent":t}},tablet:!0,featureDetect:!1});if(!r)for(var o=t.split(" "),a=1;a-1;s--){var l=o[s];if("Version/"===l.substr(0,8)){var c=l.substr(8).split(".")[0];if(n(c)&&(c=+c),c>=13)return!0}}}return r}},52942:e=>{"use strict";e.exports=function(e,t){if(t instanceof RegExp){for(var r=t.toString(),n=0;n{"use strict";var n=r(84468),i=r(20075).dfltConfig;var o={add:function(e,t,r,n,o){var a,s;e.undoQueue=e.undoQueue||{index:0,queue:[],sequence:!1},s=e.undoQueue.index,e.autoplay?e.undoQueue.inSequence||(e.autoplay=!1):(!e.undoQueue.sequence||e.undoQueue.beginSequence?(a={undo:{calls:[],args:[]},redo:{calls:[],args:[]}},e.undoQueue.queue.splice(s,e.undoQueue.queue.length-s,a),e.undoQueue.index+=1):a=e.undoQueue.queue[s-1],e.undoQueue.beginSequence=!1,a&&(a.undo.calls.unshift(t),a.undo.args.unshift(r),a.redo.calls.push(n),a.redo.args.push(o)),e.undoQueue.queue.length>i.queueLength&&(e.undoQueue.queue.shift(),e.undoQueue.index--))},startSequence:function(e){e.undoQueue=e.undoQueue||{index:0,queue:[],sequence:!1},e.undoQueue.sequence=!0,e.undoQueue.beginSequence=!0},stopSequence:function(e){e.undoQueue=e.undoQueue||{index:0,queue:[],sequence:!1},e.undoQueue.sequence=!1,e.undoQueue.beginSequence=!1},undo:function(e){var t,r;if(!(void 0===e.undoQueue||isNaN(e.undoQueue.index)||e.undoQueue.index<=0)){for(e.undoQueue.index--,t=e.undoQueue.queue[e.undoQueue.index],e.undoQueue.inSequence=!0,r=0;r=e.undoQueue.queue.length)){for(t=e.undoQueue.queue[e.undoQueue.index],e.undoQueue.inSequence=!0,r=0;r{"use strict";t.counter=function(e,t,r,n){var i=(t||"")+(r?"":"$"),o=!1===n?"":"^";return"xy"===e?new RegExp(o+"x([2-9]|[1-9][0-9]+)?y([2-9]|[1-9][0-9]+)?"+i):new RegExp(o+e+"([2-9]|[1-9][0-9]+)?"+i)}},99290:e=>{"use strict";var t=/^(.*)(\.[^\.\[\]]+|\[\d\])$/,r=/^[^\.\[\]]+$/;e.exports=function(e,n){for(;n;){var i=e.match(t);if(i)e=i[1];else{if(!e.match(r))throw new Error("bad relativeAttr call:"+[e,n]);e=""}if("^"!==n.charAt(0))break;n=n.slice(1)}return e&&"["!==n.charAt(0)?e+"."+n:e+n}},60143:(e,t,r)=>{"use strict";var n=r(19045).isArrayOrTypedArray,i=r(30167);e.exports=function e(t,r){for(var o in r){var a=r[o],s=t[o];if(s!==a)if("_"===o.charAt(0)||"function"===typeof a){if(o in t)continue;t[o]=a}else if(n(a)&&n(s)&&i(a[0])){if("customdata"===o||"ids"===o)continue;for(var l=Math.min(a.length,s.length),c=0;c{"use strict";var n=r(22036),i=r(98073),o=r(77892),a=r(65004).BADNUM,s=1e-9;function l(e,t){return et}function d(e,t){return e>=t}t.findBin=function(e,t,r){if(n(t.start))return r?Math.ceil((e-t.start)/t.size-s)-1:Math.floor((e-t.start)/t.size+s);var o,a,h=0,p=t.length,f=0,m=p>1?(t[p-1]-t[0])/(p-1):1;for(a=m>=0?r?l:c:r?d:u,e+=m*s*(r?-1:1)*(m>=0?1:-1);h90&&i.log("Long binary search..."),h-1},t.sorterAsc=function(e,t){return e-t},t.sorterDes=function(e,t){return t-e},t.distinctVals=function(e){var r,n=e.slice();for(n.sort(t.sorterAsc),r=n.length-1;r>-1&&n[r]===a;r--);for(var i,o=n[r]-n[0]||1,s=o/(r||1)/1e4,l=[],c=0;c<=r;c++){var u=n[c],d=u-i;void 0===i?(l.push(u),i=u):d>s&&(o=Math.min(o,d),l.push(u),i=u)}return{vals:l,minDiff:o}},t.roundUp=function(e,t,r){for(var n,i=0,o=t.length-1,a=0,s=r?0:1,l=r?1:0,c=r?Math.ceil:Math.floor;i0&&(n=1),r&&n)return e.sort(t)}return n?e:e.reverse()},t.findIndexOfMin=function(e,t){t=t||o;for(var r,n=1/0,i=0;i{"use strict";e.exports=function(e,t){(e.attr("class")||"").split(" ").forEach((function(t){0===t.indexOf("cursor-")&&e.classed(t,!1)})),t&&e.classed("cursor-"+t,!0)}},27849:(e,t,r)=>{"use strict";var n=r(7605),i=function(){};e.exports=function(e){for(var t in e)"function"===typeof e[t]&&(e[t]=i);e.destroy=function(){e.container.parentNode.removeChild(e.container)};var r=document.createElement("div");r.className="no-webgl",r.style.cursor="pointer",r.style.fontSize="24px",r.style.color=n.defaults[0],r.style.position="absolute",r.style.left=r.style.top="0px",r.style.width=r.style.height="100%",r.style["background-color"]=n.lightLine,r.style["z-index"]=30;var o=document.createElement("p");return o.textContent="WebGL is not supported by your browser - visit https://get.webgl.org for more info",o.style.position="relative",o.style.top="50%",o.style.left="50%",o.style.height="30%",o.style.width="50%",o.style.margin="-15% 0 0 -25%",r.appendChild(o),e.container.appendChild(r),e.container.style.background="#FFFFFF",e.container.onclick=function(){window.open("https://get.webgl.org")},!1}},60693:e=>{"use strict";e.exports=function(e){return Object.keys(e).sort()}},26423:(e,t,r)=>{"use strict";var n=r(22036),i=r(19045).isArrayOrTypedArray;t.aggNums=function(e,r,o,a){var s,l;if((!a||a>o.length)&&(a=o.length),n(r)||(r=!1),i(o[0])){for(l=new Array(a),s=0;se.length-1)return e[e.length-1];var r=t%1;return r*e[Math.ceil(t)]+(1-r)*e[Math.floor(t)]}},79689:(e,t,r)=>{"use strict";var n=r(49866);e.exports=function(e){return e?n(e):[0,0,0,1]}},77775:(e,t,r)=>{"use strict";var n=r(44740),i=r(3172),o=r(84468),a=null;e.exports=function(){if(null!==a)return a;a=!1;var e=o.isIE()||o.isSafari()||o.isIOS();if(window.navigator.userAgent&&!e){var t=Array.from(n.CSS_DECLARATIONS).reverse(),r=window.CSS&&window.CSS.supports||window.supportsCSS;if("function"===typeof r)a=t.some((function(e){return r.apply(null,e)}));else{var s=i.tester.append("image").attr("style",n.STYLE),l=window.getComputedStyle(s.node()).imageRendering;a=t.some((function(e){var t=e[1];return l===t||l===t.toLowerCase()})),s.remove()}}return a}},13480:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468),o=i.strTranslate,a=r(28795),s=r(83943).LINE_SPACING,l=/([^$]*)([$]+[^$]*[$]+)([^$]*)/;t.convertToTspans=function(e,r,g){var M=e.text(),C=!e.attr("data-notex")&&r&&r._context.typesetMath&&"undefined"!==typeof MathJax&&M.match(l),P=n.select(e.node().parentNode);if(!P.empty()){var O=e.attr("class")?e.attr("class").split(" ")[0]:"text";return O+="-math",P.selectAll("svg."+O).remove(),P.selectAll("g."+O+"-group").remove(),e.style("display",null).attr({"data-unformatted":M,"data-math":"N"}),C?(r&&r._promises||[]).push(new Promise((function(t){e.style("display","none");var r=parseInt(e.node().style.fontSize,10),a={fontSize:r};!function(e,t,r){var o,a,s,l,h=parseInt((MathJax.version||"").split(".")[0]);if(2!==h&&3!==h)return void i.warn("No MathJax version:",MathJax.version);var p=function(){return a=i.extendDeepAll({},MathJax.Hub.config),s=MathJax.Hub.processSectionDelay,void 0!==MathJax.Hub.processSectionDelay&&(MathJax.Hub.processSectionDelay=0),MathJax.Hub.Config({messageStyle:"none",tex2jax:{inlineMath:d},displayAlign:"left"})},f=function(){a=i.extendDeepAll({},MathJax.config),MathJax.config.tex||(MathJax.config.tex={}),MathJax.config.tex.inlineMath=d},m=function(){if("SVG"!==(o=MathJax.Hub.config.menuSettings.renderer))return MathJax.Hub.setRenderer("SVG")},g=function(){"svg"!==(o=MathJax.config.startup.output)&&(MathJax.config.startup.output="svg")},y=function(){var r="math-output-"+i.randstr({},64),o=(l=n.select("body").append("div").attr({id:r}).style({visibility:"hidden",position:"absolute","font-size":t.fontSize+"px"}).text(e.replace(c,"\\lt ").replace(u,"\\gt "))).node();return 2===h?MathJax.Hub.Typeset(o):MathJax.typeset([o])},v=function(){var t=l.select(2===h?".MathJax_SVG":".MathJax"),o=!t.empty()&&l.select("svg").node();if(o){var a,s=o.getBoundingClientRect();a=2===h?n.select("body").select("#MathJax_SVG_glyphs"):t.select("defs"),r(t,a,s)}else i.log("There was an error in the tex syntax.",e),r();l.remove()},x=function(){if("SVG"!==o)return MathJax.Hub.setRenderer(o)},b=function(){"svg"!==o&&(MathJax.config.startup.output=o)},_=function(){return void 0!==s&&(MathJax.Hub.processSectionDelay=s),MathJax.Hub.Config(a)},w=function(){MathJax.config=a};2===h?MathJax.Hub.Queue(p,m,y,v,x,_):3===h&&(f(),g(),MathJax.startup.defaultReady(),MathJax.startup.promise.then((function(){y(),v(),b(),w()})))}(C[2],a,(function(n,i,a){P.selectAll("svg."+O).remove(),P.selectAll("g."+O+"-group").remove();var s=n&&n.select("svg");if(!s||!s.node())return R(),void t();var l=P.append("g").classed(O+"-group",!0).attr({"pointer-events":"none","data-unformatted":M,"data-math":"Y"});l.node().appendChild(s.node()),i&&i.node()&&s.node().insertBefore(i.node().cloneNode(!0),s.node().firstChild);var c=a.width,u=a.height;s.attr({class:O,height:u,preserveAspectRatio:"xMinYMin meet"}).style({overflow:"visible","pointer-events":"none"});var d=e.node().style.fill||"black",h=s.select("g");h.attr({fill:d,stroke:d});var p=h.node().getBoundingClientRect(),f=p.width,m=p.height;(f>c||m>u)&&(s.style("overflow","hidden"),f=(p=s.node().getBoundingClientRect()).width,m=p.height);var y=+e.attr("x"),v=+e.attr("y"),x=-(r||e.node().getBoundingClientRect().height)/4;if("y"===O[0])l.attr({transform:"rotate("+[-90,y,v]+")"+o(-f/2,x-m/2)});else if("l"===O[0])v=x-m/2;else if("a"===O[0]&&0!==O.indexOf("atitle"))y=0,v=x;else{var b=e.attr("text-anchor");y-=f*("middle"===b?.5:"end"===b?1:0),v=v+x-m/2}s.attr({x:y,y:v}),g&&g.call(e,l),t(l)}))}))):R(),e}function R(){P.empty()||(O=e.attr("class")+"-math",P.select("svg."+O).remove()),e.text("").style("white-space","pre");var r=function(e,t){t=t.replace(y," ");var r,o=!1,l=[],c=-1;function u(){c++;var t=document.createElementNS(a.svg,"tspan");n.select(t).attr({class:"line",dy:c*s+"em"}),e.appendChild(t),r=t;var i=l;if(l=[{node:t}],i.length>1)for(var o=1;o doesnt match end tag <"+e+">. Pretending it did match.",t),r=l[l.length-1].node}else i.log("Ignoring unexpected end tag .",t)}var C=b.test(t);C?u():(r=e,l=[{node:e}]);for(var P=t.split(v),O=0;O|>|>)/g;var d=[["$","$"],["\\(","\\)"]];var h={sup:"font-size:70%",sub:"font-size:70%",s:"text-decoration:line-through",u:"text-decoration:underline",b:"font-weight:bold",i:"font-style:italic",a:"cursor:pointer",span:"",em:"font-style:italic;font-weight:bold"},p={sub:"0.3em",sup:"-0.6em"},f={sub:"-0.21em",sup:"0.42em"},m="\u200b",g=["http:","https:","mailto:","",void 0,":"],y=t.NEWLINES=/(\r\n?|\n)/g,v=/(<[^<>]*>)/,x=/<(\/?)([^ >]*)(\s+(.*))?>/i,b=//i;t.BR_TAG_ALL=//gi;var _=/(^|[\s"'])style\s*=\s*("([^"]*);?"|'([^']*);?')/i,w=/(^|[\s"'])href\s*=\s*("([^"]*)"|'([^']*)')/i,k=/(^|[\s"'])target\s*=\s*("([^"\s]*)"|'([^'\s]*)')/i,S=/(^|[\s"'])popup\s*=\s*("([\w=,]*)"|'([\w=,]*)')/i;function A(e,t){if(!e)return null;var r=e.match(t),n=r&&(r[3]||r[4]);return n&&E(n)}var T=/(^|;)\s*color:/;t.plainText=function(e,t){for(var r=void 0!==(t=t||{}).len&&-1!==t.len?t.len:1/0,n=void 0!==t.allowedTags?t.allowedTags:["br"],i=e.split(v),o=[],a="",s=0,l=0;l3?o.push(c.substr(0,p-3)+"..."):o.push(c.substr(0,p));break}a=""}}return o.join("")};var M={mu:"\u03bc",amp:"&",lt:"<",gt:">",nbsp:"\xa0",times:"\xd7",plusmn:"\xb1",deg:"\xb0"},C=/&(#\d+|#x[\da-fA-F]+|[a-z]+);/g;function E(e){return e.replace(C,(function(e,t){return("#"===t.charAt(0)?function(e){if(e>1114111)return;var t=String.fromCodePoint;if(t)return t(e);var r=String.fromCharCode;return e<=65535?r(e):r(55232+(e>>10),e%1024+56320)}("x"===t.charAt(1)?parseInt(t.substr(2),16):parseInt(t.substr(1),10)):M[t])||e}))}function I(e){var t=encodeURI(decodeURI(e)),r=document.createElement("a"),n=document.createElement("a");r.href=e,n.href=t;var i=r.protocol,o=n.protocol;return-1!==g.indexOf(i)&&-1!==g.indexOf(o)?t:""}function P(e,t,r){var n,o,a,s=r.horizontalAlign,l=r.verticalAlign||"top",c=e.node().getBoundingClientRect(),u=t.node().getBoundingClientRect();return o="bottom"===l?function(){return c.bottom-n.height}:"middle"===l?function(){return c.top+(c.height-n.height)/2}:function(){return c.top},a="right"===s?function(){return c.right-n.width}:"center"===s?function(){return c.left+(c.width-n.width)/2}:function(){return c.left},function(){n=this.node().getBoundingClientRect();var e=a()-u.left,t=o()-u.top,s=r.gd||{};if(r.gd){s._fullLayout._calcInverseTransform(s);var l=i.apply3DTransform(s._fullLayout._invTransform)(e,t);e=l[0],t=l[1]}return this.style({top:t+"px",left:e+"px","z-index":1e3}),this}}t.convertEntities=E,t.sanitizeHTML=function(e){e=e.replace(y," ");for(var t=document.createElement("p"),r=t,i=[],o=e.split(v),a=0;a{"use strict";var r={};function n(e){e&&null!==e.timer&&(clearTimeout(e.timer),e.timer=null)}t.throttle=function(e,t,i){var o=r[e],a=Date.now();if(!o){for(var s in r)r[s].tso.ts+t?l():o.timer=setTimeout((function(){l(),o.timer=null}),t)},t.done=function(e){var t=r[e];return t&&t.timer?new Promise((function(e){var r=t.onDone;t.onDone=function(){r&&r(),e(),t.onDone=null}})):Promise.resolve()},t.clear=function(e){if(e)n(r[e]),delete r[e];else for(var i in r)t.clear(i)}},46396:(e,t,r)=>{"use strict";var n=r(22036);e.exports=function(e,t){if(e>0)return Math.log(e)/Math.LN10;var r=Math.log(Math.min(t[0],t[1]))/Math.LN10;return n(r)||(r=Math.log(Math.max(t[0],t[1]))/Math.LN10-6),r}},76621:(e,t,r)=>{"use strict";var n=e.exports={},i=r(93752).locationmodeToLayer,o=r(52255).N4;n.getTopojsonName=function(e){return[e.scope.replace(/ /g,"-"),"_",e.resolution.toString(),"m"].join("")},n.getTopojsonPath=function(e,t){return e+t+".json"},n.getTopojsonFeatures=function(e,t){var r=i[e.locationmode],n=t.objects[r];return o(t,n).features}},41611:e=>{"use strict";e.exports={moduleType:"locale",name:"en-US",dictionary:{"Click to enter Colorscale title":"Click to enter Colorscale title"},format:{date:"%m/%d/%Y"}}},198:e=>{"use strict";e.exports={moduleType:"locale",name:"en",dictionary:{"Click to enter Colorscale title":"Click to enter Colourscale title"},format:{days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],periods:["AM","PM"],dateTime:"%a %b %e %X %Y",date:"%d/%m/%Y",time:"%H:%M:%S",decimal:".",thousands:",",grouping:[3],currency:["$",""],year:"%Y",month:"%b %Y",dayMonth:"%b %-d",dayMonthYear:"%b %-d, %Y"}}},19818:(e,t,r)=>{"use strict";var n=r(38361);e.exports=function(e){for(var t,r,i=n.layoutArrayContainers,o=n.layoutArrayRegexes,a=e.split("[")[0],s=0;s{"use strict";var n=r(64022).extendFlat,i=r(30167),o={valType:"flaglist",extras:["none"],flags:["calc","clearAxisTypes","plot","style","markerSize","colorbars"],description:["trace attributes should include an `editType` string matching this flaglist.","*calc* is the most extensive: a full (re)plot starting by clearing `gd.calcdata`","to force it to be regenerated","*clearAxisTypes* resets the types of the axes this trace is on, because new data could","cause the automatic axis type detection to change. Log type will not be cleared, as that","is never automatically chosen so must have been user-specified.","*plot* (re)plots but without first clearing `gd.calcdata`.","*style* only calls `module.style` (or module.editStyle) for all trace modules and redraws the legend.","*markerSize* is like *style*, but propagate axis-range changes due to scatter `marker.size`","*colorbars* only redraws colorbars."].join(" ")},a={valType:"flaglist",extras:["none"],flags:["calc","plot","legend","ticks","axrange","layoutstyle","modebar","camera","arraydraw","colorbars"],description:["layout attributes should include an `editType` string matching this flaglist.","*calc* is the most extensive: a full (re)plot starting by clearing `gd.calcdata`","to force it to be regenerated","*plot* (re)plots but without first clearing `gd.calcdata`.","*legend* only redraws the legend.","*ticks* only redraws axis ticks, labels, and gridlines.","*axrange* minimal sequence when updating axis ranges.","*layoutstyle* reapplies global and SVG cartesian axis styles.","*modebar* just updates the modebar.","*camera* just updates the camera settings for gl3d scenes.","*arraydraw* allows component arrays to invoke the redraw routines just for the","component(s) that changed.","*colorbars* only redraws colorbars."].join(" ")},s=o.flags.slice().concat(["fullReplot"]),l=a.flags.slice().concat("layoutReplot");function c(e){for(var t={},r=0;r{"use strict";var n=r(22036),i=r(10133),o=r(38361),a=r(84468),s=r(68543),l=r(11576),c=r(7605),u=l.cleanId,d=l.getFromTrace,h=o.traceIs;function p(e,t){var r=e[t],n=t.charAt(0);r&&"paper"!==r&&(e[t]=u(r,n,!0))}function f(e){function t(t,r){var n=e[t],i=e.title&&e.title[r];n&&!i&&(e.title||(e.title={}),e.title[r]=e[t],delete e[t])}e&&("string"!==typeof e.title&&"number"!==typeof e.title||(e.title={text:e.title}),t("titlefont","font"),t("titleposition","position"),t("titleside","side"),t("titleoffset","offset"))}function m(e){if(!a.isPlainObject(e))return!1;var t=e.name;return delete e.name,delete e.showlegend,("string"===typeof t||"number"===typeof t)&&String(t)}function g(e,t,r,n){if(r&&!n)return e;if(n&&!r)return t;if(!e.trim())return t;if(!t.trim())return e;var i,o=Math.min(e.length,t.length);for(i=0;i0&&a.log("Clearing previous rejected promises from queue."),e._promises=[]},t.cleanLayout=function(e){var r,n;e||(e={}),e.xaxis1&&(e.xaxis||(e.xaxis=e.xaxis1),delete e.xaxis1),e.yaxis1&&(e.yaxis||(e.yaxis=e.yaxis1),delete e.yaxis1),e.scene1&&(e.scene||(e.scene=e.scene1),delete e.scene1);var o=(s.subplotsRegistry.cartesian||{}).attrRegex,l=(s.subplotsRegistry.polar||{}).attrRegex,d=(s.subplotsRegistry.ternary||{}).attrRegex,h=(s.subplotsRegistry.gl3d||{}).attrRegex,m=Object.keys(e);for(r=0;r3?(R.x=1.02,R.xanchor="left"):R.x<-2&&(R.x=-.02,R.xanchor="right"),R.y>3?(R.y=1.02,R.yanchor="bottom"):R.y<-2&&(R.y=-.02,R.yanchor="top")),f(e),"rotate"===e.dragmode&&(e.dragmode="orbit"),c.clean(e),e.template&&e.template.layout&&t.cleanLayout(e.template.layout),e},t.cleanData=function(e){for(var r=0;r0)return e.substr(0,t)}t.hasParent=function(e,t){for(var r=b(t);r;){if(r in e)return!0;r=b(r)}return!1};var _=["x","y","z"];t.clearAxisTypes=function(e,t,r){for(var n=0;n{"use strict";var n=r(49841);t._doPlot=n._doPlot,t.newPlot=n.newPlot,t.restyle=n.restyle,t.relayout=n.relayout,t.redraw=n.redraw,t.update=n.update,t._guiRestyle=n._guiRestyle,t._guiRelayout=n._guiRelayout,t._guiUpdate=n._guiUpdate,t._storeDirectGUIEdit=n._storeDirectGUIEdit,t.react=n.react,t.extendTraces=n.extendTraces,t.prependTraces=n.prependTraces,t.addTraces=n.addTraces,t.deleteTraces=n.deleteTraces,t.moveTraces=n.moveTraces,t.purge=n.purge,t.addFrames=n.addFrames,t.deleteFrames=n.deleteFrames,t.animate=n.animate,t.setPlotConfig=n.setPlotConfig;var i=r(51124).getGraphDiv,o=r(98820).eraseActiveShape;t.deleteActiveShape=function(e){return o(i(e))},t.toImage=r(81530),t.validate=r(91447),t.downloadImage=r(52593);var a=r(59428);t.makeTemplate=a.makeTemplate,t.validateTemplate=a.validateTemplate},90491:(e,t,r)=>{"use strict";var n=r(30167),i=r(17266),o=r(98073),a=r(41222).sorterAsc,s=r(38361);t.containerArrayMatch=r(19818);var l=t.isAddVal=function(e){return"add"===e||n(e)},c=t.isRemoveVal=function(e){return null===e||"remove"===e};t.applyContainerArrayChanges=function(e,t,r,n,u){var d=t.astr,h=s.getComponentMethod(d,"supplyLayoutDefaults"),p=s.getComponentMethod(d,"draw"),f=s.getComponentMethod(d,"drawOne"),m=n.replot||n.recalc||h===i||p===i,g=e.layout,y=e._fullLayout;if(r[""]){Object.keys(r).length>1&&o.warn("Full array edits are incompatible with other edits",d);var v=r[""][""];if(c(v))t.set(null);else{if(!Array.isArray(v))return o.warn("Unrecognized full array edit value",d,v),!0;t.set(v)}return!m&&(h(g,y),p(e),!0)}var x,b,_,w,k,S,A,T,M=Object.keys(r).map(Number).sort(a),C=t.get(),E=C||[],I=u(y,d).get(),P=[],O=-1,R=E.length;for(x=0;xE.length-(A?0:1))o.warn("index out of range",d,_);else if(void 0!==S)k.length>1&&o.warn("Insertion & removal are incompatible with edits to the same index.",d,_),c(S)?P.push(_):A?("add"===S&&(S={}),E.splice(_,0,S),I&&I.splice(_,0,{})):o.warn("Unrecognized full object edit value",d,_,S),-1===O&&(O=_);else for(b=0;b=0;x--)E.splice(P[x],1),I&&I.splice(P[x],1);if(E.length?C||t.set(E):t.set(null),m)return!1;if(h(g,y),f!==i){var L;if(-1===O)L=M;else{for(R=Math.max(E.length,R),L=[],x=0;x=O);x++)L.push(_);for(x=O;x{"use strict";var n=r(41871),i=r(22036),o=r(59283),a=r(84468),s=a.nestedProperty,l=r(13711),c=r(41931),u=r(38361),d=r(30166),h=r(68543),p=r(85729),f=r(60696),m=r(49080),g=r(3172),y=r(7605),v=r(67831).initInteractions,x=r(28795),b=r(76789).clearOutline,_=r(20075).dfltConfig,w=r(90491),k=r(5440),S=r(88470),A=r(72587),T=r(93143).AX_NAME_PATTERN,M=0;function C(e){var t=e._fullLayout;t._redrawFromAutoMarginCount?t._redrawFromAutoMarginCount--:e.emit("plotly_afterplot")}function E(e,t){try{e._fullLayout._paper.style("background",t)}catch(r){a.error(r)}}function I(e,t){E(e,y.combine(t,"white"))}function P(e,t){if(!e._context){e._context=a.extendDeep({},_);var r=n.select("base");e._context._baseUrl=r.size()&&r.attr("href")?window.location.href.split("#")[0]:""}var i,s,l,c=e._context;if(t){for(s=Object.keys(t),i=0;i=e.data.length||i<-e.data.length)throw new Error(r+" must be valid indices for gd.data.");if(t.indexOf(i,n+1)>-1||i>=0&&t.indexOf(-e.data.length+i)>-1||i<0&&t.indexOf(e.data.length+i)>-1)throw new Error("each index in "+r+" must be unique.")}}function L(e,t,r){if(!Array.isArray(e.data))throw new Error("gd.data must be an array.");if("undefined"===typeof t)throw new Error("currentIndices is a required argument.");if(Array.isArray(t)||(t=[t]),R(e,t,"currentIndices"),"undefined"===typeof r||Array.isArray(r)||(r=[r]),"undefined"!==typeof r&&R(e,r,"newIndices"),"undefined"!==typeof r&&t.length!==r.length)throw new Error("current and new indices must be of equal length.")}function D(e,t,r,n,o){!function(e,t,r,n){var i=a.isPlainObject(n);if(!Array.isArray(e.data))throw new Error("gd.data must be an array");if(!a.isPlainObject(t))throw new Error("update must be a key:value object");if("undefined"===typeof r)throw new Error("indices must be an integer or array of integers");for(var o in R(e,r,"indices"),t){if(!Array.isArray(t[o])||t[o].length!==r.length)throw new Error("attribute "+o+" must be an array of length equal to indices array length");if(i&&(!(o in n)||!Array.isArray(n[o])||n[o].length!==t[o].length))throw new Error("when maxPoints is set as a key:value object it must contain a 1:1 corrispondence with the keys and number of traces in the update object")}}(e,t,r,n);for(var l=function(e,t,r,n){var o,l,c,u,d,h=a.isPlainObject(n),p=[];for(var f in Array.isArray(r)||(r=[r]),r=O(r,e.data.length-1),t)for(var m=0;m-1&&-1===r.indexOf("grouptitlefont")?l(r,r.replace("titlefont","title.font")):r.indexOf("titleposition")>-1?l(r,r.replace("titleposition","title.position")):r.indexOf("titleside")>-1?l(r,r.replace("titleside","title.side")):r.indexOf("titleoffset")>-1&&l(r,r.replace("titleoffset","title.offset")):l(r,r.replace("title","title.text"));function l(t,r){e[r]=e[t],delete e[t]}}function H(e,t,r){e=a.getGraphDiv(e),k.clearPromiseQueue(e);var n={};if("string"===typeof t)n[t]=r;else{if(!a.isPlainObject(t))return a.warn("Relayout fail.",t,r),Promise.reject();n=a.extendFlat({},t)}Object.keys(n).length&&(e.changed=!0);var i=X(e,n),o=i.flags;o.calc&&(e.calcdata=void 0);var s=[h.previousPromises];o.layoutReplot?s.push(S.layoutReplot):Object.keys(n).length&&($(e,o,i)||h.supplyDefaults(e),o.legend&&s.push(S.doLegend),o.layoutstyle&&s.push(S.layoutStyles),o.axrange&&W(s,i.rangesAltered),o.ticks&&s.push(S.doTicksRelayout),o.modebar&&s.push(S.doModeBar),o.camera&&s.push(S.doCamera),o.colorbars&&s.push(S.doColorBars),s.push(C)),s.push(h.rehover,h.redrag,h.reselect),c.add(e,H,[e,i.undoit],H,[e,i.redoit]);var l=a.syncOrAsync(s,e);return l&&l.then||(l=Promise.resolve(e)),l.then((function(){return e.emit("plotly_relayout",i.eventData),e}))}function $(e,t,r){var n,i,o=e._fullLayout;if(!t.axrange)return!1;for(var s in t)if("axrange"!==s&&t[s])return!1;var l=function(e,t){return a.coerce(n,i,m,e,t)},c={};for(var u in r.rangesAltered){var d=p.id2name(u);if(n=e.layout[d],i=o[d],f(n,i,l,c),i._matchGroup)for(var h in i._matchGroup)if(h!==u){var g=o[p.id2name(h)];g.autorange=i.autorange,g.range=i.range.slice(),g._input.range=i.range.slice()}}return!0}function W(e,t){var r=t?function(e){var r=[];for(var n in t){var i=p.getFromId(e,n);if(r.push(n),-1!==(i.ticklabelposition||"").indexOf("inside")&&i._anchorAxis&&r.push(i._anchorAxis._id),i._matchGroup)for(var o in i._matchGroup)t[o]||r.push(o)}return p.draw(e,r,{skipTitle:!0})}:function(e){return p.draw(e,"redraw")};e.push(b,S.doAutoRangeAndConstraints,r,S.drawData,S.finalDraw)}var q=/^[xyz]axis[0-9]*\.range(\[[0|1]\])?$/,G=/^[xyz]axis[0-9]*\.autorange$/,Y=/^[xyz]axis[0-9]*\.domain(\[[0|1]\])?$/;function X(e,t){var r,n,i,o=e.layout,l=e._fullLayout,c=l._guiEditing,h=N(l._preGUI,c),f=Object.keys(t),m=p.list(e),g=a.extendDeepAll({},t),y={};for(U(t),f=Object.keys(t),n=0;n0&&"string"!==typeof R.parts[D];)D--;var z=R.parts[D],j=R.parts[D-1]+"."+z,B=R.parts.slice(0,D).join("."),V=s(e.layout,B).get(),H=s(l,B).get(),$=R.get();if(void 0!==L){S[O]=L,M[O]="reverse"===z?L:F($);var W=d.getLayoutValObject(l,R.parts);if(W&&W.impliedEdits&&null!==L)for(var X in W.impliedEdits)C(a.relativeAttr(O,X),W.impliedEdits[X]);if(-1!==["width","height"].indexOf(O))if(L){C("autosize",null);var K="height"===O?"width":"height";C(K,l[K])}else l[O]=e._initialAutoSize[O];else if("autosize"===O)C("width",L?null:l.width),C("height",L?null:l.height);else if(j.match(q))P(j),s(l,B+"._inputRange").set(null);else if(j.match(G)){P(j),s(l,B+"._inputRange").set(null);var J=s(l,B).get();J._inputDomain&&(J._input.domain=J._inputDomain.slice())}else j.match(Y)&&s(l,B+"._inputDomain").set(null);if("type"===z){E=V;var Q="linear"===H.type&&"log"===L,ee="log"===H.type&&"linear"===L;if(Q||ee){if(E&&E.range)if(H.autorange)Q&&(E.range=E.range[1]>E.range[0]?[1,2]:[2,1]);else{var te=E.range[0],re=E.range[1];Q?(te<=0&&re<=0&&C(B+".autorange",!0),te<=0?te=re/1e6:re<=0&&(re=te/1e6),C(B+".range[0]",Math.log(te)/Math.LN10),C(B+".range[1]",Math.log(re)/Math.LN10)):(C(B+".range[0]",Math.pow(10,te)),C(B+".range[1]",Math.pow(10,re)))}else C(B+".autorange",!0);Array.isArray(l._subplots.polar)&&l._subplots.polar.length&&l[R.parts[0]]&&"radialaxis"===R.parts[1]&&delete l[R.parts[0]]._subplot.viewInitial["radialaxis.range"],u.getComponentMethod("annotations","convertCoords")(e,H,L,C),u.getComponentMethod("images","convertCoords")(e,H,L,C)}else C(B+".autorange",!0),C(B+".range",null);s(l,B+"._inputRange").set(null)}else if(z.match(T)){var ne=s(l,O).get(),ie=(L||{}).type;ie&&"-"!==ie||(ie="linear"),u.getComponentMethod("annotations","convertCoords")(e,ne,ie,C),u.getComponentMethod("images","convertCoords")(e,ne,ie,C)}var oe=w.containerArrayMatch(O);if(oe){r=oe.array,n=oe.index;var ae=oe.property,se=W||{editType:"calc"};""!==n&&""===ae&&(w.isAddVal(L)?M[O]=null:w.isRemoveVal(L)?M[O]=(s(o,r).get()||[])[n]:a.warn("unrecognized full object value",t)),A.update(_,se),y[r]||(y[r]={});var le=y[r][n];le||(le=y[r][n]={}),le[ae]=L,delete t[O]}else"reverse"===z?(V.range?V.range.reverse():(C(B+".autorange",!0),V.range=[1,0]),H.autorange?_.calc=!0:_.plot=!0):("dragmode"===O&&(!1===L&&!1!==$||!1!==L&&!1===$)||l._has("scatter-like")&&l._has("regl")&&"dragmode"===O&&("lasso"===L||"select"===L)&&"lasso"!==$&&"select"!==$||l._has("gl2d")?_.plot=!0:W?A.update(_,W):_.calc=!0,R.set(L))}}for(r in y){w.applyContainerArrayChanges(e,h(o,r),y[r],_,h)||(_.plot=!0)}for(var ce in I){var ue=(E=p.getFromId(e,ce))&&E._constraintGroup;if(ue)for(var de in _.calc=!0,ue)I[de]||(p.getFromId(e,de)._constraintShrinkable=!0)}(Z(e)||t.height||t.width)&&(_.plot=!0);var he=l.shapes;for(n=0;n1;)if(n.pop(),void 0!==(r=s(t,n.join(".")+".uirevision").get()))return r;return t.uirevision}function ne(e,t){for(var r=0;r=i.length?i[0]:i[e]:i}function l(e){return Array.isArray(o)?e>=o.length?o[0]:o[e]:o}function c(e,t){var r=0;return function(){if(e&&++r===t)return e()}}return void 0===n._frameWaitingCnt&&(n._frameWaitingCnt=0),new Promise((function(o,u){function d(){n._currentFrame&&n._currentFrame.onComplete&&n._currentFrame.onComplete();var t=n._currentFrame=n._frameQueue.shift();if(t){var r=t.name?t.name.toString():null;e._fullLayout._currentFrame=r,n._lastFrameAt=Date.now(),n._timeToNext=t.frameOpts.duration,h.transition(e,t.frame.data,t.frame.layout,k.coerceTraceIndices(e,t.frame.traces),t.frameOpts,t.transitionOpts).then((function(){t.onComplete&&t.onComplete()})),e.emit("plotly_animatingframe",{name:r,frame:t.frame,animation:{frame:t.frameOpts,transition:t.transitionOpts}})}else e.emit("plotly_animated"),window.cancelAnimationFrame(n._animationRaf),n._animationRaf=null}function p(){e.emit("plotly_animating"),n._lastFrameAt=-1/0,n._timeToNext=0,n._runningTransitions=0,n._currentFrame=null;var t=function(){n._animationRaf=window.requestAnimationFrame(t),Date.now()-n._lastFrameAt>n._timeToNext&&d()};t()}var f,m,g=0;function y(e){return Array.isArray(i)?g>=i.length?e.transitionOpts=i[g]:e.transitionOpts=i[0]:e.transitionOpts=i,g++,e}var v=[],x=void 0===t||null===t,b=Array.isArray(t);if(!x&&!b&&a.isPlainObject(t))v.push({type:"object",data:y(a.extendFlat({},t))});else if(x||-1!==["string","number"].indexOf(typeof t))for(f=0;f0&&SS)&&A.push(m);v=A}}v.length>0?function(t){if(0!==t.length){for(var i=0;i=0;n--)if(a.isPlainObject(t[n])){var m=t[n].name,g=(u[m]||f[m]||{}).name,y=t[n].name,v=u[g]||f[g];g&&y&&"number"===typeof y&&v&&M<5&&(M++,a.warn('addFrames: overwriting frame "'+(u[g]||f[g]).name+'" with a frame whose name of type "number" also equates to "'+g+'". This is valid but may potentially lead to unexpected behavior since all plotly.js frame names are stored internally as strings.'),5===M&&a.warn("addFrames: This API call has yielded too many of these warnings. For the rest of this call, further warnings about numeric frame names will be suppressed.")),f[m]={name:m},p.push({frame:h.supplyFrameDefaults(t[n]),index:r&&void 0!==r[n]&&null!==r[n]?r[n]:d+n})}p.sort((function(e,t){return e.index>t.index?-1:e.index=0;n--){if("number"===typeof(i=p[n].frame).name&&a.warn("Warning: addFrames accepts frames with numeric names, but the numbers areimplicitly cast to strings"),!i.name)for(;u[i.name="frame "+e._transitionData._counter++];);if(u[i.name]){for(o=0;o=0;r--)n=t[r],o.push({type:"delete",index:n}),s.unshift({type:"insert",index:n,value:i[n]});var l=h.modifyFrames,u=h.modifyFrames,d=[e,s],p=[e,o];return c&&c.add(e,l,d,u,p),h.modifyFrames(e,o)},t.addTraces=function e(r,n,i){r=a.getGraphDiv(r);var o,s,l=[],u=t.deleteTraces,d=e,h=[r,l],p=[r,n];for(function(e,t,r){var n,i;if(!Array.isArray(e.data))throw new Error("gd.data must be an array.");if("undefined"===typeof t)throw new Error("traces must be defined.");for(Array.isArray(t)||(t=[t]),n=0;n=0&&r=0&&r{"use strict";var t={staticPlot:{valType:"boolean",dflt:!1,description:["Determines whether the graphs are interactive or not.","If *false*, no interactivity, for export or image generation."].join(" ")},typesetMath:{valType:"boolean",dflt:!0,description:["Determines whether math should be typeset or not,","when MathJax (either v2 or v3) is present on the page."].join(" ")},plotlyServerURL:{valType:"string",dflt:"",description:["When set it determines base URL for","the 'Edit in Chart Studio' `showEditInChartStudio`/`showSendToCloud` mode bar button","and the showLink/sendData on-graph link.","To enable sending your data to Chart Studio Cloud, you need to","set both `plotlyServerURL` to 'https://chart-studio.plotly.com' and","also set `showSendToCloud` to true."].join(" ")},editable:{valType:"boolean",dflt:!1,description:["Determines whether the graph is editable or not.","Sets all pieces of `edits`","unless a separate `edits` config item overrides individual parts."].join(" ")},edits:{annotationPosition:{valType:"boolean",dflt:!1,description:["Determines if the main anchor of the annotation is editable.","The main anchor corresponds to the","text (if no arrow) or the arrow (which drags the whole thing leaving","the arrow length & direction unchanged)."].join(" ")},annotationTail:{valType:"boolean",dflt:!1,description:["Has only an effect for annotations with arrows.","Enables changing the length and direction of the arrow."].join(" ")},annotationText:{valType:"boolean",dflt:!1,description:"Enables editing annotation text."},axisTitleText:{valType:"boolean",dflt:!1,description:"Enables editing axis title text."},colorbarPosition:{valType:"boolean",dflt:!1,description:"Enables moving colorbars."},colorbarTitleText:{valType:"boolean",dflt:!1,description:"Enables editing colorbar title text."},legendPosition:{valType:"boolean",dflt:!1,description:"Enables moving the legend."},legendText:{valType:"boolean",dflt:!1,description:"Enables editing the trace name fields from the legend"},shapePosition:{valType:"boolean",dflt:!1,description:"Enables moving shapes."},titleText:{valType:"boolean",dflt:!1,description:"Enables editing the global layout title."}},editSelection:{valType:"boolean",dflt:!0,description:"Enables moving selections."},autosizable:{valType:"boolean",dflt:!1,description:["Determines whether the graphs are plotted with respect to","layout.autosize:true and infer its container size."].join(" ")},responsive:{valType:"boolean",dflt:!1,description:["Determines whether to change the layout size when window is resized.","In v3, this option will be removed and will always be true."].join(" ")},fillFrame:{valType:"boolean",dflt:!1,description:["When `layout.autosize` is turned on, determines whether the graph","fills the container (the default) or the screen (if set to *true*)."].join(" ")},frameMargins:{valType:"number",dflt:0,min:0,max:.5,description:["When `layout.autosize` is turned on, set the frame margins","in fraction of the graph size."].join(" ")},scrollZoom:{valType:"flaglist",flags:["cartesian","gl3d","geo","mapbox","map"],extras:[!0,!1],dflt:"gl3d+geo+map",description:["Determines whether mouse wheel or two-finger scroll zooms is enable.","Turned on by default for gl3d, geo, mapbox and map subplots","(as these subplot types do not have zoombox via pan),","but turned off by default for cartesian subplots.","Set `scrollZoom` to *false* to disable scrolling for all subplots."].join(" ")},doubleClick:{valType:"enumerated",values:[!1,"reset","autosize","reset+autosize"],dflt:"reset+autosize",description:["Sets the double click interaction mode.","Has an effect only in cartesian plots.","If *false*, double click is disable.","If *reset*, double click resets the axis ranges to their initial values.","If *autosize*, double click set the axis ranges to their autorange values.","If *reset+autosize*, the odd double clicks resets the axis ranges","to their initial values and even double clicks set the axis ranges","to their autorange values."].join(" ")},doubleClickDelay:{valType:"number",dflt:300,min:0,description:["Sets the delay for registering a double-click in ms.","This is the time interval (in ms) between first mousedown and","2nd mouseup to constitute a double-click.","This setting propagates to all on-subplot double clicks","(except for geo, mapbox and map) and on-legend double clicks."].join(" ")},showAxisDragHandles:{valType:"boolean",dflt:!0,description:["Set to *false* to omit cartesian axis pan/zoom drag handles."].join(" ")},showAxisRangeEntryBoxes:{valType:"boolean",dflt:!0,description:["Set to *false* to omit direct range entry at the pan/zoom drag points,","note that `showAxisDragHandles` must be enabled to have an effect."].join(" ")},showTips:{valType:"boolean",dflt:!0,description:["Determines whether or not tips are shown while interacting","with the resulting graphs."].join(" ")},showLink:{valType:"boolean",dflt:!1,description:["Determines whether a link to Chart Studio Cloud is displayed","at the bottom right corner of resulting graphs.","Use with `sendData` and `linkText`."].join(" ")},linkText:{valType:"string",dflt:"Edit chart",noBlank:!0,description:["Sets the text appearing in the `showLink` link."].join(" ")},sendData:{valType:"boolean",dflt:!0,description:["If *showLink* is true, does it contain data","just link to a Chart Studio Cloud file?"].join(" ")},showSources:{valType:"any",dflt:!1,description:["Adds a source-displaying function to show sources on","the resulting graphs."].join(" ")},displayModeBar:{valType:"enumerated",values:["hover",!0,!1],dflt:"hover",description:["Determines the mode bar display mode.","If *true*, the mode bar is always visible.","If *false*, the mode bar is always hidden.","If *hover*, the mode bar is visible while the mouse cursor","is on the graph container."].join(" ")},showSendToCloud:{valType:"boolean",dflt:!1,description:['Should we include a ModeBar button, labeled "Edit in Chart Studio",',"that sends this chart to chart-studio.plotly.com (formerly plot.ly) or another plotly server","as specified by `plotlyServerURL` for editing, export, etc? Prior to version 1.43.0","this button was included by default, now it is opt-in using this flag.","Note that this button can (depending on `plotlyServerURL` being set) send your data","to an external server. However that server does not persist your data",'until you arrive at the Chart Studio and explicitly click "Save".'].join(" ")},showEditInChartStudio:{valType:"boolean",dflt:!1,description:["Same as `showSendToCloud`, but use a pencil icon instead of a floppy-disk.","Note that if both `showSendToCloud` and `showEditInChartStudio` are turned,","only `showEditInChartStudio` will be honored."].join(" ")},modeBarButtonsToRemove:{valType:"any",dflt:[],description:["Remove mode bar buttons by name.","See ./components/modebar/buttons.js for the list of names."].join(" ")},modeBarButtonsToAdd:{valType:"any",dflt:[],description:["Add mode bar button using config objects","See ./components/modebar/buttons.js for list of arguments.","To enable predefined modebar buttons e.g. shape drawing, hover and spikelines,","simply provide their string name(s). This could include:","*v1hovermode*, *hoverclosest*, *hovercompare*, *togglehover*, *togglespikelines*,","*drawline*, *drawopenpath*, *drawclosedpath*, *drawcircle*, *drawrect* and *eraseshape*.","Please note that these predefined buttons will only be shown if they are compatible","with all trace types used in a graph."].join(" ")},modeBarButtons:{valType:"any",dflt:!1,description:["Define fully custom mode bar buttons as nested array,","where the outer arrays represents button groups, and","the inner arrays have buttons config objects or names of default buttons","See ./components/modebar/buttons.js for more info."].join(" ")},toImageButtonOptions:{valType:"any",dflt:{},description:["Statically override options for toImage modebar button","allowed keys are format, filename, width, height, scale","see ../components/modebar/buttons.js"].join(" ")},displaylogo:{valType:"boolean",dflt:!0,description:["Determines whether or not the plotly logo is displayed","on the end of the mode bar."].join(" ")},watermark:{valType:"boolean",dflt:!1,description:"watermark the images with the company's logo"},plotGlPixelRatio:{valType:"number",dflt:2,min:1,max:4,description:["Set the pixel ratio during WebGL image export.","This config option was formerly named `plot3dPixelRatio`","which is now deprecated."].join(" ")},setBackground:{valType:"any",dflt:"transparent",description:["Set function to add the background color (i.e. `layout.paper_color`)","to a different container.","This function take the graph div as first argument and the current background","color as second argument.","Alternatively, set to string *opaque* to ensure there is white behind it."].join(" ")},topojsonURL:{valType:"string",noBlank:!0,dflt:"https://cdn.plot.ly/",description:["Set the URL to topojson used in geo charts.","By default, the topojson files are fetched from cdn.plot.ly.","For example, set this option to:","/dist/topojson/","to render geographical feature using the topojson files","that ship with the plotly.js module."].join(" ")},mapboxAccessToken:{valType:"string",dflt:null,description:["Mapbox access token (required to plot mapbox trace types)","If using an Mapbox Atlas server, set this option to ''","so that plotly.js won't attempt to authenticate to the public Mapbox server."].join(" ")},logging:{valType:"integer",min:0,max:2,dflt:1,description:["Turn all console logging on or off (errors will be thrown)","This should ONLY be set via Plotly.setPlotConfig","Available levels:","0: no logs","1: warnings and errors, but not informational messages","2: verbose logs"].join(" ")},notifyOnLogging:{valType:"integer",min:0,max:2,dflt:0,description:["Set on-graph logging (notifier) level","This should ONLY be set via Plotly.setPlotConfig","Available levels:","0: no on-graph logs","1: warnings and errors, but not informational messages","2: verbose logs"].join(" ")},queueLength:{valType:"integer",min:0,dflt:0,description:"Sets the length of the undo/redo queue."},globalTransforms:{valType:"any",dflt:[],description:["Set global transform to be applied to all traces with no","specification needed"].join(" ")},locale:{valType:"string",dflt:"en-US",description:["Which localization should we use?","Should be a string like 'en' or 'en-US'."].join(" ")},locales:{valType:"any",dflt:{},description:["Localization definitions","Locales can be provided either here (specific to one chart) or globally","by registering them as modules.","Should be an object of objects {locale: {dictionary: {...}, format: {...}}}","{"," da: {"," dictionary: {'Reset axes': 'Nulstil aksler', ...},"," format: {months: [...], shortMonths: [...]}"," },"," ...","}","All parts are optional. When looking for translation or format fields, we","look first for an exact match in a config locale, then in a registered","module. If those fail, we strip off any regionalization ('en-US' -> 'en')","and try each (config, registry) again. The final fallback for translation","is untranslated (which is US English) and for formats is the base English","(the only consequence being the last fallback date format %x is DD/MM/YYYY","instead of MM/DD/YYYY). Currently `grouping` and `currency` are ignored","for our automatic number formatting, but can be used in custom formats."].join(" ")}},r={};!function e(t,r){for(var n in t){var i=t[n];i.valType?r[n]=i.dflt:(r[n]||(r[n]={}),e(i,r[n]))}}(t,r),e.exports={configAttributes:t,dfltConfig:r}},30166:(e,t,r)=>{"use strict";var n=r(38361),i=r(84468),o=r(75622),a=r(98005),s=r(44380),l=r(34765),c=r(20075).configAttributes,u=r(72587),d=i.extendDeepAll,h=i.isPlainObject,p=i.isArrayOrTypedArray,f=i.nestedProperty,m=i.valObjectMeta,g="_isSubplotObj",y="_isLinkedToArray",v="_deprecated",x=[g,y,"_arrayAttrRegexps",v];function b(e,t,r){if(!e)return!1;if(e._isLinkedToArray)if(_(t[r]))r++;else if(r=o.length)return!1;if(2===e.dimensions){if(r++,t.length===r)return e;var a=t[r];if(!_(a))return!1;e=o[i][a]}else e=o[i]}else e=o}}return e}function _(e){return e===Math.round(e)&&e>=0}function w(){var e,t,r={};for(e in d(r,a),n.subplotsRegistry){if((t=n.subplotsRegistry[e]).layoutAttributes)if(Array.isArray(t.attr))for(var i=0;i=l.length)return!1;i=(r=(n.transformsRegistry[l[c].type]||{}).attributes)&&r[t[2]],s=3}else{var u=e._module;if(u||(u=(n.modules[e.type||o.type.dflt]||{})._module),!u)return!1;if(!(i=(r=u.attributes)&&r[a])){var d=u.basePlotModule;d&&d.attributes&&(i=d.attributes[a])}i||(i=o[a])}return b(i,t,s)},t.getLayoutValObject=function(e,t){var r=function(e,t){var r,i,o,s,l=e._basePlotModules;if(l){var c;for(r=0;r{"use strict";var n=r(84468),i=r(75622),o="templateitemname",a={name:{valType:"string",editType:"none",description:["When used in a template, named items are created in the output figure","in addition to any items the figure already has in this array.","You can modify these items in the output figure by making your own","item with `templateitemname` matching this `name`","alongside your modifications (including `visible: false` or","`enabled: false` to hide it).","Has no effect outside of a template."].join(" ")}};function s(e){return e&&"string"===typeof e}function l(e){var t=e.length-1;return"s"!==e.charAt(t)&&n.warn("bad argument to arrayDefaultKey: "+e),e.substr(0,e.length-1)+"defaults"}a[o]={valType:"string",editType:"calc",description:["Used to refer to a named item in this array in the template. Named","items from the template will be created even without a matching item","in the input figure, but you can modify one by making an item with","`templateitemname` matching its `name`, alongside your modifications","(including `visible: false` or `enabled: false` to hide it).","If there is no template or no matching item, this item will be","hidden unless you explicitly show it with `visible: true`."].join(" ")},t.templatedArray=function(e,t){return t._isLinkedToArray=e,t.name=a.name,t[o]=a[o],t},t.traceTemplater=function(e){var t,r,o={};for(t in e)r=e[t],Array.isArray(r)&&r.length&&(o[t]=0);return{newTrace:function(a){var s={type:t=n.coerce(a,{},i,"type"),_template:null};if(t in o){r=e[t];var l=o[t]%r.length;o[t]++,s._template=r[l]}return s}}},t.newContainer=function(e,t,r){var i=e._template,o=i&&(i[t]||r&&i[r]);return n.isPlainObject(o)||(o=null),e[t]={_template:o}},t.arrayTemplater=function(e,t,r){var n=e._template,i=n&&n[l(t)],a=n&&n[t];Array.isArray(a)&&a.length||(a=[]);var c={};return{newItem:function(e){var t={name:e.name,_input:e},n=t[o]=e[o];if(!s(n))return t._template=i,t;for(var l=0;l=i&&(r._input||{})._templateitemname;s&&(a=i);var l,c=t+"["+a+"]";function u(){l={},s&&(l[c]={},l[c][o]=s)}function d(e,t){s?n.nestedProperty(l[c],e).set(t):l[c+"."+e]=t}function h(){var e=l;return u(),e}return u(),{modifyBase:function(e,t){l[e]=t},modifyItem:d,getUpdateObj:h,applyUpdate:function(t,r){t&&d(t,r);var i=h();for(var o in i)n.nestedProperty(e,o).set(i[o])}}}},88470:(e,t,r)=>{"use strict";var n=r(41871),i=r(38361),o=r(68543),a=r(84468),s=r(13480),l=r(76574),c=r(7605),u=r(3172),d=r(13701),h=r(94082),p=r(85729),f=r(83943),m=r(80038),g=m.enforce,y=m.clean,v=r(49618).doAutoRange,x="start",b="middle",_="end",w=r(93143).zindexSeparator;function k(e,t,r){for(var n=0;n=e[1]||i[1]<=e[0])&&(o[0]t[0]))return!0}return!1}function S(e){var r,i,s,l,d,m,g=e._fullLayout,y=g._size,v=y.p,x=p.list(e,"",!0);if(g._paperdiv.style({width:e._context.responsive&&g.autosize&&!e._context._hasZeroWidth&&!e.layout.width?"100%":g.width+"px",height:e._context.responsive&&g.autosize&&!e._context._hasZeroHeight&&!e.layout.height?"100%":g.height+"px"}).selectAll(".main-svg").call(u.setSize,g.width,g.height),e._context.setBackground(e,g.paper_bgcolor),t.drawMainTitle(e),h.manage(e),!g._has("cartesian"))return o.previousPromises(e);function b(e,t,r){var n=e._lw/2;return"x"===e._id.charAt(0)?t?"top"===r?t._offset-v-n:t._offset+t._length+v+n:y.t+y.h*(1-(e.position||0))+n%1:t?"right"===r?t._offset+t._length+v+n:t._offset-v-n:y.l+y.w*(e.position||0)+n%1}for(r=0;r.5?"t":"b",a=e._fullLayout.margin[o],s=0;"paper"===t.yref?s=r+t.pad.t+t.pad.b:"container"===t.yref&&(s=function(e,t,r,n,i){var o=0;"middle"===r&&(o+=i/2);"t"===e?("top"===r&&(o+=i),o+=n-t*n):("bottom"===r&&(o+=i),o+=t*n);return o}(o,n,i,e._fullLayout.height,r)+t.pad.t+t.pad.b);if(s>a)return s;return 0}(e,t,m);if(g>0){!function(e,t,r,n){var i="title.automargin",s=e._fullLayout.title,l=s.y>.5?"t":"b",c={x:s.x,y:s.y,t:0,b:0},u={};"paper"===s.yref&&function(e,t,r,n,i){var o="paper"===t.yref?e._fullLayout._size.h:e._fullLayout.height,s=a.isTopAnchor(t)?n:n-i,l="b"===r?o-s:s;return!(a.isTopAnchor(t)&&"t"===r||a.isBottomAnchor(t)&&"b"===r)&&l{"use strict";var n=r(84468),i=n.isPlainObject,o=r(30166),a=r(68543),s=r(75622),l=r(37091),c=r(20075).dfltConfig;function u(e,t){e=n.extendDeep({},e);var r,o,a=Object.keys(e).sort();function s(t,r,n){if(i(r)&&i(t))u(t,r);else if(Array.isArray(r)&&Array.isArray(t)){var a=l.arrayTemplater({_template:e},n);for(o=0;ok?u.push({code:"unused",traceType:v,templateCount:w,dataCount:k}):k>w&&u.push({code:"reused",traceType:v,templateCount:w,dataCount:k})}}else u.push({code:"data"});if(function e(t,r){for(var n in t)if("_"!==n.charAt(0)){var o=t[n],a=m(t,n,r);i(o)?(Array.isArray(t)&&!1===o._template&&o.templateitemname&&u.push({code:"missing",path:a,templateitemname:o.templateitemname}),e(o,a)):Array.isArray(o)&&g(o)&&e(o,a)}}({data:p,layout:h},""),u.length)return u.map(y)}},81530:(e,t,r)=>{"use strict";var n=r(22036),i=r(49841),o=r(68543),a=r(84468),s=r(5240),l=r(85916),c=r(69939),u=r(17316).version,d={format:{valType:"enumerated",values:["png","jpeg","webp","svg","full-json"],dflt:"png",description:"Sets the format of exported image."},width:{valType:"number",min:1,description:["Sets the exported image width.","Defaults to the value found in `layout.width`","If set to *null*, the exported image width will match the current graph width."].join(" ")},height:{valType:"number",min:1,description:["Sets the exported image height.","Defaults to the value found in `layout.height`","If set to *null*, the exported image height will match the current graph height."].join(" ")},scale:{valType:"number",min:0,dflt:1,description:["Sets a scaling for the generated image.","If set, all features of a graphs (e.g. text, line width)","are scaled, unlike simply setting","a bigger *width* and *height*."].join(" ")},setBackground:{valType:"any",dflt:!1,description:["Sets the image background mode.","By default, the image background is determined by `layout.paper_bgcolor`,","the *transparent* mode.","One might consider setting `setBackground` to *opaque*","when exporting a *jpeg* image as JPEGs do not support opacity."].join(" ")},imageDataOnly:{valType:"boolean",dflt:!1,description:["Determines whether or not the return value is prefixed by","the image format's corresponding 'data:image;' spec."].join(" ")}};e.exports=function(e,t){var r,h,p,f;function m(e){return!(e in t)||a.validate(t[e],d[e])}if(t=t||{},a.isPlainObject(e)?(r=e.data||[],h=e.layout||{},p=e.config||{},f={}):(e=a.getGraphDiv(e),r=a.extendDeep([],e.data),h=a.extendDeep({},e.layout),p=e._context,f=e._fullLayout||{}),!m("width")&&null!==t.width||!m("height")&&null!==t.height)throw new Error("Height and width should be pixel values.");if(!m("format"))throw new Error("Export format is not "+a.join2(d.format.values,", "," or ")+".");var g={};function y(e,r){return a.coerce(t,g,d,e,r)}var v=y("format"),x=y("width"),b=y("height"),_=y("scale"),w=y("setBackground"),k=y("imageDataOnly"),S=document.createElement("div");S.style.position="absolute",S.style.left="-5000px",document.body.appendChild(S);var A=a.extendFlat({},h);x?A.width=x:null===t.width&&n(f.width)&&(A.width=f.width),b?A.height=b:null===t.height&&n(f.height)&&(A.height=f.height);var T=a.extendFlat({},p,{_exportedPlot:!0,staticPlot:!0,setBackground:w}),M=s.getRedrawFunc(S);function C(){return new Promise((function(e){setTimeout(e,s.getDelay(S._fullLayout))}))}function E(){return new Promise((function(e,t){var r=l(S,v,_),n=S._fullLayout.width,d=S._fullLayout.height;function h(){i.purge(S),document.body.removeChild(S)}if("full-json"===v){var p=o.graphJson(S,!1,"keepdata","object",!0,!0);return p.version=u,p=JSON.stringify(p),h(),e(k?p:s.encodeJSON(p))}if(h(),"svg"===v)return e(k?r:s.encodeSVG(r));var f=document.createElement("canvas");f.id=a.randstr(),c({format:v,width:n,height:d,scale:_,canvas:f,svg:r,promise:!0}).then(e).catch(t)}))}return new Promise((function(e,t){i.newPlot(S,r,A,T).then(M).then(C).then(E).then((function(t){e(function(e){return k?e.replace(s.IMAGE_URL_PREFIX,""):e}(t))})).catch((function(e){t(e)}))}))}},91447:(e,t,r)=>{"use strict";var n=r(84468),i=r(68543),o=r(30166),a=r(20075).dfltConfig,s=n.isPlainObject,l=Array.isArray,c=n.isArrayOrTypedArray;function u(e,t,r,i,o,a){a=a||[];for(var d=Object.keys(e),h=0;hx.length&&i.push(p("unused",o,y.concat(x.length)));var A,T,M,C,E,I=x.length,P=Array.isArray(S);if(P&&(I=Math.min(I,S.length)),2===b.dimensions)for(T=0;Tx[T].length&&i.push(p("unused",o,y.concat(T,x[T].length)));var O=x[T].length;for(A=0;A<(P?Math.min(O,S[T].length):O);A++)M=P?S[T][A]:S,C=v[T][A],E=x[T][A],n.validate(C,M)?E!==C&&E!==+C&&i.push(p("dynamic",o,y.concat(T,A),C,E)):i.push(p("value",o,y.concat(T,A),C))}else i.push(p("array",o,y.concat(T),v[T]));else for(T=0;T1&&h.push(p("object","layout"))),i.supplyDefaults(f);for(var m=f._fullData,g=r.length,y=0;y{"use strict";e.exports={mode:{valType:"enumerated",dflt:"afterall",values:["immediate","next","afterall"],description:["Describes how a new animate call interacts with currently-running","animations. If `immediate`, current animations are interrupted and","the new animation is started. If `next`, the current frame is allowed","to complete, after which the new animation is started. If `afterall`","all existing frames are animated to completion before the new animation","is started."].join(" ")},direction:{valType:"enumerated",values:["forward","reverse"],dflt:"forward",description:["The direction in which to play the frames triggered by the animation call"].join(" ")},fromcurrent:{valType:"boolean",dflt:!1,description:["Play frames starting at the current frame instead of the beginning."].join(" ")},frame:{duration:{valType:"number",min:0,dflt:500,description:["The duration in milliseconds of each frame. If greater than the frame","duration, it will be limited to the frame duration."].join(" ")},redraw:{valType:"boolean",dflt:!0,description:["Redraw the plot at completion of the transition. This is desirable","for transitions that include properties that cannot be transitioned,","but may significantly slow down updates that do not require a full","redraw of the plot"].join(" ")}},transition:{duration:{valType:"number",min:0,dflt:500,editType:"none",description:["The duration of the transition, in milliseconds. If equal to zero,","updates are synchronous."].join(" ")},easing:{valType:"enumerated",dflt:"cubic-in-out",values:["linear","quad","cubic","sin","exp","circle","elastic","back","bounce","linear-in","quad-in","cubic-in","sin-in","exp-in","circle-in","elastic-in","back-in","bounce-in","linear-out","quad-out","cubic-out","sin-out","exp-out","circle-out","elastic-out","back-out","bounce-out","linear-in-out","quad-in-out","cubic-in-out","sin-in-out","exp-in-out","circle-in-out","elastic-in-out","back-in-out","bounce-in-out"],editType:"none",description:"The easing function used for the transition"},ordering:{valType:"enumerated",values:["layout first","traces first"],dflt:"layout first",editType:"none",description:["Determines whether the figure's layout or traces smoothly transitions","during updates that make both traces and layout change."].join(" ")}}}},38851:(e,t,r)=>{"use strict";var n=r(84468),i=r(37091);e.exports=function(e,t,r){var o,a,s=r.name,l=r.inclusionAttr||"visible",c=t[s],u=n.isArrayOrTypedArray(e[s])?e[s]:[],d=t[s]=[],h=i.arrayTemplater(t,s,l);for(o=0;o{"use strict";var n=r(91740),i=r(25087);e.exports={type:{valType:"enumerated",values:[],dflt:"scatter",editType:"calc+clearAxisTypes",_noTemplating:!0},visible:{valType:"enumerated",values:[!0,!1,"legendonly"],dflt:!0,editType:"calc",description:["Determines whether or not this trace is visible.","If *legendonly*, the trace is not drawn,","but can appear as a legend item","(provided that the legend itself is visible)."].join(" ")},showlegend:{valType:"boolean",dflt:!0,editType:"style",description:["Determines whether or not an item corresponding to this","trace is shown in the legend."].join(" ")},legend:{valType:"subplotid",dflt:"legend",editType:"style",description:["Sets the reference to a legend to show this trace in.","References to these legends are *legend*, *legend2*, *legend3*, etc.","Settings for these legends are set in the layout, under","`layout.legend`, `layout.legend2`, etc."].join(" ")},legendgroup:{valType:"string",dflt:"",editType:"style",description:["Sets the legend group for this trace.","Traces and shapes part of the same legend group hide/show at the same time","when toggling legend items."].join(" ")},legendgrouptitle:{text:{valType:"string",dflt:"",editType:"style",description:["Sets the title of the legend group."].join(" ")},font:n({editType:"style",description:["Sets this legend group's title font."].join(" ")}),editType:"style"},legendrank:{valType:"number",dflt:1e3,editType:"style",description:["Sets the legend rank for this trace.","Items and groups with smaller ranks are presented on top/left side while","with *reversed* `legend.traceorder` they are on bottom/right side.","The default legendrank is 1000,","so that you can use ranks less than 1000 to place certain items before all unranked items,","and ranks greater than 1000 to go after all unranked items.","When having unranked or equal rank items shapes would be displayed after traces","i.e. according to their order in data and layout."].join(" ")},legendwidth:{valType:"number",min:0,editType:"style",description:"Sets the width (in px or fraction) of the legend for this trace."},opacity:{valType:"number",min:0,max:1,dflt:1,editType:"style",description:"Sets the opacity of the trace."},name:{valType:"string",editType:"style",description:["Sets the trace name.","The trace name appears as the legend item and on hover."].join(" ")},uid:{valType:"string",editType:"plot",anim:!0,description:["Assign an id to this trace,","Use this to provide object constancy between traces during animations","and transitions."].join(" ")},ids:{valType:"data_array",editType:"calc",anim:!0,description:["Assigns id labels to each datum.","These ids for object constancy of data points during animation.","Should be an array of strings, not numbers or any other type."].join(" ")},customdata:{valType:"data_array",editType:"calc",description:["Assigns extra data each datum.","This may be useful when listening to hover, click and selection events.","Note that, *scatter* traces also appends customdata items in the markers","DOM elements"].join(" ")},meta:{valType:"any",arrayOk:!0,editType:"plot",description:["Assigns extra meta information associated with this trace","that can be used in various text attributes.","Attributes such as trace `name`, graph, axis and colorbar `title.text`, annotation `text`","`rangeselector`, `updatemenues` and `sliders` `label` text","all support `meta`.","To access the trace `meta` values in an attribute in the same trace, simply use","`%{meta[i]}` where `i` is the index or key of the `meta`","item in question.","To access trace `meta` in layout attributes, use","`%{data[n[.meta[i]}` where `i` is the index or key of the `meta`","and `n` is the trace index."].join(" ")},selectedpoints:{valType:"any",editType:"calc",description:["Array containing integer indices of selected points.","Has an effect only for traces that support selections.","Note that an empty array means an empty selection where the `unselected`","are turned on for all points, whereas, any other non-array values means no","selection all where the `selected` and `unselected` styles have no effect."].join(" ")},hoverinfo:{valType:"flaglist",flags:["x","y","z","text","name"],extras:["all","none","skip"],arrayOk:!0,dflt:"all",editType:"none",description:["Determines which trace information appear on hover.","If `none` or `skip` are set, no information is displayed upon hovering.","But, if `none` is set, click and hover events are still fired."].join(" ")},hoverlabel:i.hoverlabel,stream:{token:{valType:"string",noBlank:!0,strict:!0,editType:"calc",description:["The stream id number links a data trace on a plot with a stream.","See https://chart-studio.plotly.com/settings for more details."].join(" ")},maxpoints:{valType:"number",min:0,max:1e4,dflt:500,editType:"calc",description:["Sets the maximum number of points to keep on the plots from an","incoming stream.","If `maxpoints` is set to *50*, only the newest 50 points will","be displayed on the plot."].join(" ")},editType:"calc"},transforms:{_isLinkedToArray:"transform",editType:"calc",description:["WARNING: All transforms are deprecated and may be removed from the API in next major version.","An array of operations that manipulate the trace data,","for example filtering or sorting the data arrays."].join(" ")},uirevision:{valType:"any",editType:"none",description:["Controls persistence of some user-driven changes to the trace:","`constraintrange` in `parcoords` traces, as well as some","`editable: true` modifications such as `name` and `colorbar.title`.","Defaults to `layout.uirevision`.","Note that other user-driven trace attribute changes are controlled","by `layout` attributes:","`trace.visible` is controlled by `layout.legend.uirevision`,","`selectedpoints` is controlled by `layout.selectionrevision`,","and `colorbar.(x|y)` (accessible with `config: {editable: true}`)","is controlled by `layout.editrevision`.","Trace changes are tracked by `uid`, which only falls back on trace","index if no `uid` is provided. So if your app can add/remove traces","before the end of the `data` array, such that the same trace has a","different index, you can still preserve user-driven changes if you","give each trace a `uid` that stays with it as it moves."].join(" ")}}},35087:(e,t,r)=>{"use strict";var n=r(22036),i=r(84468),o=i.dateTime2ms,a=i.incrementMonth,s=r(65004).ONEAVGMONTH;e.exports=function(e,t,r,i){if("date"!==t.type)return{vals:i};var l=e[r+"periodalignment"];if(!l)return{vals:i};var c,u=e[r+"period"];if(n(u)){if((u=+u)<=0)return{vals:i}}else if("string"===typeof u&&"M"===u.charAt(0)){var d=+u.substring(1);if(!(d>0&&Math.round(d)===d))return{vals:i};c=d}for(var h=t.calendar,p="start"===l,f="end"===l,m=e[r+"period0"],g=o(m,h)||0,y=[],v=[],x=[],b=i.length,_=0;_A;)S=a(S,-c,h);for(;S<=A;)S=a(S,c,h);k=a(S,-c,h)}else{for(S=g+(w=Math.round((A-g)/u))*u;S>A;)S-=u;for(;S<=A;)S+=u;k=S-u}y[_]=p?k:f?S:(k+S)/2,v[_]=k,x[_]=S}return{vals:y,starts:v,ends:x}}},86237:e=>{"use strict";e.exports={xaxis:{valType:"subplotid",dflt:"x",editType:"calc+clearAxisTypes",description:["Sets a reference between this trace's x coordinates and","a 2D cartesian x axis.","If *x* (the default value), the x coordinates refer to","`layout.xaxis`.","If *x2*, the x coordinates refer to `layout.xaxis2`, and so on."].join(" ")},yaxis:{valType:"subplotid",dflt:"y",editType:"calc+clearAxisTypes",description:["Sets a reference between this trace's y coordinates and","a 2D cartesian y axis.","If *y* (the default value), the y coordinates refer to","`layout.yaxis`.","If *y2*, the y coordinates refer to `layout.yaxis2`, and so on."].join(" ")}}},49618:(e,t,r)=>{"use strict";var n=r(41871),i=r(22036),o=r(84468),a=r(65004).FP_SAFE,s=r(38361),l=r(3172),c=r(11576),u=c.getFromId,d=c.isLinked;function h(e,t){var r,n,i=[],a=e._fullLayout,s=f(a,t,0),l=f(a,t,1),c=g(e,t),u=c.min,d=c.max;if(0===u.length||0===d.length)return o.simpleMap(t.range,t.r2l);var h=u[0].val,m=d[0].val;for(r=1;r0&&((A=I-s(b)-l(_))>P?T/A>O&&(w=b,k=_,O=T/A):T/I>O&&(w={val:b.val,nopad:1},k={val:_.val,nopad:1},O=T/I));if(h===m){var R=h-1,L=h+1;if(C)if(0===h)i=[0,1];else{var D=(h>0?d:u).reduce((function(e,t){return Math.max(e,l(t))}),0),z=h/(1-Math.min(.5,D/I));i=h>0?[0,z]:[z,0]}else i=E?[Math.max(0,R),Math.max(1,L)]:[R,L]}else C?(w.val>=0&&(w={val:0,nopad:1}),k.val<=0&&(k={val:0,nopad:1})):E&&(w.val-O*s(w)<0&&(w={val:0,nopad:1}),k.val<=0&&(k={val:1,nopad:1})),O=(k.val-w.val-p(t,b.val,_.val))/(I-s(w)-l(k)),i=[w.val-O*s(w),k.val+O*l(k)];return i=S(i,t),t.limitRange&&t.limitRange(),v&&i.reverse(),o.simpleMap(i,t.l2r||Number)}function p(e,t,r){var n=0;if(e.rangebreaks)for(var i=e.locateBreaks(t,r),o=0;o0?r.ppadplus:r.ppadminus)||r.ppad||0),M=A((e._m>0?r.ppadminus:r.ppadplus)||r.ppad||0),C=A(r.vpadplus||r.vpad),E=A(r.vpadminus||r.vpad);if(!k){if(h=1/0,p=-1/0,w)for(n=0;n0&&(h=o),o>p&&o-a&&(h=o),o>p&&o=O;n--)P(n);return{min:f,max:m,opts:r}},concatExtremes:g};var m=3;function g(e,t,r){var n,i,o,a=t._id,s=e._fullData,l=e._fullLayout,c=[],d=[];function h(e,t){for(n=0;n=r&&(c.extrapad||!a)){s=!1;break}i(t,c.val)&&c.pad<=r&&(a||!c.extrapad)&&(e.splice(l,1),l--)}if(s){var u=o&&0===t;e.push({val:t,pad:u?0:r,extrapad:!u&&a})}}function b(e){return i(e)&&Math.abs(e)=t}function k(e,t,r){return void 0===t||void 0===r||(t=e.d2l(t))<(r=e.d2l(r))}function S(e,t){if(!t||!t.autorangeoptions)return e;var r=e[0],n=e[1],i=t.autorangeoptions.include;if(void 0!==i){var a=t.d2l(r),s=t.d2l(n);o.isArrayOrTypedArray(i)||(i=[i]);for(var l=0;l=c&&(a=c,r=c),s<=c&&(s=c,n=c)}}return r=function(e,t){var r=t.autorangeoptions;return r&&void 0!==r.minallowed&&k(t,r.minallowed,r.maxallowed)?r.minallowed:r&&void 0!==r.clipmin&&k(t,r.clipmin,r.clipmax)?Math.max(e,t.d2l(r.clipmin)):e}(r,t),n=function(e,t){var r=t.autorangeoptions;return r&&void 0!==r.maxallowed&&k(t,r.minallowed,r.maxallowed)?r.maxallowed:r&&void 0!==r.clipmax&&k(t,r.clipmin,r.clipmax)?Math.min(e,t.d2l(r.clipmax)):e}(n,t),[r,n]}},87832:e=>{"use strict";e.exports=function(e,t,r){var n,i;if(r){var o="reversed"===t||"min reversed"===t||"max reversed"===t;n=r[o?1:0],i=r[o?0:1]}var a=e("autorangeoptions.minallowed",null===i?n:void 0),s=e("autorangeoptions.maxallowed",null===n?i:void 0);void 0===a&&e("autorangeoptions.clipmin"),void 0===s&&e("autorangeoptions.clipmax"),e("autorangeoptions.include")}},85729:(e,t,r)=>{"use strict";var n=r(41871),i=r(22036),o=r(68543),a=r(38361),s=r(84468),l=s.strTranslate,c=r(13480),u=r(13701),d=r(7605),h=r(3172),p=r(49080),f=r(13530),m=r(65004),g=m.ONEMAXYEAR,y=m.ONEAVGYEAR,v=m.ONEMINYEAR,x=m.ONEMAXQUARTER,b=m.ONEAVGQUARTER,_=m.ONEMINQUARTER,w=m.ONEMAXMONTH,k=m.ONEAVGMONTH,S=m.ONEMINMONTH,A=m.ONEWEEK,T=m.ONEDAY,M=T/2,C=m.ONEHOUR,E=m.ONEMIN,I=m.ONESEC,P=m.ONEMILLI,O=m.ONEMICROSEC,R=m.MINUS_SIGN,L=m.BADNUM,D={K:"zeroline"},z={K:"gridline",L:"path"},j={K:"minor-gridline",L:"path"},F={K:"tick",L:"path"},N={K:"tick",L:"text"},B={width:["x","r","l","xl","xr"],height:["y","t","b","yt","yb"],right:["r","xr"],left:["l","xl"],top:["t","yt"],bottom:["b","yb"]},V=r(83943),U=V.MID_SHIFT,H=V.CAP_SHIFT,$=V.LINE_SPACING,W=V.OPPOSITE_SIDE,q=e.exports={};q.setConvert=r(45958);var G=r(84339),Y=r(11576),X=Y.idSort,Z=Y.isLinked;q.id2name=Y.id2name,q.name2id=Y.name2id,q.cleanId=Y.cleanId,q.list=Y.list,q.listIds=Y.listIds,q.getFromId=Y.getFromId,q.getFromTrace=Y.getFromTrace;var K=r(49618);q.getAutoRange=K.getAutoRange,q.findExtremes=K.findExtremes;function J(e){var t=1e-4*(e[1]-e[0]);return[e[0]-t,e[1]+t]}q.coerceRef=function(e,t,r,n,i,o){var a=n.charAt(n.length-1),l=r._fullLayout._subplots[a+"axis"],c=n+"ref",u={};return i||(i=l[0]||("string"===typeof o?o:o[0])),o||(o=i),l=l.concat(l.map((function(e){return e+" domain"}))),u[c]={valType:"enumerated",values:l.concat(o?"string"===typeof o?[o]:o:[]),dflt:i},s.coerce(e,t,u,c)},q.getRefType=function(e){return void 0===e?e:"paper"===e?"paper":"pixel"===e?"pixel":/( domain)$/.test(e)?"domain":"range"},q.coercePosition=function(e,t,r,n,i,o){var a,l;if("range"!==q.getRefType(n))a=s.ensureNumber,l=r(i,o);else{var c=q.getFromId(t,n);l=r(i,o=c.fraction2r(o)),a=c.cleanPos}e[i]=a(l)},q.cleanPosition=function(e,t,r){return("paper"===r||"pixel"===r?s.ensureNumber:q.getFromId(t,r).cleanPos)(e)},q.redrawComponents=function(e,t){t=t||q.listIds(e);var r=e._fullLayout;function n(n,i,o,s){for(var l=a.getComponentMethod(n,i),c={},u=0;un&&h2e-6||((r-e._forceTick0)/e._minDtick%1+1.000001)%1>2e-6)&&(e._minDtick=0)):e._minDtick=0},q.saveRangeInitial=function(e,t){for(var r=q.list(e,"",!0),n=!1,i=0;i.3*h||u(n)||u(o))){var p=r.dtick/2;e+=e+pa){var l=Number(r.substr(1));o.exactYears>a&&l%12===0?e=q.tickIncrement(e,"M6","reverse")+1.5*T:o.exactMonths>a?e=q.tickIncrement(e,"M1","reverse")+15.5*T:e-=M;var c=q.tickIncrement(e,r);if(c<=n)return c}return e}(v,e,y,c,o)),g=v,0;g<=u;)g=q.tickIncrement(g,y,!1,o);return{start:t.c2r(v,0,o),end:t.c2r(g,0,o),size:y,_dataSpan:u-c}},q.prepMinorTicks=function(e,t,r){if(!t.minor.dtick){delete e.dtick;var n,o=t.dtick&&i(t._tmin);if(o){var a=q.tickIncrement(t._tmin,t.dtick,!0);n=[t._tmin,.99*a+.01*t._tmin]}else{var l=s.simpleMap(t.range,t.r2l);n=[l[0],.8*l[0]+.2*l[1]]}if(e.range=s.simpleMap(n,t.l2r),e._isMinor=!0,q.prepTicks(e,r),o){var c=i(t.dtick),u=i(e.dtick),d=c?t.dtick:+t.dtick.substring(1),h=u?e.dtick:+e.dtick.substring(1);c&&u?re(d,h)?d===2*A&&h===2*T&&(e.dtick=A):d===2*A&&h===3*T?e.dtick=A:d!==A||(t._input.minor||{}).nticks?ne(d/h,2.5)?e.dtick=d/2:e.dtick=d:e.dtick=T:"M"===String(t.dtick).charAt(0)?u?e.dtick="M1":re(d,h)?d>=12&&2===h&&(e.dtick="M3"):e.dtick=t.dtick:"L"===String(e.dtick).charAt(0)?"L"===String(t.dtick).charAt(0)?re(d,h)||(e.dtick=ne(d/h,2.5)?t.dtick/2:t.dtick):e.dtick="D1":"D2"===e.dtick&&+t.dtick>1&&(e.dtick=1)}e.range=t.range}void 0===t.minor._tick0Init&&(e.tick0=t.tick0)},q.prepTicks=function(e,t){var r=s.simpleMap(e.range,e.r2l,void 0,void 0,t);if("auto"===e.tickmode||!e.dtick){var n,o=e.nticks;o||("category"===e.type||"multicategory"===e.type?(n=e.tickfont?s.bigFont(e.tickfont.size||12):15,o=e._length/n):(n="y"===e._id.charAt(0)?40:80,o=s.constrain(e._length/n,4,9)+1),"radialaxis"===e._name&&(o*=2)),e.minor&&"array"!==e.minor.tickmode||"array"===e.tickmode&&(o*=100),e._roughDTick=Math.abs(r[1]-r[0])/o,q.autoTicks(e,e._roughDTick),e._minDtick>0&&e.dtick<2*e._minDtick&&(e.dtick=e._minDtick,e.tick0=e.l2r(e._forceTick0))}"period"===e.ticklabelmode&&function(e){var t;function r(){return!(i(e.dtick)||"M"!==e.dtick.charAt(0))}var n=r(),o=q.getTickFormat(e);if(o){var a=e._dtickInit!==e.dtick;/%[fLQsSMX]/.test(o)||(/%[HI]/.test(o)?(t=C,a&&!n&&e.dticke.range[1],p=!e.ticklabelindex||s.isArrayOrTypedArray(e.ticklabelindex)?e.ticklabelindex:[e.ticklabelindex],f=s.simpleMap(e.range,e.r2l,void 0,void 0,t),m=f[1]=(U?0:1);H--){var $=!H;H?(e._dtickInit=e.dtick,e._tick0Init=e.tick0):(e.minor._dtickInit=e.minor.dtick,e.minor._tick0Init=e.minor.tick0);var W=H?e:s.extendFlat({},e,e.minor);if($?q.prepMinorTicks(W,e,t):q.prepTicks(W,t),"array"!==W.tickmode)if("sync"!==W.tickmode){var G=J(f),Y=G[0],X=G[1],Z=i(W.dtick),K="log"===l&&!(Z||"L"===W.dtick.charAt(0)),Q=q.tickFirst(W,t);if(H){if(e._tmin=Q,Q=X:ne<=X;ne=q.tickIncrement(ne,ie,m,c)){if(H&&ee++,W.rangebreaks&&!m){if(ne=D)break}if(N.length>z||ne===re)break;re=ne;var oe={value:ne};H?(K&&ne!==(0|ne)&&(oe.simpleLabel=!0),u>1&&ee%u&&(oe.skipLabel=!0),N.push(oe)):(oe.minor=!0,B.push(oe))}}else N=[],j=ae(e);else H?(N=[],j=se(e,!$)):(B=[],F=se(e,!$))}if(!B||B.length<2)p=!1;else{var le=(B[1].value-B[0].value)*(h?-1:1);r=le,n=e.tickformat,(/%f/.test(n)?r>=O:/%L/.test(n)?r>=P:/%[SX]/.test(n)?r>=I:/%M/.test(n)?r>=E:/%[HI]/.test(n)?r>=C:/%p/.test(n)?r>=M:/%[Aadejuwx]/.test(n)?r>=T:/%[UVW]/.test(n)?r>=A:/%[Bbm]/.test(n)?r>=S:/%[q]/.test(n)?r>=_:!/%[Yy]/.test(n)||r>=v)||(p=!1)}if(p){var ce=N.concat(B);d&&N.length&&(ce=ce.slice(1)),(ce=ce.sort((function(e,t){return e.value-t.value})).filter((function(e,t,r){return 0===t||e.value!==r[t-1].value}))).map((function(e,t){return void 0!==e.minor||e.skipLabel?null:t})).filter((function(e){return null!==e})).forEach((function(e){p.map((function(t){var r=e+t;r>=0&&r0?(o=n-1,a=n):(o=n,a=n);var s,l=e[o].value,c=e[a].value,u=Math.abs(c-l),d=r||u,h=0;d>=v?h=u>=v&&u<=g?u:y:r===b&&d>=_?h=u>=_&&u<=x?u:b:d>=S?h=u>=S&&u<=w?u:k:r===A&&d>=A?h=A:d>=T?h=T:r===M&&d>=M?h=M:r===C&&d>=C&&(h=C),h>=u&&(h=u,s=!0);var p=i+h;if(t.rangebreaks&&h>0){for(var f=0,m=0;m<84;m++){var E=(m+.5)/84;t.maskBreaks(i*(1-E)+E*p)!==L&&f++}(h*=f/84)||(e[n].drop=!0),s&&u>A&&(h=u)}(h>0||0===n)&&(e[n].periodX=i+h/2)}}(V,e,e._definedDelta),e.rangebreaks){var ye="y"===e._id.charAt(0),ve=1;"auto"===e.tickmode&&(ve=e.tickfont?e.tickfont.size:12);var xe=NaN;for(o=N.length-1;o>-1;o--)if(N[o].drop)N.splice(o,1);else{N[o].value=ze(N[o].value,e);var be=e.c2p(N[o].value);(ye?xe>be-ve:xeD||nD&&(r.periodX=D),n10||"01-01"!==n.substr(5)?e._tickround="d":e._tickround=+t.substr(1)%12===0?"y":"m";else if(t>=T&&o<=10||t>=15*T)e._tickround="d";else if(t>=E&&o<=16||t>=C)e._tickround="M";else if(t>=I&&o<=19||t>=E)e._tickround="S";else{var a=e.l2r(r+t).replace(/^-/,"").length;e._tickround=Math.max(o,a)-20,e._tickround<0&&(e._tickround=4)}}else if(i(t)||"L"===t.charAt(0)){var s=e.range.map(e.r2d||Number);i(t)||(t=Number(t.substr(1))),e._tickround=2-Math.floor(Math.log(t)/Math.LN10+.01);var l=Math.max(Math.abs(s[0]),Math.abs(s[1])),c=Math.floor(Math.log(l)/Math.LN10+.01),u=void 0===e.minexponent?3:e.minexponent;Math.abs(c)>u&&(xe(e.exponentformat)&&!be(c)?e._tickexponent=3*Math.round((c-1)/3):e._tickexponent=c)}else e._tickround=null}function ye(e,t,r){var n=e.tickfont||{};return{x:t,dx:0,dy:0,text:r||"",fontSize:n.size,font:n.family,fontWeight:n.weight,fontStyle:n.style,fontVariant:n.variant,fontTextcase:n.textcase,fontLineposition:n.lineposition,fontShadow:n.shadow,fontColor:n.color}}q.autoTicks=function(e,t,r){var n;function o(e){return Math.pow(e,Math.floor(Math.log(t)/Math.LN10))}if("date"===e.type){e.tick0=s.dateTick0(e.calendar,0);var a=2*t;if(a>y)t/=y,n=o(10),e.dtick="M"+12*me(t,n,le);else if(a>k)t/=k,e.dtick="M"+me(t,1,ce);else if(a>T){if(e.dtick=me(t,T,e._hasDayOfWeekBreaks?[1,2,7,14]:de),!r){var l=q.getTickFormat(e),c="period"===e.ticklabelmode;c&&(e._rawTick0=e.tick0),/%[uVW]/.test(l)?e.tick0=s.dateTick0(e.calendar,2):e.tick0=s.dateTick0(e.calendar,1),c&&(e._dowTick0=e.tick0)}}else a>C?e.dtick=me(t,C,ce):a>E?e.dtick=me(t,E,ue):a>I?e.dtick=me(t,I,ue):(n=o(10),e.dtick=me(t,n,le))}else if("log"===e.type){e.tick0=0;var u=s.simpleMap(e.range,e.r2l);if(e._isMinor&&(t*=1.5),t>.7)e.dtick=Math.ceil(t);else if(Math.abs(u[1]-u[0])<1){var d=1.5*Math.abs((u[1]-u[0])/t);t=Math.abs(Math.pow(10,u[1])-Math.pow(10,u[0]))/d,n=o(10),e.dtick="L"+me(t,n,le)}else e.dtick=t>.3?"D2":"D1"}else"category"===e.type||"multicategory"===e.type?(e.tick0=0,e.dtick=Math.ceil(Math.max(t,1))):De(e)?(e.tick0=0,n=1,e.dtick=me(t,n,fe)):(e.tick0=0,n=o(10),e.dtick=me(t,n,le));if(0===e.dtick&&(e.dtick=1),!i(e.dtick)&&"string"!==typeof e.dtick){var h=e.dtick;throw e.dtick=1,"ax.dtick error: "+String(h)}},q.tickIncrement=function(e,t,r,o){var a=r?-1:1;if(i(t))return s.increment(e,a*t);var l=t.charAt(0),c=a*Number(t.substr(1));if("M"===l)return s.incrementMonth(e,c,o);if("L"===l)return Math.log(Math.pow(10,e)+c)/Math.LN10;if("D"===l){var u="D2"===t?pe:he,d=e+.01*a,h=s.roundUp(s.mod(d,1),u,r);return Math.floor(d)+Math.log(n.round(Math.pow(10,h),1))/Math.LN10}throw"unrecognized dtick "+String(t)},q.tickFirst=function(e,t){var r=e.r2l||Number,o=s.simpleMap(e.range,r,void 0,void 0,t),a=o[1]=0&&r<=e._length?t:null};if(l&&s.isArrayOrTypedArray(e.ticktext)){var p=s.simpleMap(e.range,e.r2l),f=(Math.abs(p[1]-p[0])-(e._lBreaks||0))/1e4;for(o=0;o ")}else e._prevDateHead=l,c+="
"+l;t.text=c}(e,a,r,c):"log"===u?function(e,t,r,n,o){var a=e.dtick,l=t.x,c=e.tickformat,u="string"===typeof a&&a.charAt(0);"never"===o&&(o="");n&&"L"!==u&&(a="L3",u="L");if(c||"L"===u)t.text=_e(Math.pow(10,l),e,o,n);else if(i(a)||"D"===u&&s.mod(l+.01,1)<.1){var d=Math.round(l),h=Math.abs(d),p=e.exponentformat;"power"===p||xe(p)&&be(d)?(t.text=0===d?1:1===d?"10":"10"+(d>1?"":R)+h+"",t.fontSize*=1.25):("e"===p||"E"===p)&&h>2?t.text="1"+p+(d>0?"+":R)+h:(t.text=_e(Math.pow(10,l),e,"","fakehover"),"D1"===a&&"y"===e._id.charAt(0)&&(t.dy-=t.fontSize/6))}else{if("D"!==u)throw"unrecognized dtick "+String(a);t.text=String(Math.round(Math.pow(10,s.mod(l,1)))),t.fontSize*=.75}if("D1"===e.dtick){var f=String(t.text).charAt(0);"0"!==f&&"1"!==f||("y"===e._id.charAt(0)?t.dx-=t.fontSize/4:(t.dy+=t.fontSize/2,t.dx+=(e.range[1]>e.range[0]?1:-1)*t.fontSize*(l<0?.5:.25)))}}(e,a,0,c,g):"category"===u?function(e,t){var r=e._categories[Math.round(t.x)];void 0===r&&(r="");t.text=String(r)}(e,a):"multicategory"===u?function(e,t,r){var n=Math.round(t.x),i=e._categories[n]||[],o=void 0===i[1]?"":String(i[1]),a=void 0===i[0]?"":String(i[0]);r?t.text=a+" - "+o:(t.text=o,t.text2=a)}(e,a,r):De(e)?function(e,t,r,n,i){if("radians"!==e.thetaunit||r)t.text=_e(t.x,e,i,n);else{var o=t.x/180;if(0===o)t.text="0";else{var a=function(e){function t(e,t){return Math.abs(e-t)<=1e-6}function r(e,n){return t(n,0)?e:r(n,e%n)}function n(e){for(var r=1;!t(Math.round(e*r)/r,e);)r*=10;return r}var i=n(e),o=e*i,a=Math.abs(r(o,i));return[Math.round(o/a),Math.round(i/a)]}(o);if(a[1]>=100)t.text=_e(s.deg2rad(t.x),e,i,n);else{var l=t.x<0;1===a[1]?1===a[0]?t.text="\u03c0":t.text=a[0]+"\u03c0":t.text=["",a[0],"","\u2044","",a[1],"","\u03c0"].join(""),l&&(t.text=R+t.text)}}}}(e,a,r,c,g):function(e,t,r,n,i){"never"===i?i="":"all"===e.showexponent&&Math.abs(t.x/e.dtick)<1e-6&&(i="hide");t.text=_e(t.x,e,i,n)}(e,a,0,c,g),n||(e.tickprefix&&!m(e.showtickprefix)&&(a.text=e.tickprefix+a.text),e.ticksuffix&&!m(e.showticksuffix)&&(a.text+=e.ticksuffix)),e.labelalias&&e.labelalias.hasOwnProperty(a.text)){var y=e.labelalias[a.text];"string"===typeof y&&(a.text=y)}return("boundaries"===e.tickson||e.showdividers)&&(a.xbnd=[h(a.x-.5),h(a.x+e.dtick-.5)]),a},q.hoverLabelText=function(e,t,r){r&&(e=s.extendFlat({},e,{hoverformat:r}));var n=s.isArrayOrTypedArray(t)?t[0]:t,i=s.isArrayOrTypedArray(t)?t[1]:void 0;if(void 0!==i&&i!==n)return q.hoverLabelText(e,n,r)+" - "+q.hoverLabelText(e,i,r);var o="log"===e.type&&n<=0,a=q.tickText(e,e.c2l(o?-n:n),"hover").text;return o?0===n?"0":R+a:a};var ve=["f","p","n","\u03bc","m","","k","M","G","T"];function xe(e){return"SI"===e||"B"===e}function be(e){return e>14||e<-15}function _e(e,t,r,n){var o=e<0,a=t._tickround,l=r||t.exponentformat||"B",c=t._tickexponent,u=q.getTickFormat(t),d=t.separatethousands;if(n){var h={exponentformat:l,minexponent:t.minexponent,dtick:"none"===t.showexponent?t.dtick:i(e)&&Math.abs(e)||1,range:"none"===t.showexponent?t.range.map(t.r2d):[0,e||1]};ge(h),a=(Number(h._tickround)||0)+4,c=h._tickexponent,t.hoverformat&&(u=t.hoverformat)}if(u)return t._numFormat(u)(e).replace(/-/g,R);var p,f=Math.pow(10,-a)/2;if("none"===l&&(c=0),(e=Math.abs(e))"+p+"
":"B"===l&&9===c?e+="B":xe(l)&&(e+=ve[c/3+5]));return o?R+e:e}function we(e,t){if(e){var r=Object.keys(B).reduce((function(e,r){return-1!==t.indexOf(r)&&B[r].forEach((function(t){e[t]=1})),e}),{});Object.keys(e).forEach((function(t){r[t]||(1===t.length?e[t]=0:delete e[t])}))}}function ke(e,t){for(var r=[],n={},i=0;i1&&r=i.min&&e=n(e))}function s(e,t){var r=null===t[0],n=null===t[1],i=o(e,t[0])>=0,a=o(e,t[1])<=0;return(r||i)&&(n||a)}if(e.tickformatstops&&e.tickformatstops.length>0)switch(e.type){case"date":case"linear":for(t=0;t=0&&i.unshift(i.splice(n,1).shift())}}));var a={false:{left:0,right:0}};return s.syncOrAsync(i.map((function(t){return function(){if(t){var n=q.getFromId(e,t);r||(r={}),r.axShifts=a,r.overlayingShiftedAx=o;var i=q.drawOne(e,n,r);return n._shiftPusher&&Ne(n,n._fullDepth||0,a,!0),n._r=n.range.slice(),n._rl=s.simpleMap(n._r,n.r2l),i}}})))},q.drawOne=function(e,t,r){var n,i,l,p=(r=r||{}).axShifts||{},f=r.overlayingShiftedAx||[];t.setScale();var m=e._fullLayout,g=t._id,y=g.charAt(0),v=q.counterLetter(g),x=m._plots[t._mainSubplot];if(x){if(t._shiftPusher=t.autoshift||-1!==f.indexOf(t._id)||-1!==f.indexOf(t.overlaying),t._shiftPusher&"free"===t.anchor){var b=t.linewidth/2||0;"inside"===t.ticks&&(b+=t.ticklen),Ne(t,b,p,!0),Ne(t,t.shift||0,p,!1)}!0===r.skipTitle&&void 0!==t._shift||(t._shift=function(e,t){return e.autoshift?t[e.overlaying][e.side]:e.shift||0}(t,p));var _=x[y+"axislayer"],w=t._mainLinePosition,k=w+=t._shift,S=t._mainMirrorPosition,A=t._vals=q.calcTicks(t),T=[t.mirror,k,S].join("_");for(n=0;n0?r.bottom-u:0,d))));var h=0,p=0;if(t._shiftPusher&&(h=Math.max(d,r.height>0?"l"===l?u-r.left:r.right-u:0),t.title.text!==m._dfltTitle[y]&&(p=(t._titleStandoff||0)+(t._titleScoot||0),"l"===l&&(p+=Te(t))),t._fullDepth=Math.max(h,p)),t.automargin){n={x:0,y:0,r:0,l:0,t:0,b:0};var f=[0,1],g="number"===typeof t._shift?t._shift:0;if("x"===y){if("b"===l?n[l]=t._depth:(n[l]=t._depth=Math.max(r.width>0?u-r.top:0,d),f.reverse()),r.width>0){var x=r.right-(t._offset+t._length);x>0&&(n.xr=1,n.r=x);var b=t._offset-r.left;b>0&&(n.xl=0,n.l=b)}}else if("l"===l?(t._depth=Math.max(r.height>0?u-r.left:0,d),n[l]=t._depth-g):(t._depth=Math.max(r.height>0?r.right-u:0,d),n[l]=t._depth+g,f.reverse()),r.height>0){var _=r.bottom-(t._offset+t._length);_>0&&(n.yb=0,n.b=_);var w=t._offset-r.top;w>0&&(n.yt=1,n.t=w)}n[v]="free"===t.anchor?t.position:t._anchorAxis.domain[f[0]],t.title.text!==m._dfltTitle[y]&&(n[l]+=Te(t)+(t.title.standoff||0)),t.mirror&&"free"!==t.anchor&&((i={x:0,y:0,r:0,l:0,t:0,b:0})[c]=t.linewidth,t.mirror&&!0!==t.mirror&&(i[c]+=d),!0===t.mirror||"ticks"===t.mirror?i[v]=t._anchorAxis.domain[f[1]]:"all"!==t.mirror&&"allticks"!==t.mirror||(i[v]=[t._counterDomainMin,t._counterDomainMax][f[1]]))}de&&(s=a.getComponentMethod("rangeslider","autoMarginOpts")(e,t)),"string"===typeof t.automargin&&(we(n,t.automargin),we(i,t.automargin)),o.autoMargin(e,Ee(t),n),o.autoMargin(e,Ie(t),i),o.autoMargin(e,Pe(t),s)})),s.syncOrAsync(ce)}}function he(e){var r=g+(e||"tick");return M[r]||(M[r]=function(e,t,r){var n,i,o,a;if(e._selections[t].size())n=1/0,i=-1/0,o=1/0,a=-1/0,e._selections[t].each((function(){var e=Ce(this),t=h.bBox(e.node().parentNode);n=Math.min(n,t.top),i=Math.max(i,t.bottom),o=Math.min(o,t.left),a=Math.max(a,t.right)}));else{var s=q.makeLabelFns(e,r);n=i=s.yFn({dx:0,dy:0,fontSize:0}),o=a=s.xFn({dx:0,dy:0,fontSize:0})}return{top:n,bottom:i,left:o,right:a,height:i-n,width:a-o}}(t,r,k)),M[r]}},q.getTickSigns=function(e,t){var r=e._id.charAt(0),n={x:"top",y:"right"}[r],i=e.side===n?1:-1,o=[-1,1,i,-i];return"inside"!==(t?(e.minor||{}).ticks:e.ticks)===("x"===r)&&(o=o.map((function(e){return-e}))),e.side&&o.push({l:-1,t:-1,r:1,b:1}[e.side.charAt(0)]),o},q.makeTransTickFn=function(e){return"x"===e._id.charAt(0)?function(t){return l(e._offset+e.l2p(t.x),0)}:function(t){return l(0,e._offset+e.l2p(t.x))}},q.makeTransTickLabelFn=function(e){var t=function(e){var t=e.ticklabelposition||"",r=function(e){return-1!==t.indexOf(e)},n=r("top"),i=r("left"),o=r("right"),a=r("bottom"),s=r("inside"),l=a||i||n||o;if(!l&&!s)return[0,0];var c=e.side,u=l?(e.tickwidth||0)/2:0,d=3,h=e.tickfont?e.tickfont.size:12;(a||n)&&(u+=h*H,d+=(e.linewidth||0)/2);(i||o)&&(u+=(e.linewidth||0)/2,d+=3);s&&"top"===c&&(d-=h*(1-H));(i||n)&&(u=-u);"bottom"!==c&&"right"!==c||(d=-d);return[l?u:0,s?d:0]}(e),r=e.ticklabelshift||0,n=e.ticklabelstandoff||0,i=t[0],o=t[1],a=e.range[0]>e.range[1],s=e.ticklabelposition&&-1!==e.ticklabelposition.indexOf("inside"),c=!s;r&&(r*=a?-1:1);if(n){var u=e.side;n*=s&&("top"===u||"left"===u)||c&&("bottom"===u||"right"===u)?1:-1}return"x"===e._id.charAt(0)?function(t){return l(i+e._offset+e.l2p(Se(t))+r,o+n)}:function(t){return l(o+n,i+e._offset+e.l2p(Se(t))+r)}},q.makeTickPath=function(e,t,r,n){n||(n={});var i=n.minor;if(i&&!e.minor)return"";var o=void 0!==n.len?n.len:i?e.minor.ticklen:e.ticklen,a=e._id.charAt(0),s=(e.linewidth||1)/2;return"x"===a?"M0,"+(t+s*r)+"v"+o*r:"M"+(t+s*r)+",0h"+o*r},q.makeLabelFns=function(e,t,r){var n=e.ticklabelposition||"",o=function(e){return-1!==n.indexOf(e)},a=o("top"),l=o("left"),c=o("right"),u=o("bottom")||l||a||c,d=o("inside"),h="inside"===n&&"inside"===e.ticks||!d&&"outside"===e.ticks&&"boundaries"!==e.tickson,p=0,f=0,m=h?e.ticklen:0;if(d?m*=-1:u&&(m=0),h&&(p+=m,r)){var g=s.deg2rad(r);p=m*Math.cos(g)+1,f=m*Math.sin(g)}e.showticklabels&&(h||e.showline)&&(p+=.2*e.tickfont.size);var y,v,x,b,_,w={labelStandoff:p+=(e.linewidth||1)/2*(d?-1:1),labelShift:f},k=0,S=e.side,A=e._id.charAt(0),T=e.tickangle;if("x"===A)b=(_=!d&&"bottom"===S||d&&"top"===S)?1:-1,d&&(b*=-1),y=f*b,v=t+p*b,x=_?1:-.2,90===Math.abs(T)&&(d?x+=U:x=-90===T&&"bottom"===S?H:90===T&&"top"===S?U:.5,k=U/2*(T/90)),w.xFn=function(e){return e.dx+y+k*e.fontSize},w.yFn=function(e){return e.dy+v+e.fontSize*x},w.anchorFn=function(e,t){if(u){if(l)return"end";if(c)return"start"}return i(t)&&0!==t&&180!==t?t*b<0!==d?"end":"start":"middle"},w.heightFn=function(t,r,n){return r<-60||r>60?-.5*n:"top"===e.side!==d?-n:0};else if("y"===A){if(b=(_=!d&&"left"===S||d&&"right"===S)?1:-1,d&&(b*=-1),y=p,v=f*b,x=0,d||90!==Math.abs(T)||(x=-90===T&&"left"===S||90===T&&"right"===S?H:.5),d){var M=i(T)?+T:0;if(0!==M){var C=s.deg2rad(M);k=Math.abs(Math.sin(C))*H*b,x=0}}w.xFn=function(e){return e.dx+t-(y+e.fontSize*x)*b+k*e.fontSize},w.yFn=function(e){return e.dy+v+e.fontSize*U},w.anchorFn=function(e,t){return i(t)&&90===Math.abs(t)?"middle":_?"end":"start"},w.heightFn=function(t,r,n){return"right"===e.side&&(r*=-1),r<-30?-n:r<30?-.5*n:0}}return w},q.drawTicks=function(e,t,r){r=r||{};var i=t._id+"tick",o=[].concat(t.minor&&t.minor.ticks?r.vals.filter((function(e){return e.minor&&!e.noTick})):[]).concat(t.ticks?r.vals.filter((function(e){return!e.minor&&!e.noTick})):[]),a=r.layer.selectAll("path."+i).data(o,Ae);a.exit().remove(),a.enter().append("path").classed(i,1).classed("ticks",1).classed("crisp",!1!==r.crisp).each((function(e){return d.stroke(n.select(this),e.minor?t.minor.tickcolor:t.tickcolor)})).style("stroke-width",(function(r){return h.crispRound(e,r.minor?t.minor.tickwidth:t.tickwidth,1)+"px"})).attr("d",r.path).style("display",null),Fe(t,[F]),a.attr("transform",r.transFn)},q.drawGrid=function(e,t,r){if(r=r||{},"sync"!==t.tickmode){var i=t._id+"grid",o=t.minor&&t.minor.showgrid,a=o?r.vals.filter((function(e){return e.minor})):[],s=t.showgrid?r.vals.filter((function(e){return!e.minor})):[],l=r.counterAxis;if(l&&q.shouldShowZeroLine(e,t,l))for(var c="array"===t.tickmode,u=0;u=0;y--){var v=y?m:g;if(v){var x=v.selectAll("path."+i).data(y?s:a,Ae);x.exit().remove(),x.enter().append("path").classed(i,1).classed("crisp",!1!==r.crisp),x.attr("transform",r.transFn).attr("d",r.path).each((function(e){return d.stroke(n.select(this),e.minor?t.minor.gridcolor:t.gridcolor||"#ddd")})).style("stroke-dasharray",(function(e){return h.dashStyle(e.minor?t.minor.griddash:t.griddash,e.minor?t.minor.gridwidth:t.gridwidth)})).style("stroke-width",(function(e){return(e.minor?f:t._gw)+"px"})).style("display",null),"function"===typeof r.path&&x.attr("d",r.path)}}Fe(t,[z,j])}},q.drawZeroLine=function(e,t,r){r=r||r;var n=t._id+"zl",i=q.shouldShowZeroLine(e,t,r.counterAxis),o=r.layer.selectAll("path."+n).data(i?[{x:0,id:t._id}]:[]);o.exit().remove(),o.enter().append("path").classed(n,1).classed("zl",1).classed("crisp",!1!==r.crisp).each((function(){r.layer.selectAll("path").sort((function(e,t){return X(e.id,t.id)}))})),o.attr("transform",r.transFn).attr("d",r.path).call(d.stroke,t.zerolinecolor||d.defaultLine).style("stroke-width",h.crispRound(e,t.zerolinewidth,t._gw||1)+"px").style("display",null),Fe(t,[D])},q.drawLabels=function(e,t,r){r=r||{};var o=e._fullLayout,a=t._id,u=r.cls||a+"tick",d=r.vals.filter((function(e){return e.text})),p=r.labelFns,f=r.secondary?0:t.tickangle,m=(t._prevTickAngles||{})[u],g=r.layer.selectAll("g."+u).data(t.showticklabels?d:[],Ae),y=[];function v(e,o){e.each((function(e){var a=n.select(this),s=a.select(".text-math-group"),u=p.anchorFn(e,o),d=r.transFn.call(a.node(),e)+(i(o)&&0!==+o?" rotate("+o+","+p.xFn(e)+","+(p.yFn(e)-e.fontSize/2)+")":""),f=c.lineCount(a),m=$*e.fontSize,g=p.heightFn(e,i(o)?+o:0,(f-1)*m);if(g&&(d+=l(0,g)),s.empty()){var y=a.select("text");y.attr({transform:d,"text-anchor":u}),y.style("opacity",1),t._adjustTickLabelsOverflow&&t._adjustTickLabelsOverflow()}else{var v=h.bBox(s.node()).width*{end:-.5,start:.5}[u];s.attr("transform",d+l(v,0))}}))}g.enter().append("g").classed(u,1).append("text").attr("text-anchor","middle").each((function(t){var r=n.select(this),i=e._promises.length;r.call(c.positionText,p.xFn(t),p.yFn(t)).call(h.font,{family:t.font,size:t.fontSize,color:t.fontColor,weight:t.fontWeight,style:t.fontStyle,variant:t.fontVariant,textcase:t.fontTextcase,lineposition:t.fontLineposition,shadow:t.fontShadow}).text(t.text).call(c.convertToTspans,e),e._promises[i]?y.push(e._promises.pop().then((function(){v(r,f)}))):v(r,f)})),Fe(t,[N]),g.exit().remove(),r.repositionOnUpdate&&g.each((function(e){n.select(this).select("text").call(c.positionText,p.xFn(e),p.yFn(e))})),t._adjustTickLabelsOverflow=function(){var r=t.ticklabeloverflow;if(r&&"allow"!==r){var i=-1!==r.indexOf("hide"),a="x"===t._id.charAt(0),l=0,c=a?e._fullLayout.width:e._fullLayout.height;if(-1!==r.indexOf("domain")){var u=s.simpleMap(t.range,t.r2l);l=t.l2p(u[0])+t._offset,c=t.l2p(u[1])+t._offset}var d=Math.min(l,c),p=Math.max(l,c),f=t.side,m=1/0,y=-1/0;for(var v in g.each((function(e){var r=n.select(this);if(r.select(".text-math-group").empty()){var o=h.bBox(r.node()),s=0;a?(o.right>p||o.leftp||o.top+(t.tickangle?0:e.fontSize/4)t["_visibleLabelMin_"+r._id]?l.style("display","none"):"tick"!==e.K||i||l.style("display",null)}))}))}))}))},v(g,m+1?m:f);var x=null;t._selections&&(t._selections[u]=g);var b=[function(){return y.length&&Promise.all(y)}];t.automargin&&o._redrawFromAutoMarginCount&&90===m?(x=m,b.push((function(){v(g,m)}))):b.push((function(){if(v(g,f),d.length&&t.autotickangles&&("log"!==t.type||"D"!==String(t.dtick).charAt(0))){x=t.autotickangles[0];var e,n=0,i=[],o=1;g.each((function(e){n=Math.max(n,e.fontSize);var r=t.l2p(e.x),a=Ce(this),s=h.bBox(a.node());o=Math.max(o,c.lineCount(a)),i.push({top:0,bottom:10,height:10,left:r-s.width/2,right:r+s.width/2+2,width:s.width+2})}));var a=("boundaries"===t.tickson||t.showdividers)&&!r.secondary,l=d.length,u=Math.abs((d[l-1].x-d[0].x)*t._m)/(l-1),p=a?u/2:u,m=a?t.ticklen:1.25*n*o,y=p/Math.sqrt(Math.pow(p,2)+Math.pow(m,2)),b=t.autotickangles.map((function(e){return e*Math.PI/180})),_=b.find((function(e){return Math.abs(Math.cos(e))<=y}));void 0===_&&(_=b.reduce((function(e,t){return Math.abs(Math.cos(e))B*L&&(P=L,C[M]=E[M]=O[M])}var V=Math.abs(P-I);V-S>0?S*=1+S/(V-=S):S=0,"y"!==t._id.charAt(0)&&(S=-S),C[T]=w.p2r(w.r2p(E[T])+A*S),"min"===w.autorange||"max reversed"===w.autorange?(C[0]=null,w._rangeInitial0=void 0,w._rangeInitial1=void 0):"max"!==w.autorange&&"min reversed"!==w.autorange||(C[1]=null,w._rangeInitial0=void 0,w._rangeInitial1=void 0),o._insideTickLabelsUpdaterange[w._name+".range"]=C}var U=s.syncOrAsync(b);return U&&U.then&&e._promises.push(U),U},q.getPxPosition=function(e,t){var r,n=e._fullLayout._size,i=t._id.charAt(0),o=t.side;return"free"!==t.anchor?r=t._anchorAxis:"x"===i?r={_offset:n.t+(1-(t.position||0))*n.h,_length:0}:"y"===i&&(r={_offset:n.l+(t.position||0)*n.w+t._shift,_length:0}),"top"===o||"left"===o?r._offset:"bottom"===o||"right"===o?r._offset+r._length:void 0},q.shouldShowZeroLine=function(e,t,r){var n=s.simpleMap(t.range,t.r2l);return n[0]*n[1]<=0&&t.zeroline&&("linear"===t.type||"-"===t.type)&&!(t.rangebreaks&&t.maskBreaks(0)===L)&&(Me(t,0)||!function(e,t,r,n){var i=r._mainAxis;if(!i)return;var o=e._fullLayout,a=t._id.charAt(0),s=q.counterLetter(t._id),l=t._offset+(Math.abs(n[0])1)for(n=1;n{"use strict";var n=r(22036),i=r(84468),o=r(65004).BADNUM,a=i.isArrayOrTypedArray,s=i.isDateTime,l=i.cleanNumber,c=Math.round;function u(e,t){return t?n(e):"number"===typeof e}function d(e){return Math.max(1,(e-1)/1e3)}e.exports=function(e,t,r){var i=e,h=r.noMultiCategory;if(a(i)&&!i.length)return"-";if(!h&&function(e){return a(e[0])&&a(e[1])}(i))return"multicategory";if(h&&Array.isArray(i[0])){for(var p=[],f=0;f2*a}(i,t))return"date";var g="strict"!==r.autotypenumbers;return function(e,t){for(var r=e.length,n=d(r),i=0,a=0,s={},u=0;u2*i}(i,g)?"category":function(e,t){for(var r=e.length,n=0;n{"use strict";var n=r(22036),i=r(38361),o=r(84468),a=r(37091),s=r(38851),l=r(49080),c=r(43452),u=r(3118),d=r(83193),h=r(89655),p=r(74128),f=r(40190),m=r(60696),g=r(45958),y=r(93143).WEEKDAY_PATTERN,v=r(93143).HOUR_PATTERN;function x(e,t,r){function i(r,n){return o.coerce(e,t,l.rangebreaks,r,n)}if(i("enabled")){var a=i("bounds");if(a&&a.length>=2){var s,c,u="";if(2===a.length)for(s=0;s<2;s++)if(c=_(a[s])){u=y;break}var d=i("pattern",u);if(d===y)for(s=0;s<2;s++)(c=_(a[s]))&&(t.bounds[s]=a[s]=c-1);if(d)for(s=0;s<2;s++)switch(c=a[s],d){case y:if(!n(c))return void(t.enabled=!1);if((c=+c)!==Math.floor(c)||c<0||c>=7)return void(t.enabled=!1);t.bounds[s]=a[s]=c;break;case v:if(!n(c))return void(t.enabled=!1);if((c=+c)<0||c>24)return void(t.enabled=!1);t.bounds[s]=a[s]=c}if(!1===r.autorange){var h=r.range;if(h[0]h[1])return void(t.enabled=!1)}else if(a[0]>h[0]&&a[1]{"use strict";var n=r(3127),i=n.FORMAT_LINK,o=n.DATE_FORMAT_LINK;function a(e,t){return["Sets the "+e+" formatting rule"+(t?"for `"+t+"` ":""),"using d3 formatting mini-languages","which are very similar to those in Python. For numbers, see: "+i+"."].join(" ")}function s(e,t){return a(e,t)+[" And for dates see: "+o+".","We add two items to d3's date formatter:","*%h* for half of the year as a decimal number as well as","*%{n}f* for fractional seconds","with n digits. For example, *2016-10-13 09:15:23.456* with tickformat","*%H~%M~%S.%2f* would display *09~15~23.46*"].join(" ")}e.exports={axisHoverFormat:function(e,t){return{valType:"string",dflt:"",editType:"none",description:(t?a:s)("hover text",e)+["By default the values are formatted using "+(t?"generic number format":"`"+e+"axis.hoverformat`")+"."].join(" ")}},descriptionOnlyNumbers:a,descriptionWithDates:s}},11576:(e,t,r)=>{"use strict";var n=r(38361),i=r(93143);function o(e,t){if(t&&t.length)for(var r=0;rn?1:-1:+(e.substr(1)||1)-+(t.substr(1)||1)},t.ref2id=function(e){return!!/^[xyz]/.test(e)&&e.split(" ")[0]},t.isLinked=function(e,t){return o(t,e._axisMatchGroups)||o(t,e._axisConstraintGroups)}},74128:(e,t,r)=>{"use strict";var n=r(19045).isTypedArraySpec;e.exports=function(e,t,r,i){if("category"===t.type){var o,a=e.categoryarray,s=Array.isArray(a)&&a.length>0||n(a);s&&(o="array");var l,c=r("categoryorder",o);"array"===c&&(l=r("categoryarray")),s||"array"!==c||(c=t.categoryorder="trace"),"trace"===c?t._initialCategories=[]:"array"===c?t._initialCategories=l.slice():(l=function(e,t){var r,n,i,o=t.dataAttr||e._id.charAt(0),a={};if(t.axData)r=t.axData;else for(r=[],n=0;n{"use strict";var n=r(22036),i=r(84468),o=r(65004),a=o.ONEDAY,s=o.ONEWEEK;t.dtick=function(e,t){var r="log"===t,i="date"===t,o="category"===t,s=i?a:1;if(!e)return s;if(n(e))return(e=Number(e))<=0?s:o?Math.max(1,Math.round(e)):i?Math.max(.1,e):e;if("string"!==typeof e||!i&&!r)return s;var l=e.charAt(0),c=e.substr(1);return(c=n(c)?Number(c):0)<=0||!(i&&"M"===l&&c===Math.round(c)||r&&"L"===l||r&&"D"===l&&(1===c||2===c))?s:e},t.tick0=function(e,t,r,o){return"date"===t?i.cleanDate(e,i.dateTick0(r,o%s===0?1:0)):"D1"!==o&&"D2"!==o?n(e)?Number(e):0:void 0}},93143:(e,t,r)=>{"use strict";var n=r(51195).counter;e.exports={idRegex:{x:n("x","( domain)?"),y:n("y","( domain)?")},attrRegex:n("[xy]axis"),xAxisMatch:n("xaxis"),yAxisMatch:n("yaxis"),AX_ID_PATTERN:/^[xyz][0-9]*( domain)?$/,AX_NAME_PATTERN:/^[xyz]axis[0-9]*$/,SUBPLOT_PATTERN:/^x([0-9]*)y([0-9]*)$/,HOUR_PATTERN:"hour",WEEKDAY_PATTERN:"day of week",MINDRAG:8,MINZOOM:20,DRAGGERSIZE:20,REDRAWDELAY:50,DFLTRANGEX:[-1,6],DFLTRANGEY:[-1,4],traceLayerClasses:["imagelayer","heatmaplayer","contourcarpetlayer","contourlayer","funnellayer","waterfalllayer","barlayer","carpetlayer","violinlayer","boxlayer","ohlclayer","scattercarpetlayer","scatterlayer"],clipOnAxisFalseQuery:[".scatterlayer",".barlayer",".funnellayer",".waterfalllayer"],layerValue2layerClass:{"above traces":"above","below traces":"below"},zindexSeparator:"z"}},80038:(e,t,r)=>{"use strict";var n=r(84468),i=r(49618),o=r(11576).id2name,a=r(49080),s=r(57008),l=r(45958),c=r(65004).ALMOST_EQUAL,u=r(83943).FROM_BL;function d(e,t,r){var i=r.axIds,s=r.layoutOut,l=r.hasImage,c=s._axisConstraintGroups,u=s._axisMatchGroups,d=t._id,m=d.charAt(0),g=((s._splomAxes||{})[m]||{})[d]||{},y=t._id,v="x"===y.charAt(0);function x(r,i){return n.coerce(e,t,a,r,i)}t._matchGroup=null,t._constraintGroup=null,x("constrain",l?"domain":"range"),n.coerce(e,t,{constraintoward:{valType:"enumerated",values:v?["left","center","right"]:["bottom","middle","top"],dflt:v?"center":"middle"}},"constraintoward");var b,_,w=t.type,k=[];for(b=0;bn?i.substr(n):o.substr(r))+a:i+o+e*t:a}function g(e,t){for(var r=t._size,n=r.h/r.w,i={},o=Object.keys(e),a=0;ac*x)||k)for(r=0;rR&&jP&&(P=j);h/=(P-I)/(2*O),I=l.l2r(I),P=l.l2r(P),l.range=l._input.range=M{"use strict";var n=r(41871),i=r(84468),o=i.numberFormat,a=r(23498),s=r(17390),l=r(38361),c=i.strTranslate,u=r(13480),d=r(7605),h=r(3172),p=r(32212),f=r(85729),m=r(29454),g=r(25732),y=r(2705),v=y.selectingOrDrawing,x=y.freeMode,b=r(83943).FROM_TL,_=r(76574),w=r(88470).redrawReglTraces,k=r(68543),S=r(11576).getFromId,A=r(76789).prepSelect,T=r(76789).clearOutline,M=r(76789).selectOnClick,C=r(57008),E=r(93143),I=E.MINDRAG,P=E.MINZOOM,O=!0;function R(e,t,r,n){var o=i.ensureSingle(e.draglayer,t,r,(function(t){t.classed("drag",!0).style({fill:"transparent","stroke-width":0}).attr("data-subplot",e.id)}));return o.call(m,n),o.node()}function L(e,t,r,i,o,a,s){var l=R(e,"rect",t,r);return n.select(l).call(h.setRect,i,o,a,s),l}function D(e,t){for(var r=0;r=0?Math.min(e,.9):1/(1/Math.max(e,-.3)+3.222))}function N(e,t,r,n,i){return e.append("path").attr("class","zoombox").style({fill:t>.2?"rgba(0,0,0,0)":"rgba(255,255,255,0)","stroke-width":0}).attr("transform",c(r,n)).attr("d",i+"Z")}function B(e,t,r){return e.append("path").attr("class","zoombox-corners").style({fill:d.background,stroke:d.defaultLine,"stroke-width":1,opacity:0}).attr("transform",c(t,r)).attr("d","M0,0Z")}function V(e,t,r,n,i,o){e.attr("d",n+"M"+r.l+","+r.t+"v"+r.h+"h"+r.w+"v-"+r.h+"h-"+r.w+"Z"),U(e,t,i,o)}function U(e,t,r,n){r||(e.transition().style("fill",n>.2?"rgba(0,0,0,0.4)":"rgba(255,255,255,0.3)").duration(200),t.transition().style("opacity",1).duration(200))}function H(e){n.select(e).selectAll(".zoombox,.js-zoombox-backdrop,.js-zoombox-menu,.zoombox-corners").remove()}function $(e){O&&e.data&&e._context.showTips&&(i.notifier(i._(e,"Double-click to zoom back out"),"long"),O=!1)}function W(e){var t=Math.floor(Math.min(e.b-e.t,e.r-e.l,P)/2);return"M"+(e.l-3.5)+","+(e.t-.5+t)+"h3v"+-t+"h"+t+"v-3h-"+(t+3)+"ZM"+(e.r+3.5)+","+(e.t-.5+t)+"h-3v"+-t+"h"+-t+"v-3h"+(t+3)+"ZM"+(e.r+3.5)+","+(e.b+.5-t)+"h-3v"+t+"h"+-t+"v3h"+(t+3)+"ZM"+(e.l-3.5)+","+(e.b+.5-t)+"h3v"+t+"h"+t+"v3h-"+(t+3)+"Z"}function q(e,t,r,n,o){for(var a,s,l,c,u=!1,d={},h={},p=(o||{}).xaHash,f=(o||{}).yaHash,m=0;m=0)i._fullLayout._deactivateShape(i);else{var a=i._fullLayout.clickmode;if(H(i),2!==e||ye||$e(),ge)a.indexOf("select")>-1&&M(r,i,Z,K,t.id,Pe),a.indexOf("event")>-1&&p.click(i,r,t.id);else if(1===e&&ye){var s=m?R:O,c="s"===m||"w"===y?0:1,d=s._name+".range["+c+"]",h=function(e,t){var r,n=e.range[t],i=Math.abs(n-e.range[1-t]);return"date"===e.type?n:"log"===e.type?(r=Math.ceil(Math.max(0,-Math.log(i)/Math.LN10))+3,o("."+r+"g")(Math.pow(10,n))):(r=Math.floor(Math.log(Math.abs(n))/Math.LN10)-Math.floor(Math.log(i)/Math.LN10)+4,o("."+String(r)+"g")(n))}(s,c),f="left",g="middle";if(s.fixedrange)return;m?(g="n"===m?"top":"bottom","right"===s.side&&(f="right")):"e"===y&&(f="right"),i._context.showAxisRangeEntryBoxes&&n.select(be).call(u.makeEditable,{gd:i,immediate:!0,background:i._fullLayout.paper_bgcolor,text:String(h),fill:s.tickfont?s.tickfont.color:"#444",horizontalAlign:f,verticalAlign:g}).on("edit",(function(e){var t=s.d2r(e);void 0!==t&&l.call("_guiRelayout",i,d,t)}))}}}function Le(t,r){if(e._transitioningWithDuration)return!1;var n=Math.max(0,Math.min(ee,pe*t+_e)),i=Math.max(0,Math.min(te,fe*r+we)),o=Math.abs(n-_e),a=Math.abs(i-we);function s(){Me="",ke.r=ke.l,ke.t=ke.b,Ee.attr("d","M0,0Z")}if(ke.l=Math.min(_e,n),ke.r=Math.max(_e,n),ke.t=Math.min(we,i),ke.b=Math.max(we,i),re.isSubplotConstrained)o>P||a>P?(Me="xy",o/ee>a/te?(a=o*te/ee,we>i?ke.t=we-a:ke.b=we+a):(o=a*ee/te,_e>n?ke.l=_e-o:ke.r=_e+o),Ee.attr("d",W(ke))):s();else if(ne.isSubplotConstrained)if(o>P||a>P){Me="xy";var l=Math.min(ke.l/ee,(te-ke.b)/te),c=Math.max(ke.r/ee,(te-ke.t)/te);ke.l=l*ee,ke.r=c*ee,ke.b=(1-l)*te,ke.t=(1-c)*te,Ee.attr("d",W(ke))}else s();else!oe||a0){var u;if(ne.isSubplotConstrained||!ie&&1===oe.length){for(u=0;u1&&(void 0!==o.maxallowed&&se===(o.range[0]1&&(void 0!==a.maxallowed&&le===(a.range[0]{"use strict";var n=r(41871),i=r(32212),o=r(25732),a=r(29454),s=r(15133).makeDragBox,l=r(93143).DRAGGERSIZE;t.initInteractions=function(e){var r=e._fullLayout;if(e._context.staticPlot)n.select(e).selectAll(".drag").remove();else if(r._has("cartesian")||r._has("splom")){Object.keys(r._plots||{}).sort((function(e,t){if((r._plots[e].mainplot&&!0)===(r._plots[t].mainplot&&!0)){var n=e.split("y"),i=t.split("y");return n[0]===i[0]?Number(n[1]||1)-Number(i[1]||1):Number(n[0]||1)-Number(i[0]||1)}return r._plots[e].mainplot?1:-1})).forEach((function(t){var n=r._plots[t],a=n.xaxis,c=n.yaxis;if(!n.mainplot){var u=s(e,n,a._offset,c._offset,a._length,c._length,"ns","ew");u.onmousemove=function(r){e._fullLayout._rehover=function(){e._fullLayout._hoversubplot===t&&e._fullLayout._plots[t]&&i.hover(e,r,t)},i.hover(e,r,t),e._fullLayout._lasthover=u,e._fullLayout._hoversubplot=t},u.onmouseout=function(t){e._dragging||(e._fullLayout._hoversubplot=null,o.unhover(e,t))},e._context.showAxisDragHandles&&(s(e,n,a._offset-l,c._offset-l,l,l,"n","w"),s(e,n,a._offset+a._length,c._offset-l,l,l,"n","e"),s(e,n,a._offset-l,c._offset+c._length,l,l,"s","w"),s(e,n,a._offset+a._length,c._offset+c._length,l,l,"s","e"))}if(e._context.showAxisDragHandles){if(t===a._mainSubplot){var d=a._mainLinePosition;"top"===a.side&&(d-=l),s(e,n,a._offset+.1*a._length,d,.8*a._length,l,"","ew"),s(e,n,a._offset,d,.1*a._length,l,"","w"),s(e,n,a._offset+.9*a._length,d,.1*a._length,l,"","e")}if(t===c._mainSubplot){var h=c._mainLinePosition;"right"!==c.side&&(h-=l),s(e,n,h,c._offset+.1*c._length,l,.8*c._length,"ns",""),s(e,n,h,c._offset+.9*c._length,l,.1*c._length,"s",""),s(e,n,h,c._offset,l,.1*c._length,"n","")}}}));var a=r._hoverlayer.node();a.onmousemove=function(t){t.target=e._fullLayout._lasthover,i.hover(e,t,r._hoversubplot)},a.onclick=function(t){t.target=e._fullLayout._lasthover,i.click(e,t)},a.onmousedown=function(t){e._fullLayout._lasthover.onmousedown(t)},t.updateFx(e)}},t.updateFx=function(e){var t=e._fullLayout,r="pan"===t.dragmode?"move":"crosshair";a(t._draggers,r)}},84381:(e,t,r)=>{"use strict";var n=r(38361),i=r(84468),o=r(11576);e.exports=function(e){return function(t,r){var a=t[e];if(Array.isArray(a))for(var s=n.subplotsRegistry.cartesian,l=s.idRegex,c=r._subplots,u=c.xaxis,d=c.yaxis,h=c.cartesian,p=r._has("cartesian")||r._has("gl2d"),f=0;f{"use strict";var n=r(41871),i=r(38361),o=r(84468),a=r(68543),s=r(3172),l=r(50246).eV,c=r(11576),u=r(93143),d=r(28795),h=o.ensureSingle;function p(e,t,r){return o.ensureSingle(e,t,r,(function(e){e.datum(r)}))}var f=u.zindexSeparator;function m(e,t,r,o,a){for(var c,d,h,p=u.traceLayerClasses,f=e._fullLayout,m=f._zindices,g=f._modules,y=[],v=[],x=0;x1)if(l)t.xlines=h(n,"path","xlines-above"),t.ylines=h(n,"path","ylines-above"),t.xaxislayer=h(n,"g","xaxislayer-above"),t.yaxislayer=h(n,"g","yaxislayer-above");else{if(!o){var d=h(n,"g","layer-subplot");t.shapelayer=h(d,"g","shapelayer"),t.imagelayer=h(d,"g","imagelayer"),t.minorGridlayer=h(n,"g","minor-gridlayer"),t.gridlayer=h(n,"g","gridlayer"),t.zerolinelayer=h(n,"g","zerolinelayer");var m=h(n,"g","layer-between");t.shapelayerBetween=h(m,"g","shapelayer"),t.imagelayerBetween=h(m,"g","imagelayer"),h(n,"path","xlines-below"),h(n,"path","ylines-below"),t.overlinesBelow=h(n,"g","overlines-below"),h(n,"g","xaxislayer-below"),h(n,"g","yaxislayer-below"),t.overaxesBelow=h(n,"g","overaxes-below")}t.overplot=h(n,"g","overplot"),t.plot=h(t.overplot,"g",i),o||(t.xlines=h(n,"path","xlines-above"),t.ylines=h(n,"path","ylines-above"),t.overlinesAbove=h(n,"g","overlines-above"),h(n,"g","xaxislayer-above"),h(n,"g","yaxislayer-above"),t.overaxesAbove=h(n,"g","overaxes-above"),t.xlines=n.select(".xlines-"+a),t.ylines=n.select(".ylines-"+s),t.xaxislayer=n.select(".xaxislayer-"+a),t.yaxislayer=n.select(".yaxislayer-"+s))}else{var g=t.mainplotinfo,y=g.plotgroup,v=i+"-x",x=i+"-y";t.minorGridlayer=g.minorGridlayer,t.gridlayer=g.gridlayer,t.zerolinelayer=g.zerolinelayer,h(g.overlinesBelow,"path",v),h(g.overlinesBelow,"path",x),h(g.overaxesBelow,"g",v),h(g.overaxesBelow,"g",x),t.plot=h(g.overplot,"g",i),h(g.overlinesAbove,"path",v),h(g.overlinesAbove,"path",x),h(g.overaxesAbove,"g",v),h(g.overaxesAbove,"g",x),t.xlines=y.select(".overlines-"+a).select("."+v),t.ylines=y.select(".overlines-"+s).select("."+x),t.xaxislayer=y.select(".overaxes-"+a).select("."+v),t.yaxislayer=y.select(".overaxes-"+s).select("."+x)}o||(l||(p(t.minorGridlayer,"g",t.xaxis._id),p(t.minorGridlayer,"g",t.yaxis._id),t.minorGridlayer.selectAll("g").map((function(e){return e[0]})).sort(c.idSort),p(t.gridlayer,"g",t.xaxis._id),p(t.gridlayer,"g",t.yaxis._id),t.gridlayer.selectAll("g").map((function(e){return e[0]})).sort(c.idSort)),t.xlines.style("fill","none").classed("crisp",!0),t.ylines.style("fill","none").classed("crisp",!0))}function y(e,t){if(e){var r={};for(var i in e.each((function(e){var i=e[0];n.select(this).remove(),v(i,t),r[i]=!0})),t._plots)for(var o=t._plots[i].overlays||[],a=0;a0){var g=p.id;if(-1!==g.indexOf(f))continue;g+=f+(u+1),p=o.extendFlat({},p,{id:g,plot:a._cartesianlayer.selectAll(".subplot").select("."+g)})}for(var y,v=[],x=0;x1&&(w+=f+_),b.push(n+w),r=0;r{"use strict";var n=r(91740),i=r(17992),o=r(2703).T,a=r(64022).extendFlat,s=r(37091).templatedArray,l=r(39363).descriptionWithDates,c=r(65004).ONEDAY,u=r(93143),d=u.HOUR_PATTERN,h=u.WEEKDAY_PATTERN,p={valType:"enumerated",values:["auto","linear","array"],editType:"ticks",impliedEdits:{tick0:void 0,dtick:void 0},description:["Sets the tick mode for this axis.","If *auto*, the number of ticks is set via `nticks`.","If *linear*, the placement of the ticks is determined by","a starting position `tick0` and a tick step `dtick`","(*linear* is the default value if `tick0` and `dtick` are provided).","If *array*, the placement of the ticks is set via `tickvals`","and the tick text is `ticktext`.","(*array* is the default value if `tickvals` is provided)."].join(" ")},f=a({},p,{values:p.values.slice().concat(["sync"]),description:[p.description,"If *sync*, the number of ticks will sync with the overlayed axis","set by `overlaying` property."].join(" ")});function m(e){return{valType:"integer",min:0,dflt:e?5:0,editType:"ticks",description:["Specifies the maximum number of ticks for the particular axis.","The actual number of ticks will be chosen automatically to be","less than or equal to `nticks`.","Has an effect only if `tickmode` is set to *auto*."].join(" ")}}var g={valType:"any",editType:"ticks",impliedEdits:{tickmode:"linear"},description:["Sets the placement of the first tick on this axis.","Use with `dtick`.","If the axis `type` is *log*, then you must take the log of your starting tick","(e.g. to set the starting tick to 100, set the `tick0` to 2)","except when `dtick`=*L* (see `dtick` for more info).","If the axis `type` is *date*, it should be a date string, like date data.","If the axis `type` is *category*, it should be a number, using the scale where","each category is assigned a serial number from zero in the order it appears."].join(" ")},y={valType:"any",editType:"ticks",impliedEdits:{tickmode:"linear"},description:["Sets the step in-between ticks on this axis. Use with `tick0`.","Must be a positive number, or special strings available to *log* and *date* axes.","If the axis `type` is *log*, then ticks are set every 10^(n*dtick) where n","is the tick number. For example,","to set a tick mark at 1, 10, 100, 1000, ... set dtick to 1.","To set tick marks at 1, 100, 10000, ... set dtick to 2.","To set tick marks at 1, 5, 25, 125, 625, 3125, ... set dtick to log_10(5), or 0.69897000433.","*log* has several special values; *L*, where `f` is a positive number,","gives ticks linearly spaced in value (but not position).","For example `tick0` = 0.1, `dtick` = *L0.5* will put ticks at 0.1, 0.6, 1.1, 1.6 etc.","To show powers of 10 plus small digits between, use *D1* (all digits) or *D2* (only 2 and 5).","`tick0` is ignored for *D1* and *D2*.","If the axis `type` is *date*, then you must convert the time to milliseconds.","For example, to set the interval between ticks to one day,","set `dtick` to 86400000.0.","*date* also has special values *M* gives ticks spaced by a number of months.","`n` must be a positive integer.","To set ticks on the 15th of every third month, set `tick0` to *2000-01-15* and `dtick` to *M3*.","To set ticks every 4 years, set `dtick` to *M48*"].join(" ")},v={valType:"data_array",editType:"ticks",description:["Sets the values at which ticks on this axis appear.","Only has an effect if `tickmode` is set to *array*.","Used with `ticktext`."].join(" ")},x={valType:"enumerated",values:["outside","inside",""],editType:"ticks",description:["Determines whether ticks are drawn or not.","If **, this axis' ticks are not drawn.","If *outside* (*inside*), this axis' are drawn outside (inside)","the axis lines."].join(" ")};function b(e){var t={valType:"number",min:0,editType:"ticks",description:"Sets the tick length (in px)."};return e||(t.dflt=5),t}function _(e){var t={valType:"number",min:0,editType:"ticks",description:"Sets the tick width (in px)."};return e||(t.dflt=1),t}var w={valType:"color",dflt:i.defaultLine,editType:"ticks",description:"Sets the tick color."},k={valType:"color",dflt:i.lightLine,editType:"ticks",description:"Sets the color of the grid lines."};function S(e){var t={valType:"number",min:0,editType:"ticks",description:"Sets the width (in px) of the grid lines."};return e||(t.dflt=1),t}var A=a({},o,{editType:"ticks"}),T={valType:"boolean",editType:"ticks",description:["Determines whether or not grid lines are drawn.","If *true*, the grid lines are drawn at every tick mark."].join(" ")};e.exports={visible:{valType:"boolean",editType:"plot",description:["A single toggle to hide the axis while preserving interaction like dragging.","Default is true when a cheater plot is present on the axis, otherwise","false"].join(" ")},color:{valType:"color",dflt:i.defaultLine,editType:"ticks",description:["Sets default for all colors associated with this axis","all at once: line, font, tick, and grid colors.","Grid color is lightened by blending this with the plot background","Individual pieces can override this."].join(" ")},title:{text:{valType:"string",editType:"ticks",description:["Sets the title of this axis.","Note that before the existence of `title.text`, the title's","contents used to be defined as the `title` attribute itself.","This behavior has been deprecated."].join(" ")},font:n({editType:"ticks",description:["Sets this axis' title font.","Note that the title's font used to be customized","by the now deprecated `titlefont` attribute."].join(" ")}),standoff:{valType:"number",min:0,editType:"ticks",description:["Sets the standoff distance (in px) between the axis labels and the title text","The default value is a function of the axis tick labels, the title `font.size`","and the axis `linewidth`.","Note that the axis title position is always constrained within the margins,","so the actual standoff distance is always less than the set or default value.","By setting `standoff` and turning on `automargin`, plotly.js will push the","margins to fit the axis title at given standoff distance."].join(" ")},editType:"ticks"},type:{valType:"enumerated",values:["-","linear","log","date","category","multicategory"],dflt:"-",editType:"calc",_noTemplating:!0,description:["Sets the axis type.","By default, plotly attempts to determined the axis type","by looking into the data of the traces that referenced","the axis in question."].join(" ")},autotypenumbers:{valType:"enumerated",values:["convert types","strict"],dflt:"convert types",editType:"calc",description:["Using *strict* a numeric string in trace data is not converted to a number.","Using *convert types* a numeric string in trace data may be","treated as a number during automatic axis `type` detection.","Defaults to layout.autotypenumbers."].join(" ")},autorange:{valType:"enumerated",values:[!0,!1,"reversed","min reversed","max reversed","min","max"],dflt:!0,editType:"axrange",impliedEdits:{"range[0]":void 0,"range[1]":void 0},description:["Determines whether or not the range of this axis is","computed in relation to the input data.","See `rangemode` for more info.","If `range` is provided and it has a value for both the","lower and upper bound, `autorange` is set to *false*.","Using *min* applies autorange only to set the minimum.","Using *max* applies autorange only to set the maximum.","Using *min reversed* applies autorange only to set the minimum on a reversed axis.","Using *max reversed* applies autorange only to set the maximum on a reversed axis.","Using *reversed* applies autorange on both ends and reverses the axis direction."].join(" ")},autorangeoptions:{minallowed:{valType:"any",editType:"plot",impliedEdits:{"range[0]":void 0,"range[1]":void 0},description:["Use this value exactly as autorange minimum."].join(" ")},maxallowed:{valType:"any",editType:"plot",impliedEdits:{"range[0]":void 0,"range[1]":void 0},description:["Use this value exactly as autorange maximum."].join(" ")},clipmin:{valType:"any",editType:"plot",impliedEdits:{"range[0]":void 0,"range[1]":void 0},description:["Clip autorange minimum if it goes beyond this value.","Has no effect when `autorangeoptions.minallowed` is provided."].join(" ")},clipmax:{valType:"any",editType:"plot",impliedEdits:{"range[0]":void 0,"range[1]":void 0},description:["Clip autorange maximum if it goes beyond this value.","Has no effect when `autorangeoptions.maxallowed` is provided."].join(" ")},include:{valType:"any",arrayOk:!0,editType:"plot",impliedEdits:{"range[0]":void 0,"range[1]":void 0},description:["Ensure this value is included in autorange."].join(" ")},editType:"plot"},rangemode:{valType:"enumerated",values:["normal","tozero","nonnegative"],dflt:"normal",editType:"plot",description:["If *normal*, the range is computed in relation to the extrema","of the input data.","If *tozero*`, the range extends to 0,","regardless of the input data","If *nonnegative*, the range is non-negative,","regardless of the input data.","Applies only to linear axes."].join(" ")},range:{valType:"info_array",items:[{valType:"any",editType:"axrange",impliedEdits:{"^autorange":!1},anim:!0},{valType:"any",editType:"axrange",impliedEdits:{"^autorange":!1},anim:!0}],editType:"axrange",impliedEdits:{autorange:!1},anim:!0,description:["Sets the range of this axis.","If the axis `type` is *log*, then you must take the log of your","desired range (e.g. to set the range from 1 to 100,","set the range from 0 to 2).","If the axis `type` is *date*, it should be date strings,","like date data, though Date objects and unix milliseconds","will be accepted and converted to strings.","If the axis `type` is *category*, it should be numbers,","using the scale where each category is assigned a serial","number from zero in the order it appears.","Leaving either or both elements `null` impacts the default `autorange`."].join(" ")},minallowed:{valType:"any",editType:"plot",impliedEdits:{"^autorange":!1},description:["Determines the minimum range of this axis."].join(" ")},maxallowed:{valType:"any",editType:"plot",impliedEdits:{"^autorange":!1},description:["Determines the maximum range of this axis."].join(" ")},fixedrange:{valType:"boolean",dflt:!1,editType:"calc",description:["Determines whether or not this axis is zoom-able.","If true, then zoom is disabled."].join(" ")},insiderange:{valType:"info_array",items:[{valType:"any",editType:"plot"},{valType:"any",editType:"plot"}],editType:"plot",description:["Could be used to set the desired inside range of this axis","(excluding the labels) when `ticklabelposition` of","the anchored axis has *inside*.","Not implemented for axes with `type` *log*.","This would be ignored when `range` is provided."].join(" ")},scaleanchor:{valType:"enumerated",values:[u.idRegex.x.toString(),u.idRegex.y.toString(),!1],editType:"plot",description:["If set to another axis id (e.g. `x2`, `y`), the range of this axis","changes together with the range of the corresponding axis","such that the scale of pixels per unit is in a constant ratio.","Both axes are still zoomable, but when you zoom one, the other will","zoom the same amount, keeping a fixed midpoint.","`constrain` and `constraintoward` determine how we enforce the constraint.","You can chain these, ie `yaxis: {scaleanchor: *x*}, xaxis2: {scaleanchor: *y*}`","but you can only link axes of the same `type`.","The linked axis can have the opposite letter (to constrain the aspect ratio)","or the same letter (to match scales across subplots).","Loops (`yaxis: {scaleanchor: *x*}, xaxis: {scaleanchor: *y*}` or longer) are redundant","and the last constraint encountered will be ignored to avoid possible","inconsistent constraints via `scaleratio`.","Note that setting axes simultaneously in both a `scaleanchor` and a `matches` constraint","is currently forbidden.","Setting `false` allows to remove a default constraint (occasionally,","you may need to prevent a default `scaleanchor` constraint from",'being applied, eg. when having an image trace `yaxis: {scaleanchor: "x"}`',"is set automatically in order for pixels to be rendered as squares,","setting `yaxis: {scaleanchor: false}` allows to remove the constraint)."].join(" ")},scaleratio:{valType:"number",min:0,dflt:1,editType:"plot",description:["If this axis is linked to another by `scaleanchor`, this determines the pixel","to unit scale ratio. For example, if this value is 10, then every unit on","this axis spans 10 times the number of pixels as a unit on the linked axis.","Use this for example to create an elevation profile where the vertical scale","is exaggerated a fixed amount with respect to the horizontal."].join(" ")},constrain:{valType:"enumerated",values:["range","domain"],editType:"plot",description:["If this axis needs to be compressed (either due to its own `scaleanchor` and","`scaleratio` or those of the other axis), determines how that happens:","by increasing the *range*, or by decreasing the *domain*.","Default is *domain* for axes containing image traces, *range* otherwise."].join(" ")},constraintoward:{valType:"enumerated",values:["left","center","right","top","middle","bottom"],editType:"plot",description:["If this axis needs to be compressed (either due to its own `scaleanchor` and","`scaleratio` or those of the other axis), determines which direction we push","the originally specified plot area. Options are *left*, *center* (default),","and *right* for x axes, and *top*, *middle* (default), and *bottom* for y axes."].join(" ")},matches:{valType:"enumerated",values:[u.idRegex.x.toString(),u.idRegex.y.toString()],editType:"calc",description:["If set to another axis id (e.g. `x2`, `y`), the range of this axis","will match the range of the corresponding axis in data-coordinates space.","Moreover, matching axes share auto-range values, category lists and","histogram auto-bins.","Note that setting axes simultaneously in both a `scaleanchor` and a `matches` constraint","is currently forbidden.","Moreover, note that matching axes must have the same `type`."].join(" ")},rangebreaks:s("rangebreak",{enabled:{valType:"boolean",dflt:!0,editType:"calc",description:["Determines whether this axis rangebreak is enabled or disabled.","Please note that `rangebreaks` only work for *date* axis type."].join(" ")},bounds:{valType:"info_array",items:[{valType:"any",editType:"calc"},{valType:"any",editType:"calc"}],editType:"calc",description:["Sets the lower and upper bounds of this axis rangebreak.","Can be used with `pattern`."].join(" ")},pattern:{valType:"enumerated",values:[h,d,""],editType:"calc",description:["Determines a pattern on the time line that generates breaks.","If *"+h+"* - days of the week in English e.g. 'Sunday' or `sun`","(matching is case-insensitive and considers only the first three characters),","as well as Sunday-based integers between 0 and 6.","If *"+d+"* - hour (24-hour clock) as decimal numbers between 0 and 24.","for more info.","Examples:","- { pattern: '"+h+"', bounds: [6, 1] }"," or simply { bounds: ['sat', 'mon'] }"," breaks from Saturday to Monday (i.e. skips the weekends).","- { pattern: '"+d+"', bounds: [17, 8] }"," breaks from 5pm to 8am (i.e. skips non-work hours)."].join(" ")},values:{valType:"info_array",freeLength:!0,editType:"calc",items:{valType:"any",editType:"calc"},description:["Sets the coordinate values corresponding to the rangebreaks.","An alternative to `bounds`.","Use `dvalue` to set the size of the values along the axis."].join(" ")},dvalue:{valType:"number",editType:"calc",min:0,dflt:c,description:["Sets the size of each `values` item.","The default is one day in milliseconds."].join(" ")},editType:"calc"}),tickmode:f,nticks:m(),tick0:g,dtick:y,ticklabelstep:{valType:"integer",min:1,dflt:1,editType:"ticks",description:["Sets the spacing between tick labels as compared to the spacing between ticks.","A value of 1 (default) means each tick gets a label.","A value of 2 means shows every 2nd label.","A larger value n means only every nth tick is labeled.","`tick0` determines which labels are shown.","Not implemented for axes with `type` *log* or *multicategory*, or when `tickmode` is *array*."].join(" ")},tickvals:v,ticktext:{valType:"data_array",editType:"ticks",description:["Sets the text displayed at the ticks position via `tickvals`.","Only has an effect if `tickmode` is set to *array*.","Used with `tickvals`."].join(" ")},ticks:x,tickson:{valType:"enumerated",values:["labels","boundaries"],dflt:"labels",editType:"ticks",description:["Determines where ticks and grid lines are drawn with respect to their","corresponding tick labels.","Only has an effect for axes of `type` *category* or *multicategory*.","When set to *boundaries*, ticks and grid lines are drawn half a category","to the left/bottom of labels."].join(" ")},ticklabelmode:{valType:"enumerated",values:["instant","period"],dflt:"instant",editType:"ticks",description:["Determines where tick labels are drawn with respect to their","corresponding ticks and grid lines.","Only has an effect for axes of `type` *date*","When set to *period*, tick labels are drawn in the middle of the period","between ticks."].join(" ")},ticklabelposition:{valType:"enumerated",values:["outside","inside","outside top","inside top","outside left","inside left","outside right","inside right","outside bottom","inside bottom"],dflt:"outside",editType:"calc",description:["Determines where tick labels are drawn with respect to the axis","Please note that","top or bottom has no effect on x axes or when `ticklabelmode` is set to *period*.","Similarly","left or right has no effect on y axes or when `ticklabelmode` is set to *period*.","Has no effect on *multicategory* axes or when `tickson` is set to *boundaries*.","When used on axes linked by `matches` or `scaleanchor`,","no extra padding for inside labels would be added by autorange,","so that the scales could match."].join(" ")},ticklabeloverflow:{valType:"enumerated",values:["allow","hide past div","hide past domain"],editType:"calc",description:["Determines how we handle tick labels that would overflow either the graph div or the domain of the axis.","The default value for inside tick labels is *hide past domain*.","Otherwise on *category* and *multicategory* axes the default is *allow*.","In other cases the default is *hide past div*."].join(" ")},ticklabelshift:{valType:"integer",dflt:0,editType:"ticks",description:["Shifts the tick labels by the specified number of pixels in parallel to the axis.","Positive values move the labels in the positive direction of the axis."].join(" ")},ticklabelstandoff:{valType:"integer",dflt:0,editType:"ticks",description:["Sets the standoff distance (in px) between the axis tick labels and their default position.","A positive `ticklabelstandoff` moves the labels farther away from the plot area","if `ticklabelposition` is *outside*, and deeper into the plot area if","`ticklabelposition` is *inside*. A negative `ticklabelstandoff` works in the opposite","direction, moving outside ticks towards the plot area and inside ticks towards","the outside. If the negative value is large enough, inside ticks can even end up","outside and vice versa."].join(" ")},ticklabelindex:{valType:"integer",arrayOk:!0,editType:"calc",description:["Only for axes with `type` *date* or *linear*.","Instead of drawing the major tick label, draw the label for the minor tick","that is n positions away from the major tick. E.g. to always draw the label for the","minor tick before each major tick, choose `ticklabelindex` -1. This is useful for date","axes with `ticklabelmode` *period* if you want to label the period that ends with each","major tick instead of the period that begins there."].join(" ")},mirror:{valType:"enumerated",values:[!0,"ticks",!1,"all","allticks"],dflt:!1,editType:"ticks+layoutstyle",description:["Determines if the axis lines or/and ticks are mirrored to","the opposite side of the plotting area.","If *true*, the axis lines are mirrored.","If *ticks*, the axis lines and ticks are mirrored.","If *false*, mirroring is disable.","If *all*, axis lines are mirrored on all shared-axes subplots.","If *allticks*, axis lines and ticks are mirrored","on all shared-axes subplots."].join(" ")},ticklen:b(),tickwidth:_(),tickcolor:w,showticklabels:{valType:"boolean",dflt:!0,editType:"ticks",description:"Determines whether or not the tick labels are drawn."},labelalias:{valType:"any",dflt:!1,editType:"ticks",description:["Replacement text for specific tick or hover labels.","For example using {US: 'USA', CA: 'Canada'} changes US to USA","and CA to Canada. The labels we would have shown must match","the keys exactly, after adding any tickprefix or ticksuffix.","For negative numbers the minus sign symbol used (U+2212) is wider than the regular ascii dash.","That means you need to use \u22121 instead of -1.","labelalias can be used with any axis type, and both keys (if needed)","and values (if desired) can include html-like tags or MathJax."].join(" ")},automargin:{valType:"flaglist",flags:["height","width","left","right","top","bottom"],extras:[!0,!1],dflt:!1,editType:"ticks",description:["Determines whether long tick labels automatically grow the figure","margins."].join(" ")},showspikes:{valType:"boolean",dflt:!1,editType:"modebar",description:["Determines whether or not spikes (aka droplines) are drawn for this axis.","Note: This only takes affect when hovermode = closest"].join(" ")},spikecolor:{valType:"color",dflt:null,editType:"none",description:"Sets the spike color. If undefined, will use the series color"},spikethickness:{valType:"number",dflt:3,editType:"none",description:"Sets the width (in px) of the zero line."},spikedash:a({},o,{dflt:"dash",editType:"none"}),spikemode:{valType:"flaglist",flags:["toaxis","across","marker"],dflt:"toaxis",editType:"none",description:["Determines the drawing mode for the spike line","If *toaxis*, the line is drawn from the data point to the axis the ","series is plotted on.","If *across*, the line is drawn across the entire plot area, and","supercedes *toaxis*.","If *marker*, then a marker dot is drawn on the axis the series is","plotted on"].join(" ")},spikesnap:{valType:"enumerated",values:["data","cursor","hovered data"],dflt:"hovered data",editType:"none",description:"Determines whether spikelines are stuck to the cursor or to the closest datapoints."},tickfont:n({editType:"ticks",description:"Sets the tick font."}),tickangle:{valType:"angle",dflt:"auto",editType:"ticks",description:["Sets the angle of the tick labels with respect to the horizontal.","For example, a `tickangle` of -90 draws the tick labels","vertically."].join(" ")},autotickangles:{valType:"info_array",freeLength:!0,items:{valType:"angle"},dflt:[0,30,90],editType:"ticks",description:["When `tickangle` is set to *auto*, it will be set to the first","angle in this array that is large enough to prevent label","overlap."].join(" ")},tickprefix:{valType:"string",dflt:"",editType:"ticks",description:"Sets a tick label prefix."},showtickprefix:{valType:"enumerated",values:["all","first","last","none"],dflt:"all",editType:"ticks",description:["If *all*, all tick labels are displayed with a prefix.","If *first*, only the first tick is displayed with a prefix.","If *last*, only the last tick is displayed with a suffix.","If *none*, tick prefixes are hidden."].join(" ")},ticksuffix:{valType:"string",dflt:"",editType:"ticks",description:"Sets a tick label suffix."},showticksuffix:{valType:"enumerated",values:["all","first","last","none"],dflt:"all",editType:"ticks",description:"Same as `showtickprefix` but for tick suffixes."},showexponent:{valType:"enumerated",values:["all","first","last","none"],dflt:"all",editType:"ticks",description:["If *all*, all exponents are shown besides their significands.","If *first*, only the exponent of the first tick is shown.","If *last*, only the exponent of the last tick is shown.","If *none*, no exponents appear."].join(" ")},exponentformat:{valType:"enumerated",values:["none","e","E","power","SI","B"],dflt:"B",editType:"ticks",description:["Determines a formatting rule for the tick exponents.","For example, consider the number 1,000,000,000.","If *none*, it appears as 1,000,000,000.","If *e*, 1e+9.","If *E*, 1E+9.","If *power*, 1x10^9 (with 9 in a super script).","If *SI*, 1G.","If *B*, 1B."].join(" ")},minexponent:{valType:"number",dflt:3,min:0,editType:"ticks",description:["Hide SI prefix for 10^n if |n| is below this number.","This only has an effect when `tickformat` is *SI* or *B*."].join(" ")},separatethousands:{valType:"boolean",dflt:!1,editType:"ticks",description:['If "true", even 4-digit integers are separated'].join(" ")},tickformat:{valType:"string",dflt:"",editType:"ticks",description:l("tick label")},tickformatstops:s("tickformatstop",{enabled:{valType:"boolean",dflt:!0,editType:"ticks",description:["Determines whether or not this stop is used.","If `false`, this stop is ignored even within its `dtickrange`."].join(" ")},dtickrange:{valType:"info_array",items:[{valType:"any",editType:"ticks"},{valType:"any",editType:"ticks"}],editType:"ticks",description:["range [*min*, *max*], where *min*, *max* - dtick values","which describe some zoom level, it is possible to omit *min*","or *max* value by passing *null*"].join(" ")},value:{valType:"string",dflt:"",editType:"ticks",description:["string - dtickformat for described zoom level, the same as *tickformat*"].join(" ")},editType:"ticks"}),hoverformat:{valType:"string",dflt:"",editType:"none",description:l("hover text")},showline:{valType:"boolean",dflt:!1,editType:"ticks+layoutstyle",description:["Determines whether or not a line bounding this axis is drawn."].join(" ")},linecolor:{valType:"color",dflt:i.defaultLine,editType:"layoutstyle",description:"Sets the axis line color."},linewidth:{valType:"number",min:0,dflt:1,editType:"ticks+layoutstyle",description:"Sets the width (in px) of the axis line."},showgrid:T,gridcolor:k,gridwidth:S(),griddash:A,zeroline:{valType:"boolean",editType:"ticks",description:["Determines whether or not a line is drawn at along the 0 value","of this axis.","If *true*, the zero line is drawn on top of the grid lines."].join(" ")},zerolinecolor:{valType:"color",dflt:i.defaultLine,editType:"ticks",description:"Sets the line color of the zero line."},zerolinewidth:{valType:"number",dflt:1,editType:"ticks",description:"Sets the width (in px) of the zero line."},showdividers:{valType:"boolean",dflt:!0,editType:"ticks",description:["Determines whether or not a dividers are drawn","between the category levels of this axis.","Only has an effect on *multicategory* axes."].join(" ")},dividercolor:{valType:"color",dflt:i.defaultLine,editType:"ticks",description:["Sets the color of the dividers","Only has an effect on *multicategory* axes."].join(" ")},dividerwidth:{valType:"number",dflt:1,editType:"ticks",description:["Sets the width (in px) of the dividers","Only has an effect on *multicategory* axes."].join(" ")},anchor:{valType:"enumerated",values:["free",u.idRegex.x.toString(),u.idRegex.y.toString()],editType:"plot",description:["If set to an opposite-letter axis id (e.g. `x2`, `y`), this axis is bound to","the corresponding opposite-letter axis.","If set to *free*, this axis' position is determined by `position`."].join(" ")},side:{valType:"enumerated",values:["top","bottom","left","right"],editType:"plot",description:["Determines whether a x (y) axis is positioned","at the *bottom* (*left*) or *top* (*right*)","of the plotting area."].join(" ")},overlaying:{valType:"enumerated",values:["free",u.idRegex.x.toString(),u.idRegex.y.toString()],editType:"plot",description:["If set a same-letter axis id, this axis is overlaid on top of","the corresponding same-letter axis, with traces and axes visible for both","axes.","If *false*, this axis does not overlay any same-letter axes.","In this case, for axes with overlapping domains only the highest-numbered","axis will be visible."].join(" ")},minor:{tickmode:p,nticks:m("minor"),tick0:g,dtick:y,tickvals:v,ticks:x,ticklen:b("minor"),tickwidth:_("minor"),tickcolor:w,gridcolor:k,gridwidth:S("minor"),griddash:A,showgrid:T,editType:"ticks"},layer:{valType:"enumerated",values:["above traces","below traces"],dflt:"above traces",editType:"plot",description:["Sets the layer on which this axis is displayed.","If *above traces*, this axis is displayed above all the subplot's traces","If *below traces*, this axis is displayed below all the subplot's traces,","but above the grid lines.","Useful when used together with scatter-like traces with `cliponaxis`","set to *false* to show markers and/or text nodes above this axis."].join(" ")},domain:{valType:"info_array",items:[{valType:"number",min:0,max:1,editType:"plot"},{valType:"number",min:0,max:1,editType:"plot"}],dflt:[0,1],editType:"plot",description:["Sets the domain of this axis (in plot fraction)."].join(" ")},position:{valType:"number",min:0,max:1,dflt:0,editType:"plot",description:["Sets the position of this axis in the plotting space","(in normalized coordinates).","Only has an effect if `anchor` is set to *free*."].join(" ")},autoshift:{valType:"boolean",dflt:!1,editType:"plot",description:["Automatically reposition the axis to avoid","overlap with other axes with the same `overlaying` value.","This repositioning will account for any `shift` amount applied to other","axes on the same side with `autoshift` is set to true.","Only has an effect if `anchor` is set to *free*."].join(" ")},shift:{valType:"number",editType:"plot",description:["Moves the axis a given number of pixels from where it would have been otherwise.","Accepts both positive and negative values, which will shift the axis either right","or left, respectively.","If `autoshift` is set to true, then this defaults to a padding of -3 if `side` is set to *left*.","and defaults to +3 if `side` is set to *right*. Defaults to 0 if `autoshift` is set to false.","Only has an effect if `anchor` is set to *free*."].join(" ")},categoryorder:{valType:"enumerated",values:["trace","category ascending","category descending","array","total ascending","total descending","min ascending","min descending","max ascending","max descending","sum ascending","sum descending","mean ascending","mean descending","geometric mean ascending","geometric mean descending","median ascending","median descending"],dflt:"trace",editType:"calc",description:["Specifies the ordering logic for the case of categorical variables.","By default, plotly uses *trace*, which specifies the order that is present in the data supplied.","Set `categoryorder` to *category ascending* or *category descending* if order should be determined by","the alphanumerical order of the category names.","Set `categoryorder` to *array* to derive the ordering from the attribute `categoryarray`. If a category","is not found in the `categoryarray` array, the sorting behavior for that attribute will be identical to","the *trace* mode. The unspecified categories will follow the categories in `categoryarray`.","Set `categoryorder` to *total ascending* or *total descending* if order should be determined by the","numerical order of the values.","Similarly, the order can be determined by the min, max, sum, mean, geometric mean or median of all the values."].join(" ")},categoryarray:{valType:"data_array",editType:"calc",description:["Sets the order in which categories on this axis appear.","Only has an effect if `categoryorder` is set to *array*.","Used with `categoryorder`."].join(" ")},uirevision:{valType:"any",editType:"none",description:["Controls persistence of user-driven changes in axis `range`,","`autorange`, and `title` if in `editable: true` configuration.","Defaults to `layout.uirevision`."].join(" ")},editType:"calc",_deprecated:{autotick:{valType:"boolean",editType:"ticks",description:["Obsolete.","Set `tickmode` to *auto* for old `autotick` *true* behavior.","Set `tickmode` to *linear* for `autotick` *false*."].join(" ")},title:{valType:"string",editType:"ticks",description:["Value of `title` is no longer a simple *string* but a set of sub-attributes.","To set the axis' title, please use `title.text` now."].join(" ")},titlefont:n({editType:"ticks",description:["Former `titlefont` is now the sub-attribute `font` of `title`.","To customize title font properties, please use `title.font` now."].join(" ")})}}},85647:(e,t,r)=>{"use strict";var n=r(84468),i=r(7605),o=r(82561).isUnifiedHover,a=r(71886),s=r(37091),l=r(98005),c=r(49080),u=r(18453),d=r(42730),h=r(80038),p=r(44528),f=r(11576),m=f.id2name,g=f.name2id,y=r(93143).AX_ID_PATTERN,v=r(38361),x=v.traceIs,b=v.getComponentMethod;function _(e,t,r){Array.isArray(e[t])?e[t].push(r):e[t]=[r]}e.exports=function(e,t,r){var v,w,k=t.autotypenumbers,S={},A={},T={},M={},C={},E={},I={},P={},O={},R={};for(v=0;v{"use strict";var n=r(23498).mix,i=r(17992),o=r(84468);e.exports=function(e,t,r,a){var s=(a=a||{}).dfltColor;function l(r,n){return o.coerce2(e,t,a.attributes,r,n)}var c=l("linecolor",s),u=l("linewidth");r("showline",a.showLine||!!c||!!u)||(delete t.linecolor,delete t.linewidth);var d=l("gridcolor",n(s,a.bgColor,a.blend||i.lightFraction).toRgbString()),h=l("gridwidth"),p=l("griddash");if(r("showgrid",a.showGrid||!!d||!!h||!!p)||(delete t.gridcolor,delete t.gridwidth,delete t.griddash),a.hasMinor){var f=l("minor.gridcolor",n(t.gridcolor,a.bgColor,67).toRgbString()),m=l("minor.gridwidth",t.gridwidth||1),g=l("minor.griddash",t.griddash||"solid");r("minor.showgrid",!!f||!!m||!!g)||(delete t.minor.gridcolor,delete t.minor.gridwidth,delete t.minor.griddash)}if(!a.noZeroLine){var y=l("zerolinecolor",s),v=l("zerolinewidth");r("zeroline",a.showGrid||!!y||!!v)||(delete t.zerolinecolor,delete t.zerolinewidth)}}},44528:(e,t,r)=>{"use strict";var n=r(22036),i=r(84468);e.exports=function(e,t,r,o){var a,s,l,c,u,d,h=o.counterAxes||[],p=o.overlayableAxes||[],f=o.letter,m=o.grid,g=o.overlayingDomain;m&&(s=m._domains[f][m._axisMap[t._id]],a=m._anchors[t._id],s&&(l=m[f+"side"].split(" ")[0],c=m.domain[f]["right"===l||"top"===l?1:0])),s=s||[0,1],a=a||(n(e.position)?"free":h[0]||"free"),l=l||("x"===f?"bottom":"left"),c=c||0,u=0,d=!1;var y=i.coerce(e,t,{anchor:{valType:"enumerated",values:["free"].concat(h),dflt:a}},"anchor"),v=i.coerce(e,t,{side:{valType:"enumerated",values:"x"===f?["bottom","top"]:["left","right"],dflt:l}},"side");if("free"===y){if("y"===f)r("autoshift")&&(c="left"===v?g[0]:g[1],d=!t.automargin||t.automargin,u="left"===v?-3:3),r("shift",u);r("position",c)}r("automargin",d);var x=!1;if(p.length&&(x=i.coerce(e,t,{overlaying:{valType:"enumerated",values:[!1].concat(p),dflt:!1}},"overlaying")),!x){var b=r("domain",s);b[0]>b[1]-1/4096&&(t.domain=s),i.noneOrAll(e.domain,t.domain,s),"sync"===t.tickmode&&(t.tickmode="auto")}return r("layer"),t}},89655:(e,t,r)=>{"use strict";var n=r(46518);e.exports=function(e,t,r,i,o){o||(o={});var a=o.tickSuffixDflt,s=n(e);r("tickprefix")&&r("showtickprefix",s),r("ticksuffix",a)&&r("showticksuffix",s)}},60696:(e,t,r)=>{"use strict";var n=r(87832);e.exports=function(e,t,r,i){var o=t._template||{},a=t.type||o.type||"-";r("minallowed"),r("maxallowed");var s,l=r("range");l||(i.noInsiderange||"log"===a||(!(s=r("insiderange"))||null!==s[0]&&null!==s[1]||(t.insiderange=!1,s=void 0),s&&(l=r("range",s))));var c,u=t.getAutorangeDflt(l,i),d=r("autorange",u);!l||(null!==l[0]||null!==l[1])&&(null!==l[0]&&null!==l[1]||"reversed"!==d&&!0!==d)&&(null===l[0]||"min"!==d&&"max reversed"!==d)&&(null===l[1]||"max"!==d&&"min reversed"!==d)||(l=void 0,delete t.range,t.autorange=!0,c=!0),c||(d=r("autorange",u=t.getAutorangeDflt(l,i))),d&&(n(r,d,l),"linear"!==a&&"-"!==a||r("rangemode")),t.cleanRange()}},57008:(e,t,r)=>{"use strict";var n=r(83943).FROM_BL;e.exports=function(e,t,r){void 0===r&&(r=n[e.constraintoward||"center"]);var i=[e.r2l(e.range[0]),e.r2l(e.range[1])],o=i[0]+(i[1]-i[0])*r;e.range=e._input.range=[e.l2r(o+(i[0]-o)*t),e.l2r(o+(i[1]-o)*t)],e.setScale()}},45958:(e,t,r)=>{"use strict";var n=r(41871),i=r(9212).aL,o=r(84468),a=o.numberFormat,s=r(22036),l=o.cleanNumber,c=o.ms2DateTime,u=o.dateTime2ms,d=o.ensureNumber,h=o.isArrayOrTypedArray,p=r(65004),f=p.FP_SAFE,m=p.BADNUM,g=p.LOG_CLIP,y=p.ONEWEEK,v=p.ONEDAY,x=p.ONEHOUR,b=p.ONEMIN,_=p.ONESEC,w=r(11576),k=r(93143),S=k.HOUR_PATTERN,A=k.WEEKDAY_PATTERN;function T(e){return Math.pow(10,e)}function M(e){return null!==e&&void 0!==e}e.exports=function(e,t){t=t||{};var r=e._id||"x",p=r.charAt(0);function C(t,r){if(t>0)return Math.log(t)/Math.LN10;if(t<=0&&r&&e.range&&2===e.range.length){var n=e.range[0],i=e.range[1];return.5*(n+i-2*g*Math.abs(n-i))}return m}function E(t,r,n,i){if((i||{}).msUTC&&s(t))return+t;var a=u(t,n||e.calendar);if(a===m){if(!s(t))return m;t=+t;var l=Math.floor(10*o.mod(t+.05,1)),c=Math.round(t-l/10);a=u(new Date(c))+l/10}return a}function I(t,r,n){return c(t,r,n||e.calendar)}function P(t){return e._categories[Math.round(t)]}function O(t){if(M(t)){if(void 0===e._categoriesMap&&(e._categoriesMap={}),void 0!==e._categoriesMap[t])return e._categoriesMap[t];e._categories.push("number"===typeof t?String(t):t);var r=e._categories.length-1;return e._categoriesMap[t]=r,r}return m}function R(t){if(e._categoriesMap)return e._categoriesMap[t]}function L(e){var t=R(e);return void 0!==t?t:s(e)?+e:void 0}function D(e){return s(e)?+e:R(e)}function z(e,t,r){return n.round(r+t*e,2)}function j(e,t,r){return(e-r)/t}var F=function(t){return s(t)?z(t,e._m,e._b):m},N=function(t){return j(t,e._m,e._b)};if(e.rangebreaks){var B="y"===p;F=function(t){if(!s(t))return m;var r=e._rangebreaks.length;if(!r)return z(t,e._m,e._b);var n=B;e.range[0]>e.range[1]&&(n=!n);for(var i=n?-1:1,o=i*t,a=0,l=0;lu)){a=o<(c+u)/2?l:l+1;break}a=l+1}var d=e._B[a]||0;return isFinite(d)?z(t,e._m2,d):0},N=function(t){var r=e._rangebreaks.length;if(!r)return j(t,e._m,e._b);for(var n=0,i=0;ie._rangebreaks[i].pmax&&(n=i+1);return j(t,e._m2,e._B[n])}}e.c2l="log"===e.type?C:d,e.l2c="log"===e.type?T:d,e.l2p=F,e.p2l=N,e.c2p="log"===e.type?function(e,t){return F(C(e,t))}:F,e.p2c="log"===e.type?function(e){return T(N(e))}:N,-1!==["linear","-"].indexOf(e.type)?(e.d2r=e.r2d=e.d2c=e.r2c=e.d2l=e.r2l=l,e.c2d=e.c2r=e.l2d=e.l2r=d,e.d2p=e.r2p=function(t){return e.l2p(l(t))},e.p2d=e.p2r=N,e.cleanPos=d):"log"===e.type?(e.d2r=e.d2l=function(e,t){return C(l(e),t)},e.r2d=e.r2c=function(e){return T(l(e))},e.d2c=e.r2l=l,e.c2d=e.l2r=d,e.c2r=C,e.l2d=T,e.d2p=function(t,r){return e.l2p(e.d2r(t,r))},e.p2d=function(e){return T(N(e))},e.r2p=function(t){return e.l2p(l(t))},e.p2r=N,e.cleanPos=d):"date"===e.type?(e.d2r=e.r2d=o.identity,e.d2c=e.r2c=e.d2l=e.r2l=E,e.c2d=e.c2r=e.l2d=e.l2r=I,e.d2p=e.r2p=function(t,r,n){return e.l2p(E(t,0,n))},e.p2d=e.p2r=function(e,t,r){return I(N(e),t,r)},e.cleanPos=function(t){return o.cleanDate(t,m,e.calendar)}):"category"===e.type?(e.d2c=e.d2l=O,e.r2d=e.c2d=e.l2d=P,e.d2r=e.d2l_noadd=L,e.r2c=function(t){var r=D(t);return void 0!==r?r:e.fraction2r(.5)},e.l2r=e.c2r=d,e.r2l=D,e.d2p=function(t){return e.l2p(e.r2c(t))},e.p2d=function(e){return P(N(e))},e.r2p=e.d2p,e.p2r=N,e.cleanPos=function(e){return"string"===typeof e&&""!==e?e:d(e)}):"multicategory"===e.type&&(e.r2d=e.c2d=e.l2d=P,e.d2r=e.d2l_noadd=L,e.r2c=function(t){var r=L(t);return void 0!==r?r:e.fraction2r(.5)},e.r2c_just_indices=R,e.l2r=e.c2r=d,e.r2l=L,e.d2p=function(t){return e.l2p(e.r2c(t))},e.p2d=function(e){return P(N(e))},e.r2p=e.d2p,e.p2r=N,e.cleanPos=function(e){return Array.isArray(e)||"string"===typeof e&&""!==e?e:d(e)},e.setupMultiCategory=function(n){var i,a,s=e._traceIndices,l=e._matchGroup;if(l&&0===e._categories.length)for(var c in l)if(c!==r){var u=t[w.id2name(c)];s=s.concat(u._traceIndices)}var d=[[0,{}],[0,{}]],f=[];for(i=0;il[1]&&(i[s?0:1]=n),i[0]===i[1]){var c=e.l2r(r),u=e.l2r(n);if(void 0!==r){var d=c+1;void 0!==n&&(d=Math.min(d,u)),i[s?1:0]=d}if(void 0!==n){var h=u+1;void 0!==r&&(h=Math.max(h,c)),i[s?0:1]=h}}}},e.cleanRange=function(t,r){e._cleanRange(t,r),e.limitRange(t)},e._cleanRange=function(t,r){r||(r={}),t||(t="range");var n,i,a=o.nestedProperty(e,t).get();if(i=(i="date"===e.type?o.dfltRange(e.calendar):"y"===p?k.DFLTRANGEY:"realaxis"===e._name?[0,1]:r.dfltRange||k.DFLTRANGEX).slice(),"tozero"!==e.rangemode&&"nonnegative"!==e.rangemode||(i[0]=0),a&&2===a.length){var l=null===a[0],c=null===a[1];for("date"!==e.type||e.autorange||(a[0]=o.cleanDate(a[0],m,e.calendar),a[1]=o.cleanDate(a[1],m,e.calendar)),n=0;n<2;n++)if("date"===e.type){if(!o.isDateTime(a[n],e.calendar)){e[t]=i;break}if(e.r2l(a[0])===e.r2l(a[1])){var u=o.constrain(e.r2l(a[0]),o.MIN_MS+1e3,o.MAX_MS-1e3);a[0]=e.l2r(u-1e3),a[1]=e.l2r(u+1e3);break}}else{if(!s(a[n])){if(l||c||!s(a[1-n])){e[t]=i;break}a[n]=a[1-n]*(n?10:.1)}if(a[n]<-f?a[n]=-f:a[n]>f&&(a[n]=f),a[0]===a[1]){var d=Math.max(1,Math.abs(1e-6*a[0]));a[0]-=d,a[1]+=d}}}else o.nestedProperty(e,t).set(i)},e.setScale=function(r){var n=t._size;if(e.overlaying){var i=w.getFromId({_fullLayout:t},e.overlaying);e.domain=i.domain}var o=r&&e._r?"_r":"range",a=e.calendar;e.cleanRange(o);var s,l,c=e.r2l(e[o][0],a),u=e.r2l(e[o][1],a),d="y"===p;if((d?(e._offset=n.t+(1-e.domain[1])*n.h,e._length=n.h*(e.domain[1]-e.domain[0]),e._m=e._length/(c-u),e._b=-e._m*u):(e._offset=n.l+e.domain[0]*n.w,e._length=n.w*(e.domain[1]-e.domain[0]),e._m=e._length/(u-c),e._b=-e._m*c),e._rangebreaks=[],e._lBreaks=0,e._m2=0,e._B=[],e.rangebreaks)&&(e._rangebreaks=e.locateBreaks(Math.min(c,u),Math.max(c,u)),e._rangebreaks.length)){for(s=0;su&&(h=!h),h&&e._rangebreaks.reverse();var f=h?-1:1;for(e._m2=f*e._length/(Math.abs(u-c)-e._lBreaks),e._B.push(-e._m2*(d?u:c)),s=0;si&&(i+=7,ai&&(i+=24,a=n&&a=n&&t=s.min&&(es.max&&(s.max=n),i=!1)}i&&c.push({min:e,max:n})}};for(n=0;n{"use strict";e.exports=function(e){var t=["showexponent","showtickprefix","showticksuffix"].filter((function(t){return void 0!==e[t]}));if(t.every((function(r){return e[r]===e[t[0]]}))||1===t.length)return e[t[0]]}},83193:(e,t,r)=>{"use strict";var n=r(84468),i=r(7605).contrast,o=r(49080),a=r(46518),s=r(38851);function l(e,t){function r(r,i){return n.coerce(e,t,o.tickformatstops,r,i)}r("enabled")&&(r("dtickrange"),r("value"))}e.exports=function(e,t,r,c,u){u||(u={});var d=r("labelalias");n.isPlainObject(d)||delete t.labelalias;var h=a(e);if(r("showticklabels")){u.noTicklabelshift||r("ticklabelshift"),u.noTicklabelstandoff||r("ticklabelstandoff");var p=u.font||{},f=t.color,m=-1!==(t.ticklabelposition||"").indexOf("inside")?i(u.bgColor):f&&f!==o.color.dflt?f:p.color;if(n.coerceFont(r,"tickfont",p,{overrideDflt:{color:m}}),u.noTicklabelstep||"multicategory"===c||"log"===c||r("ticklabelstep"),!u.noAng){var g=r("tickangle");u.noAutotickangles||"auto"!==g||r("autotickangles")}if("category"!==c){var y=r("tickformat");s(e,t,{name:"tickformatstops",inclusionAttr:"enabled",handleItemDefaults:l}),t.tickformatstops.length||delete t.tickformatstops,u.noExp||y||"date"===c||(r("showexponent",h),r("exponentformat"),r("minexponent"),r("separatethousands"))}}}},3118:(e,t,r)=>{"use strict";var n=r(84468),i=r(49080);e.exports=function(e,t,r,o){var a=o.isMinor,s=a?e.minor||{}:e,l=a?t.minor:t,c=a?i.minor:i,u=a?"minor.":"",d=n.coerce2(s,l,c,"ticklen",a?.6*(t.ticklen||5):void 0),h=n.coerce2(s,l,c,"tickwidth",a?t.tickwidth||1:void 0),p=n.coerce2(s,l,c,"tickcolor",(a?t.tickcolor:void 0)||l.color);r(u+"ticks",!a&&o.outerTicks||d||h||p?"outside":"")||(delete l.ticklen,delete l.tickwidth,delete l.tickcolor)}},43452:(e,t,r)=>{"use strict";var n=r(13530),i=r(84468).isArrayOrTypedArray,o=r(19045).isTypedArraySpec,a=r(19045).decodeTypedArraySpec;e.exports=function(e,t,r,s,l){l||(l={});var c=l.isMinor,u=c?e.minor||{}:e,d=c?t.minor:t,h=c?"minor.":"";function p(e){var t=u[e];return o(t)&&(t=a(t)),void 0!==t?t:(d._template||{})[e]}var f=p("tick0"),m=p("dtick"),g=p("tickvals"),y=r(h+"tickmode",i(g)?"array":m?"linear":"auto");if("auto"===y||"sync"===y)r(h+"nticks");else if("linear"===y){var v=d.dtick=n.dtick(m,s);d.tick0=n.tick0(f,s,t.calendar,v)}else if("multicategory"!==s){void 0===r(h+"tickvals")?d.tickmode="auto":c||r("ticktext")}}},85695:(e,t,r)=>{"use strict";var n=r(41871),i=r(38361),o=r(84468),a=r(3172),s=r(85729);e.exports=function(e,t,r,l){var c=e._fullLayout;if(0!==t.length){var u,d,h,p;l&&(u=l());var f=n.ease(r.easing);return e._transitionData._interruptCallbacks.push((function(){return window.cancelAnimationFrame(p),p=null,function(){for(var r={},n=0;nr.duration?(!function(){for(var r={},n=0;n rect").call(a.setTranslate,0,0).call(a.setScale,1,1),e.plot.call(a.setTranslate,t._offset,r._offset).call(a.setScale,1,1);var n=e.plot.selectAll(".scatterlayer .trace");n.selectAll(".point").call(a.setPointGroupScale,1,1),n.selectAll(".textpoint").call(a.setTextPointsScale,1,1),n.call(a.hideOutsideRangePoints,e)}function g(t,r){var n=t.plotinfo,i=n.xaxis,l=n.yaxis,c=i._length,u=l._length,d=!!t.xr1,h=!!t.yr1,p=[];if(d){var f=o.simpleMap(t.xr0,i.r2l),m=o.simpleMap(t.xr1,i.r2l),g=f[1]-f[0],y=m[1]-m[0];p[0]=(f[0]*(1-r)+r*m[0]-f[0])/(f[1]-f[0])*c,p[2]=c*(1-r+r*y/g),i.range[0]=i.l2r(f[0]*(1-r)+r*m[0]),i.range[1]=i.l2r(f[1]*(1-r)+r*m[1])}else p[0]=0,p[2]=c;if(h){var v=o.simpleMap(t.yr0,l.r2l),x=o.simpleMap(t.yr1,l.r2l),b=v[1]-v[0],_=x[1]-x[0];p[1]=(v[1]*(1-r)+r*x[1]-v[1])/(v[0]-v[1])*u,p[3]=u*(1-r+r*_/b),l.range[0]=i.l2r(v[0]*(1-r)+r*x[0]),l.range[1]=l.l2r(v[1]*(1-r)+r*x[1])}else p[1]=0,p[3]=u;s.drawOne(e,i,{skipTitle:!0}),s.drawOne(e,l,{skipTitle:!0}),s.redrawComponents(e,[i._id,l._id]);var w=d?c/p[2]:1,k=h?u/p[3]:1,S=d?p[0]:0,A=h?p[1]:0,T=d?p[0]/p[2]*c:0,M=h?p[1]/p[3]*u:0,C=i._offset-T,E=l._offset-M;n.clipRect.call(a.setTranslate,S,A).call(a.setScale,1/w,1/k),n.plot.call(a.setTranslate,C,E).call(a.setScale,w,k),a.setPointGroupScale(n.zoomScalePts,1/w,1/k),a.setTextPointsScale(n.zoomScaleTxt,1/w,1/k)}s.redrawComponents(e)}},18453:(e,t,r)=>{"use strict";var n=r(38361).traceIs,i=r(84339);function o(e){return{v:"x",h:"y"}[e.orientation||"v"]}function a(e,t){var r=o(e),i=n(e,"box-violin"),a=n(e._fullInput||{},"candlestick");return i&&!a&&t===r&&void 0===e[r]&&void 0===e[r+"0"]}e.exports=function(e,t,r,s){r("autotypenumbers",s.autotypenumbersDflt),"-"===r("type",(s.splomStash||{}).type)&&(!function(e,t){if("-"!==e.type)return;var r,s=e._id,l=s.charAt(0);-1!==s.indexOf("scene")&&(s=l);var c=function(e,t,r){for(var n=0;n0&&(i["_"+r+"axes"]||{})[t])return i;if((i[r+"axis"]||r)===t){if(a(i,r))return i;if((i[r]||[]).length||i[r+"0"])return i}}}(t,s,l);if(!c)return;if("histogram"===c.type&&l==={v:"y",h:"x"}[c.orientation||"v"])return void(e.type="linear");var u=l+"calendar",d=c[u],h={noMultiCategory:!n(c,"cartesian")||n(c,"noMultiCategory")};"box"===c.type&&c._hasPreCompStats&&l==={h:"x",v:"y"}[c.orientation||"v"]&&(h.noMultiCategory=!0);if(h.autotypenumbers=e.autotypenumbers,a(c,l)){var p=o(c),f=[];for(r=0;r{"use strict";var n=r(38361),i=r(84468);function o(e,t,r){var n,o,a,s=!1;if("data"===t.type)n=e._fullData[null!==t.traces?t.traces[0]:0];else{if("layout"!==t.type)return!1;n=e._fullLayout}return o=i.nestedProperty(n,t.prop).get(),(a=r[t.type]=r[t.type]||{}).hasOwnProperty(t.prop)&&a[t.prop]!==o&&(s=!0),a[t.prop]=o,{changed:s,value:o}}function a(e,t){var r=[],n=t[0],o={};if("string"===typeof n)o[n]=t[1];else{if(!i.isPlainObject(n))return r;o=n}return l(o,(function(e,t,n){r.push({type:"layout",prop:e,value:n})}),"",0),r}function s(e,t){var r,n,o,a,s=[];if(n=t[0],o=t[1],r=t[2],a={},"string"===typeof n)a[n]=o;else{if(!i.isPlainObject(n))return s;a=n,void 0===r&&(r=o)}return void 0===r&&(r=null),l(a,(function(t,n,i){var o,a;if(Array.isArray(i)){a=i.slice();var l=Math.min(a.length,e.data.length);r&&(l=Math.min(l,r.length)),o=[];for(var c=0;c0?".":"")+o;i.isPlainObject(a)?l(a,t,s,n+1):t(s,o,a)}}))}t.manageCommandObserver=function(e,r,n,a){var s={},l=!0;r&&r._commandObserver&&(s=r._commandObserver),s.cache||(s.cache={}),s.lookupTable={};var c=t.hasSimpleAPICommandBindings(e,n,s.lookupTable);if(r&&r._commandObserver){if(c)return s;if(r._commandObserver.remove)return r._commandObserver.remove(),r._commandObserver=null,s}if(c){o(e,c,s.cache),s.check=function(){if(l){var t=o(e,c,s.cache);return t.changed&&a&&void 0!==s.lookupTable[t.value]&&(s.disable(),Promise.resolve(a({value:t.value,type:c.type,prop:c.prop,traces:c.traces,index:s.lookupTable[t.value]})).then(s.enable,s.enable)),t.changed}};for(var u=["plotly_relayout","plotly_redraw","plotly_restyle","plotly_update","plotly_animatingframe","plotly_afterplot"],d=0;d{"use strict";var n=r(64022).extendFlat;t.u=function(e,t){t=t||{};var r={valType:"info_array",editType:(e=e||{}).editType,items:[{valType:"number",min:0,max:1,editType:e.editType},{valType:"number",min:0,max:1,editType:e.editType}],dflt:[0,1]},i=e.name?e.name+" ":"",o=e.trace?"trace ":"subplot ",a=t.description?" "+t.description:"",s={x:n({},r,{description:["Sets the horizontal domain of this ",i,o,"(in plot fraction).",a].join("")}),y:n({},r,{description:["Sets the vertical domain of this ",i,o,"(in plot fraction).",a].join("")}),editType:e.editType};return e.noGridCell||(s.row={valType:"integer",min:0,dflt:0,editType:e.editType,description:["If there is a layout grid, use the domain ","for this row in the grid for this ",i,o,".",a].join("")},s.column={valType:"integer",min:0,dflt:0,editType:e.editType,description:["If there is a layout grid, use the domain ","for this column in the grid for this ",i,o,".",a].join("")}),s},t.N=function(e,t,r,n){var i=n&&n.x||[0,1],o=n&&n.y||[0,1],a=t.grid;if(a){var s=r("domain.column");void 0!==s&&(s{"use strict";e.exports=function(e){var t=e.variantValues,r=e.editType,n=e.colorEditType;void 0===n&&(n=r);var i={editType:r,valType:"integer",min:1,max:1e3,extras:["normal","bold"],dflt:"normal",description:["Sets the weight (or boldness) of the font."].join(" ")};e.noNumericWeightValues&&(i.valType="enumerated",i.values=i.extras,i.extras=void 0,i.min=void 0,i.max=void 0);var o={family:{valType:"string",noBlank:!0,strict:!0,editType:r,description:["HTML font family - the typeface that will be applied by the web browser.","The web browser will only be able to apply a font if it is available on the system","which it operates. Provide multiple font families, separated by commas, to indicate","the preference in which to apply fonts if they aren't available on the system.","The Chart Studio Cloud (at https://chart-studio.plotly.com or on-premise) generates images on a server,","where only a select number of","fonts are installed and supported.","These include *Arial*, *Balto*, *Courier New*, *Droid Sans*, *Droid Serif*,","*Droid Sans Mono*, *Gravitas One*, *Old Standard TT*, *Open Sans*, *Overpass*,","*PT Sans Narrow*, *Raleway*, *Times New Roman*."].join(" ")},size:{valType:"number",min:1,editType:r},color:{valType:"color",editType:n},weight:i,style:{editType:r,valType:"enumerated",values:["normal","italic"],dflt:"normal",description:["Sets whether a font should be styled with a normal or italic face from its family."].join(" ")},variant:e.noFontVariant?void 0:{editType:r,valType:"enumerated",values:t||["normal","small-caps","all-small-caps","all-petite-caps","petite-caps","unicase"],dflt:"normal",description:["Sets the variant of the font."].join(" ")},textcase:e.noFontTextcase?void 0:{editType:r,valType:"enumerated",values:["normal","word caps","upper","lower"],dflt:"normal",description:["Sets capitalization of text.","It can be used to make text appear in all-uppercase or all-lowercase,","or with each word capitalized."].join(" ")},lineposition:e.noFontLineposition?void 0:{editType:r,valType:"flaglist",flags:["under","over","through"],extras:["none"],dflt:"none",description:["Sets the kind of decoration line(s) with text,","such as an *under*, *over* or *through*","as well as combinations e.g. *under+over*, etc."].join(" ")},shadow:e.noFontShadow?void 0:{editType:r,valType:"string",dflt:e.autoShadowDflt?"auto":"none",description:["Sets the shape and color of the shadow behind text.","*auto* places minimal shadow and applies contrast text font color.","See https://developer.mozilla.org/en-US/docs/Web/CSS/text-shadow for additional options."].join(" ")},editType:r,description:""+(e.description||"")};return e.autoSize&&(o.size.dflt="auto"),e.autoColor&&(o.color.dflt="auto"),e.arrayOk&&(o.family.arrayOk=!0,o.weight.arrayOk=!0,o.style.arrayOk=!0,e.noFontVariant||(o.variant.arrayOk=!0),e.noFontTextcase||(o.textcase.arrayOk=!0),e.noFontLineposition||(o.lineposition.arrayOk=!0),e.noFontShadow||(o.shadow.arrayOk=!0),o.size.arrayOk=!0,o.color.arrayOk=!0),o}},44380:e=>{"use strict";e.exports={_isLinkedToArray:"frames_entry",group:{valType:"string",description:["An identifier that specifies the group to which the frame belongs,","used by animate to select a subset of frames."].join(" ")},name:{valType:"string",description:"A label by which to identify the frame"},traces:{valType:"any",description:["A list of trace indices that identify the respective traces in the","data attribute"].join(" ")},baseframe:{valType:"string",description:["The name of the frame into which this frame's properties are merged","before applying. This is used to unify properties and avoid needing","to specify the same values for the same properties in multiple frames."].join(" ")},data:{valType:"any",description:["A list of traces this frame modifies. The format is identical to the","normal trace definition."].join(" ")},layout:{valType:"any",description:["Layout properties which this frame modifies. The format is identical","to the normal layout definition."].join(" ")}}},93752:(e,t)=>{"use strict";t.projNames={airy:"airy",aitoff:"aitoff","albers usa":"albersUsa",albers:"albers",august:"august","azimuthal equal area":"azimuthalEqualArea","azimuthal equidistant":"azimuthalEquidistant",baker:"baker",bertin1953:"bertin1953",boggs:"boggs",bonne:"bonne",bottomley:"bottomley",bromley:"bromley",collignon:"collignon","conic conformal":"conicConformal","conic equal area":"conicEqualArea","conic equidistant":"conicEquidistant",craig:"craig",craster:"craster","cylindrical equal area":"cylindricalEqualArea","cylindrical stereographic":"cylindricalStereographic",eckert1:"eckert1",eckert2:"eckert2",eckert3:"eckert3",eckert4:"eckert4",eckert5:"eckert5",eckert6:"eckert6",eisenlohr:"eisenlohr","equal earth":"equalEarth",equirectangular:"equirectangular",fahey:"fahey","foucaut sinusoidal":"foucautSinusoidal",foucaut:"foucaut",ginzburg4:"ginzburg4",ginzburg5:"ginzburg5",ginzburg6:"ginzburg6",ginzburg8:"ginzburg8",ginzburg9:"ginzburg9",gnomonic:"gnomonic","gringorten quincuncial":"gringortenQuincuncial",gringorten:"gringorten",guyou:"guyou",hammer:"hammer",hill:"hill",homolosine:"homolosine",hufnagel:"hufnagel",hyperelliptical:"hyperelliptical",kavrayskiy7:"kavrayskiy7",lagrange:"lagrange",larrivee:"larrivee",laskowski:"laskowski",loximuthal:"loximuthal",mercator:"mercator",miller:"miller",mollweide:"mollweide","mt flat polar parabolic":"mtFlatPolarParabolic","mt flat polar quartic":"mtFlatPolarQuartic","mt flat polar sinusoidal":"mtFlatPolarSinusoidal","natural earth":"naturalEarth","natural earth1":"naturalEarth1","natural earth2":"naturalEarth2","nell hammer":"nellHammer",nicolosi:"nicolosi",orthographic:"orthographic",patterson:"patterson","peirce quincuncial":"peirceQuincuncial",polyconic:"polyconic","rectangular polyconic":"rectangularPolyconic",robinson:"robinson",satellite:"satellite","sinu mollweide":"sinuMollweide",sinusoidal:"sinusoidal",stereographic:"stereographic",times:"times","transverse mercator":"transverseMercator","van der grinten":"vanDerGrinten","van der grinten2":"vanDerGrinten2","van der grinten3":"vanDerGrinten3","van der grinten4":"vanDerGrinten4",wagner4:"wagner4",wagner6:"wagner6",wiechel:"wiechel","winkel tripel":"winkel3",winkel3:"winkel3"},t.axesNames=["lonaxis","lataxis"],t.lonaxisSpan={orthographic:180,"azimuthal equal area":360,"azimuthal equidistant":360,"conic conformal":180,gnomonic:160,stereographic:180,"transverse mercator":180,"*":360},t.lataxisSpan={"conic conformal":150,stereographic:179.5,"*":180},t.scopeDefaults={world:{lonaxisRange:[-180,180],lataxisRange:[-90,90],projType:"equirectangular",projRotate:[0,0,0]},usa:{lonaxisRange:[-180,-50],lataxisRange:[15,80],projType:"albers usa"},europe:{lonaxisRange:[-30,60],lataxisRange:[30,85],projType:"conic conformal",projRotate:[15,0,0],projParallels:[0,60]},asia:{lonaxisRange:[22,160],lataxisRange:[-15,55],projType:"mercator",projRotate:[0,0,0]},africa:{lonaxisRange:[-30,60],lataxisRange:[-40,40],projType:"mercator",projRotate:[0,0,0]},"north america":{lonaxisRange:[-180,-45],lataxisRange:[5,85],projType:"conic conformal",projRotate:[-100,0,0],projParallels:[29.5,45.5]},"south america":{lonaxisRange:[-100,-30],lataxisRange:[-60,15],projType:"mercator",projRotate:[0,0,0]}},t.clipPad=.001,t.precision=.1,t.landColor="#F0DC82",t.waterColor="#3399FF",t.locationmodeToLayer={"ISO-3":"countries","USA-states":"subunits","country names":"countries"},t.sphereSVG={type:"Sphere"},t.fillLayers={ocean:1,land:1,lakes:1},t.lineLayers={subunits:1,countries:1,coastlines:1,rivers:1,frame:1},t.layers=["bg","ocean","land","lakes","subunits","countries","coastlines","rivers","lataxis","lonaxis","frame","backplot","frontplot"],t.layersForChoropleth=["bg","ocean","land","subunits","countries","coastlines","lataxis","lonaxis","frame","backplot","rivers","lakes","frontplot"],t.layerNameToAdjective={ocean:"ocean",land:"land",lakes:"lake",subunits:"subunit",countries:"country",coastlines:"coastline",rivers:"river",frame:"frame"}},68632:(e,t,r)=>{"use strict";var n=r(41871),i=r(85487),o=i.geoPath,a=i.geoDistance,s=r(50167),l=r(38361),c=r(84468),u=c.strTranslate,d=r(7605),h=r(3172),p=r(32212),f=r(68543),m=r(85729),g=r(49618).getAutoRange,y=r(25732),v=r(76789).prepSelect,x=r(76789).clearOutline,b=r(76789).selectOnClick,_=r(82602),w=r(93752),k=r(63925),S=r(76621),A=r(52255).N4;function T(e){this.id=e.id,this.graphDiv=e.graphDiv,this.container=e.container,this.topojsonURL=e.topojsonURL,this.isStatic=e.staticPlot,this.topojsonName=null,this.topojson=null,this.projection=null,this.scope=null,this.viewInitial=null,this.fitScale=null,this.bounds=null,this.midPt=null,this.hasChoropleth=!1,this.traceHash={},this.layers={},this.basePaths={},this.dataPaths={},this.dataPoints={},this.clipDef=null,this.clipRect=null,this.bgRect=null,this.makeFramework()}var M=T.prototype;function C(e,t){var r=w.clipPad,n=e[0]+r,i=e[1]-r,o=t[0]+r,a=t[1]-r;n>0&&i<0&&(i+=360);var s=(i-n)/4;return{type:"Polygon",coordinates:[[[n,o],[n,a],[n+s,a],[n+2*s,a],[n+3*s,a],[i,a],[i,o],[i-s,o],[i-2*s,o],[i-3*s,o],[n,o]]]}}e.exports=function(e){return new T(e)},M.plot=function(e,t,r,n){var i=this;if(n)return i.update(e,t,!0);i._geoCalcData=e,i._fullLayout=t;var o=t[this.id],a=[],s=!1;for(var l in w.layerNameToAdjective)if("frame"!==l&&o["show"+l]){s=!0;break}for(var c=!1,u=0;u0&&a._module.calcGeoJSON(o,t)}if(!r){if(this.updateProjection(e,t))return;this.viewInitial&&this.scope===n.scope||this.saveViewInitial(n)}this.scope=n.scope,this.updateBaseLayers(t,n),this.updateDims(t,n),this.updateFx(t,n),f.generalUpdatePerTraceModule(this.graphDiv,this,e,n);var s=this.layers.frontplot.select(".scatterlayer");this.dataPoints.point=s.selectAll(".point"),this.dataPoints.text=s.selectAll("text"),this.dataPaths.line=s.selectAll(".js-line");var l=this.layers.backplot.select(".choroplethlayer");this.dataPaths.choropleth=l.selectAll("path"),this._render()},M.updateProjection=function(e,t){var r=this.graphDiv,n=t[this.id],l=t._size,u=n.domain,d=n.projection,h=n.lonaxis,p=n.lataxis,f=h._ax,m=p._ax,y=this.projection=function(e){var t=e.projection,r=t.type,n=w.projNames[r];n="geo"+c.titleCase(n);for(var l=(i[n]||s[n])(),u=e._isSatellite?180*Math.acos(1/t.distance)/Math.PI:e._isClipped?w.lonaxisSpan[r]/2:null,d=["center","rotate","parallels","clipExtent"],h=function(e){return e?l:[]},p=0;pu*Math.PI/180}return!1},l.getPath=function(){return o().projection(l)},l.getBounds=function(e){return l.getPath().bounds(e)},l.precision(w.precision),e._isSatellite&&l.tilt(t.tilt).distance(t.distance);u&&l.clipAngle(u-w.clipPad);return l}(n),v=[[l.l+l.w*u.x[0],l.t+l.h*(1-u.y[1])],[l.l+l.w*u.x[1],l.t+l.h*(1-u.y[0])]],x=n.center||{},b=d.rotation||{},_=h.range||[],k=p.range||[];if(n.fitbounds){f._length=v[1][0]-v[0][0],m._length=v[1][1]-v[0][1],f.range=g(r,f),m.range=g(r,m);var S=(f.range[0]+f.range[1])/2,A=(m.range[0]+m.range[1])/2;if(n._isScoped)x={lon:S,lat:A};else if(n._isClipped){x={lon:S,lat:A},b={lon:S,lat:A,roll:b.roll};var T=d.type,M=w.lonaxisSpan[T]/2||180,E=w.lataxisSpan[T]/2||90;_=[S-M,S+M],k=[A-E,A+E]}else x={lon:S,lat:A},b={lon:S,lat:b.lat,roll:b.roll}}y.center([x.lon-b.lon,x.lat-b.lat]).rotate([-b.lon,-b.lat,b.roll]).parallels(d.parallels);var I=C(_,k);y.fitExtent(v,I);var P=this.bounds=y.getBounds(I),O=this.fitScale=y.scale(),R=y.translate();if(n.fitbounds){var L=y.getBounds(C(f.range,m.range)),D=Math.min((P[1][0]-P[0][0])/(L[1][0]-L[0][0]),(P[1][1]-P[0][1])/(L[1][1]-L[0][1]));isFinite(D)?y.scale(D*O):c.warn("Something went wrong during"+this.id+"fitbounds computations.")}else y.scale(d.scale*O);var z=this.midPt=[(P[0][0]+P[1][0])/2,(P[0][1]+P[1][1])/2];if(y.translate([R[0]+(z[0]-R[0]),R[1]+(z[1]-R[1])]).clipExtent(P),n._isAlbersUsa){var j=y([x.lon,x.lat]),F=y.translate();y.translate([F[0]-(j[0]-F[0]),F[1]-(j[1]-F[1])])}},M.updateBaseLayers=function(e,t){var r=this,i=r.topojson,o=r.layers,a=r.basePaths;function s(e){return"lonaxis"===e||"lataxis"===e}function l(e){return Boolean(w.lineLayers[e])}function c(e){return Boolean(w.fillLayers[e])}var u=(this.hasChoropleth?w.layersForChoropleth:w.layers).filter((function(e){return l(e)||c(e)?t["show"+e]:!s(e)||t[e].showgrid})),p=r.framework.selectAll(".layer").data(u,String);p.exit().each((function(e){delete o[e],delete a[e],n.select(this).remove()})),p.enter().append("g").attr("class",(function(e){return"layer "+e})).each((function(e){var t=o[e]=n.select(this);"bg"===e?r.bgRect=t.append("rect").style("pointer-events","all"):s(e)?a[e]=t.append("path").style("fill","none"):"backplot"===e?t.append("g").classed("choroplethlayer",!0):"frontplot"===e?t.append("g").classed("scatterlayer",!0):l(e)?a[e]=t.append("path").style("fill","none").style("stroke-miterlimit",2):c(e)&&(a[e]=t.append("path").style("stroke","none"))})),p.order(),p.each((function(r){var n=a[r],o=w.layerNameToAdjective[r];"frame"===r?n.datum(w.sphereSVG):l(r)||c(r)?n.datum(A(i,i.objects[r])):s(r)&&n.datum(function(e,t,r){var n,i,o,a=1e-6,s=2.5,l=t[e],c=w.scopeDefaults[t.scope];"lonaxis"===e?(n=c.lonaxisRange,i=c.lataxisRange,o=function(e,t){return[e,t]}):"lataxis"===e&&(n=c.lataxisRange,i=c.lonaxisRange,o=function(e,t){return[t,e]});var u={type:"linear",range:[n[0],n[1]-a],tick0:l.tick0,dtick:l.dtick};m.setConvert(u,r);var d=m.calcTicks(u);t.isScoped||"lonaxis"!==e||d.pop();for(var h=d.length,p=new Array(h),f=0;f-1&&b(n.event,i,[r.xaxis],[r.yaxis],r.id,u),s.indexOf("event")>-1&&p.click(i,n.event))}))}function d(e){return r.projection.invert([e[0]+r.xaxis._offset,e[1]+r.yaxis._offset])}},M.makeFramework=function(){var e=this,t=e.graphDiv,r=t._fullLayout,i="clip"+r._uid+e.id;e.clipDef=r._clips.append("clipPath").attr("id",i),e.clipRect=e.clipDef.append("rect"),e.framework=n.select(e.container).append("g").attr("class","geo "+e.id).call(h.setClipUrl,i,t),e.project=function(t){var r=e.projection(t);return r?[r[0]-e.xaxis._offset,r[1]-e.yaxis._offset]:[null,null]},e.xaxis={_id:"x",c2p:function(t){return e.project(t)[0]}},e.yaxis={_id:"y",c2p:function(t){return e.project(t)[1]}},e.mockAxis={type:"linear",showexponent:"all",exponentformat:"B"},m.setConvert(e.mockAxis,r)},M.saveViewInitial=function(e){var t,r=e.center||{},n=e.projection,i=n.rotation||{};this.viewInitial={fitbounds:e.fitbounds,"projection.scale":n.scale},t=e._isScoped?{"center.lon":r.lon,"center.lat":r.lat}:e._isClipped?{"projection.rotation.lon":i.lon,"projection.rotation.lat":i.lat}:{"center.lon":r.lon,"center.lat":r.lat,"projection.rotation.lon":i.lon},c.extendFlat(this.viewInitial,t)},M.render=function(e){this._hasMarkerAngles&&e?this.plot(this._geoCalcData,this._fullLayout,[],!0):this._render()},M._render=function(){var e,t=this.projection,r=t.getPath();function n(e){var r=t(e.lonlat);return r?u(r[0],r[1]):null}function i(e){return t.isLonLatOverEdges(e.lonlat)?"none":null}for(e in this.basePaths)this.basePaths[e].attr("d",r);for(e in this.dataPaths)this.dataPaths[e].attr("d",(function(e){return r(e.geojson)}));for(e in this.dataPoints)this.dataPoints[e].attr("display",i).attr("transform",n)}},81073:(e,t,r)=>{"use strict";var n=r(50246).fX,i=r(84468).counterRegex,o=r(68632),a="geo",s=i(a),l={};l[a]={valType:"subplotid",dflt:a,editType:"calc",description:["Sets a reference between this trace's geospatial coordinates and","a geographic map.","If *geo* (the default value), the geospatial coordinates refer to","`layout.geo`.","If *geo2*, the geospatial coordinates refer to `layout.geo2`,","and so on."].join(" ")},e.exports={attr:a,name:a,idRoot:a,idRegex:s,attrRegex:s,attributes:l,layoutAttributes:r(91319),supplyLayoutDefaults:r(14992),plot:function(e){for(var t=e._fullLayout,r=e.calcdata,i=t._subplots[a],s=0;s{"use strict";var n=r(17992),i=r(81159).u,o=r(2703).T,a=r(93752),s=r(72587).overrideAll,l=r(60693),c={range:{valType:"info_array",items:[{valType:"number"},{valType:"number"}],description:["Sets the range of this axis (in degrees),","sets the map's clipped coordinates."].join(" ")},showgrid:{valType:"boolean",dflt:!1,description:"Sets whether or not graticule are shown on the map."},tick0:{valType:"number",dflt:0,description:["Sets the graticule's starting tick longitude/latitude."].join(" ")},dtick:{valType:"number",description:["Sets the graticule's longitude/latitude tick step."].join(" ")},gridcolor:{valType:"color",dflt:n.lightLine,description:["Sets the graticule's stroke color."].join(" ")},gridwidth:{valType:"number",min:0,dflt:1,description:["Sets the graticule's stroke width (in px)."].join(" ")},griddash:o};(e.exports=s({domain:i({name:"geo"},{description:["Note that geo subplots are constrained by domain.","In general, when `projection.scale` is set to 1.","a map will fit either its x or y domain, but not both."].join(" ")}),fitbounds:{valType:"enumerated",values:[!1,"locations","geojson"],dflt:!1,editType:"plot",description:["Determines if this subplot's view settings are auto-computed to fit trace data.","On scoped maps, setting `fitbounds` leads to `center.lon` and `center.lat` getting auto-filled.","On maps with a non-clipped projection, setting `fitbounds` leads to `center.lon`, `center.lat`,","and `projection.rotation.lon` getting auto-filled.","On maps with a clipped projection, setting `fitbounds` leads to `center.lon`, `center.lat`,","`projection.rotation.lon`, `projection.rotation.lat`, `lonaxis.range` and `lonaxis.range`","getting auto-filled.","If *locations*, only the trace's visible locations are considered in the `fitbounds` computations.","If *geojson*, the entire trace input `geojson` (if provided) is considered in the `fitbounds` computations,","Defaults to *false*."].join(" ")},resolution:{valType:"enumerated",values:[110,50],dflt:110,coerceNumber:!0,description:["Sets the resolution of the base layers.","The values have units of km/mm","e.g. 110 corresponds to a scale ratio of 1:110,000,000."].join(" ")},scope:{valType:"enumerated",values:l(a.scopeDefaults),dflt:"world",description:"Set the scope of the map."},projection:{type:{valType:"enumerated",values:l(a.projNames),description:"Sets the projection type."},rotation:{lon:{valType:"number",description:["Rotates the map along parallels","(in degrees East).","Defaults to the center of the `lonaxis.range` values."].join(" ")},lat:{valType:"number",description:["Rotates the map along meridians","(in degrees North)."].join(" ")},roll:{valType:"number",description:["Roll the map (in degrees)","For example, a roll of *180* makes the map appear upside down."].join(" ")}},tilt:{valType:"number",dflt:0,description:["For satellite projection type only.","Sets the tilt angle of perspective projection."].join(" ")},distance:{valType:"number",min:1.001,dflt:2,description:["For satellite projection type only.","Sets the distance from the center of the sphere to the point of view","as a proportion of the sphere\u2019s radius."].join(" ")},parallels:{valType:"info_array",items:[{valType:"number"},{valType:"number"}],description:["For conic projection types only.","Sets the parallels (tangent, secant)","where the cone intersects the sphere."].join(" ")},scale:{valType:"number",min:0,dflt:1,description:["Zooms in or out on the map view.","A scale of *1* corresponds to the largest zoom level","that fits the map's lon and lat ranges. "].join(" ")}},center:{lon:{valType:"number",description:["Sets the longitude of the map's center.","By default, the map's longitude center lies at the middle of the longitude range","for scoped projection and above `projection.rotation.lon` otherwise."].join(" ")},lat:{valType:"number",description:["Sets the latitude of the map's center.","For all projection types, the map's latitude center lies","at the middle of the latitude range by default."].join(" ")}},visible:{valType:"boolean",dflt:!0,description:"Sets the default visibility of the base layers."},showcoastlines:{valType:"boolean",description:"Sets whether or not the coastlines are drawn."},coastlinecolor:{valType:"color",dflt:n.defaultLine,description:"Sets the coastline color."},coastlinewidth:{valType:"number",min:0,dflt:1,description:"Sets the coastline stroke width (in px)."},showland:{valType:"boolean",dflt:!1,description:"Sets whether or not land masses are filled in color."},landcolor:{valType:"color",dflt:a.landColor,description:"Sets the land mass color."},showocean:{valType:"boolean",dflt:!1,description:"Sets whether or not oceans are filled in color."},oceancolor:{valType:"color",dflt:a.waterColor,description:"Sets the ocean color"},showlakes:{valType:"boolean",dflt:!1,description:"Sets whether or not lakes are drawn."},lakecolor:{valType:"color",dflt:a.waterColor,description:"Sets the color of the lakes."},showrivers:{valType:"boolean",dflt:!1,description:"Sets whether or not rivers are drawn."},rivercolor:{valType:"color",dflt:a.waterColor,description:"Sets color of the rivers."},riverwidth:{valType:"number",min:0,dflt:1,description:"Sets the stroke width (in px) of the rivers."},showcountries:{valType:"boolean",description:"Sets whether or not country boundaries are drawn."},countrycolor:{valType:"color",dflt:n.defaultLine,description:"Sets line color of the country boundaries."},countrywidth:{valType:"number",min:0,dflt:1,description:"Sets line width (in px) of the country boundaries."},showsubunits:{valType:"boolean",description:["Sets whether or not boundaries of subunits within countries","(e.g. states, provinces) are drawn."].join(" ")},subunitcolor:{valType:"color",dflt:n.defaultLine,description:"Sets the color of the subunits boundaries."},subunitwidth:{valType:"number",min:0,dflt:1,description:"Sets the stroke width (in px) of the subunits boundaries."},showframe:{valType:"boolean",description:"Sets whether or not a frame is drawn around the map."},framecolor:{valType:"color",dflt:n.defaultLine,description:"Sets the color the frame."},framewidth:{valType:"number",min:0,dflt:1,description:"Sets the stroke width (in px) of the frame."},bgcolor:{valType:"color",dflt:n.background,description:"Set the background color of the map"},lonaxis:c,lataxis:c},"plot","from-root")).uirevision={valType:"any",editType:"none",description:["Controls persistence of user-driven changes in the view","(projection and center). Defaults to `layout.uirevision`."].join(" ")}},14992:(e,t,r)=>{"use strict";var n=r(84468),i=r(54883),o=r(50246).KO,a=r(93752),s=r(91319),l=a.axesNames;function c(e,t,r,i){var s=o(i.fullData,"geo",i.id).map((function(e){return e._expandedIndex})),c=r("resolution"),u=r("scope"),d=a.scopeDefaults[u],h=r("projection.type",d.projType),p=t._isAlbersUsa="albers usa"===h;p&&(u=t.scope="usa");var f=t._isScoped="world"!==u,m=t._isSatellite="satellite"===h,g=t._isConic=-1!==h.indexOf("conic")||"albers"===h,y=t._isClipped=!!a.lonaxisSpan[h];if(!1===e.visible){var v=n.extendDeep({},t._template);v.showcoastlines=!1,v.showcountries=!1,v.showframe=!1,v.showlakes=!1,v.showland=!1,v.showocean=!1,v.showrivers=!1,v.showsubunits=!1,v.lonaxis&&(v.lonaxis.showgrid=!1),v.lataxis&&(v.lataxis.showgrid=!1),t._template=v}for(var x=r("visible"),b=0;b0&&P<0&&(P+=360);var O,R,L,D=(I+P)/2;if(!p){var z=f?d.projRotate:[D,0,0];O=r("projection.rotation.lon",z[0]),r("projection.rotation.lat",z[1]),r("projection.rotation.roll",z[2]),r("showcoastlines",!f&&x)&&(r("coastlinecolor"),r("coastlinewidth")),r("showocean",!!x&&void 0)&&r("oceancolor")}(p?(R=-96.6,L=38.7):(R=f?D:O,L=(E[0]+E[1])/2),r("center.lon",R),r("center.lat",L),m&&(r("projection.tilt"),r("projection.distance")),g)&&r("projection.parallels",d.projParallels||[0,60]);r("projection.scale"),r("showland",!!x&&void 0)&&r("landcolor"),r("showlakes",!!x&&void 0)&&r("lakecolor"),r("showrivers",!!x&&void 0)&&(r("rivercolor"),r("riverwidth")),r("showcountries",f&&"usa"!==u&&x)&&(r("countrycolor"),r("countrywidth")),("usa"===u||"north america"===u&&50===c)&&(r("showsubunits",x),r("subunitcolor"),r("subunitwidth")),f||r("showframe",x)&&(r("framecolor"),r("framewidth")),r("bgcolor"),r("fitbounds")&&(delete t.projection.scale,f?(delete t.center.lon,delete t.center.lat):y?(delete t.center.lon,delete t.center.lat,delete t.projection.rotation.lon,delete t.projection.rotation.lat,delete t.lonaxis.range,delete t.lataxis.range):(delete t.center.lon,delete t.center.lat,delete t.projection.rotation.lon))}e.exports=function(e,t,r){i(e,t,r,{type:"geo",attributes:s,handleDefaults:c,fullData:r,partition:"y"})}},82602:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468),o=r(38361),a=Math.PI/180,s=180/Math.PI,l={cursor:"pointer"},c={cursor:"auto"};function u(e,t){return n.behavior.zoom().translate(t.translate()).scale(t.scale())}function d(e,t,r){var n=e.id,a=e.graphDiv,s=a.layout,l=s[n],c=a._fullLayout,u=c[n],d={},h={};function p(e,t){d[n+"."+e]=i.nestedProperty(l,e).get(),o.call("_storeDirectGUIEdit",s,c._preGUI,d);var r=i.nestedProperty(u,e);r.get()!==t&&(r.set(t),i.nestedProperty(l,e).set(t),h[n+"."+e]=t)}r(p),p("projection.scale",t.scale()/e.fitScale),p("fitbounds",!1),a.emit("plotly_relayout",h)}function h(e,t){var r=u(0,t);function i(r){var n=t.invert(e.midPt);r("center.lon",n[0]),r("center.lat",n[1])}return r.on("zoomstart",(function(){n.select(this).style(l)})).on("zoom",(function(){t.scale(n.event.scale).translate(n.event.translate),e.render(!0);var r=t.invert(e.midPt);e.graphDiv.emit("plotly_relayouting",{"geo.projection.scale":t.scale()/e.fitScale,"geo.center.lon":r[0],"geo.center.lat":r[1]})})).on("zoomend",(function(){n.select(this).style(c),d(e,t,i)})),r}function p(e,t){var r,i,o,a,s,h,p,f,m,g=u(0,t);function y(e){return t.invert(e)}function v(r){var n=t.rotate(),i=t.invert(e.midPt);r("projection.rotation.lon",-n[0]),r("center.lon",i[0]),r("center.lat",i[1])}return g.on("zoomstart",(function(){n.select(this).style(l),r=n.mouse(this),i=t.rotate(),o=t.translate(),a=i,s=y(r)})).on("zoom",(function(){if(h=n.mouse(this),function(e){var r=y(e);if(!r)return!0;var n=t(r);return Math.abs(n[0]-e[0])>2||Math.abs(n[1]-e[1])>2}(r))return g.scale(t.scale()),void g.translate(t.translate());t.scale(n.event.scale),t.translate([o[0],n.event.translate[1]]),s?y(h)&&(f=y(h),p=[a[0]+(f[0]-s[0]),i[1],i[2]],t.rotate(p),a=p):s=y(r=h),m=!0,e.render(!0);var l=t.rotate(),c=t.invert(e.midPt);e.graphDiv.emit("plotly_relayouting",{"geo.projection.scale":t.scale()/e.fitScale,"geo.center.lon":c[0],"geo.center.lat":c[1],"geo.projection.rotation.lon":-l[0]})})).on("zoomend",(function(){n.select(this).style(c),m&&d(e,t,v)})),g}function f(e,t){var r,i={r:t.rotate(),k:t.scale()},o=u(0,t),h=function(e){var t=0,r=arguments.length,i=[];for(;++tf?(o=(d>0?90:-90)-p,i=0):(o=Math.asin(d/f)*s-p,i=Math.sqrt(f*f-d*d));var m=180-o-2*p,y=(Math.atan2(h,u)-Math.atan2(c,i))*s,x=(Math.atan2(h,u)-Math.atan2(c,-i))*s,b=g(r[0],r[1],o,y),_=g(r[0],r[1],m,x);return b<=_?[o,y,r[2]]:[m,x,r[2]]}(l,r,d);isFinite(p[0])&&isFinite(p[1])&&isFinite(p[2])||(p=d),t.rotate(p),d=p}}else r=m(t,c=e);h.of(this,arguments)({type:"zoom"})})),e=h.of(this,arguments),p++||e({type:"zoomstart"})})).on("zoomend",(function(){var r;n.select(this).style(c),f.call(o,"zoom",null),r=h.of(this,arguments),--p||r({type:"zoomend"}),d(e,t,y)})).on("zoom.redraw",(function(){e.render(!0);var r=t.rotate();e.graphDiv.emit("plotly_relayouting",{"geo.projection.scale":t.scale()/e.fitScale,"geo.projection.rotation.lon":-r[0],"geo.projection.rotation.lat":-r[1]})})),n.rebind(o,h,"on")}function m(e,t){var r=e.invert(t);return r&&isFinite(r[0])&&isFinite(r[1])&&function(e){var t=e[0]*a,r=e[1]*a,n=Math.cos(r);return[n*Math.cos(t),n*Math.sin(t),Math.sin(r)]}(r)}function g(e,t,r,n){var i=y(r-e),o=y(n-t);return Math.sqrt(i*i+o*o)}function y(e){return(e%360+540)%360-180}function v(e,t,r){var n=r*a,i=e.slice(),o=0===t?1:0,s=2===t?1:2,l=Math.cos(n),c=Math.sin(n);return i[o]=e[o]*l-e[s]*c,i[s]=e[s]*l+e[o]*c,i}function x(e,t){for(var r=0,n=0,i=e.length;n{"use strict";var n=r(38361),i=r(93143).SUBPLOT_PATTERN;t.fX=function(e,t,r){var i=n.subplotsRegistry[t];if(!i)return[];for(var o=i.attr,a=[],s=0;s{"use strict";var n=r(96797),i=r(78306),o=r(58530),a=r(93143),s=r(17390);function l(e,t){this.element=e,this.plot=t,this.mouseListener=null,this.wheelListener=null,this.lastInputTime=Date.now(),this.lastPos=[0,0],this.boxEnabled=!1,this.boxInited=!1,this.boxStart=[0,0],this.boxEnd=[0,0],this.dragStart=[0,0]}e.exports=function(e){var t=e.mouseContainer,r=e.glplot,c=new l(t,r);function u(){e.xaxis.autorange=!1,e.yaxis.autorange=!1}function d(t,n,i){var o,s,l=e.calcDataBox(),d=r.viewBox,h=c.lastPos[0],p=c.lastPos[1],f=a.MINDRAG*r.pixelRatio,m=a.MINZOOM*r.pixelRatio;function g(t,r,n){var i=Math.min(r,n),o=Math.max(r,n);i!==o?(l[t]=i,l[t+2]=o,c.dataBox=l,e.setRanges(l)):(e.selectBox.selectBox=[0,0,1,1],e.glplot.setDirty())}switch(n*=r.pixelRatio,i*=r.pixelRatio,i=d[3]-d[1]-i,e.fullLayout.dragmode){case"zoom":if(t){var y=n/(d[2]-d[0])*(l[2]-l[0])+l[0],v=i/(d[3]-d[1])*(l[3]-l[1])+l[1];c.boxInited||(c.boxStart[0]=y,c.boxStart[1]=v,c.dragStart[0]=n,c.dragStart[1]=i),c.boxEnd[0]=y,c.boxEnd[1]=v,c.boxInited=!0,c.boxEnabled||c.boxStart[0]===c.boxEnd[0]&&c.boxStart[1]===c.boxEnd[1]||(c.boxEnabled=!0);var x=Math.abs(c.dragStart[0]-n)Math.abs(s)?(c.boxEnd[1]=c.boxStart[1]+Math.abs(o)*_*(s>=0?1:-1),c.boxEnd[1]l[3]&&(c.boxEnd[1]=l[3],c.boxEnd[0]=c.boxStart[0]+(l[3]-c.boxStart[1])/Math.abs(_))):(c.boxEnd[0]=c.boxStart[0]+Math.abs(s)/_*(o>=0?1:-1),c.boxEnd[0]l[2]&&(c.boxEnd[0]=l[2],c.boxEnd[1]=c.boxStart[1]+(l[2]-c.boxStart[0])*Math.abs(_)))}}else c.boxEnabled?(o=c.boxStart[0]!==c.boxEnd[0],s=c.boxStart[1]!==c.boxEnd[1],o||s?(o&&(g(0,c.boxStart[0],c.boxEnd[0]),e.xaxis.autorange=!1),s&&(g(1,c.boxStart[1],c.boxEnd[1]),e.yaxis.autorange=!1),e.relayoutCallback()):e.glplot.setDirty(),c.boxEnabled=!1,c.boxInited=!1):c.boxInited&&(c.boxInited=!1);break;case"pan":c.boxEnabled=!1,c.boxInited=!1,t?(c.panning||(c.dragStart[0]=n,c.dragStart[1]=i),Math.abs(c.dragStart[0]-n){"use strict";var n=r(85729),i=r(79689);function o(e){this.scene=e,this.gl=e.gl,this.pixelRatio=e.pixelRatio,this.screenBox=[0,0,1,1],this.viewBox=[0,0,1,1],this.dataBox=[-1,-1,1,1],this.borderLineEnable=[!1,!1,!1,!1],this.borderLineWidth=[1,1,1,1],this.borderLineColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.ticks=[[],[]],this.tickEnable=[!0,!0,!1,!1],this.tickPad=[15,15,15,15],this.tickAngle=[0,0,0,0],this.tickColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.tickMarkLength=[0,0,0,0],this.tickMarkWidth=[0,0,0,0],this.tickMarkColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.labels=["x","y"],this.labelEnable=[!0,!0,!1,!1],this.labelAngle=[0,Math.PI/2,0,3*Math.PI/2],this.labelPad=[15,15,15,15],this.labelSize=[12,12],this.labelFont=["sans-serif","sans-serif"],this.labelColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.title="",this.titleEnable=!0,this.titleCenter=[0,0,0,0],this.titleAngle=0,this.titleColor=[0,0,0,1],this.titleFont="sans-serif",this.titleSize=18,this.gridLineEnable=[!0,!0],this.gridLineColor=[[0,0,0,.5],[0,0,0,.5]],this.gridLineWidth=[1,1],this.zeroLineEnable=[!0,!0],this.zeroLineWidth=[1,1],this.zeroLineColor=[[0,0,0,1],[0,0,0,1]],this.borderColor=[0,0,0,0],this.backgroundColor=[0,0,0,0],this.static=this.scene.staticPlot}var a=o.prototype,s=["xaxis","yaxis"];a.merge=function(e){var t,r,n,o,a,l,c,u,d,h,p;for(this.titleEnable=!1,this.backgroundColor=i(e.plot_bgcolor),h=0;h<2;++h){var f=(t=s[h]).charAt(0);for(n=(r=e[this.scene[t]._name]).title.text===this.scene.fullLayout._dfltTitle[f]?"":r.title.text,p=0;p<=2;p+=2)this.labelEnable[h+p]=!1,this.labels[h+p]=n,this.labelColor[h+p]=i(r.title.font.color),this.labelFont[h+p]=r.title.font.family,this.labelSize[h+p]=r.title.font.size,this.labelPad[h+p]=this.getLabelPad(t,r),this.tickEnable[h+p]=!1,this.tickColor[h+p]=i((r.tickfont||{}).color),this.tickAngle[h+p]="auto"===r.tickangle?0:Math.PI*-r.tickangle/180,this.tickPad[h+p]=this.getTickPad(r),this.tickMarkLength[h+p]=0,this.tickMarkWidth[h+p]=r.tickwidth||0,this.tickMarkColor[h+p]=i(r.tickcolor),this.borderLineEnable[h+p]=!1,this.borderLineColor[h+p]=i(r.linecolor),this.borderLineWidth[h+p]=r.linewidth||0;c=this.hasSharedAxis(r),a=this.hasAxisInDfltPos(t,r)&&!c,l=this.hasAxisInAltrPos(t,r)&&!c,o=r.mirror||!1,u=c?-1!==String(o).indexOf("all"):!!o,d=c?"allticks"===o:-1!==String(o).indexOf("ticks"),a?this.labelEnable[h]=!0:l&&(this.labelEnable[h+2]=!0),a?this.tickEnable[h]=r.showticklabels:l&&(this.tickEnable[h+2]=r.showticklabels),(a||u)&&(this.borderLineEnable[h]=r.showline),(l||u)&&(this.borderLineEnable[h+2]=r.showline),(a||d)&&(this.tickMarkLength[h]=this.getTickMarkLength(r)),(l||d)&&(this.tickMarkLength[h+2]=this.getTickMarkLength(r)),this.gridLineEnable[h]=r.showgrid,this.gridLineColor[h]=i(r.gridcolor),this.gridLineWidth[h]=r.gridwidth,this.zeroLineEnable[h]=r.zeroline,this.zeroLineColor[h]=i(r.zerolinecolor),this.zeroLineWidth[h]=r.zerolinewidth}},a.hasSharedAxis=function(e){var t=this.scene,r=t.fullLayout._subplots.gl2d;return 0!==n.findSubplotsWithAxis(r,e).indexOf(t.id)},a.hasAxisInDfltPos=function(e,t){var r=t.side;return"xaxis"===e?"bottom"===r:"yaxis"===e?"left"===r:void 0},a.hasAxisInAltrPos=function(e,t){var r=t.side;return"xaxis"===e?"top"===r:"yaxis"===e?"right"===r:void 0},a.getLabelPad=function(e,t){var r=1.5,n=t.title.font.size,i=t.showticklabels;return"xaxis"===e?"top"===t.side?n*(r+(i?1:0))-10:n*(r+(i?.5:0))-10:"yaxis"===e?"right"===t.side?10+n*(r+(i?1:.5)):10+n*(r+(i?.5:0)):void 0},a.getTickPad=function(e){return"outside"===e.ticks?10+e.ticklen:15},a.getTickMarkLength=function(e){if(!e.ticks)return 0;var t=e.ticklen;return"inside"===e.ticks?-t:t},e.exports=function(e){return new o(e)}},84017:(e,t,r)=>{"use strict";var n=r(72587).overrideAll,i=r(86107),o=r(98005),a=r(28795),s=r(93143),l=r(9510),c=r(97174),u=r(50246).KO;t.name="gl2d",t.attr=["xaxis","yaxis"],t.idRoot=["x","y"],t.idRegex=s.idRegex,t.attrRegex=s.attrRegex,t.attributes=r(86237),t.supplyLayoutDefaults=function(e,t,r){t._has("cartesian")||l.supplyLayoutDefaults(e,t,r)},t.layoutAttrOverrides=n(l.layoutAttributes,"plot","from-root"),t.baseLayoutAttrOverrides=n({plot_bgcolor:o.plot_bgcolor,hoverlabel:c.hoverlabel},"plot","nested"),t.plot=function(e){for(var t=e._fullLayout,r=e._fullData,n=t._subplots.gl2d,o=0;o{"use strict";var n,i,o=r(38361),a=r(85729),s=r(32212),l=r(76107).gl_plot2d,c=r(76107).gl_spikes2d,u=r(76107).gl_select_box,d=r(46095),h=r(19450),p=r(44634),f=r(27849),m=r(80038),g=m.enforce,y=m.clean,v=r(49618).doAutoRange,x=r(2705),b=x.drawMode,_=x.selectMode,w=["xaxis","yaxis"],k=r(93143).SUBPLOT_PATTERN;function S(e,t){this.container=e.container,this.graphDiv=e.graphDiv,this.pixelRatio=e.plotGlPixelRatio||window.devicePixelRatio,this.id=e.id,this.staticPlot=!!e.staticPlot,this.scrollZoom=this.graphDiv._context._scrollZoom.cartesian,this.fullData=null,this.updateRefs(t),this.makeFramework(),this.stopped||(this.glplotOptions=h(this),this.glplotOptions.merge(t),this.glplot=l(this.glplotOptions),this.camera=p(this),this.traces={},this.spikes=c(this.glplot),this.selectBox=u(this.glplot,{innerFill:!1,outerFill:!0}),this.lastButtonState=0,this.pickResult=null,this.isMouseOver=!0,this.stopped=!1,this.redraw=this.draw.bind(this),this.redraw())}e.exports=S;var A=S.prototype;A.makeFramework=function(){if(this.staticPlot){if(!i&&(n=document.createElement("canvas"),!(i=d({canvas:n,preserveDrawingBuffer:!1,premultipliedAlpha:!0,antialias:!0}))))throw new Error("Error creating static canvas/context for image server");this.canvas=n,this.gl=i}else{var e=this.container.querySelector(".gl-canvas-focus"),t=d({canvas:e,preserveDrawingBuffer:!0,premultipliedAlpha:!0});if(!t)return f(this),void(this.stopped=!0);this.canvas=e,this.gl=t}var r=this.canvas;r.style.width="100%",r.style.height="100%",r.style.position="absolute",r.style.top="0px",r.style.left="0px",r.style["pointer-events"]="none",this.updateSize(r);var o=this.svgContainer=document.createElementNS("http://www.w3.org/2000/svg","svg");o.style.position="absolute",o.style.top=o.style.left="0px",o.style.width=o.style.height="100%",o.style["z-index"]=20,o.style["pointer-events"]="none";var a=this.mouseContainer=document.createElement("div");a.style.position="absolute",a.style["pointer-events"]="auto",this.pickCanvas=this.container.querySelector(".gl-canvas-pick");var s=this.container;s.appendChild(o),s.appendChild(a);var l=this;a.addEventListener("mouseout",(function(){l.isMouseOver=!1,l.unhover()})),a.addEventListener("mouseover",(function(){l.isMouseOver=!0}))},A.toImage=function(e){e||(e="png"),this.stopped=!0,this.staticPlot&&this.container.appendChild(n),this.updateSize(this.canvas);var t=this.glplot.gl,r=t.drawingBufferWidth,i=t.drawingBufferHeight;t.clearColor(1,1,1,0),t.clear(t.COLOR_BUFFER_BIT|t.DEPTH_BUFFER_BIT),this.glplot.setDirty(),this.glplot.draw(),t.bindFramebuffer(t.FRAMEBUFFER,null);var o=new Uint8Array(r*i*4);t.readPixels(0,0,r,i,t.RGBA,t.UNSIGNED_BYTE,o);for(var a=0,s=i-1;a{"use strict";var n=r(72587).overrideAll,i=r(97174),o=r(76960),a=r(50246).KO,s=r(84468),l=r(28795),c="gl3d",u="scene";t.name=c,t.attr=u,t.idRoot=u,t.idRegex=t.attrRegex=s.counterRegex("scene"),t.attributes=r(70706),t.layoutAttributes=r(78465),t.baseLayoutAttrOverrides=n({hoverlabel:i.hoverlabel},"plot","nested"),t.supplyLayoutDefaults=r(23845),t.plot=function(e){for(var t=e._fullLayout,r=e._fullData,n=t._subplots[c],i=0;i{"use strict";e.exports={scene:{valType:"subplotid",dflt:"scene",editType:"calc+clearAxisTypes",description:["Sets a reference between this trace's 3D coordinate system and","a 3D scene.","If *scene* (the default value), the (x,y,z) coordinates refer to","`layout.scene`.","If *scene2*, the (x,y,z) coordinates refer to `layout.scene2`,","and so on."].join(" ")}}},56556:(e,t,r)=>{"use strict";var n=r(7605),i=r(49080),o=r(64022).extendFlat,a=r(72587).overrideAll;e.exports=a({visible:i.visible,showspikes:{valType:"boolean",dflt:!0,description:["Sets whether or not spikes starting from","data points to this axis' wall are shown on hover."].join(" ")},spikesides:{valType:"boolean",dflt:!0,description:["Sets whether or not spikes extending from the","projection data points to this axis' wall boundaries","are shown on hover."].join(" ")},spikethickness:{valType:"number",min:0,dflt:2,description:"Sets the thickness (in px) of the spikes."},spikecolor:{valType:"color",dflt:n.defaultLine,description:"Sets the color of the spikes."},showbackground:{valType:"boolean",dflt:!1,description:["Sets whether or not this axis' wall","has a background color."].join(" ")},backgroundcolor:{valType:"color",dflt:"rgba(204, 204, 204, 0.5)",description:"Sets the background color of this axis' wall."},showaxeslabels:{valType:"boolean",dflt:!0,description:"Sets whether or not this axis is labeled"},color:i.color,categoryorder:i.categoryorder,categoryarray:i.categoryarray,title:{text:i.title.text,font:i.title.font},type:o({},i.type,{values:["-","linear","log","date","category"]}),autotypenumbers:i.autotypenumbers,autorange:i.autorange,autorangeoptions:{minallowed:i.autorangeoptions.minallowed,maxallowed:i.autorangeoptions.maxallowed,clipmin:i.autorangeoptions.clipmin,clipmax:i.autorangeoptions.clipmax,include:i.autorangeoptions.include,editType:"plot"},rangemode:i.rangemode,minallowed:i.minallowed,maxallowed:i.maxallowed,range:o({},i.range,{items:[{valType:"any",editType:"plot",impliedEdits:{"^autorange":!1}},{valType:"any",editType:"plot",impliedEdits:{"^autorange":!1}}],anim:!1}),tickmode:i.minor.tickmode,nticks:i.nticks,tick0:i.tick0,dtick:i.dtick,tickvals:i.tickvals,ticktext:i.ticktext,ticks:i.ticks,mirror:i.mirror,ticklen:i.ticklen,tickwidth:i.tickwidth,tickcolor:i.tickcolor,showticklabels:i.showticklabels,labelalias:i.labelalias,tickfont:i.tickfont,tickangle:i.tickangle,tickprefix:i.tickprefix,showtickprefix:i.showtickprefix,ticksuffix:i.ticksuffix,showticksuffix:i.showticksuffix,showexponent:i.showexponent,exponentformat:i.exponentformat,minexponent:i.minexponent,separatethousands:i.separatethousands,tickformat:i.tickformat,tickformatstops:i.tickformatstops,hoverformat:i.hoverformat,showline:i.showline,linecolor:i.linecolor,linewidth:i.linewidth,showgrid:i.showgrid,gridcolor:o({},i.gridcolor,{dflt:"rgb(204, 204, 204)"}),gridwidth:i.gridwidth,zeroline:i.zeroline,zerolinecolor:i.zerolinecolor,zerolinewidth:i.zerolinewidth,_deprecated:{title:i._deprecated.title,titlefont:i._deprecated.titlefont}},"plot","from-root")},89051:(e,t,r)=>{"use strict";var n=r(23498).mix,i=r(84468),o=r(37091),a=r(56556),s=r(18453),l=r(42730),c=["xaxis","yaxis","zaxis"],u=13600/187;e.exports=function(e,t,r){var d,h;function p(e,t){return i.coerce(d,h,a,e,t)}for(var f=0;f{"use strict";var n=r(79689),i=r(84468),o=["xaxis","yaxis","zaxis"];function a(){this.bounds=[[-10,-10,-10],[10,10,10]],this.ticks=[[],[],[]],this.tickEnable=[!0,!0,!0],this.tickFont=["sans-serif","sans-serif","sans-serif"],this.tickSize=[12,12,12],this.tickFontWeight=["normal","normal","normal","normal"],this.tickFontStyle=["normal","normal","normal","normal"],this.tickFontVariant=["normal","normal","normal","normal"],this.tickAngle=[0,0,0],this.tickColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.tickPad=[18,18,18],this.labels=["x","y","z"],this.labelEnable=[!0,!0,!0],this.labelFont=["Open Sans","Open Sans","Open Sans"],this.labelSize=[20,20,20],this.labelFontWeight=["normal","normal","normal","normal"],this.labelFontStyle=["normal","normal","normal","normal"],this.labelFontVariant=["normal","normal","normal","normal"],this.labelColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.labelPad=[30,30,30],this.lineEnable=[!0,!0,!0],this.lineMirror=[!1,!1,!1],this.lineWidth=[1,1,1],this.lineColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.lineTickEnable=[!0,!0,!0],this.lineTickMirror=[!1,!1,!1],this.lineTickLength=[10,10,10],this.lineTickWidth=[1,1,1],this.lineTickColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.gridEnable=[!0,!0,!0],this.gridWidth=[1,1,1],this.gridColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.zeroEnable=[!0,!0,!0],this.zeroLineColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.zeroLineWidth=[2,2,2],this.backgroundEnable=[!0,!0,!0],this.backgroundColor=[[.8,.8,.8,.5],[.8,.8,.8,.5],[.8,.8,.8,.5]],this._defaultTickPad=this.tickPad.slice(),this._defaultLabelPad=this.labelPad.slice(),this._defaultLineTickLength=this.lineTickLength.slice()}a.prototype.merge=function(e,t){for(var r=this,a=0;a<3;++a){var s=t[o[a]];s.visible?(r.labels[a]=e._meta?i.templateString(s.title.text,e._meta):s.title.text,"font"in s.title&&(s.title.font.color&&(r.labelColor[a]=n(s.title.font.color)),s.title.font.family&&(r.labelFont[a]=s.title.font.family),s.title.font.size&&(r.labelSize[a]=s.title.font.size),s.title.font.weight&&(r.labelFontWeight[a]=s.title.font.weight),s.title.font.style&&(r.labelFontStyle[a]=s.title.font.style),s.title.font.variant&&(r.labelFontVariant[a]=s.title.font.variant)),"showline"in s&&(r.lineEnable[a]=s.showline),"linecolor"in s&&(r.lineColor[a]=n(s.linecolor)),"linewidth"in s&&(r.lineWidth[a]=s.linewidth),"showgrid"in s&&(r.gridEnable[a]=s.showgrid),"gridcolor"in s&&(r.gridColor[a]=n(s.gridcolor)),"gridwidth"in s&&(r.gridWidth[a]=s.gridwidth),"log"===s.type?r.zeroEnable[a]=!1:"zeroline"in s&&(r.zeroEnable[a]=s.zeroline),"zerolinecolor"in s&&(r.zeroLineColor[a]=n(s.zerolinecolor)),"zerolinewidth"in s&&(r.zeroLineWidth[a]=s.zerolinewidth),"ticks"in s&&s.ticks?r.lineTickEnable[a]=!0:r.lineTickEnable[a]=!1,"ticklen"in s&&(r.lineTickLength[a]=r._defaultLineTickLength[a]=s.ticklen),"tickcolor"in s&&(r.lineTickColor[a]=n(s.tickcolor)),"tickwidth"in s&&(r.lineTickWidth[a]=s.tickwidth),"tickangle"in s&&(r.tickAngle[a]="auto"===s.tickangle?-3600:Math.PI*-s.tickangle/180),"showticklabels"in s&&(r.tickEnable[a]=s.showticklabels),"tickfont"in s&&(s.tickfont.color&&(r.tickColor[a]=n(s.tickfont.color)),s.tickfont.family&&(r.tickFont[a]=s.tickfont.family),s.tickfont.size&&(r.tickSize[a]=s.tickfont.size),s.tickfont.weight&&(r.tickFontWeight[a]=s.tickfont.weight),s.tickfont.style&&(r.tickFontStyle[a]=s.tickfont.style),s.tickfont.variant&&(r.tickFontVariant[a]=s.tickfont.variant)),"mirror"in s?-1!==["ticks","all","allticks"].indexOf(s.mirror)?(r.lineTickMirror[a]=!0,r.lineMirror[a]=!0):!0===s.mirror?(r.lineTickMirror[a]=!1,r.lineMirror[a]=!0):(r.lineTickMirror[a]=!1,r.lineMirror[a]=!1):r.lineMirror[a]=!1,"showbackground"in s&&!1!==s.showbackground?(r.backgroundEnable[a]=!0,r.backgroundColor[a]=n(s.backgroundcolor)):r.backgroundEnable[a]=!1):(r.tickEnable[a]=!1,r.labelEnable[a]=!1,r.lineEnable[a]=!1,r.lineTickEnable[a]=!1,r.gridEnable[a]=!1,r.zeroEnable[a]=!1,r.backgroundEnable[a]=!1)}},e.exports=function(e,t){var r=new a;return r.merge(e,t),r}},23845:(e,t,r)=>{"use strict";var n=r(84468),i=r(7605),o=r(38361),a=r(54883),s=r(89051),l=r(78465),c=r(50246).KO,u="gl3d";function d(e,t,r,n){for(var a=r("bgcolor"),l=i.combine(a,n.paper_bgcolor),d=["up","center","eye"],h=0;h.999&&(g="turntable"):g="turntable")}else g="turntable";r("dragmode",g),r("hovermode",n.getDfltFromLayout("hovermode"))}e.exports=function(e,t,r){var i=t._basePlotModules.length>1;a(e,t,r,{type:u,attributes:l,handleDefaults:d,fullLayout:t,font:t.font,fullData:r,getDfltFromLayout:function(t){if(!i)return n.validate(e[t],l[t])?e[t]:void 0},autotypenumbersDflt:t.autotypenumbers,paper_bgcolor:t.paper_bgcolor,calendar:t.calendar})}},78465:(e,t,r)=>{"use strict";var n=r(56556),i=r(81159).u,o=r(64022).extendFlat,a=r(84468).counterRegex;function s(e,t,r){return{x:{valType:"number",dflt:e,editType:"camera"},y:{valType:"number",dflt:t,editType:"camera"},z:{valType:"number",dflt:r,editType:"camera"},editType:"camera"}}e.exports={_arrayAttrRegexps:[a("scene",".annotations",!0)],bgcolor:{valType:"color",dflt:"rgba(0,0,0,0)",editType:"plot"},camera:{up:o(s(0,0,1),{description:["Sets the (x,y,z) components of the 'up' camera vector.","This vector determines the up direction of this scene","with respect to the page.","The default is *{x: 0, y: 0, z: 1}* which means that","the z axis points up."].join(" ")}),center:o(s(0,0,0),{description:["Sets the (x,y,z) components of the 'center' camera vector","This vector determines the translation (x,y,z) space","about the center of this scene.","By default, there is no such translation."].join(" ")}),eye:o(s(1.25,1.25,1.25),{description:["Sets the (x,y,z) components of the 'eye' camera vector.","This vector determines the view point about the origin","of this scene."].join(" ")}),projection:{type:{valType:"enumerated",values:["perspective","orthographic"],dflt:"perspective",editType:"calc",description:["Sets the projection type. The projection type could be","either *perspective* or *orthographic*. The default is","*perspective*."].join(" ")},editType:"calc"},editType:"camera"},domain:i({name:"scene",editType:"plot"}),aspectmode:{valType:"enumerated",values:["auto","cube","data","manual"],dflt:"auto",editType:"plot",impliedEdits:{"aspectratio.x":void 0,"aspectratio.y":void 0,"aspectratio.z":void 0},description:["If *cube*, this scene's axes are drawn as a cube,","regardless of the axes' ranges.","If *data*, this scene's axes are drawn","in proportion with the axes' ranges.","If *manual*, this scene's axes are drawn","in proportion with the input of *aspectratio*","(the default behavior if *aspectratio* is provided).","If *auto*, this scene's axes are drawn","using the results of *data* except when one axis","is more than four times the size of the two others,","where in that case the results of *cube* are used."].join(" ")},aspectratio:{x:{valType:"number",min:0,editType:"plot",impliedEdits:{"^aspectmode":"manual"}},y:{valType:"number",min:0,editType:"plot",impliedEdits:{"^aspectmode":"manual"}},z:{valType:"number",min:0,editType:"plot",impliedEdits:{"^aspectmode":"manual"}},editType:"plot",impliedEdits:{aspectmode:"manual"},description:["Sets this scene's axis aspectratio."].join(" ")},xaxis:n,yaxis:n,zaxis:n,dragmode:{valType:"enumerated",values:["orbit","turntable","zoom","pan",!1],editType:"plot",description:["Determines the mode of drag interactions for this scene."].join(" ")},hovermode:{valType:"enumerated",values:["closest",!1],dflt:"closest",editType:"modebar",description:["Determines the mode of hover interactions for this scene."].join(" ")},uirevision:{valType:"any",editType:"none",description:["Controls persistence of user-driven changes in camera attributes.","Defaults to `layout.uirevision`."].join(" ")},editType:"plot",_deprecated:{cameraposition:{valType:"info_array",editType:"camera",description:"Obsolete. Use `camera` instead."}}}},68044:(e,t,r)=>{"use strict";var n=r(79689),i=["xaxis","yaxis","zaxis"];function o(){this.enabled=[!0,!0,!0],this.colors=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.drawSides=[!0,!0,!0],this.lineWidth=[1,1,1]}o.prototype.merge=function(e){for(var t=0;t<3;++t){var r=e[i[t]];r.visible?(this.enabled[t]=r.showspikes,this.colors[t]=n(r.spikecolor),this.drawSides[t]=r.spikesides,this.lineWidth[t]=r.spikethickness):(this.enabled[t]=!1,this.drawSides[t]=!1)}},e.exports=function(e){var t=new o;return t.merge(e),t}},44435:(e,t,r)=>{"use strict";e.exports=function(e){for(var t=e.axesOptions,r=e.glplot.axesPixels,s=e.fullSceneLayout,l=[[],[],[]],c=0;c<3;++c){var u=s[o[c]];if(u._length=(r[c].hi-r[c].lo)*r[c].pixelsPerDataUnit/e.dataScale[c],Math.abs(u._length)===1/0||isNaN(u._length))l[c]=[];else{u._input_range=u.range.slice(),u.range[0]=r[c].lo/e.dataScale[c],u.range[1]=r[c].hi/e.dataScale[c],u._m=1/(e.dataScale[c]*r[c].pixelsPerDataUnit),u.range[0]===u.range[1]&&(u.range[0]-=1,u.range[1]+=1);var d=u.tickmode;if("auto"===u.tickmode){u.tickmode="linear";var h=u.nticks||i.constrain(u._length/40,4,9);n.autoTicks(u,Math.abs(u.range[1]-u.range[0])/h)}for(var p=n.calcTicks(u,{msUTC:!0}),f=0;f/g," "));l[c]=p,u.tickmode=d}}t.ticks=l;for(c=0;c<3;++c){a[c]=.5*(e.glplot.bounds[0][c]+e.glplot.bounds[1][c]);for(f=0;f<2;++f)t.bounds[f][c]=e.glplot.bounds[f][c]}e.contourLevels=function(e){for(var t=new Array(3),r=0;r<3;++r){for(var n=e[r],i=new Array(n.length),o=0;o{"use strict";function t(e,t){var r,n,i=[0,0,0,0];for(r=0;r<4;++r)for(n=0;n<4;++n)i[n]+=e[4*r+n]*t[r];return i}e.exports=function(e,r){return t(e.projection,t(e.view,t(e.model,[r[0],r[1],r[2],1])))}},76960:(e,t,r)=>{"use strict";var n,i,o=r(76107).gl_plot3d,a=o.createCamera,s=o.createScene,l=r(46095),c=r(17390),u=r(38361),d=r(84468),h=d.preserveDrawingBuffer(),p=r(85729),f=r(32212),m=r(79689),g=r(27849),y=r(65393),v=r(596),x=r(68044),b=r(44435),_=r(49618).applyAutorangeOptions,w=!1;function k(e,t){var r=document.createElement("div"),n=e.container;this.graphDiv=e.graphDiv;var i=document.createElementNS("http://www.w3.org/2000/svg","svg");i.style.position="absolute",i.style.top=i.style.left="0px",i.style.width=i.style.height="100%",i.style["z-index"]=20,i.style["pointer-events"]="none",r.appendChild(i),this.svgContainer=i,r.id=e.id,r.style.position="absolute",r.style.top=r.style.left="0px",r.style.width=r.style.height="100%",n.appendChild(r),this.fullLayout=t,this.id=e.id||"scene",this.fullSceneLayout=t[this.id],this.plotArgs=[[],{},{}],this.axesOptions=v(t,t[this.id]),this.spikeOptions=x(t[this.id]),this.container=r,this.staticMode=!!e.staticPlot,this.pixelRatio=this.pixelRatio||e.plotGlPixelRatio||2,this.dataScale=[1,1,1],this.contourLevels=[[],[],[]],this.convertAnnotations=u.getComponentMethod("annotations3d","convert"),this.drawAnnotations=u.getComponentMethod("annotations3d","draw"),this.initializeGLPlot()}var S=k.prototype;S.prepareOptions=function(){var e=this,t={canvas:e.canvas,gl:e.gl,glOptions:{preserveDrawingBuffer:h,premultipliedAlpha:!0,antialias:!0},container:e.container,axes:e.axesOptions,spikes:e.spikeOptions,pickRadius:10,snapToData:!0,autoScale:!0,autoBounds:!1,cameraObject:e.camera,pixelRatio:e.pixelRatio};if(e.staticMode){if(!i&&(n=document.createElement("canvas"),!(i=l({canvas:n,preserveDrawingBuffer:!0,premultipliedAlpha:!0,antialias:!0}))))throw new Error("error creating static canvas/context for image server");t.gl=i,t.canvas=n}return t};var A=!0;S.tryCreatePlot=function(){var e=this,t=e.prepareOptions(),r=!0;try{e.glplot=s(t)}catch(n){if(e.staticMode||!A||h)r=!1;else{d.warn(["webgl setup failed possibly due to","false preserveDrawingBuffer config.","The mobile/tablet device may not be detected by is-mobile module.","Enabling preserveDrawingBuffer in second attempt to create webgl scene..."].join(" "));try{h=t.glOptions.preserveDrawingBuffer=!0,e.glplot=s(t)}catch(n){h=t.glOptions.preserveDrawingBuffer=!1,r=!1}}}return A=!1,r},S.initializeGLCamera=function(){var e=this,t=e.fullSceneLayout.camera,r="orthographic"===t.projection.type;e.camera=a(e.container,{center:[t.center.x,t.center.y,t.center.z],eye:[t.eye.x,t.eye.y,t.eye.z],up:[t.up.x,t.up.y,t.up.z],_ortho:r,zoomMin:.01,zoomMax:100,mode:"orbit"})},S.initializeGLPlot=function(){var e=this;if(e.initializeGLCamera(),!e.tryCreatePlot())return g(e);e.traces={},e.make4thDimension();var t=e.graphDiv,r=t.layout,n=function(){var t={};return e.isCameraChanged(r)&&(t[e.id+".camera"]=e.getCamera()),e.isAspectChanged(r)&&(t[e.id+".aspectratio"]=e.glplot.getAspectratio(),"manual"!==r[e.id].aspectmode&&(e.fullSceneLayout.aspectmode=r[e.id].aspectmode=t[e.id+".aspectmode"]="manual")),t},i=function(e){if(!1!==e.fullSceneLayout.dragmode){var t=n();e.saveLayout(r),e.graphDiv.emit("plotly_relayout",t)}};return e.glplot.canvas&&(e.glplot.canvas.addEventListener("mouseup",(function(){i(e)})),e.glplot.canvas.addEventListener("touchstart",(function(){w=!0})),e.glplot.canvas.addEventListener("wheel",(function(r){if(t._context._scrollZoom.gl3d){if(e.camera._ortho){var n=r.deltaX>r.deltaY?1.1:1/1.1,o=e.glplot.getAspectratio();e.glplot.setAspectratio({x:n*o.x,y:n*o.y,z:n*o.z})}i(e)}}),!!c&&{passive:!1}),e.glplot.canvas.addEventListener("mousemove",(function(){if(!1!==e.fullSceneLayout.dragmode&&0!==e.camera.mouseListener.buttons){var t=n();e.graphDiv.emit("plotly_relayouting",t)}})),e.staticMode||e.glplot.canvas.addEventListener("webglcontextlost",(function(r){t&&t.emit&&t.emit("plotly_webglcontextlost",{event:r,layer:e.id})}),!1)),e.glplot.oncontextloss=function(){e.recoverContext()},e.glplot.onrender=function(){e.render()},!0},S.render=function(){var e,t=this,r=t.graphDiv,n=t.svgContainer,i=t.container.getBoundingClientRect();r._fullLayout._calcInverseTransform(r);var o=r._fullLayout._invScaleX,a=r._fullLayout._invScaleY,s=i.width*o,l=i.height*a;n.setAttributeNS(null,"viewBox","0 0 "+s+" "+l),n.setAttributeNS(null,"width",s),n.setAttributeNS(null,"height",l),b(t),t.glplot.axes.update(t.axesOptions);for(var c=Object.keys(t.traces),u=null,h=t.glplot.selection,m=0;m")):"isosurface"===e.type||"volume"===e.type?(S.valueLabel=p.hoverLabelText(t._mockAxis,t._mockAxis.d2l(h.traceCoordinate[3]),e.valuehoverformat),C.push("value: "+S.valueLabel),h.textLabel&&C.push(h.textLabel),x=C.join("
")):x=h.textLabel;var E={x:h.traceCoordinate[0],y:h.traceCoordinate[1],z:h.traceCoordinate[2],data:_._input,fullData:_,curveNumber:_.index,pointNumber:k};f.appendArrayPointValue(E,_,k),e._module.eventData&&(E=_._module.eventData(E,h,_,{},k));var I={points:[E]};if(t.fullSceneLayout.hovermode){var P=[];f.loneHover({trace:_,x:(.5+.5*v[0]/v[3])*s,y:(.5-.5*v[1]/v[3])*l,xLabel:S.xLabel,yLabel:S.yLabel,zLabel:S.zLabel,text:x,name:u.name,color:f.castHoverOption(_,k,"bgcolor")||u.color,borderColor:f.castHoverOption(_,k,"bordercolor"),fontFamily:f.castHoverOption(_,k,"font.family"),fontSize:f.castHoverOption(_,k,"font.size"),fontColor:f.castHoverOption(_,k,"font.color"),nameLength:f.castHoverOption(_,k,"namelength"),textAlign:f.castHoverOption(_,k,"align"),hovertemplate:d.castOption(_,k,"hovertemplate"),hovertemplateLabels:d.extendFlat({},E,S),eventData:[E]},{container:n,gd:r,inOut_bbox:P}),E.bbox=P[0]}h.distance<5&&(h.buttons||w)?r.emit("plotly_click",I):r.emit("plotly_hover",I),this.oldEventData=I}else f.loneUnhover(n),this.oldEventData&&r.emit("plotly_unhover",this.oldEventData),this.oldEventData=void 0;t.drawAnnotations(t)},S.recoverContext=function(){var e=this;e.glplot.dispose();var t=function(){e.glplot.gl.isContextLost()?requestAnimationFrame(t):e.initializeGLPlot()?e.plot.apply(e,e.plotArgs):d.error("Catastrophic and unrecoverable WebGL error. Context lost.")};requestAnimationFrame(t)};var T=["xaxis","yaxis","zaxis"];function M(e,t,r){for(var n=e.fullSceneLayout,i=0;i<3;i++){var o=T[i],a=o.charAt(0),s=n[o],l=t[a],c=t[a+"calendar"],u=t["_"+a+"length"];if(d.isArrayOrTypedArray(l))for(var h,p=0;p<(u||l.length);p++)if(d.isArrayOrTypedArray(l[p]))for(var f=0;fy[1][a])y[0][a]=-1,y[1][a]=1;else{var O=y[1][a]-y[0][a];y[0][a]-=O/32,y[1][a]+=O/32}if(b=[y[0][a],y[1][a]],b=_(b,l),y[0][a]=b[0],y[1][a]=b[1],l.isReversed()){var R=y[0][a];y[0][a]=y[1][a],y[1][a]=R}}else b=l.range,y[0][a]=l.r2l(b[0]),y[1][a]=l.r2l(b[1]);y[0][a]===y[1][a]&&(y[0][a]-=1,y[1][a]+=1),v[a]=y[1][a]-y[0][a],l.range=[y[0][a],y[1][a]],l.limitRange(),n.glplot.setBounds(a,{min:l.range[0]*p[a],max:l.range[1]*p[a]})}var L=u.aspectmode;if("cube"===L)g=[1,1,1];else if("manual"===L){var D=u.aspectratio;g=[D.x,D.y,D.z]}else{if("auto"!==L&&"data"!==L)throw new Error("scene.js aspectRatio was not one of the enumerated types");var z=[1,1,1];for(a=0;a<3;++a){var j=x[c=(l=u[T[a]]).type];z[a]=Math.pow(j.acc,1/j.count)/p[a]}g="data"===L||Math.max.apply(null,z)/Math.min.apply(null,z)<=4?z:[1,1,1]}u.aspectratio.x=d.aspectratio.x=g[0],u.aspectratio.y=d.aspectratio.y=g[1],u.aspectratio.z=d.aspectratio.z=g[2],n.glplot.setAspectratio(u.aspectratio),n.viewInitial.aspectratio||(n.viewInitial.aspectratio={x:u.aspectratio.x,y:u.aspectratio.y,z:u.aspectratio.z}),n.viewInitial.aspectmode||(n.viewInitial.aspectmode=u.aspectmode);var F=u.domain||null,N=t._size||null;if(F&&N){var B=n.container.style;B.position="absolute",B.left=N.l+F.x[0]*N.w+"px",B.top=N.t+(1-F.y[1])*N.h+"px",B.width=N.w*(F.x[1]-F.x[0])+"px",B.height=N.h*(F.y[1]-F.y[0])+"px"}n.glplot.redraw()}},S.destroy=function(){var e=this;e.glplot&&(e.camera.mouseListener.enabled=!1,e.container.removeEventListener("wheel",e.camera.wheelListener),e.camera=null,e.glplot.dispose(),e.container.parentNode.removeChild(e.container),e.glplot=null)},S.getCamera=function(){var e,t=this;return t.camera.view.recalcMatrix(t.camera.view.lastT()),{up:{x:(e=t.camera).up[0],y:e.up[1],z:e.up[2]},center:{x:e.center[0],y:e.center[1],z:e.center[2]},eye:{x:e.eye[0],y:e.eye[1],z:e.eye[2]},projection:{type:!0===e._ortho?"orthographic":"perspective"}}},S.setViewport=function(e){var t,r=this,n=e.camera;r.camera.lookAt.apply(this,[[(t=n).eye.x,t.eye.y,t.eye.z],[t.center.x,t.center.y,t.center.z],[t.up.x,t.up.y,t.up.z]]),r.glplot.setAspectratio(e.aspectratio),"orthographic"===n.projection.type!==r.camera._ortho&&(r.glplot.redraw(),r.glplot.clearRGBA(),r.glplot.dispose(),r.initializeGLPlot())},S.isCameraChanged=function(e){var t=this.getCamera(),r=d.nestedProperty(e,this.id+".camera").get();function n(e,t,r,n){var i=["up","center","eye"],o=["x","y","z"];return t[i[r]]&&e[i[r]][o[n]]===t[i[r]][o[n]]}var i=!1;if(void 0===r)i=!0;else{for(var o=0;o<3;o++)for(var a=0;a<3;a++)if(!n(t,r,o,a)){i=!0;break}(!r.projection||t.projection&&t.projection.type!==r.projection.type)&&(i=!0)}return i},S.isAspectChanged=function(e){var t=this.glplot.getAspectratio(),r=d.nestedProperty(e,this.id+".aspectratio").get();return void 0===r||r.x!==t.x||r.y!==t.y||r.z!==t.z},S.saveLayout=function(e){var t,r,n,i,o,a,s=this,l=s.fullLayout,c=s.isCameraChanged(e),h=s.isAspectChanged(e),p=c||h;if(p){var f={};if(c&&(t=s.getCamera(),n=(r=d.nestedProperty(e,s.id+".camera")).get(),f[s.id+".camera"]=n),h&&(i=s.glplot.getAspectratio(),a=(o=d.nestedProperty(e,s.id+".aspectratio")).get(),f[s.id+".aspectratio"]=a),u.call("_storeDirectGUIEdit",e,l._preGUI,f),c)r.set(t),d.nestedProperty(l,s.id+".camera").set(t);if(h)o.set(i),d.nestedProperty(l,s.id+".aspectratio").set(i),s.glplot.redraw()}return p},S.updateFx=function(e,t){var r=this,n=r.camera;if(n)if("orbit"===e)n.mode="orbit",n.keyBindingMode="rotate";else if("turntable"===e){n.up=[0,0,1],n.mode="turntable",n.keyBindingMode="rotate";var i=r.graphDiv,o=i._fullLayout,a=r.fullSceneLayout.camera,s=a.up.x,l=a.up.y,c=a.up.z;if(c/Math.sqrt(s*s+l*l+c*c)<.999){var h=r.id+".camera.up",p={x:0,y:0,z:1},f={};f[h]=p;var m=i.layout;u.call("_storeDirectGUIEdit",m,o._preGUI,f),a.up=p,d.nestedProperty(m,h).set(p)}}else n.keyBindingMode=e;r.fullSceneLayout.hovermode=t},S.toImage=function(e){var t=this;e||(e="png"),t.staticMode&&t.container.appendChild(n),t.glplot.redraw();var r=t.glplot.gl,i=r.drawingBufferWidth,o=r.drawingBufferHeight;r.bindFramebuffer(r.FRAMEBUFFER,null);var a=new Uint8Array(i*o*4);r.readPixels(0,0,i,o,r.RGBA,r.UNSIGNED_BYTE,a),function(e,t,r){for(var n=0,i=r-1;n0)for(var s=255/a,l=0;l<3;++l)e[o+l]=Math.min(s*e[o+l],255)}}(a,i,o);var s=document.createElement("canvas");s.width=i,s.height=o;var l,c=s.getContext("2d",{willReadFrequently:!0}),u=c.createImageData(i,o);switch(u.data.set(a),c.putImageData(u,0,0),e){case"jpeg":l=s.toDataURL("image/jpeg");break;case"webp":l=s.toDataURL("image/webp");break;default:l=s.toDataURL("image/png")}return t.staticMode&&t.container.removeChild(n),l},S.setConvert=function(){for(var e=0;e<3;e++){var t=this.fullSceneLayout[T[e]];p.setConvert(t,this.fullLayout),t.setScale=d.noop}},S.make4thDimension=function(){var e=this,t=e.graphDiv._fullLayout;e._mockAxis={type:"linear",showexponent:"all",exponentformat:"B"},p.setConvert(e._mockAxis,t)},e.exports=k},11038:e=>{"use strict";e.exports=function(e,t,r,n){n=n||e.length;for(var i=new Array(n),o=0;o{"use strict";var n=r(91740),i=r(34765),o=r(17992),a=r(3374),s=r(26724),l=r(18420),c=r(64022).extendFlat,u=n({editType:"calc",description:["Sets the global font.","Note that fonts used in traces and other","layout components inherit from the global font."].join(" ")});u.family.dflt='"Open Sans", verdana, arial, sans-serif',u.size.dflt=12,u.color.dflt=o.defaultLine,e.exports={font:u,title:{text:{valType:"string",editType:"layoutstyle",description:["Sets the plot's title.","Note that before the existence of `title.text`, the title's","contents used to be defined as the `title` attribute itself.","This behavior has been deprecated."].join(" ")},font:n({editType:"layoutstyle",description:["Sets the title font.","Note that the title's font used to be customized","by the now deprecated `titlefont` attribute."].join(" ")}),subtitle:{text:{valType:"string",editType:"layoutstyle",description:"Sets the plot's subtitle."},font:n({editType:"layoutstyle",description:"Sets the subtitle font."}),editType:"layoutstyle"},xref:{valType:"enumerated",dflt:"container",values:["container","paper"],editType:"layoutstyle",description:["Sets the container `x` refers to.","*container* spans the entire `width` of the plot.","*paper* refers to the width of the plotting area only."].join(" ")},yref:{valType:"enumerated",dflt:"container",values:["container","paper"],editType:"layoutstyle",description:["Sets the container `y` refers to.","*container* spans the entire `height` of the plot.","*paper* refers to the height of the plotting area only."].join(" ")},x:{valType:"number",min:0,max:1,dflt:.5,editType:"layoutstyle",description:["Sets the x position with respect to `xref` in normalized","coordinates from *0* (left) to *1* (right)."].join(" ")},y:{valType:"number",min:0,max:1,dflt:"auto",editType:"layoutstyle",description:["Sets the y position with respect to `yref` in normalized","coordinates from *0* (bottom) to *1* (top).","*auto* places the baseline of the title onto the","vertical center of the top margin."].join(" ")},xanchor:{valType:"enumerated",dflt:"auto",values:["auto","left","center","right"],editType:"layoutstyle",description:["Sets the title's horizontal alignment with respect to its x position.","*left* means that the title starts at x,","*right* means that the title ends at x","and *center* means that the title's center is at x.","*auto* divides `xref` by three and calculates the `xanchor`","value automatically based on the value of `x`."].join(" ")},yanchor:{valType:"enumerated",dflt:"auto",values:["auto","top","middle","bottom"],editType:"layoutstyle",description:["Sets the title's vertical alignment with respect to its y position.","*top* means that the title's cap line is at y,","*bottom* means that the title's baseline is at y","and *middle* means that the title's midline is at y.","*auto* divides `yref` by three and calculates the `yanchor`","value automatically based on the value of `y`."].join(" ")},pad:c(l({editType:"layoutstyle"}),{description:["Sets the padding of the title.","Each padding value only applies when the corresponding","`xanchor`/`yanchor` value is set accordingly. E.g. for left","padding to take effect, `xanchor` must be set to *left*.","The same rule applies if `xanchor`/`yanchor` is determined automatically.","Padding is muted if the respective anchor value is *middle*/*center*."].join(" ")}),automargin:{valType:"boolean",dflt:!1,editType:"plot",description:["Determines whether the title can automatically push the figure margins.","If `yref='paper'` then the margin will expand to ensure that the title doesn\u2019t","overlap with the edges of the container. If `yref='container'` then the margins","will ensure that the title doesn\u2019t overlap with the plot area, tick labels,","and axis titles. If `automargin=true` and the margins need to be expanded,","then y will be set to a default 1 and yanchor will be set to an appropriate","default to ensure that minimal margin space is needed. Note that when `yref='paper'`,","only 1 or 0 are allowed y values. Invalid values will be reset to the default 1."].join(" ")},editType:"layoutstyle"},uniformtext:{mode:{valType:"enumerated",values:[!1,"hide","show"],dflt:!1,editType:"plot",description:["Determines how the font size for various text","elements are uniformed between each trace type.","If the computed text sizes were smaller than","the minimum size defined by `uniformtext.minsize`","using *hide* option hides the text; and","using *show* option shows the text without further downscaling.","Please note that if the size defined by `minsize` is greater than","the font size defined by trace, then the `minsize` is used."].join(" ")},minsize:{valType:"number",min:0,dflt:0,editType:"plot",description:["Sets the minimum text size between traces of the same type."].join(" ")},editType:"plot"},autosize:{valType:"boolean",dflt:!1,editType:"none",description:["Determines whether or not a layout width or height","that has been left undefined by the user","is initialized on each relayout.","Note that, regardless of this attribute,","an undefined layout width or height","is always initialized on the first call to plot."].join(" ")},width:{valType:"number",min:10,dflt:700,editType:"plot",description:["Sets the plot's width (in px)."].join(" ")},height:{valType:"number",min:10,dflt:450,editType:"plot",description:["Sets the plot's height (in px)."].join(" ")},minreducedwidth:{valType:"number",min:2,dflt:64,editType:"plot",description:"Minimum width of the plot with margin.automargin applied (in px)"},minreducedheight:{valType:"number",min:2,dflt:64,editType:"plot",description:"Minimum height of the plot with margin.automargin applied (in px)"},margin:{l:{valType:"number",min:0,dflt:80,editType:"plot",description:"Sets the left margin (in px)."},r:{valType:"number",min:0,dflt:80,editType:"plot",description:"Sets the right margin (in px)."},t:{valType:"number",min:0,dflt:100,editType:"plot",description:"Sets the top margin (in px)."},b:{valType:"number",min:0,dflt:80,editType:"plot",description:"Sets the bottom margin (in px)."},pad:{valType:"number",min:0,dflt:0,editType:"plot",description:["Sets the amount of padding (in px)","between the plotting area and the axis lines"].join(" ")},autoexpand:{valType:"boolean",dflt:!0,editType:"plot",description:["Turns on/off margin expansion computations.","Legends, colorbars, updatemenus, sliders, axis rangeselector and rangeslider","are allowed to push the margins by defaults."].join(" ")},editType:"plot"},computed:{valType:"any",editType:"none",description:["Placeholder for exporting automargin-impacting values namely","`margin.t`, `margin.b`, `margin.l` and `margin.r` in *full-json* mode."].join(" ")},paper_bgcolor:{valType:"color",dflt:o.background,editType:"plot",description:"Sets the background color of the paper where the graph is drawn."},plot_bgcolor:{valType:"color",dflt:o.background,editType:"layoutstyle",description:["Sets the background color of the plotting area in-between x and y axes."].join(" ")},autotypenumbers:{valType:"enumerated",values:["convert types","strict"],dflt:"convert types",editType:"calc",description:["Using *strict* a numeric string in trace data is not converted to a number.","Using *convert types* a numeric string in trace data may be","treated as a number during automatic axis `type` detection.","This is the default value; however it could be overridden for individual axes."].join(" ")},separators:{valType:"string",editType:"plot",description:["Sets the decimal and thousand separators.","For example, *. * puts a '.' before decimals and a space","between thousands. In English locales, dflt is *.,* but","other locales may alter this default."].join(" ")},hidesources:{valType:"boolean",dflt:!1,editType:"plot",description:["Determines whether or not a text link citing the data source is","placed at the bottom-right cored of the figure.","Has only an effect only on graphs that have been generated via","forked graphs from the Chart Studio Cloud (at https://chart-studio.plotly.com or on-premise)."].join(" ")},showlegend:{valType:"boolean",editType:"legend",description:["Determines whether or not a legend is drawn.","Default is `true` if there is a trace to show and any of these:","a) Two or more traces would by default be shown in the legend.","b) One pie trace is shown in the legend.","c) One trace is explicitly given with `showlegend: true`."].join(" ")},colorway:{valType:"colorlist",dflt:o.defaults,editType:"calc",description:"Sets the default trace colors."},datarevision:{valType:"any",editType:"calc",description:["If provided, a changed value tells `Plotly.react` that","one or more data arrays has changed. This way you can modify","arrays in-place rather than making a complete new copy for an","incremental change.","If NOT provided, `Plotly.react` assumes that data arrays are","being treated as immutable, thus any data array with a","different identity from its predecessor contains new data."].join(" ")},uirevision:{valType:"any",editType:"none",description:["Used to allow user interactions with the plot to persist after","`Plotly.react` calls that are unaware of these interactions.","If `uirevision` is omitted, or if it is given and it changed from","the previous `Plotly.react` call, the exact new figure is used.","If `uirevision` is truthy and did NOT change, any attribute","that has been affected by user interactions and did not receive a","different value in the new figure will keep the interaction value.","`layout.uirevision` attribute serves as the default for","`uirevision` attributes in various sub-containers. For finer","control you can set these sub-attributes directly. For example,","if your app separately controls the data on the x and y axes you","might set `xaxis.uirevision=*time*` and `yaxis.uirevision=*cost*`.","Then if only the y data is changed, you can update","`yaxis.uirevision=*quantity*` and the y axis range will reset but","the x axis range will retain any user-driven zoom."].join(" ")},editrevision:{valType:"any",editType:"none",description:["Controls persistence of user-driven changes in `editable: true`","configuration, other than trace names and axis titles.","Defaults to `layout.uirevision`."].join(" ")},selectionrevision:{valType:"any",editType:"none",description:["Controls persistence of user-driven changes in selected points","from all traces."].join(" ")},template:{valType:"any",editType:"calc",description:["Default attributes to be applied to the plot. Templates can be","created from existing plots using `Plotly.makeTemplate`, or","created manually. They should be objects with format:","`{layout: layoutTemplate, data: {[type]: [traceTemplate, ...]}, ...}`","`layoutTemplate` and `traceTemplate` are objects matching the","attribute structure of `layout` and a data trace. ","Trace templates are applied cyclically to traces of each type.","Container arrays (eg `annotations`) have special handling:","An object ending in `defaults` (eg `annotationdefaults`) is applied","to each array item. But if an item has a `templateitemname` key","we look in the template array for an item with matching `name` and","apply that instead. If no matching `name` is found we mark the item","invisible. Any named template item not referenced is appended to","the end of the array, so you can use this for a watermark annotation","or a logo image, for example. To omit one of these items on the plot,","make an item with matching `templateitemname` and `visible: false`."].join(" ")},newshape:a.newshape,activeshape:a.activeshape,newselection:s.newselection,activeselection:s.activeselection,meta:{valType:"any",arrayOk:!0,editType:"plot",description:["Assigns extra meta information that can be used in various `text` attributes.","Attributes such as the graph, axis and colorbar `title.text`, annotation `text`","`trace.name` in legend items, `rangeselector`, `updatemenus` and `sliders` `label` text","all support `meta`. One can access `meta` fields using template strings:","`%{meta[i]}` where `i` is the index of the `meta`","item in question.","`meta` can also be an object for example `{key: value}` which can be accessed","%{meta[key]}."].join(" ")},transition:c({},i.transition,{description:["Sets transition options used during Plotly.react updates."].join(" "),editType:"none"}),_deprecated:{title:{valType:"string",editType:"layoutstyle",description:["Value of `title` is no longer a simple *string* but a set of sub-attributes.","To set the contents of the title, please use `title.text` now."].join(" ")},titlefont:n({editType:"layoutstyle",description:["Former `titlefont` is now the sub-attribute `font` of `title`.","To customize title font properties, please use `title.font` now."].join(" ")})}}},76687:(e,t,r)=>{"use strict";var n=r(60693),i=r(31158),o="https://basemaps.cartocdn.com/gl/positron-gl-style/style.json",a="https://basemaps.cartocdn.com/gl/dark-matter-gl-style/style.json",s="https://basemaps.cartocdn.com/gl/voyager-gl-style/style.json",l={basic:s,streets:s,outdoors:s,light:o,dark:a,satellite:r(18021),"satellite-streets":i,"open-street-map":{id:"osm",version:8,sources:{"plotly-osm-tiles":{type:"raster",attribution:'\xa9 OpenStreetMap contributors',tiles:["https://tile.openstreetmap.org/{z}/{x}/{y}.png"],tileSize:256}},layers:[{id:"plotly-osm-tiles",type:"raster",source:"plotly-osm-tiles",minzoom:0,maxzoom:22}],glyphs:"https://fonts.openmaptiles.org/{fontstack}/{range}.pbf"},"white-bg":{id:"white-bg",version:8,sources:{},layers:[{id:"white-bg",type:"background",paint:{"background-color":"#FFFFFF"},minzoom:0,maxzoom:22}],glyphs:"https://fonts.openmaptiles.org/{fontstack}/{range}.pbf"},"carto-positron":o,"carto-darkmatter":a,"carto-voyager":s,"carto-positron-nolabels":"https://basemaps.cartocdn.com/gl/positron-nolabels-gl-style/style.json","carto-darkmatter-nolabels":"https://basemaps.cartocdn.com/gl/dark-matter-nolabels-gl-style/style.json","carto-voyager-nolabels":"https://basemaps.cartocdn.com/gl/voyager-nolabels-gl-style/style.json"},c=n(l);e.exports={styleValueDflt:"basic",stylesMap:l,styleValuesMap:c,traceLayerPrefix:"plotly-trace-layer-",layoutLayerPrefix:"plotly-layout-layer-",missingStyleErrorMsg:["No valid maplibre style found, please set `map.style` to one of:",c.join(", "),"or use a tile service."].join("\n"),mapOnErrorMsg:"Map error."}},37888:(e,t,r)=>{"use strict";var n=r(84468);e.exports=function(e,t){var r=e.split(" "),i=r[0],o=r[1],a=n.isArrayOrTypedArray(t)?n.mean(t):t,s=.5+a/100,l=1.5+a/100,c=["",""],u=[0,0];switch(i){case"top":c[0]="top",u[1]=-l;break;case"bottom":c[0]="bottom",u[1]=l}switch(o){case"left":c[1]="right",u[0]=-s;break;case"right":c[1]="left",u[0]=s}return{anchor:c[0]&&c[1]?c.join("-"):c[0]?c[0]:c[1]?c[1]:"center",offset:u}}},29534:(e,t,r)=>{"use strict";var n=r(84468),i=n.strTranslate,o=n.strScale,a=r(50246).fX,s=r(28795),l=r(41871),c=r(3172),u=r(13480),d=r(72948),h="map";t.name=h,t.attr="subplot",t.idRoot=h,t.idRegex=t.attrRegex=n.counterRegex(h),t.attributes={subplot:{valType:"subplotid",dflt:"map",editType:"calc",description:["Sets a reference between this trace's data coordinates and","a map subplot.","If *map* (the default value), the data refer to `layout.map`.","If *map2*, the data refer to `layout.map2`, and so on."].join(" ")}},t.layoutAttributes=r(99696),t.supplyLayoutDefaults=r(50567),t.plot=function(e){for(var t=e._fullLayout,r=e.calcdata,i=t._subplots[h],o=0;ox/2){var b=m.split("|").join("
");y.text(b).attr("data-unformatted",b).call(u.convertToTspans,e),v=c.bBox(y.node())}y.attr("transform",i(-3,8-v.height)),g.insert("rect",".static-attribution").attr({x:-v.width-6,y:-v.height-3,width:v.width+6,height:v.height+3,fill:"rgba(255, 255, 255, 0.75)"});var _=1;v.width+6>x&&(_=x/(v.width+6));var w=[n.l+n.w*p.x[1],n.t+n.h*(1-p.y[0])];g.attr("transform",i(w[0],w[1])+o(_))}},t.updateFx=function(e){for(var t=e._fullLayout,r=t._subplots[h],n=0;n{"use strict";var n=r(84468),i=r(13480).sanitizeHTML,o=r(37888),a=r(76687);function s(e,t){this.subplot=e,this.uid=e.uid+"-"+t,this.index=t,this.idSource="source-"+this.uid,this.idLayer=a.layoutLayerPrefix+this.uid,this.sourceType=null,this.source=null,this.layerType=null,this.below=null,this.visible=!1}var l=s.prototype;function c(e){if(!e.visible)return!1;var t=e.source;if(Array.isArray(t)&&t.length>0){for(var r=0;r0}function u(e){var t={},r={};switch(e.type){case"circle":n.extendFlat(r,{"circle-radius":e.circle.radius,"circle-color":e.color,"circle-opacity":e.opacity});break;case"line":n.extendFlat(r,{"line-width":e.line.width,"line-color":e.color,"line-opacity":e.opacity,"line-dasharray":e.line.dash});break;case"fill":n.extendFlat(r,{"fill-color":e.color,"fill-outline-color":e.fill.outlinecolor,"fill-opacity":e.opacity});break;case"symbol":var i=e.symbol,a=o(i.textposition,i.iconsize);n.extendFlat(t,{"icon-image":i.icon+"-15","icon-size":i.iconsize/10,"text-field":i.text,"text-size":i.textfont.size,"text-anchor":a.anchor,"text-offset":a.offset,"symbol-placement":i.placement}),n.extendFlat(r,{"icon-color":e.color,"text-color":i.textfont.color,"text-opacity":e.opacity});break;case"raster":n.extendFlat(r,{"raster-fade-duration":0,"raster-opacity":e.opacity})}return{layout:t,paint:r}}l.update=function(e){this.visible?this.needsNewImage(e)?this.updateImage(e):this.needsNewSource(e)?(this.removeLayer(),this.updateSource(e),this.updateLayer(e)):this.needsNewLayer(e)?this.updateLayer(e):this.updateStyle(e):(this.updateSource(e),this.updateLayer(e)),this.visible=c(e)},l.needsNewImage=function(e){return this.subplot.map.getSource(this.idSource)&&"image"===this.sourceType&&"image"===e.sourcetype&&(this.source!==e.source||JSON.stringify(this.coordinates)!==JSON.stringify(e.coordinates))},l.needsNewSource=function(e){return this.sourceType!==e.sourcetype||JSON.stringify(this.source)!==JSON.stringify(e.source)||this.layerType!==e.type},l.needsNewLayer=function(e){return this.layerType!==e.type||this.below!==this.subplot.belowLookup["layout-"+this.index]},l.lookupBelow=function(){return this.subplot.belowLookup["layout-"+this.index]},l.updateImage=function(e){this.subplot.map.getSource(this.idSource).updateImage({url:e.source,coordinates:e.coordinates});var t=this.findFollowingMapLayerId(this.lookupBelow());null!==t&&this.subplot.map.moveLayer(this.idLayer,t)},l.updateSource=function(e){var t=this.subplot.map;if(t.getSource(this.idSource)&&t.removeSource(this.idSource),this.sourceType=e.sourcetype,this.source=e.source,c(e)){var r=function(e){var t,r=e.sourcetype,n=e.source,o={type:r};"geojson"===r?t="data":"vector"===r?t="string"===typeof n?"url":"tiles":"raster"===r?(t="tiles",o.tileSize=256):"image"===r&&(t="url",o.coordinates=e.coordinates);o[t]=n,e.sourceattribution&&(o.attribution=i(e.sourceattribution));return o}(e);t.addSource(this.idSource,r)}},l.findFollowingMapLayerId=function(e){if("traces"===e)for(var t=this.subplot.getMapLayers(),r=0;r{"use strict";var n=r(84468),i=r(7605).defaultLine,o=r(81159).u,a=r(91740),s=r(22049).textposition,l=r(72587).overrideAll,c=r(37091).templatedArray,u=r(76687),d=a({noFontVariant:!0,noFontShadow:!0,noFontLineposition:!0,noFontTextcase:!0,description:["Sets the icon text font (color=map.layer.paint.text-color, size=map.layer.layout.text-size).","Has an effect only when `type` is set to *symbol*."].join(" ")});d.family.dflt="Open Sans Regular, Arial Unicode MS Regular",(e.exports=l({_arrayAttrRegexps:[n.counterRegex("map",".layers",!0)],domain:o({name:"map"}),style:{valType:"any",values:u.styleValuesMap,dflt:u.styleValueDflt,description:["Defines the map layers that are rendered by default below the trace layers defined in `data`,","which are themselves by default rendered below the layers defined in `layout.map.layers`.","","These layers can be defined either explicitly as a Map Style object which can contain multiple","layer definitions that load data from any public or private Tile Map Service (TMS or XYZ) or Web Map Service (WMS)","or implicitly by using one of the built-in style objects which use WMSes","or by using a custom style URL","","Map Style objects are of the form described in the MapLibre GL JS documentation available at","https://maplibre.org/maplibre-style-spec/","","The built-in plotly.js styles objects are:",u.styleValuesMap.join(", ")+"."].join(" ")},center:{lon:{valType:"number",dflt:0,description:"Sets the longitude of the center of the map (in degrees East)."},lat:{valType:"number",dflt:0,description:"Sets the latitude of the center of the map (in degrees North)."}},zoom:{valType:"number",dflt:1,description:"Sets the zoom level of the map (map.zoom)."},bearing:{valType:"number",dflt:0,description:"Sets the bearing angle of the map in degrees counter-clockwise from North (map.bearing)."},pitch:{valType:"number",dflt:0,description:["Sets the pitch angle of the map","(in degrees, where *0* means perpendicular to the surface of the map) (map.pitch)."].join(" ")},bounds:{west:{valType:"number",description:["Sets the minimum longitude of the map (in degrees East)","if `east`, `south` and `north` are declared."].join(" ")},east:{valType:"number",description:["Sets the maximum longitude of the map (in degrees East)","if `west`, `south` and `north` are declared."].join(" ")},south:{valType:"number",description:["Sets the minimum latitude of the map (in degrees North)","if `east`, `west` and `north` are declared."].join(" ")},north:{valType:"number",description:["Sets the maximum latitude of the map (in degrees North)","if `east`, `west` and `south` are declared."].join(" ")}},layers:c("layer",{visible:{valType:"boolean",dflt:!0,description:["Determines whether this layer is displayed"].join(" ")},sourcetype:{valType:"enumerated",values:["geojson","vector","raster","image"],dflt:"geojson",description:["Sets the source type for this layer,","that is the type of the layer data."].join(" ")},source:{valType:"any",description:["Sets the source data for this layer (map.layer.source).","When `sourcetype` is set to *geojson*, `source` can be a URL to a GeoJSON","or a GeoJSON object.","When `sourcetype` is set to *vector* or *raster*, `source` can be a URL or","an array of tile URLs.","When `sourcetype` is set to *image*, `source` can be a URL to an image."].join(" ")},sourcelayer:{valType:"string",dflt:"",description:["Specifies the layer to use from a vector tile source (map.layer.source-layer).","Required for *vector* source type that supports multiple layers."].join(" ")},sourceattribution:{valType:"string",description:["Sets the attribution for this source."].join(" ")},type:{valType:"enumerated",values:["circle","line","fill","symbol","raster"],dflt:"circle",description:["Sets the layer type,","that is the how the layer data set in `source` will be rendered","With `sourcetype` set to *geojson*, the following values are allowed:","*circle*, *line*, *fill* and *symbol*.","but note that *line* and *fill* are not compatible with Point","GeoJSON geometries.","With `sourcetype` set to *vector*, the following values are allowed:"," *circle*, *line*, *fill* and *symbol*.","With `sourcetype` set to *raster* or `*image*`, only the *raster* value is allowed."].join(" ")},coordinates:{valType:"any",description:["Sets the coordinates array contains [longitude, latitude] pairs","for the image corners listed in clockwise order:","top left, top right, bottom right, bottom left.","Only has an effect for *image* `sourcetype`."].join(" ")},below:{valType:"string",description:["Determines if the layer will be inserted","before the layer with the specified ID.","If omitted or set to '',","the layer will be inserted above every existing layer."].join(" ")},color:{valType:"color",dflt:i,description:["Sets the primary layer color.","If `type` is *circle*, color corresponds to the circle color (map.layer.paint.circle-color)","If `type` is *line*, color corresponds to the line color (map.layer.paint.line-color)","If `type` is *fill*, color corresponds to the fill color (map.layer.paint.fill-color)","If `type` is *symbol*, color corresponds to the icon color (map.layer.paint.icon-color)"].join(" ")},opacity:{valType:"number",min:0,max:1,dflt:1,description:["Sets the opacity of the layer.","If `type` is *circle*, opacity corresponds to the circle opacity (map.layer.paint.circle-opacity)","If `type` is *line*, opacity corresponds to the line opacity (map.layer.paint.line-opacity)","If `type` is *fill*, opacity corresponds to the fill opacity (map.layer.paint.fill-opacity)","If `type` is *symbol*, opacity corresponds to the icon/text opacity (map.layer.paint.text-opacity)"].join(" ")},minzoom:{valType:"number",min:0,max:24,dflt:0,description:["Sets the minimum zoom level (map.layer.minzoom).","At zoom levels less than the minzoom, the layer will be hidden."].join(" ")},maxzoom:{valType:"number",min:0,max:24,dflt:24,description:["Sets the maximum zoom level (map.layer.maxzoom).","At zoom levels equal to or greater than the maxzoom, the layer will be hidden."].join(" ")},circle:{radius:{valType:"number",dflt:15,description:["Sets the circle radius (map.layer.paint.circle-radius).","Has an effect only when `type` is set to *circle*."].join(" ")}},line:{width:{valType:"number",dflt:2,description:["Sets the line width (map.layer.paint.line-width).","Has an effect only when `type` is set to *line*."].join(" ")},dash:{valType:"data_array",description:["Sets the length of dashes and gaps (map.layer.paint.line-dasharray).","Has an effect only when `type` is set to *line*."].join(" ")}},fill:{outlinecolor:{valType:"color",dflt:i,description:["Sets the fill outline color (map.layer.paint.fill-outline-color).","Has an effect only when `type` is set to *fill*."].join(" ")}},symbol:{icon:{valType:"string",dflt:"marker",description:["Sets the symbol icon image (map.layer.layout.icon-image).","Full list: https://www.map.com/maki-icons/"].join(" ")},iconsize:{valType:"number",dflt:10,description:["Sets the symbol icon size (map.layer.layout.icon-size).","Has an effect only when `type` is set to *symbol*."].join(" ")},text:{valType:"string",dflt:"",description:["Sets the symbol text (map.layer.layout.text-field)."].join(" ")},placement:{valType:"enumerated",values:["point","line","line-center"],dflt:"point",description:["Sets the symbol and/or text placement (map.layer.layout.symbol-placement).","If `placement` is *point*, the label is placed where the geometry is located","If `placement` is *line*, the label is placed along the line of the geometry","If `placement` is *line-center*, the label is placed on the center of the geometry"].join(" ")},textfont:d,textposition:n.extendFlat({},s,{arrayOk:!1})}})},"plot","from-root")).uirevision={valType:"any",editType:"none",description:["Controls persistence of user-driven changes in the view:","`center`, `zoom`, `bearing`, `pitch`. Defaults to `layout.uirevision`."].join(" ")}},50567:(e,t,r)=>{"use strict";var n=r(84468),i=r(54883),o=r(38851),a=r(99696);function s(e,t,r){r("style"),r("center.lon"),r("center.lat"),r("zoom"),r("bearing"),r("pitch");var n=r("bounds.west"),i=r("bounds.east"),a=r("bounds.south"),s=r("bounds.north");void 0!==n&&void 0!==i&&void 0!==a&&void 0!==s||delete t.bounds,o(e,t,{name:"layers",handleItemDefaults:l}),t._input=e}function l(e,t){function r(r,i){return n.coerce(e,t,a.layers,r,i)}if(r("visible")){var i,o=r("sourcetype"),s="raster"===o||"image"===o;r("source"),r("sourceattribution"),"vector"===o&&r("sourcelayer"),"image"===o&&r("coordinates"),s&&(i="raster");var l=r("type",i);s&&"raster"!==l&&(l=t.type="raster",n.log("Source types *raster* and *image* must drawn *raster* layer type.")),r("below"),r("color"),r("opacity"),r("minzoom"),r("maxzoom"),"circle"===l&&r("circle.radius"),"line"===l&&(r("line.width"),r("line.dash")),"fill"===l&&r("fill.outlinecolor"),"symbol"===l&&(r("symbol.icon"),r("symbol.iconsize"),r("symbol.text"),n.coerceFont(r,"symbol.textfont",void 0,{noFontVariant:!0,noFontShadow:!0,noFontLineposition:!0,noFontTextcase:!0}),r("symbol.textposition"),r("symbol.placement"))}}e.exports=function(e,t,r){i(e,t,r,{type:"map",attributes:a,handleDefaults:s,partition:"y"})}},72948:(e,t,r)=>{"use strict";var n=r(53631),i=r(84468),o=r(63925),a=r(38361),s=r(85729),l=r(25732),c=r(32212),u=r(2705),d=u.drawMode,h=u.selectMode,p=r(76789).prepSelect,f=r(76789).clearOutline,m=r(76789).clearSelectionsCache,g=r(76789).selectOnClick,y=r(76687),v=r(51386);function x(e,t){this.id=t,this.gd=e;var r=e._fullLayout,n=e._context;this.container=r._glcontainer.node(),this.isStatic=n.staticPlot,this.uid=r._uid+"-"+this.id,this.div=null,this.xaxis=null,this.yaxis=null,this.createFramework(r),this.map=null,this.styleObj=null,this.traceHash={},this.layerList=[],this.belowLookup={},this.dragging=!1,this.wheeling=!1}var b=x.prototype;b.plot=function(e,t,r){var n,i=this;n=i.map?new Promise((function(r,n){i.updateMap(e,t,r,n)})):new Promise((function(r,n){i.createMap(e,t,r,n)})),r.push(n)},b.createMap=function(e,t,r,i){var a=this,s=t[a.id],l=a.styleObj=w(s.style),c=s.bounds,u=c?[[c.west,c.south],[c.east,c.north]]:null,d=a.map=new n.Map({container:a.div,style:l.style,center:k(s.center),zoom:s.zoom,bearing:s.bearing,pitch:s.pitch,maxBounds:u,interactive:!a.isStatic,preserveDrawingBuffer:a.isStatic,doubleClickZoom:!1,boxZoom:!1,attributionControl:!1}).addControl(new n.AttributionControl({compact:!0})),h={};d.on("styleimagemissing",(function(e){var t=e.id;if(!h[t]&&t.includes("-15")){h[t]=!0;var r=new Image(15,15);r.onload=function(){d.addImage(t,r)},r.crossOrigin="Anonymous",r.src="https://unpkg.com/maki@2.1.0/icons/"+t+".svg"}})),d.setTransformRequest((function(e){return{url:e=(e=(e=e.replace("https://fonts.openmaptiles.org/Open Sans Extrabold","https://fonts.openmaptiles.org/Open Sans Extra Bold")).replace("https://tiles.basemaps.cartocdn.com/fonts/Open Sans Extrabold","https://fonts.openmaptiles.org/Open Sans Extra Bold")).replace("https://fonts.openmaptiles.org/Open Sans Regular,Arial Unicode MS Regular","https://fonts.openmaptiles.org/Klokantech Noto Sans Regular")}})),d._canvas.style.left="0px",d._canvas.style.top="0px",a.rejectOnError(i),a.isStatic||a.initFx(e,t);var p=[];p.push(new Promise((function(e){d.once("load",e)}))),p=p.concat(o.fetchTraceGeoData(e)),Promise.all(p).then((function(){a.fillBelowLookup(e,t),a.updateData(e),a.updateLayout(t),a.resolveOnRender(r)})).catch(i)},b.updateMap=function(e,t,r,n){var i=this,a=i.map,s=t[this.id];i.rejectOnError(n);var l=[],c=w(s.style);JSON.stringify(i.styleObj)!==JSON.stringify(c)&&(i.styleObj=c,a.setStyle(c.style),i.traceHash={},l.push(new Promise((function(e){a.once("styledata",e)})))),l=l.concat(o.fetchTraceGeoData(e)),Promise.all(l).then((function(){i.fillBelowLookup(e,t),i.updateData(e),i.updateLayout(t),i.resolveOnRender(r)})).catch(n)},b.fillBelowLookup=function(e,t){var r,n,i=t[this.id].layers,o=this.belowLookup={},a=!1;for(r=0;r1)for(r=0;r-1&&g(t.originalEvent,n,[r.xaxis],[r.yaxis],r.id,e),i.indexOf("event")>-1&&c.click(n,t.originalEvent)}}},b.updateFx=function(e){var t=this,r=t.map,n=t.gd;if(!t.isStatic){var o,a=e.dragmode;o=function(e,r){r.isRect?(e.range={})[t.id]=[c([r.xmin,r.ymin]),c([r.xmax,r.ymax])]:(e.lassoPoints={})[t.id]=r.map(c)};var s=t.dragOptions;t.dragOptions=i.extendDeep(s||{},{dragmode:e.dragmode,element:t.div,gd:n,plotinfo:{id:t.id,domain:e[t.id].domain,xaxis:t.xaxis,yaxis:t.yaxis,fillRangeItems:o},xaxes:[t.xaxis],yaxes:[t.yaxis],subplot:t.id}),r.off("click",t.onClickInPanHandler),h(a)||d(a)?(r.dragPan.disable(),r.on("zoomstart",t.clearOutline),t.dragOptions.prepFn=function(e,r,n){p(e,r,n,t.dragOptions,a)},l.init(t.dragOptions)):(r.dragPan.enable(),r.off("zoomstart",t.clearOutline),t.div.onmousedown=null,t.div.ontouchstart=null,t.div.removeEventListener("touchstart",t.div._ontouchstart),t.onClickInPanHandler=t.onClickInPanFn(t.dragOptions),r.on("click",t.onClickInPanHandler))}function c(e){var r=t.map.unproject(e);return[r.lng,r.lat]}},b.updateFramework=function(e){var t=e[this.id].domain,r=e._size,n=this.div.style;n.width=r.w*(t.x[1]-t.x[0])+"px",n.height=r.h*(t.y[1]-t.y[0])+"px",n.left=r.l+t.x[0]*r.w+"px",n.top=r.t+(1-t.y[1])*r.h+"px",this.xaxis._offset=r.l+t.x[0]*r.w,this.xaxis._length=r.w*(t.x[1]-t.x[0]),this.yaxis._offset=r.t+(1-t.y[1])*r.h,this.yaxis._length=r.h*(t.y[1]-t.y[0])},b.updateLayers=function(e){var t,r=e[this.id].layers,n=this.layerList;if(r.length!==n.length){for(t=0;t{"use strict";var n=r(60693),i="1.13.4",o='\xa9 OpenStreetMap contributors',a=['\xa9 Carto',o].join(" "),s=['Map tiles by Stamen Design','under CC BY 3.0',"|",'Data by OpenStreetMap contributors','under ODbL'].join(" "),l={"open-street-map":{id:"osm",version:8,sources:{"plotly-osm-tiles":{type:"raster",attribution:o,tiles:["https://a.tile.openstreetmap.org/{z}/{x}/{y}.png","https://b.tile.openstreetmap.org/{z}/{x}/{y}.png"],tileSize:256}},layers:[{id:"plotly-osm-tiles",type:"raster",source:"plotly-osm-tiles",minzoom:0,maxzoom:22}],glyphs:"https://fonts.openmaptiles.org/{fontstack}/{range}.pbf"},"white-bg":{id:"white-bg",version:8,sources:{},layers:[{id:"white-bg",type:"background",paint:{"background-color":"#FFFFFF"},minzoom:0,maxzoom:22}],glyphs:"https://fonts.openmaptiles.org/{fontstack}/{range}.pbf"},"carto-positron":{id:"carto-positron",version:8,sources:{"plotly-carto-positron":{type:"raster",attribution:a,tiles:["https://cartodb-basemaps-c.global.ssl.fastly.net/light_all/{z}/{x}/{y}.png"],tileSize:256}},layers:[{id:"plotly-carto-positron",type:"raster",source:"plotly-carto-positron",minzoom:0,maxzoom:22}],glyphs:"https://fonts.openmaptiles.org/{fontstack}/{range}.pbf"},"carto-darkmatter":{id:"carto-darkmatter",version:8,sources:{"plotly-carto-darkmatter":{type:"raster",attribution:a,tiles:["https://cartodb-basemaps-c.global.ssl.fastly.net/dark_all/{z}/{x}/{y}.png"],tileSize:256}},layers:[{id:"plotly-carto-darkmatter",type:"raster",source:"plotly-carto-darkmatter",minzoom:0,maxzoom:22}],glyphs:"https://fonts.openmaptiles.org/{fontstack}/{range}.pbf"},"stamen-terrain":{id:"stamen-terrain",version:8,sources:{"plotly-stamen-terrain":{type:"raster",attribution:s,tiles:["https://tiles.stadiamaps.com/tiles/stamen_terrain/{z}/{x}/{y}.png?api_key="],tileSize:256}},layers:[{id:"plotly-stamen-terrain",type:"raster",source:"plotly-stamen-terrain",minzoom:0,maxzoom:22}],glyphs:"https://fonts.openmaptiles.org/{fontstack}/{range}.pbf"},"stamen-toner":{id:"stamen-toner",version:8,sources:{"plotly-stamen-toner":{type:"raster",attribution:s,tiles:["https://tiles.stadiamaps.com/tiles/stamen_toner/{z}/{x}/{y}.png?api_key="],tileSize:256}},layers:[{id:"plotly-stamen-toner",type:"raster",source:"plotly-stamen-toner",minzoom:0,maxzoom:22}],glyphs:"https://fonts.openmaptiles.org/{fontstack}/{range}.pbf"},"stamen-watercolor":{id:"stamen-watercolor",version:8,sources:{"plotly-stamen-watercolor":{type:"raster",attribution:['Map tiles by Stamen Design','under CC BY 3.0',"|",'Data by OpenStreetMap contributors','under CC BY SA'].join(" "),tiles:["https://tiles.stadiamaps.com/tiles/stamen_watercolor/{z}/{x}/{y}.jpg?api_key="],tileSize:256}},layers:[{id:"plotly-stamen-watercolor",type:"raster",source:"plotly-stamen-watercolor",minzoom:0,maxzoom:22}],glyphs:"https://fonts.openmaptiles.org/{fontstack}/{range}.pbf"}},c=n(l);e.exports={requiredVersion:i,styleUrlPrefix:"mapbox://styles/mapbox/",styleUrlSuffix:"v9",styleValuesMapbox:["basic","streets","outdoors","light","dark","satellite","satellite-streets"],styleValueDflt:"basic",stylesNonMapbox:l,styleValuesNonMapbox:c,traceLayerPrefix:"plotly-trace-layer-",layoutLayerPrefix:"plotly-layout-layer-",wrongVersionErrorMsg:["Your custom plotly.js bundle is not using the correct mapbox-gl version","Please install @plotly/mapbox-gl@"+i+"."].join("\n"),noAccessTokenErrorMsg:["Missing Mapbox access token.","Mapbox trace type require a Mapbox access token to be registered.","For example:"," Plotly.newPlot(gd, data, layout, { mapboxAccessToken: 'my-access-token' });","More info here: https://www.mapbox.com/help/define-access-token/"].join("\n"),missingStyleErrorMsg:["No valid mapbox style found, please set `mapbox.style` to one of:",c.join(", "),"or register a Mapbox access token to use a Mapbox-served style."].join("\n"),multipleTokensErrorMsg:["Set multiple mapbox access token across different mapbox subplot,","using first token found as mapbox-gl does not allow multipleaccess tokens on the same page."].join("\n"),mapOnErrorMsg:"Mapbox error.",mapboxLogo:{path0:"m 10.5,1.24 c -5.11,0 -9.25,4.15 -9.25,9.25 0,5.1 4.15,9.25 9.25,9.25 5.1,0 9.25,-4.15 9.25,-9.25 0,-5.11 -4.14,-9.25 -9.25,-9.25 z m 4.39,11.53 c -1.93,1.93 -4.78,2.31 -6.7,2.31 -0.7,0 -1.41,-0.05 -2.1,-0.16 0,0 -1.02,-5.64 2.14,-8.81 0.83,-0.83 1.95,-1.28 3.13,-1.28 1.27,0 2.49,0.51 3.39,1.42 1.84,1.84 1.89,4.75 0.14,6.52 z",path1:"M 10.5,-0.01 C 4.7,-0.01 0,4.7 0,10.49 c 0,5.79 4.7,10.5 10.5,10.5 5.8,0 10.5,-4.7 10.5,-10.5 C 20.99,4.7 16.3,-0.01 10.5,-0.01 Z m 0,19.75 c -5.11,0 -9.25,-4.15 -9.25,-9.25 0,-5.1 4.14,-9.26 9.25,-9.26 5.11,0 9.25,4.15 9.25,9.25 0,5.13 -4.14,9.26 -9.25,9.26 z",path2:"M 14.74,6.25 C 12.9,4.41 9.98,4.35 8.23,6.1 5.07,9.27 6.09,14.91 6.09,14.91 c 0,0 5.64,1.02 8.81,-2.14 C 16.64,11 16.59,8.09 14.74,6.25 Z m -2.27,4.09 -0.91,1.87 -0.9,-1.87 -1.86,-0.91 1.86,-0.9 0.9,-1.87 0.91,1.87 1.86,0.9 z",polygon:"11.56,12.21 10.66,10.34 8.8,9.43 10.66,8.53 11.56,6.66 12.47,8.53 14.33,9.43 12.47,10.34"},styleRules:{map:"overflow:hidden;position:relative;","missing-css":"display:none;",canary:"background-color:salmon;","ctrl-bottom-left":"position: absolute; pointer-events: none; z-index: 2; bottom: 0; left: 0;","ctrl-bottom-right":"position: absolute; pointer-events: none; z-index: 2; right: 0; bottom: 0;",ctrl:"clear: both; pointer-events: auto; transform: translate(0, 0);","ctrl-attrib.mapboxgl-compact .mapboxgl-ctrl-attrib-inner":"display: none;","ctrl-attrib.mapboxgl-compact:hover .mapboxgl-ctrl-attrib-inner":"display: block; margin-top:2px","ctrl-attrib.mapboxgl-compact:hover":"padding: 2px 24px 2px 4px; visibility: visible; margin-top: 6px;","ctrl-attrib.mapboxgl-compact::after":'content: ""; cursor: pointer; position: absolute; background-image: url(\'data:image/svg+xml;charset=utf-8,%3Csvg viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"%3E %3Cpath fill="%23333333" fill-rule="evenodd" d="M4,10a6,6 0 1,0 12,0a6,6 0 1,0 -12,0 M9,7a1,1 0 1,0 2,0a1,1 0 1,0 -2,0 M9,10a1,1 0 1,1 2,0l0,3a1,1 0 1,1 -2,0"/%3E %3C/svg%3E\'); background-color: rgba(255, 255, 255, 0.5); width: 24px; height: 24px; box-sizing: border-box; border-radius: 12px;',"ctrl-attrib.mapboxgl-compact":"min-height: 20px; padding: 0; margin: 10px; position: relative; background-color: #fff; border-radius: 3px 12px 12px 3px;","ctrl-bottom-right > .mapboxgl-ctrl-attrib.mapboxgl-compact::after":"bottom: 0; right: 0","ctrl-bottom-left > .mapboxgl-ctrl-attrib.mapboxgl-compact::after":"bottom: 0; left: 0","ctrl-bottom-left .mapboxgl-ctrl":"margin: 0 0 10px 10px; float: left;","ctrl-bottom-right .mapboxgl-ctrl":"margin: 0 10px 10px 0; float: right;","ctrl-attrib":"color: rgba(0, 0, 0, 0.75); text-decoration: none; font-size: 12px","ctrl-attrib a":"color: rgba(0, 0, 0, 0.75); text-decoration: none; font-size: 12px","ctrl-attrib a:hover":"color: inherit; text-decoration: underline;","ctrl-attrib .mapbox-improve-map":"font-weight: bold; margin-left: 2px;","attrib-empty":"display: none;","ctrl-logo":'display:block; width: 21px; height: 21px; background-image: url(\'data:image/svg+xml;charset=utf-8,%3C?xml version="1.0" encoding="utf-8"?%3E %3Csvg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 21 21" style="enable-background:new 0 0 21 21;" xml:space="preserve"%3E%3Cg transform="translate(0,0.01)"%3E%3Cpath d="m 10.5,1.24 c -5.11,0 -9.25,4.15 -9.25,9.25 0,5.1 4.15,9.25 9.25,9.25 5.1,0 9.25,-4.15 9.25,-9.25 0,-5.11 -4.14,-9.25 -9.25,-9.25 z m 4.39,11.53 c -1.93,1.93 -4.78,2.31 -6.7,2.31 -0.7,0 -1.41,-0.05 -2.1,-0.16 0,0 -1.02,-5.64 2.14,-8.81 0.83,-0.83 1.95,-1.28 3.13,-1.28 1.27,0 2.49,0.51 3.39,1.42 1.84,1.84 1.89,4.75 0.14,6.52 z" style="opacity:0.9;fill:%23ffffff;enable-background:new" class="st0"/%3E%3Cpath d="M 10.5,-0.01 C 4.7,-0.01 0,4.7 0,10.49 c 0,5.79 4.7,10.5 10.5,10.5 5.8,0 10.5,-4.7 10.5,-10.5 C 20.99,4.7 16.3,-0.01 10.5,-0.01 Z m 0,19.75 c -5.11,0 -9.25,-4.15 -9.25,-9.25 0,-5.1 4.14,-9.26 9.25,-9.26 5.11,0 9.25,4.15 9.25,9.25 0,5.13 -4.14,9.26 -9.25,9.26 z" style="opacity:0.35;enable-background:new" class="st1"/%3E%3Cpath d="M 14.74,6.25 C 12.9,4.41 9.98,4.35 8.23,6.1 5.07,9.27 6.09,14.91 6.09,14.91 c 0,0 5.64,1.02 8.81,-2.14 C 16.64,11 16.59,8.09 14.74,6.25 Z m -2.27,4.09 -0.91,1.87 -0.9,-1.87 -1.86,-0.91 1.86,-0.9 0.9,-1.87 0.91,1.87 1.86,0.9 z" style="opacity:0.35;enable-background:new" class="st1"/%3E%3Cpolygon points="11.56,12.21 10.66,10.34 8.8,9.43 10.66,8.53 11.56,6.66 12.47,8.53 14.33,9.43 12.47,10.34 " style="opacity:0.9;fill:%23ffffff;enable-background:new" class="st0"/%3E%3C/g%3E%3C/svg%3E\')'}}},25065:(e,t,r)=>{"use strict";var n=r(84468);e.exports=function(e,t){var r=e.split(" "),i=r[0],o=r[1],a=n.isArrayOrTypedArray(t)?n.mean(t):t,s=.5+a/100,l=1.5+a/100,c=["",""],u=[0,0];switch(i){case"top":c[0]="top",u[1]=-l;break;case"bottom":c[0]="bottom",u[1]=l}switch(o){case"left":c[1]="right",u[0]=-s;break;case"right":c[1]="left",u[0]=s}return{anchor:c[0]&&c[1]?c.join("-"):c[0]?c[0]:c[1]?c[1]:"center",offset:u}}},81587:(e,t,r)=>{"use strict";var n=r(64871),i=r(84468),o=i.strTranslate,a=i.strScale,s=r(50246).fX,l=r(28795),c=r(41871),u=r(3172),d=r(13480),h=r(14312),p="mapbox",f=t.constants=r(26966);t.name=p,t.attr="subplot",t.idRoot=p,t.idRegex=t.attrRegex=i.counterRegex(p);var m=["mapbox subplots and traces are deprecated!","Please consider switching to `map` subplots and traces.","Learn more at: https://plotly.com/javascript/maplibre-migration/"].join(" ");t.attributes={subplot:{valType:"subplotid",dflt:"mapbox",editType:"calc",description:[m,"Sets a reference between this trace's data coordinates and","a mapbox subplot.","If *mapbox* (the default value), the data refer to `layout.mapbox`.","If *mapbox2*, the data refer to `layout.mapbox2`, and so on."].join(" ")}},t.layoutAttributes=r(6185),t.supplyLayoutDefaults=r(76846);var g=!0;function y(e){return"string"===typeof e&&(-1!==f.styleValuesMapbox.indexOf(e)||0===e.indexOf("mapbox://")||0===e.indexOf("stamen"))}t.plot=function(e){g&&(g=!1,i.warn(m));var t=e._fullLayout,r=e.calcdata,o=t._subplots[p];if(n.version!==f.requiredVersion)throw new Error(f.wrongVersionErrorMsg);var a=function(e,t){var r=e._fullLayout,n=e._context;if(""===n.mapboxAccessToken)return"";for(var o=[],a=[],s=!1,l=!1,c=0;c1&&i.warn(f.multipleTokensErrorMsg),o[0]):(a.length&&i.log(["Listed mapbox access token(s)",a.join(","),"but did not use a Mapbox map style, ignoring token(s)."].join(" ")),"")}(e,o);n.accessToken=a;for(var l=0;lw/2){var k=v.split("|").join("
");b.text(k).attr("data-unformatted",k).call(d.convertToTspans,e),_=u.bBox(b.node())}b.attr("transform",o(-3,8-_.height)),x.insert("rect",".static-attribution").attr({x:-_.width-6,y:-_.height-3,width:_.width+6,height:_.height+3,fill:"rgba(255, 255, 255, 0.75)"});var S=1;_.width+6>w&&(S=w/(_.width+6));var A=[n.l+n.w*h.x[1],n.t+n.h*(1-h.y[0])];x.attr("transform",o(A[0],A[1])+a(S))}},t.updateFx=function(e){for(var t=e._fullLayout,r=t._subplots[p],n=0;n{"use strict";var n=r(84468),i=r(13480).sanitizeHTML,o=r(25065),a=r(26966);function s(e,t){this.subplot=e,this.uid=e.uid+"-"+t,this.index=t,this.idSource="source-"+this.uid,this.idLayer=a.layoutLayerPrefix+this.uid,this.sourceType=null,this.source=null,this.layerType=null,this.below=null,this.visible=!1}var l=s.prototype;function c(e){if(!e.visible)return!1;var t=e.source;if(Array.isArray(t)&&t.length>0){for(var r=0;r0}function u(e){var t={},r={};switch(e.type){case"circle":n.extendFlat(r,{"circle-radius":e.circle.radius,"circle-color":e.color,"circle-opacity":e.opacity});break;case"line":n.extendFlat(r,{"line-width":e.line.width,"line-color":e.color,"line-opacity":e.opacity,"line-dasharray":e.line.dash});break;case"fill":n.extendFlat(r,{"fill-color":e.color,"fill-outline-color":e.fill.outlinecolor,"fill-opacity":e.opacity});break;case"symbol":var i=e.symbol,a=o(i.textposition,i.iconsize);n.extendFlat(t,{"icon-image":i.icon+"-15","icon-size":i.iconsize/10,"text-field":i.text,"text-size":i.textfont.size,"text-anchor":a.anchor,"text-offset":a.offset,"symbol-placement":i.placement}),n.extendFlat(r,{"icon-color":e.color,"text-color":i.textfont.color,"text-opacity":e.opacity});break;case"raster":n.extendFlat(r,{"raster-fade-duration":0,"raster-opacity":e.opacity})}return{layout:t,paint:r}}l.update=function(e){this.visible?this.needsNewImage(e)?this.updateImage(e):this.needsNewSource(e)?(this.removeLayer(),this.updateSource(e),this.updateLayer(e)):this.needsNewLayer(e)?this.updateLayer(e):this.updateStyle(e):(this.updateSource(e),this.updateLayer(e)),this.visible=c(e)},l.needsNewImage=function(e){return this.subplot.map.getSource(this.idSource)&&"image"===this.sourceType&&"image"===e.sourcetype&&(this.source!==e.source||JSON.stringify(this.coordinates)!==JSON.stringify(e.coordinates))},l.needsNewSource=function(e){return this.sourceType!==e.sourcetype||JSON.stringify(this.source)!==JSON.stringify(e.source)||this.layerType!==e.type},l.needsNewLayer=function(e){return this.layerType!==e.type||this.below!==this.subplot.belowLookup["layout-"+this.index]},l.lookupBelow=function(){return this.subplot.belowLookup["layout-"+this.index]},l.updateImage=function(e){this.subplot.map.getSource(this.idSource).updateImage({url:e.source,coordinates:e.coordinates});var t=this.findFollowingMapboxLayerId(this.lookupBelow());null!==t&&this.subplot.map.moveLayer(this.idLayer,t)},l.updateSource=function(e){var t=this.subplot.map;if(t.getSource(this.idSource)&&t.removeSource(this.idSource),this.sourceType=e.sourcetype,this.source=e.source,c(e)){var r=function(e){var t,r=e.sourcetype,n=e.source,o={type:r};"geojson"===r?t="data":"vector"===r?t="string"===typeof n?"url":"tiles":"raster"===r?(t="tiles",o.tileSize=256):"image"===r&&(t="url",o.coordinates=e.coordinates);o[t]=n,e.sourceattribution&&(o.attribution=i(e.sourceattribution));return o}(e);t.addSource(this.idSource,r)}},l.findFollowingMapboxLayerId=function(e){if("traces"===e)for(var t=this.subplot.getMapLayers(),r=0;r{"use strict";var n=r(84468),i=r(7605).defaultLine,o=r(81159).u,a=r(91740),s=r(22049).textposition,l=r(72587).overrideAll,c=r(37091).templatedArray,u=r(26966),d=a({noFontVariant:!0,noFontShadow:!0,noFontLineposition:!0,noFontTextcase:!0,description:["Sets the icon text font (color=mapbox.layer.paint.text-color, size=mapbox.layer.layout.text-size).","Has an effect only when `type` is set to *symbol*."].join(" ")});d.family.dflt="Open Sans Regular, Arial Unicode MS Regular",(e.exports=l({_arrayAttrRegexps:[n.counterRegex("mapbox",".layers",!0)],domain:o({name:"mapbox"}),accesstoken:{valType:"string",noBlank:!0,strict:!0,description:["Sets the mapbox access token to be used for this mapbox map.","Alternatively, the mapbox access token can be set in the","configuration options under `mapboxAccessToken`.","Note that accessToken are only required when `style`","(e.g with values :",u.styleValuesMapbox.join(", "),")","and/or a layout layer references the Mapbox server."].join(" ")},style:{valType:"any",values:u.styleValuesMapbox.concat(u.styleValuesNonMapbox),dflt:u.styleValueDflt,description:["Defines the map layers that are rendered by default below the trace layers defined in `data`,","which are themselves by default rendered below the layers defined in `layout.mapbox.layers`.","","These layers can be defined either explicitly as a Mapbox Style object which can contain multiple","layer definitions that load data from any public or private Tile Map Service (TMS or XYZ) or Web Map Service (WMS)","or implicitly by using one of the built-in style objects which use WMSes which do not require any","access tokens, or by using a default Mapbox style or custom Mapbox style URL, both of","which require a Mapbox access token","","Note that Mapbox access token can be set in the `accesstoken` attribute","or in the `mapboxAccessToken` config option.","","Mapbox Style objects are of the form described in the Mapbox GL JS documentation available at","https://docs.mapbox.com/mapbox-gl-js/style-spec","","The built-in plotly.js styles objects are:",u.styleValuesNonMapbox.join(", "),"","The built-in Mapbox styles are:",u.styleValuesMapbox.join(", "),"","Mapbox style URLs are of the form: mapbox://mapbox.mapbox--"].join(" ")},center:{lon:{valType:"number",dflt:0,description:"Sets the longitude of the center of the map (in degrees East)."},lat:{valType:"number",dflt:0,description:"Sets the latitude of the center of the map (in degrees North)."}},zoom:{valType:"number",dflt:1,description:"Sets the zoom level of the map (mapbox.zoom)."},bearing:{valType:"number",dflt:0,description:"Sets the bearing angle of the map in degrees counter-clockwise from North (mapbox.bearing)."},pitch:{valType:"number",dflt:0,description:["Sets the pitch angle of the map","(in degrees, where *0* means perpendicular to the surface of the map) (mapbox.pitch)."].join(" ")},bounds:{west:{valType:"number",description:["Sets the minimum longitude of the map (in degrees East)","if `east`, `south` and `north` are declared."].join(" ")},east:{valType:"number",description:["Sets the maximum longitude of the map (in degrees East)","if `west`, `south` and `north` are declared."].join(" ")},south:{valType:"number",description:["Sets the minimum latitude of the map (in degrees North)","if `east`, `west` and `north` are declared."].join(" ")},north:{valType:"number",description:["Sets the maximum latitude of the map (in degrees North)","if `east`, `west` and `south` are declared."].join(" ")}},layers:c("layer",{visible:{valType:"boolean",dflt:!0,description:["Determines whether this layer is displayed"].join(" ")},sourcetype:{valType:"enumerated",values:["geojson","vector","raster","image"],dflt:"geojson",description:["Sets the source type for this layer,","that is the type of the layer data."].join(" ")},source:{valType:"any",description:["Sets the source data for this layer (mapbox.layer.source).","When `sourcetype` is set to *geojson*, `source` can be a URL to a GeoJSON","or a GeoJSON object.","When `sourcetype` is set to *vector* or *raster*, `source` can be a URL or","an array of tile URLs.","When `sourcetype` is set to *image*, `source` can be a URL to an image."].join(" ")},sourcelayer:{valType:"string",dflt:"",description:["Specifies the layer to use from a vector tile source (mapbox.layer.source-layer).","Required for *vector* source type that supports multiple layers."].join(" ")},sourceattribution:{valType:"string",description:["Sets the attribution for this source."].join(" ")},type:{valType:"enumerated",values:["circle","line","fill","symbol","raster"],dflt:"circle",description:["Sets the layer type,","that is the how the layer data set in `source` will be rendered","With `sourcetype` set to *geojson*, the following values are allowed:","*circle*, *line*, *fill* and *symbol*.","but note that *line* and *fill* are not compatible with Point","GeoJSON geometries.","With `sourcetype` set to *vector*, the following values are allowed:"," *circle*, *line*, *fill* and *symbol*.","With `sourcetype` set to *raster* or `*image*`, only the *raster* value is allowed."].join(" ")},coordinates:{valType:"any",description:["Sets the coordinates array contains [longitude, latitude] pairs","for the image corners listed in clockwise order:","top left, top right, bottom right, bottom left.","Only has an effect for *image* `sourcetype`."].join(" ")},below:{valType:"string",description:["Determines if the layer will be inserted","before the layer with the specified ID.","If omitted or set to '',","the layer will be inserted above every existing layer."].join(" ")},color:{valType:"color",dflt:i,description:["Sets the primary layer color.","If `type` is *circle*, color corresponds to the circle color (mapbox.layer.paint.circle-color)","If `type` is *line*, color corresponds to the line color (mapbox.layer.paint.line-color)","If `type` is *fill*, color corresponds to the fill color (mapbox.layer.paint.fill-color)","If `type` is *symbol*, color corresponds to the icon color (mapbox.layer.paint.icon-color)"].join(" ")},opacity:{valType:"number",min:0,max:1,dflt:1,description:["Sets the opacity of the layer.","If `type` is *circle*, opacity corresponds to the circle opacity (mapbox.layer.paint.circle-opacity)","If `type` is *line*, opacity corresponds to the line opacity (mapbox.layer.paint.line-opacity)","If `type` is *fill*, opacity corresponds to the fill opacity (mapbox.layer.paint.fill-opacity)","If `type` is *symbol*, opacity corresponds to the icon/text opacity (mapbox.layer.paint.text-opacity)"].join(" ")},minzoom:{valType:"number",min:0,max:24,dflt:0,description:["Sets the minimum zoom level (mapbox.layer.minzoom).","At zoom levels less than the minzoom, the layer will be hidden."].join(" ")},maxzoom:{valType:"number",min:0,max:24,dflt:24,description:["Sets the maximum zoom level (mapbox.layer.maxzoom).","At zoom levels equal to or greater than the maxzoom, the layer will be hidden."].join(" ")},circle:{radius:{valType:"number",dflt:15,description:["Sets the circle radius (mapbox.layer.paint.circle-radius).","Has an effect only when `type` is set to *circle*."].join(" ")}},line:{width:{valType:"number",dflt:2,description:["Sets the line width (mapbox.layer.paint.line-width).","Has an effect only when `type` is set to *line*."].join(" ")},dash:{valType:"data_array",description:["Sets the length of dashes and gaps (mapbox.layer.paint.line-dasharray).","Has an effect only when `type` is set to *line*."].join(" ")}},fill:{outlinecolor:{valType:"color",dflt:i,description:["Sets the fill outline color (mapbox.layer.paint.fill-outline-color).","Has an effect only when `type` is set to *fill*."].join(" ")}},symbol:{icon:{valType:"string",dflt:"marker",description:["Sets the symbol icon image (mapbox.layer.layout.icon-image).","Full list: https://www.mapbox.com/maki-icons/"].join(" ")},iconsize:{valType:"number",dflt:10,description:["Sets the symbol icon size (mapbox.layer.layout.icon-size).","Has an effect only when `type` is set to *symbol*."].join(" ")},text:{valType:"string",dflt:"",description:["Sets the symbol text (mapbox.layer.layout.text-field)."].join(" ")},placement:{valType:"enumerated",values:["point","line","line-center"],dflt:"point",description:["Sets the symbol and/or text placement (mapbox.layer.layout.symbol-placement).","If `placement` is *point*, the label is placed where the geometry is located","If `placement` is *line*, the label is placed along the line of the geometry","If `placement` is *line-center*, the label is placed on the center of the geometry"].join(" ")},textfont:d,textposition:n.extendFlat({},s,{arrayOk:!1})}})},"plot","from-root")).uirevision={valType:"any",editType:"none",description:["Controls persistence of user-driven changes in the view:","`center`, `zoom`, `bearing`, `pitch`. Defaults to `layout.uirevision`."].join(" ")}},76846:(e,t,r)=>{"use strict";var n=r(84468),i=r(54883),o=r(38851),a=r(6185);function s(e,t,r,n){r("accesstoken",n.accessToken),r("style"),r("center.lon"),r("center.lat"),r("zoom"),r("bearing"),r("pitch");var i=r("bounds.west"),a=r("bounds.east"),s=r("bounds.south"),c=r("bounds.north");void 0!==i&&void 0!==a&&void 0!==s&&void 0!==c||delete t.bounds,o(e,t,{name:"layers",handleItemDefaults:l}),t._input=e}function l(e,t){function r(r,i){return n.coerce(e,t,a.layers,r,i)}if(r("visible")){var i,o=r("sourcetype"),s="raster"===o||"image"===o;r("source"),r("sourceattribution"),"vector"===o&&r("sourcelayer"),"image"===o&&r("coordinates"),s&&(i="raster");var l=r("type",i);s&&"raster"!==l&&(l=t.type="raster",n.log("Source types *raster* and *image* must drawn *raster* layer type.")),r("below"),r("color"),r("opacity"),r("minzoom"),r("maxzoom"),"circle"===l&&r("circle.radius"),"line"===l&&(r("line.width"),r("line.dash")),"fill"===l&&r("fill.outlinecolor"),"symbol"===l&&(r("symbol.icon"),r("symbol.iconsize"),r("symbol.text"),n.coerceFont(r,"symbol.textfont",void 0,{noFontVariant:!0,noFontShadow:!0,noFontLineposition:!0,noFontTextcase:!0}),r("symbol.textposition"),r("symbol.placement"))}}e.exports=function(e,t,r){i(e,t,r,{type:"mapbox",attributes:a,handleDefaults:s,partition:"y",accessToken:t._mapboxAccessToken})}},14312:(e,t,r)=>{"use strict";var n=r(64871),i=r(84468),o=r(63925),a=r(38361),s=r(85729),l=r(25732),c=r(32212),u=r(2705),d=u.drawMode,h=u.selectMode,p=r(76789).prepSelect,f=r(76789).clearOutline,m=r(76789).clearSelectionsCache,g=r(76789).selectOnClick,y=r(26966),v=r(50869);function x(e,t){this.id=t,this.gd=e;var r=e._fullLayout,n=e._context;this.container=r._glcontainer.node(),this.isStatic=n.staticPlot,this.uid=r._uid+"-"+this.id,this.div=null,this.xaxis=null,this.yaxis=null,this.createFramework(r),this.map=null,this.accessToken=null,this.styleObj=null,this.traceHash={},this.layerList=[],this.belowLookup={},this.dragging=!1,this.wheeling=!1}var b=x.prototype;b.plot=function(e,t,r){var n,i=this,o=t[i.id];i.map&&o.accesstoken!==i.accessToken&&(i.map.remove(),i.map=null,i.styleObj=null,i.traceHash={},i.layerList=[]),n=i.map?new Promise((function(r,n){i.updateMap(e,t,r,n)})):new Promise((function(r,n){i.createMap(e,t,r,n)})),r.push(n)},b.createMap=function(e,t,r,i){var a=this,s=t[a.id],l=a.styleObj=w(s.style,t);a.accessToken=s.accesstoken;var c=s.bounds,u=c?[[c.west,c.south],[c.east,c.north]]:null,d=a.map=new n.Map({container:a.div,style:l.style,center:S(s.center),zoom:s.zoom,bearing:s.bearing,pitch:s.pitch,maxBounds:u,interactive:!a.isStatic,preserveDrawingBuffer:a.isStatic,doubleClickZoom:!1,boxZoom:!1,attributionControl:!1}).addControl(new n.AttributionControl({compact:!0}));d._canvas.style.left="0px",d._canvas.style.top="0px",a.rejectOnError(i),a.isStatic||a.initFx(e,t);var h=[];h.push(new Promise((function(e){d.once("load",e)}))),h=h.concat(o.fetchTraceGeoData(e)),Promise.all(h).then((function(){a.fillBelowLookup(e,t),a.updateData(e),a.updateLayout(t),a.resolveOnRender(r)})).catch(i)},b.updateMap=function(e,t,r,n){var i=this,a=i.map,s=t[this.id];i.rejectOnError(n);var l=[],c=w(s.style,t);JSON.stringify(i.styleObj)!==JSON.stringify(c)&&(i.styleObj=c,a.setStyle(c.style),i.traceHash={},l.push(new Promise((function(e){a.once("styledata",e)})))),l=l.concat(o.fetchTraceGeoData(e)),Promise.all(l).then((function(){i.fillBelowLookup(e,t),i.updateData(e),i.updateLayout(t),i.resolveOnRender(r)})).catch(n)},b.fillBelowLookup=function(e,t){var r,n,i=t[this.id].layers,o=this.belowLookup={},a=!1;for(r=0;r1)for(r=0;r-1&&g(t.originalEvent,n,[r.xaxis],[r.yaxis],r.id,e),i.indexOf("event")>-1&&c.click(n,t.originalEvent)}}},b.updateFx=function(e){var t=this,r=t.map,n=t.gd;if(!t.isStatic){var o,a=e.dragmode;o=function(e,r){r.isRect?(e.range={})[t.id]=[c([r.xmin,r.ymin]),c([r.xmax,r.ymax])]:(e.lassoPoints={})[t.id]=r.map(c)};var s=t.dragOptions;t.dragOptions=i.extendDeep(s||{},{dragmode:e.dragmode,element:t.div,gd:n,plotinfo:{id:t.id,domain:e[t.id].domain,xaxis:t.xaxis,yaxis:t.yaxis,fillRangeItems:o},xaxes:[t.xaxis],yaxes:[t.yaxis],subplot:t.id}),r.off("click",t.onClickInPanHandler),h(a)||d(a)?(r.dragPan.disable(),r.on("zoomstart",t.clearOutline),t.dragOptions.prepFn=function(e,r,n){p(e,r,n,t.dragOptions,a)},l.init(t.dragOptions)):(r.dragPan.enable(),r.off("zoomstart",t.clearOutline),t.div.onmousedown=null,t.div.ontouchstart=null,t.div.removeEventListener("touchstart",t.div._ontouchstart),t.onClickInPanHandler=t.onClickInPanFn(t.dragOptions),r.on("click",t.onClickInPanHandler))}function c(e){var r=t.map.unproject(e);return[r.lng,r.lat]}},b.updateFramework=function(e){var t=e[this.id].domain,r=e._size,n=this.div.style;n.width=r.w*(t.x[1]-t.x[0])+"px",n.height=r.h*(t.y[1]-t.y[0])+"px",n.left=r.l+t.x[0]*r.w+"px",n.top=r.t+(1-t.y[1])*r.h+"px",this.xaxis._offset=r.l+t.x[0]*r.w,this.xaxis._length=r.w*(t.x[1]-t.x[0]),this.yaxis._offset=r.t+(1-t.y[1])*r.h,this.yaxis._length=r.h*(t.y[1]-t.y[0])},b.updateLayers=function(e){var t,r=e[this.id].layers,n=this.layerList;if(r.length!==n.length){for(t=0;t{"use strict";e.exports=function(e){var t=e.editType;return{t:{valType:"number",dflt:0,editType:t,description:"The amount of padding (in px) along the top of the component."},r:{valType:"number",dflt:0,editType:t,description:"The amount of padding (in px) on the right side of the component."},b:{valType:"number",dflt:0,editType:t,description:"The amount of padding (in px) along the bottom of the component."},l:{valType:"number",dflt:0,editType:t,description:"The amount of padding (in px) on the left side of the component."},editType:t}}},68543:(e,t,r)=>{"use strict";var n=r(41871),i=r(9212).de,o=r(80902).OE,a=r(22036),s=r(12160),l=r(38361),c=r(30166),u=r(37091),d=r(84468),h=r(7605),p=r(65004).BADNUM,f=r(11576),m=r(35473).clearOutline,g=r(92716),y=r(34765),v=r(44380),x=r(50246).eV,b=d.relinkPrivateKeys,_=d._,w=e.exports={};d.extendFlat(w,l),w.attributes=r(75622),w.attributes.type.values=w.allTypes,w.fontAttrs=r(91740),w.layoutAttributes=r(98005);var k=w.transformsRegistry,S=r(46854);w.executeAPICommand=S.executeAPICommand,w.computeAPICommandBindings=S.computeAPICommandBindings,w.manageCommandObserver=S.manageCommandObserver,w.hasSimpleAPICommandBindings=S.hasSimpleAPICommandBindings,w.redrawText=function(e){return e=d.getGraphDiv(e),new Promise((function(t){setTimeout((function(){e._fullLayout&&(l.getComponentMethod("annotations","draw")(e),l.getComponentMethod("legend","draw")(e),l.getComponentMethod("colorbar","draw")(e),t(w.previousPromises(e)))}),300)}))},w.resize=function(e){var t;e=d.getGraphDiv(e);var r=new Promise((function(r,n){e&&!d.isHidden(e)||n(new Error("Resize must be passed a displayed plot div element.")),e._redrawTimer&&clearTimeout(e._redrawTimer),e._resolveResize&&(t=e._resolveResize),e._resolveResize=r,e._redrawTimer=setTimeout((function(){if(!e.layout||e.layout.width&&e.layout.height||d.isHidden(e))r(e);else{delete e.layout.width,delete e.layout.height;var t=e.changed;e.autoplay=!0,l.call("relayout",e,{autosize:!0}).then((function(){e.changed=t,e._resolveResize===r&&(delete e._resolveResize,r(e))}))}}),100)}));return t&&t(r),r},w.previousPromises=function(e){if((e._promises||[]).length)return Promise.all(e._promises).then((function(){e._promises=[]}))},w.addLinks=function(e){if(e._context.showLink||e._context.showSources){var t=e._fullLayout,r=d.ensureSingle(t._paper,"text","js-plot-link-container",(function(e){e.style({"font-family":'"Open Sans", Arial, sans-serif',"font-size":"12px",fill:h.defaultLine,"pointer-events":"all"}).each((function(){var e=n.select(this);e.append("tspan").classed("js-link-to-tool",!0),e.append("tspan").classed("js-link-spacer",!0),e.append("tspan").classed("js-sourcelinks",!0)}))})),i=r.node(),o={y:t._paper.attr("height")-9};document.body.contains(i)&&i.getComputedTextLength()>=t.width-20?(o["text-anchor"]="start",o.x=5):(o["text-anchor"]="end",o.x=t._paper.attr("width")-7),r.attr(o);var a=r.select(".js-link-to-tool"),s=r.select(".js-link-spacer"),l=r.select(".js-sourcelinks");e._context.showSources&&e._context.showSources(e),e._context.showLink&&function(e,t){t.text("");var r=t.append("a").attr({"xlink:xlink:href":"#",class:"link--impt link--embedview","font-weight":"bold"}).text(e._context.linkText+" "+String.fromCharCode(187));if(e._context.sendData)r.on("click",(function(){w.sendDataToCloud(e)}));else{var n=window.location.pathname.split("/"),i=window.location.search;r.attr({"xlink:xlink:show":"new","xlink:xlink:href":"/"+n[2].split(".")[0]+"/"+n[1]+i})}}(e,a),s.text(a.text()&&l.text()?" - ":"")}},w.sendDataToCloud=function(e){var t=(window.PLOTLYENV||{}).BASE_URL||e._context.plotlyServerURL;if(t){e.emit("plotly_beforeexport");var r=n.select(e).append("div").attr("id","hiddenform").style("display","none"),i=r.append("form").attr({action:t+"/external",method:"post",target:"_blank"});return i.append("input").attr({type:"text",name:"data"}).node().value=w.graphJson(e,!1,"keepdata"),i.node().submit(),r.remove(),e.emit("plotly_afterexport"),!1}};var A=["days","shortDays","months","shortMonths","periods","dateTime","date","time","decimal","thousands","grouping","currency"],T=["year","month","dayMonth","dayMonthYear"];function M(e,t){var r=e._context.locale;r||(r="en-US");var n=!1,i={};function o(e){for(var r=!0,o=0;o1&&L.length>1){for(l.getComponentMethod("grid","sizeDefaults")(c,s),a=0;a15&&L.length>15&&0===s.shapes.length&&0===s.images.length,w.linkSubplots(h,s,u,n),w.cleanPlot(h,s,u,n);var N=!(!n._has||!n._has("gl2d")),B=!(!s._has||!s._has("gl2d")),V=!(!n._has||!n._has("cartesian"))||N,U=!(!s._has||!s._has("cartesian"))||B;V&&!U?n._bgLayer.remove():U&&!V&&(s._shouldCreateBgLayer=!0),n._zoomlayer&&!e._dragging&&m({_fullLayout:n}),function(e,t){var r,n=[];t.meta&&(r=t._meta={meta:t.meta,layout:{meta:t.meta}});for(var i=0;i0){var u=1-2*s;n=Math.round(u*n),i=Math.round(u*i)}}var h=w.layoutAttributes.width.min,p=w.layoutAttributes.height.min;n1,m=!t.height&&Math.abs(r.height-i)>1;(m||f)&&(f&&(r.width=n),m&&(r.height=i)),e._initialAutoSize||(e._initialAutoSize={width:n,height:i}),w.sanitizeMargins(r)},w.supplyLayoutModuleDefaults=function(e,t,r,n){var i,o,a,s=l.componentsRegistry,c=t._basePlotModules,u=l.subplotsRegistry.cartesian;for(i in s)(a=s[i]).includeBasePlot&&a.includeBasePlot(e,t);for(var h in c.length||c.push(u),t._has("cartesian")&&(l.getComponentMethod("grid","contentDefaults")(e,t),u.finalizeSubplots(e,t)),t._subplots)t._subplots[h].sort(d.subplotSort);for(o=0;o1&&(r.l/=y,r.r/=y)}if(p){var v=(r.t+r.b)/p;v>1&&(r.t/=v,r.b/=v)}var x=void 0!==r.xl?r.xl:r.x,b=void 0!==r.xr?r.xr:r.x,_=void 0!==r.yt?r.yt:r.y,k=void 0!==r.yb?r.yb:r.y;f[t]={l:{val:x,size:r.l+g},r:{val:b,size:r.r+g},b:{val:k,size:r.b+g},t:{val:_,size:r.t+g}},m[t]=1}else delete f[t],delete m[t];if(!n._replotting)return w.doAutoMargin(e)}},w.doAutoMargin=function(e){var t=e._fullLayout,r=t.width,n=t.height;t._size||(t._size={}),O(t);var i=t._size,o=t.margin,s={t:0,b:0,l:0,r:0},c=d.extendFlat({},i),u=o.l,h=o.r,p=o.t,m=o.b,g=t._pushmargin,y=t._pushmarginIds,v=t.minreducedwidth,x=t.minreducedheight;if(!1!==o.autoexpand){for(var b in g)y[b]||delete g[b];var _=e._fullLayout._reservedMargin;for(var k in _)for(var S in _[k]){var A=_[k][S];s[S]=Math.max(s[S],A)}for(var T in g.base={l:{val:0,size:u},r:{val:1,size:h},t:{val:1,size:p},b:{val:0,size:m}},s){var M=0;for(var C in g)"base"!==C&&a(g[C][T].size)&&(M=g[C][T].size>M?g[C][T].size:M);var E=Math.max(0,o[T]-M);s[T]=Math.max(0,s[T]-E)}for(var I in g){var P=g[I].l||{},R=g[I].b||{},L=P.val,D=P.size,z=R.val,j=R.size,F=r-s.r-s.l,N=n-s.t-s.b;for(var B in g){if(a(D)&&g[B].r){var V=g[B].r.val,U=g[B].r.size;if(V>L){var H=(D*V+(U-F)*L)/(V-L),$=(U*(1-L)+(D-F)*(1-V))/(V-L);H+$>u+h&&(u=H,h=$)}}if(a(j)&&g[B].t){var W=g[B].t.val,q=g[B].t.size;if(W>z){var G=(j*W+(q-N)*z)/(W-z),Y=(q*(1-z)+(j-N)*(1-W))/(W-z);G+Y>m+p&&(m=G,p=Y)}}}}}var X=d.constrain(r-o.l-o.r,2,v),Z=d.constrain(n-o.t-o.b,2,x),K=Math.max(0,r-X),J=Math.max(0,n-Z);if(K){var Q=(u+h)/K;Q>1&&(u/=Q,h/=Q)}if(J){var ee=(m+p)/J;ee>1&&(m/=ee,p/=ee)}if(i.l=Math.round(u)+s.l,i.r=Math.round(h)+s.r,i.t=Math.round(p)+s.t,i.b=Math.round(m)+s.b,i.p=Math.round(o.pad),i.w=Math.round(r)-i.l-i.r,i.h=Math.round(n)-i.t-i.b,!t._replotting&&(w.didMarginChange(c,i)||function(e){if("_redrawFromAutoMarginCount"in e._fullLayout)return!1;var t=f.list(e,"",!0);for(var r in t)if(t[r].autoshift||t[r].shift)return!0;return!1}(e))){"_redrawFromAutoMarginCount"in t?t._redrawFromAutoMarginCount++:t._redrawFromAutoMarginCount=1;var te=3*(1+Object.keys(y).length);if(t._redrawFromAutoMarginCount0&&(e._transitioningWithDuration=!0),e._transitionData._interruptCallbacks.push((function(){n=!0})),r.redraw&&e._transitionData._interruptCallbacks.push((function(){return l.call("redraw",e)})),e._transitionData._interruptCallbacks.push((function(){e.emit("plotly_transitioninterrupted",[])}));var o=0,a=0;function s(){return o++,function(){a++,n||a!==o||function(t){if(!e._transitionData)return;(function(e){if(e)for(;e.length;)e.shift()})(e._transitionData._interruptCallbacks),Promise.resolve().then((function(){if(r.redraw)return l.call("redraw",e)})).then((function(){e._transitioning=!1,e._transitioningWithDuration=!1,e.emit("plotly_transitioned",[])})).then(t)}(i)}}r.runFn(s),setTimeout(s())}))}],o=d.syncOrAsync(i,e);return o&&o.then||(o=Promise.resolve()),o.then((function(){return e}))}w.didMarginChange=function(e,t){for(var r=0;r1)return!0}return!1},w.graphJson=function(e,t,r,n,i,o){(i&&t&&!e._fullData||i&&!t&&!e._fullLayout)&&w.supplyDefaults(e);var a=i?e._fullData:e.data,l=i?e._fullLayout:e.layout,c=(e._transitionData||{})._frames;function u(e,t){if("function"===typeof e)return t?"_function_":null;if(d.isPlainObject(e)){var n,i={};return Object.keys(e).sort().forEach((function(o){if(-1===["_","["].indexOf(o.charAt(0)))if("function"!==typeof e[o]){if("keepdata"===r){if("src"===o.substr(o.length-3))return}else if("keepstream"===r){if("string"===typeof(n=e[o+"src"])&&n.indexOf(":")>0&&!d.isPlainObject(e.stream))return}else if("keepall"!==r&&"string"===typeof(n=e[o+"src"])&&n.indexOf(":")>0)return;i[o]=u(e[o],t)}else t&&(i[o]="_function")})),i}var o=Array.isArray(e),a=d.isTypedArray(e);if((o||a)&&e.dtype&&e.shape){var l=e.bdata;return u({dtype:e.dtype,shape:e.shape,bdata:d.isArrayBuffer(l)?s.encode(l):l},t)}return o?e.map((function(e){return u(e,t)})):a?d.simpleMap(e,d.identity):d.isJSDate(e)?d.ms2DateTimeLocal(+e):e}var h={data:(a||[]).map((function(e){var r=u(e);return t&&delete r.fit,r}))};if(!t&&(h.layout=u(l),i)){var p=l._size;h.layout.computed={margin:{b:p.b,l:p.l,r:p.r,t:p.t}}}return c&&(h.frames=u(c)),o&&(h.config=u(e._context,!0)),"object"===n?h:JSON.stringify(h)},w.modifyFrames=function(e,t){var r,n,i,o=e._transitionData._frames,a=e._transitionData._frameHash;for(r=0;r=0;o--)if(l[o].enabled){r._indexToPoints=l[o]._indexToPoints;break}n&&n.calc&&(a=n.calc(e,r))}Array.isArray(a)&&a[0]||(a=[{x:p,y:p}]),a[0].t||(a[0].t={}),a[0].trace=r,h[t]=a}}for(z(a,s,u),i=0;i{"use strict";e.exports={attr:"subplot",name:"polar",axisNames:["angularaxis","radialaxis"],axisName2dataArray:{angularaxis:"theta",radialaxis:"r"},layerNames:["draglayer","plotbg","backplot","angular-grid","radial-grid","frontplot","angular-line","radial-line","angular-axis","radial-axis"],radialDragBoxSize:50,angularDragBoxSize:30,cornerLen:25,cornerHalfWidth:2,MINDRAG:8,MINZOOM:20,OFFEDGE:20}},81453:(e,t,r)=>{"use strict";var n=r(84468),i=r(39926).tester,o=n.findIndexOfMin,a=n.isAngleInsideSector,s=n.angleDelta,l=n.angleDist;function c(e,t,r,n){var i,o,a=n[0],s=n[1],l=d(Math.sin(t)-Math.sin(e)),c=d(Math.cos(t)-Math.cos(e)),u=Math.tan(r),h=d(1/u),p=l/c,f=s-p*a;return h?l&&c?o=u*(i=f/(u-p)):c?(i=s*h,o=s):(i=a,o=a*u):l&&c?(i=0,o=f):c?(i=0,o=s):i=o=NaN,[i,o]}function u(e,t,r,i){return n.isFullCircle([t,r])?function(e,t){var r,n=t.length,i=new Array(n+1);for(r=0;r1e-10?e:0}function h(e,t,r){t=t||0,r=r||0;for(var n=e.length,i=new Array(n),o=0;o0?r:1/0})),i=n.mod(r+1,t.length);return[t[r],t[i]]},findIntersectionXY:c,findXYatLength:function(e,t,r,n){var i=-t*r,o=t*t+1,a=2*(t*i-r),s=i*i+r*r-e*e,l=Math.sqrt(a*a-4*o*s),c=(-a+l)/(2*o),u=(-a-l)/(2*o);return[[c,t*c+i+n],[u,t*u+i+n]]},clampTiny:d,pathPolygon:function(e,t,r,n,i,o){return"M"+h(u(e,t,r,n),i,o).join("L")},pathPolygonAnnulus:function(e,t,r,n,i,o,a){var s,l;e{"use strict";var n=r(50246).fX,i=r(84468).counterRegex,o=r(74908),a=r(28261),s=a.attr,l=a.name,c=i(l),u={};u[s]={valType:"subplotid",dflt:l,editType:"calc",description:["Sets a reference between this trace's data coordinates and","a polar subplot.","If *polar* (the default value), the data refer to `layout.polar`.","If *polar2*, the data refer to `layout.polar2`, and so on."].join(" ")},e.exports={attr:s,name:l,idRoot:l,idRegex:c,attrRegex:c,attributes:u,layoutAttributes:r(35882),supplyLayoutDefaults:r(15997),plot:function(e){for(var t=e._fullLayout,r=e.calcdata,i=t._subplots[l],a=0;a{"use strict";var n=r(17992),i=r(49080),o=r(81159).u,a=r(84468).extendFlat,s=r(72587).overrideAll,l=s({color:i.color,showline:a({},i.showline,{dflt:!0}),linecolor:i.linecolor,linewidth:i.linewidth,showgrid:a({},i.showgrid,{dflt:!0}),gridcolor:i.gridcolor,gridwidth:i.gridwidth,griddash:i.griddash},"plot","from-root"),c=s({tickmode:i.minor.tickmode,nticks:i.nticks,tick0:i.tick0,dtick:i.dtick,tickvals:i.tickvals,ticktext:i.ticktext,ticks:i.ticks,ticklen:i.ticklen,tickwidth:i.tickwidth,tickcolor:i.tickcolor,ticklabelstep:i.ticklabelstep,showticklabels:i.showticklabels,labelalias:i.labelalias,showtickprefix:i.showtickprefix,tickprefix:i.tickprefix,showticksuffix:i.showticksuffix,ticksuffix:i.ticksuffix,showexponent:i.showexponent,exponentformat:i.exponentformat,minexponent:i.minexponent,separatethousands:i.separatethousands,tickfont:i.tickfont,tickangle:i.tickangle,tickformat:i.tickformat,tickformatstops:i.tickformatstops,layer:i.layer},"plot","from-root"),u={visible:a({},i.visible,{dflt:!0}),type:a({},i.type,{values:["-","linear","log","date","category"]}),autotypenumbers:i.autotypenumbers,autorangeoptions:{minallowed:i.autorangeoptions.minallowed,maxallowed:i.autorangeoptions.maxallowed,clipmin:i.autorangeoptions.clipmin,clipmax:i.autorangeoptions.clipmax,include:i.autorangeoptions.include,editType:"plot"},autorange:a({},i.autorange,{editType:"plot"}),rangemode:{valType:"enumerated",values:["tozero","nonnegative","normal"],dflt:"tozero",editType:"calc",description:["If *tozero*`, the range extends to 0,","regardless of the input data","If *nonnegative*, the range is non-negative,","regardless of the input data.","If *normal*, the range is computed in relation to the extrema","of the input data (same behavior as for cartesian axes)."].join(" ")},minallowed:a({},i.minallowed,{editType:"plot"}),maxallowed:a({},i.maxallowed,{editType:"plot"}),range:a({},i.range,{items:[{valType:"any",editType:"plot",impliedEdits:{"^autorange":!1}},{valType:"any",editType:"plot",impliedEdits:{"^autorange":!1}}],editType:"plot"}),categoryorder:i.categoryorder,categoryarray:i.categoryarray,angle:{valType:"angle",editType:"plot",description:["Sets the angle (in degrees) from which the radial axis is drawn.","Note that by default, radial axis line on the theta=0 line","corresponds to a line pointing right (like what mathematicians prefer).","Defaults to the first `polar.sector` angle."].join(" ")},autotickangles:i.autotickangles,side:{valType:"enumerated",values:["clockwise","counterclockwise"],dflt:"clockwise",editType:"plot",description:["Determines on which side of radial axis line","the tick and tick labels appear."].join(" ")},title:{text:a({},i.title.text,{editType:"plot",dflt:""}),font:a({},i.title.font,{editType:"plot"}),editType:"plot"},hoverformat:i.hoverformat,uirevision:{valType:"any",editType:"none",description:["Controls persistence of user-driven changes in axis `range`,","`autorange`, `angle`, and `title` if in `editable: true` configuration.","Defaults to `polar.uirevision`."].join(" ")},editType:"calc",_deprecated:{title:i._deprecated.title,titlefont:i._deprecated.titlefont}};a(u,l,c);var d={visible:a({},i.visible,{dflt:!0}),type:{valType:"enumerated",values:["-","linear","category"],dflt:"-",editType:"calc",_noTemplating:!0,description:["Sets the angular axis type.","If *linear*, set `thetaunit` to determine the unit in which axis value are shown.","If *category, use `period` to set the number of integer coordinates around polar axis."].join(" ")},autotypenumbers:i.autotypenumbers,categoryorder:i.categoryorder,categoryarray:i.categoryarray,thetaunit:{valType:"enumerated",values:["radians","degrees"],dflt:"degrees",editType:"calc",description:["Sets the format unit of the formatted *theta* values.","Has an effect only when `angularaxis.type` is *linear*."].join(" ")},period:{valType:"number",editType:"calc",min:0,description:["Set the angular period.","Has an effect only when `angularaxis.type` is *category*."].join(" ")},direction:{valType:"enumerated",values:["counterclockwise","clockwise"],dflt:"counterclockwise",editType:"calc",description:["Sets the direction corresponding to positive angles."].join(" ")},rotation:{valType:"angle",editType:"calc",description:["Sets that start position (in degrees) of the angular axis","By default, polar subplots with `direction` set to *counterclockwise*","get a `rotation` of *0*","which corresponds to due East (like what mathematicians prefer).","In turn, polar with `direction` set to *clockwise* get a rotation of *90*","which corresponds to due North (like on a compass),"].join(" ")},hoverformat:i.hoverformat,uirevision:{valType:"any",editType:"none",description:["Controls persistence of user-driven changes in axis `rotation`.","Defaults to `polar.uirevision`."].join(" ")},editType:"calc"};a(d,l,c),e.exports={domain:o({name:"polar",editType:"plot"}),sector:{valType:"info_array",items:[{valType:"number",editType:"plot"},{valType:"number",editType:"plot"}],dflt:[0,360],editType:"plot",description:["Sets angular span of this polar subplot with two angles (in degrees).","Sector are assumed to be spanned in the counterclockwise direction","with *0* corresponding to rightmost limit of the polar subplot."].join(" ")},hole:{valType:"number",min:0,max:1,dflt:0,editType:"plot",description:["Sets the fraction of the radius to cut out of the polar subplot."].join(" ")},bgcolor:{valType:"color",editType:"plot",dflt:n.background,description:"Set the background color of the subplot"},radialaxis:u,angularaxis:d,gridshape:{valType:"enumerated",values:["circular","linear"],dflt:"circular",editType:"plot",description:["Determines if the radial axis grid lines and angular axis line are drawn","as *circular* sectors or as *linear* (polygon) sectors.","Has an effect only when the angular axis has `type` *category*.","Note that `radialaxis.angle` is snapped to the angle of the closest","vertex when `gridshape` is *circular*","(so that radial axis scale is the same as the data scale)."].join(" ")},uirevision:{valType:"any",editType:"none",description:["Controls persistence of user-driven changes in axis attributes,","if not overridden in the individual axes.","Defaults to `layout.uirevision`."].join(" ")},editType:"calc"}},15997:(e,t,r)=>{"use strict";var n=r(84468),i=r(7605),o=r(37091),a=r(54883),s=r(50246).KO,l=r(43452),c=r(3118),u=r(83193),d=r(89655),h=r(74128),p=r(40190),f=r(87832),m=r(84339),g=r(35882),y=r(82880),v=r(28261),x=v.axisNames;function b(e,t,r,a){var m=r("bgcolor");a.bgColor=i.combine(m,a.paper_bgcolor);var b=r("sector");r("hole");var w,k=s(a.fullData,v.name,a.id),S=a.layoutOut;function A(e,t){return r(w+"."+e,t)}for(var T=0;T{"use strict";var n=r(41871),i=r(23498),o=r(38361),a=r(84468),s=a.strRotate,l=a.strTranslate,c=r(7605),u=r(3172),d=r(68543),h=r(85729),p=r(45958),f=r(82880),m=r(49618).doAutoRange,g=r(15133),y=r(25732),v=r(32212),x=r(13701),b=r(76789).prepSelect,_=r(76789).selectOnClick,w=r(76789).clearOutline,k=r(29454),S=r(76574),A=r(88470).redrawReglTraces,T=r(83943).MID_SHIFT,M=r(28261),C=r(81453),E=r(52266),I=E.smith,P=E.reactanceArc,O=E.resistanceArc,R=E.smithTransform,L=a._,D=a.mod,z=a.deg2rad,j=a.rad2deg;function F(e,t,r){this.isSmith=r||!1,this.id=t,this.gd=e,this._hasClipOnAxisFalse=null,this.vangles=null,this.radialAxisAngle=null,this.traceHash={},this.layers={},this.clipPaths={},this.clipIds={},this.viewInitial={};var n=e._fullLayout,i="clip"+n._uid+t;this.clipIds.forTraces=i+"-for-traces",this.clipPaths.forTraces=n._clips.append("clipPath").attr("id",this.clipIds.forTraces),this.clipPaths.forTraces.append("path"),this.framework=n["_"+(r?"smith":"polar")+"layer"].append("g").attr("class",t),this.getHole=function(e){return this.isSmith?0:e.hole},this.getSector=function(e){return this.isSmith?[0,360]:e.sector},this.getRadial=function(e){return this.isSmith?e.realaxis:e.radialaxis},this.getAngular=function(e){return this.isSmith?e.imaginaryaxis:e.angularaxis},r||(this.radialTickLayout=null,this.angularTickLayout=null)}var N=F.prototype;function B(e){var t=e.ticks+String(e.ticklen)+String(e.showticklabels);return"side"in e&&(t+=e.side),t}function V(e,t){return t[a.findIndexOfMin(t,(function(t){return a.angleDist(e,t)}))]}function U(e,t,r){return t?(e.attr("display",null),e.attr(r)):e&&e.attr("display","none"),e}e.exports=function(e,t,r){return new F(e,t,r)},N.plot=function(e,t){for(var r=this,n=t[r.id],i=!1,o=0;o=90||l>90&&c>=450?1:d<=0&&p<=0?0:Math.max(d,p);t=l<=180&&c>=180||l>180&&c>=540?-1:u>=0&&h>=0?0:Math.min(u,h);r=l<=270&&c>=270||l>270&&c>=630?-1:d>=0&&p>=0?0:Math.min(d,p);n=c>=360?1:u<=0&&h<=0?0:Math.max(u,h);return[t,r,n,i]}(f),_=b[2]-b[0],w=b[3]-b[1],k=p/h,S=Math.abs(w/_);k>S?(m=h,x=(p-(g=h*S))/i.h/2,y=[s[0],s[1]],v=[d[0]+x,d[1]-x]):(g=p,x=(h-(m=p/S))/i.w/2,y=[s[0]+x,s[1]-x],v=[d[0],d[1]]),r.xLength2=m,r.yLength2=g,r.xDomain2=y,r.yDomain2=v;var A,T=r.xOffset2=i.l+i.w*y[0],M=r.yOffset2=i.t+i.h*(1-v[1]),C=r.radius=m/_,E=r.innerRadius=r.getHole(t)*C,I=r.cx=T-C*b[0],P=r.cy=M+C*b[3],O=r.cxx=I-T,R=r.cyy=P-M,L=o.side;"counterclockwise"===L?(A=L,L="top"):"clockwise"===L&&(A=L,L="bottom"),r.radialAxis=r.mockAxis(e,t,o,{_id:"x",side:L,_trueSide:A,domain:[E/i.w,C/i.w]}),r.angularAxis=r.mockAxis(e,t,a,{side:"right",domain:[0,Math.PI],autorange:!1}),r.doAutoRange(e,t),r.updateAngularAxis(e,t),r.updateRadialAxis(e,t),r.updateRadialAxisTitle(e,t),r.xaxis=r.mockCartesianAxis(e,t,{_id:"x",domain:y}),r.yaxis=r.mockCartesianAxis(e,t,{_id:"y",domain:v});var j=r.pathSubplot();r.clipPaths.forTraces.select("path").attr("d",j).attr("transform",l(O,R)),n.frontplot.attr("transform",l(T,M)).call(u.setClipUrl,r._hasClipOnAxisFalse?null:r.clipIds.forTraces,r.gd),n.bg.attr("d",j).attr("transform",l(I,P)).call(c.fill,t.bgcolor)},N.mockAxis=function(e,t,r,n){var i=a.extendFlat({},r,n);return f(i,t,e),i},N.mockCartesianAxis=function(e,t,r){var n=this,i=n.isSmith,o=r._id,s=a.extendFlat({type:"linear"},r);p(s,e);var l={x:[0,2],y:[1,3]};return s.setRange=function(){var e=n.sectorBBox,r=l[o],i=n.radialAxis._rl,a=(i[1]-i[0])/(1-n.getHole(t));s.range=[e[r[0]]*a,e[r[1]]*a]},s.isPtWithinRange="x"!==o||i?function(){return!0}:function(e){return n.isPtInside(e)},s.setRange(),s.setScale(),s},N.doAutoRange=function(e,t){var r=this,n=r.gd,i=r.radialAxis,o=r.getRadial(t);m(n,i);var a=i.range;if(o.range=a.slice(),o._input.range=a.slice(),i._rl=[i.r2l(a[0],null,"gregorian"),i.r2l(a[1],null,"gregorian")],void 0!==i.minallowed){var s=i.r2l(i.minallowed);i._rl[0]>i._rl[1]?i._rl[1]=Math.max(i._rl[1],s):i._rl[0]=Math.max(i._rl[0],s)}if(void 0!==i.maxallowed){var l=i.r2l(i.maxallowed);i._rl[0]90&&m<=270&&(g.tickangle=180);var x=v?function(e){var t=R(r,I([e.x,0]));return l(t[0]-d,t[1]-p)}:function(e){return l(g.l2p(e.x)+u,0)},b=v?function(e){return O(r,e.x,-1/0,1/0)}:function(e){return r.pathArc(g.r2p(e.x)+u)},_=B(f);if(r.radialTickLayout!==_&&(i["radial-axis"].selectAll(".xtick").remove(),r.radialTickLayout=_),y){g.setScale();var w=0,k=v?(g.tickvals||[]).filter((function(e){return e>=0})).map((function(e){return h.tickText(g,e,!0,!1)})):h.calcTicks(g),S=v?k:h.clipEnds(g,k),A=h.getTickSigns(g)[2];v&&(("top"===g.ticks&&"bottom"===g.side||"bottom"===g.ticks&&"top"===g.side)&&(A=-A),"top"===g.ticks&&"top"===g.side&&(w=-g.ticklen),"bottom"===g.ticks&&"bottom"===g.side&&(w=g.ticklen)),h.drawTicks(n,g,{vals:k,layer:i["radial-axis"],path:h.makeTickPath(g,0,A),transFn:x,crisp:!1}),h.drawGrid(n,g,{vals:S,layer:i["radial-grid"],path:b,transFn:a.noop,crisp:!1}),h.drawLabels(n,g,{vals:k,layer:i["radial-axis"],transFn:x,labelFns:h.makeLabelFns(g,w)})}var T=r.radialAxisAngle=r.vangles?j(V(z(f.angle),r.vangles)):f.angle,M=l(d,p),C=M+s(-T);U(i["radial-axis"],y&&(f.showticklabels||f.ticks),{transform:C}),U(i["radial-grid"],y&&f.showgrid,{transform:v?"":M}),U(i["radial-line"].select("line"),y&&f.showline,{x1:v?-o:u,y1:0,x2:o,y2:0,transform:C}).attr("stroke-width",f.linewidth).call(c.stroke,f.linecolor)},N.updateRadialAxisTitle=function(e,t,r){if(!this.isSmith){var n=this,i=n.gd,o=n.radius,a=n.cx,s=n.cy,l=n.getRadial(t),c=n.id+"title",d=0;if(l.title){var h=u.bBox(n.layers["radial-axis"].node()).height,p=l.title.font.size,f=l.side;d="top"===f?p:"counterclockwise"===f?-(h+.4*p):h+.8*p}var m=void 0!==r?r:n.radialAxisAngle,g=z(m),y=Math.cos(g),v=Math.sin(g),b=a+o/2*y+d*v,_=s-o/2*v+d*y;n.layers["radial-axis-title"]=x.draw(i,c,{propContainer:l,propName:n.id+".radialaxis.title",placeholder:L(i,"Click to enter radial axis title"),attributes:{x:b,y:_,"text-anchor":"middle"},transform:{rotate:-m}})}},N.updateAngularAxis=function(e,t){var r=this,n=r.gd,i=r.layers,o=r.radius,u=r.innerRadius,d=r.cx,p=r.cy,f=r.getAngular(t),m=r.angularAxis,g=r.isSmith;g||(r.fillViewInitialKey("angularaxis.rotation",f.rotation),m.setGeometry(),m.setScale());var y=g?function(e){var t=R(r,I([0,e.x]));return Math.atan2(t[0]-d,t[1]-p)-Math.PI/2}:function(e){return m.t2g(e.x)};"linear"===m.type&&"radians"===m.thetaunit&&(m.tick0=j(m.tick0),m.dtick=j(m.dtick));var v=function(e){return l(d+o*Math.cos(e),p-o*Math.sin(e))},x=g?function(e){var t=R(r,I([0,e.x]));return l(t[0],t[1])}:function(e){return v(y(e))},b=g?function(e){var t=R(r,I([0,e.x])),n=Math.atan2(t[0]-d,t[1]-p)-Math.PI/2;return l(t[0],t[1])+s(-j(n))}:function(e){var t=y(e);return v(t)+s(-j(t))},_=g?function(e){return P(r,e.x,0,1/0)}:function(e){var t=y(e),r=Math.cos(t),n=Math.sin(t);return"M"+[d+u*r,p-u*n]+"L"+[d+o*r,p-o*n]},w=h.makeLabelFns(m,0).labelStandoff,k={xFn:function(e){var t=y(e);return Math.cos(t)*w},yFn:function(e){var t=y(e),r=Math.sin(t)>0?.2:1;return-Math.sin(t)*(w+e.fontSize*r)+Math.abs(Math.cos(t))*(e.fontSize*T)},anchorFn:function(e){var t=y(e),r=Math.cos(t);return Math.abs(r)<.1?"middle":r>0?"start":"end"},heightFn:function(e,t,r){var n=y(e);return-.5*(1+Math.sin(n))*r}},S=B(f);r.angularTickLayout!==S&&(i["angular-axis"].selectAll("."+m._id+"tick").remove(),r.angularTickLayout=S);var A,M=g?[1/0].concat(m.tickvals||[]).map((function(e){return h.tickText(m,e,!0,!1)})):h.calcTicks(m);if(g&&(M[0].text="\u221e",M[0].fontSize*=1.75),"linear"===t.gridshape?(A=M.map(y),a.angleDelta(A[0],A[1])<0&&(A=A.slice().reverse())):A=null,r.vangles=A,"category"===m.type&&(M=M.filter((function(e){return a.isAngleInsideSector(y(e),r.sectorInRad)}))),m.visible){var C="inside"===m.ticks?-1:1,E=(m.linewidth||1)/2;h.drawTicks(n,m,{vals:M,layer:i["angular-axis"],path:"M"+C*E+",0h"+C*m.ticklen,transFn:b,crisp:!1}),h.drawGrid(n,m,{vals:M,layer:i["angular-grid"],path:_,transFn:a.noop,crisp:!1}),h.drawLabels(n,m,{vals:M,layer:i["angular-axis"],repositionOnUpdate:!0,transFn:x,labelFns:k})}U(i["angular-line"].select("path"),f.showline,{d:r.pathSubplot(),transform:l(d,p)}).attr("stroke-width",f.linewidth).call(c.stroke,f.linecolor)},N.updateFx=function(e,t){this.gd._context.staticPlot||(!this.isSmith&&(this.updateAngularDrag(e),this.updateRadialDrag(e,t,0),this.updateRadialDrag(e,t,1)),this.updateHoverAndMainDrag(e))},N.updateHoverAndMainDrag=function(e){var t,r,s=this,c=s.isSmith,u=s.gd,d=s.layers,h=e._zoomlayer,p=M.MINZOOM,f=M.OFFEDGE,m=s.radius,x=s.innerRadius,k=s.cx,S=s.cy,A=s.cxx,T=s.cyy,E=s.sectorInRad,I=s.vangles,P=s.radialAxis,O=C.clampTiny,R=C.findXYatLength,L=C.findEnclosingVertexAngles,D=M.cornerHalfWidth,z=M.cornerLen/2,j=g.makeDragger(d,"path","maindrag",!1===e.dragmode?"none":"crosshair");n.select(j).attr("d",s.pathSubplot()).attr("transform",l(k,S)),j.onmousemove=function(e){v.hover(u,e,s.id),u._fullLayout._lasthover=j,u._fullLayout._hoversubplot=s.id},j.onmouseout=function(e){u._dragging||y.unhover(u,e)};var F,N,B,V,U,H,$,W,q,G={element:j,gd:u,subplot:s.id,plotinfo:{id:s.id,xaxis:s.xaxis,yaxis:s.yaxis},xaxes:[s.xaxis],yaxes:[s.yaxis]};function Y(e,t){return Math.sqrt(e*e+t*t)}function X(e,t){return Y(e-A,t-T)}function Z(e,t){return Math.atan2(T-t,e-A)}function K(e,t){return[e*Math.cos(t),e*Math.sin(-t)]}function J(e,t){if(0===e)return s.pathSector(2*D);var r=z/e,n=t-r,i=t+r,o=Math.max(0,Math.min(e,m)),a=o-D,l=o+D;return"M"+K(a,n)+"A"+[a,a]+" 0,0,0 "+K(a,i)+"L"+K(l,i)+"A"+[l,l]+" 0,0,1 "+K(l,n)+"Z"}function Q(e,t,r){if(0===e)return s.pathSector(2*D);var n,i,o=K(e,t),a=K(e,r),l=O((o[0]+a[0])/2),c=O((o[1]+a[1])/2);if(l&&c){var u=c/l,d=-1/u,h=R(D,u,l,c);n=R(z,d,h[0][0],h[0][1]),i=R(z,d,h[1][0],h[1][1])}else{var p,f;c?(p=z,f=D):(p=D,f=z),n=[[l-p,c-f],[l+p,c-f]],i=[[l-p,c+f],[l+p,c+f]]}return"M"+n.join("L")+"L"+i.reverse().join("L")+"Z"}function ee(e,t){return t=Math.max(Math.min(t,m),x),ep?(e-1&&1===e&&_(t,u,[s.xaxis],[s.yaxis],s.id,G),r.indexOf("event")>-1&&v.click(u,t,s.id)}G.prepFn=function(e,n,o){var l=u._fullLayout.dragmode,d=j.getBoundingClientRect();u._fullLayout._calcInverseTransform(u);var p=u._fullLayout._invTransform;t=u._fullLayout._invScaleX,r=u._fullLayout._invScaleY;var f=a.apply3DTransform(p)(n-d.left,o-d.top);if(F=f[0],N=f[1],I){var y=C.findPolygonOffset(m,E[0],E[1],I);F+=A+y[0],N+=T+y[1]}switch(l){case"zoom":G.clickFn=se,c||(G.moveFn=I?ie:re,G.doneFn=oe,function(){B=null,V=null,U=s.pathSubplot(),H=!1;var e=u._fullLayout[s.id];$=i(e.bgcolor).getLuminance(),(W=g.makeZoombox(h,$,k,S,U)).attr("fill-rule","evenodd"),q=g.makeCorners(h,k,S),w(u)}());break;case"select":case"lasso":b(e,n,o,G,l)}},y.init(G)},N.updateRadialDrag=function(e,t,r){var i=this,c=i.gd,u=i.layers,d=i.radius,h=i.innerRadius,p=i.cx,f=i.cy,m=i.radialAxis,v=M.radialDragBoxSize,x=v/2;if(m.visible){var b,_,k,T=z(i.radialAxisAngle),C=m._rl,E=C[0],I=C[1],P=C[r],O=.75*(C[1]-C[0])/(1-i.getHole(t))/d;r?(b=p+(d+x)*Math.cos(T),_=f-(d+x)*Math.sin(T),k="radialdrag"):(b=p+(h-x)*Math.cos(T),_=f-(h-x)*Math.sin(T),k="radialdrag-inner");var R,L,D,F=g.makeRectDragger(u,k,"crosshair",-x,-x,v,v),N={element:F,gd:c};!1===e.dragmode&&(N.dragmode=!1),U(n.select(F),m.visible&&h0===(r?D>E:D{"use strict";var n=r(84468),i=r(45958),o=n.deg2rad,a=n.rad2deg;e.exports=function(e,t,r){switch(i(e,r),e._id){case"x":case"radialaxis":!function(e,t){var r=t._subplot;e.setGeometry=function(){var t=e._rl[0],n=e._rl[1],i=r.innerRadius,o=(r.radius-i)/(n-t),a=i/o,s=t>n?function(e){return e<=0}:function(e){return e>=0};e.c2g=function(r){var n=e.c2l(r)-t;return(s(n)?n:0)+a},e.g2c=function(r){return e.l2c(r+t-a)},e.g2p=function(e){return e*o},e.c2p=function(t){return e.g2p(e.c2g(t))}}}(e,t);break;case"angularaxis":!function(e,t){var r=e.type;if("linear"===r){var i=e.d2c,s=e.c2d;e.d2c=function(e,t){return function(e,t){return"degrees"===t?o(e):e}(i(e),t)},e.c2d=function(e,t){return s(function(e,t){return"degrees"===t?a(e):e}(e,t))}}e.makeCalcdata=function(t,r){var n,i,o=t[r],a=t._length,s=function(r){return e.d2c(r,t.thetaunit)};if(o)for(n=new Array(a),i=0;i{"use strict";e.exports={attr:"subplot",name:"smith",axisNames:["realaxis","imaginaryaxis"],axisName2dataArray:{imaginaryaxis:"imag",realaxis:"real"}}},52266:e=>{"use strict";function t(e){return e<0?-1:e>0?1:0}function r(e){var t=e[0],r=e[1];if(!isFinite(t)||!isFinite(r))return[1,0];var n=(t+1)*(t+1)+r*r;return[(t*t+r*r-1)/n,2*r/n]}function n(e,t){var r=t[0],n=t[1];return[r*e.radius+e.cx,-n*e.radius+e.cy]}function i(e,t){return t*e.radius}e.exports={smith:r,reactanceArc:function(e,t,o,a){var s=n(e,r([o,t])),l=s[0],c=s[1],u=n(e,r([a,t])),d=u[0],h=u[1];if(0===t)return["M"+l+","+c,"L"+d+","+h].join(" ");var p=i(e,1/Math.abs(t));return["M"+l+","+c,"A"+p+","+p+" 0 0,"+(t<0?1:0)+" "+d+","+h].join(" ")},resistanceArc:function(e,o,a,s){var l=i(e,1/(o+1)),c=n(e,r([o,a])),u=c[0],d=c[1],h=n(e,r([o,s])),p=h[0],f=h[1];if(t(a)!==t(s)){var m=n(e,r([o,0]));return["M"+u+","+d,"A"+l+","+l+" 0 0,"+(0{"use strict";var n=r(50246).fX,i=r(84468).counterRegex,o=r(74908),a=r(28958),s=a.attr,l=a.name,c=i(l),u={};u[s]={valType:"subplotid",dflt:l,editType:"calc",description:["Sets a reference between this trace's data coordinates and","a smith subplot.","If *smith* (the default value), the data refer to `layout.smith`.","If *smith2*, the data refer to `layout.smith2`, and so on."].join(" ")},e.exports={attr:s,name:l,idRoot:l,idRegex:c,attrRegex:c,attributes:u,layoutAttributes:r(39473),supplyLayoutDefaults:r(41686),plot:function(e){for(var t=e._fullLayout,r=e.calcdata,i=t._subplots[l],a=0;a{"use strict";var n=r(17992),i=r(49080),o=r(81159).u,a=r(84468).extendFlat,s=r(72587).overrideAll,l=s({color:i.color,showline:a({},i.showline,{dflt:!0}),linecolor:i.linecolor,linewidth:i.linewidth,showgrid:a({},i.showgrid,{dflt:!0}),gridcolor:i.gridcolor,gridwidth:i.gridwidth,griddash:i.griddash},"plot","from-root"),c=s({ticklen:i.ticklen,tickwidth:a({},i.tickwidth,{dflt:2}),tickcolor:i.tickcolor,showticklabels:i.showticklabels,labelalias:i.labelalias,showtickprefix:i.showtickprefix,tickprefix:i.tickprefix,showticksuffix:i.showticksuffix,ticksuffix:i.ticksuffix,tickfont:i.tickfont,tickformat:i.tickformat,hoverformat:i.hoverformat,layer:i.layer},"plot","from-root"),u=a({visible:a({},i.visible,{dflt:!0}),tickvals:{dflt:[.2,.5,1,2,5],valType:"data_array",editType:"plot",description:"Sets the values at which ticks on this axis appear."},tickangle:a({},i.tickangle,{dflt:90}),ticks:{valType:"enumerated",values:["top","bottom",""],editType:"ticks",description:["Determines whether ticks are drawn or not.","If **, this axis' ticks are not drawn.","If *top* (*bottom*), this axis' are drawn above (below)","the axis line."].join(" ")},side:{valType:"enumerated",values:["top","bottom"],dflt:"top",editType:"plot",description:["Determines on which side of real axis line","the tick and tick labels appear."].join(" ")},editType:"calc"},l,c),d=a({visible:a({},i.visible,{dflt:!0}),tickvals:{valType:"data_array",editType:"plot",description:["Sets the values at which ticks on this axis appear.","Defaults to `realaxis.tickvals` plus the same as negatives and zero."].join(" ")},ticks:i.ticks,editType:"calc"},l,c);e.exports={domain:o({name:"smith",editType:"plot"}),bgcolor:{valType:"color",editType:"plot",dflt:n.background,description:"Set the background color of the subplot"},realaxis:u,imaginaryaxis:d,editType:"calc"}},41686:(e,t,r)=>{"use strict";var n=r(84468),i=r(7605),o=r(37091),a=r(54883),s=r(50246).KO,l=r(89655),c=r(83193),u=r(40190),d=r(45958),h=r(39473),p=r(28958),f=p.axisNames,m=function(e,t){var r={};return function(n){var i=t?t(n):n;if(i in r)return r[i];var o=e(n);return r[i]=o,o}}((function(e){return n.isTypedArray(e)&&(e=Array.from(e)),e.slice().reverse().map((function(e){return-e})).concat([0]).concat(e)}),String);function g(e,t,r,a){var g=r("bgcolor");a.bgColor=i.combine(g,a.paper_bgcolor);var y,v=s(a.fullData,p.name,a.id),x=a.layoutOut;function b(e,t){return r(y+"."+e,t)}for(var _=0;_{"use strict";var n=r(84468),i=r(37091),o=r(81159).N;e.exports=function(e,t,r,a){var s,l,c=a.type,u=a.attributes,d=a.handleDefaults,h=a.partition||"x",p=t._subplots[c],f=p.length,m=f&&p[0].replace(/\d+$/,"");function g(e,t){return n.coerce(s,l,u,e,t)}for(var y=0;y{"use strict";var n=r(3127),i=n.FORMAT_LINK,o=n.DATE_FORMAT_LINK;function a(e){return["Variables are inserted using %{variable},",'for example "y: %{y}"'+(e&&e.supportOther?" as well as %{xother}, {%_xother}, {%_xother_}, {%xother_}. When showing info for several points, *xother* will be added to those with different x positions from the first point. An underscore before or after *(x|y)other* will add a space on that side, only when this field is shown.":"."),'Numbers are formatted using d3-format\'s syntax %{variable:d3-format}, for example "Price: %{y:$.2f}".',i,"for details on the formatting syntax.",'Dates are formatted using d3-time-format\'s syntax %{variable|d3-time-format}, for example "Day: %{2019-01-01|%A}".',o,"for details on the date formatting syntax."].join(" ")}function s(e){var t=e.description?" "+e.description:"",r=e.keys||[];if(r.length>0){for(var n=[],i=0;i` is displayed in the secondary box, for example "{fullData.name}".',"To hide the secondary box completely, use an empty tag ``."].join(" ")};return!1!==e.arrayOk&&(n.arrayOk=!0),n},t.ay=function(e,t){e=e||{};var r=s(t=t||{}),n={valType:"string",dflt:"",editType:e.editType||"calc",description:["Template string used for rendering the information text that appear on points.","Note that this will override `textinfo`.",a(),"Every attributes that can be specified per-point (the ones that are `arrayOk: true`) are available.",r].join(" ")};return!1!==e.arrayOk&&(n.arrayOk=!0),n},t.LF=function(e,t){t=t||{};var r=(e=e||{}).newshape?"new ":"",n=s(t);return{valType:"string",dflt:"",editType:e.editType||"arraydraw",description:["Template string used for rendering the "+r+"shape's label.","Note that this will override `text`.",["Variables are inserted using %{variable},",'for example "x0: %{x0}".','Numbers are formatted using d3-format\'s syntax %{variable:d3-format}, for example "Price: %{x0:$.2f}". See',i,"for details on the formatting syntax.",'Dates are formatted using d3-time-format\'s syntax %{variable|d3-time-format}, for example "Day: %{x0|%m %b %Y}". See',o,"for details on the date formatting syntax.","A single multiplication or division operation may be applied to numeric variables, and combined with",'d3 number formatting, for example "Length in cm: %{x0*2.54}", "%{slope*60:.1f} meters per second."',"For log axes, variable values are given in log units.","For date axes, x/y coordinate variables and center variables use datetimes, while all other variable values use values in ms."].join(" "),n].join(" ")}}},73859:(e,t,r)=>{"use strict";var n=r(2536),i=r(50246).fX,o=r(84468).counterRegex,a="ternary";t.name=a;var s=t.attr="subplot";t.idRoot=a,t.idRegex=t.attrRegex=o(a),(t.attributes={})[s]={valType:"subplotid",dflt:"ternary",editType:"calc",description:["Sets a reference between this trace's data coordinates and","a ternary subplot.","If *ternary* (the default value), the data refer to `layout.ternary`.","If *ternary2*, the data refer to `layout.ternary2`, and so on."].join(" ")},t.layoutAttributes=r(49273),t.supplyLayoutDefaults=r(41918),t.plot=function(e){for(var t=e._fullLayout,r=e.calcdata,o=t._subplots[a],s=0;s{"use strict";var n=r(17992),i=r(81159).u,o=r(49080),a=r(72587).overrideAll,s=r(64022).extendFlat,l={title:{text:o.title.text,font:o.title.font},color:o.color,tickmode:o.minor.tickmode,nticks:s({},o.nticks,{dflt:6,min:1}),tick0:o.tick0,dtick:o.dtick,tickvals:o.tickvals,ticktext:o.ticktext,ticks:o.ticks,ticklen:o.ticklen,tickwidth:o.tickwidth,tickcolor:o.tickcolor,ticklabelstep:o.ticklabelstep,showticklabels:o.showticklabels,labelalias:o.labelalias,showtickprefix:o.showtickprefix,tickprefix:o.tickprefix,showticksuffix:o.showticksuffix,ticksuffix:o.ticksuffix,showexponent:o.showexponent,exponentformat:o.exponentformat,minexponent:o.minexponent,separatethousands:o.separatethousands,tickfont:o.tickfont,tickangle:o.tickangle,tickformat:o.tickformat,tickformatstops:o.tickformatstops,hoverformat:o.hoverformat,showline:s({},o.showline,{dflt:!0}),linecolor:o.linecolor,linewidth:o.linewidth,showgrid:s({},o.showgrid,{dflt:!0}),gridcolor:o.gridcolor,gridwidth:o.gridwidth,griddash:o.griddash,layer:o.layer,min:{valType:"number",dflt:0,min:0,description:["The minimum value visible on this axis.","The maximum is determined by the sum minus the minimum","values of the other two axes. The full view corresponds to","all the minima set to zero."].join(" ")},_deprecated:{title:o._deprecated.title,titlefont:o._deprecated.titlefont}},c=e.exports=a({domain:i({name:"ternary"}),bgcolor:{valType:"color",dflt:n.background,description:"Set the background color of the subplot"},sum:{valType:"number",dflt:1,min:0,description:["The number each triplet should sum to,","and the maximum range of each axis"].join(" ")},aaxis:l,baxis:l,caxis:l},"plot","from-root");c.uirevision={valType:"any",editType:"none",description:["Controls persistence of user-driven changes in axis `min` and `title`,","if not overridden in the individual axes.","Defaults to `layout.uirevision`."].join(" ")},c.aaxis.uirevision=c.baxis.uirevision=c.caxis.uirevision={valType:"any",editType:"none",description:["Controls persistence of user-driven changes in axis `min`,","and `title` if in `editable: true` configuration.","Defaults to `ternary.uirevision`."].join(" ")}},41918:(e,t,r)=>{"use strict";var n=r(7605),i=r(37091),o=r(84468),a=r(54883),s=r(83193),l=r(89655),c=r(3118),u=r(43452),d=r(40190),h=r(49273),p=["aaxis","baxis","caxis"];function f(e,t,r,o){var a,s,l,c=r("bgcolor"),u=r("sum");o.bgColor=n.combine(c,o.paper_bgcolor);for(var d=0;d=u&&(h.min=0,f.min=0,g.min=0,e.aaxis&&delete e.aaxis.min,e.baxis&&delete e.baxis.min,e.caxis&&delete e.caxis.min)}function m(e,t,r,n){var i=h[t._name];function a(r,n){return o.coerce(e,t,i,r,n)}a("uirevision",n.uirevision),t.type="linear";var p=a("color"),f=p!==i.color.dflt?p:r.font.color,m=t._name.charAt(0).toUpperCase(),g="Component "+m,y=a("title.text",g);t._hovertitle=y===g?y:m,o.coerceFont(a,"title.font",r.font,{overrideDflt:{size:o.bigFont(r.font.size),color:f}}),a("min"),u(e,t,a,"linear"),l(e,t,a,"linear"),s(e,t,a,"linear",{noAutotickangles:!0,noTicklabelshift:!0,noTicklabelstandoff:!0}),c(e,t,a,{outerTicks:!0}),a("showticklabels")&&(o.coerceFont(a,"tickfont",r.font,{overrideDflt:{color:f}}),a("tickangle"),a("tickformat")),d(e,t,a,{dfltColor:p,bgColor:r.bgColor,blend:60,showLine:!0,showGrid:!0,noZeroLine:!0,attributes:i}),a("hoverformat"),a("layer")}e.exports=function(e,t,r){a(e,t,r,{type:"ternary",attributes:h,handleDefaults:f,font:t.font,paper_bgcolor:t.paper_bgcolor})}},2536:(e,t,r)=>{"use strict";var n=r(41871),i=r(23498),o=r(38361),a=r(84468),s=a.strTranslate,l=a._,c=r(7605),u=r(3172),d=r(45958),h=r(64022).extendFlat,p=r(68543),f=r(85729),m=r(25732),g=r(32212),y=r(2705),v=y.freeMode,x=y.rectMode,b=r(13701),_=r(76789).prepSelect,w=r(76789).selectOnClick,k=r(76789).clearOutline,S=r(76789).clearSelectionsCache,A=r(93143);function T(e,t){this.id=e.id,this.graphDiv=e.graphDiv,this.init(t),this.makeFramework(t),this.updateFx(t),this.aTickLayout=null,this.bTickLayout=null,this.cTickLayout=null}e.exports=T;var M=T.prototype;M.init=function(e){this.container=e._ternarylayer,this.defs=e._defs,this.layoutId=e._uid,this.traceHash={},this.layers={}},M.plot=function(e,t){var r=this,n=t[r.id],i=t._size;r._hasClipOnAxisFalse=!1;for(var o=0;oC*b?i=(o=b)*C:o=(i=x)/C,a=y*i/x,l=v*o/b,r=t.l+t.w*m-i/2,n=t.t+t.h*(1-g)-o/2,p.x0=r,p.y0=n,p.w=i,p.h=o,p.sum=_,p.xaxis={type:"linear",range:[w+2*S-_,_-w-2*k],domain:[m-a/2,m+a/2],_id:"x"},d(p.xaxis,p.graphDiv._fullLayout),p.xaxis.setScale(),p.xaxis.isPtWithinRange=function(e){return e.a>=p.aaxis.range[0]&&e.a<=p.aaxis.range[1]&&e.b>=p.baxis.range[1]&&e.b<=p.baxis.range[0]&&e.c>=p.caxis.range[1]&&e.c<=p.caxis.range[0]},p.yaxis={type:"linear",range:[w,_-k-S],domain:[g-l/2,g+l/2],_id:"y"},d(p.yaxis,p.graphDiv._fullLayout),p.yaxis.setScale(),p.yaxis.isPtWithinRange=function(){return!0};var A=p.yaxis.domain[0],T=p.aaxis=h({},e.aaxis,{range:[w,_-k-S],side:"left",tickangle:(+e.aaxis.tickangle||0)-30,domain:[A,A+l*C],anchor:"free",position:0,_id:"y",_length:i});d(T,p.graphDiv._fullLayout),T.setScale();var M=p.baxis=h({},e.baxis,{range:[_-w-S,k],side:"bottom",domain:p.xaxis.domain,anchor:"free",position:0,_id:"x",_length:i});d(M,p.graphDiv._fullLayout),M.setScale();var E=p.caxis=h({},e.caxis,{range:[_-w-k,S],side:"right",tickangle:(+e.caxis.tickangle||0)+30,domain:[A,A+l*C],anchor:"free",position:0,_id:"y",_length:i});d(E,p.graphDiv._fullLayout),E.setScale();var I="M"+r+","+(n+o)+"h"+i+"l-"+i/2+",-"+o+"Z";p.clipDef.select("path").attr("d",I),p.layers.plotbg.select("path").attr("d",I);var P="M0,"+o+"h"+i+"l-"+i/2+",-"+o+"Z";p.clipDefRelative.select("path").attr("d",P);var O=s(r,n);p.plotContainer.selectAll(".scatterlayer,.maplayer").attr("transform",O),p.clipDefRelative.select("path").attr("transform",null);var R=s(r-M._offset,n+o);p.layers.baxis.attr("transform",R),p.layers.bgrid.attr("transform",R);var L=s(r+i/2,n)+"rotate(30)"+s(0,-T._offset);p.layers.aaxis.attr("transform",L),p.layers.agrid.attr("transform",L);var D=s(r+i/2,n)+"rotate(-30)"+s(0,-E._offset);p.layers.caxis.attr("transform",D),p.layers.cgrid.attr("transform",D),p.drawAxes(!0),p.layers.aline.select("path").attr("d",T.showline?"M"+r+","+(n+o)+"l"+i/2+",-"+o:"M0,0").call(c.stroke,T.linecolor||"#000").style("stroke-width",(T.linewidth||0)+"px"),p.layers.bline.select("path").attr("d",M.showline?"M"+r+","+(n+o)+"h"+i:"M0,0").call(c.stroke,M.linecolor||"#000").style("stroke-width",(M.linewidth||0)+"px"),p.layers.cline.select("path").attr("d",E.showline?"M"+(r+i/2)+","+n+"l"+i/2+","+o:"M0,0").call(c.stroke,E.linecolor||"#000").style("stroke-width",(E.linewidth||0)+"px"),p.graphDiv._context.staticPlot||p.initInteractions(),u.setClipUrl(p.layers.frontplot,p._hasClipOnAxisFalse?null:p.clipId,p.graphDiv)},M.drawAxes=function(e){var t=this,r=t.graphDiv,n=t.id.substr(7)+"title",i=t.layers,o=t.aaxis,a=t.baxis,s=t.caxis;if(t.drawAx(o),t.drawAx(a),t.drawAx(s),e){var c=Math.max(o.showticklabels?o.tickfont.size/2:0,(s.showticklabels?.75*s.tickfont.size:0)+("outside"===s.ticks?.87*s.ticklen:0)),u=(a.showticklabels?a.tickfont.size:0)+("outside"===a.ticks?a.ticklen:0)+3;i["a-title"]=b.draw(r,"a"+n,{propContainer:o,propName:t.id+".aaxis.title",placeholder:l(r,"Click to enter Component A title"),attributes:{x:t.x0+t.w/2,y:t.y0-o.title.font.size/3-c,"text-anchor":"middle"}}),i["b-title"]=b.draw(r,"b"+n,{propContainer:a,propName:t.id+".baxis.title",placeholder:l(r,"Click to enter Component B title"),attributes:{x:t.x0-u,y:t.y0+t.h+.83*a.title.font.size+u,"text-anchor":"middle"}}),i["c-title"]=b.draw(r,"c"+n,{propContainer:s,propName:t.id+".caxis.title",placeholder:l(r,"Click to enter Component C title"),attributes:{x:t.x0+t.w+u,y:t.y0+t.h+.83*s.title.font.size+u,"text-anchor":"middle"}})}},M.drawAx=function(e){var t,r=this,n=r.graphDiv,i=e._name,o=i.charAt(0),s=e._id,l=r.layers[i],c=o+"tickLayout",u=(t=e).ticks+String(t.ticklen)+String(t.showticklabels);r[c]!==u&&(l.selectAll("."+s+"tick").remove(),r[c]=u),e.setScale();var d=f.calcTicks(e),h=f.clipEnds(e,d),p=f.makeTransTickFn(e),m=f.getTickSigns(e)[2],g=a.deg2rad(30),y=m*(e.linewidth||1)/2,v=m*e.ticklen,x=r.w,b=r.h,_="b"===o?"M0,"+y+"l"+Math.sin(g)*v+","+Math.cos(g)*v:"M"+y+",0l"+Math.cos(g)*v+","+-Math.sin(g)*v,w={a:"M0,0l"+b+",-"+x/2,b:"M0,0l-"+x/2+",-"+b,c:"M0,0l-"+b+","+x/2}[o];f.drawTicks(n,e,{vals:"inside"===e.ticks?h:d,layer:l,path:_,transFn:p,crisp:!1}),f.drawGrid(n,e,{vals:h,layer:r.layers[o+"grid"],path:w,transFn:p,crisp:!1}),f.drawLabels(n,e,{vals:d,layer:l,transFn:p,labelFns:f.makeLabelFns(e,0,30)})};var E=A.MINZOOM/2+.87,I="m-0.87,.5h"+E+"v3h-"+(E+5.2)+"l"+(E/2+2.6)+",-"+(.87*E+4.5)+"l2.6,1.5l-"+E/2+","+.87*E+"Z",P="m0.87,.5h-"+E+"v3h"+(E+5.2)+"l-"+(E/2+2.6)+",-"+(.87*E+4.5)+"l-2.6,1.5l"+E/2+","+.87*E+"Z",O="m0,1l"+E/2+","+.87*E+"l2.6,-1.5l-"+(E/2+2.6)+",-"+(.87*E+4.5)+"l-"+(E/2+2.6)+","+(.87*E+4.5)+"l2.6,1.5l"+E/2+",-"+.87*E+"Z",R=!0;function L(e){n.select(e).selectAll(".zoombox,.js-zoombox-backdrop,.js-zoombox-menu,.zoombox-corners").remove()}M.clearOutline=function(){S(this.dragOptions),k(this.dragOptions.gd)},M.initInteractions=function(){var e,t,r,n,d,h,p,f,y,b,k,S,T=this,M=T.layers.plotbg.select("path").node(),E=T.graphDiv,D=E._fullLayout._zoomlayer;function z(e){var t={};return t[T.id+".aaxis.min"]=e.a,t[T.id+".baxis.min"]=e.b,t[T.id+".caxis.min"]=e.c,t}function j(e,t){var r=E._fullLayout.clickmode;L(E),2===e&&(E.emit("plotly_doubleclick",null),o.call("_guiRelayout",E,z({a:0,b:0,c:0}))),r.indexOf("select")>-1&&1===e&&w(t,E,[T.xaxis],[T.yaxis],T.id,T.dragOptions),r.indexOf("event")>-1&&g.click(E,t,T.id)}function F(e,t){return 1-t/T.h}function N(e,t){return 1-(e+(T.h-t)/Math.sqrt(3))/T.w}function B(e,t){return(e-(T.h-t)/Math.sqrt(3))/T.w}function V(i,o){var a=r+i*e,s=n+o*t,l=Math.max(0,Math.min(1,F(0,n),F(0,s))),c=Math.max(0,Math.min(1,N(r,n),N(a,s))),u=Math.max(0,Math.min(1,B(r,n),B(a,s))),m=(l/2+u)*T.w,g=(1-l/2-c)*T.w,v=(m+g)/2,x=g-m,_=(1-l)*T.h,w=_-x/C;x.2?"rgba(0,0,0,0.4)":"rgba(255,255,255,0.3)").duration(200),S.transition().style("opacity",1).duration(200),b=!0),E.emit("plotly_relayouting",z(p))}function U(){L(E),p!==d&&(o.call("_guiRelayout",E,z(p)),R&&E.data&&E._context.showTips&&(a.notifier(l(E,"Double-click to zoom back out"),"long"),R=!1))}function H(e,t){var r=e/T.xaxis._m,n=t/T.yaxis._m,i=[(p={a:d.a-n,b:d.b+(r+n)/2,c:d.c-(r-n)/2}).a,p.b,p.c].sort(a.sorterAsc),o=i.indexOf(p.a),l=i.indexOf(p.b),c=i.indexOf(p.c);i[0]<0&&(i[1]+i[0]/2<0?(i[2]+=i[0]+i[1],i[0]=i[1]=0):(i[2]+=i[0]/2,i[1]+=i[0]/2,i[0]=0),p={a:i[o],b:i[l],c:i[c]},t=(d.a-p.a)*T.yaxis._m,e=(d.c-p.c-d.b+p.b)*T.xaxis._m);var h=s(T.x0+e,T.y0+t);T.plotContainer.selectAll(".scatterlayer,.maplayer").attr("transform",h);var f=s(-e,-t);T.clipDefRelative.select("path").attr("transform",f),T.aaxis.range=[p.a,T.sum-p.b-p.c],T.baxis.range=[T.sum-p.a-p.c,p.b],T.caxis.range=[T.sum-p.a-p.b,p.c],T.drawAxes(!1),T._hasClipOnAxisFalse&&T.plotContainer.select(".scatterlayer").selectAll(".trace").call(u.hideOutsideRangePoints,T),E.emit("plotly_relayouting",z(p))}function $(){o.call("_guiRelayout",E,z(p))}this.dragOptions={element:M,gd:E,plotinfo:{id:T.id,domain:E._fullLayout[T.id].domain,xaxis:T.xaxis,yaxis:T.yaxis},subplot:T.id,prepFn:function(o,l,u){T.dragOptions.xaxes=[T.xaxis],T.dragOptions.yaxes=[T.yaxis],e=E._fullLayout._invScaleX,t=E._fullLayout._invScaleY;var m=T.dragOptions.dragmode=E._fullLayout.dragmode;v(m)?T.dragOptions.minDrag=1:T.dragOptions.minDrag=void 0,"zoom"===m?(T.dragOptions.moveFn=V,T.dragOptions.clickFn=j,T.dragOptions.doneFn=U,function(e,t,o){var l=M.getBoundingClientRect();r=t-l.left,n=o-l.top,E._fullLayout._calcInverseTransform(E);var u=E._fullLayout._invTransform,m=a.apply3DTransform(u)(r,n);r=m[0],n=m[1],d={a:T.aaxis.range[0],b:T.baxis.range[1],c:T.caxis.range[1]},p=d,h=T.aaxis.range[1]-d.a,f=i(T.graphDiv._fullLayout[T.id].bgcolor).getLuminance(),y="M0,"+T.h+"L"+T.w/2+", 0L"+T.w+","+T.h+"Z",b=!1,k=D.append("path").attr("class","zoombox").attr("transform",s(T.x0,T.y0)).style({fill:f>.2?"rgba(0,0,0,0)":"rgba(255,255,255,0)","stroke-width":0}).attr("d",y),S=D.append("path").attr("class","zoombox-corners").attr("transform",s(T.x0,T.y0)).style({fill:c.background,stroke:c.defaultLine,"stroke-width":1,opacity:0}).attr("d","M0,0Z"),T.clearOutline(E)}(0,l,u)):"pan"===m?(T.dragOptions.moveFn=H,T.dragOptions.clickFn=j,T.dragOptions.doneFn=$,d={a:T.aaxis.range[0],b:T.baxis.range[1],c:T.caxis.range[1]},p=d,T.clearOutline(E)):(x(m)||v(m))&&_(o,l,u,T.dragOptions,m)}},M.onmousemove=function(e){g.hover(E,e,T.id),E._fullLayout._lasthover=M,E._fullLayout._hoversubplot=T.id},M.onmouseout=function(e){E._dragging||m.unhover(E,e)},m.init(this.dragOptions)}},38361:(e,t,r)=>{"use strict";var n=r(98073),i=r(17266),o=r(52942),a=r(30167),s=r(51124).addStyleRule,l=r(64022),c=r(75622),u=r(98005),d=l.extendFlat,h=l.extendDeepAll;function p(e){var i=e.name,o=e.categories,a=e.meta;if(t.modules[i])n.log("Type "+i+" already registered");else{t.subplotsRegistry[e.basePlotModule.name]||function(e){var r=e.name;if(t.subplotsRegistry[r])return void n.log("Plot type "+r+" already registered.");for(var i in y(e),t.subplotsRegistry[r]=e,t.componentsRegistry)b(i,e.name)}(e.basePlotModule);for(var l={},c=0;c{"use strict";var n=r(38361),i=r(84468),o=i.extendFlat,a=i.extendDeep;function s(e){var t;switch(e){case"themes__thumb":t={autosize:!0,width:150,height:150,title:{text:""},showlegend:!1,margin:{l:5,r:5,t:5,b:5,pad:0},annotations:[]};break;case"thumbnail":t={title:{text:""},hidesources:!0,showlegend:!1,borderwidth:0,bordercolor:"",margin:{l:1,r:1,t:1,b:1,pad:0},annotations:[]};break;default:t={}}return t}e.exports=function(e,t){var r,i,l=e.data,c=e.layout,u=a([],l),d=a({},c,s(t.tileClass)),h=e._context||{};if(t.width&&(d.width=t.width),t.height&&(d.height=t.height),"thumbnail"===t.tileClass||"themes__thumb"===t.tileClass){d.annotations=[];var p=Object.keys(d);for(r=0;r-1&&(d[p[r]].title={text:""});for(r=0;r{"use strict";var n=r(84468),i=r(81530),o=r(6878),a=r(5240);e.exports=function(e,t){var r;return n.isPlainObject(e)||(r=n.getGraphDiv(e)),(t=t||{}).format=t.format||"png",t.width=t.width||null,t.height=t.height||null,t.imageDataOnly=!0,new Promise((function(s,l){r&&r._snapshotInProgress&&l(new Error("Snapshotting already in progress.")),n.isIE()&&"svg"!==t.format&&l(new Error(a.MSG_IE_BAD_FORMAT)),r&&(r._snapshotInProgress=!0);var c=i(e,t),u=t.filename||e.fn||"newplot";u+="."+t.format.replace("-","."),c.then((function(e){return r&&(r._snapshotInProgress=!1),o(e,u,t.format)})).then((function(e){s(e)})).catch((function(e){r&&(r._snapshotInProgress=!1),l(e)}))}))}},6878:(e,t,r)=>{"use strict";var n=r(84468),i=r(5240);e.exports=function(e,t,r){var o=document.createElement("a"),a="download"in o;return new Promise((function(s,l){var c,u;if(n.isIE())return c=i.createBlob(e,"svg"),window.navigator.msSaveBlob(c,t),c=null,s(t);if(a)return c=i.createBlob(e,r),u=i.createObjectURL(c),o.href=u,o.download=t,document.body.appendChild(o),o.click(),document.body.removeChild(o),i.revokeObjectURL(u),c=null,s(t);if(n.isSafari()){var d="svg"===r?",":";base64,";return i.octetStream(d+encodeURIComponent(e)),s(t)}l(new Error("download error"))}))}},5240:(e,t,r)=>{"use strict";var n=r(38361);t.getDelay=function(e){return e._has&&(e._has("gl3d")||e._has("gl2d")||e._has("mapbox")||e._has("map"))?500:0},t.getRedrawFunc=function(e){return function(){n.getComponentMethod("colorbar","draw")(e)}},t.encodeSVG=function(e){return"data:image/svg+xml,"+encodeURIComponent(e)},t.encodeJSON=function(e){return"data:application/json,"+encodeURIComponent(e)};var i=window.URL||window.webkitURL;t.createObjectURL=function(e){return i.createObjectURL(e)},t.revokeObjectURL=function(e){return i.revokeObjectURL(e)},t.createBlob=function(e,t){if("svg"===t)return new window.Blob([e],{type:"image/svg+xml;charset=utf-8"});if("full-json"===t)return new window.Blob([e],{type:"application/json;charset=utf-8"});var r=function(e){for(var t=e.length,r=new ArrayBuffer(t),n=new Uint8Array(r),i=0;i{"use strict";var n=r(5240),i={getDelay:n.getDelay,getRedrawFunc:n.getRedrawFunc,clone:r(24451),toSVG:r(85916),svgToImg:r(69939),toImage:r(35375),downloadImage:r(52593)};e.exports=i},69939:(e,t,r)=>{"use strict";var n=r(84468),i=r(27284).EventEmitter,o=r(5240);e.exports=function(e){var t=e.emitter||new i,r=new Promise((function(i,a){var s=window.Image,l=e.svg,c=e.format||"png";if(n.isIE()&&"svg"!==c){var u=new Error(o.MSG_IE_BAD_FORMAT);return a(u),e.promise?r:t.emit("error",u)}var d,h,p=e.canvas,f=e.scale||1,m=e.width||300,g=e.height||150,y=f*m,v=f*g,x=p.getContext("2d",{willReadFrequently:!0}),b=new s;"svg"===c||n.isSafari()?h=o.encodeSVG(l):(d=o.createBlob(l,"svg"),h=o.createObjectURL(d)),p.width=y,p.height=v,b.onload=function(){var r;switch(d=null,o.revokeObjectURL(h),"svg"!==c&&x.drawImage(b,0,0,y,v),c){case"jpeg":r=p.toDataURL("image/jpeg");break;case"png":r=p.toDataURL("image/png");break;case"webp":r=p.toDataURL("image/webp");break;case"svg":r=h;break;default:var n="Image format is not jpeg, png, svg or webp.";if(a(new Error(n)),!e.promise)return t.emit("error",n)}i(r),e.promise||t.emit("success",r)},b.onerror=function(r){if(d=null,o.revokeObjectURL(h),a(r),!e.promise)return t.emit("error",r)},b.src=h}));return e.promise?r:t}},35375:(e,t,r)=>{"use strict";var n=r(27284).EventEmitter,i=r(38361),o=r(84468),a=r(5240),s=r(24451),l=r(85916),c=r(69939);e.exports=function(e,t){var r=new n,u=s(e,{format:"png"}),d=u.gd;d.style.position="absolute",d.style.left="-5000px",document.body.appendChild(d);var h=a.getRedrawFunc(d);return i.call("_doPlot",d,u.data,u.layout,u.config).then(h).then((function(){var e=a.getDelay(d._fullLayout);setTimeout((function(){var e=l(d),n=document.createElement("canvas");n.id=o.randstr(),(r=c({format:t.format,width:d._fullLayout.width,height:d._fullLayout.height,canvas:n,emitter:r,svg:e})).clean=function(){d&&document.body.removeChild(d)}}),e)})).catch((function(e){r.emit("error",e)})),r}},85916:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468),o=r(3172),a=r(7605),s=r(28795),l=/"/g,c="TOBESTRIPPED",u=new RegExp('("'+c+")|("+c+'")',"g");e.exports=function(e,t,r){var d,h=e._fullLayout,p=h._paper,f=h._toppaper,m=h.width,g=h.height;p.insert("rect",":first-child").call(o.setRect,0,0,m,g).call(a.fill,h.paper_bgcolor);var y=h._basePlotModules||[];for(d=0;d")?"":t.html(e).text()}));return t.remove(),r}(w),w=(w=w.replace(/&(?!\w+;|\#[0-9]+;| \#x[0-9A-F]+;)/g,"&")).replace(u,"'"),i.isIE()&&(w=(w=(w=w.replace(/"/gi,"'")).replace(/(\('#)([^']*)('\))/gi,'("#$2")')).replace(/(\\')/gi,'"')),w}},15251:(e,t,r)=>{"use strict";var n=r(84468);e.exports=function(e,t){for(var r=0;r{"use strict";var n=r(22049),i=r(39363).axisHoverFormat,o=r(84425).rb,a=r(84425).ay,s=r(6636),l=r(91740),c=r(41508),u=r(2703).k,d=r(64022).extendFlat,h=l({editType:"calc",arrayOk:!0,colorEditType:"style",description:""}),p=d({},n.marker.line.width,{dflt:0}),f=d({width:p,editType:"calc"},s("marker.line")),m=d({line:f,editType:"calc"},s("marker"),{opacity:{valType:"number",arrayOk:!0,dflt:1,min:0,max:1,editType:"style",description:"Sets the opacity of the bars."},pattern:u,cornerradius:{valType:"any",editType:"calc",description:["Sets the rounding of corners. May be an integer number of pixels,","or a percentage of bar width (as a string ending in %). Defaults to `layout.barcornerradius`.","In stack or relative barmode, the first trace to set cornerradius is used for the whole stack."].join(" ")}});e.exports={x:n.x,x0:n.x0,dx:n.dx,y:n.y,y0:n.y0,dy:n.dy,xperiod:n.xperiod,yperiod:n.yperiod,xperiod0:n.xperiod0,yperiod0:n.yperiod0,xperiodalignment:n.xperiodalignment,yperiodalignment:n.yperiodalignment,xhoverformat:i("x"),yhoverformat:i("y"),text:n.text,texttemplate:a({editType:"plot"},{keys:c.eventDataKeys}),hovertext:n.hovertext,hovertemplate:o({},{keys:c.eventDataKeys}),textposition:{valType:"enumerated",values:["inside","outside","auto","none"],dflt:"auto",arrayOk:!0,editType:"calc",description:["Specifies the location of the `text`.","*inside* positions `text` inside, next to the bar end","(rotated and scaled if needed).","*outside* positions `text` outside, next to the bar end","(scaled if needed), unless there is another bar stacked on","this one, then the text gets pushed inside.","*auto* tries to position `text` inside the bar, but if","the bar is too small and no bar is stacked on this one","the text is moved outside.","If *none*, no text appears."].join(" ")},insidetextanchor:{valType:"enumerated",values:["end","middle","start"],dflt:"end",editType:"plot",description:["Determines if texts are kept at center or start/end points in `textposition` *inside* mode."].join(" ")},textangle:{valType:"angle",dflt:"auto",editType:"plot",description:["Sets the angle of the tick labels with respect to the bar.","For example, a `tickangle` of -90 draws the tick labels","vertically. With *auto* the texts may automatically be","rotated to fit with the maximum size in bars."].join(" ")},textfont:d({},h,{description:"Sets the font used for `text`."}),insidetextfont:d({},h,{description:"Sets the font used for `text` lying inside the bar."}),outsidetextfont:d({},h,{description:"Sets the font used for `text` lying outside the bar."}),constraintext:{valType:"enumerated",values:["inside","outside","both","none"],dflt:"both",editType:"calc",description:["Constrain the size of text inside or outside a bar to be no","larger than the bar itself."].join(" ")},cliponaxis:d({},n.cliponaxis,{description:["Determines whether the text nodes","are clipped about the subplot axes.","To show the text nodes above axis lines and tick labels,","make sure to set `xaxis.layer` and `yaxis.layer` to *below traces*."].join(" ")}),orientation:{valType:"enumerated",values:["v","h"],editType:"calc+clearAxisTypes",description:["Sets the orientation of the bars.","With *v* (*h*), the value of the each bar spans","along the vertical (horizontal)."].join(" ")},base:{valType:"any",dflt:null,arrayOk:!0,editType:"calc",description:["Sets where the bar base is drawn (in position axis units).","In *stack* or *relative* barmode,","traces that set *base* will be excluded","and drawn in *overlay* mode instead."].join(" ")},offset:{valType:"number",dflt:null,arrayOk:!0,editType:"calc",description:["Shifts the position where the bar is drawn","(in position axis units).","In *group* barmode,","traces that set *offset* will be excluded","and drawn in *overlay* mode instead."].join(" ")},width:{valType:"number",dflt:null,min:0,arrayOk:!0,editType:"calc",description:["Sets the bar width (in position axis units)."].join(" ")},marker:m,offsetgroup:n.offsetgroup,alignmentgroup:n.alignmentgroup,selected:{marker:{opacity:n.selected.marker.opacity,color:n.selected.marker.color,editType:"style"},textfont:n.selected.textfont,editType:"style"},unselected:{marker:{opacity:n.unselected.marker.opacity,color:n.unselected.marker.color,editType:"style"},textfont:n.unselected.textfont,editType:"style"},zorder:n.zorder,_deprecated:{bardir:{valType:"enumerated",editType:"calc",values:["v","h"],description:"Renamed to `orientation`."}}}},63520:(e,t,r)=>{"use strict";var n=r(85729),i=r(35087),o=r(73084).hasColorscale,a=r(95500),s=r(15251),l=r(40304);e.exports=function(e,t){var r,c,u,d,h,p,f=n.getFromId(e,t.xaxis||"x"),m=n.getFromId(e,t.yaxis||"y"),g={msUTC:!(!t.base&&0!==t.base)};"h"===t.orientation?(r=f.makeCalcdata(t,"x",g),u=m.makeCalcdata(t,"y"),d=i(t,m,"y",u),h=!!t.yperiodalignment,p="y"):(r=m.makeCalcdata(t,"y",g),u=f.makeCalcdata(t,"x"),d=i(t,f,"x",u),h=!!t.xperiodalignment,p="x"),c=d.vals;for(var y=Math.min(c.length,r.length),v=new Array(y),x=0;x{"use strict";e.exports={TEXTPAD:3,eventDataKeys:["value","label"]}},51203:(e,t,r)=>{"use strict";var n=r(22036),i=r(84468).isArrayOrTypedArray,o=r(65004).BADNUM,a=r(38361),s=r(85729),l=r(80038).getAxisGroup,c=r(70891);function u(e,t,r,a,u){if(a.length){var b,_,w,k;switch(function(e,t){var r,o;for(r=0;rd+c||!n(u))}for(var p=0;p{"use strict";var n=r(22036),i=r(84468),o=r(7605),a=r(38361),s=r(53124),l=r(26386),c=r(4241),u=r(53558),d=r(29744),h=i.coerceFont;function p(e){if(n(e)){if((e=+e)>=0)return e}else if("string"===typeof e&&"%"===(e=e.trim()).slice(-1)&&n(e.slice(0,-1))&&(e=+e.slice(0,-1))>=0)return e+"%"}function f(e,t,r,n,o,a){var s=!(!1===(a=a||{}).moduleHasSelected),l=!(!1===a.moduleHasUnselected),c=!(!1===a.moduleHasConstrain),u=!(!1===a.moduleHasCliponaxis),d=!(!1===a.moduleHasTextangle),p=!(!1===a.moduleHasInsideanchor),f=!!a.hasPathbar,m=Array.isArray(o)||"auto"===o,g=m||"inside"===o,y=m||"outside"===o;if(g||y){var v=h(n,"textfont",r.font),x=i.extendFlat({},v),b=!(e.textfont&&e.textfont.color);if(b&&delete x.color,h(n,"insidetextfont",x),f){var _=i.extendFlat({},v);b&&delete _.color,h(n,"pathbar.textfont",_)}y&&h(n,"outsidetextfont",v),s&&n("selected.textfont.color"),l&&n("unselected.textfont.color"),c&&n("constraintext"),u&&n("cliponaxis"),d&&n("textangle"),n("texttemplate")}g&&p&&n("insidetextanchor")}e.exports={supplyDefaults:function(e,t,r,n){function u(r,n){return i.coerce(e,t,d,r,n)}if(s(e,t,n,u)){l(e,t,n,u),u("xhoverformat"),u("yhoverformat"),u("zorder"),u("orientation",t.x&&!t.y?"h":"v"),u("base"),u("offset"),u("width"),u("text"),u("hovertext"),u("hovertemplate");var h=u("textposition");f(e,t,n,u,h,{moduleHasSelected:!0,moduleHasUnselected:!0,moduleHasConstrain:!0,moduleHasCliponaxis:!0,moduleHasTextangle:!0,moduleHasInsideanchor:!0}),c(e,t,u,r,n);var p=(t.marker.line||{}).color,m=a.getComponentMethod("errorbars","supplyDefaults");m(e,t,p||o.defaultLine,{axis:"y"}),m(e,t,p||o.defaultLine,{axis:"x",inherit:"y"}),i.coerceSelectionMarkerOpacity(t,u)}else t.visible=!1},crossTraceDefaults:function(e,t){var r,n;function o(e,t){return i.coerce(n._input,n,d,e,t)}for(var a=0;a{"use strict";e.exports=function(e,t,r){return e.x="xVal"in t?t.xVal:t.x,e.y="yVal"in t?t.yVal:t.y,t.xa&&(e.xaxis=t.xa),t.ya&&(e.yaxis=t.ya),"h"===r.orientation?(e.label=e.y,e.value=e.x):(e.label=e.x,e.value=e.y),e}},30792:(e,t,r)=>{"use strict";var n=r(22036),i=r(23498),o=r(84468).isArrayOrTypedArray;t.coerceString=function(e,t,r){if("string"===typeof t){if(t||!e.noBlank)return t}else if(("number"===typeof t||!0===t)&&!e.strict)return String(t);return void 0!==r?r:e.dflt},t.coerceNumber=function(e,t,r){if(n(t)){t=+t;var i=e.min,o=e.max;if(!(void 0!==i&&to))return t}return void 0!==r?r:e.dflt},t.coerceColor=function(e,t,r){return i(t).isValid()?t:void 0!==r?r:e.dflt},t.coerceEnumerated=function(e,t,r){return e.coerceNumber&&(t=+t),-1!==e.values.indexOf(t)?t:void 0!==r?r:e.dflt},t.getValue=function(e,t){var r;return o(e)?t{"use strict";var n=r(32212),i=r(38361),o=r(7605),a=r(84468).fillText,s=r(30792).getLineWidth,l=r(85729).hoverLabelText,c=r(65004).BADNUM;function u(e,t,r,i,o){var s,u,d,h,p,f,m,g=e.cd,y=g[0].trace,v=g[0].t,x="closest"===i,b="waterfall"===y.type,_=e.maxHoverDistance,w=e.maxSpikeDistance;"h"===y.orientation?(s=r,u=t,d="y",h="x",p=L,f=O):(s=t,u=r,d="x",h="y",f=L,p=O);var k=y[d+"period"],S=x||k;function A(e){return M(e,-1)}function T(e){return M(e,1)}function M(e,t){var r=e.w;return e[d]+t*r/2}function C(e){return e[d+"End"]-e[d+"Start"]}var E=x?A:k?function(e){return e.p-C(e)/2}:function(e){return Math.min(A(e),e.p-v.bardelta/2)},I=x?T:k?function(e){return e.p+C(e)/2}:function(e){return Math.max(T(e),e.p+v.bardelta/2)};function P(e,t,r){return o.finiteRange&&(r=0),n.inbox(e-s,t-s,r+Math.min(1,Math.abs(t-e)/m)-1)}function O(e){return P(E(e),I(e),_)}function R(e){var t=e[h];if(b){var r=Math.abs(e.rawS)||0;u>0?t+=r:u<0&&(t-=r)}return t}function L(e){var t=u,r=e.b,i=R(e);return n.inbox(r-t,i-t,_+(i-t)/(i-r)-1)}var D=e[d+"a"],z=e[h+"a"];m=Math.abs(D.r2c(D.range[1])-D.r2c(D.range[0]));var j=n.getDistanceFunction(i,p,f,(function(e){return(p(e)+f(e))/2}));if(n.getClosest(g,j,e),!1!==e.index&&g[e.index].p!==c){S||(E=function(e){return Math.min(A(e),e.p-v.bargroupwidth/2)},I=function(e){return Math.max(T(e),e.p+v.bargroupwidth/2)});var F=g[e.index],N=y.base?F.b+F.s:F.s;e[h+"0"]=e[h+"1"]=z.c2p(F[h],!0),e[h+"LabelVal"]=N;var B=v.extents[v.extents.round(F.p)];e[d+"0"]=D.c2p(x?E(F):B[0],!0),e[d+"1"]=D.c2p(x?I(F):B[1],!0);var V=void 0!==F.orig_p;return e[d+"LabelVal"]=V?F.orig_p:F.p,e.labelLabel=l(D,e[d+"LabelVal"],y[d+"hoverformat"]),e.valueLabel=l(z,e[h+"LabelVal"],y[h+"hoverformat"]),e.baseLabel=l(z,F.b,y[h+"hoverformat"]),e.spikeDistance=(function(e){var t=u,r=e.b,i=R(e);return n.inbox(r-t,i-t,w+(i-t)/(i-r)-1)}(F)+function(e){return P(A(e),T(e),w)}(F))/2,e[d+"Spike"]=D.c2p(F.p,!0),a(F,y,e),e.hovertemplate=y.hovertemplate,e}}function d(e,t){var r=t.mcc||e.marker.color,n=t.mlcc||e.marker.line.color,i=s(e,t);return o.opacity(r)?r:o.opacity(n)&&i?n:void 0}e.exports={hoverPoints:function(e,t,r,n,o){var a=u(e,t,r,n,o);if(a){var s=a.cd,l=s[0].trace,c=s[a.index];return a.color=d(l,c),i.getComponentMethod("errorbars","hoverInfo")(c,l,a),[a]}},hoverOnBars:u,getTraceColor:d}},42541:(e,t,r)=>{"use strict";e.exports={attributes:r(29744),layoutAttributes:r(23707),supplyDefaults:r(81543).supplyDefaults,crossTraceDefaults:r(81543).crossTraceDefaults,supplyLayoutDefaults:r(57724),calc:r(63520),crossTraceCalc:r(51203).crossTraceCalc,colorbar:r(17789),arraysToCalcdata:r(15251),plot:r(32018).plot,style:r(52464).style,styleOnSelect:r(52464).styleOnSelect,hoverPoints:r(3332).hoverPoints,eventData:r(60604),selectPoints:r(12969),moduleType:"trace",name:"bar",basePlotModule:r(9510),categories:["bar-like","cartesian","svg","bar","oriented","errorBarsOK","showLegend","zoomScale"],animatable:!0,meta:{description:["The data visualized by the span of the bars is set in `y`","if `orientation` is set to *v* (the default)","and the labels are set in `x`.","By setting `orientation` to *h*, the roles are interchanged."].join(" ")}}},23707:e=>{"use strict";e.exports={barmode:{valType:"enumerated",values:["stack","group","overlay","relative"],dflt:"group",editType:"calc",description:["Determines how bars at the same location coordinate","are displayed on the graph.","With *stack*, the bars are stacked on top of one another","With *relative*, the bars are stacked on top of one another,","with negative values below the axis, positive values above","With *group*, the bars are plotted next to one another","centered around the shared location.","With *overlay*, the bars are plotted over one another,","you might need to reduce *opacity* to see multiple bars."].join(" ")},barnorm:{valType:"enumerated",values:["","fraction","percent"],dflt:"",editType:"calc",description:["Sets the normalization for bar traces on the graph.","With *fraction*, the value of each bar is divided by the sum of all","values at that location coordinate.","*percent* is the same but multiplied by 100 to show percentages."].join(" ")},bargap:{valType:"number",min:0,max:1,editType:"calc",description:["Sets the gap (in plot fraction) between bars of","adjacent location coordinates."].join(" ")},bargroupgap:{valType:"number",min:0,max:1,dflt:0,editType:"calc",description:["Sets the gap (in plot fraction) between bars of","the same location coordinate."].join(" ")},barcornerradius:{valType:"any",editType:"calc",description:["Sets the rounding of bar corners. May be an integer number of pixels,","or a percentage of bar width (as a string ending in %)."].join(" ")}}},57724:(e,t,r)=>{"use strict";var n=r(38361),i=r(85729),o=r(84468),a=r(23707),s=r(81543).validateCornerradius;e.exports=function(e,t,r){function l(r,n){return o.coerce(e,t,a,r,n)}for(var c=!1,u=!1,d=!1,h={},p=l("barmode"),f=0;f{"use strict";var n=r(41871),i=r(22036),o=r(84468),a=r(13480),s=r(7605),l=r(3172),c=r(38361),u=r(85729).tickText,d=r(35655),h=d.recordMinTextSize,p=d.clearMinTextSize,f=r(52464),m=r(30792),g=r(41508),y=r(29744),v=y.text,x=y.textposition,b=r(82561).appendArrayPointValue,_=g.TEXTPAD;function w(e){return e.id}function k(e){if(e.ids)return w}function S(e){return(e>0)-(e<0)}function A(e,t){return e0}function C(e,t,r,n,i){return!(e<0||t<0)&&(r<=e&&n<=t||r<=t&&n<=e||(i?e>=r*(t/n):t>=n*(e/r)))}function E(e){return"auto"===e?0:e}function I(e,t){var r=Math.PI/180*t,n=Math.abs(Math.sin(r)),i=Math.abs(Math.cos(r));return{x:e.width*i+e.height*n,y:e.width*n+e.height*i}}function P(e,t,r,n,i,o){var a=!!o.isHorizontal,s=!!o.constrained,l=o.angle||0,c=o.anchor,u="end"===c,d="start"===c,h=((o.leftToRight||0)+1)/2,p=1-h,f=o.hasB,m=o.r,g=o.overhead,y=i.width,v=i.height,x=Math.abs(t-e),b=Math.abs(n-r),w=x>2*_&&b>2*_?_:0;x-=2*w,b-=2*w;var k=E(l);"auto"!==l||y<=x&&v<=b||!(y>x||v>b)||(y>b||v>x)&&y_){var C=function(e,t,r,n,i,o,a,s,l){var c,u,d,h,p,f=Math.max(0,Math.abs(t-e)-2*_),m=Math.max(0,Math.abs(n-r)-2*_),g=o-_,y=a?g-Math.sqrt(g*g-(g-a)*(g-a)):g,v=l?2*g:s?g-a:2*y,x=l?2*g:s?2*y:g-a;i.y/i.x>=m/(f-v)?h=m/i.y:i.y/i.x<=(m-x)/f?h=f/i.x:!l&&s?(c=i.x*i.x+i.y*i.y/4,d=(f-g)*(f-g)+(m/2-g)*(m/2-g)-g*g,h=(-(u=-2*i.x*(f-g)-i.y*(m/2-g))+Math.sqrt(u*u-4*c*d))/(2*c)):l?(c=(i.x*i.x+i.y*i.y)/4,d=(f/2-g)*(f/2-g)+(m/2-g)*(m/2-g)-g*g,h=(-(u=-i.x*(f/2-g)-i.y*(m/2-g))+Math.sqrt(u*u-4*c*d))/(2*c)):(c=i.x*i.x/4+i.y*i.y,d=(f/2-g)*(f/2-g)+(m-g)*(m-g)-g*g,h=(-(u=-i.x*(f/2-g)-2*i.y*(m-g))+Math.sqrt(u*u-4*c*d))/(2*c));h=Math.min(1,h),p=s?Math.max(0,g-Math.sqrt(Math.max(0,g*g-(g-(m-i.y*h)/2)*(g-(m-i.y*h)/2)))-a):Math.max(0,g-Math.sqrt(Math.max(0,g*g-(g-(f-i.x*h)/2)*(g-(f-i.x*h)/2)))-a);return{scale:h,pad:p}}(e,t,r,n,M,m,g,a,f);S=C.scale,T=C.pad}else S=1,s&&(S=Math.min(1,x/M.x,b/M.y)),T=0;var P=i.left*p+i.right*h,O=(i.top+i.bottom)/2,R=(e+_)*p+(t-_)*h,L=(r+n)/2,D=0,z=0;if(d||u){var j=(a?M.x:M.y)/2;m&&(u||f)&&(w+=T);var F=a?A(e,t):A(r,n);a?d?(R=e+F*w,D=-F*j):(R=t-F*w,D=F*j):d?(L=r+F*w,z=-F*j):(L=n-F*w,z=F*j)}return{textX:P,textY:O,targetX:R,targetY:L,anchorX:D,anchorY:z,scale:S,rotate:k}}e.exports={plot:function(e,t,r,d,g,y){var w=t.xaxis,O=t.yaxis,R=e._fullLayout,L=e._context.staticPlot;g||(g={mode:R.barmode,norm:R.barmode,gap:R.bargap,groupgap:R.bargroupgap},p("bar",R));var D=o.makeTraceGroups(d,r,"trace bars").each((function(r){var c=n.select(this),d=r[0].trace,p=r[0].t,D="waterfall"===d.type,z="funnel"===d.type,j="histogram"===d.type,F="bar"===d.type,N=F||z,B=0;D&&d.connector.visible&&"between"===d.connector.mode&&(B=d.connector.line.width/2);var V="h"===d.orientation,U=M(g),H=o.ensureSingle(c,"g","points"),$=k(d),W=H.selectAll("g.point").data(o.identity,$);W.enter().append("g").classed("point",!0),W.exit().remove(),W.each((function(c,k){var M,D,z=n.select(this),H=function(e,t,r,n){var i=[],o=[],a=n?t:r,s=n?r:t;return i[0]=a.c2p(e.s0,!0),o[0]=s.c2p(e.p0,!0),i[1]=a.c2p(e.s1,!0),o[1]=s.c2p(e.p1,!0),n?[i,o]:[o,i]}(c,w,O,V),$=H[0][0],W=H[0][1],q=H[1][0],G=H[1][1],Y=0===(V?W-$:G-q);if(Y&&N&&m.getLineWidth(d,c)&&(Y=!1),Y||(Y=!i($)||!i(W)||!i(q)||!i(G)),c.isBlank=Y,Y&&(V?W=$:G=q),B&&!Y&&(V?($-=A($,W)*B,W+=A($,W)*B):(q-=A(q,G)*B,G+=A(q,G)*B)),"waterfall"===d.type){if(!Y){var X=d[c.dir].marker;M=X.line.width,D=X.color}}else M=m.getLineWidth(d,c),D=c.mc||d.marker.color;function Z(e){var t=n.round(M/2%1,2);return 0===g.gap&&0===g.groupgap?n.round(Math.round(e)-t,2):e}var K=s.opacity(D)<1||M>.01?Z:function(e,t,r){return r&&e===t?e:Math.abs(e-t)>=2?Z(e):e>t?Math.ceil(e):Math.floor(e)};e._context.staticPlot||($=K($,W,V),W=K(W,$,V),q=K(q,G,!V),G=K(G,q,!V));var J,Q=V?w.c2p:O.c2p;J=c.s0>0?c._sMax:c.s0<0?c._sMin:c.s1>0?c._sMax:c._sMin;var ee,te,re=F||j?function(e,t){if(!e)return 0;var r,n=V?Math.abs(G-q):Math.abs(W-$),i=V?Math.abs(W-$):Math.abs(G-q),o=K(Math.abs(Q(J,!0)-Q(0,!0))),a=c.hasB?Math.min(n/2,i/2):Math.min(n/2,o);return r="%"===t?n*(Math.min(50,e)/100):e,K(Math.max(Math.min(r,a),0))}(p.cornerradiusvalue,p.cornerradiusform):0,ne="M"+$+","+q+"V"+G+"H"+W+"V"+q+"Z",ie=0;if(re&&c.s){var oe=0===S(c.s0)||S(c.s)===S(c.s0)?c.s1:c.s0;if((ie=K(c.hasB?0:Math.abs(Q(J,!0)-Q(oe,!0))))0?Math.sqrt(ie*(2*re-ie)):0,de=ae>0?Math.max:Math.min;ee="M"+$+","+q+"V"+(G-ce*se)+"H"+de(W-(re-ie)*ae,$)+"A "+re+","+re+" 0 0 "+le+" "+W+","+(G-re*se-ue)+"V"+(q+re*se+ue)+"A "+re+","+re+" 0 0 "+le+" "+de(W-(re-ie)*ae,$)+","+(q+ce*se)+"Z"}else if(c.hasB)ee="M"+($+re*ae)+","+q+"A "+re+","+re+" 0 0 "+le+" "+$+","+(q+re*se)+"V"+(G-re*se)+"A "+re+","+re+" 0 0 "+le+" "+($+re*ae)+","+G+"H"+(W-re*ae)+"A "+re+","+re+" 0 0 "+le+" "+W+","+(G-re*se)+"V"+(q+re*se)+"A "+re+","+re+" 0 0 "+le+" "+(W-re*ae)+","+q+"Z";else{var he=(te=Math.abs(G-q)+ie)0?Math.sqrt(ie*(2*re-ie)):0,fe=se>0?Math.max:Math.min;ee="M"+($+he*ae)+","+q+"V"+fe(G-(re-ie)*se,q)+"A "+re+","+re+" 0 0 "+le+" "+($+re*ae-pe)+","+G+"H"+(W-re*ae+pe)+"A "+re+","+re+" 0 0 "+le+" "+(W-he*ae)+","+fe(G-(re-ie)*se,q)+"V"+q+"Z"}}else ee=ne}else ee=ne;var me=T(o.ensureSingle(z,"path"),R,g,y);if(me.style("vector-effect",L?"none":"non-scaling-stroke").attr("d",isNaN((W-$)*(G-q))||Y&&e._context.staticPlot?"M0,0Z":ee).call(l.setClipUrl,t.layerClipId,e),!R.uniformtext.mode&&U){var ge=l.makePointStyleFns(d);l.singlePointStyle(c,me,d,ge,e)}!function(e,t,r,n,i,s,c,d,p,g,y,w,k){var S,M=t.xaxis,O=t.yaxis,R=e._fullLayout;function L(t,r,n){return o.ensureSingle(t,"text").text(r).attr({class:"bartext bartext-"+S,"text-anchor":"middle","data-notex":1}).call(l.font,n).call(a.convertToTspans,e)}var D=n[0].trace,z="h"===D.orientation,j=function(e,t,r,n,i){var a,s=t[0].trace,l=s.texttemplate;a=l?function(e,t,r,n,i){var a=t[0].trace,s=o.castOption(a,r,"texttemplate");if(!s)return"";var l,c,d,h,p="histogram"===a.type,f="waterfall"===a.type,m="funnel"===a.type,g="h"===a.orientation;g?(l="y",c=i,d="x",h=n):(l="x",c=n,d="y",h=i);function y(e){return u(c,c.c2l(e),!0).text}function v(e){return u(h,h.c2l(e),!0).text}var x=t[r],_={};_.label=x.p,_.labelLabel=_[l+"Label"]=y(x.p);var w=o.castOption(a,x.i,"text");(0===w||w)&&(_.text=w);_.value=x.s,_.valueLabel=_[d+"Label"]=v(x.s);var k={};b(k,a,x.i),(p||void 0===k.x)&&(k.x=g?_.value:_.label);(p||void 0===k.y)&&(k.y=g?_.label:_.value);(p||void 0===k.xLabel)&&(k.xLabel=g?_.valueLabel:_.labelLabel);(p||void 0===k.yLabel)&&(k.yLabel=g?_.labelLabel:_.valueLabel);f&&(_.delta=+x.rawS||x.s,_.deltaLabel=v(_.delta),_.final=x.v,_.finalLabel=v(_.final),_.initial=_.final-_.delta,_.initialLabel=v(_.initial));m&&(_.value=x.s,_.valueLabel=v(_.value),_.percentInitial=x.begR,_.percentInitialLabel=o.formatPercent(x.begR),_.percentPrevious=x.difR,_.percentPreviousLabel=o.formatPercent(x.difR),_.percentTotal=x.sumR,_.percenTotalLabel=o.formatPercent(x.sumR));var S=o.castOption(a,x.i,"customdata");S&&(_.customdata=S);return o.texttemplateString(s,_,e._d3locale,k,_,a._meta||{})}(e,t,r,n,i):s.textinfo?function(e,t,r,n){var i=e[0].trace,a="h"===i.orientation,s="waterfall"===i.type,l="funnel"===i.type;function c(e){return u(a?n:r,e,!0).text}function d(e){return u(a?r:n,+e,!0).text}var h,p=i.textinfo,f=e[t],m=p.split("+"),g=[],y=function(e){return-1!==m.indexOf(e)};y("label")&&g.push(c(e[t].p));y("text")&&(0===(h=o.castOption(i,f.i,"text"))||h)&&g.push(h);if(s){var v=+f.rawS||f.s,x=f.v,b=x-v;y("initial")&&g.push(d(b)),y("delta")&&g.push(d(v)),y("final")&&g.push(d(x))}if(l){y("value")&&g.push(d(f.s));var _=0;y("percent initial")&&_++,y("percent previous")&&_++,y("percent total")&&_++;var w=_>1;y("percent initial")&&(h=o.formatPercent(f.begR),w&&(h+=" of initial"),g.push(h)),y("percent previous")&&(h=o.formatPercent(f.difR),w&&(h+=" of previous"),g.push(h)),y("percent total")&&(h=o.formatPercent(f.sumR),w&&(h+=" of total"),g.push(h))}return g.join("
")}(t,r,n,i):m.getValue(s.text,r);return m.coerceString(v,a)}(R,n,i,M,O);S=function(e,t){var r=m.getValue(e.textposition,t);return m.coerceEnumerated(x,r)}(D,i);var F="stack"===w.mode||"relative"===w.mode,N=n[i],B=!F||N._outmost,V=N.hasB,U=g&&g-y>_;if(!j||"none"===S||(N.isBlank||s===c||d===p)&&("auto"===S||"inside"===S))return void r.select("text").remove();var H=R.font,$=f.getBarColor(n[i],D),W=f.getInsideTextFont(D,i,H,$),q=f.getOutsideTextFont(D,i,H),G=D.insidetextanchor||"end",Y=r.datum();z?"log"===M.type&&Y.s0<=0&&(s=M.range[0]0&&J>0;ie=U?V?C(re-2*g,ne,K,J,z)||C(re,ne-2*g,K,J,z):z?C(re-(g-y),ne,K,J,z)||C(re,ne-2*(g-y),K,J,z):C(re,ne-(g-y),K,J,z)||C(re-2*(g-y),ne,K,J,z):C(re,ne,K,J,z),oe&&ie?S="inside":(S="outside",X.remove(),X=null)}else S="inside";if(!X){var ae=(X=L(r,j,Q=o.ensureUniformFontSize(e,"outside"===S?q:W))).attr("transform");if(X.attr("transform",""),K=(Z=l.bBox(X.node())).width,J=Z.height,X.attr("transform",ae),K<=0||J<=0)return void X.remove()}var se,le=D.textangle;se="outside"===S?function(e,t,r,n,i,o){var a,s=!!o.isHorizontal,l=!!o.constrained,c=o.angle||0,u=i.width,d=i.height,h=Math.abs(t-e),p=Math.abs(n-r);a=s?p>2*_?_:0:h>2*_?_:0;var f=1;l&&(f=s?Math.min(1,p/d):Math.min(1,h/u));var m=E(c),g=I(i,m),y=(s?g.x:g.y)/2,v=(i.left+i.right)/2,x=(i.top+i.bottom)/2,b=(e+t)/2,w=(r+n)/2,k=0,S=0,T=s?A(t,e):A(r,n);s?(b=t-T*a,k=T*y):(w=n+T*a,S=-T*y);return{textX:v,textY:x,targetX:b,targetY:w,anchorX:k,anchorY:S,scale:f,rotate:m}}(s,c,d,p,Z,{isHorizontal:z,constrained:"both"===D.constraintext||"outside"===D.constraintext,angle:le}):P(s,c,d,p,Z,{isHorizontal:z,constrained:"both"===D.constraintext||"inside"===D.constraintext,angle:le,anchor:G,hasB:V,r:g,overhead:y});se.fontSize=Q.size,h("histogram"===D.type?"bar":D.type,se,R),N.transform=se;var ce=T(X,R,w,k);o.setTransormAndDisplay(ce,se)}(e,t,z,r,k,$,W,q,G,re,ie,g,y),t.layerClipId&&l.hideOutsideRangePoint(c,z.select("text"),w,O,d.xcalendar,d.ycalendar)}));var q=!1===d.cliponaxis;l.setClipUrl(c,q?null:t.layerClipId,e)}));c.getComponentMethod("errorbars","plot")(e,D,t,g)},toMoveInsideBar:P}},12969:e=>{"use strict";function t(e,t,r,n,i){var o=t.c2p(n?e.s0:e.p0,!0),a=t.c2p(n?e.s1:e.p1,!0),s=r.c2p(n?e.p0:e.s0,!0),l=r.c2p(n?e.p1:e.s1,!0);return i?[(o+a)/2,(s+l)/2]:n?[a,(s+l)/2]:[(o+a)/2,l]}e.exports=function(e,r){var n,i=e.cd,o=e.xaxis,a=e.yaxis,s=i[0].trace,l="funnel"===s.type,c="h"===s.orientation,u=[];if(!1===r)for(n=0;n{"use strict";e.exports=i;var n=r(84468).distinctVals;function i(e,t){this.traces=e,this.sepNegVal=t.sepNegVal,this.overlapNoMerge=t.overlapNoMerge;for(var r=1/0,i=t.posAxis._id.charAt(0),o=[],a=0;a{"use strict";var n=r(41871),i=r(7605),o=r(3172),a=r(84468),s=r(38361),l=r(35655).resizeText,c=r(29744),u=c.textfont,d=c.insidetextfont,h=c.outsidetextfont,p=r(30792);function f(e,t,r){o.pointStyle(e.selectAll("path"),t,r),m(e,t,r)}function m(e,t,r){e.selectAll("text").each((function(e){var i=n.select(this),s=a.ensureUniformFontSize(r,g(i,e,t,r));o.font(i,s)}))}function g(e,t,r,n){var i=n._fullLayout.font,o=r.textfont;if(e.classed("bartext-inside")){var a=_(t,r);o=v(r,t.i,i,a)}else e.classed("bartext-outside")&&(o=x(r,t.i,i));return o}function y(e,t,r){return b(u,e.textfont,t,r)}function v(e,t,r,n){var o=y(e,t,r);return(void 0===e._input.textfont||void 0===e._input.textfont.color||Array.isArray(e.textfont.color)&&void 0===e.textfont.color[t])&&(o={color:i.contrast(n),family:o.family,size:o.size,weight:o.weight,style:o.style,variant:o.variant,textcase:o.textcase,lineposition:o.lineposition,shadow:o.shadow}),b(d,e.insidetextfont,t,o)}function x(e,t,r){var n=y(e,t,r);return b(h,e.outsidetextfont,t,n)}function b(e,t,r,n){t=t||{};var i=p.getValue(t.family,r),o=p.getValue(t.size,r),a=p.getValue(t.color,r),s=p.getValue(t.weight,r),l=p.getValue(t.style,r),c=p.getValue(t.variant,r),u=p.getValue(t.textcase,r),d=p.getValue(t.lineposition,r),h=p.getValue(t.shadow,r);return{family:p.coerceString(e.family,i,n.family),size:p.coerceNumber(e.size,o,n.size),color:p.coerceColor(e.color,a,n.color),weight:p.coerceString(e.weight,s,n.weight),style:p.coerceString(e.style,l,n.style),variant:p.coerceString(e.variant,c,n.variant),textcase:p.coerceString(e.variant,u,n.textcase),lineposition:p.coerceString(e.variant,d,n.lineposition),shadow:p.coerceString(e.variant,h,n.shadow)}}function _(e,t){return"waterfall"===t.type?t[e.dir].marker.color:e.mcc||e.mc||t.marker.color}e.exports={style:function(e){var t=n.select(e).selectAll('g[class^="barlayer"]').selectAll("g.trace");l(e,t,"bar");var r=t.size(),i=e._fullLayout;t.style("opacity",(function(e){return e[0].trace.opacity})).each((function(e){("stack"===i.barmode&&r>1||0===i.bargap&&0===i.bargroupgap&&!e[0].trace.marker.line.width)&&n.select(this).attr("shape-rendering","crispEdges")})),t.selectAll("g.points").each((function(t){f(n.select(this),t[0].trace,e)})),s.getComponentMethod("errorbars","style")(t)},styleTextPoints:m,styleOnSelect:function(e,t,r){var i=t[0].trace;i.selectedpoints?function(e,t,r){o.selectedPointStyle(e.selectAll("path"),t),function(e,t,r){e.each((function(e){var i,s=n.select(this);if(e.selected){i=a.ensureUniformFontSize(r,g(s,e,t,r));var l=t.selected.textfont&&t.selected.textfont.color;l&&(i.color=l),o.font(s,i)}else o.selectedTextStyle(s,t)}))}(e.selectAll("text"),t,r)}(r,i,e):(f(r,i,e),s.getComponentMethod("errorbars","style")(r))},getInsideTextFont:v,getOutsideTextFont:x,getBarColor:_,resizeText:l}},4241:(e,t,r)=>{"use strict";var n=r(7605),i=r(73084).hasColorscale,o=r(16155),a=r(84468).coercePattern;e.exports=function(e,t,r,s,l){var c=r("marker.color",s),u=i(e,"marker");u&&o(e,t,l,r,{prefix:"marker.",cLetter:"c"}),r("marker.line.color",n.defaultLine),i(e,"marker.line")&&o(e,t,l,r,{prefix:"marker.line.",cLetter:"c"}),r("marker.line.width"),r("marker.opacity"),a(r,"marker.pattern",c,u),r("selected.marker.color"),r("unselected.marker.color")}},35655:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468);function o(e){return"_"+e+"Text_minsize"}e.exports={recordMinTextSize:function(e,t,r){if(r.uniformtext.mode){var n=o(e),i=r.uniformtext.minsize,a=t.scale*t.fontSize;t.hide=a{"use strict";var n=r(84425).rb,i=r(64022).extendFlat,o=r(18889),a=r(29744);e.exports={r:o.r,theta:o.theta,r0:o.r0,dr:o.dr,theta0:o.theta0,dtheta:o.dtheta,thetaunit:o.thetaunit,base:i({},a.base,{description:["Sets where the bar base is drawn (in radial axis units).","In *stack* barmode,","traces that set *base* will be excluded","and drawn in *overlay* mode instead."].join(" ")}),offset:i({},a.offset,{description:["Shifts the angular position where the bar is drawn","(in *thetatunit* units)."].join(" ")}),width:i({},a.width,{description:["Sets the bar angular width (in *thetaunit* units)."].join(" ")}),text:i({},a.text,{description:["Sets hover text elements associated with each bar.","If a single string, the same string appears over all bars.","If an array of string, the items are mapped in order to the","this trace's coordinates."].join(" ")}),hovertext:i({},a.hovertext,{description:"Same as `text`."}),marker:function(){var e=i({},a.marker);return delete e.cornerradius,e}(),hoverinfo:o.hoverinfo,hovertemplate:n(),selected:a.selected,unselected:a.unselected}},60334:(e,t,r)=>{"use strict";var n=r(73084).hasColorscale,i=r(95500),o=r(84468).isArrayOrTypedArray,a=r(15251),s=r(51203).setGroupPositions,l=r(40304),c=r(38361).traceIs,u=r(84468).extendFlat;e.exports={calc:function(e,t){for(var r=e._fullLayout,s=t.subplot,c=r[s].radialaxis,u=r[s].angularaxis,d=c.makeCalcdata(t,"r"),h=u.makeCalcdata(t,"theta"),p=t._length,f=new Array(p),m=d,g=h,y=0;y{"use strict";var n=r(84468),i=r(19150).handleRThetaDefaults,o=r(4241),a=r(24978);e.exports=function(e,t,r,s){function l(r,i){return n.coerce(e,t,a,r,i)}i(e,t,s,l)?(l("thetaunit"),l("base"),l("offset"),l("width"),l("text"),l("hovertext"),l("hovertemplate"),o(e,t,l,r,s),n.coerceSelectionMarkerOpacity(t,l)):t.visible=!1}},32477:(e,t,r)=>{"use strict";var n=r(32212),i=r(84468),o=r(3332).getTraceColor,a=i.fillText,s=r(99152).makeHoverPointText,l=r(81453).isPtInsidePolygon;e.exports=function(e,t,r){var c=e.cd,u=c[0].trace,d=e.subplot,h=d.radialAxis,p=d.angularAxis,f=d.vangles,m=f?l:i.isPtInsideSector,g=e.maxHoverDistance,y=p._period||2*Math.PI,v=Math.abs(h.g2p(Math.sqrt(t*t+r*r))),x=Math.atan2(r,t);h.range[0]>h.range[1]&&(x+=Math.PI);if(n.getClosest(c,(function(e){return m(v,x,[e.rp0,e.rp1],[e.thetag0,e.thetag1],f)?g+Math.min(1,Math.abs(e.thetag1-e.thetag0)/y)-1+(e.rp1-v)/(e.rp1-e.rp0)-1:1/0}),e),!1!==e.index){var b=c[e.index];e.x0=e.x1=b.ct[0],e.y0=e.y1=b.ct[1];var _=i.extendFlat({},b,{r:b.s,theta:b.p});return a(b,u,e),s(_,u,d,e),e.hovertemplate=u.hovertemplate,e.color=o(u,b),e.xLabelVal=e.yLabelVal=void 0,b.s<0&&(e.idealAlign="left"),[e]}}},51915:(e,t,r)=>{"use strict";e.exports={moduleType:"trace",name:"barpolar",basePlotModule:r(76016),categories:["polar","bar","showLegend"],attributes:r(24978),layoutAttributes:r(96609),supplyDefaults:r(73445),supplyLayoutDefaults:r(27846),calc:r(60334).calc,crossTraceCalc:r(60334).crossTraceCalc,plot:r(3596),colorbar:r(17789),formatLabels:r(87009),style:r(52464).style,styleOnSelect:r(52464).styleOnSelect,hoverPoints:r(32477),selectPoints:r(12969),meta:{hrName:"bar_polar",description:["The data visualized by the radial span of the bars is set in `r`"].join(" ")}}},96609:e=>{"use strict";e.exports={barmode:{valType:"enumerated",values:["stack","overlay"],dflt:"stack",editType:"calc",description:["Determines how bars at the same location coordinate","are displayed on the graph.","With *stack*, the bars are stacked on top of one another","With *overlay*, the bars are plotted over one another,","you might need to reduce *opacity* to see multiple bars."].join(" ")},bargap:{valType:"number",dflt:.1,min:0,max:1,editType:"calc",description:["Sets the gap between bars of","adjacent location coordinates.","Values are unitless, they represent fractions of the minimum difference","in bar positions in the data."].join(" ")}}},27846:(e,t,r)=>{"use strict";var n=r(84468),i=r(96609);e.exports=function(e,t,r){var o,a={};function s(r,a){return n.coerce(e[o]||{},t[o],i,r,a)}for(var l=0;l{"use strict";var n=r(41871),i=r(22036),o=r(84468),a=r(3172),s=r(81453);e.exports=function(e,t,r){var l=e._context.staticPlot,c=t.xaxis,u=t.yaxis,d=t.radialAxis,h=t.angularAxis,p=function(e){var t=e.cxx,r=e.cyy;if(e.vangles)return function(n,i,a,l){var c,u;o.angleDelta(a,l)>0?(c=a,u=l):(c=l,u=a);var d=[s.findEnclosingVertexAngles(c,e.vangles)[0],(c+u)/2,s.findEnclosingVertexAngles(u,e.vangles)[1]];return s.pathPolygonAnnulus(n,i,c,u,d,t,r)};return function(e,n,i,a){return o.pathAnnulus(e,n,i,a,t,r)}}(t),f=t.layers.frontplot.select("g.barlayer");o.makeTraceGroups(f,r,"trace bars").each((function(){var r=n.select(this),s=o.ensureSingle(r,"g","points").selectAll("g.point").data(o.identity);s.enter().append("g").style("vector-effect",l?"none":"non-scaling-stroke").style("stroke-miterlimit",2).classed("point",!0),s.exit().remove(),s.each((function(e){var t,r=n.select(this),a=e.rp0=d.c2p(e.s0),s=e.rp1=d.c2p(e.s1),l=e.thetag0=h.c2g(e.p0),f=e.thetag1=h.c2g(e.p1);if(i(a)&&i(s)&&i(l)&&i(f)&&a!==s&&l!==f){var m=d.c2g(e.s1),g=(l+f)/2;e.ct=[c.c2p(m*Math.cos(g)),u.c2p(m*Math.sin(g))],t=p(a,s,l,f)}else t="M0,0Z";o.ensureSingle(r,"path").attr("d",t)})),a.setClipUrl(r,t._hasClipOnAxisFalse?t.clipIds.forTraces:null,e)}))}},46812:(e,t,r)=>{"use strict";var n=r(50821),i=r(22049),o=r(29744),a=r(17992),s=r(39363).axisHoverFormat,l=r(84425).rb,c=r(64022).extendFlat,u=i.marker,d=u.line;e.exports={y:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the y sample data or coordinates.","See overview for more info."].join(" ")},x:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the x sample data or coordinates.","See overview for more info."].join(" ")},x0:{valType:"any",editType:"calc+clearAxisTypes",description:["Sets the x coordinate for single-box traces","or the starting coordinate for multi-box traces","set using q1/median/q3.","See overview for more info."].join(" ")},y0:{valType:"any",editType:"calc+clearAxisTypes",description:["Sets the y coordinate for single-box traces","or the starting coordinate for multi-box traces","set using q1/median/q3.","See overview for more info."].join(" ")},dx:{valType:"number",editType:"calc",description:["Sets the x coordinate step for multi-box traces","set using q1/median/q3."].join(" ")},dy:{valType:"number",editType:"calc",description:["Sets the y coordinate step for multi-box traces","set using q1/median/q3."].join(" ")},xperiod:i.xperiod,yperiod:i.yperiod,xperiod0:i.xperiod0,yperiod0:i.yperiod0,xperiodalignment:i.xperiodalignment,yperiodalignment:i.yperiodalignment,xhoverformat:s("x"),yhoverformat:s("y"),name:{valType:"string",editType:"calc+clearAxisTypes",description:["Sets the trace name.","The trace name appears as the legend item and on hover.","For box traces, the name will also be used for the position","coordinate, if `x` and `x0` (`y` and `y0` if horizontal) are","missing and the position axis is categorical"].join(" ")},q1:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the Quartile 1 values.","There should be as many items as the number of boxes desired."].join(" ")},median:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the median values.","There should be as many items as the number of boxes desired."].join(" ")},q3:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the Quartile 3 values.","There should be as many items as the number of boxes desired."].join(" ")},lowerfence:{valType:"data_array",editType:"calc",description:["Sets the lower fence values.","There should be as many items as the number of boxes desired.","This attribute has effect only under the q1/median/q3 signature.","If `lowerfence` is not provided but a sample (in `y` or `x`) is set,","we compute the lower as the last sample point below 1.5 times the IQR."].join(" ")},upperfence:{valType:"data_array",editType:"calc",description:["Sets the upper fence values.","There should be as many items as the number of boxes desired.","This attribute has effect only under the q1/median/q3 signature.","If `upperfence` is not provided but a sample (in `y` or `x`) is set,","we compute the upper as the last sample point above 1.5 times the IQR."].join(" ")},notched:{valType:"boolean",editType:"calc",description:["Determines whether or not notches are drawn.","Notches displays a confidence interval around the median.","We compute the confidence interval as median +/- 1.57 * IQR / sqrt(N),","where IQR is the interquartile range and N is the sample size.","If two boxes' notches do not overlap there is 95% confidence their medians differ.","See https://sites.google.com/site/davidsstatistics/home/notched-box-plots for more info.","Defaults to *false* unless `notchwidth` or `notchspan` is set."].join(" ")},notchwidth:{valType:"number",min:0,max:.5,dflt:.25,editType:"calc",description:["Sets the width of the notches relative to","the box' width.","For example, with 0, the notches are as wide as the box(es)."].join(" ")},notchspan:{valType:"data_array",editType:"calc",description:["Sets the notch span from the boxes' `median` values.","There should be as many items as the number of boxes desired.","This attribute has effect only under the q1/median/q3 signature.","If `notchspan` is not provided but a sample (in `y` or `x`) is set,","we compute it as 1.57 * IQR / sqrt(N),","where N is the sample size."].join(" ")},boxpoints:{valType:"enumerated",values:["all","outliers","suspectedoutliers",!1],editType:"calc",description:["If *outliers*, only the sample points lying outside the whiskers","are shown","If *suspectedoutliers*, the outlier points are shown and","points either less than 4*Q1-3*Q3 or greater than 4*Q3-3*Q1","are highlighted (see `outliercolor`)","If *all*, all sample points are shown","If *false*, only the box(es) are shown with no sample points","Defaults to *suspectedoutliers* when `marker.outliercolor` or","`marker.line.outliercolor` is set.","Defaults to *all* under the q1/median/q3 signature.","Otherwise defaults to *outliers*."].join(" ")},jitter:{valType:"number",min:0,max:1,editType:"calc",description:["Sets the amount of jitter in the sample points drawn.","If *0*, the sample points align along the distribution axis.","If *1*, the sample points are drawn in a random jitter of width","equal to the width of the box(es)."].join(" ")},pointpos:{valType:"number",min:-2,max:2,editType:"calc",description:["Sets the position of the sample points in relation to the box(es).","If *0*, the sample points are places over the center of the box(es).","Positive (negative) values correspond to positions to the","right (left) for vertical boxes and above (below) for horizontal boxes"].join(" ")},sdmultiple:{valType:"number",min:0,editType:"calc",dflt:1,description:["Scales the box size when sizemode=sd","Allowing boxes to be drawn across any stddev range","For example 1-stddev, 3-stddev, 5-stddev"].join(" ")},sizemode:{valType:"enumerated",values:["quartiles","sd"],editType:"calc",dflt:"quartiles",description:["Sets the upper and lower bound for the boxes","quartiles means box is drawn between Q1 and Q3","SD means the box is drawn between Mean +- Standard Deviation","Argument sdmultiple (default 1) to scale the box size","So it could be drawn 1-stddev, 3-stddev etc"].join(" ")},boxmean:{valType:"enumerated",values:[!0,"sd",!1],editType:"calc",description:["If *true*, the mean of the box(es)' underlying distribution is","drawn as a dashed line inside the box(es).","If *sd* the standard deviation is also drawn.","Defaults to *true* when `mean` is set.","Defaults to *sd* when `sd` is set","Otherwise defaults to *false*."].join(" ")},mean:{valType:"data_array",editType:"calc",description:["Sets the mean values.","There should be as many items as the number of boxes desired.","This attribute has effect only under the q1/median/q3 signature.","If `mean` is not provided but a sample (in `y` or `x`) is set,","we compute the mean for each box using the sample values."].join(" ")},sd:{valType:"data_array",editType:"calc",description:["Sets the standard deviation values.","There should be as many items as the number of boxes desired.","This attribute has effect only under the q1/median/q3 signature.","If `sd` is not provided but a sample (in `y` or `x`) is set,","we compute the standard deviation for each box using the sample values."].join(" ")},orientation:{valType:"enumerated",values:["v","h"],editType:"calc+clearAxisTypes",description:["Sets the orientation of the box(es).","If *v* (*h*), the distribution is visualized along","the vertical (horizontal)."].join(" ")},quartilemethod:{valType:"enumerated",values:["linear","exclusive","inclusive"],dflt:"linear",editType:"calc",description:["Sets the method used to compute the sample's Q1 and Q3 quartiles.","The *linear* method uses the 25th percentile for Q1 and 75th percentile for Q3","as computed using method #10 (listed on http://jse.amstat.org/v14n3/langford.html).","The *exclusive* method uses the median to divide the ordered dataset into two halves","if the sample is odd, it does not include the median in either half -","Q1 is then the median of the lower half and","Q3 the median of the upper half.","The *inclusive* method also uses the median to divide the ordered dataset into two halves","but if the sample is odd, it includes the median in both halves -","Q1 is then the median of the lower half and","Q3 the median of the upper half."].join(" ")},width:{valType:"number",min:0,dflt:0,editType:"calc",description:["Sets the width of the box in data coordinate","If *0* (default value) the width is automatically selected based on the positions","of other box traces in the same subplot."].join(" ")},marker:{outliercolor:{valType:"color",dflt:"rgba(0, 0, 0, 0)",editType:"style",description:"Sets the color of the outlier sample points."},symbol:c({},u.symbol,{arrayOk:!1,editType:"plot"}),opacity:c({},u.opacity,{arrayOk:!1,dflt:1,editType:"style"}),angle:c({},u.angle,{arrayOk:!1,editType:"calc"}),size:c({},u.size,{arrayOk:!1,editType:"calc"}),color:c({},u.color,{arrayOk:!1,editType:"style"}),line:{color:c({},d.color,{arrayOk:!1,dflt:a.defaultLine,editType:"style"}),width:c({},d.width,{arrayOk:!1,dflt:0,editType:"style"}),outliercolor:{valType:"color",editType:"style",description:["Sets the border line color of the outlier sample points.","Defaults to marker.color"].join(" ")},outlierwidth:{valType:"number",min:0,dflt:1,editType:"style",description:["Sets the border line width (in px) of the outlier sample points."].join(" ")},editType:"style"},editType:"plot"},line:{color:{valType:"color",editType:"style",description:"Sets the color of line bounding the box(es)."},width:{valType:"number",min:0,dflt:2,editType:"style",description:"Sets the width (in px) of line bounding the box(es)."},editType:"plot"},fillcolor:n(),whiskerwidth:{valType:"number",min:0,max:1,dflt:.5,editType:"calc",description:["Sets the width of the whiskers relative to","the box' width.","For example, with 1, the whiskers are as wide as the box(es)."].join(" ")},showwhiskers:{valType:"boolean",editType:"calc",description:["Determines whether or not whiskers are visible.","Defaults to true for `sizemode` *quartiles*, false for *sd*."].join(" ")},offsetgroup:o.offsetgroup,alignmentgroup:o.alignmentgroup,selected:{marker:i.selected.marker,editType:"style"},unselected:{marker:i.unselected.marker,editType:"style"},text:c({},i.text,{description:["Sets the text elements associated with each sample value.","If a single string, the same string appears over","all the data points.","If an array of string, the items are mapped in order to the","this trace's (x,y) coordinates.","To be seen, trace `hoverinfo` must contain a *text* flag."].join(" ")}),hovertext:c({},i.hovertext,{description:"Same as `text`."}),hovertemplate:l({description:["N.B. This only has an effect when hovering on points."].join(" ")}),hoveron:{valType:"flaglist",flags:["boxes","points"],dflt:"boxes+points",editType:"style",description:["Do the hover effects highlight individual boxes ","or sample points or both?"].join(" ")},zorder:i.zorder}},66524:(e,t,r)=>{"use strict";var n=r(22036),i=r(85729),o=r(35087),a=r(84468),s=r(65004).BADNUM,l=a._;e.exports=function(e,t){var r,c,v,x,b,_,w,k=e._fullLayout,S=i.getFromId(e,t.xaxis||"x"),A=i.getFromId(e,t.yaxis||"y"),T=[],M="violin"===t.type?"_numViolins":"_numBoxes";"h"===t.orientation?(v=S,x="x",b=A,_="y",w=!!t.yperiodalignment):(v=A,x="y",b=S,_="x",w=!!t.xperiodalignment);var C,E,I,P,O,R,L=function(e,t,r,i){var s,l=t in e,c=t+"0"in e,u="d"+t in e;if(l||c&&u){var d=r.makeCalcdata(e,t);return[o(e,r,t,d).vals,d]}s=c?e[t+"0"]:"name"in e&&("category"===r.type||n(e.name)&&-1!==["linear","log"].indexOf(r.type)||a.isDateTime(e.name)&&"date"===r.type)?e.name:i;for(var h="multicategory"===r.type?r.r2c_just_indices(s):r.d2c(s,0,e[t+"calendar"]),p=e._length,f=new Array(p),m=0;mC.uf};if(t._hasPreCompStats){var V=t[x],U=function(e){return v.d2c((t[e]||[])[r])},H=1/0,$=-1/0;for(r=0;r=C.q1&&C.q3>=C.med){var q=U("lowerfence");C.lf=q!==s&&q<=C.q1?q:p(C,I,P);var G=U("upperfence");C.uf=G!==s&&G>=C.q3?G:f(C,I,P);var Y=U("mean");C.mean=Y!==s?Y:P?a.mean(I,P):(C.q1+C.q3)/2;var X=U("sd");C.sd=Y!==s&&X>=0?X:P?a.stdev(I,P,C.mean):C.q3-C.q1,C.lo=m(C),C.uo=g(C);var Z=U("notchspan");Z=Z!==s&&Z>0?Z:y(C,P),C.ln=C.med-Z,C.un=C.med+Z;var K=C.lf,J=C.uf;t.boxpoints&&I.length&&(K=Math.min(K,I[0]),J=Math.max(J,I[P-1])),t.notched&&(K=Math.min(K,C.ln),J=Math.max(J,C.un)),C.min=K,C.max=J}else{var Q;a.warn(["Invalid input - make sure that q1 <= median <= q3","q1 = "+C.q1,"median = "+C.med,"q3 = "+C.q3].join("\n")),Q=C.med!==s?C.med:C.q1!==s?C.q3!==s?(C.q1+C.q3)/2:C.q1:C.q3!==s?C.q3:0,C.med=Q,C.q1=C.q3=Q,C.lf=C.uf=Q,C.mean=C.sd=Q,C.ln=C.un=Q,C.min=C.max=Q}H=Math.min(H,C.min),$=Math.max($,C.max),C.pts2=E.filter(B),T.push(C)}}t._extremes[v._id]=i.findExtremes(v,[H,$],{padded:!0})}else{var ee=v.makeCalcdata(t,x),te=function(e,t){for(var r=e.length,n=new Array(r+1),i=0;i=0&&ie0){var ue,de;if((C={}).pos=C[_]=F[r],E=C.pts=ne[r].sort(d),P=(I=C[x]=E.map(h)).length,C.min=I[0],C.max=I[P-1],C.mean=a.mean(I,P),C.sd=a.stdev(I,P,C.mean)*t.sdmultiple,C.med=a.interp(I,.5),P%2&&(le||ce))le?(ue=I.slice(0,P/2),de=I.slice(P/2+1)):ce&&(ue=I.slice(0,P/2+1),de=I.slice(P/2)),C.q1=a.interp(ue,.5),C.q3=a.interp(de,.5);else C.q1=a.interp(I,.25),C.q3=a.interp(I,.75);C.lf=p(C,I,P),C.uf=f(C,I,P),C.lo=m(C),C.uo=g(C);var he=y(C,P);C.ln=C.med-he,C.un=C.med+he,oe=Math.min(oe,C.ln),ae=Math.max(ae,C.un),C.pts2=E.filter(B),T.push(C)}t.notched&&a.isTypedArray(ee)&&(ee=Array.from(ee)),t._extremes[v._id]=i.findExtremes(v,t.notched?ee.concat([oe,ae]):ee,{padded:!0})}return function(e,t){if(a.isArrayOrTypedArray(t.selectedpoints))for(var r=0;r0?(T[0].t={num:k[M],dPos:N,posLetter:_,valLetter:x,labels:{med:l(e,"median:"),min:l(e,"min:"),q1:l(e,"q1:"),q3:l(e,"q3:"),max:l(e,"max:"),mean:"sd"===t.boxmean||"sd"===t.sizemode?l(e,"mean \xb1 \u03c3:").replace("\u03c3",1===t.sdmultiple?"\u03c3":t.sdmultiple+"\u03c3"):l(e,"mean:"),lf:l(e,"lower fence:"),uf:l(e,"upper fence:")}},k[M]++,T):[{t:{empty:!0}}]};var c={text:"tx",hovertext:"htx"};function u(e,t,r){for(var n in c)a.isArrayOrTypedArray(t[n])&&(Array.isArray(r)?a.isArrayOrTypedArray(t[n][r[0]])&&(e[c[n]]=t[n][r[0]][r[1]]):e[c[n]]=t[n][r])}function d(e,t){return e.v-t.v}function h(e){return e.v}function p(e,t,r){return 0===r?e.q1:Math.min(e.q1,t[Math.min(a.findBin(2.5*e.q1-1.5*e.q3,t,!0)+1,r-1)])}function f(e,t,r){return 0===r?e.q3:Math.max(e.q3,t[Math.max(a.findBin(2.5*e.q3-1.5*e.q1,t),0)])}function m(e){return 4*e.q1-3*e.q3}function g(e){return 4*e.q3-3*e.q1}function y(e,t){return 0===t?0:1.57*(e.q3-e.q1)/Math.sqrt(t)}},11927:(e,t,r)=>{"use strict";var n=r(85729),i=r(84468),o=r(80038).getAxisGroup,a=["v","h"];function s(e,t,r,a){var s,l,c,u=t.calcdata,d=t._fullLayout,h=a._id,p=h.charAt(0),f=[],m=0;for(s=0;s1,b=1-d[e+"gap"],_=1-d[e+"groupgap"];for(s=0;s0){var $=C.pointpos,W=C.jitter,q=C.marker.size/2,G=0;$+W>=0&&((G=U*($+W))>T?(H=!0,B=q,F=G):G>z&&(B=q,F=T)),G<=T&&(F=T);var Y=0;$-W<=0&&((Y=-U*($-W))>M?(H=!0,V=q,N=Y):Y>j&&(V=q,N=M)),Y<=M&&(N=M)}else F=T,N=M;var X=new Array(c.length);for(l=0;l{"use strict";var n=r(84468),i=r(38361),o=r(7605),a=r(26386),s=r(53558),l=r(84339),c=r(46812);function u(e,t,r,o){function a(e){var t=0;return e&&e.length&&(t+=1,n.isArrayOrTypedArray(e[0])&&e[0].length&&(t+=1)),t}function s(t){return n.validate(e[t],c[t])}var u,d=r("y"),h=r("x");if("box"===t.type){var p=r("q1"),f=r("median"),m=r("q3");t._hasPreCompStats=p&&p.length&&f&&f.length&&m&&m.length,u=Math.min(n.minRowLength(p),n.minRowLength(f),n.minRowLength(m))}var g,y,v=a(d),x=a(h),b=v&&n.minRowLength(d),_=x&&n.minRowLength(h),w=o.calendar,k={autotypenumbers:o.autotypenumbers};if(t._hasPreCompStats)switch(String(x)+String(v)){case"00":var S=s("x0")||s("dx");g=(s("y0")||s("dy"))&&!S?"h":"v",y=u;break;case"10":g="v",y=Math.min(u,_);break;case"20":g="h",y=Math.min(u,h.length);break;case"01":g="h",y=Math.min(u,b);break;case"02":g="v",y=Math.min(u,d.length);break;case"12":g="v",y=Math.min(u,_,d.length);break;case"21":g="h",y=Math.min(u,h.length,b);break;case"11":y=0;break;case"22":var A,T=!1;for(A=0;A0?(g="v",y=x>0?Math.min(_,b):Math.min(b)):x>0?(g="h",y=Math.min(_)):y=0;if(y){t._length=y;var M=r("orientation",g);t._hasPreCompStats?"v"===M&&0===x?(r("x0",0),r("dx",1)):"h"===M&&0===v&&(r("y0",0),r("dy",1)):"v"===M&&0===x?r("x0"):"h"===M&&0===v&&r("y0"),i.getComponentMethod("calendars","handleTraceDefaults")(e,t,["x","y"],o)}else t.visible=!1}function d(e,t,r,i){var o=i.prefix,a=n.coerce2(e,t,c,"marker.outliercolor"),s=r("marker.line.outliercolor"),l="outliers";t._hasPreCompStats?l="all":(a||s)&&(l="suspectedoutliers");var u=r(o+"points",l);u?(r("jitter","all"===u?.3:0),r("pointpos","all"===u?-1.5:0),r("marker.symbol"),r("marker.opacity"),r("marker.size"),r("marker.angle"),r("marker.color",t.line.color),r("marker.line.color"),r("marker.line.width"),"suspectedoutliers"===u&&(r("marker.line.outliercolor",t.marker.color),r("marker.line.outlierwidth")),r("selected.marker.color"),r("unselected.marker.color"),r("selected.marker.size"),r("unselected.marker.size"),r("text"),r("hovertext")):delete t.marker;var d=r("hoveron");"all"!==d&&-1===d.indexOf("points")||r("hovertemplate"),n.coerceSelectionMarkerOpacity(t,r)}e.exports={supplyDefaults:function(e,t,r,i){function s(r,i){return n.coerce(e,t,c,r,i)}if(u(e,t,s,i),!1!==t.visible){a(e,t,i,s),s("xhoverformat"),s("yhoverformat");var l=t._hasPreCompStats;l&&(s("lowerfence"),s("upperfence")),s("line.color",(e.marker||{}).color||r),s("line.width"),s("fillcolor",o.addOpacity(t.line.color,.5));var h=!1;if(l){var p=s("mean"),f=s("sd");p&&p.length&&(h=!0,f&&f.length&&(h="sd"))}s("whiskerwidth");var m,g=s("sizemode");"quartiles"===g&&(m=s("boxmean",h)),s("showwhiskers","quartiles"===g),"sd"!==g&&"sd"!==m||s("sdmultiple"),s("width"),s("quartilemethod");var y=!1;if(l){var v=s("notchspan");v&&v.length&&(y=!0)}else n.validate(e.notchwidth,c.notchwidth)&&(y=!0);s("notched",y)&&s("notchwidth"),d(e,t,s,{prefix:"box"}),s("zorder")}},crossTraceDefaults:function(e,t){var r,i;function o(e){return n.coerce(i._input,i,c,e)}for(var a=0;a{"use strict";e.exports=function(e,t){return t.hoverOnBox&&(e.hoverOnBox=t.hoverOnBox),"xVal"in t&&(e.x=t.xVal),"yVal"in t&&(e.y=t.yVal),t.xa&&(e.xaxis=t.xa),t.ya&&(e.yaxis=t.ya),e}},88203:(e,t,r)=>{"use strict";var n=r(85729),i=r(84468),o=r(32212),a=r(7605),s=i.fillText;function l(e,t,r,s){var l,c,u,d,h,p,f,m,g,y,v,x,b,_,w=e.cd,k=e.xa,S=e.ya,A=w[0].trace,T=w[0].t,M="violin"===A.type,C=T.bdPos,E=T.wHover,I=function(e){return u.c2l(e.pos)+T.bPos-u.c2l(p)};M&&"both"!==A.side?("positive"===A.side&&(g=function(e){var t=I(e);return o.inbox(t,t+E,y)},x=C,b=0),"negative"===A.side&&(g=function(e){var t=I(e);return o.inbox(t-E,t,y)},x=0,b=C)):(g=function(e){var t=I(e);return o.inbox(t-E,t+E,y)},x=b=C),_=M?function(e){return o.inbox(e.span[0]-h,e.span[1]-h,y)}:function(e){return o.inbox(e.min-h,e.max-h,y)},"h"===A.orientation?(h=t,p=r,f=_,m=g,l="y",u=S,c="x",d=k):(h=r,p=t,f=g,m=_,l="x",u=k,c="y",d=S);var P=Math.min(1,C/Math.abs(u.r2c(u.range[1])-u.r2c(u.range[0])));function O(e){return(f(e)+m(e))/2}y=e.maxHoverDistance-P,v=e.maxSpikeDistance-P;var R=o.getDistanceFunction(s,f,m,O);if(o.getClosest(w,R,e),!1===e.index)return[];var L=w[e.index],D=A.line.color,z=(A.marker||{}).color;a.opacity(D)&&A.line.width?e.color=D:a.opacity(z)&&A.boxpoints?e.color=z:e.color=A.fillcolor,e[l+"0"]=u.c2p(L.pos+T.bPos-b,!0),e[l+"1"]=u.c2p(L.pos+T.bPos+x,!0),e[l+"LabelVal"]=void 0!==L.orig_p?L.orig_p:L.pos;var j=l+"Spike";e.spikeDistance=O(L)*v/y,e[j]=u.c2p(L.pos,!0);var F=A.boxmean||"sd"===A.sizemode||(A.meanline||{}).visible,N=A.boxpoints||A.points,B=N&&F?["max","uf","q3","med","mean","q1","lf","min"]:N&&!F?["max","uf","q3","med","q1","lf","min"]:!N&&F?["max","q3","med","mean","q1","min"]:["max","q3","med","q1","min"],V=d.range[1]{"use strict";e.exports={attributes:r(46812),layoutAttributes:r(23031),supplyDefaults:r(27563).supplyDefaults,crossTraceDefaults:r(27563).crossTraceDefaults,supplyLayoutDefaults:r(85296).supplyLayoutDefaults,calc:r(66524),crossTraceCalc:r(11927).crossTraceCalc,plot:r(60110).plot,style:r(13684).style,styleOnSelect:r(13684).styleOnSelect,hoverPoints:r(88203).hoverPoints,eventData:r(22912),selectPoints:r(33341),moduleType:"trace",name:"box",basePlotModule:r(9510),categories:["cartesian","svg","symbols","oriented","box-violin","showLegend","boxLayout","zoomScale"],meta:{description:["Each box spans from quartile 1 (Q1) to quartile 3 (Q3).","The second quartile (Q2, i.e. the median) is marked by a line inside the box.","The fences grow outward from the boxes' edges,","by default they span +/- 1.5 times the interquartile range (IQR: Q3-Q1),","The sample mean and standard deviation as well as notches and","the sample, outlier and suspected outliers points can be optionally","added to the box plot.","The values and positions corresponding to each boxes can be input","using two signatures.","The first signature expects users to supply the sample values in the `y`","data array for vertical boxes (`x` for horizontal boxes).","By supplying an `x` (`y`) array, one box per distinct `x` (`y`) value is drawn","If no `x` (`y`) {array} is provided, a single box is drawn.","In this case, the box is positioned with the trace `name` or with `x0` (`y0`) if provided.","The second signature expects users to supply the boxes corresponding Q1, median and Q3","statistics in the `q1`, `median` and `q3` data arrays respectively.","Other box features relying on statistics namely `lowerfence`, `upperfence`, `notchspan`","can be set directly by the users.","To have plotly compute them or to show sample points besides the boxes,","users can set the `y` data array for vertical boxes (`x` for horizontal boxes)","to a 2D array with the outer length corresponding","to the number of boxes in the traces and the inner length corresponding the sample size."].join(" ")}}},23031:e=>{"use strict";e.exports={boxmode:{valType:"enumerated",values:["group","overlay"],dflt:"overlay",editType:"calc",description:["Determines how boxes at the same location coordinate","are displayed on the graph.","If *group*, the boxes are plotted next to one another","centered around the shared location.","If *overlay*, the boxes are plotted over one another,","you might need to set *opacity* to see them multiple boxes.","Has no effect on traces that have *width* set."].join(" ")},boxgap:{valType:"number",min:0,max:1,dflt:.3,editType:"calc",description:["Sets the gap (in plot fraction) between boxes of","adjacent location coordinates.","Has no effect on traces that have *width* set."].join(" ")},boxgroupgap:{valType:"number",min:0,max:1,dflt:.3,editType:"calc",description:["Sets the gap (in plot fraction) between boxes of","the same location coordinate.","Has no effect on traces that have *width* set."].join(" ")}}},85296:(e,t,r)=>{"use strict";var n=r(38361),i=r(84468),o=r(23031);function a(e,t,r,i,o){for(var a=o+"Layout",s=!1,l=0;l{"use strict";var n=r(41871),i=r(84468),o=r(3172);function a(e,t,r,o,a){var s,l,c="h"===r.orientation,u=t.val,d=t.pos,h=!!d.rangebreaks,p=o.bPos,f=o.wdPos||0,m=o.bPosPxOffset||0,g=r.whiskerwidth||0,y=!1!==r.showwhiskers,v=r.notched||!1,x=v?1-2*r.notchwidth:1;Array.isArray(o.bdPos)?(s=o.bdPos[0],l=o.bdPos[1]):(s=o.bdPos,l=o.bdPos);var b=e.selectAll("path.box").data("violin"!==r.type||r.box.visible?i.identity:[]);b.enter().append("path").style("vector-effect",a?"none":"non-scaling-stroke").attr("class","box"),b.exit().remove(),b.each((function(e){if(e.empty)return n.select(this).attr("d","M0,0Z");var t=d.c2l(e.pos+p,!0),o=d.l2p(t-s)+m,a=d.l2p(t+l)+m,b=h?(o+a)/2:d.l2p(t)+m,_=r.whiskerwidth,w=h?o*_+(1-_)*b:d.l2p(t-f)+m,k=h?a*_+(1-_)*b:d.l2p(t+f)+m,S=d.l2p(t-s*x)+m,A=d.l2p(t+l*x)+m,T="sd"===r.sizemode,M=u.c2p(T?e.mean-e.sd:e.q1,!0),C=T?u.c2p(e.mean+e.sd,!0):u.c2p(e.q3,!0),E=i.constrain(T?u.c2p(e.mean,!0):u.c2p(e.med,!0),Math.min(M,C)+1,Math.max(M,C)-1),I=void 0===e.lf||!1===r.boxpoints||T,P=u.c2p(I?e.min:e.lf,!0),O=u.c2p(I?e.max:e.uf,!0),R=u.c2p(e.ln,!0),L=u.c2p(e.un,!0);c?n.select(this).attr("d","M"+E+","+S+"V"+A+"M"+M+","+o+"V"+a+(v?"H"+R+"L"+E+","+A+"L"+L+","+a:"")+"H"+C+"V"+o+(v?"H"+L+"L"+E+","+S+"L"+R+","+o:"")+"Z"+(y?"M"+M+","+b+"H"+P+"M"+C+","+b+"H"+O+(0===g?"":"M"+P+","+w+"V"+k+"M"+O+","+w+"V"+k):"")):n.select(this).attr("d","M"+S+","+E+"H"+A+"M"+o+","+M+"H"+a+(v?"V"+R+"L"+A+","+E+"L"+a+","+L:"")+"V"+C+"H"+o+(v?"V"+L+"L"+S+","+E+"L"+o+","+R:"")+"Z"+(y?"M"+b+","+M+"V"+P+"M"+b+","+C+"V"+O+(0===g?"":"M"+w+","+P+"H"+k+"M"+w+","+O+"H"+k):""))}))}function s(e,t,r,n){var a=t.x,s=t.y,l=n.bdPos,c=n.bPos,u=r.boxpoints||r.points;i.seedPseudoRandom();var d=e.selectAll("g.points").data(u?function(e){return e.forEach((function(e){e.t=n,e.trace=r})),e}:[]);d.enter().append("g").attr("class","points"),d.exit().remove();var h=d.selectAll("path").data((function(e){var t,n,o=e.pts2,a=Math.max((e.max-e.min)/10,e.q3-e.q1),s=1e-9*a,d=.01*a,h=[],p=0;if(r.jitter){if(0===a)for(p=1,h=new Array(o.length),t=0;te.lo&&(x.so=!0)}return o}));h.enter().append("path").classed("point",!0),h.exit().remove(),h.call(o.translatePoints,a,s)}function l(e,t,r,o){var a,s,l=t.val,c=t.pos,u=!!c.rangebreaks,d=o.bPos,h=o.bPosPxOffset||0,p=r.boxmean||(r.meanline||{}).visible;Array.isArray(o.bdPos)?(a=o.bdPos[0],s=o.bdPos[1]):(a=o.bdPos,s=o.bdPos);var f=e.selectAll("path.mean").data("box"===r.type&&r.boxmean||"violin"===r.type&&r.box.visible&&r.meanline.visible?i.identity:[]);f.enter().append("path").attr("class","mean").style({fill:"none","vector-effect":"non-scaling-stroke"}),f.exit().remove(),f.each((function(e){var t=c.c2l(e.pos+d,!0),i=c.l2p(t-a)+h,o=c.l2p(t+s)+h,f=u?(i+o)/2:c.l2p(t)+h,m=l.c2p(e.mean,!0),g=l.c2p(e.mean-e.sd,!0),y=l.c2p(e.mean+e.sd,!0);"h"===r.orientation?n.select(this).attr("d","M"+m+","+i+"V"+o+("sd"===p?"m0,0L"+g+","+f+"L"+m+","+i+"L"+y+","+f+"Z":"")):n.select(this).attr("d","M"+i+","+m+"H"+o+("sd"===p?"m0,0L"+f+","+g+"L"+i+","+m+"L"+f+","+y+"Z":""))}))}e.exports={plot:function(e,t,r,o){var c=e._context.staticPlot,u=t.xaxis,d=t.yaxis;i.makeTraceGroups(o,r,"trace boxes").each((function(e){var t,r,i=n.select(this),o=e[0],h=o.t,p=o.trace;(h.wdPos=h.bdPos*p.whiskerwidth,!0!==p.visible||h.empty)?i.remove():("h"===p.orientation?(t=d,r=u):(t=u,r=d),a(i,{pos:t,val:r},p,h,c),s(i,{x:u,y:d},p,h),l(i,{pos:t,val:r},p,h))}))},plotBoxAndWhiskers:a,plotPoints:s,plotBoxMean:l}},33341:e=>{"use strict";e.exports=function(e,t){var r,n,i=e.cd,o=e.xaxis,a=e.yaxis,s=[];if(!1===t)for(r=0;r{"use strict";var n=r(41871),i=r(7605),o=r(3172);e.exports={style:function(e,t,r){var a=r||n.select(e).selectAll("g.trace.boxes");a.style("opacity",(function(e){return e[0].trace.opacity})),a.each((function(t){var r=n.select(this),a=t[0].trace,s=a.line.width;function l(e,t,r,n){e.style("stroke-width",t+"px").call(i.stroke,r).call(i.fill,n)}var c=r.selectAll("path.box");if("candlestick"===a.type)c.each((function(e){if(!e.empty){var t=n.select(this),r=a[e.dir];l(t,r.line.width,r.line.color,r.fillcolor),t.style("opacity",a.selectedpoints&&!e.selected?.3:1)}}));else{l(c,s,a.line.color,a.fillcolor),r.selectAll("path.mean").style({"stroke-width":s,"stroke-dasharray":2*s+"px,"+s+"px"}).call(i.stroke,a.line.color);var u=r.selectAll("path.point");o.pointStyle(u,a,e)}}))},styleOnSelect:function(e,t,r){var n=t[0].trace,i=r.selectAll("path.point");n.selectedpoints?o.selectedPointStyle(i,n):o.pointStyle(i,n,e)}}},17930:(e,t,r)=>{"use strict";var n=r(84468).extendFlat,i=r(39363).axisHoverFormat,o=r(46385),a=r(46812);function s(e){return{line:{color:n({},a.line.color,{dflt:e}),width:a.line.width,editType:"style"},fillcolor:a.fillcolor,editType:"style"}}e.exports={xperiod:o.xperiod,xperiod0:o.xperiod0,xperiodalignment:o.xperiodalignment,xhoverformat:i("x"),yhoverformat:i("y"),x:o.x,open:o.open,high:o.high,low:o.low,close:o.close,line:{width:n({},a.line.width,{description:[a.line.width.description,"Note that this style setting can also be set per","direction via `increasing.line.width` and","`decreasing.line.width`."].join(" ")}),editType:"style"},increasing:s(o.increasing.line.color.dflt),decreasing:s(o.decreasing.line.color.dflt),text:o.text,hovertext:o.hovertext,whiskerwidth:n({},a.whiskerwidth,{dflt:0}),hoverlabel:o.hoverlabel,zorder:a.zorder}},92966:(e,t,r)=>{"use strict";var n=r(84468),i=r(85729),o=r(35087),a=r(89717).calcCommon;function s(e,t,r,n){return{min:r,q1:Math.min(e,n),med:n,q3:Math.max(e,n),max:t}}e.exports=function(e,t){var r=e._fullLayout,l=i.getFromId(e,t.xaxis),c=i.getFromId(e,t.yaxis),u=l.makeCalcdata(t,"x"),d=o(t,l,"x",u).vals,h=a(e,t,u,d,c,s);return h.length?(n.extendFlat(h[0].t,{num:r._numBoxes,dPos:n.distinctVals(d).minDiff/2,posLetter:"x",valLetter:"y"}),r._numBoxes++,h):[{t:{empty:!0}}]}},16317:(e,t,r)=>{"use strict";var n=r(84468),i=r(7605),o=r(14771),a=r(26386),s=r(17930);function l(e,t,r,n){var o=r(n+".line.color");r(n+".line.width",t.line.width),r(n+".fillcolor",i.addOpacity(o,.5))}e.exports=function(e,t,r,i){function c(r,i){return n.coerce(e,t,s,r,i)}o(e,t,c,i)?(a(e,t,i,c,{x:!0}),c("xhoverformat"),c("yhoverformat"),c("line.width"),l(e,t,c,"increasing"),l(e,t,c,"decreasing"),c("text"),c("hovertext"),c("whiskerwidth"),i._requestRangeslider[t.xaxis]=!0,c("zorder")):t.visible=!1}},90195:(e,t,r)=>{"use strict";e.exports={moduleType:"trace",name:"candlestick",basePlotModule:r(9510),categories:["cartesian","svg","showLegend","candlestick","boxLayout"],meta:{description:["The candlestick is a style of financial chart describing","open, high, low and close for a given `x` coordinate (most likely time).","The boxes represent the spread between the `open` and `close` values and","the lines represent the spread between the `low` and `high` values","Sample points where the close value is higher (lower) then the open","value are called increasing (decreasing).","By default, increasing candles are drawn in green whereas","decreasing are drawn in red."].join(" ")},attributes:r(17930),layoutAttributes:r(23031),supplyLayoutDefaults:r(85296).supplyLayoutDefaults,crossTraceCalc:r(11927).crossTraceCalc,supplyDefaults:r(16317),calc:r(92966),plot:r(60110).plot,layerName:"boxlayer",style:r(13684).style,hoverPoints:r(45400).hoverPoints,selectPoints:r(39304)}},62237:(e,t,r)=>{"use strict";var n=r(74183),i=r(37091);e.exports=function(e,t,r,o,a){o("a")||(o("da"),o("a0")),o("b")||(o("db"),o("b0")),function(e,t,r,o){["aaxis","baxis"].forEach((function(a){var s=a.charAt(0),l=e[a]||{},c=i.newContainer(t,a),u={noAutotickangles:!0,noTicklabelshift:!0,noTicklabelstandoff:!0,noTicklabelstep:!0,tickfont:"x",id:s+"axis",letter:s,font:t.font,name:a,data:e[s],calendar:t.calendar,dfltColor:o,bgColor:r.paper_bgcolor,autotypenumbersDflt:r.autotypenumbers,fullLayout:r};n(l,c,u),c._categories=c._categories||[],e[a]||"-"===l.type||(e[a]={type:l.type})}))}(e,t,r,a)}},77983:(e,t,r)=>{"use strict";var n=r(84468).isArrayOrTypedArray;function i(e,t){if(!n(e)||t>=10)return null;for(var r=1/0,o=-1/0,a=e.length,s=0;s{"use strict";var n=r(91740),i=r(5808),o=r(17992),a=n({editType:"calc",description:"The default font used for axis & tick labels on this carpet"}),s=r(22049).zorder;a.family.dflt='"Open Sans", verdana, arial, sans-serif',a.size.dflt=12,a.color.dflt=o.defaultLine,e.exports={carpet:{valType:"string",editType:"calc",description:["An identifier for this carpet, so that `scattercarpet` and","`contourcarpet` traces can specify a carpet plot on which","they lie"].join(" ")},x:{valType:"data_array",editType:"calc+clearAxisTypes",description:["A two dimensional array of x coordinates at each carpet point.","If omitted, the plot is a cheater plot and the xaxis is hidden","by default."].join(" ")},y:{valType:"data_array",editType:"calc+clearAxisTypes",description:"A two dimensional array of y coordinates at each carpet point."},a:{valType:"data_array",editType:"calc",description:["An array containing values of the first parameter value"].join(" ")},a0:{valType:"number",dflt:0,editType:"calc",description:["Alternate to `a`.","Builds a linear space of a coordinates.","Use with `da`","where `a0` is the starting coordinate and `da` the step."].join(" ")},da:{valType:"number",dflt:1,editType:"calc",description:["Sets the a coordinate step.","See `a0` for more info."].join(" ")},b:{valType:"data_array",editType:"calc",description:"A two dimensional array of y coordinates at each carpet point."},b0:{valType:"number",dflt:0,editType:"calc",description:["Alternate to `b`.","Builds a linear space of a coordinates.","Use with `db`","where `b0` is the starting coordinate and `db` the step."].join(" ")},db:{valType:"number",dflt:1,editType:"calc",description:["Sets the b coordinate step.","See `b0` for more info."].join(" ")},cheaterslope:{valType:"number",dflt:1,editType:"calc",description:["The shift applied to each successive row of data in creating a cheater plot.","Only used if `x` is been omitted."].join(" ")},aaxis:i,baxis:i,font:a,color:{valType:"color",dflt:o.defaultLine,editType:"plot",description:["Sets default for all colors associated with this axis","all at once: line, font, tick, and grid colors.","Grid color is lightened by blending this with the plot background","Individual pieces can override this."].join(" ")},transforms:void 0,zorder:s}},26674:(e,t,r)=>{"use strict";var n=r(84468).isArrayOrTypedArray;e.exports=function(e,t,r,i){var o,a,s,l,c,u,d,h,p,f,m,g,y,v=n(r)?"a":"b",x=("a"===v?e.aaxis:e.baxis).smoothing,b="a"===v?e.a2i:e.b2j,_="a"===v?r:i,w="a"===v?i:r,k="a"===v?t.a.length:t.b.length,S="a"===v?t.b.length:t.a.length,A=Math.floor("a"===v?e.b2j(w):e.a2i(w)),T="a"===v?function(t){return e.evalxy([],t,A)}:function(t){return e.evalxy([],A,t)};x&&(s=Math.max(0,Math.min(S-2,A)),l=A-s,a="a"===v?function(t,r){return e.dxydi([],t,s,r,l)}:function(t,r){return e.dxydj([],s,t,l,r)});var M=b(_[0]),C=b(_[1]),E=M0?Math.floor:Math.ceil,O=E>0?Math.ceil:Math.floor,R=E>0?Math.min:Math.max,L=E>0?Math.max:Math.min,D=P(M+I),z=O(C-I),j=[[d=T(M)]];for(o=D;o*E{"use strict";var n=r(91740),i=r(17992),o=r(49080),a=r(39363).descriptionWithDates,s=r(72587).overrideAll,l=r(2703).T,c=r(64022).extendFlat;e.exports={color:{valType:"color",editType:"calc",description:["Sets default for all colors associated with this axis","all at once: line, font, tick, and grid colors.","Grid color is lightened by blending this with the plot background","Individual pieces can override this."].join(" ")},smoothing:{valType:"number",dflt:1,min:0,max:1.3,editType:"calc"},title:{text:{valType:"string",dflt:"",editType:"calc",description:["Sets the title of this axis.","Note that before the existence of `title.text`, the title's","contents used to be defined as the `title` attribute itself.","This behavior has been deprecated."].join(" ")},font:n({editType:"calc",description:["Sets this axis' title font.","Note that the title's font used to be set","by the now deprecated `titlefont` attribute."].join(" ")}),offset:{valType:"number",dflt:10,editType:"calc",description:["An additional amount by which to offset the title from the tick","labels, given in pixels.","Note that this used to be set","by the now deprecated `titleoffset` attribute."].join(" ")},editType:"calc"},type:{valType:"enumerated",values:["-","linear","date","category"],dflt:"-",editType:"calc",description:["Sets the axis type.","By default, plotly attempts to determined the axis type","by looking into the data of the traces that referenced","the axis in question."].join(" ")},autotypenumbers:o.autotypenumbers,autorange:{valType:"enumerated",values:[!0,!1,"reversed"],dflt:!0,editType:"calc",description:["Determines whether or not the range of this axis is","computed in relation to the input data.","See `rangemode` for more info.","If `range` is provided, then `autorange` is set to *false*."].join(" ")},rangemode:{valType:"enumerated",values:["normal","tozero","nonnegative"],dflt:"normal",editType:"calc",description:["If *normal*, the range is computed in relation to the extrema","of the input data.","If *tozero*`, the range extends to 0,","regardless of the input data","If *nonnegative*, the range is non-negative,","regardless of the input data."].join(" ")},range:{valType:"info_array",editType:"calc",items:[{valType:"any",editType:"calc"},{valType:"any",editType:"calc"}],description:["Sets the range of this axis.","If the axis `type` is *log*, then you must take the log of your","desired range (e.g. to set the range from 1 to 100,","set the range from 0 to 2).","If the axis `type` is *date*, it should be date strings,","like date data, though Date objects and unix milliseconds","will be accepted and converted to strings.","If the axis `type` is *category*, it should be numbers,","using the scale where each category is assigned a serial","number from zero in the order it appears."].join(" ")},fixedrange:{valType:"boolean",dflt:!1,editType:"calc",description:["Determines whether or not this axis is zoom-able.","If true, then zoom is disabled."].join(" ")},cheatertype:{valType:"enumerated",values:["index","value"],dflt:"value",editType:"calc"},tickmode:{valType:"enumerated",values:["linear","array"],dflt:"array",editType:"calc"},nticks:{valType:"integer",min:0,dflt:0,editType:"calc",description:["Specifies the maximum number of ticks for the particular axis.","The actual number of ticks will be chosen automatically to be","less than or equal to `nticks`.","Has an effect only if `tickmode` is set to *auto*."].join(" ")},tickvals:{valType:"data_array",editType:"calc",description:["Sets the values at which ticks on this axis appear.","Only has an effect if `tickmode` is set to *array*.","Used with `ticktext`."].join(" ")},ticktext:{valType:"data_array",editType:"calc",description:["Sets the text displayed at the ticks position via `tickvals`.","Only has an effect if `tickmode` is set to *array*.","Used with `tickvals`."].join(" ")},showticklabels:{valType:"enumerated",values:["start","end","both","none"],dflt:"start",editType:"calc",description:["Determines whether axis labels are drawn on the low side,","the high side, both, or neither side of the axis."].join(" ")},labelalias:c({},o.labelalias,{editType:"calc"}),tickfont:n({editType:"calc",description:"Sets the tick font."}),tickangle:{valType:"angle",dflt:"auto",editType:"calc",description:["Sets the angle of the tick labels with respect to the horizontal.","For example, a `tickangle` of -90 draws the tick labels","vertically."].join(" ")},tickprefix:{valType:"string",dflt:"",editType:"calc",description:"Sets a tick label prefix."},showtickprefix:{valType:"enumerated",values:["all","first","last","none"],dflt:"all",editType:"calc",description:["If *all*, all tick labels are displayed with a prefix.","If *first*, only the first tick is displayed with a prefix.","If *last*, only the last tick is displayed with a suffix.","If *none*, tick prefixes are hidden."].join(" ")},ticksuffix:{valType:"string",dflt:"",editType:"calc",description:"Sets a tick label suffix."},showticksuffix:{valType:"enumerated",values:["all","first","last","none"],dflt:"all",editType:"calc",description:"Same as `showtickprefix` but for tick suffixes."},showexponent:{valType:"enumerated",values:["all","first","last","none"],dflt:"all",editType:"calc",description:["If *all*, all exponents are shown besides their significands.","If *first*, only the exponent of the first tick is shown.","If *last*, only the exponent of the last tick is shown.","If *none*, no exponents appear."].join(" ")},exponentformat:{valType:"enumerated",values:["none","e","E","power","SI","B"],dflt:"B",editType:"calc",description:["Determines a formatting rule for the tick exponents.","For example, consider the number 1,000,000,000.","If *none*, it appears as 1,000,000,000.","If *e*, 1e+9.","If *E*, 1E+9.","If *power*, 1x10^9 (with 9 in a super script).","If *SI*, 1G.","If *B*, 1B."].join(" ")},minexponent:{valType:"number",dflt:3,min:0,editType:"calc",description:["Hide SI prefix for 10^n if |n| is below this number"].join(" ")},separatethousands:{valType:"boolean",dflt:!1,editType:"calc",description:['If "true", even 4-digit integers are separated'].join(" ")},tickformat:{valType:"string",dflt:"",editType:"calc",description:a("tick label")},tickformatstops:s(o.tickformatstops,"calc","from-root"),categoryorder:{valType:"enumerated",values:["trace","category ascending","category descending","array"],dflt:"trace",editType:"calc",description:["Specifies the ordering logic for the case of categorical variables.","By default, plotly uses *trace*, which specifies the order that is present in the data supplied.","Set `categoryorder` to *category ascending* or *category descending* if order should be determined by","the alphanumerical order of the category names.","Set `categoryorder` to *array* to derive the ordering from the attribute `categoryarray`. If a category","is not found in the `categoryarray` array, the sorting behavior for that attribute will be identical to","the *trace* mode. The unspecified categories will follow the categories in `categoryarray`."].join(" ")},categoryarray:{valType:"data_array",editType:"calc",description:["Sets the order in which categories on this axis appear.","Only has an effect if `categoryorder` is set to *array*.","Used with `categoryorder`."].join(" ")},labelpadding:{valType:"integer",dflt:10,editType:"calc",description:"Extra padding between label and the axis"},labelprefix:{valType:"string",editType:"calc",description:"Sets a axis label prefix."},labelsuffix:{valType:"string",dflt:"",editType:"calc",description:"Sets a axis label suffix."},showline:{valType:"boolean",dflt:!1,editType:"calc",description:["Determines whether or not a line bounding this axis is drawn."].join(" ")},linecolor:{valType:"color",dflt:i.defaultLine,editType:"calc",description:"Sets the axis line color."},linewidth:{valType:"number",min:0,dflt:1,editType:"calc",description:"Sets the width (in px) of the axis line."},gridcolor:{valType:"color",editType:"calc",description:"Sets the axis line color."},gridwidth:{valType:"number",min:0,dflt:1,editType:"calc",description:"Sets the width (in px) of the axis line."},griddash:c({},l,{editType:"calc"}),showgrid:{valType:"boolean",dflt:!0,editType:"calc",description:["Determines whether or not grid lines are drawn.","If *true*, the grid lines are drawn at every tick mark."].join(" ")},minorgridcount:{valType:"integer",min:0,dflt:0,editType:"calc",description:"Sets the number of minor grid ticks per major grid tick"},minorgridwidth:{valType:"number",min:0,dflt:1,editType:"calc",description:"Sets the width (in px) of the grid lines."},minorgriddash:c({},l,{editType:"calc"}),minorgridcolor:{valType:"color",dflt:i.lightLine,editType:"calc",description:"Sets the color of the grid lines."},startline:{valType:"boolean",editType:"calc",description:["Determines whether or not a line is drawn at along the starting value","of this axis.","If *true*, the start line is drawn on top of the grid lines."].join(" ")},startlinecolor:{valType:"color",editType:"calc",description:"Sets the line color of the start line."},startlinewidth:{valType:"number",dflt:1,editType:"calc",description:"Sets the width (in px) of the start line."},endline:{valType:"boolean",editType:"calc",description:["Determines whether or not a line is drawn at along the final value","of this axis.","If *true*, the end line is drawn on top of the grid lines."].join(" ")},endlinewidth:{valType:"number",dflt:1,editType:"calc",description:"Sets the width (in px) of the end line."},endlinecolor:{valType:"color",editType:"calc",description:"Sets the line color of the end line."},tick0:{valType:"number",min:0,dflt:0,editType:"calc",description:"The starting index of grid lines along the axis"},dtick:{valType:"number",min:0,dflt:1,editType:"calc",description:"The stride between grid lines along the axis"},arraytick0:{valType:"integer",min:0,dflt:0,editType:"calc",description:"The starting index of grid lines along the axis"},arraydtick:{valType:"integer",min:1,dflt:1,editType:"calc",description:"The stride between grid lines along the axis"},_deprecated:{title:{valType:"string",editType:"calc",description:["Deprecated in favor of `title.text`.","Note that value of `title` is no longer a simple","*string* but a set of sub-attributes."].join(" ")},titlefont:n({editType:"calc",description:"Deprecated in favor of `title.font`."}),titleoffset:{valType:"number",dflt:10,editType:"calc",description:"Deprecated in favor of `title.offset`."}},editType:"calc"}},74183:(e,t,r)=>{"use strict";var n=r(39462),i=r(7605).addOpacity,o=r(38361),a=r(84468),s=r(43452),l=r(83193),c=r(89655),u=r(74128),d=r(45958),h=r(84339);e.exports=function(e,t,r){var p=r.letter,f=r.font||{},m=n[p+"axis"];function g(r,n){return a.coerce(e,t,m,r,n)}function y(r,n){return a.coerce2(e,t,m,r,n)}r.name&&(t._name=r.name,t._id=r.name),g("autotypenumbers",r.autotypenumbersDflt);var v=g("type");("-"===v&&(r.data&&function(e,t){if("-"!==e.type)return;var r=e._id.charAt(0),n=e[r+"calendar"];e.type=h(t,n,{autotypenumbers:e.autotypenumbers})}(t,r.data),"-"===t.type?t.type="linear":v=e.type=t.type),g("smoothing"),g("cheatertype"),g("showticklabels"),g("labelprefix",p+" = "),g("labelsuffix"),g("showtickprefix"),g("showticksuffix"),g("separatethousands"),g("tickformat"),g("exponentformat"),g("minexponent"),g("showexponent"),g("categoryorder"),g("tickmode"),g("tickvals"),g("ticktext"),g("tick0"),g("dtick"),"array"===t.tickmode&&(g("arraytick0"),g("arraydtick")),g("labelpadding"),t._hovertitle=p,"date"===v)&&o.getComponentMethod("calendars","handleDefaults")(e,t,"calendar",r.calendar);d(t,r.fullLayout),t.c2p=a.identity;var x=g("color",r.dfltColor),b=x===e.color?x:f.color;g("title.text")&&(a.coerceFont(g,"title.font",f,{overrideDflt:{size:a.bigFont(f.size),color:b}}),g("title.offset")),g("tickangle"),g("autorange",!t.isValidRange(e.range))&&g("rangemode"),g("range"),t.cleanRange(),g("fixedrange"),s(e,t,g,v),c(e,t,g,v,r),l(e,t,g,v,r),u(e,t,g,{data:r.data,dataAttr:p});var _=y("gridcolor",i(x,.3)),w=y("gridwidth"),k=y("griddash"),S=g("showgrid");S||(delete t.gridcolor,delete t.gridwidth,delete t.griddash);var A=y("startlinecolor",x),T=y("startlinewidth",w);g("startline",t.showgrid||!!A||!!T)||(delete t.startlinecolor,delete t.startlinewidth);var M=y("endlinecolor",x),C=y("endlinewidth",w);return g("endline",t.showgrid||!!M||!!C)||(delete t.endlinecolor,delete t.endlinewidth),S?(g("minorgridcount"),g("minorgridwidth",w),g("minorgriddash",k),g("minorgridcolor",i(_,.06)),t.minorgridcount||(delete t.minorgridwidth,delete t.minorgriddash,delete t.minorgridcolor)):(delete t.gridcolor,delete t.gridwidth,delete t.griddash),"none"===t.showticklabels&&(delete t.tickfont,delete t.tickangle,delete t.showexponent,delete t.exponentformat,delete t.minexponent,delete t.tickformat,delete t.showticksuffix,delete t.showtickprefix),t.showticksuffix||delete t.ticksuffix,t.showtickprefix||delete t.tickprefix,g("tickmode"),t}},45602:(e,t,r)=>{"use strict";var n=r(85729),i=r(84468).isArray1D,o=r(75958),a=r(77983),s=r(9562),l=r(24914),c=r(87944),u=r(15200),d=r(70788),h=r(31828),p=r(49891);e.exports=function(e,t){var r=n.getFromId(e,t.xaxis),f=n.getFromId(e,t.yaxis),m=t.aaxis,g=t.baxis,y=t.x,v=t.y,x=[];y&&i(y)&&x.push("x"),v&&i(v)&&x.push("y"),x.length&&h(t,m,g,"a","b",x);var b=t._a=t._a||t.a,_=t._b=t._b||t.b;y=t._x||t.x,v=t._y||t.y;var w={};if(t._cheater){var k="index"===m.cheatertype?b.length:b,S="index"===g.cheatertype?_.length:_;y=o(k,S,t.cheaterslope)}t._x=y=u(y),t._y=v=u(v),d(y,b,_),d(v,b,_),p(t),t.setScale();var A=a(y),T=a(v),M=.5*(A[1]-A[0]),C=.5*(A[1]+A[0]),E=.5*(T[1]-T[0]),I=.5*(T[1]+T[0]),P=1.3;return A=[C-M*P,C+M*P],T=[I-E*P,I+E*P],t._extremes[r._id]=n.findExtremes(r,A,{padded:!0}),t._extremes[f._id]=n.findExtremes(f,T,{padded:!0}),s(t,"a","b"),s(t,"b","a"),l(t,m),l(t,g),w.clipsegments=c(t._xctrl,t._yctrl,m,g),w.x=y,w.y=v,w.a=b,w.b=_,[w]}},87944:e=>{"use strict";e.exports=function(e,t,r,n){var i,o,a,s=[],l=!!r.smoothing,c=!!n.smoothing,u=e[0].length-1,d=e.length-1;for(i=0,o=[],a=[];i<=u;i++)o[i]=e[0][i],a[i]=t[0][i];for(s.push({x:o,y:a,bicubic:l}),i=0,o=[],a=[];i<=d;i++)o[i]=e[i][u],a[i]=t[i][u];for(s.push({x:o,y:a,bicubic:c}),i=u,o=[],a=[];i>=0;i--)o[u-i]=e[d][i],a[u-i]=t[d][i];for(s.push({x:o,y:a,bicubic:l}),i=d,o=[],a=[];i>=0;i--)o[d-i]=e[i][0],a[d-i]=t[i][0];return s.push({x:o,y:a,bicubic:c}),s}},9562:(e,t,r)=>{"use strict";var n=r(85729),i=r(64022).extendFlat;e.exports=function(e,t,r){var o,a,s,l,c,u,d,h,p,f,m,g,y,v,x=e["_"+t],b=e[t+"axis"],_=b._gridlines=[],w=b._minorgridlines=[],k=b._boundarylines=[],S=e["_"+r],A=e[r+"axis"];"array"===b.tickmode&&(b.tickvals=x.slice());var T=e._xctrl,M=e._yctrl,C=T[0].length,E=T.length,I=e._a.length,P=e._b.length;n.prepTicks(b),"array"===b.tickmode&&delete b.tickvals;var O=b.smoothing?3:1;function R(n){var i,o,a,s,l,c,u,d,p,f,m,g,y=[],v=[],x={};if("b"===t)for(o=e.b2j(n),a=Math.floor(Math.max(0,Math.min(P-2,o))),s=o-a,x.length=P,x.crossLength=I,x.xy=function(t){return e.evalxy([],t,o)},x.dxy=function(t,r){return e.dxydi([],t,a,r,s)},i=0;i0&&(p=e.dxydi([],i-1,a,0,s),y.push(l[0]+p[0]/3),v.push(l[1]+p[1]/3),f=e.dxydi([],i-1,a,1,s),y.push(d[0]-f[0]/3),v.push(d[1]-f[1]/3)),y.push(d[0]),v.push(d[1]),l=d;else for(i=e.a2i(n),c=Math.floor(Math.max(0,Math.min(I-2,i))),u=i-c,x.length=I,x.crossLength=P,x.xy=function(t){return e.evalxy([],i,t)},x.dxy=function(t,r){return e.dxydj([],c,t,u,r)},o=0;o0&&(m=e.dxydj([],c,o-1,u,0),y.push(l[0]+m[0]/3),v.push(l[1]+m[1]/3),g=e.dxydj([],c,o-1,u,1),y.push(d[0]-g[0]/3),v.push(d[1]-g[1]/3)),y.push(d[0]),v.push(d[1]),l=d;return x.axisLetter=t,x.axis=b,x.crossAxis=A,x.value=n,x.constvar=r,x.index=h,x.x=y,x.y=v,x.smoothing=A.smoothing,x}function L(n){var i,o,a,s,l,c=[],u=[],d={};if(d.length=x.length,d.crossLength=S.length,"b"===t)for(a=Math.max(0,Math.min(P-2,n)),l=Math.min(1,Math.max(0,n-a)),d.xy=function(t){return e.evalxy([],t,n)},d.dxy=function(t,r){return e.dxydi([],t,a,r,l)},i=0;ix.length-1||_.push(i(L(a),{color:b.gridcolor,width:b.gridwidth,dash:b.griddash}));for(h=u;hx.length-1)&&!(m<0||m>x.length-1))for(g=x[s],y=x[m],o=0;ox[x.length-1]||w.push(i(R(f),{color:b.minorgridcolor,width:b.minorgridwidth,dash:b.minorgriddash}));b.startline&&k.push(i(L(0),{color:b.startlinecolor,width:b.startlinewidth})),b.endline&&k.push(i(L(x.length-1),{color:b.endlinecolor,width:b.endlinewidth}))}else{for(l=5e-15,u=(c=[Math.floor((x[x.length-1]-b.tick0)/b.dtick*(1+l)),Math.ceil((x[0]-b.tick0)/b.dtick/(1+l))].sort((function(e,t){return e-t})))[0],d=c[1],h=u;h<=d;h++)p=b.tick0+b.dtick*h,_.push(i(R(p),{color:b.gridcolor,width:b.gridwidth,dash:b.griddash}));for(h=u-1;hx[x.length-1]||w.push(i(R(f),{color:b.minorgridcolor,width:b.minorgridwidth,dash:b.minorgriddash}));b.startline&&k.push(i(R(x[0]),{color:b.startlinecolor,width:b.startlinewidth})),b.endline&&k.push(i(R(x[x.length-1]),{color:b.endlinecolor,width:b.endlinewidth}))}}},24914:(e,t,r)=>{"use strict";var n=r(85729),i=r(64022).extendFlat;e.exports=function(e,t){var r,o,a,s=t._labels=[],l=t._gridlines;for(r=0;r{"use strict";e.exports=function(e,t,r,n){var i=e[0]-t[0],o=e[1]-t[1],a=r[0]-t[0],s=r[1]-t[1],l=Math.pow(i*i+o*o,.25),c=Math.pow(a*a+s*s,.25),u=(c*c*i-l*l*a)*n,d=(c*c*o-l*l*s)*n,h=c*(l+c)*3,p=l*(l+c)*3;return[[t[0]+(h&&u/h),t[1]+(h&&d/h)],[t[0]-(p&&u/p),t[1]-(p&&d/p)]]}},75958:(e,t,r)=>{"use strict";var n=r(84468).isArrayOrTypedArray;e.exports=function(e,t,r){var i,o,a,s,l,c,u=[],d=n(e)?e.length:e,h=n(t)?t.length:t,p=n(e)?e:null,f=n(t)?t:null;p&&(a=(p.length-1)/(p[p.length-1]-p[0])/(d-1)),f&&(s=(f.length-1)/(f[f.length-1]-f[0])/(h-1));var m=1/0,g=-1/0;for(o=0;o{"use strict";var n=r(54304),i=r(84468).ensureArray;function o(e,t,r){var n=-.5*r[0]+1.5*t[0],i=-.5*r[1]+1.5*t[1];return[(2*n+e[0])/3,(2*i+e[1])/3]}e.exports=function(e,t,r,a,s,l){var c,u,d,h,p,f,m,g,y,v,x=r[0].length,b=r.length,_=s?3*x-2:x,w=l?3*b-2:b;for(e=i(e,w),t=i(t,w),d=0;d{"use strict";e.exports={RELATIVE_CULL_TOLERANCE:1e-6}},12889:e=>{"use strict";e.exports=function(e,t,r){return t&&r?function(t,r,n,i,o){var a,s,l,c,u,d;t||(t=[]),r*=3,n*=3;var h=i*i,p=1-i,f=p*p,m=p*i*2,g=-3*f,y=3*(f-m),v=3*(m-h),x=3*h,b=o*o,_=b*o,w=1-o,k=w*w,S=k*w;for(d=0;d{"use strict";e.exports=function(e,t,r){return t&&r?function(t,r,n,i,o){var a,s,l,c,u,d;t||(t=[]),r*=3,n*=3;var h=i*i,p=h*i,f=1-i,m=f*f,g=m*f,y=o*o,v=1-o,x=v*v,b=v*o*2,_=-3*x,w=3*(x-b),k=3*(b-y),S=3*y;for(d=0;d{"use strict";e.exports=function(e,t,r,n,i){var o=t-2,a=r-2;return n&&i?function(t,r,n){var i,s,l,c,u,d;t||(t=[]);var h=Math.max(0,Math.min(Math.floor(r),o)),p=Math.max(0,Math.min(Math.floor(n),a)),f=Math.max(0,Math.min(1,r-h)),m=Math.max(0,Math.min(1,n-p));h*=3,p*=3;var g=f*f,y=g*f,v=1-f,x=v*v,b=x*v,_=m*m,w=_*m,k=1-m,S=k*k,A=S*k;for(d=0;d{"use strict";var n=r(84468),i=r(67773),o=r(62237),a=r(39462),s=r(17992);e.exports=function(e,t,r,l){function c(r,i){return n.coerce(e,t,a,r,i)}t._clipPathId="clip"+t.uid+"carpet";var u=c("color",s.defaultLine);(n.coerceFont(c,"font",l.font),c("carpet"),o(e,t,l,c,u),t.a&&t.b)?(t.a.length<3&&(t.aaxis.smoothing=0),t.b.length<3&&(t.baxis.smoothing=0),i(e,t,c)||(t.visible=!1),t._cheater&&c("cheaterslope"),c("zorder")):t.visible=!1}},57879:(e,t,r)=>{"use strict";e.exports={attributes:r(39462),supplyDefaults:r(88049),plot:r(42656),calc:r(45602),animatable:!0,isContainer:!0,moduleType:"trace",name:"carpet",basePlotModule:r(9510),categories:["cartesian","svg","carpet","carpetAxis","notLegendIsolatable","noMultiCategory","noHover","noSortingByValue"],meta:{description:["The data describing carpet axis layout is set in `y` and (optionally)","also `x`. If only `y` is present, `x` the plot is interpreted as a","cheater plot and is filled in using the `y` values.","`x` and `y` may either be 2D arrays matching with each dimension matching","that of `a` and `b`, or they may be 1D arrays with total length equal to","that of `a` and `b`."].join(" ")}}},35738:e=>{"use strict";e.exports=function(e,t){for(var r,n=e._fullData.length,i=0;i{"use strict";e.exports=function(e,t,r){if(0===e.length)return"";var n,i=[],o=r?3:1;for(n=0;n{"use strict";var n=r(84468).isArrayOrTypedArray;e.exports=function(e,t,r){var i;for(n(e)?e.length>t.length&&(e=e.slice(0,t.length)):e=[],i=0;i{"use strict";e.exports=function(e,t,r,n,i,o){var a=i[0]*e.dpdx(t),s=i[1]*e.dpdy(r),l=1,c=1;if(o){var u=Math.sqrt(i[0]*i[0]+i[1]*i[1]),d=Math.sqrt(o[0]*o[0]+o[1]*o[1]),h=(i[0]*o[0]+i[1]*o[1])/u/d;c=Math.max(0,h)}var p=180*Math.atan2(s,a)/Math.PI;return p<-90?(p+=180,l=-l):p>90&&(p-=180,l=-l),{angle:p,flip:l,p:e.c2p(n,t,r),offsetMultplier:c}}},42656:(e,t,r)=>{"use strict";var n=r(41871),i=r(3172),o=r(87435),a=r(38166),s=r(59838),l=r(13480),c=r(84468),u=c.strRotate,d=c.strTranslate,h=r(83943);function p(e,t,r,s,l,c,u){var d="const-"+l+"-lines",h=r.selectAll("."+d).data(c);h.enter().append("path").classed(d,!0).style("vector-effect",u?"none":"non-scaling-stroke"),h.each((function(r){var s=r,l=s.x,c=s.y,u=o([],l,e.c2p),d=o([],c,t.c2p),h="M"+a(u,d,s.smoothing);n.select(this).attr("d",h).style("stroke-width",s.width).style("stroke",s.color).style("stroke-dasharray",i.dashStyle(s.dash,s.width)).style("fill","none")})),h.exit().remove()}function f(e,t,r,o,a,c,h,p){var f=c.selectAll("text."+p).data(h);f.enter().append("text").classed(p,!0);var m=0,g={};return f.each((function(a,c){var h;if("auto"===a.axis.tickangle)h=s(o,t,r,a.xy,a.dxy);else{var p=(a.axis.tickangle+180)*Math.PI/180;h=s(o,t,r,a.xy,[Math.cos(p),Math.sin(p)])}c||(g={angle:h.angle,flip:h.flip});var f=(a.endAnchor?-1:1)*h.flip,y=n.select(this).attr({"text-anchor":f>0?"start":"end","data-notex":1}).call(i.font,a.font).text(a.text).call(l.convertToTspans,e),v=i.bBox(this);y.attr("transform",d(h.p[0],h.p[1])+u(h.angle)+d(a.axis.labelpadding*f,.3*v.height)),m=Math.max(m,v.width+a.axis.labelpadding)})),f.exit().remove(),g.maxExtent=m,g}e.exports=function(e,t,r,i){var l=e._context.staticPlot,u=t.xaxis,d=t.yaxis,h=e._fullLayout._clips;c.makeTraceGroups(i,r,"trace").each((function(t){var r=n.select(this),i=t[0],m=i.trace,g=m.aaxis,v=m.baxis,x=c.ensureSingle(r,"g","minorlayer"),b=c.ensureSingle(r,"g","majorlayer"),_=c.ensureSingle(r,"g","boundarylayer"),w=c.ensureSingle(r,"g","labellayer");r.style("opacity",m.opacity),p(u,d,b,g,"a",g._gridlines,!0),p(u,d,b,v,"b",v._gridlines,!0),p(u,d,x,g,"a",g._minorgridlines,!0),p(u,d,x,v,"b",v._minorgridlines,!0),p(u,d,_,g,"a-boundary",g._boundarylines,l),p(u,d,_,v,"b-boundary",v._boundarylines,l);var k=f(e,u,d,m,i,w,g._labels,"a-label"),S=f(e,u,d,m,i,w,v._labels,"b-label");!function(e,t,r,n,i,o,a,l){var u,d,h,p,f=c.aggNums(Math.min,null,r.a),m=c.aggNums(Math.max,null,r.a),g=c.aggNums(Math.min,null,r.b),v=c.aggNums(Math.max,null,r.b);u=.5*(f+m),d=g,h=r.ab2xy(u,d,!0),p=r.dxyda_rough(u,d),void 0===a.angle&&c.extendFlat(a,s(r,i,o,h,r.dxydb_rough(u,d)));y(e,t,r,n,h,p,r.aaxis,i,o,a,"a-title"),u=f,d=.5*(g+v),h=r.ab2xy(u,d,!0),p=r.dxydb_rough(u,d),void 0===l.angle&&c.extendFlat(l,s(r,i,o,h,r.dxyda_rough(u,d)));y(e,t,r,n,h,p,r.baxis,i,o,l,"b-title")}(e,w,m,i,u,d,k,S),function(e,t,r,n,i){var s,l,u,d,h=r.select("#"+e._clipPathId);h.size()||(h=r.append("clipPath").classed("carpetclip",!0));var p=c.ensureSingle(h,"path","carpetboundary"),f=t.clipsegments,m=[];for(d=0;d90&&v<270,b=n.select(this);b.text(h.title.text).call(l.convertToTspans,e),x&&(_=(-l.lineCount(b)+g)*m*o-_),b.attr("transform",d(t.p[0],t.p[1])+u(t.angle)+d(0,_)).attr("text-anchor","middle").call(i.font,h.title.font)})),b.exit().remove()}},49891:(e,t,r)=>{"use strict";var n=r(73338),i=r(41222).findBin,o=r(34120),a=r(18230),s=r(12889),l=r(18758);e.exports=function(e){var t=e._a,r=e._b,c=t.length,u=r.length,d=e.aaxis,h=e.baxis,p=t[0],f=t[c-1],m=r[0],g=r[u-1],y=t[t.length-1]-t[0],v=r[r.length-1]-r[0],x=y*n.RELATIVE_CULL_TOLERANCE,b=v*n.RELATIVE_CULL_TOLERANCE;p-=x,f+=x,m-=b,g+=b,e.isVisible=function(e,t){return e>p&&em&&tf||tg},e.setScale=function(){var t=e._x,r=e._y,n=o(e._xctrl,e._yctrl,t,r,d.smoothing,h.smoothing);e._xctrl=n[0],e._yctrl=n[1],e.evalxy=a([e._xctrl,e._yctrl],c,u,d.smoothing,h.smoothing),e.dxydi=s([e._xctrl,e._yctrl],d.smoothing,h.smoothing),e.dxydj=l([e._xctrl,e._yctrl],d.smoothing,h.smoothing)},e.i2a=function(e){var r=Math.max(0,Math.floor(e[0]),c-2),n=e[0]-r;return(1-n)*t[r]+n*t[r+1]},e.j2b=function(e){var t=Math.max(0,Math.floor(e[1]),c-2),n=e[1]-t;return(1-n)*r[t]+n*r[t+1]},e.ij2ab=function(t){return[e.i2a(t[0]),e.j2b(t[1])]},e.a2i=function(e){var r=Math.max(0,Math.min(i(e,t),c-2)),n=t[r],o=t[r+1];return Math.max(0,Math.min(c-1,r+(e-n)/(o-n)))},e.b2j=function(e){var t=Math.max(0,Math.min(i(e,r),u-2)),n=r[t],o=r[t+1];return Math.max(0,Math.min(u-1,t+(e-n)/(o-n)))},e.ab2ij=function(t){return[e.a2i(t[0]),e.b2j(t[1])]},e.i2c=function(t,r){return e.evalxy([],t,r)},e.ab2xy=function(n,i,o){if(!o&&(nt[c-1]|ir[u-1]))return[!1,!1];var a=e.a2i(n),s=e.b2j(i),l=e.evalxy([],a,s);if(o){var d,h,p,f,m=0,g=0,y=[];nt[c-1]?(d=c-2,h=1,m=(n-t[c-1])/(t[c-1]-t[c-2])):h=a-(d=Math.max(0,Math.min(c-2,Math.floor(a)))),ir[u-1]?(p=u-2,f=1,g=(i-r[u-1])/(r[u-1]-r[u-2])):f=s-(p=Math.max(0,Math.min(u-2,Math.floor(s)))),m&&(e.dxydi(y,d,p,h,f),l[0]+=y[0]*m,l[1]+=y[1]*m),g&&(e.dxydj(y,d,p,h,f),l[0]+=y[0]*g,l[1]+=y[1]*g)}return l},e.c2p=function(e,t,r){return[t.c2p(e[0]),r.c2p(e[1])]},e.p2x=function(e,t,r){return[t.p2c(e[0]),r.p2c(e[1])]},e.dadi=function(e){var r=Math.max(0,Math.min(t.length-2,e));return t[r+1]-t[r]},e.dbdj=function(e){var t=Math.max(0,Math.min(r.length-2,e));return r[t+1]-r[t]},e.dxyda=function(t,r,n,i){var o=e.dxydi(null,t,r,n,i),a=e.dadi(t,n);return[o[0]/a,o[1]/a]},e.dxydb=function(t,r,n,i){var o=e.dxydj(null,t,r,n,i),a=e.dbdj(r,i);return[o[0]/a,o[1]/a]},e.dxyda_rough=function(t,r,n){var i=y*(n||.1),o=e.ab2xy(t+i,r,!0),a=e.ab2xy(t-i,r,!0);return[.5*(o[0]-a[0])/i,.5*(o[1]-a[1])/i]},e.dxydb_rough=function(t,r,n){var i=v*(n||.1),o=e.ab2xy(t,r+i,!0),a=e.ab2xy(t,r-i,!0);return[.5*(o[0]-a[0])/i,.5*(o[1]-a[1])/i]},e.dpdx=function(e){return e._m},e.dpdy=function(e){return e._m}}},70788:(e,t,r)=>{"use strict";var n=r(84468);e.exports=function(e,t,r){var i,o,a,s=[],l=[],c=e[0].length,u=e.length;function d(t,r){var n,i=0,o=0;return t>0&&void 0!==(n=e[r][t-1])&&(o++,i+=n),t0&&void 0!==(n=e[r-1][t])&&(o++,i+=n),r0&&o0&&i1e-5);return n.log("Smoother converged to",S,"after",A,"iterations"),e}},67773:(e,t,r)=>{"use strict";var n=r(84468).isArray1D;e.exports=function(e,t,r){var i=r("x"),o=i&&i.length,a=r("y"),s=a&&a.length;if(!o&&!s)return!1;if(t._cheater=!i,o&&!n(i)||s&&!n(a))t._length=null;else{var l=o?i.length:1/0;s&&(l=Math.min(l,a.length)),t.a&&t.a.length&&(l=Math.min(l,t.a.length)),t.b&&t.b.length&&(l=Math.min(l,t.b.length)),t._length=l}return!0}},5169:(e,t,r)=>{"use strict";var n=r(84425).rb,i=r(16490),o=r(6636),a=r(75622),s=r(17992).defaultLine,l=r(64022).extendFlat,c=i.marker.line;e.exports=l({locations:{valType:"data_array",editType:"calc",description:["Sets the coordinates via location IDs or names.","See `locationmode` for more info."].join(" ")},locationmode:i.locationmode,z:{valType:"data_array",editType:"calc",description:"Sets the color values."},geojson:l({},i.geojson,{description:["Sets optional GeoJSON data associated with this trace.","If not given, the features on the base map are used.","It can be set as a valid GeoJSON object or as a URL string.","Note that we only accept GeoJSONs of type *FeatureCollection* or *Feature*","with geometries of type *Polygon* or *MultiPolygon*."].join(" ")}),featureidkey:i.featureidkey,text:l({},i.text,{description:"Sets the text elements associated with each location."}),hovertext:l({},i.hovertext,{description:"Same as `text`."}),marker:{line:{color:l({},c.color,{dflt:s}),width:l({},c.width,{dflt:1}),editType:"calc"},opacity:{valType:"number",arrayOk:!0,min:0,max:1,dflt:1,editType:"style",description:"Sets the opacity of the locations."},editType:"calc"},selected:{marker:{opacity:i.selected.marker.opacity,editType:"plot"},editType:"plot"},unselected:{marker:{opacity:i.unselected.marker.opacity,editType:"plot"},editType:"plot"},hoverinfo:l({},a.hoverinfo,{editType:"calc",flags:["location","z","text","name"]}),hovertemplate:n(),showlegend:l({},a.showlegend,{dflt:!1})},o("",{cLetter:"z",editTypeOverride:"calc"}))},71861:(e,t,r)=>{"use strict";var n=r(22036),i=r(65004).BADNUM,o=r(95500),a=r(24294),s=r(40304);function l(e){return e&&"string"===typeof e}e.exports=function(e,t){var r,c=t._length,u=new Array(c);r=t.geojson?function(e){return l(e)||n(e)}:l;for(var d=0;d{"use strict";var n=r(84468),i=r(16155),o=r(5169);e.exports=function(e,t,r,a){function s(r,i){return n.coerce(e,t,o,r,i)}var l=s("locations"),c=s("z");if(l&&l.length&&n.isArrayOrTypedArray(c)&&c.length){t._length=Math.min(l.length,c.length);var u,d=s("geojson");("string"===typeof d&&""!==d||n.isPlainObject(d))&&(u="geojson-id"),"geojson-id"===s("locationmode",u)&&s("featureidkey"),s("text"),s("hovertext"),s("hovertemplate"),s("marker.line.width")&&s("marker.line.color"),s("marker.opacity"),i(e,t,a,s,{prefix:"",cLetter:"z"}),n.coerceSelectionMarkerOpacity(t,s)}else t.visible=!1}},621:e=>{"use strict";e.exports=function(e,t,r,n,i){e.location=t.location,e.z=t.z;var o=n[i];return o.fIn&&o.fIn.properties&&(e.properties=o.fIn.properties),e.ct=o.ct,e}},81880:(e,t,r)=>{"use strict";var n=r(85729),i=r(5169),o=r(84468).fillText;e.exports=function(e,t,r){var a,s,l,c,u=e.cd,d=u[0].trace,h=e.subplot,p=[t,r],f=[t+360,r];for(s=0;s")}(e,d,a),[e]}},24226:(e,t,r)=>{"use strict";e.exports={attributes:r(5169),supplyDefaults:r(29782),colorbar:r(11610),calc:r(71861),calcGeoJSON:r(77851).calcGeoJSON,plot:r(77851).plot,style:r(30411).style,styleOnSelect:r(30411).styleOnSelect,hoverPoints:r(81880),eventData:r(621),selectPoints:r(76712),moduleType:"trace",name:"choropleth",basePlotModule:r(81073),categories:["geo","noOpacity","showLegend"],meta:{description:["The data that describes the choropleth value-to-color mapping","is set in `z`.","The geographic locations corresponding to each value in `z`","are set in `locations`."].join(" ")}}},77851:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468),o=r(63925),a=r(76621).getTopojsonFeatures,s=r(49618).findExtremes,l=r(30411).style;e.exports={calcGeoJSON:function(e,t){for(var r=e[0].trace,n=t[r.geo],i=n._subplot,l=r.locationmode,c=r._length,u="geojson-id"===l?o.extractTraceFeature(e):a(r,i.topojson),d=[],h=[],p=0;p{"use strict";e.exports=function(e,t){var r,n,i,o,a,s=e.cd,l=e.xaxis,c=e.yaxis,u=[];if(!1===t)for(r=0;r{"use strict";var n=r(41871),i=r(7605),o=r(3172),a=r(39265);function s(e,t){var r=t[0].trace,s=t[0].node3.selectAll(".choroplethlocation"),l=r.marker||{},c=l.line||{},u=a.makeColorScaleFuncFromTrace(r);s.each((function(e){n.select(this).attr("fill",u(e.z)).call(i.stroke,e.mlc||c.color).call(o.dashLine,"",e.mlw||c.width||0).style("opacity",l.opacity)})),o.selectedPointStyle(s,r)}e.exports={style:function(e,t){t&&s(e,t)},styleOnSelect:function(e,t){var r=t[0].node3,n=t[0].trace;n.selectedpoints?o.selectedPointStyle(r.selectAll(".choroplethlocation"),n):s(0,t)}}},76899:(e,t,r)=>{"use strict";var n=r(5169),i=r(6636),o=r(84425).rb,a=r(75622),s=r(64022).extendFlat;e.exports=s({locations:{valType:"data_array",editType:"calc",description:["Sets which features found in *geojson* to plot using","their feature `id` field."].join(" ")},z:{valType:"data_array",editType:"calc",description:"Sets the color values."},geojson:{valType:"any",editType:"calc",description:["Sets the GeoJSON data associated with this trace.","It can be set as a valid GeoJSON object or as a URL string.","Note that we only accept GeoJSONs of type *FeatureCollection* or *Feature*","with geometries of type *Polygon* or *MultiPolygon*."].join(" ")},featureidkey:s({},n.featureidkey,{description:["Sets the key in GeoJSON features which is used as id to match the items","included in the `locations` array.","Support nested property, for example *properties.name*."].join(" ")}),below:{valType:"string",editType:"plot",description:["Determines if the choropleth polygons will be inserted","before the layer with the specified ID.","By default, choroplethmap traces are placed above the water layers.","If set to '',","the layer will be inserted above every existing layer."].join(" ")},text:n.text,hovertext:n.hovertext,marker:{line:{color:s({},n.marker.line.color,{editType:"plot"}),width:s({},n.marker.line.width,{editType:"plot"}),editType:"calc"},opacity:s({},n.marker.opacity,{editType:"plot"}),editType:"calc"},selected:{marker:{opacity:s({},n.selected.marker.opacity,{editType:"plot"}),editType:"plot"},editType:"plot"},unselected:{marker:{opacity:s({},n.unselected.marker.opacity,{editType:"plot"}),editType:"plot"},editType:"plot"},hoverinfo:n.hoverinfo,hovertemplate:o({},{keys:["properties"]}),showlegend:s({},a.showlegend,{dflt:!1})},i("",{cLetter:"z",editTypeOverride:"calc"}))},23255:(e,t,r)=>{"use strict";var n=r(22036),i=r(84468),o=r(39265),a=r(3172),s=r(89385).makeBlank,l=r(63925);function c(e){var t,r=e[0].trace,n=r._opts;if(r.selectedpoints){for(var o=a.makeSelectedPointStyleFns(r),s=0;s{"use strict";var n=r(84468),i=r(16155),o=r(76899);e.exports=function(e,t,r,a){function s(r,i){return n.coerce(e,t,o,r,i)}var l=s("locations"),c=s("z"),u=s("geojson");n.isArrayOrTypedArray(l)&&l.length&&n.isArrayOrTypedArray(c)&&c.length&&("string"===typeof u&&""!==u||n.isPlainObject(u))?(s("featureidkey"),t._length=Math.min(l.length,c.length),s("below"),s("text"),s("hovertext"),s("hovertemplate"),s("marker.line.width")&&s("marker.line.color"),s("marker.opacity"),i(e,t,a,s,{prefix:"",cLetter:"z"}),n.coerceSelectionMarkerOpacity(t,s)):t.visible=!1}},61168:(e,t,r)=>{"use strict";e.exports={attributes:r(76899),supplyDefaults:r(16324),colorbar:r(11610),calc:r(71861),plot:r(33325),hoverPoints:r(81880),eventData:r(621),selectPoints:r(76712),styleOnSelect:function(e,t){t&&t[0].trace._glTrace.updateOnSelect(t)},getBelow:function(e,t){for(var r=t.getMapLayers(),n=r.length-2;n>=0;n--){var i=r[n].id;if("string"===typeof i&&0===i.indexOf("water"))for(var o=n+1;o{"use strict";var n=r(23255).convert,i=r(23255).convertOnSelect,o=r(76687).traceLayerPrefix;function a(e,t){this.type="choroplethmap",this.subplot=e,this.uid=t,this.sourceId="source-"+t,this.layerList=[["fill",o+t+"-fill"],["line",o+t+"-line"]],this.below=null}var s=a.prototype;s.update=function(e){this._update(n(e)),e[0].trace._glTrace=this},s.updateOnSelect=function(e){this._update(i(e))},s._update=function(e){var t=this.subplot,r=this.layerList,n=t.belowLookup["trace-"+this.uid];t.map.getSource(this.sourceId).setData(e.geojson),n!==this.below&&(this._removeLayers(),this._addLayers(e,n),this.below=n);for(var i=0;i=0;r--)e.removeLayer(t[r][1])},s.dispose=function(){var e=this.subplot.map;this._removeLayers(),e.removeSource(this.sourceId)},e.exports=function(e,t){var r=t[0].trace,i=new a(e,r.uid),o=i.sourceId,s=n(t),l=i.below=e.belowLookup["trace-"+r.uid];return e.map.addSource(o,{type:"geojson",data:s.geojson}),i._addLayers(s,l),t[0].trace._glTrace=i,i}},64532:(e,t,r)=>{"use strict";var n=r(5169),i=r(6636),o=r(84425).rb,a=r(75622),s=r(64022).extendFlat;e.exports=s({locations:{valType:"data_array",editType:"calc",description:["Sets which features found in *geojson* to plot using","their feature `id` field."].join(" ")},z:{valType:"data_array",editType:"calc",description:"Sets the color values."},geojson:{valType:"any",editType:"calc",description:["Sets the GeoJSON data associated with this trace.","It can be set as a valid GeoJSON object or as a URL string.","Note that we only accept GeoJSONs of type *FeatureCollection* or *Feature*","with geometries of type *Polygon* or *MultiPolygon*."].join(" ")},featureidkey:s({},n.featureidkey,{description:["Sets the key in GeoJSON features which is used as id to match the items","included in the `locations` array.","Support nested property, for example *properties.name*."].join(" ")}),below:{valType:"string",editType:"plot",description:["Determines if the choropleth polygons will be inserted","before the layer with the specified ID.","By default, choroplethmapbox traces are placed above the water layers.","If set to '',","the layer will be inserted above every existing layer."].join(" ")},text:n.text,hovertext:n.hovertext,marker:{line:{color:s({},n.marker.line.color,{editType:"plot"}),width:s({},n.marker.line.width,{editType:"plot"}),editType:"calc"},opacity:s({},n.marker.opacity,{editType:"plot"}),editType:"calc"},selected:{marker:{opacity:s({},n.selected.marker.opacity,{editType:"plot"}),editType:"plot"},editType:"plot"},unselected:{marker:{opacity:s({},n.unselected.marker.opacity,{editType:"plot"}),editType:"plot"},editType:"plot"},hoverinfo:n.hoverinfo,hovertemplate:o({},{keys:["properties"]}),showlegend:s({},a.showlegend,{dflt:!1})},i("",{cLetter:"z",editTypeOverride:"calc"}))},73906:(e,t,r)=>{"use strict";var n=r(22036),i=r(84468),o=r(39265),a=r(3172),s=r(89385).makeBlank,l=r(63925);function c(e){var t,r=e[0].trace,n=r._opts;if(r.selectedpoints){for(var o=a.makeSelectedPointStyleFns(r),s=0;s{"use strict";var n=r(84468),i=r(16155),o=r(64532);e.exports=function(e,t,r,a){function s(r,i){return n.coerce(e,t,o,r,i)}var l=s("locations"),c=s("z"),u=s("geojson");n.isArrayOrTypedArray(l)&&l.length&&n.isArrayOrTypedArray(c)&&c.length&&("string"===typeof u&&""!==u||n.isPlainObject(u))?(s("featureidkey"),t._length=Math.min(l.length,c.length),s("below"),s("text"),s("hovertext"),s("hovertemplate"),s("marker.line.width")&&s("marker.line.color"),s("marker.opacity"),i(e,t,a,s,{prefix:"",cLetter:"z"}),n.coerceSelectionMarkerOpacity(t,s)):t.visible=!1}},7257:(e,t,r)=>{"use strict";var n=["*choroplethmapbox* trace is deprecated!","Please consider switching to the *choroplethmap* trace type and `map` subplots.","Learn more at: https://plotly.com/javascript/maplibre-migration/"].join(" ");e.exports={attributes:r(64532),supplyDefaults:r(92739),colorbar:r(11610),calc:r(71861),plot:r(67606),hoverPoints:r(81880),eventData:r(621),selectPoints:r(76712),styleOnSelect:function(e,t){t&&t[0].trace._glTrace.updateOnSelect(t)},getBelow:function(e,t){for(var r=t.getMapLayers(),n=r.length-2;n>=0;n--){var i=r[n].id;if("string"===typeof i&&0===i.indexOf("water"))for(var o=n+1;o{"use strict";var n=r(73906).convert,i=r(73906).convertOnSelect,o=r(26966).traceLayerPrefix;function a(e,t){this.type="choroplethmapbox",this.subplot=e,this.uid=t,this.sourceId="source-"+t,this.layerList=[["fill",o+t+"-fill"],["line",o+t+"-line"]],this.below=null}var s=a.prototype;s.update=function(e){this._update(n(e)),e[0].trace._glTrace=this},s.updateOnSelect=function(e){this._update(i(e))},s._update=function(e){var t=this.subplot,r=this.layerList,n=t.belowLookup["trace-"+this.uid];t.map.getSource(this.sourceId).setData(e.geojson),n!==this.below&&(this._removeLayers(),this._addLayers(e,n),this.below=n);for(var i=0;i=0;r--)e.removeLayer(t[r][1])},s.dispose=function(){var e=this.subplot.map;this._removeLayers(),e.removeSource(this.sourceId)},e.exports=function(e,t){var r=t[0].trace,i=new a(e,r.uid),o=i.sourceId,s=n(t),l=i.below=e.belowLookup["trace-"+r.uid];return e.map.addSource(o,{type:"geojson",data:s.geojson}),i._addLayers(s,l),t[0].trace._glTrace=i,i}},86438:(e,t,r)=>{"use strict";var n=r(6636),i=r(39363).axisHoverFormat,o=r(84425).rb,a=r(64989),s=r(75622),l=r(64022).extendFlat,c={x:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the x coordinates of the vector field","and of the displayed cones."].join(" ")},y:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the y coordinates of the vector field","and of the displayed cones."].join(" ")},z:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the z coordinates of the vector field","and of the displayed cones."].join(" ")},u:{valType:"data_array",editType:"calc",description:"Sets the x components of the vector field."},v:{valType:"data_array",editType:"calc",description:"Sets the y components of the vector field."},w:{valType:"data_array",editType:"calc",description:"Sets the z components of the vector field."},sizemode:{valType:"enumerated",values:["scaled","absolute","raw"],editType:"calc",dflt:"scaled",description:["Determines whether `sizeref` is set as a *scaled* (i.e unitless) scalar","(normalized by the max u/v/w norm in the vector field) or as","*absolute* value (in the same units as the vector field).","To display sizes in actual vector length use *raw*."].join(" ")},sizeref:{valType:"number",editType:"calc",min:0,description:["Adjusts the cone size scaling.","The size of the cones is determined by their u/v/w norm multiplied a factor and `sizeref`.",'This factor (computed internally) corresponds to the minimum "time" to travel across',"two successive x/y/z positions at the average velocity of those two successive positions.","All cones in a given trace use the same factor.","With `sizemode` set to *raw*, its default value is *1*.","With `sizemode` set to *scaled*, `sizeref` is unitless, its default value is *0.5*.","With `sizemode` set to *absolute*, `sizeref` has the same units as the u/v/w vector field,","its the default value is half the sample's maximum vector norm."].join(" ")},anchor:{valType:"enumerated",editType:"calc",values:["tip","tail","cm","center"],dflt:"cm",description:["Sets the cones' anchor with respect to their x/y/z positions.","Note that *cm* denote the cone's center of mass which corresponds to","1/4 from the tail to tip."].join(" ")},text:{valType:"string",dflt:"",arrayOk:!0,editType:"calc",description:["Sets the text elements associated with the cones.","If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,","these elements will be seen in the hover labels."].join(" ")},hovertext:{valType:"string",dflt:"",arrayOk:!0,editType:"calc",description:"Same as `text`."},hovertemplate:o({editType:"calc"},{keys:["norm"]}),uhoverformat:i("u",1),vhoverformat:i("v",1),whoverformat:i("w",1),xhoverformat:i("x"),yhoverformat:i("y"),zhoverformat:i("z"),showlegend:l({},s.showlegend,{dflt:!1})};l(c,n("",{colorAttr:"u/v/w norm",showScaleDflt:!0,editTypeOverride:"calc"}));["opacity","lightposition","lighting"].forEach((function(e){c[e]=a[e]})),c.hoverinfo=l({},s.hoverinfo,{editType:"calc",flags:["x","y","z","u","v","w","norm","text","name"],dflt:"x+y+z+norm+text+name"}),c.transforms=void 0,e.exports=c},9634:(e,t,r)=>{"use strict";var n=r(95500);e.exports=function(e,t){for(var r=t.u,i=t.v,o=t.w,a=Math.min(t.x.length,t.y.length,t.z.length,r.length,i.length,o.length),s=-1/0,l=1/0,c=0;c{"use strict";var n=r(76107).gl_cone3d,i=r(76107).gl_cone3d.createConeMesh,o=r(84468).simpleMap,a=r(23207).parseColorScale,s=r(39265).extractOpts,l=r(84468).isArrayOrTypedArray,c=r(11038);function u(e,t){this.scene=e,this.uid=t,this.mesh=null,this.data=null}var d=u.prototype;d.handlePick=function(e){if(e.object===this.mesh){var t=e.index=e.data.index,r=this.data.x[t],n=this.data.y[t],i=this.data.z[t],o=this.data.u[t],a=this.data.v[t],s=this.data.w[t];e.traceCoordinate=[r,n,i,o,a,s,Math.sqrt(o*o+a*a+s*s)];var c=this.data.hovertext||this.data.text;return l(c)&&void 0!==c[t]?e.textLabel=c[t]:c&&(e.textLabel=c),!0}};var h={xaxis:0,yaxis:1,zaxis:2},p={tip:1,tail:0,cm:.25,center:.5},f={tip:1,tail:1,cm:.75,center:.5};function m(e,t){var r=e.fullSceneLayout,i=e.dataScale,l={};function u(e,t){var n=r[t],a=i[h[t]];return o(e,(function(e){return n.d2l(e)*a}))}l.vectors=c(u(t.u,"xaxis"),u(t.v,"yaxis"),u(t.w,"zaxis"),t._len),l.positions=c(u(t.x,"xaxis"),u(t.y,"yaxis"),u(t.z,"zaxis"),t._len);var d=s(t);l.colormap=a(t),l.vertexIntensityBounds=[d.min/t._normMax,d.max/t._normMax],l.coneOffset=p[t.anchor];var m=t.sizemode;"scaled"===m?l.coneSize=t.sizeref||.5:"absolute"===m?l.coneSize=t.sizeref&&t._normMax?t.sizeref/t._normMax:.5:"raw"===m&&(l.coneSize=t.sizeref),l.coneSizemode=m;var g=n(l),y=t.lightposition;return g.lightPosition=[y.x,y.y,y.z],g.ambient=t.lighting.ambient,g.diffuse=t.lighting.diffuse,g.specular=t.lighting.specular,g.roughness=t.lighting.roughness,g.fresnel=t.lighting.fresnel,g.opacity=t.opacity,t._pad=f[t.anchor]*g.vectorScale*g.coneScale*t._normMax,g}d.update=function(e){this.data=e;var t=m(this.scene,e);this.mesh.update(t)},d.dispose=function(){this.scene.glplot.remove(this.mesh),this.mesh.dispose()},e.exports=function(e,t){var r=e.glplot.gl,n=m(e,t),o=i(r,n),a=new u(e,t.uid);return a.mesh=o,a.data=t,o._trace=a,e.glplot.add(o),a}},4945:(e,t,r)=>{"use strict";var n=r(84468),i=r(16155),o=r(86438);e.exports=function(e,t,r,a){function s(r,i){return n.coerce(e,t,o,r,i)}var l=s("u"),c=s("v"),u=s("w"),d=s("x"),h=s("y"),p=s("z");if(l&&l.length&&c&&c.length&&u&&u.length&&d&&d.length&&h&&h.length&&p&&p.length){var f=s("sizemode");s("sizeref","raw"===f?1:.5),s("anchor"),s("lighting.ambient"),s("lighting.diffuse"),s("lighting.specular"),s("lighting.roughness"),s("lighting.fresnel"),s("lightposition.x"),s("lightposition.y"),s("lightposition.z"),i(e,t,a,s,{prefix:"",cLetter:"c"}),s("text"),s("hovertext"),s("hovertemplate"),s("uhoverformat"),s("vhoverformat"),s("whoverformat"),s("xhoverformat"),s("yhoverformat"),s("zhoverformat"),t._length=null}else t.visible=!1}},15863:(e,t,r)=>{"use strict";e.exports={moduleType:"trace",name:"cone",basePlotModule:r(48648),categories:["gl3d","showLegend"],attributes:r(86438),supplyDefaults:r(4945),colorbar:{min:"cmin",max:"cmax"},calc:r(9634),plot:r(65680),eventData:function(e,t){return e.norm=t.traceCoordinate[6],e},meta:{description:["Use cone traces to visualize vector fields.","","Specify a vector field using 6 1D arrays,","3 position arrays `x`, `y` and `z`","and 3 vector component arrays `u`, `v`, `w`.","The cones are drawn exactly at the positions given","by `x`, `y` and `z`."].join(" ")}}},15425:(e,t,r)=>{"use strict";var n=r(86327),i=r(22049),o=r(39363),a=o.axisHoverFormat,s=o.descriptionOnlyNumbers,l=r(6636),c=r(2703).T,u=r(91740),d=r(64022).extendFlat,h=r(23605),p=h.COMPARISON_OPS2,f=h.INTERVAL_OPS,m=i.line;e.exports=d({z:n.z,x:n.x,x0:n.x0,dx:n.dx,y:n.y,y0:n.y0,dy:n.dy,xperiod:n.xperiod,yperiod:n.yperiod,xperiod0:i.xperiod0,yperiod0:i.yperiod0,xperiodalignment:n.xperiodalignment,yperiodalignment:n.yperiodalignment,text:n.text,hovertext:n.hovertext,transpose:n.transpose,xtype:n.xtype,ytype:n.ytype,xhoverformat:a("x"),yhoverformat:a("y"),zhoverformat:a("z",1),hovertemplate:n.hovertemplate,texttemplate:d({},n.texttemplate,{description:["For this trace it only has an effect if `coloring` is set to *heatmap*.",n.texttemplate.description].join(" ")}),textfont:d({},n.textfont,{description:["For this trace it only has an effect if `coloring` is set to *heatmap*.",n.textfont.description].join(" ")}),hoverongaps:n.hoverongaps,connectgaps:d({},n.connectgaps,{description:["Determines whether or not gaps","(i.e. {nan} or missing values)","in the `z` data are filled in.","It is defaulted to true if `z` is a","one dimensional array","otherwise it is defaulted to false."].join(" ")}),fillcolor:{valType:"color",editType:"calc",description:["Sets the fill color if `contours.type` is *constraint*.","Defaults to a half-transparent variant of the line color,","marker color, or marker line color, whichever is available."].join(" ")},autocontour:{valType:"boolean",dflt:!0,editType:"calc",impliedEdits:{"contours.start":void 0,"contours.end":void 0,"contours.size":void 0},description:["Determines whether or not the contour level attributes are","picked by an algorithm.","If *true*, the number of contour levels can be set in `ncontours`.","If *false*, set the contour level attributes in `contours`."].join(" ")},ncontours:{valType:"integer",dflt:15,min:1,editType:"calc",description:["Sets the maximum number of contour levels. The actual number","of contours will be chosen automatically to be less than or","equal to the value of `ncontours`.","Has an effect only if `autocontour` is *true* or if","`contours.size` is missing."].join(" ")},contours:{type:{valType:"enumerated",values:["levels","constraint"],dflt:"levels",editType:"calc",description:["If `levels`, the data is represented as a contour plot with multiple","levels displayed. If `constraint`, the data is represented as constraints","with the invalid region shaded as specified by the `operation` and","`value` parameters."].join(" ")},start:{valType:"number",dflt:null,editType:"plot",impliedEdits:{"^autocontour":!1},description:["Sets the starting contour level value.","Must be less than `contours.end`"].join(" ")},end:{valType:"number",dflt:null,editType:"plot",impliedEdits:{"^autocontour":!1},description:["Sets the end contour level value.","Must be more than `contours.start`"].join(" ")},size:{valType:"number",dflt:null,min:0,editType:"plot",impliedEdits:{"^autocontour":!1},description:["Sets the step between each contour level.","Must be positive."].join(" ")},coloring:{valType:"enumerated",values:["fill","heatmap","lines","none"],dflt:"fill",editType:"calc",description:["Determines the coloring method showing the contour values.","If *fill*, coloring is done evenly between each contour level","If *heatmap*, a heatmap gradient coloring is applied","between each contour level.","If *lines*, coloring is done on the contour lines.","If *none*, no coloring is applied on this trace."].join(" ")},showlines:{valType:"boolean",dflt:!0,editType:"plot",description:["Determines whether or not the contour lines are drawn.","Has an effect only if `contours.coloring` is set to *fill*."].join(" ")},showlabels:{valType:"boolean",dflt:!1,editType:"plot",description:["Determines whether to label the contour lines with their values."].join(" ")},labelfont:u({editType:"plot",colorEditType:"style",description:["Sets the font used for labeling the contour levels.","The default color comes from the lines, if shown.","The default family and size come from `layout.font`."].join(" ")}),labelformat:{valType:"string",dflt:"",editType:"plot",description:s("contour label")},operation:{valType:"enumerated",values:[].concat(p).concat(f),dflt:"=",editType:"calc",description:["Sets the constraint operation.","*=* keeps regions equal to `value`","*<* and *<=* keep regions less than `value`","*>* and *>=* keep regions greater than `value`","*[]*, *()*, *[)*, and *(]* keep regions inside `value[0]` to `value[1]`","*][*, *)(*, *](*, *)[* keep regions outside `value[0]` to value[1]`","Open vs. closed intervals make no difference to constraint display, but","all versions are allowed for consistency with filter transforms."].join(" ")},value:{valType:"any",dflt:0,editType:"calc",description:["Sets the value or values of the constraint boundary.","When `operation` is set to one of the comparison values","("+p+")","*value* is expected to be a number.","When `operation` is set to one of the interval values","("+f+")","*value* is expected to be an array of two numbers where the first","is the lower bound and the second is the upper bound."].join(" ")},editType:"calc",impliedEdits:{autocontour:!1}},line:{color:d({},m.color,{editType:"style+colorbars",description:["Sets the color of the contour level.","Has no effect if `contours.coloring` is set to *lines*."].join(" ")}),width:{valType:"number",min:0,editType:"style+colorbars",description:["Sets the contour line width in (in px)","Defaults to *0.5* when `contours.type` is *levels*.","Defaults to *2* when `contour.type` is *constraint*."].join(" ")},dash:c,smoothing:d({},m.smoothing,{description:["Sets the amount of smoothing for the contour lines,","where *0* corresponds to no smoothing."].join(" ")}),editType:"plot"},zorder:i.zorder},l("",{cLetter:"z",autoColorDflt:!1,editTypeOverride:"calc"}))},15621:(e,t,r)=>{"use strict";var n=r(39265),i=r(27447),o=r(98746),a=r(86414);e.exports=function(e,t){var r=i(e,t),s=r[0].z;o(t,s);var l,c=t.contours,u=n.extractOpts(t);if("heatmap"===c.coloring&&u.auto&&!1===t.autocontour){var d=c.start,h=a(c),p=c.size||1,f=Math.floor((h-d)/p)+1;isFinite(p)||(p=1,f=1);var m=d-p/2;l=[m,m+f*p]}else l=s;return n.calc(e,t,{vals:l,cLetter:"z"}),r}},11275:e=>{"use strict";e.exports=function(e,t){var r,n=e[0],i=n.z;switch(t.type){case"levels":var o=Math.min(i[0][0],i[0][1]);for(r=0;ra.level||a.starts.length&&o===a.level)}break;case"constraint":if(n.prefixBoundary=!1,n.edgepaths.length)return;var s=n.x.length,l=n.y.length,c=-1/0,u=1/0;for(r=0;r":p>c&&(n.prefixBoundary=!0);break;case"<":(pc||n.starts.length&&h===u)&&(n.prefixBoundary=!0);break;case"][":d=Math.min(p[0],p[1]),h=Math.max(p[0],p[1]),dc&&(n.prefixBoundary=!0)}}}},62848:(e,t,r)=>{"use strict";var n=r(39265),i=r(26063),o=r(86414);e.exports={min:"zmin",max:"zmax",calc:function(e,t,r){var a=t.contours,s=t.line,l=a.size||1,c=a.coloring,u=i(t,{isColorbar:!0});if("heatmap"===c){var d=n.extractOpts(t);r._fillgradient=d.reversescale?n.flipScale(d.colorscale):d.colorscale,r._zrange=[d.min,d.max]}else"fill"===c&&(r._fillcolor=u);r._line={color:"lines"===c?u:s.color,width:!1!==a.showlines?s.width:0,dash:s.dash},r._levels={start:a.start,end:o(a),size:l}}}},55907:e=>{"use strict";e.exports={BOTTOMSTART:[1,9,13,104,713],TOPSTART:[4,6,7,104,713],LEFTSTART:[8,12,14,208,1114],RIGHTSTART:[2,3,11,208,1114],NEWDELTA:[null,[-1,0],[0,-1],[-1,0],[1,0],null,[0,-1],[-1,0],[0,1],[0,1],null,[0,1],[1,0],[1,0],[0,-1]],CHOOSESADDLE:{104:[4,1],208:[2,8],713:[7,13],1114:[11,14]},SADDLEREMAINDER:{1:4,2:8,4:1,7:13,8:2,11:14,13:7,14:11},LABELDISTANCE:2,LABELINCREASE:10,LABELMIN:3,LABELMAX:10,LABELOPTIMIZER:{EDGECOST:1,ANGLECOST:1,NEIGHBORCOST:5,SAMELEVELFACTOR:10,SAMELEVELDISTANCE:5,MAXCOST:100,INITIALSEARCHPOINTS:10,ITERATIONS:5}}},10052:(e,t,r)=>{"use strict";var n=r(22036),i=r(34225),o=r(7605),a=o.addOpacity,s=o.opacity,l=r(23605),c=r(84468).isArrayOrTypedArray,u=l.CONSTRAINT_REDUCTION,d=l.COMPARISON_OPS2;e.exports=function(e,t,r,o,l,h){var p,f,m,g=t.contours,y=r("contours.operation");(g._operation=u[y],function(e,t){var r;-1===d.indexOf(t.operation)?(e("contours.value",[0,1]),c(t.value)?t.value.length>2?t.value=t.value.slice(2):0===t.length?t.value=[0,1]:t.length<2?(r=parseFloat(t.value[0]),t.value=[r,r+1]):t.value=[parseFloat(t.value[0]),parseFloat(t.value[1])]:n(t.value)&&(r=parseFloat(t.value),t.value=[r,r+1])):(e("contours.value",0),n(t.value)||(c(t.value)?t.value=parseFloat(t.value[0]):t.value=0))}(r,g),"="===y?p=g.showlines=!0:(p=r("contours.showlines"),m=r("fillcolor",a((e.line||{}).color||l,.5))),p)&&(f=r("line.color",m&&s(m)?a(t.fillcolor,1):l),r("line.width",2),r("line.dash"));r("line.smoothing"),i(r,o,f,h)}},59286:(e,t,r)=>{"use strict";var n=r(23605),i=r(22036);function o(e,t){var r,o=Array.isArray(t);function a(e){return i(e)?+e:null}return-1!==n.COMPARISON_OPS2.indexOf(e)?r=a(o?t[0]:t):-1!==n.INTERVAL_OPS.indexOf(e)?r=o?[a(t[0]),a(t[1])]:[a(t),a(t)]:-1!==n.SET_OPS.indexOf(e)&&(r=o?t.map(a):[a(t)]),r}function a(e){return function(t){t=o(e,t);var r=Math.min(t[0],t[1]),n=Math.max(t[0],t[1]);return{start:r,end:n,size:n-r}}}function s(e){return function(t){return{start:t=o(e,t),end:1/0,size:1/0}}}e.exports={"[]":a("[]"),"][":a("]["),">":s(">"),"<":s("<"),"=":s("=")}},95248:e=>{"use strict";e.exports=function(e,t,r,n){var i=n("contours.start"),o=n("contours.end"),a=!1===i||!1===o,s=r("contours.size");!(a?t.autocontour=!0:r("autocontour",!1))&&s||r("ncontours")}},89298:(e,t,r)=>{"use strict";var n=r(84468);function i(e){return n.extendFlat({},e,{edgepaths:n.extendDeep([],e.edgepaths),paths:n.extendDeep([],e.paths),starts:n.extendDeep([],e.starts)})}e.exports=function(e,t){var r,o,a,s=function(e){return e.reverse()},l=function(e){return e};switch(t){case"=":case"<":return e;case">":for(1!==e.length&&n.warn("Contour data invalid for the specified inequality operation."),o=e[0],r=0;r{"use strict";var n=r(84468),i=r(44168),o=r(26386),a=r(10052),s=r(95248),l=r(19704),c=r(27475),u=r(15425);e.exports=function(e,t,r,d){function h(r,i){return n.coerce(e,t,u,r,i)}if(i(e,t,h,d)){o(e,t,d,h),h("xhoverformat"),h("yhoverformat"),h("text"),h("hovertext"),h("hoverongaps"),h("hovertemplate");var p="constraint"===h("contours.type");h("connectgaps",n.isArray1D(t.z)),p?a(e,t,h,d,r):(s(e,t,h,(function(r){return n.coerce2(e,t,u,r)})),l(e,t,h,d)),t.contours&&"heatmap"===t.contours.coloring&&c(h,d),h("zorder")}else t.visible=!1}},617:(e,t,r)=>{"use strict";var n=r(84468),i=r(59286),o=r(86414);e.exports=function(e,t,r){for(var a="constraint"===e.type?i[e._operation](e.value):e,s=a.size,l=[],c=o(a),u=r.trace._carpetTrace,d=u?{xaxis:u.aaxis,yaxis:u.baxis,x:r.a,y:r.b}:{xaxis:t.xaxis,yaxis:t.yaxis,x:r.x,y:r.y},h=a.start;h1e3){n.warn("Too many contours, clipping at 1000",e);break}return l}},86414:e=>{"use strict";e.exports=function(e){return e.end+e.size/1e6}},93896:(e,t,r)=>{"use strict";var n=r(84468),i=r(55907);function o(e,t,r,n){return Math.abs(e[0]-t[0])20&&t?208===e||1114===e?n=0===r[0]?1:-1:o=0===r[1]?1:-1:-1!==i.BOTTOMSTART.indexOf(e)?o=1:-1!==i.LEFTSTART.indexOf(e)?n=1:-1!==i.TOPSTART.indexOf(e)?o=-1:n=-1;return[n,o]}(h,r,t),f=[l(e,t,[-p[0],-p[1]])],m=e.z.length,g=e.z[0].length,y=t.slice(),v=p.slice();for(u=0;u<1e4;u++){if(h>20?(h=i.CHOOSESADDLE[h][(p[0]||p[1])<0?0:1],e.crossings[d]=i.SADDLEREMAINDER[h]):delete e.crossings[d],!(p=i.NEWDELTA[h])){n.log("Found bad marching index:",h,t,e.level);break}f.push(l(e,t,p)),t[0]+=p[0],t[1]+=p[1],d=t.join(","),o(f[f.length-1],f[f.length-2],s,c)&&f.pop();var x=p[0]&&(t[0]<0||t[0]>g-2)||p[1]&&(t[1]<0||t[1]>m-2);if(t[0]===y[0]&&t[1]===y[1]&&p[0]===v[0]&&p[1]===v[1]||r&&x)break;h=e.crossings[d]}1e4===u&&n.log("Infinite loop in contour?");var b,_,w,k,S,A,T,M,C,E,I,P=o(f[0],f[f.length-1],s,c),O=0,R=.2*e.smoothing,L=[],D=0;for(u=1;u=D;u--)if((b=L[u])=D&&b+L[_]M&&C--,e.edgepaths[C]=I.concat(f,E));break}N||(e.edgepaths[M]=f.concat(E))}for(M=0;M{"use strict";var n=r(7605),i=r(46954);e.exports=function(e,t,r,o,a){a||(a={}),a.isContour=!0;var s=i(e,t,r,o,a);return s&&s.forEach((function(e){var t=e.trace;"constraint"===t.contours.type&&(t.fillcolor&&n.opacity(t.fillcolor)?e.color=n.addOpacity(t.fillcolor,1):t.contours.showlines&&n.opacity(t.line.color)&&(e.color=n.addOpacity(t.line.color,1)))})),s}},7506:(e,t,r)=>{"use strict";e.exports={attributes:r(15425),supplyDefaults:r(11878),calc:r(15621),plot:r(30155).plot,style:r(84923),colorbar:r(62848),hoverPoints:r(69768),moduleType:"trace",name:"contour",basePlotModule:r(9510),categories:["cartesian","svg","2dMap","contour","showLegend"],meta:{description:["The data from which contour lines are computed is set in `z`.","Data in `z` must be a {2D array} of numbers.","Say that `z` has N rows and M columns, then by default,","these N rows correspond to N y coordinates","(set in `y` or auto-generated) and the M columns","correspond to M x coordinates (set in `x` or auto-generated).","By setting `transpose` to *true*, the above behavior is flipped."].join(" ")}}},34225:(e,t,r)=>{"use strict";var n=r(84468);e.exports=function(e,t,r,i){if(i||(i={}),e("contours.showlabels")){var o=t.font;n.coerceFont(e,"contours.labelfont",o,{overrideDflt:{color:r}}),e("contours.labelformat")}!1!==i.hasHover&&e("zhoverformat")}},26063:(e,t,r)=>{"use strict";var n=r(41871),i=r(39265),o=r(86414);e.exports=function(e){var t=e.contours,r=t.start,a=o(t),s=t.size||1,l=Math.floor((a-r)/s)+1,c="lines"===t.coloring?0:1,u=i.extractOpts(e);isFinite(s)||(s=1,l=1);var d,h,p=u.reversescale?i.flipScale(u.colorscale):u.colorscale,f=p.length,m=new Array(f),g=new Array(f),y=u.min,v=u.max;if("heatmap"===t.coloring){for(h=0;h=v)&&(r<=y&&(r=y),a>=v&&(a=v),l=Math.floor((a-r)/s)+1,c=0),h=0;hy&&(m.unshift(y),g.unshift(g[0])),m[m.length-1]{"use strict";var n=r(55907);function i(e,t){var r=(t[0][0]>e?0:1)+(t[0][1]>e?0:2)+(t[1][1]>e?0:4)+(t[1][0]>e?0:8);return 5===r||10===r?e>(t[0][0]+t[0][1]+t[1][0]+t[1][1])/4?5===r?713:1114:5===r?104:208:15===r?0:r}e.exports=function(e){var t,r,o,a,s,l,c,u,d,h=e[0].z,p=h.length,f=h[0].length,m=2===p||2===f;for(r=0;r{"use strict";var n=r(41871),i=r(84468),o=r(3172),a=r(39265),s=r(13480),l=r(85729),c=r(45958),u=r(21313),d=r(6140),h=r(93896),p=r(617),f=r(89298),m=r(11275),g=r(55907),y=g.LABELOPTIMIZER;function v(e,t){var r,n,a,s,l,c,u,d="",h=0,p=e.edgepaths.map((function(e,t){return t})),f=!0;function m(e){return Math.abs(e[1]-t[2][1])<.01}function g(e){return Math.abs(e[0]-t[0][0])<.01}function y(e){return Math.abs(e[0]-t[2][0])<.01}for(;p.length;){for(c=o.smoothopen(e.edgepaths[h],e.smoothing),d+=f?c:c.replace(/^M/,"L"),p.splice(p.indexOf(h),1),r=e.edgepaths[h][e.edgepaths[h].length-1],s=-1,a=0;a<4;a++){if(!r){i.log("Missing end?",h,e);break}for(u=r,Math.abs(u[1]-t[0][1])<.01&&!y(r)?n=t[1]:g(r)?n=t[0]:m(r)?n=t[3]:y(r)&&(n=t[2]),l=0;l=0&&(n=v,s=l):Math.abs(r[1]-n[1])<.01?Math.abs(r[1]-v[1])<.01&&(v[0]-r[0])*(n[0]-v[0])>=0&&(n=v,s=l):i.log("endpt to newendpt is not vert. or horz.",r,n,v)}if(r=n,s>=0)break;d+="L"+n}if(s===e.edgepaths.length){i.log("unclosed perimeter path");break}h=s,(f=-1===p.indexOf(h))&&(h=p[0],d+="Z")}for(h=0;hn.center?n.right-s:s-n.left)/(u+Math.abs(Math.sin(c)*a)),p=(l>n.middle?n.bottom-l:l-n.top)/(Math.abs(d)+Math.cos(c)*a);if(h<1||p<1)return 1/0;var f=y.EDGECOST*(1/(h-1)+1/(p-1));f+=y.ANGLECOST*c*c;for(var m=s-u,g=l-d,v=s+u,x=l+d,b=0;b2*y.MAXCOST)break;p&&(s/=2),l=(a=c-s/2)+1.5*s}if(h<=y.MAXCOST)return u},t.addLabelData=function(e,t,r,n){var i=t.fontSize,o=t.width+i/3,a=Math.max(0,t.height-i/3),s=e.x,l=e.y,c=e.theta,u=Math.sin(c),d=Math.cos(c),h=function(e,t){return[s+e*d-t*u,l+e*u+t*d]},p=[h(-o/2,-a/2),h(-o/2,a/2),h(o/2,a/2),h(o/2,-a/2)];r.push({text:t.text,x:s,y:l,dy:t.dy,theta:c,level:t.level,width:o,height:a}),n.push(p)},t.drawLabels=function(e,t,r,o,a){var l=e.selectAll("text").data(t,(function(e){return e.text+","+e.x+","+e.y+","+e.theta}));if(l.exit().remove(),l.enter().append("text").attr({"data-notex":1,"text-anchor":"middle"}).each((function(e){var t=e.x+Math.sin(e.theta)*e.dy,i=e.y-Math.cos(e.theta)*e.dy;n.select(this).text(e.text).attr({x:t,y:i,transform:"rotate("+180*e.theta/Math.PI+" "+t+" "+i+")"}).call(s.convertToTspans,r)})),a){for(var c="",u=0;u{"use strict";var n=r(85729),i=r(84468);function o(e,t,r){var i={type:"linear",range:[e,t]};return n.autoTicks(i,(t-e)/(r||15)),i}e.exports=function(e,t){var r=e.contours;if(e.autocontour){var a=e.zmin,s=e.zmax;(e.zauto||void 0===a)&&(a=i.aggNums(Math.min,null,t)),(e.zauto||void 0===s)&&(s=i.aggNums(Math.max,null,t));var l=o(a,s,e.ncontours);r.size=l.dtick,r.start=n.tickFirst(l),l.range.reverse(),r.end=n.tickFirst(l),r.start===a&&(r.start+=r.size),r.end===s&&(r.end-=r.size),r.start>r.end&&(r.start=r.end=(r.start+r.end)/2),e._input.contours||(e._input.contours={}),i.extendFlat(e._input.contours,{start:r.start,end:r.end,size:r.size}),e._input.autocontour=!0}else if("constraint"!==r.type){var c,u=r.start,d=r.end,h=e._input.contours;if(u>d&&(r.start=h.start=d,d=r.end=h.end=u,u=r.start),!(r.size>0))c=u===d?1:o(u,d,e.ncontours).dtick,h.size=r.size=c}}},84923:(e,t,r)=>{"use strict";var n=r(41871),i=r(3172),o=r(14141),a=r(26063);e.exports=function(e){var t=n.select(e).selectAll("g.contour");t.style("opacity",(function(e){return e[0].trace.opacity})),t.each((function(e){var t=n.select(this),r=e[0].trace,o=r.contours,s=r.line,l=o.size||1,c=o.start,u="constraint"===o.type,d=!u&&"lines"===o.coloring,h=!u&&"fill"===o.coloring,p=d||h?a(r):null;t.selectAll("g.contourlevel").each((function(e){n.select(this).selectAll("path").call(i.lineGroupStyle,s.width,d?p(e.level):s.color,s.dash)}));var f=o.labelfont;if(t.selectAll("g.contourlabels text").each((function(e){i.font(n.select(this),{weight:f.weight,style:f.style,variant:f.variant,textcase:f.textcase,lineposition:f.lineposition,shadow:f.shadow,family:f.family,size:f.size,color:f.color||(d?p(e.level):s.color)})})),u)t.selectAll("g.contourfill path").style("fill",r.fillcolor);else if(h){var m;t.selectAll("g.contourfill path").style("fill",(function(e){return void 0===m&&(m=e.level),p(e.level+.5*l)})),void 0===m&&(m=c),t.selectAll("g.contourbg path").style("fill",p(m-.5*l))}})),o(e)}},19704:(e,t,r)=>{"use strict";var n=r(16155),i=r(34225);e.exports=function(e,t,r,o,a){var s,l=r("contours.coloring"),c="";"fill"===l&&(s=r("contours.showlines")),!1!==s&&("lines"!==l&&(c=r("line.color","#000")),r("line.width",.5),r("line.dash")),"none"!==l&&(!0!==e.showlegend&&(t.showlegend=!1),t._dfltShowLegend=!1,n(e,t,o,r,{prefix:"",cLetter:"z"})),r("line.smoothing"),i(r,o,c,a)}},29028:(e,t,r)=>{"use strict";var n=r(86327),i=r(15425),o=r(6636),a=r(64022).extendFlat,s=i.contours;e.exports=a({carpet:{valType:"string",editType:"calc",description:["The `carpet` of the carpet axes on which this contour trace lies"].join(" ")},z:n.z,a:n.x,a0:n.x0,da:n.dx,b:n.y,b0:n.y0,db:n.dy,text:n.text,hovertext:n.hovertext,transpose:n.transpose,atype:n.xtype,btype:n.ytype,fillcolor:i.fillcolor,autocontour:i.autocontour,ncontours:i.ncontours,contours:{type:s.type,start:s.start,end:s.end,size:s.size,coloring:{valType:"enumerated",values:["fill","lines","none"],dflt:"fill",editType:"calc",description:["Determines the coloring method showing the contour values.","If *fill*, coloring is done evenly between each contour level","If *lines*, coloring is done on the contour lines.","If *none*, no coloring is applied on this trace."].join(" ")},showlines:s.showlines,showlabels:s.showlabels,labelfont:s.labelfont,labelformat:s.labelformat,operation:s.operation,value:s.value,editType:"calc",impliedEdits:{autocontour:!1}},line:{color:i.line.color,width:i.line.width,dash:i.line.dash,smoothing:i.line.smoothing,editType:"plot"},zorder:i.zorder,transforms:void 0},o("",{cLetter:"z",autoColorDflt:!1}))},27780:(e,t,r)=>{"use strict";var n=r(95500),i=r(84468),o=r(31828),a=r(15200),s=r(71034),l=r(55059),c=r(83341),u=r(95283),d=r(35738),h=r(98746);e.exports=function(e,t){var r=t._carpetTrace=d(e,t);if(r&&r.visible&&"legendonly"!==r.visible){if(!t.a||!t.b){var p=e.data[r.index],f=e.data[t.index];f.a||(f.a=p.a),f.b||(f.b=p.b),u(f,t,t._defaultColor,e._fullLayout)}var m=function(e,t){var r,u,d,h,p,f,m,g=t._carpetTrace,y=g.aaxis,v=g.baxis;y._minDtick=0,v._minDtick=0,i.isArray1D(t.z)&&o(t,y,v,"a","b",["z"]);r=t._a=t._a||t.a,h=t._b=t._b||t.b,r=r?y.makeCalcdata(t,"_a"):[],h=h?v.makeCalcdata(t,"_b"):[],u=t.a0||0,d=t.da||1,p=t.b0||0,f=t.db||1,m=t._z=a(t._z||t.z,t.transpose),t._emptypoints=l(m),s(m,t._emptypoints);var x=i.maxRowLength(m),b="scaled"===t.xtype?"":r,_=c(t,b,u,d,x,y),w="scaled"===t.ytype?"":h,k=c(t,w,p,f,m.length,v),S={a:_,b:k,z:m};"levels"===t.contours.type&&"none"!==t.contours.coloring&&n(e,t,{vals:m,containerStr:"",cLetter:"z"});return[S]}(e,t);return h(t,t._z),m}}},95283:(e,t,r)=>{"use strict";var n=r(84468),i=r(44168),o=r(29028),a=r(10052),s=r(95248),l=r(19704);e.exports=function(e,t,r,c){function u(r,i){return n.coerce(e,t,o,r,i)}if(u("carpet"),e.a&&e.b){if(!i(e,t,u,c,"a","b"))return void(t.visible=!1);u("text"),"constraint"===u("contours.type")?a(e,t,u,c,r,{hasHover:!1}):(s(e,t,u,(function(r){return n.coerce2(e,t,o,r)})),l(e,t,u,c,{hasHover:!1}))}else t._defaultColor=r,t._length=null;u("zorder")}},12809:(e,t,r)=>{"use strict";e.exports={attributes:r(29028),supplyDefaults:r(95283),colorbar:r(62848),calc:r(27780),plot:r(32646),style:r(84923),moduleType:"trace",name:"contourcarpet",basePlotModule:r(9510),categories:["cartesian","svg","carpet","contour","symbols","showLegend","hasLines","carpetDependent","noHover","noSortingByValue"],meta:{hrName:"contour_carpet",description:["Plots contours on either the first carpet axis or the","carpet axis with a matching `carpet` attribute. Data `z`","is interpreted as matching that of the corresponding carpet","axis."].join(" ")}}},32646:(e,t,r)=>{"use strict";var n=r(41871),i=r(87435),o=r(38166),a=r(3172),s=r(84468),l=r(6140),c=r(93896),u=r(30155),d=r(55907),h=r(89298),p=r(617),f=r(11275),m=r(35738),g=r(26674);function y(e,t,r){var n=e.getPointAtLength(t),i=e.getPointAtLength(r),o=i.x-n.x,a=i.y-n.y,s=Math.sqrt(o*o+a*a);return[o/s,a/s]}function v(e){var t=Math.sqrt(e[0]*e[0]+e[1]*e[1]);return[e[0]/t,e[1]/t]}function x(e,t){var r=Math.abs(e[0]*t[0]+e[1]*t[1]);return Math.sqrt(1-r*r)/r}e.exports=function(e,t,r,b){var _=t.xaxis,w=t.yaxis;s.makeTraceGroups(b,r,"contour").each((function(r){var b=n.select(this),k=r[0],S=k.trace,A=S._carpetTrace=m(e,S),T=e.calcdata[A.index][0];if(A.visible&&"legendonly"!==A.visible){var M=k.a,C=k.b,E=S.contours,I=p(E,t,k),P="constraint"===E.type,O=E._operation,R=P?"="===O?"lines":"fill":E.coloring,L=[[M[0],C[C.length-1]],[M[M.length-1],C[C.length-1]],[M[M.length-1],C[0]],[M[0],C[0]]];l(I);var D=1e-8*(M[M.length-1]-M[0]),z=1e-8*(C[C.length-1]-C[0]);c(I,D,z);var j,F,N,B,V=I;"constraint"===E.type&&(V=h(I,O)),function(e,t){var r,n,i,o,a,s,l,c,u;for(r=0;r=0;B--)j=T.clipsegments[B],F=i([],j.x,_.c2p),N=i([],j.y,w.c2p),F.reverse(),N.reverse(),U.push(o(F,N,j.bicubic));var H="M"+U.join("L")+"Z";!function(e,t,r,n,a,l){var c,u,d,h,p=s.ensureSingle(e,"g","contourbg").selectAll("path").data("fill"!==l||a?[]:[0]);p.enter().append("path"),p.exit().remove();var f=[];for(h=0;h=0&&(h=E,f=m):Math.abs(d[1]-h[1])=0&&(h=E,f=m):s.log("endpt to newendpt is not vert. or horz.",d,h,E)}if(f>=0)break;v+=M(d,h),d=h}if(f===t.edgepaths.length){s.log("unclosed perimeter path");break}u=f,(b=-1===x.indexOf(u))&&(u=x[0],v+=M(d,h)+"Z",d=null)}for(u=0;ug&&(n.max=g);n.len=n.max-n.min}(n,r,e,i,c,t.height),!(i.len<(t.width+t.height)*d.LABELMIN)))for(var o=Math.min(Math.ceil(i.len/R),d.LABELMAX),a=0;a{"use strict";var n=r(6636),i=r(84425).rb,o=r(75622),a=r(5427),s=r(64022).extendFlat;e.exports=s({lon:a.lon,lat:a.lat,z:{valType:"data_array",editType:"calc",description:["Sets the points' weight.","For example, a value of 10 would be equivalent to having 10 points of weight 1","in the same spot"].join(" ")},radius:{valType:"number",editType:"plot",arrayOk:!0,min:1,dflt:30,description:["Sets the radius of influence of one `lon` / `lat` point in pixels.","Increasing the value makes the densitymap trace smoother, but less detailed."].join(" ")},below:{valType:"string",editType:"plot",description:["Determines if the densitymap trace will be inserted","before the layer with the specified ID.","By default, densitymap traces are placed below the first","layer of type symbol","If set to '',","the layer will be inserted above every existing layer."].join(" ")},text:a.text,hovertext:a.hovertext,hoverinfo:s({},o.hoverinfo,{flags:["lon","lat","z","text","name"]}),hovertemplate:i(),showlegend:s({},o.showlegend,{dflt:!1})},n("",{cLetter:"z",editTypeOverride:"calc"}))},3509:(e,t,r)=>{"use strict";var n=r(22036),i=r(84468).isArrayOrTypedArray,o=r(65004).BADNUM,a=r(95500),s=r(84468)._;e.exports=function(e,t){for(var r=t._length,l=new Array(r),c=t.z,u=i(c)&&c.length,d=0;d{"use strict";var n=r(22036),i=r(84468),o=r(7605),a=r(39265),s=r(65004).BADNUM,l=r(89385).makeBlank;e.exports=function(e){var t=e[0].trace,r=!0===t.visible&&0!==t._length,c=t._opts={heatmap:{layout:{visibility:"none"},paint:{}},geojson:l()};if(!r)return c;var u,d=[],h=t.z,p=t.radius,f=i.isArrayOrTypedArray(h)&&h.length,m=i.isArrayOrTypedArray(p);for(u=0;u0?+p[u]:0),d.push({type:"Feature",geometry:{type:"Point",coordinates:y},properties:v})}}var b=a.extractOpts(t),_=b.reversescale?a.flipScale(b.colorscale):b.colorscale,w=_[0][1],k=["interpolate",["linear"],["heatmap-density"],0,o.opacity(w)<1?w:o.addOpacity(w,0)];for(u=1;u<_.length;u++)k.push(_[u][0],_[u][1]);var S=["interpolate",["linear"],["get","z"],b.min,0,b.max,1];return i.extendFlat(c.heatmap.paint,{"heatmap-weight":f?S:1/(b.max-b.min),"heatmap-color":k,"heatmap-radius":m?{type:"identity",property:"r"}:t.radius,"heatmap-opacity":t.opacity}),c.geojson={type:"FeatureCollection",features:d},c.heatmap.layout.visibility="visible",c}},17366:(e,t,r)=>{"use strict";var n=r(84468),i=r(16155),o=r(79633);e.exports=function(e,t,r,a){function s(r,i){return n.coerce(e,t,o,r,i)}var l=s("lon")||[],c=s("lat")||[],u=Math.min(l.length,c.length);u?(t._length=u,s("z"),s("radius"),s("below"),s("text"),s("hovertext"),s("hovertemplate"),i(e,t,a,s,{prefix:"",cLetter:"z"})):t.visible=!1}},88077:e=>{"use strict";e.exports=function(e,t){return e.lon=t.lon,e.lat=t.lat,e.z=t.z,e}},69624:(e,t,r)=>{"use strict";var n=r(85729),i=r(42206).hoverPoints,o=r(42206).getExtraText;e.exports=function(e,t,r){var a=i(e,t,r);if(a){var s=a[0],l=s.cd,c=l[0].trace,u=l[s.index];if(delete s.color,"z"in u){var d=s.subplot.mockAxis;s.z=u.z,s.zLabel=n.tickText(d,d.c2l(u.z),"hover").text}return s.extraText=o(c,u,l[0].t.labels),[s]}}},36066:(e,t,r)=>{"use strict";e.exports={attributes:r(79633),supplyDefaults:r(17366),colorbar:r(11610),formatLabels:r(5043),calc:r(3509),plot:r(98363),hoverPoints:r(69624),eventData:r(88077),getBelow:function(e,t){for(var r=t.getMapLayers(),n=0;n{"use strict";var n=r(71654),i=r(76687).traceLayerPrefix;function o(e,t){this.type="densitymap",this.subplot=e,this.uid=t,this.sourceId="source-"+t,this.layerList=[["heatmap",i+t+"-heatmap"]],this.below=null}var a=o.prototype;a.update=function(e){var t=this.subplot,r=this.layerList,i=n(e),o=t.belowLookup["trace-"+this.uid];t.map.getSource(this.sourceId).setData(i.geojson),o!==this.below&&(this._removeLayers(),this._addLayers(i,o),this.below=o);for(var a=0;a=0;r--)e.removeLayer(t[r][1])},a.dispose=function(){var e=this.subplot.map;this._removeLayers(),e.removeSource(this.sourceId)},e.exports=function(e,t){var r=t[0].trace,i=new o(e,r.uid),a=i.sourceId,s=n(t),l=i.below=e.belowLookup["trace-"+r.uid];return e.map.addSource(a,{type:"geojson",data:s.geojson}),i._addLayers(s,l),i}},41078:(e,t,r)=>{"use strict";var n=r(6636),i=r(84425).rb,o=r(75622),a=r(2244),s=r(64022).extendFlat;e.exports=s({lon:a.lon,lat:a.lat,z:{valType:"data_array",editType:"calc",description:["Sets the points' weight.","For example, a value of 10 would be equivalent to having 10 points of weight 1","in the same spot"].join(" ")},radius:{valType:"number",editType:"plot",arrayOk:!0,min:1,dflt:30,description:["Sets the radius of influence of one `lon` / `lat` point in pixels.","Increasing the value makes the densitymapbox trace smoother, but less detailed."].join(" ")},below:{valType:"string",editType:"plot",description:["Determines if the densitymapbox trace will be inserted","before the layer with the specified ID.","By default, densitymapbox traces are placed below the first","layer of type symbol","If set to '',","the layer will be inserted above every existing layer."].join(" ")},text:a.text,hovertext:a.hovertext,hoverinfo:s({},o.hoverinfo,{flags:["lon","lat","z","text","name"]}),hovertemplate:i(),showlegend:s({},o.showlegend,{dflt:!1})},n("",{cLetter:"z",editTypeOverride:"calc"}))},21010:(e,t,r)=>{"use strict";var n=r(22036),i=r(84468).isArrayOrTypedArray,o=r(65004).BADNUM,a=r(95500),s=r(84468)._;e.exports=function(e,t){for(var r=t._length,l=new Array(r),c=t.z,u=i(c)&&c.length,d=0;d{"use strict";var n=r(22036),i=r(84468),o=r(7605),a=r(39265),s=r(65004).BADNUM,l=r(89385).makeBlank;e.exports=function(e){var t=e[0].trace,r=!0===t.visible&&0!==t._length,c=t._opts={heatmap:{layout:{visibility:"none"},paint:{}},geojson:l()};if(!r)return c;var u,d=[],h=t.z,p=t.radius,f=i.isArrayOrTypedArray(h)&&h.length,m=i.isArrayOrTypedArray(p);for(u=0;u0?+p[u]:0),d.push({type:"Feature",geometry:{type:"Point",coordinates:y},properties:v})}}var b=a.extractOpts(t),_=b.reversescale?a.flipScale(b.colorscale):b.colorscale,w=_[0][1],k=["interpolate",["linear"],["heatmap-density"],0,o.opacity(w)<1?w:o.addOpacity(w,0)];for(u=1;u<_.length;u++)k.push(_[u][0],_[u][1]);var S=["interpolate",["linear"],["get","z"],b.min,0,b.max,1];return i.extendFlat(c.heatmap.paint,{"heatmap-weight":f?S:1/(b.max-b.min),"heatmap-color":k,"heatmap-radius":m?{type:"identity",property:"r"}:t.radius,"heatmap-opacity":t.opacity}),c.geojson={type:"FeatureCollection",features:d},c.heatmap.layout.visibility="visible",c}},3265:(e,t,r)=>{"use strict";var n=r(84468),i=r(16155),o=r(41078);e.exports=function(e,t,r,a){function s(r,i){return n.coerce(e,t,o,r,i)}var l=s("lon")||[],c=s("lat")||[],u=Math.min(l.length,c.length);u?(t._length=u,s("z"),s("radius"),s("below"),s("text"),s("hovertext"),s("hovertemplate"),i(e,t,a,s,{prefix:"",cLetter:"z"})):t.visible=!1}},16058:e=>{"use strict";e.exports=function(e,t){return e.lon=t.lon,e.lat=t.lat,e.z=t.z,e}},83049:(e,t,r)=>{"use strict";var n=r(85729),i=r(98835).hoverPoints,o=r(98835).getExtraText;e.exports=function(e,t,r){var a=i(e,t,r);if(a){var s=a[0],l=s.cd,c=l[0].trace,u=l[s.index];if(delete s.color,"z"in u){var d=s.subplot.mockAxis;s.z=u.z,s.zLabel=n.tickText(d,d.c2l(u.z),"hover").text}return s.extraText=o(c,u,l[0].t.labels),[s]}}},583:(e,t,r)=>{"use strict";var n=["*densitymapbox* trace is deprecated!","Please consider switching to the *densitymap* trace type and `map` subplots.","Learn more at: https://plotly.com/javascript/maplibre-migration/"].join(" ");e.exports={attributes:r(41078),supplyDefaults:r(3265),colorbar:r(11610),formatLabels:r(74466),calc:r(21010),plot:r(53520),hoverPoints:r(83049),eventData:r(16058),getBelow:function(e,t){for(var r=t.getMapLayers(),n=0;n{"use strict";var n=r(20320),i=r(26966).traceLayerPrefix;function o(e,t){this.type="densitymapbox",this.subplot=e,this.uid=t,this.sourceId="source-"+t,this.layerList=[["heatmap",i+t+"-heatmap"]],this.below=null}var a=o.prototype;a.update=function(e){var t=this.subplot,r=this.layerList,i=n(e),o=t.belowLookup["trace-"+this.uid];t.map.getSource(this.sourceId).setData(i.geojson),o!==this.below&&(this._removeLayers(),this._addLayers(i,o),this.below=o);for(var a=0;a=0;r--)e.removeLayer(t[r][1])},a.dispose=function(){var e=this.subplot.map;this._removeLayers(),e.removeSource(this.sourceId)},e.exports=function(e,t){var r=t[0].trace,i=new o(e,r.uid),a=i.sourceId,s=n(t),l=i.below=e.belowLookup["trace-"+r.uid];return e.map.addSource(a,{type:"geojson",data:s.geojson}),i._addLayers(s,l),i}},66584:(e,t,r)=>{"use strict";var n=r(84468);e.exports=function(e,t){for(var r=0;r{"use strict";var n=r(29744),i=r(22049).line,o=r(75622),a=r(39363).axisHoverFormat,s=r(84425).rb,l=r(84425).ay,c=r(77073),u=r(64022).extendFlat,d=r(7605);e.exports={x:n.x,x0:n.x0,dx:n.dx,y:n.y,y0:n.y0,dy:n.dy,xperiod:n.xperiod,yperiod:n.yperiod,xperiod0:n.xperiod0,yperiod0:n.yperiod0,xperiodalignment:n.xperiodalignment,yperiodalignment:n.yperiodalignment,xhoverformat:a("x"),yhoverformat:a("y"),hovertext:n.hovertext,hovertemplate:s({},{keys:c.eventDataKeys}),hoverinfo:u({},o.hoverinfo,{flags:["name","x","y","text","percent initial","percent previous","percent total"]}),textinfo:{valType:"flaglist",flags:["label","text","percent initial","percent previous","percent total","value"],extras:["none"],editType:"plot",arrayOk:!1,description:["Determines which trace information appear on the graph.","In the case of having multiple funnels, percentages & totals","are computed separately (per trace)."].join(" ")},texttemplate:l({editType:"plot"},{keys:c.eventDataKeys.concat(["label","value"])}),text:n.text,textposition:n.textposition,insidetextanchor:u({},n.insidetextanchor,{dflt:"middle"}),textangle:u({},n.textangle,{dflt:0}),textfont:n.textfont,insidetextfont:n.insidetextfont,outsidetextfont:n.outsidetextfont,constraintext:n.constraintext,cliponaxis:n.cliponaxis,orientation:u({},n.orientation,{description:["Sets the orientation of the funnels.","With *v* (*h*), the value of the each bar spans","along the vertical (horizontal).","By default funnels are tend to be oriented horizontally;","unless only *y* array is presented or orientation is set to *v*.","Also regarding graphs including only 'horizontal' funnels,","*autorange* on the *y-axis* are set to *reversed*."].join(" ")}),offset:u({},n.offset,{arrayOk:!1}),width:u({},n.width,{arrayOk:!1}),marker:function(){var e=u({},n.marker);return delete e.pattern,delete e.cornerradius,e}(),connector:{fillcolor:{valType:"color",editType:"style",description:["Sets the fill color."].join(" ")},line:{color:u({},i.color,{dflt:d.defaultLine}),width:u({},i.width,{dflt:0,editType:"plot"}),dash:i.dash,editType:"style"},visible:{valType:"boolean",dflt:!0,editType:"plot",description:["Determines if connector regions and lines are drawn."].join(" ")},editType:"plot"},offsetgroup:n.offsetgroup,alignmentgroup:n.alignmentgroup,zorder:n.zorder}},10759:(e,t,r)=>{"use strict";var n=r(85729),i=r(35087),o=r(66584),a=r(40304),s=r(65004).BADNUM;function l(e){return e===s?0:e}e.exports=function(e,t){var r,c,u,d,h,p,f,m,g=n.getFromId(e,t.xaxis||"x"),y=n.getFromId(e,t.yaxis||"y");"h"===t.orientation?(r=g.makeCalcdata(t,"x"),u=y.makeCalcdata(t,"y"),d=i(t,y,"y",u),h=!!t.yperiodalignment,p="y"):(r=y.makeCalcdata(t,"y"),u=g.makeCalcdata(t,"x"),d=i(t,g,"x",u),h=!!t.xperiodalignment,p="x"),c=d.vals;var v,x=Math.min(c.length,r.length),b=new Array(x);for(t._base=[],f=0;f{"use strict";e.exports={eventDataKeys:["percentInitial","percentPrevious","percentTotal"]}},10404:(e,t,r)=>{"use strict";var n=r(51203).setGroupPositions;e.exports=function(e,t){var r,i,o=e._fullLayout,a=e._fullData,s=e.calcdata,l=t.xaxis,c=t.yaxis,u=[],d=[],h=[];for(i=0;i{"use strict";var n=r(84468),i=r(53558),o=r(81543).handleText,a=r(53124),s=r(26386),l=r(53031),c=r(7605);e.exports={supplyDefaults:function(e,t,r,i){function u(r,i){return n.coerce(e,t,l,r,i)}if(a(e,t,i,u)){s(e,t,i,u),u("xhoverformat"),u("yhoverformat"),u("orientation",t.y&&!t.x?"v":"h"),u("offset"),u("width");var d=u("text");u("hovertext"),u("hovertemplate");var h=u("textposition");o(e,t,i,u,h,{moduleHasSelected:!1,moduleHasUnselected:!1,moduleHasConstrain:!0,moduleHasCliponaxis:!0,moduleHasTextangle:!0,moduleHasInsideanchor:!0}),"none"===t.textposition||t.texttemplate||u("textinfo",n.isArrayOrTypedArray(d)?"text+value":"value");var p=u("marker.color",r);if(u("marker.line.color",c.defaultLine),u("marker.line.width"),u("connector.visible"))u("connector.fillcolor",function(e){var t=n.isArrayOrTypedArray(e)?"#000":e;return c.addOpacity(t,.5*c.opacity(t))}(p)),u("connector.line.width")&&(u("connector.line.color"),u("connector.line.dash"));u("zorder")}else t.visible=!1},crossTraceDefaults:function(e,t){var r,o;function a(e){return n.coerce(o._input,o,l,e)}if("group"===t.funnelmode)for(var s=0;s{"use strict";e.exports=function(e,t){return e.x="xVal"in t?t.xVal:t.x,e.y="yVal"in t?t.yVal:t.y,"percentInitial"in t&&(e.percentInitial=t.percentInitial),"percentPrevious"in t&&(e.percentPrevious=t.percentPrevious),"percentTotal"in t&&(e.percentTotal=t.percentTotal),t.xa&&(e.xaxis=t.xa),t.ya&&(e.yaxis=t.ya),e}},36058:(e,t,r)=>{"use strict";var n=r(7605).opacity,i=r(3332).hoverOnBars,o=r(84468).formatPercent;e.exports=function(e,t,r,a,s){var l=i(e,t,r,a,s);if(l){var c=l.cd,u=c[0].trace,d="h"===u.orientation,h=c[l.index];l[(d?"x":"y")+"LabelVal"]=h.s,l.percentInitial=h.begR,l.percentInitialLabel=o(h.begR,1),l.percentPrevious=h.difR,l.percentPreviousLabel=o(h.difR,1),l.percentTotal=h.sumR,l.percentTotalLabel=o(h.sumR,1);var p=h.hi||u.hoverinfo,f=[];if(p&&"none"!==p&&"skip"!==p){var m="all"===p,g=p.split("+"),y=function(e){return m||-1!==g.indexOf(e)};y("percent initial")&&f.push(l.percentInitialLabel+" of initial"),y("percent previous")&&f.push(l.percentPreviousLabel+" of previous"),y("percent total")&&f.push(l.percentTotalLabel+" of total")}return l.extraText=f.join("
"),l.color=function(e,t){var r=e.marker,i=t.mc||r.color,o=t.mlc||r.line.color,a=t.mlw||r.line.width;if(n(i))return i;if(n(o)&&a)return o}(u,h),[l]}}},67276:(e,t,r)=>{"use strict";e.exports={attributes:r(53031),layoutAttributes:r(5902),supplyDefaults:r(59264).supplyDefaults,crossTraceDefaults:r(59264).crossTraceDefaults,supplyLayoutDefaults:r(99801),calc:r(10759),crossTraceCalc:r(10404),plot:r(46353),style:r(62797).style,hoverPoints:r(36058),eventData:r(72963),selectPoints:r(12969),moduleType:"trace",name:"funnel",basePlotModule:r(9510),categories:["bar-like","cartesian","svg","oriented","showLegend","zoomScale"],meta:{description:["Visualize stages in a process using length-encoded bars. This trace can be used","to show data in either a part-to-whole representation wherein each item appears",'in a single stage, or in a "drop-off" representation wherein each item appears in','each stage it traversed. See also the "funnelarea" trace type for a different',"approach to visualizing funnel data."].join(" ")}}},5902:e=>{"use strict";e.exports={funnelmode:{valType:"enumerated",values:["stack","group","overlay"],dflt:"stack",editType:"calc",description:["Determines how bars at the same location coordinate","are displayed on the graph.","With *stack*, the bars are stacked on top of one another","With *group*, the bars are plotted next to one another","centered around the shared location.","With *overlay*, the bars are plotted over one another,","you might need to reduce *opacity* to see multiple bars."].join(" ")},funnelgap:{valType:"number",min:0,max:1,editType:"calc",description:["Sets the gap (in plot fraction) between bars of","adjacent location coordinates."].join(" ")},funnelgroupgap:{valType:"number",min:0,max:1,dflt:0,editType:"calc",description:["Sets the gap (in plot fraction) between bars of","the same location coordinate."].join(" ")}}},99801:(e,t,r)=>{"use strict";var n=r(84468),i=r(5902);e.exports=function(e,t,r){var o=!1;function a(r,o){return n.coerce(e,t,i,r,o)}for(var s=0;s{"use strict";var n=r(41871),i=r(84468),o=r(3172),a=r(65004).BADNUM,s=r(32018),l=r(35655).clearMinTextSize;function c(e,t,r,n){var i=[],o=[],a=n?t:r,s=n?r:t;return i[0]=a.c2p(e.s0,!0),o[0]=s.c2p(e.p0,!0),i[1]=a.c2p(e.s1,!0),o[1]=s.c2p(e.p1,!0),i[2]=a.c2p(e.nextS0,!0),o[2]=s.c2p(e.nextP0,!0),i[3]=a.c2p(e.nextS1,!0),o[3]=s.c2p(e.nextP1,!0),n?[i,o]:[o,i]}e.exports=function(e,t,r,u){var d=e._fullLayout;l("funnel",d),function(e,t,r,s){var l=t.xaxis,u=t.yaxis;i.makeTraceGroups(s,r,"trace bars").each((function(r){var s=n.select(this),d=r[0].trace,h=i.ensureSingle(s,"g","regions");if(d.connector&&d.connector.visible){var p="h"===d.orientation,f=h.selectAll("g.region").data(i.identity);f.enter().append("g").classed("region",!0),f.exit().remove();var m=f.size();f.each((function(r,s){if(s===m-1||r.cNext){var d=c(r,l,u,p),h=d[0],f=d[1],g="";h[0]!==a&&f[0]!==a&&h[1]!==a&&f[1]!==a&&h[2]!==a&&f[2]!==a&&h[3]!==a&&f[3]!==a&&(g+=p?"M"+h[0]+","+f[1]+"L"+h[2]+","+f[2]+"H"+h[3]+"L"+h[1]+","+f[1]+"Z":"M"+h[1]+","+f[1]+"L"+h[2]+","+f[3]+"V"+f[2]+"L"+h[1]+","+f[0]+"Z"),""===g&&(g="M0,0Z"),i.ensureSingle(n.select(this),"path").attr("d",g).call(o.setClipUrl,t.layerClipId,e)}}))}else h.remove()}))}(e,t,r,u),function(e,t,r,a){var s=t.xaxis,l=t.yaxis;i.makeTraceGroups(a,r,"trace bars").each((function(r){var a=n.select(this),u=r[0].trace,d=i.ensureSingle(a,"g","lines");if(u.connector&&u.connector.visible&&u.connector.line.width){var h="h"===u.orientation,p=d.selectAll("g.line").data(i.identity);p.enter().append("g").classed("line",!0),p.exit().remove();var f=p.size();p.each((function(r,a){if(a===f-1||r.cNext){var u=c(r,s,l,h),d=u[0],p=u[1],m="";void 0!==d[3]&&void 0!==p[3]&&(h?(m+="M"+d[0]+","+p[1]+"L"+d[2]+","+p[2],m+="M"+d[1]+","+p[1]+"L"+d[3]+","+p[2]):(m+="M"+d[1]+","+p[1]+"L"+d[2]+","+p[3],m+="M"+d[1]+","+p[0]+"L"+d[2]+","+p[2])),""===m&&(m="M0,0Z"),i.ensureSingle(n.select(this),"path").attr("d",m).call(o.setClipUrl,t.layerClipId,e)}}))}else d.remove()}))}(e,t,r,u),s.plot(e,t,r,u,{mode:d.funnelmode,norm:d.funnelmode,gap:d.funnelgap,groupgap:d.funnelgroupgap})}},62797:(e,t,r)=>{"use strict";var n=r(41871),i=r(3172),o=r(7605),a=r(64253).DESELECTDIM,s=r(52464),l=r(35655).resizeText,c=s.styleTextPoints;e.exports={style:function(e,t,r){var s=r||n.select(e).selectAll('g[class^="funnellayer"]').selectAll("g.trace");l(e,s,"funnel"),s.style("opacity",(function(e){return e[0].trace.opacity})),s.each((function(t){var r=n.select(this),s=t[0].trace;r.selectAll(".point > path").each((function(e){if(!e.isBlank){var t=s.marker;n.select(this).call(o.fill,e.mc||t.color).call(o.stroke,e.mlc||t.line.color).call(i.dashLine,t.line.dash,e.mlw||t.line.width).style("opacity",s.selectedpoints&&!e.selected?a:1)}})),c(r,s,e),r.selectAll(".regions").each((function(){n.select(this).selectAll("path").style("stroke-width",0).call(o.fill,s.connector.fillcolor)})),r.selectAll(".lines").each((function(){var e=s.connector.line;i.lineGroupStyle(n.select(this).selectAll("path"),e.width,e.color,e.dash)}))}))}}},99016:(e,t,r)=>{"use strict";var n=r(59453),i=r(75622),o=r(81159).u,a=r(84425).rb,s=r(84425).ay,l=r(64022).extendFlat;e.exports={labels:n.labels,label0:n.label0,dlabel:n.dlabel,values:n.values,marker:{colors:n.marker.colors,line:{color:l({},n.marker.line.color,{dflt:null,description:["Sets the color of the line enclosing each sector.","Defaults to the `paper_bgcolor` value."].join(" ")}),width:l({},n.marker.line.width,{dflt:1}),editType:"calc"},pattern:n.marker.pattern,editType:"calc"},text:n.text,hovertext:n.hovertext,scalegroup:l({},n.scalegroup,{description:["If there are multiple funnelareas that should be sized according to","their totals, link them by providing a non-empty group id here","shared by every trace in the same group."].join(" ")}),textinfo:l({},n.textinfo,{flags:["label","text","value","percent"]}),texttemplate:s({editType:"plot"},{keys:["label","color","value","text","percent"]}),hoverinfo:l({},i.hoverinfo,{flags:["label","text","value","percent","name"]}),hovertemplate:a({},{keys:["label","color","value","text","percent"]}),textposition:l({},n.textposition,{values:["inside","none"],dflt:"inside"}),textfont:n.textfont,insidetextfont:n.insidetextfont,title:{text:n.title.text,font:n.title.font,position:l({},n.title.position,{values:["top left","top center","top right"],dflt:"top center"}),editType:"plot"},domain:o({name:"funnelarea",trace:!0,editType:"calc"}),aspectratio:{valType:"number",min:0,dflt:1,editType:"plot",description:["Sets the ratio between height and width"].join(" ")},baseratio:{valType:"number",min:0,max:1,dflt:.333,editType:"plot",description:["Sets the ratio between bottom length and maximum top length."].join(" ")}}},87456:(e,t,r)=>{"use strict";var n=r(68543);t.name="funnelarea",t.plot=function(e,r,i,o){n.plotBasePlot(t.name,e,r,i,o)},t.clean=function(e,r,i,o){n.cleanBasePlot(t.name,e,r,i,o)}},87288:(e,t,r)=>{"use strict";var n=r(59217);e.exports={calc:function(e,t){return n.calc(e,t)},crossTraceCalc:function(e){n.crossTraceCalc(e,{type:"funnelarea"})}}},71647:(e,t,r)=>{"use strict";var n=r(84468),i=r(99016),o=r(81159).N,a=r(81543).handleText,s=r(69834).handleLabelsAndValues,l=r(69834).handleMarkerDefaults;e.exports=function(e,t,r,c){function u(r,o){return n.coerce(e,t,i,r,o)}var d=u("labels"),h=u("values"),p=s(d,h),f=p.len;if(t._hasLabels=p.hasLabels,t._hasValues=p.hasValues,!t._hasLabels&&t._hasValues&&(u("label0"),u("dlabel")),f){t._length=f,l(e,t,c,u),u("scalegroup");var m,g=u("text"),y=u("texttemplate");if(y||(m=u("textinfo",Array.isArray(g)?"text+percent":"percent")),u("hovertext"),u("hovertemplate"),y||m&&"none"!==m){var v=u("textposition");a(e,t,c,u,v,{moduleHasSelected:!1,moduleHasUnselected:!1,moduleHasConstrain:!1,moduleHasCliponaxis:!1,moduleHasTextangle:!1,moduleHasInsideanchor:!1})}else"none"===m&&u("textposition","none");o(t,c,u),u("title.text")&&(u("title.position"),n.coerceFont(u,"title.font",c.font)),u("aspectratio"),u("baseratio")}else t.visible=!1}},31189:(e,t,r)=>{"use strict";e.exports={moduleType:"trace",name:"funnelarea",basePlotModule:r(87456),categories:["pie-like","funnelarea","showLegend"],attributes:r(99016),layoutAttributes:r(32067),supplyDefaults:r(71647),supplyLayoutDefaults:r(66148),calc:r(87288).calc,crossTraceCalc:r(87288).crossTraceCalc,plot:r(42618),style:r(86216),styleOne:r(32100),meta:{description:["Visualize stages in a process using area-encoded trapezoids. This trace can be used",'to show data in a part-to-whole representation similar to a "pie" trace, wherein','each item appears in a single stage. See also the "funnel" trace type for a different',"approach to visualizing funnel data."].join(" ")}}},32067:(e,t,r)=>{"use strict";var n=r(66008).hiddenlabels;e.exports={hiddenlabels:n,funnelareacolorway:{valType:"colorlist",editType:"calc",description:["Sets the default funnelarea slice colors. Defaults to the main","`colorway` used for trace colors. If you specify a new","list here it can still be extended with lighter and darker","colors, see `extendfunnelareacolors`."].join(" ")},extendfunnelareacolors:{valType:"boolean",dflt:!0,editType:"calc",description:["If `true`, the funnelarea slice colors (whether given by `funnelareacolorway` or","inherited from `colorway`) will be extended to three times its","original length by first repeating every color 20% lighter then","each color 20% darker. This is intended to reduce the likelihood","of reusing the same color when you have many slices, but you can","set `false` to disable.","Colors provided in the trace, using `marker.colors`, are never","extended."].join(" ")}}},66148:(e,t,r)=>{"use strict";var n=r(84468),i=r(32067);e.exports=function(e,t){function r(r,o){return n.coerce(e,t,i,r,o)}r("hiddenlabels"),r("funnelareacolorway",t.colorway),r("extendfunnelareacolors")}},42618:(e,t,r)=>{"use strict";var n=r(41871),i=r(3172),o=r(84468),a=o.strScale,s=o.strTranslate,l=r(13480),c=r(32018).toMoveInsideBar,u=r(35655),d=u.recordMinTextSize,h=u.clearMinTextSize,p=r(97367),f=r(50183),m=f.attachFxHandlers,g=f.determineInsideTextFont,y=f.layoutAreas,v=f.prerenderTitles,x=f.positionTitleOutside,b=f.formatSliceLabel;function _(e,t){return"l"+(t[0]-e[0])+","+(t[1]-e[1])}function w(e,t){return[.5*(e[0]+t[0]),.5*(e[1]+t[1])]}e.exports=function(e,t){var r=e._context.staticPlot,u=e._fullLayout;h("funnelarea",u),v(t,e),y(t,u._size),o.makeTraceGroups(u._funnelarealayer,t,"trace").each((function(t){var h=n.select(this),f=t[0],y=f.trace;!function(e){if(!e.length)return;var t=e[0],r=t.trace,n=r.aspectratio,i=r.baseratio;i>.999&&(i=.999);var o,a=Math.pow(i,2),s=t.vTotal,l=s,c=s*a/(1-a)/s;function u(){var e=Math.sqrt(c);return{x:e,y:-e}}function d(){var e=u();return[e.x,e.y]}var h,p,f=[];for(f.push(d()),h=e.length-1;h>-1;h--)if(!(p=e[h]).hidden){var m=p.v/l;c+=m,f.push(d())}var g=1/0,y=-1/0;for(h=0;h-1;h--)if(!(p=e[h]).hidden){var M=f[T+=1][0],C=f[T][1];p.TL=[-M,C],p.TR=[M,C],p.BL=S,p.BR=A,p.pxmid=w(p.TR,p.BR),S=p.TL,A=p.TR}}(t),h.each((function(){var h=n.select(this).selectAll("g.slice").data(t);h.enter().append("g").classed("slice",!0),h.exit().remove(),h.each((function(a,s){if(a.hidden)n.select(this).selectAll("path,g").remove();else{a.pointNumber=a.i,a.curveNumber=y.index;var h=f.cx,v=f.cy,x=n.select(this),w=x.selectAll("path.surface").data([a]);w.enter().append("path").classed("surface",!0).style({"pointer-events":r?"none":"all"}),x.call(m,e,t);var k="M"+(h+a.TR[0])+","+(v+a.TR[1])+_(a.TR,a.BR)+_(a.BR,a.BL)+_(a.BL,a.TL)+"Z";w.attr("d",k),b(e,a,f);var S=p.castOption(y.textposition,a.pts),A=x.selectAll("g.slicetext").data(a.text&&"none"!==S?[0]:[]);A.enter().append("g").classed("slicetext",!0),A.exit().remove(),A.each((function(){var r=o.ensureSingle(n.select(this),"text","",(function(e){e.attr("data-notex",1)})),p=o.ensureUniformFontSize(e,g(y,a,u.font));r.text(a.text).attr({class:"slicetext",transform:"","text-anchor":"middle"}).call(i.font,p).call(l.convertToTspans,e);var f,m,x,b=i.bBox(r.node()),_=Math.min(a.BL[1],a.BR[1])+v,w=Math.max(a.TL[1],a.TR[1])+v;m=Math.max(a.TL[0],a.BL[0])+h,x=Math.min(a.TR[0],a.BR[0])+h,(f=c(m,x,_,w,b,{isHorizontal:!0,constrained:!0,angle:0,anchor:"middle"})).fontSize=p.size,d(y.type,f,u),t[s].transform=f,o.setTransormAndDisplay(r,f)}))}}));var v=n.select(this).selectAll("g.titletext").data(y.title.text?[0]:[]);v.enter().append("g").classed("titletext",!0),v.exit().remove(),v.each((function(){var t=o.ensureSingle(n.select(this),"text","",(function(e){e.attr("data-notex",1)})),r=y.title.text;y._meta&&(r=o.templateString(r,y._meta)),t.text(r).attr({class:"titletext",transform:"","text-anchor":"middle"}).call(i.font,y.title.font).call(l.convertToTspans,e);var c=x(f,u._size);t.attr("transform",s(c.x,c.y)+a(Math.min(1,c.scale))+s(c.tx,c.ty))}))}))}))}},86216:(e,t,r)=>{"use strict";var n=r(41871),i=r(32100),o=r(35655).resizeText;e.exports=function(e){var t=e._fullLayout._funnelarealayer.selectAll(".trace");o(e,t,"funnelarea"),t.each((function(t){var r=t[0].trace,o=n.select(this);o.style({opacity:r.opacity}),o.selectAll("path.surface").each((function(t){n.select(this).call(i,t,r,e)}))}))}},86327:(e,t,r)=>{"use strict";var n=r(22049),i=r(75622),o=r(91740),a=r(39363).axisHoverFormat,s=r(84425).rb,l=r(84425).ay,c=r(6636),u=r(64022).extendFlat;e.exports=u({z:{valType:"data_array",editType:"calc",description:"Sets the z data."},x:u({},n.x,{impliedEdits:{xtype:"array"}}),x0:u({},n.x0,{impliedEdits:{xtype:"scaled"}}),dx:u({},n.dx,{impliedEdits:{xtype:"scaled"}}),y:u({},n.y,{impliedEdits:{ytype:"array"}}),y0:u({},n.y0,{impliedEdits:{ytype:"scaled"}}),dy:u({},n.dy,{impliedEdits:{ytype:"scaled"}}),xperiod:u({},n.xperiod,{impliedEdits:{xtype:"scaled"}}),yperiod:u({},n.yperiod,{impliedEdits:{ytype:"scaled"}}),xperiod0:u({},n.xperiod0,{impliedEdits:{xtype:"scaled"}}),yperiod0:u({},n.yperiod0,{impliedEdits:{ytype:"scaled"}}),xperiodalignment:u({},n.xperiodalignment,{impliedEdits:{xtype:"scaled"}}),yperiodalignment:u({},n.yperiodalignment,{impliedEdits:{ytype:"scaled"}}),text:{valType:"data_array",editType:"calc",description:"Sets the text elements associated with each z value."},hovertext:{valType:"data_array",editType:"calc",description:"Same as `text`."},transpose:{valType:"boolean",dflt:!1,editType:"calc",description:"Transposes the z data."},xtype:{valType:"enumerated",values:["array","scaled"],editType:"calc+clearAxisTypes",description:["If *array*, the heatmap's x coordinates are given by *x*","(the default behavior when `x` is provided).","If *scaled*, the heatmap's x coordinates are given by *x0* and *dx*","(the default behavior when `x` is not provided)."].join(" ")},ytype:{valType:"enumerated",values:["array","scaled"],editType:"calc+clearAxisTypes",description:["If *array*, the heatmap's y coordinates are given by *y*","(the default behavior when `y` is provided)","If *scaled*, the heatmap's y coordinates are given by *y0* and *dy*","(the default behavior when `y` is not provided)"].join(" ")},zsmooth:{valType:"enumerated",values:["fast","best",!1],dflt:!1,editType:"calc",description:["Picks a smoothing algorithm use to smooth `z` data."].join(" ")},hoverongaps:{valType:"boolean",dflt:!0,editType:"none",description:["Determines whether or not gaps","(i.e. {nan} or missing values)","in the `z` data have hover labels associated with them."].join(" ")},connectgaps:{valType:"boolean",editType:"calc",description:["Determines whether or not gaps","(i.e. {nan} or missing values)","in the `z` data are filled in.","It is defaulted to true if `z` is a","one dimensional array and `zsmooth` is not false;","otherwise it is defaulted to false."].join(" ")},xgap:{valType:"number",dflt:0,min:0,editType:"plot",description:"Sets the horizontal gap (in pixels) between bricks."},ygap:{valType:"number",dflt:0,min:0,editType:"plot",description:"Sets the vertical gap (in pixels) between bricks."},xhoverformat:a("x"),yhoverformat:a("y"),zhoverformat:a("z",1),hovertemplate:s(),texttemplate:l({arrayOk:!1,editType:"plot"},{keys:["x","y","z","text"]}),textfont:o({editType:"plot",autoSize:!0,autoColor:!0,colorEditType:"style",description:"Sets the text font."}),showlegend:u({},i.showlegend,{dflt:!1}),zorder:n.zorder},{transforms:void 0},c("",{cLetter:"z",autoColorDflt:!1}))},27447:(e,t,r)=>{"use strict";var n=r(38361),i=r(84468),o=r(85729),a=r(35087),s=r(86807),l=r(95500),c=r(31828),u=r(15200),d=r(71034),h=r(55059),p=r(83341),f=r(65004).BADNUM;function m(e){for(var t=[],r=e.length,n=0;n1){var t=(e[e.length-1]-e[0])/(e.length-1),r=Math.abs(t/100);for(S=0;Sr)return!1}return!0}(T.rangebreaks||M.rangebreaks)&&(k=function(e,t,r){for(var n=[],i=-1,o=0;o{"use strict";var n=r(22036),i=r(84468),o=r(65004).BADNUM;e.exports=function(e,t,r,a){var s,l,c,u,d,h;function p(e){if(n(e))return+e}if(t&&t.transpose){for(s=0,d=0;d{"use strict";e.exports={min:"zmin",max:"zmax"}},31828:(e,t,r)=>{"use strict";var n=r(84468),i=r(65004).BADNUM,o=r(35087);e.exports=function(e,t,r,a,s,l){var c=e._length,u=t.makeCalcdata(e,a),d=r.makeCalcdata(e,s);u=o(e,t,a,u).vals,d=o(e,r,s,d).vals;var h,p,f,m,g=e.text,y=void 0!==g&&n.isArray1D(g),v=e.hovertext,x=void 0!==v&&n.isArray1D(v),b=n.distinctVals(u),_=b.vals,w=n.distinctVals(d),k=w.vals,S=[],A=k.length,T=_.length;for(h=0;h{"use strict";var n=r(84468),i=r(44168),o=r(27475),a=r(26386),s=r(27706),l=r(16155),c=r(86327);e.exports=function(e,t,r,u){function d(r,i){return n.coerce(e,t,c,r,i)}i(e,t,d,u)?(a(e,t,u,d),d("xhoverformat"),d("yhoverformat"),d("text"),d("hovertext"),d("hovertemplate"),o(d,u),s(e,t,d,u),d("hoverongaps"),d("connectgaps",n.isArray1D(t.z)&&!1!==t.zsmooth),l(e,t,u,d,{prefix:"",cLetter:"z"}),d("zorder")):t.visible=!1}},55059:(e,t,r)=>{"use strict";var n=r(84468).maxRowLength;e.exports=function(e){var t,r,i,o,a,s,l,c,u=[],d={},h=[],p=e[0],f=[],m=[0,0,0],g=n(e);for(r=0;r=0;a--)(s=((d[[(r=(o=h[a])[0])-1,i=o[1]]]||m)[2]+(d[[r+1,i]]||m)[2]+(d[[r,i-1]]||m)[2]+(d[[r,i+1]]||m)[2])/20)&&(l[o]=[r,i,s],h.splice(a,1),c=!0);if(!c)throw"findEmpties iterated with no new neighbors";for(o in l)d[o]=l[o],u.push(l[o])}return u.sort((function(e,t){return t[2]-e[2]}))}},46954:(e,t,r)=>{"use strict";var n=r(32212),i=r(84468),o=i.isArrayOrTypedArray,a=r(85729),s=r(39265).extractOpts;e.exports=function(e,t,r,l,c){c||(c={});var u,d,h,p,f=c.isContour,m=e.cd[0],g=m.trace,y=e.xa,v=e.ya,x=m.x,b=m.y,_=m.z,w=m.xCenter,k=m.yCenter,S=m.zmask,A=g.zhoverformat,T=x,M=b;if(!1!==e.index){try{h=Math.round(e.index[1]),p=Math.round(e.index[0])}catch(B){return void i.error("Error hovering on heatmap, pointNumber must be [row,col], found:",e.index)}if(h<0||h>=_[0].length||p<0||p>_.length)return}else{if(n.inbox(t-x[0],t-x[x.length-1],0)>0||n.inbox(r-b[0],r-b[b.length-1],0)>0)return;if(f){var C;for(T=[2*x[0]-x[1]],C=1;C{"use strict";e.exports={attributes:r(86327),supplyDefaults:r(75696),calc:r(27447),plot:r(21313),colorbar:r(11610),style:r(14141),hoverPoints:r(46954),moduleType:"trace",name:"heatmap",basePlotModule:r(9510),categories:["cartesian","svg","2dMap","showLegend"],meta:{description:["The data that describes the heatmap value-to-color mapping","is set in `z`.","Data in `z` can either be a {2D array} of values (ragged or not)","or a 1D array of values.","In the case where `z` is a {2D array},","say that `z` has N rows and M columns.","Then, by default, the resulting heatmap will have N partitions along","the y axis and M partitions along the x axis.","In other words, the i-th row/ j-th column cell in `z`","is mapped to the i-th partition of the y axis","(starting from the bottom of the plot) and the j-th partition","of the x-axis (starting from the left of the plot).","This behavior can be flipped by using `transpose`.","Moreover, `x` (`y`) can be provided with M or M+1 (N or N+1) elements.","If M (N), then the coordinates correspond to the center of the","heatmap cells and the cells have equal width.","If M+1 (N+1), then the coordinates correspond to the edges of the","heatmap cells.","In the case where `z` is a 1D {array}, the x and y coordinates must be","provided in `x` and `y` respectively to form data triplets."].join(" ")}}},71034:(e,t,r)=>{"use strict";var n=r(84468),i=[[-1,0],[1,0],[0,-1],[0,1]];function o(e){return.5-.25*Math.min(1,.5*e)}function a(e,t,r){var n,o,a,s,l,c,u,d,h,p,f,m,g,y=0;for(s=0;sm&&(y=Math.max(y,Math.abs(e[o][a]-f)/(g-m))))}return y}e.exports=function(e,t){var r,i=1;for(a(e,t),r=0;r.01;r++)i=a(e,t,o(i));return i>.01&&n.log("interp2d didn't converge quickly",i),e}},27475:(e,t,r)=>{"use strict";var n=r(84468);e.exports=function(e,t){e("texttemplate");var r=n.extendFlat({},t.font,{color:"auto",size:"auto"});n.coerceFont(e,"textfont",r)}},83341:(e,t,r)=>{"use strict";var n=r(38361),i=r(84468).isArrayOrTypedArray;e.exports=function(e,t,r,o,a,s){var l,c,u,d=[],h=n.traceIs(e,"contour"),p=n.traceIs(e,"histogram"),f=n.traceIs(e,"gl2d");if(i(t)&&t.length>1&&!p&&"category"!==s.type){var m=t.length;if(!(m<=a))return h?t.slice(0,a):t.slice(0,a+1);if(h||f)d=Array.from(t).slice(0,a);else if(1===a)d="log"===s.type?[.5*t[0],2*t[0]]:[t[0]-.5,t[0]+.5];else if("log"===s.type){for(d=[Math.pow(t[0],1.5)/Math.pow(t[1],.5)],u=1;u{"use strict";var n=r(41871),i=r(23498),o=r(38361),a=r(3172),s=r(85729),l=r(84468),c=r(13480),u=r(40777),d=r(7605),h=r(39265).extractOpts,p=r(39265).makeColorScaleFuncFromTrace,f=r(28795),m=r(83943).LINE_SPACING,g=r(77775),y=r(44740).STYLE,v="heatmap-label";function x(e){return e.selectAll("g."+v)}function b(e){x(e).remove()}function _(e,t){var r=t.length-2,n=l.constrain(l.findBin(e,t),0,r),i=t[n],o=t[n+1],a=l.constrain(n+(e-i)/(o-i)-.5,0,r),s=Math.round(a),c=Math.abs(a-s);return a&&a!==r&&c?{bin0:s,frac:c,bin1:Math.round(s+c/(a-s))}:{bin0:s,bin1:s,frac:0}}function w(e,t){var r=t.length-1,n=l.constrain(l.findBin(e,t),0,r),i=t[n],o=(e-i)/(t[n+1]-i)||0;return o<=0?{bin0:n,bin1:n,frac:0}:o<.5?{bin0:n,bin1:n+1,frac:o}:{bin0:n+1,bin1:n,frac:1-o}}function k(e,t,r){e[t]=r[0],e[t+1]=r[1],e[t+2]=r[2],e[t+3]=Math.round(255*r[3])}e.exports=function(e,t,r,S){var A=t.xaxis,T=t.yaxis;l.makeTraceGroups(S,r,"hm").each((function(t){var r,S,M,C,E,I,P,O,R=n.select(this),L=t[0],D=L.trace,z=D.xgap||0,j=D.ygap||0,F=L.z,N=L.x,B=L.y,V=L.xCenter,U=L.yCenter,H=o.traceIs(D,"contour"),$=H?"best":D.zsmooth,W=F.length,q=l.maxRowLength(F),G=!1,Y=!1;for(I=0;void 0===r&&I0;)S=A.c2p(N[I]),I--;for(S0;)E=T.c2p(B[I]),I--;E=A._length||S<=0||C>=T._length||E<=0)return R.selectAll("image").data([]).exit().remove(),void b(R);"fast"===X?(K=q,J=W):(K=Q,J=ee);var te=document.createElement("canvas");te.width=K,te.height=J;var re,ne,ie=te.getContext("2d",{willReadFrequently:!0}),oe=p(D,{noNumericCheck:!0,returnArray:!0});"fast"===X?(re=G?function(e){return q-1-e}:l.identity,ne=Y?function(e){return W-1-e}:l.identity):(re=function(e){return l.constrain(Math.round(A.c2p(N[e])-r),0,Q)},ne=function(e){return l.constrain(Math.round(T.c2p(B[e])-C),0,ee)});var ae,se,le,ce,ue=ne(0),de=[ue,ue],he=G?0:1,pe=Y?0:1,fe=0,me=0,ge=0,ye=0;function ve(e,t){if(void 0!==e){var r=oe(e);return r[0]=Math.round(r[0]),r[1]=Math.round(r[1]),r[2]=Math.round(r[2]),fe+=t,me+=r[0]*t,ge+=r[1]*t,ye+=r[2]*t,r}return[0,0,0,0]}function xe(e,t,r,n){var i=e[r.bin0];if(void 0===i)return ve(void 0,1);var o,a=e[r.bin1],s=t[r.bin0],l=t[r.bin1],c=a-i||0,u=s-i||0;return o=void 0===a?void 0===l?0:void 0===s?2*(l-i):2*(2*l-s-i)/3:void 0===l?void 0===s?0:2*(2*i-a-s)/3:void 0===s?2*(2*l-a-i)/3:l+i-a-s,ve(i+r.frac*c+n.frac*(u+r.frac*o))}if("default"!==X){var be,_e=0;try{be=new Uint8Array(K*J*4)}catch(gt){be=new Array(K*J*4)}if("smooth"===X){var we,ke,Se,Ae=V||N,Te=U||B,Me=new Array(Ae.length),Ce=new Array(Te.length),Ee=new Array(Q),Ie=V?w:_,Pe=U?w:_;for(I=0;IXe||Xe>T._length))for(P=We;PKe||Ke>A._length)){var Je=u({x:Ze,y:Ye},D,e._fullLayout);Je.x=Ze,Je.y=Ye;var Qe=L.z[I][P];void 0===Qe?(Je.z="",Je.zLabel=""):(Je.z=Qe,Je.zLabel=s.tickText(Ve,Qe,"hover").text);var et=L.text&&L.text[I]&&L.text[I][P];void 0!==et&&!1!==et||(et=""),Je.text=et;var tt=l.texttemplateString(Ne,Je,e._fullLayout._d3locale,Je,D._meta||{});if(tt){var rt=tt.split("
"),nt=rt.length,it=0;for(O=0;O{"use strict";var n=r(41871);e.exports=function(e){n.select(e).selectAll(".hm image").style("opacity",(function(e){return e.trace.opacity}))}},27706:e=>{"use strict";e.exports=function(e,t,r){!1===r("zsmooth")&&(r("xgap"),r("ygap")),r("zhoverformat")}},44168:(e,t,r)=>{"use strict";var n=r(22036),i=r(84468),o=r(38361);function a(e,t){var r=t(e);return"scaled"===(r?t(e+"type","array"):"scaled")&&(t(e+"0"),t("d"+e)),r}e.exports=function(e,t,r,s,l,c){var u,d,h=r("z");if(l=l||"x",c=c||"y",void 0===h||!h.length)return 0;if(i.isArray1D(h)){u=r(l),d=r(c);var p=i.minRowLength(u),f=i.minRowLength(d);if(0===p||0===f)return 0;t._length=Math.min(p,f,h.length)}else{if(u=a(l,r),d=a(c,r),!function(e){for(var t,r=!0,o=!1,a=!1,s=0;s0&&(o=!0);for(var l=0;l{"use strict";for(var n=r(86327),i=r(6636),o=r(64022).extendFlat,a=r(72587).overrideAll,s=["z","x","x0","dx","y","y0","dy","text","transpose","xtype","ytype"],l={},c=0;c{"use strict";var n=r(76107).gl_heatmap2d,i=r(85729),o=r(79689);function a(e,t){this.scene=e,this.uid=t,this.type="heatmapgl",this.name="",this.hoverinfo="all",this.xData=[],this.yData=[],this.zData=[],this.textLabels=[],this.idToIndex=[],this.bounds=[0,0,0,0],this.options={zsmooth:"fast",z:[],x:[],y:[],shape:[0,0],colorLevels:[0],colorValues:[0,0,0,1]},this.heatmap=n(e.glplot,this.options),this.heatmap._trace=this}var s=a.prototype;s.handlePick=function(e){var t=this.options,r=t.shape,n=e.pointId,i=n%r[0],o=Math.floor(n/r[0]),a=n;return{trace:this,dataCoord:e.dataCoord,traceCoord:[t.x[i],t.y[o],t.z[a]],textLabel:this.textLabels[n],name:this.name,pointIndex:[o,i],hoverinfo:this.hoverinfo}},s.update=function(e,t){var r=t[0];this.index=e.index,this.name=e.name,this.hoverinfo=e.hoverinfo;var n=r.z;this.options.z=[].concat.apply([],n);var a=n[0].length,s=n.length;this.options.shape=[a,s],this.options.x=r.x,this.options.y=r.y,this.options.zsmooth=e.zsmooth;var l=function(e){for(var t=e.colorscale,r=e.zmin,n=e.zmax,i=t.length,a=new Array(i),s=new Array(4*i),l=0;l{"use strict";var n=r(84468),i=r(44168),o=r(16155),a=r(9682);e.exports=function(e,t,r,s){function l(r,i){return n.coerce(e,t,a,r,i)}i(e,t,l,s)?(l("text"),l("zsmooth"),o(e,t,s,l,{prefix:"",cLetter:"z"})):t.visible=!1}},37995:(e,t,r)=>{"use strict";var n=["*heatmapgl* trace is deprecated!","Please consider switching to the *heatmap* or *image* trace types.","Alternatively you could contribute/sponsor rewriting this trace type","based on cartesian features and using regl framework."].join(" ");e.exports={attributes:r(9682),supplyDefaults:r(44965),colorbar:r(11610),calc:r(27447),plot:r(92468),moduleType:"trace",name:"heatmapgl",basePlotModule:r(84017),categories:["gl","gl2d","2dMap"],meta:{description:[n,"WebGL version of the heatmap trace type."].join(" ")}}},91757:(e,t,r)=>{"use strict";var n=r(29744),i=r(39363).axisHoverFormat,o=r(84425).rb,a=r(84425).ay,s=r(91740),l=r(74263),c=r(58119),u=r(64022).extendFlat;e.exports={x:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the sample data to be binned on the x axis."].join(" ")},y:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the sample data to be binned on the y axis."].join(" ")},xhoverformat:i("x"),yhoverformat:i("y"),text:u({},n.text,{description:["Sets hover text elements associated with each bar.","If a single string, the same string appears over all bars.","If an array of string, the items are mapped in order to the","this trace's coordinates."].join(" ")}),hovertext:u({},n.hovertext,{description:"Same as `text`."}),orientation:n.orientation,histfunc:{valType:"enumerated",values:["count","sum","avg","min","max"],dflt:"count",editType:"calc",description:["Specifies the binning function used for this histogram trace.","If *count*, the histogram values are computed by counting the","number of values lying inside each bin.","If *sum*, *avg*, *min*, *max*,","the histogram values are computed using","the sum, the average, the minimum or the maximum","of the values lying inside each bin respectively."].join(" ")},histnorm:{valType:"enumerated",values:["","percent","probability","density","probability density"],dflt:"",editType:"calc",description:["Specifies the type of normalization used for this histogram trace.","If **, the span of each bar corresponds to the number of","occurrences (i.e. the number of data points lying inside the bins).","If *percent* / *probability*, the span of each bar corresponds to","the percentage / fraction of occurrences with respect to the total","number of sample points","(here, the sum of all bin HEIGHTS equals 100% / 1).","If *density*, the span of each bar corresponds to the number of","occurrences in a bin divided by the size of the bin interval","(here, the sum of all bin AREAS equals the","total number of sample points).","If *probability density*, the area of each bar corresponds to the","probability that an event will fall into the corresponding bin","(here, the sum of all bin AREAS equals 1)."].join(" ")},cumulative:{enabled:{valType:"boolean",dflt:!1,editType:"calc",description:["If true, display the cumulative distribution by summing the","binned values. Use the `direction` and `centralbin` attributes","to tune the accumulation method.","Note: in this mode, the *density* `histnorm` settings behave","the same as their equivalents without *density*:","** and *density* both rise to the number of data points, and","*probability* and *probability density* both rise to the","number of sample points."].join(" ")},direction:{valType:"enumerated",values:["increasing","decreasing"],dflt:"increasing",editType:"calc",description:["Only applies if cumulative is enabled.","If *increasing* (default) we sum all prior bins, so the result","increases from left to right. If *decreasing* we sum later bins","so the result decreases from left to right."].join(" ")},currentbin:{valType:"enumerated",values:["include","exclude","half"],dflt:"include",editType:"calc",description:["Only applies if cumulative is enabled.","Sets whether the current bin is included, excluded, or has half","of its value included in the current cumulative value.","*include* is the default for compatibility with various other","tools, however it introduces a half-bin bias to the results.","*exclude* makes the opposite half-bin bias, and *half* removes","it."].join(" ")},editType:"calc"},nbinsx:{valType:"integer",min:0,dflt:0,editType:"calc",description:["Specifies the maximum number of desired bins. This value will be used","in an algorithm that will decide the optimal bin size such that the","histogram best visualizes the distribution of the data.","Ignored if `xbins.size` is provided."].join(" ")},xbins:l("x",!0),nbinsy:{valType:"integer",min:0,dflt:0,editType:"calc",description:["Specifies the maximum number of desired bins. This value will be used","in an algorithm that will decide the optimal bin size such that the","histogram best visualizes the distribution of the data.","Ignored if `ybins.size` is provided."].join(" ")},ybins:l("y",!0),autobinx:{valType:"boolean",dflt:null,editType:"calc",description:["Obsolete: since v1.42 each bin attribute is auto-determined","separately and `autobinx` is not needed. However, we accept","`autobinx: true` or `false` and will update `xbins` accordingly","before deleting `autobinx` from the trace."].join(" ")},autobiny:{valType:"boolean",dflt:null,editType:"calc",description:["Obsolete: since v1.42 each bin attribute is auto-determined","separately and `autobiny` is not needed. However, we accept","`autobiny: true` or `false` and will update `ybins` accordingly","before deleting `autobiny` from the trace."].join(" ")},bingroup:{valType:"string",dflt:"",editType:"calc",description:["Set a group of histogram traces which will have compatible bin settings.","Note that traces on the same subplot and with the same *orientation*","under `barmode` *stack*, *relative* and *group* are forced into the same bingroup,","Using `bingroup`, traces under `barmode` *overlay* and on different axes","(of the same axis type) can have compatible bin settings.","Note that histogram and histogram2d* trace can share the same `bingroup`"].join(" ")},hovertemplate:o({},{keys:c.eventDataKeys}),texttemplate:a({arrayOk:!1,editType:"plot"},{keys:["label","value"]}),textposition:u({},n.textposition,{arrayOk:!1}),textfont:s({arrayOk:!1,editType:"plot",colorEditType:"style",description:"Sets the text font."}),outsidetextfont:s({arrayOk:!1,editType:"plot",colorEditType:"style",description:"Sets the font used for `text` lying outside the bar."}),insidetextfont:s({arrayOk:!1,editType:"plot",colorEditType:"style",description:"Sets the font used for `text` lying inside the bar."}),insidetextanchor:n.insidetextanchor,textangle:n.textangle,cliponaxis:n.cliponaxis,constraintext:n.constraintext,marker:n.marker,offsetgroup:n.offsetgroup,alignmentgroup:n.alignmentgroup,selected:n.selected,unselected:n.unselected,_deprecated:{bardir:n._deprecated.bardir},zorder:n.zorder}},98525:e=>{"use strict";e.exports=function(e,t){for(var r=e.length,n=0,i=0;i{"use strict";e.exports=function(e,t){return{start:{valType:"any",editType:"calc",description:["Sets the starting value for the",e,"axis bins. Defaults to the minimum data value,","shifted down if necessary to make nice round values","and to remove ambiguous bin edges. For example, if most of the","data is integers we shift the bin edges 0.5 down, so a `size`","of 5 would have a default `start` of -0.5, so it is clear","that 0-4 are in the first bin, 5-9 in the second, but","continuous data gets a start of 0 and bins [0,5), [5,10) etc.","Dates behave similarly, and `start` should be a date string.","For category data, `start` is based on the category serial","numbers, and defaults to -0.5.",t?"If multiple non-overlaying histograms share a subplot, the first explicit `start` is used exactly and all others are shifted down (if necessary) to differ from that one by an integer number of bins.":""].join(" ")},end:{valType:"any",editType:"calc",description:["Sets the end value for the",e,"axis bins. The last bin may not end exactly at this value,","we increment the bin edge by `size` from `start` until we","reach or exceed `end`. Defaults to the maximum data value.","Like `start`, for dates use a date string, and for category","data `end` is based on the category serial numbers."].join(" ")},size:{valType:"any",editType:"calc",description:["Sets the size of each",e,"axis bin.","Default behavior: If `nbins"+e+"` is 0 or omitted,","we choose a nice round bin size such that the number of bins","is about the same as the typical number of samples in each bin.","If `nbins"+e+"` is provided, we choose a nice round","bin size giving no more than that many bins.","For date data, use milliseconds or *M* for months, as in","`axis.dtick`. For category data, the number of categories to","bin together (always defaults to 1).",t?"If multiple non-overlaying histograms share a subplot, the first explicit `size` is used and all others discarded. If no `size` is provided,the sample data from all traces is combined to determine `size` as described above.":""].join(" ")},editType:"calc"}}},38133:(e,t,r)=>{"use strict";var n=r(22036);e.exports={count:function(e,t,r){return r[e]++,1},sum:function(e,t,r,i){var o=i[t];return n(o)?(o=Number(o),r[e]+=o,o):0},avg:function(e,t,r,i,o){var a=i[t];return n(a)&&(a=Number(a),r[e]+=a,o[e]++),0},min:function(e,t,r,i){var o=i[t];if(n(o)){if(o=Number(o),!n(r[e]))return r[e]=o,o;if(r[e]>o){var a=o-r[e];return r[e]=o,a}}return 0},max:function(e,t,r,i){var o=i[t];if(n(o)){if(o=Number(o),!n(r[e]))return r[e]=o,o;if(r[e]{"use strict";var n=r(65004),i=n.ONEAVGYEAR,o=n.ONEAVGMONTH,a=n.ONEDAY,s=n.ONEHOUR,l=n.ONEMIN,c=n.ONESEC,u=r(85729).tickIncrement;function d(e,t,r,n){if(e*t<=0)return 1/0;for(var i=Math.abs(t-e),o="date"===r.type,a=h(i,o),s=0;s<10;s++){var l=h(80*a,o);if(a===l)break;if(!p(l,e,t,o,r,n))break;a=l}return a}function h(e,t){return t&&e>c?e>a?e>1.1*i?i:e>1.1*o?o:a:e>s?s:e>l?l:c:Math.pow(10,Math.floor(Math.log(e)/Math.LN10))}function p(e,t,r,n,o,s){if(n&&e>a){var l=f(t,o,s),c=f(r,o,s),u=e===i?0:1;return l[u]!==c[u]}return Math.floor(r/e)-Math.floor(t/e)>.1}function f(e,t,r){var n=t.c2d(e,i,r).split("-");return""===n[0]&&(n.unshift(),n[0]="-"+n[0]),n}e.exports=function(e,t,r,n,o){var s,l,c=-1.1*t,h=-.1*t,p=e-h,f=r[0],m=r[1],g=Math.min(d(f+h,f+p,n,o),d(m+h,m+p,n,o)),y=Math.min(d(f+c,f+h,n,o),d(m+c,m+h,n,o));if(g>y&&ya){var v=s===i?1:6,x=s===i?"M12":"M1";return function(t,r){var a=n.c2d(t,i,o),s=a.indexOf("-",v);s>0&&(a=a.substr(0,s));var c=n.d2c(a,0,o);if(c{"use strict";var n=r(22036),i=r(84468),o=r(38361),a=r(85729),s=r(15251),l=r(38133),c=r(67632),u=r(98525),d=r(18121);function h(e,t,r,s,l){var c,u,d,p,f,m,g,y=s+"bins",v=e._fullLayout,x=t["_"+s+"bingroup"],b=v._histogramBinOpts[x],_="overlay"===v.barmode,w=function(e){return r.r2c(e,0,p)},k=function(e){return r.c2r(e,0,p)},S="date"===r.type?function(e){return e||0===e?i.cleanDate(e,null,p):null}:function(e){return n(e)?Number(e):null};function A(e,t,r){t[e+"Found"]?(t[e]=S(t[e]),null===t[e]&&(t[e]=r[e])):(m[e]=t[e]=r[e],i.nestedProperty(u[0],y+"."+e).set(r[e]))}if(t["_"+s+"autoBinFinished"])delete t["_"+s+"autoBinFinished"];else{u=b.traces;var T=[],M=!0,C=!1,E=!1;for(c=0;cr.r2l(F)&&(B=a.tickIncrement(B,b.size,!0,p)),L.start=r.l2r(B),j||i.nestedProperty(t,y+".start").set(L.start)}var V=b.end,U=r.r2l(R.end),H=void 0!==U;if((b.endFound||H)&&U!==r.r2l(V)){var $=H?U:i.aggNums(Math.max,null,f);L.end=r.l2r($),H||i.nestedProperty(t,y+".start").set(L.end)}var W="autobin"+s;return!1===t._input[W]&&(t._input[y]=i.extendFlat({},t[y]||{}),delete t._input[W],delete t[W]),[L,f]}e.exports={calc:function(e,t){var r,o,p,f,m=[],g=[],y="h"===t.orientation,v=a.getFromId(e,y?t.yaxis:t.xaxis),x=y?"y":"x",b={x:"y",y:"x"}[x],_=t[x+"calendar"],w=t.cumulative,k=h(e,t,v,x),S=k[0],A=k[1],T="string"===typeof S.size,M=[],C=T?M:S,E=[],I=[],P=[],O=0,R=t.histnorm,L=t.histfunc,D=-1!==R.indexOf("density");w.enabled&&D&&(R=R.replace(/ ?density$/,""),D=!1);var z,j="max"===L||"min"===L?null:0,F=l.count,N=c[R],B=!1,V=function(e){return v.r2c(e,0,_)};for(i.isArrayOrTypedArray(t[b])&&"count"!==L&&(z=t[b],B="avg"===L,F=l[L]),r=V(S.start),p=V(S.end)+(r-a.tickIncrement(r,S.size,!1,_))/1e6;r=0&&f=0;n--)s(n);else if("increasing"===t){for(n=1;n=0;n--)e[n]+=e[n+1];"exclude"===r&&(e.push(0),e.shift())}}(g,w.direction,w.currentbin);var K=Math.min(m.length,g.length),J=[],Q=0,ee=K-1;for(r=0;r=Q;r--)if(g[r]){ee=r;break}for(r=Q;r<=ee;r++)if(n(m[r])&&n(g[r])){var te={p:m[r],s:g[r],b:0};w.enabled||(te.pts=P[r],q?te.ph0=te.ph1=P[r].length?A[P[r][0]]:m[r]:(t._computePh=!0,te.ph0=$(M[r]),te.ph1=$(M[r+1],!0))),J.push(te)}return 1===J.length&&(J[0].width1=a.tickIncrement(J[0].p,S.size,!1,_)-J[0].p),s(J,t),i.isArrayOrTypedArray(t.selectedpoints)&&i.tagSelected(J,t,X),J},calcAllAutoBins:h}},58119:e=>{"use strict";e.exports={eventDataKeys:["binNumber"]}},15801:(e,t,r)=>{"use strict";var n=r(84468),i=r(11576),o=r(38361).traceIs,a=r(53558),s=r(81543).validateCornerradius,l=n.nestedProperty,c=r(80038).getAxisGroup,u=[{aStr:{x:"xbins.start",y:"ybins.start"},name:"start"},{aStr:{x:"xbins.end",y:"ybins.end"},name:"end"},{aStr:{x:"xbins.size",y:"ybins.size"},name:"size"},{aStr:{x:"nbinsx",y:"nbinsy"},name:"nbins"}],d=["x","y"];e.exports=function(e,t){var r,h,p,f,m,g,y,v=t._histogramBinOpts={},x=[],b={},_=[];function w(e,t){return n.coerce(r._input,r,r._module.attributes,e,t)}function k(e){return"v"===e.orientation?"x":"y"}function S(e,r,o){var a=e.uid+"__"+o;r||(r=a);var s=function(e,r){return i.getFromTrace({_fullLayout:t},e,r).type}(e,o),l=e[o+"calendar"]||"",c=v[r],u=!0;c&&(s===c.axType&&l===c.calendar?(u=!1,c.traces.push(e),c.dirs.push(o)):(r=a,s!==c.axType&&n.warn(["Attempted to group the bins of trace",e.index,"set on a","type:"+s,"axis","with bins on","type:"+c.axType,"axis."].join(" ")),l!==c.calendar&&n.warn(["Attempted to group the bins of trace",e.index,"set with a",l,"calendar","with bins",c.calendar?"on a "+c.calendar+" calendar":"w/o a set calendar"].join(" ")))),u&&(v[r]={traces:[e],dirs:[o],axType:s,calendar:e[o+"calendar"]||""}),e["_"+o+"bingroup"]=r}for(m=0;m{"use strict";var n=r(38361),i=r(84468),o=r(7605),a=r(81543).handleText,s=r(4241),l=r(91757);e.exports=function(e,t,r,c){function u(r,n){return i.coerce(e,t,l,r,n)}var d=u("x"),h=u("y");u("cumulative.enabled")&&(u("cumulative.direction"),u("cumulative.currentbin")),u("text");var p=u("textposition");a(e,t,c,u,p,{moduleHasSelected:!0,moduleHasUnselected:!0,moduleHasConstrain:!0,moduleHasCliponaxis:!0,moduleHasTextangle:!0,moduleHasInsideanchor:!0}),u("hovertext"),u("hovertemplate"),u("xhoverformat"),u("yhoverformat");var f=u("orientation",h&&!d?"h":"v"),m="v"===f?"x":"y",g="v"===f?"y":"x",y=d&&h?Math.min(i.minRowLength(d)&&i.minRowLength(h)):i.minRowLength(t[m]||[]);if(y){t._length=y,n.getComponentMethod("calendars","handleTraceDefaults")(e,t,["x","y"],c),t[g]&&u("histfunc"),u("histnorm"),u("autobin"+m),s(e,t,u,r,c),i.coerceSelectionMarkerOpacity(t,u);var v=(t.marker.line||{}).color,x=n.getComponentMethod("errorbars","supplyDefaults");x(e,t,v||o.defaultLine,{axis:"y"}),x(e,t,v||o.defaultLine,{axis:"x",inherit:"y"}),u("zorder")}else t.visible=!1}},89057:e=>{"use strict";e.exports=function(e,t,r,n,i){if(e.x="xVal"in t?t.xVal:t.x,e.y="yVal"in t?t.yVal:t.y,"zLabelVal"in t&&(e.z=t.zLabelVal),t.xa&&(e.xaxis=t.xa),t.ya&&(e.yaxis=t.ya),!(r.cumulative||{}).enabled){var o,a=Array.isArray(i)?n[0].pts[i[0]][i[1]]:n[i].pts;if(e.pointNumbers=a,e.binNumber=e.pointNumber,delete e.pointNumber,delete e.pointIndex,r._indexToPoints){o=[];for(var s=0;s{"use strict";var n=r(3332).hoverPoints,i=r(85729).hoverLabelText;e.exports=function(e,t,r,o,a){var s=n(e,t,r,o,a);if(s){var l=(e=s[0]).cd[e.index],c=e.cd[0].trace;if(!c.cumulative.enabled){var u="h"===c.orientation?"y":"x";e[u+"Label"]=i(e[u+"a"],[l.ph0,l.ph1],c[u+"hoverformat"])}return s}}},48182:(e,t,r)=>{"use strict";e.exports={attributes:r(91757),layoutAttributes:r(23707),supplyDefaults:r(47866),crossTraceDefaults:r(15801),supplyLayoutDefaults:r(57724),calc:r(52257).calc,crossTraceCalc:r(51203).crossTraceCalc,plot:r(32018).plot,layerName:"barlayer",style:r(52464).style,styleOnSelect:r(52464).styleOnSelect,colorbar:r(17789),hoverPoints:r(51068),selectPoints:r(12969),eventData:r(89057),moduleType:"trace",name:"histogram",basePlotModule:r(9510),categories:["bar-like","cartesian","svg","bar","histogram","oriented","errorBarsOK","showLegend"],meta:{description:["The sample data from which statistics are computed is set in `x`","for vertically spanning histograms and","in `y` for horizontally spanning histograms.","Binning options are set `xbins` and `ybins` respectively","if no aggregation data is provided."].join(" ")}}},67632:e=>{"use strict";e.exports={percent:function(e,t){for(var r=e.length,n=100/t,i=0;i{"use strict";var n=r(91757),i=r(74263),o=r(86327),a=r(75622),s=r(39363).axisHoverFormat,l=r(84425).rb,c=r(84425).ay,u=r(6636),d=r(64022).extendFlat;e.exports=d({x:n.x,y:n.y,z:{valType:"data_array",editType:"calc",description:"Sets the aggregation data."},marker:{color:{valType:"data_array",editType:"calc",description:"Sets the aggregation data."},editType:"calc"},histnorm:n.histnorm,histfunc:n.histfunc,nbinsx:n.nbinsx,xbins:i("x"),nbinsy:n.nbinsy,ybins:i("y"),autobinx:n.autobinx,autobiny:n.autobiny,bingroup:d({},n.bingroup,{description:["Set the `xbingroup` and `ybingroup` default prefix","For example, setting a `bingroup` of *1* on two histogram2d traces","will make them their x-bins and y-bins match separately."].join(" ")}),xbingroup:d({},n.bingroup,{description:["Set a group of histogram traces which will have compatible x-bin settings.","Using `xbingroup`, histogram2d and histogram2dcontour traces ","(on axes of the same axis type) can have compatible x-bin settings.","Note that the same `xbingroup` value can be used to set (1D) histogram `bingroup`"].join(" ")}),ybingroup:d({},n.bingroup,{description:["Set a group of histogram traces which will have compatible y-bin settings.","Using `ybingroup`, histogram2d and histogram2dcontour traces ","(on axes of the same axis type) can have compatible y-bin settings.","Note that the same `ybingroup` value can be used to set (1D) histogram `bingroup`"].join(" ")}),xgap:o.xgap,ygap:o.ygap,zsmooth:o.zsmooth,xhoverformat:s("x"),yhoverformat:s("y"),zhoverformat:s("z",1),hovertemplate:l({},{keys:"z"}),texttemplate:c({arrayOk:!1,editType:"plot"},{keys:"z"}),textfont:o.textfont,showlegend:d({},a.showlegend,{dflt:!1})},u("",{cLetter:"z",autoColorDflt:!1}))},86807:(e,t,r)=>{"use strict";var n=r(84468),i=r(85729),o=r(38133),a=r(67632),s=r(98525),l=r(18121),c=r(52257).calcAllAutoBins;function u(e,t,r,n){var i,o=new Array(e);if(n)for(i=0;iM&&k.splice(M,k.length-M),T.length>M&&T.splice(M,T.length-M);var C=[],E=[],I=[],P="string"===typeof w.size,O="string"===typeof A.size,R=[],L=[],D=P?R:w,z=O?L:A,j=0,F=[],N=[],B=t.histnorm,V=t.histfunc,U=-1!==B.indexOf("density"),H="max"===V||"min"===V?null:0,$=o.count,W=a[B],q=!1,G=[],Y=[],X="z"in t?t.z:"marker"in t&&Array.isArray(t.marker.color)?t.marker.color:"";X&&"count"!==V&&(q="avg"===V,$=o[V]);var Z=w.size,K=x(w.start),J=x(w.end)+(K-i.tickIncrement(K,Z,!1,y))/1e6;for(r=K;r=0&&p=0&&f{"use strict";var n=r(84468),i=r(36193),o=r(27706),a=r(16155),s=r(27475),l=r(18935);e.exports=function(e,t,r,c){function u(r,i){return n.coerce(e,t,l,r,i)}i(e,t,u,c),!1!==t.visible&&(o(e,t,u,c),a(e,t,c,u,{prefix:"",cLetter:"z"}),u("hovertemplate"),s(u,c),u("xhoverformat"),u("yhoverformat"))}},51050:(e,t,r)=>{"use strict";var n=r(46954),i=r(85729).hoverLabelText;e.exports=function(e,t,r,o,a){var s=n(e,t,r,o,a);if(s){var l=(e=s[0]).index,c=l[0],u=l[1],d=e.cd[0],h=d.trace,p=d.xRanges[u],f=d.yRanges[c];return e.xLabel=i(e.xa,[p[0],p[1]],h.xhoverformat),e.yLabel=i(e.ya,[f[0],f[1]],h.yhoverformat),s}}},78332:(e,t,r)=>{"use strict";e.exports={attributes:r(18935),supplyDefaults:r(90992),crossTraceDefaults:r(15801),calc:r(27447),plot:r(21313),layerName:"heatmaplayer",colorbar:r(11610),style:r(14141),hoverPoints:r(51050),eventData:r(89057),moduleType:"trace",name:"histogram2d",basePlotModule:r(9510),categories:["cartesian","svg","2dMap","histogram","showLegend"],meta:{hrName:"histogram_2d",description:["The sample data from which statistics are computed is set in `x`","and `y` (where `x` and `y` represent marginal distributions,","binning is set in `xbins` and `ybins` in this case)","or `z` (where `z` represent the 2D distribution and binning set,","binning is set by `x` and `y` in this case).","The resulting distribution is visualized as a heatmap."].join(" ")}}},36193:(e,t,r)=>{"use strict";var n=r(38361),i=r(84468);e.exports=function(e,t,r,o){var a=r("x"),s=r("y"),l=i.minRowLength(a),c=i.minRowLength(s);l&&c?(t._length=Math.min(l,c),n.getComponentMethod("calendars","handleTraceDefaults")(e,t,["x","y"],o),(r("z")||r("marker.color"))&&r("histfunc"),r("histnorm"),r("autobinx"),r("autobiny")):t.visible=!1}},637:(e,t,r)=>{"use strict";var n=r(18935),i=r(15425),o=r(6636),a=r(39363).axisHoverFormat,s=r(64022).extendFlat;e.exports=s({x:n.x,y:n.y,z:n.z,marker:n.marker,histnorm:n.histnorm,histfunc:n.histfunc,nbinsx:n.nbinsx,xbins:n.xbins,nbinsy:n.nbinsy,ybins:n.ybins,autobinx:n.autobinx,autobiny:n.autobiny,bingroup:n.bingroup,xbingroup:n.xbingroup,ybingroup:n.ybingroup,autocontour:i.autocontour,ncontours:i.ncontours,contours:i.contours,line:{color:i.line.color,width:s({},i.line.width,{dflt:.5,description:"Sets the contour line width in (in px)"}),dash:i.line.dash,smoothing:i.line.smoothing,editType:"plot"},xhoverformat:a("x"),yhoverformat:a("y"),zhoverformat:a("z",1),hovertemplate:n.hovertemplate,texttemplate:i.texttemplate,textfont:i.textfont},o("",{cLetter:"z",editTypeOverride:"calc"}))},38154:(e,t,r)=>{"use strict";var n=r(84468),i=r(36193),o=r(95248),a=r(19704),s=r(27475),l=r(637);e.exports=function(e,t,r,c){function u(r,i){return n.coerce(e,t,l,r,i)}i(e,t,u,c),!1!==t.visible&&(o(e,t,u,(function(r){return n.coerce2(e,t,l,r)})),a(e,t,u,c),u("xhoverformat"),u("yhoverformat"),u("hovertemplate"),t.contours&&"heatmap"===t.contours.coloring&&s(u,c))}},93350:(e,t,r)=>{"use strict";e.exports={attributes:r(637),supplyDefaults:r(38154),crossTraceDefaults:r(15801),calc:r(15621),plot:r(30155).plot,layerName:"contourlayer",style:r(84923),colorbar:r(62848),hoverPoints:r(69768),moduleType:"trace",name:"histogram2dcontour",basePlotModule:r(9510),categories:["cartesian","svg","2dMap","contour","histogram","showLegend"],meta:{hrName:"histogram_2d_contour",description:["The sample data from which statistics are computed is set in `x`","and `y` (where `x` and `y` represent marginal distributions,","binning is set in `xbins` and `ybins` in this case)","or `z` (where `z` represent the 2D distribution and binning set,","binning is set by `x` and `y` in this case).","The resulting distribution is visualized as a contour plot."].join(" ")}}},34302:(e,t,r)=>{"use strict";var n=r(84425).rb,i=r(84425).ay,o=r(6636),a=r(81159).u,s=r(59453),l=r(10535),c=r(14345),u=r(35995),d=r(64022).extendFlat,h=r(2703).k;e.exports={labels:l.labels,parents:l.parents,values:l.values,branchvalues:l.branchvalues,count:l.count,level:l.level,maxdepth:l.maxdepth,tiling:{orientation:{valType:"enumerated",values:["v","h"],dflt:"h",editType:"plot",description:["When set in conjunction with `tiling.flip`, determines on","which side the root nodes are drawn in the chart. If","`tiling.orientation` is *v* and `tiling.flip` is **, the root","nodes appear at the top. If `tiling.orientation` is *v* and","`tiling.flip` is *y*, the root nodes appear at the bottom. If","`tiling.orientation` is *h* and `tiling.flip` is **, the","root nodes appear at the left. If `tiling.orientation` is *h*","and `tiling.flip` is *x*, the root nodes appear at the right."].join(" ")},flip:c.tiling.flip,pad:{valType:"number",min:0,dflt:0,editType:"plot",description:["Sets the inner padding (in px)."].join(" ")},editType:"calc"},marker:d({colors:l.marker.colors,line:l.marker.line,pattern:h,editType:"calc"},o("marker",{colorAttr:"colors",anim:!1})),leaf:l.leaf,pathbar:c.pathbar,text:s.text,textinfo:l.textinfo,texttemplate:i({editType:"plot"},{keys:u.eventDataKeys.concat(["label","value"])}),hovertext:s.hovertext,hoverinfo:l.hoverinfo,hovertemplate:n({},{keys:u.eventDataKeys}),textfont:s.textfont,insidetextfont:s.insidetextfont,outsidetextfont:c.outsidetextfont,textposition:c.textposition,sort:s.sort,root:l.root,domain:a({name:"icicle",trace:!0,editType:"calc"})}},60078:(e,t,r)=>{"use strict";var n=r(68543);t.name="icicle",t.plot=function(e,r,i,o){n.plotBasePlot(t.name,e,r,i,o)},t.clean=function(e,r,i,o){n.cleanBasePlot(t.name,e,r,i,o)}},11930:(e,t,r)=>{"use strict";var n=r(54151);t._=function(e,t){return n.calc(e,t)},t.t=function(e){return n._runCrossTraceCalc("icicle",e)}},21769:(e,t,r)=>{"use strict";var n=r(84468),i=r(34302),o=r(7605),a=r(81159).N,s=r(81543).handleText,l=r(41508).TEXTPAD,c=r(69834).handleMarkerDefaults,u=r(39265),d=u.hasColorscale,h=u.handleDefaults;e.exports=function(e,t,r,u){function p(r,o){return n.coerce(e,t,i,r,o)}var f=p("labels"),m=p("parents");if(f&&f.length&&m&&m.length){var g=p("values");g&&g.length?p("branchvalues"):p("count"),p("level"),p("maxdepth"),p("tiling.orientation"),p("tiling.flip"),p("tiling.pad");var y=p("text");p("texttemplate"),t.texttemplate||p("textinfo",n.isArrayOrTypedArray(y)?"text+label":"label"),p("hovertext"),p("hovertemplate");var v=p("pathbar.visible");s(e,t,u,p,"auto",{hasPathbar:v,moduleHasSelected:!1,moduleHasUnselected:!1,moduleHasConstrain:!1,moduleHasCliponaxis:!1,moduleHasTextangle:!1,moduleHasInsideanchor:!1}),p("textposition"),c(e,t,u,p);var x=t._hasColorscale=d(e,"marker","colors")||(e.marker||{}).coloraxis;x&&h(e,t,u,p,{prefix:"marker.",cLetter:"c"}),p("leaf.opacity",x?1:.7),t._hovered={marker:{line:{width:2,color:o.contrast(u.paper_bgcolor)}}},v&&(p("pathbar.thickness",t.pathbar.textfont.size+2*l),p("pathbar.side"),p("pathbar.edgeshape")),p("sort"),p("root.color"),a(t,u,p),t._length=null}else t.visible=!1}},28678:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468),o=r(3172),a=r(13480),s=r(72685),l=r(5762).styleOne,c=r(35995),u=r(4425),d=r(10676),h=r(88817).formatSliceLabel,p=!1;e.exports=function(e,t,r,f,m){var g=m.width,y=m.height,v=m.viewX,x=m.viewY,b=m.pathSlice,_=m.toMoveInsideSlice,w=m.strTransform,k=m.hasTransition,S=m.handleSlicesExit,A=m.makeUpdateSliceInterpolator,T=m.makeUpdateTextInterpolator,M=m.prevEntry,C=e._context.staticPlot,E=e._fullLayout,I=t[0].trace,P=-1!==I.textposition.indexOf("left"),O=-1!==I.textposition.indexOf("right"),R=-1!==I.textposition.indexOf("bottom"),L=s(r,[g,y],{flipX:I.tiling.flip.indexOf("x")>-1,flipY:I.tiling.flip.indexOf("y")>-1,orientation:I.tiling.orientation,pad:{inner:I.tiling.pad},maxDepth:I._maxDepth}).descendants(),D=1/0,z=-1/0;L.forEach((function(e){var t=e.depth;t>=I._maxDepth?(e.x0=e.x1=(e.x0+e.x1)/2,e.y0=e.y1=(e.y0+e.y1)/2):(D=Math.min(D,t),z=Math.max(z,t))})),f=f.data(L,u.getPtId),I._maxVisibleLayers=isFinite(z)?z-D+1:0,f.enter().append("g").classed("slice",!0),S(f,p,{},[g,y],b),f.order();var j=null;if(k&&M){var F=u.getPtId(M);f.each((function(e){null===j&&u.getPtId(e)===F&&(j={x0:e.x0,x1:e.x1,y0:e.y0,y1:e.y1})}))}var N=function(){return j||{x0:0,x1:g,y0:0,y1:y}},B=f;return k&&(B=B.transition().each("end",(function(){var t=n.select(this);u.setSliceCursor(t,e,{hideOnRoot:!0,hideOnLeaves:!1,isTransitioning:!1})}))),B.each((function(s){s._x0=v(s.x0),s._x1=v(s.x1),s._y0=x(s.y0),s._y1=x(s.y1),s._hoverX=v(s.x1-I.tiling.pad),s._hoverY=x(R?s.y1-I.tiling.pad/2:s.y0+I.tiling.pad/2);var f=n.select(this),m=i.ensureSingle(f,"path","surface",(function(e){e.style("pointer-events",C?"none":"all")}));k?m.transition().attrTween("d",(function(e){var t=A(e,p,N(),[g,y],{orientation:I.tiling.orientation,flipX:I.tiling.flip.indexOf("x")>-1,flipY:I.tiling.flip.indexOf("y")>-1});return function(e){return b(t(e))}})):m.attr("d",b),f.call(d,r,e,t,{styleOne:l,eventDataKeys:c.eventDataKeys,transitionTime:c.CLICK_TRANSITION_TIME,transitionEasing:c.CLICK_TRANSITION_EASING}).call(u.setSliceCursor,e,{isTransitioning:e._transitioning}),m.call(l,s,I,e,{hovered:!1}),s.x0===s.x1||s.y0===s.y1?s._text="":s._text=h(s,r,I,t,E)||"";var S=i.ensureSingle(f,"g","slicetext"),M=i.ensureSingle(S,"text","",(function(e){e.attr("data-notex",1)})),L=i.ensureUniformFontSize(e,u.determineTextFont(I,s,E.font));M.text(s._text||" ").classed("slicetext",!0).attr("text-anchor",O?"end":P?"start":"middle").call(o.font,L).call(a.convertToTspans,e),s.textBB=o.bBox(M.node()),s.transform=_(s,{fontSize:L.size}),s.transform.fontSize=L.size,k?M.transition().attrTween("transform",(function(e){var t=T(e,p,N(),[g,y]);return function(e){return w(t(e))}})):M.attr("transform",w(s))})),j}},4639:(e,t,r)=>{"use strict";e.exports={moduleType:"trace",name:"icicle",basePlotModule:r(60078),categories:[],animatable:!0,attributes:r(34302),layoutAttributes:r(2013),supplyDefaults:r(21769),supplyLayoutDefaults:r(74890),calc:r(11930)._,crossTraceCalc:r(11930).t,plot:r(25006),style:r(5762).style,colorbar:r(17789),meta:{description:["Visualize hierarchal data from leaves (and/or outer branches) towards root","with rectangles. The icicle sectors are determined by the entries in","*labels* or *ids* and in *parents*."].join(" ")}}},2013:e=>{"use strict";e.exports={iciclecolorway:{valType:"colorlist",editType:"calc",description:["Sets the default icicle slice colors. Defaults to the main","`colorway` used for trace colors. If you specify a new","list here it can still be extended with lighter and darker","colors, see `extendiciclecolors`."].join(" ")},extendiciclecolors:{valType:"boolean",dflt:!0,editType:"calc",description:["If `true`, the icicle slice colors (whether given by `iciclecolorway` or","inherited from `colorway`) will be extended to three times its","original length by first repeating every color 20% lighter then","each color 20% darker. This is intended to reduce the likelihood","of reusing the same color when you have many slices, but you can","set `false` to disable.","Colors provided in the trace, using `marker.colors`, are never","extended."].join(" ")}}},74890:(e,t,r)=>{"use strict";var n=r(84468),i=r(2013);e.exports=function(e,t){function r(r,o){return n.coerce(e,t,i,r,o)}r("iciclecolorway",t.colorway),r("extendiciclecolors")}},72685:(e,t,r)=>{"use strict";var n=r(28203),i=r(10654);e.exports=function(e,t,r){var o=r.flipX,a=r.flipY,s="h"===r.orientation,l=r.maxDepth,c=t[0],u=t[1];l&&(c=(e.height+1)*t[0]/Math.min(e.height+1,l),u=(e.height+1)*t[1]/Math.min(e.height+1,l));var d=n.partition().padding(r.pad.inner).size(s?[t[1],c]:[t[0],u])(e);return(s||o||a)&&i(d,t,{swapXY:s,flipX:o,flipY:a}),d}},25006:(e,t,r)=>{"use strict";var n=r(18434),i=r(28678);e.exports=function(e,t,r,o){return n(e,t,r,o,{type:"icicle",drawDescendants:i})}},5762:(e,t,r)=>{"use strict";var n=r(41871),i=r(7605),o=r(84468),a=r(35655).resizeText,s=r(32155);function l(e,t,r,n){var a=t.data.data,l=!t.children,c=a.i,u=o.castOption(r,c,"marker.line.color")||i.defaultLine,d=o.castOption(r,c,"marker.line.width")||0;e.call(s,t,r,n).style("stroke-width",d).call(i.stroke,u).style("opacity",l?r.leaf.opacity:null)}e.exports={style:function(e){var t=e._fullLayout._iciclelayer.selectAll(".trace");a(e,t,"icicle"),t.each((function(t){var r=n.select(this),i=t[0].trace;r.style("opacity",i.opacity),r.selectAll("path.surface").each((function(t){n.select(this).call(l,t,i,e)}))}))},styleOne:l}},95296:(e,t,r)=>{"use strict";for(var n=r(75622),i=r(22049).zorder,o=r(84425).rb,a=r(64022).extendFlat,s=r(57108).colormodel,l=["rgb","rgba","rgba256","hsl","hsla"],c=[],u=[],d=0;d][;base64],"'].join(" ")},z:{valType:"data_array",editType:"calc",description:["A 2-dimensional array in which each element is an array of 3 or 4 numbers representing a color."].join(" ")},colormodel:{valType:"enumerated",values:l,editType:"calc",description:["Color model used to map the numerical color components described in `z` into colors.","If `source` is specified, this attribute will be set to `rgba256`","otherwise it defaults to `rgb`."].join(" ")},zsmooth:{valType:"enumerated",values:["fast",!1],dflt:!1,editType:"plot",description:["Picks a smoothing algorithm used to smooth `z` data.","This only applies for image traces that use the `source` attribute."].join(" ")},zmin:{valType:"info_array",items:[{valType:"number",editType:"calc"},{valType:"number",editType:"calc"},{valType:"number",editType:"calc"},{valType:"number",editType:"calc"}],editType:"calc",description:["Array defining the lower bound for each color component.","Note that the default value will depend on the colormodel.",c.join(" ")].join(" ")},zmax:{valType:"info_array",items:[{valType:"number",editType:"calc"},{valType:"number",editType:"calc"},{valType:"number",editType:"calc"},{valType:"number",editType:"calc"}],editType:"calc",description:["Array defining the higher bound for each color component.","Note that the default value will depend on the colormodel.",u.join(" ")].join(" ")},x0:{valType:"any",dflt:0,editType:"calc+clearAxisTypes",description:["Set the image's x position. The left edge of the image","(or the right edge if the x axis is reversed or dx is negative)","will be found at xmin=x0-dx/2"].join(" ")},y0:{valType:"any",dflt:0,editType:"calc+clearAxisTypes",description:["Set the image's y position. The top edge of the image","(or the bottom edge if the y axis is NOT reversed or if dy is negative)","will be found at ymin=y0-dy/2. By default when an image trace is","included, the y axis will be reversed so that the image is right-side-up,","but you can disable this by setting yaxis.autorange=true or by providing","an explicit y axis range."].join(" ")},dx:{valType:"number",dflt:1,editType:"calc",description:"Set the pixel's horizontal size."},dy:{valType:"number",dflt:1,editType:"calc",description:"Set the pixel's vertical size"},text:{valType:"data_array",editType:"plot",description:"Sets the text elements associated with each z value."},hovertext:{valType:"data_array",editType:"plot",description:"Same as `text`."},hoverinfo:a({},n.hoverinfo,{flags:["x","y","z","color","name","text"],dflt:"x+y+z+text+name"}),hovertemplate:o({},{keys:["z","color","colormodel"]}),zorder:i,transforms:void 0})},656:(e,t,r)=>{"use strict";var n=r(84468),i=r(57108),o=r(22036),a=r(85729),s=r(84468).maxRowLength,l=r(39992).p;function c(e,t,r,i){return function(o){return n.constrain((o-e)*t,r,i)}}function u(e,t){return function(r){return n.constrain(r,e,t)}}e.exports=function(e,t){var r,n;if(t._hasZ)r=t.z.length,n=s(t.z);else if(t._hasSource){var d=l(t.source);r=d.height,n=d.width}var h,p=a.getFromId(e,t.xaxis||"x"),f=a.getFromId(e,t.yaxis||"y"),m=p.d2c(t.x0)-t.dx/2,g=f.d2c(t.y0)-t.dy/2,y=[m,m+n*t.dx],v=[g,g+r*t.dy];if(p&&"log"===p.type)for(h=0;h{"use strict";e.exports={colormodel:{rgb:{min:[0,0,0],max:[255,255,255],fmt:function(e){return e.slice(0,3)},suffix:["","",""]},rgba:{min:[0,0,0,0],max:[255,255,255,1],fmt:function(e){return e.slice(0,4)},suffix:["","","",""]},rgba256:{colormodel:"rgba",zminDflt:[0,0,0,0],zmaxDflt:[255,255,255,255],min:[0,0,0,0],max:[255,255,255,1],fmt:function(e){return e.slice(0,4)},suffix:["","","",""]},hsl:{min:[0,0,0],max:[360,100,100],fmt:function(e){var t=e.slice(0,3);return t[1]=t[1]+"%",t[2]=t[2]+"%",t},suffix:["\xb0","%","%"]},hsla:{min:[0,0,0,0],max:[360,100,100,1],fmt:function(e){var t=e.slice(0,4);return t[1]=t[1]+"%",t[2]=t[2]+"%",t},suffix:["\xb0","%","%",""]}}}},60311:(e,t,r)=>{"use strict";var n=r(84468),i=r(95296),o=r(57108),a=r(5240).IMAGE_URL_PREFIX;e.exports=function(e,t){function r(r,o){return n.coerce(e,t,i,r,o)}r("source"),t.source&&!t.source.match(a)&&delete t.source,t._hasSource=!!t.source;var s,l=r("z");(t._hasZ=!(void 0===l||!l.length||!l[0]||!l[0].length),t._hasZ||t._hasSource)?(r("x0"),r("y0"),r("dx"),r("dy"),t._hasZ?(r("colormodel","rgb"),r("zmin",(s=o.colormodel[t.colormodel]).zminDflt||s.min),r("zmax",s.zmaxDflt||s.max)):t._hasSource&&(t.colormodel="rgba256",s=o.colormodel[t.colormodel],t.zmin=s.zminDflt,t.zmax=s.zmaxDflt),r("zsmooth"),r("text"),r("hovertext"),r("hovertemplate"),t._length=null,r("zorder")):t.visible=!1}},54284:e=>{"use strict";e.exports=function(e,t){return"xVal"in t&&(e.x=t.xVal),"yVal"in t&&(e.y=t.yVal),t.xa&&(e.xaxis=t.xa),t.ya&&(e.yaxis=t.ya),e.color=t.color,e.colormodel=t.trace.colormodel,e.z||(e.z=t.color),e}},39992:(e,t,r)=>{"use strict";var n=r(77681),i=r(5240).IMAGE_URL_PREFIX,o=r(26382).Buffer;t.p=function(e){var t=e.replace(i,""),r=new o(t,"base64");return n(r)}},28935:(e,t,r)=>{"use strict";var n=r(32212),i=r(84468),o=i.isArrayOrTypedArray,a=r(57108);e.exports=function(e,t,r){var s=e.cd[0],l=s.trace,c=e.xa,u=e.ya;if(!(n.inbox(t-s.x0,t-(s.x0+s.w*l.dx),0)>0||n.inbox(r-s.y0,r-(s.y0+s.h*l.dy),0)>0)){var d,h=Math.floor((t-s.x0)/l.dx),p=Math.floor(Math.abs(r-s.y0)/l.dy);if(l._hasZ?d=s.z[p][h]:l._hasSource&&(d=l._canvas.el.getContext("2d",{willReadFrequently:!0}).getImageData(h,p,1,1).data),d){var f,m=s.hi||l.hoverinfo;if(m){var g=m.split("+");-1!==g.indexOf("all")&&(g=["color"]),-1!==g.indexOf("color")&&(f=!0)}var y,v=a.colormodel[l.colormodel],x=v.colormodel||l.colormodel,b=x.length,_=l._scaler(d),w=v.suffix,k=[];(l.hovertemplate||f)&&(k.push("["+[_[0]+w[0],_[1]+w[1],_[2]+w[2]].join(", ")),4===b&&k.push(", "+_[3]+w[3]),k.push("]"),k=k.join(""),e.extraText=x.toUpperCase()+": "+k),o(l.hovertext)&&o(l.hovertext[p])?y=l.hovertext[p][h]:o(l.text)&&o(l.text[p])&&(y=l.text[p][h]);var S=u.c2p(s.y0+(p+.5)*l.dy),A=s.x0+(h+.5)*l.dx,T=s.y0+(p+.5)*l.dy,M="["+d.slice(0,l.colormodel.length).join(", ")+"]";return[i.extendFlat(e,{index:[p,h],x0:c.c2p(s.x0+h*l.dx),x1:c.c2p(s.x0+(h+1)*l.dx),y0:S,y1:S,color:_,xVal:A,xLabelVal:A,yVal:T,yLabelVal:T,zLabelVal:M,text:y,hovertemplateLabels:{zLabel:M,colorLabel:k,"color[0]Label":_[0]+w[0],"color[1]Label":_[1]+w[1],"color[2]Label":_[2]+w[2],"color[3]Label":_[3]+w[3]}})]}}}},14717:(e,t,r)=>{"use strict";e.exports={attributes:r(95296),supplyDefaults:r(60311),calc:r(656),plot:r(67234),style:r(11859),hoverPoints:r(28935),eventData:r(54284),moduleType:"trace",name:"image",basePlotModule:r(9510),categories:["cartesian","svg","2dMap","noSortingByValue"],animatable:!1,meta:{description:["Display an image, i.e. data on a 2D regular raster.","By default, when an image is displayed in a subplot,","its y axis will be reversed (ie. `autorange: 'reversed'`),","constrained to the domain (ie. `constrain: 'domain'`)","and it will have the same scale as its x axis (ie. `scaleanchor: 'x,`)","in order for pixels to be rendered as squares."].join(" ")}}},67234:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468),o=i.strTranslate,a=r(28795),s=r(57108),l=r(77775),c=r(44740).STYLE;e.exports=function(e,t,r,u){var d=t.xaxis,h=t.yaxis,p=!e._context._exportedPlot&&l();i.makeTraceGroups(u,r,"im").each((function(t){var r=n.select(this),l=t[0],u=l.trace,f=("fast"===u.zsmooth||!1===u.zsmooth&&p)&&!u._hasZ&&u._hasSource&&"linear"===d.type&&"linear"===h.type;u._realImage=f;var m,g,y,v,x,b,_=l.z,w=l.x0,k=l.y0,S=l.w,A=l.h,T=u.dx,M=u.dy;for(b=0;void 0===m&&b0;)g=d.c2p(w+b*T),b--;for(b=0;void 0===v&&b0;)x=h.c2p(k+b*M),b--;if(gR[0];if(L||D){var z=m+C/2,j=v+E/2;P+="transform:"+o(z+"px",j+"px")+"scale("+(L?-1:1)+","+(D?-1:1)+")"+o(-z+"px",-j+"px")+";"}}I.attr("style",P);var F=new Promise((function(e){if(u._hasZ)e();else if(u._hasSource)if(u._canvas&&u._canvas.el.width===S&&u._canvas.el.height===A&&u._canvas.source===u.source)e();else{var t=document.createElement("canvas");t.width=S,t.height=A;var r=t.getContext("2d",{willReadFrequently:!0});u._image=u._image||new Image;var n=u._image;n.onload=function(){r.drawImage(n,0,0),u._canvas={el:t,source:u.source},e()},n.setAttribute("src",u.source)}})).then((function(){var e,t;if(u._hasZ)t=N((function(e,t){var r=_[t][e];return i.isTypedArray(r)&&(r=Array.from(r)),r})),e=t.toDataURL("image/png");else if(u._hasSource)if(f)e=u.source;else{var r=u._canvas.el.getContext("2d",{willReadFrequently:!0}).getImageData(0,0,S,A).data;t=N((function(e,t){var n=4*(t*S+e);return[r[n],r[n+1],r[n+2],r[n+3]]})),e=t.toDataURL("image/png")}I.attr({"xlink:href":e,height:E,width:C,x:m,y:v})}));e._promises.push(F)}function N(e){var t=document.createElement("canvas");t.width=C,t.height=E;var r,n=t.getContext("2d",{willReadFrequently:!0}),o=function(e){return i.constrain(Math.round(d.c2p(w+e*T)-m),0,C)},a=function(e){return i.constrain(Math.round(h.c2p(k+e*M)-v),0,E)},c=s.colormodel[u.colormodel],p=c.colormodel||u.colormodel,f=c.fmt;for(b=0;b{"use strict";var n=r(41871);e.exports=function(e){n.select(e).selectAll(".im image").style("opacity",(function(e){return e[0].trace.opacity}))}},17580:(e,t,r)=>{"use strict";var n=r(64022).extendFlat,i=r(64022).extendDeep,o=r(72587).overrideAll,a=r(91740),s=r(17992),l=r(81159).u,c=r(49080),u=r(37091).templatedArray,d=r(22876),h=r(39363).descriptionOnlyNumbers,p=a({editType:"plot",colorEditType:"plot"}),f={color:{valType:"color",editType:"plot",description:["Sets the background color of the arc."].join(" ")},line:{color:{valType:"color",dflt:s.defaultLine,editType:"plot",description:["Sets the color of the line enclosing each sector."].join(" ")},width:{valType:"number",min:0,dflt:0,editType:"plot",description:["Sets the width (in px) of the line enclosing each sector."].join(" ")},editType:"calc"},thickness:{valType:"number",min:0,max:1,dflt:1,editType:"plot",description:["Sets the thickness of the bar as a fraction of the total thickness of the gauge."].join(" ")},editType:"calc"},m={valType:"info_array",items:[{valType:"number",editType:"plot"},{valType:"number",editType:"plot"}],editType:"plot",description:["Sets the range of this axis."].join(" ")},g=u("step",i({},f,{range:m}));e.exports={mode:{valType:"flaglist",editType:"calc",flags:["number","delta","gauge"],dflt:"number",description:["Determines how the value is displayed on the graph.","`number` displays the value numerically in text.","`delta` displays the difference to a reference value in text.","Finally, `gauge` displays the value graphically on an axis."].join(" ")},value:{valType:"number",editType:"calc",anim:!0,description:["Sets the number to be displayed."].join(" ")},align:{valType:"enumerated",values:["left","center","right"],editType:"plot",description:["Sets the horizontal alignment of the `text` within the box.","Note that this attribute has no effect if an angular gauge is displayed:","in this case, it is always centered"].join(" ")},domain:l({name:"indicator",trace:!0,editType:"calc"}),title:{text:{valType:"string",editType:"plot",description:["Sets the title of this indicator."].join(" ")},align:{valType:"enumerated",values:["left","center","right"],editType:"plot",description:["Sets the horizontal alignment of the title.","It defaults to `center` except for bullet charts","for which it defaults to right."].join(" ")},font:n({},p,{description:["Set the font used to display the title"].join(" ")}),editType:"plot"},number:{valueformat:{valType:"string",dflt:"",editType:"plot",description:h("value")},font:n({},p,{description:["Set the font used to display main number"].join(" ")}),prefix:{valType:"string",dflt:"",editType:"plot",description:["Sets a prefix appearing before the number."].join(" ")},suffix:{valType:"string",dflt:"",editType:"plot",description:["Sets a suffix appearing next to the number."].join(" ")},editType:"plot"},delta:{reference:{valType:"number",editType:"calc",description:["Sets the reference value to compute the delta.","By default, it is set to the current value."].join(" ")},position:{valType:"enumerated",values:["top","bottom","left","right"],dflt:"bottom",editType:"plot",description:["Sets the position of delta with respect to the number."].join(" ")},relative:{valType:"boolean",editType:"plot",dflt:!1,description:["Show relative change"].join(" ")},valueformat:{valType:"string",editType:"plot",description:h("value")},increasing:{symbol:{valType:"string",dflt:d.INCREASING.SYMBOL,editType:"plot",description:["Sets the symbol to display for increasing value"].join(" ")},color:{valType:"color",dflt:d.INCREASING.COLOR,editType:"plot",description:["Sets the color for increasing value."].join(" ")},editType:"plot"},decreasing:{symbol:{valType:"string",dflt:d.DECREASING.SYMBOL,editType:"plot",description:["Sets the symbol to display for increasing value"].join(" ")},color:{valType:"color",dflt:d.DECREASING.COLOR,editType:"plot",description:["Sets the color for increasing value."].join(" ")},editType:"plot"},font:n({},p,{description:["Set the font used to display the delta"].join(" ")}),prefix:{valType:"string",dflt:"",editType:"plot",description:["Sets a prefix appearing before the delta."].join(" ")},suffix:{valType:"string",dflt:"",editType:"plot",description:["Sets a suffix appearing next to the delta."].join(" ")},editType:"calc"},gauge:{shape:{valType:"enumerated",editType:"plot",dflt:"angular",values:["angular","bullet"],description:["Set the shape of the gauge"].join(" ")},bar:i({},f,{color:{dflt:"green"},description:["Set the appearance of the gauge's value"].join(" ")}),bgcolor:{valType:"color",editType:"plot",description:"Sets the gauge background color."},bordercolor:{valType:"color",dflt:s.defaultLine,editType:"plot",description:"Sets the color of the border enclosing the gauge."},borderwidth:{valType:"number",min:0,dflt:1,editType:"plot",description:"Sets the width (in px) of the border enclosing the gauge."},axis:o({range:m,visible:n({},c.visible,{dflt:!0}),tickmode:c.minor.tickmode,nticks:c.nticks,tick0:c.tick0,dtick:c.dtick,tickvals:c.tickvals,ticktext:c.ticktext,ticks:n({},c.ticks,{dflt:"outside"}),ticklen:c.ticklen,tickwidth:c.tickwidth,tickcolor:c.tickcolor,ticklabelstep:c.ticklabelstep,showticklabels:c.showticklabels,labelalias:c.labelalias,tickfont:a({description:"Sets the color bar's tick label font"}),tickangle:c.tickangle,tickformat:c.tickformat,tickformatstops:c.tickformatstops,tickprefix:c.tickprefix,showtickprefix:c.showtickprefix,ticksuffix:c.ticksuffix,showticksuffix:c.showticksuffix,separatethousands:c.separatethousands,exponentformat:c.exponentformat,minexponent:c.minexponent,showexponent:c.showexponent,editType:"plot"},"plot"),steps:g,threshold:{line:{color:n({},f.line.color,{description:["Sets the color of the threshold line."].join(" ")}),width:n({},f.line.width,{dflt:1,description:["Sets the width (in px) of the threshold line."].join(" ")}),editType:"plot"},thickness:n({},f.thickness,{dflt:.85,description:["Sets the thickness of the threshold line as a fraction of the thickness of the gauge."].join(" ")}),value:{valType:"number",editType:"calc",dflt:!1,description:["Sets a treshold value drawn as a line."].join(" ")},editType:"plot"},description:"The gauge of the Indicator plot.",editType:"plot"}}},13788:(e,t,r)=>{"use strict";var n=r(68543);t.name="indicator",t.plot=function(e,r,i,o){n.plotBasePlot(t.name,e,r,i,o)},t.clean=function(e,r,i,o){n.cleanBasePlot(t.name,e,r,i,o)}},15372:e=>{"use strict";e.exports={calc:function(e,t){var r=[],n=t.value;"number"!==typeof t._lastValue&&(t._lastValue=t.value);var i=t._lastValue,o=i;return t._hasDelta&&"number"===typeof t.delta.reference&&(o=t.delta.reference),r[0]={y:n,lastY:i,delta:n-o,relativeDelta:(n-o)/o},r}}},22184:e=>{"use strict";e.exports={defaultNumberFontSize:80,bulletNumberDomainSize:.25,bulletPadding:.025,innerRadius:.75,valueThickness:.5,titlePadding:5,horizontalPadding:10}},87035:(e,t,r)=>{"use strict";var n=r(84468),i=r(17580),o=r(81159).N,a=r(37091),s=r(38851),l=r(22184),c=r(43452),u=r(3118),d=r(83193),h=r(89655);function p(e,t){function r(r,o){return n.coerce(e,t,i.gauge.steps,r,o)}r("color"),r("line.color"),r("line.width"),r("range"),r("thickness")}e.exports={supplyDefaults:function(e,t,r,f){function m(r,o){return n.coerce(e,t,i,r,o)}o(t,f,m),m("mode"),t._hasNumber=-1!==t.mode.indexOf("number"),t._hasDelta=-1!==t.mode.indexOf("delta"),t._hasGauge=-1!==t.mode.indexOf("gauge");var g=m("value");t._range=[0,"number"===typeof g?1.5*g:1];var y,v,x=new Array(2);if(t._hasNumber){m("number.valueformat");var b=n.extendFlat({},f.font);b.size=void 0,n.coerceFont(m,"number.font",b),void 0===t.number.font.size&&(t.number.font.size=l.defaultNumberFontSize,x[0]=!0),m("number.prefix"),m("number.suffix"),y=t.number.font.size}if(t._hasDelta){var _=n.extendFlat({},f.font);_.size=void 0,n.coerceFont(m,"delta.font",_),void 0===t.delta.font.size&&(t.delta.font.size=(t._hasNumber?.5:1)*(y||l.defaultNumberFontSize),x[1]=!0),m("delta.reference",t.value),m("delta.relative"),m("delta.valueformat",t.delta.relative?"2%":""),m("delta.increasing.symbol"),m("delta.increasing.color"),m("delta.decreasing.symbol"),m("delta.decreasing.color"),m("delta.position"),m("delta.prefix"),m("delta.suffix"),v=t.delta.font.size}t._scaleNumbers=(!t._hasNumber||x[0])&&(!t._hasDelta||x[1])||!1;var w,k,S,A,T=n.extendFlat({},f.font);function M(e,t){return n.coerce(w,k,i.gauge,e,t)}function C(e,t){return n.coerce(S,A,i.gauge.axis,e,t)}if(T.size=.25*(y||v||l.defaultNumberFontSize),n.coerceFont(m,"title.font",T),m("title.text"),t._hasGauge){(w=e.gauge)||(w={}),k=a.newContainer(t,"gauge"),M("shape"),(t._isBullet="bullet"===t.gauge.shape)||m("title.align","center"),(t._isAngular="angular"===t.gauge.shape)||m("align","center"),M("bgcolor",f.paper_bgcolor),M("borderwidth"),M("bordercolor"),M("bar.color"),M("bar.line.color"),M("bar.line.width"),M("bar.thickness",l.valueThickness*("bullet"===t.gauge.shape?.5:1)),s(w,k,{name:"steps",handleItemDefaults:p}),M("threshold.value"),M("threshold.thickness"),M("threshold.line.width"),M("threshold.line.color"),S={},w&&(S=w.axis||{}),A=a.newContainer(k,"axis"),C("visible"),t._range=C("range",t._range);var E={font:f.font,noAutotickangles:!0,outerTicks:!0,noTicklabelshift:!0,noTicklabelstandoff:!0};c(S,A,C,"linear"),h(S,A,C,"linear",E),d(S,A,C,"linear",E),u(S,A,C,E)}else m("title.align","center"),m("align","center"),t._isAngular=t._isBullet=!1;t._length=null}}},11009:(e,t,r)=>{"use strict";e.exports={moduleType:"trace",name:"indicator",basePlotModule:r(13788),categories:["svg","noOpacity","noHover"],animatable:!0,attributes:r(17580),supplyDefaults:r(87035).supplyDefaults,calc:r(15372).calc,plot:r(41278),meta:{description:["An indicator is used to visualize a single `value` along with some","contextual information such as `steps` or a `threshold`, using a","combination of three visual elements: a number, a delta, and/or a gauge.","Deltas are taken with respect to a `reference`.","Gauges can be either angular or bullet (aka linear) gauges."].join(" ")}}},41278:(e,t,r)=>{"use strict";var n=r(41871),i=r(70359).GW,o=r(70359).Dj,a=r(84468),s=a.strScale,l=a.strTranslate,c=a.rad2deg,u=r(83943).MID_SHIFT,d=r(3172),h=r(22184),p=r(13480),f=r(85729),m=r(42730),g=r(44528),y=r(49080),v=r(7605),x={left:"start",center:"middle",right:"end"},b={left:0,center:.5,right:1},_=/[yzafpn\xb5mkMGTPEZY]/;function w(e){return e&&e.duration>0}function k(e){e.each((function(e){v.stroke(n.select(this),e.line.color)})).each((function(e){v.fill(n.select(this),e.color)})).style("stroke-width",(function(e){return e.line.width}))}function S(e,t,r){var n=e._fullLayout,i=a.extendFlat({type:"linear",ticks:"outside",range:r,showline:!0},t),o={type:"linear",_id:"x"+t._id},s={letter:"x",font:n.font,noAutotickangles:!0,noHover:!0,noTickson:!0};function l(e,t){return a.coerce(i,o,y,e,t)}return m(i,o,l,s,n),g(i,o,l,s),o}function A(e,t,r){return[Math.min(t/e.width,r/e.height),e,t+"x"+r]}function T(e,t,r,i){var o=document.createElementNS("http://www.w3.org/2000/svg","text"),a=n.select(o);return a.text(e).attr("x",0).attr("y",0).attr("text-anchor",r).attr("data-unformatted",e).call(p.convertToTspans,i).call(d.font,t),d.bBox(a.node())}function M(e,t,r,n,i,o){var s="_cache"+t;e[s]&&e[s].key===i||(e[s]={key:i,value:r});var l=a.aggNums(o,null,[e[s].value,n],2);return e[s].value=l,l}e.exports=function(e,t,r,m){var g,y=e._fullLayout;w(r)&&m&&(g=m()),a.makeTraceGroups(y._indicatorlayer,t,"trace").each((function(t){var m,C,E,I,P,O=t[0].trace,R=n.select(this),L=O._hasGauge,D=O._isAngular,z=O._isBullet,j=O.domain,F={w:y._size.w*(j.x[1]-j.x[0]),h:y._size.h*(j.y[1]-j.y[0]),l:y._size.l+y._size.w*j.x[0],r:y._size.r+y._size.w*(1-j.x[1]),t:y._size.t+y._size.h*(1-j.y[1]),b:y._size.b+y._size.h*j.y[0]},N=F.l+F.w/2,B=F.t+F.h/2,V=Math.min(F.w/2,F.h),U=h.innerRadius*V,H=O.align||"center";if(C=B,L){if(D&&(m=N,C=B+V/2,E=function(e){return function(e,t){var r=Math.sqrt(e.width/2*(e.width/2)+e.height*e.height),n=t/r;return[n,e,t]}(e,.9*U)}),z){var $=h.bulletPadding,W=1-h.bulletNumberDomainSize+$;m=F.l+(W+(1-W)*b[H])*F.w,E=function(e){return A(e,(h.bulletNumberDomainSize-$)*F.w,F.h)}}}else m=F.l+b[H]*F.w,E=function(e){return A(e,F.w,F.h)};!function(e,t,r,i){var c,u,h,m=r[0].trace,g=i.numbersX,y=i.numbersY,k=m.align||"center",A=x[k],C=i.transitionOpts,E=i.onComplete,I=a.ensureSingle(t,"g","numbers"),P=[];m._hasNumber&&P.push("number");m._hasDelta&&(P.push("delta"),"left"===m.delta.position&&P.reverse());var O=I.selectAll("text").data(P);function R(t,r,n,i){if(!t.match("s")||n>=0===i>=0||r(n).slice(-1).match(_)||r(i).slice(-1).match(_))return r;var o=t.slice().replace("s","f").replace(/\d+/,(function(e){return parseInt(e)-1})),a=S(e,{tickformat:o});return function(e){return Math.abs(e)<1?f.tickText(a,e).text:r(e)}}function L(){var t=S(e,{tickformat:m.number.valueformat},m._range);t.setScale(),f.prepTicks(t);var i=function(e){return f.tickText(t,e).text},a=m.number.suffix,s=m.number.prefix,l=I.select("text.number");function u(){var t="number"===typeof r[0].y?s+i(r[0].y)+a:"-";l.text(t).call(d.font,m.number.font).call(p.convertToTspans,e)}return w(C)?l.transition().duration(C.duration).ease(C.easing).each("end",(function(){u(),E&&E()})).each("interrupt",(function(){u(),E&&E()})).attrTween("text",(function(){var e=n.select(this),t=o(r[0].lastY,r[0].y);m._lastValue=r[0].y;var l=R(m.number.valueformat,i,r[0].lastY,r[0].y);return function(r){e.text(s+l(t(r))+a)}})):u(),c=T(s+i(r[0].y)+a,m.number.font,A,e),l}function D(){var t=S(e,{tickformat:m.delta.valueformat},m._range);t.setScale(),f.prepTicks(t);var i=function(e){return f.tickText(t,e).text},a=m.delta.suffix,s=m.delta.prefix,l=function(e){return m.delta.relative?e.relativeDelta:e.delta},c=function(e,t){return 0===e||"number"!==typeof e||isNaN(e)?"-":(e>0?m.delta.increasing.symbol:m.delta.decreasing.symbol)+s+t(e)+a},h=function(e){return e.delta>=0?m.delta.increasing.color:m.delta.decreasing.color};void 0===m._deltaLastValue&&(m._deltaLastValue=l(r[0]));var g=I.select("text.delta");function y(){g.text(c(l(r[0]),i)).call(v.fill,h(r[0])).call(p.convertToTspans,e)}return g.call(d.font,m.delta.font).call(v.fill,h({delta:m._deltaLastValue})),w(C)?g.transition().duration(C.duration).ease(C.easing).tween("text",(function(){var e=n.select(this),t=l(r[0]),a=m._deltaLastValue,s=R(m.delta.valueformat,i,a,t),u=o(a,t);return m._deltaLastValue=t,function(t){e.text(c(u(t),s)),e.call(v.fill,h({delta:u(t)}))}})).each("end",(function(){y(),E&&E()})).each("interrupt",(function(){y(),E&&E()})):y(),u=T(c(l(r[0]),i),m.delta.font,A,e),g}O.enter().append("text"),O.attr("text-anchor",(function(){return A})).attr("class",(function(e){return e})).attr("x",null).attr("y",null).attr("dx",null).attr("dy",null),O.exit().remove();var z,j=m.mode+m.align;m._hasDelta&&(z=D(),j+=m.delta.position+m.delta.font.size+m.delta.font.family+m.delta.valueformat,j+=m.delta.increasing.symbol+m.delta.decreasing.symbol,h=u);m._hasNumber&&(L(),j+=m.number.font.size+m.number.font.family+m.number.valueformat+m.number.suffix+m.number.prefix,h=c);if(m._hasDelta&&m._hasNumber){var F,N,B=[(c.left+c.right)/2,(c.top+c.bottom)/2],V=[(u.left+u.right)/2,(u.top+u.bottom)/2],U=.75*m.delta.font.size;"left"===m.delta.position&&(F=M(m,"deltaPos",0,-1*(c.width*b[m.align]+u.width*(1-b[m.align])+U),j,Math.min),N=B[1]-V[1],h={width:c.width+u.width+U,height:Math.max(c.height,u.height),left:u.left+F,right:c.right,top:Math.min(c.top,u.top+N),bottom:Math.max(c.bottom,u.bottom+N)}),"right"===m.delta.position&&(F=M(m,"deltaPos",0,c.width*(1-b[m.align])+u.width*b[m.align]+U,j,Math.max),N=B[1]-V[1],h={width:c.width+u.width+U,height:Math.max(c.height,u.height),left:c.left,right:u.right+F,top:Math.min(c.top,u.top+N),bottom:Math.max(c.bottom,u.bottom+N)}),"bottom"===m.delta.position&&(F=null,N=u.height,h={width:Math.max(c.width,u.width),height:c.height+u.height,left:Math.min(c.left,u.left),right:Math.max(c.right,u.right),top:c.bottom-c.height,bottom:c.bottom+u.height}),"top"===m.delta.position&&(F=null,N=c.top,h={width:Math.max(c.width,u.width),height:c.height+u.height,left:Math.min(c.left,u.left),right:Math.max(c.right,u.right),top:c.bottom-c.height-u.height,bottom:c.bottom}),z.attr({dx:F,dy:N})}(m._hasNumber||m._hasDelta)&&I.attr("transform",(function(){var e=i.numbersScaler(h);j+=e[2];var t,r=M(m,"numbersScale",1,e[0],j,Math.min);m._scaleNumbers||(r=1),t=m._isAngular?y-r*h.bottom:y-r*(h.top+h.bottom)/2,m._numbersTop=r*h.top+t;var n=h[k];"center"===k&&(n=(h.left+h.right)/2);var o=g-r*n;return o=M(m,"numbersTranslate",0,o,j,Math.max),l(o,t)+s(r)}))}(e,R,t,{numbersX:m,numbersY:C,numbersScaler:E,transitionOpts:r,onComplete:g}),L&&(I={range:O.gauge.axis.range,color:O.gauge.bgcolor,line:{color:O.gauge.bordercolor,width:0},thickness:1},P={range:O.gauge.axis.range,color:"rgba(0, 0, 0, 0)",line:{color:O.gauge.bordercolor,width:O.gauge.borderwidth},thickness:1});var q=R.selectAll("g.angular").data(D?t:[]);q.exit().remove();var G=R.selectAll("g.angularaxis").data(D?t:[]);G.exit().remove(),D&&function(e,t,r,o){var a,s,d,h,p=r[0].trace,m=o.size,g=o.radius,y=o.innerRadius,v=o.gaugeBg,x=o.gaugeOutline,b=[m.l+m.w/2,m.t+m.h/2+g/2],_=o.gauge,A=o.layer,T=o.transitionOpts,M=o.onComplete,C=Math.PI/2;function E(e){var t=p.gauge.axis.range[0],r=(e-t)/(p.gauge.axis.range[1]-t)*Math.PI-C;return r<-C?-C:r>C?C:r}function I(e){return n.svg.arc().innerRadius((y+g)/2-e/2*(g-y)).outerRadius((y+g)/2+e/2*(g-y)).startAngle(-C)}function P(e){e.attr("d",(function(e){return I(e.thickness).startAngle(E(e.range[0])).endAngle(E(e.range[1]))()}))}_.enter().append("g").classed("angular",!0),_.attr("transform",l(b[0],b[1])),A.enter().append("g").classed("angularaxis",!0).classed("crisp",!0),A.selectAll("g.xangularaxistick,path,text").remove(),a=S(e,p.gauge.axis),a.type="linear",a.range=p.gauge.axis.range,a._id="xangularaxis",a.ticklabeloverflow="allow",a.setScale();var O=function(e){return(a.range[0]-e.x)/(a.range[1]-a.range[0])*Math.PI+Math.PI},R={},L=f.makeLabelFns(a,0).labelStandoff;R.xFn=function(e){var t=O(e);return Math.cos(t)*L},R.yFn=function(e){var t=O(e),r=Math.sin(t)>0?.2:1;return-Math.sin(t)*(L+e.fontSize*r)+Math.abs(Math.cos(t))*(e.fontSize*u)},R.anchorFn=function(e){var t=O(e),r=Math.cos(t);return Math.abs(r)<.1?"middle":r>0?"start":"end"},R.heightFn=function(e,t,r){var n=O(e);return-.5*(1+Math.sin(n))*r};var D=function(e){return l(b[0]+g*Math.cos(e),b[1]-g*Math.sin(e))};d=function(e){return D(O(e))};var z=function(e){var t=O(e);return D(t)+"rotate("+-c(t)+")"};if(s=f.calcTicks(a),h=f.getTickSigns(a)[2],a.visible){h="inside"===a.ticks?-1:1;var j=(a.linewidth||1)/2;f.drawTicks(e,a,{vals:s,layer:A,path:"M"+h*j+",0h"+h*a.ticklen,transFn:z}),f.drawLabels(e,a,{vals:s,layer:A,transFn:d,labelFns:R})}var F=[v].concat(p.gauge.steps),N=_.selectAll("g.bg-arc").data(F);N.enter().append("g").classed("bg-arc",!0).append("path"),N.select("path").call(P).call(k),N.exit().remove();var B=I(p.gauge.bar.thickness),V=_.selectAll("g.value-arc").data([p.gauge.bar]);V.enter().append("g").classed("value-arc",!0).append("path");var U=V.select("path");w(T)?(U.transition().duration(T.duration).ease(T.easing).each("end",(function(){M&&M()})).each("interrupt",(function(){M&&M()})).attrTween("d",(H=B,$=E(r[0].lastY),W=E(r[0].y),function(){var e=i($,W);return function(t){return H.endAngle(e(t))()}})),p._lastValue=r[0].y):U.attr("d","number"===typeof r[0].y?B.endAngle(E(r[0].y)):"M0,0Z");var H,$,W;U.call(k),V.exit().remove(),F=[];var q=p.gauge.threshold.value;(q||0===q)&&F.push({range:[q,q],color:p.gauge.threshold.color,line:{color:p.gauge.threshold.line.color,width:p.gauge.threshold.line.width},thickness:p.gauge.threshold.thickness});var G=_.selectAll("g.threshold-arc").data(F);G.enter().append("g").classed("threshold-arc",!0).append("path"),G.select("path").call(P).call(k),G.exit().remove();var Y=_.selectAll("g.gauge-outline").data([x]);Y.enter().append("g").classed("gauge-outline",!0).append("path"),Y.select("path").call(P).call(k),Y.exit().remove()}(e,0,t,{radius:V,innerRadius:U,gauge:q,layer:G,size:F,gaugeBg:I,gaugeOutline:P,transitionOpts:r,onComplete:g});var Y=R.selectAll("g.bullet").data(z?t:[]);Y.exit().remove();var X=R.selectAll("g.bulletaxis").data(z?t:[]);X.exit().remove(),z&&function(e,t,r,n){var i,o,a,s,c,u=r[0].trace,d=n.gauge,p=n.layer,m=n.gaugeBg,g=n.gaugeOutline,y=n.size,x=u.domain,b=n.transitionOpts,_=n.onComplete;d.enter().append("g").classed("bullet",!0),d.attr("transform",l(y.l,y.t)),p.enter().append("g").classed("bulletaxis",!0).classed("crisp",!0),p.selectAll("g.xbulletaxistick,path,text").remove();var A=y.h,T=u.gauge.bar.thickness*A,M=x.x[0],C=x.x[0]+(x.x[1]-x.x[0])*(u._hasNumber||u._hasDelta?1-h.bulletNumberDomainSize:1);i=S(e,u.gauge.axis),i._id="xbulletaxis",i.domain=[M,C],i.setScale(),o=f.calcTicks(i),a=f.makeTransTickFn(i),s=f.getTickSigns(i)[2],c=y.t+y.h,i.visible&&(f.drawTicks(e,i,{vals:"inside"===i.ticks?f.clipEnds(i,o):o,layer:p,path:f.makeTickPath(i,c,s),transFn:a}),f.drawLabels(e,i,{vals:o,layer:p,transFn:a,labelFns:f.makeLabelFns(i,c)}));function E(e){e.attr("width",(function(e){return Math.max(0,i.c2p(e.range[1])-i.c2p(e.range[0]))})).attr("x",(function(e){return i.c2p(e.range[0])})).attr("y",(function(e){return.5*(1-e.thickness)*A})).attr("height",(function(e){return e.thickness*A}))}var I=[m].concat(u.gauge.steps),P=d.selectAll("g.bg-bullet").data(I);P.enter().append("g").classed("bg-bullet",!0).append("rect"),P.select("rect").call(E).call(k),P.exit().remove();var O=d.selectAll("g.value-bullet").data([u.gauge.bar]);O.enter().append("g").classed("value-bullet",!0).append("rect"),O.select("rect").attr("height",T).attr("y",(A-T)/2).call(k),w(b)?O.select("rect").transition().duration(b.duration).ease(b.easing).each("end",(function(){_&&_()})).each("interrupt",(function(){_&&_()})).attr("width",Math.max(0,i.c2p(Math.min(u.gauge.axis.range[1],r[0].y)))):O.select("rect").attr("width","number"===typeof r[0].y?Math.max(0,i.c2p(Math.min(u.gauge.axis.range[1],r[0].y))):0);O.exit().remove();var R=r.filter((function(){return u.gauge.threshold.value||0===u.gauge.threshold.value})),L=d.selectAll("g.threshold-bullet").data(R);L.enter().append("g").classed("threshold-bullet",!0).append("line"),L.select("line").attr("x1",i.c2p(u.gauge.threshold.value)).attr("x2",i.c2p(u.gauge.threshold.value)).attr("y1",(1-u.gauge.threshold.thickness)/2*A).attr("y2",(1-(1-u.gauge.threshold.thickness)/2)*A).call(v.stroke,u.gauge.threshold.line.color).style("stroke-width",u.gauge.threshold.line.width),L.exit().remove();var D=d.selectAll("g.gauge-outline").data([g]);D.enter().append("g").classed("gauge-outline",!0).append("rect"),D.select("rect").call(E).call(k),D.exit().remove()}(e,0,t,{gauge:Y,layer:X,size:F,gaugeBg:I,gaugeOutline:P,transitionOpts:r,onComplete:g});var Z=R.selectAll("text.title").data(t);Z.exit().remove(),Z.enter().append("text").classed("title",!0),Z.attr("text-anchor",(function(){return z?x.right:x[O.title.align]})).text(O.title.text).call(d.font,O.title.font).call(p.convertToTspans,e),Z.attr("transform",(function(){var e,t=F.l+F.w*b[O.title.align],r=h.titlePadding,n=d.bBox(Z.node());if(L){if(D)if(O.gauge.axis.visible)e=d.bBox(G.node()).top-r-n.bottom;else e=F.t+F.h/2-V/2-n.bottom-r;z&&(e=C-(n.top+n.bottom)/2,t=F.l-h.bulletPadding*F.w)}else e=O._numbersTop-r-n.bottom;return l(t,e)}))}))}},68583:(e,t,r)=>{"use strict";var n=r(6636),i=r(39363).axisHoverFormat,o=r(84425).rb,a=r(64989),s=r(75622),l=r(64022).extendFlat,c=r(72587).overrideAll;function u(e){return{show:{valType:"boolean",dflt:!1,description:["Determines whether or not slice planes about the",e,"dimension are drawn."].join(" ")},locations:{valType:"data_array",dflt:[],description:["Specifies the location(s) of slices on the axis.","When not specified slices would be created for","all points of the axis",e,"except start and end."].join(" ")},fill:{valType:"number",min:0,max:1,dflt:1,description:["Sets the fill ratio of the `slices`. The default fill value of the","`slices` is 1 meaning that they are entirely shaded. On the other hand","Applying a `fill` ratio less than one would allow the creation of","openings parallel to the edges."].join(" ")}}}function d(e){return{show:{valType:"boolean",dflt:!0,description:["Sets the fill ratio of the `slices`. The default fill value of the",e,"`slices` is 1 meaning that they are entirely shaded. On the other hand","Applying a `fill` ratio less than one would allow the creation of","openings parallel to the edges."].join(" ")},fill:{valType:"number",min:0,max:1,dflt:1,description:["Sets the fill ratio of the `caps`. The default fill value of the","`caps` is 1 meaning that they are entirely shaded. On the other hand","Applying a `fill` ratio less than one would allow the creation of","openings parallel to the edges."].join(" ")}}}var h=e.exports=c(l({x:{valType:"data_array",description:["Sets the X coordinates of the vertices on X axis."].join(" ")},y:{valType:"data_array",description:["Sets the Y coordinates of the vertices on Y axis."].join(" ")},z:{valType:"data_array",description:["Sets the Z coordinates of the vertices on Z axis."].join(" ")},value:{valType:"data_array",description:["Sets the 4th dimension (value) of the vertices."].join(" ")},isomin:{valType:"number",description:["Sets the minimum boundary for iso-surface plot."].join(" ")},isomax:{valType:"number",description:["Sets the maximum boundary for iso-surface plot."].join(" ")},surface:{show:{valType:"boolean",dflt:!0,description:["Hides/displays surfaces between minimum and maximum iso-values."].join(" ")},count:{valType:"integer",dflt:2,min:1,description:["Sets the number of iso-surfaces between minimum and maximum iso-values.","By default this value is 2 meaning that only minimum and maximum surfaces","would be drawn."].join(" ")},fill:{valType:"number",min:0,max:1,dflt:1,description:["Sets the fill ratio of the iso-surface. The default fill value of the","surface is 1 meaning that they are entirely shaded. On the other hand","Applying a `fill` ratio less than one would allow the creation of","openings parallel to the edges."].join(" ")},pattern:{valType:"flaglist",flags:["A","B","C","D","E"],extras:["all","odd","even"],dflt:"all",description:["Sets the surface pattern of the iso-surface 3-D sections. The default pattern of","the surface is `all` meaning that the rest of surface elements would be shaded.","The check options (either 1 or 2) could be used to draw half of the squares","on the surface. Using various combinations of capital `A`, `B`, `C`, `D` and `E`","may also be used to reduce the number of triangles on the iso-surfaces and","creating other patterns of interest."].join(" ")}},spaceframe:{show:{valType:"boolean",dflt:!1,description:["Displays/hides tetrahedron shapes between minimum and","maximum iso-values. Often useful when either caps or","surfaces are disabled or filled with values less than 1."].join(" ")},fill:{valType:"number",min:0,max:1,dflt:.15,description:["Sets the fill ratio of the `spaceframe` elements. The default fill value","is 0.15 meaning that only 15% of the area of every faces of tetras would be","shaded. Applying a greater `fill` ratio would allow the creation of stronger","elements or could be sued to have entirely closed areas (in case of using 1)."].join(" ")}},slices:{x:u("x"),y:u("y"),z:u("z")},caps:{x:d("x"),y:d("y"),z:d("z")},text:{valType:"string",dflt:"",arrayOk:!0,description:["Sets the text elements associated with the vertices.","If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,","these elements will be seen in the hover labels."].join(" ")},hovertext:{valType:"string",dflt:"",arrayOk:!0,description:"Same as `text`."},hovertemplate:o(),xhoverformat:i("x"),yhoverformat:i("y"),zhoverformat:i("z"),valuehoverformat:i("value",1),showlegend:l({},s.showlegend,{dflt:!1})},n("",{colorAttr:"`value`",showScaleDflt:!0,editTypeOverride:"calc"}),{opacity:a.opacity,lightposition:a.lightposition,lighting:a.lighting,flatshading:a.flatshading,contour:a.contour,hoverinfo:l({},s.hoverinfo)}),"calc","nested");h.flatshading.dflt=!0,h.lighting.facenormalsepsilon.dflt=0,h.x.editType=h.y.editType=h.z.editType=h.value.editType="calc+clearAxisTypes",h.transforms=void 0},84839:(e,t,r)=>{"use strict";var n=r(95500),i=r(65953).processGrid,o=r(65953).filter;e.exports=function(e,t){t._len=Math.min(t.x.length,t.y.length,t.z.length,t.value.length),t._x=o(t.x,t._len),t._y=o(t.y,t._len),t._z=o(t.z,t._len),t._value=o(t.value,t._len);var r=i(t);t._gridFill=r.fill,t._Xs=r.Xs,t._Ys=r.Ys,t._Zs=r.Zs,t._len=r.len;for(var a=1/0,s=-1/0,l=0;l{"use strict";var n=r(76107).gl_mesh3d,i=r(23207).parseColorScale,o=r(84468).isArrayOrTypedArray,a=r(79689),s=r(39265).extractOpts,l=r(11038),c=function(e,t){for(var r=t.length-1;r>0;r--){var n=Math.min(t[r],t[r-1]),i=Math.max(t[r],t[r-1]);if(i>n&&n-1}function z(e,t){return null===e?t:e}function j(t,r,n){I();var i,o,a,l=[r],c=[n];if(s>=1)l=[r],c=[n];else if(s>0){var u=function(e,t){var r=e[0],n=e[1],i=e[2],o=function(e,t,r){for(var n=[],i=0;i-1?n[p]:E(f,m,y);h[p]=x>-1?x:O(f,m,y,z(t,v))}i=h[0],o=h[1],a=h[2],e._meshI.push(i),e._meshJ.push(o),e._meshK.push(a),++g}}function F(e,t,r,n){var i=e[3];in&&(i=n);for(var o=(e[3]-i)/(e[3]-t[3]+1e-9),a=[],s=0;s<4;s++)a[s]=(1-o)*e[s]+o*t[s];return a}function N(e,t,r){return e>=t&&e<=r}function B(e){var t=.001*(C-M);return e>=M-t&&e<=C+t}function V(t){for(var r=[],n=0;n<4;n++){var i=t[n];r.push([e._x[i],e._y[i],e._z[i],e._value[i]])}return r}function U(e,t,r,n,i,o){o||(o=1),r=[-1,-1,-1];var a=!1,s=[N(t[0][3],n,i),N(t[1][3],n,i),N(t[2][3],n,i)];if(!s[0]&&!s[1]&&!s[2])return!1;var l=function(e,t,r){return B(t[0][3])&&B(t[1][3])&&B(t[2][3])?(j(e,t,r),!0):o<3&&U(e,t,r,M,C,++o)};if(s[0]&&s[1]&&s[2])return l(e,t,r)||a;var c=!1;return[[0,1,2],[2,0,1],[1,2,0]].forEach((function(o){if(s[o[0]]&&s[o[1]]&&!s[o[2]]){var u=t[o[0]],d=t[o[1]],h=t[o[2]],p=F(h,u,n,i),f=F(h,d,n,i);a=l(e,[f,p,u],[-1,-1,r[o[0]]])||a,a=l(e,[u,d,f],[r[o[0]],r[o[1]],-1])||a,c=!0}})),c||[[0,1,2],[1,2,0],[2,0,1]].forEach((function(o){if(s[o[0]]&&!s[o[1]]&&!s[o[2]]){var u=t[o[0]],d=t[o[1]],h=t[o[2]],p=F(d,u,n,i),f=F(h,u,n,i);a=l(e,[f,p,u],[-1,-1,r[o[0]]])||a,c=!0}})),a}function H(e,t,r,n){var i=!1,o=V(t),a=[N(o[0][3],r,n),N(o[1][3],r,n),N(o[2][3],r,n),N(o[3][3],r,n)];if(!a[0]&&!a[1]&&!a[2]&&!a[3])return i;if(a[0]&&a[1]&&a[2]&&a[3])return m&&(i=function(e,t,r){var n=function(n,i,o){j(e,[t[n],t[i],t[o]],[r[n],r[i],r[o]])};n(0,1,2),n(3,0,1),n(2,3,0),n(1,2,3)}(e,o,t)||i),i;var s=!1;return[[0,1,2,3],[3,0,1,2],[2,3,0,1],[1,2,3,0]].forEach((function(l){if(a[l[0]]&&a[l[1]]&&a[l[2]]&&!a[l[3]]){var c=o[l[0]],u=o[l[1]],d=o[l[2]],h=o[l[3]];if(m)i=j(e,[c,u,d],[t[l[0]],t[l[1]],t[l[2]]])||i;else{var p=F(h,c,r,n),f=F(h,u,r,n),g=F(h,d,r,n);i=j(null,[p,f,g],[-1,-1,-1])||i}s=!0}})),s?i:([[0,1,2,3],[1,2,3,0],[2,3,0,1],[3,0,1,2],[0,2,3,1],[1,3,2,0]].forEach((function(l){if(a[l[0]]&&a[l[1]]&&!a[l[2]]&&!a[l[3]]){var c=o[l[0]],u=o[l[1]],d=o[l[2]],h=o[l[3]],p=F(d,c,r,n),f=F(d,u,r,n),g=F(h,u,r,n),y=F(h,c,r,n);m?(i=j(e,[c,y,p],[t[l[0]],-1,-1])||i,i=j(e,[u,f,g],[t[l[1]],-1,-1])||i):i=function(e,t,r){var n=function(n,i,o){j(e,[t[n],t[i],t[o]],[r[n],r[i],r[o]])};n(0,1,2),n(2,3,0)}(null,[p,f,g,y],[-1,-1,-1,-1])||i,s=!0}})),s||[[0,1,2,3],[1,2,3,0],[2,3,0,1],[3,0,1,2]].forEach((function(l){if(a[l[0]]&&!a[l[1]]&&!a[l[2]]&&!a[l[3]]){var c=o[l[0]],u=o[l[1]],d=o[l[2]],h=o[l[3]],p=F(u,c,r,n),f=F(d,c,r,n),g=F(h,c,r,n);m?(i=j(e,[c,p,f],[t[l[0]],-1,-1])||i,i=j(e,[c,f,g],[t[l[0]],-1,-1])||i,i=j(e,[c,g,p],[t[l[0]],-1,-1])||i):i=j(null,[p,f,g],[-1,-1,-1])||i,s=!0}})),i)}function $(e,t,r,n,i,o,a,s,l,c,u){var d=!1;return f&&(D(e,"A")&&(d=H(null,[t,r,n,o],c,u)||d),D(e,"B")&&(d=H(null,[r,n,i,l],c,u)||d),D(e,"C")&&(d=H(null,[r,o,a,l],c,u)||d),D(e,"D")&&(d=H(null,[n,o,s,l],c,u)||d),D(e,"E")&&(d=H(null,[r,n,o,l],c,u)||d)),m&&(d=H(e,[r,n,o,l],c,u)||d),d}function W(e,t,r,n,i,o,a,s){return[!0===s[0]||U(e,V([t,r,n]),[t,r,n],o,a),!0===s[1]||U(e,V([n,i,t]),[n,i,t],o,a)]}function q(e,t,r,n,i,o,a,s,l){return s?W(e,t,r,i,n,o,a,l):W(e,r,i,n,t,o,a,l)}function G(e,t,r,n,i,o,a){var s,l,c,u,d=!1,h=function(){d=U(e,[s,l,c],[-1,-1,-1],i,o)||d,d=U(e,[c,u,s],[-1,-1,-1],i,o)||d},p=a[0],f=a[1],m=a[2];return p&&(s=R(V([S(t,r-0,n-0)])[0],V([S(t-1,r-0,n-0)])[0],p),l=R(V([S(t,r-0,n-1)])[0],V([S(t-1,r-0,n-1)])[0],p),c=R(V([S(t,r-1,n-1)])[0],V([S(t-1,r-1,n-1)])[0],p),u=R(V([S(t,r-1,n-0)])[0],V([S(t-1,r-1,n-0)])[0],p),h()),f&&(s=R(V([S(t-0,r,n-0)])[0],V([S(t-0,r-1,n-0)])[0],f),l=R(V([S(t-0,r,n-1)])[0],V([S(t-0,r-1,n-1)])[0],f),c=R(V([S(t-1,r,n-1)])[0],V([S(t-1,r-1,n-1)])[0],f),u=R(V([S(t-1,r,n-0)])[0],V([S(t-1,r-1,n-0)])[0],f),h()),m&&(s=R(V([S(t-0,r-0,n)])[0],V([S(t-0,r-0,n-1)])[0],m),l=R(V([S(t-0,r-1,n)])[0],V([S(t-0,r-1,n-1)])[0],m),c=R(V([S(t-1,r-1,n)])[0],V([S(t-1,r-1,n-1)])[0],m),u=R(V([S(t-1,r-0,n)])[0],V([S(t-1,r-0,n-1)])[0],m),h()),d}function Y(e,t,r,n,i,o,a,s,l,c,u,d){var h=e;return d?(f&&"even"===e&&(h=null),$(h,t,r,n,i,o,a,s,l,c,u)):(f&&"odd"===e&&(h=null),$(h,l,s,a,o,i,n,r,t,c,u))}function X(e,t,r,n,i){for(var o=[],a=0,s=0;sMath.abs(k-T)?[A,k]:[k,T];Q(r,E[0],E[1])}}var I=[[Math.min(M,T),Math.max(M,T)],[Math.min(A,C),Math.max(A,C)]];["x","y","z"].forEach((function(r){for(var n=[],i=0;i0&&(d.push(f.id),"x"===r?h.push([f.distRatio,0,0]):"y"===r?h.push([0,f.distRatio,0]):h.push([0,0,f.distRatio]))}else u=ne(1,"x"===r?b-1:"y"===r?_-1:w-1);d.length>0&&(n[o]="x"===r?ee(t,d,a,s,h,n[o]):"y"===r?te(t,d,a,s,h,n[o]):re(t,d,a,s,h,n[o]),o++),u.length>0&&(n[o]="x"===r?X(t,u,a,s,n[o]):"y"===r?Z(t,u,a,s,n[o]):K(t,u,a,s,n[o]),o++)}var m=e.caps[r];m.show&&m.fill&&(L(m.fill),n[o]="x"===r?X(t,[0,b-1],a,s,n[o]):"y"===r?Z(t,[0,_-1],a,s,n[o]):K(t,[0,w-1],a,s,n[o]),o++)}})),0===g&&P(),e._meshX=n,e._meshY=i,e._meshZ=o,e._meshIntensity=a,e._Xs=y,e._Ys=v,e._Zs=x}(),e}e.exports={findNearestOnAxis:c,generateIsoMeshes:p,createIsosurfaceTrace:function(e,t){var r=e.glplot.gl,i=n({gl:r}),o=new u(e,i,t.uid);return i._trace=o,o.update(t),e.glplot.add(i),o}}},8448:(e,t,r)=>{"use strict";var n=r(84468),i=r(38361),o=r(68583),a=r(16155);function s(e,t,r,n,o){var s=o("isomin"),l=o("isomax");void 0!==l&&null!==l&&void 0!==s&&null!==s&&s>l&&(t.isomin=null,t.isomax=null);var c=o("x"),u=o("y"),d=o("z"),h=o("value");c&&c.length&&u&&u.length&&d&&d.length&&h&&h.length?(i.getComponentMethod("calendars","handleTraceDefaults")(e,t,["x","y","z"],n),o("valuehoverformat"),["x","y","z"].forEach((function(e){o(e+"hoverformat");var t="caps."+e;o(t+".show")&&o(t+".fill");var r="slices."+e;o(r+".show")&&(o(r+".fill"),o(r+".locations"))})),o("spaceframe.show")&&o("spaceframe.fill"),o("surface.show")&&(o("surface.count"),o("surface.fill"),o("surface.pattern")),o("contour.show")&&(o("contour.color"),o("contour.width")),["text","hovertext","hovertemplate","lighting.ambient","lighting.diffuse","lighting.specular","lighting.roughness","lighting.fresnel","lighting.vertexnormalsepsilon","lighting.facenormalsepsilon","lightposition.x","lightposition.y","lightposition.z","flatshading","opacity"].forEach((function(e){o(e)})),a(e,t,n,o,{prefix:"",cLetter:"c"}),t._length=null):t.visible=!1}e.exports={supplyDefaults:function(e,t,r,i){s(e,t,r,i,(function(r,i){return n.coerce(e,t,o,r,i)}))},supplyIsoDefaults:s}},56876:(e,t,r)=>{"use strict";e.exports={attributes:r(68583),supplyDefaults:r(8448).supplyDefaults,calc:r(84839),colorbar:{min:"cmin",max:"cmax"},plot:r(53043).createIsosurfaceTrace,moduleType:"trace",name:"isosurface",basePlotModule:r(48648),categories:["gl3d","showLegend"],meta:{description:["Draws isosurfaces between iso-min and iso-max values with coordinates given by","four 1-dimensional arrays containing the `value`, `x`, `y` and `z` of every vertex","of a uniform or non-uniform 3-D grid. Horizontal or vertical slices, caps as well as","spaceframe between iso-min and iso-max values could also be drawn using this trace."].join(" ")}}},64989:(e,t,r)=>{"use strict";var n=r(6636),i=r(39363).axisHoverFormat,o=r(84425).rb,a=r(41094),s=r(75622),l=r(64022).extendFlat;e.exports=l({x:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the X coordinates of the vertices. The nth element of vectors `x`, `y` and `z`","jointly represent the X, Y and Z coordinates of the nth vertex."].join(" ")},y:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the Y coordinates of the vertices. The nth element of vectors `x`, `y` and `z`","jointly represent the X, Y and Z coordinates of the nth vertex."].join(" ")},z:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the Z coordinates of the vertices. The nth element of vectors `x`, `y` and `z`","jointly represent the X, Y and Z coordinates of the nth vertex."].join(" ")},i:{valType:"data_array",editType:"calc",description:["A vector of vertex indices, i.e. integer values between 0 and the length of the vertex","vectors, representing the *first* vertex of a triangle. For example, `{i[m], j[m], k[m]}`","together represent face m (triangle m) in the mesh, where `i[m] = n` points to the triplet","`{x[n], y[n], z[n]}` in the vertex arrays. Therefore, each element in `i` represents a","point in space, which is the first vertex of a triangle."].join(" ")},j:{valType:"data_array",editType:"calc",description:["A vector of vertex indices, i.e. integer values between 0 and the length of the vertex","vectors, representing the *second* vertex of a triangle. For example, `{i[m], j[m], k[m]}` ","together represent face m (triangle m) in the mesh, where `j[m] = n` points to the triplet","`{x[n], y[n], z[n]}` in the vertex arrays. Therefore, each element in `j` represents a","point in space, which is the second vertex of a triangle."].join(" ")},k:{valType:"data_array",editType:"calc",description:["A vector of vertex indices, i.e. integer values between 0 and the length of the vertex","vectors, representing the *third* vertex of a triangle. For example, `{i[m], j[m], k[m]}`","together represent face m (triangle m) in the mesh, where `k[m] = n` points to the triplet ","`{x[n], y[n], z[n]}` in the vertex arrays. Therefore, each element in `k` represents a","point in space, which is the third vertex of a triangle."].join(" ")},text:{valType:"string",dflt:"",arrayOk:!0,editType:"calc",description:["Sets the text elements associated with the vertices.","If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,","these elements will be seen in the hover labels."].join(" ")},hovertext:{valType:"string",dflt:"",arrayOk:!0,editType:"calc",description:"Same as `text`."},hovertemplate:o({editType:"calc"}),xhoverformat:i("x"),yhoverformat:i("y"),zhoverformat:i("z"),delaunayaxis:{valType:"enumerated",values:["x","y","z"],dflt:"z",editType:"calc",description:["Sets the Delaunay axis, which is the axis that is perpendicular to the surface of the","Delaunay triangulation.","It has an effect if `i`, `j`, `k` are not provided and `alphahull` is set to indicate","Delaunay triangulation."].join(" ")},alphahull:{valType:"number",dflt:-1,editType:"calc",description:["Determines how the mesh surface triangles are derived from the set of","vertices (points) represented by the `x`, `y` and `z` arrays, if","the `i`, `j`, `k` arrays are not supplied.","For general use of `mesh3d` it is preferred that `i`, `j`, `k` are","supplied.","If *-1*, Delaunay triangulation is used, which is mainly suitable if the","mesh is a single, more or less layer surface that is perpendicular to `delaunayaxis`.","In case the `delaunayaxis` intersects the mesh surface at more than one point","it will result triangles that are very long in the dimension of `delaunayaxis`.","If *>0*, the alpha-shape algorithm is used. In this case, the positive `alphahull` value","signals the use of the alpha-shape algorithm, _and_ its value","acts as the parameter for the mesh fitting.","If *0*, the convex-hull algorithm is used. It is suitable for convex bodies","or if the intention is to enclose the `x`, `y` and `z` point set into a convex","hull."].join(" ")},intensity:{valType:"data_array",editType:"calc",description:["Sets the intensity values for vertices or cells","as defined by `intensitymode`.","It can be used for plotting fields on meshes."].join(" ")},intensitymode:{valType:"enumerated",values:["vertex","cell"],dflt:"vertex",editType:"calc",description:["Determines the source of `intensity` values."].join(" ")},color:{valType:"color",editType:"calc",description:"Sets the color of the whole mesh"},vertexcolor:{valType:"data_array",editType:"calc",description:["Sets the color of each vertex","Overrides *color*. While Red, green and blue colors","are in the range of 0 and 255; in the case of having","vertex color data in RGBA format, the alpha color","should be normalized to be between 0 and 1."].join(" ")},facecolor:{valType:"data_array",editType:"calc",description:["Sets the color of each face","Overrides *color* and *vertexcolor*."].join(" ")},transforms:void 0},n("",{colorAttr:"`intensity`",showScaleDflt:!0,editTypeOverride:"calc"}),{opacity:a.opacity,flatshading:{valType:"boolean",dflt:!1,editType:"calc",description:["Determines whether or not normal smoothing is applied to the meshes,","creating meshes with an angular, low-poly look via flat reflections."].join(" ")},contour:{show:l({},a.contours.x.show,{description:["Sets whether or not dynamic contours are shown on hover"].join(" ")}),color:a.contours.x.color,width:a.contours.x.width,editType:"calc"},lightposition:{x:l({},a.lightposition.x,{dflt:1e5}),y:l({},a.lightposition.y,{dflt:1e5}),z:l({},a.lightposition.z,{dflt:0}),editType:"calc"},lighting:l({vertexnormalsepsilon:{valType:"number",min:0,max:1,dflt:1e-12,editType:"calc",description:"Epsilon for vertex normals calculation avoids math issues arising from degenerate geometry."},facenormalsepsilon:{valType:"number",min:0,max:1,dflt:1e-6,editType:"calc",description:"Epsilon for face normals calculation avoids math issues arising from degenerate geometry."},editType:"calc"},a.lighting),hoverinfo:l({},s.hoverinfo,{editType:"calc"}),showlegend:l({},s.showlegend,{dflt:!1})})},98673:(e,t,r)=>{"use strict";var n=r(95500);e.exports=function(e,t){t.intensity&&n(e,t,{vals:t.intensity,containerStr:"",cLetter:"c"})}},85805:(e,t,r)=>{"use strict";var n=r(76107).gl_mesh3d,i=r(76107).delaunay_triangulate,o=r(76107).alpha_shape,a=r(76107).convex_hull,s=r(23207).parseColorScale,l=r(84468).isArrayOrTypedArray,c=r(79689),u=r(39265).extractOpts,d=r(11038);function h(e,t,r){this.scene=e,this.uid=r,this.mesh=t,this.name="",this.color="#fff",this.data=null,this.showContour=!1}var p=h.prototype;function f(e){for(var t=[],r=e.length,n=0;n=t-.5)return!1;return!0}p.handlePick=function(e){if(e.object===this.mesh){var t=e.index=e.data.index;e.data._cellCenter?e.traceCoordinate=e.data.dataCoordinate:e.traceCoordinate=[this.data.x[t],this.data.y[t],this.data.z[t]];var r=this.data.hovertext||this.data.text;return l(r)&&void 0!==r[t]?e.textLabel=r[t]:r&&(e.textLabel=r),!0}},p.update=function(e){var t=this.scene,r=t.fullSceneLayout;this.data=e;var n,l=e.x.length,h=d(m(r.xaxis,e.x,t.dataScale[0],e.xcalendar),m(r.yaxis,e.y,t.dataScale[1],e.ycalendar),m(r.zaxis,e.z,t.dataScale[2],e.zcalendar));if(e.i&&e.j&&e.k){if(e.i.length!==e.j.length||e.j.length!==e.k.length||!y(e.i,l)||!y(e.j,l)||!y(e.k,l))return;n=d(g(e.i),g(e.j),g(e.k))}else n=0===e.alphahull?a(h):e.alphahull>0?o(e.alphahull,h):function(e,t){for(var r=["x","y","z"].indexOf(e),n=[],o=t.length,a=0;a{"use strict";var n=r(38361),i=r(84468),o=r(16155),a=r(64989);e.exports=function(e,t,r,s){function l(r,n){return i.coerce(e,t,a,r,n)}function c(e){var t=e.map((function(e){var t=l(e);return t&&i.isArrayOrTypedArray(t)?t:null}));return t.every((function(e){return e&&e.length===t[0].length}))&&t}c(["x","y","z"])?(c(["i","j","k"]),(!t.i||t.j&&t.k)&&(!t.j||t.k&&t.i)&&(!t.k||t.i&&t.j)?(n.getComponentMethod("calendars","handleTraceDefaults")(e,t,["x","y","z"],s),["lighting.ambient","lighting.diffuse","lighting.specular","lighting.roughness","lighting.fresnel","lighting.vertexnormalsepsilon","lighting.facenormalsepsilon","lightposition.x","lightposition.y","lightposition.z","flatshading","alphahull","delaunayaxis","opacity"].forEach((function(e){l(e)})),l("contour.show")&&(l("contour.color"),l("contour.width")),"intensity"in e?(l("intensity"),l("intensitymode"),o(e,t,s,l,{prefix:"",cLetter:"c"})):(t.showscale=!1,"facecolor"in e?l("facecolor"):"vertexcolor"in e?l("vertexcolor"):l("color",r)),l("text"),l("hovertext"),l("hovertemplate"),l("xhoverformat"),l("yhoverformat"),l("zhoverformat"),t._length=null):t.visible=!1):t.visible=!1}},56902:(e,t,r)=>{"use strict";e.exports={attributes:r(64989),supplyDefaults:r(52042),calc:r(98673),colorbar:{min:"cmin",max:"cmax"},plot:r(85805),moduleType:"trace",name:"mesh3d",basePlotModule:r(48648),categories:["gl3d","showLegend"],meta:{description:["Draws sets of triangles with coordinates given by","three 1-dimensional arrays in `x`, `y`, `z` and","(1) a sets of `i`, `j`, `k` indices","(2) Delaunay triangulation or","(3) the Alpha-shape algorithm or","(4) the Convex-hull algorithm"].join(" ")}}},46385:(e,t,r)=>{"use strict";var n=r(84468).extendFlat,i=r(22049),o=r(39363).axisHoverFormat,a=r(2703).T,s=r(25087),l=r(22876),c=l.INCREASING.COLOR,u=l.DECREASING.COLOR,d=i.line;function h(e){return{line:{color:n({},d.color,{dflt:e}),width:d.width,dash:a,editType:"style"},editType:"style"}}e.exports={xperiod:i.xperiod,xperiod0:i.xperiod0,xperiodalignment:i.xperiodalignment,xhoverformat:o("x"),yhoverformat:o("y"),x:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the x coordinates.","If absent, linear coordinate will be generated."].join(" ")},open:{valType:"data_array",editType:"calc",description:"Sets the open values."},high:{valType:"data_array",editType:"calc",description:"Sets the high values."},low:{valType:"data_array",editType:"calc",description:"Sets the low values."},close:{valType:"data_array",editType:"calc",description:"Sets the close values."},line:{width:n({},d.width,{description:[d.width,"Note that this style setting can also be set per","direction via `increasing.line.width` and","`decreasing.line.width`."].join(" ")}),dash:n({},a,{description:[a.description,"Note that this style setting can also be set per","direction via `increasing.line.dash` and","`decreasing.line.dash`."].join(" ")}),editType:"style"},increasing:h(c),decreasing:h(u),text:{valType:"string",dflt:"",arrayOk:!0,editType:"calc",description:["Sets hover text elements associated with each sample point.","If a single string, the same string appears over","all the data points.","If an array of string, the items are mapped in order to","this trace's sample points."].join(" ")},hovertext:{valType:"string",dflt:"",arrayOk:!0,editType:"calc",description:"Same as `text`."},tickwidth:{valType:"number",min:0,max:.5,dflt:.3,editType:"calc",description:["Sets the width of the open/close tick marks","relative to the *x* minimal interval."].join(" ")},hoverlabel:n({},s.hoverlabel,{split:{valType:"boolean",dflt:!1,editType:"style",description:["Show hover information (open, close, high, low) in","separate labels."].join(" ")}}),zorder:i.zorder}},89717:(e,t,r)=>{"use strict";var n=r(84468),i=n._,o=r(85729),a=r(35087),s=r(65004).BADNUM;function l(e,t,r,n){return{o:e,h:t,l:r,c:n}}function c(e,t,r,a,l,c){for(var u=l.makeCalcdata(t,"open"),d=l.makeCalcdata(t,"high"),h=l.makeCalcdata(t,"low"),p=l.makeCalcdata(t,"close"),f=n.isArrayOrTypedArray(t.text),m=n.isArrayOrTypedArray(t.hovertext),g=!0,y=null,v=!!t.xperiodalignment,x=[],b=0;by):g=A>w,y=A;var T=c(w,k,S,A);T.pos=_,T.yc=(w+A)/2,T.i=b,T.dir=g?"increasing":"decreasing",T.x=T.pos,T.y=[S,k],v&&(T.orig_p=r[b]),f&&(T.tx=t.text[b]),m&&(T.htx=t.hovertext[b]),x.push(T)}else x.push({pos:_,empty:!0})}return t._extremes[l._id]=o.findExtremes(l,n.concat(h,d),{padded:!0}),x.length&&(x[0].t={labels:{open:i(e,"open:")+" ",high:i(e,"high:")+" ",low:i(e,"low:")+" ",close:i(e,"close:")+" "}}),x}e.exports={calc:function(e,t){var r=o.getFromId(e,t.xaxis),i=o.getFromId(e,t.yaxis),s=function(e,t,r){var i=r._minDiff;if(!i){var o,s=e._fullData,l=[];for(i=1/0,o=0;o{"use strict";var n=r(84468),i=r(14771),o=r(26386),a=r(46385);function s(e,t,r,n){r(n+".line.color"),r(n+".line.width",t.line.width),r(n+".line.dash",t.line.dash)}e.exports=function(e,t,r,l){function c(r,i){return n.coerce(e,t,a,r,i)}i(e,t,c,l)?(o(e,t,l,c,{x:!0}),c("xhoverformat"),c("yhoverformat"),c("line.width"),c("line.dash"),s(e,t,c,"increasing"),s(e,t,c,"decreasing"),c("text"),c("hovertext"),c("tickwidth"),l._requestRangeslider[t.xaxis]=!0,c("zorder")):t.visible=!1}},45400:(e,t,r)=>{"use strict";var n=r(85729),i=r(84468),o=r(32212),a=r(7605),s=r(84468).fillText,l=r(22876),c={increasing:l.INCREASING.SYMBOL,decreasing:l.DECREASING.SYMBOL};function u(e,t,r,n){var i,s,l=e.cd,c=e.xa,u=l[0].trace,d=l[0].t,h=u.type,p="ohlc"===h?"l":"min",f="ohlc"===h?"h":"max",m=d.bPos||0,g=d.bdPos||d.tickLen,y=d.wHover,v=Math.min(1,g/Math.abs(c.r2c(c.range[1])-c.r2c(c.range[0])));function x(e){var r=function(e){return e.pos+m-t}(e);return o.inbox(r-y,r+y,i)}function b(e){var t=e[p],n=e[f];return t===n||o.inbox(t-r,n-r,i)}function _(e){return(x(e)+b(e))/2}i=e.maxHoverDistance-v,s=e.maxSpikeDistance-v;var w=o.getDistanceFunction(n,x,b,_);if(o.getClosest(l,w,e),!1===e.index)return null;var k=l[e.index];if(k.empty)return null;var S=u[k.dir],A=S.line.color;return a.opacity(A)&&S.line.width?e.color=A:e.color=S.fillcolor,e.x0=c.c2p(k.pos+m-g,!0),e.x1=c.c2p(k.pos+m+g,!0),e.xLabelVal=void 0!==k.orig_p?k.orig_p:k.pos,e.spikeDistance=_(k)*s/i,e.xSpike=c.c2p(k.pos,!0),e}function d(e,t,r,o){var a=e.cd,s=e.ya,l=a[0].trace,c=a[0].t,d=[],h=u(e,t,r,o);if(!h)return[];var p=a[h.index].hi||l.hoverinfo,f=p.split("+");if(!("all"===p||-1!==f.indexOf("y")))return[];for(var m=["high","open","close","low"],g={},y=0;y"+c.labels[x]+n.hoverLabelText(s,b,l.yhoverformat):((v=i.extendFlat({},h)).y0=v.y1=_,v.yLabelVal=b,v.yLabel=c.labels[x]+n.hoverLabelText(s,b,l.yhoverformat),v.name="",d.push(v),g[b]=v)}return d}function h(e,t,r,i){var o=e.cd,a=e.ya,l=o[0].trace,d=o[0].t,h=u(e,t,r,i);if(!h)return[];var p=o[h.index],f=h.index=p.i,m=p.dir;function g(e){return d.labels[e]+n.hoverLabelText(a,l[e][f],l.yhoverformat)}var y=p.hi||l.hoverinfo,v=y.split("+"),x="all"===y,b=x||-1!==v.indexOf("y"),_=x||-1!==v.indexOf("text"),w=b?[g("open"),g("high"),g("low"),g("close")+" "+c[m]]:[];return _&&s(p,l,w),h.extraText=w.join("
"),h.y0=h.y1=a.c2p(p.yc,!0),[h]}e.exports={hoverPoints:function(e,t,r,n){return e.cd[0].trace.hoverlabel.split?d(e,t,r,n):h(e,t,r,n)},hoverSplit:d,hoverOnPoints:h}},95490:(e,t,r)=>{"use strict";e.exports={moduleType:"trace",name:"ohlc",basePlotModule:r(9510),categories:["cartesian","svg","showLegend"],meta:{description:["The ohlc (short for Open-High-Low-Close) is a style of financial chart describing","open, high, low and close for a given `x` coordinate (most likely time).","The tip of the lines represent the `low` and `high` values and","the horizontal segments represent the `open` and `close` values.","Sample points where the close value is higher (lower) then the open","value are called increasing (decreasing).","By default, increasing items are drawn in green whereas","decreasing are drawn in red."].join(" ")},attributes:r(46385),supplyDefaults:r(2518),calc:r(89717).calc,plot:r(84571),style:r(8171),hoverPoints:r(45400).hoverPoints,selectPoints:r(39304)}},14771:(e,t,r)=>{"use strict";var n=r(38361),i=r(84468);e.exports=function(e,t,r,o){var a=r("x"),s=r("open"),l=r("high"),c=r("low"),u=r("close");if(r("hoverlabel.split"),n.getComponentMethod("calendars","handleTraceDefaults")(e,t,["x"],o),s&&l&&c&&u){var d=Math.min(s.length,l.length,c.length,u.length);return a&&(d=Math.min(d,i.minRowLength(a))),t._length=d,d}}},84571:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468);e.exports=function(e,t,r,o){var a=t.yaxis,s=t.xaxis,l=!!s.rangebreaks;i.makeTraceGroups(o,r,"trace ohlc").each((function(e){var t=n.select(this),r=e[0],o=r.t;if(!0!==r.trace.visible||o.empty)t.remove();else{var c=o.tickLen,u=t.selectAll("path").data(i.identity);u.enter().append("path"),u.exit().remove(),u.attr("d",(function(e){if(e.empty)return"M0,0Z";var t=s.c2p(e.pos-c,!0),r=s.c2p(e.pos+c,!0),n=l?(t+r)/2:s.c2p(e.pos,!0);return"M"+t+","+a.c2p(e.o,!0)+"H"+n+"M"+n+","+a.c2p(e.h,!0)+"V"+a.c2p(e.l,!0)+"M"+r+","+a.c2p(e.c,!0)+"H"+n}))}}))}},39304:e=>{"use strict";e.exports=function(e,t){var r,n=e.cd,i=e.xaxis,o=e.yaxis,a=[],s=n[0].t.bPos||0;if(!1===t)for(r=0;r{"use strict";var n=r(41871),i=r(3172),o=r(7605);e.exports=function(e,t,r){var a=r||n.select(e).selectAll("g.ohlclayer").selectAll("g.trace");a.style("opacity",(function(e){return e[0].trace.opacity})),a.each((function(e){var t=e[0].trace;n.select(this).selectAll("path").each((function(e){if(!e.empty){var r=t[e.dir].line;n.select(this).style("fill","none").call(o.stroke,r.color).call(i.dashLine,r.dash,r.width).style("opacity",t.selectedpoints&&!e.selected?.3:1)}}))}))}},56133:(e,t,r)=>{"use strict";var n=r(64022).extendFlat,i=r(75622),o=r(91740),a=r(6636),s=r(84425).rb,l=r(81159).u,c=n({editType:"calc"},a("line",{editTypeOverride:"calc"}),{shape:{valType:"enumerated",values:["linear","hspline"],dflt:"linear",editType:"plot",description:["Sets the shape of the paths.","If `linear`, paths are composed of straight lines.","If `hspline`, paths are composed of horizontal curved splines"].join(" ")},hovertemplate:s({editType:"plot",arrayOk:!1},{keys:["count","probability"],description:["This value here applies when hovering over lines."].join(" ")})});e.exports={domain:l({name:"parcats",trace:!0,editType:"calc"}),hoverinfo:n({},i.hoverinfo,{flags:["count","probability"],editType:"plot",arrayOk:!1}),hoveron:{valType:"enumerated",values:["category","color","dimension"],dflt:"category",editType:"plot",description:["Sets the hover interaction mode for the parcats diagram.","If `category`, hover interaction take place per category.","If `color`, hover interactions take place per color per category.","If `dimension`, hover interactions take place across all categories per dimension."].join(" ")},hovertemplate:s({editType:"plot",arrayOk:!1},{keys:["count","probability","category","categorycount","colorcount","bandcolorcount"],description:["This value here applies when hovering over dimensions.","Note that `*categorycount`, *colorcount* and *bandcolorcount*","are only available when `hoveron` contains the *color* flag"].join(" ")}),arrangement:{valType:"enumerated",values:["perpendicular","freeform","fixed"],dflt:"perpendicular",editType:"plot",description:["Sets the drag interaction mode for categories and dimensions.","If `perpendicular`, the categories can only move along a line perpendicular to the paths.","If `freeform`, the categories can freely move on the plane.","If `fixed`, the categories and dimensions are stationary."].join(" ")},bundlecolors:{valType:"boolean",dflt:!0,editType:"plot",description:"Sort paths so that like colors are bundled together within each category."},sortpaths:{valType:"enumerated",values:["forward","backward"],dflt:"forward",editType:"plot",description:["Sets the path sorting algorithm.","If `forward`, sort paths based on dimension categories from left to right.","If `backward`, sort paths based on dimensions categories from right to left."].join(" ")},labelfont:o({editType:"calc",description:"Sets the font for the `dimension` labels."}),tickfont:o({autoShadowDflt:!0,editType:"calc",description:"Sets the font for the `category` labels."}),dimensions:{_isLinkedToArray:"dimension",label:{valType:"string",editType:"calc",description:"The shown name of the dimension."},categoryorder:{valType:"enumerated",values:["trace","category ascending","category descending","array"],dflt:"trace",editType:"calc",description:["Specifies the ordering logic for the categories in the dimension.","By default, plotly uses *trace*, which specifies the order that is present in the data supplied.","Set `categoryorder` to *category ascending* or *category descending* if order should be determined by","the alphanumerical order of the category names.","Set `categoryorder` to *array* to derive the ordering from the attribute `categoryarray`. If a category","is not found in the `categoryarray` array, the sorting behavior for that attribute will be identical to","the *trace* mode. The unspecified categories will follow the categories in `categoryarray`."].join(" ")},categoryarray:{valType:"data_array",editType:"calc",description:["Sets the order in which categories in this dimension appear.","Only has an effect if `categoryorder` is set to *array*.","Used with `categoryorder`."].join(" ")},ticktext:{valType:"data_array",editType:"calc",description:["Sets alternative tick labels for the categories in this dimension.","Only has an effect if `categoryorder` is set to *array*.","Should be an array the same length as `categoryarray`","Used with `categoryorder`."].join(" ")},values:{valType:"data_array",dflt:[],editType:"calc",description:["Dimension values. `values[n]` represents the category value of the `n`th point in the dataset,","therefore the `values` vector for all dimensions must be the same (longer vectors","will be truncated)."].join(" ")},displayindex:{valType:"integer",editType:"calc",description:["The display index of dimension, from left to right, zero indexed, defaults to dimension","index."].join(" ")},editType:"calc",description:"The dimensions (variables) of the parallel categories diagram.",visible:{valType:"boolean",dflt:!0,editType:"calc",description:"Shows the dimension when set to `true` (the default). Hides the dimension for `false`."}},line:c,counts:{valType:"number",min:0,dflt:1,arrayOk:!0,editType:"calc",description:["The number of observations represented by each state. Defaults to 1 so that each state represents","one observation"].join(" ")},customdata:void 0,hoverlabel:void 0,ids:void 0,legend:void 0,legendgroup:void 0,legendrank:void 0,opacity:void 0,selectedpoints:void 0,showlegend:void 0}},75167:(e,t,r)=>{"use strict";var n=r(50246).eV,i=r(78687),o="parcats";t.name=o,t.plot=function(e,t,r,a){var s=n(e.calcdata,o);if(s.length){var l=s[0];i(e,l,r,a)}},t.clean=function(e,t,r,n){var i=n._has&&n._has("parcats"),o=t._has&&t._has("parcats");i&&!o&&n._paperdiv.selectAll(".parcats").remove()}},74713:(e,t,r)=>{"use strict";var n=r(85876).wrap,i=r(73084).hasColorscale,o=r(95500),a=r(32064),s=r(3172),l=r(84468),c=r(22036);function u(e,t,r){e.valueInds.push(t),e.count+=r}function d(e,t,r){e.valueInds.push(t),e.count+=r}e.exports=function(e,t){var r=l.filterVisible(t.dimensions);if(0===r.length)return[];var h,p,f,m=r.map((function(e){var t;if("trace"===e.categoryorder)t=null;else if("array"===e.categoryorder)t=e.categoryarray;else{t=a(e.values);for(var r=!0,n=0;n=e.length)return!1;if(void 0!==t[e[r]])return!1;t[e[r]]=!0}return!0}(r))for(t=0;t{"use strict";var n=r(84468),i=r(73084).hasColorscale,o=r(16155),a=r(81159).N,s=r(38851),l=r(56133),c=r(28692),u=r(19045).isTypedArraySpec;function d(e,t){function r(r,i){return n.coerce(e,t,l.dimensions,r,i)}var i=r("values"),o=r("visible");if(i&&i.length||(o=t.visible=!1),o){r("label"),r("displayindex",t._index);var a,s=e.categoryarray,c=n.isArrayOrTypedArray(s)&&s.length>0||u(s);c&&(a="array");var d=r("categoryorder",a);"array"===d?(r("categoryarray"),r("ticktext")):(delete e.categoryarray,delete e.ticktext),c||"array"!==d||(t.categoryorder="trace")}}e.exports=function(e,t,r,u){function h(r,i){return n.coerce(e,t,l,r,i)}var p=s(e,t,{name:"dimensions",handleItemDefaults:d}),f=function(e,t,r,a,s){s("line.shape"),s("line.hovertemplate");var l=s("line.color",a.colorway[0]);if(i(e,"line")&&n.isArrayOrTypedArray(l)){if(l.length)return s("line.colorscale"),o(e,t,a,s,{prefix:"line.",cLetter:"c"}),l.length;t.line.color=r}return 1/0}(e,t,r,u,h);a(t,u,h),Array.isArray(p)&&p.length||(t.visible=!1),c(t,p,"values",f),h("hoveron"),h("hovertemplate"),h("arrangement"),h("bundlecolors"),h("sortpaths"),h("counts");var m=u.font;n.coerceFont(h,"labelfont",m,{overrideDflt:{size:Math.round(m.size)}}),n.coerceFont(h,"tickfont",m,{autoShadowDflt:!0,overrideDflt:{size:Math.round(m.size/1.2)}})}},17406:(e,t,r)=>{"use strict";e.exports={attributes:r(56133),supplyDefaults:r(73554),calc:r(74713),plot:r(78687),colorbar:{container:"line",min:"cmin",max:"cmax"},moduleType:"trace",name:"parcats",basePlotModule:r(75167),categories:["noOpacity"],meta:{description:["Parallel categories diagram for multidimensional categorical data."].join(" ")}}},81492:(e,t,r)=>{"use strict";var n=r(41871),i=r(70359).Dj,o=r(49841),a=r(32212),s=r(84468),l=s.strTranslate,c=r(3172),u=r(23498),d=r(13480);function h(e,t,r,i){var o=t._context.staticPlot,a=e.map(j.bind(0,t,r)),u=i.selectAll("g.parcatslayer").data([null]);u.enter().append("g").attr("class","parcatslayer").style("pointer-events",o?"none":"all");var h=u.selectAll("g.trace.parcats").data(a,p),v=h.enter().append("g").attr("class","trace parcats");h.attr("transform",(function(e){return l(e.x,e.y)})),v.append("g").attr("class","paths");var x=h.select("g.paths").selectAll("path.path").data((function(e){return e.paths}),p);x.attr("fill",(function(e){return e.model.color}));var w=x.enter().append("path").attr("class","path").attr("stroke-opacity",0).attr("fill",(function(e){return e.model.color})).attr("fill-opacity",0);_(w),x.attr("d",(function(e){return e.svgD})),w.empty()||x.sort(m),x.exit().remove(),x.on("mouseover",g).on("mouseout",y).on("click",b),v.append("g").attr("class","dimensions");var A=h.select("g.dimensions").selectAll("g.dimension").data((function(e){return e.dimensions}),p);A.enter().append("g").attr("class","dimension"),A.attr("transform",(function(e){return l(e.x,0)})),A.exit().remove();var T=A.selectAll("g.category").data((function(e){return e.categories}),p),M=T.enter().append("g").attr("class","category");T.attr("transform",(function(e){return l(0,e.y)})),M.append("rect").attr("class","catrect").attr("pointer-events","none"),T.select("rect.catrect").attr("fill","none").attr("width",(function(e){return e.width})).attr("height",(function(e){return e.height})),k(M);var C=T.selectAll("rect.bandrect").data((function(e){return e.bands}),p);C.each((function(){s.raiseToTop(this)})),C.attr("fill",(function(e){return e.color}));var L=C.enter().append("rect").attr("class","bandrect").attr("stroke-opacity",0).attr("fill",(function(e){return e.color})).attr("fill-opacity",0);C.attr("fill",(function(e){return e.color})).attr("width",(function(e){return e.width})).attr("height",(function(e){return e.height})).attr("y",(function(e){return e.y})).attr("cursor",(function(e){return"fixed"===e.parcatsViewModel.arrangement?"default":"perpendicular"===e.parcatsViewModel.arrangement?"ns-resize":"move"})),S(L),C.exit().remove(),M.append("text").attr("class","catlabel").attr("pointer-events","none"),T.select("text.catlabel").attr("text-anchor",(function(e){return f(e)?"start":"end"})).attr("alignment-baseline","middle").style("fill","rgb(0, 0, 0)").attr("x",(function(e){return f(e)?e.width+5:-5})).attr("y",(function(e){return e.height/2})).text((function(e){return e.model.categoryLabel})).each((function(e){c.font(n.select(this),e.parcatsViewModel.categorylabelfont),d.convertToTspans(n.select(this),t)})),M.append("text").attr("class","dimlabel"),T.select("text.dimlabel").attr("text-anchor","middle").attr("alignment-baseline","baseline").attr("cursor",(function(e){return"fixed"===e.parcatsViewModel.arrangement?"default":"ew-resize"})).attr("x",(function(e){return e.width/2})).attr("y",-5).text((function(e,t){return 0===t?e.parcatsViewModel.model.dimensions[e.model.dimensionInd].dimensionLabel:null})).each((function(e){c.font(n.select(this),e.parcatsViewModel.labelfont)})),T.selectAll("rect.bandrect").on("mouseover",E).on("mouseout",I),T.exit().remove(),A.call(n.behavior.drag().origin((function(e){return{x:e.x,y:0}})).on("dragstart",P).on("drag",O).on("dragend",R)),h.each((function(e){e.traceSelection=n.select(this),e.pathSelection=n.select(this).selectAll("g.paths").selectAll("path.path"),e.dimensionSelection=n.select(this).selectAll("g.dimensions").selectAll("g.dimension")})),h.exit().remove()}function p(e){return e.key}function f(e){var t=e.parcatsViewModel.dimensions.length,r=e.parcatsViewModel.dimensions[t-1].model.dimensionInd;return e.model.dimensionInd===r}function m(e,t){return e.model.rawColor>t.model.rawColor?1:e.model.rawColor"),E=n.mouse(d)[0];a.loneHover({trace:h,x:b-f.left+m.left,y:_-f.top+m.top,text:C,color:e.model.color,borderColor:"black",fontFamily:'Monaco, "Courier New", monospace',fontSize:10,fontColor:k,idealAlign:E1&&h.displayInd===d.dimensions.length-1?(i=c.left,o="left"):(i=c.left+c.width,o="right");var m=u.model.count,g=u.model.categoryLabel,y=m/u.parcatsViewModel.model.count,v={countLabel:m,categoryLabel:g,probabilityLabel:y.toFixed(3)},x=[];-1!==u.parcatsViewModel.hoverinfoItems.indexOf("count")&&x.push(["Count:",v.countLabel].join(" ")),-1!==u.parcatsViewModel.hoverinfoItems.indexOf("probability")&&x.push(["P("+v.categoryLabel+"):",v.probabilityLabel].join(" "));var b=x.join("
");return{trace:p,x:a*(i-t.left),y:s*(f-t.top),text:b,color:"lightgray",borderColor:"black",fontFamily:'Monaco, "Courier New", monospace',fontSize:12,fontColor:"black",idealAlign:o,hovertemplate:p.hovertemplate,hovertemplateLabels:v,eventData:[{data:p._input,fullData:p,count:m,category:g,probability:y}]}}function E(e){if(!e.parcatsViewModel.dragDimension&&-1===e.parcatsViewModel.hoverinfoItems.indexOf("skip")){if(n.mouse(this)[1]<-1)return;var t,r=e.parcatsViewModel.graphDiv,i=r._fullLayout,o=i._paperdiv.node().getBoundingClientRect(),l=e.parcatsViewModel.hoveron,c=this;if("color"===l?(!function(e){var t=n.select(e).datum(),r=A(t);w(r),r.each((function(){s.raiseToTop(this)})),n.select(e.parentNode).selectAll("rect.bandrect").filter((function(e){return e.color===t.color})).each((function(){s.raiseToTop(this),n.select(this).attr("stroke","black").attr("stroke-width",1.5)}))}(c),M(c,"plotly_hover",n.event)):(!function(e){n.select(e.parentNode).selectAll("rect.bandrect").each((function(e){var t=A(e);w(t),t.each((function(){s.raiseToTop(this)}))})),n.select(e.parentNode).select("rect.catrect").attr("stroke","black").attr("stroke-width",2.5)}(c),T(c,"plotly_hover",n.event)),-1===e.parcatsViewModel.hoverinfoItems.indexOf("none"))"category"===l?t=C(r,o,c):"color"===l?t=function(e,t,r){e._fullLayout._calcInverseTransform(e);var i,o,a=e._fullLayout._invScaleX,s=e._fullLayout._invScaleY,l=r.getBoundingClientRect(),c=n.select(r).datum(),d=c.categoryViewModel,h=d.parcatsViewModel,p=h.model.dimensions[d.model.dimensionInd],f=h.trace,m=l.y+l.height/2;h.dimensions.length>1&&p.displayInd===h.dimensions.length-1?(i=l.left,o="left"):(i=l.left+l.width,o="right");var g=d.model.categoryLabel,y=c.parcatsViewModel.model.count,v=0;c.categoryViewModel.bands.forEach((function(e){e.color===c.color&&(v+=e.count)}));var x=d.model.count,b=0;h.pathSelection.each((function(e){e.model.color===c.color&&(b+=e.model.count)}));var _=v/y,w=v/b,k=v/x,S={countLabel:v,categoryLabel:g,probabilityLabel:_.toFixed(3)},A=[];-1!==d.parcatsViewModel.hoverinfoItems.indexOf("count")&&A.push(["Count:",S.countLabel].join(" ")),-1!==d.parcatsViewModel.hoverinfoItems.indexOf("probability")&&(A.push("P(color \u2229 "+g+"): "+S.probabilityLabel),A.push("P("+g+" | color): "+w.toFixed(3)),A.push("P(color | "+g+"): "+k.toFixed(3)));var T=A.join("
"),M=u.mostReadable(c.color,["black","white"]);return{trace:f,x:a*(i-t.left),y:s*(m-t.top),text:T,color:c.color,borderColor:"black",fontFamily:'Monaco, "Courier New", monospace',fontColor:M,fontSize:10,idealAlign:o,hovertemplate:f.hovertemplate,hovertemplateLabels:S,eventData:[{data:f._input,fullData:f,category:g,count:y,probability:_,categorycount:x,colorcount:b,bandcolorcount:v}]}}(r,o,c):"dimension"===l&&(t=function(e,t,r){var i=[];return n.select(r.parentNode.parentNode).selectAll("g.category").select("rect.catrect").each((function(){i.push(C(e,t,this))})),i}(r,o,c)),t&&a.loneHover(t,{container:i._hoverlayer.node(),outerContainer:i._paper.node(),gd:r})}}function I(e){var t=e.parcatsViewModel;if(!t.dragDimension&&(_(t.pathSelection),k(t.dimensionSelection.selectAll("g.category")),S(t.dimensionSelection.selectAll("g.category").selectAll("rect.bandrect")),a.loneUnhover(t.graphDiv._fullLayout._hoverlayer.node()),t.pathSelection.sort(m),-1===t.hoverinfoItems.indexOf("skip"))){"color"===e.parcatsViewModel.hoveron?M(this,"plotly_unhover",n.event):T(this,"plotly_unhover",n.event)}}function P(e){"fixed"!==e.parcatsViewModel.arrangement&&(e.dragDimensionDisplayInd=e.model.displayInd,e.initialDragDimensionDisplayInds=e.parcatsViewModel.model.dimensions.map((function(e){return e.displayInd})),e.dragHasMoved=!1,e.dragCategoryDisplayInd=null,n.select(this).selectAll("g.category").select("rect.catrect").each((function(t){var r=n.mouse(this)[0],i=n.mouse(this)[1];-2<=r&&r<=t.width+2&&-2<=i&&i<=t.height+2&&(e.dragCategoryDisplayInd=t.model.displayInd,e.initialDragCategoryDisplayInds=e.model.categories.map((function(e){return e.displayInd})),t.model.dragY=t.y,s.raiseToTop(this.parentNode),n.select(this.parentNode).selectAll("rect.bandrect").each((function(t){t.yd.y+d.height/2&&(a.model.displayInd=d.model.displayInd,d.model.displayInd=l),e.dragCategoryDisplayInd=a.model.displayInd}if(null===e.dragCategoryDisplayInd||"freeform"===e.parcatsViewModel.arrangement){o.model.dragX=n.event.x;var h=e.parcatsViewModel.dimensions[r],p=e.parcatsViewModel.dimensions[i];void 0!==h&&o.model.dragXp.x&&(o.model.displayInd=p.model.displayInd,p.model.displayInd=e.dragDimensionDisplayInd),e.dragDimensionDisplayInd=o.model.displayInd}B(e.parcatsViewModel),N(e.parcatsViewModel),z(e.parcatsViewModel),D(e.parcatsViewModel)}}function R(e){if("fixed"!==e.parcatsViewModel.arrangement&&null!==e.dragDimensionDisplayInd){n.select(this).selectAll("text").attr("font-weight","normal");var t={},r=L(e.parcatsViewModel),i=e.parcatsViewModel.model.dimensions.map((function(e){return e.displayInd})),a=e.initialDragDimensionDisplayInds.some((function(e,t){return e!==i[t]}));a&&i.forEach((function(r,n){var i=e.parcatsViewModel.model.dimensions[n].containerInd;t["dimensions["+i+"].displayindex"]=r}));var s=!1;if(null!==e.dragCategoryDisplayInd){var l=e.model.categories.map((function(e){return e.displayInd}));if(s=e.initialDragCategoryDisplayInds.some((function(e,t){return e!==l[t]}))){var c=e.model.categories.slice().sort((function(e,t){return e.displayInd-t.displayInd})),u=c.map((function(e){return e.categoryValue})),d=c.map((function(e){return e.categoryLabel}));t["dimensions["+e.model.containerInd+"].categoryarray"]=[u],t["dimensions["+e.model.containerInd+"].ticktext"]=[d],t["dimensions["+e.model.containerInd+"].categoryorder"]="array"}}if(-1===e.parcatsViewModel.hoverinfoItems.indexOf("skip")&&!e.dragHasMoved&&e.potentialClickBand&&("color"===e.parcatsViewModel.hoveron?M(e.potentialClickBand,"plotly_click",n.event.sourceEvent):T(e.potentialClickBand,"plotly_click",n.event.sourceEvent)),e.model.dragX=null,null!==e.dragCategoryDisplayInd)e.parcatsViewModel.dimensions[e.dragDimensionDisplayInd].categories[e.dragCategoryDisplayInd].model.dragY=null,e.dragCategoryDisplayInd=null;e.dragDimensionDisplayInd=null,e.parcatsViewModel.dragDimension=null,e.dragHasMoved=null,e.potentialClickBand=null,B(e.parcatsViewModel),N(e.parcatsViewModel),n.transition().duration(300).ease("cubic-in-out").each((function(){z(e.parcatsViewModel,!0),D(e.parcatsViewModel,!0)})).each("end",(function(){(a||s)&&o.restyle(e.parcatsViewModel.graphDiv,t,[r])}))}}function L(e){for(var t,r=e.graphDiv._fullData,n=0;n=0;s--)u+="C"+c[s]+","+(t[s+1]+n)+" "+l[s]+","+(t[s]+n)+" "+(e[s]+r[s])+","+(t[s]+n),u+="l-"+r[s]+",0 ";return u+="Z"}function N(e){var t=e.dimensions,r=e.model,n=t.map((function(e){return e.categories.map((function(e){return e.y}))})),i=e.model.dimensions.map((function(e){return e.categories.map((function(e){return e.displayInd}))})),o=e.model.dimensions.map((function(e){return e.displayInd})),a=e.dimensions.map((function(e){return e.model.dimensionInd})),s=t.map((function(e){return e.x})),l=t.map((function(e){return e.width})),c=[];for(var u in r.paths)r.paths.hasOwnProperty(u)&&c.push(r.paths[u]);function d(e){var t=e.categoryInds.map((function(e,t){return i[t][e]}));return a.map((function(e){return t[e]}))}c.sort((function(t,r){var n=d(t),i=d(r);return"backward"===e.sortpaths&&(n.reverse(),i.reverse()),n.push(t.valueInds[0]),i.push(r.valueInds[0]),e.bundlecolors&&(n.unshift(t.rawColor),i.unshift(r.rawColor)),ni?1:0}));for(var h=new Array(c.length),p=t[0].model.count,f=t[0].categories.map((function(e){return e.height})).reduce((function(e,t){return e+t})),m=0;m0?f*(y.count/p):0;for(var v,x=new Array(n.length),b=0;b1?(e.width-80-16)/(n-1):0)*i;var o,a,s,l,c,u=[],d=e.model.maxCats,h=t.categories.length,p=t.count,f=e.height-8*(d-1),m=8*(d-h)/2,g=t.categories.map((function(e){return{displayInd:e.displayInd,categoryInd:e.categoryInd}}));for(g.sort((function(e,t){return e.displayInd-t.displayInd})),c=0;c0?a.count/p*f:0,s={key:a.valueInds[0],model:a,width:16,height:o,y:null!==a.dragY?a.dragY:m,bands:[],parcatsViewModel:e},m=m+o+8,u.push(s);return{key:t.dimensionInd,x:null!==t.dragX?t.dragX:r,y:0,width:16,model:t,categories:u,parcatsViewModel:e,dragCategoryDisplayInd:null,dragDimensionDisplayInd:null,initialDragDimensionDisplayInds:null,initialDragCategoryDisplayInds:null,dragHasMoved:null,potentialClickBand:null}}e.exports=function(e,t,r,n){h(r,e,n,t)}},78687:(e,t,r)=>{"use strict";var n=r(81492);e.exports=function(e,t,r,i){var o=e._fullLayout,a=o._paper,s=o._size;n(e,a,t,{width:s.w,height:s.h,margin:{t:s.t,r:s.r,b:s.b,l:s.l}},r,i)}},70436:(e,t,r)=>{"use strict";var n=r(6636),i=r(49080),o=r(91740),a=r(81159).u,s=r(64022).extendFlat,l=r(37091).templatedArray;e.exports={domain:a({name:"parcoords",trace:!0,editType:"plot"}),labelangle:{valType:"angle",dflt:0,editType:"plot",description:["Sets the angle of the labels with respect to the horizontal.","For example, a `tickangle` of -90 draws the labels vertically.","Tilted labels with *labelangle* may be positioned better","inside margins when `labelposition` is set to *bottom*."].join(" ")},labelside:{valType:"enumerated",values:["top","bottom"],dflt:"top",editType:"plot",description:["Specifies the location of the `label`.","*top* positions labels above, next to the title","*bottom* positions labels below the graph","Tilted labels with *labelangle* may be positioned better","inside margins when `labelposition` is set to *bottom*."].join(" ")},labelfont:o({editType:"plot",description:"Sets the font for the `dimension` labels."}),tickfont:o({autoShadowDflt:!0,editType:"plot",description:"Sets the font for the `dimension` tick values."}),rangefont:o({editType:"plot",description:"Sets the font for the `dimension` range values."}),dimensions:l("dimension",{label:{valType:"string",editType:"plot",description:"The shown name of the dimension."},tickvals:s({},i.tickvals,{editType:"plot",description:["Sets the values at which ticks on this axis appear."].join(" ")}),ticktext:s({},i.ticktext,{editType:"plot",description:["Sets the text displayed at the ticks position via `tickvals`."].join(" ")}),tickformat:s({},i.tickformat,{editType:"plot"}),visible:{valType:"boolean",dflt:!0,editType:"plot",description:"Shows the dimension when set to `true` (the default). Hides the dimension for `false`."},range:{valType:"info_array",items:[{valType:"number",editType:"plot"},{valType:"number",editType:"plot"}],editType:"plot",description:["The domain range that represents the full, shown axis extent. Defaults to the `values` extent.","Must be an array of `[fromValue, toValue]` with finite numbers as elements."].join(" ")},constraintrange:{valType:"info_array",freeLength:!0,dimensions:"1-2",items:[{valType:"any",editType:"plot"},{valType:"any",editType:"plot"}],editType:"plot",description:["The domain range to which the filter on the dimension is constrained. Must be an array","of `[fromValue, toValue]` with `fromValue <= toValue`, or if `multiselect` is not","disabled, you may give an array of arrays, where each inner array is `[fromValue, toValue]`."].join(" ")},multiselect:{valType:"boolean",dflt:!0,editType:"plot",description:"Do we allow multiple selection ranges or just a single range?"},values:{valType:"data_array",editType:"calc",description:["Dimension values. `values[n]` represents the value of the `n`th point in the dataset,","therefore the `values` vector for all dimensions must be the same (longer vectors","will be truncated). Each value must be a finite number."].join(" ")},editType:"calc",description:"The dimensions (variables) of the parallel coordinates chart. 2..60 dimensions are supported."}),line:s({editType:"calc"},n("line",{colorscaleDflt:"Viridis",autoColorDflt:!1,editTypeOverride:"calc"})),unselected:{line:{color:{valType:"color",dflt:"#7f7f7f",editType:"plot",description:["Sets the base color of unselected lines.","in connection with `unselected.line.opacity`."].join(" ")},opacity:{valType:"number",min:0,max:1,dflt:"auto",editType:"plot",description:["Sets the opacity of unselected lines.","The default *auto* decreases the opacity smoothly as the number of lines increases.","Use *1* to achieve exact `unselected.line.color`."].join(" ")},editType:"plot"},editType:"plot"}}},15118:(e,t,r)=>{"use strict";var n=r(97712),i=r(41871),o=r(85876).keyFun,a=r(85876).repeat,s=r(84468).sorterAsc,l=r(84468).strTranslate,c=n.bar.snapRatio;function u(e,t){return e*(1-c)+t*c}var d=n.bar.snapClose;function h(e,t){return e*(1-d)+t*d}function p(e,t,r,n){if(function(e,t){for(var r=0;r=t[r][0]&&e<=t[r][1])return!0;return!1}(r,n))return r;var i=e?-1:1,o=0,a=t.length-1;if(i<0){var s=o;o=a,a=s}for(var l=t[o],c=l,d=o;i*dt){h=r;break}}if(o=u,isNaN(o)&&(o=isNaN(d)||isNaN(h)?isNaN(d)?h:d:t-c[d][1]e[1]+r||t=.9*e[1]+.1*e[0]?"n":t<=.9*e[0]+.1*e[1]?"s":"ns"}(f,t);m&&(a.interval=l[o],a.intervalPix=f,a.region=m)}}if(e.ordinal&&!a.region){var g=e.unitTickvals,v=e.unitToPaddedPx.invert(t);for(r=0;r=x[0]&&v<=x[1]){a.clickableOrdinalRange=x;break}}}return a}function w(e,t){i.event.sourceEvent.stopPropagation();var r=t.height-i.mouse(e)[1]-2*n.verticalPadding,o=t.brush.svgBrush;o.wasDragged=!0,o._dragging=!0,o.grabbingBar?o.newExtent=[r-o.grabPoint,r+o.barLength-o.grabPoint].map(t.unitToPaddedPx.invert):o.newExtent=[o.startExtent,t.unitToPaddedPx.invert(r)].sort(s),t.brush.filterSpecified=!0,o.extent=o.stayingIntervals.concat([o.newExtent]),o.brushCallback(t),b(e.parentNode)}function k(e,t){var r=_(t,t.height-i.mouse(e)[1]-2*n.verticalPadding),o="crosshair";r.clickableOrdinalRange?o="pointer":r.region&&(o=r.region+"-resize"),i.select(document.body).style("cursor",o)}function S(e){e.on("mousemove",(function(e){i.event.preventDefault(),e.parent.inBrushDrag||k(this,e)})).on("mouseleave",(function(e){e.parent.inBrushDrag||v()})).call(i.behavior.drag().on("dragstart",(function(e){!function(e,t){i.event.sourceEvent.stopPropagation();var r=t.height-i.mouse(e)[1]-2*n.verticalPadding,o=t.unitToPaddedPx.invert(r),a=t.brush,s=_(t,r),l=s.interval,c=a.svgBrush;if(c.wasDragged=!1,c.grabbingBar="ns"===s.region,c.grabbingBar){var u=l.map(t.unitToPaddedPx);c.grabPoint=r-u[0]-n.verticalPadding,c.barLength=u[1]-u[0]}c.clickableOrdinalRange=s.clickableOrdinalRange,c.stayingIntervals=t.multiselect&&a.filterSpecified?a.filter.getConsolidated():[],l&&(c.stayingIntervals=c.stayingIntervals.filter((function(e){return e[0]!==l[0]&&e[1]!==l[1]}))),c.startExtent=s.region?l["s"===s.region?1:0]:o,t.parent.inBrushDrag=!0,c.brushStartCallback()}(this,e)})).on("drag",(function(e){w(this,e)})).on("dragend",(function(e){!function(e,t){var r=t.brush,n=r.filter,o=r.svgBrush;o._dragging||(k(e,t),w(e,t),t.brush.svgBrush.wasDragged=!1),o._dragging=!1,i.event.sourceEvent.stopPropagation();var a=o.grabbingBar;if(o.grabbingBar=!1,o.grabLocation=void 0,t.parent.inBrushDrag=!1,v(),!o.wasDragged)return o.wasDragged=void 0,o.clickableOrdinalRange?r.filterSpecified&&t.multiselect?o.extent.push(o.clickableOrdinalRange):(o.extent=[o.clickableOrdinalRange],r.filterSpecified=!0):a?(o.extent=o.stayingIntervals,0===o.extent.length&&T(r)):T(r),o.brushCallback(t),b(e.parentNode),void o.brushEndCallback(r.filterSpecified?n.getConsolidated():[]);var s=function(){n.set(n.getConsolidated())};if(t.ordinal){var l=t.unitTickvals;l[l.length-1]o.newExtent[0];o.extent=o.stayingIntervals.concat(c?[o.newExtent]:[]),o.extent.length||T(r),o.brushCallback(t),c?b(e.parentNode,s):(s(),b(e.parentNode))}else s();o.brushEndCallback(r.filterSpecified?n.getConsolidated():[])}(this,e)})))}function A(e,t){return e[0]-t[0]}function T(e){e.filterSpecified=!1,e.svgBrush.extent=[[-1/0,1/0]]}function M(e){for(var t,r=e.slice(),n=[],i=r.shift();i;){for(t=i.slice();(i=r.shift())&&i[0]<=t[1];)t[1]=Math.max(t[1],i[1]);n.push(t)}return 1===n.length&&n[0][0]>n[0][1]&&(n=[]),n}e.exports={makeBrush:function(e,t,r,n,i,o){var a,l=function(){var e,t,r=[];return{set:function(n){1===(r=n.map((function(e){return e.slice().sort(s)})).sort(A)).length&&r[0][0]===-1/0&&r[0][1]===1/0&&(r=[[0,-1]]),e=M(r),t=r.reduce((function(e,t){return[Math.min(e[0],t[0]),Math.max(e[1],t[1])]}),[1/0,-1/0])},get:function(){return r.slice()},getConsolidated:function(){return e},getBounds:function(){return t}}}();return l.set(r),{filter:l,filterSpecified:t,svgBrush:{extent:[],brushStartCallback:n,brushCallback:(a=i,function(e){var t=e.brush,r=function(e){return e.svgBrush.extent.map((function(e){return e.slice()}))}(t),n=r.slice();t.filter.set(n),a()}),brushEndCallback:o}}},ensureAxisBrush:function(e,t,r){var i=e.selectAll("."+n.cn.axisBrush).data(a,o);i.enter().append("g").classed(n.cn.axisBrush,!0),function(e,t,r){var i=r._context.staticPlot,o=e.selectAll(".background").data(a);o.enter().append("rect").classed("background",!0).call(f).call(m).style("pointer-events",i?"none":"auto").attr("transform",l(0,n.verticalPadding)),o.call(S).attr("height",(function(e){return e.height-n.verticalPadding}));var s=e.selectAll(".highlight-shadow").data(a);s.enter().append("line").classed("highlight-shadow",!0).attr("x",-n.bar.width/2).attr("stroke-width",n.bar.width+n.bar.strokeWidth).attr("stroke",t).attr("opacity",n.bar.strokeOpacity).attr("stroke-linecap","butt"),s.attr("y1",(function(e){return e.height})).call(x);var c=e.selectAll(".highlight").data(a);c.enter().append("line").classed("highlight",!0).attr("x",-n.bar.width/2).attr("stroke-width",n.bar.width-n.bar.strokeWidth).attr("stroke",n.bar.fillColor).attr("opacity",n.bar.fillOpacity).attr("stroke-linecap","butt"),c.attr("y1",(function(e){return e.height})).call(x)}(i,t,r)},cleanRanges:function(e,t){if(Array.isArray(e[0])?(e=e.map((function(e){return e.sort(s)})),e=t.multiselect?M(e.sort(A)):[e[0]]):e=[e.sort(s)],t.tickvals){var r=t.tickvals.slice().sort(s);if(!(e=e.map((function(e){var t=[p(0,r,e[0],[]),p(1,r,e[1],[])];if(t[1]>t[0])return t})).filter((function(e){return e}))).length)return}return e.length>1?e:e[0]}}},78723:(e,t,r)=>{"use strict";e.exports={attributes:r(70436),supplyDefaults:r(86291),calc:r(77028),colorbar:{container:"line",min:"cmin",max:"cmax"},moduleType:"trace",name:"parcoords",basePlotModule:r(26756),categories:["gl","regl","noOpacity","noHover"],meta:{description:["Parallel coordinates for multidimensional exploratory data analysis.","The samples are specified in `dimensions`.","The colors are set in `line.color`."].join(" ")}}},26756:(e,t,r)=>{"use strict";var n=r(41871),i=r(50246).eV,o=r(81894),a=r(28795);t.name="parcoords",t.plot=function(e){var t=i(e.calcdata,"parcoords")[0];t.length&&o(e,t)},t.clean=function(e,t,r,n){var i=n._has&&n._has("parcoords"),o=t._has&&t._has("parcoords");i&&!o&&(n._paperdiv.selectAll(".parcoords").remove(),n._glimages.selectAll("*").remove())},t.toSVG=function(e){var t=e._fullLayout._glimages,r=n.select(e).selectAll(".svg-container");r.filter((function(e,t){return t===r.size()-1})).selectAll(".gl-canvas-context, .gl-canvas-focus").each((function(){var e=this,r=e.toDataURL("image/png");t.append("svg:image").attr({xmlns:a.svg,"xlink:href":r,preserveAspectRatio:"none",x:0,y:0,width:e.style.width,height:e.style.height})})),window.setTimeout((function(){n.selectAll("#filterBarPattern").attr("id","filterBarPattern")}),60)}},77028:(e,t,r)=>{"use strict";var n=r(84468).isArrayOrTypedArray,i=r(39265),o=r(85876).wrap;e.exports=function(e,t){var r,a;return i.hasColorscale(t,"line")&&n(t.line.color)?(r=t.line.color,a=i.extractOpts(t.line).colorscale,i.calc(e,t,{vals:r,containerStr:"line",cLetter:"c"})):(r=function(e){for(var t=new Array(e),r=0;r{"use strict";e.exports={maxDimensionCount:60,overdrag:45,verticalPadding:2,tickDistance:50,canvasPixelRatio:1,blockLineCount:5e3,layers:["contextLineLayer","focusLineLayer","pickLineLayer"],axisTitleOffset:28,axisExtentOffset:10,bar:{width:4,captureWidth:10,fillColor:"magenta",fillOpacity:1,snapDuration:150,snapRatio:.25,snapClose:.01,strokeOpacity:1,strokeWidth:1,handleHeight:8,handleOpacity:1,handleOverlap:0},cn:{axisExtentText:"axis-extent-text",parcoordsLineLayers:"parcoords-line-layers",parcoordsLineLayer:"parcoords-lines",parcoords:"parcoords",parcoordsControlView:"parcoords-control-view",yAxis:"y-axis",axisOverlays:"axis-overlays",axis:"axis",axisHeading:"axis-heading",axisTitle:"axis-title",axisExtent:"axis-extent",axisExtentTop:"axis-extent-top",axisExtentTopText:"axis-extent-top-text",axisExtentBottom:"axis-extent-bottom",axisExtentBottomText:"axis-extent-bottom-text",axisBrush:"axis-brush"},id:{filterBarPattern:"filter-bar-pattern"}}},86291:(e,t,r)=>{"use strict";var n=r(84468),i=r(73084).hasColorscale,o=r(16155),a=r(81159).N,s=r(38851),l=r(85729),c=r(70436),u=r(15118),d=r(97712).maxDimensionCount,h=r(28692);function p(e,t,r,i){function o(r,i){return n.coerce(e,t,c.dimensions,r,i)}var a=o("values"),s=o("visible");if(a&&a.length||(s=t.visible=!1),s){o("label"),o("tickvals"),o("ticktext"),o("tickformat");var d=o("range");t._ax={_id:"y",type:"linear",showexponent:"all",exponentformat:"B",range:d},l.setConvert(t._ax,i.layout),o("multiselect");var h=o("constraintrange");h&&(t.constraintrange=u.cleanRanges(h,t))}}e.exports=function(e,t,r,l){function u(r,i){return n.coerce(e,t,c,r,i)}var f=e.dimensions;Array.isArray(f)&&f.length>d&&(n.log("parcoords traces support up to "+d+" dimensions at the moment"),f.splice(d));var m=s(e,t,{name:"dimensions",layout:l,handleItemDefaults:p}),g=function(e,t,r,a,s){var l=s("line.color",r);if(i(e,"line")&&n.isArrayOrTypedArray(l)){if(l.length)return s("line.colorscale"),o(e,t,a,s,{prefix:"line.",cLetter:"c"}),l.length;t.line.color=r}return 1/0}(e,t,r,l,u);a(t,l,u),Array.isArray(m)&&m.length||(t.visible=!1),h(t,m,"values",g);var y=n.extendFlat({},l.font,{size:Math.round(l.font.size/1.2)});n.coerceFont(u,"labelfont",y),n.coerceFont(u,"tickfont",y,{autoShadowDflt:!0}),n.coerceFont(u,"rangefont",y),u("labelangle"),u("labelside"),u("unselected.line.color"),u("unselected.line.opacity")}},67412:(e,t,r)=>{"use strict";var n=r(84468).isTypedArray;t.convertTypedArray=function(e){return n(e)?Array.prototype.slice.call(e):e},t.isOrdinal=function(e){return!!e.tickvals},t.isVisible=function(e){return e.visible||!("visible"in e)}},71049:(e,t,r)=>{"use strict";var n=r(78723);n.plot=r(81894),e.exports=n},87626:(e,t,r)=>{"use strict";var n=["precision highp float;","","varying vec4 fragColor;","","attribute vec4 p01_04, p05_08, p09_12, p13_16,"," p17_20, p21_24, p25_28, p29_32,"," p33_36, p37_40, p41_44, p45_48,"," p49_52, p53_56, p57_60, colors;","","uniform mat4 dim0A, dim1A, dim0B, dim1B, dim0C, dim1C, dim0D, dim1D,"," loA, hiA, loB, hiB, loC, hiC, loD, hiD;","","uniform vec2 resolution, viewBoxPos, viewBoxSize;","uniform float maskHeight;","uniform float drwLayer; // 0: context, 1: focus, 2: pick","uniform vec4 contextColor;","uniform sampler2D maskTexture, palette;","","bool isPick = (drwLayer > 1.5);","bool isContext = (drwLayer < 0.5);","","const vec4 ZEROS = vec4(0.0, 0.0, 0.0, 0.0);","const vec4 UNITS = vec4(1.0, 1.0, 1.0, 1.0);","","float val(mat4 p, mat4 v) {"," return dot(matrixCompMult(p, v) * UNITS, UNITS);","}","","float axisY(float ratio, mat4 A, mat4 B, mat4 C, mat4 D) {"," float y1 = val(A, dim0A) + val(B, dim0B) + val(C, dim0C) + val(D, dim0D);"," float y2 = val(A, dim1A) + val(B, dim1B) + val(C, dim1C) + val(D, dim1D);"," return y1 * (1.0 - ratio) + y2 * ratio;","}","","int iMod(int a, int b) {"," return a - b * (a / b);","}","","bool fOutside(float p, float lo, float hi) {"," return (lo < hi) && (lo > p || p > hi);","}","","bool vOutside(vec4 p, vec4 lo, vec4 hi) {"," return ("," fOutside(p[0], lo[0], hi[0]) ||"," fOutside(p[1], lo[1], hi[1]) ||"," fOutside(p[2], lo[2], hi[2]) ||"," fOutside(p[3], lo[3], hi[3])"," );","}","","bool mOutside(mat4 p, mat4 lo, mat4 hi) {"," return ("," vOutside(p[0], lo[0], hi[0]) ||"," vOutside(p[1], lo[1], hi[1]) ||"," vOutside(p[2], lo[2], hi[2]) ||"," vOutside(p[3], lo[3], hi[3])"," );","}","","bool outsideBoundingBox(mat4 A, mat4 B, mat4 C, mat4 D) {"," return mOutside(A, loA, hiA) ||"," mOutside(B, loB, hiB) ||"," mOutside(C, loC, hiC) ||"," mOutside(D, loD, hiD);","}","","bool outsideRasterMask(mat4 A, mat4 B, mat4 C, mat4 D) {"," mat4 pnts[4];"," pnts[0] = A;"," pnts[1] = B;"," pnts[2] = C;"," pnts[3] = D;",""," for(int i = 0; i < 4; ++i) {"," for(int j = 0; j < 4; ++j) {"," for(int k = 0; k < 4; ++k) {"," if(0 == iMod("," int(255.0 * texture2D(maskTexture,"," vec2("," (float(i * 2 + j / 2) + 0.5) / 8.0,"," (pnts[i][j][k] * (maskHeight - 1.0) + 1.0) / maskHeight"," ))[3]"," ) / int(pow(2.0, float(iMod(j * 4 + k, 8)))),"," 2"," )) return true;"," }"," }"," }"," return false;","}","","vec4 position(bool isContext, float v, mat4 A, mat4 B, mat4 C, mat4 D) {"," float x = 0.5 * sign(v) + 0.5;"," float y = axisY(x, A, B, C, D);"," float z = 1.0 - abs(v);",""," z += isContext ? 0.0 : 2.0 * float("," outsideBoundingBox(A, B, C, D) ||"," outsideRasterMask(A, B, C, D)"," );",""," return vec4("," 2.0 * (vec2(x, y) * viewBoxSize + viewBoxPos) / resolution - 1.0,"," z,"," 1.0"," );","}","","void main() {"," mat4 A = mat4(p01_04, p05_08, p09_12, p13_16);"," mat4 B = mat4(p17_20, p21_24, p25_28, p29_32);"," mat4 C = mat4(p33_36, p37_40, p41_44, p45_48);"," mat4 D = mat4(p49_52, p53_56, p57_60, ZEROS);",""," float v = colors[3];",""," gl_Position = position(isContext, v, A, B, C, D);",""," fragColor ="," isContext ? vec4(contextColor) :"," isPick ? vec4(colors.rgb, 1.0) : texture2D(palette, vec2(abs(v), 0.5));","}"].join("\n"),i=["precision highp float;","","varying vec4 fragColor;","","void main() {"," gl_FragColor = fragColor;","}"].join("\n"),o=r(97712).maxDimensionCount,a=r(84468),s=1e-6,l=2048,c=new Uint8Array(4),u=new Uint8Array(4),d={shape:[256,1],format:"rgba",type:"uint8",mag:"nearest",min:"nearest"};function h(e,t,r,n,i){var o=e._gl;o.enable(o.SCISSOR_TEST),o.scissor(t,r,n,i),e.clear({color:[0,0,0,0],depth:1})}function p(e,t,r,n,i,o){var a=o.key;r.drawCompleted||(!function(e){e.read({x:0,y:0,width:1,height:1,data:c})}(e),r.drawCompleted=!0),function s(l){var c=Math.min(n,i-l*n);0===l&&(window.cancelAnimationFrame(r.currentRafs[a]),delete r.currentRafs[a],h(e,o.scissorX,o.scissorY,o.scissorWidth,o.viewBoxSize[1])),r.clearOnly||(o.count=2*c,o.offset=2*l*n,t(o),l*n+c>>8*t)%256/255}function g(e,t,r){for(var n=new Array(8*t),i=0,o=0;ou&&(u=e[i].dim1.canvasX,a=i);0===s&&h(A,0,0,r.canvasWidth,r.canvasHeight);var d=function(e){var t,r,n,i=[[],[]];for(n=0;n<64;n++){var o=!e&&n{"use strict";e.exports=function(e,t,r,n){var i,o;for(n||(n=1/0),i=0;i{"use strict";var n=r(41871),i=r(84468),o=i.isArrayOrTypedArray,a=i.numberFormat,s=r(17705),l=r(85729),c=i.strRotate,u=i.strTranslate,d=r(13480),h=r(3172),p=r(39265),f=r(85876),m=f.keyFun,g=f.repeat,y=f.unwrap,v=r(67412),x=r(97712),b=r(15118),_=r(87626);function w(e,t,r){return i.aggNums(e,null,t,r)}function k(e,t){return A(w(Math.min,e,t),w(Math.max,e,t))}function S(e){var t=e.range;return t?A(t[0],t[1]):k(e.values,e._length)}function A(e,t){return!isNaN(e)&&isFinite(e)||(e=0),!isNaN(t)&&isFinite(t)||(t=0),e===t&&(0===e?(e-=1,t+=1):(e*=.9,t*=1.1)),[e,t]}function T(e,t,r,i,o){var s,l,c=S(r);return i?n.scale.ordinal().domain(i.map((s=a(r.tickformat),l=o,l?function(e,t){var r=l[t];return null===r||void 0===r?s(e):r}:s))).range(i.map((function(r){var n=(r-c[0])/(c[1]-c[0]);return e-t+n*(2*t-e)}))):n.scale.linear().domain(c).range([e-t,t])}function M(e){if(e.tickvals){var t=S(e);return n.scale.ordinal().domain(e.tickvals).range(e.tickvals.map((function(e){return(e-t[0])/(t[1]-t[0])})))}}function C(e){var t=e.map((function(e){return e[0]})),r=e.map((function(e){var t=s(e[1]);return n.rgb("rgb("+t[0]+","+t[1]+","+t[2]+")")})),i="rgb".split("").map((function(e){return n.scale.linear().clamp(!0).domain(t).range(r.map((i=e,function(e){return e[i]})));var i}));return function(e){return i.map((function(t){return t(e)}))}}function E(e){return e.dimensions.some((function(e){return e.brush.filterSpecified}))}function I(e,t,r){var o=y(t),a=o.trace,l=v.convertTypedArray(o.lineColor),c=a.line,u={color:s(a.unselected.line.color),opacity:a.unselected.line.opacity},d=p.extractOpts(c),h=d.reversescale?p.flipScale(o.cscale):o.cscale,f=a.domain,m=a.dimensions,g=e.width,b=a.labelangle,_=a.labelside,w=a.labelfont,k=a.tickfont,A=a.rangefont,T=i.extendDeepNoArrays({},c,{color:l.map(n.scale.linear().domain(S({values:l,range:[d.min,d.max],_length:a._length}))),blockLineCount:x.blockLineCount,canvasOverdrag:x.overdrag*x.canvasPixelRatio}),M=Math.floor(g*(f.x[1]-f.x[0])),E=Math.floor(e.height*(f.y[1]-f.y[0])),I=e.margin||{l:80,r:80,t:100,b:80},P=M,O=E;return{key:r,colCount:m.filter(v.isVisible).length,dimensions:m,tickDistance:x.tickDistance,unitToColor:C(h),lines:T,deselectedLines:u,labelAngle:b,labelSide:_,labelFont:w,tickFont:k,rangeFont:A,layoutWidth:g,layoutHeight:e.height,domain:f,translateX:f.x[0]*g,translateY:e.height-f.y[1]*e.height,pad:I,canvasWidth:P*x.canvasPixelRatio+2*T.canvasOverdrag,canvasHeight:O*x.canvasPixelRatio,width:P,height:O,canvasPixelRatio:x.canvasPixelRatio}}function P(e,t,r){var s=r.width,l=r.height,c=r.dimensions,u=r.canvasPixelRatio,d=function(e){return s*e/Math.max(1,r.colCount-1)},h=x.verticalPadding/l,p=function(e,t){return n.scale.linear().range([t,e-t])}(l,x.verticalPadding),f={key:r.key,xScale:d,model:r,inBrushDrag:!1},m={};return f.dimensions=c.filter(v.isVisible).map((function(s,c){var g=function(e,t){return n.scale.linear().domain(S(e)).range([t,1-t])}(s,h),y=m[s.label];m[s.label]=(y||0)+1;var _=s.label+(y?"__"+y:""),w=s.constraintrange,k=w&&w.length;k&&!o(w[0])&&(w=[w]);var A=k?w.map((function(e){return e.map(g)})):[[-1/0,1/0]],C=s.values;C.length>s._length&&(C=C.slice(0,s._length));var I,P=s.tickvals;function O(e,t){return{val:e,text:I[t]}}function R(e,t){return e.val-t.val}if(o(P)&&P.length){i.isTypedArray(P)&&(P=Array.from(P)),I=s.ticktext,o(I)&&I.length?I.length>P.length?I=I.slice(0,P.length):P.length>I.length&&(P=P.slice(0,I.length)):I=P.map(a(s.tickformat));for(var L=1;L=r||l>=i)return;var c=e.lineLayer.readPixel(s,i-1-l),u=0!==c[3],d=u?c[2]+256*(c[1]+256*c[0]):null,h={x:s,y:l,clientX:t.clientX,clientY:t.clientY,dataIndex:e.model.key,curveNumber:d};d!==j&&(u?o.hover(h):o.unhover&&o.unhover(h),j=d)}})),C.style("opacity",(function(e){return e.pick?0:1})),p.style("background","rgba(255, 255, 255, 0)");var F=p.selectAll("."+x.cn.parcoords).data(M,m);F.exit().remove(),F.enter().append("g").classed(x.cn.parcoords,!0).style("shape-rendering","crispEdges").style("pointer-events","none"),F.attr("transform",(function(e){return u(e.model.translateX,e.model.translateY)}));var N=F.selectAll("."+x.cn.parcoordsControlView).data(g,m);N.enter().append("g").classed(x.cn.parcoordsControlView,!0),N.attr("transform",(function(e){return u(e.model.pad.l,e.model.pad.t)}));var B=N.selectAll("."+x.cn.yAxis).data((function(e){return e.dimensions}),m);B.enter().append("g").classed(x.cn.yAxis,!0),N.each((function(e){L(B,e,w)})),C.each((function(e){if(e.viewModel){!e.lineLayer||o?e.lineLayer=_(this,e):e.lineLayer.update(e),(e.key||0===e.key)&&(e.viewModel[e.key]=e.lineLayer);var t=!e.context||o;e.lineLayer.render(e.viewModel.panels,t)}})),B.attr("transform",(function(e){return u(e.xScale(e.xIndex),0)})),B.call(n.behavior.drag().origin((function(e){return e})).on("drag",(function(e){var t=e.parent;T.linePickActive(!1),e.x=Math.max(-x.overdrag,Math.min(e.model.width+x.overdrag,n.event.x)),e.canvasX=e.x*e.model.canvasPixelRatio,B.sort((function(e,t){return e.x-t.x})).each((function(t,r){t.xIndex=r,t.x=e===t?t.x:t.xScale(t.xIndex),t.canvasX=t.x*t.model.canvasPixelRatio})),L(B,t,w),B.filter((function(t){return 0!==Math.abs(e.xIndex-t.xIndex)})).attr("transform",(function(e){return u(e.xScale(e.xIndex),0)})),n.select(this).attr("transform",u(e.x,0)),B.each((function(r,n,i){i===e.parent.key&&(t.dimensions[n]=r)})),t.contextLayer&&t.contextLayer.render(t.panels,!1,!E(t)),t.focusLayer.render&&t.focusLayer.render(t.panels)})).on("dragend",(function(e){var t=e.parent;e.x=e.xScale(e.xIndex),e.canvasX=e.x*e.model.canvasPixelRatio,L(B,t,w),n.select(this).attr("transform",(function(e){return u(e.x,0)})),t.contextLayer&&t.contextLayer.render(t.panels,!1,!E(t)),t.focusLayer&&t.focusLayer.render(t.panels),t.pickLayer&&t.pickLayer.render(t.panels,!0),T.linePickActive(!0),o&&o.axesMoved&&o.axesMoved(t.key,t.dimensions.map((function(e){return e.crossfilterDimensionIndex})))}))),B.exit().remove();var V=B.selectAll("."+x.cn.axisOverlays).data(g,m);V.enter().append("g").classed(x.cn.axisOverlays,!0),V.selectAll("."+x.cn.axis).remove();var U=V.selectAll("."+x.cn.axis).data(g,m);U.enter().append("g").classed(x.cn.axis,!0),U.each((function(e){var t=e.model.height/e.model.tickDistance,r=e.domainScale,i=r.domain();n.select(this).call(n.svg.axis().orient("left").tickSize(4).outerTickSize(2).ticks(t,e.tickFormat).tickValues(e.ordinal?i:null).tickFormat((function(t){return v.isOrdinal(e)?t:D(e.model.dimensions[e.visibleIndex],t)})).scale(r)),h.font(U.selectAll("text"),e.model.tickFont)})),U.selectAll(".domain, .tick>line").attr("fill","none").attr("stroke","black").attr("stroke-opacity",.25).attr("stroke-width","1px"),U.selectAll("text").style("cursor","default");var H=V.selectAll("."+x.cn.axisHeading).data(g,m);H.enter().append("g").classed(x.cn.axisHeading,!0);var $=H.selectAll("."+x.cn.axisTitle).data(g,m);$.enter().append("text").classed(x.cn.axisTitle,!0).attr("text-anchor","middle").style("cursor","ew-resize").style("pointer-events",a?"none":"auto"),$.text((function(e){return e.label})).each((function(t){var r=n.select(this);h.font(r,t.model.labelFont),d.convertToTspans(r,e)})).attr("transform",(function(e){var t=R(e.model.labelAngle,e.model.labelSide),r=x.axisTitleOffset;return(t.dir>0?"":u(0,2*r+e.model.height))+c(t.degrees)+u(-r*t.dx,-r*t.dy)})).attr("text-anchor",(function(e){var t=R(e.model.labelAngle,e.model.labelSide);return 2*Math.abs(t.dx)>Math.abs(t.dy)?t.dir*t.dx<0?"start":"end":"middle"}));var W=V.selectAll("."+x.cn.axisExtent).data(g,m);W.enter().append("g").classed(x.cn.axisExtent,!0);var q=W.selectAll("."+x.cn.axisExtentTop).data(g,m);q.enter().append("g").classed(x.cn.axisExtentTop,!0),q.attr("transform",u(0,-x.axisExtentOffset));var G=q.selectAll("."+x.cn.axisExtentTopText).data(g,m);G.enter().append("text").classed(x.cn.axisExtentTopText,!0).call(O),G.text((function(e){return z(e,!0)})).each((function(e){h.font(n.select(this),e.model.rangeFont)}));var Y=W.selectAll("."+x.cn.axisExtentBottom).data(g,m);Y.enter().append("g").classed(x.cn.axisExtentBottom,!0),Y.attr("transform",(function(e){return u(0,e.model.height+x.axisExtentOffset)}));var X=Y.selectAll("."+x.cn.axisExtentBottomText).data(g,m);X.enter().append("text").classed(x.cn.axisExtentBottomText,!0).attr("dy","0.75em").call(O),X.text((function(e){return z(e,!1)})).each((function(e){h.font(n.select(this),e.model.rangeFont)})),b.ensureAxisBrush(V,S,e)}},81894:(e,t,r)=>{"use strict";var n=r(14412),i=r(48488),o=r(67412).isVisible,a={};function s(e,t,r){var n=t.indexOf(r),i=e.indexOf(n);return-1===i&&(i+=t.length),i}(e.exports=function(e,t){var r=e._fullLayout;if(i(e,[],a)){var l={},c={},u={},d={},h=r._size;t.forEach((function(t,r){var n=t[0].trace;u[r]=n.index;var i=d[r]=n._fullInput.index;l[r]=e.data[i].dimensions,c[r]=e.data[i].dimensions.slice()}));n(e,t,{width:h.w,height:h.h,margin:{t:h.t,r:h.r,b:h.b,l:h.l}},{filterChanged:function(t,n,i){var o=c[t][n],a=i.map((function(e){return e.slice()})),s="dimensions["+n+"].constraintrange",l=r._tracePreGUI[e._fullData[u[t]]._fullInput.uid];if(void 0===l[s]){var h=o.constraintrange;l[s]=h||null}var p=e._fullData[u[t]].dimensions[n];a.length?(1===a.length&&(a=a[0]),o.constraintrange=a,p.constraintrange=a.slice(),a=[a]):(delete o.constraintrange,delete p.constraintrange,a=null);var f={};f[s]=a,e.emit("plotly_restyle",[f,[d[t]]])},hover:function(t){e.emit("plotly_hover",t)},unhover:function(t){e.emit("plotly_unhover",t)},axesMoved:function(t,r){var n=function(e,t){return function(r,n){return s(e,t,r)-s(e,t,n)}}(r,c[t].filter(o));l[t].sort(n),c[t].filter((function(e){return!o(e)})).sort((function(e){return c[t].indexOf(e)})).forEach((function(e){l[t].splice(l[t].indexOf(e),1),l[t].splice(c[t].indexOf(e),0,e)})),e.emit("plotly_restyle",[{dimensions:[l[t]]},[d[t]]])}})}}).reglPrecompiled=a},59453:(e,t,r)=>{"use strict";var n=r(75622),i=r(81159).u,o=r(91740),a=r(17992),s=r(84425).rb,l=r(84425).ay,c=r(64022).extendFlat,u=r(2703).k,d=o({editType:"plot",arrayOk:!0,colorEditType:"plot",description:"Sets the font used for `textinfo`."});e.exports={labels:{valType:"data_array",editType:"calc",description:["Sets the sector labels.","If `labels` entries are duplicated, we sum associated `values`","or simply count occurrences if `values` is not provided.","For other array attributes (including color) we use the first","non-empty entry among all occurrences of the label."].join(" ")},label0:{valType:"number",dflt:0,editType:"calc",description:["Alternate to `labels`.","Builds a numeric set of labels.","Use with `dlabel`","where `label0` is the starting label and `dlabel` the step."].join(" ")},dlabel:{valType:"number",dflt:1,editType:"calc",description:"Sets the label step. See `label0` for more info."},values:{valType:"data_array",editType:"calc",description:["Sets the values of the sectors.","If omitted, we count occurrences of each label."].join(" ")},marker:{colors:{valType:"data_array",editType:"calc",description:["Sets the color of each sector.","If not specified, the default trace color set is used","to pick the sector colors."].join(" ")},line:{color:{valType:"color",dflt:a.defaultLine,arrayOk:!0,editType:"style",description:["Sets the color of the line enclosing each sector."].join(" ")},width:{valType:"number",min:0,dflt:0,arrayOk:!0,editType:"style",description:["Sets the width (in px) of the line enclosing each sector."].join(" ")},editType:"calc"},pattern:u,editType:"calc"},text:{valType:"data_array",editType:"plot",description:["Sets text elements associated with each sector.","If trace `textinfo` contains a *text* flag, these elements will be seen","on the chart.","If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,","these elements will be seen in the hover labels."].join(" ")},hovertext:{valType:"string",dflt:"",arrayOk:!0,editType:"style",description:["Sets hover text elements associated with each sector.","If a single string, the same string appears for","all data points.","If an array of string, the items are mapped in order of","this trace's sectors.","To be seen, trace `hoverinfo` must contain a *text* flag."].join(" ")},scalegroup:{valType:"string",dflt:"",editType:"calc",description:["If there are multiple pie charts that should be sized according to","their totals, link them by providing a non-empty group id here","shared by every trace in the same group."].join(" ")},textinfo:{valType:"flaglist",flags:["label","text","value","percent"],extras:["none"],editType:"calc",description:["Determines which trace information appear on the graph."].join(" ")},hoverinfo:c({},n.hoverinfo,{flags:["label","text","value","percent","name"]}),hovertemplate:s({},{keys:["label","color","value","percent","text"]}),texttemplate:l({editType:"plot"},{keys:["label","color","value","percent","text"]}),textposition:{valType:"enumerated",values:["inside","outside","auto","none"],dflt:"auto",arrayOk:!0,editType:"plot",description:["Specifies the location of the `textinfo`."].join(" ")},textfont:c({},d,{description:"Sets the font used for `textinfo`."}),insidetextorientation:{valType:"enumerated",values:["horizontal","radial","tangential","auto"],dflt:"auto",editType:"plot",description:["Controls the orientation of the text inside chart sectors.","When set to *auto*, text may be oriented in any direction in order","to be as big as possible in the middle of a sector.","The *horizontal* option orients text to be parallel with the bottom","of the chart, and may make text smaller in order to achieve that goal.","The *radial* option orients text along the radius of the sector.","The *tangential* option orients text perpendicular to the radius of the sector."].join(" ")},insidetextfont:c({},d,{description:"Sets the font used for `textinfo` lying inside the sector."}),outsidetextfont:c({},d,{description:"Sets the font used for `textinfo` lying outside the sector."}),automargin:{valType:"boolean",dflt:!1,editType:"plot",description:["Determines whether outside text labels can push the margins."].join(" ")},title:{text:{valType:"string",dflt:"",editType:"plot",description:["Sets the title of the chart.","If it is empty, no title is displayed.","Note that before the existence of `title.text`, the title's","contents used to be defined as the `title` attribute itself.","This behavior has been deprecated."].join(" ")},font:c({},d,{description:["Sets the font used for `title`.","Note that the title's font used to be set","by the now deprecated `titlefont` attribute."].join(" ")}),position:{valType:"enumerated",values:["top left","top center","top right","middle center","bottom left","bottom center","bottom right"],editType:"plot",description:["Specifies the location of the `title`.","Note that the title's position used to be set","by the now deprecated `titleposition` attribute."].join(" ")},editType:"plot"},domain:i({name:"pie",trace:!0,editType:"calc"}),hole:{valType:"number",min:0,max:1,dflt:0,editType:"calc",description:["Sets the fraction of the radius to cut out of the pie.","Use this to make a donut chart."].join(" ")},sort:{valType:"boolean",dflt:!0,editType:"calc",description:["Determines whether or not the sectors are reordered","from largest to smallest."].join(" ")},direction:{valType:"enumerated",values:["clockwise","counterclockwise"],dflt:"counterclockwise",editType:"calc",description:["Specifies the direction at which succeeding sectors follow","one another."].join(" ")},rotation:{valType:"angle",dflt:0,editType:"calc",description:["Instead of the first slice starting at 12 o'clock,","rotate to some other angle."].join(" ")},pull:{valType:"number",min:0,max:1,dflt:0,arrayOk:!0,editType:"calc",description:["Sets the fraction of larger radius to pull the sectors","out from the center. This can be a constant","to pull all slices apart from each other equally","or an array to highlight one or more slices."].join(" ")},_deprecated:{title:{valType:"string",dflt:"",editType:"calc",description:["Deprecated in favor of `title.text`.","Note that value of `title` is no longer a simple","*string* but a set of sub-attributes."].join(" ")},titlefont:c({},d,{description:"Deprecated in favor of `title.font`."}),titleposition:{valType:"enumerated",values:["top left","top center","top right","middle center","bottom left","bottom center","bottom right"],editType:"calc",description:"Deprecated in favor of `title.position`."}}}},3143:(e,t,r)=>{"use strict";var n=r(68543);t.name="pie",t.plot=function(e,r,i,o){n.plotBasePlot(t.name,e,r,i,o)},t.clean=function(e,r,i,o){n.cleanBasePlot(t.name,e,r,i,o)}},59217:(e,t,r)=>{"use strict";var n=r(22036),i=r(23498),o=r(7605),a={};function s(e){return function(t,r){return!!t&&(!!(t=i(t)).isValid()&&(t=o.addOpacity(t,t.getAlpha()),e[r]||(e[r]=t),t))}}function l(e,t){var r,n=JSON.stringify(e),o=t[n];if(!o){for(o=e.slice(),r=0;r=0})),("funnelarea"===t.type?y:t.sort)&&o.sort((function(e,t){return t.v-e.v})),o[0]&&(o[0].vTotal=g),o},crossTraceCalc:function(e,t){var r=(t||{}).type;r||(r="pie");var n=e._fullLayout,i=e.calcdata,o=n[r+"colorway"],s=n["_"+r+"colormap"];n["extend"+r+"colors"]&&(o=l(o,a));for(var c=0,u=0;u{"use strict";var n=r(22036),i=r(84468),o=r(59453),a=r(81159).N,s=r(81543).handleText,l=r(84468).coercePattern;function c(e,t){var r=i.isArrayOrTypedArray(e),o=i.isArrayOrTypedArray(t),a=Math.min(r?e.length:1/0,o?t.length:1/0);if(isFinite(a)||(a=0),a&&o){for(var s,l=0;l0){s=!0;break}}s||(a=0)}return{hasLabels:r,hasValues:o,len:a}}function u(e,t,r,n,i){n("marker.line.width")&&n("marker.line.color",i?void 0:r.paper_bgcolor);var o=n("marker.colors");l(n,"marker.pattern",o),e.marker&&!t.marker.pattern.fgcolor&&(t.marker.pattern.fgcolor=e.marker.colors),t.marker.pattern.bgcolor||(t.marker.pattern.bgcolor=r.paper_bgcolor)}e.exports={handleLabelsAndValues:c,handleMarkerDefaults:u,supplyDefaults:function(e,t,r,n){function l(r,n){return i.coerce(e,t,o,r,n)}var d=c(l("labels"),l("values")),h=d.len;if(t._hasLabels=d.hasLabels,t._hasValues=d.hasValues,!t._hasLabels&&t._hasValues&&(l("label0"),l("dlabel")),h){t._length=h,u(e,t,n,l,!0),l("scalegroup");var p,f=l("text"),m=l("texttemplate");if(m||(p=l("textinfo",i.isArrayOrTypedArray(f)?"text+percent":"percent")),l("hovertext"),l("hovertemplate"),m||p&&"none"!==p){var g=l("textposition");s(e,t,n,l,g,{moduleHasSelected:!1,moduleHasUnselected:!1,moduleHasConstrain:!1,moduleHasCliponaxis:!1,moduleHasTextangle:!1,moduleHasInsideanchor:!1}),(Array.isArray(g)||"auto"===g||"outside"===g)&&l("automargin"),("inside"===g||"auto"===g||Array.isArray(g))&&l("insidetextorientation")}else"none"===p&&l("textposition","none");a(t,n,l);var y=l("hole");if(l("title.text")){var v=l("title.position",y?"middle center":"top center");y||"middle center"!==v||(t.title.position="top center"),i.coerceFont(l,"title.font",n.font)}l("sort"),l("direction"),l("rotation"),l("pull")}else t.visible=!1}}},71857:(e,t,r)=>{"use strict";var n=r(82561).appendArrayMultiPointValues;e.exports=function(e,t){var r={curveNumber:t.index,pointNumbers:e.pts,data:t._input,fullData:t,label:e.label,color:e.color,value:e.v,percent:e.percent,text:e.text,bbox:e.bbox,v:e.v};return 1===e.pts.length&&(r.pointNumber=r.i=e.pts[0]),n(r,t,e.pts),"funnelarea"===t.type&&(delete r.v,delete r.i),r}},16074:(e,t,r)=>{"use strict";var n=r(3172),i=r(7605);e.exports=function(e,t,r,o){var a=r.marker.pattern;a&&a.shape?n.pointStyle(e,r,o,t):i.fill(e,t.color)}},97367:(e,t,r)=>{"use strict";var n=r(84468);function i(e){return-1!==e.indexOf("e")?e.replace(/[.]?0+e/,"e"):-1!==e.indexOf(".")?e.replace(/[.]?0+$/,""):e}t.formatPiePercent=function(e,t){var r=i((100*e).toPrecision(3));return n.numSeparate(r,t)+"%"},t.formatPieValue=function(e,t){var r=i(e.toPrecision(10));return n.numSeparate(r,t)},t.getFirstFilled=function(e,t){if(n.isArrayOrTypedArray(e))for(var r=0;r{"use strict";e.exports={attributes:r(59453),supplyDefaults:r(69834).supplyDefaults,supplyLayoutDefaults:r(59375),layoutAttributes:r(66008),calc:r(59217).calc,crossTraceCalc:r(59217).crossTraceCalc,plot:r(50183).plot,style:r(67775),styleOne:r(32100),moduleType:"trace",name:"pie",basePlotModule:r(3143),categories:["pie-like","pie","showLegend"],meta:{description:["A data visualized by the sectors of the pie is set in `values`.","The sector labels are set in `labels`.","The sector colors are set in `marker.colors`"].join(" ")}}},66008:e=>{"use strict";e.exports={hiddenlabels:{valType:"data_array",editType:"calc",description:["hiddenlabels is the funnelarea & pie chart analog of","visible:'legendonly'","but it can contain many labels, and can simultaneously","hide slices from several pies/funnelarea charts"].join(" ")},piecolorway:{valType:"colorlist",editType:"calc",description:["Sets the default pie slice colors. Defaults to the main","`colorway` used for trace colors. If you specify a new","list here it can still be extended with lighter and darker","colors, see `extendpiecolors`."].join(" ")},extendpiecolors:{valType:"boolean",dflt:!0,editType:"calc",description:["If `true`, the pie slice colors (whether given by `piecolorway` or","inherited from `colorway`) will be extended to three times its","original length by first repeating every color 20% lighter then","each color 20% darker. This is intended to reduce the likelihood","of reusing the same color when you have many slices, but you can","set `false` to disable.","Colors provided in the trace, using `marker.colors`, are never","extended."].join(" ")}}},59375:(e,t,r)=>{"use strict";var n=r(84468),i=r(66008);e.exports=function(e,t){function r(r,o){return n.coerce(e,t,i,r,o)}r("hiddenlabels"),r("piecolorway",t.colorway),r("extendpiecolors")}},50183:(e,t,r)=>{"use strict";var n=r(41871),i=r(68543),o=r(32212),a=r(7605),s=r(3172),l=r(84468),c=l.strScale,u=l.strTranslate,d=r(13480),h=r(35655),p=h.recordMinTextSize,f=h.clearMinTextSize,m=r(41508).TEXTPAD,g=r(97367),y=r(71857),v=r(84468).isValidTextValue;function x(e,t,r){var i=r[0],a=i.cx,s=i.cy,c=i.trace,u="funnelarea"===c.type;"_hasHoverLabel"in c||(c._hasHoverLabel=!1),"_hasHoverEvent"in c||(c._hasHoverEvent=!1),e.on("mouseover",(function(e){var r=t._fullLayout,d=t._fullData[c.index];if(!t._dragging&&!1!==r.hovermode){var h=d.hoverinfo;if(Array.isArray(h)&&(h=o.castHoverinfo({hoverinfo:[g.castOption(h,e.pts)],_module:c._module},r,0)),"all"===h&&(h="label+text+value+percent+name"),d.hovertemplate||"none"!==h&&"skip"!==h&&h){var p=e.rInscribed||0,f=a+e.pxmid[0]*(1-p),m=s+e.pxmid[1]*(1-p),v=r.separators,x=[];if(h&&-1!==h.indexOf("label")&&x.push(e.label),e.text=g.castOption(d.hovertext||d.text,e.pts),h&&-1!==h.indexOf("text")){var b=e.text;l.isValidTextValue(b)&&x.push(b)}e.value=e.v,e.valueLabel=g.formatPieValue(e.v,v),h&&-1!==h.indexOf("value")&&x.push(e.valueLabel),e.percent=e.v/i.vTotal,e.percentLabel=g.formatPiePercent(e.percent,v),h&&-1!==h.indexOf("percent")&&x.push(e.percentLabel);var _=d.hoverlabel,w=_.font,k=[];o.loneHover({trace:c,x0:f-p*i.r,x1:f+p*i.r,y:m,_x0:u?a+e.TL[0]:f-p*i.r,_x1:u?a+e.TR[0]:f+p*i.r,_y0:u?s+e.TL[1]:m-p*i.r,_y1:u?s+e.BL[1]:m+p*i.r,text:x.join("
"),name:d.hovertemplate||-1!==h.indexOf("name")?d.name:void 0,idealAlign:e.pxmid[0]<0?"left":"right",color:g.castOption(_.bgcolor,e.pts)||e.color,borderColor:g.castOption(_.bordercolor,e.pts),fontFamily:g.castOption(w.family,e.pts),fontSize:g.castOption(w.size,e.pts),fontColor:g.castOption(w.color,e.pts),nameLength:g.castOption(_.namelength,e.pts),textAlign:g.castOption(_.align,e.pts),hovertemplate:g.castOption(d.hovertemplate,e.pts),hovertemplateLabels:e,eventData:[y(e,d)]},{container:r._hoverlayer.node(),outerContainer:r._paper.node(),gd:t,inOut_bbox:k}),e.bbox=k[0],c._hasHoverLabel=!0}c._hasHoverEvent=!0,t.emit("plotly_hover",{points:[y(e,d)],event:n.event})}})),e.on("mouseout",(function(e){var r=t._fullLayout,i=t._fullData[c.index],a=n.select(this).datum();c._hasHoverEvent&&(e.originalEvent=n.event,t.emit("plotly_unhover",{points:[y(a,i)],event:n.event}),c._hasHoverEvent=!1),c._hasHoverLabel&&(o.loneUnhover(r._hoverlayer.node()),c._hasHoverLabel=!1)})),e.on("click",(function(e){var r=t._fullLayout,i=t._fullData[c.index];t._dragging||!1===r.hovermode||(t._hoverdata=[y(e,i)],o.click(t,n.event))}))}function b(e,t,r){var n=g.castOption(e.insidetextfont.color,t.pts);!n&&e._input.textfont&&(n=g.castOption(e._input.textfont.color,t.pts));var i=g.castOption(e.insidetextfont.family,t.pts)||g.castOption(e.textfont.family,t.pts)||r.family,o=g.castOption(e.insidetextfont.size,t.pts)||g.castOption(e.textfont.size,t.pts)||r.size,s=g.castOption(e.insidetextfont.weight,t.pts)||g.castOption(e.textfont.weight,t.pts)||r.weight,l=g.castOption(e.insidetextfont.style,t.pts)||g.castOption(e.textfont.style,t.pts)||r.style,c=g.castOption(e.insidetextfont.variant,t.pts)||g.castOption(e.textfont.variant,t.pts)||r.variant,u=g.castOption(e.insidetextfont.textcase,t.pts)||g.castOption(e.textfont.textcase,t.pts)||r.textcase,d=g.castOption(e.insidetextfont.lineposition,t.pts)||g.castOption(e.textfont.lineposition,t.pts)||r.lineposition,h=g.castOption(e.insidetextfont.shadow,t.pts)||g.castOption(e.textfont.shadow,t.pts)||r.shadow;return{color:n||a.contrast(t.color),family:i,size:o,weight:s,style:l,variant:c,textcase:u,lineposition:d,shadow:h}}function _(e,t){for(var r,n,i=0;it&&t>n||r=-4;g-=2)y(Math.PI*g,"tan");for(g=4;g>=-4;g-=2)y(Math.PI*(g+1),"tan")}if(d||p){for(g=4;g>=-4;g-=2)y(Math.PI*(g+1.5),"rad");for(g=4;g>=-4;g-=2)y(Math.PI*(g+.5),"rad")}}if(s||f||d){var v=Math.sqrt(e.width*e.width+e.height*e.height);if((o={scale:i*n*2/v,rCenter:1-i,rotate:0}).textPosAngle=(t.startangle+t.stopangle)/2,o.scale>=1)return o;m.push(o)}(f||p)&&((o=k(e,n,a,l,c)).textPosAngle=(t.startangle+t.stopangle)/2,m.push(o)),(f||h)&&((o=S(e,n,a,l,c)).textPosAngle=(t.startangle+t.stopangle)/2,m.push(o));for(var x=0,b=0,_=0;_=1)break}return m[x]}function k(e,t,r,n,i){t=Math.max(0,t-2*m);var o=e.width/e.height,a=M(o,n,t,r);return{scale:2*a/e.height,rCenter:A(o,a/t),rotate:T(i)}}function S(e,t,r,n,i){t=Math.max(0,t-2*m);var o=e.height/e.width,a=M(o,n,t,r);return{scale:2*a/e.width,rCenter:A(o,a/t),rotate:T(i+Math.PI/2)}}function A(e,t){return Math.cos(t)-e*t}function T(e){return(180/Math.PI*e+720)%180-90}function M(e,t,r,n){var i=e+1/(2*Math.tan(t));return r*Math.min(1/(Math.sqrt(i*i+.5)+i),n/(Math.sqrt(e*e+n/2)+e))}function C(e,t){return e.v!==t.vTotal||t.trace.hole?Math.min(1/(1+1/Math.sin(e.halfangle)),e.ring/2):1}function E(e,t){var r=t.pxmid[0],n=t.pxmid[1],i=e.width/2,o=e.height/2;return r<0&&(i*=-1),n<0&&(o*=-1),{scale:1,rCenter:1,rotate:0,x:i+Math.abs(o)*(i>0?1:-1)/2,y:o/(1+r*r/(n*n)),outside:!0}}function I(e,t){var r,n,i,o=e.trace,a={x:e.cx,y:e.cy},s={tx:0,ty:0};s.ty+=o.title.font.size,i=O(o),-1!==o.title.position.indexOf("top")?(a.y-=(1+i)*e.r,s.ty-=e.titleBox.height):-1!==o.title.position.indexOf("bottom")&&(a.y+=(1+i)*e.r);var l,c,u=(l=e.r,c=e.trace.aspectratio,l/(void 0===c?1:c)),d=t.w*(o.domain.x[1]-o.domain.x[0])/2;return-1!==o.title.position.indexOf("left")?(d+=u,a.x-=(1+i)*u,s.tx+=e.titleBox.width/2):-1!==o.title.position.indexOf("center")?d*=2:-1!==o.title.position.indexOf("right")&&(d+=u,a.x+=(1+i)*u,s.tx-=e.titleBox.width/2),r=d/e.titleBox.width,n=P(e,t)/e.titleBox.height,{x:a.x,y:a.y,scale:Math.min(r,n),tx:s.tx,ty:s.ty}}function P(e,t){var r=e.trace,n=t.h*(r.domain.y[1]-r.domain.y[0]);return Math.min(e.titleBox.height,n/2)}function O(e){var t,r=e.pull;if(!r)return 0;if(l.isArrayOrTypedArray(r))for(r=0,t=0;tr&&(r=e.pull[t]);return r}function R(e,t){for(var r=[],n=0;n1?u=(c=r.r)/i.aspectratio:c=(u=r.r)*i.aspectratio,l=(c*=(1+i.baseratio)/2)*u}a=Math.min(a,l/r.vTotal)}for(n=0;n")}if(o){var x=l.castOption(i,t.i,"texttemplate");if(x){var b=function(e){return{label:e.label,value:e.v,valueLabel:g.formatPieValue(e.v,n.separators),percent:e.v/r.vTotal,percentLabel:g.formatPiePercent(e.v/r.vTotal,n.separators),color:e.color,text:e.text,customdata:l.castOption(i,e.i,"customdata")}}(t),_=g.getFirstFilled(i.text,t.pts);(v(_)||""===_)&&(b.text=_),t.text=l.texttemplateString(x,b,e._fullLayout._d3locale,b,i._meta||{})}else t.text=""}}function z(e,t){var r=e.rotate*Math.PI/180,n=Math.cos(r),i=Math.sin(r),o=(t.left+t.right)/2,a=(t.top+t.bottom)/2;e.textX=o*n-a*i,e.textY=o*i+a*n,e.noCenter=!0}e.exports={plot:function(e,t){var r=e._context.staticPlot,o=e._fullLayout,h=o._size;f("pie",o),_(t,e),R(t,h);var m=l.makeTraceGroups(o._pielayer,t,"trace").each((function(t){var f=n.select(this),m=t[0],y=m.trace;!function(e){var t,r,n,i=e[0],o=i.r,a=i.trace,s=g.getRotationAngle(a.rotation),l=2*Math.PI/i.vTotal,c="px0",u="px1";if("counterclockwise"===a.direction){for(t=0;ti.vTotal/2?1:0,r.halfangle=Math.PI*Math.min(r.v/i.vTotal,.5),r.ring=1-a.hole,r.rInscribed=C(r,i))}(t),f.attr("stroke-linejoin","round"),f.each((function(){var v=n.select(this).selectAll("g.slice").data(t);v.enter().append("g").classed("slice",!0),v.exit().remove();var _=[[[],[]],[[],[]]],k=!1;v.each((function(i,a){if(i.hidden)n.select(this).selectAll("path,g").remove();else{i.pointNumber=i.i,i.curveNumber=y.index,_[i.pxmid[1]<0?0:1][i.pxmid[0]<0?0:1].push(i);var c=m.cx,u=m.cy,h=n.select(this),f=h.selectAll("path.surface").data([i]);if(f.enter().append("path").classed("surface",!0).style({"pointer-events":r?"none":"all"}),h.call(x,e,t),y.pull){var v=+g.castOption(y.pull,i.pts)||0;v>0&&(c+=v*i.pxmid[0],u+=v*i.pxmid[1])}i.cxFinal=c,i.cyFinal=u;var S=y.hole;if(i.v===m.vTotal){var A="M"+(c+i.px0[0])+","+(u+i.px0[1])+P(i.px0,i.pxmid,!0,1)+P(i.pxmid,i.px0,!0,1)+"Z";S?f.attr("d","M"+(c+S*i.px0[0])+","+(u+S*i.px0[1])+P(i.px0,i.pxmid,!1,S)+P(i.pxmid,i.px0,!1,S)+"Z"+A):f.attr("d",A)}else{var T=P(i.px0,i.px1,!0,1);if(S){var M=1-S;f.attr("d","M"+(c+S*i.px1[0])+","+(u+S*i.px1[1])+P(i.px1,i.px0,!1,S)+"l"+M*i.px0[0]+","+M*i.px0[1]+T+"Z")}else f.attr("d","M"+c+","+u+"l"+i.px0[0]+","+i.px0[1]+T+"Z")}D(e,i,m);var C=g.castOption(y.textposition,i.pts),I=h.selectAll("g.slicetext").data(i.text&&"none"!==C?[0]:[]);I.enter().append("g").classed("slicetext",!0),I.exit().remove(),I.each((function(){var r=l.ensureSingle(n.select(this),"text","",(function(e){e.attr("data-notex",1)})),h=l.ensureUniformFontSize(e,"outside"===C?function(e,t,r){var n=g.castOption(e.outsidetextfont.color,t.pts)||g.castOption(e.textfont.color,t.pts)||r.color,i=g.castOption(e.outsidetextfont.family,t.pts)||g.castOption(e.textfont.family,t.pts)||r.family,o=g.castOption(e.outsidetextfont.size,t.pts)||g.castOption(e.textfont.size,t.pts)||r.size,a=g.castOption(e.outsidetextfont.weight,t.pts)||g.castOption(e.textfont.weight,t.pts)||r.weight,s=g.castOption(e.outsidetextfont.style,t.pts)||g.castOption(e.textfont.style,t.pts)||r.style,l=g.castOption(e.outsidetextfont.variant,t.pts)||g.castOption(e.textfont.variant,t.pts)||r.variant,c=g.castOption(e.outsidetextfont.textcase,t.pts)||g.castOption(e.textfont.textcase,t.pts)||r.textcase,u=g.castOption(e.outsidetextfont.lineposition,t.pts)||g.castOption(e.textfont.lineposition,t.pts)||r.lineposition,d=g.castOption(e.outsidetextfont.shadow,t.pts)||g.castOption(e.textfont.shadow,t.pts)||r.shadow;return{color:n,family:i,size:o,weight:a,style:s,variant:l,textcase:c,lineposition:u,shadow:d}}(y,i,o.font):b(y,i,o.font));r.text(i.text).attr({class:"slicetext",transform:"","text-anchor":"middle"}).call(s.font,h).call(d.convertToTspans,e);var f,v=s.bBox(r.node());if("outside"===C)f=E(v,i);else if(f=w(v,i,m),"auto"===C&&f.scale<1){var x=l.ensureUniformFontSize(e,y.outsidetextfont);r.call(s.font,x),f=E(v=s.bBox(r.node()),i)}var _=f.textPosAngle,S=void 0===_?i.pxmid:L(m.r,_);if(f.targetX=c+S[0]*f.rCenter+(f.x||0),f.targetY=u+S[1]*f.rCenter+(f.y||0),z(f,v),f.outside){var A=f.targetY;i.yLabelMin=A-v.height/2,i.yLabelMid=A,i.yLabelMax=A+v.height/2,i.labelExtraX=0,i.labelExtraY=0,k=!0}f.fontSize=h.size,p(y.type,f,o),t[a].transform=f,l.setTransormAndDisplay(r,f)}))}function P(e,t,r,n){var o=n*(t[0]-e[0]),a=n*(t[1]-e[1]);return"a"+n*m.r+","+n*m.r+" 0 "+i.largeArc+(r?" 1 ":" 0 ")+o+","+a}}));var S=n.select(this).selectAll("g.titletext").data(y.title.text?[0]:[]);if(S.enter().append("g").classed("titletext",!0),S.exit().remove(),S.each((function(){var t,r=l.ensureSingle(n.select(this),"text","",(function(e){e.attr("data-notex",1)})),i=y.title.text;y._meta&&(i=l.templateString(i,y._meta)),r.text(i).attr({class:"titletext",transform:"","text-anchor":"middle"}).call(s.font,y.title.font).call(d.convertToTspans,e),t="middle center"===y.title.position?function(e){var t=Math.sqrt(e.titleBox.width*e.titleBox.width+e.titleBox.height*e.titleBox.height);return{x:e.cx,y:e.cy,scale:e.trace.hole*e.r*2/t,tx:0,ty:-e.titleBox.height/2+e.trace.title.font.size}}(m):I(m,h),r.attr("transform",u(t.x,t.y)+c(Math.min(1,t.scale))+u(t.tx,t.ty))})),k&&function(e,t){var r,n,i,o,a,s,c,u,d,h,p,f,m;function y(e,t){return e.pxmid[1]-t.pxmid[1]}function v(e,t){return t.pxmid[1]-e.pxmid[1]}function x(e,r){r||(r={});var i,u,d,p,f=r.labelExtraY+(n?r.yLabelMax:r.yLabelMin),m=n?e.yLabelMin:e.yLabelMax,y=n?e.yLabelMax:e.yLabelMin,v=e.cyFinal+a(e.px0[1],e.px1[1]),x=f-m;if(x*c>0&&(e.labelExtraY=x),l.isArrayOrTypedArray(t.pull))for(u=0;u=(g.castOption(t.pull,d.pts)||0)||((e.pxmid[1]-d.pxmid[1])*c>0?(x=d.cyFinal+a(d.px0[1],d.px1[1])-m-e.labelExtraY)*c>0&&(e.labelExtraY+=x):(y+e.labelExtraY-v)*c>0&&(i=3*s*Math.abs(u-h.indexOf(e)),(p=d.cxFinal+o(d.px0[0],d.px1[0])+i-(e.cxFinal+e.pxmid[0])-e.labelExtraX)*s>0&&(e.labelExtraX+=p)))}for(n=0;n<2;n++)for(i=n?y:v,a=n?Math.max:Math.min,c=n?1:-1,r=0;r<2;r++){for(o=r?Math.max:Math.min,s=r?1:-1,(u=e[n][r]).sort(i),d=e[1-n][r],h=d.concat(u),f=[],p=0;pMath.abs(d)?s+="l"+d*e.pxmid[0]/e.pxmid[1]+","+d+"H"+(o+e.labelExtraX+c):s+="l"+e.labelExtraX+","+u+"v"+(d-u)+"h"+c}else s+="V"+(e.yLabelMid+e.labelExtraY)+"h"+c;l.ensureSingle(r,"path","textline").call(a.stroke,t.outsidetextfont.color).attr({"stroke-width":Math.min(2,t.outsidetextfont.size/8),d:s,fill:"none"})}else r.select("path.textline").remove()}))}(v,y),k&&y.automargin){var A=s.bBox(f.node()),T=y.domain,M=h.w*(T.x[1]-T.x[0]),C=h.h*(T.y[1]-T.y[0]),P=(.5*M-m.r)/h.w,O=(.5*C-m.r)/h.h;i.autoMargin(e,"pie."+y.uid+".automargin",{xl:T.x[0]-P,xr:T.x[1]+P,yb:T.y[0]-O,yt:T.y[1]+O,l:Math.max(m.cx-m.r-A.left,0),r:Math.max(A.right-(m.cx+m.r),0),b:Math.max(A.bottom-(m.cy+m.r),0),t:Math.max(m.cy-m.r-A.top,0),pad:5})}}))}));setTimeout((function(){m.selectAll("tspan").each((function(){var e=n.select(this);e.attr("dy")&&e.attr("dy",e.attr("dy"))}))}),0)},formatSliceLabel:D,transformInsideText:w,determineInsideTextFont:b,positionTitleOutside:I,prerenderTitles:_,layoutAreas:R,attachFxHandlers:x,computeTransform:z}},67775:(e,t,r)=>{"use strict";var n=r(41871),i=r(32100),o=r(35655).resizeText;e.exports=function(e){var t=e._fullLayout._pielayer.selectAll(".trace");o(e,t,"pie"),t.each((function(t){var r=t[0].trace,o=n.select(this);o.style({opacity:r.opacity}),o.selectAll("path.surface").each((function(t){n.select(this).call(i,t,r,e)}))}))}},32100:(e,t,r)=>{"use strict";var n=r(7605),i=r(97367).castOption,o=r(16074);e.exports=function(e,t,r,a){var s=r.marker.line,l=i(s.color,t.pts)||n.defaultLine,c=i(s.width,t.pts)||0;e.call(o,t,r,a).style("stroke-width",c).call(n.stroke,l)}},85126:(e,t,r)=>{"use strict";var n=r(22049);e.exports={x:n.x,y:n.y,xy:{valType:"data_array",editType:"calc",description:["Faster alternative to specifying `x` and `y` separately.","If supplied, it must be a typed `Float32Array` array that","represents points such that `xy[i * 2] = x[i]` and `xy[i * 2 + 1] = y[i]`"].join(" ")},indices:{valType:"data_array",editType:"calc",description:["A sequential value, 0..n, supply it to avoid creating this array inside plotting.","If specified, it must be a typed `Int32Array` array.","Its length must be equal to or greater than the number of points.","For the best performance and memory use, create one large `indices` typed array","that is guaranteed to be at least as long as the largest number of points during","use, and reuse it on each `Plotly.restyle()` call."].join(" ")},xbounds:{valType:"data_array",editType:"calc",description:["Specify `xbounds` in the shape of `[xMin, xMax] to avoid looping through","the `xy` typed array. Use it in conjunction with `xy` and `ybounds` for the performance benefits."].join(" ")},ybounds:{valType:"data_array",editType:"calc",description:["Specify `ybounds` in the shape of `[yMin, yMax] to avoid looping through","the `xy` typed array. Use it in conjunction with `xy` and `xbounds` for the performance benefits."].join(" ")},text:n.text,marker:{color:{valType:"color",arrayOk:!1,editType:"calc",description:["Sets the marker fill color. It accepts a specific color.","If the color is not fully opaque and there are hundreds of thousands","of points, it may cause slower zooming and panning."].join(" ")},opacity:{valType:"number",min:0,max:1,dflt:1,arrayOk:!1,editType:"calc",description:["Sets the marker opacity. The default value is `1` (fully opaque).","If the markers are not fully opaque and there are hundreds of thousands","of points, it may cause slower zooming and panning.","Opacity fades the color even if `blend` is left on `false` even if there","is no translucency effect in that case."].join(" ")},blend:{valType:"boolean",dflt:null,editType:"calc",description:["Determines if colors are blended together for a translucency effect","in case `opacity` is specified as a value less then `1`.","Setting `blend` to `true` reduces zoom/pan","speed if used with large numbers of points."].join(" ")},sizemin:{valType:"number",min:.1,max:2,dflt:.5,editType:"calc",description:["Sets the minimum size (in px) of the rendered marker points, effective when","the `pointcloud` shows a million or more points."].join(" ")},sizemax:{valType:"number",min:.1,dflt:20,editType:"calc",description:["Sets the maximum size (in px) of the rendered marker points.","Effective when the `pointcloud` shows only few points."].join(" ")},border:{color:{valType:"color",arrayOk:!1,editType:"calc",description:["Sets the stroke color. It accepts a specific color.","If the color is not fully opaque and there are hundreds of thousands","of points, it may cause slower zooming and panning."].join(" ")},arearatio:{valType:"number",min:0,max:1,dflt:0,editType:"calc",description:["Specifies what fraction of the marker area is covered with the","border."].join(" ")},editType:"calc"},editType:"calc"},transforms:void 0}},43856:(e,t,r)=>{"use strict";var n=r(76107).gl_pointcloud2d,i=r(84468).isArrayOrTypedArray,o=r(79689),a=r(49618).findExtremes,s=r(58864);function l(e,t){this.scene=e,this.uid=t,this.type="pointcloud",this.pickXData=[],this.pickYData=[],this.xData=[],this.yData=[],this.textLabels=[],this.color="rgb(0, 0, 0)",this.name="",this.hoverinfo="all",this.idToIndex=new Int32Array(0),this.bounds=[0,0,0,0],this.pointcloudOptions={positions:new Float32Array(0),idToIndex:this.idToIndex,sizemin:.5,sizemax:12,color:[0,0,0,1],areaRatio:1,borderColor:[0,0,0,1]},this.pointcloud=n(e.glplot,this.pointcloudOptions),this.pointcloud._trace=this}var c=l.prototype;c.handlePick=function(e){var t=this.idToIndex[e.pointId];return{trace:this,dataCoord:e.dataCoord,traceCoord:this.pickXYData?[this.pickXYData[2*t],this.pickXYData[2*t+1]]:[this.pickXData[t],this.pickYData[t]],textLabel:i(this.textLabels)?this.textLabels[t]:this.textLabels,color:this.color,name:this.name,pointIndex:t,hoverinfo:this.hoverinfo}},c.update=function(e){this.index=e.index,this.textLabels=e.text,this.name=e.name,this.hoverinfo=e.hoverinfo,this.bounds=[1/0,1/0,-1/0,-1/0],this.updateFast(e),this.color=s(e,{})},c.updateFast=function(e){var t,r,n,i,s,l,c=this.xData=this.pickXData=e.x,u=this.yData=this.pickYData=e.y,d=this.pickXYData=e.xy,h=e.xbounds&&e.ybounds,p=e.indices,f=this.bounds;if(d){if(n=d,t=d.length>>>1,h)f[0]=e.xbounds[0],f[2]=e.xbounds[1],f[1]=e.ybounds[0],f[3]=e.ybounds[1];else for(l=0;lf[2]&&(f[2]=i),sf[3]&&(f[3]=s);if(p)r=p;else for(r=new Int32Array(t),l=0;lf[2]&&(f[2]=i),sf[3]&&(f[3]=s);this.idToIndex=r,this.pointcloudOptions.idToIndex=r,this.pointcloudOptions.positions=n;var m=o(e.marker.color),g=o(e.marker.border.color),y=e.opacity*e.marker.opacity;m[3]*=y,this.pointcloudOptions.color=m;var v=e.marker.blend;if(null===v){v=c.length<100||u.length<100}this.pointcloudOptions.blend=v,g[3]*=y,this.pointcloudOptions.borderColor=g;var x=e.marker.sizemin,b=Math.max(e.marker.sizemax,e.marker.sizemin);this.pointcloudOptions.sizeMin=x,this.pointcloudOptions.sizeMax=b,this.pointcloudOptions.areaRatio=e.marker.border.arearatio,this.pointcloud.update(this.pointcloudOptions);var _=this.scene.xaxis,w=this.scene.yaxis,k=b/2||.5;e._extremes[_._id]=a(_,[f[0],f[2]],{ppad:k}),e._extremes[w._id]=a(w,[f[1],f[3]],{ppad:k})},c.dispose=function(){this.pointcloud.dispose()},e.exports=function(e,t){var r=new l(e,t.uid);return r.update(t),r}},40433:(e,t,r)=>{"use strict";var n=r(84468),i=r(85126);e.exports=function(e,t,r){function o(r,o){return n.coerce(e,t,i,r,o)}o("x"),o("y"),o("xbounds"),o("ybounds"),e.xy&&e.xy instanceof Float32Array&&(t.xy=e.xy),e.indices&&e.indices instanceof Int32Array&&(t.indices=e.indices),o("text"),o("marker.color",r),o("marker.opacity"),o("marker.blend"),o("marker.sizemin"),o("marker.sizemax"),o("marker.border.color",r),o("marker.border.arearatio"),t._length=null}},93975:(e,t,r)=>{"use strict";var n=["*pointcloud* trace is deprecated!","Please consider switching to the *scattergl* trace type."].join(" ");e.exports={attributes:r(85126),supplyDefaults:r(40433),calc:r(2356),plot:r(43856),moduleType:"trace",name:"pointcloud",basePlotModule:r(84017),categories:["gl","gl2d","showLegend"],meta:{description:[n,"The data visualized as a point cloud set in `x` and `y`","using the WebGl plotting engine."].join(" ")}}},25820:(e,t,r)=>{"use strict";var n=r(91740),i=r(75622),o=r(17992),a=r(25087),s=r(81159).u,l=r(84425).rb,c=r(6636),u=r(37091).templatedArray,d=r(39363).descriptionOnlyNumbers,h=r(64022).extendFlat,p=r(72587).overrideAll;(e.exports=p({hoverinfo:h({},i.hoverinfo,{flags:[],arrayOk:!1,description:["Determines which trace information appear on hover.","If `none` or `skip` are set, no information is displayed upon hovering.","But, if `none` is set, click and hover events are still fired.","Note that this attribute is superseded by `node.hoverinfo` and `node.hoverinfo`","for nodes and links respectively."].join(" ")}),hoverlabel:a.hoverlabel,domain:s({name:"sankey",trace:!0}),orientation:{valType:"enumerated",values:["v","h"],dflt:"h",description:"Sets the orientation of the Sankey diagram."},valueformat:{valType:"string",dflt:".3s",description:d("value")},valuesuffix:{valType:"string",dflt:"",description:["Adds a unit to follow the value in the hover tooltip. Add a space if a separation","is necessary from the value."].join(" ")},arrangement:{valType:"enumerated",values:["snap","perpendicular","freeform","fixed"],dflt:"snap",description:["If value is `snap` (the default), the node arrangement is assisted by automatic snapping of elements to","preserve space between nodes specified via `nodepad`.","If value is `perpendicular`, the nodes can only move along a line perpendicular to the flow.","If value is `freeform`, the nodes can freely move on the plane.","If value is `fixed`, the nodes are stationary."].join(" ")},textfont:n({autoShadowDflt:!0,description:"Sets the font for node labels"}),customdata:void 0,node:{label:{valType:"data_array",dflt:[],description:"The shown name of the node."},groups:{valType:"info_array",impliedEdits:{x:[],y:[]},dimensions:2,freeLength:!0,dflt:[],items:{valType:"number",editType:"calc"},description:["Groups of nodes.","Each group is defined by an array with the indices of the nodes it contains.","Multiple groups can be specified."].join(" ")},x:{valType:"data_array",dflt:[],description:"The normalized horizontal position of the node."},y:{valType:"data_array",dflt:[],description:"The normalized vertical position of the node."},color:{valType:"color",arrayOk:!0,description:["Sets the `node` color. It can be a single value, or an array for specifying color for each `node`.","If `node.color` is omitted, then the default `Plotly` color palette will be cycled through","to have a variety of colors. These defaults are not fully opaque, to allow some visibility of","what is beneath the node."].join(" ")},customdata:{valType:"data_array",editType:"calc",description:["Assigns extra data to each node."].join(" ")},line:{color:{valType:"color",dflt:o.defaultLine,arrayOk:!0,description:["Sets the color of the `line` around each `node`."].join(" ")},width:{valType:"number",min:0,dflt:.5,arrayOk:!0,description:["Sets the width (in px) of the `line` around each `node`."].join(" ")}},pad:{valType:"number",arrayOk:!1,min:0,dflt:20,description:"Sets the padding (in px) between the `nodes`."},thickness:{valType:"number",arrayOk:!1,min:1,dflt:20,description:"Sets the thickness (in px) of the `nodes`."},hoverinfo:{valType:"enumerated",values:["all","none","skip"],dflt:"all",description:["Determines which trace information appear when hovering nodes.","If `none` or `skip` are set, no information is displayed upon hovering.","But, if `none` is set, click and hover events are still fired."].join(" ")},hoverlabel:a.hoverlabel,hovertemplate:l({},{description:"Variables `sourceLinks` and `targetLinks` are arrays of link objects.",keys:["value","label"]}),align:{valType:"enumerated",values:["justify","left","right","center"],dflt:"justify",description:"Sets the alignment method used to position the nodes along the horizontal axis."},description:"The nodes of the Sankey plot."},link:{arrowlen:{valType:"number",min:0,dflt:0,description:["Sets the length (in px) of the links arrow, if 0 no arrow will be drawn."].join(" ")},label:{valType:"data_array",dflt:[],description:"The shown name of the link."},color:{valType:"color",arrayOk:!0,description:["Sets the `link` color. It can be a single value, or an array for specifying color for each `link`.","If `link.color` is omitted, then by default, a translucent grey link will be used."].join(" ")},hovercolor:{valType:"color",arrayOk:!0,description:["Sets the `link` hover color. It can be a single value, or an array for specifying hover colors for","each `link`. If `link.hovercolor` is omitted, then by default, links will become slightly more","opaque when hovered over."].join(" ")},customdata:{valType:"data_array",editType:"calc",description:["Assigns extra data to each link."].join(" ")},line:{color:{valType:"color",dflt:o.defaultLine,arrayOk:!0,description:["Sets the color of the `line` around each `link`."].join(" ")},width:{valType:"number",min:0,dflt:0,arrayOk:!0,description:["Sets the width (in px) of the `line` around each `link`."].join(" ")}},source:{valType:"data_array",dflt:[],description:"An integer number `[0..nodes.length - 1]` that represents the source node."},target:{valType:"data_array",dflt:[],description:"An integer number `[0..nodes.length - 1]` that represents the target node."},value:{valType:"data_array",dflt:[],description:"A numeric value representing the flow volume value."},hoverinfo:{valType:"enumerated",values:["all","none","skip"],dflt:"all",description:["Determines which trace information appear when hovering links.","If `none` or `skip` are set, no information is displayed upon hovering.","But, if `none` is set, click and hover events are still fired."].join(" ")},hoverlabel:a.hoverlabel,hovertemplate:l({},{description:"Variables `source` and `target` are node objects.",keys:["value","label"]}),colorscales:u("concentrationscales",{editType:"calc",label:{valType:"string",editType:"calc",description:"The label of the links to color based on their concentration within a flow.",dflt:""},cmax:{valType:"number",editType:"calc",dflt:1,description:"Sets the upper bound of the color domain."},cmin:{valType:"number",editType:"calc",dflt:0,description:"Sets the lower bound of the color domain."},colorscale:h(c().colorscale,{dflt:[[0,"white"],[1,"black"]]})}),description:"The links of the Sankey plot."}},"calc","nested")).transforms=void 0},88108:(e,t,r)=>{"use strict";var n=r(72587).overrideAll,i=r(50246).eV,o=r(54830),a=r(97174),s=r(29454),l=r(25732),c=r(76789).prepSelect,u=r(84468),d=r(38361),h="sankey";function p(e,t){var r=e._fullData[t],n=e._fullLayout,i=n.dragmode,o="pan"===n.dragmode?"move":"crosshair",a=r._bgRect;if(a&&"pan"!==i&&"zoom"!==i){s(a,o);var h={_id:"x",c2p:u.identity,_offset:r._sankey.translateX,_length:r._sankey.width},p={_id:"y",c2p:u.identity,_offset:r._sankey.translateY,_length:r._sankey.height},f={gd:e,element:a.node(),plotinfo:{id:t,xaxis:h,yaxis:p,fillRangeItems:u.noop},subplot:t,xaxes:[h],yaxes:[p],doneFnCompleted:function(r){var n,i=e._fullData[t],o=i.node.groups.slice(),a=[];function s(e){for(var t=i._sankey.graph.nodes,r=0;r{"use strict";var n=r(76330),i=r(84468),o=r(85876).wrap,a=i.isArrayOrTypedArray,s=i.isIndex,l=r(39265);function c(e){var t,r=e.node,o=e.link,c=[],u=a(o.color),d=a(o.hovercolor),h=a(o.customdata),p={},f={},m=o.colorscales.length;for(t=0;tx&&(x=o.source[t]),o.target[t]>x&&(x=o.target[t]);var b,_=x+1;e.node._count=_;var w=e.node.groups,k={};for(t=0;t0&&s(E,_)&&s(I,_)&&(!k.hasOwnProperty(E)||!k.hasOwnProperty(I)||k[E]!==k[I])){k.hasOwnProperty(I)&&(I=k[I]),k.hasOwnProperty(E)&&(E=k[E]),I=+I,p[E=+E]=p[I]=!0;var P="";o.label&&o.label[t]&&(P=o.label[t]);var O=null;P&&f.hasOwnProperty(P)&&(O=f[P]),c.push({pointNumber:t,label:P,color:u?o.color[t]:o.color,hovercolor:d?o.hovercolor[t]:o.hovercolor,customdata:h?o.customdata[t]:o.customdata,concentrationscale:O,source:E,target:I,value:+C}),M.source.push(E),M.target.push(I)}}var R=_+w.length,L=a(r.color),D=a(r.customdata),z=[];for(t=0;t_-1,childrenNodes:[],pointNumber:t,label:j,color:L?r.color[t]:r.color,customdata:D?r.customdata[t]:r.customdata})}var F=!1;return function(e,t,r){for(var o=i.init2dArray(e,0),a=0;a1}))}(R,M.source,M.target)&&(F=!0),{circular:F,links:c,nodes:z,groups:w,groupLookup:k}}e.exports=function(e,t){var r=c(t);return o({circular:r.circular,_nodes:r.nodes,_links:r.links,_groups:r.groups,_groupLookup:r.groupLookup})}},48248:e=>{"use strict";e.exports={nodeTextOffsetHorizontal:4,nodeTextOffsetVertical:3,nodePadAcross:10,sankeyIterations:50,forceIterations:5,forceTicksPerFrame:10,duration:500,ease:"linear",cn:{sankey:"sankey",sankeyLinks:"sankey-links",sankeyLink:"sankey-link",sankeyNodeSet:"sankey-node-set",sankeyNode:"sankey-node",nodeRect:"node-rect",nodeLabel:"node-label"}}},63787:(e,t,r)=>{"use strict";var n=r(84468),i=r(25820),o=r(7605),a=r(23498),s=r(81159).N,l=r(15171),c=r(37091),u=r(38851);function d(e,t){function r(r,o){return n.coerce(e,t,i.link.colorscales,r,o)}r("label"),r("cmin"),r("cmax"),r("colorscale")}e.exports=function(e,t,r,h){function p(r,o){return n.coerce(e,t,i,r,o)}var f=n.extendDeep(h.hoverlabel,e.hoverlabel),m=e.node,g=c.newContainer(t,"node");function y(e,t){return n.coerce(m,g,i.node,e,t)}y("label"),y("groups"),y("x"),y("y"),y("pad"),y("thickness"),y("line.color"),y("line.width"),y("hoverinfo",e.hoverinfo),l(m,g,y,f),y("hovertemplate"),y("align");var v=h.colorway;y("color",g.label.map((function(e,t){return o.addOpacity(function(e){return v[e%v.length]}(t),.8)}))),y("customdata");var x=e.link||{},b=c.newContainer(t,"link");function _(e,t){return n.coerce(x,b,i.link,e,t)}_("label"),_("arrowlen"),_("source"),_("target"),_("value"),_("line.color"),_("line.width"),_("hoverinfo",e.hoverinfo),l(x,b,_,f),_("hovertemplate");var w,k=a(h.paper_bgcolor).getLuminance()<.333,S=_("color",k?"rgba(255, 255, 255, 0.6)":"rgba(0, 0, 0, 0.2)");function A(e){var t=a(e);if(!t.isValid())return e;var r=t.getAlpha();return r<=.8?t.setAlpha(r+.2):t=k?t.brighten():t.darken(),t.toRgbString()}_("hovercolor",Array.isArray(S)?S.map(A):A(S)),_("customdata"),u(x,b,{name:"colorscales",handleItemDefaults:d}),s(t,h,p),p("orientation"),p("valueformat"),p("valuesuffix"),g.x.length&&g.y.length&&(w="freeform"),p("arrangement",w),n.coerceFont(p,"textfont",h.font,{autoShadowDflt:!0}),t._length=null}},12593:(e,t,r)=>{"use strict";e.exports={attributes:r(25820),supplyDefaults:r(63787),calc:r(77596),plot:r(54830),moduleType:"trace",name:"sankey",basePlotModule:r(88108),selectPoints:r(8125),categories:["noOpacity"],meta:{description:["Sankey plots for network flow data analysis.","The nodes are specified in `nodes` and the links between sources and targets in `links`.","The colors are set in `nodes[i].color` and `links[i].color`, otherwise defaults are used."].join(" ")}}},54830:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468),o=i.numberFormat,a=r(34817),s=r(32212),l=r(7605),c=r(48248).cn,u=i._;function d(e){return""!==e}function h(e,t){return e.filter((function(e){return e.key===t.traceId}))}function p(e,t){n.select(e).select("path").style("fill-opacity",t),n.select(e).select("rect").style("fill-opacity",t)}function f(e){n.select(e).select("text.name").style("fill","black")}function m(e){return function(t){return-1!==e.node.sourceLinks.indexOf(t.link)||-1!==e.node.targetLinks.indexOf(t.link)}}function g(e){return function(t){return-1!==t.node.sourceLinks.indexOf(e.link)||-1!==t.node.targetLinks.indexOf(e.link)}}function y(e,t,r){t&&r&&h(r,t).selectAll("."+c.sankeyLink).filter(m(t)).call(x.bind(0,t,r,!1))}function v(e,t,r){t&&r&&h(r,t).selectAll("."+c.sankeyLink).filter(m(t)).call(b.bind(0,t,r,!1))}function x(e,t,r,n){n.style("fill",(function(e){if(!e.link.concentrationscale)return e.tinyColorHoverHue})).style("fill-opacity",(function(e){if(!e.link.concentrationscale)return e.tinyColorHoverAlpha})),n.each((function(r){var n=r.link.label;""!==n&&h(t,e).selectAll("."+c.sankeyLink).filter((function(e){return e.link.label===n})).style("fill",(function(e){if(!e.link.concentrationscale)return e.tinyColorHoverHue})).style("fill-opacity",(function(e){if(!e.link.concentrationscale)return e.tinyColorHoverAlpha}))})),r&&h(t,e).selectAll("."+c.sankeyNode).filter(g(e)).call(y)}function b(e,t,r,n){n.style("fill",(function(e){return e.tinyColorHue})).style("fill-opacity",(function(e){return e.tinyColorAlpha})),n.each((function(r){var n=r.link.label;""!==n&&h(t,e).selectAll("."+c.sankeyLink).filter((function(e){return e.link.label===n})).style("fill",(function(e){return e.tinyColorHue})).style("fill-opacity",(function(e){return e.tinyColorAlpha}))})),r&&h(t,e).selectAll(c.sankeyNode).filter(g(e)).call(v)}function _(e,t){var r=e.hoverlabel||{},n=i.nestedProperty(r,t).get();return!Array.isArray(n)&&n}e.exports=function(e,t){for(var r=e._fullLayout,i=r._paper,h=r._size,m=0;m"),color:_(a,"bgcolor")||l.addOpacity(m.color,1),borderColor:_(a,"bordercolor"),fontFamily:_(a,"font.family"),fontSize:_(a,"font.size"),fontColor:_(a,"font.color"),fontWeight:_(a,"font.weight"),fontStyle:_(a,"font.style"),fontVariant:_(a,"font.variant"),fontTextcase:_(a,"font.textcase"),fontLineposition:_(a,"font.lineposition"),fontShadow:_(a,"font.shadow"),nameLength:_(a,"namelength"),textAlign:_(a,"align"),idealAlign:n.event.x"),color:_(a,"bgcolor")||i.tinyColorHue,borderColor:_(a,"bordercolor"),fontFamily:_(a,"font.family"),fontSize:_(a,"font.size"),fontColor:_(a,"font.color"),fontWeight:_(a,"font.weight"),fontStyle:_(a,"font.style"),fontVariant:_(a,"font.variant"),fontTextcase:_(a,"font.textcase"),fontLineposition:_(a,"font.lineposition"),fontShadow:_(a,"font.shadow"),nameLength:_(a,"namelength"),textAlign:_(a,"align"),idealAlign:"left",hovertemplate:a.hovertemplate,hovertemplateLabels:v,eventData:[i.node]},{container:r._hoverlayer.node(),outerContainer:r._paper.node(),gd:e});p(w,.85),f(w)}}},unhover:function(t,i,o){!1!==e._fullLayout.hovermode&&(n.select(t).call(v,i,o),"skip"!==i.node.trace.node.hoverinfo&&(i.node.fullData=i.node.trace,e.emit("plotly_unhover",{event:n.event,points:[i.node]})),s.loneUnhover(r._hoverlayer.node()))},select:function(t,r,i){var o=r.node;o.originalEvent=n.event,e._hoverdata=[o],n.select(t).call(v,r,i),s.click(e,{target:!0})}}})}},34817:(e,t,r)=>{"use strict";var n=r(58479),i=r(70359).Dj,o=r(41871),a=r(40293),s=r(33428),l=r(48248),c=r(23498),u=r(7605),d=r(3172),h=r(84468),p=h.strTranslate,f=h.strRotate,m=r(85876),g=m.keyFun,y=m.repeat,v=m.unwrap,x=r(13480),b=r(38361),_=r(83943),w=_.CAP_SHIFT,k=_.LINE_SPACING;function S(e,t,r){var n,i=v(t),o=i.trace,u=o.domain,d="h"===o.orientation,p=o.node.pad,f=o.node.thickness,m={justify:a.sankeyJustify,left:a.sankeyLeft,right:a.sankeyRight,center:a.sankeyCenter}[o.node.align],g=e.width*(u.x[1]-u.x[0]),y=e.height*(u.y[1]-u.y[0]),x=i._nodes,b=i._links,_=i.circular;(n=_?s.sankeyCircular().circularLinkGap(0):a.sankey()).iterations(l.sankeyIterations).size(d?[g,y]:[y,g]).nodeWidth(f).nodePadding(p).nodeId((function(e){return e.pointNumber})).nodeAlign(m).nodes(x).links(b);var w,k,S,A=n();for(var T in n.nodePadding()=i||(r=i-t.y0)>1e-6&&(t.y0+=r,t.y1+=r),i=t.y1+p}))}(function(e){var t,r,n=e.map((function(e,t){return{x0:e.x0,index:t}})).sort((function(e,t){return e.x0-t.x0})),i=[],o=-1,a=-1/0;for(w=0;wa+f&&(o+=1,t=s.x0),a=s.x0,i[o]||(i[o]=[]),i[o].push(s),r=t-s.x0,s.x0+=r,s.x1+=r}return i}(x=A.nodes));n.update(A)}return{circular:_,key:r,trace:o,guid:h.randstr(),horizontal:d,width:g,height:y,nodePad:o.node.pad,nodeLineColor:o.node.line.color,nodeLineWidth:o.node.line.width,linkLineColor:o.link.line.color,linkLineWidth:o.link.line.width,linkArrowLength:o.link.arrowlen,valueFormat:o.valueformat,valueSuffix:o.valuesuffix,textFont:o.textfont,translateX:u.x[0]*e.width+e.margin.l,translateY:e.height-u.y[1]*e.height+e.margin.t,dragParallel:d?y:g,dragPerpendicular:d?g:y,arrangement:o.arrangement,sankey:n,graph:A,forceLayouts:{},interactionState:{dragInProgress:!1,hovered:!1}}}function A(e,t,r){var n=c(t.color),i=c(t.hovercolor),o=t.source.label+"|"+t.target.label+"__"+r;return t.trace=e.trace,t.curveNumber=e.trace.index,{circular:e.circular,key:o,traceId:e.key,pointNumber:t.pointNumber,link:t,tinyColorHue:u.tinyRGB(n),tinyColorAlpha:n.getAlpha(),tinyColorHoverHue:u.tinyRGB(i),tinyColorHoverAlpha:i.getAlpha(),linkPath:T,linkLineColor:e.linkLineColor,linkLineWidth:e.linkLineWidth,linkArrowLength:e.linkArrowLength,valueFormat:e.valueFormat,valueSuffix:e.valueSuffix,sankey:e.sankey,parent:e,interactionState:e.interactionState,flow:t.flow}}function T(){return function(e){var t=e.linkArrowLength;if(e.link.circular)return function(e,t){var r=e.width/2,n=e.circularPathData;return"top"===e.circularLinkType?"M "+(n.targetX-t)+" "+(n.targetY+r)+" L"+(n.rightInnerExtent-t)+" "+(n.targetY+r)+"A"+(n.rightLargeArcRadius+r)+" "+(n.rightSmallArcRadius+r)+" 0 0 1 "+(n.rightFullExtent-r-t)+" "+(n.targetY-n.rightSmallArcRadius)+"L"+(n.rightFullExtent-r-t)+" "+n.verticalRightInnerExtent+"A"+(n.rightLargeArcRadius+r)+" "+(n.rightLargeArcRadius+r)+" 0 0 1 "+(n.rightInnerExtent-t)+" "+(n.verticalFullExtent-r)+"L"+n.leftInnerExtent+" "+(n.verticalFullExtent-r)+"A"+(n.leftLargeArcRadius+r)+" "+(n.leftLargeArcRadius+r)+" 0 0 1 "+(n.leftFullExtent+r)+" "+n.verticalLeftInnerExtent+"L"+(n.leftFullExtent+r)+" "+(n.sourceY-n.leftSmallArcRadius)+"A"+(n.leftLargeArcRadius+r)+" "+(n.leftSmallArcRadius+r)+" 0 0 1 "+n.leftInnerExtent+" "+(n.sourceY+r)+"L"+n.sourceX+" "+(n.sourceY+r)+"L"+n.sourceX+" "+(n.sourceY-r)+"L"+n.leftInnerExtent+" "+(n.sourceY-r)+"A"+(n.leftLargeArcRadius-r)+" "+(n.leftSmallArcRadius-r)+" 0 0 0 "+(n.leftFullExtent-r)+" "+(n.sourceY-n.leftSmallArcRadius)+"L"+(n.leftFullExtent-r)+" "+n.verticalLeftInnerExtent+"A"+(n.leftLargeArcRadius-r)+" "+(n.leftLargeArcRadius-r)+" 0 0 0 "+n.leftInnerExtent+" "+(n.verticalFullExtent+r)+"L"+(n.rightInnerExtent-t)+" "+(n.verticalFullExtent+r)+"A"+(n.rightLargeArcRadius-r)+" "+(n.rightLargeArcRadius-r)+" 0 0 0 "+(n.rightFullExtent+r-t)+" "+n.verticalRightInnerExtent+"L"+(n.rightFullExtent+r-t)+" "+(n.targetY-n.rightSmallArcRadius)+"A"+(n.rightLargeArcRadius-r)+" "+(n.rightSmallArcRadius-r)+" 0 0 0 "+(n.rightInnerExtent-t)+" "+(n.targetY-r)+"L"+(n.targetX-t)+" "+(n.targetY-r)+(t>0?"L"+n.targetX+" "+n.targetY:"")+"Z":"M "+(n.targetX-t)+" "+(n.targetY-r)+" L"+(n.rightInnerExtent-t)+" "+(n.targetY-r)+"A"+(n.rightLargeArcRadius+r)+" "+(n.rightSmallArcRadius+r)+" 0 0 0 "+(n.rightFullExtent-r-t)+" "+(n.targetY+n.rightSmallArcRadius)+"L"+(n.rightFullExtent-r-t)+" "+n.verticalRightInnerExtent+"A"+(n.rightLargeArcRadius+r)+" "+(n.rightLargeArcRadius+r)+" 0 0 0 "+(n.rightInnerExtent-t)+" "+(n.verticalFullExtent+r)+"L"+n.leftInnerExtent+" "+(n.verticalFullExtent+r)+"A"+(n.leftLargeArcRadius+r)+" "+(n.leftLargeArcRadius+r)+" 0 0 0 "+(n.leftFullExtent+r)+" "+n.verticalLeftInnerExtent+"L"+(n.leftFullExtent+r)+" "+(n.sourceY+n.leftSmallArcRadius)+"A"+(n.leftLargeArcRadius+r)+" "+(n.leftSmallArcRadius+r)+" 0 0 0 "+n.leftInnerExtent+" "+(n.sourceY-r)+"L"+n.sourceX+" "+(n.sourceY-r)+"L"+n.sourceX+" "+(n.sourceY+r)+"L"+n.leftInnerExtent+" "+(n.sourceY+r)+"A"+(n.leftLargeArcRadius-r)+" "+(n.leftSmallArcRadius-r)+" 0 0 1 "+(n.leftFullExtent-r)+" "+(n.sourceY+n.leftSmallArcRadius)+"L"+(n.leftFullExtent-r)+" "+n.verticalLeftInnerExtent+"A"+(n.leftLargeArcRadius-r)+" "+(n.leftLargeArcRadius-r)+" 0 0 1 "+n.leftInnerExtent+" "+(n.verticalFullExtent-r)+"L"+(n.rightInnerExtent-t)+" "+(n.verticalFullExtent-r)+"A"+(n.rightLargeArcRadius-r)+" "+(n.rightLargeArcRadius-r)+" 0 0 1 "+(n.rightFullExtent+r-t)+" "+n.verticalRightInnerExtent+"L"+(n.rightFullExtent+r-t)+" "+(n.targetY+n.rightSmallArcRadius)+"A"+(n.rightLargeArcRadius-r)+" "+(n.rightSmallArcRadius-r)+" 0 0 1 "+(n.rightInnerExtent-t)+" "+(n.targetY+r)+"L"+(n.targetX-t)+" "+(n.targetY+r)+(t>0?"L"+n.targetX+" "+n.targetY:"")+"Z"}(e.link,t);var r=Math.abs((e.link.target.x0-e.link.source.x1)/2);t>r&&(t=r);var n=e.link.source.x1,o=e.link.target.x0-t,a=i(n,o),s=a(.5),l=a(.5),c=e.link.y0-e.link.width/2,u=e.link.y0+e.link.width/2,d=e.link.y1-e.link.width/2,h=e.link.y1+e.link.width/2,p="M"+n+","+c,f="C"+s+","+c+" "+l+","+d+" "+o+","+d,m="C"+l+","+h+" "+s+","+u+" "+n+","+u,g=t>0?"L"+(o+t)+","+(d+e.link.width/2):"";return p+f+(g+="L"+o+","+h)+m+"Z"}}function M(e,t){var r=c(t.color),n=l.nodePadAcross,i=e.nodePad/2;t.dx=t.x1-t.x0,t.dy=t.y1-t.y0;var o=t.dx,a=Math.max(.5,t.dy),s="node_"+t.pointNumber;return t.group&&(s=h.randstr()),t.trace=e.trace,t.curveNumber=e.trace.index,{index:t.pointNumber,key:s,partOfGroup:t.partOfGroup||!1,group:t.group,traceId:e.key,trace:e.trace,node:t,nodePad:e.nodePad,nodeLineColor:e.nodeLineColor,nodeLineWidth:e.nodeLineWidth,textFont:e.textFont,size:e.horizontal?e.height:e.width,visibleWidth:Math.ceil(o),visibleHeight:a,zoneX:-n,zoneY:-i,zoneWidth:o+2*n,zoneHeight:a+2*i,labelY:e.horizontal?t.dy/2+1:t.dx/2+1,left:1===t.originalLayer,sizeAcross:e.width,forceLayouts:e.forceLayouts,horizontal:e.horizontal,darkBackground:r.getBrightness()<=128,tinyColorHue:u.tinyRGB(r),tinyColorAlpha:r.getAlpha(),valueFormat:e.valueFormat,valueSuffix:e.valueSuffix,sankey:e.sankey,graph:e.graph,arrangement:e.arrangement,uniqueNodeLabelPathId:[e.guid,e.key,s].join("_"),interactionState:e.interactionState,figure:e}}function C(e){e.attr("transform",(function(e){return p(e.node.x0.toFixed(3),e.node.y0.toFixed(3))}))}function E(e){e.call(C)}function I(e,t){e.call(E),t.attr("d",T())}function P(e){e.attr("width",(function(e){return e.node.x1-e.node.x0})).attr("height",(function(e){return e.visibleHeight}))}function O(e){return e.link.width>1||e.linkLineWidth>0}function R(e){return p(e.translateX,e.translateY)+(e.horizontal?"matrix(1 0 0 1 0 0)":"matrix(0 1 1 0 0 0)")}function L(e,t,r){e.on(".basic",null).on("mouseover.basic",(function(e){e.interactionState.dragInProgress||e.partOfGroup||(r.hover(this,e,t),e.interactionState.hovered=[this,e])})).on("mousemove.basic",(function(e){e.interactionState.dragInProgress||e.partOfGroup||(r.follow(this,e),e.interactionState.hovered=[this,e])})).on("mouseout.basic",(function(e){e.interactionState.dragInProgress||e.partOfGroup||(r.unhover(this,e,t),e.interactionState.hovered=!1)})).on("click.basic",(function(e){e.interactionState.hovered&&(r.unhover(this,e,t),e.interactionState.hovered=!1),e.interactionState.dragInProgress||e.partOfGroup||r.select(this,e,t)}))}function D(e,t,r,i){var a=o.behavior.drag().origin((function(e){return{x:e.node.x0+e.visibleWidth/2,y:e.node.y0+e.visibleHeight/2}})).on("dragstart",(function(o){if("fixed"!==o.arrangement&&(h.ensureSingle(i._fullLayout._infolayer,"g","dragcover",(function(e){i._fullLayout._dragCover=e})),h.raiseToTop(this),o.interactionState.dragInProgress=o.node,j(o.node),o.interactionState.hovered&&(r.nodeEvents.unhover.apply(0,o.interactionState.hovered),o.interactionState.hovered=!1),"snap"===o.arrangement)){var a=o.traceId+"|"+o.key;o.forceLayouts[a]?o.forceLayouts[a].alpha(1):function(e,t,r){!function(e){for(var t=0;t0&&n.forceLayouts[t].alpha(0)}}(0,t,i,r)).stop()}(0,a,o),function(e,t,r,n,i){window.requestAnimationFrame((function o(){var a;for(a=0;a0)window.requestAnimationFrame(o);else{var s=r.node.originalX;r.node.x0=s-r.visibleWidth/2,r.node.x1=s+r.visibleWidth/2,z(r,i)}}))}(e,t,o,a,i)}})).on("drag",(function(r){if("fixed"!==r.arrangement){var n=o.event.x,i=o.event.y;"snap"===r.arrangement?(r.node.x0=n-r.visibleWidth/2,r.node.x1=n+r.visibleWidth/2,r.node.y0=i-r.visibleHeight/2,r.node.y1=i+r.visibleHeight/2):("freeform"===r.arrangement&&(r.node.x0=n-r.visibleWidth/2,r.node.x1=n+r.visibleWidth/2),i=Math.max(0,Math.min(r.size-r.visibleHeight/2,i)),r.node.y0=i-r.visibleHeight/2,r.node.y1=i+r.visibleHeight/2),j(r.node),"snap"!==r.arrangement&&(r.sankey.update(r.graph),I(e.filter(F(r)),t))}})).on("dragend",(function(e){if("fixed"!==e.arrangement){e.interactionState.dragInProgress=!1;for(var t=0;t{"use strict";e.exports=function(e,t){for(var r=[],n=e.cd[0].trace,i=n._sankey.graph.nodes,o=0;o{"use strict";var n=r(84468);e.exports=function(e,t){for(var r=0;r{"use strict";var n=r(39363).axisHoverFormat,i=r(84425).ay,o=r(84425).rb,a=r(6636),s=r(91740),l=r(2703).T,c=r(2703).k,u=r(3172),d=r(56003),h=r(64022).extendFlat,p=r(50821);function f(e){return{valType:"any",dflt:0,editType:"calc",description:["Only relevant when the axis `type` is *date*.","Sets the period positioning in milliseconds or *M* on the "+e+" axis.","Special values in the form of *M* could be used to declare","the number of months. In this case `n` must be a positive integer."].join(" ")}}function m(e){return{valType:"any",editType:"calc",description:["Only relevant when the axis `type` is *date*.","Sets the base for period positioning in milliseconds or date string on the "+e+" axis.","When `"+e+"period` is round number of weeks,","the `"+e+"period0` by default would be on a Sunday i.e. 2000-01-02,","otherwise it would be at 2000-01-01."].join(" ")}}function g(e){return{valType:"enumerated",values:["start","middle","end"],dflt:"middle",editType:"calc",description:["Only relevant when the axis `type` is *date*.","Sets the alignment of data points on the "+e+" axis."].join(" ")}}e.exports={x:{valType:"data_array",editType:"calc+clearAxisTypes",anim:!0,description:"Sets the x coordinates."},x0:{valType:"any",dflt:0,editType:"calc+clearAxisTypes",anim:!0,description:["Alternate to `x`.","Builds a linear space of x coordinates.","Use with `dx`","where `x0` is the starting coordinate and `dx` the step."].join(" ")},dx:{valType:"number",dflt:1,editType:"calc",anim:!0,description:["Sets the x coordinate step.","See `x0` for more info."].join(" ")},y:{valType:"data_array",editType:"calc+clearAxisTypes",anim:!0,description:"Sets the y coordinates."},y0:{valType:"any",dflt:0,editType:"calc+clearAxisTypes",anim:!0,description:["Alternate to `y`.","Builds a linear space of y coordinates.","Use with `dy`","where `y0` is the starting coordinate and `dy` the step."].join(" ")},dy:{valType:"number",dflt:1,editType:"calc",anim:!0,description:["Sets the y coordinate step.","See `y0` for more info."].join(" ")},xperiod:f("x"),yperiod:f("y"),xperiod0:m("x0"),yperiod0:m("y0"),xperiodalignment:g("x"),yperiodalignment:g("y"),xhoverformat:n("x"),yhoverformat:n("y"),offsetgroup:{valType:"string",dflt:"",editType:"calc",description:["Set several traces linked to the same position axis","or matching axes to the same","offsetgroup where bars of the same position coordinate will line up."].join(" ")},alignmentgroup:{valType:"string",dflt:"",editType:"calc",description:["Set several traces linked to the same position axis","or matching axes to the same","alignmentgroup. This controls whether bars compute their positional","range dependently or independently."].join(" ")},stackgroup:{valType:"string",dflt:"",editType:"calc",description:["Set several scatter traces (on the same subplot) to the same","stackgroup in order to add their y values (or their x values if","`orientation` is *h*). If blank or omitted this trace will not be","stacked. Stacking also turns `fill` on by default, using *tonexty*","(*tonextx*) if `orientation` is *h* (*v*) and sets the default","`mode` to *lines* irrespective of point count.","You can only stack on a numeric (linear or log) axis.","Traces in a `stackgroup` will only fill to (or be filled to) other","traces in the same group. With multiple `stackgroup`s or some","traces stacked and some not, if fill-linked traces are not already","consecutive, the later ones will be pushed down in the drawing order."].join(" ")},orientation:{valType:"enumerated",values:["v","h"],editType:"calc",description:["Only relevant in the following cases:","1. when `scattermode` is set to *group*.","2. when `stackgroup` is used, and only the first","`orientation` found in the `stackgroup` will be used - including","if `visible` is *legendonly* but not if it is `false`. Sets the","stacking direction. With *v* (*h*), the y (x) values of subsequent","traces are added. Also affects the default value of `fill`."].join(" ")},groupnorm:{valType:"enumerated",values:["","fraction","percent"],dflt:"",editType:"calc",description:["Only relevant when `stackgroup` is used, and only the first","`groupnorm` found in the `stackgroup` will be used - including","if `visible` is *legendonly* but not if it is `false`.","Sets the normalization for the sum of this `stackgroup`.","With *fraction*, the value of each trace at each location is","divided by the sum of all trace values at that location.","*percent* is the same but multiplied by 100 to show percentages.","If there are multiple subplots, or multiple `stackgroup`s on one","subplot, each will be normalized within its own set."].join(" ")},stackgaps:{valType:"enumerated",values:["infer zero","interpolate"],dflt:"infer zero",editType:"calc",description:["Only relevant when `stackgroup` is used, and only the first","`stackgaps` found in the `stackgroup` will be used - including","if `visible` is *legendonly* but not if it is `false`.","Determines how we handle locations at which other traces in this","group have data but this one does not.","With *infer zero* we insert a zero at these locations.","With *interpolate* we linearly interpolate between existing","values, and extrapolate a constant beyond the existing values."].join(" ")},text:{valType:"string",dflt:"",arrayOk:!0,editType:"calc",description:["Sets text elements associated with each (x,y) pair.","If a single string, the same string appears over","all the data points.","If an array of string, the items are mapped in order to the","this trace's (x,y) coordinates.","If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,","these elements will be seen in the hover labels."].join(" ")},texttemplate:i({},{}),hovertext:{valType:"string",dflt:"",arrayOk:!0,editType:"style",description:["Sets hover text elements associated with each (x,y) pair.","If a single string, the same string appears over","all the data points.","If an array of string, the items are mapped in order to the","this trace's (x,y) coordinates.","To be seen, trace `hoverinfo` must contain a *text* flag."].join(" ")},mode:{valType:"flaglist",flags:["lines","markers","text"],extras:["none"],editType:"calc",description:["Determines the drawing mode for this scatter trace.","If the provided `mode` includes *text* then the `text` elements","appear at the coordinates. Otherwise, the `text` elements","appear on hover.","If there are less than "+d.PTS_LINESONLY+" points","and the trace is not stacked","then the default is *lines+markers*. Otherwise, *lines*."].join(" ")},hoveron:{valType:"flaglist",flags:["points","fills"],editType:"style",description:["Do the hover effects highlight individual points (markers or","line points) or do they highlight filled regions?","If the fill is *toself* or *tonext* and there are no markers","or text, then the default is *fills*, otherwise it is *points*."].join(" ")},hovertemplate:o({},{keys:d.eventDataKeys}),line:{color:{valType:"color",editType:"style",anim:!0,description:"Sets the line color."},width:{valType:"number",min:0,dflt:2,editType:"style",anim:!0,description:"Sets the line width (in px)."},shape:{valType:"enumerated",values:["linear","spline","hv","vh","hvh","vhv"],dflt:"linear",editType:"plot",description:["Determines the line shape.","With *spline* the lines are drawn using spline interpolation.","The other available values correspond to step-wise line shapes."].join(" ")},smoothing:{valType:"number",min:0,max:1.3,dflt:1,editType:"plot",description:["Has an effect only if `shape` is set to *spline*","Sets the amount of smoothing.","*0* corresponds to no smoothing (equivalent to a *linear* shape)."].join(" ")},dash:h({},l,{editType:"style"}),backoff:{valType:"number",min:0,dflt:"auto",arrayOk:!0,editType:"plot",description:["Sets the line back off from the end point of the nth line segment (in px).","This option is useful e.g. to avoid overlap with arrowhead markers.","With *auto* the lines would trim before markers if `marker.angleref` is set to *previous*."].join(" ")},simplify:{valType:"boolean",dflt:!0,editType:"plot",description:["Simplifies lines by removing nearly-collinear points. When transitioning","lines, it may be desirable to disable this so that the number of points","along the resulting SVG path is unaffected."].join(" ")},editType:"plot"},connectgaps:{valType:"boolean",dflt:!1,editType:"calc",description:["Determines whether or not gaps","(i.e. {nan} or missing values)","in the provided data arrays are connected."].join(" ")},cliponaxis:{valType:"boolean",dflt:!0,editType:"plot",description:["Determines whether or not markers and text nodes","are clipped about the subplot axes.","To show markers and text nodes above axis lines and tick labels,","make sure to set `xaxis.layer` and `yaxis.layer` to *below traces*."].join(" ")},fill:{valType:"enumerated",values:["none","tozeroy","tozerox","tonexty","tonextx","toself","tonext"],editType:"calc",description:["Sets the area to fill with a solid color.","Defaults to *none* unless this trace is stacked, then it gets","*tonexty* (*tonextx*) if `orientation` is *v* (*h*)","Use with `fillcolor` if not *none*.","*tozerox* and *tozeroy* fill to x=0 and y=0 respectively.","*tonextx* and *tonexty* fill between the endpoints of this","trace and the endpoints of the trace before it, connecting those","endpoints with straight lines (to make a stacked area graph);","if there is no trace before it, they behave like *tozerox* and","*tozeroy*.","*toself* connects the endpoints of the trace (or each segment","of the trace if it has gaps) into a closed shape.","*tonext* fills the space between two traces if one completely","encloses the other (eg consecutive contour lines), and behaves like","*toself* if there is no trace before it. *tonext* should not be","used if one trace does not enclose the other.","Traces in a `stackgroup` will only fill to (or be filled to) other","traces in the same group. With multiple `stackgroup`s or some","traces stacked and some not, if fill-linked traces are not already","consecutive, the later ones will be pushed down in the drawing order."].join(" ")},fillcolor:p(!0),fillgradient:h({type:{valType:"enumerated",values:["radial","horizontal","vertical","none"],dflt:"none",editType:"calc",description:["Sets the type/orientation of the color gradient for the fill.","Defaults to *none*."].join(" ")},start:{valType:"number",editType:"calc",description:["Sets the gradient start value.","It is given as the absolute position on the axis determined by","the orientiation. E.g., if orientation is *horizontal*, the","gradient will be horizontal and start from the x-position","given by start. If omitted, the gradient starts at the lowest","value of the trace along the respective axis.","Ignored if orientation is *radial*."].join(" ")},stop:{valType:"number",editType:"calc",description:["Sets the gradient end value.","It is given as the absolute position on the axis determined by","the orientiation. E.g., if orientation is *horizontal*, the","gradient will be horizontal and end at the x-position","given by end. If omitted, the gradient ends at the highest","value of the trace along the respective axis.","Ignored if orientation is *radial*."].join(" ")},colorscale:{valType:"colorscale",editType:"style",description:["Sets the fill gradient colors as a color scale.","The color scale is interpreted as a gradient","applied in the direction specified by *orientation*,","from the lowest to the highest value of the scatter","plot along that axis, or from the center to the most","distant point from it, if orientation is *radial*."].join(" ")},editType:"calc",description:["Sets a fill gradient.","If not specified, the fillcolor is used instead."].join(" ")}),fillpattern:c,marker:h({symbol:{valType:"enumerated",values:u.symbolList,dflt:"circle",arrayOk:!0,editType:"style",description:["Sets the marker symbol type.","Adding 100 is equivalent to appending *-open* to a symbol name.","Adding 200 is equivalent to appending *-dot* to a symbol name.","Adding 300 is equivalent to appending *-open-dot*","or *dot-open* to a symbol name."].join(" ")},opacity:{valType:"number",min:0,max:1,arrayOk:!0,editType:"style",anim:!0,description:"Sets the marker opacity."},angle:{valType:"angle",dflt:0,arrayOk:!0,editType:"plot",anim:!1,description:["Sets the marker angle in respect to `angleref`."].join(" ")},angleref:{valType:"enumerated",values:["previous","up"],dflt:"up",editType:"plot",anim:!1,description:["Sets the reference for marker angle.","With *previous*, angle 0 points along the line from the previous point to this one.","With *up*, angle 0 points toward the top of the screen."].join(" ")},standoff:{valType:"number",min:0,dflt:0,arrayOk:!0,editType:"plot",anim:!0,description:["Moves the marker away from the data point in the direction of `angle` (in px).","This can be useful for example if you have another marker at this","location and you want to point an arrowhead marker at it."].join(" ")},size:{valType:"number",min:0,dflt:6,arrayOk:!0,editType:"calc",anim:!0,description:"Sets the marker size (in px)."},maxdisplayed:{valType:"number",min:0,dflt:0,editType:"plot",description:["Sets a maximum number of points to be drawn on the graph.","*0* corresponds to no limit."].join(" ")},sizeref:{valType:"number",dflt:1,editType:"calc",description:["Has an effect only if `marker.size` is set to a numerical array.","Sets the scale factor used to determine the rendered size of","marker points. Use with `sizemin` and `sizemode`."].join(" ")},sizemin:{valType:"number",min:0,dflt:0,editType:"calc",description:["Has an effect only if `marker.size` is set to a numerical array.","Sets the minimum size (in px) of the rendered marker points."].join(" ")},sizemode:{valType:"enumerated",values:["diameter","area"],dflt:"diameter",editType:"calc",description:["Has an effect only if `marker.size` is set to a numerical array.","Sets the rule for which the data in `size` is converted","to pixels."].join(" ")},line:h({width:{valType:"number",min:0,arrayOk:!0,editType:"style",anim:!0,description:"Sets the width (in px) of the lines bounding the marker points."},editType:"calc"},a("marker.line",{anim:!0})),gradient:{type:{valType:"enumerated",values:["radial","horizontal","vertical","none"],arrayOk:!0,dflt:"none",editType:"calc",description:["Sets the type of gradient used to fill the markers"].join(" ")},color:{valType:"color",arrayOk:!0,editType:"calc",description:["Sets the final color of the gradient fill:","the center color for radial, the right for horizontal,","or the bottom for vertical."].join(" ")},editType:"calc"},editType:"calc"},a("marker",{anim:!0})),selected:{marker:{opacity:{valType:"number",min:0,max:1,editType:"style",description:"Sets the marker opacity of selected points."},color:{valType:"color",editType:"style",description:"Sets the marker color of selected points."},size:{valType:"number",min:0,editType:"style",description:"Sets the marker size of selected points."},editType:"style"},textfont:{color:{valType:"color",editType:"style",description:"Sets the text font color of selected points."},editType:"style"},editType:"style"},unselected:{marker:{opacity:{valType:"number",min:0,max:1,editType:"style",description:"Sets the marker opacity of unselected points, applied only when a selection exists."},color:{valType:"color",editType:"style",description:"Sets the marker color of unselected points, applied only when a selection exists."},size:{valType:"number",min:0,editType:"style",description:"Sets the marker size of unselected points, applied only when a selection exists."},editType:"style"},textfont:{color:{valType:"color",editType:"style",description:"Sets the text font color of unselected points, applied only when a selection exists."},editType:"style"},editType:"style"},textposition:{valType:"enumerated",values:["top left","top center","top right","middle left","middle center","middle right","bottom left","bottom center","bottom right"],dflt:"middle center",arrayOk:!0,editType:"calc",description:["Sets the positions of the `text` elements","with respects to the (x,y) coordinates."].join(" ")},textfont:s({editType:"calc",colorEditType:"style",arrayOk:!0,description:"Sets the text font."}),zorder:{valType:"integer",dflt:0,editType:"plot",description:["Sets the layer on which this trace is displayed, relative to","other SVG traces on the same subplot. SVG traces with higher `zorder`","appear in front of those with lower `zorder`."].join(" ")}}},20389:(e,t,r)=>{"use strict";var n=r(22036),i=r(84468),o=r(85729),a=r(35087),s=r(65004).BADNUM,l=r(31811),c=r(85387),u=r(24294),d=r(40304);function h(e,t,r,n,i,a,s){var c=t._length,u=e._fullLayout,d=r._id,h=n._id,p=u._firstScatter[m(t)]===t.uid,f=(g(t,u,r,n)||{}).orientation,y=t.fill;r._minDtick=0,n._minDtick=0;var v={padded:!0},x={padded:!0};s&&(v.ppad=x.ppad=s);var b=c<2||i[0]!==i[c-1]||a[0]!==a[c-1];b&&("tozerox"===y||"tonextx"===y&&(p||"h"===f))?v.tozero=!0:(t.error_y||{}).visible||"tonexty"!==y&&"tozeroy"!==y&&(l.hasMarkers(t)||l.hasText(t))||(v.padded=!1,v.ppad=0),b&&("tozeroy"===y||"tonexty"===y&&(p||"v"===f))?x.tozero=!0:"tonextx"!==y&&"tozerox"!==y||(x.padded=!1),d&&(t._extremes[d]=o.findExtremes(r,i,v)),h&&(t._extremes[h]=o.findExtremes(n,a,x))}function p(e,t){if(l.hasMarkers(e)){var r,n=e.marker,a=1.6*(e.marker.sizeref||1);if(r="area"===e.marker.sizemode?function(e){return Math.max(Math.sqrt((e||0)/a),3)}:function(e){return Math.max((e||0)/a,3)},i.isArrayOrTypedArray(n.size)){var s={type:"linear"};o.setConvert(s);for(var c=s.makeCalcdata(e.marker,"size"),u=new Array(t),d=0;dl&&I[y].gap;)y--;for(x=I[y].s,m=I.length-1;m>y;m--)I[m].s=x;for(;l{"use strict";var n=r(84468);e.exports=function(e,t){n.isArrayOrTypedArray(t.selectedpoints)&&n.tagSelected(e,t)}},85387:(e,t,r)=>{"use strict";var n=r(73084).hasColorscale,i=r(95500),o=r(31811);e.exports=function(e,t){o.hasLines(t)&&n(t,"line")&&i(e,t,{vals:t.line.color,containerStr:"line",cLetter:"c"}),o.hasMarkers(t)&&(n(t,"marker")&&i(e,t,{vals:t.marker.color,containerStr:"marker",cLetter:"c"}),n(t,"marker.line")&&i(e,t,{vals:t.marker.line.color,containerStr:"marker.line",cLetter:"c"}))}},56003:e=>{"use strict";e.exports={PTS_LINESONLY:20,minTolerance:.2,toleranceGrowth:10,maxScreensAway:20,eventDataKeys:[]}},4918:(e,t,r)=>{"use strict";var n=r(20389),i=r(51203).setGroupPositions;function o(e,t,r,n,i,o,a){i[n]=!0;var s={i:null,gap:!0,s:0};if(s[a]=r,e.splice(t,0,s),t&&r===e[t-1][a]){var l=e[t-1];s.s=l.s,s.i=l.i,s.gap=l.gap}else o&&(s.s=function(e,t,r,n){var i=e[t-1],o=e[t+1];return o?i?i.s+(o.s-i.s)*(r-i[n])/(o[n]-i[n]):o.s:i.s}(e,t,r,a));t||(e[0].t=e[1].t,e[0].trace=e[1].trace,delete e[1].t,delete e[1].trace)}e.exports=function(e,t){"group"===e._fullLayout.scattermode&&function(e,t){for(var r=t.xaxis,n=t.yaxis,o=e._fullLayout,a=e._fullData,s=e.calcdata,l=[],c=[],u=0;uM[d]&&d{"use strict";var n=r(84468),i=r(53558),o=r(22049);e.exports=function(e,t){var r,a,s;function l(e){return n.coerce(a._input,a,o,e)}if("group"===t.scattermode)for(s=0;s=0;d--){var h=e[d];if("scatter"===h.type&&h.xaxis===c.xaxis&&h.yaxis===c.yaxis){h.opacity=void 0;break}}}}}},2374:(e,t,r)=>{"use strict";var n=r(84468),i=r(38361),o=r(22049),a=r(56003),s=r(31811),l=r(53124),c=r(26386),u=r(11583),d=r(93379),h=r(1091),p=r(33381),f=r(80272),m=r(7751),g=r(84468).coercePattern;e.exports=function(e,t,r,y){function v(r,i){return n.coerce(e,t,o,r,i)}var x=l(e,t,y,v);if(x||(t.visible=!1),t.visible){c(e,t,y,v),v("xhoverformat"),v("yhoverformat"),v("zorder");var b=u(e,t,y,v);"group"===y.scattermode&&void 0===t.orientation&&v("orientation","v");var _=!b&&x{"use strict";e.exports=function(e){return{valType:"color",editType:"style",anim:!0,description:["Sets the fill color.","Defaults to a half-transparent variant of the line color,","marker color, or marker line color, whichever is available."+(e?" If fillgradient is specified, fillcolor is ignored except for setting the background color of the hover label, if any.":"")].join(" ")}}},7751:(e,t,r)=>{"use strict";var n=r(7605),i=r(84468).isArrayOrTypedArray;e.exports=function(e,t,r,o,a){a||(a={});var s,l=!1;if(t.marker){var c=t.marker.color,u=(t.marker.line||{}).color;c&&!i(c)?l=c:u&&!i(u)&&(l=u)}if(a.moduleHasFillgradient&&"none"!==o("fillgradient.type")){o("fillgradient.start"),o("fillgradient.stop");var d=o("fillgradient.colorscale");d&&(s=function(e){for(var t=n.interpolate(e[0][1],e[1][1],.5),r=2;r{"use strict";var n=r(85729);e.exports=function(e,t,r){var i={},o={_fullLayout:r},a=n.getFromTrace(o,t,"x"),s=n.getFromTrace(o,t,"y"),l=e.orig_x;void 0===l&&(l=e.x);var c=e.orig_y;return void 0===c&&(c=e.y),i.xLabel=n.tickText(a,a.c2l(l),!0).text,i.yLabel=n.tickText(s,s.c2l(c),!0).text,i}},58864:(e,t,r)=>{"use strict";var n=r(7605),i=r(31811);e.exports=function(e,t){var r,o;if("lines"===e.mode)return(r=e.line.color)&&n.opacity(r)?r:e.fillcolor;if("none"===e.mode)return e.fill?e.fillcolor:"";var a=t.mcc||(e.marker||{}).color,s=t.mlcc||((e.marker||{}).line||{}).color;return(o=a&&n.opacity(a)?a:s&&n.opacity(s)&&(t.mlw||((e.marker||{}).line||{}).width)?s:"")?n.opacity(o)<.3?n.addOpacity(o,.3):o:(r=(e.line||{}).color)&&n.opacity(r)&&i.hasLines(e)&&e.line.width?r:e.fillcolor}},53558:(e,t,r)=>{"use strict";var n=r(80038).getAxisGroup;e.exports=function(e,t,r,i){var o=t.orientation,a=t[{v:"x",h:"y"}[o]+"axis"],s=n(r,a)+o,l=r._alignmentOpts||{},c=i("alignmentgroup"),u=l[s];u||(u=l[s]={});var d=u[c];d?d.traces.push(t):d=u[c]={traces:[t],alignmentIndex:Object.keys(u).length,offsetGroups:{}};var h=i("offsetgroup"),p=d.offsetGroups,f=p[h];h&&(f||(f=p[h]={offsetIndex:Object.keys(p).length}),t._offsetIndex=f.offsetIndex)}},32168:(e,t,r)=>{"use strict";var n=r(84468),i=r(32212),o=r(38361),a=r(58864),s=r(7605),l=n.fillText;e.exports=function(e,t,r,c){var u=e.cd,d=u[0].trace,h=e.xa,p=e.ya,f=h.c2p(t),m=p.c2p(r),g=[f,m],y=d.hoveron||"",v=-1!==d.mode.indexOf("markers")?3:.5,x=!!d.xperiodalignment,b=!!d.yperiodalignment;if(-1!==y.indexOf("points")){var _=function(e){var t=Math.max(v,e.mrc||0),r=h.c2p(e.x)-f,n=p.c2p(e.y)-m;return Math.max(Math.sqrt(r*r+n*n)-t,1-v/t)},w=i.getDistanceFunction(c,(function(e){if(x){var t=h.c2p(e.xStart),r=h.c2p(e.xEnd);return f>=Math.min(t,r)&&f<=Math.max(t,r)?0:1/0}var n=Math.max(3,e.mrc||0),i=1-1/n,o=Math.abs(h.c2p(e.x)-f);return o=Math.min(t,r)&&m<=Math.max(t,r)?0:1/0}var n=Math.max(3,e.mrc||0),i=1-1/n,o=Math.abs(p.c2p(e.y)-m);return or!==(c=i[n][1])>=r&&(a=i[n-1][0],s=i[n][0],c-l&&(o=a+(s-a)*(r-l)/(c-l),d=Math.min(d,o),f=Math.max(f,o)));return{x0:d=Math.max(d,0),x1:f=Math.min(f,h._length),y0:r,y1:r}}(d._polygons);null===O&&(O={x0:g[0],x1:g[0],y0:g[1],y1:g[1]});var R=s.defaultLine;return s.opacity(d.fillcolor)?R=d.fillcolor:s.opacity((d.line||{}).color)&&(R=d.line.color),n.extendFlat(e,{distance:e.maxHoverDistance,x0:O.x0,x1:O.x1,y0:O.y0,y1:O.y1,color:R,hovertemplate:!1}),delete e.index,d.text&&!n.isArrayOrTypedArray(d.text)?e.text=String(d.text):e.text=d.name,[e]}}},69906:(e,t,r)=>{"use strict";var n=r(31811);e.exports={hasLines:n.hasLines,hasMarkers:n.hasMarkers,hasText:n.hasText,isBubble:n.isBubble,attributes:r(22049),layoutAttributes:r(92716),supplyDefaults:r(2374),crossTraceDefaults:r(70253),supplyLayoutDefaults:r(53083),calc:r(20389).calc,crossTraceCalc:r(4918),arraysToCalcdata:r(24294),plot:r(34923),colorbar:r(17789),formatLabels:r(40777),style:r(47323).style,styleOnSelect:r(47323).styleOnSelect,hoverPoints:r(32168),selectPoints:r(57112),animatable:!0,moduleType:"trace",name:"scatter",basePlotModule:r(9510),categories:["cartesian","svg","symbols","errorBarsOK","showLegend","scatter-like","zoomScale"],meta:{description:["The scatter trace type encompasses line charts, scatter charts, text charts, and bubble charts.","The data visualized as scatter point or lines is set in `x` and `y`.","Text (appearing either on the chart or on hover only) is via `text`.","Bubble charts are achieved by setting `marker.size` and/or `marker.color`","to numerical arrays."].join(" ")}}},92716:e=>{"use strict";e.exports={scattermode:{valType:"enumerated",values:["group","overlay"],dflt:"overlay",editType:"calc",description:["Determines how scatter points at the same location coordinate","are displayed on the graph.","With *group*, the scatter points are plotted next to one another","centered around the shared location.","With *overlay*, the scatter points are plotted over one another,","you might need to reduce *opacity* to see multiple scatter points."].join(" ")},scattergap:{valType:"number",min:0,max:1,editType:"calc",description:["Sets the gap (in plot fraction) between scatter points of","adjacent location coordinates.","Defaults to `bargap`."].join(" ")}}},53083:(e,t,r)=>{"use strict";var n=r(84468),i=r(92716);e.exports=function(e,t){var r,o,a="group"===t.barmode;"group"===t.scattermode&&(r="scattergap",o=a?t.bargap:.2,n.coerce(e,t,i,r,o))}},1091:(e,t,r)=>{"use strict";var n=r(84468).isArrayOrTypedArray,i=r(73084).hasColorscale,o=r(16155);e.exports=function(e,t,r,a,s,l){l||(l={});var c=(e.marker||{}).color;(c&&c._inputArray&&(c=c._inputArray),s("line.color",r),i(e,"line"))?o(e,t,a,s,{prefix:"line.",cLetter:"c"}):s("line.color",!n(c)&&c||r);s("line.width"),l.noDash||s("line.dash"),l.backoff&&s("line.backoff")}},43446:(e,t,r)=>{"use strict";var n=r(3172),i=r(65004),o=i.BADNUM,a=i.LOG_CLIP,s=a+.5,l=a-.5,c=r(84468),u=c.segmentsIntersect,d=c.constrain,h=r(56003);e.exports=function(e,t){var r,i,a,p,f,m,g,y,v,x,b,_,w,k,S,A,T,M,C=t.trace||{},E=t.xaxis,I=t.yaxis,P="log"===E.type,O="log"===I.type,R=E._length,L=I._length,D=t.backoff,z=C.marker,j=t.connectGaps,F=t.baseTolerance,N=t.shape,B="linear"===N,V=C.fill&&"none"!==C.fill,U=[],H=h.minTolerance,$=e.length,W=new Array($),q=0;function G(r){var n=e[r];if(!n)return!1;var i=t.linearized?E.l2p(n.x):E.c2p(n.x),a=t.linearized?I.l2p(n.y):I.c2p(n.y);if(i===o){if(P&&(i=E.c2p(n.x,!0)),i===o)return!1;O&&a===o&&(i*=Math.abs(E._m*L*(E._m>0?s:l)/(I._m*R*(I._m>0?s:l)))),i*=1e3}if(a===o){if(O&&(a=I.c2p(n.y,!0)),a===o)return!1;a*=1e3}return[i,a]}function Y(e,t,r,n){var i=r-e,o=n-t,a=.5-e,s=.5-t,l=i*i+o*o,c=i*a+o*s;if(c>0&&cae||e[1]le)return[d(e[0],oe,ae),d(e[1],se,le)]}function de(e,t){return e[0]===t[0]&&(e[0]===oe||e[0]===ae)||(e[1]===t[1]&&(e[1]===se||e[1]===le)||void 0)}function he(e,t,r){return function(n,i){var o=ue(n),a=ue(i),s=[];if(o&&a&&de(o,a))return s;o&&s.push(o),a&&s.push(a);var l=2*c.constrain((n[e]+i[e])/2,t,r)-((o||n)[e]+(a||i)[e]);l&&((o&&a?l>0===o[e]>a[e]?o:a:o||a)[e]+=l);return s}}function pe(e){var t=e[0],r=e[1],n=t===W[q-1][0],i=r===W[q-1][1];if(!n||!i)if(q>1){var o=t===W[q-2][0],a=r===W[q-2][1];n&&(t===oe||t===ae)&&o?a?q--:W[q-1]=e:i&&(r===se||r===le)&&a?o?q--:W[q-1]=e:W[q++]=e}else W[q++]=e}function fe(e){W[q-1][0]!==e[0]&&W[q-1][1]!==e[1]&&pe([Q,ee]),pe(e),te=null,Q=ee=0}"linear"===N||"spline"===N?ne=function(e,t){for(var r=[],n=0,i=0;i<4;i++){var o=ce[i],a=u(e[0],e[1],t[0],t[1],o[0],o[1],o[2],o[3]);a&&(!n||Math.abs(a.x-r[0][0])>1||Math.abs(a.y-r[0][1])>1)&&(a=[a.x,a.y],n&&Z(a,e)ae?ae:0,J=t[1]le?le:0,K||J){if(q)if(te){var n=ne(te,t);n.length>1&&(fe(n[0]),W[q++]=n[1])}else re=ne(W[q-1],t)[0],W[q++]=re;else W[q++]=[K||t[0],J||t[1]];var i=W[q-1];K&&J&&(i[0]!==K||i[1]!==J)?(te&&(Q!==K&&ee!==J?pe(Q&&ee?function(e,t){var r=t[0]-e[0],n=(t[1]-e[1])/r;return(e[1]*t[0]-t[1]*e[0])/r>0?[n>0?oe:ae,le]:[n>0?ae:oe,se]}(te,t):[Q||K,ee||J]):Q&&ee&&pe([Q,ee])),pe([K,J])):Q-K&&ee-J&&pe([K||Q,J||ee]),te=t,Q=K,ee=J}else te&&fe(ne(te,t)[0]),W[q++]=t}for(r=0;r<$;r++)if(i=G(r)){for(q=0,te=null,ge(i),r++;r<$;r++){if(!(p=G(r))){if(j)continue;break}if(B&&t.simplify){var ye=G(r+1);if(x=Z(p,i),V&&(0===q||q===$-1)||!(xX(m,ye))break;a=m,(w=v[0]*y[0]+v[1]*y[1])>b?(b=w,p=m,g=!1):w<_&&(_=w,f=m,g=!0)}if(g?(ge(p),a!==f&&ge(f)):(f!==i&&ge(f),a!==p&&ge(p)),ge(a),r>=e.length||!m)break;ge(m),i=m}}else ge(p)}te&&pe([Q||te[0],ee||te[1]]),U.push(W.slice(0,q))}var ve=N.slice(N.length-1);if(D&&"h"!==ve&&"v"!==ve){for(var xe=!1,be=-1,_e=[],we=0;we{"use strict";e.exports=function(e,t,r){"spline"===r("line.shape")&&r("line.smoothing")}},49313:e=>{"use strict";var t={tonextx:1,tonexty:1,tonext:1};e.exports=function(e,r,n){var i,o,a,s,l,c={},u=!1,d=-1,h=0,p=-1;for(o=0;o=0?l=p:(l=p=h,h++),l{"use strict";var n=r(22036);e.exports=function(e,t){t||(t=2);var r=e.marker,i=r.sizeref||1,o=r.sizemin||0,a="area"===r.sizemode?function(e){return Math.sqrt(e/i)}:function(e){return e/i};return function(e){var r=a(e/t);return n(r)&&r>0?Math.max(r,o):0}}},17789:e=>{"use strict";e.exports={container:"marker",min:"cmin",max:"cmax"}},93379:(e,t,r)=>{"use strict";var n=r(7605),i=r(73084).hasColorscale,o=r(16155),a=r(31811);e.exports=function(e,t,r,s,l,c){var u=a.isBubble(e),d=(e.line||{}).color;(c=c||{},d&&(r=d),l("marker.symbol"),l("marker.opacity",u?.7:1),l("marker.size"),c.noAngle||(l("marker.angle"),c.noAngleRef||l("marker.angleref"),c.noStandOff||l("marker.standoff")),l("marker.color",r),i(e,"marker")&&o(e,t,s,l,{prefix:"marker.",cLetter:"c"}),c.noSelect||(l("selected.marker.color"),l("unselected.marker.color"),l("selected.marker.size"),l("unselected.marker.size")),c.noLine||(l("marker.line.color",d&&!Array.isArray(d)&&t.marker.color!==d?d:u?n.background:n.defaultLine),i(e,"marker.line")&&o(e,t,s,l,{prefix:"marker.line.",cLetter:"c"}),l("marker.line.width",u?1:0)),u&&(l("marker.sizeref"),l("marker.sizemin"),l("marker.sizemode")),c.gradient)&&("none"!==l("marker.gradient.type")&&l("marker.gradient.color"))}},26386:(e,t,r)=>{"use strict";var n=r(84468).dateTick0,i=r(65004).ONEWEEK;function o(e,t){return n(t,e%i===0?1:0)}e.exports=function(e,t,r,n,i){if(i||(i={x:!0,y:!0}),i.x){var a=n("xperiod");a&&(n("xperiod0",o(a,t.xcalendar)),n("xperiodalignment"))}if(i.y){var s=n("yperiod");s&&(n("yperiod0",o(s,t.ycalendar)),n("yperiodalignment"))}}},34923:(e,t,r)=>{"use strict";var n=r(41871),i=r(38361),o=r(84468),a=o.ensureSingle,s=o.identity,l=r(3172),c=r(31811),u=r(43446),d=r(49313),h=r(39926).tester;function p(e,t,r,d,p,f,m){var g,y=e._context.staticPlot;!function(e,t,r,i,a){var s=r.xaxis,l=r.yaxis,u=n.extent(o.simpleMap(s.range,s.r2c)),d=n.extent(o.simpleMap(l.range,l.r2c)),h=i[0].trace;if(!c.hasMarkers(h))return;var p=h.marker.maxdisplayed;if(0===p)return;var f=i.filter((function(e){return e.x>=u[0]&&e.x<=u[1]&&e.y>=d[0]&&e.y<=d[1]})),m=Math.ceil(f.length/p),g=0;a.forEach((function(e,r){var n=e[0].trace;c.hasMarkers(n)&&n.marker.maxdisplayed>0&&r0;function x(e){return v?e.transition():e}var b=r.xaxis,_=r.yaxis,w=d[0].trace,k=w.line,S=n.select(f),A=a(S,"g","errorbars"),T=a(S,"g","lines"),M=a(S,"g","points"),C=a(S,"g","text");if(i.getComponentMethod("errorbars","plot")(e,A,r,m),!0===w.visible){var E,I;x(S).style("opacity",w.opacity);var P,O,R=w.fill.charAt(w.fill.length-1);"x"!==R&&"y"!==R&&(R=""),"y"===R?(P=1,O=_.c2p(0,!0)):"x"===R&&(P=0,O=b.c2p(0,!0)),d[0][r.isRangePlot?"nodeRangePlot3":"node3"]=S;var L,D,z="",j=[],F=w._prevtrace,N=null,B=null;F&&(z=F._prevRevpath||"",I=F._nextFill,j=F._ownPolygons,N=F._fillsegments,B=F._fillElement);var V,U,H,$,W,q,G="",Y="",X=[];w._polygons=[];var Z=[],K=[],J=o.noop;if(E=w._ownFill,c.hasLines(w)||"none"!==w.fill){I&&I.datum(d),-1!==["hv","vh","hvh","vhv"].indexOf(k.shape)?(V=l.steps(k.shape),U=l.steps(k.shape.split("").reverse().join(""))):V=U="spline"===k.shape?function(e){var t=e[e.length-1];return e.length>1&&e[0][0]===t[0]&&e[0][1]===t[1]?l.smoothclosed(e.slice(1),k.smoothing):l.smoothopen(e,k.smoothing)}:function(e){return"M"+e.join("L")},H=function(e){return U(e.reverse())},K=u(d,{xaxis:b,yaxis:_,trace:w,connectGaps:w.connectgaps,baseTolerance:Math.max(k.width||1,3)/4,shape:k.shape,backoff:k.backoff,simplify:k.simplify,fill:w.fill}),Z=new Array(K.length);var Q=0;for(g=0;g0,g=d(e,t,r);((u=i.selectAll("g.trace").data(g,(function(e){return e[0].trace.uid}))).enter().append("g").attr("class",(function(e){return"trace scatter trace"+e[0].trace.uid})).style("stroke-miterlimit",2),u.order(),function(e,t,r){t.each((function(t){var i=a(n.select(this),"g","fills");l.setClipUrl(i,r.layerClipId,e);var o=t[0].trace,c=[];o._ownfill&&c.push("_ownFill"),o._nexttrace&&c.push("_nextFill");var u=i.selectAll("g").data(c,s);u.enter().append("g"),u.exit().each((function(e){o[e]=null})).remove(),u.order().each((function(e){o[e]=a(n.select(this),"path","js-fill")}))}))}(e,u,t),m)?(c&&(h=c()),n.transition().duration(o.duration).ease(o.easing).each("end",(function(){h&&h()})).each("interrupt",(function(){h&&h()})).each((function(){i.selectAll("g.trace").each((function(r,n){p(e,n,t,r,g,this,o)}))}))):u.each((function(r,n){p(e,n,t,r,g,this,o)}));f&&u.exit().remove(),i.selectAll("path:not([d])").remove()}},57112:(e,t,r)=>{"use strict";var n=r(31811);e.exports=function(e,t){var r,i,o,a,s=e.cd,l=e.xaxis,c=e.yaxis,u=[],d=s[0].trace;if(!n.hasMarkers(d)&&!n.hasText(d))return[];if(!1===t)for(r=0;r{"use strict";var t=["orientation","groupnorm","stackgaps"];e.exports=function(e,r,n,i){var o=n._scatterStackOpts,a=i("stackgroup");if(a){var s=r.xaxis+r.yaxis,l=o[s];l||(l=o[s]={});var c=l[a],u=!1;c?c.traces.push(r):(c=l[a]={traceIndices:[],traces:[r]},u=!0);for(var d={orientation:r.x&&!r.y?"h":"v"},h=0;h{"use strict";var n=r(41871),i=r(3172),o=r(38361);function a(e,t,r){i.pointStyle(e.selectAll("path.point"),t,r)}function s(e,t,r){i.textPointStyle(e.selectAll("text"),t,r)}e.exports={style:function(e){var t=n.select(e).selectAll("g.trace.scatter");t.style("opacity",(function(e){return e[0].trace.opacity})),t.selectAll("g.points").each((function(t){a(n.select(this),t.trace||t[0].trace,e)})),t.selectAll("g.text").each((function(t){s(n.select(this),t.trace||t[0].trace,e)})),t.selectAll("g.trace path.js-line").call(i.lineGroupStyle),t.selectAll("g.trace path.js-fill").call(i.fillGroupStyle,e,!1),o.getComponentMethod("errorbars","style")(t)},stylePoints:a,styleText:s,styleOnSelect:function(e,t,r){var n=t[0].trace;n.selectedpoints?(i.selectedPointStyle(r.selectAll("path.point"),n),i.selectedTextStyle(r.selectAll("text"),n)):(a(r,n,e),s(r,n,e))}}},31811:(e,t,r)=>{"use strict";var n=r(84468),i=r(19045).isTypedArraySpec;e.exports={hasLines:function(e){return e.visible&&e.mode&&-1!==e.mode.indexOf("lines")},hasMarkers:function(e){return e.visible&&(e.mode&&-1!==e.mode.indexOf("markers")||"splom"===e.type)},hasText:function(e){return e.visible&&e.mode&&-1!==e.mode.indexOf("text")},isBubble:function(e){var t=e.marker;return n.isPlainObject(t)&&(n.isArrayOrTypedArray(t.size)||i(t.size))}}},80272:(e,t,r)=>{"use strict";var n=r(84468);e.exports=function(e,t,r,i,o){o=o||{},i("textposition"),n.coerceFont(i,"textfont",o.font||r.font,o),o.noSelect||(i("selected.textfont.color"),i("unselected.textfont.color"))}},53124:(e,t,r)=>{"use strict";var n=r(84468),i=r(38361);e.exports=function(e,t,r,o){var a,s=o("x"),l=o("y");if(i.getComponentMethod("calendars","handleTraceDefaults")(e,t,["x","y"],r),s){var c=n.minRowLength(s);l?a=Math.min(c,n.minRowLength(l)):(a=c,o("y0"),o("dy"))}else{if(!l)return 0;a=n.minRowLength(l),o("x0"),o("dx")}return t._length=a,a}},85812:(e,t,r)=>{"use strict";var n=r(22049),i=r(91740),o=r(6636),a=r(39363).axisHoverFormat,s=r(84425).rb,l=r(84425).ay,c=r(75622),u=r(30915),d=r(10956),h=r(64022).extendFlat,p=r(72587).overrideAll,f=r(60693),m=n.line,g=n.marker,y=g.line,v=h({width:m.width,dash:{valType:"enumerated",values:f(u),dflt:"solid",description:"Sets the dash style of the lines."}},o("line"));function x(e){return{show:{valType:"boolean",dflt:!1,description:["Sets whether or not projections are shown along the",e,"axis."].join(" ")},opacity:{valType:"number",min:0,max:1,dflt:1,description:"Sets the projection color."},scale:{valType:"number",min:0,max:10,dflt:2/3,description:["Sets the scale factor determining the size of the","projection marker points."].join(" ")}}}var b=e.exports=p({x:n.x,y:n.y,z:{valType:"data_array",description:"Sets the z coordinates."},text:h({},n.text,{description:["Sets text elements associated with each (x,y,z) triplet.","If a single string, the same string appears over","all the data points.","If an array of string, the items are mapped in order to the","this trace's (x,y,z) coordinates.","If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,","these elements will be seen in the hover labels."].join(" ")}),texttemplate:l({},{}),hovertext:h({},n.hovertext,{description:["Sets text elements associated with each (x,y,z) triplet.","If a single string, the same string appears over","all the data points.","If an array of string, the items are mapped in order to the","this trace's (x,y,z) coordinates.","To be seen, trace `hoverinfo` must contain a *text* flag."].join(" ")}),hovertemplate:s(),xhoverformat:a("x"),yhoverformat:a("y"),zhoverformat:a("z"),mode:h({},n.mode,{dflt:"lines+markers"}),surfaceaxis:{valType:"enumerated",values:[-1,0,1,2],dflt:-1,description:["If *-1*, the scatter points are not fill with a surface","If *0*, *1*, *2*, the scatter points are filled with","a Delaunay surface about the x, y, z respectively."].join(" ")},surfacecolor:{valType:"color",description:"Sets the surface fill color."},projection:{x:x("x"),y:x("y"),z:x("z")},connectgaps:n.connectgaps,line:v,marker:h({symbol:{valType:"enumerated",values:f(d),dflt:"circle",arrayOk:!0,description:"Sets the marker symbol type."},size:h({},g.size,{dflt:8}),sizeref:g.sizeref,sizemin:g.sizemin,sizemode:g.sizemode,opacity:h({},g.opacity,{arrayOk:!1,description:["Sets the marker opacity.","Note that the marker opacity for scatter3d traces","must be a scalar value for performance reasons.","To set a blending opacity value","(i.e. which is not transparent), set *marker.color*","to an rgba color and use its alpha channel."].join(" ")}),colorbar:g.colorbar,line:h({width:h({},y.width,{arrayOk:!1})},o("marker.line"))},o("marker")),textposition:h({},n.textposition,{dflt:"top center"}),textfont:i({noFontShadow:!0,noFontLineposition:!0,noFontTextcase:!0,editType:"calc",colorEditType:"style",arrayOk:!0,variantValues:["normal","small-caps"],description:"Sets the text font."}),opacity:c.opacity,hoverinfo:h({},c.hoverinfo)},"calc","nested");b.x.editType=b.y.editType=b.z.editType="calc+clearAxisTypes"},2356:(e,t,r)=>{"use strict";var n=r(24294),i=r(85387);e.exports=function(e,t){var r=[{x:!1,y:!1,trace:t,t:{}}];return n(r,t),i(e,t),r}},78772:(e,t,r)=>{"use strict";var n=r(38361);function i(e,t,r,i){if(!t||!t.visible)return null;for(var o=n.getComponentMethod("errorbars","makeComputeError")(t),a=new Array(e.length),s=0;s0){var h=i.c2l(u);i._lowerLogErrorBound||(i._lowerLogErrorBound=h),i._lowerErrorBound=Math.min(i._lowerLogErrorBound,h)}}else a[s]=[-l[0]*r,l[1]*r]}return a}e.exports=function(e,t,r){var n=[i(e.x,e.error_x,t[0],r.xaxis),i(e.y,e.error_y,t[1],r.yaxis),i(e.z,e.error_z,t[2],r.zaxis)],o=function(e){for(var t=0;t{"use strict";var n=r(76107).gl_line3d,i=r(76107).gl_scatter3d,o=r(76107).gl_error3d,a=r(76107).gl_mesh3d,s=r(76107).delaunay_triangulate,l=r(84468),c=r(79689),u=r(23207).formatColor,d=r(14204),h=r(30915),p=r(10956),f=r(85729),m=r(82561).appendArrayPointValue,g=r(78772);function y(e,t){this.scene=e,this.uid=t,this.linePlot=null,this.scatterPlot=null,this.errorBars=null,this.textMarkers=null,this.delaunayMesh=null,this.color=null,this.mode="",this.dataPoints=[],this.axesBounds=[[-1/0,-1/0,-1/0],[1/0,1/0,1/0]],this.textLabels=null,this.data=null}var v=y.prototype;function x(e){return null===e||void 0===e?0:e.indexOf("left")>-1?-1:e.indexOf("right")>-1?1:0}function b(e){return null===e||void 0===e?0:e.indexOf("top")>-1?-1:e.indexOf("bottom")>-1?1:0}function _(e,t){return t(4*e)}function w(e){return p[e]}function k(e,t,r,n,i){var o=null;if(l.isArrayOrTypedArray(e)){o=[];for(var a=0;a=0){var m=function(e,t,r){var n,i=(r+1)%3,o=(r+2)%3,a=[],l=[];for(n=0;n{"use strict";var n=r(38361),i=r(84468),o=r(31811),a=r(93379),s=r(1091),l=r(80272),c=r(85812);e.exports=function(e,t,r,u){function d(r,n){return i.coerce(e,t,c,r,n)}var h=function(e,t,r,i){var o=0,a=r("x"),s=r("y"),l=r("z");n.getComponentMethod("calendars","handleTraceDefaults")(e,t,["x","y","z"],i),a&&s&&l&&(o=Math.min(a.length,s.length,l.length),t._length=t._xlength=t._ylength=t._zlength=o);return o}(e,t,d,u);if(h){d("text"),d("hovertext"),d("hovertemplate"),d("xhoverformat"),d("yhoverformat"),d("zhoverformat"),d("mode"),o.hasMarkers(t)&&a(e,t,r,u,d,{noSelect:!0,noAngle:!0}),o.hasLines(t)&&(d("connectgaps"),s(e,t,r,u,d)),o.hasText(t)&&(d("texttemplate"),l(e,t,u,d,{noSelect:!0,noFontShadow:!0,noFontLineposition:!0,noFontTextcase:!0}));var p=(t.line||{}).color,f=(t.marker||{}).color;d("surfaceaxis")>=0&&d("surfacecolor",p||f);for(var m=["x","y","z"],g=0;g<3;++g){var y="projection."+m[g];d(y+".show")&&(d(y+".opacity"),d(y+".scale"))}var v=n.getComponentMethod("errorbars","supplyDefaults");v(e,t,p||f||r,{axis:"z"}),v(e,t,p||f||r,{axis:"y",inherit:"z"}),v(e,t,p||f||r,{axis:"x",inherit:"z"})}else t.visible=!1}},31129:(e,t,r)=>{"use strict";e.exports={plot:r(73458),attributes:r(85812),markerSymbols:r(10956),supplyDefaults:r(88099),colorbar:[{container:"marker",min:"cmin",max:"cmax"},{container:"line",min:"cmin",max:"cmax"}],calc:r(2356),moduleType:"trace",name:"scatter3d",basePlotModule:r(48648),categories:["gl3d","symbols","showLegend","scatter-like"],meta:{hrName:"scatter_3d",description:["The data visualized as scatter point or lines in 3D dimension","is set in `x`, `y`, `z`.","Text (appearing either on the chart or on hover only) is via `text`.","Bubble charts are achieved by setting `marker.size` and/or `marker.color`","Projections are achieved via `projection`.","Surface fills are achieved via `surfaceaxis`."].join(" ")}}},42596:(e,t,r)=>{"use strict";var n=r(50821),i=r(22049),o=r(75622),a=r(84425).rb,s=r(84425).ay,l=r(6636),c=r(64022).extendFlat,u=i.marker,d=i.line,h=u.line;e.exports={carpet:{valType:"string",editType:"calc",description:["An identifier for this carpet, so that `scattercarpet` and","`contourcarpet` traces can specify a carpet plot on which","they lie"].join(" ")},a:{valType:"data_array",editType:"calc",description:"Sets the a-axis coordinates."},b:{valType:"data_array",editType:"calc",description:"Sets the b-axis coordinates."},mode:c({},i.mode,{dflt:"markers"}),text:c({},i.text,{description:["Sets text elements associated with each (a,b) point.","If a single string, the same string appears over","all the data points.","If an array of strings, the items are mapped in order to the","the data points in (a,b).","If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,","these elements will be seen in the hover labels."].join(" ")}),texttemplate:s({editType:"plot"},{keys:["a","b","text"]}),hovertext:c({},i.hovertext,{description:["Sets hover text elements associated with each (a,b) point.","If a single string, the same string appears over","all the data points.","If an array of strings, the items are mapped in order to the","the data points in (a,b).","To be seen, trace `hoverinfo` must contain a *text* flag."].join(" ")}),line:{color:d.color,width:d.width,dash:d.dash,backoff:d.backoff,shape:c({},d.shape,{values:["linear","spline"]}),smoothing:d.smoothing,editType:"calc"},connectgaps:i.connectgaps,fill:c({},i.fill,{values:["none","toself","tonext"],dflt:"none",description:["Sets the area to fill with a solid color.","Use with `fillcolor` if not *none*.","scatterternary has a subset of the options available to scatter.","*toself* connects the endpoints of the trace (or each segment","of the trace if it has gaps) into a closed shape.","*tonext* fills the space between two traces if one completely","encloses the other (eg consecutive contour lines), and behaves like","*toself* if there is no trace before it. *tonext* should not be","used if one trace does not enclose the other."].join(" ")}),fillcolor:n(),marker:c({symbol:u.symbol,opacity:u.opacity,maxdisplayed:u.maxdisplayed,angle:u.angle,angleref:u.angleref,standoff:u.standoff,size:u.size,sizeref:u.sizeref,sizemin:u.sizemin,sizemode:u.sizemode,line:c({width:h.width,editType:"calc"},l("marker.line")),gradient:u.gradient,editType:"calc"},l("marker")),textfont:i.textfont,textposition:i.textposition,selected:i.selected,unselected:i.unselected,hoverinfo:c({},o.hoverinfo,{flags:["a","b","text","name"]}),hoveron:i.hoveron,hovertemplate:a(),zorder:i.zorder}},34404:(e,t,r)=>{"use strict";var n=r(22036),i=r(85387),o=r(24294),a=r(40304),s=r(20389).calcMarkerSize,l=r(35738);e.exports=function(e,t){var r=t._carpetTrace=l(e,t);if(r&&r.visible&&"legendonly"!==r.visible){var c;t.xaxis=r.xaxis,t.yaxis=r.yaxis;var u,d,h=t._length,p=new Array(h),f=!1;for(c=0;c{"use strict";var n=r(84468),i=r(56003),o=r(31811),a=r(93379),s=r(1091),l=r(33381),c=r(80272),u=r(7751),d=r(42596);e.exports=function(e,t,r,h){function p(r,i){return n.coerce(e,t,d,r,i)}p("carpet"),t.xaxis="x",t.yaxis="y";var f=p("a"),m=p("b"),g=Math.min(f.length,m.length);if(g){t._length=g,p("text"),p("texttemplate"),p("hovertext"),p("mode",g{"use strict";e.exports=function(e,t,r,n,i){var o=n[i];return e.a=o.a,e.b=o.b,e.y=o.y,e}},5986:e=>{"use strict";e.exports=function(e,t){var r={},n=t._carpet,i=n.ab2ij([e.a,e.b]),o=Math.floor(i[0]),a=i[0]-o,s=Math.floor(i[1]),l=i[1]-s,c=n.evalxy([],o,s,a,l);return r.yLabel=c[1].toFixed(3),r}},82515:(e,t,r)=>{"use strict";var n=r(32168),i=r(84468).fillText;e.exports=function(e,t,r,o){var a=n(e,t,r,o);if(a&&!1!==a[0].index){var s=a[0];if(void 0===s.index){var l=1-s.y0/e.ya._length,c=e.xa._length,u=c*l/2,d=c-u;return s.x0=Math.max(Math.min(s.x0,d),u),s.x1=Math.max(Math.min(s.x1,d),u),a}var h=s.cd[s.index];s.a=h.a,s.b=h.b,s.xLabelVal=void 0,s.yLabelVal=void 0;var p=s.trace,f=p._carpet,m=p._module.formatLabels(h,p);s.yLabel=m.yLabel,delete s.text;var g=[];if(!p.hovertemplate){var y=(h.hi||p.hoverinfo).split("+");-1!==y.indexOf("all")&&(y=["a","b","text"]),-1!==y.indexOf("a")&&v(f.aaxis,h.a),-1!==y.indexOf("b")&&v(f.baxis,h.b),g.push("y: "+s.yLabel),-1!==y.indexOf("text")&&i(h,p,g),s.extraText=g.join("
")}return a}function v(e,t){var r;r=e.labelprefix&&e.labelprefix.length>0?e.labelprefix.replace(/ = $/,""):e._hovertitle,g.push(r+": "+t.toFixed(3)+e.labelsuffix)}}},64649:(e,t,r)=>{"use strict";e.exports={attributes:r(42596),supplyDefaults:r(4275),colorbar:r(17789),formatLabels:r(5986),calc:r(34404),plot:r(39270),style:r(47323).style,styleOnSelect:r(47323).styleOnSelect,hoverPoints:r(82515),selectPoints:r(57112),eventData:r(50616),moduleType:"trace",name:"scattercarpet",basePlotModule:r(9510),categories:["svg","carpet","symbols","showLegend","carpetDependent","zoomScale"],meta:{hrName:"scatter_carpet",description:["Plots a scatter trace on either the first carpet axis or the","carpet axis with a matching `carpet` attribute."].join(" ")}}},39270:(e,t,r)=>{"use strict";var n=r(34923),i=r(85729),o=r(3172);e.exports=function(e,t,r,a){var s,l,c,u=r[0][0].carpet,d=i.getFromId(e,u.xaxis||"x"),h=i.getFromId(e,u.yaxis||"y"),p={xaxis:d,yaxis:h,plot:t.plot};for(s=0;s{"use strict";var n=r(84425).rb,i=r(84425).ay,o=r(50821),a=r(22049),s=r(75622),l=r(6636),c=r(2703).T,u=r(64022).extendFlat,d=r(72587).overrideAll,h=a.marker,p=a.line,f=h.line;e.exports=d({lon:{valType:"data_array",description:"Sets the longitude coordinates (in degrees East)."},lat:{valType:"data_array",description:"Sets the latitude coordinates (in degrees North)."},locations:{valType:"data_array",description:["Sets the coordinates via location IDs or names.","Coordinates correspond to the centroid of each location given.","See `locationmode` for more info."].join(" ")},locationmode:{valType:"enumerated",values:["ISO-3","USA-states","country names","geojson-id"],dflt:"ISO-3",description:["Determines the set of locations used to match entries in `locations`","to regions on the map.","Values *ISO-3*, *USA-states*, *country names* correspond to features on","the base map and value *geojson-id* corresponds to features from a custom","GeoJSON linked to the `geojson` attribute."].join(" ")},geojson:{valType:"any",editType:"calc",description:["Sets optional GeoJSON data associated with this trace.","If not given, the features on the base map are used when `locations` is set.","It can be set as a valid GeoJSON object or as a URL string.","Note that we only accept GeoJSONs of type *FeatureCollection* or *Feature*","with geometries of type *Polygon* or *MultiPolygon*."].join(" ")},featureidkey:{valType:"string",editType:"calc",dflt:"id",description:["Sets the key in GeoJSON features which is used as id to match the items","included in the `locations` array.","Only has an effect when `geojson` is set.","Support nested property, for example *properties.name*."].join(" ")},mode:u({},a.mode,{dflt:"markers"}),text:u({},a.text,{description:["Sets text elements associated with each (lon,lat) pair","or item in `locations`.","If a single string, the same string appears over","all the data points.","If an array of string, the items are mapped in order to the","this trace's (lon,lat) or `locations` coordinates.","If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,","these elements will be seen in the hover labels."].join(" ")}),texttemplate:i({editType:"plot"},{keys:["lat","lon","location","text"]}),hovertext:u({},a.hovertext,{description:["Sets hover text elements associated with each (lon,lat) pair","or item in `locations`.","If a single string, the same string appears over","all the data points.","If an array of string, the items are mapped in order to the","this trace's (lon,lat) or `locations` coordinates.","To be seen, trace `hoverinfo` must contain a *text* flag."].join(" ")}),textfont:a.textfont,textposition:a.textposition,line:{color:p.color,width:p.width,dash:c},connectgaps:a.connectgaps,marker:u({symbol:h.symbol,opacity:h.opacity,angle:h.angle,angleref:u({},h.angleref,{values:["previous","up","north"],description:["Sets the reference for marker angle.","With *previous*, angle 0 points along the line from the previous point to this one.","With *up*, angle 0 points toward the top of the screen.","With *north*, angle 0 points north based on the current map projection."].join(" ")}),standoff:h.standoff,size:h.size,sizeref:h.sizeref,sizemin:h.sizemin,sizemode:h.sizemode,colorbar:h.colorbar,line:u({width:f.width},l("marker.line")),gradient:h.gradient},l("marker")),fill:{valType:"enumerated",values:["none","toself"],dflt:"none",description:["Sets the area to fill with a solid color.","Use with `fillcolor` if not *none*.","*toself* connects the endpoints of the trace (or each segment","of the trace if it has gaps) into a closed shape."].join(" ")},fillcolor:o(),selected:a.selected,unselected:a.unselected,hoverinfo:u({},s.hoverinfo,{flags:["lon","lat","location","text","name"]}),hovertemplate:n()},"calc","nested")},36038:(e,t,r)=>{"use strict";var n=r(22036),i=r(65004).BADNUM,o=r(85387),a=r(24294),s=r(40304),l=r(84468).isArrayOrTypedArray,c=r(84468)._;function u(e){return e&&"string"===typeof e}e.exports=function(e,t){var r,d=l(t.locations),h=d?t.locations.length:t._length,p=new Array(h);r=t.geojson?function(e){return u(e)||n(e)}:u;for(var f=0;f{"use strict";var n=r(84468),i=r(31811),o=r(93379),a=r(1091),s=r(80272),l=r(7751),c=r(16490);e.exports=function(e,t,r,u){function d(r,i){return n.coerce(e,t,c,r,i)}var h,p=d("locations");if(p&&p.length){var f,m=d("geojson");("string"===typeof m&&""!==m||n.isPlainObject(m))&&(f="geojson-id"),"geojson-id"===d("locationmode",f)&&d("featureidkey"),h=p.length}else{var g=d("lon")||[],y=d("lat")||[];h=Math.min(g.length,y.length)}h?(t._length=h,d("text"),d("hovertext"),d("hovertemplate"),d("mode"),i.hasMarkers(t)&&o(e,t,r,u,d,{gradient:!0}),i.hasLines(t)&&(a(e,t,r,u,d),d("connectgaps")),i.hasText(t)&&(d("texttemplate"),s(e,t,u,d)),d("fill"),"none"!==t.fill&&l(e,t,r,d),n.coerceSelectionMarkerOpacity(t,d)):t.visible=!1}},25798:e=>{"use strict";e.exports=function(e,t,r,n,i){e.lon=t.lon,e.lat=t.lat,e.location=t.loc?t.loc:null;var o=n[i];return o.fIn&&o.fIn.properties&&(e.properties=o.fIn.properties),e}},42384:(e,t,r)=>{"use strict";var n=r(85729);e.exports=function(e,t,r){var i={},o=r[t.geo]._subplot.mockAxis,a=e.lonlat;return i.lonLabel=n.tickText(o,o.c2l(a[0]),!0).text,i.latLabel=n.tickText(o,o.c2l(a[1]),!0).text,i}},8917:(e,t,r)=>{"use strict";var n=r(32212),i=r(65004).BADNUM,o=r(58864),a=r(84468).fillText,s=r(16490);e.exports=function(e,t,r){var l=e.cd,c=l[0].trace,u=e.xa,d=e.ya,h=e.subplot,p=h.projection.isLonLatOverEdges,f=h.project;if(n.getClosest(l,(function(e){var n=e.lonlat;if(n[0]===i)return 1/0;if(p(n))return 1/0;var o=f(n),a=f([t,r]),s=Math.abs(o[0]-a[0]),l=Math.abs(o[1]-a[1]),c=Math.max(3,e.mrc||0);return Math.max(Math.sqrt(s*s+l*l)-c,1-3/c)}),e),!1!==e.index){var m=l[e.index],g=m.lonlat,y=[u.c2p(g),d.c2p(g)],v=m.mrc||1;e.x0=y[0]-v,e.x1=y[0]+v,e.y0=y[1]-v,e.y1=y[1]+v,e.loc=m.loc,e.lon=g[0],e.lat=g[1];var x={};x[c.geo]={_subplot:h};var b=c._module.formatLabels(m,c,x);return e.lonLabel=b.lonLabel,e.latLabel=b.latLabel,e.color=o(c,m),e.extraText=function(e,t,r,n){if(e.hovertemplate)return;var i=t.hi||e.hoverinfo,o="all"===i?s.hoverinfo.flags:i.split("+"),l=-1!==o.indexOf("location")&&Array.isArray(e.locations),c=-1!==o.indexOf("lon"),u=-1!==o.indexOf("lat"),d=-1!==o.indexOf("text"),h=[];function p(e){return e+"\xb0"}l?h.push(t.loc):c&&u?h.push("("+p(r.latLabel)+", "+p(r.lonLabel)+")"):c?h.push(n.lon+p(r.lonLabel)):u&&h.push(n.lat+p(r.latLabel));d&&a(t,e,h);return h.join("
")}(c,m,e,l[0].t.labels),e.hovertemplate=c.hovertemplate,[e]}}},69491:(e,t,r)=>{"use strict";e.exports={attributes:r(16490),supplyDefaults:r(79389),colorbar:r(17789),formatLabels:r(42384),calc:r(36038),calcGeoJSON:r(71732).calcGeoJSON,plot:r(71732).plot,style:r(65078),styleOnSelect:r(47323).styleOnSelect,hoverPoints:r(8917),eventData:r(25798),selectPoints:r(97303),moduleType:"trace",name:"scattergeo",basePlotModule:r(81073),categories:["geo","symbols","showLegend","scatter-like"],meta:{hrName:"scatter_geo",description:["The data visualized as scatter point or lines on a geographic map","is provided either by longitude/latitude pairs in `lon` and `lat`","respectively or by geographic location IDs or names in `locations`."].join(" ")}}},71732:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468),o=r(76621).getTopojsonFeatures,a=r(89385),s=r(63925),l=r(49618).findExtremes,c=r(65004).BADNUM,u=r(20389).calcMarkerSize,d=r(31811),h=r(65078);e.exports={calcGeoJSON:function(e,t){var r,n,a=e[0].trace,d=t[a.geo],h=d._subplot,p=a._length;if(i.isArrayOrTypedArray(a.locations)){var f=a.locationmode,m="geojson-id"===f?s.extractTraceFeature(e):o(a,h.topojson);for(r=0;r{"use strict";var n=r(31811),i=r(65004).BADNUM;e.exports=function(e,t){var r,o,a,s,l,c=e.cd,u=e.xaxis,d=e.yaxis,h=[],p=c[0].trace;if(!n.hasMarkers(p)&&!n.hasText(p))return[];if(!1===t)for(l=0;l{"use strict";var n=r(41871),i=r(3172),o=r(7605),a=r(47323),s=a.stylePoints,l=a.styleText;e.exports=function(e,t){t&&function(e,t){var r=t[0].trace,a=t[0].node3;a.style("opacity",t[0].trace.opacity),s(a,r,e),l(a,r,e),a.selectAll("path.js-line").style("fill","none").each((function(e){var t=n.select(this),r=e.trace,a=r.line||{};t.call(o.stroke,a.color).call(i.dashLine,a.dash||"",a.width||0),"none"!==r.fill&&t.call(o.fill,r.fillcolor)}))}(e,t)}},86600:(e,t,r)=>{"use strict";var n=r(75622),i=r(91740),o=r(50821),a=r(22049),s=r(39363).axisHoverFormat,l=r(6636),c=r(60693),u=r(64022).extendFlat,d=r(72587).overrideAll,h=r(12364).DASHES,p=a.line,f=a.marker,m=f.line,g=e.exports=d({x:a.x,x0:a.x0,dx:a.dx,y:a.y,y0:a.y0,dy:a.dy,xperiod:a.xperiod,yperiod:a.yperiod,xperiod0:a.xperiod0,yperiod0:a.yperiod0,xperiodalignment:a.xperiodalignment,yperiodalignment:a.yperiodalignment,xhoverformat:s("x"),yhoverformat:s("y"),text:a.text,hovertext:a.hovertext,textposition:a.textposition,textfont:i({noFontShadow:!0,noFontLineposition:!0,noFontTextcase:!0,editType:"calc",colorEditType:"style",arrayOk:!0,noNumericWeightValues:!0,variantValues:["normal","small-caps"],description:"Sets the text font."}),mode:{valType:"flaglist",flags:["lines","markers","text"],extras:["none"],description:["Determines the drawing mode for this scatter trace."].join(" ")},line:{color:p.color,width:p.width,shape:{valType:"enumerated",values:["linear","hv","vh","hvh","vhv"],dflt:"linear",editType:"plot",description:["Determines the line shape.","The values correspond to step-wise line shapes."].join(" ")},dash:{valType:"enumerated",values:c(h),dflt:"solid",description:"Sets the style of the lines."}},marker:u({},l("marker"),{symbol:f.symbol,angle:f.angle,size:f.size,sizeref:f.sizeref,sizemin:f.sizemin,sizemode:f.sizemode,opacity:f.opacity,colorbar:f.colorbar,line:u({},l("marker.line"),{width:m.width})}),connectgaps:a.connectgaps,fill:u({},a.fill,{dflt:"none"}),fillcolor:o(),selected:{marker:a.selected.marker,textfont:a.selected.textfont},unselected:{marker:a.unselected.marker,textfont:a.unselected.textfont},opacity:n.opacity},"calc","nested");g.x.editType=g.y.editType=g.x0.editType=g.y0.editType="calc+clearAxisTypes",g.hovertemplate=a.hovertemplate,g.texttemplate=a.texttemplate},96951:(e,t,r)=>{"use strict";var n=r(31311);e.exports={moduleType:"trace",name:"scattergl",basePlotModule:r(9510),categories:["gl","regl","cartesian","symbols","errorBarsOK","showLegend","scatter-like"],attributes:r(86600),supplyDefaults:r(11807),crossTraceDefaults:r(70253),colorbar:r(17789),formatLabels:r(90518),calc:r(75032),hoverPoints:n.hoverPoints,selectPoints:r(77761),meta:{hrName:"scatter_gl",description:["The data visualized as scatter point or lines is set in `x` and `y`","using the WebGL plotting engine.","Bubble charts are achieved by setting `marker.size` and/or `marker.color`","to a numerical arrays."].join(" ")}}},75032:(e,t,r)=>{"use strict";var n=r(2210),i=r(84468),o=r(11576),a=r(49618).findExtremes,s=r(35087),l=r(20389),c=l.calcMarkerSize,u=l.calcAxisExpansion,d=l.setFirstScatter,h=r(85387),p=r(36398),f=r(5093),m=r(65004).BADNUM,g=r(12364).TOO_MANY_POINTS;function y(e,t,r){var n=e._extremes[t._id],i=a(t,r._bnds,{padded:!0});n.min=n.min.concat(i.min),n.max=n.max.concat(i.max)}e.exports=function(e,t){var r,a=e._fullLayout,l=t._xA=o.getFromId(e,t.xaxis,"x"),v=t._yA=o.getFromId(e,t.yaxis,"y"),x=a._plots[t.xaxis+t.yaxis],b=t._length,_=b>=g,w=2*b,k={},S=l.makeCalcdata(t,"x"),A=v.makeCalcdata(t,"y"),T=s(t,l,"x",S),M=s(t,v,"y",A),C=T.vals,E=M.vals;t._x=C,t._y=E,t.xperiodalignment&&(t._origX=S,t._xStarts=T.starts,t._xEnds=T.ends),t.yperiodalignment&&(t._origY=A,t._yStarts=M.starts,t._yEnds=M.ends);var I=new Array(w),P=new Array(b);for(r=0;r1&&i.extendFlat(s.line,p.linePositions(e,r,n));if(s.errorX||s.errorY){var l=p.errorBarPositions(e,r,n,o,a);s.errorX&&i.extendFlat(s.errorX,l.x),s.errorY&&i.extendFlat(s.errorY,l.y)}s.text&&(i.extendFlat(s.text,{positions:n},p.textPosition(e,r,s.text,s.marker)),i.extendFlat(s.textSel,{positions:n},p.textPosition(e,r,s.text,s.markerSel)),i.extendFlat(s.textUnsel,{positions:n},p.textPosition(e,r,s.text,s.markerUnsel)));return s}(e,0,t,I,C,E),L=f(e,x);return d(a,t),_?R.marker&&(O=R.marker.sizeAvg||Math.max(R.marker.size,3)):O=c(t,b),u(e,t,l,v,C,E,O),R.errorX&&y(t,l,R.errorX),R.errorY&&y(t,v,R.errorY),R.fill&&!L.fill2d&&(L.fill2d=!0),R.marker&&!L.scatter2d&&(L.scatter2d=!0),R.line&&!L.line2d&&(L.line2d=!0),!R.errorX&&!R.errorY||L.error2d||(L.error2d=!0),R.text&&!L.glText&&(L.glText=!0),R.marker&&(R.marker.snap=b),L.lineOptions.push(R.line),L.errorXOptions.push(R.errorX),L.errorYOptions.push(R.errorY),L.fillOptions.push(R.fill),L.markerOptions.push(R.marker),L.markerSelectedOptions.push(R.markerSel),L.markerUnselectedOptions.push(R.markerUnsel),L.textOptions.push(R.text),L.textSelectedOptions.push(R.textSel),L.textUnselectedOptions.push(R.textUnsel),L.selectBatch.push([]),L.unselectBatch.push([]),k._scene=L,k.index=L.count,k.x=C,k.y=E,k.positions=I,L.count++,[{x:!1,y:!1,t:k,trace:t}]}},12364:e=>{"use strict";e.exports={TOO_MANY_POINTS:1e5,SYMBOL_SDF_SIZE:200,SYMBOL_SIZE:20,SYMBOL_STROKE:1,DOT_RE:/-dot/,OPEN_RE:/-open/,DASHES:{solid:[1],dot:[1,1],dash:[4,1],longdash:[8,1],dashdot:[4,1,1,1],longdashdot:[8,1,1,1]}}},36398:(e,t,r)=>{"use strict";var n=r(22036),i=r(87572),o=r(49866),a=r(38361),s=r(84468),l=s.isArrayOrTypedArray,c=r(3172),u=r(11576),d=r(23207).formatColor,h=r(31811),p=r(14204),f=r(81728),m=r(12364),g=r(64253).DESELECTDIM,y={start:1,left:1,end:-1,right:-1,middle:0,center:0,bottom:1,top:-1},v=r(82561).appendArrayPointValue;function x(e,t){var r,i=e._fullLayout,o=t._length,a=t.textfont,c=t.textposition,u=l(c)?c:[c],d=a.color,h=a.size,p=a.family,f=a.weight,m=a.style,g=a.variant,y={},x=e._context.plotGlPixelRatio,_=t.texttemplate;if(_){y.text=[];var w=i._d3locale,k=Array.isArray(_),S=k?Math.min(_.length,o):o,A=k?function(e){return _[e]}:function(){return _};for(r=0;r500?"bold":"normal":e}function _(e,t){var r,n,i=t._length,a=t.marker,s={},c=l(a.symbol),u=l(a.angle),h=l(a.color),m=l(a.line.color),g=l(a.opacity),y=l(a.size),v=l(a.line.width);if(c||(n=f.isOpenSymbol(a.symbol)),c||h||m||g||u){s.symbols=new Array(i),s.angles=new Array(i),s.colors=new Array(i),s.borderColors=new Array(i);var x=a.symbol,b=a.angle,_=d(a,a.opacity,i),w=d(a.line,a.opacity,i);if(!l(w[0])){var k=w;for(w=Array(i),r=0;rm.TOO_MANY_POINTS||h.hasMarkers(t)?"rect":"round";if(c&&t.connectgaps){var d=n[0],p=n[1];for(i=0;i1?c[i]:c[0]:c,m=l(u)?u.length>1?u[i]:u[0]:u,g=y[f],v=y[m],x=d?d/.8+1:0,b=-v*x-.5*v;a.offset[i]=[g*x/p,b/p]}}return a}}},11807:(e,t,r)=>{"use strict";var n=r(84468),i=r(38361),o=r(81728),a=r(86600),s=r(56003),l=r(31811),c=r(53124),u=r(26386),d=r(93379),h=r(1091),p=r(7751),f=r(80272);e.exports=function(e,t,r,m){function g(r,i){return n.coerce(e,t,a,r,i)}var y=!!e.marker&&o.isOpenSymbol(e.marker.symbol),v=l.isBubble(e),x=c(e,t,m,g);if(x){u(e,t,m,g),g("xhoverformat"),g("yhoverformat");var b=x{"use strict";var n=r(84468),i=r(7605),o=r(64253).DESELECTDIM;e.exports={styleTextSelection:function(e){var t,r,a=e[0],s=a.trace,l=a.t,c=l._scene,u=l.index,d=c.selectBatch[u],h=c.unselectBatch[u],p=c.textOptions[u],f=c.textSelectedOptions[u]||{},m=c.textUnselectedOptions[u]||{},g=n.extendFlat({},p);if(d.length||h.length){var y=f.color,v=m.color,x=p.color,b=n.isArrayOrTypedArray(x);for(g.color=new Array(s._length),t=0;t{"use strict";var n=r(40777);e.exports=function(e,t,r){var i=e.i;return"x"in e||(e.x=t._x[i]),"y"in e||(e.y=t._y[i]),n(e,t,r)}},81728:(e,t,r)=>{"use strict";var n=r(12364);t.isOpenSymbol=function(e){return"string"===typeof e?n.OPEN_RE.test(e):e%200>100},t.isDotSymbol=function(e){return"string"===typeof e?n.DOT_RE.test(e):e>200}},31311:(e,t,r)=>{"use strict";var n=r(38361),i=r(84468),o=r(58864);function a(e,t,r,a){var s=e.xa,l=e.ya,c=e.distance,u=e.dxy,d=e.index,h={pointNumber:d,x:t[d],y:r[d]};h.tx=i.isArrayOrTypedArray(a.text)?a.text[d]:a.text,h.htx=Array.isArray(a.hovertext)?a.hovertext[d]:a.hovertext,h.data=Array.isArray(a.customdata)?a.customdata[d]:a.customdata,h.tp=Array.isArray(a.textposition)?a.textposition[d]:a.textposition;var p=a.textfont;p&&(h.ts=i.isArrayOrTypedArray(p.size)?p.size[d]:p.size,h.tc=i.isArrayOrTypedArray(p.color)?p.color[d]:p.color,h.tf=Array.isArray(p.family)?p.family[d]:p.family,h.tw=Array.isArray(p.weight)?p.weight[d]:p.weight,h.ty=Array.isArray(p.style)?p.style[d]:p.style,h.tv=Array.isArray(p.variant)?p.variant[d]:p.variant);var f=a.marker;f&&(h.ms=i.isArrayOrTypedArray(f.size)?f.size[d]:f.size,h.mo=i.isArrayOrTypedArray(f.opacity)?f.opacity[d]:f.opacity,h.mx=i.isArrayOrTypedArray(f.symbol)?f.symbol[d]:f.symbol,h.ma=i.isArrayOrTypedArray(f.angle)?f.angle[d]:f.angle,h.mc=i.isArrayOrTypedArray(f.color)?f.color[d]:f.color);var m=f&&f.line;m&&(h.mlc=Array.isArray(m.color)?m.color[d]:m.color,h.mlw=i.isArrayOrTypedArray(m.width)?m.width[d]:m.width);var g=f&&f.gradient;g&&"none"!==g.type&&(h.mgt=Array.isArray(g.type)?g.type[d]:g.type,h.mgc=Array.isArray(g.color)?g.color[d]:g.color);var y=s.c2p(h.x,!0),v=l.c2p(h.y,!0),x=h.mrc||1,b=a.hoverlabel;b&&(h.hbg=Array.isArray(b.bgcolor)?b.bgcolor[d]:b.bgcolor,h.hbc=Array.isArray(b.bordercolor)?b.bordercolor[d]:b.bordercolor,h.hts=i.isArrayOrTypedArray(b.font.size)?b.font.size[d]:b.font.size,h.htc=Array.isArray(b.font.color)?b.font.color[d]:b.font.color,h.htf=Array.isArray(b.font.family)?b.font.family[d]:b.font.family,h.hnl=i.isArrayOrTypedArray(b.namelength)?b.namelength[d]:b.namelength);var _=a.hoverinfo;_&&(h.hi=Array.isArray(_)?_[d]:_);var w=a.hovertemplate;w&&(h.ht=Array.isArray(w)?w[d]:w);var k={};k[e.index]=h;var S=a._origX,A=a._origY,T=i.extendFlat({},e,{color:o(a,h),x0:y-x,x1:y+x,xLabelVal:S?S[d]:h.x,y0:v-x,y1:v+x,yLabelVal:A?A[d]:h.y,cd:k,distance:c,spikeDistance:u,hovertemplate:h.ht});return h.htx?T.text=h.htx:h.tx?T.text=h.tx:a.text&&(T.text=a.text),i.fillText(h,a,T),n.getComponentMethod("errorbars","hoverInfo")(h,a,T),T}e.exports={hoverPoints:function(e,t,r,n){var i,o,s,l,c,u,d,h,p,f,m=e.cd,g=m[0].t,y=m[0].trace,v=e.xa,x=e.ya,b=g.x,_=g.y,w=v.c2p(t),k=x.c2p(r),S=e.distance;if(g.tree){var A=v.p2c(w-S),T=v.p2c(w+S),M=x.p2c(k-S),C=x.p2c(k+S);i="x"===n?g.tree.range(Math.min(A,T),Math.min(x._rl[0],x._rl[1]),Math.max(A,T),Math.max(x._rl[0],x._rl[1])):g.tree.range(Math.min(A,T),Math.min(M,C),Math.max(A,T),Math.max(M,C))}else i=g.ids;var E=S;if("x"===n){var I=!!y.xperiodalignment,P=!!y.yperiodalignment;for(u=0;u=Math.min(O,R)&&w<=Math.max(O,R)?0:1/0}if(d=Math.min(L,D)&&k<=Math.max(L,D)?0:1/0}f=Math.sqrt(d*d+h*h),s=i[u]}}}else for(u=i.length-1;u>-1;u--)l=b[o=i[u]],c=_[o],d=v.c2p(l)-w,h=x.c2p(c)-k,(p=Math.sqrt(d*d+h*h)){"use strict";var n=r(96951);n.plot=r(95674),e.exports=n},95674:(e,t,r)=>{"use strict";var n=r(50695),i=r(10545),o=r(30003),a=r(78481),s=r(84468),l=r(2705).selectMode,c=r(48488),u=r(31811),d=r(49313),h=r(88367).styleTextSelection,p={};function f(e,t,r,n){var i=e._size,o=e.width*n,a=e.height*n,s=i.l*n,l=i.b*n,c=i.r*n,u=i.t*n,d=i.w*n,h=i.h*n;return[s+t.domain[0]*d,l+r.domain[0]*h,o-c-(1-t.domain[1])*d,a-u-(1-r.domain[1])*h]}(e.exports=function(e,t,r){if(r.length){var m,g,y=e._fullLayout,v=t._scene,x=t.xaxis,b=t.yaxis;if(v)if(c(e,["ANGLE_instanced_arrays","OES_element_index_uint"],p)){var _=v.count,w=y._glcanvas.data()[0].regl;if(d(e,t,r),v.dirty){if(!v.line2d&&!v.error2d||v.scatter2d||v.fill2d||v.glText||w.clear({}),!0===v.error2d&&(v.error2d=o(w)),!0===v.line2d&&(v.line2d=i(w)),!0===v.scatter2d&&(v.scatter2d=n(w)),!0===v.fill2d&&(v.fill2d=i(w)),!0===v.glText)for(v.glText=new Array(_),m=0;m<_;m++)v.glText[m]=new a(w);if(v.glText){if(_>v.glText.length){var k=_-v.glText.length;for(m=0;mr&&(isNaN(t[n])||isNaN(t[n+1]));)n-=2;e.positions=t.slice(r,n+2)}return e})),v.line2d.update(v.lineOptions)),v.error2d){var A=(v.errorXOptions||[]).concat(v.errorYOptions||[]);v.error2d.update(A)}v.scatter2d&&v.scatter2d.update(v.markerOptions),v.fillOrder=s.repeat(null,_),v.fill2d&&(v.fillOptions=v.fillOptions.map((function(e,t){var n=r[t];if(e&&n&&n[0]&&n[0].trace){var i,o,a=n[0],s=a.trace,l=a.t,c=v.lineOptions[t],u=[];s._ownfill&&u.push(t),s._nexttrace&&u.push(t+1),u.length&&(v.fillOrder[t]=u);var d,h,p=[],f=c&&c.positions||l.positions;if("tozeroy"===s.fill){for(d=0;dd&&isNaN(f[h+1]);)h-=2;0!==f[d+1]&&(p=[f[d],0]),p=p.concat(f.slice(d,h+2)),0!==f[h+1]&&(p=p.concat([f[h],0]))}else if("tozerox"===s.fill){for(d=0;dd&&isNaN(f[h]);)h-=2;0!==f[d]&&(p=[0,f[d+1]]),p=p.concat(f.slice(d,h+2)),0!==f[h]&&(p=p.concat([0,f[h+1]]))}else if("toself"===s.fill||"tonext"===s.fill){for(p=[],i=0,e.splitNull=!0,o=0;o-1;for(m=0;m<_;m++){var E=r[m][0],I=E.trace,P=E.t,O=P.index,R=I._length,L=P.x,D=P.y;if(I.selectedpoints||M||C){if(M||(M=!0),I.selectedpoints){var z=v.selectBatch[O]=s.selIndices2selPoints(I),j={};for(g=0;g{"use strict";var n=r(84468);e.exports=function(e,t){var r=t._scene,i={count:0,dirty:!0,lineOptions:[],fillOptions:[],markerOptions:[],markerSelectedOptions:[],markerUnselectedOptions:[],errorXOptions:[],errorYOptions:[],textOptions:[],textSelectedOptions:[],textUnselectedOptions:[],selectBatch:[],unselectBatch:[]},o={fill2d:!1,scatter2d:!1,error2d:!1,line2d:!1,glText:!1,select2d:!1};return t._scene||((r=t._scene={}).init=function(){n.extendFlat(r,o,i)},r.init(),r.update=function(e){var t=n.repeat(e,r.count);if(r.fill2d&&r.fill2d.update(t),r.scatter2d&&r.scatter2d.update(t),r.line2d&&r.line2d.update(t),r.error2d&&r.error2d.update(t.concat(t)),r.select2d&&r.select2d.update(t),r.glText)for(var i=0;i{"use strict";var n=r(31811),i=r(88367).styleTextSelection;e.exports=function(e,t){var r=e.cd,o=e.xaxis,a=e.yaxis,s=[],l=r[0].trace,c=r[0].t,u=l._length,d=c.x,h=c.y,p=c._scene,f=c.index;if(!p)return s;var m=n.hasText(l),g=n.hasMarkers(l),y=!g&&!m;if(!0!==l.visible||y)return s;var v=[],x=[];if(!1!==t&&!t.degenerate)for(var b=0;b{"use strict";var n=r(84425).rb,i=r(84425).ay,o=r(50821),a=r(16490),s=r(22049),l=r(99696),c=r(75622),u=r(6636),d=r(64022).extendFlat,h=r(72587).overrideAll,p=r(99696),f=a.line,m=a.marker;e.exports=h({lon:a.lon,lat:a.lat,cluster:{enabled:{valType:"boolean",description:"Determines whether clustering is enabled or disabled."},maxzoom:d({},p.layers.maxzoom,{description:["Sets the maximum zoom level.","At zoom levels equal to or greater than this, points will never be clustered."].join(" ")}),step:{valType:"number",arrayOk:!0,dflt:-1,min:-1,description:["Sets how many points it takes to create a cluster or advance to the next cluster step.","Use this in conjunction with arrays for `size` and / or `color`.","If an integer, steps start at multiples of this number.","If an array, each step extends from the given value until one less than the next value."].join(" ")},size:{valType:"number",arrayOk:!0,dflt:20,min:0,description:["Sets the size for each cluster step."].join(" ")},color:{valType:"color",arrayOk:!0,description:["Sets the color for each cluster step."].join(" ")},opacity:d({},m.opacity,{dflt:1})},mode:d({},s.mode,{dflt:"markers",description:["Determines the drawing mode for this scatter trace.","If the provided `mode` includes *text* then the `text` elements","appear at the coordinates. Otherwise, the `text` elements","appear on hover."].join(" ")}),text:d({},s.text,{description:["Sets text elements associated with each (lon,lat) pair","If a single string, the same string appears over","all the data points.","If an array of string, the items are mapped in order to the","this trace's (lon,lat) coordinates.","If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,","these elements will be seen in the hover labels."].join(" ")}),texttemplate:i({editType:"plot"},{keys:["lat","lon","text"]}),hovertext:d({},s.hovertext,{description:["Sets hover text elements associated with each (lon,lat) pair","If a single string, the same string appears over","all the data points.","If an array of string, the items are mapped in order to the","this trace's (lon,lat) coordinates.","To be seen, trace `hoverinfo` must contain a *text* flag."].join(" ")}),line:{color:f.color,width:f.width},connectgaps:s.connectgaps,marker:d({symbol:{valType:"string",dflt:"circle",arrayOk:!0,description:["Sets the marker symbol.","Full list: https://www.map.com/maki-icons/","Note that the array `marker.color` and `marker.size`","are only available for *circle* symbols."].join(" ")},angle:{valType:"number",dflt:"auto",arrayOk:!0,description:["Sets the marker orientation from true North, in degrees clockwise.","When using the *auto* default, no rotation would be applied","in perspective views which is different from using a zero angle."].join(" ")},allowoverlap:{valType:"boolean",dflt:!1,description:["Flag to draw all symbols, even if they overlap."].join(" ")},opacity:m.opacity,size:m.size,sizeref:m.sizeref,sizemin:m.sizemin,sizemode:m.sizemode},u("marker")),fill:a.fill,fillcolor:o(),textfont:l.layers.symbol.textfont,textposition:l.layers.symbol.textposition,below:{valType:"string",description:["Determines if this scattermap trace's layers are to be inserted","before the layer with the specified ID.","By default, scattermap layers are inserted","above all the base layers.","To place the scattermap layers above every other layer, set `below` to *''*."].join(" ")},selected:{marker:s.selected.marker},unselected:{marker:s.unselected.marker},hoverinfo:d({},c.hoverinfo,{flags:["lon","lat","text","name"]}),hovertemplate:n()},"calc","nested")},11829:e=>{"use strict";var t=["Metropolis Black Italic","Metropolis Black","Metropolis Bold Italic","Metropolis Bold","Metropolis Extra Bold Italic","Metropolis Extra Bold","Metropolis Extra Light Italic","Metropolis Extra Light","Metropolis Light Italic","Metropolis Light","Metropolis Medium Italic","Metropolis Medium","Metropolis Regular Italic","Metropolis Regular","Metropolis Semi Bold Italic","Metropolis Semi Bold","Metropolis Thin Italic","Metropolis Thin","Open Sans Bold Italic","Open Sans Bold","Open Sans Extrabold Italic","Open Sans Extrabold","Open Sans Italic","Open Sans Light Italic","Open Sans Light","Open Sans Regular","Open Sans Semibold Italic","Open Sans Semibold","Klokantech Noto Sans Bold","Klokantech Noto Sans CJK Bold","Klokantech Noto Sans CJK Regular","Klokantech Noto Sans Italic","Klokantech Noto Sans Regular"];e.exports={isSupportedFont:function(e){return-1!==t.indexOf(e)}}},49959:(e,t,r)=>{"use strict";var n=r(22036),i=r(84468),o=r(65004).BADNUM,a=r(89385),s=r(39265),l=r(3172),c=r(14204),u=r(31811),d=r(11829).isSupportedFont,h=r(37888),p=r(82561).appendArrayPointValue,f=r(13480).NEWLINES,m=r(13480).BR_TAG_ALL;function g(e){return{type:e,geojson:a.makeBlank(),layout:{visibility:"none"},filter:null,paint:{}}}function y(e,t){return i.isArrayOrTypedArray(e)?t?function(t){return n(e[t])?+e[t]:0}:function(t){return e[t]}:e?function(){return e}:v}function v(){return""}function x(e){return e[0]===o}function b(e,t){var r;if(i.isArrayOrTypedArray(e)&&i.isArrayOrTypedArray(t)){r=["step",["get","point_count"],e[0]];for(var n=1;n850?" Black":i>750?" Extra Bold":i>650?" Bold":i>550?" Semi Bold":i>450?" Medium":i>350?" Regular":i>250?" Light":i>150?" Extra Light":" Thin"):"Open Sans"===o.slice(0,2).join(" ")?(s="Open Sans",s+=i>750?" Extrabold":i>650?" Bold":i>550?" Semibold":i>350?" Regular":" Light"):"Klokantech Noto Sans"===o.slice(0,3).join(" ")&&(s="Klokantech Noto Sans","CJK"===o[3]&&(s+=" CJK"),s+=i>500?" Bold":" Regular")),a&&(s+=" Italic"),"Open Sans Regular Italic"===s?s="Open Sans Italic":"Open Sans Regular Bold"===s?s="Open Sans Bold":"Open Sans Regular Bold Italic"===s?s="Open Sans Bold Italic":"Klokantech Noto Sans Regular Italic"===s&&(s="Klokantech Noto Sans Italic"),d(s)||(s=r),s.split(", ")}e.exports=function(e,t){var r,o=t[0].trace,d=!0===o.visible&&0!==o._length,w="none"!==o.fill,k=u.hasLines(o),S=u.hasMarkers(o),A=u.hasText(o),T=S&&"circle"===o.marker.symbol,M=S&&"circle"!==o.marker.symbol,C=o.cluster&&o.cluster.enabled,E=g("fill"),I=g("line"),P=g("circle"),O=g("symbol"),R={fill:E,line:I,circle:P,symbol:O};if(!d)return R;if((w||k)&&(r=a.calcTraceToLineCoords(t)),w&&(E.geojson=a.makePolygon(r),E.layout.visibility="visible",i.extendFlat(E.paint,{"fill-color":o.fillcolor})),k&&(I.geojson=a.makeLine(r),I.layout.visibility="visible",i.extendFlat(I.paint,{"line-width":o.line.width,"line-color":o.line.color,"line-opacity":o.opacity})),T){var L=function(e){var t,r,o,a,u=e[0].trace,d=u.marker,h=u.selectedpoints,p=i.isArrayOrTypedArray(d.color),f=i.isArrayOrTypedArray(d.size),m=i.isArrayOrTypedArray(d.opacity);function g(e){return u.opacity*e}function y(e){return e/2}p&&(r=s.hasColorscale(u,"marker")?s.makeColorScaleFuncFromTrace(d):i.identity);f&&(o=c(u));m&&(a=function(e){return g(n(e)?+i.constrain(e,0,1):0)});var v,b=[];for(t=0;t{"use strict";var n=r(84468),i=r(31811),o=r(93379),a=r(1091),s=r(80272),l=r(7751),c=r(5427),u=r(11829).isSupportedFont;e.exports=function(e,t,r,d){function h(r,i){return n.coerce(e,t,c,r,i)}function p(r,i){return n.coerce2(e,t,c,r,i)}var f=function(e,t,r){var n=r("lon")||[],i=r("lat")||[],o=Math.min(n.length,i.length);return t._length=o,o}(0,t,h);if(f){if(h("text"),h("texttemplate"),h("hovertext"),h("hovertemplate"),h("mode"),h("below"),i.hasMarkers(t)){o(e,t,r,d,h,{noLine:!0,noAngle:!0}),h("marker.allowoverlap"),h("marker.angle");var m=t.marker;"circle"!==m.symbol&&(n.isArrayOrTypedArray(m.size)&&(m.size=m.size[0]),n.isArrayOrTypedArray(m.color)&&(m.color=m.color[0]))}i.hasLines(t)&&(a(e,t,r,d,h,{noDash:!0}),h("connectgaps"));var g=p("cluster.maxzoom"),y=p("cluster.step"),v=p("cluster.color",t.marker&&t.marker.color||r),x=p("cluster.size"),b=p("cluster.opacity");if(h("cluster.enabled",!1!==g||!1!==y||!1!==v||!1!==x||!1!==b)||i.hasText(t)){var _=d.font.family;s(e,t,d,h,{noSelect:!0,noFontVariant:!0,noFontShadow:!0,noFontLineposition:!0,noFontTextcase:!0,font:{family:u(_)?_:"Open Sans Regular",weight:d.font.weight,style:d.font.style,size:d.font.size,color:d.font.color}})}h("fill"),"none"!==t.fill&&l(e,t,r,h),n.coerceSelectionMarkerOpacity(t,h)}else t.visible=!1}},81287:e=>{"use strict";e.exports=function(e,t){return e.lon=t.lon,e.lat=t.lat,e}},5043:(e,t,r)=>{"use strict";var n=r(85729);e.exports=function(e,t,r){var i={},o=r[t.subplot]._subplot.mockAxis,a=e.lonlat;return i.lonLabel=n.tickText(o,o.c2l(a[0]),!0).text,i.latLabel=n.tickText(o,o.c2l(a[1]),!0).text,i}},42206:(e,t,r)=>{"use strict";var n=r(32212),i=r(84468),o=r(58864),a=i.fillText,s=r(65004).BADNUM,l=r(76687).traceLayerPrefix;function c(e,t,r){if(!e.hovertemplate){var n=(t.hi||e.hoverinfo).split("+"),i=-1!==n.indexOf("all"),o=-1!==n.indexOf("lon"),s=-1!==n.indexOf("lat"),l=t.lonlat,c=[];return i||o&&s?c.push("("+u(l[1])+", "+u(l[0])+")"):o?c.push(r.lon+u(l[0])):s&&c.push(r.lat+u(l[1])),(i||-1!==n.indexOf("text"))&&a(t,e,c),c.join("
")}function u(e){return e+"\xb0"}}e.exports={hoverPoints:function(e,t,r){var a=e.cd,u=a[0].trace,d=e.xa,h=e.ya,p=e.subplot,f=[],m=l+u.uid+"-circle",g=u.cluster&&u.cluster.enabled;if(g){var y=p.map.queryRenderedFeatures(null,{layers:[m]});f=y.map((function(e){return e.id}))}var v=360*(t>=0?Math.floor((t+180)/360):Math.ceil((t-180)/360)),x=t-v;if(n.getClosest(a,(function(e){var t=e.lonlat;if(t[0]===s)return 1/0;if(g&&-1===f.indexOf(e.i+1))return 1/0;var n=i.modHalf(t[0],360),o=t[1],a=p.project([n,o]),l=a.x-d.c2p([x,o]),c=a.y-h.c2p([n,r]),u=Math.max(3,e.mrc||0);return Math.max(Math.sqrt(l*l+c*c)-u,1-3/u)}),e),!1!==e.index){var b=a[e.index],_=b.lonlat,w=[i.modHalf(_[0],360)+v,_[1]],k=d.c2p(w),S=h.c2p(w),A=b.mrc||1;e.x0=k-A,e.x1=k+A,e.y0=S-A,e.y1=S+A;var T={};T[u.subplot]={_subplot:p};var M=u._module.formatLabels(b,u,T);return e.lonLabel=M.lonLabel,e.latLabel=M.latLabel,e.color=o(u,b),e.extraText=c(u,b,a[0].t.labels),e.hovertemplate=u.hovertemplate,[e]}},getExtraText:c}},89779:(e,t,r)=>{"use strict";e.exports={attributes:r(5427),supplyDefaults:r(27796),colorbar:r(17789),formatLabels:r(5043),calc:r(36038),plot:r(30365),hoverPoints:r(42206).hoverPoints,eventData:r(81287),selectPoints:r(21758),styleOnSelect:function(e,t){t&&t[0].trace._glTrace.update(t)},moduleType:"trace",name:"scattermap",basePlotModule:r(29534),categories:["map","gl","symbols","showLegend","scatter-like"],meta:{hrName:"scatter_map",description:["The data visualized as scatter point, lines or marker symbols","on a MapLibre GL geographic map","is provided by longitude/latitude pairs in `lon` and `lat`."].join(" ")}}},30365:(e,t,r)=>{"use strict";var n=r(84468),i=r(49959),o=r(76687).traceLayerPrefix,a={cluster:["cluster","clusterCount","circle"],nonCluster:["fill","line","circle","symbol"]};function s(e,t,r,n){this.type="scattermap",this.subplot=e,this.uid=t,this.clusterEnabled=r,this.isHidden=n,this.sourceIds={fill:"source-"+t+"-fill",line:"source-"+t+"-line",circle:"source-"+t+"-circle",symbol:"source-"+t+"-symbol",cluster:"source-"+t+"-circle",clusterCount:"source-"+t+"-circle"},this.layerIds={fill:o+t+"-fill",line:o+t+"-line",circle:o+t+"-circle",symbol:o+t+"-symbol",cluster:o+t+"-cluster",clusterCount:o+t+"-cluster-count"},this.below=null}var l=s.prototype;l.addSource=function(e,t,r){var i={type:"geojson",data:t.geojson};r&&r.enabled&&n.extendFlat(i,{cluster:!0,clusterMaxZoom:r.maxzoom});var o=this.subplot.map.getSource(this.sourceIds[e]);o?o.setData(t.geojson):this.subplot.map.addSource(this.sourceIds[e],i)},l.setSourceData=function(e,t){this.subplot.map.getSource(this.sourceIds[e]).setData(t.geojson)},l.addLayer=function(e,t,r){var n={type:t.type,id:this.layerIds[e],source:this.sourceIds[e],layout:t.layout,paint:t.paint};t.filter&&(n.filter=t.filter);for(var i,o=this.layerIds[e],a=this.subplot.getMapLayers(),s=0;s=0;r--){var i=t[r];n.removeLayer(u.layerIds[i])}e||n.removeSource(u.sourceIds.circle)}(e):function(e){for(var t=a.nonCluster,r=t.length-1;r>=0;r--){var i=t[r];n.removeLayer(u.layerIds[i]),e||n.removeSource(u.sourceIds[i])}}(e)}function h(e){l?function(e){e||u.addSource("circle",o.circle,t.cluster);for(var r=a.cluster,n=0;n=0;r--){var n=t[r];e.removeLayer(this.layerIds[n]),e.removeSource(this.sourceIds[n])}},e.exports=function(e,t){var r,n,o,l=t[0].trace,c=l.cluster&&l.cluster.enabled,u=!0!==l.visible,d=new s(e,l.uid,c,u),h=i(e.gd,t),p=d.below=e.belowLookup["trace-"+l.uid];if(c)for(d.addSource("circle",h.circle,l.cluster),r=0;r{"use strict";var n=r(84468),i=r(31811),o=r(65004).BADNUM;e.exports=function(e,t){var r,a=e.cd,s=e.xaxis,l=e.yaxis,c=[],u=a[0].trace;if(!i.hasMarkers(u))return[];if(!1===t)for(r=0;r{"use strict";var n=r(84425).rb,i=r(84425).ay,o=r(50821),a=r(16490),s=r(22049),l=r(6185),c=r(75622),u=r(6636),d=r(64022).extendFlat,h=r(72587).overrideAll,p=r(6185),f=a.line,m=a.marker;e.exports=h({lon:a.lon,lat:a.lat,cluster:{enabled:{valType:"boolean",description:"Determines whether clustering is enabled or disabled."},maxzoom:d({},p.layers.maxzoom,{description:["Sets the maximum zoom level.","At zoom levels equal to or greater than this, points will never be clustered."].join(" ")}),step:{valType:"number",arrayOk:!0,dflt:-1,min:-1,description:["Sets how many points it takes to create a cluster or advance to the next cluster step.","Use this in conjunction with arrays for `size` and / or `color`.","If an integer, steps start at multiples of this number.","If an array, each step extends from the given value until one less than the next value."].join(" ")},size:{valType:"number",arrayOk:!0,dflt:20,min:0,description:["Sets the size for each cluster step."].join(" ")},color:{valType:"color",arrayOk:!0,description:["Sets the color for each cluster step."].join(" ")},opacity:d({},m.opacity,{dflt:1})},mode:d({},s.mode,{dflt:"markers",description:["Determines the drawing mode for this scatter trace.","If the provided `mode` includes *text* then the `text` elements","appear at the coordinates. Otherwise, the `text` elements","appear on hover."].join(" ")}),text:d({},s.text,{description:["Sets text elements associated with each (lon,lat) pair","If a single string, the same string appears over","all the data points.","If an array of string, the items are mapped in order to the","this trace's (lon,lat) coordinates.","If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,","these elements will be seen in the hover labels."].join(" ")}),texttemplate:i({editType:"plot"},{keys:["lat","lon","text"]}),hovertext:d({},s.hovertext,{description:["Sets hover text elements associated with each (lon,lat) pair","If a single string, the same string appears over","all the data points.","If an array of string, the items are mapped in order to the","this trace's (lon,lat) coordinates.","To be seen, trace `hoverinfo` must contain a *text* flag."].join(" ")}),line:{color:f.color,width:f.width},connectgaps:s.connectgaps,marker:d({symbol:{valType:"string",dflt:"circle",arrayOk:!0,description:["Sets the marker symbol.","Full list: https://www.mapbox.com/maki-icons/","Note that the array `marker.color` and `marker.size`","are only available for *circle* symbols."].join(" ")},angle:{valType:"number",dflt:"auto",arrayOk:!0,description:["Sets the marker orientation from true North, in degrees clockwise.","When using the *auto* default, no rotation would be applied","in perspective views which is different from using a zero angle."].join(" ")},allowoverlap:{valType:"boolean",dflt:!1,description:["Flag to draw all symbols, even if they overlap."].join(" ")},opacity:m.opacity,size:m.size,sizeref:m.sizeref,sizemin:m.sizemin,sizemode:m.sizemode},u("marker")),fill:a.fill,fillcolor:o(),textfont:l.layers.symbol.textfont,textposition:l.layers.symbol.textposition,below:{valType:"string",description:["Determines if this scattermapbox trace's layers are to be inserted","before the layer with the specified ID.","By default, scattermapbox layers are inserted","above all the base layers.","To place the scattermapbox layers above every other layer, set `below` to *''*."].join(" ")},selected:{marker:s.selected.marker},unselected:{marker:s.unselected.marker},hoverinfo:d({},c.hoverinfo,{flags:["lon","lat","text","name"]}),hovertemplate:n()},"calc","nested")},29520:e=>{"use strict";var t=["Metropolis Black Italic","Metropolis Black","Metropolis Bold Italic","Metropolis Bold","Metropolis Extra Bold Italic","Metropolis Extra Bold","Metropolis Extra Light Italic","Metropolis Extra Light","Metropolis Light Italic","Metropolis Light","Metropolis Medium Italic","Metropolis Medium","Metropolis Regular Italic","Metropolis Regular","Metropolis Semi Bold Italic","Metropolis Semi Bold","Metropolis Thin Italic","Metropolis Thin","Open Sans Bold Italic","Open Sans Bold","Open Sans Extrabold Italic","Open Sans Extrabold","Open Sans Italic","Open Sans Light Italic","Open Sans Light","Open Sans Regular","Open Sans Semibold Italic","Open Sans Semibold","Klokantech Noto Sans Bold","Klokantech Noto Sans CJK Bold","Klokantech Noto Sans CJK Regular","Klokantech Noto Sans Italic","Klokantech Noto Sans Regular"];e.exports={isSupportedFont:function(e){return-1!==t.indexOf(e)}}},56706:(e,t,r)=>{"use strict";var n=r(22036),i=r(84468),o=r(65004).BADNUM,a=r(89385),s=r(39265),l=r(3172),c=r(14204),u=r(31811),d=r(29520).isSupportedFont,h=r(25065),p=r(82561).appendArrayPointValue,f=r(13480).NEWLINES,m=r(13480).BR_TAG_ALL;function g(e){return{type:e,geojson:a.makeBlank(),layout:{visibility:"none"},filter:null,paint:{}}}function y(e,t){return i.isArrayOrTypedArray(e)?t?function(t){return n(e[t])?+e[t]:0}:function(t){return e[t]}:e?function(){return e}:v}function v(){return""}function x(e){return e[0]===o}function b(e,t){var r;if(i.isArrayOrTypedArray(e)&&i.isArrayOrTypedArray(t)){r=["step",["get","point_count"],e[0]];for(var n=1;n850?" Black":i>750?" Extra Bold":i>650?" Bold":i>550?" Semi Bold":i>450?" Medium":i>350?" Regular":i>250?" Light":i>150?" Extra Light":" Thin"):"Open Sans"===o.slice(0,2).join(" ")?(s="Open Sans",s+=i>750?" Extrabold":i>650?" Bold":i>550?" Semibold":i>350?" Regular":" Light"):"Klokantech Noto Sans"===o.slice(0,3).join(" ")&&(s="Klokantech Noto Sans","CJK"===o[3]&&(s+=" CJK"),s+=i>500?" Bold":" Regular")),a&&(s+=" Italic"),"Open Sans Regular Italic"===s?s="Open Sans Italic":"Open Sans Regular Bold"===s?s="Open Sans Bold":"Open Sans Regular Bold Italic"===s?s="Open Sans Bold Italic":"Klokantech Noto Sans Regular Italic"===s&&(s="Klokantech Noto Sans Italic"),d(s)||(s=r),s.split(", ")}e.exports=function(e,t){var r,o=t[0].trace,d=!0===o.visible&&0!==o._length,w="none"!==o.fill,k=u.hasLines(o),S=u.hasMarkers(o),A=u.hasText(o),T=S&&"circle"===o.marker.symbol,M=S&&"circle"!==o.marker.symbol,C=o.cluster&&o.cluster.enabled,E=g("fill"),I=g("line"),P=g("circle"),O=g("symbol"),R={fill:E,line:I,circle:P,symbol:O};if(!d)return R;if((w||k)&&(r=a.calcTraceToLineCoords(t)),w&&(E.geojson=a.makePolygon(r),E.layout.visibility="visible",i.extendFlat(E.paint,{"fill-color":o.fillcolor})),k&&(I.geojson=a.makeLine(r),I.layout.visibility="visible",i.extendFlat(I.paint,{"line-width":o.line.width,"line-color":o.line.color,"line-opacity":o.opacity})),T){var L=function(e){var t,r,o,a,u=e[0].trace,d=u.marker,h=u.selectedpoints,p=i.isArrayOrTypedArray(d.color),f=i.isArrayOrTypedArray(d.size),m=i.isArrayOrTypedArray(d.opacity);function g(e){return u.opacity*e}function y(e){return e/2}p&&(r=s.hasColorscale(u,"marker")?s.makeColorScaleFuncFromTrace(d):i.identity);f&&(o=c(u));m&&(a=function(e){return g(n(e)?+i.constrain(e,0,1):0)});var v,b=[];for(t=0;t{"use strict";var n=r(84468),i=r(31811),o=r(93379),a=r(1091),s=r(80272),l=r(7751),c=r(2244),u=r(29520).isSupportedFont;e.exports=function(e,t,r,d){function h(r,i){return n.coerce(e,t,c,r,i)}function p(r,i){return n.coerce2(e,t,c,r,i)}var f=function(e,t,r){var n=r("lon")||[],i=r("lat")||[],o=Math.min(n.length,i.length);return t._length=o,o}(0,t,h);if(f){if(h("text"),h("texttemplate"),h("hovertext"),h("hovertemplate"),h("mode"),h("below"),i.hasMarkers(t)){o(e,t,r,d,h,{noLine:!0,noAngle:!0}),h("marker.allowoverlap"),h("marker.angle");var m=t.marker;"circle"!==m.symbol&&(n.isArrayOrTypedArray(m.size)&&(m.size=m.size[0]),n.isArrayOrTypedArray(m.color)&&(m.color=m.color[0]))}i.hasLines(t)&&(a(e,t,r,d,h,{noDash:!0}),h("connectgaps"));var g=p("cluster.maxzoom"),y=p("cluster.step"),v=p("cluster.color",t.marker&&t.marker.color||r),x=p("cluster.size"),b=p("cluster.opacity");if(h("cluster.enabled",!1!==g||!1!==y||!1!==v||!1!==x||!1!==b)||i.hasText(t)){var _=d.font.family;s(e,t,d,h,{noSelect:!0,noFontVariant:!0,noFontShadow:!0,noFontLineposition:!0,noFontTextcase:!0,font:{family:u(_)?_:"Open Sans Regular",weight:d.font.weight,style:d.font.style,size:d.font.size,color:d.font.color}})}h("fill"),"none"!==t.fill&&l(e,t,r,h),n.coerceSelectionMarkerOpacity(t,h)}else t.visible=!1}},10264:e=>{"use strict";e.exports=function(e,t){return e.lon=t.lon,e.lat=t.lat,e}},74466:(e,t,r)=>{"use strict";var n=r(85729);e.exports=function(e,t,r){var i={},o=r[t.subplot]._subplot.mockAxis,a=e.lonlat;return i.lonLabel=n.tickText(o,o.c2l(a[0]),!0).text,i.latLabel=n.tickText(o,o.c2l(a[1]),!0).text,i}},98835:(e,t,r)=>{"use strict";var n=r(32212),i=r(84468),o=r(58864),a=i.fillText,s=r(65004).BADNUM,l=r(26966).traceLayerPrefix;function c(e,t,r){if(!e.hovertemplate){var n=(t.hi||e.hoverinfo).split("+"),i=-1!==n.indexOf("all"),o=-1!==n.indexOf("lon"),s=-1!==n.indexOf("lat"),l=t.lonlat,c=[];return i||o&&s?c.push("("+u(l[1])+", "+u(l[0])+")"):o?c.push(r.lon+u(l[0])):s&&c.push(r.lat+u(l[1])),(i||-1!==n.indexOf("text"))&&a(t,e,c),c.join("
")}function u(e){return e+"\xb0"}}e.exports={hoverPoints:function(e,t,r){var a=e.cd,u=a[0].trace,d=e.xa,h=e.ya,p=e.subplot,f=[],m=l+u.uid+"-circle",g=u.cluster&&u.cluster.enabled;if(g){var y=p.map.queryRenderedFeatures(null,{layers:[m]});f=y.map((function(e){return e.id}))}var v=360*(t>=0?Math.floor((t+180)/360):Math.ceil((t-180)/360)),x=t-v;if(n.getClosest(a,(function(e){var t=e.lonlat;if(t[0]===s)return 1/0;if(g&&-1===f.indexOf(e.i+1))return 1/0;var n=i.modHalf(t[0],360),o=t[1],a=p.project([n,o]),l=a.x-d.c2p([x,o]),c=a.y-h.c2p([n,r]),u=Math.max(3,e.mrc||0);return Math.max(Math.sqrt(l*l+c*c)-u,1-3/u)}),e),!1!==e.index){var b=a[e.index],_=b.lonlat,w=[i.modHalf(_[0],360)+v,_[1]],k=d.c2p(w),S=h.c2p(w),A=b.mrc||1;e.x0=k-A,e.x1=k+A,e.y0=S-A,e.y1=S+A;var T={};T[u.subplot]={_subplot:p};var M=u._module.formatLabels(b,u,T);return e.lonLabel=M.lonLabel,e.latLabel=M.latLabel,e.color=o(u,b),e.extraText=c(u,b,a[0].t.labels),e.hovertemplate=u.hovertemplate,[e]}},getExtraText:c}},97321:(e,t,r)=>{"use strict";var n=["*scattermapbox* trace is deprecated!","Please consider switching to the *scattermap* trace type and `map` subplots.","Learn more at: https://plotly.com/javascript/maplibre-migration/"].join(" ");e.exports={attributes:r(2244),supplyDefaults:r(90835),colorbar:r(17789),formatLabels:r(74466),calc:r(36038),plot:r(21702),hoverPoints:r(98835).hoverPoints,eventData:r(10264),selectPoints:r(2501),styleOnSelect:function(e,t){t&&t[0].trace._glTrace.update(t)},moduleType:"trace",name:"scattermapbox",basePlotModule:r(81587),categories:["mapbox","gl","symbols","showLegend","scatter-like"],meta:{hrName:"scatter_mapbox",description:[n,"The data visualized as scatter point, lines or marker symbols","on a Mapbox GL geographic map","is provided by longitude/latitude pairs in `lon` and `lat`."].join(" ")}}},21702:(e,t,r)=>{"use strict";var n=r(84468),i=r(56706),o=r(26966).traceLayerPrefix,a={cluster:["cluster","clusterCount","circle"],nonCluster:["fill","line","circle","symbol"]};function s(e,t,r,n){this.type="scattermapbox",this.subplot=e,this.uid=t,this.clusterEnabled=r,this.isHidden=n,this.sourceIds={fill:"source-"+t+"-fill",line:"source-"+t+"-line",circle:"source-"+t+"-circle",symbol:"source-"+t+"-symbol",cluster:"source-"+t+"-circle",clusterCount:"source-"+t+"-circle"},this.layerIds={fill:o+t+"-fill",line:o+t+"-line",circle:o+t+"-circle",symbol:o+t+"-symbol",cluster:o+t+"-cluster",clusterCount:o+t+"-cluster-count"},this.below=null}var l=s.prototype;l.addSource=function(e,t,r){var i={type:"geojson",data:t.geojson};r&&r.enabled&&n.extendFlat(i,{cluster:!0,clusterMaxZoom:r.maxzoom});var o=this.subplot.map.getSource(this.sourceIds[e]);o?o.setData(t.geojson):this.subplot.map.addSource(this.sourceIds[e],i)},l.setSourceData=function(e,t){this.subplot.map.getSource(this.sourceIds[e]).setData(t.geojson)},l.addLayer=function(e,t,r){var n={type:t.type,id:this.layerIds[e],source:this.sourceIds[e],layout:t.layout,paint:t.paint};t.filter&&(n.filter=t.filter);for(var i,o=this.layerIds[e],a=this.subplot.getMapLayers(),s=0;s=0;r--){var i=t[r];n.removeLayer(u.layerIds[i])}e||n.removeSource(u.sourceIds.circle)}(e):function(e){for(var t=a.nonCluster,r=t.length-1;r>=0;r--){var i=t[r];n.removeLayer(u.layerIds[i]),e||n.removeSource(u.sourceIds[i])}}(e)}function h(e){l?function(e){e||u.addSource("circle",o.circle,t.cluster);for(var r=a.cluster,n=0;n=0;r--){var n=t[r];e.removeLayer(this.layerIds[n]),e.removeSource(this.sourceIds[n])}},e.exports=function(e,t){var r,n,o,l=t[0].trace,c=l.cluster&&l.cluster.enabled,u=!0!==l.visible,d=new s(e,l.uid,c,u),h=i(e.gd,t),p=d.below=e.belowLookup["trace-"+l.uid];if(c)for(d.addSource("circle",h.circle,l.cluster),r=0;r{"use strict";var n=r(84468),i=r(31811),o=r(65004).BADNUM;e.exports=function(e,t){var r,a=e.cd,s=e.xaxis,l=e.yaxis,c=[],u=a[0].trace;if(!i.hasMarkers(u))return[];if(!1===t)for(r=0;r{"use strict";var n=r(84425).rb,i=r(84425).ay,o=r(64022).extendFlat,a=r(50821),s=r(22049),l=r(75622),c=s.line;e.exports={mode:s.mode,r:{valType:"data_array",editType:"calc+clearAxisTypes",description:"Sets the radial coordinates"},theta:{valType:"data_array",editType:"calc+clearAxisTypes",description:"Sets the angular coordinates"},r0:{valType:"any",dflt:0,editType:"calc+clearAxisTypes",description:["Alternate to `r`.","Builds a linear space of r coordinates.","Use with `dr`","where `r0` is the starting coordinate and `dr` the step."].join(" ")},dr:{valType:"number",dflt:1,editType:"calc",description:"Sets the r coordinate step."},theta0:{valType:"any",dflt:0,editType:"calc+clearAxisTypes",description:["Alternate to `theta`.","Builds a linear space of theta coordinates.","Use with `dtheta`","where `theta0` is the starting coordinate and `dtheta` the step."].join(" ")},dtheta:{valType:"number",editType:"calc",description:["Sets the theta coordinate step.","By default, the `dtheta` step equals the subplot's period divided","by the length of the `r` coordinates."].join(" ")},thetaunit:{valType:"enumerated",values:["radians","degrees","gradians"],dflt:"degrees",editType:"calc+clearAxisTypes",description:["Sets the unit of input *theta* values.","Has an effect only when on *linear* angular axes."].join(" ")},text:s.text,texttemplate:i({editType:"plot"},{keys:["r","theta","text"]}),hovertext:s.hovertext,line:{color:c.color,width:c.width,dash:c.dash,backoff:c.backoff,shape:o({},c.shape,{values:["linear","spline"]}),smoothing:c.smoothing,editType:"calc"},connectgaps:s.connectgaps,marker:s.marker,cliponaxis:o({},s.cliponaxis,{dflt:!1}),textposition:s.textposition,textfont:s.textfont,fill:o({},s.fill,{values:["none","toself","tonext"],dflt:"none",description:["Sets the area to fill with a solid color.","Use with `fillcolor` if not *none*.","scatterpolar has a subset of the options available to scatter.","*toself* connects the endpoints of the trace (or each segment","of the trace if it has gaps) into a closed shape.","*tonext* fills the space between two traces if one completely","encloses the other (eg consecutive contour lines), and behaves like","*toself* if there is no trace before it. *tonext* should not be","used if one trace does not enclose the other."].join(" ")}),fillcolor:a(),hoverinfo:o({},l.hoverinfo,{flags:["r","theta","text","name"]}),hoveron:s.hoveron,hovertemplate:n(),selected:s.selected,unselected:s.unselected}},97805:(e,t,r)=>{"use strict";var n=r(22036),i=r(65004).BADNUM,o=r(85729),a=r(85387),s=r(24294),l=r(40304),c=r(20389).calcMarkerSize;e.exports=function(e,t){for(var r=e._fullLayout,u=t.subplot,d=r[u].radialaxis,h=r[u].angularaxis,p=d.makeCalcdata(t,"r"),f=h.makeCalcdata(t,"theta"),m=t._length,g=new Array(m),y=0;y{"use strict";var n=r(84468),i=r(31811),o=r(93379),a=r(1091),s=r(33381),l=r(80272),c=r(7751),u=r(56003).PTS_LINESONLY,d=r(18889);function h(e,t,r,i){var o,a=i("r"),s=i("theta");if(n.isTypedArray(a)&&(t.r=a=Array.from(a)),n.isTypedArray(s)&&(t.theta=s=Array.from(s)),a)s?o=Math.min(a.length,s.length):(o=a.length,i("theta0"),i("dtheta"));else{if(!s)return 0;o=t.theta.length,i("r0"),i("dr")}return t._length=o,o}e.exports={handleRThetaDefaults:h,supplyDefaults:function(e,t,r,p){function f(r,i){return n.coerce(e,t,d,r,i)}var m=h(e,t,p,f);if(m){f("thetaunit"),f("mode",m{"use strict";var n=r(84468),i=r(85729);e.exports=function(e,t,r){var o,a,s={},l=r[t.subplot]._subplot;l?(o=l.radialAxis,a=l.angularAxis):(o=(l=r[t.subplot]).radialaxis,a=l.angularaxis);var c=o.c2l(e.r);s.rLabel=i.tickText(o,c,!0).text;var u="degrees"===a.thetaunit?n.rad2deg(e.theta):e.theta;return s.thetaLabel=i.tickText(a,u,!0).text,s}},99152:(e,t,r)=>{"use strict";var n=r(32168);function i(e,t,r,n){var i=r.radialAxis,o=r.angularAxis;i._hovertitle="r",o._hovertitle="\u03b8";var a={};a[t.subplot]={_subplot:r};var s=t._module.formatLabels(e,t,a);n.rLabel=s.rLabel,n.thetaLabel=s.thetaLabel;var l=e.hi||t.hoverinfo,c=[];function u(e,t){c.push(e._hovertitle+": "+t)}if(!t.hovertemplate){var d=l.split("+");-1!==d.indexOf("all")&&(d=["r","theta","text"]),-1!==d.indexOf("r")&&u(i,n.rLabel),-1!==d.indexOf("theta")&&u(o,n.thetaLabel),-1!==d.indexOf("text")&&n.text&&(c.push(n.text),delete n.text),n.extraText=c.join("
")}}e.exports={hoverPoints:function(e,t,r,o){var a=n(e,t,r,o);if(a&&!1!==a[0].index){var s=a[0];if(void 0===s.index)return a;var l=e.subplot,c=s.cd[s.index],u=s.trace;if(l.isPtInside(c))return s.xLabelVal=void 0,s.yLabelVal=void 0,i(c,u,l,s),s.hovertemplate=u.hovertemplate,a}},makeHoverPointText:i}},54026:(e,t,r)=>{"use strict";e.exports={moduleType:"trace",name:"scatterpolar",basePlotModule:r(76016),categories:["polar","symbols","showLegend","scatter-like"],attributes:r(18889),supplyDefaults:r(19150).supplyDefaults,colorbar:r(17789),formatLabels:r(87009),calc:r(97805),plot:r(80131),style:r(47323).style,styleOnSelect:r(47323).styleOnSelect,hoverPoints:r(99152).hoverPoints,selectPoints:r(57112),meta:{hrName:"scatter_polar",description:["The scatterpolar trace type encompasses line charts, scatter charts, text charts, and bubble charts","in polar coordinates.","The data visualized as scatter point or lines is set in","`r` (radial) and `theta` (angular) coordinates","Text (appearing either on the chart or on hover only) is via `text`.","Bubble charts are achieved by setting `marker.size` and/or `marker.color`","to numerical arrays."].join(" ")}}},80131:(e,t,r)=>{"use strict";var n=r(34923),i=r(65004).BADNUM;e.exports=function(e,t,r){for(var o=t.layers.frontplot.select("g.scatterlayer"),a=t.xaxis,s=t.yaxis,l={xaxis:a,yaxis:s,plot:t.framework,layerClipId:t._hasClipOnAxisFalse?t.clipIds.forTraces:null},c=t.radialAxis,u=t.angularAxis,d=0;d{"use strict";var n=r(18889),i=r(86600),o=r(84425).ay;e.exports={mode:n.mode,r:n.r,theta:n.theta,r0:n.r0,dr:n.dr,theta0:n.theta0,dtheta:n.dtheta,thetaunit:n.thetaunit,text:n.text,texttemplate:o({editType:"plot"},{keys:["r","theta","text"]}),hovertext:n.hovertext,hovertemplate:n.hovertemplate,line:{color:i.line.color,width:i.line.width,dash:i.line.dash,editType:"calc"},connectgaps:i.connectgaps,marker:i.marker,fill:i.fill,fillcolor:i.fillcolor,textposition:i.textposition,textfont:i.textfont,hoverinfo:n.hoverinfo,selected:n.selected,unselected:n.unselected}},77727:(e,t,r)=>{"use strict";e.exports={moduleType:"trace",name:"scatterpolargl",basePlotModule:r(76016),categories:["gl","regl","polar","symbols","showLegend","scatter-like"],attributes:r(36384),supplyDefaults:r(9655),colorbar:r(17789),formatLabels:r(49822),calc:r(46160),hoverPoints:r(94695).hoverPoints,selectPoints:r(77761),meta:{hrName:"scatter_polar_gl",description:["The scatterpolargl trace type encompasses line charts, scatter charts, and bubble charts","in polar coordinates using the WebGL plotting engine.","The data visualized as scatter point or lines is set in","`r` (radial) and `theta` (angular) coordinates","Bubble charts are achieved by setting `marker.size` and/or `marker.color`","to numerical arrays."].join(" ")}}},46160:(e,t,r)=>{"use strict";var n=r(85387),i=r(20389).calcMarkerSize,o=r(36398),a=r(85729),s=r(12364).TOO_MANY_POINTS;e.exports=function(e,t){var r=e._fullLayout,l=t.subplot,c=r[l].radialaxis,u=r[l].angularaxis,d=t._r=c.makeCalcdata(t,"r"),h=t._theta=u.makeCalcdata(t,"theta"),p=t._length,f={};p{"use strict";var n=r(84468),i=r(31811),o=r(19150).handleRThetaDefaults,a=r(93379),s=r(1091),l=r(80272),c=r(7751),u=r(56003).PTS_LINESONLY,d=r(36384);e.exports=function(e,t,r,h){function p(r,i){return n.coerce(e,t,d,r,i)}var f=o(e,t,h,p);f?(p("thetaunit"),p("mode",f{"use strict";var n=r(87009);e.exports=function(e,t,r){var i=e.i;return"r"in e||(e.r=t._r[i]),"theta"in e||(e.theta=t._theta[i]),n(e,t,r)}},94695:(e,t,r)=>{"use strict";var n=r(31311),i=r(99152).makeHoverPointText;e.exports={hoverPoints:function(e,t,r,o){var a=e.cd[0].t,s=a.r,l=a.theta,c=n.hoverPoints(e,t,r,o);if(c&&!1!==c[0].index){var u=c[0];if(void 0===u.index)return c;var d=e.subplot,h=u.cd[u.index],p=u.trace;if(h.r=s[u.index],h.theta=l[u.index],d.isPtInside(h))return u.xLabelVal=void 0,u.yLabelVal=void 0,i(h,p,d,u),c}}}},80477:(e,t,r)=>{"use strict";var n=r(77727);n.plot=r(29090),e.exports=n},29090:(e,t,r)=>{"use strict";var n=r(2210),i=r(22036),o=r(95674),a=r(5093),s=r(36398),l=r(84468),c=r(12364).TOO_MANY_POINTS;e.exports=function(e,t,r){if(r.length){var u=t.radialAxis,d=t.angularAxis,h=a(e,t);return r.forEach((function(r){if(r&&r[0]&&r[0].trace){var o,a=r[0],p=a.trace,f=a.t,m=p._length,g=f.r,y=f.theta,v=f.opts,x=g.slice(),b=y.slice();for(o=0;o=c&&(v.marker.cluster=f.tree),v.marker&&(v.markerSel.positions=v.markerUnsel.positions=v.marker.positions=_),v.line&&_.length>1&&l.extendFlat(v.line,s.linePositions(e,p,_)),v.text&&(l.extendFlat(v.text,{positions:_},s.textPosition(e,p,v.text,v.marker)),l.extendFlat(v.textSel,{positions:_},s.textPosition(e,p,v.text,v.markerSel)),l.extendFlat(v.textUnsel,{positions:_},s.textPosition(e,p,v.text,v.markerUnsel))),v.fill&&!h.fill2d&&(h.fill2d=!0),v.marker&&!h.scatter2d&&(h.scatter2d=!0),v.line&&!h.line2d&&(h.line2d=!0),v.text&&!h.glText&&(h.glText=!0),h.lineOptions.push(v.line),h.fillOptions.push(v.fill),h.markerOptions.push(v.marker),h.markerSelectedOptions.push(v.markerSel),h.markerUnselectedOptions.push(v.markerUnsel),h.textOptions.push(v.text),h.textSelectedOptions.push(v.textSel),h.textUnselectedOptions.push(v.textUnsel),h.selectBatch.push([]),h.unselectBatch.push([]),f.x=w,f.y=k,f.rawx=w,f.rawy=k,f.r=g,f.theta=y,f.positions=_,f._scene=h,f.index=h.count,h.count++}})),o(e,t,r)}},e.exports.reglPrecompiled={}},69036:(e,t,r)=>{"use strict";var n=r(84425).rb,i=r(84425).ay,o=r(64022).extendFlat,a=r(50821),s=r(22049),l=r(75622),c=s.line;e.exports={mode:s.mode,real:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the real component of the data, in units of normalized impedance","such that real=1, imag=0 is the center of the chart."].join(" ")},imag:{valType:"data_array",editType:"calc+clearAxisTypes",description:["Sets the imaginary component of the data, in units of normalized impedance","such that real=1, imag=0 is the center of the chart."].join(" ")},text:s.text,texttemplate:i({editType:"plot"},{keys:["real","imag","text"]}),hovertext:s.hovertext,line:{color:c.color,width:c.width,dash:c.dash,backoff:c.backoff,shape:o({},c.shape,{values:["linear","spline"]}),smoothing:c.smoothing,editType:"calc"},connectgaps:s.connectgaps,marker:s.marker,cliponaxis:o({},s.cliponaxis,{dflt:!1}),textposition:s.textposition,textfont:s.textfont,fill:o({},s.fill,{values:["none","toself","tonext"],dflt:"none",description:["Sets the area to fill with a solid color.","Use with `fillcolor` if not *none*.","scattersmith has a subset of the options available to scatter.","*toself* connects the endpoints of the trace (or each segment","of the trace if it has gaps) into a closed shape.","*tonext* fills the space between two traces if one completely","encloses the other (eg consecutive contour lines), and behaves like","*toself* if there is no trace before it. *tonext* should not be","used if one trace does not enclose the other."].join(" ")}),fillcolor:a(),hoverinfo:o({},l.hoverinfo,{flags:["real","imag","text","name"]}),hoveron:s.hoveron,hovertemplate:n(),selected:s.selected,unselected:s.unselected}},88876:(e,t,r)=>{"use strict";var n=r(22036),i=r(65004).BADNUM,o=r(85387),a=r(24294),s=r(40304),l=r(20389).calcMarkerSize;e.exports=function(e,t){for(var r=e._fullLayout,c=t.subplot,u=r[c].realaxis,d=r[c].imaginaryaxis,h=u.makeCalcdata(t,"real"),p=d.makeCalcdata(t,"imag"),f=t._length,m=new Array(f),g=0;g{"use strict";var n=r(84468),i=r(31811),o=r(93379),a=r(1091),s=r(33381),l=r(80272),c=r(7751),u=r(56003).PTS_LINESONLY,d=r(69036);e.exports=function(e,t,r,h){function p(r,i){return n.coerce(e,t,d,r,i)}var f=function(e,t,r,i){var o,a=i("real"),s=i("imag");a&&s&&(o=Math.min(a.length,s.length));n.isTypedArray(a)&&(t.real=a=Array.from(a));n.isTypedArray(s)&&(t.imag=s=Array.from(s));return t._length=o,o}(0,t,0,p);if(f){p("mode",f{"use strict";var n=r(85729);e.exports=function(e,t,r){var i={},o=r[t.subplot]._subplot;return i.realLabel=n.tickText(o.radialAxis,e.real,!0).text,i.imagLabel=n.tickText(o.angularAxis,e.imag,!0).text,i}},82747:(e,t,r)=>{"use strict";var n=r(32168);function i(e,t,r,n){var i=r.radialAxis,o=r.angularAxis;i._hovertitle="real",o._hovertitle="imag";var a={};a[t.subplot]={_subplot:r};var s=t._module.formatLabels(e,t,a);n.realLabel=s.realLabel,n.imagLabel=s.imagLabel;var l=e.hi||t.hoverinfo,c=[];function u(e,t){c.push(e._hovertitle+": "+t)}if(!t.hovertemplate){var d=l.split("+");-1!==d.indexOf("all")&&(d=["real","imag","text"]),-1!==d.indexOf("real")&&u(i,n.realLabel),-1!==d.indexOf("imag")&&u(o,n.imagLabel),-1!==d.indexOf("text")&&n.text&&(c.push(n.text),delete n.text),n.extraText=c.join("
")}}e.exports={hoverPoints:function(e,t,r,o){var a=n(e,t,r,o);if(a&&!1!==a[0].index){var s=a[0];if(void 0===s.index)return a;var l=e.subplot,c=s.cd[s.index],u=s.trace;if(l.isPtInside(c))return s.xLabelVal=void 0,s.yLabelVal=void 0,i(c,u,l,s),s.hovertemplate=u.hovertemplate,a}},makeHoverPointText:i}},19009:(e,t,r)=>{"use strict";e.exports={moduleType:"trace",name:"scattersmith",basePlotModule:r(97147),categories:["smith","symbols","showLegend","scatter-like"],attributes:r(69036),supplyDefaults:r(83099),colorbar:r(17789),formatLabels:r(32762),calc:r(88876),plot:r(66110),style:r(47323).style,styleOnSelect:r(47323).styleOnSelect,hoverPoints:r(82747).hoverPoints,selectPoints:r(57112),meta:{hrName:"scatter_smith",description:["The scattersmith trace type encompasses line charts, scatter charts, text charts, and bubble charts","in smith coordinates.","The data visualized as scatter point or lines is set in","`real` and `imag` (imaginary) coordinates","Text (appearing either on the chart or on hover only) is via `text`.","Bubble charts are achieved by setting `marker.size` and/or `marker.color`","to numerical arrays."].join(" ")}}},66110:(e,t,r)=>{"use strict";var n=r(34923),i=r(65004).BADNUM,o=r(52266).smith;e.exports=function(e,t,r){for(var a=t.layers.frontplot.select("g.scatterlayer"),s=t.xaxis,l=t.yaxis,c={xaxis:s,yaxis:l,plot:t.framework,layerClipId:t._hasClipOnAxisFalse?t.clipIds.forTraces:null},u=0;u{"use strict";var n=r(84425).rb,i=r(84425).ay,o=r(50821),a=r(22049),s=r(75622),l=r(6636),c=r(2703).T,u=r(64022).extendFlat,d=a.marker,h=a.line,p=d.line;e.exports={a:{valType:"data_array",editType:"calc",description:["Sets the quantity of component `a` in each data point.","If `a`, `b`, and `c` are all provided, they need not be","normalized, only the relative values matter. If only two","arrays are provided they must be normalized to match","`ternary.sum`."].join(" ")},b:{valType:"data_array",editType:"calc",description:["Sets the quantity of component `a` in each data point.","If `a`, `b`, and `c` are all provided, they need not be","normalized, only the relative values matter. If only two","arrays are provided they must be normalized to match","`ternary.sum`."].join(" ")},c:{valType:"data_array",editType:"calc",description:["Sets the quantity of component `a` in each data point.","If `a`, `b`, and `c` are all provided, they need not be","normalized, only the relative values matter. If only two","arrays are provided they must be normalized to match","`ternary.sum`."].join(" ")},sum:{valType:"number",dflt:0,min:0,editType:"calc",description:["The number each triplet should sum to,","if only two of `a`, `b`, and `c` are provided.","This overrides `ternary.sum` to normalize this specific","trace, but does not affect the values displayed on the axes.","0 (or missing) means to use ternary.sum"].join(" ")},mode:u({},a.mode,{dflt:"markers"}),text:u({},a.text,{description:["Sets text elements associated with each (a,b,c) point.","If a single string, the same string appears over","all the data points.","If an array of strings, the items are mapped in order to the","the data points in (a,b,c).","If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,","these elements will be seen in the hover labels."].join(" ")}),texttemplate:i({editType:"plot"},{keys:["a","b","c","text"]}),hovertext:u({},a.hovertext,{description:["Sets hover text elements associated with each (a,b,c) point.","If a single string, the same string appears over","all the data points.","If an array of strings, the items are mapped in order to the","the data points in (a,b,c).","To be seen, trace `hoverinfo` must contain a *text* flag."].join(" ")}),line:{color:h.color,width:h.width,dash:c,backoff:h.backoff,shape:u({},h.shape,{values:["linear","spline"]}),smoothing:h.smoothing,editType:"calc"},connectgaps:a.connectgaps,cliponaxis:a.cliponaxis,fill:u({},a.fill,{values:["none","toself","tonext"],dflt:"none",description:["Sets the area to fill with a solid color.","Use with `fillcolor` if not *none*.","scatterternary has a subset of the options available to scatter.","*toself* connects the endpoints of the trace (or each segment","of the trace if it has gaps) into a closed shape.","*tonext* fills the space between two traces if one completely","encloses the other (eg consecutive contour lines), and behaves like","*toself* if there is no trace before it. *tonext* should not be","used if one trace does not enclose the other."].join(" ")}),fillcolor:o(),marker:u({symbol:d.symbol,opacity:d.opacity,angle:d.angle,angleref:d.angleref,standoff:d.standoff,maxdisplayed:d.maxdisplayed,size:d.size,sizeref:d.sizeref,sizemin:d.sizemin,sizemode:d.sizemode,line:u({width:p.width,editType:"calc"},l("marker.line")),gradient:d.gradient,editType:"calc"},l("marker")),textfont:a.textfont,textposition:a.textposition,selected:a.selected,unselected:a.unselected,hoverinfo:u({},s.hoverinfo,{flags:["a","b","c","text","name"]}),hoveron:a.hoveron,hovertemplate:n()}},58444:(e,t,r)=>{"use strict";var n=r(22036),i=r(85387),o=r(24294),a=r(40304),s=r(20389).calcMarkerSize,l=["a","b","c"],c={a:["b","c"],b:["a","c"],c:["a","b"]};e.exports=function(e,t){var r,u,d,h,p,f,m=e._fullLayout[t.subplot].sum,g=t.sum||m,y={a:t.a,b:t.b,c:t.c};for(r=0;r{"use strict";var n=r(84468),i=r(56003),o=r(31811),a=r(93379),s=r(1091),l=r(33381),c=r(80272),u=r(7751),d=r(94124);e.exports=function(e,t,r,h){function p(r,i){return n.coerce(e,t,d,r,i)}var f,m=p("a"),g=p("b"),y=p("c");if(m?(f=m.length,g?(f=Math.min(f,g.length),y&&(f=Math.min(f,y.length))):f=y?Math.min(f,y.length):0):g&&y&&(f=Math.min(g.length,y.length)),f){t._length=f,p("sum"),p("text"),p("hovertext"),"fills"!==t.hoveron&&p("hovertemplate"),p("mode",f{"use strict";e.exports=function(e,t,r,n,i){if(t.xa&&(e.xaxis=t.xa),t.ya&&(e.yaxis=t.ya),n[i]){var o=n[i];e.a=o.a,e.b=o.b,e.c=o.c}else e.a=t.a,e.b=t.b,e.c=t.c;return e}},46810:(e,t,r)=>{"use strict";var n=r(85729);e.exports=function(e,t,r){var i={},o=r[t.subplot]._subplot;return i.aLabel=n.tickText(o.aaxis,e.a,!0).text,i.bLabel=n.tickText(o.baxis,e.b,!0).text,i.cLabel=n.tickText(o.caxis,e.c,!0).text,i}},89979:(e,t,r)=>{"use strict";var n=r(32168);e.exports=function(e,t,r,i){var o=n(e,t,r,i);if(o&&!1!==o[0].index){var a=o[0];if(void 0===a.index){var s=1-a.y0/e.ya._length,l=e.xa._length,c=l*s/2,u=l-c;return a.x0=Math.max(Math.min(a.x0,u),c),a.x1=Math.max(Math.min(a.x1,u),c),o}var d=a.cd[a.index],h=a.trace,p=a.subplot;a.a=d.a,a.b=d.b,a.c=d.c,a.xLabelVal=void 0,a.yLabelVal=void 0;var f={};f[h.subplot]={_subplot:p};var m=h._module.formatLabels(d,h,f);a.aLabel=m.aLabel,a.bLabel=m.bLabel,a.cLabel=m.cLabel;var g=d.hi||h.hoverinfo,y=[];if(!h.hovertemplate){var v=g.split("+");-1!==v.indexOf("all")&&(v=["a","b","c"]),-1!==v.indexOf("a")&&x(p.aaxis,a.aLabel),-1!==v.indexOf("b")&&x(p.baxis,a.bLabel),-1!==v.indexOf("c")&&x(p.caxis,a.cLabel)}return a.extraText=y.join("
"),a.hovertemplate=h.hovertemplate,o}function x(e,t){y.push(e._hovertitle+": "+t)}}},2945:(e,t,r)=>{"use strict";e.exports={attributes:r(94124),supplyDefaults:r(42491),colorbar:r(17789),formatLabels:r(46810),calc:r(58444),plot:r(702),style:r(47323).style,styleOnSelect:r(47323).styleOnSelect,hoverPoints:r(89979),selectPoints:r(57112),eventData:r(92976),moduleType:"trace",name:"scatterternary",basePlotModule:r(73859),categories:["ternary","symbols","showLegend","scatter-like"],meta:{hrName:"scatter_ternary",description:["Provides similar functionality to the *scatter* type but on a ternary phase diagram.","The data is provided by at least two arrays out of `a`, `b`, `c` triplets."].join(" ")}}},702:(e,t,r)=>{"use strict";var n=r(34923);e.exports=function(e,t,r){var i=t.plotContainer;i.select(".scatterlayer").selectAll("*").remove();for(var o=t.xaxis,a=t.yaxis,s={xaxis:o,yaxis:a,plot:i,layerClipId:t._hasClipOnAxisFalse?t.clipIdRelative:null},l=t.layers.frontplot.select("g.scatterlayer"),c=0;c{"use strict";var n=r(22049),i=r(6636),o=r(39363).axisHoverFormat,a=r(84425).rb,s=r(86600),l=r(93143).idRegex,c=r(37091).templatedArray,u=r(64022).extendFlat,d=n.marker,h=d.line,p=u(i("marker.line",{editTypeOverride:"calc"}),{width:u({},h.width,{editType:"calc"}),editType:"calc"}),f=u(i("marker"),{symbol:d.symbol,angle:d.angle,size:u({},d.size,{editType:"markerSize"}),sizeref:d.sizeref,sizemin:d.sizemin,sizemode:d.sizemode,opacity:d.opacity,colorbar:d.colorbar,line:p,editType:"calc"});function m(e){return{valType:"info_array",freeLength:!0,editType:"calc",items:{valType:"subplotid",regex:l[e],editType:"plot"},description:["Sets the list of "+e+" axes","corresponding to dimensions of this splom trace.","By default, a splom will match the first N "+e+"axes","where N is the number of input dimensions.","Note that, in case where `diagonal.visible` is false and `showupperhalf`","or `showlowerhalf` is false, this splom trace will generate","one less x-axis and one less y-axis."].join(" ")}}f.color.editType=f.cmin.editType=f.cmax.editType="style",e.exports={dimensions:c("dimension",{visible:{valType:"boolean",dflt:!0,editType:"calc",description:["Determines whether or not this dimension is shown on the graph.","Note that even visible false dimension contribute to the","default grid generate by this splom trace."].join(" ")},label:{valType:"string",editType:"calc",description:"Sets the label corresponding to this splom dimension."},values:{valType:"data_array",editType:"calc+clearAxisTypes",description:"Sets the dimension values to be plotted."},axis:{type:{valType:"enumerated",values:["linear","log","date","category"],editType:"calc+clearAxisTypes",description:["Sets the axis type for this dimension's generated","x and y axes.","Note that the axis `type` values set in layout take","precedence over this attribute."].join(" ")},matches:{valType:"boolean",dflt:!1,editType:"calc",description:["Determines whether or not the x & y axes generated by this","dimension match.","Equivalent to setting the `matches` axis attribute in the layout","with the correct axis id."].join(" ")},editType:"calc+clearAxisTypes"},editType:"calc+clearAxisTypes"}),text:u({},s.text,{description:["Sets text elements associated with each (x,y) pair to appear on hover.","If a single string, the same string appears over","all the data points.","If an array of string, the items are mapped in order to the","this trace's (x,y) coordinates."].join(" ")}),hovertext:u({},s.hovertext,{description:"Same as `text`."}),hovertemplate:a(),xhoverformat:o("x"),yhoverformat:o("y"),marker:f,xaxes:m("x"),yaxes:m("y"),diagonal:{visible:{valType:"boolean",dflt:!0,editType:"calc",description:["Determines whether or not subplots on the diagonal are displayed."].join(" ")},editType:"calc"},showupperhalf:{valType:"boolean",dflt:!0,editType:"calc",description:["Determines whether or not subplots on the upper half","from the diagonal are displayed."].join(" ")},showlowerhalf:{valType:"boolean",dflt:!0,editType:"calc",description:["Determines whether or not subplots on the lower half","from the diagonal are displayed."].join(" ")},selected:{marker:s.selected.marker,editType:"calc"},unselected:{marker:s.unselected.marker,editType:"calc"},opacity:s.opacity}},46811:(e,t,r)=>{"use strict";var n=r(38361),i=r(41734);e.exports={moduleType:"trace",name:"splom",categories:["gl","regl","cartesian","symbols","showLegend","scatter-like"],attributes:r(70828),supplyDefaults:r(49179),colorbar:r(17789),calc:r(23596),plot:r(63806),hoverPoints:r(80475).hoverPoints,selectPoints:r(42925),editStyle:r(98051),meta:{description:["Splom traces generate scatter plot matrix visualizations.","Each splom `dimensions` items correspond to a generated axis.","Values for each of those dimensions are set in `dimensions[i].values`.","Splom traces support all `scattergl` marker style attributes.","Specify `layout.grid` attributes and/or layout x-axis and y-axis attributes","for more control over the axis positioning and style. "].join(" ")}},n.register(i)},50876:(e,t,r)=>{"use strict";var n=r(10545),i=r(38361),o=r(48488),a=r(50246).eV,s=r(9510),l=r(11576).getFromId,c=r(85729).shouldShowZeroLine,u="splom",d={};function h(e,t,r){for(var n=r.matrixOptions.data.length,i=t._visibleDims,o=r.viewOpts.ranges=new Array(n),a=0;a{"use strict";var n=r(84468),i=r(11576),o=r(20389).calcMarkerSize,a=r(20389).calcAxisExpansion,s=r(85387),l=r(36398).markerSelection,c=r(36398).markerStyle,u=r(73681),d=r(65004).BADNUM,h=r(12364).TOO_MANY_POINTS;e.exports=function(e,t){var r,p,f,m,g,y,v=t.dimensions,x=t._length,b={},_=b.cdata=[],w=b.data=[],k=t._visibleDims=[];function S(e,r){for(var i=e.makeCalcdata({v:r.values,vcalendar:t.calendar},"v"),o=0;oh?b.sizeAvg||Math.max(b.size,3):o(t,x),p=0;p{"use strict";var n=r(84468),i=r(38851),o=r(70828),a=r(31811),s=r(93379),l=r(28692),c=r(81728).isOpenSymbol;function u(e,t){function r(r,i){return n.coerce(e,t,o.dimensions,r,i)}r("label");var i=r("values");i&&i.length?r("visible"):t.visible=!1,r("axis.type"),r("axis.matches")}e.exports=function(e,t,r,d){function h(r,i){return n.coerce(e,t,o,r,i)}var p=i(e,t,{name:"dimensions",handleItemDefaults:u}),f=h("diagonal.visible"),m=h("showupperhalf"),g=h("showlowerhalf");if(l(t,p,"values")&&(f||m||g)){h("text"),h("hovertext"),h("hovertemplate"),h("xhoverformat"),h("yhoverformat"),s(e,t,r,d,h,{noAngleRef:!0,noStandOff:!0});var y=c(t.marker.symbol),v=a.isBubble(t);h("marker.line.width",y||v?1:0),function(e,t,r,n){var i,o,a=t.dimensions,s=a.length,l=t.showupperhalf,c=t.showlowerhalf,u=t.diagonal.visible,d=new Array(s),h=new Array(s);for(i=0;io&&l||i{"use strict";var n=r(84468),i=r(85387),o=r(36398).markerStyle;e.exports=function(e,t){var r=t.trace,a=e._fullLayout._splomScenes[r.uid];if(a){i(e,r),n.extendFlat(a.matrixOptions,o(e,r));var s=n.extendFlat({},a.matrixOptions,a.viewOpts);a.matrix.update(s,null)}}},40540:(e,t)=>{"use strict";t.getDimIndex=function(e,t){for(var r=t._id,n={x:0,y:1}[r.charAt(0)],i=e._visibleDims,o=0;o{"use strict";var n=r(40540),i=r(31311).calcHover,o=r(85729).getFromId,a=r(64022).extendFlat;function s(e,t,r,o){var a=e.cd[0].trace,s=e.scene.matrixOptions.cdata,l=e.xa,c=e.ya,u=l.c2p(t),d=c.c2p(r),h=e.distance,p=n.getDimIndex(a,l),f=n.getDimIndex(a,c);if(!1===p||!1===f)return[e];for(var m,g,y=s[p],v=s[f],x=h,b=0;b{"use strict";var n=r(46811);n.basePlotModule=r(50876),e.exports=n},63806:(e,t,r)=>{"use strict";var n=r(76958),i=r(84468),o=r(11576),a=r(2705).selectMode;function s(e,t){var r,s,l,c,u,d=e._fullLayout,h=d._size,p=t.trace,f=t.t,m=d._splomScenes[p.uid],g=m.matrixOptions,y=g.cdata,v=d._glcanvas.data()[0].regl,x=d.dragmode;if(0!==y.length){g.lower=p.showupperhalf,g.upper=p.showlowerhalf,g.diagonal=p.diagonal.visible;var b=p._visibleDims,_=y.length,w=m.viewOpts={};for(w.ranges=new Array(_),w.domains=new Array(_),u=0;u-1,P=!0;if(a(x)||!!p.selectedpoints||I){var O=p._length;if(p.selectedpoints){m.selectBatch=p.selectedpoints;var R=p.selectedpoints,L={};for(l=0;l{"use strict";var n=r(84468);e.exports=function(e,t){var r=e._fullLayout,i=t.uid,o=r._splomScenes;o||(o=r._splomScenes={});var a={dirty:!0,selectBatch:[],unselectBatch:[]},s=o[t.uid];return s||((s=o[i]=n.extendFlat({},a,{matrix:!1,selectBatch:[],unselectBatch:[]})).draw=function(){s.matrix&&s.matrix.draw&&(s.selectBatch.length||s.unselectBatch.length?s.matrix.draw(s.unselectBatch,s.selectBatch):s.matrix.draw()),s.dirty=!1},s.destroy=function(){s.matrix&&s.matrix.destroy&&s.matrix.destroy(),s.matrixOptions=null,s.selectBatch=null,s.unselectBatch=null,s=null}),s.dirty||n.extendFlat(s,a),s}},42925:(e,t,r)=>{"use strict";var n=r(84468),i=n.pushUnique,o=r(31811),a=r(40540);e.exports=function(e,t){var r=e.cd,s=r[0].trace,l=r[0].t,c=e.scene,u=c.matrixOptions.cdata,d=e.xaxis,h=e.yaxis,p=[];if(!c)return p;var f=!o.hasMarkers(s)&&!o.hasText(s);if(!0!==s.visible||f)return p;var m=a.getDimIndex(s,d),g=a.getDimIndex(s,h);if(!1===m||!1===g)return p;var y=l.xpx[m],v=l.ypx[g],x=u[m],b=u[g],_=(e.scene.selectBatch||[]).slice(),w=[];if(!1!==t&&!t.degenerate)for(var k=0;k{"use strict";var n=r(6636),i=r(39363).axisHoverFormat,o=r(84425).rb,a=r(64989),s=r(75622),l=r(64022).extendFlat,c={x:{valType:"data_array",editType:"calc+clearAxisTypes",description:"Sets the x coordinates of the vector field."},y:{valType:"data_array",editType:"calc+clearAxisTypes",description:"Sets the y coordinates of the vector field."},z:{valType:"data_array",editType:"calc+clearAxisTypes",description:"Sets the z coordinates of the vector field."},u:{valType:"data_array",editType:"calc",description:"Sets the x components of the vector field."},v:{valType:"data_array",editType:"calc",description:"Sets the y components of the vector field."},w:{valType:"data_array",editType:"calc",description:"Sets the z components of the vector field."},starts:{x:{valType:"data_array",editType:"calc",description:["Sets the x components of the starting position of the streamtubes"].join(" ")},y:{valType:"data_array",editType:"calc",description:["Sets the y components of the starting position of the streamtubes"].join(" ")},z:{valType:"data_array",editType:"calc",description:["Sets the z components of the starting position of the streamtubes"].join(" ")},editType:"calc"},maxdisplayed:{valType:"integer",min:0,dflt:1e3,editType:"calc",description:["The maximum number of displayed segments in a streamtube."].join(" ")},sizeref:{valType:"number",editType:"calc",min:0,dflt:1,description:["The scaling factor for the streamtubes.","The default is 1, which avoids two max divergence tubes from touching","at adjacent starting positions."].join(" ")},text:{valType:"string",dflt:"",editType:"calc",description:["Sets a text element associated with this trace.","If trace `hoverinfo` contains a *text* flag,","this text element will be seen in all hover labels.","Note that streamtube traces do not support array `text` values."].join(" ")},hovertext:{valType:"string",dflt:"",editType:"calc",description:"Same as `text`."},hovertemplate:o({editType:"calc"},{keys:["tubex","tubey","tubez","tubeu","tubev","tubew","norm","divergence"]}),uhoverformat:i("u",1),vhoverformat:i("v",1),whoverformat:i("w",1),xhoverformat:i("x"),yhoverformat:i("y"),zhoverformat:i("z"),showlegend:l({},s.showlegend,{dflt:!1})};l(c,n("",{colorAttr:"u/v/w norm",showScaleDflt:!0,editTypeOverride:"calc"}));["opacity","lightposition","lighting"].forEach((function(e){c[e]=a[e]})),c.hoverinfo=l({},s.hoverinfo,{editType:"calc",flags:["x","y","z","u","v","w","norm","divergence","text","name"],dflt:"x+y+z+norm+text+name"}),c.transforms=void 0,e.exports=c},65953:(e,t,r)=>{"use strict";var n=r(84468),i=r(95500);function o(e){var t,r,i,o,s,l,c,u,d,h,p,f,m=e._x,g=e._y,y=e._z,v=e._len,x=-1/0,b=1/0,_=-1/0,w=1/0,k=-1/0,S=1/0,A="";for(v&&(c=m[0],d=g[0],p=y[0]),v>1&&(u=m[v-1],h=g[v-1],f=y[v-1]),t=0;tu?"-":"+")+"x")).replace("y",(d>h?"-":"+")+"y")).replace("z",(p>f?"-":"+")+"z");var E=function(){v=0,T=[],M=[],C=[]};(!v||v{"use strict";var n=r(76107).gl_streamtube3d,i=n.createTubeMesh,o=r(84468),a=r(23207).parseColorScale,s=r(39265).extractOpts,l=r(11038),c={xaxis:0,yaxis:1,zaxis:2};function u(e,t){this.scene=e,this.uid=t,this.mesh=null,this.data=null}var d=u.prototype;function h(e){var t=e.length;return t>2?e.slice(1,t-1):2===t?[(e[0]+e[1])/2]:e}function p(e){var t=e.length;return 1===t?[.5,.5]:[e[1]-e[0],e[t-1]-e[t-2]]}function f(e,t){var r=e.fullSceneLayout,i=e.dataScale,u=t._len,d={};function f(e,t){var n=r[t],a=i[c[t]];return o.simpleMap(e,(function(e){return n.d2l(e)*a}))}if(d.vectors=l(f(t._u,"xaxis"),f(t._v,"yaxis"),f(t._w,"zaxis"),u),!u)return{positions:[],cells:[]};var m=f(t._Xs,"xaxis"),g=f(t._Ys,"yaxis"),y=f(t._Zs,"zaxis");if(d.meshgrid=[m,g,y],d.gridFill=t._gridFill,t._slen)d.startingPositions=l(f(t._startsX,"xaxis"),f(t._startsY,"yaxis"),f(t._startsZ,"zaxis"));else{for(var v=g[0],x=h(m),b=h(y),_=new Array(x.length*b.length),w=0,k=0;k{"use strict";var n=r(84468),i=r(16155),o=r(6957);e.exports=function(e,t,r,a){function s(r,i){return n.coerce(e,t,o,r,i)}var l=s("u"),c=s("v"),u=s("w"),d=s("x"),h=s("y"),p=s("z");l&&l.length&&c&&c.length&&u&&u.length&&d&&d.length&&h&&h.length&&p&&p.length?(s("starts.x"),s("starts.y"),s("starts.z"),s("maxdisplayed"),s("sizeref"),s("lighting.ambient"),s("lighting.diffuse"),s("lighting.specular"),s("lighting.roughness"),s("lighting.fresnel"),s("lightposition.x"),s("lightposition.y"),s("lightposition.z"),i(e,t,a,s,{prefix:"",cLetter:"c"}),s("text"),s("hovertext"),s("hovertemplate"),s("uhoverformat"),s("vhoverformat"),s("whoverformat"),s("xhoverformat"),s("yhoverformat"),s("zhoverformat"),t._length=null):t.visible=!1}},23862:(e,t,r)=>{"use strict";e.exports={moduleType:"trace",name:"streamtube",basePlotModule:r(48648),categories:["gl3d","showLegend"],attributes:r(6957),supplyDefaults:r(96506),colorbar:{min:"cmin",max:"cmax"},calc:r(65953).calc,plot:r(46365),eventData:function(e,t){return e.tubex=e.x,e.tubey=e.y,e.tubez=e.z,e.tubeu=t.traceCoordinate[3],e.tubev=t.traceCoordinate[4],e.tubew=t.traceCoordinate[5],e.norm=t.traceCoordinate[6],e.divergence=t.traceCoordinate[7],delete e.x,delete e.y,delete e.z,e},meta:{description:["Use a streamtube trace to visualize flow in a vector field.","","Specify a vector field using 6 1D arrays of equal length,","3 position arrays `x`, `y` and `z`","and 3 vector component arrays `u`, `v`, and `w`.","","By default, the tubes' starting positions will be cut from the vector field's","x-z plane at its minimum y value.","To specify your own starting position, use attributes `starts.x`, `starts.y`","and `starts.z`.","The color is encoded by the norm of (u, v, w), and the local radius","by the divergence of (u, v, w)."].join(" ")}}},10535:(e,t,r)=>{"use strict";var n=r(75622),i=r(84425).rb,o=r(84425).ay,a=r(6636),s=r(81159).u,l=r(59453),c=r(36689),u=r(64022).extendFlat,d=r(2703).k;e.exports={labels:{valType:"data_array",editType:"calc",description:["Sets the labels of each of the sectors."].join(" ")},parents:{valType:"data_array",editType:"calc",description:["Sets the parent sectors for each of the sectors.","Empty string items '' are understood to reference","the root node in the hierarchy.",'If `ids` is filled, `parents` items are understood to be "ids" themselves.',"When `ids` is not set, plotly attempts to find matching items in `labels`,","but beware they must be unique."].join(" ")},values:{valType:"data_array",editType:"calc",description:["Sets the values associated with each of the sectors.","Use with `branchvalues` to determine how the values are summed."].join(" ")},branchvalues:{valType:"enumerated",values:["remainder","total"],dflt:"remainder",editType:"calc",description:["Determines how the items in `values` are summed.","When set to *total*, items in `values` are taken to be value of all its descendants.","When set to *remainder*, items in `values` corresponding to the root and the branches sectors","are taken to be the extra part not part of the sum of the values at their leaves."].join(" ")},count:{valType:"flaglist",flags:["branches","leaves"],dflt:"leaves",editType:"calc",description:["Determines default for `values` when it is not provided,","by inferring a 1 for each of the *leaves* and/or *branches*, otherwise 0."].join(" ")},level:{valType:"any",editType:"plot",anim:!0,description:["Sets the level from which this trace hierarchy is rendered.","Set `level` to `''` to start from the root node in the hierarchy.",'Must be an "id" if `ids` is filled in, otherwise plotly attempts to find a matching',"item in `labels`."].join(" ")},maxdepth:{valType:"integer",editType:"plot",dflt:-1,description:["Sets the number of rendered sectors from any given `level`.","Set `maxdepth` to *-1* to render all the levels in the hierarchy."].join(" ")},marker:u({colors:{valType:"data_array",editType:"calc",description:["Sets the color of each sector of this trace.","If not specified, the default trace color set is used","to pick the sector colors."].join(" ")},line:{color:u({},l.marker.line.color,{dflt:null,description:["Sets the color of the line enclosing each sector.","Defaults to the `paper_bgcolor` value."].join(" ")}),width:u({},l.marker.line.width,{dflt:1}),editType:"calc"},pattern:d,editType:"calc"},a("marker",{colorAttr:"colors",anim:!1})),leaf:{opacity:{valType:"number",editType:"style",min:0,max:1,description:["Sets the opacity of the leaves. With colorscale","it is defaulted to 1; otherwise it is defaulted to 0.7"].join(" ")},editType:"plot"},text:l.text,textinfo:{valType:"flaglist",flags:["label","text","value","current path","percent root","percent entry","percent parent"],extras:["none"],editType:"plot",description:["Determines which trace information appear on the graph."].join(" ")},texttemplate:o({editType:"plot"},{keys:c.eventDataKeys.concat(["label","value"])}),hovertext:l.hovertext,hoverinfo:u({},n.hoverinfo,{flags:["label","text","value","name","current path","percent root","percent entry","percent parent"],dflt:"label+text+value+name"}),hovertemplate:i({},{keys:c.eventDataKeys}),textfont:l.textfont,insidetextorientation:l.insidetextorientation,insidetextfont:l.insidetextfont,outsidetextfont:u({},l.outsidetextfont,{description:["Sets the font used for `textinfo` lying outside the sector.","This option refers to the root of the hierarchy","presented at the center of a sunburst graph.","Please note that if a hierarchy has multiple root nodes,","this option won't have any effect and `insidetextfont` would be used."].join(" ")}),rotation:{valType:"angle",dflt:0,editType:"plot",description:["Rotates the whole diagram counterclockwise by some angle.","By default the first slice starts at 3 o'clock."].join(" ")},sort:l.sort,root:{color:{valType:"color",editType:"calc",dflt:"rgba(0,0,0,0)",description:["sets the color of the root node for a sunburst/treemap/icicle trace.","this has no effect when a colorscale is used to set the markers."].join(" ")},editType:"calc"},domain:s({name:"sunburst",trace:!0,editType:"calc"})}},75569:(e,t,r)=>{"use strict";var n=r(68543);t.name="sunburst",t.plot=function(e,r,i,o){n.plotBasePlot(t.name,e,r,i,o)},t.clean=function(e,r,i,o){n.cleanBasePlot(t.name,e,r,i,o)}},54151:(e,t,r)=>{"use strict";var n=r(28203),i=r(22036),o=r(84468),a=r(39265).makeColorScaleFuncFromTrace,s=r(59217).makePullColorFn,l=r(59217).generateExtendedColors,c=r(39265).calc,u=r(65004).ALMOST_EQUAL,d={},h={},p={};function f(e,t,r){var n=0,i=e.children;if(i){for(var o=i.length,a=0;a=0};v?(r=Math.min(y.length,b.length),l=function(e){return T(y[e])&&M(e)},d=function(e){return String(y[e])}):(r=Math.min(x.length,b.length),l=function(e){return T(x[e])&&M(e)},d=function(e){return String(x[e])}),w&&(r=Math.min(r,_.length));for(var C=0;C1){for(var O=o.randstr(),R=0;R{"use strict";e.exports={CLICK_TRANSITION_TIME:750,CLICK_TRANSITION_EASING:"linear",eventDataKeys:["currentPath","root","entry","percentRoot","percentEntry","percentParent"]}},87520:(e,t,r)=>{"use strict";var n=r(84468),i=r(10535),o=r(81159).N,a=r(81543).handleText,s=r(69834).handleMarkerDefaults,l=r(39265),c=l.hasColorscale,u=l.handleDefaults;e.exports=function(e,t,r,l){function d(r,o){return n.coerce(e,t,i,r,o)}var h=d("labels"),p=d("parents");if(h&&h.length&&p&&p.length){var f=d("values");f&&f.length?d("branchvalues"):d("count"),d("level"),d("maxdepth"),s(e,t,l,d);var m=t._hasColorscale=c(e,"marker","colors")||(e.marker||{}).coloraxis;m&&u(e,t,l,d,{prefix:"marker.",cLetter:"c"}),d("leaf.opacity",m?1:.7);var g=d("text");d("texttemplate"),t.texttemplate||d("textinfo",n.isArrayOrTypedArray(g)?"text+label":"label"),d("hovertext"),d("hovertemplate");a(e,t,l,d,"auto",{moduleHasSelected:!1,moduleHasUnselected:!1,moduleHasConstrain:!1,moduleHasCliponaxis:!1,moduleHasTextangle:!1,moduleHasInsideanchor:!1}),d("insidetextorientation"),d("sort"),d("rotation"),d("root.color"),o(t,l,d),t._length=null}else t.visible=!1}},32155:(e,t,r)=>{"use strict";var n=r(3172),i=r(7605);e.exports=function(e,t,r,o,a){var s=t.data.data,l=s.i,c=a||s.color;if(l>=0){t.i=s.i;var u=r.marker;u.pattern&&u.colors&&u.pattern.shape||(u.color=c,t.color=c),n.pointStyle(e,r,o,t)}else i.fill(e,c)}},10676:(e,t,r)=>{"use strict";var n=r(41871),i=r(38361),o=r(82561).appendArrayPointValue,a=r(32212),s=r(84468),l=r(13711),c=r(4425),u=r(97367).formatPieValue;function d(e,t,r){for(var n=e.data.data,i={curveNumber:t.index,pointNumber:n.i,data:t._input,fullData:t},a=0;a"),name:A||L("name")?v.name:void 0,color:S("hoverlabel.bgcolor")||x.color,borderColor:S("hoverlabel.bordercolor"),fontFamily:S("hoverlabel.font.family"),fontSize:S("hoverlabel.font.size"),fontColor:S("hoverlabel.font.color"),fontWeight:S("hoverlabel.font.weight"),fontStyle:S("hoverlabel.font.style"),fontVariant:S("hoverlabel.font.variant"),nameLength:S("hoverlabel.namelength"),textAlign:S("hoverlabel.align"),hovertemplate:A,hovertemplateLabels:P,eventData:l};g&&(j.x0=C-i.rInscribed*i.rpx1,j.x1=C+i.rInscribed*i.rpx1,j.idealAlign=i.pxmid[0]<0?"left":"right"),y&&(j.x=C,j.idealAlign=C<0?"left":"right");var F=[];a.loneHover(j,{container:o._hoverlayer.node(),outerContainer:o._paper.node(),gd:r,inOut_bbox:F}),l[0].bbox=F[0],f._hasHoverLabel=!0}if(y){var N=e.select("path.surface");h.styleOne(N,i,v,r,{hovered:!0})}f._hasHoverEvent=!0,r.emit("plotly_hover",{points:l||[d(i,v,h.eventDataKeys)],event:n.event})}})),e.on("mouseout",(function(t){var i=r._fullLayout,o=r._fullData[f.index],s=n.select(this).datum();if(f._hasHoverEvent&&(t.originalEvent=n.event,r.emit("plotly_unhover",{points:[d(s,o,h.eventDataKeys)],event:n.event}),f._hasHoverEvent=!1),f._hasHoverLabel&&(a.loneUnhover(i._hoverlayer.node()),f._hasHoverLabel=!1),y){var l=e.select("path.surface");h.styleOne(l,s,o,r,{hovered:!1})}})),e.on("click",(function(e){var t=r._fullLayout,o=r._fullData[f.index],s=g&&(c.isHierarchyRoot(e)||c.isLeaf(e)),u=c.getPtId(e),p=c.isEntry(e)?c.findEntryWithChild(m,u):c.findEntryWithLevel(m,u),y=c.getPtId(p),v={points:[d(e,o,h.eventDataKeys)],event:n.event};s||(v.nextLevel=y);var x=l.triggerHandler(r,"plotly_"+f.type+"click",v);if(!1!==x&&t.hovermode&&(r._hoverdata=[d(e,o,h.eventDataKeys)],a.click(r,n.event)),!s&&!1!==x&&!r._dragging&&!r._transitioning){i.call("_storeDirectGUIEdit",o,t._tracePreGUI[o.uid],{level:o.level});var b={data:[{level:y}],traces:[f.index]},_={frame:{redraw:!1,duration:h.transitionTime},transition:{duration:h.transitionTime,easing:h.transitionEasing},mode:"immediate",fromcurrent:!0};a.loneUnhover(t._hoverlayer.node()),i.call("animate",r,b,_)}}))}},4425:(e,t,r)=>{"use strict";var n=r(84468),i=r(7605),o=r(29454),a=r(97367);function s(e){return e.data.data.pid}t.findEntryWithLevel=function(e,r){var n;return r&&e.eachAfter((function(e){if(t.getPtId(e)===r)return n=e.copy()})),n||e},t.findEntryWithChild=function(e,r){var n;return e.eachAfter((function(e){for(var i=e.children||[],o=0;o0)},t.getMaxDepth=function(e){return e.maxdepth>=0?e.maxdepth:1/0},t.isHeader=function(e,r){return!(t.isLeaf(e)||e.depth===r._maxDepth-1)},t.getParent=function(e,r){return t.findEntryWithLevel(e,s(r))},t.listPath=function(e,r){var n=e.parent;if(!n)return[];var i=r?[n.data[r]]:[n];return t.listPath(n,r).concat(i)},t.getPath=function(e){return t.listPath(e,"label").join("/")+"/"},t.formatValue=a.formatPieValue,t.formatPercent=function(e,t){var r=n.formatPercent(e,0);return"0%"===r&&(r=a.formatPiePercent(e,t)),r}},89004:(e,t,r)=>{"use strict";e.exports={moduleType:"trace",name:"sunburst",basePlotModule:r(75569),categories:[],animatable:!0,attributes:r(10535),layoutAttributes:r(95406),supplyDefaults:r(87520),supplyLayoutDefaults:r(33241),calc:r(54151).calc,crossTraceCalc:r(54151).crossTraceCalc,plot:r(88817).plot,style:r(66317).style,colorbar:r(17789),meta:{description:["Visualize hierarchal data spanning outward radially from root to leaves.","The sunburst sectors are determined by the entries in *labels* or *ids*","and in *parents*."].join(" ")}}},95406:e=>{"use strict";e.exports={sunburstcolorway:{valType:"colorlist",editType:"calc",description:["Sets the default sunburst slice colors. Defaults to the main","`colorway` used for trace colors. If you specify a new","list here it can still be extended with lighter and darker","colors, see `extendsunburstcolors`."].join(" ")},extendsunburstcolors:{valType:"boolean",dflt:!0,editType:"calc",description:["If `true`, the sunburst slice colors (whether given by `sunburstcolorway` or","inherited from `colorway`) will be extended to three times its","original length by first repeating every color 20% lighter then","each color 20% darker. This is intended to reduce the likelihood","of reusing the same color when you have many slices, but you can","set `false` to disable.","Colors provided in the trace, using `marker.colors`, are never","extended."].join(" ")}}},33241:(e,t,r)=>{"use strict";var n=r(84468),i=r(95406);e.exports=function(e,t){function r(r,o){return n.coerce(e,t,i,r,o)}r("sunburstcolorway",t.colorway),r("extendsunburstcolors")}},88817:(e,t,r)=>{"use strict";var n=r(41871),i=r(28203),o=r(70359).GW,a=r(3172),s=r(84468),l=r(13480),c=r(35655),u=c.recordMinTextSize,d=c.clearMinTextSize,h=r(50183),p=r(97367).getRotationAngle,f=h.computeTransform,m=h.transformInsideText,g=r(66317).styleOne,y=r(52464).resizeText,v=r(10676),x=r(36689),b=r(4425);function _(e,r,c,d){var h=e._context.staticPlot,y=e._fullLayout,_=!y.uniformtext.mode&&b.hasTransition(d),k=n.select(c).selectAll("g.slice"),S=r[0],A=S.trace,T=S.hierarchy,M=b.findEntryWithLevel(T,A.level),C=b.getMaxDepth(A),E=y._size,I=A.domain,P=E.w*(I.x[1]-I.x[0]),O=E.h*(I.y[1]-I.y[0]),R=.5*Math.min(P,O),L=S.cx=E.l+E.w*(I.x[1]+I.x[0])/2,D=S.cy=E.t+E.h*(1-I.y[0])-O/2;if(!M)return k.remove();var z=null,j={};_&&k.each((function(e){j[b.getPtId(e)]={rpx0:e.rpx0,rpx1:e.rpx1,x0:e.x0,x1:e.x1,transform:e.transform},!z&&b.isEntry(e)&&(z=e)}));var F=function(e){return i.partition().size([2*Math.PI,e.height+1])(e)}(M).descendants(),N=M.height+1,B=0,V=C;S.hasMultipleRoots&&b.isHierarchyRoot(M)&&(F=F.slice(1),N-=1,B=1,V+=1),F=F.filter((function(e){return e.y1<=V}));var U=p(A.rotation);U&&F.forEach((function(e){e.x0+=U,e.x1+=U}));var H=Math.min(N,C),$=function(e){return(e-B)/H*R},W=function(e,t){return[e*Math.cos(t),-e*Math.sin(t)]},q=function(e){return s.pathAnnulus(e.rpx0,e.rpx1,e.x0,e.x1,L,D)},G=function(e){return L+w(e)[0]*(e.transform.rCenter||0)+(e.transform.x||0)},Y=function(e){return D+w(e)[1]*(e.transform.rCenter||0)+(e.transform.y||0)};(k=k.data(F,b.getPtId)).enter().append("g").classed("slice",!0),_?k.exit().transition().each((function(){var e=n.select(this);e.select("path.surface").transition().attrTween("d",(function(e){var t=function(e){var t,r=b.getPtId(e),n=j[r],i=j[b.getPtId(M)];if(i){var a=(e.x1>i.x1?2*Math.PI:0)+U;t=e.rpx1X?2*Math.PI:0)+U;t={x0:i,x1:i}}else t={rpx0:R,rpx1:R},s.extendFlat(t,J(e));else t={rpx0:0,rpx1:0};else t={x0:U,x1:U};return o(t,n)}(e);return function(e){return q(t(e))}})):d.attr("d",q),c.call(v,M,e,r,{eventDataKeys:x.eventDataKeys,transitionTime:x.CLICK_TRANSITION_TIME,transitionEasing:x.CLICK_TRANSITION_EASING}).call(b.setSliceCursor,e,{hideOnRoot:!0,hideOnLeaves:!0,isTransitioning:e._transitioning}),d.call(g,i,A,e);var p=s.ensureSingle(c,"g","slicetext"),w=s.ensureSingle(p,"text","",(function(e){e.attr("data-notex",1)})),k=s.ensureUniformFontSize(e,b.determineTextFont(A,i,y.font));w.text(t.formatSliceLabel(i,M,A,r,y)).classed("slicetext",!0).attr("text-anchor","middle").call(a.font,k).call(l.convertToTspans,e);var T=a.bBox(w.node());i.transform=m(T,i,S),i.transform.targetX=G(i),i.transform.targetY=Y(i);var C=function(e,t){var r=e.transform;return f(r,t),r.fontSize=k.size,u(A.type,r,y),s.getTextTransform(r)};_?w.transition().attrTween("transform",(function(e){var t=function(e){var t,r=j[b.getPtId(e)],n=e.transform;if(r)t=r;else if(t={rpx1:e.rpx1,transform:{textPosAngle:n.textPosAngle,scale:0,rotate:n.rotate,rCenter:n.rCenter,x:n.x,y:n.y}},z)if(e.parent)if(X){var i=e.x1>X?2*Math.PI:0;t.x0=t.x1=i}else s.extendFlat(t,J(e));else t.x0=t.x1=U;else t.x0=t.x1=U;var a=o(t.transform.textPosAngle,e.transform.textPosAngle),l=o(t.rpx1,e.rpx1),c=o(t.x0,e.x0),d=o(t.x1,e.x1),h=o(t.transform.scale,n.scale),p=o(t.transform.rotate,n.rotate),f=0===n.rCenter?3:0===t.transform.rCenter?1/3:1,m=o(t.transform.rCenter,n.rCenter),g=function(e){return m(Math.pow(e,f))};return function(e){var t=l(e),r=c(e),i=d(e),o=g(e),s={pxmid:W(t,(r+i)/2),rpx1:t,transform:{textPosAngle:a(e),rCenter:o,x:n.x,y:n.y}};return u(A.type,n,y),{transform:{targetX:G(s),targetY:Y(s),scale:h(e),rotate:p(e),rCenter:o}}}}(e);return function(e){return C(t(e),T)}})):w.attr("transform",C(i,T))}))}function w(e){return t=e.rpx1,r=e.transform.textPosAngle,[t*Math.sin(r),-t*Math.cos(r)];var t,r}t.plot=function(e,t,r,i){var o,a,s=e._fullLayout,l=s._sunburstlayer,c=!r,u=!s.uniformtext.mode&&b.hasTransition(r);(d("sunburst",s),(o=l.selectAll("g.trace.sunburst").data(t,(function(e){return e[0].trace.uid}))).enter().append("g").classed("trace",!0).classed("sunburst",!0).attr("stroke-linejoin","round"),o.order(),u)?(i&&(a=i()),n.transition().duration(r.duration).ease(r.easing).each("end",(function(){a&&a()})).each("interrupt",(function(){a&&a()})).each((function(){l.selectAll("g.trace").each((function(t){_(e,t,this,r)}))}))):(o.each((function(t){_(e,t,this,r)})),s.uniformtext.mode&&y(e,s._sunburstlayer.selectAll(".trace"),"sunburst"));c&&o.exit().remove()},t.formatSliceLabel=function(e,t,r,n,i){var o=r.texttemplate,a=r.textinfo;if(!o&&(!a||"none"===a))return"";var l=i.separators,c=n[0],u=e.data.data,d=c.hierarchy,h=b.isHierarchyRoot(e),p=b.getParent(d,e),f=b.getValue(e);if(!o){var m,g=a.split("+"),y=function(e){return-1!==g.indexOf(e)},v=[];if(y("label")&&u.label&&v.push(u.label),u.hasOwnProperty("v")&&y("value")&&v.push(b.formatValue(u.v,l)),!h){y("current path")&&v.push(b.getPath(e.data));var x=0;y("percent parent")&&x++,y("percent entry")&&x++,y("percent root")&&x++;var _=x>1;if(x){var w,k=function(e){m=b.formatPercent(w,l),_&&(m+=" of "+e),v.push(m)};y("percent parent")&&!h&&(w=f/b.getValue(p),k("parent")),y("percent entry")&&(w=f/b.getValue(t),k("entry")),y("percent root")&&(w=f/b.getValue(d),k("root"))}}return y("text")&&(m=s.castOption(r,u.i,"text"),s.isValidTextValue(m)&&v.push(m)),v.join("
")}var S=s.castOption(r,u.i,"texttemplate");if(!S)return"";var A={};u.label&&(A.label=u.label),u.hasOwnProperty("v")&&(A.value=u.v,A.valueLabel=b.formatValue(u.v,l)),A.currentPath=b.getPath(e.data),h||(A.percentParent=f/b.getValue(p),A.percentParentLabel=b.formatPercent(A.percentParent,l),A.parent=b.getPtLabel(p)),A.percentEntry=f/b.getValue(t),A.percentEntryLabel=b.formatPercent(A.percentEntry,l),A.entry=b.getPtLabel(t),A.percentRoot=f/b.getValue(d),A.percentRootLabel=b.formatPercent(A.percentRoot,l),A.root=b.getPtLabel(d),u.hasOwnProperty("color")&&(A.color=u.color);var T=s.castOption(r,u.i,"text");return(s.isValidTextValue(T)||""===T)&&(A.text=T),A.customdata=s.castOption(r,u.i,"customdata"),s.texttemplateString(S,A,i._d3locale,A,r._meta||{})}},66317:(e,t,r)=>{"use strict";var n=r(41871),i=r(7605),o=r(84468),a=r(35655).resizeText,s=r(32155);function l(e,t,r,n){var a=t.data.data,l=!t.children,c=a.i,u=o.castOption(r,c,"marker.line.color")||i.defaultLine,d=o.castOption(r,c,"marker.line.width")||0;e.call(s,t,r,n).style("stroke-width",d).call(i.stroke,u).style("opacity",l?r.leaf.opacity:null)}e.exports={style:function(e){var t=e._fullLayout._sunburstlayer.selectAll(".trace");a(e,t,"sunburst"),t.each((function(t){var r=n.select(this),i=t[0].trace;r.style("opacity",i.opacity),r.selectAll("path.surface").each((function(t){n.select(this).call(l,t,i,e)}))}))},styleOne:l}},41094:(e,t,r)=>{"use strict";var n=r(7605),i=r(6636),o=r(39363).axisHoverFormat,a=r(84425).rb,s=r(75622),l=r(64022).extendFlat,c=r(72587).overrideAll;function u(e){return{valType:"boolean",dflt:!1,description:["Determines whether or not these contour lines are projected","on the",e,"plane.","If `highlight` is set to *true* (the default), the projected","lines are shown on hover.","If `show` is set to *true*, the projected lines are shown","in permanence."].join(" ")}}function d(e){return{show:{valType:"boolean",dflt:!1,description:["Determines whether or not contour lines about the",e,"dimension are drawn."].join(" ")},start:{valType:"number",dflt:null,editType:"plot",description:["Sets the starting contour level value.","Must be less than `contours.end`"].join(" ")},end:{valType:"number",dflt:null,editType:"plot",description:["Sets the end contour level value.","Must be more than `contours.start`"].join(" ")},size:{valType:"number",dflt:null,min:0,editType:"plot",description:["Sets the step between each contour level.","Must be positive."].join(" ")},project:{x:u("x"),y:u("y"),z:u("z")},color:{valType:"color",dflt:n.defaultLine,description:"Sets the color of the contour lines."},usecolormap:{valType:"boolean",dflt:!1,description:["An alternate to *color*.","Determines whether or not the contour lines are colored using","the trace *colorscale*."].join(" ")},width:{valType:"number",min:1,max:16,dflt:2,description:"Sets the width of the contour lines."},highlight:{valType:"boolean",dflt:!0,description:["Determines whether or not contour lines about the",e,"dimension are highlighted on hover."].join(" ")},highlightcolor:{valType:"color",dflt:n.defaultLine,description:"Sets the color of the highlighted contour lines."},highlightwidth:{valType:"number",min:1,max:16,dflt:2,description:"Sets the width of the highlighted contour lines."}}}var h=e.exports=c(l({z:{valType:"data_array",description:"Sets the z coordinates."},x:{valType:"data_array",description:"Sets the x coordinates."},y:{valType:"data_array",description:"Sets the y coordinates."},text:{valType:"string",dflt:"",arrayOk:!0,description:["Sets the text elements associated with each z value.","If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,","these elements will be seen in the hover labels."].join(" ")},hovertext:{valType:"string",dflt:"",arrayOk:!0,description:"Same as `text`."},hovertemplate:a(),xhoverformat:o("x"),yhoverformat:o("y"),zhoverformat:o("z"),connectgaps:{valType:"boolean",dflt:!1,editType:"calc",description:["Determines whether or not gaps","(i.e. {nan} or missing values)","in the `z` data are filled in."].join(" ")},surfacecolor:{valType:"data_array",description:["Sets the surface color values,","used for setting a color scale independent of `z`."].join(" ")}},i("",{colorAttr:"z or surfacecolor",showScaleDflt:!0,autoColorDflt:!1,editTypeOverride:"calc"}),{contours:{x:d("x"),y:d("y"),z:d("z")},hidesurface:{valType:"boolean",dflt:!1,description:["Determines whether or not a surface is drawn.","For example, set `hidesurface` to *false*","`contours.x.show` to *true* and","`contours.y.show` to *true* to draw a wire frame plot."].join(" ")},lightposition:{x:{valType:"number",min:-1e5,max:1e5,dflt:10,description:"Numeric vector, representing the X coordinate for each vertex."},y:{valType:"number",min:-1e5,max:1e5,dflt:1e4,description:"Numeric vector, representing the Y coordinate for each vertex."},z:{valType:"number",min:-1e5,max:1e5,dflt:0,description:"Numeric vector, representing the Z coordinate for each vertex."}},lighting:{ambient:{valType:"number",min:0,max:1,dflt:.8,description:"Ambient light increases overall color visibility but can wash out the image."},diffuse:{valType:"number",min:0,max:1,dflt:.8,description:"Represents the extent that incident rays are reflected in a range of angles."},specular:{valType:"number",min:0,max:2,dflt:.05,description:"Represents the level that incident rays are reflected in a single direction, causing shine."},roughness:{valType:"number",min:0,max:1,dflt:.5,description:"Alters specular reflection; the rougher the surface, the wider and less contrasty the shine."},fresnel:{valType:"number",min:0,max:5,dflt:.2,description:["Represents the reflectance as a dependency of the viewing angle; e.g. paper is reflective","when viewing it from the edge of the paper (almost 90 degrees), causing shine."].join(" ")}},opacity:{valType:"number",min:0,max:1,dflt:1,description:["Sets the opacity of the surface.","Please note that in the case of using high `opacity` values for example a value","greater than or equal to 0.5 on two surfaces (and 0.25 with four surfaces), an","overlay of multiple transparent surfaces may not perfectly be sorted in depth by the","webgl API. This behavior may be improved in the near future and is subject to change."].join(" ")},opacityscale:{valType:"any",editType:"calc",description:["Sets the opacityscale.","The opacityscale must be an array containing","arrays mapping a normalized value to an opacity value.","At minimum, a mapping for the lowest (0) and highest (1)","values are required. For example,","`[[0, 1], [0.5, 0.2], [1, 1]]` means that higher/lower values would have","higher opacity values and those in the middle would be more transparent","Alternatively, `opacityscale` may be a palette name string","of the following list: 'min', 'max', 'extremes' and 'uniform'.","The default is 'uniform'."].join(" ")},_deprecated:{zauto:l({},i.zauto,{description:"Obsolete. Use `cauto` instead."}),zmin:l({},i.zmin,{description:"Obsolete. Use `cmin` instead."}),zmax:l({},i.zmax,{description:"Obsolete. Use `cmax` instead."})},hoverinfo:l({},s.hoverinfo),showlegend:l({},s.showlegend,{dflt:!1})}),"calc","nested");h.x.editType=h.y.editType=h.z.editType="calc+clearAxisTypes",h.transforms=void 0},6978:(e,t,r)=>{"use strict";var n=r(95500);e.exports=function(e,t){t.surfacecolor?n(e,t,{vals:t.surfacecolor,containerStr:"",cLetter:"c"}):n(e,t,{vals:t.z,containerStr:"",cLetter:"c"})}},47152:(e,t,r)=>{"use strict";var n=r(76107).gl_surface3d,i=r(76107).ndarray,o=r(76107).ndarray_linear_interpolate.d2,a=r(71034),s=r(55059),l=r(84468).isArrayOrTypedArray,c=r(23207).parseColorScale,u=r(79689),d=r(39265).extractOpts;function h(e,t,r){this.scene=e,this.uid=r,this.surface=t,this.data=null,this.showContour=[!1,!1,!1],this.contourStart=[null,null,null],this.contourEnd=[null,null,null],this.contourSize=[0,0,0],this.minValues=[1/0,1/0,1/0],this.maxValues=[-1/0,-1/0,-1/0],this.dataScaleX=1,this.dataScaleY=1,this.refineData=!0,this.objectOffset=[0,0,0]}var p=h.prototype;p.getXat=function(e,t,r,n){var i=l(this.data.x)?l(this.data.x[0])?this.data.x[t][e]:this.data.x[e]:e;return void 0===r?i:n.d2l(i,0,r)},p.getYat=function(e,t,r,n){var i=l(this.data.y)?l(this.data.y[0])?this.data.y[t][e]:this.data.y[t]:t;return void 0===r?i:n.d2l(i,0,r)},p.getZat=function(e,t,r,n){var i=this.data.z[t][e];return null===i&&this.data.connectgaps&&this.data._interpolatedZ&&(i=this.data._interpolatedZ[t][e]),void 0===r?i:n.d2l(i,0,r)},p.handlePick=function(e){if(e.object===this.surface){var t=(e.data.index[0]-1)/this.dataScaleX-1,r=(e.data.index[1]-1)/this.dataScaleY-1,n=Math.max(Math.min(Math.round(t),this.data.z[0].length-1),0),i=Math.max(Math.min(Math.round(r),this.data._ylength-1),0);e.index=[n,i],e.traceCoordinate=[this.getXat(n,i),this.getYat(n,i),this.getZat(n,i)],e.dataCoordinate=[this.getXat(n,i,this.data.xcalendar,this.scene.fullSceneLayout.xaxis),this.getYat(n,i,this.data.ycalendar,this.scene.fullSceneLayout.yaxis),this.getZat(n,i,this.data.zcalendar,this.scene.fullSceneLayout.zaxis)];for(var o=0;o<3;o++){var a=e.dataCoordinate[o];null!==a&&void 0!==a&&(e.dataCoordinate[o]*=this.scene.dataScale[o])}var s=this.data.hovertext||this.data.text;return l(s)&&s[i]&&void 0!==s[i][n]?e.textLabel=s[i][n]:e.textLabel=s||"",e.data.dataCoordinate=e.dataCoordinate.slice(),this.surface.highlight(e.data),this.scene.glplot.spikes.position=e.dataCoordinate,!0}};var f=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997,1009,1013,1019,1021,1031,1033,1039,1049,1051,1061,1063,1069,1087,1091,1093,1097,1103,1109,1117,1123,1129,1151,1153,1163,1171,1181,1187,1193,1201,1213,1217,1223,1229,1231,1237,1249,1259,1277,1279,1283,1289,1291,1297,1301,1303,1307,1319,1321,1327,1361,1367,1373,1381,1399,1409,1423,1427,1429,1433,1439,1447,1451,1453,1459,1471,1481,1483,1487,1489,1493,1499,1511,1523,1531,1543,1549,1553,1559,1567,1571,1579,1583,1597,1601,1607,1609,1613,1619,1621,1627,1637,1657,1663,1667,1669,1693,1697,1699,1709,1721,1723,1733,1741,1747,1753,1759,1777,1783,1787,1789,1801,1811,1823,1831,1847,1861,1867,1871,1873,1877,1879,1889,1901,1907,1913,1931,1933,1949,1951,1973,1979,1987,1993,1997,1999,2003,2011,2017,2027,2029,2039,2053,2063,2069,2081,2083,2087,2089,2099,2111,2113,2129,2131,2137,2141,2143,2153,2161,2179,2203,2207,2213,2221,2237,2239,2243,2251,2267,2269,2273,2281,2287,2293,2297,2309,2311,2333,2339,2341,2347,2351,2357,2371,2377,2381,2383,2389,2393,2399,2411,2417,2423,2437,2441,2447,2459,2467,2473,2477,2503,2521,2531,2539,2543,2549,2551,2557,2579,2591,2593,2609,2617,2621,2633,2647,2657,2659,2663,2671,2677,2683,2687,2689,2693,2699,2707,2711,2713,2719,2729,2731,2741,2749,2753,2767,2777,2789,2791,2797,2801,2803,2819,2833,2837,2843,2851,2857,2861,2879,2887,2897,2903,2909,2917,2927,2939,2953,2957,2963,2969,2971,2999];function m(e,t){if(e0){r=f[n];break}return r}function v(e,t){if(!(e<1||t<1)){for(var r=g(e),n=g(t),i=1,o=0;o_;)r--,r/=y(r),++r1?n:1},p.refineCoords=function(e){for(var t=this.dataScaleX,r=this.dataScaleY,n=e[0].shape[0],o=e[0].shape[1],a=0|Math.floor(e[0].shape[0]*t+1),s=0|Math.floor(e[0].shape[1]*r+1),l=1+n+1,c=1+o+1,u=i(new Float32Array(l*c),[l,c]),d=[1/t,0,0,0,1/r,0,0,0,1],h=0;h0&&null!==this.contourStart[e]&&null!==this.contourEnd[e]&&this.contourEnd[e]>this.contourStart[e]))for(i[e]=!0,t=this.contourStart[e];to&&(this.minValues[t]=o),this.maxValues[t]{"use strict";var n=r(38361),i=r(84468),o=r(16155),a=r(41094);function s(e,t,r,n){var i=n("opacityscale");"max"===i?t.opacityscale=[[0,.1],[1,1]]:"min"===i?t.opacityscale=[[0,1],[1,.1]]:"extremes"===i?t.opacityscale=function(e,t){for(var r=[],n=0;n<32;n++){var i=n/31,o=t+(1-t)*(1-Math.pow(Math.sin(e*i*Math.PI),2));r.push([i,Math.max(0,Math.min(1,o))])}return r}(1,.1):function(e){var t=0;if(!Array.isArray(e)||e.length<2)return!1;if(!e[0]||!e[e.length-1])return!1;if(0!==+e[0][0]||1!==+e[e.length-1][0])return!1;for(var r=0;r{"use strict";e.exports={attributes:r(41094),supplyDefaults:r(25969).supplyDefaults,colorbar:{min:"cmin",max:"cmax"},calc:r(6978),plot:r(47152),moduleType:"trace",name:"surface",basePlotModule:r(48648),categories:["gl3d","2dMap","showLegend"],meta:{description:["The data the describes the coordinates of the surface is set in `z`.","Data in `z` should be a {2D array}.","Coordinates in `x` and `y` can either be 1D {arrays}","or {2D arrays} (e.g. to graph parametric surfaces).","If not provided in `x` and `y`, the x and y coordinates are assumed","to be linear starting at 0 with a unit step.","The color scale corresponds to the `z` values by default.","For custom color scales, use `surfacecolor` which should be a {2D array},","where its bounds can be controlled using `cmin` and `cmax`."].join(" ")}}},90927:(e,t,r)=>{"use strict";var n=r(38467),i=r(64022).extendFlat,o=r(72587).overrideAll,a=r(91740),s=r(81159).u,l=r(39363).descriptionOnlyNumbers;(e.exports=o({domain:s({name:"table",trace:!0}),columnwidth:{valType:"number",arrayOk:!0,dflt:null,description:["The width of columns expressed as a ratio. Columns fill the available width","in proportion of their specified column widths."].join(" ")},columnorder:{valType:"data_array",description:["Specifies the rendered order of the data columns; for example, a value `2` at position `0`","means that column index `0` in the data will be rendered as the","third column, as columns have an index base of zero."].join(" ")},header:{values:{valType:"data_array",dflt:[],description:["Header cell values. `values[m][n]` represents the value of the `n`th point in column `m`,","therefore the `values[m]` vector length for all columns must be the same (longer vectors","will be truncated). Each value must be a finite number or a string."].join(" ")},format:{valType:"data_array",dflt:[],description:l("cell value")},prefix:{valType:"string",arrayOk:!0,dflt:null,description:"Prefix for cell values."},suffix:{valType:"string",arrayOk:!0,dflt:null,description:"Suffix for cell values."},height:{valType:"number",dflt:28,description:"The height of cells."},align:i({},n.align,{arrayOk:!0}),line:{width:{valType:"number",arrayOk:!0,dflt:1},color:{valType:"color",arrayOk:!0,dflt:"grey"}},fill:{color:{valType:"color",arrayOk:!0,dflt:"white",description:["Sets the cell fill color. It accepts either a specific color","or an array of colors or a 2D array of colors."].join(" ")}},font:i({},a({arrayOk:!0}))},cells:{values:{valType:"data_array",dflt:[],description:["Cell values. `values[m][n]` represents the value of the `n`th point in column `m`,","therefore the `values[m]` vector length for all columns must be the same (longer vectors","will be truncated). Each value must be a finite number or a string."].join(" ")},format:{valType:"data_array",dflt:[],description:l("cell value")},prefix:{valType:"string",arrayOk:!0,dflt:null,description:"Prefix for cell values."},suffix:{valType:"string",arrayOk:!0,dflt:null,description:"Suffix for cell values."},height:{valType:"number",dflt:20,description:"The height of cells."},align:i({},n.align,{arrayOk:!0}),line:{width:{valType:"number",arrayOk:!0,dflt:1},color:{valType:"color",arrayOk:!0,dflt:"grey"}},fill:{color:{valType:"color",arrayOk:!0,dflt:"white",description:["Sets the cell fill color. It accepts either a specific color","or an array of colors or a 2D array of colors."].join(" ")}},font:i({},a({arrayOk:!0}))}},"calc","from-root")).transforms=void 0},41225:(e,t,r)=>{"use strict";var n=r(50246).eV,i=r(32649),o="table";t.name=o,t.plot=function(e){var t=n(e.calcdata,o)[0];t.length&&i(e,t)},t.clean=function(e,t,r,n){var i=n._has&&n._has(o),a=t._has&&t._has(o);i&&!a&&n._paperdiv.selectAll(".table").remove()}},87855:(e,t,r)=>{"use strict";var n=r(85876).wrap;e.exports=function(){return n({})}},5769:e=>{"use strict";e.exports={cellPad:8,columnExtentOffset:10,columnTitleOffset:28,emptyHeaderHeight:16,latexCheck:/^\$.*\$$/,goldenRatio:1.618,lineBreaker:"
",maxDimensionCount:60,overdrag:45,releaseTransitionDuration:120,releaseTransitionEase:"cubic-out",scrollbarCaptureWidth:18,scrollbarHideDelay:1e3,scrollbarHideDuration:1e3,scrollbarOffset:5,scrollbarWidth:8,transitionDuration:100,transitionEase:"cubic-out",uplift:5,wrapSpacer:" ",wrapSplitCharacter:" ",cn:{table:"table",tableControlView:"table-control-view",scrollBackground:"scroll-background",yColumn:"y-column",columnBlock:"column-block",scrollAreaClip:"scroll-area-clip",scrollAreaClipRect:"scroll-area-clip-rect",columnBoundary:"column-boundary",columnBoundaryClippath:"column-boundary-clippath",columnBoundaryRect:"column-boundary-rect",columnCells:"column-cells",columnCell:"column-cell",cellRect:"cell-rect",cellText:"cell-text",cellTextHolder:"cell-text-holder",scrollbarKit:"scrollbar-kit",scrollbar:"scrollbar",scrollbarSlider:"scrollbar-slider",scrollbarGlyph:"scrollbar-glyph",scrollbarCaptureZone:"scrollbar-capture-zone"}}},1391:(e,t,r)=>{"use strict";var n=r(5769),i=r(64022).extendFlat,o=r(22036),a=r(19045).isTypedArray,s=r(19045).isArrayOrTypedArray;function l(e){if(s(e)){for(var t=0,r=0;r=t||c===e.length-1)&&(n[i]=a,a.key=l++,a.firstRowIndex=s,a.lastRowIndex=c,a={firstRowIndex:null,lastRowIndex:null,rows:[]},i+=o,s=c+1,o=0);return n}e.exports=function(e,t){var r=u(t.cells.values),a=function(e){return e.slice(t.header.values.length,e.length)},m=u(t.header.values);m.length&&!m[0].length&&(m[0]=[""],m=u(m));var g=m.concat(a(r).map((function(){return d((m[0]||[""]).length)}))),y=t.domain,v=Math.floor(e._fullLayout._size.w*(y.x[1]-y.x[0])),x=Math.floor(e._fullLayout._size.h*(y.y[1]-y.y[0])),b=t.header.values.length?g[0].map((function(){return t.header.height})):[n.emptyHeaderHeight],_=r.length?r[0].map((function(){return t.cells.height})):[],w=b.reduce(c,0),k=f(_,x-w+n.uplift),S=p(f(b,w),[]),A=p(k,S),T={},M=t._fullInput.columnorder;s(M)&&(M=Array.from(M)),M=M.concat(a(r.map((function(e,t){return t}))));var C=g.map((function(e,r){var n=s(t.columnwidth)?t.columnwidth[Math.min(r,t.columnwidth.length-1)]:t.columnwidth;return o(n)?Number(n):1})),E=C.reduce(c,0);C=C.map((function(e){return e/E*v}));var I=Math.max(l(t.header.line.width),l(t.cells.line.width)),P={key:t.uid+e._context.staticPlot,translateX:y.x[0]*e._fullLayout._size.w,translateY:e._fullLayout._size.h*(1-y.y[1]),size:e._fullLayout._size,width:v,maxLineWidth:I,height:x,columnOrder:M,groupHeight:x,rowBlocks:A,headerRowBlocks:S,scrollY:0,cells:i({},t.cells,{values:r}),headerCells:i({},t.header,{values:g}),gdColumns:g.map((function(e){return e[0]})),gdColumnsOriginalOrder:g.map((function(e){return e[0]})),prevPages:[0,0],scrollbarState:{scrollbarScrollInProgress:!1},columns:g.map((function(e,t){var r=T[e];return T[e]=(r||0)+1,{key:e+"__"+T[e],label:e,specIndex:t,xIndex:M[t],xScale:h,x:void 0,calcdata:void 0,columnWidth:C[t]}}))};return P.columns.forEach((function(e){e.calcdata=P,e.x=h(e)})),P}},44735:(e,t,r)=>{"use strict";var n=r(64022).extendFlat;t.splitToPanels=function(e){var t=[0,0],r=n({},e,{key:"header",type:"header",page:0,prevPages:t,currentRepaint:[null,null],dragHandle:!0,values:e.calcdata.headerCells.values[e.specIndex],rowBlocks:e.calcdata.headerRowBlocks,calcdata:n({},e.calcdata,{cells:e.calcdata.headerCells})});return[n({},e,{key:"cells1",type:"cells",page:0,prevPages:t,currentRepaint:[null,null],dragHandle:!1,values:e.calcdata.cells.values[e.specIndex],rowBlocks:e.calcdata.rowBlocks}),n({},e,{key:"cells2",type:"cells",page:1,prevPages:t,currentRepaint:[null,null],dragHandle:!1,values:e.calcdata.cells.values[e.specIndex],rowBlocks:e.calcdata.rowBlocks}),r]},t.splitToCells=function(e){var t=function(e){var t=e.rowBlocks[e.page],r=t?t.rows[0].rowIndex:0,n=t?r+t.rows.length:0;return[r,n]}(e);return(e.values||[]).slice(t[0],t[1]).map((function(r,n){return{keyWithinBlock:n+("string"===typeof r&&r.match(/[<$&> ]/)?"_keybuster_"+Math.random():""),key:t[0]+n,column:e,calcdata:e.calcdata,page:e.page,rowBlocks:e.rowBlocks,value:r}}))}},6152:(e,t,r)=>{"use strict";var n=r(84468),i=r(90927),o=r(81159).N;e.exports=function(e,t,r,a){function s(r,o){return n.coerce(e,t,i,r,o)}o(t,a,s),s("columnwidth"),s("header.values"),s("header.format"),s("header.align"),s("header.prefix"),s("header.suffix"),s("header.height"),s("header.line.width"),s("header.line.color"),s("header.fill.color"),n.coerceFont(s,"header.font",a.font),function(e,t){for(var r=e.columnorder||[],n=e.header.values.length,i=r.slice(0,n),o=i.slice().sort((function(e,t){return e-t})),a=i.map((function(e){return o.indexOf(e)})),s=a.length;s{"use strict";e.exports={attributes:r(90927),supplyDefaults:r(6152),calc:r(87855),plot:r(32649),moduleType:"trace",name:"table",basePlotModule:r(41225),categories:["noOpacity"],meta:{description:["Table view for detailed data viewing.","The data are arranged in a grid of rows and columns.","Most styling can be specified for columns, rows or individual cells.","Table is using a column-major order, ie. the grid is represented as a vector of column vectors."].join(" ")}}},32649:(e,t,r)=>{"use strict";var n=r(5769),i=r(41871),o=r(84468),a=o.numberFormat,s=r(85876),l=r(3172),c=r(13480),u=r(84468).raiseToTop,d=r(84468).strTranslate,h=r(84468).cancelTransition,p=r(1391),f=r(44735),m=r(7605);function g(e){return Math.ceil(e.calcdata.maxLineWidth/2)}function y(e,t){return"clip"+e._fullLayout._uid+"_scrollAreaBottomClip_"+t.key}function v(e,t){return"clip"+e._fullLayout._uid+"_columnBoundaryClippath_"+t.calcdata.key+"_"+t.specIndex}function x(e){return[].concat.apply([],e.map((function(e){return e}))).map((function(e){return e.__data__}))}function b(e,t,r){var o=e.selectAll("."+n.cn.scrollbarKit).data(s.repeat,s.keyFun);o.enter().append("g").classed(n.cn.scrollbarKit,!0).style("shape-rendering","geometricPrecision"),o.each((function(e){var t=e.scrollbarState;t.totalHeight=function(e){var t=e.rowBlocks;return z(t,t.length-1)+(t.length?j(t[t.length-1],1/0):1)}(e),t.scrollableAreaHeight=e.groupHeight-C(e),t.currentlyVisibleHeight=Math.min(t.totalHeight,t.scrollableAreaHeight),t.ratio=t.currentlyVisibleHeight/t.totalHeight,t.barLength=Math.max(t.ratio*t.currentlyVisibleHeight,n.goldenRatio*n.scrollbarWidth),t.barWiggleRoom=t.currentlyVisibleHeight-t.barLength,t.wiggleRoom=Math.max(0,t.totalHeight-t.scrollableAreaHeight),t.topY=0===t.barWiggleRoom?0:e.scrollY/t.wiggleRoom*t.barWiggleRoom,t.bottomY=t.topY+t.barLength,t.dragMultiplier=t.wiggleRoom/t.barWiggleRoom})).attr("transform",(function(e){var t=e.width+n.scrollbarWidth/2+n.scrollbarOffset;return d(t,C(e))}));var a=o.selectAll("."+n.cn.scrollbar).data(s.repeat,s.keyFun);a.enter().append("g").classed(n.cn.scrollbar,!0);var l=a.selectAll("."+n.cn.scrollbarSlider).data(s.repeat,s.keyFun);l.enter().append("g").classed(n.cn.scrollbarSlider,!0),l.attr("transform",(function(e){return d(0,e.scrollbarState.topY||0)}));var c=l.selectAll("."+n.cn.scrollbarGlyph).data(s.repeat,s.keyFun);c.enter().append("line").classed(n.cn.scrollbarGlyph,!0).attr("stroke","black").attr("stroke-width",n.scrollbarWidth).attr("stroke-linecap","round").attr("y1",n.scrollbarWidth/2),c.attr("y2",(function(e){return e.scrollbarState.barLength-n.scrollbarWidth/2})).attr("stroke-opacity",(function(e){return e.columnDragInProgress||!e.scrollbarState.barWiggleRoom||r?0:.4})),c.transition().delay(0).duration(0),c.transition().delay(n.scrollbarHideDelay).duration(n.scrollbarHideDuration).attr("stroke-opacity",0);var u=a.selectAll("."+n.cn.scrollbarCaptureZone).data(s.repeat,s.keyFun);u.enter().append("line").classed(n.cn.scrollbarCaptureZone,!0).attr("stroke","white").attr("stroke-opacity",.01).attr("stroke-width",n.scrollbarCaptureWidth).attr("stroke-linecap","butt").attr("y1",0).on("mousedown",(function(r){var n=i.event.y,o=this.getBoundingClientRect(),a=r.scrollbarState,s=n-o.top,l=i.scale.linear().domain([0,a.scrollableAreaHeight]).range([0,a.totalHeight]).clamp(!0);a.topY<=s&&s<=a.bottomY||I(t,e,null,l(s-a.barLength/2))(r)})).call(i.behavior.drag().origin((function(e){return i.event.stopPropagation(),e.scrollbarState.scrollbarScrollInProgress=!0,e})).on("drag",I(t,e)).on("dragend",(function(){}))),u.attr("y2",(function(e){return e.scrollbarState.scrollableAreaHeight})),t._context.staticPlot&&(c.remove(),u.remove())}function _(e,t,r,o){var a=function(e){var t=e.selectAll("."+n.cn.columnCells).data(s.repeat,s.keyFun);return t.enter().append("g").classed(n.cn.columnCells,!0),t.exit().remove(),t}(r),c=function(e){var t=e.selectAll("."+n.cn.columnCell).data(f.splitToCells,(function(e){return e.keyWithinBlock}));return t.enter().append("g").classed(n.cn.columnCell,!0),t.exit().remove(),t}(a);!function(e){e.each((function(e,t){var r=e.calcdata.cells.font,n=e.column.specIndex,i={size:S(r.size,n,t),color:S(r.color,n,t),family:S(r.family,n,t),weight:S(r.weight,n,t),style:S(r.style,n,t),variant:S(r.variant,n,t),textcase:S(r.textcase,n,t),lineposition:S(r.lineposition,n,t),shadow:S(r.shadow,n,t)};e.rowNumber=e.key,e.align=S(e.calcdata.cells.align,n,t),e.cellBorderWidth=S(e.calcdata.cells.line.width,n,t),e.font=i}))}(c);var u=function(e){var t=e.selectAll("."+n.cn.cellRect).data(s.repeat,(function(e){return e.keyWithinBlock}));return t.enter().append("rect").classed(n.cn.cellRect,!0),t}(c);!function(e){e.attr("width",(function(e){return e.column.columnWidth})).attr("stroke-width",(function(e){return e.cellBorderWidth})).each((function(e){var t=i.select(this);m.stroke(t,S(e.calcdata.cells.line.color,e.column.specIndex,e.rowNumber)),m.fill(t,S(e.calcdata.cells.fill.color,e.column.specIndex,e.rowNumber))}))}(u);var d=function(e){var t=e.selectAll("."+n.cn.cellTextHolder).data(s.repeat,(function(e){return e.keyWithinBlock}));return t.enter().append("g").classed(n.cn.cellTextHolder,!0).style("shape-rendering","geometricPrecision"),t}(c),h=function(e){var t=e.selectAll("."+n.cn.cellText).data(s.repeat,(function(e){return e.keyWithinBlock}));return t.enter().append("text").classed(n.cn.cellText,!0).style("cursor",(function(){return"auto"})).on("mousedown",(function(){i.event.stopPropagation()})),t}(d);!function(e){e.each((function(e){l.font(i.select(this),e.font)}))}(h),w(h,t,o,e),D(c)}function w(e,t,r,o){e.text((function(e){var t=e.column.specIndex,r=e.rowNumber,i=e.value,o="string"===typeof i,s=o&&i.match(/
/i),l=!o||s;e.mayHaveMarkup=o&&i.match(/[<&>]/);var c,u="string"===typeof(c=i)&&c.match(n.latexCheck);e.latex=u;var d,h,p=u?"":S(e.calcdata.cells.prefix,t,r)||"",f=u?"":S(e.calcdata.cells.suffix,t,r)||"",m=u?null:S(e.calcdata.cells.format,t,r)||null,g=p+(m?a(m)(e.value):e.value)+f;if(e.wrappingNeeded=!e.wrapped&&!l&&!u&&(d=k(g)),e.cellHeightMayIncrease=s||u||e.mayHaveMarkup||(void 0===d?k(g):d),e.needsConvertToTspans=e.mayHaveMarkup||e.wrappingNeeded||e.latex,e.wrappingNeeded){var y=(" "===n.wrapSplitCharacter?g.replace(/i&&n.push(o),i+=l}return n}(i,l,s);1===c.length&&(c[0]===i.length-1?c.unshift(c[0]-1):c.push(c[0]+1)),c[0]%2&&c.reverse(),t.each((function(e,t){e.page=c[t],e.scrollY=l})),t.attr("transform",(function(e){var t=z(e.rowBlocks,e.page)-e.scrollY;return d(0,t)})),e&&(P(e,r,t,c,n.prevPages,n,0),P(e,r,t,c,n.prevPages,n,1),b(r,e))}}function I(e,t,r,o){return function(a){var s=a.calcdata?a.calcdata:a,l=t.filter((function(e){return s.key===e.key})),c=r||s.scrollbarState.dragMultiplier,u=s.scrollY;s.scrollY=void 0===o?s.scrollY+c*i.event.dy:o;var d=l.selectAll("."+n.cn.yColumn).selectAll("."+n.cn.columnBlock).filter(T);return E(e,d,l),s.scrollY===u}}function P(e,t,r,n,i,o,a){n[a]!==i[a]&&(clearTimeout(o.currentRepaint[a]),o.currentRepaint[a]=setTimeout((function(){var o=r.filter((function(e,t){return t===a&&n[t]!==i[t]}));_(e,t,o,r),i[a]=n[a]})))}function O(e,t,r,o){return function(){var a=i.select(t.parentNode);a.each((function(e){var t=e.fragments;a.selectAll("tspan.line").each((function(e,r){t[r].width=this.getComputedTextLength()}));var r,i,o=t[t.length-1].width,s=t.slice(0,-1),l=[],c=0,u=e.column.columnWidth-2*n.cellPad;for(e.value="";s.length;)c+(i=(r=s.shift()).width+o)>u&&(e.value+=l.join(n.wrapSpacer)+n.lineBreaker,l=[],c=0),l.push(r.text),c+=i;c&&(e.value+=l.join(n.wrapSpacer)),e.wrapped=!0})),a.selectAll("tspan.line").remove(),w(a.select("."+n.cn.cellText),r,e,o),i.select(t.parentNode.parentNode).call(D)}}function R(e,t,r,o,a){return function(){if(!a.settledY){var s=i.select(t.parentNode),l=N(a),c=a.key-l.firstRowIndex,u=l.rows[c].rowHeight,h=a.cellHeightMayIncrease?t.parentNode.getBoundingClientRect().height+2*n.cellPad:u,p=Math.max(h,u);p-l.rows[c].rowHeight&&(l.rows[c].rowHeight=p,e.selectAll("."+n.cn.columnCell).call(D),E(null,e.filter(T),0),b(r,o,!0)),s.attr("transform",(function(){var e=this,t=e.parentNode.getBoundingClientRect(),r=i.select(e.parentNode).select("."+n.cn.cellRect).node().getBoundingClientRect(),o=e.transform.baseVal.consolidate(),s=r.top-t.top+(o?o.matrix.f:n.cellPad);return d(L(a,i.select(e.parentNode).select("."+n.cn.cellTextHolder).node().getBoundingClientRect().width),s)})),a.settledY=!0}}}function L(e,t){switch(e.align){case"left":default:return n.cellPad;case"right":return e.column.columnWidth-(t||0)-n.cellPad;case"center":return(e.column.columnWidth-(t||0))/2}}function D(e){e.attr("transform",(function(e){var t=e.rowBlocks[0].auxiliaryBlocks.reduce((function(e,t){return e+j(t,1/0)}),0),r=j(N(e),e.key);return d(0,r+t)})).selectAll("."+n.cn.cellRect).attr("height",(function(e){return(t=N(e),r=e.key,t.rows[r-t.firstRowIndex]).rowHeight;var t,r}))}function z(e,t){for(var r=0,n=t-1;n>=0;n--)r+=F(e[n]);return r}function j(e,t){for(var r=0,n=0;n{"use strict";var n=r(84425).rb,i=r(84425).ay,o=r(6636),a=r(81159).u,s=r(59453),l=r(10535),c=r(35995),u=r(64022).extendFlat,d=r(2703).k;e.exports={labels:l.labels,parents:l.parents,values:l.values,branchvalues:l.branchvalues,count:l.count,level:l.level,maxdepth:l.maxdepth,tiling:{packing:{valType:"enumerated",values:["squarify","binary","dice","slice","slice-dice","dice-slice"],dflt:"squarify",editType:"plot",description:["Determines d3 treemap solver.","For more info please refer to https://github.com/d3/d3-hierarchy#treemap-tiling"].join(" ")},squarifyratio:{valType:"number",min:1,dflt:1,editType:"plot",description:["When using *squarify* `packing` algorithm, according to https://github.com/d3/d3-hierarchy/blob/v3.1.1/README.md#squarify_ratio","this option specifies the desired aspect ratio of the generated rectangles.","The ratio must be specified as a number greater than or equal to one.","Note that the orientation of the generated rectangles (tall or wide)","is not implied by the ratio; for example, a ratio of two will attempt","to produce a mixture of rectangles whose width:height ratio is either 2:1 or 1:2.","When using *squarify*, unlike d3 which uses the Golden Ratio i.e. 1.618034,","Plotly applies 1 to increase squares in treemap layouts."].join(" ")},flip:{valType:"flaglist",flags:["x","y"],dflt:"",editType:"plot",description:["Determines if the positions obtained from solver are flipped on each axis."].join(" ")},pad:{valType:"number",min:0,dflt:3,editType:"plot",description:["Sets the inner padding (in px)."].join(" ")},editType:"calc"},marker:u({pad:{t:{valType:"number",min:0,editType:"plot",description:["Sets the padding form the top (in px)."].join(" ")},l:{valType:"number",min:0,editType:"plot",description:["Sets the padding form the left (in px)."].join(" ")},r:{valType:"number",min:0,editType:"plot",description:["Sets the padding form the right (in px)."].join(" ")},b:{valType:"number",min:0,editType:"plot",description:["Sets the padding form the bottom (in px)."].join(" ")},editType:"calc"},colors:l.marker.colors,pattern:d,depthfade:{valType:"enumerated",values:[!0,!1,"reversed"],editType:"style",description:["Determines if the sector colors are faded towards","the background from the leaves up to the headers.","This option is unavailable when a `colorscale` is present,","defaults to false when `marker.colors` is set,","but otherwise defaults to true.","When set to *reversed*, the fading direction is inverted,","that is the top elements within hierarchy are drawn with fully saturated colors","while the leaves are faded towards the background color."].join(" ")},line:l.marker.line,cornerradius:{valType:"number",min:0,dflt:0,editType:"plot",description:["Sets the maximum rounding of corners (in px)."].join(" ")},editType:"calc"},o("marker",{colorAttr:"colors",anim:!1})),pathbar:{visible:{valType:"boolean",dflt:!0,editType:"plot",description:["Determines if the path bar is drawn","i.e. outside the trace `domain` and","with one pixel gap."].join(" ")},side:{valType:"enumerated",values:["top","bottom"],dflt:"top",editType:"plot",description:["Determines on which side of the the treemap the","`pathbar` should be presented."].join(" ")},edgeshape:{valType:"enumerated",values:[">","<","|","/","\\"],dflt:">",editType:"plot",description:["Determines which shape is used for edges between `barpath` labels."].join(" ")},thickness:{valType:"number",min:12,editType:"plot",description:["Sets the thickness of `pathbar` (in px). If not specified the `pathbar.textfont.size` is used","with 3 pixles extra padding on each side."].join(" ")},textfont:u({},s.textfont,{description:"Sets the font used inside `pathbar`."}),editType:"calc"},text:s.text,textinfo:l.textinfo,texttemplate:i({editType:"plot"},{keys:c.eventDataKeys.concat(["label","value"])}),hovertext:s.hovertext,hoverinfo:l.hoverinfo,hovertemplate:n({},{keys:c.eventDataKeys}),textfont:s.textfont,insidetextfont:s.insidetextfont,outsidetextfont:u({},s.outsidetextfont,{description:["Sets the font used for `textinfo` lying outside the sector.","This option refers to the root of the hierarchy","presented on top left corner of a treemap graph.","Please note that if a hierarchy has multiple root nodes,","this option won't have any effect and `insidetextfont` would be used."].join(" ")}),textposition:{valType:"enumerated",values:["top left","top center","top right","middle left","middle center","middle right","bottom left","bottom center","bottom right"],dflt:"top left",editType:"plot",description:["Sets the positions of the `text` elements."].join(" ")},sort:s.sort,root:l.root,domain:a({name:"treemap",trace:!0,editType:"calc"})}},10347:(e,t,r)=>{"use strict";var n=r(68543);t.name="treemap",t.plot=function(e,r,i,o){n.plotBasePlot(t.name,e,r,i,o)},t.clean=function(e,r,i,o){n.cleanBasePlot(t.name,e,r,i,o)}},28845:(e,t,r)=>{"use strict";var n=r(54151);t._=function(e,t){return n.calc(e,t)},t.t=function(e){return n._runCrossTraceCalc("treemap",e)}},35995:e=>{"use strict";e.exports={CLICK_TRANSITION_TIME:750,CLICK_TRANSITION_EASING:"poly",eventDataKeys:["currentPath","root","entry","percentRoot","percentEntry","percentParent"],gapWithPathbar:1}},82190:(e,t,r)=>{"use strict";var n=r(84468),i=r(14345),o=r(7605),a=r(81159).N,s=r(81543).handleText,l=r(41508).TEXTPAD,c=r(69834).handleMarkerDefaults,u=r(39265),d=u.hasColorscale,h=u.handleDefaults;e.exports=function(e,t,r,u){function p(r,o){return n.coerce(e,t,i,r,o)}var f=p("labels"),m=p("parents");if(f&&f.length&&m&&m.length){var g=p("values");g&&g.length?p("branchvalues"):p("count"),p("level"),p("maxdepth"),"squarify"===p("tiling.packing")&&p("tiling.squarifyratio"),p("tiling.flip"),p("tiling.pad");var y=p("text");p("texttemplate"),t.texttemplate||p("textinfo",n.isArrayOrTypedArray(y)?"text+label":"label"),p("hovertext"),p("hovertemplate");var v=p("pathbar.visible");s(e,t,u,p,"auto",{hasPathbar:v,moduleHasSelected:!1,moduleHasUnselected:!1,moduleHasConstrain:!1,moduleHasCliponaxis:!1,moduleHasTextangle:!1,moduleHasInsideanchor:!1}),p("textposition");var x=-1!==t.textposition.indexOf("bottom");c(e,t,u,p),(t._hasColorscale=d(e,"marker","colors")||(e.marker||{}).coloraxis)?h(e,t,u,p,{prefix:"marker.",cLetter:"c"}):p("marker.depthfade",!(t.marker.colors||[]).length);var b=2*t.textfont.size;p("marker.pad.t",x?b/4:b),p("marker.pad.l",b/4),p("marker.pad.r",b/4),p("marker.pad.b",x?b:b/4),p("marker.cornerradius"),t._hovered={marker:{line:{width:2,color:o.contrast(u.paper_bgcolor)}}},v&&(p("pathbar.thickness",t.pathbar.textfont.size+2*l),p("pathbar.side"),p("pathbar.edgeshape")),p("sort"),p("root.color"),a(t,u,p),t._length=null}else t.visible=!1}},18434:(e,t,r)=>{"use strict";var n=r(41871),i=r(4425),o=r(35655).clearMinTextSize,a=r(52464).resizeText,s=r(40968);e.exports=function(e,t,r,l,c){var u,d,h=c.type,p=c.drawDescendants,f=e._fullLayout,m=f["_"+h+"layer"],g=!r;(o(h,f),(u=m.selectAll("g.trace."+h).data(t,(function(e){return e[0].trace.uid}))).enter().append("g").classed("trace",!0).classed(h,!0),u.order(),!f.uniformtext.mode&&i.hasTransition(r))?(l&&(d=l()),n.transition().duration(r.duration).ease(r.easing).each("end",(function(){d&&d()})).each("interrupt",(function(){d&&d()})).each((function(){m.selectAll("g.trace").each((function(t){s(e,t,this,r,p)}))}))):(u.each((function(t){s(e,t,this,r,p)})),f.uniformtext.mode&&a(e,m.selectAll(".trace"),h));g&&u.exit().remove()}},6403:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468),o=r(3172),a=r(13480),s=r(41524),l=r(65283).styleOne,c=r(35995),u=r(4425),d=r(10676),h=!0;e.exports=function(e,t,r,p,f){var m=f.barDifY,g=f.width,y=f.height,v=f.viewX,x=f.viewY,b=f.pathSlice,_=f.toMoveInsideSlice,w=f.strTransform,k=f.hasTransition,S=f.handleSlicesExit,A=f.makeUpdateSliceInterpolator,T=f.makeUpdateTextInterpolator,M={},C=e._context.staticPlot,E=e._fullLayout,I=t[0],P=I.trace,O=I.hierarchy,R=g/P._entryDepth,L=u.listPath(r.data,"id"),D=s(O.copy(),[g,y],{packing:"dice",pad:{inner:0,top:0,left:0,right:0,bottom:0}}).descendants();(D=D.filter((function(e){var t=L.indexOf(e.data.id);return-1!==t&&(e.x0=R*t,e.x1=R*(t+1),e.y0=m,e.y1=m+y,e.onPathbar=!0,!0)}))).reverse(),(p=p.data(D,u.getPtId)).enter().append("g").classed("pathbar",!0),S(p,h,M,[g,y],b),p.order();var z=p;k&&(z=z.transition().each("end",(function(){var t=n.select(this);u.setSliceCursor(t,e,{hideOnRoot:!1,hideOnLeaves:!1,isTransitioning:!1})}))),z.each((function(s){s._x0=v(s.x0),s._x1=v(s.x1),s._y0=x(s.y0),s._y1=x(s.y1),s._hoverX=v(s.x1-Math.min(g,y)/2),s._hoverY=x(s.y1-y/2);var p=n.select(this),f=i.ensureSingle(p,"path","surface",(function(e){e.style("pointer-events",C?"none":"all")}));k?f.transition().attrTween("d",(function(e){var t=A(e,h,M,[g,y]);return function(e){return b(t(e))}})):f.attr("d",b),p.call(d,r,e,t,{styleOne:l,eventDataKeys:c.eventDataKeys,transitionTime:c.CLICK_TRANSITION_TIME,transitionEasing:c.CLICK_TRANSITION_EASING}).call(u.setSliceCursor,e,{hideOnRoot:!1,hideOnLeaves:!1,isTransitioning:e._transitioning}),f.call(l,s,P,e,{hovered:!1}),s._text=(u.getPtLabel(s)||"").split("
").join(" ")||"";var m=i.ensureSingle(p,"g","slicetext"),S=i.ensureSingle(m,"text","",(function(e){e.attr("data-notex",1)})),I=i.ensureUniformFontSize(e,u.determineTextFont(P,s,E.font,{onPathbar:!0}));S.text(s._text||" ").classed("slicetext",!0).attr("text-anchor","start").call(o.font,I).call(a.convertToTspans,e),s.textBB=o.bBox(S.node()),s.transform=_(s,{fontSize:I.size,onPathbar:!0}),s.transform.fontSize=I.size,k?S.transition().attrTween("transform",(function(e){var t=T(e,h,M,[g,y]);return function(e){return w(t(e))}})):S.attr("transform",w(s))}))}},60953:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468),o=r(3172),a=r(13480),s=r(41524),l=r(65283).styleOne,c=r(35995),u=r(4425),d=r(10676),h=r(88817).formatSliceLabel,p=!1;e.exports=function(e,t,r,f,m){var g=m.width,y=m.height,v=m.viewX,x=m.viewY,b=m.pathSlice,_=m.toMoveInsideSlice,w=m.strTransform,k=m.hasTransition,S=m.handleSlicesExit,A=m.makeUpdateSliceInterpolator,T=m.makeUpdateTextInterpolator,M=m.prevEntry,C=e._context.staticPlot,E=e._fullLayout,I=t[0].trace,P=-1!==I.textposition.indexOf("left"),O=-1!==I.textposition.indexOf("right"),R=-1!==I.textposition.indexOf("bottom"),L=!R&&!I.marker.pad.t||R&&!I.marker.pad.b,D=s(r,[g,y],{packing:I.tiling.packing,squarifyratio:I.tiling.squarifyratio,flipX:I.tiling.flip.indexOf("x")>-1,flipY:I.tiling.flip.indexOf("y")>-1,pad:{inner:I.tiling.pad,top:I.marker.pad.t,left:I.marker.pad.l,right:I.marker.pad.r,bottom:I.marker.pad.b}}).descendants(),z=1/0,j=-1/0;D.forEach((function(e){var t=e.depth;t>=I._maxDepth?(e.x0=e.x1=(e.x0+e.x1)/2,e.y0=e.y1=(e.y0+e.y1)/2):(z=Math.min(z,t),j=Math.max(j,t))})),f=f.data(D,u.getPtId),I._maxVisibleLayers=isFinite(j)?j-z+1:0,f.enter().append("g").classed("slice",!0),S(f,p,{},[g,y],b),f.order();var F=null;if(k&&M){var N=u.getPtId(M);f.each((function(e){null===F&&u.getPtId(e)===N&&(F={x0:e.x0,x1:e.x1,y0:e.y0,y1:e.y1})}))}var B=function(){return F||{x0:0,x1:g,y0:0,y1:y}},V=f;return k&&(V=V.transition().each("end",(function(){var t=n.select(this);u.setSliceCursor(t,e,{hideOnRoot:!0,hideOnLeaves:!1,isTransitioning:!1})}))),V.each((function(s){var f=u.isHeader(s,I);s._x0=v(s.x0),s._x1=v(s.x1),s._y0=x(s.y0),s._y1=x(s.y1),s._hoverX=v(s.x1-I.marker.pad.r),s._hoverY=x(R?s.y1-I.marker.pad.b/2:s.y0+I.marker.pad.t/2);var m=n.select(this),S=i.ensureSingle(m,"path","surface",(function(e){e.style("pointer-events",C?"none":"all")}));k?S.transition().attrTween("d",(function(e){var t=A(e,p,B(),[g,y]);return function(e){return b(t(e))}})):S.attr("d",b),m.call(d,r,e,t,{styleOne:l,eventDataKeys:c.eventDataKeys,transitionTime:c.CLICK_TRANSITION_TIME,transitionEasing:c.CLICK_TRANSITION_EASING}).call(u.setSliceCursor,e,{isTransitioning:e._transitioning}),S.call(l,s,I,e,{hovered:!1}),s.x0===s.x1||s.y0===s.y1?s._text="":s._text=f?L?"":u.getPtLabel(s)||"":h(s,r,I,t,E)||"";var M=i.ensureSingle(m,"g","slicetext"),D=i.ensureSingle(M,"text","",(function(e){e.attr("data-notex",1)})),z=i.ensureUniformFontSize(e,u.determineTextFont(I,s,E.font)),j=s._text||" ",F=f&&-1===j.indexOf("
");D.text(j).classed("slicetext",!0).attr("text-anchor",O?"end":P||F?"start":"middle").call(o.font,z).call(a.convertToTspans,e),s.textBB=o.bBox(D.node()),s.transform=_(s,{fontSize:z.size,isHeader:f}),s.transform.fontSize=z.size,k?D.transition().attrTween("transform",(function(e){var t=T(e,p,B(),[g,y]);return function(e){return w(t(e))}})):D.attr("transform",w(s))})),F}},10654:e=>{"use strict";e.exports=function e(t,r,n){var i;n.swapXY&&(i=t.x0,t.x0=t.y0,t.y0=i,i=t.x1,t.x1=t.y1,t.y1=i),n.flipX&&(i=t.x0,t.x0=r[0]-t.x1,t.x1=r[0]-i),n.flipY&&(i=t.y0,t.y0=r[1]-t.y1,t.y1=r[1]-i);var o=t.children;if(o)for(var a=0;a{"use strict";e.exports={moduleType:"trace",name:"treemap",basePlotModule:r(10347),categories:[],animatable:!0,attributes:r(14345),layoutAttributes:r(80996),supplyDefaults:r(82190),supplyLayoutDefaults:r(38483),calc:r(28845)._,crossTraceCalc:r(28845).t,plot:r(37347),style:r(65283).style,colorbar:r(17789),meta:{description:["Visualize hierarchal data from leaves (and/or outer branches) towards root","with rectangles. The treemap sectors are determined by the entries in","*labels* or *ids* and in *parents*."].join(" ")}}},80996:e=>{"use strict";e.exports={treemapcolorway:{valType:"colorlist",editType:"calc",description:["Sets the default treemap slice colors. Defaults to the main","`colorway` used for trace colors. If you specify a new","list here it can still be extended with lighter and darker","colors, see `extendtreemapcolors`."].join(" ")},extendtreemapcolors:{valType:"boolean",dflt:!0,editType:"calc",description:["If `true`, the treemap slice colors (whether given by `treemapcolorway` or","inherited from `colorway`) will be extended to three times its","original length by first repeating every color 20% lighter then","each color 20% darker. This is intended to reduce the likelihood","of reusing the same color when you have many slices, but you can","set `false` to disable.","Colors provided in the trace, using `marker.colors`, are never","extended."].join(" ")}}},38483:(e,t,r)=>{"use strict";var n=r(84468),i=r(80996);e.exports=function(e,t){function r(r,o){return n.coerce(e,t,i,r,o)}r("treemapcolorway",t.colorway),r("extendtreemapcolors")}},41524:(e,t,r)=>{"use strict";var n=r(28203),i=r(10654);e.exports=function(e,t,r){var o,a=r.flipX,s=r.flipY,l="dice-slice"===r.packing,c=r.pad[s?"bottom":"top"],u=r.pad[a?"right":"left"],d=r.pad[a?"left":"right"],h=r.pad[s?"top":"bottom"];l&&(o=u,u=c,c=o,o=d,d=h,h=o);var p=n.treemap().tile(function(e,t){switch(e){case"squarify":return n.treemapSquarify.ratio(t);case"binary":return n.treemapBinary;case"dice":return n.treemapDice;case"slice":return n.treemapSlice;default:return n.treemapSliceDice}}(r.packing,r.squarifyratio)).paddingInner(r.pad.inner).paddingLeft(u).paddingRight(d).paddingTop(c).paddingBottom(h).size(l?[t[1],t[0]]:t)(e);return(l||a||s)&&i(p,t,{swapXY:l,flipX:a,flipY:s}),p}},37347:(e,t,r)=>{"use strict";var n=r(18434),i=r(60953);e.exports=function(e,t,r,o){return n(e,t,r,o,{type:"treemap",drawDescendants:i})}},40968:(e,t,r)=>{"use strict";var n=r(41871),i=r(70359).GW,o=r(4425),a=r(84468),s=r(41508).TEXTPAD,l=r(32018).toMoveInsideBar,c=r(35655).recordMinTextSize,u=r(35995),d=r(6403);function h(e){return o.isHierarchyRoot(e)?"":o.getPtId(e)}e.exports=function(e,t,r,p,f){var m=e._fullLayout,g=t[0],y=g.trace,v="icicle"===y.type,x=g.hierarchy,b=o.findEntryWithLevel(x,y.level),_=n.select(r),w=_.selectAll("g.pathbar"),k=_.selectAll("g.slice");if(!b)return w.remove(),void k.remove();var S=o.isHierarchyRoot(b),A=!m.uniformtext.mode&&o.hasTransition(p),T=o.getMaxDepth(y),M=m._size,C=y.domain,E=M.w*(C.x[1]-C.x[0]),I=M.h*(C.y[1]-C.y[0]),P=E,O=y.pathbar.thickness,R=y.marker.line.width+u.gapWithPathbar,L=y.pathbar.visible?y.pathbar.side.indexOf("bottom")>-1?I+R:-(O+R):0,D={x0:P,x1:P,y0:L,y1:L+O},z=function(e,t,r){var n=y.tiling.pad,i=function(e){return e-n<=t.x0},o=function(e){return e+n>=t.x1},a=function(e){return e-n<=t.y0},s=function(e){return e+n>=t.y1};return e.x0===t.x0&&e.x1===t.x1&&e.y0===t.y0&&e.y1===t.y1?{x0:e.x0,x1:e.x1,y0:e.y0,y1:e.y1}:{x0:i(e.x0-n)?0:o(e.x0-n)?r[0]:e.x0,x1:i(e.x1+n)?0:o(e.x1+n)?r[0]:e.x1,y0:a(e.y0-n)?0:s(e.y0-n)?r[1]:e.y0,y1:a(e.y1+n)?0:s(e.y1+n)?r[1]:e.y1}},j=null,F={},N={},B=null,V=function(e,t){return t?F[h(e)]:N[h(e)]},U=function(e,t,r,n){if(t)return F[h(x)]||D;var i=N[y.level]||r;return function(e){return e.data.depth-b.data.depth=(n-=(v?te:te.r)-s)){var p=(r+n)/2;r=p,n=p}var f;ae?i<(f=o-(v?te:te.b))&&f"===ee?(l.x-=o,c.x-=o,u.x-=o,d.x-=o):"/"===ee?(u.x-=o,d.x-=o,a.x-=o/2,s.x-=o/2):"\\"===ee?(l.x-=o,c.x-=o,a.x-=o/2,s.x-=o/2):"<"===ee&&(a.x-=o,s.x-=o),Q(l),Q(d),Q(a),Q(c),Q(u),Q(s),"M"+K(l.x,l.y)+"L"+K(c.x,c.y)+"L"+K(s.x,s.y)+"L"+K(u.x,u.y)+"L"+K(d.x,d.y)+"L"+K(a.x,a.y)+"Z"},toMoveInsideSlice:se,makeUpdateSliceInterpolator:ce,makeUpdateTextInterpolator:ue,handleSlicesExit:de,hasTransition:A,strTransform:he}):w.remove()}},65283:(e,t,r)=>{"use strict";var n=r(41871),i=r(7605),o=r(84468),a=r(4425),s=r(35655).resizeText,l=r(32155);function c(e,t,r,n,s){var c,u,d=(s||{}).hovered,h=t.data.data,p=h.i,f=h.color,m=a.isHierarchyRoot(t),g=1;if(d)c=r._hovered.marker.line.color,u=r._hovered.marker.line.width;else if(m&&f===r.root.color)g=100,c="rgba(0,0,0,0)",u=0;else if(c=o.castOption(r,p,"marker.line.color")||i.defaultLine,u=o.castOption(r,p,"marker.line.width")||0,!r._hasColorscale&&!t.onPathbar){var y=r.marker.depthfade;if(y){var v,x=i.combine(i.addOpacity(r._backgroundColor,.75),f);if(!0===y){var b=a.getMaxDepth(r);v=isFinite(b)?a.isLeaf(t)?0:r._maxVisibleLayers-(t.data.depth-r._entryDepth):t.data.height+1}else v=t.data.depth-r._entryDepth,r._atRootLevel||v++;if(v>0)for(var _=0;_{"use strict";var n=r(46812),i=r(64022).extendFlat,o=r(39363).axisHoverFormat;e.exports={y:n.y,x:n.x,x0:n.x0,y0:n.y0,xhoverformat:o("x"),yhoverformat:o("y"),name:i({},n.name,{description:["Sets the trace name.","The trace name appears as the legend item and on hover.","For violin traces, the name will also be used for the position","coordinate, if `x` and `x0` (`y` and `y0` if horizontal) are","missing and the position axis is categorical.","Note that the trace name is also used as a default value","for attribute `scalegroup` (please see its description for details)."].join(" ")}),orientation:i({},n.orientation,{description:["Sets the orientation of the violin(s).","If *v* (*h*), the distribution is visualized along","the vertical (horizontal)."].join(" ")}),bandwidth:{valType:"number",min:0,editType:"calc",description:["Sets the bandwidth used to compute the kernel density estimate.","By default, the bandwidth is determined by Silverman's rule of thumb."].join(" ")},scalegroup:{valType:"string",dflt:"",editType:"calc",description:["If there are multiple violins that should be sized according to","to some metric (see `scalemode`), link them by providing a non-empty group id here","shared by every trace in the same group.","If a violin's `width` is undefined, `scalegroup` will default to the trace's name.","In this case, violins with the same names will be linked together"].join(" ")},scalemode:{valType:"enumerated",values:["width","count"],dflt:"width",editType:"calc",description:["Sets the metric by which the width of each violin is determined.","*width* means each violin has the same (max) width","*count* means the violins are scaled by the number of sample points making","up each violin."].join(" ")},spanmode:{valType:"enumerated",values:["soft","hard","manual"],dflt:"soft",editType:"calc",description:["Sets the method by which the span in data space where the density function will be computed.","*soft* means the span goes from the sample's minimum value minus two bandwidths","to the sample's maximum value plus two bandwidths.","*hard* means the span goes from the sample's minimum to its maximum value.","For custom span settings, use mode *manual* and fill in the `span` attribute."].join(" ")},span:{valType:"info_array",items:[{valType:"any",editType:"calc"},{valType:"any",editType:"calc"}],editType:"calc",description:["Sets the span in data space for which the density function will be computed.","Has an effect only when `spanmode` is set to *manual*."].join(" ")},line:{color:{valType:"color",editType:"style",description:"Sets the color of line bounding the violin(s)."},width:{valType:"number",min:0,dflt:2,editType:"style",description:"Sets the width (in px) of line bounding the violin(s)."},editType:"plot"},fillcolor:n.fillcolor,points:i({},n.boxpoints,{description:["If *outliers*, only the sample points lying outside the whiskers","are shown","If *suspectedoutliers*, the outlier points are shown and","points either less than 4*Q1-3*Q3 or greater than 4*Q3-3*Q1","are highlighted (see `outliercolor`)","If *all*, all sample points are shown","If *false*, only the violins are shown with no sample points.","Defaults to *suspectedoutliers* when `marker.outliercolor` or","`marker.line.outliercolor` is set,","otherwise defaults to *outliers*."].join(" ")}),jitter:i({},n.jitter,{description:["Sets the amount of jitter in the sample points drawn.","If *0*, the sample points align along the distribution axis.","If *1*, the sample points are drawn in a random jitter of width","equal to the width of the violins."].join(" ")}),pointpos:i({},n.pointpos,{description:["Sets the position of the sample points in relation to the violins.","If *0*, the sample points are places over the center of the violins.","Positive (negative) values correspond to positions to the","right (left) for vertical violins and above (below) for horizontal violins."].join(" ")}),width:i({},n.width,{description:["Sets the width of the violin in data coordinates.","If *0* (default value) the width is automatically selected based on the positions","of other violin traces in the same subplot."].join(" ")}),marker:n.marker,text:n.text,hovertext:n.hovertext,hovertemplate:n.hovertemplate,quartilemethod:n.quartilemethod,box:{visible:{valType:"boolean",dflt:!1,editType:"plot",description:["Determines if an miniature box plot is drawn inside the violins. "].join(" ")},width:{valType:"number",min:0,max:1,dflt:.25,editType:"plot",description:["Sets the width of the inner box plots relative to","the violins' width.","For example, with 1, the inner box plots are as wide as the violins."].join(" ")},fillcolor:{valType:"color",editType:"style",description:"Sets the inner box plot fill color."},line:{color:{valType:"color",editType:"style",description:"Sets the inner box plot bounding line color."},width:{valType:"number",min:0,editType:"style",description:"Sets the inner box plot bounding line width."},editType:"style"},editType:"plot"},meanline:{visible:{valType:"boolean",dflt:!1,editType:"plot",description:["Determines if a line corresponding to the sample's mean is shown","inside the violins.","If `box.visible` is turned on, the mean line is drawn inside the inner box.","Otherwise, the mean line is drawn from one side of the violin to other."].join(" ")},color:{valType:"color",editType:"style",description:"Sets the mean line color."},width:{valType:"number",min:0,editType:"style",description:"Sets the mean line width."},editType:"plot"},side:{valType:"enumerated",values:["both","positive","negative"],dflt:"both",editType:"calc",description:["Determines on which side of the position value the density function making up","one half of a violin is plotted.","Useful when comparing two violin traces under *overlay* mode, where one trace","has `side` set to *positive* and the other to *negative*."].join(" ")},offsetgroup:n.offsetgroup,alignmentgroup:n.alignmentgroup,selected:n.selected,unselected:n.unselected,hoveron:{valType:"flaglist",flags:["violins","points","kde"],dflt:"violins+points+kde",extras:["all"],editType:"style",description:["Do the hover effects highlight individual violins","or sample points or the kernel density estimate or any combination of them?"].join(" ")},zorder:n.zorder}},29952:(e,t,r)=>{"use strict";var n=r(84468),i=r(85729),o=r(66524),a=r(54632),s=r(65004).BADNUM;function l(e,t,r){var i=t.max-t.min;if(!i)return e.bandwidth?e.bandwidth:0;if(e.bandwidth)return Math.max(e.bandwidth,i/1e4);var o=r.length,a=n.stdev(r,o-1,t.mean);return Math.max(function(e,t,r){return 1.059*Math.min(t,r/1.349)*Math.pow(e,-.2)}(o,a,t.q3-t.q1),i/100)}function c(e,t,r,n){var o,a=e.spanmode,l=e.span||[],c=[t.min,t.max],u=[t.min-2*n,t.max+2*n];function d(n){var i=l[n],o="multicategory"===r.type?r.r2c(i):r.d2c(i,0,e[t.valLetter+"calendar"]);return o===s?u[n]:o}var h={type:"linear",range:o="soft"===a?u:"hard"===a?c:[d(0),d(1)]};return i.setConvert(h),h.cleanRange(),o}e.exports=function(e,t){var r=o(e,t);if(r[0].t.empty)return r;for(var s=e._fullLayout,u=i.getFromId(e,t["h"===t.orientation?"xaxis":"yaxis"]),d=1/0,h=-1/0,p=0,f=0,m=0;m{"use strict";var n=r(11927).setPositionOffset,i=["v","h"];e.exports=function(e,t){for(var r=e.calcdata,o=t.xaxis,a=t.yaxis,s=0;s{"use strict";var n=r(84468),i=r(7605),o=r(27563),a=r(69040);e.exports=function(e,t,r,s){function l(r,i){return n.coerce(e,t,a,r,i)}function c(r,i){return n.coerce2(e,t,a,r,i)}if(o.handleSampleDefaults(e,t,l,s),!1!==t.visible){l("bandwidth"),l("side"),l("width")||(l("scalegroup",t.name),l("scalemode"));var u,d=l("span");Array.isArray(d)&&(u="manual"),l("spanmode",u);var h=l("line.color",(e.marker||{}).color||r),p=l("line.width"),f=l("fillcolor",i.addOpacity(t.line.color,.5));o.handlePointsDefaults(e,t,l,{prefix:""});var m=c("box.width"),g=c("box.fillcolor",f),y=c("box.line.color",h),v=c("box.line.width",p);l("box.visible",Boolean(m||g||y||v))||(t.box={visible:!1});var x=c("meanline.color",h),b=c("meanline.width",p);l("meanline.visible",Boolean(x||b))||(t.meanline={visible:!1}),l("quartilemethod"),l("zorder")}}},54632:(e,t,r)=>{"use strict";var n=r(84468),i=function(e){return 1/Math.sqrt(2*Math.PI)*Math.exp(-.5*e*e)};t.makeKDE=function(e,t,r){var n=r.length,o=i,a=e.bandwidth,s=1/(n*a);return function(e){for(var t=0,i=0;i{"use strict";var n=r(7605),i=r(84468),o=r(85729),a=r(88203),s=r(54632);e.exports=function(e,t,r,l,c){c||(c={});var u,d,h=c.hoverLayer,p=e.cd,f=p[0].trace,m=f.hoveron,g=-1!==m.indexOf("violins"),y=-1!==m.indexOf("kde"),v=[];if(g||y){var x=a.hoverOnBoxes(e,t,r,l);if(y&&x.length>0){var b,_,w,k,S,A=e.xa,T=e.ya;"h"===f.orientation?(S=t,b="y",w=T,_="x",k=A):(S=r,b="x",w=A,_="y",k=T);var M=p[e.index];if(S>=M.span[0]&&S<=M.span[1]){var C=i.extendFlat({},e),E=k.c2p(S,!0),I=s.getKdeValue(M,f,S),P=s.getPositionOnKdePath(M,f,E),O=w._offset,R=w._length;C[b+"0"]=P[0],C[b+"1"]=P[1],C[_+"0"]=C[_+"1"]=E,C[_+"Label"]=_+": "+o.hoverLabelText(k,S,f[_+"hoverformat"])+", "+p[0].t.labels.kde+" "+I.toFixed(3);for(var L=0,D=0;D{"use strict";e.exports={attributes:r(69040),layoutAttributes:r(85211),supplyDefaults:r(93959),crossTraceDefaults:r(27563).crossTraceDefaults,supplyLayoutDefaults:r(13500),calc:r(29952),crossTraceCalc:r(53411),plot:r(25586),style:r(78064),styleOnSelect:r(47323).styleOnSelect,hoverPoints:r(62423),selectPoints:r(33341),moduleType:"trace",name:"violin",basePlotModule:r(9510),categories:["cartesian","svg","symbols","oriented","box-violin","showLegend","violinLayout","zoomScale"],meta:{description:["In vertical (horizontal) violin plots,","statistics are computed using `y` (`x`) values.","By supplying an `x` (`y`) array, one violin per distinct x (y) value","is drawn","If no `x` (`y`) {array} is provided, a single violin is drawn.","That violin position is then positioned with","with `name` or with `x0` (`y0`) if provided."].join(" ")}}},85211:(e,t,r)=>{"use strict";var n=r(23031),i=r(84468).extendFlat;e.exports={violinmode:i({},n.boxmode,{description:["Determines how violins at the same location coordinate","are displayed on the graph.","If *group*, the violins are plotted next to one another","centered around the shared location.","If *overlay*, the violins are plotted over one another,","you might need to set *opacity* to see them multiple violins.","Has no effect on traces that have *width* set."].join(" ")}),violingap:i({},n.boxgap,{description:["Sets the gap (in plot fraction) between violins of","adjacent location coordinates.","Has no effect on traces that have *width* set."].join(" ")}),violingroupgap:i({},n.boxgroupgap,{description:["Sets the gap (in plot fraction) between violins of","the same location coordinate.","Has no effect on traces that have *width* set."].join(" ")})}},13500:(e,t,r)=>{"use strict";var n=r(84468),i=r(85211),o=r(85296);e.exports=function(e,t,r){o._supply(e,t,r,(function(r,o){return n.coerce(e,t,i,r,o)}),"violin")}},25586:(e,t,r)=>{"use strict";var n=r(41871),i=r(84468),o=r(3172),a=r(60110),s=r(43446),l=r(54632);e.exports=function(e,t,r,c){var u=e._context.staticPlot,d=e._fullLayout,h=t.xaxis,p=t.yaxis;function f(e,t){var r=s(e,{xaxis:h,yaxis:p,trace:t,connectGaps:!0,baseTolerance:.75,shape:"spline",simplify:!0,linearized:!0});return o.smoothopen(r[0],1)}i.makeTraceGroups(c,r,"trace violins").each((function(e){var r=n.select(this),o=e[0],s=o.t,c=o.trace;if(!0!==c.visible||s.empty)r.remove();else{var m=s.bPos,g=s.bdPos,y=t[s.valLetter+"axis"],v=t[s.posLetter+"axis"],x="both"===c.side,b=x||"positive"===c.side,_=x||"negative"===c.side,w=r.selectAll("path.violin").data(i.identity);w.enter().append("path").style("vector-effect",u?"none":"non-scaling-stroke").attr("class","violin"),w.exit().remove(),w.each((function(e){var t,r,i,o,a,l,u,h,p=n.select(this),w=e.density,k=w.length,S=v.c2l(e.pos+m,!0),A=v.l2p(S);if(c.width)t=s.maxKDE/g;else{var T=d._violinScaleGroupStats[c.scalegroup];t="count"===c.scalemode?T.maxKDE/g*(T.maxCount/e.pts.length):T.maxKDE/g}if(b){for(u=new Array(k),a=0;a{"use strict";var n=r(41871),i=r(7605),o=r(47323).stylePoints;e.exports=function(e){var t=n.select(e).selectAll("g.trace.violins");t.style("opacity",(function(e){return e[0].trace.opacity})),t.each((function(t){var r=t[0].trace,a=n.select(this),s=r.box||{},l=s.line||{},c=r.meanline||{},u=c.width;a.selectAll("path.violin").style("stroke-width",r.line.width+"px").call(i.stroke,r.line.color).call(i.fill,r.fillcolor),a.selectAll("path.box").style("stroke-width",l.width+"px").call(i.stroke,l.color).call(i.fill,s.fillcolor);var d={"stroke-width":u+"px","stroke-dasharray":2*u+"px,"+u+"px"};a.selectAll("path.mean").style(d).call(i.stroke,c.color),a.selectAll("path.meanline").style(d).call(i.stroke,c.color),o(a,r,e)}))}},68821:(e,t,r)=>{"use strict";var n=r(6636),i=r(68583),o=r(41094),a=r(75622),s=r(64022).extendFlat,l=r(72587).overrideAll,c=e.exports=l(s({x:i.x,y:i.y,z:i.z,value:i.value,isomin:i.isomin,isomax:i.isomax,surface:i.surface,spaceframe:{show:{valType:"boolean",dflt:!1,description:["Displays/hides tetrahedron shapes between minimum and","maximum iso-values. Often useful when either caps or","surfaces are disabled or filled with values less than 1."].join(" ")},fill:{valType:"number",min:0,max:1,dflt:1,description:["Sets the fill ratio of the `spaceframe` elements. The default fill value","is 1 meaning that they are entirely shaded. Applying a `fill` ratio less","than one would allow the creation of openings parallel to the edges."].join(" ")}},slices:i.slices,caps:i.caps,text:i.text,hovertext:i.hovertext,xhoverformat:i.xhoverformat,yhoverformat:i.yhoverformat,zhoverformat:i.zhoverformat,valuehoverformat:i.valuehoverformat,hovertemplate:i.hovertemplate},n("",{colorAttr:"`value`",showScaleDflt:!0,editTypeOverride:"calc"}),{colorbar:i.colorbar,opacity:i.opacity,opacityscale:o.opacityscale,lightposition:i.lightposition,lighting:i.lighting,flatshading:i.flatshading,contour:i.contour,hoverinfo:s({},a.hoverinfo),showlegend:s({},a.showlegend,{dflt:!1})}),"calc","nested");c.x.editType=c.y.editType=c.z.editType=c.value.editType="calc+clearAxisTypes",c.transforms=void 0},44581:(e,t,r)=>{"use strict";var n=r(76107).gl_mesh3d,i=r(23207).parseColorScale,o=r(84468).isArrayOrTypedArray,a=r(79689),s=r(39265).extractOpts,l=r(11038),c=r(53043).findNearestOnAxis,u=r(53043).generateIsoMeshes;function d(e,t,r){this.scene=e,this.uid=r,this.mesh=t,this.name="",this.data=null,this.showContour=!1}var h=d.prototype;h.handlePick=function(e){if(e.object===this.mesh){var t=e.data.index,r=this.data._meshX[t],n=this.data._meshY[t],i=this.data._meshZ[t],a=this.data._Ys.length,s=this.data._Zs.length,l=c(r,this.data._Xs).id,u=c(n,this.data._Ys).id,d=c(i,this.data._Zs).id,h=e.index=d+s*u+s*a*l;e.traceCoordinate=[this.data._meshX[h],this.data._meshY[h],this.data._meshZ[h],this.data._value[h]];var p=this.data.hovertext||this.data.text;return o(p)&&void 0!==p[h]?e.textLabel=p[h]:p&&(e.textLabel=p),!0}},h.update=function(e){var t=this.scene,r=t.fullSceneLayout;function n(e,t,r,n){return t.map((function(t){return e.d2l(t,0,n)*r}))}this.data=u(e);var o={positions:l(n(r.xaxis,e._meshX,t.dataScale[0],e.xcalendar),n(r.yaxis,e._meshY,t.dataScale[1],e.ycalendar),n(r.zaxis,e._meshZ,t.dataScale[2],e.zcalendar)),cells:l(e._meshI,e._meshJ,e._meshK),lightPosition:[e.lightposition.x,e.lightposition.y,e.lightposition.z],ambient:e.lighting.ambient,diffuse:e.lighting.diffuse,specular:e.lighting.specular,roughness:e.lighting.roughness,fresnel:e.lighting.fresnel,vertexNormalsEpsilon:e.lighting.vertexnormalsepsilon,faceNormalsEpsilon:e.lighting.facenormalsepsilon,opacity:e.opacity,opacityscale:e.opacityscale,contourEnable:e.contour.show,contourColor:a(e.contour.color).slice(0,3),contourWidth:e.contour.width,useFacetNormals:e.flatshading},c=s(e);o.vertexIntensity=e._meshIntensity,o.vertexIntensityBounds=[c.min,c.max],o.colormap=i(e),this.mesh.update(o)},h.dispose=function(){this.scene.glplot.remove(this.mesh),this.mesh.dispose()},e.exports=function(e,t){var r=e.glplot.gl,i=n({gl:r}),o=new d(e,i,t.uid);return i._trace=o,o.update(t),e.glplot.add(i),o}},46402:(e,t,r)=>{"use strict";var n=r(84468),i=r(68821),o=r(8448).supplyIsoDefaults,a=r(25969).opacityscaleDefaults;e.exports=function(e,t,r,s){function l(r,o){return n.coerce(e,t,i,r,o)}o(e,t,r,s,l),a(e,t,s,l)}},34030:(e,t,r)=>{"use strict";e.exports={attributes:r(68821),supplyDefaults:r(46402),calc:r(84839),colorbar:{min:"cmin",max:"cmax"},plot:r(44581),moduleType:"trace",name:"volume",basePlotModule:r(48648),categories:["gl3d","showLegend"],meta:{description:["Draws volume trace between iso-min and iso-max values with coordinates given by","four 1-dimensional arrays containing the `value`, `x`, `y` and `z` of every vertex","of a uniform or non-uniform 3-D grid. Horizontal or vertical slices, caps as well as","spaceframe between iso-min and iso-max values could also be drawn using this trace."].join(" ")}}},76345:(e,t,r)=>{"use strict";var n=r(29744),i=r(22049).line,o=r(75622),a=r(39363).axisHoverFormat,s=r(84425).rb,l=r(84425).ay,c=r(81451),u=r(64022).extendFlat,d=r(7605);function h(e){return{marker:{color:u({},n.marker.color,{arrayOk:!1,editType:"style",description:"Sets the marker color of all "+e+" values."}),line:{color:u({},n.marker.line.color,{arrayOk:!1,editType:"style",description:"Sets the line color of all "+e+" values."}),width:u({},n.marker.line.width,{arrayOk:!1,editType:"style",description:"Sets the line width of all "+e+" values."}),editType:"style"},editType:"style"},editType:"style"}}e.exports={measure:{valType:"data_array",dflt:[],editType:"calc",description:["An array containing types of values.","By default the values are considered as 'relative'.","However; it is possible to use 'total' to compute the sums.","Also 'absolute' could be applied to reset the computed total","or to declare an initial value where needed."].join(" ")},base:{valType:"number",dflt:null,arrayOk:!1,editType:"calc",description:["Sets where the bar base is drawn (in position axis units)."].join(" ")},x:n.x,x0:n.x0,dx:n.dx,y:n.y,y0:n.y0,dy:n.dy,xperiod:n.xperiod,yperiod:n.yperiod,xperiod0:n.xperiod0,yperiod0:n.yperiod0,xperiodalignment:n.xperiodalignment,yperiodalignment:n.yperiodalignment,xhoverformat:a("x"),yhoverformat:a("y"),hovertext:n.hovertext,hovertemplate:s({},{keys:c.eventDataKeys}),hoverinfo:u({},o.hoverinfo,{flags:["name","x","y","text","initial","delta","final"]}),textinfo:{valType:"flaglist",flags:["label","text","initial","delta","final"],extras:["none"],editType:"plot",arrayOk:!1,description:["Determines which trace information appear on the graph.","In the case of having multiple waterfalls, totals","are computed separately (per trace)."].join(" ")},texttemplate:l({editType:"plot"},{keys:c.eventDataKeys.concat(["label"])}),text:n.text,textposition:n.textposition,insidetextanchor:n.insidetextanchor,textangle:n.textangle,textfont:n.textfont,insidetextfont:n.insidetextfont,outsidetextfont:n.outsidetextfont,constraintext:n.constraintext,cliponaxis:n.cliponaxis,orientation:n.orientation,offset:n.offset,width:n.width,increasing:h("increasing"),decreasing:h("decreasing"),totals:h("intermediate sums and total"),connector:{line:{color:u({},i.color,{dflt:d.defaultLine}),width:u({},i.width,{editType:"plot"}),dash:i.dash,editType:"plot"},mode:{valType:"enumerated",values:["spanning","between"],dflt:"between",editType:"plot",description:["Sets the shape of connector lines."].join(" ")},visible:{valType:"boolean",dflt:!0,editType:"plot",description:["Determines if connector lines are drawn. "].join(" ")},editType:"plot"},offsetgroup:n.offsetgroup,alignmentgroup:n.alignmentgroup,zorder:n.zorder}},63165:(e,t,r)=>{"use strict";var n=r(85729),i=r(35087),o=r(84468).mergeArray,a=r(40304),s=r(65004).BADNUM;function l(e){return"a"===e||"absolute"===e}function c(e){return"t"===e||"total"===e}e.exports=function(e,t){var r,u,d,h,p,f,m=n.getFromId(e,t.xaxis||"x"),g=n.getFromId(e,t.yaxis||"y");"h"===t.orientation?(r=m.makeCalcdata(t,"x"),d=g.makeCalcdata(t,"y"),h=i(t,g,"y",d),p=!!t.yperiodalignment,f="y"):(r=g.makeCalcdata(t,"y"),d=m.makeCalcdata(t,"x"),h=i(t,m,"x",d),p=!!t.xperiodalignment,f="x"),u=h.vals;for(var y,v=Math.min(u.length,r.length),x=new Array(v),b=0,_=!1,w=0;w{"use strict";e.exports={eventDataKeys:["initial","delta","final"]}},13662:(e,t,r)=>{"use strict";var n=r(51203).setGroupPositions;e.exports=function(e,t){var r,i,o=e._fullLayout,a=e._fullData,s=e.calcdata,l=t.xaxis,c=t.yaxis,u=[],d=[],h=[];for(i=0;i{"use strict";var n=r(84468),i=r(53558),o=r(81543).handleText,a=r(53124),s=r(26386),l=r(76345),c=r(7605),u=r(22876),d=u.INCREASING.COLOR,h=u.DECREASING.COLOR;function p(e,t,r){e(t+".marker.color",r),e(t+".marker.line.color",c.defaultLine),e(t+".marker.line.width")}e.exports={supplyDefaults:function(e,t,r,i){function c(r,i){return n.coerce(e,t,l,r,i)}if(a(e,t,i,c)){s(e,t,i,c),c("xhoverformat"),c("yhoverformat"),c("measure"),c("orientation",t.x&&!t.y?"h":"v"),c("base"),c("offset"),c("width"),c("text"),c("hovertext"),c("hovertemplate");var u=c("textposition");if(o(e,t,i,c,u,{moduleHasSelected:!1,moduleHasUnselected:!1,moduleHasConstrain:!0,moduleHasCliponaxis:!0,moduleHasTextangle:!0,moduleHasInsideanchor:!0}),"none"!==t.textposition&&(c("texttemplate"),t.texttemplate||c("textinfo")),p(c,"increasing",d),p(c,"decreasing",h),p(c,"totals","#4499FF"),c("connector.visible"))c("connector.mode"),c("connector.line.width")&&(c("connector.line.color"),c("connector.line.dash"));c("zorder")}else t.visible=!1},crossTraceDefaults:function(e,t){var r,o;function a(e){return n.coerce(o._input,o,l,e)}if("group"===t.waterfallmode)for(var s=0;s{"use strict";e.exports=function(e,t){return e.x="xVal"in t?t.xVal:t.x,e.y="yVal"in t?t.yVal:t.y,"initial"in t&&(e.initial=t.initial),"delta"in t&&(e.delta=t.delta),"final"in t&&(e.final=t.final),t.xa&&(e.xaxis=t.xa),t.ya&&(e.yaxis=t.ya),e}},43648:(e,t,r)=>{"use strict";var n=r(85729).hoverLabelText,i=r(7605).opacity,o=r(3332).hoverOnBars,a=r(22876),s=a.INCREASING.SYMBOL,l=a.DECREASING.SYMBOL;e.exports=function(e,t,r,a,c){var u=o(e,t,r,a,c);if(u){var d=u.cd,h=d[0].trace,p="h"===h.orientation,f=p?"x":"y",m=p?e.xa:e.ya,g=d[u.index],y=g.isSum?g.b+g.s:g.rawS;u.initial=g.b+g.s-y,u.delta=y,u.final=u.initial+u.delta;var v=S(Math.abs(u.delta));u.deltaLabel=y<0?"("+v+")":v,u.finalLabel=S(u.final),u.initialLabel=S(u.initial);var x=g.hi||h.hoverinfo,b=[];if(x&&"none"!==x&&"skip"!==x){var _="all"===x,w=x.split("+"),k=function(e){return _||-1!==w.indexOf(e)};g.isSum||(!k("final")||k(p?"x":"y")||b.push(u.finalLabel),k("delta")&&(y<0?b.push(u.deltaLabel+" "+l):b.push(u.deltaLabel+" "+s)),k("initial")&&b.push("Initial: "+u.initialLabel))}return b.length&&(u.extraText=b.join("
")),u.color=function(e,t){var r=e[t.dir].marker,n=r.color,o=r.line.color,a=r.line.width;if(i(n))return n;if(i(o)&&a)return o}(h,g),[u]}function S(e){return n(m,e,h[f+"hoverformat"])}}},16954:(e,t,r)=>{"use strict";e.exports={attributes:r(76345),layoutAttributes:r(88404),supplyDefaults:r(88894).supplyDefaults,crossTraceDefaults:r(88894).crossTraceDefaults,supplyLayoutDefaults:r(259),calc:r(63165),crossTraceCalc:r(13662),plot:r(46739),style:r(979).style,hoverPoints:r(43648),eventData:r(43237),selectPoints:r(12969),moduleType:"trace",name:"waterfall",basePlotModule:r(9510),categories:["bar-like","cartesian","svg","oriented","showLegend","zoomScale"],meta:{description:["Draws waterfall trace which is useful graph to displays the","contribution of various elements (either positive or negative)","in a bar chart. The data visualized by the span of the bars is","set in `y` if `orientation` is set to *v* (the default) and the","labels are set in `x`.","By setting `orientation` to *h*, the roles are interchanged."].join(" ")}}},88404:e=>{"use strict";e.exports={waterfallmode:{valType:"enumerated",values:["group","overlay"],dflt:"group",editType:"calc",description:["Determines how bars at the same location coordinate","are displayed on the graph.","With *group*, the bars are plotted next to one another","centered around the shared location.","With *overlay*, the bars are plotted over one another,","you might need to reduce *opacity* to see multiple bars."].join(" ")},waterfallgap:{valType:"number",min:0,max:1,editType:"calc",description:["Sets the gap (in plot fraction) between bars of","adjacent location coordinates."].join(" ")},waterfallgroupgap:{valType:"number",min:0,max:1,dflt:0,editType:"calc",description:["Sets the gap (in plot fraction) between bars of","the same location coordinate."].join(" ")}}},259:(e,t,r)=>{"use strict";var n=r(84468),i=r(88404);e.exports=function(e,t,r){var o=!1;function a(r,o){return n.coerce(e,t,i,r,o)}for(var s=0;s{"use strict";var n=r(41871),i=r(84468),o=r(3172),a=r(65004).BADNUM,s=r(32018),l=r(35655).clearMinTextSize;e.exports=function(e,t,r,c){var u=e._fullLayout;l("waterfall",u),s.plot(e,t,r,c,{mode:u.waterfallmode,norm:u.waterfallmode,gap:u.waterfallgap,groupgap:u.waterfallgroupgap}),function(e,t,r,s){var l=t.xaxis,c=t.yaxis;i.makeTraceGroups(s,r,"trace bars").each((function(r){var s=n.select(this),u=r[0].trace,d=i.ensureSingle(s,"g","lines");if(u.connector&&u.connector.visible){var h="h"===u.orientation,p=u.connector.mode,f=d.selectAll("g.line").data(i.identity);f.enter().append("g").classed("line",!0),f.exit().remove();var m=f.size();f.each((function(r,s){if(s===m-1||r.cNext){var u=function(e,t,r,n){var i=[],o=[],a=n?t:r,s=n?r:t;return i[0]=a.c2p(e.s0,!0),o[0]=s.c2p(e.p0,!0),i[1]=a.c2p(e.s1,!0),o[1]=s.c2p(e.p1,!0),i[2]=a.c2p(e.nextS0,!0),o[2]=s.c2p(e.nextP0,!0),n?[i,o]:[o,i]}(r,l,c,h),d=u[0],f=u[1],g="";d[0]!==a&&f[0]!==a&&d[1]!==a&&f[1]!==a&&("spanning"===p&&!r.isSum&&s>0&&(g+=h?"M"+d[0]+","+f[1]+"V"+f[0]:"M"+d[1]+","+f[0]+"H"+d[0]),"between"!==p&&(r.isSum||s{"use strict";var n=r(41871),i=r(3172),o=r(7605),a=r(64253).DESELECTDIM,s=r(52464),l=r(35655).resizeText,c=s.styleTextPoints;e.exports={style:function(e,t,r){var s=r||n.select(e).selectAll('g[class^="waterfalllayer"]').selectAll("g.trace");l(e,s,"waterfall"),s.style("opacity",(function(e){return e[0].trace.opacity})),s.each((function(t){var r=n.select(this),s=t[0].trace;r.selectAll(".point > path").each((function(e){if(!e.isBlank){var t=s[e.dir].marker;n.select(this).call(o.fill,t.color).call(o.stroke,t.line.color).call(i.dashLine,t.line.dash,t.line.width).style("opacity",s.selectedpoints&&!e.selected?a:1)}})),c(r,s,e),r.selectAll(".lines").each((function(){var e=s.connector.line;i.lineGroupStyle(n.select(this).selectAll("path"),e.width,e.color,e.dash)}))}))}}},2479:(e,t,r)=>{"use strict";var n=r(85729),i=r(84468),o=r(30166),a=r(32813).z,s=r(65004).BADNUM;t.moduleType="transform",t.name="aggregate";var l=t.attributes={enabled:{valType:"boolean",dflt:!0,editType:"calc",description:["Determines whether this aggregate transform is enabled or disabled."].join(" ")},groups:{valType:"string",strict:!0,noBlank:!0,arrayOk:!0,dflt:"x",editType:"calc",description:["Sets the grouping target to which the aggregation is applied.","Data points with matching group values will be coalesced into","one point, using the supplied aggregation functions to reduce data","in other data arrays.","If a string, `groups` is assumed to be a reference to a data array","in the parent trace object.","To aggregate by nested variables, use *.* to access them.","For example, set `groups` to *marker.color* to aggregate","about the marker color array.","If an array, `groups` is itself the data array by which we aggregate."].join(" ")},aggregations:{_isLinkedToArray:"aggregation",target:{valType:"string",editType:"calc",description:["A reference to the data array in the parent trace to aggregate.","To aggregate by nested variables, use *.* to access them.","For example, set `groups` to *marker.color* to aggregate","over the marker color array.","The referenced array must already exist, unless `func` is *count*,","and each array may only be referenced once."].join(" ")},func:{valType:"enumerated",values:["count","sum","avg","median","mode","rms","stddev","min","max","first","last","change","range"],dflt:"first",editType:"calc",description:["Sets the aggregation function.","All values from the linked `target`, corresponding to the same value","in the `groups` array, are collected and reduced by this function.","*count* is simply the number of values in the `groups` array, so does","not even require the linked array to exist. *first* (*last*) is just","the first (last) linked value.","Invalid values are ignored, so for example in *avg* they do not","contribute to either the numerator or the denominator.","Any data type (numeric, date, category) may be aggregated with any","function, even though in certain cases it is unlikely to make sense,","for example a sum of dates or average of categories.","*median* will return the average of the two central values if there is","an even count. *mode* will return the first value to reach the maximum","count, in case of a tie.","*change* will return the difference between the first and last linked values.","*range* will return the difference between the min and max linked values."].join(" ")},funcmode:{valType:"enumerated",values:["sample","population"],dflt:"sample",editType:"calc",description:["*stddev* supports two formula variants: *sample* (normalize by N-1)","and *population* (normalize by N)."].join(" ")},enabled:{valType:"boolean",dflt:!0,editType:"calc",description:["Determines whether this aggregation function is enabled or disabled."].join(" ")},editType:"calc"},editType:"calc"},c=l.aggregations;function u(e,t,r,o){if(o.enabled){for(var a=o.target,l=i.nestedProperty(t,a),c=l.get(),u=function(e,t){var r=e.func,n=t.d2c,o=t.c2d;switch(r){case"count":return d;case"first":return h;case"last":return p;case"sum":return function(e,t){for(var r=0,i=0;ii&&(i=u,a=c)}}return i?o(a):s};case"rms":return function(e,t){for(var r=0,i=0,a=0;a{"use strict";var n=r(84468),i=r(38361),o=r(85729),a=r(32813).z,s=r(23605),l=s.COMPARISON_OPS,c=s.INTERVAL_OPS,u=s.SET_OPS;t.moduleType="transform",t.name="filter",t.attributes={enabled:{valType:"boolean",dflt:!0,editType:"calc",description:["Determines whether this filter transform is enabled or disabled."].join(" ")},target:{valType:"string",strict:!0,noBlank:!0,arrayOk:!0,dflt:"x",editType:"calc",description:["Sets the filter target by which the filter is applied.","If a string, `target` is assumed to be a reference to a data array","in the parent trace object.","To filter about nested variables, use *.* to access them.","For example, set `target` to *marker.color* to filter","about the marker color array.","If an array, `target` is then the data array by which the filter is applied."].join(" ")},operation:{valType:"enumerated",values:[].concat(l).concat(c).concat(u),dflt:"=",editType:"calc",description:["Sets the filter operation.","*=* keeps items equal to `value`","*!=* keeps items not equal to `value`","*<* keeps items less than `value`","*<=* keeps items less than or equal to `value`","*>* keeps items greater than `value`","*>=* keeps items greater than or equal to `value`","*[]* keeps items inside `value[0]` to `value[1]` including both bounds","*()* keeps items inside `value[0]` to `value[1]` excluding both bounds","*[)* keeps items inside `value[0]` to `value[1]` including `value[0]` but excluding `value[1]","*(]* keeps items inside `value[0]` to `value[1]` excluding `value[0]` but including `value[1]","*][* keeps items outside `value[0]` to `value[1]` and equal to both bounds","*)(* keeps items outside `value[0]` to `value[1]`","*](* keeps items outside `value[0]` to `value[1]` and equal to `value[0]`","*)[* keeps items outside `value[0]` to `value[1]` and equal to `value[1]`","*{}* keeps items present in a set of values","*}{* keeps items not present in a set of values"].join(" ")},value:{valType:"any",dflt:0,editType:"calc",description:["Sets the value or values by which to filter.","Values are expected to be in the same type as the data linked","to `target`.","When `operation` is set to one of","the comparison values ("+l+")","`value` is expected to be a number or a string.","When `operation` is set to one of the interval values","("+c+")","`value` is expected to be 2-item array where the first item","is the lower bound and the second item is the upper bound.","When `operation`, is set to one of the set values","("+u+")","`value` is expected to be an array with as many items as","the desired set elements."].join(" ")},preservegaps:{valType:"boolean",dflt:!1,editType:"calc",description:["Determines whether or not gaps in data arrays produced by the filter operation","are preserved.","Setting this to *true* might be useful when plotting a line chart","with `connectgaps` set to *false*."].join(" ")},editType:"calc"},t.supplyDefaults=function(e){var r={};function o(i,o){return n.coerce(e,r,t.attributes,i,o)}if(o("enabled")){var a=o("target");if(n.isArrayOrTypedArray(a)&&0===a.length)return r.enabled=!1,r;o("preservegaps"),o("operation"),o("value");var s=i.getComponentMethod("calendars","handleDefaults");s(e,r,"valuecalendar",null),s(e,r,"targetcalendar",null)}return r},t.calcTransform=function(e,t,r){if(r.enabled){var i=n.getTargetArray(t,r);if(i){var s=r.target,d=i.length;t._length&&(d=Math.min(d,t._length));var h=r.targetcalendar,p=t._arrayAttrs,f=r.preservegaps;if("string"===typeof s){var m=n.nestedProperty(t,s+"calendar").get();m&&(h=m)}var g,y,v=function(e,t,r){var i=e.operation,o=e.value,a=n.isArrayOrTypedArray(o);function s(e){return-1!==e.indexOf(i)}var d,h=function(r){return t(r,0,e.valuecalendar)},p=function(e){return t(e,0,r)};s(l)?d=h(a?o[0]:o):s(c)?d=a?[h(o[0]),h(o[1])]:[h(o),h(o)]:s(u)&&(d=a?o.map(h):[h(o)]);switch(i){case"=":return function(e){return p(e)===d};case"!=":return function(e){return p(e)!==d};case"<":return function(e){return p(e)":return function(e){return p(e)>d};case">=":return function(e){return p(e)>=d};case"[]":return function(e){var t=p(e);return t>=d[0]&&t<=d[1]};case"()":return function(e){var t=p(e);return t>d[0]&&t=d[0]&&td[0]&&t<=d[1]};case"][":return function(e){var t=p(e);return t<=d[0]||t>=d[1]};case")(":return function(e){var t=p(e);return td[1]};case"](":return function(e){var t=p(e);return t<=d[0]||t>d[1]};case")[":return function(e){var t=p(e);return t=d[1]};case"{}":return function(e){return-1!==d.indexOf(p(e))};case"}{":return function(e){return-1===d.indexOf(p(e))}}}(r,o.getDataToCoordFunc(e,t,s,i),h),x={},b={},_=0;f?(g=function(e){x[e.astr]=n.extendDeep([],e.get()),e.set(new Array(d))},y=function(e,t){var r=x[e.astr][t];e.get()[t]=r}):(g=function(e){x[e.astr]=n.extendDeep([],e.get()),e.set([])},y=function(e,t){var r=x[e.astr][t];e.get().push(r)}),S(g);for(var w=a(t.transforms,r),k=0;k{"use strict";var n=r(84468),i=r(30166),o=r(68543),a=r(32813).z;function s(e,t){var r,s,l,c,u,d,h,p,f,m,g=t.transform,y=t.transformIndex,v=e.transforms[y].groups,x=a(e.transforms,g);if(!n.isArrayOrTypedArray(v)||0===v.length)return[e];var b=n.filterUnique(v),_=new Array(b.length),w=v.length,k=i.findArrayAttributes(e),S=g.styles||[],A={};for(r=0;r1?"%{group} (%{trace})":"%{group}");var l=e.styles,c=a.styles=[];if(l)for(o=0;o{"use strict";t.z=function(e,t){for(var r,n,i=0;i{"use strict";var n=r(84468),i=r(85729),o=r(32813).z,a=r(65004).BADNUM;t.moduleType="transform",t.name="sort",t.attributes={enabled:{valType:"boolean",dflt:!0,editType:"calc",description:["Determines whether this sort transform is enabled or disabled."].join(" ")},target:{valType:"string",strict:!0,noBlank:!0,arrayOk:!0,dflt:"x",editType:"calc",description:["Sets the target by which the sort transform is applied.","If a string, *target* is assumed to be a reference to a data array","in the parent trace object.","To sort about nested variables, use *.* to access them.","For example, set `target` to *marker.size* to sort","about the marker size array.","If an array, *target* is then the data array by which","the sort transform is applied."].join(" ")},order:{valType:"enumerated",values:["ascending","descending"],dflt:"ascending",editType:"calc",description:["Sets the sort transform order."].join(" ")},editType:"calc"},t.supplyDefaults=function(e){var r={};function i(i,o){return n.coerce(e,r,t.attributes,i,o)}return i("enabled")&&(i("target"),i("order")),r},t.calcTransform=function(e,t,r){if(r.enabled){var s=n.getTargetArray(t,r);if(s){var l=r.target,c=s.length;t._length&&(c=Math.min(c,t._length));var u,d,h=t._arrayAttrs,p=function(e,t,r,n){var i,o=new Array(n),s=new Array(n);for(i=0;i{"use strict";t.version="2.35.2"},76107:e=>{!function(){var t={1964:function(e,t,r){e.exports={alpha_shape:r(3502),convex_hull:r(7352),delaunay_triangulate:r(7642),gl_cone3d:r(6405),gl_error3d:r(9165),gl_heatmap2d:r(2510),gl_line3d:r(5714),gl_mesh3d:r(7201),gl_plot2d:r(1850),gl_plot3d:r(4100),gl_pointcloud2d:r(4696),gl_scatter3d:r(8418),gl_select_box:r(3161),gl_spikes2d:r(4098),gl_streamtube3d:r(7815),gl_surface3d:r(9499),ndarray:r(9618),ndarray_linear_interpolate:r(4317)}},4793:function(e,t,r){"use strict";function n(e,t){for(var r=0;rp)throw new RangeError('The value "'+e+'" is invalid for option "size"');var t=new Uint8Array(e);return Object.setPrototypeOf(t,m.prototype),t}function m(e,t,r){if("number"===typeof e){if("string"===typeof t)throw new TypeError('The "string" argument must be of type string. Received type number');return v(e)}return g(e,t,r)}function g(e,t,r){if("string"===typeof e)return function(e,t){"string"===typeof t&&""!==t||(t="utf8");if(!m.isEncoding(t))throw new TypeError("Unknown encoding: "+t);var r=0|w(e,t),n=f(r),i=n.write(e,t);i!==r&&(n=n.slice(0,i));return n}(e,t);if(ArrayBuffer.isView(e))return function(e){if(re(e,Uint8Array)){var t=new Uint8Array(e);return b(t.buffer,t.byteOffset,t.byteLength)}return x(e)}(e);if(null==e)throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+c(e));if(re(e,ArrayBuffer)||e&&re(e.buffer,ArrayBuffer))return b(e,t,r);if("undefined"!==typeof SharedArrayBuffer&&(re(e,SharedArrayBuffer)||e&&re(e.buffer,SharedArrayBuffer)))return b(e,t,r);if("number"===typeof e)throw new TypeError('The "value" argument must not be of type number. Received type number');var n=e.valueOf&&e.valueOf();if(null!=n&&n!==e)return m.from(n,t,r);var i=function(e){if(m.isBuffer(e)){var t=0|_(e.length),r=f(t);return 0===r.length||e.copy(r,0,0,t),r}if(void 0!==e.length)return"number"!==typeof e.length||ne(e.length)?f(0):x(e);if("Buffer"===e.type&&Array.isArray(e.data))return x(e.data)}(e);if(i)return i;if("undefined"!==typeof Symbol&&null!=Symbol.toPrimitive&&"function"===typeof e[Symbol.toPrimitive])return m.from(e[Symbol.toPrimitive]("string"),t,r);throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+c(e))}function y(e){if("number"!==typeof e)throw new TypeError('"size" argument must be of type number');if(e<0)throw new RangeError('The value "'+e+'" is invalid for option "size"')}function v(e){return y(e),f(e<0?0:0|_(e))}function x(e){for(var t=e.length<0?0:0|_(e.length),r=f(t),n=0;n=p)throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x"+p.toString(16)+" bytes");return 0|e}function w(e,t){if(m.isBuffer(e))return e.length;if(ArrayBuffer.isView(e)||re(e,ArrayBuffer))return e.byteLength;if("string"!==typeof e)throw new TypeError('The "string" argument must be one of type string, Buffer, or ArrayBuffer. Received type '+c(e));var r=e.length,n=arguments.length>2&&!0===arguments[2];if(!n&&0===r)return 0;for(var i=!1;;)switch(t){case"ascii":case"latin1":case"binary":return r;case"utf8":case"utf-8":return Q(e).length;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return 2*r;case"hex":return r>>>1;case"base64":return ee(e).length;default:if(i)return n?-1:Q(e).length;t=(""+t).toLowerCase(),i=!0}}function k(e,t,r){var n=!1;if((void 0===t||t<0)&&(t=0),t>this.length)return"";if((void 0===r||r>this.length)&&(r=this.length),r<=0)return"";if((r>>>=0)<=(t>>>=0))return"";for(e||(e="utf8");;)switch(e){case"hex":return j(this,t,r);case"utf8":case"utf-8":return R(this,t,r);case"ascii":return D(this,t,r);case"latin1":case"binary":return z(this,t,r);case"base64":return O(this,t,r);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return F(this,t,r);default:if(n)throw new TypeError("Unknown encoding: "+e);e=(e+"").toLowerCase(),n=!0}}function S(e,t,r){var n=e[t];e[t]=e[r],e[r]=n}function A(e,t,r,n,i){if(0===e.length)return-1;if("string"===typeof r?(n=r,r=0):r>2147483647?r=2147483647:r<-2147483648&&(r=-2147483648),ne(r=+r)&&(r=i?0:e.length-1),r<0&&(r=e.length+r),r>=e.length){if(i)return-1;r=e.length-1}else if(r<0){if(!i)return-1;r=0}if("string"===typeof t&&(t=m.from(t,n)),m.isBuffer(t))return 0===t.length?-1:T(e,t,r,n,i);if("number"===typeof t)return t&=255,"function"===typeof Uint8Array.prototype.indexOf?i?Uint8Array.prototype.indexOf.call(e,t,r):Uint8Array.prototype.lastIndexOf.call(e,t,r):T(e,[t],r,n,i);throw new TypeError("val must be string, number or Buffer")}function T(e,t,r,n,i){var o,a=1,s=e.length,l=t.length;if(void 0!==n&&("ucs2"===(n=String(n).toLowerCase())||"ucs-2"===n||"utf16le"===n||"utf-16le"===n)){if(e.length<2||t.length<2)return-1;a=2,s/=2,l/=2,r/=2}function c(e,t){return 1===a?e[t]:e.readUInt16BE(t*a)}if(i){var u=-1;for(o=r;os&&(r=s-l),o=r;o>=0;o--){for(var d=!0,h=0;hi&&(n=i):n=i;var o,a=t.length;for(n>a/2&&(n=a/2),o=0;o>8,i=r%256,o.push(i),o.push(n);return o}(t,e.length-r),e,r,n)}function O(e,t,r){return 0===t&&r===e.length?u.fromByteArray(e):u.fromByteArray(e.slice(t,r))}function R(e,t,r){r=Math.min(e.length,r);for(var n=[],i=t;i239?4:o>223?3:o>191?2:1;if(i+s<=r){var l=void 0,c=void 0,u=void 0,d=void 0;switch(s){case 1:o<128&&(a=o);break;case 2:128===(192&(l=e[i+1]))&&(d=(31&o)<<6|63&l)>127&&(a=d);break;case 3:l=e[i+1],c=e[i+2],128===(192&l)&&128===(192&c)&&(d=(15&o)<<12|(63&l)<<6|63&c)>2047&&(d<55296||d>57343)&&(a=d);break;case 4:l=e[i+1],c=e[i+2],u=e[i+3],128===(192&l)&&128===(192&c)&&128===(192&u)&&(d=(15&o)<<18|(63&l)<<12|(63&c)<<6|63&u)>65535&&d<1114112&&(a=d)}}null===a?(a=65533,s=1):a>65535&&(a-=65536,n.push(a>>>10&1023|55296),a=56320|1023&a),n.push(a),i+=s}return function(e){var t=e.length;if(t<=L)return String.fromCharCode.apply(String,e);var r="",n=0;for(;nn.length?(m.isBuffer(o)||(o=m.from(o)),o.copy(n,i)):Uint8Array.prototype.set.call(n,o,i);else{if(!m.isBuffer(o))throw new TypeError('"list" argument must be an Array of Buffers');o.copy(n,i)}i+=o.length}return n},m.byteLength=w,m.prototype._isBuffer=!0,m.prototype.swap16=function(){var e=this.length;if(e%2!==0)throw new RangeError("Buffer size must be a multiple of 16-bits");for(var t=0;tr&&(e+=" ... "),""},h&&(m.prototype[h]=m.prototype.inspect),m.prototype.compare=function(e,t,r,n,i){if(re(e,Uint8Array)&&(e=m.from(e,e.offset,e.byteLength)),!m.isBuffer(e))throw new TypeError('The "target" argument must be one of type Buffer or Uint8Array. Received type '+c(e));if(void 0===t&&(t=0),void 0===r&&(r=e?e.length:0),void 0===n&&(n=0),void 0===i&&(i=this.length),t<0||r>e.length||n<0||i>this.length)throw new RangeError("out of range index");if(n>=i&&t>=r)return 0;if(n>=i)return-1;if(t>=r)return 1;if(this===e)return 0;for(var o=(i>>>=0)-(n>>>=0),a=(r>>>=0)-(t>>>=0),s=Math.min(o,a),l=this.slice(n,i),u=e.slice(t,r),d=0;d>>=0,isFinite(r)?(r>>>=0,void 0===n&&(n="utf8")):(n=r,r=void 0)}var i=this.length-t;if((void 0===r||r>i)&&(r=i),e.length>0&&(r<0||t<0)||t>this.length)throw new RangeError("Attempt to write outside buffer bounds");n||(n="utf8");for(var o=!1;;)switch(n){case"hex":return M(this,e,t,r);case"utf8":case"utf-8":return C(this,e,t,r);case"ascii":case"latin1":case"binary":return E(this,e,t,r);case"base64":return I(this,e,t,r);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return P(this,e,t,r);default:if(o)throw new TypeError("Unknown encoding: "+n);n=(""+n).toLowerCase(),o=!0}},m.prototype.toJSON=function(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};var L=4096;function D(e,t,r){var n="";r=Math.min(e.length,r);for(var i=t;in)&&(r=n);for(var i="",o=t;or)throw new RangeError("Trying to access beyond buffer length")}function B(e,t,r,n,i,o){if(!m.isBuffer(e))throw new TypeError('"buffer" argument must be a Buffer instance');if(t>i||te.length)throw new RangeError("Index out of range")}function V(e,t,r,n,i){X(t,n,i,e,r,7);var o=Number(t&BigInt(4294967295));e[r++]=o,o>>=8,e[r++]=o,o>>=8,e[r++]=o,o>>=8,e[r++]=o;var a=Number(t>>BigInt(32)&BigInt(4294967295));return e[r++]=a,a>>=8,e[r++]=a,a>>=8,e[r++]=a,a>>=8,e[r++]=a,r}function U(e,t,r,n,i){X(t,n,i,e,r,7);var o=Number(t&BigInt(4294967295));e[r+7]=o,o>>=8,e[r+6]=o,o>>=8,e[r+5]=o,o>>=8,e[r+4]=o;var a=Number(t>>BigInt(32)&BigInt(4294967295));return e[r+3]=a,a>>=8,e[r+2]=a,a>>=8,e[r+1]=a,a>>=8,e[r]=a,r+8}function H(e,t,r,n,i,o){if(r+n>e.length)throw new RangeError("Index out of range");if(r<0)throw new RangeError("Index out of range")}function $(e,t,r,n,i){return t=+t,r>>>=0,i||H(e,0,r,4),d.write(e,t,r,n,23,4),r+4}function W(e,t,r,n,i){return t=+t,r>>>=0,i||H(e,0,r,8),d.write(e,t,r,n,52,8),r+8}m.prototype.slice=function(e,t){var r=this.length;(e=~~e)<0?(e+=r)<0&&(e=0):e>r&&(e=r),(t=void 0===t?r:~~t)<0?(t+=r)<0&&(t=0):t>r&&(t=r),t>>=0,t>>>=0,r||N(e,t,this.length);for(var n=this[e],i=1,o=0;++o>>=0,t>>>=0,r||N(e,t,this.length);for(var n=this[e+--t],i=1;t>0&&(i*=256);)n+=this[e+--t]*i;return n},m.prototype.readUint8=m.prototype.readUInt8=function(e,t){return e>>>=0,t||N(e,1,this.length),this[e]},m.prototype.readUint16LE=m.prototype.readUInt16LE=function(e,t){return e>>>=0,t||N(e,2,this.length),this[e]|this[e+1]<<8},m.prototype.readUint16BE=m.prototype.readUInt16BE=function(e,t){return e>>>=0,t||N(e,2,this.length),this[e]<<8|this[e+1]},m.prototype.readUint32LE=m.prototype.readUInt32LE=function(e,t){return e>>>=0,t||N(e,4,this.length),(this[e]|this[e+1]<<8|this[e+2]<<16)+16777216*this[e+3]},m.prototype.readUint32BE=m.prototype.readUInt32BE=function(e,t){return e>>>=0,t||N(e,4,this.length),16777216*this[e]+(this[e+1]<<16|this[e+2]<<8|this[e+3])},m.prototype.readBigUInt64LE=oe((function(e){Z(e>>>=0,"offset");var t=this[e],r=this[e+7];void 0!==t&&void 0!==r||K(e,this.length-8);var n=t+this[++e]*Math.pow(2,8)+this[++e]*Math.pow(2,16)+this[++e]*Math.pow(2,24),i=this[++e]+this[++e]*Math.pow(2,8)+this[++e]*Math.pow(2,16)+r*Math.pow(2,24);return BigInt(n)+(BigInt(i)<>>=0,"offset");var t=this[e],r=this[e+7];void 0!==t&&void 0!==r||K(e,this.length-8);var n=t*Math.pow(2,24)+this[++e]*Math.pow(2,16)+this[++e]*Math.pow(2,8)+this[++e],i=this[++e]*Math.pow(2,24)+this[++e]*Math.pow(2,16)+this[++e]*Math.pow(2,8)+r;return(BigInt(n)<>>=0,t>>>=0,r||N(e,t,this.length);for(var n=this[e],i=1,o=0;++o=(i*=128)&&(n-=Math.pow(2,8*t)),n},m.prototype.readIntBE=function(e,t,r){e>>>=0,t>>>=0,r||N(e,t,this.length);for(var n=t,i=1,o=this[e+--n];n>0&&(i*=256);)o+=this[e+--n]*i;return o>=(i*=128)&&(o-=Math.pow(2,8*t)),o},m.prototype.readInt8=function(e,t){return e>>>=0,t||N(e,1,this.length),128&this[e]?-1*(255-this[e]+1):this[e]},m.prototype.readInt16LE=function(e,t){e>>>=0,t||N(e,2,this.length);var r=this[e]|this[e+1]<<8;return 32768&r?4294901760|r:r},m.prototype.readInt16BE=function(e,t){e>>>=0,t||N(e,2,this.length);var r=this[e+1]|this[e]<<8;return 32768&r?4294901760|r:r},m.prototype.readInt32LE=function(e,t){return e>>>=0,t||N(e,4,this.length),this[e]|this[e+1]<<8|this[e+2]<<16|this[e+3]<<24},m.prototype.readInt32BE=function(e,t){return e>>>=0,t||N(e,4,this.length),this[e]<<24|this[e+1]<<16|this[e+2]<<8|this[e+3]},m.prototype.readBigInt64LE=oe((function(e){Z(e>>>=0,"offset");var t=this[e],r=this[e+7];void 0!==t&&void 0!==r||K(e,this.length-8);var n=this[e+4]+this[e+5]*Math.pow(2,8)+this[e+6]*Math.pow(2,16)+(r<<24);return(BigInt(n)<>>=0,"offset");var t=this[e],r=this[e+7];void 0!==t&&void 0!==r||K(e,this.length-8);var n=(t<<24)+this[++e]*Math.pow(2,16)+this[++e]*Math.pow(2,8)+this[++e];return(BigInt(n)<>>=0,t||N(e,4,this.length),d.read(this,e,!0,23,4)},m.prototype.readFloatBE=function(e,t){return e>>>=0,t||N(e,4,this.length),d.read(this,e,!1,23,4)},m.prototype.readDoubleLE=function(e,t){return e>>>=0,t||N(e,8,this.length),d.read(this,e,!0,52,8)},m.prototype.readDoubleBE=function(e,t){return e>>>=0,t||N(e,8,this.length),d.read(this,e,!1,52,8)},m.prototype.writeUintLE=m.prototype.writeUIntLE=function(e,t,r,n){(e=+e,t>>>=0,r>>>=0,n)||B(this,e,t,r,Math.pow(2,8*r)-1,0);var i=1,o=0;for(this[t]=255&e;++o>>=0,r>>>=0,n)||B(this,e,t,r,Math.pow(2,8*r)-1,0);var i=r-1,o=1;for(this[t+i]=255&e;--i>=0&&(o*=256);)this[t+i]=e/o&255;return t+r},m.prototype.writeUint8=m.prototype.writeUInt8=function(e,t,r){return e=+e,t>>>=0,r||B(this,e,t,1,255,0),this[t]=255&e,t+1},m.prototype.writeUint16LE=m.prototype.writeUInt16LE=function(e,t,r){return e=+e,t>>>=0,r||B(this,e,t,2,65535,0),this[t]=255&e,this[t+1]=e>>>8,t+2},m.prototype.writeUint16BE=m.prototype.writeUInt16BE=function(e,t,r){return e=+e,t>>>=0,r||B(this,e,t,2,65535,0),this[t]=e>>>8,this[t+1]=255&e,t+2},m.prototype.writeUint32LE=m.prototype.writeUInt32LE=function(e,t,r){return e=+e,t>>>=0,r||B(this,e,t,4,4294967295,0),this[t+3]=e>>>24,this[t+2]=e>>>16,this[t+1]=e>>>8,this[t]=255&e,t+4},m.prototype.writeUint32BE=m.prototype.writeUInt32BE=function(e,t,r){return e=+e,t>>>=0,r||B(this,e,t,4,4294967295,0),this[t]=e>>>24,this[t+1]=e>>>16,this[t+2]=e>>>8,this[t+3]=255&e,t+4},m.prototype.writeBigUInt64LE=oe((function(e){return V(this,e,arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,BigInt(0),BigInt("0xffffffffffffffff"))})),m.prototype.writeBigUInt64BE=oe((function(e){return U(this,e,arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,BigInt(0),BigInt("0xffffffffffffffff"))})),m.prototype.writeIntLE=function(e,t,r,n){if(e=+e,t>>>=0,!n){var i=Math.pow(2,8*r-1);B(this,e,t,r,i-1,-i)}var o=0,a=1,s=0;for(this[t]=255&e;++o>>=0,!n){var i=Math.pow(2,8*r-1);B(this,e,t,r,i-1,-i)}var o=r-1,a=1,s=0;for(this[t+o]=255&e;--o>=0&&(a*=256);)e<0&&0===s&&0!==this[t+o+1]&&(s=1),this[t+o]=(e/a|0)-s&255;return t+r},m.prototype.writeInt8=function(e,t,r){return e=+e,t>>>=0,r||B(this,e,t,1,127,-128),e<0&&(e=255+e+1),this[t]=255&e,t+1},m.prototype.writeInt16LE=function(e,t,r){return e=+e,t>>>=0,r||B(this,e,t,2,32767,-32768),this[t]=255&e,this[t+1]=e>>>8,t+2},m.prototype.writeInt16BE=function(e,t,r){return e=+e,t>>>=0,r||B(this,e,t,2,32767,-32768),this[t]=e>>>8,this[t+1]=255&e,t+2},m.prototype.writeInt32LE=function(e,t,r){return e=+e,t>>>=0,r||B(this,e,t,4,2147483647,-2147483648),this[t]=255&e,this[t+1]=e>>>8,this[t+2]=e>>>16,this[t+3]=e>>>24,t+4},m.prototype.writeInt32BE=function(e,t,r){return e=+e,t>>>=0,r||B(this,e,t,4,2147483647,-2147483648),e<0&&(e=4294967295+e+1),this[t]=e>>>24,this[t+1]=e>>>16,this[t+2]=e>>>8,this[t+3]=255&e,t+4},m.prototype.writeBigInt64LE=oe((function(e){return V(this,e,arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))})),m.prototype.writeBigInt64BE=oe((function(e){return U(this,e,arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))})),m.prototype.writeFloatLE=function(e,t,r){return $(this,e,t,!0,r)},m.prototype.writeFloatBE=function(e,t,r){return $(this,e,t,!1,r)},m.prototype.writeDoubleLE=function(e,t,r){return W(this,e,t,!0,r)},m.prototype.writeDoubleBE=function(e,t,r){return W(this,e,t,!1,r)},m.prototype.copy=function(e,t,r,n){if(!m.isBuffer(e))throw new TypeError("argument should be a Buffer");if(r||(r=0),n||0===n||(n=this.length),t>=e.length&&(t=e.length),t||(t=0),n>0&&n=this.length)throw new RangeError("Index out of range");if(n<0)throw new RangeError("sourceEnd out of bounds");n>this.length&&(n=this.length),e.length-t>>=0,r=void 0===r?this.length:r>>>0,e||(e=0),"number"===typeof e)for(o=t;o=n+4;r-=3)t="_".concat(e.slice(r-3,r)).concat(t);return"".concat(e.slice(0,r)).concat(t)}function X(e,t,r,n,i,o){if(e>r||e3?0===t||t===BigInt(0)?">= 0".concat(s," and < 2").concat(s," ** ").concat(8*(o+1)).concat(s):">= -(2".concat(s," ** ").concat(8*(o+1)-1).concat(s,") and < 2 ** ")+"".concat(8*(o+1)-1).concat(s):">= ".concat(t).concat(s," and <= ").concat(r).concat(s),new q.ERR_OUT_OF_RANGE("value",a,e)}!function(e,t,r){Z(t,"offset"),void 0!==e[t]&&void 0!==e[t+r]||K(t,e.length-(r+1))}(n,i,o)}function Z(e,t){if("number"!==typeof e)throw new q.ERR_INVALID_ARG_TYPE(t,"number",e)}function K(e,t,r){if(Math.floor(e)!==e)throw Z(e,r),new q.ERR_OUT_OF_RANGE(r||"offset","an integer",e);if(t<0)throw new q.ERR_BUFFER_OUT_OF_BOUNDS;throw new q.ERR_OUT_OF_RANGE(r||"offset",">= ".concat(r?1:0," and <= ").concat(t),e)}G("ERR_BUFFER_OUT_OF_BOUNDS",(function(e){return e?"".concat(e," is outside of buffer bounds"):"Attempt to access memory outside buffer bounds"}),RangeError),G("ERR_INVALID_ARG_TYPE",(function(e,t){return'The "'.concat(e,'" argument must be of type number. Received type ').concat(c(t))}),TypeError),G("ERR_OUT_OF_RANGE",(function(e,t,r){var n='The value of "'.concat(e,'" is out of range.'),i=r;return Number.isInteger(r)&&Math.abs(r)>Math.pow(2,32)?i=Y(String(r)):"bigint"===typeof r&&(i=String(r),(r>Math.pow(BigInt(2),BigInt(32))||r<-Math.pow(BigInt(2),BigInt(32)))&&(i=Y(i)),i+="n"),n+=" It must be ".concat(t,". Received ").concat(i)}),RangeError);var J=/[^+/0-9A-Za-z-_]/g;function Q(e,t){var r;t=t||1/0;for(var n=e.length,i=null,o=[],a=0;a55295&&r<57344){if(!i){if(r>56319){(t-=3)>-1&&o.push(239,191,189);continue}if(a+1===n){(t-=3)>-1&&o.push(239,191,189);continue}i=r;continue}if(r<56320){(t-=3)>-1&&o.push(239,191,189),i=r;continue}r=65536+(i-55296<<10|r-56320)}else i&&(t-=3)>-1&&o.push(239,191,189);if(i=null,r<128){if((t-=1)<0)break;o.push(r)}else if(r<2048){if((t-=2)<0)break;o.push(r>>6|192,63&r|128)}else if(r<65536){if((t-=3)<0)break;o.push(r>>12|224,r>>6&63|128,63&r|128)}else{if(!(r<1114112))throw new Error("Invalid code point");if((t-=4)<0)break;o.push(r>>18|240,r>>12&63|128,r>>6&63|128,63&r|128)}}return o}function ee(e){return u.toByteArray(function(e){if((e=(e=e.split("=")[0]).trim().replace(J,"")).length<2)return"";for(;e.length%4!==0;)e+="=";return e}(e))}function te(e,t,r,n){var i;for(i=0;i=t.length||i>=e.length);++i)t[i+r]=e[i];return i}function re(e,t){return e instanceof t||null!=e&&null!=e.constructor&&null!=e.constructor.name&&e.constructor.name===t.name}function ne(e){return e!==e}var ie=function(){for(var e="0123456789abcdef",t=new Array(256),r=0;r<16;++r)for(var n=16*r,i=0;i<16;++i)t[n+i]=e[r]+e[i];return t}();function oe(e){return"undefined"===typeof BigInt?ae:e}function ae(){throw new Error("BigInt not supported")}},9216:function(e){"use strict";e.exports=i,e.exports.isMobile=i,e.exports.default=i;var t=/(android|bb\d+|meego).+mobile|armv7l|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series[46]0|samsungbrowser.*mobile|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino/i,r=/CrOS/,n=/android|ipad|playbook|silk/i;function i(e){e||(e={});var i=e.ua;if(i||"undefined"===typeof navigator||(i=navigator.userAgent),i&&i.headers&&"string"===typeof i.headers["user-agent"]&&(i=i.headers["user-agent"]),"string"!==typeof i)return!1;var o=t.test(i)&&!r.test(i)||!!e.tablet&&n.test(i);return!o&&e.tablet&&e.featureDetect&&navigator&&navigator.maxTouchPoints>1&&-1!==i.indexOf("Macintosh")&&-1!==i.indexOf("Safari")&&(o=!0),o}},6296:function(e,t,r){"use strict";e.exports=function(e){var t=(e=e||{}).eye||[0,0,1],r=e.center||[0,0,0],s=e.up||[0,1,0],l=e.distanceLimits||[0,1/0],c=e.mode||"turntable",u=n(),d=i(),h=o();return u.setDistanceLimits(l[0],l[1]),u.lookAt(0,t,r,s),d.setDistanceLimits(l[0],l[1]),d.lookAt(0,t,r,s),h.setDistanceLimits(l[0],l[1]),h.lookAt(0,t,r,s),new a({turntable:u,orbit:d,matrix:h},c)};var n=r(7261),i=r(9977),o=r(4192);function a(e,t){this._controllerNames=Object.keys(e),this._controllerList=this._controllerNames.map((function(t){return e[t]})),this._mode=t,this._active=e[t],this._active||(this._mode="turntable",this._active=e.turntable),this.modes=this._controllerNames,this.computedMatrix=this._active.computedMatrix,this.computedEye=this._active.computedEye,this.computedUp=this._active.computedUp,this.computedCenter=this._active.computedCenter,this.computedRadius=this._active.computedRadius}var s=a.prototype;s.flush=function(e){for(var t=this._controllerList,r=0;r0?a-4:a;for(r=0;r>16&255,c[u++]=t>>8&255,c[u++]=255&t;2===l&&(t=n[e.charCodeAt(r)]<<2|n[e.charCodeAt(r+1)]>>4,c[u++]=255&t);1===l&&(t=n[e.charCodeAt(r)]<<10|n[e.charCodeAt(r+1)]<<4|n[e.charCodeAt(r+2)]>>2,c[u++]=t>>8&255,c[u++]=255&t);return c},t.fromByteArray=function(e){for(var t,n=e.length,i=n%3,o=[],a=16383,s=0,c=n-i;sc?c:s+a));1===i?(t=e[n-1],o.push(r[t>>2]+r[t<<4&63]+"==")):2===i&&(t=(e[n-2]<<8)+e[n-1],o.push(r[t>>10]+r[t>>4&63]+r[t<<2&63]+"="));return o.join("")};for(var r=[],n=[],i="undefined"!==typeof Uint8Array?Uint8Array:Array,o="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",a=0;a<64;++a)r[a]=o[a],n[o.charCodeAt(a)]=a;function s(e){var t=e.length;if(t%4>0)throw new Error("Invalid string. Length must be a multiple of 4");var r=e.indexOf("=");return-1===r&&(r=t),[r,r===t?0:4-r%4]}function l(e,t,n){for(var i,o,a=[],s=t;s>18&63]+r[o>>12&63]+r[o>>6&63]+r[63&o]);return a.join("")}n["-".charCodeAt(0)]=62,n["_".charCodeAt(0)]=63},3865:function(e,t,r){"use strict";var n=r(869);e.exports=function(e,t){return n(e[0].mul(t[1]).add(t[0].mul(e[1])),e[1].mul(t[1]))}},1318:function(e){"use strict";e.exports=function(e,t){return e[0].mul(t[1]).cmp(t[0].mul(e[1]))}},8697:function(e,t,r){"use strict";var n=r(869);e.exports=function(e,t){return n(e[0].mul(t[1]),e[1].mul(t[0]))}},7842:function(e,t,r){"use strict";var n=r(6330),i=r(1533),o=r(2651),a=r(4387),s=r(869),l=r(8697);e.exports=function e(t,r){if(n(t))return r?l(t,e(r)):[t[0].clone(),t[1].clone()];var c,u,d=0;if(i(t))c=t.clone();else if("string"===typeof t)c=a(t);else{if(0===t)return[o(0),o(1)];if(t===Math.floor(t))c=o(t);else{for(;t!==Math.floor(t);)t*=Math.pow(2,256),d-=256;c=o(t)}}if(n(r))c.mul(r[1]),u=r[0].clone();else if(i(r))u=r.clone();else if("string"===typeof r)u=a(r);else if(r)if(r===Math.floor(r))u=o(r);else{for(;r!==Math.floor(r);)r*=Math.pow(2,256),d+=256;u=o(r)}else u=o(1);d>0?c=c.ushln(d):d<0&&(u=u.ushln(-d));return s(c,u)}},6330:function(e,t,r){"use strict";var n=r(1533);e.exports=function(e){return Array.isArray(e)&&2===e.length&&n(e[0])&&n(e[1])}},5716:function(e,t,r){"use strict";var n=r(6859);e.exports=function(e){return e.cmp(new n(0))}},1369:function(e,t,r){"use strict";var n=r(5716);e.exports=function(e){var t=e.length,r=e.words,i=0;if(1===t)i=r[0];else if(2===t)i=r[0]+67108864*r[1];else for(var o=0;o20)return 52;return r+32}},1533:function(e,t,r){"use strict";r(6859);e.exports=function(e){return e&&"object"===typeof e&&Boolean(e.words)}},2651:function(e,t,r){"use strict";var n=r(6859),i=r(2361);e.exports=function(e){var t=i.exponent(e);return t<52?new n(e):new n(e*Math.pow(2,52-t)).ushln(t-52)}},869:function(e,t,r){"use strict";var n=r(2651),i=r(5716);e.exports=function(e,t){var r=i(e),o=i(t);if(0===r)return[n(0),n(1)];if(0===o)return[n(0),n(0)];o<0&&(e=e.neg(),t=t.neg());var a=e.gcd(t);if(a.cmpn(1))return[e.div(a),t.div(a)];return[e,t]}},4387:function(e,t,r){"use strict";var n=r(6859);e.exports=function(e){return new n(e)}},6504:function(e,t,r){"use strict";var n=r(869);e.exports=function(e,t){return n(e[0].mul(t[0]),e[1].mul(t[1]))}},7721:function(e,t,r){"use strict";var n=r(5716);e.exports=function(e){return n(e[0])*n(e[1])}},5572:function(e,t,r){"use strict";var n=r(869);e.exports=function(e,t){return n(e[0].mul(t[1]).sub(e[1].mul(t[0])),e[1].mul(t[1]))}},946:function(e,t,r){"use strict";var n=r(1369),i=r(4025);e.exports=function(e){var t=e[0],r=e[1];if(0===t.cmpn(0))return 0;var o=t.abs().divmod(r.abs()),a=o.div,s=n(a),l=o.mod,c=t.negative!==r.negative?-1:1;if(0===l.cmpn(0))return c*s;if(s){var u=i(s)+4;return c*(s+(h=n(l.ushln(u).divRound(r)))*Math.pow(2,-u))}var d=r.bitLength()-l.bitLength()+53,h=n(l.ushln(d).divRound(r));return d<1023?c*h*Math.pow(2,-d):c*(h*=Math.pow(2,-1023))*Math.pow(2,1023-d)}},2478:function(e){"use strict";function t(e,t,r,n,i){for(var o=i+1;n<=i;){var a=n+i>>>1,s=e[a];(void 0!==r?r(s,t):s-t)>=0?(o=a,i=a-1):n=a+1}return o}function r(e,t,r,n,i){for(var o=i+1;n<=i;){var a=n+i>>>1,s=e[a];(void 0!==r?r(s,t):s-t)>0?(o=a,i=a-1):n=a+1}return o}function n(e,t,r,n,i){for(var o=n-1;n<=i;){var a=n+i>>>1,s=e[a];(void 0!==r?r(s,t):s-t)<0?(o=a,n=a+1):i=a-1}return o}function i(e,t,r,n,i){for(var o=n-1;n<=i;){var a=n+i>>>1,s=e[a];(void 0!==r?r(s,t):s-t)<=0?(o=a,n=a+1):i=a-1}return o}function o(e,t,r,n,i){for(;n<=i;){var o=n+i>>>1,a=e[o],s=void 0!==r?r(a,t):a-t;if(0===s)return o;s<=0?n=o+1:i=o-1}return-1}function a(e,t,r,n,i,o){return"function"===typeof r?o(e,t,r,void 0===n?0:0|n,void 0===i?e.length-1:0|i):o(e,t,void 0,void 0===r?0:0|r,void 0===n?e.length-1:0|n)}e.exports={ge:function(e,r,n,i,o){return a(e,r,n,i,o,t)},gt:function(e,t,n,i,o){return a(e,t,n,i,o,r)},lt:function(e,t,r,i,o){return a(e,t,r,i,o,n)},le:function(e,t,r,n,o){return a(e,t,r,n,o,i)},eq:function(e,t,r,n,i){return a(e,t,r,n,i,o)}}},8828:function(e,t){"use strict";function r(e){var t=32;return(e&=-e)&&t--,65535&e&&(t-=16),16711935&e&&(t-=8),252645135&e&&(t-=4),858993459&e&&(t-=2),1431655765&e&&(t-=1),t}t.INT_BITS=32,t.INT_MAX=2147483647,t.INT_MIN=-1<<31,t.sign=function(e){return(e>0)-(e<0)},t.abs=function(e){var t=e>>31;return(e^t)-t},t.min=function(e,t){return t^(e^t)&-(e65535)<<4,t|=r=((e>>>=t)>255)<<3,t|=r=((e>>>=r)>15)<<2,(t|=r=((e>>>=r)>3)<<1)|(e>>>=r)>>1},t.log10=function(e){return e>=1e9?9:e>=1e8?8:e>=1e7?7:e>=1e6?6:e>=1e5?5:e>=1e4?4:e>=1e3?3:e>=100?2:e>=10?1:0},t.popCount=function(e){return 16843009*((e=(858993459&(e-=e>>>1&1431655765))+(e>>>2&858993459))+(e>>>4)&252645135)>>>24},t.countTrailingZeros=r,t.nextPow2=function(e){return e+=0===e,--e,e|=e>>>1,e|=e>>>2,e|=e>>>4,e|=e>>>8,(e|=e>>>16)+1},t.prevPow2=function(e){return e|=e>>>1,e|=e>>>2,e|=e>>>4,e|=e>>>8,(e|=e>>>16)-(e>>>1)},t.parity=function(e){return e^=e>>>16,e^=e>>>8,e^=e>>>4,27030>>>(e&=15)&1};var n=new Array(256);!function(e){for(var t=0;t<256;++t){var r=t,n=t,i=7;for(r>>>=1;r;r>>>=1)n<<=1,n|=1&r,--i;e[t]=n<>>8&255]<<16|n[e>>>16&255]<<8|n[e>>>24&255]},t.interleave2=function(e,t){return(e=1431655765&((e=858993459&((e=252645135&((e=16711935&((e&=65535)|e<<8))|e<<4))|e<<2))|e<<1))|(t=1431655765&((t=858993459&((t=252645135&((t=16711935&((t&=65535)|t<<8))|t<<4))|t<<2))|t<<1))<<1},t.deinterleave2=function(e,t){return(e=65535&((e=16711935&((e=252645135&((e=858993459&((e=e>>>t&1431655765)|e>>>1))|e>>>2))|e>>>4))|e>>>16))<<16>>16},t.interleave3=function(e,t,r){return e=1227133513&((e=3272356035&((e=251719695&((e=4278190335&((e&=1023)|e<<16))|e<<8))|e<<4))|e<<2),(e|=(t=1227133513&((t=3272356035&((t=251719695&((t=4278190335&((t&=1023)|t<<16))|t<<8))|t<<4))|t<<2))<<1)|(r=1227133513&((r=3272356035&((r=251719695&((r=4278190335&((r&=1023)|r<<16))|r<<8))|r<<4))|r<<2))<<2},t.deinterleave3=function(e,t){return(e=1023&((e=4278190335&((e=251719695&((e=3272356035&((e=e>>>t&1227133513)|e>>>2))|e>>>4))|e>>>8))|e>>>16))<<22>>22},t.nextCombination=function(e){var t=e|e-1;return t+1|(~t&-~t)-1>>>r(e)+1}},6859:function(e,t,r){!function(e,t){"use strict";function n(e,t){if(!e)throw new Error(t||"Assertion failed")}function i(e,t){e.super_=t;var r=function(){};r.prototype=t.prototype,e.prototype=new r,e.prototype.constructor=e}function o(e,t,r){if(o.isBN(e))return e;this.negative=0,this.words=null,this.length=0,this.red=null,null!==e&&("le"!==t&&"be"!==t||(r=t,t=10),this._init(e||0,t||10,r||"be"))}var a;"object"===typeof e?e.exports=o:t.BN=o,o.BN=o,o.wordSize=26;try{a="undefined"!==typeof window&&"undefined"!==typeof window.Buffer?window.Buffer:r(7790).Buffer}catch(A){}function s(e,t){var r=e.charCodeAt(t);return r>=65&&r<=70?r-55:r>=97&&r<=102?r-87:r-48&15}function l(e,t,r){var n=s(e,r);return r-1>=t&&(n|=s(e,r-1)<<4),n}function c(e,t,r,n){for(var i=0,o=Math.min(e.length,r),a=t;a=49?s-49+10:s>=17?s-17+10:s}return i}o.isBN=function(e){return e instanceof o||null!==e&&"object"===typeof e&&e.constructor.wordSize===o.wordSize&&Array.isArray(e.words)},o.max=function(e,t){return e.cmp(t)>0?e:t},o.min=function(e,t){return e.cmp(t)<0?e:t},o.prototype._init=function(e,t,r){if("number"===typeof e)return this._initNumber(e,t,r);if("object"===typeof e)return this._initArray(e,t,r);"hex"===t&&(t=16),n(t===(0|t)&&t>=2&&t<=36);var i=0;"-"===(e=e.toString().replace(/\s+/g,""))[0]&&(i++,this.negative=1),i=0;i-=3)a=e[i]|e[i-1]<<8|e[i-2]<<16,this.words[o]|=a<>>26-s&67108863,(s+=24)>=26&&(s-=26,o++);else if("le"===r)for(i=0,o=0;i>>26-s&67108863,(s+=24)>=26&&(s-=26,o++);return this.strip()},o.prototype._parseHex=function(e,t,r){this.length=Math.ceil((e.length-t)/6),this.words=new Array(this.length);for(var n=0;n=t;n-=2)i=l(e,t,n)<=18?(o-=18,a+=1,this.words[a]|=i>>>26):o+=8;else for(n=(e.length-t)%2===0?t+1:t;n=18?(o-=18,a+=1,this.words[a]|=i>>>26):o+=8;this.strip()},o.prototype._parseBase=function(e,t,r){this.words=[0],this.length=1;for(var n=0,i=1;i<=67108863;i*=t)n++;n--,i=i/t|0;for(var o=e.length-r,a=o%n,s=Math.min(o,o-a)+r,l=0,u=r;u1&&0===this.words[this.length-1];)this.length--;return this._normSign()},o.prototype._normSign=function(){return 1===this.length&&0===this.words[0]&&(this.negative=0),this},o.prototype.inspect=function(){return(this.red?""};var u=["","0","00","000","0000","00000","000000","0000000","00000000","000000000","0000000000","00000000000","000000000000","0000000000000","00000000000000","000000000000000","0000000000000000","00000000000000000","000000000000000000","0000000000000000000","00000000000000000000","000000000000000000000","0000000000000000000000","00000000000000000000000","000000000000000000000000","0000000000000000000000000"],d=[0,0,25,16,12,11,10,9,8,8,7,7,7,7,6,6,6,6,6,6,6,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5],h=[0,0,33554432,43046721,16777216,48828125,60466176,40353607,16777216,43046721,1e7,19487171,35831808,62748517,7529536,11390625,16777216,24137569,34012224,47045881,64e6,4084101,5153632,6436343,7962624,9765625,11881376,14348907,17210368,20511149,243e5,28629151,33554432,39135393,45435424,52521875,60466176];function p(e,t,r){r.negative=t.negative^e.negative;var n=e.length+t.length|0;r.length=n,n=n-1|0;var i=0|e.words[0],o=0|t.words[0],a=i*o,s=67108863&a,l=a/67108864|0;r.words[0]=s;for(var c=1;c>>26,d=67108863&l,h=Math.min(c,t.length-1),p=Math.max(0,c-e.length+1);p<=h;p++){var f=c-p|0;u+=(a=(i=0|e.words[f])*(o=0|t.words[p])+d)/67108864|0,d=67108863&a}r.words[c]=0|d,l=0|u}return 0!==l?r.words[c]=0|l:r.length--,r.strip()}o.prototype.toString=function(e,t){var r;if(t=0|t||1,16===(e=e||10)||"hex"===e){r="";for(var i=0,o=0,a=0;a>>24-i&16777215)||a!==this.length-1?u[6-l.length]+l+r:l+r,(i+=2)>=26&&(i-=26,a--)}for(0!==o&&(r=o.toString(16)+r);r.length%t!==0;)r="0"+r;return 0!==this.negative&&(r="-"+r),r}if(e===(0|e)&&e>=2&&e<=36){var c=d[e],p=h[e];r="";var f=this.clone();for(f.negative=0;!f.isZero();){var m=f.modn(p).toString(e);r=(f=f.idivn(p)).isZero()?m+r:u[c-m.length]+m+r}for(this.isZero()&&(r="0"+r);r.length%t!==0;)r="0"+r;return 0!==this.negative&&(r="-"+r),r}n(!1,"Base should be between 2 and 36")},o.prototype.toNumber=function(){var e=this.words[0];return 2===this.length?e+=67108864*this.words[1]:3===this.length&&1===this.words[2]?e+=4503599627370496+67108864*this.words[1]:this.length>2&&n(!1,"Number can only safely store up to 53 bits"),0!==this.negative?-e:e},o.prototype.toJSON=function(){return this.toString(16)},o.prototype.toBuffer=function(e,t){return n("undefined"!==typeof a),this.toArrayLike(a,e,t)},o.prototype.toArray=function(e,t){return this.toArrayLike(Array,e,t)},o.prototype.toArrayLike=function(e,t,r){var i=this.byteLength(),o=r||Math.max(1,i);n(i<=o,"byte array longer than desired length"),n(o>0,"Requested array length <= 0"),this.strip();var a,s,l="le"===t,c=new e(o),u=this.clone();if(l){for(s=0;!u.isZero();s++)a=u.andln(255),u.iushrn(8),c[s]=a;for(;s=4096&&(r+=13,t>>>=13),t>=64&&(r+=7,t>>>=7),t>=8&&(r+=4,t>>>=4),t>=2&&(r+=2,t>>>=2),r+t},o.prototype._zeroBits=function(e){if(0===e)return 26;var t=e,r=0;return 0===(8191&t)&&(r+=13,t>>>=13),0===(127&t)&&(r+=7,t>>>=7),0===(15&t)&&(r+=4,t>>>=4),0===(3&t)&&(r+=2,t>>>=2),0===(1&t)&&r++,r},o.prototype.bitLength=function(){var e=this.words[this.length-1],t=this._countBits(e);return 26*(this.length-1)+t},o.prototype.zeroBits=function(){if(this.isZero())return 0;for(var e=0,t=0;te.length?this.clone().ior(e):e.clone().ior(this)},o.prototype.uor=function(e){return this.length>e.length?this.clone().iuor(e):e.clone().iuor(this)},o.prototype.iuand=function(e){var t;t=this.length>e.length?e:this;for(var r=0;re.length?this.clone().iand(e):e.clone().iand(this)},o.prototype.uand=function(e){return this.length>e.length?this.clone().iuand(e):e.clone().iuand(this)},o.prototype.iuxor=function(e){var t,r;this.length>e.length?(t=this,r=e):(t=e,r=this);for(var n=0;ne.length?this.clone().ixor(e):e.clone().ixor(this)},o.prototype.uxor=function(e){return this.length>e.length?this.clone().iuxor(e):e.clone().iuxor(this)},o.prototype.inotn=function(e){n("number"===typeof e&&e>=0);var t=0|Math.ceil(e/26),r=e%26;this._expand(t),r>0&&t--;for(var i=0;i0&&(this.words[i]=~this.words[i]&67108863>>26-r),this.strip()},o.prototype.notn=function(e){return this.clone().inotn(e)},o.prototype.setn=function(e,t){n("number"===typeof e&&e>=0);var r=e/26|0,i=e%26;return this._expand(r+1),this.words[r]=t?this.words[r]|1<e.length?(r=this,n=e):(r=e,n=this);for(var i=0,o=0;o>>26;for(;0!==i&&o>>26;if(this.length=r.length,0!==i)this.words[this.length]=i,this.length++;else if(r!==this)for(;oe.length?this.clone().iadd(e):e.clone().iadd(this)},o.prototype.isub=function(e){if(0!==e.negative){e.negative=0;var t=this.iadd(e);return e.negative=1,t._normSign()}if(0!==this.negative)return this.negative=0,this.iadd(e),this.negative=1,this._normSign();var r,n,i=this.cmp(e);if(0===i)return this.negative=0,this.length=1,this.words[0]=0,this;i>0?(r=this,n=e):(r=e,n=this);for(var o=0,a=0;a>26,this.words[a]=67108863&t;for(;0!==o&&a>26,this.words[a]=67108863&t;if(0===o&&a>>13,p=0|a[1],f=8191&p,m=p>>>13,g=0|a[2],y=8191&g,v=g>>>13,x=0|a[3],b=8191&x,_=x>>>13,w=0|a[4],k=8191&w,S=w>>>13,A=0|a[5],T=8191&A,M=A>>>13,C=0|a[6],E=8191&C,I=C>>>13,P=0|a[7],O=8191&P,R=P>>>13,L=0|a[8],D=8191&L,z=L>>>13,j=0|a[9],F=8191&j,N=j>>>13,B=0|s[0],V=8191&B,U=B>>>13,H=0|s[1],$=8191&H,W=H>>>13,q=0|s[2],G=8191&q,Y=q>>>13,X=0|s[3],Z=8191&X,K=X>>>13,J=0|s[4],Q=8191&J,ee=J>>>13,te=0|s[5],re=8191&te,ne=te>>>13,ie=0|s[6],oe=8191&ie,ae=ie>>>13,se=0|s[7],le=8191&se,ce=se>>>13,ue=0|s[8],de=8191&ue,he=ue>>>13,pe=0|s[9],fe=8191&pe,me=pe>>>13;r.negative=e.negative^t.negative,r.length=19;var ge=(c+(n=Math.imul(d,V))|0)+((8191&(i=(i=Math.imul(d,U))+Math.imul(h,V)|0))<<13)|0;c=((o=Math.imul(h,U))+(i>>>13)|0)+(ge>>>26)|0,ge&=67108863,n=Math.imul(f,V),i=(i=Math.imul(f,U))+Math.imul(m,V)|0,o=Math.imul(m,U);var ye=(c+(n=n+Math.imul(d,$)|0)|0)+((8191&(i=(i=i+Math.imul(d,W)|0)+Math.imul(h,$)|0))<<13)|0;c=((o=o+Math.imul(h,W)|0)+(i>>>13)|0)+(ye>>>26)|0,ye&=67108863,n=Math.imul(y,V),i=(i=Math.imul(y,U))+Math.imul(v,V)|0,o=Math.imul(v,U),n=n+Math.imul(f,$)|0,i=(i=i+Math.imul(f,W)|0)+Math.imul(m,$)|0,o=o+Math.imul(m,W)|0;var ve=(c+(n=n+Math.imul(d,G)|0)|0)+((8191&(i=(i=i+Math.imul(d,Y)|0)+Math.imul(h,G)|0))<<13)|0;c=((o=o+Math.imul(h,Y)|0)+(i>>>13)|0)+(ve>>>26)|0,ve&=67108863,n=Math.imul(b,V),i=(i=Math.imul(b,U))+Math.imul(_,V)|0,o=Math.imul(_,U),n=n+Math.imul(y,$)|0,i=(i=i+Math.imul(y,W)|0)+Math.imul(v,$)|0,o=o+Math.imul(v,W)|0,n=n+Math.imul(f,G)|0,i=(i=i+Math.imul(f,Y)|0)+Math.imul(m,G)|0,o=o+Math.imul(m,Y)|0;var xe=(c+(n=n+Math.imul(d,Z)|0)|0)+((8191&(i=(i=i+Math.imul(d,K)|0)+Math.imul(h,Z)|0))<<13)|0;c=((o=o+Math.imul(h,K)|0)+(i>>>13)|0)+(xe>>>26)|0,xe&=67108863,n=Math.imul(k,V),i=(i=Math.imul(k,U))+Math.imul(S,V)|0,o=Math.imul(S,U),n=n+Math.imul(b,$)|0,i=(i=i+Math.imul(b,W)|0)+Math.imul(_,$)|0,o=o+Math.imul(_,W)|0,n=n+Math.imul(y,G)|0,i=(i=i+Math.imul(y,Y)|0)+Math.imul(v,G)|0,o=o+Math.imul(v,Y)|0,n=n+Math.imul(f,Z)|0,i=(i=i+Math.imul(f,K)|0)+Math.imul(m,Z)|0,o=o+Math.imul(m,K)|0;var be=(c+(n=n+Math.imul(d,Q)|0)|0)+((8191&(i=(i=i+Math.imul(d,ee)|0)+Math.imul(h,Q)|0))<<13)|0;c=((o=o+Math.imul(h,ee)|0)+(i>>>13)|0)+(be>>>26)|0,be&=67108863,n=Math.imul(T,V),i=(i=Math.imul(T,U))+Math.imul(M,V)|0,o=Math.imul(M,U),n=n+Math.imul(k,$)|0,i=(i=i+Math.imul(k,W)|0)+Math.imul(S,$)|0,o=o+Math.imul(S,W)|0,n=n+Math.imul(b,G)|0,i=(i=i+Math.imul(b,Y)|0)+Math.imul(_,G)|0,o=o+Math.imul(_,Y)|0,n=n+Math.imul(y,Z)|0,i=(i=i+Math.imul(y,K)|0)+Math.imul(v,Z)|0,o=o+Math.imul(v,K)|0,n=n+Math.imul(f,Q)|0,i=(i=i+Math.imul(f,ee)|0)+Math.imul(m,Q)|0,o=o+Math.imul(m,ee)|0;var _e=(c+(n=n+Math.imul(d,re)|0)|0)+((8191&(i=(i=i+Math.imul(d,ne)|0)+Math.imul(h,re)|0))<<13)|0;c=((o=o+Math.imul(h,ne)|0)+(i>>>13)|0)+(_e>>>26)|0,_e&=67108863,n=Math.imul(E,V),i=(i=Math.imul(E,U))+Math.imul(I,V)|0,o=Math.imul(I,U),n=n+Math.imul(T,$)|0,i=(i=i+Math.imul(T,W)|0)+Math.imul(M,$)|0,o=o+Math.imul(M,W)|0,n=n+Math.imul(k,G)|0,i=(i=i+Math.imul(k,Y)|0)+Math.imul(S,G)|0,o=o+Math.imul(S,Y)|0,n=n+Math.imul(b,Z)|0,i=(i=i+Math.imul(b,K)|0)+Math.imul(_,Z)|0,o=o+Math.imul(_,K)|0,n=n+Math.imul(y,Q)|0,i=(i=i+Math.imul(y,ee)|0)+Math.imul(v,Q)|0,o=o+Math.imul(v,ee)|0,n=n+Math.imul(f,re)|0,i=(i=i+Math.imul(f,ne)|0)+Math.imul(m,re)|0,o=o+Math.imul(m,ne)|0;var we=(c+(n=n+Math.imul(d,oe)|0)|0)+((8191&(i=(i=i+Math.imul(d,ae)|0)+Math.imul(h,oe)|0))<<13)|0;c=((o=o+Math.imul(h,ae)|0)+(i>>>13)|0)+(we>>>26)|0,we&=67108863,n=Math.imul(O,V),i=(i=Math.imul(O,U))+Math.imul(R,V)|0,o=Math.imul(R,U),n=n+Math.imul(E,$)|0,i=(i=i+Math.imul(E,W)|0)+Math.imul(I,$)|0,o=o+Math.imul(I,W)|0,n=n+Math.imul(T,G)|0,i=(i=i+Math.imul(T,Y)|0)+Math.imul(M,G)|0,o=o+Math.imul(M,Y)|0,n=n+Math.imul(k,Z)|0,i=(i=i+Math.imul(k,K)|0)+Math.imul(S,Z)|0,o=o+Math.imul(S,K)|0,n=n+Math.imul(b,Q)|0,i=(i=i+Math.imul(b,ee)|0)+Math.imul(_,Q)|0,o=o+Math.imul(_,ee)|0,n=n+Math.imul(y,re)|0,i=(i=i+Math.imul(y,ne)|0)+Math.imul(v,re)|0,o=o+Math.imul(v,ne)|0,n=n+Math.imul(f,oe)|0,i=(i=i+Math.imul(f,ae)|0)+Math.imul(m,oe)|0,o=o+Math.imul(m,ae)|0;var ke=(c+(n=n+Math.imul(d,le)|0)|0)+((8191&(i=(i=i+Math.imul(d,ce)|0)+Math.imul(h,le)|0))<<13)|0;c=((o=o+Math.imul(h,ce)|0)+(i>>>13)|0)+(ke>>>26)|0,ke&=67108863,n=Math.imul(D,V),i=(i=Math.imul(D,U))+Math.imul(z,V)|0,o=Math.imul(z,U),n=n+Math.imul(O,$)|0,i=(i=i+Math.imul(O,W)|0)+Math.imul(R,$)|0,o=o+Math.imul(R,W)|0,n=n+Math.imul(E,G)|0,i=(i=i+Math.imul(E,Y)|0)+Math.imul(I,G)|0,o=o+Math.imul(I,Y)|0,n=n+Math.imul(T,Z)|0,i=(i=i+Math.imul(T,K)|0)+Math.imul(M,Z)|0,o=o+Math.imul(M,K)|0,n=n+Math.imul(k,Q)|0,i=(i=i+Math.imul(k,ee)|0)+Math.imul(S,Q)|0,o=o+Math.imul(S,ee)|0,n=n+Math.imul(b,re)|0,i=(i=i+Math.imul(b,ne)|0)+Math.imul(_,re)|0,o=o+Math.imul(_,ne)|0,n=n+Math.imul(y,oe)|0,i=(i=i+Math.imul(y,ae)|0)+Math.imul(v,oe)|0,o=o+Math.imul(v,ae)|0,n=n+Math.imul(f,le)|0,i=(i=i+Math.imul(f,ce)|0)+Math.imul(m,le)|0,o=o+Math.imul(m,ce)|0;var Se=(c+(n=n+Math.imul(d,de)|0)|0)+((8191&(i=(i=i+Math.imul(d,he)|0)+Math.imul(h,de)|0))<<13)|0;c=((o=o+Math.imul(h,he)|0)+(i>>>13)|0)+(Se>>>26)|0,Se&=67108863,n=Math.imul(F,V),i=(i=Math.imul(F,U))+Math.imul(N,V)|0,o=Math.imul(N,U),n=n+Math.imul(D,$)|0,i=(i=i+Math.imul(D,W)|0)+Math.imul(z,$)|0,o=o+Math.imul(z,W)|0,n=n+Math.imul(O,G)|0,i=(i=i+Math.imul(O,Y)|0)+Math.imul(R,G)|0,o=o+Math.imul(R,Y)|0,n=n+Math.imul(E,Z)|0,i=(i=i+Math.imul(E,K)|0)+Math.imul(I,Z)|0,o=o+Math.imul(I,K)|0,n=n+Math.imul(T,Q)|0,i=(i=i+Math.imul(T,ee)|0)+Math.imul(M,Q)|0,o=o+Math.imul(M,ee)|0,n=n+Math.imul(k,re)|0,i=(i=i+Math.imul(k,ne)|0)+Math.imul(S,re)|0,o=o+Math.imul(S,ne)|0,n=n+Math.imul(b,oe)|0,i=(i=i+Math.imul(b,ae)|0)+Math.imul(_,oe)|0,o=o+Math.imul(_,ae)|0,n=n+Math.imul(y,le)|0,i=(i=i+Math.imul(y,ce)|0)+Math.imul(v,le)|0,o=o+Math.imul(v,ce)|0,n=n+Math.imul(f,de)|0,i=(i=i+Math.imul(f,he)|0)+Math.imul(m,de)|0,o=o+Math.imul(m,he)|0;var Ae=(c+(n=n+Math.imul(d,fe)|0)|0)+((8191&(i=(i=i+Math.imul(d,me)|0)+Math.imul(h,fe)|0))<<13)|0;c=((o=o+Math.imul(h,me)|0)+(i>>>13)|0)+(Ae>>>26)|0,Ae&=67108863,n=Math.imul(F,$),i=(i=Math.imul(F,W))+Math.imul(N,$)|0,o=Math.imul(N,W),n=n+Math.imul(D,G)|0,i=(i=i+Math.imul(D,Y)|0)+Math.imul(z,G)|0,o=o+Math.imul(z,Y)|0,n=n+Math.imul(O,Z)|0,i=(i=i+Math.imul(O,K)|0)+Math.imul(R,Z)|0,o=o+Math.imul(R,K)|0,n=n+Math.imul(E,Q)|0,i=(i=i+Math.imul(E,ee)|0)+Math.imul(I,Q)|0,o=o+Math.imul(I,ee)|0,n=n+Math.imul(T,re)|0,i=(i=i+Math.imul(T,ne)|0)+Math.imul(M,re)|0,o=o+Math.imul(M,ne)|0,n=n+Math.imul(k,oe)|0,i=(i=i+Math.imul(k,ae)|0)+Math.imul(S,oe)|0,o=o+Math.imul(S,ae)|0,n=n+Math.imul(b,le)|0,i=(i=i+Math.imul(b,ce)|0)+Math.imul(_,le)|0,o=o+Math.imul(_,ce)|0,n=n+Math.imul(y,de)|0,i=(i=i+Math.imul(y,he)|0)+Math.imul(v,de)|0,o=o+Math.imul(v,he)|0;var Te=(c+(n=n+Math.imul(f,fe)|0)|0)+((8191&(i=(i=i+Math.imul(f,me)|0)+Math.imul(m,fe)|0))<<13)|0;c=((o=o+Math.imul(m,me)|0)+(i>>>13)|0)+(Te>>>26)|0,Te&=67108863,n=Math.imul(F,G),i=(i=Math.imul(F,Y))+Math.imul(N,G)|0,o=Math.imul(N,Y),n=n+Math.imul(D,Z)|0,i=(i=i+Math.imul(D,K)|0)+Math.imul(z,Z)|0,o=o+Math.imul(z,K)|0,n=n+Math.imul(O,Q)|0,i=(i=i+Math.imul(O,ee)|0)+Math.imul(R,Q)|0,o=o+Math.imul(R,ee)|0,n=n+Math.imul(E,re)|0,i=(i=i+Math.imul(E,ne)|0)+Math.imul(I,re)|0,o=o+Math.imul(I,ne)|0,n=n+Math.imul(T,oe)|0,i=(i=i+Math.imul(T,ae)|0)+Math.imul(M,oe)|0,o=o+Math.imul(M,ae)|0,n=n+Math.imul(k,le)|0,i=(i=i+Math.imul(k,ce)|0)+Math.imul(S,le)|0,o=o+Math.imul(S,ce)|0,n=n+Math.imul(b,de)|0,i=(i=i+Math.imul(b,he)|0)+Math.imul(_,de)|0,o=o+Math.imul(_,he)|0;var Me=(c+(n=n+Math.imul(y,fe)|0)|0)+((8191&(i=(i=i+Math.imul(y,me)|0)+Math.imul(v,fe)|0))<<13)|0;c=((o=o+Math.imul(v,me)|0)+(i>>>13)|0)+(Me>>>26)|0,Me&=67108863,n=Math.imul(F,Z),i=(i=Math.imul(F,K))+Math.imul(N,Z)|0,o=Math.imul(N,K),n=n+Math.imul(D,Q)|0,i=(i=i+Math.imul(D,ee)|0)+Math.imul(z,Q)|0,o=o+Math.imul(z,ee)|0,n=n+Math.imul(O,re)|0,i=(i=i+Math.imul(O,ne)|0)+Math.imul(R,re)|0,o=o+Math.imul(R,ne)|0,n=n+Math.imul(E,oe)|0,i=(i=i+Math.imul(E,ae)|0)+Math.imul(I,oe)|0,o=o+Math.imul(I,ae)|0,n=n+Math.imul(T,le)|0,i=(i=i+Math.imul(T,ce)|0)+Math.imul(M,le)|0,o=o+Math.imul(M,ce)|0,n=n+Math.imul(k,de)|0,i=(i=i+Math.imul(k,he)|0)+Math.imul(S,de)|0,o=o+Math.imul(S,he)|0;var Ce=(c+(n=n+Math.imul(b,fe)|0)|0)+((8191&(i=(i=i+Math.imul(b,me)|0)+Math.imul(_,fe)|0))<<13)|0;c=((o=o+Math.imul(_,me)|0)+(i>>>13)|0)+(Ce>>>26)|0,Ce&=67108863,n=Math.imul(F,Q),i=(i=Math.imul(F,ee))+Math.imul(N,Q)|0,o=Math.imul(N,ee),n=n+Math.imul(D,re)|0,i=(i=i+Math.imul(D,ne)|0)+Math.imul(z,re)|0,o=o+Math.imul(z,ne)|0,n=n+Math.imul(O,oe)|0,i=(i=i+Math.imul(O,ae)|0)+Math.imul(R,oe)|0,o=o+Math.imul(R,ae)|0,n=n+Math.imul(E,le)|0,i=(i=i+Math.imul(E,ce)|0)+Math.imul(I,le)|0,o=o+Math.imul(I,ce)|0,n=n+Math.imul(T,de)|0,i=(i=i+Math.imul(T,he)|0)+Math.imul(M,de)|0,o=o+Math.imul(M,he)|0;var Ee=(c+(n=n+Math.imul(k,fe)|0)|0)+((8191&(i=(i=i+Math.imul(k,me)|0)+Math.imul(S,fe)|0))<<13)|0;c=((o=o+Math.imul(S,me)|0)+(i>>>13)|0)+(Ee>>>26)|0,Ee&=67108863,n=Math.imul(F,re),i=(i=Math.imul(F,ne))+Math.imul(N,re)|0,o=Math.imul(N,ne),n=n+Math.imul(D,oe)|0,i=(i=i+Math.imul(D,ae)|0)+Math.imul(z,oe)|0,o=o+Math.imul(z,ae)|0,n=n+Math.imul(O,le)|0,i=(i=i+Math.imul(O,ce)|0)+Math.imul(R,le)|0,o=o+Math.imul(R,ce)|0,n=n+Math.imul(E,de)|0,i=(i=i+Math.imul(E,he)|0)+Math.imul(I,de)|0,o=o+Math.imul(I,he)|0;var Ie=(c+(n=n+Math.imul(T,fe)|0)|0)+((8191&(i=(i=i+Math.imul(T,me)|0)+Math.imul(M,fe)|0))<<13)|0;c=((o=o+Math.imul(M,me)|0)+(i>>>13)|0)+(Ie>>>26)|0,Ie&=67108863,n=Math.imul(F,oe),i=(i=Math.imul(F,ae))+Math.imul(N,oe)|0,o=Math.imul(N,ae),n=n+Math.imul(D,le)|0,i=(i=i+Math.imul(D,ce)|0)+Math.imul(z,le)|0,o=o+Math.imul(z,ce)|0,n=n+Math.imul(O,de)|0,i=(i=i+Math.imul(O,he)|0)+Math.imul(R,de)|0,o=o+Math.imul(R,he)|0;var Pe=(c+(n=n+Math.imul(E,fe)|0)|0)+((8191&(i=(i=i+Math.imul(E,me)|0)+Math.imul(I,fe)|0))<<13)|0;c=((o=o+Math.imul(I,me)|0)+(i>>>13)|0)+(Pe>>>26)|0,Pe&=67108863,n=Math.imul(F,le),i=(i=Math.imul(F,ce))+Math.imul(N,le)|0,o=Math.imul(N,ce),n=n+Math.imul(D,de)|0,i=(i=i+Math.imul(D,he)|0)+Math.imul(z,de)|0,o=o+Math.imul(z,he)|0;var Oe=(c+(n=n+Math.imul(O,fe)|0)|0)+((8191&(i=(i=i+Math.imul(O,me)|0)+Math.imul(R,fe)|0))<<13)|0;c=((o=o+Math.imul(R,me)|0)+(i>>>13)|0)+(Oe>>>26)|0,Oe&=67108863,n=Math.imul(F,de),i=(i=Math.imul(F,he))+Math.imul(N,de)|0,o=Math.imul(N,he);var Re=(c+(n=n+Math.imul(D,fe)|0)|0)+((8191&(i=(i=i+Math.imul(D,me)|0)+Math.imul(z,fe)|0))<<13)|0;c=((o=o+Math.imul(z,me)|0)+(i>>>13)|0)+(Re>>>26)|0,Re&=67108863;var Le=(c+(n=Math.imul(F,fe))|0)+((8191&(i=(i=Math.imul(F,me))+Math.imul(N,fe)|0))<<13)|0;return c=((o=Math.imul(N,me))+(i>>>13)|0)+(Le>>>26)|0,Le&=67108863,l[0]=ge,l[1]=ye,l[2]=ve,l[3]=xe,l[4]=be,l[5]=_e,l[6]=we,l[7]=ke,l[8]=Se,l[9]=Ae,l[10]=Te,l[11]=Me,l[12]=Ce,l[13]=Ee,l[14]=Ie,l[15]=Pe,l[16]=Oe,l[17]=Re,l[18]=Le,0!==c&&(l[19]=c,r.length++),r};function m(e,t,r){return(new g).mulp(e,t,r)}function g(e,t){this.x=e,this.y=t}Math.imul||(f=p),o.prototype.mulTo=function(e,t){var r,n=this.length+e.length;return r=10===this.length&&10===e.length?f(this,e,t):n<63?p(this,e,t):n<1024?function(e,t,r){r.negative=t.negative^e.negative,r.length=e.length+t.length;for(var n=0,i=0,o=0;o>>26)|0)>>>26,a&=67108863}r.words[o]=s,n=a,a=i}return 0!==n?r.words[o]=n:r.length--,r.strip()}(this,e,t):m(this,e,t),r},g.prototype.makeRBT=function(e){for(var t=new Array(e),r=o.prototype._countBits(e)-1,n=0;n>=1;return n},g.prototype.permute=function(e,t,r,n,i,o){for(var a=0;a>>=1)i++;return 1<>>=13,r[2*a+1]=8191&o,o>>>=13;for(a=2*t;a>=26,t+=i/67108864|0,t+=o>>>26,this.words[r]=67108863&o}return 0!==t&&(this.words[r]=t,this.length++),this},o.prototype.muln=function(e){return this.clone().imuln(e)},o.prototype.sqr=function(){return this.mul(this)},o.prototype.isqr=function(){return this.imul(this.clone())},o.prototype.pow=function(e){var t=function(e){for(var t=new Array(e.bitLength()),r=0;r>>i}return t}(e);if(0===t.length)return new o(1);for(var r=this,n=0;n=0);var t,r=e%26,i=(e-r)/26,o=67108863>>>26-r<<26-r;if(0!==r){var a=0;for(t=0;t>>26-r}a&&(this.words[t]=a,this.length++)}if(0!==i){for(t=this.length-1;t>=0;t--)this.words[t+i]=this.words[t];for(t=0;t=0),i=t?(t-t%26)/26:0;var o=e%26,a=Math.min((e-o)/26,this.length),s=67108863^67108863>>>o<a)for(this.length-=a,c=0;c=0&&(0!==u||c>=i);c--){var d=0|this.words[c];this.words[c]=u<<26-o|d>>>o,u=d&s}return l&&0!==u&&(l.words[l.length++]=u),0===this.length&&(this.words[0]=0,this.length=1),this.strip()},o.prototype.ishrn=function(e,t,r){return n(0===this.negative),this.iushrn(e,t,r)},o.prototype.shln=function(e){return this.clone().ishln(e)},o.prototype.ushln=function(e){return this.clone().iushln(e)},o.prototype.shrn=function(e){return this.clone().ishrn(e)},o.prototype.ushrn=function(e){return this.clone().iushrn(e)},o.prototype.testn=function(e){n("number"===typeof e&&e>=0);var t=e%26,r=(e-t)/26,i=1<=0);var t=e%26,r=(e-t)/26;if(n(0===this.negative,"imaskn works only with positive numbers"),this.length<=r)return this;if(0!==t&&r++,this.length=Math.min(r,this.length),0!==t){var i=67108863^67108863>>>t<=67108864;t++)this.words[t]-=67108864,t===this.length-1?this.words[t+1]=1:this.words[t+1]++;return this.length=Math.max(this.length,t+1),this},o.prototype.isubn=function(e){if(n("number"===typeof e),n(e<67108864),e<0)return this.iaddn(-e);if(0!==this.negative)return this.negative=0,this.iaddn(e),this.negative=1,this;if(this.words[0]-=e,1===this.length&&this.words[0]<0)this.words[0]=-this.words[0],this.negative=1;else for(var t=0;t>26)-(l/67108864|0),this.words[i+r]=67108863&o}for(;i>26,this.words[i+r]=67108863&o;if(0===s)return this.strip();for(n(-1===s),s=0,i=0;i>26,this.words[i]=67108863&o;return this.negative=1,this.strip()},o.prototype._wordDiv=function(e,t){var r=(this.length,e.length),n=this.clone(),i=e,a=0|i.words[i.length-1];0!==(r=26-this._countBits(a))&&(i=i.ushln(r),n.iushln(r),a=0|i.words[i.length-1]);var s,l=n.length-i.length;if("mod"!==t){(s=new o(null)).length=l+1,s.words=new Array(s.length);for(var c=0;c=0;d--){var h=67108864*(0|n.words[i.length+d])+(0|n.words[i.length+d-1]);for(h=Math.min(h/a|0,67108863),n._ishlnsubmul(i,h,d);0!==n.negative;)h--,n.negative=0,n._ishlnsubmul(i,1,d),n.isZero()||(n.negative^=1);s&&(s.words[d]=h)}return s&&s.strip(),n.strip(),"div"!==t&&0!==r&&n.iushrn(r),{div:s||null,mod:n}},o.prototype.divmod=function(e,t,r){return n(!e.isZero()),this.isZero()?{div:new o(0),mod:new o(0)}:0!==this.negative&&0===e.negative?(s=this.neg().divmod(e,t),"mod"!==t&&(i=s.div.neg()),"div"!==t&&(a=s.mod.neg(),r&&0!==a.negative&&a.iadd(e)),{div:i,mod:a}):0===this.negative&&0!==e.negative?(s=this.divmod(e.neg(),t),"mod"!==t&&(i=s.div.neg()),{div:i,mod:s.mod}):0!==(this.negative&e.negative)?(s=this.neg().divmod(e.neg(),t),"div"!==t&&(a=s.mod.neg(),r&&0!==a.negative&&a.isub(e)),{div:s.div,mod:a}):e.length>this.length||this.cmp(e)<0?{div:new o(0),mod:this}:1===e.length?"div"===t?{div:this.divn(e.words[0]),mod:null}:"mod"===t?{div:null,mod:new o(this.modn(e.words[0]))}:{div:this.divn(e.words[0]),mod:new o(this.modn(e.words[0]))}:this._wordDiv(e,t);var i,a,s},o.prototype.div=function(e){return this.divmod(e,"div",!1).div},o.prototype.mod=function(e){return this.divmod(e,"mod",!1).mod},o.prototype.umod=function(e){return this.divmod(e,"mod",!0).mod},o.prototype.divRound=function(e){var t=this.divmod(e);if(t.mod.isZero())return t.div;var r=0!==t.div.negative?t.mod.isub(e):t.mod,n=e.ushrn(1),i=e.andln(1),o=r.cmp(n);return o<0||1===i&&0===o?t.div:0!==t.div.negative?t.div.isubn(1):t.div.iaddn(1)},o.prototype.modn=function(e){n(e<=67108863);for(var t=(1<<26)%e,r=0,i=this.length-1;i>=0;i--)r=(t*r+(0|this.words[i]))%e;return r},o.prototype.idivn=function(e){n(e<=67108863);for(var t=0,r=this.length-1;r>=0;r--){var i=(0|this.words[r])+67108864*t;this.words[r]=i/e|0,t=i%e}return this.strip()},o.prototype.divn=function(e){return this.clone().idivn(e)},o.prototype.egcd=function(e){n(0===e.negative),n(!e.isZero());var t=this,r=e.clone();t=0!==t.negative?t.umod(e):t.clone();for(var i=new o(1),a=new o(0),s=new o(0),l=new o(1),c=0;t.isEven()&&r.isEven();)t.iushrn(1),r.iushrn(1),++c;for(var u=r.clone(),d=t.clone();!t.isZero();){for(var h=0,p=1;0===(t.words[0]&p)&&h<26;++h,p<<=1);if(h>0)for(t.iushrn(h);h-- >0;)(i.isOdd()||a.isOdd())&&(i.iadd(u),a.isub(d)),i.iushrn(1),a.iushrn(1);for(var f=0,m=1;0===(r.words[0]&m)&&f<26;++f,m<<=1);if(f>0)for(r.iushrn(f);f-- >0;)(s.isOdd()||l.isOdd())&&(s.iadd(u),l.isub(d)),s.iushrn(1),l.iushrn(1);t.cmp(r)>=0?(t.isub(r),i.isub(s),a.isub(l)):(r.isub(t),s.isub(i),l.isub(a))}return{a:s,b:l,gcd:r.iushln(c)}},o.prototype._invmp=function(e){n(0===e.negative),n(!e.isZero());var t=this,r=e.clone();t=0!==t.negative?t.umod(e):t.clone();for(var i,a=new o(1),s=new o(0),l=r.clone();t.cmpn(1)>0&&r.cmpn(1)>0;){for(var c=0,u=1;0===(t.words[0]&u)&&c<26;++c,u<<=1);if(c>0)for(t.iushrn(c);c-- >0;)a.isOdd()&&a.iadd(l),a.iushrn(1);for(var d=0,h=1;0===(r.words[0]&h)&&d<26;++d,h<<=1);if(d>0)for(r.iushrn(d);d-- >0;)s.isOdd()&&s.iadd(l),s.iushrn(1);t.cmp(r)>=0?(t.isub(r),a.isub(s)):(r.isub(t),s.isub(a))}return(i=0===t.cmpn(1)?a:s).cmpn(0)<0&&i.iadd(e),i},o.prototype.gcd=function(e){if(this.isZero())return e.abs();if(e.isZero())return this.abs();var t=this.clone(),r=e.clone();t.negative=0,r.negative=0;for(var n=0;t.isEven()&&r.isEven();n++)t.iushrn(1),r.iushrn(1);for(;;){for(;t.isEven();)t.iushrn(1);for(;r.isEven();)r.iushrn(1);var i=t.cmp(r);if(i<0){var o=t;t=r,r=o}else if(0===i||0===r.cmpn(1))break;t.isub(r)}return r.iushln(n)},o.prototype.invm=function(e){return this.egcd(e).a.umod(e)},o.prototype.isEven=function(){return 0===(1&this.words[0])},o.prototype.isOdd=function(){return 1===(1&this.words[0])},o.prototype.andln=function(e){return this.words[0]&e},o.prototype.bincn=function(e){n("number"===typeof e);var t=e%26,r=(e-t)/26,i=1<>>26,s&=67108863,this.words[a]=s}return 0!==o&&(this.words[a]=o,this.length++),this},o.prototype.isZero=function(){return 1===this.length&&0===this.words[0]},o.prototype.cmpn=function(e){var t,r=e<0;if(0!==this.negative&&!r)return-1;if(0===this.negative&&r)return 1;if(this.strip(),this.length>1)t=1;else{r&&(e=-e),n(e<=67108863,"Number is too big");var i=0|this.words[0];t=i===e?0:ie.length)return 1;if(this.length=0;r--){var n=0|this.words[r],i=0|e.words[r];if(n!==i){ni&&(t=1);break}}return t},o.prototype.gtn=function(e){return 1===this.cmpn(e)},o.prototype.gt=function(e){return 1===this.cmp(e)},o.prototype.gten=function(e){return this.cmpn(e)>=0},o.prototype.gte=function(e){return this.cmp(e)>=0},o.prototype.ltn=function(e){return-1===this.cmpn(e)},o.prototype.lt=function(e){return-1===this.cmp(e)},o.prototype.lten=function(e){return this.cmpn(e)<=0},o.prototype.lte=function(e){return this.cmp(e)<=0},o.prototype.eqn=function(e){return 0===this.cmpn(e)},o.prototype.eq=function(e){return 0===this.cmp(e)},o.red=function(e){return new k(e)},o.prototype.toRed=function(e){return n(!this.red,"Already a number in reduction context"),n(0===this.negative,"red works only with positives"),e.convertTo(this)._forceRed(e)},o.prototype.fromRed=function(){return n(this.red,"fromRed works only with numbers in reduction context"),this.red.convertFrom(this)},o.prototype._forceRed=function(e){return this.red=e,this},o.prototype.forceRed=function(e){return n(!this.red,"Already a number in reduction context"),this._forceRed(e)},o.prototype.redAdd=function(e){return n(this.red,"redAdd works only with red numbers"),this.red.add(this,e)},o.prototype.redIAdd=function(e){return n(this.red,"redIAdd works only with red numbers"),this.red.iadd(this,e)},o.prototype.redSub=function(e){return n(this.red,"redSub works only with red numbers"),this.red.sub(this,e)},o.prototype.redISub=function(e){return n(this.red,"redISub works only with red numbers"),this.red.isub(this,e)},o.prototype.redShl=function(e){return n(this.red,"redShl works only with red numbers"),this.red.shl(this,e)},o.prototype.redMul=function(e){return n(this.red,"redMul works only with red numbers"),this.red._verify2(this,e),this.red.mul(this,e)},o.prototype.redIMul=function(e){return n(this.red,"redMul works only with red numbers"),this.red._verify2(this,e),this.red.imul(this,e)},o.prototype.redSqr=function(){return n(this.red,"redSqr works only with red numbers"),this.red._verify1(this),this.red.sqr(this)},o.prototype.redISqr=function(){return n(this.red,"redISqr works only with red numbers"),this.red._verify1(this),this.red.isqr(this)},o.prototype.redSqrt=function(){return n(this.red,"redSqrt works only with red numbers"),this.red._verify1(this),this.red.sqrt(this)},o.prototype.redInvm=function(){return n(this.red,"redInvm works only with red numbers"),this.red._verify1(this),this.red.invm(this)},o.prototype.redNeg=function(){return n(this.red,"redNeg works only with red numbers"),this.red._verify1(this),this.red.neg(this)},o.prototype.redPow=function(e){return n(this.red&&!e.red,"redPow(normalNum)"),this.red._verify1(this),this.red.pow(this,e)};var y={k256:null,p224:null,p192:null,p25519:null};function v(e,t){this.name=e,this.p=new o(t,16),this.n=this.p.bitLength(),this.k=new o(1).iushln(this.n).isub(this.p),this.tmp=this._tmp()}function x(){v.call(this,"k256","ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f")}function b(){v.call(this,"p224","ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001")}function _(){v.call(this,"p192","ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff")}function w(){v.call(this,"25519","7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed")}function k(e){if("string"===typeof e){var t=o._prime(e);this.m=t.p,this.prime=t}else n(e.gtn(1),"modulus must be greater than 1"),this.m=e,this.prime=null}function S(e){k.call(this,e),this.shift=this.m.bitLength(),this.shift%26!==0&&(this.shift+=26-this.shift%26),this.r=new o(1).iushln(this.shift),this.r2=this.imod(this.r.sqr()),this.rinv=this.r._invmp(this.m),this.minv=this.rinv.mul(this.r).isubn(1).div(this.m),this.minv=this.minv.umod(this.r),this.minv=this.r.sub(this.minv)}v.prototype._tmp=function(){var e=new o(null);return e.words=new Array(Math.ceil(this.n/13)),e},v.prototype.ireduce=function(e){var t,r=e;do{this.split(r,this.tmp),t=(r=(r=this.imulK(r)).iadd(this.tmp)).bitLength()}while(t>this.n);var n=t0?r.isub(this.p):void 0!==r.strip?r.strip():r._strip(),r},v.prototype.split=function(e,t){e.iushrn(this.n,0,t)},v.prototype.imulK=function(e){return e.imul(this.k)},i(x,v),x.prototype.split=function(e,t){for(var r=4194303,n=Math.min(e.length,9),i=0;i>>22,o=a}o>>>=22,e.words[i-10]=o,0===o&&e.length>10?e.length-=10:e.length-=9},x.prototype.imulK=function(e){e.words[e.length]=0,e.words[e.length+1]=0,e.length+=2;for(var t=0,r=0;r>>=26,e.words[r]=i,t=n}return 0!==t&&(e.words[e.length++]=t),e},o._prime=function(e){if(y[e])return y[e];var t;if("k256"===e)t=new x;else if("p224"===e)t=new b;else if("p192"===e)t=new _;else{if("p25519"!==e)throw new Error("Unknown prime "+e);t=new w}return y[e]=t,t},k.prototype._verify1=function(e){n(0===e.negative,"red works only with positives"),n(e.red,"red works only with red numbers")},k.prototype._verify2=function(e,t){n(0===(e.negative|t.negative),"red works only with positives"),n(e.red&&e.red===t.red,"red works only with red numbers")},k.prototype.imod=function(e){return this.prime?this.prime.ireduce(e)._forceRed(this):e.umod(this.m)._forceRed(this)},k.prototype.neg=function(e){return e.isZero()?e.clone():this.m.sub(e)._forceRed(this)},k.prototype.add=function(e,t){this._verify2(e,t);var r=e.add(t);return r.cmp(this.m)>=0&&r.isub(this.m),r._forceRed(this)},k.prototype.iadd=function(e,t){this._verify2(e,t);var r=e.iadd(t);return r.cmp(this.m)>=0&&r.isub(this.m),r},k.prototype.sub=function(e,t){this._verify2(e,t);var r=e.sub(t);return r.cmpn(0)<0&&r.iadd(this.m),r._forceRed(this)},k.prototype.isub=function(e,t){this._verify2(e,t);var r=e.isub(t);return r.cmpn(0)<0&&r.iadd(this.m),r},k.prototype.shl=function(e,t){return this._verify1(e),this.imod(e.ushln(t))},k.prototype.imul=function(e,t){return this._verify2(e,t),this.imod(e.imul(t))},k.prototype.mul=function(e,t){return this._verify2(e,t),this.imod(e.mul(t))},k.prototype.isqr=function(e){return this.imul(e,e.clone())},k.prototype.sqr=function(e){return this.mul(e,e)},k.prototype.sqrt=function(e){if(e.isZero())return e.clone();var t=this.m.andln(3);if(n(t%2===1),3===t){var r=this.m.add(new o(1)).iushrn(2);return this.pow(e,r)}for(var i=this.m.subn(1),a=0;!i.isZero()&&0===i.andln(1);)a++,i.iushrn(1);n(!i.isZero());var s=new o(1).toRed(this),l=s.redNeg(),c=this.m.subn(1).iushrn(1),u=this.m.bitLength();for(u=new o(2*u*u).toRed(this);0!==this.pow(u,c).cmp(l);)u.redIAdd(l);for(var d=this.pow(u,i),h=this.pow(e,i.addn(1).iushrn(1)),p=this.pow(e,i),f=a;0!==p.cmp(s);){for(var m=p,g=0;0!==m.cmp(s);g++)m=m.redSqr();n(g=0;n--){for(var c=t.words[n],u=l-1;u>=0;u--){var d=c>>u&1;i!==r[0]&&(i=this.sqr(i)),0!==d||0!==a?(a<<=1,a|=d,(4===++s||0===n&&0===u)&&(i=this.mul(i,r[a]),s=0,a=0)):s=0}l=26}return i},k.prototype.convertTo=function(e){var t=e.umod(this.m);return t===e?t.clone():t},k.prototype.convertFrom=function(e){var t=e.clone();return t.red=null,t},o.mont=function(e){return new S(e)},i(S,k),S.prototype.convertTo=function(e){return this.imod(e.ushln(this.shift))},S.prototype.convertFrom=function(e){var t=this.imod(e.mul(this.rinv));return t.red=null,t},S.prototype.imul=function(e,t){if(e.isZero()||t.isZero())return e.words[0]=0,e.length=1,e;var r=e.imul(t),n=r.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),i=r.isub(n).iushrn(this.shift),o=i;return i.cmp(this.m)>=0?o=i.isub(this.m):i.cmpn(0)<0&&(o=i.iadd(this.m)),o._forceRed(this)},S.prototype.mul=function(e,t){if(e.isZero()||t.isZero())return new o(0)._forceRed(this);var r=e.mul(t),n=r.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),i=r.isub(n).iushrn(this.shift),a=i;return i.cmp(this.m)>=0?a=i.isub(this.m):i.cmpn(0)<0&&(a=i.iadd(this.m)),a._forceRed(this)},S.prototype.invm=function(e){return this.imod(e._invmp(this.m).mul(this.r2))._forceRed(this)}}(e=r.nmd(e),this)},6204:function(e){"use strict";e.exports=function(e){var t,r,n,i=e.length,o=0;for(t=0;t>>1;if(!(u<=0)){var d,h=i.mallocDouble(2*u*s),p=i.mallocInt32(s);if((s=l(e,u,h,p))>0){if(1===u&&n)o.init(s),d=o.sweepComplete(u,r,0,s,h,p,0,s,h,p);else{var f=i.mallocDouble(2*u*c),m=i.mallocInt32(c);(c=l(t,u,f,m))>0&&(o.init(s+c),d=1===u?o.sweepBipartite(u,r,0,s,h,p,0,c,f,m):a(u,r,n,s,h,p,c,f,m),i.free(f),i.free(m))}i.free(h),i.free(p)}return d}}}function u(e,t){n.push([e,t])}},2455:function(e,t){"use strict";function r(e){return e?function(e,t,r,n,i,o,a,s,l,c,u){return i-n>l-s?function(e,t,r,n,i,o,a,s,l,c,u){for(var d=2*e,h=n,p=d*n;hc-l?n?function(e,t,r,n,i,o,a,s,l,c,u){for(var d=2*e,h=n,p=d*n;h0;){var L=(O-=1)*b,D=w[L],z=w[L+1],j=w[L+2],F=w[L+3],N=w[L+4],B=w[L+5],V=O*_,U=k[V],H=k[V+1],$=1&B,W=!!(16&B),q=u,G=M,Y=E,X=I;if($&&(q=E,G=I,Y=u,X=M),!(2&B&&z>=(j=g(e,D,z,j,q,G,H)))&&!(4&B&&(z=y(e,D,z,j,q,G,U))>=j)){var Z=j-z,K=N-F;if(W){if(e*Z*(Z+K)=p0)&&!(p1>=hi)"),m=u("lo===p0"),g=u("lo>>1,h=2*e,p=d,f=s[h*d+t];for(;c=x?(p=v,f=x):y>=_?(p=g,f=y):(p=b,f=_):x>=_?(p=v,f=x):_>=y?(p=g,f=y):(p=b,f=_);for(var w=h*(u-1),k=h*p,S=0;Sr&&i[d+t]>c;--u,d-=a){for(var h=d,p=d+a,f=0;fh;++h,l+=s){if(i[l+d]===a)if(u===h)u+=1,c+=s;else{for(var p=0;s>p;++p){var f=i[l+p];i[l+p]=i[c],i[c++]=f}var m=o[h];o[h]=o[u],o[u++]=m}}return u},"loh;++h,l+=s){if(i[l+d]p;++p){var f=i[l+p];i[l+p]=i[c],i[c++]=f}var m=o[h];o[h]=o[u],o[u++]=m}}return u},"lo<=p0":function(e,t,r,n,i,o,a){for(var s=2*e,l=s*r,c=l,u=r,d=e+t,h=r;n>h;++h,l+=s){if(i[l+d]<=a)if(u===h)u+=1,c+=s;else{for(var p=0;s>p;++p){var f=i[l+p];i[l+p]=i[c],i[c++]=f}var m=o[h];o[h]=o[u],o[u++]=m}}return u},"hi<=p0":function(e,t,r,n,i,o,a){for(var s=2*e,l=s*r,c=l,u=r,d=e+t,h=r;n>h;++h,l+=s){if(i[l+d]<=a)if(u===h)u+=1,c+=s;else{for(var p=0;s>p;++p){var f=i[l+p];i[l+p]=i[c],i[c++]=f}var m=o[h];o[h]=o[u],o[u++]=m}}return u},"lop;++p,l+=s){var f=i[l+d],m=i[l+h];if(fg;++g){var y=i[l+g];i[l+g]=i[c],i[c++]=y}var v=o[p];o[p]=o[u],o[u++]=v}}return u},"lo<=p0&&p0<=hi":function(e,t,r,n,i,o,a){for(var s=2*e,l=s*r,c=l,u=r,d=t,h=e+t,p=r;n>p;++p,l+=s){var f=i[l+d],m=i[l+h];if(f<=a&&a<=m)if(u===p)u+=1,c+=s;else{for(var g=0;s>g;++g){var y=i[l+g];i[l+g]=i[c],i[c++]=y}var v=o[p];o[p]=o[u],o[u++]=v}}return u},"!(lo>=p0)&&!(p1>=hi)":function(e,t,r,n,i,o,a,s){for(var l=2*e,c=l*r,u=c,d=r,h=t,p=e+t,f=r;n>f;++f,c+=l){var m=i[c+h],g=i[c+p];if(!(m>=a)&&!(s>=g))if(d===f)d+=1,u+=l;else{for(var y=0;l>y;++y){var v=i[c+y];i[c+y]=i[u],i[u++]=v}var x=o[f];o[f]=o[d],o[d++]=x}}return d}}},1811:function(e){"use strict";e.exports=function(e,n){n<=4*t?r(0,n-1,e):c(0,n-1,e)};var t=32;function r(e,t,r){for(var n=2*(e+1),i=e+1;i<=t;++i){for(var o=r[n++],a=r[n++],s=i,l=n-2;s-- >e;){var c=r[l-2],u=r[l-1];if(cr[t+1])}function l(e,t,r,n){var i=n[e*=2];return i>1,g=m-h,y=m+h,v=p,x=g,b=m,_=y,w=f,k=e+1,S=u-1,A=0;s(v,x,d)&&(A=v,v=x,x=A),s(_,w,d)&&(A=_,_=w,w=A),s(v,b,d)&&(A=v,v=b,b=A),s(x,b,d)&&(A=x,x=b,b=A),s(v,_,d)&&(A=v,v=_,_=A),s(b,_,d)&&(A=b,b=_,_=A),s(x,w,d)&&(A=x,x=w,w=A),s(x,b,d)&&(A=x,x=b,b=A),s(_,w,d)&&(A=_,_=w,w=A);for(var T=d[2*x],M=d[2*x+1],C=d[2*_],E=d[2*_+1],I=2*v,P=2*b,O=2*w,R=2*p,L=2*m,D=2*f,z=0;z<2;++z){var j=d[I+z],F=d[P+z],N=d[O+z];d[R+z]=j,d[L+z]=F,d[D+z]=N}i(g,e,d),i(y,u,d);for(var B=k;B<=S;++B)if(l(B,T,M,d))B!==k&&n(B,k,d),++k;else if(!l(B,C,E,d))for(;;){if(l(S,C,E,d)){l(S,T,M,d)?(o(B,k,S,d),++k,--S):(n(B,S,d),--S);break}if(--S>>1;o(f,M);var C=0,E=0;for(k=0;k=a)m(u,d,E--,I=I-a|0);else if(I>=0)m(l,c,C--,I);else if(I<=-a){I=-I-a|0;for(var P=0;P>>1;o(f,C);var E=0,I=0,P=0;for(S=0;S>1===f[2*S+3]>>1&&(R=2,S+=1),O<0){for(var L=-(O>>1)-1,D=0;D>1)-1;0===R?m(l,c,E--,L):1===R?m(u,d,I--,L):2===R&&m(h,p,P--,L)}}},scanBipartite:function(e,t,r,n,i,s,u,d,h,p,y,v){var x=0,b=2*e,_=t,w=t+e,k=1,S=1;n?S=a:k=a;for(var A=i;A>>1;o(f,E);var I=0;for(A=0;A=a?(O=!n,T-=a):(O=!!n,T-=1),O)g(l,c,I++,T);else{var R=v[T],L=b*T,D=y[L+t+1],z=y[L+t+1+e];e:for(var j=0;j>>1;o(f,k);var S=0;for(x=0;x=a)l[S++]=b-a;else{var T=p[b-=1],M=g*b,C=h[M+t+1],E=h[M+t+1+e];e:for(var I=0;I=0;--I)if(l[I]===b){for(L=I+1;L0;){for(var p=r.pop(),f=(u=-1,d=-1,l=a[s=r.pop()],1);f=0||(t.flip(s,p),i(e,t,r,u,s,d),i(e,t,r,s,d,u),i(e,t,r,d,p,u),i(e,t,r,p,u,d)))}}},5023:function(e,t,r){"use strict";var n=r(2478);function i(e,t,r,n,i,o,a){this.cells=e,this.neighbor=t,this.flags=n,this.constraint=r,this.active=i,this.next=o,this.boundary=a}function o(e,t){return e[0]-t[0]||e[1]-t[1]||e[2]-t[2]}e.exports=function(e,t,r){var n=function(e,t){for(var r=e.cells(),n=r.length,a=0;a0||l.length>0;){for(;s.length>0;){var p=s.pop();if(c[p]!==-a){c[p]=a;u[p];for(var f=0;f<3;++f){var m=h[3*p+f];m>=0&&0===c[m]&&(d[3*p+f]?l.push(m):(s.push(m),c[m]=a))}}}var g=l;l=s,s=g,l.length=0,a=-a}var y=function(e,t,r){for(var n=0,i=0;i1&&i(r[h[p-2]],r[h[p-1]],o)>0;)e.push([h[p-1],h[p-2],a]),p-=1;h.length=p,h.push(a);var f=d.upperIds;for(p=f.length;p>1&&i(r[f[p-2]],r[f[p-1]],o)<0;)e.push([f[p-2],f[p-1],a]),p-=1;f.length=p,f.push(a)}}function u(e,t){var r;return(r=e.a[0]f[0]&&i.push(new a(f,p,2,l),new a(p,f,1,l))}i.sort(s);for(var m=i[0].a[0]-(1+Math.abs(i[0].a[0]))*Math.pow(2,-52),g=[new o([m,1],[m,0],-1,[],[],[],[])],y=[],v=(l=0,i.length);l=0}}(),o.removeTriangle=function(e,t,r){var n=this.stars;a(n[e],t,r),a(n[t],r,e),a(n[r],e,t)},o.addTriangle=function(e,t,r){var n=this.stars;n[e].push(t,r),n[t].push(r,e),n[r].push(e,t)},o.opposite=function(e,t){for(var r=this.stars[t],n=1,i=r.length;nt[2]?1:0)}function y(e,t,r){if(0!==e.length){if(t)for(var n=0;n=0;--o){var x=t[u=(M=n[o])[0]],b=x[0],_=x[1],w=e[b],k=e[_];if((w[0]-k[0]||w[1]-k[1])<0){var S=b;b=_,_=S}x[0]=b;var A,T=x[1]=M[1];for(i&&(A=x[2]);o>0&&n[o-1][0]===u;){var M,C=(M=n[--o])[1];i?t.push([T,C,A]):t.push([T,C]),T=C}i?t.push([T,_,A]):t.push([T,_])}return h}(e,t,h,g,r),x=f(e,v);return y(t,x,r),!!x||(h.length>0||g.length>0)}},3637:function(e,t,r){"use strict";e.exports=function(e,t,r,n){var o=s(t,e),d=s(n,r),h=u(o,d);if(0===a(h))return null;var p=s(e,r),f=u(d,p),m=i(f,h),g=c(o,m);return l(e,g)};var n=r(6504),i=r(8697),o=r(5572),a=r(7721),s=r(544),l=r(2653),c=r(8987);function u(e,t){return o(n(e[0],t[1]),n(e[1],t[0]))}},3642:function(e){e.exports={jet:[{index:0,rgb:[0,0,131]},{index:.125,rgb:[0,60,170]},{index:.375,rgb:[5,255,255]},{index:.625,rgb:[255,255,0]},{index:.875,rgb:[250,0,0]},{index:1,rgb:[128,0,0]}],hsv:[{index:0,rgb:[255,0,0]},{index:.169,rgb:[253,255,2]},{index:.173,rgb:[247,255,2]},{index:.337,rgb:[0,252,4]},{index:.341,rgb:[0,252,10]},{index:.506,rgb:[1,249,255]},{index:.671,rgb:[2,0,253]},{index:.675,rgb:[8,0,253]},{index:.839,rgb:[255,0,251]},{index:.843,rgb:[255,0,245]},{index:1,rgb:[255,0,6]}],hot:[{index:0,rgb:[0,0,0]},{index:.3,rgb:[230,0,0]},{index:.6,rgb:[255,210,0]},{index:1,rgb:[255,255,255]}],spring:[{index:0,rgb:[255,0,255]},{index:1,rgb:[255,255,0]}],summer:[{index:0,rgb:[0,128,102]},{index:1,rgb:[255,255,102]}],autumn:[{index:0,rgb:[255,0,0]},{index:1,rgb:[255,255,0]}],winter:[{index:0,rgb:[0,0,255]},{index:1,rgb:[0,255,128]}],bone:[{index:0,rgb:[0,0,0]},{index:.376,rgb:[84,84,116]},{index:.753,rgb:[169,200,200]},{index:1,rgb:[255,255,255]}],copper:[{index:0,rgb:[0,0,0]},{index:.804,rgb:[255,160,102]},{index:1,rgb:[255,199,127]}],greys:[{index:0,rgb:[0,0,0]},{index:1,rgb:[255,255,255]}],yignbu:[{index:0,rgb:[8,29,88]},{index:.125,rgb:[37,52,148]},{index:.25,rgb:[34,94,168]},{index:.375,rgb:[29,145,192]},{index:.5,rgb:[65,182,196]},{index:.625,rgb:[127,205,187]},{index:.75,rgb:[199,233,180]},{index:.875,rgb:[237,248,217]},{index:1,rgb:[255,255,217]}],greens:[{index:0,rgb:[0,68,27]},{index:.125,rgb:[0,109,44]},{index:.25,rgb:[35,139,69]},{index:.375,rgb:[65,171,93]},{index:.5,rgb:[116,196,118]},{index:.625,rgb:[161,217,155]},{index:.75,rgb:[199,233,192]},{index:.875,rgb:[229,245,224]},{index:1,rgb:[247,252,245]}],yiorrd:[{index:0,rgb:[128,0,38]},{index:.125,rgb:[189,0,38]},{index:.25,rgb:[227,26,28]},{index:.375,rgb:[252,78,42]},{index:.5,rgb:[253,141,60]},{index:.625,rgb:[254,178,76]},{index:.75,rgb:[254,217,118]},{index:.875,rgb:[255,237,160]},{index:1,rgb:[255,255,204]}],bluered:[{index:0,rgb:[0,0,255]},{index:1,rgb:[255,0,0]}],rdbu:[{index:0,rgb:[5,10,172]},{index:.35,rgb:[106,137,247]},{index:.5,rgb:[190,190,190]},{index:.6,rgb:[220,170,132]},{index:.7,rgb:[230,145,90]},{index:1,rgb:[178,10,28]}],picnic:[{index:0,rgb:[0,0,255]},{index:.1,rgb:[51,153,255]},{index:.2,rgb:[102,204,255]},{index:.3,rgb:[153,204,255]},{index:.4,rgb:[204,204,255]},{index:.5,rgb:[255,255,255]},{index:.6,rgb:[255,204,255]},{index:.7,rgb:[255,153,255]},{index:.8,rgb:[255,102,204]},{index:.9,rgb:[255,102,102]},{index:1,rgb:[255,0,0]}],rainbow:[{index:0,rgb:[150,0,90]},{index:.125,rgb:[0,0,200]},{index:.25,rgb:[0,25,255]},{index:.375,rgb:[0,152,255]},{index:.5,rgb:[44,255,150]},{index:.625,rgb:[151,255,0]},{index:.75,rgb:[255,234,0]},{index:.875,rgb:[255,111,0]},{index:1,rgb:[255,0,0]}],portland:[{index:0,rgb:[12,51,131]},{index:.25,rgb:[10,136,186]},{index:.5,rgb:[242,211,56]},{index:.75,rgb:[242,143,56]},{index:1,rgb:[217,30,30]}],blackbody:[{index:0,rgb:[0,0,0]},{index:.2,rgb:[230,0,0]},{index:.4,rgb:[230,210,0]},{index:.7,rgb:[255,255,255]},{index:1,rgb:[160,200,255]}],earth:[{index:0,rgb:[0,0,130]},{index:.1,rgb:[0,180,180]},{index:.2,rgb:[40,210,40]},{index:.4,rgb:[230,230,50]},{index:.6,rgb:[120,70,20]},{index:1,rgb:[255,255,255]}],electric:[{index:0,rgb:[0,0,0]},{index:.15,rgb:[30,0,100]},{index:.4,rgb:[120,0,100]},{index:.6,rgb:[160,90,0]},{index:.8,rgb:[230,200,0]},{index:1,rgb:[255,250,220]}],alpha:[{index:0,rgb:[255,255,255,0]},{index:1,rgb:[255,255,255,1]}],viridis:[{index:0,rgb:[68,1,84]},{index:.13,rgb:[71,44,122]},{index:.25,rgb:[59,81,139]},{index:.38,rgb:[44,113,142]},{index:.5,rgb:[33,144,141]},{index:.63,rgb:[39,173,129]},{index:.75,rgb:[92,200,99]},{index:.88,rgb:[170,220,50]},{index:1,rgb:[253,231,37]}],inferno:[{index:0,rgb:[0,0,4]},{index:.13,rgb:[31,12,72]},{index:.25,rgb:[85,15,109]},{index:.38,rgb:[136,34,106]},{index:.5,rgb:[186,54,85]},{index:.63,rgb:[227,89,51]},{index:.75,rgb:[249,140,10]},{index:.88,rgb:[249,201,50]},{index:1,rgb:[252,255,164]}],magma:[{index:0,rgb:[0,0,4]},{index:.13,rgb:[28,16,68]},{index:.25,rgb:[79,18,123]},{index:.38,rgb:[129,37,129]},{index:.5,rgb:[181,54,122]},{index:.63,rgb:[229,80,100]},{index:.75,rgb:[251,135,97]},{index:.88,rgb:[254,194,135]},{index:1,rgb:[252,253,191]}],plasma:[{index:0,rgb:[13,8,135]},{index:.13,rgb:[75,3,161]},{index:.25,rgb:[125,3,168]},{index:.38,rgb:[168,34,150]},{index:.5,rgb:[203,70,121]},{index:.63,rgb:[229,107,93]},{index:.75,rgb:[248,148,65]},{index:.88,rgb:[253,195,40]},{index:1,rgb:[240,249,33]}],warm:[{index:0,rgb:[125,0,179]},{index:.13,rgb:[172,0,187]},{index:.25,rgb:[219,0,170]},{index:.38,rgb:[255,0,130]},{index:.5,rgb:[255,63,74]},{index:.63,rgb:[255,123,0]},{index:.75,rgb:[234,176,0]},{index:.88,rgb:[190,228,0]},{index:1,rgb:[147,255,0]}],cool:[{index:0,rgb:[125,0,179]},{index:.13,rgb:[116,0,218]},{index:.25,rgb:[98,74,237]},{index:.38,rgb:[68,146,231]},{index:.5,rgb:[0,204,197]},{index:.63,rgb:[0,247,146]},{index:.75,rgb:[0,255,88]},{index:.88,rgb:[40,255,8]},{index:1,rgb:[147,255,0]}],"rainbow-soft":[{index:0,rgb:[125,0,179]},{index:.1,rgb:[199,0,180]},{index:.2,rgb:[255,0,121]},{index:.3,rgb:[255,108,0]},{index:.4,rgb:[222,194,0]},{index:.5,rgb:[150,255,0]},{index:.6,rgb:[0,255,55]},{index:.7,rgb:[0,246,150]},{index:.8,rgb:[50,167,222]},{index:.9,rgb:[103,51,235]},{index:1,rgb:[124,0,186]}],bathymetry:[{index:0,rgb:[40,26,44]},{index:.13,rgb:[59,49,90]},{index:.25,rgb:[64,76,139]},{index:.38,rgb:[63,110,151]},{index:.5,rgb:[72,142,158]},{index:.63,rgb:[85,174,163]},{index:.75,rgb:[120,206,163]},{index:.88,rgb:[187,230,172]},{index:1,rgb:[253,254,204]}],cdom:[{index:0,rgb:[47,15,62]},{index:.13,rgb:[87,23,86]},{index:.25,rgb:[130,28,99]},{index:.38,rgb:[171,41,96]},{index:.5,rgb:[206,67,86]},{index:.63,rgb:[230,106,84]},{index:.75,rgb:[242,149,103]},{index:.88,rgb:[249,193,135]},{index:1,rgb:[254,237,176]}],chlorophyll:[{index:0,rgb:[18,36,20]},{index:.13,rgb:[25,63,41]},{index:.25,rgb:[24,91,59]},{index:.38,rgb:[13,119,72]},{index:.5,rgb:[18,148,80]},{index:.63,rgb:[80,173,89]},{index:.75,rgb:[132,196,122]},{index:.88,rgb:[175,221,162]},{index:1,rgb:[215,249,208]}],density:[{index:0,rgb:[54,14,36]},{index:.13,rgb:[89,23,80]},{index:.25,rgb:[110,45,132]},{index:.38,rgb:[120,77,178]},{index:.5,rgb:[120,113,213]},{index:.63,rgb:[115,151,228]},{index:.75,rgb:[134,185,227]},{index:.88,rgb:[177,214,227]},{index:1,rgb:[230,241,241]}],"freesurface-blue":[{index:0,rgb:[30,4,110]},{index:.13,rgb:[47,14,176]},{index:.25,rgb:[41,45,236]},{index:.38,rgb:[25,99,212]},{index:.5,rgb:[68,131,200]},{index:.63,rgb:[114,156,197]},{index:.75,rgb:[157,181,203]},{index:.88,rgb:[200,208,216]},{index:1,rgb:[241,237,236]}],"freesurface-red":[{index:0,rgb:[60,9,18]},{index:.13,rgb:[100,17,27]},{index:.25,rgb:[142,20,29]},{index:.38,rgb:[177,43,27]},{index:.5,rgb:[192,87,63]},{index:.63,rgb:[205,125,105]},{index:.75,rgb:[216,162,148]},{index:.88,rgb:[227,199,193]},{index:1,rgb:[241,237,236]}],oxygen:[{index:0,rgb:[64,5,5]},{index:.13,rgb:[106,6,15]},{index:.25,rgb:[144,26,7]},{index:.38,rgb:[168,64,3]},{index:.5,rgb:[188,100,4]},{index:.63,rgb:[206,136,11]},{index:.75,rgb:[220,174,25]},{index:.88,rgb:[231,215,44]},{index:1,rgb:[248,254,105]}],par:[{index:0,rgb:[51,20,24]},{index:.13,rgb:[90,32,35]},{index:.25,rgb:[129,44,34]},{index:.38,rgb:[159,68,25]},{index:.5,rgb:[182,99,19]},{index:.63,rgb:[199,134,22]},{index:.75,rgb:[212,171,35]},{index:.88,rgb:[221,210,54]},{index:1,rgb:[225,253,75]}],phase:[{index:0,rgb:[145,105,18]},{index:.13,rgb:[184,71,38]},{index:.25,rgb:[186,58,115]},{index:.38,rgb:[160,71,185]},{index:.5,rgb:[110,97,218]},{index:.63,rgb:[50,123,164]},{index:.75,rgb:[31,131,110]},{index:.88,rgb:[77,129,34]},{index:1,rgb:[145,105,18]}],salinity:[{index:0,rgb:[42,24,108]},{index:.13,rgb:[33,50,162]},{index:.25,rgb:[15,90,145]},{index:.38,rgb:[40,118,137]},{index:.5,rgb:[59,146,135]},{index:.63,rgb:[79,175,126]},{index:.75,rgb:[120,203,104]},{index:.88,rgb:[193,221,100]},{index:1,rgb:[253,239,154]}],temperature:[{index:0,rgb:[4,35,51]},{index:.13,rgb:[23,51,122]},{index:.25,rgb:[85,59,157]},{index:.38,rgb:[129,79,143]},{index:.5,rgb:[175,95,130]},{index:.63,rgb:[222,112,101]},{index:.75,rgb:[249,146,66]},{index:.88,rgb:[249,196,65]},{index:1,rgb:[232,250,91]}],turbidity:[{index:0,rgb:[34,31,27]},{index:.13,rgb:[65,50,41]},{index:.25,rgb:[98,69,52]},{index:.38,rgb:[131,89,57]},{index:.5,rgb:[161,112,59]},{index:.63,rgb:[185,140,66]},{index:.75,rgb:[202,174,88]},{index:.88,rgb:[216,209,126]},{index:1,rgb:[233,246,171]}],"velocity-blue":[{index:0,rgb:[17,32,64]},{index:.13,rgb:[35,52,116]},{index:.25,rgb:[29,81,156]},{index:.38,rgb:[31,113,162]},{index:.5,rgb:[50,144,169]},{index:.63,rgb:[87,173,176]},{index:.75,rgb:[149,196,189]},{index:.88,rgb:[203,221,211]},{index:1,rgb:[254,251,230]}],"velocity-green":[{index:0,rgb:[23,35,19]},{index:.13,rgb:[24,64,38]},{index:.25,rgb:[11,95,45]},{index:.38,rgb:[39,123,35]},{index:.5,rgb:[95,146,12]},{index:.63,rgb:[152,165,18]},{index:.75,rgb:[201,186,69]},{index:.88,rgb:[233,216,137]},{index:1,rgb:[255,253,205]}],cubehelix:[{index:0,rgb:[0,0,0]},{index:.07,rgb:[22,5,59]},{index:.13,rgb:[60,4,105]},{index:.2,rgb:[109,1,135]},{index:.27,rgb:[161,0,147]},{index:.33,rgb:[210,2,142]},{index:.4,rgb:[251,11,123]},{index:.47,rgb:[255,29,97]},{index:.53,rgb:[255,54,69]},{index:.6,rgb:[255,85,46]},{index:.67,rgb:[255,120,34]},{index:.73,rgb:[255,157,37]},{index:.8,rgb:[241,191,57]},{index:.87,rgb:[224,220,93]},{index:.93,rgb:[218,241,142]},{index:1,rgb:[227,253,198]}]}},6729:function(e,t,r){"use strict";var n=r(3642),i=r(395);function o(e){return[e[0]/255,e[1]/255,e[2]/255,e[3]]}function a(e){for(var t,r="#",n=0;n<3;++n)r+=("00"+(t=(t=e[n]).toString(16))).substr(t.length);return r}function s(e){return"rgba("+e.join(",")+")"}e.exports=function(e){var t,r,l,c,u,d,h,p,f,m;e||(e={});p=(e.nshades||72)-1,h=e.format||"hex",(d=e.colormap)||(d="jet");if("string"===typeof d){if(d=d.toLowerCase(),!n[d])throw Error(d+" not a supported colorscale");u=n[d]}else{if(!Array.isArray(d))throw Error("unsupported colormap option",d);u=d.slice()}if(u.length>p+1)throw new Error(d+" map requires nshades to be at least size "+u.length);f=Array.isArray(e.alpha)?2!==e.alpha.length?[1,1]:e.alpha.slice():"number"===typeof e.alpha?[e.alpha,e.alpha]:[1,1];t=u.map((function(e){return Math.round(e.index*p)})),f[0]=Math.min(Math.max(f[0],0),1),f[1]=Math.min(Math.max(f[1],0),1);var g=u.map((function(e,t){var r=u[t].index,n=u[t].rgb.slice();return 4===n.length&&n[3]>=0&&n[3]<=1||(n[3]=f[0]+(f[1]-f[0])*r),n})),y=[];for(m=0;m0||l(e,t,o)?-1:1:0===s?c>0||l(e,t,r)?1:-1:i(c-s)}var d=n(e,t,r);return d>0?a>0&&n(e,t,o)>0?1:-1:d<0?a>0||n(e,t,o)>0?1:-1:n(e,t,o)>0||l(e,t,r)?1:-1};var n=r(3250),i=r(8572),o=r(9362),a=r(5382),s=r(8210);function l(e,t,r){var n=o(e[0],-t[0]),i=o(e[1],-t[1]),l=o(r[0],-t[0]),c=o(r[1],-t[1]),u=s(a(n,l),a(i,c));return u[u.length-1]>=0}},8572:function(e){"use strict";e.exports=function(e){return e<0?-1:e>0?1:0}},8507:function(e){e.exports=function(e,n){var i=e.length,o=e.length-n.length;if(o)return o;switch(i){case 0:return 0;case 1:return e[0]-n[0];case 2:return e[0]+e[1]-n[0]-n[1]||t(e[0],e[1])-t(n[0],n[1]);case 3:var a=e[0]+e[1],s=n[0]+n[1];if(o=a+e[2]-(s+n[2]))return o;var l=t(e[0],e[1]),c=t(n[0],n[1]);return t(l,e[2])-t(c,n[2])||t(l+e[2],a)-t(c+n[2],s);case 4:var u=e[0],d=e[1],h=e[2],p=e[3],f=n[0],m=n[1],g=n[2],y=n[3];return u+d+h+p-(f+m+g+y)||t(u,d,h,p)-t(f,m,g,y,f)||t(u+d,u+h,u+p,d+h,d+p,h+p)-t(f+m,f+g,f+y,m+g,m+y,g+y)||t(u+d+h,u+d+p,u+h+p,d+h+p)-t(f+m+g,f+m+y,f+g+y,m+g+y);default:for(var v=e.slice().sort(r),x=n.slice().sort(r),b=0;be[r][0]&&(r=n);return tr?[[r],[t]]:[[t]]}},4750:function(e,t,r){"use strict";e.exports=function(e){var t=n(e),r=t.length;if(r<=2)return[];for(var i=new Array(r),o=t[r-1],a=0;a=t[l]&&(s+=1);o[a]=s}}return e}(n(o,!0),r)}};var n=r(8954),i=r(3952)},4769:function(e){"use strict";e.exports=function(e,t,r,n,i,o){var a=i-1,s=i*i,l=a*a,c=(1+2*i)*l,u=i*l,d=s*(3-2*i),h=s*a;if(e.length){o||(o=new Array(e.length));for(var p=e.length-1;p>=0;--p)o[p]=c*e[p]+u*t[p]+d*r[p]+h*n[p];return o}return c*e+u*t+d*r+h*n},e.exports.derivative=function(e,t,r,n,i,o){var a=6*i*i-6*i,s=3*i*i-4*i+1,l=-6*i*i+6*i,c=3*i*i-2*i;if(e.length){o||(o=new Array(e.length));for(var u=e.length-1;u>=0;--u)o[u]=a*e[u]+s*t[u]+l*r[u]+c*n[u];return o}return a*e+s*t+l*r[u]+c*n}},7642:function(e,t,r){"use strict";var n=r(8954),i=r(1682);function o(e,t){this.point=e,this.index=t}function a(e,t){for(var r=e.point,n=t.point,i=r.length,o=0;o=2)return!1;e[r]=n}return!0})):_.filter((function(e){for(var t=0;t<=s;++t){var r=y[e[t]];if(r<0)return!1;e[t]=r}return!0}));if(1&s)for(u=0;u<_.length;++u){h=(b=_[u])[0];b[0]=b[1],b[1]=h}return _}},2361:function(e){var t=!1;if("undefined"!==typeof Float64Array){var r=new Float64Array(1),n=new Uint32Array(r.buffer);if(r[0]=1,t=!0,1072693248===n[1]){e.exports=function(e){return r[0]=e,[n[0],n[1]]},e.exports.pack=function(e,t){return n[0]=e,n[1]=t,r[0]},e.exports.lo=function(e){return r[0]=e,n[0]},e.exports.hi=function(e){return r[0]=e,n[1]}}else if(1072693248===n[0]){e.exports=function(e){return r[0]=e,[n[1],n[0]]},e.exports.pack=function(e,t){return n[1]=e,n[0]=t,r[0]},e.exports.lo=function(e){return r[0]=e,n[1]},e.exports.hi=function(e){return r[0]=e,n[0]}}else t=!1}if(!t){var i=new Buffer(8);e.exports=function(e){return i.writeDoubleLE(e,0,!0),[i.readUInt32LE(0,!0),i.readUInt32LE(4,!0)]},e.exports.pack=function(e,t){return i.writeUInt32LE(e,0,!0),i.writeUInt32LE(t,4,!0),i.readDoubleLE(0,!0)},e.exports.lo=function(e){return i.writeDoubleLE(e,0,!0),i.readUInt32LE(0,!0)},e.exports.hi=function(e){return i.writeDoubleLE(e,0,!0),i.readUInt32LE(4,!0)}}e.exports.sign=function(t){return e.exports.hi(t)>>>31},e.exports.exponent=function(t){return(e.exports.hi(t)<<1>>>21)-1023},e.exports.fraction=function(t){var r=e.exports.lo(t),n=e.exports.hi(t),i=1048575&n;return 2146435072&n&&(i+=1<<20),[r,i]},e.exports.denormalized=function(t){return!(2146435072&e.exports.hi(t))}},1338:function(e){"use strict";function t(e,r,n){var i=0|e[n];if(i<=0)return[];var o,a=new Array(i);if(n===e.length-1)for(o=0;o0)return function(e,t){var r,n;for(r=new Array(e),n=0;n=r-1){h=l.length-1;var f=e-t[r-1];for(p=0;p=r-1)for(var u=s.length-1,d=(t[r-1],0);d=0;--r)if(e[--t])return!1;return!0},s.jump=function(e){var t=this.lastT(),r=this.dimension;if(!(e0;--d)n.push(o(l[d-1],c[d-1],arguments[d])),i.push(0)}},s.push=function(e){var t=this.lastT(),r=this.dimension;if(!(e1e-6?1/s:0;this._time.push(e);for(var h=r;h>0;--h){var p=o(c[h-1],u[h-1],arguments[h]);n.push(p),i.push((p-n[a++])*d)}}},s.set=function(e){var t=this.dimension;if(!(e0;--l)r.push(o(a[l-1],s[l-1],arguments[l])),n.push(0)}},s.move=function(e){var t=this.lastT(),r=this.dimension;if(!(e<=t||arguments.length!==r+1)){var n=this._state,i=this._velocity,a=n.length-this.dimension,s=this.bounds,l=s[0],c=s[1],u=e-t,d=u>1e-6?1/u:0;this._time.push(e);for(var h=r;h>0;--h){var p=arguments[h];n.push(o(l[h-1],c[h-1],n[a++]+p)),i.push(p*d)}}},s.idle=function(e){var t=this.lastT();if(!(e=0;--d)n.push(o(l[d],c[d],n[a]+u*i[a])),i.push(0),a+=1}}},3840:function(e){"use strict";e.exports=function(e){return new o(e||p,null)};function t(e,t,r,n,i,o){this._color=e,this.key=t,this.value=r,this.left=n,this.right=i,this._count=o}function r(e){return new t(e._color,e.key,e.value,e.left,e.right,e._count)}function n(e,r){return new t(e,r.key,r.value,r.left,r.right,r._count)}function i(e){e._count=1+(e.left?e.left._count:0)+(e.right?e.right._count:0)}function o(e,t){this._compare=e,this.root=t}var a=o.prototype;function s(e,t){var r;if(t.left&&(r=s(e,t.left)))return r;return(r=e(t.key,t.value))||(t.right?s(e,t.right):void 0)}function l(e,t,r,n){if(t(e,n.key)<=0){var i;if(n.left)if(i=l(e,t,r,n.left))return i;if(i=r(n.key,n.value))return i}if(n.right)return l(e,t,r,n.right)}function c(e,t,r,n,i){var o,a=r(e,i.key),s=r(t,i.key);if(a<=0){if(i.left&&(o=c(e,t,r,n,i.left)))return o;if(s>0&&(o=n(i.key,i.value)))return o}if(s>0&&i.right)return c(e,t,r,n,i.right)}function u(e,t){this.tree=e,this._stack=t}Object.defineProperty(a,"keys",{get:function(){var e=[];return this.forEach((function(t,r){e.push(t)})),e}}),Object.defineProperty(a,"values",{get:function(){var e=[];return this.forEach((function(t,r){e.push(r)})),e}}),Object.defineProperty(a,"length",{get:function(){return this.root?this.root._count:0}}),a.insert=function(e,r){for(var a=this._compare,s=this.root,l=[],c=[];s;){var u=a(e,s.key);l.push(s),c.push(u),s=u<=0?s.left:s.right}l.push(new t(0,e,r,null,null,1));for(var d=l.length-2;d>=0;--d){s=l[d];c[d]<=0?l[d]=new t(s._color,s.key,s.value,l[d+1],s.right,s._count+1):l[d]=new t(s._color,s.key,s.value,s.left,l[d+1],s._count+1)}for(d=l.length-1;d>1;--d){var h=l[d-1];s=l[d];if(1===h._color||1===s._color)break;var p=l[d-2];if(p.left===h)if(h.left===s){if(!(f=p.right)||0!==f._color){if(p._color=0,p.left=h.right,h._color=1,h.right=p,l[d-2]=h,l[d-1]=s,i(p),i(h),d>=3)(m=l[d-3]).left===p?m.left=h:m.right=h;break}h._color=1,p.right=n(1,f),p._color=0,d-=1}else{if(!(f=p.right)||0!==f._color){if(h.right=s.left,p._color=0,p.left=s.right,s._color=1,s.left=h,s.right=p,l[d-2]=s,l[d-1]=h,i(p),i(h),i(s),d>=3)(m=l[d-3]).left===p?m.left=s:m.right=s;break}h._color=1,p.right=n(1,f),p._color=0,d-=1}else if(h.right===s){if(!(f=p.left)||0!==f._color){if(p._color=0,p.right=h.left,h._color=1,h.left=p,l[d-2]=h,l[d-1]=s,i(p),i(h),d>=3)(m=l[d-3]).right===p?m.right=h:m.left=h;break}h._color=1,p.left=n(1,f),p._color=0,d-=1}else{var f;if(!(f=p.left)||0!==f._color){var m;if(h.left=s.right,p._color=0,p.right=s.left,s._color=1,s.right=h,s.left=p,l[d-2]=s,l[d-1]=h,i(p),i(h),i(s),d>=3)(m=l[d-3]).right===p?m.right=s:m.left=s;break}h._color=1,p.left=n(1,f),p._color=0,d-=1}}return l[0]._color=1,new o(a,l[0])},a.forEach=function(e,t,r){if(this.root)switch(arguments.length){case 1:return s(e,this.root);case 2:return l(t,this._compare,e,this.root);case 3:if(this._compare(t,r)>=0)return;return c(t,r,this._compare,e,this.root)}},Object.defineProperty(a,"begin",{get:function(){for(var e=[],t=this.root;t;)e.push(t),t=t.left;return new u(this,e)}}),Object.defineProperty(a,"end",{get:function(){for(var e=[],t=this.root;t;)e.push(t),t=t.right;return new u(this,e)}}),a.at=function(e){if(e<0)return new u(this,[]);for(var t=this.root,r=[];;){if(r.push(t),t.left){if(e=t.right._count)break;t=t.right}return new u(this,[])},a.ge=function(e){for(var t=this._compare,r=this.root,n=[],i=0;r;){var o=t(e,r.key);n.push(r),o<=0&&(i=n.length),r=o<=0?r.left:r.right}return n.length=i,new u(this,n)},a.gt=function(e){for(var t=this._compare,r=this.root,n=[],i=0;r;){var o=t(e,r.key);n.push(r),o<0&&(i=n.length),r=o<0?r.left:r.right}return n.length=i,new u(this,n)},a.lt=function(e){for(var t=this._compare,r=this.root,n=[],i=0;r;){var o=t(e,r.key);n.push(r),o>0&&(i=n.length),r=o<=0?r.left:r.right}return n.length=i,new u(this,n)},a.le=function(e){for(var t=this._compare,r=this.root,n=[],i=0;r;){var o=t(e,r.key);n.push(r),o>=0&&(i=n.length),r=o<0?r.left:r.right}return n.length=i,new u(this,n)},a.find=function(e){for(var t=this._compare,r=this.root,n=[];r;){var i=t(e,r.key);if(n.push(r),0===i)return new u(this,n);r=i<=0?r.left:r.right}return new u(this,[])},a.remove=function(e){var t=this.find(e);return t?t.remove():this},a.get=function(e){for(var t=this._compare,r=this.root;r;){var n=t(e,r.key);if(0===n)return r.value;r=n<=0?r.left:r.right}};var d=u.prototype;function h(e,t){e.key=t.key,e.value=t.value,e.left=t.left,e.right=t.right,e._color=t._color,e._count=t._count}function p(e,t){return et?1:0}Object.defineProperty(d,"valid",{get:function(){return this._stack.length>0}}),Object.defineProperty(d,"node",{get:function(){return this._stack.length>0?this._stack[this._stack.length-1]:null},enumerable:!0}),d.clone=function(){return new u(this.tree,this._stack.slice())},d.remove=function(){var e=this._stack;if(0===e.length)return this.tree;var a=new Array(e.length),s=e[e.length-1];a[a.length-1]=new t(s._color,s.key,s.value,s.left,s.right,s._count);for(var l=e.length-2;l>=0;--l){(s=e[l]).left===e[l+1]?a[l]=new t(s._color,s.key,s.value,a[l+1],s.right,s._count):a[l]=new t(s._color,s.key,s.value,s.left,a[l+1],s._count)}if((s=a[a.length-1]).left&&s.right){var c=a.length;for(s=s.left;s.right;)a.push(s),s=s.right;var u=a[c-1];a.push(new t(s._color,u.key,u.value,s.left,s.right,s._count)),a[c-1].key=s.key,a[c-1].value=s.value;for(l=a.length-2;l>=c;--l)s=a[l],a[l]=new t(s._color,s.key,s.value,s.left,a[l+1],s._count);a[c-1].left=a[c]}if(0===(s=a[a.length-1])._color){var d=a[a.length-2];d.left===s?d.left=null:d.right===s&&(d.right=null),a.pop();for(l=0;l=0;--l){if(t=e[l],0===l)return void(t._color=1);if((o=e[l-1]).left===t){if((a=o.right).right&&0===a.right._color)return s=(a=o.right=r(a)).right=r(a.right),o.right=a.left,a.left=o,a.right=s,a._color=o._color,t._color=1,o._color=1,s._color=1,i(o),i(a),l>1&&((c=e[l-2]).left===o?c.left=a:c.right=a),void(e[l-1]=a);if(a.left&&0===a.left._color)return s=(a=o.right=r(a)).left=r(a.left),o.right=s.left,a.left=s.right,s.left=o,s.right=a,s._color=o._color,o._color=1,a._color=1,t._color=1,i(o),i(a),i(s),l>1&&((c=e[l-2]).left===o?c.left=s:c.right=s),void(e[l-1]=s);if(1===a._color){if(0===o._color)return o._color=1,void(o.right=n(0,a));o.right=n(0,a);continue}a=r(a),o.right=a.left,a.left=o,a._color=o._color,o._color=0,i(o),i(a),l>1&&((c=e[l-2]).left===o?c.left=a:c.right=a),e[l-1]=a,e[l]=o,l+11&&((c=e[l-2]).right===o?c.right=a:c.left=a),void(e[l-1]=a);if(a.right&&0===a.right._color)return s=(a=o.left=r(a)).right=r(a.right),o.left=s.right,a.right=s.left,s.right=o,s.left=a,s._color=o._color,o._color=1,a._color=1,t._color=1,i(o),i(a),i(s),l>1&&((c=e[l-2]).right===o?c.right=s:c.left=s),void(e[l-1]=s);if(1===a._color){if(0===o._color)return o._color=1,void(o.left=n(0,a));o.left=n(0,a);continue}var c;a=r(a),o.left=a.right,a.right=o,a._color=o._color,o._color=0,i(o),i(a),l>1&&((c=e[l-2]).right===o?c.right=a:c.left=a),e[l-1]=a,e[l]=o,l+10)return this._stack[this._stack.length-1].key},enumerable:!0}),Object.defineProperty(d,"value",{get:function(){if(this._stack.length>0)return this._stack[this._stack.length-1].value},enumerable:!0}),Object.defineProperty(d,"index",{get:function(){var e=0,t=this._stack;if(0===t.length){var r=this.tree.root;return r?r._count:0}t[t.length-1].left&&(e=t[t.length-1].left._count);for(var n=t.length-2;n>=0;--n)t[n+1]===t[n].right&&(++e,t[n].left&&(e+=t[n].left._count));return e},enumerable:!0}),d.next=function(){var e=this._stack;if(0!==e.length){var t=e[e.length-1];if(t.right)for(t=t.right;t;)e.push(t),t=t.left;else for(e.pop();e.length>0&&e[e.length-1].right===t;)t=e[e.length-1],e.pop()}},Object.defineProperty(d,"hasNext",{get:function(){var e=this._stack;if(0===e.length)return!1;if(e[e.length-1].right)return!0;for(var t=e.length-1;t>0;--t)if(e[t-1].left===e[t])return!0;return!1}}),d.update=function(e){var r=this._stack;if(0===r.length)throw new Error("Can't update empty node!");var n=new Array(r.length),i=r[r.length-1];n[n.length-1]=new t(i._color,i.key,e,i.left,i.right,i._count);for(var a=r.length-2;a>=0;--a)(i=r[a]).left===r[a+1]?n[a]=new t(i._color,i.key,i.value,n[a+1],i.right,i._count):n[a]=new t(i._color,i.key,i.value,i.left,n[a+1],i._count);return new o(this.tree._compare,n[0])},d.prev=function(){var e=this._stack;if(0!==e.length){var t=e[e.length-1];if(t.left)for(t=t.left;t;)e.push(t),t=t.right;else for(e.pop();e.length>0&&e[e.length-1].left===t;)t=e[e.length-1],e.pop()}},Object.defineProperty(d,"hasPrev",{get:function(){var e=this._stack;if(0===e.length)return!1;if(e[e.length-1].left)return!0;for(var t=e.length-1;t>0;--t)if(e[t-1].right===e[t])return!0;return!1}})},3837:function(e,t,r){"use strict";e.exports=function(e,t){var r=new p(e);return r.update(t),r};var n=r(4935),i=r(501),o=r(5304),a=r(6429),s=r(6444),l=new Float32Array([1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]),c=ArrayBuffer,u=DataView;function d(e){return Array.isArray(e)||function(e){return c.isView(e)&&!(e instanceof u)}(e)}function h(e,t){return e[0]=t[0],e[1]=t[1],e[2]=t[2],e}function p(e){this.gl=e,this.pixelRatio=1,this.bounds=[[-10,-10,-10],[10,10,10]],this.ticks=[[],[],[]],this.autoTicks=!0,this.tickSpacing=[1,1,1],this.tickEnable=[!0,!0,!0],this.tickFont=["sans-serif","sans-serif","sans-serif"],this.tickFontStyle=["normal","normal","normal"],this.tickFontWeight=["normal","normal","normal"],this.tickFontVariant=["normal","normal","normal"],this.tickSize=[12,12,12],this.tickAngle=[0,0,0],this.tickAlign=["auto","auto","auto"],this.tickColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.tickPad=[10,10,10],this.lastCubeProps={cubeEdges:[0,0,0],axis:[0,0,0]},this.labels=["x","y","z"],this.labelEnable=[!0,!0,!0],this.labelFont=["sans-serif","sans-serif","sans-serif"],this.labelFontStyle=["normal","normal","normal"],this.labelFontWeight=["normal","normal","normal"],this.labelFontVariant=["normal","normal","normal"],this.labelSize=[20,20,20],this.labelAngle=[0,0,0],this.labelAlign=["auto","auto","auto"],this.labelColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.labelPad=[10,10,10],this.lineEnable=[!0,!0,!0],this.lineMirror=[!1,!1,!1],this.lineWidth=[1,1,1],this.lineColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.lineTickEnable=[!0,!0,!0],this.lineTickMirror=[!1,!1,!1],this.lineTickLength=[0,0,0],this.lineTickWidth=[1,1,1],this.lineTickColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.gridEnable=[!0,!0,!0],this.gridWidth=[1,1,1],this.gridColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.zeroEnable=[!0,!0,!0],this.zeroLineColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.zeroLineWidth=[2,2,2],this.backgroundEnable=[!1,!1,!1],this.backgroundColor=[[.8,.8,.8,.5],[.8,.8,.8,.5],[.8,.8,.8,.5]],this._firstInit=!0,this._text=null,this._lines=null,this._background=o(e)}var f=p.prototype;function m(){this.primalOffset=[0,0,0],this.primalMinor=[0,0,0],this.mirrorOffset=[0,0,0],this.mirrorMinor=[0,0,0]}f.update=function(e){function t(t,r,n){if(n in e){var i,o=e[n],a=this[n];(t?d(o)&&d(o[0]):d(o))?this[n]=i=[r(o[0]),r(o[1]),r(o[2])]:this[n]=i=[r(o),r(o),r(o)];for(var s=0;s<3;++s)if(i[s]!==a[s])return!0}return!1}e=e||{};var r,o=t.bind(this,!1,Number),a=t.bind(this,!1,Boolean),l=t.bind(this,!1,String),c=t.bind(this,!0,(function(e){if(d(e)){if(3===e.length)return[+e[0],+e[1],+e[2],1];if(4===e.length)return[+e[0],+e[1],+e[2],+e[3]]}return[0,0,0,1]})),u=!1,h=!1;if("bounds"in e)for(var p=e.bounds,f=0;f<2;++f)for(var m=0;m<3;++m)p[f][m]!==this.bounds[f][m]&&(h=!0),this.bounds[f][m]=p[f][m];if("ticks"in e){r=e.ticks,u=!0,this.autoTicks=!1;for(f=0;f<3;++f)this.tickSpacing[f]=0}else o("tickSpacing")&&(this.autoTicks=!0,h=!0);if(this._firstInit&&("ticks"in e||"tickSpacing"in e||(this.autoTicks=!0),h=!0,u=!0,this._firstInit=!1),h&&this.autoTicks&&(r=s.create(this.bounds,this.tickSpacing),u=!0),u){for(f=0;f<3;++f)r[f].sort((function(e,t){return e.x-t.x}));s.equal(r,this.ticks)?u=!1:this.ticks=r}a("tickEnable"),l("tickFont")&&(u=!0),l("tickFontStyle")&&(u=!0),l("tickFontWeight")&&(u=!0),l("tickFontVariant")&&(u=!0),o("tickSize"),o("tickAngle"),o("tickPad"),c("tickColor");var g=l("labels");l("labelFont")&&(g=!0),l("labelFontStyle")&&(g=!0),l("labelFontWeight")&&(g=!0),l("labelFontVariant")&&(g=!0),a("labelEnable"),o("labelSize"),o("labelPad"),c("labelColor"),a("lineEnable"),a("lineMirror"),o("lineWidth"),c("lineColor"),a("lineTickEnable"),a("lineTickMirror"),o("lineTickLength"),o("lineTickWidth"),c("lineTickColor"),a("gridEnable"),o("gridWidth"),c("gridColor"),a("zeroEnable"),c("zeroLineColor"),o("zeroLineWidth"),a("backgroundEnable"),c("backgroundColor");var y=[{family:this.labelFont[0],style:this.labelFontStyle[0],weight:this.labelFontWeight[0],variant:this.labelFontVariant[0]},{family:this.labelFont[1],style:this.labelFontStyle[1],weight:this.labelFontWeight[1],variant:this.labelFontVariant[1]},{family:this.labelFont[2],style:this.labelFontStyle[2],weight:this.labelFontWeight[2],variant:this.labelFontVariant[2]}],v=[{family:this.tickFont[0],style:this.tickFontStyle[0],weight:this.tickFontWeight[0],variant:this.tickFontVariant[0]},{family:this.tickFont[1],style:this.tickFontStyle[1],weight:this.tickFontWeight[1],variant:this.tickFontVariant[1]},{family:this.tickFont[2],style:this.tickFontStyle[2],weight:this.tickFontWeight[2],variant:this.tickFontVariant[2]}];this._text?this._text&&(g||u)&&this._text.update(this.bounds,this.labels,y,this.ticks,v):this._text=n(this.gl,this.bounds,this.labels,y,this.ticks,v),this._lines&&u&&(this._lines.dispose(),this._lines=null),this._lines||(this._lines=i(this.gl,this.bounds,this.ticks))};var g=[new m,new m,new m];function y(e,t,r,n,i){for(var o=e.primalOffset,a=e.primalMinor,s=e.mirrorOffset,l=e.mirrorMinor,c=n[t],u=0;u<3;++u)if(t!==u){var d=o,h=s,p=a,f=l;c&1<0?(p[u]=-1,f[u]=0):(p[u]=0,f[u]=1)}}var v=[0,0,0],x={model:l,view:l,projection:l,_ortho:!1};f.isOpaque=function(){return!0},f.isTransparent=function(){return!1},f.drawTransparent=function(e){};var b=[0,0,0],_=[0,0,0],w=[0,0,0];f.draw=function(e){e=e||x;for(var t=this.gl,r=e.model||l,n=e.view||l,i=e.projection||l,o=this.bounds,s=e._ortho||!1,c=a(r,n,i,o,s),u=c.cubeEdges,d=c.axis,p=n[12],f=n[13],m=n[14],k=n[15],S=(s?2:1)*this.pixelRatio*(i[3]*p+i[7]*f+i[11]*m+i[15]*k)/t.drawingBufferHeight,A=0;A<3;++A)this.lastCubeProps.cubeEdges[A]=u[A],this.lastCubeProps.axis[A]=d[A];var T=g;for(A=0;A<3;++A)y(g[A],A,this.bounds,u,d);t=this.gl;var M,C=v;for(A=0;A<3;++A)this.backgroundEnable[A]?C[A]=d[A]:C[A]=0;this._background.draw(r,n,i,o,C,this.backgroundColor),this._lines.bind(r,n,i,this);for(A=0;A<3;++A){var E=[0,0,0];d[A]>0?E[A]=o[1][A]:E[A]=o[0][A];for(var I=0;I<2;++I){var P=(A+1+I)%3,O=(A+1+(1^I))%3;this.gridEnable[P]&&this._lines.drawGrid(P,O,this.bounds,E,this.gridColor[P],this.gridWidth[P]*this.pixelRatio)}for(I=0;I<2;++I){P=(A+1+I)%3,O=(A+1+(1^I))%3;this.zeroEnable[O]&&Math.min(o[0][O],o[1][O])<=0&&Math.max(o[0][O],o[1][O])>=0&&this._lines.drawZero(P,O,this.bounds,E,this.zeroLineColor[O],this.zeroLineWidth[O]*this.pixelRatio)}}for(A=0;A<3;++A){this.lineEnable[A]&&this._lines.drawAxisLine(A,this.bounds,T[A].primalOffset,this.lineColor[A],this.lineWidth[A]*this.pixelRatio),this.lineMirror[A]&&this._lines.drawAxisLine(A,this.bounds,T[A].mirrorOffset,this.lineColor[A],this.lineWidth[A]*this.pixelRatio);var R=h(b,T[A].primalMinor),L=h(_,T[A].mirrorMinor),D=this.lineTickLength;for(I=0;I<3;++I){var z=S/r[5*I];R[I]*=D[I]*z,L[I]*=D[I]*z}this.lineTickEnable[A]&&this._lines.drawAxisTicks(A,T[A].primalOffset,R,this.lineTickColor[A],this.lineTickWidth[A]*this.pixelRatio),this.lineTickMirror[A]&&this._lines.drawAxisTicks(A,T[A].mirrorOffset,L,this.lineTickColor[A],this.lineTickWidth[A]*this.pixelRatio)}this._lines.unbind(),this._text.bind(r,n,i,this.pixelRatio);var j,F;function N(e){(F=[0,0,0])[e]=1}function B(e,t,r){var n=(e+1)%3,i=(e+2)%3,o=t[n],a=t[i],s=r[n],l=r[i];o>0&&l>0||o>0&&l<0||o<0&&l>0||o<0&&l<0?N(n):(a>0&&s>0||a>0&&s<0||a<0&&s>0||a<0&&s<0)&&N(i)}for(A=0;A<3;++A){var V=T[A].primalMinor,U=T[A].mirrorMinor,H=h(w,T[A].primalOffset);for(I=0;I<3;++I)this.lineTickEnable[A]&&(H[I]+=S*V[I]*Math.max(this.lineTickLength[I],0)/r[5*I]);var $=[0,0,0];if($[A]=1,this.tickEnable[A]){-3600===this.tickAngle[A]?(this.tickAngle[A]=0,this.tickAlign[A]="auto"):this.tickAlign[A]=-1,j=1,"auto"===(M=[this.tickAlign[A],.5,j])[0]?M[0]=0:M[0]=parseInt(""+M[0]),F=[0,0,0],B(A,V,U);for(I=0;I<3;++I)H[I]+=S*V[I]*this.tickPad[I]/r[5*I];this._text.drawTicks(A,this.tickSize[A],this.tickAngle[A],H,this.tickColor[A],$,F,M)}if(this.labelEnable[A]){j=0,F=[0,0,0],this.labels[A].length>4&&(N(A),j=1),"auto"===(M=[this.labelAlign[A],.5,j])[0]?M[0]=0:M[0]=parseInt(""+M[0]);for(I=0;I<3;++I)H[I]+=S*V[I]*this.labelPad[I]/r[5*I];H[A]+=.5*(o[0][A]+o[1][A]),this._text.drawLabel(A,this.labelSize[A],this.labelAngle[A],H,this.labelColor[A],[0,0,0],F,M)}}this._text.unbind()},f.dispose=function(){this._text.dispose(),this._lines.dispose(),this._background.dispose(),this._lines=null,this._text=null,this._background=null,this.gl=null}},5304:function(e,t,r){"use strict";e.exports=function(e){for(var t=[],r=[],s=0,l=0;l<3;++l)for(var c=(l+1)%3,u=(l+2)%3,d=[0,0,0],h=[0,0,0],p=-1;p<=1;p+=2){r.push(s,s+2,s+1,s+1,s+2,s+3),d[l]=p,h[l]=p;for(var f=-1;f<=1;f+=2){d[c]=f;for(var m=-1;m<=1;m+=2)d[u]=m,t.push(d[0],d[1],d[2],h[0],h[1],h[2]),s+=1}var g=c;c=u,u=g}var y=n(e,new Float32Array(t)),v=n(e,new Uint16Array(r),e.ELEMENT_ARRAY_BUFFER),x=i(e,[{buffer:y,type:e.FLOAT,size:3,offset:0,stride:24},{buffer:y,type:e.FLOAT,size:3,offset:12,stride:24}],v),b=o(e);return b.attributes.position.location=0,b.attributes.normal.location=1,new a(e,y,x,b)};var n=r(2762),i=r(8116),o=r(1879).bg;function a(e,t,r,n){this.gl=e,this.buffer=t,this.vao=r,this.shader=n}var s=a.prototype;s.draw=function(e,t,r,n,i,o){for(var a=!1,s=0;s<3;++s)a=a||i[s];if(a){var l=this.gl;l.enable(l.POLYGON_OFFSET_FILL),l.polygonOffset(1,2),this.shader.bind(),this.shader.uniforms={model:e,view:t,projection:r,bounds:n,enable:i,colors:o},this.vao.bind(),this.vao.draw(this.gl.TRIANGLES,36),this.vao.unbind(),l.disable(l.POLYGON_OFFSET_FILL)}},s.dispose=function(){this.vao.dispose(),this.buffer.dispose(),this.shader.dispose()}},6429:function(e,t,r){"use strict";e.exports=function(e,t,r,o,p){i(s,t,e),i(s,r,s);for(var v=0,x=0;x<2;++x){u[2]=o[x][2];for(var b=0;b<2;++b){u[1]=o[b][1];for(var _=0;_<2;++_)u[0]=o[_][0],h(l[v],u,s),v+=1}}var w=-1;for(x=0;x<8;++x){for(var k=l[x][3],S=0;S<3;++S)c[x][S]=l[x][S]/k;p&&(c[x][2]*=-1),k<0&&(w<0||c[x][2]C&&(w|=1<C&&(w|=1<c[x][1])&&(z=x);var j=-1;for(x=0;x<3;++x){if((N=z^1<c[F][0]&&(F=N)}var B=m;B[0]=B[1]=B[2]=0,B[n.log2(j^z)]=z&j,B[n.log2(z^F)]=z&F;var V=7^F;V===w||V===D?(V=7^j,B[n.log2(F^V)]=V&F):B[n.log2(j^V)]=V&j;var U=g,H=w;for(A=0;A<3;++A)U[A]=H&1< HALF_PI) && (b <= ONE_AND_HALF_PI)) ?\n b - PI :\n b;\n}\n\nfloat look_horizontal_or_vertical(float a, float ratio) {\n // ratio controls the ratio between being horizontal to (vertical + horizontal)\n // if ratio is set to 0.5 then it is 50%, 50%.\n // when using a higher ratio e.g. 0.75 the result would\n // likely be more horizontal than vertical.\n\n float b = positive_angle(a);\n\n return\n (b < ( ratio) * HALF_PI) ? 0.0 :\n (b < (2.0 - ratio) * HALF_PI) ? -HALF_PI :\n (b < (2.0 + ratio) * HALF_PI) ? 0.0 :\n (b < (4.0 - ratio) * HALF_PI) ? HALF_PI :\n 0.0;\n}\n\nfloat roundTo(float a, float b) {\n return float(b * floor((a + 0.5 * b) / b));\n}\n\nfloat look_round_n_directions(float a, int n) {\n float b = positive_angle(a);\n float div = TWO_PI / float(n);\n float c = roundTo(b, div);\n return look_upwards(c);\n}\n\nfloat applyAlignOption(float rawAngle, float delta) {\n return\n (option > 2) ? look_round_n_directions(rawAngle + delta, option) : // option 3-n: round to n directions\n (option == 2) ? look_horizontal_or_vertical(rawAngle + delta, hv_ratio) : // horizontal or vertical\n (option == 1) ? rawAngle + delta : // use free angle, and flip to align with one direction of the axis\n (option == 0) ? look_upwards(rawAngle) : // use free angle, and stay upwards\n (option ==-1) ? 0.0 : // useful for backward compatibility, all texts remains horizontal\n rawAngle; // otherwise return back raw input angle\n}\n\nbool isAxisTitle = (axis.x == 0.0) &&\n (axis.y == 0.0) &&\n (axis.z == 0.0);\n\nvoid main() {\n //Compute world offset\n float axisDistance = position.z;\n vec3 dataPosition = axisDistance * axis + offset;\n\n float beta = angle; // i.e. user defined attributes for each tick\n\n float axisAngle;\n float clipAngle;\n float flip;\n\n if (enableAlign) {\n axisAngle = (isAxisTitle) ? HALF_PI :\n computeViewAngle(dataPosition, dataPosition + axis);\n clipAngle = computeViewAngle(dataPosition, dataPosition + alignDir);\n\n axisAngle += (sin(axisAngle) < 0.0) ? PI : 0.0;\n clipAngle += (sin(clipAngle) < 0.0) ? PI : 0.0;\n\n flip = (dot(vec2(cos(axisAngle), sin(axisAngle)),\n vec2(sin(clipAngle),-cos(clipAngle))) > 0.0) ? 1.0 : 0.0;\n\n beta += applyAlignOption(clipAngle, flip * PI);\n }\n\n //Compute plane offset\n vec2 planeCoord = position.xy * pixelScale;\n\n mat2 planeXform = scale * mat2(\n cos(beta), sin(beta),\n -sin(beta), cos(beta)\n );\n\n vec2 viewOffset = 2.0 * planeXform * planeCoord / resolution;\n\n //Compute clip position\n vec3 clipPosition = project(dataPosition);\n\n //Apply text offset in clip coordinates\n clipPosition += vec3(viewOffset, 0.0);\n\n //Done\n gl_Position = vec4(clipPosition, 1.0);\n}\n"]),l=n(["precision highp float;\n#define GLSLIFY 1\n\nuniform vec4 color;\nvoid main() {\n gl_FragColor = color;\n}"]);t.Q=function(e){return i(e,s,l,null,[{name:"position",type:"vec3"}])};var c=n(["precision highp float;\n#define GLSLIFY 1\n\nattribute vec3 position;\nattribute vec3 normal;\n\nuniform mat4 model, view, projection;\nuniform vec3 enable;\nuniform vec3 bounds[2];\n\nvarying vec3 colorChannel;\n\nvoid main() {\n\n vec3 signAxis = sign(bounds[1] - bounds[0]);\n\n vec3 realNormal = signAxis * normal;\n\n if(dot(realNormal, enable) > 0.0) {\n vec3 minRange = min(bounds[0], bounds[1]);\n vec3 maxRange = max(bounds[0], bounds[1]);\n vec3 nPosition = mix(minRange, maxRange, 0.5 * (position + 1.0));\n gl_Position = projection * (view * (model * vec4(nPosition, 1.0)));\n } else {\n gl_Position = vec4(0,0,0,0);\n }\n\n colorChannel = abs(realNormal);\n}\n"]),u=n(["precision highp float;\n#define GLSLIFY 1\n\nuniform vec4 colors[3];\n\nvarying vec3 colorChannel;\n\nvoid main() {\n gl_FragColor = colorChannel.x * colors[0] +\n colorChannel.y * colors[1] +\n colorChannel.z * colors[2];\n}"]);t.bg=function(e){return i(e,c,u,null,[{name:"position",type:"vec3"},{name:"normal",type:"vec3"}])}},4935:function(e,t,r){"use strict";e.exports=function(e,t,r,o,s,l){var u=n(e),d=i(e,[{buffer:u,size:3}]),h=a(e);h.attributes.position.location=0;var p=new c(e,h,u,d);return p.update(t,r,o,s,l),p};var n=r(2762),i=r(8116),o=r(4359),a=r(1879).Q,s=window||process.global||{},l=s.__TEXT_CACHE||{};s.__TEXT_CACHE={};function c(e,t,r,n){this.gl=e,this.shader=t,this.buffer=r,this.vao=n,this.tickOffset=this.tickCount=this.labelOffset=this.labelCount=null}var u=c.prototype,d=[0,0];u.bind=function(e,t,r,n){this.vao.bind(),this.shader.bind();var i=this.shader.uniforms;i.model=e,i.view=t,i.projection=r,i.pixelScale=n,d[0]=this.gl.drawingBufferWidth,d[1]=this.gl.drawingBufferHeight,this.shader.uniforms.resolution=d},u.unbind=function(){this.vao.unbind()},u.update=function(e,t,r,n,i){var a=[];function s(e,t,r,n,i,s){var c=[r.style,r.weight,r.variant,r.family].join("_"),u=l[c];u||(u=l[c]={});var d=u[t];d||(d=u[t]=function(e,t){try{return o(e,t)}catch(r){return console.warn('error vectorizing text:"'+e+'" error:',r),{cells:[],positions:[]}}}(t,{triangles:!0,font:r.family,fontStyle:r.style,fontWeight:r.weight,fontVariant:r.variant,textAlign:"center",textBaseline:"middle",lineSpacing:i,styletags:s}));for(var h=(n||12)/12,p=d.positions,f=d.cells,m=0,g=f.length;m=0;--v){var x=p[y[v]];a.push(h*x[0],-h*x[1],e)}}for(var c=[0,0,0],u=[0,0,0],d=[0,0,0],h=[0,0,0],p={breaklines:!0,bolds:!0,italics:!0,subscripts:!0,superscripts:!0},f=0;f<3;++f){d[f]=a.length/3|0,s(.5*(e[0][f]+e[1][f]),t[f],r[f],12,1.25,p),h[f]=(a.length/3|0)-d[f],c[f]=a.length/3|0;for(var m=0;m=0&&(i=r.length-n-1);var o=Math.pow(10,i),a=Math.round(e*t*o),s=a+"";if(s.indexOf("e")>=0)return s;var l=a/o,c=a%o;a<0?(l=0|-Math.ceil(l),c=0|-c):(l=0|Math.floor(l),c|=0);var u=""+l;if(a<0&&(u="-"+u),i){for(var d=""+c;d.length=e[0][i];--a)o.push({x:a*t[i],text:r(t[i],a)});n.push(o)}return n},t.equal=function(e,t){for(var r=0;r<3;++r){if(e[r].length!==t[r].length)return!1;for(var n=0;nr)throw new Error("gl-buffer: If resizing buffer, must not specify offset");return e.bufferSubData(t,o,i),r}function u(e,t){for(var r=n.malloc(e.length,t),i=e.length,o=0;o=0;--n){if(t[n]!==r)return!1;r*=e[n]}return!0}(e.shape,e.stride))0===e.offset&&e.data.length===e.shape[0]?this.length=c(this.gl,this.type,this.length,this.usage,e.data,t):this.length=c(this.gl,this.type,this.length,this.usage,e.data.subarray(e.offset,e.shape[0]),t);else{var s=n.malloc(e.size,r),l=o(s,e.shape);i.assign(l,e),this.length=c(this.gl,this.type,this.length,this.usage,t<0?s:s.subarray(0,e.size),t),n.free(s)}}else if(Array.isArray(e)){var d;d=this.type===this.gl.ELEMENT_ARRAY_BUFFER?u(e,"uint16"):u(e,"float32"),this.length=c(this.gl,this.type,this.length,this.usage,t<0?d:d.subarray(0,e.length),t),n.free(d)}else if("object"===typeof e&&"number"===typeof e.length)this.length=c(this.gl,this.type,this.length,this.usage,e,t);else{if("number"!==typeof e&&void 0!==e)throw new Error("gl-buffer: Invalid data type");if(t>=0)throw new Error("gl-buffer: Cannot specify offset when resizing buffer");(e|=0)<=0&&(e=1),this.gl.bufferData(this.type,0|e,this.usage),this.length=e}},e.exports=function(e,t,r,n){if(r=r||e.ARRAY_BUFFER,n=n||e.DYNAMIC_DRAW,r!==e.ARRAY_BUFFER&&r!==e.ELEMENT_ARRAY_BUFFER)throw new Error("gl-buffer: Invalid type for webgl buffer, must be either gl.ARRAY_BUFFER or gl.ELEMENT_ARRAY_BUFFER");if(n!==e.DYNAMIC_DRAW&&n!==e.STATIC_DRAW&&n!==e.STREAM_DRAW)throw new Error("gl-buffer: Invalid usage for buffer, must be either gl.DYNAMIC_DRAW, gl.STATIC_DRAW or gl.STREAM_DRAW");var i=e.createBuffer(),o=new s(e,r,i,0,n);return o.update(t),o}},6405:function(e,t,r){"use strict";var n=r(2931);e.exports=function(e,t){var r=e.positions,i=e.vectors,o={positions:[],vertexIntensity:[],vertexIntensityBounds:e.vertexIntensityBounds,vectors:[],cells:[],coneOffset:e.coneOffset,colormap:e.colormap};if(0===e.positions.length)return t&&(t[0]=[0,0,0],t[1]=[0,0,0]),o;for(var a=0,s=1/0,l=-1/0,c=1/0,u=-1/0,d=1/0,h=-1/0,p=null,f=null,m=[],g=1/0,y=!1,v="raw"===e.coneSizemode,x=0;xa&&(a=n.length(_)),x&&!v){var w=2*n.distance(p,b)/(n.length(f)+n.length(_));w?(g=Math.min(g,w),y=!1):y=!0}y||(p=b,f=_),m.push(_)}var k=[s,c,d],S=[l,u,h];t&&(t[0]=k,t[1]=S),0===a&&(a=1);var A=1/a;isFinite(g)||(g=1),o.vectorScale=g;var T=e.coneSize||(v?1:.5);e.absoluteConeSize&&(T=e.absoluteConeSize*A),o.coneScale=T;x=0;for(var M=0;x=1},p.isTransparent=function(){return this.opacity<1},p.pickSlots=1,p.setPickBase=function(e){this.pickId=e},p.update=function(e){e=e||{};var t=this.gl;this.dirty=!0,"lightPosition"in e&&(this.lightPosition=e.lightPosition),"opacity"in e&&(this.opacity=e.opacity),"ambient"in e&&(this.ambientLight=e.ambient),"diffuse"in e&&(this.diffuseLight=e.diffuse),"specular"in e&&(this.specularLight=e.specular),"roughness"in e&&(this.roughness=e.roughness),"fresnel"in e&&(this.fresnel=e.fresnel),void 0!==e.tubeScale&&(this.tubeScale=e.tubeScale),void 0!==e.vectorScale&&(this.vectorScale=e.vectorScale),void 0!==e.coneScale&&(this.coneScale=e.coneScale),void 0!==e.coneOffset&&(this.coneOffset=e.coneOffset),e.colormap&&(this.texture.shape=[256,256],this.texture.minFilter=t.LINEAR_MIPMAP_LINEAR,this.texture.magFilter=t.LINEAR,this.texture.setPixels(function(e){for(var t=u({colormap:e,nshades:256,format:"rgba"}),r=new Uint8Array(1024),n=0;n<256;++n){for(var i=t[n],o=0;o<3;++o)r[4*n+o]=i[o];r[4*n+3]=255*i[3]}return c(r,[256,256,4],[4,0,1])}(e.colormap)),this.texture.generateMipmap());var r=e.cells,n=e.positions,i=e.vectors;if(n&&r&&i){var o=[],a=[],s=[],l=[],d=[];this.cells=r,this.positions=n,this.vectors=i;var h=e.meshColor||[1,1,1,1],p=e.vertexIntensity,f=1/0,m=-1/0;if(p)if(e.vertexIntensityBounds)f=+e.vertexIntensityBounds[0],m=+e.vertexIntensityBounds[1];else for(var g=0;g0){var m=this.triShader;m.bind(),m.uniforms=c,this.triangleVAO.bind(),t.drawArrays(t.TRIANGLES,0,3*this.triangleCount),this.triangleVAO.unbind()}},p.drawPick=function(e){e=e||{};for(var t=this.gl,r=e.model||d,n=e.view||d,i=e.projection||d,o=[[-1e6,-1e6,-1e6],[1e6,1e6,1e6]],a=0;a<3;++a)o[0][a]=Math.max(o[0][a],this.clipBounds[0][a]),o[1][a]=Math.min(o[1][a],this.clipBounds[1][a]);this._model=[].slice.call(r),this._view=[].slice.call(n),this._projection=[].slice.call(i),this._resolution=[t.drawingBufferWidth,t.drawingBufferHeight];var s={model:r,view:n,projection:i,clipBounds:o,tubeScale:this.tubeScale,vectorScale:this.vectorScale,coneScale:this.coneScale,coneOffset:this.coneOffset,pickId:this.pickId/255},l=this.pickShader;l.bind(),l.uniforms=s,this.triangleCount>0&&(this.triangleVAO.bind(),t.drawArrays(t.TRIANGLES,0,3*this.triangleCount),this.triangleVAO.unbind())},p.pick=function(e){if(!e)return null;if(e.id!==this.pickId)return null;var t=e.value[0]+256*e.value[1]+65536*e.value[2],r=this.cells[t],n=this.positions[r[1]].slice(0,3),i={position:n,dataCoordinate:n,index:Math.floor(r[1]/48)};return"cone"===this.traceType?i.index=Math.floor(r[1]/48):"streamtube"===this.traceType&&(i.intensity=this.intensity[r[1]],i.velocity=this.vectors[r[1]].slice(0,3),i.divergence=this.vectors[r[1]][3],i.index=t),i},p.dispose=function(){this.texture.dispose(),this.triShader.dispose(),this.pickShader.dispose(),this.triangleVAO.dispose(),this.trianglePositions.dispose(),this.triangleVectors.dispose(),this.triangleColors.dispose(),this.triangleUVs.dispose(),this.triangleIds.dispose()},e.exports=function(e,t,r){var s=r.shaders;1===arguments.length&&(e=(t=e).gl);var l=function(e,t){var r=n(e,t.meshShader.vertex,t.meshShader.fragment,null,t.meshShader.attributes);return r.attributes.position.location=0,r.attributes.color.location=2,r.attributes.uv.location=3,r.attributes.vector.location=4,r}(e,s),u=function(e,t){var r=n(e,t.pickShader.vertex,t.pickShader.fragment,null,t.pickShader.attributes);return r.attributes.position.location=0,r.attributes.id.location=1,r.attributes.vector.location=4,r}(e,s),d=a(e,c(new Uint8Array([255,255,255,255]),[1,1,4]));d.generateMipmap(),d.minFilter=e.LINEAR_MIPMAP_LINEAR,d.magFilter=e.LINEAR;var p=i(e),f=i(e),m=i(e),g=i(e),y=i(e),v=new h(e,d,l,u,p,f,y,m,g,o(e,[{buffer:p,type:e.FLOAT,size:4},{buffer:y,type:e.UNSIGNED_BYTE,size:4,normalized:!0},{buffer:m,type:e.FLOAT,size:4},{buffer:g,type:e.FLOAT,size:2},{buffer:f,type:e.FLOAT,size:4}]),r.traceType||"cone");return v.update(t),v}},614:function(e,t,r){var n=r(3236),i=n(["precision highp float;\n\nprecision highp float;\n#define GLSLIFY 1\n\nvec3 getOrthogonalVector(vec3 v) {\n // Return up-vector for only-z vector.\n // Return ax + by + cz = 0, a point that lies on the plane that has v as a normal and that isn't (0,0,0).\n // From the above if-statement we have ||a|| > 0 U ||b|| > 0.\n // Assign z = 0, x = -b, y = a:\n // a*-b + b*a + c*0 = -ba + ba + 0 = 0\n if (v.x*v.x > v.z*v.z || v.y*v.y > v.z*v.z) {\n return normalize(vec3(-v.y, v.x, 0.0));\n } else {\n return normalize(vec3(0.0, v.z, -v.y));\n }\n}\n\n// Calculate the cone vertex and normal at the given index.\n//\n// The returned vertex is for a cone with its top at origin and height of 1.0,\n// pointing in the direction of the vector attribute.\n//\n// Each cone is made up of a top vertex, a center base vertex and base perimeter vertices.\n// These vertices are used to make up the triangles of the cone by the following:\n// segment + 0 top vertex\n// segment + 1 perimeter vertex a+1\n// segment + 2 perimeter vertex a\n// segment + 3 center base vertex\n// segment + 4 perimeter vertex a\n// segment + 5 perimeter vertex a+1\n// Where segment is the number of the radial segment * 6 and a is the angle at that radial segment.\n// To go from index to segment, floor(index / 6)\n// To go from segment to angle, 2*pi * (segment/segmentCount)\n// To go from index to segment index, index - (segment*6)\n//\nvec3 getConePosition(vec3 d, float rawIndex, float coneOffset, out vec3 normal) {\n\n const float segmentCount = 8.0;\n\n float index = rawIndex - floor(rawIndex /\n (segmentCount * 6.0)) *\n (segmentCount * 6.0);\n\n float segment = floor(0.001 + index/6.0);\n float segmentIndex = index - (segment*6.0);\n\n normal = -normalize(d);\n\n if (segmentIndex > 2.99 && segmentIndex < 3.01) {\n return mix(vec3(0.0), -d, coneOffset);\n }\n\n float nextAngle = (\n (segmentIndex > 0.99 && segmentIndex < 1.01) ||\n (segmentIndex > 4.99 && segmentIndex < 5.01)\n ) ? 1.0 : 0.0;\n float angle = 2.0 * 3.14159 * ((segment + nextAngle) / segmentCount);\n\n vec3 v1 = mix(d, vec3(0.0), coneOffset);\n vec3 v2 = v1 - d;\n\n vec3 u = getOrthogonalVector(d);\n vec3 v = normalize(cross(u, d));\n\n vec3 x = u * cos(angle) * length(d)*0.25;\n vec3 y = v * sin(angle) * length(d)*0.25;\n vec3 v3 = v2 + x + y;\n if (segmentIndex < 3.0) {\n vec3 tx = u * sin(angle);\n vec3 ty = v * -cos(angle);\n vec3 tangent = tx + ty;\n normal = normalize(cross(v3 - v1, tangent));\n }\n\n if (segmentIndex == 0.0) {\n return mix(d, vec3(0.0), coneOffset);\n }\n return v3;\n}\n\nattribute vec3 vector;\nattribute vec4 color, position;\nattribute vec2 uv;\n\nuniform float vectorScale, coneScale, coneOffset;\nuniform mat4 model, view, projection, inverseModel;\nuniform vec3 eyePosition, lightPosition;\n\nvarying vec3 f_normal, f_lightDirection, f_eyeDirection, f_data, f_position;\nvarying vec4 f_color;\nvarying vec2 f_uv;\n\nvoid main() {\n // Scale the vector magnitude to stay constant with\n // model & view changes.\n vec3 normal;\n vec3 XYZ = getConePosition(mat3(model) * ((vectorScale * coneScale) * vector), position.w, coneOffset, normal);\n vec4 conePosition = model * vec4(position.xyz, 1.0) + vec4(XYZ, 0.0);\n\n //Lighting geometry parameters\n vec4 cameraCoordinate = view * conePosition;\n cameraCoordinate.xyz /= cameraCoordinate.w;\n f_lightDirection = lightPosition - cameraCoordinate.xyz;\n f_eyeDirection = eyePosition - cameraCoordinate.xyz;\n f_normal = normalize((vec4(normal, 0.0) * inverseModel).xyz);\n\n // vec4 m_position = model * vec4(conePosition, 1.0);\n vec4 t_position = view * conePosition;\n gl_Position = projection * t_position;\n\n f_color = color;\n f_data = conePosition.xyz;\n f_position = position.xyz;\n f_uv = uv;\n}\n"]),o=n(["#extension GL_OES_standard_derivatives : enable\n\nprecision highp float;\n#define GLSLIFY 1\n\nfloat beckmannDistribution(float x, float roughness) {\n float NdotH = max(x, 0.0001);\n float cos2Alpha = NdotH * NdotH;\n float tan2Alpha = (cos2Alpha - 1.0) / cos2Alpha;\n float roughness2 = roughness * roughness;\n float denom = 3.141592653589793 * roughness2 * cos2Alpha * cos2Alpha;\n return exp(tan2Alpha / roughness2) / denom;\n}\n\nfloat cookTorranceSpecular(\n vec3 lightDirection,\n vec3 viewDirection,\n vec3 surfaceNormal,\n float roughness,\n float fresnel) {\n\n float VdotN = max(dot(viewDirection, surfaceNormal), 0.0);\n float LdotN = max(dot(lightDirection, surfaceNormal), 0.0);\n\n //Half angle vector\n vec3 H = normalize(lightDirection + viewDirection);\n\n //Geometric term\n float NdotH = max(dot(surfaceNormal, H), 0.0);\n float VdotH = max(dot(viewDirection, H), 0.000001);\n float LdotH = max(dot(lightDirection, H), 0.000001);\n float G1 = (2.0 * NdotH * VdotN) / VdotH;\n float G2 = (2.0 * NdotH * LdotN) / LdotH;\n float G = min(1.0, min(G1, G2));\n \n //Distribution term\n float D = beckmannDistribution(NdotH, roughness);\n\n //Fresnel term\n float F = pow(1.0 - VdotN, fresnel);\n\n //Multiply terms and done\n return G * F * D / max(3.14159265 * VdotN, 0.000001);\n}\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nuniform vec3 clipBounds[2];\nuniform float roughness, fresnel, kambient, kdiffuse, kspecular, opacity;\nuniform sampler2D texture;\n\nvarying vec3 f_normal, f_lightDirection, f_eyeDirection, f_data, f_position;\nvarying vec4 f_color;\nvarying vec2 f_uv;\n\nvoid main() {\n if (outOfRange(clipBounds[0], clipBounds[1], f_position)) discard;\n vec3 N = normalize(f_normal);\n vec3 L = normalize(f_lightDirection);\n vec3 V = normalize(f_eyeDirection);\n\n if(gl_FrontFacing) {\n N = -N;\n }\n\n float specular = min(1.0, max(0.0, cookTorranceSpecular(L, V, N, roughness, fresnel)));\n float diffuse = min(kambient + kdiffuse * max(dot(N, L), 0.0), 1.0);\n\n vec4 surfaceColor = f_color * texture2D(texture, f_uv);\n vec4 litColor = surfaceColor.a * vec4(diffuse * surfaceColor.rgb + kspecular * vec3(1,1,1) * specular, 1.0);\n\n gl_FragColor = litColor * opacity;\n}\n"]),a=n(["precision highp float;\n\nprecision highp float;\n#define GLSLIFY 1\n\nvec3 getOrthogonalVector(vec3 v) {\n // Return up-vector for only-z vector.\n // Return ax + by + cz = 0, a point that lies on the plane that has v as a normal and that isn't (0,0,0).\n // From the above if-statement we have ||a|| > 0 U ||b|| > 0.\n // Assign z = 0, x = -b, y = a:\n // a*-b + b*a + c*0 = -ba + ba + 0 = 0\n if (v.x*v.x > v.z*v.z || v.y*v.y > v.z*v.z) {\n return normalize(vec3(-v.y, v.x, 0.0));\n } else {\n return normalize(vec3(0.0, v.z, -v.y));\n }\n}\n\n// Calculate the cone vertex and normal at the given index.\n//\n// The returned vertex is for a cone with its top at origin and height of 1.0,\n// pointing in the direction of the vector attribute.\n//\n// Each cone is made up of a top vertex, a center base vertex and base perimeter vertices.\n// These vertices are used to make up the triangles of the cone by the following:\n// segment + 0 top vertex\n// segment + 1 perimeter vertex a+1\n// segment + 2 perimeter vertex a\n// segment + 3 center base vertex\n// segment + 4 perimeter vertex a\n// segment + 5 perimeter vertex a+1\n// Where segment is the number of the radial segment * 6 and a is the angle at that radial segment.\n// To go from index to segment, floor(index / 6)\n// To go from segment to angle, 2*pi * (segment/segmentCount)\n// To go from index to segment index, index - (segment*6)\n//\nvec3 getConePosition(vec3 d, float rawIndex, float coneOffset, out vec3 normal) {\n\n const float segmentCount = 8.0;\n\n float index = rawIndex - floor(rawIndex /\n (segmentCount * 6.0)) *\n (segmentCount * 6.0);\n\n float segment = floor(0.001 + index/6.0);\n float segmentIndex = index - (segment*6.0);\n\n normal = -normalize(d);\n\n if (segmentIndex > 2.99 && segmentIndex < 3.01) {\n return mix(vec3(0.0), -d, coneOffset);\n }\n\n float nextAngle = (\n (segmentIndex > 0.99 && segmentIndex < 1.01) ||\n (segmentIndex > 4.99 && segmentIndex < 5.01)\n ) ? 1.0 : 0.0;\n float angle = 2.0 * 3.14159 * ((segment + nextAngle) / segmentCount);\n\n vec3 v1 = mix(d, vec3(0.0), coneOffset);\n vec3 v2 = v1 - d;\n\n vec3 u = getOrthogonalVector(d);\n vec3 v = normalize(cross(u, d));\n\n vec3 x = u * cos(angle) * length(d)*0.25;\n vec3 y = v * sin(angle) * length(d)*0.25;\n vec3 v3 = v2 + x + y;\n if (segmentIndex < 3.0) {\n vec3 tx = u * sin(angle);\n vec3 ty = v * -cos(angle);\n vec3 tangent = tx + ty;\n normal = normalize(cross(v3 - v1, tangent));\n }\n\n if (segmentIndex == 0.0) {\n return mix(d, vec3(0.0), coneOffset);\n }\n return v3;\n}\n\nattribute vec4 vector;\nattribute vec4 position;\nattribute vec4 id;\n\nuniform mat4 model, view, projection;\nuniform float vectorScale, coneScale, coneOffset;\n\nvarying vec3 f_position;\nvarying vec4 f_id;\n\nvoid main() {\n vec3 normal;\n vec3 XYZ = getConePosition(mat3(model) * ((vectorScale * coneScale) * vector.xyz), position.w, coneOffset, normal);\n vec4 conePosition = model * vec4(position.xyz, 1.0) + vec4(XYZ, 0.0);\n gl_Position = projection * (view * conePosition);\n f_id = id;\n f_position = position.xyz;\n}\n"]),s=n(["precision highp float;\n#define GLSLIFY 1\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nuniform vec3 clipBounds[2];\nuniform float pickId;\n\nvarying vec3 f_position;\nvarying vec4 f_id;\n\nvoid main() {\n if (outOfRange(clipBounds[0], clipBounds[1], f_position)) discard;\n\n gl_FragColor = vec4(pickId, f_id.xyz);\n}"]);t.meshShader={vertex:i,fragment:o,attributes:[{name:"position",type:"vec4"},{name:"color",type:"vec4"},{name:"uv",type:"vec2"},{name:"vector",type:"vec3"}]},t.pickShader={vertex:a,fragment:s,attributes:[{name:"position",type:"vec4"},{name:"id",type:"vec4"},{name:"vector",type:"vec3"}]}},737:function(e){e.exports={0:"NONE",1:"ONE",2:"LINE_LOOP",3:"LINE_STRIP",4:"TRIANGLES",5:"TRIANGLE_STRIP",6:"TRIANGLE_FAN",256:"DEPTH_BUFFER_BIT",512:"NEVER",513:"LESS",514:"EQUAL",515:"LEQUAL",516:"GREATER",517:"NOTEQUAL",518:"GEQUAL",519:"ALWAYS",768:"SRC_COLOR",769:"ONE_MINUS_SRC_COLOR",770:"SRC_ALPHA",771:"ONE_MINUS_SRC_ALPHA",772:"DST_ALPHA",773:"ONE_MINUS_DST_ALPHA",774:"DST_COLOR",775:"ONE_MINUS_DST_COLOR",776:"SRC_ALPHA_SATURATE",1024:"STENCIL_BUFFER_BIT",1028:"FRONT",1029:"BACK",1032:"FRONT_AND_BACK",1280:"INVALID_ENUM",1281:"INVALID_VALUE",1282:"INVALID_OPERATION",1285:"OUT_OF_MEMORY",1286:"INVALID_FRAMEBUFFER_OPERATION",2304:"CW",2305:"CCW",2849:"LINE_WIDTH",2884:"CULL_FACE",2885:"CULL_FACE_MODE",2886:"FRONT_FACE",2928:"DEPTH_RANGE",2929:"DEPTH_TEST",2930:"DEPTH_WRITEMASK",2931:"DEPTH_CLEAR_VALUE",2932:"DEPTH_FUNC",2960:"STENCIL_TEST",2961:"STENCIL_CLEAR_VALUE",2962:"STENCIL_FUNC",2963:"STENCIL_VALUE_MASK",2964:"STENCIL_FAIL",2965:"STENCIL_PASS_DEPTH_FAIL",2966:"STENCIL_PASS_DEPTH_PASS",2967:"STENCIL_REF",2968:"STENCIL_WRITEMASK",2978:"VIEWPORT",3024:"DITHER",3042:"BLEND",3088:"SCISSOR_BOX",3089:"SCISSOR_TEST",3106:"COLOR_CLEAR_VALUE",3107:"COLOR_WRITEMASK",3317:"UNPACK_ALIGNMENT",3333:"PACK_ALIGNMENT",3379:"MAX_TEXTURE_SIZE",3386:"MAX_VIEWPORT_DIMS",3408:"SUBPIXEL_BITS",3410:"RED_BITS",3411:"GREEN_BITS",3412:"BLUE_BITS",3413:"ALPHA_BITS",3414:"DEPTH_BITS",3415:"STENCIL_BITS",3553:"TEXTURE_2D",4352:"DONT_CARE",4353:"FASTEST",4354:"NICEST",5120:"BYTE",5121:"UNSIGNED_BYTE",5122:"SHORT",5123:"UNSIGNED_SHORT",5124:"INT",5125:"UNSIGNED_INT",5126:"FLOAT",5386:"INVERT",5890:"TEXTURE",6401:"STENCIL_INDEX",6402:"DEPTH_COMPONENT",6406:"ALPHA",6407:"RGB",6408:"RGBA",6409:"LUMINANCE",6410:"LUMINANCE_ALPHA",7680:"KEEP",7681:"REPLACE",7682:"INCR",7683:"DECR",7936:"VENDOR",7937:"RENDERER",7938:"VERSION",9728:"NEAREST",9729:"LINEAR",9984:"NEAREST_MIPMAP_NEAREST",9985:"LINEAR_MIPMAP_NEAREST",9986:"NEAREST_MIPMAP_LINEAR",9987:"LINEAR_MIPMAP_LINEAR",10240:"TEXTURE_MAG_FILTER",10241:"TEXTURE_MIN_FILTER",10242:"TEXTURE_WRAP_S",10243:"TEXTURE_WRAP_T",10497:"REPEAT",10752:"POLYGON_OFFSET_UNITS",16384:"COLOR_BUFFER_BIT",32769:"CONSTANT_COLOR",32770:"ONE_MINUS_CONSTANT_COLOR",32771:"CONSTANT_ALPHA",32772:"ONE_MINUS_CONSTANT_ALPHA",32773:"BLEND_COLOR",32774:"FUNC_ADD",32777:"BLEND_EQUATION_RGB",32778:"FUNC_SUBTRACT",32779:"FUNC_REVERSE_SUBTRACT",32819:"UNSIGNED_SHORT_4_4_4_4",32820:"UNSIGNED_SHORT_5_5_5_1",32823:"POLYGON_OFFSET_FILL",32824:"POLYGON_OFFSET_FACTOR",32854:"RGBA4",32855:"RGB5_A1",32873:"TEXTURE_BINDING_2D",32926:"SAMPLE_ALPHA_TO_COVERAGE",32928:"SAMPLE_COVERAGE",32936:"SAMPLE_BUFFERS",32937:"SAMPLES",32938:"SAMPLE_COVERAGE_VALUE",32939:"SAMPLE_COVERAGE_INVERT",32968:"BLEND_DST_RGB",32969:"BLEND_SRC_RGB",32970:"BLEND_DST_ALPHA",32971:"BLEND_SRC_ALPHA",33071:"CLAMP_TO_EDGE",33170:"GENERATE_MIPMAP_HINT",33189:"DEPTH_COMPONENT16",33306:"DEPTH_STENCIL_ATTACHMENT",33635:"UNSIGNED_SHORT_5_6_5",33648:"MIRRORED_REPEAT",33901:"ALIASED_POINT_SIZE_RANGE",33902:"ALIASED_LINE_WIDTH_RANGE",33984:"TEXTURE0",33985:"TEXTURE1",33986:"TEXTURE2",33987:"TEXTURE3",33988:"TEXTURE4",33989:"TEXTURE5",33990:"TEXTURE6",33991:"TEXTURE7",33992:"TEXTURE8",33993:"TEXTURE9",33994:"TEXTURE10",33995:"TEXTURE11",33996:"TEXTURE12",33997:"TEXTURE13",33998:"TEXTURE14",33999:"TEXTURE15",34e3:"TEXTURE16",34001:"TEXTURE17",34002:"TEXTURE18",34003:"TEXTURE19",34004:"TEXTURE20",34005:"TEXTURE21",34006:"TEXTURE22",34007:"TEXTURE23",34008:"TEXTURE24",34009:"TEXTURE25",34010:"TEXTURE26",34011:"TEXTURE27",34012:"TEXTURE28",34013:"TEXTURE29",34014:"TEXTURE30",34015:"TEXTURE31",34016:"ACTIVE_TEXTURE",34024:"MAX_RENDERBUFFER_SIZE",34041:"DEPTH_STENCIL",34055:"INCR_WRAP",34056:"DECR_WRAP",34067:"TEXTURE_CUBE_MAP",34068:"TEXTURE_BINDING_CUBE_MAP",34069:"TEXTURE_CUBE_MAP_POSITIVE_X",34070:"TEXTURE_CUBE_MAP_NEGATIVE_X",34071:"TEXTURE_CUBE_MAP_POSITIVE_Y",34072:"TEXTURE_CUBE_MAP_NEGATIVE_Y",34073:"TEXTURE_CUBE_MAP_POSITIVE_Z",34074:"TEXTURE_CUBE_MAP_NEGATIVE_Z",34076:"MAX_CUBE_MAP_TEXTURE_SIZE",34338:"VERTEX_ATTRIB_ARRAY_ENABLED",34339:"VERTEX_ATTRIB_ARRAY_SIZE",34340:"VERTEX_ATTRIB_ARRAY_STRIDE",34341:"VERTEX_ATTRIB_ARRAY_TYPE",34342:"CURRENT_VERTEX_ATTRIB",34373:"VERTEX_ATTRIB_ARRAY_POINTER",34466:"NUM_COMPRESSED_TEXTURE_FORMATS",34467:"COMPRESSED_TEXTURE_FORMATS",34660:"BUFFER_SIZE",34661:"BUFFER_USAGE",34816:"STENCIL_BACK_FUNC",34817:"STENCIL_BACK_FAIL",34818:"STENCIL_BACK_PASS_DEPTH_FAIL",34819:"STENCIL_BACK_PASS_DEPTH_PASS",34877:"BLEND_EQUATION_ALPHA",34921:"MAX_VERTEX_ATTRIBS",34922:"VERTEX_ATTRIB_ARRAY_NORMALIZED",34930:"MAX_TEXTURE_IMAGE_UNITS",34962:"ARRAY_BUFFER",34963:"ELEMENT_ARRAY_BUFFER",34964:"ARRAY_BUFFER_BINDING",34965:"ELEMENT_ARRAY_BUFFER_BINDING",34975:"VERTEX_ATTRIB_ARRAY_BUFFER_BINDING",35040:"STREAM_DRAW",35044:"STATIC_DRAW",35048:"DYNAMIC_DRAW",35632:"FRAGMENT_SHADER",35633:"VERTEX_SHADER",35660:"MAX_VERTEX_TEXTURE_IMAGE_UNITS",35661:"MAX_COMBINED_TEXTURE_IMAGE_UNITS",35663:"SHADER_TYPE",35664:"FLOAT_VEC2",35665:"FLOAT_VEC3",35666:"FLOAT_VEC4",35667:"INT_VEC2",35668:"INT_VEC3",35669:"INT_VEC4",35670:"BOOL",35671:"BOOL_VEC2",35672:"BOOL_VEC3",35673:"BOOL_VEC4",35674:"FLOAT_MAT2",35675:"FLOAT_MAT3",35676:"FLOAT_MAT4",35678:"SAMPLER_2D",35680:"SAMPLER_CUBE",35712:"DELETE_STATUS",35713:"COMPILE_STATUS",35714:"LINK_STATUS",35715:"VALIDATE_STATUS",35716:"INFO_LOG_LENGTH",35717:"ATTACHED_SHADERS",35718:"ACTIVE_UNIFORMS",35719:"ACTIVE_UNIFORM_MAX_LENGTH",35720:"SHADER_SOURCE_LENGTH",35721:"ACTIVE_ATTRIBUTES",35722:"ACTIVE_ATTRIBUTE_MAX_LENGTH",35724:"SHADING_LANGUAGE_VERSION",35725:"CURRENT_PROGRAM",36003:"STENCIL_BACK_REF",36004:"STENCIL_BACK_VALUE_MASK",36005:"STENCIL_BACK_WRITEMASK",36006:"FRAMEBUFFER_BINDING",36007:"RENDERBUFFER_BINDING",36048:"FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE",36049:"FRAMEBUFFER_ATTACHMENT_OBJECT_NAME",36050:"FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL",36051:"FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE",36053:"FRAMEBUFFER_COMPLETE",36054:"FRAMEBUFFER_INCOMPLETE_ATTACHMENT",36055:"FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT",36057:"FRAMEBUFFER_INCOMPLETE_DIMENSIONS",36061:"FRAMEBUFFER_UNSUPPORTED",36064:"COLOR_ATTACHMENT0",36096:"DEPTH_ATTACHMENT",36128:"STENCIL_ATTACHMENT",36160:"FRAMEBUFFER",36161:"RENDERBUFFER",36162:"RENDERBUFFER_WIDTH",36163:"RENDERBUFFER_HEIGHT",36164:"RENDERBUFFER_INTERNAL_FORMAT",36168:"STENCIL_INDEX8",36176:"RENDERBUFFER_RED_SIZE",36177:"RENDERBUFFER_GREEN_SIZE",36178:"RENDERBUFFER_BLUE_SIZE",36179:"RENDERBUFFER_ALPHA_SIZE",36180:"RENDERBUFFER_DEPTH_SIZE",36181:"RENDERBUFFER_STENCIL_SIZE",36194:"RGB565",36336:"LOW_FLOAT",36337:"MEDIUM_FLOAT",36338:"HIGH_FLOAT",36339:"LOW_INT",36340:"MEDIUM_INT",36341:"HIGH_INT",36346:"SHADER_COMPILER",36347:"MAX_VERTEX_UNIFORM_VECTORS",36348:"MAX_VARYING_VECTORS",36349:"MAX_FRAGMENT_UNIFORM_VECTORS",37440:"UNPACK_FLIP_Y_WEBGL",37441:"UNPACK_PREMULTIPLY_ALPHA_WEBGL",37442:"CONTEXT_LOST_WEBGL",37443:"UNPACK_COLORSPACE_CONVERSION_WEBGL",37444:"BROWSER_DEFAULT_WEBGL"}},5171:function(e,t,r){var n=r(737);e.exports=function(e){return n[e]}},9165:function(e,t,r){"use strict";e.exports=function(e){var t=e.gl,r=n(t),a=i(t,[{buffer:r,type:t.FLOAT,size:3,offset:0,stride:40},{buffer:r,type:t.FLOAT,size:4,offset:12,stride:40},{buffer:r,type:t.FLOAT,size:3,offset:28,stride:40}]),l=o(t);l.attributes.position.location=0,l.attributes.color.location=1,l.attributes.offset.location=2;var c=new s(t,r,a,l);return c.update(e),c};var n=r(2762),i=r(8116),o=r(3436),a=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1];function s(e,t,r,n){this.gl=e,this.shader=n,this.buffer=t,this.vao=r,this.pixelRatio=1,this.bounds=[[1/0,1/0,1/0],[-1/0,-1/0,-1/0]],this.clipBounds=[[-1/0,-1/0,-1/0],[1/0,1/0,1/0]],this.lineWidth=[1,1,1],this.capSize=[10,10,10],this.lineCount=[0,0,0],this.lineOffset=[0,0,0],this.opacity=1,this.hasAlpha=!1}var l=s.prototype;function c(e,t){for(var r=0;r<3;++r)e[0][r]=Math.min(e[0][r],t[r]),e[1][r]=Math.max(e[1][r],t[r])}l.isOpaque=function(){return!this.hasAlpha},l.isTransparent=function(){return this.hasAlpha},l.drawTransparent=l.draw=function(e){var t=this.gl,r=this.shader.uniforms;this.shader.bind();var n=r.view=e.view||a,i=r.projection=e.projection||a;r.model=e.model||a,r.clipBounds=this.clipBounds,r.opacity=this.opacity;var o=n[12],s=n[13],l=n[14],c=n[15],u=(e._ortho||!1?2:1)*this.pixelRatio*(i[3]*o+i[7]*s+i[11]*l+i[15]*c)/t.drawingBufferHeight;this.vao.bind();for(var d=0;d<3;++d)t.lineWidth(this.lineWidth[d]*this.pixelRatio),r.capSize=this.capSize[d]*u,this.lineCount[d]&&t.drawArrays(t.LINES,this.lineOffset[d],this.lineCount[d]);this.vao.unbind()};var u=function(){for(var e=new Array(3),t=0;t<3;++t){for(var r=[],n=1;n<=2;++n)for(var i=-1;i<=1;i+=2){var o=[0,0,0];o[(n+t)%3]=i,r.push(o)}e[t]=r}return e}();function d(e,t,r,n){for(var i=u[n],o=0;o0)(m=u.slice())[s]+=p[1][s],i.push(u[0],u[1],u[2],f[0],f[1],f[2],f[3],0,0,0,m[0],m[1],m[2],f[0],f[1],f[2],f[3],0,0,0),c(this.bounds,m),a+=2+d(i,m,f,s)}}this.lineCount[s]=a-this.lineOffset[s]}this.buffer.update(i)}},l.dispose=function(){this.shader.dispose(),this.buffer.dispose(),this.vao.dispose()}},3436:function(e,t,r){"use strict";var n=r(3236),i=r(9405),o=n(["precision highp float;\n#define GLSLIFY 1\n\nattribute vec3 position, offset;\nattribute vec4 color;\nuniform mat4 model, view, projection;\nuniform float capSize;\nvarying vec4 fragColor;\nvarying vec3 fragPosition;\n\nvoid main() {\n vec4 worldPosition = model * vec4(position, 1.0);\n worldPosition = (worldPosition / worldPosition.w) + vec4(capSize * offset, 0.0);\n gl_Position = projection * (view * worldPosition);\n fragColor = color;\n fragPosition = position;\n}"]),a=n(["precision highp float;\n#define GLSLIFY 1\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nuniform vec3 clipBounds[2];\nuniform float opacity;\nvarying vec3 fragPosition;\nvarying vec4 fragColor;\n\nvoid main() {\n if (\n outOfRange(clipBounds[0], clipBounds[1], fragPosition) ||\n fragColor.a * opacity == 0.\n ) discard;\n\n gl_FragColor = opacity * fragColor;\n}"]);e.exports=function(e){return i(e,o,a,null,[{name:"position",type:"vec3"},{name:"color",type:"vec4"},{name:"offset",type:"vec3"}])}},2260:function(e,t,r){"use strict";var n=r(7766);e.exports=function(e,t,r,n){i||(i=e.FRAMEBUFFER_UNSUPPORTED,o=e.FRAMEBUFFER_INCOMPLETE_ATTACHMENT,a=e.FRAMEBUFFER_INCOMPLETE_DIMENSIONS,s=e.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT);var c=e.getExtension("WEBGL_draw_buffers");!l&&c&&function(e,t){var r=e.getParameter(t.MAX_COLOR_ATTACHMENTS_WEBGL);l=new Array(r+1);for(var n=0;n<=r;++n){for(var i=new Array(r),o=0;ou||r<0||r>u)throw new Error("gl-fbo: Parameters are too large for FBO");var d=1;if("color"in(n=n||{})){if((d=Math.max(0|n.color,0))<0)throw new Error("gl-fbo: Must specify a nonnegative number of colors");if(d>1){if(!c)throw new Error("gl-fbo: Multiple draw buffer extension not supported");if(d>e.getParameter(c.MAX_COLOR_ATTACHMENTS_WEBGL))throw new Error("gl-fbo: Context does not support "+d+" draw buffers")}}var h=e.UNSIGNED_BYTE,p=e.getExtension("OES_texture_float");if(n.float&&d>0){if(!p)throw new Error("gl-fbo: Context does not support floating point textures");h=e.FLOAT}else n.preferFloat&&d>0&&p&&(h=e.FLOAT);var m=!0;"depth"in n&&(m=!!n.depth);var g=!1;"stencil"in n&&(g=!!n.stencil);return new f(e,t,r,h,d,m,g,c)};var i,o,a,s,l=null;function c(e){return[e.getParameter(e.FRAMEBUFFER_BINDING),e.getParameter(e.RENDERBUFFER_BINDING),e.getParameter(e.TEXTURE_BINDING_2D)]}function u(e,t){e.bindFramebuffer(e.FRAMEBUFFER,t[0]),e.bindRenderbuffer(e.RENDERBUFFER,t[1]),e.bindTexture(e.TEXTURE_2D,t[2])}function d(e){switch(e){case i:throw new Error("gl-fbo: Framebuffer unsupported");case o:throw new Error("gl-fbo: Framebuffer incomplete attachment");case a:throw new Error("gl-fbo: Framebuffer incomplete dimensions");case s:throw new Error("gl-fbo: Framebuffer incomplete missing attachment");default:throw new Error("gl-fbo: Framebuffer failed for unspecified reason")}}function h(e,t,r,i,o,a){if(!i)return null;var s=n(e,t,r,o,i);return s.magFilter=e.NEAREST,s.minFilter=e.NEAREST,s.mipSamples=1,s.bind(),e.framebufferTexture2D(e.FRAMEBUFFER,a,e.TEXTURE_2D,s.handle,0),s}function p(e,t,r,n,i){var o=e.createRenderbuffer();return e.bindRenderbuffer(e.RENDERBUFFER,o),e.renderbufferStorage(e.RENDERBUFFER,n,t,r),e.framebufferRenderbuffer(e.FRAMEBUFFER,i,e.RENDERBUFFER,o),o}function f(e,t,r,n,i,o,a,s){this.gl=e,this._shape=[0|t,0|r],this._destroyed=!1,this._ext=s,this.color=new Array(i);for(var f=0;f1&&s.drawBuffersWEBGL(l[a]);var v=r.getExtension("WEBGL_depth_texture");v?f?e.depth=h(r,i,o,v.UNSIGNED_INT_24_8_WEBGL,r.DEPTH_STENCIL,r.DEPTH_STENCIL_ATTACHMENT):m&&(e.depth=h(r,i,o,r.UNSIGNED_SHORT,r.DEPTH_COMPONENT,r.DEPTH_ATTACHMENT)):m&&f?e._depth_rb=p(r,i,o,r.DEPTH_STENCIL,r.DEPTH_STENCIL_ATTACHMENT):m?e._depth_rb=p(r,i,o,r.DEPTH_COMPONENT16,r.DEPTH_ATTACHMENT):f&&(e._depth_rb=p(r,i,o,r.STENCIL_INDEX,r.STENCIL_ATTACHMENT));var x=r.checkFramebufferStatus(r.FRAMEBUFFER);if(x!==r.FRAMEBUFFER_COMPLETE){for(e._destroyed=!0,r.bindFramebuffer(r.FRAMEBUFFER,null),r.deleteFramebuffer(e.handle),e.handle=null,e.depth&&(e.depth.dispose(),e.depth=null),e._depth_rb&&(r.deleteRenderbuffer(e._depth_rb),e._depth_rb=null),y=0;yi||r<0||r>i)throw new Error("gl-fbo: Can't resize FBO, invalid dimensions");e._shape[0]=t,e._shape[1]=r;for(var o=c(n),a=0;a>8*p&255;this.pickOffset=r,i.bind();var f=i.uniforms;f.viewTransform=e,f.pickOffset=t,f.shape=this.shape;var m=i.attributes;return this.positionBuffer.bind(),m.position.pointer(),this.weightBuffer.bind(),m.weight.pointer(s.UNSIGNED_BYTE,!1),this.idBuffer.bind(),m.pickId.pointer(s.UNSIGNED_BYTE,!1),s.drawArrays(s.TRIANGLES,0,a),r+this.shape[0]*this.shape[1]}}}(),u.pick=function(e,t,r){var n=this.pickOffset,i=this.shape[0]*this.shape[1];if(r=n+i)return null;var o=r-n,a=this.xData,s=this.yData;return{object:this,pointId:o,dataCoord:[a[o%this.shape[0]],s[o/this.shape[0]|0]]}},u.update=function(e){var t=(e=e||{}).shape||[0,0],r=e.x||i(t[0]),a=e.y||i(t[1]),s=e.z||new Float32Array(t[0]*t[1]),l=!1!==e.zsmooth;this.xData=r,this.yData=a;var c,u,h,p,f=e.colorLevels||[0],m=e.colorValues||[0,0,0,1],g=f.length,y=this.bounds;l?(c=y[0]=r[0],u=y[1]=a[0],h=y[2]=r[r.length-1],p=y[3]=a[a.length-1]):(c=y[0]=r[0]+(r[1]-r[0])/2,u=y[1]=a[0]+(a[1]-a[0])/2,h=y[2]=r[r.length-1]+(r[r.length-1]-r[r.length-2])/2,p=y[3]=a[a.length-1]+(a[a.length-1]-a[a.length-2])/2);var v=1/(h-c),x=1/(p-u),b=t[0],_=t[1];this.shape=[b,_];var w=(l?(b-1)*(_-1):b*_)*(d.length>>>1);this.numVertices=w;for(var k=o.mallocUint8(4*w),S=o.mallocFloat32(2*w),A=o.mallocUint8(2*w),T=o.mallocUint32(w),M=0,C=l?b-1:b,E=l?_-1:_,I=0;I max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nuniform vec3 clipBounds[2];\nuniform sampler2D dashTexture;\nuniform float dashScale;\nuniform float opacity;\n\nvarying vec3 worldPosition;\nvarying float pixelArcLength;\nvarying vec4 fragColor;\n\nvoid main() {\n if (\n outOfRange(clipBounds[0], clipBounds[1], worldPosition) ||\n fragColor.a * opacity == 0.\n ) discard;\n\n float dashWeight = texture2D(dashTexture, vec2(dashScale * pixelArcLength, 0)).r;\n if(dashWeight < 0.5) {\n discard;\n }\n gl_FragColor = fragColor * opacity;\n}\n"]),s=n(["precision highp float;\n#define GLSLIFY 1\n\n#define FLOAT_MAX 1.70141184e38\n#define FLOAT_MIN 1.17549435e-38\n\n// https://github.com/mikolalysenko/glsl-read-float/blob/master/index.glsl\nvec4 packFloat(float v) {\n float av = abs(v);\n\n //Handle special cases\n if(av < FLOAT_MIN) {\n return vec4(0.0, 0.0, 0.0, 0.0);\n } else if(v > FLOAT_MAX) {\n return vec4(127.0, 128.0, 0.0, 0.0) / 255.0;\n } else if(v < -FLOAT_MAX) {\n return vec4(255.0, 128.0, 0.0, 0.0) / 255.0;\n }\n\n vec4 c = vec4(0,0,0,0);\n\n //Compute exponent and mantissa\n float e = floor(log2(av));\n float m = av * pow(2.0, -e) - 1.0;\n\n //Unpack mantissa\n c[1] = floor(128.0 * m);\n m -= c[1] / 128.0;\n c[2] = floor(32768.0 * m);\n m -= c[2] / 32768.0;\n c[3] = floor(8388608.0 * m);\n\n //Unpack exponent\n float ebias = e + 127.0;\n c[0] = floor(ebias / 2.0);\n ebias -= c[0] * 2.0;\n c[1] += floor(ebias) * 128.0;\n\n //Unpack sign bit\n c[0] += 128.0 * step(0.0, -v);\n\n //Scale back to range\n return c / 255.0;\n}\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nuniform float pickId;\nuniform vec3 clipBounds[2];\n\nvarying vec3 worldPosition;\nvarying float pixelArcLength;\nvarying vec4 fragColor;\n\nvoid main() {\n if (outOfRange(clipBounds[0], clipBounds[1], worldPosition)) discard;\n\n gl_FragColor = vec4(pickId/255.0, packFloat(pixelArcLength).xyz);\n}"]),l=[{name:"position",type:"vec3"},{name:"nextPosition",type:"vec3"},{name:"arcLength",type:"float"},{name:"lineWidth",type:"float"},{name:"color",type:"vec4"}];t.createShader=function(e){return i(e,o,a,null,l)},t.createPickShader=function(e){return i(e,o,s,null,l)}},5714:function(e,t,r){"use strict";e.exports=function(e){var t=e.gl||e.scene&&e.scene.gl,r=d(t);r.attributes.position.location=0,r.attributes.nextPosition.location=1,r.attributes.arcLength.location=2,r.attributes.lineWidth.location=3,r.attributes.color.location=4;var a=h(t);a.attributes.position.location=0,a.attributes.nextPosition.location=1,a.attributes.arcLength.location=2,a.attributes.lineWidth.location=3,a.attributes.color.location=4;for(var s=n(t),l=i(t,[{buffer:s,size:3,offset:0,stride:48},{buffer:s,size:3,offset:12,stride:48},{buffer:s,size:1,offset:24,stride:48},{buffer:s,size:1,offset:28,stride:48},{buffer:s,size:4,offset:32,stride:48}]),u=c(new Array(1024),[256,1,4]),p=0;p<1024;++p)u.data[p]=255;var f=o(t,u);f.wrap=t.REPEAT;var m=new y(t,r,a,s,l,f);return m.update(e),m};var n=r(2762),i=r(8116),o=r(7766),a=new Uint8Array(4),s=new Float32Array(a.buffer);var l=r(2478),c=r(9618),u=r(7319),d=u.createShader,h=u.createPickShader,p=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1];function f(e,t){for(var r=0,n=0;n<3;++n){var i=e[n]-t[n];r+=i*i}return Math.sqrt(r)}function m(e){for(var t=[[-1e6,-1e6,-1e6],[1e6,1e6,1e6]],r=0;r<3;++r)t[0][r]=Math.max(e[0][r],t[0][r]),t[1][r]=Math.min(e[1][r],t[1][r]);return t}function g(e,t,r,n){this.arcLength=e,this.position=t,this.index=r,this.dataCoordinate=n}function y(e,t,r,n,i,o){this.gl=e,this.shader=t,this.pickShader=r,this.buffer=n,this.vao=i,this.clipBounds=[[-1/0,-1/0,-1/0],[1/0,1/0,1/0]],this.points=[],this.arcLength=[],this.vertexCount=0,this.bounds=[[0,0,0],[0,0,0]],this.pickId=0,this.lineWidth=1,this.texture=o,this.dashScale=1,this.opacity=1,this.hasAlpha=!1,this.dirty=!0,this.pixelRatio=1}var v=y.prototype;v.isTransparent=function(){return this.hasAlpha},v.isOpaque=function(){return!this.hasAlpha},v.pickSlots=1,v.setPickBase=function(e){this.pickId=e},v.drawTransparent=v.draw=function(e){if(this.vertexCount){var t=this.gl,r=this.shader,n=this.vao;r.bind(),r.uniforms={model:e.model||p,view:e.view||p,projection:e.projection||p,clipBounds:m(this.clipBounds),dashTexture:this.texture.bind(),dashScale:this.dashScale/this.arcLength[this.arcLength.length-1],opacity:this.opacity,screenShape:[t.drawingBufferWidth,t.drawingBufferHeight],pixelRatio:this.pixelRatio},n.bind(),n.draw(t.TRIANGLE_STRIP,this.vertexCount),n.unbind()}},v.drawPick=function(e){if(this.vertexCount){var t=this.gl,r=this.pickShader,n=this.vao;r.bind(),r.uniforms={model:e.model||p,view:e.view||p,projection:e.projection||p,pickId:this.pickId,clipBounds:m(this.clipBounds),screenShape:[t.drawingBufferWidth,t.drawingBufferHeight],pixelRatio:this.pixelRatio},n.bind(),n.draw(t.TRIANGLE_STRIP,this.vertexCount),n.unbind()}},v.update=function(e){var t,r;this.dirty=!0;var n=!!e.connectGaps;"dashScale"in e&&(this.dashScale=e.dashScale),this.hasAlpha=!1,"opacity"in e&&(this.opacity=+e.opacity,this.opacity<1&&(this.hasAlpha=!0));var i=[],o=[],a=[],s=0,u=0,d=[[1/0,1/0,1/0],[-1/0,-1/0,-1/0]],h=e.position||e.positions;if(h){var p=e.color||e.colors||[0,0,0,1],m=e.lineWidth||1,g=!1;e:for(t=1;t0){for(var w=0;w<24;++w)i.push(i[i.length-12]);u+=2,g=!0}continue e}d[0][r]=Math.min(d[0][r],b[r],_[r]),d[1][r]=Math.max(d[1][r],b[r],_[r])}Array.isArray(p[0])?(y=p.length>t-1?p[t-1]:p.length>0?p[p.length-1]:[0,0,0,1],v=p.length>t?p[t]:p.length>0?p[p.length-1]:[0,0,0,1]):y=v=p,3===y.length&&(y=[y[0],y[1],y[2],1]),3===v.length&&(v=[v[0],v[1],v[2],1]),!this.hasAlpha&&y[3]<1&&(this.hasAlpha=!0),x=Array.isArray(m)?m.length>t-1?m[t-1]:m.length>0?m[m.length-1]:[0,0,0,1]:m;var k=s;if(s+=f(b,_),g){for(r=0;r<2;++r)i.push(b[0],b[1],b[2],_[0],_[1],_[2],k,x,y[0],y[1],y[2],y[3]);u+=2,g=!1}i.push(b[0],b[1],b[2],_[0],_[1],_[2],k,x,y[0],y[1],y[2],y[3],b[0],b[1],b[2],_[0],_[1],_[2],k,-x,y[0],y[1],y[2],y[3],_[0],_[1],_[2],b[0],b[1],b[2],s,-x,v[0],v[1],v[2],v[3],_[0],_[1],_[2],b[0],b[1],b[2],s,x,v[0],v[1],v[2],v[3]),u+=4}}if(this.buffer.update(i),o.push(s),a.push(h[h.length-1].slice()),this.bounds=d,this.vertexCount=u,this.points=a,this.arcLength=o,"dashes"in e){var S=e.dashes.slice();for(S.unshift(0),t=1;t1.0001)return null;y+=g[d]}if(Math.abs(y-1)>.001)return null;return[h,s(e,g),g]}},840:function(e,t,r){var n=r(3236),i=n(["precision highp float;\n#define GLSLIFY 1\n\nattribute vec3 position, normal;\nattribute vec4 color;\nattribute vec2 uv;\n\nuniform mat4 model\n , view\n , projection\n , inverseModel;\nuniform vec3 eyePosition\n , lightPosition;\n\nvarying vec3 f_normal\n , f_lightDirection\n , f_eyeDirection\n , f_data;\nvarying vec4 f_color;\nvarying vec2 f_uv;\n\nvec4 project(vec3 p) {\n return projection * (view * (model * vec4(p, 1.0)));\n}\n\nvoid main() {\n gl_Position = project(position);\n\n //Lighting geometry parameters\n vec4 cameraCoordinate = view * vec4(position , 1.0);\n cameraCoordinate.xyz /= cameraCoordinate.w;\n f_lightDirection = lightPosition - cameraCoordinate.xyz;\n f_eyeDirection = eyePosition - cameraCoordinate.xyz;\n f_normal = normalize((vec4(normal, 0.0) * inverseModel).xyz);\n\n f_color = color;\n f_data = position;\n f_uv = uv;\n}\n"]),o=n(["#extension GL_OES_standard_derivatives : enable\n\nprecision highp float;\n#define GLSLIFY 1\n\nfloat beckmannDistribution(float x, float roughness) {\n float NdotH = max(x, 0.0001);\n float cos2Alpha = NdotH * NdotH;\n float tan2Alpha = (cos2Alpha - 1.0) / cos2Alpha;\n float roughness2 = roughness * roughness;\n float denom = 3.141592653589793 * roughness2 * cos2Alpha * cos2Alpha;\n return exp(tan2Alpha / roughness2) / denom;\n}\n\nfloat cookTorranceSpecular(\n vec3 lightDirection,\n vec3 viewDirection,\n vec3 surfaceNormal,\n float roughness,\n float fresnel) {\n\n float VdotN = max(dot(viewDirection, surfaceNormal), 0.0);\n float LdotN = max(dot(lightDirection, surfaceNormal), 0.0);\n\n //Half angle vector\n vec3 H = normalize(lightDirection + viewDirection);\n\n //Geometric term\n float NdotH = max(dot(surfaceNormal, H), 0.0);\n float VdotH = max(dot(viewDirection, H), 0.000001);\n float LdotH = max(dot(lightDirection, H), 0.000001);\n float G1 = (2.0 * NdotH * VdotN) / VdotH;\n float G2 = (2.0 * NdotH * LdotN) / LdotH;\n float G = min(1.0, min(G1, G2));\n \n //Distribution term\n float D = beckmannDistribution(NdotH, roughness);\n\n //Fresnel term\n float F = pow(1.0 - VdotN, fresnel);\n\n //Multiply terms and done\n return G * F * D / max(3.14159265 * VdotN, 0.000001);\n}\n\n//#pragma glslify: beckmann = require(glsl-specular-beckmann) // used in gl-surface3d\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nuniform vec3 clipBounds[2];\nuniform float roughness\n , fresnel\n , kambient\n , kdiffuse\n , kspecular;\nuniform sampler2D texture;\n\nvarying vec3 f_normal\n , f_lightDirection\n , f_eyeDirection\n , f_data;\nvarying vec4 f_color;\nvarying vec2 f_uv;\n\nvoid main() {\n if (f_color.a == 0.0 ||\n outOfRange(clipBounds[0], clipBounds[1], f_data)\n ) discard;\n\n vec3 N = normalize(f_normal);\n vec3 L = normalize(f_lightDirection);\n vec3 V = normalize(f_eyeDirection);\n\n if(gl_FrontFacing) {\n N = -N;\n }\n\n float specular = min(1.0, max(0.0, cookTorranceSpecular(L, V, N, roughness, fresnel)));\n //float specular = max(0.0, beckmann(L, V, N, roughness)); // used in gl-surface3d\n\n float diffuse = min(kambient + kdiffuse * max(dot(N, L), 0.0), 1.0);\n\n vec4 surfaceColor = vec4(f_color.rgb, 1.0) * texture2D(texture, f_uv);\n vec4 litColor = surfaceColor.a * vec4(diffuse * surfaceColor.rgb + kspecular * vec3(1,1,1) * specular, 1.0);\n\n gl_FragColor = litColor * f_color.a;\n}\n"]),a=n(["precision highp float;\n#define GLSLIFY 1\n\nattribute vec3 position;\nattribute vec4 color;\nattribute vec2 uv;\n\nuniform mat4 model, view, projection;\n\nvarying vec4 f_color;\nvarying vec3 f_data;\nvarying vec2 f_uv;\n\nvoid main() {\n gl_Position = projection * (view * (model * vec4(position, 1.0)));\n f_color = color;\n f_data = position;\n f_uv = uv;\n}"]),s=n(["precision highp float;\n#define GLSLIFY 1\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nuniform vec3 clipBounds[2];\nuniform sampler2D texture;\nuniform float opacity;\n\nvarying vec4 f_color;\nvarying vec3 f_data;\nvarying vec2 f_uv;\n\nvoid main() {\n if (outOfRange(clipBounds[0], clipBounds[1], f_data)) discard;\n\n gl_FragColor = f_color * texture2D(texture, f_uv) * opacity;\n}"]),l=n(["precision highp float;\n#define GLSLIFY 1\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nattribute vec3 position;\nattribute vec4 color;\nattribute vec2 uv;\nattribute float pointSize;\n\nuniform mat4 model, view, projection;\nuniform vec3 clipBounds[2];\n\nvarying vec4 f_color;\nvarying vec2 f_uv;\n\nvoid main() {\n if (outOfRange(clipBounds[0], clipBounds[1], position)) {\n\n gl_Position = vec4(0.0, 0.0 ,0.0 ,0.0);\n } else {\n gl_Position = projection * (view * (model * vec4(position, 1.0)));\n }\n gl_PointSize = pointSize;\n f_color = color;\n f_uv = uv;\n}"]),c=n(["precision highp float;\n#define GLSLIFY 1\n\nuniform sampler2D texture;\nuniform float opacity;\n\nvarying vec4 f_color;\nvarying vec2 f_uv;\n\nvoid main() {\n vec2 pointR = gl_PointCoord.xy - vec2(0.5, 0.5);\n if(dot(pointR, pointR) > 0.25) {\n discard;\n }\n gl_FragColor = f_color * texture2D(texture, f_uv) * opacity;\n}"]),u=n(["precision highp float;\n#define GLSLIFY 1\n\nattribute vec3 position;\nattribute vec4 id;\n\nuniform mat4 model, view, projection;\n\nvarying vec3 f_position;\nvarying vec4 f_id;\n\nvoid main() {\n gl_Position = projection * (view * (model * vec4(position, 1.0)));\n f_id = id;\n f_position = position;\n}"]),d=n(["precision highp float;\n#define GLSLIFY 1\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nuniform vec3 clipBounds[2];\nuniform float pickId;\n\nvarying vec3 f_position;\nvarying vec4 f_id;\n\nvoid main() {\n if (outOfRange(clipBounds[0], clipBounds[1], f_position)) discard;\n\n gl_FragColor = vec4(pickId, f_id.xyz);\n}"]),h=n(["precision highp float;\n#define GLSLIFY 1\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nattribute vec3 position;\nattribute float pointSize;\nattribute vec4 id;\n\nuniform mat4 model, view, projection;\nuniform vec3 clipBounds[2];\n\nvarying vec3 f_position;\nvarying vec4 f_id;\n\nvoid main() {\n if (outOfRange(clipBounds[0], clipBounds[1], position)) {\n\n gl_Position = vec4(0.0, 0.0, 0.0, 0.0);\n } else {\n gl_Position = projection * (view * (model * vec4(position, 1.0)));\n gl_PointSize = pointSize;\n }\n f_id = id;\n f_position = position;\n}"]),p=n(["precision highp float;\n#define GLSLIFY 1\n\nattribute vec3 position;\n\nuniform mat4 model, view, projection;\n\nvoid main() {\n gl_Position = projection * (view * (model * vec4(position, 1.0)));\n}"]),f=n(["precision highp float;\n#define GLSLIFY 1\n\nuniform vec3 contourColor;\n\nvoid main() {\n gl_FragColor = vec4(contourColor, 1.0);\n}\n"]);t.meshShader={vertex:i,fragment:o,attributes:[{name:"position",type:"vec3"},{name:"normal",type:"vec3"},{name:"color",type:"vec4"},{name:"uv",type:"vec2"}]},t.wireShader={vertex:a,fragment:s,attributes:[{name:"position",type:"vec3"},{name:"color",type:"vec4"},{name:"uv",type:"vec2"}]},t.pointShader={vertex:l,fragment:c,attributes:[{name:"position",type:"vec3"},{name:"color",type:"vec4"},{name:"uv",type:"vec2"},{name:"pointSize",type:"float"}]},t.pickShader={vertex:u,fragment:d,attributes:[{name:"position",type:"vec3"},{name:"id",type:"vec4"}]},t.pointPickShader={vertex:h,fragment:d,attributes:[{name:"position",type:"vec3"},{name:"pointSize",type:"float"},{name:"id",type:"vec4"}]},t.contourShader={vertex:p,fragment:f,attributes:[{name:"position",type:"vec3"}]}},7201:function(e,t,r){"use strict";var n=r(9405),i=r(2762),o=r(8116),a=r(7766),s=r(8406),l=r(6760),c=r(7608),u=r(9618),d=r(6729),h=r(7765),p=r(1888),f=r(840),m=r(7626),g=f.meshShader,y=f.wireShader,v=f.pointShader,x=f.pickShader,b=f.pointPickShader,_=f.contourShader,w=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1];function k(e,t,r,n,i,o,a,s,l,c,u,d,h,p,f,m,g,y,v,x,b,_,k,S,A,T,M){this.gl=e,this.pixelRatio=1,this.cells=[],this.positions=[],this.intensity=[],this.texture=t,this.dirty=!0,this.triShader=r,this.lineShader=n,this.pointShader=i,this.pickShader=o,this.pointPickShader=a,this.contourShader=s,this.trianglePositions=l,this.triangleColors=u,this.triangleNormals=h,this.triangleUVs=d,this.triangleIds=c,this.triangleVAO=p,this.triangleCount=0,this.lineWidth=1,this.edgePositions=f,this.edgeColors=g,this.edgeUVs=y,this.edgeIds=m,this.edgeVAO=v,this.edgeCount=0,this.pointPositions=x,this.pointColors=_,this.pointUVs=k,this.pointSizes=S,this.pointIds=b,this.pointVAO=A,this.pointCount=0,this.contourLineWidth=1,this.contourPositions=T,this.contourVAO=M,this.contourCount=0,this.contourColor=[0,0,0],this.contourEnable=!0,this.pickVertex=!0,this.pickId=1,this.bounds=[[1/0,1/0,1/0],[-1/0,-1/0,-1/0]],this.clipBounds=[[-1/0,-1/0,-1/0],[1/0,1/0,1/0]],this.lightPosition=[1e5,1e5,0],this.ambientLight=.8,this.diffuseLight=.8,this.specularLight=2,this.roughness=.5,this.fresnel=1.5,this.opacity=1,this.hasAlpha=!1,this.opacityscale=!1,this._model=w,this._view=w,this._projection=w,this._resolution=[1,1]}var S=k.prototype;function A(e,t){if(!t)return 1;if(!t.length)return 1;for(var r=0;re&&r>0){var n=(t[r][0]-e)/(t[r][0]-t[r-1][0]);return t[r][1]*(1-n)+n*t[r-1][1]}}return 1}function T(e){var t=n(e,v.vertex,v.fragment);return t.attributes.position.location=0,t.attributes.color.location=2,t.attributes.uv.location=3,t.attributes.pointSize.location=4,t}function M(e){var t=n(e,x.vertex,x.fragment);return t.attributes.position.location=0,t.attributes.id.location=1,t}function C(e){var t=n(e,b.vertex,b.fragment);return t.attributes.position.location=0,t.attributes.id.location=1,t.attributes.pointSize.location=4,t}function E(e){var t=n(e,_.vertex,_.fragment);return t.attributes.position.location=0,t}S.isOpaque=function(){return!this.hasAlpha},S.isTransparent=function(){return this.hasAlpha},S.pickSlots=1,S.setPickBase=function(e){this.pickId=e},S.highlight=function(e){if(e&&this.contourEnable){for(var t=h(this.cells,this.intensity,e.intensity),r=t.cells,n=t.vertexIds,i=t.vertexWeights,o=r.length,a=p.mallocFloat32(6*o),s=0,l=0;l0&&((d=this.triShader).bind(),d.uniforms=s,this.triangleVAO.bind(),t.drawArrays(t.TRIANGLES,0,3*this.triangleCount),this.triangleVAO.unbind());this.edgeCount>0&&this.lineWidth>0&&((d=this.lineShader).bind(),d.uniforms=s,this.edgeVAO.bind(),t.lineWidth(this.lineWidth*this.pixelRatio),t.drawArrays(t.LINES,0,2*this.edgeCount),this.edgeVAO.unbind());this.pointCount>0&&((d=this.pointShader).bind(),d.uniforms=s,this.pointVAO.bind(),t.drawArrays(t.POINTS,0,this.pointCount),this.pointVAO.unbind());this.contourEnable&&this.contourCount>0&&this.contourLineWidth>0&&((d=this.contourShader).bind(),d.uniforms=s,this.contourVAO.bind(),t.drawArrays(t.LINES,0,this.contourCount),this.contourVAO.unbind())},S.drawPick=function(e){e=e||{};for(var t=this.gl,r=e.model||w,n=e.view||w,i=e.projection||w,o=[[-1e6,-1e6,-1e6],[1e6,1e6,1e6]],a=0;a<3;++a)o[0][a]=Math.max(o[0][a],this.clipBounds[0][a]),o[1][a]=Math.min(o[1][a],this.clipBounds[1][a]);this._model=[].slice.call(r),this._view=[].slice.call(n),this._projection=[].slice.call(i),this._resolution=[t.drawingBufferWidth,t.drawingBufferHeight];var s,l={model:r,view:n,projection:i,clipBounds:o,pickId:this.pickId/255};((s=this.pickShader).bind(),s.uniforms=l,this.triangleCount>0&&(this.triangleVAO.bind(),t.drawArrays(t.TRIANGLES,0,3*this.triangleCount),this.triangleVAO.unbind()),this.edgeCount>0&&(this.edgeVAO.bind(),t.lineWidth(this.lineWidth*this.pixelRatio),t.drawArrays(t.LINES,0,2*this.edgeCount),this.edgeVAO.unbind()),this.pointCount>0)&&((s=this.pointPickShader).bind(),s.uniforms=l,this.pointVAO.bind(),t.drawArrays(t.POINTS,0,this.pointCount),this.pointVAO.unbind())},S.pick=function(e){if(!e)return null;if(e.id!==this.pickId)return null;for(var t=e.value[0]+256*e.value[1]+65536*e.value[2],r=this.cells[t],n=this.positions,i=new Array(r.length),o=0;ol[S]&&(o.uniforms.dataAxis=e,o.uniforms.screenOffset=t,o.uniforms.color=g[n],o.uniforms.angle=y[n],c.drawArrays(c.TRIANGLES,l[S],l[A]-l[S]))),v[n]&&k&&(t[1^n]-=T*p*x[n],o.uniforms.dataAxis=r,o.uniforms.screenOffset=t,o.uniforms.color=b[n],o.uniforms.angle=_[n],c.drawArrays(c.TRIANGLES,w,k)),t[1^n]=T*u[2+(1^n)]-1,f[n+2]&&(t[1^n]+=T*p*m[n+2],Sl[S]&&(o.uniforms.dataAxis=e,o.uniforms.screenOffset=t,o.uniforms.color=g[n+2],o.uniforms.angle=y[n+2],c.drawArrays(c.TRIANGLES,l[S],l[A]-l[S]))),v[n+2]&&k&&(t[1^n]+=T*p*x[n+2],o.uniforms.dataAxis=r,o.uniforms.screenOffset=t,o.uniforms.color=b[n+2],o.uniforms.angle=_[n+2],c.drawArrays(c.TRIANGLES,w,k))}}(),c.drawTitle=function(){var e=[0,0],t=[0,0];return function(){var r=this.plot,n=this.shader,i=r.gl,o=r.screenBox,a=r.titleCenter,s=r.titleAngle,l=r.titleColor,c=r.pixelRatio;if(this.titleCount){for(var u=0;u<2;++u)t[u]=2*(a[u]*c-o[u])/(o[2+u]-o[u])-1;n.bind(),n.uniforms.dataAxis=e,n.uniforms.screenOffset=t,n.uniforms.angle=s,n.uniforms.color=l,i.drawArrays(i.TRIANGLES,this.titleOffset,this.titleCount)}}}(),c.bind=function(){var e=[0,0],t=[0,0],r=[0,0];return function(){var n=this.plot,i=this.shader,o=n._tickBounds,a=n.dataBox,s=n.screenBox,l=n.viewBox;i.bind();for(var c=0;c<2;++c){var u=o[c],d=o[c+2]-u,h=.5*(a[c+2]+a[c]),p=a[c+2]-a[c],f=l[c],m=l[c+2]-f,g=s[c],y=s[c+2]-g;t[c]=2*d/p*m/y,e[c]=2*(u-h)/p*m/y}r[1]=2*n.pixelRatio/(s[3]-s[1]),r[0]=r[1]*(s[3]-s[1])/(s[2]-s[0]),i.uniforms.dataScale=t,i.uniforms.dataShift=e,i.uniforms.textScale=r,this.vbo.bind(),i.attributes.textCoordinate.pointer()}}(),c.update=function(e){var t,r,n,i,a,s=[],l=e.ticks,c=e.bounds;for(a=0;a<2;++a){var u=[Math.floor(s.length/3)],d=[-1/0],h=l[a];for(t=0;t=0){var m=t[f]-n[f]*(t[f+2]-t[f])/(n[f+2]-n[f]);0===f?a.drawLine(m,t[1],m,t[3],p[f],h[f]):a.drawLine(t[0],m,t[2],m,p[f],h[f])}}for(f=0;f=0;--e)this.objects[e].dispose();this.objects.length=0;for(e=this.overlays.length-1;e>=0;--e)this.overlays[e].dispose();this.overlays.length=0,this.gl=null},c.addObject=function(e){this.objects.indexOf(e)<0&&(this.objects.push(e),this.setDirty())},c.removeObject=function(e){for(var t=this.objects,r=0;rMath.abs(t))c.rotate(o,0,0,-e*r*Math.PI*f.rotateSpeed/window.innerWidth);else if(!f._ortho){var a=-f.zoomSpeed*i*t/window.innerHeight*(o-c.lastT())/20;c.pan(o,0,0,d*(Math.exp(a)-1))}}}),!0)},f.enableMouseListeners(),f};var n=r(3025),i=r(6296),o=r(351),a=r(8512),s=r(24),l=r(7520)},799:function(e,t,r){var n=r(3236),i=r(9405),o=n(["precision mediump float;\n#define GLSLIFY 1\nattribute vec2 position;\nvarying vec2 uv;\nvoid main() {\n uv = position;\n gl_Position = vec4(position, 0, 1);\n}"]),a=n(["precision mediump float;\n#define GLSLIFY 1\n\nuniform sampler2D accumBuffer;\nvarying vec2 uv;\n\nvoid main() {\n vec4 accum = texture2D(accumBuffer, 0.5 * (uv + 1.0));\n gl_FragColor = min(vec4(1,1,1,1), accum);\n}"]);e.exports=function(e){return i(e,o,a,null,[{name:"position",type:"vec2"}])}},4100:function(e,t,r){"use strict";var n=r(4437),i=r(3837),o=r(5445),a=r(4449),s=r(3589),l=r(2260),c=r(7169),u=r(351),d=r(4772),h=r(4040),p=r(799),f=r(9216)({tablet:!0,featureDetect:!0});function m(){this.mouse=[-1,-1],this.screen=null,this.distance=1/0,this.index=null,this.dataCoordinate=null,this.dataPosition=null,this.object=null,this.data=null}function g(e){var t=Math.round(Math.log(Math.abs(e))/Math.log(10));if(t<0){var r=Math.round(Math.pow(10,-t));return Math.ceil(e*r)/r}if(t>0){r=Math.round(Math.pow(10,t));return Math.ceil(e/r)*r}return Math.ceil(e)}function y(e){return"boolean"!==typeof e||e}e.exports={createScene:function(e){(e=e||{}).camera=e.camera||{};var t=e.canvas;if(!t){if(t=document.createElement("canvas"),e.container)e.container.appendChild(t);else document.body.appendChild(t)}var r=e.gl;r||(e.glOptions&&(f=!!e.glOptions.preserveDrawingBuffer),r=function(e,t){var r=null;try{(r=e.getContext("webgl",t))||(r=e.getContext("experimental-webgl",t))}catch(n){return null}return r}(t,e.glOptions||{premultipliedAlpha:!0,antialias:!0,preserveDrawingBuffer:f}));if(!r)throw new Error("webgl not supported");var v=e.bounds||[[-10,-10,-10],[10,10,10]],x=new m,b=l(r,r.drawingBufferWidth,r.drawingBufferHeight,{preferFloat:!f}),_=p(r),w=e.cameraObject&&!0===e.cameraObject._ortho||e.camera.projection&&"orthographic"===e.camera.projection.type||!1,k={eye:e.camera.eye||[2,0,0],center:e.camera.center||[0,0,0],up:e.camera.up||[0,1,0],zoomMin:e.camera.zoomMax||.1,zoomMax:e.camera.zoomMin||100,mode:e.camera.mode||"turntable",_ortho:w},S=e.axes||{},A=i(r,S);A.enable=!S.disable;var T=e.spikes||{},M=a(r,T),C=[],E=[],I=[],P=[],O=!0,R=!0,L=new Array(16),D=new Array(16),z={view:null,projection:L,model:D,_ortho:!1},j=(R=!0,[r.drawingBufferWidth,r.drawingBufferHeight]),F=e.cameraObject||n(t,k),N={gl:r,contextLost:!1,pixelRatio:e.pixelRatio||1,canvas:t,selection:x,camera:F,axes:A,axesPixels:null,spikes:M,bounds:v,objects:C,shape:j,aspect:e.aspectRatio||[1,1,1],pickRadius:e.pickRadius||10,zNear:e.zNear||.01,zFar:e.zFar||1e3,fovy:e.fovy||Math.PI/4,clearColor:e.clearColor||[0,0,0,0],autoResize:y(e.autoResize),autoBounds:y(e.autoBounds),autoScale:!!e.autoScale,autoCenter:y(e.autoCenter),clipToBounds:y(e.clipToBounds),snapToData:!!e.snapToData,onselect:e.onselect||null,onrender:e.onrender||null,onclick:e.onclick||null,cameraParams:z,oncontextloss:null,mouseListener:null,_stopped:!1,getAspectratio:function(){return{x:this.aspect[0],y:this.aspect[1],z:this.aspect[2]}},setAspectratio:function(e){this.aspect[0]=e.x,this.aspect[1]=e.y,this.aspect[2]=e.z,R=!0},setBounds:function(e,t){this.bounds[0][e]=t.min,this.bounds[1][e]=t.max},setClearColor:function(e){this.clearColor=e},clearRGBA:function(){this.gl.clearColor(this.clearColor[0],this.clearColor[1],this.clearColor[2],this.clearColor[3]),this.gl.clear(this.gl.COLOR_BUFFER_BIT|this.gl.DEPTH_BUFFER_BIT)}},B=[r.drawingBufferWidth/N.pixelRatio|0,r.drawingBufferHeight/N.pixelRatio|0];function V(){if(!N._stopped&&N.autoResize){var e=t.parentNode,r=1,n=1;e&&e!==document.body?(r=e.clientWidth,n=e.clientHeight):(r=window.innerWidth,n=window.innerHeight);var i=0|Math.ceil(r*N.pixelRatio),o=0|Math.ceil(n*N.pixelRatio);if(i!==t.width||o!==t.height){t.width=i,t.height=o;var a=t.style;a.position=a.position||"absolute",a.left="0px",a.top="0px",a.width=r+"px",a.height=n+"px",O=!0}}}N.autoResize&&V();function U(){for(var e=C.length,t=P.length,n=0;n0&&0===I[t-1];)I.pop(),P.pop().dispose()}function H(){if(N.contextLost)return!0;r.isContextLost()&&(N.contextLost=!0,N.mouseListener.enabled=!1,N.selection.object=null,N.oncontextloss&&N.oncontextloss())}window.addEventListener("resize",V),N.update=function(e){N._stopped||(e=e||{},O=!0,R=!0)},N.add=function(e){N._stopped||(e.axes=A,C.push(e),E.push(-1),O=!0,R=!0,U())},N.remove=function(e){if(!N._stopped){var t=C.indexOf(e);t<0||(C.splice(t,1),E.pop(),O=!0,R=!0,U())}},N.dispose=function(){if(!N._stopped&&(N._stopped=!0,window.removeEventListener("resize",V),t.removeEventListener("webglcontextlost",H),N.mouseListener.enabled=!1,!N.contextLost)){A.dispose(),M.dispose();for(var e=0;ex.distance)continue;for(var c=0;c 1.0) {\n discard;\n }\n baseColor = mix(borderColor, color, step(radius, centerFraction));\n gl_FragColor = vec4(baseColor.rgb * baseColor.a, baseColor.a);\n }\n}\n"]),t.pickVertex=n(["precision mediump float;\n#define GLSLIFY 1\n\nattribute vec2 position;\nattribute vec4 pickId;\n\nuniform mat3 matrix;\nuniform float pointSize;\nuniform vec4 pickOffset;\n\nvarying vec4 fragId;\n\nvoid main() {\n vec3 hgPosition = matrix * vec3(position, 1);\n gl_Position = vec4(hgPosition.xy, 0, hgPosition.z);\n gl_PointSize = pointSize;\n\n vec4 id = pickId + pickOffset;\n id.y += floor(id.x / 256.0);\n id.x -= floor(id.x / 256.0) * 256.0;\n\n id.z += floor(id.y / 256.0);\n id.y -= floor(id.y / 256.0) * 256.0;\n\n id.w += floor(id.z / 256.0);\n id.z -= floor(id.z / 256.0) * 256.0;\n\n fragId = id;\n}\n"]),t.pickFragment=n(["precision mediump float;\n#define GLSLIFY 1\n\nvarying vec4 fragId;\n\nvoid main() {\n float radius = length(2.0 * gl_PointCoord.xy - 1.0);\n if(radius > 1.0) {\n discard;\n }\n gl_FragColor = fragId / 255.0;\n}\n"])},4696:function(e,t,r){"use strict";var n=r(9405),i=r(2762),o=r(1888),a=r(6640);function s(e,t,r,n,i){this.plot=e,this.offsetBuffer=t,this.pickBuffer=r,this.shader=n,this.pickShader=i,this.sizeMin=.5,this.sizeMinCap=2,this.sizeMax=20,this.areaRatio=1,this.pointCount=0,this.color=[1,0,0,1],this.borderColor=[0,0,0,1],this.blend=!1,this.pickOffset=0,this.points=null}e.exports=function(e,t){var r=e.gl,o=i(r),l=i(r),c=n(r,a.pointVertex,a.pointFragment),u=n(r,a.pickVertex,a.pickFragment),d=new s(e,o,l,c,u);return d.update(t),e.addObject(d),d};var l=s.prototype;l.dispose=function(){this.shader.dispose(),this.pickShader.dispose(),this.offsetBuffer.dispose(),this.pickBuffer.dispose(),this.plot.removeObject(this)},l.update=function(e){var t;function r(t,r){return t in e?e[t]:r}e=e||{},this.sizeMin=r("sizeMin",.5),this.sizeMax=r("sizeMax",20),this.color=r("color",[1,0,0,1]).slice(),this.areaRatio=r("areaRatio",1),this.borderColor=r("borderColor",[0,0,0,1]).slice(),this.blend=r("blend",!1);var n=e.positions.length>>>1,i=e.positions instanceof Float32Array,a=e.idToIndex instanceof Int32Array&&e.idToIndex.length>=n,s=e.positions,l=i?s:o.mallocFloat32(s.length),c=a?e.idToIndex:o.mallocInt32(n);if(i||l.set(s),!a)for(l.set(s),t=0;t>>1;for(r=0;r=t[0]&&o<=t[2]&&a>=t[1]&&a<=t[3]&&n++}return n}(this.points,a),u=this.plot.pickPixelRatio*Math.max(Math.min(this.sizeMinCap,this.sizeMin),Math.min(this.sizeMax,this.sizeMax/Math.pow(c,.33333)));e[0]=2/s,e[4]=2/l,e[6]=-2*a[0]/s-1,e[7]=-2*a[1]/l-1,this.offsetBuffer.bind(),i.bind(),i.attributes.position.pointer(),i.uniforms.matrix=e,i.uniforms.color=this.color,i.uniforms.borderColor=this.borderColor,i.uniforms.pointCloud=u<5,i.uniforms.pointSize=u,i.uniforms.centerFraction=Math.min(1,Math.max(0,Math.sqrt(1-this.areaRatio))),n&&(t[0]=255&r,t[1]=r>>8&255,t[2]=r>>16&255,t[3]=r>>24&255,this.pickBuffer.bind(),i.attributes.pickId.pointer(o.UNSIGNED_BYTE),i.uniforms.pickOffset=t,this.pickOffset=r);var d=o.getParameter(o.BLEND),h=o.getParameter(o.DITHER);return d&&!this.blend&&o.disable(o.BLEND),h&&o.disable(o.DITHER),o.drawArrays(o.POINTS,0,this.pointCount),d&&!this.blend&&o.enable(o.BLEND),h&&o.enable(o.DITHER),r+this.pointCount}}(),l.draw=l.unifiedDraw,l.drawPick=l.unifiedDraw,l.pick=function(e,t,r){var n=this.pickOffset,i=this.pointCount;if(r=n+i)return null;var o=r-n,a=this.points;return{object:this,pointId:o,dataCoord:[a[2*o],a[2*o+1]]}}},783:function(e){e.exports=function(e,t,r,n){var i,o,a,s,l,c=t[0],u=t[1],d=t[2],h=t[3],p=r[0],f=r[1],m=r[2],g=r[3];(o=c*p+u*f+d*m+h*g)<0&&(o=-o,p=-p,f=-f,m=-m,g=-g);1-o>1e-6?(i=Math.acos(o),a=Math.sin(i),s=Math.sin((1-n)*i)/a,l=Math.sin(n*i)/a):(s=1-n,l=n);return e[0]=s*c+l*p,e[1]=s*u+l*f,e[2]=s*d+l*m,e[3]=s*h+l*g,e}},5964:function(e){"use strict";e.exports=function(e){return e||0===e?e.toString():""}},9366:function(e,t,r){"use strict";var n=r(4359);e.exports=function(e,t,r){var o=[t.style,t.weight,t.variant,t.family].join("_"),a=i[o];a||(a=i[o]={});if(e in a)return a[e];var s={textAlign:"center",textBaseline:"middle",lineHeight:1,font:t.family,fontStyle:t.style,fontWeight:t.weight,fontVariant:t.variant,lineSpacing:1.25,styletags:{breaklines:!0,bolds:!0,italics:!0,subscripts:!0,superscripts:!0},triangles:!0},l=n(e,s);s.triangles=!1;var c,u,d=n(e,s);if(r&&1!==r){for(c=0;c max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nattribute vec3 position;\nattribute vec4 color;\nattribute vec2 glyph;\nattribute vec4 id;\n\nuniform vec4 highlightId;\nuniform float highlightScale;\nuniform mat4 model, view, projection;\nuniform vec3 clipBounds[2];\n\nvarying vec4 interpColor;\nvarying vec4 pickId;\nvarying vec3 dataCoordinate;\n\nvoid main() {\n if (outOfRange(clipBounds[0], clipBounds[1], position)) {\n\n gl_Position = vec4(0,0,0,0);\n } else {\n float scale = 1.0;\n if(distance(highlightId, id) < 0.0001) {\n scale = highlightScale;\n }\n\n vec4 worldPosition = model * vec4(position, 1);\n vec4 viewPosition = view * worldPosition;\n viewPosition = viewPosition / viewPosition.w;\n vec4 clipPosition = projection * (viewPosition + scale * vec4(glyph.x, -glyph.y, 0, 0));\n\n gl_Position = clipPosition;\n interpColor = color;\n pickId = id;\n dataCoordinate = position;\n }\n}"]),a=i(["precision highp float;\n#define GLSLIFY 1\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nattribute vec3 position;\nattribute vec4 color;\nattribute vec2 glyph;\nattribute vec4 id;\n\nuniform mat4 model, view, projection;\nuniform vec2 screenSize;\nuniform vec3 clipBounds[2];\nuniform float highlightScale, pixelRatio;\nuniform vec4 highlightId;\n\nvarying vec4 interpColor;\nvarying vec4 pickId;\nvarying vec3 dataCoordinate;\n\nvoid main() {\n if (outOfRange(clipBounds[0], clipBounds[1], position)) {\n\n gl_Position = vec4(0,0,0,0);\n } else {\n float scale = pixelRatio;\n if(distance(highlightId.bgr, id.bgr) < 0.001) {\n scale *= highlightScale;\n }\n\n vec4 worldPosition = model * vec4(position, 1.0);\n vec4 viewPosition = view * worldPosition;\n vec4 clipPosition = projection * viewPosition;\n clipPosition /= clipPosition.w;\n\n gl_Position = clipPosition + vec4(screenSize * scale * vec2(glyph.x, -glyph.y), 0.0, 0.0);\n interpColor = color;\n pickId = id;\n dataCoordinate = position;\n }\n}"]),s=i(["precision highp float;\n#define GLSLIFY 1\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nattribute vec3 position;\nattribute vec4 color;\nattribute vec2 glyph;\nattribute vec4 id;\n\nuniform float highlightScale;\nuniform vec4 highlightId;\nuniform vec3 axes[2];\nuniform mat4 model, view, projection;\nuniform vec2 screenSize;\nuniform vec3 clipBounds[2];\nuniform float scale, pixelRatio;\n\nvarying vec4 interpColor;\nvarying vec4 pickId;\nvarying vec3 dataCoordinate;\n\nvoid main() {\n if (outOfRange(clipBounds[0], clipBounds[1], position)) {\n\n gl_Position = vec4(0,0,0,0);\n } else {\n float lscale = pixelRatio * scale;\n if(distance(highlightId, id) < 0.0001) {\n lscale *= highlightScale;\n }\n\n vec4 clipCenter = projection * (view * (model * vec4(position, 1)));\n vec3 dataPosition = position + 0.5*lscale*(axes[0] * glyph.x + axes[1] * glyph.y) * clipCenter.w * screenSize.y;\n vec4 clipPosition = projection * (view * (model * vec4(dataPosition, 1)));\n\n gl_Position = clipPosition;\n interpColor = color;\n pickId = id;\n dataCoordinate = dataPosition;\n }\n}\n"]),l=i(["precision highp float;\n#define GLSLIFY 1\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nuniform vec3 fragClipBounds[2];\nuniform float opacity;\n\nvarying vec4 interpColor;\nvarying vec3 dataCoordinate;\n\nvoid main() {\n if (\n outOfRange(fragClipBounds[0], fragClipBounds[1], dataCoordinate) ||\n interpColor.a * opacity == 0.\n ) discard;\n gl_FragColor = interpColor * opacity;\n}\n"]),c=i(["precision highp float;\n#define GLSLIFY 1\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nuniform vec3 fragClipBounds[2];\nuniform float pickGroup;\n\nvarying vec4 pickId;\nvarying vec3 dataCoordinate;\n\nvoid main() {\n if (outOfRange(fragClipBounds[0], fragClipBounds[1], dataCoordinate)) discard;\n\n gl_FragColor = vec4(pickGroup, pickId.bgr);\n}"]),u=[{name:"position",type:"vec3"},{name:"color",type:"vec4"},{name:"glyph",type:"vec2"},{name:"id",type:"vec4"}],d={vertex:o,fragment:l,attributes:u},h={vertex:a,fragment:l,attributes:u},p={vertex:s,fragment:l,attributes:u},f={vertex:o,fragment:c,attributes:u},m={vertex:a,fragment:c,attributes:u},g={vertex:s,fragment:c,attributes:u};function y(e,t){var r=n(e,t),i=r.attributes;return i.position.location=0,i.color.location=1,i.glyph.location=2,i.id.location=3,r}t.createPerspective=function(e){return y(e,d)},t.createOrtho=function(e){return y(e,h)},t.createProject=function(e){return y(e,p)},t.createPickPerspective=function(e){return y(e,f)},t.createPickOrtho=function(e){return y(e,m)},t.createPickProject=function(e){return y(e,g)}},8418:function(e,t,r){"use strict";var n=r(5219),i=r(2762),o=r(8116),a=r(1888),s=r(6760),l=r(1283),c=r(9366),u=r(5964),d=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1],h=ArrayBuffer,p=DataView;function f(e){return Array.isArray(e)||function(e){return h.isView(e)&&!(e instanceof p)}(e)}function m(e,t){var r=e[0],n=e[1],i=e[2],o=e[3];return e[0]=t[0]*r+t[4]*n+t[8]*i+t[12]*o,e[1]=t[1]*r+t[5]*n+t[9]*i+t[13]*o,e[2]=t[2]*r+t[6]*n+t[10]*i+t[14]*o,e[3]=t[3]*r+t[7]*n+t[11]*i+t[15]*o,e}function g(e,t,r,n){return m(n,n),m(n,n),m(n,n)}function y(e,t){this.index=e,this.dataCoordinate=this.position=t}function v(e){return!0===e||e>1?1:e}function x(e,t,r,n,i,o,a,s,l,c,u,d){this.gl=e,this.pixelRatio=1,this.shader=t,this.orthoShader=r,this.projectShader=n,this.pointBuffer=i,this.colorBuffer=o,this.glyphBuffer=a,this.idBuffer=s,this.vao=l,this.vertexCount=0,this.lineVertexCount=0,this.opacity=1,this.hasAlpha=!1,this.lineWidth=0,this.projectScale=[2/3,2/3,2/3],this.projectOpacity=[1,1,1],this.projectHasAlpha=!1,this.pickId=0,this.pickPerspectiveShader=c,this.pickOrthoShader=u,this.pickProjectShader=d,this.points=[],this._selectResult=new y(0,[0,0,0]),this.useOrtho=!0,this.bounds=[[1/0,1/0,1/0],[-1/0,-1/0,-1/0]],this.axesProject=[!0,!0,!0],this.axesBounds=[[-1/0,-1/0,-1/0],[1/0,1/0,1/0]],this.highlightId=[1,1,1,1],this.highlightScale=2,this.clipBounds=[[-1/0,-1/0,-1/0],[1/0,1/0,1/0]],this.dirty=!0}e.exports=function(e){var t=e.gl,r=l.createPerspective(t),n=l.createOrtho(t),a=l.createProject(t),s=l.createPickPerspective(t),c=l.createPickOrtho(t),u=l.createPickProject(t),d=i(t),h=i(t),p=i(t),f=i(t),m=o(t,[{buffer:d,size:3,type:t.FLOAT},{buffer:h,size:4,type:t.FLOAT},{buffer:p,size:2,type:t.FLOAT},{buffer:f,size:4,type:t.UNSIGNED_BYTE,normalized:!0}]),g=new x(t,r,n,a,d,h,p,f,m,s,c,u);return g.update(e),g};var b=x.prototype;b.pickSlots=1,b.setPickBase=function(e){this.pickId=e},b.isTransparent=function(){if(this.hasAlpha)return!0;for(var e=0;e<3;++e)if(this.axesProject[e]&&this.projectHasAlpha)return!0;return!1},b.isOpaque=function(){if(!this.hasAlpha)return!0;for(var e=0;e<3;++e)if(this.axesProject[e]&&!this.projectHasAlpha)return!0;return!1};var _=[0,0],w=[0,0,0],k=[0,0,0],S=[0,0,0,1],A=[0,0,0,1],T=d.slice(),M=[0,0,0],C=[[0,0,0],[0,0,0]];function E(e){return e[0]=e[1]=e[2]=0,e}function I(e,t){return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=1,e}function P(e,t,r,n){return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[r]=n,e}function O(e,t,r,n){var i,o=t.axesProject,a=t.gl,l=e.uniforms,c=r.model||d,u=r.view||d,h=r.projection||d,p=t.axesBounds,f=function(e){for(var t=C,r=0;r<2;++r)for(var n=0;n<3;++n)t[r][n]=Math.max(Math.min(e[r][n],1e8),-1e8);return t}(t.clipBounds);i=t.axes&&t.axes.lastCubeProps?t.axes.lastCubeProps.axis:[1,1,1],_[0]=2/a.drawingBufferWidth,_[1]=2/a.drawingBufferHeight,e.bind(),l.view=u,l.projection=h,l.screenSize=_,l.highlightId=t.highlightId,l.highlightScale=t.highlightScale,l.clipBounds=f,l.pickGroup=t.pickId/255,l.pixelRatio=n;for(var m=0;m<3;++m)if(o[m]){l.scale=t.projectScale[m],l.opacity=t.projectOpacity[m];for(var y=T,v=0;v<16;++v)y[v]=0;for(v=0;v<4;++v)y[5*v]=1;y[5*m]=0,i[m]<0?y[12+m]=p[0][m]:y[12+m]=p[1][m],s(y,c,y),l.model=y;var x=(m+1)%3,b=(m+2)%3,O=E(w),R=E(k);O[x]=1,R[b]=1;var L=g(0,0,0,I(S,O)),D=g(0,0,0,I(A,R));if(Math.abs(L[1])>Math.abs(D[1])){var z=L;L=D,D=z,z=O,O=R,R=z;var j=x;x=b,b=j}L[0]<0&&(O[x]=-1),D[1]>0&&(R[b]=-1);var F=0,N=0;for(v=0;v<4;++v)F+=Math.pow(c[4*x+v],2),N+=Math.pow(c[4*b+v],2);O[x]/=Math.sqrt(F),R[b]/=Math.sqrt(N),l.axes[0]=O,l.axes[1]=R,l.fragClipBounds[0]=P(M,f[0],m,-1e8),l.fragClipBounds[1]=P(M,f[1],m,1e8),t.vao.bind(),t.vao.draw(a.TRIANGLES,t.vertexCount),t.lineWidth>0&&(a.lineWidth(t.lineWidth*n),t.vao.draw(a.LINES,t.lineVertexCount,t.vertexCount)),t.vao.unbind()}}var R=[[-1e8,-1e8,-1e8],[1e8,1e8,1e8]];function L(e,t,r,n,i,o,a){var s=r.gl;if((o===r.projectHasAlpha||a)&&O(t,r,n,i),o===r.hasAlpha||a){e.bind();var l=e.uniforms;l.model=n.model||d,l.view=n.view||d,l.projection=n.projection||d,_[0]=2/s.drawingBufferWidth,_[1]=2/s.drawingBufferHeight,l.screenSize=_,l.highlightId=r.highlightId,l.highlightScale=r.highlightScale,l.fragClipBounds=R,l.clipBounds=r.axes.bounds,l.opacity=r.opacity,l.pickGroup=r.pickId/255,l.pixelRatio=i,r.vao.bind(),r.vao.draw(s.TRIANGLES,r.vertexCount),r.lineWidth>0&&(s.lineWidth(r.lineWidth*i),r.vao.draw(s.LINES,r.lineVertexCount,r.vertexCount)),r.vao.unbind()}}function D(e,t,r,i){var o;o=f(e)?t=this.pointCount||t<0)return null;var r=this.points[t],n=this._selectResult;n.index=t;for(var i=0;i<3;++i)n.position[i]=n.dataCoordinate[i]=r[i];return n},b.highlight=function(e){if(e){var t=e.index,r=255&t,n=t>>8&255,i=t>>16&255;this.highlightId=[r/255,n/255,i/255,0]}else this.highlightId=[1,1,1,1]},b.update=function(e){if("perspective"in(e=e||{})&&(this.useOrtho=!e.perspective),"orthographic"in e&&(this.useOrtho=!!e.orthographic),"lineWidth"in e&&(this.lineWidth=e.lineWidth),"project"in e)if(f(e.project))this.axesProject=e.project;else{var t=!!e.project;this.axesProject=[t,t,t]}if("projectScale"in e)if(f(e.projectScale))this.projectScale=e.projectScale.slice();else{var r=+e.projectScale;this.projectScale=[r,r,r]}if(this.projectHasAlpha=!1,"projectOpacity"in e){if(f(e.projectOpacity))this.projectOpacity=e.projectOpacity.slice();else{r=+e.projectOpacity;this.projectOpacity=[r,r,r]}for(var n=0;n<3;++n)this.projectOpacity[n]=v(this.projectOpacity[n]),this.projectOpacity[n]<1&&(this.projectHasAlpha=!0)}this.hasAlpha=!1,"opacity"in e&&(this.opacity=v(e.opacity),this.opacity<1&&(this.hasAlpha=!0)),this.dirty=!0;var i,o,s=e.position,l={family:e.font||"normal",style:e.fontStyle||"normal",weight:e.fontWeight||"normal",variant:e.fontVariant||"normal"},c=e.alignment||[0,0];if(2===c.length)i=c[0],o=c[1];else{i=[],o=[];for(n=0;n0){var R=0,L=b,z=[0,0,0,1],j=[0,0,0,1],F=f(p)&&f(p[0]),N=f(y)&&f(y[0]);e:for(n=0;n0?1-M[0][0]:G<0?1+M[1][0]:1,Y*=Y>0?1-M[0][1]:Y<0?1+M[1][1]:1],Z=A.cells||[],K=A.positions||[];for(S=0;S0){var y=r*u;a.drawBox(d-y,h-y,p+y,h+y,o),a.drawBox(d-y,f-y,p+y,f+y,o),a.drawBox(d-y,h-y,d+y,f+y,o),a.drawBox(p-y,h-y,p+y,f+y,o)}}}},s.update=function(e){e=e||{},this.innerFill=!!e.innerFill,this.outerFill=!!e.outerFill,this.innerColor=(e.innerColor||[0,0,0,.5]).slice(),this.outerColor=(e.outerColor||[0,0,0,.5]).slice(),this.borderColor=(e.borderColor||[0,0,0,1]).slice(),this.borderWidth=e.borderWidth||0,this.selectBox=(e.selectBox||this.selectBox).slice()},s.dispose=function(){this.boxBuffer.dispose(),this.boxShader.dispose(),this.plot.removeOverlay(this)}},3589:function(e,t,r){"use strict";e.exports=function(e,t){var r=t[0],o=t[1],a=n(e,r,o,{}),s=i.mallocUint8(r*o*4);return new l(e,a,s)};var n=r(2260),i=r(1888),o=r(9618),a=r(8828).nextPow2;function s(e,t,r,n,i){this.coord=[e,t],this.id=r,this.value=n,this.distance=i}function l(e,t,r){this.gl=e,this.fbo=t,this.buffer=r,this._readTimeout=null;var n=this;this._readCallback=function(){n.gl&&(t.bind(),e.readPixels(0,0,t.shape[0],t.shape[1],e.RGBA,e.UNSIGNED_BYTE,n.buffer),n._readTimeout=null)}}var c=l.prototype;Object.defineProperty(c,"shape",{get:function(){return this.gl?this.fbo.shape.slice():[0,0]},set:function(e){if(this.gl){this.fbo.shape=e;var t=this.fbo.shape[0],r=this.fbo.shape[1];if(r*t*4>this.buffer.length){i.free(this.buffer);for(var n=this.buffer=i.mallocUint8(a(r*t*4)),o=0;or)for(e=r;et)for(e=t;e=0){for(var k=0|w.type.charAt(w.type.length-1),S=new Array(k),A=0;A=0;)T+=1;_[v]=T}var M=new Array(r.length);function C(){h.program=a.program(p,h._vref,h._fref,b,_);for(var e=0;e=0){if((f=h.charCodeAt(h.length-1)-48)<2||f>4)throw new n("","Invalid data type for attribute "+d+": "+h);s(e,t,p[0],i,f,o,d)}else{if(!(h.indexOf("mat")>=0))throw new n("","Unknown data type for attribute "+d+": "+h);var f;if((f=h.charCodeAt(h.length-1)-48)<2||f>4)throw new n("","Invalid data type for attribute "+d+": "+h);l(e,t,p,i,f,o,d)}}}return o};var n=r(8866);function i(e,t,r,n,i,o){this._gl=e,this._wrapper=t,this._index=r,this._locations=n,this._dimension=i,this._constFunc=o}var o=i.prototype;o.pointer=function(e,t,r,n){var i=this,o=i._gl,a=i._locations[i._index];o.vertexAttribPointer(a,i._dimension,e||o.FLOAT,!!t,r||0,n||0),o.enableVertexAttribArray(a)},o.set=function(e,t,r,n){return this._constFunc(this._locations[this._index],e,t,r,n)},Object.defineProperty(o,"location",{get:function(){return this._locations[this._index]},set:function(e){return e!==this._locations[this._index]&&(this._locations[this._index]=0|e,this._wrapper.program=null),0|e}});var a=[function(e,t,r){return void 0===r.length?e.vertexAttrib1f(t,r):e.vertexAttrib1fv(t,r)},function(e,t,r,n){return void 0===r.length?e.vertexAttrib2f(t,r,n):e.vertexAttrib2fv(t,r)},function(e,t,r,n,i){return void 0===r.length?e.vertexAttrib3f(t,r,n,i):e.vertexAttrib3fv(t,r)},function(e,t,r,n,i,o){return void 0===r.length?e.vertexAttrib4f(t,r,n,i,o):e.vertexAttrib4fv(t,r)}];function s(e,t,r,n,o,s,l){var c=a[o],u=new i(e,t,r,n,o,c);Object.defineProperty(s,l,{set:function(t){return e.disableVertexAttribArray(n[r]),c(e,n[r],t),t},get:function(){return u},enumerable:!0})}function l(e,t,r,n,i,o,a){for(var l=new Array(i),c=new Array(i),u=0;u4)throw new i("","Invalid uniform dimension type for matrix "+name+": "+v);e["uniformMatrix"+y+"fv"](s[d],!1,h);break}throw new i("","Unknown uniform data type for "+name+": "+v)}if((y=v.charCodeAt(v.length-1)-48)<2||y>4)throw new i("","Invalid data type");switch(v.charAt(0)){case"b":case"i":e["uniform"+y+"iv"](s[d],h);break;case"v":e["uniform"+y+"fv"](s[d],h);break;default:throw new i("","Unrecognized data type for vector "+name+": "+v)}}}}}}function c(e,t){if("object"!==typeof t)return[[e,t]];var r=[];for(var n in t){var i=t[n],o=e;parseInt(n)+""===n?o+="["+n+"]":o+="."+n,"object"===typeof i?r.push.apply(r,c(o,i)):r.push([o,i])}return r}function u(e,t,n){if("object"===typeof n){var c=d(n);Object.defineProperty(e,t,{get:o(c),set:l(n),enumerable:!0,configurable:!1})}else s[n]?Object.defineProperty(e,t,{get:(u=n,function(e,t,r){return e.getUniform(t.program,r[u])}),set:l(n),enumerable:!0,configurable:!1}):e[t]=function(e){switch(e){case"bool":return!1;case"int":case"sampler2D":case"samplerCube":case"float":return 0;default:var t=e.indexOf("vec");if(0<=t&&t<=1&&e.length===4+t){if((r=e.charCodeAt(e.length-1)-48)<2||r>4)throw new i("","Invalid data type");return"b"===e.charAt(0)?a(r,!1):a(r,0)}if(0===e.indexOf("mat")&&4===e.length){var r;if((r=e.charCodeAt(e.length-1)-48)<2||r>4)throw new i("","Invalid uniform dimension type for matrix "+name+": "+e);return a(r*r,0)}throw new i("","Unknown uniform data type for "+name+": "+e)}}(r[n].type);var u}function d(e){var t;if(Array.isArray(e)){t=new Array(e.length);for(var r=0;r1){s[0]in o||(o[s[0]]=[]),o=o[s[0]];for(var l=1;l1)for(var l=0;l 0 U ||b|| > 0.\n // Assign z = 0, x = -b, y = a:\n // a*-b + b*a + c*0 = -ba + ba + 0 = 0\n if (v.x*v.x > v.z*v.z || v.y*v.y > v.z*v.z) {\n return normalize(vec3(-v.y, v.x, 0.0));\n } else {\n return normalize(vec3(0.0, v.z, -v.y));\n }\n}\n\n// Calculate the tube vertex and normal at the given index.\n//\n// The returned vertex is for a tube ring with its center at origin, radius of length(d), pointing in the direction of d.\n//\n// Each tube segment is made up of a ring of vertices.\n// These vertices are used to make up the triangles of the tube by connecting them together in the vertex array.\n// The indexes of tube segments run from 0 to 8.\n//\nvec3 getTubePosition(vec3 d, float index, out vec3 normal) {\n float segmentCount = 8.0;\n\n float angle = 2.0 * 3.14159 * (index / segmentCount);\n\n vec3 u = getOrthogonalVector(d);\n vec3 v = normalize(cross(u, d));\n\n vec3 x = u * cos(angle) * length(d);\n vec3 y = v * sin(angle) * length(d);\n vec3 v3 = x + y;\n\n normal = normalize(v3);\n\n return v3;\n}\n\nattribute vec4 vector;\nattribute vec4 color, position;\nattribute vec2 uv;\n\nuniform float vectorScale, tubeScale;\nuniform mat4 model, view, projection, inverseModel;\nuniform vec3 eyePosition, lightPosition;\n\nvarying vec3 f_normal, f_lightDirection, f_eyeDirection, f_data, f_position;\nvarying vec4 f_color;\nvarying vec2 f_uv;\n\nvoid main() {\n // Scale the vector magnitude to stay constant with\n // model & view changes.\n vec3 normal;\n vec3 XYZ = getTubePosition(mat3(model) * (tubeScale * vector.w * normalize(vector.xyz)), position.w, normal);\n vec4 tubePosition = model * vec4(position.xyz, 1.0) + vec4(XYZ, 0.0);\n\n //Lighting geometry parameters\n vec4 cameraCoordinate = view * tubePosition;\n cameraCoordinate.xyz /= cameraCoordinate.w;\n f_lightDirection = lightPosition - cameraCoordinate.xyz;\n f_eyeDirection = eyePosition - cameraCoordinate.xyz;\n f_normal = normalize((vec4(normal, 0.0) * inverseModel).xyz);\n\n // vec4 m_position = model * vec4(tubePosition, 1.0);\n vec4 t_position = view * tubePosition;\n gl_Position = projection * t_position;\n\n f_color = color;\n f_data = tubePosition.xyz;\n f_position = position.xyz;\n f_uv = uv;\n}\n"]),o=n(["#extension GL_OES_standard_derivatives : enable\n\nprecision highp float;\n#define GLSLIFY 1\n\nfloat beckmannDistribution(float x, float roughness) {\n float NdotH = max(x, 0.0001);\n float cos2Alpha = NdotH * NdotH;\n float tan2Alpha = (cos2Alpha - 1.0) / cos2Alpha;\n float roughness2 = roughness * roughness;\n float denom = 3.141592653589793 * roughness2 * cos2Alpha * cos2Alpha;\n return exp(tan2Alpha / roughness2) / denom;\n}\n\nfloat cookTorranceSpecular(\n vec3 lightDirection,\n vec3 viewDirection,\n vec3 surfaceNormal,\n float roughness,\n float fresnel) {\n\n float VdotN = max(dot(viewDirection, surfaceNormal), 0.0);\n float LdotN = max(dot(lightDirection, surfaceNormal), 0.0);\n\n //Half angle vector\n vec3 H = normalize(lightDirection + viewDirection);\n\n //Geometric term\n float NdotH = max(dot(surfaceNormal, H), 0.0);\n float VdotH = max(dot(viewDirection, H), 0.000001);\n float LdotH = max(dot(lightDirection, H), 0.000001);\n float G1 = (2.0 * NdotH * VdotN) / VdotH;\n float G2 = (2.0 * NdotH * LdotN) / LdotH;\n float G = min(1.0, min(G1, G2));\n \n //Distribution term\n float D = beckmannDistribution(NdotH, roughness);\n\n //Fresnel term\n float F = pow(1.0 - VdotN, fresnel);\n\n //Multiply terms and done\n return G * F * D / max(3.14159265 * VdotN, 0.000001);\n}\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nuniform vec3 clipBounds[2];\nuniform float roughness, fresnel, kambient, kdiffuse, kspecular, opacity;\nuniform sampler2D texture;\n\nvarying vec3 f_normal, f_lightDirection, f_eyeDirection, f_data, f_position;\nvarying vec4 f_color;\nvarying vec2 f_uv;\n\nvoid main() {\n if (outOfRange(clipBounds[0], clipBounds[1], f_position)) discard;\n vec3 N = normalize(f_normal);\n vec3 L = normalize(f_lightDirection);\n vec3 V = normalize(f_eyeDirection);\n\n if(gl_FrontFacing) {\n N = -N;\n }\n\n float specular = min(1.0, max(0.0, cookTorranceSpecular(L, V, N, roughness, fresnel)));\n float diffuse = min(kambient + kdiffuse * max(dot(N, L), 0.0), 1.0);\n\n vec4 surfaceColor = f_color * texture2D(texture, f_uv);\n vec4 litColor = surfaceColor.a * vec4(diffuse * surfaceColor.rgb + kspecular * vec3(1,1,1) * specular, 1.0);\n\n gl_FragColor = litColor * opacity;\n}\n"]),a=n(["precision highp float;\n\nprecision highp float;\n#define GLSLIFY 1\n\nvec3 getOrthogonalVector(vec3 v) {\n // Return up-vector for only-z vector.\n // Return ax + by + cz = 0, a point that lies on the plane that has v as a normal and that isn't (0,0,0).\n // From the above if-statement we have ||a|| > 0 U ||b|| > 0.\n // Assign z = 0, x = -b, y = a:\n // a*-b + b*a + c*0 = -ba + ba + 0 = 0\n if (v.x*v.x > v.z*v.z || v.y*v.y > v.z*v.z) {\n return normalize(vec3(-v.y, v.x, 0.0));\n } else {\n return normalize(vec3(0.0, v.z, -v.y));\n }\n}\n\n// Calculate the tube vertex and normal at the given index.\n//\n// The returned vertex is for a tube ring with its center at origin, radius of length(d), pointing in the direction of d.\n//\n// Each tube segment is made up of a ring of vertices.\n// These vertices are used to make up the triangles of the tube by connecting them together in the vertex array.\n// The indexes of tube segments run from 0 to 8.\n//\nvec3 getTubePosition(vec3 d, float index, out vec3 normal) {\n float segmentCount = 8.0;\n\n float angle = 2.0 * 3.14159 * (index / segmentCount);\n\n vec3 u = getOrthogonalVector(d);\n vec3 v = normalize(cross(u, d));\n\n vec3 x = u * cos(angle) * length(d);\n vec3 y = v * sin(angle) * length(d);\n vec3 v3 = x + y;\n\n normal = normalize(v3);\n\n return v3;\n}\n\nattribute vec4 vector;\nattribute vec4 position;\nattribute vec4 id;\n\nuniform mat4 model, view, projection;\nuniform float tubeScale;\n\nvarying vec3 f_position;\nvarying vec4 f_id;\n\nvoid main() {\n vec3 normal;\n vec3 XYZ = getTubePosition(mat3(model) * (tubeScale * vector.w * normalize(vector.xyz)), position.w, normal);\n vec4 tubePosition = model * vec4(position.xyz, 1.0) + vec4(XYZ, 0.0);\n\n gl_Position = projection * (view * tubePosition);\n f_id = id;\n f_position = position.xyz;\n}\n"]),s=n(["precision highp float;\n#define GLSLIFY 1\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nuniform vec3 clipBounds[2];\nuniform float pickId;\n\nvarying vec3 f_position;\nvarying vec4 f_id;\n\nvoid main() {\n if (outOfRange(clipBounds[0], clipBounds[1], f_position)) discard;\n\n gl_FragColor = vec4(pickId, f_id.xyz);\n}"]);t.meshShader={vertex:i,fragment:o,attributes:[{name:"position",type:"vec4"},{name:"color",type:"vec4"},{name:"uv",type:"vec2"},{name:"vector",type:"vec4"}]},t.pickShader={vertex:a,fragment:s,attributes:[{name:"position",type:"vec4"},{name:"id",type:"vec4"},{name:"vector",type:"vec4"}]}},7815:function(e,t,r){"use strict";var n=r(2931),i=r(9970),o=["xyz","xzy","yxz","yzx","zxy","zyx"],a=function(e,t,r,o){for(var a=0,s=0;s0)for(k=0;k<8;k++){var S=(k+1)%8;c.push(h[k],p[k],p[S],p[S],h[S],h[k]),d.push(v,y,y,y,v,v),f.push(m,g,g,g,m,m);var A=c.length;u.push([A-6,A-5,A-4],[A-3,A-2,A-1])}var T=h;h=p,p=T;var M=v;v=y,y=M;var C=m;m=g,g=C}return{positions:c,cells:u,vectors:d,vertexIntensity:f}}(e,r,o,a)})),d=[],h=[],p=[],f=[];for(s=0;st)return r-1}return r},l=function(e,t,r){return er?r:e},c=function(e){var t=1/0;e.sort((function(e,t){return e-t}));for(var r=e.length,n=1;nd-1||v>h-1||x>p-1)return n.create();var b,_,w,k,S,A,T=o[0][f],M=o[0][y],C=o[1][m],E=o[1][v],I=o[2][g],P=(a-T)/(M-T),O=(c-C)/(E-C),R=(u-I)/(o[2][x]-I);switch(isFinite(P)||(P=.5),isFinite(O)||(O=.5),isFinite(R)||(R=.5),r.reversedX&&(f=d-1-f,y=d-1-y),r.reversedY&&(m=h-1-m,v=h-1-v),r.reversedZ&&(g=p-1-g,x=p-1-x),r.filled){case 5:S=g,A=x,w=m*p,k=v*p,b=f*p*h,_=y*p*h;break;case 4:S=g,A=x,b=f*p,_=y*p,w=m*p*d,k=v*p*d;break;case 3:w=m,k=v,S=g*h,A=x*h,b=f*h*p,_=y*h*p;break;case 2:w=m,k=v,b=f*h,_=y*h,S=g*h*d,A=x*h*d;break;case 1:b=f,_=y,S=g*d,A=x*d,w=m*d*p,k=v*d*p;break;default:b=f,_=y,w=m*d,k=v*d,S=g*d*h,A=x*d*h}var L=i[b+w+S],D=i[b+w+A],z=i[b+k+S],j=i[b+k+A],F=i[_+w+S],N=i[_+w+A],B=i[_+k+S],V=i[_+k+A],U=n.create(),H=n.create(),$=n.create(),W=n.create();n.lerp(U,L,F,P),n.lerp(H,D,N,P),n.lerp($,z,B,P),n.lerp(W,j,V,P);var q=n.create(),G=n.create();n.lerp(q,U,$,O),n.lerp(G,H,W,O);var Y=n.create();return n.lerp(Y,q,G,R),Y}(t,e,p)},m=e.getDivergence||function(e,t){var r=n.create(),i=1e-4;n.add(r,e,[i,0,0]);var o=f(r);n.subtract(o,o,t),n.scale(o,o,1/i),n.add(r,e,[0,i,0]);var a=f(r);n.subtract(a,a,t),n.scale(a,a,1/i),n.add(r,e,[0,0,i]);var s=f(r);return n.subtract(s,s,t),n.scale(s,s,1/i),n.add(r,o,a),n.add(r,r,s),r},g=[],y=t[0][0],v=t[0][1],x=t[0][2],b=t[1][0],_=t[1][1],w=t[1][2],k=function(e){var t=e[0],r=e[1],n=e[2];return!(tb||r_||nw)},S=10*n.distance(t[0],t[1])/i,A=S*S,T=1,M=0,C=r.length;C>1&&(T=function(e){for(var t=[],r=[],n=[],i={},o={},a={},s=e.length,l=0;lM&&(M=j),D.push(j),g.push({points:P,velocities:O,divergences:D});for(var F=0;F<100*i&&P.lengthA&&n.scale(N,N,S/Math.sqrt(B)),n.add(N,N,I),R=f(N),n.squaredDistance(L,N)-A>-1e-4*A){P.push(N),L=N,O.push(R);z=m(N,R),j=n.length(z);isFinite(j)&&j>M&&(M=j),D.push(j)}I=N}}var V=a(g,e.colormap,M,T);return d?V.tubeScale=d:(0===M&&(M=1),V.tubeScale=.5*u*T/M),V};var u=r(6740),d=r(6405).createMesh;e.exports.createTubeMesh=function(e,t){return d(e,t,{shaders:u,traceType:"streamtube"})}},990:function(e,t,r){var n=r(9405),i=r(3236),o=i(["precision highp float;\n#define GLSLIFY 1\n\nattribute vec4 uv;\nattribute vec3 f;\nattribute vec3 normal;\n\nuniform vec3 objectOffset;\nuniform mat4 model, view, projection, inverseModel;\nuniform vec3 lightPosition, eyePosition;\nuniform sampler2D colormap;\n\nvarying float value, kill;\nvarying vec3 worldCoordinate;\nvarying vec2 planeCoordinate;\nvarying vec3 lightDirection, eyeDirection, surfaceNormal;\nvarying vec4 vColor;\n\nvoid main() {\n vec3 localCoordinate = vec3(uv.zw, f.x);\n worldCoordinate = objectOffset + localCoordinate;\n mat4 objectOffsetTranslation = mat4(1.0) + mat4(vec4(0), vec4(0), vec4(0), vec4(objectOffset, 0));\n vec4 worldPosition = (model * objectOffsetTranslation) * vec4(localCoordinate, 1.0);\n vec4 clipPosition = projection * (view * worldPosition);\n gl_Position = clipPosition;\n kill = f.y;\n value = f.z;\n planeCoordinate = uv.xy;\n\n vColor = texture2D(colormap, vec2(value, value));\n\n //Lighting geometry parameters\n vec4 cameraCoordinate = view * worldPosition;\n cameraCoordinate.xyz /= cameraCoordinate.w;\n lightDirection = lightPosition - cameraCoordinate.xyz;\n eyeDirection = eyePosition - cameraCoordinate.xyz;\n surfaceNormal = normalize((vec4(normal,0) * inverseModel).xyz);\n}\n"]),a=i(["precision highp float;\n#define GLSLIFY 1\n\nfloat beckmannDistribution(float x, float roughness) {\n float NdotH = max(x, 0.0001);\n float cos2Alpha = NdotH * NdotH;\n float tan2Alpha = (cos2Alpha - 1.0) / cos2Alpha;\n float roughness2 = roughness * roughness;\n float denom = 3.141592653589793 * roughness2 * cos2Alpha * cos2Alpha;\n return exp(tan2Alpha / roughness2) / denom;\n}\n\nfloat beckmannSpecular(\n vec3 lightDirection,\n vec3 viewDirection,\n vec3 surfaceNormal,\n float roughness) {\n return beckmannDistribution(dot(surfaceNormal, normalize(lightDirection + viewDirection)), roughness);\n}\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nuniform vec3 lowerBound, upperBound;\nuniform float contourTint;\nuniform vec4 contourColor;\nuniform sampler2D colormap;\nuniform vec3 clipBounds[2];\nuniform float roughness, fresnel, kambient, kdiffuse, kspecular, opacity;\nuniform float vertexColor;\n\nvarying float value, kill;\nvarying vec3 worldCoordinate;\nvarying vec3 lightDirection, eyeDirection, surfaceNormal;\nvarying vec4 vColor;\n\nvoid main() {\n if (\n kill > 0.0 ||\n vColor.a == 0.0 ||\n outOfRange(clipBounds[0], clipBounds[1], worldCoordinate)\n ) discard;\n\n vec3 N = normalize(surfaceNormal);\n vec3 V = normalize(eyeDirection);\n vec3 L = normalize(lightDirection);\n\n if(gl_FrontFacing) {\n N = -N;\n }\n\n float specular = max(beckmannSpecular(L, V, N, roughness), 0.);\n float diffuse = min(kambient + kdiffuse * max(dot(N, L), 0.0), 1.0);\n\n //decide how to interpolate color \u2014 in vertex or in fragment\n vec4 surfaceColor =\n step(vertexColor, .5) * texture2D(colormap, vec2(value, value)) +\n step(.5, vertexColor) * vColor;\n\n vec4 litColor = surfaceColor.a * vec4(diffuse * surfaceColor.rgb + kspecular * vec3(1,1,1) * specular, 1.0);\n\n gl_FragColor = mix(litColor, contourColor, contourTint) * opacity;\n}\n"]),s=i(["precision highp float;\n#define GLSLIFY 1\n\nattribute vec4 uv;\nattribute float f;\n\nuniform vec3 objectOffset;\nuniform mat3 permutation;\nuniform mat4 model, view, projection;\nuniform float height, zOffset;\nuniform sampler2D colormap;\n\nvarying float value, kill;\nvarying vec3 worldCoordinate;\nvarying vec2 planeCoordinate;\nvarying vec3 lightDirection, eyeDirection, surfaceNormal;\nvarying vec4 vColor;\n\nvoid main() {\n vec3 dataCoordinate = permutation * vec3(uv.xy, height);\n worldCoordinate = objectOffset + dataCoordinate;\n mat4 objectOffsetTranslation = mat4(1.0) + mat4(vec4(0), vec4(0), vec4(0), vec4(objectOffset, 0));\n vec4 worldPosition = (model * objectOffsetTranslation) * vec4(dataCoordinate, 1.0);\n\n vec4 clipPosition = projection * (view * worldPosition);\n clipPosition.z += zOffset;\n\n gl_Position = clipPosition;\n value = f + objectOffset.z;\n kill = -1.0;\n planeCoordinate = uv.zw;\n\n vColor = texture2D(colormap, vec2(value, value));\n\n //Don't do lighting for contours\n surfaceNormal = vec3(1,0,0);\n eyeDirection = vec3(0,1,0);\n lightDirection = vec3(0,0,1);\n}\n"]),l=i(["precision highp float;\n#define GLSLIFY 1\n\nbool outOfRange(float a, float b, float p) {\n return ((p > max(a, b)) || \n (p < min(a, b)));\n}\n\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y));\n}\n\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\n return (outOfRange(a.x, b.x, p.x) ||\n outOfRange(a.y, b.y, p.y) ||\n outOfRange(a.z, b.z, p.z));\n}\n\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\n return outOfRange(a.xyz, b.xyz, p.xyz);\n}\n\nuniform vec2 shape;\nuniform vec3 clipBounds[2];\nuniform float pickId;\n\nvarying float value, kill;\nvarying vec3 worldCoordinate;\nvarying vec2 planeCoordinate;\nvarying vec3 surfaceNormal;\n\nvec2 splitFloat(float v) {\n float vh = 255.0 * v;\n float upper = floor(vh);\n float lower = fract(vh);\n return vec2(upper / 255.0, floor(lower * 16.0) / 16.0);\n}\n\nvoid main() {\n if ((kill > 0.0) ||\n (outOfRange(clipBounds[0], clipBounds[1], worldCoordinate))) discard;\n\n vec2 ux = splitFloat(planeCoordinate.x / shape.x);\n vec2 uy = splitFloat(planeCoordinate.y / shape.y);\n gl_FragColor = vec4(pickId, ux.x, uy.x, ux.y + (uy.y/16.0));\n}\n"]);t.createShader=function(e){var t=n(e,o,a,null,[{name:"uv",type:"vec4"},{name:"f",type:"vec3"},{name:"normal",type:"vec3"}]);return t.attributes.uv.location=0,t.attributes.f.location=1,t.attributes.normal.location=2,t},t.createPickShader=function(e){var t=n(e,o,l,null,[{name:"uv",type:"vec4"},{name:"f",type:"vec3"},{name:"normal",type:"vec3"}]);return t.attributes.uv.location=0,t.attributes.f.location=1,t.attributes.normal.location=2,t},t.createContourShader=function(e){var t=n(e,s,a,null,[{name:"uv",type:"vec4"},{name:"f",type:"float"}]);return t.attributes.uv.location=0,t.attributes.f.location=1,t},t.createPickContourShader=function(e){var t=n(e,s,l,null,[{name:"uv",type:"vec4"},{name:"f",type:"float"}]);return t.attributes.uv.location=0,t.attributes.f.location=1,t}},9499:function(e,t,r){"use strict";e.exports=function(e){var t=e.gl,r=v(t),n=b(t),s=x(t),l=_(t),c=i(t),u=o(t,[{buffer:c,size:4,stride:w,offset:0},{buffer:c,size:3,stride:w,offset:16},{buffer:c,size:3,stride:w,offset:28}]),d=i(t),h=o(t,[{buffer:d,size:4,stride:20,offset:0},{buffer:d,size:1,stride:20,offset:16}]),p=i(t),f=o(t,[{buffer:p,size:2,type:t.FLOAT}]),m=a(t,1,M,t.RGBA,t.UNSIGNED_BYTE);m.minFilter=t.LINEAR,m.magFilter=t.LINEAR;var g=new C(t,[0,0],[[0,0,0],[0,0,0]],r,n,c,u,m,s,l,d,h,p,f,[0,0,0]),y={levels:[[],[],[]]};for(var k in e)y[k]=e[k];return y.colormap=y.colormap||"jet",g.update(y),g};var n=r(8828),i=r(2762),o=r(8116),a=r(7766),s=r(1888),l=r(6729),c=r(5298),u=r(9994),d=r(9618),h=r(3711),p=r(6760),f=r(7608),m=r(2478),g=r(6199),y=r(990),v=y.createShader,x=y.createContourShader,b=y.createPickShader,_=y.createPickContourShader,w=40,k=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1],S=[[0,0],[0,1],[1,0],[1,1],[1,0],[0,1]],A=[[0,0,0,0,0,0,0,0,0],[0,0,0,0,0,0,0,0,0],[0,0,0,0,0,0,0,0,0]];function T(e,t,r,n,i){this.position=e,this.index=t,this.uv=r,this.level=n,this.dataCoordinate=i}!function(){for(var e=0;e<3;++e){var t=A[e],r=(e+2)%3;t[(e+1)%3+0]=1,t[r+3]=1,t[e+6]=1}}();var M=256;function C(e,t,r,n,i,o,a,l,c,u,h,p,f,m,g){this.gl=e,this.shape=t,this.bounds=r,this.objectOffset=g,this.intensityBounds=[],this._shader=n,this._pickShader=i,this._coordinateBuffer=o,this._vao=a,this._colorMap=l,this._contourShader=c,this._contourPickShader=u,this._contourBuffer=h,this._contourVAO=p,this._contourOffsets=[[],[],[]],this._contourCounts=[[],[],[]],this._vertexCount=0,this._pickResult=new T([0,0,0],[0,0],[0,0],[0,0,0],[0,0,0]),this._dynamicBuffer=f,this._dynamicVAO=m,this._dynamicOffsets=[0,0,0],this._dynamicCounts=[0,0,0],this.contourWidth=[1,1,1],this.contourLevels=[[1],[1],[1]],this.contourTint=[0,0,0],this.contourColor=[[.5,.5,.5,1],[.5,.5,.5,1],[.5,.5,.5,1]],this.showContour=!0,this.showSurface=!0,this.enableHighlight=[!0,!0,!0],this.highlightColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.highlightTint=[1,1,1],this.highlightLevel=[-1,-1,-1],this.enableDynamic=[!0,!0,!0],this.dynamicLevel=[NaN,NaN,NaN],this.dynamicColor=[[0,0,0,1],[0,0,0,1],[0,0,0,1]],this.dynamicTint=[1,1,1],this.dynamicWidth=[1,1,1],this.axesBounds=[[1/0,1/0,1/0],[-1/0,-1/0,-1/0]],this.surfaceProject=[!1,!1,!1],this.contourProject=[[!1,!1,!1],[!1,!1,!1],[!1,!1,!1]],this.colorBounds=[!1,!1],this._field=[d(s.mallocFloat(1024),[0,0]),d(s.mallocFloat(1024),[0,0]),d(s.mallocFloat(1024),[0,0])],this.pickId=1,this.clipBounds=[[-1/0,-1/0,-1/0],[1/0,1/0,1/0]],this.snapToData=!1,this.pixelRatio=1,this.opacity=1,this.lightPosition=[10,1e4,0],this.ambientLight=.8,this.diffuseLight=.8,this.specularLight=2,this.roughness=.5,this.fresnel=1.5,this.vertexColor=0,this.dirty=!0}var E=C.prototype;E.genColormap=function(e,t){var r=!1,n=u([l({colormap:e,nshades:M,format:"rgba"}).map((function(e,n){var i=t?function(e,t){if(!t)return 1;if(!t.length)return 1;for(var r=0;re&&r>0){var n=(t[r][0]-e)/(t[r][0]-t[r-1][0]);return t[r][1]*(1-n)+n*t[r-1][1]}}return 1}(n/255,t):e[3];return i<1&&(r=!0),[e[0],e[1],e[2],255*i]}))]);return c.divseq(n,255),this.hasAlphaScale=r,n},E.isTransparent=function(){return this.opacity<1||this.hasAlphaScale},E.isOpaque=function(){return!this.isTransparent()},E.pickSlots=1,E.setPickBase=function(e){this.pickId=e};var I=[0,0,0],P={showSurface:!1,showContour:!1,projections:[k.slice(),k.slice(),k.slice()],clipBounds:[[[0,0,0],[0,0,0]],[[0,0,0],[0,0,0]],[[0,0,0],[0,0,0]]]};function O(e,t){var r,n,i,o=t.axes&&t.axes.lastCubeProps.axis||I,a=t.showSurface,s=t.showContour;for(r=0;r<3;++r)for(a=a||t.surfaceProject[r],n=0;n<3;++n)s=s||t.contourProject[r][n];for(r=0;r<3;++r){var l=P.projections[r];for(n=0;n<16;++n)l[n]=0;for(n=0;n<4;++n)l[5*n]=1;l[5*r]=0,l[12+r]=t.axesBounds[+(o[r]>0)][r],p(l,e.model,l);var c=P.clipBounds[r];for(i=0;i<2;++i)for(n=0;n<3;++n)c[i][n]=e.clipBounds[i][n];c[0][r]=-1e8,c[1][r]=1e8}return P.showSurface=a,P.showContour=s,P}var R={model:k,view:k,projection:k,inverseModel:k.slice(),lowerBound:[0,0,0],upperBound:[0,0,0],colorMap:0,clipBounds:[[0,0,0],[0,0,0]],height:0,contourTint:0,contourColor:[0,0,0,1],permutation:[1,0,0,0,1,0,0,0,1],zOffset:-1e-4,objectOffset:[0,0,0],kambient:1,kdiffuse:1,kspecular:1,lightPosition:[1e3,1e3,1e3],eyePosition:[0,0,0],roughness:1,fresnel:1,opacity:1,vertexColor:0},L=k.slice(),D=[1,0,0,0,1,0,0,0,1];function z(e,t){e=e||{};var r=this.gl;r.disable(r.CULL_FACE),this._colorMap.bind(0);var n=R;n.model=e.model||k,n.view=e.view||k,n.projection=e.projection||k,n.lowerBound=[this.bounds[0][0],this.bounds[0][1],this.colorBounds[0]||this.bounds[0][2]],n.upperBound=[this.bounds[1][0],this.bounds[1][1],this.colorBounds[1]||this.bounds[1][2]],n.objectOffset=this.objectOffset,n.contourColor=this.contourColor[0],n.inverseModel=f(n.inverseModel,n.model);for(var i=0;i<2;++i)for(var o=n.clipBounds[i],a=0;a<3;++a)o[a]=Math.min(Math.max(this.clipBounds[i][a],-1e8),1e8);n.kambient=this.ambientLight,n.kdiffuse=this.diffuseLight,n.kspecular=this.specularLight,n.roughness=this.roughness,n.fresnel=this.fresnel,n.opacity=this.opacity,n.height=0,n.permutation=D,n.vertexColor=this.vertexColor;var s=L;for(p(s,n.view,n.model),p(s,n.projection,s),f(s,s),i=0;i<3;++i)n.eyePosition[i]=s[12+i]/s[15];var l=s[15];for(i=0;i<3;++i)l+=this.lightPosition[i]*s[4*i+3];for(i=0;i<3;++i){var c=s[12+i];for(a=0;a<3;++a)c+=s[4*a+i]*this.lightPosition[a];n.lightPosition[i]=c/l}var u=O(n,this);if(u.showSurface){for(this._shader.bind(),this._shader.uniforms=n,this._vao.bind(),this.showSurface&&this._vertexCount&&this._vao.draw(r.TRIANGLES,this._vertexCount),i=0;i<3;++i)this.surfaceProject[i]&&this.vertexCount&&(this._shader.uniforms.model=u.projections[i],this._shader.uniforms.clipBounds=u.clipBounds[i],this._vao.draw(r.TRIANGLES,this._vertexCount));this._vao.unbind()}if(u.showContour){var d=this._contourShader;n.kambient=1,n.kdiffuse=0,n.kspecular=0,n.opacity=1,d.bind(),d.uniforms=n;var h=this._contourVAO;for(h.bind(),i=0;i<3;++i)for(d.uniforms.permutation=A[i],r.lineWidth(this.contourWidth[i]*this.pixelRatio),a=0;a>4)/16)/255,i=Math.floor(n),o=n-i,a=t[1]*(e.value[1]+(15&e.value[2])/16)/255,s=Math.floor(a),l=a-s;i+=1,s+=1;var c=r.position;c[0]=c[1]=c[2]=0;for(var u=0;u<2;++u)for(var d=u?o:1-o,h=0;h<2;++h)for(var p=i+u,f=s+h,g=d*(h?l:1-l),y=0;y<3;++y)c[y]+=this._field[y].get(p,f)*g;for(var v=this._pickResult.level,x=0;x<3;++x)if(v[x]=m.le(this.contourLevels[x],c[x]),v[x]<0)this.contourLevels[x].length>0&&(v[x]=0);else if(v[x]Math.abs(_-c[x])&&(v[x]+=1)}for(r.index[0]=o<.5?i:i+1,r.index[1]=l<.5?s:s+1,r.uv[0]=n/t[0],r.uv[1]=a/t[1],y=0;y<3;++y)r.dataCoordinate[y]=this._field[y].get(r.index[0],r.index[1]);return r},E.padField=function(e,t){var r=t.shape.slice(),n=e.shape.slice();c.assign(e.lo(1,1).hi(r[0],r[1]),t),c.assign(e.lo(1).hi(r[0],1),t.hi(r[0],1)),c.assign(e.lo(1,n[1]-1).hi(r[0],1),t.lo(0,r[1]-1).hi(r[0],1)),c.assign(e.lo(0,1).hi(1,r[1]),t.hi(1)),c.assign(e.lo(n[0]-1,1).hi(1,r[1]),t.lo(r[0]-1)),e.set(0,0,t.get(0,0)),e.set(0,n[1]-1,t.get(0,r[1]-1)),e.set(n[0]-1,0,t.get(r[0]-1,0)),e.set(n[0]-1,n[1]-1,t.get(r[0]-1,r[1]-1))},E.update=function(e){e=e||{},this.objectOffset=e.objectOffset||this.objectOffset,this.dirty=!0,"contourWidth"in e&&(this.contourWidth=F(e.contourWidth,Number)),"showContour"in e&&(this.showContour=F(e.showContour,Boolean)),"showSurface"in e&&(this.showSurface=!!e.showSurface),"contourTint"in e&&(this.contourTint=F(e.contourTint,Boolean)),"contourColor"in e&&(this.contourColor=B(e.contourColor)),"contourProject"in e&&(this.contourProject=F(e.contourProject,(function(e){return F(e,Boolean)}))),"surfaceProject"in e&&(this.surfaceProject=e.surfaceProject),"dynamicColor"in e&&(this.dynamicColor=B(e.dynamicColor)),"dynamicTint"in e&&(this.dynamicTint=F(e.dynamicTint,Number)),"dynamicWidth"in e&&(this.dynamicWidth=F(e.dynamicWidth,Number)),"opacity"in e&&(this.opacity=e.opacity),"opacityscale"in e&&(this.opacityscale=e.opacityscale),"colorBounds"in e&&(this.colorBounds=e.colorBounds),"vertexColor"in e&&(this.vertexColor=e.vertexColor?1:0),"colormap"in e&&this._colorMap.setPixels(this.genColormap(e.colormap,this.opacityscale));var t=e.field||e.coords&&e.coords[2]||null,r=!1;if(t||(t=this._field[2].shape[0]||this._field[2].shape[2]?this._field[2].lo(1,1).hi(this._field[2].shape[0]-2,this._field[2].shape[1]-2):this._field[2].hi(0,0)),"field"in e||"coords"in e){var i=(t.shape[0]+2)*(t.shape[1]+2);i>this._field[2].data.length&&(s.freeFloat(this._field[2].data),this._field[2].data=s.mallocFloat(n.nextPow2(i))),this._field[2]=d(this._field[2].data,[t.shape[0]+2,t.shape[1]+2]),this.padField(this._field[2],t),this.shape=t.shape.slice();for(var o=this.shape,a=0;a<2;++a)this._field[2].size>this._field[a].data.length&&(s.freeFloat(this._field[a].data),this._field[a].data=s.mallocFloat(this._field[2].size)),this._field[a]=d(this._field[a].data,[o[0]+2,o[1]+2]);if(e.coords){var l=e.coords;if(!Array.isArray(l)||3!==l.length)throw new Error("gl-surface: invalid coordinates for x/y");for(a=0;a<2;++a){var c=l[a];for(y=0;y<2;++y)if(c.shape[y]!==o[y])throw new Error("gl-surface: coords have incorrect shape");this.padField(this._field[a],c)}}else if(e.ticks){var u=e.ticks;if(!Array.isArray(u)||2!==u.length)throw new Error("gl-surface: invalid ticks");for(a=0;a<2;++a){var p=u[a];if((Array.isArray(p)||p.length)&&(p=d(p)),p.shape[0]!==o[a])throw new Error("gl-surface: invalid tick length");var f=d(p.data,o);f.stride[a]=p.stride[0],f.stride[1^a]=0,this.padField(this._field[a],f)}}else{for(a=0;a<2;++a){var m=[0,0];m[a]=1,this._field[a]=d(this._field[a].data,[o[0]+2,o[1]+2],m,0)}this._field[0].set(0,0,0);for(var y=0;y0){for(var xe=0;xe<5;++xe)J.pop();V-=1}continue e}J.push(ne[0],ne[1],ae[0],ae[1],ne[2]),V+=1}}re.push(V)}this._contourOffsets[Q]=te,this._contourCounts[Q]=re}var be=s.mallocFloat(J.length);for(a=0;as||a[1]<0||a[1]>s)throw new Error("gl-texture2d: Invalid texture size");var l=f(a,t.stride.slice()),c=0;"float32"===r?c=e.FLOAT:"float64"===r?(c=e.FLOAT,l=!1,r="float32"):"uint8"===r?c=e.UNSIGNED_BYTE:(c=e.UNSIGNED_BYTE,l=!1,r="uint8");var d,p,g=0;if(2===a.length)g=e.LUMINANCE,a=[a[0],a[1],1],t=n(t.data,a,[t.stride[0],t.stride[1],1],t.offset);else{if(3!==a.length)throw new Error("gl-texture2d: Invalid shape for texture");if(1===a[2])g=e.ALPHA;else if(2===a[2])g=e.LUMINANCE_ALPHA;else if(3===a[2])g=e.RGB;else{if(4!==a[2])throw new Error("gl-texture2d: Invalid shape for pixel coords");g=e.RGBA}}c!==e.FLOAT||e.getExtension("OES_texture_float")||(c=e.UNSIGNED_BYTE,l=!1);var y=t.size;if(l)d=0===t.offset&&t.data.length===y?t.data:t.data.subarray(t.offset,t.offset+y);else{var v=[a[2],a[2]*a[0],1];p=o.malloc(y,r);var x=n(p,a,v,0);"float32"!==r&&"float64"!==r||c!==e.UNSIGNED_BYTE?i.assign(x,t):u(x,t),d=p.subarray(0,y)}var b=m(e);e.texImage2D(e.TEXTURE_2D,0,g,a[0],a[1],0,g,c,d),l||o.free(p);return new h(e,b,a[0],a[1],g,c)}(e,t)}throw new Error("gl-texture2d: Invalid arguments for texture2d constructor")};var a=null,s=null,l=null;function c(e){return"undefined"!=typeof HTMLCanvasElement&&e instanceof HTMLCanvasElement||"undefined"!=typeof HTMLImageElement&&e instanceof HTMLImageElement||"undefined"!=typeof HTMLVideoElement&&e instanceof HTMLVideoElement||"undefined"!=typeof ImageData&&e instanceof ImageData}var u=function(e,t){i.muls(e,t,255)};function d(e,t,r){var n=e.gl,i=n.getParameter(n.MAX_TEXTURE_SIZE);if(t<0||t>i||r<0||r>i)throw new Error("gl-texture2d: Invalid texture size");return e._shape=[t,r],e.bind(),n.texImage2D(n.TEXTURE_2D,0,e.format,t,r,0,e.format,e.type,null),e._mipLevels=[0],e}function h(e,t,r,n,i,o){this.gl=e,this.handle=t,this.format=i,this.type=o,this._shape=[r,n],this._mipLevels=[0],this._magFilter=e.NEAREST,this._minFilter=e.NEAREST,this._wrapS=e.CLAMP_TO_EDGE,this._wrapT=e.CLAMP_TO_EDGE,this._anisoSamples=1;var a=this,s=[this._wrapS,this._wrapT];Object.defineProperties(s,[{get:function(){return a._wrapS},set:function(e){return a.wrapS=e}},{get:function(){return a._wrapT},set:function(e){return a.wrapT=e}}]),this._wrapVector=s;var l=[this._shape[0],this._shape[1]];Object.defineProperties(l,[{get:function(){return a._shape[0]},set:function(e){return a.width=e}},{get:function(){return a._shape[1]},set:function(e){return a.height=e}}]),this._shapeVector=l}var p=h.prototype;function f(e,t){return 3===e.length?1===t[2]&&t[1]===e[0]*e[2]&&t[0]===e[2]:1===t[0]&&t[1]===e[0]}function m(e){var t=e.createTexture();return e.bindTexture(e.TEXTURE_2D,t),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.NEAREST),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.NEAREST),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE),t}function g(e,t,r,n,i){var o=e.getParameter(e.MAX_TEXTURE_SIZE);if(t<0||t>o||r<0||r>o)throw new Error("gl-texture2d: Invalid texture shape");if(i===e.FLOAT&&!e.getExtension("OES_texture_float"))throw new Error("gl-texture2d: Floating point textures not supported on this platform");var a=m(e);return e.texImage2D(e.TEXTURE_2D,0,n,t,r,0,n,i,null),new h(e,a,t,r,n,i)}Object.defineProperties(p,{minFilter:{get:function(){return this._minFilter},set:function(e){this.bind();var t=this.gl;if(this.type===t.FLOAT&&a.indexOf(e)>=0&&(t.getExtension("OES_texture_float_linear")||(e=t.NEAREST)),s.indexOf(e)<0)throw new Error("gl-texture2d: Unknown filter mode "+e);return t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MIN_FILTER,e),this._minFilter=e}},magFilter:{get:function(){return this._magFilter},set:function(e){this.bind();var t=this.gl;if(this.type===t.FLOAT&&a.indexOf(e)>=0&&(t.getExtension("OES_texture_float_linear")||(e=t.NEAREST)),s.indexOf(e)<0)throw new Error("gl-texture2d: Unknown filter mode "+e);return t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MAG_FILTER,e),this._magFilter=e}},mipSamples:{get:function(){return this._anisoSamples},set:function(e){var t=this._anisoSamples;if(this._anisoSamples=0|Math.max(e,1),t!==this._anisoSamples){var r=this.gl.getExtension("EXT_texture_filter_anisotropic");r&&this.gl.texParameterf(this.gl.TEXTURE_2D,r.TEXTURE_MAX_ANISOTROPY_EXT,this._anisoSamples)}return this._anisoSamples}},wrapS:{get:function(){return this._wrapS},set:function(e){if(this.bind(),l.indexOf(e)<0)throw new Error("gl-texture2d: Unknown wrap mode "+e);return this.gl.texParameteri(this.gl.TEXTURE_2D,this.gl.TEXTURE_WRAP_S,e),this._wrapS=e}},wrapT:{get:function(){return this._wrapT},set:function(e){if(this.bind(),l.indexOf(e)<0)throw new Error("gl-texture2d: Unknown wrap mode "+e);return this.gl.texParameteri(this.gl.TEXTURE_2D,this.gl.TEXTURE_WRAP_T,e),this._wrapT=e}},wrap:{get:function(){return this._wrapVector},set:function(e){if(Array.isArray(e)||(e=[e,e]),2!==e.length)throw new Error("gl-texture2d: Must specify wrap mode for rows and columns");for(var t=0;t<2;++t)if(l.indexOf(e[t])<0)throw new Error("gl-texture2d: Unknown wrap mode "+e);this._wrapS=e[0],this._wrapT=e[1];var r=this.gl;return this.bind(),r.texParameteri(r.TEXTURE_2D,r.TEXTURE_WRAP_S,this._wrapS),r.texParameteri(r.TEXTURE_2D,r.TEXTURE_WRAP_T,this._wrapT),e}},shape:{get:function(){return this._shapeVector},set:function(e){if(Array.isArray(e)){if(2!==e.length)throw new Error("gl-texture2d: Invalid texture shape")}else e=[0|e,0|e];return d(this,0|e[0],0|e[1]),[0|e[0],0|e[1]]}},width:{get:function(){return this._shape[0]},set:function(e){return d(this,e|=0,this._shape[1]),e}},height:{get:function(){return this._shape[1]},set:function(e){return e|=0,d(this,this._shape[0],e),e}}}),p.bind=function(e){var t=this.gl;return void 0!==e&&t.activeTexture(t.TEXTURE0+(0|e)),t.bindTexture(t.TEXTURE_2D,this.handle),void 0!==e?0|e:t.getParameter(t.ACTIVE_TEXTURE)-t.TEXTURE0},p.dispose=function(){this.gl.deleteTexture(this.handle)},p.generateMipmap=function(){this.bind(),this.gl.generateMipmap(this.gl.TEXTURE_2D);for(var e=Math.min(this._shape[0],this._shape[1]),t=0;e>0;++t,e>>>=1)this._mipLevels.indexOf(t)<0&&this._mipLevels.push(t)},p.setPixels=function(e,t,r,a){var s=this.gl;this.bind(),Array.isArray(t)?(a=r,r=0|t[1],t=0|t[0]):(t=t||0,r=r||0),a=a||0;var l=c(e)?e:e.raw;if(l){this._mipLevels.indexOf(a)<0?(s.texImage2D(s.TEXTURE_2D,0,this.format,this.format,this.type,l),this._mipLevels.push(a)):s.texSubImage2D(s.TEXTURE_2D,a,t,r,this.format,this.type,l)}else{if(!(e.shape&&e.stride&&e.data))throw new Error("gl-texture2d: Unsupported data type");if(e.shape.length<2||t+e.shape[1]>this._shape[1]>>>a||r+e.shape[0]>this._shape[0]>>>a||t<0||r<0)throw new Error("gl-texture2d: Texture dimensions are out of bounds");!function(e,t,r,a,s,l,c,d){var h=d.dtype,p=d.shape.slice();if(p.length<2||p.length>3)throw new Error("gl-texture2d: Invalid ndarray, must be 2d or 3d");var m=0,g=0,y=f(p,d.stride.slice());"float32"===h?m=e.FLOAT:"float64"===h?(m=e.FLOAT,y=!1,h="float32"):"uint8"===h?m=e.UNSIGNED_BYTE:(m=e.UNSIGNED_BYTE,y=!1,h="uint8");if(2===p.length)g=e.LUMINANCE,p=[p[0],p[1],1],d=n(d.data,p,[d.stride[0],d.stride[1],1],d.offset);else{if(3!==p.length)throw new Error("gl-texture2d: Invalid shape for texture");if(1===p[2])g=e.ALPHA;else if(2===p[2])g=e.LUMINANCE_ALPHA;else if(3===p[2])g=e.RGB;else{if(4!==p[2])throw new Error("gl-texture2d: Invalid shape for pixel coords");g=e.RGBA}p[2]}g!==e.LUMINANCE&&g!==e.ALPHA||s!==e.LUMINANCE&&s!==e.ALPHA||(g=s);if(g!==s)throw new Error("gl-texture2d: Incompatible texture format for setPixels");var v=d.size,x=c.indexOf(a)<0;x&&c.push(a);if(m===l&&y)0===d.offset&&d.data.length===v?x?e.texImage2D(e.TEXTURE_2D,a,s,p[0],p[1],0,s,l,d.data):e.texSubImage2D(e.TEXTURE_2D,a,t,r,p[0],p[1],s,l,d.data):x?e.texImage2D(e.TEXTURE_2D,a,s,p[0],p[1],0,s,l,d.data.subarray(d.offset,d.offset+v)):e.texSubImage2D(e.TEXTURE_2D,a,t,r,p[0],p[1],s,l,d.data.subarray(d.offset,d.offset+v));else{var b;b=l===e.FLOAT?o.mallocFloat32(v):o.mallocUint8(v);var _=n(b,p,[p[2],p[2]*p[0],1]);m===e.FLOAT&&l===e.UNSIGNED_BYTE?u(_,d):i.assign(_,d),x?e.texImage2D(e.TEXTURE_2D,a,s,p[0],p[1],0,s,l,b.subarray(0,v)):e.texSubImage2D(e.TEXTURE_2D,a,t,r,p[0],p[1],s,l,b.subarray(0,v)),l===e.FLOAT?o.freeFloat32(b):o.freeUint8(b)}}(s,t,r,a,this.format,this.type,this._mipLevels,e)}}},1433:function(e){"use strict";e.exports=function(e,t,r){t?t.bind():e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null);var n=0|e.getParameter(e.MAX_VERTEX_ATTRIBS);if(r){if(r.length>n)throw new Error("gl-vao: Too many vertex attributes");for(var i=0;i1?0:Math.acos(s)};var n=r(2825),i=r(3536),o=r(244)},9226:function(e){e.exports=function(e,t){return e[0]=Math.ceil(t[0]),e[1]=Math.ceil(t[1]),e[2]=Math.ceil(t[2]),e}},3126:function(e){e.exports=function(e){var t=new Float32Array(3);return t[0]=e[0],t[1]=e[1],t[2]=e[2],t}},3990:function(e){e.exports=function(e,t){return e[0]=t[0],e[1]=t[1],e[2]=t[2],e}},1091:function(e){e.exports=function(){var e=new Float32Array(3);return e[0]=0,e[1]=0,e[2]=0,e}},5911:function(e){e.exports=function(e,t,r){var n=t[0],i=t[1],o=t[2],a=r[0],s=r[1],l=r[2];return e[0]=i*l-o*s,e[1]=o*a-n*l,e[2]=n*s-i*a,e}},5455:function(e,t,r){e.exports=r(7056)},7056:function(e){e.exports=function(e,t){var r=t[0]-e[0],n=t[1]-e[1],i=t[2]-e[2];return Math.sqrt(r*r+n*n+i*i)}},4008:function(e,t,r){e.exports=r(6690)},6690:function(e){e.exports=function(e,t,r){return e[0]=t[0]/r[0],e[1]=t[1]/r[1],e[2]=t[2]/r[2],e}},244:function(e){e.exports=function(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]}},2613:function(e){e.exports=1e-6},9922:function(e,t,r){e.exports=function(e,t){var r=e[0],i=e[1],o=e[2],a=t[0],s=t[1],l=t[2];return Math.abs(r-a)<=n*Math.max(1,Math.abs(r),Math.abs(a))&&Math.abs(i-s)<=n*Math.max(1,Math.abs(i),Math.abs(s))&&Math.abs(o-l)<=n*Math.max(1,Math.abs(o),Math.abs(l))};var n=r(2613)},9265:function(e){e.exports=function(e,t){return e[0]===t[0]&&e[1]===t[1]&&e[2]===t[2]}},2681:function(e){e.exports=function(e,t){return e[0]=Math.floor(t[0]),e[1]=Math.floor(t[1]),e[2]=Math.floor(t[2]),e}},5137:function(e,t,r){e.exports=function(e,t,r,i,o,a){var s,l;t||(t=3);r||(r=0);l=i?Math.min(i*t+r,e.length):e.length;for(s=r;s0&&(o=1/Math.sqrt(o),e[0]=t[0]*o,e[1]=t[1]*o,e[2]=t[2]*o);return e}},7636:function(e){e.exports=function(e,t){t=t||1;var r=2*Math.random()*Math.PI,n=2*Math.random()-1,i=Math.sqrt(1-n*n)*t;return e[0]=Math.cos(r)*i,e[1]=Math.sin(r)*i,e[2]=n*t,e}},6894:function(e){e.exports=function(e,t,r,n){var i=r[1],o=r[2],a=t[1]-i,s=t[2]-o,l=Math.sin(n),c=Math.cos(n);return e[0]=t[0],e[1]=i+a*c-s*l,e[2]=o+a*l+s*c,e}},109:function(e){e.exports=function(e,t,r,n){var i=r[0],o=r[2],a=t[0]-i,s=t[2]-o,l=Math.sin(n),c=Math.cos(n);return e[0]=i+s*l+a*c,e[1]=t[1],e[2]=o+s*c-a*l,e}},8692:function(e){e.exports=function(e,t,r,n){var i=r[0],o=r[1],a=t[0]-i,s=t[1]-o,l=Math.sin(n),c=Math.cos(n);return e[0]=i+a*c-s*l,e[1]=o+a*l+s*c,e[2]=t[2],e}},2447:function(e){e.exports=function(e,t){return e[0]=Math.round(t[0]),e[1]=Math.round(t[1]),e[2]=Math.round(t[2]),e}},6621:function(e){e.exports=function(e,t,r){return e[0]=t[0]*r,e[1]=t[1]*r,e[2]=t[2]*r,e}},8489:function(e){e.exports=function(e,t,r,n){return e[0]=t[0]+r[0]*n,e[1]=t[1]+r[1]*n,e[2]=t[2]+r[2]*n,e}},1463:function(e){e.exports=function(e,t,r,n){return e[0]=t,e[1]=r,e[2]=n,e}},6141:function(e,t,r){e.exports=r(2953)},5486:function(e,t,r){e.exports=r(3066)},2953:function(e){e.exports=function(e,t){var r=t[0]-e[0],n=t[1]-e[1],i=t[2]-e[2];return r*r+n*n+i*i}},3066:function(e){e.exports=function(e){var t=e[0],r=e[1],n=e[2];return t*t+r*r+n*n}},2229:function(e,t,r){e.exports=r(6843)},6843:function(e){e.exports=function(e,t,r){return e[0]=t[0]-r[0],e[1]=t[1]-r[1],e[2]=t[2]-r[2],e}},492:function(e){e.exports=function(e,t,r){var n=t[0],i=t[1],o=t[2];return e[0]=n*r[0]+i*r[3]+o*r[6],e[1]=n*r[1]+i*r[4]+o*r[7],e[2]=n*r[2]+i*r[5]+o*r[8],e}},5673:function(e){e.exports=function(e,t,r){var n=t[0],i=t[1],o=t[2],a=r[3]*n+r[7]*i+r[11]*o+r[15];return a=a||1,e[0]=(r[0]*n+r[4]*i+r[8]*o+r[12])/a,e[1]=(r[1]*n+r[5]*i+r[9]*o+r[13])/a,e[2]=(r[2]*n+r[6]*i+r[10]*o+r[14])/a,e}},264:function(e){e.exports=function(e,t,r){var n=t[0],i=t[1],o=t[2],a=r[0],s=r[1],l=r[2],c=r[3],u=c*n+s*o-l*i,d=c*i+l*n-a*o,h=c*o+a*i-s*n,p=-a*n-s*i-l*o;return e[0]=u*c+p*-a+d*-l-h*-s,e[1]=d*c+p*-s+h*-a-u*-l,e[2]=h*c+p*-l+u*-s-d*-a,e}},4361:function(e){e.exports=function(e,t,r){return e[0]=t[0]+r[0],e[1]=t[1]+r[1],e[2]=t[2]+r[2],e[3]=t[3]+r[3],e}},2335:function(e){e.exports=function(e){var t=new Float32Array(4);return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t}},2933:function(e){e.exports=function(e,t){return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e}},7536:function(e){e.exports=function(){var e=new Float32Array(4);return e[0]=0,e[1]=0,e[2]=0,e[3]=0,e}},4691:function(e){e.exports=function(e,t){var r=t[0]-e[0],n=t[1]-e[1],i=t[2]-e[2],o=t[3]-e[3];return Math.sqrt(r*r+n*n+i*i+o*o)}},1373:function(e){e.exports=function(e,t,r){return e[0]=t[0]/r[0],e[1]=t[1]/r[1],e[2]=t[2]/r[2],e[3]=t[3]/r[3],e}},3750:function(e){e.exports=function(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]+e[3]*t[3]}},3390:function(e){e.exports=function(e,t,r,n){var i=new Float32Array(4);return i[0]=e,i[1]=t,i[2]=r,i[3]=n,i}},9970:function(e,t,r){e.exports={create:r(7536),clone:r(2335),fromValues:r(3390),copy:r(2933),set:r(4578),add:r(4361),subtract:r(6860),multiply:r(3576),divide:r(1373),min:r(2334),max:r(160),scale:r(9288),scaleAndAdd:r(4844),distance:r(4691),squaredDistance:r(7960),length:r(6808),squaredLength:r(483),negate:r(1498),inverse:r(4494),normalize:r(5177),dot:r(3750),lerp:r(2573),random:r(9131),transformMat4:r(5352),transformQuat:r(4041)}},4494:function(e){e.exports=function(e,t){return e[0]=1/t[0],e[1]=1/t[1],e[2]=1/t[2],e[3]=1/t[3],e}},6808:function(e){e.exports=function(e){var t=e[0],r=e[1],n=e[2],i=e[3];return Math.sqrt(t*t+r*r+n*n+i*i)}},2573:function(e){e.exports=function(e,t,r,n){var i=t[0],o=t[1],a=t[2],s=t[3];return e[0]=i+n*(r[0]-i),e[1]=o+n*(r[1]-o),e[2]=a+n*(r[2]-a),e[3]=s+n*(r[3]-s),e}},160:function(e){e.exports=function(e,t,r){return e[0]=Math.max(t[0],r[0]),e[1]=Math.max(t[1],r[1]),e[2]=Math.max(t[2],r[2]),e[3]=Math.max(t[3],r[3]),e}},2334:function(e){e.exports=function(e,t,r){return e[0]=Math.min(t[0],r[0]),e[1]=Math.min(t[1],r[1]),e[2]=Math.min(t[2],r[2]),e[3]=Math.min(t[3],r[3]),e}},3576:function(e){e.exports=function(e,t,r){return e[0]=t[0]*r[0],e[1]=t[1]*r[1],e[2]=t[2]*r[2],e[3]=t[3]*r[3],e}},1498:function(e){e.exports=function(e,t){return e[0]=-t[0],e[1]=-t[1],e[2]=-t[2],e[3]=-t[3],e}},5177:function(e){e.exports=function(e,t){var r=t[0],n=t[1],i=t[2],o=t[3],a=r*r+n*n+i*i+o*o;a>0&&(a=1/Math.sqrt(a),e[0]=r*a,e[1]=n*a,e[2]=i*a,e[3]=o*a);return e}},9131:function(e,t,r){var n=r(5177),i=r(9288);e.exports=function(e,t){return t=t||1,e[0]=Math.random(),e[1]=Math.random(),e[2]=Math.random(),e[3]=Math.random(),n(e,e),i(e,e,t),e}},9288:function(e){e.exports=function(e,t,r){return e[0]=t[0]*r,e[1]=t[1]*r,e[2]=t[2]*r,e[3]=t[3]*r,e}},4844:function(e){e.exports=function(e,t,r,n){return e[0]=t[0]+r[0]*n,e[1]=t[1]+r[1]*n,e[2]=t[2]+r[2]*n,e[3]=t[3]+r[3]*n,e}},4578:function(e){e.exports=function(e,t,r,n,i){return e[0]=t,e[1]=r,e[2]=n,e[3]=i,e}},7960:function(e){e.exports=function(e,t){var r=t[0]-e[0],n=t[1]-e[1],i=t[2]-e[2],o=t[3]-e[3];return r*r+n*n+i*i+o*o}},483:function(e){e.exports=function(e){var t=e[0],r=e[1],n=e[2],i=e[3];return t*t+r*r+n*n+i*i}},6860:function(e){e.exports=function(e,t,r){return e[0]=t[0]-r[0],e[1]=t[1]-r[1],e[2]=t[2]-r[2],e[3]=t[3]-r[3],e}},5352:function(e){e.exports=function(e,t,r){var n=t[0],i=t[1],o=t[2],a=t[3];return e[0]=r[0]*n+r[4]*i+r[8]*o+r[12]*a,e[1]=r[1]*n+r[5]*i+r[9]*o+r[13]*a,e[2]=r[2]*n+r[6]*i+r[10]*o+r[14]*a,e[3]=r[3]*n+r[7]*i+r[11]*o+r[15]*a,e}},4041:function(e){e.exports=function(e,t,r){var n=t[0],i=t[1],o=t[2],a=r[0],s=r[1],l=r[2],c=r[3],u=c*n+s*o-l*i,d=c*i+l*n-a*o,h=c*o+a*i-s*n,p=-a*n-s*i-l*o;return e[0]=u*c+p*-a+d*-l-h*-s,e[1]=d*c+p*-s+h*-a-u*-l,e[2]=h*c+p*-l+u*-s-d*-a,e[3]=t[3],e}},1848:function(e,t,r){var n=r(4905),i=r(6468);e.exports=function(e){for(var t=Array.isArray(e)?e:n(e),r=0;r0)continue;r=e.slice(0,1).join("")}return N(r),P+=r.length,(M=M.slice(r.length)).length}}function G(){return/[^a-fA-F0-9]/.test(t)?(N(M.join("")),T=l,S):(M.push(t),r=t,S+1)}function Y(){return"."===t||/[eE]/.test(t)?(M.push(t),T=m,r=t,S+1):"x"===t&&1===M.length&&"0"===M[0]?(T=_,M.push(t),r=t,S+1):/[^\d]/.test(t)?(N(M.join("")),T=l,S):(M.push(t),r=t,S+1)}function X(){return"f"===t&&(M.push(t),r=t,S+=1),/[eE]/.test(t)?(M.push(t),r=t,S+1):("-"!==t&&"+"!==t||!/[eE]/.test(r))&&/[^\d]/.test(t)?(N(M.join("")),T=l,S):(M.push(t),r=t,S+1)}function Z(){if(/[^\d\w_]/.test(t)){var e=M.join("");return T=F[e]?v:j[e]?y:g,N(M.join("")),T=l,S}return M.push(t),r=t,S+1}};var n=r(620),i=r(7827),o=r(6852),a=r(7932),s=r(3508),l=999,c=9999,u=0,d=1,h=2,p=3,f=4,m=5,g=6,y=7,v=8,x=9,b=10,_=11,w=["block-comment","line-comment","preprocessor","operator","integer","float","ident","builtin","keyword","whitespace","eof","integer"]},3508:function(e,t,r){var n=r(6852);n=n.slice().filter((function(e){return!/^(gl\_|texture)/.test(e)})),e.exports=n.concat(["gl_VertexID","gl_InstanceID","gl_Position","gl_PointSize","gl_FragCoord","gl_FrontFacing","gl_FragDepth","gl_PointCoord","gl_MaxVertexAttribs","gl_MaxVertexUniformVectors","gl_MaxVertexOutputVectors","gl_MaxFragmentInputVectors","gl_MaxVertexTextureImageUnits","gl_MaxCombinedTextureImageUnits","gl_MaxTextureImageUnits","gl_MaxFragmentUniformVectors","gl_MaxDrawBuffers","gl_MinProgramTexelOffset","gl_MaxProgramTexelOffset","gl_DepthRangeParameters","gl_DepthRange","trunc","round","roundEven","isnan","isinf","floatBitsToInt","floatBitsToUint","intBitsToFloat","uintBitsToFloat","packSnorm2x16","unpackSnorm2x16","packUnorm2x16","unpackUnorm2x16","packHalf2x16","unpackHalf2x16","outerProduct","transpose","determinant","inverse","texture","textureSize","textureProj","textureLod","textureOffset","texelFetch","texelFetchOffset","textureProjOffset","textureLodOffset","textureProjLod","textureProjLodOffset","textureGrad","textureGradOffset","textureProjGrad","textureProjGradOffset"])},6852:function(e){e.exports=["abs","acos","all","any","asin","atan","ceil","clamp","cos","cross","dFdx","dFdy","degrees","distance","dot","equal","exp","exp2","faceforward","floor","fract","gl_BackColor","gl_BackLightModelProduct","gl_BackLightProduct","gl_BackMaterial","gl_BackSecondaryColor","gl_ClipPlane","gl_ClipVertex","gl_Color","gl_DepthRange","gl_DepthRangeParameters","gl_EyePlaneQ","gl_EyePlaneR","gl_EyePlaneS","gl_EyePlaneT","gl_Fog","gl_FogCoord","gl_FogFragCoord","gl_FogParameters","gl_FragColor","gl_FragCoord","gl_FragData","gl_FragDepth","gl_FragDepthEXT","gl_FrontColor","gl_FrontFacing","gl_FrontLightModelProduct","gl_FrontLightProduct","gl_FrontMaterial","gl_FrontSecondaryColor","gl_LightModel","gl_LightModelParameters","gl_LightModelProducts","gl_LightProducts","gl_LightSource","gl_LightSourceParameters","gl_MaterialParameters","gl_MaxClipPlanes","gl_MaxCombinedTextureImageUnits","gl_MaxDrawBuffers","gl_MaxFragmentUniformComponents","gl_MaxLights","gl_MaxTextureCoords","gl_MaxTextureImageUnits","gl_MaxTextureUnits","gl_MaxVaryingFloats","gl_MaxVertexAttribs","gl_MaxVertexTextureImageUnits","gl_MaxVertexUniformComponents","gl_ModelViewMatrix","gl_ModelViewMatrixInverse","gl_ModelViewMatrixInverseTranspose","gl_ModelViewMatrixTranspose","gl_ModelViewProjectionMatrix","gl_ModelViewProjectionMatrixInverse","gl_ModelViewProjectionMatrixInverseTranspose","gl_ModelViewProjectionMatrixTranspose","gl_MultiTexCoord0","gl_MultiTexCoord1","gl_MultiTexCoord2","gl_MultiTexCoord3","gl_MultiTexCoord4","gl_MultiTexCoord5","gl_MultiTexCoord6","gl_MultiTexCoord7","gl_Normal","gl_NormalMatrix","gl_NormalScale","gl_ObjectPlaneQ","gl_ObjectPlaneR","gl_ObjectPlaneS","gl_ObjectPlaneT","gl_Point","gl_PointCoord","gl_PointParameters","gl_PointSize","gl_Position","gl_ProjectionMatrix","gl_ProjectionMatrixInverse","gl_ProjectionMatrixInverseTranspose","gl_ProjectionMatrixTranspose","gl_SecondaryColor","gl_TexCoord","gl_TextureEnvColor","gl_TextureMatrix","gl_TextureMatrixInverse","gl_TextureMatrixInverseTranspose","gl_TextureMatrixTranspose","gl_Vertex","greaterThan","greaterThanEqual","inversesqrt","length","lessThan","lessThanEqual","log","log2","matrixCompMult","max","min","mix","mod","normalize","not","notEqual","pow","radians","reflect","refract","sign","sin","smoothstep","sqrt","step","tan","texture2D","texture2DLod","texture2DProj","texture2DProjLod","textureCube","textureCubeLod","texture2DLodEXT","texture2DProjLodEXT","textureCubeLodEXT","texture2DGradEXT","texture2DProjGradEXT","textureCubeGradEXT"]},7932:function(e,t,r){var n=r(620);e.exports=n.slice().concat(["layout","centroid","smooth","case","mat2x2","mat2x3","mat2x4","mat3x2","mat3x3","mat3x4","mat4x2","mat4x3","mat4x4","uvec2","uvec3","uvec4","samplerCubeShadow","sampler2DArray","sampler2DArrayShadow","isampler2D","isampler3D","isamplerCube","isampler2DArray","usampler2D","usampler3D","usamplerCube","usampler2DArray","coherent","restrict","readonly","writeonly","resource","atomic_uint","noperspective","patch","sample","subroutine","common","partition","active","filter","image1D","image2D","image3D","imageCube","iimage1D","iimage2D","iimage3D","iimageCube","uimage1D","uimage2D","uimage3D","uimageCube","image1DArray","image2DArray","iimage1DArray","iimage2DArray","uimage1DArray","uimage2DArray","image1DShadow","image2DShadow","image1DArrayShadow","image2DArrayShadow","imageBuffer","iimageBuffer","uimageBuffer","sampler1DArray","sampler1DArrayShadow","isampler1D","isampler1DArray","usampler1D","usampler1DArray","isampler2DRect","usampler2DRect","samplerBuffer","isamplerBuffer","usamplerBuffer","sampler2DMS","isampler2DMS","usampler2DMS","sampler2DMSArray","isampler2DMSArray","usampler2DMSArray"])},620:function(e){e.exports=["precision","highp","mediump","lowp","attribute","const","uniform","varying","break","continue","do","for","while","if","else","in","out","inout","float","int","uint","void","bool","true","false","discard","return","mat2","mat3","mat4","vec2","vec3","vec4","ivec2","ivec3","ivec4","bvec2","bvec3","bvec4","sampler1D","sampler2D","sampler3D","samplerCube","sampler1DShadow","sampler2DShadow","struct","asm","class","union","enum","typedef","template","this","packed","goto","switch","default","inline","noinline","volatile","public","static","extern","external","interface","long","short","double","half","fixed","unsigned","input","output","hvec2","hvec3","hvec4","dvec2","dvec3","dvec4","fvec2","fvec3","fvec4","sampler2DRect","sampler3DRect","sampler2DRectShadow","sizeof","cast","namespace","using"]},7827:function(e){e.exports=["<<=",">>=","++","--","<<",">>","<=",">=","==","!=","&&","||","+=","-=","*=","/=","%=","&=","^^","^=","|=","(",")","[","]",".","!","~","*","/","%","+","-","<",">","&","^","|","?",":","=",",",";","{","}"]},4905:function(e,t,r){var n=r(5874);e.exports=function(e,t){var r=n(t),i=[];return i=(i=i.concat(r(e))).concat(r(null))}},3236:function(e){e.exports=function(e){"string"===typeof e&&(e=[e]);for(var t=[].slice.call(arguments,1),r=[],n=0;n>1,u=-7,d=r?i-1:0,h=r?-1:1,p=e[t+d];for(d+=h,o=p&(1<<-u)-1,p>>=-u,u+=s;u>0;o=256*o+e[t+d],d+=h,u-=8);for(a=o&(1<<-u)-1,o>>=-u,u+=n;u>0;a=256*a+e[t+d],d+=h,u-=8);if(0===o)o=1-c;else{if(o===l)return a?NaN:1/0*(p?-1:1);a+=Math.pow(2,n),o-=c}return(p?-1:1)*a*Math.pow(2,o-n)},t.write=function(e,t,r,n,i,o){var a,s,l,c=8*o-i-1,u=(1<>1,h=23===i?Math.pow(2,-24)-Math.pow(2,-77):0,p=n?0:o-1,f=n?1:-1,m=t<0||0===t&&1/t<0?1:0;for(t=Math.abs(t),isNaN(t)||t===1/0?(s=isNaN(t)?1:0,a=u):(a=Math.floor(Math.log(t)/Math.LN2),t*(l=Math.pow(2,-a))<1&&(a--,l*=2),(t+=a+d>=1?h/l:h*Math.pow(2,1-d))*l>=2&&(a++,l/=2),a+d>=u?(s=0,a=u):a+d>=1?(s=(t*l-1)*Math.pow(2,i),a+=d):(s=t*Math.pow(2,d-1)*Math.pow(2,i),a=0));i>=8;e[r+p]=255&s,p+=f,s/=256,i-=8);for(a=a<0;e[r+p]=255&a,p+=f,a/=256,c-=8);e[r+p-f]|=128*m}},8954:function(e,t,r){"use strict";e.exports=function(e,t){var r=e.length;if(0===r)throw new Error("Must have at least d+1 points");var i=e[0].length;if(r<=i)throw new Error("Must input at least d+1 points");var a=e.slice(0,i+1),s=n.apply(void 0,a);if(0===s)throw new Error("Input not in general position");for(var l=new Array(i+1),u=0;u<=i;++u)l[u]=u;s<0&&(l[0]=1,l[1]=0);var d=new o(l,new Array(i+1),!1),h=d.adjacent,p=new Array(i+2);for(u=0;u<=i;++u){for(var f=l.slice(),m=0;m<=i;++m)m===u&&(f[m]=-1);var g=f[0];f[0]=f[1],f[1]=g;var y=new o(f,new Array(i+1),!0);h[u]=y,p[u]=y}p[i+1]=d;for(u=0;u<=i;++u){f=h[u].vertices;var v=h[u].adjacent;for(m=0;m<=i;++m){var x=f[m];if(x<0)v[m]=d;else for(var b=0;b<=i;++b)h[b].vertices.indexOf(x)<0&&(v[m]=h[b])}}var _=new c(i,a,p),w=!!t;for(u=i+1;u0;)for(var s=(e=a.pop()).adjacent,l=0;l<=r;++l){var c=s[l];if(c.boundary&&!(c.lastVisited<=-n)){for(var u=c.vertices,d=0;d<=r;++d){var h=u[d];i[d]=h<0?t:o[h]}var p=this.orient();if(p>0)return c;c.lastVisited=-n,0===p&&a.push(c)}}return null},u.walk=function(e,t){var r=this.vertices.length-1,n=this.dimension,i=this.vertices,o=this.tuple,a=t?this.interior.length*Math.random()|0:this.interior.length-1,s=this.interior[a];e:for(;!s.boundary;){for(var l=s.vertices,c=s.adjacent,u=0;u<=n;++u)o[u]=i[l[u]];s.lastVisited=r;for(u=0;u<=n;++u){var d=c[u];if(!(d.lastVisited>=r)){var h=o[u];o[u]=e;var p=this.orient();if(o[u]=h,p<0){s=d;continue e}d.boundary?d.lastVisited=-r:d.lastVisited=r}}return}return s},u.addPeaks=function(e,t){var r=this.vertices.length-1,n=this.dimension,i=this.vertices,l=this.tuple,c=this.interior,u=this.simplices,d=[t];t.lastVisited=r,t.vertices[t.vertices.indexOf(-1)]=r,t.boundary=!1,c.push(t);for(var h=[];d.length>0;){var p=(t=d.pop()).vertices,f=t.adjacent,m=p.indexOf(r);if(!(m<0))for(var g=0;g<=n;++g)if(g!==m){var y=f[g];if(y.boundary&&!(y.lastVisited>=r)){var v=y.vertices;if(y.lastVisited!==-r){for(var x=0,b=0;b<=n;++b)v[b]<0?(x=b,l[b]=e):l[b]=i[v[b]];if(this.orient()>0){v[x]=r,y.boundary=!1,c.push(y),d.push(y),y.lastVisited=r;continue}y.lastVisited=-r}var _=y.adjacent,w=p.slice(),k=f.slice(),S=new o(w,k,!0);u.push(S);var A=_.indexOf(t);if(!(A<0)){_[A]=S,k[m]=y,w[g]=-1,k[g]=t,f[g]=S,S.flip();for(b=0;b<=n;++b){var T=w[b];if(!(T<0||T===r)){for(var M=new Array(n-1),C=0,E=0;E<=n;++E){var I=w[E];I<0||E===b||(M[C++]=I)}h.push(new a(M,S,b))}}}}}}h.sort(s);for(g=0;g+1=0?a[l++]=s[u]:c=1&u;if(c===(1&e)){var d=a[0];a[0]=a[1],a[1]=d}t.push(a)}}return t}},3352:function(e,t,r){"use strict";var n=r(2478);function i(e,t,r,n,i){this.mid=e,this.left=t,this.right=r,this.leftPoints=n,this.rightPoints=i,this.count=(t?t.count:0)+(r?r.count:0)+n.length}e.exports=function(e){if(!e||0===e.length)return new y(null);return new y(g(e))};var o=i.prototype;function a(e,t){e.mid=t.mid,e.left=t.left,e.right=t.right,e.leftPoints=t.leftPoints,e.rightPoints=t.rightPoints,e.count=t.count}function s(e,t){var r=g(t);e.mid=r.mid,e.left=r.left,e.right=r.right,e.leftPoints=r.leftPoints,e.rightPoints=r.rightPoints,e.count=r.count}function l(e,t){var r=e.intervals([]);r.push(t),s(e,r)}function c(e,t){var r=e.intervals([]),n=r.indexOf(t);return n<0?0:(r.splice(n,1),s(e,r),1)}function u(e,t,r){for(var n=0;n=0&&e[n][1]>=t;--n){var i=r(e[n]);if(i)return i}}function h(e,t){for(var r=0;r>1],o=[],a=[],s=[];for(r=0;r3*(t+1)?l(this,e):this.left.insert(e):this.left=g([e]);else if(e[0]>this.mid)this.right?4*(this.right.count+1)>3*(t+1)?l(this,e):this.right.insert(e):this.right=g([e]);else{var r=n.ge(this.leftPoints,e,f),i=n.ge(this.rightPoints,e,m);this.leftPoints.splice(r,0,e),this.rightPoints.splice(i,0,e)}},o.remove=function(e){var t=this.count-this.leftPoints;if(e[1]3*(t-1)?c(this,e):2===(s=this.left.remove(e))?(this.left=null,this.count-=1,1):(1===s&&(this.count-=1),s):0;if(e[0]>this.mid)return this.right?4*(this.left?this.left.count:0)>3*(t-1)?c(this,e):2===(s=this.right.remove(e))?(this.right=null,this.count-=1,1):(1===s&&(this.count-=1),s):0;if(1===this.count)return this.leftPoints[0]===e?2:0;if(1===this.leftPoints.length&&this.leftPoints[0]===e){if(this.left&&this.right){for(var r=this,i=this.left;i.right;)r=i,i=i.right;if(r===this)i.right=this.right;else{var o=this.left,s=this.right;r.count-=i.count,r.right=i.left,i.left=o,i.right=s}a(this,i),this.count=(this.left?this.left.count:0)+(this.right?this.right.count:0)+this.leftPoints.length}else this.left?a(this,this.left):a(this,this.right);return 1}for(o=n.ge(this.leftPoints,e,f);othis.mid){var r;if(this.right)if(r=this.right.queryPoint(e,t))return r;return d(this.rightPoints,e,t)}return h(this.leftPoints,t)},o.queryInterval=function(e,t,r){var n;if(ethis.mid&&this.right&&(n=this.right.queryInterval(e,t,r)))return n;return tthis.mid?d(this.rightPoints,e,r):h(this.leftPoints,r)};var v=y.prototype;v.insert=function(e){this.root?this.root.insert(e):this.root=new i(e[0],null,null,[e],[e])},v.remove=function(e){if(this.root){var t=this.root.remove(e);return 2===t&&(this.root=null),0!==t}return!1},v.queryPoint=function(e,t){if(this.root)return this.root.queryPoint(e,t)},v.queryInterval=function(e,t,r){if(e<=t&&this.root)return this.root.queryInterval(e,t,r)},Object.defineProperty(v,"count",{get:function(){return this.root?this.root.count:0}}),Object.defineProperty(v,"intervals",{get:function(){return this.root?this.root.intervals([]):[]}})},7762:function(e){"use strict";e.exports=function(e){for(var t=new Array(e),r=0;r13)&&32!==t&&133!==t&&160!==t&&5760!==t&&6158!==t&&(t<8192||t>8205)&&8232!==t&&8233!==t&&8239!==t&&8287!==t&&8288!==t&&12288!==t&&65279!==t)return!1;return!0}},395:function(e){e.exports=function(e,t,r){return e*(1-r)+t*r}},2652:function(e,t,r){var n=r(4335),i=r(6864),o=r(1903),a=r(9921),s=r(7608),l=r(5665),c={length:r(1387),normalize:r(3536),dot:r(244),cross:r(5911)},u=i(),d=i(),h=[0,0,0,0],p=[[0,0,0],[0,0,0],[0,0,0]],f=[0,0,0];function m(e,t,r,n,i){e[0]=t[0]*n+r[0]*i,e[1]=t[1]*n+r[1]*i,e[2]=t[2]*n+r[2]*i}e.exports=function(e,t,r,i,g,y){if(t||(t=[0,0,0]),r||(r=[0,0,0]),i||(i=[0,0,0]),g||(g=[0,0,0,1]),y||(y=[0,0,0,1]),!n(u,e))return!1;if(o(d,u),d[3]=0,d[7]=0,d[11]=0,d[15]=1,Math.abs(a(d)<1e-8))return!1;var v,x,b=u[3],_=u[7],w=u[11],k=u[12],S=u[13],A=u[14],T=u[15];if(0!==b||0!==_||0!==w){if(h[0]=b,h[1]=_,h[2]=w,h[3]=T,!s(d,d))return!1;l(d,d),function(e,t,r){var n=t[0],i=t[1],o=t[2],a=t[3];e[0]=r[0]*n+r[4]*i+r[8]*o+r[12]*a,e[1]=r[1]*n+r[5]*i+r[9]*o+r[13]*a,e[2]=r[2]*n+r[6]*i+r[10]*o+r[14]*a,e[3]=r[3]*n+r[7]*i+r[11]*o+r[15]*a}(g,h,d)}else g[0]=g[1]=g[2]=0,g[3]=1;if(t[0]=k,t[1]=S,t[2]=A,x=u,(v=p)[0][0]=x[0],v[0][1]=x[1],v[0][2]=x[2],v[1][0]=x[4],v[1][1]=x[5],v[1][2]=x[6],v[2][0]=x[8],v[2][1]=x[9],v[2][2]=x[10],r[0]=c.length(p[0]),c.normalize(p[0],p[0]),i[0]=c.dot(p[0],p[1]),m(p[1],p[1],p[0],1,-i[0]),r[1]=c.length(p[1]),c.normalize(p[1],p[1]),i[0]/=r[1],i[1]=c.dot(p[0],p[2]),m(p[2],p[2],p[0],1,-i[1]),i[2]=c.dot(p[1],p[2]),m(p[2],p[2],p[1],1,-i[2]),r[2]=c.length(p[2]),c.normalize(p[2],p[2]),i[1]/=r[2],i[2]/=r[2],c.cross(f,p[1],p[2]),c.dot(p[0],f)<0)for(var M=0;M<3;M++)r[M]*=-1,p[M][0]*=-1,p[M][1]*=-1,p[M][2]*=-1;return y[0]=.5*Math.sqrt(Math.max(1+p[0][0]-p[1][1]-p[2][2],0)),y[1]=.5*Math.sqrt(Math.max(1-p[0][0]+p[1][1]-p[2][2],0)),y[2]=.5*Math.sqrt(Math.max(1-p[0][0]-p[1][1]+p[2][2],0)),y[3]=.5*Math.sqrt(Math.max(1+p[0][0]+p[1][1]+p[2][2],0)),p[2][1]>p[1][2]&&(y[0]=-y[0]),p[0][2]>p[2][0]&&(y[1]=-y[1]),p[1][0]>p[0][1]&&(y[2]=-y[2]),!0}},4335:function(e){e.exports=function(e,t){var r=t[15];if(0===r)return!1;for(var n=1/r,i=0;i<16;i++)e[i]=t[i]*n;return!0}},7442:function(e,t,r){var n=r(6658),i=r(7182),o=r(2652),a=r(9921),s=r(8648),l=d(),c=d(),u=d();function d(){return{translate:h(),scale:h(1),skew:h(),perspective:[0,0,0,1],quaternion:[0,0,0,1]}}function h(e){return[e||0,e||0,e||0]}e.exports=function(e,t,r,d){if(0===a(t)||0===a(r))return!1;var h=o(t,l.translate,l.scale,l.skew,l.perspective,l.quaternion),p=o(r,c.translate,c.scale,c.skew,c.perspective,c.quaternion);return!(!h||!p)&&(n(u.translate,l.translate,c.translate,d),n(u.skew,l.skew,c.skew,d),n(u.scale,l.scale,c.scale,d),n(u.perspective,l.perspective,c.perspective,d),s(u.quaternion,l.quaternion,c.quaternion,d),i(e,u.translate,u.scale,u.skew,u.perspective,u.quaternion),!0)}},7182:function(e,t,r){var n={identity:r(7894),translate:r(7656),multiply:r(6760),create:r(6864),scale:r(2504),fromRotationTranslation:r(6743)},i=(n.create(),n.create());e.exports=function(e,t,r,o,a,s){return n.identity(e),n.fromRotationTranslation(e,s,t),e[3]=a[0],e[7]=a[1],e[11]=a[2],e[15]=a[3],n.identity(i),0!==o[2]&&(i[9]=o[2],n.multiply(e,e,i)),0!==o[1]&&(i[9]=0,i[8]=o[1],n.multiply(e,e,i)),0!==o[0]&&(i[8]=0,i[4]=o[0],n.multiply(e,e,i)),n.scale(e,e,r),e}},4192:function(e,t,r){"use strict";var n=r(2478),i=r(7442),o=r(7608),a=r(5567),s=r(2408),l=r(7089),c=r(6582),u=r(7656),d=(r(2504),r(3536)),h=[0,0,0];function p(e){this._components=e.slice(),this._time=[0],this.prevMatrix=e.slice(),this.nextMatrix=e.slice(),this.computedMatrix=e.slice(),this.computedInverse=e.slice(),this.computedEye=[0,0,0],this.computedUp=[0,0,0],this.computedCenter=[0,0,0],this.computedRadius=[0],this._limits=[-1/0,1/0]}e.exports=function(e){return new p((e=e||{}).matrix||[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1])};var f=p.prototype;f.recalcMatrix=function(e){var t=this._time,r=n.le(t,e),a=this.computedMatrix;if(!(r<0)){var s=this._components;if(r===t.length-1)for(var l=16*r,c=0;c<16;++c)a[c]=s[l++];else{var u=t[r+1]-t[r],h=(l=16*r,this.prevMatrix),p=!0;for(c=0;c<16;++c)h[c]=s[l++];var f=this.nextMatrix;for(c=0;c<16;++c)f[c]=s[l++],p=p&&h[c]===f[c];if(u<1e-6||p)for(c=0;c<16;++c)a[c]=h[c];else i(a,h,f,(e-t[r])/u)}var m=this.computedUp;m[0]=a[1],m[1]=a[5],m[2]=a[9],d(m,m);var g=this.computedInverse;o(g,a);var y=this.computedEye,v=g[15];y[0]=g[12]/v,y[1]=g[13]/v,y[2]=g[14]/v;var x=this.computedCenter,b=Math.exp(this.computedRadius[0]);for(c=0;c<3;++c)x[c]=y[c]-a[2+4*c]*b}},f.idle=function(e){if(!(e1&&n(e[a[u-2]],e[a[u-1]],c)<=0;)u-=1,a.pop();for(a.push(l),u=s.length;u>1&&n(e[s[u-2]],e[s[u-1]],c)>=0;)u-=1,s.pop();s.push(l)}r=new Array(s.length+a.length-2);for(var d=0,h=(i=0,a.length);i0;--p)r[d++]=s[p];return r};var n=r(3250)[3]},351:function(e,t,r){"use strict";e.exports=function(e,t){t||(t=e,e=window);var r=0,i=0,o=0,a={shift:!1,alt:!1,control:!1,meta:!1},s=!1;function l(e){var t=!1;return"altKey"in e&&(t=t||e.altKey!==a.alt,a.alt=!!e.altKey),"shiftKey"in e&&(t=t||e.shiftKey!==a.shift,a.shift=!!e.shiftKey),"ctrlKey"in e&&(t=t||e.ctrlKey!==a.control,a.control=!!e.ctrlKey),"metaKey"in e&&(t=t||e.metaKey!==a.meta,a.meta=!!e.metaKey),t}function c(e,s){var c=n.x(s),u=n.y(s);"buttons"in s&&(e=0|s.buttons),(e!==r||c!==i||u!==o||l(s))&&(r=0|e,i=c||0,o=u||0,t&&t(r,i,o,a))}function u(e){c(0,e)}function d(){(r||i||o||a.shift||a.alt||a.meta||a.control)&&(i=o=0,r=0,a.shift=a.alt=a.control=a.meta=!1,t&&t(0,0,0,a))}function h(e){l(e)&&t&&t(r,i,o,a)}function p(e){0===n.buttons(e)?c(0,e):c(r,e)}function f(e){c(r|n.buttons(e),e)}function m(e){c(r&~n.buttons(e),e)}function g(){s||(s=!0,e.addEventListener("mousemove",p),e.addEventListener("mousedown",f),e.addEventListener("mouseup",m),e.addEventListener("mouseleave",u),e.addEventListener("mouseenter",u),e.addEventListener("mouseout",u),e.addEventListener("mouseover",u),e.addEventListener("blur",d),e.addEventListener("keyup",h),e.addEventListener("keydown",h),e.addEventListener("keypress",h),e!==window&&(window.addEventListener("blur",d),window.addEventListener("keyup",h),window.addEventListener("keydown",h),window.addEventListener("keypress",h)))}g();var y={element:e};return Object.defineProperties(y,{enabled:{get:function(){return s},set:function(t){t?g():function(){if(!s)return;s=!1,e.removeEventListener("mousemove",p),e.removeEventListener("mousedown",f),e.removeEventListener("mouseup",m),e.removeEventListener("mouseleave",u),e.removeEventListener("mouseenter",u),e.removeEventListener("mouseout",u),e.removeEventListener("mouseover",u),e.removeEventListener("blur",d),e.removeEventListener("keyup",h),e.removeEventListener("keydown",h),e.removeEventListener("keypress",h),e!==window&&(window.removeEventListener("blur",d),window.removeEventListener("keyup",h),window.removeEventListener("keydown",h),window.removeEventListener("keypress",h))}()},enumerable:!0},buttons:{get:function(){return r},enumerable:!0},x:{get:function(){return i},enumerable:!0},y:{get:function(){return o},enumerable:!0},mods:{get:function(){return a},enumerable:!0}}),y};var n=r(4687)},24:function(e){var t={left:0,top:0};e.exports=function(e,r,n){r=r||e.currentTarget||e.srcElement,Array.isArray(n)||(n=[0,0]);var i=e.clientX||0,o=e.clientY||0,a=(s=r,s===window||s===document||s===document.body?t:s.getBoundingClientRect());var s;return n[0]=i-a.left,n[1]=o-a.top,n}},4687:function(e,t){"use strict";function r(e){return e.target||e.srcElement||window}t.buttons=function(e){if("object"===typeof e){if("buttons"in e)return e.buttons;if("which"in e){if(2===(t=e.which))return 4;if(3===t)return 2;if(t>0)return 1<=0)return 1< 0");"function"!==typeof e.vertex&&t("Must specify vertex creation function");"function"!==typeof e.cell&&t("Must specify cell creation function");"function"!==typeof e.phase&&t("Must specify phase function");for(var s=e.getters||[],l=new Array(o),c=0;c=0?l[c]=!0:l[c]=!1;return function(e,t,r,o,a,s){var l=[s,a].join(",");return(0,i[l])(e,t,r,n.mallocUint32,n.freeUint32)}(e.vertex,e.cell,e.phase,0,r,l)};var i={"false,0,1":function(e,t,r,n,i){return function(o,a,s,l){var c,u=0|o.shape[0],d=0|o.shape[1],h=o.data,p=0|o.offset,f=0|o.stride[0],m=0|o.stride[1],g=p,y=0|-f,v=0,x=0|-m,b=0,_=-f-m|0,w=0,k=0|f,S=m-f*u|0,A=0,T=0,M=0,C=2*u|0,E=n(C),I=n(C),P=0,O=0,R=-1,L=-1,D=0,z=0|-u,j=0|u,F=0,N=-u-1|0,B=u-1|0,V=0,U=0,H=0;for(A=0;A0){if(T=1,E[P++]=r(h[g],a,s,l),g+=k,u>0)for(A=1,c=h[g],O=E[P]=r(c,a,s,l),D=E[P+R],F=E[P+z],V=E[P+N],O===D&&O===F&&O===V||(v=h[g+y],b=h[g+x],w=h[g+_],e(A,T,c,v,b,w,O,D,F,V,a,s,l),U=I[P]=M++),P+=1,g+=k,A=2;A0)for(A=1,c=h[g],O=E[P]=r(c,a,s,l),D=E[P+R],F=E[P+z],V=E[P+N],O===D&&O===F&&O===V||(v=h[g+y],b=h[g+x],w=h[g+_],e(A,T,c,v,b,w,O,D,F,V,a,s,l),U=I[P]=M++,V!==F&&t(I[P+z],U,b,w,F,V,a,s,l)),P+=1,g+=k,A=2;A0){if(A=1,E[P++]=r(h[g],a,s,l),g+=k,d>0)for(T=1,c=h[g],O=E[P]=r(c,a,s,l),F=E[P+z],D=E[P+R],V=E[P+N],O===F&&O===D&&O===V||(v=h[g+y],b=h[g+x],w=h[g+_],e(A,T,c,v,b,w,O,F,D,V,a,s,l),U=I[P]=M++),P+=1,g+=k,T=2;T0)for(T=1,c=h[g],O=E[P]=r(c,a,s,l),F=E[P+z],D=E[P+R],V=E[P+N],O===F&&O===D&&O===V||(v=h[g+y],b=h[g+x],w=h[g+_],e(A,T,c,v,b,w,O,F,D,V,a,s,l),U=I[P]=M++,V!==F&&t(I[P+z],U,w,v,V,F,a,s,l)),P+=1,g+=k,T=2;T2&&o[1]>2&&n(i.pick(-1,-1).lo(1,1).hi(o[0]-2,o[1]-2),e.pick(-1,-1,0).lo(1,1).hi(o[0]-2,o[1]-2),e.pick(-1,-1,1).lo(1,1).hi(o[0]-2,o[1]-2)),o[1]>2&&(r(i.pick(0,-1).lo(1).hi(o[1]-2),e.pick(0,-1,1).lo(1).hi(o[1]-2)),t(e.pick(0,-1,0).lo(1).hi(o[1]-2))),o[1]>2&&(r(i.pick(o[0]-1,-1).lo(1).hi(o[1]-2),e.pick(o[0]-1,-1,1).lo(1).hi(o[1]-2)),t(e.pick(o[0]-1,-1,0).lo(1).hi(o[1]-2))),o[0]>2&&(r(i.pick(-1,0).lo(1).hi(o[0]-2),e.pick(-1,0,0).lo(1).hi(o[0]-2)),t(e.pick(-1,0,1).lo(1).hi(o[0]-2))),o[0]>2&&(r(i.pick(-1,o[1]-1).lo(1).hi(o[0]-2),e.pick(-1,o[1]-1,0).lo(1).hi(o[0]-2)),t(e.pick(-1,o[1]-1,1).lo(1).hi(o[0]-2))),e.set(0,0,0,0),e.set(0,0,1,0),e.set(o[0]-1,0,0,0),e.set(o[0]-1,0,1,0),e.set(0,o[1]-1,0,0),e.set(0,o[1]-1,1,0),e.set(o[0]-1,o[1]-1,0,0),e.set(o[0]-1,o[1]-1,1,0),e}}e.exports=function(e,t,r){return Array.isArray(r)||(r=n(t.dimension,"string"===typeof r?r:"clamp")),0===t.size?e:0===t.dimension?(e.set(0),e):function(e){var t=e.join();if(o=u[t])return o;for(var r=e.length,n=[d,h],i=1;i<=r;++i)n.push(p(i));var o=f.apply(void 0,n);return u[t]=o,o}(r)(e,t)}},4317:function(e){"use strict";function t(e,t){var r=Math.floor(t),n=t-r,i=0<=r&&r0;){x<64?(l=x,x=0):(l=64,x-=64);for(var b=0|e[1];b>0;){b<64?(c=b,b=0):(c=64,b-=64),n=y+x*d+b*h,a=v+x*f+b*m;var _=0,w=0,k=0,S=p,A=d-u*p,T=h-l*d,M=g,C=f-u*g,E=m-l*f;for(k=0;k0;){m<64?(l=m,m=0):(l=64,m-=64);for(var g=0|e[0];g>0;){g<64?(s=g,g=0):(s=64,g-=64),n=p+m*u+g*c,a=f+m*h+g*d;var y=0,v=0,x=u,b=c-l*u,_=h,w=d-l*h;for(v=0;v0;){v<64?(c=v,v=0):(c=64,v-=64);for(var x=0|e[0];x>0;){x<64?(s=x,x=0):(s=64,x-=64);for(var b=0|e[1];b>0;){b<64?(l=b,b=0):(l=64,b-=64),n=g+v*h+x*u+b*d,a=y+v*m+x*p+b*f;var _=0,w=0,k=0,S=h,A=u-c*h,T=d-s*u,M=m,C=p-c*m,E=f-s*p;for(k=0;kr;){y=0,v=m-a;t:for(g=0;gb)break t;v+=d,y+=h}for(y=m,v=m-a,g=0;g>1,$=H-B,W=H+B,q=V,G=$,Y=H,X=W,Z=U,K=i+1,J=o-1,Q=!0,ee=0,te=0,re=0,ne=d,ie=t(ne),oe=t(ne);A=l*q,T=l*G,N=s;e:for(S=0;S0){g=q,q=G,G=g;break e}if(re<0)break e;N+=p}A=l*X,T=l*Z,N=s;e:for(S=0;S0){g=X,X=Z,Z=g;break e}if(re<0)break e;N+=p}A=l*q,T=l*Y,N=s;e:for(S=0;S0){g=q,q=Y,Y=g;break e}if(re<0)break e;N+=p}A=l*G,T=l*Y,N=s;e:for(S=0;S0){g=G,G=Y,Y=g;break e}if(re<0)break e;N+=p}A=l*q,T=l*X,N=s;e:for(S=0;S0){g=q,q=X,X=g;break e}if(re<0)break e;N+=p}A=l*Y,T=l*X,N=s;e:for(S=0;S0){g=Y,Y=X,X=g;break e}if(re<0)break e;N+=p}A=l*G,T=l*Z,N=s;e:for(S=0;S0){g=G,G=Z,Z=g;break e}if(re<0)break e;N+=p}A=l*G,T=l*Y,N=s;e:for(S=0;S0){g=G,G=Y,Y=g;break e}if(re<0)break e;N+=p}A=l*X,T=l*Z,N=s;e:for(S=0;S0){g=X,X=Z,Z=g;break e}if(re<0)break e;N+=p}for(A=l*q,T=l*G,M=l*Y,C=l*X,E=l*Z,I=l*V,P=l*H,O=l*U,F=0,N=s,S=0;S0)){if(re<0){for(A=l*b,T=l*K,M=l*J,N=s,S=0;S0)for(;;){_=s+J*l,F=0;e:for(S=0;S0)){_=s+J*l,F=0;e:for(S=0;SU){e:for(;;){for(_=s+K*l,F=0,N=s,S=0;S1&&n?s(r,n[0],n[1]):s(r)}(e,t,l);return n(l,c)}},446:function(e,t,r){"use strict";var n=r(7640),i={};e.exports=function(e){var t=e.order,r=e.dtype,o=[t,r].join(":"),a=i[o];return a||(i[o]=a=n(t,r)),a(e),e}},9618:function(e,t,r){var n=r(7163),i="undefined"!==typeof Float64Array;function o(e,t){return e[0]-t[0]}function a(){var e,t=this.stride,r=new Array(t.length);for(e=0;e=0&&(t+=o*(r=0|e),i-=r),new n(this.data,i,o,t)},i.step=function(e){var t=this.shape[0],r=this.stride[0],i=this.offset,o=0,a=Math.ceil;return"number"===typeof e&&((o=0|e)<0?(i+=r*(t-1),t=a(-t/o)):t=a(t/o),r*=o),new n(this.data,t,r,i)},i.transpose=function(e){e=void 0===e?0:0|e;var t=this.shape,r=this.stride;return new n(this.data,t[e],r[e],this.offset)},i.pick=function(e){var r=[],n=[],i=this.offset;return"number"===typeof e&&e>=0?i=i+this.stride[0]*e|0:(r.push(this.shape[0]),n.push(this.stride[0])),(0,t[r.length+1])(this.data,r,n,i)},function(e,t,r,i){return new n(e,t[0],r[0],i)}},2:function(e,t,r){function n(e,t,r,n,i,o){this.data=e,this.shape=[t,r],this.stride=[n,i],this.offset=0|o}var i=n.prototype;return i.dtype=e,i.dimension=2,Object.defineProperty(i,"size",{get:function(){return this.shape[0]*this.shape[1]}}),Object.defineProperty(i,"order",{get:function(){return Math.abs(this.stride[0])>Math.abs(this.stride[1])?[1,0]:[0,1]}}),i.set=function(t,r,n){return"generic"===e?this.data.set(this.offset+this.stride[0]*t+this.stride[1]*r,n):this.data[this.offset+this.stride[0]*t+this.stride[1]*r]=n},i.get=function(t,r){return"generic"===e?this.data.get(this.offset+this.stride[0]*t+this.stride[1]*r):this.data[this.offset+this.stride[0]*t+this.stride[1]*r]},i.index=function(e,t){return this.offset+this.stride[0]*e+this.stride[1]*t},i.hi=function(e,t){return new n(this.data,"number"!==typeof e||e<0?this.shape[0]:0|e,"number"!==typeof t||t<0?this.shape[1]:0|t,this.stride[0],this.stride[1],this.offset)},i.lo=function(e,t){var r=this.offset,i=0,o=this.shape[0],a=this.shape[1],s=this.stride[0],l=this.stride[1];return"number"===typeof e&&e>=0&&(r+=s*(i=0|e),o-=i),"number"===typeof t&&t>=0&&(r+=l*(i=0|t),a-=i),new n(this.data,o,a,s,l,r)},i.step=function(e,t){var r=this.shape[0],i=this.shape[1],o=this.stride[0],a=this.stride[1],s=this.offset,l=0,c=Math.ceil;return"number"===typeof e&&((l=0|e)<0?(s+=o*(r-1),r=c(-r/l)):r=c(r/l),o*=l),"number"===typeof t&&((l=0|t)<0?(s+=a*(i-1),i=c(-i/l)):i=c(i/l),a*=l),new n(this.data,r,i,o,a,s)},i.transpose=function(e,t){e=void 0===e?0:0|e,t=void 0===t?1:0|t;var r=this.shape,i=this.stride;return new n(this.data,r[e],r[t],i[e],i[t],this.offset)},i.pick=function(e,r){var n=[],i=[],o=this.offset;return"number"===typeof e&&e>=0?o=o+this.stride[0]*e|0:(n.push(this.shape[0]),i.push(this.stride[0])),"number"===typeof r&&r>=0?o=o+this.stride[1]*r|0:(n.push(this.shape[1]),i.push(this.stride[1])),(0,t[n.length+1])(this.data,n,i,o)},function(e,t,r,i){return new n(e,t[0],t[1],r[0],r[1],i)}},3:function(e,t,r){function n(e,t,r,n,i,o,a,s){this.data=e,this.shape=[t,r,n],this.stride=[i,o,a],this.offset=0|s}var i=n.prototype;return i.dtype=e,i.dimension=3,Object.defineProperty(i,"size",{get:function(){return this.shape[0]*this.shape[1]*this.shape[2]}}),Object.defineProperty(i,"order",{get:function(){var e=Math.abs(this.stride[0]),t=Math.abs(this.stride[1]),r=Math.abs(this.stride[2]);return e>t?t>r?[2,1,0]:e>r?[1,2,0]:[1,0,2]:e>r?[2,0,1]:r>t?[0,1,2]:[0,2,1]}}),i.set=function(t,r,n,i){return"generic"===e?this.data.set(this.offset+this.stride[0]*t+this.stride[1]*r+this.stride[2]*n,i):this.data[this.offset+this.stride[0]*t+this.stride[1]*r+this.stride[2]*n]=i},i.get=function(t,r,n){return"generic"===e?this.data.get(this.offset+this.stride[0]*t+this.stride[1]*r+this.stride[2]*n):this.data[this.offset+this.stride[0]*t+this.stride[1]*r+this.stride[2]*n]},i.index=function(e,t,r){return this.offset+this.stride[0]*e+this.stride[1]*t+this.stride[2]*r},i.hi=function(e,t,r){return new n(this.data,"number"!==typeof e||e<0?this.shape[0]:0|e,"number"!==typeof t||t<0?this.shape[1]:0|t,"number"!==typeof r||r<0?this.shape[2]:0|r,this.stride[0],this.stride[1],this.stride[2],this.offset)},i.lo=function(e,t,r){var i=this.offset,o=0,a=this.shape[0],s=this.shape[1],l=this.shape[2],c=this.stride[0],u=this.stride[1],d=this.stride[2];return"number"===typeof e&&e>=0&&(i+=c*(o=0|e),a-=o),"number"===typeof t&&t>=0&&(i+=u*(o=0|t),s-=o),"number"===typeof r&&r>=0&&(i+=d*(o=0|r),l-=o),new n(this.data,a,s,l,c,u,d,i)},i.step=function(e,t,r){var i=this.shape[0],o=this.shape[1],a=this.shape[2],s=this.stride[0],l=this.stride[1],c=this.stride[2],u=this.offset,d=0,h=Math.ceil;return"number"===typeof e&&((d=0|e)<0?(u+=s*(i-1),i=h(-i/d)):i=h(i/d),s*=d),"number"===typeof t&&((d=0|t)<0?(u+=l*(o-1),o=h(-o/d)):o=h(o/d),l*=d),"number"===typeof r&&((d=0|r)<0?(u+=c*(a-1),a=h(-a/d)):a=h(a/d),c*=d),new n(this.data,i,o,a,s,l,c,u)},i.transpose=function(e,t,r){e=void 0===e?0:0|e,t=void 0===t?1:0|t,r=void 0===r?2:0|r;var i=this.shape,o=this.stride;return new n(this.data,i[e],i[t],i[r],o[e],o[t],o[r],this.offset)},i.pick=function(e,r,n){var i=[],o=[],a=this.offset;return"number"===typeof e&&e>=0?a=a+this.stride[0]*e|0:(i.push(this.shape[0]),o.push(this.stride[0])),"number"===typeof r&&r>=0?a=a+this.stride[1]*r|0:(i.push(this.shape[1]),o.push(this.stride[1])),"number"===typeof n&&n>=0?a=a+this.stride[2]*n|0:(i.push(this.shape[2]),o.push(this.stride[2])),(0,t[i.length+1])(this.data,i,o,a)},function(e,t,r,i){return new n(e,t[0],t[1],t[2],r[0],r[1],r[2],i)}},4:function(e,t,r){function n(e,t,r,n,i,o,a,s,l,c){this.data=e,this.shape=[t,r,n,i],this.stride=[o,a,s,l],this.offset=0|c}var i=n.prototype;return i.dtype=e,i.dimension=4,Object.defineProperty(i,"size",{get:function(){return this.shape[0]*this.shape[1]*this.shape[2]*this.shape[3]}}),Object.defineProperty(i,"order",{get:r}),i.set=function(t,r,n,i,o){return"generic"===e?this.data.set(this.offset+this.stride[0]*t+this.stride[1]*r+this.stride[2]*n+this.stride[3]*i,o):this.data[this.offset+this.stride[0]*t+this.stride[1]*r+this.stride[2]*n+this.stride[3]*i]=o},i.get=function(t,r,n,i){return"generic"===e?this.data.get(this.offset+this.stride[0]*t+this.stride[1]*r+this.stride[2]*n+this.stride[3]*i):this.data[this.offset+this.stride[0]*t+this.stride[1]*r+this.stride[2]*n+this.stride[3]*i]},i.index=function(e,t,r,n){return this.offset+this.stride[0]*e+this.stride[1]*t+this.stride[2]*r+this.stride[3]*n},i.hi=function(e,t,r,i){return new n(this.data,"number"!==typeof e||e<0?this.shape[0]:0|e,"number"!==typeof t||t<0?this.shape[1]:0|t,"number"!==typeof r||r<0?this.shape[2]:0|r,"number"!==typeof i||i<0?this.shape[3]:0|i,this.stride[0],this.stride[1],this.stride[2],this.stride[3],this.offset)},i.lo=function(e,t,r,i){var o=this.offset,a=0,s=this.shape[0],l=this.shape[1],c=this.shape[2],u=this.shape[3],d=this.stride[0],h=this.stride[1],p=this.stride[2],f=this.stride[3];return"number"===typeof e&&e>=0&&(o+=d*(a=0|e),s-=a),"number"===typeof t&&t>=0&&(o+=h*(a=0|t),l-=a),"number"===typeof r&&r>=0&&(o+=p*(a=0|r),c-=a),"number"===typeof i&&i>=0&&(o+=f*(a=0|i),u-=a),new n(this.data,s,l,c,u,d,h,p,f,o)},i.step=function(e,t,r,i){var o=this.shape[0],a=this.shape[1],s=this.shape[2],l=this.shape[3],c=this.stride[0],u=this.stride[1],d=this.stride[2],h=this.stride[3],p=this.offset,f=0,m=Math.ceil;return"number"===typeof e&&((f=0|e)<0?(p+=c*(o-1),o=m(-o/f)):o=m(o/f),c*=f),"number"===typeof t&&((f=0|t)<0?(p+=u*(a-1),a=m(-a/f)):a=m(a/f),u*=f),"number"===typeof r&&((f=0|r)<0?(p+=d*(s-1),s=m(-s/f)):s=m(s/f),d*=f),"number"===typeof i&&((f=0|i)<0?(p+=h*(l-1),l=m(-l/f)):l=m(l/f),h*=f),new n(this.data,o,a,s,l,c,u,d,h,p)},i.transpose=function(e,t,r,i){e=void 0===e?0:0|e,t=void 0===t?1:0|t,r=void 0===r?2:0|r,i=void 0===i?3:0|i;var o=this.shape,a=this.stride;return new n(this.data,o[e],o[t],o[r],o[i],a[e],a[t],a[r],a[i],this.offset)},i.pick=function(e,r,n,i){var o=[],a=[],s=this.offset;return"number"===typeof e&&e>=0?s=s+this.stride[0]*e|0:(o.push(this.shape[0]),a.push(this.stride[0])),"number"===typeof r&&r>=0?s=s+this.stride[1]*r|0:(o.push(this.shape[1]),a.push(this.stride[1])),"number"===typeof n&&n>=0?s=s+this.stride[2]*n|0:(o.push(this.shape[2]),a.push(this.stride[2])),"number"===typeof i&&i>=0?s=s+this.stride[3]*i|0:(o.push(this.shape[3]),a.push(this.stride[3])),(0,t[o.length+1])(this.data,o,a,s)},function(e,t,r,i){return new n(e,t[0],t[1],t[2],t[3],r[0],r[1],r[2],r[3],i)}},5:function(e,t,r){function n(e,t,r,n,i,o,a,s,l,c,u,d){this.data=e,this.shape=[t,r,n,i,o],this.stride=[a,s,l,c,u],this.offset=0|d}var i=n.prototype;return i.dtype=e,i.dimension=5,Object.defineProperty(i,"size",{get:function(){return this.shape[0]*this.shape[1]*this.shape[2]*this.shape[3]*this.shape[4]}}),Object.defineProperty(i,"order",{get:r}),i.set=function(t,r,n,i,o,a){return"generic"===e?this.data.set(this.offset+this.stride[0]*t+this.stride[1]*r+this.stride[2]*n+this.stride[3]*i+this.stride[4]*o,a):this.data[this.offset+this.stride[0]*t+this.stride[1]*r+this.stride[2]*n+this.stride[3]*i+this.stride[4]*o]=a},i.get=function(t,r,n,i,o){return"generic"===e?this.data.get(this.offset+this.stride[0]*t+this.stride[1]*r+this.stride[2]*n+this.stride[3]*i+this.stride[4]*o):this.data[this.offset+this.stride[0]*t+this.stride[1]*r+this.stride[2]*n+this.stride[3]*i+this.stride[4]*o]},i.index=function(e,t,r,n,i){return this.offset+this.stride[0]*e+this.stride[1]*t+this.stride[2]*r+this.stride[3]*n+this.stride[4]*i},i.hi=function(e,t,r,i,o){return new n(this.data,"number"!==typeof e||e<0?this.shape[0]:0|e,"number"!==typeof t||t<0?this.shape[1]:0|t,"number"!==typeof r||r<0?this.shape[2]:0|r,"number"!==typeof i||i<0?this.shape[3]:0|i,"number"!==typeof o||o<0?this.shape[4]:0|o,this.stride[0],this.stride[1],this.stride[2],this.stride[3],this.stride[4],this.offset)},i.lo=function(e,t,r,i,o){var a=this.offset,s=0,l=this.shape[0],c=this.shape[1],u=this.shape[2],d=this.shape[3],h=this.shape[4],p=this.stride[0],f=this.stride[1],m=this.stride[2],g=this.stride[3],y=this.stride[4];return"number"===typeof e&&e>=0&&(a+=p*(s=0|e),l-=s),"number"===typeof t&&t>=0&&(a+=f*(s=0|t),c-=s),"number"===typeof r&&r>=0&&(a+=m*(s=0|r),u-=s),"number"===typeof i&&i>=0&&(a+=g*(s=0|i),d-=s),"number"===typeof o&&o>=0&&(a+=y*(s=0|o),h-=s),new n(this.data,l,c,u,d,h,p,f,m,g,y,a)},i.step=function(e,t,r,i,o){var a=this.shape[0],s=this.shape[1],l=this.shape[2],c=this.shape[3],u=this.shape[4],d=this.stride[0],h=this.stride[1],p=this.stride[2],f=this.stride[3],m=this.stride[4],g=this.offset,y=0,v=Math.ceil;return"number"===typeof e&&((y=0|e)<0?(g+=d*(a-1),a=v(-a/y)):a=v(a/y),d*=y),"number"===typeof t&&((y=0|t)<0?(g+=h*(s-1),s=v(-s/y)):s=v(s/y),h*=y),"number"===typeof r&&((y=0|r)<0?(g+=p*(l-1),l=v(-l/y)):l=v(l/y),p*=y),"number"===typeof i&&((y=0|i)<0?(g+=f*(c-1),c=v(-c/y)):c=v(c/y),f*=y),"number"===typeof o&&((y=0|o)<0?(g+=m*(u-1),u=v(-u/y)):u=v(u/y),m*=y),new n(this.data,a,s,l,c,u,d,h,p,f,m,g)},i.transpose=function(e,t,r,i,o){e=void 0===e?0:0|e,t=void 0===t?1:0|t,r=void 0===r?2:0|r,i=void 0===i?3:0|i,o=void 0===o?4:0|o;var a=this.shape,s=this.stride;return new n(this.data,a[e],a[t],a[r],a[i],a[o],s[e],s[t],s[r],s[i],s[o],this.offset)},i.pick=function(e,r,n,i,o){var a=[],s=[],l=this.offset;return"number"===typeof e&&e>=0?l=l+this.stride[0]*e|0:(a.push(this.shape[0]),s.push(this.stride[0])),"number"===typeof r&&r>=0?l=l+this.stride[1]*r|0:(a.push(this.shape[1]),s.push(this.stride[1])),"number"===typeof n&&n>=0?l=l+this.stride[2]*n|0:(a.push(this.shape[2]),s.push(this.stride[2])),"number"===typeof i&&i>=0?l=l+this.stride[3]*i|0:(a.push(this.shape[3]),s.push(this.stride[3])),"number"===typeof o&&o>=0?l=l+this.stride[4]*o|0:(a.push(this.shape[4]),s.push(this.stride[4])),(0,t[a.length+1])(this.data,a,s,l)},function(e,t,r,i){return new n(e,t[0],t[1],t[2],t[3],t[4],r[0],r[1],r[2],r[3],r[4],i)}}};function l(e,t){var r=-1===t?"T":String(t),n=s[r];return-1===t?n(e):0===t?n(e,c[e][0]):n(e,c[e],a)}var c={generic:[],buffer:[],array:[],float32:[],float64:[],int8:[],int16:[],int32:[],uint8_clamped:[],uint8:[],uint16:[],uint32:[],bigint64:[],biguint64:[]};e.exports=function(e,t,r,o){if(void 0===e)return(0,c.array[0])([]);"number"===typeof e&&(e=[e]),void 0===t&&(t=[e.length]);var a=t.length;if(void 0===r){r=new Array(a);for(var s=a-1,u=1;s>=0;--s)r[s]=u,u*=t[s]}if(void 0===o){o=0;for(s=0;s>>0;e.exports=function(e,t){if(isNaN(e)||isNaN(t))return NaN;if(e===t)return e;if(0===e)return t<0?-i:i;var r=n.hi(e),a=n.lo(e);t>e===e>0?a===o?(r+=1,a=0):a+=1:0===a?(a=o,r-=1):a-=1;return n.pack(a,r)}},8406:function(e,t){t.vertexNormals=function(e,t,r){for(var n=t.length,i=new Array(n),o=void 0===r?1e-6:r,a=0;ao){var b=i[c],_=1/Math.sqrt(g*v);for(x=0;x<3;++x){var w=(x+1)%3,k=(x+2)%3;b[x]+=_*(y[w]*m[k]-y[k]*m[w])}}}for(a=0;ao)for(_=1/Math.sqrt(S),x=0;x<3;++x)b[x]*=_;else for(x=0;x<3;++x)b[x]=0}return i},t.faceNormals=function(e,t,r){for(var n=e.length,i=new Array(n),o=void 0===r?1e-6:r,a=0;ao?1/Math.sqrt(p):0;for(c=0;c<3;++c)h[c]*=p;i[a]=h}return i}},4081:function(e){"use strict";e.exports=function(e,t,r,n,i,o,a,s,l,c){var u=t+o+c;if(d>0){var d=Math.sqrt(u+1);e[0]=.5*(a-l)/d,e[1]=.5*(s-n)/d,e[2]=.5*(r-o)/d,e[3]=.5*d}else{var h=Math.max(t,o,c);d=Math.sqrt(2*h-u+1);t>=h?(e[0]=.5*d,e[1]=.5*(i+r)/d,e[2]=.5*(s+n)/d,e[3]=.5*(a-l)/d):o>=h?(e[0]=.5*(r+i)/d,e[1]=.5*d,e[2]=.5*(l+a)/d,e[3]=.5*(s-n)/d):(e[0]=.5*(n+s)/d,e[1]=.5*(a+l)/d,e[2]=.5*d,e[3]=.5*(r-i)/d)}return e}},9977:function(e,t,r){"use strict";e.exports=function(e){var t=(e=e||{}).center||[0,0,0],r=e.rotation||[0,0,0,1],n=e.radius||1;t=[].slice.call(t,0,3),u(r=[].slice.call(r,0,4),r);var i=new d(r,t,Math.log(n));i.setDistanceLimits(e.zoomMin,e.zoomMax),("eye"in e||"up"in e)&&i.lookAt(0,e.eye,e.center,e.up);return i};var n=r(9215),i=r(6582),o=r(7399),a=r(7608),s=r(4081);function l(e,t,r){return Math.sqrt(Math.pow(e,2)+Math.pow(t,2)+Math.pow(r,2))}function c(e,t,r,n){return Math.sqrt(Math.pow(e,2)+Math.pow(t,2)+Math.pow(r,2)+Math.pow(n,2))}function u(e,t){var r=t[0],n=t[1],i=t[2],o=t[3],a=c(r,n,i,o);a>1e-6?(e[0]=r/a,e[1]=n/a,e[2]=i/a,e[3]=o/a):(e[0]=e[1]=e[2]=0,e[3]=1)}function d(e,t,r){this.radius=n([r]),this.center=n(t),this.rotation=n(e),this.computedRadius=this.radius.curve(0),this.computedCenter=this.center.curve(0),this.computedRotation=this.rotation.curve(0),this.computedUp=[.1,0,0],this.computedEye=[.1,0,0],this.computedMatrix=[.1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],this.recalcMatrix(0)}var h=d.prototype;h.lastT=function(){return Math.max(this.radius.lastT(),this.center.lastT(),this.rotation.lastT())},h.recalcMatrix=function(e){this.radius.curve(e),this.center.curve(e),this.rotation.curve(e);var t=this.computedRotation;u(t,t);var r=this.computedMatrix;o(r,t);var n=this.computedCenter,i=this.computedEye,a=this.computedUp,s=Math.exp(this.computedRadius[0]);i[0]=n[0]+s*r[2],i[1]=n[1]+s*r[6],i[2]=n[2]+s*r[10],a[0]=r[1],a[1]=r[5],a[2]=r[9];for(var l=0;l<3;++l){for(var c=0,d=0;d<3;++d)c+=r[l+4*d]*i[d];r[12+l]=-c}},h.getMatrix=function(e,t){this.recalcMatrix(e);var r=this.computedMatrix;if(t){for(var n=0;n<16;++n)t[n]=r[n];return t}return r},h.idle=function(e){this.center.idle(e),this.radius.idle(e),this.rotation.idle(e)},h.flush=function(e){this.center.flush(e),this.radius.flush(e),this.rotation.flush(e)},h.pan=function(e,t,r,n){t=t||0,r=r||0,n=n||0,this.recalcMatrix(e);var i=this.computedMatrix,o=i[1],a=i[5],s=i[9],c=l(o,a,s);o/=c,a/=c,s/=c;var u=i[0],d=i[4],h=i[8],p=u*o+d*a+h*s,f=l(u-=o*p,d-=a*p,h-=s*p);u/=f,d/=f,h/=f;var m=i[2],g=i[6],y=i[10],v=m*o+g*a+y*s,x=m*u+g*d+y*h,b=l(m-=v*o+x*u,g-=v*a+x*d,y-=v*s+x*h);m/=b,g/=b,y/=b;var _=u*t+o*r,w=d*t+a*r,k=h*t+s*r;this.center.move(e,_,w,k);var S=Math.exp(this.computedRadius[0]);S=Math.max(1e-4,S+n),this.radius.set(e,Math.log(S))},h.rotate=function(e,t,r,n){this.recalcMatrix(e),t=t||0,r=r||0;var i=this.computedMatrix,o=i[0],a=i[4],s=i[8],u=i[1],d=i[5],h=i[9],p=i[2],f=i[6],m=i[10],g=t*o+r*u,y=t*a+r*d,v=t*s+r*h,x=-(f*v-m*y),b=-(m*g-p*v),_=-(p*y-f*g),w=Math.sqrt(Math.max(0,1-Math.pow(x,2)-Math.pow(b,2)-Math.pow(_,2))),k=c(x,b,_,w);k>1e-6?(x/=k,b/=k,_/=k,w/=k):(x=b=_=0,w=1);var S=this.computedRotation,A=S[0],T=S[1],M=S[2],C=S[3],E=A*w+C*x+T*_-M*b,I=T*w+C*b+M*x-A*_,P=M*w+C*_+A*b-T*x,O=C*w-A*x-T*b-M*_;if(n){x=p,b=f,_=m;var R=Math.sin(n)/l(x,b,_);x*=R,b*=R,_*=R,O=O*(w=Math.cos(t))-(E=E*w+O*x+I*_-P*b)*x-(I=I*w+O*b+P*x-E*_)*b-(P=P*w+O*_+E*b-I*x)*_}var L=c(E,I,P,O);L>1e-6?(E/=L,I/=L,P/=L,O/=L):(E=I=P=0,O=1),this.rotation.set(e,E,I,P,O)},h.lookAt=function(e,t,r,n){this.recalcMatrix(e),r=r||this.computedCenter,t=t||this.computedEye,n=n||this.computedUp;var o=this.computedMatrix;i(o,t,r,n);var a=this.computedRotation;s(a,o[0],o[1],o[2],o[4],o[5],o[6],o[8],o[9],o[10]),u(a,a),this.rotation.set(e,a[0],a[1],a[2],a[3]);for(var l=0,c=0;c<3;++c)l+=Math.pow(r[c]-t[c],2);this.radius.set(e,.5*Math.log(Math.max(l,1e-6))),this.center.set(e,r[0],r[1],r[2])},h.translate=function(e,t,r,n){this.center.move(e,t||0,r||0,n||0)},h.setMatrix=function(e,t){var r=this.computedRotation;s(r,t[0],t[1],t[2],t[4],t[5],t[6],t[8],t[9],t[10]),u(r,r),this.rotation.set(e,r[0],r[1],r[2],r[3]);var n=this.computedMatrix;a(n,t);var i=n[15];if(Math.abs(i)>1e-6){var o=n[12]/i,l=n[13]/i,c=n[14]/i;this.recalcMatrix(e);var d=Math.exp(this.computedRadius[0]);this.center.set(e,o-n[2]*d,l-n[6]*d,c-n[10]*d),this.radius.idle(e)}else this.center.idle(e),this.radius.idle(e)},h.setDistance=function(e,t){t>0&&this.radius.set(e,Math.log(t))},h.setDistanceLimits=function(e,t){e=e>0?Math.log(e):-1/0,t=t>0?Math.log(t):1/0,t=Math.max(t,e),this.radius.bounds[0][0]=e,this.radius.bounds[1][0]=t},h.getDistanceLimits=function(e){var t=this.radius.bounds;return e?(e[0]=Math.exp(t[0][0]),e[1]=Math.exp(t[1][0]),e):[Math.exp(t[0][0]),Math.exp(t[1][0])]},h.toJSON=function(){return this.recalcMatrix(this.lastT()),{center:this.computedCenter.slice(),rotation:this.computedRotation.slice(),distance:Math.log(this.computedRadius[0]),zoomMin:this.radius.bounds[0][0],zoomMax:this.radius.bounds[1][0]}},h.fromJSON=function(e){var t=this.lastT(),r=e.center;r&&this.center.set(t,r[0],r[1],r[2]);var n=e.rotation;n&&this.rotation.set(t,n[0],n[1],n[2],n[3]);var i=e.distance;i&&i>0&&this.radius.set(t,Math.log(i)),this.setDistanceLimits(e.zoomMin,e.zoomMax)}},1371:function(e,t,r){"use strict";var n=r(3233);e.exports=function(e,t,r){return n(r="undefined"!==typeof r?r+"":" ",t)+e}},3202:function(e){e.exports=function(e,t){t||(t=[0,""]),e=String(e);var r=parseFloat(e,10);return t[0]=r,t[1]=e.match(/[\d.\-\+]*\s*(.*)/)[1]||"",t}},3088:function(e,t,r){"use strict";e.exports=function(e,t){for(var r=0|t.length,i=e.length,o=[new Array(r),new Array(r)],a=0;a0){a=o[u][r][0],l=u;break}s=a[1^l];for(var d=0;d<2;++d)for(var h=o[d][r],p=0;p0&&(a=f,s=m,l=d)}return i||a&&c(a,l),s}function d(e,r){var i=o[r][e][0],a=[e];c(i,r);for(var s=i[1^r];;){for(;s!==e;)a.push(s),s=u(a[a.length-2],s,!1);if(o[0][e].length+o[1][e].length===0)break;var l=a[a.length-1],d=e,h=a[1],p=u(l,d,!0);if(n(t[l],t[d],t[h],t[p])<0)break;a.push(e),s=u(l,d)}return a}function h(e,t){return t[1]===t[t.length-1]}for(a=0;a0;){o[0][a].length;var m=d(a,p);h(0,m)?f.push.apply(f,m):(f.length>0&&l.push(f),f=m)}f.length>0&&l.push(f)}return l};var n=r(3140)},5609:function(e,t,r){"use strict";e.exports=function(e,t){for(var r=n(e,t.length),i=new Array(t.length),o=new Array(t.length),a=[],s=0;s0;){i[p=a.pop()]=!1;var c=r[p];for(s=0;s0}))).length,g=new Array(m),y=new Array(m);for(p=0;p0;){var F=z.pop(),N=C[F];l(N,(function(e,t){return e-t}));var B,V=N.length,U=j[F];if(0===U)B=[H=f[F]];for(p=0;p=0))if(j[$]=1^U,z.push($),0===U)D(H=f[$])||(H.reverse(),B.push(H))}0===U&&r.push(B)}return r};var n=r(3134),i=r(3088),o=r(5085),a=r(5250),s=r(8210),l=r(1682),c=r(5609);function u(e,t){for(var r=new Array(e),n=0;n0&&t[i]===r[0]))return 1;o=e[i-1]}for(var s=1;o;){var l=o.key,c=n(r,l[0],l[1]);if(l[0][0]0))return 0;s=-1,o=o.right}else if(c>0)o=o.left;else{if(!(c<0))return 0;s=1,o=o.right}}return s}}(y.slabs,y.coordinates);return 0===o.length?v:function(e,t){return function(r){return e(r[0],r[1])?0:t(r)}}(l(o),v)};var n=r(3250)[3],i=r(4209),o=r(3352),a=r(2478);function s(){return!0}function l(e){for(var t={},r=0;r=c?(S=1,v=c+2*h+f):v=h*(S=-h/c)+f):(S=0,p>=0?(A=0,v=f):-p>=d?(A=1,v=d+2*p+f):v=p*(A=-p/d)+f);else if(A<0)A=0,h>=0?(S=0,v=f):-h>=c?(S=1,v=c+2*h+f):v=h*(S=-h/c)+f;else{var T=1/k;v=(S*=T)*(c*S+u*(A*=T)+2*h)+A*(u*S+d*A+2*p)+f}else S<0?(b=d+p)>(x=u+h)?(_=b-x)>=(w=c-2*u+d)?(S=1,A=0,v=c+2*h+f):v=(S=_/w)*(c*S+u*(A=1-S)+2*h)+A*(u*S+d*A+2*p)+f:(S=0,b<=0?(A=1,v=d+2*p+f):p>=0?(A=0,v=f):v=p*(A=-p/d)+f):A<0?(b=c+h)>(x=u+p)?(_=b-x)>=(w=c-2*u+d)?(A=1,S=0,v=d+2*p+f):v=(S=1-(A=_/w))*(c*S+u*A+2*h)+A*(u*S+d*A+2*p)+f:(A=0,b<=0?(S=1,v=c+2*h+f):h>=0?(S=0,v=f):v=h*(S=-h/c)+f):(_=d+p-u-h)<=0?(S=0,A=1,v=d+2*p+f):_>=(w=c-2*u+d)?(S=1,A=0,v=c+2*h+f):v=(S=_/w)*(c*S+u*(A=1-S)+2*h)+A*(u*S+d*A+2*p)+f;var M=1-S-A;for(l=0;l0){var c=e[r-1];if(0===n(s,c)&&o(c)!==l){r-=1;continue}}e[r++]=s}}return e.length=r,e}},3233:function(e){"use strict";var t,r="";e.exports=function(e,n){if("string"!==typeof e)throw new TypeError("expected a string");if(1===n)return e;if(2===n)return e+e;var i=e.length*n;if(t!==e||"undefined"===typeof t)t=e,r="";else if(r.length>=i)return r.substr(0,i);for(;i>r.length&&n>1;)1&n&&(r+=e),n>>=1,e+=e;return r=(r+=e).substr(0,i)}},3025:function(e,t,r){e.exports=r.g.performance&&r.g.performance.now?function(){return performance.now()}:Date.now||function(){return+new Date}},7004:function(e){"use strict";e.exports=function(e){for(var t=e.length,r=e[e.length-1],n=t,i=t-2;i>=0;--i){var o=r;(l=(s=e[i])-((r=o+s)-o))&&(e[--n]=r,r=l)}var a=0;for(i=n;i0){if(o<=0)return a;n=i+o}else{if(!(i<0))return a;if(o>=0)return a;n=-(i+o)}var s=33306690738754716e-32*n;return a>=s||a<=-s?a:d(e,t,r)},function(e,t,r,n){var i=e[0]-n[0],o=t[0]-n[0],a=r[0]-n[0],s=e[1]-n[1],l=t[1]-n[1],c=r[1]-n[1],u=e[2]-n[2],d=t[2]-n[2],p=r[2]-n[2],f=o*c,m=a*l,g=a*s,y=i*c,v=i*l,x=o*s,b=u*(f-m)+d*(g-y)+p*(v-x),_=7771561172376103e-31*((Math.abs(f)+Math.abs(m))*Math.abs(u)+(Math.abs(g)+Math.abs(y))*Math.abs(d)+(Math.abs(v)+Math.abs(x))*Math.abs(p));return b>_||-b>_?b:h(e,t,r,n)}];function f(e){var t=p[e.length];return t||(t=p[e.length]=u(e.length)),t.apply(void 0,e)}function m(e,t,r,n,i,o,a){return function(t,r,s,l,c){switch(arguments.length){case 0:case 1:return 0;case 2:return n(t,r);case 3:return i(t,r,s);case 4:return o(t,r,s,l);case 5:return a(t,r,s,l,c)}for(var u=new Array(arguments.length),d=0;d0&&a>0||o<0&&a<0)return!1;var s=n(r,e,t),l=n(i,e,t);if(s>0&&l>0||s<0&&l<0)return!1;if(0===o&&0===a&&0===s&&0===l)return function(e,t,r,n){for(var i=0;i<2;++i){var o=e[i],a=t[i],s=Math.min(o,a),l=Math.max(o,a),c=r[i],u=n[i],d=Math.min(c,u);if(Math.max(c,u)=n?(i=d,(l+=1)=n?(i=d,(l+=1)>1,c=t[2*l+1];if(c===o)return l;o>1,c=t[2*l+1];if(c===o)return l;o>1,c=t[2*l+1];if(c===o)return l;o>1,s=o(e[a],t);s<=0?(0===s&&a,a+1):s>0&&a-1}return i}function u(e,t){for(var r=new Array(e.length),i=0,a=r.length;i=e.length||0!==o(e[g],s)););}return r}function d(e,t){if(t<0)return[];for(var r=[],i=(1<0)-(e<0)},t.abs=function(e){var t=e>>31;return(e^t)-t},t.min=function(e,t){return t^(e^t)&-(e65535)<<4,t|=r=((e>>>=t)>255)<<3,t|=r=((e>>>=r)>15)<<2,(t|=r=((e>>>=r)>3)<<1)|(e>>>=r)>>1},t.log10=function(e){return e>=1e9?9:e>=1e8?8:e>=1e7?7:e>=1e6?6:e>=1e5?5:e>=1e4?4:e>=1e3?3:e>=100?2:e>=10?1:0},t.popCount=function(e){return 16843009*((e=(858993459&(e-=e>>>1&1431655765))+(e>>>2&858993459))+(e>>>4)&252645135)>>>24},t.countTrailingZeros=r,t.nextPow2=function(e){return e+=0===e,--e,e|=e>>>1,e|=e>>>2,e|=e>>>4,e|=e>>>8,(e|=e>>>16)+1},t.prevPow2=function(e){return e|=e>>>1,e|=e>>>2,e|=e>>>4,e|=e>>>8,(e|=e>>>16)-(e>>>1)},t.parity=function(e){return e^=e>>>16,e^=e>>>8,e^=e>>>4,27030>>>(e&=15)&1};var n=new Array(256);!function(e){for(var t=0;t<256;++t){var r=t,n=t,i=7;for(r>>>=1;r;r>>>=1)n<<=1,n|=1&r,--i;e[t]=n<>>8&255]<<16|n[e>>>16&255]<<8|n[e>>>24&255]},t.interleave2=function(e,t){return(e=1431655765&((e=858993459&((e=252645135&((e=16711935&((e&=65535)|e<<8))|e<<4))|e<<2))|e<<1))|(t=1431655765&((t=858993459&((t=252645135&((t=16711935&((t&=65535)|t<<8))|t<<4))|t<<2))|t<<1))<<1},t.deinterleave2=function(e,t){return(e=65535&((e=16711935&((e=252645135&((e=858993459&((e=e>>>t&1431655765)|e>>>1))|e>>>2))|e>>>4))|e>>>16))<<16>>16},t.interleave3=function(e,t,r){return e=1227133513&((e=3272356035&((e=251719695&((e=4278190335&((e&=1023)|e<<16))|e<<8))|e<<4))|e<<2),(e|=(t=1227133513&((t=3272356035&((t=251719695&((t=4278190335&((t&=1023)|t<<16))|t<<8))|t<<4))|t<<2))<<1)|(r=1227133513&((r=3272356035&((r=251719695&((r=4278190335&((r&=1023)|r<<16))|r<<8))|r<<4))|r<<2))<<2},t.deinterleave3=function(e,t){return(e=1023&((e=4278190335&((e=251719695&((e=3272356035&((e=e>>>t&1227133513)|e>>>2))|e>>>4))|e>>>8))|e>>>16))<<22>>22},t.nextCombination=function(e){var t=e|e-1;return t+1|(~t&-~t)-1>>>r(e)+1}},2014:function(e,t,r){"use strict";var n=r(3105),i=r(4623);function o(e,t){var r=e.length,n=e.length-t.length,i=Math.min;if(n)return n;switch(r){case 0:return 0;case 1:return e[0]-t[0];case 2:return(s=e[0]+e[1]-t[0]-t[1])||i(e[0],e[1])-i(t[0],t[1]);case 3:var o=e[0]+e[1],a=t[0]+t[1];if(s=o+e[2]-(a+t[2]))return s;var s,l=i(e[0],e[1]),c=i(t[0],t[1]);return(s=i(l,e[2])-i(c,t[2]))||i(l+e[2],o)-i(c+t[2],a);default:var u=e.slice(0);u.sort();var d=t.slice(0);d.sort();for(var h=0;h>1,s=o(e[a],t);s<=0?(0===s&&(i=a),r=a+1):s>0&&(n=a-1)}return i}function u(e,t){for(var r=new Array(e.length),i=0,a=r.length;i=e.length||0!==o(e[g],s)););}return r}function d(e,t){if(t<0)return[];for(var r=[],i=(1<>>u&1&&c.push(i[u]);t.push(c)}return s(t)},t.skeleton=d,t.boundary=function(e){for(var t=[],r=0,n=e.length;r>1:(e>>1)-1}function x(e){for(var t=y(e);;){var r=t,n=2*e+1,i=2*(e+1),o=e;if(n0;){var r=v(e);if(r>=0)if(t0){var e=S[0];return g(0,T-1),T-=1,x(0),e}return-1}function w(e,t){var r=S[e];return c[r]===t?e:(c[r]=-1/0,b(e),_(),c[r]=t,b((T+=1)-1))}function k(e){if(!u[e]){u[e]=!0;var t=s[e],r=l[e];s[r]>=0&&(s[r]=t),l[t]>=0&&(l[t]=r),A[t]>=0&&w(A[t],m(t)),A[r]>=0&&w(A[r],m(r))}}var S=[],A=new Array(o);for(d=0;d>1;d>=0;--d)x(d);for(;;){var M=_();if(M<0||c[M]>r)break;k(M)}var C=[];for(d=0;d=0&&r>=0&&t!==r){var n=A[t],i=A[r];n!==i&&I.push([n,i])}})),i.unique(i.normalize(I)),{positions:C,edges:I}};var n=r(3250),i=r(2014)},1303:function(e,t,r){"use strict";e.exports=function(e,t){var r,o,a,s;if(t[0][0]t[1][0]))return i(t,e);r=t[1],o=t[0]}if(e[0][0]e[1][0]))return-i(e,t);a=e[1],s=e[0]}var l=n(r,o,s),c=n(r,o,a);if(l<0){if(c<=0)return l}else if(l>0){if(c>=0)return l}else if(c)return c;if(l=n(s,a,o),c=n(s,a,r),l<0){if(c<=0)return l}else if(l>0){if(c>=0)return l}else if(c)return c;return o[0]-s[0]};var n=r(3250);function i(e,t){var r,i,o,a;if(t[0][0]t[1][0])){var s=Math.min(e[0][1],e[1][1]),l=Math.max(e[0][1],e[1][1]),c=Math.min(t[0][1],t[1][1]),u=Math.max(t[0][1],t[1][1]);return lu?s-u:l-u}r=t[1],i=t[0]}e[0][1]0)if(t[0]!==a[1][0])r=e,e=e.right;else{if(l=c(e.right,t))return l;e=e.left}else{if(t[0]!==a[1][0])return e;var l;if(l=c(e.right,t))return l;e=e.left}}return r}function u(e,t,r,n){this.y=e,this.index=t,this.start=r,this.closed=n}function d(e,t,r,n){this.x=e,this.segment=t,this.create=r,this.index=n}s.prototype.castUp=function(e){var t=n.le(this.coordinates,e[0]);if(t<0)return-1;this.slabs[t];var r=c(this.slabs[t],e),i=-1;if(r&&(i=r.value),this.coordinates[t]===e[0]){var s=null;if(r&&(s=r.key),t>0){var u=c(this.slabs[t-1],e);u&&(s?a(u.key,s)>0&&(s=u.key,i=u.value):(i=u.value,s=u.key))}var d=this.horizontal[t];if(d.length>0){var h=n.ge(d,e[1],l);if(h=d.length)return i;p=d[h]}}if(p.start)if(s){var f=o(s[0],s[1],[e[0],p.y]);s[0][0]>s[1][0]&&(f=-f),f>0&&(i=p.index)}else i=p.index;else p.y!==e[1]&&(i=p.index)}}}return i}},5202:function(e,t,r){"use strict";var n=r(1944),i=r(8210);function o(e,t){var r=i(n(e,t),[t[t.length-1]]);return r[r.length-1]}function a(e,t,r,n){var i=-t/(n-t);i<0?i=0:i>1&&(i=1);for(var o=1-i,a=e.length,s=new Array(a),l=0;l0||i>0&&u<0){var d=a(s,u,l,i);r.push(d),n.push(d.slice())}u<0?n.push(l.slice()):u>0?r.push(l.slice()):(r.push(l.slice()),n.push(l.slice())),i=u}return{positive:r,negative:n}},e.exports.positive=function(e,t){for(var r=[],n=o(e[e.length-1],t),i=e[e.length-1],s=e[0],l=0;l0||n>0&&c<0)&&r.push(a(i,c,s,n)),c>=0&&r.push(s.slice()),n=c}return r},e.exports.negative=function(e,t){for(var r=[],n=o(e[e.length-1],t),i=e[e.length-1],s=e[0],l=0;l0||n>0&&c<0)&&r.push(a(i,c,s,n)),c<=0&&r.push(s.slice()),n=c}return r}},3387:function(e,t,r){var n;!function(){"use strict";var i={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function o(e){return function(e,t){var r,n,a,s,l,c,u,d,h,p=1,f=e.length,m="";for(n=0;n=0),s.type){case"b":r=parseInt(r,10).toString(2);break;case"c":r=String.fromCharCode(parseInt(r,10));break;case"d":case"i":r=parseInt(r,10);break;case"j":r=JSON.stringify(r,null,s.width?parseInt(s.width):0);break;case"e":r=s.precision?parseFloat(r).toExponential(s.precision):parseFloat(r).toExponential();break;case"f":r=s.precision?parseFloat(r).toFixed(s.precision):parseFloat(r);break;case"g":r=s.precision?String(Number(r.toPrecision(s.precision))):parseFloat(r);break;case"o":r=(parseInt(r,10)>>>0).toString(8);break;case"s":r=String(r),r=s.precision?r.substring(0,s.precision):r;break;case"t":r=String(!!r),r=s.precision?r.substring(0,s.precision):r;break;case"T":r=Object.prototype.toString.call(r).slice(8,-1).toLowerCase(),r=s.precision?r.substring(0,s.precision):r;break;case"u":r=parseInt(r,10)>>>0;break;case"v":r=r.valueOf(),r=s.precision?r.substring(0,s.precision):r;break;case"x":r=(parseInt(r,10)>>>0).toString(16);break;case"X":r=(parseInt(r,10)>>>0).toString(16).toUpperCase()}i.json.test(s.type)?m+=r:(!i.number.test(s.type)||d&&!s.sign?h="":(h=d?"+":"-",r=r.toString().replace(i.sign,"")),c=s.pad_char?"0"===s.pad_char?"0":s.pad_char.charAt(1):" ",u=s.width-(h+r).length,l=s.width&&u>0?c.repeat(u):"",m+=s.align?h+r+l:"0"===c?h+l+r:l+h+r)}return m}(function(e){if(s[e])return s[e];var t,r=e,n=[],o=0;for(;r;){if(null!==(t=i.text.exec(r)))n.push(t[0]);else if(null!==(t=i.modulo.exec(r)))n.push("%");else{if(null===(t=i.placeholder.exec(r)))throw new SyntaxError("[sprintf] unexpected placeholder");if(t[2]){o|=1;var a=[],l=t[2],c=[];if(null===(c=i.key.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(a.push(c[1]);""!==(l=l.substring(c[0].length));)if(null!==(c=i.key_access.exec(l)))a.push(c[1]);else{if(null===(c=i.index_access.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");a.push(c[1])}t[2]=a}else o|=2;if(3===o)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");n.push({placeholder:t[0],param_no:t[1],keys:t[2],sign:t[3],pad_char:t[4],align:t[5],width:t[6],precision:t[7],type:t[8]})}r=r.substring(t[0].length)}return s[e]=n}(e),arguments)}function a(e,t){return o.apply(null,[e].concat(t||[]))}var s=Object.create(null);t.sprintf=o,t.vsprintf=a,"undefined"!==typeof window&&(window.sprintf=o,window.vsprintf=a,void 0===(n=function(){return{sprintf:o,vsprintf:a}}.call(t,r,t,e))||(e.exports=n))}()},3711:function(e,t,r){"use strict";e.exports=function(e,t){if(e.dimension<=0)return{positions:[],cells:[]};if(1===e.dimension)return function(e,t){for(var r=i(e,t),n=r.length,o=new Array(n),a=new Array(n),s=0;sn|0},vertex:function(e,t,r,n,i,o,a,s,l,c,u,d,h){var p=(a|0)+(s<<1)+(l<<2)+(c<<3)|0;if(0!==p&&15!==p)switch(p){case 0:case 15:u.push([e-.5,t-.5]);break;case 1:u.push([e-.25-.25*(n+r-2*h)/(r-n),t-.25-.25*(i+r-2*h)/(r-i)]);break;case 2:u.push([e-.75-.25*(-n-r+2*h)/(n-r),t-.25-.25*(o+n-2*h)/(n-o)]);break;case 3:u.push([e-.5,t-.5-.5*(i+r+o+n-4*h)/(r-i+n-o)]);break;case 4:u.push([e-.25-.25*(o+i-2*h)/(i-o),t-.75-.25*(-i-r+2*h)/(i-r)]);break;case 5:u.push([e-.5-.5*(n+r+o+i-4*h)/(r-n+i-o),t-.5]);break;case 6:u.push([e-.5-.25*(-n-r+o+i)/(n-r+i-o),t-.5-.25*(-i-r+o+n)/(i-r+n-o)]);break;case 7:u.push([e-.75-.25*(o+i-2*h)/(i-o),t-.75-.25*(o+n-2*h)/(n-o)]);break;case 8:u.push([e-.75-.25*(-o-i+2*h)/(o-i),t-.75-.25*(-o-n+2*h)/(o-n)]);break;case 9:u.push([e-.5-.25*(n+r+-o-i)/(r-n+o-i),t-.5-.25*(i+r+-o-n)/(r-i+o-n)]);break;case 10:u.push([e-.5-.5*(-n-r-o-i+4*h)/(n-r+o-i),t-.5]);break;case 11:u.push([e-.25-.25*(-o-i+2*h)/(o-i),t-.75-.25*(i+r-2*h)/(r-i)]);break;case 12:u.push([e-.5,t-.5-.5*(-i-r-o-n+4*h)/(i-r+o-n)]);break;case 13:u.push([e-.75-.25*(n+r-2*h)/(r-n),t-.25-.25*(-o-n+2*h)/(o-n)]);break;case 14:u.push([e-.25-.25*(-n-r+2*h)/(n-r),t-.25-.25*(-i-r+2*h)/(i-r)])}},cell:function(e,t,r,n,i,o,a,s,l){i?s.push([e,t]):s.push([t,e])}});return function(e,t){var r=[],i=[];return n(e,r,i,t),{positions:r,cells:i}}}};var a={}},529:function(e,t,r){"use strict";e.exports=function e(t,r,i){var a=(i=i||{}).fontStyle||"normal",s=i.fontWeight||"normal",l=i.fontVariant||"normal",c=[a,s,l,t].join("_"),u=o[c];u||(u=o[c]={" ":{data:new Float32Array(0),shape:.2}});var d=u[r];if(!d)if(r.length<=1||!/\d/.test(r))d=u[r]=function(e){for(var t=e.cells,r=e.positions,n=new Float32Array(6*t.length),i=0,o=0,a=0;a0&&(m+=.02);var y=new Float32Array(f),v=0,x=-.5*m;for(g=0;gMath.max(r,n)?i[2]=1:r>Math.max(t,n)?i[0]=1:i[1]=1;for(var o=0,a=0,l=0;l<3;++l)o+=e[l]*e[l],a+=i[l]*e[l];for(l=0;l<3;++l)i[l]-=a/o*e[l];return s(i,i),i}function h(e,t,r,i,o,a,s,l){this.center=n(r),this.up=n(i),this.right=n(o),this.radius=n([a]),this.angle=n([s,l]),this.angle.bounds=[[-1/0,-Math.PI/2],[1/0,Math.PI/2]],this.setDistanceLimits(e,t),this.computedCenter=this.center.curve(0),this.computedUp=this.up.curve(0),this.computedRight=this.right.curve(0),this.computedRadius=this.radius.curve(0),this.computedAngle=this.angle.curve(0),this.computedToward=[0,0,0],this.computedEye=[0,0,0],this.computedMatrix=new Array(16);for(var c=0;c<16;++c)this.computedMatrix[c]=.5;this.recalcMatrix(0)}var p=h.prototype;p.setDistanceLimits=function(e,t){e=e>0?Math.log(e):-1/0,t=t>0?Math.log(t):1/0,t=Math.max(t,e),this.radius.bounds[0][0]=e,this.radius.bounds[1][0]=t},p.getDistanceLimits=function(e){var t=this.radius.bounds[0];return e?(e[0]=Math.exp(t[0][0]),e[1]=Math.exp(t[1][0]),e):[Math.exp(t[0][0]),Math.exp(t[1][0])]},p.recalcMatrix=function(e){this.center.curve(e),this.up.curve(e),this.right.curve(e),this.radius.curve(e),this.angle.curve(e);for(var t=this.computedUp,r=this.computedRight,n=0,i=0,o=0;o<3;++o)i+=t[o]*r[o],n+=t[o]*t[o];var l=Math.sqrt(n),u=0;for(o=0;o<3;++o)r[o]-=t[o]*i/n,u+=r[o]*r[o],t[o]/=l;var d=Math.sqrt(u);for(o=0;o<3;++o)r[o]/=d;var h=this.computedToward;a(h,t,r),s(h,h);var p=Math.exp(this.computedRadius[0]),f=this.computedAngle[0],m=this.computedAngle[1],g=Math.cos(f),y=Math.sin(f),v=Math.cos(m),x=Math.sin(m),b=this.computedCenter,_=g*v,w=y*v,k=x,S=-g*x,A=-y*x,T=v,M=this.computedEye,C=this.computedMatrix;for(o=0;o<3;++o){var E=_*r[o]+w*h[o]+k*t[o];C[4*o+1]=S*r[o]+A*h[o]+T*t[o],C[4*o+2]=E,C[4*o+3]=0}var I=C[1],P=C[5],O=C[9],R=C[2],L=C[6],D=C[10],z=P*D-O*L,j=O*R-I*D,F=I*L-P*R,N=c(z,j,F);z/=N,j/=N,F/=N,C[0]=z,C[4]=j,C[8]=F;for(o=0;o<3;++o)M[o]=b[o]+C[2+4*o]*p;for(o=0;o<3;++o){u=0;for(var B=0;B<3;++B)u+=C[o+4*B]*M[B];C[12+o]=-u}C[15]=1},p.getMatrix=function(e,t){this.recalcMatrix(e);var r=this.computedMatrix;if(t){for(var n=0;n<16;++n)t[n]=r[n];return t}return r};var f=[0,0,0];p.rotate=function(e,t,r,n){if(this.angle.move(e,t,r),n){this.recalcMatrix(e);var i=this.computedMatrix;f[0]=i[2],f[1]=i[6],f[2]=i[10];for(var a=this.computedUp,s=this.computedRight,l=this.computedToward,c=0;c<3;++c)i[4*c]=a[c],i[4*c+1]=s[c],i[4*c+2]=l[c];o(i,i,n,f);for(c=0;c<3;++c)a[c]=i[4*c],s[c]=i[4*c+1];this.up.set(e,a[0],a[1],a[2]),this.right.set(e,s[0],s[1],s[2])}},p.pan=function(e,t,r,n){t=t||0,r=r||0,n=n||0,this.recalcMatrix(e);var i=this.computedMatrix,o=(Math.exp(this.computedRadius[0]),i[1]),a=i[5],s=i[9],l=c(o,a,s);o/=l,a/=l,s/=l;var u=i[0],d=i[4],h=i[8],p=u*o+d*a+h*s,f=c(u-=o*p,d-=a*p,h-=s*p),m=(u/=f)*t+o*r,g=(d/=f)*t+a*r,y=(h/=f)*t+s*r;this.center.move(e,m,g,y);var v=Math.exp(this.computedRadius[0]);v=Math.max(1e-4,v+n),this.radius.set(e,Math.log(v))},p.translate=function(e,t,r,n){this.center.move(e,t||0,r||0,n||0)},p.setMatrix=function(e,t,r,n){var o=1;"number"===typeof r&&(o=0|r),(o<0||o>3)&&(o=1);var a=(o+2)%3;t||(this.recalcMatrix(e),t=this.computedMatrix);var s=t[o],l=t[o+4],d=t[o+8];if(n){var h=Math.abs(s),p=Math.abs(l),f=Math.abs(d),m=Math.max(h,p,f);h===m?(s=s<0?-1:1,l=d=0):f===m?(d=d<0?-1:1,s=l=0):(l=l<0?-1:1,s=d=0)}else{var g=c(s,l,d);s/=g,l/=g,d/=g}var y,v,x=t[a],b=t[a+4],_=t[a+8],w=x*s+b*l+_*d,k=c(x-=s*w,b-=l*w,_-=d*w),S=l*(_/=k)-d*(b/=k),A=d*(x/=k)-s*_,T=s*b-l*x,M=c(S,A,T);if(S/=M,A/=M,T/=M,this.center.jump(e,$,W,q),this.radius.idle(e),this.up.jump(e,s,l,d),this.right.jump(e,x,b,_),2===o){var C=t[1],E=t[5],I=t[9],P=C*x+E*b+I*_,O=C*S+E*A+I*T;y=z<0?-Math.PI/2:Math.PI/2,v=Math.atan2(O,P)}else{var R=t[2],L=t[6],D=t[10],z=R*s+L*l+D*d,j=R*x+L*b+D*_,F=R*S+L*A+D*T;y=Math.asin(u(z)),v=Math.atan2(F,j)}this.angle.jump(e,v,y),this.recalcMatrix(e);var N=t[2],B=t[6],V=t[10],U=this.computedMatrix;i(U,t);var H=U[15],$=U[12]/H,W=U[13]/H,q=U[14]/H,G=Math.exp(this.computedRadius[0]);this.center.jump(e,$-N*G,W-B*G,q-V*G)},p.lastT=function(){return Math.max(this.center.lastT(),this.up.lastT(),this.right.lastT(),this.radius.lastT(),this.angle.lastT())},p.idle=function(e){this.center.idle(e),this.up.idle(e),this.right.idle(e),this.radius.idle(e),this.angle.idle(e)},p.flush=function(e){this.center.flush(e),this.up.flush(e),this.right.flush(e),this.radius.flush(e),this.angle.flush(e)},p.setDistance=function(e,t){t>0&&this.radius.set(e,Math.log(t))},p.lookAt=function(e,t,r,n){this.recalcMatrix(e),t=t||this.computedEye,r=r||this.computedCenter;var i=(n=n||this.computedUp)[0],o=n[1],a=n[2],s=c(i,o,a);if(!(s<1e-6)){i/=s,o/=s,a/=s;var l=t[0]-r[0],d=t[1]-r[1],h=t[2]-r[2],p=c(l,d,h);if(!(p<1e-6)){l/=p,d/=p,h/=p;var f=this.computedRight,m=f[0],g=f[1],y=f[2],v=i*m+o*g+a*y,x=c(m-=v*i,g-=v*o,y-=v*a);if(!(x<.01&&(x=c(m=o*h-a*d,g=a*l-i*h,y=i*d-o*l))<1e-6)){m/=x,g/=x,y/=x,this.up.set(e,i,o,a),this.right.set(e,m,g,y),this.center.set(e,r[0],r[1],r[2]),this.radius.set(e,Math.log(p));var b=o*y-a*g,_=a*m-i*y,w=i*g-o*m,k=c(b,_,w),S=i*l+o*d+a*h,A=m*l+g*d+y*h,T=(b/=k)*l+(_/=k)*d+(w/=k)*h,M=Math.asin(u(S)),C=Math.atan2(T,A),E=this.angle._state,I=E[E.length-1],P=E[E.length-2];I%=2*Math.PI;var O=Math.abs(I+2*Math.PI-C),R=Math.abs(I-C),L=Math.abs(I-2*Math.PI-C);O0?r.pop():new ArrayBuffer(e)}function f(e){return new Uint8Array(p(e),0,e)}function m(e){return new Uint16Array(p(2*e),0,e)}function g(e){return new Uint32Array(p(4*e),0,e)}function y(e){return new Int8Array(p(e),0,e)}function v(e){return new Int16Array(p(2*e),0,e)}function x(e){return new Int32Array(p(4*e),0,e)}function b(e){return new Float32Array(p(4*e),0,e)}function _(e){return new Float64Array(p(8*e),0,e)}function w(e){return a?new Uint8ClampedArray(p(e),0,e):f(e)}function k(e){return s?new BigUint64Array(p(8*e),0,e):null}function S(e){return l?new BigInt64Array(p(8*e),0,e):null}function A(e){return new DataView(p(e),0,e)}function T(e){e=n.nextPow2(e);var t=n.log2(e),r=d[t];return r.length>0?r.pop():new o(e)}t.free=function(e){if(o.isBuffer(e))d[n.log2(e.length)].push(e);else{if("[object ArrayBuffer]"!==Object.prototype.toString.call(e)&&(e=e.buffer),!e)return;var t=e.length||e.byteLength,r=0|n.log2(t);u[r].push(e)}},t.freeUint8=t.freeUint16=t.freeUint32=t.freeBigUint64=t.freeInt8=t.freeInt16=t.freeInt32=t.freeBigInt64=t.freeFloat32=t.freeFloat=t.freeFloat64=t.freeDouble=t.freeUint8Clamped=t.freeDataView=function(e){h(e.buffer)},t.freeArrayBuffer=h,t.freeBuffer=function(e){d[n.log2(e.length)].push(e)},t.malloc=function(e,t){if(void 0===t||"arraybuffer"===t)return p(e);switch(t){case"uint8":return f(e);case"uint16":return m(e);case"uint32":return g(e);case"int8":return y(e);case"int16":return v(e);case"int32":return x(e);case"float":case"float32":return b(e);case"double":case"float64":return _(e);case"uint8_clamped":return w(e);case"bigint64":return S(e);case"biguint64":return k(e);case"buffer":return T(e);case"data":case"dataview":return A(e);default:return null}return null},t.mallocArrayBuffer=p,t.mallocUint8=f,t.mallocUint16=m,t.mallocUint32=g,t.mallocInt8=y,t.mallocInt16=v,t.mallocInt32=x,t.mallocFloat32=t.mallocFloat=b,t.mallocFloat64=t.mallocDouble=_,t.mallocUint8Clamped=w,t.mallocBigUint64=k,t.mallocBigInt64=S,t.mallocDataView=A,t.mallocBuffer=T,t.clearCache=function(){for(var e=0;e<32;++e)c.UINT8[e].length=0,c.UINT16[e].length=0,c.UINT32[e].length=0,c.INT8[e].length=0,c.INT16[e].length=0,c.INT32[e].length=0,c.FLOAT[e].length=0,c.DOUBLE[e].length=0,c.BIGUINT64[e].length=0,c.BIGINT64[e].length=0,c.UINT8C[e].length=0,u[e].length=0,d[e].length=0}},1755:function(e){"use strict";function t(e){this.roots=new Array(e),this.ranks=new Array(e);for(var t=0;t0&&(o=n.size),n.lineSpacing&&n.lineSpacing>0&&(a=n.lineSpacing),n.styletags&&n.styletags.breaklines&&(s.breaklines=!!n.styletags.breaklines),n.styletags&&n.styletags.bolds&&(s.bolds=!!n.styletags.bolds),n.styletags&&n.styletags.italics&&(s.italics=!!n.styletags.italics),n.styletags&&n.styletags.subscripts&&(s.subscripts=!!n.styletags.subscripts),n.styletags&&n.styletags.superscripts&&(s.superscripts=!!n.styletags.superscripts));return r.font=[n.fontStyle,n.fontVariant,n.fontWeight,o+"px",n.font].filter((function(e){return e})).join(" "),r.textAlign="start",r.textBaseline="alphabetic",r.direction="ltr",w(function(e,t,r,n,o,a){r=r.replace(/\n/g,""),r=!0===a.breaklines?r.replace(/\/g,"\n"):r.replace(/\/g," ");var s="",l=[];for(k=0;k-1?parseInt(e[1+i]):0,l=o>-1?parseInt(r[1+o]):0;s!==l&&(n=n.replace(j(),"?px "),T*=Math.pow(.75,l-s),n=n.replace("?px ",j())),A+=.25*E*(l-s)}if(!0===a.superscripts){var c=e.indexOf(f),d=r.indexOf(f),p=c>-1?parseInt(e[1+c]):0,m=d>-1?parseInt(r[1+d]):0;p!==m&&(n=n.replace(j(),"?px "),T*=Math.pow(.75,m-p),n=n.replace("?px ",j())),A-=.25*E*(m-p)}if(!0===a.bolds){var g=e.indexOf(u)>-1,v=r.indexOf(u)>-1;!g&&v&&(n=x?n.replace("italic ","italic bold "):"bold "+n),g&&!v&&(n=n.replace("bold ",""))}if(!0===a.italics){var x=e.indexOf(h)>-1,b=r.indexOf(h)>-1;!x&&b&&(n="italic "+n),x&&!b&&(n=n.replace("italic ",""))}t.font=n}for(w=0;w",o="",a=i.length,s=o.length,l=t[0]===f||t[0]===y,c=0,u=-s;c>-1&&-1!==(c=r.indexOf(i,c))&&-1!==(u=r.indexOf(o,c+a))&&!(u<=c);){for(var d=c;d=u)n[d]=null,r=r.substr(0,d)+" "+r.substr(d+1);else if(null!==n[d]){var h=n[d].indexOf(t[0]);-1===h?n[d]+=t:l&&(n[d]=n[d].substr(0,h+1)+(1+parseInt(n[d][h+1]))+n[d].substr(h+2))}var p=c+a,m=r.substr(p,u-p).indexOf(i);c=-1!==m?m:u+s}return n}function b(e,t){var r=n(e,128);return t?o(r.cells,r.positions,.25):{edges:r.cells,positions:r.positions}}function _(e,t,r,n){var i=b(e,n),o=function(e,t,r){for(var n=t.textAlign||"start",i=t.textBaseline||"alphabetic",o=[1<<30,1<<30],a=[0,0],s=e.length,l=0;l=0?t[o]:i}))},has___:{value:x((function(t){var n=v(t);return n?r in n:e.indexOf(t)>=0}))},set___:{value:x((function(n,i){var o,a=v(n);return a?a[r]=i:(o=e.indexOf(n))>=0?t[o]=i:(o=e.length,t[o]=i,e[o]=n),this}))},delete___:{value:x((function(n){var i,o,a=v(n);return a?r in a&&delete a[r]:!((i=e.indexOf(n))<0)&&(o=e.length-1,e[i]=void 0,t[i]=t[o],e[i]=e[o],e.length=o,t.length=o,!0)}))}})};m.prototype=Object.create(Object.prototype,{get:{value:function(e,t){return this.get___(e,t)},writable:!0,configurable:!0},has:{value:function(e){return this.has___(e)},writable:!0,configurable:!0},set:{value:function(e,t){return this.set___(e,t)},writable:!0,configurable:!0},delete:{value:function(e){return this.delete___(e)},writable:!0,configurable:!0}}),"function"===typeof r?function(){function n(){this instanceof m||b();var e,n=new r,i=void 0,o=!1;return e=t?function(e,t){return n.set(e,t),n.has(e)||(i||(i=new m),i.set(e,t)),this}:function(e,t){if(o)try{n.set(e,t)}catch(r){i||(i=new m),i.set___(e,t)}else n.set(e,t);return this},Object.create(m.prototype,{get___:{value:x((function(e,t){return i?n.has(e)?n.get(e):i.get___(e,t):n.get(e,t)}))},has___:{value:x((function(e){return n.has(e)||!!i&&i.has___(e)}))},set___:{value:x(e)},delete___:{value:x((function(e){var t=!!n.delete(e);return i&&i.delete___(e)||t}))},permitHostObjects___:{value:x((function(e){if(e!==g)throw new Error("bogus call to permitHostObjects___");o=!0}))}})}t&&"undefined"!==typeof Proxy&&(Proxy=void 0),n.prototype=m.prototype,e.exports=n,Object.defineProperty(WeakMap.prototype,"constructor",{value:WeakMap,enumerable:!1,configurable:!0,writable:!0})}():("undefined"!==typeof Proxy&&(Proxy=void 0),e.exports=m)}function g(e){e.permitHostObjects___&&e.permitHostObjects___(g)}function y(e){return!(e.substr(0,8)==l&&"___"===e.substr(e.length-3))}function v(e){if(e!==Object(e))throw new TypeError("Not an object: "+e);var t=e[c];if(t&&t.key===e)return t;if(s(e)){t={key:e};try{return a(e,c,{value:t,writable:!1,enumerable:!1,configurable:!1}),t}catch(r){return}}}function x(e){return e.prototype=null,Object.freeze(e)}function b(){p||"undefined"===typeof console||(p=!0,console.warn("WeakMap should be invoked as new WeakMap(), not WeakMap(). This will be an error in the future."))}}()},236:function(e,t,r){var n=r(8284);e.exports=function(){var e={};return function(t){if(("object"!==typeof t||null===t)&&"function"!==typeof t)throw new Error("Weakmap-shim: Key must be object");var r=t.valueOf(e);return r&&r.identity===e?r:n(t,e)}}},8284:function(e){e.exports=function(e,t){var r={identity:t},n=e.valueOf;return Object.defineProperty(e,"valueOf",{value:function(e){return e!==t?n.apply(this,arguments):r},writable:!0}),r}},606:function(e,t,r){var n=r(236);e.exports=function(){var e=n();return{get:function(t,r){var n=e(t);return n.hasOwnProperty("value")?n.value:r},set:function(t,r){return e(t).value=r,this},has:function(t){return"value"in e(t)},delete:function(t){return delete e(t).value}}}},3349:function(e){"use strict";var t=function(){return function(e,t,r,n,i,o){var a=e[0],s=r[0],l=[0],c=s;n|=0;var u=0,d=s;for(u=0;u=0!==p>=0&&i.push(l[0]+.5+.5*(h+p)/(h-p)),n+=d,++l[0]}}};e.exports=function(e){return r={funcName:e.funcName},function(e){var t={};return function(r,n,i){var o=r.dtype,a=r.order,s=[o,a.join()].join(),l=t[s];return l||(t[s]=l=e([o,a])),l(r.shape.slice(0),r.data,r.stride,0|r.offset,n,i)}}(t.bind(void 0,r));var r}({funcName:"zeroCrossings"})},781:function(e,t,r){"use strict";e.exports=function(e,t){var r=[];return t=+t||0,n(e.hi(e.shape[0]-1),r,t),r};var n=r(3349)},7790:function(){}},r={};function n(e){var i=r[e];if(void 0!==i)return i.exports;var o=r[e]={id:e,loaded:!1,exports:{}};return t[e].call(o.exports,o,o.exports,n),o.loaded=!0,o.exports}n.g=function(){if("object"===typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"===typeof window)return window}}(),n.nmd=function(e){return e.paths=[],e.children||(e.children=[]),e};var i=n(1964);e.exports=i}()},56734:e=>{e.exports=function(e,t,r,n){var i=e[0],o=e[1],a=!1;void 0===r&&(r=0),void 0===n&&(n=t.length);for(var s=n-r,l=0,c=s-1;lo!==p>o&&i<(h-u)*(o-d)/(p-d)+u&&(a=!a)}return a}},72761:(e,t,r)=>{var n,i=r(16746),o=r(64011),a=r(16479),s=r(49971),l=r(58732),c=r(74282),u=!1,d=o();function h(e,t,r){var i=n.segments(e),o=n.segments(t),a=r(n.combine(i,o));return n.polygon(a)}n={buildLog:function(e){return!0===e?u=i():!1===e&&(u=!1),!1!==u&&u.list},epsilon:function(e){return d.epsilon(e)},segments:function(e){var t=a(!0,d,u);return e.regions.forEach(t.addRegion),{segments:t.calculate(e.inverted),inverted:e.inverted}},combine:function(e,t){return{combined:a(!1,d,u).calculate(e.segments,e.inverted,t.segments,t.inverted),inverted1:e.inverted,inverted2:t.inverted}},selectUnion:function(e){return{segments:l.union(e.combined,u),inverted:e.inverted1||e.inverted2}},selectIntersect:function(e){return{segments:l.intersect(e.combined,u),inverted:e.inverted1&&e.inverted2}},selectDifference:function(e){return{segments:l.difference(e.combined,u),inverted:e.inverted1&&!e.inverted2}},selectDifferenceRev:function(e){return{segments:l.differenceRev(e.combined,u),inverted:!e.inverted1&&e.inverted2}},selectXor:function(e){return{segments:l.xor(e.combined,u),inverted:e.inverted1!==e.inverted2}},polygon:function(e){return{regions:s(e.segments,d,u),inverted:e.inverted}},polygonFromGeoJSON:function(e){return c.toPolygon(n,e)},polygonToGeoJSON:function(e){return c.fromPolygon(n,d,e)},union:function(e,t){return h(e,t,n.selectUnion)},intersect:function(e,t){return h(e,t,n.selectIntersect)},difference:function(e,t){return h(e,t,n.selectDifference)},differenceRev:function(e,t){return h(e,t,n.selectDifferenceRev)},xor:function(e,t){return h(e,t,n.selectXor)}},"object"===typeof window&&(window.PolyBool=n),e.exports=n},16746:e=>{e.exports=function(){var e,t=0,r=!1;function n(t,r){return e.list.push({type:t,data:r?JSON.parse(JSON.stringify(r)):void 0}),e}return e={list:[],segmentId:function(){return t++},checkIntersection:function(e,t){return n("check",{seg1:e,seg2:t})},segmentChop:function(e,t){return n("div_seg",{seg:e,pt:t}),n("chop",{seg:e,pt:t})},statusRemove:function(e){return n("pop_seg",{seg:e})},segmentUpdate:function(e){return n("seg_update",{seg:e})},segmentNew:function(e,t){return n("new_seg",{seg:e,primary:t})},segmentRemove:function(e){return n("rem_seg",{seg:e})},tempStatus:function(e,t,r){return n("temp_status",{seg:e,above:t,below:r})},rewind:function(e){return n("rewind",{seg:e})},status:function(e,t,r){return n("status",{seg:e,above:t,below:r})},vert:function(t){return t===r?e:(r=t,n("vert",{x:t}))},log:function(e){return"string"!==typeof e&&(e=JSON.stringify(e,!1," ")),n("log",{txt:e})},reset:function(){return n("reset")},selected:function(e){return n("selected",{segs:e})},chainStart:function(e){return n("chain_start",{seg:e})},chainRemoveHead:function(e,t){return n("chain_rem_head",{index:e,pt:t})},chainRemoveTail:function(e,t){return n("chain_rem_tail",{index:e,pt:t})},chainNew:function(e,t){return n("chain_new",{pt1:e,pt2:t})},chainMatch:function(e){return n("chain_match",{index:e})},chainClose:function(e){return n("chain_close",{index:e})},chainAddHead:function(e,t){return n("chain_add_head",{index:e,pt:t})},chainAddTail:function(e,t){return n("chain_add_tail",{index:e,pt:t})},chainConnect:function(e,t){return n("chain_con",{index1:e,index2:t})},chainReverse:function(e){return n("chain_rev",{index:e})},chainJoin:function(e,t){return n("chain_join",{index1:e,index2:t})},done:function(){return n("done")}}}},64011:e=>{e.exports=function(e){"number"!==typeof e&&(e=1e-10);var t={epsilon:function(t){return"number"===typeof t&&(e=t),e},pointAboveOrOnLine:function(t,r,n){var i=r[0],o=r[1],a=n[0],s=n[1],l=t[0];return(a-i)*(t[1]-o)-(s-o)*(l-i)>=-e},pointBetween:function(t,r,n){var i=t[1]-r[1],o=n[0]-r[0],a=t[0]-r[0],s=n[1]-r[1],l=a*o+i*s;return!(l-e)},pointsSameX:function(t,r){return Math.abs(t[0]-r[0])e!=a-i>e&&(o-c)*(i-u)/(a-u)+c-n>e&&(s=!s),o=c,a=u}return s}};return t}},74282:e=>{var t={toPolygon:function(e,t){function r(t){if(t.length<=0)return e.segments({inverted:!1,regions:[]});function r(t){var r=t.slice(0,t.length-1);return e.segments({inverted:!1,regions:[r]})}for(var n=r(t[0]),i=1;i{var n=r(4729);e.exports=function(e,t,r){function i(e,t,n){return{id:r?r.segmentId():-1,start:e,end:t,myFill:{above:n.myFill.above,below:n.myFill.below},otherFill:null}}var o=n.create();function a(e,r){o.insertBefore(e,(function(n){return function(e,r,n,i,o,a){var s=t.pointsCompare(r,o);return 0!==s?s:t.pointsSame(n,a)?0:e!==i?e?1:-1:t.pointAboveOrOnLine(n,i?o:a,i?a:o)?1:-1}(e.isStart,e.pt,r,n.isStart,n.pt,n.other.pt)<0}))}function s(e,t){var r=function(e,t){var r=n.node({isStart:!0,pt:e.start,seg:e,primary:t,other:null,status:null});return a(r,e.end),r}(e,t);return function(e,t,r){var i=n.node({isStart:!1,pt:t.end,seg:t,primary:r,other:e,status:null});e.other=i,a(i,e.pt)}(r,e,t),r}function l(e,t){var n=i(t,e.seg.end,e.seg);return function(e,t){r&&r.segmentChop(e.seg,t),e.other.remove(),e.seg.end=t,e.other.pt=t,a(e.other,e.pt)}(e,t),s(n,e.primary)}function c(i,a){var s=n.create();function c(e){return s.findTransition((function(r){return function(e,r){var n=e.seg.start,i=e.seg.end,o=r.seg.start,a=r.seg.end;return t.pointsCollinear(n,o,a)?t.pointsCollinear(i,o,a)||t.pointAboveOrOnLine(i,o,a)?1:-1:t.pointAboveOrOnLine(n,o,a)?1:-1}(e,r.ev)>0}))}function u(e,n){var i=e.seg,o=n.seg,a=i.start,s=i.end,c=o.start,u=o.end;r&&r.checkIntersection(i,o);var d=t.linesIntersect(a,s,c,u);if(!1===d){if(!t.pointsCollinear(a,s,c))return!1;if(t.pointsSame(a,u)||t.pointsSame(s,c))return!1;var h=t.pointsSame(a,c),p=t.pointsSame(s,u);if(h&&p)return n;var f=!h&&t.pointBetween(a,c,u),m=!p&&t.pointBetween(s,c,u);if(h)return m?l(n,s):l(e,u),n;f&&(p||(m?l(n,s):l(e,u)),l(n,a))}else 0===d.alongA&&(-1===d.alongB?l(e,c):0===d.alongB?l(e,d.pt):1===d.alongB&&l(e,u)),0===d.alongB&&(-1===d.alongA?l(n,a):0===d.alongA?l(n,d.pt):1===d.alongA&&l(n,s));return!1}for(var d=[];!o.isEmpty();){var h=o.getHead();if(r&&r.vert(h.pt[0]),h.isStart){r&&r.segmentNew(h.seg,h.primary);var p=c(h),f=p.before?p.before.ev:null,m=p.after?p.after.ev:null;function g(){if(f){var e=u(h,f);if(e)return e}return!!m&&u(h,m)}r&&r.tempStatus(h.seg,!!f&&f.seg,!!m&&m.seg);var y,v=g();if(v){var x;if(e)(x=null===h.seg.myFill.below||h.seg.myFill.above!==h.seg.myFill.below)&&(v.seg.myFill.above=!v.seg.myFill.above);else v.seg.otherFill=h.seg.myFill;r&&r.segmentUpdate(v.seg),h.other.remove(),h.remove()}if(o.getHead()!==h){r&&r.rewind(h.seg);continue}if(e)x=null===h.seg.myFill.below||h.seg.myFill.above!==h.seg.myFill.below,h.seg.myFill.below=m?m.seg.myFill.above:i,h.seg.myFill.above=x?!h.seg.myFill.below:h.seg.myFill.below;else if(null===h.seg.otherFill)y=m?h.primary===m.primary?m.seg.otherFill.above:m.seg.myFill.above:h.primary?a:i,h.seg.otherFill={above:y,below:y};r&&r.status(h.seg,!!f&&f.seg,!!m&&m.seg),h.other.status=p.insert(n.node({ev:h}))}else{var b=h.status;if(null===b)throw new Error("PolyBool: Zero-length segment detected; your epsilon is probably too small or too large");if(s.exists(b.prev)&&s.exists(b.next)&&u(b.prev.ev,b.next.ev),r&&r.statusRemove(b.ev.seg),b.remove(),!h.primary){var _=h.seg.myFill;h.seg.myFill=h.seg.otherFill,h.seg.otherFill=_}d.push(h.seg)}o.getHead().remove()}return r&&r.done(),d}return e?{addRegion:function(e){for(var n,i,o,a=e[e.length-1],l=0;l{e.exports={create:function(){var e={root:{root:!0,next:null},exists:function(t){return null!==t&&t!==e.root},isEmpty:function(){return null===e.root.next},getHead:function(){return e.root.next},insertBefore:function(t,r){for(var n=e.root,i=e.root.next;null!==i;){if(r(i))return t.prev=i.prev,t.next=i,i.prev.next=t,void(i.prev=t);n=i,i=i.next}n.next=t,t.prev=n,t.next=null},findTransition:function(t){for(var r=e.root,n=e.root.next;null!==n&&!t(n);)r=n,n=n.next;return{before:r===e.root?null:r,after:n,insert:function(e){return e.prev=r,e.next=n,r.next=e,null!==n&&(n.prev=e),e}}}};return e},node:function(e){return e.prev=null,e.next=null,e.remove=function(){e.prev.next=e.next,e.next&&(e.next.prev=e.prev),e.prev=null,e.next=null},e}}},49971:e=>{e.exports=function(e,t,r){var n=[],i=[];return e.forEach((function(e){var o=e.start,a=e.end;if(t.pointsSame(o,a))console.warn("PolyBool: Warning: Zero-length segment detected; your epsilon is probably too small or too large");else{r&&r.chainStart(e);for(var s={index:0,matches_head:!1,matches_pt1:!1},l={index:0,matches_head:!1,matches_pt1:!1},c=s,u=0;u{function t(e,t,r){var n=[];return e.forEach((function(e){var i=(e.myFill.above?8:0)+(e.myFill.below?4:0)+(e.otherFill&&e.otherFill.above?2:0)+(e.otherFill&&e.otherFill.below?1:0);0!==t[i]&&n.push({id:r?r.segmentId():-1,start:e.start,end:e.end,myFill:{above:1===t[i],below:2===t[i]},otherFill:null})})),r&&r.selected(n),n}var r={union:function(e,r){return t(e,[0,2,1,0,2,2,0,0,1,0,1,0,0,0,0,0],r)},intersect:function(e,r){return t(e,[0,0,0,0,0,2,0,2,0,0,1,1,0,2,1,0],r)},difference:function(e,r){return t(e,[0,0,0,0,2,0,2,0,1,1,0,0,0,1,2,0],r)},differenceRev:function(e,r){return t(e,[0,2,1,0,0,0,1,1,0,2,0,2,0,0,0,0],r)},xor:function(e,r){return t(e,[0,2,1,0,2,0,0,1,1,0,0,2,0,1,2,0],r)}};e.exports=r},37163:e=>{"use strict";e.exports=["Float32Array","Float64Array","Int8Array","Int16Array","Int32Array","Uint8Array","Uint8ClampedArray","Uint16Array","Uint32Array","BigInt64Array","BigUint64Array"]},88963:(e,t,r)=>{"use strict";var n=r(61781).Transform,i=r(33320);function o(){n.call(this,{readableObjectMode:!0})}function a(e,t,r){Error.call(this),Error.captureStackTrace?Error.captureStackTrace(this,this.constructor):this.stack=(new Error).stack||"",this.name=this.constructor.name,this.message=e,t&&(this.code=t),r&&(this.statusCode=r)}o.prototype=Object.create(n.prototype),o.prototype.constructor=o,i(o.prototype),t.rU=function(e,t,r){for(var n=t,i=0;i{"use strict";function t(e,t){var r=new Error(e);return r.code=t,r}function r(e){try{return decodeURIComponent(escape(e))}catch(t){return e}}function n(e,r,n){this.input=e.subarray(r,n),this.start=r;var i=String.fromCharCode.apply(null,this.input.subarray(0,4));if("II*\0"!==i&&"MM\0*"!==i)throw t("invalid TIFF signature","EBADDATA");this.big_endian="M"===i[0]}n.prototype.each=function(e){this.aborted=!1;var t=this.read_uint32(4);for(this.ifds_to_read=[{id:0,offset:t}];this.ifds_to_read.length>0&&!this.aborted;){var r=this.ifds_to_read.shift();r.offset&&this.scan_ifd(r.id,r.offset,e)}},n.prototype.read_uint16=function(e){var r=this.input;if(e+2>r.length)throw t("unexpected EOF","EBADDATA");return this.big_endian?256*r[e]+r[e+1]:r[e]+256*r[e+1]},n.prototype.read_uint32=function(e){var r=this.input;if(e+4>r.length)throw t("unexpected EOF","EBADDATA");return this.big_endian?16777216*r[e]+65536*r[e+1]+256*r[e+2]+r[e+3]:r[e]+256*r[e+1]+65536*r[e+2]+16777216*r[e+3]},n.prototype.is_subifd_link=function(e,t){return 0===e&&34665===t||0===e&&34853===t||34665===e&&40965===t},n.prototype.exif_format_length=function(e){switch(e){case 1:case 2:case 6:case 7:return 1;case 3:case 8:return 2;case 4:case 9:case 11:return 4;case 5:case 10:case 12:return 8;default:return 0}},n.prototype.exif_format_read=function(e,t){var r;switch(e){case 1:case 2:return r=this.input[t];case 6:return(r=this.input[t])|33554430*(128&r);case 3:return r=this.read_uint16(t);case 8:return(r=this.read_uint16(t))|131070*(32768&r);case 4:return r=this.read_uint32(t);case 9:return 0|(r=this.read_uint32(t));default:return null}},n.prototype.scan_ifd=function(e,n,i){var o=this.read_uint16(n);n+=2;for(var a=0;athis.input.length)throw t("unexpected EOF","EBADDATA");for(var f=[],m=h,g=0;g0&&(this.ifds_to_read.push({id:s,offset:f[0]}),p=!0),!1===i({is_big_endian:this.big_endian,ifd:e,tag:s,format:l,count:c,entry_offset:n+this.start,data_length:d,data_offset:h+this.start,value:f,is_subifd_link:p}))return void(this.aborted=!0);n+=12}0===e&&this.ifds_to_read.push({id:1,offset:this.read_uint32(n)})},e.exports.ExifParser=n,e.exports.get_orientation=function(e){var t=0;try{return new n(e,0,e.length).each((function(e){if(0===e.ifd&&274===e.tag&&Array.isArray(e.value))return t=e.value[0],!1})),t}catch(r){return-1}}},37825:(e,t,r)=>{"use strict";var n=r(88963).bc,i=r(88963).bb;function o(e,t){if(e.length<4+t)return null;var r=i(e,t);return e.length>4&15,i=15&e[4],o=e[5]>>4&15,a=n(e,6),l=8,c=0;ct.width||e.width===t.width&&e.height>t.height?e:t})),r=e.reduce((function(e,t){return e.height>t.height||e.height===t.height&&e.width>t.width?e:t}));return t.width>r.height||t.width===r.height&&t.height>r.width?t:r}(t.sizes),n=1;t.transforms.forEach((function(e){var t={1:6,2:5,3:8,4:7,5:4,6:3,7:2,8:1},r={1:4,2:3,3:2,4:1,5:6,6:5,7:8,8:7};if("imir"===e.type&&(n=0===e.value?r[n]:t[n=t[n=r[n]]]),"irot"===e.type)for(var i=0;i{"use strict";var n=r(88963).VG,i=r(88963).rU,o=r(88963).bb,a=r(37825),s=r(20670),l=n("ftyp");e.exports=function(e){if(i(e,4,l)){var t=a.unbox(e,0);if(t){var r=a.getMimeType(t.data);if(r){for(var n,c=t.end;;){var u=a.unbox(e,c);if(!u)break;if(c=u.end,"mdat"===u.boxtype)return;if("meta"===u.boxtype){n=u.data;break}}if(n){var d=a.readSizeFromMeta(n);if(d){var h={width:d.width,height:d.height,type:r.type,mime:r.mime,wUnits:"px",hUnits:"px"};if(d.variants.length>1&&(h.variants=d.variants),d.orientation&&(h.orientation=d.orientation),d.exif_location&&d.exif_location.offset+d.exif_location.length<=e.length){var p=o(e,d.exif_location.offset),f=e.slice(d.exif_location.offset+p+4,d.exif_location.offset+d.exif_location.length),m=s.get_orientation(f);m>0&&(h.orientation=m)}return h}}}}}}},60873:(e,t,r)=>{"use strict";var n=r(88963).VG,i=r(88963).rU,o=r(88963).$l,a=n("BM");e.exports=function(e){if(!(e.length<26)&&i(e,0,a))return{width:o(e,18),height:o(e,22),type:"bmp",mime:"image/bmp",wUnits:"px",hUnits:"px"}}},19144:(e,t,r)=>{"use strict";var n=r(88963).VG,i=r(88963).rU,o=r(88963).$l,a=n("GIF87a"),s=n("GIF89a");e.exports=function(e){if(!(e.length<10)&&(i(e,0,a)||i(e,0,s)))return{width:o(e,6),height:o(e,8),type:"gif",mime:"image/gif",wUnits:"px",hUnits:"px"}}},28087:(e,t,r)=>{"use strict";var n=r(88963).$l;e.exports=function(e){var t=n(e,0),r=n(e,2),i=n(e,4);if(0===t&&1===r&&i){for(var o=[],a={width:0,height:0},s=0;sa.width||c>a.height)&&(a=u)}return{width:a.width,height:a.height,variants:o,type:"ico",mime:"image/x-icon",wUnits:"px",hUnits:"px"}}}},96266:(e,t,r)=>{"use strict";var n=r(88963).bc,i=r(88963).VG,o=r(88963).rU,a=r(20670),s=i("Exif\0\0");e.exports=function(e){if(!(e.length<2)&&255===e[0]&&216===e[1]&&255===e[2])for(var t=2;;){for(;;){if(e.length-t<2)return;if(255===e[t++])break}for(var r,i,l=e[t++];255===l;)l=e[t++];if(208<=l&&l<=217||1===l)r=0;else{if(!(192<=l&&l<=254))return;if(e.length-t<2)return;r=n(e,t)-2,t+=2}if(217===l||218===l)return;if(225===l&&r>=10&&o(e,t,s)&&(i=a.get_orientation(e.slice(t+6,t+r))),r>=5&&192<=l&&l<=207&&196!==l&&200!==l&&204!==l){if(e.length-t0&&(c.orientation=i),c}t+=r}}},82473:(e,t,r)=>{"use strict";var n=r(88963).VG,i=r(88963).rU,o=r(88963).bb,a=n("\x89PNG\r\n\x1a\n"),s=n("IHDR");e.exports=function(e){if(!(e.length<24)&&i(e,0,a)&&i(e,12,s))return{width:o(e,16),height:o(e,20),type:"png",mime:"image/png",wUnits:"px",hUnits:"px"}}},77897:(e,t,r)=>{"use strict";var n=r(88963).VG,i=r(88963).rU,o=r(88963).bb,a=n("8BPS\0\x01");e.exports=function(e){if(!(e.length<22)&&i(e,0,a))return{width:o(e,18),height:o(e,14),type:"psd",mime:"image/vnd.adobe.photoshop",wUnits:"px",hUnits:"px"}}},24628:e=>{"use strict";function t(e){return"number"===typeof e&&isFinite(e)&&e>0}var r=/<[-_.:a-zA-Z0-9][^>]*>/,n=/^<([-_.:a-zA-Z0-9]+:)?svg\s/,i=/[^-]\bwidth="([^%]+?)"|[^-]\bwidth='([^%]+?)'/,o=/\bheight="([^%]+?)"|\bheight='([^%]+?)'/,a=/\bview[bB]ox="(.+?)"|\bview[bB]ox='(.+?)'/,s=/in$|mm$|cm$|pt$|pc$|px$|em$|ex$/;function l(e){return s.test(e)?e.match(s)[0]:"px"}e.exports=function(e){if(function(e){var t,r=0,n=e.length;for(239===e[0]&&187===e[1]&&191===e[2]&&(r=3);r{"use strict";var n=r(88963).VG,i=r(88963).rU,o=r(88963).$l,a=r(88963).bc,s=r(88963).tF,l=r(88963).bb,c=n("II*\0"),u=n("MM\0*");function d(e,t,r){return r?a(e,t):o(e,t)}function h(e,t,r){return r?l(e,t):s(e,t)}function p(e,t,r){var n=d(e,t+2,r);return 1!==h(e,t+4,r)||3!==n&&4!==n?null:3===n?d(e,t+8,r):h(e,t+8,r)}e.exports=function(e){if(!(e.length<8)&&(i(e,0,c)||i(e,0,u))){var t=77===e[0],r=h(e,4,t)-8;if(!(r<0)){var n=r+8;if(!(e.length-n<2)){var o=12*d(e,n+0,t);if(!(o<=0)&&(n+=2,!(e.length-n{"use strict";var n=r(88963).VG,i=r(88963).rU,o=r(88963).$l,a=r(88963).tF,s=r(20670),l=n("RIFF"),c=n("WEBP");function u(e,t){if(157===e[t+3]&&1===e[t+4]&&42===e[t+5])return{width:16383&o(e,t+6),height:16383&o(e,t+8),type:"webp",mime:"image/webp",wUnits:"px",hUnits:"px"}}function d(e,t){if(47===e[t]){var r=a(e,t+1);return{width:1+(16383&r),height:1+(r>>14&16383),type:"webp",mime:"image/webp",wUnits:"px",hUnits:"px"}}}function h(e,t){return{width:1+(e[t+6]<<16|e[t+5]<<8|e[t+4]),height:1+(e[t+9]<e.length)){for(;t+8=10?r=r||u(e,t+8):"VP8L"===p&&f>=9?r=r||d(e,t+8):"VP8X"===p&&f>=10?r=r||h(e,t+8):"EXIF"===p&&(n=s.get_orientation(e.slice(t+8,t+8+f)),t=1/0),t+=8+f}else t++;if(r)return n>0&&(r.orientation=n),r}}}},59348:(e,t,r)=>{"use strict";e.exports={avif:r(15476),bmp:r(60873),gif:r(19144),ico:r(28087),jpeg:r(96266),png:r(82473),psd:r(77897),svg:r(24628),tiff:r(56551),webp:r(65754)}},77681:(e,t,r)=>{"use strict";var n=r(59348);e.exports=function(e){return function(e){for(var t=Object.keys(n),r=0;r{"use strict";var n=r(13218);function i(){}function o(){}o.resetWarningCache=i,e.exports=function(){function e(e,t,r,i,o,a){if(a!==n){var s=new Error("Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types");throw s.name="Invariant Violation",s}}function t(){return e}e.isRequired=e;var r={array:e,bigint:e,bool:e,func:e,number:e,object:e,string:e,symbol:e,any:e,arrayOf:t,element:e,elementType:e,instanceOf:t,node:e,objectOf:t,oneOf:t,oneOfType:t,shape:t,exact:t,checkPropTypes:o,resetWarningCache:i};return r.PropTypes=r,r}},65173:(e,t,r)=>{e.exports=r(41497)()},13218:e=>{"use strict";e.exports="SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"},39108:e=>{"use strict";var t=String.prototype.replace,r=/%20/g,n="RFC1738",i="RFC3986";e.exports={default:i,formatters:{RFC1738:function(e){return t.call(e,r,"+")},RFC3986:function(e){return String(e)}},RFC1738:n,RFC3986:i}},22908:(e,t,r)=>{"use strict";var n=r(82129),i=r(90639),o=r(39108);e.exports={formats:o,parse:i,stringify:n}},90639:(e,t,r)=>{"use strict";var n=r(60149),i=Object.prototype.hasOwnProperty,o=Array.isArray,a={allowDots:!1,allowEmptyArrays:!1,allowPrototypes:!1,allowSparse:!1,arrayLimit:20,charset:"utf-8",charsetSentinel:!1,comma:!1,decodeDotInKeys:!1,decoder:n.decode,delimiter:"&",depth:5,duplicates:"combine",ignoreQueryPrefix:!1,interpretNumericEntities:!1,parameterLimit:1e3,parseArrays:!0,plainObjects:!1,strictDepth:!1,strictNullHandling:!1},s=function(e){return e.replace(/&#(\d+);/g,(function(e,t){return String.fromCharCode(parseInt(t,10))}))},l=function(e,t){return e&&"string"===typeof e&&t.comma&&e.indexOf(",")>-1?e.split(","):e},c=function(e,t,r,n){if(e){var o=r.allowDots?e.replace(/\.([^.[]+)/g,"[$1]"):e,a=/(\[[^[\]]*])/g,s=r.depth>0&&/(\[[^[\]]*])/.exec(o),c=s?o.slice(0,s.index):o,u=[];if(c){if(!r.plainObjects&&i.call(Object.prototype,c)&&!r.allowPrototypes)return;u.push(c)}for(var d=0;r.depth>0&&null!==(s=a.exec(o))&&d=0;--o){var a,s=e[o];if("[]"===s&&r.parseArrays)a=r.allowEmptyArrays&&(""===i||r.strictNullHandling&&null===i)?[]:[].concat(i);else{a=r.plainObjects?Object.create(null):{};var c="["===s.charAt(0)&&"]"===s.charAt(s.length-1)?s.slice(1,-1):s,u=r.decodeDotInKeys?c.replace(/%2E/g,"."):c,d=parseInt(u,10);r.parseArrays||""!==u?!isNaN(d)&&s!==u&&String(d)===u&&d>=0&&r.parseArrays&&d<=r.arrayLimit?(a=[])[d]=i:"__proto__"!==u&&(a[u]=i):a={0:i}}i=a}return i}(u,t,r,n)}};e.exports=function(e,t){var r=function(e){if(!e)return a;if("undefined"!==typeof e.allowEmptyArrays&&"boolean"!==typeof e.allowEmptyArrays)throw new TypeError("`allowEmptyArrays` option can only be `true` or `false`, when provided");if("undefined"!==typeof e.decodeDotInKeys&&"boolean"!==typeof e.decodeDotInKeys)throw new TypeError("`decodeDotInKeys` option can only be `true` or `false`, when provided");if(null!==e.decoder&&"undefined"!==typeof e.decoder&&"function"!==typeof e.decoder)throw new TypeError("Decoder has to be a function.");if("undefined"!==typeof e.charset&&"utf-8"!==e.charset&&"iso-8859-1"!==e.charset)throw new TypeError("The charset option must be either utf-8, iso-8859-1, or undefined");var t="undefined"===typeof e.charset?a.charset:e.charset,r="undefined"===typeof e.duplicates?a.duplicates:e.duplicates;if("combine"!==r&&"first"!==r&&"last"!==r)throw new TypeError("The duplicates option must be either combine, first, or last");return{allowDots:"undefined"===typeof e.allowDots?!0===e.decodeDotInKeys||a.allowDots:!!e.allowDots,allowEmptyArrays:"boolean"===typeof e.allowEmptyArrays?!!e.allowEmptyArrays:a.allowEmptyArrays,allowPrototypes:"boolean"===typeof e.allowPrototypes?e.allowPrototypes:a.allowPrototypes,allowSparse:"boolean"===typeof e.allowSparse?e.allowSparse:a.allowSparse,arrayLimit:"number"===typeof e.arrayLimit?e.arrayLimit:a.arrayLimit,charset:t,charsetSentinel:"boolean"===typeof e.charsetSentinel?e.charsetSentinel:a.charsetSentinel,comma:"boolean"===typeof e.comma?e.comma:a.comma,decodeDotInKeys:"boolean"===typeof e.decodeDotInKeys?e.decodeDotInKeys:a.decodeDotInKeys,decoder:"function"===typeof e.decoder?e.decoder:a.decoder,delimiter:"string"===typeof e.delimiter||n.isRegExp(e.delimiter)?e.delimiter:a.delimiter,depth:"number"===typeof e.depth||!1===e.depth?+e.depth:a.depth,duplicates:r,ignoreQueryPrefix:!0===e.ignoreQueryPrefix,interpretNumericEntities:"boolean"===typeof e.interpretNumericEntities?e.interpretNumericEntities:a.interpretNumericEntities,parameterLimit:"number"===typeof e.parameterLimit?e.parameterLimit:a.parameterLimit,parseArrays:!1!==e.parseArrays,plainObjects:"boolean"===typeof e.plainObjects?e.plainObjects:a.plainObjects,strictDepth:"boolean"===typeof e.strictDepth?!!e.strictDepth:a.strictDepth,strictNullHandling:"boolean"===typeof e.strictNullHandling?e.strictNullHandling:a.strictNullHandling}}(t);if(""===e||null===e||"undefined"===typeof e)return r.plainObjects?Object.create(null):{};for(var u="string"===typeof e?function(e,t){var r={__proto__:null},c=t.ignoreQueryPrefix?e.replace(/^\?/,""):e;c=c.replace(/%5B/gi,"[").replace(/%5D/gi,"]");var u,d=t.parameterLimit===1/0?void 0:t.parameterLimit,h=c.split(t.delimiter,d),p=-1,f=t.charset;if(t.charsetSentinel)for(u=0;u-1&&(g=o(g)?[g]:g);var b=i.call(r,m);b&&"combine"===t.duplicates?r[m]=n.combine(r[m],g):b&&"last"!==t.duplicates||(r[m]=g)}return r}(e,r):e,d=r.plainObjects?Object.create(null):{},h=Object.keys(u),p=0;p{"use strict";var n=r(19269),i=r(60149),o=r(39108),a=Object.prototype.hasOwnProperty,s={brackets:function(e){return e+"[]"},comma:"comma",indices:function(e,t){return e+"["+t+"]"},repeat:function(e){return e}},l=Array.isArray,c=Array.prototype.push,u=function(e,t){c.apply(e,l(t)?t:[t])},d=Date.prototype.toISOString,h=o.default,p={addQueryPrefix:!1,allowDots:!1,allowEmptyArrays:!1,arrayFormat:"indices",charset:"utf-8",charsetSentinel:!1,delimiter:"&",encode:!0,encodeDotInKeys:!1,encoder:i.encode,encodeValuesOnly:!1,format:h,formatter:o.formatters[h],indices:!1,serializeDate:function(e){return d.call(e)},skipNulls:!1,strictNullHandling:!1},f={},m=function e(t,r,o,a,s,c,d,h,m,g,y,v,x,b,_,w,k,S){for(var A,T=t,M=S,C=0,E=!1;void 0!==(M=M.get(f))&&!E;){var I=M.get(t);if(C+=1,"undefined"!==typeof I){if(I===C)throw new RangeError("Cyclic object value");E=!0}"undefined"===typeof M.get(f)&&(C=0)}if("function"===typeof g?T=g(r,T):T instanceof Date?T=x(T):"comma"===o&&l(T)&&(T=i.maybeMap(T,(function(e){return e instanceof Date?x(e):e}))),null===T){if(c)return m&&!w?m(r,p.encoder,k,"key",b):r;T=""}if("string"===typeof(A=T)||"number"===typeof A||"boolean"===typeof A||"symbol"===typeof A||"bigint"===typeof A||i.isBuffer(T))return m?[_(w?r:m(r,p.encoder,k,"key",b))+"="+_(m(T,p.encoder,k,"value",b))]:[_(r)+"="+_(String(T))];var P,O=[];if("undefined"===typeof T)return O;if("comma"===o&&l(T))w&&m&&(T=i.maybeMap(T,m)),P=[{value:T.length>0?T.join(",")||null:void 0}];else if(l(g))P=g;else{var R=Object.keys(T);P=y?R.sort(y):R}var L=h?r.replace(/\./g,"%2E"):r,D=a&&l(T)&&1===T.length?L+"[]":L;if(s&&l(T)&&0===T.length)return D+"[]";for(var z=0;z0?b+x:""}},60149:(e,t,r)=>{"use strict";var n=r(39108),i=Object.prototype.hasOwnProperty,o=Array.isArray,a=function(){for(var e=[],t=0;t<256;++t)e.push("%"+((t<16?"0":"")+t.toString(16)).toUpperCase());return e}(),s=function(e,t){for(var r=t&&t.plainObjects?Object.create(null):{},n=0;n1;){var t=e.pop(),r=t.obj[t.prop];if(o(r)){for(var n=[],i=0;i=l?s.slice(u,u+l):s,h=[],p=0;p=48&&f<=57||f>=65&&f<=90||f>=97&&f<=122||o===n.RFC1738&&(40===f||41===f)?h[h.length]=d.charAt(p):f<128?h[h.length]=a[f]:f<2048?h[h.length]=a[192|f>>6]+a[128|63&f]:f<55296||f>=57344?h[h.length]=a[224|f>>12]+a[128|f>>6&63]+a[128|63&f]:(p+=1,f=65536+((1023&f)<<10|1023&d.charCodeAt(p)),h[h.length]=a[240|f>>18]+a[128|f>>12&63]+a[128|f>>6&63]+a[128|63&f])}c+=h.join("")}return c},isBuffer:function(e){return!(!e||"object"!==typeof e)&&!!(e.constructor&&e.constructor.isBuffer&&e.constructor.isBuffer(e))},isRegExp:function(e){return"[object RegExp]"===Object.prototype.toString.call(e)},maybeMap:function(e,t){if(o(e)){for(var r=[],n=0;n{for(var n=r(57588),i="undefined"===typeof window?r.g:window,o=["moz","webkit"],a="AnimationFrame",s=i["request"+a],l=i["cancel"+a]||i["cancelRequest"+a],c=0;!s&&c{"use strict";var n=r(65043),i=r(78853);function o(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,r=1;r
MapLibre'};class _s{constructor(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:bs;this._toggleAttribution=()=>{this._container.classList.contains("maplibregl-compact")&&(this._container.classList.contains("maplibregl-compact-show")?(this._container.setAttribute("open",""),this._container.classList.remove("maplibregl-compact-show")):(this._container.classList.add("maplibregl-compact-show"),this._container.removeAttribute("open")))},this._updateData=e=>{!e||"metadata"!==e.sourceDataType&&"visibility"!==e.sourceDataType&&"style"!==e.dataType&&"terrain"!==e.type||this._updateAttributions()},this._updateCompact=()=>{this._map.getCanvasContainer().offsetWidth<=640||this._compact?!1===this._compact?this._container.setAttribute("open",""):this._container.classList.contains("maplibregl-compact")||this._container.classList.contains("maplibregl-attrib-empty")||(this._container.setAttribute("open",""),this._container.classList.add("maplibregl-compact","maplibregl-compact-show")):(this._container.setAttribute("open",""),this._container.classList.contains("maplibregl-compact")&&this._container.classList.remove("maplibregl-compact","maplibregl-compact-show"))},this._updateCompactMinimize=()=>{this._container.classList.contains("maplibregl-compact")&&this._container.classList.contains("maplibregl-compact-show")&&this._container.classList.remove("maplibregl-compact-show")},this.options=e}getDefaultPosition(){return"bottom-right"}onAdd(e){return this._map=e,this._compact=this.options.compact,this._container=a.create("details","maplibregl-ctrl maplibregl-ctrl-attrib"),this._compactButton=a.create("summary","maplibregl-ctrl-attrib-button",this._container),this._compactButton.addEventListener("click",this._toggleAttribution),this._setElementTitle(this._compactButton,"ToggleAttribution"),this._innerContainer=a.create("div","maplibregl-ctrl-attrib-inner",this._container),this._updateAttributions(),this._updateCompact(),this._map.on("styledata",this._updateData),this._map.on("sourcedata",this._updateData),this._map.on("terrain",this._updateData),this._map.on("resize",this._updateCompact),this._map.on("drag",this._updateCompactMinimize),this._container}onRemove(){a.remove(this._container),this._map.off("styledata",this._updateData),this._map.off("sourcedata",this._updateData),this._map.off("terrain",this._updateData),this._map.off("resize",this._updateCompact),this._map.off("drag",this._updateCompactMinimize),this._map=void 0,this._compact=void 0,this._attribHTML=void 0}_setElementTitle(e,t){const r=this._map._getUIString(`AttributionControl.${t}`);e.title=r,e.setAttribute("aria-label",r)}_updateAttributions(){if(!this._map.style)return;let e=[];if(this.options.customAttribution&&(Array.isArray(this.options.customAttribution)?e=e.concat(this.options.customAttribution.map((e=>"string"!==typeof e?"":e))):"string"===typeof this.options.customAttribution&&e.push(this.options.customAttribution)),this._map.style.stylesheet){const e=this._map.style.stylesheet;this.styleOwner=e.owner,this.styleId=e.id}const t=this._map.style.sourceCaches;for(const n in t){const r=t[n];if(r.used||r.usedForTerrain){const t=r.getSource();t.attribution&&e.indexOf(t.attribution)<0&&e.push(t.attribution)}}e=e.filter((e=>String(e).trim())),e.sort(((e,t)=>e.length-t.length)),e=e.filter(((t,r)=>{for(let n=r+1;n=0)return!1;return!0}));const r=e.join(" | ");r!==this._attribHTML&&(this._attribHTML=r,e.length?(this._innerContainer.innerHTML=r,this._container.classList.remove("maplibregl-attrib-empty")):this._container.classList.add("maplibregl-attrib-empty"),this._updateCompact(),this._editLink=null)}}class ws{constructor(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};this._updateCompact=()=>{const e=this._container.children;if(e.length){const t=e[0];this._map.getCanvasContainer().offsetWidth<=640||this._compact?!1!==this._compact&&t.classList.add("maplibregl-compact"):t.classList.remove("maplibregl-compact")}},this.options=e}getDefaultPosition(){return"bottom-left"}onAdd(e){this._map=e,this._compact=this.options&&this.options.compact,this._container=a.create("div","maplibregl-ctrl");const t=a.create("a","maplibregl-ctrl-logo");return t.target="_blank",t.rel="noopener nofollow",t.href="https://maplibre.org/",t.setAttribute("aria-label",this._map._getUIString("LogoControl.Title")),t.setAttribute("rel","noopener nofollow"),this._container.appendChild(t),this._container.style.display="block",this._map.on("resize",this._updateCompact),this._updateCompact(),this._container}onRemove(){a.remove(this._container),this._map.off("resize",this._updateCompact),this._map=void 0,this._compact=void 0}}class ks{constructor(){this._queue=[],this._id=0,this._cleared=!1,this._currentlyRunning=!1}add(e){const t=++this._id;return this._queue.push({callback:e,id:t,cancelled:!1}),t}remove(e){const t=this._currentlyRunning,r=t?this._queue.concat(t):this._queue;for(const n of r)if(n.id===e)return void(n.cancelled=!0)}run(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;if(this._currentlyRunning)throw new Error("Attempting to run(), but is already running.");const t=this._currentlyRunning=this._queue;this._queue=[];for(const r of t)if(!r.cancelled&&(r.callback(e),this._cleared))break;this._cleared=!1,this._currentlyRunning=!1}clear(){this._currentlyRunning&&(this._cleared=!0),this._queue=[]}}var Ss=t.Y([{name:"a_pos3d",type:"Int16",components:3}]);class As extends t.E{constructor(e){super(),this.sourceCache=e,this._tiles={},this._renderableTilesKeys=[],this._sourceTileCache={},this.minzoom=0,this.maxzoom=22,this.tileSize=512,this.deltaZoom=1,e.usedForTerrain=!0,e.tileSize=this.tileSize*2**this.deltaZoom}destruct(){this.sourceCache.usedForTerrain=!1,this.sourceCache.tileSize=null}update(e,r){this.sourceCache.update(e,r),this._renderableTilesKeys=[];const n={};for(const i of e.coveringTiles({tileSize:this.tileSize,minzoom:this.minzoom,maxzoom:this.maxzoom,reparseOverscaled:!1,terrain:r}))n[i.key]=!0,this._renderableTilesKeys.push(i.key),this._tiles[i.key]||(i.posMatrix=new Float64Array(16),t.aP(i.posMatrix,0,t.X,0,t.X,0,1),this._tiles[i.key]=new He(i,this.tileSize));for(const t in this._tiles)n[t]||delete this._tiles[t]}freeRtt(e){for(const t in this._tiles){const r=this._tiles[t];(!e||r.tileID.equals(e)||r.tileID.isChildOf(e)||e.isChildOf(r.tileID))&&(r.rtt=[])}}getRenderableTiles(){return this._renderableTilesKeys.map((e=>this.getTileByID(e)))}getTileByID(e){return this._tiles[e]}getTerrainCoords(e){const r={};for(const n of this._renderableTilesKeys){const i=this._tiles[n].tileID;if(i.canonical.equals(e.canonical)){const i=e.clone();i.posMatrix=new Float64Array(16),t.aP(i.posMatrix,0,t.X,0,t.X,0,1),r[n]=i}else if(i.canonical.isChildOf(e.canonical)){const o=e.clone();o.posMatrix=new Float64Array(16);const a=i.canonical.z-e.canonical.z,s=i.canonical.x-(i.canonical.x>>a<>a<>a;t.aP(o.posMatrix,0,c,0,c,0,1),t.J(o.posMatrix,o.posMatrix,[-s*c,-l*c,0]),r[n]=o}else if(e.canonical.isChildOf(i.canonical)){const o=e.clone();o.posMatrix=new Float64Array(16);const a=e.canonical.z-i.canonical.z,s=e.canonical.x-(e.canonical.x>>a<>a<>a;t.aP(o.posMatrix,0,t.X,0,t.X,0,1),t.J(o.posMatrix,o.posMatrix,[s*c,l*c,0]),t.K(o.posMatrix,o.posMatrix,[1/2**a,1/2**a,0]),r[n]=o}}return r}getSourceTile(e,t){const r=this.sourceCache._source;let n=e.overscaledZ-this.deltaZoom;if(n>r.maxzoom&&(n=r.maxzoom),n=r.minzoom&&(!i||!i.dem);)i=this.sourceCache.getTileByID(e.scaledTo(n--).key);return i}tilesAfterTime(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:Date.now();return Object.values(this._tiles).filter((t=>t.timeAdded>=e))}}class Ts{constructor(e,t,r){this.painter=e,this.sourceCache=new As(t),this.options=r,this.exaggeration="number"===typeof r.exaggeration?r.exaggeration:1,this.qualityFactor=2,this.meshSize=128,this._demMatrixCache={},this.coordsIndex=[],this._coordsTextureSize=1024}getDEMElevation(e,r,n){let i=arguments.length>3&&void 0!==arguments[3]?arguments[3]:t.X;var o;if(!(r>=0&&r=0&&n3&&void 0!==arguments[3]?arguments[3]:t.X;return this.getDEMElevation(e,r,n,i)*this.exaggeration}getTerrainData(e){if(!this._emptyDemTexture){const e=this.painter.context,r=new t.R({width:1,height:1},new Uint8Array(4));this._emptyDepthTexture=new F(e,r,e.gl.RGBA,{premultiply:!1}),this._emptyDemUnpack=[0,0,0,0],this._emptyDemTexture=new F(e,new t.R({width:1,height:1}),e.gl.RGBA,{premultiply:!1}),this._emptyDemTexture.bind(e.gl.NEAREST,e.gl.CLAMP_TO_EDGE),this._emptyDemMatrix=t.an([])}const r=this.sourceCache.getSourceTile(e,!0);if(r&&r.dem&&(!r.demTexture||r.needsTerrainPrepare)){const e=this.painter.context;r.demTexture=this.painter.getTileTexture(r.dem.stride),r.demTexture?r.demTexture.update(r.dem.getPixels(),{premultiply:!1}):r.demTexture=new F(e,r.dem.getPixels(),e.gl.RGBA,{premultiply:!1}),r.demTexture.bind(e.gl.NEAREST,e.gl.CLAMP_TO_EDGE),r.needsTerrainPrepare=!1}const n=r&&r+r.tileID.key+e.key;if(n&&!this._demMatrixCache[n]){const n=this.sourceCache.sourceCache._source.maxzoom;let i=e.canonical.z-r.tileID.canonical.z;e.overscaledZ>e.canonical.z&&(e.canonical.z>=n?i=e.canonical.z-n:t.w("cannot calculate elevation if elevation maxzoom > source.maxzoom"));const o=e.canonical.x-(e.canonical.x>>i<>i<>8<<4|t>>8,r[o+3]=0;const n=new t.R({width:this._coordsTextureSize,height:this._coordsTextureSize},new Uint8Array(r.buffer)),i=new F(e,n,e.gl.RGBA,{premultiply:!1});return i.bind(e.gl.NEAREST,e.gl.CLAMP_TO_EDGE),this._coordsTexture=i,i}pointCoordinate(e){this.painter.maybeDrawDepthAndCoords(!0);const r=new Uint8Array(4),n=this.painter.context,i=n.gl,o=Math.round(e.x*this.painter.pixelRatio/devicePixelRatio),a=Math.round(e.y*this.painter.pixelRatio/devicePixelRatio),s=Math.round(this.painter.height/devicePixelRatio);n.bindFramebuffer.set(this.getFramebuffer("coords").framebuffer),i.readPixels(o,s-a-1,1,1,i.RGBA,i.UNSIGNED_BYTE,r),n.bindFramebuffer.set(null);const l=r[0]+(r[2]>>4<<8),c=r[1]+((15&r[2])<<8),u=this.coordsIndex[255-r[3]],d=u&&this.sourceCache.getTileByID(u);if(!d)return null;const h=this._coordsTextureSize,p=(1<e.id!==t)),this._recentlyUsed.push(e.id)}stampObject(e){e.stamp=++this._stamp}getOrCreateFreeObject(){for(const t of this._recentlyUsed)if(!this._objects[t].inUse)return this._objects[t];if(this._objects.length>=this._size)throw new Error("No free RenderPool available, call freeAllObjects() required!");const e=this._createObject(this._objects.length);return this._objects.push(e),e}freeObject(e){e.inUse=!1}freeAllObjects(){for(const e of this._objects)this.freeObject(e)}isFull(){return!(this._objects.length!e.inUse))}}const Cs={background:!0,fill:!0,line:!0,raster:!0,hillshade:!0};class Es{constructor(e,t){this.painter=e,this.terrain=t,this.pool=new Ms(e.context,30,t.sourceCache.tileSize*t.qualityFactor)}destruct(){this.pool.destruct()}getTexture(e){return this.pool.getObjectForId(e.rtt[this._stacks.length-1].id).texture}prepareForRender(e,t){this._stacks=[],this._prevType=null,this._rttTiles=[],this._renderableTiles=this.terrain.sourceCache.getRenderableTiles(),this._renderableLayerIds=e._order.filter((r=>!e._layers[r].isHidden(t))),this._coordsDescendingInv={};for(const r in e.sourceCaches){this._coordsDescendingInv[r]={};const t=e.sourceCaches[r].getVisibleCoordinates();for(const e of t){const t=this.terrain.sourceCache.getTerrainCoords(e);for(const e in t)this._coordsDescendingInv[r][e]||(this._coordsDescendingInv[r][e]=[]),this._coordsDescendingInv[r][e].push(t[e])}}this._coordsDescendingInvStr={};for(const r of e._order){const t=e._layers[r],n=t.source;if(Cs[t.type]&&!this._coordsDescendingInvStr[n]){this._coordsDescendingInvStr[n]={};for(const e in this._coordsDescendingInv[n])this._coordsDescendingInvStr[n][e]=this._coordsDescendingInv[n][e].map((e=>e.key)).sort().join()}}for(const r of this._renderableTiles)for(const e in this._coordsDescendingInvStr){const t=this._coordsDescendingInvStr[e][r.tileID.key];t&&t!==r.rttCoords[e]&&(r.rtt=[])}}renderLayer(e){if(e.isHidden(this.painter.transform.zoom))return!1;const r=e.type,n=this.painter,i=this._renderableLayerIds[this._renderableLayerIds.length-1]===e.id;if(Cs[r]&&(this._prevType&&Cs[this._prevType]||this._stacks.push([]),this._prevType=r,this._stacks[this._stacks.length-1].push(e.id),!i))return!0;if(Cs[this._prevType]||Cs[r]&&i){this._prevType=r;const e=this._stacks.length-1,i=this._stacks[e]||[];for(const r of this._renderableTiles){if(this.pool.isFull()&&(Xo(this.painter,this.terrain,this._rttTiles),this._rttTiles=[],this.pool.freeAllObjects()),this._rttTiles.push(r),r.rtt[e]){const t=this.pool.getObjectForId(r.rtt[e].id);if(t.stamp===r.rtt[e].stamp){this.pool.useObject(t);continue}}const o=this.pool.getOrCreateFreeObject();this.pool.useObject(o),this.pool.stampObject(o),r.rtt[e]={id:o.id,stamp:o.stamp},n.context.bindFramebuffer.set(o.fbo.framebuffer),n.context.clear({color:t.aM.transparent,stencil:0}),n.currentStencilSource=void 0;for(let e=0;er.maxZoom)throw new Error("maxZoom must be greater than or equal to minZoom");if(null!=r.minPitch&&null!=r.maxPitch&&r.minPitch>r.maxPitch)throw new Error("maxPitch must be greater than or equal to minPitch");if(null!=r.minPitch&&r.minPitchzs)throw new Error(`maxPitch must be less than or equal to ${zs}`);if(super(new na(r.minZoom,r.maxZoom,r.minPitch,r.maxPitch,r.renderWorldCopies),{bearingSnap:r.bearingSnap}),this._idleTriggered=!1,this._crossFadingFactor=1,this._renderTaskQueue=new ks,this._controls=[],this._mapId=t.a4(),this._contextLost=e=>{e.preventDefault(),this._frameRequest&&(this._frameRequest.abort(),this._frameRequest=null),this.fire(new t.k("webglcontextlost",{originalEvent:e}))},this._contextRestored=e=>{this._setupPainter(),this.resize(),this._update(),this.fire(new t.k("webglcontextrestored",{originalEvent:e}))},this._onMapScroll=e=>{if(e.target===this._container)return this._container.scrollTop=0,this._container.scrollLeft=0,!1},this._onWindowOnline=()=>{this._update()},this._interactive=r.interactive,this._maxTileCacheSize=r.maxTileCacheSize,this._maxTileCacheZoomLevels=r.maxTileCacheZoomLevels,this._failIfMajorPerformanceCaveat=!0===r.failIfMajorPerformanceCaveat,this._preserveDrawingBuffer=!0===r.preserveDrawingBuffer,this._antialias=!0===r.antialias,this._trackResize=!0===r.trackResize,this._bearingSnap=r.bearingSnap,this._refreshExpiredTiles=!0===r.refreshExpiredTiles,this._fadeDuration=r.fadeDuration,this._crossSourceCollisions=!0===r.crossSourceCollisions,this._collectResourceTiming=!0===r.collectResourceTiming,this._locale=Object.assign(Object.assign({},Is),r.locale),this._clickTolerance=r.clickTolerance,this._overridePixelRatio=r.pixelRatio,this._maxCanvasSize=r.maxCanvasSize,this.transformCameraUpdate=r.transformCameraUpdate,this.cancelPendingTileRequestsWhileZooming=!0===r.cancelPendingTileRequestsWhileZooming,this._imageQueueHandle=f.addThrottleControl((()=>this.isMoving())),this._requestManager=new m(r.transformRequest),"string"===typeof r.container){if(this._container=document.getElementById(r.container),!this._container)throw new Error(`Container '${r.container}' not found.`)}else{if(!(r.container instanceof HTMLElement))throw new Error("Invalid type: 'container' must be a String or HTMLElement.");this._container=r.container}if(r.maxBounds&&this.setMaxBounds(r.maxBounds),this._setupContainer(),this._setupPainter(),this.on("move",(()=>this._update(!1))).on("moveend",(()=>this._update(!1))).on("zoom",(()=>this._update(!0))).on("terrain",(()=>{this.painter.terrainFacilitator.dirty=!0,this._update(!0)})).once("idle",(()=>{this._idleTriggered=!0})),"undefined"!==typeof window){addEventListener("online",this._onWindowOnline,!1);let e=!1;const t=ia((e=>{this._trackResize&&!this._removed&&(this.resize(e),this.redraw())}),50);this._resizeObserver=new ResizeObserver((r=>{e?t(r):e=!0})),this._resizeObserver.observe(this._container)}this.handlers=new vs(this,r);const n="string"===typeof r.hash&&r.hash||void 0;this._hash=r.hash&&new oa(n).addTo(this),this._hash&&this._hash._onHashChange()||(this.jumpTo({center:r.center,zoom:r.zoom,bearing:r.bearing,pitch:r.pitch}),r.bounds&&(this.resize(),this.fitBounds(r.bounds,t.e({},r.fitBoundsOptions,{duration:0})))),this.resize(),this._localIdeographFontFamily=r.localIdeographFontFamily,this._validateStyle=r.validateStyle,r.style&&this.setStyle(r.style,{localIdeographFontFamily:r.localIdeographFontFamily}),r.attributionControl&&this.addControl(new _s("boolean"===typeof r.attributionControl?void 0:r.attributionControl)),r.maplibreLogo&&this.addControl(new ws,r.logoPosition),this.on("style.load",(()=>{this.transform.unmodified&&this.jumpTo(this.style.stylesheet)})),this.on("data",(e=>{this._update("style"===e.dataType),this.fire(new t.k(`${e.dataType}data`,e))})),this.on("dataloading",(e=>{this.fire(new t.k(`${e.dataType}dataloading`,e))})),this.on("dataabort",(e=>{this.fire(new t.k("sourcedataabort",e))}))}_getMapId(){return this._mapId}addControl(e,r){if(void 0===r&&(r=e.getDefaultPosition?e.getDefaultPosition():"top-right"),!e||!e.onAdd)return this.fire(new t.j(new Error("Invalid argument to map.addControl(). Argument must be a control with onAdd and onRemove methods.")));const n=e.onAdd(this);this._controls.push(e);const i=this._controlPositions[r];return-1!==r.indexOf("bottom")?i.insertBefore(n,i.firstChild):i.appendChild(n),this}removeControl(e){if(!e||!e.onRemove)return this.fire(new t.j(new Error("Invalid argument to map.removeControl(). Argument must be a control with onAdd and onRemove methods.")));const r=this._controls.indexOf(e);return r>-1&&this._controls.splice(r,1),e.onRemove(this),this}hasControl(e){return this._controls.indexOf(e)>-1}calculateCameraOptionsFromTo(e,t,r,n){return null==n&&this.terrain&&(n=this.terrain.getElevationForLngLatZoom(r,this.transform.tileZoom)),super.calculateCameraOptionsFromTo(e,t,r,n)}resize(e){var r;const n=this._containerDimensions(),i=n[0],o=n[1],a=this._getClampedPixelRatio(i,o);if(this._resizeCanvas(i,o,a),this.painter.resize(i,o,a),this.painter.overLimit()){const e=this.painter.context.gl;this._maxCanvasSize=[e.drawingBufferWidth,e.drawingBufferHeight];const t=this._getClampedPixelRatio(i,o);this._resizeCanvas(i,o,t),this.painter.resize(i,o,t)}this.transform.resize(i,o),null===(r=this._requestedCameraState)||void 0===r||r.resize(i,o);const s=!this._moving;return s&&(this.stop(),this.fire(new t.k("movestart",e)).fire(new t.k("move",e))),this.fire(new t.k("resize",e)),s&&this.fire(new t.k("moveend",e)),this}_getClampedPixelRatio(e,t){const{0:r,1:n}=this._maxCanvasSize,i=this.getPixelRatio(),o=e*i,a=t*i,s=o>r?r/o:1,l=a>n?n/a:1;return Math.min(s,l)*i}getPixelRatio(){var e;return null!==(e=this._overridePixelRatio)&&void 0!==e?e:devicePixelRatio}setPixelRatio(e){this._overridePixelRatio=e,this.resize()}getBounds(){return this.transform.getBounds()}getMaxBounds(){return this.transform.getMaxBounds()}setMaxBounds(e){return this.transform.setMaxBounds(_e.convert(e)),this._update()}setMinZoom(e){if((e=null===e||void 0===e?Os:e)>=Os&&e<=this.transform.maxZoom)return this.transform.minZoom=e,this._update(),this.getZoom()=this.transform.minZoom)return this.transform.maxZoom=e,this._update(),this.getZoom()>e&&this.setZoom(e),this;throw new Error("maxZoom must be greater than the current minZoom")}getMaxZoom(){return this.transform.maxZoom}setMinPitch(e){if((e=null===e||void 0===e?Ls:e)=Ls&&e<=this.transform.maxPitch)return this.transform.minPitch=e,this._update(),this.getPitch()zs)throw new Error(`maxPitch must be less than or equal to ${zs}`);if(e>=this.transform.minPitch)return this.transform.maxPitch=e,this._update(),this.getPitch()>e&&this.setPitch(e),this;throw new Error("maxPitch must be greater than the current minPitch")}getMaxPitch(){return this.transform.maxPitch}getRenderWorldCopies(){return this.transform.renderWorldCopies}setRenderWorldCopies(e){return this.transform.renderWorldCopies=e,this._update()}project(e){return this.transform.locationPoint(t.N.convert(e),this.style&&this.terrain)}unproject(e){return this.transform.pointLocation(t.P.convert(e),this.terrain)}isMoving(){var e;return this._moving||(null===(e=this.handlers)||void 0===e?void 0:e.isMoving())}isZooming(){var e;return this._zooming||(null===(e=this.handlers)||void 0===e?void 0:e.isZooming())}isRotating(){var e;return this._rotating||(null===(e=this.handlers)||void 0===e?void 0:e.isRotating())}_createDelegatedListener(e,t,r){if("mouseenter"===e||"mouseover"===e){let n=!1;const i=i=>{const o=t.filter((e=>this.getLayer(e))),a=0!==o.length?this.queryRenderedFeatures(i.point,{layers:o}):[];a.length?n||(n=!0,r.call(this,new fa(e,this,i.originalEvent,{features:a}))):n=!1};return{layers:t,listener:r,delegates:{mousemove:i,mouseout:()=>{n=!1}}}}if("mouseleave"===e||"mouseout"===e){let n=!1;const i=i=>{const o=t.filter((e=>this.getLayer(e)));(0!==o.length?this.queryRenderedFeatures(i.point,{layers:o}):[]).length?n=!0:n&&(n=!1,r.call(this,new fa(e,this,i.originalEvent)))},o=t=>{n&&(n=!1,r.call(this,new fa(e,this,t.originalEvent)))};return{layers:t,listener:r,delegates:{mousemove:i,mouseout:o}}}{const n=e=>{const n=t.filter((e=>this.getLayer(e))),i=0!==n.length?this.queryRenderedFeatures(e.point,{layers:n}):[];i.length&&(e.features=i,r.call(this,e),delete e.features)};return{layers:t,listener:r,delegates:{[e]:n}}}}_saveDelegatedListener(e,t){this._delegatedListeners=this._delegatedListeners||{},this._delegatedListeners[e]=this._delegatedListeners[e]||[],this._delegatedListeners[e].push(t)}_removeDelegatedListener(e,t,r){if(!this._delegatedListeners||!this._delegatedListeners[e])return;const n=this._delegatedListeners[e];for(let i=0;it.includes(e)))){for(const t in e.delegates)this.off(t,e.delegates[t]);return void n.splice(i,1)}}}on(e,t,r){if(void 0===r)return super.on(e,t);const n="string"===typeof t?[t]:t,i=this._createDelegatedListener(e,n,r);this._saveDelegatedListener(e,i);for(const o in i.delegates)this.on(o,i.delegates[o]);return this}once(e,t,r){var n=this;if(void 0===r)return super.once(e,t);const i="string"===typeof t?[t]:t,o=this._createDelegatedListener(e,i,r);for(const a in o.delegates){const t=o.delegates[a];o.delegates[a]=function(){n._removeDelegatedListener(e,i,r),t(...arguments)}}this._saveDelegatedListener(e,o);for(const a in o.delegates)this.once(a,o.delegates[a]);return this}off(e,t,r){if(void 0===r)return super.off(e,t);const n="string"===typeof t?[t]:t;return this._removeDelegatedListener(e,n,r),this}queryRenderedFeatures(e,r){if(!this.style)return[];let n;const i=e instanceof t.P||Array.isArray(e),o=i?e:[[0,0],[this.transform.width,this.transform.height]];if(r=r||(i?{}:e)||{},o instanceof t.P||"number"===typeof o[0])n=[t.P.convert(o)];else{const e=t.P.convert(o[0]),r=t.P.convert(o[1]);n=[e,new t.P(r.x,e.y),r,new t.P(e.x,r.y),e]}return this.style.queryRenderedFeatures(n,r,this.transform)}querySourceFeatures(e,t){return this.style.querySourceFeatures(e,t)}setStyle(e,r){return!1!==(r=t.e({},{localIdeographFontFamily:this._localIdeographFontFamily,validate:this._validateStyle},r)).diff&&r.localIdeographFontFamily===this._localIdeographFontFamily&&this.style&&e?(this._diffStyle(e,r),this):(this._localIdeographFontFamily=r.localIdeographFontFamily,this._updateStyle(e,r))}setTransformRequest(e){return this._requestManager.setTransformRequest(e),this}_getUIString(e){const t=this._locale[e];if(null==t)throw new Error(`Missing UI string '${e}'`);return t}_updateStyle(e,t){if(t.transformStyle&&this.style&&!this.style._loaded)return void this.style.once("style.load",(()=>this._updateStyle(e,t)));const r=this.style&&t.transformStyle?this.style.serialize():void 0;return this.style&&(this.style.setEventedParent(null),this.style._remove(!e)),e?(this.style=new Kt(this,t||{}),this.style.setEventedParent(this,{style:this.style}),"string"===typeof e?this.style.loadURL(e,t,r):this.style.loadJSON(e,t,r),this):(delete this.style,this)}_lazyInitEmptyStyle(){this.style||(this.style=new Kt(this,{}),this.style.setEventedParent(this,{style:this.style}),this.style.loadEmpty())}_diffStyle(e,r){if("string"===typeof e){const n=e,i=this._requestManager.transformRequest(n,"Style");t.h(i,new AbortController).then((e=>{this._updateDiff(e.data,r)})).catch((e=>{e&&this.fire(new t.j(e))}))}else"object"===typeof e&&this._updateDiff(e,r)}_updateDiff(e,r){try{this.style.setState(e,r)&&this._update(!0)}catch(n){t.w(`Unable to perform style diff: ${n.message||n.error||n}. Rebuilding the style from scratch.`),this._updateStyle(e,r)}}getStyle(){if(this.style)return this.style.serialize()}isStyleLoaded(){return this.style?this.style.loaded():t.w("There is no style added to the map.")}addSource(e,t){return this._lazyInitEmptyStyle(),this.style.addSource(e,t),this._update(!0)}isSourceLoaded(e){const r=this.style&&this.style.sourceCaches[e];if(void 0!==r)return r.loaded();this.fire(new t.j(new Error(`There is no source with ID '${e}'`)))}setTerrain(e){if(this.style._checkLoaded(),this._terrainDataCallback&&this.style.off("data",this._terrainDataCallback),e){const r=this.style.sourceCaches[e.source];if(!r)throw new Error(`cannot load terrain, because there exists no source with ID: ${e.source}`);null===this.terrain&&r.reload();for(const n in this.style._layers){const r=this.style._layers[n];"hillshade"===r.type&&r.source===e.source&&t.w("You are using the same source for a hillshade layer and for 3D terrain. Please consider using two separate sources to improve rendering quality.")}this.terrain=new Ts(this.painter,r,e),this.painter.renderToTexture=new Es(this.painter,this.terrain),this.transform.minElevationForCurrentTile=this.terrain.getMinTileElevationForLngLatZoom(this.transform.center,this.transform.tileZoom),this.transform.elevation=this.terrain.getElevationForLngLatZoom(this.transform.center,this.transform.tileZoom),this._terrainDataCallback=t=>{"style"===t.dataType?this.terrain.sourceCache.freeRtt():"source"===t.dataType&&t.tile&&(t.sourceId!==e.source||this._elevationFreeze||(this.transform.minElevationForCurrentTile=this.terrain.getMinTileElevationForLngLatZoom(this.transform.center,this.transform.tileZoom),this.transform.elevation=this.terrain.getElevationForLngLatZoom(this.transform.center,this.transform.tileZoom)),this.terrain.sourceCache.freeRtt(t.tile.tileID))},this.style.on("data",this._terrainDataCallback)}else this.terrain&&this.terrain.sourceCache.destruct(),this.terrain=null,this.painter.renderToTexture&&this.painter.renderToTexture.destruct(),this.painter.renderToTexture=null,this.transform.minElevationForCurrentTile=0,this.transform.elevation=0;return this.fire(new t.k("terrain",{terrain:e})),this}getTerrain(){var e,t;return null!==(t=null===(e=this.terrain)||void 0===e?void 0:e.options)&&void 0!==t?t:null}areTilesLoaded(){const e=this.style&&this.style.sourceCaches;for(const t in e){const r=e[t]._tiles;for(const e in r){const t=r[e];if("loaded"!==t.state&&"errored"!==t.state)return!1}}return!0}removeSource(e){return this.style.removeSource(e),this._update(!0)}getSource(e){return this.style.getSource(e)}addImage(e,r){let n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};const{pixelRatio:i=1,sdf:a=!1,stretchX:s,stretchY:l,content:c,textFitWidth:u,textFitHeight:d}=n;this._lazyInitEmptyStyle();const h=0;if(!(r instanceof HTMLImageElement||t.b(r))){if(void 0===r.width||void 0===r.height)return this.fire(new t.j(new Error("Invalid arguments to map.addImage(). The second argument must be an `HTMLImageElement`, `ImageData`, `ImageBitmap`, or object with `width`, `height`, and `data` properties with the same format as `ImageData`")));{const{width:n,height:o,data:p}=r,f=r;return this.style.addImage(e,{data:new t.R({width:n,height:o},new Uint8Array(p)),pixelRatio:i,stretchX:s,stretchY:l,content:c,textFitWidth:u,textFitHeight:d,sdf:a,version:h,userImage:f}),f.onAdd&&f.onAdd(this,e),this}}{const{width:n,height:p,data:f}=o.getImageData(r);this.style.addImage(e,{data:new t.R({width:n,height:p},f),pixelRatio:i,stretchX:s,stretchY:l,content:c,textFitWidth:u,textFitHeight:d,sdf:a,version:h})}}updateImage(e,r){const n=this.style.getImage(e);if(!n)return this.fire(new t.j(new Error("The map has no image with that id. If you are adding a new image use `map.addImage(...)` instead.")));const i=r instanceof HTMLImageElement||t.b(r)?o.getImageData(r):r,{width:a,height:s,data:l}=i;if(void 0===a||void 0===s)return this.fire(new t.j(new Error("Invalid arguments to map.updateImage(). The second argument must be an `HTMLImageElement`, `ImageData`, `ImageBitmap`, or object with `width`, `height`, and `data` properties with the same format as `ImageData`")));if(a!==n.data.width||s!==n.data.height)return this.fire(new t.j(new Error("The width and height of the updated image must be that same as the previous version of the image")));const c=!(r instanceof HTMLImageElement||t.b(r));return n.data.replace(l,c),this.style.updateImage(e,n),this}getImage(e){return this.style.getImage(e)}hasImage(e){return e?!!this.style.getImage(e):(this.fire(new t.j(new Error("Missing required image id"))),!1)}removeImage(e){this.style.removeImage(e)}loadImage(e){return f.getImage(this._requestManager.transformRequest(e,"Image"),new AbortController)}listImages(){return this.style.listImages()}addLayer(e,t){return this._lazyInitEmptyStyle(),this.style.addLayer(e,t),this._update(!0)}moveLayer(e,t){return this.style.moveLayer(e,t),this._update(!0)}removeLayer(e){return this.style.removeLayer(e),this._update(!0)}getLayer(e){return this.style.getLayer(e)}getLayersOrder(){return this.style.getLayersOrder()}setLayerZoomRange(e,t,r){return this.style.setLayerZoomRange(e,t,r),this._update(!0)}setFilter(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};return this.style.setFilter(e,t,r),this._update(!0)}getFilter(e){return this.style.getFilter(e)}setPaintProperty(e,t,r){let n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};return this.style.setPaintProperty(e,t,r,n),this._update(!0)}getPaintProperty(e,t){return this.style.getPaintProperty(e,t)}setLayoutProperty(e,t,r){let n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};return this.style.setLayoutProperty(e,t,r,n),this._update(!0)}getLayoutProperty(e,t){return this.style.getLayoutProperty(e,t)}setGlyphs(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return this._lazyInitEmptyStyle(),this.style.setGlyphs(e,t),this._update(!0)}getGlyphs(){return this.style.getGlyphsUrl()}addSprite(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};return this._lazyInitEmptyStyle(),this.style.addSprite(e,t,r,(e=>{e||this._update(!0)})),this}removeSprite(e){return this._lazyInitEmptyStyle(),this.style.removeSprite(e),this._update(!0)}getSprite(){return this.style.getSprite()}setSprite(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return this._lazyInitEmptyStyle(),this.style.setSprite(e,t,(e=>{e||this._update(!0)})),this}setLight(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return this._lazyInitEmptyStyle(),this.style.setLight(e,t),this._update(!0)}getLight(){return this.style.getLight()}setSky(e){return this._lazyInitEmptyStyle(),this.style.setSky(e),this._update(!0)}getSky(){return this.style.getSky()}setFeatureState(e,t){return this.style.setFeatureState(e,t),this._update()}removeFeatureState(e,t){return this.style.removeFeatureState(e,t),this._update()}getFeatureState(e){return this.style.getFeatureState(e)}getContainer(){return this._container}getCanvasContainer(){return this._canvasContainer}getCanvas(){return this._canvas}_containerDimensions(){let e=0,t=0;return this._container&&(e=this._container.clientWidth||400,t=this._container.clientHeight||300),[e,t]}_setupContainer(){const e=this._container;e.classList.add("maplibregl-map");const t=this._canvasContainer=a.create("div","maplibregl-canvas-container",e);this._interactive&&t.classList.add("maplibregl-interactive"),this._canvas=a.create("canvas","maplibregl-canvas",t),this._canvas.addEventListener("webglcontextlost",this._contextLost,!1),this._canvas.addEventListener("webglcontextrestored",this._contextRestored,!1),this._canvas.setAttribute("tabindex",this._interactive?"0":"-1"),this._canvas.setAttribute("aria-label",this._getUIString("Map.Title")),this._canvas.setAttribute("role","region");const r=this._containerDimensions(),n=this._getClampedPixelRatio(r[0],r[1]);this._resizeCanvas(r[0],r[1],n);const i=this._controlContainer=a.create("div","maplibregl-control-container",e),o=this._controlPositions={};["top-left","top-right","bottom-left","bottom-right"].forEach((e=>{o[e]=a.create("div",`maplibregl-ctrl-${e} `,i)})),this._container.addEventListener("scroll",this._onMapScroll,!1)}_resizeCanvas(e,t,r){this._canvas.width=Math.floor(r*e),this._canvas.height=Math.floor(r*t),this._canvas.style.width=`${e}px`,this._canvas.style.height=`${t}px`}_setupPainter(){const e={alpha:!0,stencil:!0,depth:!0,failIfMajorPerformanceCaveat:this._failIfMajorPerformanceCaveat,preserveDrawingBuffer:this._preserveDrawingBuffer,antialias:this._antialias||!1};let t=null;this._canvas.addEventListener("webglcontextcreationerror",(r=>{t={requestedAttributes:e},r&&(t.statusMessage=r.statusMessage,t.type=r.type)}),{once:!0});const r=this._canvas.getContext("webgl2",e)||this._canvas.getContext("webgl",e);if(!r){const e="Failed to initialize WebGL";throw t?(t.message=e,new Error(JSON.stringify(t))):new Error(e)}this.painter=new Jo(r,this.transform),s.testSupport(r)}loaded(){return!this._styleDirty&&!this._sourcesDirty&&!!this.style&&this.style.loaded()}_update(e){return this.style&&this.style._loaded?(this._styleDirty=this._styleDirty||e,this._sourcesDirty=!0,this.triggerRepaint(),this):this}_requestRenderFrame(e){return this._update(),this._renderTaskQueue.add(e)}_cancelRenderFrame(e){this._renderTaskQueue.remove(e)}_render(e){const r=this._idleTriggered?this._fadeDuration:0;if(this.painter.context.setDirty(),this.painter.setBaseState(),this._renderTaskQueue.run(e),this._removed)return;let n=!1;if(this.style&&this._styleDirty){this._styleDirty=!1;const e=this.transform.zoom,i=o.now();this.style.zoomHistory.update(e,i);const a=new t.z(e,{now:i,fadeDuration:r,zoomHistory:this.style.zoomHistory,transition:this.style.getTransition()}),s=a.crossFadingFactor();1===s&&s===this._crossFadingFactor||(n=!0,this._crossFadingFactor=s),this.style.update(a)}this.style&&this._sourcesDirty&&(this._sourcesDirty=!1,this.style._updateSources(this.transform)),this.terrain?(this.terrain.sourceCache.update(this.transform,this.terrain),this.transform.minElevationForCurrentTile=this.terrain.getMinTileElevationForLngLatZoom(this.transform.center,this.transform.tileZoom),this._elevationFreeze||(this.transform.elevation=this.terrain.getElevationForLngLatZoom(this.transform.center,this.transform.tileZoom))):(this.transform.minElevationForCurrentTile=0,this.transform.elevation=0),this._placementDirty=this.style&&this.style._updatePlacement(this.painter.transform,this.showCollisionBoxes,r,this._crossSourceCollisions),this.painter.render(this.style,{showTileBoundaries:this.showTileBoundaries,showOverdrawInspector:this._showOverdrawInspector,rotating:this.isRotating(),zooming:this.isZooming(),moving:this.isMoving(),fadeDuration:r,showPadding:this.showPadding}),this.fire(new t.k("render")),this.loaded()&&!this._loaded&&(this._loaded=!0,t.bf.mark(t.bg.load),this.fire(new t.k("load"))),this.style&&(this.style.hasTransitions()||n)&&(this._styleDirty=!0),this.style&&!this._placementDirty&&this.style._releaseSymbolFadeTiles();const i=this._sourcesDirty||this._styleDirty||this._placementDirty;return i||this._repaint?this.triggerRepaint():!this.isMoving()&&this.loaded()&&this.fire(new t.k("idle")),!this._loaded||this._fullyLoaded||i||(this._fullyLoaded=!0,t.bf.mark(t.bg.fullLoad)),this}redraw(){return this.style&&(this._frameRequest&&(this._frameRequest.abort(),this._frameRequest=null),this._render(0)),this}remove(){var e;this._hash&&this._hash.remove();for(const t of this._controls)t.onRemove(this);this._controls=[],this._frameRequest&&(this._frameRequest.abort(),this._frameRequest=null),this._renderTaskQueue.clear(),this.painter.destroy(),this.handlers.destroy(),delete this.handlers,this.setStyle(null),"undefined"!==typeof window&&removeEventListener("online",this._onWindowOnline,!1),f.removeThrottleControl(this._imageQueueHandle),null===(e=this._resizeObserver)||void 0===e||e.disconnect();const r=this.painter.context.gl.getExtension("WEBGL_lose_context");(null===r||void 0===r?void 0:r.loseContext)&&r.loseContext(),this._canvas.removeEventListener("webglcontextrestored",this._contextRestored,!1),this._canvas.removeEventListener("webglcontextlost",this._contextLost,!1),a.remove(this._canvasContainer),a.remove(this._controlContainer),this._container.classList.remove("maplibregl-map"),t.bf.clearMetrics(),this._removed=!0,this.fire(new t.k("remove"))}triggerRepaint(){this.style&&!this._frameRequest&&(this._frameRequest=new AbortController,o.frameAsync(this._frameRequest).then((e=>{t.bf.frame(e),this._frameRequest=null,this._render(e)})).catch((()=>{})))}get showTileBoundaries(){return!!this._showTileBoundaries}set showTileBoundaries(e){this._showTileBoundaries!==e&&(this._showTileBoundaries=e,this._update())}get showPadding(){return!!this._showPadding}set showPadding(e){this._showPadding!==e&&(this._showPadding=e,this._update())}get showCollisionBoxes(){return!!this._showCollisionBoxes}set showCollisionBoxes(e){this._showCollisionBoxes!==e&&(this._showCollisionBoxes=e,e?this.style._generateCollisionBoxes():this._update())}get showOverdrawInspector(){return!!this._showOverdrawInspector}set showOverdrawInspector(e){this._showOverdrawInspector!==e&&(this._showOverdrawInspector=e,this._update())}get repaint(){return!!this._repaint}set repaint(e){this._repaint!==e&&(this._repaint=e,this.triggerRepaint())}get vertices(){return!!this._vertices}set vertices(e){this._vertices=e,this._update()}get version(){return Ps}getCameraTargetElevation(){return this.transform.elevation}};const Ns=e=>{e.touchstart=e.dragStart,e.touchmoveWindow=e.dragMove,e.touchend=e.dragEnd},Bs=e=>{let{enable:t,clickTolerance:r,bearingDegreesPerPixelMoved:n=.8}=e;const i=new Da;return new Ea({clickTolerance:r,move:(e,t)=>({bearingDelta:(t.x-e.x)*n}),moveStateManager:i,enable:t,assignEvents:Ns})},Vs=e=>{let{enable:t,clickTolerance:r,pitchDegreesPerPixelMoved:n=-.5}=e;const i=new Da;return new Ea({clickTolerance:r,move:(e,t)=>({pitchDelta:(t.y-e.y)*n}),moveStateManager:i,enable:t,assignEvents:Ns})},Us={showCompass:!0,showZoom:!0,visualizePitch:!1};class Hs{constructor(e){this._updateZoomButtons=()=>{const e=this._map.getZoom(),t=e===this._map.getMaxZoom(),r=e===this._map.getMinZoom();this._zoomInButton.disabled=t,this._zoomOutButton.disabled=r,this._zoomInButton.setAttribute("aria-disabled",t.toString()),this._zoomOutButton.setAttribute("aria-disabled",r.toString())},this._rotateCompassArrow=()=>{const e=this.options.visualizePitch?`scale(${1/Math.pow(Math.cos(this._map.transform.pitch*(Math.PI/180)),.5)}) rotateX(${this._map.transform.pitch}deg) rotateZ(${this._map.transform.angle*(180/Math.PI)}deg)`:`rotate(${this._map.transform.angle*(180/Math.PI)}deg)`;this._compassIcon.style.transform=e},this._setButtonTitle=(e,t)=>{const r=this._map._getUIString(`NavigationControl.${t}`);e.title=r,e.setAttribute("aria-label",r)},this.options=t.e({},Us,e),this._container=a.create("div","maplibregl-ctrl maplibregl-ctrl-group"),this._container.addEventListener("contextmenu",(e=>e.preventDefault())),this.options.showZoom&&(this._zoomInButton=this._createButton("maplibregl-ctrl-zoom-in",(e=>this._map.zoomIn({},{originalEvent:e}))),a.create("span","maplibregl-ctrl-icon",this._zoomInButton).setAttribute("aria-hidden","true"),this._zoomOutButton=this._createButton("maplibregl-ctrl-zoom-out",(e=>this._map.zoomOut({},{originalEvent:e}))),a.create("span","maplibregl-ctrl-icon",this._zoomOutButton).setAttribute("aria-hidden","true")),this.options.showCompass&&(this._compass=this._createButton("maplibregl-ctrl-compass",(e=>{this.options.visualizePitch?this._map.resetNorthPitch({},{originalEvent:e}):this._map.resetNorth({},{originalEvent:e})})),this._compassIcon=a.create("span","maplibregl-ctrl-icon",this._compass),this._compassIcon.setAttribute("aria-hidden","true"))}onAdd(e){return this._map=e,this.options.showZoom&&(this._setButtonTitle(this._zoomInButton,"ZoomIn"),this._setButtonTitle(this._zoomOutButton,"ZoomOut"),this._map.on("zoom",this._updateZoomButtons),this._updateZoomButtons()),this.options.showCompass&&(this._setButtonTitle(this._compass,"ResetBearing"),this.options.visualizePitch&&this._map.on("pitch",this._rotateCompassArrow),this._map.on("rotate",this._rotateCompassArrow),this._rotateCompassArrow(),this._handler=new $s(this._map,this._compass,this.options.visualizePitch)),this._container}onRemove(){a.remove(this._container),this.options.showZoom&&this._map.off("zoom",this._updateZoomButtons),this.options.showCompass&&(this.options.visualizePitch&&this._map.off("pitch",this._rotateCompassArrow),this._map.off("rotate",this._rotateCompassArrow),this._handler.off(),delete this._handler),delete this._map}_createButton(e,t){const r=a.create("button",e,this._container);return r.type="button",r.addEventListener("click",t),r}}class $s{constructor(e,r){let n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];this.mousedown=e=>{this.startMouse(t.e({},e,{ctrlKey:!0,preventDefault:()=>e.preventDefault()}),a.mousePos(this.element,e)),a.addEventListener(window,"mousemove",this.mousemove),a.addEventListener(window,"mouseup",this.mouseup)},this.mousemove=e=>{this.moveMouse(e,a.mousePos(this.element,e))},this.mouseup=e=>{this.mouseRotate.dragEnd(e),this.mousePitch&&this.mousePitch.dragEnd(e),this.offTemp()},this.touchstart=e=>{1!==e.targetTouches.length?this.reset():(this._startPos=this._lastPos=a.touchPos(this.element,e.targetTouches)[0],this.startTouch(e,this._startPos),a.addEventListener(window,"touchmove",this.touchmove,{passive:!1}),a.addEventListener(window,"touchend",this.touchend))},this.touchmove=e=>{1!==e.targetTouches.length?this.reset():(this._lastPos=a.touchPos(this.element,e.targetTouches)[0],this.moveTouch(e,this._lastPos))},this.touchend=e=>{0===e.targetTouches.length&&this._startPos&&this._lastPos&&this._startPos.dist(this._lastPos){this.mouseRotate.reset(),this.mousePitch&&this.mousePitch.reset(),this.touchRotate.reset(),this.touchPitch&&this.touchPitch.reset(),delete this._startPos,delete this._lastPos,this.offTemp()},this._clickTolerance=10;const i=e.dragRotate._mouseRotate.getClickTolerance(),o=e.dragRotate._mousePitch.getClickTolerance();this.element=r,this.mouseRotate=Ba({clickTolerance:i,enable:!0}),this.touchRotate=Bs({clickTolerance:i,enable:!0}),this.map=e,n&&(this.mousePitch=Va({clickTolerance:o,enable:!0}),this.touchPitch=Vs({clickTolerance:o,enable:!0})),a.addEventListener(r,"mousedown",this.mousedown),a.addEventListener(r,"touchstart",this.touchstart,{passive:!1}),a.addEventListener(r,"touchcancel",this.reset)}startMouse(e,t){this.mouseRotate.dragStart(e,t),this.mousePitch&&this.mousePitch.dragStart(e,t),a.disableDrag()}startTouch(e,t){this.touchRotate.dragStart(e,t),this.touchPitch&&this.touchPitch.dragStart(e,t),a.disableDrag()}moveMouse(e,t){const r=this.map,{bearingDelta:n}=this.mouseRotate.dragMove(e,t)||{};if(n&&r.setBearing(r.getBearing()+n),this.mousePitch){const{pitchDelta:n}=this.mousePitch.dragMove(e,t)||{};n&&r.setPitch(r.getPitch()+n)}}moveTouch(e,t){const r=this.map,{bearingDelta:n}=this.touchRotate.dragMove(e,t)||{};if(n&&r.setBearing(r.getBearing()+n),this.touchPitch){const{pitchDelta:n}=this.touchPitch.dragMove(e,t)||{};n&&r.setPitch(r.getPitch()+n)}}off(){const e=this.element;a.removeEventListener(e,"mousedown",this.mousedown),a.removeEventListener(e,"touchstart",this.touchstart,{passive:!1}),a.removeEventListener(window,"touchmove",this.touchmove,{passive:!1}),a.removeEventListener(window,"touchend",this.touchend),a.removeEventListener(e,"touchcancel",this.reset),this.offTemp()}offTemp(){a.enableDrag(),a.removeEventListener(window,"mousemove",this.mousemove),a.removeEventListener(window,"mouseup",this.mouseup),a.removeEventListener(window,"touchmove",this.touchmove,{passive:!1}),a.removeEventListener(window,"touchend",this.touchend)}}let Ws;function qs(){return t._(this,arguments,void 0,(function(){let e=arguments.length>0&&void 0!==arguments[0]&&arguments[0];return function*(){if(void 0!==Ws&&!e)return Ws;if(void 0===window.navigator.permissions)return Ws=!!window.navigator.geolocation,Ws;try{const e=yield window.navigator.permissions.query({name:"geolocation"});Ws="denied"!==e.state}catch(t){Ws=!!window.navigator.geolocation}return Ws}()}))}function Gs(e,r,n){const i=new t.N(e.lng,e.lat);if(e=new t.N(e.lng,e.lat),r){const i=new t.N(e.lng-360,e.lat),o=new t.N(e.lng+360,e.lat),a=n.locationPoint(e).distSqr(r);n.locationPoint(i).distSqr(r)180;){const t=n.locationPoint(e);if(t.x>=0&&t.y>=0&&t.x<=n.width&&t.y<=n.height)break;e.lng>n.center.lng?e.lng-=360:e.lng+=360}return e.lng!==i.lng&&n.locationPoint(e).y>n.height/2-n.getHorizon()?e:i}const Ys={center:"translate(-50%,-50%)",top:"translate(-50%,0)","top-left":"translate(0,0)","top-right":"translate(-100%,0)",bottom:"translate(-50%,-100%)","bottom-left":"translate(0,-100%)","bottom-right":"translate(-100%,-100%)",left:"translate(0,-50%)",right:"translate(-100%,-50%)"};function Xs(e,t,r){const n=e.classList;for(const i in Ys)n.remove(`maplibregl-${r}-anchor-${i}`);n.add(`maplibregl-${r}-anchor-${t}`)}class Zs extends t.E{constructor(e){if(super(),this._onKeyPress=e=>{const t=e.code,r=e.charCode||e.keyCode;"Space"!==t&&"Enter"!==t&&32!==r&&13!==r||this.togglePopup()},this._onMapClick=e=>{const t=e.originalEvent.target,r=this._element;this._popup&&(t===r||r.contains(t))&&this.togglePopup()},this._update=e=>{var t;if(!this._map)return;const r=this._map.loaded()&&!this._map.isMoving();("terrain"===(null===e||void 0===e?void 0:e.type)||"render"===(null===e||void 0===e?void 0:e.type)&&!r)&&this._map.once("render",this._update),this._map.transform.renderWorldCopies?this._lngLat=Gs(this._lngLat,this._flatPos,this._map.transform):this._lngLat=null===(t=this._lngLat)||void 0===t?void 0:t.wrap(),this._flatPos=this._pos=this._map.project(this._lngLat)._add(this._offset),this._map.terrain&&(this._flatPos=this._map.transform.locationPoint(this._lngLat)._add(this._offset));let n="";"viewport"===this._rotationAlignment||"auto"===this._rotationAlignment?n=`rotateZ(${this._rotation}deg)`:"map"===this._rotationAlignment&&(n=`rotateZ(${this._rotation-this._map.getBearing()}deg)`);let i="";"viewport"===this._pitchAlignment||"auto"===this._pitchAlignment?i="rotateX(0deg)":"map"===this._pitchAlignment&&(i=`rotateX(${this._map.getPitch()}deg)`),this._subpixelPositioning||e&&"moveend"!==e.type||(this._pos=this._pos.round()),a.setTransform(this._element,`${Ys[this._anchor]} translate(${this._pos.x}px, ${this._pos.y}px) ${i} ${n}`),o.frameAsync(new AbortController).then((()=>{this._updateOpacity(e&&"moveend"===e.type)})).catch((()=>{}))},this._onMove=e=>{if(!this._isDragging){const t=this._clickTolerance||this._map._clickTolerance;this._isDragging=e.point.dist(this._pointerdownPos)>=t}this._isDragging&&(this._pos=e.point.sub(this._positionDelta),this._lngLat=this._map.unproject(this._pos),this.setLngLat(this._lngLat),this._element.style.pointerEvents="none","pending"===this._state&&(this._state="active",this.fire(new t.k("dragstart"))),this.fire(new t.k("drag")))},this._onUp=()=>{this._element.style.pointerEvents="auto",this._positionDelta=null,this._pointerdownPos=null,this._isDragging=!1,this._map.off("mousemove",this._onMove),this._map.off("touchmove",this._onMove),"active"===this._state&&this.fire(new t.k("dragend")),this._state="inactive"},this._addDragHandler=e=>{this._element.contains(e.originalEvent.target)&&(e.preventDefault(),this._positionDelta=e.point.sub(this._pos).add(this._offset),this._pointerdownPos=e.point,this._state="pending",this._map.on("mousemove",this._onMove),this._map.on("touchmove",this._onMove),this._map.once("mouseup",this._onUp),this._map.once("touchend",this._onUp))},this._anchor=e&&e.anchor||"center",this._color=e&&e.color||"#3FB1CE",this._scale=e&&e.scale||1,this._draggable=e&&e.draggable||!1,this._clickTolerance=e&&e.clickTolerance||0,this._subpixelPositioning=e&&e.subpixelPositioning||!1,this._isDragging=!1,this._state="inactive",this._rotation=e&&e.rotation||0,this._rotationAlignment=e&&e.rotationAlignment||"auto",this._pitchAlignment=e&&e.pitchAlignment&&"auto"!==e.pitchAlignment?e.pitchAlignment:this._rotationAlignment,this.setOpacity(),this.setOpacity(null===e||void 0===e?void 0:e.opacity,null===e||void 0===e?void 0:e.opacityWhenCovered),e&&e.element)this._element=e.element,this._offset=t.P.convert(e&&e.offset||[0,0]);else{this._defaultMarker=!0,this._element=a.create("div");const r=a.createNS("http://www.w3.org/2000/svg","svg"),n=41,i=27;r.setAttributeNS(null,"display","block"),r.setAttributeNS(null,"height",`${n}px`),r.setAttributeNS(null,"width",`${i}px`),r.setAttributeNS(null,"viewBox",`0 0 ${i} ${n}`);const o=a.createNS("http://www.w3.org/2000/svg","g");o.setAttributeNS(null,"stroke","none"),o.setAttributeNS(null,"stroke-width","1"),o.setAttributeNS(null,"fill","none"),o.setAttributeNS(null,"fill-rule","evenodd");const s=a.createNS("http://www.w3.org/2000/svg","g");s.setAttributeNS(null,"fill-rule","nonzero");const l=a.createNS("http://www.w3.org/2000/svg","g");l.setAttributeNS(null,"transform","translate(3.0, 29.0)"),l.setAttributeNS(null,"fill","#000000");const c=[{rx:"10.5",ry:"5.25002273"},{rx:"10.5",ry:"5.25002273"},{rx:"9.5",ry:"4.77275007"},{rx:"8.5",ry:"4.29549936"},{rx:"7.5",ry:"3.81822308"},{rx:"6.5",ry:"3.34094679"},{rx:"5.5",ry:"2.86367051"},{rx:"4.5",ry:"2.38636864"}];for(const e of c){const t=a.createNS("http://www.w3.org/2000/svg","ellipse");t.setAttributeNS(null,"opacity","0.04"),t.setAttributeNS(null,"cx","10.5"),t.setAttributeNS(null,"cy","5.80029008"),t.setAttributeNS(null,"rx",e.rx),t.setAttributeNS(null,"ry",e.ry),l.appendChild(t)}const u=a.createNS("http://www.w3.org/2000/svg","g");u.setAttributeNS(null,"fill",this._color);const d=a.createNS("http://www.w3.org/2000/svg","path");d.setAttributeNS(null,"d","M27,13.5 C27,19.074644 20.250001,27.000002 14.75,34.500002 C14.016665,35.500004 12.983335,35.500004 12.25,34.500002 C6.7499993,27.000002 0,19.222562 0,13.5 C0,6.0441559 6.0441559,0 13.5,0 C20.955844,0 27,6.0441559 27,13.5 Z"),u.appendChild(d);const h=a.createNS("http://www.w3.org/2000/svg","g");h.setAttributeNS(null,"opacity","0.25"),h.setAttributeNS(null,"fill","#000000");const p=a.createNS("http://www.w3.org/2000/svg","path");p.setAttributeNS(null,"d","M13.5,0 C6.0441559,0 0,6.0441559 0,13.5 C0,19.222562 6.7499993,27 12.25,34.5 C13,35.522727 14.016664,35.500004 14.75,34.5 C20.250001,27 27,19.074644 27,13.5 C27,6.0441559 20.955844,0 13.5,0 Z M13.5,1 C20.415404,1 26,6.584596 26,13.5 C26,15.898657 24.495584,19.181431 22.220703,22.738281 C19.945823,26.295132 16.705119,30.142167 13.943359,33.908203 C13.743445,34.180814 13.612715,34.322738 13.5,34.441406 C13.387285,34.322738 13.256555,34.180814 13.056641,33.908203 C10.284481,30.127985 7.4148684,26.314159 5.015625,22.773438 C2.6163816,19.232715 1,15.953538 1,13.5 C1,6.584596 6.584596,1 13.5,1 Z"),h.appendChild(p);const f=a.createNS("http://www.w3.org/2000/svg","g");f.setAttributeNS(null,"transform","translate(6.0, 7.0)"),f.setAttributeNS(null,"fill","#FFFFFF");const m=a.createNS("http://www.w3.org/2000/svg","g");m.setAttributeNS(null,"transform","translate(8.0, 8.0)");const g=a.createNS("http://www.w3.org/2000/svg","circle");g.setAttributeNS(null,"fill","#000000"),g.setAttributeNS(null,"opacity","0.25"),g.setAttributeNS(null,"cx","5.5"),g.setAttributeNS(null,"cy","5.5"),g.setAttributeNS(null,"r","5.4999962");const y=a.createNS("http://www.w3.org/2000/svg","circle");y.setAttributeNS(null,"fill","#FFFFFF"),y.setAttributeNS(null,"cx","5.5"),y.setAttributeNS(null,"cy","5.5"),y.setAttributeNS(null,"r","5.4999962"),m.appendChild(g),m.appendChild(y),s.appendChild(l),s.appendChild(u),s.appendChild(h),s.appendChild(f),s.appendChild(m),r.appendChild(s),r.setAttributeNS(null,"height",n*this._scale+"px"),r.setAttributeNS(null,"width",i*this._scale+"px"),this._element.appendChild(r),this._offset=t.P.convert(e&&e.offset||[0,-14])}if(this._element.classList.add("maplibregl-marker"),this._element.addEventListener("dragstart",(e=>{e.preventDefault()})),this._element.addEventListener("mousedown",(e=>{e.preventDefault()})),Xs(this._element,this._anchor,"marker"),e&&e.className)for(const t of e.className.split(" "))this._element.classList.add(t);this._popup=null}addTo(e){return this.remove(),this._map=e,this._element.setAttribute("aria-label",e._getUIString("Marker.Title")),e.getCanvasContainer().appendChild(this._element),e.on("move",this._update),e.on("moveend",this._update),e.on("terrain",this._update),this.setDraggable(this._draggable),this._update(),this._map.on("click",this._onMapClick),this}remove(){return this._opacityTimeout&&(clearTimeout(this._opacityTimeout),delete this._opacityTimeout),this._map&&(this._map.off("click",this._onMapClick),this._map.off("move",this._update),this._map.off("moveend",this._update),this._map.off("terrain",this._update),this._map.off("mousedown",this._addDragHandler),this._map.off("touchstart",this._addDragHandler),this._map.off("mouseup",this._onUp),this._map.off("touchend",this._onUp),this._map.off("mousemove",this._onMove),this._map.off("touchmove",this._onMove),delete this._map),a.remove(this._element),this._popup&&this._popup.remove(),this}getLngLat(){return this._lngLat}setLngLat(e){return this._lngLat=t.N.convert(e),this._pos=null,this._popup&&this._popup.setLngLat(this._lngLat),this._update(),this}getElement(){return this._element}setPopup(e){if(this._popup&&(this._popup.remove(),this._popup=null,this._element.removeEventListener("keypress",this._onKeyPress),this._originalTabIndex||this._element.removeAttribute("tabindex")),e){if(!("offset"in e.options)){const t=38.1,r=13.5,n=Math.abs(r)/Math.SQRT2;e.options.offset=this._defaultMarker?{top:[0,0],"top-left":[0,0],"top-right":[0,0],bottom:[0,-t],"bottom-left":[n,-1*(t-r+n)],"bottom-right":[-n,-1*(t-r+n)],left:[r,-1*(t-r)],right:[-r,-1*(t-r)]}:this._offset}this._popup=e,this._originalTabIndex=this._element.getAttribute("tabindex"),this._originalTabIndex||this._element.setAttribute("tabindex","0"),this._element.addEventListener("keypress",this._onKeyPress)}return this}setSubpixelPositioning(e){return this._subpixelPositioning=e,this}getPopup(){return this._popup}togglePopup(){const e=this._popup;return this._element.style.opacity===this._opacityWhenCovered?this:e?(e.isOpen()?e.remove():(e.setLngLat(this._lngLat),e.addTo(this._map)),this):this}_updateOpacity(){let e=arguments.length>0&&void 0!==arguments[0]&&arguments[0];var r,n;if(!(null===(r=this._map)||void 0===r?void 0:r.terrain))return void(this._element.style.opacity!==this._opacity&&(this._element.style.opacity=this._opacity));if(e)this._opacityTimeout=null;else{if(this._opacityTimeout)return;this._opacityTimeout=setTimeout((()=>{this._opacityTimeout=null}),100)}const i=this._map,o=i.terrain.depthAtPoint(this._pos),a=i.terrain.getElevationForLngLatZoom(this._lngLat,i.transform.tileZoom),s=.006;if(i.transform.lngLatToCameraDepth(this._lngLat,a)-os;(null===(n=this._popup)||void 0===n?void 0:n.isOpen())&&d&&this._popup.remove(),this._element.style.opacity=d?this._opacityWhenCovered:this._opacity}getOffset(){return this._offset}setOffset(e){return this._offset=t.P.convert(e),this._update(),this}addClassName(e){this._element.classList.add(e)}removeClassName(e){this._element.classList.remove(e)}toggleClassName(e){return this._element.classList.toggle(e)}setDraggable(e){return this._draggable=!!e,this._map&&(e?(this._map.on("mousedown",this._addDragHandler),this._map.on("touchstart",this._addDragHandler)):(this._map.off("mousedown",this._addDragHandler),this._map.off("touchstart",this._addDragHandler))),this}isDraggable(){return this._draggable}setRotation(e){return this._rotation=e||0,this._update(),this}getRotation(){return this._rotation}setRotationAlignment(e){return this._rotationAlignment=e||"auto",this._update(),this}getRotationAlignment(){return this._rotationAlignment}setPitchAlignment(e){return this._pitchAlignment=e&&"auto"!==e?e:this._rotationAlignment,this._update(),this}getPitchAlignment(){return this._pitchAlignment}setOpacity(e,t){return void 0===e&&void 0===t&&(this._opacity="1",this._opacityWhenCovered="0.2"),void 0!==e&&(this._opacity=e),void 0!==t&&(this._opacityWhenCovered=t),this._map&&this._updateOpacity(!0),this}}const Ks={positionOptions:{enableHighAccuracy:!1,maximumAge:0,timeout:6e3},fitBoundsOptions:{maxZoom:15},trackUserLocation:!1,showAccuracyCircle:!0,showUserLocation:!0};let Js=0,Qs=!1;class el extends t.E{constructor(e){super(),this._onSuccess=e=>{if(this._map){if(this._isOutOfMapMaxBounds(e))return this._setErrorState(),this.fire(new t.k("outofmaxbounds",e)),this._updateMarker(),void this._finish();if(this.options.trackUserLocation)switch(this._lastKnownPosition=e,this._watchState){case"WAITING_ACTIVE":case"ACTIVE_LOCK":case"ACTIVE_ERROR":this._watchState="ACTIVE_LOCK",this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-waiting"),this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active-error"),this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-active");break;case"BACKGROUND":case"BACKGROUND_ERROR":this._watchState="BACKGROUND",this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-waiting"),this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-background-error"),this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-background");break;default:throw new Error(`Unexpected watchState ${this._watchState}`)}this.options.showUserLocation&&"OFF"!==this._watchState&&this._updateMarker(e),this.options.trackUserLocation&&"ACTIVE_LOCK"!==this._watchState||this._updateCamera(e),this.options.showUserLocation&&this._dotElement.classList.remove("maplibregl-user-location-dot-stale"),this.fire(new t.k("geolocate",e)),this._finish()}},this._updateCamera=e=>{const r=new t.N(e.coords.longitude,e.coords.latitude),n=e.coords.accuracy,i=this._map.getBearing(),o=t.e({bearing:i},this.options.fitBoundsOptions),a=_e.fromLngLat(r,n);this._map.fitBounds(a,o,{geolocateSource:!0})},this._updateMarker=e=>{if(e){const r=new t.N(e.coords.longitude,e.coords.latitude);this._accuracyCircleMarker.setLngLat(r).addTo(this._map),this._userLocationDotMarker.setLngLat(r).addTo(this._map),this._accuracy=e.coords.accuracy,this.options.showUserLocation&&this.options.showAccuracyCircle&&this._updateCircleRadius()}else this._userLocationDotMarker.remove(),this._accuracyCircleMarker.remove()},this._onZoom=()=>{this.options.showUserLocation&&this.options.showAccuracyCircle&&this._updateCircleRadius()},this._onError=e=>{if(this._map){if(this.options.trackUserLocation)if(1===e.code){this._watchState="OFF",this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-waiting"),this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active"),this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active-error"),this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-background"),this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-background-error"),this._geolocateButton.disabled=!0;const e=this._map._getUIString("GeolocateControl.LocationNotAvailable");this._geolocateButton.title=e,this._geolocateButton.setAttribute("aria-label",e),void 0!==this._geolocationWatchID&&this._clearWatch()}else{if(3===e.code&&Qs)return;this._setErrorState()}"OFF"!==this._watchState&&this.options.showUserLocation&&this._dotElement.classList.add("maplibregl-user-location-dot-stale"),this.fire(new t.k("error",e)),this._finish()}},this._finish=()=>{this._timeoutId&&clearTimeout(this._timeoutId),this._timeoutId=void 0},this._setupUI=()=>{this._map&&(this._container.addEventListener("contextmenu",(e=>e.preventDefault())),this._geolocateButton=a.create("button","maplibregl-ctrl-geolocate",this._container),a.create("span","maplibregl-ctrl-icon",this._geolocateButton).setAttribute("aria-hidden","true"),this._geolocateButton.type="button",this._geolocateButton.disabled=!0)},this._finishSetupUI=e=>{if(this._map){if(!1===e){t.w("Geolocation support is not available so the GeolocateControl will be disabled.");const e=this._map._getUIString("GeolocateControl.LocationNotAvailable");this._geolocateButton.disabled=!0,this._geolocateButton.title=e,this._geolocateButton.setAttribute("aria-label",e)}else{const e=this._map._getUIString("GeolocateControl.FindMyLocation");this._geolocateButton.disabled=!1,this._geolocateButton.title=e,this._geolocateButton.setAttribute("aria-label",e)}this.options.trackUserLocation&&(this._geolocateButton.setAttribute("aria-pressed","false"),this._watchState="OFF"),this.options.showUserLocation&&(this._dotElement=a.create("div","maplibregl-user-location-dot"),this._userLocationDotMarker=new Zs({element:this._dotElement}),this._circleElement=a.create("div","maplibregl-user-location-accuracy-circle"),this._accuracyCircleMarker=new Zs({element:this._circleElement,pitchAlignment:"map"}),this.options.trackUserLocation&&(this._watchState="OFF"),this._map.on("zoom",this._onZoom)),this._geolocateButton.addEventListener("click",(()=>this.trigger())),this._setup=!0,this.options.trackUserLocation&&this._map.on("movestart",(e=>{const r=e.originalEvent&&"resize"===e.originalEvent.type;e.geolocateSource||"ACTIVE_LOCK"!==this._watchState||r||(this._watchState="BACKGROUND",this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-background"),this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active"),this.fire(new t.k("trackuserlocationend")),this.fire(new t.k("userlocationlostfocus")))}))}},this.options=t.e({},Ks,e)}onAdd(e){return this._map=e,this._container=a.create("div","maplibregl-ctrl maplibregl-ctrl-group"),this._setupUI(),qs().then((e=>this._finishSetupUI(e))),this._container}onRemove(){void 0!==this._geolocationWatchID&&(window.navigator.geolocation.clearWatch(this._geolocationWatchID),this._geolocationWatchID=void 0),this.options.showUserLocation&&this._userLocationDotMarker&&this._userLocationDotMarker.remove(),this.options.showAccuracyCircle&&this._accuracyCircleMarker&&this._accuracyCircleMarker.remove(),a.remove(this._container),this._map.off("zoom",this._onZoom),this._map=void 0,Js=0,Qs=!1}_isOutOfMapMaxBounds(e){const t=this._map.getMaxBounds(),r=e.coords;return t&&(r.longitudet.getEast()||r.latitudet.getNorth())}_setErrorState(){switch(this._watchState){case"WAITING_ACTIVE":this._watchState="ACTIVE_ERROR",this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active"),this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-active-error");break;case"ACTIVE_LOCK":this._watchState="ACTIVE_ERROR",this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active"),this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-active-error"),this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-waiting");break;case"BACKGROUND":this._watchState="BACKGROUND_ERROR",this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-background"),this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-background-error"),this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-waiting");break;case"ACTIVE_ERROR":break;default:throw new Error(`Unexpected watchState ${this._watchState}`)}}_updateCircleRadius(){const e=this._map.getBounds(),t=e.getSouthEast(),r=e.getNorthEast(),n=t.distanceTo(r),i=this._map._container.clientHeight,o=Math.ceil(this._accuracy/(n/i)*2);this._circleElement.style.width=`${o}px`,this._circleElement.style.height=`${o}px`}trigger(){if(!this._setup)return t.w("Geolocate control triggered before added to a map"),!1;if(this.options.trackUserLocation){switch(this._watchState){case"OFF":this._watchState="WAITING_ACTIVE",this.fire(new t.k("trackuserlocationstart"));break;case"WAITING_ACTIVE":case"ACTIVE_LOCK":case"ACTIVE_ERROR":case"BACKGROUND_ERROR":Js--,Qs=!1,this._watchState="OFF",this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-waiting"),this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active"),this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active-error"),this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-background"),this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-background-error"),this.fire(new t.k("trackuserlocationend"));break;case"BACKGROUND":this._watchState="ACTIVE_LOCK",this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-background"),this._lastKnownPosition&&this._updateCamera(this._lastKnownPosition),this.fire(new t.k("trackuserlocationstart")),this.fire(new t.k("userlocationfocus"));break;default:throw new Error(`Unexpected watchState ${this._watchState}`)}switch(this._watchState){case"WAITING_ACTIVE":this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-waiting"),this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-active");break;case"ACTIVE_LOCK":this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-active");break;case"OFF":break;default:throw new Error(`Unexpected watchState ${this._watchState}`)}if("OFF"===this._watchState&&void 0!==this._geolocationWatchID)this._clearWatch();else if(void 0===this._geolocationWatchID){let e;this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-waiting"),this._geolocateButton.setAttribute("aria-pressed","true"),Js++,Js>1?(e={maximumAge:6e5,timeout:0},Qs=!0):(e=this.options.positionOptions,Qs=!1),this._geolocationWatchID=window.navigator.geolocation.watchPosition(this._onSuccess,this._onError,e)}}else window.navigator.geolocation.getCurrentPosition(this._onSuccess,this._onError,this.options.positionOptions),this._timeoutId=setTimeout(this._finish,1e4);return!0}_clearWatch(){window.navigator.geolocation.clearWatch(this._geolocationWatchID),this._geolocationWatchID=void 0,this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-waiting"),this._geolocateButton.setAttribute("aria-pressed","false"),this.options.showUserLocation&&this._updateMarker(null)}}const tl={maxWidth:100,unit:"metric"};class rl{constructor(e){this._onMove=()=>{nl(this._map,this._container,this.options)},this.setUnit=e=>{this.options.unit=e,nl(this._map,this._container,this.options)},this.options=Object.assign(Object.assign({},tl),e)}getDefaultPosition(){return"bottom-left"}onAdd(e){return this._map=e,this._container=a.create("div","maplibregl-ctrl maplibregl-ctrl-scale",e.getContainer()),this._map.on("move",this._onMove),this._onMove(),this._container}onRemove(){a.remove(this._container),this._map.off("move",this._onMove),this._map=void 0}}function nl(e,t,r){const n=r&&r.maxWidth||100,i=e._container.clientHeight/2,o=e.unproject([0,i]),a=e.unproject([n,i]),s=o.distanceTo(a);if(r&&"imperial"===r.unit){const r=3.2808*s;r>5280?il(t,n,r/5280,e._getUIString("ScaleControl.Miles")):il(t,n,r,e._getUIString("ScaleControl.Feet"))}else r&&"nautical"===r.unit?il(t,n,s/1852,e._getUIString("ScaleControl.NauticalMiles")):s>=1e3?il(t,n,s/1e3,e._getUIString("ScaleControl.Kilometers")):il(t,n,s,e._getUIString("ScaleControl.Meters"))}function il(e,t,r,n){const i=al(r),o=i/r;e.style.width=t*o+"px",e.innerHTML=`${i} ${n}`}function ol(e){const t=Math.pow(10,Math.ceil(-Math.log(e)/Math.LN10));return Math.round(e*t)/t}function al(e){const t=Math.pow(10,`${Math.floor(e)}`.length-1);let r=e/t;return r=r>=10?10:r>=5?5:r>=3?3:r>=2?2:r>=1?1:ol(r),t*r}class sl extends t.E{constructor(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};super(),this._onFullscreenChange=()=>{var e;let t=window.document.fullscreenElement||window.document.mozFullScreenElement||window.document.webkitFullscreenElement||window.document.msFullscreenElement;for(;null===(e=null===t||void 0===t?void 0:t.shadowRoot)||void 0===e?void 0:e.fullscreenElement;)t=t.shadowRoot.fullscreenElement;t===this._container!==this._fullscreen&&this._handleFullscreenChange()},this._onClickFullscreen=()=>{this._isFullscreen()?this._exitFullscreen():this._requestFullscreen()},this._fullscreen=!1,e&&e.container&&(e.container instanceof HTMLElement?this._container=e.container:t.w("Full screen control 'container' must be a DOM element.")),"onfullscreenchange"in document?this._fullscreenchange="fullscreenchange":"onmozfullscreenchange"in document?this._fullscreenchange="mozfullscreenchange":"onwebkitfullscreenchange"in document?this._fullscreenchange="webkitfullscreenchange":"onmsfullscreenchange"in document&&(this._fullscreenchange="MSFullscreenChange")}onAdd(e){return this._map=e,this._container||(this._container=this._map.getContainer()),this._controlContainer=a.create("div","maplibregl-ctrl maplibregl-ctrl-group"),this._setupUI(),this._controlContainer}onRemove(){a.remove(this._controlContainer),this._map=null,window.document.removeEventListener(this._fullscreenchange,this._onFullscreenChange)}_setupUI(){const e=this._fullscreenButton=a.create("button","maplibregl-ctrl-fullscreen",this._controlContainer);a.create("span","maplibregl-ctrl-icon",e).setAttribute("aria-hidden","true"),e.type="button",this._updateTitle(),this._fullscreenButton.addEventListener("click",this._onClickFullscreen),window.document.addEventListener(this._fullscreenchange,this._onFullscreenChange)}_updateTitle(){const e=this._getTitle();this._fullscreenButton.setAttribute("aria-label",e),this._fullscreenButton.title=e}_getTitle(){return this._map._getUIString(this._isFullscreen()?"FullscreenControl.Exit":"FullscreenControl.Enter")}_isFullscreen(){return this._fullscreen}_handleFullscreenChange(){this._fullscreen=!this._fullscreen,this._fullscreenButton.classList.toggle("maplibregl-ctrl-shrink"),this._fullscreenButton.classList.toggle("maplibregl-ctrl-fullscreen"),this._updateTitle(),this._fullscreen?(this.fire(new t.k("fullscreenstart")),this._prevCooperativeGesturesEnabled=this._map.cooperativeGestures.isEnabled(),this._map.cooperativeGestures.disable()):(this.fire(new t.k("fullscreenend")),this._prevCooperativeGesturesEnabled&&this._map.cooperativeGestures.enable())}_exitFullscreen(){window.document.exitFullscreen?window.document.exitFullscreen():window.document.mozCancelFullScreen?window.document.mozCancelFullScreen():window.document.msExitFullscreen?window.document.msExitFullscreen():window.document.webkitCancelFullScreen?window.document.webkitCancelFullScreen():this._togglePseudoFullScreen()}_requestFullscreen(){this._container.requestFullscreen?this._container.requestFullscreen():this._container.mozRequestFullScreen?this._container.mozRequestFullScreen():this._container.msRequestFullscreen?this._container.msRequestFullscreen():this._container.webkitRequestFullscreen?this._container.webkitRequestFullscreen():this._togglePseudoFullScreen()}_togglePseudoFullScreen(){this._container.classList.toggle("maplibregl-pseudo-fullscreen"),this._handleFullscreenChange(),this._map.resize()}}class ll{constructor(e){this._toggleTerrain=()=>{this._map.getTerrain()?this._map.setTerrain(null):this._map.setTerrain(this.options),this._updateTerrainIcon()},this._updateTerrainIcon=()=>{this._terrainButton.classList.remove("maplibregl-ctrl-terrain"),this._terrainButton.classList.remove("maplibregl-ctrl-terrain-enabled"),this._map.terrain?(this._terrainButton.classList.add("maplibregl-ctrl-terrain-enabled"),this._terrainButton.title=this._map._getUIString("TerrainControl.Disable")):(this._terrainButton.classList.add("maplibregl-ctrl-terrain"),this._terrainButton.title=this._map._getUIString("TerrainControl.Enable"))},this.options=e}onAdd(e){return this._map=e,this._container=a.create("div","maplibregl-ctrl maplibregl-ctrl-group"),this._terrainButton=a.create("button","maplibregl-ctrl-terrain",this._container),a.create("span","maplibregl-ctrl-icon",this._terrainButton).setAttribute("aria-hidden","true"),this._terrainButton.type="button",this._terrainButton.addEventListener("click",this._toggleTerrain),this._updateTerrainIcon(),this._map.on("terrain",this._updateTerrainIcon),this._container}onRemove(){a.remove(this._container),this._map.off("terrain",this._updateTerrainIcon),this._map=void 0}}const cl={closeButton:!0,closeOnClick:!0,focusAfterOpen:!0,className:"",maxWidth:"240px",subpixelPositioning:!1},ul=["a[href]","[tabindex]:not([tabindex='-1'])","[contenteditable]:not([contenteditable='false'])","button:not([disabled])","input:not([disabled])","select:not([disabled])","textarea:not([disabled])"].join(", ");class dl extends t.E{constructor(e){super(),this.remove=()=>(this._content&&a.remove(this._content),this._container&&(a.remove(this._container),delete this._container),this._map&&(this._map.off("move",this._update),this._map.off("move",this._onClose),this._map.off("click",this._onClose),this._map.off("remove",this.remove),this._map.off("mousemove",this._onMouseMove),this._map.off("mouseup",this._onMouseUp),this._map.off("drag",this._onDrag),this._map._canvasContainer.classList.remove("maplibregl-track-pointer"),delete this._map,this.fire(new t.k("close"))),this),this._onMouseUp=e=>{this._update(e.point)},this._onMouseMove=e=>{this._update(e.point)},this._onDrag=e=>{this._update(e.point)},this._update=e=>{var t;const r=this._lngLat||this._trackPointer;if(!this._map||!r||!this._content)return;if(!this._container){if(this._container=a.create("div","maplibregl-popup",this._map.getContainer()),this._tip=a.create("div","maplibregl-popup-tip",this._container),this._container.appendChild(this._content),this.options.className)for(const e of this.options.className.split(" "))this._container.classList.add(e);this._closeButton&&this._closeButton.setAttribute("aria-label",this._map._getUIString("Popup.Close")),this._trackPointer&&this._container.classList.add("maplibregl-popup-track-pointer")}if(this.options.maxWidth&&this._container.style.maxWidth!==this.options.maxWidth&&(this._container.style.maxWidth=this.options.maxWidth),this._map.transform.renderWorldCopies&&!this._trackPointer?this._lngLat=Gs(this._lngLat,this._flatPos,this._map.transform):this._lngLat=null===(t=this._lngLat)||void 0===t?void 0:t.wrap(),this._trackPointer&&!e)return;const n=this._flatPos=this._pos=this._trackPointer&&e?e:this._map.project(this._lngLat);this._map.terrain&&(this._flatPos=this._trackPointer&&e?e:this._map.transform.locationPoint(this._lngLat));let i=this.options.anchor;const o=hl(this.options.offset);if(!i){const e=this._container.offsetWidth,t=this._container.offsetHeight;let r;r=n.y+o.bottom.ythis._map.transform.height-t?["bottom"]:[],n.xthis._map.transform.width-e/2&&r.push("right"),i=0===r.length?"bottom":r.join("-")}let s=n.add(o[i]);this.options.subpixelPositioning||(s=s.round()),a.setTransform(this._container,`${Ys[i]} translate(${s.x}px,${s.y}px)`),Xs(this._container,i,"popup")},this._onClose=()=>{this.remove()},this.options=t.e(Object.create(cl),e)}addTo(e){return this._map&&this.remove(),this._map=e,this.options.closeOnClick&&this._map.on("click",this._onClose),this.options.closeOnMove&&this._map.on("move",this._onClose),this._map.on("remove",this.remove),this._update(),this._focusFirstElement(),this._trackPointer?(this._map.on("mousemove",this._onMouseMove),this._map.on("mouseup",this._onMouseUp),this._container&&this._container.classList.add("maplibregl-popup-track-pointer"),this._map._canvasContainer.classList.add("maplibregl-track-pointer")):this._map.on("move",this._update),this.fire(new t.k("open")),this}isOpen(){return!!this._map}getLngLat(){return this._lngLat}setLngLat(e){return this._lngLat=t.N.convert(e),this._pos=null,this._flatPos=null,this._trackPointer=!1,this._update(),this._map&&(this._map.on("move",this._update),this._map.off("mousemove",this._onMouseMove),this._container&&this._container.classList.remove("maplibregl-popup-track-pointer"),this._map._canvasContainer.classList.remove("maplibregl-track-pointer")),this}trackPointer(){return this._trackPointer=!0,this._pos=null,this._flatPos=null,this._update(),this._map&&(this._map.off("move",this._update),this._map.on("mousemove",this._onMouseMove),this._map.on("drag",this._onDrag),this._container&&this._container.classList.add("maplibregl-popup-track-pointer"),this._map._canvasContainer.classList.add("maplibregl-track-pointer")),this}getElement(){return this._container}setText(e){return this.setDOMContent(document.createTextNode(e))}setHTML(e){const t=document.createDocumentFragment(),r=document.createElement("body");let n;for(r.innerHTML=e;n=r.firstChild,n;)t.appendChild(n);return this.setDOMContent(t)}getMaxWidth(){var e;return null===(e=this._container)||void 0===e?void 0:e.style.maxWidth}setMaxWidth(e){return this.options.maxWidth=e,this._update(),this}setDOMContent(e){if(this._content)for(;this._content.hasChildNodes();)this._content.firstChild&&this._content.removeChild(this._content.firstChild);else this._content=a.create("div","maplibregl-popup-content",this._container);return this._content.appendChild(e),this._createCloseButton(),this._update(),this._focusFirstElement(),this}addClassName(e){return this._container&&this._container.classList.add(e),this}removeClassName(e){return this._container&&this._container.classList.remove(e),this}setOffset(e){return this.options.offset=e,this._update(),this}toggleClassName(e){if(this._container)return this._container.classList.toggle(e)}setSubpixelPositioning(e){this.options.subpixelPositioning=e}_createCloseButton(){this.options.closeButton&&(this._closeButton=a.create("button","maplibregl-popup-close-button",this._content),this._closeButton.type="button",this._closeButton.innerHTML="×",this._closeButton.addEventListener("click",this._onClose))}_focusFirstElement(){if(!this.options.focusAfterOpen||!this._container)return;const e=this._container.querySelector(ul);e&&e.focus()}}function hl(e){if(e){if("number"===typeof e){const r=Math.round(Math.abs(e)/Math.SQRT2);return{center:new t.P(0,0),top:new t.P(0,e),"top-left":new t.P(r,r),"top-right":new t.P(-r,r),bottom:new t.P(0,-e),"bottom-left":new t.P(r,-r),"bottom-right":new t.P(-r,-r),left:new t.P(e,0),right:new t.P(-e,0)}}if(e instanceof t.P||Array.isArray(e)){const r=t.P.convert(e);return{center:r,top:r,"top-left":r,"top-right":r,bottom:r,"bottom-left":r,"bottom-right":r,left:r,right:r}}return{center:t.P.convert(e.center||[0,0]),top:t.P.convert(e.top||[0,0]),"top-left":t.P.convert(e["top-left"]||[0,0]),"top-right":t.P.convert(e["top-right"]||[0,0]),bottom:t.P.convert(e.bottom||[0,0]),"bottom-left":t.P.convert(e["bottom-left"]||[0,0]),"bottom-right":t.P.convert(e["bottom-right"]||[0,0]),left:t.P.convert(e.left||[0,0]),right:t.P.convert(e.right||[0,0])}}return hl(new t.P(0,0))}const pl=r.version;function fl(e,t){return Ve().setRTLTextPlugin(e,t)}function ml(){return Ve().getRTLTextPluginStatus()}function gl(){return pl}function yl(){return ie.workerCount}function vl(e){ie.workerCount=e}function xl(){return t.a.MAX_PARALLEL_IMAGE_REQUESTS}function bl(e){t.a.MAX_PARALLEL_IMAGE_REQUESTS=e}function _l(){return t.a.WORKER_URL}function wl(e){t.a.WORKER_URL=e}function kl(e){return he().broadcast("IS",e)}e.AJAXError=t.bh,e.Evented=t.E,e.LngLat=t.N,e.MercatorCoordinate=t.Z,e.Point=t.P,e.addProtocol=t.bi,e.config=t.a,e.removeProtocol=t.bj,e.AttributionControl=_s,e.BoxZoomHandler=ba,e.CanvasSource=Pe,e.CooperativeGesturesHandler=fs,e.DoubleClickZoomHandler=ls,e.DragPanHandler=ds,e.DragRotateHandler=hs,e.EdgeInsets=ta,e.FullscreenControl=sl,e.GeoJSONSource=Te,e.GeolocateControl=el,e.Hash=oa,e.ImageSource=Ce,e.KeyboardHandler=ts,e.LngLatBounds=_e,e.LogoControl=ws,e.Map=Fs,e.MapMouseEvent=fa,e.MapTouchEvent=ma,e.MapWheelEvent=ga,e.Marker=Zs,e.NavigationControl=Hs,e.Popup=dl,e.RasterDEMTileSource=Ae,e.RasterTileSource=Se,e.ScaleControl=rl,e.ScrollZoomHandler=ss,e.Style=Kt,e.TerrainControl=ll,e.TwoFingersTouchPitchHandler=Qa,e.TwoFingersTouchRotateHandler=Za,e.TwoFingersTouchZoomHandler=Ga,e.TwoFingersTouchZoomRotateHandler=ps,e.VectorTileSource=ke,e.VideoSource=Ie,e.addSourceType=ze,e.clearPrewarmedResources=ue,e.getMaxParallelImageRequests=xl,e.getRTLTextPluginStatus=ml,e.getVersion=gl,e.getWorkerCount=yl,e.getWorkerUrl=_l,e.importScriptInWorkers=kl,e.prewarm=ce,e.setMaxParallelImageRequests=bl,e.setRTLTextPlugin=fl,e.setWorkerCount=vl,e.setWorkerUrl=wl})),e}()},23498:function(e){e.exports=function(){"use strict";function e(t){return e="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},e(t)}var t=/^\s+/,r=/\s+$/;function n(e,t){if(t=t||{},(e=e||"")instanceof n)return e;if(!(this instanceof n))return new n(e,t);var r=i(e);this._originalInput=e,this._r=r.r,this._g=r.g,this._b=r.b,this._a=r.a,this._roundA=Math.round(100*this._a)/100,this._format=t.format||r.format,this._gradientType=t.gradientType,this._r<1&&(this._r=Math.round(this._r)),this._g<1&&(this._g=Math.round(this._g)),this._b<1&&(this._b=Math.round(this._b)),this._ok=r.ok}function i(t){var r={r:0,g:0,b:0},n=1,i=null,a=null,l=null,u=!1,d=!1;return"string"==typeof t&&(t=B(t)),"object"==e(t)&&(N(t.r)&&N(t.g)&&N(t.b)?(r=o(t.r,t.g,t.b),u=!0,d="%"===String(t.r).substr(-1)?"prgb":"rgb"):N(t.h)&&N(t.s)&&N(t.v)?(i=D(t.s),a=D(t.v),r=c(t.h,i,a),u=!0,d="hsv"):N(t.h)&&N(t.s)&&N(t.l)&&(i=D(t.s),l=D(t.l),r=s(t.h,i,l),u=!0,d="hsl"),t.hasOwnProperty("a")&&(n=t.a)),n=C(n),{ok:u,format:t.format||d,r:Math.min(255,Math.max(r.r,0)),g:Math.min(255,Math.max(r.g,0)),b:Math.min(255,Math.max(r.b,0)),a:n}}function o(e,t,r){return{r:255*E(e,255),g:255*E(t,255),b:255*E(r,255)}}function a(e,t,r){e=E(e,255),t=E(t,255),r=E(r,255);var n,i,o=Math.max(e,t,r),a=Math.min(e,t,r),s=(o+a)/2;if(o==a)n=i=0;else{var l=o-a;switch(i=s>.5?l/(2-o-a):l/(o+a),o){case e:n=(t-r)/l+(t1&&(r-=1),r<1/6?e+6*(t-e)*r:r<.5?t:r<2/3?e+(t-e)*(2/3-r)*6:e}if(e=E(e,360),t=E(t,100),r=E(r,100),0===t)n=i=o=r;else{var s=r<.5?r*(1+t):r+t-r*t,l=2*r-s;n=a(l,s,e+1/3),i=a(l,s,e),o=a(l,s,e-1/3)}return{r:255*n,g:255*i,b:255*o}}function l(e,t,r){e=E(e,255),t=E(t,255),r=E(r,255);var n,i,o=Math.max(e,t,r),a=Math.min(e,t,r),s=o,l=o-a;if(i=0===o?0:l/o,o==a)n=0;else{switch(o){case e:n=(t-r)/l+(t>1)+720)%360;--t;)i.h=(i.h+o)%360,a.push(n(i));return a}function S(e,t){t=t||6;for(var r=n(e).toHsv(),i=r.h,o=r.s,a=r.v,s=[],l=1/t;t--;)s.push(n({h:i,s:o,v:a})),a=(a+l)%1;return s}n.prototype={isDark:function(){return this.getBrightness()<128},isLight:function(){return!this.isDark()},isValid:function(){return this._ok},getOriginalInput:function(){return this._originalInput},getFormat:function(){return this._format},getAlpha:function(){return this._a},getBrightness:function(){var e=this.toRgb();return(299*e.r+587*e.g+114*e.b)/1e3},getLuminance:function(){var e,t,r,n=this.toRgb();return e=n.r/255,t=n.g/255,r=n.b/255,.2126*(e<=.03928?e/12.92:Math.pow((e+.055)/1.055,2.4))+.7152*(t<=.03928?t/12.92:Math.pow((t+.055)/1.055,2.4))+.0722*(r<=.03928?r/12.92:Math.pow((r+.055)/1.055,2.4))},setAlpha:function(e){return this._a=C(e),this._roundA=Math.round(100*this._a)/100,this},toHsv:function(){var e=l(this._r,this._g,this._b);return{h:360*e.h,s:e.s,v:e.v,a:this._a}},toHsvString:function(){var e=l(this._r,this._g,this._b),t=Math.round(360*e.h),r=Math.round(100*e.s),n=Math.round(100*e.v);return 1==this._a?"hsv("+t+", "+r+"%, "+n+"%)":"hsva("+t+", "+r+"%, "+n+"%, "+this._roundA+")"},toHsl:function(){var e=a(this._r,this._g,this._b);return{h:360*e.h,s:e.s,l:e.l,a:this._a}},toHslString:function(){var e=a(this._r,this._g,this._b),t=Math.round(360*e.h),r=Math.round(100*e.s),n=Math.round(100*e.l);return 1==this._a?"hsl("+t+", "+r+"%, "+n+"%)":"hsla("+t+", "+r+"%, "+n+"%, "+this._roundA+")"},toHex:function(e){return u(this._r,this._g,this._b,e)},toHexString:function(e){return"#"+this.toHex(e)},toHex8:function(e){return d(this._r,this._g,this._b,this._a,e)},toHex8String:function(e){return"#"+this.toHex8(e)},toRgb:function(){return{r:Math.round(this._r),g:Math.round(this._g),b:Math.round(this._b),a:this._a}},toRgbString:function(){return 1==this._a?"rgb("+Math.round(this._r)+", "+Math.round(this._g)+", "+Math.round(this._b)+")":"rgba("+Math.round(this._r)+", "+Math.round(this._g)+", "+Math.round(this._b)+", "+this._roundA+")"},toPercentageRgb:function(){return{r:Math.round(100*E(this._r,255))+"%",g:Math.round(100*E(this._g,255))+"%",b:Math.round(100*E(this._b,255))+"%",a:this._a}},toPercentageRgbString:function(){return 1==this._a?"rgb("+Math.round(100*E(this._r,255))+"%, "+Math.round(100*E(this._g,255))+"%, "+Math.round(100*E(this._b,255))+"%)":"rgba("+Math.round(100*E(this._r,255))+"%, "+Math.round(100*E(this._g,255))+"%, "+Math.round(100*E(this._b,255))+"%, "+this._roundA+")"},toName:function(){return 0===this._a?"transparent":!(this._a<1)&&(T[u(this._r,this._g,this._b,!0)]||!1)},toFilter:function(e){var t="#"+h(this._r,this._g,this._b,this._a),r=t,i=this._gradientType?"GradientType = 1, ":"";if(e){var o=n(e);r="#"+h(o._r,o._g,o._b,o._a)}return"progid:DXImageTransform.Microsoft.gradient("+i+"startColorstr="+t+",endColorstr="+r+")"},toString:function(e){var t=!!e;e=e||this._format;var r=!1,n=this._a<1&&this._a>=0;return t||!n||"hex"!==e&&"hex6"!==e&&"hex3"!==e&&"hex4"!==e&&"hex8"!==e&&"name"!==e?("rgb"===e&&(r=this.toRgbString()),"prgb"===e&&(r=this.toPercentageRgbString()),"hex"!==e&&"hex6"!==e||(r=this.toHexString()),"hex3"===e&&(r=this.toHexString(!0)),"hex4"===e&&(r=this.toHex8String(!0)),"hex8"===e&&(r=this.toHex8String()),"name"===e&&(r=this.toName()),"hsl"===e&&(r=this.toHslString()),"hsv"===e&&(r=this.toHsvString()),r||this.toHexString()):"name"===e&&0===this._a?this.toName():this.toRgbString()},clone:function(){return n(this.toString())},_applyModification:function(e,t){var r=e.apply(null,[this].concat([].slice.call(t)));return this._r=r._r,this._g=r._g,this._b=r._b,this.setAlpha(r._a),this},lighten:function(){return this._applyModification(g,arguments)},brighten:function(){return this._applyModification(y,arguments)},darken:function(){return this._applyModification(v,arguments)},desaturate:function(){return this._applyModification(p,arguments)},saturate:function(){return this._applyModification(f,arguments)},greyscale:function(){return this._applyModification(m,arguments)},spin:function(){return this._applyModification(x,arguments)},_applyCombination:function(e,t){return e.apply(null,[this].concat([].slice.call(t)))},analogous:function(){return this._applyCombination(k,arguments)},complement:function(){return this._applyCombination(b,arguments)},monochromatic:function(){return this._applyCombination(S,arguments)},splitcomplement:function(){return this._applyCombination(w,arguments)},triad:function(){return this._applyCombination(_,[3])},tetrad:function(){return this._applyCombination(_,[4])}},n.fromRatio=function(t,r){if("object"==e(t)){var i={};for(var o in t)t.hasOwnProperty(o)&&(i[o]="a"===o?t[o]:D(t[o]));t=i}return n(t,r)},n.equals=function(e,t){return!(!e||!t)&&n(e).toRgbString()==n(t).toRgbString()},n.random=function(){return n.fromRatio({r:Math.random(),g:Math.random(),b:Math.random()})},n.mix=function(e,t,r){r=0===r?0:r||50;var i=n(e).toRgb(),o=n(t).toRgb(),a=r/100;return n({r:(o.r-i.r)*a+i.r,g:(o.g-i.g)*a+i.g,b:(o.b-i.b)*a+i.b,a:(o.a-i.a)*a+i.a})},n.readability=function(e,t){var r=n(e),i=n(t);return(Math.max(r.getLuminance(),i.getLuminance())+.05)/(Math.min(r.getLuminance(),i.getLuminance())+.05)},n.isReadable=function(e,t,r){var i,o,a=n.readability(e,t);switch(o=!1,(i=V(r)).level+i.size){case"AAsmall":case"AAAlarge":o=a>=4.5;break;case"AAlarge":o=a>=3;break;case"AAAsmall":o=a>=7}return o},n.mostReadable=function(e,t,r){var i,o,a,s,l=null,c=0;o=(r=r||{}).includeFallbackColors,a=r.level,s=r.size;for(var u=0;uc&&(c=i,l=n(t[u]));return n.isReadable(e,l,{level:a,size:s})||!o?l:(r.includeFallbackColors=!1,n.mostReadable(e,["#fff","#000"],r))};var A=n.names={aliceblue:"f0f8ff",antiquewhite:"faebd7",aqua:"0ff",aquamarine:"7fffd4",azure:"f0ffff",beige:"f5f5dc",bisque:"ffe4c4",black:"000",blanchedalmond:"ffebcd",blue:"00f",blueviolet:"8a2be2",brown:"a52a2a",burlywood:"deb887",burntsienna:"ea7e5d",cadetblue:"5f9ea0",chartreuse:"7fff00",chocolate:"d2691e",coral:"ff7f50",cornflowerblue:"6495ed",cornsilk:"fff8dc",crimson:"dc143c",cyan:"0ff",darkblue:"00008b",darkcyan:"008b8b",darkgoldenrod:"b8860b",darkgray:"a9a9a9",darkgreen:"006400",darkgrey:"a9a9a9",darkkhaki:"bdb76b",darkmagenta:"8b008b",darkolivegreen:"556b2f",darkorange:"ff8c00",darkorchid:"9932cc",darkred:"8b0000",darksalmon:"e9967a",darkseagreen:"8fbc8f",darkslateblue:"483d8b",darkslategray:"2f4f4f",darkslategrey:"2f4f4f",darkturquoise:"00ced1",darkviolet:"9400d3",deeppink:"ff1493",deepskyblue:"00bfff",dimgray:"696969",dimgrey:"696969",dodgerblue:"1e90ff",firebrick:"b22222",floralwhite:"fffaf0",forestgreen:"228b22",fuchsia:"f0f",gainsboro:"dcdcdc",ghostwhite:"f8f8ff",gold:"ffd700",goldenrod:"daa520",gray:"808080",green:"008000",greenyellow:"adff2f",grey:"808080",honeydew:"f0fff0",hotpink:"ff69b4",indianred:"cd5c5c",indigo:"4b0082",ivory:"fffff0",khaki:"f0e68c",lavender:"e6e6fa",lavenderblush:"fff0f5",lawngreen:"7cfc00",lemonchiffon:"fffacd",lightblue:"add8e6",lightcoral:"f08080",lightcyan:"e0ffff",lightgoldenrodyellow:"fafad2",lightgray:"d3d3d3",lightgreen:"90ee90",lightgrey:"d3d3d3",lightpink:"ffb6c1",lightsalmon:"ffa07a",lightseagreen:"20b2aa",lightskyblue:"87cefa",lightslategray:"789",lightslategrey:"789",lightsteelblue:"b0c4de",lightyellow:"ffffe0",lime:"0f0",limegreen:"32cd32",linen:"faf0e6",magenta:"f0f",maroon:"800000",mediumaquamarine:"66cdaa",mediumblue:"0000cd",mediumorchid:"ba55d3",mediumpurple:"9370db",mediumseagreen:"3cb371",mediumslateblue:"7b68ee",mediumspringgreen:"00fa9a",mediumturquoise:"48d1cc",mediumvioletred:"c71585",midnightblue:"191970",mintcream:"f5fffa",mistyrose:"ffe4e1",moccasin:"ffe4b5",navajowhite:"ffdead",navy:"000080",oldlace:"fdf5e6",olive:"808000",olivedrab:"6b8e23",orange:"ffa500",orangered:"ff4500",orchid:"da70d6",palegoldenrod:"eee8aa",palegreen:"98fb98",paleturquoise:"afeeee",palevioletred:"db7093",papayawhip:"ffefd5",peachpuff:"ffdab9",peru:"cd853f",pink:"ffc0cb",plum:"dda0dd",powderblue:"b0e0e6",purple:"800080",rebeccapurple:"663399",red:"f00",rosybrown:"bc8f8f",royalblue:"4169e1",saddlebrown:"8b4513",salmon:"fa8072",sandybrown:"f4a460",seagreen:"2e8b57",seashell:"fff5ee",sienna:"a0522d",silver:"c0c0c0",skyblue:"87ceeb",slateblue:"6a5acd",slategray:"708090",slategrey:"708090",snow:"fffafa",springgreen:"00ff7f",steelblue:"4682b4",tan:"d2b48c",teal:"008080",thistle:"d8bfd8",tomato:"ff6347",turquoise:"40e0d0",violet:"ee82ee",wheat:"f5deb3",white:"fff",whitesmoke:"f5f5f5",yellow:"ff0",yellowgreen:"9acd32"},T=n.hexNames=M(A);function M(e){var t={};for(var r in e)e.hasOwnProperty(r)&&(t[e[r]]=r);return t}function C(e){return e=parseFloat(e),(isNaN(e)||e<0||e>1)&&(e=1),e}function E(e,t){O(e)&&(e="100%");var r=R(e);return e=Math.min(t,Math.max(0,parseFloat(e))),r&&(e=parseInt(e*t,10)/100),Math.abs(e-t)<1e-6?1:e%t/parseFloat(t)}function I(e){return Math.min(1,Math.max(0,e))}function P(e){return parseInt(e,16)}function O(e){return"string"==typeof e&&-1!=e.indexOf(".")&&1===parseFloat(e)}function R(e){return"string"===typeof e&&-1!=e.indexOf("%")}function L(e){return 1==e.length?"0"+e:""+e}function D(e){return e<=1&&(e=100*e+"%"),e}function z(e){return Math.round(255*parseFloat(e)).toString(16)}function j(e){return P(e)/255}var F=function(){var e="(?:[-\\+]?\\d*\\.\\d+%?)|(?:[-\\+]?\\d+%?)",t="[\\s|\\(]+("+e+")[,|\\s]+("+e+")[,|\\s]+("+e+")\\s*\\)?",r="[\\s|\\(]+("+e+")[,|\\s]+("+e+")[,|\\s]+("+e+")[,|\\s]+("+e+")\\s*\\)?";return{CSS_UNIT:new RegExp(e),rgb:new RegExp("rgb"+t),rgba:new RegExp("rgba"+r),hsl:new RegExp("hsl"+t),hsla:new RegExp("hsla"+r),hsv:new RegExp("hsv"+t),hsva:new RegExp("hsva"+r),hex3:/^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,hex6:/^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,hex4:/^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,hex8:/^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/}}();function N(e){return!!F.CSS_UNIT.exec(e)}function B(e){e=e.replace(t,"").replace(r,"").toLowerCase();var n,i=!1;if(A[e])e=A[e],i=!0;else if("transparent"==e)return{r:0,g:0,b:0,a:0,format:"name"};return(n=F.rgb.exec(e))?{r:n[1],g:n[2],b:n[3]}:(n=F.rgba.exec(e))?{r:n[1],g:n[2],b:n[3],a:n[4]}:(n=F.hsl.exec(e))?{h:n[1],s:n[2],l:n[3]}:(n=F.hsla.exec(e))?{h:n[1],s:n[2],l:n[3],a:n[4]}:(n=F.hsv.exec(e))?{h:n[1],s:n[2],v:n[3]}:(n=F.hsva.exec(e))?{h:n[1],s:n[2],v:n[3],a:n[4]}:(n=F.hex8.exec(e))?{r:P(n[1]),g:P(n[2]),b:P(n[3]),a:j(n[4]),format:i?"name":"hex8"}:(n=F.hex6.exec(e))?{r:P(n[1]),g:P(n[2]),b:P(n[3]),format:i?"name":"hex"}:(n=F.hex4.exec(e))?{r:P(n[1]+""+n[1]),g:P(n[2]+""+n[2]),b:P(n[3]+""+n[3]),a:j(n[4]+""+n[4]),format:i?"name":"hex8"}:!!(n=F.hex3.exec(e))&&{r:P(n[1]+""+n[1]),g:P(n[2]+""+n[2]),b:P(n[3]+""+n[3]),format:i?"name":"hex"}}function V(e){var t,r;return"AA"!==(t=((e=e||{level:"AA",size:"small"}).level||"AA").toUpperCase())&&"AAA"!==t&&(t="AA"),"small"!==(r=(e.size||"small").toLowerCase())&&"large"!==r&&(r="small"),{level:t,size:r}}return n}()},58168:(e,t,r)=>{"use strict";function n(){return n=Object.assign?Object.assign.bind():function(e){for(var t=1;tn})},98587:(e,t,r)=>{"use strict";function n(e,t){if(null==e)return{};var r={};for(var n in e)if({}.hasOwnProperty.call(e,n)){if(t.includes(n))continue;r[n]=e[n]}return r}r.d(t,{A:()=>n})},58387:(e,t,r)=>{"use strict";function n(e){var t,r,i="";if("string"==typeof e||"number"==typeof e)i+=e;else if("object"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;ti});const i=function(){for(var e,t,r=0,i="",o=arguments.length;r{"use strict";function n(e,t,r){e.prototype=t.prototype=r,r.constructor=e}function i(e,t){var r=Object.create(e.prototype);for(var n in t)r[n]=t[n];return r}function o(){}r.d(t,{Ay:()=>_,Qh:()=>S});var a=.7,s=1/a,l="\\s*([+-]?\\d+)\\s*",c="\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)\\s*",u="\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)%\\s*",d=/^#([0-9a-f]{3,8})$/,h=new RegExp(`^rgb\\(${l},${l},${l}\\)$`),p=new RegExp(`^rgb\\(${u},${u},${u}\\)$`),f=new RegExp(`^rgba\\(${l},${l},${l},${c}\\)$`),m=new RegExp(`^rgba\\(${u},${u},${u},${c}\\)$`),g=new RegExp(`^hsl\\(${c},${u},${u}\\)$`),y=new RegExp(`^hsla\\(${c},${u},${u},${c}\\)$`),v={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074};function x(){return this.rgb().formatHex()}function b(){return this.rgb().formatRgb()}function _(e){var t,r;return e=(e+"").trim().toLowerCase(),(t=d.exec(e))?(r=t[1].length,t=parseInt(t[1],16),6===r?w(t):3===r?new A(t>>8&15|t>>4&240,t>>4&15|240&t,(15&t)<<4|15&t,1):8===r?k(t>>24&255,t>>16&255,t>>8&255,(255&t)/255):4===r?k(t>>12&15|t>>8&240,t>>8&15|t>>4&240,t>>4&15|240&t,((15&t)<<4|15&t)/255):null):(t=h.exec(e))?new A(t[1],t[2],t[3],1):(t=p.exec(e))?new A(255*t[1]/100,255*t[2]/100,255*t[3]/100,1):(t=f.exec(e))?k(t[1],t[2],t[3],t[4]):(t=m.exec(e))?k(255*t[1]/100,255*t[2]/100,255*t[3]/100,t[4]):(t=g.exec(e))?P(t[1],t[2]/100,t[3]/100,1):(t=y.exec(e))?P(t[1],t[2]/100,t[3]/100,t[4]):v.hasOwnProperty(e)?w(v[e]):"transparent"===e?new A(NaN,NaN,NaN,0):null}function w(e){return new A(e>>16&255,e>>8&255,255&e,1)}function k(e,t,r,n){return n<=0&&(e=t=r=NaN),new A(e,t,r,n)}function S(e,t,r,n){return 1===arguments.length?((i=e)instanceof o||(i=_(i)),i?new A((i=i.rgb()).r,i.g,i.b,i.opacity):new A):new A(e,t,r,null==n?1:n);var i}function A(e,t,r,n){this.r=+e,this.g=+t,this.b=+r,this.opacity=+n}function T(){return`#${I(this.r)}${I(this.g)}${I(this.b)}`}function M(){const e=C(this.opacity);return`${1===e?"rgb(":"rgba("}${E(this.r)}, ${E(this.g)}, ${E(this.b)}${1===e?")":`, ${e})`}`}function C(e){return isNaN(e)?1:Math.max(0,Math.min(1,e))}function E(e){return Math.max(0,Math.min(255,Math.round(e)||0))}function I(e){return((e=E(e))<16?"0":"")+e.toString(16)}function P(e,t,r,n){return n<=0?e=t=r=NaN:r<=0||r>=1?e=t=NaN:t<=0&&(e=NaN),new R(e,t,r,n)}function O(e){if(e instanceof R)return new R(e.h,e.s,e.l,e.opacity);if(e instanceof o||(e=_(e)),!e)return new R;if(e instanceof R)return e;var t=(e=e.rgb()).r/255,r=e.g/255,n=e.b/255,i=Math.min(t,r,n),a=Math.max(t,r,n),s=NaN,l=a-i,c=(a+i)/2;return l?(s=t===a?(r-n)/l+6*(r0&&c<1?0:s,new R(s,l,c,e.opacity)}function R(e,t,r,n){this.h=+e,this.s=+t,this.l=+r,this.opacity=+n}function L(e){return(e=(e||0)%360)<0?e+360:e}function D(e){return Math.max(0,Math.min(1,e||0))}function z(e,t,r){return 255*(e<60?t+(r-t)*e/60:e<180?r:e<240?t+(r-t)*(240-e)/60:t)}n(o,_,{copy(e){return Object.assign(new this.constructor,this,e)},displayable(){return this.rgb().displayable()},hex:x,formatHex:x,formatHex8:function(){return this.rgb().formatHex8()},formatHsl:function(){return O(this).formatHsl()},formatRgb:b,toString:b}),n(A,S,i(o,{brighter(e){return e=null==e?s:Math.pow(s,e),new A(this.r*e,this.g*e,this.b*e,this.opacity)},darker(e){return e=null==e?a:Math.pow(a,e),new A(this.r*e,this.g*e,this.b*e,this.opacity)},rgb(){return this},clamp(){return new A(E(this.r),E(this.g),E(this.b),C(this.opacity))},displayable(){return-.5<=this.r&&this.r<255.5&&-.5<=this.g&&this.g<255.5&&-.5<=this.b&&this.b<255.5&&0<=this.opacity&&this.opacity<=1},hex:T,formatHex:T,formatHex8:function(){return`#${I(this.r)}${I(this.g)}${I(this.b)}${I(255*(isNaN(this.opacity)?1:this.opacity))}`},formatRgb:M,toString:M})),n(R,(function(e,t,r,n){return 1===arguments.length?O(e):new R(e,t,r,null==n?1:n)}),i(o,{brighter(e){return e=null==e?s:Math.pow(s,e),new R(this.h,this.s,this.l*e,this.opacity)},darker(e){return e=null==e?a:Math.pow(a,e),new R(this.h,this.s,this.l*e,this.opacity)},rgb(){var e=this.h%360+360*(this.h<0),t=isNaN(e)||isNaN(this.s)?0:this.s,r=this.l,n=r+(r<.5?r:1-r)*t,i=2*r-n;return new A(z(e>=240?e-240:e+120,i,n),z(e,i,n),z(e<120?e+240:e-120,i,n),this.opacity)},clamp(){return new R(L(this.h),D(this.s),D(this.l),C(this.opacity))},displayable(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1},formatHsl(){const e=C(this.opacity);return`${1===e?"hsl(":"hsla("}${L(this.h)}, ${100*D(this.s)}%, ${100*D(this.l)}%${1===e?")":`, ${e})`}`}}))},38419:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=e=>()=>e},70359:(e,t,r)=>{"use strict";r.d(t,{GW:()=>h,Dj:()=>s.A});var n=r(75206),i=r(75365);function o(e,t){var r,n=t?t.length:0,i=e?Math.min(n,e.length):0,o=new Array(i),a=new Array(n);for(r=0;r{"use strict";function n(e,t){return e=+e,t=+t,function(r){return e*(1-r)+t*r}}r.d(t,{A:()=>n})},75365:(e,t,r)=>{"use strict";r.d(t,{Ay:()=>c});var n=r(75206);function i(e,t,r,n,i){var o=e*e,a=o*e;return((1-3*e+3*o-a)*t+(4-6*o+3*a)*r+(1+3*e+3*o-3*a)*n+a*i)/6}var o=r(38419);function a(e,t){return function(r){return e+r*t}}function s(e){return 1===(e=+e)?l:function(t,r){return r-t?function(e,t,r){return e=Math.pow(e,r),t=Math.pow(t,r)-e,r=1/r,function(n){return Math.pow(e+n*t,r)}}(t,r,e):(0,o.A)(isNaN(t)?r:t)}}function l(e,t){var r=t-e;return r?a(e,r):(0,o.A)(isNaN(e)?t:e)}const c=function e(t){var r=s(t);function i(e,t){var i=r((e=(0,n.Qh)(e)).r,(t=(0,n.Qh)(t)).r),o=r(e.g,t.g),a=r(e.b,t.b),s=l(e.opacity,t.opacity);return function(t){return e.r=i(t),e.g=o(t),e.b=a(t),e.opacity=s(t),e+""}}return i.gamma=e,i}(1);function u(e){return function(t){var r,i,o=t.length,a=new Array(o),s=new Array(o),l=new Array(o);for(r=0;r=1?(r=1,t-1):Math.floor(r*t),o=e[n],a=e[n+1],s=n>0?e[n-1]:2*o-a,l=n{"use strict";r.d(t,{A:()=>a});var n=r(50010),i=/[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,o=new RegExp(i.source,"g");function a(e,t){var r,a,s,l=i.lastIndex=o.lastIndex=0,c=-1,u=[],d=[];for(e+="",t+="";(r=i.exec(e))&&(a=o.exec(t));)(s=a.index)>l&&(s=t.slice(l,s),u[c]?u[c]+=s:u[++c]=s),(r=r[0])===(a=a[0])?u[c]?u[c]+=a:u[++c]=a:(u[++c]=null,d.push({i:c,x:(0,n.A)(r,a)})),l=o.lastIndex;return l{"use strict";e.exports=JSON.parse('["xx-small","x-small","small","medium","large","x-large","xx-large","larger","smaller"]')},2362:e=>{"use strict";e.exports=JSON.parse('["normal","condensed","semi-condensed","extra-condensed","ultra-condensed","expanded","semi-expanded","extra-expanded","ultra-expanded"]')},87486:e=>{"use strict";e.exports=JSON.parse('["normal","italic","oblique"]')},99803:e=>{"use strict";e.exports=JSON.parse('["normal","bold","bolder","lighter","100","200","300","400","500","600","700","800","900"]')},54324:e=>{"use strict";e.exports=JSON.parse('["inherit","initial","unset"]')},94316:e=>{"use strict";e.exports=JSON.parse('["caption","icon","menu","message-box","small-caption","status-bar"]')},31158:e=>{"use strict";e.exports=JSON.parse('{"version":8,"name":"orto","metadata":{"maputnik:renderer":"mlgljs"},"center":[1.537786,41.837539],"zoom":12,"bearing":0,"pitch":0,"light":{"anchor":"viewport","color":"white","intensity":0.4,"position":[1.15,45,30]},"sources":{"ortoEsri":{"type":"raster","tiles":["https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}"],"tileSize":256,"maxzoom":18,"attribution":"ESRI © ESRI"},"ortoInstaMaps":{"type":"raster","tiles":["https://tilemaps.icgc.cat/mapfactory/wmts/orto_8_12/CAT3857/{z}/{x}/{y}.png"],"tileSize":256,"maxzoom":13},"ortoICGC":{"type":"raster","tiles":["https://geoserveis.icgc.cat/icc_mapesmultibase/noutm/wmts/orto/GRID3857/{z}/{x}/{y}.jpeg"],"tileSize":256,"minzoom":13.1,"maxzoom":20},"openmaptiles":{"type":"vector","url":"https://geoserveis.icgc.cat/contextmaps/basemap.json"}},"sprite":"https://geoserveis.icgc.cat/contextmaps/sprites/sprite@1","glyphs":"https://geoserveis.icgc.cat/contextmaps/glyphs/{fontstack}/{range}.pbf","layers":[{"id":"background","type":"background","paint":{"background-color":"#F4F9F4"}},{"id":"ortoEsri","type":"raster","source":"ortoEsri","maxzoom":16,"layout":{"visibility":"visible"}},{"id":"ortoICGC","type":"raster","source":"ortoICGC","minzoom":13.1,"maxzoom":19,"layout":{"visibility":"visible"}},{"id":"ortoInstaMaps","type":"raster","source":"ortoInstaMaps","maxzoom":13,"layout":{"visibility":"visible"}},{"id":"waterway_tunnel","type":"line","source":"openmaptiles","source-layer":"waterway","minzoom":14,"filter":["all",["in","class","river","stream","canal"],["==","brunnel","tunnel"]],"layout":{"line-cap":"round"},"paint":{"line-color":"#a0c8f0","line-width":{"base":1.3,"stops":[[13,0.5],[20,6]]},"line-dasharray":[2,4]}},{"id":"waterway-other","type":"line","metadata":{"mapbox:group":"1444849382550.77"},"source":"openmaptiles","source-layer":"waterway","filter":["!in","class","canal","river","stream"],"layout":{"line-cap":"round"},"paint":{"line-color":"#a0c8f0","line-width":{"base":1.3,"stops":[[13,0.5],[20,2]]}}},{"id":"waterway-stream-canal","type":"line","metadata":{"mapbox:group":"1444849382550.77"},"source":"openmaptiles","source-layer":"waterway","filter":["all",["in","class","canal","stream"],["!=","brunnel","tunnel"]],"layout":{"line-cap":"round"},"paint":{"line-color":"#a0c8f0","line-width":{"base":1.3,"stops":[[13,0.5],[20,6]]}}},{"id":"waterway-river","type":"line","metadata":{"mapbox:group":"1444849382550.77"},"source":"openmaptiles","source-layer":"waterway","filter":["all",["==","class","river"],["!=","brunnel","tunnel"]],"layout":{"line-cap":"round"},"paint":{"line-color":"#a0c8f0","line-width":{"base":1.2,"stops":[[10,0.8],[20,4]]},"line-opacity":0.5}},{"id":"water-offset","type":"fill","metadata":{"mapbox:group":"1444849382550.77"},"source":"openmaptiles","source-layer":"water","maxzoom":8,"filter":["==","$type","Polygon"],"layout":{"visibility":"visible"},"paint":{"fill-opacity":0,"fill-color":"#a0c8f0","fill-translate":{"base":1,"stops":[[6,[2,0]],[8,[0,0]]]}}},{"id":"water","type":"fill","metadata":{"mapbox:group":"1444849382550.77"},"source":"openmaptiles","source-layer":"water","layout":{"visibility":"visible"},"paint":{"fill-color":"hsl(210, 67%, 85%)","fill-opacity":0}},{"id":"water-pattern","type":"fill","metadata":{"mapbox:group":"1444849382550.77"},"source":"openmaptiles","source-layer":"water","layout":{"visibility":"visible"},"paint":{"fill-translate":[0,2.5],"fill-pattern":"wave","fill-opacity":1}},{"id":"landcover-ice-shelf","type":"fill","metadata":{"mapbox:group":"1444849382550.77"},"source":"openmaptiles","source-layer":"landcover","filter":["==","subclass","ice_shelf"],"layout":{"visibility":"visible"},"paint":{"fill-color":"#fff","fill-opacity":{"base":1,"stops":[[0,0.9],[10,0.3]]}}},{"id":"tunnel-service-track-casing","type":"line","metadata":{"mapbox:group":"1444849354174.1904"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","tunnel"],["in","class","service","track"]],"layout":{"line-join":"round"},"paint":{"line-color":"#cfcdca","line-dasharray":[0.5,0.25],"line-width":{"base":1.2,"stops":[[15,1],[16,4],[20,11]]}}},{"id":"tunnel-minor-casing","type":"line","metadata":{"mapbox:group":"1444849354174.1904"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","tunnel"],["==","class","minor"]],"layout":{"line-join":"round"},"paint":{"line-color":"#cfcdca","line-opacity":{"stops":[[12,0],[12.5,1]]},"line-width":{"base":1.2,"stops":[[12,0.5],[13,1],[14,4],[20,15]]}}},{"id":"tunnel-secondary-tertiary-casing","type":"line","metadata":{"mapbox:group":"1444849354174.1904"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","tunnel"],["in","class","secondary","tertiary"]],"layout":{"line-join":"round"},"paint":{"line-color":"#e9ac77","line-opacity":1,"line-width":{"base":1.2,"stops":[[8,1.5],[20,17]]}}},{"id":"tunnel-trunk-primary-casing","type":"line","metadata":{"mapbox:group":"1444849354174.1904"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","tunnel"],["in","class","primary","trunk"]],"layout":{"line-join":"round"},"paint":{"line-color":"#e9ac77","line-width":{"base":1.2,"stops":[[5,0.4],[6,0.6],[7,1.5],[20,22]]},"line-opacity":0.7}},{"id":"tunnel-motorway-casing","type":"line","metadata":{"mapbox:group":"1444849354174.1904"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","tunnel"],["==","class","motorway"]],"layout":{"line-join":"round","visibility":"visible"},"paint":{"line-color":"#e9ac77","line-dasharray":[0.5,0.25],"line-width":{"base":1.2,"stops":[[5,0.4],[6,0.6],[7,1.5],[20,22]]},"line-opacity":0.5}},{"id":"tunnel-path","type":"line","metadata":{"mapbox:group":"1444849354174.1904"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","$type","LineString"],["all",["==","brunnel","tunnel"],["==","class","path"]]],"paint":{"line-color":"#cba","line-dasharray":[1.5,0.75],"line-width":{"base":1.2,"stops":[[15,1.2],[20,4]]}}},{"id":"tunnel-service-track","type":"line","metadata":{"mapbox:group":"1444849354174.1904"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","tunnel"],["in","class","service","track"]],"layout":{"line-join":"round"},"paint":{"line-color":"#fff","line-width":{"base":1.2,"stops":[[15.5,0],[16,2],[20,7.5]]}}},{"id":"tunnel-minor","type":"line","metadata":{"mapbox:group":"1444849354174.1904"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","tunnel"],["==","class","minor_road"]],"layout":{"line-join":"round"},"paint":{"line-color":"#fff","line-opacity":1,"line-width":{"base":1.2,"stops":[[13.5,0],[14,2.5],[20,11.5]]}}},{"id":"tunnel-secondary-tertiary","type":"line","metadata":{"mapbox:group":"1444849354174.1904"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","tunnel"],["in","class","secondary","tertiary"]],"layout":{"line-join":"round"},"paint":{"line-color":"#fff4c6","line-width":{"base":1.2,"stops":[[6.5,0],[7,0.5],[20,10]]}}},{"id":"tunnel-trunk-primary","type":"line","metadata":{"mapbox:group":"1444849354174.1904"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","tunnel"],["in","class","primary","trunk"]],"layout":{"line-join":"round"},"paint":{"line-color":"#fff4c6","line-width":{"base":1.2,"stops":[[6.5,0],[7,0.5],[20,18]]},"line-opacity":0.5}},{"id":"tunnel-motorway","type":"line","metadata":{"mapbox:group":"1444849354174.1904"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","tunnel"],["==","class","motorway"]],"layout":{"line-join":"round","visibility":"visible"},"paint":{"line-color":"#ffdaa6","line-width":{"base":1.2,"stops":[[6.5,0],[7,0.5],[20,18]]},"line-opacity":0.5}},{"id":"tunnel-railway","type":"line","metadata":{"mapbox:group":"1444849354174.1904"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","tunnel"],["==","class","rail"]],"paint":{"line-color":"#bbb","line-width":{"base":1.4,"stops":[[14,0.4],[15,0.75],[20,2]]},"line-dasharray":[2,2]}},{"id":"ferry","type":"line","source":"openmaptiles","source-layer":"transportation","filter":["all",["in","class","ferry"]],"layout":{"line-join":"round","visibility":"visible"},"paint":{"line-color":"rgba(108, 159, 182, 1)","line-width":1.1,"line-dasharray":[2,2]}},{"id":"aeroway-taxiway-casing","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"aeroway","minzoom":12,"filter":["all",["in","class","taxiway"]],"layout":{"line-cap":"round","line-join":"round","visibility":"visible"},"paint":{"line-color":"rgba(153, 153, 153, 1)","line-width":{"base":1.5,"stops":[[11,2],[17,12]]},"line-opacity":1}},{"id":"aeroway-runway-casing","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"aeroway","minzoom":12,"filter":["all",["in","class","runway"]],"layout":{"line-cap":"round","line-join":"round","visibility":"visible"},"paint":{"line-color":"rgba(153, 153, 153, 1)","line-width":{"base":1.5,"stops":[[11,5],[17,55]]},"line-opacity":1}},{"id":"aeroway-taxiway","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"aeroway","minzoom":4,"filter":["all",["in","class","taxiway"],["==","$type","LineString"]],"layout":{"line-cap":"round","line-join":"round","visibility":"visible"},"paint":{"line-color":"rgba(255, 255, 255, 1)","line-width":{"base":1.5,"stops":[[11,1],[17,10]]},"line-opacity":{"base":1,"stops":[[11,0],[12,1]]}}},{"id":"aeroway-runway","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"aeroway","minzoom":4,"filter":["all",["in","class","runway"],["==","$type","LineString"]],"layout":{"line-cap":"round","line-join":"round","visibility":"visible"},"paint":{"line-color":"rgba(255, 255, 255, 1)","line-width":{"base":1.5,"stops":[[11,4],[17,50]]},"line-opacity":{"base":1,"stops":[[11,0],[12,1]]}}},{"id":"highway-motorway-link-casing","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","minzoom":12,"filter":["all",["!in","brunnel","bridge","tunnel"],["==","class","motorway_link"]],"layout":{"line-cap":"round","line-join":"round"},"paint":{"line-color":"#e9ac77","line-opacity":1,"line-width":{"base":1.2,"stops":[[12,1],[13,3],[14,4],[20,15]]}}},{"id":"highway-link-casing","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","minzoom":13,"filter":["all",["!in","brunnel","bridge","tunnel"],["in","class","primary_link","secondary_link","tertiary_link","trunk_link"]],"layout":{"line-cap":"round","line-join":"round","visibility":"visible"},"paint":{"line-color":"#e9ac77","line-opacity":1,"line-width":{"base":1.2,"stops":[[12,1],[13,3],[14,4],[20,15]]}}},{"id":"highway-minor-casing","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","$type","LineString"],["all",["!=","brunnel","tunnel"],["in","class","minor","service","track"]]],"layout":{"line-cap":"round","line-join":"round"},"paint":{"line-color":"#cfcdca","line-opacity":{"stops":[[12,0],[12.5,0]]},"line-width":{"base":1.2,"stops":[[12,0.5],[13,1],[14,4],[20,15]]}}},{"id":"highway-secondary-tertiary-casing","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["!in","brunnel","bridge","tunnel"],["in","class","secondary","tertiary"]],"layout":{"line-cap":"butt","line-join":"round","visibility":"visible"},"paint":{"line-color":"#e9ac77","line-opacity":0.5,"line-width":{"base":1.2,"stops":[[8,1.5],[20,17]]}}},{"id":"highway-primary-casing","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","minzoom":5,"filter":["all",["!in","brunnel","bridge","tunnel"],["in","class","primary"]],"layout":{"line-cap":"butt","line-join":"round","visibility":"visible"},"paint":{"line-color":"#e9ac77","line-opacity":{"stops":[[7,0],[8,0.6]]},"line-width":{"base":1.2,"stops":[[7,0],[8,0.6],[9,1.5],[20,22]]}}},{"id":"highway-trunk-casing","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","minzoom":5,"filter":["all",["!in","brunnel","bridge","tunnel"],["in","class","trunk"]],"layout":{"line-cap":"butt","line-join":"round","visibility":"visible"},"paint":{"line-color":"#e9ac77","line-opacity":{"stops":[[5,0],[6,0.5]]},"line-width":{"base":1.2,"stops":[[5,0],[6,0.6],[7,1.5],[20,22]]}}},{"id":"highway-motorway-casing","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","minzoom":4,"filter":["all",["!in","brunnel","bridge","tunnel"],["==","class","motorway"]],"layout":{"line-cap":"butt","line-join":"round","visibility":"visible"},"paint":{"line-color":"#e9ac77","line-width":{"base":1.2,"stops":[[4,0],[5,0.4],[6,0.6],[7,1.5],[20,22]]},"line-opacity":{"stops":[[4,0],[5,0.5]]}}},{"id":"highway-path","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","$type","LineString"],["all",["!in","brunnel","bridge","tunnel"],["==","class","path"]]],"paint":{"line-color":"#cba","line-dasharray":[1.5,0.75],"line-width":{"base":1.2,"stops":[[15,1.2],[20,4]]}}},{"id":"highway-motorway-link","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","minzoom":12,"filter":["all",["!in","brunnel","bridge","tunnel"],["==","class","motorway_link"]],"layout":{"line-cap":"round","line-join":"round"},"paint":{"line-color":"#fc8","line-width":{"base":1.2,"stops":[[12.5,0],[13,1.5],[14,2.5],[20,11.5]]}}},{"id":"highway-link","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","minzoom":13,"filter":["all",["!in","brunnel","bridge","tunnel"],["in","class","primary_link","secondary_link","tertiary_link","trunk_link"]],"layout":{"line-cap":"round","line-join":"round","visibility":"visible"},"paint":{"line-color":"#fea","line-width":{"base":1.2,"stops":[[12.5,0],[13,1.5],[14,2.5],[20,11.5]]}}},{"id":"highway-minor","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","$type","LineString"],["all",["!=","brunnel","tunnel"],["in","class","minor","service","track"]]],"layout":{"line-cap":"round","line-join":"round"},"paint":{"line-color":"#fff","line-opacity":0.5,"line-width":{"base":1.2,"stops":[[13.5,0],[14,2.5],[20,11.5]]}}},{"id":"highway-secondary-tertiary","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["!in","brunnel","bridge","tunnel"],["in","class","secondary","tertiary"]],"layout":{"line-cap":"round","line-join":"round","visibility":"visible"},"paint":{"line-color":"#fea","line-width":{"base":1.2,"stops":[[6.5,0],[8,0.5],[20,13]]},"line-opacity":0.5}},{"id":"highway-primary","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","$type","LineString"],["all",["!in","brunnel","bridge","tunnel"],["in","class","primary"]]],"layout":{"line-cap":"round","line-join":"round","visibility":"visible"},"paint":{"line-color":"#fea","line-width":{"base":1.2,"stops":[[8.5,0],[9,0.5],[20,18]]},"line-opacity":0}},{"id":"highway-trunk","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","$type","LineString"],["all",["!in","brunnel","bridge","tunnel"],["in","class","trunk"]]],"layout":{"line-cap":"round","line-join":"round","visibility":"visible"},"paint":{"line-color":"#fea","line-width":{"base":1.2,"stops":[[6.5,0],[7,0.5],[20,18]]},"line-opacity":0.5}},{"id":"highway-motorway","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","minzoom":5,"filter":["all",["==","$type","LineString"],["all",["!in","brunnel","bridge","tunnel"],["==","class","motorway"]]],"layout":{"line-cap":"round","line-join":"round","visibility":"visible"},"paint":{"line-color":"#fc8","line-width":{"base":1.2,"stops":[[6.5,0],[7,0.5],[20,18]]},"line-opacity":0.5}},{"id":"railway-transit","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","$type","LineString"],["all",["==","class","transit"],["!in","brunnel","tunnel"]]],"layout":{"visibility":"visible"},"paint":{"line-color":"hsla(0, 0%, 73%, 0.77)","line-width":{"base":1.4,"stops":[[14,0.4],[20,1]]}}},{"id":"railway-transit-hatching","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","$type","LineString"],["all",["==","class","transit"],["!in","brunnel","tunnel"]]],"layout":{"visibility":"visible"},"paint":{"line-color":"hsla(0, 0%, 73%, 0.68)","line-dasharray":[0.2,8],"line-width":{"base":1.4,"stops":[[14.5,0],[15,2],[20,6]]}}},{"id":"railway-service","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","$type","LineString"],["all",["==","class","rail"],["has","service"]]],"paint":{"line-color":"hsla(0, 0%, 73%, 0.77)","line-width":{"base":1.4,"stops":[[14,0.4],[20,1]]}}},{"id":"railway-service-hatching","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","$type","LineString"],["all",["==","class","rail"],["has","service"]]],"layout":{"visibility":"visible"},"paint":{"line-color":"hsla(0, 0%, 73%, 0.68)","line-dasharray":[0.2,8],"line-width":{"base":1.4,"stops":[[14.5,0],[15,2],[20,6]]}}},{"id":"railway","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","$type","LineString"],["all",["!has","service"],["!in","brunnel","bridge","tunnel"],["==","class","rail"]]],"paint":{"line-color":"#bbb","line-width":{"base":1.4,"stops":[[14,0.4],[15,0.75],[20,2]]}}},{"id":"railway-hatching","type":"line","metadata":{"mapbox:group":"1444849345966.4436"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","$type","LineString"],["all",["!has","service"],["!in","brunnel","bridge","tunnel"],["==","class","rail"]]],"paint":{"line-color":"#bbb","line-dasharray":[0.2,8],"line-width":{"base":1.4,"stops":[[14.5,0],[15,3],[20,8]]}}},{"id":"bridge-motorway-link-casing","type":"line","metadata":{"mapbox:group":"1444849334699.1902"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","bridge"],["==","class","motorway_link"]],"layout":{"line-join":"round"},"paint":{"line-color":"#e9ac77","line-opacity":1,"line-width":{"base":1.2,"stops":[[12,1],[13,3],[14,4],[20,15]]}}},{"id":"bridge-link-casing","type":"line","metadata":{"mapbox:group":"1444849334699.1902"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","bridge"],["in","class","primary_link","secondary_link","tertiary_link","trunk_link"]],"layout":{"line-join":"round"},"paint":{"line-color":"#e9ac77","line-opacity":1,"line-width":{"base":1.2,"stops":[[12,1],[13,3],[14,4],[20,15]]}}},{"id":"bridge-secondary-tertiary-casing","type":"line","metadata":{"mapbox:group":"1444849334699.1902"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","bridge"],["in","class","secondary","tertiary"]],"layout":{"line-join":"round"},"paint":{"line-color":"#e9ac77","line-opacity":1,"line-width":{"base":1.2,"stops":[[8,1.5],[20,28]]}}},{"id":"bridge-trunk-primary-casing","type":"line","metadata":{"mapbox:group":"1444849334699.1902"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","bridge"],["in","class","primary","trunk"]],"layout":{"line-join":"round"},"paint":{"line-color":"hsl(28, 76%, 67%)","line-width":{"base":1.2,"stops":[[5,0.4],[6,0.6],[7,1.5],[20,26]]}}},{"id":"bridge-motorway-casing","type":"line","metadata":{"mapbox:group":"1444849334699.1902"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","bridge"],["==","class","motorway"]],"layout":{"line-join":"round"},"paint":{"line-color":"#e9ac77","line-width":{"base":1.2,"stops":[[5,0.4],[6,0.6],[7,1.5],[20,22]]},"line-opacity":0.5}},{"id":"bridge-path-casing","type":"line","metadata":{"mapbox:group":"1444849334699.1902"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","$type","LineString"],["all",["==","brunnel","bridge"],["==","class","path"]]],"paint":{"line-color":"#f8f4f0","line-width":{"base":1.2,"stops":[[15,1.2],[20,18]]}}},{"id":"bridge-path","type":"line","metadata":{"mapbox:group":"1444849334699.1902"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","$type","LineString"],["all",["==","brunnel","bridge"],["==","class","path"]]],"paint":{"line-color":"#cba","line-width":{"base":1.2,"stops":[[15,1.2],[20,4]]},"line-dasharray":[1.5,0.75]}},{"id":"bridge-motorway-link","type":"line","metadata":{"mapbox:group":"1444849334699.1902"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","bridge"],["==","class","motorway_link"]],"layout":{"line-join":"round"},"paint":{"line-color":"#fc8","line-width":{"base":1.2,"stops":[[12.5,0],[13,1.5],[14,2.5],[20,11.5]]}}},{"id":"bridge-link","type":"line","metadata":{"mapbox:group":"1444849334699.1902"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","bridge"],["in","class","primary_link","secondary_link","tertiary_link","trunk_link"]],"layout":{"line-join":"round"},"paint":{"line-color":"#fea","line-width":{"base":1.2,"stops":[[12.5,0],[13,1.5],[14,2.5],[20,11.5]]}}},{"id":"bridge-secondary-tertiary","type":"line","metadata":{"mapbox:group":"1444849334699.1902"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","bridge"],["in","class","secondary","tertiary"]],"layout":{"line-join":"round"},"paint":{"line-color":"#fea","line-width":{"base":1.2,"stops":[[6.5,0],[7,0.5],[20,20]]}}},{"id":"bridge-trunk-primary","type":"line","metadata":{"mapbox:group":"1444849334699.1902"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","bridge"],["in","class","primary","trunk"]],"layout":{"line-join":"round"},"paint":{"line-color":"#fea","line-width":{"base":1.2,"stops":[[6.5,0],[7,0.5],[20,18]]}}},{"id":"bridge-motorway","type":"line","metadata":{"mapbox:group":"1444849334699.1902"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","bridge"],["==","class","motorway"]],"layout":{"line-join":"round"},"paint":{"line-color":"#fc8","line-width":{"base":1.2,"stops":[[6.5,0],[7,0.5],[20,18]]},"line-opacity":0.5}},{"id":"bridge-railway","type":"line","metadata":{"mapbox:group":"1444849334699.1902"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","bridge"],["==","class","rail"]],"paint":{"line-color":"#bbb","line-width":{"base":1.4,"stops":[[14,0.4],[15,0.75],[20,2]]}}},{"id":"bridge-railway-hatching","type":"line","metadata":{"mapbox:group":"1444849334699.1902"},"source":"openmaptiles","source-layer":"transportation","filter":["all",["==","brunnel","bridge"],["==","class","rail"]],"paint":{"line-color":"#bbb","line-dasharray":[0.2,8],"line-width":{"base":1.4,"stops":[[14.5,0],[15,3],[20,8]]}}},{"id":"cablecar","type":"line","source":"openmaptiles","source-layer":"transportation","minzoom":13,"filter":["==","class","cable_car"],"layout":{"visibility":"visible","line-cap":"round"},"paint":{"line-color":"hsl(0, 0%, 70%)","line-width":{"base":1,"stops":[[11,1],[19,2.5]]}}},{"id":"cablecar-dash","type":"line","source":"openmaptiles","source-layer":"transportation","minzoom":13,"filter":["==","class","cable_car"],"layout":{"visibility":"visible","line-cap":"round"},"paint":{"line-color":"hsl(0, 0%, 70%)","line-width":{"base":1,"stops":[[11,3],[19,5.5]]},"line-dasharray":[2,3]}},{"id":"boundary-land-level-4","type":"line","source":"openmaptiles","source-layer":"boundary","filter":["all",[">=","admin_level",4],["<=","admin_level",8],["!=","maritime",1]],"layout":{"line-join":"round"},"paint":{"line-color":"#9e9cab","line-dasharray":[3,1,1,1],"line-width":{"base":1.4,"stops":[[4,0.4],[5,1],[12,3]]},"line-opacity":0.6}},{"id":"boundary-land-level-2","type":"line","source":"openmaptiles","source-layer":"boundary","filter":["all",["==","admin_level",2],["!=","maritime",1],["!=","disputed",1]],"layout":{"line-cap":"round","line-join":"round"},"paint":{"line-color":"hsl(248, 7%, 66%)","line-width":{"base":1,"stops":[[0,0.6],[4,1.4],[5,2],[12,2]]}}},{"id":"boundary-land-disputed","type":"line","source":"openmaptiles","source-layer":"boundary","filter":["all",["!=","maritime",1],["==","disputed",1]],"layout":{"line-cap":"round","line-join":"round"},"paint":{"line-color":"hsl(248, 7%, 70%)","line-dasharray":[1,3],"line-width":{"base":1,"stops":[[0,0.6],[4,1.4],[5,2],[12,8]]}}},{"id":"boundary-water","type":"line","source":"openmaptiles","source-layer":"boundary","filter":["all",["in","admin_level",2,4],["==","maritime",1]],"layout":{"line-cap":"round","line-join":"round"},"paint":{"line-color":"rgba(154, 189, 214, 1)","line-width":{"base":1,"stops":[[0,0.6],[4,1],[5,1],[12,1]]},"line-opacity":{"stops":[[6,0],[10,0]]}}},{"id":"waterway-name","type":"symbol","source":"openmaptiles","source-layer":"waterway","minzoom":13,"filter":["all",["==","$type","LineString"],["has","name"]],"layout":{"text-font":["Noto Sans Italic"],"text-size":14,"text-field":"{name:latin} {name:nonlatin}","text-max-width":5,"text-rotation-alignment":"map","symbol-placement":"line","text-letter-spacing":0.2,"symbol-spacing":350},"paint":{"text-color":"#74aee9","text-halo-width":1.5,"text-halo-color":"rgba(255,255,255,0.7)"}},{"id":"water-name-lakeline","type":"symbol","source":"openmaptiles","source-layer":"water_name","filter":["==","$type","LineString"],"layout":{"text-font":["Noto Sans Italic"],"text-size":14,"text-field":"{name:latin}\\n{name:nonlatin}","text-max-width":5,"text-rotation-alignment":"map","symbol-placement":"line","symbol-spacing":350,"text-letter-spacing":0.2},"paint":{"text-color":"#74aee9","text-halo-width":1.5,"text-halo-color":"rgba(255,255,255,0.7)"}},{"id":"water-name-ocean","type":"symbol","source":"openmaptiles","source-layer":"water_name","filter":["all",["==","$type","Point"],["==","class","ocean"]],"layout":{"text-font":["Noto Sans Italic"],"text-size":14,"text-field":"{name:latin}","text-max-width":5,"text-rotation-alignment":"map","symbol-placement":"point","symbol-spacing":350,"text-letter-spacing":0.2},"paint":{"text-color":"#74aee9","text-halo-width":1.5,"text-halo-color":"rgba(255,255,255,0.7)"}},{"id":"water-name-other","type":"symbol","source":"openmaptiles","source-layer":"water_name","filter":["all",["==","$type","Point"],["!in","class","ocean"]],"layout":{"text-font":["Noto Sans Italic"],"text-size":{"stops":[[0,10],[6,14]]},"text-field":"{name:latin}\\n{name:nonlatin}","text-max-width":5,"text-rotation-alignment":"map","symbol-placement":"point","symbol-spacing":350,"text-letter-spacing":0.2,"visibility":"visible"},"paint":{"text-color":"#74aee9","text-halo-width":1.5,"text-halo-color":"rgba(255,255,255,0.7)"}},{"id":"poi-level-3","type":"symbol","source":"openmaptiles","source-layer":"poi","minzoom":16,"filter":["all",["==","$type","Point"],[">=","rank",25]],"layout":{"text-padding":2,"text-font":["Noto Sans Regular"],"text-anchor":"top","icon-image":"{class}_11","text-field":"{name:latin}\\n{name:nonlatin}","text-offset":[0,0.6],"text-size":12,"text-max-width":9},"paint":{"text-halo-blur":0.5,"text-color":"#666","text-halo-width":1,"text-halo-color":"#ffffff"}},{"id":"poi-level-2","type":"symbol","source":"openmaptiles","source-layer":"poi","minzoom":15,"filter":["all",["==","$type","Point"],["<=","rank",24],[">=","rank",15]],"layout":{"text-padding":2,"text-font":["Noto Sans Regular"],"text-anchor":"top","icon-image":"{class}_11","text-field":"{name:latin}\\n{name:nonlatin}","text-offset":[0,0.6],"text-size":12,"text-max-width":9},"paint":{"text-halo-blur":0.5,"text-color":"#666","text-halo-width":1,"text-halo-color":"#ffffff"}},{"id":"poi-level-1","type":"symbol","source":"openmaptiles","source-layer":"poi","minzoom":14,"filter":["all",["==","$type","Point"],["<=","rank",14],["has","name"]],"layout":{"text-padding":2,"text-font":["Noto Sans Regular"],"text-anchor":"top","icon-image":"{class}_11","text-field":"{name:latin}\\n{name:nonlatin}","text-offset":[0,0.6],"text-size":11,"text-max-width":9},"paint":{"text-halo-blur":0.5,"text-color":"rgba(191, 228, 172, 1)","text-halo-width":1,"text-halo-color":"rgba(30, 29, 29, 1)"}},{"id":"poi-railway","type":"symbol","source":"openmaptiles","source-layer":"poi","minzoom":13,"filter":["all",["==","$type","Point"],["has","name"],["==","class","railway"],["==","subclass","station"]],"layout":{"text-padding":2,"text-font":["Noto Sans Regular"],"text-anchor":"top","icon-image":"{class}_11","text-field":"{name:latin}\\n{name:nonlatin}","text-offset":[0,0.6],"text-size":12,"text-max-width":9,"icon-optional":false,"icon-ignore-placement":false,"icon-allow-overlap":false,"text-ignore-placement":false,"text-allow-overlap":false,"text-optional":true},"paint":{"text-halo-blur":0.5,"text-color":"#666","text-halo-width":1,"text-halo-color":"#ffffff"}},{"id":"road_oneway","type":"symbol","source":"openmaptiles","source-layer":"transportation","minzoom":15,"filter":["all",["==","oneway",1],["in","class","motorway","trunk","primary","secondary","tertiary","minor","service"]],"layout":{"symbol-placement":"line","icon-image":"oneway","symbol-spacing":75,"icon-padding":2,"icon-rotation-alignment":"map","icon-rotate":90,"icon-size":{"stops":[[15,0.5],[19,1]]}},"paint":{"icon-opacity":0.5}},{"id":"road_oneway_opposite","type":"symbol","source":"openmaptiles","source-layer":"transportation","minzoom":15,"filter":["all",["==","oneway",-1],["in","class","motorway","trunk","primary","secondary","tertiary","minor","service"]],"layout":{"symbol-placement":"line","icon-image":"oneway","symbol-spacing":75,"icon-padding":2,"icon-rotation-alignment":"map","icon-rotate":-90,"icon-size":{"stops":[[15,0.5],[19,1]]}},"paint":{"icon-opacity":0.5}},{"id":"highway-name-path","type":"symbol","source":"openmaptiles","source-layer":"transportation_name","minzoom":15.5,"filter":["==","class","path"],"layout":{"text-size":{"base":1,"stops":[[13,12],[14,13]]},"text-font":["Noto Sans Regular"],"text-field":"{name:latin} {name:nonlatin}","symbol-placement":"line","text-rotation-alignment":"map"},"paint":{"text-halo-color":"#f8f4f0","text-color":"hsl(30, 23%, 62%)","text-halo-width":0.5}},{"id":"highway-name-minor","type":"symbol","source":"openmaptiles","source-layer":"transportation_name","minzoom":15,"filter":["all",["==","$type","LineString"],["in","class","minor","service","track"]],"layout":{"text-size":{"base":1,"stops":[[13,12],[14,13]]},"text-font":["Noto Sans Regular"],"text-field":"{name:latin} {name:nonlatin}","symbol-placement":"line","text-rotation-alignment":"map"},"paint":{"text-halo-blur":0.5,"text-color":"#765","text-halo-width":1}},{"id":"highway-name-major","type":"symbol","source":"openmaptiles","source-layer":"transportation_name","minzoom":12.2,"filter":["in","class","primary","secondary","tertiary","trunk"],"layout":{"text-size":{"base":1,"stops":[[13,12],[14,13]]},"text-font":["Noto Sans Regular"],"text-field":"{name:latin} {name:nonlatin}","symbol-placement":"line","text-rotation-alignment":"map"},"paint":{"text-halo-blur":0.5,"text-color":"#765","text-halo-width":1}},{"id":"highway-shield","type":"symbol","source":"openmaptiles","source-layer":"transportation_name","minzoom":8,"filter":["all",["<=","ref_length",6],["==","$type","LineString"],["!in","network","us-interstate","us-highway","us-state"]],"layout":{"text-size":10,"icon-image":"road_{ref_length}","icon-rotation-alignment":"viewport","symbol-spacing":200,"text-font":["Noto Sans Regular"],"symbol-placement":{"base":1,"stops":[[10,"point"],[11,"line"]]},"text-rotation-alignment":"viewport","icon-size":1,"text-field":"{ref}"},"paint":{"text-opacity":1,"text-color":"rgba(20, 19, 19, 1)","text-halo-color":"rgba(230, 221, 221, 0)","text-halo-width":2,"icon-color":"rgba(183, 18, 18, 1)","icon-opacity":0.3,"icon-halo-color":"rgba(183, 55, 55, 0)"}},{"id":"highway-shield-us-interstate","type":"symbol","source":"openmaptiles","source-layer":"transportation_name","minzoom":7,"filter":["all",["<=","ref_length",6],["==","$type","LineString"],["in","network","us-interstate"]],"layout":{"text-size":10,"icon-image":"{network}_{ref_length}","icon-rotation-alignment":"viewport","symbol-spacing":200,"text-font":["Noto Sans Regular"],"symbol-placement":{"base":1,"stops":[[7,"point"],[7,"line"],[8,"line"]]},"text-rotation-alignment":"viewport","icon-size":1,"text-field":"{ref}"},"paint":{"text-color":"rgba(0, 0, 0, 1)"}},{"id":"highway-shield-us-other","type":"symbol","source":"openmaptiles","source-layer":"transportation_name","minzoom":9,"filter":["all",["<=","ref_length",6],["==","$type","LineString"],["in","network","us-highway","us-state"]],"layout":{"text-size":10,"icon-image":"{network}_{ref_length}","icon-rotation-alignment":"viewport","symbol-spacing":200,"text-font":["Noto Sans Regular"],"symbol-placement":{"base":1,"stops":[[10,"point"],[11,"line"]]},"text-rotation-alignment":"viewport","icon-size":1,"text-field":"{ref}"},"paint":{"text-color":"rgba(0, 0, 0, 1)"}},{"id":"place-other","type":"symbol","metadata":{"mapbox:group":"1444849242106.713"},"source":"openmaptiles","source-layer":"place","minzoom":12,"filter":["!in","class","city","town","village","country","continent"],"layout":{"text-letter-spacing":0.1,"text-size":{"base":1.2,"stops":[[12,10],[15,14]]},"text-font":["Noto Sans Bold"],"text-field":"{name:latin}\\n{name:nonlatin}","text-transform":"uppercase","text-max-width":9,"visibility":"visible"},"paint":{"text-color":"rgba(255,255,255,1)","text-halo-width":1.2,"text-halo-color":"rgba(57, 28, 28, 1)"}},{"id":"place-village","type":"symbol","metadata":{"mapbox:group":"1444849242106.713"},"source":"openmaptiles","source-layer":"place","minzoom":10,"filter":["==","class","village"],"layout":{"text-font":["Noto Sans Regular"],"text-size":{"base":1.2,"stops":[[10,12],[15,16]]},"text-field":"{name:latin}\\n{name:nonlatin}","text-max-width":8,"visibility":"visible"},"paint":{"text-color":"rgba(255, 255, 255, 1)","text-halo-width":1.2,"text-halo-color":"rgba(10, 9, 9, 0.8)"}},{"id":"place-town","type":"symbol","metadata":{"mapbox:group":"1444849242106.713"},"source":"openmaptiles","source-layer":"place","filter":["==","class","town"],"layout":{"text-font":["Noto Sans Regular"],"text-size":{"base":1.2,"stops":[[10,14],[15,24]]},"text-field":"{name:latin}\\n{name:nonlatin}","text-max-width":8,"visibility":"visible"},"paint":{"text-color":"rgba(255, 255, 255, 1)","text-halo-width":1.2,"text-halo-color":"rgba(22, 22, 22, 0.8)"}},{"id":"place-city","type":"symbol","metadata":{"mapbox:group":"1444849242106.713"},"source":"openmaptiles","source-layer":"place","filter":["all",["!=","capital",2],["==","class","city"]],"layout":{"text-font":["Noto Sans Regular"],"text-size":{"base":1.2,"stops":[[7,14],[11,24]]},"text-field":"{name:latin}\\n{name:nonlatin}","text-max-width":8,"visibility":"visible"},"paint":{"text-color":"rgba(0, 0, 0, 1)","text-halo-width":1.2,"text-halo-color":"rgba(255,255,255,0.8)"}},{"id":"place-city-capital","type":"symbol","metadata":{"mapbox:group":"1444849242106.713"},"source":"openmaptiles","source-layer":"place","filter":["all",["==","capital",2],["==","class","city"]],"layout":{"text-font":["Noto Sans Regular"],"text-size":{"base":1.2,"stops":[[7,14],[11,24]]},"text-field":"{name:latin}\\n{name:nonlatin}","text-max-width":8,"icon-image":"star_11","text-offset":[0.4,0],"icon-size":0.8,"text-anchor":"left","visibility":"visible"},"paint":{"text-color":"#333","text-halo-width":1.2,"text-halo-color":"rgba(255,255,255,0.8)"}},{"id":"place-country-other","type":"symbol","metadata":{"mapbox:group":"1444849242106.713"},"source":"openmaptiles","source-layer":"place","filter":["all",["==","class","country"],[">=","rank",3],["!has","iso_a2"]],"layout":{"text-font":["Noto Sans Italic"],"text-field":"{name:latin}","text-size":{"stops":[[3,11],[7,17]]},"text-transform":"uppercase","text-max-width":6.25,"visibility":"visible"},"paint":{"text-halo-blur":1,"text-color":"#334","text-halo-width":2,"text-halo-color":"rgba(255,255,255,0.8)"}},{"id":"place-country-3","type":"symbol","metadata":{"mapbox:group":"1444849242106.713"},"source":"openmaptiles","source-layer":"place","filter":["all",["==","class","country"],[">=","rank",3],["has","iso_a2"]],"layout":{"text-font":["Noto Sans Bold"],"text-field":"{name:latin}","text-size":{"stops":[[3,11],[7,17]]},"text-transform":"uppercase","text-max-width":6.25,"visibility":"visible"},"paint":{"text-halo-blur":1,"text-color":"#334","text-halo-width":2,"text-halo-color":"rgba(255,255,255,0.8)"}},{"id":"place-country-2","type":"symbol","metadata":{"mapbox:group":"1444849242106.713"},"source":"openmaptiles","source-layer":"place","filter":["all",["==","class","country"],["==","rank",2],["has","iso_a2"]],"layout":{"text-font":["Noto Sans Bold"],"text-field":"{name:latin}","text-size":{"stops":[[2,11],[5,17]]},"text-transform":"uppercase","text-max-width":6.25,"visibility":"visible"},"paint":{"text-halo-blur":1,"text-color":"#334","text-halo-width":2,"text-halo-color":"rgba(255,255,255,0.8)"}},{"id":"place-country-1","type":"symbol","metadata":{"mapbox:group":"1444849242106.713"},"source":"openmaptiles","source-layer":"place","filter":["all",["==","class","country"],["==","rank",1],["has","iso_a2"]],"layout":{"text-font":["Noto Sans Bold"],"text-field":"{name:latin}","text-size":{"stops":[[1,11],[4,17]]},"text-transform":"uppercase","text-max-width":6.25,"visibility":"visible"},"paint":{"text-halo-blur":1,"text-color":"#334","text-halo-width":2,"text-halo-color":"rgba(255,255,255,0.8)"}},{"id":"place-continent","type":"symbol","metadata":{"mapbox:group":"1444849242106.713"},"source":"openmaptiles","source-layer":"place","maxzoom":1,"filter":["==","class","continent"],"layout":{"text-font":["Noto Sans Bold"],"text-field":"{name:latin}","text-size":14,"text-max-width":6.25,"text-transform":"uppercase","visibility":"visible"},"paint":{"text-halo-blur":1,"text-color":"#334","text-halo-width":2,"text-halo-color":"rgba(255,255,255,0.8)"}}],"id":"qebnlkra6"}')},18021:e=>{"use strict";e.exports=JSON.parse('{"version":8,"name":"orto","metadata":{},"center":[1.537786,41.837539],"zoom":12,"bearing":0,"pitch":0,"light":{"anchor":"viewport","color":"white","intensity":0.4,"position":[1.15,45,30]},"sources":{"ortoEsri":{"type":"raster","tiles":["https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}"],"tileSize":256,"maxzoom":18,"attribution":"ESRI © ESRI"},"ortoInstaMaps":{"type":"raster","tiles":["https://tilemaps.icgc.cat/mapfactory/wmts/orto_8_12/CAT3857/{z}/{x}/{y}.png"],"tileSize":256,"maxzoom":13},"ortoICGC":{"type":"raster","tiles":["https://geoserveis.icgc.cat/icc_mapesmultibase/noutm/wmts/orto/GRID3857/{z}/{x}/{y}.jpeg"],"tileSize":256,"minzoom":13.1,"maxzoom":20},"openmaptiles":{"type":"vector","url":"https://geoserveis.icgc.cat/contextmaps/basemap.json"}},"sprite":"https://geoserveis.icgc.cat/contextmaps/sprites/sprite@1","glyphs":"https://geoserveis.icgc.cat/contextmaps/glyphs/{fontstack}/{range}.pbf","layers":[{"id":"background","type":"background","paint":{"background-color":"#F4F9F4"}},{"id":"ortoEsri","type":"raster","source":"ortoEsri","maxzoom":16,"layout":{"visibility":"visible"}},{"id":"ortoICGC","type":"raster","source":"ortoICGC","minzoom":13.1,"maxzoom":19,"layout":{"visibility":"visible"}},{"id":"ortoInstaMaps","type":"raster","source":"ortoInstaMaps","maxzoom":13,"layout":{"visibility":"visible"}}]}')},28332:e=>{"use strict";e.exports=JSON.parse('{"version":"1.3.0","nodeVersion":"v23.4.0","reactVersion":"18.2.0"}')}},t={};function r(n){var i=t[n];if(void 0!==i)return i.exports;var o=t[n]={id:n,loaded:!1,exports:{}};return e[n].call(o.exports,o,o.exports,r),o.loaded=!0,o.exports}r.m=e,r.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return r.d(t,{a:t}),t},(()=>{var e,t=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__;r.t=function(n,i){if(1&i&&(n=this(n)),8&i)return n;if("object"===typeof n&&n){if(4&i&&n.__esModule)return n;if(16&i&&"function"===typeof n.then)return n}var o=Object.create(null);r.r(o);var a={};e=e||[null,t({}),t([]),t(t)];for(var s=2&i&&n;"object"==typeof s&&!~e.indexOf(s);s=t(s))Object.getOwnPropertyNames(s).forEach((e=>a[e]=()=>n[e]));return a.default=()=>n,r.d(o,a),o}})(),r.d=(e,t)=>{for(var n in t)r.o(t,n)&&!r.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},r.f={},r.e=e=>Promise.all(Object.keys(r.f).reduce(((t,n)=>(r.f[n](e,t),t)),[])),r.u=e=>"static/js/"+e+".8edbc83a.chunk.js",r.miniCssF=e=>{},r.g=function(){if("object"===typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"===typeof window)return window}}(),r.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),(()=>{var e={},t="optinist:";r.l=(n,i,o,a)=>{if(e[n])e[n].push(i);else{var s,l;if(void 0!==o)for(var c=document.getElementsByTagName("script"),u=0;u{s.onerror=s.onload=null,clearTimeout(p);var i=e[n];if(delete e[n],s.parentNode&&s.parentNode.removeChild(s),i&&i.forEach((e=>e(r))),t)return t(r)},p=setTimeout(h.bind(null,void 0,{type:"timeout",target:s}),12e4);s.onerror=h.bind(null,s.onerror),s.onload=h.bind(null,s.onload),l&&document.head.appendChild(s)}}})(),r.r=e=>{"undefined"!==typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.nmd=e=>(e.paths=[],e.children||(e.children=[]),e),r.p="/",(()=>{var e={792:0};r.f.j=(t,n)=>{var i=r.o(e,t)?e[t]:void 0;if(0!==i)if(i)n.push(i[2]);else{var o=new Promise(((r,n)=>i=e[t]=[r,n]));n.push(i[2]=o);var a=r.p+r.u(t),s=new Error;r.l(a,(n=>{if(r.o(e,t)&&(0!==(i=e[t])&&(e[t]=void 0),i)){var o=n&&("load"===n.type?"missing":n.type),a=n&&n.target&&n.target.src;s.message="Loading chunk "+t+" failed.\n("+o+": "+a+")",s.name="ChunkLoadError",s.type=o,s.request=a,i[1](s)}}),"chunk-"+t,t)}};var t=(t,n)=>{var i,o,a=n[0],s=n[1],l=n[2],c=0;if(a.some((t=>0!==e[t]))){for(i in s)r.o(s,i)&&(r.m[i]=s[i]);if(l)l(r)}for(t&&t(n);c{"use strict";var e={};r.r(e),r.d(e,{hasBrowserEnv:()=>ou,hasStandardBrowserEnv:()=>su,hasStandardBrowserWebWorkerEnv:()=>lu,navigator:()=>au,origin:()=>cu});var t={};r.r(t),r.d(t,{FILE:()=>eZ,HTML:()=>nZ,TEXT:()=>rZ,URL:()=>tZ});var n=r(65043),i=r.t(n,2),o=r(29461),a=r(98443),s=r(97950),l=r.t(s,2);let c=function(e){e()};const u=Symbol.for("react-redux-context"),d="undefined"!==typeof globalThis?globalThis:{};function h(){var e;if(!n.createContext)return{};const t=null!=(e=d[u])?e:d[u]=new Map;let r=t.get(n.createContext);return r||(r=n.createContext(null),t.set(n.createContext,r)),r}const p=h();function f(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:p;return function(){return(0,n.useContext)(e)}}const m=f();let g=()=>{throw new Error("uSES not initialized!")};const y=(e,t)=>e===t;function v(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:p;const t=e===p?m:f(e);return function(e){let r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{equalityFn:i=y,stabilityCheck:o,noopCheck:a}="function"===typeof r?{equalityFn:r}:r;const{store:s,subscription:l,getServerState:c,stabilityCheck:u,noopCheck:d}=t(),h=((0,n.useRef)(!0),(0,n.useCallback)({[e.name]:t=>e(t)}[e.name],[e,u,o])),p=g(l.addNestedSub,s.getState,c||s.getState,h,i);return(0,n.useDebugValue)(p),p}}const x=v();r(80219),r(2086);function b(){const e=c;let t=null,r=null;return{clear(){t=null,r=null},notify(){e((()=>{let e=t;for(;e;)e.callback(),e=e.next}))},get(){let e=[],r=t;for(;r;)e.push(r),r=r.next;return e},subscribe(e){let n=!0,i=r={callback:e,next:null,prev:r};return i.prev?i.prev.next=i:t=i,function(){n&&null!==t&&(n=!1,i.next?i.next.prev=i.prev:r=i.prev,i.prev?i.prev.next=i.next:t=i.next)}}}}const _={notify(){},get:()=>[]};const w=!("undefined"===typeof window||"undefined"===typeof window.document||"undefined"===typeof window.document.createElement)?n.useLayoutEffect:n.useEffect;let k=null;const S=function(e){let{store:t,context:r,children:i,serverState:o,stabilityCheck:a="once",noopCheck:s="once"}=e;const l=n.useMemo((()=>{const e=function(e,t){let r,n=_,i=0,o=!1;function a(){c.onStateChange&&c.onStateChange()}function s(){i++,r||(r=t?t.addNestedSub(a):e.subscribe(a),n=b())}function l(){i--,r&&0===i&&(r(),r=void 0,n.clear(),n=_)}const c={addNestedSub:function(e){s();const t=n.subscribe(e);let r=!1;return()=>{r||(r=!0,t(),l())}},notifyNestedSubs:function(){n.notify()},handleChangeWrapper:a,isSubscribed:function(){return o},trySubscribe:function(){o||(o=!0,s())},tryUnsubscribe:function(){o&&(o=!1,l())},getListeners:()=>n};return c}(t);return{store:t,subscription:e,getServerState:o?()=>o:void 0,stabilityCheck:a,noopCheck:s}}),[t,o,a,s]),c=n.useMemo((()=>t.getState()),[t]);w((()=>{const{subscription:e}=l;return e.onStateChange=e.notifyNestedSubs,e.trySubscribe(),c!==t.getState()&&e.notifyNestedSubs(),()=>{e.tryUnsubscribe(),e.onStateChange=void 0}}),[l,c]);const u=r||p;return n.createElement(u.Provider,{value:l},i)};function A(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:p;const t=e===p?m:f(e);return function(){const{store:e}=t();return e}}const T=A();function M(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:p;const t=e===p?T:A(e);return function(){return t().dispatch}}const C=M();var E,I;E=a.useSyncExternalStoreWithSelector,g=E,(e=>{k=e})(o.useSyncExternalStore),I=s.unstable_batchedUpdates,c=I;var P=r(84391),O=r(58168),R=r(98587);const L=n.createContext(null);function D(){return n.useContext(L)}const z="function"===typeof Symbol&&Symbol.for?Symbol.for("mui.nested"):"__THEME_NESTED__";var j=r(70579);const F=function(e){const{children:t,theme:r}=e,i=D(),o=n.useMemo((()=>{const e=null===i?r:function(e,t){if("function"===typeof t)return t(e);return(0,O.A)({},e,t)}(i,r);return null!=e&&(e[z]=null!==i),e}),[r,i]);return(0,j.jsx)(L.Provider,{value:o,children:t})};var N=r(84575);const B=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null;const t=n.useContext(N.T);return t&&(r=t,0!==Object.keys(r).length)?t:e;var r},V=["value"],U=n.createContext();const H=()=>{const e=n.useContext(U);return null!=e&&e},$=function(e){let{value:t}=e,r=(0,R.A)(e,V);return(0,j.jsx)(U.Provider,(0,O.A)({value:null==t||t},r))};var W=r(13654);const q={};function G(e,t,r){let i=arguments.length>3&&void 0!==arguments[3]&&arguments[3];return n.useMemo((()=>{const n=e&&t[e]||t;if("function"===typeof r){const o=r(n),a=e?(0,O.A)({},t,{[e]:o}):o;return i?()=>a:a}return e?(0,O.A)({},t,{[e]:r}):(0,O.A)({},t,r)}),[e,t,r,i])}const Y=function(e){const{children:t,theme:r,themeId:n}=e,i=B(q),o=D()||q,a=G(n,i,r),s=G(n,o,r,!0),l="rtl"===a.direction;return(0,j.jsx)(F,{theme:s,children:(0,j.jsx)(N.T.Provider,{value:a,children:(0,j.jsx)($,{value:l,children:(0,j.jsx)(W.A,{value:null==a?void 0:a.components,children:t})})})})};var X=r(13375);const Z=["theme"];function K(e){let{theme:t}=e,r=(0,R.A)(e,Z);const n=t[X.A];return(0,j.jsx)(Y,(0,O.A)({},r,{themeId:n?X.A:void 0,theme:n||t}))}function J(){return J=Object.assign?Object.assign.bind():function(e){for(var t=1;t=0&&(t.hash=e.substr(r),e=e.substr(0,r));let n=e.indexOf("?");n>=0&&(t.search=e.substr(n),e=e.substr(0,n)),e&&(t.pathname=e)}return t}function le(e,t,r,n){void 0===n&&(n={});let{window:i=document.defaultView,v5Compat:o=!1}=n,a=i.history,s=Q.Pop,l=null,c=u();function u(){return(a.state||{idx:null}).idx}function d(){s=Q.Pop;let e=u(),t=null==e?null:e-c;c=e,l&&l({action:s,location:p.location,delta:t})}function h(e){let t="null"!==i.location.origin?i.location.origin:i.location.href,r="string"===typeof e?e:ae(e);return r=r.replace(/ $/,"%20"),re(t,"No window.location.(origin|href) available to create URL for href: "+r),new URL(r,t)}null==c&&(c=0,a.replaceState(J({},a.state,{idx:c}),""));let p={get action(){return s},get location(){return e(i,a)},listen(e){if(l)throw new Error("A history only accepts one active listener");return i.addEventListener(te,d),l=e,()=>{i.removeEventListener(te,d),l=null}},createHref:e=>t(i,e),createURL:h,encodeLocation(e){let t=h(e);return{pathname:t.pathname,search:t.search,hash:t.hash}},push:function(e,t){s=Q.Push;let n=oe(p.location,e,t);r&&r(n,e),c=u()+1;let d=ie(n,c),h=p.createHref(n);try{a.pushState(d,"",h)}catch(f){if(f instanceof DOMException&&"DataCloneError"===f.name)throw f;i.location.assign(h)}o&&l&&l({action:s,location:p.location,delta:1})},replace:function(e,t){s=Q.Replace;let n=oe(p.location,e,t);r&&r(n,e),c=u();let i=ie(n,c),d=p.createHref(n);a.replaceState(i,"",d),o&&l&&l({action:s,location:p.location,delta:0})},go:e=>a.go(e)};return p}var ce,ue;(ue=ce||(ce={})).data="data",ue.deferred="deferred",ue.redirect="redirect",ue.error="error";new Set(["lazy","caseSensitive","path","id","index","children"]);function de(e,t,r){return void 0===r&&(r="/"),he(e,t,r,!1)}function he(e,t,r,n){let i=Te(("string"===typeof t?se(t):t).pathname||"/",r);if(null==i)return null;let o=pe(e);!function(e){e.sort(((e,t)=>e.score!==t.score?t.score-e.score:function(e,t){let r=e.length===t.length&&e.slice(0,-1).every(((e,r)=>e===t[r]));return r?e[e.length-1]-t[t.length-1]:0}(e.routesMeta.map((e=>e.childrenIndex)),t.routesMeta.map((e=>e.childrenIndex)))))}(o);let a=null;for(let s=0;null==a&&s{let a={relativePath:void 0===o?e.path||"":o,caseSensitive:!0===e.caseSensitive,childrenIndex:i,route:e};a.relativePath.startsWith("/")&&(re(a.relativePath.startsWith(n),'Absolute route path "'+a.relativePath+'" nested under path "'+n+'" is not valid. An absolute child route path must start with the combined path of all its parent routes.'),a.relativePath=a.relativePath.slice(n.length));let s=Pe([n,a.relativePath]),l=r.concat(a);e.children&&e.children.length>0&&(re(!0!==e.index,'Index routes must not have child routes. Please remove all child routes from route path "'+s+'".'),pe(e.children,t,l,s)),(null!=e.path||e.index)&&t.push({path:s,score:we(s,e.index),routesMeta:l})};return e.forEach(((e,t)=>{var r;if(""!==e.path&&null!=(r=e.path)&&r.includes("?"))for(let n of fe(e.path))i(e,t,n);else i(e,t)})),t}function fe(e){let t=e.split("/");if(0===t.length)return[];let[r,...n]=t,i=r.endsWith("?"),o=r.replace(/\?$/,"");if(0===n.length)return i?[o,""]:[o];let a=fe(n.join("/")),s=[];return s.push(...a.map((e=>""===e?o:[o,e].join("/")))),i&&s.push(...a),s.map((t=>e.startsWith("/")&&""===t?"/":t))}const me=/^:[\w-]+$/,ge=3,ye=2,ve=1,xe=10,be=-2,_e=e=>"*"===e;function we(e,t){let r=e.split("/"),n=r.length;return r.some(_e)&&(n+=be),t&&(n+=ye),r.filter((e=>!_e(e))).reduce(((e,t)=>e+(me.test(t)?ge:""===t?ve:xe)),n)}function ke(e,t,r){void 0===r&&(r=!1);let{routesMeta:n}=e,i={},o="/",a=[];for(let s=0;s(n.push({paramName:t,isOptional:null!=r}),r?"/?([^\\/]+)?":"/([^\\/]+)")));e.endsWith("*")?(n.push({paramName:"*"}),i+="*"===e||"/*"===e?"(.*)$":"(?:\\/(.+)|\\/*)$"):r?i+="\\/*$":""!==e&&"/"!==e&&(i+="(?:(?=\\/|$))");let o=new RegExp(i,t?void 0:"i");return[o,n]}(e.path,e.caseSensitive,e.end),i=t.match(r);if(!i)return null;let o=i[0],a=o.replace(/(.)\/+$/,"$1"),s=i.slice(1);return{params:n.reduce(((e,t,r)=>{let{paramName:n,isOptional:i}=t;if("*"===n){let e=s[r]||"";a=o.slice(0,o.length-e.length).replace(/(.)\/+$/,"$1")}const l=s[r];return e[n]=i&&!l?void 0:(l||"").replace(/%2F/g,"/"),e}),{}),pathname:o,pathnameBase:a,pattern:e}}function Ae(e){try{return e.split("/").map((e=>decodeURIComponent(e).replace(/\//g,"%2F"))).join("/")}catch(t){return ne(!1,'The URL path "'+e+'" could not be decoded because it is is a malformed URL segment. This is probably due to a bad percent encoding ('+t+")."),e}}function Te(e,t){if("/"===t)return e;if(!e.toLowerCase().startsWith(t.toLowerCase()))return null;let r=t.endsWith("/")?t.length-1:t.length,n=e.charAt(r);return n&&"/"!==n?null:e.slice(r)||"/"}function Me(e,t,r,n){return"Cannot include a '"+e+"' character in a manually specified `to."+t+"` field ["+JSON.stringify(n)+"]. Please separate it out to the `to."+r+'` field. Alternatively you may provide the full path as a string in and the router will parse it for you.'}function Ce(e){return e.filter(((e,t)=>0===t||e.route.path&&e.route.path.length>0))}function Ee(e,t){let r=Ce(e);return t?r.map(((e,t)=>t===r.length-1?e.pathname:e.pathnameBase)):r.map((e=>e.pathnameBase))}function Ie(e,t,r,n){let i;void 0===n&&(n=!1),"string"===typeof e?i=se(e):(i=J({},e),re(!i.pathname||!i.pathname.includes("?"),Me("?","pathname","search",i)),re(!i.pathname||!i.pathname.includes("#"),Me("#","pathname","hash",i)),re(!i.search||!i.search.includes("#"),Me("#","search","hash",i)));let o,a=""===e||""===i.pathname,s=a?"/":i.pathname;if(null==s)o=r;else{let e=t.length-1;if(!n&&s.startsWith("..")){let t=s.split("/");for(;".."===t[0];)t.shift(),e-=1;i.pathname=t.join("/")}o=e>=0?t[e]:"/"}let l=function(e,t){void 0===t&&(t="/");let{pathname:r,search:n="",hash:i=""}="string"===typeof e?se(e):e,o=r?r.startsWith("/")?r:function(e,t){let r=t.replace(/\/+$/,"").split("/");return e.split("/").forEach((e=>{".."===e?r.length>1&&r.pop():"."!==e&&r.push(e)})),r.length>1?r.join("/"):"/"}(r,t):t;return{pathname:o,search:Re(n),hash:Le(i)}}(i,o),c=s&&"/"!==s&&s.endsWith("/"),u=(a||"."===s)&&r.endsWith("/");return l.pathname.endsWith("/")||!c&&!u||(l.pathname+="/"),l}const Pe=e=>e.join("/").replace(/\/\/+/g,"/"),Oe=e=>e.replace(/\/+$/,"").replace(/^\/*/,"/"),Re=e=>e&&"?"!==e?e.startsWith("?")?e:"?"+e:"",Le=e=>e&&"#"!==e?e.startsWith("#")?e:"#"+e:"";Error;function De(e){return null!=e&&"number"===typeof e.status&&"string"===typeof e.statusText&&"boolean"===typeof e.internal&&"data"in e}const ze=["post","put","patch","delete"],je=(new Set(ze),["get",...ze]);new Set(je),new Set([301,302,303,307,308]),new Set([307,308]);Symbol("deferred");function Fe(){return Fe=Object.assign?Object.assign.bind():function(e){for(var t=1;t{r.current=!0})),n.useCallback((function(n,i){void 0===i&&(i={}),r.current&&("number"===typeof n?e.navigate(n):e.navigate(n,Fe({fromRouteId:t},i)))}),[e,t])}():function(){We()||re(!1);let e=n.useContext(Ne),{basename:t,future:r,navigator:i}=n.useContext(Ve),{matches:o}=n.useContext(He),{pathname:a}=qe(),s=JSON.stringify(Ee(o,r.v7_relativeSplatPath)),l=n.useRef(!1);return Ge((()=>{l.current=!0})),n.useCallback((function(r,n){if(void 0===n&&(n={}),!l.current)return;if("number"===typeof r)return void i.go(r);let o=Ie(r,JSON.parse(s),a,"path"===n.relative);null==e&&"/"!==t&&(o.pathname="/"===o.pathname?t:Pe([t,o.pathname])),(n.replace?i.replace:i.push)(o,n.state,n)}),[t,i,s,a,e])}()}function Xe(e,t){let{relative:r}=void 0===t?{}:t,{future:i}=n.useContext(Ve),{matches:o}=n.useContext(He),{pathname:a}=qe(),s=JSON.stringify(Ee(o,i.v7_relativeSplatPath));return n.useMemo((()=>Ie(e,JSON.parse(s),a,"path"===r)),[e,s,a,r])}function Ze(e,t,r,i){We()||re(!1);let{navigator:o}=n.useContext(Ve),{matches:a}=n.useContext(He),s=a[a.length-1],l=s?s.params:{},c=(s&&s.pathname,s?s.pathnameBase:"/");s&&s.route;let u,d=qe();if(t){var h;let e="string"===typeof t?se(t):t;"/"===c||(null==(h=e.pathname)?void 0:h.startsWith(c))||re(!1),u=e}else u=d;let p=u.pathname||"/",f=p;if("/"!==c){let e=c.replace(/^\//,"").split("/");f="/"+p.replace(/^\//,"").split("/").slice(e.length).join("/")}let m=de(e,{pathname:f});let g=tt(m&&m.map((e=>Object.assign({},e,{params:Object.assign({},l,e.params),pathname:Pe([c,o.encodeLocation?o.encodeLocation(e.pathname).pathname:e.pathname]),pathnameBase:"/"===e.pathnameBase?c:Pe([c,o.encodeLocation?o.encodeLocation(e.pathnameBase).pathname:e.pathnameBase])}))),a,r,i);return t&&g?n.createElement(Ue.Provider,{value:{location:Fe({pathname:"/",search:"",hash:"",state:null,key:"default"},u),navigationType:Q.Pop}},g):g}function Ke(){let e=function(){var e;let t=n.useContext($e),r=ot(nt.UseRouteError),i=at(nt.UseRouteError);if(void 0!==t)return t;return null==(e=r.errors)?void 0:e[i]}(),t=De(e)?e.status+" "+e.statusText:e instanceof Error?e.message:JSON.stringify(e),r=e instanceof Error?e.stack:null,i="rgba(200,200,200, 0.5)",o={padding:"0.5rem",backgroundColor:i};return n.createElement(n.Fragment,null,n.createElement("h2",null,"Unexpected Application Error!"),n.createElement("h3",{style:{fontStyle:"italic"}},t),r?n.createElement("pre",{style:o},r):null,null)}const Je=n.createElement(Ke,null);class Qe extends n.Component{constructor(e){super(e),this.state={location:e.location,revalidation:e.revalidation,error:e.error}}static getDerivedStateFromError(e){return{error:e}}static getDerivedStateFromProps(e,t){return t.location!==e.location||"idle"!==t.revalidation&&"idle"===e.revalidation?{error:e.error,location:e.location,revalidation:e.revalidation}:{error:void 0!==e.error?e.error:t.error,location:t.location,revalidation:e.revalidation||t.revalidation}}componentDidCatch(e,t){console.error("React Router caught the following error during render",e,t)}render(){return void 0!==this.state.error?n.createElement(He.Provider,{value:this.props.routeContext},n.createElement($e.Provider,{value:this.state.error,children:this.props.component})):this.props.children}}function et(e){let{routeContext:t,match:r,children:i}=e,o=n.useContext(Ne);return o&&o.static&&o.staticContext&&(r.route.errorElement||r.route.ErrorBoundary)&&(o.staticContext._deepestRenderedBoundaryId=r.route.id),n.createElement(He.Provider,{value:t},i)}function tt(e,t,r,i){var o;if(void 0===t&&(t=[]),void 0===r&&(r=null),void 0===i&&(i=null),null==e){var a;if(!r)return null;if(r.errors)e=r.matches;else{if(!(null!=(a=i)&&a.v7_partialHydration&&0===t.length&&!r.initialized&&r.matches.length>0))return null;e=r.matches}}let s=e,l=null==(o=r)?void 0:o.errors;if(null!=l){let e=s.findIndex((e=>e.route.id&&void 0!==(null==l?void 0:l[e.route.id])));e>=0||re(!1),s=s.slice(0,Math.min(s.length,e+1))}let c=!1,u=-1;if(r&&i&&i.v7_partialHydration)for(let n=0;n=0?s.slice(0,u+1):[s[0]];break}}}return s.reduceRight(((e,i,o)=>{let a,d=!1,h=null,p=null;var f;r&&(a=l&&i.route.id?l[i.route.id]:void 0,h=i.route.errorElement||Je,c&&(u<0&&0===o?(f="route-fallback",!1||st[f]||(st[f]=!0),d=!0,p=null):u===o&&(d=!0,p=i.route.hydrateFallbackElement||null)));let m=t.concat(s.slice(0,o+1)),g=()=>{let t;return t=a?h:d?p:i.route.Component?n.createElement(i.route.Component,null):i.route.element?i.route.element:e,n.createElement(et,{match:i,routeContext:{outlet:e,matches:m,isDataRoute:null!=r},children:t})};return r&&(i.route.ErrorBoundary||i.route.errorElement||0===o)?n.createElement(Qe,{location:r.location,revalidation:r.revalidation,component:h,error:a,children:g(),routeContext:{outlet:null,matches:m,isDataRoute:!0}}):g()}),null)}var rt=function(e){return e.UseBlocker="useBlocker",e.UseRevalidator="useRevalidator",e.UseNavigateStable="useNavigate",e}(rt||{}),nt=function(e){return e.UseBlocker="useBlocker",e.UseLoaderData="useLoaderData",e.UseActionData="useActionData",e.UseRouteError="useRouteError",e.UseNavigation="useNavigation",e.UseRouteLoaderData="useRouteLoaderData",e.UseMatches="useMatches",e.UseRevalidator="useRevalidator",e.UseNavigateStable="useNavigate",e.UseRouteId="useRouteId",e}(nt||{});function it(e){let t=n.useContext(Ne);return t||re(!1),t}function ot(e){let t=n.useContext(Be);return t||re(!1),t}function at(e){let t=function(){let e=n.useContext(He);return e||re(!1),e}(),r=t.matches[t.matches.length-1];return r.route.id||re(!1),r.route.id}const st={};const lt={};const ct=(e,t,r)=>{var n;lt[n="\u26a0\ufe0f React Router Future Flag Warning: "+t+". You can use the `"+e+"` future flag to opt-in early. For more information, see "+r+"."]||(lt[n]=!0,console.warn(n))};function ut(e,t){null!=e&&e.v7_startTransition||ct("v7_startTransition","React Router will begin wrapping state updates in `React.startTransition` in v7","https://reactrouter.com/v6/upgrading/future#v7_starttransition"),null!=e&&e.v7_relativeSplatPath||t&&t.v7_relativeSplatPath||ct("v7_relativeSplatPath","Relative route resolution within Splat routes is changing in v7","https://reactrouter.com/v6/upgrading/future#v7_relativesplatpath"),t&&(t.v7_fetcherPersist||ct("v7_fetcherPersist","The persistence behavior of fetchers is changing in v7","https://reactrouter.com/v6/upgrading/future#v7_fetcherpersist"),t.v7_normalizeFormMethod||ct("v7_normalizeFormMethod","Casing of `formMethod` fields is being normalized to uppercase in v7","https://reactrouter.com/v6/upgrading/future#v7_normalizeformmethod"),t.v7_partialHydration||ct("v7_partialHydration","`RouterProvider` hydration behavior is changing in v7","https://reactrouter.com/v6/upgrading/future#v7_partialhydration"),t.v7_skipActionErrorRevalidation||ct("v7_skipActionErrorRevalidation","The revalidation behavior after 4xx/5xx `action` responses is changing in v7","https://reactrouter.com/v6/upgrading/future#v7_skipactionerrorrevalidation"))}i.startTransition;function dt(e){let{to:t,replace:r,state:i,relative:o}=e;We()||re(!1);let{future:a,static:s}=n.useContext(Ve),{matches:l}=n.useContext(He),{pathname:c}=qe(),u=Ye(),d=Ie(t,Ee(l,a.v7_relativeSplatPath),c,"path"===o),h=JSON.stringify(d);return n.useEffect((()=>u(JSON.parse(h),{replace:r,state:i,relative:o})),[u,h,o,r,i]),null}function ht(e){re(!1)}function pt(e){let{basename:t="/",children:r=null,location:i,navigationType:o=Q.Pop,navigator:a,static:s=!1,future:l}=e;We()&&re(!1);let c=t.replace(/^\/*/,"/"),u=n.useMemo((()=>({basename:c,navigator:a,static:s,future:Fe({v7_relativeSplatPath:!1},l)})),[c,l,a,s]);"string"===typeof i&&(i=se(i));let{pathname:d="/",search:h="",hash:p="",state:f=null,key:m="default"}=i,g=n.useMemo((()=>{let e=Te(d,c);return null==e?null:{location:{pathname:e,search:h,hash:p,state:f,key:m},navigationType:o}}),[c,d,h,p,f,m,o]);return null==g?null:n.createElement(Ve.Provider,{value:u},n.createElement(Ue.Provider,{children:r,value:g}))}function ft(e){let{children:t,location:r}=e;return Ze(mt(t),r)}new Promise((()=>{}));n.Component;function mt(e,t){void 0===t&&(t=[]);let r=[];return n.Children.forEach(e,((e,i)=>{if(!n.isValidElement(e))return;let o=[...t,i];if(e.type===n.Fragment)return void r.push.apply(r,mt(e.props.children,o));e.type!==ht&&re(!1),e.props.index&&e.props.children&&re(!1);let a={id:e.props.id||o.join("-"),caseSensitive:e.props.caseSensitive,element:e.props.element,Component:e.props.Component,index:e.props.index,path:e.props.path,loader:e.props.loader,action:e.props.action,errorElement:e.props.errorElement,ErrorBoundary:e.props.ErrorBoundary,hasErrorBoundary:null!=e.props.ErrorBoundary||null!=e.props.errorElement,shouldRevalidate:e.props.shouldRevalidate,handle:e.props.handle,lazy:e.props.lazy};e.props.children&&(a.children=mt(e.props.children,o)),r.push(a)})),r}function gt(){return gt=Object.assign?Object.assign.bind():function(e){for(var t=1;t=0||(i[r]=e[r]);return i}function vt(e){return void 0===e&&(e=""),new URLSearchParams("string"===typeof e||Array.isArray(e)||e instanceof URLSearchParams?e:Object.keys(e).reduce(((t,r)=>{let n=e[r];return t.concat(Array.isArray(n)?n.map((e=>[r,e])):[[r,n]])}),[]))}new Set(["application/x-www-form-urlencoded","multipart/form-data","text/plain"]);const xt=["onClick","relative","reloadDocument","replace","state","target","to","preventScrollReset","viewTransition"];try{window.__reactRouterVersion="6"}catch(ene){}new Map;const bt=i.startTransition;l.flushSync,i.useId;function _t(e){let{basename:t,children:r,future:i,window:o}=e,a=n.useRef();var s;null==a.current&&(a.current=(void 0===(s={window:o,v5Compat:!0})&&(s={}),le((function(e,t){let{pathname:r,search:n,hash:i}=e.location;return oe("",{pathname:r,search:n,hash:i},t.state&&t.state.usr||null,t.state&&t.state.key||"default")}),(function(e,t){return"string"===typeof t?t:ae(t)}),null,s)));let l=a.current,[c,u]=n.useState({action:l.action,location:l.location}),{v7_startTransition:d}=i||{},h=n.useCallback((e=>{d&&bt?bt((()=>u(e))):u(e)}),[u,d]);return n.useLayoutEffect((()=>l.listen(h)),[l,h]),n.useEffect((()=>ut(i)),[i]),n.createElement(pt,{basename:t,children:r,location:c.location,navigationType:c.action,navigator:l,future:i})}const wt="undefined"!==typeof window&&"undefined"!==typeof window.document&&"undefined"!==typeof window.document.createElement,kt=/^(?:[a-z][a-z0-9+.-]*:|\/\/)/i,St=n.forwardRef((function(e,t){let r,{onClick:i,relative:o,reloadDocument:a,replace:s,state:l,target:c,to:u,preventScrollReset:d,viewTransition:h}=e,p=yt(e,xt),{basename:f}=n.useContext(Ve),m=!1;if("string"===typeof u&&kt.test(u)&&(r=u,wt))try{let e=new URL(window.location.href),t=u.startsWith("//")?new URL(e.protocol+u):new URL(u),r=Te(t.pathname,f);t.origin===e.origin&&null!=r?u=r+t.search+t.hash:m=!0}catch(ene){}let g=function(e,t){let{relative:r}=void 0===t?{}:t;We()||re(!1);let{basename:i,navigator:o}=n.useContext(Ve),{hash:a,pathname:s,search:l}=Xe(e,{relative:r}),c=s;return"/"!==i&&(c="/"===s?i:Pe([i,s])),o.createHref({pathname:c,search:l,hash:a})}(u,{relative:o}),y=function(e,t){let{target:r,replace:i,state:o,preventScrollReset:a,relative:s,viewTransition:l}=void 0===t?{}:t,c=Ye(),u=qe(),d=Xe(e,{relative:s});return n.useCallback((t=>{if(function(e,t){return 0===e.button&&(!t||"_self"===t)&&!function(e){return!!(e.metaKey||e.altKey||e.ctrlKey||e.shiftKey)}(e)}(t,r)){t.preventDefault();let r=void 0!==i?i:ae(u)===ae(d);c(e,{replace:r,state:o,preventScrollReset:a,relative:s,viewTransition:l})}}),[u,c,d,i,o,r,e,a,s,l])}(u,{replace:s,state:l,target:c,preventScrollReset:d,relative:o,viewTransition:h});return n.createElement("a",gt({},p,{href:r||g,onClick:m||a?i:function(e){i&&i(e),e.defaultPrevented||y(e)},ref:t,target:c}))}));var At,Tt,Mt,Ct;function Et(e){let t=n.useRef(vt(e)),r=n.useRef(!1),i=qe(),o=n.useMemo((()=>function(e,t){let r=vt(e);return t&&t.forEach(((e,n)=>{r.has(n)||t.getAll(n).forEach((e=>{r.append(n,e)}))})),r}(i.search,r.current?null:t.current)),[i.search]),a=Ye(),s=n.useCallback(((e,t)=>{const n=vt("function"===typeof e?e(o):e);r.current=!0,a("?"+n,t)}),[a,o]);return[o,s]}(Tt=At||(At={})).UseScrollRestoration="useScrollRestoration",Tt.UseSubmit="useSubmit",Tt.UseSubmitFetcher="useSubmitFetcher",Tt.UseFetcher="useFetcher",Tt.useViewTransitionState="useViewTransitionState",(Ct=Mt||(Mt={})).UseFetcher="useFetcher",Ct.UseFetchers="useFetchers",Ct.UseScrollRestoration="useScrollRestoration";function It(e){var t,r,n="";if("string"==typeof e||"number"==typeof e)n+=e;else if("object"==typeof e)if(Array.isArray(e))for(t=0;t"object"==typeof window?((e?e.querySelector("#_goober"):window._goober)||Object.assign((e||document.head).appendChild(document.createElement("style")),{innerHTML:" ",id:"_goober"})).firstChild:e||Ot,Lt=/(?:([\u0080-\uFFFF\w-%@]+) *:? *([^{;]+?);|([^;}{]*?) *{)|(}\s*)/g,Dt=/\/\*[^]*?\*\/| +/g,zt=/\n+/g,jt=(e,t)=>{let r="",n="",i="";for(let o in e){let a=e[o];"@"==o[0]?"i"==o[1]?r=o+" "+a+";":n+="f"==o[1]?jt(a,o):o+"{"+jt(a,"k"==o[1]?"":t)+"}":"object"==typeof a?n+=jt(a,t?t.replace(/([^,])+/g,(e=>o.replace(/([^,]*:\S+\([^)]*\))|([^,])+/g,(t=>/&/.test(t)?t.replace(/&/g,e):e?e+" "+t:t)))):o):null!=a&&(o=/^--/.test(o)?o:o.replace(/[A-Z]/g,"-$&").toLowerCase(),i+=jt.p?jt.p(o,a):o+":"+a+";")}return r+(t&&i?t+"{"+i+"}":i)+n},Ft={},Nt=e=>{if("object"==typeof e){let t="";for(let r in e)t+=r+Nt(e[r]);return t}return e};function Bt(e){let t=this||{},r=e.call?e(t.p):e;return((e,t,r,n,i)=>{let o=Nt(e),a=Ft[o]||(Ft[o]=(e=>{let t=0,r=11;for(;t>>0;return"go"+r})(o));if(!Ft[a]){let t=o!==e?e:(e=>{let t,r,n=[{}];for(;t=Lt.exec(e.replace(Dt,""));)t[4]?n.shift():t[3]?(r=t[3].replace(zt," ").trim(),n.unshift(n[0][r]=n[0][r]||{})):n[0][t[1]]=t[2].replace(zt," ").trim();return n[0]})(e);Ft[a]=jt(i?{["@keyframes "+a]:t}:t,r?"":"."+a)}let s=r&&Ft.g?Ft.g:null;return r&&(Ft.g=Ft[a]),((e,t,r,n)=>{n?t.data=t.data.replace(n,e):-1===t.data.indexOf(e)&&(t.data=r?e+t.data:t.data+e)})(Ft[a],t,n,s),a})(r.unshift?r.raw?((e,t,r)=>e.reduce(((e,n,i)=>{let o=t[i];if(o&&o.call){let e=o(r),t=e&&e.props&&e.props.className||/^go/.test(e)&&e;o=t?"."+t:e&&"object"==typeof e?e.props?"":jt(e,""):!1===e?"":e}return e+n+(null==o?"":o)}),""))(r,[].slice.call(arguments,1),t.p):r.reduce(((e,r)=>Object.assign(e,r&&r.call?r(t.p):r)),{}):r,Rt(t.target),t.g,t.o,t.k)}Bt.bind({g:1}),Bt.bind({k:1});function Vt(e,t){for(var r=0;r=0||(i[r]=e[r]);return i}function qt(e){if(void 0===e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return e}var Gt=function(){return""},Yt=n.createContext({enqueueSnackbar:Gt,closeSnackbar:Gt}),Xt="@media (max-width:599.95px)",Zt="@media (min-width:600px)",Kt=function(e){return e.charAt(0).toUpperCase()+e.slice(1)},Jt=function(e){return""+Kt(e.vertical)+Kt(e.horizontal)},Qt=function(e){return!!e||0===e},er="unmounted",tr="exited",rr="entering",nr="entered",ir="exiting",or=function(e){function t(t){var r;r=e.call(this,t)||this;var n,i=t.appear;return r.appearStatus=null,t.in?i?(n=tr,r.appearStatus=rr):n=nr:n=t.unmountOnExit||t.mountOnEnter?er:tr,r.state={status:n},r.nextCallback=null,r}$t(t,e),t.getDerivedStateFromProps=function(e,t){return e.in&&t.status===er?{status:tr}:null};var r=t.prototype;return r.componentDidMount=function(){this.updateStatus(!0,this.appearStatus)},r.componentDidUpdate=function(e){var t=null;if(e!==this.props){var r=this.state.status;this.props.in?r!==rr&&r!==nr&&(t=rr):r!==rr&&r!==nr||(t=ir)}this.updateStatus(!1,t)},r.componentWillUnmount=function(){this.cancelNextCallback()},r.getTimeouts=function(){var e=this.props.timeout,t=e,r=e;return null!=e&&"number"!==typeof e&&"string"!==typeof e&&(r=e.exit,t=e.enter),{exit:r,enter:t}},r.updateStatus=function(e,t){void 0===e&&(e=!1),null!==t?(this.cancelNextCallback(),t===rr?this.performEnter(e):this.performExit()):this.props.unmountOnExit&&this.state.status===tr&&this.setState({status:er})},r.performEnter=function(e){var t=this,r=this.props.enter,n=e,i=this.getTimeouts();e||r?(this.props.onEnter&&this.props.onEnter(this.node,n),this.safeSetState({status:rr},(function(){t.props.onEntering&&t.props.onEntering(t.node,n),t.onTransitionEnd(i.enter,(function(){t.safeSetState({status:nr},(function(){t.props.onEntered&&t.props.onEntered(t.node,n)}))}))}))):this.safeSetState({status:nr},(function(){t.props.onEntered&&t.props.onEntered(t.node,n)}))},r.performExit=function(){var e=this,t=this.props.exit,r=this.getTimeouts();t?(this.props.onExit&&this.props.onExit(this.node),this.safeSetState({status:ir},(function(){e.props.onExiting&&e.props.onExiting(e.node),e.onTransitionEnd(r.exit,(function(){e.safeSetState({status:tr},(function(){e.props.onExited&&e.props.onExited(e.node)}))}))}))):this.safeSetState({status:tr},(function(){e.props.onExited&&e.props.onExited(e.node)}))},r.cancelNextCallback=function(){null!==this.nextCallback&&this.nextCallback.cancel&&(this.nextCallback.cancel(),this.nextCallback=null)},r.safeSetState=function(e,t){t=this.setNextCallback(t),this.setState(e,t)},r.setNextCallback=function(e){var t=this,r=!0;return this.nextCallback=function(){r&&(r=!1,t.nextCallback=null,e())},this.nextCallback.cancel=function(){r=!1},this.nextCallback},r.onTransitionEnd=function(e,t){this.setNextCallback(t);var r=null==e&&!this.props.addEndListener;this.node&&!r?(this.props.addEndListener&&this.props.addEndListener(this.node,this.nextCallback),null!=e&&setTimeout(this.nextCallback,e)):setTimeout(this.nextCallback,0)},r.render=function(){var e=this.state.status;if(e===er)return null;var t=this.props;return(0,t.children)(e,Wt(t,["children","in","mountOnEnter","unmountOnExit","appear","enter","exit","timeout","addEndListener","onEnter","onEntering","onEntered","onExit","onExiting","onExited","nodeRef"]))},Ut(t,[{key:"node",get:function(){var e,t=null===(e=this.props.nodeRef)||void 0===e?void 0:e.current;if(!t)throw new Error("notistack - Custom snackbar is not refForwarding");return t}}]),t}(n.Component);function ar(){}function sr(e,t){"function"===typeof e?e(t):e&&(e.current=t)}function lr(e,t){return(0,n.useMemo)((function(){return null==e&&null==t?null:function(r){sr(e,r),sr(t,r)}}),[e,t])}function cr(e){var t=e.timeout,r=e.style,n=void 0===r?{}:r,i=e.mode;return{duration:"object"===typeof t?t[i]||0:t,easing:n.transitionTimingFunction,delay:n.transitionDelay}}or.defaultProps={in:!1,mountOnEnter:!1,unmountOnExit:!1,appear:!1,enter:!0,exit:!0,onEnter:ar,onEntering:ar,onEntered:ar,onExit:ar,onExiting:ar,onExited:ar};var ur="cubic-bezier(0.4, 0, 0.2, 1)",dr="cubic-bezier(0.0, 0, 0.2, 1)",hr="cubic-bezier(0.4, 0, 0.6, 1)",pr=function(e){e.scrollTop=e.scrollTop},fr=function(e){return Math.round(e)+"ms"};function mr(e,t){void 0===e&&(e=["all"]);var r=t||{},n=r.duration,i=void 0===n?300:n,o=r.easing,a=void 0===o?ur:o,s=r.delay,l=void 0===s?0:s;return(Array.isArray(e)?e:[e]).map((function(e){var t="string"===typeof i?i:fr(i),r="string"===typeof l?l:fr(l);return e+" "+t+" "+a+" "+r})).join(",")}function gr(e){var t=function(e){return e&&e.ownerDocument||document}(e);return t.defaultView||window}function yr(e,t){if(t){var r=function(e,t){var r,n=t.getBoundingClientRect(),i=gr(t);if(t.fakeTransform)r=t.fakeTransform;else{var o=i.getComputedStyle(t);r=o.getPropertyValue("-webkit-transform")||o.getPropertyValue("transform")}var a=0,s=0;if(r&&"none"!==r&&"string"===typeof r){var l=r.split("(")[1].split(")")[0].split(",");a=parseInt(l[4],10),s=parseInt(l[5],10)}switch(e){case"left":return"translateX("+(i.innerWidth+a-n.left)+"px)";case"right":return"translateX(-"+(n.left+n.width-a)+"px)";case"up":return"translateY("+(i.innerHeight+s-n.top)+"px)";default:return"translateY(-"+(n.top+n.height-s)+"px)"}}(e,t);r&&(t.style.webkitTransform=r,t.style.transform=r)}}var vr=(0,n.forwardRef)((function(e,t){var r=e.children,i=e.direction,o=void 0===i?"down":i,a=e.in,s=e.style,l=e.timeout,c=void 0===l?0:l,u=e.onEnter,d=e.onEntered,h=e.onExit,p=e.onExited,f=Wt(e,["children","direction","in","style","timeout","onEnter","onEntered","onExit","onExited"]),m=(0,n.useRef)(null),g=lr(r.ref,m),y=lr(g,t),v=(0,n.useCallback)((function(){m.current&&yr(o,m.current)}),[o]);return(0,n.useEffect)((function(){if(!a&&"down"!==o&&"right"!==o){var e=function(e,t){var r;function n(){for(var n=this,i=arguments.length,o=new Array(i),a=0;a-1,o=e.snacks.findIndex(t)>-1;if(n||o)return e}return r.handleDisplaySnack(Ht({},e,{queue:[].concat(e.queue,[d])}))})),c},r.handleDisplaySnack=function(e){return e.snacks.length>=r.maxSnack?r.handleDismissOldest(e):r.processQueue(e)},r.processQueue=function(e){var t=e.queue,r=e.snacks;return t.length>0?Ht({},e,{snacks:[].concat(r,[t[0]]),queue:t.slice(1,t.length)}):e},r.handleDismissOldest=function(e){if(e.snacks.some((function(e){return!e.open||e.requestClose})))return e;var t=!1,n=!1;e.snacks.reduce((function(e,t){return e+(t.open&&t.persist?1:0)}),0)===r.maxSnack&&(n=!0);var i=e.snacks.map((function(e){return t||e.persist&&!n?Ht({},e):(t=!0,e.entered?(e.onClose&&e.onClose(null,"maxsnack",e.id),r.props.onClose&&r.props.onClose(null,"maxsnack",e.id),Ht({},e,{open:!1})):Ht({},e,{requestClose:!0}))}));return Ht({},e,{snacks:i})},r.handleEnteredSnack=function(e,t,n){if(!Qt(n))throw new Error("handleEnteredSnack Cannot be called with undefined key");r.setState((function(e){return{snacks:e.snacks.map((function(e){return e.id===n?Ht({},e,{entered:!0}):Ht({},e)}))}}))},r.handleCloseSnack=function(e,t,n){r.props.onClose&&r.props.onClose(e,t,n);var i=void 0===n;r.setState((function(e){var t=e.snacks,r=e.queue;return{snacks:t.map((function(e){return i||e.id===n?e.entered?Ht({},e,{open:!1}):Ht({},e,{requestClose:!0}):Ht({},e)})),queue:r.filter((function(e){return e.id!==n}))}}))},r.closeSnackbar=function(e){var t=r.state.snacks.find((function(t){return t.id===e}));Qt(e)&&t&&t.onClose&&t.onClose(null,"instructed",e),r.handleCloseSnack(null,"instructed",e)},r.handleExitedSnack=function(e,t){if(!Qt(t))throw new Error("handleExitedSnack Cannot be called with undefined key");r.setState((function(e){var n=r.processQueue(Ht({},e,{snacks:e.snacks.filter((function(e){return e.id!==t}))}));return 0===n.queue.length?n:r.handleDismissOldest(n)}))},Qr=r.enqueueSnackbar,r.closeSnackbar,r.state={snacks:[],queue:[],contextValue:{enqueueSnackbar:r.enqueueSnackbar.bind(qt(r)),closeSnackbar:r.closeSnackbar.bind(qt(r))}},r}return $t(t,e),t.prototype.render=function(){var e=this,t=this.state.contextValue,r=this.props,i=r.domRoot,o=r.children,a=r.dense,l=void 0!==a&&a,c=r.Components,u=void 0===c?{}:c,d=r.classes,h=this.state.snacks.reduce((function(e,t){var r,n=Jt(t.anchorOrigin),i=e[n]||[];return Ht({},e,((r={})[n]=[].concat(i,[t]),r))}),{}),p=Object.keys(h).map((function(t){var r=h[t],i=r[0];return n.createElement(cn,{key:t,dense:l,anchorOrigin:i.anchorOrigin,classes:d},r.map((function(t){return n.createElement(rn,{key:t.id,snack:t,classes:d,Component:u[t.variant],onClose:e.handleCloseSnack,onEnter:e.props.onEnter,onExit:e.props.onExit,onExited:Fr([e.handleExitedSnack,e.props.onExited],t.id),onEntered:Fr([e.handleEnteredSnack,e.props.onEntered],t.id)})})))}));return n.createElement(Yt.Provider,{value:t},o,i?(0,s.createPortal)(p,i):p)},Ut(t,[{key:"maxSnack",get:function(){return this.props.maxSnack||Sr.maxSnack}}]),t}(n.Component),hn=function(){return(0,n.useContext)(Yt)},pn=r(74802),fn=r(58387),mn=r(98610),gn=r(67266),yn=r(34535),vn=r(98206),xn=r(95849),bn=r(93319),_n=r(87844);function wn(e,t){return wn=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(e,t){return e.__proto__=t,e},wn(e,t)}function kn(e,t){e.prototype=Object.create(t.prototype),e.prototype.constructor=e,wn(e,t)}const Sn=n.createContext(null);function An(e,t){var r=Object.create(null);return e&&n.Children.map(e,(function(e){return e})).forEach((function(e){r[e.key]=function(e){return t&&(0,n.isValidElement)(e)?t(e):e}(e)})),r}function Tn(e,t,r){return null!=r[t]?r[t]:e.props[t]}function Mn(e,t,r){var i=An(e.children),o=function(e,t){function r(r){return r in t?t[r]:e[r]}e=e||{},t=t||{};var n,i=Object.create(null),o=[];for(var a in e)a in t?o.length&&(i[a]=o,o=[]):o.push(a);var s={};for(var l in t){if(i[l])for(n=0;n{if(!l&&null!=c){const e=setTimeout(c,u);return()=>{clearTimeout(e)}}}),[c,l,u]),(0,j.jsx)("span",{className:p,style:f,children:(0,j.jsx)("span",{className:m})})};var Ln=r(92532);const Dn=(0,Ln.A)("MuiTouchRipple",["root","ripple","rippleVisible","ripplePulsate","child","childLeaving","childPulsate"]),zn=["center","classes","className"];let jn,Fn,Nn,Bn,Vn=e=>e;const Un=(0,Pn.i7)(jn||(jn=Vn` + 0% { + transform: scale(0); + opacity: 0.1; + } + + 100% { + transform: scale(1); + opacity: 0.3; + } +`)),Hn=(0,Pn.i7)(Fn||(Fn=Vn` + 0% { + opacity: 1; + } + + 100% { + opacity: 0; + } +`)),$n=(0,Pn.i7)(Nn||(Nn=Vn` + 0% { + transform: scale(1); + } + + 50% { + transform: scale(0.92); + } + + 100% { + transform: scale(1); + } +`)),Wn=(0,yn.Ay)("span",{name:"MuiTouchRipple",slot:"Root"})({overflow:"hidden",pointerEvents:"none",position:"absolute",zIndex:0,top:0,right:0,bottom:0,left:0,borderRadius:"inherit"}),qn=(0,yn.Ay)(Rn,{name:"MuiTouchRipple",slot:"Ripple"})(Bn||(Bn=Vn` + opacity: 0; + position: absolute; + + &.${0} { + opacity: 0.3; + transform: scale(1); + animation-name: ${0}; + animation-duration: ${0}ms; + animation-timing-function: ${0}; + } + + &.${0} { + animation-duration: ${0}ms; + } + + & .${0} { + opacity: 1; + display: block; + width: 100%; + height: 100%; + border-radius: 50%; + background-color: currentColor; + } + + & .${0} { + opacity: 0; + animation-name: ${0}; + animation-duration: ${0}ms; + animation-timing-function: ${0}; + } + + & .${0} { + position: absolute; + /* @noflip */ + left: 0px; + top: 0; + animation-name: ${0}; + animation-duration: 2500ms; + animation-timing-function: ${0}; + animation-iteration-count: infinite; + animation-delay: 200ms; + } +`),Dn.rippleVisible,Un,550,(e=>{let{theme:t}=e;return t.transitions.easing.easeInOut}),Dn.ripplePulsate,(e=>{let{theme:t}=e;return t.transitions.duration.shorter}),Dn.child,Dn.childLeaving,Hn,550,(e=>{let{theme:t}=e;return t.transitions.easing.easeInOut}),Dn.childPulsate,$n,(e=>{let{theme:t}=e;return t.transitions.easing.easeInOut})),Gn=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiTouchRipple"}),{center:i=!1,classes:o={},className:a}=r,s=(0,R.A)(r,zn),[l,c]=n.useState([]),u=n.useRef(0),d=n.useRef(null);n.useEffect((()=>{d.current&&(d.current(),d.current=null)}),[l]);const h=n.useRef(!1),p=(0,On.A)(),f=n.useRef(null),m=n.useRef(null),g=n.useCallback((e=>{const{pulsate:t,rippleX:r,rippleY:n,rippleSize:i,cb:a}=e;c((e=>[...e,(0,j.jsx)(qn,{classes:{ripple:(0,fn.A)(o.ripple,Dn.ripple),rippleVisible:(0,fn.A)(o.rippleVisible,Dn.rippleVisible),ripplePulsate:(0,fn.A)(o.ripplePulsate,Dn.ripplePulsate),child:(0,fn.A)(o.child,Dn.child),childLeaving:(0,fn.A)(o.childLeaving,Dn.childLeaving),childPulsate:(0,fn.A)(o.childPulsate,Dn.childPulsate)},timeout:550,pulsate:t,rippleX:r,rippleY:n,rippleSize:i},u.current)])),u.current+=1,d.current=a}),[o]),y=n.useCallback((function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:()=>{};const{pulsate:n=!1,center:o=i||t.pulsate,fakeElement:a=!1}=t;if("mousedown"===(null==e?void 0:e.type)&&h.current)return void(h.current=!1);"touchstart"===(null==e?void 0:e.type)&&(h.current=!0);const s=a?null:m.current,l=s?s.getBoundingClientRect():{width:0,height:0,left:0,top:0};let c,u,d;if(o||void 0===e||0===e.clientX&&0===e.clientY||!e.clientX&&!e.touches)c=Math.round(l.width/2),u=Math.round(l.height/2);else{const{clientX:t,clientY:r}=e.touches&&e.touches.length>0?e.touches[0]:e;c=Math.round(t-l.left),u=Math.round(r-l.top)}if(o)d=Math.sqrt((2*l.width**2+l.height**2)/3),d%2===0&&(d+=1);else{const e=2*Math.max(Math.abs((s?s.clientWidth:0)-c),c)+2,t=2*Math.max(Math.abs((s?s.clientHeight:0)-u),u)+2;d=Math.sqrt(e**2+t**2)}null!=e&&e.touches?null===f.current&&(f.current=()=>{g({pulsate:n,rippleX:c,rippleY:u,rippleSize:d,cb:r})},p.start(80,(()=>{f.current&&(f.current(),f.current=null)}))):g({pulsate:n,rippleX:c,rippleY:u,rippleSize:d,cb:r})}),[i,g,p]),v=n.useCallback((()=>{y({},{pulsate:!0})}),[y]),x=n.useCallback(((e,t)=>{if(p.clear(),"touchend"===(null==e?void 0:e.type)&&f.current)return f.current(),f.current=null,void p.start(0,(()=>{x(e,t)}));f.current=null,c((e=>e.length>0?e.slice(1):e)),d.current=t}),[p]);return n.useImperativeHandle(t,(()=>({pulsate:v,start:y,stop:x})),[v,y,x]),(0,j.jsx)(Wn,(0,O.A)({className:(0,fn.A)(Dn.root,o.root,a),ref:m},s,{children:(0,j.jsx)(In,{component:null,exit:!0,children:l})}))}));var Yn=r(72372);function Xn(e){return(0,Yn.Ay)("MuiButtonBase",e)}const Zn=(0,Ln.A)("MuiButtonBase",["root","disabled","focusVisible"]),Kn=["action","centerRipple","children","className","component","disabled","disableRipple","disableTouchRipple","focusRipple","focusVisibleClassName","LinkComponent","onBlur","onClick","onContextMenu","onDragLeave","onFocus","onFocusVisible","onKeyDown","onKeyUp","onMouseDown","onMouseLeave","onMouseUp","onTouchEnd","onTouchMove","onTouchStart","tabIndex","TouchRippleProps","touchRippleRef","type"],Jn=(0,yn.Ay)("button",{name:"MuiButtonBase",slot:"Root",overridesResolver:(e,t)=>t.root})({display:"inline-flex",alignItems:"center",justifyContent:"center",position:"relative",boxSizing:"border-box",WebkitTapHighlightColor:"transparent",backgroundColor:"transparent",outline:0,border:0,margin:0,borderRadius:0,padding:0,cursor:"pointer",userSelect:"none",verticalAlign:"middle",MozAppearance:"none",WebkitAppearance:"none",textDecoration:"none",color:"inherit","&::-moz-focus-inner":{borderStyle:"none"},[`&.${Zn.disabled}`]:{pointerEvents:"none",cursor:"default"},"@media print":{colorAdjust:"exact"}}),Qn=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiButtonBase"}),{action:i,centerRipple:o=!1,children:a,className:s,component:l="button",disabled:c=!1,disableRipple:u=!1,disableTouchRipple:d=!1,focusRipple:h=!1,LinkComponent:p="a",onBlur:f,onClick:m,onContextMenu:g,onDragLeave:y,onFocus:v,onFocusVisible:x,onKeyDown:b,onKeyUp:_,onMouseDown:w,onMouseLeave:k,onMouseUp:S,onTouchEnd:A,onTouchMove:T,onTouchStart:M,tabIndex:C=0,TouchRippleProps:E,touchRippleRef:I,type:P}=r,L=(0,R.A)(r,Kn),D=n.useRef(null),z=n.useRef(null),F=(0,xn.A)(z,I),{isFocusVisibleRef:N,onFocus:B,onBlur:V,ref:U}=(0,_n.A)(),[H,$]=n.useState(!1);c&&H&&$(!1),n.useImperativeHandle(i,(()=>({focusVisible:()=>{$(!0),D.current.focus()}})),[]);const[W,q]=n.useState(!1);n.useEffect((()=>{q(!0)}),[]);const G=W&&!u&&!c;function Y(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:d;return(0,bn.A)((n=>{t&&t(n);return!r&&z.current&&z.current[e](n),!0}))}n.useEffect((()=>{H&&h&&!u&&W&&z.current.pulsate()}),[u,h,H,W]);const X=Y("start",w),Z=Y("stop",g),K=Y("stop",y),J=Y("stop",S),Q=Y("stop",(e=>{H&&e.preventDefault(),k&&k(e)})),ee=Y("start",M),te=Y("stop",A),re=Y("stop",T),ne=Y("stop",(e=>{V(e),!1===N.current&&$(!1),f&&f(e)}),!1),ie=(0,bn.A)((e=>{D.current||(D.current=e.currentTarget),B(e),!0===N.current&&($(!0),x&&x(e)),v&&v(e)})),oe=()=>{const e=D.current;return l&&"button"!==l&&!("A"===e.tagName&&e.href)},ae=n.useRef(!1),se=(0,bn.A)((e=>{h&&!ae.current&&H&&z.current&&" "===e.key&&(ae.current=!0,z.current.stop(e,(()=>{z.current.start(e)}))),e.target===e.currentTarget&&oe()&&" "===e.key&&e.preventDefault(),b&&b(e),e.target===e.currentTarget&&oe()&&"Enter"===e.key&&!c&&(e.preventDefault(),m&&m(e))})),le=(0,bn.A)((e=>{h&&" "===e.key&&z.current&&H&&!e.defaultPrevented&&(ae.current=!1,z.current.stop(e,(()=>{z.current.pulsate(e)}))),_&&_(e),m&&e.target===e.currentTarget&&oe()&&" "===e.key&&!e.defaultPrevented&&m(e)}));let ce=l;"button"===ce&&(L.href||L.to)&&(ce=p);const ue={};"button"===ce?(ue.type=void 0===P?"button":P,ue.disabled=c):(L.href||L.to||(ue.role="button"),c&&(ue["aria-disabled"]=c));const de=(0,xn.A)(t,U,D);const he=(0,O.A)({},r,{centerRipple:o,component:l,disabled:c,disableRipple:u,disableTouchRipple:d,focusRipple:h,tabIndex:C,focusVisible:H}),pe=(e=>{const{disabled:t,focusVisible:r,focusVisibleClassName:n,classes:i}=e,o={root:["root",t&&"disabled",r&&"focusVisible"]},a=(0,mn.A)(o,Xn,i);return r&&n&&(a.root+=` ${n}`),a})(he);return(0,j.jsxs)(Jn,(0,O.A)({as:ce,className:(0,fn.A)(pe.root,s),ownerState:he,onBlur:ne,onClick:m,onContextMenu:Z,onFocus:ie,onKeyDown:se,onKeyUp:le,onMouseDown:X,onMouseLeave:Q,onMouseUp:J,onDragLeave:K,onTouchEnd:te,onTouchMove:re,onTouchStart:ee,ref:de,tabIndex:c?-1:C,type:P},ue,L,{children:[a,G?(0,j.jsx)(Gn,(0,O.A)({ref:F,center:o},E)):null]}))}));var ei=r(6803);function ti(e){return(0,Yn.Ay)("MuiIconButton",e)}const ri=(0,Ln.A)("MuiIconButton",["root","disabled","colorInherit","colorPrimary","colorSecondary","colorError","colorInfo","colorSuccess","colorWarning","edgeStart","edgeEnd","sizeSmall","sizeMedium","sizeLarge"]),ni=["edge","children","className","color","disabled","disableFocusRipple","size"],ii=(0,yn.Ay)(Qn,{name:"MuiIconButton",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,"default"!==r.color&&t[`color${(0,ei.A)(r.color)}`],r.edge&&t[`edge${(0,ei.A)(r.edge)}`],t[`size${(0,ei.A)(r.size)}`]]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({textAlign:"center",flex:"0 0 auto",fontSize:t.typography.pxToRem(24),padding:8,borderRadius:"50%",overflow:"visible",color:(t.vars||t).palette.action.active,transition:t.transitions.create("background-color",{duration:t.transitions.duration.shortest})},!r.disableRipple&&{"&:hover":{backgroundColor:t.vars?`rgba(${t.vars.palette.action.activeChannel} / ${t.vars.palette.action.hoverOpacity})`:(0,gn.X4)(t.palette.action.active,t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},"start"===r.edge&&{marginLeft:"small"===r.size?-3:-12},"end"===r.edge&&{marginRight:"small"===r.size?-3:-12})}),(e=>{let{theme:t,ownerState:r}=e;var n;const i=null==(n=(t.vars||t).palette)?void 0:n[r.color];return(0,O.A)({},"inherit"===r.color&&{color:"inherit"},"inherit"!==r.color&&"default"!==r.color&&(0,O.A)({color:null==i?void 0:i.main},!r.disableRipple&&{"&:hover":(0,O.A)({},i&&{backgroundColor:t.vars?`rgba(${i.mainChannel} / ${t.vars.palette.action.hoverOpacity})`:(0,gn.X4)(i.main,t.palette.action.hoverOpacity)},{"@media (hover: none)":{backgroundColor:"transparent"}})}),"small"===r.size&&{padding:5,fontSize:t.typography.pxToRem(18)},"large"===r.size&&{padding:12,fontSize:t.typography.pxToRem(28)},{[`&.${ri.disabled}`]:{backgroundColor:"transparent",color:(t.vars||t).palette.action.disabled}})})),oi=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiIconButton"}),{edge:n=!1,children:i,className:o,color:a="default",disabled:s=!1,disableFocusRipple:l=!1,size:c="medium"}=r,u=(0,R.A)(r,ni),d=(0,O.A)({},r,{edge:n,color:a,disabled:s,disableFocusRipple:l,size:c}),h=(e=>{const{classes:t,disabled:r,color:n,edge:i,size:o}=e,a={root:["root",r&&"disabled","default"!==n&&`color${(0,ei.A)(n)}`,i&&`edge${(0,ei.A)(i)}`,`size${(0,ei.A)(o)}`]};return(0,mn.A)(a,ti,t)})(d);return(0,j.jsx)(ii,(0,O.A)({className:(0,fn.A)(h.root,o),centerRipple:!0,focusRipple:!l,disabled:s,ref:t},u,{ownerState:d,children:i}))}));var ai=r(82030),si=r(58812),li=r(18698),ci=r(18280);const ui=(0,ci.A)();const di=function(){return B(arguments.length>0&&void 0!==arguments[0]?arguments[0]:ui)},hi=["className","component"];var pi=r(79386),fi=r(40688);const mi=(0,Ln.A)("MuiBox",["root"]),gi=(0,fi.A)(),yi=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const{themeId:t,defaultTheme:r,defaultClassName:i="MuiBox-root",generateClassName:o}=e,a=(0,ai.default)("div",{shouldForwardProp:e=>"theme"!==e&&"sx"!==e&&"as"!==e})(si.A);return n.forwardRef((function(e,n){const s=di(r),l=(0,li.A)(e),{className:c,component:u="div"}=l,d=(0,R.A)(l,hi);return(0,j.jsx)(a,(0,O.A)({as:u,ref:n,className:(0,fn.A)(c,o?o(i):i),theme:t&&s[t]||s},d))}))}({themeId:X.A,defaultTheme:gi,defaultClassName:mi.root,generateClassName:pi.A.generate}),vi=(0,yn.Ay)(yi,{shouldForwardProp:e=>"position"!==e})((e=>{let{position:t}=e;return{top:0,bottom:0,left:0,right:0,position:t,backgroundColor:"rgba(255,255,255,0.6)",zIndex:1e5}})),xi=Pn.i7` + 100% {transform: rotate(360deg)} +`,bi=Pn.i7` + 0% {clip-path:polygon(50% 50%,0 0,0 0,0 0,0 0,0 0)} + 25% {clip-path:polygon(50% 50%,0 0,100% 0,100% 0,100% 0,100% 0)} + 50% {clip-path:polygon(50% 50%,0 0,100% 0,100% 100%,100% 100%,100% 100%)} + 75% {clip-path:polygon(50% 50%,0 0,100% 0,100% 100%,0 100%,0 100%)} + 100% {clip-path:polygon(50% 50%,0 0,100% 0,100% 100%,0 100%,0 0)} +`,_i=(0,yn.Ay)("span")((()=>({display:"block",width:48,height:48,borderRadius:"50%",position:"relative",zIndex:100,top:"calc(50% - 24px)",left:"calc(50% - 24px)",animation:`${xi} 1s linear infinite`,"&:before":{content:"''",boxSizing:"border-box",position:"absolute",inset:0,borderRadius:"50%",border:"3px solid rgba(0,0,0,0.8)",animation:`${bi} 2s linear infinite`}}))),wi=e=>{let{position:t="fixed",loading:r}=e;return r&&(0,j.jsx)(vi,{position:t,children:(0,j.jsx)(_i,{})})};var ki=r(89611);const Si=e=>{let t;return t=e<1?5.11916*e**2:4.5*Math.log(e+1)+2,(t/100).toFixed(2)};function Ai(e){return(0,Yn.Ay)("MuiPaper",e)}(0,Ln.A)("MuiPaper",["root","rounded","outlined","elevation","elevation0","elevation1","elevation2","elevation3","elevation4","elevation5","elevation6","elevation7","elevation8","elevation9","elevation10","elevation11","elevation12","elevation13","elevation14","elevation15","elevation16","elevation17","elevation18","elevation19","elevation20","elevation21","elevation22","elevation23","elevation24"]);const Ti=["className","component","elevation","square","variant"],Mi=(0,yn.Ay)("div",{name:"MuiPaper",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,t[r.variant],!r.square&&t.rounded,"elevation"===r.variant&&t[`elevation${r.elevation}`]]}})((e=>{let{theme:t,ownerState:r}=e;var n;return(0,O.A)({backgroundColor:(t.vars||t).palette.background.paper,color:(t.vars||t).palette.text.primary,transition:t.transitions.create("box-shadow")},!r.square&&{borderRadius:t.shape.borderRadius},"outlined"===r.variant&&{border:`1px solid ${(t.vars||t).palette.divider}`},"elevation"===r.variant&&(0,O.A)({boxShadow:(t.vars||t).shadows[r.elevation]},!t.vars&&"dark"===t.palette.mode&&{backgroundImage:`linear-gradient(${(0,gn.X4)("#fff",Si(r.elevation))}, ${(0,gn.X4)("#fff",Si(r.elevation))})`},t.vars&&{backgroundImage:null==(n=t.vars.overlays)?void 0:n[r.elevation]}))})),Ci=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiPaper"}),{className:n,component:i="div",elevation:o=1,square:a=!1,variant:s="elevation"}=r,l=(0,R.A)(r,Ti),c=(0,O.A)({},r,{component:i,elevation:o,square:a,variant:s}),u=(e=>{const{square:t,elevation:r,variant:n,classes:i}=e,o={root:["root",n,!t&&"rounded","elevation"===n&&`elevation${r}`]};return(0,mn.A)(o,Ai,i)})(c);return(0,j.jsx)(Mi,(0,O.A)({as:i,ownerState:c,className:(0,fn.A)(u.root,n),ref:t},l))}));function Ei(e){return(0,Yn.Ay)("MuiAppBar",e)}(0,Ln.A)("MuiAppBar",["root","positionFixed","positionAbsolute","positionSticky","positionStatic","positionRelative","colorDefault","colorPrimary","colorSecondary","colorInherit","colorTransparent","colorError","colorInfo","colorSuccess","colorWarning"]);const Ii=["className","color","enableColorOnDark","position"],Pi=(e,t)=>e?`${null==e?void 0:e.replace(")","")}, ${t})`:t,Oi=(0,yn.Ay)(Ci,{name:"MuiAppBar",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,t[`position${(0,ei.A)(r.position)}`],t[`color${(0,ei.A)(r.color)}`]]}})((e=>{let{theme:t,ownerState:r}=e;const n="light"===t.palette.mode?t.palette.grey[100]:t.palette.grey[900];return(0,O.A)({display:"flex",flexDirection:"column",width:"100%",boxSizing:"border-box",flexShrink:0},"fixed"===r.position&&{position:"fixed",zIndex:(t.vars||t).zIndex.appBar,top:0,left:"auto",right:0,"@media print":{position:"absolute"}},"absolute"===r.position&&{position:"absolute",zIndex:(t.vars||t).zIndex.appBar,top:0,left:"auto",right:0},"sticky"===r.position&&{position:"sticky",zIndex:(t.vars||t).zIndex.appBar,top:0,left:"auto",right:0},"static"===r.position&&{position:"static"},"relative"===r.position&&{position:"relative"},!t.vars&&(0,O.A)({},"default"===r.color&&{backgroundColor:n,color:t.palette.getContrastText(n)},r.color&&"default"!==r.color&&"inherit"!==r.color&&"transparent"!==r.color&&{backgroundColor:t.palette[r.color].main,color:t.palette[r.color].contrastText},"inherit"===r.color&&{color:"inherit"},"dark"===t.palette.mode&&!r.enableColorOnDark&&{backgroundColor:null,color:null},"transparent"===r.color&&(0,O.A)({backgroundColor:"transparent",color:"inherit"},"dark"===t.palette.mode&&{backgroundImage:"none"})),t.vars&&(0,O.A)({},"default"===r.color&&{"--AppBar-background":r.enableColorOnDark?t.vars.palette.AppBar.defaultBg:Pi(t.vars.palette.AppBar.darkBg,t.vars.palette.AppBar.defaultBg),"--AppBar-color":r.enableColorOnDark?t.vars.palette.text.primary:Pi(t.vars.palette.AppBar.darkColor,t.vars.palette.text.primary)},r.color&&!r.color.match(/^(default|inherit|transparent)$/)&&{"--AppBar-background":r.enableColorOnDark?t.vars.palette[r.color].main:Pi(t.vars.palette.AppBar.darkBg,t.vars.palette[r.color].main),"--AppBar-color":r.enableColorOnDark?t.vars.palette[r.color].contrastText:Pi(t.vars.palette.AppBar.darkColor,t.vars.palette[r.color].contrastText)},!["inherit","transparent"].includes(r.color)&&{backgroundColor:"var(--AppBar-background)"},{color:"inherit"===r.color?"inherit":"var(--AppBar-color)"},"transparent"===r.color&&{backgroundImage:"none",backgroundColor:"transparent",color:"inherit"}))})),Ri=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiAppBar"}),{className:n,color:i="primary",enableColorOnDark:o=!1,position:a="fixed"}=r,s=(0,R.A)(r,Ii),l=(0,O.A)({},r,{color:i,position:a,enableColorOnDark:o}),c=(e=>{const{color:t,position:r,classes:n}=e,i={root:["root",`color${(0,ei.A)(t)}`,`position${(0,ei.A)(r)}`]};return(0,mn.A)(i,Ei,n)})(l);return(0,j.jsx)(Oi,(0,O.A)({square:!0,component:"header",ownerState:l,elevation:4,className:(0,fn.A)(c.root,n,"fixed"===a&&"mui-fixed"),ref:t},s))}));function Li(e){return(0,Yn.Ay)("MuiToolbar",e)}(0,Ln.A)("MuiToolbar",["root","gutters","regular","dense"]);const Di=["className","component","disableGutters","variant"],zi=(0,yn.Ay)("div",{name:"MuiToolbar",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,!r.disableGutters&&t.gutters,t[r.variant]]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({position:"relative",display:"flex",alignItems:"center"},!r.disableGutters&&{paddingLeft:t.spacing(2),paddingRight:t.spacing(2),[t.breakpoints.up("sm")]:{paddingLeft:t.spacing(3),paddingRight:t.spacing(3)}},"dense"===r.variant&&{minHeight:48})}),(e=>{let{theme:t,ownerState:r}=e;return"regular"===r.variant&&t.mixins.toolbar})),ji=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiToolbar"}),{className:n,component:i="div",disableGutters:o=!1,variant:a="regular"}=r,s=(0,R.A)(r,Di),l=(0,O.A)({},r,{component:i,disableGutters:o,variant:a}),c=(e=>{const{classes:t,disableGutters:r,variant:n}=e,i={root:["root",!r&&"gutters",n]};return(0,mn.A)(i,Li,t)})(l);return(0,j.jsx)(zi,(0,O.A)({as:i,className:(0,fn.A)(c.root,n),ref:t,ownerState:l},s))}));function Fi(e){return(0,Yn.Ay)("MuiTypography",e)}(0,Ln.A)("MuiTypography",["root","h1","h2","h3","h4","h5","h6","subtitle1","subtitle2","body1","body2","inherit","button","caption","overline","alignLeft","alignRight","alignCenter","alignJustify","noWrap","gutterBottom","paragraph"]);const Ni=["align","className","component","gutterBottom","noWrap","paragraph","variant","variantMapping"],Bi=(0,yn.Ay)("span",{name:"MuiTypography",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.variant&&t[r.variant],"inherit"!==r.align&&t[`align${(0,ei.A)(r.align)}`],r.noWrap&&t.noWrap,r.gutterBottom&&t.gutterBottom,r.paragraph&&t.paragraph]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({margin:0},"inherit"===r.variant&&{font:"inherit"},"inherit"!==r.variant&&t.typography[r.variant],"inherit"!==r.align&&{textAlign:r.align},r.noWrap&&{overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},r.gutterBottom&&{marginBottom:"0.35em"},r.paragraph&&{marginBottom:16})})),Vi={h1:"h1",h2:"h2",h3:"h3",h4:"h4",h5:"h5",h6:"h6",subtitle1:"h6",subtitle2:"h6",body1:"p",body2:"p",inherit:"p"},Ui={primary:"primary.main",textPrimary:"text.primary",secondary:"secondary.main",textSecondary:"text.secondary",error:"error.main"},Hi=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiTypography"}),n=(e=>Ui[e]||e)(r.color),i=(0,li.A)((0,O.A)({},r,{color:n})),{align:o="inherit",className:a,component:s,gutterBottom:l=!1,noWrap:c=!1,paragraph:u=!1,variant:d="body1",variantMapping:h=Vi}=i,p=(0,R.A)(i,Ni),f=(0,O.A)({},i,{align:o,color:n,className:a,component:s,gutterBottom:l,noWrap:c,paragraph:u,variant:d,variantMapping:h}),m=s||(u?"p":h[d]||Vi[d])||"span",g=(e=>{const{align:t,gutterBottom:r,noWrap:n,paragraph:i,variant:o,classes:a}=e,s={root:["root",o,"inherit"!==e.align&&`align${(0,ei.A)(t)}`,r&&"gutterBottom",n&&"noWrap",i&&"paragraph"]};return(0,mn.A)(s,Fi,a)})(f);return(0,j.jsx)(Bi,(0,O.A)({as:m,ref:t,ownerState:f,className:(0,fn.A)(g.root,a)},p))}));var $i=r(39089),Wi=r(1702),qi=r(28147),Gi=r(63462);const Yi=function(e){return"string"===typeof e};const Xi=function(e,t,r){return void 0===e||Yi(e)?t:(0,O.A)({},t,{ownerState:(0,O.A)({},t.ownerState,r)})};const Zi=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];if(void 0===e)return{};const r={};return Object.keys(e).filter((r=>r.match(/^on[A-Z]/)&&"function"===typeof e[r]&&!t.includes(r))).forEach((t=>{r[t]=e[t]})),r};const Ki=function(e){if(void 0===e)return{};const t={};return Object.keys(e).filter((t=>!(t.match(/^on[A-Z]/)&&"function"===typeof e[t]))).forEach((r=>{t[r]=e[r]})),t};const Ji=function(e){const{getSlotProps:t,additionalProps:r,externalSlotProps:n,externalForwardedProps:i,className:o}=e;if(!t){const e=(0,fn.A)(null==r?void 0:r.className,o,null==i?void 0:i.className,null==n?void 0:n.className),t=(0,O.A)({},null==r?void 0:r.style,null==i?void 0:i.style,null==n?void 0:n.style),a=(0,O.A)({},r,i,n);return e.length>0&&(a.className=e),Object.keys(t).length>0&&(a.style=t),{props:a,internalRef:void 0}}const a=Zi((0,O.A)({},i,n)),s=Ki(n),l=Ki(i),c=t(a),u=(0,fn.A)(null==c?void 0:c.className,null==r?void 0:r.className,o,null==i?void 0:i.className,null==n?void 0:n.className),d=(0,O.A)({},null==c?void 0:c.style,null==r?void 0:r.style,null==i?void 0:i.style,null==n?void 0:n.style),h=(0,O.A)({},c,r,l,s);return u.length>0&&(h.className=u),Object.keys(d).length>0&&(h.style=d),{props:h,internalRef:c.ref}};const Qi=function(e,t,r){return"function"===typeof e?e(t,r):e},eo=["elementType","externalSlotProps","ownerState","skipResolvingSlotProps"];const to=function(e){var t;const{elementType:r,externalSlotProps:n,ownerState:i,skipResolvingSlotProps:o=!1}=e,a=(0,R.A)(e,eo),s=o?{}:Qi(n,i),{props:l,internalRef:c}=Ji((0,O.A)({},a,{externalSlotProps:s})),u=(0,Gi.A)(c,null==s?void 0:s.ref,null==(t=e.additionalProps)?void 0:t.ref);return Xi(r,(0,O.A)({},l,{ref:u}),i)};var ro=r(22427);const no=n.createContext({});function io(e){return(0,Yn.Ay)("MuiList",e)}(0,Ln.A)("MuiList",["root","padding","dense","subheader"]);const oo=["children","className","component","dense","disablePadding","subheader"],ao=(0,yn.Ay)("ul",{name:"MuiList",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,!r.disablePadding&&t.padding,r.dense&&t.dense,r.subheader&&t.subheader]}})((e=>{let{ownerState:t}=e;return(0,O.A)({listStyle:"none",margin:0,padding:0,position:"relative"},!t.disablePadding&&{paddingTop:8,paddingBottom:8},t.subheader&&{paddingTop:0})})),so=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiList"}),{children:i,className:o,component:a="ul",dense:s=!1,disablePadding:l=!1,subheader:c}=r,u=(0,R.A)(r,oo),d=n.useMemo((()=>({dense:s})),[s]),h=(0,O.A)({},r,{component:a,dense:s,disablePadding:l}),p=(e=>{const{classes:t,disablePadding:r,dense:n,subheader:i}=e,o={root:["root",!r&&"padding",n&&"dense",i&&"subheader"]};return(0,mn.A)(o,io,t)})(h);return(0,j.jsx)(no.Provider,{value:d,children:(0,j.jsxs)(ao,(0,O.A)({as:a,className:(0,fn.A)(p.root,o),ref:t,ownerState:h},u,{children:[c,i]}))})}));function lo(e){const t=e.documentElement.clientWidth;return Math.abs(window.innerWidth-t)}const co=lo;var uo=r(55013);const ho=["actions","autoFocus","autoFocusItem","children","className","disabledItemsFocusable","disableListWrap","onKeyDown","variant"];function po(e,t,r){return e===t?e.firstChild:t&&t.nextElementSibling?t.nextElementSibling:r?null:e.firstChild}function fo(e,t,r){return e===t?r?e.firstChild:e.lastChild:t&&t.previousElementSibling?t.previousElementSibling:r?null:e.lastChild}function mo(e,t){if(void 0===t)return!0;let r=e.innerText;return void 0===r&&(r=e.textContent),r=r.trim().toLowerCase(),0!==r.length&&(t.repeating?r[0]===t.keys[0]:0===r.indexOf(t.keys.join("")))}function go(e,t,r,n,i,o){let a=!1,s=i(e,t,!!t&&r);for(;s;){if(s===e.firstChild){if(a)return!1;a=!0}const t=!n&&(s.disabled||"true"===s.getAttribute("aria-disabled"));if(s.hasAttribute("tabindex")&&mo(s,o)&&!t)return s.focus(),!0;s=i(e,s,r)}return!1}const yo=n.forwardRef((function(e,t){const{actions:r,autoFocus:i=!1,autoFocusItem:o=!1,children:a,className:s,disabledItemsFocusable:l=!1,disableListWrap:c=!1,onKeyDown:u,variant:d="selectedMenu"}=e,h=(0,R.A)(e,ho),p=n.useRef(null),f=n.useRef({keys:[],repeating:!0,previousKeyMatched:!0,lastTime:null});(0,uo.A)((()=>{i&&p.current.focus()}),[i]),n.useImperativeHandle(r,(()=>({adjustStyleForScrollbar:(e,t)=>{let{direction:r}=t;const n=!p.current.style.width;if(e.clientHeight{n.isValidElement(e)?(e.props.disabled||("selectedMenu"===d&&e.props.selected||-1===g)&&(g=t),g===t&&(e.props.disabled||e.props.muiSkipListHighlight||e.type.muiSkipListHighlight)&&(g+=1,g>=a.length&&(g=-1))):g===t&&(g+=1,g>=a.length&&(g=-1))}));const y=n.Children.map(a,((e,t)=>{if(t===g){const t={};return o&&(t.autoFocus=!0),void 0===e.props.tabIndex&&"selectedMenu"===d&&(t.tabIndex=0),n.cloneElement(e,t)}return e}));return(0,j.jsx)(so,(0,O.A)({role:"menu",ref:m,className:s,onKeyDown:e=>{const t=p.current,r=e.key,n=(0,ro.A)(t).activeElement;if("ArrowDown"===r)e.preventDefault(),go(t,n,c,l,po);else if("ArrowUp"===r)e.preventDefault(),go(t,n,c,l,fo);else if("Home"===r)e.preventDefault(),go(t,null,c,l,po);else if("End"===r)e.preventDefault(),go(t,null,c,l,fo);else if(1===r.length){const i=f.current,o=r.toLowerCase(),a=performance.now();i.keys.length>0&&(a-i.lastTime>500?(i.keys=[],i.repeating=!0,i.previousKeyMatched=!0):i.repeating&&o!==i.keys[0]&&(i.repeating=!1)),i.lastTime=a,i.keys.push(o);const s=n&&!i.repeating&&mo(n,i);i.previousKeyMatched&&(s||go(t,n,!1,l,po,i))?e.preventDefault():i.previousKeyMatched=!1}u&&u(e)},tabIndex:i?0:-1},h,{children:y}))}));var vo=r(80950),xo=r(36078);const bo=!1;var _o="unmounted",wo="exited",ko="entering",So="entered",Ao="exiting",To=function(e){function t(t,r){var n;n=e.call(this,t,r)||this;var i,o=r&&!r.isMounting?t.enter:t.appear;return n.appearStatus=null,t.in?o?(i=wo,n.appearStatus=ko):i=So:i=t.unmountOnExit||t.mountOnEnter?_o:wo,n.state={status:i},n.nextCallback=null,n}kn(t,e),t.getDerivedStateFromProps=function(e,t){return e.in&&t.status===_o?{status:wo}:null};var r=t.prototype;return r.componentDidMount=function(){this.updateStatus(!0,this.appearStatus)},r.componentDidUpdate=function(e){var t=null;if(e!==this.props){var r=this.state.status;this.props.in?r!==ko&&r!==So&&(t=ko):r!==ko&&r!==So||(t=Ao)}this.updateStatus(!1,t)},r.componentWillUnmount=function(){this.cancelNextCallback()},r.getTimeouts=function(){var e,t,r,n=this.props.timeout;return e=t=r=n,null!=n&&"number"!==typeof n&&(e=n.exit,t=n.enter,r=void 0!==n.appear?n.appear:t),{exit:e,enter:t,appear:r}},r.updateStatus=function(e,t){if(void 0===e&&(e=!1),null!==t)if(this.cancelNextCallback(),t===ko){if(this.props.unmountOnExit||this.props.mountOnEnter){var r=this.props.nodeRef?this.props.nodeRef.current:s.findDOMNode(this);r&&function(e){e.scrollTop}(r)}this.performEnter(e)}else this.performExit();else this.props.unmountOnExit&&this.state.status===wo&&this.setState({status:_o})},r.performEnter=function(e){var t=this,r=this.props.enter,n=this.context?this.context.isMounting:e,i=this.props.nodeRef?[n]:[s.findDOMNode(this),n],o=i[0],a=i[1],l=this.getTimeouts(),c=n?l.appear:l.enter;!e&&!r||bo?this.safeSetState({status:So},(function(){t.props.onEntered(o)})):(this.props.onEnter(o,a),this.safeSetState({status:ko},(function(){t.props.onEntering(o,a),t.onTransitionEnd(c,(function(){t.safeSetState({status:So},(function(){t.props.onEntered(o,a)}))}))})))},r.performExit=function(){var e=this,t=this.props.exit,r=this.getTimeouts(),n=this.props.nodeRef?void 0:s.findDOMNode(this);t&&!bo?(this.props.onExit(n),this.safeSetState({status:Ao},(function(){e.props.onExiting(n),e.onTransitionEnd(r.exit,(function(){e.safeSetState({status:wo},(function(){e.props.onExited(n)}))}))}))):this.safeSetState({status:wo},(function(){e.props.onExited(n)}))},r.cancelNextCallback=function(){null!==this.nextCallback&&(this.nextCallback.cancel(),this.nextCallback=null)},r.safeSetState=function(e,t){t=this.setNextCallback(t),this.setState(e,t)},r.setNextCallback=function(e){var t=this,r=!0;return this.nextCallback=function(n){r&&(r=!1,t.nextCallback=null,e(n))},this.nextCallback.cancel=function(){r=!1},this.nextCallback},r.onTransitionEnd=function(e,t){this.setNextCallback(t);var r=this.props.nodeRef?this.props.nodeRef.current:s.findDOMNode(this),n=null==e&&!this.props.addEndListener;if(r&&!n){if(this.props.addEndListener){var i=this.props.nodeRef?[this.nextCallback]:[r,this.nextCallback],o=i[0],a=i[1];this.props.addEndListener(o,a)}null!=e&&setTimeout(this.nextCallback,e)}else setTimeout(this.nextCallback,0)},r.render=function(){var e=this.state.status;if(e===_o)return null;var t=this.props,r=t.children,i=(t.in,t.mountOnEnter,t.unmountOnExit,t.appear,t.enter,t.exit,t.timeout,t.addEndListener,t.onEnter,t.onEntering,t.onEntered,t.onExit,t.onExiting,t.onExited,t.nodeRef,(0,R.A)(t,["children","in","mountOnEnter","unmountOnExit","appear","enter","exit","timeout","addEndListener","onEnter","onEntering","onEntered","onExit","onExiting","onExited","nodeRef"]));return n.createElement(Sn.Provider,{value:null},"function"===typeof r?r(e,i):n.cloneElement(n.Children.only(r),i))},t}(n.Component);function Mo(){}To.contextType=Sn,To.propTypes={},To.defaultProps={in:!1,mountOnEnter:!1,unmountOnExit:!1,appear:!1,enter:!0,exit:!0,onEnter:Mo,onEntering:Mo,onEntered:Mo,onExit:Mo,onExiting:Mo,onExited:Mo},To.UNMOUNTED=_o,To.EXITED=wo,To.ENTERING=ko,To.ENTERED=So,To.EXITING=Ao;const Co=To;var Eo=r(15170);function Io(){const e=di(Eo.A);return e[X.A]||e}const Po=e=>e.scrollTop;function Oo(e,t){var r,n;const{timeout:i,easing:o,style:a={}}=e;return{duration:null!=(r=a.transitionDuration)?r:"number"===typeof i?i:i[t.mode]||0,easing:null!=(n=a.transitionTimingFunction)?n:"object"===typeof o?o[t.mode]:o,delay:a.transitionDelay}}const Ro=["addEndListener","appear","children","easing","in","onEnter","onEntered","onEntering","onExit","onExited","onExiting","style","timeout","TransitionComponent"];function Lo(e){return`scale(${e}, ${e**2})`}const Do={entering:{opacity:1,transform:Lo(1)},entered:{opacity:1,transform:"none"}},zo="undefined"!==typeof navigator&&/^((?!chrome|android).)*(safari|mobile)/i.test(navigator.userAgent)&&/(os |version\/)15(.|_)4/i.test(navigator.userAgent),jo=n.forwardRef((function(e,t){const{addEndListener:r,appear:i=!0,children:o,easing:a,in:s,onEnter:l,onEntered:c,onEntering:u,onExit:d,onExited:h,onExiting:p,style:f,timeout:m="auto",TransitionComponent:g=Co}=e,y=(0,R.A)(e,Ro),v=(0,On.A)(),x=n.useRef(),b=Io(),_=n.useRef(null),w=(0,xn.A)(_,o.ref,t),k=e=>t=>{if(e){const r=_.current;void 0===t?e(r):e(r,t)}},S=k(u),A=k(((e,t)=>{Po(e);const{duration:r,delay:n,easing:i}=Oo({style:f,timeout:m,easing:a},{mode:"enter"});let o;"auto"===m?(o=b.transitions.getAutoHeightDuration(e.clientHeight),x.current=o):o=r,e.style.transition=[b.transitions.create("opacity",{duration:o,delay:n}),b.transitions.create("transform",{duration:zo?o:.666*o,delay:n,easing:i})].join(","),l&&l(e,t)})),T=k(c),M=k(p),C=k((e=>{const{duration:t,delay:r,easing:n}=Oo({style:f,timeout:m,easing:a},{mode:"exit"});let i;"auto"===m?(i=b.transitions.getAutoHeightDuration(e.clientHeight),x.current=i):i=t,e.style.transition=[b.transitions.create("opacity",{duration:i,delay:r}),b.transitions.create("transform",{duration:zo?i:.666*i,delay:zo?r:r||.333*i,easing:n})].join(","),e.style.opacity=0,e.style.transform=Lo(.75),d&&d(e)})),E=k(h);return(0,j.jsx)(g,(0,O.A)({appear:i,in:s,nodeRef:_,onEnter:A,onEntered:T,onEntering:S,onExit:C,onExited:E,onExiting:M,addEndListener:e=>{"auto"===m&&v.start(x.current||0,e),r&&r(_.current,e)},timeout:"auto"===m?null:m},y,{children:(e,t)=>n.cloneElement(o,(0,O.A)({style:(0,O.A)({opacity:0,transform:Lo(.75),visibility:"exited"!==e||s?void 0:"hidden"},Do[e],f,o.props.style),ref:w},t))}))}));jo.muiSupportAuto=!0;const Fo=jo;var No=r(31668);const Bo=["input","select","textarea","a[href]","button","[tabindex]","audio[controls]","video[controls]",'[contenteditable]:not([contenteditable="false"])'].join(",");function Vo(e){const t=[],r=[];return Array.from(e.querySelectorAll(Bo)).forEach(((e,n)=>{const i=function(e){const t=parseInt(e.getAttribute("tabindex")||"",10);return Number.isNaN(t)?"true"===e.contentEditable||("AUDIO"===e.nodeName||"VIDEO"===e.nodeName||"DETAILS"===e.nodeName)&&null===e.getAttribute("tabindex")?0:e.tabIndex:t}(e);-1!==i&&function(e){return!(e.disabled||"INPUT"===e.tagName&&"hidden"===e.type||function(e){if("INPUT"!==e.tagName||"radio"!==e.type)return!1;if(!e.name)return!1;const t=t=>e.ownerDocument.querySelector(`input[type="radio"]${t}`);let r=t(`[name="${e.name}"]:checked`);return r||(r=t(`[name="${e.name}"]`)),r!==e}(e))}(e)&&(0===i?t.push(e):r.push({documentOrder:n,tabIndex:i,node:e}))})),r.sort(((e,t)=>e.tabIndex===t.tabIndex?e.documentOrder-t.documentOrder:e.tabIndex-t.tabIndex)).map((e=>e.node)).concat(t)}function Uo(){return!0}const Ho=function(e){const{children:t,disableAutoFocus:r=!1,disableEnforceFocus:i=!1,disableRestoreFocus:o=!1,getTabbable:a=Vo,isEnabled:s=Uo,open:l}=e,c=n.useRef(!1),u=n.useRef(null),d=n.useRef(null),h=n.useRef(null),p=n.useRef(null),f=n.useRef(!1),m=n.useRef(null),g=(0,Gi.A)(t.ref,m),y=n.useRef(null);n.useEffect((()=>{l&&m.current&&(f.current=!r)}),[r,l]),n.useEffect((()=>{if(!l||!m.current)return;const e=(0,No.A)(m.current);return m.current.contains(e.activeElement)||(m.current.hasAttribute("tabIndex")||m.current.setAttribute("tabIndex","-1"),f.current&&m.current.focus()),()=>{o||(h.current&&h.current.focus&&(c.current=!0,h.current.focus()),h.current=null)}}),[l]),n.useEffect((()=>{if(!l||!m.current)return;const e=(0,No.A)(m.current),t=t=>{y.current=t,!i&&s()&&"Tab"===t.key&&e.activeElement===m.current&&t.shiftKey&&(c.current=!0,d.current&&d.current.focus())},r=()=>{const t=m.current;if(null===t)return;if(!e.hasFocus()||!s()||c.current)return void(c.current=!1);if(t.contains(e.activeElement))return;if(i&&e.activeElement!==u.current&&e.activeElement!==d.current)return;if(e.activeElement!==p.current)p.current=null;else if(null!==p.current)return;if(!f.current)return;let r=[];if(e.activeElement!==u.current&&e.activeElement!==d.current||(r=a(m.current)),r.length>0){var n,o;const e=Boolean((null==(n=y.current)?void 0:n.shiftKey)&&"Tab"===(null==(o=y.current)?void 0:o.key)),t=r[0],i=r[r.length-1];"string"!==typeof t&&"string"!==typeof i&&(e?i.focus():t.focus())}else t.focus()};e.addEventListener("focusin",r),e.addEventListener("keydown",t,!0);const n=setInterval((()=>{e.activeElement&&"BODY"===e.activeElement.tagName&&r()}),50);return()=>{clearInterval(n),e.removeEventListener("focusin",r),e.removeEventListener("keydown",t,!0)}}),[r,i,o,s,l,a]);const v=e=>{null===h.current&&(h.current=e.relatedTarget),f.current=!0};return(0,j.jsxs)(n.Fragment,{children:[(0,j.jsx)("div",{tabIndex:l?0:-1,onFocus:v,ref:u,"data-testid":"sentinelStart"}),n.cloneElement(t,{ref:g,onFocus:e=>{null===h.current&&(h.current=e.relatedTarget),f.current=!0,p.current=e.target;const r=t.props.onFocus;r&&r(e)}}),(0,j.jsx)("div",{tabIndex:l?0:-1,onFocus:v,ref:d,"data-testid":"sentinelEnd"})]})};var $o=r(84440),Wo=r(26564);const qo=n.forwardRef((function(e,t){const{children:r,container:i,disablePortal:o=!1}=e,[a,l]=n.useState(null),c=(0,Gi.A)(n.isValidElement(r)?r.ref:null,t);if((0,$o.A)((()=>{o||l(function(e){return"function"===typeof e?e():e}(i)||document.body)}),[i,o]),(0,$o.A)((()=>{if(a&&!o)return(0,Wo.A)(t,a),()=>{(0,Wo.A)(t,null)}}),[t,a,o]),o){if(n.isValidElement(r)){const e={ref:c};return n.cloneElement(r,e)}return(0,j.jsx)(n.Fragment,{children:r})}return(0,j.jsx)(n.Fragment,{children:a?s.createPortal(r,a):a})})),Go=["addEndListener","appear","children","easing","in","onEnter","onEntered","onEntering","onExit","onExited","onExiting","style","timeout","TransitionComponent"],Yo={entering:{opacity:1},entered:{opacity:1}},Xo=n.forwardRef((function(e,t){const r=Io(),i={enter:r.transitions.duration.enteringScreen,exit:r.transitions.duration.leavingScreen},{addEndListener:o,appear:a=!0,children:s,easing:l,in:c,onEnter:u,onEntered:d,onEntering:h,onExit:p,onExited:f,onExiting:m,style:g,timeout:y=i,TransitionComponent:v=Co}=e,x=(0,R.A)(e,Go),b=n.useRef(null),_=(0,xn.A)(b,s.ref,t),w=e=>t=>{if(e){const r=b.current;void 0===t?e(r):e(r,t)}},k=w(h),S=w(((e,t)=>{Po(e);const n=Oo({style:g,timeout:y,easing:l},{mode:"enter"});e.style.webkitTransition=r.transitions.create("opacity",n),e.style.transition=r.transitions.create("opacity",n),u&&u(e,t)})),A=w(d),T=w(m),M=w((e=>{const t=Oo({style:g,timeout:y,easing:l},{mode:"exit"});e.style.webkitTransition=r.transitions.create("opacity",t),e.style.transition=r.transitions.create("opacity",t),p&&p(e)})),C=w(f);return(0,j.jsx)(v,(0,O.A)({appear:a,in:c,nodeRef:b,onEnter:S,onEntered:A,onEntering:k,onExit:M,onExited:C,onExiting:T,addEndListener:e=>{o&&o(b.current,e)},timeout:y},x,{children:(e,t)=>n.cloneElement(s,(0,O.A)({style:(0,O.A)({opacity:0,visibility:"exited"!==e||c?void 0:"hidden"},Yo[e],g,s.props.style),ref:_},t))}))}));function Zo(e){return(0,Yn.Ay)("MuiBackdrop",e)}(0,Ln.A)("MuiBackdrop",["root","invisible"]);const Ko=["children","className","component","components","componentsProps","invisible","open","slotProps","slots","TransitionComponent","transitionDuration"],Jo=(0,yn.Ay)("div",{name:"MuiBackdrop",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.invisible&&t.invisible]}})((e=>{let{ownerState:t}=e;return(0,O.A)({position:"fixed",display:"flex",alignItems:"center",justifyContent:"center",right:0,bottom:0,top:0,left:0,backgroundColor:"rgba(0, 0, 0, 0.5)",WebkitTapHighlightColor:"transparent"},t.invisible&&{backgroundColor:"transparent"})})),Qo=n.forwardRef((function(e,t){var r,n,i;const o=(0,vn.b)({props:e,name:"MuiBackdrop"}),{children:a,className:s,component:l="div",components:c={},componentsProps:u={},invisible:d=!1,open:h,slotProps:p={},slots:f={},TransitionComponent:m=Xo,transitionDuration:g}=o,y=(0,R.A)(o,Ko),v=(0,O.A)({},o,{component:l,invisible:d}),x=(e=>{const{classes:t,invisible:r}=e,n={root:["root",r&&"invisible"]};return(0,mn.A)(n,Zo,t)})(v),b=null!=(r=p.root)?r:u.root;return(0,j.jsx)(m,(0,O.A)({in:h,timeout:g},y,{children:(0,j.jsx)(Jo,(0,O.A)({"aria-hidden":!0},b,{as:null!=(n=null!=(i=f.root)?i:c.Root)?n:l,className:(0,fn.A)(x.root,s,null==b?void 0:b.className),ownerState:(0,O.A)({},v,null==b?void 0:b.ownerState),classes:x,ref:t,children:a}))}))}));var ea=r(31782),ta=r(42456),ra=r(63940);function na(e,t){t?e.setAttribute("aria-hidden","true"):e.removeAttribute("aria-hidden")}function ia(e){return parseInt((0,ra.A)(e).getComputedStyle(e).paddingRight,10)||0}function oa(e,t,r,n,i){const o=[t,r,...n];[].forEach.call(e.children,(e=>{const t=-1===o.indexOf(e),r=!function(e){const t=-1!==["TEMPLATE","SCRIPT","STYLE","LINK","MAP","META","NOSCRIPT","PICTURE","COL","COLGROUP","PARAM","SLOT","SOURCE","TRACK"].indexOf(e.tagName),r="INPUT"===e.tagName&&"hidden"===e.getAttribute("type");return t||r}(e);t&&r&&na(e,i)}))}function aa(e,t){let r=-1;return e.some(((e,n)=>!!t(e)&&(r=n,!0))),r}function sa(e,t){const r=[],n=e.container;if(!t.disableScrollLock){if(function(e){const t=(0,No.A)(e);return t.body===e?(0,ra.A)(e).innerWidth>t.documentElement.clientWidth:e.scrollHeight>e.clientHeight}(n)){const e=lo((0,No.A)(n));r.push({value:n.style.paddingRight,property:"padding-right",el:n}),n.style.paddingRight=`${ia(n)+e}px`;const t=(0,No.A)(n).querySelectorAll(".mui-fixed");[].forEach.call(t,(t=>{r.push({value:t.style.paddingRight,property:"padding-right",el:t}),t.style.paddingRight=`${ia(t)+e}px`}))}let e;if(n.parentNode instanceof DocumentFragment)e=(0,No.A)(n).body;else{const t=n.parentElement,r=(0,ra.A)(n);e="HTML"===(null==t?void 0:t.nodeName)&&"scroll"===r.getComputedStyle(t).overflowY?t:n}r.push({value:e.style.overflow,property:"overflow",el:e},{value:e.style.overflowX,property:"overflow-x",el:e},{value:e.style.overflowY,property:"overflow-y",el:e}),e.style.overflow="hidden"}return()=>{r.forEach((e=>{let{value:t,el:r,property:n}=e;t?r.style.setProperty(n,t):r.style.removeProperty(n)}))}}const la=new class{constructor(){this.containers=void 0,this.modals=void 0,this.modals=[],this.containers=[]}add(e,t){let r=this.modals.indexOf(e);if(-1!==r)return r;r=this.modals.length,this.modals.push(e),e.modalRef&&na(e.modalRef,!1);const n=function(e){const t=[];return[].forEach.call(e.children,(e=>{"true"===e.getAttribute("aria-hidden")&&t.push(e)})),t}(t);oa(t,e.mount,e.modalRef,n,!0);const i=aa(this.containers,(e=>e.container===t));return-1!==i?(this.containers[i].modals.push(e),r):(this.containers.push({modals:[e],container:t,restore:null,hiddenSiblings:n}),r)}mount(e,t){const r=aa(this.containers,(t=>-1!==t.modals.indexOf(e))),n=this.containers[r];n.restore||(n.restore=sa(n,t))}remove(e){let t=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];const r=this.modals.indexOf(e);if(-1===r)return r;const n=aa(this.containers,(t=>-1!==t.modals.indexOf(e))),i=this.containers[n];if(i.modals.splice(i.modals.indexOf(e),1),this.modals.splice(r,1),0===i.modals.length)i.restore&&i.restore(),e.modalRef&&na(e.modalRef,t),oa(i.container,e.mount,e.modalRef,i.hiddenSiblings,!1),this.containers.splice(n,1);else{const e=i.modals[i.modals.length-1];e.modalRef&&na(e.modalRef,!1)}return r}isTopModal(e){return this.modals.length>0&&this.modals[this.modals.length-1]===e}};const ca=function(e){const{container:t,disableEscapeKeyDown:r=!1,disableScrollLock:i=!1,manager:o=la,closeAfterTransition:a=!1,onTransitionEnter:s,onTransitionExited:l,children:c,onClose:u,open:d,rootRef:h}=e,p=n.useRef({}),f=n.useRef(null),m=n.useRef(null),g=(0,Gi.A)(m,h),[y,v]=n.useState(!d),x=function(e){return!!e&&e.props.hasOwnProperty("in")}(c);let b=!0;"false"!==e["aria-hidden"]&&!1!==e["aria-hidden"]||(b=!1);const _=()=>(p.current.modalRef=m.current,p.current.mount=f.current,p.current),w=()=>{o.mount(_(),{disableScrollLock:i}),m.current&&(m.current.scrollTop=0)},k=(0,ea.A)((()=>{const e=function(e){return"function"===typeof e?e():e}(t)||(0,No.A)(f.current).body;o.add(_(),e),m.current&&w()})),S=n.useCallback((()=>o.isTopModal(_())),[o]),A=(0,ea.A)((e=>{f.current=e,e&&(d&&S()?w():m.current&&na(m.current,b))})),T=n.useCallback((()=>{o.remove(_(),b)}),[b,o]);n.useEffect((()=>()=>{T()}),[T]),n.useEffect((()=>{d?k():x&&a||T()}),[d,T,x,a,k]);const M=e=>t=>{var n;null==(n=e.onKeyDown)||n.call(e,t),"Escape"===t.key&&229!==t.which&&S()&&(r||(t.stopPropagation(),u&&u(t,"escapeKeyDown")))},C=e=>t=>{var r;null==(r=e.onClick)||r.call(e,t),t.target===t.currentTarget&&u&&u(t,"backdropClick")};return{getRootProps:function(){let t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const r=Zi(e);delete r.onTransitionEnter,delete r.onTransitionExited;const n=(0,O.A)({},r,t);return(0,O.A)({role:"presentation"},n,{onKeyDown:M(n),ref:g})},getBackdropProps:function(){const e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return(0,O.A)({"aria-hidden":!0},e,{onClick:C(e),open:d})},getTransitionProps:()=>({onEnter:(0,ta.A)((()=>{v(!1),s&&s()}),null==c?void 0:c.props.onEnter),onExited:(0,ta.A)((()=>{v(!0),l&&l(),a&&T()}),null==c?void 0:c.props.onExited)}),rootRef:g,portalRef:A,isTopModal:S,exited:y,hasTransition:x}};function ua(e){return(0,Yn.Ay)("MuiModal",e)}(0,Ln.A)("MuiModal",["root","hidden","backdrop"]);const da=["BackdropComponent","BackdropProps","classes","className","closeAfterTransition","children","container","component","components","componentsProps","disableAutoFocus","disableEnforceFocus","disableEscapeKeyDown","disablePortal","disableRestoreFocus","disableScrollLock","hideBackdrop","keepMounted","onBackdropClick","onClose","onTransitionEnter","onTransitionExited","open","slotProps","slots","theme"],ha=(0,yn.Ay)("div",{name:"MuiModal",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,!r.open&&r.exited&&t.hidden]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({position:"fixed",zIndex:(t.vars||t).zIndex.modal,right:0,bottom:0,top:0,left:0},!r.open&&r.exited&&{visibility:"hidden"})})),pa=(0,yn.Ay)(Qo,{name:"MuiModal",slot:"Backdrop",overridesResolver:(e,t)=>t.backdrop})({zIndex:-1}),fa=n.forwardRef((function(e,t){var r,i,o,a,s,l;const c=(0,vn.b)({name:"MuiModal",props:e}),{BackdropComponent:u=pa,BackdropProps:d,className:h,closeAfterTransition:p=!1,children:f,container:m,component:g,components:y={},componentsProps:v={},disableAutoFocus:x=!1,disableEnforceFocus:b=!1,disableEscapeKeyDown:_=!1,disablePortal:w=!1,disableRestoreFocus:k=!1,disableScrollLock:S=!1,hideBackdrop:A=!1,keepMounted:T=!1,onBackdropClick:M,open:C,slotProps:E,slots:I}=c,P=(0,R.A)(c,da),L=(0,O.A)({},c,{closeAfterTransition:p,disableAutoFocus:x,disableEnforceFocus:b,disableEscapeKeyDown:_,disablePortal:w,disableRestoreFocus:k,disableScrollLock:S,hideBackdrop:A,keepMounted:T}),{getRootProps:D,getBackdropProps:z,getTransitionProps:F,portalRef:N,isTopModal:B,exited:V,hasTransition:U}=ca((0,O.A)({},L,{rootRef:t})),H=(0,O.A)({},L,{exited:V}),$=(e=>{const{open:t,exited:r,classes:n}=e,i={root:["root",!t&&r&&"hidden"],backdrop:["backdrop"]};return(0,mn.A)(i,ua,n)})(H),W={};if(void 0===f.props.tabIndex&&(W.tabIndex="-1"),U){const{onEnter:e,onExited:t}=F();W.onEnter=e,W.onExited=t}const q=null!=(r=null!=(i=null==I?void 0:I.root)?i:y.Root)?r:ha,G=null!=(o=null!=(a=null==I?void 0:I.backdrop)?a:y.Backdrop)?o:u,Y=null!=(s=null==E?void 0:E.root)?s:v.root,X=null!=(l=null==E?void 0:E.backdrop)?l:v.backdrop,Z=to({elementType:q,externalSlotProps:Y,externalForwardedProps:P,getSlotProps:D,additionalProps:{ref:t,as:g},ownerState:H,className:(0,fn.A)(h,null==Y?void 0:Y.className,null==$?void 0:$.root,!H.open&&H.exited&&(null==$?void 0:$.hidden))}),K=to({elementType:G,externalSlotProps:X,additionalProps:d,getSlotProps:e=>z((0,O.A)({},e,{onClick:t=>{M&&M(t),null!=e&&e.onClick&&e.onClick(t)}})),className:(0,fn.A)(null==X?void 0:X.className,null==d?void 0:d.className,null==$?void 0:$.backdrop),ownerState:H});return T||C||U&&!V?(0,j.jsx)(qo,{ref:N,container:m,disablePortal:w,children:(0,j.jsxs)(q,(0,O.A)({},Z,{children:[!A&&u?(0,j.jsx)(G,(0,O.A)({},K)):null,(0,j.jsx)(Ho,{disableEnforceFocus:b,disableAutoFocus:x,disableRestoreFocus:k,isEnabled:B,open:C,children:n.cloneElement(f,W)})]}))}):null}));function ma(e){return(0,Yn.Ay)("MuiPopover",e)}(0,Ln.A)("MuiPopover",["root","paper"]);const ga=["onEntering"],ya=["action","anchorEl","anchorOrigin","anchorPosition","anchorReference","children","className","container","elevation","marginThreshold","open","PaperProps","slots","slotProps","transformOrigin","TransitionComponent","transitionDuration","TransitionProps","disableScrollLock"],va=["slotProps"];function xa(e,t){let r=0;return"number"===typeof t?r=t:"center"===t?r=e.height/2:"bottom"===t&&(r=e.height),r}function ba(e,t){let r=0;return"number"===typeof t?r=t:"center"===t?r=e.width/2:"right"===t&&(r=e.width),r}function _a(e){return[e.horizontal,e.vertical].map((e=>"number"===typeof e?`${e}px`:e)).join(" ")}function wa(e){return"function"===typeof e?e():e}const ka=(0,yn.Ay)(fa,{name:"MuiPopover",slot:"Root",overridesResolver:(e,t)=>t.root})({}),Sa=(0,yn.Ay)(Ci,{name:"MuiPopover",slot:"Paper",overridesResolver:(e,t)=>t.paper})({position:"absolute",overflowY:"auto",overflowX:"hidden",minWidth:16,minHeight:16,maxWidth:"calc(100% - 32px)",maxHeight:"calc(100% - 32px)",outline:0}),Aa=n.forwardRef((function(e,t){var r,i,o;const a=(0,vn.b)({props:e,name:"MuiPopover"}),{action:s,anchorEl:l,anchorOrigin:c={vertical:"top",horizontal:"left"},anchorPosition:u,anchorReference:d="anchorEl",children:h,className:p,container:f,elevation:m=8,marginThreshold:g=16,open:y,PaperProps:v={},slots:x,slotProps:b,transformOrigin:_={vertical:"top",horizontal:"left"},TransitionComponent:w=Fo,transitionDuration:k="auto",TransitionProps:{onEntering:S}={},disableScrollLock:A=!1}=a,T=(0,R.A)(a.TransitionProps,ga),M=(0,R.A)(a,ya),C=null!=(r=null==b?void 0:b.paper)?r:v,E=n.useRef(),I=(0,xn.A)(E,C.ref),P=(0,O.A)({},a,{anchorOrigin:c,anchorReference:d,elevation:m,marginThreshold:g,externalPaperSlotProps:C,transformOrigin:_,TransitionComponent:w,transitionDuration:k,TransitionProps:T}),L=(e=>{const{classes:t}=e;return(0,mn.A)({root:["root"],paper:["paper"]},ma,t)})(P),D=n.useCallback((()=>{if("anchorPosition"===d)return u;const e=wa(l),t=(e&&1===e.nodeType?e:(0,ro.A)(E.current).body).getBoundingClientRect();return{top:t.top+xa(t,c.vertical),left:t.left+ba(t,c.horizontal)}}),[l,c.horizontal,c.vertical,u,d]),z=n.useCallback((e=>({vertical:xa(e,_.vertical),horizontal:ba(e,_.horizontal)})),[_.horizontal,_.vertical]),F=n.useCallback((e=>{const t={width:e.offsetWidth,height:e.offsetHeight},r=z(t);if("none"===d)return{top:null,left:null,transformOrigin:_a(r)};const n=D();let i=n.top-r.vertical,o=n.left-r.horizontal;const a=i+t.height,s=o+t.width,c=(0,xo.A)(wa(l)),u=c.innerHeight-g,h=c.innerWidth-g;if(null!==g&&iu){const e=a-u;i-=e,r.vertical+=e}if(null!==g&&oh){const e=s-h;o-=e,r.horizontal+=e}return{top:`${Math.round(i)}px`,left:`${Math.round(o)}px`,transformOrigin:_a(r)}}),[l,d,D,z,g]),[N,B]=n.useState(y),V=n.useCallback((()=>{const e=E.current;if(!e)return;const t=F(e);null!==t.top&&(e.style.top=t.top),null!==t.left&&(e.style.left=t.left),e.style.transformOrigin=t.transformOrigin,B(!0)}),[F]);n.useEffect((()=>(A&&window.addEventListener("scroll",V),()=>window.removeEventListener("scroll",V))),[l,A,V]);n.useEffect((()=>{y&&V()})),n.useImperativeHandle(s,(()=>y?{updatePosition:()=>{V()}}:null),[y,V]),n.useEffect((()=>{if(!y)return;const e=(0,vo.A)((()=>{V()})),t=(0,xo.A)(l);return t.addEventListener("resize",e),()=>{e.clear(),t.removeEventListener("resize",e)}}),[l,y,V]);let U=k;"auto"!==k||w.muiSupportAuto||(U=void 0);const H=f||(l?(0,ro.A)(wa(l)).body:void 0),$=null!=(i=null==x?void 0:x.root)?i:ka,W=null!=(o=null==x?void 0:x.paper)?o:Sa,q=to({elementType:W,externalSlotProps:(0,O.A)({},C,{style:N?C.style:(0,O.A)({},C.style,{opacity:0})}),additionalProps:{elevation:m,ref:I},ownerState:P,className:(0,fn.A)(L.paper,null==C?void 0:C.className)}),G=to({elementType:$,externalSlotProps:(null==b?void 0:b.root)||{},externalForwardedProps:M,additionalProps:{ref:t,slotProps:{backdrop:{invisible:!0}},container:H,open:y},ownerState:P,className:(0,fn.A)(L.root,p)}),{slotProps:Y}=G,X=(0,R.A)(G,va);return(0,j.jsx)($,(0,O.A)({},X,!Yi($)&&{slotProps:Y,disableScrollLock:A},{children:(0,j.jsx)(w,(0,O.A)({appear:!0,in:y,onEntering:(e,t)=>{S&&S(e,t),V()},onExited:()=>{B(!1)},timeout:U},T,{children:(0,j.jsx)(W,(0,O.A)({},q,{children:h}))}))}))}));var Ta=r(61475);function Ma(e){return(0,Yn.Ay)("MuiMenu",e)}(0,Ln.A)("MuiMenu",["root","paper","list"]);const Ca=["onEntering"],Ea=["autoFocus","children","className","disableAutoFocusItem","MenuListProps","onClose","open","PaperProps","PopoverClasses","transitionDuration","TransitionProps","variant","slots","slotProps"],Ia={vertical:"top",horizontal:"right"},Pa={vertical:"top",horizontal:"left"},Oa=(0,yn.Ay)(Aa,{shouldForwardProp:e=>(0,Ta.A)(e)||"classes"===e,name:"MuiMenu",slot:"Root",overridesResolver:(e,t)=>t.root})({}),Ra=(0,yn.Ay)(Sa,{name:"MuiMenu",slot:"Paper",overridesResolver:(e,t)=>t.paper})({maxHeight:"calc(100% - 96px)",WebkitOverflowScrolling:"touch"}),La=(0,yn.Ay)(yo,{name:"MuiMenu",slot:"List",overridesResolver:(e,t)=>t.list})({outline:0}),Da=n.forwardRef((function(e,t){var r,i;const o=(0,vn.b)({props:e,name:"MuiMenu"}),{autoFocus:a=!0,children:s,className:l,disableAutoFocusItem:c=!1,MenuListProps:u={},onClose:d,open:h,PaperProps:p={},PopoverClasses:f,transitionDuration:m="auto",TransitionProps:{onEntering:g}={},variant:y="selectedMenu",slots:v={},slotProps:x={}}=o,b=(0,R.A)(o.TransitionProps,Ca),_=(0,R.A)(o,Ea),w=H(),k=(0,O.A)({},o,{autoFocus:a,disableAutoFocusItem:c,MenuListProps:u,onEntering:g,PaperProps:p,transitionDuration:m,TransitionProps:b,variant:y}),S=(e=>{const{classes:t}=e;return(0,mn.A)({root:["root"],paper:["paper"],list:["list"]},Ma,t)})(k),A=a&&!c&&h,T=n.useRef(null);let M=-1;n.Children.map(s,((e,t)=>{n.isValidElement(e)&&(e.props.disabled||("selectedMenu"===y&&e.props.selected||-1===M)&&(M=t))}));const C=null!=(r=v.paper)?r:Ra,E=null!=(i=x.paper)?i:p,I=to({elementType:v.root,externalSlotProps:x.root,ownerState:k,className:[S.root,l]}),P=to({elementType:C,externalSlotProps:E,ownerState:k,className:S.paper});return(0,j.jsx)(Oa,(0,O.A)({onClose:d,anchorOrigin:{vertical:"bottom",horizontal:w?"right":"left"},transformOrigin:w?Ia:Pa,slots:{paper:C,root:v.root},slotProps:{root:I,paper:P},open:h,ref:t,transitionDuration:m,TransitionProps:(0,O.A)({onEntering:(e,t)=>{T.current&&T.current.adjustStyleForScrollbar(e,{direction:w?"rtl":"ltr"}),g&&g(e,t)}},b),ownerState:k},_,{classes:f,children:(0,j.jsx)(La,(0,O.A)({onKeyDown:e=>{"Tab"===e.key&&(e.preventDefault(),d&&d(e,"tabKeyDown"))},actions:T,autoFocus:a&&(-1===M||c),autoFocusItem:A,variant:y},u,{className:(0,fn.A)(S.list,u.className),children:s}))}))}));function za(e){return(0,Yn.Ay)("MuiDivider",e)}const ja=(0,Ln.A)("MuiDivider",["root","absolute","fullWidth","inset","middle","flexItem","light","vertical","withChildren","withChildrenVertical","textAlignRight","textAlignLeft","wrapper","wrapperVertical"]);function Fa(e){return(0,Yn.Ay)("MuiListItemIcon",e)}const Na=(0,Ln.A)("MuiListItemIcon",["root","alignItemsFlexStart"]);function Ba(e){return(0,Yn.Ay)("MuiListItemText",e)}const Va=(0,Ln.A)("MuiListItemText",["root","multiline","dense","inset","primary","secondary"]);function Ua(e){return(0,Yn.Ay)("MuiMenuItem",e)}const Ha=(0,Ln.A)("MuiMenuItem",["root","focusVisible","dense","disabled","divider","gutters","selected"]),$a=["autoFocus","component","dense","divider","disableGutters","focusVisibleClassName","role","tabIndex","className"],Wa=(0,yn.Ay)(Qn,{shouldForwardProp:e=>(0,Ta.A)(e)||"classes"===e,name:"MuiMenuItem",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.dense&&t.dense,r.divider&&t.divider,!r.disableGutters&&t.gutters]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({},t.typography.body1,{display:"flex",justifyContent:"flex-start",alignItems:"center",position:"relative",textDecoration:"none",minHeight:48,paddingTop:6,paddingBottom:6,boxSizing:"border-box",whiteSpace:"nowrap"},!r.disableGutters&&{paddingLeft:16,paddingRight:16},r.divider&&{borderBottom:`1px solid ${(t.vars||t).palette.divider}`,backgroundClip:"padding-box"},{"&:hover":{textDecoration:"none",backgroundColor:(t.vars||t).palette.action.hover,"@media (hover: none)":{backgroundColor:"transparent"}},[`&.${Ha.selected}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity})`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity),[`&.${Ha.focusVisible}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.focusOpacity}))`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity+t.palette.action.focusOpacity)}},[`&.${Ha.selected}:hover`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.hoverOpacity}))`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity+t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity})`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity)}},[`&.${Ha.focusVisible}`]:{backgroundColor:(t.vars||t).palette.action.focus},[`&.${Ha.disabled}`]:{opacity:(t.vars||t).palette.action.disabledOpacity},[`& + .${ja.root}`]:{marginTop:t.spacing(1),marginBottom:t.spacing(1)},[`& + .${ja.inset}`]:{marginLeft:52},[`& .${Va.root}`]:{marginTop:0,marginBottom:0},[`& .${Va.inset}`]:{paddingLeft:36},[`& .${Na.root}`]:{minWidth:36}},!r.dense&&{[t.breakpoints.up("sm")]:{minHeight:"auto"}},r.dense&&(0,O.A)({minHeight:32,paddingTop:4,paddingBottom:4},t.typography.body2,{[`& .${Na.root} svg`]:{fontSize:"1.25rem"}}))})),qa=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiMenuItem"}),{autoFocus:i=!1,component:o="li",dense:a=!1,divider:s=!1,disableGutters:l=!1,focusVisibleClassName:c,role:u="menuitem",tabIndex:d,className:h}=r,p=(0,R.A)(r,$a),f=n.useContext(no),m=n.useMemo((()=>({dense:a||f.dense||!1,disableGutters:l})),[f.dense,a,l]),g=n.useRef(null);(0,uo.A)((()=>{i&&g.current&&g.current.focus()}),[i]);const y=(0,O.A)({},r,{dense:m.dense,divider:s,disableGutters:l}),v=(e=>{const{disabled:t,dense:r,divider:n,disableGutters:i,selected:o,classes:a}=e,s={root:["root",r&&"dense",t&&"disabled",!i&&"gutters",n&&"divider",o&&"selected"]},l=(0,mn.A)(s,Ua,a);return(0,O.A)({},a,l)})(r),x=(0,xn.A)(g,t);let b;return r.disabled||(b=void 0!==d?d:-1),(0,j.jsx)(no.Provider,{value:m,children:(0,j.jsx)(Wa,(0,O.A)({ref:x,role:u,tabIndex:b,component:o,focusVisibleClassName:(0,fn.A)(v.focusVisible,c),className:(0,fn.A)(v.root,h)},p,{ownerState:y,classes:v}))})}));function Ga(e){for(var t=arguments.length,r=Array(t>1?t-1:0),n=1;n3?t.i-4:t.i:Array.isArray(e)?1:rs(e)?2:ns(e)?3:0}function Ja(e,t){return 2===Ka(e)?e.has(t):Object.prototype.hasOwnProperty.call(e,t)}function Qa(e,t){return 2===Ka(e)?e.get(t):e[t]}function es(e,t,r){var n=Ka(e);2===n?e.set(t,r):3===n?e.add(r):e[t]=r}function ts(e,t){return e===t?0!==e||1/e==1/t:e!=e&&t!=t}function rs(e){return Ps&&e instanceof Map}function ns(e){return Os&&e instanceof Set}function is(e){return e.o||e.t}function os(e){if(Array.isArray(e))return Array.prototype.slice.call(e);var t=Ns(e);delete t[zs];for(var r=Fs(t),n=0;n1&&(e.set=e.add=e.clear=e.delete=ss),Object.freeze(e),t&&Za(e,(function(e,t){return as(t,!0)}),!0)),e}function ss(){Ga(2)}function ls(e){return null==e||"object"!=typeof e||Object.isFrozen(e)}function cs(e){var t=Bs[e];return t||Ga(18,e),t}function us(e,t){Bs[e]||(Bs[e]=t)}function ds(){return Es}function hs(e,t){t&&(cs("Patches"),e.u=[],e.s=[],e.v=t)}function ps(e){fs(e),e.p.forEach(gs),e.p=null}function fs(e){e===Es&&(Es=e.l)}function ms(e){return Es={p:[],l:Es,h:e,m:!0,_:0}}function gs(e){var t=e[zs];0===t.i||1===t.i?t.j():t.g=!0}function ys(e,t){t._=t.p.length;var r=t.p[0],n=void 0!==e&&e!==r;return t.h.O||cs("ES5").S(t,e,n),n?(r[zs].P&&(ps(t),Ga(4)),Xa(e)&&(e=vs(t,e),t.l||bs(t,e)),t.u&&cs("Patches").M(r[zs].t,e,t.u,t.s)):e=vs(t,r,[]),ps(t),t.u&&t.v(t.u,t.s),e!==Ls?e:void 0}function vs(e,t,r){if(ls(t))return t;var n=t[zs];if(!n)return Za(t,(function(i,o){return xs(e,n,t,i,o,r)}),!0),t;if(n.A!==e)return t;if(!n.P)return bs(e,n.t,!0),n.t;if(!n.I){n.I=!0,n.A._--;var i=4===n.i||5===n.i?n.o=os(n.k):n.o,o=i,a=!1;3===n.i&&(o=new Set(i),i.clear(),a=!0),Za(o,(function(t,o){return xs(e,n,i,t,o,r,a)})),bs(e,i,!1),r&&e.u&&cs("Patches").N(n,r,e.u,e.s)}return n.o}function xs(e,t,r,n,i,o,a){if(Ya(i)){var s=vs(e,i,o&&t&&3!==t.i&&!Ja(t.R,n)?o.concat(n):void 0);if(es(r,n,s),!Ya(s))return;e.m=!1}else a&&r.add(i);if(Xa(i)&&!ls(i)){if(!e.h.D&&e._<1)return;vs(e,i),t&&t.A.l||bs(e,i)}}function bs(e,t,r){void 0===r&&(r=!1),!e.l&&e.h.D&&e.m&&as(t,r)}function _s(e,t){var r=e[zs];return(r?is(r):e)[t]}function ws(e,t){if(t in e)for(var r=Object.getPrototypeOf(e);r;){var n=Object.getOwnPropertyDescriptor(r,t);if(n)return n;r=Object.getPrototypeOf(r)}}function ks(e){e.P||(e.P=!0,e.l&&ks(e.l))}function Ss(e){e.o||(e.o=os(e.t))}function As(e,t,r){var n=rs(t)?cs("MapSet").F(t,r):ns(t)?cs("MapSet").T(t,r):e.O?function(e,t){var r=Array.isArray(e),n={i:r?1:0,A:t?t.A:ds(),P:!1,I:!1,R:{},l:t,t:e,k:null,o:null,j:null,C:!1},i=n,o=Vs;r&&(i=[n],o=Us);var a=Proxy.revocable(i,o),s=a.revoke,l=a.proxy;return n.k=l,n.j=s,l}(t,r):cs("ES5").J(t,r);return(r?r.A:ds()).p.push(n),n}function Ts(e,t){switch(t){case 2:return new Map(e);case 3:return Array.from(e)}return os(e)}function Ms(){function e(e,t){var r=i[e];return r?r.enumerable=t:i[e]=r={configurable:!0,enumerable:t,get:function(){var t=this[zs];return Vs.get(t,e)},set:function(t){var r=this[zs];Vs.set(r,e,t)}},r}function t(e){for(var t=e.length-1;t>=0;t--){var i=e[t][zs];if(!i.P)switch(i.i){case 5:n(i)&&ks(i);break;case 4:r(i)&&ks(i)}}}function r(e){for(var t=e.t,r=e.k,n=Fs(r),i=n.length-1;i>=0;i--){var o=n[i];if(o!==zs){var a=t[o];if(void 0===a&&!Ja(t,o))return!0;var s=r[o],l=s&&s[zs];if(l?l.t!==a:!ts(s,a))return!0}}var c=!!t[zs];return n.length!==Fs(t).length+(c?0:1)}function n(e){var t=e.k;if(t.length!==e.t.length)return!0;var r=Object.getOwnPropertyDescriptor(t,t.length-1);if(r&&!r.get)return!0;for(var n=0;n1?n-1:0),s=1;s1?n-1:0),o=1;o=0;r--){var n=t[r];if(0===n.path.length&&"replace"===n.op){e=n.value;break}}r>-1&&(t=t.slice(r+1));var i=cs("Patches").$;return Ya(e)?i(e,t):this.produce(e,(function(e){return i(e,t)}))},e}()),$s=Hs.produce;Hs.produceWithPatches.bind(Hs),Hs.setAutoFreeze.bind(Hs),Hs.setUseProxies.bind(Hs),Hs.applyPatches.bind(Hs),Hs.createDraft.bind(Hs),Hs.finishDraft.bind(Hs);const Ws=$s;function qs(e){return qs="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},qs(e)}function Gs(e){var t=function(e,t){if("object"!=qs(e)||!e)return e;var r=e[Symbol.toPrimitive];if(void 0!==r){var n=r.call(e,t||"default");if("object"!=qs(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}(e,"string");return"symbol"==qs(t)?t:t+""}function Ys(e,t,r){return(t=Gs(t))in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function Xs(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function Zs(e){for(var t=1;t0&&i[i.length-1])&&(6===o[0]||2===o[0])){a=0;continue}if(3===o[0]&&(!i||o[1]>i[0]&&o[1]-1;return r&&n}function Hl(e){return"function"===typeof e[0]&&"pending"in e[0]&&"fulfilled"in e[0]&&"rejected"in e[0]}function $l(){for(var e=[],t=0;t{localStorage.setItem("access_token",e)},Zl=()=>localStorage.getItem("access_token"),Kl=()=>{localStorage.removeItem("refresh_token"),Jl(),Ql(),window.location.href="/login"},Jl=()=>localStorage.removeItem("access_token"),Ql=()=>localStorage.removeItem("ExToken");function ec(e,t){return function(){return e.apply(t,arguments)}}const{toString:tc}=Object.prototype,{getPrototypeOf:rc}=Object,nc=(ic=Object.create(null),e=>{const t=tc.call(e);return ic[t]||(ic[t]=t.slice(8,-1).toLowerCase())});var ic;const oc=e=>(e=e.toLowerCase(),t=>nc(t)===e),ac=e=>t=>typeof t===e,{isArray:sc}=Array,lc=ac("undefined");const cc=oc("ArrayBuffer");const uc=ac("string"),dc=ac("function"),hc=ac("number"),pc=e=>null!==e&&"object"===typeof e,fc=e=>{if("object"!==nc(e))return!1;const t=rc(e);return(null===t||t===Object.prototype||null===Object.getPrototypeOf(t))&&!(Symbol.toStringTag in e)&&!(Symbol.iterator in e)},mc=oc("Date"),gc=oc("File"),yc=oc("Blob"),vc=oc("FileList"),xc=oc("URLSearchParams"),[bc,_c,wc,kc]=["ReadableStream","Request","Response","Headers"].map(oc);function Sc(e,t){let r,n,{allOwnKeys:i=!1}=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(null!==e&&"undefined"!==typeof e)if("object"!==typeof e&&(e=[e]),sc(e))for(r=0,n=e.length;r0;)if(n=r[i],t===n.toLowerCase())return n;return null}const Tc="undefined"!==typeof globalThis?globalThis:"undefined"!==typeof self?self:"undefined"!==typeof window?window:global,Mc=e=>!lc(e)&&e!==Tc;const Cc=(Ec="undefined"!==typeof Uint8Array&&rc(Uint8Array),e=>Ec&&e instanceof Ec);var Ec;const Ic=oc("HTMLFormElement"),Pc=(e=>{let{hasOwnProperty:t}=e;return(e,r)=>t.call(e,r)})(Object.prototype),Oc=oc("RegExp"),Rc=(e,t)=>{const r=Object.getOwnPropertyDescriptors(e),n={};Sc(r,((r,i)=>{let o;!1!==(o=t(r,i,e))&&(n[i]=o||r)})),Object.defineProperties(e,n)},Lc="abcdefghijklmnopqrstuvwxyz",Dc="0123456789",zc={DIGIT:Dc,ALPHA:Lc,ALPHA_DIGIT:Lc+Lc.toUpperCase()+Dc};const jc=oc("AsyncFunction"),Fc=((e,t)=>{return e?setImmediate:t?(r=`axios@${Math.random()}`,n=[],Tc.addEventListener("message",(e=>{let{source:t,data:i}=e;t===Tc&&i===r&&n.length&&n.shift()()}),!1),e=>{n.push(e),Tc.postMessage(r,"*")}):e=>setTimeout(e);var r,n})("function"===typeof setImmediate,dc(Tc.postMessage)),Nc="undefined"!==typeof queueMicrotask?queueMicrotask.bind(Tc):"undefined"!==typeof process&&process.nextTick||Fc,Bc={isArray:sc,isArrayBuffer:cc,isBuffer:function(e){return null!==e&&!lc(e)&&null!==e.constructor&&!lc(e.constructor)&&dc(e.constructor.isBuffer)&&e.constructor.isBuffer(e)},isFormData:e=>{let t;return e&&("function"===typeof FormData&&e instanceof FormData||dc(e.append)&&("formdata"===(t=nc(e))||"object"===t&&dc(e.toString)&&"[object FormData]"===e.toString()))},isArrayBufferView:function(e){let t;return t="undefined"!==typeof ArrayBuffer&&ArrayBuffer.isView?ArrayBuffer.isView(e):e&&e.buffer&&cc(e.buffer),t},isString:uc,isNumber:hc,isBoolean:e=>!0===e||!1===e,isObject:pc,isPlainObject:fc,isReadableStream:bc,isRequest:_c,isResponse:wc,isHeaders:kc,isUndefined:lc,isDate:mc,isFile:gc,isBlob:yc,isRegExp:Oc,isFunction:dc,isStream:e=>pc(e)&&dc(e.pipe),isURLSearchParams:xc,isTypedArray:Cc,isFileList:vc,forEach:Sc,merge:function e(){const{caseless:t}=Mc(this)&&this||{},r={},n=(n,i)=>{const o=t&&Ac(r,i)||i;fc(r[o])&&fc(n)?r[o]=e(r[o],n):fc(n)?r[o]=e({},n):sc(n)?r[o]=n.slice():r[o]=n};for(let i=0,o=arguments.length;i3&&void 0!==arguments[3]?arguments[3]:{};return Sc(t,((t,n)=>{r&&dc(t)?e[n]=ec(t,r):e[n]=t}),{allOwnKeys:n}),e},trim:e=>e.trim?e.trim():e.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,""),stripBOM:e=>(65279===e.charCodeAt(0)&&(e=e.slice(1)),e),inherits:(e,t,r,n)=>{e.prototype=Object.create(t.prototype,n),e.prototype.constructor=e,Object.defineProperty(e,"super",{value:t.prototype}),r&&Object.assign(e.prototype,r)},toFlatObject:(e,t,r,n)=>{let i,o,a;const s={};if(t=t||{},null==e)return t;do{for(i=Object.getOwnPropertyNames(e),o=i.length;o-- >0;)a=i[o],n&&!n(a,e,t)||s[a]||(t[a]=e[a],s[a]=!0);e=!1!==r&&rc(e)}while(e&&(!r||r(e,t))&&e!==Object.prototype);return t},kindOf:nc,kindOfTest:oc,endsWith:(e,t,r)=>{e=String(e),(void 0===r||r>e.length)&&(r=e.length),r-=t.length;const n=e.indexOf(t,r);return-1!==n&&n===r},toArray:e=>{if(!e)return null;if(sc(e))return e;let t=e.length;if(!hc(t))return null;const r=new Array(t);for(;t-- >0;)r[t]=e[t];return r},forEachEntry:(e,t)=>{const r=(e&&e[Symbol.iterator]).call(e);let n;for(;(n=r.next())&&!n.done;){const r=n.value;t.call(e,r[0],r[1])}},matchAll:(e,t)=>{let r;const n=[];for(;null!==(r=e.exec(t));)n.push(r);return n},isHTMLForm:Ic,hasOwnProperty:Pc,hasOwnProp:Pc,reduceDescriptors:Rc,freezeMethods:e=>{Rc(e,((t,r)=>{if(dc(e)&&-1!==["arguments","caller","callee"].indexOf(r))return!1;const n=e[r];dc(n)&&(t.enumerable=!1,"writable"in t?t.writable=!1:t.set||(t.set=()=>{throw Error("Can not rewrite read-only method '"+r+"'")}))}))},toObjectSet:(e,t)=>{const r={},n=e=>{e.forEach((e=>{r[e]=!0}))};return sc(e)?n(e):n(String(e).split(t)),r},toCamelCase:e=>e.toLowerCase().replace(/[-_\s]([a-z\d])(\w*)/g,(function(e,t,r){return t.toUpperCase()+r})),noop:()=>{},toFiniteNumber:(e,t)=>null!=e&&Number.isFinite(e=+e)?e:t,findKey:Ac,global:Tc,isContextDefined:Mc,ALPHABET:zc,generateString:function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:16,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:zc.ALPHA_DIGIT,r="";const{length:n}=t;for(;e--;)r+=t[Math.random()*n|0];return r},isSpecCompliantForm:function(e){return!!(e&&dc(e.append)&&"FormData"===e[Symbol.toStringTag]&&e[Symbol.iterator])},toJSONObject:e=>{const t=new Array(10),r=(e,n)=>{if(pc(e)){if(t.indexOf(e)>=0)return;if(!("toJSON"in e)){t[n]=e;const i=sc(e)?[]:{};return Sc(e,((e,t)=>{const o=r(e,n+1);!lc(o)&&(i[t]=o)})),t[n]=void 0,i}}return e};return r(e,0)},isAsyncFn:jc,isThenable:e=>e&&(pc(e)||dc(e))&&dc(e.then)&&dc(e.catch),setImmediate:Fc,asap:Nc};function Vc(e,t,r,n,i){Error.call(this),Error.captureStackTrace?Error.captureStackTrace(this,this.constructor):this.stack=(new Error).stack,this.message=e,this.name="AxiosError",t&&(this.code=t),r&&(this.config=r),n&&(this.request=n),i&&(this.response=i,this.status=i.status?i.status:null)}Bc.inherits(Vc,Error,{toJSON:function(){return{message:this.message,name:this.name,description:this.description,number:this.number,fileName:this.fileName,lineNumber:this.lineNumber,columnNumber:this.columnNumber,stack:this.stack,config:Bc.toJSONObject(this.config),code:this.code,status:this.status}}});const Uc=Vc.prototype,Hc={};["ERR_BAD_OPTION_VALUE","ERR_BAD_OPTION","ECONNABORTED","ETIMEDOUT","ERR_NETWORK","ERR_FR_TOO_MANY_REDIRECTS","ERR_DEPRECATED","ERR_BAD_RESPONSE","ERR_BAD_REQUEST","ERR_CANCELED","ERR_NOT_SUPPORT","ERR_INVALID_URL"].forEach((e=>{Hc[e]={value:e}})),Object.defineProperties(Vc,Hc),Object.defineProperty(Uc,"isAxiosError",{value:!0}),Vc.from=(e,t,r,n,i,o)=>{const a=Object.create(Uc);return Bc.toFlatObject(e,a,(function(e){return e!==Error.prototype}),(e=>"isAxiosError"!==e)),Vc.call(a,e.message,t,r,n,i),a.cause=e,a.name=e.name,o&&Object.assign(a,o),a};const $c=Vc;function Wc(e){return Bc.isPlainObject(e)||Bc.isArray(e)}function qc(e){return Bc.endsWith(e,"[]")?e.slice(0,-2):e}function Gc(e,t,r){return e?e.concat(t).map((function(e,t){return e=qc(e),!r&&t?"["+e+"]":e})).join(r?".":""):t}const Yc=Bc.toFlatObject(Bc,{},null,(function(e){return/^is[A-Z]/.test(e)}));const Xc=function(e,t,r){if(!Bc.isObject(e))throw new TypeError("target must be an object");t=t||new FormData;const n=(r=Bc.toFlatObject(r,{metaTokens:!0,dots:!1,indexes:!1},!1,(function(e,t){return!Bc.isUndefined(t[e])}))).metaTokens,i=r.visitor||c,o=r.dots,a=r.indexes,s=(r.Blob||"undefined"!==typeof Blob&&Blob)&&Bc.isSpecCompliantForm(t);if(!Bc.isFunction(i))throw new TypeError("visitor must be a function");function l(e){if(null===e)return"";if(Bc.isDate(e))return e.toISOString();if(!s&&Bc.isBlob(e))throw new $c("Blob is not supported. Use a Buffer instead.");return Bc.isArrayBuffer(e)||Bc.isTypedArray(e)?s&&"function"===typeof Blob?new Blob([e]):Buffer.from(e):e}function c(e,r,i){let s=e;if(e&&!i&&"object"===typeof e)if(Bc.endsWith(r,"{}"))r=n?r:r.slice(0,-2),e=JSON.stringify(e);else if(Bc.isArray(e)&&function(e){return Bc.isArray(e)&&!e.some(Wc)}(e)||(Bc.isFileList(e)||Bc.endsWith(r,"[]"))&&(s=Bc.toArray(e)))return r=qc(r),s.forEach((function(e,n){!Bc.isUndefined(e)&&null!==e&&t.append(!0===a?Gc([r],n,o):null===a?r:r+"[]",l(e))})),!1;return!!Wc(e)||(t.append(Gc(i,r,o),l(e)),!1)}const u=[],d=Object.assign(Yc,{defaultVisitor:c,convertValue:l,isVisitable:Wc});if(!Bc.isObject(e))throw new TypeError("data must be an object");return function e(r,n){if(!Bc.isUndefined(r)){if(-1!==u.indexOf(r))throw Error("Circular reference detected in "+n.join("."));u.push(r),Bc.forEach(r,(function(r,o){!0===(!(Bc.isUndefined(r)||null===r)&&i.call(t,r,Bc.isString(o)?o.trim():o,n,d))&&e(r,n?n.concat(o):[o])})),u.pop()}}(e),t};function Zc(e){const t={"!":"%21","'":"%27","(":"%28",")":"%29","~":"%7E","%20":"+","%00":"\0"};return encodeURIComponent(e).replace(/[!'()~]|%20|%00/g,(function(e){return t[e]}))}function Kc(e,t){this._pairs=[],e&&Xc(e,this,t)}const Jc=Kc.prototype;Jc.append=function(e,t){this._pairs.push([e,t])},Jc.toString=function(e){const t=e?function(t){return e.call(this,t,Zc)}:Zc;return this._pairs.map((function(e){return t(e[0])+"="+t(e[1])}),"").join("&")};const Qc=Kc;function eu(e){return encodeURIComponent(e).replace(/%3A/gi,":").replace(/%24/g,"$").replace(/%2C/gi,",").replace(/%20/g,"+").replace(/%5B/gi,"[").replace(/%5D/gi,"]")}function tu(e,t,r){if(!t)return e;const n=r&&r.encode||eu,i=r&&r.serialize;let o;if(o=i?i(t,r):Bc.isURLSearchParams(t)?t.toString():new Qc(t,r).toString(n),o){const t=e.indexOf("#");-1!==t&&(e=e.slice(0,t)),e+=(-1===e.indexOf("?")?"?":"&")+o}return e}const ru=class{constructor(){this.handlers=[]}use(e,t,r){return this.handlers.push({fulfilled:e,rejected:t,synchronous:!!r&&r.synchronous,runWhen:r?r.runWhen:null}),this.handlers.length-1}eject(e){this.handlers[e]&&(this.handlers[e]=null)}clear(){this.handlers&&(this.handlers=[])}forEach(e){Bc.forEach(this.handlers,(function(t){null!==t&&e(t)}))}},nu={silentJSONParsing:!0,forcedJSONParsing:!0,clarifyTimeoutError:!1},iu={isBrowser:!0,classes:{URLSearchParams:"undefined"!==typeof URLSearchParams?URLSearchParams:Qc,FormData:"undefined"!==typeof FormData?FormData:null,Blob:"undefined"!==typeof Blob?Blob:null},protocols:["http","https","file","blob","url","data"]},ou="undefined"!==typeof window&&"undefined"!==typeof document,au="object"===typeof navigator&&navigator||void 0,su=ou&&(!au||["ReactNative","NativeScript","NS"].indexOf(au.product)<0),lu="undefined"!==typeof WorkerGlobalScope&&self instanceof WorkerGlobalScope&&"function"===typeof self.importScripts,cu=ou&&window.location.href||"http://localhost",uu={...e,...iu};const du=function(e){function t(e,r,n,i){let o=e[i++];if("__proto__"===o)return!0;const a=Number.isFinite(+o),s=i>=e.length;if(o=!o&&Bc.isArray(n)?n.length:o,s)return Bc.hasOwnProp(n,o)?n[o]=[n[o],r]:n[o]=r,!a;n[o]&&Bc.isObject(n[o])||(n[o]=[]);return t(e,r,n[o],i)&&Bc.isArray(n[o])&&(n[o]=function(e){const t={},r=Object.keys(e);let n;const i=r.length;let o;for(n=0;n{t(function(e){return Bc.matchAll(/\w+|\[(\w*)]/g,e).map((e=>"[]"===e[0]?"":e[1]||e[0]))}(e),n,r,0)})),r}return null};const hu={transitional:nu,adapter:["xhr","http","fetch"],transformRequest:[function(e,t){const r=t.getContentType()||"",n=r.indexOf("application/json")>-1,i=Bc.isObject(e);i&&Bc.isHTMLForm(e)&&(e=new FormData(e));if(Bc.isFormData(e))return n?JSON.stringify(du(e)):e;if(Bc.isArrayBuffer(e)||Bc.isBuffer(e)||Bc.isStream(e)||Bc.isFile(e)||Bc.isBlob(e)||Bc.isReadableStream(e))return e;if(Bc.isArrayBufferView(e))return e.buffer;if(Bc.isURLSearchParams(e))return t.setContentType("application/x-www-form-urlencoded;charset=utf-8",!1),e.toString();let o;if(i){if(r.indexOf("application/x-www-form-urlencoded")>-1)return function(e,t){return Xc(e,new uu.classes.URLSearchParams,Object.assign({visitor:function(e,t,r,n){return uu.isNode&&Bc.isBuffer(e)?(this.append(t,e.toString("base64")),!1):n.defaultVisitor.apply(this,arguments)}},t))}(e,this.formSerializer).toString();if((o=Bc.isFileList(e))||r.indexOf("multipart/form-data")>-1){const t=this.env&&this.env.FormData;return Xc(o?{"files[]":e}:e,t&&new t,this.formSerializer)}}return i||n?(t.setContentType("application/json",!1),function(e,t,r){if(Bc.isString(e))try{return(t||JSON.parse)(e),Bc.trim(e)}catch(ene){if("SyntaxError"!==ene.name)throw ene}return(r||JSON.stringify)(e)}(e)):e}],transformResponse:[function(e){const t=this.transitional||hu.transitional,r=t&&t.forcedJSONParsing,n="json"===this.responseType;if(Bc.isResponse(e)||Bc.isReadableStream(e))return e;if(e&&Bc.isString(e)&&(r&&!this.responseType||n)){const r=!(t&&t.silentJSONParsing)&&n;try{return JSON.parse(e)}catch(ene){if(r){if("SyntaxError"===ene.name)throw $c.from(ene,$c.ERR_BAD_RESPONSE,this,null,this.response);throw ene}}}return e}],timeout:0,xsrfCookieName:"XSRF-TOKEN",xsrfHeaderName:"X-XSRF-TOKEN",maxContentLength:-1,maxBodyLength:-1,env:{FormData:uu.classes.FormData,Blob:uu.classes.Blob},validateStatus:function(e){return e>=200&&e<300},headers:{common:{Accept:"application/json, text/plain, */*","Content-Type":void 0}}};Bc.forEach(["delete","get","head","post","put","patch"],(e=>{hu.headers[e]={}}));const pu=hu,fu=Bc.toObjectSet(["age","authorization","content-length","content-type","etag","expires","from","host","if-modified-since","if-unmodified-since","last-modified","location","max-forwards","proxy-authorization","referer","retry-after","user-agent"]),mu=Symbol("internals");function gu(e){return e&&String(e).trim().toLowerCase()}function yu(e){return!1===e||null==e?e:Bc.isArray(e)?e.map(yu):String(e)}function vu(e,t,r,n,i){return Bc.isFunction(n)?n.call(this,t,r):(i&&(t=r),Bc.isString(t)?Bc.isString(n)?-1!==t.indexOf(n):Bc.isRegExp(n)?n.test(t):void 0:void 0)}class xu{constructor(e){e&&this.set(e)}set(e,t,r){const n=this;function i(e,t,r){const i=gu(t);if(!i)throw new Error("header name must be a non-empty string");const o=Bc.findKey(n,i);(!o||void 0===n[o]||!0===r||void 0===r&&!1!==n[o])&&(n[o||t]=yu(e))}const o=(e,t)=>Bc.forEach(e,((e,r)=>i(e,r,t)));if(Bc.isPlainObject(e)||e instanceof this.constructor)o(e,t);else if(Bc.isString(e)&&(e=e.trim())&&!/^[-_a-zA-Z0-9^`|~,!#$%&'*+.]+$/.test(e.trim()))o((e=>{const t={};let r,n,i;return e&&e.split("\n").forEach((function(e){i=e.indexOf(":"),r=e.substring(0,i).trim().toLowerCase(),n=e.substring(i+1).trim(),!r||t[r]&&fu[r]||("set-cookie"===r?t[r]?t[r].push(n):t[r]=[n]:t[r]=t[r]?t[r]+", "+n:n)})),t})(e),t);else if(Bc.isHeaders(e))for(const[a,s]of e.entries())i(s,a,r);else null!=e&&i(t,e,r);return this}get(e,t){if(e=gu(e)){const r=Bc.findKey(this,e);if(r){const e=this[r];if(!t)return e;if(!0===t)return function(e){const t=Object.create(null),r=/([^\s,;=]+)\s*(?:=\s*([^,;]+))?/g;let n;for(;n=r.exec(e);)t[n[1]]=n[2];return t}(e);if(Bc.isFunction(t))return t.call(this,e,r);if(Bc.isRegExp(t))return t.exec(e);throw new TypeError("parser must be boolean|regexp|function")}}}has(e,t){if(e=gu(e)){const r=Bc.findKey(this,e);return!(!r||void 0===this[r]||t&&!vu(0,this[r],r,t))}return!1}delete(e,t){const r=this;let n=!1;function i(e){if(e=gu(e)){const i=Bc.findKey(r,e);!i||t&&!vu(0,r[i],i,t)||(delete r[i],n=!0)}}return Bc.isArray(e)?e.forEach(i):i(e),n}clear(e){const t=Object.keys(this);let r=t.length,n=!1;for(;r--;){const i=t[r];e&&!vu(0,this[i],i,e,!0)||(delete this[i],n=!0)}return n}normalize(e){const t=this,r={};return Bc.forEach(this,((n,i)=>{const o=Bc.findKey(r,i);if(o)return t[o]=yu(n),void delete t[i];const a=e?function(e){return e.trim().toLowerCase().replace(/([a-z\d])(\w*)/g,((e,t,r)=>t.toUpperCase()+r))}(i):String(i).trim();a!==i&&delete t[i],t[a]=yu(n),r[a]=!0})),this}concat(){for(var e=arguments.length,t=new Array(e),r=0;r{null!=r&&!1!==r&&(t[n]=e&&Bc.isArray(r)?r.join(", "):r)})),t}[Symbol.iterator](){return Object.entries(this.toJSON())[Symbol.iterator]()}toString(){return Object.entries(this.toJSON()).map((e=>{let[t,r]=e;return t+": "+r})).join("\n")}get[Symbol.toStringTag](){return"AxiosHeaders"}static from(e){return e instanceof this?e:new this(e)}static concat(e){const t=new this(e);for(var r=arguments.length,n=new Array(r>1?r-1:0),i=1;it.set(e))),t}static accessor(e){const t=(this[mu]=this[mu]={accessors:{}}).accessors,r=this.prototype;function n(e){const n=gu(e);t[n]||(!function(e,t){const r=Bc.toCamelCase(" "+t);["get","set","has"].forEach((n=>{Object.defineProperty(e,n+r,{value:function(e,r,i){return this[n].call(this,t,e,r,i)},configurable:!0})}))}(r,e),t[n]=!0)}return Bc.isArray(e)?e.forEach(n):n(e),this}}xu.accessor(["Content-Type","Content-Length","Accept","Accept-Encoding","User-Agent","Authorization"]),Bc.reduceDescriptors(xu.prototype,((e,t)=>{let{value:r}=e,n=t[0].toUpperCase()+t.slice(1);return{get:()=>r,set(e){this[n]=e}}})),Bc.freezeMethods(xu);const bu=xu;function _u(e,t){const r=this||pu,n=t||r,i=bu.from(n.headers);let o=n.data;return Bc.forEach(e,(function(e){o=e.call(r,o,i.normalize(),t?t.status:void 0)})),i.normalize(),o}function wu(e){return!(!e||!e.__CANCEL__)}function ku(e,t,r){$c.call(this,null==e?"canceled":e,$c.ERR_CANCELED,t,r),this.name="CanceledError"}Bc.inherits(ku,$c,{__CANCEL__:!0});const Su=ku;function Au(e,t,r){const n=r.config.validateStatus;r.status&&n&&!n(r.status)?t(new $c("Request failed with status code "+r.status,[$c.ERR_BAD_REQUEST,$c.ERR_BAD_RESPONSE][Math.floor(r.status/100)-4],r.config,r.request,r)):e(r)}const Tu=function(e,t){e=e||10;const r=new Array(e),n=new Array(e);let i,o=0,a=0;return t=void 0!==t?t:1e3,function(s){const l=Date.now(),c=n[a];i||(i=l),r[o]=s,n[o]=l;let u=a,d=0;for(;u!==o;)d+=r[u++],u%=e;if(o=(o+1)%e,o===a&&(a=(a+1)%e),l-i1&&void 0!==arguments[1]?arguments[1]:Date.now();i=o,r=null,n&&(clearTimeout(n),n=null),e.apply(null,t)};return[function(){const e=Date.now(),t=e-i;for(var s=arguments.length,l=new Array(s),c=0;c=o?a(l,e):(r=l,n||(n=setTimeout((()=>{n=null,a(r)}),o-t)))},()=>r&&a(r)]},Cu=function(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:3,n=0;const i=Tu(50,250);return Mu((r=>{const o=r.loaded,a=r.lengthComputable?r.total:void 0,s=o-n,l=i(s);n=o;e({loaded:o,total:a,progress:a?o/a:void 0,bytes:s,rate:l||void 0,estimated:l&&a&&o<=a?(a-o)/l:void 0,event:r,lengthComputable:null!=a,[t?"download":"upload"]:!0})}),r)},Eu=(e,t)=>{const r=null!=e;return[n=>t[0]({lengthComputable:r,total:e,loaded:n}),t[1]]},Iu=e=>function(){for(var t=arguments.length,r=new Array(t),n=0;ne(...r)))},Pu=uu.hasStandardBrowserEnv?function(){const e=uu.navigator&&/(msie|trident)/i.test(uu.navigator.userAgent),t=document.createElement("a");let r;function n(r){let n=r;return e&&(t.setAttribute("href",n),n=t.href),t.setAttribute("href",n),{href:t.href,protocol:t.protocol?t.protocol.replace(/:$/,""):"",host:t.host,search:t.search?t.search.replace(/^\?/,""):"",hash:t.hash?t.hash.replace(/^#/,""):"",hostname:t.hostname,port:t.port,pathname:"/"===t.pathname.charAt(0)?t.pathname:"/"+t.pathname}}return r=n(window.location.href),function(e){const t=Bc.isString(e)?n(e):e;return t.protocol===r.protocol&&t.host===r.host}}():function(){return!0},Ou=uu.hasStandardBrowserEnv?{write(e,t,r,n,i,o){const a=[e+"="+encodeURIComponent(t)];Bc.isNumber(r)&&a.push("expires="+new Date(r).toGMTString()),Bc.isString(n)&&a.push("path="+n),Bc.isString(i)&&a.push("domain="+i),!0===o&&a.push("secure"),document.cookie=a.join("; ")},read(e){const t=document.cookie.match(new RegExp("(^|;\\s*)("+e+")=([^;]*)"));return t?decodeURIComponent(t[3]):null},remove(e){this.write(e,"",Date.now()-864e5)}}:{write(){},read:()=>null,remove(){}};function Ru(e,t){return e&&!/^([a-z][a-z\d+\-.]*:)?\/\//i.test(t)?function(e,t){return t?e.replace(/\/?\/$/,"")+"/"+t.replace(/^\/+/,""):e}(e,t):t}const Lu=e=>e instanceof bu?{...e}:e;function Du(e,t){t=t||{};const r={};function n(e,t,r){return Bc.isPlainObject(e)&&Bc.isPlainObject(t)?Bc.merge.call({caseless:r},e,t):Bc.isPlainObject(t)?Bc.merge({},t):Bc.isArray(t)?t.slice():t}function i(e,t,r){return Bc.isUndefined(t)?Bc.isUndefined(e)?void 0:n(void 0,e,r):n(e,t,r)}function o(e,t){if(!Bc.isUndefined(t))return n(void 0,t)}function a(e,t){return Bc.isUndefined(t)?Bc.isUndefined(e)?void 0:n(void 0,e):n(void 0,t)}function s(r,i,o){return o in t?n(r,i):o in e?n(void 0,r):void 0}const l={url:o,method:o,data:o,baseURL:a,transformRequest:a,transformResponse:a,paramsSerializer:a,timeout:a,timeoutMessage:a,withCredentials:a,withXSRFToken:a,adapter:a,responseType:a,xsrfCookieName:a,xsrfHeaderName:a,onUploadProgress:a,onDownloadProgress:a,decompress:a,maxContentLength:a,maxBodyLength:a,beforeRedirect:a,transport:a,httpAgent:a,httpsAgent:a,cancelToken:a,socketPath:a,responseEncoding:a,validateStatus:s,headers:(e,t)=>i(Lu(e),Lu(t),!0)};return Bc.forEach(Object.keys(Object.assign({},e,t)),(function(n){const o=l[n]||i,a=o(e[n],t[n],n);Bc.isUndefined(a)&&o!==s||(r[n]=a)})),r}const zu=e=>{const t=Du({},e);let r,{data:n,withXSRFToken:i,xsrfHeaderName:o,xsrfCookieName:a,headers:s,auth:l}=t;if(t.headers=s=bu.from(s),t.url=tu(Ru(t.baseURL,t.url),e.params,e.paramsSerializer),l&&s.set("Authorization","Basic "+btoa((l.username||"")+":"+(l.password?unescape(encodeURIComponent(l.password)):""))),Bc.isFormData(n))if(uu.hasStandardBrowserEnv||uu.hasStandardBrowserWebWorkerEnv)s.setContentType(void 0);else if(!1!==(r=s.getContentType())){const[e,...t]=r?r.split(";").map((e=>e.trim())).filter(Boolean):[];s.setContentType([e||"multipart/form-data",...t].join("; "))}if(uu.hasStandardBrowserEnv&&(i&&Bc.isFunction(i)&&(i=i(t)),i||!1!==i&&Pu(t.url))){const e=o&&a&&Ou.read(a);e&&s.set(o,e)}return t},ju="undefined"!==typeof XMLHttpRequest&&function(e){return new Promise((function(t,r){const n=zu(e);let i=n.data;const o=bu.from(n.headers).normalize();let a,s,l,c,u,{responseType:d,onUploadProgress:h,onDownloadProgress:p}=n;function f(){c&&c(),u&&u(),n.cancelToken&&n.cancelToken.unsubscribe(a),n.signal&&n.signal.removeEventListener("abort",a)}let m=new XMLHttpRequest;function g(){if(!m)return;const n=bu.from("getAllResponseHeaders"in m&&m.getAllResponseHeaders());Au((function(e){t(e),f()}),(function(e){r(e),f()}),{data:d&&"text"!==d&&"json"!==d?m.response:m.responseText,status:m.status,statusText:m.statusText,headers:n,config:e,request:m}),m=null}m.open(n.method.toUpperCase(),n.url,!0),m.timeout=n.timeout,"onloadend"in m?m.onloadend=g:m.onreadystatechange=function(){m&&4===m.readyState&&(0!==m.status||m.responseURL&&0===m.responseURL.indexOf("file:"))&&setTimeout(g)},m.onabort=function(){m&&(r(new $c("Request aborted",$c.ECONNABORTED,e,m)),m=null)},m.onerror=function(){r(new $c("Network Error",$c.ERR_NETWORK,e,m)),m=null},m.ontimeout=function(){let t=n.timeout?"timeout of "+n.timeout+"ms exceeded":"timeout exceeded";const i=n.transitional||nu;n.timeoutErrorMessage&&(t=n.timeoutErrorMessage),r(new $c(t,i.clarifyTimeoutError?$c.ETIMEDOUT:$c.ECONNABORTED,e,m)),m=null},void 0===i&&o.setContentType(null),"setRequestHeader"in m&&Bc.forEach(o.toJSON(),(function(e,t){m.setRequestHeader(t,e)})),Bc.isUndefined(n.withCredentials)||(m.withCredentials=!!n.withCredentials),d&&"json"!==d&&(m.responseType=n.responseType),p&&([l,u]=Cu(p,!0),m.addEventListener("progress",l)),h&&m.upload&&([s,c]=Cu(h),m.upload.addEventListener("progress",s),m.upload.addEventListener("loadend",c)),(n.cancelToken||n.signal)&&(a=t=>{m&&(r(!t||t.type?new Su(null,e,m):t),m.abort(),m=null)},n.cancelToken&&n.cancelToken.subscribe(a),n.signal&&(n.signal.aborted?a():n.signal.addEventListener("abort",a)));const y=function(e){const t=/^([-+\w]{1,25})(:?\/\/|:)/.exec(e);return t&&t[1]||""}(n.url);y&&-1===uu.protocols.indexOf(y)?r(new $c("Unsupported protocol "+y+":",$c.ERR_BAD_REQUEST,e)):m.send(i||null)}))},Fu=(e,t)=>{const{length:r}=e=e?e.filter(Boolean):[];if(t||r){let r,n=new AbortController;const i=function(e){if(!r){r=!0,a();const t=e instanceof Error?e:this.reason;n.abort(t instanceof $c?t:new Su(t instanceof Error?t.message:t))}};let o=t&&setTimeout((()=>{o=null,i(new $c(`timeout ${t} of ms exceeded`,$c.ETIMEDOUT))}),t);const a=()=>{e&&(o&&clearTimeout(o),o=null,e.forEach((e=>{e.unsubscribe?e.unsubscribe(i):e.removeEventListener("abort",i)})),e=null)};e.forEach((e=>e.addEventListener("abort",i)));const{signal:s}=n;return s.unsubscribe=()=>Bc.asap(a),s}},Nu=function*(e,t){let r=e.byteLength;if(!t||r{const i=async function*(e,t){for await(const r of Bu(e))yield*Nu(r,t)}(e,t);let o,a=0,s=e=>{o||(o=!0,n&&n(e))};return new ReadableStream({async pull(e){try{const{done:t,value:n}=await i.next();if(t)return s(),void e.close();let o=n.byteLength;if(r){let e=a+=o;r(e)}e.enqueue(new Uint8Array(n))}catch(t){throw s(t),t}},cancel:e=>(s(e),i.return())},{highWaterMark:2})},Uu="function"===typeof fetch&&"function"===typeof Request&&"function"===typeof Response,Hu=Uu&&"function"===typeof ReadableStream,$u=Uu&&("function"===typeof TextEncoder?(Wu=new TextEncoder,e=>Wu.encode(e)):async e=>new Uint8Array(await new Response(e).arrayBuffer()));var Wu;const qu=function(e){try{for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n{let e=!1;const t=new Request(uu.origin,{body:new ReadableStream,method:"POST",get duplex(){return e=!0,"half"}}).headers.has("Content-Type");return e&&!t})),Yu=Hu&&qu((()=>Bc.isReadableStream(new Response("").body))),Xu={stream:Yu&&(e=>e.body)};var Zu;Uu&&(Zu=new Response,["text","arrayBuffer","blob","formData","stream"].forEach((e=>{!Xu[e]&&(Xu[e]=Bc.isFunction(Zu[e])?t=>t[e]():(t,r)=>{throw new $c(`Response type '${e}' is not supported`,$c.ERR_NOT_SUPPORT,r)})})));const Ku=async(e,t)=>{const r=Bc.toFiniteNumber(e.getContentLength());return null==r?(async e=>{if(null==e)return 0;if(Bc.isBlob(e))return e.size;if(Bc.isSpecCompliantForm(e)){const t=new Request(uu.origin,{method:"POST",body:e});return(await t.arrayBuffer()).byteLength}return Bc.isArrayBufferView(e)||Bc.isArrayBuffer(e)?e.byteLength:(Bc.isURLSearchParams(e)&&(e+=""),Bc.isString(e)?(await $u(e)).byteLength:void 0)})(t):r},Ju={http:null,xhr:ju,fetch:Uu&&(async e=>{let{url:t,method:r,data:n,signal:i,cancelToken:o,timeout:a,onDownloadProgress:s,onUploadProgress:l,responseType:c,headers:u,withCredentials:d="same-origin",fetchOptions:h}=zu(e);c=c?(c+"").toLowerCase():"text";let p,f=Fu([i,o&&o.toAbortSignal()],a);const m=f&&f.unsubscribe&&(()=>{f.unsubscribe()});let g;try{if(l&&Gu&&"get"!==r&&"head"!==r&&0!==(g=await Ku(u,n))){let e,r=new Request(t,{method:"POST",body:n,duplex:"half"});if(Bc.isFormData(n)&&(e=r.headers.get("content-type"))&&u.setContentType(e),r.body){const[e,t]=Eu(g,Cu(Iu(l)));n=Vu(r.body,65536,e,t)}}Bc.isString(d)||(d=d?"include":"omit");const i="credentials"in Request.prototype;p=new Request(t,{...h,signal:f,method:r.toUpperCase(),headers:u.normalize().toJSON(),body:n,duplex:"half",credentials:i?d:void 0});let o=await fetch(p);const a=Yu&&("stream"===c||"response"===c);if(Yu&&(s||a&&m)){const e={};["status","statusText","headers"].forEach((t=>{e[t]=o[t]}));const t=Bc.toFiniteNumber(o.headers.get("content-length")),[r,n]=s&&Eu(t,Cu(Iu(s),!0))||[];o=new Response(Vu(o.body,65536,r,(()=>{n&&n(),m&&m()})),e)}c=c||"text";let y=await Xu[Bc.findKey(Xu,c)||"text"](o,e);return!a&&m&&m(),await new Promise(((t,r)=>{Au(t,r,{data:y,headers:bu.from(o.headers),status:o.status,statusText:o.statusText,config:e,request:p})}))}catch(y){if(m&&m(),y&&"TypeError"===y.name&&/fetch/i.test(y.message))throw Object.assign(new $c("Network Error",$c.ERR_NETWORK,e,p),{cause:y.cause||y});throw $c.from(y,y&&y.code,e,p)}})};Bc.forEach(Ju,((e,t)=>{if(e){try{Object.defineProperty(e,"name",{value:t})}catch(ene){}Object.defineProperty(e,"adapterName",{value:t})}}));const Qu=e=>`- ${e}`,ed=e=>Bc.isFunction(e)||null===e||!1===e,td=e=>{e=Bc.isArray(e)?e:[e];const{length:t}=e;let r,n;const i={};for(let o=0;o{let[t,r]=e;return`adapter ${t} `+(!1===r?"is not supported by the environment":"is not available in the build")}));let r=t?e.length>1?"since :\n"+e.map(Qu).join("\n"):" "+Qu(e[0]):"as no adapter specified";throw new $c("There is no suitable adapter to dispatch the request "+r,"ERR_NOT_SUPPORT")}return n};function rd(e){if(e.cancelToken&&e.cancelToken.throwIfRequested(),e.signal&&e.signal.aborted)throw new Su(null,e)}function nd(e){rd(e),e.headers=bu.from(e.headers),e.data=_u.call(e,e.transformRequest),-1!==["post","put","patch"].indexOf(e.method)&&e.headers.setContentType("application/x-www-form-urlencoded",!1);return td(e.adapter||pu.adapter)(e).then((function(t){return rd(e),t.data=_u.call(e,e.transformResponse,t),t.headers=bu.from(t.headers),t}),(function(t){return wu(t)||(rd(e),t&&t.response&&(t.response.data=_u.call(e,e.transformResponse,t.response),t.response.headers=bu.from(t.response.headers))),Promise.reject(t)}))}const id="1.7.7",od={};["object","boolean","number","function","string","symbol"].forEach(((e,t)=>{od[e]=function(r){return typeof r===e||"a"+(t<1?"n ":" ")+e}}));const ad={};od.transitional=function(e,t,r){function n(e,t){return"[Axios v1.7.7] Transitional option '"+e+"'"+t+(r?". "+r:"")}return(r,i,o)=>{if(!1===e)throw new $c(n(i," has been removed"+(t?" in "+t:"")),$c.ERR_DEPRECATED);return t&&!ad[i]&&(ad[i]=!0,console.warn(n(i," has been deprecated since v"+t+" and will be removed in the near future"))),!e||e(r,i,o)}};const sd={assertOptions:function(e,t,r){if("object"!==typeof e)throw new $c("options must be an object",$c.ERR_BAD_OPTION_VALUE);const n=Object.keys(e);let i=n.length;for(;i-- >0;){const o=n[i],a=t[o];if(a){const t=e[o],r=void 0===t||a(t,o,e);if(!0!==r)throw new $c("option "+o+" must be "+r,$c.ERR_BAD_OPTION_VALUE)}else if(!0!==r)throw new $c("Unknown option "+o,$c.ERR_BAD_OPTION)}},validators:od},ld=sd.validators;class cd{constructor(e){this.defaults=e,this.interceptors={request:new ru,response:new ru}}async request(e,t){try{return await this._request(e,t)}catch(r){if(r instanceof Error){let e;Error.captureStackTrace?Error.captureStackTrace(e={}):e=new Error;const t=e.stack?e.stack.replace(/^.+\n/,""):"";try{r.stack?t&&!String(r.stack).endsWith(t.replace(/^.+\n.+\n/,""))&&(r.stack+="\n"+t):r.stack=t}catch(ene){}}throw r}}_request(e,t){"string"===typeof e?(t=t||{}).url=e:t=e||{},t=Du(this.defaults,t);const{transitional:r,paramsSerializer:n,headers:i}=t;void 0!==r&&sd.assertOptions(r,{silentJSONParsing:ld.transitional(ld.boolean),forcedJSONParsing:ld.transitional(ld.boolean),clarifyTimeoutError:ld.transitional(ld.boolean)},!1),null!=n&&(Bc.isFunction(n)?t.paramsSerializer={serialize:n}:sd.assertOptions(n,{encode:ld.function,serialize:ld.function},!0)),t.method=(t.method||this.defaults.method||"get").toLowerCase();let o=i&&Bc.merge(i.common,i[t.method]);i&&Bc.forEach(["delete","get","head","post","put","patch","common"],(e=>{delete i[e]})),t.headers=bu.concat(o,i);const a=[];let s=!0;this.interceptors.request.forEach((function(e){"function"===typeof e.runWhen&&!1===e.runWhen(t)||(s=s&&e.synchronous,a.unshift(e.fulfilled,e.rejected))}));const l=[];let c;this.interceptors.response.forEach((function(e){l.push(e.fulfilled,e.rejected)}));let u,d=0;if(!s){const e=[nd.bind(this),void 0];for(e.unshift.apply(e,a),e.push.apply(e,l),u=e.length,c=Promise.resolve(t);d{if(!r._listeners)return;let t=r._listeners.length;for(;t-- >0;)r._listeners[t](e);r._listeners=null})),this.promise.then=e=>{let t;const n=new Promise((e=>{r.subscribe(e),t=e})).then(e);return n.cancel=function(){r.unsubscribe(t)},n},e((function(e,n,i){r.reason||(r.reason=new Su(e,n,i),t(r.reason))}))}throwIfRequested(){if(this.reason)throw this.reason}subscribe(e){this.reason?e(this.reason):this._listeners?this._listeners.push(e):this._listeners=[e]}unsubscribe(e){if(!this._listeners)return;const t=this._listeners.indexOf(e);-1!==t&&this._listeners.splice(t,1)}toAbortSignal(){const e=new AbortController,t=t=>{e.abort(t)};return this.subscribe(t),e.signal.unsubscribe=()=>this.unsubscribe(t),e.signal}static source(){let e;return{token:new dd((function(t){e=t})),cancel:e}}}const hd=dd;const pd={Continue:100,SwitchingProtocols:101,Processing:102,EarlyHints:103,Ok:200,Created:201,Accepted:202,NonAuthoritativeInformation:203,NoContent:204,ResetContent:205,PartialContent:206,MultiStatus:207,AlreadyReported:208,ImUsed:226,MultipleChoices:300,MovedPermanently:301,Found:302,SeeOther:303,NotModified:304,UseProxy:305,Unused:306,TemporaryRedirect:307,PermanentRedirect:308,BadRequest:400,Unauthorized:401,PaymentRequired:402,Forbidden:403,NotFound:404,MethodNotAllowed:405,NotAcceptable:406,ProxyAuthenticationRequired:407,RequestTimeout:408,Conflict:409,Gone:410,LengthRequired:411,PreconditionFailed:412,PayloadTooLarge:413,UriTooLong:414,UnsupportedMediaType:415,RangeNotSatisfiable:416,ExpectationFailed:417,ImATeapot:418,MisdirectedRequest:421,UnprocessableEntity:422,Locked:423,FailedDependency:424,TooEarly:425,UpgradeRequired:426,PreconditionRequired:428,TooManyRequests:429,RequestHeaderFieldsTooLarge:431,UnavailableForLegalReasons:451,InternalServerError:500,NotImplemented:501,BadGateway:502,ServiceUnavailable:503,GatewayTimeout:504,HttpVersionNotSupported:505,VariantAlsoNegotiates:506,InsufficientStorage:507,LoopDetected:508,NotExtended:510,NetworkAuthenticationRequired:511};Object.entries(pd).forEach((e=>{let[t,r]=e;pd[r]=t}));const fd=pd;const md=function e(t){const r=new ud(t),n=ec(ud.prototype.request,r);return Bc.extend(n,ud.prototype,r,{allOwnKeys:!0}),Bc.extend(n,r,null,{allOwnKeys:!0}),n.create=function(r){return e(Du(t,r))},n}(pu);md.Axios=ud,md.CanceledError=Su,md.CancelToken=hd,md.isCancel=wu,md.VERSION=id,md.toFormData=Xc,md.AxiosError=$c,md.Cancel=md.CanceledError,md.all=function(e){return Promise.all(e)},md.spread=function(e){return function(t){return e.apply(null,t)}},md.isAxiosError=function(e){return Bc.isObject(e)&&!0===e.isAxiosError},md.mergeConfig=Du,md.AxiosHeaders=bu,md.formToJSON=e=>du(Bc.isHTMLForm(e)?new FormData(e):e),md.getAdapter=td,md.HttpStatusCode=fd,md.default=md;const gd=md,yd={NODE_ENV:"production",PUBLIC_URL:"",WDS_SOCKET_HOST:void 0,WDS_SOCKET_PATH:void 0,WDS_SOCKET_PORT:void 0,FAST_REFRESH:!0}.REACT_APP_SERVER_HOST||window.location.hostname||"localhost",vd={NODE_ENV:"production",PUBLIC_URL:"",WDS_SOCKET_HOST:void 0,WDS_SOCKET_PATH:void 0,WDS_SOCKET_PORT:void 0,FAST_REFRESH:!0}.REACT_APP_SERVER_PROTO||window.location.protocol.replace(":","")||"http",xd={NODE_ENV:"production",PUBLIC_URL:"",WDS_SOCKET_HOST:void 0,WDS_SOCKET_PATH:void 0,WDS_SOCKET_PORT:void 0,FAST_REFRESH:!0}.REACT_APP_SERVER_PORT||window.location.port||("https"==vd?443:80),bd=null==xd?`${vd}://${yd}`:`${vd}://${yd}:${xd}`,_d=gd.create({baseURL:bd,timeout:6e5});_d.interceptors.request.use((async e=>(e.headers.Authorization=`Bearer ${Zl()}`,e.headers.ExToken=localStorage.getItem("ExToken"),e)),(e=>Promise.reject(e))),_d.interceptors.response.use((async e=>e),(async e=>{var t;if(401===(null===e||void 0===e||null===(t=e.response)||void 0===t?void 0:t.status))try{const{access_token:t}=await kd();return Xl(t),e.config.headers.Authorization=`Bearer ${t}`,gd(e.config)}catch(ene){var r;throw gd.isAxiosError(ene)&&400===(null===ene||void 0===ene||null===(r=ene.response)||void 0===r?void 0:r.status)&&Kl(),ene}return Promise.reject(e)}));const wd=_d,kd=async()=>(await wd.post("/auth/refresh",{refresh_token:localStorage.getItem("refresh_token")})).data;var Sd=r(22908);const Ad="user",Td=jl(`${Ad}/login`,(async(e,t)=>{try{const t=await(async e=>(await wd.post("/auth/login",e)).data)(e);return t}catch(ene){return t.rejectWithValue(ene)}})),Md=jl(`${Ad}/getMe`,(async(e,t)=>{try{return await(async()=>(await wd.get("/users/me")).data)()}catch(ene){return t.rejectWithValue(ene)}})),Cd=jl(`${Ad}/updateMe`,(async(e,t)=>{try{const r=await(async e=>(await wd.put("/users/me",e)).data)(e);return await t.dispatch(Md()),r}catch(ene){return t.rejectWithValue(ene)}})),Ed=jl(`${Ad}/deleteMe`,(async(e,t)=>{try{return await(async()=>(await wd.delete("/users/me")).data)()}catch(ene){return t.rejectWithValue(ene)}})),Id=jl(`${Ad}/updateMePassword`,(async(e,t)=>{try{return await(async e=>(await wd.put("/users/me/password",e)).data)(e)}catch(ene){return t.rejectWithValue(ene)}})),Pd=jl(`${Ad}/getListUser`,(async(e,t)=>{try{return await(async e=>{const t=(0,Sd.stringify)(e,{indices:!1});return(await wd.get(`/admin/users?${t}`)).data})(e)}catch(ene){return t.rejectWithValue(ene)}})),Od=jl(`${Ad}/getListUserSearch`,(async(e,t)=>{try{return await(async e=>(await wd.get("/users/search/share_users"+(e.keyword?`?keyword=${e.keyword}`:""))).data)(e)}catch(ene){return t.rejectWithValue(ene)}})),Rd=jl(`${Ad}/createUser`,(async(e,t)=>{try{const{dispatch:r}=t,n=await(async e=>(await wd.post("/admin/users",e)).data)(e.data);return await r(Pd(e.params)),n}catch(ene){return t.rejectWithValue(ene)}})),Ld=jl(`${Ad}/updateUser`,(async(e,t)=>{const{dispatch:r}=t;try{const t=await(async(e,t)=>(await wd.put(`/admin/users/${e}`,t)).data)(e.id,e.data);return await r(Pd(e.params)),t}catch(ene){return t.rejectWithValue(ene)}})),Dd=jl(`${Ad}/deleteUser`,(async(e,t)=>{const{dispatch:r}=t;try{const t=await(async e=>(await wd.delete(`/admin/users/${e}`)).data)(e.id);return await r(Pd(e.params)),t}catch(ene){return t.rejectWithValue(ene)}})),zd={currentUser:void 0,listUserSearch:void 0,listUser:void 0,loading:!1},jd=Pl({name:Ad,initialState:zd,reducers:{logout:()=>(Jl(),Ql(),zd),resetUserSearch:e=>{e.listUserSearch=[]}},extraReducers:e=>{e.addCase(Td.fulfilled,((e,t)=>{var r,n;Xl(t.payload.access_token),r=t.payload.refresh_token,localStorage.setItem("refresh_token",r),n=t.payload.ex_token,localStorage.setItem("ExToken",n)})).addCase(Md.fulfilled,((e,t)=>{e.currentUser=t.payload})).addCase(Pd.fulfilled,((e,t)=>{e.listUser=t.payload,e.loading=!1})).addCase(Od.fulfilled,((e,t)=>{e.listUserSearch=t.payload})).addMatcher(Bl(Od.rejected,Rd.rejected,Pd.rejected,Ld.rejected,Id.rejected,Id.fulfilled,Dd.fulfilled,Dd.rejected,Ed.rejected,Ed.fulfilled,Cd.rejected,Cd.fulfilled,Rd.fulfilled),(e=>{e.loading=!1})).addMatcher(Bl(Pd.pending,Dd.pending,Rd.pending,Cd.pending,Ed.pending,Ld.pending,Od.pending,Id.pending),(e=>{e.loading=!0})).addMatcher(Bl(Td.rejected,Md.rejected,Ed.fulfilled),(()=>(Jl(),Ql(),zd)))}}),{logout:Fd,resetUserSearch:Nd}=jd.actions,Bd=jd.reducer,Vd=()=>{const[e,t]=(0,n.useState)(null),r=Ye(),i=C();return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(oi,{color:"inherit","aria-label":"open profile menu","aria-haspopup":"true",onClick:e=>{t(e.currentTarget)},children:(0,j.jsx)($i.A,{})}),(0,j.jsxs)(Da,{id:"profile-menu",anchorEl:e,anchorOrigin:{vertical:"top",horizontal:"right"},keepMounted:!0,transformOrigin:{vertical:"top",horizontal:"right"},open:Boolean(e),onClose:()=>{t(null)},children:[(0,j.jsxs)(qa,{onClick:()=>{t(null),r("/console/account")},children:[(0,j.jsx)(qi.A,{})," Account Profile"]}),(0,j.jsxs)(qa,{onClick:()=>{t(null),i(Fd()),r("/login")},children:[(0,j.jsx)(Wi.A,{}),"SIGN OUT"]})]})]})};var Ud=r(59662);const Hd=(0,Ud.A)((0,j.jsx)("path",{d:"M12 1.27a11 11 0 00-3.48 21.46c.55.09.73-.28.73-.55v-1.84c-3.03.64-3.67-1.46-3.67-1.46-.55-1.29-1.28-1.65-1.28-1.65-.92-.65.1-.65.1-.65 1.1 0 1.73 1.1 1.73 1.1.92 1.65 2.57 1.2 3.21.92a2 2 0 01.64-1.47c-2.47-.27-5.04-1.19-5.04-5.5 0-1.1.46-2.1 1.2-2.84a3.76 3.76 0 010-2.93s.91-.28 3.11 1.1c1.8-.49 3.7-.49 5.5 0 2.1-1.38 3.02-1.1 3.02-1.1a3.76 3.76 0 010 2.93c.83.74 1.2 1.74 1.2 2.94 0 4.21-2.57 5.13-5.04 5.4.45.37.82.92.82 2.02v3.03c0 .27.1.64.73.55A11 11 0 0012 1.27"}),"GitHub"),$d=(0,Ud.A)([(0,j.jsx)("path",{d:"M21 5c-1.11-.35-2.33-.5-3.5-.5-1.95 0-4.05.4-5.5 1.5-1.45-1.1-3.55-1.5-5.5-1.5S2.45 4.9 1 6v14.65c0 .25.25.5.5.5.1 0 .15-.05.25-.05C3.1 20.45 5.05 20 6.5 20c1.95 0 4.05.4 5.5 1.5 1.35-.85 3.8-1.5 5.5-1.5 1.65 0 3.35.3 4.75 1.05.1.05.15.05.25.05.25 0 .5-.25.5-.5V6c-.6-.45-1.25-.75-2-1m0 13.5c-1.1-.35-2.3-.5-3.5-.5-1.7 0-4.15.65-5.5 1.5V8c1.35-.85 3.8-1.5 5.5-1.5 1.2 0 2.4.15 3.5.5z"},"0"),(0,j.jsx)("path",{d:"M17.5 10.5c.88 0 1.73.09 2.5.26V9.24c-.79-.15-1.64-.24-2.5-.24-1.7 0-3.24.29-4.5.83v1.66c1.13-.64 2.7-.99 4.5-.99M13 12.49v1.66c1.13-.64 2.7-.99 4.5-.99.88 0 1.73.09 2.5.26V11.9c-.79-.15-1.64-.24-2.5-.24-1.7 0-3.24.3-4.5.83m4.5 1.84c-1.7 0-3.24.29-4.5.83v1.66c1.13-.64 2.7-.99 4.5-.99.88 0 1.73.09 2.5.26v-1.52c-.79-.16-1.64-.24-2.5-.24"},"1")],"MenuBook"),Wd=(0,Ud.A)((0,j.jsx)("path",{d:"M19 19H5V5h7V3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2v-7h-2zM14 3v2h3.59l-9.83 9.83 1.41 1.41L19 6.41V10h2V3z"}),"OpenInNew"),qd=(0,Ud.A)((0,j.jsx)("path",{d:"M22 5v2h-3v3h-2V7h-3V5h3V2h2v3zm-3 14H5V5h6V3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2v-6h-2zm-4-6v4h2v-4zm-4 4h2V9h-2zm-2 0v-6H7v6z"}),"Addchart");var Gd=r(92374);function Yd(e){if(null==e)return window;if("[object Window]"!==e.toString()){var t=e.ownerDocument;return t&&t.defaultView||window}return e}function Xd(e){return e instanceof Yd(e).Element||e instanceof Element}function Zd(e){return e instanceof Yd(e).HTMLElement||e instanceof HTMLElement}function Kd(e){return"undefined"!==typeof ShadowRoot&&(e instanceof Yd(e).ShadowRoot||e instanceof ShadowRoot)}var Jd=Math.max,Qd=Math.min,eh=Math.round;function th(){var e=navigator.userAgentData;return null!=e&&e.brands&&Array.isArray(e.brands)?e.brands.map((function(e){return e.brand+"/"+e.version})).join(" "):navigator.userAgent}function rh(){return!/^((?!chrome|android).)*safari/i.test(th())}function nh(e,t,r){void 0===t&&(t=!1),void 0===r&&(r=!1);var n=e.getBoundingClientRect(),i=1,o=1;t&&Zd(e)&&(i=e.offsetWidth>0&&eh(n.width)/e.offsetWidth||1,o=e.offsetHeight>0&&eh(n.height)/e.offsetHeight||1);var a=(Xd(e)?Yd(e):window).visualViewport,s=!rh()&&r,l=(n.left+(s&&a?a.offsetLeft:0))/i,c=(n.top+(s&&a?a.offsetTop:0))/o,u=n.width/i,d=n.height/o;return{width:u,height:d,top:c,right:l+u,bottom:c+d,left:l,x:l,y:c}}function ih(e){var t=Yd(e);return{scrollLeft:t.pageXOffset,scrollTop:t.pageYOffset}}function oh(e){return e?(e.nodeName||"").toLowerCase():null}function ah(e){return((Xd(e)?e.ownerDocument:e.document)||window.document).documentElement}function sh(e){return nh(ah(e)).left+ih(e).scrollLeft}function lh(e){return Yd(e).getComputedStyle(e)}function ch(e){var t=lh(e),r=t.overflow,n=t.overflowX,i=t.overflowY;return/auto|scroll|overlay|hidden/.test(r+i+n)}function uh(e,t,r){void 0===r&&(r=!1);var n=Zd(t),i=Zd(t)&&function(e){var t=e.getBoundingClientRect(),r=eh(t.width)/e.offsetWidth||1,n=eh(t.height)/e.offsetHeight||1;return 1!==r||1!==n}(t),o=ah(t),a=nh(e,i,r),s={scrollLeft:0,scrollTop:0},l={x:0,y:0};return(n||!n&&!r)&&(("body"!==oh(t)||ch(o))&&(s=function(e){return e!==Yd(e)&&Zd(e)?{scrollLeft:(t=e).scrollLeft,scrollTop:t.scrollTop}:ih(e);var t}(t)),Zd(t)?((l=nh(t,!0)).x+=t.clientLeft,l.y+=t.clientTop):o&&(l.x=sh(o))),{x:a.left+s.scrollLeft-l.x,y:a.top+s.scrollTop-l.y,width:a.width,height:a.height}}function dh(e){var t=nh(e),r=e.offsetWidth,n=e.offsetHeight;return Math.abs(t.width-r)<=1&&(r=t.width),Math.abs(t.height-n)<=1&&(n=t.height),{x:e.offsetLeft,y:e.offsetTop,width:r,height:n}}function hh(e){return"html"===oh(e)?e:e.assignedSlot||e.parentNode||(Kd(e)?e.host:null)||ah(e)}function ph(e){return["html","body","#document"].indexOf(oh(e))>=0?e.ownerDocument.body:Zd(e)&&ch(e)?e:ph(hh(e))}function fh(e,t){var r;void 0===t&&(t=[]);var n=ph(e),i=n===(null==(r=e.ownerDocument)?void 0:r.body),o=Yd(n),a=i?[o].concat(o.visualViewport||[],ch(n)?n:[]):n,s=t.concat(a);return i?s:s.concat(fh(hh(a)))}function mh(e){return["table","td","th"].indexOf(oh(e))>=0}function gh(e){return Zd(e)&&"fixed"!==lh(e).position?e.offsetParent:null}function yh(e){for(var t=Yd(e),r=gh(e);r&&mh(r)&&"static"===lh(r).position;)r=gh(r);return r&&("html"===oh(r)||"body"===oh(r)&&"static"===lh(r).position)?t:r||function(e){var t=/firefox/i.test(th());if(/Trident/i.test(th())&&Zd(e)&&"fixed"===lh(e).position)return null;var r=hh(e);for(Kd(r)&&(r=r.host);Zd(r)&&["html","body"].indexOf(oh(r))<0;){var n=lh(r);if("none"!==n.transform||"none"!==n.perspective||"paint"===n.contain||-1!==["transform","perspective"].indexOf(n.willChange)||t&&"filter"===n.willChange||t&&n.filter&&"none"!==n.filter)return r;r=r.parentNode}return null}(e)||t}var vh="top",xh="bottom",bh="right",_h="left",wh="auto",kh=[vh,xh,bh,_h],Sh="start",Ah="end",Th="viewport",Mh="popper",Ch=kh.reduce((function(e,t){return e.concat([t+"-"+Sh,t+"-"+Ah])}),[]),Eh=[].concat(kh,[wh]).reduce((function(e,t){return e.concat([t,t+"-"+Sh,t+"-"+Ah])}),[]),Ih=["beforeRead","read","afterRead","beforeMain","main","afterMain","beforeWrite","write","afterWrite"];function Ph(e){var t=new Map,r=new Set,n=[];function i(e){r.add(e.name),[].concat(e.requires||[],e.requiresIfExists||[]).forEach((function(e){if(!r.has(e)){var n=t.get(e);n&&i(n)}})),n.push(e)}return e.forEach((function(e){t.set(e.name,e)})),e.forEach((function(e){r.has(e.name)||i(e)})),n}function Oh(e){var t;return function(){return t||(t=new Promise((function(r){Promise.resolve().then((function(){t=void 0,r(e())}))}))),t}}var Rh={placement:"bottom",modifiers:[],strategy:"absolute"};function Lh(){for(var e=arguments.length,t=new Array(e),r=0;r=0?"x":"y"}function Bh(e){var t,r=e.reference,n=e.element,i=e.placement,o=i?jh(i):null,a=i?Fh(i):null,s=r.x+r.width/2-n.width/2,l=r.y+r.height/2-n.height/2;switch(o){case vh:t={x:s,y:r.y-n.height};break;case xh:t={x:s,y:r.y+r.height};break;case bh:t={x:r.x+r.width,y:l};break;case _h:t={x:r.x-n.width,y:l};break;default:t={x:r.x,y:r.y}}var c=o?Nh(o):null;if(null!=c){var u="y"===c?"height":"width";switch(a){case Sh:t[c]=t[c]-(r[u]/2-n[u]/2);break;case Ah:t[c]=t[c]+(r[u]/2-n[u]/2)}}return t}var Vh={top:"auto",right:"auto",bottom:"auto",left:"auto"};function Uh(e){var t,r=e.popper,n=e.popperRect,i=e.placement,o=e.variation,a=e.offsets,s=e.position,l=e.gpuAcceleration,c=e.adaptive,u=e.roundOffsets,d=e.isFixed,h=a.x,p=void 0===h?0:h,f=a.y,m=void 0===f?0:f,g="function"===typeof u?u({x:p,y:m}):{x:p,y:m};p=g.x,m=g.y;var y=a.hasOwnProperty("x"),v=a.hasOwnProperty("y"),x=_h,b=vh,_=window;if(c){var w=yh(r),k="clientHeight",S="clientWidth";if(w===Yd(r)&&"static"!==lh(w=ah(r)).position&&"absolute"===s&&(k="scrollHeight",S="scrollWidth"),i===vh||(i===_h||i===bh)&&o===Ah)b=xh,m-=(d&&w===_&&_.visualViewport?_.visualViewport.height:w[k])-n.height,m*=l?1:-1;if(i===_h||(i===vh||i===xh)&&o===Ah)x=bh,p-=(d&&w===_&&_.visualViewport?_.visualViewport.width:w[S])-n.width,p*=l?1:-1}var A,T=Object.assign({position:s},c&&Vh),M=!0===u?function(e,t){var r=e.x,n=e.y,i=t.devicePixelRatio||1;return{x:eh(r*i)/i||0,y:eh(n*i)/i||0}}({x:p,y:m},Yd(r)):{x:p,y:m};return p=M.x,m=M.y,l?Object.assign({},T,((A={})[b]=v?"0":"",A[x]=y?"0":"",A.transform=(_.devicePixelRatio||1)<=1?"translate("+p+"px, "+m+"px)":"translate3d("+p+"px, "+m+"px, 0)",A)):Object.assign({},T,((t={})[b]=v?m+"px":"",t[x]=y?p+"px":"",t.transform="",t))}var Hh={left:"right",right:"left",bottom:"top",top:"bottom"};function $h(e){return e.replace(/left|right|bottom|top/g,(function(e){return Hh[e]}))}var Wh={start:"end",end:"start"};function qh(e){return e.replace(/start|end/g,(function(e){return Wh[e]}))}function Gh(e,t){var r=t.getRootNode&&t.getRootNode();if(e.contains(t))return!0;if(r&&Kd(r)){var n=t;do{if(n&&e.isSameNode(n))return!0;n=n.parentNode||n.host}while(n)}return!1}function Yh(e){return Object.assign({},e,{left:e.x,top:e.y,right:e.x+e.width,bottom:e.y+e.height})}function Xh(e,t,r){return t===Th?Yh(function(e,t){var r=Yd(e),n=ah(e),i=r.visualViewport,o=n.clientWidth,a=n.clientHeight,s=0,l=0;if(i){o=i.width,a=i.height;var c=rh();(c||!c&&"fixed"===t)&&(s=i.offsetLeft,l=i.offsetTop)}return{width:o,height:a,x:s+sh(e),y:l}}(e,r)):Xd(t)?function(e,t){var r=nh(e,!1,"fixed"===t);return r.top=r.top+e.clientTop,r.left=r.left+e.clientLeft,r.bottom=r.top+e.clientHeight,r.right=r.left+e.clientWidth,r.width=e.clientWidth,r.height=e.clientHeight,r.x=r.left,r.y=r.top,r}(t,r):Yh(function(e){var t,r=ah(e),n=ih(e),i=null==(t=e.ownerDocument)?void 0:t.body,o=Jd(r.scrollWidth,r.clientWidth,i?i.scrollWidth:0,i?i.clientWidth:0),a=Jd(r.scrollHeight,r.clientHeight,i?i.scrollHeight:0,i?i.clientHeight:0),s=-n.scrollLeft+sh(e),l=-n.scrollTop;return"rtl"===lh(i||r).direction&&(s+=Jd(r.clientWidth,i?i.clientWidth:0)-o),{width:o,height:a,x:s,y:l}}(ah(e)))}function Zh(e,t,r,n){var i="clippingParents"===t?function(e){var t=fh(hh(e)),r=["absolute","fixed"].indexOf(lh(e).position)>=0&&Zd(e)?yh(e):e;return Xd(r)?t.filter((function(e){return Xd(e)&&Gh(e,r)&&"body"!==oh(e)})):[]}(e):[].concat(t),o=[].concat(i,[r]),a=o[0],s=o.reduce((function(t,r){var i=Xh(e,r,n);return t.top=Jd(i.top,t.top),t.right=Qd(i.right,t.right),t.bottom=Qd(i.bottom,t.bottom),t.left=Jd(i.left,t.left),t}),Xh(e,a,n));return s.width=s.right-s.left,s.height=s.bottom-s.top,s.x=s.left,s.y=s.top,s}function Kh(e){return Object.assign({},{top:0,right:0,bottom:0,left:0},e)}function Jh(e,t){return t.reduce((function(t,r){return t[r]=e,t}),{})}function Qh(e,t){void 0===t&&(t={});var r=t,n=r.placement,i=void 0===n?e.placement:n,o=r.strategy,a=void 0===o?e.strategy:o,s=r.boundary,l=void 0===s?"clippingParents":s,c=r.rootBoundary,u=void 0===c?Th:c,d=r.elementContext,h=void 0===d?Mh:d,p=r.altBoundary,f=void 0!==p&&p,m=r.padding,g=void 0===m?0:m,y=Kh("number"!==typeof g?g:Jh(g,kh)),v=h===Mh?"reference":Mh,x=e.rects.popper,b=e.elements[f?v:h],_=Zh(Xd(b)?b:b.contextElement||ah(e.elements.popper),l,u,a),w=nh(e.elements.reference),k=Bh({reference:w,element:x,strategy:"absolute",placement:i}),S=Yh(Object.assign({},x,k)),A=h===Mh?S:w,T={top:_.top-A.top+y.top,bottom:A.bottom-_.bottom+y.bottom,left:_.left-A.left+y.left,right:A.right-_.right+y.right},M=e.modifiersData.offset;if(h===Mh&&M){var C=M[i];Object.keys(T).forEach((function(e){var t=[bh,xh].indexOf(e)>=0?1:-1,r=[vh,xh].indexOf(e)>=0?"y":"x";T[e]+=C[r]*t}))}return T}function ep(e,t,r){return Jd(e,Qd(t,r))}function tp(e,t,r){return void 0===r&&(r={x:0,y:0}),{top:e.top-t.height-r.y,right:e.right-t.width+r.x,bottom:e.bottom-t.height+r.y,left:e.left-t.width-r.x}}function rp(e){return[vh,bh,xh,_h].some((function(t){return e[t]>=0}))}var np=Dh({defaultModifiers:[{name:"eventListeners",enabled:!0,phase:"write",fn:function(){},effect:function(e){var t=e.state,r=e.instance,n=e.options,i=n.scroll,o=void 0===i||i,a=n.resize,s=void 0===a||a,l=Yd(t.elements.popper),c=[].concat(t.scrollParents.reference,t.scrollParents.popper);return o&&c.forEach((function(e){e.addEventListener("scroll",r.update,zh)})),s&&l.addEventListener("resize",r.update,zh),function(){o&&c.forEach((function(e){e.removeEventListener("scroll",r.update,zh)})),s&&l.removeEventListener("resize",r.update,zh)}},data:{}},{name:"popperOffsets",enabled:!0,phase:"read",fn:function(e){var t=e.state,r=e.name;t.modifiersData[r]=Bh({reference:t.rects.reference,element:t.rects.popper,strategy:"absolute",placement:t.placement})},data:{}},{name:"computeStyles",enabled:!0,phase:"beforeWrite",fn:function(e){var t=e.state,r=e.options,n=r.gpuAcceleration,i=void 0===n||n,o=r.adaptive,a=void 0===o||o,s=r.roundOffsets,l=void 0===s||s,c={placement:jh(t.placement),variation:Fh(t.placement),popper:t.elements.popper,popperRect:t.rects.popper,gpuAcceleration:i,isFixed:"fixed"===t.options.strategy};null!=t.modifiersData.popperOffsets&&(t.styles.popper=Object.assign({},t.styles.popper,Uh(Object.assign({},c,{offsets:t.modifiersData.popperOffsets,position:t.options.strategy,adaptive:a,roundOffsets:l})))),null!=t.modifiersData.arrow&&(t.styles.arrow=Object.assign({},t.styles.arrow,Uh(Object.assign({},c,{offsets:t.modifiersData.arrow,position:"absolute",adaptive:!1,roundOffsets:l})))),t.attributes.popper=Object.assign({},t.attributes.popper,{"data-popper-placement":t.placement})},data:{}},{name:"applyStyles",enabled:!0,phase:"write",fn:function(e){var t=e.state;Object.keys(t.elements).forEach((function(e){var r=t.styles[e]||{},n=t.attributes[e]||{},i=t.elements[e];Zd(i)&&oh(i)&&(Object.assign(i.style,r),Object.keys(n).forEach((function(e){var t=n[e];!1===t?i.removeAttribute(e):i.setAttribute(e,!0===t?"":t)})))}))},effect:function(e){var t=e.state,r={popper:{position:t.options.strategy,left:"0",top:"0",margin:"0"},arrow:{position:"absolute"},reference:{}};return Object.assign(t.elements.popper.style,r.popper),t.styles=r,t.elements.arrow&&Object.assign(t.elements.arrow.style,r.arrow),function(){Object.keys(t.elements).forEach((function(e){var n=t.elements[e],i=t.attributes[e]||{},o=Object.keys(t.styles.hasOwnProperty(e)?t.styles[e]:r[e]).reduce((function(e,t){return e[t]="",e}),{});Zd(n)&&oh(n)&&(Object.assign(n.style,o),Object.keys(i).forEach((function(e){n.removeAttribute(e)})))}))}},requires:["computeStyles"]},{name:"offset",enabled:!0,phase:"main",requires:["popperOffsets"],fn:function(e){var t=e.state,r=e.options,n=e.name,i=r.offset,o=void 0===i?[0,0]:i,a=Eh.reduce((function(e,r){return e[r]=function(e,t,r){var n=jh(e),i=[_h,vh].indexOf(n)>=0?-1:1,o="function"===typeof r?r(Object.assign({},t,{placement:e})):r,a=o[0],s=o[1];return a=a||0,s=(s||0)*i,[_h,bh].indexOf(n)>=0?{x:s,y:a}:{x:a,y:s}}(r,t.rects,o),e}),{}),s=a[t.placement],l=s.x,c=s.y;null!=t.modifiersData.popperOffsets&&(t.modifiersData.popperOffsets.x+=l,t.modifiersData.popperOffsets.y+=c),t.modifiersData[n]=a}},{name:"flip",enabled:!0,phase:"main",fn:function(e){var t=e.state,r=e.options,n=e.name;if(!t.modifiersData[n]._skip){for(var i=r.mainAxis,o=void 0===i||i,a=r.altAxis,s=void 0===a||a,l=r.fallbackPlacements,c=r.padding,u=r.boundary,d=r.rootBoundary,h=r.altBoundary,p=r.flipVariations,f=void 0===p||p,m=r.allowedAutoPlacements,g=t.options.placement,y=jh(g),v=l||(y===g||!f?[$h(g)]:function(e){if(jh(e)===wh)return[];var t=$h(e);return[qh(e),t,qh(t)]}(g)),x=[g].concat(v).reduce((function(e,r){return e.concat(jh(r)===wh?function(e,t){void 0===t&&(t={});var r=t,n=r.placement,i=r.boundary,o=r.rootBoundary,a=r.padding,s=r.flipVariations,l=r.allowedAutoPlacements,c=void 0===l?Eh:l,u=Fh(n),d=u?s?Ch:Ch.filter((function(e){return Fh(e)===u})):kh,h=d.filter((function(e){return c.indexOf(e)>=0}));0===h.length&&(h=d);var p=h.reduce((function(t,r){return t[r]=Qh(e,{placement:r,boundary:i,rootBoundary:o,padding:a})[jh(r)],t}),{});return Object.keys(p).sort((function(e,t){return p[e]-p[t]}))}(t,{placement:r,boundary:u,rootBoundary:d,padding:c,flipVariations:f,allowedAutoPlacements:m}):r)}),[]),b=t.rects.reference,_=t.rects.popper,w=new Map,k=!0,S=x[0],A=0;A=0,I=E?"width":"height",P=Qh(t,{placement:T,boundary:u,rootBoundary:d,altBoundary:h,padding:c}),O=E?C?bh:_h:C?xh:vh;b[I]>_[I]&&(O=$h(O));var R=$h(O),L=[];if(o&&L.push(P[M]<=0),s&&L.push(P[O]<=0,P[R]<=0),L.every((function(e){return e}))){S=T,k=!1;break}w.set(T,L)}if(k)for(var D=function(e){var t=x.find((function(t){var r=w.get(t);if(r)return r.slice(0,e).every((function(e){return e}))}));if(t)return S=t,"break"},z=f?3:1;z>0;z--){if("break"===D(z))break}t.placement!==S&&(t.modifiersData[n]._skip=!0,t.placement=S,t.reset=!0)}},requiresIfExists:["offset"],data:{_skip:!1}},{name:"preventOverflow",enabled:!0,phase:"main",fn:function(e){var t=e.state,r=e.options,n=e.name,i=r.mainAxis,o=void 0===i||i,a=r.altAxis,s=void 0!==a&&a,l=r.boundary,c=r.rootBoundary,u=r.altBoundary,d=r.padding,h=r.tether,p=void 0===h||h,f=r.tetherOffset,m=void 0===f?0:f,g=Qh(t,{boundary:l,rootBoundary:c,padding:d,altBoundary:u}),y=jh(t.placement),v=Fh(t.placement),x=!v,b=Nh(y),_="x"===b?"y":"x",w=t.modifiersData.popperOffsets,k=t.rects.reference,S=t.rects.popper,A="function"===typeof m?m(Object.assign({},t.rects,{placement:t.placement})):m,T="number"===typeof A?{mainAxis:A,altAxis:A}:Object.assign({mainAxis:0,altAxis:0},A),M=t.modifiersData.offset?t.modifiersData.offset[t.placement]:null,C={x:0,y:0};if(w){if(o){var E,I="y"===b?vh:_h,P="y"===b?xh:bh,O="y"===b?"height":"width",R=w[b],L=R+g[I],D=R-g[P],z=p?-S[O]/2:0,j=v===Sh?k[O]:S[O],F=v===Sh?-S[O]:-k[O],N=t.elements.arrow,B=p&&N?dh(N):{width:0,height:0},V=t.modifiersData["arrow#persistent"]?t.modifiersData["arrow#persistent"].padding:{top:0,right:0,bottom:0,left:0},U=V[I],H=V[P],$=ep(0,k[O],B[O]),W=x?k[O]/2-z-$-U-T.mainAxis:j-$-U-T.mainAxis,q=x?-k[O]/2+z+$+H+T.mainAxis:F+$+H+T.mainAxis,G=t.elements.arrow&&yh(t.elements.arrow),Y=G?"y"===b?G.clientTop||0:G.clientLeft||0:0,X=null!=(E=null==M?void 0:M[b])?E:0,Z=R+q-X,K=ep(p?Qd(L,R+W-X-Y):L,R,p?Jd(D,Z):D);w[b]=K,C[b]=K-R}if(s){var J,Q="x"===b?vh:_h,ee="x"===b?xh:bh,te=w[_],re="y"===_?"height":"width",ne=te+g[Q],ie=te-g[ee],oe=-1!==[vh,_h].indexOf(y),ae=null!=(J=null==M?void 0:M[_])?J:0,se=oe?ne:te-k[re]-S[re]-ae+T.altAxis,le=oe?te+k[re]+S[re]-ae-T.altAxis:ie,ce=p&&oe?function(e,t,r){var n=ep(e,t,r);return n>r?r:n}(se,te,le):ep(p?se:ne,te,p?le:ie);w[_]=ce,C[_]=ce-te}t.modifiersData[n]=C}},requiresIfExists:["offset"]},{name:"arrow",enabled:!0,phase:"main",fn:function(e){var t,r=e.state,n=e.name,i=e.options,o=r.elements.arrow,a=r.modifiersData.popperOffsets,s=jh(r.placement),l=Nh(s),c=[_h,bh].indexOf(s)>=0?"height":"width";if(o&&a){var u=function(e,t){return Kh("number"!==typeof(e="function"===typeof e?e(Object.assign({},t.rects,{placement:t.placement})):e)?e:Jh(e,kh))}(i.padding,r),d=dh(o),h="y"===l?vh:_h,p="y"===l?xh:bh,f=r.rects.reference[c]+r.rects.reference[l]-a[l]-r.rects.popper[c],m=a[l]-r.rects.reference[l],g=yh(o),y=g?"y"===l?g.clientHeight||0:g.clientWidth||0:0,v=f/2-m/2,x=u[h],b=y-d[c]-u[p],_=y/2-d[c]/2+v,w=ep(x,_,b),k=l;r.modifiersData[n]=((t={})[k]=w,t.centerOffset=w-_,t)}},effect:function(e){var t=e.state,r=e.options.element,n=void 0===r?"[data-popper-arrow]":r;null!=n&&("string"!==typeof n||(n=t.elements.popper.querySelector(n)))&&Gh(t.elements.popper,n)&&(t.elements.arrow=n)},requires:["popperOffsets"],requiresIfExists:["preventOverflow"]},{name:"hide",enabled:!0,phase:"main",requiresIfExists:["preventOverflow"],fn:function(e){var t=e.state,r=e.name,n=t.rects.reference,i=t.rects.popper,o=t.modifiersData.preventOverflow,a=Qh(t,{elementContext:"reference"}),s=Qh(t,{altBoundary:!0}),l=tp(a,n),c=tp(s,i,o),u=rp(l),d=rp(c);t.modifiersData[r]={referenceClippingOffsets:l,popperEscapeOffsets:c,isReferenceHidden:u,hasPopperEscaped:d},t.attributes.popper=Object.assign({},t.attributes.popper,{"data-popper-reference-hidden":u,"data-popper-escaped":d})}}]});function ip(e){return(0,Yn.Ay)("MuiPopper",e)}(0,Ln.A)("MuiPopper",["root"]);const op=["anchorEl","children","direction","disablePortal","modifiers","open","placement","popperOptions","popperRef","slotProps","slots","TransitionProps","ownerState"],ap=["anchorEl","children","container","direction","disablePortal","keepMounted","modifiers","open","placement","popperOptions","popperRef","style","transition","slotProps","slots"];function sp(e){return"function"===typeof e?e():e}function lp(e){return void 0!==e.nodeType}const cp={},up=n.forwardRef((function(e,t){var r;const{anchorEl:i,children:o,direction:a,disablePortal:s,modifiers:l,open:c,placement:u,popperOptions:d,popperRef:h,slotProps:p={},slots:f={},TransitionProps:m}=e,g=(0,R.A)(e,op),y=n.useRef(null),v=(0,Gi.A)(y,t),x=n.useRef(null),b=(0,Gi.A)(x,h),_=n.useRef(b);(0,$o.A)((()=>{_.current=b}),[b]),n.useImperativeHandle(h,(()=>x.current),[]);const w=function(e,t){if("ltr"===t)return e;switch(e){case"bottom-end":return"bottom-start";case"bottom-start":return"bottom-end";case"top-end":return"top-start";case"top-start":return"top-end";default:return e}}(u,a),[k,S]=n.useState(w),[A,T]=n.useState(sp(i));n.useEffect((()=>{x.current&&x.current.forceUpdate()})),n.useEffect((()=>{i&&T(sp(i))}),[i]),(0,$o.A)((()=>{if(!A||!c)return;let e=[{name:"preventOverflow",options:{altBoundary:s}},{name:"flip",options:{altBoundary:s}},{name:"onUpdate",enabled:!0,phase:"afterWrite",fn:e=>{let{state:t}=e;S(t.placement)}}];null!=l&&(e=e.concat(l)),d&&null!=d.modifiers&&(e=e.concat(d.modifiers));const t=np(A,y.current,(0,O.A)({placement:w},d,{modifiers:e}));return _.current(t),()=>{t.destroy(),_.current(null)}}),[A,s,l,c,d,w]);const M={placement:k};null!==m&&(M.TransitionProps=m);const C=(e=>{const{classes:t}=e;return(0,mn.A)({root:["root"]},ip,t)})(e),E=null!=(r=f.root)?r:"div",I=to({elementType:E,externalSlotProps:p.root,externalForwardedProps:g,additionalProps:{role:"tooltip",ref:v},ownerState:e,className:C.root});return(0,j.jsx)(E,(0,O.A)({},I,{children:"function"===typeof o?o(M):o}))})),dp=n.forwardRef((function(e,t){const{anchorEl:r,children:i,container:o,direction:a="ltr",disablePortal:s=!1,keepMounted:l=!1,modifiers:c,open:u,placement:d="bottom",popperOptions:h=cp,popperRef:p,style:f,transition:m=!1,slotProps:g={},slots:y={}}=e,v=(0,R.A)(e,ap),[x,b]=n.useState(!0);if(!l&&!u&&(!m||x))return null;let _;if(o)_=o;else if(r){const e=sp(r);_=e&&lp(e)?(0,No.A)(e).body:(0,No.A)(null).body}const w=u||!l||m&&!x?void 0:"none",k=m?{in:u,onEnter:()=>{b(!1)},onExited:()=>{b(!0)}}:void 0;return(0,j.jsx)(qo,{disablePortal:s,container:_,children:(0,j.jsx)(up,(0,O.A)({anchorEl:r,direction:a,disablePortal:s,modifiers:c,ref:t,open:m?!x:u,placement:d,popperOptions:h,popperRef:p,slotProps:g,slots:y},v,{style:(0,O.A)({position:"fixed",top:0,left:0,display:w},f),TransitionProps:k,children:i}))})})),hp=["anchorEl","component","components","componentsProps","container","disablePortal","keepMounted","modifiers","open","placement","popperOptions","popperRef","transition","slots","slotProps"],pp=(0,yn.Ay)(dp,{name:"MuiPopper",slot:"Root",overridesResolver:(e,t)=>t.root})({}),fp=n.forwardRef((function(e,t){var r;const n=(0,Gd.A)(),i=(0,vn.b)({props:e,name:"MuiPopper"}),{anchorEl:o,component:a,components:s,componentsProps:l,container:c,disablePortal:u,keepMounted:d,modifiers:h,open:p,placement:f,popperOptions:m,popperRef:g,transition:y,slots:v,slotProps:x}=i,b=(0,R.A)(i,hp),_=null!=(r=null==v?void 0:v.root)?r:null==s?void 0:s.Root,w=(0,O.A)({anchorEl:o,container:c,disablePortal:u,keepMounted:d,modifiers:h,open:p,placement:f,popperOptions:m,popperRef:g,transition:y},b);return(0,j.jsx)(pp,(0,O.A)({as:a,direction:null==n?void 0:n.direction,slots:{root:_},slotProps:null!=x?x:l},w,{ref:t}))}));var mp=r(45879),gp=r(54516);function yp(e){return(0,Yn.Ay)("MuiTooltip",e)}const vp=(0,Ln.A)("MuiTooltip",["popper","popperInteractive","popperArrow","popperClose","tooltip","tooltipArrow","touch","tooltipPlacementLeft","tooltipPlacementRight","tooltipPlacementTop","tooltipPlacementBottom","arrow"]),xp=["arrow","children","classes","components","componentsProps","describeChild","disableFocusListener","disableHoverListener","disableInteractive","disableTouchListener","enterDelay","enterNextDelay","enterTouchDelay","followCursor","id","leaveDelay","leaveTouchDelay","onClose","onOpen","open","placement","PopperComponent","PopperProps","slotProps","slots","title","TransitionComponent","TransitionProps"];const bp=(0,yn.Ay)(fp,{name:"MuiTooltip",slot:"Popper",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.popper,!r.disableInteractive&&t.popperInteractive,r.arrow&&t.popperArrow,!r.open&&t.popperClose]}})((e=>{let{theme:t,ownerState:r,open:n}=e;return(0,O.A)({zIndex:(t.vars||t).zIndex.tooltip,pointerEvents:"none"},!r.disableInteractive&&{pointerEvents:"auto"},!n&&{pointerEvents:"none"},r.arrow&&{[`&[data-popper-placement*="bottom"] .${vp.arrow}`]:{top:0,marginTop:"-0.71em","&::before":{transformOrigin:"0 100%"}},[`&[data-popper-placement*="top"] .${vp.arrow}`]:{bottom:0,marginBottom:"-0.71em","&::before":{transformOrigin:"100% 0"}},[`&[data-popper-placement*="right"] .${vp.arrow}`]:(0,O.A)({},r.isRtl?{right:0,marginRight:"-0.71em"}:{left:0,marginLeft:"-0.71em"},{height:"1em",width:"0.71em","&::before":{transformOrigin:"100% 100%"}}),[`&[data-popper-placement*="left"] .${vp.arrow}`]:(0,O.A)({},r.isRtl?{left:0,marginLeft:"-0.71em"}:{right:0,marginRight:"-0.71em"},{height:"1em",width:"0.71em","&::before":{transformOrigin:"0 0"}})})})),_p=(0,yn.Ay)("div",{name:"MuiTooltip",slot:"Tooltip",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.tooltip,r.touch&&t.touch,r.arrow&&t.tooltipArrow,t[`tooltipPlacement${(0,ei.A)(r.placement.split("-")[0])}`]]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({backgroundColor:t.vars?t.vars.palette.Tooltip.bg:(0,gn.X4)(t.palette.grey[700],.92),borderRadius:(t.vars||t).shape.borderRadius,color:(t.vars||t).palette.common.white,fontFamily:t.typography.fontFamily,padding:"4px 8px",fontSize:t.typography.pxToRem(11),maxWidth:300,margin:2,wordWrap:"break-word",fontWeight:t.typography.fontWeightMedium},r.arrow&&{position:"relative",margin:0},r.touch&&{padding:"8px 16px",fontSize:t.typography.pxToRem(14),lineHeight:(n=16/14,Math.round(1e5*n)/1e5)+"em",fontWeight:t.typography.fontWeightRegular},{[`.${vp.popper}[data-popper-placement*="left"] &`]:(0,O.A)({transformOrigin:"right center"},r.isRtl?(0,O.A)({marginLeft:"14px"},r.touch&&{marginLeft:"24px"}):(0,O.A)({marginRight:"14px"},r.touch&&{marginRight:"24px"})),[`.${vp.popper}[data-popper-placement*="right"] &`]:(0,O.A)({transformOrigin:"left center"},r.isRtl?(0,O.A)({marginRight:"14px"},r.touch&&{marginRight:"24px"}):(0,O.A)({marginLeft:"14px"},r.touch&&{marginLeft:"24px"})),[`.${vp.popper}[data-popper-placement*="top"] &`]:(0,O.A)({transformOrigin:"center bottom",marginBottom:"14px"},r.touch&&{marginBottom:"24px"}),[`.${vp.popper}[data-popper-placement*="bottom"] &`]:(0,O.A)({transformOrigin:"center top",marginTop:"14px"},r.touch&&{marginTop:"24px"})});var n})),wp=(0,yn.Ay)("span",{name:"MuiTooltip",slot:"Arrow",overridesResolver:(e,t)=>t.arrow})((e=>{let{theme:t}=e;return{overflow:"hidden",position:"absolute",width:"1em",height:"0.71em",boxSizing:"border-box",color:t.vars?t.vars.palette.Tooltip.bg:(0,gn.X4)(t.palette.grey[700],.9),"&::before":{content:'""',margin:"auto",display:"block",width:"100%",height:"100%",backgroundColor:"currentColor",transform:"rotate(45deg)"}}}));let kp=!1;const Sp=new On.E;let Ap={x:0,y:0};function Tp(e,t){return function(r){for(var n=arguments.length,i=new Array(n>1?n-1:0),o=1;o{void 0!==ve.current&&(document.body.style.WebkitUserSelect=ve.current,ve.current=void 0),pe.clear()}));n.useEffect((()=>xe),[xe]);const be=e=>{Sp.clear(),kp=!0,me(!0),$&&!ge&&$(e)},_e=(0,bn.A)((e=>{Sp.start(800+B,(()=>{kp=!1})),me(!1),U&&ge&&U(e),ue.start(re.transitions.duration.shortest,(()=>{le.current=!1}))})),we=e=>{le.current&&"touchstart"!==e.type||(ie&&ie.removeAttribute("title"),de.clear(),he.clear(),L||kp&&D?de.start(kp?D:L,(()=>{be(e)})):be(e))},ke=e=>{de.clear(),he.start(B,(()=>{_e(e)}))},{isFocusVisibleRef:Se,onBlur:Ae,onFocus:Te,ref:Me}=(0,_n.A)(),[,Ce]=n.useState(!1),Ee=e=>{Ae(e),!1===Se.current&&(Ce(!1),ke(e))},Ie=e=>{ie||oe(e.currentTarget),Te(e),!0===Se.current&&(Ce(!0),we(e))},Pe=e=>{le.current=!0;const t=te.props;t.onTouchStart&&t.onTouchStart(e)},Oe=e=>{Pe(e),he.clear(),ue.clear(),xe(),ve.current=document.body.style.WebkitUserSelect,document.body.style.WebkitUserSelect="none",pe.start(z,(()=>{document.body.style.WebkitUserSelect=ve.current,we(e)}))},Re=e=>{te.props.onTouchEnd&&te.props.onTouchEnd(e),xe(),he.start(V,(()=>{_e(e)}))};n.useEffect((()=>{if(ge)return document.addEventListener("keydown",e),()=>{document.removeEventListener("keydown",e)};function e(e){"Escape"!==e.key&&"Esc"!==e.key||_e(e)}}),[_e,ge]);const Le=(0,xn.A)(te.ref,Me,oe,t);K||0===K||(ge=!1);const De=n.useRef(),ze={},je="string"===typeof K;M?(ze.title=ge||!je||E?null:K,ze["aria-describedby"]=ge?ye:null):(ze["aria-label"]=je?K:null,ze["aria-labelledby"]=ge&&!je?ye:null);const Fe=(0,O.A)({},ze,ee,te.props,{className:(0,fn.A)(ee.className,te.props.className),onTouchStart:Pe,ref:Le},F?{onMouseMove:e=>{const t=te.props;t.onMouseMove&&t.onMouseMove(e),Ap={x:e.clientX,y:e.clientY},De.current&&De.current.update()}}:{});const Ne={};P||(Fe.onTouchStart=Oe,Fe.onTouchEnd=Re),E||(Fe.onMouseOver=Tp(we,Fe.onMouseOver),Fe.onMouseLeave=Tp(ke,Fe.onMouseLeave),ce||(Ne.onMouseOver=we,Ne.onMouseLeave=ke)),C||(Fe.onFocus=Tp(Ie,Fe.onFocus),Fe.onBlur=Tp(Ee,Fe.onBlur),ce||(Ne.onFocus=Ie,Ne.onBlur=Ee));const Be=n.useMemo((()=>{var e;let t=[{name:"arrow",enabled:Boolean(ae),options:{element:ae,padding:4}}];return null!=(e=Y.popperOptions)&&e.modifiers&&(t=t.concat(Y.popperOptions.modifiers)),(0,O.A)({},Y.popperOptions,{modifiers:t})}),[ae,Y]),Ve=(0,O.A)({},w,{isRtl:ne,arrow:k,disableInteractive:ce,placement:q,PopperComponentProp:G,touch:le.current}),Ue=(e=>{const{classes:t,disableInteractive:r,arrow:n,touch:i,placement:o}=e,a={popper:["popper",!r&&"popperInteractive",n&&"popperArrow"],tooltip:["tooltip",n&&"tooltipArrow",i&&"touch",`tooltipPlacement${(0,ei.A)(o.split("-")[0])}`],arrow:["arrow"]};return(0,mn.A)(a,yp,t)})(Ve),He=null!=(r=null!=(i=Z.popper)?i:A.Popper)?r:bp,$e=null!=(o=null!=(a=null!=(s=Z.transition)?s:A.Transition)?a:J)?o:Fo,We=null!=(l=null!=(c=Z.tooltip)?c:A.Tooltip)?l:_p,qe=null!=(u=null!=(d=Z.arrow)?d:A.Arrow)?u:wp,Ge=Xi(He,(0,O.A)({},Y,null!=(h=X.popper)?h:T.popper,{className:(0,fn.A)(Ue.popper,null==Y?void 0:Y.className,null==(p=null!=(f=X.popper)?f:T.popper)?void 0:p.className)}),Ve),Ye=Xi($e,(0,O.A)({},Q,null!=(m=X.transition)?m:T.transition),Ve),Xe=Xi(We,(0,O.A)({},null!=(g=X.tooltip)?g:T.tooltip,{className:(0,fn.A)(Ue.tooltip,null==(y=null!=(v=X.tooltip)?v:T.tooltip)?void 0:y.className)}),Ve),Ze=Xi(qe,(0,O.A)({},null!=(x=X.arrow)?x:T.arrow,{className:(0,fn.A)(Ue.arrow,null==(b=null!=(_=X.arrow)?_:T.arrow)?void 0:b.className)}),Ve);return(0,j.jsxs)(n.Fragment,{children:[n.cloneElement(te,Fe),(0,j.jsx)(He,(0,O.A)({as:null!=G?G:fp,placement:q,anchorEl:F?{getBoundingClientRect:()=>({top:Ap.y,left:Ap.x,right:Ap.x,bottom:Ap.y,width:0,height:0})}:ie,popperRef:De,open:!!ie&&ge,id:ye,transition:!0},Ne,Ge,{popperOptions:Be,children:e=>{let{TransitionProps:t}=e;return(0,j.jsx)($e,(0,O.A)({timeout:re.transitions.duration.shorter},t,Ye,{children:(0,j.jsxs)(We,(0,O.A)({},Xe,{children:[K,k?(0,j.jsx)(qe,(0,O.A)({},Ze,{ref:se})):null]}))}))}}))]})})),Cp=["className"],Ep=(0,yn.Ay)("div",{name:"MuiListItemIcon",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,"flex-start"===r.alignItems&&t.alignItemsFlexStart]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({minWidth:56,color:(t.vars||t).palette.action.active,flexShrink:0,display:"inline-flex"},"flex-start"===r.alignItems&&{marginTop:8})})),Ip=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiListItemIcon"}),{className:i}=r,o=(0,R.A)(r,Cp),a=n.useContext(no),s=(0,O.A)({},r,{alignItems:a.alignItems}),l=(e=>{const{alignItems:t,classes:r}=e,n={root:["root","flex-start"===t&&"alignItemsFlexStart"]};return(0,mn.A)(n,Fa,r)})(s);return(0,j.jsx)(Ep,(0,O.A)({className:(0,fn.A)(l.root,i),ownerState:s,ref:t},o))})),Pp=["children","className","disableTypography","inset","primary","primaryTypographyProps","secondary","secondaryTypographyProps"],Op=(0,yn.Ay)("div",{name:"MuiListItemText",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[{[`& .${Va.primary}`]:t.primary},{[`& .${Va.secondary}`]:t.secondary},t.root,r.inset&&t.inset,r.primary&&r.secondary&&t.multiline,r.dense&&t.dense]}})((e=>{let{ownerState:t}=e;return(0,O.A)({flex:"1 1 auto",minWidth:0,marginTop:4,marginBottom:4},t.primary&&t.secondary&&{marginTop:6,marginBottom:6},t.inset&&{paddingLeft:56})})),Rp=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiListItemText"}),{children:i,className:o,disableTypography:a=!1,inset:s=!1,primary:l,primaryTypographyProps:c,secondary:u,secondaryTypographyProps:d}=r,h=(0,R.A)(r,Pp),{dense:p}=n.useContext(no);let f=null!=l?l:i,m=u;const g=(0,O.A)({},r,{disableTypography:a,inset:s,primary:!!f,secondary:!!m,dense:p}),y=(e=>{const{classes:t,inset:r,primary:n,secondary:i,dense:o}=e,a={root:["root",r&&"inset",o&&"dense",n&&i&&"multiline"],primary:["primary"],secondary:["secondary"]};return(0,mn.A)(a,Ba,t)})(g);return null==f||f.type===Hi||a||(f=(0,j.jsx)(Hi,(0,O.A)({variant:p?"body2":"body1",className:y.primary,component:null!=c&&c.variant?void 0:"span",display:"block"},c,{children:f}))),null==m||m.type===Hi||a||(m=(0,j.jsx)(Hi,(0,O.A)({variant:"body2",className:y.secondary,color:"text.secondary",display:"block"},d,{children:m}))),(0,j.jsxs)(Op,(0,O.A)({className:(0,fn.A)(y.root,o),ownerState:g,ref:t},h,{children:[f,m]}))})),Lp=(0,Ud.A)((0,j.jsx)("path",{d:"M11 18h2v-2h-2zm1-16C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8m0-14c-2.21 0-4 1.79-4 4h2c0-1.1.9-2 2-2s2 .9 2 2c0 2-3 1.75-3 5h2c0-2.25 3-2.5 3-5 0-2.21-1.79-4-4-4"}),"HelpOutline");var Dp=r(9626),zp=r(5844);function jp(e){return(0,Yn.Ay)("MuiDialog",e)}const Fp=(0,Ln.A)("MuiDialog",["root","scrollPaper","scrollBody","container","paper","paperScrollPaper","paperScrollBody","paperWidthFalse","paperWidthXs","paperWidthSm","paperWidthMd","paperWidthLg","paperWidthXl","paperFullWidth","paperFullScreen"]);const Np=n.createContext({}),Bp=["aria-describedby","aria-labelledby","BackdropComponent","BackdropProps","children","className","disableEscapeKeyDown","fullScreen","fullWidth","maxWidth","onBackdropClick","onClick","onClose","open","PaperComponent","PaperProps","scroll","TransitionComponent","transitionDuration","TransitionProps"],Vp=(0,yn.Ay)(Qo,{name:"MuiDialog",slot:"Backdrop",overrides:(e,t)=>t.backdrop})({zIndex:-1}),Up=(0,yn.Ay)(fa,{name:"MuiDialog",slot:"Root",overridesResolver:(e,t)=>t.root})({"@media print":{position:"absolute !important"}}),Hp=(0,yn.Ay)("div",{name:"MuiDialog",slot:"Container",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.container,t[`scroll${(0,ei.A)(r.scroll)}`]]}})((e=>{let{ownerState:t}=e;return(0,O.A)({height:"100%","@media print":{height:"auto"},outline:0},"paper"===t.scroll&&{display:"flex",justifyContent:"center",alignItems:"center"},"body"===t.scroll&&{overflowY:"auto",overflowX:"hidden",textAlign:"center","&::after":{content:'""',display:"inline-block",verticalAlign:"middle",height:"100%",width:"0"}})})),$p=(0,yn.Ay)(Ci,{name:"MuiDialog",slot:"Paper",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.paper,t[`scrollPaper${(0,ei.A)(r.scroll)}`],t[`paperWidth${(0,ei.A)(String(r.maxWidth))}`],r.fullWidth&&t.paperFullWidth,r.fullScreen&&t.paperFullScreen]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({margin:32,position:"relative",overflowY:"auto","@media print":{overflowY:"visible",boxShadow:"none"}},"paper"===r.scroll&&{display:"flex",flexDirection:"column",maxHeight:"calc(100% - 64px)"},"body"===r.scroll&&{display:"inline-block",verticalAlign:"middle",textAlign:"left"},!r.maxWidth&&{maxWidth:"calc(100% - 64px)"},"xs"===r.maxWidth&&{maxWidth:"px"===t.breakpoints.unit?Math.max(t.breakpoints.values.xs,444):`max(${t.breakpoints.values.xs}${t.breakpoints.unit}, 444px)`,[`&.${Fp.paperScrollBody}`]:{[t.breakpoints.down(Math.max(t.breakpoints.values.xs,444)+64)]:{maxWidth:"calc(100% - 64px)"}}},r.maxWidth&&"xs"!==r.maxWidth&&{maxWidth:`${t.breakpoints.values[r.maxWidth]}${t.breakpoints.unit}`,[`&.${Fp.paperScrollBody}`]:{[t.breakpoints.down(t.breakpoints.values[r.maxWidth]+64)]:{maxWidth:"calc(100% - 64px)"}}},r.fullWidth&&{width:"calc(100% - 64px)"},r.fullScreen&&{margin:0,width:"100%",maxWidth:"100%",height:"100%",maxHeight:"none",borderRadius:0,[`&.${Fp.paperScrollBody}`]:{margin:0,maxWidth:"100%"}})})),Wp=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiDialog"}),i=Io(),o={enter:i.transitions.duration.enteringScreen,exit:i.transitions.duration.leavingScreen},{"aria-describedby":a,"aria-labelledby":s,BackdropComponent:l,BackdropProps:c,children:u,className:d,disableEscapeKeyDown:h=!1,fullScreen:p=!1,fullWidth:f=!1,maxWidth:m="sm",onBackdropClick:g,onClick:y,onClose:v,open:x,PaperComponent:b=Ci,PaperProps:_={},scroll:w="paper",TransitionComponent:k=Xo,transitionDuration:S=o,TransitionProps:A}=r,T=(0,R.A)(r,Bp),M=(0,O.A)({},r,{disableEscapeKeyDown:h,fullScreen:p,fullWidth:f,maxWidth:m,scroll:w}),C=(e=>{const{classes:t,scroll:r,maxWidth:n,fullWidth:i,fullScreen:o}=e,a={root:["root"],container:["container",`scroll${(0,ei.A)(r)}`],paper:["paper",`paperScroll${(0,ei.A)(r)}`,`paperWidth${(0,ei.A)(String(n))}`,i&&"paperFullWidth",o&&"paperFullScreen"]};return(0,mn.A)(a,jp,t)})(M),E=n.useRef(),I=(0,zp.A)(s),P=n.useMemo((()=>({titleId:I})),[I]);return(0,j.jsx)(Up,(0,O.A)({className:(0,fn.A)(C.root,d),closeAfterTransition:!0,components:{Backdrop:Vp},componentsProps:{backdrop:(0,O.A)({transitionDuration:S,as:l},c)},disableEscapeKeyDown:h,onClose:v,open:x,ref:t,onClick:e=>{y&&y(e),E.current&&(E.current=null,g&&g(e),v&&v(e,"backdropClick"))},ownerState:M},T,{children:(0,j.jsx)(k,(0,O.A)({appear:!0,in:x,timeout:S,role:"presentation"},A,{children:(0,j.jsx)(Hp,{className:(0,fn.A)(C.container),onMouseDown:e=>{E.current=e.target===e.currentTarget},ownerState:M,children:(0,j.jsx)($p,(0,O.A)({as:b,elevation:24,role:"dialog","aria-describedby":a,"aria-labelledby":I},_,{className:(0,fn.A)(C.paper,_.className),ownerState:M,children:(0,j.jsx)(Np.Provider,{value:P,children:u})}))})}))}))}));function qp(e){return(0,Yn.Ay)("MuiDialogTitle",e)}const Gp=(0,Ln.A)("MuiDialogTitle",["root"]),Yp=["className","id"],Xp=(0,yn.Ay)(Hi,{name:"MuiDialogTitle",slot:"Root",overridesResolver:(e,t)=>t.root})({padding:"16px 24px",flex:"0 0 auto"}),Zp=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiDialogTitle"}),{className:i,id:o}=r,a=(0,R.A)(r,Yp),s=r,l=(e=>{const{classes:t}=e;return(0,mn.A)({root:["root"]},qp,t)})(s),{titleId:c=o}=n.useContext(Np);return(0,j.jsx)(Xp,(0,O.A)({component:"h2",className:(0,fn.A)(l.root,i),ownerState:s,ref:t,variant:"h6",id:null!=o?o:c},a))}));function Kp(e){return(0,Yn.Ay)("MuiDialogContent",e)}(0,Ln.A)("MuiDialogContent",["root","dividers"]);const Jp=["className","dividers"],Qp=(0,yn.Ay)("div",{name:"MuiDialogContent",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.dividers&&t.dividers]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({flex:"1 1 auto",WebkitOverflowScrolling:"touch",overflowY:"auto",padding:"20px 24px"},r.dividers?{padding:"16px 24px",borderTop:`1px solid ${(t.vars||t).palette.divider}`,borderBottom:`1px solid ${(t.vars||t).palette.divider}`}:{[`.${Gp.root} + &`]:{paddingTop:0}})})),ef=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiDialogContent"}),{className:n,dividers:i=!1}=r,o=(0,R.A)(r,Jp),a=(0,O.A)({},r,{dividers:i}),s=(e=>{const{classes:t,dividers:r}=e,n={root:["root",r&&"dividers"]};return(0,mn.A)(n,Kp,t)})(a);return(0,j.jsx)(Qp,(0,O.A)({className:(0,fn.A)(s.root,n),ownerState:a,ref:t},o))}));function tf(e){return(0,Yn.Ay)("MuiDialogActions",e)}(0,Ln.A)("MuiDialogActions",["root","spacing"]);const rf=["className","disableSpacing"],nf=(0,yn.Ay)("div",{name:"MuiDialogActions",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,!r.disableSpacing&&t.spacing]}})((e=>{let{ownerState:t}=e;return(0,O.A)({display:"flex",alignItems:"center",padding:8,justifyContent:"flex-end",flex:"0 0 auto"},!t.disableSpacing&&{"& > :not(style) ~ :not(style)":{marginLeft:8}})})),of=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiDialogActions"}),{className:n,disableSpacing:i=!1}=r,o=(0,R.A)(r,rf),a=(0,O.A)({},r,{disableSpacing:i}),s=(e=>{const{classes:t,disableSpacing:r}=e,n={root:["root",!r&&"spacing"]};return(0,mn.A)(n,tf,t)})(a);return(0,j.jsx)(nf,(0,O.A)({className:(0,fn.A)(s.root,n),ownerState:a,ref:t},o))}));var af=r(13030);function sf(e){return(0,Yn.Ay)("MuiButton",e)}const lf=(0,Ln.A)("MuiButton",["root","text","textInherit","textPrimary","textSecondary","textSuccess","textError","textInfo","textWarning","outlined","outlinedInherit","outlinedPrimary","outlinedSecondary","outlinedSuccess","outlinedError","outlinedInfo","outlinedWarning","contained","containedInherit","containedPrimary","containedSecondary","containedSuccess","containedError","containedInfo","containedWarning","disableElevation","focusVisible","disabled","colorInherit","colorPrimary","colorSecondary","colorSuccess","colorError","colorInfo","colorWarning","textSizeSmall","textSizeMedium","textSizeLarge","outlinedSizeSmall","outlinedSizeMedium","outlinedSizeLarge","containedSizeSmall","containedSizeMedium","containedSizeLarge","sizeMedium","sizeSmall","sizeLarge","fullWidth","startIcon","endIcon","icon","iconSizeSmall","iconSizeMedium","iconSizeLarge"]);const cf=n.createContext({});const uf=n.createContext(void 0),df=["children","color","component","className","disabled","disableElevation","disableFocusRipple","endIcon","focusVisibleClassName","fullWidth","size","startIcon","type","variant"],hf=e=>(0,O.A)({},"small"===e.size&&{"& > *:nth-of-type(1)":{fontSize:18}},"medium"===e.size&&{"& > *:nth-of-type(1)":{fontSize:20}},"large"===e.size&&{"& > *:nth-of-type(1)":{fontSize:22}}),pf=(0,yn.Ay)(Qn,{shouldForwardProp:e=>(0,Ta.A)(e)||"classes"===e,name:"MuiButton",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,t[r.variant],t[`${r.variant}${(0,ei.A)(r.color)}`],t[`size${(0,ei.A)(r.size)}`],t[`${r.variant}Size${(0,ei.A)(r.size)}`],"inherit"===r.color&&t.colorInherit,r.disableElevation&&t.disableElevation,r.fullWidth&&t.fullWidth]}})((e=>{let{theme:t,ownerState:r}=e;var n,i;const o="light"===t.palette.mode?t.palette.grey[300]:t.palette.grey[800],a="light"===t.palette.mode?t.palette.grey.A100:t.palette.grey[700];return(0,O.A)({},t.typography.button,{minWidth:64,padding:"6px 16px",borderRadius:(t.vars||t).shape.borderRadius,transition:t.transitions.create(["background-color","box-shadow","border-color","color"],{duration:t.transitions.duration.short}),"&:hover":(0,O.A)({textDecoration:"none",backgroundColor:t.vars?`rgba(${t.vars.palette.text.primaryChannel} / ${t.vars.palette.action.hoverOpacity})`:(0,gn.X4)(t.palette.text.primary,t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}},"text"===r.variant&&"inherit"!==r.color&&{backgroundColor:t.vars?`rgba(${t.vars.palette[r.color].mainChannel} / ${t.vars.palette.action.hoverOpacity})`:(0,gn.X4)(t.palette[r.color].main,t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}},"outlined"===r.variant&&"inherit"!==r.color&&{border:`1px solid ${(t.vars||t).palette[r.color].main}`,backgroundColor:t.vars?`rgba(${t.vars.palette[r.color].mainChannel} / ${t.vars.palette.action.hoverOpacity})`:(0,gn.X4)(t.palette[r.color].main,t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}},"contained"===r.variant&&{backgroundColor:t.vars?t.vars.palette.Button.inheritContainedHoverBg:a,boxShadow:(t.vars||t).shadows[4],"@media (hover: none)":{boxShadow:(t.vars||t).shadows[2],backgroundColor:(t.vars||t).palette.grey[300]}},"contained"===r.variant&&"inherit"!==r.color&&{backgroundColor:(t.vars||t).palette[r.color].dark,"@media (hover: none)":{backgroundColor:(t.vars||t).palette[r.color].main}}),"&:active":(0,O.A)({},"contained"===r.variant&&{boxShadow:(t.vars||t).shadows[8]}),[`&.${lf.focusVisible}`]:(0,O.A)({},"contained"===r.variant&&{boxShadow:(t.vars||t).shadows[6]}),[`&.${lf.disabled}`]:(0,O.A)({color:(t.vars||t).palette.action.disabled},"outlined"===r.variant&&{border:`1px solid ${(t.vars||t).palette.action.disabledBackground}`},"contained"===r.variant&&{color:(t.vars||t).palette.action.disabled,boxShadow:(t.vars||t).shadows[0],backgroundColor:(t.vars||t).palette.action.disabledBackground})},"text"===r.variant&&{padding:"6px 8px"},"text"===r.variant&&"inherit"!==r.color&&{color:(t.vars||t).palette[r.color].main},"outlined"===r.variant&&{padding:"5px 15px",border:"1px solid currentColor"},"outlined"===r.variant&&"inherit"!==r.color&&{color:(t.vars||t).palette[r.color].main,border:t.vars?`1px solid rgba(${t.vars.palette[r.color].mainChannel} / 0.5)`:`1px solid ${(0,gn.X4)(t.palette[r.color].main,.5)}`},"contained"===r.variant&&{color:t.vars?t.vars.palette.text.primary:null==(n=(i=t.palette).getContrastText)?void 0:n.call(i,t.palette.grey[300]),backgroundColor:t.vars?t.vars.palette.Button.inheritContainedBg:o,boxShadow:(t.vars||t).shadows[2]},"contained"===r.variant&&"inherit"!==r.color&&{color:(t.vars||t).palette[r.color].contrastText,backgroundColor:(t.vars||t).palette[r.color].main},"inherit"===r.color&&{color:"inherit",borderColor:"currentColor"},"small"===r.size&&"text"===r.variant&&{padding:"4px 5px",fontSize:t.typography.pxToRem(13)},"large"===r.size&&"text"===r.variant&&{padding:"8px 11px",fontSize:t.typography.pxToRem(15)},"small"===r.size&&"outlined"===r.variant&&{padding:"3px 9px",fontSize:t.typography.pxToRem(13)},"large"===r.size&&"outlined"===r.variant&&{padding:"7px 21px",fontSize:t.typography.pxToRem(15)},"small"===r.size&&"contained"===r.variant&&{padding:"4px 10px",fontSize:t.typography.pxToRem(13)},"large"===r.size&&"contained"===r.variant&&{padding:"8px 22px",fontSize:t.typography.pxToRem(15)},r.fullWidth&&{width:"100%"})}),(e=>{let{ownerState:t}=e;return t.disableElevation&&{boxShadow:"none","&:hover":{boxShadow:"none"},[`&.${lf.focusVisible}`]:{boxShadow:"none"},"&:active":{boxShadow:"none"},[`&.${lf.disabled}`]:{boxShadow:"none"}}})),ff=(0,yn.Ay)("span",{name:"MuiButton",slot:"StartIcon",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.startIcon,t[`iconSize${(0,ei.A)(r.size)}`]]}})((e=>{let{ownerState:t}=e;return(0,O.A)({display:"inherit",marginRight:8,marginLeft:-4},"small"===t.size&&{marginLeft:-2},hf(t))})),mf=(0,yn.Ay)("span",{name:"MuiButton",slot:"EndIcon",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.endIcon,t[`iconSize${(0,ei.A)(r.size)}`]]}})((e=>{let{ownerState:t}=e;return(0,O.A)({display:"inherit",marginRight:-4,marginLeft:8},"small"===t.size&&{marginRight:-2},hf(t))})),gf=n.forwardRef((function(e,t){const r=n.useContext(cf),i=n.useContext(uf),o=(0,af.A)(r,e),a=(0,vn.b)({props:o,name:"MuiButton"}),{children:s,color:l="primary",component:c="button",className:u,disabled:d=!1,disableElevation:h=!1,disableFocusRipple:p=!1,endIcon:f,focusVisibleClassName:m,fullWidth:g=!1,size:y="medium",startIcon:v,type:x,variant:b="text"}=a,_=(0,R.A)(a,df),w=(0,O.A)({},a,{color:l,component:c,disabled:d,disableElevation:h,disableFocusRipple:p,fullWidth:g,size:y,type:x,variant:b}),k=(e=>{const{color:t,disableElevation:r,fullWidth:n,size:i,variant:o,classes:a}=e,s={root:["root",o,`${o}${(0,ei.A)(t)}`,`size${(0,ei.A)(i)}`,`${o}Size${(0,ei.A)(i)}`,`color${(0,ei.A)(t)}`,r&&"disableElevation",n&&"fullWidth"],label:["label"],startIcon:["icon","startIcon",`iconSize${(0,ei.A)(i)}`],endIcon:["icon","endIcon",`iconSize${(0,ei.A)(i)}`]},l=(0,mn.A)(s,sf,a);return(0,O.A)({},a,l)})(w),S=v&&(0,j.jsx)(ff,{className:k.startIcon,ownerState:w,children:v}),A=f&&(0,j.jsx)(mf,{className:k.endIcon,ownerState:w,children:f}),T=i||"";return(0,j.jsxs)(pf,(0,O.A)({ownerState:w,className:(0,fn.A)(r.className,k.root,u,T),component:c,disabled:d,focusRipple:!p,focusVisibleClassName:(0,fn.A)(k.focusVisible,m),ref:t,type:x},_,{classes:k,children:[S,s,A]}))}));var yf=r(89751);const vf=n.createContext();function xf(e){return(0,Yn.Ay)("MuiGrid",e)}const bf=["auto",!0,1,2,3,4,5,6,7,8,9,10,11,12],_f=(0,Ln.A)("MuiGrid",["root","container","item","zeroMinWidth",...[0,1,2,3,4,5,6,7,8,9,10].map((e=>`spacing-xs-${e}`)),...["column-reverse","column","row-reverse","row"].map((e=>`direction-xs-${e}`)),...["nowrap","wrap-reverse","wrap"].map((e=>`wrap-xs-${e}`)),...bf.map((e=>`grid-xs-${e}`)),...bf.map((e=>`grid-sm-${e}`)),...bf.map((e=>`grid-md-${e}`)),...bf.map((e=>`grid-lg-${e}`)),...bf.map((e=>`grid-xl-${e}`))]),wf=["className","columns","columnSpacing","component","container","direction","item","rowSpacing","spacing","wrap","zeroMinWidth"];function kf(e){const t=parseFloat(e);return`${t}${String(e).replace(String(t),"")||"px"}`}function Sf(e){let{breakpoints:t,values:r}=e,n="";Object.keys(r).forEach((e=>{""===n&&0!==r[e]&&(n=e)}));const i=Object.keys(t).sort(((e,r)=>t[e]-t[r]));return i.slice(0,i.indexOf(n))}const Af=(0,yn.Ay)("div",{name:"MuiGrid",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e,{container:n,direction:i,item:o,spacing:a,wrap:s,zeroMinWidth:l,breakpoints:c}=r;let u=[];n&&(u=function(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(!e||e<=0)return[];if("string"===typeof e&&!Number.isNaN(Number(e))||"number"===typeof e)return[r[`spacing-xs-${String(e)}`]];const n=[];return t.forEach((t=>{const i=e[t];Number(i)>0&&n.push(r[`spacing-${t}-${String(i)}`])})),n}(a,c,t));const d=[];return c.forEach((e=>{const n=r[e];n&&d.push(t[`grid-${e}-${String(n)}`])})),[t.root,n&&t.container,o&&t.item,l&&t.zeroMinWidth,...u,"row"!==i&&t[`direction-xs-${String(i)}`],"wrap"!==s&&t[`wrap-xs-${String(s)}`],...d]}})((e=>{let{ownerState:t}=e;return(0,O.A)({boxSizing:"border-box"},t.container&&{display:"flex",flexWrap:"wrap",width:"100%"},t.item&&{margin:0},t.zeroMinWidth&&{minWidth:0},"wrap"!==t.wrap&&{flexWrap:t.wrap})}),(function(e){let{theme:t,ownerState:r}=e;const n=(0,yf.kW)({values:r.direction,breakpoints:t.breakpoints.values});return(0,yf.NI)({theme:t},n,(e=>{const t={flexDirection:e};return 0===e.indexOf("column")&&(t[`& > .${_f.item}`]={maxWidth:"none"}),t}))}),(function(e){let{theme:t,ownerState:r}=e;const{container:n,rowSpacing:i}=r;let o={};if(n&&0!==i){const e=(0,yf.kW)({values:i,breakpoints:t.breakpoints.values});let r;"object"===typeof e&&(r=Sf({breakpoints:t.breakpoints.values,values:e})),o=(0,yf.NI)({theme:t},e,((e,n)=>{var i;const o=t.spacing(e);return"0px"!==o?{marginTop:`-${kf(o)}`,[`& > .${_f.item}`]:{paddingTop:kf(o)}}:null!=(i=r)&&i.includes(n)?{}:{marginTop:0,[`& > .${_f.item}`]:{paddingTop:0}}}))}return o}),(function(e){let{theme:t,ownerState:r}=e;const{container:n,columnSpacing:i}=r;let o={};if(n&&0!==i){const e=(0,yf.kW)({values:i,breakpoints:t.breakpoints.values});let r;"object"===typeof e&&(r=Sf({breakpoints:t.breakpoints.values,values:e})),o=(0,yf.NI)({theme:t},e,((e,n)=>{var i;const o=t.spacing(e);return"0px"!==o?{width:`calc(100% + ${kf(o)})`,marginLeft:`-${kf(o)}`,[`& > .${_f.item}`]:{paddingLeft:kf(o)}}:null!=(i=r)&&i.includes(n)?{}:{width:"100%",marginLeft:0,[`& > .${_f.item}`]:{paddingLeft:0}}}))}return o}),(function(e){let t,{theme:r,ownerState:n}=e;return r.breakpoints.keys.reduce(((e,i)=>{let o={};if(n[i]&&(t=n[i]),!t)return e;if(!0===t)o={flexBasis:0,flexGrow:1,maxWidth:"100%"};else if("auto"===t)o={flexBasis:"auto",flexGrow:0,flexShrink:0,maxWidth:"none",width:"auto"};else{const a=(0,yf.kW)({values:n.columns,breakpoints:r.breakpoints.values}),s="object"===typeof a?a[i]:a;if(void 0===s||null===s)return e;const l=Math.round(t/s*1e8)/1e6+"%";let c={};if(n.container&&n.item&&0!==n.columnSpacing){const e=r.spacing(n.columnSpacing);if("0px"!==e){const t=`calc(${l} + ${kf(e)})`;c={flexBasis:t,maxWidth:t}}}o=(0,O.A)({flexBasis:l,flexGrow:0,maxWidth:l},c)}return 0===r.breakpoints.values[i]?Object.assign(e,o):e[r.breakpoints.up(i)]=o,e}),{})}));const Tf=e=>{const{classes:t,container:r,direction:n,item:i,spacing:o,wrap:a,zeroMinWidth:s,breakpoints:l}=e;let c=[];r&&(c=function(e,t){if(!e||e<=0)return[];if("string"===typeof e&&!Number.isNaN(Number(e))||"number"===typeof e)return[`spacing-xs-${String(e)}`];const r=[];return t.forEach((t=>{const n=e[t];if(Number(n)>0){const e=`spacing-${t}-${String(n)}`;r.push(e)}})),r}(o,l));const u=[];l.forEach((t=>{const r=e[t];r&&u.push(`grid-${t}-${String(r)}`)}));const d={root:["root",r&&"container",i&&"item",s&&"zeroMinWidth",...c,"row"!==n&&`direction-xs-${String(n)}`,"wrap"!==a&&`wrap-xs-${String(a)}`,...u]};return(0,mn.A)(d,xf,t)};const Mf=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiGrid"}),{breakpoints:i}=Io(),o=(0,li.A)(r),{className:a,columns:s,columnSpacing:l,component:c="div",container:u=!1,direction:d="row",item:h=!1,rowSpacing:p,spacing:f=0,wrap:m="wrap",zeroMinWidth:g=!1}=o,y=(0,R.A)(o,wf),v=p||f,x=l||f,b=n.useContext(vf),_=u?s||12:b,w={},k=(0,O.A)({},y);i.keys.forEach((e=>{null!=y[e]&&(w[e]=y[e],delete k[e])}));const S=(0,O.A)({},o,{columns:_,container:u,direction:d,item:h,rowSpacing:v,columnSpacing:x,wrap:m,zeroMinWidth:g,spacing:f},w,{breakpoints:i.keys}),A=Tf(S);return(0,j.jsx)(vf.Provider,{value:_,children:(0,j.jsx)(Af,(0,O.A)({ownerState:S,className:(0,fn.A)(A.root,a),as:c,ref:t},k))})})),Cf=e=>{let{open:t,setOpen:r,onCancel:n,onConfirm:i,title:o,content:a,confirmLabel:s,iconType:l}=e;const c=s?`${s}-confirm-button`:"ok-button",u=()=>{n&&n(),r&&r(!1)};return(0,j.jsxs)(Wp,{open:t,onClose:u,sx:{"& .MuiDialog-container":{"& .MuiPaper-root":{minWidth:"300px",wordWrap:"break-word"}}},children:[o&&(0,j.jsx)(Zp,{children:o}),(0,j.jsx)(ef,{children:l?(0,j.jsx)(Ef,{content:a,iconType:l}):a}),(0,j.jsxs)(of,{children:[(0,j.jsx)(gf,{variant:"outlined",onClick:u,children:"cancel"}),(0,j.jsx)(gf,{variant:"contained",onClick:()=>{i&&i(),r&&r(!1)},"data-testid":c,children:null!==s&&void 0!==s?s:"ok"})]})]})},Ef=e=>{let{content:t,iconType:r}=e;return(0,j.jsxs)(Mf,{container:!0,alignItems:"center",children:[(0,j.jsx)(Mf,{item:!0,xs:2,container:!0,justifyContent:"center",children:"warning"===r?(0,j.jsx)(Dp.A,{color:"warning",fontSize:"large"}):(0,j.jsx)(Lp,{color:"info",fontSize:"large"})}),(0,j.jsx)(Mf,{item:!0,xs:10,children:t})]})};const If="experiments",Pf=e=>e.mode.mode,Of=e=>e.mode.loading,Rf=e=>e.workspace.listUserShare,Lf=e=>e.workspace.workspace,Df=e=>e.workspace.currentWorkspace.selectedTab,zf=e=>e.workspace.currentWorkspace.roiFilePath,jf=e=>e.workspace.currentWorkspace.workspaceId,Ff=e=>e.workspace.currentWorkspace.statusRoi,Nf=e=>e.workspace.currentWorkspace.workspaceName,Bf=e=>e.workspace.loading,Vf=e=>{var t;return!!Pf(e)||e.workspace.currentWorkspace.ownerId===(null===(t=e.user.currentUser)||void 0===t?void 0:t.id)},Uf=jl(`${If}/getExperiments`,(async(e,t)=>{const r=jf(t.getState());if(!r)return t.rejectWithValue("workspace id does not exist.");try{const e=await async function(e){return(await wd.get(`${bd}/experiments/${e}`)).data}(r);return e}catch(ene){return t.rejectWithValue(ene)}})),Hf=jl(`${If}/deleteExperimentByUid`,(async(e,t)=>{const r=jf(t.getState());if(!r)return t.rejectWithValue("workspace id does not exist.");try{const t=await async function(e,t){return(await wd.delete(`${bd}/experiments/${e}/${t}`)).data}(r,e);return t}catch(ene){return t.rejectWithValue(ene)}})),$f=jl(`${If}/deleteExperimentByList`,(async(e,t)=>{const r=jf(t.getState());if(!r)return t.rejectWithValue("workspace id does not exist.");try{const t=await async function(e,t){return(await wd.post(`${bd}/experiments/delete/${e}`,{uidList:t})).data}(r,e);return t}catch(ene){return t.rejectWithValue(ene)}})),Wf="displayData",qf="timeSeries",Gf="heatMap",Yf="image",Xf="csv",Zf="roi",Kf="scatter",Jf="bar",Qf="hdf5",em="html",tm="fluo",rm="behavior",nm="histogram",im="line",om="pie",am="polar",sm="matlab";function lm(e){if("string"===typeof e||"number"===typeof e)return""+e;let t="";if(Array.isArray(e))for(let r,n=0;n{let t;const r=new Set,n=(e,n)=>{const i="function"===typeof e?e(t):e;if(!Object.is(i,t)){const e=t;t=(null!=n?n:"object"!==typeof i||null===i)?i:Object.assign({},t,i),r.forEach((r=>r(t,e)))}},i=()=>t,o={setState:n,getState:i,getInitialState:()=>a,subscribe:e=>(r.add(e),()=>r.delete(e)),destroy:()=>{console.warn("[DEPRECATED] The `destroy` method will be unsupported in a future version. Instead use unsubscribe function returned by subscribe. Everything will be garbage-collected if store is garbage-collected."),r.clear()}},a=t=e(n,i,o);return o},um=e=>e?cm(e):cm;const{useDebugValue:dm}=n,{useSyncExternalStoreWithSelector:hm}=a,pm=e=>e;function fm(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:pm,r=arguments.length>2?arguments[2]:void 0;const n=hm(e.subscribe,e.getState,e.getServerState||e.getInitialState,t,r);return dm(n),n}const mm=(e,t)=>{const r=um(e),n=function(e){return fm(r,e,arguments.length>1&&void 0!==arguments[1]?arguments[1]:t)};return Object.assign(n,r),n};function gm(e,t){if(Object.is(e,t))return!0;if("object"!==typeof e||null===e||"object"!==typeof t||null===t)return!1;if(e instanceof Map&&t instanceof Map){if(e.size!==t.size)return!1;for(const[r,n]of e)if(!Object.is(n,t.get(r)))return!1;return!0}if(e instanceof Set&&t instanceof Set){if(e.size!==t.size)return!1;for(const r of e)if(!t.has(r))return!1;return!0}const r=Object.keys(e);if(r.length!==Object.keys(t).length)return!1;for(const n of r)if(!Object.prototype.hasOwnProperty.call(t,n)||!Object.is(e[n],t[n]))return!1;return!0}var ym={value:()=>{}};function vm(){for(var e,t=0,r=arguments.length,n={};t=0&&(t=e.slice(r+1),e=e.slice(0,r)),e&&!n.hasOwnProperty(e))throw new Error("unknown type: "+e);return{type:e,name:t}}))),a=-1,s=o.length;if(!(arguments.length<2)){if(null!=t&&"function"!==typeof t)throw new Error("invalid callback: "+t);for(;++a0)for(var r,n,i=new Array(r),o=0;ot?1:e>=t?0:NaN}Dm.prototype={constructor:Dm,appendChild:function(e){return this._parent.insertBefore(e,this._next)},insertBefore:function(e,t){return this._parent.insertBefore(e,t)},querySelector:function(e){return this._parent.querySelector(e)},querySelectorAll:function(e){return this._parent.querySelectorAll(e)}};var Vm="http://www.w3.org/1999/xhtml";const Um={svg:"http://www.w3.org/2000/svg",xhtml:Vm,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"};function Hm(e){var t=e+="",r=t.indexOf(":");return r>=0&&"xmlns"!==(t=e.slice(0,r))&&(e=e.slice(r+1)),Um.hasOwnProperty(t)?{space:Um[t],local:e}:e}function $m(e){return function(){this.removeAttribute(e)}}function Wm(e){return function(){this.removeAttributeNS(e.space,e.local)}}function qm(e,t){return function(){this.setAttribute(e,t)}}function Gm(e,t){return function(){this.setAttributeNS(e.space,e.local,t)}}function Ym(e,t){return function(){var r=t.apply(this,arguments);null==r?this.removeAttribute(e):this.setAttribute(e,r)}}function Xm(e,t){return function(){var r=t.apply(this,arguments);null==r?this.removeAttributeNS(e.space,e.local):this.setAttributeNS(e.space,e.local,r)}}function Zm(e){return e.ownerDocument&&e.ownerDocument.defaultView||e.document&&e||e.defaultView}function Km(e){return function(){this.style.removeProperty(e)}}function Jm(e,t,r){return function(){this.style.setProperty(e,t,r)}}function Qm(e,t,r){return function(){var n=t.apply(this,arguments);null==n?this.style.removeProperty(e):this.style.setProperty(e,n,r)}}function eg(e,t){return e.style.getPropertyValue(t)||Zm(e).getComputedStyle(e,null).getPropertyValue(t)}function tg(e){return function(){delete this[e]}}function rg(e,t){return function(){this[e]=t}}function ng(e,t){return function(){var r=t.apply(this,arguments);null==r?delete this[e]:this[e]=r}}function ig(e){return e.trim().split(/^|\s+/)}function og(e){return e.classList||new ag(e)}function ag(e){this._node=e,this._names=ig(e.getAttribute("class")||"")}function sg(e,t){for(var r=og(e),n=-1,i=t.length;++n=0&&(this._names.splice(t,1),this._node.setAttribute("class",this._names.join(" ")))},contains:function(e){return this._names.indexOf(e)>=0}};var Og=[null];function Rg(e,t){this._groups=e,this._parents=t}function Lg(){return new Rg([[document.documentElement]],Og)}Rg.prototype=Lg.prototype={constructor:Rg,select:function(e){"function"!==typeof e&&(e=Sm(e));for(var t=this._groups,r=t.length,n=new Array(r),i=0;i=_&&(_=b+1);!(x=y[_])&&++_=0;)(n=i[o])&&(a&&4^n.compareDocumentPosition(a)&&a.parentNode.insertBefore(n,a),a=n);return this},sort:function(e){function t(t,r){return t&&r?e(t.__data__,r.__data__):!t-!r}e||(e=Bm);for(var r=this._groups,n=r.length,i=new Array(n),o=0;o1?this.each((null==t?Km:"function"===typeof t?Qm:Jm)(e,t,null==r?"":r)):eg(this.node(),e)},property:function(e,t){return arguments.length>1?this.each((null==t?tg:"function"===typeof t?ng:rg)(e,t)):this.node()[e]},classed:function(e,t){var r=ig(e+"");if(arguments.length<2){for(var n=og(this.node()),i=-1,o=r.length;++i=0&&(t=e.slice(r+1),e=e.slice(0,r)),{type:e,name:t}}))}(e+""),a=o.length;if(!(arguments.length<2)){for(s=t?Cg:Mg,n=0;n=0&&t._call.call(void 0,e),t=t._next;--Yg}()}finally{Yg=0,function(){var e,t,r=qg,n=1/0;for(;r;)r._call?(n>r._time&&(n=r._time),e=r,r=r._next):(t=r._next,r._next=null,r=e?e._next=t:qg=t);Gg=e,ly(n)}(),Jg=0}}function sy(){var e=ey.now(),t=e-Kg;t>1e3&&(Qg-=t,Kg=e)}function ly(e){Yg||(Xg&&(Xg=clearTimeout(Xg)),e-Jg>24?(e<1/0&&(Xg=setTimeout(ay,e-ey.now()-Qg)),Zg&&(Zg=clearInterval(Zg))):(Zg||(Kg=ey.now(),Zg=setInterval(sy,1e3)),Yg=1,ty(ay)))}function cy(e,t,r){var n=new iy;return t=null==t?0:+t,n.restart((r=>{n.stop(),e(r+t)}),t,r),n}iy.prototype=oy.prototype={constructor:iy,restart:function(e,t,r){if("function"!==typeof e)throw new TypeError("callback is not a function");r=(null==r?ry():+r)+(null==t?0:+t),this._next||Gg===this||(Gg?Gg._next=this:qg=this,Gg=this),this._call=e,this._time=r,ly()},stop:function(){this._call&&(this._call=null,this._time=1/0,ly())}};var uy=wm("start","end","cancel","interrupt"),dy=[];function hy(e,t,r,n,i,o){var a=e.__transition;if(a){if(r in a)return}else e.__transition={};!function(e,t,r){var n,i=e.__transition;function o(e){r.state=1,r.timer.restart(a,r.delay,r.time),r.delay<=e&&a(e-r.delay)}function a(o){var c,u,d,h;if(1!==r.state)return l();for(c in i)if((h=i[c]).name===r.name){if(3===h.state)return cy(a);4===h.state?(h.state=6,h.timer.stop(),h.on.call("interrupt",e,e.__data__,h.index,h.group),delete i[c]):+c0)throw new Error("too late; already scheduled");return r}function fy(e,t){var r=my(e,t);if(r.state>3)throw new Error("too late; already running");return r}function my(e,t){var r=e.__transition;if(!r||!(r=r[t]))throw new Error("transition not found");return r}function gy(e,t){var r,n,i,o=e.__transition,a=!0;if(o){for(i in t=null==t?null:t+"",o)(r=o[i]).name===t?(n=r.state>2&&r.state<5,r.state=6,r.timer.stop(),r.on.call(n?"interrupt":"cancel",e,e.__data__,r.index,r.group),delete o[i]):a=!1;a&&delete e.__transition}}var yy,vy=r(50010),xy=180/Math.PI,by={translateX:0,translateY:0,rotate:0,skewX:0,scaleX:1,scaleY:1};function _y(e,t,r,n,i,o){var a,s,l;return(a=Math.sqrt(e*e+t*t))&&(e/=a,t/=a),(l=e*r+t*n)&&(r-=e*l,n-=t*l),(s=Math.sqrt(r*r+n*n))&&(r/=s,n/=s,l/=s),e*n180?t+=360:t-e>180&&(e+=360),o.push({i:r.push(i(r)+"rotate(",null,n)-2,x:(0,vy.A)(e,t)})):t&&r.push(i(r)+"rotate("+t+n)}(o.rotate,a.rotate,s,l),function(e,t,r,o){e!==t?o.push({i:r.push(i(r)+"skewX(",null,n)-2,x:(0,vy.A)(e,t)}):t&&r.push(i(r)+"skewX("+t+n)}(o.skewX,a.skewX,s,l),function(e,t,r,n,o,a){if(e!==r||t!==n){var s=o.push(i(o)+"scale(",null,",",null,")");a.push({i:s-4,x:(0,vy.A)(e,r)},{i:s-2,x:(0,vy.A)(t,n)})}else 1===r&&1===n||o.push(i(o)+"scale("+r+","+n+")")}(o.scaleX,o.scaleY,a.scaleX,a.scaleY,s,l),o=a=null,function(e){for(var t,r=-1,n=l.length;++r=0&&(e=e.slice(0,t)),!e||"start"===e}))}(t)?py:fy;return function(){var a=o(this,e),s=a.on;s!==n&&(i=(n=s).copy()).on(t,r),a.on=i}}(r,e,t))},attr:function(e,t){var r=Hm(e),n="transform"===r?Sy:Py;return this.attrTween(e,"function"===typeof t?(r.local?jy:zy)(r,n,My(this,"attr."+e,t)):null==t?(r.local?Ry:Oy)(r):(r.local?Dy:Ly)(r,n,t))},attrTween:function(e,t){var r="attr."+e;if(arguments.length<2)return(r=this.tween(r))&&r._value;if(null==t)return this.tween(r,null);if("function"!==typeof t)throw new Error;var n=Hm(e);return this.tween(r,(n.local?Fy:Ny)(n,t))},style:function(e,t,r){var n="transform"===(e+="")?ky:Py;return null==t?this.styleTween(e,function(e,t){var r,n,i;return function(){var o=eg(this,e),a=(this.style.removeProperty(e),eg(this,e));return o===a?null:o===r&&a===n?i:i=t(r=o,n=a)}}(e,n)).on("end.style."+e,Wy(e)):"function"===typeof t?this.styleTween(e,function(e,t,r){var n,i,o;return function(){var a=eg(this,e),s=r(this),l=s+"";return null==s&&(this.style.removeProperty(e),l=s=eg(this,e)),a===l?null:a===n&&l===i?o:(i=l,o=t(n=a,s))}}(e,n,My(this,"style."+e,t))).each(function(e,t){var r,n,i,o,a="style."+t,s="end."+a;return function(){var l=fy(this,e),c=l.on,u=null==l.value[a]?o||(o=Wy(t)):void 0;c===r&&i===u||(n=(r=c).copy()).on(s,i=u),l.on=n}}(this._id,e)):this.styleTween(e,function(e,t,r){var n,i,o=r+"";return function(){var a=eg(this,e);return a===o?null:a===n?i:i=t(n=a,r)}}(e,n,t),r).on("end.style."+e,null)},styleTween:function(e,t,r){var n="style."+(e+="");if(arguments.length<2)return(n=this.tween(n))&&n._value;if(null==t)return this.tween(n,null);if("function"!==typeof t)throw new Error;return this.tween(n,function(e,t,r){var n,i;function o(){var o=t.apply(this,arguments);return o!==i&&(n=(i=o)&&function(e,t,r){return function(n){this.style.setProperty(e,t.call(this,n),r)}}(e,o,r)),n}return o._value=t,o}(e,t,null==r?"":r))},text:function(e){return this.tween("text","function"===typeof e?function(e){return function(){var t=e(this);this.textContent=null==t?"":t}}(My(this,"text",e)):function(e){return function(){this.textContent=e}}(null==e?"":e+""))},textTween:function(e){var t="text";if(arguments.length<1)return(t=this.tween(t))&&t._value;if(null==e)return this.tween(t,null);if("function"!==typeof e)throw new Error;return this.tween(t,function(e){var t,r;function n(){var n=e.apply(this,arguments);return n!==r&&(t=(r=n)&&function(e){return function(t){this.textContent=e.call(this,t)}}(n)),t}return n._value=e,n}(e))},remove:function(){return this.on("end.remove",(e=this._id,function(){var t=this.parentNode;for(var r in this.__transition)if(+r!==e)return;t&&t.removeChild(this)}));var e},tween:function(e,t){var r=this._id;if(e+="",arguments.length<2){for(var n,i=my(this.node(),r).tween,o=0,a=i.length;o()=>e;function Qy(e,t){let{sourceEvent:r,target:n,transform:i,dispatch:o}=t;Object.defineProperties(this,{type:{value:e,enumerable:!0,configurable:!0},sourceEvent:{value:r,enumerable:!0,configurable:!0},target:{value:n,enumerable:!0,configurable:!0},transform:{value:i,enumerable:!0,configurable:!0},_:{value:o}})}function ev(e,t,r){this.k=e,this.x=t,this.y=r}ev.prototype={constructor:ev,scale:function(e){return 1===e?this:new ev(this.k*e,this.x,this.y)},translate:function(e,t){return 0===e&0===t?this:new ev(this.k,this.x+this.k*e,this.y+this.k*t)},apply:function(e){return[e[0]*this.k+this.x,e[1]*this.k+this.y]},applyX:function(e){return e*this.k+this.x},applyY:function(e){return e*this.k+this.y},invert:function(e){return[(e[0]-this.x)/this.k,(e[1]-this.y)/this.k]},invertX:function(e){return(e-this.x)/this.k},invertY:function(e){return(e-this.y)/this.k},rescaleX:function(e){return e.copy().domain(e.range().map(this.invertX,this).map(e.invert,e))},rescaleY:function(e){return e.copy().domain(e.range().map(this.invertY,this).map(e.invert,e))},toString:function(){return"translate("+this.x+","+this.y+") scale("+this.k+")"}};var tv=new ev(1,0,0);function rv(e){e.stopImmediatePropagation()}function nv(e){e.preventDefault(),e.stopImmediatePropagation()}function iv(e){return(!e.ctrlKey||"wheel"===e.type)&&!e.button}function ov(){var e=this;return e instanceof SVGElement?(e=e.ownerSVGElement||e).hasAttribute("viewBox")?[[(e=e.viewBox.baseVal).x,e.y],[e.x+e.width,e.y+e.height]]:[[0,0],[e.width.baseVal.value,e.height.baseVal.value]]:[[0,0],[e.clientWidth,e.clientHeight]]}function av(){return this.__zoom||tv}function sv(e){return-e.deltaY*(1===e.deltaMode?.05:e.deltaMode?1:.002)*(e.ctrlKey?10:1)}function lv(){return navigator.maxTouchPoints||"ontouchstart"in this}function cv(e,t,r){var n=e.invertX(t[0][0])-r[0][0],i=e.invertX(t[1][0])-r[1][0],o=e.invertY(t[0][1])-r[0][1],a=e.invertY(t[1][1])-r[1][1];return e.translate(i>n?(n+i)/2:Math.min(0,n)||Math.max(0,i),a>o?(o+a)/2:Math.min(0,o)||Math.max(0,a))}ev.prototype;const uv=e=>()=>e;function dv(e,t){let{sourceEvent:r,subject:n,target:i,identifier:o,active:a,x:s,y:l,dx:c,dy:u,dispatch:d}=t;Object.defineProperties(this,{type:{value:e,enumerable:!0,configurable:!0},sourceEvent:{value:r,enumerable:!0,configurable:!0},subject:{value:n,enumerable:!0,configurable:!0},target:{value:i,enumerable:!0,configurable:!0},identifier:{value:o,enumerable:!0,configurable:!0},active:{value:a,enumerable:!0,configurable:!0},x:{value:s,enumerable:!0,configurable:!0},y:{value:l,enumerable:!0,configurable:!0},dx:{value:c,enumerable:!0,configurable:!0},dy:{value:u,enumerable:!0,configurable:!0},_:{value:d}})}function hv(e){return!e.ctrlKey&&!e.button}function pv(){return this.parentNode}function fv(e,t){return null==t?{x:e.x,y:e.y}:t}function mv(){return navigator.maxTouchPoints||"ontouchstart"in this}dv.prototype.on=function(){var e=this._.on.apply(this._,arguments);return e===this._?this:e};const gv=(0,n.createContext)(null),yv=gv.Provider,vv=e=>`Node type "${e}" not found. Using fallback type "default".`,xv=()=>"The React Flow parent container needs a width and a height to render the graph.",bv=()=>"Only child nodes can use a parent extent.",_v=()=>"Can't create edge. An edge needs a source and a target.",wv=e=>`Marker type "${e}" doesn't exist.`,kv=(e,t)=>`Couldn't create edge for ${e?"target":"source"} handle id: "${e?t.targetHandle:t.sourceHandle}", edge id: ${t.id}.`,Sv=()=>"Handle: No node id found. Make sure to only use a Handle inside a custom Node.",Av=e=>`Edge type "${e}" not found. Using fallback type "default".`,Tv=e=>`Node with id "${e}" does not exist, it may have been removed. This can happen when a node is deleted before the "onNodeClick" handler is called.`,Mv=(()=>"[React Flow]: Seems like you have not used zustand provider as an ancestor. Help: https://reactflow.dev/error#001")();function Cv(e,t){const r=(0,n.useContext)(gv);if(null===r)throw new Error(Mv);return fm(r,e,t)}const Ev=()=>{const e=(0,n.useContext)(gv);if(null===e)throw new Error(Mv);return(0,n.useMemo)((()=>({getState:e.getState,setState:e.setState,subscribe:e.subscribe,destroy:e.destroy})),[e])},Iv=e=>e.userSelectionActive?"none":"all";function Pv(e){let{position:t,children:r,className:i,style:o,...a}=e;const s=Cv(Iv),l=`${t}`.split("-");return n.createElement("div",{className:lm(["react-flow__panel",i,...l]),style:{...o,pointerEvents:s},...a},r)}function Ov(e){let{proOptions:t,position:r="bottom-right"}=e;return t?.hideAttribution?null:n.createElement(Pv,{position:r,className:"react-flow__attribution","data-message":"Please only hide this attribution when you are subscribed to React Flow Pro: https://reactflow.dev/pro"},n.createElement("a",{href:"https://reactflow.dev",target:"_blank",rel:"noopener noreferrer","aria-label":"React Flow attribution"},"React Flow"))}var Rv=(0,n.memo)((e=>{let{x:t,y:r,label:i,labelStyle:o={},labelShowBg:a=!0,labelBgStyle:s={},labelBgPadding:l=[2,4],labelBgBorderRadius:c=2,children:u,className:d,...h}=e;const p=(0,n.useRef)(null),[f,m]=(0,n.useState)({x:0,y:0,width:0,height:0}),g=lm(["react-flow__edge-textwrapper",d]);return(0,n.useEffect)((()=>{if(p.current){const e=p.current.getBBox();m({x:e.x,y:e.y,width:e.width,height:e.height})}}),[i]),"undefined"!==typeof i&&i?n.createElement("g",{transform:`translate(${t-f.width/2} ${r-f.height/2})`,className:g,visibility:f.width?"visible":"hidden",...h},a&&n.createElement("rect",{width:f.width+2*l[0],x:-l[0],y:-l[1],height:f.height+2*l[1],className:"react-flow__edge-textbg",style:s,rx:c,ry:c}),n.createElement("text",{className:"react-flow__edge-text",y:f.height/2,dy:"0.3em",ref:p,style:o},i),u):null}));const Lv=e=>({width:e.offsetWidth,height:e.offsetHeight}),Dv=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1;return Math.min(Math.max(e,t),r)},zv=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{x:0,y:0},t=arguments.length>1?arguments[1]:void 0;return{x:Dv(e.x,t[0][0],t[1][0]),y:Dv(e.y,t[0][1],t[1][1])}},jv=(e,t,r)=>er?-Dv(Math.abs(e-r),1,50)/50:0,Fv=(e,t)=>[20*jv(e.x,35,t.width-35),20*jv(e.y,35,t.height-35)],Nv=e=>e.getRootNode?.()||window?.document,Bv=(e,t)=>({x:Math.min(e.x,t.x),y:Math.min(e.y,t.y),x2:Math.max(e.x2,t.x2),y2:Math.max(e.y2,t.y2)}),Vv=e=>{let{x:t,y:r,width:n,height:i}=e;return{x:t,y:r,x2:t+n,y2:r+i}},Uv=e=>{let{x:t,y:r,x2:n,y2:i}=e;return{x:t,y:r,width:n-t,height:i-r}},Hv=e=>({...e.positionAbsolute||{x:0,y:0},width:e.width||0,height:e.height||0}),$v=(e,t)=>{const r=Math.max(0,Math.min(e.x+e.width,t.x+t.width)-Math.max(e.x,t.x)),n=Math.max(0,Math.min(e.y+e.height,t.y+t.height)-Math.max(e.y,t.y));return Math.ceil(r*n)},Wv=e=>!isNaN(e)&&isFinite(e),qv=Symbol.for("internals"),Gv=["Enter"," ","Escape"],Yv=(e,t)=>{0};function Xv(e){const t=(e=>"nativeEvent"in e)(e)?e.nativeEvent:e,r=t.composedPath?.()?.[0]||e.target;return["INPUT","SELECT","TEXTAREA"].includes(r?.nodeName)||r?.hasAttribute("contenteditable")||!!r?.closest(".nokey")}const Zv=e=>"clientX"in e,Kv=(e,t)=>{const r=Zv(e),n=r?e.clientX:e.touches?.[0].clientX,i=r?e.clientY:e.touches?.[0].clientY;return{x:n-(t?.left??0),y:i-(t?.top??0)}},Jv=()=>"undefined"!==typeof navigator&&navigator?.userAgent?.indexOf("Mac")>=0,Qv=e=>{let{id:t,path:r,labelX:i,labelY:o,label:a,labelStyle:s,labelShowBg:l,labelBgStyle:c,labelBgPadding:u,labelBgBorderRadius:d,style:h,markerEnd:p,markerStart:f,interactionWidth:m=20}=e;return n.createElement(n.Fragment,null,n.createElement("path",{id:t,style:h,d:r,fill:"none",className:"react-flow__edge-path",markerEnd:p,markerStart:f}),m&&n.createElement("path",{d:r,fill:"none",strokeOpacity:0,strokeWidth:m,className:"react-flow__edge-interaction"}),a&&Wv(i)&&Wv(o)?n.createElement(Rv,{x:i,y:o,label:a,labelStyle:s,labelShowBg:l,labelBgStyle:c,labelBgPadding:u,labelBgBorderRadius:d}):null)};Qv.displayName="BaseEdge";function ex(e,t,r){return void 0===r?r:n=>{const i=t().edges.find((t=>t.id===e));i&&r(n,{...i})}}function tx(e){let{sourceX:t,sourceY:r,targetX:n,targetY:i}=e;const o=Math.abs(n-t)/2,a=n{let{sourceX:t,sourceY:r,targetX:i,targetY:o,sourcePosition:a=px.Bottom,targetPosition:s=px.Top,label:l,labelStyle:c,labelShowBg:u,labelBgStyle:d,labelBgPadding:h,labelBgBorderRadius:p,style:f,markerEnd:m,markerStart:g,interactionWidth:y}=e;const[v,x,b]=gx({sourceX:t,sourceY:r,sourcePosition:a,targetX:i,targetY:o,targetPosition:s});return n.createElement(Qv,{path:v,labelX:x,labelY:b,label:l,labelStyle:c,labelShowBg:u,labelBgStyle:d,labelBgPadding:h,labelBgBorderRadius:p,style:f,markerEnd:m,markerStart:g,interactionWidth:y})}));yx.displayName="SimpleBezierEdge";const vx={[px.Left]:{x:-1,y:0},[px.Right]:{x:1,y:0},[px.Top]:{x:0,y:-1},[px.Bottom]:{x:0,y:1}},xx=(e,t)=>Math.sqrt(Math.pow(t.x-e.x,2)+Math.pow(t.y-e.y,2));function bx(e){let{source:t,sourcePosition:r=px.Bottom,target:n,targetPosition:i=px.Top,center:o,offset:a}=e;const s=vx[r],l=vx[i],c={x:t.x+s.x*a,y:t.y+s.y*a},u={x:n.x+l.x*a,y:n.y+l.y*a},d=(e=>{let{source:t,sourcePosition:r=px.Bottom,target:n}=e;return r===px.Left||r===px.Right?t.xt[h]?-1:1)*r:v[h]=(u[h]>n[h]?-1:1)*r}}if(r!==i){const t="x"===h?"y":"x",r=s[h]===l[t],n=c[t]>u[t],i=c[t]=Math.max(Math.abs(d.y-g[0].y),Math.abs(x.y-g[0].y))?(f=(d.x+x.x)/2,m=g[0].y):(f=g[0].x,m=(d.y+x.y)/2)}return[[t,{x:c.x+y.x,y:c.y+y.y},...g,{x:u.x+v.x,y:u.y+v.y},n],f,m,_,w]}function _x(e){let{sourceX:t,sourceY:r,sourcePosition:n=px.Bottom,targetX:i,targetY:o,targetPosition:a=px.Top,borderRadius:s=5,centerX:l,centerY:c,offset:u=20}=e;const[d,h,p,f,m]=bx({source:{x:t,y:r},sourcePosition:n,target:{x:i,y:o},targetPosition:a,center:{x:l,y:c},offset:u}),g=d.reduce(((e,t,r)=>{let n="";return n=r>0&&r{let{sourceX:t,sourceY:r,targetX:i,targetY:o,label:a,labelStyle:s,labelShowBg:l,labelBgStyle:c,labelBgPadding:u,labelBgBorderRadius:d,style:h,sourcePosition:p=px.Bottom,targetPosition:f=px.Top,markerEnd:m,markerStart:g,pathOptions:y,interactionWidth:v}=e;const[x,b,_]=_x({sourceX:t,sourceY:r,sourcePosition:p,targetX:i,targetY:o,targetPosition:f,borderRadius:y?.borderRadius,offset:y?.offset});return n.createElement(Qv,{path:x,labelX:b,labelY:_,label:a,labelStyle:s,labelShowBg:l,labelBgStyle:c,labelBgPadding:u,labelBgBorderRadius:d,style:h,markerEnd:m,markerStart:g,interactionWidth:v})}));wx.displayName="SmoothStepEdge";const kx=(0,n.memo)((e=>n.createElement(wx,{...e,pathOptions:(0,n.useMemo)((()=>({borderRadius:0,offset:e.pathOptions?.offset})),[e.pathOptions?.offset])})));kx.displayName="StepEdge";const Sx=(0,n.memo)((e=>{let{sourceX:t,sourceY:r,targetX:i,targetY:o,label:a,labelStyle:s,labelShowBg:l,labelBgStyle:c,labelBgPadding:u,labelBgBorderRadius:d,style:h,markerEnd:p,markerStart:f,interactionWidth:m}=e;const[g,y,v]=function(e){let{sourceX:t,sourceY:r,targetX:n,targetY:i}=e;const[o,a,s,l]=tx({sourceX:t,sourceY:r,targetX:n,targetY:i});return[`M ${t},${r}L ${n},${i}`,o,a,s,l]}({sourceX:t,sourceY:r,targetX:i,targetY:o});return n.createElement(Qv,{path:g,labelX:y,labelY:v,label:a,labelStyle:s,labelShowBg:l,labelBgStyle:c,labelBgPadding:u,labelBgBorderRadius:d,style:h,markerEnd:p,markerStart:f,interactionWidth:m})}));function Ax(e,t){return e>=0?.5*e:25*t*Math.sqrt(-e)}function Tx(e){let{pos:t,x1:r,y1:n,x2:i,y2:o,c:a}=e;switch(t){case px.Left:return[r-Ax(r-i,a),n];case px.Right:return[r+Ax(i-r,a),n];case px.Top:return[r,n-Ax(n-o,a)];case px.Bottom:return[r,n+Ax(o-n,a)]}}function Mx(e){let{sourceX:t,sourceY:r,sourcePosition:n=px.Bottom,targetX:i,targetY:o,targetPosition:a=px.Top,curvature:s=.25}=e;const[l,c]=Tx({pos:n,x1:t,y1:r,x2:i,y2:o,c:s}),[u,d]=Tx({pos:a,x1:i,y1:o,x2:t,y2:r,c:s}),[h,p,f,m]=rx({sourceX:t,sourceY:r,targetX:i,targetY:o,sourceControlX:l,sourceControlY:c,targetControlX:u,targetControlY:d});return[`M${t},${r} C${l},${c} ${u},${d} ${i},${o}`,h,p,f,m]}Sx.displayName="StraightEdge";const Cx=(0,n.memo)((e=>{let{sourceX:t,sourceY:r,targetX:i,targetY:o,sourcePosition:a=px.Bottom,targetPosition:s=px.Top,label:l,labelStyle:c,labelShowBg:u,labelBgStyle:d,labelBgPadding:h,labelBgBorderRadius:p,style:f,markerEnd:m,markerStart:g,pathOptions:y,interactionWidth:v}=e;const[x,b,_]=Mx({sourceX:t,sourceY:r,sourcePosition:a,targetX:i,targetY:o,targetPosition:s,curvature:y?.curvature});return n.createElement(Qv,{path:x,labelX:b,labelY:_,label:l,labelStyle:c,labelShowBg:u,labelBgStyle:d,labelBgPadding:h,labelBgBorderRadius:p,style:f,markerEnd:m,markerStart:g,interactionWidth:v})}));Cx.displayName="BezierEdge";const Ex=(0,n.createContext)(null),Ix=Ex.Provider;Ex.Consumer;const Px=e=>"id"in e&&!("source"in e)&&!("target"in e),Ox=e=>{let{source:t,sourceHandle:r,target:n,targetHandle:i}=e;return`reactflow__edge-${t}${r||""}-${n}${i||""}`},Rx=(e,t)=>{if("undefined"===typeof e)return"";if("string"===typeof e)return e;return`${t?`${t}__`:""}${Object.keys(e).sort().map((t=>`${t}=${e[t]}`)).join("&")}`},Lx=(e,t)=>{if(!e.source||!e.target)return Yv(0,_v()),t;let r;var n;return r="id"in(n=e)&&"source"in n&&"target"in n?{...e}:{...e,id:Ox(e)},((e,t)=>t.some((t=>t.source===e.source&&t.target===e.target&&(t.sourceHandle===e.sourceHandle||!t.sourceHandle&&!e.sourceHandle)&&(t.targetHandle===e.targetHandle||!t.targetHandle&&!e.targetHandle))))(r,t)?t:t.concat(r)},Dx=(e,t,r,n)=>{let{x:i,y:o}=e,[a,s,l]=t,[c,u]=n;const d={x:(i-a)/l,y:(o-s)/l};return r?{x:c*Math.round(d.x/c),y:u*Math.round(d.y/u)}:d},zx=(e,t)=>{let{x:r,y:n}=e,[i,o,a]=t;return{x:r*a+i,y:n*a+o}},jx=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[0,0];if(!e)return{x:0,y:0,positionAbsolute:{x:0,y:0}};const r=(e.width??0)*t[0],n=(e.height??0)*t[1],i={x:e.position.x-r,y:e.position.y-n};return{...i,positionAbsolute:e.positionAbsolute?{x:e.positionAbsolute.x-r,y:e.positionAbsolute.y-n}:i}},Fx=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[0,0];if(0===e.length)return{x:0,y:0,width:0,height:0};const r=e.reduce(((e,r)=>{const{x:n,y:i}=jx(r,t).positionAbsolute;return Bv(e,Vv({x:n,y:i,width:r.width||0,height:r.height||0}))}),{x:1/0,y:1/0,x2:-1/0,y2:-1/0});return Uv(r)},Nx=function(e,t){let[r,n,i]=arguments.length>2&&void 0!==arguments[2]?arguments[2]:[0,0,1],o=arguments.length>3&&void 0!==arguments[3]&&arguments[3],a=arguments.length>4&&void 0!==arguments[4]&&arguments[4],s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:[0,0];const l={x:(t.x-r)/i,y:(t.y-n)/i,width:t.width/i,height:t.height/i},c=[];return e.forEach((e=>{const{width:t,height:r,selectable:n=!0,hidden:i=!1}=e;if(a&&!n||i)return!1;const{positionAbsolute:u}=jx(e,s),d={x:u.x,y:u.y,width:t||0,height:r||0},h=$v(l,d);("undefined"===typeof t||"undefined"===typeof r||null===t||null===r||o&&h>0||h>=(t||0)*(r||0)||e.dragging)&&c.push(e)})),c},Bx=(e,t)=>{const r=e.map((e=>e.id));return t.filter((e=>r.includes(e.source)||r.includes(e.target)))},Vx=function(e,t,r,n,i){let o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:.1;const a=t/(e.width*(1+o)),s=r/(e.height*(1+o)),l=Math.min(a,s),c=Dv(l,n,i);return{x:t/2-(e.x+e.width/2)*c,y:r/2-(e.y+e.height/2)*c,zoom:c}},Ux=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;return e.transition().duration(t)};function Hx(e,t,r,n){return(t[r]||[]).reduce(((t,i)=>(`${e.id}-${i.id}-${r}`!==n&&t.push({id:i.id||null,type:r,nodeId:e.id,x:(e.positionAbsolute?.x??0)+i.x+i.width/2,y:(e.positionAbsolute?.y??0)+i.y+i.height/2}),t)),[])}const $x={source:null,target:null,sourceHandle:null,targetHandle:null},Wx=()=>({handleDomNode:null,isValid:!1,connection:$x,endHandle:null});function qx(e,t,r,n,i,o,a){const s="target"===i,l=a.querySelector(`.react-flow__handle[data-id="${e?.nodeId}-${e?.id}-${e?.type}"]`),c={...Wx(),handleDomNode:l};if(l){const e=Gx(void 0,l),i=l.getAttribute("data-nodeid"),a=l.getAttribute("data-handleid"),u=l.classList.contains("connectable"),d=l.classList.contains("connectableend"),h={source:s?i:r,sourceHandle:s?a:n,target:s?r:i,targetHandle:s?n:a};c.connection=h;u&&d&&(t===nx.Strict?s&&"source"===e||!s&&"target"===e:i!==r||a!==n)&&(c.endHandle={nodeId:i,handleId:a,type:e},c.isValid=o(h))}return c}function Gx(e,t){return e||(t?.classList.contains("target")?"target":t?.classList.contains("source")?"source":null)}function Yx(e){e?.classList.remove("valid","connecting","react-flow__handle-valid","react-flow__handle-connecting")}function Xx(e,t){let r=null;return t?r="valid":e&&!t&&(r="invalid"),r}function Zx(e){let{event:t,handleId:r,nodeId:n,onConnect:i,isTarget:o,getState:a,setState:s,isValidConnection:l,edgeUpdaterType:c,onReconnectEnd:u}=e;const d=Nv(t.target),{connectionMode:h,domNode:p,autoPanOnConnect:f,connectionRadius:m,onConnectStart:g,panBy:y,getNodes:v,cancelConnection:x}=a();let b,_=0;const{x:w,y:k}=Kv(t),S=d?.elementFromPoint(w,k),A=Gx(c,S),T=p?.getBoundingClientRect();if(!T||!A)return;let M,C=Kv(t,T),E=!1,I=null,P=!1,O=null;const R=function(e){let{nodes:t,nodeId:r,handleId:n,handleType:i}=e;return t.reduce(((e,t)=>{if(t[qv]){const{handleBounds:o}=t[qv];let a=[],s=[];o&&(a=Hx(t,o,"source",`${r}-${n}-${i}`),s=Hx(t,o,"target",`${r}-${n}-${i}`)),e.push(...a,...s)}return e}),[])}({nodes:v(),nodeId:n,handleId:r,handleType:A}),L=()=>{if(!f)return;const[e,t]=Fv(C,T);y({x:e,y:t}),_=requestAnimationFrame(L)};function D(e){const{transform:t}=a();C=Kv(e,T);const{handle:i,validHandleResult:c}=function(e,t,r,n,i,o){const{x:a,y:s}=Kv(e),l=t.elementsFromPoint(a,s).find((e=>e.classList.contains("react-flow__handle")));if(l){const e=l.getAttribute("data-nodeid");if(e){const t=Gx(void 0,l),n=l.getAttribute("data-handleid"),a=o({nodeId:e,id:n,type:t});if(a){const o=i.find((r=>r.nodeId===e&&r.type===t&&r.id===n));return{handle:{id:n,type:t,nodeId:e,x:o?.x||r.x,y:o?.y||r.y},validHandleResult:a}}}}let c=[],u=1/0;if(i.forEach((e=>{const t=Math.sqrt((e.x-r.x)**2+(e.y-r.y)**2);if(t<=n){const r=o(e);t<=u&&(t{let{validHandleResult:t}=e;return t.isValid})),h=c.some((e=>{let{handle:t}=e;return"target"===t.type}));return c.find((e=>{let{handle:t,validHandleResult:r}=e;return h?"target"===t.type:!d||r.isValid}))||c[0]}(e,d,Dx(C,t,!1,[1,1]),m,R,(e=>qx(e,h,n,r,o?"target":"source",l,d)));if(b=i,E||(L(),E=!0),O=c.handleDomNode,I=c.connection,P=c.isValid,s({connectionPosition:b&&P?zx({x:b.x,y:b.y},t):C,connectionStatus:Xx(!!b,P),connectionEndHandle:c.endHandle}),!b&&!P&&!O)return Yx(M);I.source!==I.target&&O&&(Yx(M),M=O,O.classList.add("connecting","react-flow__handle-connecting"),O.classList.toggle("valid",P),O.classList.toggle("react-flow__handle-valid",P))}function z(e){(b||O)&&I&&P&&i?.(I),a().onConnectEnd?.(e),c&&u?.(e),Yx(M),x(),cancelAnimationFrame(_),E=!1,P=!1,I=null,O=null,d.removeEventListener("mousemove",D),d.removeEventListener("mouseup",z),d.removeEventListener("touchmove",D),d.removeEventListener("touchend",z)}s({connectionPosition:C,connectionStatus:null,connectionNodeId:n,connectionHandleId:r,connectionHandleType:A,connectionStartHandle:{nodeId:n,handleId:r,type:A},connectionEndHandle:null}),g?.(t,{nodeId:n,handleId:r,handleType:A}),d.addEventListener("mousemove",D),d.addEventListener("mouseup",z),d.addEventListener("touchmove",D),d.addEventListener("touchend",z)}const Kx=()=>!0,Jx=e=>({connectionStartHandle:e.connectionStartHandle,connectOnClick:e.connectOnClick,noPanClassName:e.noPanClassName}),Qx=(0,n.forwardRef)(((e,t)=>{let{type:r="source",position:i=px.Top,isValidConnection:o,isConnectable:a=!0,isConnectableStart:s=!0,isConnectableEnd:l=!0,id:c,onConnect:u,children:d,className:h,onMouseDown:p,onTouchStart:f,...m}=e;const g=c||null,y="target"===r,v=Ev(),x=(0,n.useContext)(Ex),{connectOnClick:b,noPanClassName:_}=Cv(Jx,gm),{connecting:w,clickConnecting:k}=Cv(((e,t,r)=>n=>{const{connectionStartHandle:i,connectionEndHandle:o,connectionClickStartHandle:a}=n;return{connecting:i?.nodeId===e&&i?.handleId===t&&i?.type===r||o?.nodeId===e&&o?.handleId===t&&o?.type===r,clickConnecting:a?.nodeId===e&&a?.handleId===t&&a?.type===r}})(x,g,r),gm);x||v.getState().onError?.("010",Sv());const S=e=>{const{defaultEdgeOptions:t,onConnect:r,hasDefaultEdges:n}=v.getState(),i={...t,...e};if(n){const{edges:e,setEdges:t}=v.getState();t(Lx(i,e))}r?.(i),u?.(i)},A=e=>{if(!x)return;const t=Zv(e);s&&(t&&0===e.button||!t)&&Zx({event:e,handleId:g,nodeId:x,onConnect:S,isTarget:y,getState:v.getState,setState:v.setState,isValidConnection:o||v.getState().isValidConnection||Kx}),t?p?.(e):f?.(e)};return n.createElement("div",{"data-handleid":g,"data-nodeid":x,"data-handlepos":i,"data-id":`${x}-${g}-${r}`,className:lm(["react-flow__handle",`react-flow__handle-${i}`,"nodrag",_,h,{source:!y,target:y,connectable:a,connectablestart:s,connectableend:l,connecting:k,connectionindicator:a&&(s&&!w||l&&w)}]),onMouseDown:A,onTouchStart:A,onClick:b?e=>{const{onClickConnectStart:t,onClickConnectEnd:n,connectionClickStartHandle:i,connectionMode:a,isValidConnection:l}=v.getState();if(!x||!i&&!s)return;if(!i)return t?.(e,{nodeId:x,handleId:g,handleType:r}),void v.setState({connectionClickStartHandle:{nodeId:x,type:r,handleId:g}});const c=Nv(e.target),u=o||l||Kx,{connection:d,isValid:h}=qx({nodeId:x,id:g,type:r},a,i.nodeId,i.handleId||null,i.type,u,c);h&&S(d),n?.(e),v.setState({connectionClickStartHandle:null})}:void 0,ref:t,...m},d)}));Qx.displayName="Handle";var eb=(0,n.memo)(Qx);const tb=e=>{let{data:t,isConnectable:r,targetPosition:i=px.Top,sourcePosition:o=px.Bottom}=e;return n.createElement(n.Fragment,null,n.createElement(eb,{type:"target",position:i,isConnectable:r}),t?.label,n.createElement(eb,{type:"source",position:o,isConnectable:r}))};tb.displayName="DefaultNode";var rb=(0,n.memo)(tb);const nb=e=>{let{data:t,isConnectable:r,sourcePosition:i=px.Bottom}=e;return n.createElement(n.Fragment,null,t?.label,n.createElement(eb,{type:"source",position:i,isConnectable:r}))};nb.displayName="InputNode";var ib=(0,n.memo)(nb);const ob=e=>{let{data:t,isConnectable:r,targetPosition:i=px.Top}=e;return n.createElement(n.Fragment,null,n.createElement(eb,{type:"target",position:i,isConnectable:r}),t?.label)};ob.displayName="OutputNode";var ab=(0,n.memo)(ob);const sb=()=>null;sb.displayName="GroupNode";const lb=e=>({selectedNodes:e.getNodes().filter((e=>e.selected)),selectedEdges:e.edges.filter((e=>e.selected)).map((e=>({...e})))}),cb=e=>e.id;function ub(e,t){return gm(e.selectedNodes.map(cb),t.selectedNodes.map(cb))&&gm(e.selectedEdges.map(cb),t.selectedEdges.map(cb))}const db=(0,n.memo)((e=>{let{onSelectionChange:t}=e;const r=Ev(),{selectedNodes:i,selectedEdges:o}=Cv(lb,ub);return(0,n.useEffect)((()=>{const e={nodes:i,edges:o};t?.(e),r.getState().onSelectionChange.forEach((t=>t(e)))}),[i,o,t]),null}));db.displayName="SelectionListener";const hb=e=>!!e.onSelectionChange;function pb(e){let{onSelectionChange:t}=e;const r=Cv(hb);return t||r?n.createElement(db,{onSelectionChange:t}):null}const fb=e=>({setNodes:e.setNodes,setEdges:e.setEdges,setDefaultNodesAndEdges:e.setDefaultNodesAndEdges,setMinZoom:e.setMinZoom,setMaxZoom:e.setMaxZoom,setTranslateExtent:e.setTranslateExtent,setNodeExtent:e.setNodeExtent,reset:e.reset});function mb(e,t){(0,n.useEffect)((()=>{"undefined"!==typeof e&&t(e)}),[e])}function gb(e,t,r){(0,n.useEffect)((()=>{"undefined"!==typeof t&&r({[e]:t})}),[t])}const yb=e=>{let{nodes:t,edges:r,defaultNodes:i,defaultEdges:o,onConnect:a,onConnectStart:s,onConnectEnd:l,onClickConnectStart:c,onClickConnectEnd:u,nodesDraggable:d,nodesConnectable:h,nodesFocusable:p,edgesFocusable:f,edgesUpdatable:m,elevateNodesOnSelect:g,minZoom:y,maxZoom:v,nodeExtent:x,onNodesChange:b,onEdgesChange:_,elementsSelectable:w,connectionMode:k,snapGrid:S,snapToGrid:A,translateExtent:T,connectOnClick:M,defaultEdgeOptions:C,fitView:E,fitViewOptions:I,onNodesDelete:P,onEdgesDelete:O,onNodeDrag:R,onNodeDragStart:L,onNodeDragStop:D,onSelectionDrag:z,onSelectionDragStart:j,onSelectionDragStop:F,noPanClassName:N,nodeOrigin:B,rfId:V,autoPanOnConnect:U,autoPanOnNodeDrag:H,onError:$,connectionRadius:W,isValidConnection:q,nodeDragThreshold:G}=e;const{setNodes:Y,setEdges:X,setDefaultNodesAndEdges:Z,setMinZoom:K,setMaxZoom:J,setTranslateExtent:Q,setNodeExtent:ee,reset:te}=Cv(fb,gm),re=Ev();return(0,n.useEffect)((()=>{const e=o?.map((e=>({...e,...C})));return Z(i,e),()=>{te()}}),[]),gb("defaultEdgeOptions",C,re.setState),gb("connectionMode",k,re.setState),gb("onConnect",a,re.setState),gb("onConnectStart",s,re.setState),gb("onConnectEnd",l,re.setState),gb("onClickConnectStart",c,re.setState),gb("onClickConnectEnd",u,re.setState),gb("nodesDraggable",d,re.setState),gb("nodesConnectable",h,re.setState),gb("nodesFocusable",p,re.setState),gb("edgesFocusable",f,re.setState),gb("edgesUpdatable",m,re.setState),gb("elementsSelectable",w,re.setState),gb("elevateNodesOnSelect",g,re.setState),gb("snapToGrid",A,re.setState),gb("snapGrid",S,re.setState),gb("onNodesChange",b,re.setState),gb("onEdgesChange",_,re.setState),gb("connectOnClick",M,re.setState),gb("fitViewOnInit",E,re.setState),gb("fitViewOnInitOptions",I,re.setState),gb("onNodesDelete",P,re.setState),gb("onEdgesDelete",O,re.setState),gb("onNodeDrag",R,re.setState),gb("onNodeDragStart",L,re.setState),gb("onNodeDragStop",D,re.setState),gb("onSelectionDrag",z,re.setState),gb("onSelectionDragStart",j,re.setState),gb("onSelectionDragStop",F,re.setState),gb("noPanClassName",N,re.setState),gb("nodeOrigin",B,re.setState),gb("rfId",V,re.setState),gb("autoPanOnConnect",U,re.setState),gb("autoPanOnNodeDrag",H,re.setState),gb("onError",$,re.setState),gb("connectionRadius",W,re.setState),gb("isValidConnection",q,re.setState),gb("nodeDragThreshold",G,re.setState),mb(t,Y),mb(r,X),mb(y,K),mb(v,J),mb(T,Q),mb(x,ee),null},vb={display:"none"},xb={position:"absolute",width:1,height:1,margin:-1,border:0,padding:0,overflow:"hidden",clip:"rect(0px, 0px, 0px, 0px)",clipPath:"inset(100%)"},bb="react-flow__node-desc",_b="react-flow__edge-desc",wb=e=>e.ariaLiveMessage;function kb(e){let{rfId:t}=e;const r=Cv(wb);return n.createElement("div",{id:`react-flow__aria-live-${t}`,"aria-live":"assertive","aria-atomic":"true",style:xb},r)}function Sb(e){let{rfId:t,disableKeyboardA11y:r}=e;return n.createElement(n.Fragment,null,n.createElement("div",{id:`${bb}-${t}`,style:vb},"Press enter or space to select a node.",!r&&"You can then use the arrow keys to move the node around."," Press delete to remove it and escape to cancel."," "),n.createElement("div",{id:`${_b}-${t}`,style:vb},"Press enter or space to select an edge. You can then press delete to remove it or escape to cancel."),!r&&n.createElement(kb,{rfId:t}))}var Ab=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{actInsideInputWithModifier:!0};const[r,i]=(0,n.useState)(!1),o=(0,n.useRef)(!1),a=(0,n.useRef)(new Set([])),[s,l]=(0,n.useMemo)((()=>{if(null!==e){const t=(Array.isArray(e)?e:[e]).filter((e=>"string"===typeof e)).map((e=>e.split("+"))),r=t.reduce(((e,t)=>e.concat(...t)),[]);return[t,r]}return[[],[]]}),[e]);return(0,n.useEffect)((()=>{const r="undefined"!==typeof document?document:null,n=t?.target||r;if(null!==e){const e=e=>{o.current=e.ctrlKey||e.metaKey||e.shiftKey;if((!o.current||o.current&&!t.actInsideInputWithModifier)&&Xv(e))return!1;const r=Mb(e.code,l);a.current.add(e[r]),Tb(s,a.current,!1)&&(e.preventDefault(),i(!0))},r=e=>{if((!o.current||o.current&&!t.actInsideInputWithModifier)&&Xv(e))return!1;const r=Mb(e.code,l);Tb(s,a.current,!0)?(i(!1),a.current.clear()):a.current.delete(e[r]),"Meta"===e.key&&a.current.clear(),o.current=!1},c=()=>{a.current.clear(),i(!1)};return n?.addEventListener("keydown",e),n?.addEventListener("keyup",r),window.addEventListener("blur",c),()=>{n?.removeEventListener("keydown",e),n?.removeEventListener("keyup",r),window.removeEventListener("blur",c)}}}),[e,i]),r};function Tb(e,t,r){return e.filter((e=>r||e.length===t.size)).some((e=>e.every((e=>t.has(e)))))}function Mb(e,t){return t.includes(e)?"code":"key"}function Cb(e,t,r,n){const i=e.parentNode||e.parentId;if(!i)return r;const o=t.get(i),a=jx(o,n);return Cb(o,t,{x:(r.x??0)+a.x,y:(r.y??0)+a.y,z:(o[qv]?.z??0)>(r.z??0)?o[qv]?.z??0:r.z??0},n)}function Eb(e,t,r){e.forEach((n=>{const i=n.parentNode||n.parentId;if(i&&!e.has(i))throw new Error(`Parent node ${i} not found`);if(i||r?.[n.id]){const{x:i,y:o,z:a}=Cb(n,e,{...n.position,z:n[qv]?.z??0},t);n.positionAbsolute={x:i,y:o},n[qv].z=a,r?.[n.id]&&(n[qv].isParent=!0)}}))}function Ib(e,t,r,n){const i=new Map,o={},a=n?1e3:0;return e.forEach((e=>{const r=(Wv(e.zIndex)?e.zIndex:0)+(e.selected?a:0),n=t.get(e.id),s={...e,positionAbsolute:{x:e.position.x,y:e.position.y}},l=e.parentNode||e.parentId;l&&(o[l]=!0);const c=n?.type&&n?.type!==e.type;Object.defineProperty(s,qv,{enumerable:!1,value:{handleBounds:c?void 0:n?.[qv]?.handleBounds,z:r}}),i.set(e.id,s)})),Eb(i,r,o),i}function Pb(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{getNodes:r,width:n,height:i,minZoom:o,maxZoom:a,d3Zoom:s,d3Selection:l,fitViewOnInitDone:c,fitViewOnInit:u,nodeOrigin:d}=e(),h=t.initial&&!c&&u;if(s&&l&&(h||!t.initial)){const e=r().filter((e=>{const r=t.includeHiddenNodes?e.width&&e.height:!e.hidden;return t.nodes?.length?r&&t.nodes.some((t=>t.id===e.id)):r})),c=e.every((e=>e.width&&e.height));if(e.length>0&&c){const r=Fx(e,d),{x:c,y:u,zoom:h}=Vx(r,n,i,t.minZoom??o,t.maxZoom??a,t.padding??.1),p=tv.translate(c,u).scale(h);return"number"===typeof t.duration&&t.duration>0?s.transform(Ux(l,t.duration),p):s.transform(l,p),!0}}return!1}function Ob(e,t){return e.forEach((e=>{const r=t.get(e.id);r&&t.set(r.id,{...r,[qv]:r[qv],selected:e.selected})})),new Map(t)}function Rb(e,t){return t.map((t=>{const r=e.find((e=>e.id===t.id));return r&&(t.selected=r.selected),t}))}function Lb(e){let{changedNodes:t,changedEdges:r,get:n,set:i}=e;const{nodeInternals:o,edges:a,onNodesChange:s,onEdgesChange:l,hasDefaultNodes:c,hasDefaultEdges:u}=n();t?.length&&(c&&i({nodeInternals:Ob(t,o)}),s?.(t)),r?.length&&(u&&i({edges:Rb(r,a)}),l?.(r))}const Db=()=>{},zb={zoomIn:Db,zoomOut:Db,zoomTo:Db,getZoom:()=>1,setViewport:Db,getViewport:()=>({x:0,y:0,zoom:1}),fitView:()=>!1,setCenter:Db,fitBounds:Db,project:e=>e,screenToFlowPosition:e=>e,flowToScreenPosition:e=>e,viewportInitialized:!1},jb=e=>({d3Zoom:e.d3Zoom,d3Selection:e.d3Selection});function Fb(){const e=(()=>{const e=Ev(),{d3Zoom:t,d3Selection:r}=Cv(jb,gm);return(0,n.useMemo)((()=>r&&t?{zoomIn:e=>t.scaleBy(Ux(r,e?.duration),1.2),zoomOut:e=>t.scaleBy(Ux(r,e?.duration),1/1.2),zoomTo:(e,n)=>t.scaleTo(Ux(r,n?.duration),e),getZoom:()=>e.getState().transform[2],setViewport:(n,i)=>{const[o,a,s]=e.getState().transform,l=tv.translate(n.x??o,n.y??a).scale(n.zoom??s);t.transform(Ux(r,i?.duration),l)},getViewport:()=>{const[t,r,n]=e.getState().transform;return{x:t,y:r,zoom:n}},fitView:t=>Pb(e.getState,t),setCenter:(n,i,o)=>{const{width:a,height:s,maxZoom:l}=e.getState(),c="undefined"!==typeof o?.zoom?o.zoom:l,u=a/2-n*c,d=s/2-i*c,h=tv.translate(u,d).scale(c);t.transform(Ux(r,o?.duration),h)},fitBounds:(n,i)=>{const{width:o,height:a,minZoom:s,maxZoom:l}=e.getState(),{x:c,y:u,zoom:d}=Vx(n,o,a,s,l,i?.padding??.1),h=tv.translate(c,u).scale(d);t.transform(Ux(r,i?.duration),h)},project:t=>{const{transform:r,snapToGrid:n,snapGrid:i}=e.getState();return console.warn("[DEPRECATED] `project` is deprecated. Instead use `screenToFlowPosition`. There is no need to subtract the react flow bounds anymore! https://reactflow.dev/api-reference/types/react-flow-instance#screen-to-flow-position"),Dx(t,r,n,i)},screenToFlowPosition:t=>{const{transform:r,snapToGrid:n,snapGrid:i,domNode:o}=e.getState();if(!o)return t;const{x:a,y:s}=o.getBoundingClientRect(),l={x:t.x-a,y:t.y-s};return Dx(l,r,n,i)},flowToScreenPosition:t=>{const{transform:r,domNode:n}=e.getState();if(!n)return t;const{x:i,y:o}=n.getBoundingClientRect(),a=zx(t,r);return{x:a.x+i,y:a.y+o}},viewportInitialized:!0}:zb),[t,r])})(),t=Ev(),r=(0,n.useCallback)((()=>t.getState().getNodes().map((e=>({...e})))),[]),i=(0,n.useCallback)((e=>t.getState().nodeInternals.get(e)),[]),o=(0,n.useCallback)((()=>{const{edges:e=[]}=t.getState();return e.map((e=>({...e})))}),[]),a=(0,n.useCallback)((e=>{const{edges:r=[]}=t.getState();return r.find((t=>t.id===e))}),[]),s=(0,n.useCallback)((e=>{const{getNodes:r,setNodes:n,hasDefaultNodes:i,onNodesChange:o}=t.getState(),a=r(),s="function"===typeof e?e(a):e;if(i)n(s);else if(o){o(0===s.length?a.map((e=>({type:"remove",id:e.id}))):s.map((e=>({item:e,type:"reset"}))))}}),[]),l=(0,n.useCallback)((e=>{const{edges:r=[],setEdges:n,hasDefaultEdges:i,onEdgesChange:o}=t.getState(),a="function"===typeof e?e(r):e;if(i)n(a);else if(o){o(0===a.length?r.map((e=>({type:"remove",id:e.id}))):a.map((e=>({item:e,type:"reset"}))))}}),[]),c=(0,n.useCallback)((e=>{const r=Array.isArray(e)?e:[e],{getNodes:n,setNodes:i,hasDefaultNodes:o,onNodesChange:a}=t.getState();if(o){i([...n(),...r])}else if(a){a(r.map((e=>({item:e,type:"add"}))))}}),[]),u=(0,n.useCallback)((e=>{const r=Array.isArray(e)?e:[e],{edges:n=[],setEdges:i,hasDefaultEdges:o,onEdgesChange:a}=t.getState();if(o)i([...n,...r]);else if(a){a(r.map((e=>({item:e,type:"add"}))))}}),[]),d=(0,n.useCallback)((()=>{const{getNodes:e,edges:r=[],transform:n}=t.getState(),[i,o,a]=n;return{nodes:e().map((e=>({...e}))),edges:r.map((e=>({...e}))),viewport:{x:i,y:o,zoom:a}}}),[]),h=(0,n.useCallback)((e=>{let{nodes:r,edges:n}=e;const{nodeInternals:i,getNodes:o,edges:a,hasDefaultNodes:s,hasDefaultEdges:l,onNodesDelete:c,onEdgesDelete:u,onNodesChange:d,onEdgesChange:h}=t.getState(),p=(r||[]).map((e=>e.id)),f=(n||[]).map((e=>e.id)),m=o().reduce(((e,t)=>{const r=t.parentNode||t.parentId,n=!p.includes(t.id)&&r&&e.find((e=>e.id===r));return("boolean"!==typeof t.deletable||t.deletable)&&(p.includes(t.id)||n)&&e.push(t),e}),[]),g=a.filter((e=>"boolean"!==typeof e.deletable||e.deletable)),y=g.filter((e=>f.includes(e.id)));if(m||y){const e=Bx(m,g),r=[...y,...e],n=r.reduce(((e,t)=>(e.includes(t.id)||e.push(t.id),e)),[]);if((l||s)&&(l&&t.setState({edges:a.filter((e=>!n.includes(e.id)))}),s&&(m.forEach((e=>{i.delete(e.id)})),t.setState({nodeInternals:new Map(i)}))),n.length>0&&(u?.(r),h&&h(n.map((e=>({id:e,type:"remove"}))))),m.length>0&&(c?.(m),d)){d(m.map((e=>({id:e.id,type:"remove"}))))}}}),[]),p=(0,n.useCallback)((e=>{const r=Wv((n=e).width)&&Wv(n.height)&&Wv(n.x)&&Wv(n.y);var n;const i=r?null:t.getState().nodeInternals.get(e.id);if(!r&&!i)return[null,null,r];return[r?e:Hv(i),i,r]}),[]),f=(0,n.useCallback)((function(e){let r=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],n=arguments.length>2?arguments[2]:void 0;const[i,o,a]=p(e);return i?(n||t.getState().getNodes()).filter((e=>{if(!a&&(e.id===o.id||!e.positionAbsolute))return!1;const t=Hv(e),n=$v(t,i);return r&&n>0||n>=i.width*i.height})):[]}),[]),m=(0,n.useCallback)((function(e,t){let r=!(arguments.length>2&&void 0!==arguments[2])||arguments[2];const[n]=p(e);if(!n)return!1;const i=$v(n,t);return r&&i>0||i>=n.width*n.height}),[]);return(0,n.useMemo)((()=>({...e,getNodes:r,getNode:i,getEdges:o,getEdge:a,setNodes:s,setEdges:l,addNodes:c,addEdges:u,toObject:d,deleteElements:h,getIntersectingNodes:f,isNodeIntersecting:m})),[e,r,i,o,a,s,l,c,u,d,h,f,m])}const Nb={actInsideInputWithModifier:!1};const Bb={position:"absolute",width:"100%",height:"100%",top:0,left:0},Vb=e=>({x:e.x,y:e.y,zoom:e.k}),Ub=(e,t)=>e.target.closest(`.${t}`),Hb=(e,t)=>2===t&&Array.isArray(e)&&e.includes(2),$b=e=>{const t=e.ctrlKey&&Jv()?10:1;return-e.deltaY*(1===e.deltaMode?.05:e.deltaMode?1:.002)*t},Wb=e=>({d3Zoom:e.d3Zoom,d3Selection:e.d3Selection,d3ZoomHandler:e.d3ZoomHandler,userSelectionActive:e.userSelectionActive}),qb=e=>{let{onMove:t,onMoveStart:r,onMoveEnd:i,onPaneContextMenu:o,zoomOnScroll:a=!0,zoomOnPinch:s=!0,panOnScroll:l=!1,panOnScrollSpeed:c=.5,panOnScrollMode:u=ox.Free,zoomOnDoubleClick:d=!0,elementsSelectable:h,panOnDrag:p=!0,defaultViewport:f,translateExtent:m,minZoom:g,maxZoom:y,zoomActivationKeyCode:v,preventScrolling:x=!0,children:b,noWheelClassName:_,noPanClassName:w}=e;const k=(0,n.useRef)(),S=Ev(),A=(0,n.useRef)(!1),T=(0,n.useRef)(!1),M=(0,n.useRef)(null),C=(0,n.useRef)({x:0,y:0,zoom:0}),{d3Zoom:E,d3Selection:I,d3ZoomHandler:P,userSelectionActive:O}=Cv(Wb,gm),R=Ab(v),L=(0,n.useRef)(0),D=(0,n.useRef)(!1),z=(0,n.useRef)();return function(e){const t=Ev();(0,n.useEffect)((()=>{let r;const n=()=>{if(!e.current)return;const r=Lv(e.current);0!==r.height&&0!==r.width||t.getState().onError?.("004",xv()),t.setState({width:r.width||500,height:r.height||500})};return n(),window.addEventListener("resize",n),e.current&&(r=new ResizeObserver((()=>n())),r.observe(e.current)),()=>{window.removeEventListener("resize",n),r&&e.current&&r.unobserve(e.current)}}),[])}(M),(0,n.useEffect)((()=>{if(M.current){const e=M.current.getBoundingClientRect(),t=function(){var e,t,r,n=iv,i=ov,o=cv,a=sv,s=lv,l=[0,1/0],c=[[-1/0,-1/0],[1/0,1/0]],u=250,d=$g,h=wm("start","zoom","end"),p=0,f=10;function m(e){e.property("__zoom",av).on("wheel.zoom",w,{passive:!1}).on("mousedown.zoom",k).on("dblclick.zoom",S).filter(s).on("touchstart.zoom",A).on("touchmove.zoom",T).on("touchend.zoom touchcancel.zoom",M).style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function g(e,t){return(t=Math.max(l[0],Math.min(l[1],t)))===e.k?e:new ev(t,e.x,e.y)}function y(e,t,r){var n=t[0]-r[0]*e.k,i=t[1]-r[1]*e.k;return n===e.x&&i===e.y?e:new ev(e.k,n,i)}function v(e){return[(+e[0][0]+ +e[1][0])/2,(+e[0][1]+ +e[1][1])/2]}function x(e,t,r,n){e.on("start.zoom",(function(){b(this,arguments).event(n).start()})).on("interrupt.zoom end.zoom",(function(){b(this,arguments).event(n).end()})).tween("zoom",(function(){var e=this,o=arguments,a=b(e,o).event(n),s=i.apply(e,o),l=null==r?v(s):"function"===typeof r?r.apply(e,o):r,c=Math.max(s[1][0]-s[0][0],s[1][1]-s[0][1]),u=e.__zoom,h="function"===typeof t?t.apply(e,o):t,p=d(u.invert(l).concat(c/u.k),h.invert(l).concat(c/h.k));return function(e){if(1===e)e=h;else{var t=p(e),r=c/t[2];e=new ev(r,l[0]-t[0]*r,l[1]-t[1]*r)}a.zoom(null,e)}}))}function b(e,t,r){return!r&&e.__zooming||new _(e,t)}function _(e,t){this.that=e,this.args=t,this.active=0,this.sourceEvent=null,this.extent=i.apply(e,t),this.taps=0}function w(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),i=1;i1?t-1:0),a=1;ap}l.event(e).zoom("mouse",o(y(l.that.__zoom,l.mouse[0]=Wg(e,s),l.mouse[1]),l.extent,c))}),!0).on("mouseup.zoom",(function(e){u.on("mousemove.zoom mouseup.zoom",null),Ug(e.view,l.moved),nv(e),l.event(e).end()}),!0),d=Wg(e,s),h=e.clientX,f=e.clientY;Vg(e.view),rv(e),l.mouse=[d,this.__zoom.invert(d)],gy(this),l.start()}}function S(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),a=1;a0?zg(this).transition().duration(u).call(x,p,l,e):zg(this).call(m.transform,p,l,e)}}function A(r){for(var i=arguments.length,o=new Array(i>1?i-1:0),a=1;a1?t-1:0),n=1;n1?n-1:0),o=1;o{I&&E&&(!l||R||O?"undefined"!==typeof P&&I.on("wheel.zoom",(function(e,t){if(!x&&"wheel"===e.type&&!e.ctrlKey||Ub(e,_))return null;e.preventDefault(),P.call(this,e,t)}),{passive:!1}):I.on("wheel.zoom",(e=>{if(Ub(e,_))return!1;e.preventDefault(),e.stopImmediatePropagation();const n=I.property("__zoom").k||1;if(e.ctrlKey&&s){const t=Wg(e),r=$b(e),i=n*Math.pow(2,r);return void E.scaleTo(I,i,t,e)}const o=1===e.deltaMode?20:1;let a=u===ox.Vertical?0:e.deltaX*o,l=u===ox.Horizontal?0:e.deltaY*o;!Jv()&&e.shiftKey&&u!==ox.Vertical&&(a=e.deltaY*o,l=0),E.translateBy(I,-a/n*c,-l/n*c,{internal:!0});const d=Vb(I.property("__zoom")),{onViewportChangeStart:h,onViewportChange:p,onViewportChangeEnd:f}=S.getState();clearTimeout(z.current),D.current||(D.current=!0,r?.(e,d),h?.(d)),D.current&&(t?.(e,d),p?.(d),z.current=setTimeout((()=>{i?.(e,d),f?.(d),D.current=!1}),150))}),{passive:!1}))}),[O,l,u,I,E,P,R,s,x,_,r,t,i]),(0,n.useEffect)((()=>{E&&E.on("start",(e=>{if(!e.sourceEvent||e.sourceEvent.internal)return null;L.current=e.sourceEvent?.button;const{onViewportChangeStart:t}=S.getState(),n=Vb(e.transform);A.current=!0,C.current=n,"mousedown"===e.sourceEvent?.type&&S.setState({paneDragging:!0}),t?.(n),r?.(e.sourceEvent,n)}))}),[E,r]),(0,n.useEffect)((()=>{E&&(O&&!A.current?E.on("zoom",null):O||E.on("zoom",(e=>{const{onViewportChange:r}=S.getState();if(S.setState({transform:[e.transform.x,e.transform.y,e.transform.k]}),T.current=!(!o||!Hb(p,L.current??0)),(t||r)&&!e.sourceEvent?.internal){const n=Vb(e.transform);r?.(n),t?.(e.sourceEvent,n)}})))}),[O,E,t,p,o]),(0,n.useEffect)((()=>{E&&E.on("end",(e=>{if(!e.sourceEvent||e.sourceEvent.internal)return null;const{onViewportChangeEnd:t}=S.getState();if(A.current=!1,S.setState({paneDragging:!1}),o&&Hb(p,L.current??0)&&!T.current&&o(e.sourceEvent),T.current=!1,(i||t)&&(r=C.current,n=e.transform,r.x!==n.x||r.y!==n.y||r.zoom!==n.k)){const r=Vb(e.transform);C.current=r,clearTimeout(k.current),k.current=setTimeout((()=>{t?.(r),i?.(e.sourceEvent,r)}),l?150:0)}var r,n}))}),[E,l,p,i,o]),(0,n.useEffect)((()=>{E&&E.filter((e=>{const t=R||a,r=s&&e.ctrlKey;if((!0===p||Array.isArray(p)&&p.includes(1))&&1===e.button&&"mousedown"===e.type&&(Ub(e,"react-flow__node")||Ub(e,"react-flow__edge")))return!0;if(!p&&!t&&!l&&!d&&!s)return!1;if(O)return!1;if(!d&&"dblclick"===e.type)return!1;if(Ub(e,_)&&"wheel"===e.type)return!1;if(Ub(e,w)&&("wheel"!==e.type||l&&"wheel"===e.type&&!R))return!1;if(!s&&e.ctrlKey&&"wheel"===e.type)return!1;if(!t&&!l&&!r&&"wheel"===e.type)return!1;if(!p&&("mousedown"===e.type||"touchstart"===e.type))return!1;if(Array.isArray(p)&&!p.includes(e.button)&&"mousedown"===e.type)return!1;const n=Array.isArray(p)&&p.includes(e.button)||!e.button||e.button<=1;return(!e.ctrlKey||"wheel"===e.type)&&n}))}),[O,E,a,s,l,d,p,h,R]),n.createElement("div",{className:"react-flow__renderer",ref:M,style:Bb},b)},Gb=e=>({userSelectionActive:e.userSelectionActive,userSelectionRect:e.userSelectionRect});function Yb(){const{userSelectionActive:e,userSelectionRect:t}=Cv(Gb,gm);return e&&t?n.createElement("div",{className:"react-flow__selection react-flow__container",style:{width:t.width,height:t.height,transform:`translate(${t.x}px, ${t.y}px)`}}):null}function Xb(e,t){const r=t.parentNode||t.parentId,n=e.find((e=>e.id===r));if(n){const e=t.position.x+t.width-n.width,r=t.position.y+t.height-n.height;if(e>0||r>0||t.position.x<0||t.position.y<0){if(n.style={...n.style}||{},n.style.width=n.style.width??n.width,n.style.height=n.style.height??n.height,e>0&&(n.style.width+=e),r>0&&(n.style.height+=r),t.position.x<0){const e=Math.abs(t.position.x);n.position.x=n.position.x-e,n.style.width+=e,t.position.x=0}if(t.position.y<0){const e=Math.abs(t.position.y);n.position.y=n.position.y-e,n.style.height+=e,t.position.y=0}n.width=n.style.width,n.height=n.style.height}}}function Zb(e,t){if(e.some((e=>"reset"===e.type)))return e.filter((e=>"reset"===e.type)).map((e=>e.item));const r=e.filter((e=>"add"===e.type)).map((e=>e.item));return t.reduce(((t,r)=>{const n=e.filter((e=>e.id===r.id));if(0===n.length)return t.push(r),t;const i={...r};for(const e of n)if(e)switch(e.type){case"select":i.selected=e.selected;break;case"position":"undefined"!==typeof e.position&&(i.position=e.position),"undefined"!==typeof e.positionAbsolute&&(i.positionAbsolute=e.positionAbsolute),"undefined"!==typeof e.dragging&&(i.dragging=e.dragging),i.expandParent&&Xb(t,i);break;case"dimensions":"undefined"!==typeof e.dimensions&&(i.width=e.dimensions.width,i.height=e.dimensions.height),"undefined"!==typeof e.updateStyle&&(i.style={...i.style||{},...e.dimensions}),"boolean"===typeof e.resizing&&(i.resizing=e.resizing),i.expandParent&&Xb(t,i);break;case"remove":return t}return t.push(i),t}),r)}function Kb(e,t){return Zb(e,t)}function Jb(e,t){return Zb(e,t)}const Qb=(e,t)=>({id:e,type:"select",selected:t});function e_(e,t){return e.reduce(((e,r)=>{const n=t.includes(r.id);return!r.selected&&n?(r.selected=!0,e.push(Qb(r.id,!0))):r.selected&&!n&&(r.selected=!1,e.push(Qb(r.id,!1))),e}),[])}const t_=(e,t)=>r=>{r.target===t.current&&e?.(r)},r_=e=>({userSelectionActive:e.userSelectionActive,elementsSelectable:e.elementsSelectable,dragging:e.paneDragging}),n_=(0,n.memo)((e=>{let{isSelecting:t,selectionMode:r=sx.Full,panOnDrag:i,onSelectionStart:o,onSelectionEnd:a,onPaneClick:s,onPaneContextMenu:l,onPaneScroll:c,onPaneMouseEnter:u,onPaneMouseMove:d,onPaneMouseLeave:h,children:p}=e;const f=(0,n.useRef)(null),m=Ev(),g=(0,n.useRef)(0),y=(0,n.useRef)(0),v=(0,n.useRef)(),{userSelectionActive:x,elementsSelectable:b,dragging:_}=Cv(r_,gm),w=()=>{m.setState({userSelectionActive:!1,userSelectionRect:null}),g.current=0,y.current=0},k=e=>{s?.(e),m.getState().resetSelectedElements(),m.setState({nodesSelectionActive:!1})},S=c?e=>c(e):void 0,A=b&&(t||x);return n.createElement("div",{className:lm(["react-flow__pane",{dragging:_,selection:t}]),onClick:A?void 0:t_(k,f),onContextMenu:t_((e=>{Array.isArray(i)&&i?.includes(2)?e.preventDefault():l?.(e)}),f),onWheel:t_(S,f),onMouseEnter:A?void 0:u,onMouseDown:A?e=>{const{resetSelectedElements:r,domNode:n}=m.getState();if(v.current=n?.getBoundingClientRect(),!b||!t||0!==e.button||e.target!==f.current||!v.current)return;const{x:i,y:a}=Kv(e,v.current);r(),m.setState({userSelectionRect:{width:0,height:0,startX:i,startY:a,x:i,y:a}}),o?.(e)}:void 0,onMouseMove:A?e=>{const{userSelectionRect:n,nodeInternals:i,edges:o,transform:a,onNodesChange:s,onEdgesChange:l,nodeOrigin:c,getNodes:u}=m.getState();if(!t||!v.current||!n)return;m.setState({userSelectionActive:!0,nodesSelectionActive:!1});const d=Kv(e,v.current),h=n.startX??0,p=n.startY??0,f={...n,x:d.xe.id)),w=b.map((e=>e.id));if(g.current!==w.length){g.current=w.length;const e=e_(x,w);e.length&&s?.(e)}if(y.current!==_.length){y.current=_.length;const e=e_(o,_);e.length&&l?.(e)}m.setState({userSelectionRect:f})}:d,onMouseUp:A?e=>{if(0!==e.button)return;const{userSelectionRect:t}=m.getState();!x&&t&&e.target===f.current&&k?.(e),m.setState({nodesSelectionActive:g.current>0}),w(),a?.(e)}:void 0,onMouseLeave:A?e=>{x&&(m.setState({nodesSelectionActive:g.current>0}),a?.(e)),w()}:h,ref:f,style:Bb},p,n.createElement(Yb,null))}));function i_(e,t){const r=e.parentNode||e.parentId;if(!r)return!1;const n=t.get(r);return!!n&&(!!n.selected||i_(n,t))}function o_(e,t,r){let n=e;do{if(n?.matches(t))return!0;if(n===r.current)return!1;n=n.parentElement}while(n);return!1}function a_(e,t,r,n){return Array.from(e.values()).filter((r=>(r.selected||r.id===n)&&(!r.parentNode||r.parentId||!i_(r,e))&&(r.draggable||t&&"undefined"===typeof r.draggable))).map((e=>({id:e.id,position:e.position||{x:0,y:0},positionAbsolute:e.positionAbsolute||{x:0,y:0},distance:{x:r.x-(e.positionAbsolute?.x??0),y:r.y-(e.positionAbsolute?.y??0)},delta:{x:0,y:0},extent:e.extent,parentNode:e.parentNode||e.parentId,parentId:e.parentNode||e.parentId,width:e.width,height:e.height,expandParent:e.expandParent})))}function s_(e,t,r,n){let i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:[0,0],o=arguments.length>5?arguments[5]:void 0;const a=function(e,t){return t&&"parent"!==t?[t[0],[t[1][0]-(e.width||0),t[1][1]-(e.height||0)]]:t}(e,e.extent||n);let s=a;const l=e.parentNode||e.parentId;if("parent"!==e.extent||e.expandParent){if(e.extent&&l&&"parent"!==e.extent){const t=r.get(l),{x:n,y:o}=jx(t,i).positionAbsolute;s=[[e.extent[0][0]+n,e.extent[0][1]+o],[e.extent[1][0]+n,e.extent[1][1]+o]]}}else if(l&&e.width&&e.height){const t=r.get(l),{x:n,y:o}=jx(t,i).positionAbsolute;s=t&&Wv(n)&&Wv(o)&&Wv(t.width)&&Wv(t.height)?[[n+e.width*i[0],o+e.height*i[1]],[n+t.width-e.width+e.width*i[0],o+t.height-e.height+e.height*i[1]]]:s}else o?.("005",bv()),s=a;let c={x:0,y:0};if(l){const e=r.get(l);c=jx(e,i).positionAbsolute}const u=s&&"parent"!==s?zv(t,s):t;return{position:{x:u.x-c.x,y:u.y-c.y},positionAbsolute:u}}function l_(e){let{nodeId:t,dragItems:r,nodeInternals:n}=e;const i=r.map((e=>({...n.get(e.id),position:e.position,positionAbsolute:e.positionAbsolute})));return[t?i.find((e=>e.id===t)):i[0],i]}n_.displayName="Pane";const c_=(e,t,r,n)=>{const i=t.querySelectorAll(e);if(!i||!i.length)return null;const o=Array.from(i),a=t.getBoundingClientRect(),s=a.width*n[0],l=a.height*n[1];return o.map((e=>{const t=e.getBoundingClientRect();return{id:e.getAttribute("data-handleid"),position:e.getAttribute("data-handlepos"),x:(t.left-a.left-s)/r,y:(t.top-a.top-l)/r,...Lv(e)}}))};function u_(e,t,r){return void 0===r?r:n=>{const i=t().nodeInternals.get(e);i&&r(n,{...i})}}function d_(e){let{id:t,store:r,unselect:n=!1,nodeRef:i}=e;const{addSelectedNodes:o,unselectNodesAndEdges:a,multiSelectionActive:s,nodeInternals:l,onError:c}=r.getState(),u=l.get(t);u?(r.setState({nodesSelectionActive:!1}),u.selected?(n||u.selected&&s)&&(a({nodes:[u],edges:[]}),requestAnimationFrame((()=>i?.current?.blur()))):o([t])):c?.("012",Tv(t))}function h_(e){return(t,r,n)=>e?.(t,n)}function p_(e){let{nodeRef:t,disabled:r=!1,noDragClassName:i,handleSelector:o,nodeId:a,isSelectable:s,selectNodesOnDrag:l}=e;const c=Ev(),[u,d]=(0,n.useState)(!1),h=(0,n.useRef)([]),p=(0,n.useRef)({x:null,y:null}),f=(0,n.useRef)(0),m=(0,n.useRef)(null),g=(0,n.useRef)({x:0,y:0}),y=(0,n.useRef)(null),v=(0,n.useRef)(!1),x=(0,n.useRef)(!1),b=(0,n.useRef)(!1),_=function(){const e=Ev();return(0,n.useCallback)((t=>{let{sourceEvent:r}=t;const{transform:n,snapGrid:i,snapToGrid:o}=e.getState(),a=r.touches?r.touches[0].clientX:r.clientX,s=r.touches?r.touches[0].clientY:r.clientY,l={x:(a-n[0])/n[2],y:(s-n[1])/n[2]};return{xSnapped:o?i[0]*Math.round(l.x/i[0]):l.x,ySnapped:o?i[1]*Math.round(l.y/i[1]):l.y,...l}}),[])}();return(0,n.useEffect)((()=>{if(t?.current){const e=zg(t.current),n=e=>{let{x:t,y:r}=e;const{nodeInternals:n,onNodeDrag:i,onSelectionDrag:o,updateNodePositions:s,nodeExtent:l,snapGrid:u,snapToGrid:f,nodeOrigin:m,onError:g}=c.getState();p.current={x:t,y:r};let v=!1,x={x:0,y:0,x2:0,y2:0};if(h.current.length>1&&l){const e=Fx(h.current,m);x=Vv(e)}if(h.current=h.current.map((e=>{const i={x:t-e.distance.x,y:r-e.distance.y};f&&(i.x=u[0]*Math.round(i.x/u[0]),i.y=u[1]*Math.round(i.y/u[1]));const o=[[l[0][0],l[0][1]],[l[1][0],l[1][1]]];h.current.length>1&&l&&!e.extent&&(o[0][0]=e.positionAbsolute.x-x.x+l[0][0],o[1][0]=e.positionAbsolute.x+(e.width??0)-x.x2+l[1][0],o[0][1]=e.positionAbsolute.y-x.y+l[0][1],o[1][1]=e.positionAbsolute.y+(e.height??0)-x.y2+l[1][1]);const a=s_(e,i,n,o,m,g);return v=v||e.position.x!==a.position.x||e.position.y!==a.position.y,e.position=a.position,e.positionAbsolute=a.positionAbsolute,e})),!v)return;s(h.current,!0,!0),d(!0);const b=a?i:h_(o);if(b&&y.current){const[e,t]=l_({nodeId:a,dragItems:h.current,nodeInternals:n});b(y.current,e,t)}},u=()=>{if(!m.current)return;const[e,t]=Fv(g.current,m.current);if(0!==e||0!==t){const{transform:r,panBy:i}=c.getState();p.current.x=(p.current.x??0)-e/r[2],p.current.y=(p.current.y??0)-t/r[2],i({x:e,y:t})&&n(p.current)}f.current=requestAnimationFrame(u)},w=e=>{const{nodeInternals:r,multiSelectionActive:n,nodesDraggable:i,unselectNodesAndEdges:o,onNodeDragStart:u,onSelectionDragStart:d}=c.getState();x.current=!0;const f=a?u:h_(d);l&&s||n||!a||r.get(a)?.selected||o(),a&&s&&l&&d_({id:a,store:c,nodeRef:t});const m=_(e);if(p.current=m,h.current=a_(r,i,m,a),f&&h.current){const[t,n]=l_({nodeId:a,dragItems:h.current,nodeInternals:r});f(e.sourceEvent,t,n)}};if(!r){const r=function(){var e,t,r,n,i=hv,o=pv,a=fv,s=mv,l={},c=wm("start","drag","end"),u=0,d=0;function h(e){e.on("mousedown.drag",p).filter(s).on("touchstart.drag",g).on("touchmove.drag",y,jg).on("touchend.drag touchcancel.drag",v).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function p(a,s){if(!n&&i.call(this,a,s)){var l=x(this,o.call(this,a,s),a,s,"mouse");l&&(zg(a.view).on("mousemove.drag",f,Fg).on("mouseup.drag",m,Fg),Vg(a.view),Ng(a),r=!1,e=a.clientX,t=a.clientY,l("start",a))}}function f(n){if(Bg(n),!r){var i=n.clientX-e,o=n.clientY-t;r=i*i+o*o>d}l.mouse("drag",n)}function m(e){zg(e.view).on("mousemove.drag mouseup.drag",null),Ug(e.view,r),Bg(e),l.mouse("end",e)}function g(e,t){if(i.call(this,e,t)){var r,n,a=e.changedTouches,s=o.call(this,e,t),l=a.length;for(r=0;r{const{domNode:t,nodeDragThreshold:r}=c.getState();0===r&&w(e),b.current=!1;const n=_(e);p.current=n,m.current=t?.getBoundingClientRect()||null,g.current=Kv(e.sourceEvent,m.current)})).on("drag",(e=>{const t=_(e),{autoPanOnNodeDrag:r,nodeDragThreshold:i}=c.getState();if("touchmove"===e.sourceEvent.type&&e.sourceEvent.touches.length>1&&(b.current=!0),!b.current){if(!v.current&&x.current&&r&&(v.current=!0,u()),!x.current){const r=t.xSnapped-(p?.current?.x??0),n=t.ySnapped-(p?.current?.y??0);Math.sqrt(r*r+n*n)>i&&w(e)}(p.current.x!==t.xSnapped||p.current.y!==t.ySnapped)&&h.current&&x.current&&(y.current=e.sourceEvent,g.current=Kv(e.sourceEvent,m.current),n(t))}})).on("end",(e=>{if(x.current&&!b.current&&(d(!1),v.current=!1,x.current=!1,cancelAnimationFrame(f.current),h.current)){const{updateNodePositions:t,nodeInternals:r,onNodeDragStop:n,onSelectionDragStop:i}=c.getState(),o=a?n:h_(i);if(t(h.current,!1,!1),o){const[t,n]=l_({nodeId:a,dragItems:h.current,nodeInternals:r});o(e.sourceEvent,t,n)}}})).filter((e=>{const r=e.target;return!e.button&&(!i||!o_(r,`.${i}`,t))&&(!o||o_(r,o,t))}));return e.call(r),()=>{e.on(".drag",null)}}e.on(".drag",null)}}),[t,r,i,o,s,c,a,l,_]),u}function f_(){const e=Ev();return(0,n.useCallback)((t=>{const{nodeInternals:r,nodeExtent:n,updateNodePositions:i,getNodes:o,snapToGrid:a,snapGrid:s,onError:l,nodesDraggable:c}=e.getState(),u=o().filter((e=>e.selected&&(e.draggable||c&&"undefined"===typeof e.draggable))),d=a?s[0]:5,h=a?s[1]:5,p=t.isShiftPressed?4:1,f=t.x*d*p,m=t.y*h*p;i(u.map((e=>{if(e.positionAbsolute){const t={x:e.positionAbsolute.x+f,y:e.positionAbsolute.y+m};a&&(t.x=s[0]*Math.round(t.x/s[0]),t.y=s[1]*Math.round(t.y/s[1]));const{positionAbsolute:i,position:o}=s_(e,t,r,n,void 0,l);e.position=o,e.positionAbsolute=i}return e})),!0,!1)}),[])}const m_={ArrowUp:{x:0,y:-1},ArrowDown:{x:0,y:1},ArrowLeft:{x:-1,y:0},ArrowRight:{x:1,y:0}};var g_=e=>{const t=t=>{let{id:r,type:i,data:o,xPos:a,yPos:s,xPosOrigin:l,yPosOrigin:c,selected:u,onClick:d,onMouseEnter:h,onMouseMove:p,onMouseLeave:f,onContextMenu:m,onDoubleClick:g,style:y,className:v,isDraggable:x,isSelectable:b,isConnectable:_,isFocusable:w,selectNodesOnDrag:k,sourcePosition:S,targetPosition:A,hidden:T,resizeObserver:M,dragHandle:C,zIndex:E,isParent:I,noDragClassName:P,noPanClassName:O,initialized:R,disableKeyboardA11y:L,ariaLabel:D,rfId:z,hasHandleBounds:j}=t;const F=Ev(),N=(0,n.useRef)(null),B=(0,n.useRef)(null),V=(0,n.useRef)(S),U=(0,n.useRef)(A),H=(0,n.useRef)(i),$=b||x||d||h||p||f,W=f_(),q=u_(r,F.getState,h),G=u_(r,F.getState,p),Y=u_(r,F.getState,f),X=u_(r,F.getState,m),Z=u_(r,F.getState,g);(0,n.useEffect)((()=>()=>{B.current&&(M?.unobserve(B.current),B.current=null)}),[]),(0,n.useEffect)((()=>{if(N.current&&!T){const e=N.current;R&&j&&B.current===e||(B.current&&M?.unobserve(B.current),M?.observe(e),B.current=e)}}),[T,R,j]),(0,n.useEffect)((()=>{const e=H.current!==i,t=V.current!==S,n=U.current!==A;N.current&&(e||t||n)&&(e&&(H.current=i),t&&(V.current=S),n&&(U.current=A),F.getState().updateNodeDimensions([{id:r,nodeElement:N.current,forceUpdate:!0}]))}),[r,i,S,A]);const K=p_({nodeRef:N,disabled:T||!x,noDragClassName:P,handleSelector:C,nodeId:r,isSelectable:b,selectNodesOnDrag:k});return T?null:n.createElement("div",{className:lm(["react-flow__node",`react-flow__node-${i}`,{[O]:x},v,{selected:u,selectable:b,parent:I,dragging:K}]),ref:N,style:{zIndex:E,transform:`translate(${l}px,${c}px)`,pointerEvents:$?"all":"none",visibility:R?"visible":"hidden",...y},"data-id":r,"data-testid":`rf__node-${r}`,onMouseEnter:q,onMouseMove:G,onMouseLeave:Y,onContextMenu:X,onClick:e=>{const{nodeDragThreshold:t}=F.getState();if(b&&(!k||!x||t>0)&&d_({id:r,store:F,nodeRef:N}),d){const t=F.getState().nodeInternals.get(r);t&&d(e,{...t})}},onDoubleClick:Z,onKeyDown:w?e=>{if(!Xv(e)&&!L)if(Gv.includes(e.key)&&b){const t="Escape"===e.key;d_({id:r,store:F,unselect:t,nodeRef:N})}else x&&u&&Object.prototype.hasOwnProperty.call(m_,e.key)&&(F.setState({ariaLiveMessage:`Moved selected node ${e.key.replace("Arrow","").toLowerCase()}. New position, x: ${~~a}, y: ${~~s}`}),W({x:m_[e.key].x,y:m_[e.key].y,isShiftPressed:e.shiftKey}))}:void 0,tabIndex:w?0:void 0,role:w?"button":void 0,"aria-describedby":L?void 0:`${bb}-${z}`,"aria-label":D},n.createElement(Ix,{value:r},n.createElement(e,{id:r,data:o,type:i,xPos:a,yPos:s,selected:u,isConnectable:_,sourcePosition:S,targetPosition:A,dragging:K,dragHandle:C,zIndex:E})))};return t.displayName="NodeWrapper",(0,n.memo)(t)};const y_=e=>{const t=e.getNodes().filter((e=>e.selected));return{...Fx(t,e.nodeOrigin),transformString:`translate(${e.transform[0]}px,${e.transform[1]}px) scale(${e.transform[2]})`,userSelectionActive:e.userSelectionActive}};var v_=(0,n.memo)((function(e){let{onSelectionContextMenu:t,noPanClassName:r,disableKeyboardA11y:i}=e;const o=Ev(),{width:a,height:s,x:l,y:c,transformString:u,userSelectionActive:d}=Cv(y_,gm),h=f_(),p=(0,n.useRef)(null);if((0,n.useEffect)((()=>{i||p.current?.focus({preventScroll:!0})}),[i]),p_({nodeRef:p}),d||!a||!s)return null;const f=t?e=>{const r=o.getState().getNodes().filter((e=>e.selected));t(e,r)}:void 0;return n.createElement("div",{className:lm(["react-flow__nodesselection","react-flow__container",r]),style:{transform:u}},n.createElement("div",{ref:p,className:"react-flow__nodesselection-rect",onContextMenu:f,tabIndex:i?void 0:-1,onKeyDown:i?void 0:e=>{Object.prototype.hasOwnProperty.call(m_,e.key)&&h({x:m_[e.key].x,y:m_[e.key].y,isShiftPressed:e.shiftKey})},style:{width:a,height:s,top:c,left:l}}))}));const x_=e=>e.nodesSelectionActive,b_=e=>{let{children:t,onPaneClick:r,onPaneMouseEnter:i,onPaneMouseMove:o,onPaneMouseLeave:a,onPaneContextMenu:s,onPaneScroll:l,deleteKeyCode:c,onMove:u,onMoveStart:d,onMoveEnd:h,selectionKeyCode:p,selectionOnDrag:f,selectionMode:m,onSelectionStart:g,onSelectionEnd:y,multiSelectionKeyCode:v,panActivationKeyCode:x,zoomActivationKeyCode:b,elementsSelectable:_,zoomOnScroll:w,zoomOnPinch:k,panOnScroll:S,panOnScrollSpeed:A,panOnScrollMode:T,zoomOnDoubleClick:M,panOnDrag:C,defaultViewport:E,translateExtent:I,minZoom:P,maxZoom:O,preventScrolling:R,onSelectionContextMenu:L,noWheelClassName:D,noPanClassName:z,disableKeyboardA11y:j}=e;const F=Cv(x_),N=Ab(p),B=Ab(x),V=B||C,U=B||S,H=N||f&&!0!==V;return(e=>{let{deleteKeyCode:t,multiSelectionKeyCode:r}=e;const i=Ev(),{deleteElements:o}=Fb(),a=Ab(t,Nb),s=Ab(r);(0,n.useEffect)((()=>{if(a){const{edges:e,getNodes:t}=i.getState(),r=t().filter((e=>e.selected)),n=e.filter((e=>e.selected));o({nodes:r,edges:n}),i.setState({nodesSelectionActive:!1})}}),[a]),(0,n.useEffect)((()=>{i.setState({multiSelectionActive:s})}),[s])})({deleteKeyCode:c,multiSelectionKeyCode:v}),n.createElement(qb,{onMove:u,onMoveStart:d,onMoveEnd:h,onPaneContextMenu:s,elementsSelectable:_,zoomOnScroll:w,zoomOnPinch:k,panOnScroll:U,panOnScrollSpeed:A,panOnScrollMode:T,zoomOnDoubleClick:M,panOnDrag:!N&&V,defaultViewport:E,translateExtent:I,minZoom:P,maxZoom:O,zoomActivationKeyCode:b,preventScrolling:R,noWheelClassName:D,noPanClassName:z},n.createElement(n_,{onSelectionStart:g,onSelectionEnd:y,onPaneClick:r,onPaneMouseEnter:i,onPaneMouseMove:o,onPaneMouseLeave:a,onPaneContextMenu:s,onPaneScroll:l,panOnDrag:V,isSelecting:!!H,selectionMode:m},t,F&&n.createElement(v_,{onSelectionContextMenu:L,noPanClassName:z,disableKeyboardA11y:j})))};b_.displayName="FlowRenderer";var __=(0,n.memo)(b_);function w_(e){const t={input:g_(e.input||ib),default:g_(e.default||rb),output:g_(e.output||ab),group:g_(e.group||sb)},r=Object.keys(e).filter((e=>!["input","default","output","group"].includes(e))).reduce(((t,r)=>(t[r]=g_(e[r]||rb),t)),{});return{...t,...r}}const k_=e=>({nodesDraggable:e.nodesDraggable,nodesConnectable:e.nodesConnectable,nodesFocusable:e.nodesFocusable,elementsSelectable:e.elementsSelectable,updateNodeDimensions:e.updateNodeDimensions,onError:e.onError}),S_=e=>{const{nodesDraggable:t,nodesConnectable:r,nodesFocusable:i,elementsSelectable:o,updateNodeDimensions:a,onError:s}=Cv(k_,gm),l=(c=e.onlyRenderVisibleElements,Cv((0,n.useCallback)((e=>c?Nx(e.nodeInternals,{x:0,y:0,width:e.width,height:e.height},e.transform,!0):e.getNodes()),[c])));var c;const u=(0,n.useRef)(),d=(0,n.useMemo)((()=>{if("undefined"===typeof ResizeObserver)return null;const e=new ResizeObserver((e=>{const t=e.map((e=>({id:e.target.getAttribute("data-id"),nodeElement:e.target,forceUpdate:!0})));a(t)}));return u.current=e,e}),[]);return(0,n.useEffect)((()=>()=>{u?.current?.disconnect()}),[]),n.createElement("div",{className:"react-flow__nodes",style:Bb},l.map((a=>{let l=a.type||"default";e.nodeTypes[l]||(s?.("003",vv(l)),l="default");const c=e.nodeTypes[l]||e.nodeTypes.default,u=!!(a.draggable||t&&"undefined"===typeof a.draggable),h=!!(a.selectable||o&&"undefined"===typeof a.selectable),p=!!(a.connectable||r&&"undefined"===typeof a.connectable),f=!!(a.focusable||i&&"undefined"===typeof a.focusable),m=e.nodeExtent?zv(a.positionAbsolute,e.nodeExtent):a.positionAbsolute,g=m?.x??0,y=m?.y??0,v=(e=>{let{x:t,y:r,width:n,height:i,origin:o}=e;return n&&i?o[0]<0||o[1]<0||o[0]>1||o[1]>1?{x:t,y:r}:{x:t-n*o[0],y:r-i*o[1]}:{x:t,y:r}})({x:g,y:y,width:a.width??0,height:a.height??0,origin:e.nodeOrigin});return n.createElement(c,{key:a.id,id:a.id,className:a.className,style:a.style,type:l,data:a.data,sourcePosition:a.sourcePosition||px.Bottom,targetPosition:a.targetPosition||px.Top,hidden:a.hidden,xPos:g,yPos:y,xPosOrigin:v.x,yPosOrigin:v.y,selectNodesOnDrag:e.selectNodesOnDrag,onClick:e.onNodeClick,onMouseEnter:e.onNodeMouseEnter,onMouseMove:e.onNodeMouseMove,onMouseLeave:e.onNodeMouseLeave,onContextMenu:e.onNodeContextMenu,onDoubleClick:e.onNodeDoubleClick,selected:!!a.selected,isDraggable:u,isSelectable:h,isConnectable:p,isFocusable:f,resizeObserver:d,dragHandle:a.dragHandle,zIndex:a[qv]?.z??0,isParent:!!a[qv]?.isParent,noDragClassName:e.noDragClassName,noPanClassName:e.noPanClassName,initialized:!!a.width&&!!a.height,rfId:e.rfId,disableKeyboardA11y:e.disableKeyboardA11y,ariaLabel:a.ariaLabel,hasHandleBounds:!!a[qv]?.handleBounds})})))};S_.displayName="NodeRenderer";var A_=(0,n.memo)(S_);const T_=(e,t,r)=>r===px.Left?e-t:r===px.Right?e+t:e,M_=(e,t,r)=>r===px.Top?e-t:r===px.Bottom?e+t:e,C_="react-flow__edgeupdater",E_=e=>{let{position:t,centerX:r,centerY:i,radius:o=10,onMouseDown:a,onMouseEnter:s,onMouseOut:l,type:c}=e;return n.createElement("circle",{onMouseDown:a,onMouseEnter:s,onMouseOut:l,className:lm([C_,`${C_}-${c}`]),cx:T_(r,o,t),cy:M_(i,o,t),r:o,stroke:"transparent",fill:"transparent"})},I_=()=>!0;var P_=e=>{const t=t=>{let{id:r,className:i,type:o,data:a,onClick:s,onEdgeDoubleClick:l,selected:c,animated:u,label:d,labelStyle:h,labelShowBg:p,labelBgStyle:f,labelBgPadding:m,labelBgBorderRadius:g,style:y,source:v,target:x,sourceX:b,sourceY:_,targetX:w,targetY:k,sourcePosition:S,targetPosition:A,elementsSelectable:T,hidden:M,sourceHandleId:C,targetHandleId:E,onContextMenu:I,onMouseEnter:P,onMouseMove:O,onMouseLeave:R,reconnectRadius:L,onReconnect:D,onReconnectStart:z,onReconnectEnd:j,markerEnd:F,markerStart:N,rfId:B,ariaLabel:V,isFocusable:U,isReconnectable:H,pathOptions:$,interactionWidth:W,disableKeyboardA11y:q}=t;const G=(0,n.useRef)(null),[Y,X]=(0,n.useState)(!1),[Z,K]=(0,n.useState)(!1),J=Ev(),Q=(0,n.useMemo)((()=>`url('#${Rx(N,B)}')`),[N,B]),ee=(0,n.useMemo)((()=>`url('#${Rx(F,B)}')`),[F,B]);if(M)return null;const te=ex(r,J.getState,l),re=ex(r,J.getState,I),ne=ex(r,J.getState,P),ie=ex(r,J.getState,O),oe=ex(r,J.getState,R),ae=(e,t)=>{if(0!==e.button)return;const{edges:n,isValidConnection:i}=J.getState(),o=t?x:v,a=(t?E:C)||null,s=t?"target":"source",l=i||I_,c=t,u=n.find((e=>e.id===r));K(!0),z?.(e,u,s);Zx({event:e,handleId:a,nodeId:o,onConnect:e=>D?.(u,e),isTarget:c,getState:J.getState,setState:J.setState,isValidConnection:l,edgeUpdaterType:s,onReconnectEnd:e=>{K(!1),j?.(e,u,s)}})},se=()=>X(!0),le=()=>X(!1),ce=!T&&!s;return n.createElement("g",{className:lm(["react-flow__edge",`react-flow__edge-${o}`,i,{selected:c,animated:u,inactive:ce,updating:Y}]),onClick:e=>{const{edges:t,addSelectedEdges:n,unselectNodesAndEdges:i,multiSelectionActive:o}=J.getState(),a=t.find((e=>e.id===r));a&&(T&&(J.setState({nodesSelectionActive:!1}),a.selected&&o?(i({nodes:[],edges:[a]}),G.current?.blur()):n([r])),s&&s(e,a))},onDoubleClick:te,onContextMenu:re,onMouseEnter:ne,onMouseMove:ie,onMouseLeave:oe,onKeyDown:U?e=>{if(!q&&Gv.includes(e.key)&&T){const{unselectNodesAndEdges:t,addSelectedEdges:n,edges:i}=J.getState();"Escape"===e.key?(G.current?.blur(),t({edges:[i.find((e=>e.id===r))]})):n([r])}}:void 0,tabIndex:U?0:void 0,role:U?"button":"img","data-testid":`rf__edge-${r}`,"aria-label":null===V?void 0:V||`Edge from ${v} to ${x}`,"aria-describedby":U?`${_b}-${B}`:void 0,ref:G},!Z&&n.createElement(e,{id:r,source:v,target:x,selected:c,animated:u,label:d,labelStyle:h,labelShowBg:p,labelBgStyle:f,labelBgPadding:m,labelBgBorderRadius:g,data:a,style:y,sourceX:b,sourceY:_,targetX:w,targetY:k,sourcePosition:S,targetPosition:A,sourceHandleId:C,targetHandleId:E,markerStart:Q,markerEnd:ee,pathOptions:$,interactionWidth:W}),H&&n.createElement(n.Fragment,null,("source"===H||!0===H)&&n.createElement(E_,{position:S,centerX:b,centerY:_,radius:L,onMouseDown:e=>ae(e,!0),onMouseEnter:se,onMouseOut:le,type:"source"}),("target"===H||!0===H)&&n.createElement(E_,{position:A,centerX:w,centerY:k,radius:L,onMouseDown:e=>ae(e,!1),onMouseEnter:se,onMouseOut:le,type:"target"})))};return t.displayName="EdgeWrapper",(0,n.memo)(t)};function O_(e){const t={default:P_(e.default||Cx),straight:P_(e.bezier||Sx),step:P_(e.step||kx),smoothstep:P_(e.step||wx),simplebezier:P_(e.simplebezier||yx)},r=Object.keys(e).filter((e=>!["default","bezier"].includes(e))).reduce(((t,r)=>(t[r]=P_(e[r]||Cx),t)),{});return{...t,...r}}function R_(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null;const n=(r?.x||0)+t.x,i=(r?.y||0)+t.y,o=r?.width||t.width,a=r?.height||t.height;switch(e){case px.Top:return{x:n+o/2,y:i};case px.Right:return{x:n+o,y:i+a/2};case px.Bottom:return{x:n+o/2,y:i+a};case px.Left:return{x:n,y:i+a/2}}}function L_(e,t){return e?1!==e.length&&t?t&&e.find((e=>e.id===t))||null:e[0]:null}function D_(e){const t=e?.[qv]?.handleBounds||null,r=t&&e?.width&&e?.height&&"undefined"!==typeof e?.positionAbsolute?.x&&"undefined"!==typeof e?.positionAbsolute?.y;return[{x:e?.positionAbsolute?.x||0,y:e?.positionAbsolute?.y||0,width:e?.width||0,height:e?.height||0},t,!!r]}const z_=[{level:0,isMaxLevel:!0,edges:[]}];function j_(e,t,r){return function(e,t){let r=arguments.length>2&&void 0!==arguments[2]&&arguments[2],n=-1;const i=e.reduce(((e,i)=>{const o=Wv(i.zIndex);let a=o?i.zIndex:0;if(r){const e=t.get(i.target),r=t.get(i.source),n=i.selected||e?.selected||r?.selected,s=Math.max(r?.[qv]?.z||0,e?.[qv]?.z||0,1e3);a=(o?i.zIndex:0)+(n?s:0)}return e[a]?e[a].push(i):e[a]=[i],n=a>n?a:n,e}),{}),o=Object.entries(i).map((e=>{let[t,r]=e;const i=+t;return{edges:r,level:i,isMaxLevel:i===n}}));return 0===o.length?z_:o}(Cv((0,n.useCallback)((r=>e?r.edges.filter((e=>{const n=t.get(e.source),i=t.get(e.target);return n?.width&&n?.height&&i?.width&&i?.height&&function(e){let{sourcePos:t,targetPos:r,sourceWidth:n,sourceHeight:i,targetWidth:o,targetHeight:a,width:s,height:l,transform:c}=e;const u={x:Math.min(t.x,r.x),y:Math.min(t.y,r.y),x2:Math.max(t.x+n,r.x+o),y2:Math.max(t.y+i,r.y+a)};u.x===u.x2&&(u.x2+=1),u.y===u.y2&&(u.y2+=1);const d=Vv({x:(0-c[0])/c[2],y:(0-c[1])/c[2],width:s/c[2],height:l/c[2]}),h=Math.max(0,Math.min(d.x2,u.x2)-Math.max(d.x,u.x)),p=Math.max(0,Math.min(d.y2,u.y2)-Math.max(d.y,u.y));return Math.ceil(h*p)>0}({sourcePos:n.positionAbsolute||{x:0,y:0},targetPos:i.positionAbsolute||{x:0,y:0},sourceWidth:n.width,sourceHeight:n.height,targetWidth:i.width,targetHeight:i.height,width:r.width,height:r.height,transform:r.transform})})):r.edges),[e,t])),t,r)}const F_={[dx.Arrow]:e=>{let{color:t="none",strokeWidth:r=1}=e;return n.createElement("polyline",{style:{stroke:t,strokeWidth:r},strokeLinecap:"round",strokeLinejoin:"round",fill:"none",points:"-5,-4 0,0 -5,4"})},[dx.ArrowClosed]:e=>{let{color:t="none",strokeWidth:r=1}=e;return n.createElement("polyline",{style:{stroke:t,fill:t,strokeWidth:r},strokeLinecap:"round",strokeLinejoin:"round",points:"-5,-4 0,0 -5,4 -5,-4"})}};const N_=e=>{let{id:t,type:r,color:i,width:o=12.5,height:a=12.5,markerUnits:s="strokeWidth",strokeWidth:l,orient:c="auto-start-reverse"}=e;const u=function(e){const t=Ev();return(0,n.useMemo)((()=>Object.prototype.hasOwnProperty.call(F_,e)?F_[e]:(t.getState().onError?.("009",wv(e)),null)),[e])}(r);return u?n.createElement("marker",{className:"react-flow__arrowhead",id:t,markerWidth:`${o}`,markerHeight:`${a}`,viewBox:"-10 -10 20 20",markerUnits:s,orient:c,refX:"0",refY:"0"},n.createElement(u,{color:i,strokeWidth:l})):null},B_=e=>{let{defaultColor:t,rfId:r}=e;const i=Cv((0,n.useCallback)((e=>{let{defaultColor:t,rfId:r}=e;return e=>{const n=[];return e.edges.reduce(((e,i)=>([i.markerStart,i.markerEnd].forEach((i=>{if(i&&"object"===typeof i){const o=Rx(i,r);n.includes(o)||(e.push({id:o,color:i.color||t,...i}),n.push(o))}})),e)),[]).sort(((e,t)=>e.id.localeCompare(t.id)))}})({defaultColor:t,rfId:r}),[t,r]),((e,t)=>!(e.length!==t.length||e.some(((e,r)=>e.id!==t[r].id)))));return n.createElement("defs",null,i.map((e=>n.createElement(N_,{id:e.id,key:e.id,type:e.type,color:e.color,width:e.width,height:e.height,markerUnits:e.markerUnits,strokeWidth:e.strokeWidth,orient:e.orient}))))};B_.displayName="MarkerDefinitions";var V_=(0,n.memo)(B_);const U_=e=>({nodesConnectable:e.nodesConnectable,edgesFocusable:e.edgesFocusable,edgesUpdatable:e.edgesUpdatable,elementsSelectable:e.elementsSelectable,width:e.width,height:e.height,connectionMode:e.connectionMode,nodeInternals:e.nodeInternals,onError:e.onError}),H_=e=>{let{defaultMarkerColor:t,onlyRenderVisibleElements:r,elevateEdgesOnSelect:i,rfId:o,edgeTypes:a,noPanClassName:s,onEdgeContextMenu:l,onEdgeMouseEnter:c,onEdgeMouseMove:u,onEdgeMouseLeave:d,onEdgeClick:h,onEdgeDoubleClick:p,onReconnect:f,onReconnectStart:m,onReconnectEnd:g,reconnectRadius:y,children:v,disableKeyboardA11y:x}=e;const{edgesFocusable:b,edgesUpdatable:_,elementsSelectable:w,width:k,height:S,connectionMode:A,nodeInternals:T,onError:M}=Cv(U_,gm),C=j_(r,T,i);return k?n.createElement(n.Fragment,null,C.map((e=>{let{level:r,edges:i,isMaxLevel:v}=e;return n.createElement("svg",{key:r,style:{zIndex:r},width:k,height:S,className:"react-flow__edges react-flow__container"},v&&n.createElement(V_,{defaultColor:t,rfId:o}),n.createElement("g",null,i.map((e=>{const[t,r,i]=D_(T.get(e.source)),[v,k,S]=D_(T.get(e.target));if(!i||!S)return null;let C=e.type||"default";a[C]||(M?.("011",Av(C)),C="default");const E=a[C]||a.default,I=A===nx.Strict?k.target:(k.target??[]).concat(k.source??[]),P=L_(r.source,e.sourceHandle),O=L_(I,e.targetHandle),R=P?.position||px.Bottom,L=O?.position||px.Top,D=!!(e.focusable||b&&"undefined"===typeof e.focusable),z=e.reconnectable||e.updatable,j="undefined"!==typeof f&&(z||_&&"undefined"===typeof z);if(!P||!O)return M?.("008",kv(P,e)),null;const{sourceX:F,sourceY:N,targetX:B,targetY:V}=((e,t,r,n,i,o)=>{const a=R_(r,e,t),s=R_(o,n,i);return{sourceX:a.x,sourceY:a.y,targetX:s.x,targetY:s.y}})(t,P,R,v,O,L);return n.createElement(E,{key:e.id,id:e.id,className:lm([e.className,s]),type:C,data:e.data,selected:!!e.selected,animated:!!e.animated,hidden:!!e.hidden,label:e.label,labelStyle:e.labelStyle,labelShowBg:e.labelShowBg,labelBgStyle:e.labelBgStyle,labelBgPadding:e.labelBgPadding,labelBgBorderRadius:e.labelBgBorderRadius,style:e.style,source:e.source,target:e.target,sourceHandleId:e.sourceHandle,targetHandleId:e.targetHandle,markerEnd:e.markerEnd,markerStart:e.markerStart,sourceX:F,sourceY:N,targetX:B,targetY:V,sourcePosition:R,targetPosition:L,elementsSelectable:w,onContextMenu:l,onMouseEnter:c,onMouseMove:u,onMouseLeave:d,onClick:h,onEdgeDoubleClick:p,onReconnect:f,onReconnectStart:m,onReconnectEnd:g,reconnectRadius:y,rfId:o,ariaLabel:e.ariaLabel,isFocusable:D,isReconnectable:j,pathOptions:"pathOptions"in e?e.pathOptions:void 0,interactionWidth:e.interactionWidth,disableKeyboardA11y:x})}))))})),v):null};H_.displayName="EdgeRenderer";var $_=(0,n.memo)(H_);const W_=e=>`translate(${e.transform[0]}px,${e.transform[1]}px) scale(${e.transform[2]})`;function q_(e){let{children:t}=e;const r=Cv(W_);return n.createElement("div",{className:"react-flow__viewport react-flow__container",style:{transform:r}},t)}const G_={[px.Left]:px.Right,[px.Right]:px.Left,[px.Top]:px.Bottom,[px.Bottom]:px.Top},Y_=e=>{let{nodeId:t,handleType:r,style:i,type:o=cx.Bezier,CustomComponent:a,connectionStatus:s}=e;const{fromNode:l,handleId:c,toX:u,toY:d,connectionMode:h}=Cv((0,n.useCallback)((e=>({fromNode:e.nodeInternals.get(t),handleId:e.connectionHandleId,toX:(e.connectionPosition.x-e.transform[0])/e.transform[2],toY:(e.connectionPosition.y-e.transform[1])/e.transform[2],connectionMode:e.connectionMode})),[t]),gm),p=l?.[qv]?.handleBounds;let f=p?.[r];if(h===nx.Loose&&(f=f||p?.["source"===r?"target":"source"]),!l||!f)return null;const m=c?f.find((e=>e.id===c)):f[0],g=m?m.x+m.width/2:(l.width??0)/2,y=m?m.y+m.height/2:l.height??0,v=(l.positionAbsolute?.x??0)+g,x=(l.positionAbsolute?.y??0)+y,b=m?.position,_=b?G_[b]:null;if(!b||!_)return null;if(a)return n.createElement(a,{connectionLineType:o,connectionLineStyle:i,fromNode:l,fromHandle:m,fromX:v,fromY:x,toX:u,toY:d,fromPosition:b,toPosition:_,connectionStatus:s});let w="";const k={sourceX:v,sourceY:x,sourcePosition:b,targetX:u,targetY:d,targetPosition:_};return o===cx.Bezier?[w]=Mx(k):o===cx.Step?[w]=_x({...k,borderRadius:0}):o===cx.SmoothStep?[w]=_x(k):o===cx.SimpleBezier?[w]=gx(k):w=`M${v},${x} ${u},${d}`,n.createElement("path",{d:w,fill:"none",className:"react-flow__connection-path",style:i})};Y_.displayName="ConnectionLine";const X_=e=>({nodeId:e.connectionNodeId,handleType:e.connectionHandleType,nodesConnectable:e.nodesConnectable,connectionStatus:e.connectionStatus,width:e.width,height:e.height});function Z_(e){let{containerStyle:t,style:r,type:i,component:o}=e;const{nodeId:a,handleType:s,nodesConnectable:l,width:c,height:u,connectionStatus:d}=Cv(X_,gm);return!!(a&&s&&c&&l)?n.createElement("svg",{style:t,width:c,height:u,className:"react-flow__edges react-flow__connectionline react-flow__container"},n.createElement("g",{className:lm(["react-flow__connection",d])},n.createElement(Y_,{nodeId:a,handleType:s,style:r,type:i,CustomComponent:o,connectionStatus:d}))):null}function K_(e,t){(0,n.useRef)(null),Ev();return(0,n.useMemo)((()=>t(e)),[e])}const J_=e=>{let{nodeTypes:t,edgeTypes:r,onMove:i,onMoveStart:o,onMoveEnd:a,onInit:s,onNodeClick:l,onEdgeClick:c,onNodeDoubleClick:u,onEdgeDoubleClick:d,onNodeMouseEnter:h,onNodeMouseMove:p,onNodeMouseLeave:f,onNodeContextMenu:m,onSelectionContextMenu:g,onSelectionStart:y,onSelectionEnd:v,connectionLineType:x,connectionLineStyle:b,connectionLineComponent:_,connectionLineContainerStyle:w,selectionKeyCode:k,selectionOnDrag:S,selectionMode:A,multiSelectionKeyCode:T,panActivationKeyCode:M,zoomActivationKeyCode:C,deleteKeyCode:E,onlyRenderVisibleElements:I,elementsSelectable:P,selectNodesOnDrag:O,defaultViewport:R,translateExtent:L,minZoom:D,maxZoom:z,preventScrolling:j,defaultMarkerColor:F,zoomOnScroll:N,zoomOnPinch:B,panOnScroll:V,panOnScrollSpeed:U,panOnScrollMode:H,zoomOnDoubleClick:$,panOnDrag:W,onPaneClick:q,onPaneMouseEnter:G,onPaneMouseMove:Y,onPaneMouseLeave:X,onPaneScroll:Z,onPaneContextMenu:K,onEdgeContextMenu:J,onEdgeMouseEnter:Q,onEdgeMouseMove:ee,onEdgeMouseLeave:te,onReconnect:re,onReconnectStart:ne,onReconnectEnd:ie,reconnectRadius:oe,noDragClassName:ae,noWheelClassName:se,noPanClassName:le,elevateEdgesOnSelect:ce,disableKeyboardA11y:ue,nodeOrigin:de,nodeExtent:he,rfId:pe}=e;const fe=K_(t,w_),me=K_(r,O_);return function(e){const t=Fb(),r=(0,n.useRef)(!1);(0,n.useEffect)((()=>{!r.current&&t.viewportInitialized&&e&&(setTimeout((()=>e(t)),1),r.current=!0)}),[e,t.viewportInitialized])}(s),n.createElement(__,{onPaneClick:q,onPaneMouseEnter:G,onPaneMouseMove:Y,onPaneMouseLeave:X,onPaneContextMenu:K,onPaneScroll:Z,deleteKeyCode:E,selectionKeyCode:k,selectionOnDrag:S,selectionMode:A,onSelectionStart:y,onSelectionEnd:v,multiSelectionKeyCode:T,panActivationKeyCode:M,zoomActivationKeyCode:C,elementsSelectable:P,onMove:i,onMoveStart:o,onMoveEnd:a,zoomOnScroll:N,zoomOnPinch:B,zoomOnDoubleClick:$,panOnScroll:V,panOnScrollSpeed:U,panOnScrollMode:H,panOnDrag:W,defaultViewport:R,translateExtent:L,minZoom:D,maxZoom:z,onSelectionContextMenu:g,preventScrolling:j,noDragClassName:ae,noWheelClassName:se,noPanClassName:le,disableKeyboardA11y:ue},n.createElement(q_,null,n.createElement($_,{edgeTypes:me,onEdgeClick:c,onEdgeDoubleClick:d,onlyRenderVisibleElements:I,onEdgeContextMenu:J,onEdgeMouseEnter:Q,onEdgeMouseMove:ee,onEdgeMouseLeave:te,onReconnect:re,onReconnectStart:ne,onReconnectEnd:ie,reconnectRadius:oe,defaultMarkerColor:F,noPanClassName:le,elevateEdgesOnSelect:!!ce,disableKeyboardA11y:ue,rfId:pe},n.createElement(Z_,{style:b,type:x,component:_,containerStyle:w})),n.createElement("div",{className:"react-flow__edgelabel-renderer"}),n.createElement(A_,{nodeTypes:fe,onNodeClick:l,onNodeDoubleClick:u,onNodeMouseEnter:h,onNodeMouseMove:p,onNodeMouseLeave:f,onNodeContextMenu:m,selectNodesOnDrag:O,onlyRenderVisibleElements:I,noPanClassName:le,noDragClassName:ae,disableKeyboardA11y:ue,nodeOrigin:de,nodeExtent:he,rfId:pe})))};J_.displayName="GraphView";var Q_=(0,n.memo)(J_);const ew=[[Number.NEGATIVE_INFINITY,Number.NEGATIVE_INFINITY],[Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY]],tw={rfId:"1",width:0,height:0,transform:[0,0,1],nodeInternals:new Map,edges:[],onNodesChange:null,onEdgesChange:null,hasDefaultNodes:!1,hasDefaultEdges:!1,d3Zoom:null,d3Selection:null,d3ZoomHandler:void 0,minZoom:.5,maxZoom:2,translateExtent:ew,nodeExtent:ew,nodesSelectionActive:!1,userSelectionActive:!1,userSelectionRect:null,connectionNodeId:null,connectionHandleId:null,connectionHandleType:"source",connectionPosition:{x:0,y:0},connectionStatus:null,connectionMode:nx.Strict,domNode:null,paneDragging:!1,noPanClassName:"nopan",nodeOrigin:[0,0],nodeDragThreshold:0,snapGrid:[15,15],snapToGrid:!1,nodesDraggable:!0,nodesConnectable:!0,nodesFocusable:!0,edgesFocusable:!0,edgesUpdatable:!0,elementsSelectable:!0,elevateNodesOnSelect:!0,fitViewOnInit:!1,fitViewOnInitDone:!1,fitViewOnInitOptions:void 0,onSelectionChange:[],multiSelectionActive:!1,connectionStartHandle:null,connectionEndHandle:null,connectionClickStartHandle:null,connectOnClick:!0,ariaLiveMessage:"",autoPanOnConnect:!0,autoPanOnNodeDrag:!0,connectionRadius:20,onError:Yv,isValidConnection:void 0},rw=()=>{return e=(e,t)=>({...tw,setNodes:r=>{const{nodeInternals:n,nodeOrigin:i,elevateNodesOnSelect:o}=t();e({nodeInternals:Ib(r,n,i,o)})},getNodes:()=>Array.from(t().nodeInternals.values()),setEdges:r=>{const{defaultEdgeOptions:n={}}=t();e({edges:r.map((e=>({...n,...e})))})},setDefaultNodesAndEdges:(r,n)=>{const i="undefined"!==typeof r,o="undefined"!==typeof n,a=i?Ib(r,new Map,t().nodeOrigin,t().elevateNodesOnSelect):new Map;e({nodeInternals:a,edges:o?n:[],hasDefaultNodes:i,hasDefaultEdges:o})},updateNodeDimensions:r=>{const{onNodesChange:n,nodeInternals:i,fitViewOnInit:o,fitViewOnInitDone:a,fitViewOnInitOptions:s,domNode:l,nodeOrigin:c}=t(),u=l?.querySelector(".react-flow__viewport");if(!u)return;const d=window.getComputedStyle(u),{m22:h}=new window.DOMMatrixReadOnly(d.transform),p=r.reduce(((e,t)=>{const r=i.get(t.id);if(r?.hidden)i.set(r.id,{...r,[qv]:{...r[qv],handleBounds:void 0}});else if(r){const n=Lv(t.nodeElement);n.width&&n.height&&(r.width!==n.width||r.height!==n.height||t.forceUpdate)&&(i.set(r.id,{...r,[qv]:{...r[qv],handleBounds:{source:c_(".source",t.nodeElement,h,c),target:c_(".target",t.nodeElement,h,c)}},...n}),e.push({id:r.id,type:"dimensions",dimensions:n}))}return e}),[]);Eb(i,c);const f=a||o&&!a&&Pb(t,{initial:!0,...s});e({nodeInternals:new Map(i),fitViewOnInitDone:f}),p?.length>0&&n?.(p)},updateNodePositions:function(e){let r=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];const{triggerNodeChanges:i}=t();i(e.map((e=>{const t={id:e.id,type:"position",dragging:n};return r&&(t.positionAbsolute=e.positionAbsolute,t.position=e.position),t})))},triggerNodeChanges:r=>{const{onNodesChange:n,nodeInternals:i,hasDefaultNodes:o,nodeOrigin:a,getNodes:s,elevateNodesOnSelect:l}=t();if(r?.length){if(o){const t=Ib(Kb(r,s()),i,a,l);e({nodeInternals:t})}n?.(r)}},addSelectedNodes:r=>{const{multiSelectionActive:n,edges:i,getNodes:o}=t();let a,s=null;n?a=r.map((e=>Qb(e,!0))):(a=e_(o(),r),s=e_(i,[])),Lb({changedNodes:a,changedEdges:s,get:t,set:e})},addSelectedEdges:r=>{const{multiSelectionActive:n,edges:i,getNodes:o}=t();let a,s=null;n?a=r.map((e=>Qb(e,!0))):(a=e_(i,r),s=e_(o(),[])),Lb({changedNodes:s,changedEdges:a,get:t,set:e})},unselectNodesAndEdges:function(){let{nodes:r,edges:n}=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const{edges:i,getNodes:o}=t(),a=n||i;Lb({changedNodes:(r||o()).map((e=>(e.selected=!1,Qb(e.id,!1)))),changedEdges:a.map((e=>Qb(e.id,!1))),get:t,set:e})},setMinZoom:r=>{const{d3Zoom:n,maxZoom:i}=t();n?.scaleExtent([r,i]),e({minZoom:r})},setMaxZoom:r=>{const{d3Zoom:n,minZoom:i}=t();n?.scaleExtent([i,r]),e({maxZoom:r})},setTranslateExtent:r=>{t().d3Zoom?.translateExtent(r),e({translateExtent:r})},resetSelectedElements:()=>{const{edges:r,getNodes:n}=t();Lb({changedNodes:n().filter((e=>e.selected)).map((e=>Qb(e.id,!1))),changedEdges:r.filter((e=>e.selected)).map((e=>Qb(e.id,!1))),get:t,set:e})},setNodeExtent:r=>{const{nodeInternals:n}=t();n.forEach((e=>{e.positionAbsolute=zv(e.position,r)})),e({nodeExtent:r,nodeInternals:new Map(n)})},panBy:e=>{const{transform:r,width:n,height:i,d3Zoom:o,d3Selection:a,translateExtent:s}=t();if(!o||!a||!e.x&&!e.y)return!1;const l=tv.translate(r[0]+e.x,r[1]+e.y).scale(r[2]),c=[[0,0],[n,i]],u=o?.constrain()(l,c,s);return o.transform(a,u),r[0]!==u.x||r[1]!==u.y||r[2]!==u.k},cancelConnection:()=>e({connectionNodeId:tw.connectionNodeId,connectionHandleId:tw.connectionHandleId,connectionHandleType:tw.connectionHandleType,connectionStatus:tw.connectionStatus,connectionStartHandle:tw.connectionStartHandle,connectionEndHandle:tw.connectionEndHandle}),reset:()=>e({...tw})}),t=Object.is,e?mm(e,t):mm;var e,t},nw=e=>{let{children:t}=e;const r=(0,n.useRef)(null);return r.current||(r.current=rw()),n.createElement(yv,{value:r.current},t)};nw.displayName="ReactFlowProvider";const iw=e=>{let{children:t}=e;return(0,n.useContext)(gv)?n.createElement(n.Fragment,null,t):n.createElement(nw,null,t)};iw.displayName="ReactFlowWrapper";const ow={input:ib,default:rb,output:ab,group:sb},aw={default:Cx,straight:Sx,step:kx,smoothstep:wx,simplebezier:yx},sw=[0,0],lw=[15,15],cw={x:0,y:0,zoom:1},uw={width:"100%",height:"100%",overflow:"hidden",position:"relative",zIndex:0},dw=(0,n.forwardRef)(((e,t)=>{let{nodes:r,edges:i,defaultNodes:o,defaultEdges:a,className:s,nodeTypes:l=ow,edgeTypes:c=aw,onNodeClick:u,onEdgeClick:d,onInit:h,onMove:p,onMoveStart:f,onMoveEnd:m,onConnect:g,onConnectStart:y,onConnectEnd:v,onClickConnectStart:x,onClickConnectEnd:b,onNodeMouseEnter:_,onNodeMouseMove:w,onNodeMouseLeave:k,onNodeContextMenu:S,onNodeDoubleClick:A,onNodeDragStart:T,onNodeDrag:M,onNodeDragStop:C,onNodesDelete:E,onEdgesDelete:I,onSelectionChange:P,onSelectionDragStart:O,onSelectionDrag:R,onSelectionDragStop:L,onSelectionContextMenu:D,onSelectionStart:z,onSelectionEnd:j,connectionMode:F=nx.Strict,connectionLineType:N=cx.Bezier,connectionLineStyle:B,connectionLineComponent:V,connectionLineContainerStyle:U,deleteKeyCode:H="Backspace",selectionKeyCode:$="Shift",selectionOnDrag:W=!1,selectionMode:q=sx.Full,panActivationKeyCode:G="Space",multiSelectionKeyCode:Y=(Jv()?"Meta":"Control"),zoomActivationKeyCode:X=(Jv()?"Meta":"Control"),snapToGrid:Z=!1,snapGrid:K=lw,onlyRenderVisibleElements:J=!1,selectNodesOnDrag:Q=!0,nodesDraggable:ee,nodesConnectable:te,nodesFocusable:re,nodeOrigin:ne=sw,edgesFocusable:ie,edgesUpdatable:oe,elementsSelectable:ae,defaultViewport:se=cw,minZoom:le=.5,maxZoom:ce=2,translateExtent:ue=ew,preventScrolling:de=!0,nodeExtent:he,defaultMarkerColor:pe="#b1b1b7",zoomOnScroll:fe=!0,zoomOnPinch:me=!0,panOnScroll:ge=!1,panOnScrollSpeed:ye=.5,panOnScrollMode:ve=ox.Free,zoomOnDoubleClick:xe=!0,panOnDrag:be=!0,onPaneClick:_e,onPaneMouseEnter:we,onPaneMouseMove:ke,onPaneMouseLeave:Se,onPaneScroll:Ae,onPaneContextMenu:Te,children:Me,onEdgeContextMenu:Ce,onEdgeDoubleClick:Ee,onEdgeMouseEnter:Ie,onEdgeMouseMove:Pe,onEdgeMouseLeave:Oe,onEdgeUpdate:Re,onEdgeUpdateStart:Le,onEdgeUpdateEnd:De,onReconnect:ze,onReconnectStart:je,onReconnectEnd:Fe,reconnectRadius:Ne=10,edgeUpdaterRadius:Be=10,onNodesChange:Ve,onEdgesChange:Ue,noDragClassName:He="nodrag",noWheelClassName:$e="nowheel",noPanClassName:We="nopan",fitView:qe=!1,fitViewOptions:Ge,connectOnClick:Ye=!0,attributionPosition:Xe,proOptions:Ze,defaultEdgeOptions:Ke,elevateNodesOnSelect:Je=!0,elevateEdgesOnSelect:Qe=!1,disableKeyboardA11y:et=!1,autoPanOnConnect:tt=!0,autoPanOnNodeDrag:rt=!0,connectionRadius:nt=20,isValidConnection:it,onError:ot,style:at,id:st,nodeDragThreshold:lt,...ct}=e;const ut=st||"1";return n.createElement("div",{...ct,style:{...at,...uw},ref:t,className:lm(["react-flow",s]),"data-testid":"rf__wrapper",id:st},n.createElement(iw,null,n.createElement(Q_,{onInit:h,onMove:p,onMoveStart:f,onMoveEnd:m,onNodeClick:u,onEdgeClick:d,onNodeMouseEnter:_,onNodeMouseMove:w,onNodeMouseLeave:k,onNodeContextMenu:S,onNodeDoubleClick:A,nodeTypes:l,edgeTypes:c,connectionLineType:N,connectionLineStyle:B,connectionLineComponent:V,connectionLineContainerStyle:U,selectionKeyCode:$,selectionOnDrag:W,selectionMode:q,deleteKeyCode:H,multiSelectionKeyCode:Y,panActivationKeyCode:G,zoomActivationKeyCode:X,onlyRenderVisibleElements:J,selectNodesOnDrag:Q,defaultViewport:se,translateExtent:ue,minZoom:le,maxZoom:ce,preventScrolling:de,zoomOnScroll:fe,zoomOnPinch:me,zoomOnDoubleClick:xe,panOnScroll:ge,panOnScrollSpeed:ye,panOnScrollMode:ve,panOnDrag:be,onPaneClick:_e,onPaneMouseEnter:we,onPaneMouseMove:ke,onPaneMouseLeave:Se,onPaneScroll:Ae,onPaneContextMenu:Te,onSelectionContextMenu:D,onSelectionStart:z,onSelectionEnd:j,onEdgeContextMenu:Ce,onEdgeDoubleClick:Ee,onEdgeMouseEnter:Ie,onEdgeMouseMove:Pe,onEdgeMouseLeave:Oe,onReconnect:ze??Re,onReconnectStart:je??Le,onReconnectEnd:Fe??De,reconnectRadius:Ne??Be,defaultMarkerColor:pe,noDragClassName:He,noWheelClassName:$e,noPanClassName:We,elevateEdgesOnSelect:Qe,rfId:ut,disableKeyboardA11y:et,nodeOrigin:ne,nodeExtent:he}),n.createElement(yb,{nodes:r,edges:i,defaultNodes:o,defaultEdges:a,onConnect:g,onConnectStart:y,onConnectEnd:v,onClickConnectStart:x,onClickConnectEnd:b,nodesDraggable:ee,nodesConnectable:te,nodesFocusable:re,edgesFocusable:ie,edgesUpdatable:oe,elementsSelectable:ae,elevateNodesOnSelect:Je,minZoom:le,maxZoom:ce,nodeExtent:he,onNodesChange:Ve,onEdgesChange:Ue,snapToGrid:Z,snapGrid:K,connectionMode:F,translateExtent:ue,connectOnClick:Ye,defaultEdgeOptions:Ke,fitView:qe,fitViewOptions:Ge,onNodesDelete:E,onEdgesDelete:I,onNodeDragStart:T,onNodeDrag:M,onNodeDragStop:C,onSelectionDrag:R,onSelectionDragStart:O,onSelectionDragStop:L,noPanClassName:We,nodeOrigin:ne,rfId:ut,autoPanOnConnect:tt,autoPanOnNodeDrag:rt,onError:ot,connectionRadius:nt,isValidConnection:it,nodeDragThreshold:lt}),n.createElement(pb,{onSelectionChange:P}),Me,n.createElement(Ov,{proOptions:Ze,position:Xe}),n.createElement(Sb,{rfId:ut,disableKeyboardA11y:et})))}));dw.displayName="ReactFlow";function hw(e){return t=>{const[r,i]=(0,n.useState)(t),o=(0,n.useCallback)((t=>i((r=>e(t,r)))),[]);return[r,i,o]}}hw(Kb),hw(Jb);const pw="flowElement",fw="input",mw="algorithm";function gw(e){return null!=e&&Px(e)&&null!=e.data}function yw(e){var t;return gw(e)&&(null===(t=e.data)||void 0===t?void 0:t.type)===mw}function vw(e){return Array.isArray(e)?0===e.length?"":1===e.length?xw(e[0]):xw(e[0])+` ... and ${e.length-1} files`:xw(e)}function xw(e){return e.split("/").reverse()[0]}function bw(e){return function(e){var t;return gw(e)&&(null===(t=e.data)||void 0===t?void 0:t.type)===fw}(e)}function _w(e){return yw(e)}const ww="input_0",kw={border:"1px solid #777",height:140,width:250,padding:0,borderRadius:0},Sw={border:"1px solid #777",height:140,width:250},Aw={height:"13%",width:"3%",border:"1px solid",borderColor:"#555",borderRadius:0,top:15},Tw="ImageFileNode",Mw="CsvFileNode",Cw="HDF5FileNode",Ew="FluoFileNode",Iw="AlgorithmNode",Pw="BehaviorFileNode",Ow="MatlabFileNode",Rw="MicroscopeFileNode",Lw={IMAGE:"image",CSV:"csv",HDF5:"hdf5",FLUO:"fluo",BEHAVIOR:"behavior",MATLAB:"matlab",MICROSCOPE:"microscope",ALL:"all"};const Dw="filesTree",zw=jl(`${Dw}/getFilesTree`,(async(e,t)=>{let{workspaceId:r,fileType:n}=e;try{const e=await async function(e,t){return(await wd.get(`${bd}/files/${e}`,{params:{file_type:t}})).data}(r,n);return e}catch(ene){return t.rejectWithValue(ene)}})),jw=jl(`${Dw}/deleteFile`,(async(e,t)=>{let{workspaceId:r,fileName:n}=e;if(!r)return t.rejectWithValue("workspace id does not exist.");try{const e=await async function(e,t){return(await wd.delete(`${bd}/files/${e}/delete/${t}`)).data}(r,n);return e}catch(ene){return t.rejectWithValue(ene)}})),Fw="fileUploader",Nw=Al(`${Fw}/setUploadProgress`),Bw=(Al(`${Fw}/setDownloadProgress`),jl(`${Fw}/uploadFile`,(async(e,t)=>{let{workspaceId:r,requestId:n,fileName:i,formData:o}=e;try{const e=(a=(e,r)=>{t.dispatch(Nw({requestId:n,progress:e,total:r}))},{onUploadProgress:function(e){if(e.total){const t=Math.round(100*e.loaded/e.total);a(t,e.total)}else a(0,100)}}),s=await async function(e,t,r,n){return(await wd.post(`${bd}/files/${e}/upload/${t}`,n,r)).data}(r,i,e,o);return{resultPath:s.file_path}}catch(ene){return t.rejectWithValue(ene)}var a})));const Vw=jl(`${Fw}/updateShape`,(async(e,t)=>{let{workspaceId:r,fileName:n}=e;const{dispatch:i}=t;try{const e=await async function(e,t){return(await wd.post(`${bd}/files/${e}/shape/${t}`)).data}(r,n);return i(zw({workspaceId:r,fileType:"image"})),e}catch(ene){return t.rejectWithValue(ene)}})),Uw=jl(`${Fw}/uploadFileViaUrl`,(async(e,t)=>{const{workspaceId:r,url:n}=e;try{const e=await(async(e,t)=>(await wd.post(`${bd}/files/${e}/download`,{url:t})).data)(r,n);return e}catch(ene){return t.rejectWithValue(ene)}})),Hw=jl(`${Fw}/getStatusLoadViaUrl`,(async(e,t)=>{const{workspaceId:r,file_name:n,requestId:i}=e;try{const e=await(async(e,t)=>(await wd.get(`${bd}/files/${e}/download/status?file_name=${t}`)).data)(r,n);return t.dispatch(Nw({requestId:i,progress:e.current/e.total*100,total:e.total})),e}catch(ene){return t.rejectWithValue(ene)}}));async function $w(e){return(await wd.get(`${bd}/params/${e}`)).data}const Ww=jl(`${pw}/addAlgorithmNode`,(async(e,t)=>{let{name:r}=e;try{return await $w(r)}catch(ene){return t.rejectWithValue(ene)}})),qw=Al(`${pw}/addInputNode`),Gw="inputNode",Yw="csv",Xw="image",Zw="hdf5",Kw="fluo",Jw="behavior",Qw="matlab",ek="microscope",tk=Al(`${Gw}/setInputNodeFilePath`);const rk="workflow",nk=jl(`${rk}/fetchExperiment`,(async(e,t)=>{try{return await async function(e){return(await wd.get(`${bd}/workflow/fetch/${e}`)).data}(e)}catch(ene){return t.rejectWithValue(ene)}})),ik=jl(`${rk}/reproduceWorkflow`,(async(e,t)=>{let{workspaceId:r,uid:n}=e;try{const e=await async function(e,t){return(await wd.get(`${bd}/workflow/reproduce/${e}/${t}`)).data}(r,n);return e}catch(ene){return t.rejectWithValue(ene)}})),ok=jl(`${rk}/importWorkflowConfig`,(async(e,t)=>{let{formData:r}=e;try{const e=await async function(e){return(await wd.post(`${bd}/workflow/import`,e)).data}(r);return e}catch(ene){return t.rejectWithValue(ene)}})),ak=jl(`${rk}/importSampleData`,(async(e,t)=>{let{workspaceId:r}=e;try{return await async function(e){return(await wd.get(`${bd}/workflow/sample_data/${e}`)).data}(r)}catch(ene){return t.rejectWithValue(ene)}})),sk=[{id:ww,type:Tw,data:{type:fw,label:"NoName"},style:Sw,position:{x:50,y:150}}],lk=[0,0,.7],ck={x:100,y:150},uk={flowNodes:sk,flowEdges:[],flowPosition:lk,elementCoord:ck,loading:!1},dk=Pl({name:pw,initialState:uk,reducers:{clearFlowElements:e=>{e.flowNodes=Kb(e.flowNodes.map((e=>({id:e.id,type:"remove"}))),e.flowNodes),e.flowNodes=sk,e.flowEdges=Jb(e.flowEdges.map((e=>({id:e.id,type:"remove"}))),e.flowEdges),e.flowPosition=lk,e.elementCoord=ck},setFlowPosition:(e,t)=>{e.flowPosition=t.payload},setFlowNodes:(e,t)=>{e.flowNodes=t.payload},setFlowEdges:(e,t)=>{e.flowEdges=t.payload},deleteFlowNodes:(e,t)=>{e.flowNodes=Kb(t.payload.map((e=>({id:e.id,type:"remove"}))),e.flowNodes)},setNodesChange:(e,t)=>{e.flowNodes=Kb(t.payload,e.flowNodes)},setEdgesChange:(e,t)=>{e.flowEdges=Jb(t.payload,e.flowEdges)},deleteFlowEdgeById:(e,t)=>{const r=e.flowEdges.find((e=>e.id===t.payload));void 0!==r&&(e.flowEdges=Jb([{id:r.id,type:"remove"}],e.flowEdges))},deleteFlowNodeById:(e,t)=>{const r=e.flowNodes.find((e=>e.id===t.payload));void 0!==r&&(e.flowNodes=Kb([{id:r.id,type:"remove"}],e.flowNodes),e.flowEdges=Jb(e.flowEdges.filter((e=>e.source===t.payload||e.target===t.payload)).map((e=>({id:e.id,type:"remove"}))),e.flowEdges))},editFlowNodePositionById:(e,t)=>{const{nodeId:r,coord:n}=t.payload,i=e.flowNodes.findIndex((e=>e.id===r));e.flowNodes[i].position=n}},extraReducers:e=>e.addCase(Ww.fulfilled,((e,t)=>{var r;let{node:n}=t.meta.arg;(null===(r=n.data)||void 0===r?void 0:r.type)===mw&&(n={...n,style:{...n.style,...kw},targetPosition:px.Left,sourcePosition:px.Right}),null!=n.position?e.flowNodes.push({...n,position:n.position}):(e.flowNodes.push({...n,position:e.elementCoord}),hk(e))})).addCase(qw,((e,t)=>{var r;let{node:n}=t.payload;(null===(r=n.data)||void 0===r?void 0:r.type)===fw&&(n={...n,style:{...n.style,...Sw},targetPosition:px.Left,sourcePosition:px.Right}),null!=n.position?e.flowNodes.push({...n,position:n.position}):(e.flowNodes.push({...n,position:e.elementCoord}),hk(e))})).addCase(tk,((e,t)=>{const{nodeId:r,filePath:n}=t.payload,i=vw(n),o=e.flowNodes.findIndex((e=>e.id===r)),a=e.flowNodes[o];null!=a.data&&(a.data.label=i)})).addCase(Bw.fulfilled,((e,t)=>{const{nodeId:r}=t.meta.arg;if(null!=r){const n=e.flowNodes.findIndex((e=>e.id===r)),i=e.flowNodes[n];null!=i.data&&(i.data.label=vw(t.payload.resultPath))}})).addCase(nk.pending,(e=>{e.loading=!0})).addCase(ik.pending,(e=>{e.loading=!0})).addCase(nk.rejected,(()=>uk)).addCase(ik.rejected,(e=>{e.loading=!1})).addMatcher(Bl(ik.fulfilled,ok.fulfilled,nk.fulfilled),((e,t)=>{e.flowPosition=lk,e.elementCoord=ck,e.flowNodes=Object.values(t.payload.nodeDict).map((e=>{var t,r,n,i,o,a,s,l;return bw(e)?{...e,data:{label:null!==(t=null===(r=e.data)||void 0===r?void 0:r.label)&&void 0!==t?t:"",type:null!==(n=null===(i=e.data)||void 0===i?void 0:i.type)&&void 0!==n?n:"input"},style:Sw}:{...e,data:{label:null!==(o=null===(a=e.data)||void 0===a?void 0:a.label)&&void 0!==o?o:"",type:null!==(s=null===(l=e.data)||void 0===l?void 0:l.type)&&void 0!==s?s:"algorithm"},style:kw}})),e.flowEdges=Object.values(t.payload.edgeDict),e.loading=!1}))});function hk(e){const{x:t}=e.elementCoord;var r,n;t>800?(e.elementCoord.x=300,e.elementCoord.y+=100):(e.elementCoord.x+=250,e.elementCoord.y+=(r=-20,n=20,Math.random()*(n-r)+r))}const{clearFlowElements:pk,setNodesChange:fk,setEdgesChange:mk,setFlowPosition:gk,setFlowNodes:yk,setFlowEdges:vk,deleteFlowNodes:xk,deleteFlowEdgeById:bk,deleteFlowNodeById:_k,editFlowNodePositionById:wk}=dk.actions,kk=dk.reducer;const Sk="pipeline",Ak="StartUninitialized",Tk="StartPending",Mk="StartError",Ck="StartSuccess",Ek="Finished",Ik="Aborted",Pk="Canceled",Ok={SUCCESS:"success",ERROR:"error",PENDING:"pending"},Rk={RUN_NEW:1,RUN_ALREADY:2},Lk={[Rk.RUN_NEW]:"RUN ALL",[Rk.RUN_ALREADY]:"RUN"};function Dk(e){switch(e){case"images":return Yf;case"timeseries":return qf;case"heatmap":return Gf;case"roi":return Zf;case"scatter":return Kf;case"bar":return Jf;case"html":return em;case"histogram":return nm;case"line":return im;case"pie":return om;case"polar":return am;default:throw new Error(`failed to map dataType: ${e}`)}}function zk(e){return e.status===Ok.PENDING}function jk(e){return e.status===Ok.SUCCESS}function Fk(e){return e.status===Ck||e.status===Ek||e.status===Ik}function Nk(e){const t={};return Object.values(e.nodeDict).filter((e=>{let{data:t}=e;return(null===t||void 0===t?void 0:t.type)===mw})).forEach((e=>{var r;let{id:n,data:i}=e;t[n]={status:Ok.PENDING,name:null!==(r=null===i||void 0===i?void 0:i.label)&&void 0!==r?r:""}})),t}function Bk(e){const t={};return Object.entries(e).forEach((e=>{let[r,n]=e;const i=n.outputPaths;"success"===n.status&&null!=i?t[r]={status:Ok.SUCCESS,message:n.message,name:n.name,outputPaths:Vk(i)}:"running"===n.status?t[r]={status:Ok.PENDING,name:n.name}:t[r]={status:Ok.ERROR,message:n.message,name:n.name}})),t}function Vk(e){const t={};return Object.entries(e).forEach((e=>{let[r,n]=e;t[r]={path:n.path,type:Dk(n.type)}})),t}const Uk=e=>{var t;return null===(t=e.pipeline.currentPipeline)||void 0===t?void 0:t.uid},Hk=e=>{const t=Uk(e);if(t){const r=e.experiments;return"fulfilled"===r.status?r.experimentList[t].name:void 0}},$k=e=>e.pipeline.run,Wk=e=>e.pipeline.runBtn;function qk(e){return zk(e.nodeResult)}const Gk=e=>$k(e).status,Yk=e=>$k(e).status===Pk,Xk=e=>$k(e).status===Ck;function Zk(e){return jk(e.nodeResult)}const Kk=e=>t=>{const r=$k(t);return Fk(r)&&Object.keys(r.runResult).includes(e)?r.runResult[e].status:null},Jk=e=>t=>{const r=$k(t);if(Fk(r)){const t=r.runResult[e];if(Object.keys(r.runResult).includes(e)&&jk(t))return t.outputPaths}throw new Error(`key error. nodeId:${e}`)},Qk=jl(`${Sk}/run`,(async(e,t)=>{let{runPostData:r}=e;const n=jf(t.getState());if(!n)return t.rejectWithValue("workspace id does not exist.");try{const e=await async function(e,t){return(await wd.post(`${bd}/run/${e}`,t)).data}(n,r);return e}catch(ene){return t.rejectWithValue(ene)}})),eS=jl(`${Sk}/runByCurrentUid`,(async(e,t)=>{let{runPostData:r}=e;const n=jf(t.getState()),i=Uk(t.getState());if(!n||null==i)return t.rejectWithValue("workspaceId or currentUid dose not exist.");try{const e=await async function(e,t,r){return(await wd.post(`${bd}/run/${e}/${t}`,r)).data}(n,i,r);return e}catch(ene){return t.rejectWithValue(ene)}})),tS=jl(`${Sk}/pollRunResult`,(async(e,t)=>{let{uid:r}=e;const n=(e=>{const t=$k(e);return Fk(t)?Object.entries(t.runResult).map((e=>{let[t,r]=e;return{nodeId:t,nodeResult:r}})).filter(qk).map((e=>{let{nodeId:t}=e;return t})):[]})(t.getState()),i=jf(t.getState());if(!i)return t.rejectWithValue("workspace id does not exist");try{const e=await async function(e){const{workspaceId:t,uid:r,pendingNodeIdList:n}=e;return(await wd.post(`${bd}/run/result/${t}/${r}`,{pendingNodeIdList:n})).data}({workspaceId:i,uid:r,pendingNodeIdList:n});return e}catch(ene){return t.rejectWithValue(ene)}})),rS=jl(`${Sk}/cancelResult`,(async(e,t)=>{let{uid:r}=e;const n=jf(t.getState());if(!n)return t.rejectWithValue("workspace id does not exist");try{const e=await async function(e){const{workspaceId:t,uid:r}=e;return(await wd.post(`${bd}/run/cancel/${t}/${r}`)).data}({workspaceId:n,uid:r});return e}catch(ene){return t.rejectWithValue(ene)}}));const nS=jl(`${Wf}/getTimeSeriesInitData`,(async(e,t)=>{let{path:r}=e;try{const e=await async function(e){return(await wd.get(`${bd}/outputs/inittimedata/${e}`)).data}(r);return e}catch(ene){return t.rejectWithValue(ene)}})),iS=jl(`${Wf}/getTimeSeriesDataById`,(async(e,t)=>{let{path:r,index:n}=e;try{const e=await async function(e,t){return(await wd.get(`${bd}/outputs/timedata/${e}`,{params:{index:t}})).data}(r,n);return e}catch(ene){return t.rejectWithValue(ene)}})),oS=jl(`${Wf}/getTimeSeriesAllData`,(async(e,t)=>{let{path:r}=e;try{const e=await async function(e){return(await wd.get(`${bd}/outputs/alltimedata/${e}`)).data}(r);return e}catch(ene){return t.rejectWithValue(ene)}})),aS=jl(`${Wf}/getHeatMapData`,(async(e,t)=>{let{path:r}=e;try{const e=await async function(e){return(await wd.get(`${bd}/outputs/data/${e}`)).data}(r);return e}catch(ene){return t.rejectWithValue(ene)}})),sS=jl(`${Wf}/getImageData`,(async(e,t)=>{let{path:r,startIndex:n,endIndex:i,workspaceId:o}=e;try{const e=await async function(e,t){return(await wd.get(`${bd}/outputs/image/${e}`,{params:{workspace_id:t.workspaceId,start_index:t.startIndex,end_index:t.endIndex}})).data}(r,{workspaceId:o,startIndex:n,endIndex:i});return e}catch(ene){return t.rejectWithValue(ene)}})),lS=jl(`${Wf}/getCsvData`,(async(e,t)=>{let{path:r,workspaceId:n}=e;try{const e=await async function(e,t){return(await wd.get(`${bd}/outputs/csv/${e}`,{params:{workspace_id:t.workspaceId}})).data}(r,{workspaceId:n});return e}catch(ene){return t.rejectWithValue(ene)}})),cS=(jl(`${Wf}/getMatlabData`,(async(e,t)=>{let{path:r,workspaceId:n}=e;try{const e=await async function(e,t){return(await wd.get(`${bd}/outputs/matlab/${e}`,{params:{workspace_id:t.workspaceId}})).data}(r,{workspaceId:n});return e}catch(ene){return t.rejectWithValue(ene)}})),jl(`${Wf}/getRoiData`,(async(e,t)=>{let{path:r,workspaceId:n}=e;try{const e=await async function(e,t){return(await wd.get(`${bd}/outputs/image/${e}`,{params:{workspace_id:t.workspaceId}})).data}(r,{workspaceId:n});return e}catch(ene){return t.rejectWithValue(ene)}}))),uS=jl(`${Wf}/cancelRoi`,(async(e,t)=>{let{path:r,workspaceId:n}=e;try{const e=await async function(e,t){return(await wd.post(`${bd}/outputs/image/${e}/cancel_edit?workspace_id=${t}`)).data}(r,n);return e}catch(ene){return t.rejectWithValue(ene)}})),dS=jl(`${Wf}/addRoi`,(async(e,t)=>{let{path:r,workspaceId:n,data:i}=e;const{dispatch:o}=t;try{const e=await async function(e,t,r){return(await wd.post(`${bd}/outputs/image/${e}/add_roi?workspace_id=${t}`,r)).data}(r,n,i);return await o(mS({path:r,workspaceId:n})),await o(cS({path:r,workspaceId:n})),e}catch(ene){return t.rejectWithValue(ene)}})),hS=jl(`${Wf}/mergeROi`,(async(e,t)=>{let{path:r,workspaceId:n,data:i}=e;const{dispatch:o}=t;try{const e=await async function(e,t,r){return(await wd.post(`${bd}/outputs/image/${e}/merge_roi?workspace_id=${t}`,r)).data}(r,n,i);return o(mS({path:r,workspaceId:n})),e}catch(ene){return t.rejectWithValue(ene)}})),pS=jl(`${Wf}/deleteRoi`,(async(e,t)=>{let{path:r,workspaceId:n,data:i}=e;const{dispatch:o}=t;try{const e=await async function(e,t,r){return(await wd.post(`${bd}/outputs/image/${e}/delete_roi?workspace_id=${t}`,r)).data}(r,n,i);return o(mS({path:r,workspaceId:n})),e}catch(ene){return t.rejectWithValue(ene)}})),fS=jl(`${Wf}/commitRoi`,(async(e,t)=>{let{path:r,workspaceId:n}=e;const{dispatch:i}=t;try{const e=await async function(e,t){return(await wd.post(`${bd}/outputs/image/${e}/commit_edit?workspace_id=${t}`)).data}(r,n);return i(mS({path:r,workspaceId:n})),e}catch(ene){return t.rejectWithValue(ene)}})),mS=jl(`${Wf}/getStatusRoi`,(async(e,t)=>{let{path:r,workspaceId:n}=e;try{const e=await async function(e,t){return(await wd.post(`${bd}/outputs/image/${e}/status?workspace_id=${t}`)).data}(r,n);return e}catch(ene){return t.rejectWithValue(ene)}})),gS=jl(`${Wf}/getScatterData`,(async(e,t)=>{let{path:r}=e;try{const e=await async function(e){return(await wd.get(`${bd}/outputs/data/${e}`,{})).data}(r);return e}catch(ene){return t.rejectWithValue(ene)}})),yS=jl(`${Wf}/getBarData`,(async(e,t)=>{let{path:r}=e;try{const e=await async function(e){return(await wd.get(`${bd}/outputs/data/${e}`,{})).data}(r);return e}catch(ene){return t.rejectWithValue(ene)}})),vS=jl(`${Wf}/getHTMLData`,(async(e,t)=>{let{path:r}=e;try{const e=await async function(e){return(await wd.get(`${bd}/outputs/html/${e}`,{})).data}(r);return e}catch(ene){return t.rejectWithValue(ene)}})),xS=jl(`${Wf}/getHistogramData`,(async(e,t)=>{let{path:r}=e;try{const e=await async function(e){return(await wd.get(`${bd}/outputs/data/${e}`,{})).data}(r);return e}catch(ene){return t.rejectWithValue(ene)}})),bS=jl(`${Wf}/getLineData`,(async(e,t)=>{let{path:r}=e;try{const e=await async function(e){return(await wd.get(`${bd}/outputs/data/${e}`,{})).data}(r);return e}catch(ene){return t.rejectWithValue(ene)}})),_S=jl(`${Wf}/getPieData`,(async(e,t)=>{let{path:r}=e;try{const e=await async function(e){return(await wd.get(`${bd}/outputs/data/${e}`,{})).data}(r);return e}catch(ene){return t.rejectWithValue(ene)}})),wS=jl(`${Wf}/getPolarData`,(async(e,t)=>{let{path:r}=e;try{const e=await async function(e){return(await wd.get(`${bd}/outputs/data/${e}`,{})).data}(r);return e}catch(ene){return t.rejectWithValue(ene)}})),kS=e=>e.displayData,SS=e=>e.displayData.loading,AS=e=>e.displayData.isEditRoiCommitting,TS=e=>t=>kS(t).timeSeries[e].data,MS=e=>t=>Object.keys(kS(t).timeSeries).includes(e),CS=e=>t=>Object.keys(kS(t).heatMap).includes(e),ES=e=>t=>kS(t).image[e],IS=e=>t=>Object.keys(kS(t).image).includes(e),PS=e=>t=>IS(e)(t)&&kS(t).image[e].pending,OS=e=>t=>Object.keys(kS(t).csv).includes(e),RS=e=>t=>OS(e)(t)?kS(t).csv[e].error:null,LS=e=>t=>OS(e)(t)&&kS(t).csv[e].pending,DS=e=>t=>OS(e)(t)&&kS(t).csv[e].fulfilled,zS=e=>t=>{var r,n;return null!==(r=null===(n=kS(t).roi[e])||void 0===n?void 0:n.data[0])&&void 0!==r?r:[]},jS=e=>t=>Object.keys(kS(t).roi).includes(e),FS=e=>t=>jS(e)(t)&&kS(t).roi[e].fulfilled,NS=e=>t=>Object.keys(kS(t).scatter).includes(e),BS=e=>t=>Object.keys(kS(t).bar).includes(e),VS=e=>t=>Object.keys(kS(t).html).includes(e),US=e=>t=>Object.keys(kS(t).histogram).includes(e),HS=e=>t=>Object.keys(kS(t).line).includes(e),$S=e=>t=>Object.keys(kS(t).pie).includes(e),WS=e=>t=>Object.keys(kS(t).polar).includes(e),qS=e=>e.displayData.statusRoi,GS="visualaizeItem",YS="displayData";function XS(e){return e.itemType===YS}function ZS(e){return e.itemType===YS&&e.dataType===Yf}function KS(e){return e.itemType===YS&&e.dataType===qf}function JS(e){return e.itemType===YS&&e.dataType===Xf}function QS(e){return e.itemType===YS&&e.dataType===Gf}function eA(e){return e.itemType===YS&&e.dataType===Kf}function tA(e){return e.itemType===YS&&e.dataType===Jf}function rA(e){return e.itemType===YS&&e.dataType===nm}function nA(e){return e.itemType===YS&&e.dataType===im}function iA(e){return e.itemType===YS&&e.dataType===am}const oA=e=>e.visualaizeItem.selectedItemId,aA=e=>Object.keys(e.visualaizeItem.items).map(Number).filter((t=>{const r=lA(t)(e);return ZS(r)&&!r.isWorkflowDialog})),sA=e=>e.visualaizeItem.items,lA=e=>t=>t.visualaizeItem.items[e],cA=e=>e.visualaizeItem.layout,uA=e=>t=>lA(e)(t).width,dA=e=>t=>lA(e)(t).height,hA=e=>t=>{const r=lA(e)(t);if(XS(r))return r.dataType;throw new Error("invalid VisualaizeItemType")},pA=e=>t=>{const r=lA(e)(t);if(XS(r))return r.nodeId;throw new Error("invalid VisualaizeItemType")},fA=e=>t=>{const r=lA(e)(t);if(XS(r))return r.filePath;throw new Error("invalid VisualaizeItemType")},mA=e=>t=>lA(e)(t).saveFileName,gA=e=>t=>lA(e)(t).saveFormat,yA=e=>t=>{const r=lA(e)(t);if(XS(r))return r.filePath;throw new Error("invalid VisualaizeItemType")},vA=e=>t=>{const r=lA(e)(t);if(XS(r))return r.filePath;throw new Error("invalid VisualaizeItemType")},xA=e=>t=>{const r=lA(e)(t);var n,i;if(ZS(r))return null!==(n=null===(i=r.roiItem)||void 0===i?void 0:i.filePath)&&void 0!==n?n:null;throw new Error("invalid VisualaizeItemType")},bA=e=>t=>{const r=lA(e)(t);if(ZS(r))return r.showticklabels;throw new Error("invalid VisualaizeItemType")},_A=e=>t=>{const r=lA(e)(t);if(ZS(r))return r.zsmooth;throw new Error("invalid VisualaizeItemType")},wA=e=>t=>{const r=lA(e)(t);if(ZS(r))return r.startIndex;throw new Error("invalid VisualaizeItemType")},kA=e=>t=>{const r=lA(e)(t);if(ZS(r))return r.endIndex;throw new Error("invalid VisualaizeItemType")},SA=e=>t=>{const r=lA(e)(t);if(ZS(r))return r.showline;throw new Error("invalid VisualaizeItemType")},AA=e=>t=>{const r=lA(e)(t);if(ZS(r))return r.showgrid;throw new Error("invalid VisualaizeItemType")},TA=e=>t=>{const r=lA(e)(t);if(ZS(r))return r.showscale;throw new Error("invalid VisualaizeItemType")},MA=e=>t=>{const r=lA(e)(t);if(ZS(r))return r.colors;throw new Error("invalid VisualaizeItemType")},CA=e=>t=>{const r=lA(e)(t);if(ZS(r))return r.alpha;throw new Error("invalid VisualaizeItemType")},EA=e=>t=>{const r=lA(e)(t);if(ZS(r))return r.roiAlpha;throw new Error("invalid VisualaizeItemType")},IA=e=>t=>{const r=lA(e)(t);if(KS(r))return r.stdBool;throw new Error("invalid VisualaizeItemType")},PA=e=>t=>{const r=lA(e)(t);if(KS(r))return r.span;throw new Error("invalid VisualaizeItemType")},OA=e=>t=>{const r=lA(e)(t);if(KS(r))return r.showgrid;throw new Error("invalid VisualaizeItemType")},RA=e=>t=>{const r=lA(e)(t);if(KS(r))return r.showline;throw new Error("invalid VisualaizeItemType")},LA=e=>t=>{const r=lA(e)(t);if(KS(r))return r.showticklabels;throw new Error("invalid VisualaizeItemType")},DA=e=>t=>{const r=lA(e)(t);if(KS(r))return r.zeroline;throw new Error("invalid VisualaizeItemType")},zA=e=>t=>{const r=lA(e)(t);if(KS(r))return r.xrange;throw new Error("invalid VisualaizeItemType")},jA=e=>t=>{const r=lA(e)(t);if(KS(r))return r.drawOrderList;throw new Error("invalid VisualaizeItemType")},FA=e=>t=>{const r=lA(e)(t);if(KS(r)){if(null!=r.refImageItemId){var n;const e=sA(t)[r.refImageItemId];if(ZS(e)&&null!=(null===(n=e.roiItem)||void 0===n?void 0:n.filePath))return(i=e.roiItem.filePath,e=>FS(i)(e)?kS(e).roi[i].roiUniqueList:null)(t)}return null}throw new Error("invalid VisualaizeItemType");var i},NA=e=>t=>{if(KS(lA(e)(t))){const r=vA(e)(t);if(null!=r&&MS(r)(t)){const n=Object.keys(TS(r)(t)),i=FA(e)(t);return null!=i?n.filter((e=>i.includes(e))):n}return[]}throw new Error("invalid VisualaizeItemType")},BA=e=>t=>{const r=zS(e)(t);return 0!==r.length?Math.max(...r.map((e=>Math.max(...e)))):0},VA=e=>t=>{const r=lA(e)(t);if(QS(r))return r.showscale;throw new Error("invalid VisualaizeItemType")},UA=e=>t=>{const r=lA(e)(t);if(QS(r))return r.colors;throw new Error("invalid VisualaizeItemType")},HA=e=>t=>{const r=lA(e)(t);if(JS(r))return r.transpose;throw new Error("invalid VisualaizeItemType")},$A=e=>t=>{const r=lA(e)(t);if(JS(r))return r.setHeader;throw new Error("invalid VisualaizeItemType")},WA=e=>t=>{const r=lA(e)(t);if(JS(r))return r.setIndex;throw new Error("invalid VisualaizeItemType")},qA=e=>t=>{const r=lA(e)(t);if(tA(r))return r.index;throw new Error("invalid VisualaizeItemType")},GA=e=>t=>{const r=lA(e)(t);if(eA(r))return r.xIndex;throw new Error("invalid VisualaizeItemType")},YA=e=>t=>{const r=lA(e)(t);if(eA(r))return r.yIndex;throw new Error("invalid VisualaizeItemType")},XA=e=>t=>{const r=sA(t),n=r[e].filePath;return 1===Object.values(r).filter((e=>e.filePath===n)).length},ZA=e=>t=>{const r=lA(e)(t);if(rA(r))return r.bins;throw new Error("invalid VisualaizeItemType")},KA=e=>t=>{const r=lA(e)(t);if(nA(r))return r.selectedIndex;throw new Error("invalid VisualaizeItemType")},JA=e=>t=>{const r=lA(e)(t);if(iA(r))return r.selectedIndex;throw new Error("invalid VisualaizeItemType")},QA=e=>t=>{const r=lA(e)(t);if(KS(r))return r.rangeUnit;throw new Error("invalid VisualaizeItemType")},eT=jl(`${GS}/setImageItemClikedDataId`,((e,t)=>{let{itemId:r,clickedDataId:n}=e;const i=sA(t.getState());Object.values(i).forEach((e=>{KS(e)&&null!=e.filePath&&e.refImageItemId===r&&!e.drawOrderList.includes(n)&&t.dispatch(iS({path:e.filePath,index:n}))}))})),tT=jl(`${GS}/selectingImageArea`,((e,t)=>{let{itemId:r,range:n}=e;const{x:i,y:o}=n,[a,s]=i.map(Math.round),[l,c]=o.map(Math.round),u=[],d=sA(t.getState()),h=d[r];if(ZS(h)&&null!=h.roiItem){const e=h.roiItem.filePath;if(null!=e){const n=zS(e)(t.getState());for(let e=a;e<=s;e++)for(let t=l;t<=c;t++){const r=n[t][e];if(null!=r){const e=String(r);u.includes(e)||u.push(e)}}Object.values(d).forEach((e=>{if(KS(e)&&null!=e.filePath&&e.refImageItemId===r){const r=e.filePath;u.forEach((e=>{t.dispatch(iS({path:r,index:String(e)}))}))}}))}}return u})),rT=Al(`${GS}/deleteDisplayItem`),nT=Al(`${GS}/setNewDisplayDataPath`),iT={items:{},selectedItemId:null,layout:[]},oT={itemType:YS,filePath:null,nodeId:null,width:500,height:500,isWorkflowDialog:!1,saveFileName:"newPlot",saveFormat:"png"},aT={...oT,dataType:Yf,startIndex:1,endIndex:10,showticklabels:!1,showline:!0,zsmooth:"best",showgrid:!1,showscale:!1,colors:[{rgb:"rgb(0, 0, 0)",offset:"0"},{rgb:"rgb(255, 255, 255)",offset:"1.0"}],activeIndex:0,alpha:1,roiItem:null,roiAlpha:1,duration:500},sT={...oT,dataType:qf,stdBool:!1,span:5,showgrid:!0,showline:!0,showticklabels:!0,zeroline:!1,xrange:{left:void 0,right:void 0},rangeUnit:"frames",maxIndex:0,drawOrderList:[],refImageItemId:null},lT={...oT,dataType:Gf,showscale:!0,colors:[{rgb:"rgb(0, 0, 255)",offset:"0"},{rgb:"rgb(200, 200, 200)",offset:"0.5"},{rgb:"rgb(255, 0, 0)",offset:"1.0"}]},cT={...oT,dataType:Xf,setHeader:null,setIndex:!1,transpose:!1},uT={...oT,dataType:Zf},dT={...oT,dataType:Kf,xIndex:"0",yIndex:"1"},hT={...oT,dataType:Jf,index:"0"},pT={...oT,dataType:Qf},fT={...oT,dataType:em},mT={...oT,dataType:tm},gT={...oT,dataType:rm},yT={...oT,dataType:nm,bins:20},vT={...oT,dataType:im,selectedIndex:0},xT={...oT,dataType:om},bT={...oT,dataType:am,selectedIndex:0},_T={...oT,dataType:sm,setHeader:null,setIndex:!1,transpose:!1};function wT(e){switch(e){case Yf:return aT;case Gf:return lT;case qf:return sT;case Xf:return cT;case Zf:return uT;case Kf:return dT;case Jf:return hT;case Qf:return pT;case em:return fT;case tm:return mT;case rm:return gT;case nm:return yT;case im:return vT;case om:return xT;case am:return bT;case sm:return _T}}const kT=Pl({name:GS,initialState:iT,reducers:{changeRangeUnit:(e,t)=>{const r=e.items[t.payload.itemId];KS(r)&&(r.rangeUnit=t.payload.rangeUnit)},pushInitialItemToNewRow:e=>{const t=AT(e);e.layout.push([t])},insertInitialItemToNextColumn:(e,t)=>{const r=AT(e),n=t.payload,i=e.layout.findIndex((e=>e.includes(n))),o=e.layout[i].indexOf(n);e.layout[i].splice(o+1,0,r)},addItemForWorkflowDialog:(e,t)=>{const{nodeId:r,filePath:n,dataType:i}=t.payload,o=ST(e),a=null!=o?o+1:0;e.items[a]={...wT(i),isWorkflowDialog:!0,nodeId:r,filePath:n}},deleteAllItemForWorkflowDialog:e=>{Object.entries(e.items).filter((e=>{let[t,r]=e;return r.isWorkflowDialog})).map((e=>{let[t,r]=e;return Number(t)})).forEach((t=>delete e.items[t]))},setItemSize:(e,t)=>{const{itemId:r,width:n,height:i}=t.payload,o=e.items[r];o.width=n,o.height=i},selectItem:(e,t)=>{e.selectedItemId=t.payload},reset:e=>{e.items=iT.items,e.layout=iT.layout,e.selectedItemId=iT.selectedItemId},setRoiItemFilePath:(e,t)=>{const{itemId:r,filePath:n,nodeId:i,outputKey:o}=t.payload,a=e.items[r];ZS(a)&&(Object.values(e.items).forEach((e=>{KS(e)&&null!=e.filePath&&e.refImageItemId===r&&(e.drawOrderList=[])})),null!=a.roiItem?(a.roiItem.filePath=n,a.roiItem.nodeId=i,a.roiItem.outputKey=o):a.roiItem={...uT,filePath:n,nodeId:i,outputKey:o})},setFilePath:(e,t)=>{const{itemId:r,filePath:n,nodeId:i}=t.payload,o=e.items[r];if(!XS(o))throw new Error("error");o.filePath=n,o.nodeId=i},setSaveFormat:(e,t)=>{e.items[t.payload.itemId].saveFormat=t.payload.saveFormat},setSaveFileName:(e,t)=>{e.items[t.payload.itemId].saveFileName=t.payload.saveFileName},setImageItemFilePath:(e,t)=>{const{itemId:r,filePath:n,nodeId:i}=t.payload,o=e.items[r];ZS(o)&&(o.filePath=n,o.nodeId=i)},setTimeSeriesItemFilePath:(e,t)=>{const{itemId:r,filePath:n,nodeId:i}=t.payload,o=e.items[r];KS(o)&&(o.filePath=n,o.nodeId=i)},setHeatMapItemFilePath:(e,t)=>{const{itemId:r,filePath:n,nodeId:i}=t.payload,o=e.items[r];QS(o)&&(o.filePath=n,o.nodeId=i)},resetImageActiveIndex:(e,t)=>{TT(e,t.payload)},incrementImageActiveIndex:(e,t)=>{const{itemId:r}=t.payload,n=e.items[r];ZS(n)&&n.activeIndex++},decrementImageActiveIndex:(e,t)=>{const{itemId:r}=t.payload,n=e.items[r];ZS(n)&&n.activeIndex--},setImageActiveIndex:(e,t)=>{const{itemId:r,activeIndex:n}=t.payload,i=e.items[r];ZS(i)&&(i.activeIndex=n)},setImageItemShowticklabels:(e,t)=>{const r=e.items[t.payload.itemId];ZS(r)&&(r.showticklabels=t.payload.showticklabels)},setImageItemZsmooth:(e,t)=>{const r=e.items[t.payload.itemId];ZS(r)&&(r.zsmooth=t.payload.zsmooth)},setImageItemShowLine:(e,t)=>{const r=e.items[t.payload.itemId];ZS(r)&&(r.showline=t.payload.showline)},setImageItemShowGrid:(e,t)=>{const r=e.items[t.payload.itemId];ZS(r)&&(r.showgrid=t.payload.showgrid)},setImageItemShowScale:(e,t)=>{const r=e.items[t.payload.itemId];ZS(r)&&(r.showscale=t.payload.showscale)},setImageItemColors:(e,t)=>{const r=e.items[t.payload.itemId];ZS(r)&&(r.colors=t.payload.colors)},setImageItemStartIndex:(e,t)=>{const r=e.items[t.payload.itemId];ZS(r)&&(r.startIndex=t.payload.startIndex)},setImageItemEndIndex:(e,t)=>{const r=e.items[t.payload.itemId];ZS(r)&&(r.endIndex=t.payload.endIndex)},setImageItemAlpha:(e,t)=>{const r=e.items[t.payload.itemId];ZS(r)&&(r.alpha=t.payload.alpha)},setImageItemRoiAlpha:(e,t)=>{const r=e.items[t.payload.itemId];ZS(r)&&(r.roiAlpha=t.payload.roiAlpha)},setImageItemDuration:(e,t)=>{const r=e.items[t.payload.itemId];ZS(r)&&(r.duration=t.payload.duration)},setTimeSeriesItemOffset:(e,t)=>{const r=e.items[t.payload.itemId];KS(r)&&(r.stdBool=t.payload.stdBool)},setTimeSeriesItemSpan:(e,t)=>{const r=e.items[t.payload.itemId];KS(r)&&(r.span=t.payload.span)},setTimeSeriesItemShowGrid:(e,t)=>{const r=e.items[t.payload.itemId];KS(r)&&(r.showgrid=t.payload.showgrid)},setTimeSeriesItemShowLine:(e,t)=>{const r=e.items[t.payload.itemId];KS(r)&&(r.showline=t.payload.showline)},setTimeSeriesItemShowTickLabels:(e,t)=>{const r=e.items[t.payload.itemId];KS(r)&&(r.showticklabels=t.payload.showticklabels)},setTimeSeriesItemZeroLine:(e,t)=>{const r=e.items[t.payload.itemId];KS(r)&&(r.zeroline=t.payload.zeroline)},setTimeSeriesItemXrangeLeft:(e,t)=>{const r=e.items[t.payload.itemId];KS(r)&&(r.xrange.left=t.payload.left)},setTimeSeriesItemXrangeRight:(e,t)=>{const r=e.items[t.payload.itemId];KS(r)&&(r.xrange.right=t.payload.right)},setTimeSeriesItemDrawOrderList:(e,t)=>{const{itemId:r,drawOrderList:n}=t.payload,i=e.items[r];KS(i)&&(i.drawOrderList=n)},resetAllOrderList:e=>{Object.keys(e.items).forEach((t=>{const r=e.items[t];KS(r)&&(r.drawOrderList=[])}))},setTimeSeriesItemMaxIndex:(e,t)=>{const{itemId:r,maxIndex:n}=t.payload,i=e.items[r];KS(i)&&(i.maxIndex=n)},setTimeSeriesRefImageItemId:(e,t)=>{const{itemId:r,refImageItemId:n}=t.payload,i=e.items[r];KS(i)&&(i.refImageItemId=null!==n&&void 0!==n?n:null,i.drawOrderList=[])},setHeatMapItemShowScale:(e,t)=>{const r=e.items[t.payload.itemId];QS(r)&&(r.showscale=t.payload.showscale)},setHeatMapItemColors:(e,t)=>{const r=e.items[t.payload.itemId];QS(r)&&(r.colors=t.payload.colors)},setCsvItemTranspose:(e,t)=>{const r=e.items[t.payload.itemId];JS(r)&&(r.transpose=t.payload.transpose)},setCsvItemSetHeader:(e,t)=>{const r=e.items[t.payload.itemId];JS(r)&&(r.setHeader=t.payload.setHeader)},setCsvItemSetIndex:(e,t)=>{const r=e.items[t.payload.itemId];JS(r)&&(r.setIndex=t.payload.setIndex)},setScatterItemXIndex:(e,t)=>{const r=e.items[t.payload.itemId];eA(r)&&(r.xIndex=t.payload.xIndex)},setScatterItemYIndex:(e,t)=>{const r=e.items[t.payload.itemId];eA(r)&&(r.yIndex=t.payload.yIndex)},setBarItemIndex:(e,t)=>{const r=e.items[t.payload.itemId];tA(r)&&(r.index=t.payload.index)},setHistogramItemBins:(e,t)=>{const r=e.items[t.payload.itemId];rA(r)&&(r.bins=t.payload.bins)},setLineItemSelectedIndex:(e,t)=>{const r=e.items[t.payload.itemId];nA(r)&&(r.selectedIndex=t.payload.selectedIndex)},setPolartemItemSelectedIndex:(e,t)=>{const r=e.items[t.payload.itemId];iA(r)&&(r.selectedIndex=t.payload.selectedIndex)}},extraReducers:e=>{e.addCase(rT,((e,t)=>{const r=t.payload.itemId;ZS(e.items[r])&&Object.values(e.items).forEach((e=>{KS(e)&&e.refImageItemId===r&&(e.refImageItemId=null)})),delete e.items[r],r===e.selectedItemId&&(e.selectedItemId=null),e.layout.forEach(((t,n)=>{const i=t.indexOf(r);-1!==i&&t.splice(i,1),0===t.length&&e.layout.splice(n,1)}))})).addCase(nT,((e,t)=>{const{itemId:r,filePath:n,nodeId:i,dataType:o}=t.payload,a=e.items[r];if(!XS(a))throw new Error("invalid VisualaizeItemType");null!=o?e.items[r]={...wT(o),width:a.width,height:a.height,filePath:n,nodeId:i}:(a.filePath=n,a.nodeId=i),TT(e,{itemId:r})})).addCase(eT.fulfilled,((e,t)=>{const{itemId:r,clickedDataId:n}=t.meta.arg,i=e.items[r];ZS(i)&&(i.clickedDataId=n),Object.values(e.items).forEach((e=>{KS(e)&&(null==e.refImageItemId||r!==e.refImageItemId||e.drawOrderList.includes(n)||e.drawOrderList.push(n))}))})).addCase(tT.fulfilled,((e,t)=>{const{itemId:r}=t.meta.arg,n=t.payload;Object.values(e.items).forEach((e=>{KS(e)&&null!=e.refImageItemId&&r===e.refImageItemId&&(e.drawOrderList=n)}))})).addMatcher(Bl(pk,Qk.fulfilled,eS.fulfilled),(()=>iT))}});function ST(e){const t=Object.keys(e.items).map((e=>Number(e)));return t.length>0?t.reduce(((e,t)=>Math.max(e,t))):null}function AT(e){const t=ST(e),r=null!=t?t+1:0;return e.items[r]=wT(Yf),e.selectedItemId=r,r}function TT(e,t){const{itemId:r}=t,n=e.items[r];ZS(n)&&(n.activeIndex=0)}const{changeRangeUnit:MT,pushInitialItemToNewRow:CT,insertInitialItemToNextColumn:ET,addItemForWorkflowDialog:IT,deleteAllItemForWorkflowDialog:PT,setItemSize:OT,selectItem:RT,setFilePath:LT,setSaveFormat:DT,setSaveFileName:zT,setHeatMapItemFilePath:jT,setImageItemFilePath:FT,setTimeSeriesItemFilePath:NT,setRoiItemFilePath:BT,resetImageActiveIndex:VT,incrementImageActiveIndex:UT,decrementImageActiveIndex:HT,setImageActiveIndex:$T,setImageItemShowticklabels:WT,setImageItemZsmooth:qT,setImageItemShowLine:GT,setImageItemShowGrid:YT,setImageItemShowScale:XT,setImageItemColors:ZT,setImageItemStartIndex:KT,setImageItemEndIndex:JT,setImageItemAlpha:QT,setImageItemRoiAlpha:eM,setImageItemDuration:tM,setTimeSeriesItemOffset:rM,setTimeSeriesItemSpan:nM,setTimeSeriesItemShowGrid:iM,setTimeSeriesItemShowLine:oM,setTimeSeriesItemShowTickLabels:aM,setTimeSeriesItemZeroLine:sM,setTimeSeriesItemXrangeLeft:lM,setTimeSeriesItemXrangeRight:cM,setTimeSeriesItemDrawOrderList:uM,setTimeSeriesItemMaxIndex:dM,setTimeSeriesRefImageItemId:hM,setHeatMapItemShowScale:pM,setHeatMapItemColors:fM,setCsvItemTranspose:mM,setCsvItemSetHeader:gM,setCsvItemSetIndex:yM,setScatterItemXIndex:vM,setScatterItemYIndex:xM,setBarItemIndex:bM,setHistogramItemBins:_M,setLineItemSelectedIndex:wM,setPolartemItemSelectedIndex:kM,resetAllOrderList:SM,reset:AM}=kT.actions,TM=kT.reducer,MM=()=>{const[e,t]=(0,n.useState)(null),r="documentation-menu",i=Boolean(e),[o,a]=(0,n.useState)(!1),s=C(),{enqueueSnackbar:l}=hn(),c=x(jf);return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(Mp,{title:"GitHub repository",children:(0,j.jsx)(oi,{href:"https://github.com/oist/optinist",target:"_blank",children:(0,j.jsx)(Hd,{})})}),(0,j.jsx)(Mp,{title:"Documentation",children:(0,j.jsx)(oi,{onClick:e=>{t(e.currentTarget)},children:(0,j.jsx)($d,{})})}),(0,j.jsxs)(Da,{id:r,anchorEl:e,open:i,onClose:()=>{t(null)},MenuListProps:{"aria-labelledby":r,role:"listbox"},children:[(0,j.jsxs)(qa,{onClick:()=>{window.open("https://optinist.readthedocs.io/en/latest/","_blank")},children:[(0,j.jsx)(Ip,{children:(0,j.jsx)(Wd,{})}),(0,j.jsx)(Rp,{children:"Go to documentation page"})]}),(0,j.jsxs)(qa,{onClick:()=>{a(!0)},children:[(0,j.jsx)(Ip,{children:(0,j.jsx)(qd,{})}),(0,j.jsx)(Rp,{children:"Import sample data"})]})]}),(0,j.jsx)(Cf,{open:o,setOpen:a,onConfirm:()=>{"number"===typeof c&&s(ak({workspaceId:c})).unwrap().then((()=>{l("Sample data import success",{variant:"success"}),s(AM()),s(Uf())})).catch((()=>{l("Sample data import error",{variant:"error"})}))},title:"Import sample data?",content:"sample data files and tutorial records will be imported.",iconType:"info"})]})},CM=r.p+"static/media/logo.e44efe3246aecc6d6219.png";var EM=r(75342);function IM(e){return(0,Yn.Ay)("MuiTab",e)}const PM=(0,Ln.A)("MuiTab",["root","labelIcon","textColorInherit","textColorPrimary","textColorSecondary","selected","disabled","fullWidth","wrapped","iconWrapper"]),OM=["className","disabled","disableFocusRipple","fullWidth","icon","iconPosition","indicator","label","onChange","onClick","onFocus","selected","selectionFollowsFocus","textColor","value","wrapped"],RM=(0,yn.Ay)(Qn,{name:"MuiTab",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.label&&r.icon&&t.labelIcon,t[`textColor${(0,ei.A)(r.textColor)}`],r.fullWidth&&t.fullWidth,r.wrapped&&t.wrapped,{[`& .${PM.iconWrapper}`]:t.iconWrapper}]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({},t.typography.button,{maxWidth:360,minWidth:90,position:"relative",minHeight:48,flexShrink:0,padding:"12px 16px",overflow:"hidden",whiteSpace:"normal",textAlign:"center"},r.label&&{flexDirection:"top"===r.iconPosition||"bottom"===r.iconPosition?"column":"row"},{lineHeight:1.25},r.icon&&r.label&&{minHeight:72,paddingTop:9,paddingBottom:9,[`& > .${PM.iconWrapper}`]:(0,O.A)({},"top"===r.iconPosition&&{marginBottom:6},"bottom"===r.iconPosition&&{marginTop:6},"start"===r.iconPosition&&{marginRight:t.spacing(1)},"end"===r.iconPosition&&{marginLeft:t.spacing(1)})},"inherit"===r.textColor&&{color:"inherit",opacity:.6,[`&.${PM.selected}`]:{opacity:1},[`&.${PM.disabled}`]:{opacity:(t.vars||t).palette.action.disabledOpacity}},"primary"===r.textColor&&{color:(t.vars||t).palette.text.secondary,[`&.${PM.selected}`]:{color:(t.vars||t).palette.primary.main},[`&.${PM.disabled}`]:{color:(t.vars||t).palette.text.disabled}},"secondary"===r.textColor&&{color:(t.vars||t).palette.text.secondary,[`&.${PM.selected}`]:{color:(t.vars||t).palette.secondary.main},[`&.${PM.disabled}`]:{color:(t.vars||t).palette.text.disabled}},r.fullWidth&&{flexShrink:1,flexGrow:1,flexBasis:0,maxWidth:"none"},r.wrapped&&{fontSize:t.typography.pxToRem(12)})})),LM=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiTab"}),{className:i,disabled:o=!1,disableFocusRipple:a=!1,fullWidth:s,icon:l,iconPosition:c="top",indicator:u,label:d,onChange:h,onClick:p,onFocus:f,selected:m,selectionFollowsFocus:g,textColor:y="inherit",value:v,wrapped:x=!1}=r,b=(0,R.A)(r,OM),_=(0,O.A)({},r,{disabled:o,disableFocusRipple:a,selected:m,icon:!!l,iconPosition:c,label:!!d,fullWidth:s,textColor:y,wrapped:x}),w=(e=>{const{classes:t,textColor:r,fullWidth:n,wrapped:i,icon:o,label:a,selected:s,disabled:l}=e,c={root:["root",o&&a&&"labelIcon",`textColor${(0,ei.A)(r)}`,n&&"fullWidth",i&&"wrapped",s&&"selected",l&&"disabled"],iconWrapper:["iconWrapper"]};return(0,mn.A)(c,IM,t)})(_),k=l&&d&&n.isValidElement(l)?n.cloneElement(l,{className:(0,fn.A)(w.iconWrapper,l.props.className)}):l;return(0,j.jsxs)(RM,(0,O.A)({focusRipple:!a,className:(0,fn.A)(w.root,i),ref:t,role:"tab","aria-selected":m,disabled:o,onClick:e=>{!m&&h&&h(e,v),p&&p(e)},onFocus:e=>{g&&!m&&h&&h(e,v),f&&f(e)},ownerState:_,tabIndex:m?0:-1},b,{children:["top"===c||"start"===c?(0,j.jsxs)(n.Fragment,{children:[k,d]}):(0,j.jsxs)(n.Fragment,{children:[d,k]}),u]}))}));let DM;function zM(){if(DM)return DM;const e=document.createElement("div"),t=document.createElement("div");return t.style.width="10px",t.style.height="1px",e.appendChild(t),e.dir="rtl",e.style.fontSize="14px",e.style.width="4px",e.style.height="1px",e.style.position="absolute",e.style.top="-1000px",e.style.overflow="scroll",document.body.appendChild(e),DM="reverse",e.scrollLeft>0?DM="default":(e.scrollLeft=1,0===e.scrollLeft&&(DM="negative")),document.body.removeChild(e),DM}function jM(e,t){const r=e.scrollLeft;if("rtl"!==t)return r;switch(zM()){case"negative":return e.scrollWidth-e.clientWidth+r;case"reverse":return e.scrollWidth-e.clientWidth-r;default:return r}}function FM(e){return(1+Math.sin(Math.PI*e-Math.PI/2))/2}const NM=["onChange"],BM={width:99,height:99,position:"absolute",top:-9999,overflow:"scroll"};const VM=(0,Ud.A)((0,j.jsx)("path",{d:"M15.41 16.09l-4.58-4.59 4.58-4.59L14 5.5l-6 6 6 6z"}),"KeyboardArrowLeft"),UM=(0,Ud.A)((0,j.jsx)("path",{d:"M8.59 16.34l4.58-4.59-4.58-4.59L10 5.75l6 6-6 6z"}),"KeyboardArrowRight");function HM(e){return(0,Yn.Ay)("MuiTabScrollButton",e)}const $M=(0,Ln.A)("MuiTabScrollButton",["root","vertical","horizontal","disabled"]),WM=["className","slots","slotProps","direction","orientation","disabled"],qM=(0,yn.Ay)(Qn,{name:"MuiTabScrollButton",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.orientation&&t[r.orientation]]}})((e=>{let{ownerState:t}=e;return(0,O.A)({width:40,flexShrink:0,opacity:.8,[`&.${$M.disabled}`]:{opacity:0}},"vertical"===t.orientation&&{width:"100%",height:40,"& svg":{transform:`rotate(${t.isRtl?-90:90}deg)`}})})),GM=n.forwardRef((function(e,t){var r,n;const i=(0,vn.b)({props:e,name:"MuiTabScrollButton"}),{className:o,slots:a={},slotProps:s={},direction:l}=i,c=(0,R.A)(i,WM),u=H(),d=(0,O.A)({isRtl:u},i),h=(e=>{const{classes:t,orientation:r,disabled:n}=e,i={root:["root",r,n&&"disabled"]};return(0,mn.A)(i,HM,t)})(d),p=null!=(r=a.StartScrollButtonIcon)?r:VM,f=null!=(n=a.EndScrollButtonIcon)?n:UM,m=to({elementType:p,externalSlotProps:s.startScrollButtonIcon,additionalProps:{fontSize:"small"},ownerState:d}),g=to({elementType:f,externalSlotProps:s.endScrollButtonIcon,additionalProps:{fontSize:"small"},ownerState:d});return(0,j.jsx)(qM,(0,O.A)({component:"div",className:(0,fn.A)(h.root,o),ref:t,role:null,ownerState:d,tabIndex:null},c,{children:"left"===l?(0,j.jsx)(p,(0,O.A)({},m)):(0,j.jsx)(f,(0,O.A)({},g))}))}));function YM(e){return(0,Yn.Ay)("MuiTabs",e)}const XM=(0,Ln.A)("MuiTabs",["root","vertical","flexContainer","flexContainerVertical","centered","scroller","fixed","scrollableX","scrollableY","hideScrollbar","scrollButtons","scrollButtonsHideMobile","indicator"]),ZM=["aria-label","aria-labelledby","action","centered","children","className","component","allowScrollButtonsMobile","indicatorColor","onChange","orientation","ScrollButtonComponent","scrollButtons","selectionFollowsFocus","slots","slotProps","TabIndicatorProps","TabScrollButtonProps","textColor","value","variant","visibleScrollbar"],KM=(e,t)=>e===t?e.firstChild:t&&t.nextElementSibling?t.nextElementSibling:e.firstChild,JM=(e,t)=>e===t?e.lastChild:t&&t.previousElementSibling?t.previousElementSibling:e.lastChild,QM=(e,t,r)=>{let n=!1,i=r(e,t);for(;i;){if(i===e.firstChild){if(n)return;n=!0}const t=i.disabled||"true"===i.getAttribute("aria-disabled");if(i.hasAttribute("tabindex")&&!t)return void i.focus();i=r(e,i)}},eC=(0,yn.Ay)("div",{name:"MuiTabs",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[{[`& .${XM.scrollButtons}`]:t.scrollButtons},{[`& .${XM.scrollButtons}`]:r.scrollButtonsHideMobile&&t.scrollButtonsHideMobile},t.root,r.vertical&&t.vertical]}})((e=>{let{ownerState:t,theme:r}=e;return(0,O.A)({overflow:"hidden",minHeight:48,WebkitOverflowScrolling:"touch",display:"flex"},t.vertical&&{flexDirection:"column"},t.scrollButtonsHideMobile&&{[`& .${XM.scrollButtons}`]:{[r.breakpoints.down("sm")]:{display:"none"}}})})),tC=(0,yn.Ay)("div",{name:"MuiTabs",slot:"Scroller",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.scroller,r.fixed&&t.fixed,r.hideScrollbar&&t.hideScrollbar,r.scrollableX&&t.scrollableX,r.scrollableY&&t.scrollableY]}})((e=>{let{ownerState:t}=e;return(0,O.A)({position:"relative",display:"inline-block",flex:"1 1 auto",whiteSpace:"nowrap"},t.fixed&&{overflowX:"hidden",width:"100%"},t.hideScrollbar&&{scrollbarWidth:"none","&::-webkit-scrollbar":{display:"none"}},t.scrollableX&&{overflowX:"auto",overflowY:"hidden"},t.scrollableY&&{overflowY:"auto",overflowX:"hidden"})})),rC=(0,yn.Ay)("div",{name:"MuiTabs",slot:"FlexContainer",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.flexContainer,r.vertical&&t.flexContainerVertical,r.centered&&t.centered]}})((e=>{let{ownerState:t}=e;return(0,O.A)({display:"flex"},t.vertical&&{flexDirection:"column"},t.centered&&{justifyContent:"center"})})),nC=(0,yn.Ay)("span",{name:"MuiTabs",slot:"Indicator",overridesResolver:(e,t)=>t.indicator})((e=>{let{ownerState:t,theme:r}=e;return(0,O.A)({position:"absolute",height:2,bottom:0,width:"100%",transition:r.transitions.create()},"primary"===t.indicatorColor&&{backgroundColor:(r.vars||r).palette.primary.main},"secondary"===t.indicatorColor&&{backgroundColor:(r.vars||r).palette.secondary.main},t.vertical&&{height:"100%",width:2,right:0})})),iC=(0,yn.Ay)((function(e){const{onChange:t}=e,r=(0,R.A)(e,NM),i=n.useRef(),o=n.useRef(null),a=()=>{i.current=o.current.offsetHeight-o.current.clientHeight};return(0,uo.A)((()=>{const e=(0,vo.A)((()=>{const e=i.current;a(),e!==i.current&&t(i.current)})),r=(0,xo.A)(o.current);return r.addEventListener("resize",e),()=>{e.clear(),r.removeEventListener("resize",e)}}),[t]),n.useEffect((()=>{a(),t(i.current)}),[t]),(0,j.jsx)("div",(0,O.A)({style:BM,ref:o},r))}))({overflowX:"auto",overflowY:"hidden",scrollbarWidth:"none","&::-webkit-scrollbar":{display:"none"}}),oC={};const aC=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiTabs"}),i=Io(),o=H(),{"aria-label":a,"aria-labelledby":s,action:l,centered:c=!1,children:u,className:d,component:h="div",allowScrollButtonsMobile:p=!1,indicatorColor:f="primary",onChange:m,orientation:g="horizontal",ScrollButtonComponent:y=GM,scrollButtons:v="auto",selectionFollowsFocus:x,slots:b={},slotProps:_={},TabIndicatorProps:w={},TabScrollButtonProps:k={},textColor:S="primary",value:A,variant:T="standard",visibleScrollbar:M=!1}=r,C=(0,R.A)(r,ZM),E="scrollable"===T,I="vertical"===g,P=I?"scrollTop":"scrollLeft",L=I?"top":"left",D=I?"bottom":"right",z=I?"clientHeight":"clientWidth",F=I?"height":"width",N=(0,O.A)({},r,{component:h,allowScrollButtonsMobile:p,indicatorColor:f,orientation:g,vertical:I,scrollButtons:v,textColor:S,variant:T,visibleScrollbar:M,fixed:!E,hideScrollbar:E&&!M,scrollableX:E&&!I,scrollableY:E&&I,centered:c&&!E,scrollButtonsHideMobile:!p}),B=(e=>{const{vertical:t,fixed:r,hideScrollbar:n,scrollableX:i,scrollableY:o,centered:a,scrollButtonsHideMobile:s,classes:l}=e,c={root:["root",t&&"vertical"],scroller:["scroller",r&&"fixed",n&&"hideScrollbar",i&&"scrollableX",o&&"scrollableY"],flexContainer:["flexContainer",t&&"flexContainerVertical",a&&"centered"],indicator:["indicator"],scrollButtons:["scrollButtons",s&&"scrollButtonsHideMobile"],scrollableX:[i&&"scrollableX"],hideScrollbar:[n&&"hideScrollbar"]};return(0,mn.A)(c,YM,l)})(N),V=to({elementType:b.StartScrollButtonIcon,externalSlotProps:_.startScrollButtonIcon,ownerState:N}),U=to({elementType:b.EndScrollButtonIcon,externalSlotProps:_.endScrollButtonIcon,ownerState:N});const[$,W]=n.useState(!1),[q,G]=n.useState(oC),[Y,X]=n.useState(!1),[Z,K]=n.useState(!1),[J,Q]=n.useState(!1),[ee,te]=n.useState({overflow:"hidden",scrollbarWidth:0}),re=new Map,ne=n.useRef(null),ie=n.useRef(null),oe=()=>{const e=ne.current;let t,r;if(e){const r=e.getBoundingClientRect();t={clientWidth:e.clientWidth,scrollLeft:e.scrollLeft,scrollTop:e.scrollTop,scrollLeftNormalized:jM(e,o?"rtl":"ltr"),scrollWidth:e.scrollWidth,top:r.top,bottom:r.bottom,left:r.left,right:r.right}}if(e&&!1!==A){const e=ie.current.children;if(e.length>0){const t=e[re.get(A)];0,r=t?t.getBoundingClientRect():null}}return{tabsMeta:t,tabMeta:r}},ae=(0,bn.A)((()=>{const{tabsMeta:e,tabMeta:t}=oe();let r,n=0;if(I)r="top",t&&e&&(n=t.top-e.top+e.scrollTop);else if(r=o?"right":"left",t&&e){const i=o?e.scrollLeftNormalized+e.clientWidth-e.scrollWidth:e.scrollLeft;n=(o?-1:1)*(t[r]-e[r]+i)}const i={[r]:n,[F]:t?t[F]:0};if(isNaN(q[r])||isNaN(q[F]))G(i);else{const e=Math.abs(q[r]-i[r]),t=Math.abs(q[F]-i[F]);(e>=1||t>=1)&&G(i)}})),se=function(e){let{animation:t=!0}=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};t?function(e,t,r){let n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:()=>{};const{ease:o=FM,duration:a=300}=n;let s=null;const l=t[e];let c=!1;const u=()=>{c=!0},d=n=>{if(c)return void i(new Error("Animation cancelled"));null===s&&(s=n);const u=Math.min(1,(n-s)/a);t[e]=o(u)*(r-l)+l,u>=1?requestAnimationFrame((()=>{i(null)})):requestAnimationFrame(d)};l===r?i(new Error("Element already at target position")):requestAnimationFrame(d)}(P,ne.current,e,{duration:i.transitions.duration.standard}):ne.current[P]=e},le=e=>{let t=ne.current[P];I?t+=e:(t+=e*(o?-1:1),t*=o&&"reverse"===zM()?-1:1),se(t)},ce=()=>{const e=ne.current[z];let t=0;const r=Array.from(ie.current.children);for(let n=0;ne){0===n&&(t=e);break}t+=i[z]}return t},ue=()=>{le(-1*ce())},de=()=>{le(ce())},he=n.useCallback((e=>{te({overflow:null,scrollbarWidth:e})}),[]),pe=(0,bn.A)((e=>{const{tabsMeta:t,tabMeta:r}=oe();if(r&&t)if(r[L]t[D]){const n=t[P]+(r[D]-t[D]);se(n,{animation:e})}})),fe=(0,bn.A)((()=>{E&&!1!==v&&Q(!J)}));n.useEffect((()=>{const e=(0,vo.A)((()=>{ne.current&&ae()}));let t;const r=r=>{r.forEach((e=>{e.removedNodes.forEach((e=>{var r;null==(r=t)||r.unobserve(e)})),e.addedNodes.forEach((e=>{var r;null==(r=t)||r.observe(e)}))})),e(),fe()},n=(0,xo.A)(ne.current);let i;return n.addEventListener("resize",e),"undefined"!==typeof ResizeObserver&&(t=new ResizeObserver(e),Array.from(ie.current.children).forEach((e=>{t.observe(e)}))),"undefined"!==typeof MutationObserver&&(i=new MutationObserver(r),i.observe(ie.current,{childList:!0})),()=>{var r,o;e.clear(),n.removeEventListener("resize",e),null==(r=i)||r.disconnect(),null==(o=t)||o.disconnect()}}),[ae,fe]),n.useEffect((()=>{const e=Array.from(ie.current.children),t=e.length;if("undefined"!==typeof IntersectionObserver&&t>0&&E&&!1!==v){const r=e[0],n=e[t-1],i={root:ne.current,threshold:.99},o=new IntersectionObserver((e=>{X(!e[0].isIntersecting)}),i);o.observe(r);const a=new IntersectionObserver((e=>{K(!e[0].isIntersecting)}),i);return a.observe(n),()=>{o.disconnect(),a.disconnect()}}}),[E,v,J,null==u?void 0:u.length]),n.useEffect((()=>{W(!0)}),[]),n.useEffect((()=>{ae()})),n.useEffect((()=>{pe(oC!==q)}),[pe,q]),n.useImperativeHandle(l,(()=>({updateIndicator:ae,updateScrollButtons:fe})),[ae,fe]);const me=(0,j.jsx)(nC,(0,O.A)({},w,{className:(0,fn.A)(B.indicator,w.className),ownerState:N,style:(0,O.A)({},q,w.style)}));let ge=0;const ye=n.Children.map(u,(e=>{if(!n.isValidElement(e))return null;const t=void 0===e.props.value?ge:e.props.value;re.set(t,ge);const r=t===A;return ge+=1,n.cloneElement(e,(0,O.A)({fullWidth:"fullWidth"===T,indicator:r&&!$&&me,selected:r,selectionFollowsFocus:x,onChange:m,textColor:S,value:t},1!==ge||!1!==A||e.props.tabIndex?{}:{tabIndex:0}))})),ve=(()=>{const e={};e.scrollbarSizeListener=E?(0,j.jsx)(iC,{onChange:he,className:(0,fn.A)(B.scrollableX,B.hideScrollbar)}):null;const t=E&&("auto"===v&&(Y||Z)||!0===v);return e.scrollButtonStart=t?(0,j.jsx)(y,(0,O.A)({slots:{StartScrollButtonIcon:b.StartScrollButtonIcon},slotProps:{startScrollButtonIcon:V},orientation:g,direction:o?"right":"left",onClick:ue,disabled:!Y},k,{className:(0,fn.A)(B.scrollButtons,k.className)})):null,e.scrollButtonEnd=t?(0,j.jsx)(y,(0,O.A)({slots:{EndScrollButtonIcon:b.EndScrollButtonIcon},slotProps:{endScrollButtonIcon:U},orientation:g,direction:o?"left":"right",onClick:de,disabled:!Z},k,{className:(0,fn.A)(B.scrollButtons,k.className)})):null,e})();return(0,j.jsxs)(eC,(0,O.A)({className:(0,fn.A)(B.root,d),ownerState:N,ref:t,as:h},C,{children:[ve.scrollButtonStart,ve.scrollbarSizeListener,(0,j.jsxs)(tC,{className:B.scroller,ownerState:N,style:{overflow:ee.overflow,[I?"margin"+(o?"Left":"Right"):"marginBottom"]:M?void 0:-ee.scrollbarWidth},ref:ne,children:[(0,j.jsx)(rC,{"aria-label":a,"aria-labelledby":s,"aria-orientation":"vertical"===g?"vertical":null,className:B.flexContainer,ownerState:N,onKeyDown:e=>{const t=ie.current,r=(0,ro.A)(t).activeElement;if("tab"!==r.getAttribute("role"))return;let n="horizontal"===g?"ArrowLeft":"ArrowUp",i="horizontal"===g?"ArrowRight":"ArrowDown";switch("horizontal"===g&&o&&(n="ArrowRight",i="ArrowLeft"),e.key){case n:e.preventDefault(),QM(t,r,JM);break;case i:e.preventDefault(),QM(t,r,KM);break;case"Home":e.preventDefault(),QM(t,null,KM);break;case"End":e.preventDefault(),QM(t,null,JM)}},ref:ie,role:"tablist",children:ye}),$&&me]}),ve.scrollButtonEnd]}))})),sC="workspace",lC=jl(`${sC}/getWorkspace`,(async(e,t)=>{const{rejectWithValue:r}=t;try{return await(async e=>(await wd.get(`/workspace/${e}`)).data)(e.id)}catch(ene){return r(ene)}})),cC=jl(`${sC}/getWorkspaceList`,(async(e,t)=>{const{rejectWithValue:r}=t;try{const t=await(async e=>{const t=(0,Sd.stringify)(e,{indices:!1});return(await wd.get(`/workspaces?${t}`)).data})(e);return t}catch(ene){return r(ene)}})),uC=jl(`${sC}/delWorkspaceList`,(async(e,t)=>{const{rejectWithValue:r,dispatch:n}=t;try{const t=await(async e=>(await wd.delete(`/workspace/${e}`)).data)(Number(e.id));return await n(cC(e.params)),t}catch(ene){return r(ene)}})),dC=jl(`${sC}/postWorkspaceList`,(async(e,t)=>{const{rejectWithValue:r}=t;try{const t=await(async e=>(await wd.post("/workspace",e)).data)(e);return t}catch(ene){return r(ene)}})),hC=jl(`${sC}/putWorkspaceList`,(async(e,t)=>{const{rejectWithValue:r}=t;try{const t=await(async e=>(await wd.put(`/workspace/${e.id}`,{name:e.name})).data)(e);return t}catch(ene){return r(ene)}})),pC=jl(`${sC}/getListUserShareWorkSpaces`,(async(e,t)=>{const{rejectWithValue:r}=t;try{return await(async e=>(await wd.get(`/workspace/share/${e}/status`)).data)(e.id)}catch(ene){return r(ene)}})),fC=jl(`${sC}/postListUserShareWorkspaces`,(async(e,t)=>{const{rejectWithValue:r}=t;try{return await(async(e,t)=>(await wd.post(`/workspace/share/${e}/status`,t)).data)(e.id,e.data)}catch(ene){return r(ene)}})),mC=Pl({name:sC,initialState:{currentWorkspace:{statusRoi:void 0,selectedTab:0,roiFilePath:void 0,workspaceId:void 0},workspace:{items:[],total:0,limit:50,offset:0},loading:!1,listUserShare:void 0},reducers:{setDataCancel:(e,t)=>{e.currentWorkspace.roiFilePath=t.payload.roiFilePath,e.currentWorkspace.workspaceId=t.payload.workspaceId,e.currentWorkspace.statusRoi=t.payload.statusRoi},setActiveTab:(e,t)=>{e.currentWorkspace.selectedTab=t.payload},setCurrentWorkspace:(e,t)=>{e.currentWorkspace.workspaceId=t.payload},clearCurrentWorkspace:e=>{e.currentWorkspace={selectedTab:0}}},extraReducers(e){e.addCase(ik.fulfilled,((e,t)=>{e.currentWorkspace.workspaceId=t.meta.arg.workspaceId,e.currentWorkspace.selectedTab=0})).addCase(lC.fulfilled,((e,t)=>{e.currentWorkspace.workspaceId=t.payload.id,e.currentWorkspace.workspaceName=t.payload.name,e.currentWorkspace.ownerId=t.payload.user.id,e.loading=!1})).addCase(cC.fulfilled,((e,t)=>{e.workspace=t.payload,e.loading=!1})).addCase(pC.fulfilled,((e,t)=>{e.listUserShare=t.payload,e.loading=!1})).addMatcher(Bl(lC.rejected,cC.rejected,dC.fulfilled,dC.rejected,hC.fulfilled,hC.rejected,uC.fulfilled,uC.rejected,pC.rejected,fC.rejected),(e=>{e.loading=!1})).addMatcher(Bl(lC.pending,cC.pending,dC.pending,hC.pending,uC.pending,pC.pending,fC.pending),(e=>{e.loading=!0}))}}),{setCurrentWorkspace:gC,clearCurrentWorkspace:yC,setActiveTab:vC,setDataCancel:xC}=mC.actions,bC=mC.reducer;function _C(e){return{id:`simple-tab-${e}`,"aria-controls":`simple-tabpanel-${e}`}}const wC=()=>{const e=C(),t=x(Df),r=x(zf),i=x(jf),o=x(Ff),a=Ye(),s=x(Pf),l=(0,n.useCallback)(((t,n)=>{if(e(vC(n)),!o||!r||!i)return;const a=!Object.keys(o).every((e=>0===o[e].length));1!==n&&a&&e(uS({path:r,workspaceId:i}))}),[r,i,o]),c=x(Xk);return(0,j.jsx)(j.Fragment,{children:(0,j.jsxs)(aC,{sx:{width:"100%"},value:t,onChange:l,centered:!0,textColor:"primary",children:[(0,j.jsx)(LM,{label:"Workflow",..._C(0)}),(0,j.jsx)(LM,{disabled:!!c,label:"Visualize",..._C(1)}),(0,j.jsx)(LM,{label:"Record",..._C(2)}),!s&&(0,j.jsx)(LM,{label:(0,j.jsx)("span",{children:(0,j.jsxs)("span",{style:{display:"flex",alignItems:"center"},children:[(0,j.jsx)(EM.A,{fontSize:"small",style:{marginRight:"0.2rem"}}),(0,j.jsx)("span",{style:{fontSize:"smaller"},children:"Workspaces"})]})}),onClick:()=>a("/console/workspaces")})]})})},kC="calc(100vh - 48px - 60px)",SC=()=>(0,j.jsx)(TC,{children:(0,j.jsxs)(ji,{children:[(0,j.jsx)(yi,{display:"flex",flexGrow:1,children:(0,j.jsx)("img",{src:CM,alt:"logo",width:75,height:50})}),(0,j.jsx)(wC,{}),(0,j.jsx)(MM,{})]})}),AC=e=>{let{handleDrawerOpen:t}=e;const r=qe();return(0,j.jsx)(TC,{children:(0,j.jsxs)(ji,{children:[(0,j.jsx)(oi,{color:"inherit","aria-label":"open drawer",onClick:t,edge:"start",children:(0,j.jsx)(ki.A,{})}),(0,j.jsx)(yi,{display:"flex",flexGrow:1,children:(0,j.jsx)(MC,{children:"STUDIO"})}),/^\/console\/workspaces\/.+$/.test(r.pathname)&&(0,j.jsx)(wC,{}),(0,j.jsx)(Vd,{}),(0,j.jsx)(MM,{})]})})},TC=(0,yn.Ay)(Ri)({position:"fixed",backgroundColor:"#E1DEDB",color:"#000000",height:60}),MC=(0,yn.Ay)(Hi)({fontWeight:600,fontSize:22}),CC=e=>{let{handleDrawerOpen:t}=e;return x(Pf)?(0,j.jsx)(SC,{}):(0,j.jsx)(AC,{handleDrawerOpen:t})};var EC=r(75114),IC=r(58094),PC=r(62647);const OC=["addEndListener","appear","children","container","direction","easing","in","onEnter","onEntered","onEntering","onExit","onExited","onExiting","style","timeout","TransitionComponent"];function RC(e,t,r){var n;const i=function(e,t,r){const n=t.getBoundingClientRect(),i=r&&r.getBoundingClientRect(),o=(0,xo.A)(t);let a;if(t.fakeTransform)a=t.fakeTransform;else{const e=o.getComputedStyle(t);a=e.getPropertyValue("-webkit-transform")||e.getPropertyValue("transform")}let s=0,l=0;if(a&&"none"!==a&&"string"===typeof a){const e=a.split("(")[1].split(")")[0].split(",");s=parseInt(e[4],10),l=parseInt(e[5],10)}return"left"===e?i?`translateX(${i.right+s-n.left}px)`:`translateX(${o.innerWidth+s-n.left}px)`:"right"===e?i?`translateX(-${n.right-i.left-s}px)`:`translateX(-${n.left+n.width-s}px)`:"up"===e?i?`translateY(${i.bottom+l-n.top}px)`:`translateY(${o.innerHeight+l-n.top}px)`:i?`translateY(-${n.top-i.top+n.height-l}px)`:`translateY(-${n.top+n.height-l}px)`}(e,t,"function"===typeof(n=r)?n():n);i&&(t.style.webkitTransform=i,t.style.transform=i)}const LC=n.forwardRef((function(e,t){const r=Io(),i={enter:r.transitions.easing.easeOut,exit:r.transitions.easing.sharp},o={enter:r.transitions.duration.enteringScreen,exit:r.transitions.duration.leavingScreen},{addEndListener:a,appear:s=!0,children:l,container:c,direction:u="down",easing:d=i,in:h,onEnter:p,onEntered:f,onEntering:m,onExit:g,onExited:y,onExiting:v,style:x,timeout:b=o,TransitionComponent:_=Co}=e,w=(0,R.A)(e,OC),k=n.useRef(null),S=(0,xn.A)(l.ref,k,t),A=e=>t=>{e&&(void 0===t?e(k.current):e(k.current,t))},T=A(((e,t)=>{RC(u,e,c),Po(e),p&&p(e,t)})),M=A(((e,t)=>{const n=Oo({timeout:b,style:x,easing:d},{mode:"enter"});e.style.webkitTransition=r.transitions.create("-webkit-transform",(0,O.A)({},n)),e.style.transition=r.transitions.create("transform",(0,O.A)({},n)),e.style.webkitTransform="none",e.style.transform="none",m&&m(e,t)})),C=A(f),E=A(v),I=A((e=>{const t=Oo({timeout:b,style:x,easing:d},{mode:"exit"});e.style.webkitTransition=r.transitions.create("-webkit-transform",t),e.style.transition=r.transitions.create("transform",t),RC(u,e,c),g&&g(e)})),P=A((e=>{e.style.webkitTransition="",e.style.transition="",y&&y(e)})),L=n.useCallback((()=>{k.current&&RC(u,k.current,c)}),[u,c]);return n.useEffect((()=>{if(h||"down"===u||"right"===u)return;const e=(0,vo.A)((()=>{k.current&&RC(u,k.current,c)})),t=(0,xo.A)(k.current);return t.addEventListener("resize",e),()=>{e.clear(),t.removeEventListener("resize",e)}}),[u,h,c]),n.useEffect((()=>{h||L()}),[h,L]),(0,j.jsx)(_,(0,O.A)({nodeRef:k,onEnter:T,onEntered:C,onEntering:M,onExit:I,onExited:P,onExiting:E,addEndListener:e=>{a&&a(k.current,e)},appear:s,in:h,timeout:b},w,{children:(e,t)=>n.cloneElement(l,(0,O.A)({ref:S,style:(0,O.A)({visibility:"exited"!==e||h?void 0:"hidden"},x,l.props.style)},t))}))}));function DC(e){return(0,Yn.Ay)("MuiDrawer",e)}const zC=(0,Ln.A)("MuiDrawer",["root","docked","paper","paperAnchorLeft","paperAnchorRight","paperAnchorTop","paperAnchorBottom","paperAnchorDockedLeft","paperAnchorDockedRight","paperAnchorDockedTop","paperAnchorDockedBottom","modal"]),jC=["BackdropProps"],FC=["anchor","BackdropProps","children","className","elevation","hideBackdrop","ModalProps","onClose","open","PaperProps","SlideProps","TransitionComponent","transitionDuration","variant"],NC=(e,t)=>{const{ownerState:r}=e;return[t.root,("permanent"===r.variant||"persistent"===r.variant)&&t.docked,t.modal]},BC=(0,yn.Ay)(fa,{name:"MuiDrawer",slot:"Root",overridesResolver:NC})((e=>{let{theme:t}=e;return{zIndex:(t.vars||t).zIndex.drawer}})),VC=(0,yn.Ay)("div",{shouldForwardProp:Ta.A,name:"MuiDrawer",slot:"Docked",skipVariantsResolver:!1,overridesResolver:NC})({flex:"0 0 auto"}),UC=(0,yn.Ay)(Ci,{name:"MuiDrawer",slot:"Paper",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.paper,t[`paperAnchor${(0,ei.A)(r.anchor)}`],"temporary"!==r.variant&&t[`paperAnchorDocked${(0,ei.A)(r.anchor)}`]]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({overflowY:"auto",display:"flex",flexDirection:"column",height:"100%",flex:"1 0 auto",zIndex:(t.vars||t).zIndex.drawer,WebkitOverflowScrolling:"touch",position:"fixed",top:0,outline:0},"left"===r.anchor&&{left:0},"top"===r.anchor&&{top:0,left:0,right:0,height:"auto",maxHeight:"100%"},"right"===r.anchor&&{right:0},"bottom"===r.anchor&&{top:"auto",left:0,bottom:0,right:0,height:"auto",maxHeight:"100%"},"left"===r.anchor&&"temporary"!==r.variant&&{borderRight:`1px solid ${(t.vars||t).palette.divider}`},"top"===r.anchor&&"temporary"!==r.variant&&{borderBottom:`1px solid ${(t.vars||t).palette.divider}`},"right"===r.anchor&&"temporary"!==r.variant&&{borderLeft:`1px solid ${(t.vars||t).palette.divider}`},"bottom"===r.anchor&&"temporary"!==r.variant&&{borderTop:`1px solid ${(t.vars||t).palette.divider}`})})),HC={left:"right",right:"left",top:"down",bottom:"up"};const $C=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiDrawer"}),i=Io(),o=H(),a={enter:i.transitions.duration.enteringScreen,exit:i.transitions.duration.leavingScreen},{anchor:s="left",BackdropProps:l,children:c,className:u,elevation:d=16,hideBackdrop:h=!1,ModalProps:{BackdropProps:p}={},onClose:f,open:m=!1,PaperProps:g={},SlideProps:y,TransitionComponent:v=LC,transitionDuration:x=a,variant:b="temporary"}=r,_=(0,R.A)(r.ModalProps,jC),w=(0,R.A)(r,FC),k=n.useRef(!1);n.useEffect((()=>{k.current=!0}),[]);const S=function(e,t){let{direction:r}=e;return"rtl"===r&&function(e){return-1!==["left","right"].indexOf(e)}(t)?HC[t]:t}({direction:o?"rtl":"ltr"},s),A=s,T=(0,O.A)({},r,{anchor:A,elevation:d,open:m,variant:b},w),M=(e=>{const{classes:t,anchor:r,variant:n}=e,i={root:["root"],docked:[("permanent"===n||"persistent"===n)&&"docked"],modal:["modal"],paper:["paper",`paperAnchor${(0,ei.A)(r)}`,"temporary"!==n&&`paperAnchorDocked${(0,ei.A)(r)}`]};return(0,mn.A)(i,DC,t)})(T),C=(0,j.jsx)(UC,(0,O.A)({elevation:"temporary"===b?d:0,square:!0},g,{className:(0,fn.A)(M.paper,g.className),ownerState:T,children:c}));if("permanent"===b)return(0,j.jsx)(VC,(0,O.A)({className:(0,fn.A)(M.root,M.docked,u),ownerState:T,ref:t},w,{children:C}));const E=(0,j.jsx)(v,(0,O.A)({in:m,direction:HC[S],timeout:x,appear:k.current},y,{children:C}));return"persistent"===b?(0,j.jsx)(VC,(0,O.A)({className:(0,fn.A)(M.root,M.docked,u),ownerState:T,ref:t},w,{children:E})):(0,j.jsx)(BC,(0,O.A)({BackdropProps:(0,O.A)({},l,p,{transitionDuration:x}),className:(0,fn.A)(M.root,M.modal,u),open:m,ownerState:T,onClose:f,hideBackdrop:h,ref:t},w,_,{children:E}))}));var WC=r(27328);function qC(e){return(0,Yn.Ay)("MuiListItem",e)}const GC=(0,Ln.A)("MuiListItem",["root","container","focusVisible","dense","alignItemsFlexStart","disabled","divider","gutters","padding","button","secondaryAction","selected"]);function YC(e){return(0,Yn.Ay)("MuiListItemButton",e)}const XC=(0,Ln.A)("MuiListItemButton",["root","focusVisible","dense","alignItemsFlexStart","disabled","divider","gutters","selected"]);function ZC(e){return(0,Yn.Ay)("MuiListItemSecondaryAction",e)}(0,Ln.A)("MuiListItemSecondaryAction",["root","disableGutters"]);const KC=["className"],JC=(0,yn.Ay)("div",{name:"MuiListItemSecondaryAction",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.disableGutters&&t.disableGutters]}})((e=>{let{ownerState:t}=e;return(0,O.A)({position:"absolute",right:16,top:"50%",transform:"translateY(-50%)"},t.disableGutters&&{right:0})})),QC=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiListItemSecondaryAction"}),{className:i}=r,o=(0,R.A)(r,KC),a=n.useContext(no),s=(0,O.A)({},r,{disableGutters:a.disableGutters}),l=(e=>{const{disableGutters:t,classes:r}=e,n={root:["root",t&&"disableGutters"]};return(0,mn.A)(n,ZC,r)})(s);return(0,j.jsx)(JC,(0,O.A)({className:(0,fn.A)(l.root,i),ownerState:s,ref:t},o))}));QC.muiName="ListItemSecondaryAction";const eE=QC,tE=["className"],rE=["alignItems","autoFocus","button","children","className","component","components","componentsProps","ContainerComponent","ContainerProps","dense","disabled","disableGutters","disablePadding","divider","focusVisibleClassName","secondaryAction","selected","slotProps","slots"],nE=(0,yn.Ay)("div",{name:"MuiListItem",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.dense&&t.dense,"flex-start"===r.alignItems&&t.alignItemsFlexStart,r.divider&&t.divider,!r.disableGutters&&t.gutters,!r.disablePadding&&t.padding,r.button&&t.button,r.hasSecondaryAction&&t.secondaryAction]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({display:"flex",justifyContent:"flex-start",alignItems:"center",position:"relative",textDecoration:"none",width:"100%",boxSizing:"border-box",textAlign:"left"},!r.disablePadding&&(0,O.A)({paddingTop:8,paddingBottom:8},r.dense&&{paddingTop:4,paddingBottom:4},!r.disableGutters&&{paddingLeft:16,paddingRight:16},!!r.secondaryAction&&{paddingRight:48}),!!r.secondaryAction&&{[`& > .${XC.root}`]:{paddingRight:48}},{[`&.${GC.focusVisible}`]:{backgroundColor:(t.vars||t).palette.action.focus},[`&.${GC.selected}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity})`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity),[`&.${GC.focusVisible}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.focusOpacity}))`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity+t.palette.action.focusOpacity)}},[`&.${GC.disabled}`]:{opacity:(t.vars||t).palette.action.disabledOpacity}},"flex-start"===r.alignItems&&{alignItems:"flex-start"},r.divider&&{borderBottom:`1px solid ${(t.vars||t).palette.divider}`,backgroundClip:"padding-box"},r.button&&{transition:t.transitions.create("background-color",{duration:t.transitions.duration.shortest}),"&:hover":{textDecoration:"none",backgroundColor:(t.vars||t).palette.action.hover,"@media (hover: none)":{backgroundColor:"transparent"}},[`&.${GC.selected}:hover`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.hoverOpacity}))`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity+t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity})`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity)}}},r.hasSecondaryAction&&{paddingRight:48})})),iE=(0,yn.Ay)("li",{name:"MuiListItem",slot:"Container",overridesResolver:(e,t)=>t.container})({position:"relative"}),oE=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiListItem"}),{alignItems:i="center",autoFocus:o=!1,button:a=!1,children:s,className:l,component:c,components:u={},componentsProps:d={},ContainerComponent:h="li",ContainerProps:{className:p}={},dense:f=!1,disabled:m=!1,disableGutters:g=!1,disablePadding:y=!1,divider:v=!1,focusVisibleClassName:x,secondaryAction:b,selected:_=!1,slotProps:w={},slots:k={}}=r,S=(0,R.A)(r.ContainerProps,tE),A=(0,R.A)(r,rE),T=n.useContext(no),M=n.useMemo((()=>({dense:f||T.dense||!1,alignItems:i,disableGutters:g})),[i,T.dense,f,g]),C=n.useRef(null);(0,uo.A)((()=>{o&&C.current&&C.current.focus()}),[o]);const E=n.Children.toArray(s),I=E.length&&(0,WC.A)(E[E.length-1],["ListItemSecondaryAction"]),P=(0,O.A)({},r,{alignItems:i,autoFocus:o,button:a,dense:M.dense,disabled:m,disableGutters:g,disablePadding:y,divider:v,hasSecondaryAction:I,selected:_}),L=(e=>{const{alignItems:t,button:r,classes:n,dense:i,disabled:o,disableGutters:a,disablePadding:s,divider:l,hasSecondaryAction:c,selected:u}=e,d={root:["root",i&&"dense",!a&&"gutters",!s&&"padding",l&&"divider",o&&"disabled",r&&"button","flex-start"===t&&"alignItemsFlexStart",c&&"secondaryAction",u&&"selected"],container:["container"]};return(0,mn.A)(d,qC,n)})(P),D=(0,xn.A)(C,t),z=k.root||u.Root||nE,F=w.root||d.root||{},N=(0,O.A)({className:(0,fn.A)(L.root,F.className,l),disabled:m},A);let B=c||"li";return a&&(N.component=c||"div",N.focusVisibleClassName=(0,fn.A)(GC.focusVisible,x),B=Qn),I?(B=N.component||c?B:"div","li"===h&&("li"===B?B="div":"li"===N.component&&(N.component="div")),(0,j.jsx)(no.Provider,{value:M,children:(0,j.jsxs)(iE,(0,O.A)({as:h,className:(0,fn.A)(L.container,p),ref:D,ownerState:P},S,{children:[(0,j.jsx)(z,(0,O.A)({},F,!Yi(z)&&{as:B,ownerState:(0,O.A)({},P,F.ownerState)},N,{children:E})),E.pop()]}))})):(0,j.jsx)(no.Provider,{value:M,children:(0,j.jsxs)(z,(0,O.A)({},F,{as:B,ref:D},!Yi(z)&&{ownerState:(0,O.A)({},P,F.ownerState)},N,{children:[E,b&&(0,j.jsx)(eE,{children:b})]}))})})),aE=["alignItems","autoFocus","component","children","dense","disableGutters","divider","focusVisibleClassName","selected","className"],sE=(0,yn.Ay)(Qn,{shouldForwardProp:e=>(0,Ta.A)(e)||"classes"===e,name:"MuiListItemButton",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.dense&&t.dense,"flex-start"===r.alignItems&&t.alignItemsFlexStart,r.divider&&t.divider,!r.disableGutters&&t.gutters]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({display:"flex",flexGrow:1,justifyContent:"flex-start",alignItems:"center",position:"relative",textDecoration:"none",minWidth:0,boxSizing:"border-box",textAlign:"left",paddingTop:8,paddingBottom:8,transition:t.transitions.create("background-color",{duration:t.transitions.duration.shortest}),"&:hover":{textDecoration:"none",backgroundColor:(t.vars||t).palette.action.hover,"@media (hover: none)":{backgroundColor:"transparent"}},[`&.${XC.selected}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity})`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity),[`&.${XC.focusVisible}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.focusOpacity}))`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity+t.palette.action.focusOpacity)}},[`&.${XC.selected}:hover`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.hoverOpacity}))`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity+t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity})`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity)}},[`&.${XC.focusVisible}`]:{backgroundColor:(t.vars||t).palette.action.focus},[`&.${XC.disabled}`]:{opacity:(t.vars||t).palette.action.disabledOpacity}},r.divider&&{borderBottom:`1px solid ${(t.vars||t).palette.divider}`,backgroundClip:"padding-box"},"flex-start"===r.alignItems&&{alignItems:"flex-start"},!r.disableGutters&&{paddingLeft:16,paddingRight:16},r.dense&&{paddingTop:4,paddingBottom:4})})),lE=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiListItemButton"}),{alignItems:i="center",autoFocus:o=!1,component:a="div",children:s,dense:l=!1,disableGutters:c=!1,divider:u=!1,focusVisibleClassName:d,selected:h=!1,className:p}=r,f=(0,R.A)(r,aE),m=n.useContext(no),g=n.useMemo((()=>({dense:l||m.dense||!1,alignItems:i,disableGutters:c})),[i,m.dense,l,c]),y=n.useRef(null);(0,uo.A)((()=>{o&&y.current&&y.current.focus()}),[o]);const v=(0,O.A)({},r,{alignItems:i,dense:g.dense,disableGutters:c,divider:u,selected:h}),x=(e=>{const{alignItems:t,classes:r,dense:n,disabled:i,disableGutters:o,divider:a,selected:s}=e,l={root:["root",n&&"dense",!o&&"gutters",a&&"divider",i&&"disabled","flex-start"===t&&"alignItemsFlexStart",s&&"selected"]},c=(0,mn.A)(l,YC,r);return(0,O.A)({},r,c)})(v),b=(0,xn.A)(y,t);return(0,j.jsx)(no.Provider,{value:g,children:(0,j.jsx)(sE,(0,O.A)({ref:b,href:f.href||f.to,component:(f.href||f.to)&&"div"===a?"button":a,focusVisibleClassName:(0,fn.A)(x.focusVisible,d),ownerState:v,className:(0,fn.A)(x.root,p)},f,{classes:x,children:s}))})}));let cE=function(e){return e[e.ADMIN=1]="ADMIN",e[e.OPERATOR=20]="OPERATOR",e}({});const uE=e=>e.user.currentUser,dE=e=>e.user.listUser,hE=e=>e.user.loading,pE=e=>e.user.listUserSearch,fE=e=>{var t;return e.user&&cE.ADMIN===(null===(t=e.user.currentUser)||void 0===t?void 0:t.role_id)},mE=e=>{let{open:t,handleDrawerClose:r}=e;const n=Ye(),i=x(fE);return(0,j.jsx)(j.Fragment,{children:(0,j.jsx)($C,{anchor:"left",open:t,onClose:r,children:(0,j.jsx)(yi,{sx:{width:240},children:(0,j.jsxs)(so,{children:[(0,j.jsx)(oE,{disablePadding:!0,children:(0,j.jsxs)(lE,{onClick:()=>{r(),n("/console")},children:[(0,j.jsx)(Ip,{children:(0,j.jsx)(IC.A,{})}),(0,j.jsx)(Rp,{primary:"Dashboard"})]})},"dashboard"),(0,j.jsx)(oE,{disablePadding:!0,children:(0,j.jsxs)(lE,{onClick:()=>{r(),n("/console/workspaces")},children:[(0,j.jsx)(Ip,{children:(0,j.jsx)(EC.A,{})}),(0,j.jsx)(Rp,{primary:"Workspaces"})]})},"workspaces"),i?(0,j.jsx)(oE,{disablePadding:!0,children:(0,j.jsxs)(lE,{onClick:()=>{r(),n("/console/account-manager")},children:[(0,j.jsx)(Ip,{children:(0,j.jsx)(PC.A,{})}),(0,j.jsx)(Rp,{primary:"Account Manager"})]})},"account-manager"):null]})})})})},gE=/^\/console\/?.*/,yE=e=>{let{children:t}=e;const[r,i]=(0,n.useState)(!1);return(0,j.jsxs)(xE,{children:[(0,j.jsx)(CC,{handleDrawerOpen:()=>{i(!0)}}),(0,j.jsxs)(bE,{children:[(0,j.jsx)(mE,{open:r,handleDrawerClose:()=>{i(!1)}}),(0,j.jsx)(_E,{children:t})]})]})},vE=e=>{let{children:t}=e;return(0,j.jsx)(xE,{children:(0,j.jsx)(bE,{children:(0,j.jsx)(_E,{children:t})})})},xE=(0,yn.Ay)(yi)({height:"100%",width:"100%"}),bE=(0,yn.Ay)(yi)((()=>({backgroundColor:"#ffffff",display:"flex",paddingTop:60,height:"calc(100% - 60px)",paddingRight:10,overflow:"auto"}))),_E=(0,yn.Ay)("main",{shouldForwardProp:e=>"open"!==e})((e=>{let{theme:t}=e;return{flexGrow:1,padding:t.spacing(3),transition:t.transitions.create("margin",{easing:t.transitions.easing.sharp,duration:t.transitions.duration.leavingScreen})}})),wE=e=>{let{children:t}=e;const r=x(uE),i=qe(),o=Ye(),a=C(),s=x(Pf),[l,c]=(0,n.useState)(!s&&gE.test(i.pathname));(0,n.useEffect)((()=>{!s&&gE.test(i.pathname)&&u()}),[i.pathname,r]);const u=async()=>{if(r)return void(l&&c(!1));const e=Zl(),t="/login"===i.pathname;try{if(e)return await a(Md()),void(t&&o("/console"));if(!t)throw new Error("fail auth")}catch{o("/login",{replace:!0})}finally{l&&c(!1)}};return s||gE.test(i.pathname)?(0,j.jsx)(yE,{children:t}):(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(wi,{loading:l}),(0,j.jsx)(vE,{children:t})]})};var kE=r(95540),SE=r(19172),AE=r(17868),TE=r(83468);const ME=["onChange","maxRows","minRows","style","value"];function CE(e){return parseInt(e,10)||0}const EE={visibility:"hidden",position:"absolute",overflow:"hidden",height:0,top:0,left:0,transform:"translateZ(0)"};const IE=n.forwardRef((function(e,t){const{onChange:r,maxRows:i,minRows:o=1,style:a,value:s}=e,l=(0,R.A)(e,ME),{current:c}=n.useRef(null!=s),u=n.useRef(null),d=(0,Gi.A)(t,u),h=n.useRef(null),p=n.useRef(null),f=n.useCallback((()=>{const t=u.current,r=(0,ra.A)(t).getComputedStyle(t);if("0px"===r.width)return{outerHeightStyle:0,overflowing:!1};const n=p.current;n.style.width=r.width,n.value=t.value||e.placeholder||"x","\n"===n.value.slice(-1)&&(n.value+=" ");const a=r.boxSizing,s=CE(r.paddingBottom)+CE(r.paddingTop),l=CE(r.borderBottomWidth)+CE(r.borderTopWidth),c=n.scrollHeight;n.value="x";const d=n.scrollHeight;let h=c;o&&(h=Math.max(Number(o)*d,h)),i&&(h=Math.min(Number(i)*d,h)),h=Math.max(h,d);return{outerHeightStyle:h+("border-box"===a?s+l:0),overflowing:Math.abs(h-c)<=1}}),[i,o,e.placeholder]),m=n.useCallback((()=>{const e=f();if(void 0===(t=e)||null===t||0===Object.keys(t).length||0===t.outerHeightStyle&&!t.overflowing)return;var t;const r=e.outerHeightStyle,n=u.current;h.current!==r&&(h.current=r,n.style.height=`${r}px`),n.style.overflow=e.overflowing?"hidden":""}),[f]);(0,$o.A)((()=>{const e=()=>{m()};let t;const r=(0,TE.A)(e),n=u.current,i=(0,ra.A)(n);let o;return i.addEventListener("resize",r),"undefined"!==typeof ResizeObserver&&(o=new ResizeObserver(e),o.observe(n)),()=>{r.clear(),cancelAnimationFrame(t),i.removeEventListener("resize",r),o&&o.disconnect()}}),[f,m]),(0,$o.A)((()=>{m()}));return(0,j.jsxs)(n.Fragment,{children:[(0,j.jsx)("textarea",(0,O.A)({value:s,onChange:e=>{c||m(),r&&r(e)},ref:d,rows:o,style:a},l)),(0,j.jsx)("textarea",{"aria-hidden":!0,className:e.className,readOnly:!0,ref:p,tabIndex:-1,style:(0,O.A)({},EE,a,{paddingTop:0,paddingBottom:0})})]})}));function PE(e){let{props:t,states:r,muiFormControl:n}=e;return r.reduce(((e,r)=>(e[r]=t[r],n&&"undefined"===typeof t[r]&&(e[r]=n[r]),e)),{})}const OE=n.createContext(void 0);function RE(){return n.useContext(OE)}var LE=r(70869);const DE=function(e){let{styles:t,themeId:r,defaultTheme:n={}}=e;const i=di(n),o="function"===typeof t?t(r&&i[r]||i):t;return(0,j.jsx)(LE.A,{styles:o})};const zE=function(e){return(0,j.jsx)(DE,(0,O.A)({},e,{defaultTheme:Eo.A,themeId:X.A}))};function jE(e){return null!=e&&!(Array.isArray(e)&&0===e.length)}function FE(e){let t=arguments.length>1&&void 0!==arguments[1]&&arguments[1];return e&&(jE(e.value)&&""!==e.value||t&&jE(e.defaultValue)&&""!==e.defaultValue)}function NE(e){return(0,Yn.Ay)("MuiInputBase",e)}const BE=(0,Ln.A)("MuiInputBase",["root","formControl","focused","disabled","adornedStart","adornedEnd","error","sizeSmall","multiline","colorSecondary","fullWidth","hiddenLabel","readOnly","input","inputSizeSmall","inputMultiline","inputTypeSearch","inputAdornedStart","inputAdornedEnd","inputHiddenLabel"]),VE=["aria-describedby","autoComplete","autoFocus","className","color","components","componentsProps","defaultValue","disabled","disableInjectingGlobalStyles","endAdornment","error","fullWidth","id","inputComponent","inputProps","inputRef","margin","maxRows","minRows","multiline","name","onBlur","onChange","onClick","onFocus","onKeyDown","onKeyUp","placeholder","readOnly","renderSuffix","rows","size","slotProps","slots","startAdornment","type","value"],UE=(e,t)=>{const{ownerState:r}=e;return[t.root,r.formControl&&t.formControl,r.startAdornment&&t.adornedStart,r.endAdornment&&t.adornedEnd,r.error&&t.error,"small"===r.size&&t.sizeSmall,r.multiline&&t.multiline,r.color&&t[`color${(0,ei.A)(r.color)}`],r.fullWidth&&t.fullWidth,r.hiddenLabel&&t.hiddenLabel]},HE=(e,t)=>{const{ownerState:r}=e;return[t.input,"small"===r.size&&t.inputSizeSmall,r.multiline&&t.inputMultiline,"search"===r.type&&t.inputTypeSearch,r.startAdornment&&t.inputAdornedStart,r.endAdornment&&t.inputAdornedEnd,r.hiddenLabel&&t.inputHiddenLabel]},$E=(0,yn.Ay)("div",{name:"MuiInputBase",slot:"Root",overridesResolver:UE})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({},t.typography.body1,{color:(t.vars||t).palette.text.primary,lineHeight:"1.4375em",boxSizing:"border-box",position:"relative",cursor:"text",display:"inline-flex",alignItems:"center",[`&.${BE.disabled}`]:{color:(t.vars||t).palette.text.disabled,cursor:"default"}},r.multiline&&(0,O.A)({padding:"4px 0 5px"},"small"===r.size&&{paddingTop:1}),r.fullWidth&&{width:"100%"})})),WE=(0,yn.Ay)("input",{name:"MuiInputBase",slot:"Input",overridesResolver:HE})((e=>{let{theme:t,ownerState:r}=e;const n="light"===t.palette.mode,i=(0,O.A)({color:"currentColor"},t.vars?{opacity:t.vars.opacity.inputPlaceholder}:{opacity:n?.42:.5},{transition:t.transitions.create("opacity",{duration:t.transitions.duration.shorter})}),o={opacity:"0 !important"},a=t.vars?{opacity:t.vars.opacity.inputPlaceholder}:{opacity:n?.42:.5};return(0,O.A)({font:"inherit",letterSpacing:"inherit",color:"currentColor",padding:"4px 0 5px",border:0,boxSizing:"content-box",background:"none",height:"1.4375em",margin:0,WebkitTapHighlightColor:"transparent",display:"block",minWidth:0,width:"100%",animationName:"mui-auto-fill-cancel",animationDuration:"10ms","&::-webkit-input-placeholder":i,"&::-moz-placeholder":i,"&:-ms-input-placeholder":i,"&::-ms-input-placeholder":i,"&:focus":{outline:0},"&:invalid":{boxShadow:"none"},"&::-webkit-search-decoration":{WebkitAppearance:"none"},[`label[data-shrink=false] + .${BE.formControl} &`]:{"&::-webkit-input-placeholder":o,"&::-moz-placeholder":o,"&:-ms-input-placeholder":o,"&::-ms-input-placeholder":o,"&:focus::-webkit-input-placeholder":a,"&:focus::-moz-placeholder":a,"&:focus:-ms-input-placeholder":a,"&:focus::-ms-input-placeholder":a},[`&.${BE.disabled}`]:{opacity:1,WebkitTextFillColor:(t.vars||t).palette.text.disabled},"&:-webkit-autofill":{animationDuration:"5000s",animationName:"mui-auto-fill"}},"small"===r.size&&{paddingTop:1},r.multiline&&{height:"auto",resize:"none",padding:0,paddingTop:0},"search"===r.type&&{MozAppearance:"textfield"})})),qE=(0,j.jsx)(zE,{styles:{"@keyframes mui-auto-fill":{from:{display:"block"}},"@keyframes mui-auto-fill-cancel":{from:{display:"block"}}}}),GE=n.forwardRef((function(e,t){var r;const i=(0,vn.b)({props:e,name:"MuiInputBase"}),{"aria-describedby":o,autoComplete:a,autoFocus:s,className:l,components:c={},componentsProps:u={},defaultValue:d,disabled:h,disableInjectingGlobalStyles:p,endAdornment:f,fullWidth:m=!1,id:g,inputComponent:y="input",inputProps:v={},inputRef:x,maxRows:b,minRows:_,multiline:w=!1,name:k,onBlur:S,onChange:A,onClick:T,onFocus:M,onKeyDown:C,onKeyUp:E,placeholder:I,readOnly:P,renderSuffix:L,rows:D,slotProps:z={},slots:F={},startAdornment:N,type:B="text",value:V}=i,U=(0,R.A)(i,VE),H=null!=v.value?v.value:V,{current:$}=n.useRef(null!=H),W=n.useRef(),q=n.useCallback((e=>{0}),[]),G=(0,xn.A)(W,x,v.ref,q),[Y,X]=n.useState(!1),Z=RE();const K=PE({props:i,muiFormControl:Z,states:["color","disabled","error","hiddenLabel","size","required","filled"]});K.focused=Z?Z.focused:Y,n.useEffect((()=>{!Z&&h&&Y&&(X(!1),S&&S())}),[Z,h,Y,S]);const J=Z&&Z.onFilled,Q=Z&&Z.onEmpty,ee=n.useCallback((e=>{FE(e)?J&&J():Q&&Q()}),[J,Q]);(0,uo.A)((()=>{$&&ee({value:H})}),[H,ee,$]);n.useEffect((()=>{ee(W.current)}),[]);let te=y,re=v;w&&"input"===te&&(re=D?(0,O.A)({type:void 0,minRows:D,maxRows:D},re):(0,O.A)({type:void 0,maxRows:b,minRows:_},re),te=IE);n.useEffect((()=>{Z&&Z.setAdornedStart(Boolean(N))}),[Z,N]);const ne=(0,O.A)({},i,{color:K.color||"primary",disabled:K.disabled,endAdornment:f,error:K.error,focused:K.focused,formControl:Z,fullWidth:m,hiddenLabel:K.hiddenLabel,multiline:w,size:K.size,startAdornment:N,type:B}),ie=(e=>{const{classes:t,color:r,disabled:n,error:i,endAdornment:o,focused:a,formControl:s,fullWidth:l,hiddenLabel:c,multiline:u,readOnly:d,size:h,startAdornment:p,type:f}=e,m={root:["root",`color${(0,ei.A)(r)}`,n&&"disabled",i&&"error",l&&"fullWidth",a&&"focused",s&&"formControl",h&&"medium"!==h&&`size${(0,ei.A)(h)}`,u&&"multiline",p&&"adornedStart",o&&"adornedEnd",c&&"hiddenLabel",d&&"readOnly"],input:["input",n&&"disabled","search"===f&&"inputTypeSearch",u&&"inputMultiline","small"===h&&"inputSizeSmall",c&&"inputHiddenLabel",p&&"inputAdornedStart",o&&"inputAdornedEnd",d&&"readOnly"]};return(0,mn.A)(m,NE,t)})(ne),oe=F.root||c.Root||$E,ae=z.root||u.root||{},se=F.input||c.Input||WE;return re=(0,O.A)({},re,null!=(r=z.input)?r:u.input),(0,j.jsxs)(n.Fragment,{children:[!p&&qE,(0,j.jsxs)(oe,(0,O.A)({},ae,!Yi(oe)&&{ownerState:(0,O.A)({},ne,ae.ownerState)},{ref:t,onClick:e=>{W.current&&e.currentTarget===e.target&&W.current.focus(),T&&T(e)}},U,{className:(0,fn.A)(ie.root,ae.className,l,P&&"MuiInputBase-readOnly"),children:[N,(0,j.jsx)(OE.Provider,{value:null,children:(0,j.jsx)(se,(0,O.A)({ownerState:ne,"aria-invalid":K.error,"aria-describedby":o,autoComplete:a,autoFocus:s,defaultValue:d,disabled:K.disabled,id:g,onAnimationStart:e=>{ee("mui-auto-fill-cancel"===e.animationName?W.current:{value:"x"})},name:k,placeholder:I,readOnly:P,required:K.required,rows:D,value:H,onKeyDown:C,onKeyUp:E,type:B},re,!Yi(se)&&{as:te,ownerState:(0,O.A)({},ne,re.ownerState)},{ref:G,className:(0,fn.A)(ie.input,re.className,P&&"MuiInputBase-readOnly"),onBlur:e=>{S&&S(e),v.onBlur&&v.onBlur(e),Z&&Z.onBlur?Z.onBlur(e):X(!1)},onChange:function(e){if(!$){const t=e.target||W.current;if(null==t)throw new Error((0,AE.A)(1));ee({value:t.value})}for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n{K.disabled?e.stopPropagation():(M&&M(e),v.onFocus&&v.onFocus(e),Z&&Z.onFocus?Z.onFocus(e):X(!0))}}))}),f,L?L((0,O.A)({},K,{startAdornment:N})):null]}))]})}));function YE(e){return(0,Yn.Ay)("MuiInput",e)}const XE=(0,O.A)({},BE,(0,Ln.A)("MuiInput",["root","underline","input"])),ZE=["disableUnderline","components","componentsProps","fullWidth","inputComponent","multiline","slotProps","slots","type"],KE=(0,yn.Ay)($E,{shouldForwardProp:e=>(0,Ta.A)(e)||"classes"===e,name:"MuiInput",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[...UE(e,t),!r.disableUnderline&&t.underline]}})((e=>{let{theme:t,ownerState:r}=e;let n="light"===t.palette.mode?"rgba(0, 0, 0, 0.42)":"rgba(255, 255, 255, 0.7)";return t.vars&&(n=`rgba(${t.vars.palette.common.onBackgroundChannel} / ${t.vars.opacity.inputUnderline})`),(0,O.A)({position:"relative"},r.formControl&&{"label + &":{marginTop:16}},!r.disableUnderline&&{"&::after":{borderBottom:`2px solid ${(t.vars||t).palette[r.color].main}`,left:0,bottom:0,content:'""',position:"absolute",right:0,transform:"scaleX(0)",transition:t.transitions.create("transform",{duration:t.transitions.duration.shorter,easing:t.transitions.easing.easeOut}),pointerEvents:"none"},[`&.${XE.focused}:after`]:{transform:"scaleX(1) translateX(0)"},[`&.${XE.error}`]:{"&::before, &::after":{borderBottomColor:(t.vars||t).palette.error.main}},"&::before":{borderBottom:`1px solid ${n}`,left:0,bottom:0,content:'"\\00a0"',position:"absolute",right:0,transition:t.transitions.create("border-bottom-color",{duration:t.transitions.duration.shorter}),pointerEvents:"none"},[`&:hover:not(.${XE.disabled}, .${XE.error}):before`]:{borderBottom:`2px solid ${(t.vars||t).palette.text.primary}`,"@media (hover: none)":{borderBottom:`1px solid ${n}`}},[`&.${XE.disabled}:before`]:{borderBottomStyle:"dotted"}})})),JE=(0,yn.Ay)(WE,{name:"MuiInput",slot:"Input",overridesResolver:HE})({}),QE=n.forwardRef((function(e,t){var r,n,i,o;const a=(0,vn.b)({props:e,name:"MuiInput"}),{disableUnderline:s,components:l={},componentsProps:c,fullWidth:u=!1,inputComponent:d="input",multiline:h=!1,slotProps:p,slots:f={},type:m="text"}=a,g=(0,R.A)(a,ZE),y=(e=>{const{classes:t,disableUnderline:r}=e,n={root:["root",!r&&"underline"],input:["input"]},i=(0,mn.A)(n,YE,t);return(0,O.A)({},t,i)})(a),v={root:{ownerState:{disableUnderline:s}}},x=(null!=p?p:c)?(0,SE.A)(null!=p?p:c,v):v,b=null!=(r=null!=(n=f.root)?n:l.Root)?r:KE,_=null!=(i=null!=(o=f.input)?o:l.Input)?i:JE;return(0,j.jsx)(GE,(0,O.A)({slots:{root:b,input:_},slotProps:x,fullWidth:u,inputComponent:d,multiline:h,ref:t,type:m},g,{classes:y}))}));QE.muiName="Input";const eI=QE;var tI=r(47260),rI=r(72819);const nI=(0,yn.Ay)("input",{shouldForwardProp:e=>"error"!==e})((e=>{let{error:t}=e;return{width:250,height:24,borderRadius:4,border:"1px solid",borderColor:t?"red":"#d9d9d9",padding:"5px 10px",marginBottom:15,transition:"all 0.3s",outline:"none",":focus, :hover":{borderColor:"#1677ff"}}})),iI={position:"absolute",right:5,top:8,fontSize:20,cursor:"pointer",color:"rgba(0,0,0,0.6)"},oI=(0,yn.Ay)(Hi)({fontSize:12,minHeight:18,color:"red",lineHeight:"14px",marginTop:-14,wordBreak:"break-word"}),aI=e=>{let{error:t,...r}=e;const[i,o]=(0,n.useState)("password");return(0,j.jsxs)(yi,{sx:{position:"relative"},children:[(0,j.jsx)(nI,{...r,type:i}),"password"===i?(0,j.jsx)(tI.A,{style:iI,onClick:()=>{o("text")}}):(0,j.jsx)(rI.A,{style:iI,onClick:()=>{o("password")}}),(0,j.jsx)(oI,{children:t})]})},sI=/^(?=.*\d)(?=.*[!#$%&()*+,-./@_|])(?=.*[a-zA-Z]).{6,255}$/,lI=/^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,cI=/[^!#$%&()*+,-./@_|a-zA-Z0-9]/,uI=(0,yn.Ay)(yi)({display:"flex",justifyContent:"space-between"}),dI=(0,yn.Ay)(yi)({margin:"20px 0"}),hI=(0,yn.Ay)(yi)({display:"flex",justifyContent:"space-between",marginBottom:10,gap:30}),pI=(0,yn.Ay)(Hi)({fontSize:14,marginTop:7,width:"100%"}),fI=e=>{let{onClose:t,open:r,onSubmit:i}=e;const[o,a]=(0,n.useState)({}),[s,l]=(0,n.useState)({}),c=(e,t)=>{const{name:r,value:n}=e.target;if(l({...s,[r]:n}),"new_password"===r&&s.confirm_password){const e={},i=(null===t||void 0===t?void 0:t(n))||"",l=d(s.confirm_password);return i?(e[r]=i,e.confirm_password=l):(e[r]=i,e.confirm_password=n!==s.confirm_password?"Passwords do not match":""),void a({...o,...e})}a({...o,[r]:(null===t||void 0===t?void 0:t(n))||""})},u=e=>e?e.length>255?"The text may not be longer than 255 characters":sI.test(e)?cI.test(e)?"Allowed special characters (!#$%&()*+,-./@_|)":"":"Your password must be at least 6 characters long and must contain at least one letter, number, and special character":"This field is required",d=e=>e?e!==s.new_password?"Passwords do not match":"":"This field is required",h=async()=>{const e={password:s.password?"":"This field is required",new_password:u(s.new_password),confirm_password:u(s.confirm_password)};o.new_password||o.confirm_password||(e.new_password||e.confirm_password?a(e):await i(s.password,s.new_password))},p=()=>{a({}),l({}),t()};return(0,j.jsxs)(Wp,{open:r,onClose:p,children:[(0,j.jsx)(Zp,{children:(0,j.jsxs)(uI,{children:[(0,j.jsx)(Hi,{sx:{fontWeight:600,fontSize:18},children:"Change Password"}),(0,j.jsxs)(Hi,{style:{fontSize:13},children:[(0,j.jsx)("span",{style:{color:"red"},children:"*"})," is required"]})]})}),(0,j.jsx)(ef,{children:(0,j.jsxs)(dI,{children:[(0,j.jsxs)(hI,{children:[(0,j.jsxs)(pI,{children:["Old Password ",(0,j.jsx)("span",{style:{color:"red"},children:"*"})]}),(0,j.jsx)(aI,{onChange:e=>c(e,u),name:"password",error:o.password,onBlur:e=>c(e,u),placeholder:"Old Password"})]}),(0,j.jsxs)(hI,{children:[(0,j.jsxs)(pI,{children:["New Password ",(0,j.jsx)("span",{style:{color:"red"},children:"*"})]}),(0,j.jsx)(aI,{onChange:e=>c(e,u),name:"new_password",error:o.new_password,placeholder:"New Password",onBlur:()=>{const{reEnter:e,new_password:t}=s;t||a((e=>({...e,new_password:"This field is required"}))),e&&e!==t&&a((e=>({...e,reEnter:"Passwords do not match"})))}})]}),(0,j.jsxs)(hI,{children:[(0,j.jsxs)(pI,{children:["Confirm Password ",(0,j.jsx)("span",{style:{color:"red"},children:"*"})]}),(0,j.jsx)(aI,{onChange:e=>c(e,d),name:"confirm_password",error:o.confirm_password,placeholder:"Confirm Password",onBlur:e=>c(e,d)})]})]})}),(0,j.jsxs)(of,{children:[(0,j.jsx)(gf,{onClick:p,variant:"outlined",children:"Close"}),(0,j.jsx)(gf,{onClick:()=>h(),variant:"contained",children:"UPDATE"})]})]})},mI=(0,yn.Ay)(yi)({margin:"20px 0 0"}),gI=e=>{let{onClose:t,open:r,onSubmit:i,loading:o,titleSubmit:a,description:s}=e;const[l,c]=(0,n.useState)("");return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsxs)(Wp,{open:r,onClose:t,maxWidth:"xs",children:[(0,j.jsx)(Zp,{children:(0,j.jsxs)(Hi,{style:{whiteSpace:"pre-wrap"},children:[s,"This operation cannot be undone. To continue, type",(0,j.jsx)("span",{style:{fontWeight:600},children:"DELETE"})," in the box below:"]})}),(0,j.jsx)(ef,{children:(0,j.jsx)(mI,{children:(0,j.jsx)(nI,{placeholder:"DELETE",value:l,onChange:e=>c(e.target.value),sx:{width:"calc(100% - 20px)"}})})}),(0,j.jsxs)(of,{children:[(0,j.jsx)(gf,{onClick:t,variant:"outlined",children:"CANCEL"}),(0,j.jsx)(gf,{onClick:()=>{"DELETE"===l&&(null===i||void 0===i||i(),c(""))},color:"error",variant:"contained",children:a})]})]}),(0,j.jsx)(wi,{loading:o})]})},yI=(0,yn.Ay)(yi)({padding:"0 20px"}),vI=(0,yn.Ay)(yi)({display:"flex",margin:"20px 0 10px 0",alignItems:"center",maxWidth:1e3}),xI=(0,yn.Ay)("h2")({marginBottom:40}),bI=(0,yn.Ay)(Hi)({fontWeight:700,minWidth:272}),_I=(0,yn.Ay)(Hi)({width:250,minWidth:250}),wI=()=>{var e;const t=x(uE),r=x(hE),i=C(),o=Ye(),[a,s]=(0,n.useState)(!1),[l,c]=(0,n.useState)(!1),[u,d]=(0,n.useState)(!1),[h,p]=(0,n.useState)(),f=(0,n.useRef)(null),{enqueueSnackbar:m}=hn(),g=(e,t)=>{m(t,{variant:e})};(0,n.useEffect)((()=>{t&&p(t.name)}),[]);const y=()=>{s(!1)},v=()=>{c(!1)};return(0,j.jsxs)(yI,{children:[(0,j.jsx)(gI,{titleSubmit:"Delete My Account",onClose:y,open:a,onSubmit:async()=>{if(!t)return;Wl(await i(Ed()))?g("error","Account deleted failed!"):o("/login"),y()},description:"Delete account will erase all of your data."}),(0,j.jsx)(fI,{onSubmit:async(e,t)=>{Wl(await i(Id({old_password:e,new_password:t})))?g("error","Failed to Change Password!"):g("success","Your password has been successfully changed!"),v()},open:l,onClose:v}),(0,j.jsx)(xI,{children:"Account Profile"}),(0,j.jsxs)(vI,{children:[(0,j.jsx)(_I,{children:"Organization"}),(0,j.jsx)(bI,{children:null===t||void 0===t||null===(e=t.organization)||void 0===e?void 0:e.name})]}),(0,j.jsxs)(vI,{children:[(0,j.jsx)(_I,{children:"Name"}),u?(0,j.jsx)(eI,{sx:{width:400},autoFocus:!0,onBlur:async e=>{if(!t||!t.name||!t.email)return;if(h===t.name)return void d(!1);const r=e.target;if(r.value){Wl(await i(Cd({name:r.value,email:t.email})))?g("error","Full name edited failed!"):g("success","Full name edited successfully!")}else g("error","Full name can't be empty!"),p(null===t||void 0===t?void 0:t.name);d(!1)},placeholder:"Name",value:h,onChange:e=>{p(e.target.value)},onKeyDown:e=>{if("Escape"===e.key)return p(null===t||void 0===t?void 0:t.name),void d(!1);var r,n,i;"Enter"!==e.key||f.current&&(null===(r=f.current)||void 0===r||null===(n=r.querySelector("input"))||void 0===n||null===(i=n.blur)||void 0===i||i.call(n))},ref:f}):(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(yi,{children:h||(null===t||void 0===t?void 0:t.name)}),(0,j.jsx)(oi,{sx:{ml:1},onClick:()=>d(!0),children:(0,j.jsx)(kE.A,{})})]})]}),(0,j.jsxs)(vI,{children:[(0,j.jsx)(_I,{children:"Email"}),(0,j.jsx)(bI,{children:null===t||void 0===t?void 0:t.email})]}),(0,j.jsxs)(vI,{children:[(0,j.jsx)(_I,{children:"Role"}),(0,j.jsx)(bI,{children:(e=>{if(!e)return;let t="";switch(e){case cE.ADMIN:t="Admin";break;case cE.OPERATOR:t="Operator"}return t})(null===t||void 0===t?void 0:t.role_id)})]}),(0,j.jsxs)(vI,{sx:{justifyContent:"space-between",mt:10,maxWidth:600},children:[(0,j.jsx)(gf,{variant:"contained",color:"primary",onClick:()=>{c(!0)},children:"Change Password"}),(0,j.jsx)(gf,{variant:"contained",color:"error",onClick:()=>{s(!0)},children:"Delete Account"})]}),(0,j.jsx)(wi,{loading:r})]})},kI=()=>(0,j.jsx)(yi,{sx:{fontWeight:600,fontSize:18,mt:4},children:"You account has been deleted."});var SI=r(63471),AI=r(65173),TI=r.n(AI);var MI=r(67598),CI=r(11188);function EI(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1;return(0,CI.A)(e,t,r)}function II(e){if(e.type)return e;if("#"===e.charAt(0))return II(function(e){e=e.slice(1);const t=new RegExp(`.{1,${e.length>=6?2:1}}`,"g");let r=e.match(t);return r&&1===r[0].length&&(r=r.map((e=>e+e))),r?`rgb${4===r.length?"a":""}(${r.map(((e,t)=>t<3?parseInt(e,16):Math.round(parseInt(e,16)/255*1e3)/1e3)).join(", ")})`:""}(e));const t=e.indexOf("("),r=e.substring(0,t);if(-1===["rgb","rgba","hsl","hsla","color"].indexOf(r))throw new Error((0,AE.A)(9,e));let n,i=e.substring(t+1,e.length-1);if("color"===r){if(i=i.split(" "),n=i.shift(),4===i.length&&"/"===i[3].charAt(0)&&(i[3]=i[3].slice(1)),-1===["srgb","display-p3","a98-rgb","prophoto-rgb","rec-2020"].indexOf(n))throw new Error((0,AE.A)(10,n))}else i=i.split(",");return i=i.map((e=>parseFloat(e))),{type:r,values:i,colorSpace:n}}function PI(e){const{type:t,colorSpace:r}=e;let{values:n}=e;return-1!==t.indexOf("rgb")?n=n.map(((e,t)=>t<3?parseInt(e,10):e)):-1!==t.indexOf("hsl")&&(n[1]=`${n[1]}%`,n[2]=`${n[2]}%`),n=-1!==t.indexOf("color")?`${r} ${n.join(" ")}`:`${n.join(", ")}`,`${t}(${n})`}function OI(e,t){return e=II(e),t=EI(t),"rgb"!==e.type&&"hsl"!==e.type||(e.type+="a"),"color"===e.type?e.values[3]=`/${t}`:e.values[3]=t,PI(e)}function RI(e,t){if(e=II(e),t=EI(t),-1!==e.type.indexOf("hsl"))e.values[2]*=1-t;else if(-1!==e.type.indexOf("rgb")||-1!==e.type.indexOf("color"))for(let r=0;r<3;r+=1)e.values[r]*=1-t;return PI(e)}function LI(e,t){if(e=II(e),t=EI(t),-1!==e.type.indexOf("hsl"))e.values[2]+=(100-e.values[2])*t;else if(-1!==e.type.indexOf("rgb"))for(let r=0;r<3;r+=1)e.values[r]+=(255-e.values[r])*t;else if(-1!==e.type.indexOf("color"))for(let r=0;r<3;r+=1)e.values[r]+=(1-e.values[r])*t;return PI(e)}function DI(e){return(0,Yn.Ay)("MuiDataGrid",e)}const zI=(0,Ln.A)("MuiDataGrid",["actionsCell","aggregationColumnHeader","aggregationColumnHeader--alignLeft","aggregationColumnHeader--alignCenter","aggregationColumnHeader--alignRight","aggregationColumnHeaderLabel","autoHeight","autosizing","booleanCell","cell--editable","cell--editing","cell--textCenter","cell--textLeft","cell--textRight","cell--withRenderer","cell--rangeTop","cell--rangeBottom","cell--rangeLeft","cell--rangeRight","cell--selectionMode","cell","cellContent","cellCheckbox","cellSkeleton","checkboxInput","columnHeader--alignCenter","columnHeader--alignLeft","columnHeader--alignRight","columnHeader--dragging","columnHeader--moving","columnHeader--numeric","columnHeader--sortable","columnHeader--sorted","columnHeader--filtered","columnHeader","columnHeaderCheckbox","columnHeaderDraggableContainer","columnHeaderDropZone","columnHeaderTitle","columnHeaderTitleContainer","columnHeaderTitleContainerContent","columnGroupHeader","columnHeader--filledGroup","columnHeader--emptyGroup","columnHeader--showColumnBorder","columnHeaders","columnHeadersInner","columnHeadersInner--scrollable","columnSeparator--resizable","columnSeparator--resizing","columnSeparator--sideLeft","columnSeparator--sideRight","columnSeparator","columnsPanel","columnsPanelRow","detailPanel","detailPanels","detailPanelToggleCell","detailPanelToggleCell--expanded","footerCell","panel","panelHeader","panelWrapper","panelContent","panelFooter","paper","editBooleanCell","editInputCell","filterForm","filterFormDeleteIcon","filterFormLogicOperatorInput","filterFormColumnInput","filterFormOperatorInput","filterFormValueInput","filterIcon","footerContainer","headerFilterRow","iconButtonContainer","iconSeparator","main","menu","menuIcon","menuIconButton","menuOpen","menuList","overlay","overlayWrapper","overlayWrapperInner","root","root--densityStandard","root--densityComfortable","root--densityCompact","root--disableUserSelection","row","row--editable","row--editing","row--lastVisible","row--dragging","row--dynamicHeight","row--detailPanelExpanded","rowReorderCellPlaceholder","rowCount","rowReorderCellContainer","rowReorderCell","rowReorderCell--draggable","scrollArea--left","scrollArea--right","scrollArea","selectedRowCount","sortIcon","toolbarContainer","toolbarFilterList","virtualScroller","virtualScrollerContent","virtualScrollerContent--overflowed","virtualScrollerRenderZone","pinnedColumns","pinnedColumns--left","pinnedColumns--right","pinnedColumnHeaders","pinnedColumnHeaders--left","pinnedColumnHeaders--right","withBorderColor","cell--withRightBorder","columnHeader--withRightBorder","treeDataGroupingCell","treeDataGroupingCellToggle","groupingCriteriaCell","groupingCriteriaCellToggle","pinnedRows","pinnedRows--top","pinnedRows--bottom","pinnedRowsRenderZone"]);const jI={[`.${zI.columnSeparator}, .${zI["columnSeparator--resizing"]}`]:{visibility:"visible",width:"auto"}},FI={[`& .${zI.iconButtonContainer}`]:{visibility:"visible",width:"auto"},[`& .${zI.menuIcon}`]:{width:"auto",visibility:"visible"}},NI=(0,yn.Ay)("div",{name:"MuiDataGrid",slot:"Root",overridesResolver:(e,t)=>[{[`&.${zI.autoHeight}`]:t.autoHeight},{[`&.${zI.aggregationColumnHeader}`]:t.aggregationColumnHeader},{[`&.${zI["aggregationColumnHeader--alignLeft"]}`]:t["aggregationColumnHeader--alignLeft"]},{[`&.${zI["aggregationColumnHeader--alignCenter"]}`]:t["aggregationColumnHeader--alignCenter"]},{[`&.${zI["aggregationColumnHeader--alignRight"]}`]:t["aggregationColumnHeader--alignRight"]},{[`&.${zI.aggregationColumnHeaderLabel}`]:t.aggregationColumnHeaderLabel},{[`&.${zI["root--disableUserSelection"]} .${zI.cell}`]:t["root--disableUserSelection"]},{[`&.${zI.autosizing}`]:t.autosizing},{[`& .${zI.editBooleanCell}`]:t.editBooleanCell},{[`& .${zI["cell--editing"]}`]:t["cell--editing"]},{[`& .${zI["cell--textCenter"]}`]:t["cell--textCenter"]},{[`& .${zI["cell--textLeft"]}`]:t["cell--textLeft"]},{[`& .${zI["cell--textRight"]}`]:t["cell--textRight"]},{[`& .${zI["cell--withRenderer"]}`]:t["cell--withRenderer"]},{[`& .${zI.cell}`]:t.cell},{[`& .${zI["cell--rangeTop"]}`]:t["cell--rangeTop"]},{[`& .${zI["cell--rangeBottom"]}`]:t["cell--rangeBottom"]},{[`& .${zI["cell--rangeLeft"]}`]:t["cell--rangeLeft"]},{[`& .${zI["cell--rangeRight"]}`]:t["cell--rangeRight"]},{[`& .${zI["cell--withRightBorder"]}`]:t["cell--withRightBorder"]},{[`& .${zI.cellContent}`]:t.cellContent},{[`& .${zI.cellCheckbox}`]:t.cellCheckbox},{[`& .${zI.cellSkeleton}`]:t.cellSkeleton},{[`& .${zI.checkboxInput}`]:t.checkboxInput},{[`& .${zI["columnHeader--alignCenter"]}`]:t["columnHeader--alignCenter"]},{[`& .${zI["columnHeader--alignLeft"]}`]:t["columnHeader--alignLeft"]},{[`& .${zI["columnHeader--alignRight"]}`]:t["columnHeader--alignRight"]},{[`& .${zI["columnHeader--dragging"]}`]:t["columnHeader--dragging"]},{[`& .${zI["columnHeader--moving"]}`]:t["columnHeader--moving"]},{[`& .${zI["columnHeader--numeric"]}`]:t["columnHeader--numeric"]},{[`& .${zI["columnHeader--sortable"]}`]:t["columnHeader--sortable"]},{[`& .${zI["columnHeader--sorted"]}`]:t["columnHeader--sorted"]},{[`& .${zI["columnHeader--withRightBorder"]}`]:t["columnHeader--withRightBorder"]},{[`& .${zI.columnHeader}`]:t.columnHeader},{[`& .${zI.headerFilterRow}`]:t.headerFilterRow},{[`& .${zI.columnHeaderCheckbox}`]:t.columnHeaderCheckbox},{[`& .${zI.columnHeaderDraggableContainer}`]:t.columnHeaderDraggableContainer},{[`& .${zI.columnHeaderTitleContainer}`]:t.columnHeaderTitleContainer},{[`& .${zI["columnSeparator--resizable"]}`]:t["columnSeparator--resizable"]},{[`& .${zI["columnSeparator--resizing"]}`]:t["columnSeparator--resizing"]},{[`& .${zI.columnSeparator}`]:t.columnSeparator},{[`& .${zI.filterIcon}`]:t.filterIcon},{[`& .${zI.iconSeparator}`]:t.iconSeparator},{[`& .${zI.menuIcon}`]:t.menuIcon},{[`& .${zI.menuIconButton}`]:t.menuIconButton},{[`& .${zI.menuOpen}`]:t.menuOpen},{[`& .${zI.menuList}`]:t.menuList},{[`& .${zI["row--editable"]}`]:t["row--editable"]},{[`& .${zI["row--editing"]}`]:t["row--editing"]},{[`& .${zI["row--dragging"]}`]:t["row--dragging"]},{[`& .${zI.row}`]:t.row},{[`& .${zI.rowReorderCellPlaceholder}`]:t.rowReorderCellPlaceholder},{[`& .${zI.rowReorderCell}`]:t.rowReorderCell},{[`& .${zI["rowReorderCell--draggable"]}`]:t["rowReorderCell--draggable"]},{[`& .${zI.sortIcon}`]:t.sortIcon},{[`& .${zI.withBorderColor}`]:t.withBorderColor},{[`& .${zI.treeDataGroupingCell}`]:t.treeDataGroupingCell},{[`& .${zI.treeDataGroupingCellToggle}`]:t.treeDataGroupingCellToggle},{[`& .${zI.detailPanelToggleCell}`]:t.detailPanelToggleCell},{[`& .${zI["detailPanelToggleCell--expanded"]}`]:t["detailPanelToggleCell--expanded"]},t.root]})((e=>{let{theme:t}=e;const r=function(e){return e.vars?e.vars.palette.TableCell.border:"light"===e.palette.mode?LI(OI(e.palette.divider,1),.88):RI(OI(e.palette.divider,1),.68)}(t),n=t.shape.borderRadius;return(0,O.A)({"--unstable_DataGrid-radius":"number"===typeof n?`${n}px`:n,"--unstable_DataGrid-headWeight":t.typography.fontWeightMedium,"--unstable_DataGrid-overlayBackground":t.vars?`rgba(${t.vars.palette.background.defaultChannel} / ${t.vars.palette.action.disabledOpacity})`:OI(t.palette.background.default,t.palette.action.disabledOpacity),"--DataGrid-cellOffsetMultiplier":2,flex:1,boxSizing:"border-box",position:"relative",borderWidth:"1px",borderStyle:"solid",borderColor:r,borderRadius:"var(--unstable_DataGrid-radius)",color:(t.vars||t).palette.text.primary},t.typography.body2,{outline:"none",height:"100%",display:"flex",minWidth:0,minHeight:0,flexDirection:"column",overflowAnchor:"none",[`&.${zI.autoHeight}`]:{height:"auto",[`& .${zI["row--lastVisible"]} .${zI.cell}`]:{borderBottomColor:"transparent"}},[`&.${zI.autosizing}`]:{[`& .${zI.columnHeaderTitleContainerContent} > *`]:{overflow:"visible !important"},[`& .${zI.cell} > *`]:{overflow:"visible !important",whiteSpace:"nowrap"},[`& .${zI.groupingCriteriaCell}`]:{width:"unset"},[`& .${zI.treeDataGroupingCell}`]:{width:"unset"}},[`& .${zI["virtualScrollerContent--overflowed"]} .${zI["row--lastVisible"]} .${zI.cell}`]:{borderBottomColor:"transparent"},[`& .${zI.columnHeader}, & .${zI.cell}`]:{WebkitTapHighlightColor:"transparent",lineHeight:null,padding:"0 10px",boxSizing:"border-box"},[`& .${zI.columnHeader}:focus-within, & .${zI.cell}:focus-within`]:{outline:`solid ${t.vars?`rgba(${t.vars.palette.primary.mainChannel} / 0.5)`:OI(t.palette.primary.main,.5)} 1px`,outlineWidth:1,outlineOffset:-1},[`& .${zI.columnHeader}:focus, & .${zI.cell}:focus`]:{outline:`solid ${t.palette.primary.main} 1px`},[`& .${zI.columnHeaderCheckbox}, & .${zI.cellCheckbox}`]:{padding:0,justifyContent:"center",alignItems:"center"},[`& .${zI.columnHeader}`]:{position:"relative",display:"flex",alignItems:"center"},[`& .${zI["columnHeader--sorted"]} .${zI.iconButtonContainer}, & .${zI["columnHeader--filtered"]} .${zI.iconButtonContainer}`]:{visibility:"visible",width:"auto"},[`& .${zI.columnHeader}:not(.${zI["columnHeader--sorted"]}) .${zI.sortIcon}`]:{opacity:0,transition:t.transitions.create(["opacity"],{duration:t.transitions.duration.shorter})},[`& .${zI.columnHeaderTitleContainer}`]:{display:"flex",alignItems:"center",minWidth:0,flex:1,whiteSpace:"nowrap",overflow:"hidden",position:"relative"},[`& .${zI.columnHeaderTitleContainerContent}`]:{overflow:"hidden",display:"flex",alignItems:"center"},[`& .${zI["columnHeader--filledGroup"]} .${zI.columnHeaderTitleContainer}`]:{borderBottomWidth:"1px",borderBottomStyle:"solid",boxSizing:"border-box"},[`& .${zI["columnHeader--filledGroup"]}.${zI["columnHeader--showColumnBorder"]} .${zI.columnHeaderTitleContainer}`]:{borderBottom:"none"},[`& .${zI["columnHeader--filledGroup"]}.${zI["columnHeader--showColumnBorder"]}`]:{borderBottomWidth:"1px",borderBottomStyle:"solid",boxSizing:"border-box"},[`& .${zI.headerFilterRow}`]:{borderTop:`1px solid ${r}`},[`& .${zI.sortIcon}, & .${zI.filterIcon}`]:{fontSize:"inherit"},[`& .${zI["columnHeader--sortable"]}`]:{cursor:"pointer"},[`& .${zI["columnHeader--alignCenter"]} .${zI.columnHeaderTitleContainer}`]:{justifyContent:"center"},[`& .${zI["columnHeader--alignRight"]} .${zI.columnHeaderDraggableContainer}, & .${zI["columnHeader--alignRight"]} .${zI.columnHeaderTitleContainer}`]:{flexDirection:"row-reverse"},[`& .${zI["columnHeader--alignCenter"]} .${zI.menuIcon}, & .${zI["columnHeader--alignRight"]} .${zI.menuIcon}`]:{marginRight:"auto",marginLeft:-6},[`& .${zI["columnHeader--alignRight"]} .${zI.menuIcon}, & .${zI["columnHeader--alignRight"]} .${zI.menuIcon}`]:{marginRight:"auto",marginLeft:-10},[`& .${zI["columnHeader--moving"]}`]:{backgroundColor:(t.vars||t).palette.action.hover},[`& .${zI.columnSeparator}`]:{visibility:"hidden",position:"absolute",zIndex:100,display:"flex",flexDirection:"column",justifyContent:"center",color:r},"@media (hover: hover)":{[`& .${zI.columnHeaders}:hover`]:jI,[`& .${zI.columnHeader}:hover`]:FI,[`& .${zI.columnHeader}:not(.${zI["columnHeader--sorted"]}):hover .${zI.sortIcon}`]:{opacity:.5}},"@media (hover: none)":{[`& .${zI.columnHeaders}`]:jI,[`& .${zI.columnHeader}`]:FI},[`& .${zI["columnSeparator--sideLeft"]}`]:{left:-12},[`& .${zI["columnSeparator--sideRight"]}`]:{right:-12},[`& .${zI["columnSeparator--resizable"]}`]:{cursor:"col-resize",touchAction:"none","&:hover":{color:(t.vars||t).palette.text.primary,"@media (hover: none)":{color:r}},[`&.${zI["columnSeparator--resizing"]}`]:{color:(t.vars||t).palette.text.primary},"& svg":{pointerEvents:"none"}},[`& .${zI.iconSeparator}`]:{color:"inherit"},[`& .${zI.menuIcon}`]:{width:0,visibility:"hidden",fontSize:20,marginRight:-10,display:"flex",alignItems:"center"},[`.${zI.menuOpen}`]:{visibility:"visible",width:"auto"},[`& .${zI.row}`]:{display:"flex",width:"fit-content",breakInside:"avoid","&:hover, &.Mui-hovered":{backgroundColor:(t.vars||t).palette.action.hover,"@media (hover: none)":{backgroundColor:"transparent"}},"&.Mui-selected":{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity})`:OI(t.palette.primary.main,t.palette.action.selectedOpacity),"&:hover, &.Mui-hovered":{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / calc(\n ${t.vars.palette.action.selectedOpacity} + \n ${t.vars.palette.action.hoverOpacity}\n ))`:OI(t.palette.primary.main,t.palette.action.selectedOpacity+t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity})`:OI(t.palette.primary.main,t.palette.action.selectedOpacity)}}}},[`& .${zI.cell}`]:{display:"flex",alignItems:"center",borderBottom:"1px solid","&.Mui-selected":{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity})`:OI(t.palette.primary.main,t.palette.action.selectedOpacity),"&:hover, &.Mui-hovered":{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity+t.palette.action.hoverOpacity})`:OI(t.palette.primary.main,t.palette.action.selectedOpacity+t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity})`:OI(t.palette.primary.main,t.palette.action.selectedOpacity)}}}},[`&.${zI["root--disableUserSelection"]} .${zI.cell}`]:{userSelect:"none"},[`& .${zI.row}:not(.${zI["row--dynamicHeight"]}) > .${zI.cell}`]:{overflow:"hidden",whiteSpace:"nowrap"},[`& .${zI.cellContent}`]:{overflow:"hidden",textOverflow:"ellipsis"},[`& .${zI.cell}.${zI["cell--selectionMode"]}`]:{cursor:"default"},[`& .${zI.cell}.${zI["cell--editing"]}`]:{padding:1,display:"flex",boxShadow:t.shadows[2],backgroundColor:(t.vars||t).palette.background.paper,"&:focus-within":{outline:`solid ${(t.vars||t).palette.primary.main} 1px`,outlineOffset:"-1px"}},[`& .${zI["row--editing"]}`]:{boxShadow:t.shadows[2]},[`& .${zI["row--editing"]} .${zI.cell}`]:{boxShadow:t.shadows[0],backgroundColor:(t.vars||t).palette.background.paper},[`& .${zI.editBooleanCell}`]:{display:"flex",height:"100%",width:"100%",alignItems:"center",justifyContent:"center"},[`& .${zI.booleanCell}[data-value="true"]`]:{color:(t.vars||t).palette.text.secondary},[`& .${zI.booleanCell}[data-value="false"]`]:{color:(t.vars||t).palette.text.disabled},[`& .${zI.actionsCell}`]:{display:"inline-flex",alignItems:"center",gridGap:t.spacing(1)},[`& .${zI.rowReorderCell}`]:{display:"inline-flex",flex:1,alignItems:"center",justifyContent:"center",opacity:(t.vars||t).palette.action.disabledOpacity},[`& .${zI["rowReorderCell--draggable"]}`]:{cursor:"move",opacity:1},[`& .${zI.rowReorderCellContainer}`]:{padding:0,alignItems:"stretch"},[`.${zI.withBorderColor}`]:{borderColor:r},[`& .${zI["cell--withRightBorder"]}`]:{borderRightWidth:"1px",borderRightStyle:"solid"},[`& .${zI["columnHeader--withRightBorder"]}`]:{borderRightWidth:"1px",borderRightStyle:"solid"},[`& .${zI["cell--textLeft"]}`]:{justifyContent:"flex-start"},[`& .${zI["cell--textRight"]}`]:{justifyContent:"flex-end"},[`& .${zI["cell--textCenter"]}`]:{justifyContent:"center"},[`& .${zI.columnHeaderDraggableContainer}`]:{display:"flex",width:"100%",height:"100%"},[`& .${zI.rowReorderCellPlaceholder}`]:{display:"none"},[`& .${zI["columnHeader--dragging"]}, & .${zI["row--dragging"]}`]:{background:(t.vars||t).palette.background.paper,padding:"0 12px",borderRadius:"var(--unstable_DataGrid-radius)",opacity:(t.vars||t).palette.action.disabledOpacity},[`& .${zI["row--dragging"]}`]:{background:(t.vars||t).palette.background.paper,padding:"0 12px",borderRadius:"var(--unstable_DataGrid-radius)",opacity:(t.vars||t).palette.action.disabledOpacity,[`& .${zI.rowReorderCellPlaceholder}`]:{display:"flex"}},[`& .${zI.treeDataGroupingCell}`]:{display:"flex",alignItems:"center",width:"100%"},[`& .${zI.treeDataGroupingCellToggle}`]:{flex:"0 0 28px",alignSelf:"stretch",marginRight:t.spacing(2)},[`& .${zI.groupingCriteriaCell}`]:{display:"flex",alignItems:"center",width:"100%"},[`& .${zI.groupingCriteriaCellToggle}`]:{flex:"0 0 28px",alignSelf:"stretch",marginRight:t.spacing(2)}})})),BI={};function VI(e,t){const r=n.useRef(BI);return r.current===BI&&(r.current=e(t)),r}const UI=[];function HI(e){n.useEffect(e,UI)}const $I=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"warning",r=!1;const n=Array.isArray(e)?e.join("\n"):e;return()=>{r||(r=!0,"error"===t?console.error(n):console.warn(n))}},WI=Object.is;function qI(e,t){if(e===t)return!0;if(!(e instanceof Object)||!(t instanceof Object))return!1;let r=0,n=0;for(const i in e){if(r+=1,!WI(e[i],t[i]))return!1;if(!(i in t))return!1}for(const i in t)n+=1;return r===n}$I(["MUI: `useGridSelector` has been called before the initialization of the state.","This hook can only be used inside the context of the grid."]);function GI(e,t){return function(e){return e.acceptsApiRef}(t)?t(e):t(e.current.state)}const YI=Object.is,XI=qI,ZI=()=>({state:null,equals:null,selector:null}),KI=function(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:YI;const i=VI(ZI),o=null!==i.current.selector,[a,s]=n.useState(o?null:GI(e,t));return i.current.state=a,i.current.equals=r,i.current.selector=t,HI((()=>e.current.store.subscribe((()=>{const t=GI(e,i.current.selector);i.current.equals(i.current.state,t)||(i.current.state=t,s(t))})))),a},JI=n.createContext(void 0);function QI(){const e=n.useContext(JI);if(void 0===e)throw new Error(["MUI: Could not find the data grid private context.","It looks like you rendered your component outside of a DataGrid, DataGridPro or DataGridPremium parent component.","This can also happen if you are bundling multiple versions of the data grid."].join("\n"));return e}const eP=n.createContext(void 0);const tP=()=>{const e=n.useContext(eP);if(!e)throw new Error("MUI: useGridRootProps should only be used inside the DataGrid, DataGridPro or DataGridPremium component.");return e};var rP="NOT_FOUND";var nP=function(e,t){return e===t};function iP(e,t){var r="object"===typeof t?t:{equalityCheck:t},n=r.equalityCheck,i=void 0===n?nP:n,o=r.maxSize,a=void 0===o?1:o,s=r.resultEqualityCheck,l=function(e){return function(t,r){if(null===t||null===r||t.length!==r.length)return!1;for(var n=t.length,i=0;i-1){var i=r[n];return n>0&&(r.splice(n,1),r.unshift(i)),i.value}return rP}return{get:n,put:function(t,i){n(t)===rP&&(r.unshift({key:t,value:i}),r.length>e&&r.pop())},getEntries:function(){return r},clear:function(){r=[]}}}(a,l);function u(){var t=c.get(arguments);if(t===rP){if(t=e.apply(null,arguments),s){var r=c.getEntries().find((function(e){return s(e.value,t)}));r&&(t=r.value)}c.put(arguments,t)}return t}return u.clearCache=function(){return c.clear()},u}function oP(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n0)throw new Error("Unsupported number of selectors");let a;if(e&&t&&r&&n&&i&&o)a=(a,s)=>{const l=lP(a),c=null!=s?s:l?a.current.instanceId:cP,u=l?a.current.state:a,d=e(u,c),h=t(u,c),p=r(u,c),f=n(u,c),m=i(u,c);return o(d,h,p,f,m)};else if(e&&t&&r&&n&&i)a=(o,a)=>{const s=lP(o),l=null!=a?a:s?o.current.instanceId:cP,c=s?o.current.state:o,u=e(c,l),d=t(c,l),h=r(c,l),p=n(c,l);return i(u,d,h,p)};else if(e&&t&&r&&n)a=(i,o)=>{const a=lP(i),s=null!=o?o:a?i.current.instanceId:cP,l=a?i.current.state:i,c=e(l,s),u=t(l,s),d=r(l,s);return n(c,u,d)};else if(e&&t&&r)a=(n,i)=>{const o=lP(n),a=null!=i?i:o?n.current.instanceId:cP,s=o?n.current.state:n,l=e(s,a),c=t(s,a);return r(l,c)};else{if(!e||!t)throw new Error("Missing arguments");a=(r,n)=>{const i=lP(r),o=null!=n?n:i?r.current.instanceId:cP,a=i?r.current.state:r,s=e(a,o);return t(s)}}return a.acceptsApiRef=!0,a},dP=function(){for(var e=arguments.length,t=new Array(e),r=0;re.density,pP=uP(hP,(e=>e.value)),fP=uP(hP,(e=>e.factor)),mP=e=>e.columns,gP=uP(mP,(e=>e.orderedFields)),yP=uP(mP,(e=>e.lookup)),vP=dP(gP,yP,((e,t)=>e.map((e=>t[e])))),xP=uP(mP,(e=>e.columnVisibilityModel)),bP=dP(vP,xP,((e,t)=>e.filter((e=>!1!==t[e.field])))),_P=dP(bP,(e=>e.map((e=>e.field)))),wP=dP(bP,(e=>{const t=[];let r=0;for(let n=0;n{const r=e.length;return 0===r?0:t[r-1]+e[r-1].computedWidth})),SP=dP(vP,(e=>e.filter((e=>e.filterable)))),AP=dP(vP,(e=>e.reduce(((e,t)=>(t.filterable&&(e[t.field]=t),e)),{}))),TP=e=>e.columnGrouping,MP=dP(TP,(e=>{var t;return null!=(t=null==e?void 0:e.unwrappedGroupingModel)?t:{}})),CP=dP(TP,(e=>{var t;return null!=(t=null==e?void 0:e.lookup)?t:{}})),EP=dP(TP,(e=>{var t;return null!=(t=null==e?void 0:e.headerStructure)?t:[]})),IP=uP(TP,(e=>{var t;return null!=(t=null==e?void 0:e.maxDepth)?t:0})),PP=e=>e.rows,OP=uP(PP,(e=>e.totalRowCount)),RP=uP(PP,(e=>e.loading)),LP=uP(PP,(e=>e.totalTopLevelRowCount)),DP=uP(PP,(e=>e.dataRowIdToModelLookup)),zP=uP(PP,(e=>e.dataRowIdToIdLookup)),jP=uP(PP,(e=>e.tree)),FP=uP(PP,(e=>e.groupingName)),NP=uP(PP,(e=>e.treeDepths)),BP=dP(PP,(e=>{const t=Object.entries(e.treeDepths);return 0===t.length?1:t.filter((e=>{let[,t]=e;return t>0})).map((e=>{let[t]=e;return Number(t)})).sort(((e,t)=>t-e))[0]+1})),VP=uP(PP,(e=>e.dataRowIds)),UP=dP(uP(PP,(e=>null==e?void 0:e.additionalRowGroups)),(e=>{var t,r;const n=null==e?void 0:e.pinnedRows;return{bottom:null==n||null==(t=n.bottom)?void 0:t.map((e=>{var t;return{id:e.id,model:null!=(t=e.model)?t:{}}})),top:null==n||null==(r=n.top)?void 0:r.map((e=>{var t;return{id:e.id,model:null!=(t=e.model)?t:{}}}))}})),HP=uP(UP,(e=>{var t,r;return((null==e||null==(t=e.top)?void 0:t.length)||0)+((null==e||null==(r=e.bottom)?void 0:r.length)||0)})),$P=()=>{var e;const t=QI(),r=tP(),n=KI(t,bP),i=KI(t,OP),o=KI(t,IP),a=KI(t,HP);let s="grid";return null!=(e=r.experimentalFeatures)&&e.ariaV7&&r.treeData&&(s="treegrid"),{role:s,"aria-colcount":n.length,"aria-rowcount":o+1+a+i,"aria-multiselectable":!r.disableMultipleRowSelection}},WP=["children","className"],qP=n.forwardRef((function(e,t){var r;const i=tP(),{children:o,className:a}=e,s=(0,R.A)(e,WP),l=QI(),c=KI(l,pP),u=n.useRef(null),d=(0,Gi.A)(u,t),h=null!=(r=i.experimentalFeatures)&&r.ariaV7?null:$P,p="function"===typeof h?h():null,f=(0,O.A)({},i,{density:c}),m=(e=>{const{autoHeight:t,density:r,classes:n}=e,i={root:["root",t&&"autoHeight",`root--density${(0,MI.A)(r)}`,"withBorderColor"]};return(0,mn.A)(i,DI,n)})(f);l.current.register("public",{rootElementRef:u});const[g,y]=n.useState(!1);return(0,$o.A)((()=>{y(!0)}),[]),g?(0,j.jsx)(NI,(0,O.A)({ref:d,className:(0,fn.A)(a,m.root),ownerState:f},p,s,{children:o})):null}));function GP(){var e,t;const r=tP();return(0,j.jsxs)(n.Fragment,{children:[(0,j.jsx)(r.slots.preferencesPanel,(0,O.A)({},null==(e=r.slotProps)?void 0:e.preferencesPanel)),r.slots.toolbar&&(0,j.jsx)(r.slots.toolbar,(0,O.A)({},null==(t=r.slotProps)?void 0:t.toolbar))]})}const YP=["ownerState"],XP=["variants"],ZP=["name","slot","skipVariantsResolver","skipSx","overridesResolver"];function KP(e){return"ownerState"!==e&&"theme"!==e&&"sx"!==e&&"as"!==e}const JP=(0,ci.A)(),QP=e=>e?e.charAt(0).toLowerCase()+e.slice(1):e;function eO(e){let{defaultTheme:t,theme:r,themeId:n}=e;return i=r,0===Object.keys(i).length?t:r[n]||r;var i}function tO(e){return e?(t,r)=>r[e]:null}function rO(e,t){let{ownerState:r}=t,n=(0,R.A)(t,YP);const i="function"===typeof e?e((0,O.A)({ownerState:r},n)):e;if(Array.isArray(i))return i.flatMap((e=>rO(e,(0,O.A)({ownerState:r},n))));if(i&&"object"===typeof i&&Array.isArray(i.variants)){const{variants:e=[]}=i;let t=(0,R.A)(i,XP);return e.forEach((e=>{let i=!0;"function"===typeof e.props?i=e.props((0,O.A)({ownerState:r},n,r)):Object.keys(e.props).forEach((t=>{(null==r?void 0:r[t])!==e.props[t]&&n[t]!==e.props[t]&&(i=!1)})),i&&(Array.isArray(t)||(t=[t]),t.push("function"===typeof e.style?e.style((0,O.A)({ownerState:r},n,r)):e.style))})),t}return i}const nO=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const{themeId:t,defaultTheme:r=JP,rootShouldForwardProp:n=KP,slotShouldForwardProp:i=KP}=e,o=e=>(0,si.A)((0,O.A)({},e,{theme:eO((0,O.A)({},e,{defaultTheme:r,themeId:t}))}));return o.__mui_systemSx=!0,function(e){let a=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};(0,ai.internal_processStyles)(e,(e=>e.filter((e=>!(null!=e&&e.__mui_systemSx)))));const{name:s,slot:l,skipVariantsResolver:c,skipSx:u,overridesResolver:d=tO(QP(l))}=a,h=(0,R.A)(a,ZP),p=void 0!==c?c:l&&"Root"!==l&&"root"!==l||!1,f=u||!1;let m=KP;"Root"===l||"root"===l?m=n:l?m=i:function(e){return"string"===typeof e&&e.charCodeAt(0)>96}(e)&&(m=void 0);const g=(0,ai.default)(e,(0,O.A)({shouldForwardProp:m,label:undefined},h)),y=e=>"function"===typeof e&&e.__emotion_real!==e||(0,SE.Q)(e)?n=>rO(e,(0,O.A)({},n,{theme:eO({theme:n.theme,defaultTheme:r,themeId:t})})):e,v=function(n){let i=y(n);for(var a=arguments.length,l=new Array(a>1?a-1:0),c=1;c{const n=eO((0,O.A)({},e,{defaultTheme:r,themeId:t}));if(!n.components||!n.components[s]||!n.components[s].styleOverrides)return null;const i=n.components[s].styleOverrides,o={};return Object.entries(i).forEach((t=>{let[r,i]=t;o[r]=rO(i,(0,O.A)({},e,{theme:n}))})),d(e,o)})),s&&!p&&u.push((e=>{var n;const i=eO((0,O.A)({},e,{defaultTheme:r,themeId:t}));return rO({variants:null==i||null==(n=i.components)||null==(n=n[s])?void 0:n.variants},(0,O.A)({},e,{theme:i}))})),f||u.push(o);const h=u.length-l.length;if(Array.isArray(n)&&h>0){const e=new Array(h).fill("");i=[...n,...e],i.raw=[...n.raw,...e]}const m=g(i,...u);return e.muiName&&(m.muiName=e.muiName),m};return g.withConfig&&(v.withConfig=g.withConfig),v}}(),iO=nO("div",{name:"MuiDataGrid",slot:"Main",overridesResolver:(e,t)=>t.main})((()=>({position:"relative",flexGrow:1,display:"flex",flexDirection:"column",overflow:"hidden"}))),oO=n.forwardRef(((e,t)=>{var r;const n=tP(),i=(e=>{const{classes:t}=e;return(0,mn.A)({root:["main"]},DI,t)})(n),o=null!=(r=n.experimentalFeatures)&&r.ariaV7?$P:null,a="function"===typeof o?o():null;return(0,j.jsx)(iO,(0,O.A)({ref:t,className:i.root,ownerState:n},a,{children:e.children}))})),aO=e=>e.sorting,sO=uP(aO,(e=>e.sortedRows)),lO=dP(sO,DP,((e,t)=>e.map((e=>{var r;return{id:e,model:null!=(r=t[e])?r:{}}})))),cO=uP(aO,(e=>e.sortModel)),uO=dP(cO,(e=>{const t=e.reduce(((t,r,n)=>(t[r.field]={sortDirection:r.sort,sortIndex:e.length>1?n+1:void 0},t)),{});return t})),dO=e=>e.filter,hO=uP(dO,(e=>e.filterModel)),pO=(uP(hO,(e=>e.quickFilterValues)),uP(dO,(e=>e.filteredRowsLookup))),fO=(uP(dO,(e=>e.filteredDescendantCountLookup)),dP((e=>e.visibleRowsLookup),lO,((e,t)=>t.filter((t=>!1!==e[t.id]))))),mO=dP(fO,(e=>e.map((e=>e.id)))),gO=dP(pO,lO,((e,t)=>t.filter((t=>!1!==e[t.id])))),yO=dP(gO,(e=>e.map((e=>e.id)))),vO=dP(fO,jP,BP,((e,t,r)=>r<2?e:e.filter((e=>{var r;return 0===(null==(r=t[e.id])?void 0:r.depth)})))),xO=uP(fO,(e=>e.length)),bO=uP(vO,(e=>e.length)),_O=dP(hO,yP,((e,t)=>{var r;return null==(r=e.items)?void 0:r.filter((e=>{var r,n;if(!e.field)return!1;const i=t[e.field];if(null==i||!i.filterOperators||0===(null==i||null==(r=i.filterOperators)?void 0:r.length))return!1;const o=i.filterOperators.find((t=>t.value===e.operator));return!!o&&(!o.InputComponent||null!=e.value&&""!==(null==(n=e.value)?void 0:n.toString()))}))})),wO=dP(_O,(e=>{const t=e.reduce(((e,t)=>(e[t.field]?e[t.field].push(t):e[t.field]=[t],e)),{});return t})),kO=e=>e.focus,SO=uP(kO,(e=>e.cell)),AO=uP(kO,(e=>e.columnHeader)),TO=(uP(kO,(e=>e.columnHeaderFilter)),uP(kO,(e=>e.columnGroupHeader))),MO=e=>e.tabIndex,CO=uP(MO,(e=>e.cell)),EO=uP(MO,(e=>e.columnHeader)),IO=(uP(MO,(e=>e.columnHeaderFilter)),uP(MO,(e=>e.columnGroupHeader))),PO=e=>e.columnMenu;function OO(e){const{VirtualScrollerComponent:t,ColumnHeadersProps:r,children:i}=e,o=QI(),a=tP(),s=n.useRef(null),l=KI(o,bP),c=KI(o,wO),u=KI(o,uO),d=KI(o,wP),h=KI(o,EO),p=KI(o,CO),f=KI(o,IO),m=KI(o,AO),g=KI(o,TO),y=KI(o,fP),v=KI(o,IP),x=KI(o,PO),b=KI(o,xP),_=KI(o,EP),w=!(null===f&&null===h&&null===p);(0,$o.A)((()=>{o.current.computeSizeAndPublishResizeEvent();const e=s.current;if("undefined"===typeof ResizeObserver)return()=>{};let t;const r=new ResizeObserver((()=>{t=requestAnimationFrame((()=>{o.current.computeSizeAndPublishResizeEvent()}))}));return e&&r.observe(e),()=>{t&&window.cancelAnimationFrame(t),e&&r.unobserve(e)}}),[o]);const k=n.useRef(null),S=n.useRef(null),A=n.useRef(null);o.current.register("private",{columnHeadersContainerElementRef:S,columnHeadersElementRef:k,virtualScrollerRef:A,mainElementRef:s});const T=!!o.current.getRootDimensions();return(0,j.jsxs)(oO,{ref:s,children:[(0,j.jsx)(a.slots.columnHeaders,(0,O.A)({ref:S,innerRef:k,visibleColumns:l,filterColumnLookup:c,sortColumnLookup:u,columnPositions:d,columnHeaderTabIndexState:h,columnGroupHeaderTabIndexState:f,columnHeaderFocus:m,columnGroupHeaderFocus:g,densityFactor:y,headerGroupingMaxDepth:v,columnMenuState:x,columnVisibility:b,columnGroupsHeaderStructure:_,hasOtherElementInTabSequence:w},r)),T&&(0,j.jsx)(t,{ref:A}),i]})}function RO(){var e;const t=tP();return t.hideFooter?null:(0,j.jsx)(t.slots.footer,(0,O.A)({},null==(e=t.slotProps)?void 0:e.footer))}const LO=n.createContext(void 0);function DO(e){let{privateApiRef:t,props:r,children:i}=e;const o=n.useRef(t.current.getPublicApi());return(0,j.jsx)(eP.Provider,{value:r,children:(0,j.jsx)(JI.Provider,{value:t,children:(0,j.jsx)(LO.Provider,{value:o,children:i})})})}function zO(e){return"function"===typeof e}function jO(e){return"object"===typeof e&&null!==e}function FO(e){return e.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&")}const NO=(e,t,r)=>Math.max(t,Math.min(r,e));function BO(e,t){if(e===t)return!0;if(e&&t&&"object"===typeof e&&"object"===typeof t){if(e.constructor!==t.constructor)return!1;if(Array.isArray(e)){const r=e.length;if(r!==t.length)return!1;for(let n=0;n{let e=i+=1831565813;return e=Math.imul(e^e>>>15,1|e),e^=e+Math.imul(e^e>>>7,61|e),((e^e>>>14)>>>0)/4294967296});var i;return()=>t+(r-t)*n()}function UO(e){return"function"===typeof structuredClone?structuredClone(e):JSON.parse(JSON.stringify(e))}function HO(e,t,r){const i=n.useRef(!0);n.useEffect((()=>{i.current=!1,e.current.register(r,t)}),[e,r,t]),i.current&&e.current.register(r,t)}const $O=function(){try{const e="__some_random_key_you_are_not_going_to_use__";return window.localStorage.setItem(e,e),window.localStorage.removeItem(e),!0}catch(e){return!1}}()&&null!=window.localStorage.getItem("DEBUG"),WO=()=>{},qO={debug:WO,info:WO,warn:WO,error:WO},GO=["debug","info","warn","error"];function YO(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:console;const n=GO.indexOf(t);if(-1===n)throw new Error(`MUI: Log level ${t} not recognized.`);const i=GO.reduce(((t,i,o)=>(t[i]=o>=n?function(){for(var t=arguments.length,n=new Array(t),o=0;o(this.listeners.add(e),()=>{this.listeners.delete(e)}),this.getSnapshot=()=>this.value,this.update=e=>{this.value=e,this.listeners.forEach((t=>t(e)))},this.value=e,this.listeners=new Set}}class ZO{constructor(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1e3;this.timeouts=new Map,this.cleanupTimeout=1e3,this.cleanupTimeout=e}register(e,t,r){this.timeouts||(this.timeouts=new Map);const n=setTimeout((()=>{"function"===typeof t&&t(),this.timeouts.delete(r.cleanupToken)}),this.cleanupTimeout);this.timeouts.set(r.cleanupToken,n)}unregister(e){const t=this.timeouts.get(e.cleanupToken);t&&(this.timeouts.delete(e.cleanupToken),clearTimeout(t))}reset(){this.timeouts&&(this.timeouts.forEach(((e,t)=>{this.unregister({cleanupToken:t})})),this.timeouts=void 0)}}class KO{constructor(){this.registry=new FinalizationRegistry((e=>{"function"===typeof e&&e()}))}register(e,t,r){this.registry.register(e,t,r)}unregister(e){this.registry.unregister(e)}reset(){}}var JO=function(e){return e.DataGrid="DataGrid",e.DataGridPro="DataGridPro",e}(JO||{});class QO{}const eR={registry:null},tR=function(e){let t=0;return function(r,i,o,a){null===e.registry&&(e.registry="undefined"!==typeof FinalizationRegistry?new KO:new ZO);const[s]=n.useState(new QO),l=n.useRef(null),c=n.useRef();c.current=o;const u=n.useRef(null);if(!l.current&&c.current){const n=(e,t,r)=>{var n;t.defaultMuiPrevented||(null==(n=c.current)||n.call(c,e,t,r))};l.current=r.current.subscribeEvent(i,n,a),t+=1,u.current={cleanupToken:t},e.registry.register(s,(()=>{var e;null==(e=l.current)||e.call(l),l.current=null,u.current=null}),u.current)}else!c.current&&l.current&&(l.current(),l.current=null,u.current&&(e.registry.unregister(u.current),u.current=null));n.useEffect((()=>{if(!l.current&&c.current){const e=(e,t,r)=>{var n;t.defaultMuiPrevented||(null==(n=c.current)||n.call(c,e,t,r))};l.current=r.current.subscribeEvent(i,e,a)}return u.current&&e.registry&&(e.registry.unregister(u.current),u.current=null),()=>{var e;null==(e=l.current)||e.call(l),l.current=null}}),[r,i,a])}}(eR),rR={isFirst:!0};function nR(e,t,r){tR(e,t,r,rR)}class iR{constructor(){this.maxListeners=20,this.warnOnce=!1,this.events={}}on(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=this.events[e];n||(n={highPriority:new Map,regular:new Map},this.events[e]=n),r.isFirst?n.highPriority.set(t,!0):n.regular.set(t,!0)}removeListener(e,t){this.events[e]&&(this.events[e].regular.delete(t),this.events[e].highPriority.delete(t))}removeAllListeners(){this.events={}}emit(e){const t=this.events[e];if(!t)return;const r=Array.from(t.highPriority.keys()),n=Array.from(t.regular.keys());for(var i=arguments.length,o=new Array(i>1?i-1:0),a=1;a=0;s-=1){const e=r[s];t.highPriority.has(e)&&e.apply(this,o)}for(let s=0;se.current,i.register=(t,r)=>{Object.keys(r).forEach((n=>{const o=r[n],a=i[n];if(!0===(null==a?void 0:a.spying)?a.target=o:i[n]=o,"public"===t){const t=e.current,r=t[n];!0===(null==r?void 0:r.spying)?r.target=o:t[n]=o}}))},i.register("private",{caches:{},eventManager:new iR}),i}(r)),r.current||(r.current=function(e){return{get state(){return e.current.state},get store(){return e.current.store},get instanceId(){return e.current.instanceId},[oR]:e.current}}(i));const o=n.useCallback((function(){for(var e=arguments.length,r=new Array(e),n=0;nvoid 0!==e.isPropagationStopped)(s)&&s.isPropagationStopped())return;const l=t.signature===JO.DataGridPro?{api:i.current.getPublicApi()}:{};i.current.eventManager.emit(o,a,s,l)}),[i,t.signature]),a=n.useCallback(((e,t,r)=>{i.current.eventManager.on(e,t,r);const n=i.current;return()=>{n.eventManager.removeListener(e,t)}}),[i]);return HO(i,{subscribeEvent:a,publishEvent:o},"public"),n.useImperativeHandle(e,(()=>r.current),[r]),n.useEffect((()=>{const e=i.current;return()=>{e.publishEvent("unmount")}}),[i]),i}const lR="none",cR={rowTreeCreation:"rowTree",filtering:"rowTree",sorting:"rowTree",visibleRowsLookupCreation:"rowTree"},uR=(e,t)=>{const r=sR(e,t);return((e,t)=>{HO(e,{getLogger:n.useCallback((e=>$O?YO(e,"debug",t.logger):t.logLevel?YO(e,t.logLevel.toString(),t.logger):qO),[t.logLevel,t.logger])},"private")})(r,t),((e,t)=>{const r=n.useRef({}),[,i]=n.useState(),o=n.useCallback((e=>{r.current[e.stateId]=e}),[]),a=n.useCallback(((n,i)=>{let o;if(o=zO(n)?n(e.current.state):n,e.current.state===o)return!1;let a=!1;const s=[];if(Object.keys(r.current).forEach((t=>{const n=r.current[t],i=n.stateSelector(e.current.state,e.current.instanceId),l=n.stateSelector(o,e.current.instanceId);l!==i&&(s.push({stateId:n.stateId,hasPropChanged:l!==n.propModel}),void 0!==n.propModel&&l!==n.propModel&&(a=!0))})),s.length>1)throw new Error(`You're not allowed to update several sub-state in one transaction. You already updated ${s[0].stateId}, therefore, you're not allowed to update ${s.map((e=>e.stateId)).join(", ")} in the same transaction.`);if(a||(e.current.state=o,e.current.publishEvent&&e.current.publishEvent("stateChange",o),e.current.store.update(o)),1===s.length){const{stateId:n,hasPropChanged:l}=s[0],c=r.current[n],u=c.stateSelector(o,e.current.instanceId);if(c.propOnChange&&l){const r=t.signature===JO.DataGridPro?{api:e.current,reason:i}:{reason:i};c.propOnChange(u,r)}a||e.current.publishEvent(c.changeEvent,u,{reason:i})}return!a}),[e,t.signature]),s=n.useCallback(((t,r,n)=>e.current.setState((e=>(0,O.A)({},e,{[t]:r(e[t])})),n)),[e]),l=n.useCallback((()=>i((()=>e.current.state))),[e]),c={updateControlState:s,registerControlState:o};HO(e,{setState:a,forceUpdate:l},"public"),HO(e,c,"private")})(r,t),(e=>{const t=n.useRef({}),r=n.useRef(!1),i=n.useCallback((e=>{!r.current&&e&&(r.current=!0,Object.values(e.appliers).forEach((e=>{e()})),r.current=!1)}),[]),o=n.useCallback(((e,r,n)=>{t.current[e]||(t.current[e]={processors:new Map,appliers:{}});const o=t.current[e];return o.processors.get(r)!==n&&(o.processors.set(r,n),i(o)),()=>{t.current[e].processors.set(r,null)}}),[i]),a=n.useCallback(((e,r,n)=>(t.current[e]||(t.current[e]={processors:new Map,appliers:{}}),t.current[e].appliers[r]=n,()=>{const n=t.current[e].appliers,i=(0,R.A)(n,[r].map(Gs));t.current[e].appliers=i})),[]),s=n.useCallback((e=>{const r=t.current[e];i(r)}),[i]),l={unstable_applyPipeProcessors:n.useCallback((function(){for(var e=arguments.length,r=new Array(e),n=0;nt?t(e,a):e),o):o}),[])};HO(e,{registerPipeProcessor:o,registerPipeApplier:a,requestPipeProcessorsApplication:s},"private"),HO(e,l,"public")})(r),(e=>{const t=n.useRef(new Map),r=n.useRef({}),i=n.useCallback(((t,n,i)=>{const o=()=>{const e=r.current[n],i=(0,R.A)(e,[t].map(Gs));r.current[n]=i};r.current[n]||(r.current[n]={});const a=r.current[n],s=a[t];return a[t]=i,s&&s!==i?(t===e.current.getActiveStrategy(cR[n])&&e.current.publishEvent("activeStrategyProcessorChange",n),o):o}),[e]),o=n.useCallback(((t,n)=>{const i=e.current.getActiveStrategy(cR[t]);if(null==i)throw new Error("Can't apply a strategy processor before defining an active strategy");const o=r.current[t];if(!o||!o[i])throw new Error(`No processor found for processor "${t}" on strategy "${i}"`);return(0,o[i])(n)}),[e]),a=n.useCallback((e=>{var r;const n=Array.from(t.current.entries()).find((t=>{let[,r]=t;return r.group===e&&r.isAvailable()}));return null!=(r=null==n?void 0:n[0])?r:lR}),[]),s=n.useCallback(((r,n,i)=>{t.current.set(n,{group:r,isAvailable:i}),e.current.publishEvent("strategyAvailabilityChange")}),[e]);HO(e,{registerStrategyProcessor:i,applyStrategyProcessor:o,getActiveStrategy:a,setStrategyAvailability:s},"private")})(r),((e,t)=>{const r=n.useCallback((e=>{if(null==t.localeText[e])throw new Error(`Missing translation for key ${e}.`);return t.localeText[e]}),[t.localeText]);e.current.register("public",{getLocaleText:r})})(r,t),r.current.register("private",{rootProps:t}),r},dR=(e,t,r)=>{const i=n.useRef(!1);i.current||(t.current.state=e(t.current.state,r,t),i.current=!0)};function hR(e,t){const r=n.useRef(null);if(r.current)return r.current;const i=e.current.getLogger(t);return r.current=i,i}const pR=e=>"Escape"===e,fR=e=>"Enter"===e,mR=e=>"Tab"===e,gR=e=>" "===e;function yR(e){return 1===e.key.length&&!e.ctrlKey&&!e.metaKey}const vR=e=>(e=>"Home"===e||"End"===e)(e)||(e=>0===e.indexOf("Arrow"))(e)||(e=>0===e.indexOf("Page"))(e)||gR(e);function xR(){const e=n.useContext(LO);if(void 0===e)throw new Error(["MUI: Could not find the data grid context.","It looks like you rendered your component outside of a DataGrid, DataGridPro or DataGridPremium parent component.","This can also happen if you are bundling multiple versions of the data grid."].join("\n"));return e}const bR=["field","id","value","formattedValue","row","rowNode","colDef","isEditable","cellMode","hasFocus","tabIndex","api"],_R=n.forwardRef((function(e,t){var r;const{field:i,id:o,value:a,rowNode:s,hasFocus:l,tabIndex:c}=e,u=(0,R.A)(e,bR),d=xR(),h=tP(),p=(e=>{const{classes:t}=e;return(0,mn.A)({root:["checkboxInput"]},DI,t)})({classes:h.classes}),f=n.useRef(null),m=n.useRef(null),g=(0,Gi.A)(f,t),y=d.current.getCellElement(o,i);n.useLayoutEffect((()=>{0===c&&y&&(y.tabIndex=-1)}),[y,c]),n.useEffect((()=>{if(l){var e;const t=null==(e=f.current)?void 0:e.querySelector("input");null==t||t.focus({preventScroll:!0})}else m.current&&m.current.stop({})}),[l]);const v=n.useCallback((e=>{gR(e.key)&&e.stopPropagation()}),[]);if("footer"===s.type||"pinnedRow"===s.type)return null;const x=d.current.isRowSelectable(o),b=d.current.getLocaleText(a?"checkboxSelectionUnselectRow":"checkboxSelectionSelectRow");return(0,j.jsx)(h.slots.baseCheckbox,(0,O.A)({ref:g,tabIndex:c,checked:a,onChange:e=>{const t={value:e.target.checked,id:o};d.current.publishEvent("rowSelectionCheckboxChange",t,e)},className:p.root,inputProps:{"aria-label":b},onKeyDown:v,disabled:!x,touchRippleRef:m},null==(r=h.slotProps)?void 0:r.baseCheckbox,u))})),wR=e=>e.rowSelection,kR=uP(wR,(e=>e.length)),SR=dP(wR,DP,((e,t)=>new Map(e.map((e=>[e,t[e]]))))),AR=dP(wR,(e=>e.reduce(((e,t)=>(e[t]=t,e)),{}))),TR=(e,t)=>t>0&&e>0?Math.ceil(e/t):0,MR=($I(["MUI: the 'rowCount' prop is undefined while using paginationMode='server'","For more detail, see http://mui.com/components/data-grid/pagination/#basic-implementation"],"error"),e=>({page:0,pageSize:e?0:100})),CR=(e,t)=>{if(t===JO.DataGrid&&e>100)throw new Error(["MUI: `pageSize` cannot exceed 100 in the MIT version of the DataGrid.","You need to upgrade to DataGridPro or DataGridPremium component to unlock this feature."].join("\n"))},ER=e=>e.pagination,IR=uP(ER,(e=>e.paginationModel)),PR=uP(ER,(e=>e.rowCount)),OR=uP(IR,(e=>e.page)),RR=uP(IR,(e=>e.pageSize)),LR=uP(RR,PR,((e,t)=>TR(t,e))),DR=dP(IR,jP,BP,fO,vO,((e,t,r,n,i)=>{const o=i.length,a=Math.min(e.pageSize*e.page,o-1),s=Math.min(a+e.pageSize-1,o-1);if(-1===a||-1===s)return null;if(r<2)return{firstRowIndex:a,lastRowIndex:s};const l=i[a],c=s-a+1,u=n.findIndex((e=>e.id===l.id));let d=u,h=0;for(;d0)&&(d+=1),0===e&&(h+=1))}return{firstRowIndex:u,lastRowIndex:d-1}})),zR=dP(fO,DR,((e,t)=>t?e.slice(t.firstRowIndex,t.lastRowIndex+1):[])),jR=dP(mO,DR,((e,t)=>t?e.slice(t.firstRowIndex,t.lastRowIndex+1):[])),FR=["field","colDef"],NR=n.forwardRef((function(e,t){var r;const i=(0,R.A)(e,FR),[,o]=n.useState(!1),a=xR(),s=tP(),l=(e=>{const{classes:t}=e;return(0,mn.A)({root:["checkboxInput"]},DI,t)})({classes:s.classes}),c=KI(a,EO),u=KI(a,wR),d=KI(a,mO),h=KI(a,jR),p=n.useMemo((()=>"function"!==typeof s.isRowSelectable?u:u.filter((e=>!!a.current.getRow(e)&&s.isRowSelectable(a.current.getRowParams(e))))),[a,s.isRowSelectable,u]),f=n.useMemo((()=>(s.pagination&&s.checkboxSelectionVisibleOnly?h:d).reduce(((e,t)=>(e[t]=!0,e)),{})),[s.pagination,s.checkboxSelectionVisibleOnly,h,d]),m=n.useMemo((()=>p.filter((e=>f[e])).length),[p,f]),g=m>0&&m0,v=null!==c&&c.field===e.field?0:-1;n.useLayoutEffect((()=>{const t=a.current.getColumnHeaderElement(e.field);0===v&&t&&(t.tabIndex=-1)}),[v,a,e.field]);const x=n.useCallback((e=>{" "===e.key&&a.current.publishEvent("headerSelectionCheckboxChange",{value:!y})}),[a,y]),b=n.useCallback((()=>{o((e=>!e))}),[]);n.useEffect((()=>a.current.subscribeEvent("rowSelectionChange",b)),[a,b]);const _=a.current.getLocaleText(y?"checkboxSelectionUnselectAllRows":"checkboxSelectionSelectAllRows");return(0,j.jsx)(s.slots.baseCheckbox,(0,O.A)({ref:t,indeterminate:g,checked:y,onChange:e=>{const t={value:e.target.checked};a.current.publishEvent("headerSelectionCheckboxChange",t)},className:l.root,inputProps:{"aria-label":_},tabIndex:v,onKeyDown:x},null==(r=s.slotProps)?void 0:r.baseCheckbox,i))})),BR=["id","value","formattedValue","api","field","row","rowNode","colDef","cellMode","isEditable","tabIndex","hasFocus","isValidating","debounceMs","isProcessingProps","onValueChange"],VR=(0,yn.Ay)(GE,{name:"MuiDataGrid",slot:"EditInputCell",overridesResolver:(e,t)=>t.editInputCell})((e=>{let{theme:t}=e;return(0,O.A)({},t.typography.body2,{padding:"1px 0","& input":{padding:"0 16px",height:"100%"}})})),UR=n.forwardRef(((e,t)=>{const r=tP(),{id:i,value:o,field:a,colDef:s,hasFocus:l,debounceMs:c=200,isProcessingProps:u,onValueChange:d}=e,h=(0,R.A)(e,BR),p=xR(),f=n.useRef(),[m,g]=n.useState(o),y=(e=>{const{classes:t}=e;return(0,mn.A)({root:["editInputCell"]},DI,t)})(r),v=n.useCallback((async e=>{const t=e.target.value;d&&await d(e,t);const r=p.current.getColumn(a);let n=t;r.valueParser&&(n=r.valueParser(t,p.current.getCellParams(i,a))),g(n),p.current.setEditCellValue({id:i,field:a,value:n,debounceMs:c,unstable_skipValueParser:!0},e)}),[p,c,a,i,d]),x=p.current.unstable_getEditCellMeta(i,a);return n.useEffect((()=>{"debouncedSetEditCellValue"!==(null==x?void 0:x.changeReason)&&g(o)}),[x,o]),(0,$o.A)((()=>{l&&f.current.focus()}),[l]),(0,j.jsx)(VR,(0,O.A)({ref:t,inputRef:f,className:y.root,ownerState:r,fullWidth:!0,type:"number"===s.type?s.type:"text",value:null!=m?m:"",onChange:v,endAdornment:u?(0,j.jsx)(r.slots.loadIcon,{fontSize:"small",color:"action"}):void 0},h))})),HR=$I(["MUI: The `sortModel` can only contain a single item when the `disableMultipleColumnsSorting` prop is set to `true`.","If you are using the community version of the `DataGrid`, this prop is always `true`."],"error"),$R=(e,t)=>t&&e.length>1?(HR(),[e[0]]):e,WR=(e,t)=>r=>(0,O.A)({},r,{sorting:(0,O.A)({},r.sorting,{sortModel:$R(e,t)})}),qR=(e,t)=>{const r=e.indexOf(t);return t&&-1!==r&&r+1!==e.length?e[r+1]:e[0]},GR=(e,t)=>null==e&&null!=t?-1:null==t&&null!=e?1:null==e&&null==t?0:null,YR=new Intl.Collator,XR=(e,t)=>{const r=GR(e,t);return null!==r?r:Number(e)-Number(t)},ZR=(e,t)=>{const r=GR(e,t);return null!==r?r:e>t?1:e{0!==this.currentId&&(clearTimeout(this.currentId),this.currentId=0)},this.disposeEffect=()=>this.clear}static create(){return new KR}start(e,t){this.clear(),this.currentId=setTimeout(t,e)}}function JR(){const e=VI(KR.create).current;return HI(e.disposeEffect),e}const QR=["item","applyValue","type","apiRef","focusElementRef","tabIndex","disabled","isFilterActive","clearButton","InputProps","variant"];function eL(e){var t,r;const{item:i,applyValue:o,type:a,apiRef:s,focusElementRef:l,tabIndex:c,disabled:u,clearButton:d,InputProps:h,variant:p="standard"}=e,f=(0,R.A)(e,QR),m=JR(),[g,y]=n.useState(null!=(t=i.value)?t:""),[v,x]=n.useState(!1),b=(0,zp.A)(),_=tP(),w=n.useCallback((e=>{const{value:t}=e.target;y(String(t)),x(!0),m.start(_.filterDebounceMs,(()=>{const e=(0,O.A)({},i,{value:t,fromInput:b});o(e),x(!1)}))}),[b,o,i,_.filterDebounceMs,m]);return n.useEffect((()=>{var e;i.fromInput===b&&void 0!==i.value||y(String(null!=(e=i.value)?e:""))}),[b,i]),(0,j.jsx)(_.slots.baseTextField,(0,O.A)({id:b,label:s.current.getLocaleText("filterPanelInputLabel"),placeholder:s.current.getLocaleText("filterPanelInputPlaceholder"),value:g,onChange:w,variant:p,type:a||"text",InputProps:(0,O.A)({},v||d?{endAdornment:v?(0,j.jsx)(_.slots.loadIcon,{fontSize:"small",color:"action"}):d}:{},{disabled:u},h,{inputProps:(0,O.A)({tabIndex:c},null==h?void 0:h.inputProps)}),InputLabelProps:{shrink:!0},inputRef:l},f,null==(r=_.slotProps)?void 0:r.baseTextField))}var tL=r(51052);const rL=e=>{const t=n.useRef({});return n.useEffect((()=>{t.current=e})),t.current};function nL(e){return"undefined"!==typeof e.normalize?e.normalize("NFD").replace(/[\u0300-\u036f]/g,""):e}function iL(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const{ignoreAccents:t=!0,ignoreCase:r=!0,limit:n,matchFrom:i="any",stringify:o,trim:a=!1}=e;return(e,s)=>{let{inputValue:l,getOptionLabel:c}=s,u=a?l.trim():l;r&&(u=u.toLowerCase()),t&&(u=nL(u));const d=u?e.filter((e=>{let n=(o||c)(e);return r&&(n=n.toLowerCase()),t&&(n=nL(n)),"start"===i?0===n.indexOf(u):n.indexOf(u)>-1})):e;return"number"===typeof n?d.slice(0,n):d}}function oL(e,t){for(let r=0;r{var t;return null!==e.current&&(null==(t=e.current.parentElement)?void 0:t.contains(document.activeElement))};const lL=function(e){const{unstable_isActiveElementInListbox:t=sL,unstable_classNamePrefix:r="Mui",autoComplete:i=!1,autoHighlight:o=!1,autoSelect:a=!1,blurOnSelect:s=!1,clearOnBlur:l=!e.freeSolo,clearOnEscape:c=!1,componentName:u="useAutocomplete",defaultValue:d=(e.multiple?[]:null),disableClearable:h=!1,disableCloseOnSelect:p=!1,disabled:f,disabledItemsFocusable:m=!1,disableListWrap:g=!1,filterOptions:y=aL,filterSelectedOptions:v=!1,freeSolo:x=!1,getOptionDisabled:b,getOptionKey:_,getOptionLabel:w=e=>{var t;return null!=(t=e.label)?t:e},groupBy:k,handleHomeEndKeys:S=!e.freeSolo,id:A,includeInputInList:T=!1,inputValue:M,isOptionEqualToValue:C=(e,t)=>e===t,multiple:E=!1,onChange:I,onClose:P,onHighlightChange:R,onInputChange:L,onOpen:D,open:z,openOnFocus:j=!1,options:F,readOnly:N=!1,selectOnFocus:B=!e.freeSolo,value:V}=e,U=(0,zp.A)(A);let H=w;H=e=>{const t=w(e);return"string"!==typeof t?String(t):t};const $=n.useRef(!1),W=n.useRef(!0),q=n.useRef(null),G=n.useRef(null),[Y,X]=n.useState(null),[Z,K]=n.useState(-1),J=o?0:-1,Q=n.useRef(J),[ee,te]=(0,tL.A)({controlled:V,default:d,name:u}),[re,ne]=(0,tL.A)({controlled:M,default:"",name:u,state:"inputValue"}),[ie,oe]=n.useState(!1),ae=n.useCallback(((e,t)=>{if(!(E?ee.length!v||!(E?ee:[ee]).some((t=>null!==t&&C(e,t))))),{inputValue:de&&ce?"":re,getOptionLabel:H}):[],fe=rL({filteredOptions:pe,value:ee,inputValue:re});n.useEffect((()=>{const e=ee!==fe.value;ie&&!e||x&&!e||ae(null,ee)}),[ee,ae,ie,fe.value,x]);const me=se&&pe.length>0&&!N,ge=(0,ea.A)((e=>{-1===e?q.current.focus():Y.querySelector(`[data-tag-index="${e}"]`).focus()}));n.useEffect((()=>{E&&Z>ee.length-1&&(K(-1),ge(-1))}),[ee,E,Z,ge]);const ye=(0,ea.A)((e=>{let{event:t,index:n,reason:i="auto"}=e;if(Q.current=n,-1===n?q.current.removeAttribute("aria-activedescendant"):q.current.setAttribute("aria-activedescendant",`${U}-option-${n}`),R&&R(t,-1===n?null:pe[n],i),!G.current)return;const o=G.current.querySelector(`[role="option"].${r}-focused`);o&&(o.classList.remove(`${r}-focused`),o.classList.remove(`${r}-focusVisible`));let a=G.current;if("listbox"!==G.current.getAttribute("role")&&(a=G.current.parentElement.querySelector('[role="listbox"]')),!a)return;if(-1===n)return void(a.scrollTop=0);const s=G.current.querySelector(`[data-option-index="${n}"]`);if(s&&(s.classList.add(`${r}-focused`),"keyboard"===i&&s.classList.add(`${r}-focusVisible`),a.scrollHeight>a.clientHeight&&"mouse"!==i&&"touch"!==i)){const e=s,t=a.clientHeight+a.scrollTop,r=e.offsetTop+e.offsetHeight;r>t?a.scrollTop=r-a.clientHeight:e.offsetTop-e.offsetHeight*(k?1.3:0){let{event:t,diff:r,direction:n="next",reason:o="auto"}=e;if(!he)return;const a=function(e,t){if(!G.current||e<0||e>=pe.length)return-1;let r=e;for(;;){const n=G.current.querySelector(`[data-option-index="${r}"]`),i=!m&&(!n||n.disabled||"true"===n.getAttribute("aria-disabled"));if(n&&n.hasAttribute("tabindex")&&!i)return r;if(r="next"===t?(r+1)%pe.length:(r-1+pe.length)%pe.length,r===e)return-1}}((()=>{const e=pe.length-1;if("reset"===r)return J;if("start"===r)return 0;if("end"===r)return e;const t=Q.current+r;return t<0?-1===t&&T?-1:g&&-1!==Q.current||Math.abs(r)>1?0:e:t>e?t===e+1&&T?-1:g||Math.abs(r)>1?e:0:t})(),n);if(ye({index:a,reason:o,event:t}),i&&"reset"!==r)if(-1===a)q.current.value=re;else{const e=H(pe[a]);q.current.value=e;0===e.toLowerCase().indexOf(re.toLowerCase())&&re.length>0&&q.current.setSelectionRange(re.length,e.length)}})),xe=n.useCallback((()=>{if(!he)return;const e=(()=>{if(-1!==Q.current&&fe.filteredOptions&&fe.filteredOptions.length!==pe.length&&fe.inputValue===re&&(E?ee.length===fe.value.length&&fe.value.every(((e,t)=>H(ee[t])===H(e))):(e=fe.value,t=ee,(e?H(e):"")===(t?H(t):"")))){const e=fe.filteredOptions[Q.current];if(e)return oL(pe,(t=>H(t)===H(e)))}var e,t;return-1})();if(-1!==e)return void(Q.current=e);const t=E?ee[0]:ee;if(0!==pe.length&&null!=t){if(G.current)if(null==t)Q.current>=pe.length-1?ye({index:pe.length-1}):ye({index:Q.current});else{const e=pe[Q.current];if(E&&e&&-1!==oL(ee,(t=>C(e,t))))return;const r=oL(pe,(e=>C(e,t)));-1===r?ve({diff:"reset"}):ye({index:r})}}else ve({diff:"reset"})}),[pe.length,!E&&ee,v,ve,ye,he,re,E]),be=(0,ea.A)((e=>{(0,Wo.A)(G,e),e&&xe()}));n.useEffect((()=>{xe()}),[xe]);const _e=e=>{se||(le(!0),ue(!0),D&&D(e))},we=(e,t)=>{se&&(le(!1),P&&P(e,t))},ke=(e,t,r,n)=>{if(E){if(ee.length===t.length&&ee.every(((e,r)=>e===t[r])))return}else if(ee===t)return;I&&I(e,t,r,n),te(t)},Se=n.useRef(!1),Ae=function(e,t){let r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"options",n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"selectOption",i=t;if(E){i=Array.isArray(ee)?ee.slice():[];const e=oL(i,(e=>C(t,e)));-1===e?i.push(t):"freeSolo"!==r&&(i.splice(e,1),n="removeOption")}ae(e,i),ke(e,i,n,{option:t}),p||e&&(e.ctrlKey||e.metaKey)||we(e,n),(!0===s||"touch"===s&&Se.current||"mouse"===s&&!Se.current)&&q.current.blur()},Te=(e,t)=>{if(!E)return;""===re&&we(e,"toggleInput");let r=Z;-1===Z?""===re&&"previous"===t&&(r=ee.length-1):(r+="next"===t?1:-1,r<0&&(r=0),r===ee.length&&(r=-1)),r=function(e,t){if(-1===e)return-1;let r=e;for(;;){if("next"===t&&r===ee.length||"previous"===t&&-1===r)return-1;const e=Y.querySelector(`[data-tag-index="${r}"]`);if(e&&e.hasAttribute("tabindex")&&!e.disabled&&"true"!==e.getAttribute("aria-disabled"))return r;r+="next"===t?1:-1}}(r,t),K(r),ge(r)},Me=e=>{$.current=!0,ne(""),L&&L(e,"","clear"),ke(e,E?[]:null,"clear")},Ce=e=>t=>{if(e.onKeyDown&&e.onKeyDown(t),!t.defaultMuiPrevented&&(-1!==Z&&-1===["ArrowLeft","ArrowRight"].indexOf(t.key)&&(K(-1),ge(-1)),229!==t.which))switch(t.key){case"Home":he&&S&&(t.preventDefault(),ve({diff:"start",direction:"next",reason:"keyboard",event:t}));break;case"End":he&&S&&(t.preventDefault(),ve({diff:"end",direction:"previous",reason:"keyboard",event:t}));break;case"PageUp":t.preventDefault(),ve({diff:-5,direction:"previous",reason:"keyboard",event:t}),_e(t);break;case"PageDown":t.preventDefault(),ve({diff:5,direction:"next",reason:"keyboard",event:t}),_e(t);break;case"ArrowDown":t.preventDefault(),ve({diff:1,direction:"next",reason:"keyboard",event:t}),_e(t);break;case"ArrowUp":t.preventDefault(),ve({diff:-1,direction:"previous",reason:"keyboard",event:t}),_e(t);break;case"ArrowLeft":Te(t,"previous");break;case"ArrowRight":Te(t,"next");break;case"Enter":if(-1!==Q.current&&he){const e=pe[Q.current],r=!!b&&b(e);if(t.preventDefault(),r)return;Ae(t,e,"selectOption"),i&&q.current.setSelectionRange(q.current.value.length,q.current.value.length)}else x&&""!==re&&!1===de&&(E&&t.preventDefault(),Ae(t,re,"createOption","freeSolo"));break;case"Escape":he?(t.preventDefault(),t.stopPropagation(),we(t,"escape")):c&&(""!==re||E&&ee.length>0)&&(t.preventDefault(),t.stopPropagation(),Me(t));break;case"Backspace":if(E&&!N&&""===re&&ee.length>0){const e=-1===Z?ee.length-1:Z,r=ee.slice();r.splice(e,1),ke(t,r,"removeOption",{option:ee[e]})}break;case"Delete":if(E&&!N&&""===re&&ee.length>0&&-1!==Z){const e=Z,r=ee.slice();r.splice(e,1),ke(t,r,"removeOption",{option:ee[e]})}}},Ee=e=>{oe(!0),j&&!$.current&&_e(e)},Ie=e=>{t(G)?q.current.focus():(oe(!1),W.current=!0,$.current=!1,a&&-1!==Q.current&&he?Ae(e,pe[Q.current],"blur"):a&&x&&""!==re?Ae(e,re,"blur","freeSolo"):l&&ae(e,ee),we(e,"blur"))},Pe=e=>{const t=e.target.value;re!==t&&(ne(t),ue(!1),L&&L(e,t,"input")),""===t?h||E||ke(e,null,"clear"):_e(e)},Oe=e=>{const t=Number(e.currentTarget.getAttribute("data-option-index"));Q.current!==t&&ye({event:e,index:t,reason:"mouse"})},Re=e=>{ye({event:e,index:Number(e.currentTarget.getAttribute("data-option-index")),reason:"touch"}),Se.current=!0},Le=e=>{const t=Number(e.currentTarget.getAttribute("data-option-index"));Ae(e,pe[t],"selectOption"),Se.current=!1},De=e=>t=>{const r=ee.slice();r.splice(e,1),ke(t,r,"removeOption",{option:ee[e]})},ze=e=>{se?we(e,"toggleInput"):_e(e)},je=e=>{e.currentTarget.contains(e.target)&&e.target.getAttribute("id")!==U&&e.preventDefault()},Fe=e=>{e.currentTarget.contains(e.target)&&(q.current.focus(),B&&W.current&&q.current.selectionEnd-q.current.selectionStart===0&&q.current.select(),W.current=!1)},Ne=e=>{f||""!==re&&se||ze(e)};let Be=x&&re.length>0;Be=Be||(E?ee.length>0:null!==ee);let Ve=pe;if(k){new Map;Ve=pe.reduce(((e,t,r)=>{const n=k(t);return e.length>0&&e[e.length-1].group===n?e[e.length-1].options.push(t):e.push({key:r,index:r,group:n,options:[t]}),e}),[])}return f&&ie&&Ie(),{getRootProps:function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return(0,O.A)({"aria-owns":me?`${U}-listbox`:null},e,{onKeyDown:Ce(e),onMouseDown:je,onClick:Fe})},getInputLabelProps:()=>({id:`${U}-label`,htmlFor:U}),getInputProps:()=>({id:U,value:re,onBlur:Ie,onFocus:Ee,onChange:Pe,onMouseDown:Ne,"aria-activedescendant":he?"":null,"aria-autocomplete":i?"both":"list","aria-controls":me?`${U}-listbox`:void 0,"aria-expanded":me,autoComplete:"off",ref:q,autoCapitalize:"none",spellCheck:"false",role:"combobox",disabled:f}),getClearProps:()=>({tabIndex:-1,type:"button",onClick:Me}),getPopupIndicatorProps:()=>({tabIndex:-1,type:"button",onClick:ze}),getTagProps:e=>{let{index:t}=e;return(0,O.A)({key:t,"data-tag-index":t,tabIndex:-1},!N&&{onDelete:De(t)})},getListboxProps:()=>({role:"listbox",id:`${U}-listbox`,"aria-labelledby":`${U}-label`,ref:be,onMouseDown:e=>{e.preventDefault()}}),getOptionProps:e=>{let{index:t,option:r}=e;var n;const i=(E?ee:[ee]).some((e=>null!=e&&C(r,e))),o=!!b&&b(r);return{key:null!=(n=null==_?void 0:_(r))?n:H(r),tabIndex:-1,role:"option",id:`${U}-option-${t}`,onMouseMove:Oe,onClick:Le,onTouchStart:Re,"data-option-index":t,"aria-disabled":o,"aria-selected":i}},id:U,inputValue:re,value:ee,dirty:Be,expanded:he&&Y,popupOpen:he,focused:ie||-1!==Z,anchorEl:Y,setAnchorEl:X,focusedTag:Z,groupedOptions:Ve}};function cL(e){return(0,Yn.Ay)("MuiListSubheader",e)}(0,Ln.A)("MuiListSubheader",["root","colorPrimary","colorInherit","gutters","inset","sticky"]);const uL=["className","color","component","disableGutters","disableSticky","inset"],dL=(0,yn.Ay)("li",{name:"MuiListSubheader",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,"default"!==r.color&&t[`color${(0,ei.A)(r.color)}`],!r.disableGutters&&t.gutters,r.inset&&t.inset,!r.disableSticky&&t.sticky]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({boxSizing:"border-box",lineHeight:"48px",listStyle:"none",color:(t.vars||t).palette.text.secondary,fontFamily:t.typography.fontFamily,fontWeight:t.typography.fontWeightMedium,fontSize:t.typography.pxToRem(14)},"primary"===r.color&&{color:(t.vars||t).palette.primary.main},"inherit"===r.color&&{color:"inherit"},!r.disableGutters&&{paddingLeft:16,paddingRight:16},r.inset&&{paddingLeft:72},!r.disableSticky&&{position:"sticky",top:0,zIndex:1,backgroundColor:(t.vars||t).palette.background.paper})})),hL=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiListSubheader"}),{className:n,color:i="default",component:o="li",disableGutters:a=!1,disableSticky:s=!1,inset:l=!1}=r,c=(0,R.A)(r,uL),u=(0,O.A)({},r,{color:i,component:o,disableGutters:a,disableSticky:s,inset:l}),d=(e=>{const{classes:t,color:r,disableGutters:n,inset:i,disableSticky:o}=e,a={root:["root","default"!==r&&`color${(0,ei.A)(r)}`,!n&&"gutters",i&&"inset",!o&&"sticky"]};return(0,mn.A)(a,cL,t)})(u);return(0,j.jsx)(dL,(0,O.A)({as:o,className:(0,fn.A)(d.root,n),ref:t,ownerState:u},c))}));hL.muiSkipListHighlight=!0;const pL=hL,fL=(0,Ud.A)((0,j.jsx)("path",{d:"M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z"}),"Cancel");function mL(e){return(0,Yn.Ay)("MuiChip",e)}const gL=(0,Ln.A)("MuiChip",["root","sizeSmall","sizeMedium","colorError","colorInfo","colorPrimary","colorSecondary","colorSuccess","colorWarning","disabled","clickable","clickableColorPrimary","clickableColorSecondary","deletable","deletableColorPrimary","deletableColorSecondary","outlined","filled","outlinedPrimary","outlinedSecondary","filledPrimary","filledSecondary","avatar","avatarSmall","avatarMedium","avatarColorPrimary","avatarColorSecondary","icon","iconSmall","iconMedium","iconColorPrimary","iconColorSecondary","label","labelSmall","labelMedium","deleteIcon","deleteIconSmall","deleteIconMedium","deleteIconColorPrimary","deleteIconColorSecondary","deleteIconOutlinedColorPrimary","deleteIconOutlinedColorSecondary","deleteIconFilledColorPrimary","deleteIconFilledColorSecondary","focusVisible"]),yL=["avatar","className","clickable","color","component","deleteIcon","disabled","icon","label","onClick","onDelete","onKeyDown","onKeyUp","size","variant","tabIndex","skipFocusWhenDisabled"],vL=(0,yn.Ay)("div",{name:"MuiChip",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e,{color:n,iconColor:i,clickable:o,onDelete:a,size:s,variant:l}=r;return[{[`& .${gL.avatar}`]:t.avatar},{[`& .${gL.avatar}`]:t[`avatar${(0,ei.A)(s)}`]},{[`& .${gL.avatar}`]:t[`avatarColor${(0,ei.A)(n)}`]},{[`& .${gL.icon}`]:t.icon},{[`& .${gL.icon}`]:t[`icon${(0,ei.A)(s)}`]},{[`& .${gL.icon}`]:t[`iconColor${(0,ei.A)(i)}`]},{[`& .${gL.deleteIcon}`]:t.deleteIcon},{[`& .${gL.deleteIcon}`]:t[`deleteIcon${(0,ei.A)(s)}`]},{[`& .${gL.deleteIcon}`]:t[`deleteIconColor${(0,ei.A)(n)}`]},{[`& .${gL.deleteIcon}`]:t[`deleteIcon${(0,ei.A)(l)}Color${(0,ei.A)(n)}`]},t.root,t[`size${(0,ei.A)(s)}`],t[`color${(0,ei.A)(n)}`],o&&t.clickable,o&&"default"!==n&&t[`clickableColor${(0,ei.A)(n)})`],a&&t.deletable,a&&"default"!==n&&t[`deletableColor${(0,ei.A)(n)}`],t[l],t[`${l}${(0,ei.A)(n)}`]]}})((e=>{let{theme:t,ownerState:r}=e;const n="light"===t.palette.mode?t.palette.grey[700]:t.palette.grey[300];return(0,O.A)({maxWidth:"100%",fontFamily:t.typography.fontFamily,fontSize:t.typography.pxToRem(13),display:"inline-flex",alignItems:"center",justifyContent:"center",height:32,color:(t.vars||t).palette.text.primary,backgroundColor:(t.vars||t).palette.action.selected,borderRadius:16,whiteSpace:"nowrap",transition:t.transitions.create(["background-color","box-shadow"]),cursor:"unset",outline:0,textDecoration:"none",border:0,padding:0,verticalAlign:"middle",boxSizing:"border-box",[`&.${gL.disabled}`]:{opacity:(t.vars||t).palette.action.disabledOpacity,pointerEvents:"none"},[`& .${gL.avatar}`]:{marginLeft:5,marginRight:-6,width:24,height:24,color:t.vars?t.vars.palette.Chip.defaultAvatarColor:n,fontSize:t.typography.pxToRem(12)},[`& .${gL.avatarColorPrimary}`]:{color:(t.vars||t).palette.primary.contrastText,backgroundColor:(t.vars||t).palette.primary.dark},[`& .${gL.avatarColorSecondary}`]:{color:(t.vars||t).palette.secondary.contrastText,backgroundColor:(t.vars||t).palette.secondary.dark},[`& .${gL.avatarSmall}`]:{marginLeft:4,marginRight:-4,width:18,height:18,fontSize:t.typography.pxToRem(10)},[`& .${gL.icon}`]:(0,O.A)({marginLeft:5,marginRight:-6},"small"===r.size&&{fontSize:18,marginLeft:4,marginRight:-4},r.iconColor===r.color&&(0,O.A)({color:t.vars?t.vars.palette.Chip.defaultIconColor:n},"default"!==r.color&&{color:"inherit"})),[`& .${gL.deleteIcon}`]:(0,O.A)({WebkitTapHighlightColor:"transparent",color:t.vars?`rgba(${t.vars.palette.text.primaryChannel} / 0.26)`:(0,gn.X4)(t.palette.text.primary,.26),fontSize:22,cursor:"pointer",margin:"0 5px 0 -6px","&:hover":{color:t.vars?`rgba(${t.vars.palette.text.primaryChannel} / 0.4)`:(0,gn.X4)(t.palette.text.primary,.4)}},"small"===r.size&&{fontSize:16,marginRight:4,marginLeft:-4},"default"!==r.color&&{color:t.vars?`rgba(${t.vars.palette[r.color].contrastTextChannel} / 0.7)`:(0,gn.X4)(t.palette[r.color].contrastText,.7),"&:hover, &:active":{color:(t.vars||t).palette[r.color].contrastText}})},"small"===r.size&&{height:24},"default"!==r.color&&{backgroundColor:(t.vars||t).palette[r.color].main,color:(t.vars||t).palette[r.color].contrastText},r.onDelete&&{[`&.${gL.focusVisible}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.action.selectedChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.focusOpacity}))`:(0,gn.X4)(t.palette.action.selected,t.palette.action.selectedOpacity+t.palette.action.focusOpacity)}},r.onDelete&&"default"!==r.color&&{[`&.${gL.focusVisible}`]:{backgroundColor:(t.vars||t).palette[r.color].dark}})}),(e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({},r.clickable&&{userSelect:"none",WebkitTapHighlightColor:"transparent",cursor:"pointer","&:hover":{backgroundColor:t.vars?`rgba(${t.vars.palette.action.selectedChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.hoverOpacity}))`:(0,gn.X4)(t.palette.action.selected,t.palette.action.selectedOpacity+t.palette.action.hoverOpacity)},[`&.${gL.focusVisible}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.action.selectedChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.focusOpacity}))`:(0,gn.X4)(t.palette.action.selected,t.palette.action.selectedOpacity+t.palette.action.focusOpacity)},"&:active":{boxShadow:(t.vars||t).shadows[1]}},r.clickable&&"default"!==r.color&&{[`&:hover, &.${gL.focusVisible}`]:{backgroundColor:(t.vars||t).palette[r.color].dark}})}),(e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({},"outlined"===r.variant&&{backgroundColor:"transparent",border:t.vars?`1px solid ${t.vars.palette.Chip.defaultBorder}`:`1px solid ${"light"===t.palette.mode?t.palette.grey[400]:t.palette.grey[700]}`,[`&.${gL.clickable}:hover`]:{backgroundColor:(t.vars||t).palette.action.hover},[`&.${gL.focusVisible}`]:{backgroundColor:(t.vars||t).palette.action.focus},[`& .${gL.avatar}`]:{marginLeft:4},[`& .${gL.avatarSmall}`]:{marginLeft:2},[`& .${gL.icon}`]:{marginLeft:4},[`& .${gL.iconSmall}`]:{marginLeft:2},[`& .${gL.deleteIcon}`]:{marginRight:5},[`& .${gL.deleteIconSmall}`]:{marginRight:3}},"outlined"===r.variant&&"default"!==r.color&&{color:(t.vars||t).palette[r.color].main,border:`1px solid ${t.vars?`rgba(${t.vars.palette[r.color].mainChannel} / 0.7)`:(0,gn.X4)(t.palette[r.color].main,.7)}`,[`&.${gL.clickable}:hover`]:{backgroundColor:t.vars?`rgba(${t.vars.palette[r.color].mainChannel} / ${t.vars.palette.action.hoverOpacity})`:(0,gn.X4)(t.palette[r.color].main,t.palette.action.hoverOpacity)},[`&.${gL.focusVisible}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette[r.color].mainChannel} / ${t.vars.palette.action.focusOpacity})`:(0,gn.X4)(t.palette[r.color].main,t.palette.action.focusOpacity)},[`& .${gL.deleteIcon}`]:{color:t.vars?`rgba(${t.vars.palette[r.color].mainChannel} / 0.7)`:(0,gn.X4)(t.palette[r.color].main,.7),"&:hover, &:active":{color:(t.vars||t).palette[r.color].main}}})})),xL=(0,yn.Ay)("span",{name:"MuiChip",slot:"Label",overridesResolver:(e,t)=>{const{ownerState:r}=e,{size:n}=r;return[t.label,t[`label${(0,ei.A)(n)}`]]}})((e=>{let{ownerState:t}=e;return(0,O.A)({overflow:"hidden",textOverflow:"ellipsis",paddingLeft:12,paddingRight:12,whiteSpace:"nowrap"},"outlined"===t.variant&&{paddingLeft:11,paddingRight:11},"small"===t.size&&{paddingLeft:8,paddingRight:8},"small"===t.size&&"outlined"===t.variant&&{paddingLeft:7,paddingRight:7})}));function bL(e){return"Backspace"===e.key||"Delete"===e.key}const _L=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiChip"}),{avatar:i,className:o,clickable:a,color:s="default",component:l,deleteIcon:c,disabled:u=!1,icon:d,label:h,onClick:p,onDelete:f,onKeyDown:m,onKeyUp:g,size:y="medium",variant:v="filled",tabIndex:x,skipFocusWhenDisabled:b=!1}=r,_=(0,R.A)(r,yL),w=n.useRef(null),k=(0,xn.A)(w,t),S=e=>{e.stopPropagation(),f&&f(e)},A=!(!1===a||!p)||a,T=A||f?Qn:l||"div",M=(0,O.A)({},r,{component:T,disabled:u,size:y,color:s,iconColor:n.isValidElement(d)&&d.props.color||s,onDelete:!!f,clickable:A,variant:v}),C=(e=>{const{classes:t,disabled:r,size:n,color:i,iconColor:o,onDelete:a,clickable:s,variant:l}=e,c={root:["root",l,r&&"disabled",`size${(0,ei.A)(n)}`,`color${(0,ei.A)(i)}`,s&&"clickable",s&&`clickableColor${(0,ei.A)(i)}`,a&&"deletable",a&&`deletableColor${(0,ei.A)(i)}`,`${l}${(0,ei.A)(i)}`],label:["label",`label${(0,ei.A)(n)}`],avatar:["avatar",`avatar${(0,ei.A)(n)}`,`avatarColor${(0,ei.A)(i)}`],icon:["icon",`icon${(0,ei.A)(n)}`,`iconColor${(0,ei.A)(o)}`],deleteIcon:["deleteIcon",`deleteIcon${(0,ei.A)(n)}`,`deleteIconColor${(0,ei.A)(i)}`,`deleteIcon${(0,ei.A)(l)}Color${(0,ei.A)(i)}`]};return(0,mn.A)(c,mL,t)})(M),E=T===Qn?(0,O.A)({component:l||"div",focusVisibleClassName:C.focusVisible},f&&{disableRipple:!0}):{};let I=null;f&&(I=c&&n.isValidElement(c)?n.cloneElement(c,{className:(0,fn.A)(c.props.className,C.deleteIcon),onClick:S}):(0,j.jsx)(fL,{className:(0,fn.A)(C.deleteIcon),onClick:S}));let P=null;i&&n.isValidElement(i)&&(P=n.cloneElement(i,{className:(0,fn.A)(C.avatar,i.props.className)}));let L=null;return d&&n.isValidElement(d)&&(L=n.cloneElement(d,{className:(0,fn.A)(C.icon,d.props.className)})),(0,j.jsxs)(vL,(0,O.A)({as:T,className:(0,fn.A)(C.root,o),disabled:!(!A||!u)||void 0,onClick:p,onKeyDown:e=>{e.currentTarget===e.target&&bL(e)&&e.preventDefault(),m&&m(e)},onKeyUp:e=>{e.currentTarget===e.target&&(f&&bL(e)?f(e):"Escape"===e.key&&w.current&&w.current.blur()),g&&g(e)},ref:k,tabIndex:b&&u?-1:x,ownerState:M},E,_,{children:[P||L,(0,j.jsx)(xL,{className:(0,fn.A)(C.label),ownerState:M,children:h}),I]}))}));function wL(e){return(0,Yn.Ay)("MuiOutlinedInput",e)}const kL=(0,O.A)({},BE,(0,Ln.A)("MuiOutlinedInput",["root","notchedOutline","input"]));function SL(e){return(0,Yn.Ay)("MuiFilledInput",e)}const AL=(0,O.A)({},BE,(0,Ln.A)("MuiFilledInput",["root","underline","input"])),TL=(0,Ud.A)((0,j.jsx)("path",{d:"M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"}),"Close"),ML=(0,Ud.A)((0,j.jsx)("path",{d:"M7 10l5 5 5-5z"}),"ArrowDropDown");function CL(e){return(0,Yn.Ay)("MuiAutocomplete",e)}const EL=(0,Ln.A)("MuiAutocomplete",["root","expanded","fullWidth","focused","focusVisible","tag","tagSizeSmall","tagSizeMedium","hasPopupIcon","hasClearIcon","inputRoot","input","inputFocused","endAdornment","clearIndicator","popupIndicator","popupIndicatorOpen","popper","popperDisablePortal","paper","listbox","loading","noOptions","option","groupLabel","groupUl"]);var IL,PL;const OL=["autoComplete","autoHighlight","autoSelect","blurOnSelect","ChipProps","className","clearIcon","clearOnBlur","clearOnEscape","clearText","closeText","componentsProps","defaultValue","disableClearable","disableCloseOnSelect","disabled","disabledItemsFocusable","disableListWrap","disablePortal","filterOptions","filterSelectedOptions","forcePopupIcon","freeSolo","fullWidth","getLimitTagsText","getOptionDisabled","getOptionKey","getOptionLabel","isOptionEqualToValue","groupBy","handleHomeEndKeys","id","includeInputInList","inputValue","limitTags","ListboxComponent","ListboxProps","loading","loadingText","multiple","noOptionsText","onChange","onClose","onHighlightChange","onInputChange","onOpen","open","openOnFocus","openText","options","PaperComponent","PopperComponent","popupIcon","readOnly","renderGroup","renderInput","renderOption","renderTags","selectOnFocus","size","slotProps","value"],RL=["ref"],LL=["key"],DL=["key"],zL=(0,yn.Ay)("div",{name:"MuiAutocomplete",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e,{fullWidth:n,hasClearIcon:i,hasPopupIcon:o,inputFocused:a,size:s}=r;return[{[`& .${EL.tag}`]:t.tag},{[`& .${EL.tag}`]:t[`tagSize${(0,ei.A)(s)}`]},{[`& .${EL.inputRoot}`]:t.inputRoot},{[`& .${EL.input}`]:t.input},{[`& .${EL.input}`]:a&&t.inputFocused},t.root,n&&t.fullWidth,o&&t.hasPopupIcon,i&&t.hasClearIcon]}})({[`&.${EL.focused} .${EL.clearIndicator}`]:{visibility:"visible"},"@media (pointer: fine)":{[`&:hover .${EL.clearIndicator}`]:{visibility:"visible"}},[`& .${EL.tag}`]:{margin:3,maxWidth:"calc(100% - 6px)"},[`& .${EL.inputRoot}`]:{[`.${EL.hasPopupIcon}&, .${EL.hasClearIcon}&`]:{paddingRight:30},[`.${EL.hasPopupIcon}.${EL.hasClearIcon}&`]:{paddingRight:56},[`& .${EL.input}`]:{width:0,minWidth:30}},[`& .${XE.root}`]:{paddingBottom:1,"& .MuiInput-input":{padding:"4px 4px 4px 0px"}},[`& .${XE.root}.${BE.sizeSmall}`]:{[`& .${XE.input}`]:{padding:"2px 4px 3px 0"}},[`& .${kL.root}`]:{padding:9,[`.${EL.hasPopupIcon}&, .${EL.hasClearIcon}&`]:{paddingRight:39},[`.${EL.hasPopupIcon}.${EL.hasClearIcon}&`]:{paddingRight:65},[`& .${EL.input}`]:{padding:"7.5px 4px 7.5px 5px"},[`& .${EL.endAdornment}`]:{right:9}},[`& .${kL.root}.${BE.sizeSmall}`]:{paddingTop:6,paddingBottom:6,paddingLeft:6,[`& .${EL.input}`]:{padding:"2.5px 4px 2.5px 8px"}},[`& .${AL.root}`]:{paddingTop:19,paddingLeft:8,[`.${EL.hasPopupIcon}&, .${EL.hasClearIcon}&`]:{paddingRight:39},[`.${EL.hasPopupIcon}.${EL.hasClearIcon}&`]:{paddingRight:65},[`& .${AL.input}`]:{padding:"7px 4px"},[`& .${EL.endAdornment}`]:{right:9}},[`& .${AL.root}.${BE.sizeSmall}`]:{paddingBottom:1,[`& .${AL.input}`]:{padding:"2.5px 4px"}},[`& .${BE.hiddenLabel}`]:{paddingTop:8},[`& .${AL.root}.${BE.hiddenLabel}`]:{paddingTop:0,paddingBottom:0,[`& .${EL.input}`]:{paddingTop:16,paddingBottom:17}},[`& .${AL.root}.${BE.hiddenLabel}.${BE.sizeSmall}`]:{[`& .${EL.input}`]:{paddingTop:8,paddingBottom:9}},[`& .${EL.input}`]:{flexGrow:1,textOverflow:"ellipsis",opacity:0},variants:[{props:{fullWidth:!0},style:{width:"100%"}},{props:{size:"small"},style:{[`& .${EL.tag}`]:{margin:2,maxWidth:"calc(100% - 4px)"}}},{props:{inputFocused:!0},style:{[`& .${EL.input}`]:{opacity:1}}},{props:{multiple:!0},style:{[`& .${EL.inputRoot}`]:{flexWrap:"wrap"}}}]}),jL=(0,yn.Ay)("div",{name:"MuiAutocomplete",slot:"EndAdornment",overridesResolver:(e,t)=>t.endAdornment})({position:"absolute",right:0,top:"50%",transform:"translate(0, -50%)"}),FL=(0,yn.Ay)(oi,{name:"MuiAutocomplete",slot:"ClearIndicator",overridesResolver:(e,t)=>t.clearIndicator})({marginRight:-2,padding:4,visibility:"hidden"}),NL=(0,yn.Ay)(oi,{name:"MuiAutocomplete",slot:"PopupIndicator",overridesResolver:(e,t)=>{let{ownerState:r}=e;return(0,O.A)({},t.popupIndicator,r.popupOpen&&t.popupIndicatorOpen)}})({padding:2,marginRight:-2,variants:[{props:{popupOpen:!0},style:{transform:"rotate(180deg)"}}]}),BL=(0,yn.Ay)(fp,{name:"MuiAutocomplete",slot:"Popper",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[{[`& .${EL.option}`]:t.option},t.popper,r.disablePortal&&t.popperDisablePortal]}})((e=>{let{theme:t}=e;return{zIndex:(t.vars||t).zIndex.modal,variants:[{props:{disablePortal:!0},style:{position:"absolute"}}]}})),VL=(0,yn.Ay)(Ci,{name:"MuiAutocomplete",slot:"Paper",overridesResolver:(e,t)=>t.paper})((e=>{let{theme:t}=e;return(0,O.A)({},t.typography.body1,{overflow:"auto"})})),UL=(0,yn.Ay)("div",{name:"MuiAutocomplete",slot:"Loading",overridesResolver:(e,t)=>t.loading})((e=>{let{theme:t}=e;return{color:(t.vars||t).palette.text.secondary,padding:"14px 16px"}})),HL=(0,yn.Ay)("div",{name:"MuiAutocomplete",slot:"NoOptions",overridesResolver:(e,t)=>t.noOptions})((e=>{let{theme:t}=e;return{color:(t.vars||t).palette.text.secondary,padding:"14px 16px"}})),$L=(0,yn.Ay)("div",{name:"MuiAutocomplete",slot:"Listbox",overridesResolver:(e,t)=>t.listbox})((e=>{let{theme:t}=e;return{listStyle:"none",margin:0,padding:"8px 0",maxHeight:"40vh",overflow:"auto",position:"relative",[`& .${EL.option}`]:{minHeight:48,display:"flex",overflow:"hidden",justifyContent:"flex-start",alignItems:"center",cursor:"pointer",paddingTop:6,boxSizing:"border-box",outline:"0",WebkitTapHighlightColor:"transparent",paddingBottom:6,paddingLeft:16,paddingRight:16,[t.breakpoints.up("sm")]:{minHeight:"auto"},[`&.${EL.focused}`]:{backgroundColor:(t.vars||t).palette.action.hover,"@media (hover: none)":{backgroundColor:"transparent"}},'&[aria-disabled="true"]':{opacity:(t.vars||t).palette.action.disabledOpacity,pointerEvents:"none"},[`&.${EL.focusVisible}`]:{backgroundColor:(t.vars||t).palette.action.focus},'&[aria-selected="true"]':{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity})`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity),[`&.${EL.focused}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.hoverOpacity}))`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity+t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:(t.vars||t).palette.action.selected}},[`&.${EL.focusVisible}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.focusOpacity}))`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity+t.palette.action.focusOpacity)}}}}})),WL=(0,yn.Ay)(pL,{name:"MuiAutocomplete",slot:"GroupLabel",overridesResolver:(e,t)=>t.groupLabel})((e=>{let{theme:t}=e;return{backgroundColor:(t.vars||t).palette.background.paper,top:-8}})),qL=(0,yn.Ay)("ul",{name:"MuiAutocomplete",slot:"GroupUl",overridesResolver:(e,t)=>t.groupUl})({padding:0,[`& .${EL.option}`]:{paddingLeft:24}}),GL=n.forwardRef((function(e,t){var r,i,o,a;const s=(0,vn.b)({props:e,name:"MuiAutocomplete"}),{autoComplete:l=!1,autoHighlight:c=!1,autoSelect:u=!1,blurOnSelect:d=!1,ChipProps:h,className:p,clearIcon:f=IL||(IL=(0,j.jsx)(TL,{fontSize:"small"})),clearOnBlur:m=!s.freeSolo,clearOnEscape:g=!1,clearText:y="Clear",closeText:v="Close",componentsProps:x={},defaultValue:b=(s.multiple?[]:null),disableClearable:_=!1,disableCloseOnSelect:w=!1,disabled:k=!1,disabledItemsFocusable:S=!1,disableListWrap:A=!1,disablePortal:T=!1,filterSelectedOptions:M=!1,forcePopupIcon:C="auto",freeSolo:E=!1,fullWidth:I=!1,getLimitTagsText:P=e=>`+${e}`,getOptionLabel:L,groupBy:D,handleHomeEndKeys:z=!s.freeSolo,includeInputInList:F=!1,limitTags:N=-1,ListboxComponent:B="ul",ListboxProps:V,loading:U=!1,loadingText:H="Loading\u2026",multiple:$=!1,noOptionsText:W="No options",openOnFocus:q=!1,openText:G="Open",PaperComponent:Y=Ci,PopperComponent:X=fp,popupIcon:Z=PL||(PL=(0,j.jsx)(ML,{})),readOnly:K=!1,renderGroup:J,renderInput:Q,renderOption:ee,renderTags:te,selectOnFocus:re=!s.freeSolo,size:ne="medium",slotProps:ie={}}=s,oe=(0,R.A)(s,OL),{getRootProps:ae,getInputProps:se,getInputLabelProps:le,getPopupIndicatorProps:ce,getClearProps:ue,getTagProps:de,getListboxProps:he,getOptionProps:pe,value:fe,dirty:me,expanded:ge,id:ye,popupOpen:ve,focused:xe,focusedTag:be,anchorEl:_e,setAnchorEl:we,inputValue:ke,groupedOptions:Se}=lL((0,O.A)({},s,{componentName:"Autocomplete"})),Ae=!_&&!k&&me&&!K,Te=(!E||!0===C)&&!1!==C,{onMouseDown:Me}=se(),{ref:Ce}=null!=V?V:{},Ee=he(),{ref:Ie}=Ee,Pe=(0,R.A)(Ee,RL),Oe=(0,xn.A)(Ie,Ce),Re=L||(e=>{var t;return null!=(t=e.label)?t:e}),Le=(0,O.A)({},s,{disablePortal:T,expanded:ge,focused:xe,fullWidth:I,getOptionLabel:Re,hasClearIcon:Ae,hasPopupIcon:Te,inputFocused:-1===be,popupOpen:ve,size:ne}),De=(e=>{const{classes:t,disablePortal:r,expanded:n,focused:i,fullWidth:o,hasClearIcon:a,hasPopupIcon:s,inputFocused:l,popupOpen:c,size:u}=e,d={root:["root",n&&"expanded",i&&"focused",o&&"fullWidth",a&&"hasClearIcon",s&&"hasPopupIcon"],inputRoot:["inputRoot"],input:["input",l&&"inputFocused"],tag:["tag",`tagSize${(0,ei.A)(u)}`],endAdornment:["endAdornment"],clearIndicator:["clearIndicator"],popupIndicator:["popupIndicator",c&&"popupIndicatorOpen"],popper:["popper",r&&"popperDisablePortal"],paper:["paper"],listbox:["listbox"],loading:["loading"],noOptions:["noOptions"],option:["option"],groupLabel:["groupLabel"],groupUl:["groupUl"]};return(0,mn.A)(d,CL,t)})(Le);let ze;if($&&fe.length>0){const e=e=>(0,O.A)({className:De.tag,disabled:k},de(e));ze=te?te(fe,e,Le):fe.map(((t,r)=>{const n=e({index:r}),{key:i}=n,o=(0,R.A)(n,LL);return(0,j.jsx)(_L,(0,O.A)({label:Re(t),size:ne},o,h),i)}))}if(N>-1&&Array.isArray(ze)){const e=ze.length-N;!xe&&e>0&&(ze=ze.splice(0,N),ze.push((0,j.jsx)("span",{className:De.tag,children:P(e)},ze.length)))}const je=J||(e=>(0,j.jsxs)("li",{children:[(0,j.jsx)(WL,{className:De.groupLabel,ownerState:Le,component:"div",children:e.group}),(0,j.jsx)(qL,{className:De.groupUl,ownerState:Le,children:e.children})]},e.key)),Fe=ee||((e,t)=>{const{key:r}=e,n=(0,R.A)(e,DL);return(0,j.jsx)("li",(0,O.A)({},n,{children:Re(t)}),r)}),Ne=(e,t)=>{const r=pe({option:e,index:t});return Fe((0,O.A)({},r,{className:De.option}),e,{selected:r["aria-selected"],index:t,inputValue:ke},Le)},Be=null!=(r=ie.clearIndicator)?r:x.clearIndicator,Ve=null!=(i=ie.paper)?i:x.paper,Ue=null!=(o=ie.popper)?o:x.popper,He=null!=(a=ie.popupIndicator)?a:x.popupIndicator,$e=e=>(0,j.jsx)(BL,(0,O.A)({as:X,disablePortal:T,style:{width:_e?_e.clientWidth:null},ownerState:Le,role:"presentation",anchorEl:_e,open:ve},Ue,{className:(0,fn.A)(De.popper,null==Ue?void 0:Ue.className),children:(0,j.jsx)(VL,(0,O.A)({ownerState:Le,as:Y},Ve,{className:(0,fn.A)(De.paper,null==Ve?void 0:Ve.className),children:e}))}));let We=null;return Se.length>0?We=$e((0,j.jsx)($L,(0,O.A)({as:B,className:De.listbox,ownerState:Le},Pe,V,{ref:Oe,children:Se.map(((e,t)=>D?je({key:e.key,group:e.group,children:e.options.map(((t,r)=>Ne(t,e.index+r)))}):Ne(e,t)))}))):U&&0===Se.length?We=$e((0,j.jsx)(UL,{className:De.loading,ownerState:Le,children:H})):0!==Se.length||E||U||(We=$e((0,j.jsx)(HL,{className:De.noOptions,ownerState:Le,role:"presentation",onMouseDown:e=>{e.preventDefault()},children:W}))),(0,j.jsxs)(n.Fragment,{children:[(0,j.jsx)(zL,(0,O.A)({ref:t,className:(0,fn.A)(De.root,p),ownerState:Le},ae(oe),{children:Q({id:ye,disabled:k,fullWidth:!0,size:"small"===ne?"small":void 0,InputLabelProps:le(),InputProps:(0,O.A)({ref:we,className:De.inputRoot,startAdornment:ze,onClick:e=>{e.target===e.currentTarget&&Me(e)}},(Ae||Te)&&{endAdornment:(0,j.jsxs)(jL,{className:De.endAdornment,ownerState:Le,children:[Ae?(0,j.jsx)(FL,(0,O.A)({},ue(),{"aria-label":y,title:y,ownerState:Le},Be,{className:(0,fn.A)(De.clearIndicator,null==Be?void 0:Be.className),children:f})):null,Te?(0,j.jsx)(NL,(0,O.A)({},ce(),{disabled:k,"aria-label":ve?v:G,title:ve?v:G,ownerState:Le},He,{className:(0,fn.A)(De.popupIndicator,null==He?void 0:He.className),children:Z})):null]})}),inputProps:(0,O.A)({className:De.input,disabled:k,readOnly:K},se())})})),_e?We:null]})})),YL=["item","applyValue","type","apiRef","focusElementRef","color","error","helperText","size","variant"];function XL(e){const{item:t,applyValue:r,type:i,apiRef:o,focusElementRef:a,color:s,error:l,helperText:c,size:u,variant:d}=e,h=(0,R.A)(e,YL),p={color:s,error:l,helperText:c,size:u,variant:d},[f,m]=n.useState(t.value||[]),g=(0,zp.A)(),y=tP();n.useEffect((()=>{var e;const r=null!=(e=t.value)?e:[];m(r.map(String))}),[t.value]);const v=n.useCallback(((e,n)=>{m(n.map(String)),r((0,O.A)({},t,{value:[...n]}))}),[r,t]);return(0,j.jsx)(GL,(0,O.A)({multiple:!0,freeSolo:!0,options:[],filterOptions:(e,t)=>{const{inputValue:r}=t;return null==r||""===r?[]:[r]},id:g,value:f,onChange:v,renderTags:(e,t)=>e.map(((e,r)=>(0,j.jsx)(y.slots.baseChip,(0,O.A)({variant:"outlined",size:"small",label:e},t({index:r}))))),renderInput:e=>{var t;return(0,j.jsx)(y.slots.baseTextField,(0,O.A)({},e,{label:o.current.getLocaleText("filterPanelInputLabel"),placeholder:o.current.getLocaleText("filterPanelInputPlaceholder"),InputLabelProps:(0,O.A)({},e.InputLabelProps,{shrink:!0}),inputRef:a,type:i||"text"},p,null==(t=y.slotProps)?void 0:t.baseTextField))}},h))}const ZL={current:null};function KL(e){return e.isInternal=!0,e}function JL(e){return void 0!==e&&!0===e.isInternal}function QL(e){return KL(((t,r)=>{const n=e(t,r);return n?e=>n(e.value,e.row,r,ZL.current):n}))}function eD(e){return e.map((e=>(0,O.A)({},e,{getApplyFilterFn:QL(e.getApplyFilterFnV7),getApplyFilterFnV7:KL(e.getApplyFilterFnV7)})))}function tD(e){return KL(((t,r,n)=>{const i=e(t,r,n);return i?e=>i(e.value,e.row,r,n):i}))}var rD=function(e){return e.And="and",e.Or="or",e}(rD||{});const nD=()=>({items:[],logicOperator:rD.And,quickFilterValues:[],quickFilterLogicOperator:rD.And});function iD(e){return{current:e.current.getPublicApi()}}let oD;const aD=(e,t)=>{const r=(0,O.A)({},e);if(null==r.id&&(r.id=Math.round(1e5*Math.random())),null==r.operator){const e=yP(t)[r.field];r.operator=e&&e.filterOperators[0].value}return r},sD=$I(["MUI: The `filterModel` can only contain a single item when the `disableMultipleColumnsFiltering` prop is set to `true`.","If you are using the community version of the `DataGrid`, this prop is always `true`."],"error"),lD=$I("MUI: The `id` field is required on `filterModel.items` when you use multiple filters.","error"),cD=$I("MUI: The `operator` field is required on `filterModel.items`, one or more of your filtering item has no `operator` provided.","error"),uD=(e,t,r)=>{const n=e.items.length>1;let i;n&&t?(sD(),i=[e.items[0]]):i=e.items;const o=n&&i.some((e=>null==e.id)),a=i.some((e=>null==e.operator));return o&&lD(),a&&cD(),a||o?(0,O.A)({},e,{items:i.map((e=>aD(e,r)))}):e.items!==i?(0,O.A)({},e,{items:i}):e},dD=(e,t,r)=>n=>(0,O.A)({},n,{filterModel:uD(e,t,r)}),hD=e=>"string"===typeof e?e.normalize("NFD").replace(/[\u0300-\u036f]/g,""):e,pD=(e,t)=>{if(!e.field||!e.operator)return null;const r=t.current.getColumn(e.field);if(!r)return null;let n;if(r.valueParser){var i;const t=r.valueParser;n=Array.isArray(e.value)?null==(i=e.value)?void 0:i.map((e=>t(e))):t(e.value)}else n=e.value;const{ignoreDiacritics:o}=t.current.rootProps;o&&(n=hD(n));const a=(0,O.A)({},e,{value:n}),s=r.filterOperators;if(null==s||!s.length)throw new Error(`MUI: No filter operators found for column '${r.field}'.`);const l=s.find((e=>e.value===a.operator));if(!l)throw new Error(`MUI: No filter operator found for column '${r.field}' and operator value '${a.operator}'.`);const c=!JL(l.getApplyFilterFn),u=!JL(l.getApplyFilterFnV7),d=iD(t);if(l.getApplyFilterFnV7&&(!c||u)){const e=l.getApplyFilterFnV7(a,r);return"function"!==typeof e?null:{v7:!0,item:a,fn:n=>{let i=t.current.getRowValue(n,r);return o&&(i=hD(i)),e(i,n,r,d)}}}const h=l.getApplyFilterFn(a,r);return"function"!==typeof h?null:{v7:!1,item:a,fn:e=>{const r=t.current.getCellParams(e,a.field);ZL.current=d,o&&(r.value=hD(r.value));const n=h(r);return ZL.current=null,n}}};let fD=1;const mD=(e,t,r)=>{const{items:n}=e,i=n.map((e=>pD(e,t))).filter((e=>!!e));if(0===i.length)return null;if(r||!function(){if(void 0!==oD)return oD;try{oD=new Function("return true")()}catch(e){oD=!1}return oD}())return(e,r)=>{const n={};for(let o=0;o`const shouldApply${t} = !shouldApplyFilter || shouldApplyFilter(${JSON.stringify(e.item.field)});`)).join("\n")}\n\nconst result$$ = {\n${i.map(((e,t)=>` ${JSON.stringify(String(e.item.id))}: !shouldApply${t}\n ? false\n : ${e.v7?`appliers[${t}].fn(row)`:`appliers[${t}].fn(getRowId(row))`},`)).join("\n")}\n};\n\nreturn result$$;`.replaceAll("$$",String(fD)));fD+=1;return(e,r)=>o(t.current.getRowId,i,e,r)},gD=(e,t,r)=>{const n=mD(e,t,r),i=((e,t)=>{var r,n,i;const o=null!=(r=null==(n=e.quickFilterValues)?void 0:n.filter(Boolean))?r:[];if(0===o.length)return null;const a=null!=(i=e.quickFilterExcludeHiddenColumns)&&i?_P(t):gP(t),s=[],{ignoreDiacritics:l}=t.current.rootProps,c=iD(t);return a.forEach((e=>{const r=t.current.getColumn(e),n=null==r?void 0:r.getApplyQuickFilterFn,i=null==r?void 0:r.getApplyQuickFilterFnV7,a=!JL(n),u=!JL(i);!i||a&&!u?n&&s.push({column:r,appliers:o.map((e=>{const t=l?hD(e):e;return{v7:!1,fn:n(t,r,c)}}))}):s.push({column:r,appliers:o.map((e=>{const t=l?hD(e):e;return{v7:!0,fn:i(t,r,c)}}))})})),function(e,r){const n={},i={};e:for(let u=0;unull!=e,vD=(e,t,r,n,i)=>{const o=((e,t,r)=>(e.cleanedFilterItems||(e.cleanedFilterItems=r.filter((e=>null!==pD(e,t)))),e.cleanedFilterItems))(i,n,r.items),a=e.filter(yD),s=t.filter(yD);if(a.length>0){var l;const e=e=>a.some((t=>t[e.id]));if((null!=(l=r.logicOperator)?l:nD().logicOperator)===rD.And){if(!o.every(e))return!1}else{if(!o.some(e))return!1}}if(s.length>0&&null!=r.quickFilterValues){var c;const e=e=>s.some((t=>t[e]));if((null!=(c=r.quickFilterLogicOperator)?c:nD().quickFilterLogicOperator)===rD.And){if(!r.quickFilterValues.every(e))return!1}else{if(!r.quickFilterValues.some(e))return!1}}return!0},xD=KL((e=>{if(!e)return null;const t=new RegExp(FO(e),"i");return(e,r,n,i)=>{let o=i.current.getRowFormattedValue(r,n);return i.current.ignoreDiacritics&&(o=hD(o)),null!=o&&t.test(o.toString())}})),bD={width:100,minWidth:50,maxWidth:1/0,hideable:!0,sortable:!0,resizable:!0,filterable:!0,groupable:!0,pinnable:!0,aggregable:!0,editable:!1,sortComparator:(e,t)=>{const r=GR(e,t);return null!==r?r:"string"===typeof e?YR.compare(e.toString(),t.toString()):e-t},type:"string",align:"left",filterOperators:function(){let e=arguments.length>0&&void 0!==arguments[0]&&arguments[0];return eD([{value:"contains",getApplyFilterFnV7:t=>{if(!t.value)return null;const r=e?t.value:t.value.trim(),n=new RegExp(FO(r),"i");return e=>null!=e&&n.test(String(e))},InputComponent:eL},{value:"equals",getApplyFilterFnV7:t=>{if(!t.value)return null;const r=e?t.value:t.value.trim(),n=new Intl.Collator(void 0,{sensitivity:"base",usage:"search"});return e=>null!=e&&0===n.compare(r,e.toString())},InputComponent:eL},{value:"startsWith",getApplyFilterFnV7:t=>{if(!t.value)return null;const r=e?t.value:t.value.trim(),n=new RegExp(`^${FO(r)}.*$`,"i");return e=>null!=e&&n.test(e.toString())},InputComponent:eL},{value:"endsWith",getApplyFilterFnV7:t=>{if(!t.value)return null;const r=e?t.value:t.value.trim(),n=new RegExp(`.*${FO(r)}$`,"i");return e=>null!=e&&n.test(e.toString())},InputComponent:eL},{value:"isEmpty",getApplyFilterFnV7:()=>e=>""===e||null==e,requiresFilterValue:!1},{value:"isNotEmpty",getApplyFilterFnV7:()=>e=>""!==e&&null!=e,requiresFilterValue:!1},{value:"isAnyOf",getApplyFilterFnV7:t=>{if(!Array.isArray(t.value)||0===t.value.length)return null;const r=e?t.value:t.value.map((e=>e.trim())),n=new Intl.Collator(void 0,{sensitivity:"base",usage:"search"});return e=>null!=e&&r.some((t=>0===n.compare(t,e.toString()||"")))},InputComponent:XL}])}(),renderEditCell:e=>(0,j.jsx)(UR,(0,O.A)({},e)),getApplyQuickFilterFn:tD(xD),getApplyQuickFilterFnV7:xD},_D="auto-generated-group-node-root",wD=Symbol("mui.id_autogenerated");const kD=(e,t,r)=>{const n=t?t(e):e.id;return function(e,t){if(null==e)throw new Error(["MUI: The data grid component requires all rows to have a unique `id` property.","Alternatively, you can use the `getRowId` prop to specify a custom id for each row.",arguments.length>2&&void 0!==arguments[2]?arguments[2]:"A row was provided without id in the rows prop:",JSON.stringify(t)].join("\n"))}(n,e,r),n},SD=e=>{let{rows:t,getRowId:r,loading:n,rowCount:i}=e;const o={type:"full",rows:[]},a={},s={};for(let l=0;l{let{tree:t,rowCountProp:r=0}=e;const n=t[_D];return Math.max(r,n.children.length+(null==n.footerId?0:1))},TD=e=>{let{apiRef:t,rowCountProp:r=0,loadingProp:n,previousTree:i,previousTreeDepths:o}=e;const a=t.current.caches.rows,{tree:s,treeDepths:l,dataRowIds:c,groupingName:u}=t.current.applyStrategyProcessor("rowTreeCreation",{previousTree:i,previousTreeDepths:o,updates:a.updates,dataRowIdToIdLookup:a.dataRowIdToIdLookup,dataRowIdToModelLookup:a.dataRowIdToModelLookup}),d=t.current.unstable_applyPipeProcessors("hydrateRows",{tree:s,treeDepths:l,dataRowIdToIdLookup:a.dataRowIdToIdLookup,dataRowIds:c,dataRowIdToModelLookup:a.dataRowIdToModelLookup});return t.current.caches.rows.updates={type:"partial",actions:{insert:[],modify:[],remove:[]},idToActionLookup:{}},(0,O.A)({},d,{totalRowCount:Math.max(r,d.dataRowIds.length),totalTopLevelRowCount:AD({tree:d.tree,rowCountProp:r}),groupingName:u,loading:n})},MD=e=>"skeletonRow"===e.type||"footer"===e.type||"group"===e.type&&e.isAutoGenerated||"pinnedRow"===e.type&&e.isAutoGenerated,CD=(e,t,r)=>{const n=e[t];if("group"!==n.type)return[];const i=[];for(let o=0;ot+=e.current.unstable_getRowHeight(r.id)),0))||0,bottom:(null==n||null==(r=n.bottom)?void 0:r.reduce(((t,r)=>t+=e.current.unstable_getRowHeight(r.id)),0))||0}}function ID(e,t){const r=fP(e);return`var(--DataGrid-overlayHeight, ${2*Math.floor(t*r)}px)`}const PD=["id","value","formattedValue","api","field","row","rowNode","colDef","cellMode","isEditable","hasFocus","tabIndex"];function OD(e){const{value:t}=e,r=(0,R.A)(e,PD),i=xR(),o=tP(),a=(e=>{const{classes:t}=e;return(0,mn.A)({root:["booleanCell"]},DI,t)})({classes:o.classes}),s=n.useMemo((()=>t?o.slots.booleanCellTrueIcon:o.slots.booleanCellFalseIcon),[o.slots.booleanCellFalseIcon,o.slots.booleanCellTrueIcon,t]);return(0,j.jsx)(s,(0,O.A)({fontSize:"small",className:a.root,titleAccess:i.current.getLocaleText(t?"booleanCellTrueLabel":"booleanCellFalseLabel"),"data-value":Boolean(t)},r))}const RD=n.memo(OD),LD=["id","value","formattedValue","api","field","row","rowNode","colDef","cellMode","isEditable","tabIndex","className","hasFocus","isValidating","isProcessingProps","error","onValueChange"];function DD(e){var t;const{id:r,value:i,field:o,className:a,hasFocus:s,onValueChange:l}=e,c=(0,R.A)(e,LD),u=xR(),d=n.useRef(null),h=(0,zp.A)(),[p,f]=n.useState(i),m=tP(),g=(e=>{const{classes:t}=e;return(0,mn.A)({root:["editBooleanCell"]},DI,t)})({classes:m.classes}),y=n.useCallback((async e=>{const t=e.target.checked;l&&await l(e,t),f(t),await u.current.setEditCellValue({id:r,field:o,value:t},e)}),[u,o,r,l]);return n.useEffect((()=>{f(i)}),[i]),(0,$o.A)((()=>{s&&d.current.focus()}),[s]),(0,j.jsx)("label",(0,O.A)({htmlFor:h,className:(0,fn.A)(g.root,a)},c,{children:(0,j.jsx)(m.slots.baseCheckbox,(0,O.A)({id:h,inputRef:d,checked:Boolean(p),onChange:y,size:"small"},null==(t=m.slotProps)?void 0:t.baseCheckbox))}))}const zD=["item","applyValue","apiRef","focusElementRef","isFilterActive","clearButton","tabIndex","label","variant","InputLabelProps"],jD=(0,yn.Ay)("div")({display:"flex",alignItems:"center",width:"100%","& button":{margin:"auto 0px 5px 5px"}});function FD(e){var t,r,i,o;const{item:a,applyValue:s,apiRef:l,focusElementRef:c,clearButton:u,tabIndex:d,label:h,variant:p="standard"}=e,f=(0,R.A)(e,zD),[m,g]=n.useState(a.value||""),y=tP(),v=(0,zp.A)(),x=(0,zp.A)(),b=(null==(t=y.slotProps)?void 0:t.baseSelect)||{},_=null==(r=b.native)||r,w=(null==(i=y.slotProps)?void 0:i.baseSelectOption)||{},k=n.useCallback((e=>{const t=e.target.value;g(t),s((0,O.A)({},a,{value:t}))}),[s,a]);n.useEffect((()=>{g(a.value||"")}),[a.value]);const S=null!=h?h:l.current.getLocaleText("filterPanelInputLabel");return(0,j.jsxs)(jD,{children:[(0,j.jsxs)(y.slots.baseFormControl,{fullWidth:!0,children:[(0,j.jsx)(y.slots.baseInputLabel,(0,O.A)({},null==(o=y.slotProps)?void 0:o.baseInputLabel,{id:v,shrink:!0,variant:p,children:S})),(0,j.jsxs)(y.slots.baseSelect,(0,O.A)({labelId:v,id:x,label:S,value:m,onChange:k,variant:p,notched:"outlined"===p||void 0,native:_,displayEmpty:!0,inputProps:{ref:c,tabIndex:d}},f,b,{children:[(0,j.jsx)(y.slots.baseSelectOption,(0,O.A)({},w,{native:_,value:"",children:l.current.getLocaleText("filterValueAny")})),(0,j.jsx)(y.slots.baseSelectOption,(0,O.A)({},w,{native:_,value:"true",children:l.current.getLocaleText("filterValueTrue")})),(0,j.jsx)(y.slots.baseSelectOption,(0,O.A)({},w,{native:_,value:"false",children:l.current.getLocaleText("filterValueFalse")}))]}))]}),u]})}const ND=(0,O.A)({},bD,{type:"boolean",align:"center",headerAlign:"center",renderCell:e=>MD(e.rowNode)?"":(0,j.jsx)(RD,(0,O.A)({},e)),renderEditCell:e=>(0,j.jsx)(DD,(0,O.A)({},e)),sortComparator:XR,valueFormatter:function(e){let{value:t,api:r}=e;return t?r.getLocaleText("booleanCellTrueLabel"):r.getLocaleText("booleanCellFalseLabel")},filterOperators:eD([{value:"is",getApplyFilterFnV7:e=>{if(!e.value)return null;const t="true"===e.value;return e=>Boolean(e)===t},InputComponent:FD}]),getApplyQuickFilterFn:void 0,getApplyQuickFilterFnV7:void 0,aggregable:!1,pastedValueParser:e=>(e=>{switch(e.toLowerCase().trim()){case"true":case"yes":case"1":return!0;case"false":case"no":case"0":case"null":case"undefined":return!1;default:return}})(e)}),BD="__check__",VD=(0,O.A)({},ND,{field:BD,type:"checkboxSelection",width:50,resizable:!1,sortable:!1,filterable:!1,aggregable:!1,disableColumnMenu:!0,disableReorder:!0,disableExport:!0,getApplyQuickFilterFn:void 0,getApplyQuickFilterFnV7:void 0,valueGetter:e=>void 0!==AR(e.api.state,e.api.instanceId)[e.id],renderHeader:e=>(0,j.jsx)(NR,(0,O.A)({},e)),renderCell:e=>(0,j.jsx)(_R,(0,O.A)({},e))});function UD(e,t){if("string"===typeof e){if(t.shouldAppendQuotes||t.escapeFormulas){const r=e.replace(/"/g,'""');return[t.delimiter,"\n","\r",'"'].some((t=>e.includes(t)))?`"${r}"`:t.escapeFormulas&&["=","+","-","@","\t","\r"].includes(r[0])?`'${r}`:r}return e}return e}const HD=(e,t)=>{const{csvOptions:r,ignoreValueFormatter:n}=t;let i;if(n){var o;const t=e.colDef.type;if("number"===t)i=String(e.value);else if("date"===t||"dateTime"===t){var a;i=null==(a=e.value)?void 0:a.toISOString()}else i="function"===typeof(null==(o=e.value)?void 0:o.toString)?e.value.toString():e.value}else i=e.formattedValue;return UD(i,r)};$I(["MUI: When the value of a field is an object or a `renderCell` is provided, the CSV export might not display the value correctly.","You can provide a `valueFormatter` with a string representation to be used."]);class $D{constructor(e){this.options=void 0,this.rowString="",this.isEmpty=!0,this.options=e}addValue(e){this.isEmpty||(this.rowString+=this.options.csvOptions.delimiter),null===e||void 0===e?this.rowString+="":"function"===typeof this.options.sanitizeCellValue?this.rowString+=this.options.sanitizeCellValue(e,this.options.csvOptions):this.rowString+=e,this.isEmpty=!1}getRowString(){return this.rowString}}function WD(e){const{columns:t,rowIds:r,csvOptions:n,ignoreValueFormatter:i,apiRef:o}=e,a=r.reduce(((e,r)=>`${e}${(e=>{let{id:t,columns:r,getCellParams:n,csvOptions:i,ignoreValueFormatter:o}=e;const a=new $D({csvOptions:i});return r.forEach((e=>{const r=n(t,e.field);a.addValue(HD(r,{ignoreValueFormatter:o,csvOptions:i}))})),a.getRowString()})({id:r,columns:t,getCellParams:o.current.getCellParams,ignoreValueFormatter:i,csvOptions:n})}\r\n`),"").trim();if(!n.includeHeaders)return a;const s=t.filter((e=>e.field!==VD.field)),l=[];if(n.includeColumnGroupsHeaders){const e=o.current.unstable_getAllGroupDetails();let t=0;const r=s.reduce(((e,r)=>{const n=o.current.unstable_getColumnGroupPath(r.field);return e[r.field]=n,t=Math.max(t,n.length),e}),{});for(let i=0;i{const o=(r[n.field]||[])[i],a=e[o];t.addValue(a?a.headerName||a.groupId:"")}))}}const c=new $D({csvOptions:n,sanitizeCellValue:UD});s.forEach((e=>{c.addValue(e.headerName||e.field)})),l.push(c);return`${`${l.map((e=>e.getRowString())).join("\r\n")}\r\n`}${a}`.trim()}function qD(e){const t=document.createElement("span");t.style.whiteSpace="pre",t.style.userSelect="all",t.style.opacity="0px",t.textContent=e,document.body.appendChild(t);const r=document.createRange();r.selectNode(t);const n=window.getSelection();n.removeAllRanges(),n.addRange(r);try{document.execCommand("copy")}finally{document.body.removeChild(t)}}const GD=(e,t)=>{const r=t.unstable_ignoreValueFormatterDuringExport,i=("object"===typeof r?null==r?void 0:r.clipboardExport:r)||!1,o=t.clipboardCopyCellDelimiter,a=n.useCallback((t=>{if(!t.ctrlKey&&!t.metaKey||"c"!==t.key)return;if(function(e){var t;return!(null==(t=window.getSelection())||!t.toString())||!!(e&&(e.selectionEnd||0)-(e.selectionStart||0)>0)}(t.target))return;let r="";if(e.current.getSelectedRows().size>0)r=e.current.getDataAsCsv({includeHeaders:!1,delimiter:o,shouldAppendQuotes:!1,escapeFormulas:!1});else{const t=SO(e);if(t){const n=e.current.getCellParams(t.id,t.field);r=HD(n,{csvOptions:{delimiter:o,shouldAppendQuotes:!1,escapeFormulas:!1},ignoreValueFormatter:i})}}var n;r=e.current.unstable_applyPipeProcessors("clipboardCopy",r),r&&(n=r,navigator.clipboard?navigator.clipboard.writeText(n).catch((()=>{qD(n)})):qD(n),e.current.publishEvent("clipboardCopy",r))}),[e,i,o]);((e,t,r,i,o)=>{const a=hR(e,"useNativeEventListener"),[s,l]=n.useState(!1),c=n.useRef(i),u=n.useCallback((e=>c.current&&c.current(e)),[]);n.useEffect((()=>{c.current=i}),[i]),n.useEffect((()=>{let n;if(n=zO(t)?t():t&&t.current?t.current:null,n&&r&&!s){a.debug(`Binding native ${r} event`),n.addEventListener(r,u,o);const t=n;l(!0);const i=()=>{a.debug(`Clearing native ${r} event`),t.removeEventListener(r,u,o)};e.current.subscribeEvent("unmount",i)}}),[t,u,r,s,a,o,e])})(e,e.current.rootElementRef,"keydown",a),nR(e,"clipboardCopy",t.onClipboardCopy)},YD=e=>(0,O.A)({},e,{columnMenu:{open:!1}}),XD=e=>{const t=n.useRef(!0);t.current&&(t.current=!1,e())},ZD=(e,t,r)=>{const i=n.useRef(),o=n.useRef(`mui-${Math.round(1e9*Math.random())}`),a=n.useCallback((()=>{i.current=e.current.registerPipeProcessor(t,o.current,r)}),[e,r,t]);XD((()=>{a()}));const s=n.useRef(!0);n.useEffect((()=>(s.current?s.current=!1:a(),()=>{i.current&&(i.current(),i.current=null)})),[a])},KD=(e,t,r)=>{const i=n.useRef(),o=n.useRef(`mui-${Math.round(1e9*Math.random())}`),a=n.useCallback((()=>{i.current=e.current.registerPipeApplier(t,o.current,r)}),[e,r,t]);XD((()=>{a()}));const s=n.useRef(!0);n.useEffect((()=>(s.current?s.current=!1:a(),()=>{i.current&&(i.current(),i.current=null)})),[a])},JD=e=>null==e?null:Number(e),QD=KL((e=>null==e||Number.isNaN(e)||""===e?null:t=>JD(t)===JD(e))),ez=(0,O.A)({},bD,{type:"number",align:"right",headerAlign:"right",sortComparator:XR,valueParser:e=>""===e?null:Number(e),valueFormatter:e=>{let{value:t}=e;return function(e){return"number"===typeof e&&!Number.isNaN(e)}(t)?t.toLocaleString():t||""},filterOperators:eD([{value:"=",getApplyFilterFnV7:e=>null==e.value||Number.isNaN(e.value)?null:t=>JD(t)===e.value,InputComponent:eL,InputComponentProps:{type:"number"}},{value:"!=",getApplyFilterFnV7:e=>null==e.value||Number.isNaN(e.value)?null:t=>JD(t)!==e.value,InputComponent:eL,InputComponentProps:{type:"number"}},{value:">",getApplyFilterFnV7:e=>null==e.value||Number.isNaN(e.value)?null:t=>null!=t&&JD(t)>e.value,InputComponent:eL,InputComponentProps:{type:"number"}},{value:">=",getApplyFilterFnV7:e=>null==e.value||Number.isNaN(e.value)?null:t=>null!=t&&JD(t)>=e.value,InputComponent:eL,InputComponentProps:{type:"number"}},{value:"<",getApplyFilterFnV7:e=>null==e.value||Number.isNaN(e.value)?null:t=>null!=t&&JD(t)null==e.value||Number.isNaN(e.value)?null:t=>null!=t&&JD(t)<=e.value,InputComponent:eL,InputComponentProps:{type:"number"}},{value:"isEmpty",getApplyFilterFnV7:()=>e=>null==e,requiresFilterValue:!1},{value:"isNotEmpty",getApplyFilterFnV7:()=>e=>null!=e,requiresFilterValue:!1},{value:"isAnyOf",getApplyFilterFnV7:e=>Array.isArray(e.value)&&0!==e.value.length?t=>null!=t&&e.value.includes(Number(t)):null,InputComponent:XL,InputComponentProps:{type:"number"}}]),getApplyQuickFilterFn:tD(QD),getApplyQuickFilterFnV7:QD}),tz=["item","applyValue","type","apiRef","focusElementRef","InputProps","isFilterActive","clearButton","tabIndex","disabled"];function rz(e){var t,r;const{item:i,applyValue:o,type:a,apiRef:s,focusElementRef:l,InputProps:c,clearButton:u,tabIndex:d,disabled:h}=e,p=(0,R.A)(e,tz),f=JR(),[m,g]=n.useState(null!=(t=i.value)?t:""),[y,v]=n.useState(!1),x=(0,zp.A)(),b=tP(),_=n.useCallback((e=>{const t=e.target.value;g(String(t)),v(!0),f.start(b.filterDebounceMs,(()=>{o((0,O.A)({},i,{value:t})),v(!1)}))}),[o,i,b.filterDebounceMs,f]);return n.useEffect((()=>{var e;const t=null!=(e=i.value)?e:"";g(String(t))}),[i.value]),(0,j.jsx)(b.slots.baseTextField,(0,O.A)({fullWidth:!0,id:x,label:s.current.getLocaleText("filterPanelInputLabel"),placeholder:s.current.getLocaleText("filterPanelInputPlaceholder"),value:m,onChange:_,variant:"standard",type:a||"text",InputLabelProps:{shrink:!0},inputRef:l,InputProps:(0,O.A)({},y||u?{endAdornment:y?(0,j.jsx)(b.slots.loadIcon,{fontSize:"small",color:"action"}):u}:{},{disabled:h},c,{inputProps:(0,O.A)({max:"datetime-local"===a?"9999-12-31T23:59":"9999-12-31",tabIndex:d},null==c?void 0:c.inputProps)})},p,null==(r=b.slotProps)?void 0:r.baseTextField))}const nz=/(\d+)-(\d+)-(\d+)/,iz=/(\d+)-(\d+)-(\d+)T(\d+):(\d+)/;function oz(e,t,r,n){if(!e.value)return null;const[i,o,a,s,l]=e.value.match(r?iz:nz).slice(1).map(Number),c=new Date(i,o-1,a,s||0,l||0).getTime();return e=>{if(!e)return!1;if(n)return t(e.getTime(),c);const i=new Date(e).setHours(r?e.getHours():0,r?e.getMinutes():0,0,0);return t(i,c)}}const az=e=>eD([{value:"is",getApplyFilterFnV7:t=>oz(t,((e,t)=>e===t),e),InputComponent:rz,InputComponentProps:{type:e?"datetime-local":"date"}},{value:"not",getApplyFilterFnV7:t=>oz(t,((e,t)=>e!==t),e),InputComponent:rz,InputComponentProps:{type:e?"datetime-local":"date"}},{value:"after",getApplyFilterFnV7:t=>oz(t,((e,t)=>e>t),e),InputComponent:rz,InputComponentProps:{type:e?"datetime-local":"date"}},{value:"onOrAfter",getApplyFilterFnV7:t=>oz(t,((e,t)=>e>=t),e),InputComponent:rz,InputComponentProps:{type:e?"datetime-local":"date"}},{value:"before",getApplyFilterFnV7:t=>oz(t,((e,t)=>eoz(t,((e,t)=>e<=t),e),InputComponent:rz,InputComponentProps:{type:e?"datetime-local":"date"}},{value:"isEmpty",getApplyFilterFnV7:()=>e=>null==e,requiresFilterValue:!1},{value:"isNotEmpty",getApplyFilterFnV7:()=>e=>null!=e,requiresFilterValue:!1}]),sz=["id","value","formattedValue","api","field","row","rowNode","colDef","cellMode","isEditable","tabIndex","hasFocus","inputProps","isValidating","isProcessingProps","onValueChange"],lz=(0,yn.Ay)(GE)({fontSize:"inherit"});function cz(e){const{id:t,value:r,field:i,colDef:o,hasFocus:a,inputProps:s,onValueChange:l}=e,c=(0,R.A)(e,sz),u="dateTime"===o.type,d=xR(),h=n.useRef(),p=n.useMemo((()=>{let e,t;if(e=null==r?null:r instanceof Date?r:new Date((null!=r?r:"").toString()),null==e||Number.isNaN(e.getTime()))t="";else{t=new Date(e.getTime()-60*e.getTimezoneOffset()*1e3).toISOString().substr(0,u?16:10)}return{parsed:e,formatted:t}}),[r,u]),[f,m]=n.useState(p),g=(e=>{const{classes:t}=e;return(0,mn.A)({root:["editInputCell"]},DI,t)})({classes:tP().classes}),y=n.useCallback((e=>{if(""===e)return null;const[t,r]=e.split("T"),[n,i,o]=t.split("-"),a=new Date;if(a.setFullYear(Number(n),Number(i)-1,Number(o)),a.setHours(0,0,0,0),r){const[e,t]=r.split(":");a.setHours(Number(e),Number(t),0,0)}return a}),[]),v=n.useCallback((async e=>{const r=e.target.value,n=y(r);l&&await l(e,n),m({parsed:n,formatted:r}),d.current.setEditCellValue({id:t,field:i,value:n},e)}),[d,i,t,l,y]);return n.useEffect((()=>{m((e=>{var t,r;return p.parsed!==e.parsed&&(null==(t=p.parsed)?void 0:t.getTime())!==(null==(r=e.parsed)?void 0:r.getTime())?p:e}))}),[p]),(0,$o.A)((()=>{a&&h.current.focus()}),[a]),(0,j.jsx)(lz,(0,O.A)({inputRef:h,fullWidth:!0,className:g.root,type:u?"datetime-local":"date",inputProps:(0,O.A)({max:u?"9999-12-31T23:59":"9999-12-31"},s),value:f.formatted,onChange:v},c))}const uz=e=>(0,j.jsx)(cz,(0,O.A)({},e));function dz(e){let{value:t,columnType:r,rowId:n,field:i}=e;if(!(t instanceof Date))throw new Error([`MUI: \`${r}\` column type only accepts \`Date\` objects as values.`,"Use `valueGetter` to transform the value into a `Date` object.",`Row ID: ${n}, field: "${i}".`].join("\n"))}const hz=(0,O.A)({},bD,{type:"date",sortComparator:ZR,valueFormatter:function(e){let{value:t,field:r,id:n}=e;return t?(dz({value:t,columnType:"date",rowId:n,field:r}),t.toLocaleDateString()):""},filterOperators:az(),renderEditCell:uz,pastedValueParser:e=>new Date(e)}),pz=(0,O.A)({},bD,{type:"dateTime",sortComparator:ZR,valueFormatter:function(e){let{value:t,field:r,id:n}=e;return t?(dz({value:t,columnType:"dateTime",rowId:n,field:r}),t.toLocaleString()):""},filterOperators:az(!0),renderEditCell:uz,pastedValueParser:e=>new Date(e)});var fz=function(e){return e.enterKeyDown="enterKeyDown",e.cellDoubleClick="cellDoubleClick",e.printableKeyDown="printableKeyDown",e.deleteKeyDown="deleteKeyDown",e.pasteKeyDown="pasteKeyDown",e}(fz||{}),mz=function(e){return e.cellFocusOut="cellFocusOut",e.escapeKeyDown="escapeKeyDown",e.enterKeyDown="enterKeyDown",e.tabKeyDown="tabKeyDown",e.shiftTabKeyDown="shiftTabKeyDown",e}(mz||{}),gz=function(e){return e.Cell="cell",e.Row="row",e}(gz||{}),yz=function(e){return e.Edit="edit",e.View="view",e}(yz||{}),vz=function(e){return e.Edit="edit",e.View="view",e}(vz||{});function xz(e){return"singleSelect"===(null==e?void 0:e.type)}function bz(e,t,r){if(void 0===t)return;const n=t.find((t=>{const n=r(t);return String(n)===String(e)}));return r(n)}const _z=["id","value","formattedValue","api","field","row","rowNode","colDef","cellMode","isEditable","tabIndex","className","hasFocus","isValidating","isProcessingProps","error","onValueChange","initialOpen","getOptionLabel","getOptionValue"],wz=["MenuProps"];function kz(e){var t,r,i;const o=tP(),{id:a,value:s,field:l,row:c,colDef:u,hasFocus:d,error:h,onValueChange:p,initialOpen:f=o.editMode===gz.Cell,getOptionLabel:m,getOptionValue:g}=e,y=(0,R.A)(e,_z),v=xR(),x=n.useRef(),b=n.useRef(),[_,w]=n.useState(f),k=null!=(r=((null==(t=o.slotProps)?void 0:t.baseSelect)||{}).native)&&r,S=(null==(i=o.slotProps)?void 0:i.baseSelect)||{},{MenuProps:A}=S,T=(0,R.A)(S,wz);if((0,$o.A)((()=>{var e;d&&(null==(e=b.current)||e.focus())}),[d]),!xz(u))return null;let M;if(M="function"===typeof(null==u?void 0:u.valueOptions)?null==u?void 0:u.valueOptions({id:a,row:c,field:l}):null==u?void 0:u.valueOptions,!M)return null;const C=g||u.getOptionValue,E=m||u.getOptionLabel;return M&&u?(0,j.jsx)(o.slots.baseSelect,(0,O.A)({ref:x,inputRef:b,value:s,onChange:async e=>{if(!xz(u)||!M)return;w(!1);const t=bz(e.target.value,M,C);p&&await p(e,t),await v.current.setEditCellValue({id:a,field:l,value:t},e)},open:_,onOpen:e=>{(function(e){return!!e.key})(e)&&"Enter"===e.key||w(!0)},MenuProps:(0,O.A)({onClose:(e,t)=>{if(o.editMode!==gz.Row){if("backdropClick"===t||pR(e.key)){const t=v.current.getCellParams(a,l);v.current.publishEvent("cellEditStop",(0,O.A)({},t,{reason:pR(e.key)?mz.escapeKeyDown:mz.cellFocusOut}))}}else w(!1)}},A),error:h,native:k,fullWidth:!0},y,T,{children:M.map((e=>{var t;const r=C(e);return(0,n.createElement)(o.slots.baseSelectOption,(0,O.A)({},(null==(t=o.slotProps)?void 0:t.baseSelectOption)||{},{native:k,key:r,value:r}),E(e))}))})):null}const Sz=["item","applyValue","type","apiRef","focusElementRef","getOptionLabel","getOptionValue","placeholder","tabIndex","label","variant","isFilterActive","clearButton","InputLabelProps"],Az=e=>{let{column:{valueOptions:t,field:r},OptionComponent:i,getOptionLabel:o,getOptionValue:a,isSelectNative:s,baseSelectOptionProps:l}=e;return("function"===typeof t?["",...t({field:r})]:["",...t||[]]).map((e=>{const t=a(e),r=o(e);return(0,n.createElement)(i,(0,O.A)({},l,{native:s,key:t,value:t}),r)}))},Tz=(0,yn.Ay)("div")({display:"flex",alignItems:"flex-end",width:"100%","& button":{margin:"auto 0px 5px 5px"}});function Mz(e){var t,r,i,o,a,s,l,c;const{item:u,applyValue:d,type:h,apiRef:p,focusElementRef:f,getOptionLabel:m,getOptionValue:g,placeholder:y,tabIndex:v,label:x,variant:b="standard",clearButton:_}=e,w=(0,R.A)(e,Sz),[k,S]=n.useState(null!=(t=u.value)?t:""),A=(0,zp.A)(),T=(0,zp.A)(),M=tP(),C=null==(r=null==(i=M.slotProps)||null==(i=i.baseSelect)?void 0:i.native)||r;let E=null;if(u.field){const e=p.current.getColumn(u.field);xz(e)&&(E=e)}const I=g||(null==(o=E)?void 0:o.getOptionValue),P=m||(null==(a=E)?void 0:a.getOptionLabel),L=n.useMemo((()=>{if(E)return"function"===typeof E.valueOptions?E.valueOptions({field:E.field}):E.valueOptions}),[E]),D=n.useCallback((e=>{let t=e.target.value;t=bz(t,L,I),S(String(t)),d((0,O.A)({},u,{value:t}))}),[L,I,d,u]);if(n.useEffect((()=>{var e;let t;if(void 0!==L){if(t=bz(u.value,L,I),t!==u.value)return void d((0,O.A)({},u,{value:t}))}else t=u.value;t=null!=(e=t)?e:"",S(String(t))}),[u,L,d,I]),!xz(E))return null;if(!xz(E))return null;const z=null!=x?x:p.current.getLocaleText("filterPanelInputLabel");return(0,j.jsxs)(Tz,{children:[(0,j.jsxs)(M.slots.baseFormControl,{children:[(0,j.jsx)(M.slots.baseInputLabel,(0,O.A)({},null==(s=M.slotProps)?void 0:s.baseInputLabel,{id:T,htmlFor:A,shrink:!0,variant:b,children:z})),(0,j.jsx)(M.slots.baseSelect,(0,O.A)({id:A,label:z,labelId:T,value:k,onChange:D,variant:b,type:h||"text",inputProps:{tabIndex:v,ref:f,placeholder:null!=y?y:p.current.getLocaleText("filterPanelInputPlaceholder")},native:C,notched:"outlined"===b||void 0},w,null==(l=M.slotProps)?void 0:l.baseSelect,{children:Az({column:E,OptionComponent:M.slots.baseSelectOption,getOptionLabel:P,getOptionValue:I,isSelectNative:C,baseSelectOptionProps:null==(c=M.slotProps)?void 0:c.baseSelectOption})}))]}),_]})}const Cz=["item","applyValue","type","apiRef","focusElementRef","color","error","helperText","size","variant","getOptionLabel","getOptionValue"],Ez=iL();function Iz(e){var t,r;const{item:i,applyValue:o,apiRef:a,focusElementRef:s,color:l,error:c,helperText:u,size:d,variant:h="standard",getOptionLabel:p,getOptionValue:f}=e,m=(0,R.A)(e,Cz),g={color:l,error:c,helperText:u,size:d,variant:h},y=(0,zp.A)(),v=tP();let x=null;if(i.field){const e=a.current.getColumn(i.field);xz(e)&&(x=e)}const b=f||(null==(t=x)?void 0:t.getOptionValue),_=p||(null==(r=x)?void 0:r.getOptionLabel),w=n.useCallback(((e,t)=>b(e)===b(t)),[b]),k=n.useMemo((()=>{var e;return null!=(e=x)&&e.valueOptions?"function"===typeof x.valueOptions?x.valueOptions({field:x.field}):x.valueOptions:[]}),[x]),S=n.useMemo((()=>null==k?void 0:k.map(b)),[k,b]),A=n.useMemo((()=>{if(!Array.isArray(i.value))return[];if(void 0!==k){return i.value.map((e=>null==S?void 0:S.findIndex((t=>t===e)))).filter((e=>e>=0)).map((e=>k[e]))}return i.value}),[i.value,k,S]);n.useEffect((()=>{Array.isArray(i.value)&&A.length===i.value.length||o((0,O.A)({},i,{value:A.map(b)}))}),[i,A,o,b]);const T=n.useCallback(((e,t)=>{o((0,O.A)({},i,{value:t.map(b)}))}),[o,i,b]);return(0,j.jsx)(GL,(0,O.A)({multiple:!0,options:k,isOptionEqualToValue:w,filterOptions:Ez,id:y,value:A,onChange:T,getOptionLabel:_,renderTags:(e,t)=>e.map(((e,r)=>(0,j.jsx)(v.slots.baseChip,(0,O.A)({variant:"outlined",size:"small",label:_(e)},t({index:r}))))),renderInput:e=>{var t;return(0,j.jsx)(v.slots.baseTextField,(0,O.A)({},e,{label:a.current.getLocaleText("filterPanelInputLabel"),placeholder:a.current.getLocaleText("filterPanelInputPlaceholder"),InputLabelProps:(0,O.A)({},e.InputLabelProps,{shrink:!0}),inputRef:s,type:"singleSelect"},g,null==(t=v.slotProps)?void 0:t.baseTextField))}},m))}const Pz=e=>null!=e&&jO(e)?e.value:e,Oz=(0,O.A)({},bD,{type:"singleSelect",getOptionLabel:e=>jO(e)?e.label:String(e),getOptionValue:e=>jO(e)?e.value:e,valueFormatter(e){const{id:t,field:r,value:n,api:i}=e,o=e.api.getColumn(r);if(!xz(o))return"";let a;if(a="function"===typeof o.valueOptions?o.valueOptions({id:t,row:t?i.getRow(t):null,field:r}):o.valueOptions,null==n)return"";if(!a)return n;if("object"!==typeof a[0])return o.getOptionLabel(n);const s=a.find((e=>o.getOptionValue(e)===n));return s?o.getOptionLabel(s):""},renderEditCell:e=>(0,j.jsx)(kz,(0,O.A)({},e)),filterOperators:eD([{value:"is",getApplyFilterFnV7:e=>null==e.value||""===e.value?null:t=>Pz(t)===Pz(e.value),InputComponent:Mz},{value:"not",getApplyFilterFnV7:e=>null==e.value||""===e.value?null:t=>Pz(t)!==Pz(e.value),InputComponent:Mz},{value:"isAnyOf",getApplyFilterFnV7:e=>{if(!Array.isArray(e.value)||0===e.value.length)return null;const t=e.value.map(Pz);return e=>t.includes(Pz(e))},InputComponent:Iz}]),pastedValueParser:(e,t)=>{const r=t.colDef,n=r.valueOptions,i="function"===typeof n?n({field:r.field}):n||[],o=r.getOptionValue;if(i.find((t=>o(t)===e)))return e}});function Rz(e){return e.substring(2).toLowerCase()}function Lz(e){const{children:t,disableReactTree:r=!1,mouseEvent:i="onClick",onClickAway:o,touchEvent:a="onTouchEnd"}=e,s=n.useRef(!1),l=n.useRef(null),c=n.useRef(!1),u=n.useRef(!1);n.useEffect((()=>(setTimeout((()=>{c.current=!0}),0),()=>{c.current=!1})),[]);const d=(0,Gi.A)(t.ref,l),h=(0,ea.A)((e=>{const t=u.current;u.current=!1;const n=(0,No.A)(l.current);if(!c.current||!l.current||"clientX"in e&&function(e,t){return t.documentElement.clientWidth-1:!n.documentElement.contains(e.target)||l.current.contains(e.target),i||!r&&t||o(e)})),p=e=>r=>{u.current=!0;const n=t.props[e];n&&n(r)},f={ref:d};return!1!==a&&(f[a]=p(a)),n.useEffect((()=>{if(!1!==a){const e=Rz(a),t=(0,No.A)(l.current),r=()=>{s.current=!0};return t.addEventListener(e,h),t.addEventListener("touchmove",r),()=>{t.removeEventListener(e,h),t.removeEventListener("touchmove",r)}}}),[h,a]),!1!==i&&(f[i]=p(i)),n.useEffect((()=>{if(!1!==i){const e=Rz(i),t=(0,No.A)(l.current);return t.addEventListener(e,h),()=>{t.removeEventListener(e,h)}}}),[h,i]),(0,j.jsx)(n.Fragment,{children:n.cloneElement(t,f)})}const Dz=["open","target","onClose","children","position","className","onExited"],zz=(0,yn.Ay)(fp,{name:"MuiDataGrid",slot:"Menu",overridesResolver:(e,t)=>t.menu})((e=>{let{theme:t}=e;return{zIndex:t.zIndex.modal,[`& .${zI.menuList}`]:{outline:0}}})),jz={"bottom-start":"top left","bottom-end":"top right"};function Fz(e){var t;const{open:r,target:i,onClose:o,children:a,position:s,className:l,onExited:c}=e,u=(0,R.A)(e,Dz),d=xR(),h=tP(),p=(e=>{const{classes:t}=e;return(0,mn.A)({root:["menu"]},DI,t)})(h),f=n.useRef(null);(0,$o.A)((()=>{var e,t;r?f.current=document.activeElement instanceof HTMLElement?document.activeElement:null:(null==(e=f.current)||null==(t=e.focus)||t.call(e),f.current=null)}),[r]),n.useEffect((()=>{const e=r?"menuOpen":"menuClose";d.current.publishEvent(e,{target:i})}),[d,r,i]);const m=e=>{e.target&&(i===e.target||null!=i&&i.contains(e.target))||o(e)};return(0,j.jsx)(zz,(0,O.A)({as:h.slots.basePopper,className:(0,fn.A)(l,p.root),ownerState:h,open:r,anchorEl:i,transition:!0,placement:s},u,null==(t=h.slotProps)?void 0:t.basePopper,{children:e=>{let{TransitionProps:t,placement:r}=e;return(0,j.jsx)(Lz,{onClickAway:m,mouseEvent:"onMouseDown",children:(0,j.jsx)(Fo,(0,O.A)({},t,{style:{transformOrigin:jz[r]},onExited:(n=null==t?void 0:t.onExited,e=>{n&&n(),c&&c(e)}),children:(0,j.jsx)(Ci,{children:a})}))});var n}}))}const Nz=["api","colDef","id","hasFocus","isEditable","field","value","formattedValue","row","rowNode","cellMode","tabIndex","position","focusElementRef"];function Bz(e){var t;const{colDef:r,id:i,hasFocus:o,tabIndex:a,position:s="bottom-end",focusElementRef:l}=e,c=(0,R.A)(e,Nz),[u,d]=n.useState(-1),[h,p]=n.useState(!1),f=xR(),m=n.useRef(null),g=n.useRef(null),y=n.useRef(!1),v=n.useRef({}),x=Io(),b=(0,zp.A)(),_=(0,zp.A)(),w=tP();if(!(e=>"function"===typeof e.getActions)(r))throw new Error("MUI: Missing the `getActions` property in the `GridColDef`.");const k=r.getActions(f.current.getRowParams(i)),S=k.filter((e=>!e.props.showInMenu)),A=k.filter((e=>e.props.showInMenu)),T=S.length+(A.length?1:0);n.useLayoutEffect((()=>{o||Object.entries(v.current).forEach((e=>{let[t,r]=e;null==r||r.stop({},(()=>{delete v.current[t]}))}))}),[o]),n.useEffect((()=>{if(u<0||!m.current)return;if(u>=m.current.children.length)return;m.current.children[u].focus({preventScroll:!0})}),[u]),n.useEffect((()=>{o||(d(-1),y.current=!1)}),[o]),n.useImperativeHandle(l,(()=>({focus(){if(!y.current){const e=k.findIndex((e=>!e.props.disabled));d(e)}}})),[k]),n.useEffect((()=>{u>=T&&d(T-1)}),[u,T]);const M=()=>{p(!1)},C=e=>t=>{v.current[e]=t},E=(e,t)=>r=>{d(e),y.current=!0,t&&t(r)};return(0,j.jsxs)("div",(0,O.A)({role:"menu",ref:m,tabIndex:-1,className:zI.actionsCell,onKeyDown:e=>{if(T<=1)return;const t=(e,r)=>{var n;if(e<0||e>k.length)return e;const i=("left"===r?-1:1)*("rtl"===x.direction?-1:1);return null!=(n=k[e+i])&&n.props.disabled?t(e+i,r):e+i};let r=u;"ArrowRight"===e.key?r=t(u,"right"):"ArrowLeft"===e.key&&(r=t(u,"left")),r<0||r>=T||r!==u&&(e.preventDefault(),e.stopPropagation(),d(r))}},c,{children:[S.map(((e,t)=>n.cloneElement(e,{key:t,touchRippleRef:C(t),onClick:E(t,e.props.onClick),tabIndex:u===t?a:-1}))),A.length>0&&_&&(0,j.jsx)(w.slots.baseIconButton,(0,O.A)({ref:g,id:_,"aria-label":f.current.getLocaleText("actionsCellMore"),"aria-haspopup":"menu","aria-expanded":h,"aria-controls":h?b:void 0,role:"menuitem",size:"small",onClick:()=>{p(!0),d(T-1),y.current=!0},touchRippleRef:C(_),tabIndex:u===S.length?a:-1},null==(t=w.slotProps)?void 0:t.baseIconButton,{children:(0,j.jsx)(w.slots.moreActionsIcon,{fontSize:"small"})})),A.length>0&&(0,j.jsx)(Fz,{open:h,target:g.current,position:s,onClose:M,children:(0,j.jsx)(yo,{id:b,className:zI.menuList,onKeyDown:e=>{"Tab"===e.key&&e.preventDefault(),["Tab","Escape"].includes(e.key)&&M()},"aria-labelledby":_,variant:"menu",autoFocusItem:!0,children:A.map(((e,t)=>n.cloneElement(e,{key:t,closeMenu:M})))})})]}))}const Vz="actions",Uz=(0,O.A)({},bD,{sortable:!1,filterable:!1,aggregable:!1,width:100,align:"center",headerAlign:"center",headerName:"",disableColumnMenu:!0,disableExport:!0,renderCell:e=>(0,j.jsx)(Bz,(0,O.A)({},e)),getApplyQuickFilterFn:void 0,getApplyQuickFilterFnV7:void 0}),Hz="__default__",$z=["maxWidth","minWidth","width","flex"];const Wz=(e,t)=>{const r={};let n=0,i=0;const o=[];e.orderedFields.forEach((t=>{const a=(0,O.A)({},e.lookup[t]);if(!1===e.columnVisibilityModel[t])a.computedWidth=0;else{let e;a.flex&&a.flex>0?(n+=a.flex,e=0,o.push(a)):e=NO(a.width||bD.width,a.minWidth||bD.minWidth,a.maxWidth||bD.maxWidth),i+=e,a.computedWidth=e}r[t]=a}));const a=Math.max(t-i,0);if(n>0&&t>0){const e=function(e){let{initialFreeSpace:t,totalFlexUnits:r,flexColumns:n}=e;const i=new Set(n.map((e=>e.field))),o={all:{},frozenFields:[],freeze:e=>{const t=o.all[e];t&&!0!==t.frozen&&(o.all[e].frozen=!0,o.frozenFields.push(e))}};return function e(){if(o.frozenFields.length===i.size)return;const a={min:{},max:{}};let s=t,l=r,c=0;o.frozenFields.forEach((e=>{s-=o.all[e].computedWidth,l-=o.all[e].flex}));for(let t=0;te.maxWidth&&(c+=e.maxWidth-r,r=e.maxWidth,a.max[e.field]=!0),o.all[e.field]={frozen:!1,computedWidth:r,flex:e.flex}}c<0?Object.keys(a.max).forEach((e=>{o.freeze(e)})):c>0?Object.keys(a.min).forEach((e=>{o.freeze(e)})):n.forEach((e=>{let{field:t}=e;o.freeze(t)})),e()}(),o.all}({initialFreeSpace:a,totalFlexUnits:n,flexColumns:o});Object.keys(e).forEach((t=>{r[t].computedWidth=e[t].computedWidth}))}return(0,O.A)({},e,{lookup:r})};function qz(e,t){let r=e[Hz];return t&&e[t]&&(r=e[t]),r}const Gz=e=>{let{apiRef:t,columnsToUpsert:r,initialState:n,columnTypes:i,columnVisibilityModel:o=xP(t),keepOnlyColumnsToUpsert:a=!1}=e;var s,l,c;const u=!t.current.state.columns;let d;if(u)d={orderedFields:[],lookup:{},columnVisibilityModel:o};else{const e=mP(t.current.state);d={orderedFields:a?[]:[...e.orderedFields],lookup:(0,O.A)({},e.lookup),columnVisibilityModel:o}}let h={};a&&!u&&(h=Object.keys(d.lookup).reduce(((e,t)=>(0,O.A)({},e,{[t]:!1})),{}));const p={};r.forEach((e=>{const{field:t}=e;p[t]=!0,h[t]=!0;let r=d.lookup[t];null==r?(r=(0,O.A)({},qz(i,e.type),{field:t,hasBeenResized:!1}),d.orderedFields.push(t)):a&&d.orderedFields.push(t),r&&r.type!==e.type&&(r=(0,O.A)({},qz(i,e.type),{field:t}));let n=r.hasBeenResized;$z.forEach((t=>{void 0!==e[t]&&(n=!0,-1===e[t]&&(e[t]=1/0))})),d.lookup[t]=(0,O.A)({},r,e,{hasBeenResized:n})})),a&&!u&&Object.keys(d.lookup).forEach((e=>{h[e]||delete d.lookup[e]}));const f=((e,t)=>{if(!t)return e;const{orderedFields:r=[],dimensions:n={}}=t,i=Object.keys(n);if(0===i.length&&0===r.length)return e;const o={},a=[];for(let c=0;c!o[e]))],l=(0,O.A)({},e.lookup);for(let c=0;c{let[r,n]=e;t[r]=-1===n?1/0:n})),l[e]=t}return(0,O.A)({},e,{orderedFields:s,lookup:l})})(t.current.unstable_applyPipeProcessors("hydrateColumns",d),n);return Wz(f,null!=(s=null==(l=(c=t.current).getRootDimensions)||null==(l=l.call(c))?void 0:l.viewportInnerSize.width)?s:0)},Yz=e=>t=>(0,O.A)({},t,{columns:e});function Xz(e){let{firstColumnToRender:t,apiRef:r,firstRowToRender:n,lastRowToRender:i,visibleRows:o}=e,a=t;for(let s=n;s{var n,i,o,a;const s=Gz({apiRef:r,columnTypes:Qz,columnsToUpsert:t.columns,initialState:null==(n=t.initialState)?void 0:n.columns,columnVisibilityModel:null!=(i=null!=(o=t.columnVisibilityModel)?o:null==(a=t.initialState)||null==(a=a.columns)?void 0:a.columnVisibilityModel)?i:{},keepOnlyColumnsToUpsert:!0});return(0,O.A)({},e,{columns:s})};const tj={compact:.7,comfortable:1.3,standard:1},rj=(e,t)=>(0,O.A)({},e,{density:{value:t.density,factor:tj[t.density]}});const nj=e=>{let{apiRef:t,options:r}=e;const n=vP(t);if(r.fields)return r.fields.reduce(((e,t)=>{const r=n.find((e=>e.field===t));return r&&e.push(r),e}),[]);return(r.allColumns?n:bP(t)).filter((e=>!e.disableExport))},ij=e=>{let{apiRef:t}=e;var r,n;const i=yO(t),o=jP(t),a=t.current.getSelectedRows(),s=i.filter((e=>"footer"!==o[e].type)),l=UP(t),c=(null==l||null==(r=l.top)?void 0:r.map((e=>e.id)))||[],u=(null==l||null==(n=l.bottom)?void 0:n.map((e=>e.id)))||[];return s.unshift(...c),s.push(...u),a.size>0?s.filter((e=>a.has(e))):s},oj=["hideMenu","options"],aj=["hideMenu","options"];function sj(e){const t=xR(),{hideMenu:r,options:n}=e,i=(0,R.A)(e,oj);return(0,j.jsx)(qa,(0,O.A)({onClick:()=>{t.current.exportDataAsCsv(n),null==r||r()}},i,{children:t.current.getLocaleText("toolbarExportCSV")}))}function lj(e){const t=xR(),{hideMenu:r,options:n}=e,i=(0,R.A)(e,aj);return(0,j.jsx)(qa,(0,O.A)({onClick:()=>{t.current.exportDataAsPrint(n),null==r||r()}},i,{children:t.current.getLocaleText("toolbarExportPrint")}))}const cj=(e,t)=>{const r=hR(e,"useGridCsvExport"),i=t.unstable_ignoreValueFormatterDuringExport,o=("object"===typeof i?null==i?void 0:i.csvExport:i)||!1,a=n.useCallback((function(){let t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};var n,i,a,s,l;r.debug("Get data as CSV");return WD({columns:nj({apiRef:e,options:t}),rowIds:(null!=(n=t.getRowsToExport)?n:ij)({apiRef:e}),csvOptions:{delimiter:t.delimiter||",",shouldAppendQuotes:null==(i=t.shouldAppendQuotes)||i,includeHeaders:null==(a=t.includeHeaders)||a,includeColumnGroupsHeaders:null==(s=t.includeColumnGroupsHeaders)||s,escapeFormulas:null==(l=t.escapeFormulas)||l},ignoreValueFormatter:o,apiRef:e})}),[r,e,o]),s=n.useCallback((e=>{r.debug("Export data as CSV");const t=a(e);!function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"csv";const r=`${arguments.length>2&&void 0!==arguments[2]?arguments[2]:document.title||"untitled"}.${t}`;if("download"in HTMLAnchorElement.prototype){const t=URL.createObjectURL(e),n=document.createElement("a");return n.href=t,n.download=r,n.click(),void setTimeout((()=>{URL.revokeObjectURL(t)}))}throw new Error("MUI: exportAs not supported")}(new Blob([null!=e&&e.utf8WithBom?new Uint8Array([239,187,191]):"",t],{type:"text/csv"}),"csv",null==e?void 0:e.fileName)}),[r,a]);HO(e,{getDataAsCsv:a,exportDataAsCsv:s},"public");const l=n.useCallback(((e,t)=>{var r;return null!=(r=t.csvOptions)&&r.disableToolbarButton?e:[...e,{component:(0,j.jsx)(sj,{options:t.csvOptions}),componentName:"csvExport"}]}),[]);ZD(e,"exportMenu",l)},uj=e=>e.rowsMeta,dj=(e,t,r)=>{var n;let i=e.paginationModel;const o=e.rowCount,a=null!=(n=null==r?void 0:r.pageSize)?n:i.pageSize,s=TR(o,a);!r||(null==r?void 0:r.page)===i.page&&(null==r?void 0:r.pageSize)===i.pageSize||(i=r);const l=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;return 0===t?e:Math.max(Math.min(e,t-1),0)}(i.page,s);return l!==i.page&&(i=(0,O.A)({},i,{page:l})),CR(i.pageSize,t),i};const hj=(e,t)=>{const r=hR(e,"useGridPrintExport"),i=n.useRef(null),o=n.useRef(null),a=n.useRef({}),s=n.useRef([]);n.useEffect((()=>{i.current=(0,No.A)(e.current.rootElementRef.current)}),[e]);const l=n.useCallback(((t,r,n)=>new Promise((i=>{const o=nj({apiRef:e,options:{fields:t,allColumns:r}}).map((e=>e.field)),a=vP(e),s={};a.forEach((e=>{s[e.field]=o.includes(e.field)})),n&&(s[VD.field]=!0),e.current.setColumnVisibilityModel(s),i()}))),[e]),c=n.useCallback((t=>{const r=t({apiRef:e}).map((t=>e.current.getRow(t)));e.current.setRows(r)}),[e]),u=n.useCallback(((r,n)=>{var o,a;const s=(0,O.A)({copyStyles:!0,hideToolbar:!1,hideFooter:!1,includeCheckboxes:!1},n),l=r.contentDocument;if(!l)return;const c=uj(e.current.state),u=e.current.rootElementRef.current,d=u.cloneNode(!0);d.querySelector(`.${zI.main}`).style.overflow="visible",d.style.contain="size";d.querySelector(`.${zI.columnHeaders}`).querySelector(`.${zI.columnHeadersInner}`).style.width="100%";let h=(null==(o=u.querySelector(`.${zI.toolbarContainer}`))?void 0:o.offsetHeight)||0,p=(null==(a=u.querySelector(`.${zI.footerContainer}`))?void 0:a.offsetHeight)||0;var f,m;s.hideToolbar&&(null==(f=d.querySelector(`.${zI.toolbarContainer}`))||f.remove(),h=0);s.hideFooter&&(null==(m=d.querySelector(`.${zI.footerContainer}`))||m.remove(),p=0);const g=c.currentPageTotalHeight+Kz(e,t.columnHeaderHeight)+h+p;if(d.style.height=`${g}px`,d.style.boxSizing="content-box",null!=n&&n.getRowsToExport){const e=d.querySelector(`.${zI.footerContainer}`);e.style.position="absolute",e.style.width="100%",e.style.top=g-p+"px"}const y=document.createElement("div");y.appendChild(d),l.body.innerHTML=y.innerHTML;const v="function"===typeof s.pageStyle?s.pageStyle():s.pageStyle;if("string"===typeof v){const e=l.createElement("style");e.appendChild(l.createTextNode(v)),l.head.appendChild(e)}s.bodyClassName&&l.body.classList.add(...s.bodyClassName.split(" "));const x=[];if(s.copyStyles){const e=u.getRootNode(),t=("ShadowRoot"===e.constructor.name?e:i.current).querySelectorAll("style, link[rel='stylesheet']");for(let r=0;r{t.addEventListener("load",(()=>e()))}))),l.head.appendChild(t)}}}Promise.all(x).then((()=>{r.contentWindow.print()}))}),[e,i,t.columnHeaderHeight]),d=n.useCallback((t=>{var r;i.current.body.removeChild(t),e.current.restoreState(o.current||{}),null!=(r=o.current)&&null!=(r=r.columns)&&r.columnVisibilityModel||e.current.setColumnVisibilityModel(a.current),e.current.unstable_setVirtualization(!0),e.current.setRows(s.current),o.current=null,a.current={},s.current=[]}),[e]),h=n.useCallback((async n=>{if(r.debug("Export data as Print"),!e.current.rootElementRef.current)throw new Error("MUI: No grid root element available.");o.current=e.current.exportState(),a.current=xP(e);const h=DP(e);if(s.current=VP(e).map((e=>h[e])),t.pagination){const t={page:0,pageSize:xO(e)};e.current.setState((e=>(0,O.A)({},e,{pagination:(0,O.A)({},e.pagination,{paginationModel:dj(e.pagination,"DataGridPro",t)})}))),e.current.forceUpdate()}await l(null==n?void 0:n.fields,null==n?void 0:n.allColumns,null==n?void 0:n.includeCheckboxes),null!=n&&n.getRowsToExport&&c(n.getRowsToExport),e.current.unstable_setVirtualization(!1),await new Promise((e=>{requestAnimationFrame((()=>{e()}))}));const p=function(e){const t=document.createElement("iframe");return t.style.position="absolute",t.style.width="0px",t.style.height="0px",t.title=e||document.title,t}(null==n?void 0:n.fileName);p.onload=()=>{u(p,n);p.contentWindow.matchMedia("print").addEventListener("change",(e=>{!1===e.matches&&d(p)}))},i.current.body.appendChild(p)}),[t,r,e,u,d,l,c]);HO(e,{exportDataAsPrint:h},"public");const p=n.useCallback(((e,t)=>{var r;return null!=(r=t.printOptions)&&r.disableToolbarButton?e:[...e,{component:(0,j.jsx)(lj,{options:t.printOptions}),componentName:"printExport"}]}),[]);ZD(e,"exportMenu",p)},pj=(e,t,r,i)=>{const o=n.useCallback((()=>{e.current.registerStrategyProcessor(t,r,i)}),[e,i,r,t]);XD((()=>{o()}));const a=n.useRef(!0);n.useEffect((()=>{a.current?a.current=!1:o()}),[o])},fj=(e,t,r)=>{var n,i,o;const a=null!=(n=null!=(i=t.filterModel)?i:null==(o=t.initialState)||null==(o=o.filter)?void 0:o.filterModel)?n:nD();return(0,O.A)({},e,{filter:{filterModel:uD(a,t.disableMultipleColumnsFiltering,r),filteredRowsLookup:{},filteredDescendantCountLookup:{}},visibleRowsLookup:{}})},mj=e=>e.filteredRowsLookup;function gj(e,t){return e.current.applyStrategyProcessor("visibleRowsLookupCreation",{tree:t.rows.tree,filteredRowsLookup:t.filter.filteredRowsLookup})}function yj(){return iP(Object.values)}const vj=(e,t)=>{let r,n;return t.pagination&&"client"===t.paginationMode?(n=DR(e),r=zR(e)):(r=fO(e),n=0===r.length?null:{firstRowIndex:0,lastRowIndex:r.length-1}),{rows:r,range:n}},xj=(e,t)=>{const r=vj(e,t);return n.useMemo((()=>({rows:r.rows,range:r.range})),[r.rows,r.range])},bj=e=>(0,O.A)({},e,{focus:{cell:null,columnHeader:null,columnHeaderFilter:null,columnGroupHeader:null},tabIndex:{cell:null,columnHeader:null,columnHeaderFilter:null,columnGroupHeader:null}}),_j="__detail_panel_toggle__",wj=e=>e.headerFiltering,kj=uP(wj,(e=>e.editing)),Sj=uP(wj,(e=>e.menuOpen));function Aj(e,t){return e.closest(`.${t}`)}function Tj(e){return e.replace(/["\\]/g,"\\$&")}function Mj(e){return`.${zI.row}[data-id="${Tj(String(e))}"]`}function Cj(e){return 1===e.target.nodeType&&!e.currentTarget.contains(e.target)}const Ej=e=>{let{currentColIndex:t,firstColIndex:r,lastColIndex:n,direction:i}=e;if("rtl"===i){if(tr)return t-1;return null},Ij=e=>{let{currentColIndex:t,firstColIndex:r,lastColIndex:n,direction:i}=e;if("rtl"===i){if(t>r)return t-1}else if("ltr"===i&&t{const r=hR(e,"useGridKeyboardNavigation"),i=xj(e,t).rows,o=Io(),a=n.useMemo((()=>function(e,t){const r=UP(e)||{};return[...r.top||[],...t,...r.bottom||[]]}(e,i)),[e,i]),s="DataGrid"!==t.signature&&t.unstable_headerFilters,l=n.useCallback((function(t,n){let i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"left";const o=fO(e),a=e.current.unstable_getCellColSpanInfo(n,t);a&&a.spannedByColSpan&&("left"===i?t=a.leftVisibleCellIndex:"right"===i&&(t=a.rightVisibleCellIndex));const s=o.findIndex((e=>e.id===n));r.debug(`Navigating to cell row ${s}, col ${t}`),e.current.scrollToIndexes({colIndex:t,rowIndex:s});const l=e.current.getVisibleColumns()[t].field;e.current.setCellFocus(n,l)}),[e,r]),c=n.useCallback(((t,n)=>{r.debug(`Navigating to header col ${t}`),e.current.scrollToIndexes({colIndex:t});const i=e.current.getVisibleColumns()[t].field;e.current.setColumnHeaderFocus(i,n)}),[e,r]),u=n.useCallback(((t,n)=>{r.debug(`Navigating to header filter col ${t}`),e.current.scrollToIndexes({colIndex:t});const i=e.current.getVisibleColumns()[t].field;e.current.setColumnHeaderFilterFocus(i,n)}),[e,r]),d=n.useCallback(((t,n,i)=>{r.debug(`Navigating to header col ${t}`),e.current.scrollToIndexes({colIndex:t});const{field:o}=e.current.getVisibleColumns()[t];e.current.setColumnGroupHeaderFocus(o,n,i)}),[e,r]),h=n.useCallback((e=>{var t;return null==(t=a[e])?void 0:t.id}),[a]),p=n.useCallback(((t,r)=>{const n=r.currentTarget.querySelector(`.${zI.columnHeaderTitleContainerContent}`);if(!!n&&n.contains(r.target)&&t.field!==VD.field)return;if(!e.current.getRootDimensions())return;const i=e.current.getViewportPageSize(),p=t.field?e.current.getColumnIndex(t.field):0,f=a.length>0?0:null,m=a.length-1,g=bP(e).length-1,y=IP(e);let v=!0;switch(r.key){case"ArrowDown":null!==f&&(s?u(p,r):l(p,h(f)));break;case"ArrowRight":{const e=Ij({currentColIndex:p,firstColIndex:0,lastColIndex:g,direction:o.direction});null!==e&&c(e,r);break}case"ArrowLeft":{const e=Ej({currentColIndex:p,firstColIndex:0,lastColIndex:g,direction:o.direction});null!==e&&c(e,r);break}case"ArrowUp":y>0&&d(p,y-1,r);break;case"PageDown":null!==f&&null!==m&&l(p,h(Math.min(f+i,m)));break;case"Home":c(0,r);break;case"End":c(g,r);break;case"Enter":(r.ctrlKey||r.metaKey)&&e.current.toggleColumnMenu(t.field);break;case" ":break;default:v=!1}v&&r.preventDefault()}),[e,a.length,s,u,l,h,o.direction,c,d]),f=n.useCallback(((t,r)=>{if(!e.current.getRootDimensions())return;const n=kj(e)===t.field,i=Sj(e)===t.field;if(n||i||!vR(r.key))return;const s=e.current.getViewportPageSize(),d=t.field?e.current.getColumnIndex(t.field):0,p=a.length-1,f=bP(e).length-1;let m=!0;switch(r.key){case"ArrowDown":{const e=h(0);null!=e&&l(d,e);break}case"ArrowRight":{const e=Ij({currentColIndex:d,firstColIndex:0,lastColIndex:f,direction:o.direction});null!==e&&u(e,r);break}case"ArrowLeft":{const n=Ej({currentColIndex:d,firstColIndex:0,lastColIndex:f,direction:o.direction});null!==n?u(n,r):e.current.setColumnHeaderFilterFocus(t.field,r);break}case"ArrowUp":c(d,r);break;case"PageDown":null!==p&&l(d,h(Math.min(0+s,p)));break;case"Home":u(0,r);break;case"End":u(f,r);break;case" ":break;default:m=!1}m&&r.preventDefault()}),[e,a.length,u,o.direction,c,l,h]),m=n.useCallback(((t,r)=>{if(!e.current.getRootDimensions())return;const n=TO(e);if(null===n)return;const{field:i,depth:o}=n,{fields:s,depth:u,maxDepth:p}=t,f=e.current.getViewportPageSize(),m=e.current.getColumnIndex(i),g=i?e.current.getColumnIndex(i):0,y=a.length-1,v=bP(e).length-1;let x=!0;switch(r.key){case"ArrowDown":u===p-1?c(m,r):d(m,o+1,r);break;case"ArrowUp":u>0&&d(m,o-1,r);break;case"ArrowRight":{const e=s.length-s.indexOf(i)-1;m+e+1<=v&&d(m+e+1,o,r);break}case"ArrowLeft":{const e=s.indexOf(i);m-e-1>=0&&d(m-e-1,o,r);break}case"PageDown":null!==y&&l(g,h(Math.min(0+f,y)));break;case"Home":d(0,o,r);break;case"End":d(v,o,r);break;case" ":break;default:x=!1}x&&r.preventDefault()}),[e,a.length,c,d,l,h]),g=n.useCallback(((t,r)=>{if(Cj(r))return;const n=e.current.getCellParams(t.id,t.field);if(n.cellMode===yz.Edit||!vR(r.key))return;if(!e.current.unstable_applyPipeProcessors("canUpdateFocus",!0,{event:r,cell:n}))return;const i=e.current.getRootDimensions();if(0===a.length||!i)return;const d=o.direction,p=e.current.getViewportPageSize(),f=t.field?e.current.getColumnIndex(t.field):0,m=a.findIndex((e=>e.id===t.id)),g=a.length-1,y=bP(e).length-1;let v=!0;switch(r.key){case"ArrowDown":m0?l(f,h(m-1)):s?u(f,r):c(f,r);break;case"ArrowRight":{const e=Ij({currentColIndex:f,firstColIndex:0,lastColIndex:y,direction:d});null!==e&&l(e,h(m),"rtl"===d?"left":"right");break}case"ArrowLeft":{const e=Ej({currentColIndex:f,firstColIndex:0,lastColIndex:y,direction:d});null!==e&&l(e,h(m),"rtl"===d?"right":"left");break}case"Tab":r.shiftKey&&f>0?l(f-1,h(m),"left"):!r.shiftKey&&f=0?l(f,h(e)):c(f,r);break}case"Home":r.ctrlKey||r.metaKey||r.shiftKey?l(0,h(0)):l(0,h(m));break;case"End":r.ctrlKey||r.metaKey||r.shiftKey?l(y,h(g)):l(y,h(m));break;default:v=!1}v&&r.preventDefault()}),[e,a,o.direction,l,h,s,u,c]),y=n.useCallback(((e,t)=>{let{event:r}=t;return" "!==r.key&&e}),[]);ZD(e,"canStartEditing",y),tR(e,"columnHeaderKeyDown",p),tR(e,"headerFilterKeyDown",f),tR(e,"columnGroupHeaderKeyDown",m),tR(e,"cellKeyDown",g)},Oj=(e,t)=>{var r,n,i,o,a;const s=(0,O.A)({},MR(t.autoPageSize),null!=(r=t.paginationModel)?r:null==(n=t.initialState)||null==(n=n.pagination)?void 0:n.paginationModel);CR(s.pageSize,t.signature);const l=null!=(i=null!=(o=t.rowCount)?o:null==(a=t.initialState)||null==(a=a.pagination)?void 0:a.rowCount)?i:0;return(0,O.A)({},e,{pagination:{paginationModel:s,rowCount:l}})},Rj=(e,t)=>{((e,t)=>{var r;const i=hR(e,"useGridPaginationModel"),o=KI(e,fP),a=Math.floor(t.rowHeight*o);e.current.registerControlState({stateId:"paginationModel",propModel:t.paginationModel,propOnChange:t.onPaginationModelChange,stateSelector:IR,changeEvent:"paginationModelChange"});const s=n.useCallback((t=>{const r=IR(e);t!==r.page&&(i.debug(`Setting page to ${t}`),e.current.setPaginationModel({page:t,pageSize:r.pageSize}))}),[e,i]),l=n.useCallback((t=>{const r=IR(e);t!==r.pageSize&&(i.debug(`Setting page size to ${t}`),e.current.setPaginationModel({pageSize:t,page:r.page}))}),[e,i]),c=n.useCallback((r=>{const n=IR(e);r!==n&&(i.debug("Setting 'paginationModel' to",r),e.current.setState((e=>(0,O.A)({},e,{pagination:(0,O.A)({},e.pagination,{paginationModel:dj(e.pagination,t.signature,r)})}))))}),[e,i,t.signature]);HO(e,{setPage:s,setPageSize:l,setPaginationModel:c},"public");const u=n.useCallback(((r,n)=>{var i;const o=IR(e);return!n.exportOnlyDirtyModels||null!=t.paginationModel||null!=(null==(i=t.initialState)||null==(i=i.pagination)?void 0:i.paginationModel)||0!==o.page&&o.pageSize!==(t.autoPageSize?0:100)?(0,O.A)({},r,{pagination:(0,O.A)({},r.pagination,{paginationModel:o})}):r}),[e,t.paginationModel,null==(r=t.initialState)||null==(r=r.pagination)?void 0:r.paginationModel,t.autoPageSize]),d=n.useCallback(((r,n)=>{var i,o;const a=null!=(i=n.stateToRestore.pagination)&&i.paginationModel?(0,O.A)({},MR(t.autoPageSize),null==(o=n.stateToRestore.pagination)?void 0:o.paginationModel):IR(e);return e.current.setState((e=>(0,O.A)({},e,{pagination:(0,O.A)({},e.pagination,{paginationModel:dj(e.pagination,t.signature,a)})}))),r}),[e,t.autoPageSize,t.signature]);ZD(e,"exportState",u),ZD(e,"restoreState",d);const h=n.useCallback((()=>{if(!t.autoPageSize)return;const r=e.current.getRootDimensions()||{viewportInnerSize:{height:0}},n=ED(e),i=Math.floor((r.viewportInnerSize.height-n.top-n.bottom)/a);e.current.setPageSize(i)}),[e,t.autoPageSize,a]),p=n.useCallback((t=>{if(null==t)return;const r=IR(e),n=LR(e);r.page>n-1&&e.current.setPage(Math.max(0,n-1))}),[e]);tR(e,"viewportInnerSizeChange",h),tR(e,"paginationModelChange",(()=>{var t;const r=IR(e);null!=(t=e.current.virtualScrollerRef)&&t.current&&e.current.scrollToIndexes({rowIndex:r.page*r.pageSize})})),tR(e,"rowCountChange",p),n.useEffect((()=>{e.current.setState((e=>(0,O.A)({},e,{pagination:(0,O.A)({},e.pagination,{paginationModel:dj(e.pagination,t.signature,t.paginationModel)})})))}),[e,t.paginationModel,t.paginationMode,t.signature]),n.useEffect(h,[h])})(e,t),((e,t)=>{var r;const i=hR(e,"useGridRowCount"),o=KI(e,bO),a=KI(e,PR);e.current.registerControlState({stateId:"paginationRowCount",propModel:t.rowCount,propOnChange:t.onRowCountChange,stateSelector:PR,changeEvent:"rowCountChange"});const s=n.useCallback((t=>{a!==t&&(i.debug("Setting 'rowCount' to",t),e.current.setState((e=>(0,O.A)({},e,{pagination:(0,O.A)({},e.pagination,{rowCount:t})}))))}),[e,i,a]);HO(e,{setRowCount:s},"public");const l=n.useCallback(((r,n)=>{var i;const o=PR(e);return n.exportOnlyDirtyModels&&null==t.rowCount&&null==(null==(i=t.initialState)||null==(i=i.pagination)?void 0:i.rowCount)?r:(0,O.A)({},r,{pagination:(0,O.A)({},r.pagination,{rowCount:o})})}),[e,t.rowCount,null==(r=t.initialState)||null==(r=r.pagination)?void 0:r.rowCount]),c=n.useCallback(((t,r)=>{var n;const i=null!=(n=r.stateToRestore.pagination)&&n.rowCount?r.stateToRestore.pagination.rowCount:PR(e);return e.current.setState((e=>(0,O.A)({},e,{pagination:(0,O.A)({},e.pagination,{rowCount:i})}))),t}),[e]);ZD(e,"exportState",l),ZD(e,"restoreState",c),n.useEffect((()=>{}),[t.rowCount,t.paginationMode]),n.useEffect((()=>{"client"===t.paginationMode?e.current.setRowCount(o):null!=t.rowCount&&e.current.setRowCount(t.rowCount)}),[e,o,t.paginationMode,t.rowCount])})(e,t)},Lj=e=>e.preferencePanel,Dj=(e,t)=>{var r,n;return(0,O.A)({},e,{preferencePanel:null!=(r=null==(n=t.initialState)?void 0:n.preferencePanel)?r:{open:!1}})},zj=e=>e.editRows,jj=["id","field"],Fj=["id","field"],Nj=$I(["MUI: A call to `processRowUpdate` threw an error which was not handled because `onProcessRowUpdateError` is missing.","To handle the error pass a callback to the `onProcessRowUpdateError` prop, e.g. ` ...} />`.","For more detail, see http://mui.com/components/data-grid/editing/#server-side-persistence."],"error");var Bj=function(e){return e.enterKeyDown="enterKeyDown",e.cellDoubleClick="cellDoubleClick",e.printableKeyDown="printableKeyDown",e.deleteKeyDown="deleteKeyDown",e}(Bj||{}),Vj=function(e){return e.rowFocusOut="rowFocusOut",e.escapeKeyDown="escapeKeyDown",e.enterKeyDown="enterKeyDown",e.tabKeyDown="tabKeyDown",e.shiftTabKeyDown="shiftTabKeyDown",e}(Vj||{});const Uj=["id"],Hj=["id"],$j=$I(["MUI: A call to `processRowUpdate` threw an error which was not handled because `onProcessRowUpdateError` is missing.","To handle the error pass a callback to the `onProcessRowUpdateError` prop, e.g. ` ...} />`.","For more detail, see http://mui.com/components/data-grid/editing/#server-side-persistence."],"error"),Wj=e=>(0,O.A)({},e,{editRows:{}}),qj=(e,t)=>{((e,t)=>{const[r,i]=n.useState({}),o=n.useRef(r),a=n.useRef({}),{processRowUpdate:s,onProcessRowUpdateError:l,cellModesModel:c,onCellModesModelChange:u}=t,d=e=>function(){t.editMode===gz.Cell&&e(...arguments)},h=n.useCallback(((t,r)=>{const n=e.current.getCellParams(t,r);if(!e.current.isCellEditable(n))throw new Error(`MUI: The cell with id=${t} and field=${r} is not editable.`)}),[e]),p=n.useCallback(((t,r,n)=>{if(e.current.getCellMode(t,r)!==n)throw new Error(`MUI: The cell with id=${t} and field=${r} is not in ${n} mode.`)}),[e]),f=n.useCallback(((t,r)=>{if(!t.isEditable)return;if(t.cellMode===yz.Edit)return;const n=(0,O.A)({},t,{reason:fz.cellDoubleClick});e.current.publishEvent("cellEditStart",n,r)}),[e]),m=n.useCallback(((t,r)=>{if(t.cellMode===yz.View)return;if(e.current.getCellMode(t.id,t.field)===yz.View)return;const n=(0,O.A)({},t,{reason:mz.cellFocusOut});e.current.publishEvent("cellEditStop",n,r)}),[e]),g=n.useCallback(((t,r)=>{if(t.cellMode===yz.Edit){if(229===r.which)return;let n;if("Escape"===r.key?n=mz.escapeKeyDown:"Enter"===r.key?n=mz.enterKeyDown:"Tab"===r.key&&(n=r.shiftKey?mz.shiftTabKeyDown:mz.tabKeyDown,r.preventDefault()),n){const i=(0,O.A)({},t,{reason:n});e.current.publishEvent("cellEditStop",i,r)}}else if(t.isEditable){let n;if(!e.current.unstable_applyPipeProcessors("canStartEditing",!0,{event:r,cellParams:t,editMode:"cell"}))return;if(yR(r)?n=fz.printableKeyDown:(r.ctrlKey||r.metaKey)&&"v"===r.key?n=fz.pasteKeyDown:"Enter"===r.key?n=fz.enterKeyDown:"Delete"!==r.key&&"Backspace"!==r.key||(n=fz.deleteKeyDown),n){const i=(0,O.A)({},t,{reason:n,key:r.key});e.current.publishEvent("cellEditStart",i,r)}}}),[e]),y=n.useCallback((t=>{const{id:r,field:n,reason:i}=t,o={id:r,field:n};i!==fz.printableKeyDown&&i!==fz.deleteKeyDown&&i!==fz.pasteKeyDown||(o.deleteValue=!0),e.current.startCellEditMode(o)}),[e]),v=n.useCallback((t=>{const{id:r,field:n,reason:i}=t;let o;e.current.runPendingEditCellValueMutation(r,n),i===mz.enterKeyDown?o="below":i===mz.tabKeyDown?o="right":i===mz.shiftTabKeyDown&&(o="left");const a="escapeKeyDown"===i;e.current.stopCellEditMode({id:r,field:n,ignoreModifications:a,cellToFocusAfter:o})}),[e]);tR(e,"cellDoubleClick",d(f)),tR(e,"cellFocusOut",d(m)),tR(e,"cellKeyDown",d(g)),tR(e,"cellEditStart",d(y)),tR(e,"cellEditStop",d(v)),nR(e,"cellEditStart",t.onCellEditStart),nR(e,"cellEditStop",t.onCellEditStop);const x=n.useCallback(((t,r)=>{const n=zj(e.current.state);return n[t]&&n[t][r]?yz.Edit:yz.View}),[e]),b=(0,ea.A)((r=>{const n=r!==t.cellModesModel;u&&n&&u(r,{}),t.cellModesModel&&n||(i(r),o.current=r,e.current.publishEvent("cellModesModelChange",r))})),_=n.useCallback(((e,t,r)=>{const n=(0,O.A)({},o.current);if(null!==r)n[e]=(0,O.A)({},n[e],{[t]:(0,O.A)({},r)});else{const r=n[e],i=(0,R.A)(r,[t].map(Gs));n[e]=i,0===Object.keys(n[e]).length&&delete n[e]}b(n)}),[b]),w=n.useCallback(((t,r,n)=>{e.current.setState((e=>{const i=(0,O.A)({},e.editRows);return null!==n?i[t]=(0,O.A)({},i[t],{[r]:(0,O.A)({},n)}):(delete i[t][r],0===Object.keys(i[t]).length&&delete i[t]),(0,O.A)({},e,{editRows:i})})),e.current.forceUpdate()}),[e]),k=n.useCallback((e=>{const{id:t,field:r}=e,n=(0,R.A)(e,jj);h(t,r),p(t,r,yz.View),_(t,r,(0,O.A)({mode:yz.Edit},n))}),[h,p,_]),S=(0,ea.A)((t=>{const{id:r,field:n,deleteValue:i,initialValue:o}=t;let a=e.current.getCellValue(r,n);(i||o)&&(a=i?"":o),w(r,n,{value:a,error:!1,isProcessingProps:!1}),e.current.setCellFocus(r,n)})),A=n.useCallback((e=>{const{id:t,field:r}=e,n=(0,R.A)(e,Fj);p(t,r,yz.Edit),_(t,r,(0,O.A)({mode:yz.View},n))}),[p,_]),T=(0,ea.A)((async t=>{const{id:r,field:n,ignoreModifications:i,cellToFocusAfter:o="none"}=t;p(r,n,yz.Edit),e.current.runPendingEditCellValueMutation(r,n);const c=()=>{w(r,n,null),_(r,n,null),"none"!==o&&e.current.moveFocusToRelativeCell(r,n,o)};if(i)return void c();const u=zj(e.current.state),{error:d,isProcessingProps:h}=u[r][n];if(d||h)return a.current[r][n].mode=yz.Edit,void _(r,n,{mode:yz.Edit});const f=e.current.getRowWithUpdatedValuesFromCellEditing(r,n);if(s){const t=e=>{a.current[r][n].mode=yz.Edit,_(r,n,{mode:yz.Edit}),l?l(e):Nj()};try{const n=e.current.getRow(r);Promise.resolve(s(f,n)).then((t=>{e.current.updateRows([t]),c()})).catch(t)}catch(m){t(m)}}else e.current.updateRows([f]),c()})),M={setCellEditingEditCellValue:n.useCallback((async t=>{var r;const{id:n,field:i,value:o,debounceMs:a,unstable_skipValueParser:s}=t;h(n,i),p(n,i,yz.Edit);const l=e.current.getColumn(i),c=e.current.getRow(n);let u=o;l.valueParser&&!s&&(u=l.valueParser(o,e.current.getCellParams(n,i)));let d=zj(e.current.state),f=(0,O.A)({},d[n][i],{value:u,changeReason:a?"debouncedSetEditCellValue":"setEditCellValue"});if(l.preProcessEditCellProps){const e=o!==d[n][i].value;f=(0,O.A)({},f,{isProcessingProps:!0}),w(n,i,f),f=await Promise.resolve(l.preProcessEditCellProps({id:n,row:c,props:f,hasChanged:e}))}return e.current.getCellMode(n,i)!==yz.View&&(d=zj(e.current.state),f=(0,O.A)({},f,{isProcessingProps:!1}),f.value=l.preProcessEditCellProps?d[n][i].value:u,w(n,i,f),d=zj(e.current.state),!(null!=(r=d[n])&&null!=(r=r[i])&&r.error))}),[e,h,p,w]),getRowWithUpdatedValuesFromCellEditing:n.useCallback(((t,r)=>{const n=e.current.getColumn(r),i=zj(e.current.state),o=e.current.getRow(t);if(!i[t]||!i[t][r])return e.current.getRow(t);const{value:a}=i[t][r];return n.valueSetter?n.valueSetter({value:a,row:o}):(0,O.A)({},o,{[r]:a})}),[e])};HO(e,{getCellMode:x,startCellEditMode:k,stopCellEditMode:A},"public"),HO(e,M,"private"),n.useEffect((()=>{c&&b(c)}),[c,b]),(0,$o.A)((()=>{const t=zP(e),n=a.current;a.current=UO(r),Object.entries(r).forEach((e=>{let[r,i]=e;Object.entries(i).forEach((e=>{let[i,o]=e;var a,s;const l=(null==(a=n[r])||null==(a=a[i])?void 0:a.mode)||yz.View,c=null!=(s=t[r])?s:r;o.mode===yz.Edit&&l===yz.View?S((0,O.A)({id:c,field:i},o)):o.mode===yz.View&&l===yz.Edit&&T((0,O.A)({id:c,field:i},o))}))}))}),[e,r,S,T])})(e,t),((e,t)=>{const[r,i]=n.useState({}),o=n.useRef(r),a=n.useRef({}),s=n.useRef(null),l=n.useRef(null),{processRowUpdate:c,onProcessRowUpdateError:u,rowModesModel:d,onRowModesModelChange:h}=t,p=e=>function(){t.editMode===gz.Row&&e(...arguments)},f=n.useCallback(((t,r)=>{const n=e.current.getCellParams(t,r);if(!e.current.isCellEditable(n))throw new Error(`MUI: The cell with id=${t} and field=${r} is not editable.`)}),[e]),m=n.useCallback(((t,r)=>{if(e.current.getRowMode(t)!==r)throw new Error(`MUI: The row with id=${t} is not in ${r} mode.`)}),[e]),g=n.useCallback(((t,r)=>{if(!t.isEditable)return;if(e.current.getRowMode(t.id)===vz.Edit)return;const n=e.current.getRowParams(t.id),i=(0,O.A)({},n,{field:t.field,reason:Bj.cellDoubleClick});e.current.publishEvent("rowEditStart",i,r)}),[e]),y=n.useCallback((e=>{l.current=e}),[]),v=n.useCallback(((t,r)=>{t.isEditable&&e.current.getRowMode(t.id)!==vz.View&&(l.current=null,s.current=setTimeout((()=>{var n;if(s.current=null,(null==(n=l.current)?void 0:n.id)!==t.id){if(!e.current.getRow(t.id))return;if(e.current.getRowMode(t.id)===vz.View)return;const n=e.current.getRowParams(t.id),i=(0,O.A)({},n,{field:t.field,reason:Vj.rowFocusOut});e.current.publishEvent("rowEditStop",i,r)}})))}),[e]);n.useEffect((()=>()=>{clearTimeout(s.current)}),[]);const x=n.useCallback(((t,r)=>{if(t.cellMode===vz.Edit){if(229===r.which)return;let n;if("Escape"===r.key)n=Vj.escapeKeyDown;else if("Enter"===r.key)n=Vj.enterKeyDown;else if("Tab"===r.key){const i=_P(e).filter((r=>e.current.getColumn(r).type===Vz||e.current.isCellEditable(e.current.getCellParams(t.id,r))));if(r.shiftKey?t.field===i[0]&&(n=Vj.shiftTabKeyDown):t.field===i[i.length-1]&&(n=Vj.tabKeyDown),r.preventDefault(),!n){const n=i.findIndex((e=>e===t.field)),o=i[r.shiftKey?n-1:n+1];e.current.setCellFocus(t.id,o)}}if(n){const i=(0,O.A)({},e.current.getRowParams(t.id),{reason:n,field:t.field});e.current.publishEvent("rowEditStop",i,r)}}else if(t.isEditable){let n;if(!e.current.unstable_applyPipeProcessors("canStartEditing",!0,{event:r,cellParams:t,editMode:"row"}))return;if(yR(r)||(r.ctrlKey||r.metaKey)&&"v"===r.key?n=Bj.printableKeyDown:"Enter"===r.key?n=Bj.enterKeyDown:"Delete"!==r.key&&"Backspace"!==r.key||(n=Bj.deleteKeyDown),n){const i=e.current.getRowParams(t.id),o=(0,O.A)({},i,{field:t.field,reason:n});e.current.publishEvent("rowEditStart",o,r)}}}),[e]),b=n.useCallback((t=>{const{id:r,field:n,reason:i}=t,o={id:r,fieldToFocus:n};i!==Bj.printableKeyDown&&i!==Bj.deleteKeyDown||(o.deleteValue=!!n),e.current.startRowEditMode(o)}),[e]),_=n.useCallback((t=>{const{id:r,reason:n,field:i}=t;let o;e.current.runPendingEditCellValueMutation(r),n===Vj.enterKeyDown?o="below":n===Vj.tabKeyDown?o="right":n===Vj.shiftTabKeyDown&&(o="left");const a="escapeKeyDown"===n;e.current.stopRowEditMode({id:r,ignoreModifications:a,field:i,cellToFocusAfter:o})}),[e]);tR(e,"cellDoubleClick",p(g)),tR(e,"cellFocusIn",p(y)),tR(e,"cellFocusOut",p(v)),tR(e,"cellKeyDown",p(x)),tR(e,"rowEditStart",p(b)),tR(e,"rowEditStop",p(_)),nR(e,"rowEditStart",t.onRowEditStart),nR(e,"rowEditStop",t.onRowEditStop);const w=n.useCallback((r=>{if(t.editMode===gz.Cell)return vz.View;const n=zj(e.current.state);return n[r]&&Object.keys(n[r]).length>0?vz.Edit:vz.View}),[e,t.editMode]),k=(0,ea.A)((r=>{const n=r!==t.rowModesModel;h&&n&&h(r,{}),t.rowModesModel&&n||(i(r),o.current=r,e.current.publishEvent("rowModesModelChange",r))})),S=n.useCallback(((e,t)=>{const r=(0,O.A)({},o.current);null!==t?r[e]=(0,O.A)({},t):delete r[e],k(r)}),[k]),A=n.useCallback(((t,r)=>{e.current.setState((e=>{const n=(0,O.A)({},e.editRows);return null!==r?n[t]=r:delete n[t],(0,O.A)({},e,{editRows:n})})),e.current.forceUpdate()}),[e]),T=n.useCallback(((t,r,n)=>{e.current.setState((e=>{const i=(0,O.A)({},e.editRows);return null!==n?i[t]=(0,O.A)({},i[t],{[r]:(0,O.A)({},n)}):(delete i[t][r],0===Object.keys(i[t]).length&&delete i[t]),(0,O.A)({},e,{editRows:i})})),e.current.forceUpdate()}),[e]),M=n.useCallback((e=>{const{id:t}=e,r=(0,R.A)(e,Uj);m(t,vz.View),S(t,(0,O.A)({mode:vz.Edit},r))}),[m,S]),C=(0,ea.A)((t=>{const{id:r,fieldToFocus:n,deleteValue:i,initialValue:o}=t,a=gP(e).reduce(((t,a)=>{if(!e.current.getCellParams(r,a).isEditable)return t;let s=e.current.getCellValue(r,a);return n===a&&(i||o)&&(s=i?"":o),t[a]={value:s,error:!1,isProcessingProps:!1},t}),{});A(r,a),n&&e.current.setCellFocus(r,n)})),E=n.useCallback((e=>{const{id:t}=e,r=(0,R.A)(e,Hj);m(t,vz.Edit),S(t,(0,O.A)({mode:vz.View},r))}),[m,S]),I=(0,ea.A)((t=>{const{id:r,ignoreModifications:n,field:i,cellToFocusAfter:o="none"}=t;e.current.runPendingEditCellValueMutation(r);const s=()=>{"none"!==o&&i&&e.current.moveFocusToRelativeCell(r,i,o),A(r,null),S(r,null)};if(n)return void s();const l=zj(e.current.state),d=e.current.getRow(r);if(Object.values(l[r]).some((e=>e.isProcessingProps)))return void(a.current[r].mode=vz.Edit);if(Object.values(l[r]).some((e=>e.error)))return a.current[r].mode=vz.Edit,void S(r,{mode:vz.Edit});const h=e.current.getRowWithUpdatedValuesFromRowEditing(r);if(c){const t=e=>{a.current[r].mode=vz.Edit,S(r,{mode:vz.Edit}),u?u(e):$j()};try{Promise.resolve(c(h,d)).then((t=>{e.current.updateRows([t]),s()})).catch(t)}catch(p){t(p)}}else e.current.updateRows([h]),s()})),P={setRowEditingEditCellValue:n.useCallback((t=>{const{id:r,field:n,value:i,debounceMs:o,unstable_skipValueParser:a}=t;f(r,n);const s=e.current.getColumn(n),l=e.current.getRow(r);let c=i;s.valueParser&&!a&&(c=s.valueParser(i,e.current.getCellParams(r,n)));let u=zj(e.current.state),d=(0,O.A)({},u[r][n],{value:c,changeReason:o?"debouncedSetEditCellValue":"setEditCellValue"});return s.preProcessEditCellProps||T(r,n,d),new Promise((t=>{const i=[];if(s.preProcessEditCellProps){const o=d.value!==u[r][n].value;d=(0,O.A)({},d,{isProcessingProps:!0}),T(r,n,d);const a=u[r],h=(0,R.A)(a,[n].map(Gs)),p=Promise.resolve(s.preProcessEditCellProps({id:r,row:l,props:d,hasChanged:o,otherFieldsProps:h})).then((i=>{e.current.getRowMode(r)!==vz.View?(u=zj(e.current.state),(i=(0,O.A)({},i,{isProcessingProps:!1})).value=s.preProcessEditCellProps?u[r][n].value:c,T(r,n,i)):t(!1)}));i.push(p)}Object.entries(u[r]).forEach((o=>{let[a,s]=o;if(a===n)return;const c=e.current.getColumn(a);if(!c.preProcessEditCellProps)return;s=(0,O.A)({},s,{isProcessingProps:!0}),T(r,a,s),u=zj(e.current.state);const d=u[r],h=(0,R.A)(d,[a].map(Gs)),p=Promise.resolve(c.preProcessEditCellProps({id:r,row:l,props:s,hasChanged:!1,otherFieldsProps:h})).then((n=>{e.current.getRowMode(r)!==vz.View?(n=(0,O.A)({},n,{isProcessingProps:!1}),T(r,a,n)):t(!1)}));i.push(p)})),Promise.all(i).then((()=>{e.current.getRowMode(r)===vz.Edit?(u=zj(e.current.state),t(!u[r][n].error)):t(!1)}))}))}),[e,f,T]),getRowWithUpdatedValuesFromRowEditing:n.useCallback((t=>{const r=zj(e.current.state),n=e.current.getRow(t);if(!r[t])return e.current.getRow(t);let i=(0,O.A)({},n);return Object.entries(r[t]).forEach((t=>{let[r,n]=t;const o=e.current.getColumn(r);o.valueSetter?i=o.valueSetter({value:n.value,row:i}):i[r]=n.value})),i}),[e])};HO(e,{getRowMode:w,startRowEditMode:M,stopRowEditMode:E},"public"),HO(e,P,"private"),n.useEffect((()=>{d&&k(d)}),[d,k]),(0,$o.A)((()=>{const t=zP(e),n=a.current;a.current=UO(r),Object.entries(r).forEach((e=>{let[r,i]=e;var o,a;const s=(null==(o=n[r])?void 0:o.mode)||vz.View,l=null!=(a=t[r])?a:r;i.mode===vz.Edit&&s===vz.View?C((0,O.A)({id:l},i)):i.mode===vz.View&&s===vz.Edit&&I((0,O.A)({id:l},i))}))}),[e,r,C,I])})(e,t);const r=n.useRef({}),{isCellEditable:i}=t,o=n.useCallback((e=>!MD(e.rowNode)&&(!!e.colDef.editable&&(!!e.colDef.renderEditCell&&(!i||i(e))))),[i]);n.useEffect((()=>{const e=r.current;return()=>{Object.entries(e).forEach((t=>{let[r,n]=t;Object.keys(n).forEach((t=>{const[n]=e[r][t];clearTimeout(n),delete e[r][t]}))}))}}),[]);const a=n.useCallback(((e,t)=>{if(r.current[e])if(t){if(r.current[e][t]){const[,n]=r.current[e][t];n()}}else Object.keys(r.current[e]).forEach((t=>{const[,n]=r.current[e][t];n()}))}),[]),s=n.useCallback((n=>{const{id:i,field:o,debounceMs:a}=n;return new Promise((s=>{((e,t,n,i)=>{if(!n)return void i();if(r.current[e]||(r.current[e]={}),r.current[e][t]){const[n]=r.current[e][t];clearTimeout(n)}const o=setTimeout((()=>{i(),delete r.current[e][t]}),n);r.current[e][t]=[o,()=>{const[n]=r.current[e][t];clearTimeout(n),i(),delete r.current[e][t]}]})(i,o,a,(async()=>{const r=t.editMode===gz.Row?e.current.setRowEditingEditCellValue:e.current.setCellEditingEditCellValue;if(e.current.getCellMode(i,o)===yz.Edit){const e=await r(n);s(e)}}))}))}),[e,t.editMode]),l=n.useCallback(((r,n)=>t.editMode===gz.Cell?e.current.getRowWithUpdatedValuesFromCellEditing(r,n):e.current.getRowWithUpdatedValuesFromRowEditing(r)),[e,t.editMode]),c=n.useCallback(((t,r)=>{var n,i;return null!=(n=null==(i=zj(e.current.state)[t])?void 0:i[r])?n:null}),[e]),u={runPendingEditCellValueMutation:a};HO(e,{isCellEditable:o,setEditCellValue:s,getRowWithUpdatedValues:l,unstable_getEditCellMeta:c},"public"),HO(e,u,"private")},Gj=(e,t,r)=>(r.current.caches.rows=SD({rows:t.rows,getRowId:t.getRowId,loading:t.loading,rowCount:t.rowCount}),(0,O.A)({},e,{rows:TD({apiRef:r,rowCountProp:t.rowCount,loadingProp:t.loading,previousTree:null,previousTreeDepths:null})})),Yj=(e,t)=>{const r=hR(e,"useGridRows"),i=xj(e,t),o=n.useRef(Date.now()),a=JR(),s=n.useCallback((t=>{const r=DP(e)[t];if(r)return r;const n=e.current.getRowNode(t);return n&&MD(n)?{[wD]:t}:null}),[e]),l=t.getRowId,c=n.useCallback((e=>wD in e?e[wD]:l?l(e):e.id),[l]),u=n.useMemo((()=>i.rows.reduce(((e,t,r)=>{let{id:n}=t;return e[n]=r,e}),{})),[i.rows]),d=n.useCallback((r=>{let{cache:n,throttle:i}=r;const s=()=>{o.current=Date.now(),e.current.setState((r=>(0,O.A)({},r,{rows:TD({apiRef:e,rowCountProp:t.rowCount,loadingProp:t.loading,previousTree:jP(e),previousTreeDepths:NP(e)})}))),e.current.publishEvent("rowsSet"),e.current.forceUpdate()};if(a.clear(),e.current.caches.rows=n,!i)return void s();const l=t.throttleRowsMs-(Date.now()-o.current);l>0?a.start(l,s):s()}),[t.throttleRowsMs,t.rowCount,t.loading,e,a]),h=n.useCallback((n=>{r.debug(`Updating all rows, new length ${n.length}`);const i=SD({rows:n,getRowId:t.getRowId,loading:t.loading,rowCount:t.rowCount}),o=e.current.caches.rows;i.rowsBeforePartialUpdates=o.rowsBeforePartialUpdates,d({cache:i,throttle:!0})}),[r,t.getRowId,t.loading,t.rowCount,d,e]),p=n.useCallback((r=>{if(t.signature===JO.DataGrid&&r.length>1)throw new Error(["MUI: You can't update several rows at once in `apiRef.current.updateRows` on the DataGrid.","You need to upgrade to DataGridPro or DataGridPremium component to unlock this feature."].join("\n"));const n=[];r.forEach((r=>{const i=kD(r,t.getRowId,"A row was provided without id when calling updateRows():"),o=e.current.getRowNode(i);if("pinnedRow"===(null==o?void 0:o.type)){const t=e.current.caches.pinnedRows,n=t.idLookup[i];n&&(t.idLookup[i]=(0,O.A)({},n,r))}else n.push(r)}));const i=(e=>{let{previousCache:t,getRowId:r,updates:n}=e;var i,o,a;if("full"===t.updates.type)throw new Error("MUI: Unable to prepare a partial update if a full update is not applied yet");const s=new Map;n.forEach((e=>{const t=kD(e,r,"A row was provided without id when calling updateRows():");s.has(t)?s.set(t,(0,O.A)({},s.get(t),e)):s.set(t,e)}));const l={type:"partial",actions:{insert:[...null!=(i=t.updates.actions.insert)?i:[]],modify:[...null!=(o=t.updates.actions.modify)?o:[]],remove:[...null!=(a=t.updates.actions.remove)?a:[]]},idToActionLookup:(0,O.A)({},t.updates.idToActionLookup)},c=(0,O.A)({},t.dataRowIdToModelLookup),u=(0,O.A)({},t.dataRowIdToIdLookup),d={insert:{},modify:{},remove:{}};s.forEach(((e,t)=>{const r=l.idToActionLookup[t];if("delete"===e._action){if("remove"===r||!c[t])return;return null!=r&&(d[r][t]=!0),l.actions.remove.push(t),delete c[t],void delete u[t]}const n=c[t];if(n)return"remove"===r?(d.remove[t]=!0,l.actions.modify.push(t)):null==r&&l.actions.modify.push(t),void(c[t]=(0,O.A)({},n,e));"remove"===r?(d.remove[t]=!0,l.actions.insert.push(t)):null==r&&l.actions.insert.push(t),c[t]=e,u[t]=t}));const h=Object.keys(d);for(let p=0;p0&&(l.actions[e]=l.actions[e].filter((e=>!t[e])))}return{dataRowIdToModelLookup:c,dataRowIdToIdLookup:u,updates:l,rowsBeforePartialUpdates:t.rowsBeforePartialUpdates,loadingPropBeforePartialUpdates:t.loadingPropBeforePartialUpdates,rowCountPropBeforePartialUpdates:t.rowCountPropBeforePartialUpdates}})({updates:n,getRowId:t.getRowId,previousCache:e.current.caches.rows});d({cache:i,throttle:!0})}),[t.signature,t.getRowId,d,e]),f=n.useCallback((()=>{const t=VP(e),r=DP(e);return new Map(t.map((e=>{var t;return[e,null!=(t=r[e])?t:{}]})))}),[e]),m=n.useCallback((()=>OP(e)),[e]),g=n.useCallback((()=>VP(e)),[e]),y=n.useCallback((e=>u[e]),[u]),v=n.useCallback(((t,r)=>{const n=e.current.getRowNode(t);if(!n)throw new Error(`MUI: No row with id #${t} found`);if("group"!==n.type)throw new Error("MUI: Only group nodes can be expanded or collapsed");const i=(0,O.A)({},n,{childrenExpanded:r});e.current.setState((e=>(0,O.A)({},e,{rows:(0,O.A)({},e.rows,{tree:(0,O.A)({},e.rows.tree,{[t]:i})})}))),e.current.forceUpdate(),e.current.publishEvent("rowExpansionChange",i)}),[e]),x=n.useCallback((t=>{var r;return null!=(r=jP(e)[t])?r:null}),[e]),b=n.useCallback((t=>{let{skipAutoGeneratedRows:r=!0,groupId:n,applySorting:i,applyFiltering:o}=t;const a=jP(e);let s;if(i){const t=a[n];if(!t)return[];const i=sO(e);s=[];for(let e=i.findIndex((e=>e===n))+1;et.depth;e+=1){const t=i[e];r&&MD(a[t])||s.push(t)}}else s=CD(a,n,r);if(o){const t=pO(e);s=s.filter((e=>!1!==t[e]))}return s}),[e]),_=n.useCallback(((t,n)=>{const i=e.current.getRowNode(t);if(!i)throw new Error(`MUI: No row with id #${t} found`);if(i.parent!==_D)throw new Error("MUI: The row reordering do not support reordering of grouped rows yet");if("leaf"!==i.type)throw new Error("MUI: The row reordering do not support reordering of footer or grouping rows");e.current.setState((i=>{const o=jP(i,e.current.instanceId)[_D],a=o.children,s=a.findIndex((e=>e===t));if(-1===s||s===n)return i;r.debug(`Moving row ${t} to index ${n}`);const l=[...a];return l.splice(n,0,l.splice(s,1)[0]),(0,O.A)({},i,{rows:(0,O.A)({},i.rows,{tree:(0,O.A)({},i.rows.tree,{[_D]:(0,O.A)({},o,{children:l})})})})})),e.current.publishEvent("rowsSet")}),[e,r]),w={getRow:s,getRowId:c,getRowModels:f,getRowsCount:m,getAllRowIds:g,setRows:h,updateRows:p,getRowNode:x,getRowIndexRelativeToVisibleRows:y,unstable_replaceRows:n.useCallback(((r,n)=>{if(t.signature===JO.DataGrid&&n.length>1)throw new Error(["MUI: You can't replace rows using `apiRef.current.unstable_replaceRows` on the DataGrid.","You need to upgrade to DataGridPro or DataGridPremium component to unlock this feature."].join("\n"));if(0===n.length)return;if(BP(e)>1)throw new Error("`apiRef.current.unstable_replaceRows` is not compatible with tree data and row grouping");const i=(0,O.A)({},jP(e)),o=(0,O.A)({},DP(e)),a=(0,O.A)({},zP(e)),s=i[_D],l=[...s.children],c=new Set;for(let e=0;e"leaf"===i[e].type));e.current.caches.rows.dataRowIdToModelLookup=o,e.current.caches.rows.dataRowIdToIdLookup=a,e.current.setState((e=>(0,O.A)({},e,{rows:(0,O.A)({},e.rows,{dataRowIdToModelLookup:o,dataRowIdToIdLookup:a,dataRowIds:u,tree:i})}))),e.current.publishEvent("rowsSet")}),[e,t.signature,t.getRowId])},k={setRowIndex:_,setRowChildrenExpansion:v,getRowGroupChildren:b},S=n.useCallback((()=>{let n;r.info("Row grouping pre-processing have changed, regenerating the row tree"),n=e.current.caches.rows.rowsBeforePartialUpdates===t.rows?(0,O.A)({},e.current.caches.rows,{updates:{type:"full",rows:VP(e)}}):SD({rows:t.rows,getRowId:t.getRowId,loading:t.loading,rowCount:t.rowCount}),d({cache:n,throttle:!1})}),[r,e,t.rows,t.getRowId,t.loading,t.rowCount,d]),A=n.useCallback((e=>{"rowTreeCreation"===e&&S()}),[S]),T=n.useCallback((()=>{e.current.getActiveStrategy("rowTree")!==FP(e)&&S()}),[e,S]);tR(e,"activeStrategyProcessorChange",A),tR(e,"strategyAvailabilityChange",T);const M=n.useCallback((()=>{e.current.setState((r=>{const n=e.current.unstable_applyPipeProcessors("hydrateRows",{tree:jP(r,e.current.instanceId),treeDepths:NP(r,e.current.instanceId),dataRowIds:VP(r,e.current.instanceId),dataRowIdToModelLookup:DP(r,e.current.instanceId),dataRowIdToIdLookup:zP(r,e.current.instanceId)});return(0,O.A)({},r,{rows:(0,O.A)({},r.rows,n,{totalTopLevelRowCount:AD({tree:n.tree,rowCountProp:t.rowCount})})})})),e.current.publishEvent("rowsSet"),e.current.forceUpdate()}),[e,t.rowCount]);KD(e,"hydrateRows",M),HO(e,w,"public"),HO(e,k,t.signature===JO.DataGrid?"private":"public");const C=n.useRef(!0);n.useEffect((()=>{if(C.current)return void(C.current=!1);const n=e.current.caches.rows.rowsBeforePartialUpdates===t.rows,i=e.current.caches.rows.loadingPropBeforePartialUpdates===t.loading,o=e.current.caches.rows.rowCountPropBeforePartialUpdates===t.rowCount;if(n)return i||(e.current.setState((e=>(0,O.A)({},e,{rows:(0,O.A)({},e.rows,{loading:t.loading})}))),e.current.caches.rows.loadingPropBeforePartialUpdates=t.loading,e.current.forceUpdate()),void(o||(e.current.setState((e=>(0,O.A)({},e,{rows:(0,O.A)({},e.rows,{totalRowCount:Math.max(t.rowCount||0,e.rows.totalRowCount),totalTopLevelRowCount:Math.max(t.rowCount||0,e.rows.totalTopLevelRowCount)})}))),e.current.caches.rows.rowCountPropBeforePartialUpdates=t.rowCount,e.current.forceUpdate()));r.debug(`Updating all rows, new length ${t.rows.length}`),d({cache:SD({rows:t.rows,getRowId:t.getRowId,loading:t.loading,rowCount:t.rowCount}),throttle:!1})}),[t.rows,t.rowCount,t.getRowId,t.loading,r,d,e])},Xj=e=>"full"===e.updates.type?(e=>{const t={[_D]:(0,O.A)({},{type:"group",id:_D,depth:-1,groupingField:null,groupingKey:null,isAutoGenerated:!0,children:[],childrenFromPath:{},childrenExpanded:!0,parent:null},{children:e})};for(let r=0;r{let{previousTree:t,actions:r}=e;const n=(0,O.A)({},t),i={};for(let s=0;s!i[e]))),n[_D]=(0,O.A)({},o,{children:a}),{groupingName:lR,tree:n,treeDepths:{0:a.length},dataRowIds:a}})({previousTree:e.previousTree,actions:e.updates.actions});class Zj extends Error{}function Kj(e,t){const{getRowId:r}=t,i=n.useCallback((t=>({field:t,colDef:e.current.getColumn(t)})),[e]),o=n.useCallback((t=>{const r=e.current.getRow(t);if(!r)throw new Zj(`No row with id #${t} found`);return{id:t,columns:e.current.getAllColumns(),row:r}}),[e]),a=n.useCallback(((t,r)=>{const n=e.current.getRow(t),i=e.current.getRowNode(t);if(!n||!i)throw new Zj(`No row with id #${t} found`);const o=SO(e),a=CO(e);return{id:t,field:r,row:n,rowNode:i,value:n[r],colDef:e.current.getColumn(r),cellMode:e.current.getCellMode(t,r),api:e.current,hasFocus:null!==o&&o.field===r&&o.id===t,tabIndex:a&&a.field===r&&a.id===t?0:-1}}),[e]),s=n.useCallback(((t,r)=>{const n=e.current.getColumn(r),i=e.current.getCellValue(t,r),o=e.current.getRow(t),a=e.current.getRowNode(t);if(!o||!a)throw new Zj(`No row with id #${t} found`);const s=SO(e),l=CO(e),c={id:t,field:r,row:o,rowNode:a,colDef:n,cellMode:e.current.getCellMode(t,r),hasFocus:null!==s&&s.field===r&&s.id===t,tabIndex:l&&l.field===r&&l.id===t?0:-1,value:i,formattedValue:i,isEditable:!1};return n&&n.valueFormatter&&(c.formattedValue=n.valueFormatter({id:t,field:c.field,value:c.value,api:e.current})),c.isEditable=n&&e.current.isCellEditable(c),c}),[e]),l=n.useCallback(((t,r)=>{const n=e.current.getColumn(r);if(!n||!n.valueGetter){const n=e.current.getRow(t);if(!n)throw new Zj(`No row with id #${t} found`);return n[r]}return n.valueGetter(a(t,r))}),[e,a]),c=n.useCallback(((e,t)=>{var n;const i=wD in e?e[wD]:null!=(n=null==r?void 0:r(e))?n:e.id,o=t.field;return t&&t.valueGetter?t.valueGetter(a(i,o)):e[o]}),[a,r]),u=n.useCallback(((t,n)=>{var i;const o=c(t,n);if(!n||!n.valueFormatter)return o;const a=null!=(i=r?r(t):t.id)?i:t[wD],s=n.field;return n.valueFormatter({id:a,field:s,value:o,api:e.current})}),[e,r,c]),d=n.useCallback((t=>e.current.rootElementRef.current?function(e,t){return e.querySelector(`[role="columnheader"][data-field="${Tj(t)}"]`)}(e.current.rootElementRef.current,t):null),[e]),h=n.useCallback((t=>e.current.rootElementRef.current?function(e,t){return e.querySelector(Mj(t))}(e.current.rootElementRef.current,t):null),[e]),p=n.useCallback(((t,r)=>e.current.rootElementRef.current?function(e,t){let{id:r,field:n}=t;const i=`${Mj(r)} .${zI.cell}[data-field="${Tj(n)}"]`;return e.querySelector(i)}(e.current.rootElementRef.current,{id:t,field:r}):null),[e]);HO(e,{getCellValue:l,getCellParams:s,getCellElement:p,getRowValue:c,getRowFormattedValue:u,getRowParams:o,getRowElement:h,getColumnHeaderParams:i,getColumnHeaderElement:d},"public")}const Jj=(e,t)=>null==e||Array.isArray(e)?e:t&&t[0]===e?t:[e],Qj=(e,t)=>{var r;return(0,O.A)({},e,{rowSelection:t.rowSelection&&null!=(r=Jj(t.rowSelectionModel))?r:[]})},eF=(e,t)=>{const r=(e=>{const{classes:t}=e;return n.useMemo((()=>(0,mn.A)({cellCheckbox:["cellCheckbox"],columnHeaderCheckbox:["columnHeaderCheckbox"]},DI,t)),[t])})({classes:t.classes}),i=n.useCallback((n=>{const i=(0,O.A)({},VD,{cellClassName:r.cellCheckbox,headerClassName:r.columnHeaderCheckbox,headerName:e.current.getLocaleText("checkboxSelectionHeaderName")}),o=t.checkboxSelection,a=null!=n.lookup[BD];return o&&!a?(n.lookup[BD]=i,n.orderedFields=[BD,...n.orderedFields]):!o&&a?(delete n.lookup[BD],n.orderedFields=n.orderedFields.filter((e=>e!==BD))):o&&a&&(n.lookup[BD]=(0,O.A)({},i,n.lookup[BD])),n}),[e,r,t.checkboxSelection]);ZD(e,"hydrateColumns",i)},tF=(e,t)=>{var r,n,i;const o=null!=(r=null!=(n=t.sortModel)?n:null==(i=t.initialState)||null==(i=i.sorting)?void 0:i.sortModel)?r:[];return(0,O.A)({},e,{sorting:{sortModel:$R(o,t.disableMultipleColumnsSorting),sortedRows:[]}})};function rF(e){const{clientHeight:t,scrollTop:r,offsetHeight:n,offsetTop:i}=e,o=i+n;return n>t?i:o-t>r?o-t:i1!==e?`${e} active filters`:`${e} active filter`,toolbarQuickFilterPlaceholder:"Search\u2026",toolbarQuickFilterLabel:"Search",toolbarQuickFilterDeleteIconLabel:"Clear",toolbarExport:"Export",toolbarExportLabel:"Export",toolbarExportCSV:"Download as CSV",toolbarExportPrint:"Print",toolbarExportExcel:"Download as Excel",columnsPanelTextFieldLabel:"Find column",columnsPanelTextFieldPlaceholder:"Column title",columnsPanelDragIconLabel:"Reorder column",columnsPanelShowAllButton:"Show all",columnsPanelHideAllButton:"Hide all",filterPanelAddFilter:"Add filter",filterPanelRemoveAll:"Remove all",filterPanelDeleteIconLabel:"Delete",filterPanelLogicOperator:"Logic operator",filterPanelOperator:"Operator",filterPanelOperatorAnd:"And",filterPanelOperatorOr:"Or",filterPanelColumns:"Columns",filterPanelInputLabel:"Value",filterPanelInputPlaceholder:"Filter value",filterOperatorContains:"contains",filterOperatorEquals:"equals",filterOperatorStartsWith:"starts with",filterOperatorEndsWith:"ends with",filterOperatorIs:"is",filterOperatorNot:"is not",filterOperatorAfter:"is after",filterOperatorOnOrAfter:"is on or after",filterOperatorBefore:"is before",filterOperatorOnOrBefore:"is on or before",filterOperatorIsEmpty:"is empty",filterOperatorIsNotEmpty:"is not empty",filterOperatorIsAnyOf:"is any of","filterOperator=":"=","filterOperator!=":"!=","filterOperator>":">","filterOperator>=":">=","filterOperator<":"<","filterOperator<=":"<=",headerFilterOperatorContains:"Contains",headerFilterOperatorEquals:"Equals",headerFilterOperatorStartsWith:"Starts with",headerFilterOperatorEndsWith:"Ends with",headerFilterOperatorIs:"Is",headerFilterOperatorNot:"Is not",headerFilterOperatorAfter:"Is after",headerFilterOperatorOnOrAfter:"Is on or after",headerFilterOperatorBefore:"Is before",headerFilterOperatorOnOrBefore:"Is on or before",headerFilterOperatorIsEmpty:"Is empty",headerFilterOperatorIsNotEmpty:"Is not empty",headerFilterOperatorIsAnyOf:"Is any of","headerFilterOperator=":"Equals","headerFilterOperator!=":"Not equals","headerFilterOperator>":"Greater than","headerFilterOperator>=":"Greater than or equal to","headerFilterOperator<":"Less than","headerFilterOperator<=":"Less than or equal to",filterValueAny:"any",filterValueTrue:"true",filterValueFalse:"false",columnMenuLabel:"Menu",columnMenuShowColumns:"Show columns",columnMenuManageColumns:"Manage columns",columnMenuFilter:"Filter",columnMenuHideColumn:"Hide column",columnMenuUnsort:"Unsort",columnMenuSortAsc:"Sort by ASC",columnMenuSortDesc:"Sort by DESC",columnHeaderFiltersTooltipActive:e=>1!==e?`${e} active filters`:`${e} active filter`,columnHeaderFiltersLabel:"Show filters",columnHeaderSortIconLabel:"Sort",footerRowSelected:e=>1!==e?`${e.toLocaleString()} rows selected`:`${e.toLocaleString()} row selected`,footerTotalRows:"Total Rows:",footerTotalVisibleRows:(e,t)=>`${e.toLocaleString()} of ${t.toLocaleString()}`,checkboxSelectionHeaderName:"Checkbox selection",checkboxSelectionSelectAllRows:"Select all rows",checkboxSelectionUnselectAllRows:"Unselect all rows",checkboxSelectionSelectRow:"Select row",checkboxSelectionUnselectRow:"Unselect row",booleanCellTrueLabel:"yes",booleanCellFalseLabel:"no",actionsCellMore:"more",pinToLeft:"Pin to left",pinToRight:"Pin to right",unpin:"Unpin",treeDataGroupingHeaderName:"Group",treeDataExpand:"see children",treeDataCollapse:"hide children",groupingColumnHeaderName:"Group",groupColumn:e=>`Group by ${e}`,unGroupColumn:e=>`Stop grouping by ${e}`,detailPanelToggle:"Detail panel toggle",expandDetailPanel:"Expand",collapseDetailPanel:"Collapse",MuiTablePagination:{},rowReorderingHeaderName:"Row reordering",aggregationMenuItemHeader:"Aggregation",aggregationFunctionLabelSum:"sum",aggregationFunctionLabelAvg:"avg",aggregationFunctionLabelMin:"min",aggregationFunctionLabelMax:"max",aggregationFunctionLabelSize:"size"};function aF(e){return String(e).match(/[\d.\-+]*\s*(.*)/)[1]||""}function sF(e){return parseFloat(e)}function lF(e){return(0,Yn.Ay)("MuiSkeleton",e)}(0,Ln.A)("MuiSkeleton",["root","text","rectangular","rounded","circular","pulse","wave","withChildren","fitContent","heightAuto"]);const cF=["animation","className","component","height","style","variant","width"];let uF,dF,hF,pF,fF=e=>e;const mF=(0,Pn.i7)(uF||(uF=fF` + 0% { + opacity: 1; + } + + 50% { + opacity: 0.4; + } + + 100% { + opacity: 1; + } +`)),gF=(0,Pn.i7)(dF||(dF=fF` + 0% { + transform: translateX(-100%); + } + + 50% { + /* +0.5s of delay between each loop */ + transform: translateX(100%); + } + + 100% { + transform: translateX(100%); + } +`)),yF=(0,yn.Ay)("span",{name:"MuiSkeleton",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,t[r.variant],!1!==r.animation&&t[r.animation],r.hasChildren&&t.withChildren,r.hasChildren&&!r.width&&t.fitContent,r.hasChildren&&!r.height&&t.heightAuto]}})((e=>{let{theme:t,ownerState:r}=e;const n=aF(t.shape.borderRadius)||"px",i=sF(t.shape.borderRadius);return(0,O.A)({display:"block",backgroundColor:t.vars?t.vars.palette.Skeleton.bg:OI(t.palette.text.primary,"light"===t.palette.mode?.11:.13),height:"1.2em"},"text"===r.variant&&{marginTop:0,marginBottom:0,height:"auto",transformOrigin:"0 55%",transform:"scale(1, 0.60)",borderRadius:`${i}${n}/${Math.round(i/.6*10)/10}${n}`,"&:empty:before":{content:'"\\00a0"'}},"circular"===r.variant&&{borderRadius:"50%"},"rounded"===r.variant&&{borderRadius:(t.vars||t).shape.borderRadius},r.hasChildren&&{"& > *":{visibility:"hidden"}},r.hasChildren&&!r.width&&{maxWidth:"fit-content"},r.hasChildren&&!r.height&&{height:"auto"})}),(e=>{let{ownerState:t}=e;return"pulse"===t.animation&&(0,Pn.AH)(hF||(hF=fF` + animation: ${0} 2s ease-in-out 0.5s infinite; + `),mF)}),(e=>{let{ownerState:t,theme:r}=e;return"wave"===t.animation&&(0,Pn.AH)(pF||(pF=fF` + position: relative; + overflow: hidden; + + /* Fix bug in Safari https://bugs.webkit.org/show_bug.cgi?id=68196 */ + -webkit-mask-image: -webkit-radial-gradient(white, black); + + &::after { + animation: ${0} 2s linear 0.5s infinite; + background: linear-gradient( + 90deg, + transparent, + ${0}, + transparent + ); + content: ''; + position: absolute; + transform: translateX(-100%); /* Avoid flash during server-side hydration */ + bottom: 0; + left: 0; + right: 0; + top: 0; + } + `),gF,(r.vars||r).palette.action.hover)})),vF=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiSkeleton"}),{animation:n="pulse",className:i,component:o="span",height:a,style:s,variant:l="text",width:c}=r,u=(0,R.A)(r,cF),d=(0,O.A)({},r,{animation:n,component:o,variant:l,hasChildren:Boolean(u.children)}),h=(e=>{const{classes:t,variant:r,animation:n,hasChildren:i,width:o,height:a}=e,s={root:["root",r,n,i&&"withChildren",i&&!o&&"fitContent",i&&!a&&"heightAuto"]};return(0,mn.A)(s,lF,t)})(d);return(0,j.jsx)(yF,(0,O.A)({as:o,ref:t,className:(0,fn.A)(h.root,i),ownerState:d},u,{style:(0,O.A)({width:c,height:a},s)}))})),xF=["field","align","width","contentWidth"];const bF=function(e){const{badgeContent:t,invisible:r=!1,max:n=99,showZero:i=!1}=e,o=rL({badgeContent:t,max:n});let a=r;!1!==r||0!==t||i||(a=!0);const{badgeContent:s,max:l=n}=a?o:e;return{badgeContent:s,invisible:a,max:l,displayValue:s&&Number(s)>l?`${l}+`:s}};function _F(e){return(0,Yn.Ay)("MuiBadge",e)}const wF=(0,Ln.A)("MuiBadge",["root","badge","dot","standard","anchorOriginTopRight","anchorOriginBottomRight","anchorOriginTopLeft","anchorOriginBottomLeft","invisible","colorError","colorInfo","colorPrimary","colorSecondary","colorSuccess","colorWarning","overlapRectangular","overlapCircular","anchorOriginTopLeftCircular","anchorOriginTopLeftRectangular","anchorOriginTopRightCircular","anchorOriginTopRightRectangular","anchorOriginBottomLeftCircular","anchorOriginBottomLeftRectangular","anchorOriginBottomRightCircular","anchorOriginBottomRightRectangular"]),kF=["anchorOrigin","className","classes","component","components","componentsProps","children","overlap","color","invisible","max","badgeContent","slots","slotProps","showZero","variant"],SF=(0,yn.Ay)("span",{name:"MuiBadge",slot:"Root",overridesResolver:(e,t)=>t.root})({position:"relative",display:"inline-flex",verticalAlign:"middle",flexShrink:0}),AF=(0,yn.Ay)("span",{name:"MuiBadge",slot:"Badge",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.badge,t[r.variant],t[`anchorOrigin${(0,ei.A)(r.anchorOrigin.vertical)}${(0,ei.A)(r.anchorOrigin.horizontal)}${(0,ei.A)(r.overlap)}`],"default"!==r.color&&t[`color${(0,ei.A)(r.color)}`],r.invisible&&t.invisible]}})((e=>{let{theme:t}=e;var r;return{display:"flex",flexDirection:"row",flexWrap:"wrap",justifyContent:"center",alignContent:"center",alignItems:"center",position:"absolute",boxSizing:"border-box",fontFamily:t.typography.fontFamily,fontWeight:t.typography.fontWeightMedium,fontSize:t.typography.pxToRem(12),minWidth:20,lineHeight:1,padding:"0 6px",height:20,borderRadius:10,zIndex:1,transition:t.transitions.create("transform",{easing:t.transitions.easing.easeInOut,duration:t.transitions.duration.enteringScreen}),variants:[...Object.keys((null!=(r=t.vars)?r:t).palette).filter((e=>{var r,n;return(null!=(r=t.vars)?r:t).palette[e].main&&(null!=(n=t.vars)?n:t).palette[e].contrastText})).map((e=>({props:{color:e},style:{backgroundColor:(t.vars||t).palette[e].main,color:(t.vars||t).palette[e].contrastText}}))),{props:{variant:"dot"},style:{borderRadius:4,height:8,minWidth:8,padding:0}},{props:e=>{let{ownerState:t}=e;return"top"===t.anchorOrigin.vertical&&"right"===t.anchorOrigin.horizontal&&"rectangular"===t.overlap},style:{top:0,right:0,transform:"scale(1) translate(50%, -50%)",transformOrigin:"100% 0%",[`&.${wF.invisible}`]:{transform:"scale(0) translate(50%, -50%)"}}},{props:e=>{let{ownerState:t}=e;return"bottom"===t.anchorOrigin.vertical&&"right"===t.anchorOrigin.horizontal&&"rectangular"===t.overlap},style:{bottom:0,right:0,transform:"scale(1) translate(50%, 50%)",transformOrigin:"100% 100%",[`&.${wF.invisible}`]:{transform:"scale(0) translate(50%, 50%)"}}},{props:e=>{let{ownerState:t}=e;return"top"===t.anchorOrigin.vertical&&"left"===t.anchorOrigin.horizontal&&"rectangular"===t.overlap},style:{top:0,left:0,transform:"scale(1) translate(-50%, -50%)",transformOrigin:"0% 0%",[`&.${wF.invisible}`]:{transform:"scale(0) translate(-50%, -50%)"}}},{props:e=>{let{ownerState:t}=e;return"bottom"===t.anchorOrigin.vertical&&"left"===t.anchorOrigin.horizontal&&"rectangular"===t.overlap},style:{bottom:0,left:0,transform:"scale(1) translate(-50%, 50%)",transformOrigin:"0% 100%",[`&.${wF.invisible}`]:{transform:"scale(0) translate(-50%, 50%)"}}},{props:e=>{let{ownerState:t}=e;return"top"===t.anchorOrigin.vertical&&"right"===t.anchorOrigin.horizontal&&"circular"===t.overlap},style:{top:"14%",right:"14%",transform:"scale(1) translate(50%, -50%)",transformOrigin:"100% 0%",[`&.${wF.invisible}`]:{transform:"scale(0) translate(50%, -50%)"}}},{props:e=>{let{ownerState:t}=e;return"bottom"===t.anchorOrigin.vertical&&"right"===t.anchorOrigin.horizontal&&"circular"===t.overlap},style:{bottom:"14%",right:"14%",transform:"scale(1) translate(50%, 50%)",transformOrigin:"100% 100%",[`&.${wF.invisible}`]:{transform:"scale(0) translate(50%, 50%)"}}},{props:e=>{let{ownerState:t}=e;return"top"===t.anchorOrigin.vertical&&"left"===t.anchorOrigin.horizontal&&"circular"===t.overlap},style:{top:"14%",left:"14%",transform:"scale(1) translate(-50%, -50%)",transformOrigin:"0% 0%",[`&.${wF.invisible}`]:{transform:"scale(0) translate(-50%, -50%)"}}},{props:e=>{let{ownerState:t}=e;return"bottom"===t.anchorOrigin.vertical&&"left"===t.anchorOrigin.horizontal&&"circular"===t.overlap},style:{bottom:"14%",left:"14%",transform:"scale(1) translate(-50%, 50%)",transformOrigin:"0% 100%",[`&.${wF.invisible}`]:{transform:"scale(0) translate(-50%, 50%)"}}},{props:{invisible:!0},style:{transition:t.transitions.create("transform",{easing:t.transitions.easing.easeInOut,duration:t.transitions.duration.leavingScreen})}}]}})),TF=n.forwardRef((function(e,t){var r,n,i,o,a,s;const l=(0,vn.b)({props:e,name:"MuiBadge"}),{anchorOrigin:c={vertical:"top",horizontal:"right"},className:u,component:d,components:h={},componentsProps:p={},children:f,overlap:m="rectangular",color:g="default",invisible:y=!1,max:v=99,badgeContent:x,slots:b,slotProps:_,showZero:w=!1,variant:k="standard"}=l,S=(0,R.A)(l,kF),{badgeContent:A,invisible:T,max:M,displayValue:C}=bF({max:v,invisible:y,badgeContent:x,showZero:w}),E=rL({anchorOrigin:c,color:g,overlap:m,variant:k,badgeContent:x}),I=T||null==A&&"dot"!==k,{color:P=g,overlap:L=m,anchorOrigin:D=c,variant:z=k}=I?E:l,F="dot"!==z?C:void 0,N=(0,O.A)({},l,{badgeContent:A,invisible:I,max:M,displayValue:F,showZero:w,anchorOrigin:D,color:P,overlap:L,variant:z}),B=(e=>{const{color:t,anchorOrigin:r,invisible:n,overlap:i,variant:o,classes:a={}}=e,s={root:["root"],badge:["badge",o,n&&"invisible",`anchorOrigin${(0,ei.A)(r.vertical)}${(0,ei.A)(r.horizontal)}`,`anchorOrigin${(0,ei.A)(r.vertical)}${(0,ei.A)(r.horizontal)}${(0,ei.A)(i)}`,`overlap${(0,ei.A)(i)}`,"default"!==t&&`color${(0,ei.A)(t)}`]};return(0,mn.A)(s,_F,a)})(N),V=null!=(r=null!=(n=null==b?void 0:b.root)?n:h.Root)?r:SF,U=null!=(i=null!=(o=null==b?void 0:b.badge)?o:h.Badge)?i:AF,H=null!=(a=null==_?void 0:_.root)?a:p.root,$=null!=(s=null==_?void 0:_.badge)?s:p.badge,W=to({elementType:V,externalSlotProps:H,externalForwardedProps:S,additionalProps:{ref:t,as:d},ownerState:N,className:(0,fn.A)(null==H?void 0:H.className,B.root,u)}),q=to({elementType:U,externalSlotProps:$,ownerState:N,className:(0,fn.A)(B.badge,null==$?void 0:$.className)});return(0,j.jsxs)(V,(0,O.A)({},W,{children:[f,(0,j.jsx)(U,(0,O.A)({},q,{children:F}))]}))})),MF=["className"],CF=nO("div",{name:"MuiDataGrid",slot:"IconButtonContainer",overridesResolver:(e,t)=>t.iconButtonContainer})((()=>({display:"flex",visibility:"hidden",width:0}))),EF=n.forwardRef((function(e,t){const{className:r}=e,n=(0,R.A)(e,MF),i=tP(),o=(e=>{const{classes:t}=e;return(0,mn.A)({root:["iconButtonContainer"]},DI,t)})(i);return(0,j.jsx)(CF,(0,O.A)({ref:t,className:(0,fn.A)(o.root,r),ownerState:i},n))}));const IF=["className","selectedRowCount"],PF=nO("div",{name:"MuiDataGrid",slot:"SelectedRowCount",overridesResolver:(e,t)=>t.selectedRowCount})((e=>{let{theme:t}=e;return{alignItems:"center",display:"flex",margin:t.spacing(0,2),visibility:"hidden",width:0,height:0,[t.breakpoints.up("sm")]:{visibility:"visible",width:"auto",height:"auto"}}})),OF=n.forwardRef((function(e,t){const{className:r,selectedRowCount:n}=e,i=(0,R.A)(e,IF),o=xR(),a=tP(),s=(e=>{const{classes:t}=e;return(0,mn.A)({root:["selectedRowCount"]},DI,t)})(a),l=o.current.getLocaleText("footerRowSelected")(n);return(0,j.jsx)(PF,(0,O.A)({ref:t,className:(0,fn.A)(s.root,r),ownerState:a},i,{children:l}))})),RF=["className"],LF=nO("div",{name:"MuiDataGrid",slot:"FooterContainer",overridesResolver:(e,t)=>t.footerContainer})({display:"flex",justifyContent:"space-between",alignItems:"center",minHeight:52,borderTop:"1px solid"}),DF=n.forwardRef((function(e,t){const{className:r}=e,n=(0,R.A)(e,RF),i=tP(),o=(e=>{const{classes:t}=e;return(0,mn.A)({root:["footerContainer","withBorderColor"]},DI,t)})(i);return(0,j.jsx)(LF,(0,O.A)({ref:t,className:(0,fn.A)(o.root,r),ownerState:i},n))})),zF=n.forwardRef((function(e,t){var r,n;const i=xR(),o=tP(),a=KI(i,LP),s=KI(i,kR),l=KI(i,bO),c=!o.hideFooterSelectedRowCount&&s>0?(0,j.jsx)(OF,{selectedRowCount:s}):(0,j.jsx)("div",{}),u=o.hideFooterRowCount||o.pagination?null:(0,j.jsx)(o.slots.footerRowCount,(0,O.A)({},null==(r=o.slotProps)?void 0:r.footerRowCount,{rowCount:a,visibleRowCount:l})),d=o.pagination&&!o.hideFooterPagination&&o.slots.pagination&&(0,j.jsx)(o.slots.pagination,(0,O.A)({},null==(n=o.slotProps)?void 0:n.pagination));return(0,j.jsxs)(DF,(0,O.A)({ref:t},e,{children:[c,u,d]}))})),jF=["className","rowCount","visibleRowCount"],FF=nO("div",{name:"MuiDataGrid",slot:"RowCount",overridesResolver:(e,t)=>t.rowCount})((e=>{let{theme:t}=e;return{alignItems:"center",display:"flex",margin:t.spacing(0,2)}})),NF=n.forwardRef((function(e,t){const{className:r,rowCount:n,visibleRowCount:i}=e,o=(0,R.A)(e,jF),a=xR(),s=tP(),l=(e=>{const{classes:t}=e;return(0,mn.A)({root:["rowCount"]},DI,t)})(s);if(0===n)return null;const c=i0&&l.open,id:l.panelId,"aria-labelledby":l.labelId},null==(n=s.slotProps)?void 0:n.panel,e,null==(i=s.slotProps)?void 0:i.basePopper,{children:c}))}));function VF(e){return(0,Yn.Ay)("MuiCircularProgress",e)}(0,Ln.A)("MuiCircularProgress",["root","determinate","indeterminate","colorPrimary","colorSecondary","svg","circle","circleDeterminate","circleIndeterminate","circleDisableShrink"]);const UF=["className","color","disableShrink","size","style","thickness","value","variant"];let HF,$F,WF,qF,GF=e=>e;const YF=44,XF=(0,Pn.i7)(HF||(HF=GF` + 0% { + transform: rotate(0deg); + } + + 100% { + transform: rotate(360deg); + } +`)),ZF=(0,Pn.i7)($F||($F=GF` + 0% { + stroke-dasharray: 1px, 200px; + stroke-dashoffset: 0; + } + + 50% { + stroke-dasharray: 100px, 200px; + stroke-dashoffset: -15px; + } + + 100% { + stroke-dasharray: 100px, 200px; + stroke-dashoffset: -125px; + } +`)),KF=(0,yn.Ay)("span",{name:"MuiCircularProgress",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,t[r.variant],t[`color${(0,ei.A)(r.color)}`]]}})((e=>{let{ownerState:t,theme:r}=e;return(0,O.A)({display:"inline-block"},"determinate"===t.variant&&{transition:r.transitions.create("transform")},"inherit"!==t.color&&{color:(r.vars||r).palette[t.color].main})}),(e=>{let{ownerState:t}=e;return"indeterminate"===t.variant&&(0,Pn.AH)(WF||(WF=GF` + animation: ${0} 1.4s linear infinite; + `),XF)})),JF=(0,yn.Ay)("svg",{name:"MuiCircularProgress",slot:"Svg",overridesResolver:(e,t)=>t.svg})({display:"block"}),QF=(0,yn.Ay)("circle",{name:"MuiCircularProgress",slot:"Circle",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.circle,t[`circle${(0,ei.A)(r.variant)}`],r.disableShrink&&t.circleDisableShrink]}})((e=>{let{ownerState:t,theme:r}=e;return(0,O.A)({stroke:"currentColor"},"determinate"===t.variant&&{transition:r.transitions.create("stroke-dashoffset")},"indeterminate"===t.variant&&{strokeDasharray:"80px, 200px",strokeDashoffset:0})}),(e=>{let{ownerState:t}=e;return"indeterminate"===t.variant&&!t.disableShrink&&(0,Pn.AH)(qF||(qF=GF` + animation: ${0} 1.4s ease-in-out infinite; + `),ZF)})),eN=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiCircularProgress"}),{className:n,color:i="primary",disableShrink:o=!1,size:a=40,style:s,thickness:l=3.6,value:c=0,variant:u="indeterminate"}=r,d=(0,R.A)(r,UF),h=(0,O.A)({},r,{color:i,disableShrink:o,size:a,thickness:l,value:c,variant:u}),p=(e=>{const{classes:t,variant:r,color:n,disableShrink:i}=e,o={root:["root",r,`color${(0,ei.A)(n)}`],svg:["svg"],circle:["circle",`circle${(0,ei.A)(r)}`,i&&"circleDisableShrink"]};return(0,mn.A)(o,VF,t)})(h),f={},m={},g={};if("determinate"===u){const e=2*Math.PI*((YF-l)/2);f.strokeDasharray=e.toFixed(3),g["aria-valuenow"]=Math.round(c),f.strokeDashoffset=`${((100-c)/100*e).toFixed(3)}px`,m.transform="rotate(-90deg)"}return(0,j.jsx)(KF,(0,O.A)({className:(0,fn.A)(p.root,n),style:(0,O.A)({width:a,height:a},m,s),ownerState:h,ref:t,role:"progressbar"},g,d,{children:(0,j.jsx)(JF,{className:p.svg,ownerState:h,viewBox:"22 22 44 44",children:(0,j.jsx)(QF,{className:p.circle,style:f,ownerState:h,cx:YF,cy:YF,r:(YF-l)/2,fill:"none",strokeWidth:l})})}))})),tN=["className"],rN=nO("div",{name:"MuiDataGrid",slot:"Overlay",overridesResolver:(e,t)=>t.overlay})({width:"100%",height:"100%",display:"flex",alignSelf:"center",alignItems:"center",justifyContent:"center",backgroundColor:"var(--unstable_DataGrid-overlayBackground)"}),nN=n.forwardRef((function(e,t){const{className:r}=e,n=(0,R.A)(e,tN),i=tP(),o=(e=>{const{classes:t}=e;return(0,mn.A)({root:["overlay"]},DI,t)})(i);return(0,j.jsx)(rN,(0,O.A)({ref:t,className:(0,fn.A)(o.root,r),ownerState:i},n))})),iN=n.forwardRef((function(e,t){return(0,j.jsx)(nN,(0,O.A)({ref:t},e,{children:(0,j.jsx)(eN,{})}))})),oN=n.forwardRef((function(e,t){const r=xR().current.getLocaleText("noRowsLabel");return(0,j.jsx)(nN,(0,O.A)({ref:t},e,{children:r}))}));function aN(e){return(0,Yn.Ay)("MuiNativeSelect",e)}const sN=(0,Ln.A)("MuiNativeSelect",["root","select","multiple","filled","outlined","standard","disabled","icon","iconOpen","iconFilled","iconOutlined","iconStandard","nativeInput","error"]),lN=["className","disabled","error","IconComponent","inputRef","variant"],cN=e=>{let{ownerState:t,theme:r}=e;return(0,O.A)({MozAppearance:"none",WebkitAppearance:"none",userSelect:"none",borderRadius:0,cursor:"pointer","&:focus":(0,O.A)({},r.vars?{backgroundColor:`rgba(${r.vars.palette.common.onBackgroundChannel} / 0.05)`}:{backgroundColor:"light"===r.palette.mode?"rgba(0, 0, 0, 0.05)":"rgba(255, 255, 255, 0.05)"},{borderRadius:0}),"&::-ms-expand":{display:"none"},[`&.${sN.disabled}`]:{cursor:"default"},"&[multiple]":{height:"auto"},"&:not([multiple]) option, &:not([multiple]) optgroup":{backgroundColor:(r.vars||r).palette.background.paper},"&&&":{paddingRight:24,minWidth:16}},"filled"===t.variant&&{"&&&":{paddingRight:32}},"outlined"===t.variant&&{borderRadius:(r.vars||r).shape.borderRadius,"&:focus":{borderRadius:(r.vars||r).shape.borderRadius},"&&&":{paddingRight:32}})},uN=(0,yn.Ay)("select",{name:"MuiNativeSelect",slot:"Select",shouldForwardProp:Ta.A,overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.select,t[r.variant],r.error&&t.error,{[`&.${sN.multiple}`]:t.multiple}]}})(cN),dN=e=>{let{ownerState:t,theme:r}=e;return(0,O.A)({position:"absolute",right:0,top:"calc(50% - .5em)",pointerEvents:"none",color:(r.vars||r).palette.action.active,[`&.${sN.disabled}`]:{color:(r.vars||r).palette.action.disabled}},t.open&&{transform:"rotate(180deg)"},"filled"===t.variant&&{right:7},"outlined"===t.variant&&{right:7})},hN=(0,yn.Ay)("svg",{name:"MuiNativeSelect",slot:"Icon",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.icon,r.variant&&t[`icon${(0,ei.A)(r.variant)}`],r.open&&t.iconOpen]}})(dN),pN=n.forwardRef((function(e,t){const{className:r,disabled:i,error:o,IconComponent:a,inputRef:s,variant:l="standard"}=e,c=(0,R.A)(e,lN),u=(0,O.A)({},e,{disabled:i,variant:l,error:o}),d=(e=>{const{classes:t,variant:r,disabled:n,multiple:i,open:o,error:a}=e,s={select:["select",r,n&&"disabled",i&&"multiple",a&&"error"],icon:["icon",`icon${(0,ei.A)(r)}`,o&&"iconOpen",n&&"disabled"]};return(0,mn.A)(s,aN,t)})(u);return(0,j.jsxs)(n.Fragment,{children:[(0,j.jsx)(uN,(0,O.A)({ownerState:u,className:(0,fn.A)(d.select,r),disabled:i,ref:s||t},c)),e.multiple?null:(0,j.jsx)(hN,{as:a,ownerState:u,className:d.icon})]})}));var fN=r(47123);function mN(e){return(0,Yn.Ay)("MuiSelect",e)}const gN=(0,Ln.A)("MuiSelect",["root","select","multiple","filled","outlined","standard","disabled","focused","icon","iconOpen","iconFilled","iconOutlined","iconStandard","nativeInput","error"]);var yN;const vN=["aria-describedby","aria-label","autoFocus","autoWidth","children","className","defaultOpen","defaultValue","disabled","displayEmpty","error","IconComponent","inputRef","labelId","MenuProps","multiple","name","onBlur","onChange","onClose","onFocus","onOpen","open","readOnly","renderValue","SelectDisplayProps","tabIndex","type","value","variant"],xN=(0,yn.Ay)("div",{name:"MuiSelect",slot:"Select",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[{[`&.${gN.select}`]:t.select},{[`&.${gN.select}`]:t[r.variant]},{[`&.${gN.error}`]:t.error},{[`&.${gN.multiple}`]:t.multiple}]}})(cN,{[`&.${gN.select}`]:{height:"auto",minHeight:"1.4375em",textOverflow:"ellipsis",whiteSpace:"nowrap",overflow:"hidden"}}),bN=(0,yn.Ay)("svg",{name:"MuiSelect",slot:"Icon",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.icon,r.variant&&t[`icon${(0,ei.A)(r.variant)}`],r.open&&t.iconOpen]}})(dN),_N=(0,yn.Ay)("input",{shouldForwardProp:e=>(0,fN.A)(e)&&"classes"!==e,name:"MuiSelect",slot:"NativeInput",overridesResolver:(e,t)=>t.nativeInput})({bottom:0,left:0,position:"absolute",opacity:0,pointerEvents:"none",width:"100%",boxSizing:"border-box"});function wN(e,t){return"object"===typeof t&&null!==t?e===t:String(e)===String(t)}function kN(e){return null==e||"string"===typeof e&&!e.trim()}const SN=n.forwardRef((function(e,t){var r;const{"aria-describedby":i,"aria-label":o,autoFocus:a,autoWidth:s,children:l,className:c,defaultOpen:u,defaultValue:d,disabled:h,displayEmpty:p,error:f=!1,IconComponent:m,inputRef:g,labelId:y,MenuProps:v={},multiple:x,name:b,onBlur:_,onChange:w,onClose:k,onFocus:S,onOpen:A,open:T,readOnly:M,renderValue:C,SelectDisplayProps:E={},tabIndex:I,value:P,variant:L="standard"}=e,D=(0,R.A)(e,vN),[z,F]=(0,gp.A)({controlled:P,default:d,name:"Select"}),[N,B]=(0,gp.A)({controlled:T,default:u,name:"Select"}),V=n.useRef(null),U=n.useRef(null),[H,$]=n.useState(null),{current:W}=n.useRef(null!=T),[q,G]=n.useState(),Y=(0,xn.A)(t,g),X=n.useCallback((e=>{U.current=e,e&&$(e)}),[]),Z=null==H?void 0:H.parentNode;n.useImperativeHandle(Y,(()=>({focus:()=>{U.current.focus()},node:V.current,value:z})),[z]),n.useEffect((()=>{u&&N&&H&&!W&&(G(s?null:Z.clientWidth),U.current.focus())}),[H,s]),n.useEffect((()=>{a&&U.current.focus()}),[a]),n.useEffect((()=>{if(!y)return;const e=(0,ro.A)(U.current).getElementById(y);if(e){const t=()=>{getSelection().isCollapsed&&U.current.focus()};return e.addEventListener("click",t),()=>{e.removeEventListener("click",t)}}}),[y]);const K=(e,t)=>{e?A&&A(t):k&&k(t),W||(G(s?null:Z.clientWidth),B(e))},J=n.Children.toArray(l),Q=e=>t=>{let r;if(t.currentTarget.hasAttribute("tabindex")){if(x){r=Array.isArray(z)?z.slice():[];const t=z.indexOf(e.props.value);-1===t?r.push(e.props.value):r.splice(t,1)}else r=e.props.value;if(e.props.onClick&&e.props.onClick(t),z!==r&&(F(r),w)){const n=t.nativeEvent||t,i=new n.constructor(n.type,n);Object.defineProperty(i,"target",{writable:!0,value:{value:r,name:b}}),w(i,e)}x||K(!1,t)}},ee=null!==H&&N;let te,re;delete D["aria-invalid"];const ne=[];let ie=!1,oe=!1;(FE({value:z})||p)&&(C?te=C(z):ie=!0);const ae=J.map((e=>{if(!n.isValidElement(e))return null;let t;if(x){if(!Array.isArray(z))throw new Error((0,AE.A)(2));t=z.some((t=>wN(t,e.props.value))),t&&ie&&ne.push(e.props.children)}else t=wN(z,e.props.value),t&&ie&&(re=e.props.children);return t&&(oe=!0),n.cloneElement(e,{"aria-selected":t?"true":"false",onClick:Q(e),onKeyUp:t=>{" "===t.key&&t.preventDefault(),e.props.onKeyUp&&e.props.onKeyUp(t)},role:"option",selected:t,value:void 0,"data-value":e.props.value})}));ie&&(te=x?0===ne.length?null:ne.reduce(((e,t,r)=>(e.push(t),r{const{classes:t,variant:r,disabled:n,multiple:i,open:o,error:a}=e,s={select:["select",r,n&&"disabled",i&&"multiple",a&&"error"],icon:["icon",`icon${(0,ei.A)(r)}`,o&&"iconOpen",n&&"disabled"],nativeInput:["nativeInput"]};return(0,mn.A)(s,mN,t)})(ue),he=(0,O.A)({},v.PaperProps,null==(r=v.slotProps)?void 0:r.paper),pe=(0,zp.A)();return(0,j.jsxs)(n.Fragment,{children:[(0,j.jsx)(xN,(0,O.A)({ref:X,tabIndex:se,role:"combobox","aria-controls":pe,"aria-disabled":h?"true":void 0,"aria-expanded":ee?"true":"false","aria-haspopup":"listbox","aria-label":o,"aria-labelledby":[y,ce].filter(Boolean).join(" ")||void 0,"aria-describedby":i,onKeyDown:e=>{if(!M){-1!==[" ","ArrowUp","ArrowDown","Enter"].indexOf(e.key)&&(e.preventDefault(),K(!0,e))}},onMouseDown:h||M?null:e=>{0===e.button&&(e.preventDefault(),U.current.focus(),K(!0,e))},onBlur:e=>{!ee&&_&&(Object.defineProperty(e,"target",{writable:!0,value:{value:z,name:b}}),_(e))},onFocus:S},E,{ownerState:ue,className:(0,fn.A)(E.className,de.select,c),id:ce,children:kN(te)?yN||(yN=(0,j.jsx)("span",{className:"notranslate",children:"\u200b"})):te})),(0,j.jsx)(_N,(0,O.A)({"aria-invalid":f,value:Array.isArray(z)?z.join(","):z,name:b,ref:V,"aria-hidden":!0,onChange:e=>{const t=J.find((t=>t.props.value===e.target.value));void 0!==t&&(F(t.props.value),w&&w(e,t))},tabIndex:-1,disabled:h,className:de.nativeInput,autoFocus:a,ownerState:ue},D)),(0,j.jsx)(bN,{as:m,className:de.icon,ownerState:ue}),(0,j.jsx)(Da,(0,O.A)({id:`menu-${b||""}`,anchorEl:Z,open:ee,onClose:e=>{K(!1,e)},anchorOrigin:{vertical:"bottom",horizontal:"center"},transformOrigin:{vertical:"top",horizontal:"center"}},v,{MenuListProps:(0,O.A)({"aria-labelledby":y,role:"listbox","aria-multiselectable":x?"true":void 0,disableListWrap:!0,id:pe},v.MenuListProps),slotProps:(0,O.A)({},v.slotProps,{paper:(0,O.A)({},he,{style:(0,O.A)({minWidth:le},null!=he?he.style:null)})}),children:ae}))]})})),AN=["disableUnderline","components","componentsProps","fullWidth","hiddenLabel","inputComponent","multiline","slotProps","slots","type"],TN=(0,yn.Ay)($E,{shouldForwardProp:e=>(0,Ta.A)(e)||"classes"===e,name:"MuiFilledInput",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[...UE(e,t),!r.disableUnderline&&t.underline]}})((e=>{let{theme:t,ownerState:r}=e;var n;const i="light"===t.palette.mode,o=i?"rgba(0, 0, 0, 0.42)":"rgba(255, 255, 255, 0.7)",a=i?"rgba(0, 0, 0, 0.06)":"rgba(255, 255, 255, 0.09)",s=i?"rgba(0, 0, 0, 0.09)":"rgba(255, 255, 255, 0.13)",l=i?"rgba(0, 0, 0, 0.12)":"rgba(255, 255, 255, 0.12)";return(0,O.A)({position:"relative",backgroundColor:t.vars?t.vars.palette.FilledInput.bg:a,borderTopLeftRadius:(t.vars||t).shape.borderRadius,borderTopRightRadius:(t.vars||t).shape.borderRadius,transition:t.transitions.create("background-color",{duration:t.transitions.duration.shorter,easing:t.transitions.easing.easeOut}),"&:hover":{backgroundColor:t.vars?t.vars.palette.FilledInput.hoverBg:s,"@media (hover: none)":{backgroundColor:t.vars?t.vars.palette.FilledInput.bg:a}},[`&.${AL.focused}`]:{backgroundColor:t.vars?t.vars.palette.FilledInput.bg:a},[`&.${AL.disabled}`]:{backgroundColor:t.vars?t.vars.palette.FilledInput.disabledBg:l}},!r.disableUnderline&&{"&::after":{borderBottom:`2px solid ${null==(n=(t.vars||t).palette[r.color||"primary"])?void 0:n.main}`,left:0,bottom:0,content:'""',position:"absolute",right:0,transform:"scaleX(0)",transition:t.transitions.create("transform",{duration:t.transitions.duration.shorter,easing:t.transitions.easing.easeOut}),pointerEvents:"none"},[`&.${AL.focused}:after`]:{transform:"scaleX(1) translateX(0)"},[`&.${AL.error}`]:{"&::before, &::after":{borderBottomColor:(t.vars||t).palette.error.main}},"&::before":{borderBottom:`1px solid ${t.vars?`rgba(${t.vars.palette.common.onBackgroundChannel} / ${t.vars.opacity.inputUnderline})`:o}`,left:0,bottom:0,content:'"\\00a0"',position:"absolute",right:0,transition:t.transitions.create("border-bottom-color",{duration:t.transitions.duration.shorter}),pointerEvents:"none"},[`&:hover:not(.${AL.disabled}, .${AL.error}):before`]:{borderBottom:`1px solid ${(t.vars||t).palette.text.primary}`},[`&.${AL.disabled}:before`]:{borderBottomStyle:"dotted"}},r.startAdornment&&{paddingLeft:12},r.endAdornment&&{paddingRight:12},r.multiline&&(0,O.A)({padding:"25px 12px 8px"},"small"===r.size&&{paddingTop:21,paddingBottom:4},r.hiddenLabel&&{paddingTop:16,paddingBottom:17},r.hiddenLabel&&"small"===r.size&&{paddingTop:8,paddingBottom:9}))})),MN=(0,yn.Ay)(WE,{name:"MuiFilledInput",slot:"Input",overridesResolver:HE})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({paddingTop:25,paddingRight:12,paddingBottom:8,paddingLeft:12},!t.vars&&{"&:-webkit-autofill":{WebkitBoxShadow:"light"===t.palette.mode?null:"0 0 0 100px #266798 inset",WebkitTextFillColor:"light"===t.palette.mode?null:"#fff",caretColor:"light"===t.palette.mode?null:"#fff",borderTopLeftRadius:"inherit",borderTopRightRadius:"inherit"}},t.vars&&{"&:-webkit-autofill":{borderTopLeftRadius:"inherit",borderTopRightRadius:"inherit"},[t.getColorSchemeSelector("dark")]:{"&:-webkit-autofill":{WebkitBoxShadow:"0 0 0 100px #266798 inset",WebkitTextFillColor:"#fff",caretColor:"#fff"}}},"small"===r.size&&{paddingTop:21,paddingBottom:4},r.hiddenLabel&&{paddingTop:16,paddingBottom:17},r.startAdornment&&{paddingLeft:0},r.endAdornment&&{paddingRight:0},r.hiddenLabel&&"small"===r.size&&{paddingTop:8,paddingBottom:9},r.multiline&&{paddingTop:0,paddingBottom:0,paddingLeft:0,paddingRight:0})})),CN=n.forwardRef((function(e,t){var r,n,i,o;const a=(0,vn.b)({props:e,name:"MuiFilledInput"}),{components:s={},componentsProps:l,fullWidth:c=!1,inputComponent:u="input",multiline:d=!1,slotProps:h,slots:p={},type:f="text"}=a,m=(0,R.A)(a,AN),g=(0,O.A)({},a,{fullWidth:c,inputComponent:u,multiline:d,type:f}),y=(e=>{const{classes:t,disableUnderline:r}=e,n={root:["root",!r&&"underline"],input:["input"]},i=(0,mn.A)(n,SL,t);return(0,O.A)({},t,i)})(a),v={root:{ownerState:g},input:{ownerState:g}},x=(null!=h?h:l)?(0,SE.A)(v,null!=h?h:l):v,b=null!=(r=null!=(n=p.root)?n:s.Root)?r:TN,_=null!=(i=null!=(o=p.input)?o:s.Input)?i:MN;return(0,j.jsx)(GE,(0,O.A)({slots:{root:b,input:_},componentsProps:x,fullWidth:c,inputComponent:u,multiline:d,ref:t,type:f},m,{classes:y}))}));CN.muiName="Input";const EN=CN;var IN;const PN=["children","classes","className","label","notched"],ON=(0,yn.Ay)("fieldset",{shouldForwardProp:Ta.A})({textAlign:"left",position:"absolute",bottom:0,right:0,top:-5,left:0,margin:0,padding:"0 8px",pointerEvents:"none",borderRadius:"inherit",borderStyle:"solid",borderWidth:1,overflow:"hidden",minWidth:"0%"}),RN=(0,yn.Ay)("legend",{shouldForwardProp:Ta.A})((e=>{let{ownerState:t,theme:r}=e;return(0,O.A)({float:"unset",width:"auto",overflow:"hidden"},!t.withLabel&&{padding:0,lineHeight:"11px",transition:r.transitions.create("width",{duration:150,easing:r.transitions.easing.easeOut})},t.withLabel&&(0,O.A)({display:"block",padding:0,height:11,fontSize:"0.75em",visibility:"hidden",maxWidth:.01,transition:r.transitions.create("max-width",{duration:50,easing:r.transitions.easing.easeOut}),whiteSpace:"nowrap","& > span":{paddingLeft:5,paddingRight:5,display:"inline-block",opacity:0,visibility:"visible"}},t.notched&&{maxWidth:"100%",transition:r.transitions.create("max-width",{duration:100,easing:r.transitions.easing.easeOut,delay:50})}))}));const LN=["components","fullWidth","inputComponent","label","multiline","notched","slots","type"],DN=(0,yn.Ay)($E,{shouldForwardProp:e=>(0,Ta.A)(e)||"classes"===e,name:"MuiOutlinedInput",slot:"Root",overridesResolver:UE})((e=>{let{theme:t,ownerState:r}=e;const n="light"===t.palette.mode?"rgba(0, 0, 0, 0.23)":"rgba(255, 255, 255, 0.23)";return(0,O.A)({position:"relative",borderRadius:(t.vars||t).shape.borderRadius,[`&:hover .${kL.notchedOutline}`]:{borderColor:(t.vars||t).palette.text.primary},"@media (hover: none)":{[`&:hover .${kL.notchedOutline}`]:{borderColor:t.vars?`rgba(${t.vars.palette.common.onBackgroundChannel} / 0.23)`:n}},[`&.${kL.focused} .${kL.notchedOutline}`]:{borderColor:(t.vars||t).palette[r.color].main,borderWidth:2},[`&.${kL.error} .${kL.notchedOutline}`]:{borderColor:(t.vars||t).palette.error.main},[`&.${kL.disabled} .${kL.notchedOutline}`]:{borderColor:(t.vars||t).palette.action.disabled}},r.startAdornment&&{paddingLeft:14},r.endAdornment&&{paddingRight:14},r.multiline&&(0,O.A)({padding:"16.5px 14px"},"small"===r.size&&{padding:"8.5px 14px"}))})),zN=(0,yn.Ay)((function(e){const{className:t,label:r,notched:n}=e,i=(0,R.A)(e,PN),o=null!=r&&""!==r,a=(0,O.A)({},e,{notched:n,withLabel:o});return(0,j.jsx)(ON,(0,O.A)({"aria-hidden":!0,className:t,ownerState:a},i,{children:(0,j.jsx)(RN,{ownerState:a,children:o?(0,j.jsx)("span",{children:r}):IN||(IN=(0,j.jsx)("span",{className:"notranslate",children:"\u200b"}))})}))}),{name:"MuiOutlinedInput",slot:"NotchedOutline",overridesResolver:(e,t)=>t.notchedOutline})((e=>{let{theme:t}=e;const r="light"===t.palette.mode?"rgba(0, 0, 0, 0.23)":"rgba(255, 255, 255, 0.23)";return{borderColor:t.vars?`rgba(${t.vars.palette.common.onBackgroundChannel} / 0.23)`:r}})),jN=(0,yn.Ay)(WE,{name:"MuiOutlinedInput",slot:"Input",overridesResolver:HE})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({padding:"16.5px 14px"},!t.vars&&{"&:-webkit-autofill":{WebkitBoxShadow:"light"===t.palette.mode?null:"0 0 0 100px #266798 inset",WebkitTextFillColor:"light"===t.palette.mode?null:"#fff",caretColor:"light"===t.palette.mode?null:"#fff",borderRadius:"inherit"}},t.vars&&{"&:-webkit-autofill":{borderRadius:"inherit"},[t.getColorSchemeSelector("dark")]:{"&:-webkit-autofill":{WebkitBoxShadow:"0 0 0 100px #266798 inset",WebkitTextFillColor:"#fff",caretColor:"#fff"}}},"small"===r.size&&{padding:"8.5px 14px"},r.multiline&&{padding:0},r.startAdornment&&{paddingLeft:0},r.endAdornment&&{paddingRight:0})})),FN=n.forwardRef((function(e,t){var r,i,o,a,s;const l=(0,vn.b)({props:e,name:"MuiOutlinedInput"}),{components:c={},fullWidth:u=!1,inputComponent:d="input",label:h,multiline:p=!1,notched:f,slots:m={},type:g="text"}=l,y=(0,R.A)(l,LN),v=(e=>{const{classes:t}=e,r=(0,mn.A)({root:["root"],notchedOutline:["notchedOutline"],input:["input"]},wL,t);return(0,O.A)({},t,r)})(l),x=RE(),b=PE({props:l,muiFormControl:x,states:["color","disabled","error","focused","hiddenLabel","size","required"]}),_=(0,O.A)({},l,{color:b.color||"primary",disabled:b.disabled,error:b.error,focused:b.focused,formControl:x,fullWidth:u,hiddenLabel:b.hiddenLabel,multiline:p,size:b.size,type:g}),w=null!=(r=null!=(i=m.root)?i:c.Root)?r:DN,k=null!=(o=null!=(a=m.input)?a:c.Input)?o:jN;return(0,j.jsx)(GE,(0,O.A)({slots:{root:w,input:k},renderSuffix:e=>(0,j.jsx)(zN,{ownerState:_,className:v.notchedOutline,label:null!=h&&""!==h&&b.required?s||(s=(0,j.jsxs)(n.Fragment,{children:[h,"\u2009","*"]})):h,notched:"undefined"!==typeof f?f:Boolean(e.startAdornment||e.filled||e.focused)}),fullWidth:u,inputComponent:d,multiline:p,ref:t,type:g},y,{classes:(0,O.A)({},v,{notchedOutline:null})}))}));FN.muiName="Input";const NN=FN,BN=["autoWidth","children","classes","className","defaultOpen","displayEmpty","IconComponent","id","input","inputProps","label","labelId","MenuProps","multiple","native","onClose","onOpen","open","renderValue","SelectDisplayProps","variant"],VN=["root"],UN={name:"MuiSelect",overridesResolver:(e,t)=>t.root,shouldForwardProp:e=>(0,Ta.A)(e)&&"variant"!==e,slot:"Root"},HN=(0,yn.Ay)(eI,UN)(""),$N=(0,yn.Ay)(NN,UN)(""),WN=(0,yn.Ay)(EN,UN)(""),qN=n.forwardRef((function(e,t){const r=(0,vn.b)({name:"MuiSelect",props:e}),{autoWidth:i=!1,children:o,classes:a={},className:s,defaultOpen:l=!1,displayEmpty:c=!1,IconComponent:u=ML,id:d,input:h,inputProps:p,label:f,labelId:m,MenuProps:g,multiple:y=!1,native:v=!1,onClose:x,onOpen:b,open:_,renderValue:w,SelectDisplayProps:k,variant:S="outlined"}=r,A=(0,R.A)(r,BN),T=v?pN:SN,M=PE({props:r,muiFormControl:RE(),states:["variant","error"]}),C=M.variant||S,E=(0,O.A)({},r,{variant:C,classes:a}),I=(e=>{const{classes:t}=e;return t})(E),P=(0,R.A)(I,VN),L=h||{standard:(0,j.jsx)(HN,{ownerState:E}),outlined:(0,j.jsx)($N,{label:f,ownerState:E}),filled:(0,j.jsx)(WN,{ownerState:E})}[C],D=(0,xn.A)(t,L.ref);return(0,j.jsx)(n.Fragment,{children:n.cloneElement(L,(0,O.A)({inputComponent:T,inputProps:(0,O.A)({children:o,error:M.error,IconComponent:u,variant:C,type:void 0,multiple:y},v?{id:d}:{autoWidth:i,defaultOpen:l,displayEmpty:c,labelId:m,MenuProps:g,onClose:x,onOpen:b,open:_,renderValue:w,SelectDisplayProps:(0,O.A)({id:d},k)},p,{classes:p?(0,SE.A)(P,p.classes):P},h?h.props.inputProps:{})},(y&&v||c)&&"outlined"===C?{notched:!0}:{},{ref:D,className:(0,fn.A)(L.props.className,s,I.root)},!h&&{variant:C},A))})}));qN.muiName="Select";const GN=qN;const YN=n.createContext();const XN=n.createContext();function ZN(e){return(0,Yn.Ay)("MuiTableCell",e)}const KN=(0,Ln.A)("MuiTableCell",["root","head","body","footer","sizeSmall","sizeMedium","paddingCheckbox","paddingNone","alignLeft","alignCenter","alignRight","alignJustify","stickyHeader"]),JN=["align","className","component","padding","scope","size","sortDirection","variant"],QN=(0,yn.Ay)("td",{name:"MuiTableCell",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,t[r.variant],t[`size${(0,ei.A)(r.size)}`],"normal"!==r.padding&&t[`padding${(0,ei.A)(r.padding)}`],"inherit"!==r.align&&t[`align${(0,ei.A)(r.align)}`],r.stickyHeader&&t.stickyHeader]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({},t.typography.body2,{display:"table-cell",verticalAlign:"inherit",borderBottom:t.vars?`1px solid ${t.vars.palette.TableCell.border}`:`1px solid\n ${"light"===t.palette.mode?(0,gn.a)((0,gn.X4)(t.palette.divider,1),.88):(0,gn.e$)((0,gn.X4)(t.palette.divider,1),.68)}`,textAlign:"left",padding:16},"head"===r.variant&&{color:(t.vars||t).palette.text.primary,lineHeight:t.typography.pxToRem(24),fontWeight:t.typography.fontWeightMedium},"body"===r.variant&&{color:(t.vars||t).palette.text.primary},"footer"===r.variant&&{color:(t.vars||t).palette.text.secondary,lineHeight:t.typography.pxToRem(21),fontSize:t.typography.pxToRem(12)},"small"===r.size&&{padding:"6px 16px",[`&.${KN.paddingCheckbox}`]:{width:24,padding:"0 12px 0 16px","& > *":{padding:0}}},"checkbox"===r.padding&&{width:48,padding:"0 0 0 4px"},"none"===r.padding&&{padding:0},"left"===r.align&&{textAlign:"left"},"center"===r.align&&{textAlign:"center"},"right"===r.align&&{textAlign:"right",flexDirection:"row-reverse"},"justify"===r.align&&{textAlign:"justify"},r.stickyHeader&&{position:"sticky",top:0,zIndex:2,backgroundColor:(t.vars||t).palette.background.default})})),eB=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiTableCell"}),{align:i="inherit",className:o,component:a,padding:s,scope:l,size:c,sortDirection:u,variant:d}=r,h=(0,R.A)(r,JN),p=n.useContext(YN),f=n.useContext(XN),m=f&&"head"===f.variant;let g;g=a||(m?"th":"td");let y=l;"td"===g?y=void 0:!y&&m&&(y="col");const v=d||f&&f.variant,x=(0,O.A)({},r,{align:i,component:g,padding:s||(p&&p.padding?p.padding:"normal"),size:c||(p&&p.size?p.size:"medium"),sortDirection:u,stickyHeader:"head"===v&&p&&p.stickyHeader,variant:v}),b=(e=>{const{classes:t,variant:r,align:n,padding:i,size:o,stickyHeader:a}=e,s={root:["root",r,a&&"stickyHeader","inherit"!==n&&`align${(0,ei.A)(n)}`,"normal"!==i&&`padding${(0,ei.A)(i)}`,`size${(0,ei.A)(o)}`]};return(0,mn.A)(s,ZN,t)})(x);let _=null;return u&&(_="asc"===u?"ascending":"descending"),(0,j.jsx)(QN,(0,O.A)({as:g,ref:t,className:(0,fn.A)(b.root,o),"aria-sort":_,scope:y,ownerState:x},h))})),tB=(0,Ud.A)((0,j.jsx)("path",{d:"M5.59 7.41L10.18 12l-4.59 4.59L7 18l6-6-6-6zM16 6h2v12h-2z"}),"LastPage"),rB=(0,Ud.A)((0,j.jsx)("path",{d:"M18.41 16.59L13.82 12l4.59-4.59L17 6l-6 6 6 6zM6 6h2v12H6z"}),"FirstPage"),nB=["backIconButtonProps","count","disabled","getItemAriaLabel","nextIconButtonProps","onPageChange","page","rowsPerPage","showFirstButton","showLastButton","slots","slotProps"],iB=n.forwardRef((function(e,t){var r,n,i,o,a,s,l,c;const{backIconButtonProps:u,count:d,disabled:h=!1,getItemAriaLabel:p,nextIconButtonProps:f,onPageChange:m,page:g,rowsPerPage:y,showFirstButton:v,showLastButton:x,slots:b={},slotProps:_={}}=e,w=(0,R.A)(e,nB),k=H(),S=null!=(r=b.firstButton)?r:oi,A=null!=(n=b.lastButton)?n:oi,T=null!=(i=b.nextButton)?i:oi,M=null!=(o=b.previousButton)?o:oi,C=null!=(a=b.firstButtonIcon)?a:rB,E=null!=(s=b.lastButtonIcon)?s:tB,I=null!=(l=b.nextButtonIcon)?l:UM,P=null!=(c=b.previousButtonIcon)?c:VM,L=k?A:S,D=k?T:M,z=k?M:T,F=k?S:A,N=k?_.lastButton:_.firstButton,B=k?_.nextButton:_.previousButton,V=k?_.previousButton:_.nextButton,U=k?_.firstButton:_.lastButton;return(0,j.jsxs)("div",(0,O.A)({ref:t},w,{children:[v&&(0,j.jsx)(L,(0,O.A)({onClick:e=>{m(e,0)},disabled:h||0===g,"aria-label":p("first",g),title:p("first",g)},N,{children:k?(0,j.jsx)(E,(0,O.A)({},_.lastButtonIcon)):(0,j.jsx)(C,(0,O.A)({},_.firstButtonIcon))})),(0,j.jsx)(D,(0,O.A)({onClick:e=>{m(e,g-1)},disabled:h||0===g,color:"inherit","aria-label":p("previous",g),title:p("previous",g)},null!=B?B:u,{children:k?(0,j.jsx)(I,(0,O.A)({},_.nextButtonIcon)):(0,j.jsx)(P,(0,O.A)({},_.previousButtonIcon))})),(0,j.jsx)(z,(0,O.A)({onClick:e=>{m(e,g+1)},disabled:h||-1!==d&&g>=Math.ceil(d/y)-1,color:"inherit","aria-label":p("next",g),title:p("next",g)},null!=V?V:f,{children:k?(0,j.jsx)(P,(0,O.A)({},_.previousButtonIcon)):(0,j.jsx)(I,(0,O.A)({},_.nextButtonIcon))})),x&&(0,j.jsx)(F,(0,O.A)({onClick:e=>{m(e,Math.max(0,Math.ceil(d/y)-1))},disabled:h||g>=Math.ceil(d/y)-1,"aria-label":p("last",g),title:p("last",g)},U,{children:k?(0,j.jsx)(C,(0,O.A)({},_.firstButtonIcon)):(0,j.jsx)(E,(0,O.A)({},_.lastButtonIcon))}))]}))}));function oB(e){return(0,Yn.Ay)("MuiTablePagination",e)}const aB=(0,Ln.A)("MuiTablePagination",["root","toolbar","spacer","selectLabel","selectRoot","select","selectIcon","input","menuItem","displayedRows","actions"]);var sB;const lB=["ActionsComponent","backIconButtonProps","className","colSpan","component","count","disabled","getItemAriaLabel","labelDisplayedRows","labelRowsPerPage","nextIconButtonProps","onPageChange","onRowsPerPageChange","page","rowsPerPage","rowsPerPageOptions","SelectProps","showFirstButton","showLastButton","slotProps","slots"],cB=(0,yn.Ay)(eB,{name:"MuiTablePagination",slot:"Root",overridesResolver:(e,t)=>t.root})((e=>{let{theme:t}=e;return{overflow:"auto",color:(t.vars||t).palette.text.primary,fontSize:t.typography.pxToRem(14),"&:last-child":{padding:0}}})),uB=(0,yn.Ay)(ji,{name:"MuiTablePagination",slot:"Toolbar",overridesResolver:(e,t)=>(0,O.A)({[`& .${aB.actions}`]:t.actions},t.toolbar)})((e=>{let{theme:t}=e;return{minHeight:52,paddingRight:2,[`${t.breakpoints.up("xs")} and (orientation: landscape)`]:{minHeight:52},[t.breakpoints.up("sm")]:{minHeight:52,paddingRight:2},[`& .${aB.actions}`]:{flexShrink:0,marginLeft:20}}})),dB=(0,yn.Ay)("div",{name:"MuiTablePagination",slot:"Spacer",overridesResolver:(e,t)=>t.spacer})({flex:"1 1 100%"}),hB=(0,yn.Ay)("p",{name:"MuiTablePagination",slot:"SelectLabel",overridesResolver:(e,t)=>t.selectLabel})((e=>{let{theme:t}=e;return(0,O.A)({},t.typography.body2,{flexShrink:0})})),pB=(0,yn.Ay)(GN,{name:"MuiTablePagination",slot:"Select",overridesResolver:(e,t)=>(0,O.A)({[`& .${aB.selectIcon}`]:t.selectIcon,[`& .${aB.select}`]:t.select},t.input,t.selectRoot)})({color:"inherit",fontSize:"inherit",flexShrink:0,marginRight:32,marginLeft:8,[`& .${aB.select}`]:{paddingLeft:8,paddingRight:24,textAlign:"right",textAlignLast:"right"}}),fB=(0,yn.Ay)(qa,{name:"MuiTablePagination",slot:"MenuItem",overridesResolver:(e,t)=>t.menuItem})({}),mB=(0,yn.Ay)("p",{name:"MuiTablePagination",slot:"DisplayedRows",overridesResolver:(e,t)=>t.displayedRows})((e=>{let{theme:t}=e;return(0,O.A)({},t.typography.body2,{flexShrink:0})}));function gB(e){let{from:t,to:r,count:n}=e;return`${t}\u2013${r} of ${-1!==n?n:`more than ${r}`}`}function yB(e){return`Go to ${e} page`}const vB=n.forwardRef((function(e,t){var r;const i=(0,vn.b)({props:e,name:"MuiTablePagination"}),{ActionsComponent:o=iB,backIconButtonProps:a,className:s,colSpan:l,component:c=eB,count:u,disabled:d=!1,getItemAriaLabel:h=yB,labelDisplayedRows:p=gB,labelRowsPerPage:f="Rows per page:",nextIconButtonProps:m,onPageChange:g,onRowsPerPageChange:y,page:v,rowsPerPage:x,rowsPerPageOptions:b=[10,25,50,100],SelectProps:_={},showFirstButton:w=!1,showLastButton:k=!1,slotProps:S={},slots:A={}}=i,T=(0,R.A)(i,lB),M=i,C=(e=>{const{classes:t}=e;return(0,mn.A)({root:["root"],toolbar:["toolbar"],spacer:["spacer"],selectLabel:["selectLabel"],select:["select"],input:["input"],selectIcon:["selectIcon"],menuItem:["menuItem"],displayedRows:["displayedRows"],actions:["actions"]},oB,t)})(M),E=null!=(r=null==S?void 0:S.select)?r:_,I=E.native?"option":fB;let P;c!==eB&&"td"!==c||(P=l||1e3);const L=(0,mp.A)(E.id),D=(0,mp.A)(E.labelId);return(0,j.jsx)(cB,(0,O.A)({colSpan:P,ref:t,as:c,ownerState:M,className:(0,fn.A)(C.root,s)},T,{children:(0,j.jsxs)(uB,{className:C.toolbar,children:[(0,j.jsx)(dB,{className:C.spacer}),b.length>1&&(0,j.jsx)(hB,{className:C.selectLabel,id:D,children:f}),b.length>1&&(0,j.jsx)(pB,(0,O.A)({variant:"standard"},!E.variant&&{input:sB||(sB=(0,j.jsx)(GE,{}))},{value:x,onChange:y,id:L,labelId:D},E,{classes:(0,O.A)({},E.classes,{root:(0,fn.A)(C.input,C.selectRoot,(E.classes||{}).root),select:(0,fn.A)(C.select,(E.classes||{}).select),icon:(0,fn.A)(C.selectIcon,(E.classes||{}).icon)}),disabled:d,children:b.map((e=>(0,n.createElement)(I,(0,O.A)({},!Yi(I)&&{ownerState:M},{className:C.menuItem,key:e.label?e.label:e,value:e.value?e.value:e}),e.label?e.label:e)))})),(0,j.jsx)(mB,{className:C.displayedRows,children:p({from:0===u?0:v*x+1,to:-1===u?(v+1)*x:-1===x?u:Math.min(u,(v+1)*x),count:-1===u?-1:u,page:v})}),(0,j.jsx)(o,{className:C.actions,backIconButtonProps:a,count:u,nextIconButtonProps:m,onPageChange:g,page:v,rowsPerPage:x,showFirstButton:w,showLastButton:k,slotProps:S.actions,slots:A.actions,getItemAriaLabel:h,disabled:d})]})}))})),xB=(0,yn.Ay)(vB)((e=>{let{theme:t}=e;return{[`& .${aB.selectLabel}`]:{display:"none",[t.breakpoints.up("sm")]:{display:"block"}},[`& .${aB.input}`]:{display:"none",[t.breakpoints.up("sm")]:{display:"inline-flex"}}}})),bB=n.forwardRef((function(e,t){const r=xR(),i=tP(),o=KI(r,IR),a=KI(r,PR),s=n.useMemo((()=>Math.floor(a/(o.pageSize||1))),[a,o.pageSize]),l=n.useCallback((e=>{const t=Number(e.target.value);r.current.setPageSize(t)}),[r]),c=n.useCallback(((e,t)=>{r.current.setPage(t)}),[r]);const u=(e=>{for(let t=0;tt.panelContent})({display:"flex",flexDirection:"column",overflow:"auto",flex:"1 1",maxHeight:400});function kB(e){const{className:t}=e,r=(0,R.A)(e,_B),n=tP(),i=(e=>{const{classes:t}=e;return(0,mn.A)({root:["panelContent"]},DI,t)})(n);return(0,j.jsx)(wB,(0,O.A)({className:(0,fn.A)(t,i.root),ownerState:n},r))}const SB=["className"],AB=nO("div",{name:"MuiDataGrid",slot:"PanelFooter",overridesResolver:(e,t)=>t.panelFooter})((e=>{let{theme:t}=e;return{padding:t.spacing(.5),display:"flex",justifyContent:"space-between"}}));function TB(e){const{className:t}=e,r=(0,R.A)(e,SB),n=tP(),i=(e=>{const{classes:t}=e;return(0,mn.A)({root:["panelFooter"]},DI,t)})(n);return(0,j.jsx)(AB,(0,O.A)({className:(0,fn.A)(t,i.root),ownerState:n},r))}const MB=["className","slotProps"],CB=(0,yn.Ay)("div",{name:"MuiDataGrid",slot:"PanelWrapper",overridesResolver:(e,t)=>t.panelWrapper})({display:"flex",flexDirection:"column",flex:1,"&:focus":{outline:0}}),EB=()=>!0,IB=n.forwardRef((function(e,t){const{className:r,slotProps:n={}}=e,i=(0,R.A)(e,MB),o=tP(),a=(e=>{const{classes:t}=e;return(0,mn.A)({root:["panelWrapper"]},DI,t)})(o);return(0,j.jsx)(Ho,(0,O.A)({open:!0,disableEnforceFocus:!0,isEnabled:EB},n.TrapFocus,{children:(0,j.jsx)(CB,(0,O.A)({ref:t,tabIndex:-1,className:(0,fn.A)(r,a.root),ownerState:o},i))}))})),PB=["item","hasMultipleFilters","deleteFilter","applyFilterChanges","multiFilterOperator","showMultiFilterOperators","disableMultiFilterOperator","applyMultiFilterOperatorChanges","focusElementRef","logicOperators","columnsSort","filterColumns","deleteIconProps","logicOperatorInputProps","operatorInputProps","columnInputProps","valueInputProps","children"],OB=["InputComponentProps"],RB=(0,yn.Ay)("div",{name:"MuiDataGrid",slot:"FilterForm",overridesResolver:(e,t)=>t.filterForm})((e=>{let{theme:t}=e;return{display:"flex",padding:t.spacing(1)}})),LB=(0,yn.Ay)("div",{name:"MuiDataGrid",slot:"FilterFormDeleteIcon",overridesResolver:(e,t)=>t.filterFormDeleteIcon})((e=>{let{theme:t}=e;return{flexShrink:0,justifyContent:"flex-end",marginRight:t.spacing(.5),marginBottom:t.spacing(.2)}})),DB=(0,yn.Ay)("div",{name:"MuiDataGrid",slot:"FilterFormLogicOperatorInput",overridesResolver:(e,t)=>t.filterFormLogicOperatorInput})({minWidth:55,marginRight:5,justifyContent:"end"}),zB=(0,yn.Ay)("div",{name:"MuiDataGrid",slot:"FilterFormColumnInput",overridesResolver:(e,t)=>t.filterFormColumnInput})({width:150}),jB=(0,yn.Ay)("div",{name:"MuiDataGrid",slot:"FilterFormOperatorInput",overridesResolver:(e,t)=>t.filterFormOperatorInput})({width:120}),FB=(0,yn.Ay)("div",{name:"MuiDataGrid",slot:"FilterFormValueInput",overridesResolver:(e,t)=>t.filterFormValueInput})({width:190}),NB=e=>e.headerName||e.field,BB=new Intl.Collator,VB=n.forwardRef((function(e,t){var r,i,o,a,s,l,c,u,d,h;const{item:p,hasMultipleFilters:f,deleteFilter:m,applyFilterChanges:g,multiFilterOperator:y,showMultiFilterOperators:v,disableMultiFilterOperator:x,applyMultiFilterOperatorChanges:b,focusElementRef:_,logicOperators:w=[rD.And,rD.Or],columnsSort:k,filterColumns:S,deleteIconProps:A={},logicOperatorInputProps:T={},operatorInputProps:M={},columnInputProps:C={},valueInputProps:E={}}=e,I=(0,R.A)(e,PB),P=xR(),L=KI(P,SP),D=KI(P,hO),z=(0,zp.A)(),F=(0,zp.A)(),N=(0,zp.A)(),B=(0,zp.A)(),V=tP(),U=(e=>{const{classes:t}=e;return(0,mn.A)({root:["filterForm"],deleteIcon:["filterFormDeleteIcon"],logicOperatorInput:["filterFormLogicOperatorInput"],columnInput:["filterFormColumnInput"],operatorInput:["filterFormOperatorInput"],valueInput:["filterFormValueInput"]},DI,t)})(V),H=n.useRef(null),$=n.useRef(null),W=f&&w.length>0,q=(null==(r=V.slotProps)?void 0:r.baseFormControl)||{},G=null==(o=((null==(i=V.slotProps)?void 0:i.baseSelect)||{}).native)||o,Y=(null==(a=V.slotProps)?void 0:a.baseInputLabel)||{},X=(null==(s=V.slotProps)?void 0:s.baseSelectOption)||{},{InputComponentProps:Z}=E,K=(0,R.A)(E,OB),J=n.useMemo((()=>{if(void 0===S||"function"!==typeof S)return L;const e=S({field:p.field,columns:L,currentFilters:(null==D?void 0:D.items)||[]});return L.filter((t=>e.includes(t.field)))}),[S,null==D?void 0:D.items,L,p.field]),Q=n.useMemo((()=>{switch(k){case"asc":return J.sort(((e,t)=>BB.compare(NB(e),NB(t))));case"desc":return J.sort(((e,t)=>-BB.compare(NB(e),NB(t))));default:return J}}),[J,k]),ee=p.field?P.current.getColumn(p.field):null,te=n.useMemo((()=>{var e;return p.operator&&ee?null==(e=ee.filterOperators)?void 0:e.find((e=>e.value===p.operator)):null}),[p,ee]),re=n.useCallback((e=>{const t=e.target.value,r=P.current.getColumn(t);if(r.field===ee.field)return;const n=r.filterOperators.find((e=>e.value===p.operator))||r.filterOperators[0],i=!n.InputComponent||n.InputComponent!==(null==te?void 0:te.InputComponent)||r.type!==ee.type;g((0,O.A)({},p,{field:t,operator:n.value,value:i?void 0:p.value}))}),[P,g,p,ee,te]),ne=n.useCallback((e=>{const t=e.target.value,r=null==ee?void 0:ee.filterOperators.find((e=>e.value===t)),n=!(null!=r&&r.InputComponent)||(null==r?void 0:r.InputComponent)!==(null==te?void 0:te.InputComponent);g((0,O.A)({},p,{operator:t,value:n?void 0:p.value}))}),[g,p,ee,te]),ie=n.useCallback((e=>{const t=e.target.value===rD.And.toString()?rD.And:rD.Or;b(t)}),[b]);return n.useImperativeHandle(_,(()=>({focus:()=>{var e;null!=te&&te.InputComponent?null==H||null==(e=H.current)||e.focus():$.current.focus()}})),[te]),(0,j.jsxs)(RB,(0,O.A)({ref:t,className:U.root,"data-id":p.id,ownerState:V},I,{children:[(0,j.jsx)(LB,(0,O.A)({variant:"standard",as:V.slots.baseFormControl},q,A,{className:(0,fn.A)(U.deleteIcon,q.className,A.className),ownerState:V,children:(0,j.jsx)(V.slots.baseIconButton,(0,O.A)({"aria-label":P.current.getLocaleText("filterPanelDeleteIconLabel"),title:P.current.getLocaleText("filterPanelDeleteIconLabel"),onClick:()=>{V.disableMultipleColumnsFiltering?void 0===p.value?m(p):g((0,O.A)({},p,{value:void 0})):m(p)},size:"small"},null==(l=V.slotProps)?void 0:l.baseIconButton,{children:(0,j.jsx)(V.slots.filterPanelDeleteIcon,{fontSize:"small"})}))})),(0,j.jsx)(DB,(0,O.A)({variant:"standard",as:V.slots.baseFormControl},q,T,{sx:(0,O.A)({display:W?"flex":"none",visibility:v?"visible":"hidden"},q.sx||{},T.sx||{}),className:(0,fn.A)(U.logicOperatorInput,q.className,T.className),ownerState:V,children:(0,j.jsx)(V.slots.baseSelect,(0,O.A)({inputProps:{"aria-label":P.current.getLocaleText("filterPanelLogicOperator")},value:y,onChange:ie,disabled:!!x||1===w.length,native:G},null==(c=V.slotProps)?void 0:c.baseSelect,{children:w.map((e=>(0,n.createElement)(V.slots.baseSelectOption,(0,O.A)({},X,{native:G,key:e.toString(),value:e.toString()}),P.current.getLocaleText((e=>{switch(e){case rD.And:return"filterPanelOperatorAnd";case rD.Or:return"filterPanelOperatorOr";default:throw new Error("MUI: Invalid `logicOperator` property in the `GridFilterPanel`.")}})(e)))))}))})),(0,j.jsxs)(zB,(0,O.A)({variant:"standard",as:V.slots.baseFormControl},q,C,{className:(0,fn.A)(U.columnInput,q.className,C.className),ownerState:V,children:[(0,j.jsx)(V.slots.baseInputLabel,(0,O.A)({},Y,{htmlFor:z,id:F,children:P.current.getLocaleText("filterPanelColumns")})),(0,j.jsx)(V.slots.baseSelect,(0,O.A)({labelId:F,id:z,label:P.current.getLocaleText("filterPanelColumns"),value:p.field||"",onChange:re,native:G},null==(u=V.slotProps)?void 0:u.baseSelect,{children:Q.map((e=>(0,n.createElement)(V.slots.baseSelectOption,(0,O.A)({},X,{native:G,key:e.field,value:e.field}),NB(e))))}))]})),(0,j.jsxs)(jB,(0,O.A)({variant:"standard",as:V.slots.baseFormControl},q,M,{className:(0,fn.A)(U.operatorInput,q.className,M.className),ownerState:V,children:[(0,j.jsx)(V.slots.baseInputLabel,(0,O.A)({},Y,{htmlFor:N,id:B,children:P.current.getLocaleText("filterPanelOperator")})),(0,j.jsx)(V.slots.baseSelect,(0,O.A)({labelId:B,label:P.current.getLocaleText("filterPanelOperator"),id:N,value:p.operator,onChange:ne,native:G,inputRef:$},null==(d=V.slotProps)?void 0:d.baseSelect,{children:null==ee||null==(h=ee.filterOperators)?void 0:h.map((e=>(0,n.createElement)(V.slots.baseSelectOption,(0,O.A)({},X,{native:G,key:e.value,value:e.value}),e.label||P.current.getLocaleText(`filterOperator${(0,MI.A)(e.value)}`))))}))]})),(0,j.jsx)(FB,(0,O.A)({variant:"standard",as:V.slots.baseFormControl},q,K,{className:(0,fn.A)(U.valueInput,q.className,K.className),ownerState:V,children:null!=te&&te.InputComponent?(0,j.jsx)(te.InputComponent,(0,O.A)({apiRef:P,item:p,applyValue:g,focusElementRef:H},te.InputComponentProps,Z)):null}))]}))})),UB=["logicOperators","columnsSort","filterFormProps","getColumnForNewFilter","children","disableAddFilterButton","disableRemoveAllButton"],HB=e=>({field:e.field,operator:e.filterOperators[0].value,id:Math.round(1e5*Math.random())}),$B=n.forwardRef((function(e,t){var r,i;const o=xR(),a=tP(),s=KI(o,hO),l=KI(o,SP),c=n.useRef(null),u=n.useRef(null),{logicOperators:d=[rD.And,rD.Or],columnsSort:h,filterFormProps:p,getColumnForNewFilter:f,disableAddFilterButton:m=!1,disableRemoveAllButton:g=!1}=e,y=(0,R.A)(e,UB),v=o.current.upsertFilterItem,x=n.useCallback((e=>{o.current.setFilterLogicOperator(e)}),[o]),b=n.useCallback((()=>{let e;if(f&&"function"===typeof f){const t=f({currentFilters:(null==s?void 0:s.items)||[],columns:l});if(null===t)return null;e=l.find((e=>{let{field:r}=e;return r===t}))}else e=l.find((e=>{var t;return null==(t=e.filterOperators)?void 0:t.length}));return e?HB(e):null}),[null==s?void 0:s.items,l,f]),_=n.useCallback((()=>{if(void 0===f||"function"!==typeof f)return b();const e=s.items.length?s.items:[b()].filter(Boolean),t=f({currentFilters:e,columns:l});if(null===t)return null;const r=l.find((e=>{let{field:r}=e;return r===t}));return r?HB(r):null}),[s.items,l,f,b]),w=n.useMemo((()=>s.items.length?s.items:(u.current||(u.current=b()),u.current?[u.current]:[])),[s.items,b]),k=w.length>1,S=n.useCallback((e=>{const t=1===w.length;o.current.deleteFilterItem(e),t&&o.current.hideFilterPanel()}),[o,w.length]);return n.useEffect((()=>{d.length>0&&s.logicOperator&&!d.includes(s.logicOperator)&&x(d[0])}),[d,x,s.logicOperator]),n.useEffect((()=>{w.length>0&&c.current.focus()}),[w.length]),(0,j.jsxs)(IB,(0,O.A)({ref:t},y,{children:[(0,j.jsx)(kB,{children:w.map(((e,t)=>(0,j.jsx)(VB,(0,O.A)({item:e,applyFilterChanges:v,deleteFilter:S,hasMultipleFilters:k,showMultiFilterOperators:t>0,multiFilterOperator:s.logicOperator,disableMultiFilterOperator:1!==t,applyMultiFilterOperatorChanges:x,focusElementRef:t===w.length-1?c:null,logicOperators:d,columnsSort:h},p),null==e.id?t:e.id)))}),a.disableMultipleColumnsFiltering||m&&g?null:(0,j.jsxs)(TB,{children:[m?(0,j.jsx)("span",{}):(0,j.jsx)(a.slots.baseButton,(0,O.A)({onClick:()=>{const e=_();e&&o.current.upsertFilterItems([...w,e])},startIcon:(0,j.jsx)(a.slots.filterPanelAddIcon,{})},null==(r=a.slotProps)?void 0:r.baseButton,{children:o.current.getLocaleText("filterPanelAddFilter")})),g?null:(0,j.jsx)(a.slots.baseButton,(0,O.A)({onClick:()=>{1===w.length&&void 0===w[0].value&&(o.current.deleteFilterItem(w[0]),o.current.hideFilterPanel()),o.current.setFilterModel((0,O.A)({},s,{items:[]}))},startIcon:(0,j.jsx)(a.slots.filterPanelRemoveAllIcon,{})},null==(i=a.slotProps)?void 0:i.baseButton,{children:o.current.getLocaleText("filterPanelRemoveAll")}))]})]}))}));function WB(e){return(0,Yn.Ay)("MuiSwitch",e)}const qB=(0,Ln.A)("MuiSwitch",["root","edgeStart","edgeEnd","switchBase","colorPrimary","colorSecondary","sizeSmall","sizeMedium","checked","disabled","input","thumb","track"]);var GB=r(28604);const YB=["component","direction","spacing","divider","children","className","useFlexGap"],XB=(0,ci.A)(),ZB=nO("div",{name:"MuiStack",slot:"Root",overridesResolver:(e,t)=>t.root});function KB(e){return nF({props:e,name:"MuiStack",defaultTheme:XB})}function JB(e,t){const r=n.Children.toArray(e).filter(Boolean);return r.reduce(((e,i,o)=>(e.push(i),o{let{ownerState:t,theme:r}=e,n=(0,O.A)({display:"flex",flexDirection:"column"},(0,yf.NI)({theme:r},(0,yf.kW)({values:t.direction,breakpoints:r.breakpoints.values}),(e=>({flexDirection:e}))));if(t.spacing){const e=(0,GB.LX)(r),i=Object.keys(r.breakpoints.values).reduce(((e,r)=>(("object"===typeof t.spacing&&null!=t.spacing[r]||"object"===typeof t.direction&&null!=t.direction[r])&&(e[r]=!0),e)),{}),o=(0,yf.kW)({values:t.direction,base:i}),a=(0,yf.kW)({values:t.spacing,base:i});"object"===typeof o&&Object.keys(o).forEach(((e,t,r)=>{if(!o[e]){const n=t>0?o[r[t-1]]:"column";o[e]=n}}));const s=(r,n)=>{return t.useFlexGap?{gap:(0,GB._W)(e,r)}:{"& > :not(style):not(style)":{margin:0},"& > :not(style) ~ :not(style)":{[`margin${i=n?o[n]:t.direction,{row:"Left","row-reverse":"Right",column:"Top","column-reverse":"Bottom"}[i]}`]:(0,GB._W)(e,r)}};var i};n=(0,SE.A)(n,(0,yf.NI)({theme:r},a,s))}return n=(0,yf.iZ)(r.breakpoints,n),n};const eV=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const{createStyledComponent:t=ZB,useThemeProps:r=KB,componentName:i="MuiStack"}=e,o=t(QB);return n.forwardRef((function(e,t){const n=r(e),a=(0,li.A)(n),{component:s="div",direction:l="column",spacing:c=0,divider:u,children:d,className:h,useFlexGap:p=!1}=a,f=(0,R.A)(a,YB),m={direction:l,spacing:c,useFlexGap:p},g=(0,mn.A)({root:["root"]},(e=>(0,Yn.Ay)(i,e)),{});return(0,j.jsx)(o,(0,O.A)({as:s,ownerState:m,ref:t,className:(0,fn.A)(g.root,h)},f,{children:u?JB(d,u):d}))}))}({createStyledComponent:(0,yn.Ay)("div",{name:"MuiStack",slot:"Root",overridesResolver:(e,t)=>t.root}),useThemeProps:e=>(0,vn.b)({props:e,name:"MuiStack"})});function tV(e){return(0,Yn.Ay)("MuiFormControlLabel",e)}const rV=(0,Ln.A)("MuiFormControlLabel",["root","labelPlacementStart","labelPlacementTop","labelPlacementBottom","disabled","label","error","required","asterisk"]),nV=["checked","className","componentsProps","control","disabled","disableTypography","inputRef","label","labelPlacement","name","onChange","required","slotProps","value"],iV=(0,yn.Ay)("label",{name:"MuiFormControlLabel",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[{[`& .${rV.label}`]:t.label},t.root,t[`labelPlacement${(0,ei.A)(r.labelPlacement)}`]]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({display:"inline-flex",alignItems:"center",cursor:"pointer",verticalAlign:"middle",WebkitTapHighlightColor:"transparent",marginLeft:-11,marginRight:16,[`&.${rV.disabled}`]:{cursor:"default"}},"start"===r.labelPlacement&&{flexDirection:"row-reverse",marginLeft:16,marginRight:-11},"top"===r.labelPlacement&&{flexDirection:"column-reverse",marginLeft:16},"bottom"===r.labelPlacement&&{flexDirection:"column",marginLeft:16},{[`& .${rV.label}`]:{[`&.${rV.disabled}`]:{color:(t.vars||t).palette.text.disabled}}})})),oV=(0,yn.Ay)("span",{name:"MuiFormControlLabel",slot:"Asterisk",overridesResolver:(e,t)=>t.asterisk})((e=>{let{theme:t}=e;return{[`&.${rV.error}`]:{color:(t.vars||t).palette.error.main}}})),aV=n.forwardRef((function(e,t){var r,i;const o=(0,vn.b)({props:e,name:"MuiFormControlLabel"}),{className:a,componentsProps:s={},control:l,disabled:c,disableTypography:u,label:d,labelPlacement:h="end",required:p,slotProps:f={}}=o,m=(0,R.A)(o,nV),g=RE(),y=null!=(r=null!=c?c:l.props.disabled)?r:null==g?void 0:g.disabled,v=null!=p?p:l.props.required,x={disabled:y,required:v};["checked","name","onChange","value","inputRef"].forEach((e=>{"undefined"===typeof l.props[e]&&"undefined"!==typeof o[e]&&(x[e]=o[e])}));const b=PE({props:o,muiFormControl:g,states:["error"]}),_=(0,O.A)({},o,{disabled:y,labelPlacement:h,required:v,error:b.error}),w=(e=>{const{classes:t,disabled:r,labelPlacement:n,error:i,required:o}=e,a={root:["root",r&&"disabled",`labelPlacement${(0,ei.A)(n)}`,i&&"error",o&&"required"],label:["label",r&&"disabled"],asterisk:["asterisk",i&&"error"]};return(0,mn.A)(a,tV,t)})(_),k=null!=(i=f.typography)?i:s.typography;let S=d;return null==S||S.type===Hi||u||(S=(0,j.jsx)(Hi,(0,O.A)({component:"span"},k,{className:(0,fn.A)(w.label,null==k?void 0:k.className),children:S}))),(0,j.jsxs)(iV,(0,O.A)({className:(0,fn.A)(w.root,a),ownerState:_,ref:t},m,{children:[n.cloneElement(l,x),v?(0,j.jsxs)(eV,{display:"block",children:[S,(0,j.jsxs)(oV,{ownerState:_,"aria-hidden":!0,className:w.asterisk,children:["\u2009","*"]})]}):S]}))})),sV=["className"],lV=nO("div",{name:"MuiDataGrid",slot:"PanelHeader",overridesResolver:(e,t)=>t.panelHeader})((e=>{let{theme:t}=e;return{padding:t.spacing(1)}}));function cV(e){const{className:t}=e,r=(0,R.A)(e,sV),n=tP(),i=(e=>{const{classes:t}=e;return(0,mn.A)({root:["panelHeader"]},DI,t)})(n);return(0,j.jsx)(lV,(0,O.A)({className:(0,fn.A)(t,i.root),ownerState:n},r))}const uV=["sort","searchPredicate","autoFocusSearchField","disableHideAllButton","disableShowAllButton","getTogglableColumns"],dV=(0,yn.Ay)("div",{name:"MuiDataGrid",slot:"ColumnsPanel",overridesResolver:(e,t)=>t.columnsPanel})({padding:"8px 0px 8px 8px"}),hV=(0,yn.Ay)("div",{name:"MuiDataGrid",slot:"ColumnsPanelRow",overridesResolver:(e,t)=>t.columnsPanelRow})((e=>{let{theme:t}=e;return{display:"flex",justifyContent:"space-between",padding:"1px 8px 1px 7px",[`& .${qB.root}`]:{marginRight:t.spacing(.5)}}})),pV=((0,yn.Ay)(oi)({justifyContent:"flex-end"}),new Intl.Collator),fV=(e,t)=>(e.headerName||e.field).toLowerCase().indexOf(t)>-1;const mV=["children","className","classes"],gV=(0,Ln.A)("MuiDataGrid",["panel","paper"]),yV=(0,yn.Ay)(fp,{name:"MuiDataGrid",slot:"Panel",overridesResolver:(e,t)=>t.panel})((e=>{let{theme:t}=e;return{zIndex:t.zIndex.modal}})),vV=(0,yn.Ay)(Ci,{name:"MuiDataGrid",slot:"Paper",overridesResolver:(e,t)=>t.paper})((e=>{let{theme:t}=e;return{backgroundColor:(t.vars||t).palette.background.paper,minWidth:300,maxHeight:450,display:"flex"}})),xV=n.forwardRef(((e,t)=>{const{children:r,className:i}=e,o=(0,R.A)(e,mV),a=xR(),s=tP(),l=gV,[c,u]=n.useState(!1),d=n.useCallback((()=>{a.current.hidePreferences()}),[a]),h=n.useCallback((e=>{pR(e.key)&&a.current.hidePreferences()}),[a]),p=n.useMemo((()=>[{name:"flip",enabled:!0,options:{rootBoundary:"document"}},{name:"isPlaced",enabled:!0,phase:"main",fn:()=>{u(!0)},effect:()=>()=>{u(!1)}}]),[]),[f,m]=n.useState(null);return n.useEffect((()=>{var e;const t=null==(e=a.current.rootElementRef)||null==(e=e.current)?void 0:e.querySelector(`.${zI.columnHeaders}`);t&&m(t)}),[a]),f?(0,j.jsx)(yV,(0,O.A)({ref:t,placement:"bottom-start",className:(0,fn.A)(i,l.panel),ownerState:s,anchorEl:f,modifiers:p},o,{children:(0,j.jsx)(Lz,{mouseEvent:"onMouseUp",onClickAway:d,children:(0,j.jsx)(vV,{className:l.paper,ownerState:s,elevation:8,onKeyDown:h,children:c&&r})})})):null}));function bV(e){return n.memo(e,qI)}let _V;const wV=["changeReason","unstable_updateValueOnRender"],kV=["column","rowId","editCellState","align","children","colIndex","height","width","className","showRightBorder","extendRowFullWidth","row","colSpan","disableDragEvents","isNotVisible","onClick","onDoubleClick","onMouseDown","onMouseUp","onMouseOver","onKeyDown","onKeyUp","onDragEnter","onDragOver","style"],SV=["changeReason","unstable_updateValueOnRender"],AV={id:-1,field:"__unset__",row:{},rowNode:{id:-1,depth:0,type:"leaf",parent:-1,groupingKey:null},colDef:{type:"string",field:"__unset__",computedWidth:0},cellMode:yz.View,hasFocus:!1,tabIndex:-1,value:null,formattedValue:"__unset__",isEditable:!1,api:{}},TV=e=>{const{align:t,showRightBorder:r,isEditable:n,isSelected:i,isSelectionMode:o,classes:a}=e,s={root:["cell",`cell--text${(0,MI.A)(t)}`,n&&"cell--editable",i&&"selected",r&&"cell--withRightBorder",o&&!n&&"cell--selectionMode","withBorderColor"],content:["cellContent"]};return(0,mn.A)(s,DI,a)};const MV=bV(n.forwardRef(((e,t)=>{const{column:r,rowId:i,editCellState:o}=e,a=xR(),s=tP(),l=r.field,c=KI(a,(()=>{try{const e=a.current.getCellParams(i,l);return e.api=a.current,e}catch(ene){if(ene instanceof Zj)return AV;throw ene}}),XI),u=KI(a,(()=>a.current.unstable_applyPipeProcessors("isCellSelected",!1,{id:i,field:l})));if(c===AV)return null;const{cellMode:d,hasFocus:h,isEditable:p,value:f,formattedValue:m}=c,g="actions"===r.type,y="view"!==d&&p||g?-1:c.tabIndex,{classes:v,getCellClassName:x}=s,b=a.current.unstable_applyPipeProcessors("cellClassName",[],{id:i,field:l});let _;if(r.cellClassName&&b.push("function"===typeof r.cellClassName?r.cellClassName(c):r.cellClassName),x&&b.push(x(c)),null==o&&r.renderCell&&(_=r.renderCell(c),b.push(zI["cell--withRenderer"]),b.push(null==v?void 0:v["cell--withRenderer"])),null!=o&&r.renderEditCell){const e=a.current.getRowWithUpdatedValues(i,r.field),t=(0,R.A)(o,wV),n=(0,O.A)({},c,{row:e},t);_=r.renderEditCell(n),b.push(zI["cell--editing"]),b.push(null==v?void 0:v["cell--editing"])}const{slots:w}=s,k=w.cell,S=(0,O.A)({},e,{ref:t,field:l,formattedValue:m,hasFocus:h,isEditable:p,isSelected:u,value:f,cellMode:d,children:_,tabIndex:y,className:(0,fn.A)(b)});return n.createElement(k,S)}))),CV=bV(n.forwardRef(((e,t)=>{var r,i,o,a;const{column:s,rowId:l,editCellState:c,align:u,colIndex:d,height:h,width:p,className:f,showRightBorder:m,colSpan:g,disableDragEvents:y,isNotVisible:v,onClick:x,onDoubleClick:b,onMouseDown:_,onMouseUp:w,onMouseOver:k,onKeyDown:S,onKeyUp:A,onDragEnter:T,onDragOver:M,style:C}=e,E=(0,R.A)(e,kV),I=xR(),P=tP(),L=s.field,D=KI(I,(()=>{try{const e=I.current.getCellParams(l,L);return e.api=I.current,e}catch(ene){if(ene instanceof Zj)return AV;throw ene}}),XI),z=KI(I,(()=>I.current.unstable_applyPipeProcessors("isCellSelected",!1,{id:l,field:L}))),{cellMode:F,hasFocus:N,isEditable:B,value:V,formattedValue:U}=D,H="actions"===s.type&&(null==(r=(i=s).getActions)?void 0:r.call(i,I.current.getRowParams(l)).some((e=>!e.props.disabled))),$="view"!==F&&B||H?-1:D.tabIndex,{classes:W,getCellClassName:q}=P,G=I.current.unstable_applyPipeProcessors("cellClassName",[],{id:l,field:L});s.cellClassName&&G.push("function"===typeof s.cellClassName?s.cellClassName(D):s.cellClassName),q&&G.push(q(D));const Y=null==U?V:U,X=n.useRef(null),Z=(0,Gi.A)(t,X),K=n.useRef(null),J=null!=(o=P.unstable_cellSelection)&&o,Q={align:u,showRightBorder:m,isEditable:B,classes:P.classes,isSelected:z,isSelectionMode:J},ee=TV(Q),te=n.useCallback((e=>t=>{const r=I.current.getCellParams(l,L||"");I.current.publishEvent(e,r,t),w&&w(t)}),[I,L,w,l]),re=n.useCallback((e=>t=>{const r=I.current.getCellParams(l,L||"");I.current.publishEvent(e,r,t),_&&_(t)}),[I,L,_,l]),ne=n.useCallback(((e,t)=>r=>{if(!I.current.getRow(l))return;const n=I.current.getCellParams(l,L||"");I.current.publishEvent(e,n,r),t&&t(r)}),[I,L,l]),ie=n.useMemo((()=>{if(v)return(0,O.A)({padding:0,opacity:0,width:0,border:0},C);return(0,O.A)({minWidth:p,maxWidth:p,minHeight:h,maxHeight:"auto"===h?"none":h},C)}),[p,h,v,C]);if(n.useEffect((()=>{if(!N||F===yz.Edit)return;const e=(0,No.A)(I.current.rootElementRef.current);if(X.current&&!X.current.contains(e.activeElement)){const e=X.current.querySelector('[tabindex="0"]'),t=K.current||e||X.current;if(void 0===_V&&document.createElement("div").focus({get preventScroll(){return _V=!0,!1}}),_V)t.focus({preventScroll:!0});else{const e=I.current.getScrollPosition();t.focus(),I.current.scroll(e)}}}),[N,F,I]),D===AV)return null;let oe,ae=E.onFocus;if(null==c&&s.renderCell&&(oe=s.renderCell(D),G.push(zI["cell--withRenderer"]),G.push(null==W?void 0:W["cell--withRenderer"])),null!=c&&s.renderEditCell){const e=I.current.getRowWithUpdatedValues(l,s.field),t=(0,R.A)(c,SV),r=(0,O.A)({},D,{row:e},t);oe=s.renderEditCell(r),G.push(zI["cell--editing"]),G.push(null==W?void 0:W["cell--editing"])}if(void 0===oe){const e=null==Y?void 0:Y.toString();oe=(0,j.jsx)("div",{className:ee.content,title:e,role:"presentation",children:e})}n.isValidElement(oe)&&H&&(oe=n.cloneElement(oe,{focusElementRef:K}));const se=y?null:{onDragEnter:ne("cellDragEnter",T),onDragOver:ne("cellDragOver",M)},le=null==(a=P.experimentalFeatures)?void 0:a.ariaV7;return(0,j.jsx)("div",(0,O.A)({ref:Z,className:(0,fn.A)(f,G,ee.root),role:le?"gridcell":"cell","data-field":L,"data-colindex":d,"aria-colindex":d+1,"aria-colspan":g,style:ie,tabIndex:$,onClick:ne("cellClick",x),onDoubleClick:ne("cellDoubleClick",b),onMouseOver:ne("cellMouseOver",k),onMouseDown:re("cellMouseDown"),onMouseUp:te("cellMouseUp"),onKeyDown:ne("cellKeyDown",S),onKeyUp:ne("cellKeyUp",A)},se,E,{onFocus:ae,children:oe}))}))),EV=["selected","hovered","rowId","row","index","style","position","rowHeight","className","visibleColumns","renderedColumns","containerWidth","firstColumnToRender","lastColumnToRender","isLastVisible","focusedCellColumnIndexNotInRange","isNotVisible","focusedCell","tabbableCell","onClick","onDoubleClick","onMouseEnter","onMouseLeave","onMouseOut","onMouseOver"];function IV(e){let{width:t}=e;if(!t)return null;const r={width:t};return(0,j.jsx)("div",{className:`${zI.cell} ${zI.withBorderColor}`,style:r})}const PV=bV(n.forwardRef((function(e,t){const{selected:r,hovered:i,rowId:o,row:a,index:s,style:l,position:c,rowHeight:u,className:d,visibleColumns:h,renderedColumns:p,containerWidth:f,firstColumnToRender:m,isLastVisible:g=!1,focusedCellColumnIndexNotInRange:y,isNotVisible:v,focusedCell:x,onClick:b,onDoubleClick:_,onMouseEnter:w,onMouseLeave:k,onMouseOut:S,onMouseOver:A}=e,T=(0,R.A)(e,EV),M=xR(),C=n.useRef(null),E=tP(),I=xj(M,E),P=KI(M,kP),L=KI(M,cO),D=KI(M,BP),z=KI(M,IP),F=KI(M,zj),N=(0,Gi.A)(C,t),B=s+z+2,V=(e=>{const{editable:t,editing:r,selected:n,isLastVisible:i,rowHeight:o,classes:a}=e,s={root:["row",n&&"selected",t&&"row--editable",r&&"row--editing",i&&"row--lastVisible","auto"===o&&"row--dynamicHeight"]};return(0,mn.A)(s,DI,a)})({selected:r,hovered:i,isLastVisible:g,classes:E.classes,editing:M.current.getRowMode(o)===vz.Edit,editable:E.editMode===gz.Row,rowHeight:u});n.useLayoutEffect((()=>{"auto"===u&&C.current&&"undefined"===typeof ResizeObserver&&M.current.unstable_storeRowHeightMeasurement(o,C.current.clientHeight,c)}),[M,u,o,c]),n.useLayoutEffect((()=>{if(I.range){const e=M.current.getRowIndexRelativeToVisibleRows(o);null!=e&&M.current.unstable_setLastMeasuredRowIndex(e)}const e=C.current;if(!e||"auto"!==u||"undefined"===typeof ResizeObserver)return;const t=new ResizeObserver((e=>{const[t]=e,r=t.borderBoxSize&&t.borderBoxSize.length>0?t.borderBoxSize[0].blockSize:t.contentRect.height;M.current.unstable_storeRowHeightMeasurement(o,r,c)}));return t.observe(e),()=>t.disconnect()}),[M,I.range,s,u,o,c]);const U=n.useCallback(((e,t)=>r=>{Cj(r)||M.current.getRow(o)&&(M.current.publishEvent(e,M.current.getRowParams(o),r),t&&t(r))}),[M,o]),H=n.useCallback((e=>{const t=Aj(e.target,zI.cell),r=null==t?void 0:t.getAttribute("data-field");if(r){if(r===VD.field)return;if(r===_j)return;if("__reorder__"===r)return;if(M.current.getCellMode(o,r)===yz.Edit)return;const e=M.current.getColumn(r);if((null==e?void 0:e.type)===Vz)return}U("rowClick",b)(e)}),[M,b,U,o]),{slots:$,slotProps:W,disableColumnReorder:q}=E,G=$.cell===CV?CV:MV,Y=E.rowReordering,X=(e,t)=>{var r,n;const i=q&&e.disableReorder||!Y&&!!L.length&&D>1&&Object.keys(F).length>0,a=null!=(r=null==(n=F[o])?void 0:n[e.field])?r:null;let s=!1;return void 0!==y&&h[y].field===e.field&&(s=!0),(0,j.jsx)(G,(0,O.A)({column:e,width:t.width,rowId:o,height:u,showRightBorder:t.showRightBorder,align:e.align||"left",colIndex:t.indexRelativeToAllColumns,colSpan:t.colSpan,disableDragEvents:i,editCellState:a,isNotVisible:s},null==W?void 0:W.cell),e.field)},Z=KI(M,(()=>(0,O.A)({},M.current.unstable_getRowInternalSizes(o))),XI);let K=u;if("auto"===K&&Z){let e=0;const t=Object.entries(Z).reduce(((t,r)=>{let[n,i]=r;return/^base[A-Z]/.test(n)?(e+=1,i>t?i:t):t}),0);t>0&&e>1&&(K=t)}const J=n.useMemo((()=>{if(v)return{opacity:0,width:0,height:0};const e=(0,O.A)({},l,{maxHeight:"auto"===u?"none":u,minHeight:K});if(null!=Z&&Z.spacingTop){e["border"===E.rowSpacingType?"borderTopWidth":"marginTop"]=Z.spacingTop}if(null!=Z&&Z.spacingBottom){const t="border"===E.rowSpacingType?"borderBottomWidth":"marginBottom";let r=e[t];"number"!==typeof r&&(r=parseInt(r||"0",10)),r+=Z.spacingBottom,e[t]=r}return e}),[v,u,l,K,Z,E.rowSpacingType]),Q=M.current.unstable_applyPipeProcessors("rowClassName",[],o);if("function"===typeof E.getRowClassName){var ee;const e=s-((null==(ee=I.range)?void 0:ee.firstRowIndex)||0),t=(0,O.A)({},M.current.getRowParams(o),{isFirstVisible:0===e,isLastVisible:e===I.rows.length-1,indexRelativeToCurrentPage:e});Q.push(E.getRowClassName(t))}const te=VO(1e4,20,80),re=M.current.getRowNode(o);if(!re)return null;const ne=re.type,ie=[];for(let n=0;n0&&(0,j.jsx)(IV,{width:oe})]}))})));function OV(e){var t;const{direction:r,index:n,sortingOrder:i}=e,o=xR(),a=tP(),s=(e=>{const{classes:t}=e;return(0,mn.A)({icon:["sortIcon"]},DI,t)})((0,O.A)({},e,{classes:a.classes})),l=function(e,t,r,n){let i;const o={};return"asc"===t?i=e.columnSortedAscendingIcon:"desc"===t?i=e.columnSortedDescendingIcon:(i=e.columnUnsortedIcon,o.sortingOrder=n),i?(0,j.jsx)(i,(0,O.A)({fontSize:"small",className:r},o)):null}(a.slots,r,s.icon,i);if(!l)return null;const c=(0,j.jsx)(a.slots.baseIconButton,(0,O.A)({tabIndex:-1,"aria-label":o.current.getLocaleText("columnHeaderSortIconLabel"),title:o.current.getLocaleText("columnHeaderSortIconLabel"),size:"small"},null==(t=a.slotProps)?void 0:t.baseIconButton,{children:l}));return(0,j.jsxs)(EF,{children:[null!=n&&(0,j.jsx)(TF,{badgeContent:n,color:"default",children:c}),null==n&&c]})}const RV=n.memo(OV),LV=n.memo((e=>{var t,r;const{colDef:i,open:o,columnMenuId:a,columnMenuButtonId:s,iconButtonRef:l}=e,c=xR(),u=tP(),d=(e=>{const{classes:t,open:r}=e,n={root:["menuIcon",r&&"menuOpen"],button:["menuIconButton"]};return(0,mn.A)(n,DI,t)})((0,O.A)({},e,{classes:u.classes})),h=n.useCallback((e=>{e.preventDefault(),e.stopPropagation(),c.current.toggleColumnMenu(i.field)}),[c,i.field]);return(0,j.jsx)("div",{className:d.root,children:(0,j.jsx)(u.slots.baseTooltip,(0,O.A)({title:c.current.getLocaleText("columnMenuLabel"),enterDelay:1e3},null==(t=u.slotProps)?void 0:t.baseTooltip,{children:(0,j.jsx)(u.slots.baseIconButton,(0,O.A)({ref:l,tabIndex:-1,className:d.button,"aria-label":c.current.getLocaleText("columnMenuLabel"),size:"small",onClick:h,"aria-haspopup":"menu","aria-expanded":o,"aria-controls":o?a:void 0,id:s},null==(r=u.slotProps)?void 0:r.baseIconButton,{children:(0,j.jsx)(u.slots.columnMenuIcon,{fontSize:"small"})}))}))})}));function DV(e){let{columnMenuId:t,columnMenuButtonId:r,ContentComponent:n,contentComponentProps:i,field:o,open:a,target:s,onExited:l}=e;const c=xR(),u=c.current.getColumn(o),d=(0,ea.A)((e=>{e&&(e.stopPropagation(),null!=s&&s.contains(e.target))||c.current.hideColumnMenu()}));return s&&u?(0,j.jsx)(Fz,{placement:"bottom-"+("right"===u.align?"start":"end"),open:a,target:s,onClose:d,onExited:l,children:(0,j.jsx)(n,(0,O.A)({colDef:u,hideMenu:d,open:a,id:t,labelledby:r},i))}):null}const zV=["className"],jV=nO("div",{name:"MuiDataGrid",slot:"ColumnHeaderTitle",overridesResolver:(e,t)=>t.columnHeaderTitle})({textOverflow:"ellipsis",overflow:"hidden",whiteSpace:"nowrap",fontWeight:"var(--unstable_DataGrid-headWeight)"}),FV=n.forwardRef((function(e,t){const{className:r}=e,n=(0,R.A)(e,zV),i=tP(),o=(e=>{const{classes:t}=e;return(0,mn.A)({root:["columnHeaderTitle"]},DI,t)})(i);return(0,j.jsx)(jV,(0,O.A)({ref:t,className:(0,fn.A)(o.root,r),ownerState:i},n))}));function NV(e){var t;const{label:r,description:i}=e,o=tP(),a=n.useRef(null),[s,l]=n.useState(""),c=n.useCallback((()=>{if(!i&&null!=a&&a.current){const t=(e=a.current).scrollHeight>e.clientHeight||e.scrollWidth>e.clientWidth;l(t?r:"")}var e}),[i,r]);return(0,j.jsx)(o.slots.baseTooltip,(0,O.A)({title:i||s},null==(t=o.slotProps)?void 0:t.baseTooltip,{children:(0,j.jsx)(FV,{onMouseOver:c,ref:a,children:r})}))}const BV=["resizable","resizing","height","side"];var VV=function(e){return e.Left="left",e.Right="right",e}(VV||{});function UV(e){const{height:t,side:r=VV.Right}=e,i=(0,R.A)(e,BV),o=tP(),a=(e=>{const{resizable:t,resizing:r,classes:n,side:i}=e,o={root:["columnSeparator",t&&"columnSeparator--resizable",r&&"columnSeparator--resizing",i&&`columnSeparator--side${(0,MI.A)(i)}`],icon:["iconSeparator"]};return(0,mn.A)(o,DI,n)})((0,O.A)({},e,{side:r,classes:o.classes})),s=n.useCallback((e=>{e.preventDefault(),e.stopPropagation()}),[]);return(0,j.jsx)("div",(0,O.A)({className:a.root,style:{minHeight:t,opacity:o.showColumnVerticalBorder?0:1}},i,{onClick:s,children:(0,j.jsx)(o.slots.columnResizeIcon,{className:a.icon})}))}const HV=n.memo(UV),$V=["classes","columnMenuOpen","colIndex","height","isResizing","sortDirection","hasFocus","tabIndex","separatorSide","isDraggable","headerComponent","description","elementId","width","columnMenuIconButton","columnMenu","columnTitleIconButtons","headerClassName","label","resizable","draggableContainerProps","columnHeaderSeparatorProps"],WV=n.forwardRef((function(e,t){const{classes:r,columnMenuOpen:i,colIndex:o,height:a,isResizing:s,sortDirection:l,hasFocus:c,tabIndex:u,separatorSide:d,isDraggable:h,headerComponent:p,description:f,width:m,columnMenuIconButton:g=null,columnMenu:y=null,columnTitleIconButtons:v=null,headerClassName:x,label:b,resizable:_,draggableContainerProps:w,columnHeaderSeparatorProps:k}=e,S=(0,R.A)(e,$V),A=QI(),T=tP(),M=n.useRef(null),[C,E]=n.useState(i),I=(0,Gi.A)(M,t);let P="none";return null!=l&&(P="asc"===l?"ascending":"descending"),n.useEffect((()=>{C||E(i)}),[C,i]),n.useLayoutEffect((()=>{const e=A.current.state.columnMenu;if(c&&!e.open){const e=M.current.querySelector('[tabindex="0"]')||M.current;null==e||e.focus(),A.current.columnHeadersContainerElementRef.current.scrollLeft=0}}),[A,c]),(0,j.jsxs)("div",(0,O.A)({ref:I,className:(0,fn.A)(r.root,x),style:{height:a,width:m,minWidth:m,maxWidth:m},role:"columnheader",tabIndex:u,"aria-colindex":o+1,"aria-sort":P,"aria-label":null==p?b:void 0},S,{children:[(0,j.jsxs)("div",(0,O.A)({className:r.draggableContainer,draggable:h,role:"presentation"},w,{children:[(0,j.jsxs)("div",{className:r.titleContainer,role:"presentation",children:[(0,j.jsx)("div",{className:r.titleContainerContent,children:void 0!==p?p:(0,j.jsx)(NV,{label:b,description:f,columnWidth:m})}),v]}),g]})),(0,j.jsx)(HV,(0,O.A)({resizable:!T.disableColumnResize&&!!_,resizing:s,height:a,side:d},k)),y]}))}));function qV(e){var t,r,i,o;const{colDef:a,columnMenuOpen:s,colIndex:l,headerHeight:c,isResizing:u,sortDirection:d,sortIndex:h,filterItemsCounter:p,hasFocus:f,tabIndex:m,disableReorder:g,separatorSide:y}=e,v=QI(),x=tP(),b=n.useRef(null),_=(0,zp.A)(),w=(0,zp.A)(),k=n.useRef(null),[S,A]=n.useState(s),T=n.useMemo((()=>!x.disableColumnReorder&&!g&&!a.disableReorder),[x.disableColumnReorder,g,a.disableReorder]);let M;a.renderHeader&&(M=a.renderHeader(v.current.getColumnHeaderParams(a.field)));const C=(e=>{const{colDef:t,classes:r,isDragging:n,sortDirection:i,showRightBorder:o,filterItemsCounter:a}=e,s=null!=i,l=null!=a&&a>0,c="number"===t.type,u={root:["columnHeader","left"===t.headerAlign&&"columnHeader--alignLeft","center"===t.headerAlign&&"columnHeader--alignCenter","right"===t.headerAlign&&"columnHeader--alignRight",t.sortable&&"columnHeader--sortable",n&&"columnHeader--moving",s&&"columnHeader--sorted",l&&"columnHeader--filtered",c&&"columnHeader--numeric","withBorderColor",o&&"columnHeader--withRightBorder"],draggableContainer:["columnHeaderDraggableContainer"],titleContainer:["columnHeaderTitleContainer"],titleContainerContent:["columnHeaderTitleContainerContent"]};return(0,mn.A)(u,DI,r)})((0,O.A)({},e,{classes:x.classes,showRightBorder:x.showColumnVerticalBorder})),E=n.useCallback((e=>t=>{Cj(t)||v.current.publishEvent(e,v.current.getColumnHeaderParams(a.field),t)}),[v,a.field]),I=n.useMemo((()=>({onClick:E("columnHeaderClick"),onDoubleClick:E("columnHeaderDoubleClick"),onMouseOver:E("columnHeaderOver"),onMouseOut:E("columnHeaderOut"),onMouseEnter:E("columnHeaderEnter"),onMouseLeave:E("columnHeaderLeave"),onKeyDown:E("columnHeaderKeyDown"),onFocus:E("columnHeaderFocus"),onBlur:E("columnHeaderBlur")})),[E]),P=n.useMemo((()=>T?{onDragStart:E("columnHeaderDragStart"),onDragEnter:E("columnHeaderDragEnter"),onDragOver:E("columnHeaderDragOver"),onDragEnd:E("columnHeaderDragEnd")}:{}),[T,E]),R=n.useMemo((()=>({onMouseDown:E("columnSeparatorMouseDown"),onDoubleClick:E("columnSeparatorDoubleClick")})),[E]);n.useEffect((()=>{S||A(s)}),[S,s]);const L=n.useCallback((()=>{A(!1)}),[]),D=!x.disableColumnMenu&&!a.disableColumnMenu&&(0,j.jsx)(LV,{colDef:a,columnMenuId:_,columnMenuButtonId:w,open:S,iconButtonRef:k}),z=(0,j.jsx)(DV,{columnMenuId:_,columnMenuButtonId:w,field:a.field,open:s,target:k.current,ContentComponent:x.slots.columnMenu,contentComponentProps:null==(t=x.slotProps)?void 0:t.columnMenu,onExited:L}),F=null!=(r=a.sortingOrder)?r:x.sortingOrder,N=(0,j.jsxs)(n.Fragment,{children:[!x.disableColumnFilter&&(0,j.jsx)(x.slots.columnHeaderFilterIconButton,(0,O.A)({field:a.field,counter:p},null==(i=x.slotProps)?void 0:i.columnHeaderFilterIconButton)),a.sortable&&!a.hideSortIcons&&(0,j.jsx)(RV,{direction:d,index:h,sortingOrder:F})]});n.useLayoutEffect((()=>{const e=v.current.state.columnMenu;if(f&&!e.open){var t;const e=b.current.querySelector('[tabindex="0"]')||b.current;null==e||e.focus(),null!=(t=v.current.columnHeadersContainerElementRef)&&t.current&&(v.current.columnHeadersContainerElementRef.current.scrollLeft=0)}}),[v,f]);const B="function"===typeof a.headerClassName?a.headerClassName({field:a.field,colDef:a}):a.headerClassName,V=null!=(o=a.headerName)?o:a.field;return(0,j.jsx)(WV,(0,O.A)({ref:b,classes:C,columnMenuOpen:s,colIndex:l,height:c,isResizing:u,sortDirection:d,hasFocus:f,tabIndex:m,separatorSide:y,isDraggable:T,headerComponent:M,description:a.description,elementId:a.field,width:a.computedWidth,columnMenuIconButton:D,columnTitleIconButtons:N,headerClassName:B,label:V,resizable:!x.disableColumnResize&&!!a.resizable,"data-field":a.field,columnMenu:z,draggableContainerProps:P,columnHeaderSeparatorProps:R},I))}const GV=e=>e.virtualization,YV=uP(GV,(e=>e.enabled)),XV=uP(GV,(e=>e.enabledForColumns)),ZV=["style"],KV=["style"];function JV(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:t.length;if(t.length<=0)return-1;if(r>=n)return r;const i=r+Math.floor((n-r)/2);return e<=t[i]?JV(e,t,r,i):JV(e,t,i+1,n)}const QV=e=>{let{firstIndex:t,lastIndex:r,buffer:n,minFirstIndex:i,maxLastIndex:o}=e;return[NO(t-n,i,o),NO(r+n,i,o)]},eU=(e,t)=>e===t||e.firstRowIndex===t.firstRowIndex&&e.lastRowIndex===t.lastRowIndex&&e.firstColumnIndex===t.firstColumnIndex&&e.lastColumnIndex===t.lastColumnIndex,tU={maxSize:3};function rU(e,t,r,n){var i,o;const a=e.current.getLastMeasuredRowIndex();let s=a===1/0;null!=(i=t.range)&&i.lastRowIndex&&!s&&(s=a>=t.range.lastRowIndex);const l=NO(a-((null==(o=t.range)?void 0:o.firstRowIndex)||0),0,r.positions.length);return s||r.positions[l]>=n?JV(n,r.positions):function(e,t,r){let n=1;for(;r({groupId:r,headerName:v,description:x,depth:o,maxDepth:a,fields:s,colIndex:c,isLastColumn:h})),[r,v,x,o,a,s,c,h]);r&&w&&(_=w(k));const S=p.showColumnVerticalBorder,A=(0,O.A)({},e,{classes:p.classes,showColumnBorder:S,headerAlign:b,depth:o,isDragging:!1}),T=null!=v?v:r,M=(0,zp.A)(),C=null===r?`empty-group-cell-${M}`:r,E=(e=>{const{classes:t,headerAlign:r,isDragging:n,showColumnBorder:i,groupId:o}=e,a={root:["columnHeader","left"===r&&"columnHeader--alignLeft","center"===r&&"columnHeader--alignCenter","right"===r&&"columnHeader--alignRight",n&&"columnHeader--moving",i&&"columnHeader--showColumnBorder",i&&"columnHeader--withRightBorder","withBorderColor",null===o?"columnHeader--emptyGroup":"columnHeader--filledGroup"],draggableContainer:["columnHeaderDraggableContainer"],titleContainer:["columnHeaderTitleContainer","withBorderColor"],titleContainerContent:["columnHeaderTitleContainerContent"]};return(0,mn.A)(a,DI,t)})(A);n.useLayoutEffect((()=>{if(u){const e=f.current.querySelector('[tabindex="0"]')||f.current;null==e||e.focus()}}),[m,u]);const I=n.useCallback((e=>t=>{Cj(t)||m.current.publishEvent(e,k,t)}),[m,k]),P=n.useMemo((()=>({onKeyDown:I("columnGroupHeaderKeyDown"),onFocus:I("columnGroupHeaderFocus"),onBlur:I("columnGroupHeaderBlur")})),[I]),R="function"===typeof y.headerClassName?y.headerClassName(k):y.headerClassName;return(0,j.jsx)(WV,(0,O.A)({ref:f,classes:E,columnMenuOpen:!1,colIndex:c,height:l,isResizing:!1,sortDirection:null,hasFocus:!1,tabIndex:d,isDraggable:!1,headerComponent:_,headerClassName:R,description:x,elementId:C,width:i,columnMenuIconButton:null,columnTitleIconButtons:null,resizable:!1,label:T,"aria-colspan":s.length,"data-fields":`|-${s.join("-|-")}-|`},P))}const iU=(0,yn.Ay)("div",{name:"MuiDataGrid",slot:"ColumnHeaderRow",overridesResolver:(e,t)=>t.columnHeaderRow})((()=>({display:"flex"})));const oU=["className"],aU=nO("div",{name:"MuiDataGrid",slot:"ColumnHeaders",overridesResolver:(e,t)=>t.columnHeaders})({position:"relative",overflow:"hidden",display:"flex",alignItems:"center",boxSizing:"border-box",borderBottom:"1px solid",borderTopLeftRadius:"var(--unstable_DataGrid-radius)",borderTopRightRadius:"var(--unstable_DataGrid-radius)"}),sU=n.forwardRef((function(e,t){const{className:r}=e,n=(0,R.A)(e,oU),i=tP(),o=(e=>{const{classes:t}=e;return(0,mn.A)({root:["columnHeaders","withBorderColor"]},DI,t)})(i);return(0,j.jsx)(aU,(0,O.A)({ref:t,className:(0,fn.A)(r,o.root),ownerState:i},n,{role:"presentation"}))})),lU=["isDragging","className"],cU=nO("div",{name:"MuiDataGrid",slot:"columnHeadersInner",overridesResolver:(e,t)=>[{[`&.${zI.columnHeaderDropZone}`]:t.columnHeaderDropZone},t.columnHeadersInner]})((()=>({display:"flex",alignItems:"flex-start",flexDirection:"column",[`&.${zI.columnHeaderDropZone} .${zI.columnHeaderDraggableContainer}`]:{cursor:"move"},[`&.${zI["columnHeadersInner--scrollable"]} .${zI.columnHeader}:last-child`]:{borderRight:"none"}}))),uU=n.forwardRef((function(e,t){var r,n;const{isDragging:i,className:o}=e,a=(0,R.A)(e,lU),s=xR(),l=tP(),c=(0,O.A)({},l,{isDragging:i,hasScrollX:null!=(r=null==(n=s.current.getRootDimensions())?void 0:n.hasScrollX)&&r}),u=(e=>{const{isDragging:t,hasScrollX:r,classes:n}=e,i={root:["columnHeadersInner",t&&"columnHeaderDropZone",r&&"columnHeadersInner--scrollable"]};return(0,mn.A)(i,DI,n)})(c);return(0,j.jsx)(cU,(0,O.A)({ref:t,className:(0,fn.A)(o,u.root),ownerState:c},a))})),dU=["innerRef","className","visibleColumns","sortColumnLookup","filterColumnLookup","columnPositions","columnHeaderTabIndexState","columnGroupHeaderTabIndexState","columnHeaderFocus","columnGroupHeaderFocus","densityFactor","headerGroupingMaxDepth","columnMenuState","columnVisibility","columnGroupsHeaderStructure","hasOtherElementInTabSequence"],hU=bV(n.forwardRef((function(e,t){const{innerRef:r,visibleColumns:i,sortColumnLookup:o,filterColumnLookup:a,columnPositions:l,columnHeaderTabIndexState:c,columnGroupHeaderTabIndexState:u,columnHeaderFocus:d,columnGroupHeaderFocus:h,densityFactor:p,headerGroupingMaxDepth:f,columnMenuState:m,columnVisibility:g,columnGroupsHeaderStructure:y,hasOtherElementInTabSequence:v}=e,x=(0,R.A)(e,dU),{isDragging:b,getRootProps:_,getInnerProps:w,getColumnHeaders:k,getColumnGroupHeaders:S}=(e=>{const{innerRef:t,minColumnIndex:r=0,visibleColumns:i,sortColumnLookup:o,filterColumnLookup:a,columnPositions:l,columnHeaderTabIndexState:c,columnGroupHeaderTabIndexState:u,columnHeaderFocus:d,columnGroupHeaderFocus:h,densityFactor:p,headerGroupingMaxDepth:f,columnMenuState:m,columnVisibility:g,columnGroupsHeaderStructure:y,hasOtherElementInTabSequence:v}=e,x=Io(),[b,_]=n.useState(""),[w,k]=n.useState(""),S=QI(),A=KI(S,XV),T=tP(),M=n.useRef(null),C=(0,Gi.A)(t,M),[E,I]=n.useState(null),P=n.useRef(E),R=n.useRef(0),L=xj(S,T),D=Kz(S,T.columnHeaderHeight),z=Math.floor(T.columnHeaderHeight*p),F=n.useCallback((e=>{E&&e&&eU(E,e)||I(e)}),[E]);n.useEffect((()=>{var e;null!=(e=S.current.columnHeadersContainerElementRef)&&e.current&&(S.current.columnHeadersContainerElementRef.current.scrollLeft=0)}),[S]);const N=n.useRef(iP(Zz,{equalityCheck:(e,t)=>["firstColumnIndex","minColumnIndex","columnBuffer"].every((r=>e[r]===t[r]))})),B=n.useCallback((e=>{const[t,n]=QV({firstIndex:e.firstRowIndex,lastIndex:e.lastRowIndex,minFirstIndex:0,maxLastIndex:L.rows.length,buffer:T.rowBuffer}),i=N.current({firstColumnIndex:e.firstColumnIndex,minColumnIndex:r,columnBuffer:T.columnBuffer,firstRowToRender:t,lastRowToRender:n,apiRef:S,visibleRows:L.rows}),o="ltr"===x.direction?1:-1,a=i>0?R.current-o*l[i]:R.current;M.current.style.transform=`translate3d(${-a}px, 0px, 0px)`}),[l,r,T.columnBuffer,S,L.rows,T.rowBuffer,x.direction]);n.useLayoutEffect((()=>{E&&B(E)}),[E,B]);const V=n.useCallback(((e,t)=>{let{left:r,renderContext:n=null}=e;var i,o;if(!M.current)return;if(R.current===r&&(null==(i=P.current)?void 0:i.firstColumnIndex)===(null==n?void 0:n.firstColumnIndex)&&(null==(o=P.current)?void 0:o.lastColumnIndex)===(null==n?void 0:n.lastColumnIndex))return;R.current=r;let a=!1;n===P.current&&P.current?a=!0:(function(e){return!!e.target}(t)?(s.flushSync((()=>{F(n)})),a=!0):F(n),P.current=n),n&&a&&B(n)}),[B,F]),U=n.useCallback((e=>k(e.field)),[]),H=n.useCallback((()=>k("")),[]),$=n.useCallback((e=>_(e.field)),[]),W=n.useCallback((()=>_("")),[]);tR(S,"columnResizeStart",U),tR(S,"columnResizeStop",H),tR(S,"columnHeaderDragStart",$),tR(S,"columnHeaderDragEnd",W),tR(S,"scrollPositionChange",V);const q=e=>{const{renderContext:t=E,minFirstColumn:n=r,maxLastColumn:o=i.length}=e||{};if(!t)return null;const[a,s]=QV({firstIndex:t.firstRowIndex,lastIndex:t.lastRowIndex,minFirstIndex:0,maxLastIndex:L.rows.length,buffer:T.rowBuffer}),l=A?N.current({firstColumnIndex:t.firstColumnIndex,minColumnIndex:n,columnBuffer:T.columnBuffer,apiRef:S,firstRowToRender:a,lastRowToRender:s,visibleRows:L.rows}):0,c=A?Math.min(t.lastColumnIndex+T.columnBuffer,o):o;return{renderedColumns:i.slice(l,c),firstColumnToRender:l,lastColumnToRender:c,minFirstColumn:n,maxLastColumn:o}},G={minHeight:D,maxHeight:D,lineHeight:`${z}px`};return{renderContext:E,getColumnHeaders:function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const r=q(e);if(null==r)return null;const{renderedColumns:n,firstColumnToRender:i}=r,s=[];for(let l=0;l{if(0===f)return null;const t=q(e);if(null==t||0===t.renderedColumns.length)return null;const{firstColumnToRender:r,lastColumnToRender:n}=t,o=[],a=[];for(let c=0;c{let{groupId:r,columnFields:n}=e;return r===o&&n.includes(t)})),p=i[n-1].field,f=null!=(l=S.current.unstable_getColumnGroupPath(p)[c])?l:null,m=e.findIndex((e=>{let{groupId:t,columnFields:r}=e;return t===f&&r.includes(p)})),v=e.slice(d,m+1).map((e=>(0,O.A)({},e,{columnFields:e.columnFields.filter((e=>!1!==g[e]))}))).filter((e=>e.columnFields.length>0)),x=v[0].columnFields.indexOf(t),b=v[0].columnFields.slice(0,x).reduce(((e,t)=>{var r;return e+(null!=(r=S.current.getColumn(t).computedWidth)?r:0)}),0);let _=r;const w=v.map((e=>{let{groupId:t,columnFields:r}=e;const n=null!==h&&h.depth===c&&r.includes(h.field),i=null!==u&&u.depth===c&&r.includes(u.field)?0:-1,o={groupId:t,width:r.reduce(((e,t)=>e+S.current.getColumn(t).computedWidth),0),fields:r,colIndex:_,hasFocus:n,tabIndex:i};return _+=r.length,o}));a.push({leftOverflow:b,elements:w})}return a.forEach(((e,t)=>{o.push((0,j.jsx)(iU,{style:{height:`${z}px`,transform:`translateX(-${e.leftOverflow}px)`},role:"row","aria-rowindex":t+1,ownerState:T,children:e.elements.map(((e,r)=>{let{groupId:n,width:o,fields:s,colIndex:l,hasFocus:c,tabIndex:u}=e;return(0,j.jsx)(nU,{groupId:n,width:o,fields:s,colIndex:l,depth:t,isLastColumn:l===i.length-s.length,maxDepth:a.length,height:z,hasFocus:c,tabIndex:u},r)}))},t))})),o},isDragging:!!b,getRootProps:function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return(0,O.A)({style:G},e)},getInnerProps:()=>({ref:C,role:"rowgroup"}),headerHeight:z}})({innerRef:r,visibleColumns:i,sortColumnLookup:o,filterColumnLookup:a,columnPositions:l,columnHeaderTabIndexState:c,columnGroupHeaderTabIndexState:u,columnHeaderFocus:d,columnGroupHeaderFocus:h,densityFactor:p,headerGroupingMaxDepth:f,columnMenuState:m,columnVisibility:g,columnGroupsHeaderStructure:y,hasOtherElementInTabSequence:v});return(0,j.jsx)(sU,(0,O.A)({ref:t},_(x),{children:(0,j.jsxs)(uU,(0,O.A)({isDragging:b},w(),{children:[S(),k()]}))}))}))),pU=["absolute","children","className","component","flexItem","light","orientation","role","textAlign","variant"],fU=(0,yn.Ay)("div",{name:"MuiDivider",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.absolute&&t.absolute,t[r.variant],r.light&&t.light,"vertical"===r.orientation&&t.vertical,r.flexItem&&t.flexItem,r.children&&t.withChildren,r.children&&"vertical"===r.orientation&&t.withChildrenVertical,"right"===r.textAlign&&"vertical"!==r.orientation&&t.textAlignRight,"left"===r.textAlign&&"vertical"!==r.orientation&&t.textAlignLeft]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({margin:0,flexShrink:0,borderWidth:0,borderStyle:"solid",borderColor:(t.vars||t).palette.divider,borderBottomWidth:"thin"},r.absolute&&{position:"absolute",bottom:0,left:0,width:"100%"},r.light&&{borderColor:t.vars?`rgba(${t.vars.palette.dividerChannel} / 0.08)`:(0,gn.X4)(t.palette.divider,.08)},"inset"===r.variant&&{marginLeft:72},"middle"===r.variant&&"horizontal"===r.orientation&&{marginLeft:t.spacing(2),marginRight:t.spacing(2)},"middle"===r.variant&&"vertical"===r.orientation&&{marginTop:t.spacing(1),marginBottom:t.spacing(1)},"vertical"===r.orientation&&{height:"100%",borderBottomWidth:0,borderRightWidth:"thin"},r.flexItem&&{alignSelf:"stretch",height:"auto"})}),(e=>{let{ownerState:t}=e;return(0,O.A)({},t.children&&{display:"flex",whiteSpace:"nowrap",textAlign:"center",border:0,borderTopStyle:"solid",borderLeftStyle:"solid","&::before, &::after":{content:'""',alignSelf:"center"}})}),(e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({},r.children&&"vertical"!==r.orientation&&{"&::before, &::after":{width:"100%",borderTop:`thin solid ${(t.vars||t).palette.divider}`,borderTopStyle:"inherit"}})}),(e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({},r.children&&"vertical"===r.orientation&&{flexDirection:"column","&::before, &::after":{height:"100%",borderLeft:`thin solid ${(t.vars||t).palette.divider}`,borderLeftStyle:"inherit"}})}),(e=>{let{ownerState:t}=e;return(0,O.A)({},"right"===t.textAlign&&"vertical"!==t.orientation&&{"&::before":{width:"90%"},"&::after":{width:"10%"}},"left"===t.textAlign&&"vertical"!==t.orientation&&{"&::before":{width:"10%"},"&::after":{width:"90%"}})})),mU=(0,yn.Ay)("span",{name:"MuiDivider",slot:"Wrapper",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.wrapper,"vertical"===r.orientation&&t.wrapperVertical]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({display:"inline-block",paddingLeft:`calc(${t.spacing(1)} * 1.2)`,paddingRight:`calc(${t.spacing(1)} * 1.2)`},"vertical"===r.orientation&&{paddingTop:`calc(${t.spacing(1)} * 1.2)`,paddingBottom:`calc(${t.spacing(1)} * 1.2)`})})),gU=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiDivider"}),{absolute:n=!1,children:i,className:o,component:a=(i?"div":"hr"),flexItem:s=!1,light:l=!1,orientation:c="horizontal",role:u=("hr"!==a?"separator":void 0),textAlign:d="center",variant:h="fullWidth"}=r,p=(0,R.A)(r,pU),f=(0,O.A)({},r,{absolute:n,component:a,flexItem:s,light:l,orientation:c,role:u,textAlign:d,variant:h}),m=(e=>{const{absolute:t,children:r,classes:n,flexItem:i,light:o,orientation:a,textAlign:s,variant:l}=e,c={root:["root",t&&"absolute",l,o&&"light","vertical"===a&&"vertical",i&&"flexItem",r&&"withChildren",r&&"vertical"===a&&"withChildrenVertical","right"===s&&"vertical"!==a&&"textAlignRight","left"===s&&"vertical"!==a&&"textAlignLeft"],wrapper:["wrapper","vertical"===a&&"wrapperVertical"]};return(0,mn.A)(c,za,n)})(f);return(0,j.jsx)(fU,(0,O.A)({as:a,className:(0,fn.A)(m.root,o),role:u,ref:t,ownerState:f},p,{children:i?(0,j.jsx)(mU,{className:m.wrapper,ownerState:f,children:i}):null}))}));gU.muiSkipListHighlight=!0;const yU=gU,vU=["displayOrder"],xU=["hideMenu","colDef","id","labelledby","className","children","open"],bU=(0,yn.Ay)(yo)((()=>({minWidth:248}))),_U=n.forwardRef((function(e,t){const{hideMenu:r,id:i,labelledby:o,className:a,children:s,open:l}=e,c=(0,R.A)(e,xU),u=n.useCallback((e=>{var t;mR(e.key)&&e.preventDefault(),t=e.key,(mR(t)||pR(t))&&r(e)}),[r]);return(0,j.jsx)(bU,(0,O.A)({id:i,ref:t,className:(0,fn.A)(zI.menuList,a),"aria-labelledby":o,onKeyDown:u,autoFocus:l},c,{children:s}))}));function wU(e){const{colDef:t,onClick:r}=e,i=xR(),o=tP(),a=1===bP(i).filter((e=>!0!==e.disableColumnMenu)).length,s=n.useCallback((e=>{a||(i.current.setColumnVisibility(t.field,!1),r(e))}),[i,t.field,r,a]);return o.disableColumnSelector||!1===t.hideable?null:(0,j.jsxs)(qa,{onClick:s,disabled:a,children:[(0,j.jsx)(Ip,{children:(0,j.jsx)(o.slots.columnMenuHideIcon,{fontSize:"small"})}),(0,j.jsx)(Rp,{children:i.current.getLocaleText("columnMenuHideColumn")})]})}function kU(e){const{onClick:t}=e,r=xR(),i=tP(),o=n.useCallback((e=>{t(e),r.current.showPreferences(Jz.columns)}),[r,t]);return i.disableColumnSelector?null:(0,j.jsxs)(qa,{onClick:o,children:[(0,j.jsx)(Ip,{children:(0,j.jsx)(i.slots.columnMenuManageColumnsIcon,{fontSize:"small"})}),(0,j.jsx)(Rp,{children:r.current.getLocaleText("columnMenuManageColumns")})]})}const SU=["defaultSlots","defaultSlotProps","slots","slotProps"],AU={columnMenuSortItem:function(e){var t;const{colDef:r,onClick:i}=e,o=xR(),a=KI(o,cO),s=tP(),l=n.useMemo((()=>{if(!r)return null;const e=a.find((e=>e.field===r.field));return null==e?void 0:e.sort}),[r,a]),c=null!=(t=r.sortingOrder)?t:s.sortingOrder,u=n.useCallback((e=>{i(e);const t=e.currentTarget.getAttribute("data-value")||null;o.current.sortColumn(r,t===l?null:t)}),[o,r,i,l]);if(!r||!r.sortable||!c.some((e=>!!e)))return null;const d=e=>{const t=o.current.getLocaleText(e);return"function"===typeof t?t(r):t};return(0,j.jsxs)(n.Fragment,{children:[c.includes("asc")&&"asc"!==l?(0,j.jsxs)(qa,{onClick:u,"data-value":"asc",children:[(0,j.jsx)(Ip,{children:(0,j.jsx)(s.slots.columnMenuSortAscendingIcon,{fontSize:"small"})}),(0,j.jsx)(Rp,{children:d("columnMenuSortAsc")})]}):null,c.includes("desc")&&"desc"!==l?(0,j.jsxs)(qa,{onClick:u,"data-value":"desc",children:[(0,j.jsx)(Ip,{children:(0,j.jsx)(s.slots.columnMenuSortDescendingIcon,{fontSize:"small"})}),(0,j.jsx)(Rp,{children:d("columnMenuSortDesc")})]}):null,c.includes(null)&&null!=l?(0,j.jsxs)(qa,{onClick:u,children:[(0,j.jsx)(Ip,{}),(0,j.jsx)(Rp,{children:o.current.getLocaleText("columnMenuUnsort")})]}):null]})},columnMenuFilterItem:function(e){const{colDef:t,onClick:r}=e,i=xR(),o=tP(),a=n.useCallback((e=>{r(e),i.current.showFilterPanel(t.field)}),[i,t.field,r]);return o.disableColumnFilter||!t.filterable?null:(0,j.jsxs)(qa,{onClick:a,children:[(0,j.jsx)(Ip,{children:(0,j.jsx)(o.slots.columnMenuFilterIcon,{fontSize:"small"})}),(0,j.jsx)(Rp,{children:i.current.getLocaleText("columnMenuFilter")})]})},columnMenuColumnsItem:function(e){return(0,j.jsxs)(n.Fragment,{children:[(0,j.jsx)(wU,(0,O.A)({},e)),(0,j.jsx)(kU,(0,O.A)({},e))]})}},TU={columnMenuSortItem:{displayOrder:10},columnMenuFilterItem:{displayOrder:20},columnMenuColumnsItem:{displayOrder:30}},MU=n.forwardRef((function(e,t){const{defaultSlots:r,defaultSlotProps:i,slots:o,slotProps:a}=e,s=(0,R.A)(e,SU),l=(e=>{const t=QI(),{defaultSlots:r,defaultSlotProps:i,slots:o={},slotProps:a={},hideMenu:s,colDef:l,addDividers:c=!0}=e,u=n.useMemo((()=>(0,O.A)({},r,o)),[r,o]),d=n.useMemo((()=>{if(!a||0===Object.keys(a).length)return i;const e=(0,O.A)({},a);return Object.entries(i).forEach((t=>{let[r,n]=t;e[r]=(0,O.A)({},n,a[r]||{})})),e}),[i,a]),h=t.current.unstable_applyPipeProcessors("columnMenu",[],e.colDef),p=n.useMemo((()=>{const e=Object.keys(r);return Object.keys(o).filter((t=>!e.includes(t)))}),[o,r]);return n.useMemo((()=>{const e=Array.from(new Set([...h,...p])).filter((e=>null!=u[e])).sort(((e,t)=>{const r=d[e],n=d[t];return(Number.isFinite(null==r?void 0:r.displayOrder)?r.displayOrder:100)-(Number.isFinite(null==n?void 0:n.displayOrder)?n.displayOrder:100)}));return e.reduce(((t,r,n)=>{let i={colDef:l,onClick:s};const o=d[r];if(o){const e=(0,R.A)(o,vU);i=(0,O.A)({},i,e)}return c&&n!==e.length-1?[...t,[u[r],i],[yU,{}]]:[...t,[u[r],i]]}),[])}),[c,l,h,s,u,d,p])})((0,O.A)({},s,{defaultSlots:r,defaultSlotProps:i,slots:o,slotProps:a}));return(0,j.jsx)(_U,(0,O.A)({ref:t},s,{children:l.map(((e,t)=>{let[r,n]=e;return(0,j.jsx)(r,(0,O.A)({},n),t)}))}))})),CU=n.forwardRef((function(e,t){return(0,j.jsx)(MU,(0,O.A)({},e,{ref:t,defaultSlots:AU,defaultSlotProps:TU}))})),EU=n.forwardRef((function(e,t){const r=xR().current.getLocaleText("noResultsOverlayLabel");return(0,j.jsx)(nN,(0,O.A)({ref:t},e,{children:r}))}));function IU(e){return(0,Yn.Ay)("PrivateSwitchBase",e)}(0,Ln.A)("PrivateSwitchBase",["root","checked","disabled","input","edgeStart","edgeEnd"]);const PU=["autoFocus","checked","checkedIcon","className","defaultChecked","disabled","disableFocusRipple","edge","icon","id","inputProps","inputRef","name","onBlur","onChange","onFocus","readOnly","required","tabIndex","type","value"],OU=(0,yn.Ay)(Qn)((e=>{let{ownerState:t}=e;return(0,O.A)({padding:9,borderRadius:"50%"},"start"===t.edge&&{marginLeft:"small"===t.size?-3:-12},"end"===t.edge&&{marginRight:"small"===t.size?-3:-12})})),RU=(0,yn.Ay)("input",{shouldForwardProp:Ta.A})({cursor:"inherit",position:"absolute",opacity:0,width:"100%",height:"100%",top:0,left:0,margin:0,padding:0,zIndex:1}),LU=n.forwardRef((function(e,t){const{autoFocus:r,checked:n,checkedIcon:i,className:o,defaultChecked:a,disabled:s,disableFocusRipple:l=!1,edge:c=!1,icon:u,id:d,inputProps:h,inputRef:p,name:f,onBlur:m,onChange:g,onFocus:y,readOnly:v,required:x=!1,tabIndex:b,type:_,value:w}=e,k=(0,R.A)(e,PU),[S,A]=(0,gp.A)({controlled:n,default:Boolean(a),name:"SwitchBase",state:"checked"}),T=RE();let M=s;T&&"undefined"===typeof M&&(M=T.disabled);const C="checkbox"===_||"radio"===_,E=(0,O.A)({},e,{checked:S,disabled:M,disableFocusRipple:l,edge:c}),I=(e=>{const{classes:t,checked:r,disabled:n,edge:i}=e,o={root:["root",r&&"checked",n&&"disabled",i&&`edge${(0,ei.A)(i)}`],input:["input"]};return(0,mn.A)(o,IU,t)})(E);return(0,j.jsxs)(OU,(0,O.A)({component:"span",className:(0,fn.A)(I.root,o),centerRipple:!0,focusRipple:!l,disabled:M,tabIndex:null,role:void 0,onFocus:e=>{y&&y(e),T&&T.onFocus&&T.onFocus(e)},onBlur:e=>{m&&m(e),T&&T.onBlur&&T.onBlur(e)},ownerState:E,ref:t},k,{children:[(0,j.jsx)(RU,(0,O.A)({autoFocus:r,checked:n,defaultChecked:a,className:I.input,disabled:M,id:C?d:void 0,name:f,onChange:e=>{if(e.nativeEvent.defaultPrevented)return;const t=e.target.checked;A(t),g&&g(e,t)},readOnly:v,ref:p,required:x,ownerState:E,tabIndex:b,type:_},"checkbox"===_&&void 0===w?{}:{value:w},h)),S?i:u]}))})),DU=(0,Ud.A)((0,j.jsx)("path",{d:"M19 5v14H5V5h14m0-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z"}),"CheckBoxOutlineBlank"),zU=(0,Ud.A)((0,j.jsx)("path",{d:"M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2zm-9 14l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z"}),"CheckBox"),jU=(0,Ud.A)((0,j.jsx)("path",{d:"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-2 10H7v-2h10v2z"}),"IndeterminateCheckBox");function FU(e){return(0,Yn.Ay)("MuiCheckbox",e)}const NU=(0,Ln.A)("MuiCheckbox",["root","checked","disabled","indeterminate","colorPrimary","colorSecondary","sizeSmall","sizeMedium"]),BU=["checkedIcon","color","icon","indeterminate","indeterminateIcon","inputProps","size","className"],VU=(0,yn.Ay)(LU,{shouldForwardProp:e=>(0,Ta.A)(e)||"classes"===e,name:"MuiCheckbox",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.indeterminate&&t.indeterminate,t[`size${(0,ei.A)(r.size)}`],"default"!==r.color&&t[`color${(0,ei.A)(r.color)}`]]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({color:(t.vars||t).palette.text.secondary},!r.disableRipple&&{"&:hover":{backgroundColor:t.vars?`rgba(${"default"===r.color?t.vars.palette.action.activeChannel:t.vars.palette[r.color].mainChannel} / ${t.vars.palette.action.hoverOpacity})`:(0,gn.X4)("default"===r.color?t.palette.action.active:t.palette[r.color].main,t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}}},"default"!==r.color&&{[`&.${NU.checked}, &.${NU.indeterminate}`]:{color:(t.vars||t).palette[r.color].main},[`&.${NU.disabled}`]:{color:(t.vars||t).palette.action.disabled}})})),UU=(0,j.jsx)(zU,{}),HU=(0,j.jsx)(DU,{}),$U=(0,j.jsx)(jU,{}),WU=n.forwardRef((function(e,t){var r,i;const o=(0,vn.b)({props:e,name:"MuiCheckbox"}),{checkedIcon:a=UU,color:s="primary",icon:l=HU,indeterminate:c=!1,indeterminateIcon:u=$U,inputProps:d,size:h="medium",className:p}=o,f=(0,R.A)(o,BU),m=c?u:l,g=c?u:a,y=(0,O.A)({},o,{color:s,indeterminate:c,size:h}),v=(e=>{const{classes:t,indeterminate:r,color:n,size:i}=e,o={root:["root",r&&"indeterminate",`color${(0,ei.A)(n)}`,`size${(0,ei.A)(i)}`]},a=(0,mn.A)(o,FU,t);return(0,O.A)({},t,a)})(y);return(0,j.jsx)(VU,(0,O.A)({type:"checkbox",inputProps:(0,O.A)({"data-indeterminate":c},d),icon:n.cloneElement(m,{fontSize:null!=(r=m.props.fontSize)?r:h}),checkedIcon:n.cloneElement(g,{fontSize:null!=(i=g.props.fontSize)?i:h}),ownerState:y,ref:t,className:(0,fn.A)(v.root,p)},f,{classes:v}))}));function qU(e){return(0,Yn.Ay)("MuiFormLabel",e)}const GU=(0,Ln.A)("MuiFormLabel",["root","colorSecondary","focused","disabled","error","filled","required","asterisk"]),YU=["children","className","color","component","disabled","error","filled","focused","required"],XU=(0,yn.Ay)("label",{name:"MuiFormLabel",slot:"Root",overridesResolver:(e,t)=>{let{ownerState:r}=e;return(0,O.A)({},t.root,"secondary"===r.color&&t.colorSecondary,r.filled&&t.filled)}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({color:(t.vars||t).palette.text.secondary},t.typography.body1,{lineHeight:"1.4375em",padding:0,position:"relative",[`&.${GU.focused}`]:{color:(t.vars||t).palette[r.color].main},[`&.${GU.disabled}`]:{color:(t.vars||t).palette.text.disabled},[`&.${GU.error}`]:{color:(t.vars||t).palette.error.main}})})),ZU=(0,yn.Ay)("span",{name:"MuiFormLabel",slot:"Asterisk",overridesResolver:(e,t)=>t.asterisk})((e=>{let{theme:t}=e;return{[`&.${GU.error}`]:{color:(t.vars||t).palette.error.main}}})),KU=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiFormLabel"}),{children:n,className:i,component:o="label"}=r,a=(0,R.A)(r,YU),s=PE({props:r,muiFormControl:RE(),states:["color","required","focused","disabled","error","filled"]}),l=(0,O.A)({},r,{color:s.color||"primary",component:o,disabled:s.disabled,error:s.error,filled:s.filled,focused:s.focused,required:s.required}),c=(e=>{const{classes:t,color:r,focused:n,disabled:i,error:o,filled:a,required:s}=e,l={root:["root",`color${(0,ei.A)(r)}`,i&&"disabled",o&&"error",a&&"filled",n&&"focused",s&&"required"],asterisk:["asterisk",o&&"error"]};return(0,mn.A)(l,qU,t)})(l);return(0,j.jsxs)(XU,(0,O.A)({as:o,ownerState:l,className:(0,fn.A)(c.root,i),ref:t},a,{children:[n,s.required&&(0,j.jsxs)(ZU,{ownerState:l,"aria-hidden":!0,className:c.asterisk,children:["\u2009","*"]})]}))}));function JU(e){return(0,Yn.Ay)("MuiInputLabel",e)}(0,Ln.A)("MuiInputLabel",["root","focused","disabled","error","required","asterisk","formControl","sizeSmall","shrink","animated","standard","filled","outlined"]);const QU=["disableAnimation","margin","shrink","variant","className"],eH=(0,yn.Ay)(KU,{shouldForwardProp:e=>(0,Ta.A)(e)||"classes"===e,name:"MuiInputLabel",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[{[`& .${GU.asterisk}`]:t.asterisk},t.root,r.formControl&&t.formControl,"small"===r.size&&t.sizeSmall,r.shrink&&t.shrink,!r.disableAnimation&&t.animated,r.focused&&t.focused,t[r.variant]]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({display:"block",transformOrigin:"top left",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis",maxWidth:"100%"},r.formControl&&{position:"absolute",left:0,top:0,transform:"translate(0, 20px) scale(1)"},"small"===r.size&&{transform:"translate(0, 17px) scale(1)"},r.shrink&&{transform:"translate(0, -1.5px) scale(0.75)",transformOrigin:"top left",maxWidth:"133%"},!r.disableAnimation&&{transition:t.transitions.create(["color","transform","max-width"],{duration:t.transitions.duration.shorter,easing:t.transitions.easing.easeOut})},"filled"===r.variant&&(0,O.A)({zIndex:1,pointerEvents:"none",transform:"translate(12px, 16px) scale(1)",maxWidth:"calc(100% - 24px)"},"small"===r.size&&{transform:"translate(12px, 13px) scale(1)"},r.shrink&&(0,O.A)({userSelect:"none",pointerEvents:"auto",transform:"translate(12px, 7px) scale(0.75)",maxWidth:"calc(133% - 24px)"},"small"===r.size&&{transform:"translate(12px, 4px) scale(0.75)"})),"outlined"===r.variant&&(0,O.A)({zIndex:1,pointerEvents:"none",transform:"translate(14px, 16px) scale(1)",maxWidth:"calc(100% - 24px)"},"small"===r.size&&{transform:"translate(14px, 9px) scale(1)"},r.shrink&&{userSelect:"none",pointerEvents:"auto",maxWidth:"calc(133% - 32px)",transform:"translate(14px, -9px) scale(0.75)"}))})),tH=n.forwardRef((function(e,t){const r=(0,vn.b)({name:"MuiInputLabel",props:e}),{disableAnimation:n=!1,shrink:i,className:o}=r,a=(0,R.A)(r,QU),s=RE();let l=i;"undefined"===typeof l&&s&&(l=s.filled||s.focused||s.adornedStart);const c=PE({props:r,muiFormControl:s,states:["size","variant","required","focused"]}),u=(0,O.A)({},r,{disableAnimation:n,formControl:s,shrink:l,size:c.size,variant:c.variant,required:c.required,focused:c.focused}),d=(e=>{const{classes:t,formControl:r,size:n,shrink:i,disableAnimation:o,variant:a,required:s}=e,l={root:["root",r&&"formControl",!o&&"animated",i&&"shrink",n&&"normal"!==n&&`size${(0,ei.A)(n)}`,a],asterisk:[s&&"asterisk"]},c=(0,mn.A)(l,JU,t);return(0,O.A)({},t,c)})(u);return(0,j.jsx)(eH,(0,O.A)({"data-shrink":l,ownerState:u,ref:t,className:(0,fn.A)(d.root,o)},a,{classes:d}))}));function rH(e){return(0,Yn.Ay)("MuiFormControl",e)}(0,Ln.A)("MuiFormControl",["root","marginNone","marginNormal","marginDense","fullWidth","disabled"]);const nH=["children","className","color","component","disabled","error","focused","fullWidth","hiddenLabel","margin","required","size","variant"],iH=(0,yn.Ay)("div",{name:"MuiFormControl",slot:"Root",overridesResolver:(e,t)=>{let{ownerState:r}=e;return(0,O.A)({},t.root,t[`margin${(0,ei.A)(r.margin)}`],r.fullWidth&&t.fullWidth)}})((e=>{let{ownerState:t}=e;return(0,O.A)({display:"inline-flex",flexDirection:"column",position:"relative",minWidth:0,padding:0,margin:0,border:0,verticalAlign:"top"},"normal"===t.margin&&{marginTop:16,marginBottom:8},"dense"===t.margin&&{marginTop:8,marginBottom:4},t.fullWidth&&{width:"100%"})})),oH=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiFormControl"}),{children:i,className:o,color:a="primary",component:s="div",disabled:l=!1,error:c=!1,focused:u,fullWidth:d=!1,hiddenLabel:h=!1,margin:p="none",required:f=!1,size:m="medium",variant:g="outlined"}=r,y=(0,R.A)(r,nH),v=(0,O.A)({},r,{color:a,component:s,disabled:l,error:c,fullWidth:d,hiddenLabel:h,margin:p,required:f,size:m,variant:g}),x=(e=>{const{classes:t,margin:r,fullWidth:n}=e,i={root:["root","none"!==r&&`margin${(0,ei.A)(r)}`,n&&"fullWidth"]};return(0,mn.A)(i,rH,t)})(v),[b,_]=n.useState((()=>{let e=!1;return i&&n.Children.forEach(i,(t=>{if(!(0,WC.A)(t,["Input","Select"]))return;const r=(0,WC.A)(t,["Select"])?t.props.input:t;r&&r.props.startAdornment&&(e=!0)})),e})),[w,k]=n.useState((()=>{let e=!1;return i&&n.Children.forEach(i,(t=>{(0,WC.A)(t,["Input","Select"])&&(FE(t.props,!0)||FE(t.props.inputProps,!0))&&(e=!0)})),e})),[S,A]=n.useState(!1);l&&S&&A(!1);const T=void 0===u||l?S:u;let M;const C=n.useMemo((()=>({adornedStart:b,setAdornedStart:_,color:a,disabled:l,error:c,filled:w,focused:T,fullWidth:d,hiddenLabel:h,size:m,onBlur:()=>{A(!1)},onEmpty:()=>{k(!1)},onFilled:()=>{k(!0)},onFocus:()=>{A(!0)},registerEffect:M,required:f,variant:g})),[b,a,l,c,w,T,d,h,M,f,m,g]);return(0,j.jsx)(OE.Provider,{value:C,children:(0,j.jsx)(iH,(0,O.A)({as:s,ownerState:v,className:(0,fn.A)(x.root,o),ref:t},y,{children:i}))})}));function aH(e){return(0,Yn.Ay)("MuiFormHelperText",e)}const sH=(0,Ln.A)("MuiFormHelperText",["root","error","disabled","sizeSmall","sizeMedium","contained","focused","filled","required"]);var lH;const cH=["children","className","component","disabled","error","filled","focused","margin","required","variant"],uH=(0,yn.Ay)("p",{name:"MuiFormHelperText",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.size&&t[`size${(0,ei.A)(r.size)}`],r.contained&&t.contained,r.filled&&t.filled]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({color:(t.vars||t).palette.text.secondary},t.typography.caption,{textAlign:"left",marginTop:3,marginRight:0,marginBottom:0,marginLeft:0,[`&.${sH.disabled}`]:{color:(t.vars||t).palette.text.disabled},[`&.${sH.error}`]:{color:(t.vars||t).palette.error.main}},"small"===r.size&&{marginTop:4},r.contained&&{marginLeft:14,marginRight:14})})),dH=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiFormHelperText"}),{children:n,className:i,component:o="p"}=r,a=(0,R.A)(r,cH),s=PE({props:r,muiFormControl:RE(),states:["variant","size","disabled","error","filled","focused","required"]}),l=(0,O.A)({},r,{component:o,contained:"filled"===s.variant||"outlined"===s.variant,variant:s.variant,size:s.size,disabled:s.disabled,error:s.error,filled:s.filled,focused:s.focused,required:s.required}),c=(e=>{const{classes:t,contained:r,size:n,disabled:i,error:o,filled:a,focused:s,required:l}=e,c={root:["root",i&&"disabled",o&&"error",n&&`size${(0,ei.A)(n)}`,r&&"contained",s&&"focused",a&&"filled",l&&"required"]};return(0,mn.A)(c,aH,t)})(l);return(0,j.jsx)(uH,(0,O.A)({as:o,ownerState:l,className:(0,fn.A)(c.root,i),ref:t},a,{children:" "===n?lH||(lH=(0,j.jsx)("span",{className:"notranslate",children:"\u200b"})):n}))}));function hH(e){return(0,Yn.Ay)("MuiTextField",e)}(0,Ln.A)("MuiTextField",["root"]);const pH=["autoComplete","autoFocus","children","className","color","defaultValue","disabled","error","FormHelperTextProps","fullWidth","helperText","id","InputLabelProps","inputProps","InputProps","inputRef","label","maxRows","minRows","multiline","name","onBlur","onChange","onFocus","placeholder","required","rows","select","SelectProps","type","value","variant"],fH={standard:eI,filled:EN,outlined:NN},mH=(0,yn.Ay)(oH,{name:"MuiTextField",slot:"Root",overridesResolver:(e,t)=>t.root})({}),gH=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiTextField"}),{autoComplete:n,autoFocus:i=!1,children:o,className:a,color:s="primary",defaultValue:l,disabled:c=!1,error:u=!1,FormHelperTextProps:d,fullWidth:h=!1,helperText:p,id:f,InputLabelProps:m,inputProps:g,InputProps:y,inputRef:v,label:x,maxRows:b,minRows:_,multiline:w=!1,name:k,onBlur:S,onChange:A,onFocus:T,placeholder:M,required:C=!1,rows:E,select:I=!1,SelectProps:P,type:L,value:D,variant:z="outlined"}=r,F=(0,R.A)(r,pH),N=(0,O.A)({},r,{autoFocus:i,color:s,disabled:c,error:u,fullWidth:h,multiline:w,required:C,select:I,variant:z}),B=(e=>{const{classes:t}=e;return(0,mn.A)({root:["root"]},hH,t)})(N);const V={};"outlined"===z&&(m&&"undefined"!==typeof m.shrink&&(V.notched=m.shrink),V.label=x),I&&(P&&P.native||(V.id=void 0),V["aria-describedby"]=void 0);const U=(0,zp.A)(f),H=p&&U?`${U}-helper-text`:void 0,$=x&&U?`${U}-label`:void 0,W=fH[z],q=(0,j.jsx)(W,(0,O.A)({"aria-describedby":H,autoComplete:n,autoFocus:i,defaultValue:l,fullWidth:h,multiline:w,name:k,rows:E,maxRows:b,minRows:_,type:L,value:D,id:U,inputRef:v,onBlur:S,onChange:A,onFocus:T,placeholder:M,inputProps:g},V,y));return(0,j.jsxs)(mH,(0,O.A)({className:(0,fn.A)(B.root,a),disabled:c,error:u,fullWidth:h,ref:t,required:C,color:s,variant:z,ownerState:N},F,{children:[null!=x&&""!==x&&(0,j.jsx)(tH,(0,O.A)({htmlFor:U,id:$},m,{children:x})),I?(0,j.jsx)(GN,(0,O.A)({"aria-describedby":H,id:U,labelId:$,value:D,input:q},P,{children:o})):q,p&&(0,j.jsx)(dH,(0,O.A)({id:H},d,{children:p}))]}))})),yH=["className","color","edge","size","sx"],vH=(0,yn.Ay)("span",{name:"MuiSwitch",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.edge&&t[`edge${(0,ei.A)(r.edge)}`],t[`size${(0,ei.A)(r.size)}`]]}})({display:"inline-flex",width:58,height:38,overflow:"hidden",padding:12,boxSizing:"border-box",position:"relative",flexShrink:0,zIndex:0,verticalAlign:"middle","@media print":{colorAdjust:"exact"},variants:[{props:{edge:"start"},style:{marginLeft:-8}},{props:{edge:"end"},style:{marginRight:-8}},{props:{size:"small"},style:{width:40,height:24,padding:7,[`& .${qB.thumb}`]:{width:16,height:16},[`& .${qB.switchBase}`]:{padding:4,[`&.${qB.checked}`]:{transform:"translateX(16px)"}}}}]}),xH=(0,yn.Ay)(LU,{name:"MuiSwitch",slot:"SwitchBase",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.switchBase,{[`& .${qB.input}`]:t.input},"default"!==r.color&&t[`color${(0,ei.A)(r.color)}`]]}})((e=>{let{theme:t}=e;return{position:"absolute",top:0,left:0,zIndex:1,color:t.vars?t.vars.palette.Switch.defaultColor:`${"light"===t.palette.mode?t.palette.common.white:t.palette.grey[300]}`,transition:t.transitions.create(["left","transform"],{duration:t.transitions.duration.shortest}),[`&.${qB.checked}`]:{transform:"translateX(20px)"},[`&.${qB.disabled}`]:{color:t.vars?t.vars.palette.Switch.defaultDisabledColor:`${"light"===t.palette.mode?t.palette.grey[100]:t.palette.grey[600]}`},[`&.${qB.checked} + .${qB.track}`]:{opacity:.5},[`&.${qB.disabled} + .${qB.track}`]:{opacity:t.vars?t.vars.opacity.switchTrackDisabled:""+("light"===t.palette.mode?.12:.2)},[`& .${qB.input}`]:{left:"-100%",width:"300%"}}}),(e=>{let{theme:t}=e;return{"&:hover":{backgroundColor:t.vars?`rgba(${t.vars.palette.action.activeChannel} / ${t.vars.palette.action.hoverOpacity})`:(0,gn.X4)(t.palette.action.active,t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}},variants:[...Object.entries(t.palette).filter((e=>{let[,t]=e;return t.main&&t.light})).map((e=>{let[r]=e;return{props:{color:r},style:{[`&.${qB.checked}`]:{color:(t.vars||t).palette[r].main,"&:hover":{backgroundColor:t.vars?`rgba(${t.vars.palette[r].mainChannel} / ${t.vars.palette.action.hoverOpacity})`:(0,gn.X4)(t.palette[r].main,t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:"transparent"}},[`&.${qB.disabled}`]:{color:t.vars?t.vars.palette.Switch[`${r}DisabledColor`]:`${"light"===t.palette.mode?(0,gn.a)(t.palette[r].main,.62):(0,gn.e$)(t.palette[r].main,.55)}`}},[`&.${qB.checked} + .${qB.track}`]:{backgroundColor:(t.vars||t).palette[r].main}}}}))]}})),bH=(0,yn.Ay)("span",{name:"MuiSwitch",slot:"Track",overridesResolver:(e,t)=>t.track})((e=>{let{theme:t}=e;return{height:"100%",width:"100%",borderRadius:7,zIndex:-1,transition:t.transitions.create(["opacity","background-color"],{duration:t.transitions.duration.shortest}),backgroundColor:t.vars?t.vars.palette.common.onBackground:`${"light"===t.palette.mode?t.palette.common.black:t.palette.common.white}`,opacity:t.vars?t.vars.opacity.switchTrack:""+("light"===t.palette.mode?.38:.3)}})),_H=(0,yn.Ay)("span",{name:"MuiSwitch",slot:"Thumb",overridesResolver:(e,t)=>t.thumb})((e=>{let{theme:t}=e;return{boxShadow:(t.vars||t).shadows[1],backgroundColor:"currentColor",width:20,height:20,borderRadius:"50%"}})),wH=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiSwitch"}),{className:n,color:i="primary",edge:o=!1,size:a="medium",sx:s}=r,l=(0,R.A)(r,yH),c=(0,O.A)({},r,{color:i,edge:o,size:a}),u=(e=>{const{classes:t,edge:r,size:n,color:i,checked:o,disabled:a}=e,s={root:["root",r&&`edge${(0,ei.A)(r)}`,`size${(0,ei.A)(n)}`],switchBase:["switchBase",`color${(0,ei.A)(i)}`,o&&"checked",a&&"disabled"],thumb:["thumb"],track:["track"],input:["input"]},l=(0,mn.A)(s,WB,t);return(0,O.A)({},t,l)})(c),d=(0,j.jsx)(_H,{className:u.thumb,ownerState:c});return(0,j.jsxs)(vH,{className:(0,fn.A)(u.root,n),sx:s,ownerState:c,children:[(0,j.jsx)(xH,(0,O.A)({type:"checkbox",icon:d,checkedIcon:d,ref:t,ownerState:c},l,{classes:(0,O.A)({},u,{root:u.switchBase})})),(0,j.jsx)(bH,{className:u.track,ownerState:c})]})}));function kH(e){return(0,Yn.Ay)("MuiInputAdornment",e)}const SH=(0,Ln.A)("MuiInputAdornment",["root","filled","standard","outlined","positionStart","positionEnd","disablePointerEvents","hiddenLabel","sizeSmall"]);var AH;const TH=["children","className","component","disablePointerEvents","disableTypography","position","variant"],MH=(0,yn.Ay)("div",{name:"MuiInputAdornment",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,t[`position${(0,ei.A)(r.position)}`],!0===r.disablePointerEvents&&t.disablePointerEvents,t[r.variant]]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({display:"flex",height:"0.01em",maxHeight:"2em",alignItems:"center",whiteSpace:"nowrap",color:(t.vars||t).palette.action.active},"filled"===r.variant&&{[`&.${SH.positionStart}&:not(.${SH.hiddenLabel})`]:{marginTop:16}},"start"===r.position&&{marginRight:8},"end"===r.position&&{marginLeft:8},!0===r.disablePointerEvents&&{pointerEvents:"none"})})),CH=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiInputAdornment"}),{children:i,className:o,component:a="div",disablePointerEvents:s=!1,disableTypography:l=!1,position:c,variant:u}=r,d=(0,R.A)(r,TH),h=RE()||{};let p=u;u&&h.variant,h&&!p&&(p=h.variant);const f=(0,O.A)({},r,{hiddenLabel:h.hiddenLabel,size:h.size,disablePointerEvents:s,position:c,variant:p}),m=(e=>{const{classes:t,disablePointerEvents:r,hiddenLabel:n,position:i,size:o,variant:a}=e,s={root:["root",r&&"disablePointerEvents",i&&`position${(0,ei.A)(i)}`,a,n&&"hiddenLabel",o&&`size${(0,ei.A)(o)}`]};return(0,mn.A)(s,kH,t)})(f);return(0,j.jsx)(OE.Provider,{value:null,children:(0,j.jsx)(MH,(0,O.A)({as:a,ownerState:f,className:(0,fn.A)(m.root,o),ref:t},d,{children:"string"!==typeof i||l?(0,j.jsxs)(n.Fragment,{children:["start"===c?AH||(AH=(0,j.jsx)("span",{className:"notranslate",children:"\u200b"})):null,i]}):(0,j.jsx)(Hi,{color:"text.secondary",children:i})}))})})),EH=["sortingOrder"],IH=n.memo((function(e){const{sortingOrder:t}=e,r=(0,R.A)(e,EH),n=tP(),[i]=t,o="asc"===i?n.slots.columnSortedAscendingIcon:n.slots.columnSortedDescendingIcon;return o?(0,j.jsx)(o,(0,O.A)({},r)):null})),PH=(0,Ud.A)((0,j.jsx)("path",{d:"M4 12l1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8-8 8z"}),"ArrowUpward"),OH=(0,Ud.A)((0,j.jsx)("path",{d:"M20 12l-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8 8-8z"}),"ArrowDownward"),RH=(0,Ud.A)((0,j.jsx)("path",{d:"M8.59 16.59 13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.41z"}),"KeyboardArrowRight"),LH=(0,Ud.A)((0,j.jsx)("path",{d:"M16.59 8.59 12 13.17 7.41 8.59 6 10l6 6 6-6z"}),"ExpandMore"),DH=(0,Ud.A)((0,j.jsx)("path",{d:"M10 18h4v-2h-4v2zM3 6v2h18V6H3zm3 7h12v-2H6v2z"}),"FilterList"),zH=(0,Ud.A)((0,j.jsx)("path",{d:"M4.25 5.61C6.27 8.2 10 13 10 13v6c0 .55.45 1 1 1h2c.55 0 1-.45 1-1v-6s3.72-4.8 5.74-7.39c.51-.66.04-1.61-.79-1.61H5.04c-.83 0-1.3.95-.79 1.61z"}),"FilterAlt"),jH=(0,Ud.A)((0,j.jsx)("path",{d:"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"}),"Search"),FH=((0,Ud.A)((0,j.jsx)("path",{d:"M3 18h18v-2H3v2zm0-5h18v-2H3v2zm0-7v2h18V6H3z"}),"Menu"),(0,Ud.A)((0,j.jsx)("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z"}),"CheckCircle"),(0,Ud.A)((0,j.jsx)("path",{d:"M6 5H3c-.55 0-1 .45-1 1v12c0 .55.45 1 1 1h3c.55 0 1-.45 1-1V6c0-.55-.45-1-1-1zm14 0h-3c-.55 0-1 .45-1 1v12c0 .55.45 1 1 1h3c.55 0 1-.45 1-1V6c0-.55-.45-1-1-1zm-7 0h-3c-.55 0-1 .45-1 1v12c0 .55.45 1 1 1h3c.55 0 1-.45 1-1V6c0-.55-.45-1-1-1z"}),"ColumnIcon")),NH=(0,Ud.A)((0,j.jsx)("path",{d:"M11 19V5h2v14z"}),"Separator"),BH=(0,Ud.A)((0,j.jsx)("path",{d:"M4 15h16v-2H4v2zm0 4h16v-2H4v2zm0-8h16V9H4v2zm0-6v2h16V5H4z"}),"ViewHeadline"),VH=(0,Ud.A)((0,j.jsx)("path",{d:"M21,8H3V4h18V8z M21,10H3v4h18V10z M21,16H3v4h18V16z"}),"TableRows"),UH=(0,Ud.A)((0,j.jsx)("path",{d:"M4 18h17v-6H4v6zM4 5v6h17V5H4z"}),"ViewStream"),HH=(0,Ud.A)((0,j.jsx)("path",{d:"M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"}),"TripleDotsVertical"),$H=(0,Ud.A)((0,j.jsx)("path",{d:"M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"}),"Close"),WH=(0,Ud.A)((0,j.jsx)("path",{d:"M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z"}),"Add"),qH=(0,Ud.A)((0,j.jsx)("path",{d:"M19 13H5v-2h14v2z"}),"Remove"),GH=(0,Ud.A)((0,j.jsx)("path",{d:"M12 4V1L8 5l4 4V6c3.31 0 6 2.69 6 6 0 1.01-.25 1.97-.7 2.8l1.46 1.46C19.54 15.03 20 13.57 20 12c0-4.42-3.58-8-8-8zm0 14c-3.31 0-6-2.69-6-6 0-1.01.25-1.97.7-2.8L5.24 7.74C4.46 8.97 4 10.43 4 12c0 4.42 3.58 8 8 8v3l4-4-4-4v3z"}),"Load"),YH=(0,Ud.A)((0,j.jsx)("path",{d:"M11 18c0 1.1-.9 2-2 2s-2-.9-2-2 .9-2 2-2 2 .9 2 2zm-2-8c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0-6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm6 4c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"}),"Drag"),XH=(0,Ud.A)((0,j.jsx)("path",{d:"M19 12v7H5v-7H3v7c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2v-7h-2zm-6 .67l2.59-2.58L17 11.5l-5 5-5-5 1.41-1.41L11 12.67V3h2z"}),"SaveAlt"),ZH=(0,Ud.A)((0,j.jsx)("path",{d:"M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z"}),"Check"),KH=(0,Ud.A)((0,j.jsx)("path",{d:"M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"}),"MoreVert"),JH=(0,Ud.A)((0,j.jsx)("path",{d:"M12 7c2.76 0 5 2.24 5 5 0 .65-.13 1.26-.36 1.83l2.92 2.92c1.51-1.26 2.7-2.89 3.43-4.75-1.73-4.39-6-7.5-11-7.5-1.4 0-2.74.25-3.98.7l2.16 2.16C10.74 7.13 11.35 7 12 7zM2 4.27l2.28 2.28.46.46C3.08 8.3 1.78 10.02 1 12c1.73 4.39 6 7.5 11 7.5 1.55 0 3.03-.3 4.38-.84l.42.42L19.73 22 21 20.73 3.27 3 2 4.27zM7.53 9.8l1.55 1.55c-.05.21-.08.43-.08.65 0 1.66 1.34 3 3 3 .22 0 .44-.03.65-.08l1.55 1.55c-.67.33-1.41.53-2.2.53-2.76 0-5-2.24-5-5 0-.79.2-1.53.53-2.2zm4.31-.78l3.15 3.15.02-.16c0-1.66-1.34-3-3-3l-.17.01z"}),"VisibilityOff"),QH=(0,Ud.A)((0,j.jsx)("g",{children:(0,j.jsx)("path",{d:"M14.67,5v14H9.33V5H14.67z M15.67,19H21V5h-5.33V19z M8.33,19V5H3v14H8.33z"})}),"ViewColumn"),e$=(0,Ud.A)((0,j.jsx)("path",{d:"M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"}),"Clear"),t$=((0,Ud.A)((0,j.jsx)("path",{d:"M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z"}),"Delete"),(0,Ud.A)((0,j.jsx)("path",{d:"M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zm2.46-7.12l1.41-1.41L12 12.59l2.12-2.12 1.41 1.41L13.41 14l2.12 2.12-1.41 1.41L12 15.41l-2.12 2.12-1.41-1.41L10.59 14l-2.13-2.12zM15.5 4l-1-1h-5l-1 1H5v2h14V4z"}),"Delete")),r$=["native"];const n$={BooleanCellTrueIcon:ZH,BooleanCellFalseIcon:$H,ColumnMenuIcon:HH,OpenFilterButtonIcon:DH,FilterPanelDeleteIcon:$H,ColumnFilteredIcon:zH,ColumnSelectorIcon:FH,ColumnUnsortedIcon:IH,ColumnSortedAscendingIcon:PH,ColumnSortedDescendingIcon:OH,ColumnResizeIcon:NH,DensityCompactIcon:BH,DensityStandardIcon:VH,DensityComfortableIcon:UH,ExportIcon:XH,MoreActionsIcon:KH,TreeDataCollapseIcon:LH,TreeDataExpandIcon:RH,GroupingCriteriaCollapseIcon:LH,GroupingCriteriaExpandIcon:RH,DetailPanelExpandIcon:WH,DetailPanelCollapseIcon:qH,RowReorderIcon:YH,QuickFilterIcon:jH,QuickFilterClearIcon:$H,ColumnMenuHideIcon:JH,ColumnMenuSortAscendingIcon:PH,ColumnMenuSortDescendingIcon:OH,ColumnMenuFilterIcon:zH,ColumnMenuManageColumnsIcon:QH,ColumnMenuClearIcon:e$,LoadIcon:GH,FilterPanelAddIcon:WH,FilterPanelRemoveAllIcon:t$,ColumnReorderIcon:YH},i$=(0,O.A)({},n$,{BaseCheckbox:WU,BaseTextField:gH,BaseFormControl:oH,BaseSelect:GN,BaseSwitch:wH,BaseButton:gf,BaseIconButton:oi,BaseInputAdornment:CH,BaseTooltip:Mp,BasePopper:fp,BaseInputLabel:tH,BaseSelectOption:function(e){let{native:t}=e,r=(0,R.A)(e,r$);return t?(0,j.jsx)("option",(0,O.A)({},r)):(0,j.jsx)(qa,(0,O.A)({},r))},BaseChip:_L}),o$=(0,O.A)({},i$,{Cell:CV,SkeletonCell:function(e){const{align:t,width:r,contentWidth:n}=e,i=(0,R.A)(e,xF),o=(e=>{const{align:t,classes:r}=e,n={root:["cell","cellSkeleton",`cell--text${(0,MI.A)(t)}`,"withBorderColor"]};return(0,mn.A)(n,DI,r)})({classes:tP().classes,align:t});return(0,j.jsx)("div",(0,O.A)({className:o.root,style:{width:r}},i,{children:(0,j.jsx)(vF,{width:`${n}%`})}))},ColumnHeaderFilterIconButton:function(e){var t,r;const{counter:i,field:o,onClick:a}=e,s=xR(),l=tP(),c=(e=>{const{classes:t}=e;return(0,mn.A)({icon:["filterIcon"]},DI,t)})((0,O.A)({},e,{classes:l.classes})),u=KI(s,Lj),d=(0,zp.A)(),h=(0,zp.A)(),p=n.useCallback((e=>{e.preventDefault(),e.stopPropagation();const{open:t,openedPanelValue:r}=Lj(s.current.state);t&&r===Jz.filters?s.current.hideFilterPanel():s.current.showFilterPanel(void 0,h,d),a&&a(s.current.getColumnHeaderParams(o),e)}),[s,o,a,h,d]);if(!i)return null;const f=u.open&&u.labelId===d,m=(0,j.jsx)(l.slots.baseIconButton,(0,O.A)({id:d,onClick:p,color:"default","aria-label":s.current.getLocaleText("columnHeaderFiltersLabel"),size:"small",tabIndex:-1,"aria-haspopup":"menu","aria-expanded":f,"aria-controls":f?h:void 0},null==(t=l.slotProps)?void 0:t.baseIconButton,{children:(0,j.jsx)(l.slots.columnFilteredIcon,{className:c.icon,fontSize:"small"})}));return(0,j.jsx)(l.slots.baseTooltip,(0,O.A)({title:s.current.getLocaleText("columnHeaderFiltersTooltipActive")(i),enterDelay:1e3},null==(r=l.slotProps)?void 0:r.baseTooltip,{children:(0,j.jsxs)(EF,{children:[i>1&&(0,j.jsx)(TF,{badgeContent:i,color:"default",children:m}),1===i&&m]})}))},ColumnMenu:CU,ColumnHeaders:hU,Footer:zF,FooterRowCount:NF,Toolbar:null,PreferencesPanel:BF,LoadingOverlay:iN,NoResultsOverlay:EU,NoRowsOverlay:oN,Pagination:bB,FilterPanel:$B,ColumnsPanel:function(e){var t,r,i;const o=xR(),a=n.useRef(null),s=KI(o,vP),l=KI(o,xP),c=tP(),[u,d]=n.useState(""),h=(e=>{const{classes:t}=e;return(0,mn.A)({root:["columnsPanel"],columnsPanelRow:["columnsPanelRow"]},DI,t)})(c),{sort:p,searchPredicate:f=fV,autoFocusSearchField:m=!0,disableHideAllButton:g=!1,disableShowAllButton:y=!1,getTogglableColumns:v}=e,x=(0,R.A)(e,uV),b=n.useMemo((()=>{switch(p){case"asc":return[...s].sort(((e,t)=>pV.compare(e.headerName||e.field,t.headerName||t.field)));case"desc":return[...s].sort(((e,t)=>-pV.compare(e.headerName||e.field,t.headerName||t.field)));default:return s}}),[s,p]),_=e=>{const{name:t}=e.target;o.current.setColumnVisibility(t,!1===l[t])},w=n.useCallback((e=>{const t=xP(o),r=(0,O.A)({},t),n=v?v(s):null;return s.forEach((t=>{t.hideable&&(null==n||n.includes(t.field))&&(e?delete r[t.field]:r[t.field]=!1)})),o.current.setColumnVisibilityModel(r)}),[o,s,v]),k=n.useCallback((e=>{d(e.target.value)}),[]),S=n.useMemo((()=>{const e=v?v(b):null,t=e?b.filter((t=>{let{field:r}=t;return e.includes(r)})):b;return u?t.filter((e=>f(e,u.toLowerCase()))):t}),[b,u,f,v]),A=n.useRef(null);n.useEffect((()=>{m?a.current.focus():A.current&&"function"===typeof A.current.focus&&A.current.focus()}),[m]);let T=!1;const M=e=>!1===T&&!1!==e.hideable&&(T=!0,!0);return(0,j.jsxs)(IB,(0,O.A)({},x,{children:[(0,j.jsx)(cV,{children:(0,j.jsx)(c.slots.baseTextField,(0,O.A)({label:o.current.getLocaleText("columnsPanelTextFieldLabel"),placeholder:o.current.getLocaleText("columnsPanelTextFieldPlaceholder"),inputRef:a,value:u,onChange:k,variant:"standard",fullWidth:!0},null==(t=c.slotProps)?void 0:t.baseTextField))}),(0,j.jsx)(kB,{children:(0,j.jsx)(dV,{className:h.root,ownerState:c,children:S.map((e=>{var t;return(0,j.jsxs)(hV,{className:h.columnsPanelRow,ownerState:c,children:[(0,j.jsx)(aV,{control:(0,j.jsx)(c.slots.baseSwitch,(0,O.A)({disabled:!1===e.hideable,checked:!1!==l[e.field],onClick:_,name:e.field,size:"small",inputRef:M(e)?A:void 0},null==(t=c.slotProps)?void 0:t.baseSwitch)),label:e.headerName||e.field}),!c.disableColumnReorder&&false]},e.field)}))})}),y&&g?null:(0,j.jsxs)(TB,{children:[g?(0,j.jsx)("span",{}):(0,j.jsx)(c.slots.baseButton,(0,O.A)({onClick:()=>w(!1)},null==(r=c.slotProps)?void 0:r.baseButton,{disabled:g,children:o.current.getLocaleText("columnsPanelHideAllButton")})),y?null:(0,j.jsx)(c.slots.baseButton,(0,O.A)({onClick:()=>w(!0)},null==(i=c.slotProps)?void 0:i.baseButton,{disabled:y,children:o.current.getLocaleText("columnsPanelShowAllButton")}))]})]}))},Panel:xV,Row:PV}),a$=e=>{if(void 0!==e)return Object.keys(e).reduce(((t,r)=>(0,O.A)({},t,{[`${r.charAt(0).toLowerCase()}${r.slice(1)}`]:e[r]})),{})},s$=["components","componentsProps"];function l$(e){var t;const r=Object.keys(e);if(!r.some((e=>e.startsWith("aria-")||e.startsWith("data-"))))return e;const n={},i=null!=(t=e.forwardedProps)?t:{};for(let o=0;o{const[t,r,i]=(o=iF({props:e,name:"MuiDataGrid"}),n.useMemo((()=>{const{components:e,componentsProps:t}=o;return[e,t,l$((0,R.A)(o,s$))]}),[o]));var o;const a=n.useMemo((()=>(0,O.A)({},oF,i.localeText)),[i.localeText]),s=n.useMemo((()=>function(e){let{defaultSlots:t,slots:r,components:n}=e;const i=null!=r?r:n?a$(n):null;if(!i||0===Object.keys(i).length)return t;const o=(0,O.A)({},t);return Object.keys(i).forEach((e=>{const t=e;void 0!==i[t]&&(o[t]=i[t])})),o}({defaultSlots:d$,slots:i.slots,components:t})),[t,i.slots]);return n.useMemo((()=>{var e;return(0,O.A)({},u$,i,{localeText:a,slots:s,slotProps:null!=(e=i.slotProps)?e:r},c$)}),[i,a,s,r])},p$=e=>(0,O.A)({},e,{rowsMeta:{currentPageTotalHeight:0,positions:[]}});const f$=(e,t,r)=>"number"===typeof e&&e>0?e:t;["MUI: The `rowHeight` prop should be a number greater than 0.","The default value will be used instead."].join("\n"),["MUI: The `getRowHeight` prop should return a number greater than 0 or 'auto'.","The default value will be used instead."].join("\n");function m$(e){return void 0!==e.field}const g$=(e,t,r)=>{if(m$(e)){if(void 0!==r[e.field])throw new Error(["MUI: columnGroupingModel contains duplicated field",`column field ${e.field} occurs two times in the grouping model:`,`- ${r[e.field].join(" > ")}`,`- ${t.join(" > ")}`].join("\n"));return void(r[e.field]=t)}const{groupId:n,children:i}=e;i.forEach((e=>{g$(e,[...t,n],r)}))},y$=e=>{if(!e)return{};const t={};return e.forEach((e=>{g$(e,[],t)})),t},v$=(e,t,r)=>{const n=e=>{var r;return null!=(r=t[e])?r:[]},i=[],o=Math.max(...e.map((e=>n(e).length))),a=(e,t,r)=>BO(n(e).slice(0,r+1),n(t).slice(0,r+1));for(let s=0;s{var i;const o=null!=(i=n(t)[s])?i:null;if(0===e.length)return[{columnFields:[t],groupId:o}];const l=e[e.length-1],c=l.columnFields[l.columnFields.length-1];return l.groupId!==o||!a(c,t,s)||(u=c,d=t,null!=r&&r.left&&r.left.includes(u)&&!r.left.includes(d)||null!=r&&r.right&&!r.right.includes(u)&&r.right.includes(d))?[...e,{columnFields:[t],groupId:o}]:[...e.slice(0,e.length-1),{columnFields:[...l.columnFields,t],groupId:o}];var u,d}),[]);i.push(t)}return i},x$=["groupId","children"],b$=e=>{let t={};return e.forEach((e=>{if(m$(e))return;const{groupId:r,children:n}=e,i=(0,R.A)(e,x$);if(!r)throw new Error("MUI: An element of the columnGroupingModel does not have either `field` or `groupId`.");n||console.warn(`MUI: group groupId=${r} has no children.`);const o=(0,O.A)({},i,{groupId:r}),a=b$(n);if(void 0!==a[r]||void 0!==t[r])throw new Error(`MUI: The groupId ${r} is used multiple times in the columnGroupingModel.`);t=(0,O.A)({},t,a,{[r]:o})})),(0,O.A)({},t)},_$=(e,t,r)=>{var n,i,o,a;if(null==(n=t.experimentalFeatures)||!n.columnGrouping)return e;const s=gP(r),l=_P(r),c=b$(null!=(i=t.columnGroupingModel)?i:[]),u=y$(null!=(o=t.columnGroupingModel)?o:[]),d=v$(s,u,null!=(a=r.current.state.pinnedColumns)?a:{}),h=0===l.length?0:Math.max(...l.map((e=>{var t,r;return null!=(t=null==(r=u[e])?void 0:r.length)?t:0})));return(0,O.A)({},e,{columnGrouping:{lookup:c,unwrappedGroupingModel:u,headerStructure:d,maxDepth:h}})},w$=(e,t)=>{const r={enabled:!t.disableVirtualization,enabledForColumns:!0};return(0,O.A)({},e,{virtualization:r})};const k$=(e,t)=>{const r=uR(e,t);return eF(r,t),(e=>{pj(e,lR,"rowTreeCreation",Xj)})(r),dR(Qj,r,t),dR(ej,r,t),dR(Gj,r,t),dR(Wj,r,t),dR(bj,r,t),dR(tF,r,t),dR(Dj,r,t),dR(fj,r,t),dR(rj,r,t),dR(Oj,r,t),dR(p$,r,t),dR(YD,r,t),dR(_$,r,t),dR(w$,r,t),Pj(r,t),((e,t)=>{const r=hR(e,"useGridSelection"),i=e=>function(){t.rowSelection&&e(...arguments)},o=n.useMemo((()=>Jj(t.rowSelectionModel,wR(e.current.state))),[e,t.rowSelectionModel]),a=n.useRef(null);e.current.registerControlState({stateId:"rowSelection",propModel:o,propOnChange:t.onRowSelectionModelChange,stateSelector:wR,changeEvent:"rowSelectionChange"});const{checkboxSelection:s,disableMultipleRowSelection:l,disableRowSelectionOnClick:c,isRowSelectable:u}=t,d=!l||s,h=xj(e,t),p=n.useCallback((t=>{var r;let n=t;const i=null!=(r=a.current)?r:t,o=e.current.isRowSelected(t);if(o){const t=mO(e),r=t.findIndex((e=>e===i)),o=t.findIndex((e=>e===n));if(r===o)return;n=r>o?t[o+1]:t[o-1]}a.current=t,e.current.selectRowRange({startId:i,endId:n},!o)}),[e]),f=n.useCallback((n=>{if(t.signature===JO.DataGrid&&!t.checkboxSelection&&Array.isArray(n)&&n.length>1)throw new Error(["MUI: `rowSelectionModel` can only contain 1 item in DataGrid.","You need to upgrade to DataGridPro or DataGridPremium component to unlock multiple selection."].join("\n"));wR(e.current.state)!==n&&(r.debug("Setting selection model"),e.current.setState((e=>(0,O.A)({},e,{rowSelection:t.rowSelection?n:[]}))),e.current.forceUpdate())}),[e,r,t.rowSelection,t.signature,t.checkboxSelection]),m=n.useCallback((t=>wR(e.current.state).includes(t)),[e]),g=n.useCallback((t=>{if(u&&!u(e.current.getRowParams(t)))return!1;const r=e.current.getRowNode(t);return"footer"!==(null==r?void 0:r.type)&&"pinnedRow"!==(null==r?void 0:r.type)}),[e,u]),y=n.useCallback((()=>SR(e)),[e]),v=n.useCallback((function(t){let n=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]&&arguments[2];if(e.current.isRowSelectable(t))if(a.current=t,i)r.debug(`Setting selection for row ${t}`),e.current.setRowSelectionModel(n?[t]:[]);else{r.debug(`Toggling selection for row ${t}`);const i=wR(e.current.state).filter((e=>e!==t));n&&i.push(t),(i.length<2||d)&&e.current.setRowSelectionModel(i)}}),[e,r,d]),x=n.useCallback((function(t){let n=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]&&arguments[2];r.debug("Setting selection for several rows");const o=t.filter((t=>e.current.isRowSelectable(t)));let a;if(i)a=n?o:[];else{const t=(0,O.A)({},AR(e));o.forEach((e=>{n?t[e]=e:delete t[e]})),a=Object.values(t)}(a.length<2||d)&&e.current.setRowSelectionModel(a)}),[e,r,d]),b=n.useCallback((function(t){let{startId:n,endId:i}=t,o=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],a=arguments.length>2&&void 0!==arguments[2]&&arguments[2];if(!e.current.getRow(n)||!e.current.getRow(i))return;r.debug(`Expanding selection from row ${n} to row ${i}`);const s=mO(e),l=s.indexOf(n),c=s.indexOf(i),[u,d]=l>c?[c,l]:[l,c],h=s.slice(u,d+1);e.current.selectRows(h,o,a)}),[e,r]),_={selectRows:x,selectRowRange:b};HO(e,{selectRow:v,setRowSelectionModel:f,getSelectedRows:y,isRowSelected:m,isRowSelectable:g},"public"),HO(e,_,t.signature===JO.DataGrid?"private":"public");const w=n.useCallback((()=>{if(t.keepNonExistentRowsSelected)return;const r=wR(e.current.state),n=DP(e),i=(0,O.A)({},AR(e));let o=!1;r.forEach((e=>{n[e]||(delete i[e],o=!0)})),o&&e.current.setRowSelectionModel(Object.values(i))}),[e,t.keepNonExistentRowsSelected]),k=n.useCallback(((t,r)=>{const n=r.metaKey||r.ctrlKey,i=!s&&!n&&!(e=>!!e.key)(r),o=!d||i,a=e.current.isRowSelected(t);o?e.current.selectRow(t,!!i||!a,!0):e.current.selectRow(t,!a,!1)}),[e,d,s]),S=n.useCallback(((t,r)=>{var n;if(c)return;const i=null==(n=r.target.closest(`.${zI.cell}`))?void 0:n.getAttribute("data-field");if(i!==VD.field&&i!==_j){if(i){const t=e.current.getColumn(i);if((null==t?void 0:t.type)===Vz)return}"pinnedRow"!==e.current.getRowNode(t.id).type&&(r.shiftKey&&(d||s)?p(t.id):k(t.id,r))}}),[c,d,s,e,p,k]),A=n.useCallback(((e,t)=>{var r;d&&t.shiftKey&&(null==(r=window.getSelection())||r.removeAllRanges())}),[d]),T=n.useCallback(((t,r)=>{r.nativeEvent.shiftKey?p(t.id):e.current.selectRow(t.id,t.value)}),[e,p]),M=n.useCallback((r=>{const n=t.checkboxSelectionVisibleOnly&&t.pagination?jR(e):mO(e),i=hO(e);e.current.selectRows(n,r.value,(null==i?void 0:i.items.length)>0)}),[e,t.checkboxSelectionVisibleOnly,t.pagination]),C=n.useCallback(((t,r)=>{if(e.current.getCellMode(t.id,t.field)!==yz.Edit&&!Cj(r)){if(vR(r.key)&&r.shiftKey){const n=SO(e);if(n&&n.id!==t.id){r.preventDefault();const i=e.current.isRowSelected(n.id);if(!d)return void e.current.selectRow(n.id,!i,!0);const o=e.current.getRowIndexRelativeToVisibleRows(n.id),a=e.current.getRowIndexRelativeToVisibleRows(t.id);let s,l;o>a?i?(s=a,l=o-1):(s=a,l=o):i?(s=o+1,l=a):(s=o,l=a);const c=h.rows.slice(s,l+1).map((e=>e.id));return void e.current.selectRows(c,!i)}}if(" "===r.key&&r.shiftKey)return r.preventDefault(),void k(t.id,r);"a"===r.key&&(r.ctrlKey||r.metaKey)&&(r.preventDefault(),x(e.current.getAllRowIds(),!0))}}),[e,k,x,h.rows,d]);tR(e,"sortedRowsSet",i(w)),tR(e,"rowClick",i(S)),tR(e,"rowSelectionCheckboxChange",i(T)),tR(e,"headerSelectionCheckboxChange",M),tR(e,"cellMouseDown",i(A)),tR(e,"cellKeyDown",i(C)),n.useEffect((()=>{void 0!==o&&e.current.setRowSelectionModel(o)}),[e,o,t.rowSelection]),n.useEffect((()=>{t.rowSelection||e.current.setRowSelectionModel([])}),[e,t.rowSelection]);const E=null!=o;n.useEffect((()=>{if(E||!t.rowSelection)return;const r=wR(e.current.state);if(g){const t=r.filter((e=>g(e)));t.length{if(!t.rowSelection||E)return;const r=wR(e.current.state);!d&&r.length>1&&e.current.setRowSelectionModel([])}),[e,d,s,E,t.rowSelection])})(r,t),function(e,t){var r,i;const o=hR(e,"useGridColumns"),a=Qz,s=n.useRef(t.columns),l=n.useRef(a);e.current.registerControlState({stateId:"visibleColumns",propModel:t.columnVisibilityModel,propOnChange:t.onColumnVisibilityModelChange,stateSelector:xP,changeEvent:"columnVisibilityModelChange"});const c=n.useCallback((t=>{o.debug("Updating columns state."),e.current.setState(Yz(t)),e.current.forceUpdate(),e.current.publishEvent("columnsChange",t.orderedFields)}),[o,e]),u=n.useCallback((t=>yP(e)[t]),[e]),d=n.useCallback((()=>vP(e)),[e]),h=n.useCallback((()=>bP(e)),[e]),p=n.useCallback((function(t){return(arguments.length>1&&void 0!==arguments[1]&&!arguments[1]?vP(e):bP(e)).findIndex((e=>e.field===t))}),[e]),f=n.useCallback((t=>{const r=p(t);return wP(e)[r]}),[e,p]),m=n.useCallback((t=>{xP(e)!==t&&(e.current.setState((r=>(0,O.A)({},r,{columns:Gz({apiRef:e,columnTypes:a,columnsToUpsert:[],initialState:void 0,columnVisibilityModel:t,keepOnlyColumnsToUpsert:!1})}))),e.current.forceUpdate())}),[e,a]),g=n.useCallback((t=>{const r=Gz({apiRef:e,columnTypes:a,columnsToUpsert:t,initialState:void 0,keepOnlyColumnsToUpsert:!1});c(r)}),[e,c,a]),y=n.useCallback(((t,r)=>{var n;const i=xP(e);if(r!==(null==(n=i[t])||n)){const n=(0,O.A)({},i,{[t]:r});e.current.setColumnVisibilityModel(n)}}),[e]),v=n.useCallback((t=>gP(e).findIndex((e=>e===t))),[e]),x=n.useCallback(((t,r)=>{const n=gP(e),i=v(t);if(i===r)return;o.debug(`Moving column ${t} to index ${r}`);const a=[...n],s=a.splice(i,1)[0];a.splice(r,0,s),c((0,O.A)({},mP(e.current.state),{orderedFields:a}));const l={column:e.current.getColumn(t),targetIndex:e.current.getColumnIndexRelativeToVisibleColumns(t),oldIndex:i};e.current.publishEvent("columnIndexChange",l)}),[e,o,c,v]),b=n.useCallback(((t,r)=>{var n,i;o.debug(`Updating column ${t} width to ${r}`);const a=mP(e.current.state),s=a.lookup[t],l=(0,O.A)({},s,{width:r,hasBeenResized:!0});c(Wz((0,O.A)({},a,{lookup:(0,O.A)({},a.lookup,{[t]:l})}),null!=(n=null==(i=e.current.getRootDimensions())?void 0:i.viewportInnerSize.width)?n:0)),e.current.publishEvent("columnWidthChange",{element:e.current.getColumnHeaderElement(t),colDef:l,width:r})}),[e,o,c]),_={setColumnIndex:x};HO(e,{getColumn:u,getAllColumns:d,getColumnIndex:p,getColumnPosition:f,getVisibleColumns:h,getColumnIndexRelativeToVisibleColumns:v,updateColumns:g,setColumnVisibilityModel:m,setColumnVisibility:y,setColumnWidth:b},"public"),HO(e,_,t.signature===JO.DataGrid?"private":"public");const w=n.useCallback(((r,n)=>{var i,o;const a={},s=xP(e);(!n.exportOnlyDirtyModels||null!=t.columnVisibilityModel||Object.keys(null!=(i=null==(o=t.initialState)||null==(o=o.columns)?void 0:o.columnVisibilityModel)?i:{}).length>0||Object.keys(s).length>0)&&(a.columnVisibilityModel=s),a.orderedFields=gP(e);const l=vP(e),c={};return l.forEach((e=>{if(e.hasBeenResized){const t={};$z.forEach((r=>{let n=e[r];n===1/0&&(n=-1),t[r]=n})),c[e.field]=t}})),Object.keys(c).length>0&&(a.dimensions=c),(0,O.A)({},r,{columns:a})}),[e,t.columnVisibilityModel,null==(r=t.initialState)?void 0:r.columns]),k=n.useCallback(((t,r)=>{var n;const i=null==(n=r.stateToRestore.columns)?void 0:n.columnVisibilityModel,o=r.stateToRestore.columns;if(null==i&&null==o)return t;const s=Gz({apiRef:e,columnTypes:a,columnsToUpsert:[],initialState:o,columnVisibilityModel:i,keepOnlyColumnsToUpsert:!1});return e.current.setState(Yz(s)),null!=o&&e.current.publishEvent("columnsChange",s.orderedFields),t}),[e,a]),S=n.useCallback(((e,r)=>{if(r===Jz.columns){var n;const e=t.slots.columnsPanel;return(0,j.jsx)(e,(0,O.A)({},null==(n=t.slotProps)?void 0:n.columnsPanel))}return e}),[t.slots.columnsPanel,null==(i=t.slotProps)?void 0:i.columnsPanel]),A=n.useCallback((e=>t.disableColumnSelector?e:[...e,"columnMenuColumnsItem"]),[t.disableColumnSelector]);ZD(e,"columnMenu",A),ZD(e,"exportState",w),ZD(e,"restoreState",k),ZD(e,"preferencePanel",S);const T=n.useRef(null);tR(e,"viewportInnerSizeChange",(t=>{T.current!==t.width&&(T.current=t.width,c(Wz(mP(e.current.state),t.width)))}));const M=n.useCallback((()=>{o.info("Columns pipe processing have changed, regenerating the columns");const t=Gz({apiRef:e,columnTypes:a,columnsToUpsert:[],initialState:void 0,keepOnlyColumnsToUpsert:!1});c(t)}),[e,o,c,a]);KD(e,"hydrateColumns",M);const C=n.useRef(!0);n.useEffect((()=>{if(C.current)return void(C.current=!1);if(o.info(`GridColumns have changed, new length ${t.columns.length}`),s.current===t.columns&&l.current===a)return;const r=Gz({apiRef:e,columnTypes:a,initialState:void 0,columnsToUpsert:t.columns,keepOnlyColumnsToUpsert:!0});s.current=t.columns,l.current=a,c(r)}),[o,e,c,t.columns,a]),n.useEffect((()=>{void 0!==t.columnVisibilityModel&&e.current.setColumnVisibilityModel(t.columnVisibilityModel)}),[e,o,t.columnVisibilityModel])}(r,t),Yj(r,t),Kj(r,t),(e=>{const t=n.useRef({}),r=n.useCallback(((e,r,n)=>{const i=t.current;i[e]||(i[e]={}),i[e][r]=n}),[]),i=n.useCallback(((e,r)=>{var n;return null==(n=t.current[e])?void 0:n[r]}),[]),o=n.useCallback((t=>{const{columnIndex:n,rowId:i,minFirstColumnIndex:o,maxLastColumnIndex:a,columns:s}=t,l=s.length,c=s[n],u="function"===typeof c.colSpan?c.colSpan(e.current.getCellParams(i,c.field)):c.colSpan;if(!u||1===u)return r(i,n,{spannedByColSpan:!1,cellProps:{colSpan:1,width:c.computedWidth}}),{colSpan:1};let d=c.computedWidth;for(let e=1;e=o&&t{let{rowId:t,minFirstColumn:r,maxLastColumn:n,columns:i}=e;for(let a=r;a1&&(a+=e.colSpan-1)}}),[o])};HO(e,{unstable_getCellColSpanInfo:i},"public"),HO(e,a,"private");const s=n.useCallback((()=>{t.current={}}),[]);tR(e,"columnOrderChange",s)})(r),((e,t)=>{var r;const i=n.useCallback((t=>{var r;return null!=(r=MP(e)[t])?r:[]}),[e]),o=n.useCallback((()=>CP(e)),[e]);HO(e,{unstable_getColumnGroupPath:i,unstable_getAllGroupDetails:o},"public");const a=n.useCallback((()=>{var r;const n=y$(null!=(r=t.columnGroupingModel)?r:[]);e.current.setState((e=>{var t,r,i;const o=null!=(t=null==(r=e.columns)?void 0:r.orderedFields)?t:[],a=null!=(i=e.pinnedColumns)?i:{},s=v$(o,n,a);return(0,O.A)({},e,{columnGrouping:(0,O.A)({},e.columnGrouping,{headerStructure:s})})}))}),[e,t.columnGroupingModel]),s=n.useCallback((r=>{var n,i,o,a;if(null==(n=t.experimentalFeatures)||!n.columnGrouping)return;const s=null!=(i=null==(o=(a=e.current).getPinnedColumns)?void 0:o.call(a))?i:{},l=gP(e),c=_P(e),u=b$(null!=r?r:[]),d=y$(null!=r?r:[]),h=v$(l,d,s),p=0===c.length?0:Math.max(...c.map((e=>{var t,r;return null!=(t=null==(r=d[e])?void 0:r.length)?t:0})));e.current.setState((e=>(0,O.A)({},e,{columnGrouping:{lookup:u,unwrappedGroupingModel:d,headerStructure:h,maxDepth:p}})))}),[e,null==(r=t.experimentalFeatures)?void 0:r.columnGrouping]);tR(e,"columnIndexChange",a),tR(e,"columnsChange",(()=>{s(t.columnGroupingModel)})),tR(e,"columnVisibilityModelChange",(()=>{s(t.columnGroupingModel)})),n.useEffect((()=>{s(t.columnGroupingModel)}),[s,t.columnGroupingModel])})(r,t),qj(r,t),((e,t)=>{const r=hR(e,"useGridFocus"),i=n.useRef(null),o=n.useCallback(((t,r)=>{t&&e.current.getRow(t.id)&&e.current.publishEvent("cellFocusOut",e.current.getCellParams(t.id,t.field),r)}),[e]),a=n.useCallback(((t,n)=>{const i=SO(e);(null==i?void 0:i.id)===t&&(null==i?void 0:i.field)===n||(e.current.setState((e=>(r.debug(`Focusing on cell with id=${t} and field=${n}`),(0,O.A)({},e,{tabIndex:{cell:{id:t,field:n},columnHeader:null,columnHeaderFilter:null,columnGroupHeader:null},focus:{cell:{id:t,field:n},columnHeader:null,columnHeaderFilter:null,columnGroupHeader:null}})))),e.current.forceUpdate(),e.current.getRow(t)&&(i&&o(i,{}),e.current.publishEvent("cellFocusIn",e.current.getCellParams(t,n))))}),[e,r,o]),s=n.useCallback((function(t){let n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const i=SO(e);o(i,n),e.current.setState((e=>(r.debug(`Focusing on column header with colIndex=${t}`),(0,O.A)({},e,{tabIndex:{columnHeader:{field:t},columnHeaderFilter:null,cell:null,columnGroupHeader:null},focus:{columnHeader:{field:t},columnHeaderFilter:null,cell:null,columnGroupHeader:null}})))),e.current.forceUpdate()}),[e,r,o]),l=n.useCallback((function(t){let n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const i=SO(e);o(i,n),e.current.setState((e=>(r.debug(`Focusing on column header filter with colIndex=${t}`),(0,O.A)({},e,{tabIndex:{columnHeader:null,columnHeaderFilter:{field:t},cell:null,columnGroupHeader:null},focus:{columnHeader:null,columnHeaderFilter:{field:t},cell:null,columnGroupHeader:null}})))),e.current.forceUpdate()}),[e,r,o]),c=n.useCallback((function(t,r){let n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};const i=SO(e);i&&e.current.publishEvent("cellFocusOut",e.current.getCellParams(i.id,i.field),n),e.current.setState((e=>(0,O.A)({},e,{tabIndex:{columnGroupHeader:{field:t,depth:r},columnHeader:null,columnHeaderFilter:null,cell:null},focus:{columnGroupHeader:{field:t,depth:r},columnHeader:null,columnHeaderFilter:null,cell:null}}))),e.current.forceUpdate()}),[e]),u=n.useCallback((()=>TO(e)),[e]),d=n.useCallback(((r,n,i)=>{let o=e.current.getColumnIndex(n);const a=bP(e),s=vj(e,{pagination:t.pagination,paginationMode:t.paginationMode}),l=UP(e),c=[].concat(l.top||[],s.rows,l.bottom||[]);let u=c.findIndex((e=>e.id===r));"right"===i?o+=1:"left"===i?o-=1:u+=1,o>=a.length?(u+=1,u=0&&(o=a.length-1)),u=NO(u,0,c.length-1);const d=c[u];if(!d)return;const h=e.current.unstable_getCellColSpanInfo(d.id,o);h&&h.spannedByColSpan&&("left"===i||"below"===i?o=h.leftVisibleCellIndex:"right"===i&&(o=h.rightVisibleCellIndex)),o=NO(o,0,a.length-1);const p=a[o];e.current.setCellFocus(d.id,p.field)}),[e,t.pagination,t.paginationMode]),h=n.useCallback((t=>{let{id:r,field:n}=t;e.current.setCellFocus(r,n)}),[e]),p=n.useCallback(((t,r)=>{"Enter"===r.key||"Tab"===r.key||"Shift"===r.key||vR(r.key)||e.current.setCellFocus(t.id,t.field)}),[e]),f=n.useCallback(((t,r)=>{let{field:n}=t;r.target===r.currentTarget&&e.current.setColumnHeaderFocus(n,r)}),[e]),m=n.useCallback(((t,r)=>{let{fields:n,depth:i}=t;if(r.target!==r.currentTarget)return;const o=TO(e);null!==o&&o.depth===i&&n.includes(o.field)||e.current.setColumnGroupHeaderFocus(n[0],i,r)}),[e]),g=n.useCallback(((t,n)=>{var i;null!=(i=n.relatedTarget)&&i.className.includes(zI.columnHeader)||(r.debug("Clearing focus"),e.current.setState((e=>(0,O.A)({},e,{focus:{cell:null,columnHeader:null,columnHeaderFilter:null,columnGroupHeader:null}}))))}),[r,e]),y=n.useCallback((e=>{i.current=e}),[]),v=n.useCallback((t=>{const r=i.current;i.current=null;const n=SO(e);if(!e.current.unstable_applyPipeProcessors("canUpdateFocus",!0,{event:t,cell:r}))return;if(!n)return void(r&&e.current.setCellFocus(r.id,r.field));if((null==r?void 0:r.id)===n.id&&(null==r?void 0:r.field)===n.field)return;const a=e.current.getCellElement(n.id,n.field);null!=a&&a.contains(t.target)||(r?e.current.setCellFocus(r.id,r.field):(e.current.setState((e=>(0,O.A)({},e,{focus:{cell:null,columnHeader:null,columnHeaderFilter:null,columnGroupHeader:null}}))),e.current.forceUpdate(),o(n,t)))}),[e,o]),x=n.useCallback((t=>{if("view"===t.cellMode)return;const r=SO(e);(null==r?void 0:r.id)===t.id&&(null==r?void 0:r.field)===t.field||e.current.setCellFocus(t.id,t.field)}),[e]),b=n.useCallback((()=>{const t=SO(e);t&&!e.current.getRow(t.id)&&e.current.setState((e=>(0,O.A)({},e,{focus:{cell:null,columnHeader:null,columnHeaderFilter:null,columnGroupHeader:null}})))}),[e]),_=(0,ea.A)((()=>{const r=SO(e);if(!r)return;const n=vj(e,{pagination:t.pagination,paginationMode:t.paginationMode});if(n.rows.find((e=>e.id===r.id)))return;const i=bP(e);e.current.setState((e=>(0,O.A)({},e,{tabIndex:{cell:{id:n.rows[0].id,field:i[0].field},columnGroupHeader:null,columnHeader:null,columnHeaderFilter:null}})))})),w={moveFocusToRelativeCell:d,setColumnGroupHeaderFocus:c,getColumnGroupHeaderFocus:u};HO(e,{setCellFocus:a,setColumnHeaderFocus:s,setColumnHeaderFilterFocus:l},"public"),HO(e,w,"private"),n.useEffect((()=>{const t=(0,No.A)(e.current.rootElementRef.current);return t.addEventListener("mouseup",v),()=>{t.removeEventListener("mouseup",v)}}),[e,v]),tR(e,"columnHeaderBlur",g),tR(e,"cellDoubleClick",h),tR(e,"cellMouseDown",y),tR(e,"cellKeyDown",p),tR(e,"cellModeChange",x),tR(e,"columnHeaderFocus",f),tR(e,"columnGroupHeaderFocus",m),tR(e,"rowsSet",b),tR(e,"paginationModelChange",_)})(r,t),((e,t)=>{var r;const i=hR(e,"useGridPreferencesPanel"),o=n.useRef(),a=n.useRef(),s=n.useCallback((()=>{i.debug("Hiding Preferences Panel");const t=Lj(e.current.state);t.openedPanelValue&&e.current.publishEvent("preferencePanelClose",{openedPanelValue:t.openedPanelValue}),e.current.setState((e=>(0,O.A)({},e,{preferencePanel:{open:!1}}))),e.current.forceUpdate()}),[e,i]),l=n.useCallback((()=>{a.current=setTimeout((()=>clearTimeout(o.current)),0)}),[]),c=n.useCallback((()=>{o.current=setTimeout(s,100)}),[s]),u=n.useCallback(((t,r,n)=>{i.debug("Opening Preferences Panel"),l(),e.current.setState((e=>(0,O.A)({},e,{preferencePanel:(0,O.A)({},e.preferencePanel,{open:!0,openedPanelValue:t,panelId:r,labelId:n})}))),e.current.publishEvent("preferencePanelOpen",{openedPanelValue:t}),e.current.forceUpdate()}),[i,l,e]);HO(e,{showPreferences:u,hidePreferences:c},"public");const d=n.useCallback(((r,n)=>{var i;const o=Lj(e.current.state);return!n.exportOnlyDirtyModels||null!=(null==(i=t.initialState)?void 0:i.preferencePanel)||o.open?(0,O.A)({},r,{preferencePanel:o}):r}),[e,null==(r=t.initialState)?void 0:r.preferencePanel]),h=n.useCallback(((t,r)=>{const n=r.stateToRestore.preferencePanel;return null!=n&&e.current.setState((e=>(0,O.A)({},e,{preferencePanel:n}))),t}),[e]);ZD(e,"exportState",d),ZD(e,"restoreState",h),n.useEffect((()=>()=>{clearTimeout(o.current),clearTimeout(a.current)}),[])})(r,t),((e,t)=>{var r,i;const o=hR(e,"useGridFilter");e.current.registerControlState({stateId:"filter",propModel:t.filterModel,propOnChange:t.onFilterModelChange,stateSelector:hO,changeEvent:"filterModelChange"});const a=n.useCallback((()=>{e.current.setState((r=>{const n=hO(r,e.current.instanceId),i="client"===t.filterMode?gD(n,e,t.disableEval):null,o=e.current.applyStrategyProcessor("filtering",{isRowMatchingFilters:i,filterModel:null!=n?n:nD()}),a=(0,O.A)({},r,{filter:(0,O.A)({},r.filter,o)}),s=gj(e,a);return(0,O.A)({},a,{visibleRowsLookup:s})})),e.current.publishEvent("filteredRowsSet")}),[e,t.filterMode,t.disableEval]),s=n.useCallback(((e,r)=>null==r||!1===r.filterable||t.disableColumnFilter?e:[...e,"columnMenuFilterItem"]),[t.disableColumnFilter]),l=n.useCallback((()=>{a(),e.current.forceUpdate()}),[e,a]),c=n.useCallback((t=>{const r=hO(e),n=[...r.items],i=n.findIndex((e=>e.id===t.id));-1===i?n.push(t):n[i]=t,e.current.setFilterModel((0,O.A)({},r,{items:n}),"upsertFilterItem")}),[e]),u=n.useCallback((t=>{const r=hO(e),n=[...r.items];t.forEach((e=>{const r=t.findIndex((t=>t.id===e.id));-1===r?n.push(e):n[r]=e})),e.current.setFilterModel((0,O.A)({},r,{items:t}),"upsertFilterItems")}),[e]),d=n.useCallback((t=>{const r=hO(e),n=r.items.filter((e=>e.id!==t.id));n.length!==r.items.length&&e.current.setFilterModel((0,O.A)({},r,{items:n}),"deleteFilterItem")}),[e]),h=n.useCallback(((r,n,i)=>{if(o.debug("Displaying filter panel"),r){const n=hO(e),i=n.items.filter((t=>{var r;if(void 0!==t.value)return!Array.isArray(t.value)||0!==t.value.length;const n=null==(r=e.current.getColumn(t.field).filterOperators)?void 0:r.find((e=>e.value===t.operator));return!("undefined"===typeof(null==n?void 0:n.requiresFilterValue)||(null==n?void 0:n.requiresFilterValue))}));let o;const a=i.find((e=>e.field===r)),s=e.current.getColumn(r);o=a?i:t.disableMultipleColumnsFiltering?[aD({field:r,operator:s.filterOperators[0].value},e)]:[...i,aD({field:r,operator:s.filterOperators[0].value},e)],e.current.setFilterModel((0,O.A)({},n,{items:o}))}e.current.showPreferences(Jz.filters,n,i)}),[e,o,t.disableMultipleColumnsFiltering]),p=n.useCallback((()=>{o.debug("Hiding filter panel"),e.current.hidePreferences()}),[e,o]),f=n.useCallback((t=>{const r=hO(e);r.logicOperator!==t&&e.current.setFilterModel((0,O.A)({},r,{logicOperator:t}),"changeLogicOperator")}),[e]),m=n.useCallback((t=>{const r=hO(e);BO(r.quickFilterValues,t)||e.current.setFilterModel((0,O.A)({},r,{quickFilterValues:[...t]}))}),[e]),g={setFilterLogicOperator:f,unstable_applyFilters:l,deleteFilterItem:d,upsertFilterItem:c,upsertFilterItems:u,setFilterModel:n.useCallback(((r,n)=>{hO(e)!==r&&(o.debug("Setting filter model"),e.current.updateControlState("filter",dD(r,t.disableMultipleColumnsFiltering,e),n),e.current.unstable_applyFilters())}),[e,o,t.disableMultipleColumnsFiltering]),showFilterPanel:h,hideFilterPanel:p,setQuickFilterValues:m,ignoreDiacritics:t.ignoreDiacritics};HO(e,g,"public");const y=n.useCallback(((r,n)=>{var i;const o=hO(e);return n.exportOnlyDirtyModels&&null==t.filterModel&&null==(null==(i=t.initialState)||null==(i=i.filter)?void 0:i.filterModel)&&BO(o,nD())?r:(0,O.A)({},r,{filter:{filterModel:o}})}),[e,t.filterModel,null==(r=t.initialState)||null==(r=r.filter)?void 0:r.filterModel]),v=n.useCallback(((r,n)=>{var i;const o=null==(i=n.stateToRestore.filter)?void 0:i.filterModel;return null==o?r:(e.current.updateControlState("filter",dD(o,t.disableMultipleColumnsFiltering,e),"restoreState"),(0,O.A)({},r,{callbacks:[...r.callbacks,e.current.unstable_applyFilters]}))}),[e,t.disableMultipleColumnsFiltering]),x=n.useCallback(((e,r)=>{if(r===Jz.filters){var n;const e=t.slots.filterPanel;return(0,j.jsx)(e,(0,O.A)({},null==(n=t.slotProps)?void 0:n.filterPanel))}return e}),[t.slots.filterPanel,null==(i=t.slotProps)?void 0:i.filterPanel]),{getRowId:b}=t,_=VI(yj),w=n.useCallback((r=>{if("client"!==t.filterMode||!r.isRowMatchingFilters)return{filteredRowsLookup:{},filteredDescendantCountLookup:{}};const n=DP(e),i={},{isRowMatchingFilters:o}=r,a={},s={passingFilterItems:null,passingQuickFilterValues:null},l=_.current(e.current.state.rows.dataRowIdToModelLookup);for(let t=0;t{o.debug("onColUpdated - GridColumns changed, applying filters");const t=hO(e),r=AP(e),n=t.items.filter((e=>e.field&&r[e.field]));n.length{"filtering"===t&&e.current.unstable_applyFilters()}),[e]),A=n.useCallback((()=>{e.current.setState((t=>(0,O.A)({},t,{visibleRowsLookup:gj(e,t)}))),e.current.forceUpdate()}),[e]);tR(e,"rowsSet",a),tR(e,"columnsChange",k),tR(e,"activeStrategyProcessorChange",S),tR(e,"rowExpansionChange",A),tR(e,"columnVisibilityModelChange",(()=>{const t=hO(e);t.quickFilterValues&&t.quickFilterExcludeHiddenColumns&&e.current.unstable_applyFilters()})),XD((()=>{e.current.unstable_applyFilters()})),(0,$o.A)((()=>{void 0!==t.filterModel&&e.current.setFilterModel(t.filterModel)}),[e,o,t.filterModel])})(r,t),((e,t)=>{var r;const i=hR(e,"useGridSorting");e.current.registerControlState({stateId:"sortModel",propModel:t.sortModel,propOnChange:t.onSortModelChange,stateSelector:cO,changeEvent:"sortModelChange"});const o=n.useCallback(((t,r)=>{const n=cO(e),i=n.findIndex((e=>e.field===t));let o=[...n];return i>-1?r?o.splice(i,1,r):o.splice(i,1):o=[...n,r],o}),[e]),a=n.useCallback(((r,n)=>{var i;const o=cO(e).find((e=>e.field===r.field));if(o){var a;const e=void 0===n?qR(null!=(a=r.sortingOrder)?a:t.sortingOrder,o.sort):n;return null==e?void 0:(0,O.A)({},o,{sort:e})}return{field:r.field,sort:void 0===n?qR(null!=(i=r.sortingOrder)?i:t.sortingOrder):n}}),[e,t.sortingOrder]),s=n.useCallback(((e,r)=>null==r||!1===r.sortable?e:(r.sortingOrder||t.sortingOrder).some((e=>!!e))?[...e,"columnMenuSortItem"]:e),[t.sortingOrder]),l=n.useCallback((()=>{e.current.setState((r=>{if("server"===t.sortingMode)return i.debug("Skipping sorting rows as sortingMode = server"),(0,O.A)({},r,{sorting:(0,O.A)({},r.sorting,{sortedRows:CD(jP(e),_D,!1)})});const n=((e,t)=>{const r=e.map((e=>((e,t)=>{const r=t.current.getColumn(e.field);return r?{getSortCellParams:e=>({id:e,field:r.field,rowNode:t.current.getRowNode(e),value:t.current.getCellValue(e,r.field),api:t.current}),comparator:"desc"===e.sort?function(){return-1*r.sortComparator(...arguments)}:r.sortComparator}:null})(e,t))).filter((e=>!!e));return 0===r.length?null:e=>e.map((e=>({node:e,params:r.map((t=>t.getSortCellParams(e.id)))}))).sort(((e,t)=>{return n=e,i=t,r.reduce(((e,t,r)=>{if(0!==e)return e;const o=n.params[r],a=i.params[r];return t.comparator(o.value,a.value,o,a)}),0);var n,i})).map((e=>e.node.id))})(cO(r,e.current.instanceId),e),o=e.current.applyStrategyProcessor("sorting",{sortRowList:n});return(0,O.A)({},r,{sorting:(0,O.A)({},r.sorting,{sortedRows:o})})})),e.current.publishEvent("sortedRowsSet"),e.current.forceUpdate()}),[e,i,t.sortingMode]),c=n.useCallback((r=>{cO(e)!==r&&(i.debug("Setting sort model"),e.current.setState(WR(r,t.disableMultipleColumnsSorting)),e.current.forceUpdate(),e.current.applySorting())}),[e,i,t.disableMultipleColumnsSorting]),u=n.useCallback(((r,n,i)=>{if(!r.sortable)return;const s=a(r,n);let l;l=!i||t.disableMultipleColumnsSorting?s?[s]:[]:o(r.field,s),e.current.setSortModel(l)}),[e,o,a,t.disableMultipleColumnsSorting]),d=n.useCallback((()=>cO(e)),[e]),h=n.useCallback((()=>lO(e).map((e=>e.model))),[e]),p=n.useCallback((()=>sO(e)),[e]),f=n.useCallback((t=>e.current.getSortedRowIds()[t]),[e]);HO(e,{getSortModel:d,getSortedRows:h,getSortedRowIds:p,getRowIdFromRowIndex:f,setSortModel:c,sortColumn:u,applySorting:l},"public");const m=n.useCallback(((r,n)=>{var i;const o=cO(e);return!n.exportOnlyDirtyModels||null!=t.sortModel||null!=(null==(i=t.initialState)||null==(i=i.sorting)?void 0:i.sortModel)||o.length>0?(0,O.A)({},r,{sorting:{sortModel:o}}):r}),[e,t.sortModel,null==(r=t.initialState)||null==(r=r.sorting)?void 0:r.sortModel]),g=n.useCallback(((r,n)=>{var i;const o=null==(i=n.stateToRestore.sorting)?void 0:i.sortModel;return null==o?r:(e.current.setState(WR(o,t.disableMultipleColumnsSorting)),(0,O.A)({},r,{callbacks:[...r.callbacks,e.current.applySorting]}))}),[e,t.disableMultipleColumnsSorting]),y=n.useCallback((t=>{const r=jP(e),n=r[_D],i=t.sortRowList?t.sortRowList(n.children.map((e=>r[e]))):[...n.children];return null!=n.footerId&&i.push(n.footerId),i}),[e]);ZD(e,"exportState",m),ZD(e,"restoreState",g),pj(e,lR,"sorting",y);const v=n.useCallback(((e,t)=>{let{colDef:r}=e;const n=t.shiftKey||t.metaKey||t.ctrlKey;u(r,void 0,n)}),[u]),x=n.useCallback(((e,t)=>{let{colDef:r}=e;!fR(t.key)||t.ctrlKey||t.metaKey||u(r,void 0,t.shiftKey)}),[u]),b=n.useCallback((()=>{const t=cO(e),r=yP(e);if(t.length>0){const n=t.filter((e=>r[e.field]));n.length{"sorting"===t&&e.current.applySorting()}),[e]);ZD(e,"columnMenu",s),tR(e,"columnHeaderClick",v),tR(e,"columnHeaderKeyDown",x),tR(e,"rowsSet",e.current.applySorting),tR(e,"columnsChange",b),tR(e,"activeStrategyProcessorChange",_),XD((()=>{e.current.applySorting()})),(0,$o.A)((()=>{void 0!==t.sortModel&&e.current.setSortModel(t.sortModel)}),[e,t.sortModel])})(r,t),((e,t)=>{const r=hR(e,"useDensity"),i=n.useCallback((t=>{r.debug(`Set grid density to ${t}`),e.current.setState((e=>{const r=hP(e),n={value:t,factor:tj[t]};return BO(r,n)?e:(0,O.A)({},e,{density:n})})),e.current.forceUpdate()}),[r,e]);n.useEffect((()=>{e.current.setDensity(t.density)}),[e,t.density]),HO(e,{setDensity:i},"public")})(r,t),Rj(r,t),((e,t)=>{const{getRowHeight:r,getRowSpacing:i,getEstimatedRowHeight:o}=t,a=n.useRef(Object.create(null)),s=n.useRef(-1),l=n.useRef(!1),c=KI(e,fP),u=KI(e,hO),d=KI(e,ER),h=KI(e,cO),p=xj(e,t),f=KI(e,UP),m=f$(t.rowHeight,u$.rowHeight),g=Math.floor(m*c),y=n.useCallback((()=>{var t,n;l.current=!1;const u=t=>{a.current[t.id]||(a.current[t.id]={sizes:{baseCenter:g},isResized:!1,autoHeight:!1,needsFirstMeasurement:!0});const{isResized:n,needsFirstMeasurement:s,sizes:u}=a.current[t.id];let d="number"===typeof g&&g>0?g:52;const h=u.baseCenter;if(n)d=h;else if(r){const e=r((0,O.A)({},t,{densityFactor:c}));if("auto"===e){if(s){const e=o?o((0,O.A)({},t,{densityFactor:c})):g;d=null!=e?e:g}else d=h;l.current=!0,a.current[t.id].autoHeight=!0}else d=f$(e,g),a.current[t.id].needsFirstMeasurement=!1,a.current[t.id].autoHeight=!1}else a.current[t.id].needsFirstMeasurement=!1;const f={};for(const e in u)/^base[A-Z]/.test(e)&&(f[e]=u[e]);if(f.baseCenter=d,i){var m,y;const r=e.current.getRowIndexRelativeToVisibleRows(t.id),n=i((0,O.A)({},t,{isFirstVisible:0===r,isLastVisible:r===p.rows.length-1,indexRelativeToCurrentPage:r}));f.spacingTop=null!=(m=n.top)?m:0,f.spacingBottom=null!=(y=n.bottom)?y:0}const v=e.current.unstable_applyPipeProcessors("rowHeight",f,t);return a.current[t.id].sizes=v,v},d=[],h=p.rows.reduce(((e,t)=>{d.push(e);let r=0,n=0;const i=u(t);for(const o in i){const e=i[o];/^base[A-Z]/.test(o)?r=e>r?e:r:n+=e}return e+r+n}),0);null==f||null==(t=f.top)||t.forEach((e=>{u(e)})),null==f||null==(n=f.bottom)||n.forEach((e=>{u(e)})),e.current.setState((e=>(0,O.A)({},e,{rowsMeta:{currentPageTotalHeight:h,positions:d}}))),l.current||(s.current=1/0),e.current.forceUpdate()}),[e,p.rows,g,r,i,o,f,c]),v=n.useCallback((e=>{const t=a.current[e];return t?t.sizes.baseCenter:g}),[g]),x=n.useCallback(((e,t)=>{a.current[e].sizes.baseCenter=t,a.current[e].isResized=!0,a.current[e].needsFirstMeasurement=!1,y()}),[y]),b=n.useMemo((()=>(0,TE.A)(y,t.rowPositionsDebounceMs)),[y,t.rowPositionsDebounceMs]),_=n.useCallback(((e,t,r)=>{if(!a.current[e]||!a.current[e].autoHeight)return;const n=a.current[e].sizes[`base${(0,MI.A)(r)}`]!==t;a.current[e].needsFirstMeasurement=!1,a.current[e].sizes[`base${(0,MI.A)(r)}`]=t,n&&b()}),[b]),w=n.useCallback((e=>{var t;return(null==(t=a.current[e])?void 0:t.autoHeight)||!1}),[]),k=n.useCallback((()=>s.current),[]),S=n.useCallback((e=>{l.current&&e>s.current&&(s.current=e)}),[]),A=n.useCallback((()=>{a.current={},y()}),[y]);n.useEffect((()=>{y()}),[g,u,d,h,y]),KD(e,"rowHeight",y);const T={getLastMeasuredRowIndex:k,rowHasAutoHeight:w};HO(e,{unstable_setLastMeasuredRowIndex:S,unstable_getRowHeight:v,unstable_getRowInternalSizes:e=>{var t;return null==(t=a.current[e])?void 0:t.sizes},unstable_setRowHeight:x,unstable_storeRowHeightMeasurement:_,resetRowHeights:A},"public"),HO(e,T,"private")})(r,t),((e,t)=>{const r=Io(),i=hR(e,"useGridScroll"),o=e.current.columnHeadersElementRef,a=e.current.virtualScrollerRef,s=KI(e,fO),l=n.useCallback((r=>{const n=OP(e),o=bP(e);if(null!=r.rowIndex&&0===n||0===o.length)return!1;i.debug(`Scrolling to cell at row ${r.rowIndex}, col: ${r.colIndex} `);let l={};if(null!=r.colIndex){const t=wP(e);let n;if("undefined"!==typeof r.rowIndex){var c;const t=null==(c=s[r.rowIndex])?void 0:c.id,i=e.current.unstable_getCellColSpanInfo(t,r.colIndex);i&&!i.spannedByColSpan&&(n=i.cellProps.width)}"undefined"===typeof n&&(n=o[r.colIndex].computedWidth),l.left=rF({clientHeight:a.current.clientWidth,scrollTop:Math.abs(a.current.scrollLeft),offsetHeight:n,offsetTop:t[r.colIndex]})}if(null!=r.rowIndex){var u,d;const n=uj(e.current.state),i=OR(e),o=RR(e),s=t.pagination?r.rowIndex-i*o:r.rowIndex,c=n.positions[s+1]?n.positions[s+1]-n.positions[s]:n.currentPageTotalHeight-n.positions[s],h=(null==(u=a.current.querySelector(`.${zI["pinnedRows--top"]}`))?void 0:u.clientHeight)||0,p=(null==(d=a.current.querySelector(`.${zI["pinnedRows--bottom"]}`))?void 0:d.clientHeight)||0;l.top=rF({clientHeight:a.current.clientHeight-h-p,scrollTop:a.current.scrollTop,offsetHeight:c,offsetTop:n.positions[s]})}return l=e.current.unstable_applyPipeProcessors("scrollToIndexes",l,r),(void 0!==typeof l.left||void 0!==typeof l.top)&&(e.current.scroll(l),!0)}),[i,e,a,t.pagination,s]),c=n.useCallback((e=>{if(a.current&&null!=e.left&&o.current){const t="rtl"===r.direction?-1:1;o.current.scrollLeft=e.left,a.current.scrollLeft=t*e.left,i.debug(`Scrolling left: ${e.left}`)}a.current&&null!=e.top&&(a.current.scrollTop=e.top,i.debug(`Scrolling top: ${e.top}`)),i.debug("Scrolling, updating container, and viewport")}),[a,r.direction,o,i]),u=n.useCallback((()=>null!=a&&a.current?{top:a.current.scrollTop,left:a.current.scrollLeft}:{top:0,left:0}),[a]);HO(e,{scroll:c,scrollToIndexes:l,getScrollPosition:u},"public")})(r,t),(e=>{const t=hR(e,"useGridColumnMenu"),r=n.useCallback((r=>{e.current.setState((e=>e.columnMenu.open&&e.columnMenu.field===r?e:(t.debug("Opening Column Menu"),(0,O.A)({},e,{columnMenu:{open:!0,field:r}}))))&&(e.current.hidePreferences(),e.current.forceUpdate())}),[e,t]),i=n.useCallback((()=>{const r=PO(e.current.state);if(r.field){const t=yP(e),n=xP(e),i=gP(e);let o=r.field;if(t[o]||(o=i[0]),!1===n[o]){const e=i.filter((e=>e===o||!1!==n[e])),t=e.indexOf(o);o=e[t+1]||e[t-1]}e.current.setColumnHeaderFocus(o)}e.current.setState((e=>e.columnMenu.open||void 0!==e.columnMenu.field?(t.debug("Hiding Column Menu"),(0,O.A)({},e,{columnMenu:(0,O.A)({},e.columnMenu,{open:!1,field:void 0})})):e))&&e.current.forceUpdate()}),[e,t]),o=n.useCallback((n=>{t.debug("Toggle Column Menu");const o=PO(e.current.state);o.open&&o.field===n?i():r(n)}),[e,t,r,i]);HO(e,{showColumnMenu:r,hideColumnMenu:i,toggleColumnMenu:o},"public"),tR(e,"columnResizeStart",i),tR(e,"virtualScrollerWheel",e.current.hideColumnMenu),tR(e,"virtualScrollerTouchMove",e.current.hideColumnMenu)})(r),cj(r,t),hj(r,t),GD(r,t),function(e,t){const r=hR(e,"useResizeContainer"),i=n.useRef(!1),o=n.useRef(null),a=n.useRef(null),s=KI(e,uj),l=KI(e,fP),c=Math.floor(t.rowHeight*l),u=Kz(e,t.columnHeaderHeight),d=n.useCallback((()=>{var r;const n=null==(r=e.current.rootElementRef)?void 0:r.current,i=kP(e),l=ED(e);if(!o.current)return;let c,d,h,p;if(null!=t.scrollbarSize)c=t.scrollbarSize;else if(i&&n){const e=(0,No.A)(n).createElement("div");e.style.width="99px",e.style.height="99px",e.style.position="absolute",e.style.overflow="scroll",e.className="scrollDiv",n.appendChild(e),c=e.offsetWidth-e.clientWidth,n.removeChild(e)}else c=0;if(t.autoHeight)p=!1,h=Math.round(i)>Math.round(o.current.width),d={width:o.current.width,height:s.currentPageTotalHeight+(h?c:0)};else{d={width:o.current.width,height:Math.max(o.current.height-u,0)};const e=(e=>{let{content:t,container:r,scrollBarSize:n}=e;const i=t.width>r.width,o=t.height>r.height;let a=!1,s=!1;return(i||o)&&(a=i,s=t.height+(a?n:0)>r.height,s&&(a=t.width+n>r.width)),{hasScrollX:a,hasScrollY:s}})({content:{width:Math.round(i),height:s.currentPageTotalHeight},container:{width:Math.round(d.width),height:d.height-l.top-l.bottom},scrollBarSize:c});p=e.hasScrollY,h=e.hasScrollX}const f={viewportOuterSize:d,viewportInnerSize:{width:d.width-(p?c:0),height:d.height-(h?c:0)},hasScrollX:h,hasScrollY:p,scrollBarSize:c},m=a.current;a.current=f,f.viewportInnerSize.width===(null==m?void 0:m.viewportInnerSize.width)&&f.viewportInnerSize.height===(null==m?void 0:m.viewportInnerSize.height)||e.current.publishEvent("viewportInnerSizeChange",f.viewportInnerSize)}),[e,t.scrollbarSize,t.autoHeight,s.currentPageTotalHeight,u]),[h,p]=n.useState(),f=n.useMemo((()=>(0,TE.A)(p,60)),[]),m=n.useRef();(0,$o.A)((()=>{h&&(d(),e.current.publishEvent("debouncedResize",o.current))}),[e,h,d]);const g=n.useCallback((()=>{e.current.computeSizeAndPublishResizeEvent()}),[e]),y=n.useCallback((()=>a.current),[]),v=n.useCallback((()=>{const r=e.current.getRootDimensions();if(!r)return 0;const n=vj(e,{pagination:t.pagination,paginationMode:t.paginationMode});if(t.getRowHeight){const t=e.current.getRenderContext(),r=t.lastRowIndex-t.firstRowIndex;return Math.min(r-1,n.rows.length)}const i=Math.floor(r.viewportInnerSize.height/c);return Math.min(i,n.rows.length)}),[e,t.pagination,t.paginationMode,t.getRowHeight,c]),x=n.useCallback((()=>{var t,r,n;const i=null==(t=e.current.mainElementRef)?void 0:t.current;if(!i)return;const o=(0,ra.A)(i).getComputedStyle(i),a=parseFloat(o.height)||0,s=parseFloat(o.width)||0,l=a!==(null==(r=m.current)?void 0:r.height),c=s!==(null==(n=m.current)?void 0:n.width);if(!m.current||l||c){const t={width:s,height:a};e.current.publishEvent("resize",t),m.current=t}}),[e]),b={getViewportPageSize:v,updateGridDimensionsRef:d,computeSizeAndPublishResizeEvent:x};HO(e,{resize:g,getRootDimensions:y},"public"),HO(e,b,"private");const _=n.useRef(!0),w=n.useCallback((e=>{o.current=e;const n=/jsdom/.test(window.navigator.userAgent);if(0!==e.height||i.current||t.autoHeight||n||(r.error(["The parent DOM element of the data grid has an empty height.","Please make sure that this element has an intrinsic height.","The grid displays with a height of 0px.","","More details: https://mui.com/r/x-data-grid-no-dimensions."].join("\n")),i.current=!0),0!==e.width||i.current||n||(r.error(["The parent DOM element of the data grid has an empty width.","Please make sure that this element has an intrinsic width.","The grid displays with a width of 0px.","","More details: https://mui.com/r/x-data-grid-no-dimensions."].join("\n")),i.current=!0),_.current)return p(e),void(_.current=!1);f(e)}),[t.autoHeight,f,r]);(0,$o.A)((()=>d()),[d]),nR(e,"sortedRowsSet",d),nR(e,"paginationModelChange",d),nR(e,"columnsChange",d),tR(e,"resize",w),nR(e,"debouncedResize",t.onResize)}(r,t),function(e,t){nR(e,"columnHeaderClick",t.onColumnHeaderClick),nR(e,"columnHeaderDoubleClick",t.onColumnHeaderDoubleClick),nR(e,"columnHeaderOver",t.onColumnHeaderOver),nR(e,"columnHeaderOut",t.onColumnHeaderOut),nR(e,"columnHeaderEnter",t.onColumnHeaderEnter),nR(e,"columnHeaderLeave",t.onColumnHeaderLeave),nR(e,"cellClick",t.onCellClick),nR(e,"cellDoubleClick",t.onCellDoubleClick),nR(e,"cellKeyDown",t.onCellKeyDown),nR(e,"preferencePanelClose",t.onPreferencePanelClose),nR(e,"preferencePanelOpen",t.onPreferencePanelOpen),nR(e,"menuOpen",t.onMenuOpen),nR(e,"menuClose",t.onMenuClose),nR(e,"rowDoubleClick",t.onRowDoubleClick),nR(e,"rowClick",t.onRowClick),nR(e,"stateChange",t.onStateChange)}(r,t),(e=>{const t=n.useCallback((function(){let t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return e.current.unstable_applyPipeProcessors("exportState",{},t)}),[e]),r=n.useCallback((t=>{e.current.unstable_applyPipeProcessors("restoreState",{callbacks:[]},{stateToRestore:t}).callbacks.forEach((e=>{e()})),e.current.forceUpdate()}),[e]);HO(e,{exportState:t,restoreState:r},"public")})(r),function(e,t){const r=t=>{e.current.setState((e=>(0,O.A)({},e,{virtualization:(0,O.A)({},e.virtualization,{enabled:t})})))},i={unstable_setVirtualization:r,unstable_setColumnVirtualization:t=>{e.current.setState((e=>(0,O.A)({},e,{virtualization:(0,O.A)({},e.virtualization,{enabledForColumns:t})})))}};HO(e,i,"public"),n.useEffect((()=>{r(!t.disableVirtualization)}),[t.disableVirtualization])}(r,t),r},S$=nO("div",{name:"MuiDataGrid",slot:"VirtualScroller",overridesResolver:(e,t)=>t.virtualScroller})({overflow:"auto",height:"100%",position:"relative","@media print":{overflow:"hidden"},zIndex:0}),A$=n.forwardRef((function(e,t){const r=tP(),n=(e=>{const{classes:t}=e;return(0,mn.A)({root:["virtualScroller"]},DI,t)})(r);return(0,j.jsx)(S$,(0,O.A)({ref:t},e,{className:(0,fn.A)(n.root,e.className),ownerState:r}))})),T$=nO("div",{name:"MuiDataGrid",slot:"VirtualScrollerContent",overridesResolver:(e,t)=>t.virtualScrollerContent})({}),M$=n.forwardRef((function(e,t){var r;const n=tP(),i=((e,t)=>{const{classes:r}=e,n={root:["virtualScrollerContent",t&&"virtualScrollerContent--overflowed"]};return(0,mn.A)(n,DI,r)})(n,!n.autoHeight&&"auto"===(null==(r=e.style)?void 0:r.minHeight));return(0,j.jsx)(T$,(0,O.A)({ref:t},e,{ownerState:n,className:(0,fn.A)(i.root,e.className)}))})),C$=["className"],E$=nO("div",{name:"MuiDataGrid",slot:"VirtualScrollerRenderZone",overridesResolver:(e,t)=>t.virtualScrollerRenderZone})({position:"absolute",display:"flex",flexDirection:"column"}),I$=n.forwardRef((function(e,t){const{className:r}=e,n=(0,R.A)(e,C$),i=tP(),o=(e=>{const{classes:t}=e;return(0,mn.A)({root:["virtualScrollerRenderZone"]},DI,t)})(i);return(0,j.jsx)(E$,(0,O.A)({ref:t,className:(0,fn.A)(o.root,r),ownerState:i},n))})),P$=nO("div",{name:"MuiDataGrid",slot:"OverlayWrapper",shouldForwardProp:e=>"overlayType"!==e,overridesResolver:(e,t)=>t.overlayWrapper})((e=>{let{overlayType:t}=e;return{position:"sticky",top:0,left:0,width:0,height:0,zIndex:"loadingOverlay"===t?5:4}})),O$=nO("div",{name:"MuiDataGrid",slot:"OverlayWrapperInner",shouldForwardProp:e=>"overlayType"!==e,overridesResolver:(e,t)=>t.overlayWrapperInner})({});function R$(e){var t,r;const i=xR(),o=tP(),[a,s]=n.useState((()=>{var e,t;return null!=(e=null==(t=i.current.getRootDimensions())?void 0:t.viewportInnerSize)?e:null})),l=n.useCallback((()=>{var e,t;s(null!=(e=null==(t=i.current.getRootDimensions())?void 0:t.viewportInnerSize)?e:null)}),[i]);(0,$o.A)((()=>i.current.subscribeEvent("viewportInnerSizeChange",l)),[i,l]);let c=null!=(t=null==a?void 0:a.height)?t:0;o.autoHeight&&0===c&&(c=ID(i,o.rowHeight));const u=(e=>{const{classes:t}=e;return(0,mn.A)({root:["overlayWrapper"],inner:["overlayWrapperInner"]},DI,t)})((0,O.A)({},e,{classes:o.classes}));return a?(0,j.jsx)(P$,{className:(0,fn.A)(u.root),overlayType:e.overlayType,children:(0,j.jsx)(O$,(0,O.A)({className:(0,fn.A)(u.inner),style:{height:c,width:null!=(r=null==a?void 0:a.width)?r:0}},e))}):null}function L$(){const e=xR(),t=tP(),r=KI(e,OP),n=KI(e,xO),i=KI(e,RP),o=!i&&r>0&&0===n;let a=null,s="";var l,c,u;i||0!==r||(a=(0,j.jsx)(t.slots.noRowsOverlay,(0,O.A)({},null==(l=t.slotProps)?void 0:l.noRowsOverlay)),s="noRowsOverlay");o&&(a=(0,j.jsx)(t.slots.noResultsOverlay,(0,O.A)({},null==(c=t.slotProps)?void 0:c.noResultsOverlay)),s="noResultsOverlay");i&&(a=(0,j.jsx)(t.slots.loadingOverlay,(0,O.A)({},null==(u=t.slotProps)?void 0:u.loadingOverlay)),s="loadingOverlay");return null===a?null:(0,j.jsx)(R$,{overlayType:s,children:a})}const D$=["className"],z$=n.forwardRef((function(e,t){const{className:r}=e,i=(0,R.A)(e,D$),{getRootProps:o,getContentProps:a,getRenderZoneProps:l,getRows:c}=(e=>{const t=QI(),r=tP(),i=KI(t,bP),o=KI(t,YV),a=KI(t,XV),{ref:l,onRenderZonePositioning:c,renderZoneMinColumnIndex:u=0,renderZoneMaxColumnIndex:d=i.length,getRowProps:h}=e,p=Io(),f=KI(t,wP),m=KI(t,kP),g=KI(t,SO),y=KI(t,CO),v=KI(t,uj),x=KI(t,AR),b=xj(t,r),_=n.useRef(null),w=n.useRef(null),k=(0,Gi.A)(l,w),[S,A]=n.useState(null),T=n.useRef(S),M=n.useRef({top:0,left:0}),[C,E]=n.useState({width:null,height:null}),I=n.useRef(m),[P,L]=n.useState(null),D=n.useRef(Object.create(null)),z=n.useRef(),F=n.useRef(),N=n.useRef(iP(((e,t,r,n,i,o)=>{let a;return o>-1&&(t>o&&o>=n||rnull!==g?i.findIndex((e=>e.field===g.field)):-1),[g,i]),V=n.useCallback((()=>{if(!o)return{firstRowIndex:0,lastRowIndex:b.rows.length,firstColumnIndex:0,lastColumnIndex:i.length};const{top:e,left:n}=M.current,s=Math.min(rU(t,b,v,e),v.positions.length-1),l=r.autoHeight?s+b.rows.length:rU(t,b,v,e+C.height);let c=0,u=f.length;if(a){let e=!1;const[i,o]=QV({firstIndex:s,lastIndex:l,minFirstIndex:0,maxLastIndex:b.rows.length,buffer:r.rowBuffer});for(let r=i;r{o?(w.current.scrollLeft=0,w.current.scrollTop=0):_.current.style.transform="translate3d(0px, 0px, 0px)"}),[o]),(0,$o.A)((()=>{E({width:w.current.clientWidth,height:w.current.clientHeight})}),[v.currentPageTotalHeight]);const U=n.useCallback((()=>{w.current&&E({width:w.current.clientWidth,height:w.current.clientHeight})}),[]);tR(t,"debouncedResize",U);const H=n.useCallback((e=>{const[n,i]=QV({firstIndex:e.firstRowIndex,lastIndex:e.lastRowIndex,minFirstIndex:0,maxLastIndex:b.rows.length,buffer:r.rowBuffer}),[o]=QV({firstIndex:e.firstColumnIndex,lastIndex:e.lastColumnIndex,minFirstIndex:u,maxLastIndex:d,buffer:r.columnBuffer}),a=Xz({firstColumnToRender:o,apiRef:t,firstRowToRender:n,lastRowToRender:i,visibleRows:b.rows}),s="ltr"===p.direction?1:-1,l=uj(t.current.state).positions[n],h=s*wP(t)[a];_.current.style.transform=`translate3d(${h}px, ${l}px, 0px)`,"function"===typeof c&&c({top:l,left:h})}),[t,b.rows,c,u,d,r.columnBuffer,r.rowBuffer,p.direction]),$=n.useCallback((()=>T.current),[]),W=n.useCallback((e=>{if(T.current&&eU(e,T.current))return void H(e);A(e),H(e);const[n,i]=QV({firstIndex:e.firstRowIndex,lastIndex:e.lastRowIndex,minFirstIndex:0,maxLastIndex:b.rows.length,buffer:r.rowBuffer});t.current.publishEvent("renderedRowsIntervalChange",{firstRowToRender:n,lastRowToRender:i}),T.current=e}),[t,A,T,b.rows.length,r.rowBuffer,H]);(0,$o.A)((()=>{if(null==C.width)return;const e=V();W(e);const{top:r,left:n}=M.current,i={top:r,left:n,renderContext:e};t.current.publishEvent("scrollPositionChange",i)}),[t,V,C.width,W]);const q=(0,ea.A)((e=>{const{scrollTop:n,scrollLeft:i}=e.currentTarget;if(M.current.top=n,M.current.left=i,!T.current||n<0)return;if("ltr"===p.direction&&i<0)return;if("rtl"===p.direction&&i>0)return;const a=o?V():T.current,l=Math.abs(a.firstRowIndex-T.current.firstRowIndex),c=Math.abs(a.lastRowIndex-T.current.lastRowIndex),u=Math.abs(a.firstColumnIndex-T.current.firstColumnIndex),d=Math.abs(a.lastColumnIndex-T.current.lastColumnIndex),h=l>=r.rowThreshold||c>=r.rowThreshold||u>=r.columnThreshold||d>=r.columnThreshold||I.current!==m;t.current.publishEvent("scrollPositionChange",{top:n,left:i,renderContext:h?a:T.current},e),h&&(s.flushSync((()=>{W(a)})),I.current=m)})),G=(0,ea.A)((e=>{t.current.publishEvent("virtualScrollerWheel",{},e)})),Y=(0,ea.A)((e=>{t.current.publishEvent("virtualScrollerTouchMove",{},e)})),X=n.useMemo((()=>null!==g?b.rows.findIndex((e=>e.id===g.id)):-1),[g,b.rows]);tR(t,"rowMouseOver",((e,t)=>{var r;t.currentTarget.contains(t.relatedTarget)||L(null!=(r=e.id)?r:null)})),tR(t,"rowMouseOut",((e,t)=>{t.currentTarget.contains(t.relatedTarget)||L(null)}));const Z=C.width&&m>=C.width,K=n.useMemo((()=>{const e=Math.max(v.currentPageTotalHeight,1);let n=!1;null!=w&&w.current&&e<=(null==w?void 0:w.current.clientHeight)&&(n=!0);const i={width:Z?m:"auto",height:e,minHeight:n?"100%":"auto"};return r.autoHeight&&0===b.rows.length&&(i.height=ID(t,r.rowHeight)),i}),[t,w,m,v.currentPageTotalHeight,Z,r.autoHeight,r.rowHeight,b.rows.length]);n.useEffect((()=>{t.current.publishEvent("virtualScrollerContentSizeChange")}),[t,K]);const J=n.useMemo((()=>{const e={};return Z||(e.overflowX="hidden"),r.autoHeight&&(e.overflowY="hidden"),e}),[Z,r.autoHeight]);return t.current.register("private",{getRenderContext:$}),{renderContext:S,updateRenderZonePosition:H,getRows:function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{renderContext:S};var n;const{onRowRender:a,renderContext:s,minFirstColumn:l=u,maxLastColumn:c=d,availableSpace:p=C.width,rowIndexOffset:f=0,position:m="center"}=e;if(!s||null==p)return null;const v=o?r.rowBuffer:0,_=o?r.columnBuffer:0,[w,k]=QV({firstIndex:s.firstRowIndex,lastIndex:s.lastRowIndex,minFirstIndex:0,maxLastIndex:b.rows.length,buffer:v}),A=[];if(e.rows)e.rows.forEach((e=>{A.push(e),t.current.calculateColSpan({rowId:e.id,minFirstColumn:l,maxLastColumn:c,columns:i})}));else{if(!b.range)return null;for(let e=w;e-1){const e=b.rows[X];(w>X||kw?A.push(e):A.unshift(e),t.current.calculateColSpan({rowId:e.id,minFirstColumn:l,maxLastColumn:c,columns:i}))}const[M,E]=QV({firstIndex:s.firstColumnIndex,lastIndex:s.lastColumnIndex,minFirstIndex:l,maxLastIndex:c,buffer:_}),I=Xz({firstColumnToRender:M,apiRef:t,firstRowToRender:w,lastRowToRender:k,visibleRows:b.rows});let L=!1;(I>B||E0&&void 0!==arguments[0]?arguments[0]:{};return(0,O.A)({ref:k,onScroll:q,onWheel:G,onTouchMove:Y},e,{style:e.style?(0,O.A)({},e.style,J):J,role:"presentation"})},getContentProps:function(){let{style:e}=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return{style:e?(0,O.A)({},e,K):K,role:"presentation"}},getRenderZoneProps:()=>({ref:_,role:"rowgroup"})}})({ref:t});return(0,j.jsxs)(A$,(0,O.A)({className:r},o(i),{children:[(0,j.jsx)(L$,{}),(0,j.jsx)(M$,(0,O.A)({},a(),{children:(0,j.jsx)(I$,(0,O.A)({},l(),{children:c()}))}))]}))})),j$=n.forwardRef((function(e,t){const r=h$(e),n=k$(r.apiRef,r);return(0,j.jsx)(DO,{privateApiRef:n,props:r,children:(0,j.jsxs)(qP,(0,O.A)({className:r.className,style:r.style,sx:r.sx,ref:t},r.forwardedProps,{children:[(0,j.jsx)(GP,{}),(0,j.jsx)(OO,{VirtualScrollerComponent:z$}),(0,j.jsx)(RO,{})]}))})})),F$=n.memo(j$);j$.propTypes={apiRef:TI().shape({current:TI().object.isRequired}),"aria-label":TI().string,"aria-labelledby":TI().string,autoHeight:TI().bool,autoPageSize:TI().bool,cellModesModel:TI().object,checkboxSelection:TI().bool,classes:TI().object,clipboardCopyCellDelimiter:TI().string,columnBuffer:TI().number,columnGroupingModel:TI().arrayOf(TI().object),columnHeaderHeight:TI().number,columns:(TI().array.isRequired,()=>null),columnThreshold:TI().number,columnVisibilityModel:TI().object,components:TI().object,componentsProps:TI().object,density:TI().oneOf(["comfortable","compact","standard"]),disableColumnFilter:TI().bool,disableColumnMenu:TI().bool,disableColumnSelector:TI().bool,disableDensitySelector:TI().bool,disableEval:TI().bool,disableRowSelectionOnClick:TI().bool,disableVirtualization:TI().bool,editMode:TI().oneOf(["cell","row"]),experimentalFeatures:TI().shape({ariaV7:TI().bool,columnGrouping:TI().bool,warnIfFocusStateIsNotSynced:TI().bool}),filterDebounceMs:TI().number,filterMode:TI().oneOf(["client","server"]),filterModel:TI().shape({items:TI().arrayOf(TI().shape({field:TI().string.isRequired,id:TI().oneOfType([TI().number,TI().string]),operator:TI().string.isRequired,value:TI().any})).isRequired,logicOperator:TI().oneOf(["and","or"]),quickFilterExcludeHiddenColumns:TI().bool,quickFilterLogicOperator:TI().oneOf(["and","or"]),quickFilterValues:TI().array}),forwardedProps:TI().object,getCellClassName:TI().func,getDetailPanelContent:TI().func,getEstimatedRowHeight:TI().func,getRowClassName:TI().func,getRowHeight:TI().func,getRowId:TI().func,getRowSpacing:TI().func,hideFooter:TI().bool,hideFooterPagination:TI().bool,hideFooterSelectedRowCount:TI().bool,ignoreDiacritics:TI().bool,initialState:TI().object,isCellEditable:TI().func,isRowSelectable:TI().func,keepNonExistentRowsSelected:TI().bool,loading:TI().bool,localeText:TI().object,logger:TI().shape({debug:TI().func.isRequired,error:TI().func.isRequired,info:TI().func.isRequired,warn:TI().func.isRequired}),logLevel:TI().oneOf(["debug","error","info","warn",!1]),nonce:TI().string,onCellClick:TI().func,onCellDoubleClick:TI().func,onCellEditStart:TI().func,onCellEditStop:TI().func,onCellKeyDown:TI().func,onCellModesModelChange:TI().func,onClipboardCopy:TI().func,onColumnHeaderClick:TI().func,onColumnHeaderDoubleClick:TI().func,onColumnHeaderEnter:TI().func,onColumnHeaderLeave:TI().func,onColumnHeaderOut:TI().func,onColumnHeaderOver:TI().func,onColumnOrderChange:TI().func,onColumnVisibilityModelChange:TI().func,onFilterModelChange:TI().func,onMenuClose:TI().func,onMenuOpen:TI().func,onPaginationModelChange:TI().func,onPreferencePanelClose:TI().func,onPreferencePanelOpen:TI().func,onProcessRowUpdateError:TI().func,onResize:TI().func,onRowClick:TI().func,onRowCountChange:TI().func,onRowDoubleClick:TI().func,onRowEditStart:TI().func,onRowEditStop:TI().func,onRowModesModelChange:TI().func,onRowSelectionModelChange:TI().func,onSortModelChange:TI().func,onStateChange:TI().func,pageSizeOptions:TI().arrayOf(TI().oneOfType([TI().number,TI().shape({label:TI().string.isRequired,value:TI().number.isRequired})]).isRequired),pagination:e=>!1===e.pagination?new Error(["MUI: `` is not a valid prop.","Infinite scrolling is not available in the MIT version.","","You need to upgrade to DataGridPro or DataGridPremium component to disable the pagination."].join("\n")):null,paginationMode:TI().oneOf(["client","server"]),paginationModel:TI().shape({page:TI().number.isRequired,pageSize:TI().number.isRequired}),processRowUpdate:TI().func,rowBuffer:TI().number,rowCount:TI().number,rowHeight:TI().number,rowModesModel:TI().object,rowPositionsDebounceMs:TI().number,rows:TI().arrayOf(TI().object).isRequired,rowSelection:TI().bool,rowSelectionModel:TI().oneOfType([TI().arrayOf(TI().oneOfType([TI().number,TI().string]).isRequired),TI().number,TI().string]),rowSpacingType:TI().oneOf(["border","margin"]),rowThreshold:TI().number,scrollbarSize:TI().number,showCellVerticalBorder:TI().bool,showColumnVerticalBorder:TI().bool,slotProps:TI().object,slots:TI().object,sortingMode:TI().oneOf(["client","server"]),sortingOrder:TI().arrayOf(TI().oneOf(["asc","desc"])),sortModel:TI().arrayOf(TI().shape({field:TI().string.isRequired,sort:TI().oneOf(["asc","desc"])})),sx:TI().oneOfType([TI().arrayOf(TI().oneOfType([TI().func,TI().object,TI().bool])),TI().func,TI().object]),unstable_ignoreValueFormatterDuringExport:TI().oneOfType([TI().shape({clipboardExport:TI().bool,csvExport:TI().bool}),TI().bool])};const N$=(0,yn.Ay)("input",{shouldForwardProp:e=>"error"!==e})((e=>{let{error:t}=e;return{width:250,height:24,borderRadius:4,border:"1px solid",borderColor:t?"red":"#d9d9d9",padding:"5px 10px",marginBottom:15,transition:"all 0.3s",outline:"none",":focus, :hover":{borderColor:"#1677ff"}}})),B$=(0,yn.Ay)(Hi)({fontSize:12,minHeight:18,color:"red",lineHeight:"14px",margin:"-14px 0px 0px 305px",wordBreak:"break-word"}),V$=e=>{let{errorMessage:t,onChange:r,value:n,type:i,onBlur:o,name:a}=e;return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(N$,{autoComplete:"Off",error:!!t,onChange:r,value:n,type:i,name:a,onBlur:o}),(0,j.jsx)(B$,{children:t})]})},U$=["className","children","classes","IconComponent","input","inputProps","variant"],H$=["root"],$$=(0,j.jsx)(eI,{}),W$=n.forwardRef((function(e,t){const r=(0,vn.b)({name:"MuiNativeSelect",props:e}),{className:i,children:o,classes:a={},IconComponent:s=ML,input:l=$$,inputProps:c}=r,u=(0,R.A)(r,U$),d=PE({props:r,muiFormControl:RE(),states:["variant"]}),h=(e=>{const{classes:t}=e;return(0,mn.A)({root:["root"]},aN,t)})((0,O.A)({},r,{classes:a})),p=(0,R.A)(a,H$);return(0,j.jsx)(n.Fragment,{children:n.cloneElement(l,(0,O.A)({inputComponent:pN,inputProps:(0,O.A)({children:o,classes:p,IconComponent:s,variant:d.variant,type:void 0},c,l?l.props.inputProps:{}),ref:t},u,{className:(0,fn.A)(h.root,l.props.className,i)}))})}));W$.muiName="Select";const q$=W$;function G$(e){return(0,Yn.Ay)("MuiPagination",e)}(0,Ln.A)("MuiPagination",["root","ul","outlined","text"]);const Y$=["boundaryCount","componentName","count","defaultPage","disabled","hideNextButton","hidePrevButton","onChange","page","showFirstButton","showLastButton","siblingCount"];function X$(e){return(0,Yn.Ay)("MuiPaginationItem",e)}const Z$=(0,Ln.A)("MuiPaginationItem",["root","page","sizeSmall","sizeLarge","text","textPrimary","textSecondary","outlined","outlinedPrimary","outlinedSecondary","rounded","ellipsis","firstLast","previousNext","focusVisible","disabled","selected","icon","colorPrimary","colorSecondary"]),K$=(0,Ud.A)((0,j.jsx)("path",{d:"M15.41 7.41L14 6l-6 6 6 6 1.41-1.41L10.83 12z"}),"NavigateBefore"),J$=(0,Ud.A)((0,j.jsx)("path",{d:"M10 6L8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z"}),"NavigateNext"),Q$=["className","color","component","components","disabled","page","selected","shape","size","slots","type","variant"],eW=(e,t)=>{const{ownerState:r}=e;return[t.root,t[r.variant],t[`size${(0,ei.A)(r.size)}`],"text"===r.variant&&t[`text${(0,ei.A)(r.color)}`],"outlined"===r.variant&&t[`outlined${(0,ei.A)(r.color)}`],"rounded"===r.shape&&t.rounded,"page"===r.type&&t.page,("start-ellipsis"===r.type||"end-ellipsis"===r.type)&&t.ellipsis,("previous"===r.type||"next"===r.type)&&t.previousNext,("first"===r.type||"last"===r.type)&&t.firstLast]},tW=(0,yn.Ay)("div",{name:"MuiPaginationItem",slot:"Root",overridesResolver:eW})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({},t.typography.body2,{borderRadius:16,textAlign:"center",boxSizing:"border-box",minWidth:32,padding:"0 6px",margin:"0 3px",color:(t.vars||t).palette.text.primary,height:"auto",[`&.${Z$.disabled}`]:{opacity:(t.vars||t).palette.action.disabledOpacity}},"small"===r.size&&{minWidth:26,borderRadius:13,margin:"0 1px",padding:"0 4px"},"large"===r.size&&{minWidth:40,borderRadius:20,padding:"0 10px",fontSize:t.typography.pxToRem(15)})})),rW=(0,yn.Ay)(Qn,{name:"MuiPaginationItem",slot:"Root",overridesResolver:eW})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({},t.typography.body2,{borderRadius:16,textAlign:"center",boxSizing:"border-box",minWidth:32,height:32,padding:"0 6px",margin:"0 3px",color:(t.vars||t).palette.text.primary,[`&.${Z$.focusVisible}`]:{backgroundColor:(t.vars||t).palette.action.focus},[`&.${Z$.disabled}`]:{opacity:(t.vars||t).palette.action.disabledOpacity},transition:t.transitions.create(["color","background-color"],{duration:t.transitions.duration.short}),"&:hover":{backgroundColor:(t.vars||t).palette.action.hover,"@media (hover: none)":{backgroundColor:"transparent"}},[`&.${Z$.selected}`]:{backgroundColor:(t.vars||t).palette.action.selected,"&:hover":{backgroundColor:t.vars?`rgba(${t.vars.palette.action.selectedChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.hoverOpacity}))`:(0,gn.X4)(t.palette.action.selected,t.palette.action.selectedOpacity+t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:(t.vars||t).palette.action.selected}},[`&.${Z$.focusVisible}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.action.selectedChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.focusOpacity}))`:(0,gn.X4)(t.palette.action.selected,t.palette.action.selectedOpacity+t.palette.action.focusOpacity)},[`&.${Z$.disabled}`]:{opacity:1,color:(t.vars||t).palette.action.disabled,backgroundColor:(t.vars||t).palette.action.selected}}},"small"===r.size&&{minWidth:26,height:26,borderRadius:13,margin:"0 1px",padding:"0 4px"},"large"===r.size&&{minWidth:40,height:40,borderRadius:20,padding:"0 10px",fontSize:t.typography.pxToRem(15)},"rounded"===r.shape&&{borderRadius:(t.vars||t).shape.borderRadius})}),(e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({},"text"===r.variant&&{[`&.${Z$.selected}`]:(0,O.A)({},"standard"!==r.color&&{color:(t.vars||t).palette[r.color].contrastText,backgroundColor:(t.vars||t).palette[r.color].main,"&:hover":{backgroundColor:(t.vars||t).palette[r.color].dark,"@media (hover: none)":{backgroundColor:(t.vars||t).palette[r.color].main}},[`&.${Z$.focusVisible}`]:{backgroundColor:(t.vars||t).palette[r.color].dark}},{[`&.${Z$.disabled}`]:{color:(t.vars||t).palette.action.disabled}})},"outlined"===r.variant&&{border:t.vars?`1px solid rgba(${t.vars.palette.common.onBackgroundChannel} / 0.23)`:"1px solid "+("light"===t.palette.mode?"rgba(0, 0, 0, 0.23)":"rgba(255, 255, 255, 0.23)"),[`&.${Z$.selected}`]:(0,O.A)({},"standard"!==r.color&&{color:(t.vars||t).palette[r.color].main,border:`1px solid ${t.vars?`rgba(${t.vars.palette[r.color].mainChannel} / 0.5)`:(0,gn.X4)(t.palette[r.color].main,.5)}`,backgroundColor:t.vars?`rgba(${t.vars.palette[r.color].mainChannel} / ${t.vars.palette.action.activatedOpacity})`:(0,gn.X4)(t.palette[r.color].main,t.palette.action.activatedOpacity),"&:hover":{backgroundColor:t.vars?`rgba(${t.vars.palette[r.color].mainChannel} / calc(${t.vars.palette.action.activatedOpacity} + ${t.vars.palette.action.focusOpacity}))`:(0,gn.X4)(t.palette[r.color].main,t.palette.action.activatedOpacity+t.palette.action.focusOpacity),"@media (hover: none)":{backgroundColor:"transparent"}},[`&.${Z$.focusVisible}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette[r.color].mainChannel} / calc(${t.vars.palette.action.activatedOpacity} + ${t.vars.palette.action.focusOpacity}))`:(0,gn.X4)(t.palette[r.color].main,t.palette.action.activatedOpacity+t.palette.action.focusOpacity)}},{[`&.${Z$.disabled}`]:{borderColor:(t.vars||t).palette.action.disabledBackground,color:(t.vars||t).palette.action.disabled}})})})),nW=(0,yn.Ay)("div",{name:"MuiPaginationItem",slot:"Icon",overridesResolver:(e,t)=>t.icon})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({fontSize:t.typography.pxToRem(20),margin:"0 -8px"},"small"===r.size&&{fontSize:t.typography.pxToRem(18)},"large"===r.size&&{fontSize:t.typography.pxToRem(22)})})),iW=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiPaginationItem"}),{className:n,color:i="standard",component:o,components:a={},disabled:s=!1,page:l,selected:c=!1,shape:u="circular",size:d="medium",slots:h={},type:p="page",variant:f="text"}=r,m=(0,R.A)(r,Q$),g=(0,O.A)({},r,{color:i,disabled:s,selected:c,shape:u,size:d,type:p,variant:f}),y=H(),v=(e=>{const{classes:t,color:r,disabled:n,selected:i,size:o,shape:a,type:s,variant:l}=e,c={root:["root",`size${(0,ei.A)(o)}`,l,a,"standard"!==r&&`color${(0,ei.A)(r)}`,"standard"!==r&&`${l}${(0,ei.A)(r)}`,n&&"disabled",i&&"selected",{page:"page",first:"firstLast",last:"firstLast","start-ellipsis":"ellipsis","end-ellipsis":"ellipsis",previous:"previousNext",next:"previousNext"}[s]],icon:["icon"]};return(0,mn.A)(c,X$,t)})(g),x=(y?{previous:h.next||a.next||J$,next:h.previous||a.previous||K$,last:h.first||a.first||rB,first:h.last||a.last||tB}:{previous:h.previous||a.previous||K$,next:h.next||a.next||J$,first:h.first||a.first||rB,last:h.last||a.last||tB})[p];return"start-ellipsis"===p||"end-ellipsis"===p?(0,j.jsx)(tW,{ref:t,ownerState:g,className:(0,fn.A)(v.root,n),children:"\u2026"}):(0,j.jsxs)(rW,(0,O.A)({ref:t,ownerState:g,component:o,disabled:s,className:(0,fn.A)(v.root,n)},m,{children:["page"===p&&l,x?(0,j.jsx)(nW,{as:x,ownerState:g,className:v.icon}):null]}))})),oW=["boundaryCount","className","color","count","defaultPage","disabled","getItemAriaLabel","hideNextButton","hidePrevButton","onChange","page","renderItem","shape","showFirstButton","showLastButton","siblingCount","size","variant"],aW=(0,yn.Ay)("nav",{name:"MuiPagination",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,t[r.variant]]}})({}),sW=(0,yn.Ay)("ul",{name:"MuiPagination",slot:"Ul",overridesResolver:(e,t)=>t.ul})({display:"flex",flexWrap:"wrap",alignItems:"center",padding:0,margin:0,listStyle:"none"});function lW(e,t,r){return"page"===e?`${r?"":"Go to "}page ${t}`:`Go to ${e} page`}const cW=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiPagination"}),{boundaryCount:n=1,className:i,color:o="standard",count:a=1,defaultPage:s=1,disabled:l=!1,getItemAriaLabel:c=lW,hideNextButton:u=!1,hidePrevButton:d=!1,renderItem:h=e=>(0,j.jsx)(iW,(0,O.A)({},e)),shape:p="circular",showFirstButton:f=!1,showLastButton:m=!1,siblingCount:g=1,size:y="medium",variant:v="text"}=r,x=(0,R.A)(r,oW),{items:b}=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const{boundaryCount:t=1,componentName:r="usePagination",count:n=1,defaultPage:i=1,disabled:o=!1,hideNextButton:a=!1,hidePrevButton:s=!1,onChange:l,page:c,showFirstButton:u=!1,showLastButton:d=!1,siblingCount:h=1}=e,p=(0,R.A)(e,Y$),[f,m]=(0,tL.A)({controlled:c,default:i,name:r,state:"page"}),g=(e,t)=>{c||m(t),l&&l(e,t)},y=(e,t)=>{const r=t-e+1;return Array.from({length:r},((t,r)=>e+r))},v=y(1,Math.min(t,n)),x=y(Math.max(n-t+1,t+1),n),b=Math.max(Math.min(f-h,n-t-2*h-1),t+2),_=Math.min(Math.max(f+h,t+2*h+2),x.length>0?x[0]-2:n-1),w=[...u?["first"]:[],...s?[]:["previous"],...v,...b>t+2?["start-ellipsis"]:t+1t?[n-t]:[],...x,...a?[]:["next"],...d?["last"]:[]],k=e=>{switch(e){case"first":return 1;case"previous":return f-1;case"next":return f+1;case"last":return n;default:return null}},S=w.map((e=>"number"===typeof e?{onClick:t=>{g(t,e)},type:"page",page:e,selected:e===f,disabled:o,"aria-current":e===f?"true":void 0}:{onClick:t=>{g(t,k(e))},type:e,page:k(e),selected:!1,disabled:o||-1===e.indexOf("ellipsis")&&("next"===e||"last"===e?f>=n:f<=1)}));return(0,O.A)({items:S},p)}((0,O.A)({},r,{componentName:"Pagination"})),_=(0,O.A)({},r,{boundaryCount:n,color:o,count:a,defaultPage:s,disabled:l,getItemAriaLabel:c,hideNextButton:u,hidePrevButton:d,renderItem:h,shape:p,showFirstButton:f,showLastButton:m,siblingCount:g,size:y,variant:v}),w=(e=>{const{classes:t,variant:r}=e,n={root:["root",r],ul:["ul"]};return(0,mn.A)(n,G$,t)})(_);return(0,j.jsx)(aW,(0,O.A)({"aria-label":"pagination navigation",className:(0,fn.A)(w.root,i),ownerState:_,ref:t},x,{children:(0,j.jsx)(sW,{className:w.ul,ownerState:_,children:b.map(((e,t)=>(0,j.jsx)("li",{children:h((0,O.A)({},e,{color:o,"aria-label":c(e.type,e.page,e.selected),shape:p,size:y,variant:v}))},t)))})}))})),uW=(0,yn.Ay)(yi)((e=>{let{theme:t}=e;return{display:"flex",justifyContent:"end",alignItems:"center",marginTop:t.spacing(2),gap:2}})),dW=e=>{var t;let{data:r,handlePage:n,handleLimit:i,limit:o}=e;return(0,j.jsxs)(uW,{children:[(0,j.jsx)("span",{children:"Rows per page: "}),(0,j.jsx)(oH,{sx:{width:"max-content",margin:"4px 16px 0 12px"},children:(0,j.jsxs)(q$,{value:o||50,onChange:i,inputProps:{name:"limit",id:"uncontrolled-native"},children:[(0,j.jsx)("option",{value:10,children:"10"}),(0,j.jsx)("option",{value:50,children:"50"}),(0,j.jsx)("option",{value:100,children:"100"})]})}),(0,j.jsx)("span",{children:`${((null===r||void 0===r?void 0:r.offset)||0)+1} - ${((null===r||void 0===r?void 0:r.offset)||0)+((null===r||void 0===r||null===(t=r.items)||void 0===t?void 0:t.length)||0)} of ${(null===r||void 0===r?void 0:r.total)||0}`}),(0,j.jsx)(cW,{count:Math.ceil(r.total/r.limit),page:Math.ceil(r.offset/r.limit)+1,onChange:n})]})},hW=(0,yn.Ay)(GN,{shouldForwardProp:e=>"error"!==e})((e=>{let{error:t}=e;return{width:272,marginBottom:"15px",border:"1px solid #d9d9d9",borderColor:t?"red":"#d9d9d9",borderRadius:4}})),pW=(0,yn.Ay)(Hi)({fontSize:12,minHeight:18,color:"red",lineHeight:"14px",margin:"-14px 0px 0px 305px",wordBreak:"break-word"}),fW=e=>{let{value:t,onChange:r,onBlur:n,errorMessage:i,options:o,name:a}=e;return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(hW,{name:a,value:t,onChange:r,onBlur:n,error:!!i,children:o.map((e=>(0,j.jsx)(qa,{value:e,children:e},e)))}),(0,j.jsx)(pW,{children:i})]})};let mW;const gW={email:"",password:"",role_id:"",name:"",confirmPassword:""},yW=e=>{let{open:t,onSubmitEdit:r,setOpenModal:i,dataEdit:o}=e;const[a,s]=(0,n.useState)(o||gW),[l,c]=(0,n.useState)(!1),[u,d]=(0,n.useState)(gW),h=e=>{const t=f("email",255,e);return t||(lI.test(e)?"":"Invalid email format")},p=function(e){let t=arguments.length>1&&void 0!==arguments[1]&&arguments[1],r=arguments.length>2?arguments[2]:void 0;if(!e&&(null===o||void 0===o||!o.uid))return"This field is required";const n=m("password",255,e);if(n)return n;const i=r||a;return!sI.test(e)&&e?"Your password must be at least 6 characters long and must contain at least one letter, number, and special character":cI.test(e)?"Allowed special characters (!#$%&()*+,-./@_|)":t&&i.password!==e&&e?"password is not match":""},f=(e,t,r)=>r?m(e,t,r):"This field is required",m=(e,t,r)=>{var n;return r&&r.length>t||null!==(n=a[e])&&void 0!==n&&n.length&&r&&r.length>t?`The text may not be longer than ${t} characters`:""},g=(e,t)=>{const{value:r,name:n}=e.target,i={...a,[n]:r};s(i);let o="email"===n?h(r):f(n,t,r),l=u.confirmPassword;n.toLowerCase().includes("password")&&(o=p(r,"confirmPassword"===n,i),"confirmPassword"!==n&&a.confirmPassword&&(l=p(i.confirmPassword,!0,i))),d({...u,confirmPassword:l,[n]:o})},y=async e=>{e.preventDefault(),c(!0);const t=(()=>{const e=f("name",100,a.name),t=h(a.email),r=f("role_id",50,a.role_id);return{email:t,password:null!==o&&void 0!==o&&o.id?"":p(a.password),confirmPassword:null!==o&&void 0!==o&&o.id?"":p(a.confirmPassword,!0),name:e,role_id:r}})();if(Object.keys(t).some((e=>!!t[e])))return d(t),void c(!1);try{await r(null===o||void 0===o?void 0:o.id,a),i(!1)}finally{c(!1)}};return(0,j.jsxs)(xW,{open:t,onClose:()=>i(!1),children:[(0,j.jsxs)(bW,{children:[(0,j.jsxs)(_W,{children:[null!==o&&void 0!==o&&o.id?"Edit":"Add"," Account"]}),(0,j.jsxs)(wW,{children:[(0,j.jsx)(kW,{children:"Name: "}),(0,j.jsx)(V$,{name:"name",value:(null===a||void 0===a?void 0:a.name)||"",onChange:e=>g(e,100),onBlur:e=>g(e,100),errorMessage:u.name}),(0,j.jsx)(kW,{children:"Role: "}),(0,j.jsx)(fW,{value:(null===a||void 0===a?void 0:a.role_id)||"",options:Object.keys(cE).filter((e=>!Number(e))),name:"role_id",onChange:e=>g(e,50),onBlur:e=>g(e,50),errorMessage:u.role_id}),(0,j.jsx)(kW,{children:"e-mail: "}),(0,j.jsx)(V$,{name:"email",value:(null===a||void 0===a?void 0:a.email)||"",onChange:e=>g(e,255),onBlur:e=>g(e,255),errorMessage:u.email}),null!==o&&void 0!==o&&o.id?null:(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(kW,{children:"Password: "}),(0,j.jsx)(V$,{name:"password",value:(null===a||void 0===a?void 0:a.password)||"",onChange:e=>g(e,255),onBlur:e=>g(e,255),type:"password",errorMessage:u.password}),(0,j.jsx)(kW,{children:"Confirm Password: "}),(0,j.jsx)(V$,{name:"confirmPassword",value:(null===a||void 0===a?void 0:a.confirmPassword)||"",onChange:e=>g(e,255),onBlur:e=>g(e,255),type:"password",errorMessage:u.confirmPassword})]})]}),(0,j.jsxs)(SW,{children:[(0,j.jsx)(gf,{variant:"outlined",onClick:()=>{i(!1)},children:"Cancel"}),(0,j.jsx)(gf,{variant:"contained",disabled:l,onClick:e=>y(e),children:"Ok"})]})]}),(0,j.jsx)(wi,{loading:l})]})},vW=(0,yn.Ay)(yi)((e=>{let{theme:t}=e;return{width:"80%",margin:t.spacing(5,"auto")}})),xW=(0,yn.Ay)(Wp)((()=>({div:{maxWidth:"unset"}}))),bW=(0,yn.Ay)(yi)((()=>({width:800}))),_W=(0,yn.Ay)(Zp)((e=>{let{theme:t}=e;return{fontSize:25,margin:t.spacing(5)}})),wW=(0,yn.Ay)(ef)((()=>({marginTop:35}))),kW=(0,yn.Ay)(yi)((e=>{let{theme:t}=e;return{width:300,display:"inline-block",textAlign:"end",marginRight:t.spacing(.5)}})),SW=(0,yn.Ay)(of)((e=>{let{theme:t}=e;return{margin:t.spacing(5)}})),AW=(0,yn.Ay)("h1")((()=>({}))),TW=()=>{var e;const t=C(),r=Ye(),i=x(dE),o=x(hE),a=x(uE),s=x(fE),[l,c]=(0,n.useState)(!1),[u,d]=(0,n.useState)({}),[h,p]=(0,n.useState)(window.location.search.replace("?","")),[f,m]=(0,n.useState)(),[g,y]=Et(),v=g.get("limit")||50,b=g.get("offset")||0,_=g.get("name")||void 0,w=g.get("email")||void 0,k=g.getAll("sort")||[],S=(0,n.useMemo)((()=>({name:_,email:w})),[_,w]),A=(0,n.useMemo)((()=>({sort:k})),[JSON.stringify(k)]),T=(0,n.useMemo)((()=>({limit:Number(v),offset:Number(b)})),[v,b]),[M,E]=(0,n.useState)({filter:{items:[{field:Object.keys(S).find((e=>S[e]))||"",operator:"contains",value:Object.values(S).find((e=>e))||null}]},sort:[{field:(null===(e=A.sort[0])||void 0===e?void 0:e.replace("role","role_id"))||"",sort:A.sort[1]}]}),{enqueueSnackbar:I}=hn(),P=(e,t)=>{I(t,{variant:e})};(0,n.useEffect)((()=>{s||r("/console")}),[JSON.stringify(s)]),(0,n.useEffect)((()=>{var e;E({filter:{items:[{field:Object.keys(S).find((e=>S[e]))||"",operator:"contains",value:Object.values(S).find((e=>e))||null}]},sort:[{field:(null===(e=A.sort[0])||void 0===e?void 0:e.replace("role","role_id"))||"",sort:A.sort[1]}]})}),[A,S]),(0,n.useEffect)((()=>{h&&h!==window.location.search.replace("?","")&&p(window.location.search.replace("?",""))}),[g]),(0,n.useEffect)((()=>{h!==window.location.search.replace("?","")&&y(h.replaceAll("+","%2B"))}),[h]),(0,n.useEffect)((()=>{t(Pd({...S,...A,...T}))}),[v,b,w,_,JSON.stringify(k)]);const O=()=>Object.keys(S).filter((e=>S[e])).map((e=>`${e}=${S[e]}`)).join("&"),R=(0,n.useCallback)((e=>`limit=${v}&offset=${e?e-1:b}`),[v,b]),L=(0,n.useCallback)((e=>{let t;E({...M,sort:e});const r=O();t=e[0]?`${r}${e[0]?`${r?"&":""}sort=${e[0].field.replace("_id","")}&sort=${e[0].sort}`:""}&${R()}`:r||A.sort[0]||b?`${r?`${r}&`:""}${R()}`:"",p(t)}),[R,O,M]),D=[{headerName:"ID",field:"id",filterable:!1,minWidth:100,flex:1},{headerName:"Name",field:"name",type:"string",minWidth:100,flex:2,filterOperators:[{label:"Contains",value:"contains",getApplyFilterFn:()=>null,InputComponent:e=>{let{applyValue:t,item:r}=e;return(0,j.jsx)(eI,{sx:{paddingTop:"16px"},defaultValue:r.value||"",onChange:e=>{mW&&clearTimeout(mW),mW=setTimeout((()=>{t({...r,value:e.target.value})}),300)}})}}]},{headerName:"Role",field:"role_id",filterable:!1,minWidth:100,flex:1,renderCell:e=>{let t="";switch(e.value){case cE.ADMIN:t="Admin";break;case cE.OPERATOR:t="OPERATOR"}return(0,j.jsx)("span",{children:t})}},{headerName:"Mail",field:"email",type:"string",minWidth:100,flex:2,filterOperators:[{label:"Contains",value:"contains",getApplyFilterFn:()=>null,InputComponent:e=>{let{applyValue:t,item:r}=e;return(0,j.jsx)(eI,{sx:{paddingTop:"16px"},defaultValue:r.value||"",onChange:e=>{mW&&clearTimeout(mW),mW=setTimeout((()=>{t({...r,value:e.target.value})}),300)}})}}]},{headerName:"",field:"action",sortable:!1,filterable:!1,minWidth:100,flex:1,renderCell:e=>{var t;const{id:r,role_id:n,name:i,email:o}=e.row;if(!r||!n||!i||!o)return null;let s;switch(n){case cE.ADMIN:s="ADMIN";break;case cE.OPERATOR:s="OPERATOR"}return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(oi,{onClick:()=>(e=>{c(!0),d(e)})({id:r,role_id:s,name:i,email:o}),children:(0,j.jsx)(kE.A,{})}),(null===(t=e.row)||void 0===t?void 0:t.id)!==(null===a||void 0===a?void 0:a.id)?(0,j.jsx)(oi,{sx:{ml:1.25},color:"error",onClick:()=>{var t,r;return((e,t)=>{e&&m({id:e,name:t,open:!0})})(null===(t=e.row)||void 0===t?void 0:t.id,null===(r=e.row)||void 0===r?void 0:r.name)},children:(0,j.jsx)(SI.A,{})}):null]})}}];return(0,j.jsxs)(vW,{children:[(0,j.jsx)(AW,{children:"Account Manager"}),(0,j.jsx)(yi,{sx:{display:"flex",justifyContent:"flex-end",gap:2,marginBottom:2},children:(0,j.jsx)(gf,{sx:{background:"#000000c4","&:hover":{backgroundColor:"#00000090"}},variant:"contained",onClick:()=>{c(!0)},children:"Add"})}),(0,j.jsx)(F$,{sx:{minHeight:400,height:"calc(100vh - 300px)"},columns:D,rows:(null===i||void 0===i?void 0:i.items)||[],filterMode:"server",sortingMode:"server",hideFooter:!0,onSortModelChange:L,filterModel:M.filter,sortModel:M.sort,onFilterModelChange:e=>{var t;E({...M,filter:e});let r="";null!==(t=e.items[0])&&void 0!==t&&t.value&&(r=e.items.filter((e=>e.value)).map((e=>`${e.field}=${null===e||void 0===e?void 0:e.value}`)).join("&"));const{sort:n}=A,i=n[0]||r||b?`${r}${n[0]?`${r?"&":""}sort=${n[0]}&sort=${n[1]}`:""}&${R()}`:"";p(i)}}),i&&i.items.length>0?(0,j.jsx)(dW,{data:i,handlePage:(e,t)=>{if(!i)return;let r="";r=Object.keys(S).filter((e=>S[e])).map((e=>`${e}=${S[e]}`)).join("&");const{sort:n}=A,o=`${r}${n[0]?`${r?"&":""}sort=${n[0]}&sort=${n[1]}`:""}&limit=${i.limit}&offset=${(t-1)*Number(v)}`;p(o)},handleLimit:e=>{let t="";t=Object.keys(S).filter((e=>S[e])).map((e=>`${e}=${S[e]}`)).join("&");const{sort:r}=A,n=`${t}${r[0]?`${t?"&":""}sort=${r[0]}&sort=${r[1]}`:""}&limit=${Number(e.target.value)}&offset=0`;p(n)},limit:Number(v)}):null,(0,j.jsx)(Cf,{open:(null===f||void 0===f?void 0:f.open)||!1,onCancel:()=>{m({...f,open:!1})},onConfirm:async()=>{if(null===f||void 0===f||!f.id||!f)return;Wl(await t(Dd({id:f.id,params:{...S,...A,...T}})))?P("error","Delete user failed!"):P("success","Account deleted successfully!"),m({...f,open:!1})},title:"Delete user?",content:(0,j.jsxs)(j.Fragment,{children:[(0,j.jsxs)(Hi,{children:["ID: ",null===f||void 0===f?void 0:f.id]}),(0,j.jsxs)(Hi,{children:["Name: ",null===f||void 0===f?void 0:f.name]})]}),confirmLabel:"delete",iconType:"warning"}),l?(0,j.jsx)(yW,{open:l,onSubmitEdit:async(e,r)=>{const{role_id:n,...i}=r;let o;switch(n){case"ADMIN":o=cE.ADMIN;break;case"OPERATOR":o=cE.OPERATOR}if(void 0!==e){if(Wl(await t(Ld({id:e,data:{name:i.name,email:i.email,role_id:o},params:{...S,...A,...T}}))))return void P("error","Account update failed!");P("success","Your account has been edited successfully!")}else{if(Wl(await t(Rd({data:{...i,role_id:o},params:{...S,...A,...T}}))))return navigator.onLine?void P("error","This email already exists!"):void P("error","Account creation failed!");P("success","Your account has been created successfully!")}},setOpenModal:e=>{c(e),e||d({})},dataEdit:u}):null,(0,j.jsx)(wi,{loading:o})]})},MW=(0,yn.Ay)(yi)({width:"100%",height:"100%"}),CW=(0,yn.Ay)(St)((()=>({textDecoration:"none"}))),EW=(0,yn.Ay)(yi)((()=>({width:"100%",height:"calc(100% - 90px)",display:"flex",alignItems:"center",justifyContent:"center"}))),IW=(0,yn.Ay)(yi)((()=>({padding:30,display:"flex",justifyContent:"center",flexWrap:"wrap",gap:32}))),PW=(0,yn.Ay)(yi)((()=>({width:170,height:150,backgroundColor:"#283237",borderRadius:4,padding:"40px 30px",color:"#fff",textAlign:"center",fontSize:24,display:"flex",alignItems:"center",justifyContent:"center",transition:"all 0.3s","&:hover":{transform:"scale(1.1)",backgroundColor:"rgba(40,50,55,0.9)"}}))),OW=(0,yn.Ay)(Hi)((()=>({fontSize:24,marginTop:30}))),RW=()=>{const e=C(),t=x(fE),r=x(uE);return(0,n.useEffect)((()=>{r&&e(Md())}),[]),(0,j.jsxs)(MW,{children:[(0,j.jsx)("h1",{style:{paddingLeft:16},children:"Dashboard"}),(0,j.jsx)(EW,{children:(0,j.jsxs)(IW,{children:[(0,j.jsx)(CW,{to:"/console/workspaces",children:(0,j.jsx)(PW,{children:(0,j.jsxs)(yi,{children:[(0,j.jsx)(EC.A,{fontSize:"large"}),(0,j.jsx)(OW,{children:"Workspaces"})]})})}),t?(0,j.jsx)(CW,{to:"/console/account-manager",children:(0,j.jsx)(PW,{children:(0,j.jsxs)(yi,{children:[(0,j.jsx)(PC.A,{fontSize:"large"}),(0,j.jsx)(OW,{children:"Account Manager"})]})})}):null]})})]})},LW=(0,yn.Ay)(yi)({width:"100%",height:"100%",display:"flex",alignItems:"center",justifyContent:"center"}),DW=(0,yn.Ay)(yi)({padding:30,boxShadow:"2px 1px 3px 1px rgba(0,0,0,0.1)",borderRadius:4}),zW=(0,yn.Ay)(Hi)({fontSize:15,fontWeight:600,marginBottom:24}),jW=(0,yn.Ay)("form")({}),FW=(0,yn.Ay)(Hi)({fontSize:14}),NW=(0,yn.Ay)("span")({color:"red",fontSize:14,marginLeft:2}),BW=(0,yn.Ay)("input",{shouldForwardProp:e=>"error"!==e})((e=>{let{error:t}=e;return{width:250,height:24,borderRadius:4,border:"1px solid",borderColor:t?"red":"#d9d9d9",padding:"5px 10px",marginBottom:22,transition:"all 0.3s",outline:"none",":focus, :hover":{borderColor:"#1677ff"}}})),VW=(0,yn.Ay)(Hi)((e=>{let{theme:t}=e;return{fontSize:12,color:"rgba(0, 0, 0, 0.65)",marginTop:t.spacing(1)}})),UW=(0,yn.Ay)(St)({marginLeft:6,color:"#1892d1"}),HW=(0,yn.Ay)("button")({backgroundColor:"#283237",color:"#ffffff",borderRadius:4,border:"none",outline:"none",padding:"10px 20px",cursor:"pointer"}),$W=(0,yn.Ay)(Hi)({fontSize:12,color:"red",position:"absolute",bottom:4}),WW=()=>{const e=Ye(),t=C(),[r,i]=(0,n.useState)(!1),[o,a]=(0,n.useState)({email:"",password:""}),[s,l]=(0,n.useState)({email:"",password:""}),c=()=>{const e={email:"",password:""};return s.email||(e.email="This field is required"),s.password||(e.password="This field is required"),a(e),e.password||e.email},u=e=>{const{name:t,value:r}=e.target;l({...s,[t]:r}),a({...o,[t]:r?"":"This field is required"})};return(0,j.jsxs)(LW,{children:[(0,j.jsxs)(DW,{children:[(0,j.jsx)(zW,{"data-testid":"title",children:"Sign in to your account"}),(0,j.jsxs)(jW,{autoComplete:"off",onSubmit:async r=>{r.preventDefault();c()||(i(!0),t(Td(s)).unwrap().then((async r=>{await t(Md()),e("/console")})).catch((e=>{var t;const r=null===(t=e.response)||void 0===t?void 0:t.status;a(r&&r>=400&&r<500?{email:"Email or password is wrong.",password:""}:{email:"An unexpected error occurred in authentication.",password:""})})).finally((()=>{i(!1)})))},children:[(0,j.jsxs)(yi,{sx:{position:"relative"},children:[(0,j.jsxs)(FW,{children:["Email",(0,j.jsx)(NW,{children:"*"})]}),(0,j.jsx)(BW,{"data-testid":"email",autoComplete:"off",error:!!o.email,name:"email",onChange:u,value:s.email,placeholder:"Enter your email"}),(0,j.jsx)($W,{"data-testid":"error-email",children:o.email})]}),(0,j.jsxs)(yi,{sx:{position:"relative"},children:[(0,j.jsxs)(FW,{children:["Password",(0,j.jsx)(NW,{children:"*"})]}),(0,j.jsx)(BW,{"data-testid":"password",autoComplete:"off",error:!!o.password,onChange:u,name:"password",type:"password",value:s.password,placeholder:"Enter your password"}),(0,j.jsx)($W,{"data-testid":"error-password",children:o.password})]}),(0,j.jsxs)(VW,{children:["Forgot your password?",(0,j.jsx)(UW,{to:"/reset-password",children:"Reset password"})]}),(0,j.jsx)(eV,{flexDirection:"row",gap:2,mt:3,alignItems:"center",justifyContent:"flex-end",children:(0,j.jsx)(HW,{"data-testid":"button-submit",type:"submit",children:"SIGN IN"})})]})]}),(0,j.jsx)(wi,{loading:r})]})};function qW(e){return(0,Yn.Ay)("MuiLink",e)}const GW=(0,Ln.A)("MuiLink",["root","underlineNone","underlineHover","underlineAlways","button","focusVisible"]);var YW=r(17162);const XW={primary:"primary.main",textPrimary:"text.primary",secondary:"secondary.main",textSecondary:"text.secondary",error:"error.main"},ZW=e=>{let{theme:t,ownerState:r}=e;const n=(e=>XW[e]||e)(r.color),i=(0,YW.Yn)(t,`palette.${n}`,!1)||r.color,o=(0,YW.Yn)(t,`palette.${n}Channel`);return"vars"in t&&o?`rgba(${o} / 0.4)`:(0,gn.X4)(i,.4)},KW=["className","color","component","onBlur","onFocus","TypographyClasses","underline","variant","sx"],JW=(0,yn.Ay)(Hi,{name:"MuiLink",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,t[`underline${(0,ei.A)(r.underline)}`],"button"===r.component&&t.button]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({},"none"===r.underline&&{textDecoration:"none"},"hover"===r.underline&&{textDecoration:"none","&:hover":{textDecoration:"underline"}},"always"===r.underline&&(0,O.A)({textDecoration:"underline"},"inherit"!==r.color&&{textDecorationColor:ZW({theme:t,ownerState:r})},{"&:hover":{textDecorationColor:"inherit"}}),"button"===r.component&&{position:"relative",WebkitTapHighlightColor:"transparent",backgroundColor:"transparent",outline:0,border:0,margin:0,borderRadius:0,padding:0,cursor:"pointer",userSelect:"none",verticalAlign:"middle",MozAppearance:"none",WebkitAppearance:"none","&::-moz-focus-inner":{borderStyle:"none"},[`&.${GW.focusVisible}`]:{outline:"auto"}})})),QW=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiLink"}),{className:i,color:o="primary",component:a="a",onBlur:s,onFocus:l,TypographyClasses:c,underline:u="always",variant:d="inherit",sx:h}=r,p=(0,R.A)(r,KW),{isFocusVisibleRef:f,onBlur:m,onFocus:g,ref:y}=(0,_n.A)(),[v,x]=n.useState(!1),b=(0,xn.A)(t,y),_=(0,O.A)({},r,{color:o,component:a,focusVisible:v,underline:u,variant:d}),w=(e=>{const{classes:t,component:r,focusVisible:n,underline:i}=e,o={root:["root",`underline${(0,ei.A)(i)}`,"button"===r&&"button",n&&"focusVisible"]};return(0,mn.A)(o,qW,t)})(_);return(0,j.jsx)(JW,(0,O.A)({color:o,className:(0,fn.A)(w.root,i),classes:c,component:a,onBlur:e=>{m(e),!1===f.current&&x(!1),s&&s(e)},onFocus:e=>{g(e),!0===f.current&&x(!0),l&&l(e)},ref:b,ownerState:_,variant:d,sx:[...Object.keys(XW).includes(o)?[]:[{color:o}],...Array.isArray(h)?h:[h]]},p))})),eq=(0,yn.Ay)(yi)({width:"100%",height:"100%",display:"flex",alignItems:"center",justifyContent:"center"}),tq=(0,yn.Ay)(yi)({padding:30,boxShadow:"2px 1px 3px 1px rgba(0,0,0,0.1)",borderRadius:4}),rq=(0,yn.Ay)(Hi)({fontSize:22,textAlign:"center",fontWeight:600}),nq=(0,yn.Ay)(Hi)({textAlign:"center",marginBottom:24,fontSize:12,color:"rgba(0, 0, 0, 0.65)"}),iq=(0,yn.Ay)(QW)({fontSize:12,"&:hover":{cursor:"pointer"}}),oq=(0,yn.Ay)("form")({}),aq=(0,yn.Ay)(Hi)({fontSize:14}),sq=(0,yn.Ay)("span")({color:"red",fontSize:14,marginLeft:2}),lq=(0,yn.Ay)("input",{shouldForwardProp:e=>"error"!==e})((e=>{let{error:t}=e;return{width:250,height:24,borderRadius:4,border:"1px solid",borderColor:t?"red":"#d9d9d9",padding:"5px 10px",marginBottom:22,transition:"all 0.3s",outline:"none",":focus, :hover":{borderColor:"#1677ff"}}})),cq=(0,yn.Ay)("button")({backgroundColor:"#283237",color:"#ffffff",borderRadius:4,border:"none",outline:"none",padding:"10px 20px",cursor:"pointer"}),uq=(0,yn.Ay)(Hi)({fontSize:12,color:"red",position:"absolute",bottom:4}),dq=()=>{const e=Ye(),[t,r]=(0,n.useState)(!1),[i,o]=(0,n.useState)({email:""}),[a,s]=(0,n.useState)({email:""}),l=e=>e?e.length>255?"The text may not be longer than 255 characters":lI.test(e)?"":"The email is invalid":"This field is required",c=()=>{const e={email:""};return e.email=l(a.email),o(e),e.email};return(0,j.jsxs)(eq,{children:[(0,j.jsxs)(tq,{children:[(0,j.jsx)(rq,{children:"Forgot password?"}),(0,j.jsx)(nq,{children:"No worries, we'll send you reset instructions."}),(0,j.jsxs)(oq,{autoComplete:"off",onSubmit:async e=>{e.preventDefault();const t=c();if(!i.email&&!t){r(!0);try{await(async e=>(await wd.post(`/auth/send_reset_password_mail?email=${e}`)).data)(encodeURIComponent(a.email)),setTimeout((()=>{alert(` You'll receive a link to reset your password at ${a.email}. Please check your mail!`)}),300)}catch{setTimeout((()=>{alert("Email does not exists!")}),300)}finally{r(!1)}}},children:[(0,j.jsxs)(yi,{sx:{position:"relative"},children:[(0,j.jsxs)(aq,{children:["Email",(0,j.jsx)(sq,{children:"*"})]}),(0,j.jsx)(lq,{autoComplete:"off",error:!!i.email,name:"email",onChange:e=>{const{name:t,value:r}=e.target,n=l(r);s({...a,[t]:r}),o({...i,[t]:n})},value:a.email,placeholder:"Enter your email"}),(0,j.jsx)(uq,{children:i.email})]}),(0,j.jsxs)(eV,{flexDirection:"row",gap:2,mt:3,alignItems:"center",justifyContent:"space-between",children:[(0,j.jsx)(iq,{onClick:()=>e("/login"),children:"Back to SIGN IN"}),(0,j.jsx)(cq,{type:"submit",children:"Reset Password"})]})]})]}),(0,j.jsx)(wi,{loading:t})]})};var hq=r(86178),pq=r.n(hq),fq=r(90136),mq=r(85502),gq=r(95382);const yq=e=>{let{usersSuggest:t,onClose:r,handleAddListUser:i,stateUserShare:o}=e;const a=(0,n.useRef)(null);(0,n.useEffect)((()=>(window.addEventListener("mousedown",s),()=>{window.removeEventListener("mousedown",s)})),[]);const s=e=>{var t;const n=e.target;null!==(t=a.current)&&void 0!==t&&t.contains(n)||"inputSearch"===n.id||null===r||void 0===r||r()};return(0,j.jsx)(xq,{ref:a,children:(0,j.jsx)(bq,{children:t.map((e=>{const t=o.some((t=>t.id===e.id));return(0,j.jsxs)(_q,{onClick:()=>i(e),style:{cursor:t?"not-allowed":"pointer"},children:[`${e.name} (${e.email})`,t?(0,j.jsx)(gq.A,{style:{fontSize:14}}):null]},e.id)}))})})},vq=(0,yn.Ay)(Wp)((()=>({"& .MuiDialog-container":{"& .MuiPaper-root":{width:"70%",maxWidth:"890px"}}}))),xq=(0,yn.Ay)(yi)((()=>({position:"absolute",background:"#fff",zIndex:100,width:"60%",boxShadow:"0 6px 16px 0 rgba(0,0,0,.08), 0 3px 6px -4px rgba(0,0,0,.12), 0 9px 28px 8px rgba(0,0,0,.05)",borderBottomLeftRadius:8,borderBottomRightRadius:8,maxHeight:200,overflow:"auto"}))),bq=(0,yn.Ay)("ul")((()=>({listStyle:"none",padding:0,margin:0}))),_q=(0,yn.Ay)("li")((e=>{let{theme:t}=e;return{padding:t.spacing(1,2),fontSize:14,cursor:"pointer",display:"flex",justifyContent:"space-between",alignItems:"center","&:hover":{backgroundColor:"rgba(0,0,0,.04)"}}})),wq=e=>{let{open:t,handleClose:r,usersShare:i,id:o,title:a}=e;const s=x(pE),l=x(hE),[c,u]=(0,n.useState)(""),[d,h]=(0,n.useState)(i||void 0),p=C(),f=(0,n.useRef)();(0,n.useEffect)((()=>{i&&h(i)}),[i]),(0,n.useEffect)((()=>{f.current&&clearTimeout(f.current),c?f.current=setTimeout((()=>{p(Od({keyword:encodeURIComponent(c)}))}),300):p(Nd())}),[c]);const m=(0,n.useCallback)((e=>[{field:"name",headerName:"Name",minWidth:140,renderCell:e=>(0,j.jsx)("span",{children:e.row.name})},{field:"email",headerName:"Email",minWidth:280,renderCell:e=>(0,j.jsx)("span",{children:e.row.email})},{field:"share",headerName:"",filterable:!1,sortable:!1,minWidth:130,renderCell:t=>t.row.share?(0,j.jsx)(gf,{onClick:r=>e(r,t),children:(0,j.jsx)(mq.A,{color:"error"})}):""}]),[JSON.stringify(null===d||void 0===d?void 0:d.users)]);return i?(0,j.jsxs)(yi,{children:[(0,j.jsxs)(vq,{open:t,onClose:r,sx:{margin:0},children:[(0,j.jsx)(Zp,{children:a||"Share Database Record"}),(0,j.jsx)(ef,{children:(0,j.jsxs)(j.Fragment,{children:[(0,j.jsxs)(yi,{style:{position:"relative"},children:[(0,j.jsx)(eI,{id:"inputSearch",sx:{width:"60%"},placeholder:"Search and add users",value:c,onChange:e=>{u(e.target.value)}}),c&&s?(0,j.jsx)(yq,{onClose:()=>{u(""),p(Nd())},usersSuggest:s,stateUserShare:(null===d||void 0===d?void 0:d.users)||[],handleAddListUser:e=>{s&&d&&(d.users.find((t=>t.id===e.id))||h({...d,users:[...d.users,e]}))}}):null]}),(0,j.jsx)("p",{children:"Permitted users"}),d&&(0,j.jsx)(F$,{sx:{minHeight:400},rows:null===d||void 0===d?void 0:d.users.map((e=>({...e,share:!0}))),columns:m(((e,t)=>{if(e.preventDefault(),e.stopPropagation(),!d)return;const r=d.users.findIndex((e=>e.id===t.id)),n=d.users.filter(((e,t)=>t!==r));h({...h,users:n})})),hideFooterPagination:!0})]})}),(0,j.jsxs)(of,{children:[(0,j.jsx)(gf,{variant:"outlined",onClick:()=>r(!1),children:"Cancel"}),(0,j.jsx)(gf,{variant:"contained",onClick:async()=>{if(!d)return;const e=d.users.map((e=>e.id));await p(fC({id:o,data:{user_ids:e}})),r(!0)},children:"Ok"})]})]}),(0,j.jsx)(wi,{loading:l})]}):null},kq=(e,t)=>!(!e||!t||e.id!==t),Sq=(e,t,r,n,i,o)=>[{field:"id",headerName:"ID",filterable:!1,sortable:!1,flex:1,minWidth:70,renderCell:e=>(0,j.jsx)("span",{children:e.value})},{field:"name",headerName:"Workspace Name",flex:2,minWidth:100,editable:!0,filterable:!1,sortable:!1,renderCell:e=>{var t;const{row:r,value:n}=e;return(0,j.jsxs)(yi,{sx:{display:"flex",alignItems:"center",gap:2,justifyContent:"space-between",width:"100%"},children:[(0,j.jsx)(Mp,{title:n,placement:"top",children:(0,j.jsx)("span",{style:{whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis",width:"100%"},children:n})}),kq(i,null===r||void 0===r||null===(t=r.user)||void 0===t?void 0:t.id)?(0,j.jsx)(oi,{onClick:()=>null===o||void 0===o?void 0:o(r.id),size:"small",children:(0,j.jsx)(kE.A,{fontSize:"small"})}):null]})}},{field:"user",headerName:"Owner",filterable:!1,sortable:!1,flex:2,minWidth:100,renderCell:e=>{var t;return(0,j.jsx)(yi,{sx:{display:"flex",alignItems:"center",gap:2},children:e.value?(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)("span",{children:null===(t=e.value)||void 0===t?void 0:t.name}),kq(i,null===e||void 0===e?void 0:e.value.id)?"":(0,j.jsx)(fq.A,{})]}):null})}},{field:"created_at",headerName:"Created",flex:2,minWidth:100,filterable:!1,sortable:!1,renderCell:e=>(0,j.jsx)("span",{style:{whiteSpace:"normal",wordBreak:"break-all",overflowWrap:"break-word"},children:pq()(e.value).format("YYYY/MM/DD hh:mm")})},{field:"workflow",headerName:"",flex:1,minWidth:160,filterable:!1,sortable:!1,renderCell:e=>(0,j.jsx)(gf,{variant:"contained",color:"primary",size:"small",onClick:()=>r(e.row.id),children:"Workflow"})},{field:"records",headerName:"",flex:1,minWidth:100,filterable:!1,sortable:!1,renderCell:e=>(0,j.jsx)(gf,{variant:"contained",color:"primary",size:"small",onClick:()=>n(e.row.id),children:"Records"})},{field:"share",headerName:"",flex:1,minWidth:70,filterable:!1,sortable:!1,renderCell:t=>{var r,n;return kq(i,null===(r=t.row)||void 0===r||null===(n=r.user)||void 0===n?void 0:n.id)?(0,j.jsx)(oi,{onClick:()=>e(t.row.id),color:t.row.shared_count?"primary":"default",children:(0,j.jsx)(fq.A,{})}):null}},{field:"delete",headerName:"",flex:1,minWidth:70,filterable:!1,sortable:!1,renderCell:e=>{var r,n;return kq(i,null===(r=e.row)||void 0===r||null===(n=r.user)||void 0===n?void 0:n.id)?(0,j.jsx)(oi,{onClick:()=>t(e.row.id,e.row.name),color:"error",children:(0,j.jsx)(SI.A,{})}):null}}],Aq=e=>{let{open:t,handleClose:r,value:n,setNewWorkSpace:i,handleOkNew:o,error:a}=e;if(!i)return null;return(0,j.jsx)(yi,{children:(0,j.jsxs)(Wp,{open:t,onClose:r,sx:{margin:0},children:[(0,j.jsx)(Zp,{children:"New Workspace"}),(0,j.jsxs)(ef,{sx:{minWidth:300},children:[(0,j.jsx)(eI,{sx:{width:"80%"},placeholder:"Workspace Name",value:n||"",onChange:e=>{i(e.target.value)}}),(0,j.jsx)("br",{}),a?(0,j.jsx)("span",{style:{color:"red"},children:a}):null]}),(0,j.jsxs)(of,{children:[(0,j.jsx)(gf,{variant:"outlined",onClick:r,children:"Cancel"}),(0,j.jsx)(gf,{variant:"contained",onClick:o,children:"Ok"})]})]})})},Tq=(0,yn.Ay)(yi)((e=>{let{theme:t}=e;return{margin:"auto",width:"90vw",padding:t.spacing(2),overflow:"auto"}})),Mq=(0,yn.Ay)("h1")((()=>({}))),Cq=()=>{const e=C(),t=Ye(),r=x(Bf),i=x(Rf),o=x(Lf),a=x(uE),[s,l]=(0,n.useState)({share:!1,del:!1,new:!1,shareId:0}),[c,u]=(0,n.useState)(),[d,h]=(0,n.useState)(),[p,f]=(0,n.useState)(""),[m,g]=(0,n.useState)(""),[y,v]=(0,n.useState)({}),[b,_]=Et(),{enqueueSnackbar:w}=hn(),k=(e,t)=>{w(t,{variant:e})},S=b.get("offset"),A=b.get("limit"),T=(0,n.useMemo)((()=>({offset:Number(S)||0,limit:Number(A)||50})),[S,A]);(0,n.useEffect)((()=>{e(cC(T))}),[T]);(0,n.useEffect)((()=>{s.share&&s.shareId&&e(pC({id:s.shareId}))}),[s.share,s.shareId]);const M=(0,n.useCallback)((e=>`limit=${o.limit}&offset=${e?(e-1)*o.limit:o.offset}`),[null===o||void 0===o?void 0:o.limit,null===o||void 0===o?void 0:o.offset]);return(0,j.jsxs)(Tq,{children:[(0,j.jsx)(Mq,{children:"Workspaces"}),(0,j.jsx)(yi,{sx:{display:"flex",justifyContent:"flex-end",gap:2,marginBottom:2},children:(0,j.jsx)(gf,{sx:{background:"#000000c4","&:hover":{backgroundColor:"#00000090"}},variant:"contained",onClick:()=>{l({...s,new:!0})},children:"New"})}),a?(0,j.jsx)(yi,{sx:{minHeight:500,height:"calc(100vh - 350px)"},children:(0,j.jsx)(F$,{onCellClick:e=>{"name"!==e.field&&v((e=>{const t={};return Object.keys(e).forEach((e=>{t[e]={mode:vz.View,ignoreModifications:!1}})),t}))},rows:null===o||void 0===o?void 0:o.items,editMode:"row",rowModesModel:y,columns:Sq((e=>{l({...s,share:!0,shareId:e})}),((e,t)=>{u({id:e,name:t}),l({...s,del:!0})}),(e=>{t(`/console/workspaces/${e}`)}),(e=>{t(`/console/workspaces/${e}`,{state:{tab:2}})}),a,(e=>{v((t=>({...t,[e]:{mode:vz.Edit}})))})).filter(Boolean),onRowModesModelChange:e=>{v(e)},isCellEditable:e=>{var t;return kq(a,null===(t=e.row.user)||void 0===t?void 0:t.id)},onProcessRowUpdateError:e=>e,onRowEditStop:e=>{g(e.row.name)},processRowUpdate:async t=>{if(!t.name)return k("error","Workspace Name can't empty"),{...t,name:m};if(t.name===m)return t;return Wl(await e(hC({name:t.name,id:t.id})))?k("error","Workspace name edit failed!"):k("success","Workspace name edited successfully!"),await e(cC(T)),t},hideFooter:!0})}):null,(null===o||void 0===o?void 0:o.items.length)>0?(0,j.jsx)(dW,{data:o,handlePage:(e,t)=>{_(`&${M(t)}`)},handleLimit:e=>{_(`limit=${Number(e.target.value)}&offset=0`)},limit:Number(A)}):null,s.share?(0,j.jsx)(wq,{title:"Share Workspace",usersShare:i,open:s.share,handleClose:t=>{t&&e(cC(T)),l({...s,share:!1})},id:s.shareId}):null,(0,j.jsx)(Cf,{open:s.del,onCancel:()=>{l({...s,del:!1})},onConfirm:async()=>{if(!c)return;Wl(await e(uC({id:c.id,params:T})))?k("error","Workspace deletion failed!"):k("success","The workspace has been deleted successfully!"),l({...s,del:!1})},title:"Delete Workspace?",content:(0,j.jsxs)(j.Fragment,{children:[(0,j.jsxs)(Hi,{children:["ID: ",null===c||void 0===c?void 0:c.id]}),(0,j.jsxs)(Hi,{children:["Name: ",null===c||void 0===c?void 0:c.name]})]}),iconType:"warning",confirmLabel:"delete"}),(0,j.jsx)(Aq,{open:s.new,handleClose:()=>{l({...s,new:!1}),f("")},setNewWorkSpace:h,value:d,error:p,handleOkNew:async()=>{if(!d)return void f("Workspace Name can't empty");Wl(await e(dC({name:d})))?k("error","Workspace creation failed!"):k("success","The workspace has been created successfully!"),await e(cC(T)),l({...s,new:!1}),f(""),h("")}}),(0,j.jsx)(wi,{loading:r})]})};var Eq=r(54536),Iq=r(65037),Pq=r(8611);const Oq=["className","elementType","ownerState","externalForwardedProps","getSlotOwnerState","internalForwardedProps"],Rq=["component","slots","slotProps"],Lq=["component"];function Dq(e,t){const{className:r,elementType:n,ownerState:i,externalForwardedProps:o,getSlotOwnerState:a,internalForwardedProps:s}=t,l=(0,R.A)(t,Oq),{component:c,slots:u={[e]:void 0},slotProps:d={[e]:void 0}}=o,h=(0,R.A)(o,Rq),p=u[e]||n,f=Qi(d[e],i),m=Ji((0,O.A)({className:r},l,{externalForwardedProps:"root"===e?h:void 0,externalSlotProps:f})),{props:{component:g},internalRef:y}=m,v=(0,R.A)(m.props,Lq),x=(0,Gi.A)(y,null==f?void 0:f.ref,t.ref),b=a?a(v):{},_=(0,O.A)({},i,b),w="root"===e?g||c:g,k=Xi(p,(0,O.A)({},"root"===e&&!c&&!u[e]&&s,"root"!==e&&!u[e]&&s,v,w&&{as:w},{ref:x}),_);return Object.keys(b).forEach((e=>{delete k[e]})),[p,k]}function zq(e){return(0,Yn.Ay)("MuiAlert",e)}const jq=(0,Ln.A)("MuiAlert",["root","action","icon","message","filled","colorSuccess","colorInfo","colorWarning","colorError","filledSuccess","filledInfo","filledWarning","filledError","outlined","outlinedSuccess","outlinedInfo","outlinedWarning","outlinedError","standard","standardSuccess","standardInfo","standardWarning","standardError"]),Fq=(0,Ud.A)((0,j.jsx)("path",{d:"M20,12A8,8 0 0,1 12,20A8,8 0 0,1 4,12A8,8 0 0,1 12,4C12.76,4 13.5,4.11 14.2, 4.31L15.77,2.74C14.61,2.26 13.34,2 12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0, 0 22,12M7.91,10.08L6.5,11.5L11,16L21,6L19.59,4.58L11,13.17L7.91,10.08Z"}),"SuccessOutlined"),Nq=(0,Ud.A)((0,j.jsx)("path",{d:"M12 5.99L19.53 19H4.47L12 5.99M12 2L1 21h22L12 2zm1 14h-2v2h2v-2zm0-6h-2v4h2v-4z"}),"ReportProblemOutlined"),Bq=(0,Ud.A)((0,j.jsx)("path",{d:"M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z"}),"ErrorOutline"),Vq=(0,Ud.A)((0,j.jsx)("path",{d:"M11,9H13V7H11M12,20C7.59,20 4,16.41 4,12C4,7.59 7.59,4 12,4C16.41,4 20,7.59 20, 12C20,16.41 16.41,20 12,20M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12A10, 10 0 0,0 12,2M11,17H13V11H11V17Z"}),"InfoOutlined"),Uq=["action","children","className","closeText","color","components","componentsProps","icon","iconMapping","onClose","role","severity","slotProps","slots","variant"],Hq=(0,yn.Ay)(Ci,{name:"MuiAlert",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,t[r.variant],t[`${r.variant}${(0,ei.A)(r.color||r.severity)}`]]}})((e=>{let{theme:t}=e;const r="light"===t.palette.mode?gn.e$:gn.a,n="light"===t.palette.mode?gn.a:gn.e$;return(0,O.A)({},t.typography.body2,{backgroundColor:"transparent",display:"flex",padding:"6px 16px",variants:[...Object.entries(t.palette).filter((e=>{let[,t]=e;return t.main&&t.light})).map((e=>{let[i]=e;return{props:{colorSeverity:i,variant:"standard"},style:{color:t.vars?t.vars.palette.Alert[`${i}Color`]:r(t.palette[i].light,.6),backgroundColor:t.vars?t.vars.palette.Alert[`${i}StandardBg`]:n(t.palette[i].light,.9),[`& .${jq.icon}`]:t.vars?{color:t.vars.palette.Alert[`${i}IconColor`]}:{color:t.palette[i].main}}}})),...Object.entries(t.palette).filter((e=>{let[,t]=e;return t.main&&t.light})).map((e=>{let[n]=e;return{props:{colorSeverity:n,variant:"outlined"},style:{color:t.vars?t.vars.palette.Alert[`${n}Color`]:r(t.palette[n].light,.6),border:`1px solid ${(t.vars||t).palette[n].light}`,[`& .${jq.icon}`]:t.vars?{color:t.vars.palette.Alert[`${n}IconColor`]}:{color:t.palette[n].main}}}})),...Object.entries(t.palette).filter((e=>{let[,t]=e;return t.main&&t.dark})).map((e=>{let[r]=e;return{props:{colorSeverity:r,variant:"filled"},style:(0,O.A)({fontWeight:t.typography.fontWeightMedium},t.vars?{color:t.vars.palette.Alert[`${r}FilledColor`],backgroundColor:t.vars.palette.Alert[`${r}FilledBg`]}:{backgroundColor:"dark"===t.palette.mode?t.palette[r].dark:t.palette[r].main,color:t.palette.getContrastText(t.palette[r].main)})}}))]})})),$q=(0,yn.Ay)("div",{name:"MuiAlert",slot:"Icon",overridesResolver:(e,t)=>t.icon})({marginRight:12,padding:"7px 0",display:"flex",fontSize:22,opacity:.9}),Wq=(0,yn.Ay)("div",{name:"MuiAlert",slot:"Message",overridesResolver:(e,t)=>t.message})({padding:"8px 0",minWidth:0,overflow:"auto"}),qq=(0,yn.Ay)("div",{name:"MuiAlert",slot:"Action",overridesResolver:(e,t)=>t.action})({display:"flex",alignItems:"flex-start",padding:"4px 0 0 16px",marginLeft:"auto",marginRight:-8}),Gq={success:(0,j.jsx)(Fq,{fontSize:"inherit"}),warning:(0,j.jsx)(Nq,{fontSize:"inherit"}),error:(0,j.jsx)(Bq,{fontSize:"inherit"}),info:(0,j.jsx)(Vq,{fontSize:"inherit"})},Yq=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiAlert"}),{action:n,children:i,className:o,closeText:a="Close",color:s,components:l={},componentsProps:c={},icon:u,iconMapping:d=Gq,onClose:h,role:p="alert",severity:f="success",slotProps:m={},slots:g={},variant:y="standard"}=r,v=(0,R.A)(r,Uq),x=(0,O.A)({},r,{color:s,severity:f,variant:y,colorSeverity:s||f}),b=(e=>{const{variant:t,color:r,severity:n,classes:i}=e,o={root:["root",`color${(0,ei.A)(r||n)}`,`${t}${(0,ei.A)(r||n)}`,`${t}`],icon:["icon"],message:["message"],action:["action"]};return(0,mn.A)(o,zq,i)})(x),_={slots:(0,O.A)({closeButton:l.CloseButton,closeIcon:l.CloseIcon},g),slotProps:(0,O.A)({},c,m)},[w,k]=Dq("closeButton",{elementType:oi,externalForwardedProps:_,ownerState:x}),[S,A]=Dq("closeIcon",{elementType:TL,externalForwardedProps:_,ownerState:x});return(0,j.jsxs)(Hq,(0,O.A)({role:p,elevation:0,ownerState:x,className:(0,fn.A)(b.root,o),ref:t},v,{children:[!1!==u?(0,j.jsx)($q,{ownerState:x,className:b.icon,children:u||d[f]||Gq[f]}):null,(0,j.jsx)(Wq,{ownerState:x,className:b.message,children:i}),null!=n?(0,j.jsx)(qq,{ownerState:x,className:b.action,children:n}):null,null==n&&h?(0,j.jsx)(qq,{ownerState:x,className:b.action,children:(0,j.jsx)(w,(0,O.A)({size:"small","aria-label":a,title:a,color:"inherit",onClick:h},k,{children:(0,j.jsx)(S,(0,O.A)({fontSize:"small"},A))}))}):null]}))}));function Xq(e){return(0,Yn.Ay)("MuiAlertTitle",e)}(0,Ln.A)("MuiAlertTitle",["root"]);const Zq=["className"],Kq=(0,yn.Ay)(Hi,{name:"MuiAlertTitle",slot:"Root",overridesResolver:(e,t)=>t.root})((e=>{let{theme:t}=e;return{fontWeight:t.typography.fontWeightMedium,marginTop:-2}})),Jq=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiAlertTitle"}),{className:n}=r,i=(0,R.A)(r,Zq),o=r,a=(e=>{const{classes:t}=e;return(0,mn.A)({root:["root"]},Xq,t)})(o);return(0,j.jsx)(Kq,(0,O.A)({gutterBottom:!0,component:"div",ownerState:o,ref:t,className:(0,fn.A)(a.root,n)},i))}));function Qq(e){return(0,Yn.Ay)("MuiTable",e)}(0,Ln.A)("MuiTable",["root","stickyHeader"]);const eG=["className","component","padding","size","stickyHeader"],tG=(0,yn.Ay)("table",{name:"MuiTable",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.stickyHeader&&t.stickyHeader]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({display:"table",width:"100%",borderCollapse:"collapse",borderSpacing:0,"& caption":(0,O.A)({},t.typography.body2,{padding:t.spacing(2),color:(t.vars||t).palette.text.secondary,textAlign:"left",captionSide:"bottom"})},r.stickyHeader&&{borderCollapse:"separate"})})),rG="table",nG=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiTable"}),{className:i,component:o=rG,padding:a="normal",size:s="medium",stickyHeader:l=!1}=r,c=(0,R.A)(r,eG),u=(0,O.A)({},r,{component:o,padding:a,size:s,stickyHeader:l}),d=(e=>{const{classes:t,stickyHeader:r}=e,n={root:["root",r&&"stickyHeader"]};return(0,mn.A)(n,Qq,t)})(u),h=n.useMemo((()=>({padding:a,size:s,stickyHeader:l})),[a,s,l]);return(0,j.jsx)(YN.Provider,{value:h,children:(0,j.jsx)(tG,(0,O.A)({as:o,role:o===rG?null:"table",ref:t,className:(0,fn.A)(d.root,i),ownerState:u},c))})}));function iG(e){return(0,Yn.Ay)("MuiTableBody",e)}(0,Ln.A)("MuiTableBody",["root"]);const oG=["className","component"],aG=(0,yn.Ay)("tbody",{name:"MuiTableBody",slot:"Root",overridesResolver:(e,t)=>t.root})({display:"table-row-group"}),sG={variant:"body"},lG="tbody",cG=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiTableBody"}),{className:n,component:i=lG}=r,o=(0,R.A)(r,oG),a=(0,O.A)({},r,{component:i}),s=(e=>{const{classes:t}=e;return(0,mn.A)({root:["root"]},iG,t)})(a);return(0,j.jsx)(XN.Provider,{value:sG,children:(0,j.jsx)(aG,(0,O.A)({className:(0,fn.A)(s.root,n),as:i,ref:t,role:i===lG?null:"rowgroup",ownerState:a},o))})}));function uG(e){return(0,Yn.Ay)("MuiTableContainer",e)}(0,Ln.A)("MuiTableContainer",["root"]);const dG=["className","component"],hG=(0,yn.Ay)("div",{name:"MuiTableContainer",slot:"Root",overridesResolver:(e,t)=>t.root})({width:"100%",overflowX:"auto"}),pG=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiTableContainer"}),{className:n,component:i="div"}=r,o=(0,R.A)(r,dG),a=(0,O.A)({},r,{component:i}),s=(e=>{const{classes:t}=e;return(0,mn.A)({root:["root"]},uG,t)})(a);return(0,j.jsx)(hG,(0,O.A)({ref:t,as:i,className:(0,fn.A)(s.root,n),ownerState:a},o))}));function fG(e){return(0,Yn.Ay)("MuiTableHead",e)}(0,Ln.A)("MuiTableHead",["root"]);const mG=["className","component"],gG=(0,yn.Ay)("thead",{name:"MuiTableHead",slot:"Root",overridesResolver:(e,t)=>t.root})({display:"table-header-group"}),yG={variant:"head"},vG="thead",xG=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiTableHead"}),{className:n,component:i=vG}=r,o=(0,R.A)(r,mG),a=(0,O.A)({},r,{component:i}),s=(e=>{const{classes:t}=e;return(0,mn.A)({root:["root"]},fG,t)})(a);return(0,j.jsx)(XN.Provider,{value:yG,children:(0,j.jsx)(gG,(0,O.A)({as:i,className:(0,fn.A)(s.root,n),ref:t,role:i===vG?null:"rowgroup",ownerState:a},o))})}));function bG(e){return(0,Yn.Ay)("MuiTableRow",e)}const _G=(0,Ln.A)("MuiTableRow",["root","selected","hover","head","footer"]),wG=["className","component","hover","selected"],kG=(0,yn.Ay)("tr",{name:"MuiTableRow",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.head&&t.head,r.footer&&t.footer]}})((e=>{let{theme:t}=e;return{color:"inherit",display:"table-row",verticalAlign:"middle",outline:0,[`&.${_G.hover}:hover`]:{backgroundColor:(t.vars||t).palette.action.hover},[`&.${_G.selected}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity})`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity),"&:hover":{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.hoverOpacity}))`:(0,gn.X4)(t.palette.primary.main,t.palette.action.selectedOpacity+t.palette.action.hoverOpacity)}}}})),SG="tr",AG=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiTableRow"}),{className:i,component:o=SG,hover:a=!1,selected:s=!1}=r,l=(0,R.A)(r,wG),c=n.useContext(XN),u=(0,O.A)({},r,{component:o,hover:a,selected:s,head:c&&"head"===c.variant,footer:c&&"footer"===c.variant}),d=(e=>{const{classes:t,selected:r,hover:n,head:i,footer:o}=e,a={root:["root",r&&"selected",n&&"hover",i&&"head",o&&"footer"]};return(0,mn.A)(a,bG,t)})(u);return(0,j.jsx)(kG,(0,O.A)({as:o,ref:t,className:(0,fn.A)(d.root,i),role:o===SG?null:"row",ownerState:u},l))})),TG=(0,Ud.A)((0,j.jsx)("path",{d:"M20 12l-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8 8-8z"}),"ArrowDownward");function MG(e){return(0,Yn.Ay)("MuiTableSortLabel",e)}const CG=(0,Ln.A)("MuiTableSortLabel",["root","active","icon","iconDirectionDesc","iconDirectionAsc"]),EG=["active","children","className","direction","hideSortIcon","IconComponent"],IG=(0,yn.Ay)(Qn,{name:"MuiTableSortLabel",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,r.active&&t.active]}})((e=>{let{theme:t}=e;return{cursor:"pointer",display:"inline-flex",justifyContent:"flex-start",flexDirection:"inherit",alignItems:"center","&:focus":{color:(t.vars||t).palette.text.secondary},"&:hover":{color:(t.vars||t).palette.text.secondary,[`& .${CG.icon}`]:{opacity:.5}},[`&.${CG.active}`]:{color:(t.vars||t).palette.text.primary,[`& .${CG.icon}`]:{opacity:1,color:(t.vars||t).palette.text.secondary}}}})),PG=(0,yn.Ay)("span",{name:"MuiTableSortLabel",slot:"Icon",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.icon,t[`iconDirection${(0,ei.A)(r.direction)}`]]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({fontSize:18,marginRight:4,marginLeft:4,opacity:0,transition:t.transitions.create(["opacity","transform"],{duration:t.transitions.duration.shorter}),userSelect:"none"},"desc"===r.direction&&{transform:"rotate(0deg)"},"asc"===r.direction&&{transform:"rotate(180deg)"})})),OG=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiTableSortLabel"}),{active:n=!1,children:i,className:o,direction:a="asc",hideSortIcon:s=!1,IconComponent:l=TG}=r,c=(0,R.A)(r,EG),u=(0,O.A)({},r,{active:n,direction:a,hideSortIcon:s,IconComponent:l}),d=(e=>{const{classes:t,direction:r,active:n}=e,i={root:["root",n&&"active"],icon:["icon",`iconDirection${(0,ei.A)(r)}`]};return(0,mn.A)(i,MG,t)})(u);return(0,j.jsxs)(IG,(0,O.A)({className:(0,fn.A)(d.root,o),component:"span",disableRipple:!0,ownerState:u,ref:t},c,{children:[i,s&&!n?null:(0,j.jsx)(PG,{as:l,className:(0,fn.A)(d.icon),ownerState:u})]}))}));var RG=r(10697);const LG=e=>e.experiments,DG=e=>"uninitialized"===LG(e).status,zG=e=>"fulfilled"===LG(e).status,jG=e=>"error"===LG(e).status,FG=e=>{const t=LG(e);if("error"===t.status)return t.message;throw new Error("experiments status is not error")},NG=e=>LG(e).loading,BG=e=>{const t=LG(e);if("fulfilled"===t.status)return t.experimentList;throw new Error("experiments status is not fulfilled")},VG=e=>t=>BG(t)[e],UG=e=>t=>VG(e)(t).name,HG=(e,t)=>r=>BG(r)[e].functions[t],$G=e=>t=>e&&VG(e)(t).frameRate||50;function WG(e){var t;const r={};return Object.entries(e.function).forEach((e=>{let[t,n]=e;const i=function(e){switch(e){case"running":return"running";case"success":return"success";case"error":return"error";default:throw new Error("failed to convert to EXPERIMENTS_STATUS")}}(n.success);r[n.unique_id]={name:n.name,nodeId:n.unique_id,status:i,hasNWB:n.hasNWB},"error"===i&&n.message&&(r[n.unique_id].message=n.message)})),{uid:e.unique_id,startedAt:e.started_at,finishedAt:e.finished_at,status:e.success,name:e.name,hasNWB:e.hasNWB,functions:r,frameRate:null===(t=e.nwb)||void 0===t?void 0:t.imaging_plane.imaging_rate}}function qG(e){const t={};return Object.entries(e).forEach((e=>{var r;let[n,i]=e;t[n]={status:i.success,message:null!==(r=i.message)&&void 0!==r?r:"",name:i.name,outputPaths:i.outputPaths}})),t}const GG={run:{status:Ak},runBtn:Rk.RUN_NEW},YG=Pl({name:Sk,initialState:GG,reducers:{setRunBtnOption:(e,t)=>{e.runBtn=t.payload.runBtnOption},clearCurrentPipeline:()=>GG},extraReducers:e=>{e.addCase(tS.fulfilled,((e,t)=>{if(e.run.status===Ck){e.run.runResult={...e.run.runResult,...Bk(t.payload)};0===Object.values(e.run.runResult).filter(zk).length&&(e.run.status=Ek)}})).addCase(tS.rejected,(e=>{e.run.status=Ik})).addCase(ik.fulfilled,((e,t)=>{e.currentPipeline={uid:t.meta.arg.uid},e.runBtn=Rk.RUN_ALREADY,e.run={status:Ak}})).addCase(ok.fulfilled,(e=>{e.currentPipeline=void 0,e.runBtn=Rk.RUN_NEW,e.run={status:Ak}})).addCase(rS.fulfilled,(e=>{e.run.status=Pk})).addMatcher(Bl(nk.fulfilled,ik.fulfilled),((e,t)=>{e.currentPipeline={uid:t.payload.unique_id},e.runBtn=Rk.RUN_ALREADY,e.run={uid:t.payload.unique_id,status:Ck,runResult:{...Bk(qG(t.payload.function))},runPostData:{name:t.payload.name,nodeDict:t.payload.nodeDict,edgeDict:t.payload.edgeDict,snakemakeParam:{},nwbParam:{},forceRunList:[]}};0===Object.values(e.run.runResult).filter(zk).length&&(e.run.status=Ek)})).addMatcher(Bl(Qk.pending,eS.pending),(e=>{e.run={status:Tk}})).addMatcher(Bl(Qk.fulfilled,eS.fulfilled),((e,t)=>{const r=t.meta.arg.runPostData,n=t.payload;e.run={uid:n,status:Ck,runResult:Nk({name:"",...r}),runPostData:{name:"",...r}},e.currentPipeline={uid:t.payload}})).addMatcher(Bl(Qk.rejected,eS.rejected),(e=>{e.run={status:Mk}})).addMatcher(Bl(nk.rejected,pk),(()=>GG))}}),{setRunBtnOption:XG,clearCurrentPipeline:ZG}=YG.actions,KG=YG.reducer,JG=(0,n.memo)((function(){const e=C(),t=x(Uk),r=(0,n.useContext)(SY),i=x((e=>{const t=Uk(e),n=Xk(e);return r===t&&n})),o=x(UG(r)),[a,s]=(0,n.useState)(!1),{enqueueSnackbar:l}=hn();return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(oi,{onClick:()=>{s(!0)},disabled:i,color:"error","data-testid":"delete-button",children:(0,j.jsx)(RG.A,{})}),(0,j.jsx)(Cf,{open:a,setOpen:s,onConfirm:()=>{e(Hf(r)).unwrap().then((()=>{})).catch((()=>{l("Failed to delete",{variant:"error"})})),r===t&&e(ZG())},title:"Delete record?",content:`${o} (${r})`,confirmLabel:"delete",iconType:"warning"})]})}));var QG=r(20689);const eY=(0,n.memo)((function(e){let{name:t,nodeId:r,hasNWB:i}=e;const o=x(jf),a=(0,n.useContext)(SY),s=(0,n.useRef)(null),[l,c]=(0,n.useState)(),{enqueueSnackbar:u}=hn();return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(oi,{onClick:async()=>{if(o)try{const e=await async function(e,t,r){const n=null!=r?`${bd}/experiments/download/nwb/${e}/${t}/${r}`:`${bd}/experiments/download/nwb/${e}/${t}`;return(await wd.get(n,{responseType:"blob"})).data}(o,a,r),t=URL.createObjectURL(new Blob([e]));c(t),setTimeout((()=>{var e;null===(e=s.current)||void 0===e||e.click(),URL.revokeObjectURL(t)}),100)}catch(e){u("File not found",{variant:"error"})}},color:"primary",disabled:!i,children:(0,j.jsx)(QG.A,{})}),(0,j.jsx)("a",{href:l,download:`nwb_${t}.nwb`,className:"hidden",ref:s,"data-testid":"nwb-download-link",children:" "})]})})),tY=(0,n.memo)((function(){const e=x(jf),t=(0,n.useContext)(SY),r=(0,n.useRef)(null),[i,o]=(0,n.useState)(),{enqueueSnackbar:a}=hn();return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(oi,{onClick:async()=>{try{const n=await async function(e,t){return(await wd.get(`${bd}/experiments/download/config/${e}/${t}`,{responseType:"blob"})).data}(e,t),i=URL.createObjectURL(new Blob([n]));o(i),setTimeout((()=>{var e;null===(e=r.current)||void 0===e||e.click(),URL.revokeObjectURL(i)}),100)}catch(n){a("File not found",{variant:"error"})}},children:(0,j.jsx)(QG.A,{color:"primary"})}),(0,j.jsx)("a",{href:i,download:`snakemake_${t}.yaml`,className:"hidden",ref:r,"data-testid":"snakemake-download-link",children:" "})]})})),rY=(0,n.memo)((function(){const e=x(jf),t=(0,n.useContext)(SY),r=(0,n.useRef)(null),[i,o]=(0,n.useState)(),{enqueueSnackbar:a}=hn();return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(oi,{onClick:async()=>{try{const n=await async function(e,t){return(await wd.get(`${bd}/workflow/download/${e}/${t}`,{responseType:"blob"})).data}(e,t),i=URL.createObjectURL(new Blob([n]));o(i),setTimeout((()=>{var e;null===(e=r.current)||void 0===e||e.click(),URL.revokeObjectURL(i)}),100)}catch(n){a("File not found",{variant:"error"})}},"data-testid":"workflow-download-button",children:(0,j.jsx)(QG.A,{color:"primary"})}),(0,j.jsx)("a",{href:i,download:`workflow_${t}.yaml`,className:"hidden",ref:r,"data-testid":"workflow-download-link",children:" "})]})}));var nY=r(28222);const iY=(0,n.memo)((function(){const[e,t]=(0,n.useState)(!1),r=x(Xk),i=C(),o=x(jf),a=(0,n.useContext)(SY),s=x(UG(a)),{enqueueSnackbar:l}=hn();return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(oi,{onClick:()=>{t(!0)},color:"primary",disabled:!!r,"data-testid":"reproduce-button",children:(0,j.jsx)(nY.A,{})}),(0,j.jsx)(Cf,{open:e,setOpen:t,onConfirm:()=>{o?i(ik({workspaceId:o,uid:a})).unwrap().then((()=>{l("Successfully reproduced.",{variant:"success"}),i(AM())})).catch((()=>{l("Failed to reproduce",{variant:"error"})})):l("Workspace id is missing",{variant:"error"})},title:"Reproduce workflow?",content:`${s} (${a})`,confirmLabel:"reproduce",iconType:"info"})]})}));var oY=r(14318);function aY(e){return(0,Yn.Ay)("MuiCollapse",e)}(0,Ln.A)("MuiCollapse",["root","horizontal","vertical","entered","hidden","wrapper","wrapperInner"]);const sY=["addEndListener","children","className","collapsedSize","component","easing","in","onEnter","onEntered","onEntering","onExit","onExited","onExiting","orientation","style","timeout","TransitionComponent"],lY=(0,yn.Ay)("div",{name:"MuiCollapse",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,t[r.orientation],"entered"===r.state&&t.entered,"exited"===r.state&&!r.in&&"0px"===r.collapsedSize&&t.hidden]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({height:0,overflow:"hidden",transition:t.transitions.create("height")},"horizontal"===r.orientation&&{height:"auto",width:0,transition:t.transitions.create("width")},"entered"===r.state&&(0,O.A)({height:"auto",overflow:"visible"},"horizontal"===r.orientation&&{width:"auto"}),"exited"===r.state&&!r.in&&"0px"===r.collapsedSize&&{visibility:"hidden"})})),cY=(0,yn.Ay)("div",{name:"MuiCollapse",slot:"Wrapper",overridesResolver:(e,t)=>t.wrapper})((e=>{let{ownerState:t}=e;return(0,O.A)({display:"flex",width:"100%"},"horizontal"===t.orientation&&{width:"auto",height:"100%"})})),uY=(0,yn.Ay)("div",{name:"MuiCollapse",slot:"WrapperInner",overridesResolver:(e,t)=>t.wrapperInner})((e=>{let{ownerState:t}=e;return(0,O.A)({width:"100%"},"horizontal"===t.orientation&&{width:"auto",height:"100%"})})),dY=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiCollapse"}),{addEndListener:i,children:o,className:a,collapsedSize:s="0px",component:l,easing:c,in:u,onEnter:d,onEntered:h,onEntering:p,onExit:f,onExited:m,onExiting:g,orientation:y="vertical",style:v,timeout:x=oY.p0.standard,TransitionComponent:b=Co}=r,_=(0,R.A)(r,sY),w=(0,O.A)({},r,{orientation:y,collapsedSize:s}),k=(e=>{const{orientation:t,classes:r}=e,n={root:["root",`${t}`],entered:["entered"],hidden:["hidden"],wrapper:["wrapper",`${t}`],wrapperInner:["wrapperInner",`${t}`]};return(0,mn.A)(n,aY,r)})(w),S=Io(),A=(0,On.A)(),T=n.useRef(null),M=n.useRef(),C="number"===typeof s?`${s}px`:s,E="horizontal"===y,I=E?"width":"height",P=n.useRef(null),L=(0,xn.A)(t,P),D=e=>t=>{if(e){const r=P.current;void 0===t?e(r):e(r,t)}},z=()=>T.current?T.current[E?"clientWidth":"clientHeight"]:0,F=D(((e,t)=>{T.current&&E&&(T.current.style.position="absolute"),e.style[I]=C,d&&d(e,t)})),N=D(((e,t)=>{const r=z();T.current&&E&&(T.current.style.position="");const{duration:n,easing:i}=Oo({style:v,timeout:x,easing:c},{mode:"enter"});if("auto"===x){const t=S.transitions.getAutoHeightDuration(r);e.style.transitionDuration=`${t}ms`,M.current=t}else e.style.transitionDuration="string"===typeof n?n:`${n}ms`;e.style[I]=`${r}px`,e.style.transitionTimingFunction=i,p&&p(e,t)})),B=D(((e,t)=>{e.style[I]="auto",h&&h(e,t)})),V=D((e=>{e.style[I]=`${z()}px`,f&&f(e)})),U=D(m),H=D((e=>{const t=z(),{duration:r,easing:n}=Oo({style:v,timeout:x,easing:c},{mode:"exit"});if("auto"===x){const r=S.transitions.getAutoHeightDuration(t);e.style.transitionDuration=`${r}ms`,M.current=r}else e.style.transitionDuration="string"===typeof r?r:`${r}ms`;e.style[I]=C,e.style.transitionTimingFunction=n,g&&g(e)}));return(0,j.jsx)(b,(0,O.A)({in:u,onEnter:F,onEntered:B,onEntering:N,onExit:V,onExited:U,onExiting:H,addEndListener:e=>{"auto"===x&&A.start(M.current||0,e),i&&i(P.current,e)},nodeRef:P,timeout:"auto"===x?null:x},_,{children:(e,t)=>(0,j.jsx)(lY,(0,O.A)({as:l,className:(0,fn.A)(k.root,a,{entered:k.entered,exited:!u&&"0px"===C&&k.hidden}[e]),style:(0,O.A)({[E?"minWidth":"minHeight"]:C},v),ref:L},t,{ownerState:(0,O.A)({},w,{state:e}),children:(0,j.jsx)(cY,{ownerState:(0,O.A)({},w,{state:e}),className:k.wrapper,ref:T,children:(0,j.jsx)(uY,{ownerState:(0,O.A)({},w,{state:e}),className:k.wrapperInner,children:o})})}))}))}));dY.muiSupportAuto=!0;const hY=dY;var pY=r(67500),fY=r(37948),mY=r(47574);const gY=(0,n.memo)((function(e){let{status:t,message:r}=e;switch(t){case"error":return(0,j.jsx)(yY,{message:r});case"success":return(0,j.jsx)(pY.A,{color:"success"});case"running":return(0,j.jsx)(mY.A,{color:"inherit"})}})),yY=(0,n.memo)((function(e){let{message:t}=e;const[r,i]=(0,n.useState)(null),o=Boolean(r),a=o?"error-message-popover":void 0;return null==t?(0,j.jsx)(fY.A,{color:"error"}):(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(oi,{"aria-describedby":a,onClick:e=>{i(e.currentTarget)},size:"small",color:"error",style:{padding:0},children:(0,j.jsx)(fY.A,{color:"error"})}),(0,j.jsx)(Aa,{id:a,open:o,anchorEl:r,onClose:()=>{i(null)},anchorOrigin:{vertical:"bottom",horizontal:"center"},slotProps:{paper:{sx:{width:"60%"}}},children:(0,j.jsx)(Hi,{variant:"body2",paragraph:!0,color:"error",padding:2,marginBottom:0,whiteSpace:"pre-wrap",children:t})})]})}));function vY(e,t){return e===t||e.length===t.length&&e.every(((e,r)=>e===t[r]))}function xY(e,t){return e===t||e.length===t.length&&e.every(((e,r)=>vY(e,t[r])))}const bY=(0,n.memo)((function(e){let{open:t}=e;return(0,j.jsx)(AG,{children:(0,j.jsx)(eB,{sx:{paddingBottom:0,paddingTop:0},colSpan:11,children:(0,j.jsx)(hY,{in:t,timeout:"auto",unmountOnExit:!0,children:(0,j.jsxs)(yi,{margin:1,children:[(0,j.jsx)(Hi,{variant:"h6",gutterBottom:!0,component:"div",children:"Details"}),(0,j.jsxs)(nG,{size:"small","aria-label":"purchases",children:[(0,j.jsx)(_Y,{}),(0,j.jsx)(wY,{})]})]})})})})})),_Y=(0,n.memo)((function(){return(0,j.jsx)(xG,{children:(0,j.jsxs)(AG,{children:[(0,j.jsx)(eB,{children:"Function"}),(0,j.jsx)(eB,{children:"nodeID"}),(0,j.jsx)(eB,{children:"Success"}),(0,j.jsx)(eB,{children:"NWB"})]})})})),wY=(0,n.memo)((function(){const e=(0,n.useContext)(SY),t=x((e=>t=>Object.keys(BG(t)[e].functions))(e),vY);return(0,j.jsx)(cG,{children:t.map((e=>(0,j.jsx)(kY,{nodeId:e},e)))})})),kY=(0,n.memo)((function(e){let{nodeId:t}=e;const r=(0,n.useContext)(SY),i=x(((e,t)=>r=>HG(e,t)(r).name)(r,t)),o=x(((e,t)=>r=>HG(e,t)(r).status)(r,t)),a=x(((e,t)=>r=>HG(e,t)(r).hasNWB)(r,t)),s=x(((e,t)=>r=>HG(e,t)(r).message)(r,t));return(0,j.jsxs)(AG,{children:[(0,j.jsx)(eB,{component:"th",scope:"row",children:i}),(0,j.jsx)(eB,{children:t}),(0,j.jsx)(eB,{children:(0,j.jsx)(gY,{status:o,message:s})}),(0,j.jsx)(eB,{children:(0,j.jsx)(eY,{name:i,nodeId:t,hasNWB:a})})]},t)})),SY=(0,n.createContext)(""),AY=()=>{const e=x(DG),t=x(zG),r=x(jG),i=C();return(0,n.useEffect)((()=>{e&&i(Uf())}),[i,e]),t?(0,j.jsx)(MY,{}):r?(0,j.jsx)(TY,{}):null},TY=()=>{const e=x(FG);return(0,j.jsxs)(Yq,{severity:"error",children:[(0,j.jsx)(Jq,{children:"failed to get experiments..."}),e]})},MY=(0,n.memo)((function(){const e=x(Vf),t=x(Uk),r=x(BG),i=Object.values(r),o=Object.keys(r),a=C(),[s,l]=(0,n.useState)([]),[c,u]=(0,n.useState)(!1),d=x((e=>{const t=Uk(e),r=Xk(e);return s.includes(t)&&r})),{enqueueSnackbar:h}=hn(),[p,f]=(0,n.useState)("desc"),[m,g]=(0,n.useState)("startedAt"),y=e=>{s.includes(e)?l(s.filter((t=>t!==e))):l([...s,e])},v=0===o.length,[b,_]=(0,n.useState)(0),[w,k]=function(e,t,r){const[i,o]=(0,n.useState)((()=>{const n=localStorage.getItem(e);return null!=n?r(JSON.parse(n)):t}));return(0,n.useEffect)((()=>{localStorage.setItem(e,JSON.stringify(i))}),[i,e]),[i,o]}("optinist_experiment_table_per_page",10,(e=>isNaN(e)?10:e)),S=b>0?Math.max(0,(1+b)*w-o.length):0;return(0,j.jsxs)(yi,{sx:{display:"flex",flexDirection:"column"},children:[(0,j.jsxs)(yi,{sx:{display:"flex",justifyContent:"flex-end",alignItems:"center"},children:[!v&&(0,j.jsxs)(Hi,{sx:{flexGrow:1,m:1},children:[s.length," selected"]}),(0,j.jsx)(gf,{sx:{margin:e=>e.spacing(0,1,1,0)},variant:"outlined",endIcon:(0,j.jsx)(Pq.A,{}),onClick:()=>{a(Uf())},children:"Reload"}),e&&(0,j.jsx)(gf,{"data-testid":"delete-selected-button",sx:{marginBottom:e=>e.spacing(1)},variant:"outlined",color:"error",endIcon:(0,j.jsx)(SI.A,{}),onClick:()=>{u(!0)},disabled:0===s.length||d,children:"Delete"})]}),(0,j.jsx)(Cf,{open:c,setOpen:u,onConfirm:()=>{a($f(s)).unwrap().then((()=>{})).catch((()=>{h("Failed to delete",{variant:"error"})})),s.filter((e=>e===t)).length>0&&a(ZG()),l([]),u(!1)},title:"Delete records?",content:(0,j.jsx)(j.Fragment,{children:s.map((e=>{const t=r[e];return(0,j.jsxs)(Hi,{children:["\u30fb",t?`${t.name} (${e})`:`Unknown (${e})`]},e)}))}),iconType:"warning",confirmLabel:"delete"}),(0,j.jsxs)(Ci,{elevation:0,variant:"outlined",sx:{flexGlow:1,height:"100%"},children:[(0,j.jsx)(pG,{component:Ci,elevation:0,children:(0,j.jsxs)(nG,{"aria-label":"collapsible table",children:[(0,j.jsx)(CY,{order:p,sortTarget:m,sortHandler:e=>()=>{f(m===e&&"asc"===p?"desc":"asc"),g(e)},allCheckIndeterminate:0!==s.length&&s.length!==Object.keys(r).length,allChecked:s.length===Object.keys(r).length,onChangeAllCheck:e=>{l(e?i.map((e=>e.uid)):[])},checkboxVisible:!v,isOwner:e}),(0,j.jsxs)(cG,{children:[i.sort(OY(p,m)).slice(b*w,b*w+w).map((t=>(0,j.jsx)(SY.Provider,{value:t.uid,children:(0,j.jsx)(EY,{onCheckBoxClick:y,checked:s.includes(t.uid),isOwner:e})},t.uid))),S>0&&(0,j.jsx)(AG,{style:{height:53*S},children:(0,j.jsx)(eB,{colSpan:10})}),v&&(0,j.jsx)(AG,{children:(0,j.jsx)(eB,{colSpan:10,children:(0,j.jsx)(Hi,{sx:{color:e=>e.palette.text.secondary,display:"flex",alignItems:"center",justifyContent:"center",height:"300px",textAlign:"center"},variant:"h6",children:"No Rows..."})})})]})]})}),(0,j.jsx)(vB,{rowsPerPageOptions:[5,10,25],component:"div",count:o.length,rowsPerPage:w,page:b,onPageChange:(e,t)=>{_(t)},onRowsPerPageChange:e=>{const t=parseInt(e.target.value,10);k(t),_(0)}})]})]})})),CY=(0,n.memo)((function(e){let{order:t,sortTarget:r,sortHandler:n,allChecked:i,onChangeAllCheck:o,allCheckIndeterminate:a,checkboxVisible:s,isOwner:l}=e;return(0,j.jsx)(xG,{children:(0,j.jsxs)(AG,{children:[(0,j.jsx)(eB,{padding:"checkbox",children:(0,j.jsx)(WU,{"data-testid":"select-all-checkbox",sx:{visibility:s?"visible":"hidden"},checked:i,indeterminate:a,onChange:e=>o(e.target.checked)})}),(0,j.jsx)(eB,{}),(0,j.jsx)(eB,{children:(0,j.jsx)(OG,{active:"startedAt"===r,direction:t,onClick:n("startedAt"),children:"Timestamp"})}),(0,j.jsx)(eB,{children:(0,j.jsx)(OG,{active:"uid"===r,direction:t,onClick:n("uid"),children:"ID"})}),(0,j.jsx)(eB,{children:(0,j.jsx)(OG,{active:"name"===r,direction:t,onClick:n("name"),children:"Name"})}),(0,j.jsx)(eB,{children:"Success"}),(0,j.jsx)(eB,{children:"Reproduce"}),(0,j.jsx)(eB,{children:"Workflow"}),(0,j.jsx)(eB,{children:"Snakemake"}),(0,j.jsx)(eB,{children:"NWB"}),l&&(0,j.jsx)(eB,{children:"Delete"})]})})})),EY=(0,n.memo)((function(e){let{onCheckBoxClick:t,checked:r,isOwner:i}=e;const o=x(jf),a=(0,n.useContext)(SY),s=x((e=>t=>VG(e)(t).startedAt)(a)),l=x((e=>t=>VG(e)(t).finishedAt)(a)),c=x((e=>t=>{const r=BG(t)[e];if(r.status)return r.status;const n=BG(t)[e].functions,i=Object.values(n).map((e=>e.status));return i.findIndex((e=>"error"===e))>=0?"error":i.findIndex((e=>"running"===e))>=0?"running":"success"})(a)),u=x(UG(a)),d=x((e=>t=>VG(e)(t).hasNWB)(a)),[h,p]=(0,n.useState)(!1),[f,m]=(0,n.useState)(!1),[g,y]=(0,n.useState)(""),[v,b]=(0,n.useState)(u),_=C(),{enqueueSnackbar:w}=hn(),k=async()=>{if(v!==u&&void 0!==o){try{await async function(e,t,r){return(await wd.patch(`${bd}/experiments/${e}/${t}/rename`,{new_name:r})).data}(o,a,v)}catch(ene){w("Failed to rename",{variant:"error"})}_(Uf())}};return(0,j.jsxs)(n.Fragment,{children:[(0,j.jsxs)(AG,{sx:{"& > *":{borderBottom:"unset"},[`& .${KN.root}`]:{borderBottomWidth:0}},children:[(0,j.jsx)(eB,{padding:"checkbox",children:(0,j.jsx)(WU,{onChange:()=>t(a),checked:r})}),(0,j.jsx)(eB,{children:(0,j.jsx)(oi,{"aria-label":"expand row",size:"small",onClick:()=>p((e=>!e)),children:h?(0,j.jsx)(Iq.A,{}):(0,j.jsx)(Eq.A,{})})}),(0,j.jsx)(eB,{sx:{minWidth:210,width:210},component:"th",scope:"row",children:null==l?s:(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(Hi,{variant:"body2",children:`${s} - ${l.split(" ")[1]}`}),(0,j.jsxs)(Hi,{variant:"body2",children:["(elapsed"," ",(new Date(l).getTime()-new Date(s).getTime())/1e3," ","sec)"]})]})}),(0,j.jsx)(eB,{children:a}),(0,j.jsx)(eB,{sx:{width:160,position:"relative"},onClick:e=>{f||g||(e.preventDefault(),m(!0))},children:f?(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(IY,{placeholder:"Name",error:!!g,onChange:e=>{let t="";e.target.value.trim()||(t="Name is empty"),y(t),b(e.target.value)},autoFocus:!0,onBlur:e=>{e.preventDefault(),g||setTimeout((()=>{m(!1),k()}),300)},value:v}),g?(0,j.jsx)(PY,{children:g}):null]}):v}),(0,j.jsx)(eB,{children:(0,j.jsx)(gY,{status:c})}),(0,j.jsx)(eB,{children:(0,j.jsx)(iY,{})}),(0,j.jsx)(eB,{children:(0,j.jsx)(rY,{})}),(0,j.jsx)(eB,{children:(0,j.jsx)(tY,{})}),(0,j.jsx)(eB,{children:(0,j.jsx)(eY,{name:a,hasNWB:d})}),i&&(0,j.jsxs)(eB,{children:[" ",(0,j.jsx)(JG,{})]})]}),(0,j.jsx)(bY,{open:h})]})})),IY=(0,yn.Ay)("input")((e=>{let{error:t}=e;return{width:"100%",border:"none",borderBottom:"1px solid",outline:"none",color:t?"#d32f2f":"",borderColor:t?"#d32f2f":""}})),PY=(0,yn.Ay)(Hi)((()=>({color:"#d32f2f",fontSize:12,height:12,position:"absolute",bottom:12})));function OY(e,t){return"desc"===e?(e,r)=>RY(e,r,t):(e,r)=>-RY(e,r,t)}function RY(e,t,r){return t[r]e[r]?1:0}const LY=e=>e.flowElement.flowNodes,DY=e=>e.flowElement.flowEdges,zY=e=>e.flowElement.flowPosition,jY=e=>e.flowElement.loading,FY=e=>t=>LY(t).find((t=>t.id===e)),NY=e=>t=>{var r,n;return null===(r=FY(e)(t))||void 0===r||null===(n=r.data)||void 0===n?void 0:n.label},BY=e=>t=>{const r=(e=>t=>DY(t).filter((t=>t.target===e)).map((e=>e.source)))(e)(t);return 0!==r.length&&(!!r.some((e=>(e=>t=>{var r;return null===(r=t.algorithmNode[e])||void 0===r?void 0:r.isUpdate})(e)(t)))||r.some((e=>BY(e)(t))))},VY=(0,n.memo)((function(){const e=x(NG),t=x(jY);return(0,j.jsx)("div",{style:{display:"flex"},children:(0,j.jsxs)("main",{style:{display:"flex",flexDirection:"column",flexGrow:1,minHeight:kC},children:[(0,j.jsx)(AY,{}),(0,j.jsx)(wi,{loading:e||t})]})})}));function UY(e,t){for(var r=arguments.length,n=new Array(r>2?r-2:0),i=2;i0&&void 0!==arguments[0]?arguments[0]:[],r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{publishSource:!0};const{publishSource:n=!0,clientOffset:i,getSourceClientOffset:o}=r,a=e.getMonitor(),s=e.getRegistry();e.dispatch(ZY(i)),function(e,t,r){UY(!t.isDragging(),"Cannot call beginDrag while dragging."),e.forEach((function(e){UY(r.getSource(e),"Expected sourceIds to be registered.")}))}(t,a,s);const l=function(e,t){let r=null;for(let n=e.length-1;n>=0;n--)if(t.canDragSource(e[n])){r=e[n];break}return r}(t,a);if(null==l)return void e.dispatch(KY);let c=null;if(i){if(!o)throw new Error("getSourceClientOffset must be defined");!function(e){UY("function"===typeof e,"When clientOffset is provided, getSourceClientOffset must be a function.")}(o),c=o(l)}e.dispatch(ZY(i,c));const u=s.getSource(l).beginDrag(a,l);if(null==u)return;!function(e){UY(HY(e),"Item must be an object.")}(u),s.pinSource(l);const d=s.getSourceType(l);return{type:WY,payload:{itemType:d,item:u,sourceId:l,clientOffset:i||null,sourceClientOffset:c||null,isSourcePublic:!!n}}}}function QY(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function eX(e){for(var t=1;t0&&void 0!==arguments[0]?arguments[0]:{};const r=e.getMonitor(),n=e.getRegistry();!function(e){UY(e.isDragging(),"Cannot call drop while not dragging."),UY(!e.didDrop(),"Cannot call drop twice during one drag operation.")}(r);const i=function(e){const t=e.getTargetIds().filter(e.canDropOnTarget,e);return t.reverse(),t}(r);i.forEach(((i,o)=>{const a=function(e,t,r,n){const i=r.getTarget(e);let o=i?i.drop(n,e):void 0;(function(e){UY("undefined"===typeof e||HY(e),"Drop result must either be an object or undefined.")})(o),"undefined"===typeof o&&(o=0===t?{}:n.getDropResult());return o}(i,o,n,r),s={type:YY,payload:{dropResult:eX({},t,a)}};e.dispatch(s)}))}}function rX(e){return function(){const t=e.getMonitor(),r=e.getRegistry();!function(e){UY(e.isDragging(),"Cannot call endDrag while not dragging.")}(t);const n=t.getSourceId();if(null!=n){r.getSource(n,!0).endDrag(t,n),r.unpinSource()}return{type:XY}}}function nX(e,t){return null===t?null===e:Array.isArray(e)?e.some((e=>e===t)):e===t}function iX(e){return function(t){let{clientOffset:r}=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};!function(e){UY(Array.isArray(e),"Expected targetIds to be an array.")}(t);const n=t.slice(0),i=e.getMonitor(),o=e.getRegistry();return function(e,t,r){for(let n=e.length-1;n>=0;n--){const i=e[n];nX(t.getTargetType(i),r)||e.splice(n,1)}}(n,o,i.getItemType()),function(e,t,r){UY(t.isDragging(),"Cannot call hover while not dragging."),UY(!t.didDrop(),"Cannot call hover after drop.");for(let n=0;n{const o=r[i];var a;return n[i]=(a=o,function(){for(var r=arguments.length,n=new Array(r),i=0;i{const e=this.store.getState().refCount>0;this.backend&&(e&&!this.isSetUp?(this.backend.setup(),this.isSetUp=!0):!e&&this.isSetUp&&(this.backend.teardown(),this.isSetUp=!1))},this.store=e,this.monitor=t,e.subscribe(this.handleRefCountChange)}}function sX(e,t){return{x:e.x-t.x,y:e.y-t.y}}const lX=[],cX=[];lX.__IS_NONE__=!0,cX.__IS_ALL__=!0;class uX{subscribeToStateChange(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{handlerIds:r}=t;UY("function"===typeof e,"listener must be a function."),UY("undefined"===typeof r||Array.isArray(r),"handlerIds, when specified, must be an array of strings.");let n=this.store.getState().stateId;return this.store.subscribe((()=>{const t=this.store.getState(),i=t.stateId;try{const o=i===n||i===n+1&&!function(e,t){return e!==lX&&(e===cX||"undefined"===typeof t||(r=e,t.filter((e=>r.indexOf(e)>-1))).length>0);var r}(t.dirtyHandlerIds,r);o||e()}finally{n=i}}))}subscribeToOffsetChange(e){UY("function"===typeof e,"listener must be a function.");let t=this.store.getState().dragOffset;return this.store.subscribe((()=>{const r=this.store.getState().dragOffset;r!==t&&(t=r,e())}))}canDragSource(e){if(!e)return!1;const t=this.registry.getSource(e);return UY(t,`Expected to find a valid source. sourceId=${e}`),!this.isDragging()&&t.canDrag(this,e)}canDropOnTarget(e){if(!e)return!1;const t=this.registry.getTarget(e);if(UY(t,`Expected to find a valid target. targetId=${e}`),!this.isDragging()||this.didDrop())return!1;return nX(this.registry.getTargetType(e),this.getItemType())&&t.canDrop(this,e)}isDragging(){return Boolean(this.getItemType())}isDraggingSource(e){if(!e)return!1;const t=this.registry.getSource(e,!0);if(UY(t,`Expected to find a valid source. sourceId=${e}`),!this.isDragging()||!this.isSourcePublic())return!1;return this.registry.getSourceType(e)===this.getItemType()&&t.isDragging(this,e)}isOverTarget(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{shallow:!1};if(!e)return!1;const{shallow:r}=t;if(!this.isDragging())return!1;const n=this.registry.getTargetType(e),i=this.getItemType();if(i&&!nX(n,i))return!1;const o=this.getTargetIds();if(!o.length)return!1;const a=o.indexOf(e);return r?a===o.length-1:a>-1}getItemType(){return this.store.getState().dragOperation.itemType}getItem(){return this.store.getState().dragOperation.item}getSourceId(){return this.store.getState().dragOperation.sourceId}getTargetIds(){return this.store.getState().dragOperation.targetIds}getDropResult(){return this.store.getState().dragOperation.dropResult}didDrop(){return this.store.getState().dragOperation.didDrop}isSourcePublic(){return Boolean(this.store.getState().dragOperation.isSourcePublic)}getInitialClientOffset(){return this.store.getState().dragOffset.initialClientOffset}getInitialSourceClientOffset(){return this.store.getState().dragOffset.initialSourceClientOffset}getClientOffset(){return this.store.getState().dragOffset.clientOffset}getSourceClientOffset(){return function(e){const{clientOffset:t,initialClientOffset:r,initialSourceClientOffset:n}=e;return t&&r&&n?sX((o=n,{x:(i=t).x+o.x,y:i.y+o.y}),r):null;var i,o}(this.store.getState().dragOffset)}getDifferenceFromInitialOffset(){return function(e){const{clientOffset:t,initialClientOffset:r}=e;return t&&r?sX(t,r):null}(this.store.getState().dragOffset)}constructor(e,t){this.store=e,this.registry=t}}const dX="undefined"!==typeof global?global:self,hX=dX.MutationObserver||dX.WebKitMutationObserver;function pX(e){return function(){const t=setTimeout(n,0),r=setInterval(n,50);function n(){clearTimeout(t),clearInterval(r),e()}}}const fX="function"===typeof hX?function(e){let t=1;const r=new hX(e),n=document.createTextNode("");return r.observe(n,{characterData:!0}),function(){t=-t,n.data=t}}:pX;class mX{call(){try{this.task&&this.task()}catch(e){this.onError(e)}finally{this.task=null,this.release(this)}}constructor(e,t){this.onError=e,this.release=t,this.task=null}}const gX=new class{enqueueTask(e){const{queue:t,requestFlush:r}=this;t.length||(r(),this.flushing=!0),t[t.length]=e}constructor(){this.queue=[],this.pendingErrors=[],this.flushing=!1,this.index=0,this.capacity=1024,this.flush=()=>{const{queue:e}=this;for(;this.indexthis.capacity){for(let t=0,r=e.length-this.index;t{this.pendingErrors.push(e),this.requestErrorThrow()},this.requestFlush=fX(this.flush),this.requestErrorThrow=pX((()=>{if(this.pendingErrors.length)throw this.pendingErrors.shift()}))}},yX=new class{create(e){const t=this.freeTasks,r=t.length?t.pop():new mX(this.onError,(e=>t[t.length]=e));return r.task=e,r}constructor(e){this.onError=e,this.freeTasks=[]}}(gX.registerPendingError);const vX="dnd-core/ADD_SOURCE",xX="dnd-core/ADD_TARGET",bX="dnd-core/REMOVE_SOURCE",_X="dnd-core/REMOVE_TARGET";function wX(e,t){t&&Array.isArray(e)?e.forEach((e=>wX(e,!1))):UY("string"===typeof e||"symbol"===typeof e,t?"Type can only be a string, a symbol, or an array of either.":"Type can only be a string or a symbol.")}var kX,SX;(SX=kX||(kX={})).SOURCE="SOURCE",SX.TARGET="TARGET";let AX=0;function TX(e){const t=(AX++).toString();switch(e){case kX.SOURCE:return`S${t}`;case kX.TARGET:return`T${t}`;default:throw new Error(`Unknown Handler Role: ${e}`)}}function MX(e){switch(e[0]){case"S":return kX.SOURCE;case"T":return kX.TARGET;default:throw new Error(`Cannot parse handler ID: ${e}`)}}function CX(e,t){const r=e.entries();let n=!1;do{const{done:e,value:[,i]}=r.next();if(i===t)return!0;n=!!e}while(!n);return!1}class EX{addSource(e,t){wX(e),function(e){UY("function"===typeof e.canDrag,"Expected canDrag to be a function."),UY("function"===typeof e.beginDrag,"Expected beginDrag to be a function."),UY("function"===typeof e.endDrag,"Expected endDrag to be a function.")}(t);const r=this.addHandler(kX.SOURCE,e,t);return this.store.dispatch(function(e){return{type:vX,payload:{sourceId:e}}}(r)),r}addTarget(e,t){wX(e,!0),function(e){UY("function"===typeof e.canDrop,"Expected canDrop to be a function."),UY("function"===typeof e.hover,"Expected hover to be a function."),UY("function"===typeof e.drop,"Expected beginDrag to be a function.")}(t);const r=this.addHandler(kX.TARGET,e,t);return this.store.dispatch(function(e){return{type:xX,payload:{targetId:e}}}(r)),r}containsHandler(e){return CX(this.dragSources,e)||CX(this.dropTargets,e)}getSource(e){let t=arguments.length>1&&void 0!==arguments[1]&&arguments[1];UY(this.isSourceId(e),"Expected a valid source ID.");return t&&e===this.pinnedSourceId?this.pinnedSource:this.dragSources.get(e)}getTarget(e){return UY(this.isTargetId(e),"Expected a valid target ID."),this.dropTargets.get(e)}getSourceType(e){return UY(this.isSourceId(e),"Expected a valid source ID."),this.types.get(e)}getTargetType(e){return UY(this.isTargetId(e),"Expected a valid target ID."),this.types.get(e)}isSourceId(e){return MX(e)===kX.SOURCE}isTargetId(e){return MX(e)===kX.TARGET}removeSource(e){var t;UY(this.getSource(e),"Expected an existing source."),this.store.dispatch(function(e){return{type:bX,payload:{sourceId:e}}}(e)),t=()=>{this.dragSources.delete(e),this.types.delete(e)},gX.enqueueTask(yX.create(t))}removeTarget(e){UY(this.getTarget(e),"Expected an existing target."),this.store.dispatch(function(e){return{type:_X,payload:{targetId:e}}}(e)),this.dropTargets.delete(e),this.types.delete(e)}pinSource(e){const t=this.getSource(e);UY(t,"Expected an existing source."),this.pinnedSourceId=e,this.pinnedSource=t}unpinSource(){UY(this.pinnedSource,"No source is pinned at the time."),this.pinnedSourceId=null,this.pinnedSource=null}addHandler(e,t,r){const n=TX(e);return this.types.set(n,t),e===kX.SOURCE?this.dragSources.set(n,r):e===kX.TARGET&&this.dropTargets.set(n,r),n}constructor(e){this.types=new Map,this.dragSources=new Map,this.dropTargets=new Map,this.pinnedSourceId=null,this.pinnedSource=null,this.store=e}}const IX=(e,t)=>e===t;function PX(){let e=arguments.length>1?arguments[1]:void 0;switch(e.type){case GY:break;case vX:case xX:case _X:case bX:return lX;default:return cX}const{targetIds:t=[],prevTargetIds:r=[]}=e.payload,n=function(e,t){const r=new Map,n=e=>{r.set(e,r.has(e)?r.get(e)+1:1)};e.forEach(n),t.forEach(n);const i=[];return r.forEach(((e,t)=>{1===e&&i.push(t)})),i}(t,r),i=n.length>0||!function(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:IX;if(e.length!==t.length)return!1;for(let n=0;n0&&void 0!==arguments[0]?arguments[0]:RX,t=arguments.length>1?arguments[1]:void 0;const{payload:r}=t;switch(t.type){case $Y:case WY:return{initialSourceClientOffset:r.sourceClientOffset,initialClientOffset:r.clientOffset,clientOffset:r.clientOffset};case GY:return n=e.clientOffset,i=r.clientOffset,!n&&!i||n&&i&&n.x===i.x&&n.y===i.y?e:function(e){for(var t=1;t0&&void 0!==arguments[0]?arguments[0]:jX,t=arguments.length>1?arguments[1]:void 0;const{payload:r}=t;switch(t.type){case WY:return zX({},e,{itemType:r.itemType,item:r.item,sourceId:r.sourceId,isSourcePublic:r.isSourcePublic,dropResult:null,didDrop:!1});case qY:return zX({},e,{isSourcePublic:!0});case GY:return zX({},e,{targetIds:r.targetIds});case _X:return-1===e.targetIds.indexOf(r.targetId)?e:zX({},e,{targetIds:(n=e.targetIds,i=r.targetId,n.filter((e=>e!==i)))});case YY:return zX({},e,{dropResult:r.dropResult,didDrop:!0,targetIds:[]});case XY:return zX({},e,{itemType:null,item:null,sourceId:null,dropResult:null,didDrop:!1,isSourcePublic:null,targetIds:[]});default:return e}var n,i}function NX(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;switch((arguments.length>1?arguments[1]:void 0).type){case vX:case xX:return e+1;case bX:case _X:return e-1;default:return e}}function BX(){return(arguments.length>0&&void 0!==arguments[0]?arguments[0]:0)+1}function VX(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function UX(e){for(var t=1;t0&&void 0!==arguments[0]?arguments[0]:{},t=arguments.length>1?arguments[1]:void 0;return{dirtyHandlerIds:PX(e.dirtyHandlerIds,{type:t.type,payload:UX({},t.payload,{prevTargetIds:(r=e,n="dragOperation.targetIds",i=[],n.split(".").reduce(((e,t)=>e&&e[t]?e[t]:i||null),r))})}),dragOffset:LX(e.dragOffset,t),refCount:NX(e.refCount,t),dragOperation:FX(e.dragOperation,t),stateId:BX(e.stateId)};var r,n,i}function $X(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:void 0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};const n=function(e){const t="undefined"!==typeof window&&window.__REDUX_DEVTOOLS_EXTENSION__;return rl(HX,e&&t&&t({name:"dnd-core",instanceId:"dnd-core"}))}(arguments.length>3&&void 0!==arguments[3]&&arguments[3]),i=new uX(n,new EX(n)),o=new aX(n,i),a=e(o,t,r);return o.receiveBackend(a),o}const WX=(0,n.createContext)({dragDropManager:void 0});function qX(e,t){if(null==e)return{};var r,n,i=function(e,t){if(null==e)return{};var r,n,i={},o=Object.keys(e);for(n=0;n=0||(i[r]=e[r]);return i}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(i[r]=e[r])}return i}let GX=0;const YX=Symbol.for("__REACT_DND_CONTEXT_INSTANCE__");var XX=(0,n.memo)((function(e){var{children:t}=e,r=qX(e,["children"]);const[i,o]=function(e){if("manager"in e){return[{dragDropManager:e.manager},!1]}const t=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:ZX(),r=arguments.length>2?arguments[2]:void 0,n=arguments.length>3?arguments[3]:void 0;const i=t;i[YX]||(i[YX]={dragDropManager:$X(e,t,r,n)});return i[YX]}(e.backend,e.context,e.options,e.debugMode),r=!e.context;return[t,r]}(r);return(0,n.useEffect)((()=>{if(o){const e=ZX();return++GX,()=>{0===--GX&&(e[YX]=null)}}}),[]),(0,j.jsx)(WX.Provider,{value:i,children:t})}));function ZX(){return"undefined"!==typeof global?global:window}function KX(e){let t=null;return()=>(null==t&&(t=e()),t)}class JX{enter(e){const t=this.entered.length;return this.entered=function(e,t){const r=new Set,n=e=>r.add(e);e.forEach(n),t.forEach(n);const i=[];return r.forEach((e=>i.push(e))),i}(this.entered.filter((t=>this.isNodeInDocument(t)&&(!t.contains||t.contains(e)))),[e]),0===t&&this.entered.length>0}leave(e){const t=this.entered.length;var r,n;return this.entered=(r=this.entered.filter(this.isNodeInDocument),n=e,r.filter((e=>e!==n))),t>0&&0===this.entered.length}reset(){this.entered=[]}constructor(e){this.entered=[],this.isNodeInDocument=e}}class QX{initializeExposedProperties(){Object.keys(this.config.exposeProperties).forEach((e=>{Object.defineProperty(this.item,e,{configurable:!0,enumerable:!0,get:()=>(console.warn(`Browser doesn't allow reading "${e}" until the drop event.`),null)})}))}loadDataTransfer(e){if(e){const t={};Object.keys(this.config.exposeProperties).forEach((r=>{const n=this.config.exposeProperties[r];null!=n&&(t[r]={value:n(e,this.config.matchesTypes),configurable:!0,enumerable:!0})})),Object.defineProperties(this.item,t)}}canDrag(){return!0}beginDrag(){return this.item}isDragging(e,t){return t===e.getSourceId()}endDrag(){}constructor(e){this.config=e,this.item={},this.initializeExposedProperties()}}const eZ="__NATIVE_FILE__",tZ="__NATIVE_URL__",rZ="__NATIVE_TEXT__",nZ="__NATIVE_HTML__";function iZ(e,t,r){const n=t.reduce(((t,r)=>t||e.getData(r)),"");return null!=n?n:r}const oZ={[eZ]:{exposeProperties:{files:e=>Array.prototype.slice.call(e.files),items:e=>e.items,dataTransfer:e=>e},matchesTypes:["Files"]},[nZ]:{exposeProperties:{html:(e,t)=>iZ(e,t,""),dataTransfer:e=>e},matchesTypes:["Html","text/html"]},[tZ]:{exposeProperties:{urls:(e,t)=>iZ(e,t,"").split("\n"),dataTransfer:e=>e},matchesTypes:["Url","text/uri-list"]},[rZ]:{exposeProperties:{text:(e,t)=>iZ(e,t,""),dataTransfer:e=>e},matchesTypes:["Text","text/plain"]}};function aZ(e){if(!e)return null;const t=Array.prototype.slice.call(e.types||[]);return Object.keys(oZ).filter((e=>{const r=oZ[e];return!!(null===r||void 0===r?void 0:r.matchesTypes)&&r.matchesTypes.some((e=>t.indexOf(e)>-1))}))[0]||null}const sZ=KX((()=>/firefox/i.test(navigator.userAgent))),lZ=KX((()=>Boolean(window.safari)));class cZ{interpolate(e){const{xs:t,ys:r,c1s:n,c2s:i,c3s:o}=this;let a=t.length-1;if(e===t[a])return r[a];let s,l=0,c=o.length-1;for(;l<=c;){s=Math.floor(.5*(l+c));const n=t[s];if(ne))return r[s];c=s-1}}a=Math.max(0,c);const u=e-t[a],d=u*u;return r[a]+n[a]*u+i[a]*d+o[a]*u*d}constructor(e,t){const{length:r}=e,n=[];for(let p=0;pe[t]{let e=new cZ([0,.5,1],[s.y,s.y/c*p,s.y+p-c]).interpolate(d);return lZ()&&o&&(e+=(window.devicePixelRatio-1)*p),e})()}}class pZ{get window(){return this.globalContext?this.globalContext:"undefined"!==typeof window?window:void 0}get document(){var e;return(null===(e=this.globalContext)||void 0===e?void 0:e.document)?this.globalContext.document:this.window?this.window.document:void 0}get rootElement(){var e;return(null===(e=this.optionsArgs)||void 0===e?void 0:e.rootElement)||this.window}constructor(e,t){this.ownerDocument=null,this.globalContext=e,this.optionsArgs=t}}function fZ(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function mZ(e){for(var t=1;t{this.sourcePreviewNodes.delete(e),this.sourcePreviewNodeOptions.delete(e)}}connectDragSource(e,t,r){this.sourceNodes.set(e,t),this.sourceNodeOptions.set(e,r);const n=t=>this.handleDragStart(t,e),i=e=>this.handleSelectStart(e);return t.setAttribute("draggable","true"),t.addEventListener("dragstart",n),t.addEventListener("selectstart",i),()=>{this.sourceNodes.delete(e),this.sourceNodeOptions.delete(e),t.removeEventListener("dragstart",n),t.removeEventListener("selectstart",i),t.setAttribute("draggable","false")}}connectDropTarget(e,t){const r=t=>this.handleDragEnter(t,e),n=t=>this.handleDragOver(t,e),i=t=>this.handleDrop(t,e);return t.addEventListener("dragenter",r),t.addEventListener("dragover",n),t.addEventListener("drop",i),()=>{t.removeEventListener("dragenter",r),t.removeEventListener("dragover",n),t.removeEventListener("drop",i)}}addEventListeners(e){e.addEventListener&&(e.addEventListener("dragstart",this.handleTopDragStart),e.addEventListener("dragstart",this.handleTopDragStartCapture,!0),e.addEventListener("dragend",this.handleTopDragEndCapture,!0),e.addEventListener("dragenter",this.handleTopDragEnter),e.addEventListener("dragenter",this.handleTopDragEnterCapture,!0),e.addEventListener("dragleave",this.handleTopDragLeaveCapture,!0),e.addEventListener("dragover",this.handleTopDragOver),e.addEventListener("dragover",this.handleTopDragOverCapture,!0),e.addEventListener("drop",this.handleTopDrop),e.addEventListener("drop",this.handleTopDropCapture,!0))}removeEventListeners(e){e.removeEventListener&&(e.removeEventListener("dragstart",this.handleTopDragStart),e.removeEventListener("dragstart",this.handleTopDragStartCapture,!0),e.removeEventListener("dragend",this.handleTopDragEndCapture,!0),e.removeEventListener("dragenter",this.handleTopDragEnter),e.removeEventListener("dragenter",this.handleTopDragEnterCapture,!0),e.removeEventListener("dragleave",this.handleTopDragLeaveCapture,!0),e.removeEventListener("dragover",this.handleTopDragOver),e.removeEventListener("dragover",this.handleTopDragOverCapture,!0),e.removeEventListener("drop",this.handleTopDrop),e.removeEventListener("drop",this.handleTopDropCapture,!0))}getCurrentSourceNodeOptions(){const e=this.monitor.getSourceId(),t=this.sourceNodeOptions.get(e);return mZ({dropEffect:this.altKeyPressed?"copy":"move"},t||{})}getCurrentDropEffect(){return this.isDraggingNativeItem()?"copy":this.getCurrentSourceNodeOptions().dropEffect}getCurrentSourcePreviewNodeOptions(){const e=this.monitor.getSourceId();return mZ({anchorX:.5,anchorY:.5,captureDraggingState:!1},this.sourcePreviewNodeOptions.get(e)||{})}isDraggingNativeItem(){const e=this.monitor.getItemType();return Object.keys(t).some((r=>t[r]===e))}beginDragNativeItem(e,t){this.clearCurrentDragSourceNode(),this.currentNativeSource=function(e,t){const r=oZ[e];if(!r)throw new Error(`native type ${e} has no configuration`);const n=new QX(r);return n.loadDataTransfer(t),n}(e,t),this.currentNativeHandle=this.registry.addSource(e,this.currentNativeSource),this.actions.beginDrag([this.currentNativeHandle])}setCurrentDragSourceNode(e){this.clearCurrentDragSourceNode(),this.currentDragSourceNode=e;this.mouseMoveTimeoutTimer=setTimeout((()=>{var e;return null===(e=this.rootElement)||void 0===e?void 0:e.addEventListener("mousemove",this.endDragIfSourceWasRemovedFromDOM,!0)}),1e3)}clearCurrentDragSourceNode(){if(this.currentDragSourceNode){var e;if(this.currentDragSourceNode=null,this.rootElement)null===(e=this.window)||void 0===e||e.clearTimeout(this.mouseMoveTimeoutTimer||void 0),this.rootElement.removeEventListener("mousemove",this.endDragIfSourceWasRemovedFromDOM,!0);return this.mouseMoveTimeoutTimer=null,!0}return!1}handleDragStart(e,t){e.defaultPrevented||(this.dragStartSourceIds||(this.dragStartSourceIds=[]),this.dragStartSourceIds.unshift(t))}handleDragEnter(e,t){this.dragEnterTargetIds.unshift(t)}handleDragOver(e,t){null===this.dragOverTargetIds&&(this.dragOverTargetIds=[]),this.dragOverTargetIds.unshift(t)}handleDrop(e,t){this.dropTargetIds.unshift(t)}constructor(e,t,r){this.sourcePreviewNodes=new Map,this.sourcePreviewNodeOptions=new Map,this.sourceNodes=new Map,this.sourceNodeOptions=new Map,this.dragStartSourceIds=null,this.dropTargetIds=[],this.dragEnterTargetIds=[],this.currentNativeSource=null,this.currentNativeHandle=null,this.currentDragSourceNode=null,this.altKeyPressed=!1,this.mouseMoveTimeoutTimer=null,this.asyncEndDragFrameId=null,this.dragOverTargetIds=null,this.lastClientOffset=null,this.hoverRafId=null,this.getSourceClientOffset=e=>{const t=this.sourceNodes.get(e);return t&&uZ(t)||null},this.endDragNativeItem=()=>{this.isDraggingNativeItem()&&(this.actions.endDrag(),this.currentNativeHandle&&this.registry.removeSource(this.currentNativeHandle),this.currentNativeHandle=null,this.currentNativeSource=null)},this.isNodeInDocument=e=>Boolean(e&&this.document&&this.document.body&&this.document.body.contains(e)),this.endDragIfSourceWasRemovedFromDOM=()=>{const e=this.currentDragSourceNode;null==e||this.isNodeInDocument(e)||(this.clearCurrentDragSourceNode()&&this.monitor.isDragging()&&this.actions.endDrag(),this.cancelHover())},this.scheduleHover=e=>{null===this.hoverRafId&&"undefined"!==typeof requestAnimationFrame&&(this.hoverRafId=requestAnimationFrame((()=>{this.monitor.isDragging()&&this.actions.hover(e||[],{clientOffset:this.lastClientOffset}),this.hoverRafId=null})))},this.cancelHover=()=>{null!==this.hoverRafId&&"undefined"!==typeof cancelAnimationFrame&&(cancelAnimationFrame(this.hoverRafId),this.hoverRafId=null)},this.handleTopDragStartCapture=()=>{this.clearCurrentDragSourceNode(),this.dragStartSourceIds=[]},this.handleTopDragStart=e=>{if(e.defaultPrevented)return;const{dragStartSourceIds:t}=this;this.dragStartSourceIds=null;const r=dZ(e);this.monitor.isDragging()&&(this.actions.endDrag(),this.cancelHover()),this.actions.beginDrag(t||[],{publishSource:!1,getSourceClientOffset:this.getSourceClientOffset,clientOffset:r});const{dataTransfer:n}=e,i=aZ(n);if(this.monitor.isDragging()){if(n&&"function"===typeof n.setDragImage){const e=this.monitor.getSourceId(),t=this.sourceNodes.get(e),i=this.sourcePreviewNodes.get(e)||t;if(i){const{anchorX:e,anchorY:o,offsetX:a,offsetY:s}=this.getCurrentSourcePreviewNodeOptions(),l=hZ(t,i,r,{anchorX:e,anchorY:o},{offsetX:a,offsetY:s});n.setDragImage(i,l.x,l.y)}}try{null===n||void 0===n||n.setData("application/json",{})}catch(o){}this.setCurrentDragSourceNode(e.target);const{captureDraggingState:t}=this.getCurrentSourcePreviewNodeOptions();t?this.actions.publishDragSource():setTimeout((()=>this.actions.publishDragSource()),0)}else if(i)this.beginDragNativeItem(i);else{if(n&&!n.types&&(e.target&&!e.target.hasAttribute||!e.target.hasAttribute("draggable")))return;e.preventDefault()}},this.handleTopDragEndCapture=()=>{this.clearCurrentDragSourceNode()&&this.monitor.isDragging()&&this.actions.endDrag(),this.cancelHover()},this.handleTopDragEnterCapture=e=>{var t;(this.dragEnterTargetIds=[],this.isDraggingNativeItem())&&(null===(t=this.currentNativeSource)||void 0===t||t.loadDataTransfer(e.dataTransfer));if(!this.enterLeaveCounter.enter(e.target)||this.monitor.isDragging())return;const{dataTransfer:r}=e,n=aZ(r);n&&this.beginDragNativeItem(n,r)},this.handleTopDragEnter=e=>{const{dragEnterTargetIds:t}=this;if(this.dragEnterTargetIds=[],!this.monitor.isDragging())return;this.altKeyPressed=e.altKey,t.length>0&&this.actions.hover(t,{clientOffset:dZ(e)});t.some((e=>this.monitor.canDropOnTarget(e)))&&(e.preventDefault(),e.dataTransfer&&(e.dataTransfer.dropEffect=this.getCurrentDropEffect()))},this.handleTopDragOverCapture=e=>{var t;(this.dragOverTargetIds=[],this.isDraggingNativeItem())&&(null===(t=this.currentNativeSource)||void 0===t||t.loadDataTransfer(e.dataTransfer))},this.handleTopDragOver=e=>{const{dragOverTargetIds:t}=this;if(this.dragOverTargetIds=[],!this.monitor.isDragging())return e.preventDefault(),void(e.dataTransfer&&(e.dataTransfer.dropEffect="none"));this.altKeyPressed=e.altKey,this.lastClientOffset=dZ(e),this.scheduleHover(t);(t||[]).some((e=>this.monitor.canDropOnTarget(e)))?(e.preventDefault(),e.dataTransfer&&(e.dataTransfer.dropEffect=this.getCurrentDropEffect())):this.isDraggingNativeItem()?e.preventDefault():(e.preventDefault(),e.dataTransfer&&(e.dataTransfer.dropEffect="none"))},this.handleTopDragLeaveCapture=e=>{this.isDraggingNativeItem()&&e.preventDefault();this.enterLeaveCounter.leave(e.target)&&(this.isDraggingNativeItem()&&setTimeout((()=>this.endDragNativeItem()),0),this.cancelHover())},this.handleTopDropCapture=e=>{var t;(this.dropTargetIds=[],this.isDraggingNativeItem())?(e.preventDefault(),null===(t=this.currentNativeSource)||void 0===t||t.loadDataTransfer(e.dataTransfer)):aZ(e.dataTransfer)&&e.preventDefault();this.enterLeaveCounter.reset()},this.handleTopDrop=e=>{const{dropTargetIds:t}=this;this.dropTargetIds=[],this.actions.hover(t,{clientOffset:dZ(e)}),this.actions.drop({dropEffect:this.getCurrentDropEffect()}),this.isDraggingNativeItem()?this.endDragNativeItem():this.monitor.isDragging()&&this.actions.endDrag(),this.cancelHover()},this.handleSelectStart=e=>{const t=e.target;"function"===typeof t.dragDrop&&("INPUT"===t.tagName||"SELECT"===t.tagName||"TEXTAREA"===t.tagName||t.isContentEditable||(e.preventDefault(),t.dragDrop()))},this.options=new pZ(t,r),this.actions=e.getActions(),this.monitor=e.getMonitor(),this.registry=e.getRegistry(),this.enterLeaveCounter=new JX(this.isNodeInDocument)}}const yZ=function(e,t,r){return new gZ(e,t,r)};var vZ=r(74681);const xZ=(0,Ud.A)((0,j.jsx)("path",{d:"M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8zM6 20V4h7v5h5v11z"}),"InsertDriveFileOutlined"),bZ=(0,n.memo)((function(e){let{title:t,children:r}=e;return(0,j.jsxs)(yi,{marginBottom:2,children:[(0,j.jsx)(_Z,{children:t}),r,(0,j.jsx)(yU,{style:{marginTop:8}})]})})),_Z=(0,yn.Ay)((e=>(0,j.jsx)(Hi,{...e})))((e=>{let{theme:t}=e;return{fontWeight:"bold",fontSize:"1.1rem",marginBottom:t.spacing(1)}})),wZ=(0,yn.Ay)(tH)({fontWeight:"bold",fontSize:"0.95rem",color:"text.secondary"}),kZ=(0,n.memo)((function(e){let{filePath:t}=e;const r=t?vw(t):"No file is selected";return(0,j.jsx)(Mp,{title:r,children:(0,j.jsx)(_L,{icon:(0,j.jsx)(xZ,{}),label:r,sx:{marginBottom:2}})})})),SZ=()=>{const e=x(jf),t=x(Nf),r=x(Uk),n=x(Hk),i=x(Pf);return(0,j.jsxs)(j.Fragment,{children:[!i&&(0,j.jsx)(bZ,{title:"Workspace",children:(0,j.jsxs)(Mf,{container:!0,mb:1,children:[e&&(0,j.jsx)(AZ,{label:"ID",value:e.toFixed(),section:"workspace"}),t&&(0,j.jsx)(AZ,{label:"NAME",value:t,section:"workspace"})]})}),r&&(0,j.jsx)(bZ,{title:"Workflow",children:(0,j.jsxs)(Mf,{container:!0,mb:1,children:[(0,j.jsx)(AZ,{label:"ID",value:r,section:"workflow"}),n&&(0,j.jsx)(AZ,{label:"NAME",value:n,section:"workflow"})]})})]})},AZ=(0,n.memo)((function(e){let{label:t,value:r,section:i}=e;const[o,a]=(0,n.useState)(!1),s=(0,n.useRef)(null);(0,n.useEffect)((()=>{const e=s.current;e&&a(e.scrollWidth>e.offsetWidth)}),[s]);const[l,c]=(0,n.useState)(null),u=()=>{c(null)},d=Boolean(l),h=d?`pipeline-info-popover-${i}-${t}`:void 0;return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(Mf,{item:!0,xs:3,children:(0,j.jsx)(Hi,{fontWeight:"bold",fontSize:"0.95rem",color:"text.secondary",children:t})}),(0,j.jsx)(Mf,{item:!0,xs:9,children:(0,j.jsxs)("div",{children:[(0,j.jsx)(Hi,{ref:s,"aria-owns":h,"aria-haspopup":"true",onMouseEnter:e=>{c(e.currentTarget)},onMouseLeave:u,noWrap:!0,variant:"body2",overflow:"hidden",textOverflow:"ellipsis",children:r}),o&&(0,j.jsx)(Aa,{id:h,open:d,anchorEl:l,anchorOrigin:{vertical:"bottom",horizontal:"left"},onClose:u,sx:{pointerEvents:"none"},disableRestoreFocus:!0,children:(0,j.jsx)(Hi,{variant:"body2",padding:2,children:r})})]})})]})})),TZ=(0,n.createContext)({nodeId:"",filePath:"",dataType:"csv",itemId:NaN});var MZ=r(18938),CZ=r.n(MZ);function EZ(e){return(0,Yn.Ay)("MuiLinearProgress",e)}(0,Ln.A)("MuiLinearProgress",["root","colorPrimary","colorSecondary","determinate","indeterminate","buffer","query","dashed","dashedColorPrimary","dashedColorSecondary","bar","barColorPrimary","barColorSecondary","bar1Indeterminate","bar1Determinate","bar1Buffer","bar2Indeterminate","bar2Buffer"]);const IZ=["className","color","value","valueBuffer","variant"];let PZ,OZ,RZ,LZ,DZ,zZ,jZ=e=>e;const FZ=(0,Pn.i7)(PZ||(PZ=jZ` + 0% { + left: -35%; + right: 100%; + } + + 60% { + left: 100%; + right: -90%; + } + + 100% { + left: 100%; + right: -90%; + } +`)),NZ=(0,Pn.i7)(OZ||(OZ=jZ` + 0% { + left: -200%; + right: 100%; + } + + 60% { + left: 107%; + right: -8%; + } + + 100% { + left: 107%; + right: -8%; + } +`)),BZ=(0,Pn.i7)(RZ||(RZ=jZ` + 0% { + opacity: 1; + background-position: 0 -23px; + } + + 60% { + opacity: 0; + background-position: 0 -23px; + } + + 100% { + opacity: 1; + background-position: -200px -23px; + } +`)),VZ=(e,t)=>"inherit"===t?"currentColor":e.vars?e.vars.palette.LinearProgress[`${t}Bg`]:"light"===e.palette.mode?(0,gn.a)(e.palette[t].main,.62):(0,gn.e$)(e.palette[t].main,.5),UZ=(0,yn.Ay)("span",{name:"MuiLinearProgress",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,t[`color${(0,ei.A)(r.color)}`],t[r.variant]]}})((e=>{let{ownerState:t,theme:r}=e;return(0,O.A)({position:"relative",overflow:"hidden",display:"block",height:4,zIndex:0,"@media print":{colorAdjust:"exact"},backgroundColor:VZ(r,t.color)},"inherit"===t.color&&"buffer"!==t.variant&&{backgroundColor:"none","&::before":{content:'""',position:"absolute",left:0,top:0,right:0,bottom:0,backgroundColor:"currentColor",opacity:.3}},"buffer"===t.variant&&{backgroundColor:"transparent"},"query"===t.variant&&{transform:"rotate(180deg)"})})),HZ=(0,yn.Ay)("span",{name:"MuiLinearProgress",slot:"Dashed",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.dashed,t[`dashedColor${(0,ei.A)(r.color)}`]]}})((e=>{let{ownerState:t,theme:r}=e;const n=VZ(r,t.color);return(0,O.A)({position:"absolute",marginTop:0,height:"100%",width:"100%"},"inherit"===t.color&&{opacity:.3},{backgroundImage:`radial-gradient(${n} 0%, ${n} 16%, transparent 42%)`,backgroundSize:"10px 10px",backgroundPosition:"0 -23px"})}),(0,Pn.AH)(LZ||(LZ=jZ` + animation: ${0} 3s infinite linear; + `),BZ)),$Z=(0,yn.Ay)("span",{name:"MuiLinearProgress",slot:"Bar1",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.bar,t[`barColor${(0,ei.A)(r.color)}`],("indeterminate"===r.variant||"query"===r.variant)&&t.bar1Indeterminate,"determinate"===r.variant&&t.bar1Determinate,"buffer"===r.variant&&t.bar1Buffer]}})((e=>{let{ownerState:t,theme:r}=e;return(0,O.A)({width:"100%",position:"absolute",left:0,bottom:0,top:0,transition:"transform 0.2s linear",transformOrigin:"left",backgroundColor:"inherit"===t.color?"currentColor":(r.vars||r).palette[t.color].main},"determinate"===t.variant&&{transition:"transform .4s linear"},"buffer"===t.variant&&{zIndex:1,transition:"transform .4s linear"})}),(e=>{let{ownerState:t}=e;return("indeterminate"===t.variant||"query"===t.variant)&&(0,Pn.AH)(DZ||(DZ=jZ` + width: auto; + animation: ${0} 2.1s cubic-bezier(0.65, 0.815, 0.735, 0.395) infinite; + `),FZ)})),WZ=(0,yn.Ay)("span",{name:"MuiLinearProgress",slot:"Bar2",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.bar,t[`barColor${(0,ei.A)(r.color)}`],("indeterminate"===r.variant||"query"===r.variant)&&t.bar2Indeterminate,"buffer"===r.variant&&t.bar2Buffer]}})((e=>{let{ownerState:t,theme:r}=e;return(0,O.A)({width:"100%",position:"absolute",left:0,bottom:0,top:0,transition:"transform 0.2s linear",transformOrigin:"left"},"buffer"!==t.variant&&{backgroundColor:"inherit"===t.color?"currentColor":(r.vars||r).palette[t.color].main},"inherit"===t.color&&{opacity:.3},"buffer"===t.variant&&{backgroundColor:VZ(r,t.color),transition:"transform .4s linear"})}),(e=>{let{ownerState:t}=e;return("indeterminate"===t.variant||"query"===t.variant)&&(0,Pn.AH)(zZ||(zZ=jZ` + width: auto; + animation: ${0} 2.1s cubic-bezier(0.165, 0.84, 0.44, 1) 1.15s infinite; + `),NZ)})),qZ=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiLinearProgress"}),{className:n,color:i="primary",value:o,valueBuffer:a,variant:s="indeterminate"}=r,l=(0,R.A)(r,IZ),c=(0,O.A)({},r,{color:i,variant:s}),u=(e=>{const{classes:t,variant:r,color:n}=e,i={root:["root",`color${(0,ei.A)(n)}`,r],dashed:["dashed",`dashedColor${(0,ei.A)(n)}`],bar1:["bar",`barColor${(0,ei.A)(n)}`,("indeterminate"===r||"query"===r)&&"bar1Indeterminate","determinate"===r&&"bar1Determinate","buffer"===r&&"bar1Buffer"],bar2:["bar","buffer"!==r&&`barColor${(0,ei.A)(n)}`,"buffer"===r&&`color${(0,ei.A)(n)}`,("indeterminate"===r||"query"===r)&&"bar2Indeterminate","buffer"===r&&"bar2Buffer"]};return(0,mn.A)(i,EZ,t)})(c),d=H(),h={},p={bar1:{},bar2:{}};if("determinate"===s||"buffer"===s)if(void 0!==o){h["aria-valuenow"]=Math.round(o),h["aria-valuemin"]=0,h["aria-valuemax"]=100;let e=o-100;d&&(e=-e),p.bar1.transform=`translateX(${e}%)`}else 0;if("buffer"===s)if(void 0!==a){let e=(a||0)-100;d&&(e=-e),p.bar2.transform=`translateX(${e}%)`}else 0;return(0,j.jsxs)(UZ,(0,O.A)({className:(0,fn.A)(u.root,n),ownerState:c,role:"progressbar"},h,{ref:t},l,{children:["buffer"===s?(0,j.jsx)(HZ,{className:u.dashed,ownerState:c}):null,(0,j.jsx)($Z,{className:u.bar1,ownerState:c,style:p.bar1}),"determinate"===s?null:(0,j.jsx)(WZ,{className:u.bar2,ownerState:c,style:p.bar2})]}))})),GZ=(0,n.memo)((function(){const{filePath:e}=(0,n.useContext)(TZ),t=C(),r=x((i=e,e=>BS(i)(e)&&kS(e).bar[i].pending));var i;const o=x(BS(e)),a=x((e=>t=>BS(e)(t)?kS(t).bar[e].error:null)(e)),s=x((e=>t=>BS(e)(t)&&kS(t).bar[e].fulfilled)(e));return(0,n.useEffect)((()=>{o||t(yS({path:e}))}),[t,o,e]),r?(0,j.jsx)(qZ,{}):null!=a?(0,j.jsx)(Hi,{color:"error",children:a}):s?(0,j.jsx)(YZ,{}):null})),YZ=(0,n.memo)((function(){const{filePath:e,itemId:t}=(0,n.useContext)(TZ),r=x((i=e,e=>{var t,r;return null!==(t=null===(r=kS(e).bar[i])||void 0===r?void 0:r.data)&&void 0!==t?t:[]}),ZZ);var i;const o=x((e=>t=>{var r;return null===(r=kS(t).bar[e])||void 0===r?void 0:r.meta})(e)),a=x(uA(t)),s=x(dA(t)),l=x(qA(t)),c=x((e=>t=>{var r,n;return null!==(r=null===(n=kS(t).bar[e])||void 0===n?void 0:n.index)&&void 0!==r?r:[]})(e)),u=(0,n.useMemo)((()=>[{x:Object.keys(r[l]),y:Object.values(r[l]),type:"bar"}]),[r,l]),d=(0,n.useMemo)((()=>({title:{text:null===o||void 0===o?void 0:o.title,x:.1},width:a,height:s-120,margin:{t:50,l:50,b:40},dragmode:"pan",autosize:!0,xaxis:{title:null===o||void 0===o?void 0:o.xlabel},yaxis:{title:null===o||void 0===o?void 0:o.ylabel}})),[o,a,s]),h=x(mA(t)),p={displayModeBar:!0,responsive:!0,toImageButtonOptions:{format:x(gA(t)),filename:h}};return(0,j.jsxs)("div",{children:[(0,j.jsx)(yi,{sx:{display:"flex"},children:(0,j.jsx)(yi,{sx:{flexGrow:1,ml:1},children:(0,j.jsx)(XZ,{dataKeys:c})})}),(0,j.jsx)(CZ(),{data:u,layout:d,config:p})]})})),XZ=(0,n.memo)((function(e){let{dataKeys:t}=e;const{itemId:r}=(0,n.useContext)(TZ),i=C(),o=x(qA(r));return(0,j.jsxs)(oH,{variant:"standard",sx:{m:1,minWidth:120},children:[(0,j.jsx)(tH,{children:"index"}),(0,j.jsx)(GN,{label:"smooth",value:`${o}`,onChange:e=>{i(bM({itemId:r,index:e.target.value}))},children:t.map(((e,t)=>(0,j.jsx)(qa,{value:t,children:e},t)))})]})}));function ZZ(e,t){if(null!=e&&null!=t){const r=Object.keys(e),n=Object.keys(t);return e===t||r.length===n.length&&r.every(((e,t)=>n[t]===e))}return void 0===e&&void 0===t}const KZ=(0,n.memo)((function(){const{filePath:e}=(0,n.useContext)(TZ),t=x(jf),r=x(OS(e)),i=x(LS(e)),o=x(DS(e)),a=x(RS(e)),s=C();return(0,n.useEffect)((()=>{t&&!r&&s(lS({path:e,workspaceId:t}))}),[s,r,e,t]),i?(0,j.jsx)(qZ,{}):null!=a?(0,j.jsx)(Hi,{color:"error",children:a}):o?(0,j.jsx)(JZ,{}):null})),JZ=(0,n.memo)((function(){const{itemId:e,filePath:t}=(0,n.useContext)(TZ),r=x(HA(e)),i=x($A(e)),o=x(WA(e));return(0,j.jsx)(QZ,{path:t,transpose:r,setHeader:i,setIndex:o})})),QZ=(0,n.memo)((function(e){let{path:t,transpose:r,setIndex:i,setHeader:o}=e;const a=x((s=t,e=>kS(e).csv[s].data),((e,t)=>null!=e&&null!=t?xY(e,t):void 0===e&&void 0===t));var s;const l=(0,n.useMemo)((()=>r?a[0].map(((e,t)=>a.map((e=>e[t])))):a),[a,r]),c=(0,n.useMemo)((()=>{const e=()=>null===o?l[0]:o>=l.length?l[l.length-1]:l[o];return i?[{field:"col0",headerName:"index",width:150},...e().map(((e,t)=>({field:`col${t+1}`,headerName:`${null===o?t:e}`,width:150})))]:e().map(((e,t)=>({field:`col${t+1}`,headerName:`${null===o?t:e}`,width:150})))}),[l,o,i]),u=l.map(((e,t)=>{const r=Object.fromEntries([t,...e].map(((e,t)=>[`col${t}`,e])));return r.id=t,r})).filter(((e,t)=>null===o||null!==o&&t>o));return(0,j.jsx)("div",{style:{height:300,width:"100%"},children:(0,j.jsx)(F$,{rows:u,columns:c})})})),eK=(0,n.memo)((function(){const{filePath:e}=(0,n.useContext)(TZ),t=C(),r=x((i=e,e=>CS(i)(e)&&kS(e).heatMap[i].pending));var i;const o=x(CS(e)),a=x((e=>t=>CS(e)(t)?kS(t).heatMap[e].error:null)(e)),s=x((e=>t=>CS(e)(t)&&kS(t).heatMap[e].fulfilled)(e));return(0,n.useEffect)((()=>{o||t(aS({path:e}))}),[t,o,e]),r?(0,j.jsx)(qZ,{}):null!=a?(0,j.jsx)(Hi,{color:"error",children:a}):s?(0,j.jsx)(tK,{}):null})),tK=(0,n.memo)((function(){const{filePath:e,itemId:t}=(0,n.useContext)(TZ),r=x((i=e,e=>kS(e).heatMap[i].data),rK);var i;const o=x((e=>t=>kS(t).heatMap[e].meta)(e)),a=x((e=>t=>kS(t).heatMap[e].columns)(e)),s=x((e=>t=>kS(t).heatMap[e].index)(e)),l=x(VA(t)),c=x(UA(t)),u=x(uA(t)),d=x(dA(t)),h=(0,n.useMemo)((()=>null!=r?[{z:r,x:a,y:s,type:"heatmap",name:"heatmap",colorscale:c.map((e=>{let t=parseFloat(e.offset);const r=c.map((e=>parseFloat(e.offset)));return t===Math.max(...r)&&(t=1),t===Math.min(...r)&&(t=0),[t,e.rgb]})),hoverongaps:!1,showlegend:!0,showscale:l}]:[]),[r,l,c,a,s]),p=(0,n.useMemo)((()=>({title:{text:null===o||void 0===o?void 0:o.title,x:.1},width:u,height:d-50,dragmode:"pan",margin:{t:50,l:50,b:40},autosize:!0,xaxis:{title:null===o||void 0===o?void 0:o.xlabel},yaxis:{title:null===o||void 0===o?void 0:o.ylabel}})),[o,u,d]),f=x(mA(t)),m={displayModeBar:!0,responsive:!0,toImageButtonOptions:{format:x(gA(t)),filename:f}};return(0,j.jsx)(CZ(),{data:h,layout:p,config:m})}));function rK(e,t){return null!=e&&null!=t?xY(e,t):void 0===e&&void 0===t}const nK=(0,n.memo)((function(){const{filePath:e}=(0,n.useContext)(TZ),t=C(),r=x((i=e,e=>US(i)(e)&&kS(e).histogram[i].pending));var i;const o=x(US(e)),a=x((e=>t=>US(e)(t)?kS(t).histogram[e].error:null)(e)),s=x((e=>t=>US(e)(t)&&kS(t).histogram[e].fulfilled)(e));return(0,n.useEffect)((()=>{o||t(xS({path:e}))}),[t,o,e]),r?(0,j.jsx)(qZ,{}):null!=a?(0,j.jsx)(Hi,{color:"error",children:a}):s?(0,j.jsx)(iK,{}):null})),iK=(0,n.memo)((function(){const{filePath:e,itemId:t}=(0,n.useContext)(TZ),r=x((i=e,e=>kS(e).histogram[i].data));var i;const o=x((e=>t=>kS(t).histogram[e].meta)(e)),a=x(uA(t)),s=x(dA(t)),l=x(ZA(t)),c=(0,n.useMemo)((()=>null!=r?[{x:r[0],type:"histogram",autobinx:!1,xbins:{size:(Math.max(...r[0])-Math.min(...r[0]))/(l-1)}}]:[]),[r,l]),u=(0,n.useMemo)((()=>({title:{text:null===o||void 0===o?void 0:o.title,x:.1},width:a,height:s-120,dragmode:"pan",margin:{t:50,l:50,b:40},autosize:!0,xaxis:{title:null===o||void 0===o?void 0:o.xlabel},yaxis:{title:null===o||void 0===o?void 0:o.ylabel}})),[o,a,s]);return(0,j.jsxs)("div",{children:[(0,j.jsx)(yi,{sx:{display:"flex"},children:(0,j.jsx)(yi,{sx:{flexGrow:1,ml:1},children:(0,j.jsx)(oK,{})})}),(0,j.jsx)(CZ(),{data:c,layout:u})]})})),oK=(0,n.memo)((function(){const{itemId:e}=(0,n.useContext)(TZ),t=C(),r=x(ZA(e));return(0,j.jsxs)(oH,{variant:"standard",sx:{m:1,minWidth:120},children:[(0,j.jsx)(tH,{children:"bins"}),(0,j.jsx)(eI,{type:"number",value:r,onChange:r=>{t(_M({itemId:e,bins:parseInt(r.target.value)}))}})]})})),aK=(0,n.memo)((function(){const{filePath:e}=(0,n.useContext)(TZ),t=C(),r=x((i=e,e=>VS(i)(e)&&kS(e).html[i].pending));var i;const o=x(VS(e)),a=x((e=>t=>VS(e)(t)?kS(t).html[e].error:null)(e)),s=x((e=>t=>VS(e)(t)&&kS(t).html[e].fulfilled)(e));return(0,n.useEffect)((()=>{o||t(vS({path:e}))}),[t,o,e]),r?(0,j.jsx)(qZ,{}):null!=a?(0,j.jsx)(Hi,{color:"error",children:a}):s?(0,j.jsx)(sK,{}):null})),sK=(0,n.memo)((function(){const{filePath:e}=(0,n.useContext)(TZ),t=x((r=e,e=>{var t,n;return null!==(t=null===(n=kS(e).html[r])||void 0===n?void 0:n.data)&&void 0!==t?t:""}));var r;return(0,j.jsx)("div",{dangerouslySetInnerHTML:{__html:t},style:{overflow:"scroll",display:"flex",height:"90%"}})}));var lK=r(20355),cK=r.n(lK),uK=r(49640);const dK={border:0,clip:"rect(0 0 0 0)",height:"1px",margin:"-1px",overflow:"hidden",padding:0,position:"absolute",whiteSpace:"nowrap",width:"1px"};const hK=function(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:(e,t)=>e===t;return e.length===t.length&&e.every(((e,n)=>r(e,t[n])))};function pK(e,t){return e-t}function fK(e,t){var r;const{index:n}=null!=(r=e.reduce(((e,r,n)=>{const i=Math.abs(t-r);return null===e||i({left:`${e}%`}),leap:e=>({width:`${e}%`})},"horizontal-reverse":{offset:e=>({right:`${e}%`}),leap:e=>({width:`${e}%`})},vertical:{offset:e=>({bottom:`${e}%`}),leap:e=>({height:`${e}%`})}},wK=e=>e;let kK;function SK(){return void 0===kK&&(kK="undefined"===typeof CSS||"function"!==typeof CSS.supports||CSS.supports("touch-action","none")),kK}const AK=e=>!e||!Yi(e);function TK(e){return(0,Yn.Ay)("MuiSlider",e)}const MK=(0,Ln.A)("MuiSlider",["root","active","colorPrimary","colorSecondary","colorError","colorInfo","colorSuccess","colorWarning","disabled","dragging","focusVisible","mark","markActive","marked","markLabel","markLabelActive","rail","sizeSmall","thumb","thumbColorPrimary","thumbColorSecondary","thumbColorError","thumbColorSuccess","thumbColorInfo","thumbColorWarning","track","trackInverted","trackFalse","thumbSizeSmall","valueLabel","valueLabelOpen","valueLabelCircle","valueLabelLabel","vertical"]);const CK=["aria-label","aria-valuetext","aria-labelledby","component","components","componentsProps","color","classes","className","disableSwap","disabled","getAriaLabel","getAriaValueText","marks","max","min","name","onChange","onChangeCommitted","orientation","shiftStep","size","step","scale","slotProps","slots","tabIndex","track","value","valueLabelDisplay","valueLabelFormat"];function EK(e){return e}const IK=(0,yn.Ay)("span",{name:"MuiSlider",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.root,t[`color${(0,ei.A)(r.color)}`],"medium"!==r.size&&t[`size${(0,ei.A)(r.size)}`],r.marked&&t.marked,"vertical"===r.orientation&&t.vertical,"inverted"===r.track&&t.trackInverted,!1===r.track&&t.trackFalse]}})((e=>{let{theme:t}=e;var r;return{borderRadius:12,boxSizing:"content-box",display:"inline-block",position:"relative",cursor:"pointer",touchAction:"none",WebkitTapHighlightColor:"transparent","@media print":{colorAdjust:"exact"},[`&.${MK.disabled}`]:{pointerEvents:"none",cursor:"default",color:(t.vars||t).palette.grey[400]},[`&.${MK.dragging}`]:{[`& .${MK.thumb}, & .${MK.track}`]:{transition:"none"}},variants:[...Object.keys((null!=(r=t.vars)?r:t).palette).filter((e=>{var r;return(null!=(r=t.vars)?r:t).palette[e].main})).map((e=>({props:{color:e},style:{color:(t.vars||t).palette[e].main}}))),{props:{orientation:"horizontal"},style:{height:4,width:"100%",padding:"13px 0","@media (pointer: coarse)":{padding:"20px 0"}}},{props:{orientation:"horizontal",size:"small"},style:{height:2}},{props:{orientation:"horizontal",marked:!0},style:{marginBottom:20}},{props:{orientation:"vertical"},style:{height:"100%",width:4,padding:"0 13px","@media (pointer: coarse)":{padding:"0 20px"}}},{props:{orientation:"vertical",size:"small"},style:{width:2}},{props:{orientation:"vertical",marked:!0},style:{marginRight:44}}]}})),PK=(0,yn.Ay)("span",{name:"MuiSlider",slot:"Rail",overridesResolver:(e,t)=>t.rail})({display:"block",position:"absolute",borderRadius:"inherit",backgroundColor:"currentColor",opacity:.38,variants:[{props:{orientation:"horizontal"},style:{width:"100%",height:"inherit",top:"50%",transform:"translateY(-50%)"}},{props:{orientation:"vertical"},style:{height:"100%",width:"inherit",left:"50%",transform:"translateX(-50%)"}},{props:{track:"inverted"},style:{opacity:1}}]}),OK=(0,yn.Ay)("span",{name:"MuiSlider",slot:"Track",overridesResolver:(e,t)=>t.track})((e=>{let{theme:t}=e;var r;return{display:"block",position:"absolute",borderRadius:"inherit",border:"1px solid currentColor",backgroundColor:"currentColor",transition:t.transitions.create(["left","width","bottom","height"],{duration:t.transitions.duration.shortest}),variants:[{props:{size:"small"},style:{border:"none"}},{props:{orientation:"horizontal"},style:{height:"inherit",top:"50%",transform:"translateY(-50%)"}},{props:{orientation:"vertical"},style:{width:"inherit",left:"50%",transform:"translateX(-50%)"}},{props:{track:!1},style:{display:"none"}},...Object.keys((null!=(r=t.vars)?r:t).palette).filter((e=>{var r;return(null!=(r=t.vars)?r:t).palette[e].main})).map((e=>({props:{color:e,track:"inverted"},style:(0,O.A)({},t.vars?{backgroundColor:t.vars.palette.Slider[`${e}Track`],borderColor:t.vars.palette.Slider[`${e}Track`]}:(0,O.A)({backgroundColor:(0,gn.a)(t.palette[e].main,.62),borderColor:(0,gn.a)(t.palette[e].main,.62)},t.applyStyles("dark",{backgroundColor:(0,gn.e$)(t.palette[e].main,.5)}),t.applyStyles("dark",{borderColor:(0,gn.e$)(t.palette[e].main,.5)})))})))]}})),RK=(0,yn.Ay)("span",{name:"MuiSlider",slot:"Thumb",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[t.thumb,t[`thumbColor${(0,ei.A)(r.color)}`],"medium"!==r.size&&t[`thumbSize${(0,ei.A)(r.size)}`]]}})((e=>{let{theme:t}=e;var r;return{position:"absolute",width:20,height:20,boxSizing:"border-box",borderRadius:"50%",outline:0,backgroundColor:"currentColor",display:"flex",alignItems:"center",justifyContent:"center",transition:t.transitions.create(["box-shadow","left","bottom"],{duration:t.transitions.duration.shortest}),"&::before":{position:"absolute",content:'""',borderRadius:"inherit",width:"100%",height:"100%",boxShadow:(t.vars||t).shadows[2]},"&::after":{position:"absolute",content:'""',borderRadius:"50%",width:42,height:42,top:"50%",left:"50%",transform:"translate(-50%, -50%)"},[`&.${MK.disabled}`]:{"&:hover":{boxShadow:"none"}},variants:[{props:{size:"small"},style:{width:12,height:12,"&::before":{boxShadow:"none"}}},{props:{orientation:"horizontal"},style:{top:"50%",transform:"translate(-50%, -50%)"}},{props:{orientation:"vertical"},style:{left:"50%",transform:"translate(-50%, 50%)"}},...Object.keys((null!=(r=t.vars)?r:t).palette).filter((e=>{var r;return(null!=(r=t.vars)?r:t).palette[e].main})).map((e=>({props:{color:e},style:{[`&:hover, &.${MK.focusVisible}`]:(0,O.A)({},t.vars?{boxShadow:`0px 0px 0px 8px rgba(${t.vars.palette[e].mainChannel} / 0.16)`}:{boxShadow:`0px 0px 0px 8px ${(0,gn.X4)(t.palette[e].main,.16)}`},{"@media (hover: none)":{boxShadow:"none"}}),[`&.${MK.active}`]:(0,O.A)({},t.vars?{boxShadow:`0px 0px 0px 14px rgba(${t.vars.palette[e].mainChannel} / 0.16)`}:{boxShadow:`0px 0px 0px 14px ${(0,gn.X4)(t.palette[e].main,.16)}`})}})))]}})),LK=(0,yn.Ay)((function(e){const{children:t,className:r,value:i}=e,o=(e=>{const{open:t}=e;return{offset:(0,fn.A)(t&&MK.valueLabelOpen),circle:MK.valueLabelCircle,label:MK.valueLabelLabel}})(e);return t?n.cloneElement(t,{className:(0,fn.A)(t.props.className)},(0,j.jsxs)(n.Fragment,{children:[t.props.children,(0,j.jsx)("span",{className:(0,fn.A)(o.offset,r),"aria-hidden":!0,children:(0,j.jsx)("span",{className:o.circle,children:(0,j.jsx)("span",{className:o.label,children:i})})})]})):null}),{name:"MuiSlider",slot:"ValueLabel",overridesResolver:(e,t)=>t.valueLabel})((e=>{let{theme:t}=e;return(0,O.A)({zIndex:1,whiteSpace:"nowrap"},t.typography.body2,{fontWeight:500,transition:t.transitions.create(["transform"],{duration:t.transitions.duration.shortest}),position:"absolute",backgroundColor:(t.vars||t).palette.grey[600],borderRadius:2,color:(t.vars||t).palette.common.white,display:"flex",alignItems:"center",justifyContent:"center",padding:"0.25rem 0.75rem",variants:[{props:{orientation:"horizontal"},style:{transform:"translateY(-100%) scale(0)",top:"-10px",transformOrigin:"bottom center","&::before":{position:"absolute",content:'""',width:8,height:8,transform:"translate(-50%, 50%) rotate(45deg)",backgroundColor:"inherit",bottom:0,left:"50%"},[`&.${MK.valueLabelOpen}`]:{transform:"translateY(-100%) scale(1)"}}},{props:{orientation:"vertical"},style:{transform:"translateY(-50%) scale(0)",right:"30px",top:"50%",transformOrigin:"right center","&::before":{position:"absolute",content:'""',width:8,height:8,transform:"translate(-50%, -50%) rotate(45deg)",backgroundColor:"inherit",right:-8,top:"50%"},[`&.${MK.valueLabelOpen}`]:{transform:"translateY(-50%) scale(1)"}}},{props:{size:"small"},style:{fontSize:t.typography.pxToRem(12),padding:"0.25rem 0.5rem"}},{props:{orientation:"vertical",size:"small"},style:{right:"20px"}}]})})),DK=(0,yn.Ay)("span",{name:"MuiSlider",slot:"Mark",shouldForwardProp:e=>(0,fN.A)(e)&&"markActive"!==e,overridesResolver:(e,t)=>{const{markActive:r}=e;return[t.mark,r&&t.markActive]}})((e=>{let{theme:t}=e;return{position:"absolute",width:2,height:2,borderRadius:1,backgroundColor:"currentColor",variants:[{props:{orientation:"horizontal"},style:{top:"50%",transform:"translate(-1px, -50%)"}},{props:{orientation:"vertical"},style:{left:"50%",transform:"translate(-50%, 1px)"}},{props:{markActive:!0},style:{backgroundColor:(t.vars||t).palette.background.paper,opacity:.8}}]}})),zK=(0,yn.Ay)("span",{name:"MuiSlider",slot:"MarkLabel",shouldForwardProp:e=>(0,fN.A)(e)&&"markLabelActive"!==e,overridesResolver:(e,t)=>t.markLabel})((e=>{let{theme:t}=e;return(0,O.A)({},t.typography.body2,{color:(t.vars||t).palette.text.secondary,position:"absolute",whiteSpace:"nowrap",variants:[{props:{orientation:"horizontal"},style:{top:30,transform:"translateX(-50%)","@media (pointer: coarse)":{top:40}}},{props:{orientation:"vertical"},style:{left:36,transform:"translateY(50%)","@media (pointer: coarse)":{left:44}}},{props:{markLabelActive:!0},style:{color:(t.vars||t).palette.text.primary}}]})})),jK=e=>{let{children:t}=e;return t},FK=n.forwardRef((function(e,t){var r,i,o,a,s,l,c,u,d,h,p,f,m,g,y,v,x,b,_,w,k,S,A,T;const M=(0,vn.b)({props:e,name:"MuiSlider"}),C=H(),{"aria-label":E,"aria-valuetext":I,"aria-labelledby":P,component:L="span",components:D={},componentsProps:z={},color:F="primary",classes:N,className:B,disableSwap:V=!1,disabled:U=!1,getAriaLabel:$,getAriaValueText:W,marks:q=!1,max:G=100,min:Y=0,orientation:X="horizontal",shiftStep:Z=10,size:K="medium",step:J=1,scale:Q=EK,slotProps:ee,slots:te,track:re="normal",valueLabelDisplay:ne="off",valueLabelFormat:ie=EK}=M,oe=(0,R.A)(M,CK),ae=(0,O.A)({},M,{isRtl:C,max:G,min:Y,classes:N,disabled:U,disableSwap:V,orientation:X,marks:q,color:F,size:K,step:J,shiftStep:Z,scale:Q,track:re,valueLabelDisplay:ne,valueLabelFormat:ie}),{axisProps:se,getRootProps:le,getHiddenInputProps:ce,getThumbProps:ue,open:de,active:he,axis:pe,focusedThumbIndex:fe,range:me,dragging:ge,marks:ye,values:ve,trackOffset:xe,trackLeap:be,getThumbStyle:_e}=function(e){const{"aria-labelledby":t,defaultValue:r,disabled:i=!1,disableSwap:o=!1,isRtl:a=!1,marks:s=!1,max:l=100,min:c=0,name:u,onChange:d,onChangeCommitted:h,orientation:p="horizontal",rootRef:f,scale:m=wK,step:g=1,shiftStep:y=10,tabIndex:v,value:x}=e,b=n.useRef(),[_,w]=n.useState(-1),[k,S]=n.useState(-1),[A,T]=n.useState(!1),M=n.useRef(0),[C,E]=(0,tL.A)({controlled:x,default:null!=r?r:c,name:"Slider"}),I=d&&((e,t,r)=>{const n=e.nativeEvent||e,i=new n.constructor(n.type,n);Object.defineProperty(i,"target",{writable:!0,value:{value:t,name:u}}),d(i,t,r)}),P=Array.isArray(C);let R=P?C.slice().sort(pK):[C];R=R.map((e=>null==e?c:(0,CI.A)(e,c,l)));const L=!0===s&&null!==g?[...Array(Math.floor((l-c)/g)+1)].map(((e,t)=>({value:c+g*t}))):s||[],D=L.map((e=>e.value)),{isFocusVisibleRef:z,onBlur:j,onFocus:F,ref:N}=(0,uK.A)(),[B,V]=n.useState(-1),U=n.useRef(),H=(0,Gi.A)(N,U),$=(0,Gi.A)(f,H),W=e=>t=>{var r;const n=Number(t.currentTarget.getAttribute("data-index"));F(t),!0===z.current&&V(n),S(n),null==e||null==(r=e.onFocus)||r.call(e,t)},q=e=>t=>{var r;j(t),!1===z.current&&V(-1),S(-1),null==e||null==(r=e.onBlur)||r.call(e,t)},G=(e,t)=>{const r=Number(e.currentTarget.getAttribute("data-index")),n=R[r],i=D.indexOf(n);let a=t;if(L&&null==g){const e=D[D.length-1];a=a>e?e:at=>{var r;if(null!==g){const e=Number(t.currentTarget.getAttribute("data-index")),r=R[e];let n=null;("ArrowLeft"===t.key||"ArrowDown"===t.key)&&t.shiftKey||"PageDown"===t.key?n=Math.max(r-y,c):(("ArrowRight"===t.key||"ArrowUp"===t.key)&&t.shiftKey||"PageUp"===t.key)&&(n=Math.min(r+y,l)),null!==n&&(G(t,n),t.preventDefault())}null==e||null==(r=e.onKeyDown)||r.call(e,t)};(0,$o.A)((()=>{var e;i&&U.current.contains(document.activeElement)&&(null==(e=document.activeElement)||e.blur())}),[i]),i&&-1!==_&&w(-1),i&&-1!==B&&V(-1);const X=n.useRef();let Z=p;a&&"horizontal"===p&&(Z+="-reverse");const K=e=>{let{finger:t,move:r=!1}=e;const{current:n}=U,{width:i,height:a,bottom:s,left:u}=n.getBoundingClientRect();let d,h;if(d=0===Z.indexOf("vertical")?(s-t.y)/a:(t.x-u)/i,-1!==Z.indexOf("-reverse")&&(d=1-d),h=function(e,t,r){return(r-t)*e+t}(d,c,l),g)h=yK(h,g,c);else{const e=fK(D,h);h=D[e]}h=(0,CI.A)(h,c,l);let p=0;if(P){p=r?X.current:fK(R,h),o&&(h=(0,CI.A)(h,R[p-1]||-1/0,R[p+1]||1/0));const e=h;h=vK({values:R,newValue:h,index:p}),o&&r||(p=h.indexOf(e),X.current=p)}return{newValue:h,activeIndex:p}},J=(0,ea.A)((e=>{const t=mK(e,b);if(!t)return;if(M.current+=1,"mousemove"===e.type&&0===e.buttons)return void Q(e);const{newValue:r,activeIndex:n}=K({finger:t,move:!0});xK({sliderRef:U,activeIndex:n,setActive:w}),E(r),!A&&M.current>2&&T(!0),I&&!bK(r,C)&&I(e,r,n)})),Q=(0,ea.A)((e=>{const t=mK(e,b);if(T(!1),!t)return;const{newValue:r}=K({finger:t,move:!0});w(-1),"touchend"===e.type&&S(-1),h&&h(e,r),b.current=void 0,te()})),ee=(0,ea.A)((e=>{if(i)return;SK()||e.preventDefault();const t=e.changedTouches[0];null!=t&&(b.current=t.identifier);const r=mK(e,b);if(!1!==r){const{newValue:t,activeIndex:n}=K({finger:r});xK({sliderRef:U,activeIndex:n,setActive:w}),E(t),I&&!bK(t,C)&&I(e,t,n)}M.current=0;const n=(0,No.A)(U.current);n.addEventListener("touchmove",J,{passive:!0}),n.addEventListener("touchend",Q,{passive:!0})})),te=n.useCallback((()=>{const e=(0,No.A)(U.current);e.removeEventListener("mousemove",J),e.removeEventListener("mouseup",Q),e.removeEventListener("touchmove",J),e.removeEventListener("touchend",Q)}),[Q,J]);n.useEffect((()=>{const{current:e}=U;return e.addEventListener("touchstart",ee,{passive:SK()}),()=>{e.removeEventListener("touchstart",ee),te()}}),[te,ee]),n.useEffect((()=>{i&&te()}),[i,te]);const re=gK(P?R[0]:c,c,l),ne=gK(R[R.length-1],c,l)-re,ie=e=>t=>{var r;null==(r=e.onMouseLeave)||r.call(e,t),S(-1)};return{active:_,axis:Z,axisProps:_K,dragging:A,focusedThumbIndex:B,getHiddenInputProps:function(){let r=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};var n;const o=Zi(r),s={onChange:(d=o||{},e=>{var t;null==(t=d.onChange)||t.call(d,e),G(e,e.target.valueAsNumber)}),onFocus:W(o||{}),onBlur:q(o||{}),onKeyDown:Y(o||{})};var d;const h=(0,O.A)({},o,s);return(0,O.A)({tabIndex:v,"aria-labelledby":t,"aria-orientation":p,"aria-valuemax":m(l),"aria-valuemin":m(c),name:u,type:"range",min:e.min,max:e.max,step:null===e.step&&e.marks?"any":null!=(n=e.step)?n:void 0,disabled:i},r,h,{style:(0,O.A)({},dK,{direction:a?"rtl":"ltr",width:"100%",height:"100%"})})},getRootProps:function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const t=Zi(e),r={onMouseDown:(n=t||{},e=>{var t;if(null==(t=n.onMouseDown)||t.call(n,e),i)return;if(e.defaultPrevented)return;if(0!==e.button)return;e.preventDefault();const r=mK(e,b);if(!1!==r){const{newValue:t,activeIndex:n}=K({finger:r});xK({sliderRef:U,activeIndex:n,setActive:w}),E(t),I&&!bK(t,C)&&I(e,t,n)}M.current=0;const o=(0,No.A)(U.current);o.addEventListener("mousemove",J,{passive:!0}),o.addEventListener("mouseup",Q)})};var n;const o=(0,O.A)({},t,r);return(0,O.A)({},e,{ref:$},o)},getThumbProps:function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const t=Zi(e),r={onMouseOver:(n=t||{},e=>{var t;null==(t=n.onMouseOver)||t.call(n,e);const r=Number(e.currentTarget.getAttribute("data-index"));S(r)}),onMouseLeave:ie(t||{})};var n;return(0,O.A)({},e,t,r)},marks:L,open:k,range:P,rootRef:$,trackLeap:ne,trackOffset:re,values:R,getThumbStyle:e=>({pointerEvents:-1!==_&&_!==e?"none":void 0})}}((0,O.A)({},ae,{rootRef:t}));ae.marked=ye.length>0&&ye.some((e=>e.label)),ae.dragging=ge,ae.focusedThumbIndex=fe;const we=(e=>{const{disabled:t,dragging:r,marked:n,orientation:i,track:o,classes:a,color:s,size:l}=e,c={root:["root",t&&"disabled",r&&"dragging",n&&"marked","vertical"===i&&"vertical","inverted"===o&&"trackInverted",!1===o&&"trackFalse",s&&`color${(0,ei.A)(s)}`,l&&`size${(0,ei.A)(l)}`],rail:["rail"],track:["track"],mark:["mark"],markActive:["markActive"],markLabel:["markLabel"],markLabelActive:["markLabelActive"],valueLabel:["valueLabel"],thumb:["thumb",t&&"disabled",l&&`thumbSize${(0,ei.A)(l)}`,s&&`thumbColor${(0,ei.A)(s)}`],active:["active"],disabled:["disabled"],focusVisible:["focusVisible"]};return(0,mn.A)(c,TK,a)})(ae),ke=null!=(r=null!=(i=null==te?void 0:te.root)?i:D.Root)?r:IK,Se=null!=(o=null!=(a=null==te?void 0:te.rail)?a:D.Rail)?o:PK,Ae=null!=(s=null!=(l=null==te?void 0:te.track)?l:D.Track)?s:OK,Te=null!=(c=null!=(u=null==te?void 0:te.thumb)?u:D.Thumb)?c:RK,Me=null!=(d=null!=(h=null==te?void 0:te.valueLabel)?h:D.ValueLabel)?d:LK,Ce=null!=(p=null!=(f=null==te?void 0:te.mark)?f:D.Mark)?p:DK,Ee=null!=(m=null!=(g=null==te?void 0:te.markLabel)?g:D.MarkLabel)?m:zK,Ie=null!=(y=null!=(v=null==te?void 0:te.input)?v:D.Input)?y:"input",Pe=null!=(x=null==ee?void 0:ee.root)?x:z.root,Oe=null!=(b=null==ee?void 0:ee.rail)?b:z.rail,Re=null!=(_=null==ee?void 0:ee.track)?_:z.track,Le=null!=(w=null==ee?void 0:ee.thumb)?w:z.thumb,De=null!=(k=null==ee?void 0:ee.valueLabel)?k:z.valueLabel,ze=null!=(S=null==ee?void 0:ee.mark)?S:z.mark,je=null!=(A=null==ee?void 0:ee.markLabel)?A:z.markLabel,Fe=null!=(T=null==ee?void 0:ee.input)?T:z.input,Ne=to({elementType:ke,getSlotProps:le,externalSlotProps:Pe,externalForwardedProps:oe,additionalProps:(0,O.A)({},AK(ke)&&{as:L}),ownerState:(0,O.A)({},ae,null==Pe?void 0:Pe.ownerState),className:[we.root,B]}),Be=to({elementType:Se,externalSlotProps:Oe,ownerState:ae,className:we.rail}),Ve=to({elementType:Ae,externalSlotProps:Re,additionalProps:{style:(0,O.A)({},se[pe].offset(xe),se[pe].leap(be))},ownerState:(0,O.A)({},ae,null==Re?void 0:Re.ownerState),className:we.track}),Ue=to({elementType:Te,getSlotProps:ue,externalSlotProps:Le,ownerState:(0,O.A)({},ae,null==Le?void 0:Le.ownerState),className:we.thumb}),He=to({elementType:Me,externalSlotProps:De,ownerState:(0,O.A)({},ae,null==De?void 0:De.ownerState),className:we.valueLabel}),$e=to({elementType:Ce,externalSlotProps:ze,ownerState:ae,className:we.mark}),We=to({elementType:Ee,externalSlotProps:je,ownerState:ae,className:we.markLabel}),qe=to({elementType:Ie,getSlotProps:ce,externalSlotProps:Fe,ownerState:ae});return(0,j.jsxs)(ke,(0,O.A)({},Ne,{children:[(0,j.jsx)(Se,(0,O.A)({},Be)),(0,j.jsx)(Ae,(0,O.A)({},Ve)),ye.filter((e=>e.value>=Y&&e.value<=G)).map(((e,t)=>{const r=gK(e.value,Y,G),i=se[pe].offset(r);let o;return o=!1===re?-1!==ve.indexOf(e.value):"normal"===re&&(me?e.value>=ve[0]&&e.value<=ve[ve.length-1]:e.value<=ve[0])||"inverted"===re&&(me?e.value<=ve[0]||e.value>=ve[ve.length-1]:e.value>=ve[0]),(0,j.jsxs)(n.Fragment,{children:[(0,j.jsx)(Ce,(0,O.A)({"data-index":t},$e,!Yi(Ce)&&{markActive:o},{style:(0,O.A)({},i,$e.style),className:(0,fn.A)($e.className,o&&we.markActive)})),null!=e.label?(0,j.jsx)(Ee,(0,O.A)({"aria-hidden":!0,"data-index":t},We,!Yi(Ee)&&{markLabelActive:o},{style:(0,O.A)({},i,We.style),className:(0,fn.A)(we.markLabel,We.className,o&&we.markLabelActive),children:e.label})):null]},t)})),ve.map(((e,t)=>{const r=gK(e,Y,G),n=se[pe].offset(r),i="off"===ne?jK:Me;return(0,j.jsx)(i,(0,O.A)({},!Yi(i)&&{valueLabelFormat:ie,valueLabelDisplay:ne,value:"function"===typeof ie?ie(Q(e),t):ie,index:t,open:de===t||he===t||"on"===ne,disabled:U},He,{children:(0,j.jsx)(Te,(0,O.A)({"data-index":t},Ue,{className:(0,fn.A)(we.thumb,Ue.className,he===t&&we.active,fe===t&&we.focusVisible),style:(0,O.A)({},n,_e(t),Ue.style),children:(0,j.jsx)(Ie,(0,O.A)({"data-index":t,"aria-label":$?$(t):E,"aria-valuenow":Q(e),"aria-labelledby":P,"aria-valuetext":W?W(Q(e),t):I,value:ve[t]},qe))}))}),t)}))]}))})),NK="Add ROI",BK="Delete ROI",VK="Merge ROI",UK="/cell_roi.json",HK={width:30,height:30,left:Math.floor(145.5),top:Math.floor(145.5)};var $K=function(e){return e.LEFT="LEFT",e.RIGHT="RIGHT",e.BOTTOM="BOTTOM",e.TOP="TOP",e}($K||{});const WK=320,qK=(0,n.memo)((function(){const{filePath:e,itemId:t}=(0,n.useContext)(TZ),r=x(jf),i=x(wA(t)),o=x(kA(t)),a=x(PS(e)),s=x(IS(e)),l=x((c=e,e=>IS(c)(e)&&kS(e).image[c].fulfilled));var c;const u=x((e=>t=>IS(e)(t)?kS(t).image[e].error:null)(e)),d=x(xA(t)),h=C();return(0,n.useEffect)((()=>{r&&(s||h(sS({path:e,workspaceId:r,startIndex:null!==i&&void 0!==i?i:1,endIndex:null!==o&&void 0!==o?o:10})),null!=d&&h(cS({path:d,workspaceId:r})))}),[h,s,e,r,i,o,d]),a?(0,j.jsx)(qZ,{}):null!=u?(0,j.jsx)(Hi,{color:"error",children:u}):l?(0,j.jsx)(GK,{}):null})),GK=(0,n.memo)((function(){const{itemId:e}=(0,n.useContext)(TZ),t=x((e=>t=>{const r=lA(e)(t);if(ZS(r))return r.activeIndex;throw new Error("invalid VisualaizeItemType")})(e));return(0,j.jsx)(YK,{activeIndex:t})})),YK=(0,n.memo)((function(e){let{activeIndex:t}=e;const{enqueueSnackbar:r}=hn(),i=C(),o=x(jf),{filePath:a,itemId:s}=(0,n.useContext)(TZ),l=x(((e,t)=>r=>ES(e)(r).data[t])(a,t),ZK),c=x((u=a,e=>kS(e).image[u].meta));var u;const d=x(xA(s)),h=(0,n.useRef)(d),p=x((e=>null!=d?zS(d)(e):[]),ZK),[f,m]=(0,n.useState)(p),[g,y]=(0,n.useState)([]),v=x(sA),b=x(bA(s)),_=x(SA(s)),w=x(_A(s)),k=x(AA(s)),S=x(TA(s)),A=x(MA(s)),T=x(CA(s)),M=x(((e,t)=>r=>{const n=lA(e)(r);if(KS(n)){const e=n.maxIndex;if(0!==e)return e}return null!==t?BA(t)(r):0})(s,d)),E=x(EA(s)),I=x(uA(s)),P=x(dA(s)),O=x(qS),[R,L]=(0,n.useState)(HK),[D,z]=(0,n.useState)(!1),[F,N]=(0,n.useState)(""),[B,V]=(0,n.useState)(),U=x((e=>t=>{const r=lA(e)(t);var n,i;if(ZS(r))return null!==(n=null===(i=r.roiItem)||void 0===i?void 0:i.outputKey)&&void 0!==n?n:null;throw new Error("invalid VisualaizeItemType")})(s)),H=(0,n.useRef)(0),$=(0,n.useRef)(0),W=cK()({colormap:"jet",nshades:100,format:"rgba",alpha:1});(0,n.useEffect)((()=>{m(p)}),[p]),(0,n.useEffect)((()=>{d&&o&&i(mS({path:d,workspaceId:o}))}),[d,o]),(0,n.useEffect)((()=>(h.current=d,()=>{h.current&&o&&h.current.includes(UK)&&i(uS({path:h.current,workspaceId:o}))})),[d]);const q=(0,n.useMemo)((()=>[{z:l,type:"heatmap",name:"images",colorscale:A.map((e=>{let t=parseFloat(e.offset);const r=A.map((e=>parseFloat(e.offset)));t===Math.max(...r)&&(t=1),t===Math.min(...r)&&(t=0);return[t,KK(e.rgb.replace(/[^0-9,]/g,"").split(",").map((e=>Number(e))),T)]})),hoverongaps:!1,showscale:S,zsmooth:w},{z:f,type:"heatmap",name:"roi",hovertemplate:F===NK?"none":"cell id: %{z}",colorscale:[...Array(M+1)].map(((e,t)=>{const r=Math.floor((t%10*10+t/10)%100),n=t/M,i=KK(W[r],E);if(!F){if(O.temp_delete_roi.includes(t))return[n,"#ffffff"];if(O.temp_merge_roi.includes(t))return[n,"#e134eb"];if(O.temp_add_roi.includes(t))return[n,"#3483eb"]}if(F===NK){if(O.temp_delete_roi.includes(t))return[n,"#ffffff"];if(O.temp_add_roi.includes(t))return[n,"#3483eb"];if(O.temp_merge_roi.includes(t))return[n,"#e134eb"]}if(F===BK){if(g.find((e=>e.z===t))||O.temp_delete_roi.includes(t))return[n,"#ffffff"];if(O.temp_add_roi.includes(t))return[n,"#3483eb"];if(O.temp_merge_roi.includes(t))return[n,"#e134eb"]}if(F===VK){if(O.temp_delete_roi.includes(t))return[n,"#ffffff"];if(g.find((e=>e.z===t))||O.temp_merge_roi.includes(t))return[n,"#e134eb"];if(O.temp_add_roi.includes(t))return[n,"#3483eb"]}return[n,i]})),zmin:0,zmax:M,hoverongaps:!1,zsmooth:!1,showscale:!1}]),[l,f,w,S,A,W,M,E,T,g,F,O]),[G,Y]=(0,n.useState)(!1),[X,Z]=(0,n.useState)(!0),K=(0,n.useCallback)((()=>{if(O)return Object.keys(O).every((e=>0===O[e].length))}),[JSON.stringify(O)]),[J,Q]=(0,n.useState)(!K());(0,n.useEffect)((()=>{Q(!K())}),[K]);const ee=function(e){let t,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:500;return function(){for(var n=arguments.length,i=new Array(n),o=0;oe(...i)),r)}}((e=>{null!=e.range&&i(tT({itemId:s,range:e.range}))})),te=(0,n.useMemo)((()=>({title:{text:null===c||void 0===c?void 0:c.title,x:.1},width:I,height:P-130,margin:{t:30,l:100,b:20},dragmode:G?"select":"pan",xaxis:{title:null===c||void 0===c?void 0:c.xlabel,autorange:!0,showgrid:k,showline:_,zeroline:!1,autotick:!0,ticks:"",showticklabels:b},yaxis:{title:null===c||void 0===c?void 0:c.ylabel,automargin:!0,autorange:"reversed",showgrid:k,showline:_,zeroline:!1,autotick:!0,ticks:"",showticklabels:b}})),[c,k,_,b,I,P,G,F]),re=x(mA(s)),ne={displayModeBar:!0,responsive:!0,toImageButtonOptions:{format:x(gA(s)),filename:re}},ie=e=>{if(![VK,BK].includes(F))return;if(isNaN(Number(e.z)))return;let t;if(O.temp_delete_roi.includes(e.z))return;t=g.findIndex((t=>t.z===e.z))<0?[...g,e]:g.filter((t=>t.z!==e.z)),y(t)};(0,n.useEffect)((()=>{!K&&X&&Z(!1)}),[JSON.stringify(O),X]),(0,n.useEffect)((()=>{d&&void 0!==o&&i(xC({roiFilePath:d,workspaceId:o,statusRoi:O}))}),[d,F,JSON.stringify(O)]);const oe=()=>{Q(!0)},ae=()=>{N(""),Q(!0),L(HK),V(void 0),y([])},se=()=>{z(!1),V(void 0)},le=(e,t)=>{V(e),H.current=t.pageX,$.current=t.pageY},ce=async()=>{if(d&&o){if(F===NK){const e=f[0].length-1,t=f.length-1,r=Number(((R.width+2)/(WK/e)).toFixed(1)),n=Number(((R.height+2)/(WK/t)).toFixed(1)),a=Number((R.left/(WK/e)).toFixed(1)),s=Number((R.top/(WK/t)).toFixed(1)),l={posx:a+Math.floor(r/2),posy:s+Math.floor(n/2),sizex:r,sizey:n};await i(SM()),await i(dS({path:d,workspaceId:o,data:l})),ae()}if(F===VK){if(g.length<2)return;i(SM()),i(hS({path:d,workspaceId:o,data:{ids:g.map((e=>e.z))}})),y([]),o&&i(cS({path:d,workspaceId:o}))}else if(F===BK){if(!g.length)return;i(SM()),await i(pS({path:d,workspaceId:o,data:{ids:g.map((e=>e.z))}})),y([]),o&&i(cS({path:d,workspaceId:o}))}N(""),Q(!0),i(mS({path:d,workspaceId:o}))}},ue=()=>{v&&Object.keys(v).forEach((e=>{KS(v[e])&&i(nS({path:v[e].filePath,itemId:Number(e)}))}))};return O?(0,j.jsxs)(JK,{children:[(0,j.jsxs)(yi,{sx:{display:"flex"},children:[(0,j.jsx)(yi,{sx:{flexGrow:1,mt:1},children:(0,j.jsx)(XK,{activeIndex:t})}),(0,j.jsx)(aV,{sx:{ml:1},control:(0,j.jsx)(wH,{checked:G,onChange:e=>{Y(e.target.checked)}}),label:"drag select"})]}),(0,j.jsx)(yi,{sx:{minHeight:5.5},children:J&&!F&&d&&d.includes(UK)?(0,j.jsx)(j.Fragment,{children:(0,j.jsxs)(QK,{sx:{flexDirection:"column"},children:[(0,j.jsxs)(eJ,{sx:{marginBottom:2},children:[(0,j.jsx)(tJ,{onClick:()=>{N(NK)},children:NK}),(0,j.jsx)(tJ,{sx:{color:"#F84E1B"},onClick:async()=>{d&&N(BK)},children:BK}),(0,j.jsx)(tJ,{sx:{color:"#6619A9",ml:0},onClick:async()=>{d&&N(VK)},children:VK})]}),(0,j.jsxs)(eJ,{children:[Object.keys(O).some((e=>O[e].length>0))?(0,j.jsx)(tJ,{sx:{color:"#32A919"},onClick:async()=>{if(d&&void 0!==o)try{await i(fS({path:d,workspaceId:o})).unwrap(),o&&await i(cS({path:d,workspaceId:o})).unwrap(),r("Successfully committed to Edit ROI.",{variant:"success"}),ue()}catch(e){r("Failed to commit Edit ROI.",{variant:"error"})}finally{Q(!1),N("")}},children:"Commit Edit"}):null,(0,j.jsx)(tJ,{onClick:()=>{(async()=>{if(N(""),h.current&&h.current.includes(UK)&&void 0!==o){y([]);try{await i(uS({path:h.current,workspaceId:o}))}finally{o&&i(cS({path:h.current,workspaceId:o}))}}})(),Q(!1)},children:"Cancel"})]})]})}):d&&d.includes(UK)?F?(0,j.jsxs)(j.Fragment,{children:[F!==NK?(0,j.jsxs)(QK,{children:["ROI Selecteds: [",g.map((e=>e.z)).join(","),"]"]}):null,(0,j.jsxs)(QK,{sx:{display:"flex",gap:1},children:[(0,j.jsx)(tJ,{sx:{color:F===BK?"#F84E1B":F===VK?"#6619A9":"default",display:"flex",gap:1,textDecoration:"none",cursor:"default"},children:`[${F}]`}),(0,j.jsx)(tJ,{onClick:ae,children:"Cancel"}),(0,j.jsx)(tJ,{style:{opacity:g.length<2&&F===VK||g.length<1&&F===BK?.5:1,cursor:g.length<2&&F===VK||g.length<1&&F===BK?"default":"pointer"},onClick:ce,children:"OK"})]})]}):J?null:(0,j.jsx)(tJ,{sx:{width:"fit-content"},onClick:oe,children:"Edit ROI"}):null}),(0,j.jsxs)("div",{style:{position:"relative"},children:[(0,j.jsx)(CZ(),{data:q,layout:te,config:ne,onClick:e=>{const t=e.points[0];t.curveNumber>=1&&"cell_roi"===U&&ie({x:Number(t.x),y:Number(t.y),z:Number(t.z)}),t.curveNumber>=1&&t.z>=0&&i(eT({itemId:s,clickedDataId:t.z.toString()}))},onSelecting:ee}),F===NK?(0,j.jsx)(rJ,{children:(0,j.jsx)(nJ,{onMouseLeave:se,onMouseMove:e=>{const{pageX:t,pageY:r}=e;let n;if(D){const{y:i}=e.currentTarget.getBoundingClientRect();let o=R.left+(t-H.current),a=Math.ceil(r-i-15)-window.scrollY;o<0?o=0:o+R.width>WK&&(o=WK-R.width),a<0?a=0:a+R.height>WK&&(a=WK-R.height),n={...R,left:o,top:a}}else if(B===$K.LEFT){const e=R.width-(t-H.current),r=R.left+(t-H.current);if(e<10||r<1)return;n={...R,width:e,left:r}}else if(B===$K.RIGHT){const e=R.width+(t-H.current);if(e<10||e>WK-R.left)return;n={...R,width:e}}else if(B===$K.BOTTOM){const e=R.height+(r-$.current);if(e<10||e>WK-R.top)return;n={...R,height:e}}else if(B===$K.TOP){const e=R.height-(r-$.current),t=R.top+(r-$.current);if(e<10||t<1)return;n={...R,height:e,top:t}}n&&L({...R,...n}),H.current=t,$.current=r},onMouseUp:se,children:(0,j.jsxs)(iJ,{style:R,children:[(0,j.jsx)(oJ,{onMouseDown:()=>{z(!0)},style:{width:R.width-1,height:R.height-1,cursor:D?"grabbing":"grab"}}),(0,j.jsx)(sJ,{onMouseDown:e=>le($K.LEFT,e)}),(0,j.jsx)(lJ,{onMouseDown:e=>{le($K.RIGHT,e)}}),(0,j.jsx)(cJ,{onMouseDown:e=>{le($K.TOP,e)}}),(0,j.jsx)(uJ,{onMouseDown:e=>{le($K.BOTTOM,e)}})]})})}):null]})]}):null})),XK=(0,n.memo)((function(e){let{activeIndex:t}=e;const r=C(),{filePath:i,itemId:o}=(0,n.useContext)(TZ),a=x((s=i,e=>PS(s)(e)?0:ES(s)(e).data.length-1));var s;const l=x(wA(o)),c=x(kA(o)),u=x((e=>t=>{const r=lA(e)(t);if(ZS(r))return r.duration;throw new Error("invalid VisualaizeItemType")})(o)),d=(0,n.useRef)(null);(0,n.useEffect)((()=>{null!==d.current&&t>=a&&(clearInterval(d.current),d.current=null)}),[t,a]);const h=(0,n.useCallback)((()=>{t>=a&&r($T({itemId:o,activeIndex:0})),a>1&&null===d.current&&(d.current=setInterval((()=>{r(UT({itemId:o}))}),u))}),[t,a,r,u,o]),p=(0,n.useCallback)((e=>{var t,n;const i=""===(null===(t=e.target)||void 0===t?void 0:t.value)?"":Number(null===(n=e.target)||void 0===n?void 0:n.value);"number"===typeof i&&r(tM({itemId:o,duration:i}))}),[r,o]);return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(gf,{sx:{mt:1.5},variant:"outlined",onClick:h,children:"Play"}),(0,j.jsx)(gf,{sx:{mt:1.5,ml:1},variant:"outlined",onClick:()=>{null!==d.current&&(clearInterval(d.current),d.current=null)},children:"Pause"}),(0,j.jsx)(gH,{sx:{width:100,ml:2},label:"msec/frame",type:"number",inputProps:{step:100,min:0,max:1e3},InputLabelProps:{shrink:!0},onChange:p,value:u}),(0,j.jsx)(FK,{"aria-label":"Custom marks",defaultValue:20,value:l+t,valueLabelDisplay:"auto",step:1,marks:!0,min:l,max:0===a?0:c,onChange:(e,n)=>{if("number"===typeof n){const e=n-l;e>=0&&e!==t&&r($T({itemId:o,activeIndex:e}))}}})]})}));function ZK(e,t){return null!=e&&null!=t?xY(e,t):void 0===e&&void 0===t}function KK(e,t){const r=e[0],n=e[1],i=e[2],o=t,a=[r.toString(16),n.toString(16),i.toString(16),Math.round(255*o).toString(16).substring(0,2)];return a.forEach((function(e,t){1===e.length&&(a[t]="0"+e)})),`#${a.join("")}`}const JK=(0,yn.Ay)("div")` + .selectionlayer path { + stroke: white !important; + stroke-dasharray: 6 !important; + stroke-width: 2px !important; + opacity: 1 !important; + } +`,QK=(0,yn.Ay)("div")({mt:1,display:"flex",listStyle:"none",padding:0,margin:0}),eJ=(0,yn.Ay)("div")({display:"flex",gap:12}),tJ=(0,yn.Ay)("div")({textDecoration:"underline",cursor:"pointer",color:"#1155cc",zIndex:999,position:"relative"}),rJ=(0,yn.Ay)("div")({width:"100%",height:"100%",position:"absolute",left:0,top:0,borderRadius:100}),nJ=(0,yn.Ay)("div")({width:321,height:321,marginTop:30,marginLeft:99,position:"relative"}),iJ=(0,yn.Ay)("div")({border:"1px solid #ffffff",position:"absolute",borderRadius:100}),oJ=(0,yn.Ay)("div")({borderRadius:100,cursor:"grab"}),aJ=(0,yn.Ay)("div")({width:3,height:3,borderRadius:100,position:"absolute",background:"#fff"}),sJ=(0,yn.Ay)(aJ)({top:"calc(50% - 1px)",left:-2,cursor:"ew-resize"}),lJ=(0,yn.Ay)(aJ)({top:"calc(50% - 1px)",right:-2,cursor:"ew-resize"}),cJ=(0,yn.Ay)(aJ)({top:-2,right:"calc(50% - 1px)",cursor:"ns-resize"}),uJ=(0,yn.Ay)(aJ)({bottom:-2,right:"calc(50% - 1px)",cursor:"ns-resize"}),dJ=(0,n.memo)((function(){const{filePath:e}=(0,n.useContext)(TZ),t=C(),r=x((i=e,e=>HS(i)(e)&&kS(e).line[i].pending));var i;const o=x(HS(e)),a=x((e=>t=>HS(e)(t)?kS(t).line[e].error:null)(e)),s=x((e=>t=>HS(e)(t)&&kS(t).line[e].fulfilled)(e));return(0,n.useEffect)((()=>{o||t(bS({path:e}))}),[t,o,e]),r?(0,j.jsx)(qZ,{}):null!=a?(0,j.jsx)(Hi,{color:"error",children:a}):s?(0,j.jsx)(hJ,{}):null})),hJ=(0,n.memo)((function(){const{filePath:e,itemId:t}=(0,n.useContext)(TZ),r=x((i=e,e=>kS(e).line[i].data));var i;const o=x((e=>t=>kS(t).line[e].meta)(e)),a=x((e=>t=>kS(t).line[e].columns)(e)),s=x((e=>t=>kS(t).line[e].index)(e)),l=x(KA(t)),c=x(uA(t)),u=x(dA(t)),d=(0,n.useMemo)((()=>null!=r?[{x:a,y:r[l]}]:[]),[r,a,l]),h=(0,n.useMemo)((()=>({title:{text:null===o||void 0===o?void 0:o.title,x:.1},width:c,height:u-120,dragmode:"pan",margin:{t:50,l:50,b:40},autosize:!0,xaxis:{title:null===o||void 0===o?void 0:o.xlabel,tickvals:a},yaxis:{title:null===o||void 0===o?void 0:o.ylabel}})),[o,c,u,a]);return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(yi,{sx:{display:"flex"},children:(0,j.jsx)(yi,{sx:{flexGrow:1,ml:1},children:(0,j.jsx)(pJ,{index:s})})}),(0,j.jsx)(CZ(),{data:d,layout:h})]})})),pJ=(0,n.memo)((function(e){let{index:t}=e;const{itemId:r}=(0,n.useContext)(TZ),i=C(),o=x(KA(r));return(0,j.jsxs)(oH,{variant:"standard",sx:{m:1,minWidth:120},children:[(0,j.jsx)(tH,{children:"index"}),(0,j.jsx)(GN,{label:"smooth",value:o,onChange:e=>{i(wM({itemId:r,selectedIndex:Number(e.target.value)}))},children:t.map(((e,t)=>(0,j.jsx)(qa,{value:t,children:t},t)))})]})})),fJ=(0,n.memo)((function(){const{filePath:e}=(0,n.useContext)(TZ),t=C(),r=x((i=e,e=>$S(i)(e)&&kS(e).pie[i].pending));var i;const o=x($S(e)),a=x((e=>t=>$S(e)(t)?kS(t).pie[e].error:null)(e)),s=x((e=>t=>$S(e)(t)&&kS(t).pie[e].fulfilled)(e));return(0,n.useEffect)((()=>{o||t(_S({path:e}))}),[t,o,e]),r?(0,j.jsx)(qZ,{}):null!=a?(0,j.jsx)(Hi,{color:"error",children:a}):s?(0,j.jsx)(mJ,{}):null})),mJ=(0,n.memo)((function(){const{filePath:e,itemId:t}=(0,n.useContext)(TZ),r=x((i=e,e=>kS(e).pie[i].data));var i;const o=x((e=>t=>kS(t).pie[e].meta)(e)),a=x((e=>t=>kS(t).pie[e].columns)(e)),s=x(uA(t)),l=x(dA(t)),c=(0,n.useMemo)((()=>null!=r?[{values:r[0],labels:a,type:"pie",sort:!1,direction:"clockwise"}]:[]),[r,a]),u=(0,n.useMemo)((()=>({title:{text:null===o||void 0===o?void 0:o.title,x:.1},width:s,height:l-120,dragmode:"pan",margin:{t:60,l:50,b:30},autosize:!0,xaxis:{tickvals:a,title:null===o||void 0===o?void 0:o.xlabel},yaxis:{title:null===o||void 0===o?void 0:o.ylabel}})),[o,s,l,a]);return(0,j.jsx)(CZ(),{data:c,layout:u})})),gJ=(0,n.memo)((function(){const{filePath:e}=(0,n.useContext)(TZ),t=C(),r=x((i=e,e=>WS(i)(e)&&kS(e).polar[i].pending));var i;const o=x(WS(e)),a=x((e=>t=>WS(e)(t)?kS(t).polar[e].error:null)(e)),s=x((e=>t=>WS(e)(t)&&kS(t).polar[e].fulfilled)(e));return(0,n.useEffect)((()=>{o||t(wS({path:e}))}),[t,o,e]),r?(0,j.jsx)(qZ,{}):null!=a?(0,j.jsx)(Hi,{color:"error",children:a}):s?(0,j.jsx)(yJ,{}):null})),yJ=(0,n.memo)((function(){const{filePath:e,itemId:t}=(0,n.useContext)(TZ),r=x((i=e,e=>kS(e).polar[i].data));var i;const o=x((e=>t=>kS(t).polar[e].meta)(e)),a=x((e=>t=>kS(t).polar[e].columns)(e)),s=x((e=>t=>kS(t).polar[e].index)(e)),l=x(JA(t)),c=x(uA(t)),u=x(dA(t)),d=(0,n.useMemo)((()=>null!=r?[{type:"scatterpolar",mode:"lines+markae",theta:[...a,a[0]],r:[...r[l],r[l][0]]}]:[]),[r,a,l]),h=(0,n.useMemo)((()=>({title:{text:null===o||void 0===o?void 0:o.title,x:.1},width:c,height:u-120,dragmode:"pan",margin:{t:50,l:50,b:40},autosize:!0,xaxis:{tickvals:a,title:null===o||void 0===o?void 0:o.xlabel},yaxis:{title:null===o||void 0===o?void 0:o.ylabel}})),[o,c,u,a]);return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(yi,{sx:{display:"flex"},children:(0,j.jsx)(yi,{sx:{flexGrow:1,ml:1},children:(0,j.jsx)(vJ,{index:s})})}),(0,j.jsx)(CZ(),{data:d,layout:h})]})})),vJ=(0,n.memo)((function(e){let{index:t}=e;const{itemId:r}=(0,n.useContext)(TZ),i=C(),o=x(JA(r));return(0,j.jsxs)(oH,{variant:"standard",sx:{m:1,minWidth:120},children:[(0,j.jsx)(tH,{children:"index"}),(0,j.jsx)(GN,{label:"smooth",value:o,onChange:e=>{i(kM({itemId:r,selectedIndex:Number(e.target.value)}))},children:t.map(((e,t)=>(0,j.jsx)(qa,{value:t,children:t},t)))})]})})),xJ=(0,n.memo)((function(){const{filePath:e}=(0,n.useContext)(TZ),t=x((r=e,e=>jS(r)(e)&&kS(e).roi[r].pending));var r;const i=x(jS(e)),o=x(FS(e)),a=x((e=>t=>jS(e)(t)?kS(t).roi[e].error:null)(e)),s=x(jf),l=C();return(0,n.useEffect)((()=>{s&&!i&&l(cS({path:e,workspaceId:s}))}),[l,i,e,s]),t?(0,j.jsx)(qZ,{}):null!=a?(0,j.jsx)(Hi,{color:"error",children:a}):o?(0,j.jsx)(bJ,{}):null})),bJ=(0,n.memo)((function(){const{itemId:e,filePath:t}=(0,n.useContext)(TZ),r=x(zS(t),_J),i=x((o=t,e=>kS(e).roi[o].meta));var o;const a=x(uA(e)),s=x(dA(e)),l=cK()({colormap:"jet",nshades:10,format:"hex",alpha:1}).map(((e,t)=>({rgb:e,offset:String(t/9)}))),c=(0,n.useMemo)((()=>[{z:r,type:"heatmap",name:"roi",colorscale:l.map((e=>{let t=parseFloat(e.offset);const r=l.map((e=>parseFloat(e.offset)));return t===Math.max(...r)&&(t=1),t===Math.min(...r)&&(t=0),[t,e.rgb]})),hoverongaps:!1,zsmooth:!1,showlegend:!0}]),[r,l]),u=(0,n.useMemo)((()=>({title:{text:null===i||void 0===i?void 0:i.title,x:.1},width:a,height:s-50,margin:{t:30,l:120,b:30},dragmode:"pan",xaxis:{title:null===i||void 0===i?void 0:i.xlabel,autorange:!0,zeroline:!1,autotick:!0,ticks:""},yaxis:{title:null===i||void 0===i?void 0:i.ylabel,autorange:"reversed",zeroline:!1,autotick:!0,ticks:""}})),[i,a,s]),d=x(mA(e)),h={displayModeBar:!0,responsive:!0,toImageButtonOptions:{format:x(gA(e)),filename:d}};return(0,j.jsx)(CZ(),{data:c,layout:u,config:h})}));function _J(e,t){return null!=e&&null!=t?xY(e,t):void 0===e&&void 0===t}const wJ=(0,n.memo)((function(){const{filePath:e}=(0,n.useContext)(TZ),t=C(),r=x((i=e,e=>NS(i)(e)&&kS(e).scatter[i].pending));var i;const o=x(NS(e)),a=x((e=>t=>NS(e)(t)?kS(t).scatter[e].error:null)(e)),s=x((e=>t=>NS(e)(t)&&kS(t).scatter[e].fulfilled)(e));return(0,n.useEffect)((()=>{o||t(gS({path:e}))}),[t,o,e]),r?(0,j.jsx)(qZ,{}):null!=a?(0,j.jsx)(Hi,{color:"error",children:a}):s?(0,j.jsx)(kJ,{}):null})),kJ=(0,n.memo)((function(){const{filePath:e,itemId:t}=(0,n.useContext)(TZ),r=x((i=e,e=>{var t,r;return null!==(t=null===(r=kS(e).scatter[i])||void 0===r?void 0:r.data)&&void 0!==t?t:[]}),TJ);var i;const o=x((e=>t=>{var r;return null===(r=kS(t).scatter[e])||void 0===r?void 0:r.meta})(e)),a=x(GA(t)),s=x(YA(t)),l=x(uA(t)),c=x(dA(t)),u=(0,n.useMemo)((()=>[{x:r[a],y:r[s],type:"scatter",mode:"markers",text:Object.keys(r[a]),textposition:"top center",textfont:{family:"Raleway, sans-serif"},marker:{size:5,color:Object.keys(r[a])}}]),[r,a,s]),d=(0,n.useMemo)((()=>{var e,t;return{title:{text:null===o||void 0===o?void 0:o.title,x:.1},width:l,height:c-120,margin:{t:50,l:50,b:40},dragmode:"pan",autosize:!0,xaxis:{title:{text:null!==(e=null===o||void 0===o?void 0:o.xlabel)&&void 0!==e?e:`x: ${a}`,font:{family:"Courier New, monospace",size:18,color:"#7f7f7f"}}},yaxis:{title:{text:null!==(t=null===o||void 0===o?void 0:o.ylabel)&&void 0!==t?t:`y: ${s}`,font:{family:"Courier New, monospace",size:18,color:"#7f7f7f"}}}}}),[o,a,s,l,c]),h=x(mA(t)),p={displayModeBar:!0,responsive:!0,toImageButtonOptions:{format:x(gA(t)),filename:h}};return(0,j.jsxs)("div",{children:[(0,j.jsx)(yi,{sx:{display:"flex"},children:(0,j.jsxs)(yi,{sx:{flexGrow:1,ml:1},children:[(0,j.jsx)(SJ,{dataKeys:Object.keys(r)}),(0,j.jsx)(AJ,{dataKeys:Object.keys(r)})]})}),(0,j.jsx)(CZ(),{data:u,layout:d,config:p})]})})),SJ=(0,n.memo)((function(e){let{dataKeys:t}=e;const{itemId:r}=(0,n.useContext)(TZ),i=C(),o=x(GA(r));return(0,j.jsxs)(oH,{variant:"standard",sx:{m:1,minWidth:120},children:[(0,j.jsx)(tH,{children:"xIndex"}),(0,j.jsx)(GN,{label:"smooth",value:o,onChange:e=>{i(vM({itemId:r,xIndex:e.target.value}))},children:t.map((e=>(0,j.jsx)(qa,{value:e,children:e},e)))})]})})),AJ=(0,n.memo)((function(e){let{dataKeys:t}=e;const{itemId:r}=(0,n.useContext)(TZ),i=C(),o=x(YA(r));return(0,j.jsxs)(oH,{variant:"standard",sx:{m:1,minWidth:120},children:[(0,j.jsx)(tH,{children:"yIndex"}),(0,j.jsx)(GN,{label:"smooth",value:o,onChange:e=>{i(xM({itemId:r,yIndex:e.target.value}))},children:t.map((e=>(0,j.jsx)(qa,{value:e,children:e},e)))})]})}));function TJ(e,t){if(null!=e&&null!=t){const r=Object.keys(e),n=Object.keys(t);return e===t||r.length===n.length&&r.every(((e,t)=>n[t]===e))}return void 0===e&&void 0===t}const MJ=(0,n.memo)((function(){const{itemId:e,filePath:t}=(0,n.useContext)(TZ),r=C(),i=x((o=t,e=>MS(o)(e)&&kS(e).timeSeries[o].pending));var o;const a=x(MS(t)),s=x((e=>t=>MS(e)(t)?kS(t).timeSeries[e].error:null)(t)),l=x((e=>t=>MS(e)(t)&&kS(t).timeSeries[e].fulfilled)(t));return(0,n.useEffect)((()=>{a||r(nS({path:t,itemId:e}))}),[r,a,t,e]),a?null!=s?(0,j.jsx)(Hi,{color:"error",children:s}):i||l?(0,j.jsx)(CJ,{}):null:(0,j.jsx)(qZ,{})})),CJ=(0,n.memo)((function(){const{filePath:e,itemId:t}=(0,n.useContext)(TZ),r=C(),i=x(TS(e),EJ),o=x((a=e,e=>kS(e).timeSeries[a].meta));var a;const s=x((e=>t=>kS(t).timeSeries[e].xrange)(e)),l=x((e=>t=>kS(t).timeSeries[e].std)(e)),c=x(QA(t)),u=x(IA(t)),d=x(PA(t)),h=x(OA(t)),p=x(RA(t)),f=x(LA(t)),m=x(DA(t)),g=x(zA(t)),y=x(jA(t)),v=x(uA(t)),b=x(dA(t)),_=x(NA(t)),[w,k]=(0,n.useState)(s),[S,A]=(0,n.useState)(i),T=x(Uk),M=x($G(T));(0,n.useEffect)((()=>{const e={};if(y.forEach((t=>{e[t]=i[t]})),"time"===c&&i&&Object.keys(i).length>0){const t={};Object.keys(e).forEach((r=>{t[r]={},Object.keys(e[r]).forEach((n=>{const i=Number(n)/M;t[r][i]=e[r][n]}))})),k(s.map((e=>String(Number(e)/M)))),A(t)}else k(s),A(e)}),[c,s,i,y]);const E=cK()({colormap:"jet",nshades:100,format:"hex",alpha:1}),I=(0,n.useMemo)((()=>Object.fromEntries(_.map((e=>{let t=w.map((t=>{var r;return null===(r=S[e])||void 0===r?void 0:r[t]}));const r=Number(e),n=Math.floor(r%10*10+r/10)%100;if(y.includes(e)&&!u){const r=y.findIndex((t=>t===e)),n=t.reduce(((e,t)=>e+t))/t.length,i=d*Math.sqrt(t.reduce(((e,t)=>e+Math.pow(t-n,2)))/t.length);t=t.map((e=>(e-n)/(i+1e-10)+r))}return[e,{name:e,x:w,y:t,visible:!!y.includes(e)||"legendonly",line:{color:E[n]},error_y:{type:"data",array:u&&Object.keys(l).includes(e)?Object.values(l[e]):null,visible:!0}}]})))),[y,u,d,E,l,_,w,S]),P=(0,n.useMemo)((()=>{const e="time"===c?M:1;return y.map((t=>({x:Number((w.length-1)/e)+w.length/(10*e),y:I[t].y[w.length-1],xref:"x",yref:"y",text:`cell: ${t}`,arrowhead:1,ax:0,ay:-10})))}),[I,y,w,c,M]),O=(0,n.useMemo)((()=>{var e;return{title:{text:null===o||void 0===o?void 0:o.title,x:.1},margin:{t:60,l:50,b:30},dragmode:"pan",autosize:!0,width:v,height:b-50,xaxis:{title:{text:null!==(e=null===o||void 0===o?void 0:o.xlabel)&&void 0!==e?e:c},titlefont:{size:12,color:"black"},tickfont:{size:10,color:"black"},range:"frames"===c?[g.left,g.right]:["undefined"!==typeof g.left?g.left/M:-2.5,"undefined"!==typeof g.right?g.right/M:s.length/M+6.8],showgrid:h,showline:p,showticklabels:f,zeroline:m},yaxis:{title:null===o||void 0===o?void 0:o.ylabel,showgrid:h,showline:p,showticklabels:f,zeroline:m},annotations:P}}),[o,g,h,p,f,m,P,v,b,c,s,M]),R=x(mA(t)),L={displayModeBar:!0,responsive:!0,toImageButtonOptions:{format:x(gA(t)),filename:R}};return(0,j.jsx)(CZ(),{data:Object.values(I),layout:O,config:L,onLegendClick:n=>{const i=_[n.curveNumber],o=y.includes(i)?y.filter((e=>e!==i)):[...y,i];return r(uM({itemId:t,drawOrderList:o})),y.includes(i)||r(iS({path:e,index:i})),!1}})}));function EJ(e,t){if(null!=e&&null!=t){const r=Object.entries(e),n=Object.entries(t);return e===t||r.length===n.length&&r.every(((e,t)=>{let[r,i]=e;const[o,a]=n[t];return o===r&&function(e,t){const r=Object.entries(e),n=Object.entries(t);return e===t||r.length===n.length&&r.every(((e,t)=>{let[r,i]=e;const[o,a]=n[t];return o===r&&a===i}))}(a,i)}))}return void 0===e&&void 0===t}const IJ=(0,n.memo)((function(e){let{itemId:t}=e;const r=x(fA(t)),n=x(pA(t)),i=x(hA(t));return null!=r&&null!=i?(0,j.jsx)(TZ.Provider,{value:{nodeId:n,filePath:r,dataType:i,itemId:t},children:(0,j.jsx)(PJ,{dataType:i})}):(0,j.jsx)("div",{children:"Please select item correctly."})})),PJ=(0,n.memo)((function(e){let{dataType:t}=e;switch(t){case Xf:return(0,j.jsx)(KZ,{});case qf:return(0,j.jsx)(MJ,{});case Gf:return(0,j.jsx)(eK,{});case Yf:return(0,j.jsx)(qK,{});case Zf:return(0,j.jsx)(xJ,{});case Kf:return(0,j.jsx)(wJ,{});case Jf:return(0,j.jsx)(GZ,{});case em:return(0,j.jsx)(aK,{});case nm:return(0,j.jsx)(nK,{});case im:return(0,j.jsx)(dJ,{});case om:return(0,j.jsx)(fJ,{});case am:return(0,j.jsx)(gJ,{});default:return null}}));function OJ(e,t){let r=null;for(const n of Object.values(t))if(RJ(n)?n.path===e&&(r=n):r=OJ(e,n.children),null!=r)break;return r}function RJ(e){return"child"===e.type}function LJ(e,t){const r={};return Object.entries(e).forEach((e=>{let[n,i]=e;const o=null!==t&&void 0!==t?t:[];!function(e){return null!==e&&"object"===typeof e&&!Array.isArray(e)}(i)?r[n]={type:"child",value:i,path:o.concat([n]).join("/")}:(o.push(n),r[n]={type:"parent",children:LJ(i,o)})})),r}const DJ=e=>t=>t.algorithmNode[e],zJ=e=>t=>DJ(e)(t).name,jJ=e=>t=>{var r;return null===(r=DJ(e)(t))||void 0===r?void 0:r.params},FJ=e=>t=>{const r=DJ(e)(t).isUpdate,n=DJ(e)(t).originalValue,i=jJ(e)(t);return!(JSON.stringify(n)===JSON.stringify(i))&&r},NJ=e=>0===Object.keys((e=>e.algorithmNode)(e)).length,BJ=(0,n.memo)((function(e){let{open:t,onClose:r,nodeId:n}=e;const i=C(),o=()=>{r(),i(PT())};return(0,j.jsxs)(Wp,{open:t,onClose:o,fullWidth:!0,children:[(0,j.jsx)(VJ,{onClose:o,nodeId:n}),(0,j.jsx)(ef,{dividers:!0,sx:{pt:1,px:2},children:t&&(0,j.jsx)(UJ,{nodeId:n})})]})})),VJ=(0,n.memo)((function(e){let{nodeId:t,onClose:r}=e;const n=x(zJ(t));return(0,j.jsxs)(Zp,{sx:{m:0,p:2},children:["Output of ",n,(0,j.jsx)(oi,{onClick:r,sx:{position:"absolute",right:8,top:10},children:(0,j.jsx)(pn.A,{})})]})})),UJ=(0,n.memo)((function(e){let{nodeId:t}=e;const r=x((e=>t=>{const r=$k(t);if(Fk(r)){const t=r.runResult[e];if(Object.keys(r.runResult).includes(e)&&jk(t))return Object.keys(t.outputPaths)}return[]})(t),vY),[i,o]=(0,n.useState)(r[0]);return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(HJ,{outputKeyList:r,selectedOutoutKey:i,onSelectOutput:o}),(0,j.jsx)($J,{nodeId:t,outputKey:i})]})})),HJ=(0,n.memo)((function(e){let{selectedOutoutKey:t,outputKeyList:r,onSelectOutput:n}=e;return(0,j.jsx)(aC,{value:t,onChange:(e,t)=>{n(t)},variant:"scrollable",scrollButtons:"auto",sx:{[`& .${XM.scrollButtons}`]:{"&.Mui-disabled":{opacity:.3}}},children:r.map((e=>(0,j.jsx)(LM,{value:e,label:e,sx:{textTransform:"none"}},e)))})})),$J=(0,n.memo)((function(e){let{nodeId:t,outputKey:r}=e;const i=C(),o=x(((e,t)=>r=>{const n=Jk(e)(r);if(Object.keys(n).includes(t))return n[t].path;throw new Error(`key error. outputKey:${t}`)})(t,r)),a=x(((e,t)=>r=>{const n=Jk(e)(r);if(Object.keys(n).includes(t))return n[t].type;throw new Error(`key error. outputKey:${t}`)})(t,r)),s=x(((e,t,r)=>n=>{const i=sA(n);let o=null;for(const[a,s]of Object.entries(i))s.nodeId===e&&s.filePath===t&&s.dataType===r&&s.isWorkflowDialog&&(o=Number(a));return o})(t,o,a));return(0,n.useEffect)((()=>{null===s&&i(IT({nodeId:t,filePath:o,dataType:a}))}),[i,t,o,a,s]),(0,j.jsx)(yi,{sx:{mx:1,my:2},children:null!=s&&(0,j.jsx)(IJ,{itemId:s})})})),WJ=(0,n.memo)((function(e){let{open:t,onConfirm:r,onCancel:n}=e;return(0,j.jsx)(Cf,{open:t,onConfirm:r,onCancel:n,title:"Change this parameter?",content:"Changing this parameter may affect whole workflow.\n So, this workflow will be run as new workflow with new ID (RUN ALL).\n Existing nodes are kept as they are.",iconType:"warning"})})),qJ=(0,n.createContext)({onOpenOutputDialog:()=>null,onOpenFileSelectDialog:()=>null,onOpenClearWorkflowIdDialog:()=>null,onOpenInputUrlDialog:()=>null,onMessageError:()=>null});var GJ=r(72126),YJ=r(39244),XJ=r(99641);const ZJ=["element"];const KJ=n.createContext({});const JJ=()=>{};function QJ(e){const[,t]=n.useState(),{registerDescendant:r=JJ,unregisterDescendant:i=JJ,descendants:o=[],parentId:a=null}=n.useContext(KJ),s=function(e,t){for(let r=0;rt.element===e.element)),l=function(e){const t=n.useRef(null);return n.useEffect((()=>{t.current=e}),[e]),t.current}(o),c=o.some(((e,t)=>l&&l[t]&&l[t].element!==e.element));return(0,$o.A)((()=>{if(e.element)return r((0,O.A)({},e,{index:s})),()=>{i(e.element)};t({})}),[r,i,s,c,e]),{parentId:a,index:s}}function eQ(e){const{children:t,id:r}=e,[i,o]=n.useState([]),a=n.useCallback((e=>{let{element:t}=e,r=(0,R.A)(e,ZJ);o((e=>{if(0===e.length)return[(0,O.A)({},r,{element:t,index:0})];const n=function(e,t){let r=0,n=e.length-1;for(;r<=n;){const i=Math.floor((r+n)/2);if(e[i].element===t)return i;e[i].element.compareDocumentPosition(t)&Node.DOCUMENT_POSITION_PRECEDING?n=i-1:r=i+1}return r}(e,t);let i;if(e[n]&&e[n].element===t)i=e;else{const o=(0,O.A)({},r,{element:t,index:n});i=e.slice(),i.splice(n,0,o)}return i.forEach(((e,t)=>{e.index=t})),i}))}),[]),s=n.useCallback((e=>{o((t=>t.filter((t=>e!==t.element))))}),[]),l=n.useMemo((()=>({descendants:i,registerDescendant:a,unregisterDescendant:s,parentId:r})),[i,a,s,r]);return(0,j.jsx)(KJ.Provider,{value:l,children:t})}const tQ={instance:null,multiSelect:!1,disabledItemsFocusable:!1,treeId:void 0,icons:{defaultCollapseIcon:null,defaultExpandIcon:null,defaultParentIcon:null,defaultEndIcon:null}},rQ=n.createContext(tQ);const nQ=()=>n.useContext(rQ);const iQ=["classes","className","displayIcon","expansionIcon","icon","label","nodeId","onClick","onMouseDown"],oQ=n.forwardRef((function(e,t){const{classes:r,className:n,displayIcon:i,expansionIcon:o,icon:a,label:s,nodeId:l,onClick:c,onMouseDown:u}=e,d=(0,R.A)(e,iQ),{disabled:h,expanded:p,selected:f,focused:m,handleExpansion:g,handleSelection:y,preventSelection:v}=function(e){const{instance:t,multiSelect:r}=nQ(),n=!!t&&t.isNodeExpandable(e),i=!!t&&t.isNodeExpanded(e),o=!!t&&t.isNodeFocused(e),a=!!t&&t.isNodeSelected(e),s=!!t&&t.isNodeDisabled(e);return{disabled:s,expanded:i,selected:a,focused:o,handleExpansion:i=>{if(t&&!s){o||t.focusNode(i,e);const a=r&&(i.shiftKey||i.ctrlKey||i.metaKey);!n||a&&t.isNodeExpanded(e)||t.toggleNodeExpansion(i,e)}},handleSelection:n=>{t&&!s&&(o||t.focusNode(n,e),r&&(n.shiftKey||n.ctrlKey||n.metaKey)?n.shiftKey?t.selectRange(n,{end:e}):t.selectNode(n,e,!0):t.selectNode(n,e))},preventSelection:e=>{(e.shiftKey||e.ctrlKey||e.metaKey||s)&&e.preventDefault()}}}(l),x=a||o||i;return(0,j.jsxs)("div",(0,O.A)({},d,{className:(0,fn.A)(n,r.root,p&&r.expanded,f&&r.selected,m&&r.focused,h&&r.disabled),onClick:e=>{g(e),y(e),c&&c(e)},onMouseDown:e=>{v(e),u&&u(e)},ref:t,children:[(0,j.jsx)("div",{className:r.iconContainer,children:x}),(0,j.jsx)("div",{className:r.label,children:s})]}))}));function aQ(e){return(0,Yn.Ay)("MuiTreeItem",e)}const sQ=(0,Ln.A)("MuiTreeItem",["root","group","content","expanded","selected","focused","disabled","iconContainer","label"]),lQ=["children","className","collapseIcon","ContentComponent","ContentProps","endIcon","expandIcon","disabled","icon","id","label","nodeId","onClick","onMouseDown","TransitionComponent","TransitionProps"],cQ=(0,yn.Ay)("li",{name:"MuiTreeItem",slot:"Root",overridesResolver:(e,t)=>t.root})({listStyle:"none",margin:0,padding:0,outline:0}),uQ=(0,yn.Ay)(oQ,{name:"MuiTreeItem",slot:"Content",overridesResolver:(e,t)=>[t.content,t.iconContainer&&{[`& .${sQ.iconContainer}`]:t.iconContainer},t.label&&{[`& .${sQ.label}`]:t.label}]})((e=>{let{theme:t}=e;return{padding:"0 8px",width:"100%",boxSizing:"border-box",display:"flex",alignItems:"center",cursor:"pointer",WebkitTapHighlightColor:"transparent","&:hover":{backgroundColor:(t.vars||t).palette.action.hover,"@media (hover: none)":{backgroundColor:"transparent"}},[`&.${sQ.disabled}`]:{opacity:(t.vars||t).palette.action.disabledOpacity,backgroundColor:"transparent"},[`&.${sQ.focused}`]:{backgroundColor:(t.vars||t).palette.action.focus},[`&.${sQ.selected}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity})`:OI(t.palette.primary.main,t.palette.action.selectedOpacity),"&:hover":{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.hoverOpacity}))`:OI(t.palette.primary.main,t.palette.action.selectedOpacity+t.palette.action.hoverOpacity),"@media (hover: none)":{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / ${t.vars.palette.action.selectedOpacity})`:OI(t.palette.primary.main,t.palette.action.selectedOpacity)}},[`&.${sQ.focused}`]:{backgroundColor:t.vars?`rgba(${t.vars.palette.primary.mainChannel} / calc(${t.vars.palette.action.selectedOpacity} + ${t.vars.palette.action.focusOpacity}))`:OI(t.palette.primary.main,t.palette.action.selectedOpacity+t.palette.action.focusOpacity)}},[`& .${sQ.iconContainer}`]:{marginRight:4,width:15,display:"flex",flexShrink:0,justifyContent:"center","& svg":{fontSize:18}},[`& .${sQ.label}`]:(0,O.A)({paddingLeft:4,width:"100%",boxSizing:"border-box",minWidth:0,position:"relative"},t.typography.body1)}})),dQ=(0,yn.Ay)(hY,{name:"MuiTreeItem",slot:"Group",overridesResolver:(e,t)=>t.group})({margin:0,padding:0,marginLeft:17}),hQ=n.forwardRef((function(e,t){const r=iF({props:e,name:"MuiTreeItem"}),{children:i,className:o,collapseIcon:a,ContentComponent:s=oQ,ContentProps:l,endIcon:c,expandIcon:u,disabled:d,icon:h,id:p,label:f,nodeId:m,onClick:g,onMouseDown:y,TransitionComponent:v=hY,TransitionProps:x}=r,b=(0,R.A)(r,lQ),{icons:_,multiSelect:w,disabledItemsFocusable:k,treeId:S,instance:A}=nQ();let T;null!=p?T=p:S&&m&&(T=`${S}-${m}`);const[M,C]=n.useState(null),E=n.useRef(null),I=(0,Gi.A)(C,t),P=n.useMemo((()=>({element:M,id:m})),[m,M]),{index:L,parentId:D}=QJ(P),z=Boolean(Array.isArray(i)?i.length:i),F=!!A&&A.isNodeExpanded(m),N=!!A&&A.isNodeFocused(m),B=!!A&&A.isNodeSelected(m),V=!!A&&A.isNodeDisabled(m),U=(0,O.A)({},r,{expanded:F,focused:N,selected:B,disabled:V}),H=(e=>{const{classes:t}=e;return function(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0;const n={};for(const i in e){const o=e[i];let a="",s=!0;for(let e=0;e{if(A&&-1!==L)return A.updateNode({id:m,idAttribute:T,index:L,parentId:D,expandable:z,disabled:d}),()=>A.removeNode(m)}),[A,D,L,m,z,d,T]),n.useEffect((()=>{var e,t;if(A&&f)return A.mapFirstChar(m,(null!=(e=null==(t=E.current)?void 0:t.textContent)?e:"").substring(0,1).toLowerCase())}),[A,m,f]),w?q=B:B&&(q=!0),(0,j.jsxs)(cQ,(0,O.A)({className:(0,fn.A)(H.root,o),role:"treeitem","aria-expanded":z?F:void 0,"aria-selected":q,"aria-disabled":V||void 0,id:T,tabIndex:-1},b,{ownerState:U,onFocus:function(e){if(e.target===e.currentTarget){let t;t="function"===typeof e.target.getRootNode?e.target.getRootNode():(0,No.A)(e.target),t.getElementById(S).focus({preventScroll:!0})}const t=!k&&V;!A||N||e.currentTarget!==e.target||t||A.focusNode(e,m)},ref:I,children:[(0,j.jsx)(uQ,(0,O.A)({as:s,ref:E,classes:{root:H.content,expanded:H.expanded,selected:H.selected,focused:H.focused,disabled:H.disabled,iconContainer:H.iconContainer,label:H.label},label:f,nodeId:m,onClick:g,onMouseDown:y,icon:h,expansionIcon:W,displayIcon:$,ownerState:U},l)),i&&(0,j.jsx)(eQ,{id:m,children:(0,j.jsx)(dQ,(0,O.A)({as:v,unmountOnExit:!0,className:H.group,in:F,component:"ul",role:"group"},x,{children:i}))})]}))}));const pQ=function(e){return"string"===typeof e};const fQ=function(e,t,r){return void 0===e||pQ(e)?t:{...t,ownerState:{...t.ownerState,...r}}};const mQ=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];if(void 0===e)return{};const r={};return Object.keys(e).filter((r=>r.match(/^on[A-Z]/)&&"function"===typeof e[r]&&!t.includes(r))).forEach((t=>{r[t]=e[t]})),r};const gQ=function(e){if(void 0===e)return{};const t={};return Object.keys(e).filter((t=>!(t.match(/^on[A-Z]/)&&"function"===typeof e[t]))).forEach((r=>{t[r]=e[r]})),t};const yQ=function(e){const{getSlotProps:t,additionalProps:r,externalSlotProps:n,externalForwardedProps:i,className:o}=e;if(!t){const e=(0,fn.A)(r?.className,o,i?.className,n?.className),t={...r?.style,...i?.style,...n?.style},a={...r,...i,...n};return e.length>0&&(a.className=e),Object.keys(t).length>0&&(a.style=t),{props:a,internalRef:void 0}}const a=mQ({...i,...n}),s=gQ(n),l=gQ(i),c=t(a),u=(0,fn.A)(c?.className,r?.className,o,i?.className,n?.className),d={...c?.style,...r?.style,...i?.style,...n?.style},h={...c,...r,...l,...s};return u.length>0&&(h.className=u),Object.keys(d).length>0&&(h.style=d),{props:h,internalRef:c.ref}};const vQ=function(e,t,r){return"function"===typeof e?e(t,r):e};const xQ=function(e){const{elementType:t,externalSlotProps:r,ownerState:i,skipResolvingSlotProps:o=!1,...a}=e,s=o?{}:vQ(r,i),{props:l,internalRef:c}=yQ({...a,externalSlotProps:s}),u=function(){for(var e=arguments.length,t=new Array(e),r=0;rt.every((e=>null==e))?null:e=>{t.forEach((t=>{!function(e,t){"function"===typeof e?e(t):e&&(e.current=t)}(t,e)}))}),t)}(c,s?.ref,e.additionalProps?.ref);return fQ(t,{...l,ref:u},i)};function bQ(e){return(0,Yn.Ay)("MuiTreeView",e)}(0,Ln.A)("MuiTreeView",["root"]);class _Q{constructor(){this.maxListeners=20,this.warnOnce=!1,this.events={}}on(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=this.events[e];n||(n={highPriority:new Map,regular:new Map},this.events[e]=n),r.isFirst?n.highPriority.set(t,!0):n.regular.set(t,!0)}removeListener(e,t){this.events[e]&&(this.events[e].regular.delete(t),this.events[e].highPriority.delete(t))}removeAllListeners(){this.events={}}emit(e){const t=this.events[e];if(!t)return;const r=Array.from(t.highPriority.keys()),n=Array.from(t.regular.keys());for(var i=arguments.length,o=new Array(i>1?i-1:0),a=1;a=0;s-=1){const e=r[s];t.highPriority.has(e)&&e.apply(this,o)}for(let s=0;s{const r=e.getNode(t),n=e.getNavigableChildrenIds(r.parentId),i=n.indexOf(t);if(0===i)return r.parentId;let o=n[i-1];for(;e.isNodeExpanded(o)&&e.getNavigableChildrenIds(o).length>0;)o=e.getNavigableChildrenIds(o).pop();return o},kQ=(e,t)=>{if(e.isNodeExpanded(t)&&e.getNavigableChildrenIds(t).length>0)return e.getNavigableChildrenIds(t)[0];let r=e.getNode(t);for(;null!=r;){const t=e.getNavigableChildrenIds(r.parentId),n=t[t.indexOf(r.id)+1];if(n)return n;r=e.getNode(r.parentId)}return null},SQ=e=>{let t=e.getNavigableChildrenIds(null).pop();for(;e.isNodeExpanded(t);)t=e.getNavigableChildrenIds(t).pop();return t},AQ=e=>e.getNavigableChildrenIds(null)[0],TQ=(e,t)=>{Object.assign(e,t)},MQ=[e=>{let{instance:t}=e;const[r]=n.useState((()=>new _Q)),i=n.useCallback((function(){for(var e=arguments.length,t=new Array(e),n=0;nvoid 0!==e.isPropagationStopped)(a)&&a.isPropagationStopped()||r.emit(i,o,a)}),[r]),o=n.useCallback(((e,t)=>(r.on(e,t),()=>{r.removeListener(e,t)})),[r]);TQ(t,{$$publishEvent:i,$$subscribeEvent:o})}],CQ=e=>{const t=[...MQ,...e.plugins],r=t.reduce(((e,t)=>t.getDefaultizedParams?t.getDefaultizedParams(e):e),e),i=((e,t)=>{const r=n.useRef({}),[i,o]=n.useState((()=>{const n={};return e.forEach((e=>{e.models&&Object.entries(e.models).forEach((e=>{let[i,o]=e;r.current[i]={controlledProp:o.controlledProp,defaultProp:o.defaultProp,isControlled:void 0!==t[o.controlledProp]},n[i]=t[o.defaultProp]}))})),n}));return Object.fromEntries(Object.entries(r.current).map((e=>{let[r,n]=e;const a=n.isControlled?t[n.controlledProp]:i[r];return[r,{value:a,setValue:e=>{n.isControlled||o((t=>(0,O.A)({},t,{[r]:e})))}}]})))})(t,r),o=n.useRef({}).current,a=n.useRef(null),s=(0,Gi.A)(a,e.rootRef),[l,c]=n.useState((()=>{const e={};return t.forEach((t=>{t.getInitialState&&Object.assign(e,t.getInitialState(r))})),e})),u=[];let d=tQ;t.forEach((e=>{const t=e({instance:o,params:r,state:l,setState:c,rootRef:a,models:i})||{};t.getRootProps&&u.push(t.getRootProps),t.contextValue&&(d=t.contextValue)}));return{getRootProps:function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const t=(0,O.A)({role:"tree",tabIndex:0},e,{ref:s});return u.forEach((r=>{Object.assign(t,r(e))})),t},rootRef:s,contextValue:d}};function EQ(e){const{value:t,children:r}=e;return(0,j.jsx)(rQ.Provider,{value:t,children:(0,j.jsx)(eQ,{children:r})})}const IQ=e=>{let{instance:t,params:r,models:i}=e;const o=n.useCallback((e=>!!Array.isArray(i.expanded.value)&&-1!==i.expanded.value.indexOf(e)),[i.expanded.value]),a=n.useCallback((e=>{var r;return!(null==(r=t.getNode(e))||!r.expandable)}),[t]),s=(0,ea.A)(((e,t)=>{if(null==t)return;let n;n=-1!==i.expanded.value.indexOf(t)?i.expanded.value.filter((e=>e!==t)):[t].concat(i.expanded.value),r.onNodeToggle&&r.onNodeToggle(e,n),i.expanded.setValue(n)}));TQ(t,{isNodeExpanded:o,isNodeExpandable:a,toggleNodeExpansion:s,expandAllSiblings:(e,n)=>{const o=t.getNode(n),a=t.getChildrenIds(o.parentId).filter((e=>t.isNodeExpandable(e)&&!t.isNodeExpanded(e))),s=i.expanded.value.concat(a);a.length>0&&(i.expanded.setValue(s),r.onNodeToggle&&r.onNodeToggle(e,s))}})};IQ.models={expanded:{controlledProp:"expanded",defaultProp:"defaultExpanded"}};const PQ=[];IQ.getDefaultizedParams=e=>{var t;return(0,O.A)({},e,{defaultExpanded:null!=(t=e.defaultExpanded)?t:PQ})};const OQ=e=>{let{instance:t,params:r,models:i}=e;const o=n.useRef(null),a=n.useRef(!1),s=n.useRef([]),l=(e,n)=>{let o=i.selected.value.slice();const{start:l,end:c}=n;a.current&&(o=o.filter((e=>-1===s.current.indexOf(e))));let u=((e,r)=>{const[n,i]=((e,t,r)=>{if(t===r)return[t,r];const n=e.getNode(t),i=e.getNode(r);if(n.parentId===i.id||i.parentId===n.id)return i.parentId===n.id?[n.id,i.id]:[i.id,n.id];const o=[n.id],a=[i.id];let s=n.parentId,l=i.parentId,c=-1!==a.indexOf(s),u=-1!==o.indexOf(l),d=!0,h=!0;for(;!u&&!c;)d&&(o.push(s),c=-1!==a.indexOf(s),d=null!==s,!c&&d&&(s=e.getNode(s).parentId)),h&&!c&&(a.push(l),u=-1!==o.indexOf(l),h=null!==l,!u&&h&&(l=e.getNode(l).parentId));const p=c?s:l,f=e.getChildrenIds(p),m=o[o.indexOf(p)-1],g=a[a.indexOf(p)-1];return f.indexOf(m)!t.isNodeDisabled(e))),s.current=u;let d=o.concat(u);d=d.filter(((e,t)=>d.indexOf(e)===t)),r.onNodeSelect&&r.onNodeSelect(e,d),i.selected.setValue(d)};return TQ(t,{isNodeSelected:e=>Array.isArray(i.selected.value)?-1!==i.selected.value.indexOf(e):i.selected.value===e,selectNode:function(e,t){let n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];if(!r.disableSelection){if(n){if(Array.isArray(i.selected.value)){let n;n=-1!==i.selected.value.indexOf(t)?i.selected.value.filter((e=>e!==t)):[t].concat(i.selected.value),r.onNodeSelect&&r.onNodeSelect(e,n),i.selected.setValue(n)}}else{const n=r.multiSelect?[t]:t;r.onNodeSelect&&r.onNodeSelect(e,n),i.selected.setValue(n)}o.current=t,a.current=!1,s.current=[]}},selectRange:function(e,t){let n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];if(r.disableSelection)return;const{start:c=o.current,end:u,current:d}=t;n?((e,t)=>{let n=i.selected.value.slice();const{start:o,next:l,current:c}=t;l&&c&&(-1===s.current.indexOf(c)&&(s.current=[]),a.current?-1!==s.current.indexOf(l)?(n=n.filter((e=>e===o||e!==c)),s.current=s.current.filter((e=>e===o||e!==c))):(n.push(l),s.current.push(l)):(n.push(l),s.current.push(c,l)),r.onNodeSelect&&r.onNodeSelect(e,n),i.selected.setValue(n))})(e,{start:c,next:u,current:d}):null!=c&&null!=u&&l(e,{start:c,end:u}),a.current=!0},rangeSelectToLast:(e,r)=>{o.current||(o.current=r);const n=a.current?o.current:r;t.selectRange(e,{start:n,end:SQ(t)})},rangeSelectToFirst:(e,r)=>{o.current||(o.current=r);const n=a.current?o.current:r;t.selectRange(e,{start:n,end:AQ(t)})}}),{getRootProps:()=>({"aria-multiselectable":r.multiSelect})}};OQ.models={selected:{controlledProp:"selected",defaultProp:"defaultSelected"}};const RQ=[];OQ.getDefaultizedParams=e=>{var t,r,n;return(0,O.A)({},e,{disableSelection:null!=(t=e.disableSelection)&&t,multiSelect:null!=(r=e.multiSelect)&&r,defaultSelected:null!=(n=e.defaultSelected)?n:e.multiSelect?RQ:null})};class LQ{constructor(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1e3;this.timeouts=new Map,this.cleanupTimeout=1e3,this.cleanupTimeout=e}register(e,t,r){this.timeouts||(this.timeouts=new Map);const n=setTimeout((()=>{"function"===typeof t&&t(),this.timeouts.delete(r.cleanupToken)}),this.cleanupTimeout);this.timeouts.set(r.cleanupToken,n)}unregister(e){const t=this.timeouts.get(e.cleanupToken);t&&(this.timeouts.delete(e.cleanupToken),clearTimeout(t))}reset(){this.timeouts&&(this.timeouts.forEach(((e,t)=>{this.unregister({cleanupToken:t})})),this.timeouts=void 0)}}class DQ{constructor(){this.registry=new FinalizationRegistry((e=>{"function"===typeof e&&e()}))}register(e,t,r){this.registry.register(e,t,r)}unregister(e){this.registry.unregister(e)}reset(){}}class zQ{}const jQ={registry:null},FQ=function(e){let t=0;return function(r,i,o){null===e.registry&&(e.registry="undefined"!==typeof FinalizationRegistry?new DQ:new LQ);const[a]=n.useState(new zQ),s=n.useRef(null),l=n.useRef();l.current=o;const c=n.useRef(null);if(!s.current&&l.current){const n=(e,t)=>{var r;t.defaultMuiPrevented||(null==(r=l.current)||r.call(l,e,t))};s.current=r.$$subscribeEvent(i,n),t+=1,c.current={cleanupToken:t},e.registry.register(a,(()=>{var e;null==(e=s.current)||e.call(s),s.current=null,c.current=null}),c.current)}else!l.current&&s.current&&(s.current(),s.current=null,c.current&&(e.registry.unregister(c.current),c.current=null));n.useEffect((()=>{if(!s.current&&l.current){const e=(e,t)=>{var r;t.defaultMuiPrevented||(null==(r=l.current)||r.call(l,e,t))};s.current=r.$$subscribeEvent(i,e)}return c.current&&e.registry&&(e.registry.unregister(c.current),c.current=null),()=>{var e;null==(e=s.current)||e.call(s),s.current=null}}),[r,i])}}(jQ),NQ=e=>{let{instance:t,params:r,state:i,setState:o,models:a,rootRef:s}=e;const l=(0,ea.A)((e=>{const t="function"===typeof e?e(i.focusedNodeId):e;o((e=>(0,O.A)({},e,{focusedNodeId:t})))})),c=n.useCallback((e=>i.focusedNodeId===e),[i.focusedNodeId]),u=(0,ea.A)(((e,t)=>{t&&(l(t),r.onNodeFocus&&r.onNodeFocus(e,t))}));TQ(t,{isNodeFocused:c,focusNode:u}),FQ(t,"removeNode",(e=>{let{id:r}=e;l((e=>e===r&&s.current===(0,No.A)(s.current).activeElement?t.getChildrenIds(null)[0]:e))}));const d=e=>r=>{var n;if(null==(n=e.onFocus)||n.call(e,r),r.target===r.currentTarget){const e=e=>{const r=t.getNode(e);return r&&(null==r.parentId||t.isNodeExpanded(r.parentId))};let n;Array.isArray(a.selected.value)?n=a.selected.value.find(e):null!=a.selected.value&&e(a.selected.value)&&(n=a.selected.value),null==n&&(n=t.getNavigableChildrenIds(null)[0]),t.focusNode(r,n)}},h=e=>t=>{var r;null==(r=e.onBlur)||r.call(e,t),l(null)},p=t.getNode(i.focusedNodeId),f=p?p.idAttribute:null;return{getRootProps:e=>({onFocus:d(e),onBlur:h(e),"aria-activedescendant":null!=f?f:void 0})}};function BQ(e,t,r){for(let n=t;n({focusedNodeId:null}),NQ.getDefaultizedParams=e=>{var t;return(0,O.A)({},e,{disabledItemsFocusable:null!=(t=e.disabledItemsFocusable)&&t})};const VQ=[e=>{let{instance:t,params:r}=e;const i=n.useRef({}),o=n.useCallback((e=>i.current[e]),[]),a=n.useCallback((e=>{i.current[e.id]=e}),[]),s=n.useCallback((e=>{const r=(0,O.A)({},i.current);delete r[e],i.current=r,((e,t,r)=>{e.$$publishEvent(t,r)})(t,"removeNode",{id:e})}),[t]),l=n.useCallback((e=>{if(null==e)return!1;let r=t.getNode(e);if(!r)return!1;if(r.disabled)return!0;for(;null!=r.parentId;)if(r=t.getNode(r.parentId),r.disabled)return!0;return!1}),[t]),c=(0,ea.A)((e=>Object.values(i.current).filter((t=>t.parentId===e)).sort(((e,t)=>e.index-t.index)).map((e=>e.id))));TQ(t,{getNode:o,updateNode:a,removeNode:s,getChildrenIds:c,getNavigableChildrenIds:e=>{let n=t.getChildrenIds(e);return r.disabledItemsFocusable||(n=n.filter((e=>!t.isNodeDisabled(e)))),n},isNodeDisabled:l})},IQ,OQ,NQ,e=>{let{instance:t,params:r,state:i}=e;const o="rtl"===Io().direction,a=n.useRef({}),s=(0,ea.A)(((e,t)=>(a.current[e]=t,()=>{const t=(0,O.A)({},a.current);delete t[e],a.current=t})));TQ(t,{mapFirstChar:s});const l=e=>(null!=i.focusedNodeId&&t.isNodeExpandable(i.focusedNodeId)&&(t.isNodeExpanded(i.focusedNodeId)?t.focusNode(e,kQ(t,i.focusedNodeId)):t.isNodeDisabled(i.focusedNodeId)||t.toggleNodeExpansion(e,i.focusedNodeId)),!0),c=e=>{if(null==i.focusedNodeId)return!1;if(t.isNodeExpanded(i.focusedNodeId)&&!t.isNodeDisabled(i.focusedNodeId))return t.toggleNodeExpansion(e,i.focusedNodeId),!0;const r=t.getNode(i.focusedNodeId).parentId;return!!r&&(t.focusNode(e,r),!0)},u=e=>n=>{var s;null==(s=e.onKeyDown)||s.call(e,n);let u=!1;const d=n.key;if(n.altKey||n.currentTarget!==n.target||null==i.focusedNodeId)return;const h=n.ctrlKey||n.metaKey;switch(d){case" ":r.disableSelection||t.isNodeDisabled(i.focusedNodeId)||(u=!0,r.multiSelect&&n.shiftKey?t.selectRange(n,{end:i.focusedNodeId}):r.multiSelect?t.selectNode(n,i.focusedNodeId,!0):t.selectNode(n,i.focusedNodeId)),n.stopPropagation();break;case"Enter":t.isNodeDisabled(i.focusedNodeId)||(t.isNodeExpandable(i.focusedNodeId)?(t.toggleNodeExpansion(n,i.focusedNodeId),u=!0):r.disableSelection||(u=!0,r.multiSelect?t.selectNode(n,i.focusedNodeId,!0):t.selectNode(n,i.focusedNodeId))),n.stopPropagation();break;case"ArrowDown":r.multiSelect&&n.shiftKey&&!r.disableSelection&&((e,r)=>{t.isNodeDisabled(kQ(t,r))||t.selectRange(e,{end:kQ(t,r),current:r},!0)})(n,i.focusedNodeId),t.focusNode(n,kQ(t,i.focusedNodeId)),u=!0;break;case"ArrowUp":r.multiSelect&&n.shiftKey&&!r.disableSelection&&((e,r)=>{t.isNodeDisabled(wQ(t,r))||t.selectRange(e,{end:wQ(t,r),current:r},!0)})(n,i.focusedNodeId),t.focusNode(n,wQ(t,i.focusedNodeId)),u=!0;break;case"ArrowRight":u=o?c(n):l(n);break;case"ArrowLeft":u=o?l(n):c(n);break;case"Home":r.multiSelect&&h&&n.shiftKey&&!r.disableSelection&&!t.isNodeDisabled(i.focusedNodeId)&&t.rangeSelectToFirst(n,i.focusedNodeId),t.focusNode(n,AQ(t)),u=!0;break;case"End":r.multiSelect&&h&&n.shiftKey&&!r.disableSelection&&!t.isNodeDisabled(i.focusedNodeId)&&t.rangeSelectToLast(n,i.focusedNodeId),t.focusNode(n,SQ(t)),u=!0;break;default:"*"===d?(t.expandAllSiblings(n,i.focusedNodeId),u=!0):r.multiSelect&&h&&"a"===d.toLowerCase()&&!r.disableSelection?(t.selectRange(n,{start:AQ(t),end:SQ(t)}),u=!0):!h&&!n.shiftKey&&((p=d)&&1===p.length&&p.match(/\S/))&&(((e,n,i)=>{let o,s;const l=i.toLowerCase(),c=[],u=[];Object.keys(a.current).forEach((e=>{const n=t.getNode(e),i=!n.parentId||t.isNodeExpanded(n.parentId),o=!r.disabledItemsFocusable&&t.isNodeDisabled(e);i&&!o&&(c.push(e),u.push(a.current[e]))})),o=c.indexOf(n)+1,o>=c.length&&(o=0),s=BQ(u,o,l),-1===s&&(s=BQ(u,0,l)),s>-1&&t.focusNode(e,c[s])})(n,i.focusedNodeId,d),u=!0)}var p;u&&(n.preventDefault(),n.stopPropagation())};return{getRootProps:e=>({onKeyDown:u(e)})}},e=>{let{instance:t,params:r}=e;const n=(0,zp.A)(r.id);return{getRootProps:()=>({id:n}),contextValue:{treeId:n,instance:t,multiSelect:r.multiSelect,disabledItemsFocusable:r.disabledItemsFocusable,icons:{defaultCollapseIcon:r.defaultCollapseIcon,defaultEndIcon:r.defaultEndIcon,defaultExpandIcon:r.defaultExpandIcon,defaultParentIcon:r.defaultParentIcon}}}}],UQ=["disabledItemsFocusable","expanded","defaultExpanded","onNodeToggle","onNodeFocus","disableSelection","defaultSelected","selected","multiSelect","onNodeSelect","id","defaultCollapseIcon","defaultEndIcon","defaultExpandIcon","defaultParentIcon","children"],HQ=(0,yn.Ay)("ul",{name:"MuiTreeView",slot:"Root",overridesResolver:(e,t)=>t.root})({padding:0,margin:0,listStyle:"none",outline:0}),$Q=n.forwardRef((function(e,t){const r=iF({props:e,name:"MuiTreeView"}),n=r,i=r,{disabledItemsFocusable:o,expanded:a,defaultExpanded:s,onNodeToggle:l,onNodeFocus:c,disableSelection:u,defaultSelected:d,selected:h,multiSelect:p,onNodeSelect:f,id:m,defaultCollapseIcon:g,defaultEndIcon:y,defaultExpandIcon:v,defaultParentIcon:x,children:b}=i,_=(0,R.A)(i,UQ),{getRootProps:w,contextValue:k}=CQ({disabledItemsFocusable:o,expanded:a,defaultExpanded:s,onNodeToggle:l,onNodeFocus:c,disableSelection:u,defaultSelected:d,selected:h,multiSelect:p,onNodeSelect:f,id:m,defaultCollapseIcon:g,defaultEndIcon:y,defaultExpandIcon:v,defaultParentIcon:x,plugins:VQ,rootRef:t}),S=(e=>{const{classes:t}=e;return(0,mn.A)({root:["root"]},bQ,t)})(r),A=xQ({elementType:HQ,externalSlotProps:{},externalForwardedProps:_,className:S.root,getSlotProps:w,ownerState:n});return(0,j.jsx)(EQ,{value:k,children:(0,j.jsx)(HQ,(0,O.A)({},A,{children:b}))})})),WQ=e=>t=>null!=t.filesTree[e]?t.filesTree[e]:void 0;function qQ(e){return e.map((e=>e.isdir?{path:e.path,name:e.name,isDir:!0,nodes:qQ(e.nodes),shape:e.shape}:{path:e.path,name:e.name,isDir:!1,shape:e.shape}))}function GQ(e,t){let r=null;for(const n of t){if(e===n.path){r=n;break}if(n.isDir&&(r=GQ(e,n.nodes),null!=r))break}return r}const YQ=(0,n.memo)((function(e){let{open:t,initialFilePath:r,onClickCancel:i,onClickOk:o,title:a,fileType:s=Lw.ALL,multiSelect:l}=e;(0,n.useEffect)((()=>{h(r)}),[r]);const{onOpenClearWorkflowIdDialog:c}=(0,n.useContext)(qJ),u=x(Uk),[d,h]=(0,n.useState)(r),p=()=>{h(r),i()},f=Io();return(0,j.jsxs)(Wp,{open:t,onClose:p,fullWidth:!0,children:[(0,j.jsx)(Zp,{children:null!==a&&void 0!==a?a:"Select File"}),(0,j.jsxs)(ef,{dividers:!0,children:[(0,j.jsx)("div",{style:{height:300,overflow:"auto",marginBottom:f.spacing(1),border:"1px solid",padding:f.spacing(1),borderColor:f.palette.divider},children:(0,j.jsx)(XQ,{setSelectedFilePath:h,multiSelect:l,fileType:s,selectedFilePath:d})}),(0,j.jsx)(Hi,{variant:"subtitle1",children:Array.isArray(d)&&0===d.length?"No Selected File":"Selected File"}),(0,j.jsx)(JQ,{path:d,setSelectedFilePath:h})]}),(0,j.jsxs)(of,{children:[(0,j.jsx)(gf,{onClick:p,variant:"outlined",children:"cancel"}),(0,j.jsx)(gf,{onClick:()=>{null!=u?c({open:!0,handleOk:()=>{o(d)},handleCancel:()=>p()}):o(d)},variant:"contained",children:"OK"})]})]})})),XQ=(0,n.memo)((function(e){let{setSelectedFilePath:t,selectedFilePath:r,fileType:i,multiSelect:o}=e;const[a,s]=function(e){const t=C(),r=x((e=>t=>{var r;return null===(r=WQ(e)(t))||void 0===r?void 0:r.tree})(e)),i=x((e=>t=>{var r,n;return null!==(r=null===(n=WQ(e)(t))||void 0===n?void 0:n.isLatest)&&void 0!==r&&r})(e)),o=x((e=>t=>{var r,n;return null!==(r=null===(n=WQ(e)(t))||void 0===n?void 0:n.isLoading)&&void 0!==r&&r})(e)),a=x(jf);return(0,n.useEffect)((()=>{!a||i||o||t(zw({workspaceId:a,fileType:e}))}),[a,i,o,e,t]),[r,o]}(i),[l,c]=(0,n.useState)(!1),u=(e,t)=>{if(!t)return!1;const r=t=>t.path===e||!(!t.isDir||!t.nodes)&&t.nodes.some(r);return t.some(r)};(0,n.useEffect)((()=>{if(!l&&a){if(Array.isArray(r)){const e=r.filter((e=>u(e,a)));e.length!==r.length&&t(e)}else r&&!u(r,a)&&t([]);c(!0)}}),[a,l,r,t]);const d=e=>{Array.isArray(r)&&(r.includes(e)?t(r.filter((t=>e!==t))):t(r.concat(e)))},h=(e,n)=>{if(null!=a&&Array.isArray(r)){const i=GQ(e,a);if(null!=i&&i.isDir){const e=i.nodes.filter((e=>!e.isDir)).map((e=>e.path));t(n?Array.from(new Set(r.concat(e))):r.filter((t=>!e.includes(t))))}}};return(0,j.jsxs)("div",{children:[s&&(0,j.jsx)(qZ,{}),i===Lw.IMAGE?(0,j.jsxs)(j.Fragment,{children:[(0,j.jsxs)(yi,{sx:{display:"flex"},children:[(0,j.jsx)(Hi,{sx:{width:"50%"},children:"Files"}),(0,j.jsx)(Hi,{sx:{minWidth:"35%"},marginLeft:2,children:"Shapes"}),(0,j.jsx)(yi,{})]}),(0,j.jsx)(yU,{})]}):null,(0,j.jsx)($Q,{disableSelection:o,multiSelect:o,onNodeSelect:(e,r)=>{if(!o&&null!=a){const e=r;(function(e,t){const r=GQ(e,t);if(null!=r)return r.isDir;throw new Error(`failed to get node: ${e}`)})(e,a)||t(e)}},children:null===a||void 0===a?void 0:a.map((e=>(0,j.jsx)(ZQ,{fileType:i,node:e,selectedFilePath:r,multiSelect:o,onCheckDir:h,onCheckFile:d,setSelectedFilePath:t},e.name)))})]})})),ZQ=(0,n.memo)((function e(t){let{fileType:r,node:n,selectedFilePath:i,multiSelect:o,onCheckDir:a,onCheckFile:s,setSelectedFilePath:l}=t;if(n.isDir){const t=Array.isArray(i)&&n.nodes.filter((e=>!e.isDir)).map((e=>e.path)).every((e=>i.includes(e))),c=Array.isArray(i)&&n.nodes.filter((e=>!e.isDir)).map((e=>e.path)).every((e=>!i.includes(e))),u=!(t||c);return(0,j.jsx)(hQ,{icon:(0,j.jsx)(YJ.A,{htmlColor:"skyblue"}),nodeId:n.path,label:o&&n.nodes.filter((e=>!e.isDir)).length>0?(0,j.jsx)(KQ,{isDir:n.isDir,fileType:r,shape:n.shape,label:n.name,checkboxProps:{indeterminate:u,checked:t,onClick:e=>{e.stopPropagation()},onChange:e=>a(n.path,e.target.checked)},setSelectedFilePath:l,selectedFilePath:i}):n.name,children:n.nodes.map(((t,n)=>(0,j.jsx)(e,{fileType:r,node:t,selectedFilePath:i,multiSelect:o,onCheckDir:a,onCheckFile:s,setSelectedFilePath:l},n)))})}return(0,j.jsx)(hQ,{icon:(0,j.jsx)(XJ.A,{fontSize:"small"}),nodeId:n.path,label:o?(0,j.jsx)(KQ,{isDir:n.isDir,fileType:r,shape:n.shape,label:n.name,checkboxProps:{checked:Array.isArray(i)&&i.includes(n.path),onChange:()=>s(n.path)},setSelectedFilePath:l,selectedFilePath:i}):n.name})})),KQ=(0,n.memo)((function(e){let{fileType:t,shape:r,label:i,isDir:o,checkboxProps:a,setSelectedFilePath:s,selectedFilePath:l}=e;const c=C(),u=x(jf),[d,h]=(0,n.useState)(!1),p=(0,n.useCallback)(((e,t)=>{u&&(e.stopPropagation(),c(Vw({workspaceId:u,fileName:t})))}),[c,u]),f=(0,n.useCallback)((e=>{u&&(e.stopPropagation(),h(!0))}),[u]),m=(0,n.useCallback)(((e,r)=>{u&&(e.stopPropagation(),Array.isArray(l)&&s(l.filter((e=>e!==r))),c(jw({workspaceId:u,fileName:r,fileType:t})))}),[c,t,l,s,u]);return(0,j.jsxs)(yi,{sx:{"&:hover":{backgroundColor:"transparent"},cursor:"default"},children:[(0,j.jsxs)(yi,{height:24,display:"flex",alignItems:"center",children:[(0,j.jsx)(Mp,{title:(0,j.jsx)("span",{style:{fontSize:14},children:i}),placement:"left-start",children:(0,j.jsx)(yi,{sx:{width:"48%",textOverflow:"ellipsis",overflowX:"hidden",whiteSpace:"pre"},children:i})}),t===Lw.IMAGE?(0,j.jsx)(j.Fragment,{children:(0,j.jsx)(yi,{minWidth:175,marginLeft:2,alignItems:"center",children:o?null:r?`(${r.join(", ")})`:(0,j.jsx)(Mp,{title:(0,j.jsx)("span",{style:{fontSize:14},children:"parsing image shape failed"}),placement:"right",children:(0,j.jsx)(fY.A,{color:"error"})})})}):null,(0,j.jsx)(yi,{children:(0,j.jsx)(WU,{...a,disableRipple:!0,size:"small",sx:{marginRight:"4px",padding:"2px",minWidth:24}})}),o?(0,j.jsx)(yi,{width:24,marginRight:2}):(0,j.jsx)(oi,{sx:{minWidth:24},onClick:e=>p(e,i),children:(0,j.jsx)(GJ.A,{})}),(0,j.jsx)(oi,{sx:{minWidth:24},color:"error",onClick:e=>{f(e)},disabled:a.checked,"data-testid":"DeleteIconBtn",children:(0,j.jsx)(SI.A,{})})]}),(0,j.jsx)(Cf,{open:d,setOpen:h,onConfirm:()=>{m({stopPropagation:()=>{}},i),h(!1)},title:"Are you sure you want to delete this item?",content:`${i}`,confirmLabel:"delete",iconType:"warning"})]})})),JQ=(0,n.memo)((function(e){let{path:t,setSelectedFilePath:r}=e;return(0,j.jsx)(Hi,{variant:"subtitle2",children:t?Array.isArray(t)?(0,j.jsx)("ul",{style:{padding:0,margin:0,listStyleType:"none"},children:t.map((e=>(0,j.jsx)("li",{style:{marginBottom:"3px",listStyleType:"disc",marginLeft:"24px"},children:(0,j.jsxs)("span",{style:{display:"flex",justifyContent:"space-between",width:"100%"},children:[(0,j.jsx)("span",{children:e}),(0,j.jsx)(oi,{style:{padding:"0"},onClick:()=>{return n=e,void(Array.isArray(t)&&r(t.filter((e=>e!==n))));var n},children:(0,j.jsx)(pn.A,{style:{width:"15px",height:"15px"}})})]})},e)))}):t:"---"})}));var QQ=r(122);const e0="undefined"!==typeof window?n.useLayoutEffect:n.useEffect;function t0(e,t,r){const[i,o]=function(e,t,r){const[i,o]=(0,n.useState)((()=>t(e))),a=(0,n.useCallback)((()=>{const n=t(e);QQ(i,n)||(o(n),r&&r())}),[i,e,r]);return e0(a),[i,a]}(e,t,r);return e0((function(){const t=e.getHandlerId();if(null!=t)return e.subscribeToStateChange(o,{handlerIds:[t]})}),[e,o]),i}function r0(e,t,r){return t0(t,e||(()=>({})),(()=>r.reconnect()))}function n0(e,t){const r=[...t||[]];return null==t&&"function"!==typeof e&&r.push(e),(0,n.useMemo)((()=>"function"===typeof e?e():e),r)}function i0(e){return(0,n.useMemo)((()=>e.hooks.dropTarget()),[e])}function o0(e,t,r,n){let i=r?r.call(n,e,t):void 0;if(void 0!==i)return!!i;if(e===t)return!0;if("object"!==typeof e||!e||"object"!==typeof t||!t)return!1;const o=Object.keys(e),a=Object.keys(t);if(o.length!==a.length)return!1;const s=Object.prototype.hasOwnProperty.bind(t);for(let l=0;l0&&void 0!==arguments[0]?arguments[0]:null,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;if(!(0,n.isValidElement)(t)){const n=t;return e(n,r),n}const i=t;!function(e){if("string"===typeof e.type)return;const t=e.type.displayName||e.type.name||"the component";throw new Error(`Only native element nodes can now be passed to React DnD connectors.You can either wrap ${t} into a
, or turn it into a drag source or a drop target itself.`)}(i);return function(e,t){const r=e.ref;return UY("string"!==typeof r,"Cannot connect React DnD to an element with an existing string ref. Please convert it to use a callback ref instead, or wrap it into a or
. Read more: https://reactjs.org/docs/refs-and-the-dom.html#callback-refs"),r?(0,n.cloneElement)(e,{ref:e=>{c0(r,e),c0(t,e)}}):(0,n.cloneElement)(e,{ref:t})}(i,r?t=>e(t,r):e)}}function l0(e){const t={};return Object.keys(e).forEach((r=>{const n=e[r];if(r.endsWith("Ref"))t[r]=e[r];else{const e=s0(n);t[r]=()=>e}})),t}function c0(e,t){"function"===typeof e?e(t):e.current=t}class u0{get connectTarget(){return this.dropTarget}reconnect(){const e=this.didHandlerIdChange()||this.didDropTargetChange()||this.didOptionsChange();e&&this.disconnectDropTarget();const t=this.dropTarget;this.handlerId&&(t?e&&(this.lastConnectedHandlerId=this.handlerId,this.lastConnectedDropTarget=t,this.lastConnectedDropTargetOptions=this.dropTargetOptions,this.unsubscribeDropTarget=this.backend.connectDropTarget(this.handlerId,t,this.dropTargetOptions)):this.lastConnectedDropTarget=t)}receiveHandlerId(e){e!==this.handlerId&&(this.handlerId=e,this.reconnect())}get dropTargetOptions(){return this.dropTargetOptionsInternal}set dropTargetOptions(e){this.dropTargetOptionsInternal=e}didHandlerIdChange(){return this.lastConnectedHandlerId!==this.handlerId}didDropTargetChange(){return this.lastConnectedDropTarget!==this.dropTarget}didOptionsChange(){return!o0(this.lastConnectedDropTargetOptions,this.dropTargetOptions)}disconnectDropTarget(){this.unsubscribeDropTarget&&(this.unsubscribeDropTarget(),this.unsubscribeDropTarget=void 0)}get dropTarget(){return this.dropTargetNode||this.dropTargetRef&&this.dropTargetRef.current}clearDropTarget(){this.dropTargetRef=null,this.dropTargetNode=null}constructor(e){this.hooks=l0({dropTarget:(e,t)=>{this.clearDropTarget(),this.dropTargetOptions=t,a0(e)?this.dropTargetRef=e:this.dropTargetNode=e,this.reconnect()}}),this.handlerId=null,this.dropTargetRef=null,this.dropTargetOptionsInternal=null,this.lastConnectedHandlerId=null,this.lastConnectedDropTarget=null,this.lastConnectedDropTargetOptions=null,this.backend=e}}function d0(){const{dragDropManager:e}=(0,n.useContext)(WX);return UY(null!=e,"Expected drag drop context"),e}let h0=!1;class p0{receiveHandlerId(e){this.targetId=e}getHandlerId(){return this.targetId}subscribeToStateChange(e,t){return this.internalMonitor.subscribeToStateChange(e,t)}canDrop(){if(!this.targetId)return!1;UY(!h0,"You may not call monitor.canDrop() inside your canDrop() implementation. Read more: http://react-dnd.github.io/react-dnd/docs/api/drop-target-monitor");try{return h0=!0,this.internalMonitor.canDropOnTarget(this.targetId)}finally{h0=!1}}isOver(e){return!!this.targetId&&this.internalMonitor.isOverTarget(this.targetId,e)}getItemType(){return this.internalMonitor.getItemType()}getItem(){return this.internalMonitor.getItem()}getDropResult(){return this.internalMonitor.getDropResult()}didDrop(){return this.internalMonitor.didDrop()}getInitialClientOffset(){return this.internalMonitor.getInitialClientOffset()}getInitialSourceClientOffset(){return this.internalMonitor.getInitialSourceClientOffset()}getSourceClientOffset(){return this.internalMonitor.getSourceClientOffset()}getClientOffset(){return this.internalMonitor.getClientOffset()}getDifferenceFromInitialOffset(){return this.internalMonitor.getDifferenceFromInitialOffset()}constructor(e){this.targetId=null,this.internalMonitor=e.getMonitor()}}class f0{canDrop(){const e=this.spec,t=this.monitor;return!e.canDrop||e.canDrop(t.getItem(),t)}hover(){const e=this.spec,t=this.monitor;e.hover&&e.hover(t.getItem(),t)}drop(){const e=this.spec,t=this.monitor;if(e.drop)return e.drop(t.getItem(),t)}constructor(e,t){this.spec=e,this.monitor=t}}function m0(e,t,r){const i=d0(),o=function(e,t){const r=(0,n.useMemo)((()=>new f0(e,t)),[t]);return(0,n.useEffect)((()=>{r.spec=e}),[e]),r}(e,t),a=function(e){const{accept:t}=e;return(0,n.useMemo)((()=>(UY(null!=e.accept,"accept must be defined"),Array.isArray(t)?t:[t])),[t])}(e);e0((function(){const[e,n]=function(e,t,r){const n=r.getRegistry(),i=n.addTarget(e,t);return[i,()=>n.removeTarget(i)]}(a,o,i);return t.receiveHandlerId(e),r.receiveHandlerId(e),n}),[i,t,o,r,a.map((e=>e.toString())).join("|")])}function g0(e,t){const r=n0(e,t),i=function(){const e=d0();return(0,n.useMemo)((()=>new p0(e)),[e])}(),o=function(e){const t=d0(),r=(0,n.useMemo)((()=>new u0(t.getBackend())),[t]);return e0((()=>(r.dropTargetOptions=e||null,r.reconnect(),()=>r.disconnectDropTarget())),[e]),r}(r.options);return m0(r,i,o),[r0(r.collect,i,o),i0(o)]}function y0(){return n.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 32 32"},n.createElement("path",{d:"M32 18.133H18.133V32h-4.266V18.133H0v-4.266h13.867V0h4.266v13.867H32z"}))}function v0(){return n.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 32 5"},n.createElement("path",{d:"M0 0h32v4.2H0z"}))}function x0(){return n.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 32 30"},n.createElement("path",{d:"M3.692 4.63c0-.53.4-.938.939-.938h5.215V0H4.708C2.13 0 0 2.054 0 4.63v5.216h3.692V4.631zM27.354 0h-5.2v3.692h5.17c.53 0 .984.4.984.939v5.215H32V4.631A4.624 4.624 0 0027.354 0zm.954 24.83c0 .532-.4.94-.939.94h-5.215v3.768h5.215c2.577 0 4.631-2.13 4.631-4.707v-5.139h-3.692v5.139zm-23.677.94c-.531 0-.939-.4-.939-.94v-5.138H0v5.139c0 2.577 2.13 4.707 4.708 4.707h5.138V25.77H4.631z"}))}function b0(){return n.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 25 32"},n.createElement("path",{d:"M21.333 10.667H19.81V7.619C19.81 3.429 16.38 0 12.19 0 8 0 4.571 3.429 4.571 7.619v3.048H3.048A3.056 3.056 0 000 13.714v15.238A3.056 3.056 0 003.048 32h18.285a3.056 3.056 0 003.048-3.048V13.714a3.056 3.056 0 00-3.048-3.047zM12.19 24.533a3.056 3.056 0 01-3.047-3.047 3.056 3.056 0 013.047-3.048 3.056 3.056 0 013.048 3.048 3.056 3.056 0 01-3.048 3.047zm4.724-13.866H7.467V7.619c0-2.59 2.133-4.724 4.723-4.724 2.591 0 4.724 2.133 4.724 4.724v3.048z"}))}function _0(){return n.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 25 32"},n.createElement("path",{d:"M21.333 10.667H19.81V7.619C19.81 3.429 16.38 0 12.19 0c-4.114 1.828-1.37 2.133.305 2.438 1.676.305 4.42 2.59 4.42 5.181v3.048H3.047A3.056 3.056 0 000 13.714v15.238A3.056 3.056 0 003.048 32h18.285a3.056 3.056 0 003.048-3.048V13.714a3.056 3.056 0 00-3.048-3.047zM12.19 24.533a3.056 3.056 0 01-3.047-3.047 3.056 3.056 0 013.047-3.048 3.056 3.056 0 013.048 3.048 3.056 3.056 0 01-3.048 3.047z"}))}const w0=e=>{let{children:t,className:r,...i}=e;return n.createElement("button",{type:"button",className:lm(["react-flow__controls-button",r]),...i},t)};w0.displayName="ControlButton";const k0=e=>({isInteractive:e.nodesDraggable||e.nodesConnectable||e.elementsSelectable,minZoomReached:e.transform[2]<=e.minZoom,maxZoomReached:e.transform[2]>=e.maxZoom}),S0=e=>{let{style:t,showZoom:r=!0,showFitView:i=!0,showInteractive:o=!0,fitViewOptions:a,onZoomIn:s,onZoomOut:l,onFitView:c,onInteractiveChange:u,className:d,children:h,position:p="bottom-left"}=e;const f=Ev(),[m,g]=(0,n.useState)(!1),{isInteractive:y,minZoomReached:v,maxZoomReached:x}=Cv(k0,gm),{zoomIn:b,zoomOut:_,fitView:w}=Fb();if((0,n.useEffect)((()=>{g(!0)}),[]),!m)return null;return n.createElement(Pv,{className:lm(["react-flow__controls",d]),position:p,style:t,"data-testid":"rf__controls"},r&&n.createElement(n.Fragment,null,n.createElement(w0,{onClick:()=>{b(),s?.()},className:"react-flow__controls-zoomin",title:"zoom in","aria-label":"zoom in",disabled:x},n.createElement(y0,null)),n.createElement(w0,{onClick:()=>{_(),l?.()},className:"react-flow__controls-zoomout",title:"zoom out","aria-label":"zoom out",disabled:v},n.createElement(v0,null))),i&&n.createElement(w0,{className:"react-flow__controls-fitview",onClick:()=>{w(a),c?.()},title:"fit view","aria-label":"fit view"},n.createElement(x0,null)),o&&n.createElement(w0,{className:"react-flow__controls-interactive",onClick:()=>{f.setState({nodesDraggable:!y,nodesConnectable:!y,elementsSelectable:!y}),u?.(!y)},title:"toggle interactivity","aria-label":"toggle interactivity"},y?n.createElement(_0,null):n.createElement(b0,null)),h)};S0.displayName="Controls";var A0=(0,n.memo)(S0);const T0="TREE_ITEM";var M0=r(27385),C0=r(1528);function E0(e){return(0,Yn.Ay)("MuiButtonGroup",e)}const I0=(0,Ln.A)("MuiButtonGroup",["root","contained","outlined","text","disableElevation","disabled","firstButton","fullWidth","vertical","grouped","groupedHorizontal","groupedVertical","groupedText","groupedTextHorizontal","groupedTextVertical","groupedTextPrimary","groupedTextSecondary","groupedOutlined","groupedOutlinedHorizontal","groupedOutlinedVertical","groupedOutlinedPrimary","groupedOutlinedSecondary","groupedContained","groupedContainedHorizontal","groupedContainedVertical","groupedContainedPrimary","groupedContainedSecondary","lastButton","middleButton"]),P0=["children","className","color","component","disabled","disableElevation","disableFocusRipple","disableRipple","fullWidth","orientation","size","variant"],O0=(0,yn.Ay)("div",{name:"MuiButtonGroup",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[{[`& .${I0.grouped}`]:t.grouped},{[`& .${I0.grouped}`]:t[`grouped${(0,ei.A)(r.orientation)}`]},{[`& .${I0.grouped}`]:t[`grouped${(0,ei.A)(r.variant)}`]},{[`& .${I0.grouped}`]:t[`grouped${(0,ei.A)(r.variant)}${(0,ei.A)(r.orientation)}`]},{[`& .${I0.grouped}`]:t[`grouped${(0,ei.A)(r.variant)}${(0,ei.A)(r.color)}`]},{[`& .${I0.firstButton}`]:t.firstButton},{[`& .${I0.lastButton}`]:t.lastButton},{[`& .${I0.middleButton}`]:t.middleButton},t.root,t[r.variant],!0===r.disableElevation&&t.disableElevation,r.fullWidth&&t.fullWidth,"vertical"===r.orientation&&t.vertical]}})((e=>{let{theme:t,ownerState:r}=e;return(0,O.A)({display:"inline-flex",borderRadius:(t.vars||t).shape.borderRadius},"contained"===r.variant&&{boxShadow:(t.vars||t).shadows[2]},r.disableElevation&&{boxShadow:"none"},r.fullWidth&&{width:"100%"},"vertical"===r.orientation&&{flexDirection:"column"},{[`& .${I0.grouped}`]:(0,O.A)({minWidth:40,"&:hover":(0,O.A)({},"contained"===r.variant&&{boxShadow:"none"})},"contained"===r.variant&&{boxShadow:"none"}),[`& .${I0.firstButton},& .${I0.middleButton}`]:(0,O.A)({},"horizontal"===r.orientation&&{borderTopRightRadius:0,borderBottomRightRadius:0},"vertical"===r.orientation&&{borderBottomRightRadius:0,borderBottomLeftRadius:0},"text"===r.variant&&"horizontal"===r.orientation&&{borderRight:t.vars?`1px solid rgba(${t.vars.palette.common.onBackgroundChannel} / 0.23)`:"1px solid "+("light"===t.palette.mode?"rgba(0, 0, 0, 0.23)":"rgba(255, 255, 255, 0.23)"),[`&.${I0.disabled}`]:{borderRight:`1px solid ${(t.vars||t).palette.action.disabled}`}},"text"===r.variant&&"vertical"===r.orientation&&{borderBottom:t.vars?`1px solid rgba(${t.vars.palette.common.onBackgroundChannel} / 0.23)`:"1px solid "+("light"===t.palette.mode?"rgba(0, 0, 0, 0.23)":"rgba(255, 255, 255, 0.23)"),[`&.${I0.disabled}`]:{borderBottom:`1px solid ${(t.vars||t).palette.action.disabled}`}},"text"===r.variant&&"inherit"!==r.color&&{borderColor:t.vars?`rgba(${t.vars.palette[r.color].mainChannel} / 0.5)`:(0,gn.X4)(t.palette[r.color].main,.5)},"outlined"===r.variant&&"horizontal"===r.orientation&&{borderRightColor:"transparent"},"outlined"===r.variant&&"vertical"===r.orientation&&{borderBottomColor:"transparent"},"contained"===r.variant&&"horizontal"===r.orientation&&{borderRight:`1px solid ${(t.vars||t).palette.grey[400]}`,[`&.${I0.disabled}`]:{borderRight:`1px solid ${(t.vars||t).palette.action.disabled}`}},"contained"===r.variant&&"vertical"===r.orientation&&{borderBottom:`1px solid ${(t.vars||t).palette.grey[400]}`,[`&.${I0.disabled}`]:{borderBottom:`1px solid ${(t.vars||t).palette.action.disabled}`}},"contained"===r.variant&&"inherit"!==r.color&&{borderColor:(t.vars||t).palette[r.color].dark},{"&:hover":(0,O.A)({},"outlined"===r.variant&&"horizontal"===r.orientation&&{borderRightColor:"currentColor"},"outlined"===r.variant&&"vertical"===r.orientation&&{borderBottomColor:"currentColor"})}),[`& .${I0.lastButton},& .${I0.middleButton}`]:(0,O.A)({},"horizontal"===r.orientation&&{borderTopLeftRadius:0,borderBottomLeftRadius:0},"vertical"===r.orientation&&{borderTopRightRadius:0,borderTopLeftRadius:0},"outlined"===r.variant&&"horizontal"===r.orientation&&{marginLeft:-1},"outlined"===r.variant&&"vertical"===r.orientation&&{marginTop:-1})})})),R0=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiButtonGroup"}),{children:i,className:o,color:a="primary",component:s="div",disabled:l=!1,disableElevation:c=!1,disableFocusRipple:u=!1,disableRipple:d=!1,fullWidth:h=!1,orientation:p="horizontal",size:f="medium",variant:m="outlined"}=r,g=(0,R.A)(r,P0),y=(0,O.A)({},r,{color:a,component:s,disabled:l,disableElevation:c,disableFocusRipple:u,disableRipple:d,fullWidth:h,orientation:p,size:f,variant:m}),v=(e=>{const{classes:t,color:r,disabled:n,disableElevation:i,fullWidth:o,orientation:a,variant:s}=e,l={root:["root",s,"vertical"===a&&"vertical",o&&"fullWidth",i&&"disableElevation"],grouped:["grouped",`grouped${(0,ei.A)(a)}`,`grouped${(0,ei.A)(s)}`,`grouped${(0,ei.A)(s)}${(0,ei.A)(a)}`,`grouped${(0,ei.A)(s)}${(0,ei.A)(r)}`,n&&"disabled"],firstButton:["firstButton"],lastButton:["lastButton"],middleButton:["middleButton"]};return(0,mn.A)(l,E0,t)})(y),x=n.useMemo((()=>({className:v.grouped,color:a,disabled:l,disableElevation:c,disableFocusRipple:u,disableRipple:d,fullWidth:h,size:f,variant:m})),[a,l,c,u,d,h,f,m,v.grouped]),b=function(e){return n.Children.toArray(e).filter((e=>n.isValidElement(e)))}(i),_=b.length,w=e=>{const t=0===e,r=e===_-1;return t&&r?"":t?v.firstButton:r?v.lastButton:v.middleButton};return(0,j.jsx)(O0,(0,O.A)({as:s,role:"group",className:(0,fn.A)(v.root,o),ref:t,ownerState:y},g,{children:(0,j.jsx)(cf.Provider,{value:x,children:b.map(((e,t)=>(0,j.jsx)(uf.Provider,{value:w(t),children:e},t)))})}))}));function L0(e,t,r){return`${e}--${t}--${r}`}function D0(e){return e.split("--")[2]}function z0(e){if(null!=e.sourceHandle&&null!=e.targetHandle){const t=D0(e.sourceHandle),r=D0(e.targetHandle);return"SpikingActivityData"===t?"FluoData"===r||"SpikingActivityData"===r:t===r}return!0}function j0(e){var t;return x((t=e,e=>null!=e.handleColor.colorMap[t]?e.handleColor.colorMap[t]:void 0))}const F0=e=>{let{children:t,nodeId:r,selected:n,updated:i}=e;const o=Io();let a;return i?a=OI(o.palette.warning.light,n?.3:.1):n&&(a=OI(o.palette.primary.light,.2)),(0,j.jsxs)("div",{style:{height:"100%",width:"100%",background:a,display:"flex",flexDirection:"column"},children:[(0,j.jsx)(yi,{margin:1,marginBottom:0,children:t}),(0,j.jsx)(Mp,{title:r,placement:"bottom-start",children:(0,j.jsx)(Hi,{marginX:1,marginTop:"auto",marginBottom:"4px",color:vZ.A[600],fontSize:14,variant:"body2",overflow:"ellipsis",children:r})})]})};function N0(e){return"child"===e.type}function B0(e,t){let r=null;for(const[n,i]of Object.entries(e))if(N0(i)?n===t&&(r=i):r=B0(i.children,t),null!=r)break;return r}function V0(e){const t={};return Object.entries(e).forEach((e=>{let[r,n]=e;if(Object.prototype.hasOwnProperty.call(n,"children"))t[r]={type:"parent",children:V0(n.children)};else{const e=n;t[r]={type:"child",functionPath:e.path,args:e.args,returns:e.returns}}})),t}const U0=e=>e.algorithmList,H0=e=>U0(e).isLatest,$0=e=>U0(e).tree,W0="none",q0="nwb",G0="paramForm",Y0="snakemake",X0={open:!1,mode:W0,currendNodeId:null},Z0=Pl({name:"rightDrawer",initialState:X0,reducers:{openRightDrawer:(e,t)=>{e.open=!0,e.mode=t.payload},closeRightDrawer:e=>{e.open=!1,e.mode=W0},toggleParamForm:(e,t)=>{e.open&&e.mode===G0&&e.currendNodeId===t.payload?(e.open=!1,e.mode=W0,e.currendNodeId=null):(e.open=!0,e.mode=G0,e.currendNodeId=t.payload)},toggleNwb:e=>{e.open&&e.mode===q0?(e.open=!1,e.mode=W0):(e.open=!0,e.mode=q0),e.currendNodeId=null},toggleSnakemake:e=>{e.open&&e.mode===Y0?(e.open=!1,e.mode=W0):(e.open=!0,e.mode=Y0),e.currendNodeId=null}},extraReducers:e=>{e.addCase(xk,((e,t)=>{t.payload.findIndex((t=>t.id===e.currendNodeId))>0&&(e.currendNodeId=null)})).addCase(_k,((e,t)=>{t.payload===e.currendNodeId&&(e.currendNodeId=null)})).addMatcher(Bl(pk,ik.fulfilled,ok.fulfilled,nk.fulfilled,nk.rejected),(()=>X0))}}),{toggleParamForm:K0,toggleNwb:J0,toggleSnakemake:Q0,openRightDrawer:e1,closeRightDrawer:t1}=Z0.actions,r1=Z0.reducer,n1=(0,n.memo)((function(e){var t;return x((t=e.id,e=>Object.keys(e.algorithmNode).includes(t)))?(0,j.jsx)(i1,{...e}):null})),i1=(0,n.memo)((function(e){let{id:t,selected:r,isConnectable:i,data:o}=e;const{onOpenOutputDialog:a}=(0,n.useContext)(qJ),s=C(),l=p1(t),c=x(Uk),u=x(BY(t)),d=x(FJ(t)),h="undefined"!==typeof c&&(d||u);return(0,j.jsxs)(F0,{nodeId:t,selected:r,updated:!!h,children:[(0,j.jsx)("button",{className:"flowbutton",onClick:()=>{s(_k(t))},style:{color:"black",position:"absolute",top:-10,right:10},children:"\xd7"}),(0,j.jsx)(o1,{nodeId:t}),(0,j.jsxs)(Mf,{container:!0,paddingBottom:1,justifyContent:"space-between",children:[(0,j.jsx)(Mf,{item:!0,xs:10,children:(0,j.jsx)(a1,{nodeId:t,data:o})}),(0,j.jsx)(Mf,{item:!0,xs:2,children:(0,j.jsx)(d1,{nodeId:t})})]}),(0,j.jsxs)(R0,{children:[(0,j.jsx)(gf,{size:"small",onClick:()=>{s(K0(t))},disabled:l===Ok.PENDING,children:"Param"}),(0,j.jsx)(gf,{size:"small",onClick:()=>{a(t)},disabled:!l||[Ok.PENDING,Ok.ERROR,"uninitialized"].includes(l),children:"Output"})]}),(0,j.jsx)(s1,{nodeId:t}),(0,j.jsx)(l1,{nodeId:t,isConnectable:i})]})})),o1=(0,n.memo)((function(e){let{nodeId:t}=e;const r=p1(t);return x(Gk)===Ck&&r===Ok.PENDING?(0,j.jsx)("div",{style:{paddingLeft:8,paddingRight:8},children:(0,j.jsx)(qZ,{})}):null})),a1=function(e){let{nodeId:t,data:r}=e;const n=Io(),i=p1(t);return(0,j.jsx)("div",{className:"algoName",children:(0,j.jsx)(Hi,{style:{textAlign:"left",color:i===Ok.ERROR?n.palette.error.main:void 0},children:r.label})})},s1=(0,n.memo)((function(e){let{nodeId:t}=e;const r=x((e=>t=>{const r=zJ(e)(t);if(null!=r){const e=B0($0(t),r);return null===e||void 0===e?void 0:e.args}})(t),h1);return(0,j.jsx)(j.Fragment,{children:null!=r?r.filter((e=>"params"!==e.type)).map(((e,r)=>(0,j.jsx)(c1,{algoInfo:e,i:r,nodeId:t},r))):null})})),l1=(0,n.memo)((function(e){let{nodeId:t,isConnectable:r}=e;const n=x((e=>t=>{const r=zJ(e)(t);if(null!=r){const e=B0($0(t),r);return null===e||void 0===e?void 0:e.returns}})(t),h1);return(0,j.jsx)(j.Fragment,{children:null!=n?null===n||void 0===n?void 0:n.map(((e,r)=>(0,j.jsx)(u1,{algoInfo:e,i:r,nodeId:t},r))):(0,j.jsx)(eb,{type:"source",position:px.Right,id:`${t}`,style:{...Aw},isConnectable:r})})}));const c1=(0,n.memo)((function(e){let{algoInfo:{name:t,type:r,isNone:i},nodeId:o,i:a}=e;const s=j0(r),l=L0(o,t,r),[c,u]=(0,n.useState)(!1),d=function(e,t){if(void 0!==e){const r=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);return null!==r?t?`rgba(${parseInt(r[1],16)}, ${parseInt(r[2],16)}, ${parseInt(r[3],16)}, 0.55)`:`rgba(${parseInt(r[1],16)}, ${parseInt(r[2],16)}, ${parseInt(r[3],16)}, 1)`:void 0}}(s,i);return(0,j.jsx)(eb,{onMouseEnter:()=>u(!0),onMouseLeave:()=>u(!1),type:"target",position:px.Left,id:l,style:{...Aw,background:d,top:25*a+15},isValidConnection:z0,children:(0,j.jsx)(Mp,{title:(0,j.jsxs)(j.Fragment,{children:[(0,j.jsxs)(Hi,{color:"inherit",children:["name: ",t]}),(0,j.jsxs)(Hi,{color:"inherit",children:["type: ",r]})]}),open:c,placement:"left-end",arrow:!0,children:(0,j.jsx)("div",{})})},a.toFixed())})),u1=(0,n.memo)((function(e){let{algoInfo:{name:t,type:r},nodeId:i,i:o}=e;const a=j0(r),s=L0(i,t,r),[l,c]=(0,n.useState)(!1);return(0,j.jsx)(eb,{onMouseEnter:()=>c(!0),onMouseLeave:()=>c(!1),type:"source",position:px.Right,id:s,style:{...Aw,background:a,top:25*o+15},isValidConnection:z0,children:(0,j.jsx)(Mp,{title:(0,j.jsxs)(j.Fragment,{children:[(0,j.jsxs)(Hi,{color:"inherit",children:["name: ",t]}),(0,j.jsxs)(Hi,{color:"inherit",children:["type: ",r]})]}),open:l,placement:"right-end",arrow:!0,children:(0,j.jsx)("div",{})})},o.toFixed())})),d1=(0,n.memo)((function(e){let{nodeId:t}=e;const r=p1(t),i=x(Uk),o=x((e=>{var r;return null!=i&&null!==(r=(e=>t=>{const r=$k(t);return Fk(r)&&Object.keys(r.runResult).includes(e)?r.runResult[e].message:null})(t)(e))&&void 0!==r?r:null})),a=(0,n.useRef)(null),s=Io(),{onMessageError:l}=(0,n.useContext)(qJ);return r===Ok.ERROR?(0,j.jsx)(oi,{ref:a,onClick:()=>{l({anchorElRef:a,message:o})},size:"small",style:{color:s.palette.error.main,padding:0},children:(0,j.jsx)(C0.A,{})}):r===Ok.SUCCESS?(0,j.jsx)(M0.A,{color:"success",style:{verticalAlign:"middle"}}):null}));function h1(e,t){return null!=e&&null!=t?e===t||e.length===t.length&&e.every(((e,r)=>e.type===t[r].type&&e.name===t[r].name)):void 0===e&&void 0===t}function p1(e){const t=x(Uk);return x((r=>null!=t?Kk(e)(r):"uninitialized"))}var f1=r(32125),m1=r(32993),g1=r(4951),y1=r(2194),v1=r(92577);function x1(e){return e.fileType===Yw}function b1(e){return e.fileType===Qw}function _1(e){return e.fileType===Zw}const w1=e=>t=>t.inputNode[e],k1=e=>t=>Object.keys(t.inputNode).includes(e),S1=e=>t=>{const r=w1(e)(t);if(x1(r))return r.selectedFilePath;throw new Error("invalid input node type")},A1=e=>t=>{const r=w1(e)(t);if(r.fileType===Xw)return r.selectedFilePath;throw new Error("invalid input node type")},T1=e=>t=>{const r=w1(e)(t);if(_1(r))return r.selectedFilePath;throw new Error("invalid input node type")},M1=e=>t=>{const r=w1(e)(t);if(b1(r))return r.selectedFilePath;throw new Error("invalid input node type")},C1=e=>t=>{const r=w1(e)(t);if(r.fileType===ek)return r.selectedFilePath;throw new Error("invalid input node type")},E1=e=>0===Object.keys(e.inputNode).length||Object.values(e.inputNode).filter((e=>{if(_1(e))return null==e.selectedFilePath||null==e.hdf5Path;{const t=e.selectedFilePath;return Array.isArray(t)?0===t.length:null==t}})).length>0,I1=e=>t=>{const r=w1(e)(t);if(x1(r))return r.param;throw new Error(`The InputNode is not CsvInputNode. (nodeId: ${e})`)},P1=e=>t=>{const r=w1(e)(t);return _1(r)?r.hdf5Path:void 0},O1=e=>t=>{const r=w1(e)(t);return b1(r)?r.matPath:void 0},R1={[ww]:{fileType:Xw,param:{}}},L1=Pl({name:Gw,initialState:R1,reducers:{deleteInputNode(e,t){delete e[t.payload]},setCsvInputNodeParam(e,t){const{nodeId:r,param:n}=t.payload,i=e[r];x1(i)&&(i.param=n)},setInputNodeMatlabPath(e,t){const{nodeId:r,path:n}=t.payload,i=e[r];b1(i)&&(i.matPath=n)},setInputNodeHDF5Path(e,t){const{nodeId:r,path:n}=t.payload,i=e[r];_1(i)&&(i.hdf5Path=n)}},extraReducers:e=>e.addCase(tk,((e,t)=>{const{nodeId:r,filePath:n}=t.payload,i=e[r];i.selectedFilePath=n,_1(i)&&(i.hdf5Path=void 0)})).addCase(qw,((e,t)=>{var r;const{node:n,fileType:i}=t.payload;if((null===(r=n.data)||void 0===r?void 0:r.type)===fw)switch(i){case Yw:e[n.id]={fileType:i,param:{setHeader:null,setIndex:!1,transpose:!1}};break;case Xw:case Zw:e[n.id]={fileType:i,param:{}};break;case Kw:case Jw:e[n.id]={fileType:Yw,param:{setHeader:null,setIndex:!1,transpose:!1}};break;case Qw:case ek:e[n.id]={fileType:i,param:{}}}})).addCase(pk,(()=>R1)).addCase(xk,((e,t)=>{t.payload.forEach((t=>{var r;(null===(r=t.data)||void 0===r?void 0:r.type)===fw&&delete e[t.id]}))})).addCase(_k,((e,t)=>{Object.keys(e).includes(t.payload)&&delete e[t.payload]})).addCase(Bw.fulfilled,((e,t)=>{const{nodeId:r}=t.meta.arg;if(null!=r){const{resultPath:n}=t.payload,i=e[r];i.fileType===Xw?i.selectedFilePath=[n]:i.selectedFilePath=n}})).addCase(nk.rejected,(()=>R1)).addCase(ok.fulfilled,((e,t)=>{const r={};return Object.values(t.payload.nodeDict).filter(bw).forEach((e=>{null!=e.data&&(e.data.fileType===Xw?r[e.id]={fileType:Xw,param:{}}:e.data.fileType===Yw?r[e.id]={fileType:Yw,param:e.data.param}:e.data.fileType===Qw?r[e.id]={fileType:Qw,param:{}}:e.data.fileType===Zw?r[e.id]={fileType:Zw,param:{}}:e.data.fileType===ek&&(r[e.id]={fileType:ek,param:{}}))})),r})).addMatcher(Bl(nk.fulfilled,ik.fulfilled),((e,t)=>{const r={};return Object.values(t.payload.nodeDict).filter(bw).forEach((e=>{null!=e.data&&(e.data.fileType===Xw?r[e.id]={fileType:Xw,selectedFilePath:e.data.path,param:{}}:e.data.fileType===Yw?r[e.id]={fileType:Yw,selectedFilePath:e.data.path,param:e.data.param}:e.data.fileType===Qw?r[e.id]={fileType:Qw,matPath:e.data.matPath,selectedFilePath:e.data.path,param:{}}:e.data.fileType===Zw?r[e.id]={fileType:Zw,hdf5Path:e.data.hdf5Path,selectedFilePath:e.data.path,param:{}}:e.data.fileType===ek&&(r[e.id]={fileType:ek,selectedFilePath:e.data.path,param:{}}))})),r}))}),{setCsvInputNodeParam:D1,setInputNodeMatlabPath:z1,setInputNodeHDF5Path:j1}=L1.actions,F1=L1.reducer,N1=(0,n.memo)((function(e){return x(k1(e.id))?(0,j.jsx)(B1,{...e}):null})),B1=(0,n.memo)((function(e){let{id:t,selected:r}=e;const n=C(),i=x(S1(t));return(0,j.jsxs)(F0,{nodeId:t,selected:r,children:[(0,j.jsx)("button",{className:"flowbutton",onClick:()=>{n(_k(t))},style:{color:"black",position:"absolute",top:-10,right:10},children:"\xd7"}),(0,j.jsx)(G1,{nodeId:t,onChangeFilePath:e=>{Array.isArray(e)||(e=>{n(tk({nodeId:t,filePath:e}))})(e)},fileType:Yw,filePath:null!==i&&void 0!==i?i:""}),(0,j.jsx)(eb,{type:"source",position:px.Right,id:L0(t,"csv","CsvData"),style:{...Aw}})]})})),V1=(0,n.memo)((function(e){let{nodeId:t,filePath:r}=e;const[i,o]=(0,n.useState)(!1),[a,s]=(0,n.useState)(x((e=>t=>I1(e)(t).setHeader)(t))),[l,c]=(0,n.useState)(x((e=>t=>I1(e)(t).setIndex)(t))),[u,d]=(0,n.useState)(x((e=>t=>I1(e)(t).transpose)(t))),h=C(),p=()=>{o(!1)};return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(oi,{onClick:()=>o(!0),sx:{padding:0},color:"primary",children:(0,j.jsx)(v1.A,{})}),(0,j.jsxs)(Wp,{open:i,onClose:p,children:[(0,j.jsx)(Zp,{children:"Csv Setting"}),(0,j.jsxs)(ef,{dividers:!0,children:[(0,j.jsxs)(yi,{sx:{display:"flex",alignItems:"flex-start"},children:[(0,j.jsx)(aV,{sx:{margin:e=>e.spacing(0,1,0,1),whiteSpace:"nowrap"},control:(0,j.jsx)(wH,{checked:u,onChange:e=>d(e.target.checked)}),label:"Transpose"}),(0,j.jsx)(aV,{sx:{margin:e=>e.spacing(0,1,0,1),whiteSpace:"nowrap"},control:(0,j.jsx)(wH,{checked:null!=a,onChange:e=>{e.target.checked?s(0):s(null)}}),label:"Set Header"}),null!=a&&(0,j.jsx)(gH,{label:"header index",sx:{width:100,margin:e=>e.spacing(0,1,0,1)},type:"number",InputLabelProps:{shrink:!0},onChange:e=>{const t=Number(e.target.value);t>=0&&s(t)},value:a}),(0,j.jsx)(aV,{sx:{margin:e=>e.spacing(0,1,0,1),whiteSpace:"nowrap"},control:(0,j.jsx)(wH,{checked:l,onChange:e=>c(e.target.checked)}),label:"Set Index"})]}),(0,j.jsx)(Hi,{variant:"h6",children:"Preview"}),(0,j.jsx)(U1,{filePath:r,transpose:u,setHeader:a,setIndex:l})]}),(0,j.jsxs)(of,{children:[(0,j.jsx)(gf,{onClick:p,variant:"outlined",children:"cancel"}),(0,j.jsx)(gf,{onClick:()=>{o(!1),h(D1({nodeId:t,param:{setHeader:a,setIndex:l,transpose:u}}))},variant:"contained",children:"OK"})]})]})]})})),U1=(0,n.memo)((function(e){let{filePath:t,...r}=e;const i=x(OS(t)),o=x(LS(t)),a=x(DS(t)),s=x(RS(t)),l=C(),c=x(jf);return(0,n.useEffect)((()=>{c&&!i&&l(lS({path:t,workspaceId:c}))}),[l,i,t,c]),o?(0,j.jsx)(qZ,{}):null!=s?(0,j.jsx)(Hi,{color:"error",children:s}):a?(0,j.jsx)(QZ,{path:t,...r}):null})),H1=(0,n.memo)((function(e){return(0,j.jsxs)(yi,{display:"flex",alignItems:"center",children:[(0,j.jsx)(yi,{width:"100%",mr:1,children:(0,j.jsx)(qZ,{variant:"determinate",...e})}),(0,j.jsx)(yi,{minWidth:35,children:(0,j.jsx)(Hi,{variant:"body2",color:"textSecondary",children:`${Math.round(e.value)}%`})})]})})),$1={path:void 0,fileName:void 0,isUninitialized:!0,pending:!1,fulfilled:!1,uploadingProgress:void 0,error:void 0},W1=e=>t=>Object.keys(t.fileUploader).includes(e)?t.fileUploader[e]:$1;function q1(e){let{fileType:t,nodeId:r}=e;const i=C(),o=(0,n.useRef)(Ol()),a=x(jf),s=(0,n.useCallback)(((e,n)=>{if(!a)throw new Error("workspaceId is undefined");i(Bw({workspaceId:a,requestId:o.current,nodeId:r,fileName:n,formData:e,fileType:t}))}),[i,a,t,r]),l=x((e=>t=>W1(e)(t).isUninitialized)(o.current)),c=x((e=>t=>W1(e)(t).path)(o.current)),u=x((e=>t=>W1(e)(t).pending)(o.current)),d=x((e=>t=>W1(e)(t).fulfilled)(o.current)),h=x((e=>t=>W1(e)(t).uploadingProgress)(o.current)),p=x((e=>t=>W1(e)(t).error)(o.current));return{filePath:c,uninitialized:l,pending:u,fulfilled:d,progress:h,error:p,onUploadFile:s,id:o}}const G1=(0,n.memo)((function(e){let{nameNode:t,multiSelect:r=!1,filePath:n,nodeId:i,fileType:o,setOpen:a,onChangeFilePath:s}=e;const{onUploadFile:l,pending:c,uninitialized:u,progress:d,error:h,id:p}=q1({fileType:o,nodeId:i});return(0,j.jsxs)(j.Fragment,{children:[!u&&c&&null!=d&&(0,j.jsx)("div",{style:{marginLeft:2,marginRight:2},children:(0,j.jsx)(H1,{value:d})}),(0,j.jsx)(Hi,{children:t||o}),(0,j.jsx)(Y1,{multiSelect:r,filePath:n,onSelectFile:s,onUploadFile:(e,t)=>{l(e,t)},fileTreeType:o,selectButtonLabel:(0,j.jsx)(y1.A,{}),uploadViaUrl:(0,j.jsx)(m1.A,{}),nodeId:i,id:p.current,setOpen:a}),null!=h&&(0,j.jsx)(Hi,{variant:"caption",color:"error",children:h})]})})),Y1=(0,n.memo)((function(e){let{multiSelect:t=!1,filePath:r,onSelectFile:i,onUploadFile:o,fileTreeType:a,selectButtonLabel:s,uploadButtonLabel:l,uploadViaUrl:c,nodeId:u,id:d,setOpen:h}=e;const{onOpenFileSelectDialog:p,onOpenClearWorkflowIdDialog:f,onOpenInputUrlDialog:m}=(0,n.useContext)(qJ),g=C(),y=x(Uk),v=x(Xk),b=x(jf),_=(0,n.useRef)(null),w=()=>{null!=_.current&&_.current.click()};(0,n.useEffect)((()=>{u&&m({fileType:a,open:!1,filePath:r,nodeId:u,requestId:d})}),[]);const k=function(e){switch(e){case Lw.MATLAB:return".mat";case Lw.IMAGE:return".tif,.tiff";case Lw.CSV:return".csv";case Lw.HDF5:return".hdf5,.nwb";case Lw.MICROSCOPE:return".nd2,.oir,.isxd,.thor.zip";default:return}}(a),S=vw(r);return(0,j.jsxs)("div",{children:[(0,j.jsxs)(R0,{size:"small",style:{marginRight:4},children:[(0,j.jsx)(Mp,{title:"Select from uploaded files",children:(0,j.jsx)("span",{children:(0,j.jsx)(oi,{color:"primary",disabled:!!v,onClick:()=>{p({open:!0,multiSelect:t,filePath:r,fileTreeType:a,onSelectFile:i}),b&&a&&g(zw({workspaceId:b,fileType:a}))},children:s||"Select File"})})}),(0,j.jsx)(Mp,{title:"Upload file",children:(0,j.jsx)("span",{children:(0,j.jsx)(oi,{onClick:()=>{null!=y?f({open:!0,handleOk:()=>{w()},handleCancel:()=>{}}):w()},color:"primary",disabled:!!v,children:l||(0,j.jsx)(g1.A,{})})})}),c?(0,j.jsx)(Mp,{title:"Upload file via URL",children:(0,j.jsx)("span",{children:(0,j.jsx)(oi,{onClick:()=>{u&&m({fileType:a,open:!0,filePath:r,nodeId:u,requestId:d})},color:"primary",disabled:!!v,children:c})})}):null,a===Lw.CSV&&!!r&&!!u&&(0,j.jsx)(Mp,{title:"Settings",children:(0,j.jsx)("span",{children:(0,j.jsx)(oi,{disabled:!!v,children:(0,j.jsx)(V1,{nodeId:u,filePath:r})})})}),[Lw.HDF5,Lw.MATLAB].includes(a)&&!!r&&!!u&&(0,j.jsx)(Mp,{title:"Structure",children:(0,j.jsx)("span",{children:(0,j.jsx)(oi,{color:"primary",disabled:!!v,onClick:()=>null===h||void 0===h?void 0:h(!0),children:(0,j.jsx)(f1.A,{})})})})]}),(0,j.jsxs)("div",{children:[(0,j.jsx)("input",{ref:_,type:"file",onChange:e=>{if(e.preventDefault(),null!=e.target.files&&null!=e.target.files[0]){const t=e.target.files[0],r=new FormData;r.append("file",t);const n=t.name;o(r,n)}},accept:k,style:{visibility:"hidden",width:0,height:0}}),(0,j.jsx)(Mp,{title:S||null,placement:"right",children:(0,j.jsx)(Hi,{className:"selectFilePath",variant:"body2",children:S||"No file is selected."})})]})]})}));const X1=(0,n.memo)((function(e){return x(k1(e.id))?(0,j.jsx)(Z1,{...e}):null})),Z1=(0,n.memo)((function(e){let{id:t,selected:r}=e;const n=C(),i=x(S1(t)),o="BehaviorData",a=j0(o);return(0,j.jsxs)(F0,{nodeId:t,selected:r,children:[(0,j.jsx)("button",{className:"flowbutton",onClick:()=>{n(_k(t))},style:{color:"black",position:"absolute",top:-10,right:10},children:"\xd7"}),(0,j.jsx)(G1,{nodeId:t,onChangeFilePath:e=>{Array.isArray(e)||(e=>{n(tk({nodeId:t,filePath:e}))})(e)},nameNode:Jw,fileType:Yw,filePath:null!==i&&void 0!==i?i:""}),(0,j.jsx)(eb,{type:"source",position:px.Right,id:L0(t,"behavior",o),style:{...Aw,background:a}})]})})),K1=(0,n.memo)((function(e){return x(k1(e.id))?(0,j.jsx)(J1,{...e}):null})),J1=(0,n.memo)((function(e){let{id:t,selected:r}=e;const n=C(),i=x(S1(t)),o="FluoData",a=j0(o);return(0,j.jsxs)(F0,{nodeId:t,selected:r,children:[(0,j.jsx)("button",{className:"flowbutton",onClick:()=>{n(_k(t))},style:{color:"black",position:"absolute",top:-10,right:10},children:"\xd7"}),(0,j.jsx)(G1,{nodeId:t,onChangeFilePath:e=>{Array.isArray(e)||(e=>{n(tk({nodeId:t,filePath:e}))})(e)},nameNode:Kw,fileType:Yw,filePath:null!==i&&void 0!==i?i:""}),(0,j.jsx)(eb,{type:"source",position:px.Right,id:L0(t,"fluo",o),style:{...Aw,background:a}})]})}));const Q1="hdf5",e2=jl(`${Q1}/getHDF5Tree`,(async(e,t)=>{let{path:r,workspaceId:n}=e;try{const e=await async function(e,t){return(await wd.get(`${bd}/hdf5/${e}?workspace_id=${t}`)).data}(r,n);return e}catch(ene){return t.rejectWithValue(ene)}})),t2=e=>null!=e.hdf5?e.hdf5:void 0,r2=(0,n.memo)((function(e){return x(k1(e.id))?(0,j.jsx)(n2,{...e}):null})),n2=(0,n.memo)((function(e){let{id:t,selected:r}=e;const i=C(),o=x(T1(t)),[a,s]=(0,n.useState)(!1);return(0,j.jsxs)(F0,{nodeId:t,selected:r,children:[(0,j.jsx)("button",{className:"flowbutton",onClick:()=>{i(_k(t))},style:{color:"black",position:"absolute",top:-10,right:10},children:"\xd7"}),(0,j.jsx)(G1,{nodeId:t,onChangeFilePath:e=>{Array.isArray(e)||(e=>{i(tk({nodeId:t,filePath:e}))})(e)},setOpen:s,fileType:Zw,filePath:null!==o&&void 0!==o?o:""}),void 0!==o&&(0,j.jsx)(i2,{open:a,setOpen:s,nodeId:t}),(0,j.jsx)(eb,{type:"source",position:px.Right,id:L0(t,"hdf5","HDF5Data"),style:{...Aw}})]})})),i2=(0,n.memo)((function(e){let{nodeId:t,open:r,setOpen:n}=e;const i=x(P1(t));return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(Hi,{className:"selectFilePath",variant:"caption",children:i||"No structure is selected."}),(0,j.jsxs)(Wp,{open:r,onClose:()=>n(!1),fullWidth:!0,children:[(0,j.jsx)(Zp,{children:"Select File"}),(0,j.jsx)(o2,{nodeId:t}),(0,j.jsxs)(of,{children:[(0,j.jsx)(gf,{onClick:()=>n(!1),variant:"outlined",children:"cancel"}),(0,j.jsx)(gf,{onClick:()=>n(!1),color:"primary",variant:"contained",autoFocus:!0,children:"OK"})]})]})]})})),o2=(0,n.memo)((function(e){let{nodeId:t}=e;const r=Io();return(0,j.jsx)(ef,{dividers:!0,children:(0,j.jsx)("div",{style:{height:300,overflow:"auto",marginBottom:r.spacing(1),border:"1px solid",padding:r.spacing(1),borderColor:r.palette.divider},children:(0,j.jsx)(a2,{nodeId:t})})})})),a2=(0,n.memo)((function(e){let{nodeId:t}=e;const[r,i]=function(e){const t=C(),r=x((e=>{var t;return null===(t=t2(e))||void 0===t?void 0:t.tree})),i=x((e=>{var t,r;return null!==(t=null===(r=t2(e))||void 0===r?void 0:r.isLoading)&&void 0!==t&&t})),o=x(T1(e)),a=x(jf);return(0,n.useEffect)((()=>{a&&!i&&o&&t(e2({path:o,workspaceId:a}))}),[a,o]),[r,i]}(t);return(0,j.jsxs)("div",{children:[i&&(0,j.jsx)(qZ,{}),(0,j.jsx)($Q,{children:null===r||void 0===r?void 0:r.map(((e,r)=>(0,j.jsx)(s2,{node:e,nodeId:t},`hdf5tree-${t}-${r}`)))})]})})),s2=(0,n.memo)((function e(t){let{node:r,nodeId:n}=t;const i=C();return r.isDir?(0,j.jsx)(hQ,{icon:(0,j.jsx)(YJ.A,{htmlColor:"skyblue"}),nodeId:r.path,label:r.name,children:r.nodes.map(((t,r)=>(0,j.jsx)(e,{node:t,nodeId:n},r)))}):(0,j.jsx)(hQ,{icon:(0,j.jsx)(XJ.A,{fontSize:"small"}),nodeId:r.path,label:r.name+` (shape=${r.shape}, nbytes=${r.nbytes})`,onClick:()=>{return e=r.path,void i(j1({nodeId:n,path:e}));var e}})}));const l2=(0,n.memo)((function(e){return x(k1(e.id))?(0,j.jsx)(c2,{...e}):null})),c2=(0,n.memo)((function(e){let{id:t,selected:r}=e;const n=C(),i=x(A1(t),((e,t)=>null!=e&&null!=t?vY(e,t):e===t)),o="ImageData",a=j0(o);return(0,j.jsxs)(F0,{nodeId:t,selected:r,children:[(0,j.jsx)("button",{className:"flowbutton",onClick:()=>{n(_k(t))},style:{color:"black",position:"absolute",top:-10,right:10},children:"\xd7"}),(0,j.jsx)(G1,{nodeId:t,multiSelect:!0,onChangeFilePath:e=>{Array.isArray(e)&&(e=>{n(tk({nodeId:t,filePath:e}))})(e)},fileType:Xw,filePath:"string"===typeof i?[i]:i||[]}),(0,j.jsx)(eb,{type:"source",position:px.Right,id:L0(t,"image",o),style:{...Aw,background:a},isValidConnection:z0})]})}));const u2=jl(`${Q1}/getHDF5Tree`,(async(e,t)=>{let{path:r,workspaceId:n}=e;try{const e=await async function(e,t){return(await wd.get(`${bd}/mat/${e}?workspace_id=${t}`)).data}(r,n);return e}catch(ene){return t.rejectWithValue(ene)}})),d2=e=>null!=e.matlab?e.matlab:void 0,h2=(0,n.memo)((function(e){return x(k1(e.id))?(0,j.jsx)(p2,{...e}):null})),p2=(0,n.memo)((function(e){let{id:t,selected:r}=e;const i=C(),o=x(M1(t)),[a,s]=(0,n.useState)(!1);return(0,j.jsxs)(F0,{nodeId:t,selected:r,children:[(0,j.jsx)("button",{className:"flowbutton",onClick:()=>{i(_k(t))},style:{color:"black",position:"absolute",top:-10,right:10},children:"\xd7"}),(0,j.jsx)(G1,{nodeId:t,onChangeFilePath:e=>{Array.isArray(e)||(e=>{i(tk({nodeId:t,filePath:e}))})(e)},setOpen:s,fileType:Qw,filePath:null!==o&&void 0!==o?o:""}),void 0!==o&&(0,j.jsx)(f2,{open:a,setOpen:s,nodeId:t}),(0,j.jsx)(eb,{type:"source",position:px.Right,id:L0(t,"matlab","MatlabData"),style:{...Aw}})]})})),f2=(0,n.memo)((function(e){let{nodeId:t,open:r,setOpen:i}=e;const o=C(),[a,s]=(0,n.useState)(""),l=x(O1(t));return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(Hi,{className:"selectFilePath",variant:"caption",children:l||"No structure is selected."}),(0,j.jsxs)(Wp,{open:r,onClose:()=>i(!1),fullWidth:!0,children:[(0,j.jsx)(Zp,{children:"Select File"}),(0,j.jsx)(m2,{nodeId:t,fileSelect:a,setFileSelect:s}),(0,j.jsxs)(of,{children:[(0,j.jsx)(gf,{onClick:()=>{s(""),null===i||void 0===i||i(!1)},color:"primary",variant:"outlined",children:"cancel"}),(0,j.jsx)(gf,{onClick:()=>{o(z1({nodeId:t,path:a})),null===i||void 0===i||i(!1)},variant:"contained",autoFocus:!0,children:"OK"})]})]})]})})),m2=(0,n.memo)((function(e){let{nodeId:t,fileSelect:r,setFileSelect:n}=e;const i=Io();return(0,j.jsxs)(ef,{dividers:!0,children:[(0,j.jsx)("div",{style:{height:300,overflow:"auto",marginBottom:i.spacing(1),border:"1px solid",padding:i.spacing(1),borderColor:i.palette.divider},children:(0,j.jsx)(g2,{nodeId:t,fileSelect:r,setFileSelect:n})}),(0,j.jsx)(Hi,{children:"Select File"}),(0,j.jsx)(Hi,{variant:"subtitle2",children:r||"---"})]})})),g2=(0,n.memo)((function(e){let{nodeId:t,fileSelect:r,setFileSelect:i}=e;const[o,a]=function(e){const t=C(),r=x((e=>{var t;return null===(t=d2(e))||void 0===t?void 0:t.tree})),i=x((e=>{var t,r;return null!==(t=null===(r=d2(e))||void 0===r?void 0:r.isLoading)&&void 0!==t&&t})),o=x(M1(e)),a=x(jf);return(0,n.useEffect)((()=>{a&&!i&&o&&t(u2({path:o,workspaceId:a}))}),[a,o]),[r,i]}(t);return(0,j.jsxs)("div",{children:[a&&(0,j.jsx)(qZ,{}),(0,j.jsxs)(yi,{display:"flex",paddingBottom:1,children:[(0,j.jsx)(yi,{flexGrow:4,children:"Structure"}),(0,j.jsx)(yi,{flexGrow:2,children:"Type"}),(0,j.jsx)(yi,{flexGrow:3,children:"Shape"}),(0,j.jsx)(yi,{flexGrow:1})]}),(0,j.jsx)(yU,{}),(0,j.jsx)($Q,{children:null===o||void 0===o?void 0:o.map(((e,n)=>(0,j.jsx)(v2,{fileSelect:r,setFileSelect:i,node:e,nodeId:t},`matlabtree-${t}-${n}`)))})]})})),y2=(0,n.memo)((function(e){let{isFile:t=!1,label:r,shape:n,type:i,checkboxProps:o}=e;return(0,j.jsxs)(yi,{display:"flex",alignItems:"center",gap:2,children:[(0,j.jsx)(Mp,{title:(0,j.jsx)("span",{style:{fontSize:14},children:r}),placement:"left",children:(0,j.jsx)(yi,{width:t?"35%":"32%",overflow:"hidden",textOverflow:"ellipsis",children:r})}),(0,j.jsx)(yi,{width:"20%",children:i}),(0,j.jsx)(yi,{width:"25%",children:n?`(${n.join(", ")})`:""}),(0,j.jsx)(yi,{children:(0,j.jsx)(WU,{...o,disableRipple:!0,size:"small",sx:{marginRight:"4px",padding:"2px"}})})]})})),v2=(0,n.memo)((function e(t){let{node:r,nodeId:i,setFileSelect:o,fileSelect:a}=t;const s=C(),l=x(O1(i));(0,n.useEffect)((()=>{l&&(null===o||void 0===o||o(l))}),[s,l]);return r.isDir?(0,j.jsx)(hQ,{icon:(0,j.jsx)(YJ.A,{htmlColor:"skyblue"}),nodeId:r.path,label:r.name,children:r.nodes.map(((t,r)=>(0,j.jsx)(e,{setFileSelect:o,fileSelect:a,node:t,nodeId:i},r)))}):(0,j.jsx)(hQ,{icon:(0,j.jsx)(XJ.A,{fontSize:"small"}),nodeId:r.path,label:(0,j.jsx)(y2,{isFile:!0,label:r.name,type:r.dataType,shape:r.shape,checkboxProps:{checked:a===r.path}}),onClick:()=>{return e=r.path,void(null===o||void 0===o||o(e===a?"":e));var e}})}));const x2=(0,n.memo)((function(e){return x(k1(e.id))?(0,j.jsx)(b2,{...e}):null})),b2=(0,n.memo)((function(e){let{id:t,selected:r}=e;const n=C(),i=x(C1(t)),o="MicroscopeData",a=j0(o);return(0,j.jsxs)(F0,{nodeId:t,selected:r,children:[(0,j.jsx)("button",{className:"flowbutton",onClick:()=>{n(_k(t))},style:{color:"black",position:"absolute",top:-10,right:10},children:"\xd7"}),(0,j.jsx)(G1,{nodeId:t,onChangeFilePath:e=>{Array.isArray(e)||(e=>{n(tk({nodeId:t,filePath:e}))})(e)},fileType:ek,filePath:null!==i&&void 0!==i?i:""}),(0,j.jsx)(eb,{type:"source",position:px.Right,id:L0(t,"microscope",o),style:{...Aw,background:a},isValidConnection:z0})]})})),_2={ImageFileNode:l2,CsvFileNode:N1,MatlabFileNode:h2,HDF5FileNode:r2,AlgorithmNode:n1,FluoFileNode:K1,BehaviorFileNode:X1,MicroscopeFileNode:x2},w2={buttonedge:e=>{let{id:t,sourceX:r,sourceY:n,targetX:i,targetY:o,sourcePosition:a,targetPosition:s,style:l={},markerEnd:c}=e;const[u,d,h]=Mx({sourceX:r,sourceY:n,sourcePosition:a,targetX:i,targetY:o,targetPosition:s}),p=C();return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)("path",{id:t,style:l,className:"react-flow__edge-path",d:u,markerEnd:c}),(0,j.jsx)("foreignObject",{width:40,height:40,x:d-20,y:h-20,className:"edgebutton-foreignobject",children:(0,j.jsx)("button",{className:"flowbutton",onClick:()=>{p(bk(t))},children:"\xd7"})})]})}},k2=(0,Ud.A)((0,j.jsx)("path",{d:"M4 6H2v14c0 1.1.9 2 2 2h14v-2H4zm16-4H8c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2m-1 9h-4v4h-2v-4H9V9h4V5h2v4h4z"}),"AddToPhotos"),S2=(0,n.memo)((function(){const[e,t]=(0,n.useState)(!1),r=C(),i=x(Xk);return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(Mp,{title:"Create new workflow",children:(0,j.jsx)(oi,{onClick:()=>{t(!0)},color:"primary",disabled:!!i,children:(0,j.jsx)(k2,{})})}),(0,j.jsx)(Cf,{open:e,setOpen:t,onConfirm:()=>{r(pk())},title:"Create new workflow?",content:"Current workflow will be cleared.\n If the workflow has already been run, the record will NOT be deleted.",iconType:"info"})]})})),A2=(0,Ud.A)((0,j.jsx)("path",{d:"M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8zm4 18H6V4h7v5h5zM8 15.01l1.41 1.41L11 14.84V19h2v-4.16l1.59 1.59L16 15.01 12.01 11z"}),"UploadFile"),T2=(0,n.memo)((function(){const e=C(),t=(0,n.useRef)(null),{enqueueSnackbar:r}=hn(),i=x(Xk);return(0,j.jsx)(Mp,{title:"Import workflow yaml file",children:(0,j.jsxs)(oi,{onClick:()=>{var e;null===(e=t.current)||void 0===e||e.click()},color:"primary",disabled:!!i,children:[(0,j.jsx)(A2,{}),(0,j.jsx)("input",{hidden:!0,ref:t,type:"file",accept:".yaml,.yml",onChange:t=>{if(t.preventDefault(),null!=t.target.files&&null!=t.target.files[0]){const n=t.target.files[0],i=new FormData;i.append("file",n),e(ok({formData:i})).unwrap().then((()=>{r("Import success",{variant:"success"}),e(AM())})).catch((()=>{r("Invalid yaml file",{variant:"error"})}))}}})]})})}));var M2=r(86974);const C2=(0,n.memo)((function(){const e=C(),t=x(Xk);return(0,j.jsx)(Mp,{title:"NWB settings",children:(0,j.jsx)(oi,{onClick:()=>{e(J0())},color:"primary",disabled:!!t,children:(0,j.jsx)(M2.A,{})})})})),E2=(0,Ud.A)((0,j.jsx)("path",{d:"M8 5v14l11-7z"}),"PlayArrow");var I2=r(40430),P2=r(83723);const O2=(0,n.memo)((function(e){const{uid:t,runDisabled:r,filePathIsUndefined:i,algorithmNodeNotExist:o,handleCancelPipeline:a,handleRunPipeline:s,handleRunPipelineByUid:l}=e,c=C(),u=x(Wk),d=x(Xk),h=(0,n.useRef)(!1),[p,f]=(0,n.useState)(!1),{enqueueSnackbar:m}=hn(),[g,y]=(0,n.useState)(!1),v=(0,n.useRef)(null),b=e=>{v.current&&v.current.contains(e.target)||y(!1)},_=null!=t;return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsxs)(R0,{sx:{margin:1},variant:"contained",ref:v,disabled:r,children:[(0,j.jsx)(gf,{onClick:()=>{let e=null;if(o&&(e="please add some algorithm nodes to the flowchart"),i&&(e="please select input file"),null!=e)m(e,{variant:"error"});else if(u===Rk.RUN_NEW)f(!0);else{if(h.current)return;h.current=!0,l(),setTimeout((()=>{h.current=!1}),3e3)}},startIcon:u===Rk.RUN_ALREADY?(0,j.jsx)(Pq.A,{}):(0,j.jsx)(E2,{}),children:Lk[u]}),(0,j.jsx)(gf,{size:"small",onClick:()=>{y((e=>!e))},children:(0,j.jsx)(I2.A,{})})]}),(0,j.jsx)(fp,{open:g,anchorEl:v.current,role:void 0,transition:!0,disablePortal:!0,children:e=>{let{TransitionProps:t,placement:r}=e;return(0,j.jsx)(Fo,{...t,style:{transformOrigin:"bottom"===r?"center top":"center bottom"},children:(0,j.jsx)(Ci,{children:(0,j.jsx)(Lz,{onClickAway:b,children:(0,j.jsx)(yo,{children:Object.values(Rk).map((e=>(0,j.jsx)(qa,{disabled:!_&&e===Rk.RUN_ALREADY,selected:e===u,onClick:t=>((e,t)=>{c(XG({runBtnOption:t})),y(!1)})(0,e),children:Lk[e]},e)))})})})})}}),d&&(0,j.jsx)(Mp,{title:"Cancel Workflow",children:(0,j.jsx)(oi,{onClick:()=>{a()},children:(0,j.jsx)(P2.A,{color:"error"})})}),(0,j.jsx)(R2,{open:p,handleRun:e=>{h.current||(h.current=!0,s(e),setTimeout((()=>{h.current=!1}),3e3),f(!1))},handleClose:()=>f(!1)})]})})),R2=(0,n.memo)((function(e){let{open:t,handleClose:r,handleRun:i}=e;const[o,a]=(0,n.useState)("New flow"),[s,l]=(0,n.useState)(null);return(0,j.jsxs)(Wp,{open:t,onClose:r,children:[(0,j.jsx)(Zp,{children:"Name and run workflow"}),(0,j.jsx)(ef,{children:(0,j.jsx)(gH,{label:"name",autoFocus:!0,margin:"dense",fullWidth:!0,variant:"standard",onChange:e=>{a(e.target.value),""!==e.target.value&&l(null)},error:null!=s,helperText:s,value:o})}),(0,j.jsxs)(of,{children:[(0,j.jsx)(gf,{onClick:r,variant:"outlined",children:"Cancel"}),(0,j.jsx)(gf,{onClick:()=>{""!==o?i(o):l("name is empty")},variant:"contained",children:"Run"})]})]})}));var L2=r(61783);const D2=(0,n.memo)((function(){const e=C(),t=x(Xk);return(0,j.jsx)(Mp,{title:"Snakemake settings",children:(0,j.jsx)(oi,{onClick:()=>{e(Q0())},color:"primary",disabled:!!t,children:(0,j.jsx)(L2.A,{})})})})),z2=(0,n.memo)((function(e){return(0,j.jsxs)(yi,{style:{display:"flex",alignItems:"center",position:"absolute",float:"right",textAlign:"right",top:-7,right:10,zIndex:4,textTransform:"none",fontSize:"1rem"},children:[(0,j.jsx)(S2,{}),(0,j.jsx)(T2,{}),(0,j.jsx)(D2,{}),(0,j.jsx)(C2,{}),(0,j.jsx)(O2,{...e})]})})),j2=nw,F2=(0,n.memo)((function(e){const t=x(LY),r=x(DY),i=r.filter((e=>!Px(e))),o=x(jY),a=C(),s=x(zY),[l,c]=(0,n.useState)(),u=(0,n.useRef)(null),[,d]=g0((()=>({accept:T0,drop:(e,t)=>{let r;const n=t.getClientOffset();return null!=u.current&&null!=n&&null!=l&&(r=l.project({x:n.x-u.current.offsetLeft-40,y:n.y-u.current.offsetTop-40})),{position:r}}})),[l]);return(0,j.jsxs)("div",{className:"flow",children:[(0,j.jsx)(j2,{children:(0,j.jsx)("div",{className:"reactflow-wrapper",ref:u,children:(0,j.jsxs)(dw,{ref:d,nodes:t,edges:r,onNodesChange:e=>a(fk(e)),onEdgesChange:e=>a(mk(e)),onConnect:e=>{a(vk([...Lx({...e,animated:!1,style:{width:5},type:"buttonedge"},i)]))},onInit:e=>c(e),onDragOver:e=>{e.preventDefault(),e.dataTransfer.dropEffect="move"},onNodeDragStop:(e,t)=>{a(wk({nodeId:t.id,coord:{x:t.position.x,y:t.position.y}}))},nodeTypes:_2,edgeTypes:w2,defaultViewport:{x:s[0],y:s[1],zoom:s[2]},onMoveEnd:(e,t)=>{void 0!==e&&a(gk([t.x,t.y,t.zoom]))},children:[(0,j.jsx)(z2,{...e}),(0,j.jsx)(A0,{})]})})}),(0,j.jsx)(wi,{loading:o})]})}));var N2=r(91707),B2=r(21337);function V2(e){return(0,Yn.Ay)("MuiAccordionDetails",e)}(0,Ln.A)("MuiAccordionDetails",["root"]);const U2=["className"],H2=(0,yn.Ay)("div",{name:"MuiAccordionDetails",slot:"Root",overridesResolver:(e,t)=>t.root})((e=>{let{theme:t}=e;return{padding:t.spacing(1,2,2)}})),$2=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiAccordionDetails"}),{className:n}=r,i=(0,R.A)(r,U2),o=r,a=(e=>{const{classes:t}=e;return(0,mn.A)({root:["root"]},V2,t)})(o);return(0,j.jsx)(H2,(0,O.A)({className:(0,fn.A)(a.root,n),ref:t,ownerState:o},i))}));const W2=n.createContext({});function q2(e){return(0,Yn.Ay)("MuiAccordionSummary",e)}const G2=(0,Ln.A)("MuiAccordionSummary",["root","expanded","focusVisible","disabled","gutters","contentGutters","content","expandIconWrapper"]),Y2=["children","className","expandIcon","focusVisibleClassName","onClick"],X2=(0,yn.Ay)(Qn,{name:"MuiAccordionSummary",slot:"Root",overridesResolver:(e,t)=>t.root})((e=>{let{theme:t}=e;const r={duration:t.transitions.duration.shortest};return{display:"flex",minHeight:48,padding:t.spacing(0,2),transition:t.transitions.create(["min-height","background-color"],r),[`&.${G2.focusVisible}`]:{backgroundColor:(t.vars||t).palette.action.focus},[`&.${G2.disabled}`]:{opacity:(t.vars||t).palette.action.disabledOpacity},[`&:hover:not(.${G2.disabled})`]:{cursor:"pointer"},variants:[{props:e=>!e.disableGutters,style:{[`&.${G2.expanded}`]:{minHeight:64}}}]}})),Z2=(0,yn.Ay)("div",{name:"MuiAccordionSummary",slot:"Content",overridesResolver:(e,t)=>t.content})((e=>{let{theme:t}=e;return{display:"flex",flexGrow:1,margin:"12px 0",variants:[{props:e=>!e.disableGutters,style:{transition:t.transitions.create(["margin"],{duration:t.transitions.duration.shortest}),[`&.${G2.expanded}`]:{margin:"20px 0"}}}]}})),K2=(0,yn.Ay)("div",{name:"MuiAccordionSummary",slot:"ExpandIconWrapper",overridesResolver:(e,t)=>t.expandIconWrapper})((e=>{let{theme:t}=e;return{display:"flex",color:(t.vars||t).palette.action.active,transform:"rotate(0deg)",transition:t.transitions.create("transform",{duration:t.transitions.duration.shortest}),[`&.${G2.expanded}`]:{transform:"rotate(180deg)"}}})),J2=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiAccordionSummary"}),{children:i,className:o,expandIcon:a,focusVisibleClassName:s,onClick:l}=r,c=(0,R.A)(r,Y2),{disabled:u=!1,disableGutters:d,expanded:h,toggle:p}=n.useContext(W2),f=(0,O.A)({},r,{expanded:h,disabled:u,disableGutters:d}),m=(e=>{const{classes:t,expanded:r,disabled:n,disableGutters:i}=e,o={root:["root",r&&"expanded",n&&"disabled",!i&&"gutters"],focusVisible:["focusVisible"],content:["content",r&&"expanded",!i&&"contentGutters"],expandIconWrapper:["expandIconWrapper",r&&"expanded"]};return(0,mn.A)(o,q2,t)})(f);return(0,j.jsxs)(X2,(0,O.A)({focusRipple:!1,disableRipple:!0,disabled:u,component:"div","aria-expanded":h,className:(0,fn.A)(m.root,o),focusVisibleClassName:(0,fn.A)(m.focusVisible,s),onClick:e=>{p&&p(e),l&&l(e)},ref:t,ownerState:f},c,{children:[(0,j.jsx)(Z2,{className:m.content,ownerState:f,children:i}),a&&(0,j.jsx)(K2,{className:m.expandIconWrapper,ownerState:f,children:a})]}))}));function Q2(e){return(0,Yn.Ay)("MuiAccordion",e)}const e3=(0,Ln.A)("MuiAccordion",["root","rounded","expanded","disabled","gutters","region"]),t3=["children","className","defaultExpanded","disabled","disableGutters","expanded","onChange","square","slots","slotProps","TransitionComponent","TransitionProps"],r3=(0,yn.Ay)(Ci,{name:"MuiAccordion",slot:"Root",overridesResolver:(e,t)=>{const{ownerState:r}=e;return[{[`& .${e3.region}`]:t.region},t.root,!r.square&&t.rounded,!r.disableGutters&&t.gutters]}})((e=>{let{theme:t}=e;const r={duration:t.transitions.duration.shortest};return{position:"relative",transition:t.transitions.create(["margin"],r),overflowAnchor:"none","&::before":{position:"absolute",left:0,top:-1,right:0,height:1,content:'""',opacity:1,backgroundColor:(t.vars||t).palette.divider,transition:t.transitions.create(["opacity","background-color"],r)},"&:first-of-type":{"&::before":{display:"none"}},[`&.${e3.expanded}`]:{"&::before":{opacity:0},"&:first-of-type":{marginTop:0},"&:last-of-type":{marginBottom:0},"& + &":{"&::before":{display:"none"}}},[`&.${e3.disabled}`]:{backgroundColor:(t.vars||t).palette.action.disabledBackground}}}),(e=>{let{theme:t}=e;return{variants:[{props:e=>!e.square,style:{borderRadius:0,"&:first-of-type":{borderTopLeftRadius:(t.vars||t).shape.borderRadius,borderTopRightRadius:(t.vars||t).shape.borderRadius},"&:last-of-type":{borderBottomLeftRadius:(t.vars||t).shape.borderRadius,borderBottomRightRadius:(t.vars||t).shape.borderRadius,"@supports (-ms-ime-align: auto)":{borderBottomLeftRadius:0,borderBottomRightRadius:0}}}},{props:e=>!e.disableGutters,style:{[`&.${e3.expanded}`]:{margin:"16px 0"}}}]}})),n3=n.forwardRef((function(e,t){const r=(0,vn.b)({props:e,name:"MuiAccordion"}),{children:i,className:o,defaultExpanded:a=!1,disabled:s=!1,disableGutters:l=!1,expanded:c,onChange:u,square:d=!1,slots:h={},slotProps:p={},TransitionComponent:f,TransitionProps:m}=r,g=(0,R.A)(r,t3),[y,v]=(0,gp.A)({controlled:c,default:a,name:"Accordion",state:"expanded"}),x=n.useCallback((e=>{v(!y),u&&u(e,!y)}),[y,u,v]),[b,..._]=n.Children.toArray(i),w=n.useMemo((()=>({expanded:y,disabled:s,disableGutters:l,toggle:x})),[y,s,l,x]),k=(0,O.A)({},r,{square:d,disabled:s,disableGutters:l,expanded:y}),S=(e=>{const{classes:t,square:r,expanded:n,disabled:i,disableGutters:o}=e,a={root:["root",!r&&"rounded",n&&"expanded",i&&"disabled",!o&&"gutters"],region:["region"]};return(0,mn.A)(a,Q2,t)})(k),A=(0,O.A)({transition:f},h),T=(0,O.A)({transition:m},p),[M,C]=Dq("transition",{elementType:hY,externalForwardedProps:{slots:A,slotProps:T},ownerState:k});return(0,j.jsxs)(r3,(0,O.A)({className:(0,fn.A)(S.root,o),ref:t,ownerState:k,square:d},g,{children:[(0,j.jsx)(W2.Provider,{value:w,children:b}),(0,j.jsx)(M,(0,O.A)({in:y,timeout:"auto"},C,{children:(0,j.jsx)("div",{"aria-labelledby":b.props.id,id:b.props["aria-controls"],role:"region",className:S.region,children:_})}))]}))})),i3=(0,yn.Ay)((e=>(0,j.jsx)(n3,{disableGutters:!0,elevation:0,square:!0,...e})))((e=>{let{theme:t}=e;return{border:"1px solid",borderColor:t.palette.divider,boxShadow:"none",overflow:"hidden","&:before":{display:"none"}}})),o3=(0,n.memo)((function(e){let{label:t,onChange:r,value:n}=e;return(0,j.jsxs)(Mf,{container:!0,component:"label",alignItems:"center",justifyContent:"space-between",marginBottom:2,children:[(0,j.jsx)(Mf,{item:!0,children:(0,j.jsx)(Hi,{fontSize:"0.95rem",fontWeight:"bold",color:"text.secondary",children:t})}),(0,j.jsx)(Mf,{item:!0,children:(0,j.jsx)(wH,{checked:n,onChange:r})})]})})),a3=(0,yn.Ay)((e=>(0,j.jsx)(yi,{marginBottom:2,children:(0,j.jsx)(gH,{variant:"outlined",fullWidth:!0,...e})})))((e=>{let{theme:t}=e;return{"& .MuiInputLabel-root":{"&.MuiInputLabel-formControl":{position:"static",transform:"none",transition:"none",fontWeight:"bold",fontSize:"0.95rem",color:t.palette.text.secondary}},"& .MuiOutlinedInput-root":{marginTop:0},"& .MuiOutlinedInput-input":{paddingTop:"10px",paddingBottom:"8px",height:"auto"},"& .MuiOutlinedInput-notchedOutline":{top:0,"& legend":{display:"none"}}}}));function s3(e){let{paramSelector:t,paramValueSelector:r,paramUpdateActionCreator:i,requireConfirm:o}=e;function a(e){return[x(r(e)),(t,r)=>i(e,t,r)]}const s=(0,n.memo)((function(e){let{name:t,path:r,pipelineStatus:i}=e;const s=C(),[l,c]=(0,n.useState)(),[u,d]=a(r),h=(0,n.useRef)(Array.isArray(u)),p=x(Uk),{onOpenClearWorkflowIdDialog:f}=(0,n.useContext)(qJ);(0,n.useEffect)((()=>{c(u)}),[]),(0,n.useEffect)((()=>{i===Tk&&c(u)}),[i]);const m=e=>e.split(",").filter(Boolean).map((e=>Number(e)?Number(e):e)),g=Array.isArray(u)?u.toLocaleString():u||"";return(0,j.jsx)(a3,{label:t,value:void 0===g?"":g,onChange:e=>{const t=e.target.value;o&&null!=p?f({open:!0,handleOk:()=>{s(d(t,l))},handleCancel:()=>null}):s(d(t,l))},onBlur:h.current?e=>{const t=e.target.value;o&&null!=p?f({open:!0,handleOk:()=>{s(d(m(t.toString()),m(l.toString())))},handleCancel:()=>null}):s(d(m(t.toString()),m(l.toString())))}:void 0})})),l=(0,n.memo)((function(e){let{name:t,path:r,pipelineStatus:i}=e;const s=C(),[l,c]=a(r),[u,d]=(0,n.useState)(),h=x(Uk),{onOpenClearWorkflowIdDialog:p}=(0,n.useContext)(qJ);if((0,n.useEffect)((()=>{d(l)}),[]),(0,n.useEffect)((()=>{i===Tk&&d(l)}),[i]),"number"===typeof l){const e=e=>{const t=""===e.target.value?"":Number(e.target.value);"number"===typeof t&&(o&&null!=h?p({open:!0,handleOk:()=>{s(c(t,u))},handleCancel:()=>null}):s(c(t,u)))};return(0,j.jsx)(a3,{type:"number",label:t,value:l,onChange:e})}return null})),c=(0,n.memo)((function(e){let{name:t,path:r,pipelineStatus:i}=e;const s=C(),[l,c]=(0,n.useState)(),[u,d]=a(r),h=x(Uk),{onOpenClearWorkflowIdDialog:p}=(0,n.useContext)(qJ);if((0,n.useEffect)((()=>{c(u)}),[]),(0,n.useEffect)((()=>{i===Tk&&c(u)}),[i]),"boolean"===typeof u){const e=()=>{o&&null!=h?p({open:!0,handleOk:()=>{s(d(!u,l))},handleCancel:()=>null}):s(d(!u,l))};return(0,j.jsx)(o3,{label:t,value:u,onChange:e})}return null})),u=(0,n.memo)((function(e){let{name:t,path:r}=e;const n=x(Gk),[i]=a(r);return"number"===typeof i?(0,j.jsx)(l,{name:t,path:r,pipelineStatus:n}):"string"===typeof i?(0,j.jsx)(s,{name:t,path:r,pipelineStatus:n}):"boolean"===typeof i?(0,j.jsx)(c,{name:t,path:r,pipelineStatus:n}):(0,j.jsx)(s,{name:t,path:r,pipelineStatus:n})})),d=(0,n.memo)((function(e){let{path:t,name:r}=e;return(0,j.jsx)(u,{name:r,path:t})})),h=(0,n.memo)((function e(t){let{paramKey:r,param:n}=t;return RJ(n)?(0,j.jsx)(d,{path:n.path,name:r}):(0,j.jsxs)(i3,{children:[(0,j.jsx)(J2,{expandIcon:(0,j.jsx)(B2.A,{}),children:r}),(0,j.jsx)($2,{children:(0,j.jsx)("div",{children:Object.entries(n.children).map((t=>{let[r,n]=t;return(0,j.jsx)(e,{param:n,paramKey:r},r)}))})})]})}));return(0,n.memo)((function(e){let{paramKey:r}=e;const n=x(t(r));return(0,j.jsx)(h,{paramKey:r,param:n})}))}const l3=jl("NWB/getNWBParams",(async(e,t)=>{const{rejectWithValue:r}=t;try{return await async function(){return(await wd.get(`${bd}/nwb`)).data}()}catch(ene){return r(ene)}})),c3=e=>e.nwb,u3=e=>Object.keys(c3(e).params),d3=e=>t=>c3(t).params[e],h3=e=>t=>{const r=c3(t).params;if(null!=r){const t=OJ(e,r);return null===t||void 0===t?void 0:t.value}throw new Error("Param is null")},p3={params:{}},f3=Pl({name:"NWB",initialState:p3,reducers:{updateParam:(e,t)=>{const{path:r,newValue:n}=t.payload,i=OJ(r,e.params);null!=i&&(i.value=n)}},extraReducers:e=>{e.addCase(l3.fulfilled,((e,t)=>{e.params=LJ(t.payload)})).addCase(pk,(()=>p3))}}),{updateParam:m3}=f3.actions,g3=f3.reducer,y3=(0,n.memo)((function(){const e=C(),t=x(u3,vY);return(0,n.useEffect)((()=>{0===t.length&&e(l3())})),(0,j.jsx)("div",{className:"nwbParam",style:{margin:24},children:t.map(((e,t)=>(0,j.jsx)(v3,{paramKey:e},t)))})})),v3=(0,n.memo)((function(e){let{paramKey:t}=e;const r=s3({paramSelector:d3,paramValueSelector:h3,paramUpdateActionCreator:(e,t)=>m3({path:e,newValue:t}),requireConfirm:!0});return(0,j.jsx)(r,{paramKey:t})})),x3="algorithmNode",b3=jl(`${x3}/getAlgoParams`,(async(e,t)=>{let{algoName:r}=e;const{rejectWithValue:n}=t;try{return await $w(r)}catch(ene){return n(ene)}})),_3={},w3=Pl({name:x3,initialState:_3,reducers:{updateParam:(e,t)=>{const{nodeId:r,path:n,newValue:i,initValue:o}=t.payload,a=e[r].params;if(null!=a){const t=OJ(n,a);null!=t&&(t.value=i,e[r].isUpdate=!(JSON.stringify(o)===JSON.stringify(i)))}}},extraReducers:e=>{e.addCase(b3.fulfilled,((e,t)=>{const{nodeId:r}=t.meta.arg;e[r].params=LJ(t.payload)})).addCase(Ww.fulfilled,((e,t)=>{var r;const{node:n,functionPath:i,name:o,runAlready:a}=t.meta.arg,s=t.payload;var l;(null===(r=n.data)||void 0===r?void 0:r.type)===mw&&(e[n.id]={functionPath:i,name:o,params:LJ(s),originalValue:null===(l=e[n.id])||void 0===l?void 0:l.originalValue,isUpdate:null!==a&&void 0!==a&&a})})).addCase(pk,(()=>_3)).addCase(xk,((e,t)=>{t.payload.forEach((t=>{var r;(null===(r=t.data)||void 0===r?void 0:r.type)===mw&&delete e[t.id]}))})).addCase(_k,((e,t)=>{Object.keys(e).includes(t.payload)&&delete e[t.payload]})).addMatcher(Bl(nk.fulfilled,ik.fulfilled,ok.fulfilled),((e,t)=>{const r={};return Object.values(t.payload.nodeDict).filter(_w).forEach((e=>{null!=e.data&&(r[e.id]={name:e.data.label,functionPath:e.data.path,params:e.data.param,originalValue:e.data.param,isUpdate:!1})})),r})).addMatcher(Bl(Qk.fulfilled,eS.fulfilled),((e,t)=>{const r=t.meta.arg.runPostData;Object.values(r.nodeDict).filter(_w).forEach((t=>{e[t.id].isUpdate=!1}))}))}}),{updateParam:k3}=w3.actions,S3=w3.reducer,A3=(0,n.memo)((function(){const e=(0,n.useContext)(I3),t=C(),r=x(zJ(e)),i=x((e=>t=>null!==DJ(e)(t).params)(e)),o=x((e=>t=>{var r,n;return Object.keys(null!==(r=null===(n=DJ(e)(t))||void 0===n?void 0:n.params)&&void 0!==r?r:{})})(e),vY);return(0,n.useEffect)((()=>{i||t(b3({nodeId:e,algoName:r}))}),[t,e,r,i]),(0,j.jsxs)("div",{style:{padding:24},children:[(0,j.jsx)(_Z,{children:r}),o.map((e=>(0,j.jsx)(T3,{paramKey:e},e)))]})})),T3=(0,n.memo)((function(e){let{paramKey:t}=e;const r=(0,n.useContext)(I3),i=s3({paramSelector:e=>((e,t)=>r=>{const n=jJ(e)(r);if(null!=n)return n[t];throw new Error("AlgorithmParam is null")})(r,e),paramValueSelector:e=>((e,t)=>r=>{const n=jJ(e)(r);if(null!=n){const e=OJ(t,n);return null===e||void 0===e?void 0:e.value}throw new Error("AlgorithmParam is null")})(r,e),paramUpdateActionCreator:(e,t,n)=>k3({nodeId:r,path:e,newValue:t,initValue:n})});return(0,j.jsx)(i,{paramKey:t})})),M3=e=>e.rightDrawer.open,C3=e=>e.rightDrawer.mode,E3=e=>e.rightDrawer.currendNodeId,I3=(0,n.createContext)(""),P3=()=>{const e=x(E3);return null!=e?(0,j.jsx)(I3.Provider,{value:e,children:(0,j.jsx)(A3,{})}):null};const O3="Snakemake",R3=jl(`${O3}/getSnakemakeParams`,(async(e,t)=>{const{rejectWithValue:r}=t;try{return async function(){return(await wd.get(`${bd}/snakemake`)).data}()}catch(ene){return r(ene)}})),L3=e=>(e=>e.snakemake)(e).params,D3=e=>Object.keys(L3(e)),z3=e=>t=>L3(t)[e],j3=e=>t=>{const r=L3(t);if(null!=r){const t=OJ(e,r);return null===t||void 0===t?void 0:t.value}throw new Error("Param is null")},F3={params:{}},N3=Pl({name:O3,initialState:F3,reducers:{updateParam:(e,t)=>{const{path:r,newValue:n}=t.payload,i=OJ(r,e.params);null!=i&&(i.value=n)}},extraReducers:e=>{e.addCase(R3.fulfilled,((e,t)=>{e.params=LJ(t.payload)})).addCase(pk,(()=>F3))}}),{updateParam:B3}=N3.actions,V3=N3.reducer,U3=(0,n.memo)((function(){const e=C(),t=x(D3,vY);return(0,n.useEffect)((()=>{0===t.length&&e(R3())})),(0,j.jsx)("div",{className:"SnakemakeParam",style:{margin:24},children:t.map(((e,t)=>(0,j.jsx)(H3,{paramKey:e},t)))})})),H3=(0,n.memo)((function(e){let{paramKey:t}=e;const r=s3({paramSelector:z3,paramValueSelector:j3,paramUpdateActionCreator:(e,t)=>B3({path:e,newValue:t}),requireConfirm:!0});return(0,j.jsx)(r,{paramKey:t})})),$3=()=>{switch(x(C3)){case q0:return(0,j.jsx)(y3,{});case G0:return(0,j.jsx)(P3,{});case Y0:return(0,j.jsx)(U3,{});default:return null}},W3=(0,yn.Ay)($C)({width:320,flexShrink:0,[`& .${zC.paper}`]:{width:320}}),q3=(0,yn.Ay)("main")({height:"100%"}),G3=()=>{const e=x(M3),t=C(),r=x((e=>{switch(C3(e)){case q0:return"NWB Setting";case G0:return"Param Form";case Y0:return"Snakemake";default:return"none"}}));return(0,j.jsxs)(W3,{open:e,anchor:"right",variant:"persistent",children:[(0,j.jsx)(ji,{}),(0,j.jsxs)(yi,{display:"flex",alignItems:"center",children:[(0,j.jsx)(oi,{color:"inherit",onClick:()=>t(t1()),size:"large",children:(0,j.jsx)(N2.A,{})}),(0,j.jsx)(Hi,{variant:"h6",children:r})]}),(0,j.jsx)(yU,{}),(0,j.jsx)(q3,{children:(0,j.jsx)($3,{})})]})};function Y3(e){return(0,n.useMemo)((()=>e.hooks.dragSource()),[e])}function X3(e){return(0,n.useMemo)((()=>e.hooks.dragPreview()),[e])}class Z3{receiveHandlerId(e){this.handlerId!==e&&(this.handlerId=e,this.reconnect())}get connectTarget(){return this.dragSource}get dragSourceOptions(){return this.dragSourceOptionsInternal}set dragSourceOptions(e){this.dragSourceOptionsInternal=e}get dragPreviewOptions(){return this.dragPreviewOptionsInternal}set dragPreviewOptions(e){this.dragPreviewOptionsInternal=e}reconnect(){const e=this.reconnectDragSource();this.reconnectDragPreview(e)}reconnectDragSource(){const e=this.dragSource,t=this.didHandlerIdChange()||this.didConnectedDragSourceChange()||this.didDragSourceOptionsChange();return t&&this.disconnectDragSource(),this.handlerId?e?(t&&(this.lastConnectedHandlerId=this.handlerId,this.lastConnectedDragSource=e,this.lastConnectedDragSourceOptions=this.dragSourceOptions,this.dragSourceUnsubscribe=this.backend.connectDragSource(this.handlerId,e,this.dragSourceOptions)),t):(this.lastConnectedDragSource=e,t):t}reconnectDragPreview(){let e=arguments.length>0&&void 0!==arguments[0]&&arguments[0];const t=this.dragPreview,r=e||this.didHandlerIdChange()||this.didConnectedDragPreviewChange()||this.didDragPreviewOptionsChange();r&&this.disconnectDragPreview(),this.handlerId&&(t?r&&(this.lastConnectedHandlerId=this.handlerId,this.lastConnectedDragPreview=t,this.lastConnectedDragPreviewOptions=this.dragPreviewOptions,this.dragPreviewUnsubscribe=this.backend.connectDragPreview(this.handlerId,t,this.dragPreviewOptions)):this.lastConnectedDragPreview=t)}didHandlerIdChange(){return this.lastConnectedHandlerId!==this.handlerId}didConnectedDragSourceChange(){return this.lastConnectedDragSource!==this.dragSource}didConnectedDragPreviewChange(){return this.lastConnectedDragPreview!==this.dragPreview}didDragSourceOptionsChange(){return!o0(this.lastConnectedDragSourceOptions,this.dragSourceOptions)}didDragPreviewOptionsChange(){return!o0(this.lastConnectedDragPreviewOptions,this.dragPreviewOptions)}disconnectDragSource(){this.dragSourceUnsubscribe&&(this.dragSourceUnsubscribe(),this.dragSourceUnsubscribe=void 0)}disconnectDragPreview(){this.dragPreviewUnsubscribe&&(this.dragPreviewUnsubscribe(),this.dragPreviewUnsubscribe=void 0,this.dragPreviewNode=null,this.dragPreviewRef=null)}get dragSource(){return this.dragSourceNode||this.dragSourceRef&&this.dragSourceRef.current}get dragPreview(){return this.dragPreviewNode||this.dragPreviewRef&&this.dragPreviewRef.current}clearDragSource(){this.dragSourceNode=null,this.dragSourceRef=null}clearDragPreview(){this.dragPreviewNode=null,this.dragPreviewRef=null}constructor(e){this.hooks=l0({dragSource:(e,t)=>{this.clearDragSource(),this.dragSourceOptions=t||null,a0(e)?this.dragSourceRef=e:this.dragSourceNode=e,this.reconnectDragSource()},dragPreview:(e,t)=>{this.clearDragPreview(),this.dragPreviewOptions=t||null,a0(e)?this.dragPreviewRef=e:this.dragPreviewNode=e,this.reconnectDragPreview()}}),this.handlerId=null,this.dragSourceRef=null,this.dragSourceOptionsInternal=null,this.dragPreviewRef=null,this.dragPreviewOptionsInternal=null,this.lastConnectedHandlerId=null,this.lastConnectedDragSource=null,this.lastConnectedDragSourceOptions=null,this.lastConnectedDragPreview=null,this.lastConnectedDragPreviewOptions=null,this.backend=e}}let K3=!1,J3=!1;class Q3{receiveHandlerId(e){this.sourceId=e}getHandlerId(){return this.sourceId}canDrag(){UY(!K3,"You may not call monitor.canDrag() inside your canDrag() implementation. Read more: http://react-dnd.github.io/react-dnd/docs/api/drag-source-monitor");try{return K3=!0,this.internalMonitor.canDragSource(this.sourceId)}finally{K3=!1}}isDragging(){if(!this.sourceId)return!1;UY(!J3,"You may not call monitor.isDragging() inside your isDragging() implementation. Read more: http://react-dnd.github.io/react-dnd/docs/api/drag-source-monitor");try{return J3=!0,this.internalMonitor.isDraggingSource(this.sourceId)}finally{J3=!1}}subscribeToStateChange(e,t){return this.internalMonitor.subscribeToStateChange(e,t)}isDraggingSource(e){return this.internalMonitor.isDraggingSource(e)}isOverTarget(e,t){return this.internalMonitor.isOverTarget(e,t)}getTargetIds(){return this.internalMonitor.getTargetIds()}isSourcePublic(){return this.internalMonitor.isSourcePublic()}getSourceId(){return this.internalMonitor.getSourceId()}subscribeToOffsetChange(e){return this.internalMonitor.subscribeToOffsetChange(e)}canDragSource(e){return this.internalMonitor.canDragSource(e)}canDropOnTarget(e){return this.internalMonitor.canDropOnTarget(e)}getItemType(){return this.internalMonitor.getItemType()}getItem(){return this.internalMonitor.getItem()}getDropResult(){return this.internalMonitor.getDropResult()}didDrop(){return this.internalMonitor.didDrop()}getInitialClientOffset(){return this.internalMonitor.getInitialClientOffset()}getInitialSourceClientOffset(){return this.internalMonitor.getInitialSourceClientOffset()}getSourceClientOffset(){return this.internalMonitor.getSourceClientOffset()}getClientOffset(){return this.internalMonitor.getClientOffset()}getDifferenceFromInitialOffset(){return this.internalMonitor.getDifferenceFromInitialOffset()}constructor(e){this.sourceId=null,this.internalMonitor=e.getMonitor()}}class e5{beginDrag(){const e=this.spec,t=this.monitor;let r=null;return r="object"===typeof e.item?e.item:"function"===typeof e.item?e.item(t):{},null!==r&&void 0!==r?r:null}canDrag(){const e=this.spec,t=this.monitor;return"boolean"===typeof e.canDrag?e.canDrag:"function"!==typeof e.canDrag||e.canDrag(t)}isDragging(e,t){const r=this.spec,n=this.monitor,{isDragging:i}=r;return i?i(n):t===e.getSourceId()}endDrag(){const e=this.spec,t=this.monitor,r=this.connector,{end:n}=e;n&&n(t.getItem(),t),r.reconnect()}constructor(e,t,r){this.spec=e,this.monitor=t,this.connector=r}}function t5(e,t,r){const i=d0(),o=function(e,t,r){const i=(0,n.useMemo)((()=>new e5(e,t,r)),[t,r]);return(0,n.useEffect)((()=>{i.spec=e}),[e]),i}(e,t,r),a=function(e){return(0,n.useMemo)((()=>{const t=e.type;return UY(null!=t,"spec.type must be defined"),t}),[e])}(e);e0((function(){if(null!=a){const[e,n]=function(e,t,r){const n=r.getRegistry(),i=n.addSource(e,t);return[i,()=>n.removeSource(i)]}(a,o,i);return t.receiveHandlerId(e),r.receiveHandlerId(e),n}}),[i,t,r,o,a])}function r5(e,t){const r=n0(e,t);UY(!r.begin,"useDrag::spec.begin was deprecated in v14. Replace spec.begin() with spec.item(). (see more here - https://react-dnd.github.io/react-dnd/docs/api/use-drag)");const i=function(){const e=d0();return(0,n.useMemo)((()=>new Q3(e)),[e])}(),o=function(e,t){const r=d0(),i=(0,n.useMemo)((()=>new Z3(r.getBackend())),[r]);return e0((()=>(i.dragSourceOptions=e||null,i.reconnect(),()=>i.disconnectDragSource())),[i,e]),e0((()=>(i.dragPreviewOptions=t||null,i.reconnect(),()=>i.disconnectDragPreview())),[i,t]),i}(r.options,r.previewOptions);return t5(r,i,o),[r0(r.collect,i,o),Y3(o),X3(o)]}var n5=r(22505);const i5="algorithmList",o5=jl(`${i5}/getAlgoList`,(async(e,t)=>{const{rejectWithValue:r}=t;try{return await async function(){return(await wd.get(`${bd}/algolist`)).data}()}catch(ene){return r(ene)}}));const a5=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:21;return function(){let r="",n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:t;for(;n--;)r+=e[Math.random()*e.length|0];return r}}("0123456789abcdefghijklmnopqrstuvwxyz",10),s5=()=>a5(),l5=(0,n.memo)((function(){const e=C(),t=x($0),r=x(H0),i="undefined"!==typeof x(Uk);(0,n.useEffect)((()=>{r||e(o5())}),[e,r]);const o=(0,n.useCallback)(((t,r,n)=>{const o=t,a={id:`${o}_${s5()}`,type:Iw,data:{label:o,type:mw},position:n};e(Ww({node:a,name:o,functionPath:r,runAlready:i}))}),[e,i]);return(0,j.jsxs)($Q,{sx:{flexGrow:1,height:"100%"},defaultCollapseIcon:(0,j.jsx)(B2.A,{}),defaultExpandIcon:(0,j.jsx)(N2.A,{}),children:[(0,j.jsxs)(hQ,{nodeId:"Data",label:"Data",children:[(0,j.jsx)(c5,{fileName:"image",nodeName:"imageData",fileType:Xw}),(0,j.jsx)(c5,{fileName:"csv",nodeName:"csvData",fileType:Yw}),(0,j.jsx)(c5,{fileName:"hdf5",nodeName:"hdf5Data",fileType:Zw}),(0,j.jsx)(c5,{fileName:"fluo",nodeName:"fluoData",fileType:Kw}),(0,j.jsx)(c5,{fileName:"behavior",nodeName:"behaviorData",fileType:Jw}),(0,j.jsx)(c5,{fileName:"matlab",nodeName:"matlabData",fileType:Qw}),(0,j.jsx)(c5,{fileName:"microscope",nodeName:"microscopeData",fileType:ek})]}),(0,j.jsx)(hQ,{nodeId:"Algorithm",label:"Algorithm",children:Object.entries(t).map(((e,t)=>{let[r,n]=e;return(0,j.jsx)(u5,{name:r,node:n,onAddAlgoNode:o},t.toFixed())}))})]})})),c5=(0,n.memo)((function(e){let{fileName:t,nodeName:r,fileType:i}=e;const o=C(),a=(0,n.useCallback)(((e,t,r,n)=>{let i="";switch(r){case Yw:i=Mw;break;case Xw:i=Tw,r=Xw;break;case Zw:i=Cw,r=Zw;break;case Kw:i=Ew,r=Kw;break;case Jw:i=Pw,r=Jw;break;case Qw:i=Ow,r=Qw;break;case ek:i=Rw,r=ek}const a={id:`input_${s5()}`,type:i,data:{label:t,type:e},position:n};o(qw({node:a,fileType:r}))}),[o]),{isDragging:s,dragRef:l}=f5((0,n.useCallback)((e=>{a(fw,r,i,e)}),[a,r,i]));return(0,j.jsx)(p5,{ref:l,style:{opacity:s?.6:1},onFocusCapture:e=>e.stopPropagation(),nodeId:t,label:(0,j.jsx)(h5,{name:t,onClick:()=>a(fw,r,i)})})})),u5=(0,n.memo)((function e(t){let{name:r,node:n,onAddAlgoNode:i}=t;return N0(n)?(0,j.jsx)(d5,{name:r,node:n,onAddAlgoNode:i}):(0,j.jsx)(hQ,{nodeId:r,label:r,children:Object.entries(n.children).map(((t,r)=>{let[n,o]=t;return(0,j.jsx)(e,{name:n,node:o,onAddAlgoNode:i},r.toFixed())}))})})),d5=(0,n.memo)((function(e){let{name:t,node:r,onAddAlgoNode:i}=e;const{isDragging:o,dragRef:a}=f5((0,n.useCallback)((e=>{i(t,r.functionPath,e)}),[i,t,r]));return(0,j.jsx)(p5,{ref:a,style:{opacity:o?.6:1},onFocusCapture:e=>e.stopPropagation(),nodeId:t,label:(0,j.jsx)(h5,{name:t,onClick:()=>i(t,r.functionPath)})})})),h5=(0,n.memo)((function(e){let{name:t,onClick:r}=e;return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(oi,{"aria-label":"add",style:{padding:2},size:"large",onClick:r,children:(0,j.jsx)(n5.A,{})}),(0,j.jsx)(Hi,{variant:"inherit",style:{textOverflow:"ellipsis",overflow:"visible",width:"8rem",display:"inline-block"},children:t})]})})),p5=(0,yn.Ay)(hQ)({[`& .${sQ.iconContainer}`]:{margin:0,width:0}});function f5(e){const[{isDragging:t},r]=r5((()=>({type:T0,end:(t,r)=>{var n;const i=null===(n=r.getDropResult())||void 0===n?void 0:n.position;r.didDrop()&&null!=i&&e(i)},collect:e=>({isDragging:e.isDragging()})})),[e]);return{isDragging:t,dragRef:r}}const m5=e=>{let{open:t,value:r,setValue:i,handleClose:o,onLoadFileViaUrl:a,setError:s,error:l,fileType:c}=e;const[u,d]=(0,n.useState)(!1),h=e=>{const t=c===Lw.IMAGE?[".tiff",".tif"]:c===Lw.CSV?[".csv"]:c===Lw.HDF5?[".hdf5",".nwb"]:void 0,r=e.substring(e.lastIndexOf("."));if(e)if(e.startsWith("http://")||e.startsWith("https://"))if(!t||t.includes(r))s("");else{const e=1===t.length?t[0]:t.join(" or ");s(`Please enter a valid Image file URL ending with ${e}`)}else s("Please enter a valid URL starting with http:// or https://");else s("url can't be empty")},p=()=>{s(""),o()};return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsxs)(Wp,{open:t,onClose:p,fullWidth:!0,children:[(0,j.jsx)(Zp,{children:"Upload file via URL"}),(0,j.jsxs)(ef,{children:[(0,j.jsx)(gH,{margin:"dense",id:"name",label:"Link url",fullWidth:!0,variant:"standard",value:r,onChange:e=>{const{value:t}=e.target;i(t),h(t)},onBlur:()=>{h(r)}}),(0,j.jsx)(Hi,{sx:{color:"red"},children:l})]}),(0,j.jsxs)(of,{children:[(0,j.jsx)(gf,{onClick:p,variant:"outlined",children:"Cancel"}),(0,j.jsx)(gf,{disabled:!!l||!r,onClick:()=>{d(!0)},variant:"contained",children:"Load"})]})]}),(0,j.jsx)(Cf,{open:u,title:"Upload file from following URL?",content:r,setOpen:d,onConfirm:()=>{a(),i("")}})]})},g5={filePath:"",open:!1,fileTreeType:void 0,multiSelect:!1,onSelectFile:()=>null},y5={open:!1,handleOk:()=>null,handleCancel:()=>null},v5=(0,n.memo)((function(e){const t=C(),r=x(M3),i=x(jf),[o,a]=(0,n.useState)(""),[s,l]=(0,n.useState)(g5),[c,u]=(0,n.useState)(y5),[d,h]=(0,n.useState)({anchorElRef:{current:null},message:""}),[p,f]=(0,n.useState)({open:!1,nodeId:"",requestId:""}),[m,g]=(0,n.useState)(""),[y,v]=(0,n.useState)(""),{enqueueSnackbar:b}=hn(),_=(e,t)=>{b(t,{variant:e})};return(0,j.jsx)(yi,{display:"flex",children:(0,j.jsxs)(qJ.Provider,{value:{onOpenOutputDialog:a,onOpenFileSelectDialog:l,onOpenClearWorkflowIdDialog:u,onOpenInputUrlDialog:f,onMessageError:h},children:[(0,j.jsxs)(XX,{backend:yZ,children:[(0,j.jsxs)(yi,{width:240,borderRight:1,borderColor:vZ.A[300],children:[(0,j.jsx)(yi,{overflow:"auto",marginRight:2,children:(0,j.jsx)(SZ,{})}),!1,(0,j.jsxs)(yi,{overflow:"auto",children:[(0,j.jsx)(_Z,{children:"Nodes"}),(0,j.jsx)(l5,{})]})]}),(0,j.jsxs)(x5,{open:r,children:[(0,j.jsx)(F2,{...e}),o&&(0,j.jsx)(BJ,{nodeId:o,open:!0,onClose:()=>a("")}),s.open&&(0,j.jsx)(YQ,{multiSelect:s.multiSelect,initialFilePath:s.filePath,open:s.open,onClickOk:e=>{s.onSelectFile(e),l(g5)},onClickCancel:()=>{l(g5)},fileType:s.fileTreeType}),c.open&&(0,j.jsx)(WJ,{open:c.open,onConfirm:()=>{t(ZG()),c.handleOk(),u(y5)},onCancel:()=>{c.handleCancel(),u(y5)}}),p.fileType?(0,j.jsx)(m5,{open:p.open,value:m,setValue:g,handleClose:()=>{g(""),f({...p,open:!1})},onLoadFileViaUrl:async()=>{if(!i||!m)return;f({...p,open:!1});const e=await t(Uw({workspaceId:i,url:m,requestId:p.requestId}));if(e.error)return void _("error","Url does not exist!");let r=!0;const n=async()=>{const o=await t(Hw({workspaceId:i,file_name:e.payload.file_name,requestId:p.requestId}));o.payload.current!==o.payload.total?r?(r=!1,n()):setTimeout(n,1e3):(_("success","File upload finished!"),t(tk({nodeId:p.nodeId,filePath:e.payload.file_name})))};n(),l({...s,filePath:[e.payload.file_name]})},setError:v,error:y,fileType:p.fileType}):null,(null===d||void 0===d?void 0:d.message)&&(0,j.jsx)(Aa,{open:!0,anchorEl:d.anchorElRef.current,onClose:()=>h({anchorElRef:{current:null},message:""}),anchorOrigin:{vertical:"top",horizontal:"right"},transformOrigin:{vertical:"bottom",horizontal:"left"},children:(0,j.jsx)("div",{style:{margin:8,whiteSpace:"pre-wrap"},children:(0,j.jsx)(dH,{error:!0,children:d.message})})})]})]}),(0,j.jsx)(G3,{})]})})})),x5=(0,yn.Ay)("main")((e=>{let{theme:t}=e;return{flexDirection:"column",flexGrow:1,minHeight:kC,transition:t.transitions.create("margin",{easing:t.transitions.easing.sharp,duration:t.transitions.duration.leavingScreen}),marginRight:-320}}),(e=>{let{open:t,theme:r}=e;return t?{transition:r.transitions.create("margin",{easing:r.transitions.easing.easeOut,duration:r.transitions.duration.enteringScreen}),marginRight:0}:void 0})),b5=v5,_5=(0,Ud.A)((0,j.jsx)("path",{d:"m20.5 10 .5-2h-4l1-4h-2l-1 4h-4l1-4h-2L9 8H5l-.5 2h4l-1 4h-4L3 16h4l-1 4h2l1-4h4l-1 4h2l1-4h4l.5-2h-4l1-4zm-7 4h-4l1-4h4z"}),"Numbers"),w5=(0,Ud.A)((0,j.jsx)("path",{d:"M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"}),"Close");function k5(e,t){return(0,n.useCallback)((t=>{const{onMouseMove:r,onMouseUp:n}=e(t);document.addEventListener("mousemove",r),document.addEventListener("mouseup",(e=>{document.removeEventListener("mousemove",r),n.call(document,e)}),{once:!0})}),[t])}const S5=e=>{let{dataType:t,selectedNodeId:r,selectedFilePath:i,onSelect:o,label:a}=e;const s=x((e=>{const r=(e=>e.inputNode)(e);return Object.entries(r).map((t=>{let[r,n]=t;return{nodeId:r,filePath:n.selectedFilePath,fileType:n.fileType,dataType:A5(n.fileType),nodeName:NY(r)(e)}})).filter((e=>{let{filePath:t}=e;return null!=t})).filter((e=>{let{dataType:r}=e;return null==t||r===t}))}),((e,t)=>e.length===t.length&&e.every(((e,r)=>e.filePath===t[r].filePath&&e.fileType===t[r].fileType&&e.dataType===t[r].dataType&&e.nodeName===t[r].nodeName)))),l=x(Uk),c=x((e=>{if(null!=l){const r=(e=>{const t=$k(e);return Fk(t)?Object.entries(t.runResult).map((e=>{let[t,r]=e;return{nodeId:t,nodeResult:r}})).filter(Zk):[]})(e);return r.map((r=>{let{nodeId:n,nodeResult:i}=r;return{nodeId:n,nodeName:NY(n)(e),paths:Object.entries(i.outputPaths).map((e=>{let[t,r]=e;return{outputKey:t,filePath:r.path,type:r.type}})).filter((e=>{let{type:r}=e;return null==t||r===t}))}}))}return[]}),((e,t)=>e.length===t.length&&e.every(((e,r)=>{const n=t[r];return e.nodeId===n.nodeId&&e.nodeName===n.nodeName&&e.paths.length===n.paths.length&&e.paths.every(((e,t)=>e.outputKey===n.paths[t].outputKey&&e.filePath===n.paths[t].filePath&&e.type===n.paths[t].type))})))),[u,d]=(0,n.useState)(!1),h=()=>{d(!1)},p=(e,t,r,n)=>{o(e,t,r,n),h()},f=[];return s.forEach((e=>{const t=e.filePath;Array.isArray(t)?t.forEach((t=>{f.push((0,j.jsx)(qa,{value:e.nodeId&&t?`${e.nodeId}/${t}`:"",onClick:()=>p(e.nodeId,null!==t&&void 0!==t?t:"",e.dataType),children:xw(t)},e.nodeId))})):f.push((0,j.jsx)(qa,{value:e.nodeId&&e.filePath?`${e.nodeId}/${e.filePath}`:"",onClick:()=>p(e.nodeId,null!==t&&void 0!==t?t:"",e.dataType),children:e.nodeName},e.nodeId))})),c.forEach(((e,t)=>{f.push((0,j.jsx)(pL,{children:(0,j.jsx)(yU,{textAlign:"center",children:e.nodeName})},t)),e.paths.forEach((t=>{f.push((0,j.jsx)(qa,{value:e.nodeId&&t.filePath?`${e.nodeId}/${t.filePath}`:"",onClick:()=>p(e.nodeId,t.filePath,t.type,t.outputKey),children:t.outputKey},`${e.nodeId}/${t.filePath}`))}))})),(0,j.jsxs)(oH,{style:{minWidth:150,maxWidth:220},variant:"standard",children:[(0,j.jsx)(tH,{children:a||"Select Item"}),(0,j.jsx)(GN,{value:r&&i?`${r}/${i}`:"",open:u,onClose:h,onOpen:()=>{d(!0)},children:f}),s.length+c.length===0&&(0,j.jsx)(dH,{error:!0,children:"no data"})]})};function A5(e){switch(e){case Xw:return Yf;case Yw:return Xf;case Zw:return Qf;case Kw:return tm;case Jw:return rm;case Qw:case ek:return sm}}const T5=(0,n.memo)((function(e){let{itemId:t}=e;const r=C(),i=x((e=>oA(e)===t)),{size:o,onMouseDownX:a,onMouseDownY:s,onMouseDownXY:l}=function(e){const t=C(),r=x(uA(e)),i=x(dA(e)),[o,a]=(0,n.useState)({width:r,height:i}),s=(0,n.useCallback)((r=>t(OT({itemId:e,...r}))),[t,e]),l=k5((e=>{let t=e.screenX,r=o.width;return{onMouseMove:e=>{const n=r+(e.screenX-t);r=n>=I5?n:I5,a((e=>({...e,width:r}))),t=e.screenX},onMouseUp:()=>{s({...o,width:r})}}}),[o,s]),c=k5((e=>{let t=e.screenY,r=o.height;return{onMouseMove:e=>{const n=r+(e.screenY-t);r=n>=P5?n:P5,a((e=>({...e,height:r}))),t=e.screenY},onMouseUp:()=>{s({...o,height:r})}}}),[o,s]),u=k5((e=>{let t=e.screenX,r=o.width,n=e.screenY,i=o.height;return{onMouseMove:e=>{const o=r+(e.screenX-t);r=o>=I5?o:I5;const s=i+(e.screenY-n);i=s>=P5?s:P5,a({width:r,height:i}),t=e.screenX,n=e.screenY},onMouseUp:()=>{s({width:r,height:i})}}}),[o,s]);return{size:o,onMouseDownX:l,onMouseDownY:c,onMouseDownXY:u}}(t),c=x(SS),u=x(AS),[d,h]=(0,n.useState)("");return(0,j.jsxs)(yi,{sx:{m:1,display:"flex",flexDirection:"row",position:"relative"},children:[c&&d.includes("_roi.json")&&(0,j.jsx)(wi,{loading:c,position:u?"fixed":"absolute"}),(0,j.jsxs)(yi,{sx:{display:"flex",flexDirection:"column"},children:[(0,j.jsxs)(Ci,{variant:"outlined",onClick:()=>{r(RT(t))},sx:{width:`${o.width}px`,minHeight:`${o.height}px`,p:1,borderColor:e=>i?e.palette.primary.light:void 0},children:[(0,j.jsx)(M5,{itemId:t,setRoiFilePath:h}),(0,j.jsx)(IJ,{itemId:t})]},t),(0,j.jsxs)(yi,{sx:{display:"flex"},children:[(0,j.jsx)(yi,{sx:{flexGrow:1,position:"relative",top:"-2px",height:"4px",cursor:"row-resize"},onMouseDown:s}),(0,j.jsx)(yi,{sx:{position:"relative",top:"-2px",height:"4px",width:"12px",cursor:"nwse-resize"},onMouseDown:l})]})]}),(0,j.jsxs)(yi,{sx:{display:"flex",flexDirection:"column"},children:[(0,j.jsx)(yi,{sx:{flexGrow:1,position:"relative",left:"-2px",width:"4px",cursor:"col-resize"},onMouseDown:a}),(0,j.jsx)(yi,{sx:{position:"relative",height:"12px",width:"4px",left:"-2px",cursor:"nwse-resize"},onMouseDown:l})]})]})})),M5=(0,n.memo)((function(e){let{itemId:t,setRoiFilePath:r}=e;const n=x(hA(t)),i=x(fA(t)),o=x(XA(t)),a=C();return(0,j.jsxs)(yi,{display:"flex",justifyContent:"flex-end",children:[(0,j.jsxs)(yi,{flexGrow:1,display:"flex",children:[(0,j.jsx)(_L,{icon:(0,j.jsx)(_5,{}),size:"small",label:t,color:"primary",variant:"outlined",sx:{marginRight:2}}),(0,j.jsx)(C5,{itemId:t})]}),n===qf&&(0,j.jsx)(yi,{flexGrow:1,children:(0,j.jsx)(E5,{itemId:t})}),n===Yf&&(0,j.jsx)(yi,{flexGrow:1,children:(0,j.jsx)(O5,{itemId:t,setRoiFilePath:r})}),(0,j.jsx)(yi,{children:(0,j.jsx)(oi,{onClick:e=>{e.stopPropagation(),a(rT(o&&null!=i&&null!=n?{itemId:t,deleteData:!0,filePath:i,dataType:n}:{itemId:t,deleteData:!1}))},children:(0,j.jsx)(w5,{})})})]})})),C5=(0,n.memo)((function(e){let{itemId:t}=e;const r=C(),n=x(hA(t)),i=x(pA(t)),o=x(yA(t)),a=x(XA(t));return(0,j.jsx)(S5,{selectedNodeId:i,selectedFilePath:o,onSelect:(e,i,s)=>{const l={itemId:t,nodeId:e,filePath:i,dataType:s};r(nT(a&&null!=o?{...l,deleteData:!0,prevDataType:n,prevFilePath:o}:{...l,deleteData:!1}))}})})),E5=(0,n.memo)((function(e){let{itemId:t}=e;const r=C(),n=x(aA,vY),i=x((e=>t=>{const r=lA(e)(t);if(KS(r))return r.refImageItemId;throw new Error("invalid VisualaizeItemType")})(t));return(0,j.jsxs)(oH,{fullWidth:!0,variant:"standard",children:[(0,j.jsx)(tH,{children:"Link to box (#)"}),(0,j.jsxs)(GN,{value:String(i),onChange:e=>{const n=Number(e.target.value);r(hM({itemId:t,refImageItemId:isNaN(n)?null:n}))},children:[(0,j.jsx)(qa,{value:void 0,children:"None"}),n.map((e=>(0,j.jsx)(qa,{value:e,children:e},e)))]})]})})),I5=200,P5=150;const O5=(0,n.memo)((function(e){let{itemId:t,setRoiFilePath:r}=e;const i=C(),o=x((e=>t=>{const r=lA(e)(t);var n,i;if(ZS(r))return null!==(n=null===(i=r.roiItem)||void 0===i?void 0:i.nodeId)&&void 0!==n?n:null;throw new Error("invalid VisualaizeItemType")})(t)),a=x(xA(t));(0,n.useEffect)((()=>{a&&(null===r||void 0===r||r(a))}),[a]);return(0,j.jsx)(S5,{selectedFilePath:a,selectedNodeId:o,onSelect:(e,r,n,o)=>{i(BT({itemId:t,nodeId:e,filePath:r,outputKey:o}))},dataType:Zf,label:"Select Roi"})})),R5=e=>{let{itemId:t}=e;const r=C();return(0,j.jsx)(L5,{elevation:0,variant:"outlined",children:(0,j.jsx)(yi,{display:"flex",justifyContent:"center",alignItems:"center",height:"100%",children:(0,j.jsx)(D5,{onClick:()=>{r(null!=t?ET(t):CT())},children:(0,j.jsx)(n5.A,{fontSize:"large",color:"primary"})})})})},L5=(0,yn.Ay)(Ci)((e=>{let{theme:t}=e;return{width:260,height:255,border:"dashed",borderWidth:2,borderColor:t.palette.divider,margin:t.spacing(1)}})),D5=(0,yn.Ay)(gf)({width:"100%",height:"100%"}),z5=()=>{const e=x(cA,xY);return(0,j.jsxs)(yi,{display:"flex",flexWrap:"wrap",flexDirection:"column",p:1,m:1,children:[e.map(((e,t)=>(0,j.jsxs)(yi,{display:"flex",flexDirection:"row",children:[e.map((e=>(0,j.jsx)(T5,{itemId:e},e))),(0,j.jsx)(R5,{itemId:e[e.length-1]})]},t.toFixed()))),(0,j.jsx)(R5,{})]})},j5=()=>{const e=(0,n.useContext)(vre),t=x(fA(e));return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(Hi,{variant:"h6",fontWeight:"bold",children:"Csv"}),(0,j.jsx)(kZ,{filePath:t}),(0,j.jsx)(F5,{}),(0,j.jsx)(N5,{}),(0,j.jsx)(B5,{})]})},F5=()=>{const e=(0,n.useContext)(vre),t=x(HA(e)),r=C();return(0,j.jsx)(o3,{label:"Transpose",value:t,onChange:()=>{r(mM({itemId:e,transpose:!t}))}})},N5=()=>{const e=(0,n.useContext)(vre),t=x($A(e)),r=C();return(0,j.jsx)(a3,{label:"Header",value:t,type:"number",onChange:t=>{const n=""===t.target.value?null:Number(t.target.value);(null===n||n>=0)&&r(gM({itemId:e,setHeader:n}))}})},B5=()=>{const e=(0,n.useContext)(vre),t=x(WA(e)),r=C();return(0,j.jsx)(o3,{label:"SetIndex",value:t,onChange:()=>{r(yM({itemId:e,setIndex:!t}))}})};var V5=r(57514),U5={},H5=function(e,t,r,n){var i=e+"-"+t+"-"+r+(n?"-server":"");if(U5[i])return U5[i];var o=function(e,t,r,n){if("undefined"===typeof document&&!n)return null;var i=n?new n:document.createElement("canvas");i.width=2*r,i.height=2*r;var o=i.getContext("2d");return o?(o.fillStyle=e,o.fillRect(0,0,i.width,i.height),o.fillStyle=t,o.fillRect(0,0,r,r),o.translate(r,r),o.fillRect(0,0,r,r),i.toDataURL()):null}(e,t,r,n);return U5[i]=o,o},$5=Object.assign||function(e){for(var t=1;ta?1:Math.round(100*u/a)/100,t.a!==d)return{h:t.h,s:t.s,l:t.l,a:d,source:"rgb"}}else{var h=void 0;if(n!==(h=c<0?0:c>o?1:Math.round(100*c/o)/100))return{h:t.h,s:t.s,l:t.l,a:h,source:"rgb"}}return null}(e,n.props.hsl,n.props.direction,n.props.a,n.container);t&&"function"===typeof n.props.onChange&&n.props.onChange(t,e)},n.handleMouseDown=function(e){n.handleChange(e),window.addEventListener("mousemove",n.handleChange),window.addEventListener("mouseup",n.handleMouseUp)},n.handleMouseUp=function(){n.unbindEventListeners()},n.unbindEventListeners=function(){window.removeEventListener("mousemove",n.handleChange),window.removeEventListener("mouseup",n.handleMouseUp)},X5(n,r)}return function(e,t){if("function"!==typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}(t,e),Y5(t,[{key:"componentWillUnmount",value:function(){this.unbindEventListeners()}},{key:"render",value:function(){var e=this,t=this.props.rgb,r=(0,V5.Ay)({default:{alpha:{absolute:"0px 0px 0px 0px",borderRadius:this.props.radius},checkboard:{absolute:"0px 0px 0px 0px",overflow:"hidden",borderRadius:this.props.radius},gradient:{absolute:"0px 0px 0px 0px",background:"linear-gradient(to right, rgba("+t.r+","+t.g+","+t.b+", 0) 0%,\n rgba("+t.r+","+t.g+","+t.b+", 1) 100%)",boxShadow:this.props.shadow,borderRadius:this.props.radius},container:{position:"relative",height:"100%",margin:"0 3px"},pointer:{position:"absolute",left:100*t.a+"%"},slider:{width:"4px",borderRadius:"1px",height:"8px",boxShadow:"0 0 2px rgba(0, 0, 0, .6)",background:"#fff",marginTop:"1px",transform:"translateX(-2px)"}},vertical:{gradient:{background:"linear-gradient(to bottom, rgba("+t.r+","+t.g+","+t.b+", 0) 0%,\n rgba("+t.r+","+t.g+","+t.b+", 1) 100%)"},pointer:{left:0,top:100*t.a+"%"}},overwrite:G5({},this.props.style)},{vertical:"vertical"===this.props.direction,overwrite:!0});return n.createElement("div",{style:r.alpha},n.createElement("div",{style:r.checkboard},n.createElement(q5,{renderers:this.props.renderers})),n.createElement("div",{style:r.gradient}),n.createElement("div",{style:r.container,ref:function(t){return e.container=t},onMouseDown:this.handleMouseDown,onTouchMove:this.handleChange,onTouchStart:this.handleChange},n.createElement("div",{style:r.pointer},this.props.pointer?n.createElement(this.props.pointer,this.props):n.createElement("div",{style:r.slider}))))}}]),t}(n.PureComponent||n.Component);var K5=function(){function e(e,t){for(var r=0;r-1)){var i=r.getArrowOffset(),o=38===e.keyCode?n+i:n-i;r.setUpdatedValue(o,e)}},r.handleDrag=function(e){if(r.props.dragLabel){var t=Math.round(r.props.value+e.movementX);t>=0&&t<=r.props.dragMax&&r.props.onChange&&r.props.onChange(r.getValueObjectWithLabel(t),e)}},r.handleMouseDown=function(e){r.props.dragLabel&&(e.preventDefault(),r.handleDrag(e),window.addEventListener("mousemove",r.handleDrag),window.addEventListener("mouseup",r.handleMouseUp))},r.handleMouseUp=function(){r.unbindEventListeners()},r.unbindEventListeners=function(){window.removeEventListener("mousemove",r.handleDrag),window.removeEventListener("mouseup",r.handleMouseUp)},r.state={value:String(e.value).toUpperCase(),blurValue:String(e.value).toUpperCase()},r.inputId="rc-editable-input-"+Q5++,r}return function(e,t){if("function"!==typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}(t,e),K5(t,[{key:"componentDidUpdate",value:function(e,t){this.props.value===this.state.value||e.value===this.props.value&&t.value===this.state.value||(this.input===document.activeElement?this.setState({blurValue:String(this.props.value).toUpperCase()}):this.setState({value:String(this.props.value).toUpperCase(),blurValue:!this.state.blurValue&&String(this.props.value).toUpperCase()}))}},{key:"componentWillUnmount",value:function(){this.unbindEventListeners()}},{key:"getValueObjectWithLabel",value:function(e){return function(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}({},this.props.label,e)}},{key:"getArrowOffset",value:function(){return this.props.arrowOffset||1}},{key:"setUpdatedValue",value:function(e,t){var r=this.props.label?this.getValueObjectWithLabel(e):e;this.props.onChange&&this.props.onChange(r,t),this.setState({value:e})}},{key:"render",value:function(){var e=this,t=(0,V5.Ay)({default:{wrap:{position:"relative"}},"user-override":{wrap:this.props.style&&this.props.style.wrap?this.props.style.wrap:{},input:this.props.style&&this.props.style.input?this.props.style.input:{},label:this.props.style&&this.props.style.label?this.props.style.label:{}},"dragLabel-true":{label:{cursor:"ew-resize"}}},{"user-override":!0},this.props);return n.createElement("div",{style:t.wrap},n.createElement("input",{id:this.inputId,style:t.input,ref:function(t){return e.input=t},value:this.state.value,onKeyDown:this.handleKeyDown,onChange:this.handleChange,onBlur:this.handleBlur,placeholder:this.props.placeholder,spellCheck:"false"}),this.props.label&&!this.props.hideLabel?n.createElement("label",{htmlFor:this.inputId,style:t.label,onMouseDown:this.handleMouseDown},this.props.label):null)}}]),t}(n.PureComponent||n.Component);var t4=function(){function e(e,t){for(var r=0;ro?0:360*(-100*c/o+100)/100,r.h!==u)return{h:u,s:r.s,l:r.l,a:r.a,source:"hsl"}}else{var d=void 0;if(d=l<0?0:l>i?359:100*l/i*360/100,r.h!==d)return{h:d,s:r.s,l:r.l,a:r.a,source:"hsl"}}return null}(e,n.props.direction,n.props.hsl,n.container);t&&"function"===typeof n.props.onChange&&n.props.onChange(t,e)},n.handleMouseDown=function(e){n.handleChange(e),window.addEventListener("mousemove",n.handleChange),window.addEventListener("mouseup",n.handleMouseUp)},n.handleMouseUp=function(){n.unbindEventListeners()},r4(n,r)}return function(e,t){if("function"!==typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}(t,e),t4(t,[{key:"componentWillUnmount",value:function(){this.unbindEventListeners()}},{key:"unbindEventListeners",value:function(){window.removeEventListener("mousemove",this.handleChange),window.removeEventListener("mouseup",this.handleMouseUp)}},{key:"render",value:function(){var e=this,t=this.props.direction,r=void 0===t?"horizontal":t,i=(0,V5.Ay)({default:{hue:{absolute:"0px 0px 0px 0px",borderRadius:this.props.radius,boxShadow:this.props.shadow},container:{padding:"0 2px",position:"relative",height:"100%",borderRadius:this.props.radius},pointer:{position:"absolute",left:100*this.props.hsl.h/360+"%"},slider:{marginTop:"1px",width:"4px",borderRadius:"1px",height:"8px",boxShadow:"0 0 2px rgba(0, 0, 0, .6)",background:"#fff",transform:"translateX(-2px)"}},vertical:{pointer:{left:"0px",top:-100*this.props.hsl.h/360+100+"%"}}},{vertical:"vertical"===r});return n.createElement("div",{style:i.hue},n.createElement("div",{className:"hue-"+r,style:i.container,ref:function(t){return e.container=t},onMouseDown:this.handleMouseDown,onTouchMove:this.handleChange,onTouchStart:this.handleChange},n.createElement("style",null,"\n .hue-horizontal {\n background: linear-gradient(to right, #f00 0%, #ff0 17%, #0f0\n 33%, #0ff 50%, #00f 67%, #f0f 83%, #f00 100%);\n background: -webkit-linear-gradient(to right, #f00 0%, #ff0\n 17%, #0f0 33%, #0ff 50%, #00f 67%, #f0f 83%, #f00 100%);\n }\n\n .hue-vertical {\n background: linear-gradient(to top, #f00 0%, #ff0 17%, #0f0 33%,\n #0ff 50%, #00f 67%, #f0f 83%, #f00 100%);\n background: -webkit-linear-gradient(to top, #f00 0%, #ff0 17%,\n #0f0 33%, #0ff 50%, #00f 67%, #f0f 83%, #f00 100%);\n }\n "),n.createElement("div",{style:i.pointer},this.props.pointer?n.createElement(this.props.pointer,this.props):n.createElement("div",{style:i.slider}))))}}]),t}(n.PureComponent||n.Component);const i4=function(){this.__data__=[],this.size=0};const o4=function(e,t){return e===t||e!==e&&t!==t};const a4=function(e,t){for(var r=e.length;r--;)if(o4(e[r][0],t))return r;return-1};var s4=Array.prototype.splice;const l4=function(e){var t=this.__data__,r=a4(t,e);return!(r<0)&&(r==t.length-1?t.pop():s4.call(t,r,1),--this.size,!0)};const c4=function(e){var t=this.__data__,r=a4(t,e);return r<0?void 0:t[r][1]};const u4=function(e){return a4(this.__data__,e)>-1};const d4=function(e,t){var r=this.__data__,n=a4(r,e);return n<0?(++this.size,r.push([e,t])):r[n][1]=t,this};function h4(e){var t=-1,r=null==e?0:e.length;for(this.clear();++t-1&&e%1==0&&e<=9007199254740991};const $6=function(e){return null!=e&&H6(e.length)&&!O4(e)};const W6=function(e){return z6(e)&&$6(e)};const q6=function(){return!1};var G6="object"==typeof exports&&exports&&!exports.nodeType&&exports,Y6=G6&&"object"==typeof module&&module&&!module.nodeType&&module,X6=Y6&&Y6.exports===G6?b4.Buffer:void 0;const Z6=(X6?X6.isBuffer:void 0)||q6;var K6=Function.prototype,J6=Object.prototype,Q6=K6.toString,e8=J6.hasOwnProperty,t8=Q6.call(Object);const r8=function(e){if(!z6(e)||"[object Object]"!=I4(e))return!1;var t=O6(e);if(null===t)return!0;var r=e8.call(t,"constructor")&&t.constructor;return"function"==typeof r&&r instanceof r&&Q6.call(r)==t8};var n8={};n8["[object Float32Array]"]=n8["[object Float64Array]"]=n8["[object Int8Array]"]=n8["[object Int16Array]"]=n8["[object Int32Array]"]=n8["[object Uint8Array]"]=n8["[object Uint8ClampedArray]"]=n8["[object Uint16Array]"]=n8["[object Uint32Array]"]=!0,n8["[object Arguments]"]=n8["[object Array]"]=n8["[object ArrayBuffer]"]=n8["[object Boolean]"]=n8["[object DataView]"]=n8["[object Date]"]=n8["[object Error]"]=n8["[object Function]"]=n8["[object Map]"]=n8["[object Number]"]=n8["[object Object]"]=n8["[object RegExp]"]=n8["[object Set]"]=n8["[object String]"]=n8["[object WeakMap]"]=!1;const i8=function(e){return z6(e)&&H6(e.length)&&!!n8[I4(e)]};const o8=function(e){return function(t){return e(t)}};var a8="object"==typeof exports&&exports&&!exports.nodeType&&exports,s8=a8&&"object"==typeof module&&module&&!module.nodeType&&module,l8=s8&&s8.exports===a8&&v4.process,c8=function(){try{var e=s8&&s8.require&&s8.require("util").types;return e||l8&&l8.binding&&l8.binding("util")}catch(ene){}}();var u8=c8&&c8.isTypedArray;const d8=u8?o8(u8):i8;const h8=function(e,t){if(("constructor"!==t||"function"!==typeof e[t])&&"__proto__"!=t)return e[t]};var p8=Object.prototype.hasOwnProperty;const f8=function(e,t,r){var n=e[t];p8.call(e,t)&&o4(n,r)&&(void 0!==r||t in e)||y6(e,t,r)};const m8=function(e,t,r,n){var i=!r;r||(r={});for(var o=-1,a=t.length;++o-1&&e%1==0&&e0){if(++t>=800)return arguments[0]}else t=0;return e.apply(void 0,arguments)}}(R8);const z8=function(e,t){return D8(P8(e,t,C8),e+"")};const j8=function(e,t,r){if(!P4(r))return!1;var n=typeof t;return!!("number"==n?$6(r)&&v8(t,r.length):"string"==n&&t in r)&&o4(r[t],e)};const F8=function(e){return z8((function(t,r){var n=-1,i=r.length,o=i>1?r[i-1]:void 0,a=i>2?r[2]:void 0;for(o=e.length>3&&"function"==typeof o?(i--,o):void 0,a&&j8(r[0],r[1],a)&&(o=i<3?void 0:o,i=1),t=Object(t);++n=t||r<0||d&&e-c>=o}function m(){var e=V8();if(f(e))return g(e);s=setTimeout(m,function(e){var r=t-(e-l);return d?Q8(r,o-(e-c)):r}(e))}function g(e){return s=void 0,h&&n?p(e):(n=i=void 0,a)}function y(){var e=V8(),r=f(e);if(n=arguments,i=this,l=e,r){if(void 0===s)return function(e){return c=e,s=setTimeout(m,t),u?p(e):a}(l);if(d)return clearTimeout(s),s=setTimeout(m,t),p(l)}return void 0===s&&(s=setTimeout(m,t)),a}return t=K8(t)||0,P4(r)&&(u=!!r.leading,o=(d="maxWait"in r)?J8(K8(r.maxWait)||0,t):o,h="trailing"in r?!!r.trailing:h),y.cancel=function(){void 0!==s&&clearTimeout(s),c=0,n=l=i=s=void 0},y.flush=function(){return void 0===s?a:g(V8())},y};const t7=function(e,t,r){var n=!0,i=!0;if("function"!=typeof e)throw new TypeError("Expected a function");return P4(r)&&(n="leading"in r?!!r.leading:n,i="trailing"in r?!!r.trailing:i),e7(e,t,{leading:n,maxWait:t,trailing:i})};var r7=function(){function e(e,t){for(var r=0;ri&&(l=i),c<0?c=0:c>o&&(c=o);var u=l/i,d=1-c/o;return{h:t.h,s:u,v:d,a:t.a,source:"hsv"}}(e,r.props.hsl,r.container),e)},r.handleMouseDown=function(e){r.handleChange(e);var t=r.getContainerRenderWindow();t.addEventListener("mousemove",r.handleChange),t.addEventListener("mouseup",r.handleMouseUp)},r.handleMouseUp=function(){r.unbindEventListeners()},r.throttle=t7((function(e,t,r){e(t,r)}),50),r}return function(e,t){if("function"!==typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}(t,e),r7(t,[{key:"componentWillUnmount",value:function(){this.throttle.cancel(),this.unbindEventListeners()}},{key:"getContainerRenderWindow",value:function(){for(var e=this.container,t=window;!t.document.contains(e)&&t.parent!==t;)t=t.parent;return t}},{key:"unbindEventListeners",value:function(){var e=this.getContainerRenderWindow();e.removeEventListener("mousemove",this.handleChange),e.removeEventListener("mouseup",this.handleMouseUp)}},{key:"render",value:function(){var e=this,t=this.props.style||{},r=t.color,i=t.white,o=t.black,a=t.pointer,s=t.circle,l=(0,V5.Ay)({default:{color:{absolute:"0px 0px 0px 0px",background:"hsl("+this.props.hsl.h+",100%, 50%)",borderRadius:this.props.radius},white:{absolute:"0px 0px 0px 0px",borderRadius:this.props.radius},black:{absolute:"0px 0px 0px 0px",boxShadow:this.props.shadow,borderRadius:this.props.radius},pointer:{position:"absolute",top:-100*this.props.hsv.v+100+"%",left:100*this.props.hsv.s+"%",cursor:"default"},circle:{width:"4px",height:"4px",boxShadow:"0 0 0 1.5px #fff, inset 0 0 1px 1px rgba(0,0,0,.3),\n 0 0 1px 2px rgba(0,0,0,.4)",borderRadius:"50%",cursor:"hand",transform:"translate(-2px, -2px)"}},custom:{color:r,white:i,black:o,pointer:a,circle:s}},{custom:!!this.props.style});return n.createElement("div",{style:l.color,ref:function(t){return e.container=t},onMouseDown:this.handleMouseDown,onTouchMove:this.handleChange,onTouchStart:this.handleChange},n.createElement("style",null,"\n .saturation-white {\n background: -webkit-linear-gradient(to right, #fff, rgba(255,255,255,0));\n background: linear-gradient(to right, #fff, rgba(255,255,255,0));\n }\n .saturation-black {\n background: -webkit-linear-gradient(to top, #000, rgba(0,0,0,0));\n background: linear-gradient(to top, #000, rgba(0,0,0,0));\n }\n "),n.createElement("div",{style:l.white,className:"saturation-white"},n.createElement("div",{style:l.black,className:"saturation-black"}),n.createElement("div",{style:l.pointer},this.props.pointer?n.createElement(this.props.pointer,this.props):n.createElement("div",{style:l.circle}))))}}]),t}(n.PureComponent||n.Component);const i7=n7;const o7=function(e,t){for(var r=-1,n=null==e?0:e.length;++r1&&(r-=1),r<1/6?e+6*(t-e)*r:r<.5?t:r<2/3?e+(t-e)*(2/3-r)*6:e}if(e=z7(e,360),t=z7(t,100),r=z7(r,100),0===t)n=i=o=r;else{var s=r<.5?r*(1+t):r+t-r*t,l=2*r-s;n=a(l,s,e+1/3),i=a(l,s,e),o=a(l,s,e-1/3)}return{r:255*n,g:255*i,b:255*o}}(e.h,n,o),a=!0,s="hsl"),e.hasOwnProperty("a")&&(r=e.a));var l,c,u;return r=D7(r),{ok:a,format:e.format||s,r:Math.min(255,Math.max(t.r,0)),g:Math.min(255,Math.max(t.g,0)),b:Math.min(255,Math.max(t.b,0)),a:r}}(e);this._originalInput=e,this._r=r.r,this._g=r.g,this._b=r.b,this._a=r.a,this._roundA=Math.round(100*this._a)/100,this._format=t.format||r.format,this._gradientType=t.gradientType,this._r<1&&(this._r=Math.round(this._r)),this._g<1&&(this._g=Math.round(this._g)),this._b<1&&(this._b=Math.round(this._b)),this._ok=r.ok}function y7(e,t,r){e=z7(e,255),t=z7(t,255),r=z7(r,255);var n,i,o=Math.max(e,t,r),a=Math.min(e,t,r),s=(o+a)/2;if(o==a)n=i=0;else{var l=o-a;switch(i=s>.5?l/(2-o-a):l/(o+a),o){case e:n=(t-r)/l+(t>1)+720)%360;--t;)n.h=(n.h+i)%360,o.push(g7(n));return o}function O7(e,t){t=t||6;for(var r=g7(e).toHsv(),n=r.h,i=r.s,o=r.v,a=[],s=1/t;t--;)a.push(g7({h:n,s:i,v:o})),o=(o+s)%1;return a}g7.prototype={isDark:function(){return this.getBrightness()<128},isLight:function(){return!this.isDark()},isValid:function(){return this._ok},getOriginalInput:function(){return this._originalInput},getFormat:function(){return this._format},getAlpha:function(){return this._a},getBrightness:function(){var e=this.toRgb();return(299*e.r+587*e.g+114*e.b)/1e3},getLuminance:function(){var e,t,r,n=this.toRgb();return e=n.r/255,t=n.g/255,r=n.b/255,.2126*(e<=.03928?e/12.92:Math.pow((e+.055)/1.055,2.4))+.7152*(t<=.03928?t/12.92:Math.pow((t+.055)/1.055,2.4))+.0722*(r<=.03928?r/12.92:Math.pow((r+.055)/1.055,2.4))},setAlpha:function(e){return this._a=D7(e),this._roundA=Math.round(100*this._a)/100,this},toHsv:function(){var e=v7(this._r,this._g,this._b);return{h:360*e.h,s:e.s,v:e.v,a:this._a}},toHsvString:function(){var e=v7(this._r,this._g,this._b),t=Math.round(360*e.h),r=Math.round(100*e.s),n=Math.round(100*e.v);return 1==this._a?"hsv("+t+", "+r+"%, "+n+"%)":"hsva("+t+", "+r+"%, "+n+"%, "+this._roundA+")"},toHsl:function(){var e=y7(this._r,this._g,this._b);return{h:360*e.h,s:e.s,l:e.l,a:this._a}},toHslString:function(){var e=y7(this._r,this._g,this._b),t=Math.round(360*e.h),r=Math.round(100*e.s),n=Math.round(100*e.l);return 1==this._a?"hsl("+t+", "+r+"%, "+n+"%)":"hsla("+t+", "+r+"%, "+n+"%, "+this._roundA+")"},toHex:function(e){return x7(this._r,this._g,this._b,e)},toHexString:function(e){return"#"+this.toHex(e)},toHex8:function(e){return function(e,t,r,n,i){var o=[N7(Math.round(e).toString(16)),N7(Math.round(t).toString(16)),N7(Math.round(r).toString(16)),N7(V7(n))];if(i&&o[0].charAt(0)==o[0].charAt(1)&&o[1].charAt(0)==o[1].charAt(1)&&o[2].charAt(0)==o[2].charAt(1)&&o[3].charAt(0)==o[3].charAt(1))return o[0].charAt(0)+o[1].charAt(0)+o[2].charAt(0)+o[3].charAt(0);return o.join("")}(this._r,this._g,this._b,this._a,e)},toHex8String:function(e){return"#"+this.toHex8(e)},toRgb:function(){return{r:Math.round(this._r),g:Math.round(this._g),b:Math.round(this._b),a:this._a}},toRgbString:function(){return 1==this._a?"rgb("+Math.round(this._r)+", "+Math.round(this._g)+", "+Math.round(this._b)+")":"rgba("+Math.round(this._r)+", "+Math.round(this._g)+", "+Math.round(this._b)+", "+this._roundA+")"},toPercentageRgb:function(){return{r:Math.round(100*z7(this._r,255))+"%",g:Math.round(100*z7(this._g,255))+"%",b:Math.round(100*z7(this._b,255))+"%",a:this._a}},toPercentageRgbString:function(){return 1==this._a?"rgb("+Math.round(100*z7(this._r,255))+"%, "+Math.round(100*z7(this._g,255))+"%, "+Math.round(100*z7(this._b,255))+"%)":"rgba("+Math.round(100*z7(this._r,255))+"%, "+Math.round(100*z7(this._g,255))+"%, "+Math.round(100*z7(this._b,255))+"%, "+this._roundA+")"},toName:function(){return 0===this._a?"transparent":!(this._a<1)&&(L7[x7(this._r,this._g,this._b,!0)]||!1)},toFilter:function(e){var t="#"+b7(this._r,this._g,this._b,this._a),r=t,n=this._gradientType?"GradientType = 1, ":"";if(e){var i=g7(e);r="#"+b7(i._r,i._g,i._b,i._a)}return"progid:DXImageTransform.Microsoft.gradient("+n+"startColorstr="+t+",endColorstr="+r+")"},toString:function(e){var t=!!e;e=e||this._format;var r=!1,n=this._a<1&&this._a>=0;return t||!n||"hex"!==e&&"hex6"!==e&&"hex3"!==e&&"hex4"!==e&&"hex8"!==e&&"name"!==e?("rgb"===e&&(r=this.toRgbString()),"prgb"===e&&(r=this.toPercentageRgbString()),"hex"!==e&&"hex6"!==e||(r=this.toHexString()),"hex3"===e&&(r=this.toHexString(!0)),"hex4"===e&&(r=this.toHex8String(!0)),"hex8"===e&&(r=this.toHex8String()),"name"===e&&(r=this.toName()),"hsl"===e&&(r=this.toHslString()),"hsv"===e&&(r=this.toHsvString()),r||this.toHexString()):"name"===e&&0===this._a?this.toName():this.toRgbString()},clone:function(){return g7(this.toString())},_applyModification:function(e,t){var r=e.apply(null,[this].concat([].slice.call(t)));return this._r=r._r,this._g=r._g,this._b=r._b,this.setAlpha(r._a),this},lighten:function(){return this._applyModification(S7,arguments)},brighten:function(){return this._applyModification(A7,arguments)},darken:function(){return this._applyModification(T7,arguments)},desaturate:function(){return this._applyModification(_7,arguments)},saturate:function(){return this._applyModification(w7,arguments)},greyscale:function(){return this._applyModification(k7,arguments)},spin:function(){return this._applyModification(M7,arguments)},_applyCombination:function(e,t){return e.apply(null,[this].concat([].slice.call(t)))},analogous:function(){return this._applyCombination(P7,arguments)},complement:function(){return this._applyCombination(C7,arguments)},monochromatic:function(){return this._applyCombination(O7,arguments)},splitcomplement:function(){return this._applyCombination(I7,arguments)},triad:function(){return this._applyCombination(E7,[3])},tetrad:function(){return this._applyCombination(E7,[4])}},g7.fromRatio=function(e,t){if("object"==p7(e)){var r={};for(var n in e)e.hasOwnProperty(n)&&(r[n]="a"===n?e[n]:B7(e[n]));e=r}return g7(e,t)},g7.equals=function(e,t){return!(!e||!t)&&g7(e).toRgbString()==g7(t).toRgbString()},g7.random=function(){return g7.fromRatio({r:Math.random(),g:Math.random(),b:Math.random()})},g7.mix=function(e,t,r){r=0===r?0:r||50;var n=g7(e).toRgb(),i=g7(t).toRgb(),o=r/100;return g7({r:(i.r-n.r)*o+n.r,g:(i.g-n.g)*o+n.g,b:(i.b-n.b)*o+n.b,a:(i.a-n.a)*o+n.a})},g7.readability=function(e,t){var r=g7(e),n=g7(t);return(Math.max(r.getLuminance(),n.getLuminance())+.05)/(Math.min(r.getLuminance(),n.getLuminance())+.05)},g7.isReadable=function(e,t,r){var n,i,o=g7.readability(e,t);switch(i=!1,(n=function(e){var t,r;t=((e=e||{level:"AA",size:"small"}).level||"AA").toUpperCase(),r=(e.size||"small").toLowerCase(),"AA"!==t&&"AAA"!==t&&(t="AA");"small"!==r&&"large"!==r&&(r="small");return{level:t,size:r}}(r)).level+n.size){case"AAsmall":case"AAAlarge":i=o>=4.5;break;case"AAlarge":i=o>=3;break;case"AAAsmall":i=o>=7}return i},g7.mostReadable=function(e,t,r){var n,i,o,a,s=null,l=0;i=(r=r||{}).includeFallbackColors,o=r.level,a=r.size;for(var c=0;cl&&(l=n,s=g7(t[c]));return g7.isReadable(e,s,{level:o,size:a})||!i?s:(r.includeFallbackColors=!1,g7.mostReadable(e,["#fff","#000"],r))};var R7=g7.names={aliceblue:"f0f8ff",antiquewhite:"faebd7",aqua:"0ff",aquamarine:"7fffd4",azure:"f0ffff",beige:"f5f5dc",bisque:"ffe4c4",black:"000",blanchedalmond:"ffebcd",blue:"00f",blueviolet:"8a2be2",brown:"a52a2a",burlywood:"deb887",burntsienna:"ea7e5d",cadetblue:"5f9ea0",chartreuse:"7fff00",chocolate:"d2691e",coral:"ff7f50",cornflowerblue:"6495ed",cornsilk:"fff8dc",crimson:"dc143c",cyan:"0ff",darkblue:"00008b",darkcyan:"008b8b",darkgoldenrod:"b8860b",darkgray:"a9a9a9",darkgreen:"006400",darkgrey:"a9a9a9",darkkhaki:"bdb76b",darkmagenta:"8b008b",darkolivegreen:"556b2f",darkorange:"ff8c00",darkorchid:"9932cc",darkred:"8b0000",darksalmon:"e9967a",darkseagreen:"8fbc8f",darkslateblue:"483d8b",darkslategray:"2f4f4f",darkslategrey:"2f4f4f",darkturquoise:"00ced1",darkviolet:"9400d3",deeppink:"ff1493",deepskyblue:"00bfff",dimgray:"696969",dimgrey:"696969",dodgerblue:"1e90ff",firebrick:"b22222",floralwhite:"fffaf0",forestgreen:"228b22",fuchsia:"f0f",gainsboro:"dcdcdc",ghostwhite:"f8f8ff",gold:"ffd700",goldenrod:"daa520",gray:"808080",green:"008000",greenyellow:"adff2f",grey:"808080",honeydew:"f0fff0",hotpink:"ff69b4",indianred:"cd5c5c",indigo:"4b0082",ivory:"fffff0",khaki:"f0e68c",lavender:"e6e6fa",lavenderblush:"fff0f5",lawngreen:"7cfc00",lemonchiffon:"fffacd",lightblue:"add8e6",lightcoral:"f08080",lightcyan:"e0ffff",lightgoldenrodyellow:"fafad2",lightgray:"d3d3d3",lightgreen:"90ee90",lightgrey:"d3d3d3",lightpink:"ffb6c1",lightsalmon:"ffa07a",lightseagreen:"20b2aa",lightskyblue:"87cefa",lightslategray:"789",lightslategrey:"789",lightsteelblue:"b0c4de",lightyellow:"ffffe0",lime:"0f0",limegreen:"32cd32",linen:"faf0e6",magenta:"f0f",maroon:"800000",mediumaquamarine:"66cdaa",mediumblue:"0000cd",mediumorchid:"ba55d3",mediumpurple:"9370db",mediumseagreen:"3cb371",mediumslateblue:"7b68ee",mediumspringgreen:"00fa9a",mediumturquoise:"48d1cc",mediumvioletred:"c71585",midnightblue:"191970",mintcream:"f5fffa",mistyrose:"ffe4e1",moccasin:"ffe4b5",navajowhite:"ffdead",navy:"000080",oldlace:"fdf5e6",olive:"808000",olivedrab:"6b8e23",orange:"ffa500",orangered:"ff4500",orchid:"da70d6",palegoldenrod:"eee8aa",palegreen:"98fb98",paleturquoise:"afeeee",palevioletred:"db7093",papayawhip:"ffefd5",peachpuff:"ffdab9",peru:"cd853f",pink:"ffc0cb",plum:"dda0dd",powderblue:"b0e0e6",purple:"800080",rebeccapurple:"663399",red:"f00",rosybrown:"bc8f8f",royalblue:"4169e1",saddlebrown:"8b4513",salmon:"fa8072",sandybrown:"f4a460",seagreen:"2e8b57",seashell:"fff5ee",sienna:"a0522d",silver:"c0c0c0",skyblue:"87ceeb",slateblue:"6a5acd",slategray:"708090",slategrey:"708090",snow:"fffafa",springgreen:"00ff7f",steelblue:"4682b4",tan:"d2b48c",teal:"008080",thistle:"d8bfd8",tomato:"ff6347",turquoise:"40e0d0",violet:"ee82ee",wheat:"f5deb3",white:"fff",whitesmoke:"f5f5f5",yellow:"ff0",yellowgreen:"9acd32"},L7=g7.hexNames=function(e){var t={};for(var r in e)e.hasOwnProperty(r)&&(t[e[r]]=r);return t}(R7);function D7(e){return e=parseFloat(e),(isNaN(e)||e<0||e>1)&&(e=1),e}function z7(e,t){(function(e){return"string"==typeof e&&-1!=e.indexOf(".")&&1===parseFloat(e)})(e)&&(e="100%");var r=function(e){return"string"===typeof e&&-1!=e.indexOf("%")}(e);return e=Math.min(t,Math.max(0,parseFloat(e))),r&&(e=parseInt(e*t,10)/100),Math.abs(e-t)<1e-6?1:e%t/parseFloat(t)}function j7(e){return Math.min(1,Math.max(0,e))}function F7(e){return parseInt(e,16)}function N7(e){return 1==e.length?"0"+e:""+e}function B7(e){return e<=1&&(e=100*e+"%"),e}function V7(e){return Math.round(255*parseFloat(e)).toString(16)}function U7(e){return F7(e)/255}var H7=function(){var e="(?:[-\\+]?\\d*\\.\\d+%?)|(?:[-\\+]?\\d+%?)",t="[\\s|\\(]+("+e+")[,|\\s]+("+e+")[,|\\s]+("+e+")\\s*\\)?",r="[\\s|\\(]+("+e+")[,|\\s]+("+e+")[,|\\s]+("+e+")[,|\\s]+("+e+")\\s*\\)?";return{CSS_UNIT:new RegExp(e),rgb:new RegExp("rgb"+t),rgba:new RegExp("rgba"+r),hsl:new RegExp("hsl"+t),hsla:new RegExp("hsla"+r),hsv:new RegExp("hsv"+t),hsva:new RegExp("hsva"+r),hex3:/^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,hex6:/^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,hex4:/^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,hex8:/^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/}}();function $7(e){return!!H7.CSS_UNIT.exec(e)}var W7=function(e){var t=0,r=0;return h7(["r","g","b","a","h","s","l","v"],(function(n){if(e[n]&&(t+=1,isNaN(e[n])||(r+=1),"s"===n||"l"===n)){/^\d+%$/.test(e[n])&&(r+=1)}})),t===r&&e},q7=function(e,t){var r=e.hex?g7(e.hex):g7(e),n=r.toHsl(),i=r.toHsv(),o=r.toRgb(),a=r.toHex();return 0===n.s&&(n.h=t||0,i.h=t||0),{hsl:n,hex:"000000"===a&&0===o.a?"transparent":"#"+a,rgb:o,hsv:i,oldHue:e.h||t||n.h,source:e.source}},G7=function(e){if("transparent"===e)return!0;var t="#"===String(e).charAt(0)?1:0;return e.length!==4+t&&e.length<7+t&&g7(e).isValid()},Y7=function(e){if(!e)return"#fff";var t=q7(e);return"transparent"===t.hex?"rgba(0,0,0,0.4)":(299*t.rgb.r+587*t.rgb.g+114*t.rgb.b)/1e3>=128?"#000":"#fff"},X7=function(e,t){return g7(t+" ("+e.replace("\xb0","")+")")._ok},Z7=Object.assign||function(e){for(var t=1;t1&&void 0!==arguments[1]?arguments[1]:"span";return function(r){function i(){var e,t,r;!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,i);for(var n=arguments.length,o=Array(n),a=0;as))return!1;var c=o.get(e),u=o.get(t);if(c&&u)return c==t&&u==e;var d=-1,h=!0,p=2&r?new d9:void 0;for(o.set(e,t),o.set(t,e);++d1&&(e.a=1),r.props.onChange({h:r.props.hsl.h,s:r.props.hsl.s,l:r.props.hsl.l,a:Math.round(100*e.a)/100,source:"rgb"},t)):(e.h||e.s||e.l)&&("string"===typeof e.s&&e.s.includes("%")&&(e.s=e.s.replace("%","")),"string"===typeof e.l&&e.l.includes("%")&&(e.l=e.l.replace("%","")),1==e.s?e.s=.01:1==e.l&&(e.l=.01),r.props.onChange({h:e.h||r.props.hsl.h,s:Number(Qee(e.s)?r.props.hsl.s:e.s),l:Number(Qee(e.l)?r.props.hsl.l:e.l),source:"hsl"},t))},r.showHighlight=function(e){e.currentTarget.style.background="#eee"},r.hideHighlight=function(e){e.currentTarget.style.background="transparent"},1!==e.hsl.a&&"hex"===e.view?r.state={view:"rgb"}:r.state={view:e.view},r}return function(e,t){if("function"!==typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}(t,e),tte(t,[{key:"render",value:function(){var e=this,t=(0,V5.Ay)({default:{wrap:{paddingTop:"16px",display:"flex"},fields:{flex:"1",display:"flex",marginLeft:"-6px"},field:{paddingLeft:"6px",width:"100%"},alpha:{paddingLeft:"6px",width:"100%"},toggle:{width:"32px",textAlign:"right",position:"relative"},icon:{marginRight:"-4px",marginTop:"12px",cursor:"pointer",position:"relative"},iconHighlight:{position:"absolute",width:"24px",height:"28px",background:"#eee",borderRadius:"4px",top:"10px",left:"12px",display:"none"},input:{fontSize:"11px",color:"#333",width:"100%",borderRadius:"2px",border:"none",boxShadow:"inset 0 0 0 1px #dadada",height:"21px",textAlign:"center"},label:{textTransform:"uppercase",fontSize:"11px",lineHeight:"11px",color:"#969696",textAlign:"center",display:"block",marginTop:"12px"},svg:{fill:"#333",width:"24px",height:"24px",border:"1px transparent solid",borderRadius:"5px"}},disableAlpha:{alpha:{display:"none"}}},this.props,this.state),r=void 0;return"hex"===this.state.view?r=n.createElement("div",{style:t.fields,className:"flexbox-fix"},n.createElement("div",{style:t.field},n.createElement(e4,{style:{input:t.input,label:t.label},label:"hex",value:this.props.hex,onChange:this.handleChange}))):"rgb"===this.state.view?r=n.createElement("div",{style:t.fields,className:"flexbox-fix"},n.createElement("div",{style:t.field},n.createElement(e4,{style:{input:t.input,label:t.label},label:"r",value:this.props.rgb.r,onChange:this.handleChange})),n.createElement("div",{style:t.field},n.createElement(e4,{style:{input:t.input,label:t.label},label:"g",value:this.props.rgb.g,onChange:this.handleChange})),n.createElement("div",{style:t.field},n.createElement(e4,{style:{input:t.input,label:t.label},label:"b",value:this.props.rgb.b,onChange:this.handleChange})),n.createElement("div",{style:t.alpha},n.createElement(e4,{style:{input:t.input,label:t.label},label:"a",value:this.props.rgb.a,arrowOffset:.01,onChange:this.handleChange}))):"hsl"===this.state.view&&(r=n.createElement("div",{style:t.fields,className:"flexbox-fix"},n.createElement("div",{style:t.field},n.createElement(e4,{style:{input:t.input,label:t.label},label:"h",value:Math.round(this.props.hsl.h),onChange:this.handleChange})),n.createElement("div",{style:t.field},n.createElement(e4,{style:{input:t.input,label:t.label},label:"s",value:Math.round(100*this.props.hsl.s)+"%",onChange:this.handleChange})),n.createElement("div",{style:t.field},n.createElement(e4,{style:{input:t.input,label:t.label},label:"l",value:Math.round(100*this.props.hsl.l)+"%",onChange:this.handleChange})),n.createElement("div",{style:t.alpha},n.createElement(e4,{style:{input:t.input,label:t.label},label:"a",value:this.props.hsl.a,arrowOffset:.01,onChange:this.handleChange})))),n.createElement("div",{style:t.wrap,className:"flexbox-fix"},r,n.createElement("div",{style:t.toggle},n.createElement("div",{style:t.icon,onClick:this.toggleViews,ref:function(t){return e.icon=t}},n.createElement(ete.A,{style:t.svg,onMouseOver:this.showHighlight,onMouseEnter:this.showHighlight,onMouseOut:this.hideHighlight}))))}}],[{key:"getDerivedStateFromProps",value:function(e,t){return 1!==e.hsl.a&&"hex"===t.view?{view:"rgb"}:null}}]),t}(n.Component);rte.defaultProps={view:"hex"};const nte=rte;const ite=function(){var e=(0,V5.Ay)({default:{picker:{width:"12px",height:"12px",borderRadius:"6px",transform:"translate(-6px, -1px)",backgroundColor:"rgb(248, 248, 248)",boxShadow:"0 1px 4px 0 rgba(0, 0, 0, 0.37)"}}});return n.createElement("div",{style:e.picker})};const ote=function(){var e=(0,V5.Ay)({default:{picker:{width:"12px",height:"12px",borderRadius:"6px",boxShadow:"inset 0 0 0 1px #fff",transform:"translate(-6px, -6px)"}}});return n.createElement("div",{style:e.picker})};var ate=function(e){var t=e.width,r=e.onChange,i=e.disableAlpha,o=e.rgb,a=e.hsl,s=e.hsv,l=e.hex,c=e.renderers,u=e.styles,d=void 0===u?{}:u,h=e.className,p=void 0===h?"":h,f=e.defaultView,m=(0,V5.Ay)(F8({default:{picker:{width:t,background:"#fff",borderRadius:"2px",boxShadow:"0 0 2px rgba(0,0,0,.3), 0 4px 8px rgba(0,0,0,.3)",boxSizing:"initial",fontFamily:"Menlo"},saturation:{width:"100%",paddingBottom:"55%",position:"relative",borderRadius:"2px 2px 0 0",overflow:"hidden"},Saturation:{radius:"2px 2px 0 0"},body:{padding:"16px 16px 12px"},controls:{display:"flex"},color:{width:"32px"},swatch:{marginTop:"6px",width:"16px",height:"16px",borderRadius:"8px",position:"relative",overflow:"hidden"},active:{absolute:"0px 0px 0px 0px",borderRadius:"8px",boxShadow:"inset 0 0 0 1px rgba(0,0,0,.1)",background:"rgba("+o.r+", "+o.g+", "+o.b+", "+o.a+")",zIndex:"2"},toggles:{flex:"1"},hue:{height:"10px",position:"relative",marginBottom:"8px"},Hue:{radius:"2px"},alpha:{height:"10px",position:"relative"},Alpha:{radius:"2px"}},disableAlpha:{color:{width:"22px"},alpha:{display:"none"},hue:{marginBottom:"0px"},swatch:{width:"10px",height:"10px",marginTop:"0px"}}},d),{disableAlpha:i});return n.createElement("div",{style:m.picker,className:"chrome-picker "+p},n.createElement("div",{style:m.saturation},n.createElement(i7,{style:m.Saturation,hsl:a,hsv:s,pointer:ote,onChange:r})),n.createElement("div",{style:m.body},n.createElement("div",{style:m.controls,className:"flexbox-fix"},n.createElement("div",{style:m.color},n.createElement("div",{style:m.swatch},n.createElement("div",{style:m.active}),n.createElement(q5,{renderers:c}))),n.createElement("div",{style:m.toggles},n.createElement("div",{style:m.hue},n.createElement(n4,{style:m.Hue,hsl:a,pointer:ite,onChange:r})),n.createElement("div",{style:m.alpha},n.createElement(Z5,{style:m.Alpha,rgb:o,hsl:a,pointer:ite,renderers:c,onChange:r})))),n.createElement(nte,{rgb:o,hsl:a,hex:l,view:f,onChange:r,disableAlpha:i})))};ate.propTypes={width:TI().oneOfType([TI().string,TI().number]),disableAlpha:TI().bool,styles:TI().object,defaultView:TI().oneOf(["hex","rgb","hsl"])},ate.defaultProps={width:225,disableAlpha:!1,styles:{}};J7(ate);const ste=function(e){var t=e.color,r=e.onClick,i=void 0===r?function(){}:r,o=e.onSwatchHover,a=e.active,s=(0,V5.Ay)({default:{color:{background:t,width:"15px",height:"15px",float:"left",marginRight:"5px",marginBottom:"5px",position:"relative",cursor:"pointer"},dot:{absolute:"5px 5px 5px 5px",background:Y7(t),borderRadius:"50%",opacity:"0"}},active:{dot:{opacity:"1"}},"color-#FFFFFF":{color:{boxShadow:"inset 0 0 0 1px #ddd"},dot:{background:"#000"}},transparent:{dot:{background:"#000"}}},{active:a,"color-#FFFFFF":"#FFFFFF"===t,transparent:"transparent"===t});return n.createElement(n9,{style:s.color,color:t,onClick:i,onHover:o,focusStyle:{boxShadow:"0 0 4px "+t}},n.createElement("div",{style:s.dot}))};const lte=function(e){var t=e.hex,r=e.rgb,i=e.onChange,o=(0,V5.Ay)({default:{fields:{display:"flex",paddingBottom:"6px",paddingRight:"5px",position:"relative"},active:{position:"absolute",top:"6px",left:"5px",height:"9px",width:"9px",background:t},HEXwrap:{flex:"6",position:"relative"},HEXinput:{width:"80%",padding:"0px",paddingLeft:"20%",border:"none",outline:"none",background:"none",fontSize:"12px",color:"#333",height:"16px"},HEXlabel:{display:"none"},RGBwrap:{flex:"3",position:"relative"},RGBinput:{width:"70%",padding:"0px",paddingLeft:"30%",border:"none",outline:"none",background:"none",fontSize:"12px",color:"#333",height:"16px"},RGBlabel:{position:"absolute",top:"3px",left:"0px",lineHeight:"16px",textTransform:"uppercase",fontSize:"12px",color:"#999"}}}),a=function(e,t){e.r||e.g||e.b?i({r:e.r||r.r,g:e.g||r.g,b:e.b||r.b,source:"rgb"},t):i({hex:e.hex,source:"hex"},t)};return n.createElement("div",{style:o.fields,className:"flexbox-fix"},n.createElement("div",{style:o.active}),n.createElement(e4,{style:{wrap:o.HEXwrap,input:o.HEXinput,label:o.HEXlabel},label:"hex",value:t,onChange:a}),n.createElement(e4,{style:{wrap:o.RGBwrap,input:o.RGBinput,label:o.RGBlabel},label:"r",value:r.r,onChange:a}),n.createElement(e4,{style:{wrap:o.RGBwrap,input:o.RGBinput,label:o.RGBlabel},label:"g",value:r.g,onChange:a}),n.createElement(e4,{style:{wrap:o.RGBwrap,input:o.RGBinput,label:o.RGBlabel},label:"b",value:r.b,onChange:a}))};var cte=function(e){var t=e.onChange,r=e.onSwatchHover,i=e.colors,o=e.hex,a=e.rgb,s=e.styles,l=void 0===s?{}:s,c=e.className,u=void 0===c?"":c,d=(0,V5.Ay)(F8({default:{Compact:{background:"#f6f6f6",radius:"4px"},compact:{paddingTop:"5px",paddingLeft:"5px",boxSizing:"initial",width:"240px"},clear:{clear:"both"}}},l)),h=function(e,r){e.hex?G7(e.hex)&&t({hex:e.hex,source:"hex"},r):t(e,r)};return n.createElement(B8,{style:d.Compact,styles:l},n.createElement("div",{style:d.compact,className:"compact-picker "+u},n.createElement("div",null,Eee(i,(function(e){return n.createElement(ste,{key:e,color:e,active:e.toLowerCase()===o,onClick:h,onSwatchHover:r})})),n.createElement("div",{style:d.clear})),n.createElement(lte,{hex:o,rgb:a,onChange:h})))};cte.propTypes={colors:TI().arrayOf(TI().string),styles:TI().object},cte.defaultProps={colors:["#4D4D4D","#999999","#FFFFFF","#F44E3B","#FE9200","#FCDC00","#DBDF00","#A4DD00","#68CCCA","#73D8FF","#AEA1FF","#FDA1FF","#333333","#808080","#cccccc","#D33115","#E27300","#FCC400","#B0BC00","#68BC00","#16A5A5","#009CE0","#7B64FF","#FA28FF","#000000","#666666","#B3B3B3","#9F0500","#C45100","#FB9E00","#808900","#194D33","#0C797D","#0062B1","#653294","#AB149E"],styles:{}};J7(cte);const ute=(0,V5.H8)((function(e){var t=e.hover,r=e.color,i=e.onClick,o=e.onSwatchHover,a={position:"relative",zIndex:"2",outline:"2px solid #fff",boxShadow:"0 0 5px 2px rgba(0,0,0,0.25)"},s=(0,V5.Ay)({default:{swatch:{width:"25px",height:"25px",fontSize:"0"}},hover:{swatch:a}},{hover:t});return n.createElement("div",{style:s.swatch},n.createElement(n9,{color:r,onClick:i,onHover:o,focusStyle:a}))}));var dte=function(e){var t=e.width,r=e.colors,i=e.onChange,o=e.onSwatchHover,a=e.triangle,s=e.styles,l=void 0===s?{}:s,c=e.className,u=void 0===c?"":c,d=(0,V5.Ay)(F8({default:{card:{width:t,background:"#fff",border:"1px solid rgba(0,0,0,0.2)",boxShadow:"0 3px 12px rgba(0,0,0,0.15)",borderRadius:"4px",position:"relative",padding:"5px",display:"flex",flexWrap:"wrap"},triangle:{position:"absolute",border:"7px solid transparent",borderBottomColor:"#fff"},triangleShadow:{position:"absolute",border:"8px solid transparent",borderBottomColor:"rgba(0,0,0,0.15)"}},"hide-triangle":{triangle:{display:"none"},triangleShadow:{display:"none"}},"top-left-triangle":{triangle:{top:"-14px",left:"10px"},triangleShadow:{top:"-16px",left:"9px"}},"top-right-triangle":{triangle:{top:"-14px",right:"10px"},triangleShadow:{top:"-16px",right:"9px"}},"bottom-left-triangle":{triangle:{top:"35px",left:"10px",transform:"rotate(180deg)"},triangleShadow:{top:"37px",left:"9px",transform:"rotate(180deg)"}},"bottom-right-triangle":{triangle:{top:"35px",right:"10px",transform:"rotate(180deg)"},triangleShadow:{top:"37px",right:"9px",transform:"rotate(180deg)"}}},l),{"hide-triangle":"hide"===a,"top-left-triangle":"top-left"===a,"top-right-triangle":"top-right"===a,"bottom-left-triangle":"bottom-left"===a,"bottom-right-triangle":"bottom-right"===a}),h=function(e,t){return i({hex:e,source:"hex"},t)};return n.createElement("div",{style:d.card,className:"github-picker "+u},n.createElement("div",{style:d.triangleShadow}),n.createElement("div",{style:d.triangle}),Eee(r,(function(e){return n.createElement(ute,{color:e,key:e,onClick:h,onSwatchHover:o})})))};dte.propTypes={width:TI().oneOfType([TI().string,TI().number]),colors:TI().arrayOf(TI().string),triangle:TI().oneOf(["hide","top-left","top-right","bottom-left","bottom-right"]),styles:TI().object},dte.defaultProps={width:200,colors:["#B80000","#DB3E00","#FCCB00","#008B02","#006B76","#1273DE","#004DCF","#5300EB","#EB9694","#FAD0C3","#FEF3BD","#C1E1C5","#BEDADC","#C4DEF6","#BED3F3","#D4C4FB"],triangle:"top-left",styles:{}};J7(dte);const hte=function(e){var t=e.direction,r=(0,V5.Ay)({default:{picker:{width:"18px",height:"18px",borderRadius:"50%",transform:"translate(-9px, -1px)",backgroundColor:"rgb(248, 248, 248)",boxShadow:"0 1px 4px 0 rgba(0, 0, 0, 0.37)"}},vertical:{picker:{transform:"translate(-3px, -9px)"}}},{vertical:"vertical"===t});return n.createElement("div",{style:r.picker})};var pte=Object.assign||function(e){for(var t=1;t.5});return n.createElement("div",{style:r.picker})};const yte=function(){var e=(0,V5.Ay)({default:{triangle:{width:0,height:0,borderStyle:"solid",borderWidth:"4px 0 4px 6px",borderColor:"transparent transparent transparent #fff",position:"absolute",top:"1px",left:"1px"},triangleBorder:{width:0,height:0,borderStyle:"solid",borderWidth:"5px 0 5px 8px",borderColor:"transparent transparent transparent #555"},left:{Extend:"triangleBorder",transform:"translate(-13px, -4px)"},leftInside:{Extend:"triangle",transform:"translate(-8px, -5px)"},right:{Extend:"triangleBorder",transform:"translate(20px, -14px) rotate(180deg)"},rightInside:{Extend:"triangle",transform:"translate(-8px, -5px)"}}});return n.createElement("div",{style:e.pointer},n.createElement("div",{style:e.left},n.createElement("div",{style:e.leftInside})),n.createElement("div",{style:e.right},n.createElement("div",{style:e.rightInside})))};const vte=function(e){var t=e.onClick,r=e.label,i=e.children,o=e.active,a=(0,V5.Ay)({default:{button:{backgroundImage:"linear-gradient(-180deg, #FFFFFF 0%, #E6E6E6 100%)",border:"1px solid #878787",borderRadius:"2px",height:"20px",boxShadow:"0 1px 0 0 #EAEAEA",fontSize:"14px",color:"#000",lineHeight:"20px",textAlign:"center",marginBottom:"10px",cursor:"pointer"}},active:{button:{boxShadow:"0 0 0 1px #878787"}}},{active:o});return n.createElement("div",{style:a.button,onClick:t},r||i)};const xte=function(e){var t=e.rgb,r=e.currentColor,i=(0,V5.Ay)({default:{swatches:{border:"1px solid #B3B3B3",borderBottom:"1px solid #F0F0F0",marginBottom:"2px",marginTop:"1px"},new:{height:"34px",background:"rgb("+t.r+","+t.g+", "+t.b+")",boxShadow:"inset 1px 0 0 #000, inset -1px 0 0 #000, inset 0 1px 0 #000"},current:{height:"34px",background:r,boxShadow:"inset 1px 0 0 #000, inset -1px 0 0 #000, inset 0 -1px 0 #000"},label:{fontSize:"14px",color:"#000",textAlign:"center"}}});return n.createElement("div",null,n.createElement("div",{style:i.label},"new"),n.createElement("div",{style:i.swatches},n.createElement("div",{style:i.new}),n.createElement("div",{style:i.current})),n.createElement("div",{style:i.label},"current"))};var bte=function(){function e(e,t){for(var r=0;r100&&(e.a=100),e.a/=100,t({h:i.h,s:i.s,l:i.l,a:e.a,source:"rgb"},n))};return n.createElement("div",{style:s.fields,className:"flexbox-fix"},n.createElement("div",{style:s.double},n.createElement(e4,{style:{input:s.input,label:s.label},label:"hex",value:o.replace("#",""),onChange:l})),n.createElement("div",{style:s.single},n.createElement(e4,{style:{input:s.input,label:s.label},label:"r",value:r.r,onChange:l,dragLabel:"true",dragMax:"255"})),n.createElement("div",{style:s.single},n.createElement(e4,{style:{input:s.input,label:s.label},label:"g",value:r.g,onChange:l,dragLabel:"true",dragMax:"255"})),n.createElement("div",{style:s.single},n.createElement(e4,{style:{input:s.input,label:s.label},label:"b",value:r.b,onChange:l,dragLabel:"true",dragMax:"255"})),n.createElement("div",{style:s.alpha},n.createElement(e4,{style:{input:s.input,label:s.label},label:"a",value:Math.round(100*r.a),onChange:l,dragLabel:"true",dragMax:"100"})))};var kte=Object.assign||function(e){for(var t=1;t({offset:e.offset,color:e.rgb}))),[o,a]=(0,n.useState)(!1);return(0,j.jsx)($te,{open:o,setOpen:()=>a(!o),showAnglePicker:!1,width:150,maxStops:10,paletteHeight:25,palette:i,onPaletteChange:e=>{const t=e.map((e=>{const t=e.color.replace(/[^0-9,]/g,"").split(",");return{rgb:`rgb(${Number(t[0])}, ${Number(t[1])}, ${Number(t[2])})`,offset:e.offset}}));r(t)},flatStyle:!0,children:(0,j.jsx)(qte,{})})})),qte=e=>{let{onSelect:t,color:r}=e;return(0,j.jsx)(Cte,{color:r,width:"150px",onChange:e=>{const{r:r,g:n,b:i,a:o}=e.rgb;null===t||void 0===t||t(`rgb(${r}, ${n}, ${i})`,o)}})},Gte=(0,n.memo)((function(e){let{label:t,onChange:r,value:n,children:i}=e;return(0,j.jsx)(yi,{marginBottom:2,children:(0,j.jsxs)(oH,{variant:"standard",size:"small",fullWidth:!0,children:[(0,j.jsx)(tH,{style:{position:"static",transform:"none",transition:"none",fontWeight:"bold",fontSize:"0.95rem",color:"text.secondary"},children:t}),(0,j.jsx)(GN,{variant:"outlined",value:n,onChange:r,children:i})]})})})),Yte=()=>{const e=(0,n.useContext)(vre),t=x(mA(e)),r=x(gA(e)),i=C();return(0,j.jsxs)(bZ,{title:"SaveFig",children:[(0,j.jsxs)(Gte,{label:"File Format",value:r,onChange:t=>{i(DT({itemId:e,saveFormat:t.target.value}))},children:[(0,j.jsx)(qa,{value:"svg",children:"svg"}),(0,j.jsx)(qa,{value:"png",children:"png"}),(0,j.jsx)(qa,{value:"jpeg",children:"jpeg"}),(0,j.jsx)(qa,{value:"webp",children:"webp"})]}),(0,j.jsx)(a3,{type:"text",label:"Filename",value:t,onChange:t=>{i(zT({itemId:e,saveFileName:t.target.value}))}})]})},Xte=()=>{const e=(0,n.useContext)(vre),t=C(),r=x(UA(e));return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsxs)(bZ,{title:"Heatmap",children:[(0,j.jsx)(Zte,{}),(0,j.jsxs)(Mf,{container:!0,component:"label",alignItems:"center",children:[(0,j.jsx)(Mf,{item:!0,xs:8,children:(0,j.jsx)(wZ,{children:"Pick Color"})}),(0,j.jsx)(Mf,{item:!0,xs:4,children:(0,j.jsx)(Wte,{colors:r,dispatchSetColor:r=>{t(fM({itemId:e,colors:r}))}})})]})]}),(0,j.jsx)(Yte,{})]})},Zte=()=>{const e=(0,n.useContext)(vre),t=x(VA(e)),r=C();return(0,j.jsx)(o3,{label:"ShowScale",value:t,onChange:()=>{r(pM({itemId:e,showscale:!t}))}})},Kte=()=>{const e=(0,n.useContext)(vre),t=C(),r=x(yA(e)),i=x(MA(e));return(0,j.jsxs)(j.Fragment,{children:[(0,j.jsxs)(bZ,{title:"Image",children:[(0,j.jsx)(kZ,{filePath:r}),(0,j.jsx)(ore,{}),(0,j.jsx)(Jte,{}),(0,j.jsx)(Qte,{}),(0,j.jsx)(ere,{}),(0,j.jsx)(tre,{}),(0,j.jsx)(rre,{}),(0,j.jsxs)(Mf,{container:!0,component:"label",alignItems:"center",children:[(0,j.jsx)(Mf,{item:!0,xs:8,children:(0,j.jsx)(wZ,{children:"Pick Color"})}),(0,j.jsx)(Mf,{item:!0,xs:4,children:(0,j.jsx)(Wte,{colors:i,dispatchSetColor:r=>{t(ZT({itemId:e,colors:r}))}})})]}),(0,j.jsx)(nre,{}),(0,j.jsx)(ire,{})]}),(0,j.jsx)(Yte,{})]})},Jte=()=>{const e=(0,n.useContext)(vre),t=x(bA(e)),r=C();return(0,j.jsx)(o3,{label:"ShowTickLabels",value:t,onChange:()=>{r(WT({itemId:e,showticklabels:!t}))}})},Qte=()=>{const e=(0,n.useContext)(vre),t=x(SA(e)),r=C();return(0,j.jsx)(o3,{label:"ShowLine",value:t,onChange:()=>{r(GT({itemId:e,showline:!t}))}})},ere=()=>{const e=(0,n.useContext)(vre),t=x(AA(e)),r=C();return(0,j.jsx)(o3,{label:"ShowGrid",value:t,onChange:()=>{r(YT({itemId:e,showgrid:!t}))}})},tre=()=>{const e=(0,n.useContext)(vre),t=x(TA(e)),r=C();return(0,j.jsx)(o3,{label:"ShowScale",value:t,onChange:()=>{r(XT({itemId:e,showscale:!t}))}})},rre=()=>{const e=(0,n.useContext)(vre),t=x(_A(e)),r=C();return(0,j.jsxs)(Gte,{label:"Smooth",onChange:t=>{r(qT({itemId:e,zsmooth:t.target.value}))},value:t,children:[(0,j.jsx)(qa,{value:"best",children:"best"}),(0,j.jsx)(qa,{value:"fast",children:"fast"}),(0,j.jsx)(qa,{value:"false",children:"False"})]})},nre=()=>{const e=(0,n.useContext)(vre),t=C(),r=x(CA(e)),i=!(r>0);return(0,j.jsx)(a3,{label:"Image Alpha",type:"number",value:r,inputProps:{step:.1,min:0,max:1},onChange:r=>{const n=""===r.target.value?"":Number(r.target.value);"number"===typeof n&&t(QT({itemId:e,alpha:n}))},error:i,helperText:i?"index > 0":void 0})},ire=()=>{const e=(0,n.useContext)(vre),t=C(),r=x(EA(e)),i=!(r>0);return(0,j.jsx)(a3,{label:"Roi Alpha",type:"number",value:r,inputProps:{step:.1,min:0,max:1},onChange:r=>{const n=""===r.target.value?"":Number(r.target.value);"number"===typeof n&&t(eM({itemId:e,roiAlpha:n}))},error:i,helperText:i?"index > 0":void 0})},ore=()=>{const e=x(jf),t=(0,n.useContext)(vre),[r,i]=(0,n.useState)(x(wA(t))),[o,a]=(0,n.useState)(x(kA(t))),s=!(r>0),l=C(),c=x(yA(t));return(0,j.jsxs)(yi,{marginBottom:2,children:[(0,j.jsx)(wZ,{children:"Start/End Index"}),(0,j.jsxs)(yi,{sx:{display:"flex",alignItems:"flex-start"},children:[(0,j.jsx)(gH,{error:s,type:"number",inputProps:{step:1,min:0},InputLabelProps:{shrink:!0},onChange:e=>{const t=""===e.target.value?"":Number(e.target.value);"number"===typeof t&&i(t)},value:r,helperText:s?"index > 0":void 0,style:{marginRight:8}}),"~",(0,j.jsx)(gH,{type:"number",InputLabelProps:{shrink:!0},onChange:e=>{const t=""===e.target.value?"":Number(e.target.value);"number"===typeof t&&a(t)},value:o,style:{marginLeft:8,marginRight:8}}),(0,j.jsx)(gf,{size:"small",className:"ctrl_btn",variant:"contained",onClick:()=>{r>0&&(l(KT({itemId:t,startIndex:r})),l(JT({itemId:t,endIndex:o})),l(VT({itemId:t,startIndex:r,endIndex:o})),e&&null!==c&&l(sS({workspaceId:e,path:c,startIndex:null!==r&&void 0!==r?r:1,endIndex:null!==o&&void 0!==o?o:10})))},children:"load"})]})]})},are=()=>(0,j.jsx)(j.Fragment,{}),sre=()=>(0,j.jsxs)(j.Fragment,{children:[(0,j.jsxs)(bZ,{title:"TimeSeries",children:[(0,j.jsx)(lre,{}),(0,j.jsx)(cre,{}),(0,j.jsx)(ure,{}),(0,j.jsx)(dre,{}),(0,j.jsx)(hre,{}),(0,j.jsx)(pre,{}),(0,j.jsx)(fre,{}),(0,j.jsx)(mre,{}),(0,j.jsx)(gre,{})]}),(0,j.jsx)(Yte,{})]}),lre=()=>{const e=(0,n.useContext)(vre),t=x(IA(e)),r=C();return(0,j.jsx)(o3,{label:"STD",value:t,onChange:()=>{r(rM({itemId:e,stdBool:!t}))}})},cre=()=>{const e=(0,n.useContext)(vre),t=x(PA(e)),r=C();return(0,j.jsx)(a3,{type:"number",label:"vertical offset",value:t,onChange:t=>{const n=""===t.target.value?"":Number(t.target.value);"number"===typeof n&&n>0&&r(nM({itemId:e,span:n}))}})},ure=()=>{const e=(0,n.useContext)(vre),t=x(OA(e)),r=C();return(0,j.jsx)(o3,{label:"ShowGrid",value:t,onChange:()=>{r(iM({itemId:e,showgrid:!t}))}})},dre=()=>{const e=(0,n.useContext)(vre),t=x(RA(e)),r=C();return(0,j.jsx)(o3,{label:"ShowLine",value:t,onChange:()=>{r(oM({itemId:e,showline:!t}))}})},hre=()=>{const e=(0,n.useContext)(vre),t=x(LA(e)),r=C();return(0,j.jsx)(o3,{label:"ShowTickLabels",value:t,onChange:()=>{r(aM({itemId:e,showticklabels:!t}))}})},pre=()=>{const e=(0,n.useContext)(vre),t=x(DA(e)),r=C();return(0,j.jsx)(o3,{label:"ZeroLine",value:t,onChange:()=>{r(sM({itemId:e,zeroline:!t}))}})},fre=()=>{const e=(0,n.useContext)(vre),t=x(QA(e)),r=C();return(0,j.jsxs)(Gte,{label:"Range Unit",value:t,onChange:async t=>{r(MT({itemId:e,rangeUnit:t.target.value}))},children:[(0,j.jsx)(qa,{value:"frames",children:"Frames"}),(0,j.jsx)(qa,{value:"time",children:"Time"})]})},mre=()=>{var e,t;const r=x(Uk),i=(0,n.useContext)(vre),o=x($G(r)),a=x(QA(i)),s=x(zA(i)),[l,c]=(0,n.useState)(s);(0,n.useEffect)((()=>{Object.keys(l).length<1||c("frames"===a?s:{left:Number(s.left)/o,right:Number(s.right)/o})}),[JSON.stringify(a),JSON.stringify(s)]);const u=C();return(0,j.jsxs)(Mf,{container:!0,justifyContent:"space-between",children:[(0,j.jsx)(Mf,{item:!0,children:(0,j.jsx)(a3,{label:"Left",type:"number",inputProps:{min:0},style:{width:105},onChange:e=>{const t=""===e.target.value?"":Number(e.target.value);"number"===typeof t&&u(lM({itemId:i,left:"frames"===a?t:t*o}))},value:null!==(e=l.left)&&void 0!==e?e:""})}),(0,j.jsx)(Mf,{item:!0,children:(0,j.jsx)(a3,{label:"Right",type:"number",style:{width:105},onChange:e=>{const t=""===e.target.value?"":Number(e.target.value);"number"===typeof t&&u(cM({itemId:i,right:"frames"===a?t:t*o}))},value:null!==(t=l.right)&&void 0!==t?t:""})})]})},gre=()=>{const e=(0,n.useContext)(vre),t=C(),r=x(NA(e),vY),i=x(jA(e),vY),o=x(vA(e)),a=r=>{const n=r.target.value,a=r.target.checked?[...i,n]:i.filter((e=>e!==n));t(uM({itemId:e,drawOrderList:a})),null!==o&&t(iS({path:o,index:n}))},s=Object.fromEntries(r.map((e=>i.includes(e)?[e,!0]:[e,!1]))),l=(0,j.jsx)(yi,{sx:{display:"flex",flexDirection:"column",ml:3},children:r.map((e=>(0,j.jsx)(aV,{label:`Index ${e}`,control:(0,j.jsx)(WU,{checked:s[e],onChange:a,value:e})},`${e}`)))});return(0,j.jsxs)(i3,{sx:{my:2},TransitionProps:{unmountOnExit:!0},children:[(0,j.jsx)(J2,{expandIcon:(0,j.jsx)(B2.A,{}),children:"Legend select"}),(0,j.jsx)($2,{children:(0,j.jsxs)(j.Fragment,{children:[(0,j.jsx)(aV,{label:"All Check",control:(0,j.jsx)(WU,{checked:Object.values(s).every((e=>e)),onChange:n=>{t(uM({itemId:e,drawOrderList:n.target.checked?r:[]})),n.target.checked&&null!==o&&t(oS({path:o}))}})}),l]})})]})},yre=()=>{const e=x(oA);return(0,j.jsx)(j.Fragment,{children:null!=e?(0,j.jsx)(vre.Provider,{value:e,children:(0,j.jsx)(xre,{})}):"Please select item..."})},vre=(0,n.createContext)(NaN),xre=()=>{const e=(0,n.useContext)(vre),t=x(hA(e));return(0,j.jsx)(bre,{dataType:t})},bre=e=>{let{dataType:t}=e;switch(t){case Yf:return(0,j.jsx)(Kte,{});case Xf:return(0,j.jsx)(j5,{});case Gf:return(0,j.jsx)(Xte,{});case qf:return(0,j.jsx)(sre,{});case Zf:return(0,j.jsx)(are,{});case Kf:case Jf:case nm:case im:case om:case am:return(0,j.jsx)(Yte,{});case em:return(0,j.jsx)("div",{children:"html editor"});default:return null}},_re=(0,yn.Ay)("main")({display:"flex",flexDirection:"column",flexGrow:1,minHeight:kC}),wre=()=>(0,j.jsxs)(yi,{display:"flex",children:[(0,j.jsx)(yi,{width:240,marginRight:3,borderRight:1,borderColor:vZ.A[300],children:(0,j.jsxs)(yi,{overflow:"auto",marginRight:2,children:[(0,j.jsx)(SZ,{}),(0,j.jsx)(yre,{})]})}),(0,j.jsx)(_re,{children:(0,j.jsx)(z5,{})})]}),kre={status:"uninitialized",loading:!0},Sre=Pl({name:If,initialState:kre,reducers:{clearExperiments:()=>kre},extraReducers:e=>{e.addCase(Uf.pending,(()=>({status:"pending",loading:!0}))).addCase(Uf.fulfilled,((e,t)=>({status:"fulfilled",experimentList:function(e){const t={};return Object.entries(e).forEach((e=>{let[r,n]=e;t[r]=WG(n)})),t}(t.payload),loading:!1}))).addCase(Uf.rejected,((e,t)=>({status:"error",message:t.error.message,loading:!1}))).addCase(Hf.fulfilled,((e,t)=>{e.loading=!1,t.payload&&"fulfilled"===e.status&&delete e.experimentList[t.meta.arg]})).addCase($f.fulfilled,((e,t)=>{e.loading=!1,t.payload&&"fulfilled"===e.status&&t.meta.arg.map((t=>delete e.experimentList[t]))})).addCase(tS.fulfilled,((e,t)=>{if("fulfilled"===e.status){const r=t.meta.arg.uid,n=e.experimentList[r];Object.entries(t.payload).forEach((e=>{let[t,r]=e;"success"===r.status?n.functions[t].status="success":"error"===r.status&&(n.functions[t].status="error")}))}})).addMatcher(Bl(Hf.pending,$f.pending),(e=>{e.loading=!0})).addMatcher(Bl(Hf.rejected,$f.rejected),(e=>{e.loading=!1})).addMatcher(Bl(nk.fulfilled,ik.fulfilled),((e,t)=>{"fulfilled"===e.status&&(e.experimentList[t.payload.unique_id]=WG(t.payload))})).addMatcher(Bl(Qk.fulfilled,eS.fulfilled),(()=>({status:"uninitialized"})))}}),{clearExperiments:Are}=Sre.actions,Tre=Sre.reducer,Mre=aP((e=>c3(e).params),L3,(e=>{const t={};return DY(e).forEach((e=>{t[e.id]=e})),t}),(e=>{const t=LY(e),r={};return t.forEach((t=>{if(yw(t)){var n,i,o;const a=null!==(n=jJ(t.id)(e))&&void 0!==n?n:{},s=(l=t.id,e=>DJ(l)(e).functionPath)(e),c={...t,data:{...t.data,label:null!==(i=null===(o=t.data)||void 0===o?void 0:o.label)&&void 0!==i?i:"",type:mw,path:s,param:a}};r[t.id]=c}else{var a,s;const n=(e=>t=>w1(e)(t).selectedFilePath)(t.id)(e),i=(e=>t=>w1(e)(t).fileType)(t.id)(e),o=(e=>t=>w1(e)(t).param)(t.id)(e),l=P1(t.id)(e),c=O1(t.id)(e),u={...t,data:{...t.data,label:null!==(a=null===(s=t.data)||void 0===s?void 0:s.label)&&void 0!==a?a:"",type:fw,path:null!==n&&void 0!==n?n:"",param:o,matPath:c,hdf5Path:l,fileType:i}};r[t.id]=u}var l})),r}),(e=>LY(e).filter(yw).filter((t=>{const r=FJ(t.id)(e),n=Kk(t.id)(e);return r||n===Ok.ERROR})).map((t=>({nodeId:t.id,name:zJ(t.id)(e)})))),((e,t,r,n,i)=>({nwbParam:e,snakemakeParam:t,edgeDict:r,nodeDict:n,forceRunList:i})));function Cre(){const e=C(),t=C(),r=x(Pf),i=Ye(),o=qe(),{workspaceId:a}=function(){let{matches:e}=n.useContext(He),t=e[e.length-1];return t?t.params:{}}(),s=Number(a);(0,n.useEffect)((()=>(r?(e(gC(1)),e(nk(1))):t(lC({id:s})).unwrap().then((t=>{var r;e(nk(s));const n=null===(r=o.state)||void 0===r?void 0:r.tab;n&&e(vC(n))})).catch((e=>{i("/console/workspaces")})),()=>{e(Are()),e(yC())})),[e,t,i,s,o.state,r]);const l=x(Uk),c=x(Yk),u=x(Xk),d=!x(Vf)||u,h=x(E1),p=x(NJ),f=x(Mre),{enqueueSnackbar:m}=hn(),g=(0,n.useCallback)((t=>{e(Qk({runPostData:{name:t,...f,forceRunList:[]}})).unwrap().catch((()=>{m("Failed to Run workflow",{variant:"error"})}))}),[e,m,f]),y=(0,n.useCallback)((()=>{e(eS({runPostData:f})).unwrap().catch((()=>{m("Failed to Run workflow",{variant:"error"})}))}),[e,m,f]),v=(0,n.useCallback)((async()=>{if(null!=l){$l(await e(rS({uid:l})))&&m("Failed to cancel workflow. Please try again.",{variant:"error"})}}),[e,l]);(0,n.useEffect)((()=>{const t=setInterval((()=>{u&&!c&&null!=l&&e(tS({uid:l}))}),5e3);return()=>{clearInterval(t)}}),[e,l,c,u]);const b=x(Gk),[_,w]=(0,n.useState)(b);return(0,n.useEffect)((()=>{_!==b&&(b===Ek?(m("Finished",{variant:"success"}),e(Uf())):b===Ck?e(Uf()):b===Ik?(m("Aborted",{variant:"error"}),e(Uf())):b===Pk&&(m("Workflow canceled.",{variant:"success"}),e(Uf())),w(b))}),[e,b,_,m]),{filePathIsUndefined:h,algorithmNodeNotExist:p,uid:l,status:b,runDisabled:d,handleRunPipeline:g,handleRunPipelineByUid:y,handleCancelPipeline:v}}const Ere=(0,yn.Ay)("div")((e=>{let{theme:t}=e;return{flexGrow:1,backgroundColor:t.palette.background.paper,height:"100%"}}));function Ire(e){const{children:t,value:r,index:n,...i}=e;return(0,j.jsx)("div",{style:{height:"calc(100% - 58px)"},role:"tabpanel",hidden:r!==n,id:`simple-tabpanel-${n}`,"aria-labelledby":`simple-tab-${n}`,...i,children:r===n&&(0,j.jsx)(yi,{sx:{height:"100%"},children:t})})}const Pre=()=>{const e=Cre(),t=x(Df);return(0,j.jsxs)(Ere,{children:[(0,j.jsx)(Ire,{value:t,index:0,children:(0,j.jsx)(b5,{...e})}),(0,j.jsx)(Ire,{value:t,index:1,children:(0,j.jsx)(wre,{})}),(0,j.jsx)(Ire,{value:t,index:2,children:(0,j.jsx)(VY,{})})]})},Ore=jl("/getModeStandalone",(async()=>await(async()=>(await wd.get("/is_standalone")).data)())),Rre=e=>{let{snackbarKey:t}=e;const{closeSnackbar:r}=hn();return(0,j.jsx)(oi,{onClick:()=>r(t),size:"large",children:(0,j.jsx)(pn.A,{style:{color:"white"}})})},Lre=()=>{const e=C(),t=x(Pf),r=x(Of),i=()=>{e(Ore()).unwrap().catch((()=>{new Promise((e=>setTimeout(e,5e3))).then((()=>{i()}))}))};return(0,n.useEffect)((()=>{i()}),[]),r?(0,j.jsx)(wi,{loading:!0}):(0,j.jsx)(dn,{maxSnack:5,action:e=>(0,j.jsx)(Rre,{snackbarKey:e}),children:(0,j.jsx)(_t,{children:(0,j.jsx)(wE,{children:t?(0,j.jsxs)(ft,{children:[(0,j.jsx)(ht,{path:"/",element:(0,j.jsx)(Pre,{})}),(0,j.jsx)(ht,{path:"*",element:(0,j.jsx)(dt,{replace:!0,to:"/"})})]}):(0,j.jsxs)(ft,{children:[(0,j.jsx)(ht,{path:"/",element:(0,j.jsx)(dt,{replace:!0,to:"/console"})}),(0,j.jsx)(ht,{path:"/account-deleted",element:(0,j.jsx)(kI,{})}),(0,j.jsx)(ht,{path:"/login",element:(0,j.jsx)(WW,{})}),(0,j.jsx)(ht,{path:"/reset-password",element:(0,j.jsx)(dq,{})}),(0,j.jsx)(ht,{path:"/console",element:(0,j.jsx)(RW,{})}),(0,j.jsx)(ht,{path:"/console/account",element:(0,j.jsx)(wI,{})}),(0,j.jsx)(ht,{path:"/console/account-manager",element:(0,j.jsx)(TW,{})}),(0,j.jsxs)(ht,{path:"/console/workspaces",children:[(0,j.jsx)(ht,{path:"",element:(0,j.jsx)(Cq,{})}),(0,j.jsx)(ht,{path:":workspaceId",element:(0,j.jsx)(Pre,{})})]}),(0,j.jsx)(ht,{path:"/console/*",element:(0,j.jsx)(dt,{replace:!0,to:"/console"})}),(0,j.jsx)(ht,{path:"*",element:(0,j.jsx)(dt,{replace:!0,to:"/"})})]})})})})},Dre=e=>{e&&e instanceof Function&&r.e(488).then(r.bind(r,2488)).then((t=>{let{getCLS:r,getFID:n,getFCP:i,getLCP:o,getTTFB:a}=t;r(e),n(e),i(e),o(e),a(e)}))},zre=Pl({name:i5,initialState:{isLatest:!1,tree:{}},reducers:{},extraReducers:e=>{e.addCase(o5.fulfilled,((e,t)=>{e.tree=V0(t.payload),e.isLatest=!0}))}}).reducer,jre={timeSeries:{},heatMap:{},image:{},csv:{},roi:{},scatter:{},bar:{},html:{},histogram:{},line:{},pie:{},polar:{},loading:!1,loadingStack:[],statusRoi:{temp_add_roi:[],temp_delete_roi:[],temp_merge_roi:[]},isEditRoiCommitting:!1};function Fre(e,t,r){r===Yf?delete e.image[t]:r===qf?delete e.timeSeries[t]:r===Xf?delete e.csv[t]:r===Gf?delete e.heatMap[t]:r===Kf?delete e.scatter[t]:r===Jf?delete e.bar[t]:r===em?delete e.html[t]:r===nm?delete e.histogram[t]:r===im?delete e.line[t]:r===om?delete e.pie[t]:r===am&&delete e.polar[t]}const Nre=Pl({name:Wf,initialState:jre,reducers:{},extraReducers:e=>{e.addCase(rT,((e,t)=>{if(t.payload.deleteData){const{filePath:r,dataType:n}=t.payload;Fre(e,r,n)}})).addCase(nT,((e,t)=>{if(t.payload.deleteData){const{prevDataType:r,prevFilePath:n}=t.payload;Fre(e,n,r)}})).addCase(iS.pending,((e,t)=>{const{path:r}=t.meta.arg;Object.prototype.hasOwnProperty.call(e.timeSeries,r)?(e.timeSeries[r].pending=!0,e.timeSeries[r].fulfilled=!1,e.timeSeries[r].error=null):e.timeSeries[r]={type:"timeSeries",xrange:[],data:{},std:{},pending:!0,fulfilled:!1,error:null}})).addCase(iS.rejected,((e,t)=>{var r;const{path:n}=t.meta.arg;e.timeSeries[n]={type:"timeSeries",xrange:[],data:{},std:{},pending:!1,fulfilled:!1,error:null!==(r=t.error.message)&&void 0!==r?r:"rejected"}})).addCase(iS.fulfilled,((e,t)=>{const{path:r,index:n}=t.meta.arg;e.timeSeries[r].pending=!1,e.timeSeries[r].fulfilled=!0,e.timeSeries[r].error=null,e.timeSeries[r].meta=t.payload.meta,e.timeSeries[r].data[n]=t.payload.data[n],void 0!==t.payload.std[n]&&(e.timeSeries[r].std[n]=t.payload.std[n])})).addCase(oS.pending,((e,t)=>{const{path:r}=t.meta.arg;Object.prototype.hasOwnProperty.call(e.timeSeries,r)?(e.timeSeries[r].pending=!0,e.timeSeries[r].fulfilled=!1,e.timeSeries[r].error=null):e.timeSeries[r]={type:"timeSeries",xrange:[],data:{},std:{},pending:!0,fulfilled:!1,error:null}})).addCase(oS.rejected,((e,t)=>{var r;const{path:n}=t.meta.arg;e.timeSeries[n]={type:"timeSeries",xrange:[],data:{},std:{},pending:!1,fulfilled:!1,error:null!==(r=t.error.message)&&void 0!==r?r:"rejected"}})).addCase(oS.fulfilled,((e,t)=>{const{path:r}=t.meta.arg;e.timeSeries[r].pending=!1,e.timeSeries[r].fulfilled=!0,e.timeSeries[r].error=null,e.timeSeries[r].xrange=t.payload.xrange,e.timeSeries[r].meta=t.payload.meta,e.timeSeries[r].data=t.payload.data,void 0!==t.payload.std&&(e.timeSeries[r].std=t.payload.std)})).addCase(nS.pending,((e,t)=>{const{path:r}=t.meta.arg;Object.prototype.hasOwnProperty.call(e.timeSeries,r)?(e.timeSeries[r].pending=!0,e.timeSeries[r].fulfilled=!1,e.timeSeries[r].error=null):e.timeSeries[r]={type:"timeSeries",xrange:[],data:{},std:{},pending:!0,fulfilled:!1,error:null}})).addCase(nS.rejected,((e,t)=>{var r;const{path:n}=t.meta.arg;e.timeSeries[n]={type:"timeSeries",xrange:[],data:{},std:{},pending:!1,fulfilled:!1,error:null!==(r=t.error.message)&&void 0!==r?r:"rejected"}})).addCase(nS.fulfilled,((e,t)=>{const{path:r}=t.meta.arg;e.timeSeries[r].pending=!1,e.timeSeries[r].fulfilled=!0,e.timeSeries[r].error=null,e.timeSeries[r].xrange=t.payload.xrange,e.timeSeries[r].meta=t.payload.meta,e.timeSeries[r].data=t.payload.data,e.timeSeries[r].std=t.payload.std})).addCase(aS.pending,((e,t)=>{const{path:r}=t.meta.arg;e.heatMap[r]={type:"heatMap",data:[],columns:[],index:[],pending:!0,fulfilled:!1,error:null}})).addCase(aS.rejected,((e,t)=>{var r;const{path:n}=t.meta.arg;e.heatMap[n]={type:"heatMap",data:[],columns:[],index:[],pending:!1,fulfilled:!1,error:null!==(r=t.error.message)&&void 0!==r?r:"rejected"}})).addCase(aS.fulfilled,((e,t)=>{const{path:r}=t.meta.arg;e.heatMap[r]={type:"heatMap",data:t.payload.data,meta:t.payload.meta,columns:t.payload.columns,index:t.payload.index,pending:!1,fulfilled:!0,error:null}})).addCase(xS.pending,((e,t)=>{const{path:r}=t.meta.arg;e.histogram[r]={type:"histogram",data:[],pending:!0,fulfilled:!1,error:null}})).addCase(xS.rejected,((e,t)=>{var r;const{path:n}=t.meta.arg;e.histogram[n]={type:"histogram",data:[],pending:!1,fulfilled:!1,error:null!==(r=t.error.message)&&void 0!==r?r:"rejected"}})).addCase(xS.fulfilled,((e,t)=>{const{path:r}=t.meta.arg;e.histogram[r]={type:"histogram",data:t.payload.data,meta:t.payload.meta,pending:!1,fulfilled:!0,error:null}})).addCase(bS.pending,((e,t)=>{const{path:r}=t.meta.arg;e.line[r]={type:"line",data:[],columns:[],index:[],pending:!0,fulfilled:!1,error:null}})).addCase(bS.rejected,((e,t)=>{var r;const{path:n}=t.meta.arg;e.line[n]={type:"line",data:[],columns:[],index:[],pending:!1,fulfilled:!1,error:null!==(r=t.error.message)&&void 0!==r?r:"rejected"}})).addCase(bS.fulfilled,((e,t)=>{const{path:r}=t.meta.arg;e.line[r]={type:"line",data:t.payload.data,columns:t.payload.columns,index:t.payload.index,meta:t.payload.meta,pending:!1,fulfilled:!0,error:null}})).addCase(_S.pending,((e,t)=>{const{path:r}=t.meta.arg;e.pie[r]={type:"pie",data:[],columns:[],pending:!0,fulfilled:!1,error:null}})).addCase(_S.rejected,((e,t)=>{var r;const{path:n}=t.meta.arg;e.pie[n]={type:"pie",data:[],columns:[],pending:!1,fulfilled:!1,error:null!==(r=t.error.message)&&void 0!==r?r:"rejected"}})).addCase(_S.fulfilled,((e,t)=>{const{path:r}=t.meta.arg;e.pie[r]={type:"pie",data:t.payload.data,columns:t.payload.columns,meta:t.payload.meta,pending:!1,fulfilled:!0,error:null}})).addCase(wS.pending,((e,t)=>{const{path:r}=t.meta.arg;e.polar[r]={type:"polar",data:[],columns:[],index:[],pending:!0,fulfilled:!1,error:null}})).addCase(wS.rejected,((e,t)=>{var r;const{path:n}=t.meta.arg;e.polar[n]={type:"polar",data:[],columns:[],index:[],pending:!1,fulfilled:!1,error:null!==(r=t.error.message)&&void 0!==r?r:"rejected"}})).addCase(wS.fulfilled,((e,t)=>{const{path:r}=t.meta.arg;e.polar[r]={type:"polar",data:t.payload.data,columns:t.payload.columns,index:t.payload.index,meta:t.payload.meta,pending:!1,fulfilled:!0,error:null}})).addCase(sS.pending,((e,t)=>{const{path:r}=t.meta.arg;e.image[r]={type:"image",data:[],pending:!0,fulfilled:!1,error:null}})).addCase(sS.fulfilled,((e,t)=>{const{path:r}=t.meta.arg;e.image[r]={type:"image",data:t.payload.data,meta:t.payload.meta,pending:!1,fulfilled:!0,error:null}})).addCase(sS.rejected,((e,t)=>{var r;const{path:n}=t.meta.arg;e.image[n]={type:"image",data:[],pending:!1,fulfilled:!1,error:null!==(r=t.error.message)&&void 0!==r?r:"rejected"}})).addCase(lS.pending,((e,t)=>{const{path:r}=t.meta.arg;e.csv[r]={type:"csv",data:[],pending:!0,fulfilled:!1,error:null}})).addCase(lS.fulfilled,((e,t)=>{const{path:r}=t.meta.arg;e.csv[r]={type:"csv",data:t.payload.data,meta:t.payload.meta,pending:!1,fulfilled:!0,error:null}})).addCase(lS.rejected,((e,t)=>{var r;const{path:n}=t.meta.arg;e.csv[n]={type:"csv",data:[],pending:!1,fulfilled:!1,error:null!==(r=t.error.message)&&void 0!==r?r:"rejected"}})).addCase(cS.pending,((e,t)=>{const{path:r}=t.meta.arg;e.loadingStack.push(e.loading=!0),e.roi[r]={type:"roi",data:[],pending:!0,fulfilled:!1,error:null,roiUniqueList:[]}})).addCase(cS.fulfilled,((e,t)=>{const{path:r}=t.meta.arg,{data:n}=t.payload;e.loadingStack.pop(),e.loading=e.loadingStack.length>0;const i=n[0].map((e=>Array.from(new Set(e.filter((e=>null!=e)))))).flat(),o=Array.from(new Set(i)).sort(((e,t)=>e-t)).map(String);e.roi[r]={type:"roi",data:n,meta:t.payload.meta,pending:!1,fulfilled:!0,error:null,roiUniqueList:o}})).addCase(cS.rejected,((e,t)=>{var r;const{path:n}=t.meta.arg;e.loadingStack.pop(),e.loading=e.loadingStack.length>0,e.roi[n]={type:"roi",data:[],pending:!1,fulfilled:!1,error:null!==(r=t.error.message)&&void 0!==r?r:"rejected",roiUniqueList:[]}})).addCase(gS.pending,((e,t)=>{const{path:r}=t.meta.arg;e.scatter[r]={type:"scatter",data:{},pending:!0,fulfilled:!1,error:null}})).addCase(gS.fulfilled,((e,t)=>{const{path:r}=t.meta.arg;e.scatter[r]={type:"scatter",data:t.payload.data,meta:t.payload.meta,pending:!1,fulfilled:!0,error:null}})).addCase(gS.rejected,((e,t)=>{var r;const{path:n}=t.meta.arg;e.scatter[n]={type:"scatter",data:{},pending:!1,fulfilled:!1,error:null!==(r=t.error.message)&&void 0!==r?r:"rejected"}})).addCase(yS.pending,((e,t)=>{const{path:r}=t.meta.arg;e.bar[r]={type:"bar",data:{},columns:[],index:[],pending:!0,fulfilled:!1,error:null}})).addCase(yS.rejected,((e,t)=>{var r;const{path:n}=t.meta.arg;e.bar[n]={type:"bar",data:{},columns:[],index:[],pending:!1,fulfilled:!1,error:null!==(r=t.error.message)&&void 0!==r?r:"rejected"}})).addCase(yS.fulfilled,((e,t)=>{const{path:r}=t.meta.arg;e.bar[r]={type:"bar",data:t.payload.data,meta:t.payload.meta,columns:t.payload.columns,index:t.payload.index,pending:!1,fulfilled:!0,error:null}})).addCase(vS.pending,((e,t)=>{const{path:r}=t.meta.arg;e.html[r]={type:"html",data:"",pending:!0,fulfilled:!1,error:null}})).addCase(vS.fulfilled,((e,t)=>{const{path:r}=t.meta.arg;e.html[r]={type:"html",data:t.payload.data,meta:t.payload.meta,pending:!1,fulfilled:!0,error:null}})).addCase(vS.rejected,((e,t)=>{var r;const{path:n}=t.meta.arg;e.html[n]={type:"html",data:"",pending:!1,fulfilled:!1,error:null!==(r=t.error.message)&&void 0!==r?r:"rejected"}})).addCase(mS.fulfilled,((e,t)=>{e.statusRoi=t.payload,e.loadingStack.pop(),e.loading=e.loadingStack.length>0})).addCase(uS.fulfilled,(e=>{e.statusRoi={temp_add_roi:[],temp_delete_roi:[],temp_merge_roi:[]},e.loadingStack.pop(),e.loading=e.loadingStack.length>0})).addCase(fS.pending,(e=>{e.isEditRoiCommitting=!0,e.loadingStack.push(e.loading=!0)})).addMatcher(Bl(uS.pending,hS.pending,pS.pending,dS.pending,mS.pending),(e=>{e.loadingStack.push(e.loading=!0)})).addMatcher(Bl(uS.rejected,hS.rejected,hS.fulfilled,dS.rejected,dS.fulfilled,pS.rejected,pS.fulfilled,mS.rejected),(e=>{e.loadingStack.pop(),e.loading=e.loadingStack.length>0})).addMatcher(Bl(fS.rejected,fS.fulfilled),(e=>{e.isEditRoiCommitting=!1,e.loadingStack.pop(),e.loading=e.loadingStack.length>0})).addMatcher(Bl(Qk.fulfilled,eS.fulfilled),(()=>jre))}}).reducer,Bre=Pl({name:Fw,initialState:{},reducers:{setFileUploaderStateById(e,t){e[t.payload]=$1}},extraReducers:e=>{e.addCase(Nw,((e,t)=>{const{progress:r,requestId:n}=t.payload;e[n].uploadingProgress=r})).addCase(Bw.pending,((e,t)=>{const{fileName:r,requestId:n}=t.meta.arg,i=e[n];e[n]={...i,fileName:r,isUninitialized:!1,pending:!0,fulfilled:!1,uploadingProgress:0}})).addCase(Bw.fulfilled,((e,t)=>{const{requestId:r}=t.meta.arg,{resultPath:n}=t.payload,i=e[r];e[r]={...i,path:n,pending:!1,fulfilled:!0}})).addCase(Bw.rejected,((e,t)=>{const{requestId:r}=t.meta.arg,n=e[r];e[r]={...n,pending:!1,fulfilled:!1,error:t.error.message}})).addCase(Hw.pending,((e,t)=>{const{requestId:r}=t.meta.arg,n=e[r];e[r]={...n,isUninitialized:!1,pending:!0,fulfilled:!1}})).addCase(Hw.fulfilled,((e,t)=>{const{current:r,total:n}=t.payload,{requestId:i}=t.meta.arg,o=e[i];e[i]={...o,pending:!(r===n),fulfilled:!0}})).addCase(Hw.rejected,((e,t)=>{const{requestId:r}=t.meta.arg,n=e[r];e[r]={...n,pending:!1,fulfilled:!1,error:t.error.message}}))}}),{setFileUploaderStateById:Vre}=Bre.actions,Ure=Bre.reducer,Hre=Pl({name:Dw,initialState:{},reducers:{},extraReducers:e=>{e.addCase(zw.pending,((e,t)=>{const{fileType:r}=t.meta.arg;e[r]={...e[r],isLoading:!0,isLatest:!1}})).addCase(zw.fulfilled,((e,t)=>{const{fileType:r}=t.meta.arg;e[r].tree=qQ(t.payload),e[r].isLatest=!0,e[r].isLoading=!1})).addCase(jw.pending,((e,t)=>{const{fileType:r}=t.meta.arg;e[r]={...e[r],isLoading:!0,isLatest:!1}})).addCase(jw.rejected,((e,t)=>{const{fileType:r}=t.meta.arg;e[r]={...e[r],isLoading:!1,isLatest:!0},Qr("Failed to delete file",{variant:"error"})})).addCase(jw.fulfilled,((e,t)=>{const{fileType:r,fileName:n}=t.meta.arg,i=e[r].tree;e[r].tree=i.filter((e=>e.name!==n)),e[r].isLoading=!1,e[r].isLatest=!0})).addCase(Bw.pending,((e,t)=>{const{fileType:r}=t.meta.arg;r===Xw?null!=e[Lw.IMAGE]?e[Lw.IMAGE].isLatest=!1:e[Lw.IMAGE]={isLoading:!1,isLatest:!1,tree:[]}:r===Yw?null!=e[Lw.CSV]?e[Lw.CSV].isLatest=!1:e[Lw.CSV]={isLoading:!1,isLatest:!1,tree:[]}:r===Zw?null!=e[Lw.HDF5]?e[Lw.HDF5].isLatest=!1:e[Lw.HDF5]={isLoading:!1,isLatest:!1,tree:[]}:null!=e[Lw.ALL]?e[Lw.ALL].isLatest=!1:e[Lw.ALL]={isLoading:!1,isLatest:!1,tree:[]}})).addCase(Bw.fulfilled,((e,t)=>{const{fileType:r}=t.meta.arg;r===Xw?e[Lw.IMAGE].isLatest=!1:r===Yw?e[Lw.CSV].isLatest=!1:r===Zw?e[Lw.HDF5].isLatest=!1:e[Lw.ALL].isLatest=!1})).addCase(ak.fulfilled,(e=>{[Lw.IMAGE,Lw.CSV,Lw.HDF5,Lw.ALL].forEach((t=>{null!=e[t]&&(e[t].isLatest=!1)}))}))}}).reducer;var $re=r(64851);const Wre={50:"#e8eaf6",100:"#c5cae9",200:"#9fa8da",300:"#7986cb",400:"#5c6bc0",500:"#3f51b5",600:"#3949ab",700:"#303f9f",800:"#283593",900:"#1a237e",A100:"#8c9eff",A200:"#536dfe",A400:"#3d5afe",A700:"#304ffe"},qre={50:"#fffde7",100:"#fff9c4",200:"#fff59d",300:"#fff176",400:"#ffee58",500:"#ffeb3b",600:"#fdd835",700:"#fbc02d",800:"#f9a825",900:"#f57f17",A100:"#ffff8d",A200:"#ffff00",A400:"#ffea00",A700:"#ffd600"};var Gre=r(50147),Yre=r(29864),Xre=r(53612);function Zre(e){return e.map((e=>e.isDir?{name:e.name,isDir:!0,nodes:Zre(e.nodes),path:e.path}:{name:e.name,isDir:!1,shape:e.shape,path:e.path,nbytes:e.nbytes}))}function Kre(e){return e.map((e=>e.isDir?{name:e.name,isDir:!0,nodes:Kre(e.nodes),path:e.path,dataType:e.dataType}:{name:e.name,isDir:!1,shape:e.shape,path:e.path,nbytes:e.nbytes,dataType:e.dataType}))}const Jre=function(e){var t,r=El(),n=e||{},i=n.reducer,o=void 0===i?void 0:i,a=n.middleware,s=void 0===a?r():a,l=n.devTools,c=void 0===l||l,u=n.preloadedState,d=void 0===u?void 0:u,h=n.enhancers,p=void 0===h?void 0:h;if("function"===typeof o)t=o;else{if(!kl(o))throw new Error('"reducer" is a required argument, and must be a function or an object of functions that can be passed to combineReducers');t=nl(o)}var f=s;"function"===typeof f&&(f=f(r));var m=ol.apply(void 0,f),g=il;c&&(g=wl(xl({trace:!1},"object"===typeof c&&c)));var y=new Ml(m),v=y;return Array.isArray(p)?v=dl([m],p):"function"===typeof p&&(v=p(y)),rl(t,d,g.apply(void 0,v))}({reducer:nl({algorithmList:zre,algorithmNode:S3,displayData:Nre,fileUploader:Ure,flowElement:kk,inputNode:F1,handleColor:Pl({name:"handleTypeColor",initialState:{colorMap:{ImageData:$re.A[500],IscellData:Wre[500],TimeSeriesData:qre[500],Suite2pData:Gre.A[500],FluoData:Yre.A[500],SpikingActivityData:Yre.A[500],BehaviorData:qre[500],MicroscopeData:Xre.A[500]},nextKey:0},reducers:{}}).reducer,filesTree:Hre,nwb:g3,rightDrawer:r1,visualaizeItem:TM,snakemake:V3,pipeline:KG,hdf5:Pl({name:Q1,initialState:{isLoading:!1,tree:[]},reducers:{},extraReducers:e=>{e.addCase(e2.pending,(e=>{e.tree=[],e.isLoading=!0})).addCase(e2.fulfilled,((e,t)=>{e.tree=Zre(t.payload),e.isLoading=!1}))}}).reducer,matlab:Pl({name:"matlab",initialState:{isLoading:!1,tree:[]},reducers:{},extraReducers:e=>{e.addCase(u2.pending,(e=>{e.tree=[],e.isLoading=!0})).addCase(u2.fulfilled,((e,t)=>{e.tree=Kre(t.payload),e.isLoading=!1}))}}).reducer,experiments:Tre,workspace:bC,user:Bd,mode:Pl({name:"modeStandalone",initialState:{mode:void 0,loading:!0},reducers:{},extraReducers(e){e.addCase(Ore.pending,(e=>{e.loading=!0})).addCase(Ore.fulfilled,((e,t)=>{e.mode=t.payload,e.loading=!1}))}}).reducer}),middleware:e=>e({serializableCheck:!1})}),Qre=(0,fi.A)({components:{MuiTextField:{defaultProps:{variant:"standard"}},MuiSelect:{defaultProps:{variant:"standard"}},MuiDialog:{defaultProps:{disableEscapeKeyDown:!1}}}});(0,P.H)(document.getElementById("root")).render((0,j.jsx)(n.StrictMode,{children:(0,j.jsx)(S,{store:Jre,children:(0,j.jsx)(K,{theme:Qre,children:(0,j.jsx)(Lre,{})})})})),Dre()})()})(); +//# sourceMappingURL=main.d74ed89f.js.map \ No newline at end of file diff --git a/frontend/build/static/js/main.d74ed89f.js.LICENSE.txt b/frontend/build/static/js/main.d74ed89f.js.LICENSE.txt new file mode 100644 index 000000000..a972fe3ef --- /dev/null +++ b/frontend/build/static/js/main.d74ed89f.js.LICENSE.txt @@ -0,0 +1,181 @@ +/* + * @copyright 2016 Sean Connelly (@voidqk), http://syntheti.cc + * @license MIT + * @preserve Project Home: https://github.com/voidqk/polybooljs + */ + +/* +object-assign +(c) Sindre Sorhus +@license MIT +*/ + +/*! + * Determine if an object is a Buffer + * + * @author Feross Aboukhadijeh + * @license MIT + */ + +/*! + * The buffer module from node.js, for the browser. + * + * @author Feross Aboukhadijeh + * @license MIT + */ + +/*! + * pad-left + * + * Copyright (c) 2014-2015, Jon Schlinkert. + * Licensed under the MIT license. + */ + +/*! + * repeat-string + * + * Copyright (c) 2014-2015, Jon Schlinkert. + * Licensed under the MIT License. + */ + +/*! + * The buffer module from node.js, for the browser. + * + * @author Feross Aboukhadijeh + * @license MIT + */ + +/*! + * The buffer module from node.js, for the browser. + * + * @author Feross Aboukhadijeh + * @license MIT + */ + +/*! Native Promise Only + v0.8.1 (c) Kyle Simpson + MIT License: http://getify.mit-license.org +*/ + +/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh */ + +/*! safe-buffer. MIT License. Feross Aboukhadijeh */ + +/** + * @license React + * react-dom.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +/** + * @license React + * react-is.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +/** + * @license React + * react-jsx-runtime.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +/** + * @license React + * react.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +/** + * @license React + * scheduler.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +/** + * @license React + * use-sync-external-store-shim.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +/** + * @license React + * use-sync-external-store-shim/with-selector.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +/** + * @remix-run/router v1.21.0 + * + * Copyright (c) Remix Software Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE.md file in the root directory of this source tree. + * + * @license MIT + */ + +/** + * MapLibre GL JS + * @license 3-Clause BSD. Full text of license: https://github.com/maplibre/maplibre-gl-js/blob/v4.7.1/LICENSE.txt + */ + +/** + * React Router DOM v6.28.0 + * + * Copyright (c) Remix Software Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE.md file in the root directory of this source tree. + * + * @license MIT + */ + +/** + * React Router v6.28.0 + * + * Copyright (c) Remix Software Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE.md file in the root directory of this source tree. + * + * @license MIT + */ + +/** @license React v16.13.1 + * react-is.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +//! moment.js diff --git a/frontend/build/static/js/main.d74ed89f.js.map b/frontend/build/static/js/main.d74ed89f.js.map new file mode 100644 index 000000000..b09cd377b --- /dev/null +++ b/frontend/build/static/js/main.d74ed89f.js.map @@ -0,0 +1 @@ +{"version":3,"file":"static/js/main.d74ed89f.js","mappings":"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V,IACA,IACA,IACA,GAEJ,UAAa,CACT,IACA,IACA,IACA,GAEJ,qBAAwB,CACpB,IACA,IACA,IACA,GAEJ,UAAa,CACT,IACA,IACA,IACA,GAEJ,WAAc,CACV,IACA,IACA,IACA,GAEJ,UAAa,CACT,IACA,IACA,IACA,GAEJ,UAAa,CACT,IACA,IACA,IACA,GAEJ,YAAe,CACX,IACA,IACA,IACA,GAEJ,cAAiB,CACb,GACA,IACA,IACA,GAEJ,aAAgB,CACZ,IACA,IACA,IACA,GAEJ,eAAkB,CACd,IACA,IACA,IACA,GAEJ,eAAkB,CACd,IACA,IACA,IACA,GAEJ,eAAkB,CACd,IACA,IACA,IACA,GAEJ,YAAe,CACX,IACA,IACA,IACA,GAEJ,KAAQ,CACJ,EACA,IACA,EACA,GAEJ,UAAa,CACT,GACA,IACA,GACA,GAEJ,MAAS,CACL,IACA,IACA,IACA,GAEJ,QAAW,CACP,IACA,EACA,IACA,GAEJ,OAAU,CACN,IACA,EACA,EACA,GAEJ,iBAAoB,CAChB,IACA,IACA,IACA,GAEJ,WAAc,CACV,EACA,EACA,IACA,GAEJ,aAAgB,CACZ,IACA,GACA,IACA,GAEJ,aAAgB,CACZ,IACA,IACA,IACA,GAEJ,eAAkB,CACd,GACA,IACA,IACA,GAEJ,gBAAmB,CACf,IACA,IACA,IACA,GAEJ,kBAAqB,CACjB,EACA,IACA,IACA,GAEJ,gBAAmB,CACf,GACA,IACA,IACA,GAEJ,gBAAmB,CACf,IACA,GACA,IACA,GAEJ,aAAgB,CACZ,GACA,GACA,IACA,GAEJ,UAAa,CACT,IACA,IACA,IACA,GAEJ,UAAa,CACT,IACA,IACA,IACA,GAEJ,SAAY,CACR,IACA,IACA,IACA,GAEJ,YAAe,CACX,IACA,IACA,IACA,GAEJ,KAAQ,CACJ,EACA,EACA,IACA,GAEJ,QAAW,CACP,IACA,IACA,IACA,GAEJ,MAAS,CACL,IACA,IACA,EACA,GAEJ,UAAa,CACT,IACA,IACA,GACA,GAEJ,OAAU,CACN,IACA,IACA,EACA,GAEJ,UAAa,CACT,IACA,GACA,EACA,GAEJ,OAAU,CACN,IACA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,KAAM,CAChCt/C,YAAa,CACT,sCACA29C,EAAkByB,mBAAmB,IAAK,OAAQ,UACpD75W,KAAK,OAEX49b,UAAW,CACPrlF,QAAS,aACTt2V,OAAQ,CAAC,SAAU,SACnBu2V,KAAM,SACNC,SAAU,iBACVh+C,YAAa,CACT,kDACA,0EACA,mEACA,2BACA,iEACA,0EACA,iEACA,iEACA,kBACFz6T,KAAK,MAEXg6W,QAAS,CACLzB,QAAS,MACTE,SAAU,iBACVh+C,YAAa,CACT,gEACA,+DACA,mDACA,qEACA,kDACFz6T,KAAK,MAEXy9B,GAAI,CACA86U,QAAS,MACTE,SAAU,iBACVh+C,YAAa,CACT,wCACA,6CACFz6T,KAAK,MAEX09B,GAAI,CACA66U,QAAS,MACTE,SAAU,iBACVh+C,YAAa,CACT,mCACA,6CACFz6T,KAAK,MAEX69b,QAAS,CACLtlF,QAAS,SACTC,KAAM,EACNt3V,KAAM,EACND,IAAK,EACLw3V,SAAU,OACVh+C,YAAa,CACT,kFACA,8EACA,2CACFz6T,KAAK,MAEX89b,QAAS,CACLvlF,QAAS,SACTC,KAAM,EACNt3V,KAAM,EACND,IAAK,EACLw3V,SAAU,OACVh+C,YAAa,CACT,kFACA,8EACA,2CACFz6T,KAAK,MAEXk6W,KAAMsE,EAAW,CAAC,EAAGmP,EAASzT,KAAM,CAChCz/C,YAAa,CACT,sCACA29C,EAAkByB,mBAAmB,IAAK,SAAU,QACtD75W,KAAK,OAEX+9b,UAAW,CACPxlF,QAAS,aACTt2V,OAAQ,CAAC,SAAU,SACnBu2V,KAAM,SACNC,SAAU,iBACVh+C,YAAa,CACT,kDACA,0EACA,oEACA,2BACA,iEACA,0EACA,iEACA,kEACA,kBACFz6T,KAAK,MAEXm6W,QAAS,CACL5B,QAAS,MACTE,SAAU,iBACVh+C,YAAa,CACT,gEACA,+DACA,mDACA,qEACA,kDACFz6T,KAAK,MAEXu8B,GAAI,CACAg8U,QAAS,MACTE,SAAU,iBACVh+C,YAAa,CACT,wCACA,6CACFz6T,KAAK,MAEX08B,GAAI,CACA67U,QAAS,MACTE,SAAU,iBACVh+C,YAAa,CACT,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,OAAQ,CACJwtU,QAAS,aACTE,SAAU,sBACVh+C,YAAa,CACT,0BACA,iEACFz6T,KAAK,MAEXy1lB,GAAI,CACAl9O,QAAS,aACTE,SAAU,sBACVh+C,YAAa,CACT,8BACA,iEACFz6T,KAAK,MAEX01lB,WAAY,CACRn9O,QAAS,aACTE,SAAU,OACVh+C,YAAa,CACT,+BACA,gEACA,mEACA,uEACA,0EACFz6T,KAAK,MAEX21lB,WAAY,CACRp9O,QAAS,aACTE,SAAU,OACVh+C,YAAa,CACT,+BACA,gEACA,mEACA,uEACA,0EACFz6T,KAAK,MAGX41lB,QAAS,CACLr9O,QAAS,UACTE,SAAU,OACVh+C,YAAa,CACT,+CACA,4DACA,yEACA,iEACA,qFACA,2FACA,kEACFz6T,KAAK,MAEX61lB,WAAY,CACRt9O,QAAS,SACTr3V,IAAK,EACLD,IAAK,GACLu3V,KAAM,IACNC,SAAU,OACVh+C,YAAa,CACT,4CACA,kBACA,gEACFz6T,KAAK,MAEX81lB,UAAW,CACPv9O,QAAS,aACTE,SAAU,OACVh+C,YAAa,CACT,uDACA,gEACA,mEACA,sEACA,yCACA,+BACFz6T,KAAK,MAQXu2a,UAAW,CACPh+D,QAAS,aACTt2V,OAAQ,CAAC,MAAO,WAAY,qBAAqB,GACjDw2V,SAAU,OACVh+C,YAAa,CACT,mEACA,YACA,2DACA,8DACA,uCACA,wCACA,+DACA,gEACA,qCACA,sDACA,qCACFz6T,KAAK,MAEX+1lB,OAAQ,CACJx9O,QAAS,SACTr3V,IAAK,EACLD,IAAK,EACLw3V,SAAU,OACVh+C,YAAa,CACT,wDACA,+DACA,kEACA,sCACFz6T,KAAK,MAEXg2lB,SAAU,CACNz9O,QAAS,SACTr3V,KAAM,EACND,IAAK,EACLw3V,SAAU,OACVh+C,YAAa,CACT,qEACA,uEACA,4DACA,0EACFz6T,KAAK,MAEXi2lB,WAAY,CACR19O,QAAS,SACTr3V,IAAK,EACLu3V,SAAU,OACVD,KAAM,EACN/9C,YAAa,CACT,uCACA,qDACA,4CACFz6T,KAAK,MAEX02a,SAAU,CACNn+D,QAAS,aACTt2V,OAAQ,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CA,6DACA,gFACA,gFACA,8CACA,IACA,GACA,2BACA,8BACA,IACA,GACA,+CACA,8CACA,IACA,GACA,4CACA,eACA,0CACA,0CACA,0CACA,uCACA,SACA,IACA,GACA,4CACA,eACA,0CACA,0CACA,0CACA,uCACA,SACA,IACA,GACA,4DACA,sCACA,sCACA,sCACA,oCACA,IACA,GACA,2DACA,oBACA,mBACA,mBACA,mBACA,mBACA,GACA,mCACA,uCACA,2CACA,gCACA,yDACA,gCACA,kEACA,sFACA,gCACA,oEACA,wBACA,kCACA,gBACA,YACA,QACA,oBACA,IACA,GACA,2EACA,qCACA,sCACA,8BACA,GACA,0CACA,4CACA,wCACA,SACA,GACA,mBACA,4EACA,aACA,cACA,SACA,IACA,GACA,gBACA,qDACA,qDACA,qDACA,oDACA,GACA,2BACA,GACA,wDACA,GACA,kBACA,2CACA,kFACA,KACFpspB,KAAK,MAEHqspB,EAAuB,CACvB,yBACA,GACA,0BACA,GACA,gBACA,gCACA,KACFrspB,KAAK,MAEHsspB,EAASp/oB,EAAAA,OAAAA,kBAETwqW,EAAMxqW,EAAQ,OAGdq/oB,EAAoB,KAGpBC,EAAa,KAEbC,EAAa,IAAIz8jB,WAAW,GAC5B08jB,EAAY,IAAI18jB,WAAW,GAE3B28jB,EAAuB,CACvBzioB,MAAO,CAAC,IAAK,GACby2B,OAAQ,OACR1iD,KAAM,QACN++E,IAAK,UACL97D,IAAK,WAaT,SAASkU,EAAM+xS,EAAM5lU,EAAGC,EAAGmM,EAAOE,GAC9B,IAAI21E,EAAK2jP,EAAKF,IACdzjP,EAAG0sG,OAAO1sG,EAAG2zI,cACb3zI,EAAG4zI,QAAQ71N,EAAGC,EAAGmM,EAAOE,GACxBs5T,EAAK/xS,MAAM,CAACjiB,MAAO,CAAC,EAAG,EAAG,EAAG,GAAI0oB,MAAO,GAC5C,CAEA,SAAS+wnB,EAAYzlV,EAAM0lV,EAAOC,EAAajC,EAAgBkC,EAAaploB,GACxE,IAAIqloB,EAASrloB,EAAKttB,IA6BdyypB,EAAYG,iBA/CpB,SAAoB9lV,GAChBA,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AAM,OACN,KAAM,iBACN,KAAM,eACN,KAAM,gBACN,KAAM,oBACN,KAAM,gBACN,KAAM,gCACN,KAAM,KACN,KAAM,MACN,KAAM,aACN,KAAM,YACN,KAAM,iBACN,KAAM,aACN,KAAM,cACN,KAAM,aACN,KAAM,kBACN,KAAM,oBACN,KAAM,aACN,KAAM,eACN,KAAM,sBACN,KAAM,eACN,KAAM,qBACN,KAAM,eACN,KAAM,0BACN,KAAM,0BACN,KAAM,cACN,KAAM,oBACN,KAAM,WACN,KAAM,SACN,KAAM,QACN,KAAM,cACN,KAAM,eACN,KAAM,oBACN,KAAM,kBACN,KAAM,mBACN,KAAM,iBACN,KAAM,mBACN,KAAM,oBACN,KAAM,gBACN,KAAM,WACN,KAAM,aACN,KAAM,YACN,KAAM,aACN,KAAM,aACN,KAAM,eACN,KAAM,aACN,KAAM,YACN,KAAM,UACN,KAAM,SACN,KAAM,OACN,KAAM,gBACN,KAAM,QACN,KAAM,iBACN,KAAM,MACN,KAAM,eACN,KAAM,QACN,KAAM,SACN,KAAM,UACN,KAAM,gBACN,KAAM,kBACN,KAAM,QACN,KAAM,MACN,KAAM,OACN,KAAM,YACN,KAAM,kBACN,KAAM,OACN,KAAM,UACN,KAAM,OACN,KAAM,OACN,KAAM,SACN,KAAM,WACN,KAAM,UACN,KAAM,UACN,KAAM,SACN,KAAM,yBACN,KAAM,wBACN,KAAM,wBACN,KAAM,uBACN,MAAO,qBACP,MAAO,qBACP,MAAO,iBACP,MAAO,iBACP,MAAO,SACP,MAAO,uBACP,MAAO,mBACP,MAAO,iBACP,MAAO,2BACP,MAAO,iBACP,MAAO,2BACP,MAAO,cACP,MAAO,WACP,MAAO,qBACP,MAAO,gBACP,MAAO,wBACP,MAAO,yBACP,MAAO,yBACP,MAAO,sBACP,MAAO,wBACP,MAAO,QACP,MAAO,UACP,MAAO,qBACP,MAAO,2BACP,MAAO,kBACP,MAAO,iBACP,MAAO,UACP,MAAO,wBACP,MAAO,yBACP,MAAO,gBACP,MAAO,gBACP,MAAO,kBACP,MAAO,kBACP,MAAO,gBACP,MAAO,uBACP,MAAO,oBACP,MAAO,2BACP,MAAO,uBACP,MAAO,kBACP,MAAO,2BACP,MAAO,2BACP,MAAO,WACP,MAAO,WACP,MAAO,WACP,MAAO,WACP,MAAO,WACP,MAAO,WACP,MAAO,WACP,MAAO,WACP,MAAO,WACP,MAAO,WACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,KAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,iBACP,MAAO,wBACP,MAAO,gBACP,MAAO,YACP,MAAO,YACP,MAAO,mBACP,MAAO,2BACP,MAAO,8BACP,MAAO,8BACP,MAAO,8BACP,MAAO,8BACP,MAAO,8BACP,MAAO,8BACP,MAAO,4BACP,MAAO,8BACP,MAAO,2BACP,MAAO,6BACP,MAAO,2BACP,MAAO,wBACP,MAAO,8BACP,MAAO,iCACP,MAAO,6BACP,MAAO,cACP,MAAO,eACP,MAAO,oBACP,MAAO,oBACP,MAAO,+BACP,MAAO,+BACP,MAAO,uBACP,MAAO,qBACP,MAAO,iCACP,MAAO,0BACP,MAAO,eACP,MAAO,uBACP,MAAO,uBACP,MAAO,+BACP,MAAO,qCACP,MAAO,cACP,MAAO,cACP,MAAO,eACP,MAAO,kBACP,MAAO,gBACP,MAAO,iCACP,MAAO,mCACP,MAAO,cACP,MAAO,aACP,MAAO,aACP,MAAO,aACP,MAAO,WACP,MAAO,WACP,MAAO,WACP,MAAO,OACP,MAAO,YACP,MAAO,YACP,MAAO,YACP,MAAO,aACP,MAAO,aACP,MAAO,aACP,MAAO,aACP,MAAO,eACP,MAAO,gBACP,MAAO,iBACP,MAAO,cACP,MAAO,kBACP,MAAO,kBACP,MAAO,mBACP,MAAO,kBACP,MAAO,4BACP,MAAO,uBACP,MAAO,oBACP,MAAO,8BACP,MAAO,2BACP,MAAO,kBACP,MAAO,mBACP,MAAO,0BACP,MAAO,yBACP,MAAO,sBACP,MAAO,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B,MACpCgoD,EAAgBhoD,EAAoB,MAEpCynD,EAAS,IACToB,EAAQ,KACRT,EAAgB,EAChBE,EAAe,EACfE,EAAe,EACfE,EAAW,EACXC,EAAU,EACV1lD,EAAQ,EACRqmD,EAAQ,EACRD,EAAU,EACVD,EAAU,EACVL,EAAa,EACbv4sB,EAAM,GACNo4sB,EAAM,GAEN5hwB,EAAM,CACN,gBACA,eACA,eACA,WACA,UACA,QACA,QACA,UACA,UACA,aACA,MACA,UAsVG,EAED,KAAI,SACMy3E,EAAQshoB,EAA0BC,GAGlD,IAAIk7C,EAAOl7C,EAAoB,MAI/Bk7C,EAAOA,EAAKv5vB,QAAQwmB,QAAO,SAAUiH,GACnC,OAAQ,kBAAkBnM,KAAKmM,EACjC,IAEAqvD,EAAO5sE,QAAUqpvB,EAAK5yvB,OAAO,CAEzB,cACA,gBACA,cACA,eACA,eACA,iBACA,eACA,gBACA,sBACA,6BACA,4BACA,6BACA,gCACA,kCACA,0BACA,+BACA,oBACA,2BACA,2BACA,0BACA,gBAGA,QACA,QACA,YACA,QACA,QACA,iBACA,kBACA,iBACA,kBACA,gBACA,kBACA,gBACA,kBACA,eACA,iBACA,eACA,YACA,cACA,UACA,UACA,cACA,cACA,aACA,gBACA,aACA,mBACA,oBACA,mBACA,iBACA,uBACA,cACA,oBACA,kBACA,yBAIG,EAED,KAAI,SACMm2E,GAEhBA,EAAO5sE,QAAU,CAEf,MACE,OACA,MACA,MACA,OACA,OACA,OACA,QACA,MACA,QACA,OACA,OACA,UACA,WACA,MACA,QACA,MACA,OACA,cACA,QACA,QACA,eACA,2BACA,sBACA,kBACA,wBACA,eACA,gBACA,WACA,gBACA,0BACA,eACA,eACA,eACA,eACA,SACA,cACA,kBACA,mBACA,eACA,eACA,cACA,eACA,kBACA,gBACA,iBACA,4BACA,uBACA,mBACA,yBACA,gBACA,0BACA,wBACA,mBACA,iBACA,2BACA,wBACA,mBACA,kCACA,oBACA,kCACA,eACA,sBACA,0BACA,qBACA,sBACA,sBACA,gCACA,gCACA,qBACA,4BACA,qCACA,8BACA,+BACA,sCACA,+CACA,wCACA,oBACA,oBACA,oBACA,oBACA,oBACA,oBACA,oBACA,oBACA,YACA,kBACA,iBACA,kBACA,kBACA,kBACA,kBACA,WACA,gBACA,qBACA,eACA,cACA,sBACA,6BACA,sCACA,+BACA,oBACA,cACA,qBACA,mBACA,0BACA,mCACA,4BACA,YACA,cACA,mBACA,cACA,SACA,WACA,gBACA,MACA,OACA,iBACA,MACA,MACA,MACA,MACA,YACA,MACA,WACA,MACA,UACA,UACA,UACA,OACA,MACA,aACA,OACA,OACA,MACA,YACA,eACA,gBACA,mBACA,cACA,iBACA,kBACA,sBACA,oBACA,mBACA,uBACA,qBAIG,EAED,KAAI,SACM4sE,EAAQshoB,EAA0BC,GAElD,IAAIk7C,EAAOl7C,EAAoB,KAE/BvhoB,EAAO5sE,QAAUqpvB,EAAKv5vB,QAAQ2G,OAAO,CAClC,SACC,WACA,SACA,OACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,QACA,QACA,QACA,oBACA,iBACA,uBACA,aACA,aACA,eACA,kBACA,aACA,aACA,eACA,kBACA,WACA,WACA,WACA,YACA,WACA,cACA,gBACA,QACA,SACA,aACA,SACA,YACA,SACA,SACA,UACA,UACA,UACA,YACA,WACA,WACA,WACA,aACA,WACA,WACA,WACA,aACA,eACA,eACA,gBACA,gBACA,gBACA,gBACA,gBACA,gBACA,qBACA,qBACA,cACA,eACA,eACA,iBACA,uBACA,aACA,kBACA,aACA,kBACA,iBACA,iBACA,gBACA,iBACA,iBACA,cACA,eACA,eACA,mBACA,oBACA,qBAIG,EAED,IAAG,SACOm2E,GAEhBA,EAAO5sE,QAAU,CAEb,YACA,QACA,UACA,OACA,YACA,QACA,UACA,UACA,QACA,WACA,KACA,MACA,QACA,KACA,OACA,KACA,MACA,QACA,QACA,MACA,OACA,OACA,OACA,OACA,QACA,UACA,SACA,OACA,OACA,OACA,OACA,OACA,OACA,QACA,QACA,QACA,QACA,QACA,QACA,YACA,YACA,YACA,cACA,kBACA,kBACA,SAGA,MACA,QACA,QACA,OACA,UACA,WACA,OACA,SACA,OACA,SACA,UACA,SACA,WACA,WACA,SACA,SACA,SACA,WACA,YACA,OACA,QACA,SACA,OACA,QACA,WACA,QACA,SACA,QACA,QACA,QACA,QACA,QACA,QACA,QACA,QACA,QACA,gBACA,gBACA,sBACA,SACA,OACA,YACA,QAIG,EAED,KAAI,SACM4sE,GAEhBA,EAAO5sE,QAAU,CACb,MACA,MACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IACA,IAIG,EAED,KAAI,SACM4sE,EAAQshoB,EAA0BC,GAElD,IAAIwnD,EAAWxnD,EAAoB,MAEnCvhoB,EAAO5sE,QAEP,SAAwBtB,EAAK0pa,GAC3B,IAAI33Z,EAAYklvB,EAASvtV,GACrB1/U,EAAS,GAKb,OAFAA,GADAA,EAASA,EAAOjyF,OAAOga,EAAU/R,KACjBjI,OAAOga,EAAU,MAGnC,CAGO,EAED,KAAI,SACMm8D,GAEhBA,EAAO5sE,QAAU,SAAS1B,GACD,kBAAZA,IAAsBA,EAAU,CAACA,IAG5C,IAFA,IAAIm/T,EAAQ,GAAG3tU,MAAM6F,KAAKkD,UAAU,GAChCmhF,EAAQ,GACHlsF,EAAI,EAAGA,EAAIwQ,EAAQpS,OAAO,EAAG4B,IACpCksF,EAAMvtF,KAAK6R,EAAQxQ,GAAI2vU,EAAM3vU,IAAM,IAGrC,OADAksF,EAAMvtF,KAAK6R,EAAQxQ,IACZksF,EAAMtnF,KAAK,GACpB,CAGO,EAED,KAAI,SACMk6E,EAAQshoB,EAA0BC,GAElD,aAGA,IAAIlgiB,EAAYkgiB,EAAoB,MAqBpCvhoB,EAAO5sE,QAAUiuK,GAnBjB,WACC,IAAIn4F,GAAY,EAEhB,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AAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IAEvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,IAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IAEvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IACvD,KAAM,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,OAK/D502B,EAAKo+W,UAAUgD,OAASszf,mBClZxB,IAAI102B,EAAOtE,EAAQ,OACf9Q,EAAS8Q,EAAQ,OAQrB,SAASk62B,EAAgBjH,GACrBhn3B,KAAK2wC,MAAQ3wC,KAAKin3B,gBAAgBD,GAAY,KAAOhn3B,KAAKin3B,gBAAgB,GAC9E,CAwJA,SAASxzhB,EAAIhqU,EAAGiI,GACZ,OAAOjI,EAAKiI,EAAI7uB,KAAK2iC,MAAM/b,EAAIiI,EACnC,CAxJAu81B,EAAgB7s3B,UAAY,IAAIiX,EAAK6u2B,aAErCjk3B,EAAOgr3B,EAAgB7s3B,UAAW,CAG9B8J,KAAM,UAGNi82B,QAAS,UAGTwD,aAAc,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IAG3DvD,aAAa,EAGbC,SAAU,EAGVC,WAAY,EAGZC,OAAQ,EAiBRN,gBAAiB,CACb,GAAI,CACA/72B,KAAM,UACNs82B,OAAQ,CAAC,KAAM,MACfO,WAAY,CAAC,YAAa,cAAe,UAAW,MAAO,SAAU,YACrE,OAAQ,OAAQ,OAAQ,MAAO,SAAU,UACzCE,gBAAiB,CAAC,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,OAC/FI,SAAU,CAAC,YAAa,WAAY,WAAY,kBAAgB,aAAc,QAAU,UACxFC,cAAe,CAAC,MAAO,KAAM,KAAM,SAAO,OAAQ,MAAO,OACzDC,YAAa,CAAC,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,MAC5Cj5kB,OAAQ,KACRsuD,WAAY,aACZ4qhB,SAAU,EACVC,OAAO,IASfG,SAAU,SAASlwjB,GACf,IAAIh4R,EAAO1gC,KAAKgmH,UAAU0yM,EAAM14T,KAAKqn3B,SAAUrn3B,KAAKun3B,OAAQlv2B,EAAKs4B,MAAMi60B,aACvE,OACgB,MADJlq1B,EAAKg4R,QAAUh4R,EAAKg4R,OAAS,EAAI,IAAM,MAAQ,KACvD,IAAM,IAAa,KAAQ,GACnC,EASA89B,WAAY,SAAS99B,EAAM/3R,EAAOqyR,GAE9B,IAAI63jB,EAAY7q3B,KAAK2sT,QAAQ+L,EAAM/3R,EAAOqyR,GAE1C,OADA63jB,EAAUz10B,MAAOy10B,EAAUl4Z,YAAc,GAAK,EAAI,KAC3C9vd,KAAK2iC,OAAOql1B,EAAU37hB,YAAc,GAAK,GAAK,CACzD,EAQAwE,YAAa,SAASh7B,EAAM/3R,GACxB,IAAID,EAAO1gC,KAAKgmH,UAAU0yM,EAAM/3R,EAAO3gC,KAAKun3B,OAAQlv2B,EAAKs4B,MAAMq2S,cAC/D,OAAOhnV,KAAK2q3B,aAAajq1B,EAAKC,QAAU,IAClB,KAAjBD,EAAKC,SAAkB3gC,KAAK4o3B,SAASlo1B,EAAKg4R,QAAU,EAAI,EACjE,EASA0wjB,QAAS,SAAS1wjB,EAAM/3R,EAAOqyR,GAC3B,OAA4C,IAArChzT,KAAK2yd,UAAUj6J,EAAM/3R,EAAOqyR,EACvC,EAUAygK,KAAM,SAAS/6J,EAAM/3R,EAAOqyR,GACxB,IAAItyR,EAAO1gC,KAAKgmH,UAAU0yM,EAAM/3R,EAAOqyR,EAAK36S,EAAKs4B,MAAM86S,aACvD/yB,EAAOh4R,EAAKg4R,OACZ/3R,EAAQD,EAAKC,QACbqyR,EAAMtyR,EAAKsyR,MACX,IAAIk7jB,EAASx1jB,GAAQA,GAAQ,EAAI,IAAM,KACnCy1jB,EAAS,IAAM16hB,EAAIy6hB,EAAQ,MAC/B,OAAOl7jB,GAAOryR,GAAS,EAAkB,IAAbA,EAAQ,GAAwB,IAAbA,EAAQ,GAAU,GAC7D99B,KAAK2iC,OAAgB,IAAT2o1B,EAAe,KAAO,MAAuB,KAAdA,EAAS,GACxB,QAA5Btr3B,KAAK2iC,MAAM0o1B,EAAS,MAAkBlu3B,KAAKmn3B,QAAU,CAC7D,EAMAzsf,OAAQ,SAAS4+a,GAEb,IAAI80E,GADJ90E,EAAKz2yB,KAAK2iC,MAAM8zwB,GAAM,IACJt5yB,KAAKyzd,KAAK,IAAK,EAAG,GAChC53J,EAAQh5T,KAAK2iC,MAAM4o1B,EAAS,SAC5BC,EAAQ56hB,EAAI26hB,EAAQ,SACpBE,EAAS,KACb,GAAc,UAAVD,EAAmB,CACnB,IAAIE,EAAO1r3B,KAAK2iC,MAAM6o1B,EAAQ,KAC1BG,EAAO/6hB,EAAI46hB,EAAO,KACtBC,EAASzr3B,KAAK2iC,OAAQ,KAAO+o1B,EAAS,KAAOC,EAAQ,MAAQ,SAAWD,EAAO,CACnF,CACA,IAAI71jB,EAAO41jB,EAAU,KAAOzyjB,EAAS,IACrCnD,EAAQA,GAAQ,EAAIA,EAAO,EAAIA,EAC/B,IAAI+1jB,EAAOn1E,EAAKt5yB,KAAKyzd,KAAK/6J,EAAM,EAAG,GAAK,EACpC/3R,EAAS8t1B,GAAQ,IAAM5r3B,KAAK8hD,KAAK8p0B,EAAO,IAAM5r3B,KAAK8hD,MAAM8p0B,EAAO,GAAK,IACrEz7jB,EAAMsmf,EAAKt5yB,KAAKyzd,KAAK/6J,EAAM/3R,EAAO,GAAK,EAC3C,OAAO3gC,KAAK2sT,QAAQ+L,EAAM/3R,EAAOqyR,EACrC,IASJ36S,EAAKo+W,UAAUiD,QAAUu0f,EACzB512B,EAAKo+W,UAAUkD,OAASs0f,gBCzKxB,IAAI512B,EAAOtE,EAAQ,OACf9Q,EAAS8Q,EAAQ,OAGjB+y2B,EAAoBzu2B,EAAKknB,WAM7B,SAASmv1B,EAAe1H,GACpBhn3B,KAAK2wC,MAAQ3wC,KAAKin3B,gBAAgBD,GAAY,KAAOhn3B,KAAKin3B,gBAAgB,GAC9E,CAEAyH,EAAett3B,UAAY,IAAIiX,EAAK6u2B,aAEpCjk3B,EAAOyr3B,EAAett3B,UAAW,CAG7B8J,KAAM,SAGNi82B,QAAS,UAGTwH,YAAa,KAGbhE,aAAc,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IAG3DvD,aAAa,EAGbC,SAAU,EAGVC,WAAY,EAGZC,OAAQ,EAiBRN,gBAAiB,CACb,GAAI,CACA/72B,KAAM,SACNs82B,OAAQ,CAAC,OAAQ,OACjBO,WAAY,CAAC,UAAW,WAAY,QAAS,QAAS,MAAO,OAC7D,OAAQ,SAAU,YAAa,UAAW,WAAY,YACtDE,gBAAiB,CAAC,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,OAC/FI,SAAU,CAAC,SAAU,SAAU,UAAW,YAAa,WAAY,SAAU,YAC7EC,cAAe,CAAC,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,OAC1DC,YAAa,CAAC,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,MAClDj5kB,OAAQ,KACRsuD,WAAY,aACZ4qhB,SAAU,EACVC,OAAO,IASfG,SAAU,SAASlwjB,GACf,IAAIh4R,EAAO1gC,KAAKgmH,UAAU0yM,EAAM14T,KAAKqn3B,SAAUrn3B,KAAKun3B,OAAQlv2B,EAAKs4B,MAAMi60B,aACnElyjB,EAAO14T,KAAK4u3B,SAASlu1B,EAAKg4R,QAC9B,OAAOoujB,EAAkB8B,SAASlwjB,EACtC,EASA89B,WAAY,SAAS99B,EAAM/3R,EAAOqyR,GAC9B,IAAItyR,EAAO1gC,KAAKgmH,UAAU0yM,EAAM14T,KAAKqn3B,SAAUrn3B,KAAKun3B,OAAQlv2B,EAAKs4B,MAAMi60B,aACnElyjB,EAAO14T,KAAK4u3B,SAASlu1B,EAAKg4R,QAC9B,OAAOoujB,EAAkBtwhB,WAAW99B,EAAMh4R,EAAKC,QAASD,EAAKsyR,MACjE,EAQA0gC,YAAa,SAASh7B,EAAM/3R,GACxB,IAAID,EAAO1gC,KAAKgmH,UAAU0yM,EAAM/3R,EAAO3gC,KAAKun3B,OAAQlv2B,EAAKs4B,MAAMq2S,cAC/D,OAAOhnV,KAAK2q3B,aAAajq1B,EAAKC,QAAU,IAClB,IAAjBD,EAAKC,SAAiB3gC,KAAK4o3B,SAASlo1B,EAAKg4R,QAAU,EAAI,EAChE,EASA0wjB,QAAS,SAAS1wjB,EAAM/3R,EAAOqyR,GAC3B,OAAQhzT,KAAK2yd,UAAUj6J,EAAM/3R,EAAOqyR,IAAQ,GAAK,CACrD,EAUAygK,KAAM,SAAS/6J,EAAM/3R,EAAOqyR,GACxB,IAAItyR,EAAO1gC,KAAKgmH,UAAU0yM,EAAM/3R,EAAOqyR,EAAK36S,EAAKs4B,MAAM86S,aACnD/yB,EAAO14T,KAAK4u3B,SAASlu1B,EAAKg4R,QAC9B,OAAOoujB,EAAkBrzZ,KAAK/6J,EAAMh4R,EAAKC,QAASD,EAAKsyR,MAC3D,EAMA0nE,OAAQ,SAAS4+a,GACb,IAAI54wB,EAAOom1B,EAAkBpsf,OAAO4+a,GAChC5gf,EAAO14T,KAAK6u3B,SAASnu1B,EAAKg4R,QAC9B,OAAO14T,KAAK2sT,QAAQ+L,EAAMh4R,EAAKC,QAASD,EAAKsyR,MACjD,EAOA47jB,SAAU,SAASl2jB,GACf,OAAOA,EAAO14T,KAAK2u3B,aAAej2jB,IAAS14T,KAAK2u3B,aAAej2jB,IAAS,EAAI,EAAI,EACpF,EAOAm2jB,SAAU,SAASn2jB,GACf,OAAOA,EAAO14T,KAAK2u3B,aAAej2jB,GAAQ,GAAKA,GAAQ14T,KAAK2u3B,YAAc,EAAI,EAClF,IAIJt22B,EAAKo+W,UAAUmD,OAAS80f,kBCrKxB,IAAIr22B,EAAOtE,EAAQ,OACf9Q,EAAS8Q,EAAQ,OAGjB+y2B,EAAoBzu2B,EAAKknB,WAM7B,SAASuv1B,EAAa9H,GAClBhn3B,KAAK2wC,MAAQ3wC,KAAKin3B,gBAAgBD,GAAY,KAAOhn3B,KAAKin3B,gBAAgB,GAC9E,CAEA6H,EAAa1t3B,UAAY,IAAIiX,EAAK6u2B,aAElCjk3B,EAAO6r3B,EAAa1t3B,UAAW,CAG3B8J,KAAM,OAGNi82B,QAAS,UAGTwH,YAAa,IAGbhE,aAAc,CAAC,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IAG3DvD,aAAa,EAGbC,SAAU,EAGVC,WAAY,EAGZC,OAAQ,EAiBRN,gBAAiB,CACb,GAAI,CACA/72B,KAAM,OACNs82B,OAAQ,CAAC,MAAO,MAChBO,WAAY,CAAC,UAAW,WAAY,QAAS,QAAS,MAAO,OAC7D,OAAQ,SAAU,YAAa,UAAW,WAAY,YACtDE,gBAAiB,CAAC,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,OAC/FI,SAAU,CAAC,SAAU,SAAU,UAAW,YAAa,WAAY,SAAU,YAC7EC,cAAe,CAAC,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,OAC1DC,YAAa,CAAC,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,MAClDj5kB,OAAQ,KACRsuD,WAAY,aACZ4qhB,SAAU,EACVC,OAAO,IASfG,SAAU,SAASlwjB,GACf,IAAIh4R,EAAO1gC,KAAKgmH,UAAU0yM,EAAM14T,KAAKqn3B,SAAUrn3B,KAAKun3B,OAAQlv2B,EAAKs4B,MAAMi60B,aACnElyjB,EAAO14T,KAAK4u3B,SAASlu1B,EAAKg4R,QAC9B,OAAOoujB,EAAkB8B,SAASlwjB,EACtC,EASA89B,WAAY,SAAS99B,EAAM/3R,EAAOqyR,GAC9B,IAAItyR,EAAO1gC,KAAKgmH,UAAU0yM,EAAM14T,KAAKqn3B,SAAUrn3B,KAAKun3B,OAAQlv2B,EAAKs4B,MAAMi60B,aACnElyjB,EAAO14T,KAAK4u3B,SAASlu1B,EAAKg4R,QAC9B,OAAOoujB,EAAkBtwhB,WAAW99B,EAAMh4R,EAAKC,QAASD,EAAKsyR,MACjE,EAQA0gC,YAAa,SAASh7B,EAAM/3R,GACxB,IAAID,EAAO1gC,KAAKgmH,UAAU0yM,EAAM/3R,EAAO3gC,KAAKun3B,OAAQlv2B,EAAKs4B,MAAMq2S,cAC/D,OAAOhnV,KAAK2q3B,aAAajq1B,EAAKC,QAAU,IAClB,IAAjBD,EAAKC,SAAiB3gC,KAAK4o3B,SAASlo1B,EAAKg4R,QAAU,EAAI,EAChE,EASA0wjB,QAAS,SAAS1wjB,EAAM/3R,EAAOqyR,GAC3B,OAAQhzT,KAAK2yd,UAAUj6J,EAAM/3R,EAAOqyR,IAAQ,GAAK,CACrD,EAUAygK,KAAM,SAAS/6J,EAAM/3R,EAAOqyR,GACxB,IAAItyR,EAAO1gC,KAAKgmH,UAAU0yM,EAAM/3R,EAAOqyR,EAAK36S,EAAKs4B,MAAM86S,aACnD/yB,EAAO14T,KAAK4u3B,SAASlu1B,EAAKg4R,QAC9B,OAAOoujB,EAAkBrzZ,KAAK/6J,EAAMh4R,EAAKC,QAASD,EAAKsyR,MAC3D,EAMA0nE,OAAQ,SAAS4+a,GACb,IAAI54wB,EAAOom1B,EAAkBpsf,OAAO4+a,GAChC5gf,EAAO14T,KAAK6u3B,SAASnu1B,EAAKg4R,QAC9B,OAAO14T,KAAK2sT,QAAQ+L,EAAMh4R,EAAKC,QAASD,EAAKsyR,MACjD,EAOA47jB,SAAU,SAASl2jB,GACf,OAAOA,EAAO14T,KAAK2u3B,aAAej2jB,GAAQ,GAAKA,GAAQ14T,KAAK2u3B,YAAc,EAAI,EAClF,EAOAE,SAAU,SAASn2jB,GACf,OAAOA,EAAO14T,KAAK2u3B,aAAej2jB,IAAS14T,KAAK2u3B,aAAej2jB,IAAS,EAAI,EAAI,EACpF,IAIJrgT,EAAKo+W,UAAUoD,KAAOi1f,mBCpKtB,IAAIz22B,EAAOtE,EAAQ,OACf9Q,EAAS8Q,EAAQ,OASrB,SAASg72B,EAAkB/H,GACvBhn3B,KAAK2wC,MAAQ3wC,KAAKin3B,gBAAgBD,GAAY,KAAOhn3B,KAAKin3B,gBAAgB,GAC9E,CAEA8H,EAAkB3t3B,UAAY,IAAIiX,EAAK6u2B,aAEvCjk3B,EAAO8r3B,EAAkB3t3B,UAAW,CAGhC8J,KAAM,YAKNk82B,aAAa,EAGbC,SAAU,EAGVC,WAAY,EAGZC,OAAQ,EAiBRN,gBAAiB,CACb,GAAI,CACA/72B,KAAM,cACNs82B,OAAQ,CAAC,KAAM,MACfO,WAAY,CAAC,cAAe,QAAS,iBAAmB,iBAAmB,kBAAmB,kBAC9F,QAAS,WAAa,UAAW,UAAW,gBAAkB,iBAC9DE,gBAAiB,CAAC,MAAO,MAAO,OAAQ,OAAQ,OAAQ,OAAQ,MAAO,OAAS,MAAO,OAAQ,OAAQ,QACvGI,SAAU,CAAC,eAAgB,kBAAmB,mCAAqB,iCAAmB,sBAAkB,qBAAiB,gBACzHE,YAAa,CAAC,KAAM,MAAO,KAAM,KAAM,KAAM,KAAM,MACnDj5kB,OAAQ,KACRsuD,WAAY,aACZ4qhB,SAAU,EACVC,OAAO,IASfG,SAAU,SAAUlwjB,GAChB,IAAIh4R,EAAO1gC,KAAKgmH,UAAU0yM,EAAM14T,KAAKqn3B,SAAUrn3B,KAAKun3B,OAAQlv2B,EAAKs4B,MAAMi60B,aACvE,OAAyC,MAAjC5q3B,KAAKyyV,WAAW/xT,EAAKg4R,OACjC,EASA89B,WAAY,SAAU99B,EAAM/3R,EAAOqyR,GAE/B,IAAI63jB,EAAY7q3B,KAAK2sT,QAAQ+L,EAAM/3R,EAAOqyR,GAE1C,OADA63jB,EAAUz10B,KAAKy10B,EAAUl4Z,YAAa,KAC/B9vd,KAAK2iC,OAAOql1B,EAAU37hB,YAAc,GAAK,GAAK,CACzD,EAOAuD,WAAY,SAAU/5B,GAElB,IADA,IAAIs2jB,EAAY,EACP/s3B,EAAI,EAAGA,GAAK,GAAIA,IACrB+s3B,GAAahv3B,KAAK0zV,YAAYh7B,EAAMz2T,GAExC,OAAO+s3B,CACX,EAQAt7hB,YAAa,SAAUh7B,EAAM/3R,GAKzB,IAJA,IACIsu1B,EADOjv3B,KAAKgmH,UAAU0yM,EAAM/3R,EAAO3gC,KAAKun3B,OAAQlv2B,EAAKs4B,MAAMq2S,cAC9CysI,OAAS,KAAU,GAEhC7vd,EAAQ,EACH3B,EAAI,EAAGA,EAAIit3B,EAAc7u3B,OAAQ4B,IAAK,CAC3C,GAAIit3B,EAAcjt3B,GAAKgt3B,EACnB,OAAQC,EAActr3B,GAASsr3B,EAActr3B,EAAQ,GAEzDA,GACJ,CACA,OAAO,EACX,EASAwl3B,QAAS,SAAU1wjB,EAAM/3R,EAAOqyR,GAC5B,OAA4C,IAArChzT,KAAK2yd,UAAUj6J,EAAM/3R,EAAOqyR,EACvC,EAUAygK,KAAM,SAAU/6J,EAAM/3R,EAAOqyR,GACzB,IAAItyR,EAAO1gC,KAAKgmH,UAAU0yM,EAAM/3R,EAAOqyR,EAAK36S,EAAKs4B,MAAM86S,aACnD7nV,EAAS,IAAM88B,EAAKg4R,OAAS,GAAMh4R,EAAKC,QAAU,MAEtD,OADYD,EAAKsyR,MAAQk8jB,EAActr3B,EAAQ,GAAK,EACrC,KAAU,EAC7B,EAMA82X,OAAQ,SAAU4+a,GAKd,IAJA,IAAI21E,EAAQ31E,EAAK,KAAU,GAGvB11yB,EAAQ,EACH3B,EAAI,EAAGA,EAAIit3B,EAAc7u3B,UAC1B6u3B,EAAcjt3B,GAAKgt3B,GADeht3B,IAEtC2B,IAEJ,IAAIur3B,EAAWvr3B,EAAQ,MACnBgxV,EAAK/xV,KAAK2iC,OAAO2p1B,EAAW,GAAK,IACjCz2jB,EAAOk8B,EAAK,EACZj0T,EAAQwu1B,EAAW,GAAKv6hB,EACxB5hC,EAAMi8jB,EAAQC,EAActr3B,EAAQ,GAAK,EAC7C,OAAO5D,KAAK2sT,QAAQ+L,EAAM/3R,EAAOqyR,EACrC,EAQA20B,QAAS,SAASjvB,EAAM/3R,EAAOqyR,GAC3B,IAAItsI,EAAQruK,EAAK6u2B,aAAa9l3B,UAAUumV,QAAQt6U,MAAMrN,KAAMgN,WAK5D,OAJI05K,IAEAA,GADAgyI,EAAqB,MAAbA,EAAKA,KAAeA,EAAKA,KAAOA,IACvB,MAAQA,GAAQ,MAE9BhyI,CACX,EAUA1gE,UAAW,SAAS0yM,EAAM/3R,EAAOqyR,EAAK/5S,GAClC,IAAIynB,EAAOroB,EAAK6u2B,aAAa9l3B,UAAU4kH,UAAU34G,MAAMrN,KAAMgN,WAC7D,GAAI0zB,EAAKg4R,KAAO,MAAQh4R,EAAKg4R,KAAO,KAChC,MAAMz/S,EAAM5V,QAAQ,QAASrD,KAAK2wC,MAAMzlC,MAE5C,OAAOw1B,CACX,IAIJroB,EAAKo+W,UAAUqD,UAAYi1f,EAE3B,IAAIG,EAAgB,CAChB,GAAO,GAAO,GAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IACrI,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,IAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KACrI,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAEjD,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,KAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MACrI,MAAO,MAAO,MA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","sources":["../node_modules/@emotion/sheet/dist/emotion-sheet.esm.js","../node_modules/stylis/src/Utility.js","../node_modules/stylis/src/Tokenizer.js","../node_modules/stylis/src/Enum.js","../node_modules/stylis/src/Serializer.js","../node_modules/stylis/src/Parser.js","../node_modules/@emotion/cache/dist/emotion-cache.browser.esm.js","../node_modules/stylis/src/Middleware.js","../node_modules/@emotion/memoize/dist/emotion-memoize.esm.js","../node_modules/@emotion/react/dist/emotion-element-5486c51c.browser.esm.js","../node_modules/@emotion/react/dist/emotion-react.browser.esm.js","../node_modules/@emotion/serialize/node_modules/@emotion/unitless/dist/emotion-unitless.esm.js","../node_modules/@emotion/serialize/dist/emotion-serialize.esm.js","../node_modules/@emotion/hash/dist/emotion-hash.esm.js","../node_modules/@emotion/use-insertion-effect-with-fallbacks/dist/emotion-use-insertion-effect-with-fallbacks.browser.esm.js","../node_modules/@emotion/utils/dist/emotion-utils.browser.esm.js","../node_modules/@icons/material/CheckIcon.js","../node_modules/@icons/material/UnfoldMoreHorizontalIcon.js","../node_modules/@mui/icons-material/AccountCircle.js","../node_modules/@mui/icons-material/AccountTree.js","../node_modules/@mui/icons-material/Add.js","../node_modules/@mui/icons-material/AddLink.js","../node_modules/@mui/icons-material/AddPhotoAlternate.js","../node_modules/@mui/icons-material/Analytics.js","../node_modules/@mui/icons-material/ArrowDropDown.js","../node_modules/@mui/icons-material/Autorenew.js","../node_modules/@mui/icons-material/Block.js","../node_modules/@mui/icons-material/Cancel.js","../node_modules/@mui/icons-material/Check.js","../node_modules/@mui/icons-material/CheckCircleRounded.js","../node_modules/@mui/icons-material/ChecklistRtl.js","../node_modules/@mui/icons-material/ChevronRight.js","../node_modules/@mui/icons-material/Close.js","../node_modules/@mui/icons-material/Dashboard.js","../node_modules/@mui/icons-material/Delete.js","../node_modules/@mui/icons-material/DeleteOutline.js","../node_modules/@mui/icons-material/Done.js","../node_modules/@mui/icons-material/Edit.js","../node_modules/@mui/icons-material/Error.js","../node_modules/@mui/icons-material/ErrorOutline.js","../node_modules/@mui/icons-material/ExitToApp.js","../node_modules/@mui/icons-material/ExpandMore.js","../node_modules/@mui/icons-material/Folder.js","../node_modules/@mui/icons-material/Groups.js","../node_modules/@mui/icons-material/HorizontalRule.js","../node_modules/@mui/icons-material/InsertDriveFileOutlined.js","../node_modules/@mui/icons-material/KeyboardArrowDown.js","../node_modules/@mui/icons-material/KeyboardArrowUp.js","../node_modules/@mui/icons-material/Logout.js","../node_modules/@mui/icons-material/ManageAccounts.js","../node_modules/@mui/icons-material/Menu.js","../node_modules/@mui/icons-material/Portrait.js","../node_modules/@mui/icons-material/Replay.js","../node_modules/@mui/icons-material/Reply.js","../node_modules/@mui/icons-material/Route.js","../node_modules/@mui/icons-material/Settings.js","../node_modules/@mui/icons-material/SimCardDownloadOutlined.js","../node_modules/@mui/icons-material/Tune.js","../node_modules/@mui/icons-material/Visibility.js","../node_modules/@mui/icons-material/VisibilityOff.js","../node_modules/@mui/icons-material/WarningAmberRounded.js","../node_modules/@mui/icons-material/utils/createSvgIcon.js","../node_modules/@mui/material/DefaultPropsProvider/DefaultPropsProvider.js","../node_modules/@mui/material/colors/green.js","../node_modules/@mui/material/colors/grey.js","../node_modules/@mui/material/colors/orange.js","../node_modules/@mui/material/colors/purple.js","../node_modules/@mui/material/colors/red.js","../node_modules/@mui/material/colors/common.js","../node_modules/@mui/material/colors/blue.js","../node_modules/@mui/material/colors/lightBlue.js","../node_modules/@mui/material/styles/createPalette.js","../node_modules/@mui/material/styles/createTypography.js","../node_modules/@mui/material/styles/shadows.js","../node_modules/@mui/material/styles/zIndex.js","../node_modules/@mui/material/styles/createTheme.js","../node_modules/@mui/material/styles/createMixins.js","../node_modules/@mui/material/styles/createTransitions.js","../node_modules/@mui/material/styles/defaultTheme.js","../node_modules/@mui/material/styles/identifier.js","../node_modules/@mui/material/styles/rootShouldForwardProp.js","../node_modules/@mui/material/styles/slotShouldForwardProp.js","../node_modules/@mui/material/styles/styled.js","../node_modules/@mui/material/utils/capitalize.js","../node_modules/@mui/material/SvgIcon/svgIconClasses.js","../node_modules/@mui/material/SvgIcon/SvgIcon.js","../node_modules/@mui/material/utils/createSvgIcon.js","../node_modules/@mui/material/utils/debounce.js","../node_modules/@mui/material/utils/createChainedFunction.js","../node_modules/@mui/material/utils/deprecatedPropType.js","../node_modules/@mui/utils/esm/deprecatedPropType/deprecatedPropType.js","../node_modules/@mui/material/utils/requirePropFactory.js","../node_modules/@mui/utils/esm/requirePropFactory/requirePropFactory.js","../node_modules/@mui/material/utils/setRef.js","../node_modules/@mui/material/utils/unsupportedProp.js","../node_modules/@mui/utils/esm/unsupportedProp/unsupportedProp.js","../node_modules/@mui/material/utils/index.js","../node_modules/@mui/material/utils/isMuiElement.js","../node_modules/@mui/utils/esm/isMuiElement/isMuiElement.js","../node_modules/@mui/material/utils/ownerDocument.js","../node_modules/@mui/material/utils/ownerWindow.js","../node_modules/@mui/material/utils/useControlled.js","../node_modules/@mui/material/utils/useEnhancedEffect.js","../node_modules/@mui/material/utils/useEventCallback.js","../node_modules/@mui/material/utils/useForkRef.js","../node_modules/@mui/material/utils/useId.js","../node_modules/@mui/material/utils/useIsFocusVisible.js","../node_modules/@mui/styled-engine/GlobalStyles/GlobalStyles.js","../node_modules/@emotion/styled/node_modules/@emotion/is-prop-valid/dist/emotion-is-prop-valid.esm.js","../node_modules/@emotion/styled/base/dist/emotion-styled-base.browser.esm.js","../node_modules/@emotion/styled/dist/emotion-styled.browser.esm.js","../node_modules/@mui/styled-engine/StyledEngineProvider/StyledEngineProvider.js","../node_modules/@mui/styled-engine/index.js","../node_modules/@mui/system/colorManipulator.js","../node_modules/@mui/system/createStyled.js","../node_modules/@mui/system/esm/DefaultPropsProvider/DefaultPropsProvider.js","../node_modules/@mui/system/esm/breakpoints.js","../node_modules/@mui/system/esm/createTheme/applyStyles.js","../node_modules/@mui/system/esm/createTheme/createBreakpoints.js","../node_modules/@mui/system/esm/createTheme/shape.js","../node_modules/@mui/system/esm/createTheme/createTheme.js","../node_modules/@mui/system/esm/createTheme/createSpacing.js","../node_modules/@mui/system/esm/merge.js","../node_modules/@mui/system/esm/spacing.js","../node_modules/@mui/system/esm/memoize.js","../node_modules/@mui/system/esm/style.js","../node_modules/@mui/system/esm/compose.js","../node_modules/@mui/system/esm/borders.js","../node_modules/@mui/system/esm/cssGrid.js","../node_modules/@mui/system/esm/palette.js","../node_modules/@mui/system/esm/sizing.js","../node_modules/@mui/system/esm/styleFunctionSx/defaultSxConfig.js","../node_modules/@mui/system/esm/styleFunctionSx/extendSxProp.js","../node_modules/@mui/system/esm/styleFunctionSx/styleFunctionSx.js","../node_modules/@mui/system/useThemeWithoutDefault.js","../node_modules/@mui/utils/esm/ClassNameGenerator/ClassNameGenerator.js","../node_modules/@mui/utils/esm/capitalize/capitalize.js","../node_modules/@mui/utils/esm/clamp/clamp.js","../node_modules/@mui/utils/esm/composeClasses/composeClasses.js","../node_modules/@mui/utils/esm/createChainedFunction/createChainedFunction.js","../node_modules/@mui/utils/esm/debounce/debounce.js","../node_modules/@mui/utils/esm/deepmerge/deepmerge.js","../node_modules/@mui/utils/esm/formatMuiErrorMessage/formatMuiErrorMessage.js","../node_modules/@mui/utils/esm/generateUtilityClass/generateUtilityClass.js","../node_modules/@mui/utils/esm/generateUtilityClasses/generateUtilityClasses.js","../node_modules/@mui/utils/esm/getDisplayName/getDisplayName.js","../node_modules/@mui/utils/esm/ownerDocument/ownerDocument.js","../node_modules/@mui/utils/esm/ownerWindow/ownerWindow.js","../node_modules/@mui/utils/esm/resolveProps/resolveProps.js","../node_modules/@mui/utils/esm/setRef/setRef.js","../node_modules/@mui/utils/esm/useControlled/useControlled.js","../node_modules/@mui/utils/esm/useEnhancedEffect/useEnhancedEffect.js","../node_modules/@mui/utils/esm/useEventCallback/useEventCallback.js","../node_modules/@mui/utils/esm/useForkRef/useForkRef.js","../node_modules/@mui/utils/esm/useId/useId.js","../node_modules/@mui/utils/esm/useIsFocusVisible/useIsFocusVisible.js","../node_modules/@mui/utils/esm/useLazyRef/useLazyRef.js","../node_modules/@mui/utils/esm/useOnMount/useOnMount.js","../node_modules/@mui/utils/esm/useTimeout/useTimeout.js","../node_modules/@plotly/d3-sankey-circular/dist/d3-sankey-circular.es.js","../node_modules/@plotly/d3-sankey/src/align.js","../node_modules/@plotly/d3-sankey/src/constant.js","../node_modules/@plotly/d3-sankey/src/sankey.js","../node_modules/@plotly/d3-sankey/src/sankeyLinkHorizontal.js","../node_modules/@plotly/d3/d3.js","../node_modules/@plotly/mapbox-gl/dist/mapbox-gl-unminified.js","../node_modules/@plotly/point-cluster/index.js","../node_modules/@plotly/point-cluster/quad.js","../node_modules/abs-svg-path/index.js","../node_modules/array-bounds/index.js","../node_modules/array-find-index/index.js","../node_modules/array-normalize/index.js","../node_modules/array-range/index.js","../node_modules/assert/build/assert.js","../node_modules/assert/build/internal/assert/assertion_error.js","../node_modules/assert/build/internal/errors.js","../node_modules/assert/build/internal/util/comparisons.js","../node_modules/src/index.ts","../node_modules/base64-js/index.js","../node_modules/binary-search-bounds/search-bounds.js","../node_modules/bit-twiddle/twiddle.js","../node_modules/bitmap-sdf/index.js","../node_modules/buffer/index.js","../node_modules/call-bind/callBound.js","../node_modules/call-bind/index.js","../node_modules/clamp/index.js","../node_modules/color-id/index.js","../node_modules/color-name/index.js","../node_modules/color-normalize/index.js","../node_modules/color-parse/index.js","../node_modules/color-rgba/index.js","../node_modules/colormap/colorScale.js","../node_modules/colormap/index.js","../node_modules/country-regex/index.js","../node_modules/css-font/index.js","../node_modules/css-font/lib/util.js","../node_modules/css-font/parse.js","../node_modules/css-font/stringify.js","../node_modules/d/auto-bind.js","../node_modules/d/index.js","../node_modules/d3-array/src/ascending.js","../node_modules/d3-array/src/bisect.js","../node_modules/d3-array/src/bisector.js","../node_modules/d3-array/src/array.js","../node_modules/d3-array/src/ticks.js","../node_modules/d3-array/src/max.js","../node_modules/d3-array/src/number.js","../node_modules/d3-array/src/mean.js","../node_modules/d3-array/src/merge.js","../node_modules/d3-array/src/min.js","../node_modules/d3-array/src/range.js","../node_modules/d3-array/src/sum.js","../node_modules/d3-collection/src/map.js","../node_modules/d3-collection/src/nest.js","../node_modules/d3-collection/src/set.js","../node_modules/d3-force/src/center.js","../node_modules/d3-force/src/constant.js","../node_modules/d3-force/src/jiggle.js","../node_modules/d3-quadtree/src/add.js","../node_modules/d3-quadtree/src/quad.js","../node_modules/d3-quadtree/src/x.js","../node_modules/d3-quadtree/src/y.js","../node_modules/d3-quadtree/src/quadtree.js","../node_modules/d3-force/src/collide.js","../node_modules/d3-quadtree/src/cover.js","../node_modules/d3-quadtree/src/data.js","../node_modules/d3-quadtree/src/extent.js","../node_modules/d3-quadtree/src/find.js","../node_modules/d3-quadtree/src/remove.js","../node_modules/d3-quadtree/src/root.js","../node_modules/d3-quadtree/src/size.js","../node_modules/d3-quadtree/src/visit.js","../node_modules/d3-quadtree/src/visitAfter.js","../node_modules/d3-force/src/link.js","../node_modules/d3-force/node_modules/d3-dispatch/src/dispatch.js","../node_modules/d3-timer/src/timer.js","../node_modules/d3-force/src/simulation.js","../node_modules/d3-force/src/manyBody.js","../node_modules/d3-force/src/radial.js","../node_modules/d3-force/src/x.js","../node_modules/d3-force/src/y.js","../node_modules/d3-format/src/formatDecimal.js","../node_modules/d3-format/src/formatSpecifier.js","../node_modules/d3-format/src/formatPrefixAuto.js","../node_modules/d3-format/src/formatRounded.js","../node_modules/d3-format/src/formatTypes.js","../node_modules/d3-format/src/identity.js","../node_modules/d3-format/src/locale.js","../node_modules/d3-format/src/defaultLocale.js","../node_modules/d3-format/src/formatGroup.js","../node_modules/d3-format/src/formatNumerals.js","../node_modules/d3-format/src/formatTrim.js","../node_modules/d3-format/src/exponent.js","../node_modules/d3-geo-projection/src/math.js","../node_modules/d3-geo-projection/src/airy.js","../node_modules/d3-geo-projection/src/aitoff.js","../node_modules/d3-geo-projection/src/armadillo.js","../node_modules/d3-geo-projection/src/august.js","../node_modules/d3-geo-projection/src/baker.js","../node_modules/d3-geo-projection/src/berghaus.js","../node_modules/d3-geo-projection/src/hammer.js","../node_modules/d3-geo-projection/src/newton.js","../node_modules/d3-geo-projection/src/bertin.js","../node_modules/d3-geo-projection/src/mollweide.js","../node_modules/d3-geo-projection/src/boggs.js","../node_modules/d3-geo-projection/src/parallel1.js","../node_modules/d3-geo-projection/src/sinusoidal.js","../node_modules/d3-geo-projection/src/bonne.js","../node_modules/d3-geo-projection/src/bottomley.js","../node_modules/d3-geo-projection/src/bromley.js","../node_modules/d3-geo-projection/src/chamberlin.js","../node_modules/d3-geo-projection/src/collignon.js","../node_modules/d3-geo-projection/src/craig.js","../node_modules/d3-geo-projection/src/craster.js","../node_modules/d3-geo-projection/src/cylindricalEqualArea.js","../node_modules/d3-geo-projection/src/cylindricalStereographic.js","../node_modules/d3-geo-projection/src/eckert1.js","../node_modules/d3-geo-projection/src/eckert2.js","../node_modules/d3-geo-projection/src/eckert3.js","../node_modules/d3-geo-projection/src/eckert4.js","../node_modules/d3-geo-projection/src/eckert5.js","../node_modules/d3-geo-projection/src/eckert6.js","../node_modules/d3-geo-projection/src/eisenlohr.js","../node_modules/d3-geo-projection/src/fahey.js","../node_modules/d3-geo-projection/src/foucaut.js","../node_modules/d3-geo-projection/src/foucautSinusoidal.js","../node_modules/d3-geo-projection/src/gilbert.js","../node_modules/d3-geo-projection/src/gingery.js","../node_modules/d3-geo-projection/src/ginzburgPolyconic.js","../node_modules/d3-geo-projection/src/ginzburg4.js","../node_modules/d3-geo-projection/src/ginzburg5.js","../node_modules/d3-geo-projection/src/ginzburg6.js","../node_modules/d3-geo-projection/src/ginzburg8.js","../node_modules/d3-geo-projection/src/ginzburg9.js","../node_modules/d3-geo-projection/src/square.js","../node_modules/d3-geo-projection/src/gringorten.js","../node_modules/d3-geo-projection/src/elliptic.js","../node_modules/d3-geo-projection/src/guyou.js","../node_modules/d3-geo-projection/src/hammerRetroazimuthal.js","../node_modules/d3-geo-projection/src/healpix.js","../node_modules/d3-geo-projection/src/hill.js","../node_modules/d3-geo-projection/src/sinuMollweide.js","../node_modules/d3-geo-projection/src/homolosine.js","../node_modules/d3-geo-projection/src/hufnagel.js","../node_modules/d3-geo-projection/src/integrate.js","../node_modules/d3-geo-projection/src/hyperelliptical.js","../node_modules/d3-geo-projection/src/interrupted/index.js","../node_modules/d3-geo-projection/src/interrupted/boggs.js","../node_modules/d3-geo-projection/src/interrupted/homolosine.js","../node_modules/d3-geo-projection/src/interrupted/mollweide.js","../node_modules/d3-geo-projection/src/interrupted/mollweideHemispheres.js","../node_modules/d3-geo-projection/src/interrupted/sinuMollweide.js","../node_modules/d3-geo-projection/src/interrupted/sinusoidal.js","../node_modules/d3-geo-projection/src/kavrayskiy7.js","../node_modules/d3-geo-projection/src/lagrange.js","../node_modules/d3-geo-projection/src/larrivee.js","../node_modules/d3-geo-projection/src/laskowski.js","../node_modules/d3-geo-projection/src/littrow.js","../node_modules/d3-geo-projection/src/loximuthal.js","../node_modules/d3-geo-projection/src/miller.js","../node_modules/d3-geo-projection/src/modifiedStereographic.js","../node_modules/d3-geo-projection/src/mtFlatPolarParabolic.js","../node_modules/d3-geo-projection/src/mtFlatPolarQuartic.js","../node_modules/d3-geo-projection/src/mtFlatPolarSinusoidal.js","../node_modules/d3-geo-projection/src/naturalEarth2.js","../node_modules/d3-geo-projection/src/nellHammer.js","../node_modules/d3-geo-projection/src/interrupted/quarticAuthalic.js","../node_modules/d3-geo-projection/src/nicolosi.js","../node_modules/d3-geo-projection/src/patterson.js","../node_modules/d3-geo-projection/src/polyconic.js","../node_modules/d3-geo-projection/src/polyhedral/matrix.js","../node_modules/d3-geo-projection/src/polyhedral/index.js","../node_modules/d3-geo-projection/src/polyhedral/octahedron.js","../node_modules/d3-geo-projection/src/polyhedral/butterfly.js","../node_modules/d3-geo-projection/src/polyhedral/collignon.js","../node_modules/d3-geo-projection/src/polyhedral/waterman.js","../node_modules/d3-geo-projection/src/noop.js","../node_modules/d3-geo-projection/src/project/index.js","../node_modules/d3-geo-projection/src/project/clockwise.js","../node_modules/d3-geo-projection/src/project/contains.js","../node_modules/d3-geo-projection/src/quincuncial/index.js","../node_modules/d3-geo-projection/src/quincuncial/gringorten.js","../node_modules/d3-geo-projection/src/quincuncial/peirce.js","../node_modules/d3-geo-projection/src/quantize.js","../node_modules/d3-geo-projection/src/rectangularPolyconic.js","../node_modules/d3-geo-projection/src/robinson.js","../node_modules/d3-geo-projection/src/satellite.js","../node_modules/d3-geo-projection/src/stitch.js","../node_modules/d3-geo-projection/src/times.js","../node_modules/d3-geo-projection/src/twoPoint.js","../node_modules/d3-geo-projection/src/twoPointAzimuthal.js","../node_modules/d3-geo-projection/src/twoPointEquidistant.js","../node_modules/d3-geo-projection/src/vanDerGrinten.js","../node_modules/d3-geo-projection/src/vanDerGrinten2.js","../node_modules/d3-geo-projection/src/vanDerGrinten3.js","../node_modules/d3-geo-projection/src/vanDerGrinten4.js","../node_modules/d3-geo-projection/src/wagner.js","../node_modules/d3-geo-projection/src/wagner4.js","../node_modules/d3-geo-projection/src/wagner6.js","../node_modules/d3-geo-projection/src/wiechel.js","../node_modules/d3-geo-projection/src/winkel3.js","../node_modules/d3-geo/src/adder.js","../node_modules/d3-geo/src/area.js","../node_modules/d3-geo/src/bounds.js","../node_modules/d3-geo/src/cartesian.js","../node_modules/d3-geo/src/centroid.js","../node_modules/d3-geo/src/constant.js","../node_modules/d3-geo/src/circle.js","../node_modules/d3-geo/src/clip/antimeridian.js","../node_modules/d3-geo/src/clip/buffer.js","../node_modules/d3-geo/src/clip/circle.js","../node_modules/d3-geo/src/clip/index.js","../node_modules/d3-geo/src/clip/rectangle.js","../node_modules/d3-geo/src/clip/line.js","../node_modules/d3-geo/src/clip/rejoin.js","../node_modules/d3-geo/src/compose.js","../node_modules/d3-geo/src/identity.js","../node_modules/d3-geo/src/clip/extent.js","../node_modules/d3-geo/src/length.js","../node_modules/d3-geo/src/distance.js","../node_modules/d3-geo/src/contains.js","../node_modules/d3-geo/src/graticule.js","../node_modules/d3-geo/src/path/area.js","../node_modules/d3-geo/src/path/centroid.js","../node_modules/d3-geo/src/path/context.js","../node_modules/d3-geo/src/path/measure.js","../node_modules/d3-geo/src/path/string.js","../node_modules/d3-geo/src/path/index.js","../node_modules/d3-geo/src/projection/conic.js","../node_modules/d3-geo/src/projection/conicEqualArea.js","../node_modules/d3-geo/src/projection/cylindricalEqualArea.js","../node_modules/d3-geo/src/projection/albers.js","../node_modules/d3-geo/src/projection/albersUsa.js","../node_modules/d3-geo/src/projection/mercator.js","../node_modules/d3-geo/src/projection/conicConformal.js","../node_modules/d3-geo/src/projection/conicEquidistant.js","../node_modules/d3-geo/src/projection/equalEarth.js","../node_modules/d3-geo/src/projection/identity.js","../node_modules/d3-geo/src/projection/stereographic.js","../node_modules/d3-geo/src/projection/transverseMercator.js","../node_modules/d3-geo/src/interpolate.js","../node_modules/d3-geo/src/math.js","../node_modules/d3-geo/src/noop.js","../node_modules/d3-geo/src/path/bounds.js","../node_modules/d3-geo/src/pointEqual.js","../node_modules/d3-geo/src/polygonContains.js","../node_modules/d3-geo/src/projection/azimuthal.js","../node_modules/d3-geo/src/projection/azimuthalEqualArea.js","../node_modules/d3-geo/src/projection/azimuthalEquidistant.js","../node_modules/d3-geo/src/projection/equirectangular.js","../node_modules/d3-geo/src/projection/fit.js","../node_modules/d3-geo/src/projection/gnomonic.js","../node_modules/d3-geo/src/projection/resample.js","../node_modules/d3-geo/src/projection/index.js","../node_modules/d3-geo/src/projection/naturalEarth1.js","../node_modules/d3-geo/src/projection/orthographic.js","../node_modules/d3-geo/src/rotation.js","../node_modules/d3-geo/src/stream.js","../node_modules/d3-geo/src/transform.js","../node_modules/d3-hierarchy/src/cluster.js","../node_modules/d3-hierarchy/src/hierarchy/count.js","../node_modules/d3-hierarchy/src/hierarchy/index.js","../node_modules/d3-hierarchy/src/hierarchy/each.js","../node_modules/d3-hierarchy/src/hierarchy/eachAfter.js","../node_modules/d3-hierarchy/src/hierarchy/eachBefore.js","../node_modules/d3-hierarchy/src/hierarchy/sum.js","../node_modules/d3-hierarchy/src/hierarchy/sort.js","../node_modules/d3-hierarchy/src/hierarchy/path.js","../node_modules/d3-hierarchy/src/hierarchy/ancestors.js","../node_modules/d3-hierarchy/src/hierarchy/descendants.js","../node_modules/d3-hierarchy/src/hierarchy/leaves.js","../node_modules/d3-hierarchy/src/hierarchy/links.js","../node_modules/d3-hierarchy/src/array.js","../node_modules/d3-hierarchy/src/pack/enclose.js","../node_modules/d3-hierarchy/src/pack/siblings.js","../node_modules/d3-hierarchy/src/accessors.js","../node_modules/d3-hierarchy/src/constant.js","../node_modules/d3-hierarchy/src/pack/index.js","../node_modules/d3-hierarchy/src/treemap/round.js","../node_modules/d3-hierarchy/src/treemap/dice.js","../node_modules/d3-hierarchy/src/partition.js","../node_modules/d3-hierarchy/src/stratify.js","../node_modules/d3-hierarchy/src/tree.js","../node_modules/d3-hierarchy/src/treemap/slice.js","../node_modules/d3-hierarchy/src/treemap/squarify.js","../node_modules/d3-hierarchy/src/treemap/index.js","../node_modules/d3-hierarchy/src/treemap/binary.js","../node_modules/d3-hierarchy/src/treemap/sliceDice.js","../node_modules/d3-hierarchy/src/treemap/resquarify.js","../node_modules/d3-path/src/path.js","../node_modules/d3-shape/src/array.js","../node_modules/d3-shape/src/constant.js","../node_modules/d3-shape/src/point.js","../node_modules/d3-shape/src/link/index.js","../node_modules/d3-time-format/src/locale.js","../node_modules/d3-time-format/src/defaultLocale.js","../node_modules/d3-time/src/day.js","../node_modules/d3-time/src/duration.js","../node_modules/d3-time/src/millisecond.js","../node_modules/d3-time/src/second.js","../node_modules/d3-time/src/minute.js","../node_modules/d3-time/src/hour.js","../node_modules/d3-time/src/month.js","../node_modules/d3-time/src/utcMinute.js","../node_modules/d3-time/src/utcHour.js","../node_modules/d3-time/src/utcMonth.js","../node_modules/d3-time/src/interval.js","../node_modules/d3-time/src/utcDay.js","../node_modules/d3-time/src/utcWeek.js","../node_modules/d3-time/src/utcYear.js","../node_modules/d3-time/src/week.js","../node_modules/d3-time/src/year.js","../node_modules/define-data-property/index.js","../node_modules/define-properties/index.js","../node_modules/defined/index.js","../node_modules/detect-kerning/index.js","../node_modules/draw-svg-path/index.js","../node_modules/draw-svg-path/node_modules/normalize-svg-path/index.js","../node_modules/dtype/index.js","../node_modules/dup/dup.js","../node_modules/earcut/src/earcut.js","../node_modules/elementary-circuits-directed-graph/johnson.js","../node_modules/es-define-property/index.js","../node_modules/es-errors/eval.js","../node_modules/es-errors/index.js","../node_modules/es-errors/range.js","../node_modules/es-errors/ref.js","../node_modules/es-errors/syntax.js","../node_modules/es-errors/type.js","../node_modules/es-errors/uri.js","../node_modules/es5-ext/array/#/clear.js","../node_modules/es5-ext/array/from/index.js","../node_modules/es5-ext/array/from/is-implemented.js","../node_modules/es5-ext/array/from/shim.js","../node_modules/es5-ext/function/is-arguments.js","../node_modules/es5-ext/function/is-function.js","../node_modules/es5-ext/function/noop.js","../node_modules/es5-ext/math/sign/index.js","../node_modules/es5-ext/math/sign/is-implemented.js","../node_modules/es5-ext/math/sign/shim.js","../node_modules/es5-ext/number/to-integer.js","../node_modules/es5-ext/number/to-pos-integer.js","../node_modules/es5-ext/object/_iterate.js","../node_modules/es5-ext/object/assign/index.js","../node_modules/es5-ext/object/assign/is-implemented.js","../node_modules/es5-ext/object/assign/shim.js","../node_modules/es5-ext/object/copy.js","../node_modules/es5-ext/object/create.js","../node_modules/es5-ext/object/for-each.js","../node_modules/es5-ext/object/is-object.js","../node_modules/es5-ext/object/is-value.js","../node_modules/es5-ext/object/keys/index.js","../node_modules/es5-ext/object/keys/is-implemented.js","../node_modules/es5-ext/object/keys/shim.js","../node_modules/es5-ext/object/map.js","../node_modules/es5-ext/object/normalize-options.js","../node_modules/es5-ext/object/set-prototype-of/index.js","../node_modules/es5-ext/object/set-prototype-of/is-implemented.js","../node_modules/es5-ext/object/set-prototype-of/shim.js","../node_modules/es5-ext/object/valid-callable.js","../node_modules/es5-ext/object/valid-object.js","../node_modules/es5-ext/object/valid-value.js","../node_modules/es5-ext/string/#/contains/index.js","../node_modules/es5-ext/string/#/contains/is-implemented.js","../node_modules/es5-ext/string/#/contains/shim.js","../node_modules/es5-ext/string/is-string.js","../node_modules/es5-ext/string/random-uniq.js","../node_modules/es6-iterator/array.js","../node_modules/es6-iterator/for-of.js","../node_modules/es6-iterator/get.js","../node_modules/es6-iterator/index.js","../node_modules/es6-iterator/is-iterable.js","../node_modules/es6-iterator/string.js","../node_modules/es6-iterator/valid-iterable.js","../node_modules/es6-symbol/index.js","../node_modules/es6-symbol/is-implemented.js","../node_modules/es6-symbol/is-symbol.js","../node_modules/es6-symbol/lib/private/generate-name.js","../node_modules/es6-symbol/lib/private/setup/standard-symbols.js","../node_modules/es6-symbol/lib/private/setup/symbol-registry.js","../node_modules/es6-symbol/polyfill.js","../node_modules/es6-symbol/validate-symbol.js","../node_modules/es6-weak-map/index.js","../node_modules/es6-weak-map/is-implemented.js","../node_modules/es6-weak-map/is-native-implemented.js","../node_modules/es6-weak-map/polyfill.js","../node_modules/events/events.js","../node_modules/ext/global-this/implementation.js","../node_modules/ext/global-this/index.js","../node_modules/ext/global-this/is-implemented.js","../node_modules/fast-deep-equal/index.js","../node_modules/fast-isnumeric/index.js","../node_modules/flatten-vertex-data/index.js","../node_modules/font-atlas/index.js","../node_modules/font-measure/index.js","../node_modules/for-each/index.js","../node_modules/function-bind/implementation.js","../node_modules/function-bind/index.js","../node_modules/get-canvas-context/index.js","../node_modules/get-intrinsic/index.js","../node_modules/gl-mat4/adjoint.js","../node_modules/gl-mat4/clone.js","../node_modules/gl-mat4/copy.js","../node_modules/gl-mat4/create.js","../node_modules/gl-mat4/determinant.js","../node_modules/gl-mat4/fromQuat.js","../node_modules/gl-mat4/fromRotation.js","../node_modules/gl-mat4/fromRotationTranslation.js","../node_modules/gl-mat4/fromScaling.js","../node_modules/gl-mat4/fromTranslation.js","../node_modules/gl-mat4/fromXRotation.js","../node_modules/gl-mat4/fromYRotation.js","../node_modules/gl-mat4/fromZRotation.js","../node_modules/gl-mat4/frustum.js","../node_modules/gl-mat4/identity.js","../node_modules/gl-mat4/index.js","../node_modules/gl-mat4/invert.js","../node_modules/gl-mat4/lookAt.js","../node_modules/gl-mat4/multiply.js","../node_modules/gl-mat4/ortho.js","../node_modules/gl-mat4/perspective.js","../node_modules/gl-mat4/perspectiveFromFieldOfView.js","../node_modules/gl-mat4/rotate.js","../node_modules/gl-mat4/rotateX.js","../node_modules/gl-mat4/rotateY.js","../node_modules/gl-mat4/rotateZ.js","../node_modules/gl-mat4/scale.js","../node_modules/gl-mat4/str.js","../node_modules/gl-mat4/translate.js","../node_modules/gl-mat4/transpose.js","../node_modules/gl-text/dist.js","../node_modules/gl-util/context.js","../node_modules/glslify/browser.js","../node_modules/gopd/index.js","../node_modules/has-hover/index.js","../node_modules/has-passive-events/index.js","../node_modules/has-property-descriptors/index.js","../node_modules/has-proto/index.js","../node_modules/has-symbols/index.js","../node_modules/has-symbols/shams.js","../node_modules/has-tostringtag/shams.js","../node_modules/hasown/index.js","../node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","../node_modules/hoist-non-react-statics/node_modules/react-is/cjs/react-is.production.min.js","../node_modules/hoist-non-react-statics/node_modules/react-is/index.js","../node_modules/ieee754/index.js","../node_modules/inherits/inherits_browser.js","../node_modules/is-arguments/index.js","../node_modules/is-browser/client.js","../node_modules/is-callable/index.js","../node_modules/is-generator-function/index.js","../node_modules/is-iexplorer/index.js","../node_modules/is-mobile/index.js","../node_modules/is-nan/implementation.js","../node_modules/is-nan/index.js","../node_modules/is-nan/polyfill.js","../node_modules/is-nan/shim.js","../node_modules/is-obj/index.js","../node_modules/is-plain-obj/index.js","../node_modules/is-string-blank/index.js","../node_modules/is-svg-path/index.js","../node_modules/is-typed-array/index.js","../node_modules/lerp/index.js","../node_modules/lodash/_DataView.js","../node_modules/lodash/_Hash.js","../node_modules/lodash/_ListCache.js","../node_modules/lodash/_Map.js","../node_modules/lodash/_MapCache.js","../node_modules/lodash/_Promise.js","../node_modules/lodash/_Set.js","../node_modules/lodash/_SetCache.js","../node_modules/lodash/_Stack.js","../node_modules/lodash/_Symbol.js","../node_modules/lodash/_Uint8Array.js","../node_modules/lodash/_WeakMap.js","../node_modules/lodash/_arrayEach.js","../node_modules/lodash/_arrayFilter.js","../node_modules/lodash/_arrayLikeKeys.js","../node_modules/lodash/_arrayMap.js","../node_modules/lodash/_arrayPush.js","../node_modules/lodash/_arraySome.js","../node_modules/lodash/_assignValue.js","../node_modules/lodash/_assocIndexOf.js","../node_modules/lodash/_baseAssign.js","../node_modules/lodash/_baseAssignIn.js","../node_modules/lodash/_baseAssignValue.js","../node_modules/lodash/_baseClone.js","../node_modules/lodash/_baseCreate.js","../node_modules/lodash/_baseEach.js","../node_modules/lodash/_baseFor.js","../node_modules/lodash/_baseForOwn.js","../node_modules/lodash/_baseGet.js","../node_modules/lodash/_baseGetAllKeys.js","../node_modules/lodash/_baseGetTag.js","../node_modules/lodash/_baseHasIn.js","../node_modules/lodash/_baseIsArguments.js","../node_modules/lodash/_baseIsEqual.js","../node_modules/lodash/_baseIsEqualDeep.js","../node_modules/lodash/_baseIsMap.js","../node_modules/lodash/_baseIsMatch.js","../node_modules/lodash/_baseIsNative.js","../node_modules/lodash/_baseIsSet.js","../node_modules/lodash/_baseIsTypedArray.js","../node_modules/lodash/_baseIteratee.js","../node_modules/lodash/_baseKeys.js","../node_modules/lodash/_baseKeysIn.js","../node_modules/lodash/_baseMap.js","../node_modules/lodash/_baseMatches.js","../node_modules/lodash/_baseMatchesProperty.js","../node_modules/lodash/_baseProperty.js","../node_modules/lodash/_basePropertyDeep.js","../node_modules/lodash/_baseTimes.js","../node_modules/lodash/_baseToString.js","../node_modules/lodash/_baseUnary.js","../node_modules/lodash/_cacheHas.js","../node_modules/lodash/_castFunction.js","../node_modules/lodash/_castPath.js","../node_modules/lodash/_cloneArrayBuffer.js","../node_modules/lodash/_cloneBuffer.js","../node_modules/lodash/_cloneDataView.js","../node_modules/lodash/_cloneRegExp.js","../node_modules/lodash/_cloneSymbol.js","../node_modules/lodash/_cloneTypedArray.js","../node_modules/lodash/_copyArray.js","../node_modules/lodash/_copyObject.js","../node_modules/lodash/_copySymbols.js","../node_modules/lodash/_copySymbolsIn.js","../node_modules/lodash/_coreJsData.js","../node_modules/lodash/_createBaseEach.js","../node_modules/lodash/_createBaseFor.js","../node_modules/lodash/_defineProperty.js","../node_modules/lodash/_equalArrays.js","../node_modules/lodash/_equalByTag.js","../node_modules/lodash/_equalObjects.js","../node_modules/lodash/_freeGlobal.js","../node_modules/lodash/_getAllKeys.js","../node_modules/lodash/_getAllKeysIn.js","../node_modules/lodash/_getMapData.js","../node_modules/lodash/_getMatchData.js","../node_modules/lodash/_getNative.js","../node_modules/lodash/_getPrototype.js","../node_modules/lodash/_getRawTag.js","../node_modules/lodash/_getSymbols.js","../node_modules/lodash/_getSymbolsIn.js","../node_modules/lodash/_getTag.js","../node_modules/lodash/_getValue.js","../node_modules/lodash/_hasPath.js","../node_modules/lodash/_hashClear.js","../node_modules/lodash/_hashDelete.js","../node_modules/lodash/_hashGet.js","../node_modules/lodash/_hashHas.js","../node_modules/lodash/_hashSet.js","../node_modules/lodash/_initCloneArray.js","../node_modules/lodash/_initCloneByTag.js","../node_modules/lodash/_initCloneObject.js","../node_modules/lodash/_isIndex.js","../node_modules/lodash/_isKey.js","../node_modules/lodash/_isKeyable.js","../node_modules/lodash/_isMasked.js","../node_modules/lodash/_isPrototype.js","../node_modules/lodash/_isStrictComparable.js","../node_modules/lodash/_listCacheClear.js","../node_modules/lodash/_listCacheDelete.js","../node_modules/lodash/_listCacheGet.js","../node_modules/lodash/_listCacheHas.js","../node_modules/lodash/_listCacheSet.js","../node_modules/lodash/_mapCacheClear.js","../node_modules/lodash/_mapCacheDelete.js","../node_modules/lodash/_mapCacheGet.js","../node_modules/lodash/_mapCacheHas.js","../node_modules/lodash/_mapCacheSet.js","../node_modules/lodash/_mapToArray.js","../node_modules/lodash/_matchesStrictComparable.js","../node_modules/lodash/_memoizeCapped.js","../node_modules/lodash/_nativeCreate.js","../node_modules/lodash/_nativeKeys.js","../node_modules/lodash/_nativeKeysIn.js","../node_modules/lodash/_nodeUtil.js","../node_modules/lodash/_objectToString.js","../node_modules/lodash/_overArg.js","../node_modules/lodash/_root.js","../node_modules/lodash/_setCacheAdd.js","../node_modules/lodash/_setCacheHas.js","../node_modules/lodash/_setToArray.js","../node_modules/lodash/_stackClear.js","../node_modules/lodash/_stackDelete.js","../node_modules/lodash/_stackGet.js","../node_modules/lodash/_stackHas.js","../node_modules/lodash/_stackSet.js","../node_modules/lodash/_stringToPath.js","../node_modules/lodash/_toKey.js","../node_modules/lodash/_toSource.js","../node_modules/lodash/cloneDeep.js","../node_modules/lodash/eq.js","../node_modules/lodash/forOwn.js","../node_modules/lodash/get.js","../node_modules/lodash/hasIn.js","../node_modules/lodash/identity.js","../node_modules/lodash/isArguments.js","../node_modules/lodash/isArray.js","../node_modules/lodash/isArrayLike.js","../node_modules/lodash/isBuffer.js","../node_modules/lodash/isFunction.js","../node_modules/lodash/isLength.js","../node_modules/lodash/isMap.js","../node_modules/lodash/isObject.js","../node_modules/lodash/isObjectLike.js","../node_modules/lodash/isPlainObject.js","../node_modules/lodash/isSet.js","../node_modules/lodash/isString.js","../node_modules/lodash/isSymbol.js","../node_modules/lodash/isTypedArray.js","../node_modules/lodash/keys.js","../node_modules/lodash/keysIn.js","../node_modules/lodash/map.js","../node_modules/lodash/memoize.js","../node_modules/lodash/property.js","../node_modules/lodash/stubArray.js","../node_modules/lodash/stubFalse.js","../node_modules/lodash/toString.js","../node_modules/math-log2/index.js","../node_modules/moment/moment.js","../node_modules/mouse-change/mouse-listen.js","../node_modules/mouse-event-offset/index.js","../node_modules/mouse-event/mouse.js","../node_modules/mouse-wheel/wheel.js","../node_modules/native-promise-only/lib/npo.src.js","../node_modules/normalize-svg-path/index.js","../node_modules/object-assign/index.js","../node_modules/object-inspect/index.js","../node_modules/object-is/implementation.js","../node_modules/object-is/index.js","../node_modules/object-is/polyfill.js","../node_modules/object-is/shim.js","../node_modules/object-keys/implementation.js","../node_modules/object-keys/index.js","../node_modules/object-keys/isArguments.js","../node_modules/object.assign/implementation.js","../node_modules/object.assign/polyfill.js","../node_modules/parenthesis/index.js","../node_modules/parse-rect/index.js","../node_modules/parse-svg-path/index.js","../node_modules/parse-unit/index.js","../node_modules/performance-now/src/performance-now.coffee","../node_modules/pick-by-alias/index.js","../node_modules/plotly.js/build/plotcss.js","../node_modules/plotly.js/lib/aggregate.js","../node_modules/plotly.js/lib/bar.js","../node_modules/plotly.js/lib/barpolar.js","../node_modules/plotly.js/lib/box.js","../node_modules/plotly.js/lib/calendars.js","../node_modules/plotly.js/lib/candlestick.js","../node_modules/plotly.js/lib/carpet.js","../node_modules/plotly.js/lib/choropleth.js","../node_modules/plotly.js/lib/choroplethmap.js","../node_modules/plotly.js/lib/choroplethmapbox.js","../node_modules/plotly.js/lib/cone.js","../node_modules/plotly.js/lib/contour.js","../node_modules/plotly.js/lib/contourcarpet.js","../node_modules/plotly.js/lib/core.js","../node_modules/plotly.js/lib/densitymap.js","../node_modules/plotly.js/lib/densitymapbox.js","../node_modules/plotly.js/lib/filter.js","../node_modules/plotly.js/lib/funnel.js","../node_modules/plotly.js/lib/funnelarea.js","../node_modules/plotly.js/lib/groupby.js","../node_modules/plotly.js/lib/heatmap.js","../node_modules/plotly.js/lib/heatmapgl.js","../node_modules/plotly.js/lib/histogram.js","../node_modules/plotly.js/lib/histogram2d.js","../node_modules/plotly.js/lib/histogram2dcontour.js","../node_modules/plotly.js/lib/icicle.js","../node_modules/plotly.js/lib/image.js","../node_modules/plotly.js/lib/index.js","../node_modules/plotly.js/lib/indicator.js","../node_modules/plotly.js/lib/isosurface.js","../node_modules/plotly.js/lib/mesh3d.js","../node_modules/plotly.js/lib/ohlc.js","../node_modules/plotly.js/lib/parcats.js","../node_modules/plotly.js/lib/parcoords.js","../node_modules/plotly.js/lib/pie.js","../node_modules/plotly.js/lib/pointcloud.js","../node_modules/plotly.js/lib/sankey.js","../node_modules/plotly.js/lib/scatter3d.js","../node_modules/plotly.js/lib/scattercarpet.js","../node_modules/plotly.js/lib/scattergeo.js","../node_modules/plotly.js/lib/scattergl.js","../node_modules/plotly.js/lib/scattermap.js","../node_modules/plotly.js/lib/scattermapbox.js","../node_modules/plotly.js/lib/scatterpolar.js","../node_modules/plotly.js/lib/scatterpolargl.js","../node_modules/plotly.js/lib/scattersmith.js","../node_modules/plotly.js/lib/scatterternary.js","../node_modules/plotly.js/lib/sort.js","../node_modules/plotly.js/lib/splom.js","../node_modules/plotly.js/lib/streamtube.js","../node_modules/plotly.js/lib/sunburst.js","../node_modules/plotly.js/lib/surface.js","../node_modules/plotly.js/lib/table.js","../node_modules/plotly.js/lib/treemap.js","../node_modules/plotly.js/lib/violin.js","../node_modules/plotly.js/lib/volume.js","../node_modules/plotly.js/lib/waterfall.js","../node_modules/plotly.js/node_modules/color-normalize/index.js","../node_modules/plotly.js/node_modules/color-normalize/node_modules/color-parse/index.js","../node_modules/plotly.js/node_modules/color-normalize/node_modules/color-rgba/index.js","../node_modules/plotly.js/node_modules/color-rgba/index.js","../node_modules/plotly.js/node_modules/color-rgba/node_modules/color-parse/index.js","../node_modules/plotly.js/node_modules/color-space/hsl.js","../node_modules/plotly.js/node_modules/color-space/rgb.js","../node_modules/plotly.js/src/components/annotations/arrow_paths.js","../node_modules/plotly.js/src/components/annotations/attributes.js","../node_modules/plotly.js/src/components/annotations/calc_autorange.js","../node_modules/plotly.js/src/components/annotations/click.js","../node_modules/plotly.js/src/components/annotations/common_defaults.js","../node_modules/plotly.js/src/components/annotations/convert_coords.js","../node_modules/plotly.js/src/components/annotations/defaults.js","../node_modules/plotly.js/src/components/annotations/draw.js","../node_modules/plotly.js/src/components/annotations/draw_arrow_head.js","../node_modules/plotly.js/src/components/annotations/index.js","../node_modules/plotly.js/src/components/annotations3d/attributes.js","../node_modules/plotly.js/src/components/annotations3d/convert.js","../node_modules/plotly.js/src/components/annotations3d/defaults.js","../node_modules/plotly.js/src/components/annotations3d/draw.js","../node_modules/plotly.js/src/components/annotations3d/index.js","../node_modules/plotly.js/src/components/calendars/calendars.js","../node_modules/plotly.js/src/components/calendars/index.js","../node_modules/plotly.js/src/components/color/attributes.js","../node_modules/plotly.js/src/components/color/index.js","../node_modules/plotly.js/src/components/colorbar/attributes.js","../node_modules/plotly.js/src/components/colorbar/constants.js","../node_modules/plotly.js/src/components/colorbar/defaults.js","../node_modules/plotly.js/src/components/colorbar/draw.js","../node_modules/plotly.js/src/components/colorbar/has_colorbar.js","../node_modules/plotly.js/src/components/colorbar/index.js","../node_modules/plotly.js/src/components/colorscale/attributes.js","../node_modules/plotly.js/src/components/colorscale/calc.js","../node_modules/plotly.js/src/components/colorscale/cross_trace_defaults.js","../node_modules/plotly.js/src/components/colorscale/defaults.js","../node_modules/plotly.js/src/components/colorscale/helpers.js","../node_modules/plotly.js/src/components/colorscale/index.js","../node_modules/plotly.js/src/components/colorscale/layout_attributes.js","../node_modules/plotly.js/src/components/colorscale/layout_defaults.js","../node_modules/plotly.js/src/components/colorscale/scales.js","../node_modules/plotly.js/src/components/dragelement/align.js","../node_modules/plotly.js/src/components/dragelement/cursor.js","../node_modules/plotly.js/src/components/dragelement/helpers.js","../node_modules/plotly.js/src/components/dragelement/index.js","../node_modules/plotly.js/src/components/dragelement/unhover.js","../node_modules/plotly.js/src/components/drawing/attributes.js","../node_modules/plotly.js/src/components/drawing/index.js","../node_modules/plotly.js/src/components/drawing/symbol_defs.js","../node_modules/plotly.js/src/components/errorbars/attributes.js","../node_modules/plotly.js/src/components/errorbars/calc.js","../node_modules/plotly.js/src/components/errorbars/compute_error.js","../node_modules/plotly.js/src/components/errorbars/defaults.js","../node_modules/plotly.js/src/components/errorbars/index.js","../node_modules/plotly.js/src/components/errorbars/plot.js","../node_modules/plotly.js/src/components/errorbars/style.js","../node_modules/plotly.js/src/components/fx/attributes.js","../node_modules/plotly.js/src/components/fx/calc.js","../node_modules/plotly.js/src/components/fx/click.js","../node_modules/plotly.js/src/components/fx/constants.js","../node_modules/plotly.js/src/components/fx/defaults.js","../node_modules/plotly.js/src/components/fx/helpers.js","../node_modules/plotly.js/src/components/fx/hover.js","../node_modules/plotly.js/src/components/fx/hoverlabel_defaults.js","../node_modules/plotly.js/src/components/fx/hovermode_defaults.js","../node_modules/plotly.js/src/components/fx/index.js","../node_modules/plotly.js/src/components/fx/layout_attributes.js","../node_modules/plotly.js/src/components/fx/layout_defaults.js","../node_modules/plotly.js/src/components/fx/layout_global_defaults.js","../node_modules/plotly.js/src/components/grid/index.js","../node_modules/plotly.js/src/components/images/attributes.js","../node_modules/plotly.js/src/components/images/convert_coords.js","../node_modules/plotly.js/src/components/images/defaults.js","../node_modules/plotly.js/src/components/images/draw.js","../node_modules/plotly.js/src/components/images/index.js","../node_modules/plotly.js/src/components/legend/attributes.js","../node_modules/plotly.js/src/components/legend/constants.js","../node_modules/plotly.js/src/components/legend/defaults.js","../node_modules/plotly.js/src/components/legend/draw.js","../node_modules/plotly.js/src/components/legend/get_legend_data.js","../node_modules/plotly.js/src/components/legend/handle_click.js","../node_modules/plotly.js/src/components/legend/helpers.js","../node_modules/plotly.js/src/components/legend/index.js","../node_modules/plotly.js/src/components/legend/style.js","../node_modules/plotly.js/src/components/modebar/attributes.js","../node_modules/plotly.js/src/components/modebar/buttons.js","../node_modules/plotly.js/src/components/modebar/constants.js","../node_modules/plotly.js/src/components/modebar/defaults.js","../node_modules/plotly.js/src/components/modebar/index.js","../node_modules/plotly.js/src/components/modebar/manage.js","../node_modules/plotly.js/src/components/modebar/modebar.js","../node_modules/plotly.js/src/components/rangeselector/attributes.js","../node_modules/plotly.js/src/components/rangeselector/constants.js","../node_modules/plotly.js/src/components/rangeselector/defaults.js","../node_modules/plotly.js/src/components/rangeselector/draw.js","../node_modules/plotly.js/src/components/rangeselector/get_update_object.js","../node_modules/plotly.js/src/components/rangeselector/index.js","../node_modules/plotly.js/src/components/rangeslider/attributes.js","../node_modules/plotly.js/src/components/rangeslider/calc_autorange.js","../node_modules/plotly.js/src/components/rangeslider/constants.js","../node_modules/plotly.js/src/components/rangeslider/defaults.js","../node_modules/plotly.js/src/components/rangeslider/draw.js","../node_modules/plotly.js/src/components/rangeslider/helpers.js","../node_modules/plotly.js/src/components/rangeslider/index.js","../node_modules/plotly.js/src/components/rangeslider/oppaxis_attributes.js","../node_modules/plotly.js/src/components/selections/attributes.js","../node_modules/plotly.js/src/components/selections/constants.js","../node_modules/plotly.js/src/components/selections/defaults.js","../node_modules/plotly.js/src/components/selections/draw.js","../node_modules/plotly.js/src/components/selections/draw_newselection/attributes.js","../node_modules/plotly.js/src/components/selections/draw_newselection/defaults.js","../node_modules/plotly.js/src/components/selections/draw_newselection/newselections.js","../node_modules/plotly.js/src/components/selections/helpers.js","../node_modules/plotly.js/src/components/selections/index.js","../node_modules/plotly.js/src/components/selections/select.js","../node_modules/plotly.js/src/components/shapes/attributes.js","../node_modules/plotly.js/src/components/shapes/calc_autorange.js","../node_modules/plotly.js/src/components/shapes/constants.js","../node_modules/plotly.js/src/components/shapes/defaults.js","../node_modules/plotly.js/src/components/shapes/display_labels.js","../node_modules/plotly.js/src/components/shapes/display_outlines.js","../node_modules/plotly.js/src/components/shapes/draw.js","../node_modules/plotly.js/src/components/shapes/draw_newshape/attributes.js","../node_modules/plotly.js/src/components/shapes/draw_newshape/constants.js","../node_modules/plotly.js/src/components/shapes/draw_newshape/defaults.js","../node_modules/plotly.js/src/components/shapes/draw_newshape/helpers.js","../node_modules/plotly.js/src/components/shapes/draw_newshape/newshapes.js","../node_modules/plotly.js/src/components/shapes/handle_outline.js","../node_modules/plotly.js/src/components/shapes/helpers.js","../node_modules/plotly.js/src/components/shapes/index.js","../node_modules/plotly.js/src/components/shapes/label_texttemplate.js","../node_modules/plotly.js/src/components/sliders/attributes.js","../node_modules/plotly.js/src/components/sliders/constants.js","../node_modules/plotly.js/src/components/sliders/defaults.js","../node_modules/plotly.js/src/components/sliders/draw.js","../node_modules/plotly.js/src/components/sliders/index.js","../node_modules/plotly.js/src/components/titles/index.js","../node_modules/plotly.js/src/components/updatemenus/attributes.js","../node_modules/plotly.js/src/components/updatemenus/constants.js","../node_modules/plotly.js/src/components/updatemenus/defaults.js","../node_modules/plotly.js/src/components/updatemenus/draw.js","../node_modules/plotly.js/src/components/updatemenus/index.js","../node_modules/plotly.js/src/components/updatemenus/scrollbox.js","../node_modules/plotly.js/src/constants/alignment.js","../node_modules/plotly.js/src/constants/axis_placeable_objects.js","../node_modules/plotly.js/src/constants/delta.js","../node_modules/plotly.js/src/constants/docs.js","../node_modules/plotly.js/src/constants/filter_ops.js","../node_modules/plotly.js/src/constants/gl3d_dashes.js","../node_modules/plotly.js/src/constants/gl3d_markers.js","../node_modules/plotly.js/src/constants/interactions.js","../node_modules/plotly.js/src/constants/numerical.js","../node_modules/plotly.js/src/constants/pixelated_image.js","../node_modules/plotly.js/src/constants/xmlns_namespaces.js","../node_modules/plotly.js/src/core.js","../node_modules/plotly.js/src/fonts/ploticon.js","../node_modules/plotly.js/src/lib/anchor_utils.js","../node_modules/plotly.js/src/lib/angles.js","../node_modules/plotly.js/src/lib/array.js","../node_modules/plotly.js/src/lib/clean_number.js","../node_modules/plotly.js/src/lib/clear_gl_canvases.js","../node_modules/plotly.js/src/lib/clear_responsive.js","../node_modules/plotly.js/src/lib/coerce.js","../node_modules/plotly.js/src/lib/dates.js","../node_modules/plotly.js/src/lib/dom.js","../node_modules/plotly.js/src/lib/events.js","../node_modules/plotly.js/src/lib/extend.js","../node_modules/plotly.js/src/lib/filter_unique.js","../node_modules/plotly.js/src/lib/filter_visible.js","../node_modules/plotly.js/src/lib/geo_location_utils.js","../node_modules/plotly.js/src/lib/geojson_utils.js","../node_modules/plotly.js/src/lib/geometry2d.js","../node_modules/plotly.js/src/lib/gl_format_color.js","../node_modules/plotly.js/src/lib/gup.js","../node_modules/plotly.js/src/lib/identity.js","../node_modules/plotly.js/src/lib/increment.js","../node_modules/plotly.js/src/lib/index.js","../node_modules/plotly.js/src/lib/is_plain_object.js","../node_modules/plotly.js/src/lib/keyed_container.js","../node_modules/plotly.js/src/lib/localize.js","../node_modules/plotly.js/src/lib/loggers.js","../node_modules/plotly.js/src/lib/make_trace_groups.js","../node_modules/plotly.js/src/lib/matrix.js","../node_modules/plotly.js/src/lib/mod.js","../node_modules/plotly.js/src/lib/nested_property.js","../node_modules/plotly.js/src/lib/noop.js","../node_modules/plotly.js/src/lib/notifier.js","../node_modules/plotly.js/src/lib/override_cursor.js","../node_modules/plotly.js/src/lib/polygon.js","../node_modules/plotly.js/src/lib/prepare_regl.js","../node_modules/plotly.js/src/lib/preserve_drawing_buffer.js","../node_modules/plotly.js/src/lib/push_unique.js","../node_modules/plotly.js/src/lib/queue.js","../node_modules/plotly.js/src/lib/regex.js","../node_modules/plotly.js/src/lib/relative_attr.js","../node_modules/plotly.js/src/lib/relink_private.js","../node_modules/plotly.js/src/lib/search.js","../node_modules/plotly.js/src/lib/setcursor.js","../node_modules/plotly.js/src/lib/show_no_webgl_msg.js","../node_modules/plotly.js/src/lib/sort_object_keys.js","../node_modules/plotly.js/src/lib/stats.js","../node_modules/plotly.js/src/lib/str2rgbarray.js","../node_modules/plotly.js/src/lib/supports_pixelated_image.js","../node_modules/plotly.js/src/lib/svg_text_utils.js","../node_modules/plotly.js/src/lib/throttle.js","../node_modules/plotly.js/src/lib/to_log_range.js","../node_modules/plotly.js/src/lib/topojson_utils.js","../node_modules/plotly.js/src/locale-en-us.js","../node_modules/plotly.js/src/locale-en.js","../node_modules/plotly.js/src/plot_api/container_array_match.js","../node_modules/plotly.js/src/plot_api/edit_types.js","../node_modules/plotly.js/src/plot_api/helpers.js","../node_modules/plotly.js/src/plot_api/index.js","../node_modules/plotly.js/src/plot_api/manage_arrays.js","../node_modules/plotly.js/src/plot_api/plot_api.js","../node_modules/plotly.js/src/plot_api/plot_config.js","../node_modules/plotly.js/src/plot_api/plot_schema.js","../node_modules/plotly.js/src/plot_api/plot_template.js","../node_modules/plotly.js/src/plot_api/subroutines.js","../node_modules/plotly.js/src/plot_api/template_api.js","../node_modules/plotly.js/src/plot_api/to_image.js","../node_modules/plotly.js/src/plot_api/validate.js","../node_modules/plotly.js/src/plots/animation_attributes.js","../node_modules/plotly.js/src/plots/array_container_defaults.js","../node_modules/plotly.js/src/plots/attributes.js","../node_modules/plotly.js/src/plots/cartesian/align_period.js","../node_modules/plotly.js/src/plots/cartesian/attributes.js","../node_modules/plotly.js/src/plots/cartesian/autorange.js","../node_modules/plotly.js/src/plots/cartesian/autorange_options_defaults.js","../node_modules/plotly.js/src/plots/cartesian/axes.js","../node_modules/plotly.js/src/plots/cartesian/axis_autotype.js","../node_modules/plotly.js/src/plots/cartesian/axis_defaults.js","../node_modules/plotly.js/src/plots/cartesian/axis_format_attributes.js","../node_modules/plotly.js/src/plots/cartesian/axis_ids.js","../node_modules/plotly.js/src/plots/cartesian/category_order_defaults.js","../node_modules/plotly.js/src/plots/cartesian/clean_ticks.js","../node_modules/plotly.js/src/plots/cartesian/constants.js","../node_modules/plotly.js/src/plots/cartesian/constraints.js","../node_modules/plotly.js/src/plots/cartesian/dragbox.js","../node_modules/plotly.js/src/plots/cartesian/graph_interact.js","../node_modules/plotly.js/src/plots/cartesian/include_components.js","../node_modules/plotly.js/src/plots/cartesian/index.js","../node_modules/plotly.js/src/plots/cartesian/layout_attributes.js","../node_modules/plotly.js/src/plots/cartesian/layout_defaults.js","../node_modules/plotly.js/src/plots/cartesian/line_grid_defaults.js","../node_modules/plotly.js/src/plots/cartesian/position_defaults.js","../node_modules/plotly.js/src/plots/cartesian/prefix_suffix_defaults.js","../node_modules/plotly.js/src/plots/cartesian/range_defaults.js","../node_modules/plotly.js/src/plots/cartesian/scale_zoom.js","../node_modules/plotly.js/src/plots/cartesian/set_convert.js","../node_modules/plotly.js/src/plots/cartesian/show_dflt.js","../node_modules/plotly.js/src/plots/cartesian/tick_label_defaults.js","../node_modules/plotly.js/src/plots/cartesian/tick_mark_defaults.js","../node_modules/plotly.js/src/plots/cartesian/tick_value_defaults.js","../node_modules/plotly.js/src/plots/cartesian/transition_axes.js","../node_modules/plotly.js/src/plots/cartesian/type_defaults.js","../node_modules/plotly.js/src/plots/command.js","../node_modules/plotly.js/src/plots/domain.js","../node_modules/plotly.js/src/plots/font_attributes.js","../node_modules/plotly.js/src/plots/frame_attributes.js","../node_modules/plotly.js/src/plots/geo/constants.js","../node_modules/plotly.js/src/plots/geo/geo.js","../node_modules/plotly.js/src/plots/geo/index.js","../node_modules/plotly.js/src/plots/geo/layout_attributes.js","../node_modules/plotly.js/src/plots/geo/layout_defaults.js","../node_modules/plotly.js/src/plots/geo/zoom.js","../node_modules/plotly.js/src/plots/get_data.js","../node_modules/plotly.js/src/plots/gl2d/camera.js","../node_modules/plotly.js/src/plots/gl2d/convert.js","../node_modules/plotly.js/src/plots/gl2d/index.js","../node_modules/plotly.js/src/plots/gl2d/scene2d.js","../node_modules/plotly.js/src/plots/gl3d/index.js","../node_modules/plotly.js/src/plots/gl3d/layout/attributes.js","../node_modules/plotly.js/src/plots/gl3d/layout/axis_attributes.js","../node_modules/plotly.js/src/plots/gl3d/layout/axis_defaults.js","../node_modules/plotly.js/src/plots/gl3d/layout/convert.js","../node_modules/plotly.js/src/plots/gl3d/layout/defaults.js","../node_modules/plotly.js/src/plots/gl3d/layout/layout_attributes.js","../node_modules/plotly.js/src/plots/gl3d/layout/spikes.js","../node_modules/plotly.js/src/plots/gl3d/layout/tick_marks.js","../node_modules/plotly.js/src/plots/gl3d/project.js","../node_modules/plotly.js/src/plots/gl3d/scene.js","../node_modules/plotly.js/src/plots/gl3d/zip3.js","../node_modules/plotly.js/src/plots/layout_attributes.js","../node_modules/plotly.js/src/plots/map/constants.js","../node_modules/plotly.js/src/plots/map/convert_text_opts.js","../node_modules/plotly.js/src/plots/map/index.js","../node_modules/plotly.js/src/plots/map/layers.js","../node_modules/plotly.js/src/plots/map/layout_attributes.js","../node_modules/plotly.js/src/plots/map/layout_defaults.js","../node_modules/plotly.js/src/plots/map/map.js","../node_modules/plotly.js/src/plots/mapbox/constants.js","../node_modules/plotly.js/src/plots/mapbox/convert_text_opts.js","../node_modules/plotly.js/src/plots/mapbox/index.js","../node_modules/plotly.js/src/plots/mapbox/layers.js","../node_modules/plotly.js/src/plots/mapbox/layout_attributes.js","../node_modules/plotly.js/src/plots/mapbox/layout_defaults.js","../node_modules/plotly.js/src/plots/mapbox/mapbox.js","../node_modules/plotly.js/src/plots/pad_attributes.js","../node_modules/plotly.js/src/plots/plots.js","../node_modules/plotly.js/src/plots/polar/constants.js","../node_modules/plotly.js/src/plots/polar/helpers.js","../node_modules/plotly.js/src/plots/polar/index.js","../node_modules/plotly.js/src/plots/polar/layout_attributes.js","../node_modules/plotly.js/src/plots/polar/layout_defaults.js","../node_modules/plotly.js/src/plots/polar/polar.js","../node_modules/plotly.js/src/plots/polar/set_convert.js","../node_modules/plotly.js/src/plots/smith/constants.js","../node_modules/plotly.js/src/plots/smith/helpers.js","../node_modules/plotly.js/src/plots/smith/index.js","../node_modules/plotly.js/src/plots/smith/layout_attributes.js","../node_modules/plotly.js/src/plots/smith/layout_defaults.js","../node_modules/plotly.js/src/plots/subplot_defaults.js","../node_modules/plotly.js/src/plots/template_attributes.js","../node_modules/plotly.js/src/plots/ternary/index.js","../node_modules/plotly.js/src/plots/ternary/layout_attributes.js","../node_modules/plotly.js/src/plots/ternary/layout_defaults.js","../node_modules/plotly.js/src/plots/ternary/ternary.js","../node_modules/plotly.js/src/registry.js","../node_modules/plotly.js/src/snapshot/cloneplot.js","../node_modules/plotly.js/src/snapshot/download.js","../node_modules/plotly.js/src/snapshot/filesaver.js","../node_modules/plotly.js/src/snapshot/helpers.js","../node_modules/plotly.js/src/snapshot/index.js","../node_modules/plotly.js/src/snapshot/svgtoimg.js","../node_modules/plotly.js/src/snapshot/toimage.js","../node_modules/plotly.js/src/snapshot/tosvg.js","../node_modules/plotly.js/src/traces/bar/arrays_to_calcdata.js","../node_modules/plotly.js/src/traces/bar/attributes.js","../node_modules/plotly.js/src/traces/bar/calc.js","../node_modules/plotly.js/src/traces/bar/constants.js","../node_modules/plotly.js/src/traces/bar/cross_trace_calc.js","../node_modules/plotly.js/src/traces/bar/defaults.js","../node_modules/plotly.js/src/traces/bar/event_data.js","../node_modules/plotly.js/src/traces/bar/helpers.js","../node_modules/plotly.js/src/traces/bar/hover.js","../node_modules/plotly.js/src/traces/bar/index.js","../node_modules/plotly.js/src/traces/bar/layout_attributes.js","../node_modules/plotly.js/src/traces/bar/layout_defaults.js","../node_modules/plotly.js/src/traces/bar/plot.js","../node_modules/plotly.js/src/traces/bar/select.js","../node_modules/plotly.js/src/traces/bar/sieve.js","../node_modules/plotly.js/src/traces/bar/style.js","../node_modules/plotly.js/src/traces/bar/style_defaults.js","../node_modules/plotly.js/src/traces/bar/uniform_text.js","../node_modules/plotly.js/src/traces/barpolar/attributes.js","../node_modules/plotly.js/src/traces/barpolar/calc.js","../node_modules/plotly.js/src/traces/barpolar/defaults.js","../node_modules/plotly.js/src/traces/barpolar/hover.js","../node_modules/plotly.js/src/traces/barpolar/index.js","../node_modules/plotly.js/src/traces/barpolar/layout_attributes.js","../node_modules/plotly.js/src/traces/barpolar/layout_defaults.js","../node_modules/plotly.js/src/traces/barpolar/plot.js","../node_modules/plotly.js/src/traces/box/attributes.js","../node_modules/plotly.js/src/traces/box/calc.js","../node_modules/plotly.js/src/traces/box/cross_trace_calc.js","../node_modules/plotly.js/src/traces/box/defaults.js","../node_modules/plotly.js/src/traces/box/event_data.js","../node_modules/plotly.js/src/traces/box/hover.js","../node_modules/plotly.js/src/traces/box/index.js","../node_modules/plotly.js/src/traces/box/layout_attributes.js","../node_modules/plotly.js/src/traces/box/layout_defaults.js","../node_modules/plotly.js/src/traces/box/plot.js","../node_modules/plotly.js/src/traces/box/select.js","../node_modules/plotly.js/src/traces/box/style.js","../node_modules/plotly.js/src/traces/candlestick/attributes.js","../node_modules/plotly.js/src/traces/candlestick/calc.js","../node_modules/plotly.js/src/traces/candlestick/defaults.js","../node_modules/plotly.js/src/traces/candlestick/index.js","../node_modules/plotly.js/src/traces/carpet/ab_defaults.js","../node_modules/plotly.js/src/traces/carpet/array_minmax.js","../node_modules/plotly.js/src/traces/carpet/attributes.js","../node_modules/plotly.js/src/traces/carpet/axis_aligned_line.js","../node_modules/plotly.js/src/traces/carpet/axis_attributes.js","../node_modules/plotly.js/src/traces/carpet/axis_defaults.js","../node_modules/plotly.js/src/traces/carpet/calc.js","../node_modules/plotly.js/src/traces/carpet/calc_clippath.js","../node_modules/plotly.js/src/traces/carpet/calc_gridlines.js","../node_modules/plotly.js/src/traces/carpet/calc_labels.js","../node_modules/plotly.js/src/traces/carpet/catmull_rom.js","../node_modules/plotly.js/src/traces/carpet/cheater_basis.js","../node_modules/plotly.js/src/traces/carpet/compute_control_points.js","../node_modules/plotly.js/src/traces/carpet/constants.js","../node_modules/plotly.js/src/traces/carpet/create_i_derivative_evaluator.js","../node_modules/plotly.js/src/traces/carpet/create_j_derivative_evaluator.js","../node_modules/plotly.js/src/traces/carpet/create_spline_evaluator.js","../node_modules/plotly.js/src/traces/carpet/defaults.js","../node_modules/plotly.js/src/traces/carpet/index.js","../node_modules/plotly.js/src/traces/carpet/lookup_carpetid.js","../node_modules/plotly.js/src/traces/carpet/makepath.js","../node_modules/plotly.js/src/traces/carpet/map_1d_array.js","../node_modules/plotly.js/src/traces/carpet/orient_text.js","../node_modules/plotly.js/src/traces/carpet/plot.js","../node_modules/plotly.js/src/traces/carpet/set_convert.js","../node_modules/plotly.js/src/traces/carpet/smooth_fill_2d_array.js","../node_modules/plotly.js/src/traces/carpet/xy_defaults.js","../node_modules/plotly.js/src/traces/choropleth/attributes.js","../node_modules/plotly.js/src/traces/choropleth/calc.js","../node_modules/plotly.js/src/traces/choropleth/defaults.js","../node_modules/plotly.js/src/traces/choropleth/event_data.js","../node_modules/plotly.js/src/traces/choropleth/hover.js","../node_modules/plotly.js/src/traces/choropleth/index.js","../node_modules/plotly.js/src/traces/choropleth/plot.js","../node_modules/plotly.js/src/traces/choropleth/select.js","../node_modules/plotly.js/src/traces/choropleth/style.js","../node_modules/plotly.js/src/traces/choroplethmap/attributes.js","../node_modules/plotly.js/src/traces/choroplethmap/convert.js","../node_modules/plotly.js/src/traces/choroplethmap/defaults.js","../node_modules/plotly.js/src/traces/choroplethmap/index.js","../node_modules/plotly.js/src/traces/choroplethmap/plot.js","../node_modules/plotly.js/src/traces/choroplethmapbox/attributes.js","../node_modules/plotly.js/src/traces/choroplethmapbox/convert.js","../node_modules/plotly.js/src/traces/choroplethmapbox/defaults.js","../node_modules/plotly.js/src/traces/choroplethmapbox/index.js","../node_modules/plotly.js/src/traces/choroplethmapbox/plot.js","../node_modules/plotly.js/src/traces/cone/attributes.js","../node_modules/plotly.js/src/traces/cone/calc.js","../node_modules/plotly.js/src/traces/cone/convert.js","../node_modules/plotly.js/src/traces/cone/defaults.js","../node_modules/plotly.js/src/traces/cone/index.js","../node_modules/plotly.js/src/traces/contour/attributes.js","../node_modules/plotly.js/src/traces/contour/calc.js","../node_modules/plotly.js/src/traces/contour/close_boundaries.js","../node_modules/plotly.js/src/traces/contour/colorbar.js","../node_modules/plotly.js/src/traces/contour/constants.js","../node_modules/plotly.js/src/traces/contour/constraint_defaults.js","../node_modules/plotly.js/src/traces/contour/constraint_mapping.js","../node_modules/plotly.js/src/traces/contour/contours_defaults.js","../node_modules/plotly.js/src/traces/contour/convert_to_constraints.js","../node_modules/plotly.js/src/traces/contour/defaults.js","../node_modules/plotly.js/src/traces/contour/empty_pathinfo.js","../node_modules/plotly.js/src/traces/contour/end_plus.js","../node_modules/plotly.js/src/traces/contour/find_all_paths.js","../node_modules/plotly.js/src/traces/contour/hover.js","../node_modules/plotly.js/src/traces/contour/index.js","../node_modules/plotly.js/src/traces/contour/label_defaults.js","../node_modules/plotly.js/src/traces/contour/make_color_map.js","../node_modules/plotly.js/src/traces/contour/make_crossings.js","../node_modules/plotly.js/src/traces/contour/plot.js","../node_modules/plotly.js/src/traces/contour/set_contours.js","../node_modules/plotly.js/src/traces/contour/style.js","../node_modules/plotly.js/src/traces/contour/style_defaults.js","../node_modules/plotly.js/src/traces/contourcarpet/attributes.js","../node_modules/plotly.js/src/traces/contourcarpet/calc.js","../node_modules/plotly.js/src/traces/contourcarpet/defaults.js","../node_modules/plotly.js/src/traces/contourcarpet/index.js","../node_modules/plotly.js/src/traces/contourcarpet/plot.js","../node_modules/plotly.js/src/traces/densitymap/attributes.js","../node_modules/plotly.js/src/traces/densitymap/calc.js","../node_modules/plotly.js/src/traces/densitymap/convert.js","../node_modules/plotly.js/src/traces/densitymap/defaults.js","../node_modules/plotly.js/src/traces/densitymap/event_data.js","../node_modules/plotly.js/src/traces/densitymap/hover.js","../node_modules/plotly.js/src/traces/densitymap/index.js","../node_modules/plotly.js/src/traces/densitymap/plot.js","../node_modules/plotly.js/src/traces/densitymapbox/attributes.js","../node_modules/plotly.js/src/traces/densitymapbox/calc.js","../node_modules/plotly.js/src/traces/densitymapbox/convert.js","../node_modules/plotly.js/src/traces/densitymapbox/defaults.js","../node_modules/plotly.js/src/traces/densitymapbox/event_data.js","../node_modules/plotly.js/src/traces/densitymapbox/hover.js","../node_modules/plotly.js/src/traces/densitymapbox/index.js","../node_modules/plotly.js/src/traces/densitymapbox/plot.js","../node_modules/plotly.js/src/traces/funnel/arrays_to_calcdata.js","../node_modules/plotly.js/src/traces/funnel/attributes.js","../node_modules/plotly.js/src/traces/funnel/calc.js","../node_modules/plotly.js/src/traces/funnel/constants.js","../node_modules/plotly.js/src/traces/funnel/cross_trace_calc.js","../node_modules/plotly.js/src/traces/funnel/defaults.js","../node_modules/plotly.js/src/traces/funnel/event_data.js","../node_modules/plotly.js/src/traces/funnel/hover.js","../node_modules/plotly.js/src/traces/funnel/index.js","../node_modules/plotly.js/src/traces/funnel/layout_attributes.js","../node_modules/plotly.js/src/traces/funnel/layout_defaults.js","../node_modules/plotly.js/src/traces/funnel/plot.js","../node_modules/plotly.js/src/traces/funnel/style.js","../node_modules/plotly.js/src/traces/funnelarea/attributes.js","../node_modules/plotly.js/src/traces/funnelarea/base_plot.js","../node_modules/plotly.js/src/traces/funnelarea/calc.js","../node_modules/plotly.js/src/traces/funnelarea/defaults.js","../node_modules/plotly.js/src/traces/funnelarea/index.js","../node_modules/plotly.js/src/traces/funnelarea/layout_attributes.js","../node_modules/plotly.js/src/traces/funnelarea/layout_defaults.js","../node_modules/plotly.js/src/traces/funnelarea/plot.js","../node_modules/plotly.js/src/traces/funnelarea/style.js","../node_modules/plotly.js/src/traces/heatmap/attributes.js","../node_modules/plotly.js/src/traces/heatmap/calc.js","../node_modules/plotly.js/src/traces/heatmap/clean_2d_array.js","../node_modules/plotly.js/src/traces/heatmap/colorbar.js","../node_modules/plotly.js/src/traces/heatmap/convert_column_xyz.js","../node_modules/plotly.js/src/traces/heatmap/defaults.js","../node_modules/plotly.js/src/traces/heatmap/find_empties.js","../node_modules/plotly.js/src/traces/heatmap/hover.js","../node_modules/plotly.js/src/traces/heatmap/index.js","../node_modules/plotly.js/src/traces/heatmap/interp2d.js","../node_modules/plotly.js/src/traces/heatmap/label_defaults.js","../node_modules/plotly.js/src/traces/heatmap/make_bound_array.js","../node_modules/plotly.js/src/traces/heatmap/plot.js","../node_modules/plotly.js/src/traces/heatmap/style.js","../node_modules/plotly.js/src/traces/heatmap/style_defaults.js","../node_modules/plotly.js/src/traces/heatmap/xyz_defaults.js","../node_modules/plotly.js/src/traces/heatmapgl/attributes.js","../node_modules/plotly.js/src/traces/heatmapgl/convert.js","../node_modules/plotly.js/src/traces/heatmapgl/defaults.js","../node_modules/plotly.js/src/traces/heatmapgl/index.js","../node_modules/plotly.js/src/traces/histogram/attributes.js","../node_modules/plotly.js/src/traces/histogram/average.js","../node_modules/plotly.js/src/traces/histogram/bin_attributes.js","../node_modules/plotly.js/src/traces/histogram/bin_functions.js","../node_modules/plotly.js/src/traces/histogram/bin_label_vals.js","../node_modules/plotly.js/src/traces/histogram/calc.js","../node_modules/plotly.js/src/traces/histogram/constants.js","../node_modules/plotly.js/src/traces/histogram/cross_trace_defaults.js","../node_modules/plotly.js/src/traces/histogram/defaults.js","../node_modules/plotly.js/src/traces/histogram/event_data.js","../node_modules/plotly.js/src/traces/histogram/hover.js","../node_modules/plotly.js/src/traces/histogram/index.js","../node_modules/plotly.js/src/traces/histogram/norm_functions.js","../node_modules/plotly.js/src/traces/histogram2d/attributes.js","../node_modules/plotly.js/src/traces/histogram2d/calc.js","../node_modules/plotly.js/src/traces/histogram2d/defaults.js","../node_modules/plotly.js/src/traces/histogram2d/hover.js","../node_modules/plotly.js/src/traces/histogram2d/index.js","../node_modules/plotly.js/src/traces/histogram2d/sample_defaults.js","../node_modules/plotly.js/src/traces/histogram2dcontour/attributes.js","../node_modules/plotly.js/src/traces/histogram2dcontour/defaults.js","../node_modules/plotly.js/src/traces/histogram2dcontour/index.js","../node_modules/plotly.js/src/traces/icicle/attributes.js","../node_modules/plotly.js/src/traces/icicle/base_plot.js","../node_modules/plotly.js/src/traces/icicle/calc.js","../node_modules/plotly.js/src/traces/icicle/defaults.js","../node_modules/plotly.js/src/traces/icicle/draw_descendants.js","../node_modules/plotly.js/src/traces/icicle/index.js","../node_modules/plotly.js/src/traces/icicle/layout_attributes.js","../node_modules/plotly.js/src/traces/icicle/layout_defaults.js","../node_modules/plotly.js/src/traces/icicle/partition.js","../node_modules/plotly.js/src/traces/icicle/plot.js","../node_modules/plotly.js/src/traces/icicle/style.js","../node_modules/plotly.js/src/traces/image/attributes.js","../node_modules/plotly.js/src/traces/image/calc.js","../node_modules/plotly.js/src/traces/image/constants.js","../node_modules/plotly.js/src/traces/image/defaults.js","../node_modules/plotly.js/src/traces/image/event_data.js","../node_modules/plotly.js/src/traces/image/helpers.js","../node_modules/plotly.js/src/traces/image/hover.js","../node_modules/plotly.js/src/traces/image/index.js","../node_modules/plotly.js/src/traces/image/plot.js","../node_modules/plotly.js/src/traces/image/style.js","../node_modules/plotly.js/src/traces/indicator/attributes.js","../node_modules/plotly.js/src/traces/indicator/base_plot.js","../node_modules/plotly.js/src/traces/indicator/calc.js","../node_modules/plotly.js/src/traces/indicator/constants.js","../node_modules/plotly.js/src/traces/indicator/defaults.js","../node_modules/plotly.js/src/traces/indicator/index.js","../node_modules/plotly.js/src/traces/indicator/plot.js","../node_modules/plotly.js/src/traces/isosurface/attributes.js","../node_modules/plotly.js/src/traces/isosurface/calc.js","../node_modules/plotly.js/src/traces/isosurface/convert.js","../node_modules/plotly.js/src/traces/isosurface/defaults.js","../node_modules/plotly.js/src/traces/isosurface/index.js","../node_modules/plotly.js/src/traces/mesh3d/attributes.js","../node_modules/plotly.js/src/traces/mesh3d/calc.js","../node_modules/plotly.js/src/traces/mesh3d/convert.js","../node_modules/plotly.js/src/traces/mesh3d/defaults.js","../node_modules/plotly.js/src/traces/mesh3d/index.js","../node_modules/plotly.js/src/traces/ohlc/attributes.js","../node_modules/plotly.js/src/traces/ohlc/calc.js","../node_modules/plotly.js/src/traces/ohlc/defaults.js","../node_modules/plotly.js/src/traces/ohlc/hover.js","../node_modules/plotly.js/src/traces/ohlc/index.js","../node_modules/plotly.js/src/traces/ohlc/ohlc_defaults.js","../node_modules/plotly.js/src/traces/ohlc/plot.js","../node_modules/plotly.js/src/traces/ohlc/select.js","../node_modules/plotly.js/src/traces/ohlc/style.js","../node_modules/plotly.js/src/traces/parcats/attributes.js","../node_modules/plotly.js/src/traces/parcats/base_plot.js","../node_modules/plotly.js/src/traces/parcats/calc.js","../node_modules/plotly.js/src/traces/parcats/defaults.js","../node_modules/plotly.js/src/traces/parcats/index.js","../node_modules/plotly.js/src/traces/parcats/parcats.js","../node_modules/plotly.js/src/traces/parcats/plot.js","../node_modules/plotly.js/src/traces/parcoords/attributes.js","../node_modules/plotly.js/src/traces/parcoords/axisbrush.js","../node_modules/plotly.js/src/traces/parcoords/base_index.js","../node_modules/plotly.js/src/traces/parcoords/base_plot.js","../node_modules/plotly.js/src/traces/parcoords/calc.js","../node_modules/plotly.js/src/traces/parcoords/constants.js","../node_modules/plotly.js/src/traces/parcoords/defaults.js","../node_modules/plotly.js/src/traces/parcoords/helpers.js","../node_modules/plotly.js/src/traces/parcoords/index.js","../node_modules/plotly.js/src/traces/parcoords/lines.js","../node_modules/plotly.js/src/traces/parcoords/merge_length.js","../node_modules/plotly.js/src/traces/parcoords/parcoords.js","../node_modules/plotly.js/src/traces/parcoords/plot.js","../node_modules/plotly.js/src/traces/pie/attributes.js","../node_modules/plotly.js/src/traces/pie/base_plot.js","../node_modules/plotly.js/src/traces/pie/calc.js","../node_modules/plotly.js/src/traces/pie/defaults.js","../node_modules/plotly.js/src/traces/pie/event_data.js","../node_modules/plotly.js/src/traces/pie/fill_one.js","../node_modules/plotly.js/src/traces/pie/helpers.js","../node_modules/plotly.js/src/traces/pie/index.js","../node_modules/plotly.js/src/traces/pie/layout_attributes.js","../node_modules/plotly.js/src/traces/pie/layout_defaults.js","../node_modules/plotly.js/src/traces/pie/plot.js","../node_modules/plotly.js/src/traces/pie/style.js","../node_modules/plotly.js/src/traces/pie/style_one.js","../node_modules/plotly.js/src/traces/pointcloud/attributes.js","../node_modules/plotly.js/src/traces/pointcloud/convert.js","../node_modules/plotly.js/src/traces/pointcloud/defaults.js","../node_modules/plotly.js/src/traces/pointcloud/index.js","../node_modules/plotly.js/src/traces/sankey/attributes.js","../node_modules/plotly.js/src/traces/sankey/base_plot.js","../node_modules/plotly.js/src/traces/sankey/calc.js","../node_modules/plotly.js/src/traces/sankey/constants.js","../node_modules/plotly.js/src/traces/sankey/defaults.js","../node_modules/plotly.js/src/traces/sankey/index.js","../node_modules/plotly.js/src/traces/sankey/plot.js","../node_modules/plotly.js/src/traces/sankey/render.js","../node_modules/plotly.js/src/traces/sankey/select.js","../node_modules/plotly.js/src/traces/scatter/arrays_to_calcdata.js","../node_modules/plotly.js/src/traces/scatter/attributes.js","../node_modules/plotly.js/src/traces/scatter/calc.js","../node_modules/plotly.js/src/traces/scatter/calc_selection.js","../node_modules/plotly.js/src/traces/scatter/colorscale_calc.js","../node_modules/plotly.js/src/traces/scatter/constants.js","../node_modules/plotly.js/src/traces/scatter/cross_trace_calc.js","../node_modules/plotly.js/src/traces/scatter/cross_trace_defaults.js","../node_modules/plotly.js/src/traces/scatter/defaults.js","../node_modules/plotly.js/src/traces/scatter/fillcolor_attribute.js","../node_modules/plotly.js/src/traces/scatter/fillcolor_defaults.js","../node_modules/plotly.js/src/traces/scatter/format_labels.js","../node_modules/plotly.js/src/traces/scatter/get_trace_color.js","../node_modules/plotly.js/src/traces/scatter/grouping_defaults.js","../node_modules/plotly.js/src/traces/scatter/hover.js","../node_modules/plotly.js/src/traces/scatter/index.js","../node_modules/plotly.js/src/traces/scatter/layout_attributes.js","../node_modules/plotly.js/src/traces/scatter/layout_defaults.js","../node_modules/plotly.js/src/traces/scatter/line_defaults.js","../node_modules/plotly.js/src/traces/scatter/line_points.js","../node_modules/plotly.js/src/traces/scatter/line_shape_defaults.js","../node_modules/plotly.js/src/traces/scatter/link_traces.js","../node_modules/plotly.js/src/traces/scatter/make_bubble_size_func.js","../node_modules/plotly.js/src/traces/scatter/marker_colorbar.js","../node_modules/plotly.js/src/traces/scatter/marker_defaults.js","../node_modules/plotly.js/src/traces/scatter/period_defaults.js","../node_modules/plotly.js/src/traces/scatter/plot.js","../node_modules/plotly.js/src/traces/scatter/select.js","../node_modules/plotly.js/src/traces/scatter/stack_defaults.js","../node_modules/plotly.js/src/traces/scatter/style.js","../node_modules/plotly.js/src/traces/scatter/subtypes.js","../node_modules/plotly.js/src/traces/scatter/text_defaults.js","../node_modules/plotly.js/src/traces/scatter/xy_defaults.js","../node_modules/plotly.js/src/traces/scatter3d/attributes.js","../node_modules/plotly.js/src/traces/scatter3d/calc.js","../node_modules/plotly.js/src/traces/scatter3d/calc_errors.js","../node_modules/plotly.js/src/traces/scatter3d/convert.js","../node_modules/plotly.js/src/traces/scatter3d/defaults.js","../node_modules/plotly.js/src/traces/scatter3d/index.js","../node_modules/plotly.js/src/traces/scattercarpet/attributes.js","../node_modules/plotly.js/src/traces/scattercarpet/calc.js","../node_modules/plotly.js/src/traces/scattercarpet/defaults.js","../node_modules/plotly.js/src/traces/scattercarpet/event_data.js","../node_modules/plotly.js/src/traces/scattercarpet/format_labels.js","../node_modules/plotly.js/src/traces/scattercarpet/hover.js","../node_modules/plotly.js/src/traces/scattercarpet/index.js","../node_modules/plotly.js/src/traces/scattercarpet/plot.js","../node_modules/plotly.js/src/traces/scattergeo/attributes.js","../node_modules/plotly.js/src/traces/scattergeo/calc.js","../node_modules/plotly.js/src/traces/scattergeo/defaults.js","../node_modules/plotly.js/src/traces/scattergeo/event_data.js","../node_modules/plotly.js/src/traces/scattergeo/format_labels.js","../node_modules/plotly.js/src/traces/scattergeo/hover.js","../node_modules/plotly.js/src/traces/scattergeo/index.js","../node_modules/plotly.js/src/traces/scattergeo/plot.js","../node_modules/plotly.js/src/traces/scattergeo/select.js","../node_modules/plotly.js/src/traces/scattergeo/style.js","../node_modules/plotly.js/src/traces/scattergl/attributes.js","../node_modules/plotly.js/src/traces/scattergl/base_index.js","../node_modules/plotly.js/src/traces/scattergl/calc.js","../node_modules/plotly.js/src/traces/scattergl/constants.js","../node_modules/plotly.js/src/traces/scattergl/convert.js","../node_modules/plotly.js/src/traces/scattergl/defaults.js","../node_modules/plotly.js/src/traces/scattergl/edit_style.js","../node_modules/plotly.js/src/traces/scattergl/format_labels.js","../node_modules/plotly.js/src/traces/scattergl/helpers.js","../node_modules/plotly.js/src/traces/scattergl/hover.js","../node_modules/plotly.js/src/traces/scattergl/index.js","../node_modules/plotly.js/src/traces/scattergl/plot.js","../node_modules/plotly.js/src/traces/scattergl/scene_update.js","../node_modules/plotly.js/src/traces/scattergl/select.js","../node_modules/plotly.js/src/traces/scattermap/attributes.js","../node_modules/plotly.js/src/traces/scattermap/constants.js","../node_modules/plotly.js/src/traces/scattermap/convert.js","../node_modules/plotly.js/src/traces/scattermap/defaults.js","../node_modules/plotly.js/src/traces/scattermap/event_data.js","../node_modules/plotly.js/src/traces/scattermap/format_labels.js","../node_modules/plotly.js/src/traces/scattermap/hover.js","../node_modules/plotly.js/src/traces/scattermap/index.js","../node_modules/plotly.js/src/traces/scattermap/plot.js","../node_modules/plotly.js/src/traces/scattermap/select.js","../node_modules/plotly.js/src/traces/scattermapbox/attributes.js","../node_modules/plotly.js/src/traces/scattermapbox/constants.js","../node_modules/plotly.js/src/traces/scattermapbox/convert.js","../node_modules/plotly.js/src/traces/scattermapbox/defaults.js","../node_modules/plotly.js/src/traces/scattermapbox/event_data.js","../node_modules/plotly.js/src/traces/scattermapbox/format_labels.js","../node_modules/plotly.js/src/traces/scattermapbox/hover.js","../node_modules/plotly.js/src/traces/scattermapbox/index.js","../node_modules/plotly.js/src/traces/scattermapbox/plot.js","../node_modules/plotly.js/src/traces/scattermapbox/select.js","../node_modules/plotly.js/src/traces/scatterpolar/attributes.js","../node_modules/plotly.js/src/traces/scatterpolar/calc.js","../node_modules/plotly.js/src/traces/scatterpolar/defaults.js","../node_modules/plotly.js/src/traces/scatterpolar/format_labels.js","../node_modules/plotly.js/src/traces/scatterpolar/hover.js","../node_modules/plotly.js/src/traces/scatterpolar/index.js","../node_modules/plotly.js/src/traces/scatterpolar/plot.js","../node_modules/plotly.js/src/traces/scatterpolargl/attributes.js","../node_modules/plotly.js/src/traces/scatterpolargl/base_index.js","../node_modules/plotly.js/src/traces/scatterpolargl/calc.js","../node_modules/plotly.js/src/traces/scatterpolargl/defaults.js","../node_modules/plotly.js/src/traces/scatterpolargl/format_labels.js","../node_modules/plotly.js/src/traces/scatterpolargl/hover.js","../node_modules/plotly.js/src/traces/scatterpolargl/index.js","../node_modules/plotly.js/src/traces/scatterpolargl/plot.js","../node_modules/plotly.js/src/traces/scattersmith/attributes.js","../node_modules/plotly.js/src/traces/scattersmith/calc.js","../node_modules/plotly.js/src/traces/scattersmith/defaults.js","../node_modules/plotly.js/src/traces/scattersmith/format_labels.js","../node_modules/plotly.js/src/traces/scattersmith/hover.js","../node_modules/plotly.js/src/traces/scattersmith/index.js","../node_modules/plotly.js/src/traces/scattersmith/plot.js","../node_modules/plotly.js/src/traces/scatterternary/attributes.js","../node_modules/plotly.js/src/traces/scatterternary/calc.js","../node_modules/plotly.js/src/traces/scatterternary/defaults.js","../node_modules/plotly.js/src/traces/scatterternary/event_data.js","../node_modules/plotly.js/src/traces/scatterternary/format_labels.js","../node_modules/plotly.js/src/traces/scatterternary/hover.js","../node_modules/plotly.js/src/traces/scatterternary/index.js","../node_modules/plotly.js/src/traces/scatterternary/plot.js","../node_modules/plotly.js/src/traces/splom/attributes.js","../node_modules/plotly.js/src/traces/splom/base_index.js","../node_modules/plotly.js/src/traces/splom/base_plot.js","../node_modules/plotly.js/src/traces/splom/calc.js","../node_modules/plotly.js/src/traces/splom/defaults.js","../node_modules/plotly.js/src/traces/splom/edit_style.js","../node_modules/plotly.js/src/traces/splom/helpers.js","../node_modules/plotly.js/src/traces/splom/hover.js","../node_modules/plotly.js/src/traces/splom/index.js","../node_modules/plotly.js/src/traces/splom/plot.js","../node_modules/plotly.js/src/traces/splom/scene_update.js","../node_modules/plotly.js/src/traces/splom/select.js","../node_modules/plotly.js/src/traces/streamtube/attributes.js","../node_modules/plotly.js/src/traces/streamtube/calc.js","../node_modules/plotly.js/src/traces/streamtube/convert.js","../node_modules/plotly.js/src/traces/streamtube/defaults.js","../node_modules/plotly.js/src/traces/streamtube/index.js","../node_modules/plotly.js/src/traces/sunburst/attributes.js","../node_modules/plotly.js/src/traces/sunburst/base_plot.js","../node_modules/plotly.js/src/traces/sunburst/calc.js","../node_modules/plotly.js/src/traces/sunburst/constants.js","../node_modules/plotly.js/src/traces/sunburst/defaults.js","../node_modules/plotly.js/src/traces/sunburst/fill_one.js","../node_modules/plotly.js/src/traces/sunburst/fx.js","../node_modules/plotly.js/src/traces/sunburst/helpers.js","../node_modules/plotly.js/src/traces/sunburst/index.js","../node_modules/plotly.js/src/traces/sunburst/layout_attributes.js","../node_modules/plotly.js/src/traces/sunburst/layout_defaults.js","../node_modules/plotly.js/src/traces/sunburst/plot.js","../node_modules/plotly.js/src/traces/sunburst/style.js","../node_modules/plotly.js/src/traces/surface/attributes.js","../node_modules/plotly.js/src/traces/surface/calc.js","../node_modules/plotly.js/src/traces/surface/convert.js","../node_modules/plotly.js/src/traces/surface/defaults.js","../node_modules/plotly.js/src/traces/surface/index.js","../node_modules/plotly.js/src/traces/table/attributes.js","../node_modules/plotly.js/src/traces/table/base_plot.js","../node_modules/plotly.js/src/traces/table/calc.js","../node_modules/plotly.js/src/traces/table/constants.js","../node_modules/plotly.js/src/traces/table/data_preparation_helper.js","../node_modules/plotly.js/src/traces/table/data_split_helpers.js","../node_modules/plotly.js/src/traces/table/defaults.js","../node_modules/plotly.js/src/traces/table/index.js","../node_modules/plotly.js/src/traces/table/plot.js","../node_modules/plotly.js/src/traces/treemap/attributes.js","../node_modules/plotly.js/src/traces/treemap/base_plot.js","../node_modules/plotly.js/src/traces/treemap/calc.js","../node_modules/plotly.js/src/traces/treemap/constants.js","../node_modules/plotly.js/src/traces/treemap/defaults.js","../node_modules/plotly.js/src/traces/treemap/draw.js","../node_modules/plotly.js/src/traces/treemap/draw_ancestors.js","../node_modules/plotly.js/src/traces/treemap/draw_descendants.js","../node_modules/plotly.js/src/traces/treemap/flip_tree.js","../node_modules/plotly.js/src/traces/treemap/index.js","../node_modules/plotly.js/src/traces/treemap/layout_attributes.js","../node_modules/plotly.js/src/traces/treemap/layout_defaults.js","../node_modules/plotly.js/src/traces/treemap/partition.js","../node_modules/plotly.js/src/traces/treemap/plot.js","../node_modules/plotly.js/src/traces/treemap/plot_one.js","../node_modules/plotly.js/src/traces/treemap/style.js","../node_modules/plotly.js/src/traces/violin/attributes.js","../node_modules/plotly.js/src/traces/violin/calc.js","../node_modules/plotly.js/src/traces/violin/cross_trace_calc.js","../node_modules/plotly.js/src/traces/violin/defaults.js","../node_modules/plotly.js/src/traces/violin/helpers.js","../node_modules/plotly.js/src/traces/violin/hover.js","../node_modules/plotly.js/src/traces/violin/index.js","../node_modules/plotly.js/src/traces/violin/layout_attributes.js","../node_modules/plotly.js/src/traces/violin/layout_defaults.js","../node_modules/plotly.js/src/traces/violin/plot.js","../node_modules/plotly.js/src/traces/violin/style.js","../node_modules/plotly.js/src/traces/volume/attributes.js","../node_modules/plotly.js/src/traces/volume/convert.js","../node_modules/plotly.js/src/traces/volume/defaults.js","../node_modules/plotly.js/src/traces/volume/index.js","../node_modules/plotly.js/src/traces/waterfall/attributes.js","../node_modules/plotly.js/src/traces/waterfall/calc.js","../node_modules/plotly.js/src/traces/waterfall/constants.js","../node_modules/plotly.js/src/traces/waterfall/cross_trace_calc.js","../node_modules/plotly.js/src/traces/waterfall/defaults.js","../node_modules/plotly.js/src/traces/waterfall/event_data.js","../node_modules/plotly.js/src/traces/waterfall/hover.js","../node_modules/plotly.js/src/traces/waterfall/index.js","../node_modules/plotly.js/src/traces/waterfall/layout_attributes.js","../node_modules/plotly.js/src/traces/waterfall/layout_defaults.js","../node_modules/plotly.js/src/traces/waterfall/plot.js","../node_modules/plotly.js/src/traces/waterfall/style.js","../node_modules/plotly.js/src/transforms/aggregate.js","../node_modules/plotly.js/src/transforms/filter.js","../node_modules/plotly.js/src/transforms/groupby.js","../node_modules/plotly.js/src/transforms/helpers.js","../node_modules/plotly.js/src/transforms/sort.js","../node_modules/plotly.js/src/version.js","../node_modules/plotly.js/stackgl_modules/index.js","../node_modules/point-in-polygon/nested.js","../node_modules/polybooljs/index.js","../node_modules/polybooljs/lib/build-log.js","../node_modules/polybooljs/lib/epsilon.js","../node_modules/polybooljs/lib/geojson.js","../node_modules/polybooljs/lib/intersecter.js","../node_modules/polybooljs/lib/linked-list.js","../node_modules/polybooljs/lib/segment-chainer.js","../node_modules/polybooljs/lib/segment-selector.js","../node_modules/possible-typed-array-names/index.js","../node_modules/probe-image-size/lib/common.js","../node_modules/probe-image-size/lib/exif_utils.js","../node_modules/probe-image-size/lib/miaf_utils.js","../node_modules/probe-image-size/lib/parse_sync/avif.js","../node_modules/probe-image-size/lib/parse_sync/bmp.js","../node_modules/probe-image-size/lib/parse_sync/gif.js","../node_modules/probe-image-size/lib/parse_sync/ico.js","../node_modules/probe-image-size/lib/parse_sync/jpeg.js","../node_modules/probe-image-size/lib/parse_sync/png.js","../node_modules/probe-image-size/lib/parse_sync/psd.js","../node_modules/probe-image-size/lib/parse_sync/svg.js","../node_modules/probe-image-size/lib/parse_sync/tiff.js","../node_modules/probe-image-size/lib/parse_sync/webp.js","../node_modules/probe-image-size/lib/parsers_sync.js","../node_modules/probe-image-size/sync.js","../node_modules/prop-types/factoryWithThrowingShims.js","../node_modules/prop-types/index.js","../node_modules/prop-types/lib/ReactPropTypesSecret.js","../node_modules/qs/lib/formats.js","../node_modules/qs/lib/index.js","../node_modules/qs/lib/parse.js","../node_modules/qs/lib/stringify.js","../node_modules/qs/lib/utils.js","../node_modules/raf/index.js","../node_modules/react-dom/cjs/react-dom.production.min.js","../node_modules/react-dom/client.js","../node_modules/react-dom/index.js","../node_modules/react-is/cjs/react-is.production.min.js","../node_modules/react-is/index.js","../react-linear-gradient-picker/node_modules/prop-types/factoryWithThrowingShims.js","../react-linear-gradient-picker/node_modules/prop-types/index.js","../react-linear-gradient-picker/node_modules/prop-types/lib/ReactPropTypesSecret.js","../react-linear-gradient-picker/webpack/bootstrap","../react-linear-gradient-picker/webpack/runtime/compat get default export","../react-linear-gradient-picker/webpack/runtime/define property getters","../react-linear-gradient-picker/webpack/runtime/hasOwnProperty shorthand","../react-linear-gradient-picker/webpack/runtime/make namespace object","../react-linear-gradient-picker/src/lib/sortPalette/index.js","../react-linear-gradient-picker/src/lib/noop/index.js","../react-linear-gradient-picker/src/lib/snapAngle/index.js","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/iterableToArray.js","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","../react-linear-gradient-picker/src/lib/colors/parseRgb/index.js","../react-linear-gradient-picker/src/lib/colors/hexToRgb/index.js","../react-linear-gradient-picker/src/lib/getStopColor/index.js","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/toArray.js","../react-linear-gradient-picker/src/lib/colors/formatRgb/index.js","../react-linear-gradient-picker/src/lib/getStopOffset/index.js","../react-linear-gradient-picker/src/lib/angleToGradientCords/constants.js","../react-linear-gradient-picker/src/lib/angleToGradientCords/index.js","../react-linear-gradient-picker/src/lib/getGradientPreview/index.js","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/slicedToArray.js","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","../react-linear-gradient-picker/external commonjs2 \"react\"","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/defineProperty.js","../react-linear-gradient-picker/src/components/propTypes/index.js","../react-linear-gradient-picker/src/components/hooks/useDragging/index.js","../react-linear-gradient-picker/src/components/hooks/useDragging/constants.js","../react-linear-gradient-picker/src/components/AnglePicker/index.js","../react-linear-gradient-picker/src/lib/centerOffset/index.js","../react-linear-gradient-picker/src/lib/pointDegrees/index.js","../react-linear-gradient-picker/src/lib/clampAngle/index.js","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","../react-linear-gradient-picker/node_modules/@babel/runtime/helpers/esm/extends.js","../react-linear-gradient-picker/src/components/ColorStop/index.js","../react-linear-gradient-picker/src/components/ColorStop/hooks/useStopDragging.js","../react-linear-gradient-picker/src/components/ColorStopsHolder/index.js","../react-linear-gradient-picker/src/components/Palette/index.js","../react-linear-gradient-picker/src/components/ColorPicker/constants.js","../react-linear-gradient-picker/src/components/ColorPicker/index.js","../react-linear-gradient-picker/src/components/GradientPicker/constants.js","../react-linear-gradient-picker/src/components/GradientPicker/index.js","../react-linear-gradient-picker/src/components/GradientTypePicker/index.js","../react-linear-gradient-picker/src/components/GradientPickerPopover/index.js","../node_modules/react-plotlyjs-ts/dist/index.js","../node_modules/react/cjs/react-jsx-runtime.production.min.js","../node_modules/react/cjs/react.production.min.js","../node_modules/react/index.js","../node_modules/react/jsx-runtime.js","../node_modules/reactcss/lib/autoprefix.js","../node_modules/reactcss/lib/components/active.js","../node_modules/reactcss/lib/components/hover.js","../node_modules/reactcss/lib/flattenNames.js","../node_modules/reactcss/lib/index.js","../node_modules/reactcss/lib/loop.js","../node_modules/reactcss/lib/mergeClasses.js","../node_modules/regl-error2d/index.js","../node_modules/regl-line2d/index.js","../node_modules/regl-scatter2d/bundle.js","../node_modules/regl-splom/index.js","../node_modules/regl/dist/regl.unchecked.js","../node_modules/safe-buffer/index.js","../node_modules/scheduler/cjs/scheduler.production.min.js","../node_modules/scheduler/index.js","../node_modules/set-function-length/index.js","../node_modules/side-channel/index.js","../node_modules/stream-browserify/index.js","../node_modules/stream-browserify/node_modules/readable-stream/errors-browser.js","../node_modules/stream-browserify/node_modules/readable-stream/lib/_stream_duplex.js","../node_modules/stream-browserify/node_modules/readable-stream/lib/_stream_passthrough.js","../node_modules/stream-browserify/node_modules/readable-stream/lib/_stream_readable.js","../node_modules/stream-browserify/node_modules/readable-stream/lib/_stream_transform.js","../node_modules/stream-browserify/node_modules/readable-stream/lib/_stream_writable.js","../node_modules/stream-browserify/node_modules/readable-stream/lib/internal/streams/async_iterator.js","../node_modules/stream-browserify/node_modules/readable-stream/lib/internal/streams/buffer_list.js","../node_modules/stream-browserify/node_modules/readable-stream/lib/internal/streams/destroy.js","../node_modules/stream-browserify/node_modules/readable-stream/lib/internal/streams/end-of-stream.js","../node_modules/stream-browserify/node_modules/readable-stream/lib/internal/streams/from-browser.js","../node_modules/stream-browserify/node_modules/readable-stream/lib/internal/streams/pipeline.js","../node_modules/stream-browserify/node_modules/readable-stream/lib/internal/streams/state.js","../node_modules/stream-browserify/node_modules/readable-stream/lib/internal/streams/stream-browser.js","../node_modules/stream-browserify/node_modules/string_decoder/lib/string_decoder.js","../node_modules/stream-parser/index.js","../node_modules/stream-parser/node_modules/debug/src/browser.js","../node_modules/stream-parser/node_modules/debug/src/debug.js","../node_modules/stream-parser/node_modules/ms/index.js","../node_modules/string-split-by/index.js","../node_modules/strongly-connected-components/scc.js","../node_modules/svg-arc-to-cubic-bezier/modules/index.js","../node_modules/svg-path-bounds/index.js","../node_modules/svg-path-sdf/index.js","../node_modules/to-float32/index.js","../node_modules/to-px/browser.js","../node_modules/topojson-client/src/identity.js","../node_modules/topojson-client/src/feature.js","../node_modules/topojson-client/src/transform.js","../node_modules/topojson-client/src/reverse.js","../node_modules/type/function/is.js","../node_modules/type/lib/resolve-error-message.js","../node_modules/type/lib/resolve-exception.js","../node_modules/type/lib/safe-to-string.js","../node_modules/type/lib/to-short-string.js","../node_modules/type/object/is.js","../node_modules/type/plain-function/ensure.js","../node_modules/type/plain-function/is.js","../node_modules/type/prototype/is.js","../node_modules/type/string/coerce.js","../node_modules/type/value/ensure.js","../node_modules/type/value/is.js","../node_modules/typedarray-pool/pool.js","../node_modules/unquote/index.js","../node_modules/update-diff/index.js","../node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.min.js","../node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.min.js","../node_modules/use-sync-external-store/shim/index.js","../node_modules/use-sync-external-store/shim/with-selector.js","../node_modules/util-deprecate/browser.js","../node_modules/util/support/isBufferBrowser.js","../node_modules/util/support/types.js","../node_modules/util/util.js","../node_modules/webgl-context/index.js","../node_modules/which-typed-array/index.js","../node_modules/world-calendars/dist/calendars/chinese.js","../node_modules/world-calendars/dist/calendars/coptic.js","../node_modules/world-calendars/dist/calendars/discworld.js","../node_modules/world-calendars/dist/calendars/ethiopian.js","../node_modules/world-calendars/dist/calendars/hebrew.js","../node_modules/world-calendars/dist/calendars/islamic.js","../node_modules/world-calendars/dist/calendars/julian.js","../node_modules/world-calendars/dist/calendars/mayan.js","../node_modules/world-calendars/dist/calendars/nanakshahi.js","../node_modules/world-calendars/dist/calendars/nepali.js","../node_modules/world-calendars/dist/calendars/persian.js","../node_modules/world-calendars/dist/calendars/taiwan.js","../node_modules/world-calendars/dist/calendars/thai.js","../node_modules/world-calendars/dist/calendars/ummalqura.js","../node_modules/world-calendars/dist/main.js","../node_modules/world-calendars/dist/plus.js","webpack://optinist/./node_modules/maplibre-gl/dist/maplibre-gl.css?8bb3","../node_modules/@babel/runtime/helpers/extends.js","../node_modules/@babel/runtime/helpers/interopRequireDefault.js","../node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js","../node_modules/available-typed-arrays/index.js","../node_modules/maplibre-gl/node_modules/tslib/tslib.es6.js","../node_modules/maplibre-gl/node_modules/@mapbox/point-geometry/index.js","../node_modules/maplibre-gl/node_modules/@mapbox/unitbezier/index.js","../node_modules/maplibre-gl/src/util/offscreen_canvas_supported.ts","../node_modules/maplibre-gl/src/util/offscreen_canvas_distorted.ts","../node_modules/maplibre-gl/src/util/util.ts","../node_modules/maplibre-gl/src/util/abort_error.ts","../node_modules/maplibre-gl/src/util/config.ts","../node_modules/maplibre-gl/src/source/protocol_crud.ts","../node_modules/maplibre-gl/src/util/ajax.ts","../node_modules/maplibre-gl/src/util/evented.ts","../node_modules/maplibre-gl/node_modules/@maplibre/maplibre-gl-style-spec/dist/index.mjs","../node_modules/maplibre-gl/src/style/validate_style.ts","../node_modules/maplibre-gl/src/util/transferable_grid_index.ts","../node_modules/maplibre-gl/src/util/web_worker_transfer.ts","../node_modules/maplibre-gl/src/style/zoom_history.ts","../node_modules/maplibre-gl/src/util/is_char_in_unicode_block.ts","../node_modules/maplibre-gl/src/util/script_detection.ts","../node_modules/maplibre-gl/src/source/rtl_text_plugin_worker.ts","../node_modules/maplibre-gl/src/style/evaluation_parameters.ts","../node_modules/maplibre-gl/src/style/properties.ts","../node_modules/maplibre-gl/src/style/style_layer.ts","../node_modules/maplibre-gl/src/util/struct_array.ts","../node_modules/maplibre-gl/src/data/array_types.g.ts","../node_modules/maplibre-gl/src/data/bucket/circle_attributes.ts","../node_modules/maplibre-gl/src/data/segment.ts","../node_modules/maplibre-gl/src/shaders/encode_attribute.ts","../node_modules/maplibre-gl/src/data/bucket/pattern_attributes.ts","../node_modules/maplibre-gl/node_modules/murmurhash-js/murmurhash3_gc.js","../node_modules/maplibre-gl/node_modules/murmurhash-js/murmurhash2_gc.js","../node_modules/maplibre-gl/node_modules/murmurhash-js/index.js","../node_modules/maplibre-gl/src/data/feature_position_map.ts","../node_modules/maplibre-gl/src/render/uniform_binding.ts","../node_modules/maplibre-gl/src/data/program_configuration.ts","../node_modules/maplibre-gl/src/data/extent.ts","../node_modules/maplibre-gl/src/data/load_geometry.ts","../node_modules/maplibre-gl/src/data/evaluation_feature.ts","../node_modules/maplibre-gl/src/data/bucket/circle_bucket.ts","../node_modules/maplibre-gl/src/util/intersection_tests.ts","../node_modules/maplibre-gl/src/style/query_utils.ts","../node_modules/maplibre-gl/src/style/style_layer/circle_style_layer_properties.g.ts","../node_modules/maplibre-gl/node_modules/gl-matrix/esm/common.js","../node_modules/maplibre-gl/node_modules/gl-matrix/esm/mat4.js","../node_modules/maplibre-gl/node_modules/gl-matrix/esm/vec4.js","../node_modules/maplibre-gl/src/style/style_layer/circle_style_layer.ts","../node_modules/maplibre-gl/src/data/bucket/heatmap_bucket.ts","../node_modules/maplibre-gl/src/style/style_layer/heatmap_style_layer_properties.g.ts","../node_modules/maplibre-gl/src/util/image.ts","../node_modules/maplibre-gl/src/util/color_ramp.ts","../node_modules/maplibre-gl/src/style/style_layer/heatmap_style_layer.ts","../node_modules/maplibre-gl/src/style/style_layer/hillshade_style_layer_properties.g.ts","../node_modules/maplibre-gl/src/style/style_layer/hillshade_style_layer.ts","../node_modules/maplibre-gl/src/data/bucket/fill_attributes.ts","../node_modules/maplibre-gl/node_modules/earcut/src/earcut.js","../node_modules/maplibre-gl/src/data/bucket/pattern_bucket_features.ts","../node_modules/maplibre-gl/src/data/bucket/fill_bucket.ts","../node_modules/maplibre-gl/src/style/style_layer/fill_style_layer_properties.g.ts","../node_modules/maplibre-gl/src/style/style_layer/fill_style_layer.ts","../node_modules/maplibre-gl/src/data/bucket/fill_extrusion_attributes.ts","../node_modules/maplibre-gl/node_modules/@mapbox/vector-tile/lib/vectortilefeature.js","../node_modules/maplibre-gl/node_modules/@mapbox/vector-tile/lib/vectortilelayer.js","../node_modules/maplibre-gl/node_modules/@mapbox/vector-tile/lib/vectortile.js","../node_modules/maplibre-gl/node_modules/@mapbox/vector-tile/index.js","../node_modules/maplibre-gl/src/data/bucket/fill_extrusion_bucket.ts","../node_modules/maplibre-gl/src/style/style_layer/fill_extrusion_style_layer_properties.g.ts","../node_modules/maplibre-gl/src/style/style_layer/fill_extrusion_style_layer.ts","../node_modules/maplibre-gl/src/data/bucket/line_attributes.ts","../node_modules/maplibre-gl/src/data/bucket/line_attributes_ext.ts","../node_modules/maplibre-gl/src/data/bucket/line_bucket.ts","../node_modules/maplibre-gl/src/style/style_layer/line_style_layer_properties.g.ts","../node_modules/maplibre-gl/src/style/style_layer/line_style_layer.ts","../node_modules/maplibre-gl/src/data/bucket/symbol_attributes.ts","../node_modules/maplibre-gl/src/symbol/transform_text.ts","../node_modules/maplibre-gl/src/symbol/merge_lines.ts","../node_modules/maplibre-gl/src/util/verticalize_punctuation.ts","../node_modules/maplibre-gl/src/symbol/one_em.ts","../node_modules/maplibre-gl/node_modules/ieee754/index.js","../node_modules/maplibre-gl/node_modules/pbf/index.js","../node_modules/maplibre-gl/src/style/parse_glyph_pbf.ts","../node_modules/maplibre-gl/node_modules/potpack/index.js","../node_modules/maplibre-gl/src/render/image_atlas.ts","../node_modules/maplibre-gl/src/symbol/shaping.ts","../node_modules/maplibre-gl/src/symbol/symbol_size.ts","../node_modules/maplibre-gl/src/style/style_layer/overlap_mode.ts","../node_modules/maplibre-gl/src/data/bucket/symbol_bucket.ts","../node_modules/maplibre-gl/src/util/resolve_tokens.ts","../node_modules/maplibre-gl/src/style/style_layer/symbol_style_layer_properties.g.ts","../node_modules/maplibre-gl/src/style/format_section_override.ts","../node_modules/maplibre-gl/src/style/style_layer/symbol_style_layer.ts","../node_modules/maplibre-gl/src/style/style_layer/background_style_layer_properties.g.ts","../node_modules/maplibre-gl/src/style/style_layer/background_style_layer.ts","../node_modules/maplibre-gl/src/style/style_layer/raster_style_layer_properties.g.ts","../node_modules/maplibre-gl/src/style/style_layer/raster_style_layer.ts","../node_modules/maplibre-gl/src/style/style_layer/custom_style_layer.ts","../node_modules/maplibre-gl/src/style/create_style_layer.ts","../node_modules/maplibre-gl/src/util/throttled_invoker.ts","../node_modules/maplibre-gl/src/util/actor.ts","../node_modules/maplibre-gl/src/geo/lng_lat.ts","../node_modules/maplibre-gl/src/geo/mercator_coordinate.ts","../node_modules/maplibre-gl/node_modules/@mapbox/whoots-js/index.mjs","../node_modules/maplibre-gl/src/util/world_bounds.ts","../node_modules/maplibre-gl/src/source/tile_id.ts","../node_modules/maplibre-gl/src/data/dem_data.ts","../node_modules/maplibre-gl/src/util/dictionary_coder.ts","../node_modules/maplibre-gl/src/util/vectortile_to_geojson.ts","../node_modules/maplibre-gl/src/data/feature_index.ts","../node_modules/maplibre-gl/src/symbol/clip_line.ts","../node_modules/maplibre-gl/src/symbol/anchor.ts","../node_modules/maplibre-gl/src/symbol/check_max_angle.ts","../node_modules/maplibre-gl/src/symbol/get_anchors.ts","../node_modules/maplibre-gl/src/symbol/quads.ts","../node_modules/maplibre-gl/src/symbol/collision_feature.ts","../node_modules/maplibre-gl/node_modules/tinyqueue/index.js","../node_modules/maplibre-gl/src/util/find_pole_of_inaccessibility.ts","../node_modules/maplibre-gl/src/style/style_layer/variable_text_anchor.ts","../node_modules/maplibre-gl/src/symbol/symbol_layout.ts","../node_modules/maplibre-gl/node_modules/kdbush/index.js","../node_modules/maplibre-gl/src/util/performance.ts","../node_modules/maplibre-gl/src/style/style_layer_index.ts","../node_modules/maplibre-gl/src/render/glyph_atlas.ts","../node_modules/maplibre-gl/src/source/worker_tile.ts","../node_modules/maplibre-gl/src/source/vector_tile_worker_source.ts","../node_modules/maplibre-gl/src/source/raster_dem_tile_worker_source.ts","../node_modules/maplibre-gl/node_modules/@mapbox/geojson-rewind/index.js","../node_modules/maplibre-gl/src/source/geojson_wrapper.ts","../node_modules/maplibre-gl/node_modules/vt-pbf/lib/geojson_wrapper.js","../node_modules/maplibre-gl/node_modules/vt-pbf/index.js","../node_modules/maplibre-gl/node_modules/supercluster/index.js","../node_modules/maplibre-gl/node_modules/geojson-vt/src/simplify.js","../node_modules/maplibre-gl/node_modules/geojson-vt/src/feature.js","../node_modules/maplibre-gl/node_modules/geojson-vt/src/convert.js","../node_modules/maplibre-gl/node_modules/geojson-vt/src/clip.js","../node_modules/maplibre-gl/node_modules/geojson-vt/src/wrap.js","../node_modules/maplibre-gl/node_modules/geojson-vt/src/transform.js","../node_modules/maplibre-gl/node_modules/geojson-vt/src/tile.js","../node_modules/maplibre-gl/node_modules/geojson-vt/src/index.js","../node_modules/maplibre-gl/src/source/geojson_source_diff.ts","../node_modules/maplibre-gl/src/source/geojson_worker_source.ts","../node_modules/maplibre-gl/src/source/worker.ts","../node_modules/maplibre-gl/src/util/browser.ts","../node_modules/maplibre-gl/src/util/dom.ts","../node_modules/maplibre-gl/src/util/webp_supported.ts","../node_modules/maplibre-gl/src/util/image_request.ts","../node_modules/maplibre-gl/src/util/request_manager.ts","../node_modules/maplibre-gl/node_modules/gl-matrix/esm/mat2.js","../node_modules/maplibre-gl/node_modules/gl-matrix/esm/mat3.js","../node_modules/maplibre-gl/node_modules/gl-matrix/esm/vec3.js","../node_modules/maplibre-gl/node_modules/gl-matrix/esm/vec2.js","../node_modules/maplibre-gl/src/util/style.ts","../node_modules/maplibre-gl/src/style/load_sprite.ts","../node_modules/maplibre-gl/src/render/texture.ts","../node_modules/maplibre-gl/src/style/style_image.ts","../node_modules/maplibre-gl/src/render/image_manager.ts","../node_modules/maplibre-gl/src/style/load_glyph_range.ts","../node_modules/maplibre-gl/node_modules/@mapbox/tiny-sdf/index.js","../node_modules/maplibre-gl/src/render/glyph_manager.ts","../node_modules/maplibre-gl/src/style/light.ts","../node_modules/maplibre-gl/src/style/sky.ts","../node_modules/maplibre-gl/src/render/line_atlas.ts","../node_modules/maplibre-gl/src/util/web_worker.ts","../node_modules/maplibre-gl/src/util/worker_pool.ts","../node_modules/maplibre-gl/src/util/global_worker_pool.ts","../node_modules/maplibre-gl/src/util/dispatcher.ts","../node_modules/maplibre-gl/src/source/query_features.ts","../node_modules/maplibre-gl/src/source/load_tilejson.ts","../node_modules/maplibre-gl/src/geo/lng_lat_bounds.ts","../node_modules/maplibre-gl/src/source/tile_bounds.ts","../node_modules/maplibre-gl/src/source/vector_tile_source.ts","../node_modules/maplibre-gl/src/source/raster_tile_source.ts","../node_modules/maplibre-gl/src/source/raster_dem_tile_source.ts","../node_modules/maplibre-gl/src/source/geojson_source.ts","../node_modules/maplibre-gl/src/data/raster_bounds_attributes.ts","../node_modules/maplibre-gl/src/source/image_source.ts","../node_modules/maplibre-gl/src/source/video_source.ts","../node_modules/maplibre-gl/src/source/canvas_source.ts","../node_modules/maplibre-gl/src/source/source.ts","../node_modules/maplibre-gl/src/data/bucket.ts","../node_modules/maplibre-gl/src/source/rtl_text_plugin_status.ts","../node_modules/maplibre-gl/src/source/rtl_text_plugin_main_thread.ts","../node_modules/maplibre-gl/src/source/tile.ts","../node_modules/maplibre-gl/src/source/tile_cache.ts","../node_modules/maplibre-gl/src/source/source_state.ts","../node_modules/maplibre-gl/src/source/source_cache.ts","../node_modules/maplibre-gl/src/symbol/path_interpolator.ts","../node_modules/maplibre-gl/src/symbol/grid_index.ts","../node_modules/maplibre-gl/src/symbol/projection.ts","../node_modules/maplibre-gl/src/symbol/collision_index.ts","../node_modules/maplibre-gl/src/source/pixels_to_tile_units.ts","../node_modules/maplibre-gl/src/symbol/placement.ts","../node_modules/maplibre-gl/src/geo/projection/projection.ts","../node_modules/maplibre-gl/src/style/pauseable_placement.ts","../node_modules/maplibre-gl/src/symbol/cross_tile_symbol_index.ts","../node_modules/maplibre-gl/src/style/style.ts","../node_modules/maplibre-gl/src/data/pos_attributes.ts","../node_modules/maplibre-gl/src/shaders/background.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/background.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/background_pattern.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/background_pattern.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/circle.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/circle.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/clipping_mask.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/clipping_mask.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/heatmap.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/heatmap.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/heatmap_texture.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/heatmap_texture.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/collision_box.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/collision_box.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/collision_circle.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/collision_circle.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/debug.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/debug.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/fill.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/fill.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/fill_outline.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/fill_outline.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/fill_outline_pattern.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/fill_outline_pattern.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/fill_pattern.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/fill_pattern.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/fill_extrusion.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/fill_extrusion.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/fill_extrusion_pattern.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/fill_extrusion_pattern.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/hillshade_prepare.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/hillshade_prepare.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/hillshade.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/hillshade.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/line.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/line.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/line_gradient.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/line_gradient.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/line_pattern.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/line_pattern.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/line_sdf.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/line_sdf.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/raster.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/raster.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/symbol_icon.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/symbol_icon.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/symbol_sdf.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/symbol_sdf.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/symbol_text_and_icon.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/symbol_text_and_icon.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/terrain_depth.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/terrain_coords.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/terrain.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/terrain_depth.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/terrain_coords.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/terrain.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/sky.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/sky.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/shaders.ts","../node_modules/maplibre-gl/src/shaders/_prelude.fragment.glsl.g.ts","../node_modules/maplibre-gl/src/shaders/_prelude.vertex.glsl.g.ts","../node_modules/maplibre-gl/src/render/vertex_array_object.ts","../node_modules/maplibre-gl/src/render/program/terrain_program.ts","../node_modules/maplibre-gl/src/render/program.ts","../node_modules/maplibre-gl/src/render/program/pattern.ts","../node_modules/maplibre-gl/src/render/program/fill_extrusion_program.ts","../node_modules/maplibre-gl/src/render/program/fill_program.ts","../node_modules/maplibre-gl/src/render/program/circle_program.ts","../node_modules/maplibre-gl/src/render/program/collision_program.ts","../node_modules/maplibre-gl/src/render/program/debug_program.ts","../node_modules/maplibre-gl/src/render/program/clipping_mask_program.ts","../node_modules/maplibre-gl/src/render/program/heatmap_program.ts","../node_modules/maplibre-gl/src/render/program/hillshade_program.ts","../node_modules/maplibre-gl/src/render/program/line_program.ts","../node_modules/maplibre-gl/src/render/program/raster_program.ts","../node_modules/maplibre-gl/src/render/program/symbol_program.ts","../node_modules/maplibre-gl/src/render/program/background_program.ts","../node_modules/maplibre-gl/src/render/program/sky_program.ts","../node_modules/maplibre-gl/src/render/program/program_uniforms.ts","../node_modules/maplibre-gl/src/gl/index_buffer.ts","../node_modules/maplibre-gl/src/gl/vertex_buffer.ts","../node_modules/maplibre-gl/src/gl/webgl2.ts","../node_modules/maplibre-gl/src/gl/value.ts","../node_modules/maplibre-gl/src/gl/framebuffer.ts","../node_modules/maplibre-gl/src/gl/color_mode.ts","../node_modules/maplibre-gl/src/gl/context.ts","../node_modules/maplibre-gl/src/gl/depth_mode.ts","../node_modules/maplibre-gl/src/gl/stencil_mode.ts","../node_modules/maplibre-gl/src/gl/cull_face_mode.ts","../node_modules/maplibre-gl/src/render/draw_collision_debug.ts","../node_modules/maplibre-gl/src/render/draw_symbol.ts","../node_modules/maplibre-gl/src/render/draw_circle.ts","../node_modules/maplibre-gl/src/render/draw_heatmap.ts","../node_modules/maplibre-gl/src/render/draw_line.ts","../node_modules/maplibre-gl/src/render/update_pattern_positions_in_program.ts","../node_modules/maplibre-gl/src/render/draw_fill.ts","../node_modules/maplibre-gl/src/render/draw_fill_extrusion.ts","../node_modules/maplibre-gl/src/render/draw_hillshade.ts","../node_modules/maplibre-gl/src/render/draw_raster.ts","../node_modules/maplibre-gl/src/render/draw_background.ts","../node_modules/maplibre-gl/src/render/draw_debug.ts","../node_modules/maplibre-gl/src/render/draw_custom.ts","../node_modules/maplibre-gl/src/render/draw_terrain.ts","../node_modules/maplibre-gl/src/render/mesh.ts","../node_modules/maplibre-gl/src/render/draw_sky.ts","../node_modules/maplibre-gl/src/render/painter.ts","../node_modules/maplibre-gl/src/util/primitives.ts","../node_modules/maplibre-gl/src/geo/edge_insets.ts","../node_modules/maplibre-gl/src/geo/transform.ts","../node_modules/maplibre-gl/src/util/throttle.ts","../node_modules/maplibre-gl/src/ui/hash.ts","../node_modules/maplibre-gl/src/ui/handler_inertia.ts","../node_modules/maplibre-gl/src/ui/events.ts","../node_modules/maplibre-gl/src/ui/handler/map_event.ts","../node_modules/maplibre-gl/src/ui/handler/transform-provider.ts","../node_modules/maplibre-gl/src/ui/handler/box_zoom.ts","../node_modules/maplibre-gl/src/ui/handler/handler_util.ts","../node_modules/maplibre-gl/src/ui/handler/tap_recognizer.ts","../node_modules/maplibre-gl/src/ui/handler/tap_zoom.ts","../node_modules/maplibre-gl/src/ui/handler/drag_handler.ts","../node_modules/maplibre-gl/src/ui/handler/drag_move_state_manager.ts","../node_modules/maplibre-gl/src/ui/handler/mouse.ts","../node_modules/maplibre-gl/src/ui/handler/touch_pan.ts","../node_modules/maplibre-gl/src/ui/handler/two_fingers_touch.ts","../node_modules/maplibre-gl/src/ui/handler/keyboard.ts","../node_modules/maplibre-gl/src/ui/handler/scroll_zoom.ts","../node_modules/maplibre-gl/src/ui/handler/shim/dblclick_zoom.ts","../node_modules/maplibre-gl/src/ui/handler/click_zoom.ts","../node_modules/maplibre-gl/src/ui/handler/tap_drag_zoom.ts","../node_modules/maplibre-gl/src/ui/handler/shim/drag_pan.ts","../node_modules/maplibre-gl/src/ui/handler/shim/drag_rotate.ts","../node_modules/maplibre-gl/src/ui/handler/shim/two_fingers_touch.ts","../node_modules/maplibre-gl/src/ui/handler/cooperative_gestures.ts","../node_modules/maplibre-gl/src/ui/handler_manager.ts","../node_modules/maplibre-gl/src/ui/camera.ts","../node_modules/maplibre-gl/src/ui/control/attribution_control.ts","../node_modules/maplibre-gl/src/ui/control/logo_control.ts","../node_modules/maplibre-gl/src/util/task_queue.ts","../node_modules/maplibre-gl/src/data/pos3d_attributes.ts","../node_modules/maplibre-gl/src/source/terrain_source_cache.ts","../node_modules/maplibre-gl/src/render/terrain.ts","../node_modules/maplibre-gl/src/gl/render_pool.ts","../node_modules/maplibre-gl/src/render/render_to_texture.ts","../node_modules/maplibre-gl/src/ui/default_locale.ts","../node_modules/maplibre-gl/src/ui/map.ts","../node_modules/maplibre-gl/src/ui/handler/one_finger_touch_drag.ts","../node_modules/maplibre-gl/src/ui/control/navigation_control.ts","../node_modules/maplibre-gl/src/util/geolocation_support.ts","../node_modules/maplibre-gl/src/util/smart_wrap.ts","../node_modules/maplibre-gl/src/ui/anchor.ts","../node_modules/maplibre-gl/src/ui/marker.ts","../node_modules/maplibre-gl/src/ui/control/geolocate_control.ts","../node_modules/maplibre-gl/src/ui/control/scale_control.ts","../node_modules/maplibre-gl/src/ui/control/fullscreen_control.ts","../node_modules/maplibre-gl/src/ui/control/terrain_control.ts","../node_modules/maplibre-gl/src/ui/popup.ts","../node_modules/maplibre-gl/src/index.ts","../node_modules/maplibre-gl/build/rollup/maplibregl.js","../node_modules/tinycolor2/cjs/tinycolor.js","../node_modules/@babel/runtime/helpers/esm/extends.js","../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../node_modules/clsx/dist/clsx.mjs","../node_modules/d3-color/src/define.js","../node_modules/d3-color/src/color.js","../node_modules/d3-interpolate/src/constant.js","../node_modules/d3-interpolate/src/array.js","../node_modules/d3-interpolate/src/date.js","../node_modules/d3-interpolate/src/object.js","../node_modules/d3-interpolate/src/numberArray.js","../node_modules/d3-interpolate/src/value.js","../node_modules/d3-interpolate/src/number.js","../node_modules/d3-interpolate/src/basis.js","../node_modules/d3-interpolate/src/color.js","../node_modules/d3-interpolate/src/rgb.js","../node_modules/d3-interpolate/src/basisClosed.js","../node_modules/d3-interpolate/src/string.js","../webpack/bootstrap","../webpack/runtime/compat get default export","../webpack/runtime/create fake namespace object","../webpack/runtime/define property getters","../webpack/runtime/ensure chunk","../webpack/runtime/get javascript chunk filename","../webpack/runtime/get mini-css chunk filename","../webpack/runtime/global","../webpack/runtime/hasOwnProperty shorthand","../webpack/runtime/load script","../webpack/runtime/make namespace object","../webpack/runtime/node module decorator","../webpack/runtime/publicPath","../webpack/runtime/jsonp chunk loading","../node_modules/react-redux/es/utils/batch.js","../node_modules/react-redux/es/components/Context.js","../node_modules/react-redux/es/hooks/useReduxContext.js","../node_modules/react-redux/es/hooks/useSelector.js","../node_modules/react-redux/es/utils/useSyncExternalStore.js","../node_modules/react-redux/es/utils/Subscription.js","../node_modules/react-redux/es/utils/useIsomorphicLayoutEffect.js","../node_modules/react-redux/es/components/connect.js","../node_modules/react-redux/es/components/Provider.js","../node_modules/react-redux/es/hooks/useStore.js","../node_modules/react-redux/es/hooks/useDispatch.js","../node_modules/react-redux/es/index.js","../node_modules/@mui/private-theming/useTheme/ThemeContext.js","../node_modules/@mui/private-theming/useTheme/useTheme.js","../node_modules/@mui/private-theming/ThemeProvider/nested.js","../node_modules/@mui/private-theming/ThemeProvider/ThemeProvider.js","../node_modules/@mui/system/esm/useThemeWithoutDefault.js","../node_modules/@mui/system/esm/RtlProvider/index.js","../node_modules/@mui/system/esm/ThemeProvider/ThemeProvider.js","../node_modules/@mui/material/styles/ThemeProvider.js","../node_modules/@remix-run/router/history.ts","../node_modules/@remix-run/router/utils.ts","../node_modules/@remix-run/router/router.ts","../node_modules/react-router/lib/context.ts","../node_modules/react-router/lib/hooks.tsx","../node_modules/react-router/lib/deprecations.ts","../node_modules/react-router/lib/components.tsx","../node_modules/react-router-dom/dom.ts","../node_modules/react-router-dom/index.tsx","../node_modules/notistack/node_modules/clsx/dist/clsx.m.js","../node_modules/goober/dist/goober.modern.js","../node_modules/src/SnackbarContext.ts","../node_modules/src/utils/index.ts","../node_modules/src/transitions/Transition/Transition.tsx","../node_modules/src/transitions/useForkRef.ts","../node_modules/src/transitions/getTransitionProps.ts","../node_modules/src/transitions/utils.ts","../node_modules/src/transitions/createTransition.ts","../node_modules/src/transitions/Slide/Slide.tsx","../node_modules/src/utils/defaultIconVariants.tsx","../node_modules/src/SnackbarProvider/merger.ts","../node_modules/src/utils/styles.ts","../node_modules/src/transitions/Collapse/Collapse.tsx","../node_modules/src/SnackbarItem/utils.ts","../node_modules/src/utils/createChainedFunction.ts","../node_modules/src/utils/useEventCallback.ts","../node_modules/src/SnackbarItem/Snackbar.tsx","../node_modules/src/SnackbarContent/SnackbarContent.tsx","../node_modules/src/ui/MaterialDesignContent/MaterialDesignContent.tsx","../node_modules/src/SnackbarProvider/SnackbarProvider.tsx","../node_modules/src/SnackbarItem/SnackbarItem.tsx","../node_modules/src/SnackbarContainer/SnackbarContainer.tsx","../node_modules/src/useSnackbar.ts","../node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","../node_modules/@babel/runtime/helpers/esm/inheritsLoose.js","../node_modules/react-transition-group/esm/TransitionGroupContext.js","../node_modules/react-transition-group/esm/utils/ChildMapping.js","../node_modules/react-transition-group/esm/TransitionGroup.js","../node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../node_modules/@mui/material/ButtonBase/Ripple.js","../node_modules/@mui/material/ButtonBase/touchRippleClasses.js","../node_modules/@mui/material/ButtonBase/TouchRipple.js","../node_modules/@mui/material/ButtonBase/buttonBaseClasses.js","../node_modules/@mui/material/ButtonBase/ButtonBase.js","../node_modules/@mui/material/IconButton/iconButtonClasses.js","../node_modules/@mui/material/IconButton/IconButton.js","../node_modules/@mui/system/esm/useTheme.js","../node_modules/@mui/system/esm/createBox.js","../node_modules/@mui/material/Box/boxClasses.js","../node_modules/@mui/material/Box/Box.js","components/common/Loading.tsx","../node_modules/@mui/material/styles/getOverlayAlpha.js","../node_modules/@mui/material/Paper/paperClasses.js","../node_modules/@mui/material/Paper/Paper.js","../node_modules/@mui/material/AppBar/appBarClasses.js","../node_modules/@mui/material/AppBar/AppBar.js","../node_modules/@mui/material/Toolbar/toolbarClasses.js","../node_modules/@mui/material/Toolbar/Toolbar.js","../node_modules/@mui/material/Typography/typographyClasses.js","../node_modules/@mui/material/Typography/Typography.js","../node_modules/@mui/utils/esm/isHostComponent/isHostComponent.js","../node_modules/@mui/utils/esm/appendOwnerState/appendOwnerState.js","../node_modules/@mui/utils/esm/extractEventHandlers/extractEventHandlers.js","../node_modules/@mui/utils/esm/omitEventHandlers/omitEventHandlers.js","../node_modules/@mui/utils/esm/mergeSlotProps/mergeSlotProps.js","../node_modules/@mui/utils/esm/resolveComponentProps/resolveComponentProps.js","../node_modules/@mui/utils/esm/useSlotProps/useSlotProps.js","../node_modules/@mui/material/List/ListContext.js","../node_modules/@mui/material/List/listClasses.js","../node_modules/@mui/material/List/List.js","../node_modules/@mui/utils/esm/getScrollbarSize/getScrollbarSize.js","../node_modules/@mui/material/utils/getScrollbarSize.js","../node_modules/@mui/material/MenuList/MenuList.js","../node_modules/react-transition-group/esm/config.js","../node_modules/react-transition-group/esm/utils/reflow.js","../node_modules/react-transition-group/esm/Transition.js","../node_modules/@mui/material/styles/useTheme.js","../node_modules/@mui/material/transitions/utils.js","../node_modules/@mui/material/Grow/Grow.js","../node_modules/@mui/material/Unstable_TrapFocus/FocusTrap.js","../node_modules/@mui/material/Portal/Portal.js","../node_modules/@mui/material/Fade/Fade.js","../node_modules/@mui/material/Backdrop/backdropClasses.js","../node_modules/@mui/material/Backdrop/Backdrop.js","../node_modules/@mui/material/Modal/ModalManager.js","../node_modules/@mui/material/Modal/useModal.js","../node_modules/@mui/material/Modal/modalClasses.js","../node_modules/@mui/material/Modal/Modal.js","../node_modules/@mui/material/Popover/popoverClasses.js","../node_modules/@mui/material/Popover/Popover.js","../node_modules/@mui/material/Menu/menuClasses.js","../node_modules/@mui/material/Menu/Menu.js","../node_modules/@mui/material/Divider/dividerClasses.js","../node_modules/@mui/material/ListItemIcon/listItemIconClasses.js","../node_modules/@mui/material/ListItemText/listItemTextClasses.js","../node_modules/@mui/material/MenuItem/menuItemClasses.js","../node_modules/@mui/material/MenuItem/MenuItem.js","../node_modules/immer/src/utils/errors.ts","../node_modules/immer/src/utils/common.ts","../node_modules/immer/src/utils/plugins.ts","../node_modules/immer/src/core/scope.ts","../node_modules/immer/src/core/finalize.ts","../node_modules/immer/src/core/proxy.ts","../node_modules/immer/src/core/immerClass.ts","../node_modules/immer/src/core/current.ts","../node_modules/immer/src/plugins/es5.ts","../node_modules/immer/src/immer.ts","../node_modules/immer/src/utils/env.ts","../node_modules/@babel/runtime/helpers/esm/typeof.js","../node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","../node_modules/@babel/runtime/helpers/esm/toPrimitive.js","../node_modules/@babel/runtime/helpers/esm/defineProperty.js","../node_modules/@babel/runtime/helpers/esm/objectSpread2.js","../node_modules/redux/es/redux.js","../node_modules/redux-thunk/es/index.js","../node_modules/@reduxjs/toolkit/src/devtoolsExtension.ts","../node_modules/@reduxjs/toolkit/src/isPlainObject.ts","../node_modules/@reduxjs/toolkit/src/tsHelpers.ts","../node_modules/@reduxjs/toolkit/src/createAction.ts","../node_modules/@reduxjs/toolkit/src/utils.ts","../node_modules/@reduxjs/toolkit/src/getDefaultMiddleware.ts","../node_modules/@reduxjs/toolkit/src/mapBuilders.ts","../node_modules/@reduxjs/toolkit/src/createSlice.ts","../node_modules/@reduxjs/toolkit/src/createReducer.ts","../node_modules/@reduxjs/toolkit/src/nanoid.ts","../node_modules/@reduxjs/toolkit/src/createAsyncThunk.ts","../node_modules/@reduxjs/toolkit/src/matchers.ts","../node_modules/@reduxjs/toolkit/src/listenerMiddleware/index.ts","../node_modules/@reduxjs/toolkit/src/listenerMiddleware/task.ts","../node_modules/@reduxjs/toolkit/src/autoBatchEnhancer.ts","../node_modules/@reduxjs/toolkit/src/index.ts","utils/auth/AuthUtils.ts","../node_modules/axios/lib/helpers/bind.js","../node_modules/axios/lib/utils.js","../node_modules/axios/lib/core/AxiosError.js","../node_modules/axios/lib/helpers/toFormData.js","../node_modules/axios/lib/helpers/AxiosURLSearchParams.js","../node_modules/axios/lib/helpers/buildURL.js","../node_modules/axios/lib/core/InterceptorManager.js","../node_modules/axios/lib/defaults/transitional.js","../node_modules/axios/lib/platform/browser/index.js","../node_modules/axios/lib/platform/browser/classes/URLSearchParams.js","../node_modules/axios/lib/platform/browser/classes/FormData.js","../node_modules/axios/lib/platform/browser/classes/Blob.js","../node_modules/axios/lib/platform/common/utils.js","../node_modules/axios/lib/platform/index.js","../node_modules/axios/lib/helpers/formDataToJSON.js","../node_modules/axios/lib/defaults/index.js","../node_modules/axios/lib/helpers/toURLEncodedForm.js","../node_modules/axios/lib/helpers/parseHeaders.js","../node_modules/axios/lib/core/AxiosHeaders.js","../node_modules/axios/lib/core/transformData.js","../node_modules/axios/lib/cancel/isCancel.js","../node_modules/axios/lib/cancel/CanceledError.js","../node_modules/axios/lib/core/settle.js","../node_modules/axios/lib/helpers/speedometer.js","../node_modules/axios/lib/helpers/throttle.js","../node_modules/axios/lib/helpers/progressEventReducer.js","../node_modules/axios/lib/helpers/isURLSameOrigin.js","../node_modules/axios/lib/helpers/cookies.js","../node_modules/axios/lib/core/buildFullPath.js","../node_modules/axios/lib/helpers/isAbsoluteURL.js","../node_modules/axios/lib/helpers/combineURLs.js","../node_modules/axios/lib/core/mergeConfig.js","../node_modules/axios/lib/helpers/resolveConfig.js","../node_modules/axios/lib/adapters/xhr.js","../node_modules/axios/lib/helpers/parseProtocol.js","../node_modules/axios/lib/helpers/composeSignals.js","../node_modules/axios/lib/helpers/trackStream.js","../node_modules/axios/lib/adapters/fetch.js","../node_modules/axios/lib/adapters/adapters.js","../node_modules/axios/lib/helpers/null.js","../node_modules/axios/lib/core/dispatchRequest.js","../node_modules/axios/lib/env/data.js","../node_modules/axios/lib/helpers/validator.js","../node_modules/axios/lib/core/Axios.js","../node_modules/axios/lib/cancel/CancelToken.js","../node_modules/axios/lib/helpers/HttpStatusCode.js","../node_modules/axios/lib/axios.js","../node_modules/axios/lib/helpers/spread.js","../node_modules/axios/lib/helpers/isAxiosError.js","const/API.ts","utils/axios.ts","api/auth/Auth.ts","api/users/UsersAdmin.ts","store/slice/User/UserType.ts","store/slice/User/UserActions.ts","api/users/UsersMe.ts","store/slice/User/UserSlice.ts","components/Layout/Profile.tsx","../node_modules/@mui/icons-material/esm/GitHub.js","../node_modules/@mui/icons-material/esm/MenuBook.js","../node_modules/@mui/icons-material/esm/OpenInNew.js","../node_modules/@mui/icons-material/esm/Addchart.js","../node_modules/@popperjs/core/lib/dom-utils/getWindow.js","../node_modules/@popperjs/core/lib/dom-utils/instanceOf.js","../node_modules/@popperjs/core/lib/utils/math.js","../node_modules/@popperjs/core/lib/utils/userAgent.js","../node_modules/@popperjs/core/lib/dom-utils/isLayoutViewport.js","../node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js","../node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js","../node_modules/@popperjs/core/lib/dom-utils/getNodeName.js","../node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js","../node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js","../node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js","../node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js","../node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js","../node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js","../node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js","../node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js","../node_modules/@popperjs/core/lib/dom-utils/getParentNode.js","../node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js","../node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js","../node_modules/@popperjs/core/lib/dom-utils/isTableElement.js","../node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js","../node_modules/@popperjs/core/lib/enums.js","../node_modules/@popperjs/core/lib/utils/orderModifiers.js","../node_modules/@popperjs/core/lib/utils/debounce.js","../node_modules/@popperjs/core/lib/createPopper.js","../node_modules/@popperjs/core/lib/utils/mergeByName.js","../node_modules/@popperjs/core/lib/modifiers/eventListeners.js","../node_modules/@popperjs/core/lib/utils/getBasePlacement.js","../node_modules/@popperjs/core/lib/utils/getVariation.js","../node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.js","../node_modules/@popperjs/core/lib/utils/computeOffsets.js","../node_modules/@popperjs/core/lib/modifiers/computeStyles.js","../node_modules/@popperjs/core/lib/utils/getOppositePlacement.js","../node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.js","../node_modules/@popperjs/core/lib/dom-utils/contains.js","../node_modules/@popperjs/core/lib/utils/rectToClientRect.js","../node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js","../node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js","../node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js","../node_modules/@popperjs/core/lib/utils/mergePaddingObject.js","../node_modules/@popperjs/core/lib/utils/getFreshSideObject.js","../node_modules/@popperjs/core/lib/utils/expandToHashMap.js","../node_modules/@popperjs/core/lib/utils/detectOverflow.js","../node_modules/@popperjs/core/lib/utils/within.js","../node_modules/@popperjs/core/lib/modifiers/hide.js","../node_modules/@popperjs/core/lib/popper.js","../node_modules/@popperjs/core/lib/modifiers/popperOffsets.js","../node_modules/@popperjs/core/lib/modifiers/applyStyles.js","../node_modules/@popperjs/core/lib/modifiers/offset.js","../node_modules/@popperjs/core/lib/modifiers/flip.js","../node_modules/@popperjs/core/lib/utils/computeAutoPlacement.js","../node_modules/@popperjs/core/lib/modifiers/preventOverflow.js","../node_modules/@popperjs/core/lib/utils/getAltAxis.js","../node_modules/@popperjs/core/lib/modifiers/arrow.js","../node_modules/@mui/material/Popper/popperClasses.js","../node_modules/@mui/material/Popper/BasePopper.js","../node_modules/@mui/material/Popper/Popper.js","../node_modules/@mui/material/Tooltip/tooltipClasses.js","../node_modules/@mui/material/Tooltip/Tooltip.js","../node_modules/@mui/material/ListItemIcon/ListItemIcon.js","../node_modules/@mui/material/ListItemText/ListItemText.js","../node_modules/@mui/icons-material/esm/HelpOutline.js","../node_modules/@mui/material/Dialog/dialogClasses.js","../node_modules/@mui/material/Dialog/DialogContext.js","../node_modules/@mui/material/Dialog/Dialog.js","../node_modules/@mui/material/DialogTitle/dialogTitleClasses.js","../node_modules/@mui/material/DialogTitle/DialogTitle.js","../node_modules/@mui/material/DialogContent/dialogContentClasses.js","../node_modules/@mui/material/DialogContent/DialogContent.js","../node_modules/@mui/material/DialogActions/dialogActionsClasses.js","../node_modules/@mui/material/DialogActions/DialogActions.js","../node_modules/@mui/material/Button/buttonClasses.js","../node_modules/@mui/material/ButtonGroup/ButtonGroupContext.js","../node_modules/@mui/material/ButtonGroup/ButtonGroupButtonContext.js","../node_modules/@mui/material/Button/Button.js","../node_modules/@mui/material/Grid/GridContext.js","../node_modules/@mui/material/Grid/gridClasses.js","../node_modules/@mui/material/Grid/Grid.js","components/common/ConfirmDialog.tsx","store/slice/Experiments/ExperimentsType.ts","store/slice/Standalone/StandaloneSeclector.ts","store/slice/Workspace/WorkspaceSelector.ts","store/slice/Experiments/ExperimentsActions.ts","api/experiments/Experiments.ts","store/slice/DisplayData/DisplayDataType.ts","../node_modules/classcat/index.js","../node_modules/zustand/esm/vanilla.mjs","../node_modules/zustand/esm/traditional.mjs","../node_modules/zustand/esm/shallow.mjs","../node_modules/d3-dispatch/src/dispatch.js","../node_modules/d3-selection/src/selector.js","../node_modules/d3-selection/src/selectorAll.js","../node_modules/d3-selection/src/selection/selectAll.js","../node_modules/d3-selection/src/array.js","../node_modules/d3-selection/src/matcher.js","../node_modules/d3-selection/src/selection/selectChild.js","../node_modules/d3-selection/src/selection/selectChildren.js","../node_modules/d3-selection/src/selection/sparse.js","../node_modules/d3-selection/src/selection/enter.js","../node_modules/d3-selection/src/selection/data.js","../node_modules/d3-selection/src/selection/sort.js","../node_modules/d3-selection/src/namespaces.js","../node_modules/d3-selection/src/namespace.js","../node_modules/d3-selection/src/selection/attr.js","../node_modules/d3-selection/src/window.js","../node_modules/d3-selection/src/selection/style.js","../node_modules/d3-selection/src/selection/property.js","../node_modules/d3-selection/src/selection/classed.js","../node_modules/d3-selection/src/selection/text.js","../node_modules/d3-selection/src/selection/html.js","../node_modules/d3-selection/src/selection/raise.js","../node_modules/d3-selection/src/selection/lower.js","../node_modules/d3-selection/src/creator.js","../node_modules/d3-selection/src/selection/insert.js","../node_modules/d3-selection/src/selection/remove.js","../node_modules/d3-selection/src/selection/clone.js","../node_modules/d3-selection/src/selection/on.js","../node_modules/d3-selection/src/selection/dispatch.js","../node_modules/d3-selection/src/selection/index.js","../node_modules/d3-selection/src/selection/select.js","../node_modules/d3-selection/src/selection/filter.js","../node_modules/d3-selection/src/constant.js","../node_modules/d3-selection/src/selection/exit.js","../node_modules/d3-selection/src/selection/join.js","../node_modules/d3-selection/src/selection/merge.js","../node_modules/d3-selection/src/selection/order.js","../node_modules/d3-selection/src/selection/call.js","../node_modules/d3-selection/src/selection/nodes.js","../node_modules/d3-selection/src/selection/node.js","../node_modules/d3-selection/src/selection/size.js","../node_modules/d3-selection/src/selection/empty.js","../node_modules/d3-selection/src/selection/each.js","../node_modules/d3-selection/src/selection/append.js","../node_modules/d3-selection/src/selection/datum.js","../node_modules/d3-selection/src/selection/iterator.js","../node_modules/d3-selection/src/select.js","../node_modules/d3-drag/src/noevent.js","../node_modules/d3-drag/src/nodrag.js","../node_modules/d3-interpolate/src/zoom.js","../node_modules/d3-selection/src/pointer.js","../node_modules/d3-selection/src/sourceEvent.js","../node_modules/d3-transition/node_modules/d3-timer/src/timer.js","../node_modules/d3-transition/node_modules/d3-timer/src/timeout.js","../node_modules/d3-transition/src/transition/schedule.js","../node_modules/d3-transition/src/interrupt.js","../node_modules/d3-interpolate/src/transform/parse.js","../node_modules/d3-interpolate/src/transform/decompose.js","../node_modules/d3-interpolate/src/transform/index.js","../node_modules/d3-transition/src/transition/tween.js","../node_modules/d3-transition/src/transition/interpolate.js","../node_modules/d3-transition/src/transition/attr.js","../node_modules/d3-transition/src/transition/attrTween.js","../node_modules/d3-transition/src/transition/delay.js","../node_modules/d3-transition/src/transition/duration.js","../node_modules/d3-transition/src/transition/selection.js","../node_modules/d3-transition/src/transition/style.js","../node_modules/d3-transition/src/transition/index.js","../node_modules/d3-transition/src/transition/select.js","../node_modules/d3-transition/src/transition/selectAll.js","../node_modules/d3-transition/src/transition/filter.js","../node_modules/d3-transition/src/transition/merge.js","../node_modules/d3-transition/src/transition/transition.js","../node_modules/d3-transition/src/transition/on.js","../node_modules/d3-transition/src/transition/styleTween.js","../node_modules/d3-transition/src/transition/text.js","../node_modules/d3-transition/src/transition/textTween.js","../node_modules/d3-transition/src/transition/remove.js","../node_modules/d3-transition/src/transition/ease.js","../node_modules/d3-transition/src/transition/easeVarying.js","../node_modules/d3-transition/src/transition/end.js","../node_modules/d3-transition/src/selection/transition.js","../node_modules/d3-ease/src/cubic.js","../node_modules/d3-transition/src/selection/index.js","../node_modules/d3-transition/src/selection/interrupt.js","../node_modules/d3-zoom/src/constant.js","../node_modules/d3-zoom/src/event.js","../node_modules/d3-zoom/src/transform.js","../node_modules/d3-zoom/src/noevent.js","../node_modules/d3-zoom/src/zoom.js","../node_modules/d3-drag/src/constant.js","../node_modules/d3-drag/src/event.js","../node_modules/d3-drag/src/drag.js","../node_modules/@reactflow/core/dist/esm/index.mjs","store/slice/FlowElement/FlowElementType.ts","store/slice/FlowElement/FlowElementUtils.ts","api/run/RunUtils.ts","const/flowchart.ts","api/files/Files.ts","store/slice/FilesTree/FilesTreeType.ts","store/slice/FilesTree/FilesTreeAction.ts","store/slice/FileUploader/FileUploaderType.ts","store/slice/FileUploader/FileUploaderActions.ts","api/params/Params.ts","store/slice/FlowElement/FlowElementActions.ts","store/slice/InputNode/InputNodeType.ts","store/slice/InputNode/InputNodeActions.ts","store/slice/Workflow/WorkflowType.ts","store/slice/Workflow/WorkflowActions.ts","api/workflow/Workflow.ts","store/slice/FlowElement/FlowElementSlice.ts","store/slice/Pipeline/PipelineType.ts","store/slice/DisplayData/DisplayDataUtils.ts","store/slice/Pipeline/PipelineUtils.ts","store/slice/Pipeline/PipelineSelectors.ts","store/slice/Pipeline/PipelineActions.ts","api/run/Run.ts","store/slice/DisplayData/DisplayDataActions.ts","api/outputs/Outputs.ts","store/slice/DisplayData/DisplayDataSelectors.ts","store/slice/VisualizeItem/VisualizeItemType.ts","store/slice/VisualizeItem/VisualizeItemUtils.ts","store/slice/VisualizeItem/VisualizeItemSelectors.ts","store/slice/VisualizeItem/VisualizeItemActions.ts","store/slice/VisualizeItem/VisualizeItemSlice.ts","components/Layout/Tooltips.tsx","../node_modules/@mui/material/Tab/tabClasses.js","../node_modules/@mui/material/Tab/Tab.js","../node_modules/@mui/utils/esm/scrollLeft/scrollLeft.js","../node_modules/@mui/material/internal/animate.js","../node_modules/@mui/material/Tabs/ScrollbarSize.js","../node_modules/@mui/material/internal/svg-icons/KeyboardArrowLeft.js","../node_modules/@mui/material/internal/svg-icons/KeyboardArrowRight.js","../node_modules/@mui/material/TabScrollButton/tabScrollButtonClasses.js","../node_modules/@mui/material/TabScrollButton/TabScrollButton.js","../node_modules/@mui/material/Tabs/tabsClasses.js","../node_modules/@mui/material/Tabs/Tabs.js","store/slice/Workspace/WorkspaceType.ts","store/slice/Workspace/WorkspaceActions.ts","api/workspace/index.ts","store/slice/Workspace/WorkspaceSlice.ts","components/Workspace/WorkspaceTabs.tsx","const/Layout.ts","components/Layout/Header.tsx","../node_modules/@mui/material/Slide/Slide.js","../node_modules/@mui/material/Drawer/drawerClasses.js","../node_modules/@mui/material/Drawer/Drawer.js","../node_modules/@mui/material/ListItem/listItemClasses.js","../node_modules/@mui/material/ListItemButton/listItemButtonClasses.js","../node_modules/@mui/material/ListItemSecondaryAction/listItemSecondaryActionClasses.js","../node_modules/@mui/material/ListItemSecondaryAction/ListItemSecondaryAction.js","../node_modules/@mui/material/ListItem/ListItem.js","../node_modules/@mui/material/ListItemButton/ListItemButton.js","@types/index.ts","store/slice/User/UserSelector.ts","components/Layout/LeftMenu.tsx","components/Layout/index.tsx","../node_modules/@mui/material/TextareaAutosize/TextareaAutosize.js","../node_modules/@mui/material/FormControl/formControlState.js","../node_modules/@mui/material/FormControl/FormControlContext.js","../node_modules/@mui/material/FormControl/useFormControl.js","../node_modules/@mui/system/esm/GlobalStyles/GlobalStyles.js","../node_modules/@mui/material/GlobalStyles/GlobalStyles.js","../node_modules/@mui/material/InputBase/utils.js","../node_modules/@mui/material/InputBase/inputBaseClasses.js","../node_modules/@mui/material/InputBase/InputBase.js","../node_modules/@mui/material/Input/inputClasses.js","../node_modules/@mui/material/Input/Input.js","components/common/Input.tsx","components/Account/InputPassword.tsx","const/Auth.ts","components/Account/ChangePasswordModal.tsx","components/common/DeleteConfirmModal.tsx","pages/Account/index.tsx","pages/AccountDelete/index.tsx","../node_modules/@mui/system/esm/colorManipulator.js","../node_modules/@mui/x-data-grid/constants/gridClasses.js","../node_modules/@mui/x-data-grid/components/containers/GridRootStyles.js","../node_modules/@mui/x-data-grid/hooks/utils/useLazyRef.js","../node_modules/@mui/x-data-grid/hooks/utils/useOnMount.js","../node_modules/@mui/x-data-grid/utils/warning.js","../node_modules/@mui/x-data-grid/utils/fastObjectShallowCompare.js","../node_modules/@mui/x-data-grid/hooks/utils/useGridSelector.js","../node_modules/@mui/x-data-grid/hooks/utils/useGridPrivateApiContext.js","../node_modules/@mui/x-data-grid/context/GridRootPropsContext.js","../node_modules/@mui/x-data-grid/hooks/utils/useGridRootProps.js","../node_modules/reselect/es/defaultMemoize.js","../node_modules/reselect/es/index.js","../node_modules/@mui/x-data-grid/utils/createSelector.js","../node_modules/@mui/x-data-grid/hooks/features/density/densitySelector.js","../node_modules/@mui/x-data-grid/hooks/features/columns/gridColumnsSelector.js","../node_modules/@mui/x-data-grid/hooks/features/columnGrouping/gridColumnGroupsSelector.js","../node_modules/@mui/x-data-grid/hooks/features/rows/gridRowsSelector.js","../node_modules/@mui/x-data-grid/hooks/utils/useGridAriaAttributes.js","../node_modules/@mui/x-data-grid/components/containers/GridRoot.js","../node_modules/@mui/x-data-grid/components/GridHeader.js","../node_modules/@mui/system/esm/createStyled.js","../node_modules/@mui/system/esm/styled.js","../node_modules/@mui/x-data-grid/components/containers/GridMainContainer.js","../node_modules/@mui/x-data-grid/hooks/features/sorting/gridSortingSelector.js","../node_modules/@mui/x-data-grid/hooks/features/filter/gridFilterSelector.js","../node_modules/@mui/x-data-grid/hooks/features/focus/gridFocusStateSelector.js","../node_modules/@mui/x-data-grid/hooks/features/columnMenu/columnMenuSelector.js","../node_modules/@mui/x-data-grid/components/base/GridBody.js","../node_modules/@mui/x-data-grid/components/base/GridFooterPlaceholder.js","../node_modules/@mui/x-data-grid/components/GridApiContext.js","../node_modules/@mui/x-data-grid/context/GridContextProvider.js","../node_modules/@mui/x-data-grid/utils/utils.js","../node_modules/@mui/x-data-grid/hooks/utils/useGridApiMethod.js","../node_modules/@mui/x-data-grid/hooks/core/useGridLoggerFactory.js","../node_modules/@mui/x-data-grid/utils/Store.js","../node_modules/@mui/x-data-grid/utils/cleanupTracking/TimerBasedCleanupTracking.js","../node_modules/@mui/x-data-grid/utils/cleanupTracking/FinalizationRegistryBasedCleanupTracking.js","../node_modules/@mui/x-data-grid/hooks/utils/useGridApiEventHandler.js","../node_modules/@mui/x-data-grid/utils/EventManager.js","../node_modules/@mui/x-data-grid/hooks/core/useGridApiInitialization.js","../node_modules/@mui/x-data-grid/hooks/core/useGridLocaleText.js","../node_modules/@mui/x-data-grid/hooks/core/strategyProcessing/useGridStrategyProcessing.js","../node_modules/@mui/x-data-grid/hooks/core/useGridInitialization.js","../node_modules/@mui/x-data-grid/hooks/core/useGridStateInitialization.js","../node_modules/@mui/x-data-grid/hooks/core/pipeProcessing/useGridPipeProcessing.js","../node_modules/@mui/x-data-grid/hooks/utils/useGridInitializeState.js","../node_modules/@mui/x-data-grid/hooks/utils/useGridLogger.js","../node_modules/@mui/x-data-grid/hooks/utils/useGridNativeEventListener.js","../node_modules/@mui/x-data-grid/utils/keyboardUtils.js","../node_modules/@mui/x-data-grid/hooks/utils/useGridApiContext.js","../node_modules/@mui/x-data-grid/components/columnSelection/GridCellCheckboxRenderer.js","../node_modules/@mui/x-data-grid/hooks/features/rowSelection/gridRowSelectionSelector.js","../node_modules/@mui/x-data-grid/hooks/features/pagination/gridPaginationUtils.js","../node_modules/@mui/x-data-grid/hooks/features/pagination/gridPaginationSelector.js","../node_modules/@mui/x-data-grid/components/columnSelection/GridHeaderCheckbox.js","../node_modules/@mui/x-data-grid/components/cell/GridEditInputCell.js","../node_modules/@mui/x-data-grid/hooks/features/sorting/gridSortingUtils.js","../node_modules/@mui/x-data-grid/hooks/utils/useTimeout.js","../node_modules/@mui/x-data-grid/components/panel/filterPanel/GridFilterInputValue.js","../node_modules/@mui/utils/esm/usePreviousProps/usePreviousProps.js","../node_modules/@mui/material/useAutocomplete/useAutocomplete.js","../node_modules/@mui/material/ListSubheader/listSubheaderClasses.js","../node_modules/@mui/material/ListSubheader/ListSubheader.js","../node_modules/@mui/material/internal/svg-icons/Cancel.js","../node_modules/@mui/material/Chip/chipClasses.js","../node_modules/@mui/material/Chip/Chip.js","../node_modules/@mui/material/OutlinedInput/outlinedInputClasses.js","../node_modules/@mui/material/FilledInput/filledInputClasses.js","../node_modules/@mui/material/internal/svg-icons/Close.js","../node_modules/@mui/material/internal/svg-icons/ArrowDropDown.js","../node_modules/@mui/material/Autocomplete/autocompleteClasses.js","../node_modules/@mui/material/Autocomplete/Autocomplete.js","../node_modules/@mui/x-data-grid/components/panel/filterPanel/GridFilterInputMultipleValue.js","../node_modules/@mui/x-data-grid/colDef/utils.js","../node_modules/@mui/x-data-grid/models/gridFilterItem.js","../node_modules/@mui/x-data-grid/hooks/features/filter/gridFilterState.js","../node_modules/@mui/x-data-grid/utils/getPublicApiRef.js","../node_modules/@mui/x-data-grid/hooks/features/filter/gridFilterUtils.js","../node_modules/@mui/x-data-grid/colDef/gridStringOperators.js","../node_modules/@mui/x-data-grid/colDef/gridStringColDef.js","../node_modules/@mui/x-data-grid/hooks/features/rows/gridRowsUtils.js","../node_modules/@mui/x-data-grid/components/cell/GridBooleanCell.js","../node_modules/@mui/x-data-grid/components/cell/GridEditBooleanCell.js","../node_modules/@mui/x-data-grid/components/panel/filterPanel/GridFilterInputBoolean.js","../node_modules/@mui/x-data-grid/colDef/gridBooleanColDef.js","../node_modules/@mui/x-data-grid/colDef/gridBooleanOperators.js","../node_modules/@mui/x-data-grid/colDef/gridCheckboxSelectionColDef.js","../node_modules/@mui/x-data-grid/hooks/features/export/serializers/csvSerializer.js","../node_modules/@mui/x-data-grid/hooks/features/clipboard/useGridClipboard.js","../node_modules/@mui/x-data-grid/hooks/features/columnMenu/useGridColumnMenu.js","../node_modules/@mui/x-data-grid/hooks/utils/useFirstRender.js","../node_modules/@mui/x-data-grid/hooks/core/pipeProcessing/useGridRegisterPipeProcessor.js","../node_modules/@mui/x-data-grid/hooks/core/pipeProcessing/useGridRegisterPipeApplier.js","../node_modules/@mui/x-data-grid/colDef/gridNumericOperators.js","../node_modules/@mui/x-data-grid/colDef/gridNumericColDef.js","../node_modules/@mui/x-data-grid/components/panel/filterPanel/GridFilterInputDate.js","../node_modules/@mui/x-data-grid/colDef/gridDateOperators.js","../node_modules/@mui/x-data-grid/components/cell/GridEditDateCell.js","../node_modules/@mui/x-data-grid/colDef/gridDateColDef.js","../node_modules/@mui/x-data-grid/models/params/gridEditCellParams.js","../node_modules/@mui/x-data-grid/models/gridEditRowModel.js","../node_modules/@mui/x-data-grid/components/panel/filterPanel/filterPanelUtils.js","../node_modules/@mui/x-data-grid/components/cell/GridEditSingleSelectCell.js","../node_modules/@mui/x-data-grid/components/panel/filterPanel/GridFilterInputSingleSelect.js","../node_modules/@mui/x-data-grid/components/panel/filterPanel/GridFilterInputMultipleSingleSelect.js","../node_modules/@mui/x-data-grid/colDef/gridSingleSelectOperators.js","../node_modules/@mui/x-data-grid/colDef/gridSingleSelectColDef.js","../node_modules/@mui/material/ClickAwayListener/ClickAwayListener.js","../node_modules/@mui/x-data-grid/components/menu/GridMenu.js","../node_modules/@mui/x-data-grid/components/cell/GridActionsCell.js","../node_modules/@mui/x-data-grid/colDef/gridActionsColDef.js","../node_modules/@mui/x-data-grid/colDef/gridDefaultColumnTypes.js","../node_modules/@mui/x-data-grid/hooks/features/columns/gridColumnsUtils.js","../node_modules/@mui/x-data-grid/hooks/features/preferencesPanel/gridPreferencePanelsValue.js","../node_modules/@mui/x-data-grid/hooks/features/columns/useGridColumns.js","../node_modules/@mui/x-data-grid/hooks/features/density/useGridDensity.js","../node_modules/@mui/x-data-grid/hooks/features/export/utils.js","../node_modules/@mui/x-data-grid/components/toolbar/GridToolbarExport.js","../node_modules/@mui/x-data-grid/hooks/features/export/useGridCsvExport.js","../node_modules/@mui/x-data-grid/utils/exportAs.js","../node_modules/@mui/x-data-grid/hooks/features/rows/gridRowsMetaSelector.js","../node_modules/@mui/x-data-grid/hooks/features/pagination/useGridPaginationModel.js","../node_modules/@mui/x-data-grid/hooks/features/export/useGridPrintExport.js","../node_modules/@mui/x-data-grid/hooks/core/strategyProcessing/useGridRegisterStrategyProcessor.js","../node_modules/@mui/x-data-grid/hooks/features/filter/useGridFilter.js","../node_modules/@mui/x-data-grid/hooks/utils/useGridVisibleRows.js","../node_modules/@mui/x-data-grid/hooks/features/focus/useGridFocus.js","../node_modules/@mui/x-data-grid/constants/gridDetailPanelToggleField.js","../node_modules/@mui/x-data-grid/hooks/features/headerFiltering/gridHeaderFilteringSelectors.js","../node_modules/@mui/x-data-grid/utils/domUtils.js","../node_modules/@mui/x-data-grid/hooks/features/keyboardNavigation/useGridKeyboardNavigation.js","../node_modules/@mui/x-data-grid/hooks/features/pagination/useGridPagination.js","../node_modules/@mui/x-data-grid/hooks/features/pagination/useGridRowCount.js","../node_modules/@mui/x-data-grid/hooks/features/preferencesPanel/gridPreferencePanelSelector.js","../node_modules/@mui/x-data-grid/hooks/features/preferencesPanel/useGridPreferencesPanel.js","../node_modules/@mui/x-data-grid/hooks/features/editing/gridEditingSelectors.js","../node_modules/@mui/x-data-grid/hooks/features/editing/useGridCellEditing.js","../node_modules/@mui/x-data-grid/models/params/gridRowParams.js","../node_modules/@mui/x-data-grid/hooks/features/editing/useGridRowEditing.js","../node_modules/@mui/x-data-grid/hooks/features/editing/useGridEditing.js","../node_modules/@mui/x-data-grid/hooks/features/rows/useGridRows.js","../node_modules/@mui/x-data-grid/hooks/features/rows/useGridRowsPreProcessors.js","../node_modules/@mui/x-data-grid/hooks/features/rows/useGridParamsApi.js","../node_modules/@mui/x-data-grid/hooks/features/rowSelection/useGridRowSelection.js","../node_modules/@mui/x-data-grid/hooks/features/rowSelection/useGridRowSelectionPreProcessors.js","../node_modules/@mui/x-data-grid/hooks/features/sorting/useGridSorting.js","../node_modules/@mui/x-data-grid/hooks/features/scroll/useGridScroll.js","../node_modules/@mui/system/esm/useThemeProps/useThemeProps.js","../node_modules/@mui/system/esm/useThemeProps/getThemeProps.js","../node_modules/@mui/material/styles/useThemeProps.js","../node_modules/@mui/x-data-grid/constants/localeTextConstants.js","../node_modules/@mui/material/styles/cssUtils.js","../node_modules/@mui/material/Skeleton/skeletonClasses.js","../node_modules/@mui/material/Skeleton/Skeleton.js","../node_modules/@mui/x-data-grid/components/cell/GridSkeletonCell.js","../node_modules/@mui/material/Badge/useBadge.js","../node_modules/@mui/material/Badge/badgeClasses.js","../node_modules/@mui/material/Badge/Badge.js","../node_modules/@mui/x-data-grid/components/columnHeaders/GridIconButtonContainer.js","../node_modules/@mui/x-data-grid/components/GridSelectedRowCount.js","../node_modules/@mui/x-data-grid/components/containers/GridFooterContainer.js","../node_modules/@mui/x-data-grid/components/GridFooter.js","../node_modules/@mui/x-data-grid/components/GridRowCount.js","../node_modules/@mui/x-data-grid/components/panel/GridPreferencesPanel.js","../node_modules/@mui/material/CircularProgress/circularProgressClasses.js","../node_modules/@mui/material/CircularProgress/CircularProgress.js","../node_modules/@mui/x-data-grid/components/containers/GridOverlay.js","../node_modules/@mui/x-data-grid/components/GridLoadingOverlay.js","../node_modules/@mui/x-data-grid/components/GridNoRowsOverlay.js","../node_modules/@mui/material/NativeSelect/nativeSelectClasses.js","../node_modules/@mui/material/NativeSelect/NativeSelectInput.js","../node_modules/@mui/material/Select/selectClasses.js","../node_modules/@mui/material/Select/SelectInput.js","../node_modules/@mui/material/FilledInput/FilledInput.js","../node_modules/@mui/material/OutlinedInput/NotchedOutline.js","../node_modules/@mui/material/OutlinedInput/OutlinedInput.js","../node_modules/@mui/material/Select/Select.js","../node_modules/@mui/material/Table/TableContext.js","../node_modules/@mui/material/Table/Tablelvl2Context.js","../node_modules/@mui/material/TableCell/tableCellClasses.js","../node_modules/@mui/material/TableCell/TableCell.js","../node_modules/@mui/material/internal/svg-icons/LastPage.js","../node_modules/@mui/material/internal/svg-icons/FirstPage.js","../node_modules/@mui/material/TablePagination/TablePaginationActions.js","../node_modules/@mui/material/TablePagination/tablePaginationClasses.js","../node_modules/@mui/material/TablePagination/TablePagination.js","../node_modules/@mui/x-data-grid/components/GridPagination.js","../node_modules/@mui/x-data-grid/components/panel/GridPanelContent.js","../node_modules/@mui/x-data-grid/components/panel/GridPanelFooter.js","../node_modules/@mui/x-data-grid/components/panel/GridPanelWrapper.js","../node_modules/@mui/x-data-grid/components/panel/filterPanel/GridFilterForm.js","../node_modules/@mui/x-data-grid/components/panel/filterPanel/GridFilterPanel.js","../node_modules/@mui/material/Switch/switchClasses.js","../node_modules/@mui/system/esm/Stack/createStack.js","../node_modules/@mui/material/Stack/Stack.js","../node_modules/@mui/material/FormControlLabel/formControlLabelClasses.js","../node_modules/@mui/material/FormControlLabel/FormControlLabel.js","../node_modules/@mui/x-data-grid/components/panel/GridPanelHeader.js","../node_modules/@mui/x-data-grid/constants/envConstants.js","../node_modules/@mui/x-data-grid/components/panel/GridColumnsPanel.js","../node_modules/@mui/x-data-grid/components/panel/GridPanel.js","../node_modules/@mui/x-data-grid/utils/fastMemo.js","../node_modules/@mui/x-data-grid/utils/doesSupportPreventScroll.js","../node_modules/@mui/x-data-grid/components/cell/GridCell.js","../node_modules/@mui/x-data-grid/components/GridRow.js","../node_modules/@mui/x-data-grid/components/columnHeaders/GridColumnHeaderSortIcon.js","../node_modules/@mui/x-data-grid/components/columnHeaders/ColumnHeaderMenuIcon.js","../node_modules/@mui/x-data-grid/components/menu/columnMenu/GridColumnHeaderMenu.js","../node_modules/@mui/x-data-grid/components/columnHeaders/GridColumnHeaderTitle.js","../node_modules/@mui/x-data-grid/components/columnHeaders/GridColumnHeaderSeparator.js","../node_modules/@mui/x-data-grid/components/columnHeaders/GridGenericColumnHeaderItem.js","../node_modules/@mui/x-data-grid/components/columnHeaders/GridColumnHeaderItem.js","../node_modules/@mui/x-data-grid/hooks/features/virtualization/gridVirtualizationSelectors.js","../node_modules/@mui/x-data-grid/hooks/features/virtualization/useGridVirtualScroller.js","../node_modules/@mui/x-data-grid/components/columnHeaders/GridColumnGroupHeader.js","../node_modules/@mui/x-data-grid/hooks/features/columnHeaders/useGridColumnHeaders.js","../node_modules/@mui/x-data-grid/components/columnHeaders/GridBaseColumnHeaders.js","../node_modules/@mui/x-data-grid/components/columnHeaders/GridColumnHeadersInner.js","../node_modules/@mui/x-data-grid/components/GridColumnHeaders.js","../node_modules/@mui/material/Divider/Divider.js","../node_modules/@mui/x-data-grid/hooks/features/columnMenu/useGridColumnMenuSlots.js","../node_modules/@mui/x-data-grid/components/menu/columnMenu/GridColumnMenuContainer.js","../node_modules/@mui/x-data-grid/components/menu/columnMenu/menuItems/GridColumnMenuHideItem.js","../node_modules/@mui/x-data-grid/components/menu/columnMenu/menuItems/GridColumnMenuManageItem.js","../node_modules/@mui/x-data-grid/components/menu/columnMenu/GridColumnMenu.js","../node_modules/@mui/x-data-grid/components/menu/columnMenu/menuItems/GridColumnMenuSortItem.js","../node_modules/@mui/x-data-grid/components/menu/columnMenu/menuItems/GridColumnMenuFilterItem.js","../node_modules/@mui/x-data-grid/components/menu/columnMenu/menuItems/GridColumnMenuColumnsItem.js","../node_modules/@mui/x-data-grid/components/GridNoResultsOverlay.js","../node_modules/@mui/material/internal/switchBaseClasses.js","../node_modules/@mui/material/internal/SwitchBase.js","../node_modules/@mui/material/internal/svg-icons/CheckBoxOutlineBlank.js","../node_modules/@mui/material/internal/svg-icons/CheckBox.js","../node_modules/@mui/material/internal/svg-icons/IndeterminateCheckBox.js","../node_modules/@mui/material/Checkbox/checkboxClasses.js","../node_modules/@mui/material/Checkbox/Checkbox.js","../node_modules/@mui/material/FormLabel/formLabelClasses.js","../node_modules/@mui/material/FormLabel/FormLabel.js","../node_modules/@mui/material/InputLabel/inputLabelClasses.js","../node_modules/@mui/material/InputLabel/InputLabel.js","../node_modules/@mui/material/FormControl/formControlClasses.js","../node_modules/@mui/material/FormControl/FormControl.js","../node_modules/@mui/material/FormHelperText/formHelperTextClasses.js","../node_modules/@mui/material/FormHelperText/FormHelperText.js","../node_modules/@mui/material/TextField/textFieldClasses.js","../node_modules/@mui/material/TextField/TextField.js","../node_modules/@mui/material/Switch/Switch.js","../node_modules/@mui/material/InputAdornment/inputAdornmentClasses.js","../node_modules/@mui/material/InputAdornment/InputAdornment.js","../node_modules/@mui/x-data-grid/material/icons/GridColumnUnsortedIcon.js","../node_modules/@mui/x-data-grid/material/icons/index.js","../node_modules/@mui/x-data-grid/material/components/MUISelectOption.js","../node_modules/@mui/x-data-grid/material/index.js","../node_modules/@mui/x-data-grid/constants/defaultGridSlotsComponents.js","../node_modules/@mui/x-data-grid/components/columnHeaders/GridColumnHeaderFilterIconButton.js","../node_modules/@mui/x-data-grid/internals/utils/slotsMigration.js","../node_modules/@mui/x-data-grid/internals/utils/useProps.js","../node_modules/@mui/x-data-grid/DataGrid/useDataGridProps.js","../node_modules/@mui/x-data-grid/internals/utils/computeSlots.js","../node_modules/@mui/x-data-grid/hooks/features/rows/useGridRowsMeta.js","../node_modules/@mui/x-data-grid/models/gridColumnGrouping.js","../node_modules/@mui/x-data-grid/hooks/features/columnGrouping/gridColumnGroupsUtils.js","../node_modules/@mui/x-data-grid/hooks/features/columnGrouping/useGridColumnGrouping.js","../node_modules/@mui/x-data-grid/hooks/features/virtualization/useGridVirtualization.js","../node_modules/@mui/x-data-grid/DataGrid/useDataGridComponent.js","../node_modules/@mui/x-data-grid/hooks/features/columns/useGridColumnSpanning.js","../node_modules/@mui/x-data-grid/hooks/features/dimensions/useGridDimensions.js","../node_modules/@mui/x-data-grid/hooks/features/events/useGridEvents.js","../node_modules/@mui/x-data-grid/hooks/features/statePersistence/useGridStatePersistence.js","../node_modules/@mui/x-data-grid/components/virtualization/GridVirtualScroller.js","../node_modules/@mui/x-data-grid/components/virtualization/GridVirtualScrollerContent.js","../node_modules/@mui/x-data-grid/components/virtualization/GridVirtualScrollerRenderZone.js","../node_modules/@mui/x-data-grid/components/base/GridOverlays.js","../node_modules/@mui/x-data-grid/components/DataGridVirtualScroller.js","../node_modules/@mui/x-data-grid/DataGrid/DataGrid.js","../node_modules/@mui/utils/esm/chainPropTypes/chainPropTypes.js","components/common/InputError.tsx","../node_modules/@mui/material/NativeSelect/NativeSelect.js","../node_modules/@mui/material/Pagination/paginationClasses.js","../node_modules/@mui/material/usePagination/usePagination.js","../node_modules/@mui/material/PaginationItem/paginationItemClasses.js","../node_modules/@mui/material/internal/svg-icons/NavigateBefore.js","../node_modules/@mui/material/internal/svg-icons/NavigateNext.js","../node_modules/@mui/material/PaginationItem/PaginationItem.js","../node_modules/@mui/material/Pagination/Pagination.js","components/common/PaginationCustom.tsx","components/common/SelectError.tsx","pages/AccountManager/index.tsx","pages/Dashboard/index.tsx","pages/Login/index.tsx","../node_modules/@mui/material/Link/linkClasses.js","../node_modules/@mui/material/Link/getTextDecoration.js","../node_modules/@mui/material/Link/Link.js","pages/ResetPassword/index.tsx","components/Workspace/PopupShare.tsx","store/slice/Workspace/WorkspaceUtils.ts","pages/Workspace/index.tsx","../node_modules/@mui/material/utils/useSlot.js","../node_modules/@mui/material/Alert/alertClasses.js","../node_modules/@mui/material/internal/svg-icons/SuccessOutlined.js","../node_modules/@mui/material/internal/svg-icons/ReportProblemOutlined.js","../node_modules/@mui/material/internal/svg-icons/ErrorOutline.js","../node_modules/@mui/material/internal/svg-icons/InfoOutlined.js","../node_modules/@mui/material/Alert/Alert.js","../node_modules/@mui/material/AlertTitle/alertTitleClasses.js","../node_modules/@mui/material/AlertTitle/AlertTitle.js","../node_modules/@mui/material/Table/tableClasses.js","../node_modules/@mui/material/Table/Table.js","../node_modules/@mui/material/TableBody/tableBodyClasses.js","../node_modules/@mui/material/TableBody/TableBody.js","../node_modules/@mui/material/TableContainer/tableContainerClasses.js","../node_modules/@mui/material/TableContainer/TableContainer.js","../node_modules/@mui/material/TableHead/tableHeadClasses.js","../node_modules/@mui/material/TableHead/TableHead.js","../node_modules/@mui/material/TableRow/tableRowClasses.js","../node_modules/@mui/material/TableRow/TableRow.js","../node_modules/@mui/material/internal/svg-icons/ArrowDownward.js","../node_modules/@mui/material/TableSortLabel/tableSortLabelClasses.js","../node_modules/@mui/material/TableSortLabel/TableSortLabel.js","store/slice/Experiments/ExperimentsSelectors.ts","store/slice/Experiments/ExperimentsUtils.ts","store/slice/Pipeline/PipelineSlice.ts","components/Workspace/Experiment/Button/DeleteButton.tsx","components/Workspace/Experiment/Button/DownloadButton.tsx","components/Workspace/Experiment/Button/ReproduceButton.tsx","../node_modules/@mui/material/Collapse/collapseClasses.js","../node_modules/@mui/material/Collapse/Collapse.js","components/Workspace/Experiment/ExperimentStatusIcon.tsx","utils/EqualityUtils.ts","components/Workspace/Experiment/CollapsibleTable.tsx","components/Workspace/Experiment/ExperimentTable.tsx","components/utils/LocalStorageUtil.ts","store/slice/FlowElement/FlowElementSelectors.ts","components/Workspace/Experiment/Experiment.tsx","../node_modules/@react-dnd/invariant/src/index.ts","../node_modules/dnd-core/src/utils/js_utils.ts","../node_modules/dnd-core/src/actions/dragDrop/types.ts","../node_modules/dnd-core/src/actions/dragDrop/local/setClientOffset.ts","../node_modules/dnd-core/src/actions/dragDrop/beginDrag.ts","../node_modules/dnd-core/src/actions/dragDrop/drop.ts","../node_modules/dnd-core/src/actions/dragDrop/endDrag.ts","../node_modules/dnd-core/src/utils/matchesType.ts","../node_modules/dnd-core/src/actions/dragDrop/hover.ts","../node_modules/dnd-core/src/actions/dragDrop/publishDragSource.ts","../node_modules/dnd-core/src/classes/DragDropManagerImpl.ts","../node_modules/dnd-core/src/actions/dragDrop/index.ts","../node_modules/dnd-core/src/utils/coords.ts","../node_modules/dnd-core/src/utils/dirtiness.ts","../node_modules/dnd-core/src/classes/DragDropMonitorImpl.ts","../node_modules/@react-dnd/asap/src/makeRequestCall.ts","../node_modules/@react-dnd/asap/src/RawTask.ts","../node_modules/@react-dnd/asap/src/asap.ts","../node_modules/@react-dnd/asap/src/AsapQueue.ts","../node_modules/@react-dnd/asap/src/TaskFactory.ts","../node_modules/dnd-core/src/actions/registry.ts","../node_modules/dnd-core/src/contracts.ts","../node_modules/dnd-core/src/interfaces.ts","../node_modules/dnd-core/src/utils/getNextUniqueId.ts","../node_modules/dnd-core/src/classes/HandlerRegistryImpl.ts","../node_modules/dnd-core/src/utils/equality.ts","../node_modules/dnd-core/src/reducers/dirtyHandlerIds.ts","../node_modules/dnd-core/src/reducers/dragOffset.ts","../node_modules/dnd-core/src/reducers/dragOperation.ts","../node_modules/dnd-core/src/reducers/refCount.ts","../node_modules/dnd-core/src/reducers/stateId.ts","../node_modules/dnd-core/src/reducers/index.ts","../node_modules/dnd-core/src/createDragDropManager.ts","../node_modules/react-dnd/src/core/DndContext.ts","../node_modules/react-dnd/src/core/DndProvider.tsx","../node_modules/react-dnd-html5-backend/src/utils/js_utils.ts","../node_modules/react-dnd-html5-backend/src/EnterLeaveCounter.ts","../node_modules/react-dnd-html5-backend/src/NativeDragSources/NativeDragSource.ts","../node_modules/react-dnd-html5-backend/src/NativeTypes.ts","../node_modules/react-dnd-html5-backend/src/NativeDragSources/getDataFromDataTransfer.ts","../node_modules/react-dnd-html5-backend/src/NativeDragSources/nativeTypesConfig.ts","../node_modules/react-dnd-html5-backend/src/NativeDragSources/index.ts","../node_modules/react-dnd-html5-backend/src/BrowserDetector.ts","../node_modules/react-dnd-html5-backend/src/MonotonicInterpolant.ts","../node_modules/react-dnd-html5-backend/src/OffsetUtils.ts","../node_modules/react-dnd-html5-backend/src/OptionsReader.ts","../node_modules/react-dnd-html5-backend/src/HTML5BackendImpl.ts","../node_modules/react-dnd-html5-backend/src/index.ts","../node_modules/@mui/icons-material/esm/InsertDriveFileOutlined.js","components/common/ParamSection.tsx","components/common/CurrentPipelineInfo.tsx","components/Workspace/Visualize/DataContext.tsx","../node_modules/@mui/material/LinearProgress/linearProgressClasses.js","../node_modules/@mui/material/LinearProgress/LinearProgress.js","components/Workspace/Visualize/Plot/BarPlot.tsx","components/Workspace/Visualize/Plot/CsvPlot.tsx","components/Workspace/Visualize/Plot/HeatMapPlot.tsx","components/Workspace/Visualize/Plot/HistogramPlot.tsx","components/Workspace/Visualize/Plot/HTMLPlot.tsx","../node_modules/@mui/utils/esm/visuallyHidden/visuallyHidden.js","../node_modules/@mui/material/utils/areArraysEqual.js","../node_modules/@mui/material/Slider/useSlider.js","../node_modules/@mui/material/utils/shouldSpreadAdditionalProps.js","../node_modules/@mui/material/Slider/sliderClasses.js","../node_modules/@mui/material/Slider/Slider.js","../node_modules/@mui/material/Slider/SliderValueLabel.js","components/Workspace/Visualize/Plot/ImagePlot.tsx","components/Workspace/Visualize/Plot/LinePlot.tsx","components/Workspace/Visualize/Plot/PiePlot.tsx","components/Workspace/Visualize/Plot/PolarPlot.tsx","components/Workspace/Visualize/Plot/RoiPlot.tsx","components/Workspace/Visualize/Plot/ScatterPlot.tsx","components/Workspace/Visualize/Plot/TimeSeriesPlot.tsx","components/Workspace/Visualize/DisplayDataItem.tsx","utils/param/ParamUtils.ts","store/slice/AlgorithmNode/AlgorithmNodeSelectors.ts","components/Workspace/FlowChart/Dialog/AlgorithmOutputDialog.tsx","components/Workspace/FlowChart/Dialog/ClearWorkflowIdDialog.tsx","components/Workspace/FlowChart/Dialog/DialogContext.tsx","../node_modules/@mui/x-tree-view/internals/TreeViewProvider/DescendantProvider.js","../node_modules/@mui/x-tree-view/internals/TreeViewProvider/TreeViewContext.js","../node_modules/@mui/x-tree-view/internals/TreeViewProvider/useTreeViewContext.js","../node_modules/@mui/x-tree-view/TreeItem/TreeItemContent.js","../node_modules/@mui/x-tree-view/TreeItem/useTreeItem.js","../node_modules/@mui/x-tree-view/TreeItem/treeItemClasses.js","../node_modules/@mui/x-tree-view/TreeItem/TreeItem.js","../node_modules/@mui/x-tree-view/node_modules/@mui/base/node_modules/@mui/utils/esm/composeClasses/composeClasses.js","../node_modules/@mui/x-tree-view/node_modules/@mui/base/node_modules/@mui/utils/esm/isHostComponent/isHostComponent.js","../node_modules/@mui/x-tree-view/node_modules/@mui/base/node_modules/@mui/utils/esm/appendOwnerState/appendOwnerState.js","../node_modules/@mui/x-tree-view/node_modules/@mui/base/node_modules/@mui/utils/esm/extractEventHandlers/extractEventHandlers.js","../node_modules/@mui/x-tree-view/node_modules/@mui/base/node_modules/@mui/utils/esm/omitEventHandlers/omitEventHandlers.js","../node_modules/@mui/x-tree-view/node_modules/@mui/base/node_modules/@mui/utils/esm/mergeSlotProps/mergeSlotProps.js","../node_modules/@mui/x-tree-view/node_modules/@mui/base/node_modules/@mui/utils/esm/resolveComponentProps/resolveComponentProps.js","../node_modules/@mui/x-tree-view/node_modules/@mui/base/node_modules/@mui/utils/esm/useSlotProps/useSlotProps.js","../node_modules/@mui/x-tree-view/node_modules/@mui/base/node_modules/@mui/utils/esm/useForkRef/useForkRef.js","../node_modules/@mui/x-tree-view/node_modules/@mui/base/node_modules/@mui/utils/esm/setRef/setRef.js","../node_modules/@mui/x-tree-view/TreeView/treeViewClasses.js","../node_modules/@mui/x-tree-view/internals/utils/EventManager.js","../node_modules/@mui/x-tree-view/internals/useTreeView/useTreeView.utils.js","../node_modules/@mui/x-tree-view/internals/corePlugins/corePlugins.js","../node_modules/@mui/x-tree-view/internals/corePlugins/useTreeViewInstanceEvents/useTreeViewInstanceEvents.js","../node_modules/@mui/x-tree-view/internals/useTreeView/useTreeView.js","../node_modules/@mui/x-tree-view/internals/useTreeView/useTreeViewModels.js","../node_modules/@mui/x-tree-view/internals/TreeViewProvider/TreeViewProvider.js","../node_modules/@mui/x-tree-view/internals/utils/publishTreeViewEvent.js","../node_modules/@mui/x-tree-view/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.js","../node_modules/@mui/x-tree-view/internals/plugins/useTreeViewSelection/useTreeViewSelection.utils.js","../node_modules/@mui/x-tree-view/internals/plugins/useTreeViewSelection/useTreeViewSelection.js","../node_modules/@mui/x-tree-view/internals/utils/cleanupTracking/TimerBasedCleanupTracking.js","../node_modules/@mui/x-tree-view/internals/utils/cleanupTracking/FinalizationRegistryBasedCleanupTracking.js","../node_modules/@mui/x-tree-view/internals/hooks/useInstanceEventHandler.js","../node_modules/@mui/x-tree-view/internals/plugins/useTreeViewFocus/useTreeViewFocus.js","../node_modules/@mui/x-tree-view/internals/plugins/useTreeViewKeyboardNavigation/useTreeViewKeyboardNavigation.js","../node_modules/@mui/x-tree-view/internals/plugins/defaultPlugins.js","../node_modules/@mui/x-tree-view/internals/plugins/useTreeViewNodes/useTreeViewNodes.js","../node_modules/@mui/x-tree-view/internals/plugins/useTreeViewContextValueBuilder/useTreeViewContextValueBuilder.js","../node_modules/@mui/x-tree-view/TreeView/TreeView.js","store/slice/FilesTree/FilesTreeSelectors.ts","store/slice/FilesTree/FilesTreeUtils.ts","components/Workspace/FlowChart/Dialog/FileSelectDialog.tsx","../node_modules/react-dnd/src/hooks/useIsomorphicLayoutEffect.ts","../node_modules/react-dnd/src/hooks/useMonitorOutput.ts","../node_modules/react-dnd/src/hooks/useCollector.ts","../node_modules/react-dnd/src/hooks/useCollectedProps.ts","../node_modules/react-dnd/src/hooks/useOptionalFactory.ts","../node_modules/react-dnd/src/hooks/useDrop/connectors.ts","../node_modules/@react-dnd/shallowequal/src/index.ts","../node_modules/react-dnd/src/internals/isRef.ts","../node_modules/react-dnd/src/internals/wrapConnectorHooks.ts","../node_modules/react-dnd/src/internals/TargetConnector.ts","../node_modules/react-dnd/src/hooks/useDragDropManager.ts","../node_modules/react-dnd/src/internals/DropTargetMonitorImpl.ts","../node_modules/react-dnd/src/hooks/useDrop/DropTargetImpl.ts","../node_modules/react-dnd/src/hooks/useDrop/useRegisteredDropTarget.ts","../node_modules/react-dnd/src/hooks/useDrop/useDropTarget.ts","../node_modules/react-dnd/src/hooks/useDrop/useAccept.ts","../node_modules/react-dnd/src/internals/registration.ts","../node_modules/react-dnd/src/hooks/useDrop/useDrop.ts","../node_modules/react-dnd/src/hooks/useDrop/useDropTargetMonitor.ts","../node_modules/react-dnd/src/hooks/useDrop/useDropTargetConnector.ts","../node_modules/@reactflow/controls/dist/esm/index.mjs","components/Workspace/FlowChart/DnDItemType.ts","../node_modules/@mui/material/ButtonGroup/buttonGroupClasses.js","../node_modules/@mui/material/ButtonGroup/ButtonGroup.js","../node_modules/@mui/utils/esm/getValidReactChildren/getValidReactChildren.js","components/Workspace/FlowChart/FlowChartNode/FlowChartUtils.ts","components/Workspace/FlowChart/FlowChartNode/HandleColorHook.ts","store/slice/HandleTypeColor/HandleTypeColorSelectors.ts","components/Workspace/FlowChart/FlowChartNode/NodeContainer.tsx","store/slice/AlgorithmList/AlgorithmListUtils.ts","store/slice/AlgorithmList/AlgorithmListSelectors.ts","store/slice/RightDrawer/RightDrawerSlice.ts","components/Workspace/FlowChart/FlowChartNode/AlgorithmNode.tsx","store/slice/InputNode/InputNodeUtils.ts","store/slice/InputNode/InputNodeSelectors.ts","store/slice/InputNode/InputNodeSlice.ts","components/Workspace/FlowChart/FlowChartNode/CsvFileNode.tsx","components/Workspace/FlowChart/FlowChartNode/LinerProgressWithLabel.tsx","store/slice/FileUploader/FileUploaderInitlalState.ts","store/slice/FileUploader/FileUploaderSelectors.ts","store/slice/FileUploader/FileUploaderHook.ts","components/Workspace/FlowChart/FlowChartNode/FileSelect.tsx","components/Workspace/FlowChart/FlowChartNode/BehaviorFileNode.tsx","components/Workspace/FlowChart/FlowChartNode/FluoFileNode.tsx","store/slice/HDF5/HDF5Type.ts","store/slice/HDF5/HDF5Action.ts","api/hdf5/HDF5.ts","store/slice/HDF5/HDF5Selectors.ts","components/Workspace/FlowChart/FlowChartNode/HDF5FileNode.tsx","components/Workspace/FlowChart/FlowChartNode/ImageFileNode.tsx","store/slice/Matlab/MatlabAction.ts","api/matlab/Matlab.ts","store/slice/Matlab/MatlabSelectors.ts","components/Workspace/FlowChart/FlowChartNode/MatlabFileNode.tsx","components/Workspace/FlowChart/FlowChartNode/MicroscopeFileNode.tsx","components/Workspace/FlowChart/FlowChartNode/ReactFlowNodeTypesConst.ts","components/Workspace/FlowChart/CustomEdge.tsx","../node_modules/@mui/icons-material/esm/AddToPhotos.js","components/Workspace/FlowChart/Buttons/CreateWorkflow.tsx","../node_modules/@mui/icons-material/esm/UploadFile.js","components/Workspace/FlowChart/Buttons/ImportWorkflowConfig.tsx","components/Workspace/FlowChart/Buttons/NWB.tsx","../node_modules/@mui/icons-material/esm/PlayArrow.js","components/Workspace/FlowChart/Buttons/RunButtons.tsx","components/Workspace/FlowChart/Buttons/Snakemake.tsx","components/Workspace/ToolBar.tsx","components/Workspace/FlowChart/ReactFlowComponent.tsx","../node_modules/@mui/material/AccordionDetails/accordionDetailsClasses.js","../node_modules/@mui/material/AccordionDetails/AccordionDetails.js","../node_modules/@mui/material/Accordion/AccordionContext.js","../node_modules/@mui/material/AccordionSummary/accordionSummaryClasses.js","../node_modules/@mui/material/AccordionSummary/AccordionSummary.js","../node_modules/@mui/material/Accordion/accordionClasses.js","../node_modules/@mui/material/Accordion/Accordion.js","components/common/Accordion.tsx","components/common/ParamSwitch.tsx","components/common/ParamTextField.tsx","components/common/ParamFormItemCreator.tsx","store/slice/NWB/NWBType.ts","store/slice/NWB/NWBAction.ts","api/nwb/NWB.ts","store/slice/NWB/NWBSelectors.ts","store/slice/NWB/NWBSlice.ts","components/Workspace/FlowChart/RightDrawer/NWBSettingContents.tsx","store/slice/AlgorithmNode/AlgorithmNodeType.ts","store/slice/AlgorithmNode/AlgorithmNodeActions.ts","store/slice/AlgorithmNode/AlgorithmNodeSlice.ts","components/Workspace/FlowChart/RightDrawer/AlgorithmParamForm.tsx","store/slice/RightDrawer/RightDrawerSelectors.ts","components/Workspace/FlowChart/RightDrawer/ParamFormContents.tsx","store/slice/Snakemake/SnakemakeType.ts","store/slice/Snakemake/SnakemakeAction.ts","api/snakemake/Snakemake.ts","store/slice/Snakemake/SnakemakeSelectors.ts","store/slice/Snakemake/SnakemakeSlice.ts","components/Workspace/FlowChart/RightDrawer/SnakemakeSettingContents.tsx","components/Workspace/FlowChart/RightDrawer/index.tsx","../node_modules/react-dnd/src/hooks/useDrag/connectors.ts","../node_modules/react-dnd/src/internals/SourceConnector.ts","../node_modules/react-dnd/src/internals/DragSourceMonitorImpl.ts","../node_modules/react-dnd/src/hooks/useDrag/DragSourceImpl.ts","../node_modules/react-dnd/src/hooks/useDrag/useRegisteredDragSource.ts","../node_modules/react-dnd/src/hooks/useDrag/useDragSource.ts","../node_modules/react-dnd/src/hooks/useDrag/useDragType.ts","../node_modules/react-dnd/src/hooks/useDrag/useDrag.ts","../node_modules/react-dnd/src/hooks/useDrag/useDragSourceMonitor.ts","../node_modules/react-dnd/src/hooks/useDrag/useDragSourceConnector.ts","store/slice/AlgorithmList/AlgorithmListType.ts","store/slice/AlgorithmList/AlgorithmListActions.ts","api/algolist/AlgoList.ts","utils/nanoid/NanoIdUtils.ts","../node_modules/nanoid/non-secure/index.js","components/Workspace/FlowChart/TreeView.tsx","components/Workspace/PopupInputUrl.tsx","components/Workspace/FlowChart/FlowChart.tsx","../node_modules/@mui/icons-material/esm/Numbers.js","../node_modules/@mui/icons-material/esm/Close.js","components/utils/MouseDragUtil.ts","components/Workspace/Visualize/FilePathSelect.tsx","components/Workspace/Visualize/VisualizeItem.tsx","components/Workspace/Visualize/VisualizeItemAddButton.tsx","components/Workspace/Visualize/FlexItemList.tsx","components/Workspace/Visualize/Editor/CsvItemEditor.tsx","../node_modules/react-color/es/helpers/checkboard.js","../node_modules/react-color/es/components/common/Checkboard.js","../node_modules/react-color/es/components/common/Alpha.js","../node_modules/react-color/es/helpers/alpha.js","../node_modules/react-color/es/components/common/EditableInput.js","../node_modules/react-color/es/helpers/hue.js","../node_modules/react-color/es/components/common/Hue.js","../node_modules/lodash-es/_listCacheClear.js","../node_modules/lodash-es/eq.js","../node_modules/lodash-es/_assocIndexOf.js","../node_modules/lodash-es/_listCacheDelete.js","../node_modules/lodash-es/_listCacheGet.js","../node_modules/lodash-es/_listCacheHas.js","../node_modules/lodash-es/_listCacheSet.js","../node_modules/lodash-es/_ListCache.js","../node_modules/lodash-es/_stackClear.js","../node_modules/lodash-es/_stackDelete.js","../node_modules/lodash-es/_stackGet.js","../node_modules/lodash-es/_stackHas.js","../node_modules/lodash-es/_freeGlobal.js","../node_modules/lodash-es/_root.js","../node_modules/lodash-es/_Symbol.js","../node_modules/lodash-es/_getRawTag.js","../node_modules/lodash-es/_objectToString.js","../node_modules/lodash-es/_baseGetTag.js","../node_modules/lodash-es/isObject.js","../node_modules/lodash-es/isFunction.js","../node_modules/lodash-es/_coreJsData.js","../node_modules/lodash-es/_isMasked.js","../node_modules/lodash-es/_toSource.js","../node_modules/lodash-es/_baseIsNative.js","../node_modules/lodash-es/_getValue.js","../node_modules/lodash-es/_getNative.js","../node_modules/lodash-es/_Map.js","../node_modules/lodash-es/_nativeCreate.js","../node_modules/lodash-es/_hashClear.js","../node_modules/lodash-es/_hashDelete.js","../node_modules/lodash-es/_hashGet.js","../node_modules/lodash-es/_hashHas.js","../node_modules/lodash-es/_hashSet.js","../node_modules/lodash-es/_Hash.js","../node_modules/lodash-es/_mapCacheClear.js","../node_modules/lodash-es/_isKeyable.js","../node_modules/lodash-es/_getMapData.js","../node_modules/lodash-es/_mapCacheDelete.js","../node_modules/lodash-es/_mapCacheGet.js","../node_modules/lodash-es/_mapCacheHas.js","../node_modules/lodash-es/_mapCacheSet.js","../node_modules/lodash-es/_MapCache.js","../node_modules/lodash-es/_stackSet.js","../node_modules/lodash-es/_Stack.js","../node_modules/lodash-es/_defineProperty.js","../node_modules/lodash-es/_baseAssignValue.js","../node_modules/lodash-es/_assignMergeValue.js","../node_modules/lodash-es/_baseFor.js","../node_modules/lodash-es/_createBaseFor.js","../node_modules/lodash-es/_cloneBuffer.js","../node_modules/lodash-es/_Uint8Array.js","../node_modules/lodash-es/_cloneArrayBuffer.js","../node_modules/lodash-es/_cloneTypedArray.js","../node_modules/lodash-es/_copyArray.js","../node_modules/lodash-es/_baseCreate.js","../node_modules/lodash-es/_overArg.js","../node_modules/lodash-es/_getPrototype.js","../node_modules/lodash-es/_isPrototype.js","../node_modules/lodash-es/_initCloneObject.js","../node_modules/lodash-es/isObjectLike.js","../node_modules/lodash-es/_baseIsArguments.js","../node_modules/lodash-es/isArguments.js","../node_modules/lodash-es/isArray.js","../node_modules/lodash-es/isLength.js","../node_modules/lodash-es/isArrayLike.js","../node_modules/lodash-es/isArrayLikeObject.js","../node_modules/lodash-es/stubFalse.js","../node_modules/lodash-es/isBuffer.js","../node_modules/lodash-es/isPlainObject.js","../node_modules/lodash-es/_baseIsTypedArray.js","../node_modules/lodash-es/_baseUnary.js","../node_modules/lodash-es/_nodeUtil.js","../node_modules/lodash-es/isTypedArray.js","../node_modules/lodash-es/_safeGet.js","../node_modules/lodash-es/_assignValue.js","../node_modules/lodash-es/_copyObject.js","../node_modules/lodash-es/_baseTimes.js","../node_modules/lodash-es/_isIndex.js","../node_modules/lodash-es/_arrayLikeKeys.js","../node_modules/lodash-es/_nativeKeysIn.js","../node_modules/lodash-es/_baseKeysIn.js","../node_modules/lodash-es/keysIn.js","../node_modules/lodash-es/toPlainObject.js","../node_modules/lodash-es/_baseMergeDeep.js","../node_modules/lodash-es/_baseMerge.js","../node_modules/lodash-es/identity.js","../node_modules/lodash-es/_apply.js","../node_modules/lodash-es/_overRest.js","../node_modules/lodash-es/constant.js","../node_modules/lodash-es/_baseSetToString.js","../node_modules/lodash-es/_shortOut.js","../node_modules/lodash-es/_setToString.js","../node_modules/lodash-es/_baseRest.js","../node_modules/lodash-es/_isIterateeCall.js","../node_modules/lodash-es/merge.js","../node_modules/lodash-es/_createAssigner.js","../node_modules/react-color/es/components/common/Raised.js","../node_modules/lodash-es/now.js","../node_modules/lodash-es/_trimmedEndIndex.js","../node_modules/lodash-es/_baseTrim.js","../node_modules/lodash-es/isSymbol.js","../node_modules/lodash-es/toNumber.js","../node_modules/lodash-es/debounce.js","../node_modules/lodash-es/throttle.js","../node_modules/react-color/es/helpers/saturation.js","../node_modules/react-color/es/components/common/Saturation.js","../node_modules/lodash-es/_arrayEach.js","../node_modules/lodash-es/_nativeKeys.js","../node_modules/lodash-es/_baseKeys.js","../node_modules/lodash-es/keys.js","../node_modules/lodash-es/_baseEach.js","../node_modules/lodash-es/_createBaseEach.js","../node_modules/lodash-es/_baseForOwn.js","../node_modules/lodash-es/_castFunction.js","../node_modules/lodash-es/forEach.js","../node_modules/tinycolor2/esm/tinycolor.js","../node_modules/react-color/es/helpers/color.js","../node_modules/react-color/es/components/common/ColorWrap.js","../node_modules/react-color/es/helpers/interaction.js","../node_modules/react-color/es/components/common/Swatch.js","../node_modules/react-color/es/components/alpha/AlphaPointer.js","../node_modules/react-color/es/components/alpha/Alpha.js","../node_modules/lodash-es/_arrayMap.js","../node_modules/lodash-es/_setCacheAdd.js","../node_modules/lodash-es/_setCacheHas.js","../node_modules/lodash-es/_SetCache.js","../node_modules/lodash-es/_arraySome.js","../node_modules/lodash-es/_cacheHas.js","../node_modules/lodash-es/_equalArrays.js","../node_modules/lodash-es/_mapToArray.js","../node_modules/lodash-es/_setToArray.js","../node_modules/lodash-es/_equalByTag.js","../node_modules/lodash-es/_arrayPush.js","../node_modules/lodash-es/_baseGetAllKeys.js","../node_modules/lodash-es/_arrayFilter.js","../node_modules/lodash-es/stubArray.js","../node_modules/lodash-es/_getSymbols.js","../node_modules/lodash-es/_getAllKeys.js","../node_modules/lodash-es/_equalObjects.js","../node_modules/lodash-es/_DataView.js","../node_modules/lodash-es/_Promise.js","../node_modules/lodash-es/_Set.js","../node_modules/lodash-es/_WeakMap.js","../node_modules/lodash-es/_getTag.js","../node_modules/lodash-es/_baseIsEqualDeep.js","../node_modules/lodash-es/_baseIsEqual.js","../node_modules/lodash-es/_baseIsMatch.js","../node_modules/lodash-es/_isStrictComparable.js","../node_modules/lodash-es/_getMatchData.js","../node_modules/lodash-es/_matchesStrictComparable.js","../node_modules/lodash-es/_baseMatches.js","../node_modules/lodash-es/_isKey.js","../node_modules/lodash-es/memoize.js","../node_modules/lodash-es/_memoizeCapped.js","../node_modules/lodash-es/_stringToPath.js","../node_modules/lodash-es/_baseToString.js","../node_modules/lodash-es/toString.js","../node_modules/lodash-es/_castPath.js","../node_modules/lodash-es/_toKey.js","../node_modules/lodash-es/_baseGet.js","../node_modules/lodash-es/get.js","../node_modules/lodash-es/_baseHasIn.js","../node_modules/lodash-es/_hasPath.js","../node_modules/lodash-es/hasIn.js","../node_modules/lodash-es/_baseMatchesProperty.js","../node_modules/lodash-es/_baseProperty.js","../node_modules/lodash-es/_basePropertyDeep.js","../node_modules/lodash-es/property.js","../node_modules/lodash-es/_baseIteratee.js","../node_modules/lodash-es/_baseMap.js","../node_modules/lodash-es/map.js","../node_modules/react-color/es/components/block/BlockSwatches.js","../node_modules/react-color/es/components/block/Block.js","../node_modules/material-colors/dist/colors.es2015.js","../node_modules/react-color/es/components/circle/CircleSwatch.js","../node_modules/react-color/es/components/circle/Circle.js","../node_modules/lodash-es/isUndefined.js","../node_modules/react-color/es/components/chrome/ChromeFields.js","../node_modules/react-color/es/components/chrome/ChromePointer.js","../node_modules/react-color/es/components/chrome/ChromePointerCircle.js","../node_modules/react-color/es/components/chrome/Chrome.js","../node_modules/react-color/es/components/compact/CompactColor.js","../node_modules/react-color/es/components/compact/CompactFields.js","../node_modules/react-color/es/components/compact/Compact.js","../node_modules/react-color/es/components/github/GithubSwatch.js","../node_modules/react-color/es/components/github/Github.js","../node_modules/react-color/es/components/hue/HuePointer.js","../node_modules/react-color/es/components/hue/Hue.js","../node_modules/react-color/es/components/material/Material.js","../node_modules/react-color/es/components/photoshop/PhotoshopFields.js","../node_modules/react-color/es/components/photoshop/PhotoshopPointerCircle.js","../node_modules/react-color/es/components/photoshop/PhotoshopPointer.js","../node_modules/react-color/es/components/photoshop/PhotoshopButton.js","../node_modules/react-color/es/components/photoshop/PhotoshopPreviews.js","../node_modules/react-color/es/components/photoshop/Photoshop.js","../node_modules/react-color/es/components/sketch/SketchFields.js","../node_modules/react-color/es/components/sketch/SketchPresetColors.js","../node_modules/react-color/es/components/sketch/Sketch.js","../node_modules/react-color/es/components/slider/SliderSwatch.js","../node_modules/react-color/es/components/slider/SliderSwatches.js","../node_modules/react-color/es/components/slider/SliderPointer.js","../node_modules/react-color/es/components/slider/Slider.js","../node_modules/react-color/es/components/swatches/SwatchesColor.js","../node_modules/react-color/es/components/swatches/SwatchesGroup.js","../node_modules/react-color/es/components/swatches/Swatches.js","../node_modules/react-color/es/components/twitter/Twitter.js","../node_modules/react-color/es/components/google/GooglePointerCircle.js","../node_modules/react-color/es/components/google/GooglePointer.js","../node_modules/react-color/es/components/google/GoogleFields.js","../node_modules/react-color/es/components/google/Google.js","components/Workspace/Visualize/Editor/GradientColorPicker.tsx","components/common/ParamSelect.tsx","components/Workspace/Visualize/Editor/SaveFig.tsx","components/Workspace/Visualize/Editor/HeatmapItemEditor.tsx","components/Workspace/Visualize/Editor/ImageItemEditor.tsx","components/Workspace/Visualize/Editor/RoiItemEditor.tsx","components/Workspace/Visualize/Editor/TimeSeriesItemEditor.tsx","components/Workspace/Visualize/VisualizeItemEditor.tsx","components/Workspace/Visualize/Visualize.tsx","store/slice/Experiments/ExperimentsSlice.ts","store/slice/Run/RunSelectors.ts","store/slice/Pipeline/PipelineHook.ts","const/Mode.ts","pages/Workspace/Workspace.tsx","store/slice/Standalone/StandaloneActions.ts","api/modeStandalone/index.ts","App.tsx","reportWebVitals.ts","store/slice/AlgorithmList/AlgorithmListSlice.ts","store/slice/DisplayData/DisplayDataSlice.ts","store/slice/FileUploader/FileUploaderSlice.ts","store/slice/FilesTree/FilesTreeSlice.ts","../node_modules/@mui/material/colors/indigo.js","../node_modules/@mui/material/colors/yellow.js","store/slice/HDF5/HDF5Utils.ts","store/slice/Matlab/MatlabUtils.ts","store/slice/Matlab/MatlabSlice.ts","store/store.ts","../node_modules/@reduxjs/toolkit/src/configureStore.ts","store/slice/HandleTypeColor/HandleTypeColorSlice.ts","store/slice/HDF5/HDF5Slice.ts","store/slice/Matlab/MatlabType.ts","store/slice/Standalone/StandaloneSlice.ts","Theme.ts","index.tsx"],"sourcesContent":["var isDevelopment = false;\n\n/*\n\nBased off glamor's StyleSheet, thanks Sunil ❤️\n\nhigh performance StyleSheet for css-in-js systems\n\n- uses multiple style tags behind the scenes for millions of rules\n- uses `insertRule` for appending in production for *much* faster performance\n\n// usage\n\nimport { StyleSheet } from '@emotion/sheet'\n\nlet styleSheet = new StyleSheet({ key: '', container: document.head })\n\nstyleSheet.insert('#box { border: 1px solid red; }')\n- appends a css rule into the stylesheet\n\nstyleSheet.flush()\n- empties the stylesheet of all its contents\n\n*/\n\nfunction sheetForTag(tag) {\n if (tag.sheet) {\n return tag.sheet;\n } // this weirdness brought to you by firefox\n\n /* istanbul ignore next */\n\n\n for (var i = 0; i < document.styleSheets.length; i++) {\n if (document.styleSheets[i].ownerNode === tag) {\n return document.styleSheets[i];\n }\n } // this function should always return with a value\n // TS can't understand it though so we make it stop complaining here\n\n\n return undefined;\n}\n\nfunction createStyleElement(options) {\n var tag = document.createElement('style');\n tag.setAttribute('data-emotion', options.key);\n\n if (options.nonce !== undefined) {\n tag.setAttribute('nonce', options.nonce);\n }\n\n tag.appendChild(document.createTextNode(''));\n tag.setAttribute('data-s', '');\n return tag;\n}\n\nvar StyleSheet = /*#__PURE__*/function () {\n // Using Node instead of HTMLElement since container may be a ShadowRoot\n function StyleSheet(options) {\n var _this = this;\n\n this._insertTag = function (tag) {\n var before;\n\n if (_this.tags.length === 0) {\n if (_this.insertionPoint) {\n before = _this.insertionPoint.nextSibling;\n } else if (_this.prepend) {\n before = _this.container.firstChild;\n } else {\n before = _this.before;\n }\n } else {\n before = _this.tags[_this.tags.length - 1].nextSibling;\n }\n\n _this.container.insertBefore(tag, before);\n\n _this.tags.push(tag);\n };\n\n this.isSpeedy = options.speedy === undefined ? !isDevelopment : options.speedy;\n this.tags = [];\n this.ctr = 0;\n this.nonce = options.nonce; // key is the value of the data-emotion attribute, it's used to identify different sheets\n\n this.key = options.key;\n this.container = options.container;\n this.prepend = options.prepend;\n this.insertionPoint = options.insertionPoint;\n this.before = null;\n }\n\n var _proto = StyleSheet.prototype;\n\n _proto.hydrate = function hydrate(nodes) {\n nodes.forEach(this._insertTag);\n };\n\n _proto.insert = function insert(rule) {\n // the max length is how many rules we have per style tag, it's 65000 in speedy mode\n // it's 1 in dev because we insert source maps that map a single rule to a location\n // and you can only have one source map per style tag\n if (this.ctr % (this.isSpeedy ? 65000 : 1) === 0) {\n this._insertTag(createStyleElement(this));\n }\n\n var tag = this.tags[this.tags.length - 1];\n\n if (this.isSpeedy) {\n var sheet = sheetForTag(tag);\n\n try {\n // this is the ultrafast version, works across browsers\n // the big drawback is that the css won't be editable in devtools\n sheet.insertRule(rule, sheet.cssRules.length);\n } catch (e) {\n }\n } else {\n tag.appendChild(document.createTextNode(rule));\n }\n\n this.ctr++;\n };\n\n _proto.flush = function flush() {\n this.tags.forEach(function (tag) {\n var _tag$parentNode;\n\n return (_tag$parentNode = tag.parentNode) == null ? void 0 : _tag$parentNode.removeChild(tag);\n });\n this.tags = [];\n this.ctr = 0;\n };\n\n return StyleSheet;\n}();\n\nexport { StyleSheet };\n","/**\n * @param {number}\n * @return {number}\n */\nexport var abs = Math.abs\n\n/**\n * @param {number}\n * @return {string}\n */\nexport var from = String.fromCharCode\n\n/**\n * @param {object}\n * @return {object}\n */\nexport var assign = Object.assign\n\n/**\n * @param {string} value\n * @param {number} length\n * @return {number}\n */\nexport function hash (value, length) {\n\treturn charat(value, 0) ^ 45 ? (((((((length << 2) ^ charat(value, 0)) << 2) ^ charat(value, 1)) << 2) ^ charat(value, 2)) << 2) ^ charat(value, 3) : 0\n}\n\n/**\n * @param {string} value\n * @return {string}\n */\nexport function trim (value) {\n\treturn value.trim()\n}\n\n/**\n * @param {string} value\n * @param {RegExp} pattern\n * @return {string?}\n */\nexport function match (value, pattern) {\n\treturn (value = pattern.exec(value)) ? value[0] : value\n}\n\n/**\n * @param {string} value\n * @param {(string|RegExp)} pattern\n * @param {string} replacement\n * @return {string}\n */\nexport function replace (value, pattern, replacement) {\n\treturn value.replace(pattern, replacement)\n}\n\n/**\n * @param {string} value\n * @param {string} search\n * @return {number}\n */\nexport function indexof (value, search) {\n\treturn value.indexOf(search)\n}\n\n/**\n * @param {string} value\n * @param {number} index\n * @return {number}\n */\nexport function charat (value, index) {\n\treturn value.charCodeAt(index) | 0\n}\n\n/**\n * @param {string} value\n * @param {number} begin\n * @param {number} end\n * @return {string}\n */\nexport function substr (value, begin, end) {\n\treturn value.slice(begin, end)\n}\n\n/**\n * @param {string} value\n * @return {number}\n */\nexport function strlen (value) {\n\treturn value.length\n}\n\n/**\n * @param {any[]} value\n * @return {number}\n */\nexport function sizeof (value) {\n\treturn value.length\n}\n\n/**\n * @param {any} value\n * @param {any[]} array\n * @return {any}\n */\nexport function append (value, array) {\n\treturn array.push(value), value\n}\n\n/**\n * @param {string[]} array\n * @param {function} callback\n * @return {string}\n */\nexport function combine (array, callback) {\n\treturn array.map(callback).join('')\n}\n","import {from, trim, charat, strlen, substr, append, assign} from './Utility.js'\n\nexport var line = 1\nexport var column = 1\nexport var length = 0\nexport var position = 0\nexport var character = 0\nexport var characters = ''\n\n/**\n * @param {string} value\n * @param {object | null} root\n * @param {object | null} parent\n * @param {string} type\n * @param {string[] | string} props\n * @param {object[] | string} children\n * @param {number} length\n */\nexport function node (value, root, parent, type, props, children, length) {\n\treturn {value: value, root: root, parent: parent, type: type, props: props, children: children, line: line, column: column, length: length, return: ''}\n}\n\n/**\n * @param {object} root\n * @param {object} props\n * @return {object}\n */\nexport function copy (root, props) {\n\treturn assign(node('', null, null, '', null, null, 0), root, {length: -root.length}, props)\n}\n\n/**\n * @return {number}\n */\nexport function char () {\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function prev () {\n\tcharacter = position > 0 ? charat(characters, --position) : 0\n\n\tif (column--, character === 10)\n\t\tcolumn = 1, line--\n\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function next () {\n\tcharacter = position < length ? charat(characters, position++) : 0\n\n\tif (column++, character === 10)\n\t\tcolumn = 1, line++\n\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function peek () {\n\treturn charat(characters, position)\n}\n\n/**\n * @return {number}\n */\nexport function caret () {\n\treturn position\n}\n\n/**\n * @param {number} begin\n * @param {number} end\n * @return {string}\n */\nexport function slice (begin, end) {\n\treturn substr(characters, begin, end)\n}\n\n/**\n * @param {number} type\n * @return {number}\n */\nexport function token (type) {\n\tswitch (type) {\n\t\t// \\0 \\t \\n \\r \\s whitespace token\n\t\tcase 0: case 9: case 10: case 13: case 32:\n\t\t\treturn 5\n\t\t// ! + , / > @ ~ isolate token\n\t\tcase 33: case 43: case 44: case 47: case 62: case 64: case 126:\n\t\t// ; { } breakpoint token\n\t\tcase 59: case 123: case 125:\n\t\t\treturn 4\n\t\t// : accompanied token\n\t\tcase 58:\n\t\t\treturn 3\n\t\t// \" ' ( [ opening delimit token\n\t\tcase 34: case 39: case 40: case 91:\n\t\t\treturn 2\n\t\t// ) ] closing delimit token\n\t\tcase 41: case 93:\n\t\t\treturn 1\n\t}\n\n\treturn 0\n}\n\n/**\n * @param {string} value\n * @return {any[]}\n */\nexport function alloc (value) {\n\treturn line = column = 1, length = strlen(characters = value), position = 0, []\n}\n\n/**\n * @param {any} value\n * @return {any}\n */\nexport function dealloc (value) {\n\treturn characters = '', value\n}\n\n/**\n * @param {number} type\n * @return {string}\n */\nexport function delimit (type) {\n\treturn trim(slice(position - 1, delimiter(type === 91 ? type + 2 : type === 40 ? type + 1 : type)))\n}\n\n/**\n * @param {string} value\n * @return {string[]}\n */\nexport function tokenize (value) {\n\treturn dealloc(tokenizer(alloc(value)))\n}\n\n/**\n * @param {number} type\n * @return {string}\n */\nexport function whitespace (type) {\n\twhile (character = peek())\n\t\tif (character < 33)\n\t\t\tnext()\n\t\telse\n\t\t\tbreak\n\n\treturn token(type) > 2 || token(character) > 3 ? '' : ' '\n}\n\n/**\n * @param {string[]} children\n * @return {string[]}\n */\nexport function tokenizer (children) {\n\twhile (next())\n\t\tswitch (token(character)) {\n\t\t\tcase 0: append(identifier(position - 1), children)\n\t\t\t\tbreak\n\t\t\tcase 2: append(delimit(character), children)\n\t\t\t\tbreak\n\t\t\tdefault: append(from(character), children)\n\t\t}\n\n\treturn children\n}\n\n/**\n * @param {number} index\n * @param {number} count\n * @return {string}\n */\nexport function escaping (index, count) {\n\twhile (--count && next())\n\t\t// not 0-9 A-F a-f\n\t\tif (character < 48 || character > 102 || (character > 57 && character < 65) || (character > 70 && character < 97))\n\t\t\tbreak\n\n\treturn slice(index, caret() + (count < 6 && peek() == 32 && next() == 32))\n}\n\n/**\n * @param {number} type\n * @return {number}\n */\nexport function delimiter (type) {\n\twhile (next())\n\t\tswitch (character) {\n\t\t\t// ] ) \" '\n\t\t\tcase type:\n\t\t\t\treturn position\n\t\t\t// \" '\n\t\t\tcase 34: case 39:\n\t\t\t\tif (type !== 34 && type !== 39)\n\t\t\t\t\tdelimiter(character)\n\t\t\t\tbreak\n\t\t\t// (\n\t\t\tcase 40:\n\t\t\t\tif (type === 41)\n\t\t\t\t\tdelimiter(type)\n\t\t\t\tbreak\n\t\t\t// \\\n\t\t\tcase 92:\n\t\t\t\tnext()\n\t\t\t\tbreak\n\t\t}\n\n\treturn position\n}\n\n/**\n * @param {number} type\n * @param {number} index\n * @return {number}\n */\nexport function commenter (type, index) {\n\twhile (next())\n\t\t// //\n\t\tif (type + character === 47 + 10)\n\t\t\tbreak\n\t\t// /*\n\t\telse if (type + character === 42 + 42 && peek() === 47)\n\t\t\tbreak\n\n\treturn '/*' + slice(index, position - 1) + '*' + from(type === 47 ? type : next())\n}\n\n/**\n * @param {number} index\n * @return {string}\n */\nexport function identifier (index) {\n\twhile (!token(peek()))\n\t\tnext()\n\n\treturn slice(index, position)\n}\n","export var MS = '-ms-'\nexport var MOZ = '-moz-'\nexport var WEBKIT = '-webkit-'\n\nexport var COMMENT = 'comm'\nexport var RULESET = 'rule'\nexport var DECLARATION = 'decl'\n\nexport var PAGE = '@page'\nexport var MEDIA = '@media'\nexport var IMPORT = '@import'\nexport var CHARSET = '@charset'\nexport var VIEWPORT = '@viewport'\nexport var SUPPORTS = '@supports'\nexport var DOCUMENT = '@document'\nexport var NAMESPACE = '@namespace'\nexport var KEYFRAMES = '@keyframes'\nexport var FONT_FACE = '@font-face'\nexport var COUNTER_STYLE = '@counter-style'\nexport var FONT_FEATURE_VALUES = '@font-feature-values'\nexport var LAYER = '@layer'\n","import {IMPORT, LAYER, COMMENT, RULESET, DECLARATION, KEYFRAMES} from './Enum.js'\nimport {strlen, sizeof} from './Utility.js'\n\n/**\n * @param {object[]} children\n * @param {function} callback\n * @return {string}\n */\nexport function serialize (children, callback) {\n\tvar output = ''\n\tvar length = sizeof(children)\n\n\tfor (var i = 0; i < length; i++)\n\t\toutput += callback(children[i], i, children, callback) || ''\n\n\treturn output\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n * @param {function} callback\n * @return {string}\n */\nexport function stringify (element, index, children, callback) {\n\tswitch (element.type) {\n\t\tcase LAYER: if (element.children.length) break\n\t\tcase IMPORT: case DECLARATION: return element.return = element.return || element.value\n\t\tcase COMMENT: return ''\n\t\tcase KEYFRAMES: return element.return = element.value + '{' + serialize(element.children, callback) + '}'\n\t\tcase RULESET: element.value = element.props.join(',')\n\t}\n\n\treturn strlen(children = serialize(element.children, callback)) ? element.return = element.value + '{' + children + '}' : ''\n}\n","import {COMMENT, RULESET, DECLARATION} from './Enum.js'\nimport {abs, charat, trim, from, sizeof, strlen, substr, append, replace, indexof} from './Utility.js'\nimport {node, char, prev, next, peek, caret, alloc, dealloc, delimit, whitespace, escaping, identifier, commenter} from './Tokenizer.js'\n\n/**\n * @param {string} value\n * @return {object[]}\n */\nexport function compile (value) {\n\treturn dealloc(parse('', null, null, null, [''], value = alloc(value), 0, [0], value))\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {string[]} rule\n * @param {string[]} rules\n * @param {string[]} rulesets\n * @param {number[]} pseudo\n * @param {number[]} points\n * @param {string[]} declarations\n * @return {object}\n */\nexport function parse (value, root, parent, rule, rules, rulesets, pseudo, points, declarations) {\n\tvar index = 0\n\tvar offset = 0\n\tvar length = pseudo\n\tvar atrule = 0\n\tvar property = 0\n\tvar previous = 0\n\tvar variable = 1\n\tvar scanning = 1\n\tvar ampersand = 1\n\tvar character = 0\n\tvar type = ''\n\tvar props = rules\n\tvar children = rulesets\n\tvar reference = rule\n\tvar characters = type\n\n\twhile (scanning)\n\t\tswitch (previous = character, character = next()) {\n\t\t\t// (\n\t\t\tcase 40:\n\t\t\t\tif (previous != 108 && charat(characters, length - 1) == 58) {\n\t\t\t\t\tif (indexof(characters += replace(delimit(character), '&', '&\\f'), '&\\f') != -1)\n\t\t\t\t\t\tampersand = -1\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t// \" ' [\n\t\t\tcase 34: case 39: case 91:\n\t\t\t\tcharacters += delimit(character)\n\t\t\t\tbreak\n\t\t\t// \\t \\n \\r \\s\n\t\t\tcase 9: case 10: case 13: case 32:\n\t\t\t\tcharacters += whitespace(previous)\n\t\t\t\tbreak\n\t\t\t// \\\n\t\t\tcase 92:\n\t\t\t\tcharacters += escaping(caret() - 1, 7)\n\t\t\t\tcontinue\n\t\t\t// /\n\t\t\tcase 47:\n\t\t\t\tswitch (peek()) {\n\t\t\t\t\tcase 42: case 47:\n\t\t\t\t\t\tappend(comment(commenter(next(), caret()), root, parent), declarations)\n\t\t\t\t\t\tbreak\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tcharacters += '/'\n\t\t\t\t}\n\t\t\t\tbreak\n\t\t\t// {\n\t\t\tcase 123 * variable:\n\t\t\t\tpoints[index++] = strlen(characters) * ampersand\n\t\t\t// } ; \\0\n\t\t\tcase 125 * variable: case 59: case 0:\n\t\t\t\tswitch (character) {\n\t\t\t\t\t// \\0 }\n\t\t\t\t\tcase 0: case 125: scanning = 0\n\t\t\t\t\t// ;\n\t\t\t\t\tcase 59 + offset: if (ampersand == -1) characters = replace(characters, /\\f/g, '')\n\t\t\t\t\t\tif (property > 0 && (strlen(characters) - length))\n\t\t\t\t\t\t\tappend(property > 32 ? declaration(characters + ';', rule, parent, length - 1) : declaration(replace(characters, ' ', '') + ';', rule, parent, length - 2), declarations)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// @ ;\n\t\t\t\t\tcase 59: characters += ';'\n\t\t\t\t\t// { rule/at-rule\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tappend(reference = ruleset(characters, root, parent, index, offset, rules, points, type, props = [], children = [], length), rulesets)\n\n\t\t\t\t\t\tif (character === 123)\n\t\t\t\t\t\t\tif (offset === 0)\n\t\t\t\t\t\t\t\tparse(characters, root, reference, reference, props, rulesets, length, points, children)\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tswitch (atrule === 99 && charat(characters, 3) === 110 ? 100 : atrule) {\n\t\t\t\t\t\t\t\t\t// d l m s\n\t\t\t\t\t\t\t\t\tcase 100: case 108: case 109: case 115:\n\t\t\t\t\t\t\t\t\t\tparse(value, reference, reference, rule && append(ruleset(value, reference, reference, 0, 0, rules, points, type, rules, props = [], length), children), rules, children, length, points, rule ? props : children)\n\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\t\t\tparse(characters, reference, reference, reference, [''], children, 0, points, children)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tindex = offset = property = 0, variable = ampersand = 1, type = characters = '', length = pseudo\n\t\t\t\tbreak\n\t\t\t// :\n\t\t\tcase 58:\n\t\t\t\tlength = 1 + strlen(characters), property = previous\n\t\t\tdefault:\n\t\t\t\tif (variable < 1)\n\t\t\t\t\tif (character == 123)\n\t\t\t\t\t\t--variable\n\t\t\t\t\telse if (character == 125 && variable++ == 0 && prev() == 125)\n\t\t\t\t\t\tcontinue\n\n\t\t\t\tswitch (characters += from(character), character * variable) {\n\t\t\t\t\t// &\n\t\t\t\t\tcase 38:\n\t\t\t\t\t\tampersand = offset > 0 ? 1 : (characters += '\\f', -1)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// ,\n\t\t\t\t\tcase 44:\n\t\t\t\t\t\tpoints[index++] = (strlen(characters) - 1) * ampersand, ampersand = 1\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// @\n\t\t\t\t\tcase 64:\n\t\t\t\t\t\t// -\n\t\t\t\t\t\tif (peek() === 45)\n\t\t\t\t\t\t\tcharacters += delimit(next())\n\n\t\t\t\t\t\tatrule = peek(), offset = length = strlen(type = characters += identifier(caret())), character++\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// -\n\t\t\t\t\tcase 45:\n\t\t\t\t\t\tif (previous === 45 && strlen(characters) == 2)\n\t\t\t\t\t\t\tvariable = 0\n\t\t\t\t}\n\t\t}\n\n\treturn rulesets\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {number} index\n * @param {number} offset\n * @param {string[]} rules\n * @param {number[]} points\n * @param {string} type\n * @param {string[]} props\n * @param {string[]} children\n * @param {number} length\n * @return {object}\n */\nexport function ruleset (value, root, parent, index, offset, rules, points, type, props, children, length) {\n\tvar post = offset - 1\n\tvar rule = offset === 0 ? rules : ['']\n\tvar size = sizeof(rule)\n\n\tfor (var i = 0, j = 0, k = 0; i < index; ++i)\n\t\tfor (var x = 0, y = substr(value, post + 1, post = abs(j = points[i])), z = value; x < size; ++x)\n\t\t\tif (z = trim(j > 0 ? rule[x] + ' ' + y : replace(y, /&\\f/g, rule[x])))\n\t\t\t\tprops[k++] = z\n\n\treturn node(value, root, parent, offset === 0 ? RULESET : type, props, children, length)\n}\n\n/**\n * @param {number} value\n * @param {object} root\n * @param {object?} parent\n * @return {object}\n */\nexport function comment (value, root, parent) {\n\treturn node(value, root, parent, COMMENT, from(char()), substr(value, 2, -2), 0)\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {number} length\n * @return {object}\n */\nexport function declaration (value, root, parent, length) {\n\treturn node(value, root, parent, DECLARATION, substr(value, 0, length), substr(value, length + 1, -1), length)\n}\n","import { StyleSheet } from '@emotion/sheet';\nimport { dealloc, alloc, next, token, from, peek, delimit, slice, position, RULESET, combine, match, serialize, copy, replace, WEBKIT, MOZ, MS, KEYFRAMES, DECLARATION, hash, charat, strlen, indexof, stringify, rulesheet, middleware, compile } from 'stylis';\nimport '@emotion/weak-memoize';\nimport '@emotion/memoize';\n\nvar identifierWithPointTracking = function identifierWithPointTracking(begin, points, index) {\n var previous = 0;\n var character = 0;\n\n while (true) {\n previous = character;\n character = peek(); // &\\f\n\n if (previous === 38 && character === 12) {\n points[index] = 1;\n }\n\n if (token(character)) {\n break;\n }\n\n next();\n }\n\n return slice(begin, position);\n};\n\nvar toRules = function toRules(parsed, points) {\n // pretend we've started with a comma\n var index = -1;\n var character = 44;\n\n do {\n switch (token(character)) {\n case 0:\n // &\\f\n if (character === 38 && peek() === 12) {\n // this is not 100% correct, we don't account for literal sequences here - like for example quoted strings\n // stylis inserts \\f after & to know when & where it should replace this sequence with the context selector\n // and when it should just concatenate the outer and inner selectors\n // it's very unlikely for this sequence to actually appear in a different context, so we just leverage this fact here\n points[index] = 1;\n }\n\n parsed[index] += identifierWithPointTracking(position - 1, points, index);\n break;\n\n case 2:\n parsed[index] += delimit(character);\n break;\n\n case 4:\n // comma\n if (character === 44) {\n // colon\n parsed[++index] = peek() === 58 ? '&\\f' : '';\n points[index] = parsed[index].length;\n break;\n }\n\n // fallthrough\n\n default:\n parsed[index] += from(character);\n }\n } while (character = next());\n\n return parsed;\n};\n\nvar getRules = function getRules(value, points) {\n return dealloc(toRules(alloc(value), points));\n}; // WeakSet would be more appropriate, but only WeakMap is supported in IE11\n\n\nvar fixedElements = /* #__PURE__ */new WeakMap();\nvar compat = function compat(element) {\n if (element.type !== 'rule' || !element.parent || // positive .length indicates that this rule contains pseudo\n // negative .length indicates that this rule has been already prefixed\n element.length < 1) {\n return;\n }\n\n var value = element.value,\n parent = element.parent;\n var isImplicitRule = element.column === parent.column && element.line === parent.line;\n\n while (parent.type !== 'rule') {\n parent = parent.parent;\n if (!parent) return;\n } // short-circuit for the simplest case\n\n\n if (element.props.length === 1 && value.charCodeAt(0) !== 58\n /* colon */\n && !fixedElements.get(parent)) {\n return;\n } // if this is an implicitly inserted rule (the one eagerly inserted at the each new nested level)\n // then the props has already been manipulated beforehand as they that array is shared between it and its \"rule parent\"\n\n\n if (isImplicitRule) {\n return;\n }\n\n fixedElements.set(element, true);\n var points = [];\n var rules = getRules(value, points);\n var parentRules = parent.props;\n\n for (var i = 0, k = 0; i < rules.length; i++) {\n for (var j = 0; j < parentRules.length; j++, k++) {\n element.props[k] = points[i] ? rules[i].replace(/&\\f/g, parentRules[j]) : parentRules[j] + \" \" + rules[i];\n }\n }\n};\nvar removeLabel = function removeLabel(element) {\n if (element.type === 'decl') {\n var value = element.value;\n\n if ( // charcode for l\n value.charCodeAt(0) === 108 && // charcode for b\n value.charCodeAt(2) === 98) {\n // this ignores label\n element[\"return\"] = '';\n element.value = '';\n }\n }\n};\n\n/* eslint-disable no-fallthrough */\n\nfunction prefix(value, length) {\n switch (hash(value, length)) {\n // color-adjust\n case 5103:\n return WEBKIT + 'print-' + value + value;\n // animation, animation-(delay|direction|duration|fill-mode|iteration-count|name|play-state|timing-function)\n\n case 5737:\n case 4201:\n case 3177:\n case 3433:\n case 1641:\n case 4457:\n case 2921: // text-decoration, filter, clip-path, backface-visibility, column, box-decoration-break\n\n case 5572:\n case 6356:\n case 5844:\n case 3191:\n case 6645:\n case 3005: // mask, mask-image, mask-(mode|clip|size), mask-(repeat|origin), mask-position, mask-composite,\n\n case 6391:\n case 5879:\n case 5623:\n case 6135:\n case 4599:\n case 4855: // background-clip, columns, column-(count|fill|gap|rule|rule-color|rule-style|rule-width|span|width)\n\n case 4215:\n case 6389:\n case 5109:\n case 5365:\n case 5621:\n case 3829:\n return WEBKIT + value + value;\n // appearance, user-select, transform, hyphens, text-size-adjust\n\n case 5349:\n case 4246:\n case 4810:\n case 6968:\n case 2756:\n return WEBKIT + value + MOZ + value + MS + value + value;\n // flex, flex-direction\n\n case 6828:\n case 4268:\n return WEBKIT + value + MS + value + value;\n // order\n\n case 6165:\n return WEBKIT + value + MS + 'flex-' + value + value;\n // align-items\n\n case 5187:\n return WEBKIT + value + replace(value, /(\\w+).+(:[^]+)/, WEBKIT + 'box-$1$2' + MS + 'flex-$1$2') + value;\n // align-self\n\n case 5443:\n return WEBKIT + value + MS + 'flex-item-' + replace(value, /flex-|-self/, '') + value;\n // align-content\n\n case 4675:\n return WEBKIT + value + MS + 'flex-line-pack' + replace(value, /align-content|flex-|-self/, '') + value;\n // flex-shrink\n\n case 5548:\n return WEBKIT + value + MS + replace(value, 'shrink', 'negative') + value;\n // flex-basis\n\n case 5292:\n return WEBKIT + value + MS + replace(value, 'basis', 'preferred-size') + value;\n // flex-grow\n\n case 6060:\n return WEBKIT + 'box-' + replace(value, '-grow', '') + WEBKIT + value + MS + replace(value, 'grow', 'positive') + value;\n // transition\n\n case 4554:\n return WEBKIT + replace(value, /([^-])(transform)/g, '$1' + WEBKIT + '$2') + value;\n // cursor\n\n case 6187:\n return replace(replace(replace(value, /(zoom-|grab)/, WEBKIT + '$1'), /(image-set)/, WEBKIT + '$1'), value, '') + value;\n // background, background-image\n\n case 5495:\n case 3959:\n return replace(value, /(image-set\\([^]*)/, WEBKIT + '$1' + '$`$1');\n // justify-content\n\n case 4968:\n return replace(replace(value, /(.+:)(flex-)?(.*)/, WEBKIT + 'box-pack:$3' + MS + 'flex-pack:$3'), /s.+-b[^;]+/, 'justify') + WEBKIT + value + value;\n // (margin|padding)-inline-(start|end)\n\n case 4095:\n case 3583:\n case 4068:\n case 2532:\n return replace(value, /(.+)-inline(.+)/, WEBKIT + '$1$2') + value;\n // (min|max)?(width|height|inline-size|block-size)\n\n case 8116:\n case 7059:\n case 5753:\n case 5535:\n case 5445:\n case 5701:\n case 4933:\n case 4677:\n case 5533:\n case 5789:\n case 5021:\n case 4765:\n // stretch, max-content, min-content, fill-available\n if (strlen(value) - 1 - length > 6) switch (charat(value, length + 1)) {\n // (m)ax-content, (m)in-content\n case 109:\n // -\n if (charat(value, length + 4) !== 45) break;\n // (f)ill-available, (f)it-content\n\n case 102:\n return replace(value, /(.+:)(.+)-([^]+)/, '$1' + WEBKIT + '$2-$3' + '$1' + MOZ + (charat(value, length + 3) == 108 ? '$3' : '$2-$3')) + value;\n // (s)tretch\n\n case 115:\n return ~indexof(value, 'stretch') ? prefix(replace(value, 'stretch', 'fill-available'), length) + value : value;\n }\n break;\n // position: sticky\n\n case 4949:\n // (s)ticky?\n if (charat(value, length + 1) !== 115) break;\n // display: (flex|inline-flex)\n\n case 6444:\n switch (charat(value, strlen(value) - 3 - (~indexof(value, '!important') && 10))) {\n // stic(k)y\n case 107:\n return replace(value, ':', ':' + WEBKIT) + value;\n // (inline-)?fl(e)x\n\n case 101:\n return replace(value, /(.+:)([^;!]+)(;|!.+)?/, '$1' + WEBKIT + (charat(value, 14) === 45 ? 'inline-' : '') + 'box$3' + '$1' + WEBKIT + '$2$3' + '$1' + MS + '$2box$3') + value;\n }\n\n break;\n // writing-mode\n\n case 5936:\n switch (charat(value, length + 11)) {\n // vertical-l(r)\n case 114:\n return WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'tb') + value;\n // vertical-r(l)\n\n case 108:\n return WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'tb-rl') + value;\n // horizontal(-)tb\n\n case 45:\n return WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'lr') + value;\n }\n\n return WEBKIT + value + MS + value + value;\n }\n\n return value;\n}\n\nvar prefixer = function prefixer(element, index, children, callback) {\n if (element.length > -1) if (!element[\"return\"]) switch (element.type) {\n case DECLARATION:\n element[\"return\"] = prefix(element.value, element.length);\n break;\n\n case KEYFRAMES:\n return serialize([copy(element, {\n value: replace(element.value, '@', '@' + WEBKIT)\n })], callback);\n\n case RULESET:\n if (element.length) return combine(element.props, function (value) {\n switch (match(value, /(::plac\\w+|:read-\\w+)/)) {\n // :read-(only|write)\n case ':read-only':\n case ':read-write':\n return serialize([copy(element, {\n props: [replace(value, /:(read-\\w+)/, ':' + MOZ + '$1')]\n })], callback);\n // :placeholder\n\n case '::placeholder':\n return serialize([copy(element, {\n props: [replace(value, /:(plac\\w+)/, ':' + WEBKIT + 'input-$1')]\n }), copy(element, {\n props: [replace(value, /:(plac\\w+)/, ':' + MOZ + '$1')]\n }), copy(element, {\n props: [replace(value, /:(plac\\w+)/, MS + 'input-$1')]\n })], callback);\n }\n\n return '';\n });\n }\n};\n\nvar defaultStylisPlugins = [prefixer];\n\nvar createCache = function\n /*: EmotionCache */\ncreateCache(options\n/*: Options */\n) {\n var key = options.key;\n\n if (key === 'css') {\n var ssrStyles = document.querySelectorAll(\"style[data-emotion]:not([data-s])\"); // get SSRed styles out of the way of React's hydration\n // document.head is a safe place to move them to(though note document.head is not necessarily the last place they will be)\n // note this very very intentionally targets all style elements regardless of the key to ensure\n // that creating a cache works inside of render of a React component\n\n Array.prototype.forEach.call(ssrStyles, function (node\n /*: HTMLStyleElement */\n ) {\n // we want to only move elements which have a space in the data-emotion attribute value\n // because that indicates that it is an Emotion 11 server-side rendered style elements\n // while we will already ignore Emotion 11 client-side inserted styles because of the :not([data-s]) part in the selector\n // Emotion 10 client-side inserted styles did not have data-s (but importantly did not have a space in their data-emotion attributes)\n // so checking for the space ensures that loading Emotion 11 after Emotion 10 has inserted some styles\n // will not result in the Emotion 10 styles being destroyed\n var dataEmotionAttribute = node.getAttribute('data-emotion');\n\n if (dataEmotionAttribute.indexOf(' ') === -1) {\n return;\n }\n\n document.head.appendChild(node);\n node.setAttribute('data-s', '');\n });\n }\n\n var stylisPlugins = options.stylisPlugins || defaultStylisPlugins;\n\n var inserted = {};\n var container;\n /* : Node */\n\n var nodesToHydrate = [];\n\n {\n container = options.container || document.head;\n Array.prototype.forEach.call( // this means we will ignore elements which don't have a space in them which\n // means that the style elements we're looking at are only Emotion 11 server-rendered style elements\n document.querySelectorAll(\"style[data-emotion^=\\\"\" + key + \" \\\"]\"), function (node\n /*: HTMLStyleElement */\n ) {\n var attrib = node.getAttribute(\"data-emotion\").split(' ');\n\n for (var i = 1; i < attrib.length; i++) {\n inserted[attrib[i]] = true;\n }\n\n nodesToHydrate.push(node);\n });\n }\n\n var _insert;\n /*: (\n selector: string,\n serialized: SerializedStyles,\n sheet: StyleSheet,\n shouldCache: boolean\n ) => string | void */\n\n\n var omnipresentPlugins = [compat, removeLabel];\n\n {\n var currentSheet;\n var finalizingPlugins = [stringify, rulesheet(function (rule) {\n currentSheet.insert(rule);\n })];\n var serializer = middleware(omnipresentPlugins.concat(stylisPlugins, finalizingPlugins));\n\n var stylis = function stylis(styles) {\n return serialize(compile(styles), serializer);\n };\n\n _insert = function\n /*: void */\n insert(selector\n /*: string */\n , serialized\n /*: SerializedStyles */\n , sheet\n /*: StyleSheet */\n , shouldCache\n /*: boolean */\n ) {\n currentSheet = sheet;\n\n stylis(selector ? selector + \"{\" + serialized.styles + \"}\" : serialized.styles);\n\n if (shouldCache) {\n cache.inserted[serialized.name] = true;\n }\n };\n }\n\n var cache\n /*: EmotionCache */\n = {\n key: key,\n sheet: new StyleSheet({\n key: key,\n container: container,\n nonce: options.nonce,\n speedy: options.speedy,\n prepend: options.prepend,\n insertionPoint: options.insertionPoint\n }),\n nonce: options.nonce,\n inserted: inserted,\n registered: {},\n insert: _insert\n };\n cache.sheet.hydrate(nodesToHydrate);\n return cache;\n};\n\nexport { createCache as default };\n","import {MS, MOZ, WEBKIT, RULESET, KEYFRAMES, DECLARATION} from './Enum.js'\nimport {match, charat, substr, strlen, sizeof, replace, combine} from './Utility.js'\nimport {copy, tokenize} from './Tokenizer.js'\nimport {serialize} from './Serializer.js'\nimport {prefix} from './Prefixer.js'\n\n/**\n * @param {function[]} collection\n * @return {function}\n */\nexport function middleware (collection) {\n\tvar length = sizeof(collection)\n\n\treturn function (element, index, children, callback) {\n\t\tvar output = ''\n\n\t\tfor (var i = 0; i < length; i++)\n\t\t\toutput += collection[i](element, index, children, callback) || ''\n\n\t\treturn output\n\t}\n}\n\n/**\n * @param {function} callback\n * @return {function}\n */\nexport function rulesheet (callback) {\n\treturn function (element) {\n\t\tif (!element.root)\n\t\t\tif (element = element.return)\n\t\t\t\tcallback(element)\n\t}\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n * @param {function} callback\n */\nexport function prefixer (element, index, children, callback) {\n\tif (element.length > -1)\n\t\tif (!element.return)\n\t\t\tswitch (element.type) {\n\t\t\t\tcase DECLARATION: element.return = prefix(element.value, element.length, children)\n\t\t\t\t\treturn\n\t\t\t\tcase KEYFRAMES:\n\t\t\t\t\treturn serialize([copy(element, {value: replace(element.value, '@', '@' + WEBKIT)})], callback)\n\t\t\t\tcase RULESET:\n\t\t\t\t\tif (element.length)\n\t\t\t\t\t\treturn combine(element.props, function (value) {\n\t\t\t\t\t\t\tswitch (match(value, /(::plac\\w+|:read-\\w+)/)) {\n\t\t\t\t\t\t\t\t// :read-(only|write)\n\t\t\t\t\t\t\t\tcase ':read-only': case ':read-write':\n\t\t\t\t\t\t\t\t\treturn serialize([copy(element, {props: [replace(value, /:(read-\\w+)/, ':' + MOZ + '$1')]})], callback)\n\t\t\t\t\t\t\t\t// :placeholder\n\t\t\t\t\t\t\t\tcase '::placeholder':\n\t\t\t\t\t\t\t\t\treturn serialize([\n\t\t\t\t\t\t\t\t\t\tcopy(element, {props: [replace(value, /:(plac\\w+)/, ':' + WEBKIT + 'input-$1')]}),\n\t\t\t\t\t\t\t\t\t\tcopy(element, {props: [replace(value, /:(plac\\w+)/, ':' + MOZ + '$1')]}),\n\t\t\t\t\t\t\t\t\t\tcopy(element, {props: [replace(value, /:(plac\\w+)/, MS + 'input-$1')]})\n\t\t\t\t\t\t\t\t\t], callback)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\treturn ''\n\t\t\t\t\t\t})\n\t\t\t}\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n */\nexport function namespace (element) {\n\tswitch (element.type) {\n\t\tcase RULESET:\n\t\t\telement.props = element.props.map(function (value) {\n\t\t\t\treturn combine(tokenize(value), function (value, index, children) {\n\t\t\t\t\tswitch (charat(value, 0)) {\n\t\t\t\t\t\t// \\f\n\t\t\t\t\t\tcase 12:\n\t\t\t\t\t\t\treturn substr(value, 1, strlen(value))\n\t\t\t\t\t\t// \\0 ( + > ~\n\t\t\t\t\t\tcase 0: case 40: case 43: case 62: case 126:\n\t\t\t\t\t\t\treturn value\n\t\t\t\t\t\t// :\n\t\t\t\t\t\tcase 58:\n\t\t\t\t\t\t\tif (children[++index] === 'global')\n\t\t\t\t\t\t\t\tchildren[index] = '', children[++index] = '\\f' + substr(children[index], index = 1, -1)\n\t\t\t\t\t\t// \\s\n\t\t\t\t\t\tcase 32:\n\t\t\t\t\t\t\treturn index === 1 ? '' : value\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tswitch (index) {\n\t\t\t\t\t\t\t\tcase 0: element = value\n\t\t\t\t\t\t\t\t\treturn sizeof(children) > 1 ? '' : value\n\t\t\t\t\t\t\t\tcase index = sizeof(children) - 1: case 2:\n\t\t\t\t\t\t\t\t\treturn index === 2 ? value + element + element : value + element\n\t\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\t\treturn value\n\t\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t\t})\n\t}\n}\n","function memoize(fn) {\n var cache = Object.create(null);\n return function (arg) {\n if (cache[arg] === undefined) cache[arg] = fn(arg);\n return cache[arg];\n };\n}\n\nexport { memoize as default };\n","import * as React from 'react';\nimport { useContext, forwardRef } from 'react';\nimport createCache from '@emotion/cache';\nimport _extends from '@babel/runtime/helpers/esm/extends';\nimport weakMemoize from '@emotion/weak-memoize';\nimport hoistNonReactStatics from '../_isolated-hnrs/dist/emotion-react-_isolated-hnrs.browser.esm.js';\nimport { getRegisteredStyles, registerStyles, insertStyles } from '@emotion/utils';\nimport { serializeStyles } from '@emotion/serialize';\nimport { useInsertionEffectAlwaysWithSyncFallback } from '@emotion/use-insertion-effect-with-fallbacks';\n\nvar isDevelopment = false;\n\n/* import { type EmotionCache } from '@emotion/utils' */\nvar EmotionCacheContext\n/*: React.Context */\n= /* #__PURE__ */React.createContext( // we're doing this to avoid preconstruct's dead code elimination in this one case\n// because this module is primarily intended for the browser and node\n// but it's also required in react native and similar environments sometimes\n// and we could have a special build just for that\n// but this is much easier and the native packages\n// might use a different theme context in the future anyway\ntypeof HTMLElement !== 'undefined' ? /* #__PURE__ */createCache({\n key: 'css'\n}) : null);\n\nvar CacheProvider = EmotionCacheContext.Provider;\nvar __unsafe_useEmotionCache = function useEmotionCache()\n/*: EmotionCache | null*/\n{\n return useContext(EmotionCacheContext);\n};\n\nvar withEmotionCache = function withEmotionCache\n/* > */\n(func\n/*: (props: Props, cache: EmotionCache, ref: Ref) => React.Node */\n)\n/*: React.AbstractComponent */\n{\n return /*#__PURE__*/forwardRef(function (props\n /*: Props */\n , ref\n /*: Ref */\n ) {\n // the cache will never be null in the browser\n var cache = useContext(EmotionCacheContext);\n return func(props, cache, ref);\n });\n};\n\nvar ThemeContext = /* #__PURE__ */React.createContext({});\n\nvar useTheme = function useTheme() {\n return React.useContext(ThemeContext);\n};\n\nvar getTheme = function getTheme(outerTheme\n/*: Object */\n, theme\n/*: Object | (Object => Object) */\n) {\n if (typeof theme === 'function') {\n var mergedTheme = theme(outerTheme);\n\n return mergedTheme;\n }\n\n return _extends({}, outerTheme, theme);\n};\n\nvar createCacheWithTheme = /* #__PURE__ */weakMemoize(function (outerTheme) {\n return weakMemoize(function (theme) {\n return getTheme(outerTheme, theme);\n });\n});\n/*\ntype ThemeProviderProps = {\n theme: Object | (Object => Object),\n children: React.Node\n}\n*/\n\nvar ThemeProvider = function ThemeProvider(props\n/*: ThemeProviderProps */\n) {\n var theme = React.useContext(ThemeContext);\n\n if (props.theme !== theme) {\n theme = createCacheWithTheme(theme)(props.theme);\n }\n\n return /*#__PURE__*/React.createElement(ThemeContext.Provider, {\n value: theme\n }, props.children);\n};\nfunction withTheme\n/* */\n(Component\n/*: React.AbstractComponent */\n)\n/*: React.AbstractComponent<$Diff> */\n{\n var componentName = Component.displayName || Component.name || 'Component';\n\n var render = function render(props, ref) {\n var theme = React.useContext(ThemeContext);\n return /*#__PURE__*/React.createElement(Component, _extends({\n theme: theme,\n ref: ref\n }, props));\n };\n\n var WithTheme = /*#__PURE__*/React.forwardRef(render);\n WithTheme.displayName = \"WithTheme(\" + componentName + \")\";\n return hoistNonReactStatics(WithTheme, Component);\n}\n\nvar hasOwn = {}.hasOwnProperty;\n\nvar typePropName = '__EMOTION_TYPE_PLEASE_DO_NOT_USE__';\nvar createEmotionProps = function createEmotionProps(type\n/*: React.ElementType */\n, props\n/*: Object */\n) {\n\n var newProps\n /*: any */\n = {};\n\n for (var key in props) {\n if (hasOwn.call(props, key)) {\n newProps[key] = props[key];\n }\n }\n\n newProps[typePropName] = type; // Runtime labeling is an opt-in feature because:\n\n return newProps;\n};\n\nvar Insertion = function Insertion(_ref) {\n var cache = _ref.cache,\n serialized = _ref.serialized,\n isStringTag = _ref.isStringTag;\n registerStyles(cache, serialized, isStringTag);\n useInsertionEffectAlwaysWithSyncFallback(function () {\n return insertStyles(cache, serialized, isStringTag);\n });\n\n return null;\n};\n\nvar Emotion = /* #__PURE__ */withEmotionCache(\n/* */\nfunction (props, cache, ref) {\n var cssProp = props.css; // so that using `css` from `emotion` and passing the result to the css prop works\n // not passing the registered cache to serializeStyles because it would\n // make certain babel optimisations not possible\n\n if (typeof cssProp === 'string' && cache.registered[cssProp] !== undefined) {\n cssProp = cache.registered[cssProp];\n }\n\n var WrappedComponent = props[typePropName];\n var registeredStyles = [cssProp];\n var className = '';\n\n if (typeof props.className === 'string') {\n className = getRegisteredStyles(cache.registered, registeredStyles, props.className);\n } else if (props.className != null) {\n className = props.className + \" \";\n }\n\n var serialized = serializeStyles(registeredStyles, undefined, React.useContext(ThemeContext));\n\n className += cache.key + \"-\" + serialized.name;\n var newProps = {};\n\n for (var key in props) {\n if (hasOwn.call(props, key) && key !== 'css' && key !== typePropName && (!isDevelopment )) {\n newProps[key] = props[key];\n }\n }\n\n newProps.className = className;\n\n if (ref) {\n newProps.ref = ref;\n }\n\n return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Insertion, {\n cache: cache,\n serialized: serialized,\n isStringTag: typeof WrappedComponent === 'string'\n }), /*#__PURE__*/React.createElement(WrappedComponent, newProps));\n});\n\nvar Emotion$1 = Emotion;\n\nexport { CacheProvider as C, Emotion$1 as E, ThemeContext as T, __unsafe_useEmotionCache as _, ThemeProvider as a, withTheme as b, createEmotionProps as c, hasOwn as h, isDevelopment as i, useTheme as u, withEmotionCache as w };\n","import { h as hasOwn, E as Emotion, c as createEmotionProps, w as withEmotionCache, T as ThemeContext, i as isDevelopment } from './emotion-element-5486c51c.browser.esm.js';\nexport { C as CacheProvider, T as ThemeContext, a as ThemeProvider, _ as __unsafe_useEmotionCache, u as useTheme, w as withEmotionCache, b as withTheme } from './emotion-element-5486c51c.browser.esm.js';\nimport * as React from 'react';\nimport { insertStyles, registerStyles, getRegisteredStyles } from '@emotion/utils';\nimport { useInsertionEffectWithLayoutFallback, useInsertionEffectAlwaysWithSyncFallback } from '@emotion/use-insertion-effect-with-fallbacks';\nimport { serializeStyles } from '@emotion/serialize';\nimport '@emotion/cache';\nimport '@babel/runtime/helpers/extends';\nimport '@emotion/weak-memoize';\nimport '../_isolated-hnrs/dist/emotion-react-_isolated-hnrs.browser.esm.js';\nimport 'hoist-non-react-statics';\n\nvar jsx\n/*: typeof React.createElement */\n= function jsx\n/*: typeof React.createElement */\n(type\n/*: React.ElementType */\n, props\n/*: Object */\n) {\n var args = arguments;\n\n if (props == null || !hasOwn.call(props, 'css')) {\n return React.createElement.apply(undefined, args);\n }\n\n var argsLength = args.length;\n var createElementArgArray = new Array(argsLength);\n createElementArgArray[0] = Emotion;\n createElementArgArray[1] = createEmotionProps(type, props);\n\n for (var i = 2; i < argsLength; i++) {\n createElementArgArray[i] = args[i];\n }\n\n return React.createElement.apply(null, createElementArgArray);\n};\n\n// initial render from browser, insertBefore context.sheet.tags[0] or if a style hasn't been inserted there yet, appendChild\n// initial client-side render from SSR, use place of hydrating tag\n\nvar Global\n/*: React.AbstractComponent<\nGlobalProps\n> */\n= /* #__PURE__ */withEmotionCache(function (props\n/*: GlobalProps */\n, cache) {\n\n var styles = props.styles;\n var serialized = serializeStyles([styles], undefined, React.useContext(ThemeContext));\n // but it is based on a constant that will never change at runtime\n // it's effectively like having two implementations and switching them out\n // so it's not actually breaking anything\n\n\n var sheetRef = React.useRef();\n useInsertionEffectWithLayoutFallback(function () {\n var key = cache.key + \"-global\"; // use case of https://github.com/emotion-js/emotion/issues/2675\n\n var sheet = new cache.sheet.constructor({\n key: key,\n nonce: cache.sheet.nonce,\n container: cache.sheet.container,\n speedy: cache.sheet.isSpeedy\n });\n var rehydrating = false;\n var node\n /*: HTMLStyleElement | null*/\n = document.querySelector(\"style[data-emotion=\\\"\" + key + \" \" + serialized.name + \"\\\"]\");\n\n if (cache.sheet.tags.length) {\n sheet.before = cache.sheet.tags[0];\n }\n\n if (node !== null) {\n rehydrating = true; // clear the hash so this node won't be recognizable as rehydratable by other s\n\n node.setAttribute('data-emotion', key);\n sheet.hydrate([node]);\n }\n\n sheetRef.current = [sheet, rehydrating];\n return function () {\n sheet.flush();\n };\n }, [cache]);\n useInsertionEffectWithLayoutFallback(function () {\n var sheetRefCurrent = sheetRef.current;\n var sheet = sheetRefCurrent[0],\n rehydrating = sheetRefCurrent[1];\n\n if (rehydrating) {\n sheetRefCurrent[1] = false;\n return;\n }\n\n if (serialized.next !== undefined) {\n // insert keyframes\n insertStyles(cache, serialized.next, true);\n }\n\n if (sheet.tags.length) {\n // if this doesn't exist then it will be null so the style element will be appended\n var element = sheet.tags[sheet.tags.length - 1].nextElementSibling;\n sheet.before = element;\n sheet.flush();\n }\n\n cache.insert(\"\", serialized, sheet, false);\n }, [cache, serialized.name]);\n return null;\n});\n\n/* import type { Interpolation, SerializedStyles } from '@emotion/utils' */\n\nfunction css()\n/*: SerializedStyles */\n{\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return serializeStyles(args);\n}\n\n/*\ntype Keyframes = {|\n name: string,\n styles: string,\n anim: 1,\n toString: () => string\n|} & string\n*/\n\nvar keyframes = function\n /*: Keyframes */\nkeyframes() {\n var insertable = css.apply(void 0, arguments);\n var name = \"animation-\" + insertable.name;\n return {\n name: name,\n styles: \"@keyframes \" + name + \"{\" + insertable.styles + \"}\",\n anim: 1,\n toString: function toString() {\n return \"_EMO_\" + this.name + \"_\" + this.styles + \"_EMO_\";\n }\n };\n};\n\n/*\ntype ClassNameArg =\n | string\n | boolean\n | { [key: string]: boolean }\n | Array\n | null\n | void\n*/\n\nvar classnames = function\n /*: string */\nclassnames(args\n/*: Array */\n) {\n var len = args.length;\n var i = 0;\n var cls = '';\n\n for (; i < len; i++) {\n var arg = args[i];\n if (arg == null) continue;\n var toAdd = void 0;\n\n switch (typeof arg) {\n case 'boolean':\n break;\n\n case 'object':\n {\n if (Array.isArray(arg)) {\n toAdd = classnames(arg);\n } else {\n\n toAdd = '';\n\n for (var k in arg) {\n if (arg[k] && k) {\n toAdd && (toAdd += ' ');\n toAdd += k;\n }\n }\n }\n\n break;\n }\n\n default:\n {\n toAdd = arg;\n }\n }\n\n if (toAdd) {\n cls && (cls += ' ');\n cls += toAdd;\n }\n }\n\n return cls;\n};\n\nfunction merge(registered\n/*: Object */\n, css\n/*: (...args: Array) => string */\n, className\n/*: string */\n) {\n var registeredStyles = [];\n var rawClassName = getRegisteredStyles(registered, registeredStyles, className);\n\n if (registeredStyles.length < 2) {\n return className;\n }\n\n return rawClassName + css(registeredStyles);\n}\n\nvar Insertion = function Insertion(_ref) {\n var cache = _ref.cache,\n serializedArr = _ref.serializedArr;\n useInsertionEffectAlwaysWithSyncFallback(function () {\n\n for (var i = 0; i < serializedArr.length; i++) {\n insertStyles(cache, serializedArr[i], false);\n }\n });\n\n return null;\n};\n/*\ntype Props = {\n children: ({\n css: (...args: any) => string,\n cx: (...args: Array) => string,\n theme: Object\n }) => React.Node\n} */\n\n\nvar ClassNames\n/*: React.AbstractComponent*/\n= /* #__PURE__ */withEmotionCache(function (props, cache) {\n var hasRendered = false;\n var serializedArr = [];\n\n var css = function css() {\n if (hasRendered && isDevelopment) {\n throw new Error('css can only be used during render');\n }\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var serialized = serializeStyles(args, cache.registered);\n serializedArr.push(serialized); // registration has to happen here as the result of this might get consumed by `cx`\n\n registerStyles(cache, serialized, false);\n return cache.key + \"-\" + serialized.name;\n };\n\n var cx = function cx() {\n if (hasRendered && isDevelopment) {\n throw new Error('cx can only be used during render');\n }\n\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n return merge(cache.registered, css, classnames(args));\n };\n\n var content = {\n css: css,\n cx: cx,\n theme: React.useContext(ThemeContext)\n };\n var ele = props.children(content);\n hasRendered = true;\n return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Insertion, {\n cache: cache,\n serializedArr: serializedArr\n }), ele);\n});\n\nexport { ClassNames, Global, jsx as createElement, css, jsx, keyframes };\n","var unitlessKeys = {\n animationIterationCount: 1,\n aspectRatio: 1,\n borderImageOutset: 1,\n borderImageSlice: 1,\n borderImageWidth: 1,\n boxFlex: 1,\n boxFlexGroup: 1,\n boxOrdinalGroup: 1,\n columnCount: 1,\n columns: 1,\n flex: 1,\n flexGrow: 1,\n flexPositive: 1,\n flexShrink: 1,\n flexNegative: 1,\n flexOrder: 1,\n gridRow: 1,\n gridRowEnd: 1,\n gridRowSpan: 1,\n gridRowStart: 1,\n gridColumn: 1,\n gridColumnEnd: 1,\n gridColumnSpan: 1,\n gridColumnStart: 1,\n msGridRow: 1,\n msGridRowSpan: 1,\n msGridColumn: 1,\n msGridColumnSpan: 1,\n fontWeight: 1,\n lineHeight: 1,\n opacity: 1,\n order: 1,\n orphans: 1,\n scale: 1,\n tabSize: 1,\n widows: 1,\n zIndex: 1,\n zoom: 1,\n WebkitLineClamp: 1,\n // SVG-related properties\n fillOpacity: 1,\n floodOpacity: 1,\n stopOpacity: 1,\n strokeDasharray: 1,\n strokeDashoffset: 1,\n strokeMiterlimit: 1,\n strokeOpacity: 1,\n strokeWidth: 1\n};\n\nexport { unitlessKeys as default };\n","import hashString from '@emotion/hash';\nimport unitless from '@emotion/unitless';\nimport memoize from '@emotion/memoize';\n\nvar isDevelopment = false;\n\nvar hyphenateRegex = /[A-Z]|^ms/g;\nvar animationRegex = /_EMO_([^_]+?)_([^]*?)_EMO_/g;\n\nvar isCustomProperty = function isCustomProperty(property) {\n return property.charCodeAt(1) === 45;\n};\n\nvar isProcessableValue = function isProcessableValue(value) {\n return value != null && typeof value !== 'boolean';\n};\n\nvar processStyleName = /* #__PURE__ */memoize(function (styleName) {\n return isCustomProperty(styleName) ? styleName : styleName.replace(hyphenateRegex, '-$&').toLowerCase();\n});\n\nvar processStyleValue = function processStyleValue(key, value) {\n switch (key) {\n case 'animation':\n case 'animationName':\n {\n if (typeof value === 'string') {\n return value.replace(animationRegex, function (match, p1, p2) {\n cursor = {\n name: p1,\n styles: p2,\n next: cursor\n };\n return p1;\n });\n }\n }\n }\n\n if (unitless[key] !== 1 && !isCustomProperty(key) && typeof value === 'number' && value !== 0) {\n return value + 'px';\n }\n\n return value;\n};\n\nvar noComponentSelectorMessage = 'Component selectors can only be used in conjunction with ' + '@emotion/babel-plugin, the swc Emotion plugin, or another Emotion-aware ' + 'compiler transform.';\n\nfunction handleInterpolation(mergedProps, registered, interpolation) {\n if (interpolation == null) {\n return '';\n }\n\n var componentSelector = interpolation;\n\n if (componentSelector.__emotion_styles !== undefined) {\n\n return componentSelector;\n }\n\n switch (typeof interpolation) {\n case 'boolean':\n {\n return '';\n }\n\n case 'object':\n {\n var keyframes = interpolation;\n\n if (keyframes.anim === 1) {\n cursor = {\n name: keyframes.name,\n styles: keyframes.styles,\n next: cursor\n };\n return keyframes.name;\n }\n\n var serializedStyles = interpolation;\n\n if (serializedStyles.styles !== undefined) {\n var next = serializedStyles.next;\n\n if (next !== undefined) {\n // not the most efficient thing ever but this is a pretty rare case\n // and there will be very few iterations of this generally\n while (next !== undefined) {\n cursor = {\n name: next.name,\n styles: next.styles,\n next: cursor\n };\n next = next.next;\n }\n }\n\n var styles = serializedStyles.styles + \";\";\n\n return styles;\n }\n\n return createStringFromObject(mergedProps, registered, interpolation);\n }\n\n case 'function':\n {\n if (mergedProps !== undefined) {\n var previousCursor = cursor;\n var result = interpolation(mergedProps);\n cursor = previousCursor;\n return handleInterpolation(mergedProps, registered, result);\n }\n\n break;\n }\n } // finalize string values (regular strings and functions interpolated into css calls)\n\n\n var asString = interpolation;\n\n if (registered == null) {\n return asString;\n }\n\n var cached = registered[asString];\n return cached !== undefined ? cached : asString;\n}\n\nfunction createStringFromObject(mergedProps, registered, obj) {\n var string = '';\n\n if (Array.isArray(obj)) {\n for (var i = 0; i < obj.length; i++) {\n string += handleInterpolation(mergedProps, registered, obj[i]) + \";\";\n }\n } else {\n for (var key in obj) {\n var value = obj[key];\n\n if (typeof value !== 'object') {\n var asString = value;\n\n if (registered != null && registered[asString] !== undefined) {\n string += key + \"{\" + registered[asString] + \"}\";\n } else if (isProcessableValue(asString)) {\n string += processStyleName(key) + \":\" + processStyleValue(key, asString) + \";\";\n }\n } else {\n if (key === 'NO_COMPONENT_SELECTOR' && isDevelopment) {\n throw new Error(noComponentSelectorMessage);\n }\n\n if (Array.isArray(value) && typeof value[0] === 'string' && (registered == null || registered[value[0]] === undefined)) {\n for (var _i = 0; _i < value.length; _i++) {\n if (isProcessableValue(value[_i])) {\n string += processStyleName(key) + \":\" + processStyleValue(key, value[_i]) + \";\";\n }\n }\n } else {\n var interpolated = handleInterpolation(mergedProps, registered, value);\n\n switch (key) {\n case 'animation':\n case 'animationName':\n {\n string += processStyleName(key) + \":\" + interpolated + \";\";\n break;\n }\n\n default:\n {\n\n string += key + \"{\" + interpolated + \"}\";\n }\n }\n }\n }\n }\n }\n\n return string;\n}\n\nvar labelPattern = /label:\\s*([^\\s;{]+)\\s*(;|$)/g;\n// keyframes are stored on the SerializedStyles object as a linked list\n\n\nvar cursor;\nfunction serializeStyles(args, registered, mergedProps) {\n if (args.length === 1 && typeof args[0] === 'object' && args[0] !== null && args[0].styles !== undefined) {\n return args[0];\n }\n\n var stringMode = true;\n var styles = '';\n cursor = undefined;\n var strings = args[0];\n\n if (strings == null || strings.raw === undefined) {\n stringMode = false;\n styles += handleInterpolation(mergedProps, registered, strings);\n } else {\n var asTemplateStringsArr = strings;\n\n styles += asTemplateStringsArr[0];\n } // we start at 1 since we've already handled the first arg\n\n\n for (var i = 1; i < args.length; i++) {\n styles += handleInterpolation(mergedProps, registered, args[i]);\n\n if (stringMode) {\n var templateStringsArr = strings;\n\n styles += templateStringsArr[i];\n }\n }\n\n\n labelPattern.lastIndex = 0;\n var identifierName = '';\n var match; // https://esbench.com/bench/5b809c2cf2949800a0f61fb5\n\n while ((match = labelPattern.exec(styles)) !== null) {\n identifierName += '-' + match[1];\n }\n\n var name = hashString(styles) + identifierName;\n\n return {\n name: name,\n styles: styles,\n next: cursor\n };\n}\n\nexport { serializeStyles };\n","/* eslint-disable */\n// Inspired by https://github.com/garycourt/murmurhash-js\n// Ported from https://github.com/aappleby/smhasher/blob/61a0530f28277f2e850bfc39600ce61d02b518de/src/MurmurHash2.cpp#L37-L86\nfunction murmur2(str) {\n // 'm' and 'r' are mixing constants generated offline.\n // They're not really 'magic', they just happen to work well.\n // const m = 0x5bd1e995;\n // const r = 24;\n // Initialize the hash\n var h = 0; // Mix 4 bytes at a time into the hash\n\n var k,\n i = 0,\n len = str.length;\n\n for (; len >= 4; ++i, len -= 4) {\n k = str.charCodeAt(i) & 0xff | (str.charCodeAt(++i) & 0xff) << 8 | (str.charCodeAt(++i) & 0xff) << 16 | (str.charCodeAt(++i) & 0xff) << 24;\n k =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16);\n k ^=\n /* k >>> r: */\n k >>> 24;\n h =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16) ^\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Handle the last few bytes of the input array\n\n\n switch (len) {\n case 3:\n h ^= (str.charCodeAt(i + 2) & 0xff) << 16;\n\n case 2:\n h ^= (str.charCodeAt(i + 1) & 0xff) << 8;\n\n case 1:\n h ^= str.charCodeAt(i) & 0xff;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Do a few final mixes of the hash to ensure the last few\n // bytes are well-incorporated.\n\n\n h ^= h >>> 13;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n return ((h ^ h >>> 15) >>> 0).toString(36);\n}\n\nexport { murmur2 as default };\n","import * as React from 'react';\n\nvar syncFallback = function syncFallback(create) {\n return create();\n};\n\nvar useInsertionEffect = React['useInsertion' + 'Effect'] ? React['useInsertion' + 'Effect'] : false;\nvar useInsertionEffectAlwaysWithSyncFallback = useInsertionEffect || syncFallback;\nvar useInsertionEffectWithLayoutFallback = useInsertionEffect || React.useLayoutEffect;\n\nexport { useInsertionEffectAlwaysWithSyncFallback, useInsertionEffectWithLayoutFallback };\n","var isBrowser = true;\n\nfunction getRegisteredStyles(registered, registeredStyles, classNames) {\n var rawClassName = '';\n classNames.split(' ').forEach(function (className) {\n if (registered[className] !== undefined) {\n registeredStyles.push(registered[className] + \";\");\n } else if (className) {\n rawClassName += className + \" \";\n }\n });\n return rawClassName;\n}\nvar registerStyles = function registerStyles(cache, serialized, isStringTag) {\n var className = cache.key + \"-\" + serialized.name;\n\n if ( // we only need to add the styles to the registered cache if the\n // class name could be used further down\n // the tree but if it's a string tag, we know it won't\n // so we don't have to add it to registered cache.\n // this improves memory usage since we can avoid storing the whole style string\n (isStringTag === false || // we need to always store it if we're in compat mode and\n // in node since emotion-server relies on whether a style is in\n // the registered cache to know whether a style is global or not\n // also, note that this check will be dead code eliminated in the browser\n isBrowser === false ) && cache.registered[className] === undefined) {\n cache.registered[className] = serialized.styles;\n }\n};\nvar insertStyles = function insertStyles(cache, serialized, isStringTag) {\n registerStyles(cache, serialized, isStringTag);\n var className = cache.key + \"-\" + serialized.name;\n\n if (cache.inserted[serialized.name] === undefined) {\n var current = serialized;\n\n do {\n cache.insert(serialized === current ? \".\" + className : '', current, cache.sheet, true);\n\n current = current.next;\n } while (current !== undefined);\n }\n};\n\nexport { getRegisteredStyles, insertStyles, registerStyles };\n","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nvar DEFAULT_SIZE = 24;\n\nexports.default = function (_ref) {\n var _ref$fill = _ref.fill,\n fill = _ref$fill === undefined ? 'currentColor' : _ref$fill,\n _ref$width = _ref.width,\n width = _ref$width === undefined ? DEFAULT_SIZE : _ref$width,\n _ref$height = _ref.height,\n height = _ref$height === undefined ? DEFAULT_SIZE : _ref$height,\n _ref$style = _ref.style,\n style = _ref$style === undefined ? {} : _ref$style,\n props = _objectWithoutProperties(_ref, ['fill', 'width', 'height', 'style']);\n\n return _react2.default.createElement(\n 'svg',\n _extends({\n viewBox: '0 0 ' + DEFAULT_SIZE + ' ' + DEFAULT_SIZE,\n style: _extends({ fill: fill, width: width, height: height }, style)\n }, props),\n _react2.default.createElement('path', { d: 'M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z' })\n );\n};","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nvar DEFAULT_SIZE = 24;\n\nexports.default = function (_ref) {\n var _ref$fill = _ref.fill,\n fill = _ref$fill === undefined ? 'currentColor' : _ref$fill,\n _ref$width = _ref.width,\n width = _ref$width === undefined ? DEFAULT_SIZE : _ref$width,\n _ref$height = _ref.height,\n height = _ref$height === undefined ? DEFAULT_SIZE : _ref$height,\n _ref$style = _ref.style,\n style = _ref$style === undefined ? {} : _ref$style,\n props = _objectWithoutProperties(_ref, ['fill', 'width', 'height', 'style']);\n\n return _react2.default.createElement(\n 'svg',\n _extends({\n viewBox: '0 0 ' + DEFAULT_SIZE + ' ' + DEFAULT_SIZE,\n style: _extends({ fill: fill, width: width, height: height }, style)\n }, props),\n _react2.default.createElement('path', { d: 'M12,18.17L8.83,15L7.42,16.41L12,21L16.59,16.41L15.17,15M12,5.83L15.17,9L16.58,7.59L12,3L7.41,7.59L8.83,9L12,5.83Z' })\n );\n};","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m0 4c1.93 0 3.5 1.57 3.5 3.5S13.93 13 12 13s-3.5-1.57-3.5-3.5S10.07 6 12 6m0 14c-2.03 0-4.43-.82-6.14-2.88C7.55 15.8 9.68 15 12 15s4.45.8 6.14 2.12C16.43 19.18 14.03 20 12 20\"\n}), 'AccountCircle');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M22 11V3h-7v3H9V3H2v8h7V8h2v10h4v3h7v-8h-7v3h-2V8h2v3z\"\n}), 'AccountTree');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6z\"\n}), 'Add');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M8 11h8v2H8zm12.1 1H22c0-2.76-2.24-5-5-5h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7c-2.76 0-5 2.24-5 5s2.24 5 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1M19 12h-2v3h-3v2h3v3h2v-3h3v-2h-3z\"\n}), 'AddLink');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M19 7v2.99s-1.99.01-2 0V7h-3s.01-1.99 0-2h3V2h2v3h3v2zm-3 4V8h-3V5H5c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2v-8zM5 19l3-4 2 3 3-4 4 5z\"\n}), 'AddPhotoAlternate');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2M9 17H7v-5h2zm4 0h-2v-3h2zm0-5h-2v-2h2zm4 5h-2V7h2z\"\n}), 'Analytics');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"m7 10 5 5 5-5z\"\n}), 'ArrowDropDown');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 6v3l4-4-4-4v3c-4.42 0-8 3.58-8 8 0 1.57.46 3.03 1.24 4.26L6.7 14.8c-.45-.83-.7-1.79-.7-2.8 0-3.31 2.69-6 6-6m6.76 1.74L17.3 9.2c.44.84.7 1.79.7 2.8 0 3.31-2.69 6-6 6v-3l-4 4 4 4v-3c4.42 0 8-3.58 8-8 0-1.57-.46-3.03-1.24-4.26\"\n}), 'Autorenew');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2M4 12c0-4.42 3.58-8 8-8 1.85 0 3.55.63 4.9 1.69L5.69 16.9C4.63 15.55 4 13.85 4 12m8 8c-1.85 0-3.55-.63-4.9-1.69L18.31 7.1C19.37 8.45 20 10.15 20 12c0 4.42-3.58 8-8 8\"\n}), 'Block');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2m5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12z\"\n}), 'Cancel');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M9 16.17 4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z\"\n}), 'Check');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2M9.29 16.29 5.7 12.7a.9959.9959 0 0 1 0-1.41c.39-.39 1.02-.39 1.41 0L10 14.17l6.88-6.88c.39-.39 1.02-.39 1.41 0 .39.39.39 1.02 0 1.41l-7.59 7.59c-.38.39-1.02.39-1.41 0\"\n}), 'CheckCircleRounded');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M11 7H2v2h9zm0 8H2v2h9zm5.34-4L12.8 7.46l1.41-1.41 2.12 2.12 4.24-4.24L22 5.34zm0 8-3.54-3.54 1.41-1.41 2.12 2.12 4.24-4.24L22 13.34z\"\n}), 'ChecklistRtl');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M10 6 8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z\"\n}), 'ChevronRight');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z\"\n}), 'Close');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M3 13h8V3H3zm0 8h8v-6H3zm10 0h8V11h-8zm0-18v6h8V3z\"\n}), 'Dashboard');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6zM19 4h-3.5l-1-1h-5l-1 1H5v2h14z\"\n}), 'Delete');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6zM8 9h8v10H8zm7.5-5-1-1h-5l-1 1H5v2h14V4z\"\n}), 'DeleteOutline');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z\"\n}), 'Done');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M3 17.25V21h3.75L17.81 9.94l-3.75-3.75zM20.71 7.04c.39-.39.39-1.02 0-1.41l-2.34-2.34a.9959.9959 0 0 0-1.41 0l-1.83 1.83 3.75 3.75z\"\n}), 'Edit');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m1 15h-2v-2h2zm0-4h-2V7h2z\"\n}), 'Error');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2M12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8\"\n}), 'ErrorOutline');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M10.09 15.59 11.5 17l5-5-5-5-1.41 1.41L12.67 11H3v2h9.67zM19 3H5c-1.11 0-2 .9-2 2v4h2V5h14v14H5v-4H3v4c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2\"\n}), 'ExitToApp');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M16.59 8.59 12 13.17 7.41 8.59 6 10l6 6 6-6z\"\n}), 'ExpandMore');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M10 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2h-8z\"\n}), 'Folder');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 12.75c1.63 0 3.07.39 4.24.9 1.08.48 1.76 1.56 1.76 2.73V18H6v-1.61c0-1.18.68-2.26 1.76-2.73 1.17-.52 2.61-.91 4.24-.91M4 13c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2m1.13 1.1c-.37-.06-.74-.1-1.13-.1-.99 0-1.93.21-2.78.58C.48 14.9 0 15.62 0 16.43V18h4.5v-1.61c0-.83.23-1.61.63-2.29M20 13c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2m4 3.43c0-.81-.48-1.53-1.22-1.85-.85-.37-1.79-.58-2.78-.58-.39 0-.76.04-1.13.1.4.68.63 1.46.63 2.29V18H24zM12 6c1.66 0 3 1.34 3 3s-1.34 3-3 3-3-1.34-3-3 1.34-3 3-3\"\n}), 'Groups');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n fillRule: \"evenodd\",\n d: \"M4 11h16v2H4z\"\n}), 'HorizontalRule');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8zM6 20V4h7v5h5v11z\"\n}), 'InsertDriveFileOutlined');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M7.41 8.59 12 13.17l4.59-4.58L18 10l-6 6-6-6z\"\n}), 'KeyboardArrowDown');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M7.41 15.41 12 10.83l4.59 4.58L18 14l-6-6-6 6z\"\n}), 'KeyboardArrowUp');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"m17 7-1.41 1.41L18.17 11H8v2h10.17l-2.58 2.58L17 17l5-5zM4 5h8V3H4c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h8v-2H4z\"\n}), 'Logout');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)([/*#__PURE__*/(0, _jsxRuntime.jsx)(\"circle\", {\n cx: \"10\",\n cy: \"8\",\n r: \"4\"\n}, \"0\"), /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M10.67 13.02c-.22-.01-.44-.02-.67-.02-2.42 0-4.68.67-6.61 1.82-.88.52-1.39 1.5-1.39 2.53V20h9.26c-.79-1.13-1.26-2.51-1.26-4 0-1.07.25-2.07.67-2.98M20.75 16c0-.22-.03-.42-.06-.63l1.14-1.01-1-1.73-1.45.49c-.32-.27-.68-.48-1.08-.63L18 11h-2l-.3 1.49c-.4.15-.76.36-1.08.63l-1.45-.49-1 1.73 1.14 1.01c-.03.21-.06.41-.06.63s.03.42.06.63l-1.14 1.01 1 1.73 1.45-.49c.32.27.68.48 1.08.63L16 21h2l.3-1.49c.4-.15.76-.36 1.08-.63l1.45.49 1-1.73-1.14-1.01c.03-.21.06-.41.06-.63M17 18c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2\"\n}, \"1\")], 'ManageAccounts');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M3 18h18v-2H3zm0-5h18v-2H3zm0-7v2h18V6z\"\n}), 'Menu');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 12.25c1.24 0 2.25-1.01 2.25-2.25S13.24 7.75 12 7.75 9.75 8.76 9.75 10s1.01 2.25 2.25 2.25m4.5 4c0-1.5-3-2.25-4.5-2.25s-4.5.75-4.5 2.25V17h9zM19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2m0 16H5V5h14z\"\n}), 'Portrait');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 5V1L7 6l5 5V7c3.31 0 6 2.69 6 6s-2.69 6-6 6-6-2.69-6-6H4c0 4.42 3.58 8 8 8s8-3.58 8-8-3.58-8-8-8\"\n}), 'Replay');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M10 9V5l-7 7 7 7v-4.1c5 0 8.5 1.6 11 5.1-1-5-4-10-11-11\"\n}), 'Reply');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M19 15.18V7c0-2.21-1.79-4-4-4s-4 1.79-4 4v10c0 1.1-.9 2-2 2s-2-.9-2-2V8.82C8.16 8.4 9 7.3 9 6c0-1.66-1.34-3-3-3S3 4.34 3 6c0 1.3.84 2.4 2 2.82V17c0 2.21 1.79 4 4 4s4-1.79 4-4V7c0-1.1.9-2 2-2s2 .9 2 2v8.18c-1.16.41-2 1.51-2 2.82 0 1.66 1.34 3 3 3s3-1.34 3-3c0-1.3-.84-2.4-2-2.82\"\n}), 'Route');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M19.14 12.94c.04-.3.06-.61.06-.94 0-.32-.02-.64-.07-.94l2.03-1.58c.18-.14.23-.41.12-.61l-1.92-3.32c-.12-.22-.37-.29-.59-.22l-2.39.96c-.5-.38-1.03-.7-1.62-.94l-.36-2.54c-.04-.24-.24-.41-.48-.41h-3.84c-.24 0-.43.17-.47.41l-.36 2.54c-.59.24-1.13.57-1.62.94l-2.39-.96c-.22-.08-.47 0-.59.22L2.74 8.87c-.12.21-.08.47.12.61l2.03 1.58c-.05.3-.09.63-.09.94s.02.64.07.94l-2.03 1.58c-.18.14-.23.41-.12.61l1.92 3.32c.12.22.37.29.59.22l2.39-.96c.5.38 1.03.7 1.62.94l.36 2.54c.05.24.24.41.48.41h3.84c.24 0 .44-.17.47-.41l.36-2.54c.59-.24 1.13-.56 1.62-.94l2.39.96c.22.08.47 0 .59-.22l1.92-3.32c.12-.22.07-.47-.12-.61zM12 15.6c-1.98 0-3.6-1.62-3.6-3.6s1.62-3.6 3.6-3.6 3.6 1.62 3.6 3.6-1.62 3.6-3.6 3.6\"\n}), 'Settings');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)([/*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M18 2h-8L4 8v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2m0 2v16H6V8.83L10.83 4z\"\n}, \"0\"), /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"m16 13-4 4-4-4 1.41-1.41L11 13.17V9.02L13 9v4.17l1.59-1.59z\"\n}, \"1\")], 'SimCardDownloadOutlined');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M3 17v2h6v-2zM3 5v2h10V5zm10 16v-2h8v-2h-8v-2h-2v6zM7 9v2H3v2h4v2h2V9zm14 4v-2H11v2zm-6-4h2V7h4V5h-4V3h-2z\"\n}), 'Tune');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5M12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5m0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3\"\n}), 'Visibility');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 7c2.76 0 5 2.24 5 5 0 .65-.13 1.26-.36 1.83l2.92 2.92c1.51-1.26 2.7-2.89 3.43-4.75-1.73-4.39-6-7.5-11-7.5-1.4 0-2.74.25-3.98.7l2.16 2.16C10.74 7.13 11.35 7 12 7M2 4.27l2.28 2.28.46.46C3.08 8.3 1.78 10.02 1 12c1.73 4.39 6 7.5 11 7.5 1.55 0 3.03-.3 4.38-.84l.42.42L19.73 22 21 20.73 3.27 3zM7.53 9.8l1.55 1.55c-.05.21-.08.43-.08.65 0 1.66 1.34 3 3 3 .22 0 .44-.03.65-.08l1.55 1.55c-.67.33-1.41.53-2.2.53-2.76 0-5-2.24-5-5 0-.79.2-1.53.53-2.2m4.31-.78 3.15 3.15.02-.16c0-1.66-1.34-3-3-3z\"\n}), 'VisibilityOff');","\"use strict\";\n\"use client\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\nvar _jsxRuntime = require(\"react/jsx-runtime\");\nvar _default = exports.default = (0, _createSvgIcon.default)( /*#__PURE__*/(0, _jsxRuntime.jsx)(\"path\", {\n d: \"M12 5.99 19.53 19H4.47zM2.74 18c-.77 1.33.19 3 1.73 3h15.06c1.54 0 2.5-1.67 1.73-3L13.73 4.99c-.77-1.33-2.69-1.33-3.46 0zM11 11v2c0 .55.45 1 1 1s1-.45 1-1v-2c0-.55-.45-1-1-1s-1 .45-1 1m0 5h2v2h-2z\"\n}), 'WarningAmberRounded');","\"use strict\";\n'use client';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"default\", {\n enumerable: true,\n get: function () {\n return _utils.createSvgIcon;\n }\n});\nvar _utils = require(\"@mui/material/utils\");","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport SystemDefaultPropsProvider, { useDefaultProps as useSystemDefaultProps } from '@mui/system/DefaultPropsProvider';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nfunction DefaultPropsProvider(props) {\n return /*#__PURE__*/_jsx(SystemDefaultPropsProvider, _extends({}, props));\n}\nprocess.env.NODE_ENV !== \"production\" ? DefaultPropsProvider.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the TypeScript types and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * @ignore\n */\n children: PropTypes.node,\n /**\n * @ignore\n */\n value: PropTypes.object.isRequired\n} : void 0;\nexport default DefaultPropsProvider;\nexport function useDefaultProps(params) {\n return useSystemDefaultProps(params);\n}","const green = {\n 50: '#e8f5e9',\n 100: '#c8e6c9',\n 200: '#a5d6a7',\n 300: '#81c784',\n 400: '#66bb6a',\n 500: '#4caf50',\n 600: '#43a047',\n 700: '#388e3c',\n 800: '#2e7d32',\n 900: '#1b5e20',\n A100: '#b9f6ca',\n A200: '#69f0ae',\n A400: '#00e676',\n A700: '#00c853'\n};\nexport default green;","const grey = {\n 50: '#fafafa',\n 100: '#f5f5f5',\n 200: '#eeeeee',\n 300: '#e0e0e0',\n 400: '#bdbdbd',\n 500: '#9e9e9e',\n 600: '#757575',\n 700: '#616161',\n 800: '#424242',\n 900: '#212121',\n A100: '#f5f5f5',\n A200: '#eeeeee',\n A400: '#bdbdbd',\n A700: '#616161'\n};\nexport default grey;","const orange = {\n 50: '#fff3e0',\n 100: '#ffe0b2',\n 200: '#ffcc80',\n 300: '#ffb74d',\n 400: '#ffa726',\n 500: '#ff9800',\n 600: '#fb8c00',\n 700: '#f57c00',\n 800: '#ef6c00',\n 900: '#e65100',\n A100: '#ffd180',\n A200: '#ffab40',\n A400: '#ff9100',\n A700: '#ff6d00'\n};\nexport default orange;","const purple = {\n 50: '#f3e5f5',\n 100: '#e1bee7',\n 200: '#ce93d8',\n 300: '#ba68c8',\n 400: '#ab47bc',\n 500: '#9c27b0',\n 600: '#8e24aa',\n 700: '#7b1fa2',\n 800: '#6a1b9a',\n 900: '#4a148c',\n A100: '#ea80fc',\n A200: '#e040fb',\n A400: '#d500f9',\n A700: '#aa00ff'\n};\nexport default purple;","const red = {\n 50: '#ffebee',\n 100: '#ffcdd2',\n 200: '#ef9a9a',\n 300: '#e57373',\n 400: '#ef5350',\n 500: '#f44336',\n 600: '#e53935',\n 700: '#d32f2f',\n 800: '#c62828',\n 900: '#b71c1c',\n A100: '#ff8a80',\n A200: '#ff5252',\n A400: '#ff1744',\n A700: '#d50000'\n};\nexport default red;","const common = {\n black: '#000',\n white: '#fff'\n};\nexport default common;","const blue = {\n 50: '#e3f2fd',\n 100: '#bbdefb',\n 200: '#90caf9',\n 300: '#64b5f6',\n 400: '#42a5f5',\n 500: '#2196f3',\n 600: '#1e88e5',\n 700: '#1976d2',\n 800: '#1565c0',\n 900: '#0d47a1',\n A100: '#82b1ff',\n A200: '#448aff',\n A400: '#2979ff',\n A700: '#2962ff'\n};\nexport default blue;","const lightBlue = {\n 50: '#e1f5fe',\n 100: '#b3e5fc',\n 200: '#81d4fa',\n 300: '#4fc3f7',\n 400: '#29b6f6',\n 500: '#03a9f4',\n 600: '#039be5',\n 700: '#0288d1',\n 800: '#0277bd',\n 900: '#01579b',\n A100: '#80d8ff',\n A200: '#40c4ff',\n A400: '#00b0ff',\n A700: '#0091ea'\n};\nexport default lightBlue;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _formatMuiErrorMessage from \"@mui/utils/formatMuiErrorMessage\";\nconst _excluded = [\"mode\", \"contrastThreshold\", \"tonalOffset\"];\nimport deepmerge from '@mui/utils/deepmerge';\nimport { darken, getContrastRatio, lighten } from '@mui/system/colorManipulator';\nimport common from '../colors/common';\nimport grey from '../colors/grey';\nimport purple from '../colors/purple';\nimport red from '../colors/red';\nimport orange from '../colors/orange';\nimport blue from '../colors/blue';\nimport lightBlue from '../colors/lightBlue';\nimport green from '../colors/green';\nexport const light = {\n // The colors used to style the text.\n text: {\n // The most important text.\n primary: 'rgba(0, 0, 0, 0.87)',\n // Secondary text.\n secondary: 'rgba(0, 0, 0, 0.6)',\n // Disabled text have even lower visual prominence.\n disabled: 'rgba(0, 0, 0, 0.38)'\n },\n // The color used to divide different elements.\n divider: 'rgba(0, 0, 0, 0.12)',\n // The background colors used to style the surfaces.\n // Consistency between these values is important.\n background: {\n paper: common.white,\n default: common.white\n },\n // The colors used to style the action elements.\n action: {\n // The color of an active action like an icon button.\n active: 'rgba(0, 0, 0, 0.54)',\n // The color of an hovered action.\n hover: 'rgba(0, 0, 0, 0.04)',\n hoverOpacity: 0.04,\n // The color of a selected action.\n selected: 'rgba(0, 0, 0, 0.08)',\n selectedOpacity: 0.08,\n // The color of a disabled action.\n disabled: 'rgba(0, 0, 0, 0.26)',\n // The background color of a disabled action.\n disabledBackground: 'rgba(0, 0, 0, 0.12)',\n disabledOpacity: 0.38,\n focus: 'rgba(0, 0, 0, 0.12)',\n focusOpacity: 0.12,\n activatedOpacity: 0.12\n }\n};\nexport const dark = {\n text: {\n primary: common.white,\n secondary: 'rgba(255, 255, 255, 0.7)',\n disabled: 'rgba(255, 255, 255, 0.5)',\n icon: 'rgba(255, 255, 255, 0.5)'\n },\n divider: 'rgba(255, 255, 255, 0.12)',\n background: {\n paper: '#121212',\n default: '#121212'\n },\n action: {\n active: common.white,\n hover: 'rgba(255, 255, 255, 0.08)',\n hoverOpacity: 0.08,\n selected: 'rgba(255, 255, 255, 0.16)',\n selectedOpacity: 0.16,\n disabled: 'rgba(255, 255, 255, 0.3)',\n disabledBackground: 'rgba(255, 255, 255, 0.12)',\n disabledOpacity: 0.38,\n focus: 'rgba(255, 255, 255, 0.12)',\n focusOpacity: 0.12,\n activatedOpacity: 0.24\n }\n};\nfunction addLightOrDark(intent, direction, shade, tonalOffset) {\n const tonalOffsetLight = tonalOffset.light || tonalOffset;\n const tonalOffsetDark = tonalOffset.dark || tonalOffset * 1.5;\n if (!intent[direction]) {\n if (intent.hasOwnProperty(shade)) {\n intent[direction] = intent[shade];\n } else if (direction === 'light') {\n intent.light = lighten(intent.main, tonalOffsetLight);\n } else if (direction === 'dark') {\n intent.dark = darken(intent.main, tonalOffsetDark);\n }\n }\n}\nfunction getDefaultPrimary(mode = 'light') {\n if (mode === 'dark') {\n return {\n main: blue[200],\n light: blue[50],\n dark: blue[400]\n };\n }\n return {\n main: blue[700],\n light: blue[400],\n dark: blue[800]\n };\n}\nfunction getDefaultSecondary(mode = 'light') {\n if (mode === 'dark') {\n return {\n main: purple[200],\n light: purple[50],\n dark: purple[400]\n };\n }\n return {\n main: purple[500],\n light: purple[300],\n dark: purple[700]\n };\n}\nfunction getDefaultError(mode = 'light') {\n if (mode === 'dark') {\n return {\n main: red[500],\n light: red[300],\n dark: red[700]\n };\n }\n return {\n main: red[700],\n light: red[400],\n dark: red[800]\n };\n}\nfunction getDefaultInfo(mode = 'light') {\n if (mode === 'dark') {\n return {\n main: lightBlue[400],\n light: lightBlue[300],\n dark: lightBlue[700]\n };\n }\n return {\n main: lightBlue[700],\n light: lightBlue[500],\n dark: lightBlue[900]\n };\n}\nfunction getDefaultSuccess(mode = 'light') {\n if (mode === 'dark') {\n return {\n main: green[400],\n light: green[300],\n dark: green[700]\n };\n }\n return {\n main: green[800],\n light: green[500],\n dark: green[900]\n };\n}\nfunction getDefaultWarning(mode = 'light') {\n if (mode === 'dark') {\n return {\n main: orange[400],\n light: orange[300],\n dark: orange[700]\n };\n }\n return {\n main: '#ed6c02',\n // closest to orange[800] that pass 3:1.\n light: orange[500],\n dark: orange[900]\n };\n}\nexport default function createPalette(palette) {\n const {\n mode = 'light',\n contrastThreshold = 3,\n tonalOffset = 0.2\n } = palette,\n other = _objectWithoutPropertiesLoose(palette, _excluded);\n const primary = palette.primary || getDefaultPrimary(mode);\n const secondary = palette.secondary || getDefaultSecondary(mode);\n const error = palette.error || getDefaultError(mode);\n const info = palette.info || getDefaultInfo(mode);\n const success = palette.success || getDefaultSuccess(mode);\n const warning = palette.warning || getDefaultWarning(mode);\n\n // Use the same logic as\n // Bootstrap: https://github.com/twbs/bootstrap/blob/1d6e3710dd447de1a200f29e8fa521f8a0908f70/scss/_functions.scss#L59\n // and material-components-web https://github.com/material-components/material-components-web/blob/ac46b8863c4dab9fc22c4c662dc6bd1b65dd652f/packages/mdc-theme/_functions.scss#L54\n function getContrastText(background) {\n const contrastText = getContrastRatio(background, dark.text.primary) >= contrastThreshold ? dark.text.primary : light.text.primary;\n if (process.env.NODE_ENV !== 'production') {\n const contrast = getContrastRatio(background, contrastText);\n if (contrast < 3) {\n console.error([`MUI: The contrast ratio of ${contrast}:1 for ${contrastText} on ${background}`, 'falls below the WCAG recommended absolute minimum contrast ratio of 3:1.', 'https://www.w3.org/TR/2008/REC-WCAG20-20081211/#visual-audio-contrast-contrast'].join('\\n'));\n }\n }\n return contrastText;\n }\n const augmentColor = ({\n color,\n name,\n mainShade = 500,\n lightShade = 300,\n darkShade = 700\n }) => {\n color = _extends({}, color);\n if (!color.main && color[mainShade]) {\n color.main = color[mainShade];\n }\n if (!color.hasOwnProperty('main')) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: The color${name ? ` (${name})` : ''} provided to augmentColor(color) is invalid.\nThe color object needs to have a \\`main\\` property or a \\`${mainShade}\\` property.` : _formatMuiErrorMessage(11, name ? ` (${name})` : '', mainShade));\n }\n if (typeof color.main !== 'string') {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: The color${name ? ` (${name})` : ''} provided to augmentColor(color) is invalid.\n\\`color.main\\` should be a string, but \\`${JSON.stringify(color.main)}\\` was provided instead.\n\nDid you intend to use one of the following approaches?\n\nimport { green } from \"@mui/material/colors\";\n\nconst theme1 = createTheme({ palette: {\n primary: green,\n} });\n\nconst theme2 = createTheme({ palette: {\n primary: { main: green[500] },\n} });` : _formatMuiErrorMessage(12, name ? ` (${name})` : '', JSON.stringify(color.main)));\n }\n addLightOrDark(color, 'light', lightShade, tonalOffset);\n addLightOrDark(color, 'dark', darkShade, tonalOffset);\n if (!color.contrastText) {\n color.contrastText = getContrastText(color.main);\n }\n return color;\n };\n const modes = {\n dark,\n light\n };\n if (process.env.NODE_ENV !== 'production') {\n if (!modes[mode]) {\n console.error(`MUI: The palette mode \\`${mode}\\` is not supported.`);\n }\n }\n const paletteOutput = deepmerge(_extends({\n // A collection of common colors.\n common: _extends({}, common),\n // prevent mutable object.\n // The palette mode, can be light or dark.\n mode,\n // The colors used to represent primary interface elements for a user.\n primary: augmentColor({\n color: primary,\n name: 'primary'\n }),\n // The colors used to represent secondary interface elements for a user.\n secondary: augmentColor({\n color: secondary,\n name: 'secondary',\n mainShade: 'A400',\n lightShade: 'A200',\n darkShade: 'A700'\n }),\n // The colors used to represent interface elements that the user should be made aware of.\n error: augmentColor({\n color: error,\n name: 'error'\n }),\n // The colors used to represent potentially dangerous actions or important messages.\n warning: augmentColor({\n color: warning,\n name: 'warning'\n }),\n // The colors used to present information to the user that is neutral and not necessarily important.\n info: augmentColor({\n color: info,\n name: 'info'\n }),\n // The colors used to indicate the successful completion of an action that user triggered.\n success: augmentColor({\n color: success,\n name: 'success'\n }),\n // The grey colors.\n grey,\n // Used by `getContrastText()` to maximize the contrast between\n // the background and the text.\n contrastThreshold,\n // Takes a background color and returns the text color that maximizes the contrast.\n getContrastText,\n // Generate a rich color object.\n augmentColor,\n // Used by the functions below to shift a color's luminance by approximately\n // two indexes within its tonal palette.\n // E.g., shift from Red 500 to Red 300 or Red 700.\n tonalOffset\n }, modes[mode]), other);\n return paletteOutput;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"fontFamily\", \"fontSize\", \"fontWeightLight\", \"fontWeightRegular\", \"fontWeightMedium\", \"fontWeightBold\", \"htmlFontSize\", \"allVariants\", \"pxToRem\"];\nimport deepmerge from '@mui/utils/deepmerge';\nfunction round(value) {\n return Math.round(value * 1e5) / 1e5;\n}\nconst caseAllCaps = {\n textTransform: 'uppercase'\n};\nconst defaultFontFamily = '\"Roboto\", \"Helvetica\", \"Arial\", sans-serif';\n\n/**\n * @see @link{https://m2.material.io/design/typography/the-type-system.html}\n * @see @link{https://m2.material.io/design/typography/understanding-typography.html}\n */\nexport default function createTypography(palette, typography) {\n const _ref = typeof typography === 'function' ? typography(palette) : typography,\n {\n fontFamily = defaultFontFamily,\n // The default font size of the Material Specification.\n fontSize = 14,\n // px\n fontWeightLight = 300,\n fontWeightRegular = 400,\n fontWeightMedium = 500,\n fontWeightBold = 700,\n // Tell MUI what's the font-size on the html element.\n // 16px is the default font-size used by browsers.\n htmlFontSize = 16,\n // Apply the CSS properties to all the variants.\n allVariants,\n pxToRem: pxToRem2\n } = _ref,\n other = _objectWithoutPropertiesLoose(_ref, _excluded);\n if (process.env.NODE_ENV !== 'production') {\n if (typeof fontSize !== 'number') {\n console.error('MUI: `fontSize` is required to be a number.');\n }\n if (typeof htmlFontSize !== 'number') {\n console.error('MUI: `htmlFontSize` is required to be a number.');\n }\n }\n const coef = fontSize / 14;\n const pxToRem = pxToRem2 || (size => `${size / htmlFontSize * coef}rem`);\n const buildVariant = (fontWeight, size, lineHeight, letterSpacing, casing) => _extends({\n fontFamily,\n fontWeight,\n fontSize: pxToRem(size),\n // Unitless following https://meyerweb.com/eric/thoughts/2006/02/08/unitless-line-heights/\n lineHeight\n }, fontFamily === defaultFontFamily ? {\n letterSpacing: `${round(letterSpacing / size)}em`\n } : {}, casing, allVariants);\n const variants = {\n h1: buildVariant(fontWeightLight, 96, 1.167, -1.5),\n h2: buildVariant(fontWeightLight, 60, 1.2, -0.5),\n h3: buildVariant(fontWeightRegular, 48, 1.167, 0),\n h4: buildVariant(fontWeightRegular, 34, 1.235, 0.25),\n h5: buildVariant(fontWeightRegular, 24, 1.334, 0),\n h6: buildVariant(fontWeightMedium, 20, 1.6, 0.15),\n subtitle1: buildVariant(fontWeightRegular, 16, 1.75, 0.15),\n subtitle2: buildVariant(fontWeightMedium, 14, 1.57, 0.1),\n body1: buildVariant(fontWeightRegular, 16, 1.5, 0.15),\n body2: buildVariant(fontWeightRegular, 14, 1.43, 0.15),\n button: buildVariant(fontWeightMedium, 14, 1.75, 0.4, caseAllCaps),\n caption: buildVariant(fontWeightRegular, 12, 1.66, 0.4),\n overline: buildVariant(fontWeightRegular, 12, 2.66, 1, caseAllCaps),\n // TODO v6: Remove handling of 'inherit' variant from the theme as it is already handled in Material UI's Typography component. Also, remember to remove the associated types.\n inherit: {\n fontFamily: 'inherit',\n fontWeight: 'inherit',\n fontSize: 'inherit',\n lineHeight: 'inherit',\n letterSpacing: 'inherit'\n }\n };\n return deepmerge(_extends({\n htmlFontSize,\n pxToRem,\n fontFamily,\n fontSize,\n fontWeightLight,\n fontWeightRegular,\n fontWeightMedium,\n fontWeightBold\n }, variants), other, {\n clone: false // No need to clone deep\n });\n}","const shadowKeyUmbraOpacity = 0.2;\nconst shadowKeyPenumbraOpacity = 0.14;\nconst shadowAmbientShadowOpacity = 0.12;\nfunction createShadow(...px) {\n return [`${px[0]}px ${px[1]}px ${px[2]}px ${px[3]}px rgba(0,0,0,${shadowKeyUmbraOpacity})`, `${px[4]}px ${px[5]}px ${px[6]}px ${px[7]}px rgba(0,0,0,${shadowKeyPenumbraOpacity})`, `${px[8]}px ${px[9]}px ${px[10]}px ${px[11]}px rgba(0,0,0,${shadowAmbientShadowOpacity})`].join(',');\n}\n\n// Values from https://github.com/material-components/material-components-web/blob/be8747f94574669cb5e7add1a7c54fa41a89cec7/packages/mdc-elevation/_variables.scss\nconst shadows = ['none', createShadow(0, 2, 1, -1, 0, 1, 1, 0, 0, 1, 3, 0), createShadow(0, 3, 1, -2, 0, 2, 2, 0, 0, 1, 5, 0), createShadow(0, 3, 3, -2, 0, 3, 4, 0, 0, 1, 8, 0), createShadow(0, 2, 4, -1, 0, 4, 5, 0, 0, 1, 10, 0), createShadow(0, 3, 5, -1, 0, 5, 8, 0, 0, 1, 14, 0), createShadow(0, 3, 5, -1, 0, 6, 10, 0, 0, 1, 18, 0), createShadow(0, 4, 5, -2, 0, 7, 10, 1, 0, 2, 16, 1), createShadow(0, 5, 5, -3, 0, 8, 10, 1, 0, 3, 14, 2), createShadow(0, 5, 6, -3, 0, 9, 12, 1, 0, 3, 16, 2), createShadow(0, 6, 6, -3, 0, 10, 14, 1, 0, 4, 18, 3), createShadow(0, 6, 7, -4, 0, 11, 15, 1, 0, 4, 20, 3), createShadow(0, 7, 8, -4, 0, 12, 17, 2, 0, 5, 22, 4), createShadow(0, 7, 8, -4, 0, 13, 19, 2, 0, 5, 24, 4), createShadow(0, 7, 9, -4, 0, 14, 21, 2, 0, 5, 26, 4), createShadow(0, 8, 9, -5, 0, 15, 22, 2, 0, 6, 28, 5), createShadow(0, 8, 10, -5, 0, 16, 24, 2, 0, 6, 30, 5), createShadow(0, 8, 11, -5, 0, 17, 26, 2, 0, 6, 32, 5), createShadow(0, 9, 11, -5, 0, 18, 28, 2, 0, 7, 34, 6), createShadow(0, 9, 12, -6, 0, 19, 29, 2, 0, 7, 36, 6), createShadow(0, 10, 13, -6, 0, 20, 31, 3, 0, 8, 38, 7), createShadow(0, 10, 13, -6, 0, 21, 33, 3, 0, 8, 40, 7), createShadow(0, 10, 14, -6, 0, 22, 35, 3, 0, 8, 42, 7), createShadow(0, 11, 14, -7, 0, 23, 36, 3, 0, 9, 44, 8), createShadow(0, 11, 15, -7, 0, 24, 38, 3, 0, 9, 46, 8)];\nexport default shadows;","// We need to centralize the zIndex definitions as they work\n// like global values in the browser.\nconst zIndex = {\n mobileStepper: 1000,\n fab: 1050,\n speedDial: 1050,\n appBar: 1100,\n drawer: 1200,\n modal: 1300,\n snackbar: 1400,\n tooltip: 1500\n};\nexport default zIndex;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _formatMuiErrorMessage from \"@mui/utils/formatMuiErrorMessage\";\nconst _excluded = [\"breakpoints\", \"mixins\", \"spacing\", \"palette\", \"transitions\", \"typography\", \"shape\"];\nimport deepmerge from '@mui/utils/deepmerge';\nimport styleFunctionSx, { unstable_defaultSxConfig as defaultSxConfig } from '@mui/system/styleFunctionSx';\nimport systemCreateTheme from '@mui/system/createTheme';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nimport createMixins from './createMixins';\nimport createPalette from './createPalette';\nimport createTypography from './createTypography';\nimport shadows from './shadows';\nimport createTransitions from './createTransitions';\nimport zIndex from './zIndex';\nfunction createTheme(options = {}, ...args) {\n const {\n mixins: mixinsInput = {},\n palette: paletteInput = {},\n transitions: transitionsInput = {},\n typography: typographyInput = {}\n } = options,\n other = _objectWithoutPropertiesLoose(options, _excluded);\n if (options.vars) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: \\`vars\\` is a private field used for CSS variables support.\nPlease use another name.` : _formatMuiErrorMessage(18));\n }\n const palette = createPalette(paletteInput);\n const systemTheme = systemCreateTheme(options);\n let muiTheme = deepmerge(systemTheme, {\n mixins: createMixins(systemTheme.breakpoints, mixinsInput),\n palette,\n // Don't use [...shadows] until you've verified its transpiled code is not invoking the iterator protocol.\n shadows: shadows.slice(),\n typography: createTypography(palette, typographyInput),\n transitions: createTransitions(transitionsInput),\n zIndex: _extends({}, zIndex)\n });\n muiTheme = deepmerge(muiTheme, other);\n muiTheme = args.reduce((acc, argument) => deepmerge(acc, argument), muiTheme);\n if (process.env.NODE_ENV !== 'production') {\n // TODO v6: Refactor to use globalStateClassesMapping from @mui/utils once `readOnly` state class is used in Rating component.\n const stateClasses = ['active', 'checked', 'completed', 'disabled', 'error', 'expanded', 'focused', 'focusVisible', 'required', 'selected'];\n const traverse = (node, component) => {\n let key;\n\n // eslint-disable-next-line guard-for-in, no-restricted-syntax\n for (key in node) {\n const child = node[key];\n if (stateClasses.indexOf(key) !== -1 && Object.keys(child).length > 0) {\n if (process.env.NODE_ENV !== 'production') {\n const stateClass = generateUtilityClass('', key);\n console.error([`MUI: The \\`${component}\\` component increases ` + `the CSS specificity of the \\`${key}\\` internal state.`, 'You can not override it like this: ', JSON.stringify(node, null, 2), '', `Instead, you need to use the '&.${stateClass}' syntax:`, JSON.stringify({\n root: {\n [`&.${stateClass}`]: child\n }\n }, null, 2), '', 'https://mui.com/r/state-classes-guide'].join('\\n'));\n }\n // Remove the style to prevent global conflicts.\n node[key] = {};\n }\n }\n };\n Object.keys(muiTheme.components).forEach(component => {\n const styleOverrides = muiTheme.components[component].styleOverrides;\n if (styleOverrides && component.indexOf('Mui') === 0) {\n traverse(styleOverrides, component);\n }\n });\n }\n muiTheme.unstable_sxConfig = _extends({}, defaultSxConfig, other == null ? void 0 : other.unstable_sxConfig);\n muiTheme.unstable_sx = function sx(props) {\n return styleFunctionSx({\n sx: props,\n theme: this\n });\n };\n return muiTheme;\n}\nlet warnedOnce = false;\nexport function createMuiTheme(...args) {\n if (process.env.NODE_ENV !== 'production') {\n if (!warnedOnce) {\n warnedOnce = true;\n console.error(['MUI: the createMuiTheme function was renamed to createTheme.', '', \"You should use `import { createTheme } from '@mui/material/styles'`\"].join('\\n'));\n }\n }\n return createTheme(...args);\n}\nexport default createTheme;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nexport default function createMixins(breakpoints, mixins) {\n return _extends({\n toolbar: {\n minHeight: 56,\n [breakpoints.up('xs')]: {\n '@media (orientation: landscape)': {\n minHeight: 48\n }\n },\n [breakpoints.up('sm')]: {\n minHeight: 64\n }\n }\n }, mixins);\n}","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nconst _excluded = [\"duration\", \"easing\", \"delay\"];\n// Follow https://material.google.com/motion/duration-easing.html#duration-easing-natural-easing-curves\n// to learn the context in which each easing should be used.\nexport const easing = {\n // This is the most common easing curve.\n easeInOut: 'cubic-bezier(0.4, 0, 0.2, 1)',\n // Objects enter the screen at full velocity from off-screen and\n // slowly decelerate to a resting point.\n easeOut: 'cubic-bezier(0.0, 0, 0.2, 1)',\n // Objects leave the screen at full velocity. They do not decelerate when off-screen.\n easeIn: 'cubic-bezier(0.4, 0, 1, 1)',\n // The sharp curve is used by objects that may return to the screen at any time.\n sharp: 'cubic-bezier(0.4, 0, 0.6, 1)'\n};\n\n// Follow https://m2.material.io/guidelines/motion/duration-easing.html#duration-easing-common-durations\n// to learn when use what timing\nexport const duration = {\n shortest: 150,\n shorter: 200,\n short: 250,\n // most basic recommended timing\n standard: 300,\n // this is to be used in complex animations\n complex: 375,\n // recommended when something is entering screen\n enteringScreen: 225,\n // recommended when something is leaving screen\n leavingScreen: 195\n};\nfunction formatMs(milliseconds) {\n return `${Math.round(milliseconds)}ms`;\n}\nfunction getAutoHeightDuration(height) {\n if (!height) {\n return 0;\n }\n const constant = height / 36;\n\n // https://www.wolframalpha.com/input/?i=(4+%2B+15+*+(x+%2F+36+)+**+0.25+%2B+(x+%2F+36)+%2F+5)+*+10\n return Math.round((4 + 15 * constant ** 0.25 + constant / 5) * 10);\n}\nexport default function createTransitions(inputTransitions) {\n const mergedEasing = _extends({}, easing, inputTransitions.easing);\n const mergedDuration = _extends({}, duration, inputTransitions.duration);\n const create = (props = ['all'], options = {}) => {\n const {\n duration: durationOption = mergedDuration.standard,\n easing: easingOption = mergedEasing.easeInOut,\n delay = 0\n } = options,\n other = _objectWithoutPropertiesLoose(options, _excluded);\n if (process.env.NODE_ENV !== 'production') {\n const isString = value => typeof value === 'string';\n // IE11 support, replace with Number.isNaN\n // eslint-disable-next-line no-restricted-globals\n const isNumber = value => !isNaN(parseFloat(value));\n if (!isString(props) && !Array.isArray(props)) {\n console.error('MUI: Argument \"props\" must be a string or Array.');\n }\n if (!isNumber(durationOption) && !isString(durationOption)) {\n console.error(`MUI: Argument \"duration\" must be a number or a string but found ${durationOption}.`);\n }\n if (!isString(easingOption)) {\n console.error('MUI: Argument \"easing\" must be a string.');\n }\n if (!isNumber(delay) && !isString(delay)) {\n console.error('MUI: Argument \"delay\" must be a number or a string.');\n }\n if (typeof options !== 'object') {\n console.error(['MUI: Secong argument of transition.create must be an object.', \"Arguments should be either `create('prop1', options)` or `create(['prop1', 'prop2'], options)`\"].join('\\n'));\n }\n if (Object.keys(other).length !== 0) {\n console.error(`MUI: Unrecognized argument(s) [${Object.keys(other).join(',')}].`);\n }\n }\n return (Array.isArray(props) ? props : [props]).map(animatedProp => `${animatedProp} ${typeof durationOption === 'string' ? durationOption : formatMs(durationOption)} ${easingOption} ${typeof delay === 'string' ? delay : formatMs(delay)}`).join(',');\n };\n return _extends({\n getAutoHeightDuration,\n create\n }, inputTransitions, {\n easing: mergedEasing,\n duration: mergedDuration\n });\n}","'use client';\n\nimport createTheme from './createTheme';\nconst defaultTheme = createTheme();\nexport default defaultTheme;","export default '$$material';","import slotShouldForwardProp from './slotShouldForwardProp';\nconst rootShouldForwardProp = prop => slotShouldForwardProp(prop) && prop !== 'classes';\nexport default rootShouldForwardProp;","// copied from @mui/system/createStyled\nfunction slotShouldForwardProp(prop) {\n return prop !== 'ownerState' && prop !== 'theme' && prop !== 'sx' && prop !== 'as';\n}\nexport default slotShouldForwardProp;","'use client';\n\nimport createStyled from '@mui/system/createStyled';\nimport defaultTheme from './defaultTheme';\nimport THEME_ID from './identifier';\nimport rootShouldForwardProp from './rootShouldForwardProp';\nexport { default as slotShouldForwardProp } from './slotShouldForwardProp';\nexport { default as rootShouldForwardProp } from './rootShouldForwardProp';\nconst styled = createStyled({\n themeId: THEME_ID,\n defaultTheme,\n rootShouldForwardProp\n});\nexport default styled;","import capitalize from '@mui/utils/capitalize';\nexport default capitalize;","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nexport function getSvgIconUtilityClass(slot) {\n return generateUtilityClass('MuiSvgIcon', slot);\n}\nconst svgIconClasses = generateUtilityClasses('MuiSvgIcon', ['root', 'colorPrimary', 'colorSecondary', 'colorAction', 'colorError', 'colorDisabled', 'fontSizeInherit', 'fontSizeSmall', 'fontSizeMedium', 'fontSizeLarge']);\nexport default svgIconClasses;","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"children\", \"className\", \"color\", \"component\", \"fontSize\", \"htmlColor\", \"inheritViewBox\", \"titleAccess\", \"viewBox\"];\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport composeClasses from '@mui/utils/composeClasses';\nimport capitalize from '../utils/capitalize';\nimport { useDefaultProps } from '../DefaultPropsProvider';\nimport styled from '../styles/styled';\nimport { getSvgIconUtilityClass } from './svgIconClasses';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { jsxs as _jsxs } from \"react/jsx-runtime\";\nconst useUtilityClasses = ownerState => {\n const {\n color,\n fontSize,\n classes\n } = ownerState;\n const slots = {\n root: ['root', color !== 'inherit' && `color${capitalize(color)}`, `fontSize${capitalize(fontSize)}`]\n };\n return composeClasses(slots, getSvgIconUtilityClass, classes);\n};\nconst SvgIconRoot = styled('svg', {\n name: 'MuiSvgIcon',\n slot: 'Root',\n overridesResolver: (props, styles) => {\n const {\n ownerState\n } = props;\n return [styles.root, ownerState.color !== 'inherit' && styles[`color${capitalize(ownerState.color)}`], styles[`fontSize${capitalize(ownerState.fontSize)}`]];\n }\n})(({\n theme,\n ownerState\n}) => {\n var _theme$transitions, _theme$transitions$cr, _theme$transitions2, _theme$typography, _theme$typography$pxT, _theme$typography2, _theme$typography2$px, _theme$typography3, _theme$typography3$px, _palette$ownerState$c, _palette, _palette2, _palette3;\n return {\n userSelect: 'none',\n width: '1em',\n height: '1em',\n display: 'inline-block',\n // the will define the property that has `currentColor`\n // for example heroicons uses fill=\"none\" and stroke=\"currentColor\"\n fill: ownerState.hasSvgAsChild ? undefined : 'currentColor',\n flexShrink: 0,\n transition: (_theme$transitions = theme.transitions) == null || (_theme$transitions$cr = _theme$transitions.create) == null ? void 0 : _theme$transitions$cr.call(_theme$transitions, 'fill', {\n duration: (_theme$transitions2 = theme.transitions) == null || (_theme$transitions2 = _theme$transitions2.duration) == null ? void 0 : _theme$transitions2.shorter\n }),\n fontSize: {\n inherit: 'inherit',\n small: ((_theme$typography = theme.typography) == null || (_theme$typography$pxT = _theme$typography.pxToRem) == null ? void 0 : _theme$typography$pxT.call(_theme$typography, 20)) || '1.25rem',\n medium: ((_theme$typography2 = theme.typography) == null || (_theme$typography2$px = _theme$typography2.pxToRem) == null ? void 0 : _theme$typography2$px.call(_theme$typography2, 24)) || '1.5rem',\n large: ((_theme$typography3 = theme.typography) == null || (_theme$typography3$px = _theme$typography3.pxToRem) == null ? void 0 : _theme$typography3$px.call(_theme$typography3, 35)) || '2.1875rem'\n }[ownerState.fontSize],\n // TODO v5 deprecate, v6 remove for sx\n color: (_palette$ownerState$c = (_palette = (theme.vars || theme).palette) == null || (_palette = _palette[ownerState.color]) == null ? void 0 : _palette.main) != null ? _palette$ownerState$c : {\n action: (_palette2 = (theme.vars || theme).palette) == null || (_palette2 = _palette2.action) == null ? void 0 : _palette2.active,\n disabled: (_palette3 = (theme.vars || theme).palette) == null || (_palette3 = _palette3.action) == null ? void 0 : _palette3.disabled,\n inherit: undefined\n }[ownerState.color]\n };\n});\nconst SvgIcon = /*#__PURE__*/React.forwardRef(function SvgIcon(inProps, ref) {\n const props = useDefaultProps({\n props: inProps,\n name: 'MuiSvgIcon'\n });\n const {\n children,\n className,\n color = 'inherit',\n component = 'svg',\n fontSize = 'medium',\n htmlColor,\n inheritViewBox = false,\n titleAccess,\n viewBox = '0 0 24 24'\n } = props,\n other = _objectWithoutPropertiesLoose(props, _excluded);\n const hasSvgAsChild = /*#__PURE__*/React.isValidElement(children) && children.type === 'svg';\n const ownerState = _extends({}, props, {\n color,\n component,\n fontSize,\n instanceFontSize: inProps.fontSize,\n inheritViewBox,\n viewBox,\n hasSvgAsChild\n });\n const more = {};\n if (!inheritViewBox) {\n more.viewBox = viewBox;\n }\n const classes = useUtilityClasses(ownerState);\n return /*#__PURE__*/_jsxs(SvgIconRoot, _extends({\n as: component,\n className: clsx(classes.root, className),\n focusable: \"false\",\n color: htmlColor,\n \"aria-hidden\": titleAccess ? undefined : true,\n role: titleAccess ? 'img' : undefined,\n ref: ref\n }, more, other, hasSvgAsChild && children.props, {\n ownerState: ownerState,\n children: [hasSvgAsChild ? children.props.children : children, titleAccess ? /*#__PURE__*/_jsx(\"title\", {\n children: titleAccess\n }) : null]\n }));\n});\nprocess.env.NODE_ENV !== \"production\" ? SvgIcon.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * Node passed into the SVG element.\n */\n children: PropTypes.node,\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n /**\n * @ignore\n */\n className: PropTypes.string,\n /**\n * The color of the component.\n * It supports both default and custom theme colors, which can be added as shown in the\n * [palette customization guide](https://mui.com/material-ui/customization/palette/#custom-colors).\n * You can use the `htmlColor` prop to apply a color attribute to the SVG element.\n * @default 'inherit'\n */\n color: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['inherit', 'action', 'disabled', 'primary', 'secondary', 'error', 'info', 'success', 'warning']), PropTypes.string]),\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes.elementType,\n /**\n * The fontSize applied to the icon. Defaults to 24px, but can be configure to inherit font size.\n * @default 'medium'\n */\n fontSize: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['inherit', 'large', 'medium', 'small']), PropTypes.string]),\n /**\n * Applies a color attribute to the SVG element.\n */\n htmlColor: PropTypes.string,\n /**\n * If `true`, the root node will inherit the custom `component`'s viewBox and the `viewBox`\n * prop will be ignored.\n * Useful when you want to reference a custom `component` and have `SvgIcon` pass that\n * `component`'s viewBox to the root node.\n * @default false\n */\n inheritViewBox: PropTypes.bool,\n /**\n * The shape-rendering attribute. The behavior of the different options is described on the\n * [MDN Web Docs](https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/shape-rendering).\n * If you are having issues with blurry icons you should investigate this prop.\n */\n shapeRendering: PropTypes.string,\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),\n /**\n * Provides a human-readable title for the element that contains it.\n * https://www.w3.org/TR/SVG-access/#Equivalent\n */\n titleAccess: PropTypes.string,\n /**\n * Allows you to redefine what the coordinates without units mean inside an SVG element.\n * For example, if the SVG element is 500 (width) by 200 (height),\n * and you pass viewBox=\"0 0 50 20\",\n * this means that the coordinates inside the SVG will go from the top left corner (0,0)\n * to bottom right (50,20) and each unit will be worth 10px.\n * @default '0 0 24 24'\n */\n viewBox: PropTypes.string\n} : void 0;\nSvgIcon.muiName = 'SvgIcon';\nexport default SvgIcon;","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport SvgIcon from '../SvgIcon';\n\n/**\n * Private module reserved for @mui packages.\n */\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default function createSvgIcon(path, displayName) {\n function Component(props, ref) {\n return /*#__PURE__*/_jsx(SvgIcon, _extends({\n \"data-testid\": `${displayName}Icon`,\n ref: ref\n }, props, {\n children: path\n }));\n }\n if (process.env.NODE_ENV !== 'production') {\n // Need to set `displayName` on the inner component for React.memo.\n // React prior to 16.14 ignores `displayName` on the wrapper.\n Component.displayName = `${displayName}Icon`;\n }\n Component.muiName = SvgIcon.muiName;\n return /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(Component));\n}","import debounce from '@mui/utils/debounce';\nexport default debounce;","import createChainedFunction from '@mui/utils/createChainedFunction';\nexport default createChainedFunction;","import deprecatedPropType from '@mui/utils/deprecatedPropType';\nexport default deprecatedPropType;","export default function deprecatedPropType(validator, reason) {\n if (process.env.NODE_ENV === 'production') {\n return () => null;\n }\n return (props, propName, componentName, location, propFullName) => {\n const componentNameSafe = componentName || '<>';\n const propFullNameSafe = propFullName || propName;\n if (typeof props[propName] !== 'undefined') {\n return new Error(`The ${location} \\`${propFullNameSafe}\\` of ` + `\\`${componentNameSafe}\\` is deprecated. ${reason}`);\n }\n return null;\n };\n}","import requirePropFactory from '@mui/utils/requirePropFactory';\nexport default requirePropFactory;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nexport default function requirePropFactory(componentNameInError, Component) {\n if (process.env.NODE_ENV === 'production') {\n return () => null;\n }\n\n // eslint-disable-next-line react/forbid-foreign-prop-types\n const prevPropTypes = Component ? _extends({}, Component.propTypes) : null;\n const requireProp = requiredProp => (props, propName, componentName, location, propFullName, ...args) => {\n const propFullNameSafe = propFullName || propName;\n const defaultTypeChecker = prevPropTypes == null ? void 0 : prevPropTypes[propFullNameSafe];\n if (defaultTypeChecker) {\n const typeCheckerResult = defaultTypeChecker(props, propName, componentName, location, propFullName, ...args);\n if (typeCheckerResult) {\n return typeCheckerResult;\n }\n }\n if (typeof props[propName] !== 'undefined' && !props[requiredProp]) {\n return new Error(`The prop \\`${propFullNameSafe}\\` of ` + `\\`${componentNameInError}\\` can only be used together with the \\`${requiredProp}\\` prop.`);\n }\n return null;\n };\n return requireProp;\n}","import setRef from '@mui/utils/setRef';\nexport default setRef;","import unsupportedProp from '@mui/utils/unsupportedProp';\nexport default unsupportedProp;","export default function unsupportedProp(props, propName, componentName, location, propFullName) {\n if (process.env.NODE_ENV === 'production') {\n return null;\n }\n const propFullNameSafe = propFullName || propName;\n if (typeof props[propName] !== 'undefined') {\n return new Error(`The prop \\`${propFullNameSafe}\\` is not supported. Please remove it.`);\n }\n return null;\n}","'use client';\n\nimport { unstable_ClassNameGenerator as ClassNameGenerator } from '@mui/utils';\nexport { default as capitalize } from './capitalize';\nexport { default as createChainedFunction } from './createChainedFunction';\nexport { default as createSvgIcon } from './createSvgIcon';\nexport { default as debounce } from './debounce';\nexport { default as deprecatedPropType } from './deprecatedPropType';\nexport { default as isMuiElement } from './isMuiElement';\nexport { default as ownerDocument } from './ownerDocument';\nexport { default as ownerWindow } from './ownerWindow';\nexport { default as requirePropFactory } from './requirePropFactory';\nexport { default as setRef } from './setRef';\nexport { default as unstable_useEnhancedEffect } from './useEnhancedEffect';\nexport { default as unstable_useId } from './useId';\nexport { default as unsupportedProp } from './unsupportedProp';\nexport { default as useControlled } from './useControlled';\nexport { default as useEventCallback } from './useEventCallback';\nexport { default as useForkRef } from './useForkRef';\nexport { default as useIsFocusVisible } from './useIsFocusVisible';\n// TODO: remove this export once ClassNameGenerator is stable\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const unstable_ClassNameGenerator = {\n configure: generator => {\n if (process.env.NODE_ENV !== 'production') {\n console.warn(['MUI: `ClassNameGenerator` import from `@mui/material/utils` is outdated and might cause unexpected issues.', '', \"You should use `import { unstable_ClassNameGenerator } from '@mui/material/className'` instead\", '', 'The detail of the issue: https://github.com/mui/material-ui/issues/30011#issuecomment-1024993401', '', 'The updated documentation: https://mui.com/guides/classname-generator/'].join('\\n'));\n }\n ClassNameGenerator.configure(generator);\n }\n};","import isMuiElement from '@mui/utils/isMuiElement';\nexport default isMuiElement;","import * as React from 'react';\nexport default function isMuiElement(element, muiNames) {\n var _muiName, _element$type;\n return /*#__PURE__*/React.isValidElement(element) && muiNames.indexOf( // For server components `muiName` is avaialble in element.type._payload.value.muiName\n // relevant info - https://github.com/facebook/react/blob/2807d781a08db8e9873687fccc25c0f12b4fb3d4/packages/react/src/ReactLazy.js#L45\n // eslint-disable-next-line no-underscore-dangle\n (_muiName = element.type.muiName) != null ? _muiName : (_element$type = element.type) == null || (_element$type = _element$type._payload) == null || (_element$type = _element$type.value) == null ? void 0 : _element$type.muiName) !== -1;\n}","import ownerDocument from '@mui/utils/ownerDocument';\nexport default ownerDocument;","import ownerWindow from '@mui/utils/ownerWindow';\nexport default ownerWindow;","'use client';\n\nimport useControlled from '@mui/utils/useControlled';\nexport default useControlled;","'use client';\n\nimport useEnhancedEffect from '@mui/utils/useEnhancedEffect';\nexport default useEnhancedEffect;","'use client';\n\nimport useEventCallback from '@mui/utils/useEventCallback';\nexport default useEventCallback;","'use client';\n\nimport useForkRef from '@mui/utils/useForkRef';\nexport default useForkRef;","'use client';\n\nimport useId from '@mui/utils/useId';\nexport default useId;","'use client';\n\nimport useIsFocusVisible from '@mui/utils/useIsFocusVisible';\nexport default useIsFocusVisible;","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { Global } from '@emotion/react';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nfunction isEmpty(obj) {\n return obj === undefined || obj === null || Object.keys(obj).length === 0;\n}\nexport default function GlobalStyles(props) {\n const {\n styles,\n defaultTheme = {}\n } = props;\n const globalStyles = typeof styles === 'function' ? themeInput => styles(isEmpty(themeInput) ? defaultTheme : themeInput) : styles;\n return /*#__PURE__*/_jsx(Global, {\n styles: globalStyles\n });\n}\nprocess.env.NODE_ENV !== \"production\" ? GlobalStyles.propTypes = {\n defaultTheme: PropTypes.object,\n styles: PropTypes.oneOfType([PropTypes.array, PropTypes.string, PropTypes.object, PropTypes.func])\n} : void 0;","import memoize from '@emotion/memoize';\n\n// eslint-disable-next-line no-undef\nvar reactPropsRegex = /^((children|dangerouslySetInnerHTML|key|ref|autoFocus|defaultValue|defaultChecked|innerHTML|suppressContentEditableWarning|suppressHydrationWarning|valueLink|abbr|accept|acceptCharset|accessKey|action|allow|allowUserMedia|allowPaymentRequest|allowFullScreen|allowTransparency|alt|async|autoComplete|autoPlay|capture|cellPadding|cellSpacing|challenge|charSet|checked|cite|classID|className|cols|colSpan|content|contentEditable|contextMenu|controls|controlsList|coords|crossOrigin|data|dateTime|decoding|default|defer|dir|disabled|disablePictureInPicture|disableRemotePlayback|download|draggable|encType|enterKeyHint|fetchpriority|fetchPriority|form|formAction|formEncType|formMethod|formNoValidate|formTarget|frameBorder|headers|height|hidden|high|href|hrefLang|htmlFor|httpEquiv|id|inputMode|integrity|is|keyParams|keyType|kind|label|lang|list|loading|loop|low|marginHeight|marginWidth|max|maxLength|media|mediaGroup|method|min|minLength|multiple|muted|name|nonce|noValidate|open|optimum|pattern|placeholder|playsInline|poster|preload|profile|radioGroup|readOnly|referrerPolicy|rel|required|reversed|role|rows|rowSpan|sandbox|scope|scoped|scrolling|seamless|selected|shape|size|sizes|slot|span|spellCheck|src|srcDoc|srcLang|srcSet|start|step|style|summary|tabIndex|target|title|translate|type|useMap|value|width|wmode|wrap|about|datatype|inlist|prefix|property|resource|typeof|vocab|autoCapitalize|autoCorrect|autoSave|color|incremental|fallback|inert|itemProp|itemScope|itemType|itemID|itemRef|on|option|results|security|unselectable|accentHeight|accumulate|additive|alignmentBaseline|allowReorder|alphabetic|amplitude|arabicForm|ascent|attributeName|attributeType|autoReverse|azimuth|baseFrequency|baselineShift|baseProfile|bbox|begin|bias|by|calcMode|capHeight|clip|clipPathUnits|clipPath|clipRule|colorInterpolation|colorInterpolationFilters|colorProfile|colorRendering|contentScriptType|contentStyleType|cursor|cx|cy|d|decelerate|descent|diffuseConstant|direction|display|divisor|dominantBaseline|dur|dx|dy|edgeMode|elevation|enableBackground|end|exponent|externalResourcesRequired|fill|fillOpacity|fillRule|filter|filterRes|filterUnits|floodColor|floodOpacity|focusable|fontFamily|fontSize|fontSizeAdjust|fontStretch|fontStyle|fontVariant|fontWeight|format|from|fr|fx|fy|g1|g2|glyphName|glyphOrientationHorizontal|glyphOrientationVertical|glyphRef|gradientTransform|gradientUnits|hanging|horizAdvX|horizOriginX|ideographic|imageRendering|in|in2|intercept|k|k1|k2|k3|k4|kernelMatrix|kernelUnitLength|kerning|keyPoints|keySplines|keyTimes|lengthAdjust|letterSpacing|lightingColor|limitingConeAngle|local|markerEnd|markerMid|markerStart|markerHeight|markerUnits|markerWidth|mask|maskContentUnits|maskUnits|mathematical|mode|numOctaves|offset|opacity|operator|order|orient|orientation|origin|overflow|overlinePosition|overlineThickness|panose1|paintOrder|pathLength|patternContentUnits|patternTransform|patternUnits|pointerEvents|points|pointsAtX|pointsAtY|pointsAtZ|preserveAlpha|preserveAspectRatio|primitiveUnits|r|radius|refX|refY|renderingIntent|repeatCount|repeatDur|requiredExtensions|requiredFeatures|restart|result|rotate|rx|ry|scale|seed|shapeRendering|slope|spacing|specularConstant|specularExponent|speed|spreadMethod|startOffset|stdDeviation|stemh|stemv|stitchTiles|stopColor|stopOpacity|strikethroughPosition|strikethroughThickness|string|stroke|strokeDasharray|strokeDashoffset|strokeLinecap|strokeLinejoin|strokeMiterlimit|strokeOpacity|strokeWidth|surfaceScale|systemLanguage|tableValues|targetX|targetY|textAnchor|textDecoration|textRendering|textLength|to|transform|u1|u2|underlinePosition|underlineThickness|unicode|unicodeBidi|unicodeRange|unitsPerEm|vAlphabetic|vHanging|vIdeographic|vMathematical|values|vectorEffect|version|vertAdvY|vertOriginX|vertOriginY|viewBox|viewTarget|visibility|widths|wordSpacing|writingMode|x|xHeight|x1|x2|xChannelSelector|xlinkActuate|xlinkArcrole|xlinkHref|xlinkRole|xlinkShow|xlinkTitle|xlinkType|xmlBase|xmlns|xmlnsXlink|xmlLang|xmlSpace|y|y1|y2|yChannelSelector|z|zoomAndPan|for|class|autofocus)|(([Dd][Aa][Tt][Aa]|[Aa][Rr][Ii][Aa]|x)-.*))$/; // https://esbench.com/bench/5bfee68a4cd7e6009ef61d23\n\nvar isPropValid = /* #__PURE__ */memoize(function (prop) {\n return reactPropsRegex.test(prop) || prop.charCodeAt(0) === 111\n /* o */\n && prop.charCodeAt(1) === 110\n /* n */\n && prop.charCodeAt(2) < 91;\n}\n/* Z+1 */\n);\n\nexport { isPropValid as default };\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport * as React from 'react';\nimport isPropValid from '@emotion/is-prop-valid';\nimport { withEmotionCache, ThemeContext } from '@emotion/react';\nimport { getRegisteredStyles, registerStyles, insertStyles } from '@emotion/utils';\nimport { serializeStyles } from '@emotion/serialize';\nimport { useInsertionEffectAlwaysWithSyncFallback } from '@emotion/use-insertion-effect-with-fallbacks';\n\n/* import type {\n ElementType,\n StatelessFunctionalComponent,\n AbstractComponent\n} from 'react' */\n/*\nexport type Interpolations = Array\n\nexport type StyledElementType =\n | string\n | AbstractComponent<{ ...Props, className: string }, mixed>\n\nexport type StyledOptions = {\n label?: string,\n shouldForwardProp?: string => boolean,\n target?: string\n}\n\nexport type StyledComponent = StatelessFunctionalComponent & {\n defaultProps: any,\n toString: () => string,\n withComponent: (\n nextTag: StyledElementType,\n nextOptions?: StyledOptions\n ) => StyledComponent\n}\n\nexport type PrivateStyledComponent = StyledComponent & {\n __emotion_real: StyledComponent,\n __emotion_base: any,\n __emotion_styles: any,\n __emotion_forwardProp: any\n}\n*/\n\nvar testOmitPropsOnStringTag = isPropValid;\n\nvar testOmitPropsOnComponent = function testOmitPropsOnComponent(key\n/*: string */\n) {\n return key !== 'theme';\n};\n\nvar getDefaultShouldForwardProp = function getDefaultShouldForwardProp(tag\n/*: ElementType */\n) {\n return typeof tag === 'string' && // 96 is one less than the char code\n // for \"a\" so this is checking that\n // it's a lowercase character\n tag.charCodeAt(0) > 96 ? testOmitPropsOnStringTag : testOmitPropsOnComponent;\n};\nvar composeShouldForwardProps = function composeShouldForwardProps(tag\n/*: PrivateStyledComponent */\n, options\n/*: StyledOptions | void */\n, isReal\n/*: boolean */\n) {\n var shouldForwardProp;\n\n if (options) {\n var optionsShouldForwardProp = options.shouldForwardProp;\n shouldForwardProp = tag.__emotion_forwardProp && optionsShouldForwardProp ? function (propName\n /*: string */\n ) {\n return tag.__emotion_forwardProp(propName) && optionsShouldForwardProp(propName);\n } : optionsShouldForwardProp;\n }\n\n if (typeof shouldForwardProp !== 'function' && isReal) {\n shouldForwardProp = tag.__emotion_forwardProp;\n }\n\n return shouldForwardProp;\n};\n/*\nexport type CreateStyledComponent = (\n ...args: Interpolations\n) => StyledComponent\n\nexport type CreateStyled = {\n (\n tag: StyledElementType,\n options?: StyledOptions\n ): (...args: Interpolations) => StyledComponent,\n [key: string]: CreateStyledComponent,\n bind: () => CreateStyled\n}\n*/\n\nvar isDevelopment = false;\n\nvar Insertion = function Insertion(_ref) {\n var cache = _ref.cache,\n serialized = _ref.serialized,\n isStringTag = _ref.isStringTag;\n registerStyles(cache, serialized, isStringTag);\n useInsertionEffectAlwaysWithSyncFallback(function () {\n return insertStyles(cache, serialized, isStringTag);\n });\n\n return null;\n};\n\nvar createStyled\n/*: CreateStyled */\n= function createStyled\n/*: CreateStyled */\n(tag\n/*: any */\n, options\n/* ?: StyledOptions */\n) {\n\n var isReal = tag.__emotion_real === tag;\n var baseTag = isReal && tag.__emotion_base || tag;\n var identifierName;\n var targetClassName;\n\n if (options !== undefined) {\n identifierName = options.label;\n targetClassName = options.target;\n }\n\n var shouldForwardProp = composeShouldForwardProps(tag, options, isReal);\n var defaultShouldForwardProp = shouldForwardProp || getDefaultShouldForwardProp(baseTag);\n var shouldUseAs = !defaultShouldForwardProp('as');\n /* return function(): PrivateStyledComponent { */\n\n return function () {\n var args = arguments;\n var styles = isReal && tag.__emotion_styles !== undefined ? tag.__emotion_styles.slice(0) : [];\n\n if (identifierName !== undefined) {\n styles.push(\"label:\" + identifierName + \";\");\n }\n\n if (args[0] == null || args[0].raw === undefined) {\n styles.push.apply(styles, args);\n } else {\n\n styles.push(args[0][0]);\n var len = args.length;\n var i = 1;\n\n for (; i < len; i++) {\n\n styles.push(args[i], args[0][i]);\n }\n }\n\n var Styled\n /*: PrivateStyledComponent */\n = withEmotionCache(function (props, cache, ref) {\n var FinalTag = shouldUseAs && props.as || baseTag;\n var className = '';\n var classInterpolations = [];\n var mergedProps = props;\n\n if (props.theme == null) {\n mergedProps = {};\n\n for (var key in props) {\n mergedProps[key] = props[key];\n }\n\n mergedProps.theme = React.useContext(ThemeContext);\n }\n\n if (typeof props.className === 'string') {\n className = getRegisteredStyles(cache.registered, classInterpolations, props.className);\n } else if (props.className != null) {\n className = props.className + \" \";\n }\n\n var serialized = serializeStyles(styles.concat(classInterpolations), cache.registered, mergedProps);\n className += cache.key + \"-\" + serialized.name;\n\n if (targetClassName !== undefined) {\n className += \" \" + targetClassName;\n }\n\n var finalShouldForwardProp = shouldUseAs && shouldForwardProp === undefined ? getDefaultShouldForwardProp(FinalTag) : defaultShouldForwardProp;\n var newProps = {};\n\n for (var _key in props) {\n if (shouldUseAs && _key === 'as') continue;\n\n if (finalShouldForwardProp(_key)) {\n newProps[_key] = props[_key];\n }\n }\n\n newProps.className = className;\n\n if (ref) {\n newProps.ref = ref;\n }\n\n return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Insertion, {\n cache: cache,\n serialized: serialized,\n isStringTag: typeof FinalTag === 'string'\n }), /*#__PURE__*/React.createElement(FinalTag, newProps));\n });\n Styled.displayName = identifierName !== undefined ? identifierName : \"Styled(\" + (typeof baseTag === 'string' ? baseTag : baseTag.displayName || baseTag.name || 'Component') + \")\";\n Styled.defaultProps = tag.defaultProps;\n Styled.__emotion_real = Styled;\n Styled.__emotion_base = baseTag;\n Styled.__emotion_styles = styles;\n Styled.__emotion_forwardProp = shouldForwardProp;\n Object.defineProperty(Styled, 'toString', {\n value: function value() {\n if (targetClassName === undefined && isDevelopment) {\n return 'NO_COMPONENT_SELECTOR';\n }\n\n return \".\" + targetClassName;\n }\n });\n\n Styled.withComponent = function (nextTag\n /*: StyledElementType */\n , nextOptions\n /* ?: StyledOptions */\n ) {\n return createStyled(nextTag, _extends({}, options, nextOptions, {\n shouldForwardProp: composeShouldForwardProps(Styled, nextOptions, true)\n })).apply(void 0, styles);\n };\n\n return Styled;\n };\n};\n\nexport { createStyled as default };\n","import createStyled from '../base/dist/emotion-styled-base.browser.esm.js';\nimport '@babel/runtime/helpers/extends';\nimport 'react';\nimport '@emotion/is-prop-valid';\nimport '@emotion/react';\nimport '@emotion/utils';\nimport '@emotion/serialize';\nimport '@emotion/use-insertion-effect-with-fallbacks';\n\nvar tags = ['a', 'abbr', 'address', 'area', 'article', 'aside', 'audio', 'b', 'base', 'bdi', 'bdo', 'big', 'blockquote', 'body', 'br', 'button', 'canvas', 'caption', 'cite', 'code', 'col', 'colgroup', 'data', 'datalist', 'dd', 'del', 'details', 'dfn', 'dialog', 'div', 'dl', 'dt', 'em', 'embed', 'fieldset', 'figcaption', 'figure', 'footer', 'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html', 'i', 'iframe', 'img', 'input', 'ins', 'kbd', 'keygen', 'label', 'legend', 'li', 'link', 'main', 'map', 'mark', 'marquee', 'menu', 'menuitem', 'meta', 'meter', 'nav', 'noscript', 'object', 'ol', 'optgroup', 'option', 'output', 'p', 'param', 'picture', 'pre', 'progress', 'q', 'rp', 'rt', 'ruby', 's', 'samp', 'script', 'section', 'select', 'small', 'source', 'span', 'strong', 'style', 'sub', 'summary', 'sup', 'table', 'tbody', 'td', 'textarea', 'tfoot', 'th', 'thead', 'time', 'title', 'tr', 'track', 'u', 'ul', 'var', 'video', 'wbr', // SVG\n'circle', 'clipPath', 'defs', 'ellipse', 'foreignObject', 'g', 'image', 'line', 'linearGradient', 'mask', 'path', 'pattern', 'polygon', 'polyline', 'radialGradient', 'rect', 'stop', 'svg', 'text', 'tspan'];\n\nvar newStyled = createStyled.bind();\ntags.forEach(function (tagName) {\n newStyled[tagName] = newStyled(tagName);\n});\n\nexport { newStyled as default };\n","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { CacheProvider } from '@emotion/react';\nimport createCache from '@emotion/cache';\n\n// prepend: true moves MUI styles to the top of the so they're loaded first.\n// It allows developers to easily override MUI styles with other styling solutions, like CSS modules.\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nlet cache;\nif (typeof document === 'object') {\n cache = createCache({\n key: 'css',\n prepend: true\n });\n}\nexport default function StyledEngineProvider(props) {\n const {\n injectFirst,\n children\n } = props;\n return injectFirst && cache ? /*#__PURE__*/_jsx(CacheProvider, {\n value: cache,\n children: children\n }) : children;\n}\nprocess.env.NODE_ENV !== \"production\" ? StyledEngineProvider.propTypes = {\n /**\n * Your component tree.\n */\n children: PropTypes.node,\n /**\n * By default, the styles are injected last in the element of the page.\n * As a result, they gain more specificity than any other style sheet.\n * If you want to override MUI's styles, set this prop.\n */\n injectFirst: PropTypes.bool\n} : void 0;","/**\n * @mui/styled-engine v5.16.6\n *\n * @license MIT\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use client';\n\n/* eslint-disable no-underscore-dangle */\nimport emStyled from '@emotion/styled';\nexport default function styled(tag, options) {\n const stylesFactory = emStyled(tag, options);\n if (process.env.NODE_ENV !== 'production') {\n return (...styles) => {\n const component = typeof tag === 'string' ? `\"${tag}\"` : 'component';\n if (styles.length === 0) {\n console.error([`MUI: Seems like you called \\`styled(${component})()\\` without a \\`style\\` argument.`, 'You must provide a `styles` argument: `styled(\"div\")(styleYouForgotToPass)`.'].join('\\n'));\n } else if (styles.some(style => style === undefined)) {\n console.error(`MUI: the styled(${component})(...args) API requires all its args to be defined.`);\n }\n return stylesFactory(...styles);\n };\n }\n return stylesFactory;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const internal_processStyles = (tag, processor) => {\n // Emotion attaches all the styles as `__emotion_styles`.\n // Ref: https://github.com/emotion-js/emotion/blob/16d971d0da229596d6bcc39d282ba9753c9ee7cf/packages/styled/src/base.js#L186\n if (Array.isArray(tag.__emotion_styles)) {\n tag.__emotion_styles = processor(tag.__emotion_styles);\n }\n};\nexport { ThemeContext, keyframes, css } from '@emotion/react';\nexport { default as StyledEngineProvider } from './StyledEngineProvider';\nexport { default as GlobalStyles } from './GlobalStyles';","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.alpha = alpha;\nexports.blend = blend;\nexports.colorChannel = void 0;\nexports.darken = darken;\nexports.decomposeColor = decomposeColor;\nexports.emphasize = emphasize;\nexports.getContrastRatio = getContrastRatio;\nexports.getLuminance = getLuminance;\nexports.hexToRgb = hexToRgb;\nexports.hslToRgb = hslToRgb;\nexports.lighten = lighten;\nexports.private_safeAlpha = private_safeAlpha;\nexports.private_safeColorChannel = void 0;\nexports.private_safeDarken = private_safeDarken;\nexports.private_safeEmphasize = private_safeEmphasize;\nexports.private_safeLighten = private_safeLighten;\nexports.recomposeColor = recomposeColor;\nexports.rgbToHex = rgbToHex;\nvar _formatMuiErrorMessage2 = _interopRequireDefault(require(\"@mui/utils/formatMuiErrorMessage\"));\nvar _clamp = _interopRequireDefault(require(\"@mui/utils/clamp\"));\n/* eslint-disable @typescript-eslint/naming-convention */\n\n/**\n * Returns a number whose value is limited to the given range.\n * @param {number} value The value to be clamped\n * @param {number} min The lower boundary of the output range\n * @param {number} max The upper boundary of the output range\n * @returns {number} A number in the range [min, max]\n */\nfunction clampWrapper(value, min = 0, max = 1) {\n if (process.env.NODE_ENV !== 'production') {\n if (value < min || value > max) {\n console.error(`MUI: The value provided ${value} is out of range [${min}, ${max}].`);\n }\n }\n return (0, _clamp.default)(value, min, max);\n}\n\n/**\n * Converts a color from CSS hex format to CSS rgb format.\n * @param {string} color - Hex color, i.e. #nnn or #nnnnnn\n * @returns {string} A CSS rgb color string\n */\nfunction hexToRgb(color) {\n color = color.slice(1);\n const re = new RegExp(`.{1,${color.length >= 6 ? 2 : 1}}`, 'g');\n let colors = color.match(re);\n if (colors && colors[0].length === 1) {\n colors = colors.map(n => n + n);\n }\n return colors ? `rgb${colors.length === 4 ? 'a' : ''}(${colors.map((n, index) => {\n return index < 3 ? parseInt(n, 16) : Math.round(parseInt(n, 16) / 255 * 1000) / 1000;\n }).join(', ')})` : '';\n}\nfunction intToHex(int) {\n const hex = int.toString(16);\n return hex.length === 1 ? `0${hex}` : hex;\n}\n\n/**\n * Returns an object with the type and values of a color.\n *\n * Note: Does not support rgb % values.\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color()\n * @returns {object} - A MUI color object: {type: string, values: number[]}\n */\nfunction decomposeColor(color) {\n // Idempotent\n if (color.type) {\n return color;\n }\n if (color.charAt(0) === '#') {\n return decomposeColor(hexToRgb(color));\n }\n const marker = color.indexOf('(');\n const type = color.substring(0, marker);\n if (['rgb', 'rgba', 'hsl', 'hsla', 'color'].indexOf(type) === -1) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: Unsupported \\`${color}\\` color.\nThe following formats are supported: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color().` : (0, _formatMuiErrorMessage2.default)(9, color));\n }\n let values = color.substring(marker + 1, color.length - 1);\n let colorSpace;\n if (type === 'color') {\n values = values.split(' ');\n colorSpace = values.shift();\n if (values.length === 4 && values[3].charAt(0) === '/') {\n values[3] = values[3].slice(1);\n }\n if (['srgb', 'display-p3', 'a98-rgb', 'prophoto-rgb', 'rec-2020'].indexOf(colorSpace) === -1) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: unsupported \\`${colorSpace}\\` color space.\nThe following color spaces are supported: srgb, display-p3, a98-rgb, prophoto-rgb, rec-2020.` : (0, _formatMuiErrorMessage2.default)(10, colorSpace));\n }\n } else {\n values = values.split(',');\n }\n values = values.map(value => parseFloat(value));\n return {\n type,\n values,\n colorSpace\n };\n}\n\n/**\n * Returns a channel created from the input color.\n *\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color()\n * @returns {string} - The channel for the color, that can be used in rgba or hsla colors\n */\nconst colorChannel = color => {\n const decomposedColor = decomposeColor(color);\n return decomposedColor.values.slice(0, 3).map((val, idx) => decomposedColor.type.indexOf('hsl') !== -1 && idx !== 0 ? `${val}%` : val).join(' ');\n};\nexports.colorChannel = colorChannel;\nconst private_safeColorChannel = (color, warning) => {\n try {\n return colorChannel(color);\n } catch (error) {\n if (warning && process.env.NODE_ENV !== 'production') {\n console.warn(warning);\n }\n return color;\n }\n};\n\n/**\n * Converts a color object with type and values to a string.\n * @param {object} color - Decomposed color\n * @param {string} color.type - One of: 'rgb', 'rgba', 'hsl', 'hsla', 'color'\n * @param {array} color.values - [n,n,n] or [n,n,n,n]\n * @returns {string} A CSS color string\n */\nexports.private_safeColorChannel = private_safeColorChannel;\nfunction recomposeColor(color) {\n const {\n type,\n colorSpace\n } = color;\n let {\n values\n } = color;\n if (type.indexOf('rgb') !== -1) {\n // Only convert the first 3 values to int (i.e. not alpha)\n values = values.map((n, i) => i < 3 ? parseInt(n, 10) : n);\n } else if (type.indexOf('hsl') !== -1) {\n values[1] = `${values[1]}%`;\n values[2] = `${values[2]}%`;\n }\n if (type.indexOf('color') !== -1) {\n values = `${colorSpace} ${values.join(' ')}`;\n } else {\n values = `${values.join(', ')}`;\n }\n return `${type}(${values})`;\n}\n\n/**\n * Converts a color from CSS rgb format to CSS hex format.\n * @param {string} color - RGB color, i.e. rgb(n, n, n)\n * @returns {string} A CSS rgb color string, i.e. #nnnnnn\n */\nfunction rgbToHex(color) {\n // Idempotent\n if (color.indexOf('#') === 0) {\n return color;\n }\n const {\n values\n } = decomposeColor(color);\n return `#${values.map((n, i) => intToHex(i === 3 ? Math.round(255 * n) : n)).join('')}`;\n}\n\n/**\n * Converts a color from hsl format to rgb format.\n * @param {string} color - HSL color values\n * @returns {string} rgb color values\n */\nfunction hslToRgb(color) {\n color = decomposeColor(color);\n const {\n values\n } = color;\n const h = values[0];\n const s = values[1] / 100;\n const l = values[2] / 100;\n const a = s * Math.min(l, 1 - l);\n const f = (n, k = (n + h / 30) % 12) => l - a * Math.max(Math.min(k - 3, 9 - k, 1), -1);\n let type = 'rgb';\n const rgb = [Math.round(f(0) * 255), Math.round(f(8) * 255), Math.round(f(4) * 255)];\n if (color.type === 'hsla') {\n type += 'a';\n rgb.push(values[3]);\n }\n return recomposeColor({\n type,\n values: rgb\n });\n}\n/**\n * The relative brightness of any point in a color space,\n * normalized to 0 for darkest black and 1 for lightest white.\n *\n * Formula: https://www.w3.org/TR/WCAG20-TECHS/G17.html#G17-tests\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color()\n * @returns {number} The relative brightness of the color in the range 0 - 1\n */\nfunction getLuminance(color) {\n color = decomposeColor(color);\n let rgb = color.type === 'hsl' || color.type === 'hsla' ? decomposeColor(hslToRgb(color)).values : color.values;\n rgb = rgb.map(val => {\n if (color.type !== 'color') {\n val /= 255; // normalized\n }\n return val <= 0.03928 ? val / 12.92 : ((val + 0.055) / 1.055) ** 2.4;\n });\n\n // Truncate at 3 digits\n return Number((0.2126 * rgb[0] + 0.7152 * rgb[1] + 0.0722 * rgb[2]).toFixed(3));\n}\n\n/**\n * Calculates the contrast ratio between two colors.\n *\n * Formula: https://www.w3.org/TR/WCAG20-TECHS/G17.html#G17-tests\n * @param {string} foreground - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @param {string} background - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @returns {number} A contrast ratio value in the range 0 - 21.\n */\nfunction getContrastRatio(foreground, background) {\n const lumA = getLuminance(foreground);\n const lumB = getLuminance(background);\n return (Math.max(lumA, lumB) + 0.05) / (Math.min(lumA, lumB) + 0.05);\n}\n\n/**\n * Sets the absolute transparency of a color.\n * Any existing alpha values are overwritten.\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color()\n * @param {number} value - value to set the alpha channel to in the range 0 - 1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\nfunction alpha(color, value) {\n color = decomposeColor(color);\n value = clampWrapper(value);\n if (color.type === 'rgb' || color.type === 'hsl') {\n color.type += 'a';\n }\n if (color.type === 'color') {\n color.values[3] = `/${value}`;\n } else {\n color.values[3] = value;\n }\n return recomposeColor(color);\n}\nfunction private_safeAlpha(color, value, warning) {\n try {\n return alpha(color, value);\n } catch (error) {\n if (warning && process.env.NODE_ENV !== 'production') {\n console.warn(warning);\n }\n return color;\n }\n}\n\n/**\n * Darkens a color.\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color()\n * @param {number} coefficient - multiplier in the range 0 - 1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\nfunction darken(color, coefficient) {\n color = decomposeColor(color);\n coefficient = clampWrapper(coefficient);\n if (color.type.indexOf('hsl') !== -1) {\n color.values[2] *= 1 - coefficient;\n } else if (color.type.indexOf('rgb') !== -1 || color.type.indexOf('color') !== -1) {\n for (let i = 0; i < 3; i += 1) {\n color.values[i] *= 1 - coefficient;\n }\n }\n return recomposeColor(color);\n}\nfunction private_safeDarken(color, coefficient, warning) {\n try {\n return darken(color, coefficient);\n } catch (error) {\n if (warning && process.env.NODE_ENV !== 'production') {\n console.warn(warning);\n }\n return color;\n }\n}\n\n/**\n * Lightens a color.\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color()\n * @param {number} coefficient - multiplier in the range 0 - 1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\nfunction lighten(color, coefficient) {\n color = decomposeColor(color);\n coefficient = clampWrapper(coefficient);\n if (color.type.indexOf('hsl') !== -1) {\n color.values[2] += (100 - color.values[2]) * coefficient;\n } else if (color.type.indexOf('rgb') !== -1) {\n for (let i = 0; i < 3; i += 1) {\n color.values[i] += (255 - color.values[i]) * coefficient;\n }\n } else if (color.type.indexOf('color') !== -1) {\n for (let i = 0; i < 3; i += 1) {\n color.values[i] += (1 - color.values[i]) * coefficient;\n }\n }\n return recomposeColor(color);\n}\nfunction private_safeLighten(color, coefficient, warning) {\n try {\n return lighten(color, coefficient);\n } catch (error) {\n if (warning && process.env.NODE_ENV !== 'production') {\n console.warn(warning);\n }\n return color;\n }\n}\n\n/**\n * Darken or lighten a color, depending on its luminance.\n * Light colors are darkened, dark colors are lightened.\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color()\n * @param {number} coefficient=0.15 - multiplier in the range 0 - 1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\nfunction emphasize(color, coefficient = 0.15) {\n return getLuminance(color) > 0.5 ? darken(color, coefficient) : lighten(color, coefficient);\n}\nfunction private_safeEmphasize(color, coefficient, warning) {\n try {\n return emphasize(color, coefficient);\n } catch (error) {\n if (warning && process.env.NODE_ENV !== 'production') {\n console.warn(warning);\n }\n return color;\n }\n}\n\n/**\n * Blend a transparent overlay color with a background color, resulting in a single\n * RGB color.\n * @param {string} background - CSS color\n * @param {string} overlay - CSS color\n * @param {number} opacity - Opacity multiplier in the range 0 - 1\n * @param {number} [gamma=1.0] - Gamma correction factor. For gamma-correct blending, 2.2 is usual.\n */\nfunction blend(background, overlay, opacity, gamma = 1.0) {\n const blendChannel = (b, o) => Math.round((b ** (1 / gamma) * (1 - opacity) + o ** (1 / gamma) * opacity) ** gamma);\n const backgroundColor = decomposeColor(background);\n const overlayColor = decomposeColor(overlay);\n const rgb = [blendChannel(backgroundColor.values[0], overlayColor.values[0]), blendChannel(backgroundColor.values[1], overlayColor.values[1]), blendChannel(backgroundColor.values[2], overlayColor.values[2])];\n return recomposeColor({\n type: 'rgb',\n values: rgb\n });\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = createStyled;\nexports.shouldForwardProp = shouldForwardProp;\nexports.systemDefaultTheme = void 0;\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\nvar _objectWithoutPropertiesLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/objectWithoutPropertiesLoose\"));\nvar _styledEngine = _interopRequireWildcard(require(\"@mui/styled-engine\"));\nvar _deepmerge = require(\"@mui/utils/deepmerge\");\nvar _capitalize = _interopRequireDefault(require(\"@mui/utils/capitalize\"));\nvar _getDisplayName = _interopRequireDefault(require(\"@mui/utils/getDisplayName\"));\nvar _createTheme = _interopRequireDefault(require(\"./createTheme\"));\nvar _styleFunctionSx = _interopRequireDefault(require(\"./styleFunctionSx\"));\nconst _excluded = [\"ownerState\"],\n _excluded2 = [\"variants\"],\n _excluded3 = [\"name\", \"slot\", \"skipVariantsResolver\", \"skipSx\", \"overridesResolver\"];\n/* eslint-disable no-underscore-dangle */\nfunction _getRequireWildcardCache(e) { if (\"function\" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }\nfunction _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || \"object\" != typeof e && \"function\" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }\nfunction isEmpty(obj) {\n return Object.keys(obj).length === 0;\n}\n\n// https://github.com/emotion-js/emotion/blob/26ded6109fcd8ca9875cc2ce4564fee678a3f3c5/packages/styled/src/utils.js#L40\nfunction isStringTag(tag) {\n return typeof tag === 'string' &&\n // 96 is one less than the char code\n // for \"a\" so this is checking that\n // it's a lowercase character\n tag.charCodeAt(0) > 96;\n}\n\n// Update /system/styled/#api in case if this changes\nfunction shouldForwardProp(prop) {\n return prop !== 'ownerState' && prop !== 'theme' && prop !== 'sx' && prop !== 'as';\n}\nconst systemDefaultTheme = exports.systemDefaultTheme = (0, _createTheme.default)();\nconst lowercaseFirstLetter = string => {\n if (!string) {\n return string;\n }\n return string.charAt(0).toLowerCase() + string.slice(1);\n};\nfunction resolveTheme({\n defaultTheme,\n theme,\n themeId\n}) {\n return isEmpty(theme) ? defaultTheme : theme[themeId] || theme;\n}\nfunction defaultOverridesResolver(slot) {\n if (!slot) {\n return null;\n }\n return (props, styles) => styles[slot];\n}\nfunction processStyleArg(callableStyle, _ref) {\n let {\n ownerState\n } = _ref,\n props = (0, _objectWithoutPropertiesLoose2.default)(_ref, _excluded);\n const resolvedStylesArg = typeof callableStyle === 'function' ? callableStyle((0, _extends2.default)({\n ownerState\n }, props)) : callableStyle;\n if (Array.isArray(resolvedStylesArg)) {\n return resolvedStylesArg.flatMap(resolvedStyle => processStyleArg(resolvedStyle, (0, _extends2.default)({\n ownerState\n }, props)));\n }\n if (!!resolvedStylesArg && typeof resolvedStylesArg === 'object' && Array.isArray(resolvedStylesArg.variants)) {\n const {\n variants = []\n } = resolvedStylesArg,\n otherStyles = (0, _objectWithoutPropertiesLoose2.default)(resolvedStylesArg, _excluded2);\n let result = otherStyles;\n variants.forEach(variant => {\n let isMatch = true;\n if (typeof variant.props === 'function') {\n isMatch = variant.props((0, _extends2.default)({\n ownerState\n }, props, ownerState));\n } else {\n Object.keys(variant.props).forEach(key => {\n if ((ownerState == null ? void 0 : ownerState[key]) !== variant.props[key] && props[key] !== variant.props[key]) {\n isMatch = false;\n }\n });\n }\n if (isMatch) {\n if (!Array.isArray(result)) {\n result = [result];\n }\n result.push(typeof variant.style === 'function' ? variant.style((0, _extends2.default)({\n ownerState\n }, props, ownerState)) : variant.style);\n }\n });\n return result;\n }\n return resolvedStylesArg;\n}\nfunction createStyled(input = {}) {\n const {\n themeId,\n defaultTheme = systemDefaultTheme,\n rootShouldForwardProp = shouldForwardProp,\n slotShouldForwardProp = shouldForwardProp\n } = input;\n const systemSx = props => {\n return (0, _styleFunctionSx.default)((0, _extends2.default)({}, props, {\n theme: resolveTheme((0, _extends2.default)({}, props, {\n defaultTheme,\n themeId\n }))\n }));\n };\n systemSx.__mui_systemSx = true;\n return (tag, inputOptions = {}) => {\n // Filter out the `sx` style function from the previous styled component to prevent unnecessary styles generated by the composite components.\n (0, _styledEngine.internal_processStyles)(tag, styles => styles.filter(style => !(style != null && style.__mui_systemSx)));\n const {\n name: componentName,\n slot: componentSlot,\n skipVariantsResolver: inputSkipVariantsResolver,\n skipSx: inputSkipSx,\n // TODO v6: remove `lowercaseFirstLetter()` in the next major release\n // For more details: https://github.com/mui/material-ui/pull/37908\n overridesResolver = defaultOverridesResolver(lowercaseFirstLetter(componentSlot))\n } = inputOptions,\n options = (0, _objectWithoutPropertiesLoose2.default)(inputOptions, _excluded3);\n\n // if skipVariantsResolver option is defined, take the value, otherwise, true for root and false for other slots.\n const skipVariantsResolver = inputSkipVariantsResolver !== undefined ? inputSkipVariantsResolver :\n // TODO v6: remove `Root` in the next major release\n // For more details: https://github.com/mui/material-ui/pull/37908\n componentSlot && componentSlot !== 'Root' && componentSlot !== 'root' || false;\n const skipSx = inputSkipSx || false;\n let label;\n if (process.env.NODE_ENV !== 'production') {\n if (componentName) {\n // TODO v6: remove `lowercaseFirstLetter()` in the next major release\n // For more details: https://github.com/mui/material-ui/pull/37908\n label = `${componentName}-${lowercaseFirstLetter(componentSlot || 'Root')}`;\n }\n }\n let shouldForwardPropOption = shouldForwardProp;\n\n // TODO v6: remove `Root` in the next major release\n // For more details: https://github.com/mui/material-ui/pull/37908\n if (componentSlot === 'Root' || componentSlot === 'root') {\n shouldForwardPropOption = rootShouldForwardProp;\n } else if (componentSlot) {\n // any other slot specified\n shouldForwardPropOption = slotShouldForwardProp;\n } else if (isStringTag(tag)) {\n // for string (html) tag, preserve the behavior in emotion & styled-components.\n shouldForwardPropOption = undefined;\n }\n const defaultStyledResolver = (0, _styledEngine.default)(tag, (0, _extends2.default)({\n shouldForwardProp: shouldForwardPropOption,\n label\n }, options));\n const transformStyleArg = stylesArg => {\n // On the server Emotion doesn't use React.forwardRef for creating components, so the created\n // component stays as a function. This condition makes sure that we do not interpolate functions\n // which are basically components used as a selectors.\n if (typeof stylesArg === 'function' && stylesArg.__emotion_real !== stylesArg || (0, _deepmerge.isPlainObject)(stylesArg)) {\n return props => processStyleArg(stylesArg, (0, _extends2.default)({}, props, {\n theme: resolveTheme({\n theme: props.theme,\n defaultTheme,\n themeId\n })\n }));\n }\n return stylesArg;\n };\n const muiStyledResolver = (styleArg, ...expressions) => {\n let transformedStyleArg = transformStyleArg(styleArg);\n const expressionsWithDefaultTheme = expressions ? expressions.map(transformStyleArg) : [];\n if (componentName && overridesResolver) {\n expressionsWithDefaultTheme.push(props => {\n const theme = resolveTheme((0, _extends2.default)({}, props, {\n defaultTheme,\n themeId\n }));\n if (!theme.components || !theme.components[componentName] || !theme.components[componentName].styleOverrides) {\n return null;\n }\n const styleOverrides = theme.components[componentName].styleOverrides;\n const resolvedStyleOverrides = {};\n // TODO: v7 remove iteration and use `resolveStyleArg(styleOverrides[slot])` directly\n Object.entries(styleOverrides).forEach(([slotKey, slotStyle]) => {\n resolvedStyleOverrides[slotKey] = processStyleArg(slotStyle, (0, _extends2.default)({}, props, {\n theme\n }));\n });\n return overridesResolver(props, resolvedStyleOverrides);\n });\n }\n if (componentName && !skipVariantsResolver) {\n expressionsWithDefaultTheme.push(props => {\n var _theme$components;\n const theme = resolveTheme((0, _extends2.default)({}, props, {\n defaultTheme,\n themeId\n }));\n const themeVariants = theme == null || (_theme$components = theme.components) == null || (_theme$components = _theme$components[componentName]) == null ? void 0 : _theme$components.variants;\n return processStyleArg({\n variants: themeVariants\n }, (0, _extends2.default)({}, props, {\n theme\n }));\n });\n }\n if (!skipSx) {\n expressionsWithDefaultTheme.push(systemSx);\n }\n const numOfCustomFnsApplied = expressionsWithDefaultTheme.length - expressions.length;\n if (Array.isArray(styleArg) && numOfCustomFnsApplied > 0) {\n const placeholders = new Array(numOfCustomFnsApplied).fill('');\n // If the type is array, than we need to add placeholders in the template for the overrides, variants and the sx styles.\n transformedStyleArg = [...styleArg, ...placeholders];\n transformedStyleArg.raw = [...styleArg.raw, ...placeholders];\n }\n const Component = defaultStyledResolver(transformedStyleArg, ...expressionsWithDefaultTheme);\n if (process.env.NODE_ENV !== 'production') {\n let displayName;\n if (componentName) {\n displayName = `${componentName}${(0, _capitalize.default)(componentSlot || '')}`;\n }\n if (displayName === undefined) {\n displayName = `Styled(${(0, _getDisplayName.default)(tag)})`;\n }\n Component.displayName = displayName;\n }\n if (tag.muiName) {\n Component.muiName = tag.muiName;\n }\n return Component;\n };\n if (defaultStyledResolver.withConfig) {\n muiStyledResolver.withConfig = defaultStyledResolver.withConfig;\n }\n return muiStyledResolver;\n };\n}","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport resolveProps from '@mui/utils/resolveProps';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst PropsContext = /*#__PURE__*/React.createContext(undefined);\nfunction DefaultPropsProvider({\n value,\n children\n}) {\n return /*#__PURE__*/_jsx(PropsContext.Provider, {\n value: value,\n children: children\n });\n}\nprocess.env.NODE_ENV !== \"production\" ? DefaultPropsProvider.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the TypeScript types and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * @ignore\n */\n children: PropTypes.node,\n /**\n * @ignore\n */\n value: PropTypes.object\n} : void 0;\nfunction getThemeProps(params) {\n const {\n theme,\n name,\n props\n } = params;\n if (!theme || !theme.components || !theme.components[name]) {\n return props;\n }\n const config = theme.components[name];\n if (config.defaultProps) {\n // compatible with v5 signature\n return resolveProps(config.defaultProps, props);\n }\n if (!config.styleOverrides && !config.variants) {\n // v6 signature, no property 'defaultProps'\n return resolveProps(config, props);\n }\n return props;\n}\nexport function useDefaultProps({\n props,\n name\n}) {\n const ctx = React.useContext(PropsContext);\n return getThemeProps({\n props,\n name,\n theme: {\n components: ctx\n }\n });\n}\nexport default DefaultPropsProvider;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport PropTypes from 'prop-types';\nimport deepmerge from '@mui/utils/deepmerge';\nimport merge from './merge';\n\n// The breakpoint **start** at this value.\n// For instance with the first breakpoint xs: [xs, sm[.\nexport const values = {\n xs: 0,\n // phone\n sm: 600,\n // tablet\n md: 900,\n // small laptop\n lg: 1200,\n // desktop\n xl: 1536 // large screen\n};\nconst defaultBreakpoints = {\n // Sorted ASC by size. That's important.\n // It can't be configured as it's used statically for propTypes.\n keys: ['xs', 'sm', 'md', 'lg', 'xl'],\n up: key => `@media (min-width:${values[key]}px)`\n};\nexport function handleBreakpoints(props, propValue, styleFromPropValue) {\n const theme = props.theme || {};\n if (Array.isArray(propValue)) {\n const themeBreakpoints = theme.breakpoints || defaultBreakpoints;\n return propValue.reduce((acc, item, index) => {\n acc[themeBreakpoints.up(themeBreakpoints.keys[index])] = styleFromPropValue(propValue[index]);\n return acc;\n }, {});\n }\n if (typeof propValue === 'object') {\n const themeBreakpoints = theme.breakpoints || defaultBreakpoints;\n return Object.keys(propValue).reduce((acc, breakpoint) => {\n // key is breakpoint\n if (Object.keys(themeBreakpoints.values || values).indexOf(breakpoint) !== -1) {\n const mediaKey = themeBreakpoints.up(breakpoint);\n acc[mediaKey] = styleFromPropValue(propValue[breakpoint], breakpoint);\n } else {\n const cssKey = breakpoint;\n acc[cssKey] = propValue[cssKey];\n }\n return acc;\n }, {});\n }\n const output = styleFromPropValue(propValue);\n return output;\n}\nfunction breakpoints(styleFunction) {\n // false positive\n // eslint-disable-next-line react/function-component-definition\n const newStyleFunction = props => {\n const theme = props.theme || {};\n const base = styleFunction(props);\n const themeBreakpoints = theme.breakpoints || defaultBreakpoints;\n const extended = themeBreakpoints.keys.reduce((acc, key) => {\n if (props[key]) {\n acc = acc || {};\n acc[themeBreakpoints.up(key)] = styleFunction(_extends({\n theme\n }, props[key]));\n }\n return acc;\n }, null);\n return merge(base, extended);\n };\n newStyleFunction.propTypes = process.env.NODE_ENV !== 'production' ? _extends({}, styleFunction.propTypes, {\n xs: PropTypes.object,\n sm: PropTypes.object,\n md: PropTypes.object,\n lg: PropTypes.object,\n xl: PropTypes.object\n }) : {};\n newStyleFunction.filterProps = ['xs', 'sm', 'md', 'lg', 'xl', ...styleFunction.filterProps];\n return newStyleFunction;\n}\nexport function createEmptyBreakpointObject(breakpointsInput = {}) {\n var _breakpointsInput$key;\n const breakpointsInOrder = (_breakpointsInput$key = breakpointsInput.keys) == null ? void 0 : _breakpointsInput$key.reduce((acc, key) => {\n const breakpointStyleKey = breakpointsInput.up(key);\n acc[breakpointStyleKey] = {};\n return acc;\n }, {});\n return breakpointsInOrder || {};\n}\nexport function removeUnusedBreakpoints(breakpointKeys, style) {\n return breakpointKeys.reduce((acc, key) => {\n const breakpointOutput = acc[key];\n const isBreakpointUnused = !breakpointOutput || Object.keys(breakpointOutput).length === 0;\n if (isBreakpointUnused) {\n delete acc[key];\n }\n return acc;\n }, style);\n}\nexport function mergeBreakpointsInOrder(breakpointsInput, ...styles) {\n const emptyBreakpoints = createEmptyBreakpointObject(breakpointsInput);\n const mergedOutput = [emptyBreakpoints, ...styles].reduce((prev, next) => deepmerge(prev, next), {});\n return removeUnusedBreakpoints(Object.keys(emptyBreakpoints), mergedOutput);\n}\n\n// compute base for responsive values; e.g.,\n// [1,2,3] => {xs: true, sm: true, md: true}\n// {xs: 1, sm: 2, md: 3} => {xs: true, sm: true, md: true}\nexport function computeBreakpointsBase(breakpointValues, themeBreakpoints) {\n // fixed value\n if (typeof breakpointValues !== 'object') {\n return {};\n }\n const base = {};\n const breakpointsKeys = Object.keys(themeBreakpoints);\n if (Array.isArray(breakpointValues)) {\n breakpointsKeys.forEach((breakpoint, i) => {\n if (i < breakpointValues.length) {\n base[breakpoint] = true;\n }\n });\n } else {\n breakpointsKeys.forEach(breakpoint => {\n if (breakpointValues[breakpoint] != null) {\n base[breakpoint] = true;\n }\n });\n }\n return base;\n}\nexport function resolveBreakpointValues({\n values: breakpointValues,\n breakpoints: themeBreakpoints,\n base: customBase\n}) {\n const base = customBase || computeBreakpointsBase(breakpointValues, themeBreakpoints);\n const keys = Object.keys(base);\n if (keys.length === 0) {\n return breakpointValues;\n }\n let previous;\n return keys.reduce((acc, breakpoint, i) => {\n if (Array.isArray(breakpointValues)) {\n acc[breakpoint] = breakpointValues[i] != null ? breakpointValues[i] : breakpointValues[previous];\n previous = i;\n } else if (typeof breakpointValues === 'object') {\n acc[breakpoint] = breakpointValues[breakpoint] != null ? breakpointValues[breakpoint] : breakpointValues[previous];\n previous = breakpoint;\n } else {\n acc[breakpoint] = breakpointValues;\n }\n return acc;\n }, {});\n}\nexport default breakpoints;","/**\n * A universal utility to style components with multiple color modes. Always use it from the theme object.\n * It works with:\n * - [Basic theme](https://mui.com/material-ui/customization/dark-mode/)\n * - [CSS theme variables](https://mui.com/material-ui/experimental-api/css-theme-variables/overview/)\n * - Zero-runtime engine\n *\n * Tips: Use an array over object spread and place `theme.applyStyles()` last.\n *\n * ✅ [{ background: '#e5e5e5' }, theme.applyStyles('dark', { background: '#1c1c1c' })]\n *\n * 🚫 { background: '#e5e5e5', ...theme.applyStyles('dark', { background: '#1c1c1c' })}\n *\n * @example\n * 1. using with `styled`:\n * ```jsx\n * const Component = styled('div')(({ theme }) => [\n * { background: '#e5e5e5' },\n * theme.applyStyles('dark', {\n * background: '#1c1c1c',\n * color: '#fff',\n * }),\n * ]);\n * ```\n *\n * @example\n * 2. using with `sx` prop:\n * ```jsx\n * [\n * { background: '#e5e5e5' },\n * theme.applyStyles('dark', {\n * background: '#1c1c1c',\n * color: '#fff',\n * }),\n * ]}\n * />\n * ```\n *\n * @example\n * 3. theming a component:\n * ```jsx\n * extendTheme({\n * components: {\n * MuiButton: {\n * styleOverrides: {\n * root: ({ theme }) => [\n * { background: '#e5e5e5' },\n * theme.applyStyles('dark', {\n * background: '#1c1c1c',\n * color: '#fff',\n * }),\n * ],\n * },\n * }\n * }\n * })\n *```\n */\nexport default function applyStyles(key, styles) {\n // @ts-expect-error this is 'any' type\n const theme = this;\n if (theme.vars && typeof theme.getColorSchemeSelector === 'function') {\n // If CssVarsProvider is used as a provider,\n // returns '* :where([data-mui-color-scheme=\"light|dark\"]) &'\n const selector = theme.getColorSchemeSelector(key).replace(/(\\[[^\\]]+\\])/, '*:where($1)');\n return {\n [selector]: styles\n };\n }\n if (theme.palette.mode === key) {\n return styles;\n }\n return {};\n}","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nconst _excluded = [\"values\", \"unit\", \"step\"];\n// Sorted ASC by size. That's important.\n// It can't be configured as it's used statically for propTypes.\nexport const breakpointKeys = ['xs', 'sm', 'md', 'lg', 'xl'];\nconst sortBreakpointsValues = values => {\n const breakpointsAsArray = Object.keys(values).map(key => ({\n key,\n val: values[key]\n })) || [];\n // Sort in ascending order\n breakpointsAsArray.sort((breakpoint1, breakpoint2) => breakpoint1.val - breakpoint2.val);\n return breakpointsAsArray.reduce((acc, obj) => {\n return _extends({}, acc, {\n [obj.key]: obj.val\n });\n }, {});\n};\n\n// Keep in mind that @media is inclusive by the CSS specification.\nexport default function createBreakpoints(breakpoints) {\n const {\n // The breakpoint **start** at this value.\n // For instance with the first breakpoint xs: [xs, sm).\n values = {\n xs: 0,\n // phone\n sm: 600,\n // tablet\n md: 900,\n // small laptop\n lg: 1200,\n // desktop\n xl: 1536 // large screen\n },\n unit = 'px',\n step = 5\n } = breakpoints,\n other = _objectWithoutPropertiesLoose(breakpoints, _excluded);\n const sortedValues = sortBreakpointsValues(values);\n const keys = Object.keys(sortedValues);\n function up(key) {\n const value = typeof values[key] === 'number' ? values[key] : key;\n return `@media (min-width:${value}${unit})`;\n }\n function down(key) {\n const value = typeof values[key] === 'number' ? values[key] : key;\n return `@media (max-width:${value - step / 100}${unit})`;\n }\n function between(start, end) {\n const endIndex = keys.indexOf(end);\n return `@media (min-width:${typeof values[start] === 'number' ? values[start] : start}${unit}) and ` + `(max-width:${(endIndex !== -1 && typeof values[keys[endIndex]] === 'number' ? values[keys[endIndex]] : end) - step / 100}${unit})`;\n }\n function only(key) {\n if (keys.indexOf(key) + 1 < keys.length) {\n return between(key, keys[keys.indexOf(key) + 1]);\n }\n return up(key);\n }\n function not(key) {\n // handle first and last key separately, for better readability\n const keyIndex = keys.indexOf(key);\n if (keyIndex === 0) {\n return up(keys[1]);\n }\n if (keyIndex === keys.length - 1) {\n return down(keys[keyIndex]);\n }\n return between(key, keys[keys.indexOf(key) + 1]).replace('@media', '@media not all and');\n }\n return _extends({\n keys,\n values: sortedValues,\n up,\n down,\n between,\n only,\n not,\n unit\n }, other);\n}","const shape = {\n borderRadius: 4\n};\nexport default shape;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"breakpoints\", \"palette\", \"spacing\", \"shape\"];\nimport deepmerge from '@mui/utils/deepmerge';\nimport createBreakpoints from './createBreakpoints';\nimport shape from './shape';\nimport createSpacing from './createSpacing';\nimport styleFunctionSx from '../styleFunctionSx/styleFunctionSx';\nimport defaultSxConfig from '../styleFunctionSx/defaultSxConfig';\nimport applyStyles from './applyStyles';\nfunction createTheme(options = {}, ...args) {\n const {\n breakpoints: breakpointsInput = {},\n palette: paletteInput = {},\n spacing: spacingInput,\n shape: shapeInput = {}\n } = options,\n other = _objectWithoutPropertiesLoose(options, _excluded);\n const breakpoints = createBreakpoints(breakpointsInput);\n const spacing = createSpacing(spacingInput);\n let muiTheme = deepmerge({\n breakpoints,\n direction: 'ltr',\n components: {},\n // Inject component definitions.\n palette: _extends({\n mode: 'light'\n }, paletteInput),\n spacing,\n shape: _extends({}, shape, shapeInput)\n }, other);\n muiTheme.applyStyles = applyStyles;\n muiTheme = args.reduce((acc, argument) => deepmerge(acc, argument), muiTheme);\n muiTheme.unstable_sxConfig = _extends({}, defaultSxConfig, other == null ? void 0 : other.unstable_sxConfig);\n muiTheme.unstable_sx = function sx(props) {\n return styleFunctionSx({\n sx: props,\n theme: this\n });\n };\n return muiTheme;\n}\nexport default createTheme;","import { createUnarySpacing } from '../spacing';\n\n// The different signatures imply different meaning for their arguments that can't be expressed structurally.\n// We express the difference with variable names.\n\nexport default function createSpacing(spacingInput = 8) {\n // Already transformed.\n if (spacingInput.mui) {\n return spacingInput;\n }\n\n // Material Design layouts are visually balanced. Most measurements align to an 8dp grid, which aligns both spacing and the overall layout.\n // Smaller components, such as icons, can align to a 4dp grid.\n // https://m2.material.io/design/layout/understanding-layout.html\n const transform = createUnarySpacing({\n spacing: spacingInput\n });\n const spacing = (...argsInput) => {\n if (process.env.NODE_ENV !== 'production') {\n if (!(argsInput.length <= 4)) {\n console.error(`MUI: Too many arguments provided, expected between 0 and 4, got ${argsInput.length}`);\n }\n }\n const args = argsInput.length === 0 ? [1] : argsInput;\n return args.map(argument => {\n const output = transform(argument);\n return typeof output === 'number' ? `${output}px` : output;\n }).join(' ');\n };\n spacing.mui = true;\n return spacing;\n}","import deepmerge from '@mui/utils/deepmerge';\nfunction merge(acc, item) {\n if (!item) {\n return acc;\n }\n return deepmerge(acc, item, {\n clone: false // No need to clone deep, it's way faster.\n });\n}\nexport default merge;","import responsivePropType from './responsivePropType';\nimport { handleBreakpoints } from './breakpoints';\nimport { getPath } from './style';\nimport merge from './merge';\nimport memoize from './memoize';\nconst properties = {\n m: 'margin',\n p: 'padding'\n};\nconst directions = {\n t: 'Top',\n r: 'Right',\n b: 'Bottom',\n l: 'Left',\n x: ['Left', 'Right'],\n y: ['Top', 'Bottom']\n};\nconst aliases = {\n marginX: 'mx',\n marginY: 'my',\n paddingX: 'px',\n paddingY: 'py'\n};\n\n// memoize() impact:\n// From 300,000 ops/sec\n// To 350,000 ops/sec\nconst getCssProperties = memoize(prop => {\n // It's not a shorthand notation.\n if (prop.length > 2) {\n if (aliases[prop]) {\n prop = aliases[prop];\n } else {\n return [prop];\n }\n }\n const [a, b] = prop.split('');\n const property = properties[a];\n const direction = directions[b] || '';\n return Array.isArray(direction) ? direction.map(dir => property + dir) : [property + direction];\n});\nexport const marginKeys = ['m', 'mt', 'mr', 'mb', 'ml', 'mx', 'my', 'margin', 'marginTop', 'marginRight', 'marginBottom', 'marginLeft', 'marginX', 'marginY', 'marginInline', 'marginInlineStart', 'marginInlineEnd', 'marginBlock', 'marginBlockStart', 'marginBlockEnd'];\nexport const paddingKeys = ['p', 'pt', 'pr', 'pb', 'pl', 'px', 'py', 'padding', 'paddingTop', 'paddingRight', 'paddingBottom', 'paddingLeft', 'paddingX', 'paddingY', 'paddingInline', 'paddingInlineStart', 'paddingInlineEnd', 'paddingBlock', 'paddingBlockStart', 'paddingBlockEnd'];\nconst spacingKeys = [...marginKeys, ...paddingKeys];\nexport function createUnaryUnit(theme, themeKey, defaultValue, propName) {\n var _getPath;\n const themeSpacing = (_getPath = getPath(theme, themeKey, false)) != null ? _getPath : defaultValue;\n if (typeof themeSpacing === 'number') {\n return abs => {\n if (typeof abs === 'string') {\n return abs;\n }\n if (process.env.NODE_ENV !== 'production') {\n if (typeof abs !== 'number') {\n console.error(`MUI: Expected ${propName} argument to be a number or a string, got ${abs}.`);\n }\n }\n return themeSpacing * abs;\n };\n }\n if (Array.isArray(themeSpacing)) {\n return abs => {\n if (typeof abs === 'string') {\n return abs;\n }\n if (process.env.NODE_ENV !== 'production') {\n if (!Number.isInteger(abs)) {\n console.error([`MUI: The \\`theme.${themeKey}\\` array type cannot be combined with non integer values.` + `You should either use an integer value that can be used as index, or define the \\`theme.${themeKey}\\` as a number.`].join('\\n'));\n } else if (abs > themeSpacing.length - 1) {\n console.error([`MUI: The value provided (${abs}) overflows.`, `The supported values are: ${JSON.stringify(themeSpacing)}.`, `${abs} > ${themeSpacing.length - 1}, you need to add the missing values.`].join('\\n'));\n }\n }\n return themeSpacing[abs];\n };\n }\n if (typeof themeSpacing === 'function') {\n return themeSpacing;\n }\n if (process.env.NODE_ENV !== 'production') {\n console.error([`MUI: The \\`theme.${themeKey}\\` value (${themeSpacing}) is invalid.`, 'It should be a number, an array or a function.'].join('\\n'));\n }\n return () => undefined;\n}\nexport function createUnarySpacing(theme) {\n return createUnaryUnit(theme, 'spacing', 8, 'spacing');\n}\nexport function getValue(transformer, propValue) {\n if (typeof propValue === 'string' || propValue == null) {\n return propValue;\n }\n const abs = Math.abs(propValue);\n const transformed = transformer(abs);\n if (propValue >= 0) {\n return transformed;\n }\n if (typeof transformed === 'number') {\n return -transformed;\n }\n return `-${transformed}`;\n}\nexport function getStyleFromPropValue(cssProperties, transformer) {\n return propValue => cssProperties.reduce((acc, cssProperty) => {\n acc[cssProperty] = getValue(transformer, propValue);\n return acc;\n }, {});\n}\nfunction resolveCssProperty(props, keys, prop, transformer) {\n // Using a hash computation over an array iteration could be faster, but with only 28 items,\n // it's doesn't worth the bundle size.\n if (keys.indexOf(prop) === -1) {\n return null;\n }\n const cssProperties = getCssProperties(prop);\n const styleFromPropValue = getStyleFromPropValue(cssProperties, transformer);\n const propValue = props[prop];\n return handleBreakpoints(props, propValue, styleFromPropValue);\n}\nfunction style(props, keys) {\n const transformer = createUnarySpacing(props.theme);\n return Object.keys(props).map(prop => resolveCssProperty(props, keys, prop, transformer)).reduce(merge, {});\n}\nexport function margin(props) {\n return style(props, marginKeys);\n}\nmargin.propTypes = process.env.NODE_ENV !== 'production' ? marginKeys.reduce((obj, key) => {\n obj[key] = responsivePropType;\n return obj;\n}, {}) : {};\nmargin.filterProps = marginKeys;\nexport function padding(props) {\n return style(props, paddingKeys);\n}\npadding.propTypes = process.env.NODE_ENV !== 'production' ? paddingKeys.reduce((obj, key) => {\n obj[key] = responsivePropType;\n return obj;\n}, {}) : {};\npadding.filterProps = paddingKeys;\nfunction spacing(props) {\n return style(props, spacingKeys);\n}\nspacing.propTypes = process.env.NODE_ENV !== 'production' ? spacingKeys.reduce((obj, key) => {\n obj[key] = responsivePropType;\n return obj;\n}, {}) : {};\nspacing.filterProps = spacingKeys;\nexport default spacing;","export default function memoize(fn) {\n const cache = {};\n return arg => {\n if (cache[arg] === undefined) {\n cache[arg] = fn(arg);\n }\n return cache[arg];\n };\n}","import capitalize from '@mui/utils/capitalize';\nimport responsivePropType from './responsivePropType';\nimport { handleBreakpoints } from './breakpoints';\nexport function getPath(obj, path, checkVars = true) {\n if (!path || typeof path !== 'string') {\n return null;\n }\n\n // Check if CSS variables are used\n if (obj && obj.vars && checkVars) {\n const val = `vars.${path}`.split('.').reduce((acc, item) => acc && acc[item] ? acc[item] : null, obj);\n if (val != null) {\n return val;\n }\n }\n return path.split('.').reduce((acc, item) => {\n if (acc && acc[item] != null) {\n return acc[item];\n }\n return null;\n }, obj);\n}\nexport function getStyleValue(themeMapping, transform, propValueFinal, userValue = propValueFinal) {\n let value;\n if (typeof themeMapping === 'function') {\n value = themeMapping(propValueFinal);\n } else if (Array.isArray(themeMapping)) {\n value = themeMapping[propValueFinal] || userValue;\n } else {\n value = getPath(themeMapping, propValueFinal) || userValue;\n }\n if (transform) {\n value = transform(value, userValue, themeMapping);\n }\n return value;\n}\nfunction style(options) {\n const {\n prop,\n cssProperty = options.prop,\n themeKey,\n transform\n } = options;\n\n // false positive\n // eslint-disable-next-line react/function-component-definition\n const fn = props => {\n if (props[prop] == null) {\n return null;\n }\n const propValue = props[prop];\n const theme = props.theme;\n const themeMapping = getPath(theme, themeKey) || {};\n const styleFromPropValue = propValueFinal => {\n let value = getStyleValue(themeMapping, transform, propValueFinal);\n if (propValueFinal === value && typeof propValueFinal === 'string') {\n // Haven't found value\n value = getStyleValue(themeMapping, transform, `${prop}${propValueFinal === 'default' ? '' : capitalize(propValueFinal)}`, propValueFinal);\n }\n if (cssProperty === false) {\n return value;\n }\n return {\n [cssProperty]: value\n };\n };\n return handleBreakpoints(props, propValue, styleFromPropValue);\n };\n fn.propTypes = process.env.NODE_ENV !== 'production' ? {\n [prop]: responsivePropType\n } : {};\n fn.filterProps = [prop];\n return fn;\n}\nexport default style;","import merge from './merge';\nfunction compose(...styles) {\n const handlers = styles.reduce((acc, style) => {\n style.filterProps.forEach(prop => {\n acc[prop] = style;\n });\n return acc;\n }, {});\n\n // false positive\n // eslint-disable-next-line react/function-component-definition\n const fn = props => {\n return Object.keys(props).reduce((acc, prop) => {\n if (handlers[prop]) {\n return merge(acc, handlers[prop](props));\n }\n return acc;\n }, {});\n };\n fn.propTypes = process.env.NODE_ENV !== 'production' ? styles.reduce((acc, style) => Object.assign(acc, style.propTypes), {}) : {};\n fn.filterProps = styles.reduce((acc, style) => acc.concat(style.filterProps), []);\n return fn;\n}\nexport default compose;","import responsivePropType from './responsivePropType';\nimport style from './style';\nimport compose from './compose';\nimport { createUnaryUnit, getValue } from './spacing';\nimport { handleBreakpoints } from './breakpoints';\nexport function borderTransform(value) {\n if (typeof value !== 'number') {\n return value;\n }\n return `${value}px solid`;\n}\nfunction createBorderStyle(prop, transform) {\n return style({\n prop,\n themeKey: 'borders',\n transform\n });\n}\nexport const border = createBorderStyle('border', borderTransform);\nexport const borderTop = createBorderStyle('borderTop', borderTransform);\nexport const borderRight = createBorderStyle('borderRight', borderTransform);\nexport const borderBottom = createBorderStyle('borderBottom', borderTransform);\nexport const borderLeft = createBorderStyle('borderLeft', borderTransform);\nexport const borderColor = createBorderStyle('borderColor');\nexport const borderTopColor = createBorderStyle('borderTopColor');\nexport const borderRightColor = createBorderStyle('borderRightColor');\nexport const borderBottomColor = createBorderStyle('borderBottomColor');\nexport const borderLeftColor = createBorderStyle('borderLeftColor');\nexport const outline = createBorderStyle('outline', borderTransform);\nexport const outlineColor = createBorderStyle('outlineColor');\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const borderRadius = props => {\n if (props.borderRadius !== undefined && props.borderRadius !== null) {\n const transformer = createUnaryUnit(props.theme, 'shape.borderRadius', 4, 'borderRadius');\n const styleFromPropValue = propValue => ({\n borderRadius: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.borderRadius, styleFromPropValue);\n }\n return null;\n};\nborderRadius.propTypes = process.env.NODE_ENV !== 'production' ? {\n borderRadius: responsivePropType\n} : {};\nborderRadius.filterProps = ['borderRadius'];\nconst borders = compose(border, borderTop, borderRight, borderBottom, borderLeft, borderColor, borderTopColor, borderRightColor, borderBottomColor, borderLeftColor, borderRadius, outline, outlineColor);\nexport default borders;","import style from './style';\nimport compose from './compose';\nimport { createUnaryUnit, getValue } from './spacing';\nimport { handleBreakpoints } from './breakpoints';\nimport responsivePropType from './responsivePropType';\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const gap = props => {\n if (props.gap !== undefined && props.gap !== null) {\n const transformer = createUnaryUnit(props.theme, 'spacing', 8, 'gap');\n const styleFromPropValue = propValue => ({\n gap: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.gap, styleFromPropValue);\n }\n return null;\n};\ngap.propTypes = process.env.NODE_ENV !== 'production' ? {\n gap: responsivePropType\n} : {};\ngap.filterProps = ['gap'];\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const columnGap = props => {\n if (props.columnGap !== undefined && props.columnGap !== null) {\n const transformer = createUnaryUnit(props.theme, 'spacing', 8, 'columnGap');\n const styleFromPropValue = propValue => ({\n columnGap: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.columnGap, styleFromPropValue);\n }\n return null;\n};\ncolumnGap.propTypes = process.env.NODE_ENV !== 'production' ? {\n columnGap: responsivePropType\n} : {};\ncolumnGap.filterProps = ['columnGap'];\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const rowGap = props => {\n if (props.rowGap !== undefined && props.rowGap !== null) {\n const transformer = createUnaryUnit(props.theme, 'spacing', 8, 'rowGap');\n const styleFromPropValue = propValue => ({\n rowGap: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.rowGap, styleFromPropValue);\n }\n return null;\n};\nrowGap.propTypes = process.env.NODE_ENV !== 'production' ? {\n rowGap: responsivePropType\n} : {};\nrowGap.filterProps = ['rowGap'];\nexport const gridColumn = style({\n prop: 'gridColumn'\n});\nexport const gridRow = style({\n prop: 'gridRow'\n});\nexport const gridAutoFlow = style({\n prop: 'gridAutoFlow'\n});\nexport const gridAutoColumns = style({\n prop: 'gridAutoColumns'\n});\nexport const gridAutoRows = style({\n prop: 'gridAutoRows'\n});\nexport const gridTemplateColumns = style({\n prop: 'gridTemplateColumns'\n});\nexport const gridTemplateRows = style({\n prop: 'gridTemplateRows'\n});\nexport const gridTemplateAreas = style({\n prop: 'gridTemplateAreas'\n});\nexport const gridArea = style({\n prop: 'gridArea'\n});\nconst grid = compose(gap, columnGap, rowGap, gridColumn, gridRow, gridAutoFlow, gridAutoColumns, gridAutoRows, gridTemplateColumns, gridTemplateRows, gridTemplateAreas, gridArea);\nexport default grid;","import style from './style';\nimport compose from './compose';\nexport function paletteTransform(value, userValue) {\n if (userValue === 'grey') {\n return userValue;\n }\n return value;\n}\nexport const color = style({\n prop: 'color',\n themeKey: 'palette',\n transform: paletteTransform\n});\nexport const bgcolor = style({\n prop: 'bgcolor',\n cssProperty: 'backgroundColor',\n themeKey: 'palette',\n transform: paletteTransform\n});\nexport const backgroundColor = style({\n prop: 'backgroundColor',\n themeKey: 'palette',\n transform: paletteTransform\n});\nconst palette = compose(color, bgcolor, backgroundColor);\nexport default palette;","import style from './style';\nimport compose from './compose';\nimport { handleBreakpoints, values as breakpointsValues } from './breakpoints';\nexport function sizingTransform(value) {\n return value <= 1 && value !== 0 ? `${value * 100}%` : value;\n}\nexport const width = style({\n prop: 'width',\n transform: sizingTransform\n});\nexport const maxWidth = props => {\n if (props.maxWidth !== undefined && props.maxWidth !== null) {\n const styleFromPropValue = propValue => {\n var _props$theme, _props$theme2;\n const breakpoint = ((_props$theme = props.theme) == null || (_props$theme = _props$theme.breakpoints) == null || (_props$theme = _props$theme.values) == null ? void 0 : _props$theme[propValue]) || breakpointsValues[propValue];\n if (!breakpoint) {\n return {\n maxWidth: sizingTransform(propValue)\n };\n }\n if (((_props$theme2 = props.theme) == null || (_props$theme2 = _props$theme2.breakpoints) == null ? void 0 : _props$theme2.unit) !== 'px') {\n return {\n maxWidth: `${breakpoint}${props.theme.breakpoints.unit}`\n };\n }\n return {\n maxWidth: breakpoint\n };\n };\n return handleBreakpoints(props, props.maxWidth, styleFromPropValue);\n }\n return null;\n};\nmaxWidth.filterProps = ['maxWidth'];\nexport const minWidth = style({\n prop: 'minWidth',\n transform: sizingTransform\n});\nexport const height = style({\n prop: 'height',\n transform: sizingTransform\n});\nexport const maxHeight = style({\n prop: 'maxHeight',\n transform: sizingTransform\n});\nexport const minHeight = style({\n prop: 'minHeight',\n transform: sizingTransform\n});\nexport const sizeWidth = style({\n prop: 'size',\n cssProperty: 'width',\n transform: sizingTransform\n});\nexport const sizeHeight = style({\n prop: 'size',\n cssProperty: 'height',\n transform: sizingTransform\n});\nexport const boxSizing = style({\n prop: 'boxSizing'\n});\nconst sizing = compose(width, maxWidth, minWidth, height, maxHeight, minHeight, boxSizing);\nexport default sizing;","import { padding, margin } from '../spacing';\nimport { borderRadius, borderTransform } from '../borders';\nimport { gap, rowGap, columnGap } from '../cssGrid';\nimport { paletteTransform } from '../palette';\nimport { maxWidth, sizingTransform } from '../sizing';\nconst defaultSxConfig = {\n // borders\n border: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderTop: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderRight: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderBottom: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderLeft: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderColor: {\n themeKey: 'palette'\n },\n borderTopColor: {\n themeKey: 'palette'\n },\n borderRightColor: {\n themeKey: 'palette'\n },\n borderBottomColor: {\n themeKey: 'palette'\n },\n borderLeftColor: {\n themeKey: 'palette'\n },\n outline: {\n themeKey: 'borders',\n transform: borderTransform\n },\n outlineColor: {\n themeKey: 'palette'\n },\n borderRadius: {\n themeKey: 'shape.borderRadius',\n style: borderRadius\n },\n // palette\n color: {\n themeKey: 'palette',\n transform: paletteTransform\n },\n bgcolor: {\n themeKey: 'palette',\n cssProperty: 'backgroundColor',\n transform: paletteTransform\n },\n backgroundColor: {\n themeKey: 'palette',\n transform: paletteTransform\n },\n // spacing\n p: {\n style: padding\n },\n pt: {\n style: padding\n },\n pr: {\n style: padding\n },\n pb: {\n style: padding\n },\n pl: {\n style: padding\n },\n px: {\n style: padding\n },\n py: {\n style: padding\n },\n padding: {\n style: padding\n },\n paddingTop: {\n style: padding\n },\n paddingRight: {\n style: padding\n },\n paddingBottom: {\n style: padding\n },\n paddingLeft: {\n style: padding\n },\n paddingX: {\n style: padding\n },\n paddingY: {\n style: padding\n },\n paddingInline: {\n style: padding\n },\n paddingInlineStart: {\n style: padding\n },\n paddingInlineEnd: {\n style: padding\n },\n paddingBlock: {\n style: padding\n },\n paddingBlockStart: {\n style: padding\n },\n paddingBlockEnd: {\n style: padding\n },\n m: {\n style: margin\n },\n mt: {\n style: margin\n },\n mr: {\n style: margin\n },\n mb: {\n style: margin\n },\n ml: {\n style: margin\n },\n mx: {\n style: margin\n },\n my: {\n style: margin\n },\n margin: {\n style: margin\n },\n marginTop: {\n style: margin\n },\n marginRight: {\n style: margin\n },\n marginBottom: {\n style: margin\n },\n marginLeft: {\n style: margin\n },\n marginX: {\n style: margin\n },\n marginY: {\n style: margin\n },\n marginInline: {\n style: margin\n },\n marginInlineStart: {\n style: margin\n },\n marginInlineEnd: {\n style: margin\n },\n marginBlock: {\n style: margin\n },\n marginBlockStart: {\n style: margin\n },\n marginBlockEnd: {\n style: margin\n },\n // display\n displayPrint: {\n cssProperty: false,\n transform: value => ({\n '@media print': {\n display: value\n }\n })\n },\n display: {},\n overflow: {},\n textOverflow: {},\n visibility: {},\n whiteSpace: {},\n // flexbox\n flexBasis: {},\n flexDirection: {},\n flexWrap: {},\n justifyContent: {},\n alignItems: {},\n alignContent: {},\n order: {},\n flex: {},\n flexGrow: {},\n flexShrink: {},\n alignSelf: {},\n justifyItems: {},\n justifySelf: {},\n // grid\n gap: {\n style: gap\n },\n rowGap: {\n style: rowGap\n },\n columnGap: {\n style: columnGap\n },\n gridColumn: {},\n gridRow: {},\n gridAutoFlow: {},\n gridAutoColumns: {},\n gridAutoRows: {},\n gridTemplateColumns: {},\n gridTemplateRows: {},\n gridTemplateAreas: {},\n gridArea: {},\n // positions\n position: {},\n zIndex: {\n themeKey: 'zIndex'\n },\n top: {},\n right: {},\n bottom: {},\n left: {},\n // shadows\n boxShadow: {\n themeKey: 'shadows'\n },\n // sizing\n width: {\n transform: sizingTransform\n },\n maxWidth: {\n style: maxWidth\n },\n minWidth: {\n transform: sizingTransform\n },\n height: {\n transform: sizingTransform\n },\n maxHeight: {\n transform: sizingTransform\n },\n minHeight: {\n transform: sizingTransform\n },\n boxSizing: {},\n // typography\n fontFamily: {\n themeKey: 'typography'\n },\n fontSize: {\n themeKey: 'typography'\n },\n fontStyle: {\n themeKey: 'typography'\n },\n fontWeight: {\n themeKey: 'typography'\n },\n letterSpacing: {},\n textTransform: {},\n lineHeight: {},\n textAlign: {},\n typography: {\n cssProperty: false,\n themeKey: 'typography'\n }\n};\nexport default defaultSxConfig;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"sx\"];\nimport { isPlainObject } from '@mui/utils/deepmerge';\nimport defaultSxConfig from './defaultSxConfig';\nconst splitProps = props => {\n var _props$theme$unstable, _props$theme;\n const result = {\n systemProps: {},\n otherProps: {}\n };\n const config = (_props$theme$unstable = props == null || (_props$theme = props.theme) == null ? void 0 : _props$theme.unstable_sxConfig) != null ? _props$theme$unstable : defaultSxConfig;\n Object.keys(props).forEach(prop => {\n if (config[prop]) {\n result.systemProps[prop] = props[prop];\n } else {\n result.otherProps[prop] = props[prop];\n }\n });\n return result;\n};\nexport default function extendSxProp(props) {\n const {\n sx: inSx\n } = props,\n other = _objectWithoutPropertiesLoose(props, _excluded);\n const {\n systemProps,\n otherProps\n } = splitProps(other);\n let finalSx;\n if (Array.isArray(inSx)) {\n finalSx = [systemProps, ...inSx];\n } else if (typeof inSx === 'function') {\n finalSx = (...args) => {\n const result = inSx(...args);\n if (!isPlainObject(result)) {\n return systemProps;\n }\n return _extends({}, systemProps, result);\n };\n } else {\n finalSx = _extends({}, systemProps, inSx);\n }\n return _extends({}, otherProps, {\n sx: finalSx\n });\n}","import capitalize from '@mui/utils/capitalize';\nimport merge from '../merge';\nimport { getPath, getStyleValue as getValue } from '../style';\nimport { handleBreakpoints, createEmptyBreakpointObject, removeUnusedBreakpoints } from '../breakpoints';\nimport defaultSxConfig from './defaultSxConfig';\nfunction objectsHaveSameKeys(...objects) {\n const allKeys = objects.reduce((keys, object) => keys.concat(Object.keys(object)), []);\n const union = new Set(allKeys);\n return objects.every(object => union.size === Object.keys(object).length);\n}\nfunction callIfFn(maybeFn, arg) {\n return typeof maybeFn === 'function' ? maybeFn(arg) : maybeFn;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport function unstable_createStyleFunctionSx() {\n function getThemeValue(prop, val, theme, config) {\n const props = {\n [prop]: val,\n theme\n };\n const options = config[prop];\n if (!options) {\n return {\n [prop]: val\n };\n }\n const {\n cssProperty = prop,\n themeKey,\n transform,\n style\n } = options;\n if (val == null) {\n return null;\n }\n\n // TODO v6: remove, see https://github.com/mui/material-ui/pull/38123\n if (themeKey === 'typography' && val === 'inherit') {\n return {\n [prop]: val\n };\n }\n const themeMapping = getPath(theme, themeKey) || {};\n if (style) {\n return style(props);\n }\n const styleFromPropValue = propValueFinal => {\n let value = getValue(themeMapping, transform, propValueFinal);\n if (propValueFinal === value && typeof propValueFinal === 'string') {\n // Haven't found value\n value = getValue(themeMapping, transform, `${prop}${propValueFinal === 'default' ? '' : capitalize(propValueFinal)}`, propValueFinal);\n }\n if (cssProperty === false) {\n return value;\n }\n return {\n [cssProperty]: value\n };\n };\n return handleBreakpoints(props, val, styleFromPropValue);\n }\n function styleFunctionSx(props) {\n var _theme$unstable_sxCon;\n const {\n sx,\n theme = {}\n } = props || {};\n if (!sx) {\n return null; // Emotion & styled-components will neglect null\n }\n const config = (_theme$unstable_sxCon = theme.unstable_sxConfig) != null ? _theme$unstable_sxCon : defaultSxConfig;\n\n /*\n * Receive `sxInput` as object or callback\n * and then recursively check keys & values to create media query object styles.\n * (the result will be used in `styled`)\n */\n function traverse(sxInput) {\n let sxObject = sxInput;\n if (typeof sxInput === 'function') {\n sxObject = sxInput(theme);\n } else if (typeof sxInput !== 'object') {\n // value\n return sxInput;\n }\n if (!sxObject) {\n return null;\n }\n const emptyBreakpoints = createEmptyBreakpointObject(theme.breakpoints);\n const breakpointsKeys = Object.keys(emptyBreakpoints);\n let css = emptyBreakpoints;\n Object.keys(sxObject).forEach(styleKey => {\n const value = callIfFn(sxObject[styleKey], theme);\n if (value !== null && value !== undefined) {\n if (typeof value === 'object') {\n if (config[styleKey]) {\n css = merge(css, getThemeValue(styleKey, value, theme, config));\n } else {\n const breakpointsValues = handleBreakpoints({\n theme\n }, value, x => ({\n [styleKey]: x\n }));\n if (objectsHaveSameKeys(breakpointsValues, value)) {\n css[styleKey] = styleFunctionSx({\n sx: value,\n theme\n });\n } else {\n css = merge(css, breakpointsValues);\n }\n }\n } else {\n css = merge(css, getThemeValue(styleKey, value, theme, config));\n }\n }\n });\n return removeUnusedBreakpoints(breakpointsKeys, css);\n }\n return Array.isArray(sx) ? sx.map(traverse) : traverse(sx);\n }\n return styleFunctionSx;\n}\nconst styleFunctionSx = unstable_createStyleFunctionSx();\nstyleFunctionSx.filterProps = ['sx'];\nexport default styleFunctionSx;","\"use strict\";\n'use client';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar React = _interopRequireWildcard(require(\"react\"));\nvar _styledEngine = require(\"@mui/styled-engine\");\nfunction _getRequireWildcardCache(e) { if (\"function\" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }\nfunction _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || \"object\" != typeof e && \"function\" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }\nfunction isObjectEmpty(obj) {\n return Object.keys(obj).length === 0;\n}\nfunction useTheme(defaultTheme = null) {\n const contextTheme = React.useContext(_styledEngine.ThemeContext);\n return !contextTheme || isObjectEmpty(contextTheme) ? defaultTheme : contextTheme;\n}\nvar _default = exports.default = useTheme;","const defaultGenerator = componentName => componentName;\nconst createClassNameGenerator = () => {\n let generate = defaultGenerator;\n return {\n configure(generator) {\n generate = generator;\n },\n generate(componentName) {\n return generate(componentName);\n },\n reset() {\n generate = defaultGenerator;\n }\n };\n};\nconst ClassNameGenerator = createClassNameGenerator();\nexport default ClassNameGenerator;","import _formatMuiErrorMessage from \"@mui/utils/formatMuiErrorMessage\";\n// It should to be noted that this function isn't equivalent to `text-transform: capitalize`.\n//\n// A strict capitalization should uppercase the first letter of each word in the sentence.\n// We only handle the first word.\nexport default function capitalize(string) {\n if (typeof string !== 'string') {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: \\`capitalize(string)\\` expects a string argument.` : _formatMuiErrorMessage(7));\n }\n return string.charAt(0).toUpperCase() + string.slice(1);\n}","function clamp(val, min = Number.MIN_SAFE_INTEGER, max = Number.MAX_SAFE_INTEGER) {\n return Math.max(min, Math.min(val, max));\n}\nexport default clamp;","export default function composeClasses(slots, getUtilityClass, classes = undefined) {\n const output = {};\n Object.keys(slots).forEach(\n // `Object.keys(slots)` can't be wider than `T` because we infer `T` from `slots`.\n // @ts-expect-error https://github.com/microsoft/TypeScript/pull/12253#issuecomment-263132208\n slot => {\n output[slot] = slots[slot].reduce((acc, key) => {\n if (key) {\n const utilityClass = getUtilityClass(key);\n if (utilityClass !== '') {\n acc.push(utilityClass);\n }\n if (classes && classes[key]) {\n acc.push(classes[key]);\n }\n }\n return acc;\n }, []).join(' ');\n });\n return output;\n}","/**\n * Safe chained function.\n *\n * Will only create a new function if needed,\n * otherwise will pass back existing functions or null.\n */\nexport default function createChainedFunction(...funcs) {\n return funcs.reduce((acc, func) => {\n if (func == null) {\n return acc;\n }\n return function chainedFunction(...args) {\n acc.apply(this, args);\n func.apply(this, args);\n };\n }, () => {});\n}","// Corresponds to 10 frames at 60 Hz.\n// A few bytes payload overhead when lodash/debounce is ~3 kB and debounce ~300 B.\nexport default function debounce(func, wait = 166) {\n let timeout;\n function debounced(...args) {\n const later = () => {\n // @ts-ignore\n func.apply(this, args);\n };\n clearTimeout(timeout);\n timeout = setTimeout(later, wait);\n }\n debounced.clear = () => {\n clearTimeout(timeout);\n };\n return debounced;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\n// https://github.com/sindresorhus/is-plain-obj/blob/main/index.js\nexport function isPlainObject(item) {\n if (typeof item !== 'object' || item === null) {\n return false;\n }\n const prototype = Object.getPrototypeOf(item);\n return (prototype === null || prototype === Object.prototype || Object.getPrototypeOf(prototype) === null) && !(Symbol.toStringTag in item) && !(Symbol.iterator in item);\n}\nfunction deepClone(source) {\n if (!isPlainObject(source)) {\n return source;\n }\n const output = {};\n Object.keys(source).forEach(key => {\n output[key] = deepClone(source[key]);\n });\n return output;\n}\nexport default function deepmerge(target, source, options = {\n clone: true\n}) {\n const output = options.clone ? _extends({}, target) : target;\n if (isPlainObject(target) && isPlainObject(source)) {\n Object.keys(source).forEach(key => {\n if (isPlainObject(source[key]) &&\n // Avoid prototype pollution\n Object.prototype.hasOwnProperty.call(target, key) && isPlainObject(target[key])) {\n // Since `output` is a clone of `target` and we have narrowed `target` in this block we can cast to the same type.\n output[key] = deepmerge(target[key], source[key], options);\n } else if (options.clone) {\n output[key] = isPlainObject(source[key]) ? deepClone(source[key]) : source[key];\n } else {\n output[key] = source[key];\n }\n });\n }\n return output;\n}","/**\n * WARNING: Don't import this directly.\n * Use `MuiError` from `@mui/internal-babel-macros/MuiError.macro` instead.\n * @param {number} code\n */\nexport default function formatMuiErrorMessage(code) {\n // Apply babel-plugin-transform-template-literals in loose mode\n // loose mode is safe if we're concatenating primitives\n // see https://babeljs.io/docs/en/babel-plugin-transform-template-literals#loose\n /* eslint-disable prefer-template */\n let url = 'https://mui.com/production-error/?code=' + code;\n for (let i = 1; i < arguments.length; i += 1) {\n // rest params over-transpile for this case\n // eslint-disable-next-line prefer-rest-params\n url += '&args[]=' + encodeURIComponent(arguments[i]);\n }\n return 'Minified MUI error #' + code + '; visit ' + url + ' for the full message.';\n /* eslint-enable prefer-template */\n}","import ClassNameGenerator from '../ClassNameGenerator';\nexport const globalStateClasses = {\n active: 'active',\n checked: 'checked',\n completed: 'completed',\n disabled: 'disabled',\n error: 'error',\n expanded: 'expanded',\n focused: 'focused',\n focusVisible: 'focusVisible',\n open: 'open',\n readOnly: 'readOnly',\n required: 'required',\n selected: 'selected'\n};\nexport default function generateUtilityClass(componentName, slot, globalStatePrefix = 'Mui') {\n const globalStateClass = globalStateClasses[slot];\n return globalStateClass ? `${globalStatePrefix}-${globalStateClass}` : `${ClassNameGenerator.generate(componentName)}-${slot}`;\n}\nexport function isGlobalState(slot) {\n return globalStateClasses[slot] !== undefined;\n}","import generateUtilityClass from '../generateUtilityClass';\nexport default function generateUtilityClasses(componentName, slots, globalStatePrefix = 'Mui') {\n const result = {};\n slots.forEach(slot => {\n result[slot] = generateUtilityClass(componentName, slot, globalStatePrefix);\n });\n return result;\n}","import { ForwardRef, Memo } from 'react-is';\n\n// Simplified polyfill for IE11 support\n// https://github.com/JamesMGreene/Function.name/blob/58b314d4a983110c3682f1228f845d39ccca1817/Function.name.js#L3\nconst fnNameMatchRegex = /^\\s*function(?:\\s|\\s*\\/\\*.*\\*\\/\\s*)+([^(\\s/]*)\\s*/;\nexport function getFunctionName(fn) {\n const match = `${fn}`.match(fnNameMatchRegex);\n const name = match && match[1];\n return name || '';\n}\nfunction getFunctionComponentName(Component, fallback = '') {\n return Component.displayName || Component.name || getFunctionName(Component) || fallback;\n}\nfunction getWrappedName(outerType, innerType, wrapperName) {\n const functionName = getFunctionComponentName(innerType);\n return outerType.displayName || (functionName !== '' ? `${wrapperName}(${functionName})` : wrapperName);\n}\n\n/**\n * cherry-pick from\n * https://github.com/facebook/react/blob/769b1f270e1251d9dbdce0fcbd9e92e502d059b8/packages/shared/getComponentName.js\n * originally forked from recompose/getDisplayName with added IE11 support\n */\nexport default function getDisplayName(Component) {\n if (Component == null) {\n return undefined;\n }\n if (typeof Component === 'string') {\n return Component;\n }\n if (typeof Component === 'function') {\n return getFunctionComponentName(Component, 'Component');\n }\n\n // TypeScript can't have components as objects but they exist in the form of `memo` or `Suspense`\n if (typeof Component === 'object') {\n switch (Component.$$typeof) {\n case ForwardRef:\n return getWrappedName(Component, Component.render, 'ForwardRef');\n case Memo:\n return getWrappedName(Component, Component.type, 'memo');\n default:\n return undefined;\n }\n }\n return undefined;\n}","export default function ownerDocument(node) {\n return node && node.ownerDocument || document;\n}","import ownerDocument from '../ownerDocument';\nexport default function ownerWindow(node) {\n const doc = ownerDocument(node);\n return doc.defaultView || window;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\n/**\n * Add keys, values of `defaultProps` that does not exist in `props`\n * @param {object} defaultProps\n * @param {object} props\n * @returns {object} resolved props\n */\nexport default function resolveProps(defaultProps, props) {\n const output = _extends({}, props);\n Object.keys(defaultProps).forEach(propName => {\n if (propName.toString().match(/^(components|slots)$/)) {\n output[propName] = _extends({}, defaultProps[propName], output[propName]);\n } else if (propName.toString().match(/^(componentsProps|slotProps)$/)) {\n const defaultSlotProps = defaultProps[propName] || {};\n const slotProps = props[propName];\n output[propName] = {};\n if (!slotProps || !Object.keys(slotProps)) {\n // Reduce the iteration if the slot props is empty\n output[propName] = defaultSlotProps;\n } else if (!defaultSlotProps || !Object.keys(defaultSlotProps)) {\n // Reduce the iteration if the default slot props is empty\n output[propName] = slotProps;\n } else {\n output[propName] = _extends({}, slotProps);\n Object.keys(defaultSlotProps).forEach(slotPropName => {\n output[propName][slotPropName] = resolveProps(defaultSlotProps[slotPropName], slotProps[slotPropName]);\n });\n }\n } else if (output[propName] === undefined) {\n output[propName] = defaultProps[propName];\n }\n });\n return output;\n}","/**\n * TODO v5: consider making it private\n *\n * passes {value} to {ref}\n *\n * WARNING: Be sure to only call this inside a callback that is passed as a ref.\n * Otherwise, make sure to cleanup the previous {ref} if it changes. See\n * https://github.com/mui/material-ui/issues/13539\n *\n * Useful if you want to expose the ref of an inner component to the public API\n * while still using it inside the component.\n * @param ref A ref callback or ref object. If anything falsy, this is a no-op.\n */\nexport default function setRef(ref, value) {\n if (typeof ref === 'function') {\n ref(value);\n } else if (ref) {\n ref.current = value;\n }\n}","'use client';\n\n/* eslint-disable react-hooks/rules-of-hooks, react-hooks/exhaustive-deps */\nimport * as React from 'react';\nexport default function useControlled({\n controlled,\n default: defaultProp,\n name,\n state = 'value'\n}) {\n // isControlled is ignored in the hook dependency lists as it should never change.\n const {\n current: isControlled\n } = React.useRef(controlled !== undefined);\n const [valueState, setValue] = React.useState(defaultProp);\n const value = isControlled ? controlled : valueState;\n if (process.env.NODE_ENV !== 'production') {\n React.useEffect(() => {\n if (isControlled !== (controlled !== undefined)) {\n console.error([`MUI: A component is changing the ${isControlled ? '' : 'un'}controlled ${state} state of ${name} to be ${isControlled ? 'un' : ''}controlled.`, 'Elements should not switch from uncontrolled to controlled (or vice versa).', `Decide between using a controlled or uncontrolled ${name} ` + 'element for the lifetime of the component.', \"The nature of the state is determined during the first render. It's considered controlled if the value is not `undefined`.\", 'More info: https://fb.me/react-controlled-components'].join('\\n'));\n }\n }, [state, name, controlled]);\n const {\n current: defaultValue\n } = React.useRef(defaultProp);\n React.useEffect(() => {\n if (!isControlled && !Object.is(defaultValue, defaultProp)) {\n console.error([`MUI: A component is changing the default ${state} state of an uncontrolled ${name} after being initialized. ` + `To suppress this warning opt to use a controlled ${name}.`].join('\\n'));\n }\n }, [JSON.stringify(defaultProp)]);\n }\n const setValueIfUncontrolled = React.useCallback(newValue => {\n if (!isControlled) {\n setValue(newValue);\n }\n }, []);\n return [value, setValueIfUncontrolled];\n}","'use client';\n\nimport * as React from 'react';\n\n/**\n * A version of `React.useLayoutEffect` that does not show a warning when server-side rendering.\n * This is useful for effects that are only needed for client-side rendering but not for SSR.\n *\n * Before you use this hook, make sure to read https://gist.github.com/gaearon/e7d97cdf38a2907924ea12e4ebdf3c85\n * and confirm it doesn't apply to your use-case.\n */\nconst useEnhancedEffect = typeof window !== 'undefined' ? React.useLayoutEffect : React.useEffect;\nexport default useEnhancedEffect;","'use client';\n\nimport * as React from 'react';\nimport useEnhancedEffect from '../useEnhancedEffect';\n\n/**\n * Inspired by https://github.com/facebook/react/issues/14099#issuecomment-440013892\n * See RFC in https://github.com/reactjs/rfcs/pull/220\n */\n\nfunction useEventCallback(fn) {\n const ref = React.useRef(fn);\n useEnhancedEffect(() => {\n ref.current = fn;\n });\n return React.useRef((...args) =>\n // @ts-expect-error hide `this`\n (0, ref.current)(...args)).current;\n}\nexport default useEventCallback;","'use client';\n\nimport * as React from 'react';\nimport setRef from '../setRef';\nexport default function useForkRef(...refs) {\n /**\n * This will create a new function if the refs passed to this hook change and are all defined.\n * This means react will call the old forkRef with `null` and the new forkRef\n * with the ref. Cleanup naturally emerges from this behavior.\n */\n return React.useMemo(() => {\n if (refs.every(ref => ref == null)) {\n return null;\n }\n return instance => {\n refs.forEach(ref => {\n setRef(ref, instance);\n });\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, refs);\n}","'use client';\n\nimport * as React from 'react';\nlet globalId = 0;\nfunction useGlobalId(idOverride) {\n const [defaultId, setDefaultId] = React.useState(idOverride);\n const id = idOverride || defaultId;\n React.useEffect(() => {\n if (defaultId == null) {\n // Fallback to this default id when possible.\n // Use the incrementing value for client-side rendering only.\n // We can't use it server-side.\n // If you want to use random values please consider the Birthday Problem: https://en.wikipedia.org/wiki/Birthday_problem\n globalId += 1;\n setDefaultId(`mui-${globalId}`);\n }\n }, [defaultId]);\n return id;\n}\n\n// downstream bundlers may remove unnecessary concatenation, but won't remove toString call -- Workaround for https://github.com/webpack/webpack/issues/14814\nconst maybeReactUseId = React['useId'.toString()];\n/**\n *\n * @example
\n * @param idOverride\n * @returns {string}\n */\nexport default function useId(idOverride) {\n if (maybeReactUseId !== undefined) {\n const reactId = maybeReactUseId();\n return idOverride != null ? idOverride : reactId;\n }\n // eslint-disable-next-line react-hooks/rules-of-hooks -- `React.useId` is invariant at runtime.\n return useGlobalId(idOverride);\n}","'use client';\n\n// based on https://github.com/WICG/focus-visible/blob/v4.1.5/src/focus-visible.js\nimport * as React from 'react';\nimport { Timeout } from '../useTimeout/useTimeout';\nlet hadKeyboardEvent = true;\nlet hadFocusVisibleRecently = false;\nconst hadFocusVisibleRecentlyTimeout = new Timeout();\nconst inputTypesWhitelist = {\n text: true,\n search: true,\n url: true,\n tel: true,\n email: true,\n password: true,\n number: true,\n date: true,\n month: true,\n week: true,\n time: true,\n datetime: true,\n 'datetime-local': true\n};\n\n/**\n * Computes whether the given element should automatically trigger the\n * `focus-visible` class being added, i.e. whether it should always match\n * `:focus-visible` when focused.\n * @param {Element} node\n * @returns {boolean}\n */\nfunction focusTriggersKeyboardModality(node) {\n const {\n type,\n tagName\n } = node;\n if (tagName === 'INPUT' && inputTypesWhitelist[type] && !node.readOnly) {\n return true;\n }\n if (tagName === 'TEXTAREA' && !node.readOnly) {\n return true;\n }\n if (node.isContentEditable) {\n return true;\n }\n return false;\n}\n\n/**\n * Keep track of our keyboard modality state with `hadKeyboardEvent`.\n * If the most recent user interaction was via the keyboard;\n * and the key press did not include a meta, alt/option, or control key;\n * then the modality is keyboard. Otherwise, the modality is not keyboard.\n * @param {KeyboardEvent} event\n */\nfunction handleKeyDown(event) {\n if (event.metaKey || event.altKey || event.ctrlKey) {\n return;\n }\n hadKeyboardEvent = true;\n}\n\n/**\n * If at any point a user clicks with a pointing device, ensure that we change\n * the modality away from keyboard.\n * This avoids the situation where a user presses a key on an already focused\n * element, and then clicks on a different element, focusing it with a\n * pointing device, while we still think we're in keyboard modality.\n */\nfunction handlePointerDown() {\n hadKeyboardEvent = false;\n}\nfunction handleVisibilityChange() {\n if (this.visibilityState === 'hidden') {\n // If the tab becomes active again, the browser will handle calling focus\n // on the element (Safari actually calls it twice).\n // If this tab change caused a blur on an element with focus-visible,\n // re-apply the class when the user switches back to the tab.\n if (hadFocusVisibleRecently) {\n hadKeyboardEvent = true;\n }\n }\n}\nfunction prepare(doc) {\n doc.addEventListener('keydown', handleKeyDown, true);\n doc.addEventListener('mousedown', handlePointerDown, true);\n doc.addEventListener('pointerdown', handlePointerDown, true);\n doc.addEventListener('touchstart', handlePointerDown, true);\n doc.addEventListener('visibilitychange', handleVisibilityChange, true);\n}\nexport function teardown(doc) {\n doc.removeEventListener('keydown', handleKeyDown, true);\n doc.removeEventListener('mousedown', handlePointerDown, true);\n doc.removeEventListener('pointerdown', handlePointerDown, true);\n doc.removeEventListener('touchstart', handlePointerDown, true);\n doc.removeEventListener('visibilitychange', handleVisibilityChange, true);\n}\nfunction isFocusVisible(event) {\n const {\n target\n } = event;\n try {\n return target.matches(':focus-visible');\n } catch (error) {\n // Browsers not implementing :focus-visible will throw a SyntaxError.\n // We use our own heuristic for those browsers.\n // Rethrow might be better if it's not the expected error but do we really\n // want to crash if focus-visible malfunctioned?\n }\n\n // No need for validFocusTarget check. The user does that by attaching it to\n // focusable events only.\n return hadKeyboardEvent || focusTriggersKeyboardModality(target);\n}\nexport default function useIsFocusVisible() {\n const ref = React.useCallback(node => {\n if (node != null) {\n prepare(node.ownerDocument);\n }\n }, []);\n const isFocusVisibleRef = React.useRef(false);\n\n /**\n * Should be called if a blur event is fired\n */\n function handleBlurVisible() {\n // checking against potential state variable does not suffice if we focus and blur synchronously.\n // React wouldn't have time to trigger a re-render so `focusVisible` would be stale.\n // Ideally we would adjust `isFocusVisible(event)` to look at `relatedTarget` for blur events.\n // This doesn't work in IE11 due to https://github.com/facebook/react/issues/3751\n // TODO: check again if React releases their internal changes to focus event handling (https://github.com/facebook/react/pull/19186).\n if (isFocusVisibleRef.current) {\n // To detect a tab/window switch, we look for a blur event followed\n // rapidly by a visibility change.\n // If we don't see a visibility change within 100ms, it's probably a\n // regular focus change.\n hadFocusVisibleRecently = true;\n hadFocusVisibleRecentlyTimeout.start(100, () => {\n hadFocusVisibleRecently = false;\n });\n isFocusVisibleRef.current = false;\n return true;\n }\n return false;\n }\n\n /**\n * Should be called if a blur event is fired\n */\n function handleFocusVisible(event) {\n if (isFocusVisible(event)) {\n isFocusVisibleRef.current = true;\n return true;\n }\n return false;\n }\n return {\n isFocusVisibleRef,\n onFocus: handleFocusVisible,\n onBlur: handleBlurVisible,\n ref\n };\n}","'use client';\n\nimport * as React from 'react';\nconst UNINITIALIZED = {};\n\n/**\n * A React.useRef() that is initialized lazily with a function. Note that it accepts an optional\n * initialization argument, so the initialization function doesn't need to be an inline closure.\n *\n * @usage\n * const ref = useLazyRef(sortColumns, columns)\n */\nexport default function useLazyRef(init, initArg) {\n const ref = React.useRef(UNINITIALIZED);\n if (ref.current === UNINITIALIZED) {\n ref.current = init(initArg);\n }\n return ref;\n}","'use client';\n\nimport * as React from 'react';\nconst EMPTY = [];\n\n/**\n * A React.useEffect equivalent that runs once, when the component is mounted.\n */\nexport default function useOnMount(fn) {\n /* eslint-disable react-hooks/exhaustive-deps */\n React.useEffect(fn, EMPTY);\n /* eslint-enable react-hooks/exhaustive-deps */\n}","'use client';\n\nimport useLazyRef from '../useLazyRef/useLazyRef';\nimport useOnMount from '../useOnMount/useOnMount';\nexport class Timeout {\n constructor() {\n this.currentId = null;\n this.clear = () => {\n if (this.currentId !== null) {\n clearTimeout(this.currentId);\n this.currentId = null;\n }\n };\n this.disposeEffect = () => {\n return this.clear;\n };\n }\n static create() {\n return new Timeout();\n }\n /**\n * Executes `fn` after `delay`, clearing any previously scheduled call.\n */\n start(delay, fn) {\n this.clear();\n this.currentId = setTimeout(() => {\n this.currentId = null;\n fn();\n }, delay);\n }\n}\nexport default function useTimeout() {\n const timeout = useLazyRef(Timeout.create).current;\n useOnMount(timeout.disposeEffect);\n return timeout;\n}","import { min, ascending, max, mean, sum } from 'd3-array';\nimport { map, nest } from 'd3-collection';\nimport { linkHorizontal } from 'd3-shape';\nimport findCircuits from 'elementary-circuits-directed-graph';\n\n// For a given link, return the target node's depth\nfunction targetDepth(d) {\n return d.target.depth;\n}\n\n// The depth of a node when the nodeAlign (align) is set to 'left'\nfunction left(node) {\n return node.depth;\n}\n\n// The depth of a node when the nodeAlign (align) is set to 'right'\nfunction right(node, n) {\n return n - 1 - node.height;\n}\n\n// The depth of a node when the nodeAlign (align) is set to 'justify'\nfunction justify(node, n) {\n return node.sourceLinks.length ? node.depth : n - 1;\n}\n\n// The depth of a node when the nodeAlign (align) is set to 'center'\nfunction center(node) {\n return node.targetLinks.length ? node.depth : node.sourceLinks.length ? min(node.sourceLinks, targetDepth) - 1 : 0;\n}\n\n// returns a function, using the parameter given to the sankey setting\nfunction constant(x) {\n return function () {\n return x;\n };\n}\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) {\n return typeof obj;\n} : function (obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n};\n\n/// https://github.com/tomshanley/d3-sankeyCircular-circular\n\n// sort links' breadth (ie top to bottom in a column), based on their source nodes' breadths\nfunction ascendingSourceBreadth(a, b) {\n return ascendingBreadth(a.source, b.source) || a.index - b.index;\n}\n\n// sort links' breadth (ie top to bottom in a column), based on their target nodes' breadths\nfunction ascendingTargetBreadth(a, b) {\n return ascendingBreadth(a.target, b.target) || a.index - b.index;\n}\n\n// sort nodes' breadth (ie top to bottom in a column)\n// if both nodes have circular links, or both don't have circular links, then sort by the top (y0) of the node\n// else push nodes that have top circular links to the top, and nodes that have bottom circular links to the bottom\nfunction ascendingBreadth(a, b) {\n if (a.partOfCycle === b.partOfCycle) {\n return a.y0 - b.y0;\n } else {\n if (a.circularLinkType === 'top' || b.circularLinkType === 'bottom') {\n return -1;\n } else {\n return 1;\n }\n }\n}\n\n// return the value of a node or link\nfunction value(d) {\n return d.value;\n}\n\n// return the vertical center of a node\nfunction nodeCenter(node) {\n return (node.y0 + node.y1) / 2;\n}\n\n// return the vertical center of a link's source node\nfunction linkSourceCenter(link) {\n return nodeCenter(link.source);\n}\n\n// return the vertical center of a link's target node\nfunction linkTargetCenter(link) {\n return nodeCenter(link.target);\n}\n\n// Return the default value for ID for node, d.index\nfunction defaultId(d) {\n return d.index;\n}\n\n// Return the default object the graph's nodes, graph.nodes\nfunction defaultNodes(graph) {\n return graph.nodes;\n}\n\n// Return the default object the graph's nodes, graph.links\nfunction defaultLinks(graph) {\n return graph.links;\n}\n\n// Return the node from the collection that matches the provided ID, or throw an error if no match\nfunction find(nodeById, id) {\n var node = nodeById.get(id);\n if (!node) throw new Error('missing: ' + id);\n return node;\n}\n\nfunction getNodeID(node, id) {\n return id(node);\n}\n\n// The main sankeyCircular functions\n\n// Some constants for circular link calculations\nvar verticalMargin = 25;\nvar baseRadius = 10;\nvar scale = 0.3; //Possibly let user control this, although anything over 0.5 starts to get too cramped\n\nfunction sankeyCircular () {\n // Set the default values\n var x0 = 0,\n y0 = 0,\n x1 = 1,\n y1 = 1,\n // extent\n dx = 24,\n // nodeWidth\n py,\n // nodePadding, for vertical postioning\n id = defaultId,\n align = justify,\n nodes = defaultNodes,\n links = defaultLinks,\n iterations = 32,\n circularLinkGap = 2,\n paddingRatio,\n sortNodes = null;\n\n function sankeyCircular() {\n var graph = {\n nodes: nodes.apply(null, arguments),\n links: links.apply(null, arguments)\n\n // Process the graph's nodes and links, setting their positions\n\n // 1. Associate the nodes with their respective links, and vice versa\n };computeNodeLinks(graph);\n\n // 2. Determine which links result in a circular path in the graph\n identifyCircles(graph, id, sortNodes);\n\n // 4. Calculate the nodes' values, based on the values of the incoming and outgoing links\n computeNodeValues(graph);\n\n // 5. Calculate the nodes' depth based on the incoming and outgoing links\n // Sets the nodes':\n // - depth: the depth in the graph\n // - column: the depth (0, 1, 2, etc), as is relates to visual position from left to right\n // - x0, x1: the x coordinates, as is relates to visual position from left to right\n computeNodeDepths(graph);\n\n // 3. Determine how the circular links will be drawn,\n // either travelling back above the main chart (\"top\")\n // or below the main chart (\"bottom\")\n selectCircularLinkTypes(graph, id);\n\n // 6. Calculate the nodes' and links' vertical position within their respective column\n // Also readjusts sankeyCircular size if circular links are needed, and node x's\n computeNodeBreadths(graph, iterations, id);\n computeLinkBreadths(graph);\n\n // 7. Sort links per node, based on the links' source/target nodes' breadths\n // 8. Adjust nodes that overlap links that span 2+ columns\n var linkSortingIterations = 4; //Possibly let user control this number, like the iterations over node placement\n for (var iteration = 0; iteration < linkSortingIterations; iteration++) {\n\n sortSourceLinks(graph, y1, id);\n sortTargetLinks(graph, y1, id);\n resolveNodeLinkOverlaps(graph, y0, y1, id);\n sortSourceLinks(graph, y1, id);\n sortTargetLinks(graph, y1, id);\n }\n\n // 8.1 Adjust node and link positions back to fill height of chart area if compressed\n fillHeight(graph, y0, y1);\n\n // 9. Calculate visually appealling path for the circular paths, and create the \"d\" string\n addCircularPathData(graph, circularLinkGap, y1, id);\n\n return graph;\n } // end of sankeyCircular function\n\n\n // Set the sankeyCircular parameters\n // nodeID, nodeAlign, nodeWidth, nodePadding, nodes, links, size, extent, iterations, nodePaddingRatio, circularLinkGap\n sankeyCircular.nodeId = function (_) {\n return arguments.length ? (id = typeof _ === 'function' ? _ : constant(_), sankeyCircular) : id;\n };\n\n sankeyCircular.nodeAlign = function (_) {\n return arguments.length ? (align = typeof _ === 'function' ? _ : constant(_), sankeyCircular) : align;\n };\n\n sankeyCircular.nodeWidth = function (_) {\n return arguments.length ? (dx = +_, sankeyCircular) : dx;\n };\n\n sankeyCircular.nodePadding = function (_) {\n return arguments.length ? (py = +_, sankeyCircular) : py;\n };\n\n sankeyCircular.nodes = function (_) {\n return arguments.length ? (nodes = typeof _ === 'function' ? _ : constant(_), sankeyCircular) : nodes;\n };\n\n sankeyCircular.links = function (_) {\n return arguments.length ? (links = typeof _ === 'function' ? _ : constant(_), sankeyCircular) : links;\n };\n\n sankeyCircular.size = function (_) {\n return arguments.length ? (x0 = y0 = 0, x1 = +_[0], y1 = +_[1], sankeyCircular) : [x1 - x0, y1 - y0];\n };\n\n sankeyCircular.extent = function (_) {\n return arguments.length ? (x0 = +_[0][0], x1 = +_[1][0], y0 = +_[0][1], y1 = +_[1][1], sankeyCircular) : [[x0, y0], [x1, y1]];\n };\n\n sankeyCircular.iterations = function (_) {\n return arguments.length ? (iterations = +_, sankeyCircular) : iterations;\n };\n\n sankeyCircular.circularLinkGap = function (_) {\n return arguments.length ? (circularLinkGap = +_, sankeyCircular) : circularLinkGap;\n };\n\n sankeyCircular.nodePaddingRatio = function (_) {\n return arguments.length ? (paddingRatio = +_, sankeyCircular) : paddingRatio;\n };\n\n sankeyCircular.sortNodes = function (_) {\n return arguments.length ? (sortNodes = _, sankeyCircular) : sortNodes;\n };\n\n sankeyCircular.update = function (graph) {\n // 5. Calculate the nodes' depth based on the incoming and outgoing links\n // Sets the nodes':\n // - depth: the depth in the graph\n // - column: the depth (0, 1, 2, etc), as is relates to visual position from left to right\n // - x0, x1: the x coordinates, as is relates to visual position from left to right\n // computeNodeDepths(graph)\n\n // 3. Determine how the circular links will be drawn,\n // either travelling back above the main chart (\"top\")\n // or below the main chart (\"bottom\")\n selectCircularLinkTypes(graph, id);\n\n // 6. Calculate the nodes' and links' vertical position within their respective column\n // Also readjusts sankeyCircular size if circular links are needed, and node x's\n // computeNodeBreadths(graph, iterations, id)\n computeLinkBreadths(graph);\n\n // Force position of circular link type based on position\n graph.links.forEach(function (link) {\n if (link.circular) {\n link.circularLinkType = link.y0 + link.y1 < y1 ? 'top' : 'bottom';\n\n link.source.circularLinkType = link.circularLinkType;\n link.target.circularLinkType = link.circularLinkType;\n }\n });\n\n sortSourceLinks(graph, y1, id, false); // Sort links but do not move nodes\n sortTargetLinks(graph, y1, id);\n\n // 7. Sort links per node, based on the links' source/target nodes' breadths\n // 8. Adjust nodes that overlap links that span 2+ columns\n // var linkSortingIterations = 4; //Possibly let user control this number, like the iterations over node placement\n // for (var iteration = 0; iteration < linkSortingIterations; iteration++) {\n //\n // sortSourceLinks(graph, y1, id)\n // sortTargetLinks(graph, y1, id)\n // resolveNodeLinkOverlaps(graph, y0, y1, id)\n // sortSourceLinks(graph, y1, id)\n // sortTargetLinks(graph, y1, id)\n //\n // }\n\n // 8.1 Adjust node and link positions back to fill height of chart area if compressed\n // fillHeight(graph, y0, y1)\n\n // 9. Calculate visually appealling path for the circular paths, and create the \"d\" string\n addCircularPathData(graph, circularLinkGap, y1, id);\n return graph;\n };\n\n // Populate the sourceLinks and targetLinks for each node.\n // Also, if the source and target are not objects, assume they are indices.\n function computeNodeLinks(graph) {\n graph.nodes.forEach(function (node, i) {\n node.index = i;\n node.sourceLinks = [];\n node.targetLinks = [];\n });\n var nodeById = map(graph.nodes, id);\n graph.links.forEach(function (link, i) {\n link.index = i;\n var source = link.source;\n var target = link.target;\n if ((typeof source === \"undefined\" ? \"undefined\" : _typeof(source)) !== 'object') {\n source = link.source = find(nodeById, source);\n }\n if ((typeof target === \"undefined\" ? \"undefined\" : _typeof(target)) !== 'object') {\n target = link.target = find(nodeById, target);\n }\n source.sourceLinks.push(link);\n target.targetLinks.push(link);\n });\n return graph;\n }\n\n // Compute the value (size) and cycleness of each node by summing the associated links.\n function computeNodeValues(graph) {\n graph.nodes.forEach(function (node) {\n node.partOfCycle = false;\n node.value = Math.max(sum(node.sourceLinks, value), sum(node.targetLinks, value));\n node.sourceLinks.forEach(function (link) {\n if (link.circular) {\n node.partOfCycle = true;\n node.circularLinkType = link.circularLinkType;\n }\n });\n node.targetLinks.forEach(function (link) {\n if (link.circular) {\n node.partOfCycle = true;\n node.circularLinkType = link.circularLinkType;\n }\n });\n });\n }\n\n function getCircleMargins(graph) {\n var totalTopLinksWidth = 0,\n totalBottomLinksWidth = 0,\n totalRightLinksWidth = 0,\n totalLeftLinksWidth = 0;\n\n var maxColumn = max(graph.nodes, function (node) {\n return node.column;\n });\n\n graph.links.forEach(function (link) {\n if (link.circular) {\n if (link.circularLinkType == 'top') {\n totalTopLinksWidth = totalTopLinksWidth + link.width;\n } else {\n totalBottomLinksWidth = totalBottomLinksWidth + link.width;\n }\n\n if (link.target.column == 0) {\n totalLeftLinksWidth = totalLeftLinksWidth + link.width;\n }\n\n if (link.source.column == maxColumn) {\n totalRightLinksWidth = totalRightLinksWidth + link.width;\n }\n }\n });\n\n //account for radius of curves and padding between links\n totalTopLinksWidth = totalTopLinksWidth > 0 ? totalTopLinksWidth + verticalMargin + baseRadius : totalTopLinksWidth;\n totalBottomLinksWidth = totalBottomLinksWidth > 0 ? totalBottomLinksWidth + verticalMargin + baseRadius : totalBottomLinksWidth;\n totalRightLinksWidth = totalRightLinksWidth > 0 ? totalRightLinksWidth + verticalMargin + baseRadius : totalRightLinksWidth;\n totalLeftLinksWidth = totalLeftLinksWidth > 0 ? totalLeftLinksWidth + verticalMargin + baseRadius : totalLeftLinksWidth;\n\n return { \"top\": totalTopLinksWidth, \"bottom\": totalBottomLinksWidth, \"left\": totalLeftLinksWidth, \"right\": totalRightLinksWidth };\n }\n\n // Update the x0, y0, x1 and y1 for the sankeyCircular, to allow space for any circular links\n function scaleSankeySize(graph, margin) {\n\n var maxColumn = max(graph.nodes, function (node) {\n return node.column;\n });\n\n var currentWidth = x1 - x0;\n var currentHeight = y1 - y0;\n\n var newWidth = currentWidth + margin.right + margin.left;\n var newHeight = currentHeight + margin.top + margin.bottom;\n\n var scaleX = currentWidth / newWidth;\n var scaleY = currentHeight / newHeight;\n\n x0 = x0 * scaleX + margin.left;\n x1 = margin.right == 0 ? x1 : x1 * scaleX;\n y0 = y0 * scaleY + margin.top;\n y1 = y1 * scaleY;\n\n graph.nodes.forEach(function (node) {\n node.x0 = x0 + node.column * ((x1 - x0 - dx) / maxColumn);\n node.x1 = node.x0 + dx;\n });\n\n return scaleY;\n }\n\n // Iteratively assign the depth for each node.\n // Nodes are assigned the maximum depth of incoming neighbors plus one;\n // nodes with no incoming links are assigned depth zero, while\n // nodes with no outgoing links are assigned the maximum depth.\n function computeNodeDepths(graph) {\n var nodes, next, x;\n\n for (nodes = graph.nodes, next = [], x = 0; nodes.length; ++x, nodes = next, next = []) {\n nodes.forEach(function (node) {\n node.depth = x;\n node.sourceLinks.forEach(function (link) {\n if (next.indexOf(link.target) < 0 && !link.circular) {\n next.push(link.target);\n }\n });\n });\n }\n\n for (nodes = graph.nodes, next = [], x = 0; nodes.length; ++x, nodes = next, next = []) {\n nodes.forEach(function (node) {\n node.height = x;\n node.targetLinks.forEach(function (link) {\n if (next.indexOf(link.source) < 0 && !link.circular) {\n next.push(link.source);\n }\n });\n });\n }\n\n // assign column numbers, and get max value\n graph.nodes.forEach(function (node) {\n node.column = Math.floor(align.call(null, node, x));\n });\n }\n\n // Assign nodes' breadths, and then shift nodes that overlap (resolveCollisions)\n function computeNodeBreadths(graph, iterations, id) {\n var columns = nest().key(function (d) {\n return d.column;\n }).sortKeys(ascending).entries(graph.nodes).map(function (d) {\n return d.values;\n });\n\n initializeNodeBreadth(id);\n resolveCollisions();\n\n for (var alpha = 1, n = iterations; n > 0; --n) {\n relaxLeftAndRight(alpha *= 0.99, id);\n resolveCollisions();\n }\n\n function initializeNodeBreadth(id) {\n\n //override py if nodePadding has been set\n if (paddingRatio) {\n var padding = Infinity;\n columns.forEach(function (nodes) {\n var thisPadding = y1 * paddingRatio / (nodes.length + 1);\n padding = thisPadding < padding ? thisPadding : padding;\n });\n py = padding;\n }\n\n var ky = min(columns, function (nodes) {\n return (y1 - y0 - (nodes.length - 1) * py) / sum(nodes, value);\n });\n\n //calculate the widths of the links\n ky = ky * scale;\n\n graph.links.forEach(function (link) {\n link.width = link.value * ky;\n });\n\n //determine how much to scale down the chart, based on circular links\n var margin = getCircleMargins(graph);\n var ratio = scaleSankeySize(graph, margin);\n\n //re-calculate widths\n ky = ky * ratio;\n\n graph.links.forEach(function (link) {\n link.width = link.value * ky;\n });\n\n columns.forEach(function (nodes) {\n var nodesLength = nodes.length;\n nodes.forEach(function (node, i) {\n if (node.depth == columns.length - 1 && nodesLength == 1) {\n node.y0 = y1 / 2 - node.value * ky;\n node.y1 = node.y0 + node.value * ky;\n } else if (node.depth == 0 && nodesLength == 1) {\n node.y0 = y1 / 2 - node.value * ky;\n node.y1 = node.y0 + node.value * ky;\n } else if (node.partOfCycle) {\n if (numberOfNonSelfLinkingCycles(node, id) == 0) {\n node.y0 = y1 / 2 + i;\n node.y1 = node.y0 + node.value * ky;\n } else if (node.circularLinkType == 'top') {\n node.y0 = y0 + i;\n node.y1 = node.y0 + node.value * ky;\n } else {\n node.y0 = y1 - node.value * ky - i;\n node.y1 = node.y0 + node.value * ky;\n }\n } else {\n if (margin.top == 0 || margin.bottom == 0) {\n node.y0 = (y1 - y0) / nodesLength * i;\n node.y1 = node.y0 + node.value * ky;\n } else {\n node.y0 = (y1 - y0) / 2 - nodesLength / 2 + i;\n node.y1 = node.y0 + node.value * ky;\n }\n }\n });\n });\n }\n\n // For each node in each column, check the node's vertical position in relation to its targets and sources vertical position\n // and shift up/down to be closer to the vertical middle of those targets and sources\n function relaxLeftAndRight(alpha, id) {\n var columnsLength = columns.length;\n\n columns.forEach(function (nodes) {\n var n = nodes.length;\n var depth = nodes[0].depth;\n\n nodes.forEach(function (node) {\n // check the node is not an orphan\n var nodeHeight;\n if (node.sourceLinks.length || node.targetLinks.length) {\n if (node.partOfCycle && numberOfNonSelfLinkingCycles(node, id) > 0) ; else if (depth == 0 && n == 1) {\n nodeHeight = node.y1 - node.y0;\n\n node.y0 = y1 / 2 - nodeHeight / 2;\n node.y1 = y1 / 2 + nodeHeight / 2;\n } else if (depth == columnsLength - 1 && n == 1) {\n nodeHeight = node.y1 - node.y0;\n\n node.y0 = y1 / 2 - nodeHeight / 2;\n node.y1 = y1 / 2 + nodeHeight / 2;\n } else {\n var avg = 0;\n\n var avgTargetY = mean(node.sourceLinks, linkTargetCenter);\n var avgSourceY = mean(node.targetLinks, linkSourceCenter);\n\n if (avgTargetY && avgSourceY) {\n avg = (avgTargetY + avgSourceY) / 2;\n } else {\n avg = avgTargetY || avgSourceY;\n }\n\n var dy = (avg - nodeCenter(node)) * alpha;\n // positive if it node needs to move down\n node.y0 += dy;\n node.y1 += dy;\n }\n }\n });\n });\n }\n\n // For each column, check if nodes are overlapping, and if so, shift up/down\n function resolveCollisions() {\n columns.forEach(function (nodes) {\n var node,\n dy,\n y = y0,\n n = nodes.length,\n i;\n\n // Push any overlapping nodes down.\n nodes.sort(ascendingBreadth);\n\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n dy = y - node.y0;\n\n if (dy > 0) {\n node.y0 += dy;\n node.y1 += dy;\n }\n y = node.y1 + py;\n }\n\n // If the bottommost node goes outside the bounds, push it back up.\n dy = y - py - y1;\n if (dy > 0) {\n y = node.y0 -= dy, node.y1 -= dy;\n\n // Push any overlapping nodes back up.\n for (i = n - 2; i >= 0; --i) {\n node = nodes[i];\n dy = node.y1 + py - y;\n if (dy > 0) node.y0 -= dy, node.y1 -= dy;\n y = node.y0;\n }\n }\n });\n }\n }\n\n // Assign the links y0 and y1 based on source/target nodes position,\n // plus the link's relative position to other links to the same node\n function computeLinkBreadths(graph) {\n graph.nodes.forEach(function (node) {\n node.sourceLinks.sort(ascendingTargetBreadth);\n node.targetLinks.sort(ascendingSourceBreadth);\n });\n graph.nodes.forEach(function (node) {\n var y0 = node.y0;\n var y1 = y0;\n\n // start from the bottom of the node for cycle links\n var y0cycle = node.y1;\n var y1cycle = y0cycle;\n\n node.sourceLinks.forEach(function (link) {\n if (link.circular) {\n link.y0 = y0cycle - link.width / 2;\n y0cycle = y0cycle - link.width;\n } else {\n link.y0 = y0 + link.width / 2;\n y0 += link.width;\n }\n });\n node.targetLinks.forEach(function (link) {\n if (link.circular) {\n link.y1 = y1cycle - link.width / 2;\n y1cycle = y1cycle - link.width;\n } else {\n link.y1 = y1 + link.width / 2;\n y1 += link.width;\n }\n });\n });\n }\n\n return sankeyCircular;\n}\n\n/// /////////////////////////////////////////////////////////////////////////////////\n// Cycle functions\n// portion of code to detect circular links based on Colin Fergus' bl.ock https://gist.github.com/cfergus/3956043\n\n// Identify circles in the link objects\nfunction identifyCircles(graph, id, sortNodes) {\n var circularLinkID = 0;\n if (sortNodes === null) {\n\n // Building adjacency graph\n var adjList = [];\n for (var i = 0; i < graph.links.length; i++) {\n var link = graph.links[i];\n var source = link.source.index;\n var target = link.target.index;\n if (!adjList[source]) adjList[source] = [];\n if (!adjList[target]) adjList[target] = [];\n\n // Add links if not already in set\n if (adjList[source].indexOf(target) === -1) adjList[source].push(target);\n }\n\n // Find all elementary circuits\n var cycles = findCircuits(adjList);\n\n // Sort by circuits length\n cycles.sort(function (a, b) {\n return a.length - b.length;\n });\n\n var circularLinks = {};\n for (i = 0; i < cycles.length; i++) {\n var cycle = cycles[i];\n var last = cycle.slice(-2);\n if (!circularLinks[last[0]]) circularLinks[last[0]] = {};\n circularLinks[last[0]][last[1]] = true;\n }\n\n graph.links.forEach(function (link) {\n var target = link.target.index;\n var source = link.source.index;\n // If self-linking or a back-edge\n if (target === source || circularLinks[source] && circularLinks[source][target]) {\n link.circular = true;\n link.circularLinkID = circularLinkID;\n circularLinkID = circularLinkID + 1;\n } else {\n link.circular = false;\n }\n });\n } else {\n graph.links.forEach(function (link) {\n if (link.source[sortNodes] < link.target[sortNodes]) {\n link.circular = false;\n } else {\n link.circular = true;\n link.circularLinkID = circularLinkID;\n circularLinkID = circularLinkID + 1;\n }\n });\n }\n}\n\n// Assign a circular link type (top or bottom), based on:\n// - if the source/target node already has circular links, then use the same type\n// - if not, choose the type with fewer links\nfunction selectCircularLinkTypes(graph, id) {\n var numberOfTops = 0;\n var numberOfBottoms = 0;\n graph.links.forEach(function (link) {\n if (link.circular) {\n // if either souce or target has type already use that\n if (link.source.circularLinkType || link.target.circularLinkType) {\n // default to source type if available\n link.circularLinkType = link.source.circularLinkType ? link.source.circularLinkType : link.target.circularLinkType;\n } else {\n link.circularLinkType = numberOfTops < numberOfBottoms ? 'top' : 'bottom';\n }\n\n if (link.circularLinkType == 'top') {\n numberOfTops = numberOfTops + 1;\n } else {\n numberOfBottoms = numberOfBottoms + 1;\n }\n\n graph.nodes.forEach(function (node) {\n if (getNodeID(node, id) == getNodeID(link.source, id) || getNodeID(node, id) == getNodeID(link.target, id)) {\n node.circularLinkType = link.circularLinkType;\n }\n });\n }\n });\n\n //correct self-linking links to be same direction as node\n graph.links.forEach(function (link) {\n if (link.circular) {\n //if both source and target node are same type, then link should have same type\n if (link.source.circularLinkType == link.target.circularLinkType) {\n link.circularLinkType = link.source.circularLinkType;\n }\n //if link is selflinking, then link should have same type as node\n if (selfLinking(link, id)) {\n link.circularLinkType = link.source.circularLinkType;\n }\n }\n });\n}\n\n// Return the angle between a straight line between the source and target of the link, and the vertical plane of the node\nfunction linkAngle(link) {\n var adjacent = Math.abs(link.y1 - link.y0);\n var opposite = Math.abs(link.target.x0 - link.source.x1);\n\n return Math.atan(opposite / adjacent);\n}\n\n// Check if two circular links potentially overlap\nfunction circularLinksCross(link1, link2) {\n if (link1.source.column < link2.target.column) {\n return false;\n } else if (link1.target.column > link2.source.column) {\n return false;\n } else {\n return true;\n }\n}\n\n// Return the number of circular links for node, not including self linking links\nfunction numberOfNonSelfLinkingCycles(node, id) {\n var sourceCount = 0;\n node.sourceLinks.forEach(function (l) {\n sourceCount = l.circular && !selfLinking(l, id) ? sourceCount + 1 : sourceCount;\n });\n\n var targetCount = 0;\n node.targetLinks.forEach(function (l) {\n targetCount = l.circular && !selfLinking(l, id) ? targetCount + 1 : targetCount;\n });\n\n return sourceCount + targetCount;\n}\n\n// Check if a circular link is the only circular link for both its source and target node\nfunction onlyCircularLink(link) {\n var nodeSourceLinks = link.source.sourceLinks;\n var sourceCount = 0;\n nodeSourceLinks.forEach(function (l) {\n sourceCount = l.circular ? sourceCount + 1 : sourceCount;\n });\n\n var nodeTargetLinks = link.target.targetLinks;\n var targetCount = 0;\n nodeTargetLinks.forEach(function (l) {\n targetCount = l.circular ? targetCount + 1 : targetCount;\n });\n\n if (sourceCount > 1 || targetCount > 1) {\n return false;\n } else {\n return true;\n }\n}\n\n// creates vertical buffer values per set of top/bottom links\nfunction calcVerticalBuffer(links, circularLinkGap, id) {\n links.sort(sortLinkColumnAscending);\n links.forEach(function (link, i) {\n var buffer = 0;\n\n if (selfLinking(link, id) && onlyCircularLink(link)) {\n link.circularPathData.verticalBuffer = buffer + link.width / 2;\n } else {\n var j = 0;\n for (j; j < i; j++) {\n if (circularLinksCross(links[i], links[j])) {\n var bufferOverThisLink = links[j].circularPathData.verticalBuffer + links[j].width / 2 + circularLinkGap;\n buffer = bufferOverThisLink > buffer ? bufferOverThisLink : buffer;\n }\n }\n\n link.circularPathData.verticalBuffer = buffer + link.width / 2;\n }\n });\n\n return links;\n}\n\n// calculate the optimum path for a link to reduce overlaps\nfunction addCircularPathData(graph, circularLinkGap, y1, id) {\n //var baseRadius = 10\n var buffer = 5;\n //var verticalMargin = 25\n\n var minY = min(graph.links, function (link) {\n return link.source.y0;\n });\n\n // create object for circular Path Data\n graph.links.forEach(function (link) {\n if (link.circular) {\n link.circularPathData = {};\n }\n });\n\n // calc vertical offsets per top/bottom links\n var topLinks = graph.links.filter(function (l) {\n return l.circularLinkType == 'top';\n });\n /* topLinks = */calcVerticalBuffer(topLinks, circularLinkGap, id);\n\n var bottomLinks = graph.links.filter(function (l) {\n return l.circularLinkType == 'bottom';\n });\n /* bottomLinks = */calcVerticalBuffer(bottomLinks, circularLinkGap, id);\n\n // add the base data for each link\n graph.links.forEach(function (link) {\n if (link.circular) {\n link.circularPathData.arcRadius = link.width + baseRadius;\n link.circularPathData.leftNodeBuffer = buffer;\n link.circularPathData.rightNodeBuffer = buffer;\n link.circularPathData.sourceWidth = link.source.x1 - link.source.x0;\n link.circularPathData.sourceX = link.source.x0 + link.circularPathData.sourceWidth;\n link.circularPathData.targetX = link.target.x0;\n link.circularPathData.sourceY = link.y0;\n link.circularPathData.targetY = link.y1;\n\n // for self linking paths, and that the only circular link in/out of that node\n if (selfLinking(link, id) && onlyCircularLink(link)) {\n link.circularPathData.leftSmallArcRadius = baseRadius + link.width / 2;\n link.circularPathData.leftLargeArcRadius = baseRadius + link.width / 2;\n link.circularPathData.rightSmallArcRadius = baseRadius + link.width / 2;\n link.circularPathData.rightLargeArcRadius = baseRadius + link.width / 2;\n\n if (link.circularLinkType == 'bottom') {\n link.circularPathData.verticalFullExtent = link.source.y1 + verticalMargin + link.circularPathData.verticalBuffer;\n link.circularPathData.verticalLeftInnerExtent = link.circularPathData.verticalFullExtent - link.circularPathData.leftLargeArcRadius;\n link.circularPathData.verticalRightInnerExtent = link.circularPathData.verticalFullExtent - link.circularPathData.rightLargeArcRadius;\n } else {\n // top links\n link.circularPathData.verticalFullExtent = link.source.y0 - verticalMargin - link.circularPathData.verticalBuffer;\n link.circularPathData.verticalLeftInnerExtent = link.circularPathData.verticalFullExtent + link.circularPathData.leftLargeArcRadius;\n link.circularPathData.verticalRightInnerExtent = link.circularPathData.verticalFullExtent + link.circularPathData.rightLargeArcRadius;\n }\n } else {\n // else calculate normally\n // add left extent coordinates, based on links with same source column and circularLink type\n var thisColumn = link.source.column;\n var thisCircularLinkType = link.circularLinkType;\n var sameColumnLinks = graph.links.filter(function (l) {\n return l.source.column == thisColumn && l.circularLinkType == thisCircularLinkType;\n });\n\n if (link.circularLinkType == 'bottom') {\n sameColumnLinks.sort(sortLinkSourceYDescending);\n } else {\n sameColumnLinks.sort(sortLinkSourceYAscending);\n }\n\n var radiusOffset = 0;\n sameColumnLinks.forEach(function (l, i) {\n if (l.circularLinkID == link.circularLinkID) {\n link.circularPathData.leftSmallArcRadius = baseRadius + link.width / 2 + radiusOffset;\n link.circularPathData.leftLargeArcRadius = baseRadius + link.width / 2 + i * circularLinkGap + radiusOffset;\n }\n radiusOffset = radiusOffset + l.width;\n });\n\n // add right extent coordinates, based on links with same target column and circularLink type\n thisColumn = link.target.column;\n sameColumnLinks = graph.links.filter(function (l) {\n return l.target.column == thisColumn && l.circularLinkType == thisCircularLinkType;\n });\n if (link.circularLinkType == 'bottom') {\n sameColumnLinks.sort(sortLinkTargetYDescending);\n } else {\n sameColumnLinks.sort(sortLinkTargetYAscending);\n }\n\n radiusOffset = 0;\n sameColumnLinks.forEach(function (l, i) {\n if (l.circularLinkID == link.circularLinkID) {\n link.circularPathData.rightSmallArcRadius = baseRadius + link.width / 2 + radiusOffset;\n link.circularPathData.rightLargeArcRadius = baseRadius + link.width / 2 + i * circularLinkGap + radiusOffset;\n }\n radiusOffset = radiusOffset + l.width;\n });\n\n // bottom links\n if (link.circularLinkType == 'bottom') {\n link.circularPathData.verticalFullExtent = Math.max(y1, link.source.y1, link.target.y1) + verticalMargin + link.circularPathData.verticalBuffer;\n link.circularPathData.verticalLeftInnerExtent = link.circularPathData.verticalFullExtent - link.circularPathData.leftLargeArcRadius;\n link.circularPathData.verticalRightInnerExtent = link.circularPathData.verticalFullExtent - link.circularPathData.rightLargeArcRadius;\n } else {\n // top links\n link.circularPathData.verticalFullExtent = minY - verticalMargin - link.circularPathData.verticalBuffer;\n link.circularPathData.verticalLeftInnerExtent = link.circularPathData.verticalFullExtent + link.circularPathData.leftLargeArcRadius;\n link.circularPathData.verticalRightInnerExtent = link.circularPathData.verticalFullExtent + link.circularPathData.rightLargeArcRadius;\n }\n }\n\n // all links\n link.circularPathData.leftInnerExtent = link.circularPathData.sourceX + link.circularPathData.leftNodeBuffer;\n link.circularPathData.rightInnerExtent = link.circularPathData.targetX - link.circularPathData.rightNodeBuffer;\n link.circularPathData.leftFullExtent = link.circularPathData.sourceX + link.circularPathData.leftLargeArcRadius + link.circularPathData.leftNodeBuffer;\n link.circularPathData.rightFullExtent = link.circularPathData.targetX - link.circularPathData.rightLargeArcRadius - link.circularPathData.rightNodeBuffer;\n }\n\n if (link.circular) {\n link.path = createCircularPathString(link);\n } else {\n var normalPath = linkHorizontal().source(function (d) {\n var x = d.source.x0 + (d.source.x1 - d.source.x0);\n var y = d.y0;\n return [x, y];\n }).target(function (d) {\n var x = d.target.x0;\n var y = d.y1;\n return [x, y];\n });\n link.path = normalPath(link);\n }\n });\n}\n\n// create a d path using the addCircularPathData\nfunction createCircularPathString(link) {\n var pathString = '';\n // 'pathData' is assigned a value but never used\n // var pathData = {}\n\n if (link.circularLinkType == 'top') {\n pathString =\n // start at the right of the source node\n 'M' + link.circularPathData.sourceX + ' ' + link.circularPathData.sourceY + ' ' +\n // line right to buffer point\n 'L' + link.circularPathData.leftInnerExtent + ' ' + link.circularPathData.sourceY + ' ' +\n // Arc around: Centre of arc X and //Centre of arc Y\n 'A' + link.circularPathData.leftLargeArcRadius + ' ' + link.circularPathData.leftSmallArcRadius + ' 0 0 0 ' +\n // End of arc X //End of arc Y\n link.circularPathData.leftFullExtent + ' ' + (link.circularPathData.sourceY - link.circularPathData.leftSmallArcRadius) + ' ' + // End of arc X\n // line up to buffer point\n 'L' + link.circularPathData.leftFullExtent + ' ' + link.circularPathData.verticalLeftInnerExtent + ' ' +\n // Arc around: Centre of arc X and //Centre of arc Y\n 'A' + link.circularPathData.leftLargeArcRadius + ' ' + link.circularPathData.leftLargeArcRadius + ' 0 0 0 ' +\n // End of arc X //End of arc Y\n link.circularPathData.leftInnerExtent + ' ' + link.circularPathData.verticalFullExtent + ' ' + // End of arc X\n // line left to buffer point\n 'L' + link.circularPathData.rightInnerExtent + ' ' + link.circularPathData.verticalFullExtent + ' ' +\n // Arc around: Centre of arc X and //Centre of arc Y\n 'A' + link.circularPathData.rightLargeArcRadius + ' ' + link.circularPathData.rightLargeArcRadius + ' 0 0 0 ' +\n // End of arc X //End of arc Y\n link.circularPathData.rightFullExtent + ' ' + link.circularPathData.verticalRightInnerExtent + ' ' + // End of arc X\n // line down\n 'L' + link.circularPathData.rightFullExtent + ' ' + (link.circularPathData.targetY - link.circularPathData.rightSmallArcRadius) + ' ' +\n // Arc around: Centre of arc X and //Centre of arc Y\n 'A' + link.circularPathData.rightLargeArcRadius + ' ' + link.circularPathData.rightSmallArcRadius + ' 0 0 0 ' +\n // End of arc X //End of arc Y\n link.circularPathData.rightInnerExtent + ' ' + link.circularPathData.targetY + ' ' + // End of arc X\n // line to end\n 'L' + link.circularPathData.targetX + ' ' + link.circularPathData.targetY;\n } else {\n // bottom path\n pathString =\n // start at the right of the source node\n 'M' + link.circularPathData.sourceX + ' ' + link.circularPathData.sourceY + ' ' +\n // line right to buffer point\n 'L' + link.circularPathData.leftInnerExtent + ' ' + link.circularPathData.sourceY + ' ' +\n // Arc around: Centre of arc X and //Centre of arc Y\n 'A' + link.circularPathData.leftLargeArcRadius + ' ' + link.circularPathData.leftSmallArcRadius + ' 0 0 1 ' +\n // End of arc X //End of arc Y\n link.circularPathData.leftFullExtent + ' ' + (link.circularPathData.sourceY + link.circularPathData.leftSmallArcRadius) + ' ' + // End of arc X\n // line down to buffer point\n 'L' + link.circularPathData.leftFullExtent + ' ' + link.circularPathData.verticalLeftInnerExtent + ' ' +\n // Arc around: Centre of arc X and //Centre of arc Y\n 'A' + link.circularPathData.leftLargeArcRadius + ' ' + link.circularPathData.leftLargeArcRadius + ' 0 0 1 ' +\n // End of arc X //End of arc Y\n link.circularPathData.leftInnerExtent + ' ' + link.circularPathData.verticalFullExtent + ' ' + // End of arc X\n // line left to buffer point\n 'L' + link.circularPathData.rightInnerExtent + ' ' + link.circularPathData.verticalFullExtent + ' ' +\n // Arc around: Centre of arc X and //Centre of arc Y\n 'A' + link.circularPathData.rightLargeArcRadius + ' ' + link.circularPathData.rightLargeArcRadius + ' 0 0 1 ' +\n // End of arc X //End of arc Y\n link.circularPathData.rightFullExtent + ' ' + link.circularPathData.verticalRightInnerExtent + ' ' + // End of arc X\n // line up\n 'L' + link.circularPathData.rightFullExtent + ' ' + (link.circularPathData.targetY + link.circularPathData.rightSmallArcRadius) + ' ' +\n // Arc around: Centre of arc X and //Centre of arc Y\n 'A' + link.circularPathData.rightLargeArcRadius + ' ' + link.circularPathData.rightSmallArcRadius + ' 0 0 1 ' +\n // End of arc X //End of arc Y\n link.circularPathData.rightInnerExtent + ' ' + link.circularPathData.targetY + ' ' + // End of arc X\n // line to end\n 'L' + link.circularPathData.targetX + ' ' + link.circularPathData.targetY;\n }\n\n return pathString;\n}\n\n// sort links based on the distance between the source and tartget node columns\n// if the same, then use Y position of the source node\nfunction sortLinkColumnAscending(link1, link2) {\n if (linkColumnDistance(link1) == linkColumnDistance(link2)) {\n return link1.circularLinkType == 'bottom' ? sortLinkSourceYDescending(link1, link2) : sortLinkSourceYAscending(link1, link2);\n } else {\n return linkColumnDistance(link2) - linkColumnDistance(link1);\n }\n}\n\n// sort ascending links by their source vertical position, y0\nfunction sortLinkSourceYAscending(link1, link2) {\n return link1.y0 - link2.y0;\n}\n\n// sort descending links by their source vertical position, y0\nfunction sortLinkSourceYDescending(link1, link2) {\n return link2.y0 - link1.y0;\n}\n\n// sort ascending links by their target vertical position, y1\nfunction sortLinkTargetYAscending(link1, link2) {\n return link1.y1 - link2.y1;\n}\n\n// sort descending links by their target vertical position, y1\nfunction sortLinkTargetYDescending(link1, link2) {\n return link2.y1 - link1.y1;\n}\n\n// return the distance between the link's target and source node, in terms of the nodes' column\nfunction linkColumnDistance(link) {\n return link.target.column - link.source.column;\n}\n\n// return the distance between the link's target and source node, in terms of the nodes' X coordinate\nfunction linkXLength(link) {\n return link.target.x0 - link.source.x1;\n}\n\n// Return the Y coordinate on the longerLink path * which is perpendicular shorterLink's source.\n// * approx, based on a straight line from target to source, when in fact the path is a bezier\nfunction linkPerpendicularYToLinkSource(longerLink, shorterLink) {\n // get the angle for the longer link\n var angle = linkAngle(longerLink);\n\n // get the adjacent length to the other link's x position\n var heightFromY1ToPependicular = linkXLength(shorterLink) / Math.tan(angle);\n\n // add or subtract from longer link1's original y1, depending on the slope\n var yPerpendicular = incline(longerLink) == 'up' ? longerLink.y1 + heightFromY1ToPependicular : longerLink.y1 - heightFromY1ToPependicular;\n\n return yPerpendicular;\n}\n\n// Return the Y coordinate on the longerLink path * which is perpendicular shorterLink's source.\n// * approx, based on a straight line from target to source, when in fact the path is a bezier\nfunction linkPerpendicularYToLinkTarget(longerLink, shorterLink) {\n // get the angle for the longer link\n var angle = linkAngle(longerLink);\n\n // get the adjacent length to the other link's x position\n var heightFromY1ToPependicular = linkXLength(shorterLink) / Math.tan(angle);\n\n // add or subtract from longer link's original y1, depending on the slope\n var yPerpendicular = incline(longerLink) == 'up' ? longerLink.y1 - heightFromY1ToPependicular : longerLink.y1 + heightFromY1ToPependicular;\n\n return yPerpendicular;\n}\n\n// Move any nodes that overlap links which span 2+ columns\nfunction resolveNodeLinkOverlaps(graph, y0, y1, id) {\n\n graph.links.forEach(function (link) {\n if (link.circular) {\n return;\n }\n\n if (link.target.column - link.source.column > 1) {\n var columnToTest = link.source.column + 1;\n var maxColumnToTest = link.target.column - 1;\n\n var i = 1;\n var numberOfColumnsToTest = maxColumnToTest - columnToTest + 1;\n\n for (i = 1; columnToTest <= maxColumnToTest; columnToTest++, i++) {\n graph.nodes.forEach(function (node) {\n if (node.column == columnToTest) {\n var t = i / (numberOfColumnsToTest + 1);\n\n // Find all the points of a cubic bezier curve in javascript\n // https://stackoverflow.com/questions/15397596/find-all-the-points-of-a-cubic-bezier-curve-in-javascript\n\n var B0_t = Math.pow(1 - t, 3);\n var B1_t = 3 * t * Math.pow(1 - t, 2);\n var B2_t = 3 * Math.pow(t, 2) * (1 - t);\n var B3_t = Math.pow(t, 3);\n\n var py_t = B0_t * link.y0 + B1_t * link.y0 + B2_t * link.y1 + B3_t * link.y1;\n\n var linkY0AtColumn = py_t - link.width / 2;\n var linkY1AtColumn = py_t + link.width / 2;\n var dy;\n\n // If top of link overlaps node, push node up\n if (linkY0AtColumn > node.y0 && linkY0AtColumn < node.y1) {\n\n dy = node.y1 - linkY0AtColumn + 10;\n dy = node.circularLinkType == 'bottom' ? dy : -dy;\n\n node = adjustNodeHeight(node, dy, y0, y1);\n\n // check if other nodes need to move up too\n graph.nodes.forEach(function (otherNode) {\n // don't need to check itself or nodes at different columns\n if (getNodeID(otherNode, id) == getNodeID(node, id) || otherNode.column != node.column) {\n return;\n }\n if (nodesOverlap(node, otherNode)) {\n adjustNodeHeight(otherNode, dy, y0, y1);\n }\n });\n } else if (linkY1AtColumn > node.y0 && linkY1AtColumn < node.y1) {\n // If bottom of link overlaps node, push node down\n dy = linkY1AtColumn - node.y0 + 10;\n\n node = adjustNodeHeight(node, dy, y0, y1);\n\n // check if other nodes need to move down too\n graph.nodes.forEach(function (otherNode) {\n // don't need to check itself or nodes at different columns\n if (getNodeID(otherNode, id) == getNodeID(node, id) || otherNode.column != node.column) {\n return;\n }\n if (otherNode.y0 < node.y1 && otherNode.y1 > node.y1) {\n adjustNodeHeight(otherNode, dy, y0, y1);\n }\n });\n } else if (linkY0AtColumn < node.y0 && linkY1AtColumn > node.y1) {\n // if link completely overlaps node\n dy = linkY1AtColumn - node.y0 + 10;\n\n node = adjustNodeHeight(node, dy, y0, y1);\n\n graph.nodes.forEach(function (otherNode) {\n // don't need to check itself or nodes at different columns\n if (getNodeID(otherNode, id) == getNodeID(node, id) || otherNode.column != node.column) {\n return;\n }\n if (otherNode.y0 < node.y1 && otherNode.y1 > node.y1) {\n adjustNodeHeight(otherNode, dy, y0, y1);\n }\n });\n }\n }\n });\n }\n }\n });\n}\n\n// check if two nodes overlap\nfunction nodesOverlap(nodeA, nodeB) {\n // test if nodeA top partially overlaps nodeB\n if (nodeA.y0 > nodeB.y0 && nodeA.y0 < nodeB.y1) {\n return true;\n } else if (nodeA.y1 > nodeB.y0 && nodeA.y1 < nodeB.y1) {\n // test if nodeA bottom partially overlaps nodeB\n return true;\n } else if (nodeA.y0 < nodeB.y0 && nodeA.y1 > nodeB.y1) {\n // test if nodeA covers nodeB\n return true;\n } else {\n return false;\n }\n}\n\n// update a node, and its associated links, vertical positions (y0, y1)\nfunction adjustNodeHeight(node, dy, sankeyY0, sankeyY1) {\n if (node.y0 + dy >= sankeyY0 && node.y1 + dy <= sankeyY1) {\n node.y0 = node.y0 + dy;\n node.y1 = node.y1 + dy;\n\n node.targetLinks.forEach(function (l) {\n l.y1 = l.y1 + dy;\n });\n\n node.sourceLinks.forEach(function (l) {\n l.y0 = l.y0 + dy;\n });\n }\n return node;\n}\n\n// sort and set the links' y0 for each node\nfunction sortSourceLinks(graph, y1, id, moveNodes) {\n graph.nodes.forEach(function (node) {\n // move any nodes up which are off the bottom\n if (moveNodes && node.y + (node.y1 - node.y0) > y1) {\n node.y = node.y - (node.y + (node.y1 - node.y0) - y1);\n }\n\n var nodesSourceLinks = graph.links.filter(function (l) {\n return getNodeID(l.source, id) == getNodeID(node, id);\n });\n\n var nodeSourceLinksLength = nodesSourceLinks.length;\n\n // if more than 1 link then sort\n if (nodeSourceLinksLength > 1) {\n nodesSourceLinks.sort(function (link1, link2) {\n // if both are not circular...\n if (!link1.circular && !link2.circular) {\n // if the target nodes are the same column, then sort by the link's target y\n if (link1.target.column == link2.target.column) {\n return link1.y1 - link2.y1;\n } else if (!sameInclines(link1, link2)) {\n // if the links slope in different directions, then sort by the link's target y\n return link1.y1 - link2.y1;\n\n // if the links slope in same directions, then sort by any overlap\n } else {\n if (link1.target.column > link2.target.column) {\n var link2Adj = linkPerpendicularYToLinkTarget(link2, link1);\n return link1.y1 - link2Adj;\n }\n if (link2.target.column > link1.target.column) {\n var link1Adj = linkPerpendicularYToLinkTarget(link1, link2);\n return link1Adj - link2.y1;\n }\n }\n }\n\n // if only one is circular, the move top links up, or bottom links down\n if (link1.circular && !link2.circular) {\n return link1.circularLinkType == 'top' ? -1 : 1;\n } else if (link2.circular && !link1.circular) {\n return link2.circularLinkType == 'top' ? 1 : -1;\n }\n\n // if both links are circular...\n if (link1.circular && link2.circular) {\n // ...and they both loop the same way (both top)\n if (link1.circularLinkType === link2.circularLinkType && link1.circularLinkType == 'top') {\n // ...and they both connect to a target with same column, then sort by the target's y\n if (link1.target.column === link2.target.column) {\n return link1.target.y1 - link2.target.y1;\n } else {\n // ...and they connect to different column targets, then sort by how far back they\n return link2.target.column - link1.target.column;\n }\n } else if (link1.circularLinkType === link2.circularLinkType && link1.circularLinkType == 'bottom') {\n // ...and they both loop the same way (both bottom)\n // ...and they both connect to a target with same column, then sort by the target's y\n if (link1.target.column === link2.target.column) {\n return link2.target.y1 - link1.target.y1;\n } else {\n // ...and they connect to different column targets, then sort by how far back they\n return link1.target.column - link2.target.column;\n }\n } else {\n // ...and they loop around different ways, the move top up and bottom down\n return link1.circularLinkType == 'top' ? -1 : 1;\n }\n }\n });\n }\n\n // update y0 for links\n var ySourceOffset = node.y0;\n\n nodesSourceLinks.forEach(function (link) {\n link.y0 = ySourceOffset + link.width / 2;\n ySourceOffset = ySourceOffset + link.width;\n });\n\n // correct any circular bottom links so they are at the bottom of the node\n nodesSourceLinks.forEach(function (link, i) {\n if (link.circularLinkType == 'bottom') {\n var j = i + 1;\n var offsetFromBottom = 0;\n // sum the widths of any links that are below this link\n for (j; j < nodeSourceLinksLength; j++) {\n offsetFromBottom = offsetFromBottom + nodesSourceLinks[j].width;\n }\n link.y0 = node.y1 - offsetFromBottom - link.width / 2;\n }\n });\n });\n}\n\n// sort and set the links' y1 for each node\nfunction sortTargetLinks(graph, y1, id) {\n graph.nodes.forEach(function (node) {\n var nodesTargetLinks = graph.links.filter(function (l) {\n return getNodeID(l.target, id) == getNodeID(node, id);\n });\n\n var nodesTargetLinksLength = nodesTargetLinks.length;\n\n if (nodesTargetLinksLength > 1) {\n nodesTargetLinks.sort(function (link1, link2) {\n // if both are not circular, the base on the source y position\n if (!link1.circular && !link2.circular) {\n if (link1.source.column == link2.source.column) {\n return link1.y0 - link2.y0;\n } else if (!sameInclines(link1, link2)) {\n return link1.y0 - link2.y0;\n } else {\n // get the angle of the link to the further source node (ie the smaller column)\n if (link2.source.column < link1.source.column) {\n var link2Adj = linkPerpendicularYToLinkSource(link2, link1);\n\n return link1.y0 - link2Adj;\n }\n if (link1.source.column < link2.source.column) {\n var link1Adj = linkPerpendicularYToLinkSource(link1, link2);\n\n return link1Adj - link2.y0;\n }\n }\n }\n\n // if only one is circular, the move top links up, or bottom links down\n if (link1.circular && !link2.circular) {\n return link1.circularLinkType == 'top' ? -1 : 1;\n } else if (link2.circular && !link1.circular) {\n return link2.circularLinkType == 'top' ? 1 : -1;\n }\n\n // if both links are circular...\n if (link1.circular && link2.circular) {\n // ...and they both loop the same way (both top)\n if (link1.circularLinkType === link2.circularLinkType && link1.circularLinkType == 'top') {\n // ...and they both connect to a target with same column, then sort by the target's y\n if (link1.source.column === link2.source.column) {\n return link1.source.y1 - link2.source.y1;\n } else {\n // ...and they connect to different column targets, then sort by how far back they\n return link1.source.column - link2.source.column;\n }\n } else if (link1.circularLinkType === link2.circularLinkType && link1.circularLinkType == 'bottom') {\n // ...and they both loop the same way (both bottom)\n // ...and they both connect to a target with same column, then sort by the target's y\n if (link1.source.column === link2.source.column) {\n return link1.source.y1 - link2.source.y1;\n } else {\n // ...and they connect to different column targets, then sort by how far back they\n return link2.source.column - link1.source.column;\n }\n } else {\n // ...and they loop around different ways, the move top up and bottom down\n return link1.circularLinkType == 'top' ? -1 : 1;\n }\n }\n });\n }\n\n // update y1 for links\n var yTargetOffset = node.y0;\n\n nodesTargetLinks.forEach(function (link) {\n link.y1 = yTargetOffset + link.width / 2;\n yTargetOffset = yTargetOffset + link.width;\n });\n\n // correct any circular bottom links so they are at the bottom of the node\n nodesTargetLinks.forEach(function (link, i) {\n if (link.circularLinkType == 'bottom') {\n var j = i + 1;\n var offsetFromBottom = 0;\n // sum the widths of any links that are below this link\n for (j; j < nodesTargetLinksLength; j++) {\n offsetFromBottom = offsetFromBottom + nodesTargetLinks[j].width;\n }\n link.y1 = node.y1 - offsetFromBottom - link.width / 2;\n }\n });\n });\n}\n\n// test if links both slope up, or both slope down\nfunction sameInclines(link1, link2) {\n return incline(link1) == incline(link2);\n}\n\n// returns the slope of a link, from source to target\n// up => slopes up from source to target\n// down => slopes down from source to target\nfunction incline(link) {\n return link.y0 - link.y1 > 0 ? 'up' : 'down';\n}\n\n// check if link is self linking, ie links a node to the same node\nfunction selfLinking(link, id) {\n return getNodeID(link.source, id) == getNodeID(link.target, id);\n}\n\nfunction fillHeight(graph, y0, y1) {\n\n var nodes = graph.nodes;\n var links = graph.links;\n\n var top = false;\n var bottom = false;\n\n links.forEach(function (link) {\n if (link.circularLinkType == \"top\") {\n top = true;\n } else if (link.circularLinkType == \"bottom\") {\n bottom = true;\n }\n });\n\n if (top == false || bottom == false) {\n var minY0 = min(nodes, function (node) {\n return node.y0;\n });\n var maxY1 = max(nodes, function (node) {\n return node.y1;\n });\n var currentHeight = maxY1 - minY0;\n var chartHeight = y1 - y0;\n var ratio = chartHeight / currentHeight;\n\n nodes.forEach(function (node) {\n var nodeHeight = (node.y1 - node.y0) * ratio;\n node.y0 = (node.y0 - minY0) * ratio;\n node.y1 = node.y0 + nodeHeight;\n });\n\n links.forEach(function (link) {\n link.y0 = (link.y0 - minY0) * ratio;\n link.y1 = (link.y1 - minY0) * ratio;\n link.width = link.width * ratio;\n });\n }\n}\n\nexport { sankeyCircular, center as sankeyCenter, left as sankeyLeft, right as sankeyRight, justify as sankeyJustify };\n","import {min} from \"d3-array\";\n\nfunction targetDepth(d) {\n return d.target.depth;\n}\n\nexport function left(node) {\n return node.depth;\n}\n\nexport function right(node, n) {\n return n - 1 - node.height;\n}\n\nexport function justify(node, n) {\n return node.sourceLinks.length ? node.depth : n - 1;\n}\n\nexport function center(node) {\n return node.targetLinks.length ? node.depth\n : node.sourceLinks.length ? min(node.sourceLinks, targetDepth) - 1\n : 0;\n}\n","export default function constant(x) {\n return function() {\n return x;\n };\n}\n","import {ascending, min, max, sum} from \"d3-array\";\nimport {map, nest} from \"d3-collection\";\nimport {justify} from \"./align\";\nimport constant from \"./constant\";\n\nfunction ascendingSourceBreadth(a, b) {\n return ascendingBreadth(a.source, b.source) || a.index - b.index;\n}\n\nfunction ascendingTargetBreadth(a, b) {\n return ascendingBreadth(a.target, b.target) || a.index - b.index;\n}\n\nfunction ascendingBreadth(a, b) {\n return a.y0 - b.y0;\n}\n\nfunction value(d) {\n return d.value;\n}\n\nfunction nodeCenter(node) {\n return (node.y0 + node.y1) / 2;\n}\n\nfunction weightedSource(link) {\n return nodeCenter(link.source) * link.value;\n}\n\nfunction weightedTarget(link) {\n return nodeCenter(link.target) * link.value;\n}\n\nfunction defaultId(d) {\n return d.index;\n}\n\nfunction defaultNodes(graph) {\n return graph.nodes;\n}\n\nfunction defaultLinks(graph) {\n return graph.links;\n}\n\nfunction find(nodeById, id) {\n var node = nodeById.get(id);\n if (!node) throw new Error(\"missing: \" + id);\n return node;\n}\n\nexport default function() {\n var x0 = 0, y0 = 0, x1 = 1, y1 = 1, // extent\n dx = 24, // nodeWidth\n py = 8, // nodePadding\n id = defaultId,\n align = justify,\n nodes = defaultNodes,\n links = defaultLinks,\n iterations = 32,\n maxPaddedSpace = 2 / 3; // Defined as a fraction of the total available space\n\n function sankey() {\n var graph = {nodes: nodes.apply(null, arguments), links: links.apply(null, arguments)};\n computeNodeLinks(graph);\n computeNodeValues(graph);\n computeNodeDepths(graph);\n computeNodeBreadths(graph, iterations);\n computeLinkBreadths(graph);\n return graph;\n }\n\n sankey.update = function(graph) {\n computeLinkBreadths(graph);\n return graph;\n };\n\n sankey.nodeId = function(_) {\n return arguments.length ? (id = typeof _ === \"function\" ? _ : constant(_), sankey) : id;\n };\n\n sankey.nodeAlign = function(_) {\n return arguments.length ? (align = typeof _ === \"function\" ? _ : constant(_), sankey) : align;\n };\n\n sankey.nodeWidth = function(_) {\n return arguments.length ? (dx = +_, sankey) : dx;\n };\n\n sankey.nodePadding = function(_) {\n return arguments.length ? (py = +_, sankey) : py;\n };\n\n sankey.nodes = function(_) {\n return arguments.length ? (nodes = typeof _ === \"function\" ? _ : constant(_), sankey) : nodes;\n };\n\n sankey.links = function(_) {\n return arguments.length ? (links = typeof _ === \"function\" ? _ : constant(_), sankey) : links;\n };\n\n sankey.size = function(_) {\n return arguments.length ? (x0 = y0 = 0, x1 = +_[0], y1 = +_[1], sankey) : [x1 - x0, y1 - y0];\n };\n\n sankey.extent = function(_) {\n return arguments.length ? (x0 = +_[0][0], x1 = +_[1][0], y0 = +_[0][1], y1 = +_[1][1], sankey) : [[x0, y0], [x1, y1]];\n };\n\n sankey.iterations = function(_) {\n return arguments.length ? (iterations = +_, sankey) : iterations;\n };\n\n // Populate the sourceLinks and targetLinks for each node.\n // Also, if the source and target are not objects, assume they are indices.\n function computeNodeLinks(graph) {\n graph.nodes.forEach(function(node, i) {\n node.index = i;\n node.sourceLinks = [];\n node.targetLinks = [];\n });\n\n var nodeById = map(graph.nodes, id);\n graph.links.forEach(function(link, i) {\n link.index = i;\n var source = link.source, target = link.target;\n if (typeof source !== \"object\") source = link.source = find(nodeById, source);\n if (typeof target !== \"object\") target = link.target = find(nodeById, target);\n source.sourceLinks.push(link);\n target.targetLinks.push(link);\n });\n }\n\n // Compute the value (size) of each node by summing the associated links.\n function computeNodeValues(graph) {\n graph.nodes.forEach(function(node) {\n node.value = Math.max(\n sum(node.sourceLinks, value),\n sum(node.targetLinks, value)\n );\n });\n }\n\n // Iteratively assign the depth (x-position) for each node.\n // Nodes are assigned the maximum depth of incoming neighbors plus one;\n // nodes with no incoming links are assigned depth zero, while\n // nodes with no outgoing links are assigned the maximum depth.\n function computeNodeDepths(graph) {\n var nodes, next, x;\n\n for (nodes = graph.nodes, next = [], x = 0; nodes.length; ++x, nodes = next, next = []) {\n nodes.forEach(function(node) {\n node.depth = x;\n node.sourceLinks.forEach(function(link) {\n if (next.indexOf(link.target) < 0) {\n next.push(link.target);\n }\n });\n });\n }\n\n for (nodes = graph.nodes, next = [], x = 0; nodes.length; ++x, nodes = next, next = []) {\n nodes.forEach(function(node) {\n node.height = x;\n node.targetLinks.forEach(function(link) {\n if (next.indexOf(link.source) < 0) {\n next.push(link.source);\n }\n });\n });\n }\n\n var kx = (x1 - x0 - dx) / (x - 1);\n graph.nodes.forEach(function(node) {\n node.x1 = (node.x0 = x0 + Math.max(0, Math.min(x - 1, Math.floor(align.call(null, node, x)))) * kx) + dx;\n });\n }\n\n function computeNodeBreadths(graph) {\n var columns = nest()\n .key(function(d) { return d.x0; })\n .sortKeys(ascending)\n .entries(graph.nodes)\n .map(function(d) { return d.values; });\n\n //\n initializeNodeBreadth();\n resolveCollisions();\n for (var alpha = 1, n = iterations; n > 0; --n) {\n relaxRightToLeft(alpha *= 0.99);\n resolveCollisions();\n relaxLeftToRight(alpha);\n resolveCollisions();\n }\n\n function initializeNodeBreadth() {\n var L = max(columns, function(nodes) {\n return nodes.length;\n });\n var maxNodePadding = maxPaddedSpace * (y1 - y0) / (L - 1);\n if(py > maxNodePadding) py = maxNodePadding;\n var ky = min(columns, function(nodes) {\n return (y1 - y0 - (nodes.length - 1) * py) / sum(nodes, value);\n });\n\n columns.forEach(function(nodes) {\n nodes.forEach(function(node, i) {\n node.y1 = (node.y0 = i) + node.value * ky;\n });\n });\n\n graph.links.forEach(function(link) {\n link.width = link.value * ky;\n });\n }\n\n function relaxLeftToRight(alpha) {\n columns.forEach(function(nodes) {\n nodes.forEach(function(node) {\n if (node.targetLinks.length) {\n var dy = (sum(node.targetLinks, weightedSource) / sum(node.targetLinks, value) - nodeCenter(node)) * alpha;\n node.y0 += dy, node.y1 += dy;\n }\n });\n });\n }\n\n function relaxRightToLeft(alpha) {\n columns.slice().reverse().forEach(function(nodes) {\n nodes.forEach(function(node) {\n if (node.sourceLinks.length) {\n var dy = (sum(node.sourceLinks, weightedTarget) / sum(node.sourceLinks, value) - nodeCenter(node)) * alpha;\n node.y0 += dy, node.y1 += dy;\n }\n });\n });\n }\n\n function resolveCollisions() {\n columns.forEach(function(nodes) {\n var node,\n dy,\n y = y0,\n n = nodes.length,\n i;\n\n // Push any overlapping nodes down.\n nodes.sort(ascendingBreadth);\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n dy = y - node.y0;\n if (dy > 0) node.y0 += dy, node.y1 += dy;\n y = node.y1 + py;\n }\n\n // If the bottommost node goes outside the bounds, push it back up.\n dy = y - py - y1;\n if (dy > 0) {\n y = (node.y0 -= dy), node.y1 -= dy;\n\n // Push any overlapping nodes back up.\n for (i = n - 2; i >= 0; --i) {\n node = nodes[i];\n dy = node.y1 + py - y;\n if (dy > 0) node.y0 -= dy, node.y1 -= dy;\n y = node.y0;\n }\n }\n });\n }\n }\n\n function computeLinkBreadths(graph) {\n graph.nodes.forEach(function(node) {\n node.sourceLinks.sort(ascendingTargetBreadth);\n node.targetLinks.sort(ascendingSourceBreadth);\n });\n graph.nodes.forEach(function(node) {\n var y0 = node.y0, y1 = y0;\n node.sourceLinks.forEach(function(link) {\n link.y0 = y0 + link.width / 2, y0 += link.width;\n });\n node.targetLinks.forEach(function(link) {\n link.y1 = y1 + link.width / 2, y1 += link.width;\n });\n });\n }\n\n return sankey;\n}\n","import {linkHorizontal} from \"d3-shape\";\n\nfunction horizontalSource(d) {\n return [d.source.x1, d.y0];\n}\n\nfunction horizontalTarget(d) {\n return [d.target.x0, d.y1];\n}\n\nexport default function() {\n return linkHorizontal()\n .source(horizontalSource)\n .target(horizontalTarget);\n}\n","!function() {\n var d3 = {\n version: \"3.8.2\"\n };\n var d3_arraySlice = [].slice, d3_array = function(list) {\n return d3_arraySlice.call(list);\n };\n var d3_document = self.document;\n function d3_documentElement(node) {\n return node && (node.ownerDocument || node.document || node).documentElement;\n }\n function d3_window(node) {\n return node && (node.ownerDocument && node.ownerDocument.defaultView || node.document && node || node.defaultView);\n }\n if (d3_document) {\n try {\n d3_array(d3_document.documentElement.childNodes)[0].nodeType;\n } catch (e) {\n d3_array = function(list) {\n var i = list.length, array = new Array(i);\n while (i--) array[i] = list[i];\n return array;\n };\n }\n }\n if (!Date.now) Date.now = function() {\n return +new Date();\n };\n if (d3_document) {\n try {\n d3_document.createElement(\"DIV\").style.setProperty(\"opacity\", 0, \"\");\n } catch (error) {\n var d3_element_prototype = this.Element.prototype, d3_element_setAttribute = d3_element_prototype.setAttribute, d3_element_setAttributeNS = d3_element_prototype.setAttributeNS, d3_style_prototype = this.CSSStyleDeclaration.prototype, d3_style_setProperty = d3_style_prototype.setProperty;\n d3_element_prototype.setAttribute = function(name, value) {\n d3_element_setAttribute.call(this, name, value + \"\");\n };\n d3_element_prototype.setAttributeNS = function(space, local, value) {\n d3_element_setAttributeNS.call(this, space, local, value + \"\");\n };\n d3_style_prototype.setProperty = function(name, value, priority) {\n d3_style_setProperty.call(this, name, value + \"\", priority);\n };\n }\n }\n d3.ascending = d3_ascending;\n function d3_ascending(a, b) {\n return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n }\n d3.descending = function(a, b) {\n return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN;\n };\n d3.min = function(array, f) {\n var i = -1, n = array.length, a, b;\n if (arguments.length === 1) {\n while (++i < n) if ((b = array[i]) != null && b >= b) {\n a = b;\n break;\n }\n while (++i < n) if ((b = array[i]) != null && a > b) a = b;\n } else {\n while (++i < n) if ((b = f.call(array, array[i], i)) != null && b >= b) {\n a = b;\n break;\n }\n while (++i < n) if ((b = f.call(array, array[i], i)) != null && a > b) a = b;\n }\n return a;\n };\n d3.max = function(array, f) {\n var i = -1, n = array.length, a, b;\n if (arguments.length === 1) {\n while (++i < n) if ((b = array[i]) != null && b >= b) {\n a = b;\n break;\n }\n while (++i < n) if ((b = array[i]) != null && b > a) a = b;\n } else {\n while (++i < n) if ((b = f.call(array, array[i], i)) != null && b >= b) {\n a = b;\n break;\n }\n while (++i < n) if ((b = f.call(array, array[i], i)) != null && b > a) a = b;\n }\n return a;\n };\n d3.extent = function(array, f) {\n var i = -1, n = array.length, a, b, c;\n if (arguments.length === 1) {\n while (++i < n) if ((b = array[i]) != null && b >= b) {\n a = c = b;\n break;\n }\n while (++i < n) if ((b = array[i]) != null) {\n if (a > b) a = b;\n if (c < b) c = b;\n }\n } else {\n while (++i < n) if ((b = f.call(array, array[i], i)) != null && b >= b) {\n a = c = b;\n break;\n }\n while (++i < n) if ((b = f.call(array, array[i], i)) != null) {\n if (a > b) a = b;\n if (c < b) c = b;\n }\n }\n return [ a, c ];\n };\n function d3_number(x) {\n return x === null ? NaN : +x;\n }\n function d3_numeric(x) {\n return !isNaN(x);\n }\n d3.sum = function(array, f) {\n var s = 0, n = array.length, a, i = -1;\n if (arguments.length === 1) {\n while (++i < n) if (d3_numeric(a = +array[i])) s += a;\n } else {\n while (++i < n) if (d3_numeric(a = +f.call(array, array[i], i))) s += a;\n }\n return s;\n };\n d3.mean = function(array, f) {\n var s = 0, n = array.length, a, i = -1, j = n;\n if (arguments.length === 1) {\n while (++i < n) if (d3_numeric(a = d3_number(array[i]))) s += a; else --j;\n } else {\n while (++i < n) if (d3_numeric(a = d3_number(f.call(array, array[i], i)))) s += a; else --j;\n }\n if (j) return s / j;\n };\n d3.quantile = function(values, p) {\n var H = (values.length - 1) * p + 1, h = Math.floor(H), v = +values[h - 1], e = H - h;\n return e ? v + e * (values[h] - v) : v;\n };\n d3.median = function(array, f) {\n var numbers = [], n = array.length, a, i = -1;\n if (arguments.length === 1) {\n while (++i < n) if (d3_numeric(a = d3_number(array[i]))) numbers.push(a);\n } else {\n while (++i < n) if (d3_numeric(a = d3_number(f.call(array, array[i], i)))) numbers.push(a);\n }\n if (numbers.length) return d3.quantile(numbers.sort(d3_ascending), .5);\n };\n d3.variance = function(array, f) {\n var n = array.length, m = 0, a, d, s = 0, i = -1, j = 0;\n if (arguments.length === 1) {\n while (++i < n) {\n if (d3_numeric(a = d3_number(array[i]))) {\n d = a - m;\n m += d / ++j;\n s += d * (a - m);\n }\n }\n } else {\n while (++i < n) {\n if (d3_numeric(a = d3_number(f.call(array, array[i], i)))) {\n d = a - m;\n m += d / ++j;\n s += d * (a - m);\n }\n }\n }\n if (j > 1) return s / (j - 1);\n };\n d3.deviation = function() {\n var v = d3.variance.apply(this, arguments);\n return v ? Math.sqrt(v) : v;\n };\n function d3_bisector(compare) {\n return {\n left: function(a, x, lo, hi) {\n if (arguments.length < 3) lo = 0;\n if (arguments.length < 4) hi = a.length;\n while (lo < hi) {\n var mid = lo + hi >>> 1;\n if (compare(a[mid], x) < 0) lo = mid + 1; else hi = mid;\n }\n return lo;\n },\n right: function(a, x, lo, hi) {\n if (arguments.length < 3) lo = 0;\n if (arguments.length < 4) hi = a.length;\n while (lo < hi) {\n var mid = lo + hi >>> 1;\n if (compare(a[mid], x) > 0) hi = mid; else lo = mid + 1;\n }\n return lo;\n }\n };\n }\n var d3_bisect = d3_bisector(d3_ascending);\n d3.bisectLeft = d3_bisect.left;\n d3.bisect = d3.bisectRight = d3_bisect.right;\n d3.bisector = function(f) {\n return d3_bisector(f.length === 1 ? function(d, x) {\n return d3_ascending(f(d), x);\n } : f);\n };\n d3.shuffle = function(array, i0, i1) {\n if ((m = arguments.length) < 3) {\n i1 = array.length;\n if (m < 2) i0 = 0;\n }\n var m = i1 - i0, t, i;\n while (m) {\n i = Math.random() * m-- | 0;\n t = array[m + i0], array[m + i0] = array[i + i0], array[i + i0] = t;\n }\n return array;\n };\n d3.permute = function(array, indexes) {\n var i = indexes.length, permutes = new Array(i);\n while (i--) permutes[i] = array[indexes[i]];\n return permutes;\n };\n d3.pairs = function(array) {\n var i = 0, n = array.length - 1, p0, p1 = array[0], pairs = new Array(n < 0 ? 0 : n);\n while (i < n) pairs[i] = [ p0 = p1, p1 = array[++i] ];\n return pairs;\n };\n d3.transpose = function(matrix) {\n if (!(n = matrix.length)) return [];\n for (var i = -1, m = d3.min(matrix, d3_transposeLength), transpose = new Array(m); ++i < m; ) {\n for (var j = -1, n, row = transpose[i] = new Array(n); ++j < n; ) {\n row[j] = matrix[j][i];\n }\n }\n return transpose;\n };\n function d3_transposeLength(d) {\n return d.length;\n }\n d3.zip = function() {\n return d3.transpose(arguments);\n };\n d3.keys = function(map) {\n var keys = [];\n for (var key in map) keys.push(key);\n return keys;\n };\n d3.values = function(map) {\n var values = [];\n for (var key in map) values.push(map[key]);\n return values;\n };\n d3.entries = function(map) {\n var entries = [];\n for (var key in map) entries.push({\n key: key,\n value: map[key]\n });\n return entries;\n };\n d3.merge = function(arrays) {\n var n = arrays.length, m, i = -1, j = 0, merged, array;\n while (++i < n) j += arrays[i].length;\n merged = new Array(j);\n while (--n >= 0) {\n array = arrays[n];\n m = array.length;\n while (--m >= 0) {\n merged[--j] = array[m];\n }\n }\n return merged;\n };\n var abs = Math.abs;\n d3.range = function(start, stop, step) {\n if (arguments.length < 3) {\n step = 1;\n if (arguments.length < 2) {\n stop = start;\n start = 0;\n }\n }\n if ((stop - start) / step === Infinity) throw new Error(\"infinite range\");\n var range = [], k = d3_range_integerScale(abs(step)), i = -1, j;\n start *= k, stop *= k, step *= k;\n if (step < 0) while ((j = start + step * ++i) > stop) range.push(j / k); else while ((j = start + step * ++i) < stop) range.push(j / k);\n return range;\n };\n function d3_range_integerScale(x) {\n var k = 1;\n while (x * k % 1) k *= 10;\n return k;\n }\n function d3_class(ctor, properties) {\n for (var key in properties) {\n Object.defineProperty(ctor.prototype, key, {\n value: properties[key],\n enumerable: false\n });\n }\n }\n d3.map = function(object, f) {\n var map = new d3_Map();\n if (object instanceof d3_Map) {\n object.forEach(function(key, value) {\n map.set(key, value);\n });\n } else if (Array.isArray(object)) {\n var i = -1, n = object.length, o;\n if (arguments.length === 1) while (++i < n) map.set(i, object[i]); else while (++i < n) map.set(f.call(object, o = object[i], i), o);\n } else {\n for (var key in object) map.set(key, object[key]);\n }\n return map;\n };\n function d3_Map() {\n this._ = Object.create(null);\n }\n var d3_map_proto = \"__proto__\", d3_map_zero = \"\\x00\";\n d3_class(d3_Map, {\n has: d3_map_has,\n get: function(key) {\n return this._[d3_map_escape(key)];\n },\n set: function(key, value) {\n return this._[d3_map_escape(key)] = value;\n },\n remove: d3_map_remove,\n keys: d3_map_keys,\n values: function() {\n var values = [];\n for (var key in this._) values.push(this._[key]);\n return values;\n },\n entries: function() {\n var entries = [];\n for (var key in this._) entries.push({\n key: d3_map_unescape(key),\n value: this._[key]\n });\n return entries;\n },\n size: d3_map_size,\n empty: d3_map_empty,\n forEach: function(f) {\n for (var key in this._) f.call(this, d3_map_unescape(key), this._[key]);\n }\n });\n function d3_map_escape(key) {\n return (key += \"\") === d3_map_proto || key[0] === d3_map_zero ? d3_map_zero + key : key;\n }\n function d3_map_unescape(key) {\n return (key += \"\")[0] === d3_map_zero ? key.slice(1) : key;\n }\n function d3_map_has(key) {\n return d3_map_escape(key) in this._;\n }\n function d3_map_remove(key) {\n return (key = d3_map_escape(key)) in this._ && delete this._[key];\n }\n function d3_map_keys() {\n var keys = [];\n for (var key in this._) keys.push(d3_map_unescape(key));\n return keys;\n }\n function d3_map_size() {\n var size = 0;\n for (var key in this._) ++size;\n return size;\n }\n function d3_map_empty() {\n for (var key in this._) return false;\n return true;\n }\n d3.nest = function() {\n var nest = {}, keys = [], sortKeys = [], sortValues, rollup;\n function map(mapType, array, depth) {\n if (depth >= keys.length) return rollup ? rollup.call(nest, array) : sortValues ? array.sort(sortValues) : array;\n var i = -1, n = array.length, key = keys[depth++], keyValue, object, setter, valuesByKey = new d3_Map(), values;\n while (++i < n) {\n if (values = valuesByKey.get(keyValue = key(object = array[i]))) {\n values.push(object);\n } else {\n valuesByKey.set(keyValue, [ object ]);\n }\n }\n if (mapType) {\n object = mapType();\n setter = function(keyValue, values) {\n object.set(keyValue, map(mapType, values, depth));\n };\n } else {\n object = {};\n setter = function(keyValue, values) {\n object[keyValue] = map(mapType, values, depth);\n };\n }\n valuesByKey.forEach(setter);\n return object;\n }\n function entries(map, depth) {\n if (depth >= keys.length) return map;\n var array = [], sortKey = sortKeys[depth++];\n map.forEach(function(key, keyMap) {\n array.push({\n key: key,\n values: entries(keyMap, depth)\n });\n });\n return sortKey ? array.sort(function(a, b) {\n return sortKey(a.key, b.key);\n }) : array;\n }\n nest.map = function(array, mapType) {\n return map(mapType, array, 0);\n };\n nest.entries = function(array) {\n return entries(map(d3.map, array, 0), 0);\n };\n nest.key = function(d) {\n keys.push(d);\n return nest;\n };\n nest.sortKeys = function(order) {\n sortKeys[keys.length - 1] = order;\n return nest;\n };\n nest.sortValues = function(order) {\n sortValues = order;\n return nest;\n };\n nest.rollup = function(f) {\n rollup = f;\n return nest;\n };\n return nest;\n };\n d3.set = function(array) {\n var set = new d3_Set();\n if (array) for (var i = 0, n = array.length; i < n; ++i) set.add(array[i]);\n return set;\n };\n function d3_Set() {\n this._ = Object.create(null);\n }\n d3_class(d3_Set, {\n has: d3_map_has,\n add: function(key) {\n this._[d3_map_escape(key += \"\")] = true;\n return key;\n },\n remove: d3_map_remove,\n values: d3_map_keys,\n size: d3_map_size,\n empty: d3_map_empty,\n forEach: function(f) {\n for (var key in this._) f.call(this, d3_map_unescape(key));\n }\n });\n d3.behavior = {};\n function d3_identity(d) {\n return d;\n }\n d3.rebind = function(target, source) {\n var i = 1, n = arguments.length, method;\n while (++i < n) target[method = arguments[i]] = d3_rebind(target, source, source[method]);\n return target;\n };\n function d3_rebind(target, source, method) {\n return function() {\n var value = method.apply(source, arguments);\n return value === source ? target : value;\n };\n }\n function d3_vendorSymbol(object, name) {\n if (name in object) return name;\n name = name.charAt(0).toUpperCase() + name.slice(1);\n for (var i = 0, n = d3_vendorPrefixes.length; i < n; ++i) {\n var prefixName = d3_vendorPrefixes[i] + name;\n if (prefixName in object) return prefixName;\n }\n }\n var d3_vendorPrefixes = [ \"webkit\", \"ms\", \"moz\", \"Moz\", \"o\", \"O\" ];\n function d3_noop() {}\n d3.dispatch = function() {\n var dispatch = new d3_dispatch(), i = -1, n = arguments.length;\n while (++i < n) dispatch[arguments[i]] = d3_dispatch_event(dispatch);\n return dispatch;\n };\n function d3_dispatch() {}\n d3_dispatch.prototype.on = function(type, listener) {\n var i = type.indexOf(\".\"), name = \"\";\n if (i >= 0) {\n name = type.slice(i + 1);\n type = type.slice(0, i);\n }\n if (type) return arguments.length < 2 ? this[type].on(name) : this[type].on(name, listener);\n if (arguments.length === 2) {\n if (listener == null) for (type in this) {\n if (this.hasOwnProperty(type)) this[type].on(name, null);\n }\n return this;\n }\n };\n function d3_dispatch_event(dispatch) {\n var listeners = [], listenerByName = new d3_Map();\n function event() {\n var z = listeners, i = -1, n = z.length, l;\n while (++i < n) if (l = z[i].on) l.apply(this, arguments);\n return dispatch;\n }\n event.on = function(name, listener) {\n var l = listenerByName.get(name), i;\n if (arguments.length < 2) return l && l.on;\n if (l) {\n l.on = null;\n listeners = listeners.slice(0, i = listeners.indexOf(l)).concat(listeners.slice(i + 1));\n listenerByName.remove(name);\n }\n if (listener) listeners.push(listenerByName.set(name, {\n on: listener\n }));\n return dispatch;\n };\n return event;\n }\n d3.event = null;\n function d3_eventPreventDefault() {\n d3.event.preventDefault();\n }\n function d3_eventSource() {\n var e = d3.event, s;\n while (s = e.sourceEvent) e = s;\n return e;\n }\n function d3_eventDispatch(target) {\n var dispatch = new d3_dispatch(), i = 0, n = arguments.length;\n while (++i < n) dispatch[arguments[i]] = d3_dispatch_event(dispatch);\n dispatch.of = function(thiz, argumentz) {\n return function(e1) {\n try {\n var e0 = e1.sourceEvent = d3.event;\n e1.target = target;\n d3.event = e1;\n dispatch[e1.type].apply(thiz, argumentz);\n } finally {\n d3.event = e0;\n }\n };\n };\n return dispatch;\n }\n d3.requote = function(s) {\n return s.replace(d3_requote_re, \"\\\\$&\");\n };\n var d3_requote_re = /[\\\\\\^\\$\\*\\+\\?\\|\\[\\]\\(\\)\\.\\{\\}]/g;\n var d3_subclass = {}.__proto__ ? function(object, prototype) {\n object.__proto__ = prototype;\n } : function(object, prototype) {\n for (var property in prototype) object[property] = prototype[property];\n };\n function d3_selection(groups) {\n d3_subclass(groups, d3_selectionPrototype);\n return groups;\n }\n var d3_select = function(s, n) {\n return n.querySelector(s);\n }, d3_selectAll = function(s, n) {\n return n.querySelectorAll(s);\n }, d3_selectMatches = function(n, s) {\n var d3_selectMatcher = n.matches || n[d3_vendorSymbol(n, \"matchesSelector\")];\n d3_selectMatches = function(n, s) {\n return d3_selectMatcher.call(n, s);\n };\n return d3_selectMatches(n, s);\n };\n if (typeof Sizzle === \"function\") {\n d3_select = function(s, n) {\n return Sizzle(s, n)[0] || null;\n };\n d3_selectAll = Sizzle;\n d3_selectMatches = Sizzle.matchesSelector;\n }\n d3.selection = function() {\n return d3.select(d3_document.documentElement);\n };\n var d3_selectionPrototype = d3.selection.prototype = [];\n d3_selectionPrototype.select = function(selector) {\n var subgroups = [], subgroup, subnode, group, node;\n selector = d3_selection_selector(selector);\n for (var j = -1, m = this.length; ++j < m; ) {\n subgroups.push(subgroup = []);\n subgroup.parentNode = (group = this[j]).parentNode;\n for (var i = -1, n = group.length; ++i < n; ) {\n if (node = group[i]) {\n subgroup.push(subnode = selector.call(node, node.__data__, i, j));\n if (subnode && \"__data__\" in node) subnode.__data__ = node.__data__;\n } else {\n subgroup.push(null);\n }\n }\n }\n return d3_selection(subgroups);\n };\n function d3_selection_selector(selector) {\n return typeof selector === \"function\" ? selector : function() {\n return d3_select(selector, this);\n };\n }\n d3_selectionPrototype.selectAll = function(selector) {\n var subgroups = [], subgroup, node;\n selector = d3_selection_selectorAll(selector);\n for (var j = -1, m = this.length; ++j < m; ) {\n for (var group = this[j], i = -1, n = group.length; ++i < n; ) {\n if (node = group[i]) {\n subgroups.push(subgroup = d3_array(selector.call(node, node.__data__, i, j)));\n subgroup.parentNode = node;\n }\n }\n }\n return d3_selection(subgroups);\n };\n function d3_selection_selectorAll(selector) {\n return typeof selector === \"function\" ? selector : function() {\n return d3_selectAll(selector, this);\n };\n }\n var d3_nsXhtml = \"http://www.w3.org/1999/xhtml\";\n var d3_nsPrefix = {\n svg: \"http://www.w3.org/2000/svg\",\n xhtml: d3_nsXhtml,\n xlink: \"http://www.w3.org/1999/xlink\",\n xml: \"http://www.w3.org/XML/1998/namespace\",\n xmlns: \"http://www.w3.org/2000/xmlns/\"\n };\n d3.ns = {\n prefix: d3_nsPrefix,\n qualify: function(name) {\n var i = name.indexOf(\":\"), prefix = name;\n if (i >= 0 && (prefix = name.slice(0, i)) !== \"xmlns\") name = name.slice(i + 1);\n return d3_nsPrefix.hasOwnProperty(prefix) ? {\n space: d3_nsPrefix[prefix],\n local: name\n } : name;\n }\n };\n d3_selectionPrototype.attr = function(name, value) {\n if (arguments.length < 2) {\n if (typeof name === \"string\") {\n var node = this.node();\n name = d3.ns.qualify(name);\n return name.local ? node.getAttributeNS(name.space, name.local) : node.getAttribute(name);\n }\n for (value in name) this.each(d3_selection_attr(value, name[value]));\n return this;\n }\n return this.each(d3_selection_attr(name, value));\n };\n function d3_selection_attr(name, value) {\n name = d3.ns.qualify(name);\n function attrNull() {\n this.removeAttribute(name);\n }\n function attrNullNS() {\n this.removeAttributeNS(name.space, name.local);\n }\n function attrConstant() {\n this.setAttribute(name, value);\n }\n function attrConstantNS() {\n this.setAttributeNS(name.space, name.local, value);\n }\n function attrFunction() {\n var x = value.apply(this, arguments);\n if (x == null) this.removeAttribute(name); else this.setAttribute(name, x);\n }\n function attrFunctionNS() {\n var x = value.apply(this, arguments);\n if (x == null) this.removeAttributeNS(name.space, name.local); else this.setAttributeNS(name.space, name.local, x);\n }\n return value == null ? name.local ? attrNullNS : attrNull : typeof value === \"function\" ? name.local ? attrFunctionNS : attrFunction : name.local ? attrConstantNS : attrConstant;\n }\n function d3_collapse(s) {\n return s.trim().replace(/\\s+/g, \" \");\n }\n d3_selectionPrototype.classed = function(name, value) {\n if (arguments.length < 2) {\n if (typeof name === \"string\") {\n var node = this.node(), n = (name = d3_selection_classes(name)).length, i = -1;\n if (value = node.classList) {\n while (++i < n) if (!value.contains(name[i])) return false;\n } else {\n value = node.getAttribute(\"class\");\n while (++i < n) if (!d3_selection_classedRe(name[i]).test(value)) return false;\n }\n return true;\n }\n for (value in name) this.each(d3_selection_classed(value, name[value]));\n return this;\n }\n return this.each(d3_selection_classed(name, value));\n };\n function d3_selection_classedRe(name) {\n return new RegExp(\"(?:^|\\\\s+)\" + d3.requote(name) + \"(?:\\\\s+|$)\", \"g\");\n }\n function d3_selection_classes(name) {\n return (name + \"\").trim().split(/^|\\s+/);\n }\n function d3_selection_classed(name, value) {\n name = d3_selection_classes(name).map(d3_selection_classedName);\n var n = name.length;\n function classedConstant() {\n var i = -1;\n while (++i < n) name[i](this, value);\n }\n function classedFunction() {\n var i = -1, x = value.apply(this, arguments);\n while (++i < n) name[i](this, x);\n }\n return typeof value === \"function\" ? classedFunction : classedConstant;\n }\n function d3_selection_classedName(name) {\n var re = d3_selection_classedRe(name);\n return function(node, value) {\n if (c = node.classList) return value ? c.add(name) : c.remove(name);\n var c = node.getAttribute(\"class\") || \"\";\n if (value) {\n re.lastIndex = 0;\n if (!re.test(c)) node.setAttribute(\"class\", d3_collapse(c + \" \" + name));\n } else {\n node.setAttribute(\"class\", d3_collapse(c.replace(re, \" \")));\n }\n };\n }\n d3_selectionPrototype.style = function(name, value, priority) {\n var n = arguments.length;\n if (n < 3) {\n if (typeof name !== \"string\") {\n if (n < 2) value = \"\";\n for (priority in name) this.each(d3_selection_style(priority, name[priority], value));\n return this;\n }\n if (n < 2) {\n var node = this.node();\n return d3_window(node).getComputedStyle(node, null).getPropertyValue(name);\n }\n priority = \"\";\n }\n return this.each(d3_selection_style(name, value, priority));\n };\n function d3_selection_style(name, value, priority) {\n function styleNull() {\n this.style.removeProperty(name);\n }\n function styleConstant() {\n this.style.setProperty(name, value, priority);\n }\n function styleFunction() {\n var x = value.apply(this, arguments);\n if (x == null) this.style.removeProperty(name); else this.style.setProperty(name, x, priority);\n }\n return value == null ? styleNull : typeof value === \"function\" ? styleFunction : styleConstant;\n }\n d3_selectionPrototype.property = function(name, value) {\n if (arguments.length < 2) {\n if (typeof name === \"string\") return this.node()[name];\n for (value in name) this.each(d3_selection_property(value, name[value]));\n return this;\n }\n return this.each(d3_selection_property(name, value));\n };\n function d3_selection_property(name, value) {\n function propertyNull() {\n delete this[name];\n }\n function propertyConstant() {\n this[name] = value;\n }\n function propertyFunction() {\n var x = value.apply(this, arguments);\n if (x == null) delete this[name]; else this[name] = x;\n }\n return value == null ? propertyNull : typeof value === \"function\" ? propertyFunction : propertyConstant;\n }\n d3_selectionPrototype.text = function(value) {\n return arguments.length ? this.each(typeof value === \"function\" ? function() {\n var v = value.apply(this, arguments);\n this.textContent = v == null ? \"\" : v;\n } : value == null ? function() {\n this.textContent = \"\";\n } : function() {\n this.textContent = value;\n }) : this.node().textContent;\n };\n d3_selectionPrototype.html = function(value) {\n return arguments.length ? this.each(typeof value === \"function\" ? function() {\n var v = value.apply(this, arguments);\n this.innerHTML = v == null ? \"\" : v;\n } : value == null ? function() {\n this.innerHTML = \"\";\n } : function() {\n this.innerHTML = value;\n }) : this.node().innerHTML;\n };\n d3_selectionPrototype.append = function(name) {\n name = d3_selection_creator(name);\n return this.select(function() {\n return this.appendChild(name.apply(this, arguments));\n });\n };\n function d3_selection_creator(name) {\n function create() {\n var document = this.ownerDocument, namespace = this.namespaceURI;\n return namespace === d3_nsXhtml && document.documentElement.namespaceURI === d3_nsXhtml ? document.createElement(name) : document.createElementNS(namespace, name);\n }\n function createNS() {\n return this.ownerDocument.createElementNS(name.space, name.local);\n }\n return typeof name === \"function\" ? name : (name = d3.ns.qualify(name)).local ? createNS : create;\n }\n d3_selectionPrototype.insert = function(name, before) {\n name = d3_selection_creator(name);\n before = d3_selection_selector(before);\n return this.select(function() {\n return this.insertBefore(name.apply(this, arguments), before.apply(this, arguments) || null);\n });\n };\n d3_selectionPrototype.remove = function() {\n return this.each(d3_selectionRemove);\n };\n function d3_selectionRemove() {\n var parent = this.parentNode;\n if (parent) parent.removeChild(this);\n }\n d3_selectionPrototype.data = function(value, key) {\n var i = -1, n = this.length, group, node;\n if (!arguments.length) {\n value = new Array(n = (group = this[0]).length);\n while (++i < n) {\n if (node = group[i]) {\n value[i] = node.__data__;\n }\n }\n return value;\n }\n function bind(group, groupData) {\n var i, n = group.length, m = groupData.length, n0 = Math.min(n, m), updateNodes = new Array(m), enterNodes = new Array(m), exitNodes = new Array(n), node, nodeData;\n if (key) {\n var nodeByKeyValue = new d3_Map(), keyValues = new Array(n), keyValue;\n for (i = -1; ++i < n; ) {\n if (node = group[i]) {\n if (nodeByKeyValue.has(keyValue = key.call(node, node.__data__, i))) {\n exitNodes[i] = node;\n } else {\n nodeByKeyValue.set(keyValue, node);\n }\n keyValues[i] = keyValue;\n }\n }\n for (i = -1; ++i < m; ) {\n if (!(node = nodeByKeyValue.get(keyValue = key.call(groupData, nodeData = groupData[i], i)))) {\n enterNodes[i] = d3_selection_dataNode(nodeData);\n } else if (node !== true) {\n updateNodes[i] = node;\n node.__data__ = nodeData;\n }\n nodeByKeyValue.set(keyValue, true);\n }\n for (i = -1; ++i < n; ) {\n if (i in keyValues && nodeByKeyValue.get(keyValues[i]) !== true) {\n exitNodes[i] = group[i];\n }\n }\n } else {\n for (i = -1; ++i < n0; ) {\n node = group[i];\n nodeData = groupData[i];\n if (node) {\n node.__data__ = nodeData;\n updateNodes[i] = node;\n } else {\n enterNodes[i] = d3_selection_dataNode(nodeData);\n }\n }\n for (;i < m; ++i) {\n enterNodes[i] = d3_selection_dataNode(groupData[i]);\n }\n for (;i < n; ++i) {\n exitNodes[i] = group[i];\n }\n }\n enterNodes.update = updateNodes;\n enterNodes.parentNode = updateNodes.parentNode = exitNodes.parentNode = group.parentNode;\n enter.push(enterNodes);\n update.push(updateNodes);\n exit.push(exitNodes);\n }\n var enter = d3_selection_enter([]), update = d3_selection([]), exit = d3_selection([]);\n if (typeof value === \"function\") {\n while (++i < n) {\n bind(group = this[i], value.call(group, group.parentNode.__data__, i));\n }\n } else {\n while (++i < n) {\n bind(group = this[i], value);\n }\n }\n update.enter = function() {\n return enter;\n };\n update.exit = function() {\n return exit;\n };\n return update;\n };\n function d3_selection_dataNode(data) {\n return {\n __data__: data\n };\n }\n d3_selectionPrototype.datum = function(value) {\n return arguments.length ? this.property(\"__data__\", value) : this.property(\"__data__\");\n };\n d3_selectionPrototype.filter = function(filter) {\n var subgroups = [], subgroup, group, node;\n if (typeof filter !== \"function\") filter = d3_selection_filter(filter);\n for (var j = 0, m = this.length; j < m; j++) {\n subgroups.push(subgroup = []);\n subgroup.parentNode = (group = this[j]).parentNode;\n for (var i = 0, n = group.length; i < n; i++) {\n if ((node = group[i]) && filter.call(node, node.__data__, i, j)) {\n subgroup.push(node);\n }\n }\n }\n return d3_selection(subgroups);\n };\n function d3_selection_filter(selector) {\n return function() {\n return d3_selectMatches(this, selector);\n };\n }\n d3_selectionPrototype.order = function() {\n for (var j = -1, m = this.length; ++j < m; ) {\n for (var group = this[j], i = group.length - 1, next = group[i], node; --i >= 0; ) {\n if (node = group[i]) {\n if (next && next !== node.nextSibling) next.parentNode.insertBefore(node, next);\n next = node;\n }\n }\n }\n return this;\n };\n d3_selectionPrototype.sort = function(comparator) {\n comparator = d3_selection_sortComparator.apply(this, arguments);\n for (var j = -1, m = this.length; ++j < m; ) this[j].sort(comparator);\n return this.order();\n };\n function d3_selection_sortComparator(comparator) {\n if (!arguments.length) comparator = d3_ascending;\n return function(a, b) {\n return a && b ? comparator(a.__data__, b.__data__) : !a - !b;\n };\n }\n d3_selectionPrototype.each = function(callback) {\n return d3_selection_each(this, function(node, i, j) {\n callback.call(node, node.__data__, i, j);\n });\n };\n function d3_selection_each(groups, callback) {\n for (var j = 0, m = groups.length; j < m; j++) {\n for (var group = groups[j], i = 0, n = group.length, node; i < n; i++) {\n if (node = group[i]) callback(node, i, j);\n }\n }\n return groups;\n }\n d3_selectionPrototype.call = function(callback) {\n var args = d3_array(arguments);\n callback.apply(args[0] = this, args);\n return this;\n };\n d3_selectionPrototype.empty = function() {\n return !this.node();\n };\n d3_selectionPrototype.node = function() {\n for (var j = 0, m = this.length; j < m; j++) {\n for (var group = this[j], i = 0, n = group.length; i < n; i++) {\n var node = group[i];\n if (node) return node;\n }\n }\n return null;\n };\n d3_selectionPrototype.size = function() {\n var n = 0;\n d3_selection_each(this, function() {\n ++n;\n });\n return n;\n };\n function d3_selection_enter(selection) {\n d3_subclass(selection, d3_selection_enterPrototype);\n return selection;\n }\n var d3_selection_enterPrototype = [];\n d3.selection.enter = d3_selection_enter;\n d3.selection.enter.prototype = d3_selection_enterPrototype;\n d3_selection_enterPrototype.append = d3_selectionPrototype.append;\n d3_selection_enterPrototype.empty = d3_selectionPrototype.empty;\n d3_selection_enterPrototype.node = d3_selectionPrototype.node;\n d3_selection_enterPrototype.call = d3_selectionPrototype.call;\n d3_selection_enterPrototype.size = d3_selectionPrototype.size;\n d3_selection_enterPrototype.select = function(selector) {\n var subgroups = [], subgroup, subnode, upgroup, group, node;\n for (var j = -1, m = this.length; ++j < m; ) {\n upgroup = (group = this[j]).update;\n subgroups.push(subgroup = []);\n subgroup.parentNode = group.parentNode;\n for (var i = -1, n = group.length; ++i < n; ) {\n if (node = group[i]) {\n subgroup.push(upgroup[i] = subnode = selector.call(group.parentNode, node.__data__, i, j));\n subnode.__data__ = node.__data__;\n } else {\n subgroup.push(null);\n }\n }\n }\n return d3_selection(subgroups);\n };\n d3_selection_enterPrototype.insert = function(name, before) {\n if (arguments.length < 2) before = d3_selection_enterInsertBefore(this);\n return d3_selectionPrototype.insert.call(this, name, before);\n };\n function d3_selection_enterInsertBefore(enter) {\n var i0, j0;\n return function(d, i, j) {\n var group = enter[j].update, n = group.length, node;\n if (j != j0) j0 = j, i0 = 0;\n if (i >= i0) i0 = i + 1;\n while (!(node = group[i0]) && ++i0 < n) ;\n return node;\n };\n }\n d3.select = function(node) {\n var group;\n if (typeof node === \"string\") {\n group = [ d3_select(node, d3_document) ];\n group.parentNode = d3_document.documentElement;\n } else {\n group = [ node ];\n group.parentNode = d3_documentElement(node);\n }\n return d3_selection([ group ]);\n };\n d3.selectAll = function(nodes) {\n var group;\n if (typeof nodes === \"string\") {\n group = d3_array(d3_selectAll(nodes, d3_document));\n group.parentNode = d3_document.documentElement;\n } else {\n group = d3_array(nodes);\n group.parentNode = null;\n }\n return d3_selection([ group ]);\n };\n d3_selectionPrototype.on = function(type, listener, capture) {\n var n = arguments.length;\n if (n < 3) {\n if (typeof type !== \"string\") {\n if (n < 2) listener = false;\n for (capture in type) this.each(d3_selection_on(capture, type[capture], listener));\n return this;\n }\n if (n < 2) return (n = this.node()[\"__on\" + type]) && n._;\n capture = false;\n }\n return this.each(d3_selection_on(type, listener, capture));\n };\n function d3_selection_on(type, listener, capture) {\n var name = \"__on\" + type, i = type.indexOf(\".\"), wrap = d3_selection_onListener;\n if (i > 0) type = type.slice(0, i);\n var filter = d3_selection_onFilters.get(type);\n if (filter) type = filter, wrap = d3_selection_onFilter;\n function onRemove() {\n var l = this[name];\n if (l) {\n this.removeEventListener(type, l, l.$);\n delete this[name];\n }\n }\n function onAdd() {\n var l = wrap(listener, d3_array(arguments));\n onRemove.call(this);\n this.addEventListener(type, this[name] = l, l.$ = capture);\n l._ = listener;\n }\n function removeAll() {\n var re = new RegExp(\"^__on([^.]+)\" + d3.requote(type) + \"$\"), match;\n for (var name in this) {\n if (match = name.match(re)) {\n var l = this[name];\n this.removeEventListener(match[1], l, l.$);\n delete this[name];\n }\n }\n }\n return i ? listener ? onAdd : onRemove : listener ? d3_noop : removeAll;\n }\n var d3_selection_onFilters = d3.map({\n mouseenter: \"mouseover\",\n mouseleave: \"mouseout\"\n });\n if (d3_document) {\n d3_selection_onFilters.forEach(function(k) {\n if (\"on\" + k in d3_document) d3_selection_onFilters.remove(k);\n });\n }\n function d3_selection_onListener(listener, argumentz) {\n return function(e) {\n var o = d3.event;\n d3.event = e;\n argumentz[0] = this.__data__;\n try {\n listener.apply(this, argumentz);\n } finally {\n d3.event = o;\n }\n };\n }\n function d3_selection_onFilter(listener, argumentz) {\n var l = d3_selection_onListener(listener, argumentz);\n return function(e) {\n var target = this, related = e.relatedTarget;\n if (!related || related !== target && !(related.compareDocumentPosition(target) & 8)) {\n l.call(target, e);\n }\n };\n }\n var d3_event_dragSelect, d3_event_dragId = 0;\n function d3_event_dragSuppress(node) {\n var name = \".dragsuppress-\" + ++d3_event_dragId, click = \"click\" + name, w = d3.select(d3_window(node)).on(\"touchmove\" + name, d3_eventPreventDefault).on(\"dragstart\" + name, d3_eventPreventDefault).on(\"selectstart\" + name, d3_eventPreventDefault);\n if (d3_event_dragSelect == null) {\n d3_event_dragSelect = \"onselectstart\" in node ? false : d3_vendorSymbol(node.style, \"userSelect\");\n }\n if (d3_event_dragSelect) {\n var style = d3_documentElement(node).style, select = style[d3_event_dragSelect];\n style[d3_event_dragSelect] = \"none\";\n }\n return function(suppressClick) {\n w.on(name, null);\n if (d3_event_dragSelect) style[d3_event_dragSelect] = select;\n if (suppressClick) {\n var off = function() {\n w.on(click, null);\n };\n w.on(click, function() {\n d3_eventPreventDefault();\n off();\n }, true);\n setTimeout(off, 0);\n }\n };\n }\n d3.mouse = function(container) {\n return d3_mousePoint(container, d3_eventSource());\n };\n var d3_mouse_bug44083 = this.navigator && /WebKit/.test(this.navigator.userAgent) ? -1 : 0;\n function d3_mousePoint(container, e) {\n if (e.changedTouches) e = e.changedTouches[0];\n var svg = container.ownerSVGElement || container;\n if (svg.createSVGPoint) {\n var point = svg.createSVGPoint();\n if (d3_mouse_bug44083 < 0) {\n var window = d3_window(container);\n if (window.scrollX || window.scrollY) {\n svg = d3.select(\"body\").append(\"svg\").style({\n position: \"absolute\",\n top: 0,\n left: 0,\n margin: 0,\n padding: 0,\n border: \"none\"\n }, \"important\");\n var ctm = svg[0][0].getScreenCTM();\n d3_mouse_bug44083 = !(ctm.f || ctm.e);\n svg.remove();\n }\n }\n if (d3_mouse_bug44083) point.x = e.pageX, point.y = e.pageY; else point.x = e.clientX, \n point.y = e.clientY;\n point = point.matrixTransform(container.getScreenCTM().inverse());\n return [ point.x, point.y ];\n }\n var rect = container.getBoundingClientRect();\n return [ e.clientX - rect.left - container.clientLeft, e.clientY - rect.top - container.clientTop ];\n }\n d3.touch = function(container, touches, identifier) {\n if (arguments.length < 3) identifier = touches, touches = d3_eventSource().changedTouches;\n if (touches) for (var i = 0, n = touches.length, touch; i < n; ++i) {\n if ((touch = touches[i]).identifier === identifier) {\n return d3_mousePoint(container, touch);\n }\n }\n };\n d3.behavior.drag = function() {\n var event = d3_eventDispatch(drag, \"drag\", \"dragstart\", \"dragend\"), origin = null, mousedown = dragstart(d3_noop, d3.mouse, d3_window, \"mousemove\", \"mouseup\"), touchstart = dragstart(d3_behavior_dragTouchId, d3.touch, d3_identity, \"touchmove\", \"touchend\");\n function drag() {\n this.on(\"mousedown.drag\", mousedown).on(\"touchstart.drag\", touchstart);\n }\n function dragstart(id, position, subject, move, end) {\n return function() {\n var that = this, target = d3.event.target.correspondingElement || d3.event.target, parent = that.parentNode, dispatch = event.of(that, arguments), dragged = 0, dragId = id(), dragName = \".drag\" + (dragId == null ? \"\" : \"-\" + dragId), dragOffset, dragSubject = d3.select(subject(target)).on(move + dragName, moved).on(end + dragName, ended), dragRestore = d3_event_dragSuppress(target), position0 = position(parent, dragId);\n if (origin) {\n dragOffset = origin.apply(that, arguments);\n dragOffset = [ dragOffset.x - position0[0], dragOffset.y - position0[1] ];\n } else {\n dragOffset = [ 0, 0 ];\n }\n dispatch({\n type: \"dragstart\"\n });\n function moved() {\n var position1 = position(parent, dragId), dx, dy;\n if (!position1) return;\n dx = position1[0] - position0[0];\n dy = position1[1] - position0[1];\n dragged |= dx | dy;\n position0 = position1;\n dispatch({\n type: \"drag\",\n x: position1[0] + dragOffset[0],\n y: position1[1] + dragOffset[1],\n dx: dx,\n dy: dy\n });\n }\n function ended() {\n if (!position(parent, dragId)) return;\n dragSubject.on(move + dragName, null).on(end + dragName, null);\n dragRestore(dragged);\n dispatch({\n type: \"dragend\"\n });\n }\n };\n }\n drag.origin = function(x) {\n if (!arguments.length) return origin;\n origin = x;\n return drag;\n };\n return d3.rebind(drag, event, \"on\");\n };\n function d3_behavior_dragTouchId() {\n return d3.event.changedTouches[0].identifier;\n }\n d3.touches = function(container, touches) {\n if (arguments.length < 2) touches = d3_eventSource().touches;\n return touches ? d3_array(touches).map(function(touch) {\n var point = d3_mousePoint(container, touch);\n point.identifier = touch.identifier;\n return point;\n }) : [];\n };\n var ε = 1e-6, ε2 = ε * ε, π = Math.PI, τ = 2 * π, τε = τ - ε, halfπ = π / 2, d3_radians = π / 180, d3_degrees = 180 / π;\n function d3_sgn(x) {\n return x > 0 ? 1 : x < 0 ? -1 : 0;\n }\n function d3_cross2d(a, b, c) {\n return (b[0] - a[0]) * (c[1] - a[1]) - (b[1] - a[1]) * (c[0] - a[0]);\n }\n function d3_acos(x) {\n return x > 1 ? 0 : x < -1 ? π : Math.acos(x);\n }\n function d3_asin(x) {\n return x > 1 ? halfπ : x < -1 ? -halfπ : Math.asin(x);\n }\n function d3_sinh(x) {\n return ((x = Math.exp(x)) - 1 / x) / 2;\n }\n function d3_cosh(x) {\n return ((x = Math.exp(x)) + 1 / x) / 2;\n }\n function d3_tanh(x) {\n return ((x = Math.exp(2 * x)) - 1) / (x + 1);\n }\n function d3_haversin(x) {\n return (x = Math.sin(x / 2)) * x;\n }\n var ρ = Math.SQRT2, ρ2 = 2, ρ4 = 4;\n d3.interpolateZoom = function(p0, p1) {\n var ux0 = p0[0], uy0 = p0[1], w0 = p0[2], ux1 = p1[0], uy1 = p1[1], w1 = p1[2], dx = ux1 - ux0, dy = uy1 - uy0, d2 = dx * dx + dy * dy, i, S;\n if (d2 < ε2) {\n S = Math.log(w1 / w0) / ρ;\n i = function(t) {\n return [ ux0 + t * dx, uy0 + t * dy, w0 * Math.exp(ρ * t * S) ];\n };\n } else {\n var d1 = Math.sqrt(d2), b0 = (w1 * w1 - w0 * w0 + ρ4 * d2) / (2 * w0 * ρ2 * d1), b1 = (w1 * w1 - w0 * w0 - ρ4 * d2) / (2 * w1 * ρ2 * d1), r0 = Math.log(Math.sqrt(b0 * b0 + 1) - b0), r1 = Math.log(Math.sqrt(b1 * b1 + 1) - b1);\n S = (r1 - r0) / ρ;\n i = function(t) {\n var s = t * S, coshr0 = d3_cosh(r0), u = w0 / (ρ2 * d1) * (coshr0 * d3_tanh(ρ * s + r0) - d3_sinh(r0));\n return [ ux0 + u * dx, uy0 + u * dy, w0 * coshr0 / d3_cosh(ρ * s + r0) ];\n };\n }\n i.duration = S * 1e3;\n return i;\n };\n d3.behavior.zoom = function() {\n var view = {\n x: 0,\n y: 0,\n k: 1\n }, translate0, center0, center, size = [ 960, 500 ], scaleExtent = d3_behavior_zoomInfinity, duration = 250, zooming = 0, mousedown = \"mousedown.zoom\", mousemove = \"mousemove.zoom\", mouseup = \"mouseup.zoom\", mousewheelTimer, touchstart = \"touchstart.zoom\", touchtime, event = d3_eventDispatch(zoom, \"zoomstart\", \"zoom\", \"zoomend\"), x0, x1, y0, y1;\n if (!d3_behavior_zoomWheel) {\n d3_behavior_zoomWheel = \"onwheel\" in d3_document ? (d3_behavior_zoomDelta = function() {\n return -d3.event.deltaY * (d3.event.deltaMode ? 120 : 1);\n }, \"wheel\") : \"onmousewheel\" in d3_document ? (d3_behavior_zoomDelta = function() {\n return d3.event.wheelDelta;\n }, \"mousewheel\") : (d3_behavior_zoomDelta = function() {\n return -d3.event.detail;\n }, \"MozMousePixelScroll\");\n }\n function zoom(g) {\n g.on(mousedown, mousedowned).on(d3_behavior_zoomWheel + \".zoom\", mousewheeled).on(\"dblclick.zoom\", dblclicked).on(touchstart, touchstarted);\n }\n zoom.event = function(g) {\n g.each(function() {\n var dispatch = event.of(this, arguments), view1 = view;\n if (d3_transitionInheritId) {\n d3.select(this).transition().each(\"start.zoom\", function() {\n view = this.__chart__ || {\n x: 0,\n y: 0,\n k: 1\n };\n zoomstarted(dispatch);\n }).tween(\"zoom:zoom\", function() {\n var dx = size[0], dy = size[1], cx = center0 ? center0[0] : dx / 2, cy = center0 ? center0[1] : dy / 2, i = d3.interpolateZoom([ (cx - view.x) / view.k, (cy - view.y) / view.k, dx / view.k ], [ (cx - view1.x) / view1.k, (cy - view1.y) / view1.k, dx / view1.k ]);\n return function(t) {\n var l = i(t), k = dx / l[2];\n this.__chart__ = view = {\n x: cx - l[0] * k,\n y: cy - l[1] * k,\n k: k\n };\n zoomed(dispatch);\n };\n }).each(\"interrupt.zoom\", function() {\n zoomended(dispatch);\n }).each(\"end.zoom\", function() {\n zoomended(dispatch);\n });\n } else {\n this.__chart__ = view;\n zoomstarted(dispatch);\n zoomed(dispatch);\n zoomended(dispatch);\n }\n });\n };\n zoom.translate = function(_) {\n if (!arguments.length) return [ view.x, view.y ];\n view = {\n x: +_[0],\n y: +_[1],\n k: view.k\n };\n rescale();\n return zoom;\n };\n zoom.scale = function(_) {\n if (!arguments.length) return view.k;\n view = {\n x: view.x,\n y: view.y,\n k: null\n };\n scaleTo(+_);\n rescale();\n return zoom;\n };\n zoom.scaleExtent = function(_) {\n if (!arguments.length) return scaleExtent;\n scaleExtent = _ == null ? d3_behavior_zoomInfinity : [ +_[0], +_[1] ];\n return zoom;\n };\n zoom.center = function(_) {\n if (!arguments.length) return center;\n center = _ && [ +_[0], +_[1] ];\n return zoom;\n };\n zoom.size = function(_) {\n if (!arguments.length) return size;\n size = _ && [ +_[0], +_[1] ];\n return zoom;\n };\n zoom.duration = function(_) {\n if (!arguments.length) return duration;\n duration = +_;\n return zoom;\n };\n zoom.x = function(z) {\n if (!arguments.length) return x1;\n x1 = z;\n x0 = z.copy();\n view = {\n x: 0,\n y: 0,\n k: 1\n };\n return zoom;\n };\n zoom.y = function(z) {\n if (!arguments.length) return y1;\n y1 = z;\n y0 = z.copy();\n view = {\n x: 0,\n y: 0,\n k: 1\n };\n return zoom;\n };\n function location(p) {\n return [ (p[0] - view.x) / view.k, (p[1] - view.y) / view.k ];\n }\n function point(l) {\n return [ l[0] * view.k + view.x, l[1] * view.k + view.y ];\n }\n function scaleTo(s) {\n view.k = Math.max(scaleExtent[0], Math.min(scaleExtent[1], s));\n }\n function translateTo(p, l) {\n l = point(l);\n view.x += p[0] - l[0];\n view.y += p[1] - l[1];\n }\n function zoomTo(that, p, l, k) {\n that.__chart__ = {\n x: view.x,\n y: view.y,\n k: view.k\n };\n scaleTo(Math.pow(2, k));\n translateTo(center0 = p, l);\n that = d3.select(that);\n if (duration > 0) that = that.transition().duration(duration);\n that.call(zoom.event);\n }\n function rescale() {\n if (x1) x1.domain(x0.range().map(function(x) {\n return (x - view.x) / view.k;\n }).map(x0.invert));\n if (y1) y1.domain(y0.range().map(function(y) {\n return (y - view.y) / view.k;\n }).map(y0.invert));\n }\n function zoomstarted(dispatch) {\n if (!zooming++) dispatch({\n type: \"zoomstart\"\n });\n }\n function zoomed(dispatch) {\n rescale();\n dispatch({\n type: \"zoom\",\n scale: view.k,\n translate: [ view.x, view.y ]\n });\n }\n function zoomended(dispatch) {\n if (!--zooming) dispatch({\n type: \"zoomend\"\n }), center0 = null;\n }\n function mousedowned() {\n var that = this, dispatch = event.of(that, arguments), dragged = 0, subject = d3.select(d3_window(that)).on(mousemove, moved).on(mouseup, ended), location0 = location(d3.mouse(that)), dragRestore = d3_event_dragSuppress(that);\n d3_selection_interrupt.call(that);\n zoomstarted(dispatch);\n function moved() {\n dragged = 1;\n translateTo(d3.mouse(that), location0);\n zoomed(dispatch);\n }\n function ended() {\n subject.on(mousemove, null).on(mouseup, null);\n dragRestore(dragged);\n zoomended(dispatch);\n }\n }\n function touchstarted() {\n var that = this, dispatch = event.of(that, arguments), locations0 = {}, distance0 = 0, scale0, zoomName = \".zoom-\" + d3.event.changedTouches[0].identifier, touchmove = \"touchmove\" + zoomName, touchend = \"touchend\" + zoomName, targets = [], subject = d3.select(that), dragRestore = d3_event_dragSuppress(that);\n started();\n zoomstarted(dispatch);\n subject.on(mousedown, null).on(touchstart, started);\n function relocate() {\n var touches = d3.touches(that);\n scale0 = view.k;\n touches.forEach(function(t) {\n if (t.identifier in locations0) locations0[t.identifier] = location(t);\n });\n return touches;\n }\n function started() {\n var target = d3.event.target;\n d3.select(target).on(touchmove, moved).on(touchend, ended);\n targets.push(target);\n var changed = d3.event.changedTouches;\n for (var i = 0, n = changed.length; i < n; ++i) {\n locations0[changed[i].identifier] = null;\n }\n var touches = relocate(), now = Date.now();\n if (touches.length === 1) {\n if (now - touchtime < 500) {\n var p = touches[0];\n zoomTo(that, p, locations0[p.identifier], Math.floor(Math.log(view.k) / Math.LN2) + 1);\n d3_eventPreventDefault();\n }\n touchtime = now;\n } else if (touches.length > 1) {\n var p = touches[0], q = touches[1], dx = p[0] - q[0], dy = p[1] - q[1];\n distance0 = dx * dx + dy * dy;\n }\n }\n function moved() {\n var touches = d3.touches(that), p0, l0, p1, l1;\n d3_selection_interrupt.call(that);\n for (var i = 0, n = touches.length; i < n; ++i, l1 = null) {\n p1 = touches[i];\n if (l1 = locations0[p1.identifier]) {\n if (l0) break;\n p0 = p1, l0 = l1;\n }\n }\n if (l1) {\n var distance1 = (distance1 = p1[0] - p0[0]) * distance1 + (distance1 = p1[1] - p0[1]) * distance1, scale1 = distance0 && Math.sqrt(distance1 / distance0);\n p0 = [ (p0[0] + p1[0]) / 2, (p0[1] + p1[1]) / 2 ];\n l0 = [ (l0[0] + l1[0]) / 2, (l0[1] + l1[1]) / 2 ];\n scaleTo(scale1 * scale0);\n }\n touchtime = null;\n translateTo(p0, l0);\n zoomed(dispatch);\n }\n function ended() {\n if (d3.event.touches.length) {\n var changed = d3.event.changedTouches;\n for (var i = 0, n = changed.length; i < n; ++i) {\n delete locations0[changed[i].identifier];\n }\n for (var identifier in locations0) {\n return void relocate();\n }\n }\n d3.selectAll(targets).on(zoomName, null);\n subject.on(mousedown, mousedowned).on(touchstart, touchstarted);\n dragRestore();\n zoomended(dispatch);\n }\n }\n function mousewheeled() {\n var dispatch = event.of(this, arguments);\n if (mousewheelTimer) clearTimeout(mousewheelTimer); else d3_selection_interrupt.call(this), \n translate0 = location(center0 = center || d3.mouse(this)), zoomstarted(dispatch);\n mousewheelTimer = setTimeout(function() {\n mousewheelTimer = null;\n zoomended(dispatch);\n }, 50);\n d3_eventPreventDefault();\n scaleTo(Math.pow(2, d3_behavior_zoomDelta() * .002) * view.k);\n translateTo(center0, translate0);\n zoomed(dispatch);\n }\n function dblclicked() {\n var p = d3.mouse(this), k = Math.log(view.k) / Math.LN2;\n zoomTo(this, p, location(p), d3.event.shiftKey ? Math.ceil(k) - 1 : Math.floor(k) + 1);\n }\n return d3.rebind(zoom, event, \"on\");\n };\n var d3_behavior_zoomInfinity = [ 0, Infinity ], d3_behavior_zoomDelta, d3_behavior_zoomWheel;\n d3.color = d3_color;\n function d3_color() {}\n d3_color.prototype.toString = function() {\n return this.rgb() + \"\";\n };\n d3.hsl = d3_hsl;\n function d3_hsl(h, s, l) {\n return this instanceof d3_hsl ? void (this.h = +h, this.s = +s, this.l = +l) : arguments.length < 2 ? h instanceof d3_hsl ? new d3_hsl(h.h, h.s, h.l) : d3_rgb_parse(\"\" + h, d3_rgb_hsl, d3_hsl) : new d3_hsl(h, s, l);\n }\n var d3_hslPrototype = d3_hsl.prototype = new d3_color();\n d3_hslPrototype.brighter = function(k) {\n k = Math.pow(.7, arguments.length ? k : 1);\n return new d3_hsl(this.h, this.s, this.l / k);\n };\n d3_hslPrototype.darker = function(k) {\n k = Math.pow(.7, arguments.length ? k : 1);\n return new d3_hsl(this.h, this.s, k * this.l);\n };\n d3_hslPrototype.rgb = function() {\n return d3_hsl_rgb(this.h, this.s, this.l);\n };\n function d3_hsl_rgb(h, s, l) {\n var m1, m2;\n h = isNaN(h) ? 0 : (h %= 360) < 0 ? h + 360 : h;\n s = isNaN(s) ? 0 : s < 0 ? 0 : s > 1 ? 1 : s;\n l = l < 0 ? 0 : l > 1 ? 1 : l;\n m2 = l <= .5 ? l * (1 + s) : l + s - l * s;\n m1 = 2 * l - m2;\n function v(h) {\n if (h > 360) h -= 360; else if (h < 0) h += 360;\n if (h < 60) return m1 + (m2 - m1) * h / 60;\n if (h < 180) return m2;\n if (h < 240) return m1 + (m2 - m1) * (240 - h) / 60;\n return m1;\n }\n function vv(h) {\n return Math.round(v(h) * 255);\n }\n return new d3_rgb(vv(h + 120), vv(h), vv(h - 120));\n }\n d3.hcl = d3_hcl;\n function d3_hcl(h, c, l) {\n return this instanceof d3_hcl ? void (this.h = +h, this.c = +c, this.l = +l) : arguments.length < 2 ? h instanceof d3_hcl ? new d3_hcl(h.h, h.c, h.l) : h instanceof d3_lab ? d3_lab_hcl(h.l, h.a, h.b) : d3_lab_hcl((h = d3_rgb_lab((h = d3.rgb(h)).r, h.g, h.b)).l, h.a, h.b) : new d3_hcl(h, c, l);\n }\n var d3_hclPrototype = d3_hcl.prototype = new d3_color();\n d3_hclPrototype.brighter = function(k) {\n return new d3_hcl(this.h, this.c, Math.min(100, this.l + d3_lab_K * (arguments.length ? k : 1)));\n };\n d3_hclPrototype.darker = function(k) {\n return new d3_hcl(this.h, this.c, Math.max(0, this.l - d3_lab_K * (arguments.length ? k : 1)));\n };\n d3_hclPrototype.rgb = function() {\n return d3_hcl_lab(this.h, this.c, this.l).rgb();\n };\n function d3_hcl_lab(h, c, l) {\n if (isNaN(h)) h = 0;\n if (isNaN(c)) c = 0;\n return new d3_lab(l, Math.cos(h *= d3_radians) * c, Math.sin(h) * c);\n }\n d3.lab = d3_lab;\n function d3_lab(l, a, b) {\n return this instanceof d3_lab ? void (this.l = +l, this.a = +a, this.b = +b) : arguments.length < 2 ? l instanceof d3_lab ? new d3_lab(l.l, l.a, l.b) : l instanceof d3_hcl ? d3_hcl_lab(l.h, l.c, l.l) : d3_rgb_lab((l = d3_rgb(l)).r, l.g, l.b) : new d3_lab(l, a, b);\n }\n var d3_lab_K = 18;\n var d3_lab_X = .95047, d3_lab_Y = 1, d3_lab_Z = 1.08883;\n var d3_labPrototype = d3_lab.prototype = new d3_color();\n d3_labPrototype.brighter = function(k) {\n return new d3_lab(Math.min(100, this.l + d3_lab_K * (arguments.length ? k : 1)), this.a, this.b);\n };\n d3_labPrototype.darker = function(k) {\n return new d3_lab(Math.max(0, this.l - d3_lab_K * (arguments.length ? k : 1)), this.a, this.b);\n };\n d3_labPrototype.rgb = function() {\n return d3_lab_rgb(this.l, this.a, this.b);\n };\n function d3_lab_rgb(l, a, b) {\n var y = (l + 16) / 116, x = y + a / 500, z = y - b / 200;\n x = d3_lab_xyz(x) * d3_lab_X;\n y = d3_lab_xyz(y) * d3_lab_Y;\n z = d3_lab_xyz(z) * d3_lab_Z;\n return new d3_rgb(d3_xyz_rgb(3.2404542 * x - 1.5371385 * y - .4985314 * z), d3_xyz_rgb(-.969266 * x + 1.8760108 * y + .041556 * z), d3_xyz_rgb(.0556434 * x - .2040259 * y + 1.0572252 * z));\n }\n function d3_lab_hcl(l, a, b) {\n return l > 0 ? new d3_hcl(Math.atan2(b, a) * d3_degrees, Math.sqrt(a * a + b * b), l) : new d3_hcl(NaN, NaN, l);\n }\n function d3_lab_xyz(x) {\n return x > .206893034 ? x * x * x : (x - 4 / 29) / 7.787037;\n }\n function d3_xyz_lab(x) {\n return x > .008856 ? Math.pow(x, 1 / 3) : 7.787037 * x + 4 / 29;\n }\n function d3_xyz_rgb(r) {\n return Math.round(255 * (r <= .00304 ? 12.92 * r : 1.055 * Math.pow(r, 1 / 2.4) - .055));\n }\n d3.rgb = d3_rgb;\n function d3_rgb(r, g, b) {\n return this instanceof d3_rgb ? void (this.r = ~~r, this.g = ~~g, this.b = ~~b) : arguments.length < 2 ? r instanceof d3_rgb ? new d3_rgb(r.r, r.g, r.b) : d3_rgb_parse(\"\" + r, d3_rgb, d3_hsl_rgb) : new d3_rgb(r, g, b);\n }\n function d3_rgbNumber(value) {\n return new d3_rgb(value >> 16, value >> 8 & 255, value & 255);\n }\n function d3_rgbString(value) {\n return d3_rgbNumber(value) + \"\";\n }\n var d3_rgbPrototype = d3_rgb.prototype = new d3_color();\n d3_rgbPrototype.brighter = function(k) {\n k = Math.pow(.7, arguments.length ? k : 1);\n var r = this.r, g = this.g, b = this.b, i = 30;\n if (!r && !g && !b) return new d3_rgb(i, i, i);\n if (r && r < i) r = i;\n if (g && g < i) g = i;\n if (b && b < i) b = i;\n return new d3_rgb(Math.min(255, r / k), Math.min(255, g / k), Math.min(255, b / k));\n };\n d3_rgbPrototype.darker = function(k) {\n k = Math.pow(.7, arguments.length ? k : 1);\n return new d3_rgb(k * this.r, k * this.g, k * this.b);\n };\n d3_rgbPrototype.hsl = function() {\n return d3_rgb_hsl(this.r, this.g, this.b);\n };\n d3_rgbPrototype.toString = function() {\n return \"#\" + d3_rgb_hex(this.r) + d3_rgb_hex(this.g) + d3_rgb_hex(this.b);\n };\n function d3_rgb_hex(v) {\n return v < 16 ? \"0\" + Math.max(0, v).toString(16) : Math.min(255, v).toString(16);\n }\n function d3_rgb_parse(format, rgb, hsl) {\n var r = 0, g = 0, b = 0, m1, m2, color;\n m1 = /([a-z]+)\\((.*)\\)/.exec(format = format.toLowerCase());\n if (m1) {\n m2 = m1[2].split(\",\");\n switch (m1[1]) {\n case \"hsl\":\n {\n return hsl(parseFloat(m2[0]), parseFloat(m2[1]) / 100, parseFloat(m2[2]) / 100);\n }\n\n case \"rgb\":\n {\n return rgb(d3_rgb_parseNumber(m2[0]), d3_rgb_parseNumber(m2[1]), d3_rgb_parseNumber(m2[2]));\n }\n }\n }\n if (color = d3_rgb_names.get(format)) {\n return rgb(color.r, color.g, color.b);\n }\n if (format != null && format.charAt(0) === \"#\" && !isNaN(color = parseInt(format.slice(1), 16))) {\n if (format.length === 4) {\n r = (color & 3840) >> 4;\n r = r >> 4 | r;\n g = color & 240;\n g = g >> 4 | g;\n b = color & 15;\n b = b << 4 | b;\n } else if (format.length === 7) {\n r = (color & 16711680) >> 16;\n g = (color & 65280) >> 8;\n b = color & 255;\n }\n }\n return rgb(r, g, b);\n }\n function d3_rgb_hsl(r, g, b) {\n var min = Math.min(r /= 255, g /= 255, b /= 255), max = Math.max(r, g, b), d = max - min, h, s, l = (max + min) / 2;\n if (d) {\n s = l < .5 ? d / (max + min) : d / (2 - max - min);\n if (r == max) h = (g - b) / d + (g < b ? 6 : 0); else if (g == max) h = (b - r) / d + 2; else h = (r - g) / d + 4;\n h *= 60;\n } else {\n h = NaN;\n s = l > 0 && l < 1 ? 0 : h;\n }\n return new d3_hsl(h, s, l);\n }\n function d3_rgb_lab(r, g, b) {\n r = d3_rgb_xyz(r);\n g = d3_rgb_xyz(g);\n b = d3_rgb_xyz(b);\n var x = d3_xyz_lab((.4124564 * r + .3575761 * g + .1804375 * b) / d3_lab_X), y = d3_xyz_lab((.2126729 * r + .7151522 * g + .072175 * b) / d3_lab_Y), z = d3_xyz_lab((.0193339 * r + .119192 * g + .9503041 * b) / d3_lab_Z);\n return d3_lab(116 * y - 16, 500 * (x - y), 200 * (y - z));\n }\n function d3_rgb_xyz(r) {\n return (r /= 255) <= .04045 ? r / 12.92 : Math.pow((r + .055) / 1.055, 2.4);\n }\n function d3_rgb_parseNumber(c) {\n var f = parseFloat(c);\n return c.charAt(c.length - 1) === \"%\" ? Math.round(f * 2.55) : f;\n }\n var d3_rgb_names = d3.map({\n aliceblue: 15792383,\n antiquewhite: 16444375,\n aqua: 65535,\n aquamarine: 8388564,\n azure: 15794175,\n beige: 16119260,\n bisque: 16770244,\n black: 0,\n blanchedalmond: 16772045,\n blue: 255,\n blueviolet: 9055202,\n brown: 10824234,\n burlywood: 14596231,\n cadetblue: 6266528,\n chartreuse: 8388352,\n chocolate: 13789470,\n coral: 16744272,\n cornflowerblue: 6591981,\n cornsilk: 16775388,\n crimson: 14423100,\n cyan: 65535,\n darkblue: 139,\n darkcyan: 35723,\n darkgoldenrod: 12092939,\n darkgray: 11119017,\n darkgreen: 25600,\n darkgrey: 11119017,\n darkkhaki: 12433259,\n darkmagenta: 9109643,\n darkolivegreen: 5597999,\n darkorange: 16747520,\n darkorchid: 10040012,\n darkred: 9109504,\n darksalmon: 15308410,\n darkseagreen: 9419919,\n darkslateblue: 4734347,\n darkslategray: 3100495,\n darkslategrey: 3100495,\n darkturquoise: 52945,\n darkviolet: 9699539,\n deeppink: 16716947,\n deepskyblue: 49151,\n dimgray: 6908265,\n dimgrey: 6908265,\n dodgerblue: 2003199,\n firebrick: 11674146,\n floralwhite: 16775920,\n forestgreen: 2263842,\n fuchsia: 16711935,\n gainsboro: 14474460,\n ghostwhite: 16316671,\n gold: 16766720,\n goldenrod: 14329120,\n gray: 8421504,\n green: 32768,\n greenyellow: 11403055,\n grey: 8421504,\n honeydew: 15794160,\n hotpink: 16738740,\n indianred: 13458524,\n indigo: 4915330,\n ivory: 16777200,\n khaki: 15787660,\n lavender: 15132410,\n lavenderblush: 16773365,\n lawngreen: 8190976,\n lemonchiffon: 16775885,\n lightblue: 11393254,\n lightcoral: 15761536,\n lightcyan: 14745599,\n lightgoldenrodyellow: 16448210,\n lightgray: 13882323,\n lightgreen: 9498256,\n lightgrey: 13882323,\n lightpink: 16758465,\n lightsalmon: 16752762,\n lightseagreen: 2142890,\n lightskyblue: 8900346,\n lightslategray: 7833753,\n lightslategrey: 7833753,\n lightsteelblue: 11584734,\n lightyellow: 16777184,\n lime: 65280,\n limegreen: 3329330,\n linen: 16445670,\n magenta: 16711935,\n maroon: 8388608,\n mediumaquamarine: 6737322,\n mediumblue: 205,\n mediumorchid: 12211667,\n mediumpurple: 9662683,\n mediumseagreen: 3978097,\n mediumslateblue: 8087790,\n mediumspringgreen: 64154,\n mediumturquoise: 4772300,\n mediumvioletred: 13047173,\n midnightblue: 1644912,\n mintcream: 16121850,\n mistyrose: 16770273,\n moccasin: 16770229,\n navajowhite: 16768685,\n navy: 128,\n oldlace: 16643558,\n olive: 8421376,\n olivedrab: 7048739,\n orange: 16753920,\n orangered: 16729344,\n orchid: 14315734,\n palegoldenrod: 15657130,\n palegreen: 10025880,\n paleturquoise: 11529966,\n palevioletred: 14381203,\n papayawhip: 16773077,\n peachpuff: 16767673,\n peru: 13468991,\n pink: 16761035,\n plum: 14524637,\n powderblue: 11591910,\n purple: 8388736,\n rebeccapurple: 6697881,\n red: 16711680,\n rosybrown: 12357519,\n royalblue: 4286945,\n saddlebrown: 9127187,\n salmon: 16416882,\n sandybrown: 16032864,\n seagreen: 3050327,\n seashell: 16774638,\n sienna: 10506797,\n silver: 12632256,\n skyblue: 8900331,\n slateblue: 6970061,\n slategray: 7372944,\n slategrey: 7372944,\n snow: 16775930,\n springgreen: 65407,\n steelblue: 4620980,\n tan: 13808780,\n teal: 32896,\n thistle: 14204888,\n tomato: 16737095,\n turquoise: 4251856,\n violet: 15631086,\n wheat: 16113331,\n white: 16777215,\n whitesmoke: 16119285,\n yellow: 16776960,\n yellowgreen: 10145074\n });\n d3_rgb_names.forEach(function(key, value) {\n d3_rgb_names.set(key, d3_rgbNumber(value));\n });\n function d3_functor(v) {\n return typeof v === \"function\" ? v : function() {\n return v;\n };\n }\n d3.functor = d3_functor;\n d3.xhr = d3_xhrType(d3_identity);\n function d3_xhrType(response) {\n return function(url, mimeType, callback) {\n if (arguments.length === 2 && typeof mimeType === \"function\") callback = mimeType, \n mimeType = null;\n return d3_xhr(url, mimeType, response, callback);\n };\n }\n function d3_xhr(url, mimeType, response, callback) {\n var xhr = {}, dispatch = d3.dispatch(\"beforesend\", \"progress\", \"load\", \"error\"), headers = {}, request = new XMLHttpRequest(), responseType = null;\n if (self.XDomainRequest && !(\"withCredentials\" in request) && /^(http(s)?:)?\\/\\//.test(url)) request = new XDomainRequest();\n \"onload\" in request ? request.onload = request.onerror = respond : request.onreadystatechange = function() {\n request.readyState > 3 && respond();\n };\n function respond() {\n var status = request.status, result;\n if (!status && d3_xhrHasResponse(request) || status >= 200 && status < 300 || status === 304) {\n try {\n result = response.call(xhr, request);\n } catch (e) {\n dispatch.error.call(xhr, e);\n return;\n }\n dispatch.load.call(xhr, result);\n } else {\n dispatch.error.call(xhr, request);\n }\n }\n request.onprogress = function(event) {\n var o = d3.event;\n d3.event = event;\n try {\n dispatch.progress.call(xhr, request);\n } finally {\n d3.event = o;\n }\n };\n xhr.header = function(name, value) {\n name = (name + \"\").toLowerCase();\n if (arguments.length < 2) return headers[name];\n if (value == null) delete headers[name]; else headers[name] = value + \"\";\n return xhr;\n };\n xhr.mimeType = function(value) {\n if (!arguments.length) return mimeType;\n mimeType = value == null ? null : value + \"\";\n return xhr;\n };\n xhr.responseType = function(value) {\n if (!arguments.length) return responseType;\n responseType = value;\n return xhr;\n };\n xhr.response = function(value) {\n response = value;\n return xhr;\n };\n [ \"get\", \"post\" ].forEach(function(method) {\n xhr[method] = function() {\n return xhr.send.apply(xhr, [ method ].concat(d3_array(arguments)));\n };\n });\n xhr.send = function(method, data, callback) {\n if (arguments.length === 2 && typeof data === \"function\") callback = data, data = null;\n request.open(method, url, true);\n if (mimeType != null && !(\"accept\" in headers)) headers[\"accept\"] = mimeType + \",*/*\";\n if (request.setRequestHeader) for (var name in headers) request.setRequestHeader(name, headers[name]);\n if (mimeType != null && request.overrideMimeType) request.overrideMimeType(mimeType);\n if (responseType != null) request.responseType = responseType;\n if (callback != null) xhr.on(\"error\", callback).on(\"load\", function(request) {\n callback(null, request);\n });\n dispatch.beforesend.call(xhr, request);\n request.send(data == null ? null : data);\n return xhr;\n };\n xhr.abort = function() {\n request.abort();\n return xhr;\n };\n d3.rebind(xhr, dispatch, \"on\");\n return callback == null ? xhr : xhr.get(d3_xhr_fixCallback(callback));\n }\n function d3_xhr_fixCallback(callback) {\n return callback.length === 1 ? function(error, request) {\n callback(error == null ? request : null);\n } : callback;\n }\n function d3_xhrHasResponse(request) {\n var type = request.responseType;\n return type && type !== \"text\" ? request.response : request.responseText;\n }\n d3.dsv = function(delimiter, mimeType) {\n var reFormat = new RegExp('[\"' + delimiter + \"\\n]\"), delimiterCode = delimiter.charCodeAt(0);\n function dsv(url, row, callback) {\n if (arguments.length < 3) callback = row, row = null;\n var xhr = d3_xhr(url, mimeType, row == null ? response : typedResponse(row), callback);\n xhr.row = function(_) {\n return arguments.length ? xhr.response((row = _) == null ? response : typedResponse(_)) : row;\n };\n return xhr;\n }\n function response(request) {\n return dsv.parse(request.responseText);\n }\n function typedResponse(f) {\n return function(request) {\n return dsv.parse(request.responseText, f);\n };\n }\n dsv.parse = function(text, f) {\n var o;\n return dsv.parseRows(text, function(row, i) {\n if (o) return o(row, i - 1);\n var a = function(d) {\n var obj = {};\n var len = row.length;\n for (var k = 0; k < len; ++k) {\n obj[row[k]] = d[k];\n }\n return obj;\n };\n o = f ? function(row, i) {\n return f(a(row), i);\n } : a;\n });\n };\n dsv.parseRows = function(text, f) {\n var EOL = {}, EOF = {}, rows = [], N = text.length, I = 0, n = 0, t, eol;\n function token() {\n if (I >= N) return EOF;\n if (eol) return eol = false, EOL;\n var j = I;\n if (text.charCodeAt(j) === 34) {\n var i = j;\n while (i++ < N) {\n if (text.charCodeAt(i) === 34) {\n if (text.charCodeAt(i + 1) !== 34) break;\n ++i;\n }\n }\n I = i + 2;\n var c = text.charCodeAt(i + 1);\n if (c === 13) {\n eol = true;\n if (text.charCodeAt(i + 2) === 10) ++I;\n } else if (c === 10) {\n eol = true;\n }\n return text.slice(j + 1, i).replace(/\"\"/g, '\"');\n }\n while (I < N) {\n var c = text.charCodeAt(I++), k = 1;\n if (c === 10) eol = true; else if (c === 13) {\n eol = true;\n if (text.charCodeAt(I) === 10) ++I, ++k;\n } else if (c !== delimiterCode) continue;\n return text.slice(j, I - k);\n }\n return text.slice(j);\n }\n while ((t = token()) !== EOF) {\n var a = [];\n while (t !== EOL && t !== EOF) {\n a.push(t);\n t = token();\n }\n if (f && (a = f(a, n++)) == null) continue;\n rows.push(a);\n }\n return rows;\n };\n dsv.format = function(rows) {\n if (Array.isArray(rows[0])) return dsv.formatRows(rows);\n var fieldSet = new d3_Set(), fields = [];\n rows.forEach(function(row) {\n for (var field in row) {\n if (!fieldSet.has(field)) {\n fields.push(fieldSet.add(field));\n }\n }\n });\n return [ fields.map(formatValue).join(delimiter) ].concat(rows.map(function(row) {\n return fields.map(function(field) {\n return formatValue(row[field]);\n }).join(delimiter);\n })).join(\"\\n\");\n };\n dsv.formatRows = function(rows) {\n return rows.map(formatRow).join(\"\\n\");\n };\n function formatRow(row) {\n return row.map(formatValue).join(delimiter);\n }\n function formatValue(text) {\n return reFormat.test(text) ? '\"' + text.replace(/\\\"/g, '\"\"') + '\"' : text;\n }\n return dsv;\n };\n d3.csv = d3.dsv(\",\", \"text/csv\");\n d3.tsv = d3.dsv(\"\t\", \"text/tab-separated-values\");\n var d3_timer_queueHead, d3_timer_queueTail, d3_timer_interval, d3_timer_timeout, d3_timer_frame = this[d3_vendorSymbol(this, \"requestAnimationFrame\")] || function(callback) {\n setTimeout(callback, 17);\n };\n d3.timer = function() {\n d3_timer.apply(this, arguments);\n };\n function d3_timer(callback, delay, then) {\n var n = arguments.length;\n if (n < 2) delay = 0;\n if (n < 3) then = Date.now();\n var time = then + delay, timer = {\n c: callback,\n t: time,\n n: null\n };\n if (d3_timer_queueTail) d3_timer_queueTail.n = timer; else d3_timer_queueHead = timer;\n d3_timer_queueTail = timer;\n if (!d3_timer_interval) {\n d3_timer_timeout = clearTimeout(d3_timer_timeout);\n d3_timer_interval = 1;\n d3_timer_frame(d3_timer_step);\n }\n return timer;\n }\n function d3_timer_step() {\n var now = d3_timer_mark(), delay = d3_timer_sweep() - now;\n if (delay > 24) {\n if (isFinite(delay)) {\n clearTimeout(d3_timer_timeout);\n d3_timer_timeout = setTimeout(d3_timer_step, delay);\n }\n d3_timer_interval = 0;\n } else {\n d3_timer_interval = 1;\n d3_timer_frame(d3_timer_step);\n }\n }\n d3.timer.flush = function() {\n d3_timer_mark();\n d3_timer_sweep();\n };\n function d3_timer_mark() {\n var now = Date.now(), timer = d3_timer_queueHead;\n while (timer) {\n if (now >= timer.t && timer.c(now - timer.t)) timer.c = null;\n timer = timer.n;\n }\n return now;\n }\n function d3_timer_sweep() {\n var t0, t1 = d3_timer_queueHead, time = Infinity;\n while (t1) {\n if (t1.c) {\n if (t1.t < time) time = t1.t;\n t1 = (t0 = t1).n;\n } else {\n t1 = t0 ? t0.n = t1.n : d3_timer_queueHead = t1.n;\n }\n }\n d3_timer_queueTail = t0;\n return time;\n }\n d3.round = function(x, n) {\n return n ? Math.round(x * (n = Math.pow(10, n))) / n : Math.round(x);\n };\n d3.geom = {};\n function d3_geom_pointX(d) {\n return d[0];\n }\n function d3_geom_pointY(d) {\n return d[1];\n }\n d3.geom.hull = function(vertices) {\n var x = d3_geom_pointX, y = d3_geom_pointY;\n if (arguments.length) return hull(vertices);\n function hull(data) {\n if (data.length < 3) return [];\n var fx = d3_functor(x), fy = d3_functor(y), i, n = data.length, points = [], flippedPoints = [];\n for (i = 0; i < n; i++) {\n points.push([ +fx.call(this, data[i], i), +fy.call(this, data[i], i), i ]);\n }\n points.sort(d3_geom_hullOrder);\n for (i = 0; i < n; i++) flippedPoints.push([ points[i][0], -points[i][1] ]);\n var upper = d3_geom_hullUpper(points), lower = d3_geom_hullUpper(flippedPoints);\n var skipLeft = lower[0] === upper[0], skipRight = lower[lower.length - 1] === upper[upper.length - 1], polygon = [];\n for (i = upper.length - 1; i >= 0; --i) polygon.push(data[points[upper[i]][2]]);\n for (i = +skipLeft; i < lower.length - skipRight; ++i) polygon.push(data[points[lower[i]][2]]);\n return polygon;\n }\n hull.x = function(_) {\n return arguments.length ? (x = _, hull) : x;\n };\n hull.y = function(_) {\n return arguments.length ? (y = _, hull) : y;\n };\n return hull;\n };\n function d3_geom_hullUpper(points) {\n var n = points.length, hull = [ 0, 1 ], hs = 2;\n for (var i = 2; i < n; i++) {\n while (hs > 1 && d3_cross2d(points[hull[hs - 2]], points[hull[hs - 1]], points[i]) <= 0) --hs;\n hull[hs++] = i;\n }\n return hull.slice(0, hs);\n }\n function d3_geom_hullOrder(a, b) {\n return a[0] - b[0] || a[1] - b[1];\n }\n d3.geom.polygon = function(coordinates) {\n d3_subclass(coordinates, d3_geom_polygonPrototype);\n return coordinates;\n };\n var d3_geom_polygonPrototype = d3.geom.polygon.prototype = [];\n d3_geom_polygonPrototype.area = function() {\n var i = -1, n = this.length, a, b = this[n - 1], area = 0;\n while (++i < n) {\n a = b;\n b = this[i];\n area += a[1] * b[0] - a[0] * b[1];\n }\n return area * .5;\n };\n d3_geom_polygonPrototype.centroid = function(k) {\n var i = -1, n = this.length, x = 0, y = 0, a, b = this[n - 1], c;\n if (!arguments.length) k = -1 / (6 * this.area());\n while (++i < n) {\n a = b;\n b = this[i];\n c = a[0] * b[1] - b[0] * a[1];\n x += (a[0] + b[0]) * c;\n y += (a[1] + b[1]) * c;\n }\n return [ x * k, y * k ];\n };\n d3_geom_polygonPrototype.clip = function(subject) {\n var input, closed = d3_geom_polygonClosed(subject), i = -1, n = this.length - d3_geom_polygonClosed(this), j, m, a = this[n - 1], b, c, d;\n while (++i < n) {\n input = subject.slice();\n subject.length = 0;\n b = this[i];\n c = input[(m = input.length - closed) - 1];\n j = -1;\n while (++j < m) {\n d = input[j];\n if (d3_geom_polygonInside(d, a, b)) {\n if (!d3_geom_polygonInside(c, a, b)) {\n subject.push(d3_geom_polygonIntersect(c, d, a, b));\n }\n subject.push(d);\n } else if (d3_geom_polygonInside(c, a, b)) {\n subject.push(d3_geom_polygonIntersect(c, d, a, b));\n }\n c = d;\n }\n if (closed) subject.push(subject[0]);\n a = b;\n }\n return subject;\n };\n function d3_geom_polygonInside(p, a, b) {\n return (b[0] - a[0]) * (p[1] - a[1]) < (b[1] - a[1]) * (p[0] - a[0]);\n }\n function d3_geom_polygonIntersect(c, d, a, b) {\n var x1 = c[0], x3 = a[0], x21 = d[0] - x1, x43 = b[0] - x3, y1 = c[1], y3 = a[1], y21 = d[1] - y1, y43 = b[1] - y3, ua = (x43 * (y1 - y3) - y43 * (x1 - x3)) / (y43 * x21 - x43 * y21);\n return [ x1 + ua * x21, y1 + ua * y21 ];\n }\n function d3_geom_polygonClosed(coordinates) {\n var a = coordinates[0], b = coordinates[coordinates.length - 1];\n return !(a[0] - b[0] || a[1] - b[1]);\n }\n var d3_geom_voronoiEdges, d3_geom_voronoiCells, d3_geom_voronoiBeaches, d3_geom_voronoiBeachPool = [], d3_geom_voronoiFirstCircle, d3_geom_voronoiCircles, d3_geom_voronoiCirclePool = [];\n function d3_geom_voronoiBeach() {\n d3_geom_voronoiRedBlackNode(this);\n this.edge = this.site = this.circle = null;\n }\n function d3_geom_voronoiCreateBeach(site) {\n var beach = d3_geom_voronoiBeachPool.pop() || new d3_geom_voronoiBeach();\n beach.site = site;\n return beach;\n }\n function d3_geom_voronoiDetachBeach(beach) {\n d3_geom_voronoiDetachCircle(beach);\n d3_geom_voronoiBeaches.remove(beach);\n d3_geom_voronoiBeachPool.push(beach);\n d3_geom_voronoiRedBlackNode(beach);\n }\n function d3_geom_voronoiRemoveBeach(beach) {\n var circle = beach.circle, x = circle.x, y = circle.cy, vertex = {\n x: x,\n y: y\n }, previous = beach.P, next = beach.N, disappearing = [ beach ];\n d3_geom_voronoiDetachBeach(beach);\n var lArc = previous;\n while (lArc.circle && abs(x - lArc.circle.x) < ε && abs(y - lArc.circle.cy) < ε) {\n previous = lArc.P;\n disappearing.unshift(lArc);\n d3_geom_voronoiDetachBeach(lArc);\n lArc = previous;\n }\n disappearing.unshift(lArc);\n d3_geom_voronoiDetachCircle(lArc);\n var rArc = next;\n while (rArc.circle && abs(x - rArc.circle.x) < ε && abs(y - rArc.circle.cy) < ε) {\n next = rArc.N;\n disappearing.push(rArc);\n d3_geom_voronoiDetachBeach(rArc);\n rArc = next;\n }\n disappearing.push(rArc);\n d3_geom_voronoiDetachCircle(rArc);\n var nArcs = disappearing.length, iArc;\n for (iArc = 1; iArc < nArcs; ++iArc) {\n rArc = disappearing[iArc];\n lArc = disappearing[iArc - 1];\n d3_geom_voronoiSetEdgeEnd(rArc.edge, lArc.site, rArc.site, vertex);\n }\n lArc = disappearing[0];\n rArc = disappearing[nArcs - 1];\n rArc.edge = d3_geom_voronoiCreateEdge(lArc.site, rArc.site, null, vertex);\n d3_geom_voronoiAttachCircle(lArc);\n d3_geom_voronoiAttachCircle(rArc);\n }\n function d3_geom_voronoiAddBeach(site) {\n var x = site.x, directrix = site.y, lArc, rArc, dxl, dxr, node = d3_geom_voronoiBeaches._;\n while (node) {\n dxl = d3_geom_voronoiLeftBreakPoint(node, directrix) - x;\n if (dxl > ε) node = node.L; else {\n dxr = x - d3_geom_voronoiRightBreakPoint(node, directrix);\n if (dxr > ε) {\n if (!node.R) {\n lArc = node;\n break;\n }\n node = node.R;\n } else {\n if (dxl > -ε) {\n lArc = node.P;\n rArc = node;\n } else if (dxr > -ε) {\n lArc = node;\n rArc = node.N;\n } else {\n lArc = rArc = node;\n }\n break;\n }\n }\n }\n var newArc = d3_geom_voronoiCreateBeach(site);\n d3_geom_voronoiBeaches.insert(lArc, newArc);\n if (!lArc && !rArc) return;\n if (lArc === rArc) {\n d3_geom_voronoiDetachCircle(lArc);\n rArc = d3_geom_voronoiCreateBeach(lArc.site);\n d3_geom_voronoiBeaches.insert(newArc, rArc);\n newArc.edge = rArc.edge = d3_geom_voronoiCreateEdge(lArc.site, newArc.site);\n d3_geom_voronoiAttachCircle(lArc);\n d3_geom_voronoiAttachCircle(rArc);\n return;\n }\n if (!rArc) {\n newArc.edge = d3_geom_voronoiCreateEdge(lArc.site, newArc.site);\n return;\n }\n d3_geom_voronoiDetachCircle(lArc);\n d3_geom_voronoiDetachCircle(rArc);\n var lSite = lArc.site, ax = lSite.x, ay = lSite.y, bx = site.x - ax, by = site.y - ay, rSite = rArc.site, cx = rSite.x - ax, cy = rSite.y - ay, d = 2 * (bx * cy - by * cx), hb = bx * bx + by * by, hc = cx * cx + cy * cy, vertex = {\n x: (cy * hb - by * hc) / d + ax,\n y: (bx * hc - cx * hb) / d + ay\n };\n d3_geom_voronoiSetEdgeEnd(rArc.edge, lSite, rSite, vertex);\n newArc.edge = d3_geom_voronoiCreateEdge(lSite, site, null, vertex);\n rArc.edge = d3_geom_voronoiCreateEdge(site, rSite, null, vertex);\n d3_geom_voronoiAttachCircle(lArc);\n d3_geom_voronoiAttachCircle(rArc);\n }\n function d3_geom_voronoiLeftBreakPoint(arc, directrix) {\n var site = arc.site, rfocx = site.x, rfocy = site.y, pby2 = rfocy - directrix;\n if (!pby2) return rfocx;\n var lArc = arc.P;\n if (!lArc) return -Infinity;\n site = lArc.site;\n var lfocx = site.x, lfocy = site.y, plby2 = lfocy - directrix;\n if (!plby2) return lfocx;\n var hl = lfocx - rfocx, aby2 = 1 / pby2 - 1 / plby2, b = hl / plby2;\n if (aby2) return (-b + Math.sqrt(b * b - 2 * aby2 * (hl * hl / (-2 * plby2) - lfocy + plby2 / 2 + rfocy - pby2 / 2))) / aby2 + rfocx;\n return (rfocx + lfocx) / 2;\n }\n function d3_geom_voronoiRightBreakPoint(arc, directrix) {\n var rArc = arc.N;\n if (rArc) return d3_geom_voronoiLeftBreakPoint(rArc, directrix);\n var site = arc.site;\n return site.y === directrix ? site.x : Infinity;\n }\n function d3_geom_voronoiCell(site) {\n this.site = site;\n this.edges = [];\n }\n d3_geom_voronoiCell.prototype.prepare = function() {\n var halfEdges = this.edges, iHalfEdge = halfEdges.length, edge;\n while (iHalfEdge--) {\n edge = halfEdges[iHalfEdge].edge;\n if (!edge.b || !edge.a) halfEdges.splice(iHalfEdge, 1);\n }\n halfEdges.sort(d3_geom_voronoiHalfEdgeOrder);\n return halfEdges.length;\n };\n function d3_geom_voronoiCloseCells(extent) {\n var x0 = extent[0][0], x1 = extent[1][0], y0 = extent[0][1], y1 = extent[1][1], x2, y2, x3, y3, cells = d3_geom_voronoiCells, iCell = cells.length, cell, iHalfEdge, halfEdges, nHalfEdges, start, end;\n while (iCell--) {\n cell = cells[iCell];\n if (!cell || !cell.prepare()) continue;\n halfEdges = cell.edges;\n nHalfEdges = halfEdges.length;\n iHalfEdge = 0;\n while (iHalfEdge < nHalfEdges) {\n end = halfEdges[iHalfEdge].end(), x3 = end.x, y3 = end.y;\n start = halfEdges[++iHalfEdge % nHalfEdges].start(), x2 = start.x, y2 = start.y;\n if (abs(x3 - x2) > ε || abs(y3 - y2) > ε) {\n halfEdges.splice(iHalfEdge, 0, new d3_geom_voronoiHalfEdge(d3_geom_voronoiCreateBorderEdge(cell.site, end, abs(x3 - x0) < ε && y1 - y3 > ε ? {\n x: x0,\n y: abs(x2 - x0) < ε ? y2 : y1\n } : abs(y3 - y1) < ε && x1 - x3 > ε ? {\n x: abs(y2 - y1) < ε ? x2 : x1,\n y: y1\n } : abs(x3 - x1) < ε && y3 - y0 > ε ? {\n x: x1,\n y: abs(x2 - x1) < ε ? y2 : y0\n } : abs(y3 - y0) < ε && x3 - x0 > ε ? {\n x: abs(y2 - y0) < ε ? x2 : x0,\n y: y0\n } : null), cell.site, null));\n ++nHalfEdges;\n }\n }\n }\n }\n function d3_geom_voronoiHalfEdgeOrder(a, b) {\n return b.angle - a.angle;\n }\n function d3_geom_voronoiCircle() {\n d3_geom_voronoiRedBlackNode(this);\n this.x = this.y = this.arc = this.site = this.cy = null;\n }\n function d3_geom_voronoiAttachCircle(arc) {\n var lArc = arc.P, rArc = arc.N;\n if (!lArc || !rArc) return;\n var lSite = lArc.site, cSite = arc.site, rSite = rArc.site;\n if (lSite === rSite) return;\n var bx = cSite.x, by = cSite.y, ax = lSite.x - bx, ay = lSite.y - by, cx = rSite.x - bx, cy = rSite.y - by;\n var d = 2 * (ax * cy - ay * cx);\n if (d >= -ε2) return;\n var ha = ax * ax + ay * ay, hc = cx * cx + cy * cy, x = (cy * ha - ay * hc) / d, y = (ax * hc - cx * ha) / d, cy = y + by;\n var circle = d3_geom_voronoiCirclePool.pop() || new d3_geom_voronoiCircle();\n circle.arc = arc;\n circle.site = cSite;\n circle.x = x + bx;\n circle.y = cy + Math.sqrt(x * x + y * y);\n circle.cy = cy;\n arc.circle = circle;\n var before = null, node = d3_geom_voronoiCircles._;\n while (node) {\n if (circle.y < node.y || circle.y === node.y && circle.x <= node.x) {\n if (node.L) node = node.L; else {\n before = node.P;\n break;\n }\n } else {\n if (node.R) node = node.R; else {\n before = node;\n break;\n }\n }\n }\n d3_geom_voronoiCircles.insert(before, circle);\n if (!before) d3_geom_voronoiFirstCircle = circle;\n }\n function d3_geom_voronoiDetachCircle(arc) {\n var circle = arc.circle;\n if (circle) {\n if (!circle.P) d3_geom_voronoiFirstCircle = circle.N;\n d3_geom_voronoiCircles.remove(circle);\n d3_geom_voronoiCirclePool.push(circle);\n d3_geom_voronoiRedBlackNode(circle);\n arc.circle = null;\n }\n }\n function d3_geom_clipLine(x0, y0, x1, y1) {\n return function(line) {\n var a = line.a, b = line.b, ax = a.x, ay = a.y, bx = b.x, by = b.y, t0 = 0, t1 = 1, dx = bx - ax, dy = by - ay, r;\n r = x0 - ax;\n if (!dx && r > 0) return;\n r /= dx;\n if (dx < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dx > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n r = x1 - ax;\n if (!dx && r < 0) return;\n r /= dx;\n if (dx < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dx > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n r = y0 - ay;\n if (!dy && r > 0) return;\n r /= dy;\n if (dy < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dy > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n r = y1 - ay;\n if (!dy && r < 0) return;\n r /= dy;\n if (dy < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dy > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n if (t0 > 0) line.a = {\n x: ax + t0 * dx,\n y: ay + t0 * dy\n };\n if (t1 < 1) line.b = {\n x: ax + t1 * dx,\n y: ay + t1 * dy\n };\n return line;\n };\n }\n function d3_geom_voronoiClipEdges(extent) {\n var edges = d3_geom_voronoiEdges, clip = d3_geom_clipLine(extent[0][0], extent[0][1], extent[1][0], extent[1][1]), i = edges.length, e;\n while (i--) {\n e = edges[i];\n if (!d3_geom_voronoiConnectEdge(e, extent) || !clip(e) || abs(e.a.x - e.b.x) < ε && abs(e.a.y - e.b.y) < ε) {\n e.a = e.b = null;\n edges.splice(i, 1);\n }\n }\n }\n function d3_geom_voronoiConnectEdge(edge, extent) {\n var vb = edge.b;\n if (vb) return true;\n var va = edge.a, x0 = extent[0][0], x1 = extent[1][0], y0 = extent[0][1], y1 = extent[1][1], lSite = edge.l, rSite = edge.r, lx = lSite.x, ly = lSite.y, rx = rSite.x, ry = rSite.y, fx = (lx + rx) / 2, fy = (ly + ry) / 2, fm, fb;\n if (ry === ly) {\n if (fx < x0 || fx >= x1) return;\n if (lx > rx) {\n if (!va) va = {\n x: fx,\n y: y0\n }; else if (va.y >= y1) return;\n vb = {\n x: fx,\n y: y1\n };\n } else {\n if (!va) va = {\n x: fx,\n y: y1\n }; else if (va.y < y0) return;\n vb = {\n x: fx,\n y: y0\n };\n }\n } else {\n fm = (lx - rx) / (ry - ly);\n fb = fy - fm * fx;\n if (fm < -1 || fm > 1) {\n if (lx > rx) {\n if (!va) va = {\n x: (y0 - fb) / fm,\n y: y0\n }; else if (va.y >= y1) return;\n vb = {\n x: (y1 - fb) / fm,\n y: y1\n };\n } else {\n if (!va) va = {\n x: (y1 - fb) / fm,\n y: y1\n }; else if (va.y < y0) return;\n vb = {\n x: (y0 - fb) / fm,\n y: y0\n };\n }\n } else {\n if (ly < ry) {\n if (!va) va = {\n x: x0,\n y: fm * x0 + fb\n }; else if (va.x >= x1) return;\n vb = {\n x: x1,\n y: fm * x1 + fb\n };\n } else {\n if (!va) va = {\n x: x1,\n y: fm * x1 + fb\n }; else if (va.x < x0) return;\n vb = {\n x: x0,\n y: fm * x0 + fb\n };\n }\n }\n }\n edge.a = va;\n edge.b = vb;\n return true;\n }\n function d3_geom_voronoiEdge(lSite, rSite) {\n this.l = lSite;\n this.r = rSite;\n this.a = this.b = null;\n }\n function d3_geom_voronoiCreateEdge(lSite, rSite, va, vb) {\n var edge = new d3_geom_voronoiEdge(lSite, rSite);\n d3_geom_voronoiEdges.push(edge);\n if (va) d3_geom_voronoiSetEdgeEnd(edge, lSite, rSite, va);\n if (vb) d3_geom_voronoiSetEdgeEnd(edge, rSite, lSite, vb);\n d3_geom_voronoiCells[lSite.i].edges.push(new d3_geom_voronoiHalfEdge(edge, lSite, rSite));\n d3_geom_voronoiCells[rSite.i].edges.push(new d3_geom_voronoiHalfEdge(edge, rSite, lSite));\n return edge;\n }\n function d3_geom_voronoiCreateBorderEdge(lSite, va, vb) {\n var edge = new d3_geom_voronoiEdge(lSite, null);\n edge.a = va;\n edge.b = vb;\n d3_geom_voronoiEdges.push(edge);\n return edge;\n }\n function d3_geom_voronoiSetEdgeEnd(edge, lSite, rSite, vertex) {\n if (!edge.a && !edge.b) {\n edge.a = vertex;\n edge.l = lSite;\n edge.r = rSite;\n } else if (edge.l === rSite) {\n edge.b = vertex;\n } else {\n edge.a = vertex;\n }\n }\n function d3_geom_voronoiHalfEdge(edge, lSite, rSite) {\n var va = edge.a, vb = edge.b;\n this.edge = edge;\n this.site = lSite;\n this.angle = rSite ? Math.atan2(rSite.y - lSite.y, rSite.x - lSite.x) : edge.l === lSite ? Math.atan2(vb.x - va.x, va.y - vb.y) : Math.atan2(va.x - vb.x, vb.y - va.y);\n }\n d3_geom_voronoiHalfEdge.prototype = {\n start: function() {\n return this.edge.l === this.site ? this.edge.a : this.edge.b;\n },\n end: function() {\n return this.edge.l === this.site ? this.edge.b : this.edge.a;\n }\n };\n function d3_geom_voronoiRedBlackTree() {\n this._ = null;\n }\n function d3_geom_voronoiRedBlackNode(node) {\n node.U = node.C = node.L = node.R = node.P = node.N = null;\n }\n d3_geom_voronoiRedBlackTree.prototype = {\n insert: function(after, node) {\n var parent, grandpa, uncle;\n if (after) {\n node.P = after;\n node.N = after.N;\n if (after.N) after.N.P = node;\n after.N = node;\n if (after.R) {\n after = after.R;\n while (after.L) after = after.L;\n after.L = node;\n } else {\n after.R = node;\n }\n parent = after;\n } else if (this._) {\n after = d3_geom_voronoiRedBlackFirst(this._);\n node.P = null;\n node.N = after;\n after.P = after.L = node;\n parent = after;\n } else {\n node.P = node.N = null;\n this._ = node;\n parent = null;\n }\n node.L = node.R = null;\n node.U = parent;\n node.C = true;\n after = node;\n while (parent && parent.C) {\n grandpa = parent.U;\n if (parent === grandpa.L) {\n uncle = grandpa.R;\n if (uncle && uncle.C) {\n parent.C = uncle.C = false;\n grandpa.C = true;\n after = grandpa;\n } else {\n if (after === parent.R) {\n d3_geom_voronoiRedBlackRotateLeft(this, parent);\n after = parent;\n parent = after.U;\n }\n parent.C = false;\n grandpa.C = true;\n d3_geom_voronoiRedBlackRotateRight(this, grandpa);\n }\n } else {\n uncle = grandpa.L;\n if (uncle && uncle.C) {\n parent.C = uncle.C = false;\n grandpa.C = true;\n after = grandpa;\n } else {\n if (after === parent.L) {\n d3_geom_voronoiRedBlackRotateRight(this, parent);\n after = parent;\n parent = after.U;\n }\n parent.C = false;\n grandpa.C = true;\n d3_geom_voronoiRedBlackRotateLeft(this, grandpa);\n }\n }\n parent = after.U;\n }\n this._.C = false;\n },\n remove: function(node) {\n if (node.N) node.N.P = node.P;\n if (node.P) node.P.N = node.N;\n node.N = node.P = null;\n var parent = node.U, sibling, left = node.L, right = node.R, next, red;\n if (!left) next = right; else if (!right) next = left; else next = d3_geom_voronoiRedBlackFirst(right);\n if (parent) {\n if (parent.L === node) parent.L = next; else parent.R = next;\n } else {\n this._ = next;\n }\n if (left && right) {\n red = next.C;\n next.C = node.C;\n next.L = left;\n left.U = next;\n if (next !== right) {\n parent = next.U;\n next.U = node.U;\n node = next.R;\n parent.L = node;\n next.R = right;\n right.U = next;\n } else {\n next.U = parent;\n parent = next;\n node = next.R;\n }\n } else {\n red = node.C;\n node = next;\n }\n if (node) node.U = parent;\n if (red) return;\n if (node && node.C) {\n node.C = false;\n return;\n }\n do {\n if (node === this._) break;\n if (node === parent.L) {\n sibling = parent.R;\n if (sibling.C) {\n sibling.C = false;\n parent.C = true;\n d3_geom_voronoiRedBlackRotateLeft(this, parent);\n sibling = parent.R;\n }\n if (sibling.L && sibling.L.C || sibling.R && sibling.R.C) {\n if (!sibling.R || !sibling.R.C) {\n sibling.L.C = false;\n sibling.C = true;\n d3_geom_voronoiRedBlackRotateRight(this, sibling);\n sibling = parent.R;\n }\n sibling.C = parent.C;\n parent.C = sibling.R.C = false;\n d3_geom_voronoiRedBlackRotateLeft(this, parent);\n node = this._;\n break;\n }\n } else {\n sibling = parent.L;\n if (sibling.C) {\n sibling.C = false;\n parent.C = true;\n d3_geom_voronoiRedBlackRotateRight(this, parent);\n sibling = parent.L;\n }\n if (sibling.L && sibling.L.C || sibling.R && sibling.R.C) {\n if (!sibling.L || !sibling.L.C) {\n sibling.R.C = false;\n sibling.C = true;\n d3_geom_voronoiRedBlackRotateLeft(this, sibling);\n sibling = parent.L;\n }\n sibling.C = parent.C;\n parent.C = sibling.L.C = false;\n d3_geom_voronoiRedBlackRotateRight(this, parent);\n node = this._;\n break;\n }\n }\n sibling.C = true;\n node = parent;\n parent = parent.U;\n } while (!node.C);\n if (node) node.C = false;\n }\n };\n function d3_geom_voronoiRedBlackRotateLeft(tree, node) {\n var p = node, q = node.R, parent = p.U;\n if (parent) {\n if (parent.L === p) parent.L = q; else parent.R = q;\n } else {\n tree._ = q;\n }\n q.U = parent;\n p.U = q;\n p.R = q.L;\n if (p.R) p.R.U = p;\n q.L = p;\n }\n function d3_geom_voronoiRedBlackRotateRight(tree, node) {\n var p = node, q = node.L, parent = p.U;\n if (parent) {\n if (parent.L === p) parent.L = q; else parent.R = q;\n } else {\n tree._ = q;\n }\n q.U = parent;\n p.U = q;\n p.L = q.R;\n if (p.L) p.L.U = p;\n q.R = p;\n }\n function d3_geom_voronoiRedBlackFirst(node) {\n while (node.L) node = node.L;\n return node;\n }\n function d3_geom_voronoi(sites, bbox) {\n var site = sites.sort(d3_geom_voronoiVertexOrder).pop(), x0, y0, circle;\n d3_geom_voronoiEdges = [];\n d3_geom_voronoiCells = new Array(sites.length);\n d3_geom_voronoiBeaches = new d3_geom_voronoiRedBlackTree();\n d3_geom_voronoiCircles = new d3_geom_voronoiRedBlackTree();\n while (true) {\n circle = d3_geom_voronoiFirstCircle;\n if (site && (!circle || site.y < circle.y || site.y === circle.y && site.x < circle.x)) {\n if (site.x !== x0 || site.y !== y0) {\n d3_geom_voronoiCells[site.i] = new d3_geom_voronoiCell(site);\n d3_geom_voronoiAddBeach(site);\n x0 = site.x, y0 = site.y;\n }\n site = sites.pop();\n } else if (circle) {\n d3_geom_voronoiRemoveBeach(circle.arc);\n } else {\n break;\n }\n }\n if (bbox) d3_geom_voronoiClipEdges(bbox), d3_geom_voronoiCloseCells(bbox);\n var diagram = {\n cells: d3_geom_voronoiCells,\n edges: d3_geom_voronoiEdges\n };\n d3_geom_voronoiBeaches = d3_geom_voronoiCircles = d3_geom_voronoiEdges = d3_geom_voronoiCells = null;\n return diagram;\n }\n function d3_geom_voronoiVertexOrder(a, b) {\n return b.y - a.y || b.x - a.x;\n }\n d3.geom.voronoi = function(points) {\n var x = d3_geom_pointX, y = d3_geom_pointY, fx = x, fy = y, clipExtent = d3_geom_voronoiClipExtent;\n if (points) return voronoi(points);\n function voronoi(data) {\n var polygons = new Array(data.length), x0 = clipExtent[0][0], y0 = clipExtent[0][1], x1 = clipExtent[1][0], y1 = clipExtent[1][1];\n d3_geom_voronoi(sites(data), clipExtent).cells.forEach(function(cell, i) {\n var edges = cell.edges, site = cell.site, polygon = polygons[i] = edges.length ? edges.map(function(e) {\n var s = e.start();\n return [ s.x, s.y ];\n }) : site.x >= x0 && site.x <= x1 && site.y >= y0 && site.y <= y1 ? [ [ x0, y1 ], [ x1, y1 ], [ x1, y0 ], [ x0, y0 ] ] : [];\n polygon.point = data[i];\n });\n return polygons;\n }\n function sites(data) {\n return data.map(function(d, i) {\n return {\n x: Math.round(fx(d, i) / ε) * ε,\n y: Math.round(fy(d, i) / ε) * ε,\n i: i\n };\n });\n }\n voronoi.links = function(data) {\n return d3_geom_voronoi(sites(data)).edges.filter(function(edge) {\n return edge.l && edge.r;\n }).map(function(edge) {\n return {\n source: data[edge.l.i],\n target: data[edge.r.i]\n };\n });\n };\n voronoi.triangles = function(data) {\n var triangles = [];\n d3_geom_voronoi(sites(data)).cells.forEach(function(cell, i) {\n var site = cell.site, edges = cell.edges.sort(d3_geom_voronoiHalfEdgeOrder), j = -1, m = edges.length, e0, s0, e1 = edges[m - 1].edge, s1 = e1.l === site ? e1.r : e1.l;\n while (++j < m) {\n e0 = e1;\n s0 = s1;\n e1 = edges[j].edge;\n s1 = e1.l === site ? e1.r : e1.l;\n if (i < s0.i && i < s1.i && d3_geom_voronoiTriangleArea(site, s0, s1) < 0) {\n triangles.push([ data[i], data[s0.i], data[s1.i] ]);\n }\n }\n });\n return triangles;\n };\n voronoi.x = function(_) {\n return arguments.length ? (fx = d3_functor(x = _), voronoi) : x;\n };\n voronoi.y = function(_) {\n return arguments.length ? (fy = d3_functor(y = _), voronoi) : y;\n };\n voronoi.clipExtent = function(_) {\n if (!arguments.length) return clipExtent === d3_geom_voronoiClipExtent ? null : clipExtent;\n clipExtent = _ == null ? d3_geom_voronoiClipExtent : _;\n return voronoi;\n };\n voronoi.size = function(_) {\n if (!arguments.length) return clipExtent === d3_geom_voronoiClipExtent ? null : clipExtent && clipExtent[1];\n return voronoi.clipExtent(_ && [ [ 0, 0 ], _ ]);\n };\n return voronoi;\n };\n var d3_geom_voronoiClipExtent = [ [ -1e6, -1e6 ], [ 1e6, 1e6 ] ];\n function d3_geom_voronoiTriangleArea(a, b, c) {\n return (a.x - c.x) * (b.y - a.y) - (a.x - b.x) * (c.y - a.y);\n }\n d3.geom.delaunay = function(vertices) {\n return d3.geom.voronoi().triangles(vertices);\n };\n d3.geom.quadtree = function(points, x1, y1, x2, y2) {\n var x = d3_geom_pointX, y = d3_geom_pointY, compat;\n if (compat = arguments.length) {\n x = d3_geom_quadtreeCompatX;\n y = d3_geom_quadtreeCompatY;\n if (compat === 3) {\n y2 = y1;\n x2 = x1;\n y1 = x1 = 0;\n }\n return quadtree(points);\n }\n function quadtree(data) {\n var d, fx = d3_functor(x), fy = d3_functor(y), xs, ys, i, n, x1_, y1_, x2_, y2_;\n if (x1 != null) {\n x1_ = x1, y1_ = y1, x2_ = x2, y2_ = y2;\n } else {\n x2_ = y2_ = -(x1_ = y1_ = Infinity);\n xs = [], ys = [];\n n = data.length;\n if (compat) for (i = 0; i < n; ++i) {\n d = data[i];\n if (d.x < x1_) x1_ = d.x;\n if (d.y < y1_) y1_ = d.y;\n if (d.x > x2_) x2_ = d.x;\n if (d.y > y2_) y2_ = d.y;\n xs.push(d.x);\n ys.push(d.y);\n } else for (i = 0; i < n; ++i) {\n var x_ = +fx(d = data[i], i), y_ = +fy(d, i);\n if (x_ < x1_) x1_ = x_;\n if (y_ < y1_) y1_ = y_;\n if (x_ > x2_) x2_ = x_;\n if (y_ > y2_) y2_ = y_;\n xs.push(x_);\n ys.push(y_);\n }\n }\n var dx = x2_ - x1_, dy = y2_ - y1_;\n if (dx > dy) y2_ = y1_ + dx; else x2_ = x1_ + dy;\n function insert(n, d, x, y, x1, y1, x2, y2) {\n if (isNaN(x) || isNaN(y)) return;\n if (n.leaf) {\n var nx = n.x, ny = n.y;\n if (nx != null) {\n if (abs(nx - x) + abs(ny - y) < .01) {\n insertChild(n, d, x, y, x1, y1, x2, y2);\n } else {\n var nPoint = n.point;\n n.x = n.y = n.point = null;\n insertChild(n, nPoint, nx, ny, x1, y1, x2, y2);\n insertChild(n, d, x, y, x1, y1, x2, y2);\n }\n } else {\n n.x = x, n.y = y, n.point = d;\n }\n } else {\n insertChild(n, d, x, y, x1, y1, x2, y2);\n }\n }\n function insertChild(n, d, x, y, x1, y1, x2, y2) {\n var xm = (x1 + x2) * .5, ym = (y1 + y2) * .5, right = x >= xm, below = y >= ym, i = below << 1 | right;\n n.leaf = false;\n n = n.nodes[i] || (n.nodes[i] = d3_geom_quadtreeNode());\n if (right) x1 = xm; else x2 = xm;\n if (below) y1 = ym; else y2 = ym;\n insert(n, d, x, y, x1, y1, x2, y2);\n }\n var root = d3_geom_quadtreeNode();\n root.add = function(d) {\n insert(root, d, +fx(d, ++i), +fy(d, i), x1_, y1_, x2_, y2_);\n };\n root.visit = function(f) {\n d3_geom_quadtreeVisit(f, root, x1_, y1_, x2_, y2_);\n };\n root.find = function(point) {\n return d3_geom_quadtreeFind(root, point[0], point[1], x1_, y1_, x2_, y2_);\n };\n i = -1;\n if (x1 == null) {\n while (++i < n) {\n insert(root, data[i], xs[i], ys[i], x1_, y1_, x2_, y2_);\n }\n --i;\n } else data.forEach(root.add);\n xs = ys = data = d = null;\n return root;\n }\n quadtree.x = function(_) {\n return arguments.length ? (x = _, quadtree) : x;\n };\n quadtree.y = function(_) {\n return arguments.length ? (y = _, quadtree) : y;\n };\n quadtree.extent = function(_) {\n if (!arguments.length) return x1 == null ? null : [ [ x1, y1 ], [ x2, y2 ] ];\n if (_ == null) x1 = y1 = x2 = y2 = null; else x1 = +_[0][0], y1 = +_[0][1], x2 = +_[1][0], \n y2 = +_[1][1];\n return quadtree;\n };\n quadtree.size = function(_) {\n if (!arguments.length) return x1 == null ? null : [ x2 - x1, y2 - y1 ];\n if (_ == null) x1 = y1 = x2 = y2 = null; else x1 = y1 = 0, x2 = +_[0], y2 = +_[1];\n return quadtree;\n };\n return quadtree;\n };\n function d3_geom_quadtreeCompatX(d) {\n return d.x;\n }\n function d3_geom_quadtreeCompatY(d) {\n return d.y;\n }\n function d3_geom_quadtreeNode() {\n return {\n leaf: true,\n nodes: [],\n point: null,\n x: null,\n y: null\n };\n }\n function d3_geom_quadtreeVisit(f, node, x1, y1, x2, y2) {\n if (!f(node, x1, y1, x2, y2)) {\n var sx = (x1 + x2) * .5, sy = (y1 + y2) * .5, children = node.nodes;\n if (children[0]) d3_geom_quadtreeVisit(f, children[0], x1, y1, sx, sy);\n if (children[1]) d3_geom_quadtreeVisit(f, children[1], sx, y1, x2, sy);\n if (children[2]) d3_geom_quadtreeVisit(f, children[2], x1, sy, sx, y2);\n if (children[3]) d3_geom_quadtreeVisit(f, children[3], sx, sy, x2, y2);\n }\n }\n function d3_geom_quadtreeFind(root, x, y, x0, y0, x3, y3) {\n var minDistance2 = Infinity, closestPoint;\n (function find(node, x1, y1, x2, y2) {\n if (x1 > x3 || y1 > y3 || x2 < x0 || y2 < y0) return;\n if (point = node.point) {\n var point, dx = x - node.x, dy = y - node.y, distance2 = dx * dx + dy * dy;\n if (distance2 < minDistance2) {\n var distance = Math.sqrt(minDistance2 = distance2);\n x0 = x - distance, y0 = y - distance;\n x3 = x + distance, y3 = y + distance;\n closestPoint = point;\n }\n }\n var children = node.nodes, xm = (x1 + x2) * .5, ym = (y1 + y2) * .5, right = x >= xm, below = y >= ym;\n for (var i = below << 1 | right, j = i + 4; i < j; ++i) {\n if (node = children[i & 3]) switch (i & 3) {\n case 0:\n find(node, x1, y1, xm, ym);\n break;\n\n case 1:\n find(node, xm, y1, x2, ym);\n break;\n\n case 2:\n find(node, x1, ym, xm, y2);\n break;\n\n case 3:\n find(node, xm, ym, x2, y2);\n break;\n }\n }\n })(root, x0, y0, x3, y3);\n return closestPoint;\n }\n d3.interpolateRgb = d3_interpolateRgb;\n function d3_interpolateRgb(a, b) {\n a = d3.rgb(a);\n b = d3.rgb(b);\n var ar = a.r, ag = a.g, ab = a.b, br = b.r - ar, bg = b.g - ag, bb = b.b - ab;\n return function(t) {\n return \"#\" + d3_rgb_hex(Math.round(ar + br * t)) + d3_rgb_hex(Math.round(ag + bg * t)) + d3_rgb_hex(Math.round(ab + bb * t));\n };\n }\n d3.interpolateObject = d3_interpolateObject;\n function d3_interpolateObject(a, b) {\n var i = {}, c = {}, k;\n for (k in a) {\n if (k in b) {\n i[k] = d3_interpolate(a[k], b[k]);\n } else {\n c[k] = a[k];\n }\n }\n for (k in b) {\n if (!(k in a)) {\n c[k] = b[k];\n }\n }\n return function(t) {\n for (k in i) c[k] = i[k](t);\n return c;\n };\n }\n d3.interpolateNumber = d3_interpolateNumber;\n function d3_interpolateNumber(a, b) {\n a = +a, b = +b;\n return function(t) {\n return a * (1 - t) + b * t;\n };\n }\n d3.interpolateString = d3_interpolateString;\n function d3_interpolateString(a, b) {\n var bi = d3_interpolate_numberA.lastIndex = d3_interpolate_numberB.lastIndex = 0, am, bm, bs, i = -1, s = [], q = [];\n a = a + \"\", b = b + \"\";\n while ((am = d3_interpolate_numberA.exec(a)) && (bm = d3_interpolate_numberB.exec(b))) {\n if ((bs = bm.index) > bi) {\n bs = b.slice(bi, bs);\n if (s[i]) s[i] += bs; else s[++i] = bs;\n }\n if ((am = am[0]) === (bm = bm[0])) {\n if (s[i]) s[i] += bm; else s[++i] = bm;\n } else {\n s[++i] = null;\n q.push({\n i: i,\n x: d3_interpolateNumber(am, bm)\n });\n }\n bi = d3_interpolate_numberB.lastIndex;\n }\n if (bi < b.length) {\n bs = b.slice(bi);\n if (s[i]) s[i] += bs; else s[++i] = bs;\n }\n return s.length < 2 ? q[0] ? (b = q[0].x, function(t) {\n return b(t) + \"\";\n }) : function() {\n return b;\n } : (b = q.length, function(t) {\n for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);\n return s.join(\"\");\n });\n }\n var d3_interpolate_numberA = /[-+]?(?:\\d+\\.?\\d*|\\.?\\d+)(?:[eE][-+]?\\d+)?/g, d3_interpolate_numberB = new RegExp(d3_interpolate_numberA.source, \"g\");\n d3.interpolate = d3_interpolate;\n function d3_interpolate(a, b) {\n var i = d3.interpolators.length, f;\n while (--i >= 0 && !(f = d3.interpolators[i](a, b))) ;\n return f;\n }\n d3.interpolators = [ function(a, b) {\n var t = typeof b;\n return (t === \"string\" ? d3_rgb_names.has(b.toLowerCase()) || /^(#|rgb\\(|hsl\\()/i.test(b) ? d3_interpolateRgb : d3_interpolateString : b instanceof d3_color ? d3_interpolateRgb : Array.isArray(b) ? d3_interpolateArray : t === \"object\" && isNaN(b) ? d3_interpolateObject : d3_interpolateNumber)(a, b);\n } ];\n d3.interpolateArray = d3_interpolateArray;\n function d3_interpolateArray(a, b) {\n var x = [], c = [], na = a.length, nb = b.length, n0 = Math.min(a.length, b.length), i;\n for (i = 0; i < n0; ++i) x.push(d3_interpolate(a[i], b[i]));\n for (;i < na; ++i) c[i] = a[i];\n for (;i < nb; ++i) c[i] = b[i];\n return function(t) {\n for (i = 0; i < n0; ++i) c[i] = x[i](t);\n return c;\n };\n }\n var d3_ease_default = function() {\n return d3_identity;\n };\n var d3_ease = d3.map({\n linear: d3_ease_default,\n poly: d3_ease_poly,\n quad: function() {\n return d3_ease_quad;\n },\n cubic: function() {\n return d3_ease_cubic;\n },\n sin: function() {\n return d3_ease_sin;\n },\n exp: function() {\n return d3_ease_exp;\n },\n circle: function() {\n return d3_ease_circle;\n },\n elastic: d3_ease_elastic,\n back: d3_ease_back,\n bounce: function() {\n return d3_ease_bounce;\n }\n });\n var d3_ease_mode = d3.map({\n \"in\": d3_identity,\n out: d3_ease_reverse,\n \"in-out\": d3_ease_reflect,\n \"out-in\": function(f) {\n return d3_ease_reflect(d3_ease_reverse(f));\n }\n });\n d3.ease = function(name) {\n var i = name.indexOf(\"-\"), t = i >= 0 ? name.slice(0, i) : name, m = i >= 0 ? name.slice(i + 1) : \"in\";\n t = d3_ease.get(t) || d3_ease_default;\n m = d3_ease_mode.get(m) || d3_identity;\n return d3_ease_clamp(m(t.apply(null, d3_arraySlice.call(arguments, 1))));\n };\n function d3_ease_clamp(f) {\n return function(t) {\n return t <= 0 ? 0 : t >= 1 ? 1 : f(t);\n };\n }\n function d3_ease_reverse(f) {\n return function(t) {\n return 1 - f(1 - t);\n };\n }\n function d3_ease_reflect(f) {\n return function(t) {\n return .5 * (t < .5 ? f(2 * t) : 2 - f(2 - 2 * t));\n };\n }\n function d3_ease_quad(t) {\n return t * t;\n }\n function d3_ease_cubic(t) {\n return t * t * t;\n }\n function d3_ease_cubicInOut(t) {\n if (t <= 0) return 0;\n if (t >= 1) return 1;\n var t2 = t * t, t3 = t2 * t;\n return 4 * (t < .5 ? t3 : 3 * (t - t2) + t3 - .75);\n }\n function d3_ease_poly(e) {\n return function(t) {\n return Math.pow(t, e);\n };\n }\n function d3_ease_sin(t) {\n return 1 - Math.cos(t * halfπ);\n }\n function d3_ease_exp(t) {\n return Math.pow(2, 10 * (t - 1));\n }\n function d3_ease_circle(t) {\n return 1 - Math.sqrt(1 - t * t);\n }\n function d3_ease_elastic(a, p) {\n var s;\n if (arguments.length < 2) p = .45;\n if (arguments.length) s = p / τ * Math.asin(1 / a); else a = 1, s = p / 4;\n return function(t) {\n return 1 + a * Math.pow(2, -10 * t) * Math.sin((t - s) * τ / p);\n };\n }\n function d3_ease_back(s) {\n if (!s) s = 1.70158;\n return function(t) {\n return t * t * ((s + 1) * t - s);\n };\n }\n function d3_ease_bounce(t) {\n return t < 1 / 2.75 ? 7.5625 * t * t : t < 2 / 2.75 ? 7.5625 * (t -= 1.5 / 2.75) * t + .75 : t < 2.5 / 2.75 ? 7.5625 * (t -= 2.25 / 2.75) * t + .9375 : 7.5625 * (t -= 2.625 / 2.75) * t + .984375;\n }\n d3.interpolateHcl = d3_interpolateHcl;\n function d3_interpolateHcl(a, b) {\n a = d3.hcl(a);\n b = d3.hcl(b);\n var ah = a.h, ac = a.c, al = a.l, bh = b.h - ah, bc = b.c - ac, bl = b.l - al;\n if (isNaN(bc)) bc = 0, ac = isNaN(ac) ? b.c : ac;\n if (isNaN(bh)) bh = 0, ah = isNaN(ah) ? b.h : ah; else if (bh > 180) bh -= 360; else if (bh < -180) bh += 360;\n return function(t) {\n return d3_hcl_lab(ah + bh * t, ac + bc * t, al + bl * t) + \"\";\n };\n }\n d3.interpolateHsl = d3_interpolateHsl;\n function d3_interpolateHsl(a, b) {\n a = d3.hsl(a);\n b = d3.hsl(b);\n var ah = a.h, as = a.s, al = a.l, bh = b.h - ah, bs = b.s - as, bl = b.l - al;\n if (isNaN(bs)) bs = 0, as = isNaN(as) ? b.s : as;\n if (isNaN(bh)) bh = 0, ah = isNaN(ah) ? b.h : ah; else if (bh > 180) bh -= 360; else if (bh < -180) bh += 360;\n return function(t) {\n return d3_hsl_rgb(ah + bh * t, as + bs * t, al + bl * t) + \"\";\n };\n }\n d3.interpolateLab = d3_interpolateLab;\n function d3_interpolateLab(a, b) {\n a = d3.lab(a);\n b = d3.lab(b);\n var al = a.l, aa = a.a, ab = a.b, bl = b.l - al, ba = b.a - aa, bb = b.b - ab;\n return function(t) {\n return d3_lab_rgb(al + bl * t, aa + ba * t, ab + bb * t) + \"\";\n };\n }\n d3.interpolateRound = d3_interpolateRound;\n function d3_interpolateRound(a, b) {\n b -= a;\n return function(t) {\n return Math.round(a + b * t);\n };\n }\n d3.transform = function(string) {\n var g = d3_document.createElementNS(d3.ns.prefix.svg, \"g\");\n return (d3.transform = function(string) {\n if (string != null) {\n g.setAttribute(\"transform\", string);\n var t = g.transform.baseVal.consolidate();\n }\n return new d3_transform(t ? t.matrix : d3_transformIdentity);\n })(string);\n };\n function d3_transform(m) {\n var r0 = [ m.a, m.b ], r1 = [ m.c, m.d ], kx = d3_transformNormalize(r0), kz = d3_transformDot(r0, r1), ky = d3_transformNormalize(d3_transformCombine(r1, r0, -kz)) || 0;\n if (r0[0] * r1[1] < r1[0] * r0[1]) {\n r0[0] *= -1;\n r0[1] *= -1;\n kx *= -1;\n kz *= -1;\n }\n this.rotate = (kx ? Math.atan2(r0[1], r0[0]) : Math.atan2(-r1[0], r1[1])) * d3_degrees;\n this.translate = [ m.e, m.f ];\n this.scale = [ kx, ky ];\n this.skew = ky ? Math.atan2(kz, ky) * d3_degrees : 0;\n }\n d3_transform.prototype.toString = function() {\n return \"translate(\" + this.translate + \")rotate(\" + this.rotate + \")skewX(\" + this.skew + \")scale(\" + this.scale + \")\";\n };\n function d3_transformDot(a, b) {\n return a[0] * b[0] + a[1] * b[1];\n }\n function d3_transformNormalize(a) {\n var k = Math.sqrt(d3_transformDot(a, a));\n if (k) {\n a[0] /= k;\n a[1] /= k;\n }\n return k;\n }\n function d3_transformCombine(a, b, k) {\n a[0] += k * b[0];\n a[1] += k * b[1];\n return a;\n }\n var d3_transformIdentity = {\n a: 1,\n b: 0,\n c: 0,\n d: 1,\n e: 0,\n f: 0\n };\n d3.interpolateTransform = d3_interpolateTransform;\n function d3_interpolateTransformPop(s) {\n return s.length ? s.pop() + \",\" : \"\";\n }\n function d3_interpolateTranslate(ta, tb, s, q) {\n if (ta[0] !== tb[0] || ta[1] !== tb[1]) {\n var i = s.push(\"translate(\", null, \",\", null, \")\");\n q.push({\n i: i - 4,\n x: d3_interpolateNumber(ta[0], tb[0])\n }, {\n i: i - 2,\n x: d3_interpolateNumber(ta[1], tb[1])\n });\n } else if (tb[0] || tb[1]) {\n s.push(\"translate(\" + tb + \")\");\n }\n }\n function d3_interpolateRotate(ra, rb, s, q) {\n if (ra !== rb) {\n if (ra - rb > 180) rb += 360; else if (rb - ra > 180) ra += 360;\n q.push({\n i: s.push(d3_interpolateTransformPop(s) + \"rotate(\", null, \")\") - 2,\n x: d3_interpolateNumber(ra, rb)\n });\n } else if (rb) {\n s.push(d3_interpolateTransformPop(s) + \"rotate(\" + rb + \")\");\n }\n }\n function d3_interpolateSkew(wa, wb, s, q) {\n if (wa !== wb) {\n q.push({\n i: s.push(d3_interpolateTransformPop(s) + \"skewX(\", null, \")\") - 2,\n x: d3_interpolateNumber(wa, wb)\n });\n } else if (wb) {\n s.push(d3_interpolateTransformPop(s) + \"skewX(\" + wb + \")\");\n }\n }\n function d3_interpolateScale(ka, kb, s, q) {\n if (ka[0] !== kb[0] || ka[1] !== kb[1]) {\n var i = s.push(d3_interpolateTransformPop(s) + \"scale(\", null, \",\", null, \")\");\n q.push({\n i: i - 4,\n x: d3_interpolateNumber(ka[0], kb[0])\n }, {\n i: i - 2,\n x: d3_interpolateNumber(ka[1], kb[1])\n });\n } else if (kb[0] !== 1 || kb[1] !== 1) {\n s.push(d3_interpolateTransformPop(s) + \"scale(\" + kb + \")\");\n }\n }\n function d3_interpolateTransform(a, b) {\n var s = [], q = [];\n a = d3.transform(a), b = d3.transform(b);\n d3_interpolateTranslate(a.translate, b.translate, s, q);\n d3_interpolateRotate(a.rotate, b.rotate, s, q);\n d3_interpolateSkew(a.skew, b.skew, s, q);\n d3_interpolateScale(a.scale, b.scale, s, q);\n a = b = null;\n return function(t) {\n var i = -1, n = q.length, o;\n while (++i < n) s[(o = q[i]).i] = o.x(t);\n return s.join(\"\");\n };\n }\n function d3_uninterpolateNumber(a, b) {\n b = (b -= a = +a) || 1 / b;\n return function(x) {\n return (x - a) / b;\n };\n }\n function d3_uninterpolateClamp(a, b) {\n b = (b -= a = +a) || 1 / b;\n return function(x) {\n return Math.max(0, Math.min(1, (x - a) / b));\n };\n }\n d3.layout = {};\n d3.layout.bundle = function() {\n return function(links) {\n var paths = [], i = -1, n = links.length;\n while (++i < n) paths.push(d3_layout_bundlePath(links[i]));\n return paths;\n };\n };\n function d3_layout_bundlePath(link) {\n var start = link.source, end = link.target, lca = d3_layout_bundleLeastCommonAncestor(start, end), points = [ start ];\n while (start !== lca) {\n start = start.parent;\n points.push(start);\n }\n var k = points.length;\n while (end !== lca) {\n points.splice(k, 0, end);\n end = end.parent;\n }\n return points;\n }\n function d3_layout_bundleAncestors(node) {\n var ancestors = [], parent = node.parent;\n while (parent != null) {\n ancestors.push(node);\n node = parent;\n parent = parent.parent;\n }\n ancestors.push(node);\n return ancestors;\n }\n function d3_layout_bundleLeastCommonAncestor(a, b) {\n if (a === b) return a;\n var aNodes = d3_layout_bundleAncestors(a), bNodes = d3_layout_bundleAncestors(b), aNode = aNodes.pop(), bNode = bNodes.pop(), sharedNode = null;\n while (aNode === bNode) {\n sharedNode = aNode;\n aNode = aNodes.pop();\n bNode = bNodes.pop();\n }\n return sharedNode;\n }\n d3.layout.chord = function() {\n var chord = {}, chords, groups, matrix, n, padding = 0, sortGroups, sortSubgroups, sortChords;\n function relayout() {\n var subgroups = {}, groupSums = [], groupIndex = d3.range(n), subgroupIndex = [], k, x, x0, i, j;\n chords = [];\n groups = [];\n k = 0, i = -1;\n while (++i < n) {\n x = 0, j = -1;\n while (++j < n) {\n x += matrix[i][j];\n }\n groupSums.push(x);\n subgroupIndex.push(d3.range(n));\n k += x;\n }\n if (sortGroups) {\n groupIndex.sort(function(a, b) {\n return sortGroups(groupSums[a], groupSums[b]);\n });\n }\n if (sortSubgroups) {\n subgroupIndex.forEach(function(d, i) {\n d.sort(function(a, b) {\n return sortSubgroups(matrix[i][a], matrix[i][b]);\n });\n });\n }\n k = (τ - padding * n) / k;\n x = 0, i = -1;\n while (++i < n) {\n x0 = x, j = -1;\n while (++j < n) {\n var di = groupIndex[i], dj = subgroupIndex[di][j], v = matrix[di][dj], a0 = x, a1 = x += v * k;\n subgroups[di + \"-\" + dj] = {\n index: di,\n subindex: dj,\n startAngle: a0,\n endAngle: a1,\n value: v\n };\n }\n groups[di] = {\n index: di,\n startAngle: x0,\n endAngle: x,\n value: groupSums[di]\n };\n x += padding;\n }\n i = -1;\n while (++i < n) {\n j = i - 1;\n while (++j < n) {\n var source = subgroups[i + \"-\" + j], target = subgroups[j + \"-\" + i];\n if (source.value || target.value) {\n chords.push(source.value < target.value ? {\n source: target,\n target: source\n } : {\n source: source,\n target: target\n });\n }\n }\n }\n if (sortChords) resort();\n }\n function resort() {\n chords.sort(function(a, b) {\n return sortChords((a.source.value + a.target.value) / 2, (b.source.value + b.target.value) / 2);\n });\n }\n chord.matrix = function(x) {\n if (!arguments.length) return matrix;\n n = (matrix = x) && matrix.length;\n chords = groups = null;\n return chord;\n };\n chord.padding = function(x) {\n if (!arguments.length) return padding;\n padding = x;\n chords = groups = null;\n return chord;\n };\n chord.sortGroups = function(x) {\n if (!arguments.length) return sortGroups;\n sortGroups = x;\n chords = groups = null;\n return chord;\n };\n chord.sortSubgroups = function(x) {\n if (!arguments.length) return sortSubgroups;\n sortSubgroups = x;\n chords = null;\n return chord;\n };\n chord.sortChords = function(x) {\n if (!arguments.length) return sortChords;\n sortChords = x;\n if (chords) resort();\n return chord;\n };\n chord.chords = function() {\n if (!chords) relayout();\n return chords;\n };\n chord.groups = function() {\n if (!groups) relayout();\n return groups;\n };\n return chord;\n };\n d3.layout.force = function() {\n var force = {}, event = d3.dispatch(\"start\", \"tick\", \"end\"), timer, size = [ 1, 1 ], drag, alpha, friction = .9, linkDistance = d3_layout_forceLinkDistance, linkStrength = d3_layout_forceLinkStrength, charge = -30, chargeDistance2 = d3_layout_forceChargeDistance2, gravity = .1, theta2 = .64, nodes = [], links = [], distances, strengths, charges;\n function repulse(node) {\n return function(quad, x1, _, x2) {\n if (quad.point !== node) {\n var dx = quad.cx - node.x, dy = quad.cy - node.y, dw = x2 - x1, dn = dx * dx + dy * dy;\n if (dw * dw / theta2 < dn) {\n if (dn < chargeDistance2) {\n var k = quad.charge / dn;\n node.px -= dx * k;\n node.py -= dy * k;\n }\n return true;\n }\n if (quad.point && dn && dn < chargeDistance2) {\n var k = quad.pointCharge / dn;\n node.px -= dx * k;\n node.py -= dy * k;\n }\n }\n return !quad.charge;\n };\n }\n force.tick = function() {\n if ((alpha *= .99) < .005) {\n timer = null;\n event.end({\n type: \"end\",\n alpha: alpha = 0\n });\n return true;\n }\n var n = nodes.length, m = links.length, q, i, o, s, t, l, k, x, y;\n for (i = 0; i < m; ++i) {\n o = links[i];\n s = o.source;\n t = o.target;\n x = t.x - s.x;\n y = t.y - s.y;\n if (l = x * x + y * y) {\n l = alpha * strengths[i] * ((l = Math.sqrt(l)) - distances[i]) / l;\n x *= l;\n y *= l;\n t.x -= x * (k = s.weight + t.weight ? s.weight / (s.weight + t.weight) : .5);\n t.y -= y * k;\n s.x += x * (k = 1 - k);\n s.y += y * k;\n }\n }\n if (k = alpha * gravity) {\n x = size[0] / 2;\n y = size[1] / 2;\n i = -1;\n if (k) while (++i < n) {\n o = nodes[i];\n o.x += (x - o.x) * k;\n o.y += (y - o.y) * k;\n }\n }\n if (charge) {\n d3_layout_forceAccumulate(q = d3.geom.quadtree(nodes), alpha, charges);\n i = -1;\n while (++i < n) {\n if (!(o = nodes[i]).fixed) {\n q.visit(repulse(o));\n }\n }\n }\n i = -1;\n while (++i < n) {\n o = nodes[i];\n if (o.fixed) {\n o.x = o.px;\n o.y = o.py;\n } else {\n o.x -= (o.px - (o.px = o.x)) * friction;\n o.y -= (o.py - (o.py = o.y)) * friction;\n }\n }\n event.tick({\n type: \"tick\",\n alpha: alpha\n });\n };\n force.nodes = function(x) {\n if (!arguments.length) return nodes;\n nodes = x;\n return force;\n };\n force.links = function(x) {\n if (!arguments.length) return links;\n links = x;\n return force;\n };\n force.size = function(x) {\n if (!arguments.length) return size;\n size = x;\n return force;\n };\n force.linkDistance = function(x) {\n if (!arguments.length) return linkDistance;\n linkDistance = typeof x === \"function\" ? x : +x;\n return force;\n };\n force.distance = force.linkDistance;\n force.linkStrength = function(x) {\n if (!arguments.length) return linkStrength;\n linkStrength = typeof x === \"function\" ? x : +x;\n return force;\n };\n force.friction = function(x) {\n if (!arguments.length) return friction;\n friction = +x;\n return force;\n };\n force.charge = function(x) {\n if (!arguments.length) return charge;\n charge = typeof x === \"function\" ? x : +x;\n return force;\n };\n force.chargeDistance = function(x) {\n if (!arguments.length) return Math.sqrt(chargeDistance2);\n chargeDistance2 = x * x;\n return force;\n };\n force.gravity = function(x) {\n if (!arguments.length) return gravity;\n gravity = +x;\n return force;\n };\n force.theta = function(x) {\n if (!arguments.length) return Math.sqrt(theta2);\n theta2 = x * x;\n return force;\n };\n force.alpha = function(x) {\n if (!arguments.length) return alpha;\n x = +x;\n if (alpha) {\n if (x > 0) {\n alpha = x;\n } else {\n timer.c = null, timer.t = NaN, timer = null;\n event.end({\n type: \"end\",\n alpha: alpha = 0\n });\n }\n } else if (x > 0) {\n event.start({\n type: \"start\",\n alpha: alpha = x\n });\n timer = d3_timer(force.tick);\n }\n return force;\n };\n force.start = function() {\n var i, n = nodes.length, m = links.length, w = size[0], h = size[1], neighbors, o;\n for (i = 0; i < n; ++i) {\n (o = nodes[i]).index = i;\n o.weight = 0;\n }\n for (i = 0; i < m; ++i) {\n o = links[i];\n if (typeof o.source == \"number\") o.source = nodes[o.source];\n if (typeof o.target == \"number\") o.target = nodes[o.target];\n ++o.source.weight;\n ++o.target.weight;\n }\n for (i = 0; i < n; ++i) {\n o = nodes[i];\n if (isNaN(o.x)) o.x = position(\"x\", w);\n if (isNaN(o.y)) o.y = position(\"y\", h);\n if (isNaN(o.px)) o.px = o.x;\n if (isNaN(o.py)) o.py = o.y;\n }\n distances = [];\n if (typeof linkDistance === \"function\") for (i = 0; i < m; ++i) distances[i] = +linkDistance.call(this, links[i], i); else for (i = 0; i < m; ++i) distances[i] = linkDistance;\n strengths = [];\n if (typeof linkStrength === \"function\") for (i = 0; i < m; ++i) strengths[i] = +linkStrength.call(this, links[i], i); else for (i = 0; i < m; ++i) strengths[i] = linkStrength;\n charges = [];\n if (typeof charge === \"function\") for (i = 0; i < n; ++i) charges[i] = +charge.call(this, nodes[i], i); else for (i = 0; i < n; ++i) charges[i] = charge;\n function position(dimension, size) {\n if (!neighbors) {\n neighbors = new Array(n);\n for (j = 0; j < n; ++j) {\n neighbors[j] = [];\n }\n for (j = 0; j < m; ++j) {\n var o = links[j];\n neighbors[o.source.index].push(o.target);\n neighbors[o.target.index].push(o.source);\n }\n }\n var candidates = neighbors[i], j = -1, l = candidates.length, x;\n while (++j < l) if (!isNaN(x = candidates[j][dimension])) return x;\n return Math.random() * size;\n }\n return force.resume();\n };\n force.resume = function() {\n return force.alpha(.1);\n };\n force.stop = function() {\n return force.alpha(0);\n };\n force.drag = function() {\n if (!drag) drag = d3.behavior.drag().origin(d3_identity).on(\"dragstart.force\", d3_layout_forceDragstart).on(\"drag.force\", dragmove).on(\"dragend.force\", d3_layout_forceDragend);\n if (!arguments.length) return drag;\n this.on(\"mouseover.force\", d3_layout_forceMouseover).on(\"mouseout.force\", d3_layout_forceMouseout).call(drag);\n };\n function dragmove(d) {\n d.px = d3.event.x, d.py = d3.event.y;\n force.resume();\n }\n return d3.rebind(force, event, \"on\");\n };\n function d3_layout_forceDragstart(d) {\n d.fixed |= 2;\n }\n function d3_layout_forceDragend(d) {\n d.fixed &= ~6;\n }\n function d3_layout_forceMouseover(d) {\n d.fixed |= 4;\n d.px = d.x, d.py = d.y;\n }\n function d3_layout_forceMouseout(d) {\n d.fixed &= ~4;\n }\n function d3_layout_forceAccumulate(quad, alpha, charges) {\n var cx = 0, cy = 0;\n quad.charge = 0;\n if (!quad.leaf) {\n var nodes = quad.nodes, n = nodes.length, i = -1, c;\n while (++i < n) {\n c = nodes[i];\n if (c == null) continue;\n d3_layout_forceAccumulate(c, alpha, charges);\n quad.charge += c.charge;\n cx += c.charge * c.cx;\n cy += c.charge * c.cy;\n }\n }\n if (quad.point) {\n if (!quad.leaf) {\n quad.point.x += Math.random() - .5;\n quad.point.y += Math.random() - .5;\n }\n var k = alpha * charges[quad.point.index];\n quad.charge += quad.pointCharge = k;\n cx += k * quad.point.x;\n cy += k * quad.point.y;\n }\n quad.cx = cx / quad.charge;\n quad.cy = cy / quad.charge;\n }\n var d3_layout_forceLinkDistance = 20, d3_layout_forceLinkStrength = 1, d3_layout_forceChargeDistance2 = Infinity;\n d3.layout.hierarchy = function() {\n var sort = d3_layout_hierarchySort, children = d3_layout_hierarchyChildren, value = d3_layout_hierarchyValue;\n function hierarchy(root) {\n var stack = [ root ], nodes = [], node;\n root.depth = 0;\n while ((node = stack.pop()) != null) {\n nodes.push(node);\n if ((childs = children.call(hierarchy, node, node.depth)) && (n = childs.length)) {\n var n, childs, child;\n while (--n >= 0) {\n stack.push(child = childs[n]);\n child.parent = node;\n child.depth = node.depth + 1;\n }\n if (value) node.value = 0;\n node.children = childs;\n } else {\n if (value) node.value = +value.call(hierarchy, node, node.depth) || 0;\n delete node.children;\n }\n }\n d3_layout_hierarchyVisitAfter(root, function(node) {\n var childs, parent;\n if (sort && (childs = node.children)) childs.sort(sort);\n if (value && (parent = node.parent)) parent.value += node.value;\n });\n return nodes;\n }\n hierarchy.sort = function(x) {\n if (!arguments.length) return sort;\n sort = x;\n return hierarchy;\n };\n hierarchy.children = function(x) {\n if (!arguments.length) return children;\n children = x;\n return hierarchy;\n };\n hierarchy.value = function(x) {\n if (!arguments.length) return value;\n value = x;\n return hierarchy;\n };\n hierarchy.revalue = function(root) {\n if (value) {\n d3_layout_hierarchyVisitBefore(root, function(node) {\n if (node.children) node.value = 0;\n });\n d3_layout_hierarchyVisitAfter(root, function(node) {\n var parent;\n if (!node.children) node.value = +value.call(hierarchy, node, node.depth) || 0;\n if (parent = node.parent) parent.value += node.value;\n });\n }\n return root;\n };\n return hierarchy;\n };\n function d3_layout_hierarchyRebind(object, hierarchy) {\n d3.rebind(object, hierarchy, \"sort\", \"children\", \"value\");\n object.nodes = object;\n object.links = d3_layout_hierarchyLinks;\n return object;\n }\n function d3_layout_hierarchyVisitBefore(node, callback) {\n var nodes = [ node ];\n while ((node = nodes.pop()) != null) {\n callback(node);\n if ((children = node.children) && (n = children.length)) {\n var n, children;\n while (--n >= 0) nodes.push(children[n]);\n }\n }\n }\n function d3_layout_hierarchyVisitAfter(node, callback) {\n var nodes = [ node ], nodes2 = [];\n while ((node = nodes.pop()) != null) {\n nodes2.push(node);\n if ((children = node.children) && (n = children.length)) {\n var i = -1, n, children;\n while (++i < n) nodes.push(children[i]);\n }\n }\n while ((node = nodes2.pop()) != null) {\n callback(node);\n }\n }\n function d3_layout_hierarchyChildren(d) {\n return d.children;\n }\n function d3_layout_hierarchyValue(d) {\n return d.value;\n }\n function d3_layout_hierarchySort(a, b) {\n return b.value - a.value;\n }\n function d3_layout_hierarchyLinks(nodes) {\n return d3.merge(nodes.map(function(parent) {\n return (parent.children || []).map(function(child) {\n return {\n source: parent,\n target: child\n };\n });\n }));\n }\n d3.layout.partition = function() {\n var hierarchy = d3.layout.hierarchy(), size = [ 1, 1 ];\n function position(node, x, dx, dy) {\n var children = node.children;\n node.x = x;\n node.y = node.depth * dy;\n node.dx = dx;\n node.dy = dy;\n if (children && (n = children.length)) {\n var i = -1, n, c, d;\n dx = node.value ? dx / node.value : 0;\n while (++i < n) {\n position(c = children[i], x, d = c.value * dx, dy);\n x += d;\n }\n }\n }\n function depth(node) {\n var children = node.children, d = 0;\n if (children && (n = children.length)) {\n var i = -1, n;\n while (++i < n) d = Math.max(d, depth(children[i]));\n }\n return 1 + d;\n }\n function partition(d, i) {\n var nodes = hierarchy.call(this, d, i);\n position(nodes[0], 0, size[0], size[1] / depth(nodes[0]));\n return nodes;\n }\n partition.size = function(x) {\n if (!arguments.length) return size;\n size = x;\n return partition;\n };\n return d3_layout_hierarchyRebind(partition, hierarchy);\n };\n d3.layout.pie = function() {\n var value = Number, sort = d3_layout_pieSortByValue, startAngle = 0, endAngle = τ, padAngle = 0;\n function pie(data) {\n var n = data.length, values = data.map(function(d, i) {\n return +value.call(pie, d, i);\n }), a = +(typeof startAngle === \"function\" ? startAngle.apply(this, arguments) : startAngle), da = (typeof endAngle === \"function\" ? endAngle.apply(this, arguments) : endAngle) - a, p = Math.min(Math.abs(da) / n, +(typeof padAngle === \"function\" ? padAngle.apply(this, arguments) : padAngle)), pa = p * (da < 0 ? -1 : 1), sum = d3.sum(values), k = sum ? (da - n * pa) / sum : 0, index = d3.range(n), arcs = [], v;\n if (sort != null) index.sort(sort === d3_layout_pieSortByValue ? function(i, j) {\n return values[j] - values[i];\n } : function(i, j) {\n return sort(data[i], data[j]);\n });\n index.forEach(function(i) {\n arcs[i] = {\n data: data[i],\n value: v = values[i],\n startAngle: a,\n endAngle: a += v * k + pa,\n padAngle: p\n };\n });\n return arcs;\n }\n pie.value = function(_) {\n if (!arguments.length) return value;\n value = _;\n return pie;\n };\n pie.sort = function(_) {\n if (!arguments.length) return sort;\n sort = _;\n return pie;\n };\n pie.startAngle = function(_) {\n if (!arguments.length) return startAngle;\n startAngle = _;\n return pie;\n };\n pie.endAngle = function(_) {\n if (!arguments.length) return endAngle;\n endAngle = _;\n return pie;\n };\n pie.padAngle = function(_) {\n if (!arguments.length) return padAngle;\n padAngle = _;\n return pie;\n };\n return pie;\n };\n var d3_layout_pieSortByValue = {};\n d3.layout.stack = function() {\n var values = d3_identity, order = d3_layout_stackOrderDefault, offset = d3_layout_stackOffsetZero, out = d3_layout_stackOut, x = d3_layout_stackX, y = d3_layout_stackY;\n function stack(data, index) {\n if (!(n = data.length)) return data;\n var series = data.map(function(d, i) {\n return values.call(stack, d, i);\n });\n var points = series.map(function(d) {\n return d.map(function(v, i) {\n return [ x.call(stack, v, i), y.call(stack, v, i) ];\n });\n });\n var orders = order.call(stack, points, index);\n series = d3.permute(series, orders);\n points = d3.permute(points, orders);\n var offsets = offset.call(stack, points, index);\n var m = series[0].length, n, i, j, o;\n for (j = 0; j < m; ++j) {\n out.call(stack, series[0][j], o = offsets[j], points[0][j][1]);\n for (i = 1; i < n; ++i) {\n out.call(stack, series[i][j], o += points[i - 1][j][1], points[i][j][1]);\n }\n }\n return data;\n }\n stack.values = function(x) {\n if (!arguments.length) return values;\n values = x;\n return stack;\n };\n stack.order = function(x) {\n if (!arguments.length) return order;\n order = typeof x === \"function\" ? x : d3_layout_stackOrders.get(x) || d3_layout_stackOrderDefault;\n return stack;\n };\n stack.offset = function(x) {\n if (!arguments.length) return offset;\n offset = typeof x === \"function\" ? x : d3_layout_stackOffsets.get(x) || d3_layout_stackOffsetZero;\n return stack;\n };\n stack.x = function(z) {\n if (!arguments.length) return x;\n x = z;\n return stack;\n };\n stack.y = function(z) {\n if (!arguments.length) return y;\n y = z;\n return stack;\n };\n stack.out = function(z) {\n if (!arguments.length) return out;\n out = z;\n return stack;\n };\n return stack;\n };\n function d3_layout_stackX(d) {\n return d.x;\n }\n function d3_layout_stackY(d) {\n return d.y;\n }\n function d3_layout_stackOut(d, y0, y) {\n d.y0 = y0;\n d.y = y;\n }\n var d3_layout_stackOrders = d3.map({\n \"inside-out\": function(data) {\n var n = data.length, i, j, max = data.map(d3_layout_stackMaxIndex), sums = data.map(d3_layout_stackReduceSum), index = d3.range(n).sort(function(a, b) {\n return max[a] - max[b];\n }), top = 0, bottom = 0, tops = [], bottoms = [];\n for (i = 0; i < n; ++i) {\n j = index[i];\n if (top < bottom) {\n top += sums[j];\n tops.push(j);\n } else {\n bottom += sums[j];\n bottoms.push(j);\n }\n }\n return bottoms.reverse().concat(tops);\n },\n reverse: function(data) {\n return d3.range(data.length).reverse();\n },\n \"default\": d3_layout_stackOrderDefault\n });\n var d3_layout_stackOffsets = d3.map({\n silhouette: function(data) {\n var n = data.length, m = data[0].length, sums = [], max = 0, i, j, o, y0 = [];\n for (j = 0; j < m; ++j) {\n for (i = 0, o = 0; i < n; i++) o += data[i][j][1];\n if (o > max) max = o;\n sums.push(o);\n }\n for (j = 0; j < m; ++j) {\n y0[j] = (max - sums[j]) / 2;\n }\n return y0;\n },\n wiggle: function(data) {\n var n = data.length, x = data[0], m = x.length, i, j, k, s1, s2, s3, dx, o, o0, y0 = [];\n y0[0] = o = o0 = 0;\n for (j = 1; j < m; ++j) {\n for (i = 0, s1 = 0; i < n; ++i) s1 += data[i][j][1];\n for (i = 0, s2 = 0, dx = x[j][0] - x[j - 1][0]; i < n; ++i) {\n for (k = 0, s3 = (data[i][j][1] - data[i][j - 1][1]) / (2 * dx); k < i; ++k) {\n s3 += (data[k][j][1] - data[k][j - 1][1]) / dx;\n }\n s2 += s3 * data[i][j][1];\n }\n y0[j] = o -= s1 ? s2 / s1 * dx : 0;\n if (o < o0) o0 = o;\n }\n for (j = 0; j < m; ++j) y0[j] -= o0;\n return y0;\n },\n expand: function(data) {\n var n = data.length, m = data[0].length, k = 1 / n, i, j, o, y0 = [];\n for (j = 0; j < m; ++j) {\n for (i = 0, o = 0; i < n; i++) o += data[i][j][1];\n if (o) for (i = 0; i < n; i++) data[i][j][1] /= o; else for (i = 0; i < n; i++) data[i][j][1] = k;\n }\n for (j = 0; j < m; ++j) y0[j] = 0;\n return y0;\n },\n zero: d3_layout_stackOffsetZero\n });\n function d3_layout_stackOrderDefault(data) {\n return d3.range(data.length);\n }\n function d3_layout_stackOffsetZero(data) {\n var j = -1, m = data[0].length, y0 = [];\n while (++j < m) y0[j] = 0;\n return y0;\n }\n function d3_layout_stackMaxIndex(array) {\n var i = 1, j = 0, v = array[0][1], k, n = array.length;\n for (;i < n; ++i) {\n if ((k = array[i][1]) > v) {\n j = i;\n v = k;\n }\n }\n return j;\n }\n function d3_layout_stackReduceSum(d) {\n return d.reduce(d3_layout_stackSum, 0);\n }\n function d3_layout_stackSum(p, d) {\n return p + d[1];\n }\n d3.layout.histogram = function() {\n var frequency = true, valuer = Number, ranger = d3_layout_histogramRange, binner = d3_layout_histogramBinSturges;\n function histogram(data, i) {\n var bins = [], values = data.map(valuer, this), range = ranger.call(this, values, i), thresholds = binner.call(this, range, values, i), bin, i = -1, n = values.length, m = thresholds.length - 1, k = frequency ? 1 : 1 / n, x;\n while (++i < m) {\n bin = bins[i] = [];\n bin.dx = thresholds[i + 1] - (bin.x = thresholds[i]);\n bin.y = 0;\n }\n if (m > 0) {\n i = -1;\n while (++i < n) {\n x = values[i];\n if (x >= range[0] && x <= range[1]) {\n bin = bins[d3.bisect(thresholds, x, 1, m) - 1];\n bin.y += k;\n bin.push(data[i]);\n }\n }\n }\n return bins;\n }\n histogram.value = function(x) {\n if (!arguments.length) return valuer;\n valuer = x;\n return histogram;\n };\n histogram.range = function(x) {\n if (!arguments.length) return ranger;\n ranger = d3_functor(x);\n return histogram;\n };\n histogram.bins = function(x) {\n if (!arguments.length) return binner;\n binner = typeof x === \"number\" ? function(range) {\n return d3_layout_histogramBinFixed(range, x);\n } : d3_functor(x);\n return histogram;\n };\n histogram.frequency = function(x) {\n if (!arguments.length) return frequency;\n frequency = !!x;\n return histogram;\n };\n return histogram;\n };\n function d3_layout_histogramBinSturges(range, values) {\n return d3_layout_histogramBinFixed(range, Math.ceil(Math.log(values.length) / Math.LN2 + 1));\n }\n function d3_layout_histogramBinFixed(range, n) {\n var x = -1, b = +range[0], m = (range[1] - b) / n, f = [];\n while (++x <= n) f[x] = m * x + b;\n return f;\n }\n function d3_layout_histogramRange(values) {\n return [ d3.min(values), d3.max(values) ];\n }\n d3.layout.pack = function() {\n var hierarchy = d3.layout.hierarchy().sort(d3_layout_packSort), padding = 0, size = [ 1, 1 ], radius;\n function pack(d, i) {\n var nodes = hierarchy.call(this, d, i), root = nodes[0], w = size[0], h = size[1], r = radius == null ? Math.sqrt : typeof radius === \"function\" ? radius : function() {\n return radius;\n };\n root.x = root.y = 0;\n d3_layout_hierarchyVisitAfter(root, function(d) {\n d.r = +r(d.value);\n });\n d3_layout_hierarchyVisitAfter(root, d3_layout_packSiblings);\n if (padding) {\n var dr = padding * (radius ? 1 : Math.max(2 * root.r / w, 2 * root.r / h)) / 2;\n d3_layout_hierarchyVisitAfter(root, function(d) {\n d.r += dr;\n });\n d3_layout_hierarchyVisitAfter(root, d3_layout_packSiblings);\n d3_layout_hierarchyVisitAfter(root, function(d) {\n d.r -= dr;\n });\n }\n d3_layout_packTransform(root, w / 2, h / 2, radius ? 1 : 1 / Math.max(2 * root.r / w, 2 * root.r / h));\n return nodes;\n }\n pack.size = function(_) {\n if (!arguments.length) return size;\n size = _;\n return pack;\n };\n pack.radius = function(_) {\n if (!arguments.length) return radius;\n radius = _ == null || typeof _ === \"function\" ? _ : +_;\n return pack;\n };\n pack.padding = function(_) {\n if (!arguments.length) return padding;\n padding = +_;\n return pack;\n };\n return d3_layout_hierarchyRebind(pack, hierarchy);\n };\n function d3_layout_packSort(a, b) {\n return a.value - b.value;\n }\n function d3_layout_packInsert(a, b) {\n var c = a._pack_next;\n a._pack_next = b;\n b._pack_prev = a;\n b._pack_next = c;\n c._pack_prev = b;\n }\n function d3_layout_packSplice(a, b) {\n a._pack_next = b;\n b._pack_prev = a;\n }\n function d3_layout_packIntersects(a, b) {\n var dx = b.x - a.x, dy = b.y - a.y, dr = a.r + b.r;\n return .999 * dr * dr > dx * dx + dy * dy;\n }\n function d3_layout_packSiblings(node) {\n if (!(nodes = node.children) || !(n = nodes.length)) return;\n var nodes, xMin = Infinity, xMax = -Infinity, yMin = Infinity, yMax = -Infinity, a, b, c, i, j, k, n;\n function bound(node) {\n xMin = Math.min(node.x - node.r, xMin);\n xMax = Math.max(node.x + node.r, xMax);\n yMin = Math.min(node.y - node.r, yMin);\n yMax = Math.max(node.y + node.r, yMax);\n }\n nodes.forEach(d3_layout_packLink);\n a = nodes[0];\n a.x = -a.r;\n a.y = 0;\n bound(a);\n if (n > 1) {\n b = nodes[1];\n b.x = b.r;\n b.y = 0;\n bound(b);\n if (n > 2) {\n c = nodes[2];\n d3_layout_packPlace(a, b, c);\n bound(c);\n d3_layout_packInsert(a, c);\n a._pack_prev = c;\n d3_layout_packInsert(c, b);\n b = a._pack_next;\n for (i = 3; i < n; i++) {\n d3_layout_packPlace(a, b, c = nodes[i]);\n var isect = 0, s1 = 1, s2 = 1;\n for (j = b._pack_next; j !== b; j = j._pack_next, s1++) {\n if (d3_layout_packIntersects(j, c)) {\n isect = 1;\n break;\n }\n }\n if (isect == 1) {\n for (k = a._pack_prev; k !== j._pack_prev; k = k._pack_prev, s2++) {\n if (d3_layout_packIntersects(k, c)) {\n break;\n }\n }\n }\n if (isect) {\n if (s1 < s2 || s1 == s2 && b.r < a.r) d3_layout_packSplice(a, b = j); else d3_layout_packSplice(a = k, b);\n i--;\n } else {\n d3_layout_packInsert(a, c);\n b = c;\n bound(c);\n }\n }\n }\n }\n var cx = (xMin + xMax) / 2, cy = (yMin + yMax) / 2, cr = 0;\n for (i = 0; i < n; i++) {\n c = nodes[i];\n c.x -= cx;\n c.y -= cy;\n cr = Math.max(cr, c.r + Math.sqrt(c.x * c.x + c.y * c.y));\n }\n node.r = cr;\n nodes.forEach(d3_layout_packUnlink);\n }\n function d3_layout_packLink(node) {\n node._pack_next = node._pack_prev = node;\n }\n function d3_layout_packUnlink(node) {\n delete node._pack_next;\n delete node._pack_prev;\n }\n function d3_layout_packTransform(node, x, y, k) {\n var children = node.children;\n node.x = x += k * node.x;\n node.y = y += k * node.y;\n node.r *= k;\n if (children) {\n var i = -1, n = children.length;\n while (++i < n) d3_layout_packTransform(children[i], x, y, k);\n }\n }\n function d3_layout_packPlace(a, b, c) {\n var db = a.r + c.r, dx = b.x - a.x, dy = b.y - a.y;\n if (db && (dx || dy)) {\n var da = b.r + c.r, dc = dx * dx + dy * dy;\n da *= da;\n db *= db;\n var x = .5 + (db - da) / (2 * dc), y = Math.sqrt(Math.max(0, 2 * da * (db + dc) - (db -= dc) * db - da * da)) / (2 * dc);\n c.x = a.x + x * dx + y * dy;\n c.y = a.y + x * dy - y * dx;\n } else {\n c.x = a.x + db;\n c.y = a.y;\n }\n }\n d3.layout.tree = function() {\n var hierarchy = d3.layout.hierarchy().sort(null).value(null), separation = d3_layout_treeSeparation, size = [ 1, 1 ], nodeSize = null;\n function tree(d, i) {\n var nodes = hierarchy.call(this, d, i), root0 = nodes[0], root1 = wrapTree(root0);\n d3_layout_hierarchyVisitAfter(root1, firstWalk), root1.parent.m = -root1.z;\n d3_layout_hierarchyVisitBefore(root1, secondWalk);\n if (nodeSize) d3_layout_hierarchyVisitBefore(root0, sizeNode); else {\n var left = root0, right = root0, bottom = root0;\n d3_layout_hierarchyVisitBefore(root0, function(node) {\n if (node.x < left.x) left = node;\n if (node.x > right.x) right = node;\n if (node.depth > bottom.depth) bottom = node;\n });\n var tx = separation(left, right) / 2 - left.x, kx = size[0] / (right.x + separation(right, left) / 2 + tx), ky = size[1] / (bottom.depth || 1);\n d3_layout_hierarchyVisitBefore(root0, function(node) {\n node.x = (node.x + tx) * kx;\n node.y = node.depth * ky;\n });\n }\n return nodes;\n }\n function wrapTree(root0) {\n var root1 = {\n A: null,\n children: [ root0 ]\n }, queue = [ root1 ], node1;\n while ((node1 = queue.pop()) != null) {\n for (var children = node1.children, child, i = 0, n = children.length; i < n; ++i) {\n queue.push((children[i] = child = {\n _: children[i],\n parent: node1,\n children: (child = children[i].children) && child.slice() || [],\n A: null,\n a: null,\n z: 0,\n m: 0,\n c: 0,\n s: 0,\n t: null,\n i: i\n }).a = child);\n }\n }\n return root1.children[0];\n }\n function firstWalk(v) {\n var children = v.children, siblings = v.parent.children, w = v.i ? siblings[v.i - 1] : null;\n if (children.length) {\n d3_layout_treeShift(v);\n var midpoint = (children[0].z + children[children.length - 1].z) / 2;\n if (w) {\n v.z = w.z + separation(v._, w._);\n v.m = v.z - midpoint;\n } else {\n v.z = midpoint;\n }\n } else if (w) {\n v.z = w.z + separation(v._, w._);\n }\n v.parent.A = apportion(v, w, v.parent.A || siblings[0]);\n }\n function secondWalk(v) {\n v._.x = v.z + v.parent.m;\n v.m += v.parent.m;\n }\n function apportion(v, w, ancestor) {\n if (w) {\n var vip = v, vop = v, vim = w, vom = vip.parent.children[0], sip = vip.m, sop = vop.m, sim = vim.m, som = vom.m, shift;\n while (vim = d3_layout_treeRight(vim), vip = d3_layout_treeLeft(vip), vim && vip) {\n vom = d3_layout_treeLeft(vom);\n vop = d3_layout_treeRight(vop);\n vop.a = v;\n shift = vim.z + sim - vip.z - sip + separation(vim._, vip._);\n if (shift > 0) {\n d3_layout_treeMove(d3_layout_treeAncestor(vim, v, ancestor), v, shift);\n sip += shift;\n sop += shift;\n }\n sim += vim.m;\n sip += vip.m;\n som += vom.m;\n sop += vop.m;\n }\n if (vim && !d3_layout_treeRight(vop)) {\n vop.t = vim;\n vop.m += sim - sop;\n }\n if (vip && !d3_layout_treeLeft(vom)) {\n vom.t = vip;\n vom.m += sip - som;\n ancestor = v;\n }\n }\n return ancestor;\n }\n function sizeNode(node) {\n node.x *= size[0];\n node.y = node.depth * size[1];\n }\n tree.separation = function(x) {\n if (!arguments.length) return separation;\n separation = x;\n return tree;\n };\n tree.size = function(x) {\n if (!arguments.length) return nodeSize ? null : size;\n nodeSize = (size = x) == null ? sizeNode : null;\n return tree;\n };\n tree.nodeSize = function(x) {\n if (!arguments.length) return nodeSize ? size : null;\n nodeSize = (size = x) == null ? null : sizeNode;\n return tree;\n };\n return d3_layout_hierarchyRebind(tree, hierarchy);\n };\n function d3_layout_treeSeparation(a, b) {\n return a.parent == b.parent ? 1 : 2;\n }\n function d3_layout_treeLeft(v) {\n var children = v.children;\n return children.length ? children[0] : v.t;\n }\n function d3_layout_treeRight(v) {\n var children = v.children, n;\n return (n = children.length) ? children[n - 1] : v.t;\n }\n function d3_layout_treeMove(wm, wp, shift) {\n var change = shift / (wp.i - wm.i);\n wp.c -= change;\n wp.s += shift;\n wm.c += change;\n wp.z += shift;\n wp.m += shift;\n }\n function d3_layout_treeShift(v) {\n var shift = 0, change = 0, children = v.children, i = children.length, w;\n while (--i >= 0) {\n w = children[i];\n w.z += shift;\n w.m += shift;\n shift += w.s + (change += w.c);\n }\n }\n function d3_layout_treeAncestor(vim, v, ancestor) {\n return vim.a.parent === v.parent ? vim.a : ancestor;\n }\n d3.layout.cluster = function() {\n var hierarchy = d3.layout.hierarchy().sort(null).value(null), separation = d3_layout_treeSeparation, size = [ 1, 1 ], nodeSize = false;\n function cluster(d, i) {\n var nodes = hierarchy.call(this, d, i), root = nodes[0], previousNode, x = 0;\n d3_layout_hierarchyVisitAfter(root, function(node) {\n var children = node.children;\n if (children && children.length) {\n node.x = d3_layout_clusterX(children);\n node.y = d3_layout_clusterY(children);\n } else {\n node.x = previousNode ? x += separation(node, previousNode) : 0;\n node.y = 0;\n previousNode = node;\n }\n });\n var left = d3_layout_clusterLeft(root), right = d3_layout_clusterRight(root), x0 = left.x - separation(left, right) / 2, x1 = right.x + separation(right, left) / 2;\n d3_layout_hierarchyVisitAfter(root, nodeSize ? function(node) {\n node.x = (node.x - root.x) * size[0];\n node.y = (root.y - node.y) * size[1];\n } : function(node) {\n node.x = (node.x - x0) / (x1 - x0) * size[0];\n node.y = (1 - (root.y ? node.y / root.y : 1)) * size[1];\n });\n return nodes;\n }\n cluster.separation = function(x) {\n if (!arguments.length) return separation;\n separation = x;\n return cluster;\n };\n cluster.size = function(x) {\n if (!arguments.length) return nodeSize ? null : size;\n nodeSize = (size = x) == null;\n return cluster;\n };\n cluster.nodeSize = function(x) {\n if (!arguments.length) return nodeSize ? size : null;\n nodeSize = (size = x) != null;\n return cluster;\n };\n return d3_layout_hierarchyRebind(cluster, hierarchy);\n };\n function d3_layout_clusterY(children) {\n return 1 + d3.max(children, function(child) {\n return child.y;\n });\n }\n function d3_layout_clusterX(children) {\n return children.reduce(function(x, child) {\n return x + child.x;\n }, 0) / children.length;\n }\n function d3_layout_clusterLeft(node) {\n var children = node.children;\n return children && children.length ? d3_layout_clusterLeft(children[0]) : node;\n }\n function d3_layout_clusterRight(node) {\n var children = node.children, n;\n return children && (n = children.length) ? d3_layout_clusterRight(children[n - 1]) : node;\n }\n d3.layout.treemap = function() {\n var hierarchy = d3.layout.hierarchy(), round = Math.round, size = [ 1, 1 ], padding = null, pad = d3_layout_treemapPadNull, sticky = false, stickies, mode = \"squarify\", ratio = .5 * (1 + Math.sqrt(5));\n function scale(children, k) {\n var i = -1, n = children.length, child, area;\n while (++i < n) {\n area = (child = children[i]).value * (k < 0 ? 0 : k);\n child.area = isNaN(area) || area <= 0 ? 0 : area;\n }\n }\n function squarify(node) {\n var children = node.children;\n if (children && children.length) {\n var rect = pad(node), row = [], remaining = children.slice(), child, best = Infinity, score, u = mode === \"slice\" ? rect.dx : mode === \"dice\" ? rect.dy : mode === \"slice-dice\" ? node.depth & 1 ? rect.dy : rect.dx : Math.min(rect.dx, rect.dy), n;\n scale(remaining, rect.dx * rect.dy / node.value);\n row.area = 0;\n while ((n = remaining.length) > 0) {\n row.push(child = remaining[n - 1]);\n row.area += child.area;\n if (mode !== \"squarify\" || (score = worst(row, u)) <= best) {\n remaining.pop();\n best = score;\n } else {\n row.area -= row.pop().area;\n position(row, u, rect, false);\n u = Math.min(rect.dx, rect.dy);\n row.length = row.area = 0;\n best = Infinity;\n }\n }\n if (row.length) {\n position(row, u, rect, true);\n row.length = row.area = 0;\n }\n children.forEach(squarify);\n }\n }\n function stickify(node) {\n var children = node.children;\n if (children && children.length) {\n var rect = pad(node), remaining = children.slice(), child, row = [];\n scale(remaining, rect.dx * rect.dy / node.value);\n row.area = 0;\n while (child = remaining.pop()) {\n row.push(child);\n row.area += child.area;\n if (child.z != null) {\n position(row, child.z ? rect.dx : rect.dy, rect, !remaining.length);\n row.length = row.area = 0;\n }\n }\n children.forEach(stickify);\n }\n }\n function worst(row, u) {\n var s = row.area, r, rmax = 0, rmin = Infinity, i = -1, n = row.length;\n while (++i < n) {\n if (!(r = row[i].area)) continue;\n if (r < rmin) rmin = r;\n if (r > rmax) rmax = r;\n }\n s *= s;\n u *= u;\n return s ? Math.max(u * rmax * ratio / s, s / (u * rmin * ratio)) : Infinity;\n }\n function position(row, u, rect, flush) {\n var i = -1, n = row.length, x = rect.x, y = rect.y, v = u ? round(row.area / u) : 0, o;\n if (u == rect.dx) {\n if (flush || v > rect.dy) v = rect.dy;\n while (++i < n) {\n o = row[i];\n o.x = x;\n o.y = y;\n o.dy = v;\n x += o.dx = Math.min(rect.x + rect.dx - x, v ? round(o.area / v) : 0);\n }\n o.z = true;\n o.dx += rect.x + rect.dx - x;\n rect.y += v;\n rect.dy -= v;\n } else {\n if (flush || v > rect.dx) v = rect.dx;\n while (++i < n) {\n o = row[i];\n o.x = x;\n o.y = y;\n o.dx = v;\n y += o.dy = Math.min(rect.y + rect.dy - y, v ? round(o.area / v) : 0);\n }\n o.z = false;\n o.dy += rect.y + rect.dy - y;\n rect.x += v;\n rect.dx -= v;\n }\n }\n function treemap(d) {\n var nodes = stickies || hierarchy(d), root = nodes[0];\n root.x = root.y = 0;\n if (root.value) root.dx = size[0], root.dy = size[1]; else root.dx = root.dy = 0;\n if (stickies) hierarchy.revalue(root);\n scale([ root ], root.dx * root.dy / root.value);\n (stickies ? stickify : squarify)(root);\n if (sticky) stickies = nodes;\n return nodes;\n }\n treemap.size = function(x) {\n if (!arguments.length) return size;\n size = x;\n return treemap;\n };\n treemap.padding = function(x) {\n if (!arguments.length) return padding;\n function padFunction(node) {\n var p = x.call(treemap, node, node.depth);\n return p == null ? d3_layout_treemapPadNull(node) : d3_layout_treemapPad(node, typeof p === \"number\" ? [ p, p, p, p ] : p);\n }\n function padConstant(node) {\n return d3_layout_treemapPad(node, x);\n }\n var type;\n pad = (padding = x) == null ? d3_layout_treemapPadNull : (type = typeof x) === \"function\" ? padFunction : type === \"number\" ? (x = [ x, x, x, x ], \n padConstant) : padConstant;\n return treemap;\n };\n treemap.round = function(x) {\n if (!arguments.length) return round != Number;\n round = x ? Math.round : Number;\n return treemap;\n };\n treemap.sticky = function(x) {\n if (!arguments.length) return sticky;\n sticky = x;\n stickies = null;\n return treemap;\n };\n treemap.ratio = function(x) {\n if (!arguments.length) return ratio;\n ratio = x;\n return treemap;\n };\n treemap.mode = function(x) {\n if (!arguments.length) return mode;\n mode = x + \"\";\n return treemap;\n };\n return d3_layout_hierarchyRebind(treemap, hierarchy);\n };\n function d3_layout_treemapPadNull(node) {\n return {\n x: node.x,\n y: node.y,\n dx: node.dx,\n dy: node.dy\n };\n }\n function d3_layout_treemapPad(node, padding) {\n var x = node.x + padding[3], y = node.y + padding[0], dx = node.dx - padding[1] - padding[3], dy = node.dy - padding[0] - padding[2];\n if (dx < 0) {\n x += dx / 2;\n dx = 0;\n }\n if (dy < 0) {\n y += dy / 2;\n dy = 0;\n }\n return {\n x: x,\n y: y,\n dx: dx,\n dy: dy\n };\n }\n d3.random = {\n normal: function(mu, sigma) {\n var n = arguments.length;\n if (n < 2) sigma = 1;\n if (n < 1) mu = 0;\n return function() {\n var x, y, r;\n do {\n x = Math.random() * 2 - 1;\n y = Math.random() * 2 - 1;\n r = x * x + y * y;\n } while (!r || r > 1);\n return mu + sigma * x * Math.sqrt(-2 * Math.log(r) / r);\n };\n },\n logNormal: function() {\n var random = d3.random.normal.apply(d3, arguments);\n return function() {\n return Math.exp(random());\n };\n },\n bates: function(m) {\n var random = d3.random.irwinHall(m);\n return function() {\n return random() / m;\n };\n },\n irwinHall: function(m) {\n return function() {\n for (var s = 0, j = 0; j < m; j++) s += Math.random();\n return s;\n };\n }\n };\n d3.scale = {};\n function d3_scaleExtent(domain) {\n var start = domain[0], stop = domain[domain.length - 1];\n return start < stop ? [ start, stop ] : [ stop, start ];\n }\n function d3_scaleRange(scale) {\n return scale.rangeExtent ? scale.rangeExtent() : d3_scaleExtent(scale.range());\n }\n function d3_scale_bilinear(domain, range, uninterpolate, interpolate) {\n var u = uninterpolate(domain[0], domain[1]), i = interpolate(range[0], range[1]);\n return function(x) {\n return i(u(x));\n };\n }\n function d3_scale_nice(domain, nice) {\n var i0 = 0, i1 = domain.length - 1, x0 = domain[i0], x1 = domain[i1], dx;\n if (x1 < x0) {\n dx = i0, i0 = i1, i1 = dx;\n dx = x0, x0 = x1, x1 = dx;\n }\n domain[i0] = nice.floor(x0);\n domain[i1] = nice.ceil(x1);\n return domain;\n }\n function d3_scale_niceStep(step) {\n return step ? {\n floor: function(x) {\n return Math.floor(x / step) * step;\n },\n ceil: function(x) {\n return Math.ceil(x / step) * step;\n }\n } : d3_scale_niceIdentity;\n }\n var d3_scale_niceIdentity = {\n floor: d3_identity,\n ceil: d3_identity\n };\n function d3_scale_polylinear(domain, range, uninterpolate, interpolate) {\n var u = [], i = [], j = 0, k = Math.min(domain.length, range.length) - 1;\n if (domain[k] < domain[0]) {\n domain = domain.slice().reverse();\n range = range.slice().reverse();\n }\n while (++j <= k) {\n u.push(uninterpolate(domain[j - 1], domain[j]));\n i.push(interpolate(range[j - 1], range[j]));\n }\n return function(x) {\n var j = d3.bisect(domain, x, 1, k) - 1;\n return i[j](u[j](x));\n };\n }\n d3.scale.linear = function() {\n return d3_scale_linear([ 0, 1 ], [ 0, 1 ], d3_interpolate, false);\n };\n function d3_scale_linear(domain, range, interpolate, clamp) {\n var output, input;\n function rescale() {\n var linear = Math.min(domain.length, range.length) > 2 ? d3_scale_polylinear : d3_scale_bilinear, uninterpolate = clamp ? d3_uninterpolateClamp : d3_uninterpolateNumber;\n output = linear(domain, range, uninterpolate, interpolate);\n input = linear(range, domain, uninterpolate, d3_interpolate);\n return scale;\n }\n function scale(x) {\n return output(x);\n }\n scale.invert = function(y) {\n return input(y);\n };\n scale.domain = function(x) {\n if (!arguments.length) return domain;\n domain = x.map(Number);\n return rescale();\n };\n scale.range = function(x) {\n if (!arguments.length) return range;\n range = x;\n return rescale();\n };\n scale.rangeRound = function(x) {\n return scale.range(x).interpolate(d3_interpolateRound);\n };\n scale.clamp = function(x) {\n if (!arguments.length) return clamp;\n clamp = x;\n return rescale();\n };\n scale.interpolate = function(x) {\n if (!arguments.length) return interpolate;\n interpolate = x;\n return rescale();\n };\n scale.ticks = function(m) {\n return d3_scale_linearTicks(domain, m);\n };\n scale.tickFormat = function(m, format) {\n return d3_scale_linearTickFormat(domain, m, format);\n };\n scale.nice = function(m) {\n d3_scale_linearNice(domain, m);\n return rescale();\n };\n scale.copy = function() {\n return d3_scale_linear(domain, range, interpolate, clamp);\n };\n return rescale();\n }\n function d3_scale_linearRebind(scale, linear) {\n return d3.rebind(scale, linear, \"range\", \"rangeRound\", \"interpolate\", \"clamp\");\n }\n function d3_scale_linearNice(domain, m) {\n d3_scale_nice(domain, d3_scale_niceStep(d3_scale_linearTickRange(domain, m)[2]));\n d3_scale_nice(domain, d3_scale_niceStep(d3_scale_linearTickRange(domain, m)[2]));\n return domain;\n }\n function d3_scale_linearTickRange(domain, m) {\n if (m == null) m = 10;\n var extent = d3_scaleExtent(domain), span = extent[1] - extent[0], step = Math.pow(10, Math.floor(Math.log(span / m) / Math.LN10)), err = m / span * step;\n if (err <= .15) step *= 10; else if (err <= .35) step *= 5; else if (err <= .75) step *= 2;\n extent[0] = Math.ceil(extent[0] / step) * step;\n extent[1] = Math.floor(extent[1] / step) * step + step * .5;\n extent[2] = step;\n return extent;\n }\n function d3_scale_linearTicks(domain, m) {\n return d3.range.apply(d3, d3_scale_linearTickRange(domain, m));\n }\n var d3_scale_linearFormatSignificant = {\n s: 1,\n g: 1,\n p: 1,\n r: 1,\n e: 1\n };\n function d3_scale_linearPrecision(value) {\n return -Math.floor(Math.log(value) / Math.LN10 + .01);\n }\n function d3_scale_linearFormatPrecision(type, range) {\n var p = d3_scale_linearPrecision(range[2]);\n return type in d3_scale_linearFormatSignificant ? Math.abs(p - d3_scale_linearPrecision(Math.max(abs(range[0]), abs(range[1])))) + +(type !== \"e\") : p - (type === \"%\") * 2;\n }\n d3.scale.log = function() {\n return d3_scale_log(d3.scale.linear().domain([ 0, 1 ]), 10, true, [ 1, 10 ]);\n };\n function d3_scale_log(linear, base, positive, domain) {\n function log(x) {\n return (positive ? Math.log(x < 0 ? 0 : x) : -Math.log(x > 0 ? 0 : -x)) / Math.log(base);\n }\n function pow(x) {\n return positive ? Math.pow(base, x) : -Math.pow(base, -x);\n }\n function scale(x) {\n return linear(log(x));\n }\n scale.invert = function(x) {\n return pow(linear.invert(x));\n };\n scale.domain = function(x) {\n if (!arguments.length) return domain;\n positive = x[0] >= 0;\n linear.domain((domain = x.map(Number)).map(log));\n return scale;\n };\n scale.base = function(_) {\n if (!arguments.length) return base;\n base = +_;\n linear.domain(domain.map(log));\n return scale;\n };\n scale.nice = function() {\n var niced = d3_scale_nice(domain.map(log), positive ? Math : d3_scale_logNiceNegative);\n linear.domain(niced);\n domain = niced.map(pow);\n return scale;\n };\n scale.ticks = function() {\n var extent = d3_scaleExtent(domain), ticks = [], u = extent[0], v = extent[1], i = Math.floor(log(u)), j = Math.ceil(log(v)), n = base % 1 ? 2 : base;\n if (isFinite(j - i)) {\n if (positive) {\n for (;i < j; i++) for (var k = 1; k < n; k++) ticks.push(pow(i) * k);\n ticks.push(pow(i));\n } else {\n ticks.push(pow(i));\n for (;i++ < j; ) for (var k = n - 1; k > 0; k--) ticks.push(pow(i) * k);\n }\n for (i = 0; ticks[i] < u; i++) {}\n for (j = ticks.length; ticks[j - 1] > v; j--) {}\n ticks = ticks.slice(i, j);\n }\n return ticks;\n };\n scale.copy = function() {\n return d3_scale_log(linear.copy(), base, positive, domain);\n };\n return d3_scale_linearRebind(scale, linear);\n }\n var d3_scale_logNiceNegative = {\n floor: function(x) {\n return -Math.ceil(-x);\n },\n ceil: function(x) {\n return -Math.floor(-x);\n }\n };\n d3.scale.pow = function() {\n return d3_scale_pow(d3.scale.linear(), 1, [ 0, 1 ]);\n };\n function d3_scale_pow(linear, exponent, domain) {\n var powp = d3_scale_powPow(exponent), powb = d3_scale_powPow(1 / exponent);\n function scale(x) {\n return linear(powp(x));\n }\n scale.invert = function(x) {\n return powb(linear.invert(x));\n };\n scale.domain = function(x) {\n if (!arguments.length) return domain;\n linear.domain((domain = x.map(Number)).map(powp));\n return scale;\n };\n scale.ticks = function(m) {\n return d3_scale_linearTicks(domain, m);\n };\n scale.tickFormat = function(m, format) {\n return d3_scale_linearTickFormat(domain, m, format);\n };\n scale.nice = function(m) {\n return scale.domain(d3_scale_linearNice(domain, m));\n };\n scale.exponent = function(x) {\n if (!arguments.length) return exponent;\n powp = d3_scale_powPow(exponent = x);\n powb = d3_scale_powPow(1 / exponent);\n linear.domain(domain.map(powp));\n return scale;\n };\n scale.copy = function() {\n return d3_scale_pow(linear.copy(), exponent, domain);\n };\n return d3_scale_linearRebind(scale, linear);\n }\n function d3_scale_powPow(e) {\n return function(x) {\n return x < 0 ? -Math.pow(-x, e) : Math.pow(x, e);\n };\n }\n d3.scale.sqrt = function() {\n return d3.scale.pow().exponent(.5);\n };\n d3.scale.ordinal = function() {\n return d3_scale_ordinal([], {\n t: \"range\",\n a: [ [] ]\n });\n };\n function d3_scale_ordinal(domain, ranger) {\n var index, range, rangeBand;\n function scale(x) {\n return range[((index.get(x) || (ranger.t === \"range\" ? index.set(x, domain.push(x)) : NaN)) - 1) % range.length];\n }\n function steps(start, step) {\n return d3.range(domain.length).map(function(i) {\n return start + step * i;\n });\n }\n scale.domain = function(x) {\n if (!arguments.length) return domain;\n domain = [];\n index = new d3_Map();\n var i = -1, n = x.length, xi;\n while (++i < n) if (!index.has(xi = x[i])) index.set(xi, domain.push(xi));\n return scale[ranger.t].apply(scale, ranger.a);\n };\n scale.range = function(x) {\n if (!arguments.length) return range;\n range = x;\n rangeBand = 0;\n ranger = {\n t: \"range\",\n a: arguments\n };\n return scale;\n };\n scale.rangePoints = function(x, padding) {\n if (arguments.length < 2) padding = 0;\n var start = x[0], stop = x[1], step = domain.length < 2 ? (start = (start + stop) / 2, \n 0) : (stop - start) / (domain.length - 1 + padding);\n range = steps(start + step * padding / 2, step);\n rangeBand = 0;\n ranger = {\n t: \"rangePoints\",\n a: arguments\n };\n return scale;\n };\n scale.rangeRoundPoints = function(x, padding) {\n if (arguments.length < 2) padding = 0;\n var start = x[0], stop = x[1], step = domain.length < 2 ? (start = stop = Math.round((start + stop) / 2), \n 0) : (stop - start) / (domain.length - 1 + padding) | 0;\n range = steps(start + Math.round(step * padding / 2 + (stop - start - (domain.length - 1 + padding) * step) / 2), step);\n rangeBand = 0;\n ranger = {\n t: \"rangeRoundPoints\",\n a: arguments\n };\n return scale;\n };\n scale.rangeBands = function(x, padding, outerPadding) {\n if (arguments.length < 2) padding = 0;\n if (arguments.length < 3) outerPadding = padding;\n var reverse = x[1] < x[0], start = x[reverse - 0], stop = x[1 - reverse], step = (stop - start) / (domain.length - padding + 2 * outerPadding);\n range = steps(start + step * outerPadding, step);\n if (reverse) range.reverse();\n rangeBand = step * (1 - padding);\n ranger = {\n t: \"rangeBands\",\n a: arguments\n };\n return scale;\n };\n scale.rangeRoundBands = function(x, padding, outerPadding) {\n if (arguments.length < 2) padding = 0;\n if (arguments.length < 3) outerPadding = padding;\n var reverse = x[1] < x[0], start = x[reverse - 0], stop = x[1 - reverse], step = Math.floor((stop - start) / (domain.length - padding + 2 * outerPadding));\n range = steps(start + Math.round((stop - start - (domain.length - padding) * step) / 2), step);\n if (reverse) range.reverse();\n rangeBand = Math.round(step * (1 - padding));\n ranger = {\n t: \"rangeRoundBands\",\n a: arguments\n };\n return scale;\n };\n scale.rangeBand = function() {\n return rangeBand;\n };\n scale.rangeExtent = function() {\n return d3_scaleExtent(ranger.a[0]);\n };\n scale.copy = function() {\n return d3_scale_ordinal(domain, ranger);\n };\n return scale.domain(domain);\n }\n d3.scale.category10 = function() {\n return d3.scale.ordinal().range(d3_category10);\n };\n d3.scale.category20 = function() {\n return d3.scale.ordinal().range(d3_category20);\n };\n d3.scale.category20b = function() {\n return d3.scale.ordinal().range(d3_category20b);\n };\n d3.scale.category20c = function() {\n return d3.scale.ordinal().range(d3_category20c);\n };\n var d3_category10 = [ 2062260, 16744206, 2924588, 14034728, 9725885, 9197131, 14907330, 8355711, 12369186, 1556175 ].map(d3_rgbString);\n var d3_category20 = [ 2062260, 11454440, 16744206, 16759672, 2924588, 10018698, 14034728, 16750742, 9725885, 12955861, 9197131, 12885140, 14907330, 16234194, 8355711, 13092807, 12369186, 14408589, 1556175, 10410725 ].map(d3_rgbString);\n var d3_category20b = [ 3750777, 5395619, 7040719, 10264286, 6519097, 9216594, 11915115, 13556636, 9202993, 12426809, 15186514, 15190932, 8666169, 11356490, 14049643, 15177372, 8077683, 10834324, 13528509, 14589654 ].map(d3_rgbString);\n var d3_category20c = [ 3244733, 7057110, 10406625, 13032431, 15095053, 16616764, 16625259, 16634018, 3253076, 7652470, 10607003, 13101504, 7695281, 10394312, 12369372, 14342891, 6513507, 9868950, 12434877, 14277081 ].map(d3_rgbString);\n d3.scale.quantile = function() {\n return d3_scale_quantile([], []);\n };\n function d3_scale_quantile(domain, range) {\n var thresholds;\n function rescale() {\n var k = 0, q = range.length;\n thresholds = [];\n while (++k < q) thresholds[k - 1] = d3.quantile(domain, k / q);\n return scale;\n }\n function scale(x) {\n if (!isNaN(x = +x)) return range[d3.bisect(thresholds, x)];\n }\n scale.domain = function(x) {\n if (!arguments.length) return domain;\n domain = x.map(d3_number).filter(d3_numeric).sort(d3_ascending);\n return rescale();\n };\n scale.range = function(x) {\n if (!arguments.length) return range;\n range = x;\n return rescale();\n };\n scale.quantiles = function() {\n return thresholds;\n };\n scale.invertExtent = function(y) {\n y = range.indexOf(y);\n return y < 0 ? [ NaN, NaN ] : [ y > 0 ? thresholds[y - 1] : domain[0], y < thresholds.length ? thresholds[y] : domain[domain.length - 1] ];\n };\n scale.copy = function() {\n return d3_scale_quantile(domain, range);\n };\n return rescale();\n }\n d3.scale.quantize = function() {\n return d3_scale_quantize(0, 1, [ 0, 1 ]);\n };\n function d3_scale_quantize(x0, x1, range) {\n var kx, i;\n function scale(x) {\n return range[Math.max(0, Math.min(i, Math.floor(kx * (x - x0))))];\n }\n function rescale() {\n kx = range.length / (x1 - x0);\n i = range.length - 1;\n return scale;\n }\n scale.domain = function(x) {\n if (!arguments.length) return [ x0, x1 ];\n x0 = +x[0];\n x1 = +x[x.length - 1];\n return rescale();\n };\n scale.range = function(x) {\n if (!arguments.length) return range;\n range = x;\n return rescale();\n };\n scale.invertExtent = function(y) {\n y = range.indexOf(y);\n y = y < 0 ? NaN : y / kx + x0;\n return [ y, y + 1 / kx ];\n };\n scale.copy = function() {\n return d3_scale_quantize(x0, x1, range);\n };\n return rescale();\n }\n d3.scale.threshold = function() {\n return d3_scale_threshold([ .5 ], [ 0, 1 ]);\n };\n function d3_scale_threshold(domain, range) {\n function scale(x) {\n if (x <= x) return range[d3.bisect(domain, x)];\n }\n scale.domain = function(_) {\n if (!arguments.length) return domain;\n domain = _;\n return scale;\n };\n scale.range = function(_) {\n if (!arguments.length) return range;\n range = _;\n return scale;\n };\n scale.invertExtent = function(y) {\n y = range.indexOf(y);\n return [ domain[y - 1], domain[y] ];\n };\n scale.copy = function() {\n return d3_scale_threshold(domain, range);\n };\n return scale;\n }\n d3.scale.identity = function() {\n return d3_scale_identity([ 0, 1 ]);\n };\n function d3_scale_identity(domain) {\n function identity(x) {\n return +x;\n }\n identity.invert = identity;\n identity.domain = identity.range = function(x) {\n if (!arguments.length) return domain;\n domain = x.map(identity);\n return identity;\n };\n identity.ticks = function(m) {\n return d3_scale_linearTicks(domain, m);\n };\n identity.tickFormat = function(m, format) {\n return d3_scale_linearTickFormat(domain, m, format);\n };\n identity.copy = function() {\n return d3_scale_identity(domain);\n };\n return identity;\n }\n d3.svg = {};\n function d3_zero() {\n return 0;\n }\n d3.svg.arc = function() {\n var innerRadius = d3_svg_arcInnerRadius, outerRadius = d3_svg_arcOuterRadius, cornerRadius = d3_zero, padRadius = d3_svg_arcAuto, startAngle = d3_svg_arcStartAngle, endAngle = d3_svg_arcEndAngle, padAngle = d3_svg_arcPadAngle;\n function arc() {\n var r0 = Math.max(0, +innerRadius.apply(this, arguments)), r1 = Math.max(0, +outerRadius.apply(this, arguments)), a0 = startAngle.apply(this, arguments) - halfπ, a1 = endAngle.apply(this, arguments) - halfπ, da = Math.abs(a1 - a0), cw = a0 > a1 ? 0 : 1;\n if (r1 < r0) rc = r1, r1 = r0, r0 = rc;\n if (da >= τε) return circleSegment(r1, cw) + (r0 ? circleSegment(r0, 1 - cw) : \"\") + \"Z\";\n var rc, cr, rp, ap, p0 = 0, p1 = 0, x0, y0, x1, y1, x2, y2, x3, y3, path = [];\n if (ap = (+padAngle.apply(this, arguments) || 0) / 2) {\n rp = padRadius === d3_svg_arcAuto ? Math.sqrt(r0 * r0 + r1 * r1) : +padRadius.apply(this, arguments);\n if (!cw) p1 *= -1;\n if (r1) p1 = d3_asin(rp / r1 * Math.sin(ap));\n if (r0) p0 = d3_asin(rp / r0 * Math.sin(ap));\n }\n if (r1) {\n x0 = r1 * Math.cos(a0 + p1);\n y0 = r1 * Math.sin(a0 + p1);\n x1 = r1 * Math.cos(a1 - p1);\n y1 = r1 * Math.sin(a1 - p1);\n var l1 = Math.abs(a1 - a0 - 2 * p1) <= π ? 0 : 1;\n if (p1 && d3_svg_arcSweep(x0, y0, x1, y1) === cw ^ l1) {\n var h1 = (a0 + a1) / 2;\n x0 = r1 * Math.cos(h1);\n y0 = r1 * Math.sin(h1);\n x1 = y1 = null;\n }\n } else {\n x0 = y0 = 0;\n }\n if (r0) {\n x2 = r0 * Math.cos(a1 - p0);\n y2 = r0 * Math.sin(a1 - p0);\n x3 = r0 * Math.cos(a0 + p0);\n y3 = r0 * Math.sin(a0 + p0);\n var l0 = Math.abs(a0 - a1 + 2 * p0) <= π ? 0 : 1;\n if (p0 && d3_svg_arcSweep(x2, y2, x3, y3) === 1 - cw ^ l0) {\n var h0 = (a0 + a1) / 2;\n x2 = r0 * Math.cos(h0);\n y2 = r0 * Math.sin(h0);\n x3 = y3 = null;\n }\n } else {\n x2 = y2 = 0;\n }\n if (da > ε && (rc = Math.min(Math.abs(r1 - r0) / 2, +cornerRadius.apply(this, arguments))) > .001) {\n cr = r0 < r1 ^ cw ? 0 : 1;\n var rc1 = rc, rc0 = rc;\n if (da < π) {\n var oc = x3 == null ? [ x2, y2 ] : x1 == null ? [ x0, y0 ] : d3_geom_polygonIntersect([ x0, y0 ], [ x3, y3 ], [ x1, y1 ], [ x2, y2 ]), ax = x0 - oc[0], ay = y0 - oc[1], bx = x1 - oc[0], by = y1 - oc[1], kc = 1 / Math.sin(Math.acos((ax * bx + ay * by) / (Math.sqrt(ax * ax + ay * ay) * Math.sqrt(bx * bx + by * by))) / 2), lc = Math.sqrt(oc[0] * oc[0] + oc[1] * oc[1]);\n rc0 = Math.min(rc, (r0 - lc) / (kc - 1));\n rc1 = Math.min(rc, (r1 - lc) / (kc + 1));\n }\n if (x1 != null) {\n var t30 = d3_svg_arcCornerTangents(x3 == null ? [ x2, y2 ] : [ x3, y3 ], [ x0, y0 ], r1, rc1, cw), t12 = d3_svg_arcCornerTangents([ x1, y1 ], [ x2, y2 ], r1, rc1, cw);\n if (rc === rc1) {\n path.push(\"M\", t30[0], \"A\", rc1, \",\", rc1, \" 0 0,\", cr, \" \", t30[1], \"A\", r1, \",\", r1, \" 0 \", 1 - cw ^ d3_svg_arcSweep(t30[1][0], t30[1][1], t12[1][0], t12[1][1]), \",\", cw, \" \", t12[1], \"A\", rc1, \",\", rc1, \" 0 0,\", cr, \" \", t12[0]);\n } else {\n path.push(\"M\", t30[0], \"A\", rc1, \",\", rc1, \" 0 1,\", cr, \" \", t12[0]);\n }\n } else {\n path.push(\"M\", x0, \",\", y0);\n }\n if (x3 != null) {\n var t03 = d3_svg_arcCornerTangents([ x0, y0 ], [ x3, y3 ], r0, -rc0, cw), t21 = d3_svg_arcCornerTangents([ x2, y2 ], x1 == null ? [ x0, y0 ] : [ x1, y1 ], r0, -rc0, cw);\n if (rc === rc0) {\n path.push(\"L\", t21[0], \"A\", rc0, \",\", rc0, \" 0 0,\", cr, \" \", t21[1], \"A\", r0, \",\", r0, \" 0 \", cw ^ d3_svg_arcSweep(t21[1][0], t21[1][1], t03[1][0], t03[1][1]), \",\", 1 - cw, \" \", t03[1], \"A\", rc0, \",\", rc0, \" 0 0,\", cr, \" \", t03[0]);\n } else {\n path.push(\"L\", t21[0], \"A\", rc0, \",\", rc0, \" 0 0,\", cr, \" \", t03[0]);\n }\n } else {\n path.push(\"L\", x2, \",\", y2);\n }\n } else {\n path.push(\"M\", x0, \",\", y0);\n if (x1 != null) path.push(\"A\", r1, \",\", r1, \" 0 \", l1, \",\", cw, \" \", x1, \",\", y1);\n path.push(\"L\", x2, \",\", y2);\n if (x3 != null) path.push(\"A\", r0, \",\", r0, \" 0 \", l0, \",\", 1 - cw, \" \", x3, \",\", y3);\n }\n path.push(\"Z\");\n return path.join(\"\");\n }\n function circleSegment(r1, cw) {\n return \"M0,\" + r1 + \"A\" + r1 + \",\" + r1 + \" 0 1,\" + cw + \" 0,\" + -r1 + \"A\" + r1 + \",\" + r1 + \" 0 1,\" + cw + \" 0,\" + r1;\n }\n arc.innerRadius = function(v) {\n if (!arguments.length) return innerRadius;\n innerRadius = d3_functor(v);\n return arc;\n };\n arc.outerRadius = function(v) {\n if (!arguments.length) return outerRadius;\n outerRadius = d3_functor(v);\n return arc;\n };\n arc.cornerRadius = function(v) {\n if (!arguments.length) return cornerRadius;\n cornerRadius = d3_functor(v);\n return arc;\n };\n arc.padRadius = function(v) {\n if (!arguments.length) return padRadius;\n padRadius = v == d3_svg_arcAuto ? d3_svg_arcAuto : d3_functor(v);\n return arc;\n };\n arc.startAngle = function(v) {\n if (!arguments.length) return startAngle;\n startAngle = d3_functor(v);\n return arc;\n };\n arc.endAngle = function(v) {\n if (!arguments.length) return endAngle;\n endAngle = d3_functor(v);\n return arc;\n };\n arc.padAngle = function(v) {\n if (!arguments.length) return padAngle;\n padAngle = d3_functor(v);\n return arc;\n };\n arc.centroid = function() {\n var r = (+innerRadius.apply(this, arguments) + +outerRadius.apply(this, arguments)) / 2, a = (+startAngle.apply(this, arguments) + +endAngle.apply(this, arguments)) / 2 - halfπ;\n return [ Math.cos(a) * r, Math.sin(a) * r ];\n };\n return arc;\n };\n var d3_svg_arcAuto = \"auto\";\n function d3_svg_arcInnerRadius(d) {\n return d.innerRadius;\n }\n function d3_svg_arcOuterRadius(d) {\n return d.outerRadius;\n }\n function d3_svg_arcStartAngle(d) {\n return d.startAngle;\n }\n function d3_svg_arcEndAngle(d) {\n return d.endAngle;\n }\n function d3_svg_arcPadAngle(d) {\n return d && d.padAngle;\n }\n function d3_svg_arcSweep(x0, y0, x1, y1) {\n return (x0 - x1) * y0 - (y0 - y1) * x0 > 0 ? 0 : 1;\n }\n function d3_svg_arcCornerTangents(p0, p1, r1, rc, cw) {\n var x01 = p0[0] - p1[0], y01 = p0[1] - p1[1], lo = (cw ? rc : -rc) / Math.sqrt(x01 * x01 + y01 * y01), ox = lo * y01, oy = -lo * x01, x1 = p0[0] + ox, y1 = p0[1] + oy, x2 = p1[0] + ox, y2 = p1[1] + oy, x3 = (x1 + x2) / 2, y3 = (y1 + y2) / 2, dx = x2 - x1, dy = y2 - y1, d2 = dx * dx + dy * dy, r = r1 - rc, D = x1 * y2 - x2 * y1, d = (dy < 0 ? -1 : 1) * Math.sqrt(Math.max(0, r * r * d2 - D * D)), cx0 = (D * dy - dx * d) / d2, cy0 = (-D * dx - dy * d) / d2, cx1 = (D * dy + dx * d) / d2, cy1 = (-D * dx + dy * d) / d2, dx0 = cx0 - x3, dy0 = cy0 - y3, dx1 = cx1 - x3, dy1 = cy1 - y3;\n if (dx0 * dx0 + dy0 * dy0 > dx1 * dx1 + dy1 * dy1) cx0 = cx1, cy0 = cy1;\n return [ [ cx0 - ox, cy0 - oy ], [ cx0 * r1 / r, cy0 * r1 / r ] ];\n }\n function d3_true() {\n return true;\n }\n function d3_svg_line(projection) {\n var x = d3_geom_pointX, y = d3_geom_pointY, defined = d3_true, interpolate = d3_svg_lineLinear, interpolateKey = interpolate.key, tension = .7;\n function line(data) {\n var segments = [], points = [], i = -1, n = data.length, d, fx = d3_functor(x), fy = d3_functor(y);\n function segment() {\n segments.push(\"M\", interpolate(projection(points), tension));\n }\n while (++i < n) {\n if (defined.call(this, d = data[i], i)) {\n points.push([ +fx.call(this, d, i), +fy.call(this, d, i) ]);\n } else if (points.length) {\n segment();\n points = [];\n }\n }\n if (points.length) segment();\n return segments.length ? segments.join(\"\") : null;\n }\n line.x = function(_) {\n if (!arguments.length) return x;\n x = _;\n return line;\n };\n line.y = function(_) {\n if (!arguments.length) return y;\n y = _;\n return line;\n };\n line.defined = function(_) {\n if (!arguments.length) return defined;\n defined = _;\n return line;\n };\n line.interpolate = function(_) {\n if (!arguments.length) return interpolateKey;\n if (typeof _ === \"function\") interpolateKey = interpolate = _; else interpolateKey = (interpolate = d3_svg_lineInterpolators.get(_) || d3_svg_lineLinear).key;\n return line;\n };\n line.tension = function(_) {\n if (!arguments.length) return tension;\n tension = _;\n return line;\n };\n return line;\n }\n d3.svg.line = function() {\n return d3_svg_line(d3_identity);\n };\n var d3_svg_lineInterpolators = d3.map({\n linear: d3_svg_lineLinear,\n \"linear-closed\": d3_svg_lineLinearClosed,\n step: d3_svg_lineStep,\n \"step-before\": d3_svg_lineStepBefore,\n \"step-after\": d3_svg_lineStepAfter,\n basis: d3_svg_lineBasis,\n \"basis-open\": d3_svg_lineBasisOpen,\n \"basis-closed\": d3_svg_lineBasisClosed,\n bundle: d3_svg_lineBundle,\n cardinal: d3_svg_lineCardinal,\n \"cardinal-open\": d3_svg_lineCardinalOpen,\n \"cardinal-closed\": d3_svg_lineCardinalClosed,\n monotone: d3_svg_lineMonotone\n });\n d3_svg_lineInterpolators.forEach(function(key, value) {\n value.key = key;\n value.closed = /-closed$/.test(key);\n });\n function d3_svg_lineLinear(points) {\n return points.length > 1 ? points.join(\"L\") : points + \"Z\";\n }\n function d3_svg_lineLinearClosed(points) {\n return points.join(\"L\") + \"Z\";\n }\n function d3_svg_lineStep(points) {\n var i = 0, n = points.length, p = points[0], path = [ p[0], \",\", p[1] ];\n while (++i < n) path.push(\"H\", (p[0] + (p = points[i])[0]) / 2, \"V\", p[1]);\n if (n > 1) path.push(\"H\", p[0]);\n return path.join(\"\");\n }\n function d3_svg_lineStepBefore(points) {\n var i = 0, n = points.length, p = points[0], path = [ p[0], \",\", p[1] ];\n while (++i < n) path.push(\"V\", (p = points[i])[1], \"H\", p[0]);\n return path.join(\"\");\n }\n function d3_svg_lineStepAfter(points) {\n var i = 0, n = points.length, p = points[0], path = [ p[0], \",\", p[1] ];\n while (++i < n) path.push(\"H\", (p = points[i])[0], \"V\", p[1]);\n return path.join(\"\");\n }\n function d3_svg_lineCardinalOpen(points, tension) {\n return points.length < 4 ? d3_svg_lineLinear(points) : points[1] + d3_svg_lineHermite(points.slice(1, -1), d3_svg_lineCardinalTangents(points, tension));\n }\n function d3_svg_lineCardinalClosed(points, tension) {\n return points.length < 3 ? d3_svg_lineLinearClosed(points) : points[0] + d3_svg_lineHermite((points.push(points[0]), \n points), d3_svg_lineCardinalTangents([ points[points.length - 2] ].concat(points, [ points[1] ]), tension));\n }\n function d3_svg_lineCardinal(points, tension) {\n return points.length < 3 ? d3_svg_lineLinear(points) : points[0] + d3_svg_lineHermite(points, d3_svg_lineCardinalTangents(points, tension));\n }\n function d3_svg_lineHermite(points, tangents) {\n if (tangents.length < 1 || points.length != tangents.length && points.length != tangents.length + 2) {\n return d3_svg_lineLinear(points);\n }\n var quad = points.length != tangents.length, path = \"\", p0 = points[0], p = points[1], t0 = tangents[0], t = t0, pi = 1;\n if (quad) {\n path += \"Q\" + (p[0] - t0[0] * 2 / 3) + \",\" + (p[1] - t0[1] * 2 / 3) + \",\" + p[0] + \",\" + p[1];\n p0 = points[1];\n pi = 2;\n }\n if (tangents.length > 1) {\n t = tangents[1];\n p = points[pi];\n pi++;\n path += \"C\" + (p0[0] + t0[0]) + \",\" + (p0[1] + t0[1]) + \",\" + (p[0] - t[0]) + \",\" + (p[1] - t[1]) + \",\" + p[0] + \",\" + p[1];\n for (var i = 2; i < tangents.length; i++, pi++) {\n p = points[pi];\n t = tangents[i];\n path += \"S\" + (p[0] - t[0]) + \",\" + (p[1] - t[1]) + \",\" + p[0] + \",\" + p[1];\n }\n }\n if (quad) {\n var lp = points[pi];\n path += \"Q\" + (p[0] + t[0] * 2 / 3) + \",\" + (p[1] + t[1] * 2 / 3) + \",\" + lp[0] + \",\" + lp[1];\n }\n return path;\n }\n function d3_svg_lineCardinalTangents(points, tension) {\n var tangents = [], a = (1 - tension) / 2, p0, p1 = points[0], p2 = points[1], i = 1, n = points.length;\n while (++i < n) {\n p0 = p1;\n p1 = p2;\n p2 = points[i];\n tangents.push([ a * (p2[0] - p0[0]), a * (p2[1] - p0[1]) ]);\n }\n return tangents;\n }\n function d3_svg_lineBasis(points) {\n if (points.length < 3) return d3_svg_lineLinear(points);\n var i = 1, n = points.length, pi = points[0], x0 = pi[0], y0 = pi[1], px = [ x0, x0, x0, (pi = points[1])[0] ], py = [ y0, y0, y0, pi[1] ], path = [ x0, \",\", y0, \"L\", d3_svg_lineDot4(d3_svg_lineBasisBezier3, px), \",\", d3_svg_lineDot4(d3_svg_lineBasisBezier3, py) ];\n points.push(points[n - 1]);\n while (++i <= n) {\n pi = points[i];\n px.shift();\n px.push(pi[0]);\n py.shift();\n py.push(pi[1]);\n d3_svg_lineBasisBezier(path, px, py);\n }\n points.pop();\n path.push(\"L\", pi);\n return path.join(\"\");\n }\n function d3_svg_lineBasisOpen(points) {\n if (points.length < 4) return d3_svg_lineLinear(points);\n var path = [], i = -1, n = points.length, pi, px = [ 0 ], py = [ 0 ];\n while (++i < 3) {\n pi = points[i];\n px.push(pi[0]);\n py.push(pi[1]);\n }\n path.push(d3_svg_lineDot4(d3_svg_lineBasisBezier3, px) + \",\" + d3_svg_lineDot4(d3_svg_lineBasisBezier3, py));\n --i;\n while (++i < n) {\n pi = points[i];\n px.shift();\n px.push(pi[0]);\n py.shift();\n py.push(pi[1]);\n d3_svg_lineBasisBezier(path, px, py);\n }\n return path.join(\"\");\n }\n function d3_svg_lineBasisClosed(points) {\n var path, i = -1, n = points.length, m = n + 4, pi, px = [], py = [];\n while (++i < 4) {\n pi = points[i % n];\n px.push(pi[0]);\n py.push(pi[1]);\n }\n path = [ d3_svg_lineDot4(d3_svg_lineBasisBezier3, px), \",\", d3_svg_lineDot4(d3_svg_lineBasisBezier3, py) ];\n --i;\n while (++i < m) {\n pi = points[i % n];\n px.shift();\n px.push(pi[0]);\n py.shift();\n py.push(pi[1]);\n d3_svg_lineBasisBezier(path, px, py);\n }\n return path.join(\"\");\n }\n function d3_svg_lineBundle(points, tension) {\n var n = points.length - 1;\n if (n) {\n var x0 = points[0][0], y0 = points[0][1], dx = points[n][0] - x0, dy = points[n][1] - y0, i = -1, p, t;\n while (++i <= n) {\n p = points[i];\n t = i / n;\n p[0] = tension * p[0] + (1 - tension) * (x0 + t * dx);\n p[1] = tension * p[1] + (1 - tension) * (y0 + t * dy);\n }\n }\n return d3_svg_lineBasis(points);\n }\n function d3_svg_lineDot4(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];\n }\n var d3_svg_lineBasisBezier1 = [ 0, 2 / 3, 1 / 3, 0 ], d3_svg_lineBasisBezier2 = [ 0, 1 / 3, 2 / 3, 0 ], d3_svg_lineBasisBezier3 = [ 0, 1 / 6, 2 / 3, 1 / 6 ];\n function d3_svg_lineBasisBezier(path, x, y) {\n path.push(\"C\", d3_svg_lineDot4(d3_svg_lineBasisBezier1, x), \",\", d3_svg_lineDot4(d3_svg_lineBasisBezier1, y), \",\", d3_svg_lineDot4(d3_svg_lineBasisBezier2, x), \",\", d3_svg_lineDot4(d3_svg_lineBasisBezier2, y), \",\", d3_svg_lineDot4(d3_svg_lineBasisBezier3, x), \",\", d3_svg_lineDot4(d3_svg_lineBasisBezier3, y));\n }\n function d3_svg_lineSlope(p0, p1) {\n return (p1[1] - p0[1]) / (p1[0] - p0[0]);\n }\n function d3_svg_lineFiniteDifferences(points) {\n var i = 0, j = points.length - 1, m = [], p0 = points[0], p1 = points[1], d = m[0] = d3_svg_lineSlope(p0, p1);\n while (++i < j) {\n m[i] = (d + (d = d3_svg_lineSlope(p0 = p1, p1 = points[i + 1]))) / 2;\n }\n m[i] = d;\n return m;\n }\n function d3_svg_lineMonotoneTangents(points) {\n var tangents = [], d, a, b, s, m = d3_svg_lineFiniteDifferences(points), i = -1, j = points.length - 1;\n while (++i < j) {\n d = d3_svg_lineSlope(points[i], points[i + 1]);\n if (abs(d) < ε) {\n m[i] = m[i + 1] = 0;\n } else {\n a = m[i] / d;\n b = m[i + 1] / d;\n s = a * a + b * b;\n if (s > 9) {\n s = d * 3 / Math.sqrt(s);\n m[i] = s * a;\n m[i + 1] = s * b;\n }\n }\n }\n i = -1;\n while (++i <= j) {\n s = (points[Math.min(j, i + 1)][0] - points[Math.max(0, i - 1)][0]) / (6 * (1 + m[i] * m[i]));\n tangents.push([ s || 0, m[i] * s || 0 ]);\n }\n return tangents;\n }\n function d3_svg_lineMonotone(points) {\n return points.length < 3 ? d3_svg_lineLinear(points) : points[0] + d3_svg_lineHermite(points, d3_svg_lineMonotoneTangents(points));\n }\n d3.svg.line.radial = function() {\n var line = d3_svg_line(d3_svg_lineRadial);\n line.radius = line.x, delete line.x;\n line.angle = line.y, delete line.y;\n return line;\n };\n function d3_svg_lineRadial(points) {\n var point, i = -1, n = points.length, r, a;\n while (++i < n) {\n point = points[i];\n r = point[0];\n a = point[1] - halfπ;\n point[0] = r * Math.cos(a);\n point[1] = r * Math.sin(a);\n }\n return points;\n }\n function d3_svg_area(projection) {\n var x0 = d3_geom_pointX, x1 = d3_geom_pointX, y0 = 0, y1 = d3_geom_pointY, defined = d3_true, interpolate = d3_svg_lineLinear, interpolateKey = interpolate.key, interpolateReverse = interpolate, L = \"L\", tension = .7;\n function area(data) {\n var segments = [], points0 = [], points1 = [], i = -1, n = data.length, d, fx0 = d3_functor(x0), fy0 = d3_functor(y0), fx1 = x0 === x1 ? function() {\n return x;\n } : d3_functor(x1), fy1 = y0 === y1 ? function() {\n return y;\n } : d3_functor(y1), x, y;\n function segment() {\n segments.push(\"M\", interpolate(projection(points1), tension), L, interpolateReverse(projection(points0.reverse()), tension), \"Z\");\n }\n while (++i < n) {\n if (defined.call(this, d = data[i], i)) {\n points0.push([ x = +fx0.call(this, d, i), y = +fy0.call(this, d, i) ]);\n points1.push([ +fx1.call(this, d, i), +fy1.call(this, d, i) ]);\n } else if (points0.length) {\n segment();\n points0 = [];\n points1 = [];\n }\n }\n if (points0.length) segment();\n return segments.length ? segments.join(\"\") : null;\n }\n area.x = function(_) {\n if (!arguments.length) return x1;\n x0 = x1 = _;\n return area;\n };\n area.x0 = function(_) {\n if (!arguments.length) return x0;\n x0 = _;\n return area;\n };\n area.x1 = function(_) {\n if (!arguments.length) return x1;\n x1 = _;\n return area;\n };\n area.y = function(_) {\n if (!arguments.length) return y1;\n y0 = y1 = _;\n return area;\n };\n area.y0 = function(_) {\n if (!arguments.length) return y0;\n y0 = _;\n return area;\n };\n area.y1 = function(_) {\n if (!arguments.length) return y1;\n y1 = _;\n return area;\n };\n area.defined = function(_) {\n if (!arguments.length) return defined;\n defined = _;\n return area;\n };\n area.interpolate = function(_) {\n if (!arguments.length) return interpolateKey;\n if (typeof _ === \"function\") interpolateKey = interpolate = _; else interpolateKey = (interpolate = d3_svg_lineInterpolators.get(_) || d3_svg_lineLinear).key;\n interpolateReverse = interpolate.reverse || interpolate;\n L = interpolate.closed ? \"M\" : \"L\";\n return area;\n };\n area.tension = function(_) {\n if (!arguments.length) return tension;\n tension = _;\n return area;\n };\n return area;\n }\n d3_svg_lineStepBefore.reverse = d3_svg_lineStepAfter;\n d3_svg_lineStepAfter.reverse = d3_svg_lineStepBefore;\n d3.svg.area = function() {\n return d3_svg_area(d3_identity);\n };\n d3.svg.area.radial = function() {\n var area = d3_svg_area(d3_svg_lineRadial);\n area.radius = area.x, delete area.x;\n area.innerRadius = area.x0, delete area.x0;\n area.outerRadius = area.x1, delete area.x1;\n area.angle = area.y, delete area.y;\n area.startAngle = area.y0, delete area.y0;\n area.endAngle = area.y1, delete area.y1;\n return area;\n };\n function d3_source(d) {\n return d.source;\n }\n function d3_target(d) {\n return d.target;\n }\n d3.svg.chord = function() {\n var source = d3_source, target = d3_target, radius = d3_svg_chordRadius, startAngle = d3_svg_arcStartAngle, endAngle = d3_svg_arcEndAngle;\n function chord(d, i) {\n var s = subgroup(this, source, d, i), t = subgroup(this, target, d, i);\n return \"M\" + s.p0 + arc(s.r, s.p1, s.a1 - s.a0) + (equals(s, t) ? curve(s.r, s.p1, s.r, s.p0) : curve(s.r, s.p1, t.r, t.p0) + arc(t.r, t.p1, t.a1 - t.a0) + curve(t.r, t.p1, s.r, s.p0)) + \"Z\";\n }\n function subgroup(self, f, d, i) {\n var subgroup = f.call(self, d, i), r = radius.call(self, subgroup, i), a0 = startAngle.call(self, subgroup, i) - halfπ, a1 = endAngle.call(self, subgroup, i) - halfπ;\n return {\n r: r,\n a0: a0,\n a1: a1,\n p0: [ r * Math.cos(a0), r * Math.sin(a0) ],\n p1: [ r * Math.cos(a1), r * Math.sin(a1) ]\n };\n }\n function equals(a, b) {\n return a.a0 == b.a0 && a.a1 == b.a1;\n }\n function arc(r, p, a) {\n return \"A\" + r + \",\" + r + \" 0 \" + +(a > π) + \",1 \" + p;\n }\n function curve(r0, p0, r1, p1) {\n return \"Q 0,0 \" + p1;\n }\n chord.radius = function(v) {\n if (!arguments.length) return radius;\n radius = d3_functor(v);\n return chord;\n };\n chord.source = function(v) {\n if (!arguments.length) return source;\n source = d3_functor(v);\n return chord;\n };\n chord.target = function(v) {\n if (!arguments.length) return target;\n target = d3_functor(v);\n return chord;\n };\n chord.startAngle = function(v) {\n if (!arguments.length) return startAngle;\n startAngle = d3_functor(v);\n return chord;\n };\n chord.endAngle = function(v) {\n if (!arguments.length) return endAngle;\n endAngle = d3_functor(v);\n return chord;\n };\n return chord;\n };\n function d3_svg_chordRadius(d) {\n return d.radius;\n }\n d3.svg.diagonal = function() {\n var source = d3_source, target = d3_target, projection = d3_svg_diagonalProjection;\n function diagonal(d, i) {\n var p0 = source.call(this, d, i), p3 = target.call(this, d, i), m = (p0.y + p3.y) / 2, p = [ p0, {\n x: p0.x,\n y: m\n }, {\n x: p3.x,\n y: m\n }, p3 ];\n p = p.map(projection);\n return \"M\" + p[0] + \"C\" + p[1] + \" \" + p[2] + \" \" + p[3];\n }\n diagonal.source = function(x) {\n if (!arguments.length) return source;\n source = d3_functor(x);\n return diagonal;\n };\n diagonal.target = function(x) {\n if (!arguments.length) return target;\n target = d3_functor(x);\n return diagonal;\n };\n diagonal.projection = function(x) {\n if (!arguments.length) return projection;\n projection = x;\n return diagonal;\n };\n return diagonal;\n };\n function d3_svg_diagonalProjection(d) {\n return [ d.x, d.y ];\n }\n d3.svg.diagonal.radial = function() {\n var diagonal = d3.svg.diagonal(), projection = d3_svg_diagonalProjection, projection_ = diagonal.projection;\n diagonal.projection = function(x) {\n return arguments.length ? projection_(d3_svg_diagonalRadialProjection(projection = x)) : projection;\n };\n return diagonal;\n };\n function d3_svg_diagonalRadialProjection(projection) {\n return function() {\n var d = projection.apply(this, arguments), r = d[0], a = d[1] - halfπ;\n return [ r * Math.cos(a), r * Math.sin(a) ];\n };\n }\n d3.svg.symbol = function() {\n var type = d3_svg_symbolType, size = d3_svg_symbolSize;\n function symbol(d, i) {\n return (d3_svg_symbols.get(type.call(this, d, i)) || d3_svg_symbolCircle)(size.call(this, d, i));\n }\n symbol.type = function(x) {\n if (!arguments.length) return type;\n type = d3_functor(x);\n return symbol;\n };\n symbol.size = function(x) {\n if (!arguments.length) return size;\n size = d3_functor(x);\n return symbol;\n };\n return symbol;\n };\n function d3_svg_symbolSize() {\n return 64;\n }\n function d3_svg_symbolType() {\n return \"circle\";\n }\n function d3_svg_symbolCircle(size) {\n var r = Math.sqrt(size / π);\n return \"M0,\" + r + \"A\" + r + \",\" + r + \" 0 1,1 0,\" + -r + \"A\" + r + \",\" + r + \" 0 1,1 0,\" + r + \"Z\";\n }\n var d3_svg_symbols = d3.map({\n circle: d3_svg_symbolCircle,\n cross: function(size) {\n var r = Math.sqrt(size / 5) / 2;\n return \"M\" + -3 * r + \",\" + -r + \"H\" + -r + \"V\" + -3 * r + \"H\" + r + \"V\" + -r + \"H\" + 3 * r + \"V\" + r + \"H\" + r + \"V\" + 3 * r + \"H\" + -r + \"V\" + r + \"H\" + -3 * r + \"Z\";\n },\n diamond: function(size) {\n var ry = Math.sqrt(size / (2 * d3_svg_symbolTan30)), rx = ry * d3_svg_symbolTan30;\n return \"M0,\" + -ry + \"L\" + rx + \",0\" + \" 0,\" + ry + \" \" + -rx + \",0\" + \"Z\";\n },\n square: function(size) {\n var r = Math.sqrt(size) / 2;\n return \"M\" + -r + \",\" + -r + \"L\" + r + \",\" + -r + \" \" + r + \",\" + r + \" \" + -r + \",\" + r + \"Z\";\n },\n \"triangle-down\": function(size) {\n var rx = Math.sqrt(size / d3_svg_symbolSqrt3), ry = rx * d3_svg_symbolSqrt3 / 2;\n return \"M0,\" + ry + \"L\" + rx + \",\" + -ry + \" \" + -rx + \",\" + -ry + \"Z\";\n },\n \"triangle-up\": function(size) {\n var rx = Math.sqrt(size / d3_svg_symbolSqrt3), ry = rx * d3_svg_symbolSqrt3 / 2;\n return \"M0,\" + -ry + \"L\" + rx + \",\" + ry + \" \" + -rx + \",\" + ry + \"Z\";\n }\n });\n d3.svg.symbolTypes = d3_svg_symbols.keys();\n var d3_svg_symbolSqrt3 = Math.sqrt(3), d3_svg_symbolTan30 = Math.tan(30 * d3_radians);\n d3_selectionPrototype.transition = function(name) {\n var id = d3_transitionInheritId || ++d3_transitionId, ns = d3_transitionNamespace(name), subgroups = [], subgroup, node, transition = d3_transitionInherit || {\n time: Date.now(),\n ease: d3_ease_cubicInOut,\n delay: 0,\n duration: 250\n };\n for (var j = -1, m = this.length; ++j < m; ) {\n subgroups.push(subgroup = []);\n for (var group = this[j], i = -1, n = group.length; ++i < n; ) {\n if (node = group[i]) d3_transitionNode(node, i, ns, id, transition);\n subgroup.push(node);\n }\n }\n return d3_transition(subgroups, ns, id);\n };\n d3_selectionPrototype.interrupt = function(name) {\n return this.each(name == null ? d3_selection_interrupt : d3_selection_interruptNS(d3_transitionNamespace(name)));\n };\n var d3_selection_interrupt = d3_selection_interruptNS(d3_transitionNamespace());\n function d3_selection_interruptNS(ns) {\n return function() {\n var lock, activeId, active;\n if ((lock = this[ns]) && (active = lock[activeId = lock.active])) {\n active.timer.c = null;\n active.timer.t = NaN;\n if (--lock.count) delete lock[activeId]; else delete this[ns];\n lock.active += .5;\n active.event && active.event.interrupt.call(this, this.__data__, active.index);\n }\n };\n }\n function d3_transition(groups, ns, id) {\n d3_subclass(groups, d3_transitionPrototype);\n groups.namespace = ns;\n groups.id = id;\n return groups;\n }\n var d3_transitionPrototype = [], d3_transitionId = 0, d3_transitionInheritId, d3_transitionInherit;\n d3_transitionPrototype.call = d3_selectionPrototype.call;\n d3_transitionPrototype.empty = d3_selectionPrototype.empty;\n d3_transitionPrototype.node = d3_selectionPrototype.node;\n d3_transitionPrototype.size = d3_selectionPrototype.size;\n d3.transition = function(selection, name) {\n return selection && selection.transition ? d3_transitionInheritId ? selection.transition(name) : selection : d3.selection().transition(selection);\n };\n d3.transition.prototype = d3_transitionPrototype;\n d3_transitionPrototype.select = function(selector) {\n var id = this.id, ns = this.namespace, subgroups = [], subgroup, subnode, node;\n selector = d3_selection_selector(selector);\n for (var j = -1, m = this.length; ++j < m; ) {\n subgroups.push(subgroup = []);\n for (var group = this[j], i = -1, n = group.length; ++i < n; ) {\n if ((node = group[i]) && (subnode = selector.call(node, node.__data__, i, j))) {\n if (\"__data__\" in node) subnode.__data__ = node.__data__;\n d3_transitionNode(subnode, i, ns, id, node[ns][id]);\n subgroup.push(subnode);\n } else {\n subgroup.push(null);\n }\n }\n }\n return d3_transition(subgroups, ns, id);\n };\n d3_transitionPrototype.selectAll = function(selector) {\n var id = this.id, ns = this.namespace, subgroups = [], subgroup, subnodes, node, subnode, transition;\n selector = d3_selection_selectorAll(selector);\n for (var j = -1, m = this.length; ++j < m; ) {\n for (var group = this[j], i = -1, n = group.length; ++i < n; ) {\n if (node = group[i]) {\n transition = node[ns][id];\n subnodes = selector.call(node, node.__data__, i, j);\n subgroups.push(subgroup = []);\n for (var k = -1, o = subnodes.length; ++k < o; ) {\n if (subnode = subnodes[k]) d3_transitionNode(subnode, k, ns, id, transition);\n subgroup.push(subnode);\n }\n }\n }\n }\n return d3_transition(subgroups, ns, id);\n };\n d3_transitionPrototype.filter = function(filter) {\n var subgroups = [], subgroup, group, node;\n if (typeof filter !== \"function\") filter = d3_selection_filter(filter);\n for (var j = 0, m = this.length; j < m; j++) {\n subgroups.push(subgroup = []);\n for (var group = this[j], i = 0, n = group.length; i < n; i++) {\n if ((node = group[i]) && filter.call(node, node.__data__, i, j)) {\n subgroup.push(node);\n }\n }\n }\n return d3_transition(subgroups, this.namespace, this.id);\n };\n d3_transitionPrototype.tween = function(name, tween) {\n var id = this.id, ns = this.namespace;\n if (arguments.length < 2) return this.node()[ns][id].tween.get(name);\n return d3_selection_each(this, tween == null ? function(node) {\n node[ns][id].tween.remove(name);\n } : function(node) {\n node[ns][id].tween.set(name, tween);\n });\n };\n function d3_transition_tween(groups, name, value, tween) {\n var id = groups.id, ns = groups.namespace;\n return d3_selection_each(groups, typeof value === \"function\" ? function(node, i, j) {\n node[ns][id].tween.set(name, tween(value.call(node, node.__data__, i, j)));\n } : (value = tween(value), function(node) {\n node[ns][id].tween.set(name, value);\n }));\n }\n d3_transitionPrototype.attr = function(nameNS, value) {\n if (arguments.length < 2) {\n for (value in nameNS) this.attr(value, nameNS[value]);\n return this;\n }\n var interpolate = nameNS == \"transform\" ? d3_interpolateTransform : d3_interpolate, name = d3.ns.qualify(nameNS);\n function attrNull() {\n this.removeAttribute(name);\n }\n function attrNullNS() {\n this.removeAttributeNS(name.space, name.local);\n }\n function attrTween(b) {\n return b == null ? attrNull : (b += \"\", function() {\n var a = this.getAttribute(name), i;\n return a !== b && (i = interpolate(a, b), function(t) {\n this.setAttribute(name, i(t));\n });\n });\n }\n function attrTweenNS(b) {\n return b == null ? attrNullNS : (b += \"\", function() {\n var a = this.getAttributeNS(name.space, name.local), i;\n return a !== b && (i = interpolate(a, b), function(t) {\n this.setAttributeNS(name.space, name.local, i(t));\n });\n });\n }\n return d3_transition_tween(this, \"attr.\" + nameNS, value, name.local ? attrTweenNS : attrTween);\n };\n d3_transitionPrototype.attrTween = function(nameNS, tween) {\n var name = d3.ns.qualify(nameNS);\n function attrTween(d, i) {\n var f = tween.call(this, d, i, this.getAttribute(name));\n return f && function(t) {\n this.setAttribute(name, f(t));\n };\n }\n function attrTweenNS(d, i) {\n var f = tween.call(this, d, i, this.getAttributeNS(name.space, name.local));\n return f && function(t) {\n this.setAttributeNS(name.space, name.local, f(t));\n };\n }\n return this.tween(\"attr.\" + nameNS, name.local ? attrTweenNS : attrTween);\n };\n d3_transitionPrototype.style = function(name, value, priority) {\n var n = arguments.length;\n if (n < 3) {\n if (typeof name !== \"string\") {\n if (n < 2) value = \"\";\n for (priority in name) this.style(priority, name[priority], value);\n return this;\n }\n priority = \"\";\n }\n function styleNull() {\n this.style.removeProperty(name);\n }\n function styleString(b) {\n return b == null ? styleNull : (b += \"\", function() {\n var a = d3_window(this).getComputedStyle(this, null).getPropertyValue(name), i;\n return a !== b && (i = d3_interpolate(a, b), function(t) {\n this.style.setProperty(name, i(t), priority);\n });\n });\n }\n return d3_transition_tween(this, \"style.\" + name, value, styleString);\n };\n d3_transitionPrototype.styleTween = function(name, tween, priority) {\n if (arguments.length < 3) priority = \"\";\n function styleTween(d, i) {\n var f = tween.call(this, d, i, d3_window(this).getComputedStyle(this, null).getPropertyValue(name));\n return f && function(t) {\n this.style.setProperty(name, f(t), priority);\n };\n }\n return this.tween(\"style.\" + name, styleTween);\n };\n d3_transitionPrototype.text = function(value) {\n return d3_transition_tween(this, \"text\", value, d3_transition_text);\n };\n function d3_transition_text(b) {\n if (b == null) b = \"\";\n return function() {\n this.textContent = b;\n };\n }\n d3_transitionPrototype.remove = function() {\n var ns = this.namespace;\n return this.each(\"end.transition\", function() {\n var p;\n if (this[ns].count < 2 && (p = this.parentNode)) p.removeChild(this);\n });\n };\n d3_transitionPrototype.ease = function(value) {\n var id = this.id, ns = this.namespace;\n if (arguments.length < 1) return this.node()[ns][id].ease;\n if (typeof value !== \"function\") value = d3.ease.apply(d3, arguments);\n return d3_selection_each(this, function(node) {\n node[ns][id].ease = value;\n });\n };\n d3_transitionPrototype.delay = function(value) {\n var id = this.id, ns = this.namespace;\n if (arguments.length < 1) return this.node()[ns][id].delay;\n return d3_selection_each(this, typeof value === \"function\" ? function(node, i, j) {\n node[ns][id].delay = +value.call(node, node.__data__, i, j);\n } : (value = +value, function(node) {\n node[ns][id].delay = value;\n }));\n };\n d3_transitionPrototype.duration = function(value) {\n var id = this.id, ns = this.namespace;\n if (arguments.length < 1) return this.node()[ns][id].duration;\n return d3_selection_each(this, typeof value === \"function\" ? function(node, i, j) {\n node[ns][id].duration = Math.max(1, value.call(node, node.__data__, i, j));\n } : (value = Math.max(1, value), function(node) {\n node[ns][id].duration = value;\n }));\n };\n d3_transitionPrototype.each = function(type, listener) {\n var id = this.id, ns = this.namespace;\n if (arguments.length < 2) {\n var inherit = d3_transitionInherit, inheritId = d3_transitionInheritId;\n try {\n d3_transitionInheritId = id;\n d3_selection_each(this, function(node, i, j) {\n d3_transitionInherit = node[ns][id];\n type.call(node, node.__data__, i, j);\n });\n } finally {\n d3_transitionInherit = inherit;\n d3_transitionInheritId = inheritId;\n }\n } else {\n d3_selection_each(this, function(node) {\n var transition = node[ns][id];\n (transition.event || (transition.event = d3.dispatch(\"start\", \"end\", \"interrupt\"))).on(type, listener);\n });\n }\n return this;\n };\n d3_transitionPrototype.transition = function() {\n var id0 = this.id, id1 = ++d3_transitionId, ns = this.namespace, subgroups = [], subgroup, group, node, transition;\n for (var j = 0, m = this.length; j < m; j++) {\n subgroups.push(subgroup = []);\n for (var group = this[j], i = 0, n = group.length; i < n; i++) {\n if (node = group[i]) {\n transition = node[ns][id0];\n d3_transitionNode(node, i, ns, id1, {\n time: transition.time,\n ease: transition.ease,\n delay: transition.delay + transition.duration,\n duration: transition.duration\n });\n }\n subgroup.push(node);\n }\n }\n return d3_transition(subgroups, ns, id1);\n };\n function d3_transitionNamespace(name) {\n return name == null ? \"__transition__\" : \"__transition_\" + name + \"__\";\n }\n function d3_transitionNode(node, i, ns, id, inherit) {\n var lock = node[ns] || (node[ns] = {\n active: 0,\n count: 0\n }), transition = lock[id], time, timer, duration, ease, tweens;\n function schedule(elapsed) {\n var delay = transition.delay;\n timer.t = delay + time;\n if (delay <= elapsed) return start(elapsed - delay);\n timer.c = start;\n }\n function start(elapsed) {\n var activeId = lock.active, active = lock[activeId];\n if (active) {\n active.timer.c = null;\n active.timer.t = NaN;\n --lock.count;\n delete lock[activeId];\n active.event && active.event.interrupt.call(node, node.__data__, active.index);\n }\n for (var cancelId in lock) {\n if (+cancelId < id) {\n var cancel = lock[cancelId];\n cancel.timer.c = null;\n cancel.timer.t = NaN;\n --lock.count;\n delete lock[cancelId];\n }\n }\n timer.c = tick;\n d3_timer(function() {\n if (timer.c && tick(elapsed || 1)) {\n timer.c = null;\n timer.t = NaN;\n }\n return 1;\n }, 0, time);\n lock.active = id;\n transition.event && transition.event.start.call(node, node.__data__, i);\n tweens = [];\n transition.tween.forEach(function(key, value) {\n if (value = value.call(node, node.__data__, i)) {\n tweens.push(value);\n }\n });\n ease = transition.ease;\n duration = transition.duration;\n }\n function tick(elapsed) {\n var t = elapsed / duration, e = ease(t), n = tweens.length;\n while (n > 0) {\n tweens[--n].call(node, e);\n }\n if (t >= 1) {\n transition.event && transition.event.end.call(node, node.__data__, i);\n if (--lock.count) delete lock[id]; else delete node[ns];\n return 1;\n }\n }\n if (!transition) {\n time = inherit.time;\n timer = d3_timer(schedule, 0, time);\n transition = lock[id] = {\n tween: new d3_Map(),\n time: time,\n timer: timer,\n delay: inherit.delay,\n duration: inherit.duration,\n ease: inherit.ease,\n index: i\n };\n inherit = null;\n ++lock.count;\n }\n }\n d3.svg.axis = function() {\n var scale = d3.scale.linear(), orient = d3_svg_axisDefaultOrient, innerTickSize = 6, outerTickSize = 6, tickPadding = 3, tickArguments_ = [ 10 ], tickValues = null, tickFormat_;\n function axis(g) {\n g.each(function() {\n var g = d3.select(this);\n var scale0 = this.__chart__ || scale, scale1 = this.__chart__ = scale.copy();\n var ticks = tickValues == null ? scale1.ticks ? scale1.ticks.apply(scale1, tickArguments_) : scale1.domain() : tickValues, tickFormat = tickFormat_ == null ? scale1.tickFormat ? scale1.tickFormat.apply(scale1, tickArguments_) : d3_identity : tickFormat_, tick = g.selectAll(\".tick\").data(ticks, scale1), tickEnter = tick.enter().insert(\"g\", \".domain\").attr(\"class\", \"tick\").style(\"opacity\", ε), tickExit = d3.transition(tick.exit()).style(\"opacity\", ε).remove(), tickUpdate = d3.transition(tick.order()).style(\"opacity\", 1), tickSpacing = Math.max(innerTickSize, 0) + tickPadding, tickTransform;\n var range = d3_scaleRange(scale1), path = g.selectAll(\".domain\").data([ 0 ]), pathUpdate = (path.enter().append(\"path\").attr(\"class\", \"domain\"), \n d3.transition(path));\n tickEnter.append(\"line\");\n tickEnter.append(\"text\");\n var lineEnter = tickEnter.select(\"line\"), lineUpdate = tickUpdate.select(\"line\"), text = tick.select(\"text\").text(tickFormat), textEnter = tickEnter.select(\"text\"), textUpdate = tickUpdate.select(\"text\"), sign = orient === \"top\" || orient === \"left\" ? -1 : 1, x1, x2, y1, y2;\n if (orient === \"bottom\" || orient === \"top\") {\n tickTransform = d3_svg_axisX, x1 = \"x\", y1 = \"y\", x2 = \"x2\", y2 = \"y2\";\n text.attr(\"dy\", sign < 0 ? \"0em\" : \".71em\").style(\"text-anchor\", \"middle\");\n pathUpdate.attr(\"d\", \"M\" + range[0] + \",\" + sign * outerTickSize + \"V0H\" + range[1] + \"V\" + sign * outerTickSize);\n } else {\n tickTransform = d3_svg_axisY, x1 = \"y\", y1 = \"x\", x2 = \"y2\", y2 = \"x2\";\n text.attr(\"dy\", \".32em\").style(\"text-anchor\", sign < 0 ? \"end\" : \"start\");\n pathUpdate.attr(\"d\", \"M\" + sign * outerTickSize + \",\" + range[0] + \"H0V\" + range[1] + \"H\" + sign * outerTickSize);\n }\n lineEnter.attr(y2, sign * innerTickSize);\n textEnter.attr(y1, sign * tickSpacing);\n lineUpdate.attr(x2, 0).attr(y2, sign * innerTickSize);\n textUpdate.attr(x1, 0).attr(y1, sign * tickSpacing);\n if (scale1.rangeBand) {\n var x = scale1, dx = x.rangeBand() / 2;\n scale0 = scale1 = function(d) {\n return x(d) + dx;\n };\n } else if (scale0.rangeBand) {\n scale0 = scale1;\n } else {\n tickExit.call(tickTransform, scale1, scale0);\n }\n tickEnter.call(tickTransform, scale0, scale1);\n tickUpdate.call(tickTransform, scale1, scale1);\n });\n }\n axis.scale = function(x) {\n if (!arguments.length) return scale;\n scale = x;\n return axis;\n };\n axis.orient = function(x) {\n if (!arguments.length) return orient;\n orient = x in d3_svg_axisOrients ? x + \"\" : d3_svg_axisDefaultOrient;\n return axis;\n };\n axis.ticks = function() {\n if (!arguments.length) return tickArguments_;\n tickArguments_ = d3_array(arguments);\n return axis;\n };\n axis.tickValues = function(x) {\n if (!arguments.length) return tickValues;\n tickValues = x;\n return axis;\n };\n axis.tickFormat = function(x) {\n if (!arguments.length) return tickFormat_;\n tickFormat_ = x;\n return axis;\n };\n axis.tickSize = function(x) {\n var n = arguments.length;\n if (!n) return innerTickSize;\n innerTickSize = +x;\n outerTickSize = +arguments[n - 1];\n return axis;\n };\n axis.innerTickSize = function(x) {\n if (!arguments.length) return innerTickSize;\n innerTickSize = +x;\n return axis;\n };\n axis.outerTickSize = function(x) {\n if (!arguments.length) return outerTickSize;\n outerTickSize = +x;\n return axis;\n };\n axis.tickPadding = function(x) {\n if (!arguments.length) return tickPadding;\n tickPadding = +x;\n return axis;\n };\n axis.tickSubdivide = function() {\n return arguments.length && axis;\n };\n return axis;\n };\n var d3_svg_axisDefaultOrient = \"bottom\", d3_svg_axisOrients = {\n top: 1,\n right: 1,\n bottom: 1,\n left: 1\n };\n function d3_svg_axisX(selection, x0, x1) {\n selection.attr(\"transform\", function(d) {\n var v0 = x0(d);\n return \"translate(\" + (isFinite(v0) ? v0 : x1(d)) + \",0)\";\n });\n }\n function d3_svg_axisY(selection, y0, y1) {\n selection.attr(\"transform\", function(d) {\n var v0 = y0(d);\n return \"translate(0,\" + (isFinite(v0) ? v0 : y1(d)) + \")\";\n });\n }\n d3.svg.brush = function() {\n var event = d3_eventDispatch(brush, \"brushstart\", \"brush\", \"brushend\"), x = null, y = null, xExtent = [ 0, 0 ], yExtent = [ 0, 0 ], xExtentDomain, yExtentDomain, xClamp = true, yClamp = true, resizes = d3_svg_brushResizes[0];\n function brush(g) {\n g.each(function() {\n var g = d3.select(this).style(\"pointer-events\", \"all\").style(\"-webkit-tap-highlight-color\", \"rgba(0,0,0,0)\").on(\"mousedown.brush\", brushstart).on(\"touchstart.brush\", brushstart);\n var background = g.selectAll(\".background\").data([ 0 ]);\n background.enter().append(\"rect\").attr(\"class\", \"background\").style(\"visibility\", \"hidden\").style(\"cursor\", \"crosshair\");\n g.selectAll(\".extent\").data([ 0 ]).enter().append(\"rect\").attr(\"class\", \"extent\").style(\"cursor\", \"move\");\n var resize = g.selectAll(\".resize\").data(resizes, d3_identity);\n resize.exit().remove();\n resize.enter().append(\"g\").attr(\"class\", function(d) {\n return \"resize \" + d;\n }).style(\"cursor\", function(d) {\n return d3_svg_brushCursor[d];\n }).append(\"rect\").attr(\"x\", function(d) {\n return /[ew]$/.test(d) ? -3 : null;\n }).attr(\"y\", function(d) {\n return /^[ns]/.test(d) ? -3 : null;\n }).attr(\"width\", 6).attr(\"height\", 6).style(\"visibility\", \"hidden\");\n resize.style(\"display\", brush.empty() ? \"none\" : null);\n var gUpdate = d3.transition(g), backgroundUpdate = d3.transition(background), range;\n if (x) {\n range = d3_scaleRange(x);\n backgroundUpdate.attr(\"x\", range[0]).attr(\"width\", range[1] - range[0]);\n redrawX(gUpdate);\n }\n if (y) {\n range = d3_scaleRange(y);\n backgroundUpdate.attr(\"y\", range[0]).attr(\"height\", range[1] - range[0]);\n redrawY(gUpdate);\n }\n redraw(gUpdate);\n });\n }\n brush.event = function(g) {\n g.each(function() {\n var event_ = event.of(this, arguments), extent1 = {\n x: xExtent,\n y: yExtent,\n i: xExtentDomain,\n j: yExtentDomain\n }, extent0 = this.__chart__ || extent1;\n this.__chart__ = extent1;\n if (d3_transitionInheritId) {\n d3.select(this).transition().each(\"start.brush\", function() {\n xExtentDomain = extent0.i;\n yExtentDomain = extent0.j;\n xExtent = extent0.x;\n yExtent = extent0.y;\n event_({\n type: \"brushstart\"\n });\n }).tween(\"brush:brush\", function() {\n var xi = d3_interpolateArray(xExtent, extent1.x), yi = d3_interpolateArray(yExtent, extent1.y);\n xExtentDomain = yExtentDomain = null;\n return function(t) {\n xExtent = extent1.x = xi(t);\n yExtent = extent1.y = yi(t);\n event_({\n type: \"brush\",\n mode: \"resize\"\n });\n };\n }).each(\"end.brush\", function() {\n xExtentDomain = extent1.i;\n yExtentDomain = extent1.j;\n event_({\n type: \"brush\",\n mode: \"resize\"\n });\n event_({\n type: \"brushend\"\n });\n });\n } else {\n event_({\n type: \"brushstart\"\n });\n event_({\n type: \"brush\",\n mode: \"resize\"\n });\n event_({\n type: \"brushend\"\n });\n }\n });\n };\n function redraw(g) {\n g.selectAll(\".resize\").attr(\"transform\", function(d) {\n return \"translate(\" + xExtent[+/e$/.test(d)] + \",\" + yExtent[+/^s/.test(d)] + \")\";\n });\n }\n function redrawX(g) {\n g.select(\".extent\").attr(\"x\", xExtent[0]);\n g.selectAll(\".extent,.n>rect,.s>rect\").attr(\"width\", xExtent[1] - xExtent[0]);\n }\n function redrawY(g) {\n g.select(\".extent\").attr(\"y\", yExtent[0]);\n g.selectAll(\".extent,.e>rect,.w>rect\").attr(\"height\", yExtent[1] - yExtent[0]);\n }\n function brushstart() {\n var target = this, eventTarget = d3.select(d3.event.target), event_ = event.of(target, arguments), g = d3.select(target), resizing = eventTarget.datum(), resizingX = !/^(n|s)$/.test(resizing) && x, resizingY = !/^(e|w)$/.test(resizing) && y, dragging = eventTarget.classed(\"extent\"), dragRestore = d3_event_dragSuppress(target), center, origin = d3.mouse(target), offset;\n var w = d3.select(d3_window(target)).on(\"keydown.brush\", keydown).on(\"keyup.brush\", keyup);\n if (d3.event.changedTouches) {\n w.on(\"touchmove.brush\", brushmove).on(\"touchend.brush\", brushend);\n } else {\n w.on(\"mousemove.brush\", brushmove).on(\"mouseup.brush\", brushend);\n }\n g.interrupt().selectAll(\"*\").interrupt();\n if (dragging) {\n origin[0] = xExtent[0] - origin[0];\n origin[1] = yExtent[0] - origin[1];\n } else if (resizing) {\n var ex = +/w$/.test(resizing), ey = +/^n/.test(resizing);\n offset = [ xExtent[1 - ex] - origin[0], yExtent[1 - ey] - origin[1] ];\n origin[0] = xExtent[ex];\n origin[1] = yExtent[ey];\n } else if (d3.event.altKey) center = origin.slice();\n g.style(\"pointer-events\", \"none\").selectAll(\".resize\").style(\"display\", null);\n d3.select(\"body\").style(\"cursor\", eventTarget.style(\"cursor\"));\n event_({\n type: \"brushstart\"\n });\n brushmove();\n function keydown() {\n if (d3.event.keyCode == 32) {\n if (!dragging) {\n center = null;\n origin[0] -= xExtent[1];\n origin[1] -= yExtent[1];\n dragging = 2;\n }\n d3_eventPreventDefault();\n }\n }\n function keyup() {\n if (d3.event.keyCode == 32 && dragging == 2) {\n origin[0] += xExtent[1];\n origin[1] += yExtent[1];\n dragging = 0;\n d3_eventPreventDefault();\n }\n }\n function brushmove() {\n var point = d3.mouse(target), moved = false;\n if (offset) {\n point[0] += offset[0];\n point[1] += offset[1];\n }\n if (!dragging) {\n if (d3.event.altKey) {\n if (!center) center = [ (xExtent[0] + xExtent[1]) / 2, (yExtent[0] + yExtent[1]) / 2 ];\n origin[0] = xExtent[+(point[0] < center[0])];\n origin[1] = yExtent[+(point[1] < center[1])];\n } else center = null;\n }\n if (resizingX && move1(point, x, 0)) {\n redrawX(g);\n moved = true;\n }\n if (resizingY && move1(point, y, 1)) {\n redrawY(g);\n moved = true;\n }\n if (moved) {\n redraw(g);\n event_({\n type: \"brush\",\n mode: dragging ? \"move\" : \"resize\"\n });\n }\n }\n function move1(point, scale, i) {\n var range = d3_scaleRange(scale), r0 = range[0], r1 = range[1], position = origin[i], extent = i ? yExtent : xExtent, size = extent[1] - extent[0], min, max;\n if (dragging) {\n r0 -= position;\n r1 -= size + position;\n }\n min = (i ? yClamp : xClamp) ? Math.max(r0, Math.min(r1, point[i])) : point[i];\n if (dragging) {\n max = (min += position) + size;\n } else {\n if (center) position = Math.max(r0, Math.min(r1, 2 * center[i] - min));\n if (position < min) {\n max = min;\n min = position;\n } else {\n max = position;\n }\n }\n if (extent[0] != min || extent[1] != max) {\n if (i) yExtentDomain = null; else xExtentDomain = null;\n extent[0] = min;\n extent[1] = max;\n return true;\n }\n }\n function brushend() {\n brushmove();\n g.style(\"pointer-events\", \"all\").selectAll(\".resize\").style(\"display\", brush.empty() ? \"none\" : null);\n d3.select(\"body\").style(\"cursor\", null);\n w.on(\"mousemove.brush\", null).on(\"mouseup.brush\", null).on(\"touchmove.brush\", null).on(\"touchend.brush\", null).on(\"keydown.brush\", null).on(\"keyup.brush\", null);\n dragRestore();\n event_({\n type: \"brushend\"\n });\n }\n }\n brush.x = function(z) {\n if (!arguments.length) return x;\n x = z;\n resizes = d3_svg_brushResizes[!x << 1 | !y];\n return brush;\n };\n brush.y = function(z) {\n if (!arguments.length) return y;\n y = z;\n resizes = d3_svg_brushResizes[!x << 1 | !y];\n return brush;\n };\n brush.clamp = function(z) {\n if (!arguments.length) return x && y ? [ xClamp, yClamp ] : x ? xClamp : y ? yClamp : null;\n if (x && y) xClamp = !!z[0], yClamp = !!z[1]; else if (x) xClamp = !!z; else if (y) yClamp = !!z;\n return brush;\n };\n brush.extent = function(z) {\n var x0, x1, y0, y1, t;\n if (!arguments.length) {\n if (x) {\n if (xExtentDomain) {\n x0 = xExtentDomain[0], x1 = xExtentDomain[1];\n } else {\n x0 = xExtent[0], x1 = xExtent[1];\n if (x.invert) x0 = x.invert(x0), x1 = x.invert(x1);\n if (x1 < x0) t = x0, x0 = x1, x1 = t;\n }\n }\n if (y) {\n if (yExtentDomain) {\n y0 = yExtentDomain[0], y1 = yExtentDomain[1];\n } else {\n y0 = yExtent[0], y1 = yExtent[1];\n if (y.invert) y0 = y.invert(y0), y1 = y.invert(y1);\n if (y1 < y0) t = y0, y0 = y1, y1 = t;\n }\n }\n return x && y ? [ [ x0, y0 ], [ x1, y1 ] ] : x ? [ x0, x1 ] : y && [ y0, y1 ];\n }\n if (x) {\n x0 = z[0], x1 = z[1];\n if (y) x0 = x0[0], x1 = x1[0];\n xExtentDomain = [ x0, x1 ];\n if (x.invert) x0 = x(x0), x1 = x(x1);\n if (x1 < x0) t = x0, x0 = x1, x1 = t;\n if (x0 != xExtent[0] || x1 != xExtent[1]) xExtent = [ x0, x1 ];\n }\n if (y) {\n y0 = z[0], y1 = z[1];\n if (x) y0 = y0[1], y1 = y1[1];\n yExtentDomain = [ y0, y1 ];\n if (y.invert) y0 = y(y0), y1 = y(y1);\n if (y1 < y0) t = y0, y0 = y1, y1 = t;\n if (y0 != yExtent[0] || y1 != yExtent[1]) yExtent = [ y0, y1 ];\n }\n return brush;\n };\n brush.clear = function() {\n if (!brush.empty()) {\n xExtent = [ 0, 0 ], yExtent = [ 0, 0 ];\n xExtentDomain = yExtentDomain = null;\n }\n return brush;\n };\n brush.empty = function() {\n return !!x && xExtent[0] == xExtent[1] || !!y && yExtent[0] == yExtent[1];\n };\n return d3.rebind(brush, event, \"on\");\n };\n var d3_svg_brushCursor = {\n n: \"ns-resize\",\n e: \"ew-resize\",\n s: \"ns-resize\",\n w: \"ew-resize\",\n nw: \"nwse-resize\",\n ne: \"nesw-resize\",\n se: \"nwse-resize\",\n sw: \"nesw-resize\"\n };\n var d3_svg_brushResizes = [ [ \"n\", \"e\", \"s\", \"w\", \"nw\", \"ne\", \"se\", \"sw\" ], [ \"e\", \"w\" ], [ \"n\", \"s\" ], [] ];\n d3.text = d3_xhrType(function(request) {\n return request.responseText;\n });\n d3.json = function(url, callback) {\n return d3_xhr(url, \"application/json\", d3_json, callback);\n };\n function d3_json(request) {\n return JSON.parse(request.responseText);\n }\n d3.html = function(url, callback) {\n return d3_xhr(url, \"text/html\", d3_html, callback);\n };\n function d3_html(request) {\n var range = d3_document.createRange();\n range.selectNode(d3_document.body);\n return range.createContextualFragment(request.responseText);\n }\n d3.xml = d3_xhrType(function(request) {\n return request.responseXML;\n });\n if (typeof define === \"function\" && define.amd) define(d3); else if (typeof module === \"object\" && module.exports) module.exports = d3; else this.d3 = d3;\n}.apply(self);","/* Mapbox GL JS is licensed under the 3-Clause BSD License. Full text of license: https://github.com/mapbox/mapbox-gl-js/blob/v1.13.1/LICENSE.txt */\n(function (global, factory) {\ntypeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\ntypeof define === 'function' && define.amd ? define(factory) :\n(global = global || self, global.mapboxgl = factory());\n}(this, (function () { 'use strict';\n\n/* eslint-disable */\n\nvar shared, worker, mapboxgl;\n// define gets called three times: one for each chunk. we rely on the order\n// they're imported to know which is which\nfunction define(_, chunk) {\nif (!shared) {\n shared = chunk;\n} else if (!worker) {\n worker = chunk;\n} else {\n var workerBundleString = 'var sharedChunk = {}; (' + shared + ')(sharedChunk); (' + worker + ')(sharedChunk);'\n\n var sharedChunk = {};\n shared(sharedChunk);\n mapboxgl = chunk(sharedChunk);\n if (typeof window !== 'undefined') {\n mapboxgl.workerUrl = window.URL.createObjectURL(new Blob([workerBundleString], { type: 'text/javascript' }));\n }\n}\n}\n\n\ndefine(['exports'], function (exports) { 'use strict';\n\nfunction createCommonjsModule(fn, module) {\n\treturn module = { exports: {} }, fn(module, module.exports), module.exports;\n}\n\nvar version = \"1.13.4\";\n\nvar unitbezier = UnitBezier;\nfunction UnitBezier(p1x, p1y, p2x, p2y) {\n this.cx = 3 * p1x;\n this.bx = 3 * (p2x - p1x) - this.cx;\n this.ax = 1 - this.cx - this.bx;\n this.cy = 3 * p1y;\n this.by = 3 * (p2y - p1y) - this.cy;\n this.ay = 1 - this.cy - this.by;\n this.p1x = p1x;\n this.p1y = p2y;\n this.p2x = p2x;\n this.p2y = p2y;\n}\nUnitBezier.prototype.sampleCurveX = function (t) {\n return ((this.ax * t + this.bx) * t + this.cx) * t;\n};\nUnitBezier.prototype.sampleCurveY = function (t) {\n return ((this.ay * t + this.by) * t + this.cy) * t;\n};\nUnitBezier.prototype.sampleCurveDerivativeX = function (t) {\n return (3 * this.ax * t + 2 * this.bx) * t + this.cx;\n};\nUnitBezier.prototype.solveCurveX = function (x, epsilon) {\n if (typeof epsilon === 'undefined') {\n epsilon = 0.000001;\n }\n var t0, t1, t2, x2, i;\n for (t2 = x, i = 0; i < 8; i++) {\n x2 = this.sampleCurveX(t2) - x;\n if (Math.abs(x2) < epsilon) {\n return t2;\n }\n var d2 = this.sampleCurveDerivativeX(t2);\n if (Math.abs(d2) < 0.000001) {\n break;\n }\n t2 = t2 - x2 / d2;\n }\n t0 = 0;\n t1 = 1;\n t2 = x;\n if (t2 < t0) {\n return t0;\n }\n if (t2 > t1) {\n return t1;\n }\n while (t0 < t1) {\n x2 = this.sampleCurveX(t2);\n if (Math.abs(x2 - x) < epsilon) {\n return t2;\n }\n if (x > x2) {\n t0 = t2;\n } else {\n t1 = t2;\n }\n t2 = (t1 - t0) * 0.5 + t0;\n }\n return t2;\n};\nUnitBezier.prototype.solve = function (x, epsilon) {\n return this.sampleCurveY(this.solveCurveX(x, epsilon));\n};\n\nvar pointGeometry = Point;\nfunction Point(x, y) {\n this.x = x;\n this.y = y;\n}\nPoint.prototype = {\n clone: function () {\n return new Point(this.x, this.y);\n },\n add: function (p) {\n return this.clone()._add(p);\n },\n sub: function (p) {\n return this.clone()._sub(p);\n },\n multByPoint: function (p) {\n return this.clone()._multByPoint(p);\n },\n divByPoint: function (p) {\n return this.clone()._divByPoint(p);\n },\n mult: function (k) {\n return this.clone()._mult(k);\n },\n div: function (k) {\n return this.clone()._div(k);\n },\n rotate: function (a) {\n return this.clone()._rotate(a);\n },\n rotateAround: function (a, p) {\n return this.clone()._rotateAround(a, p);\n },\n matMult: function (m) {\n return this.clone()._matMult(m);\n },\n unit: function () {\n return this.clone()._unit();\n },\n perp: function () {\n return this.clone()._perp();\n },\n round: function () {\n return this.clone()._round();\n },\n mag: function () {\n return Math.sqrt(this.x * this.x + this.y * this.y);\n },\n equals: function (other) {\n return this.x === other.x && this.y === other.y;\n },\n dist: function (p) {\n return Math.sqrt(this.distSqr(p));\n },\n distSqr: function (p) {\n var dx = p.x - this.x, dy = p.y - this.y;\n return dx * dx + dy * dy;\n },\n angle: function () {\n return Math.atan2(this.y, this.x);\n },\n angleTo: function (b) {\n return Math.atan2(this.y - b.y, this.x - b.x);\n },\n angleWith: function (b) {\n return this.angleWithSep(b.x, b.y);\n },\n angleWithSep: function (x, y) {\n return Math.atan2(this.x * y - this.y * x, this.x * x + this.y * y);\n },\n _matMult: function (m) {\n var x = m[0] * this.x + m[1] * this.y, y = m[2] * this.x + m[3] * this.y;\n this.x = x;\n this.y = y;\n return this;\n },\n _add: function (p) {\n this.x += p.x;\n this.y += p.y;\n return this;\n },\n _sub: function (p) {\n this.x -= p.x;\n this.y -= p.y;\n return this;\n },\n _mult: function (k) {\n this.x *= k;\n this.y *= k;\n return this;\n },\n _div: function (k) {\n this.x /= k;\n this.y /= k;\n return this;\n },\n _multByPoint: function (p) {\n this.x *= p.x;\n this.y *= p.y;\n return this;\n },\n _divByPoint: function (p) {\n this.x /= p.x;\n this.y /= p.y;\n return this;\n },\n _unit: function () {\n this._div(this.mag());\n return this;\n },\n _perp: function () {\n var y = this.y;\n this.y = this.x;\n this.x = -y;\n return this;\n },\n _rotate: function (angle) {\n var cos = Math.cos(angle), sin = Math.sin(angle), x = cos * this.x - sin * this.y, y = sin * this.x + cos * this.y;\n this.x = x;\n this.y = y;\n return this;\n },\n _rotateAround: function (angle, p) {\n var cos = Math.cos(angle), sin = Math.sin(angle), x = p.x + cos * (this.x - p.x) - sin * (this.y - p.y), y = p.y + sin * (this.x - p.x) + cos * (this.y - p.y);\n this.x = x;\n this.y = y;\n return this;\n },\n _round: function () {\n this.x = Math.round(this.x);\n this.y = Math.round(this.y);\n return this;\n }\n};\nPoint.convert = function (a) {\n if (a instanceof Point) {\n return a;\n }\n if (Array.isArray(a)) {\n return new Point(a[0], a[1]);\n }\n return a;\n};\n\nvar window$1 = typeof self !== 'undefined' ? self : {};\n\nfunction deepEqual(a, b) {\n if (Array.isArray(a)) {\n if (!Array.isArray(b) || a.length !== b.length) {\n return false;\n }\n for (var i = 0; i < a.length; i++) {\n if (!deepEqual(a[i], b[i])) {\n return false;\n }\n }\n return true;\n }\n if (typeof a === 'object' && a !== null && b !== null) {\n if (!(typeof b === 'object')) {\n return false;\n }\n var keys = Object.keys(a);\n if (keys.length !== Object.keys(b).length) {\n return false;\n }\n for (var key in a) {\n if (!deepEqual(a[key], b[key])) {\n return false;\n }\n }\n return true;\n }\n return a === b;\n}\n\nvar MAX_SAFE_INTEGER = Math.pow(2, 53) - 1;\nfunction easeCubicInOut(t) {\n if (t <= 0) {\n return 0;\n }\n if (t >= 1) {\n return 1;\n }\n var t2 = t * t, t3 = t2 * t;\n return 4 * (t < 0.5 ? t3 : 3 * (t - t2) + t3 - 0.75);\n}\nfunction bezier(p1x, p1y, p2x, p2y) {\n var bezier = new unitbezier(p1x, p1y, p2x, p2y);\n return function (t) {\n return bezier.solve(t);\n };\n}\nvar ease = bezier(0.25, 0.1, 0.25, 1);\nfunction clamp(n, min, max) {\n return Math.min(max, Math.max(min, n));\n}\nfunction wrap(n, min, max) {\n var d = max - min;\n var w = ((n - min) % d + d) % d + min;\n return w === min ? max : w;\n}\nfunction asyncAll(array, fn, callback) {\n if (!array.length) {\n return callback(null, []);\n }\n var remaining = array.length;\n var results = new Array(array.length);\n var error = null;\n array.forEach(function (item, i) {\n fn(item, function (err, result) {\n if (err) {\n error = err;\n }\n results[i] = result;\n if (--remaining === 0) {\n callback(error, results);\n }\n });\n });\n}\nfunction values(obj) {\n var result = [];\n for (var k in obj) {\n result.push(obj[k]);\n }\n return result;\n}\nfunction keysDifference(obj, other) {\n var difference = [];\n for (var i in obj) {\n if (!(i in other)) {\n difference.push(i);\n }\n }\n return difference;\n}\nfunction extend(dest) {\n var sources = [], len = arguments.length - 1;\n while (len-- > 0)\n sources[len] = arguments[len + 1];\n for (var i = 0, list = sources; i < list.length; i += 1) {\n var src = list[i];\n for (var k in src) {\n dest[k] = src[k];\n }\n }\n return dest;\n}\nfunction pick(src, properties) {\n var result = {};\n for (var i = 0; i < properties.length; i++) {\n var k = properties[i];\n if (k in src) {\n result[k] = src[k];\n }\n }\n return result;\n}\nvar id = 1;\nfunction uniqueId() {\n return id++;\n}\nfunction uuid() {\n function b(a) {\n return a ? (a ^ Math.random() * 16 >> a / 4).toString(16) : ([10000000] + -[1000] + -4000 + -8000 + -100000000000).replace(/[018]/g, b);\n }\n return b();\n}\nfunction nextPowerOfTwo(value) {\n if (value <= 1) {\n return 1;\n }\n return Math.pow(2, Math.ceil(Math.log(value) / Math.LN2));\n}\nfunction validateUuid(str) {\n return str ? /^[0-9a-f]{8}-[0-9a-f]{4}-[4][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i.test(str) : false;\n}\nfunction bindAll(fns, context) {\n fns.forEach(function (fn) {\n if (!context[fn]) {\n return;\n }\n context[fn] = context[fn].bind(context);\n });\n}\nfunction endsWith(string, suffix) {\n return string.indexOf(suffix, string.length - suffix.length) !== -1;\n}\nfunction mapObject(input, iterator, context) {\n var output = {};\n for (var key in input) {\n output[key] = iterator.call(context || this, input[key], key, input);\n }\n return output;\n}\nfunction filterObject(input, iterator, context) {\n var output = {};\n for (var key in input) {\n if (iterator.call(context || this, input[key], key, input)) {\n output[key] = input[key];\n }\n }\n return output;\n}\nfunction clone(input) {\n if (Array.isArray(input)) {\n return input.map(clone);\n } else if (typeof input === 'object' && input) {\n return mapObject(input, clone);\n } else {\n return input;\n }\n}\nfunction arraysIntersect(a, b) {\n for (var l = 0; l < a.length; l++) {\n if (b.indexOf(a[l]) >= 0) {\n return true;\n }\n }\n return false;\n}\nvar warnOnceHistory = {};\nfunction warnOnce(message) {\n if (!warnOnceHistory[message]) {\n if (typeof console !== 'undefined') {\n console.warn(message);\n }\n warnOnceHistory[message] = true;\n }\n}\nfunction isCounterClockwise(a, b, c) {\n return (c.y - a.y) * (b.x - a.x) > (b.y - a.y) * (c.x - a.x);\n}\nfunction calculateSignedArea(ring) {\n var sum = 0;\n for (var i = 0, len = ring.length, j = len - 1, p1 = void 0, p2 = void 0; i < len; j = i++) {\n p1 = ring[i];\n p2 = ring[j];\n sum += (p2.x - p1.x) * (p1.y + p2.y);\n }\n return sum;\n}\nfunction sphericalToCartesian(ref) {\n var r = ref[0];\n var azimuthal = ref[1];\n var polar = ref[2];\n azimuthal += 90;\n azimuthal *= Math.PI / 180;\n polar *= Math.PI / 180;\n return {\n x: r * Math.cos(azimuthal) * Math.sin(polar),\n y: r * Math.sin(azimuthal) * Math.sin(polar),\n z: r * Math.cos(polar)\n };\n}\nfunction isWorker() {\n return typeof WorkerGlobalScope !== 'undefined' && typeof self !== 'undefined' && self instanceof WorkerGlobalScope;\n}\nfunction parseCacheControl(cacheControl) {\n var re = /(?:^|(?:\\s*\\,\\s*))([^\\x00-\\x20\\(\\)<>@\\,;\\:\\\\\"\\/\\[\\]\\?\\=\\{\\}\\x7F]+)(?:\\=(?:([^\\x00-\\x20\\(\\)<>@\\,;\\:\\\\\"\\/\\[\\]\\?\\=\\{\\}\\x7F]+)|(?:\\\"((?:[^\"\\\\]|\\\\.)*)\\\")))?/g;\n var header = {};\n cacheControl.replace(re, function ($0, $1, $2, $3) {\n var value = $2 || $3;\n header[$1] = value ? value.toLowerCase() : true;\n return '';\n });\n if (header['max-age']) {\n var maxAge = parseInt(header['max-age'], 10);\n if (isNaN(maxAge)) {\n delete header['max-age'];\n } else {\n header['max-age'] = maxAge;\n }\n }\n return header;\n}\nvar _isSafari = null;\nfunction isSafari(scope) {\n if (_isSafari == null) {\n var userAgent = scope.navigator ? scope.navigator.userAgent : null;\n _isSafari = !!scope.safari || !!(userAgent && (/\\b(iPad|iPhone|iPod)\\b/.test(userAgent) || !!userAgent.match('Safari') && !userAgent.match('Chrome')));\n }\n return _isSafari;\n}\nfunction storageAvailable(type) {\n try {\n var storage = window$1[type];\n storage.setItem('_mapbox_test_', 1);\n storage.removeItem('_mapbox_test_');\n return true;\n } catch (e) {\n return false;\n }\n}\nfunction b64EncodeUnicode(str) {\n return window$1.btoa(encodeURIComponent(str).replace(/%([0-9A-F]{2})/g, function (match, p1) {\n return String.fromCharCode(Number('0x' + p1));\n }));\n}\nfunction b64DecodeUnicode(str) {\n return decodeURIComponent(window$1.atob(str).split('').map(function (c) {\n return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2);\n }).join(''));\n}\n\nvar now = window$1.performance && window$1.performance.now ? window$1.performance.now.bind(window$1.performance) : Date.now.bind(Date);\nvar raf = window$1.requestAnimationFrame || window$1.mozRequestAnimationFrame || window$1.webkitRequestAnimationFrame || window$1.msRequestAnimationFrame;\nvar cancel = window$1.cancelAnimationFrame || window$1.mozCancelAnimationFrame || window$1.webkitCancelAnimationFrame || window$1.msCancelAnimationFrame;\nvar linkEl;\nvar reducedMotionQuery;\nvar exported = {\n now: now,\n frame: function frame(fn) {\n var frame = raf(fn);\n return {\n cancel: function () {\n return cancel(frame);\n }\n };\n },\n getImageData: function getImageData(img, padding) {\n if (padding === void 0)\n padding = 0;\n var canvas = window$1.document.createElement('canvas');\n var context = canvas.getContext('2d');\n if (!context) {\n throw new Error('failed to create canvas 2d context');\n }\n canvas.width = img.width;\n canvas.height = img.height;\n context.drawImage(img, 0, 0, img.width, img.height);\n return context.getImageData(-padding, -padding, img.width + 2 * padding, img.height + 2 * padding);\n },\n resolveURL: function resolveURL(path) {\n if (!linkEl) {\n linkEl = window$1.document.createElement('a');\n }\n linkEl.href = path;\n return linkEl.href;\n },\n hardwareConcurrency: window$1.navigator && window$1.navigator.hardwareConcurrency || 4,\n get devicePixelRatio() {\n return window$1.devicePixelRatio;\n },\n get prefersReducedMotion() {\n if (!window$1.matchMedia) {\n return false;\n }\n if (reducedMotionQuery == null) {\n reducedMotionQuery = window$1.matchMedia('(prefers-reduced-motion: reduce)');\n }\n return reducedMotionQuery.matches;\n }\n};\n\nvar config = {\n API_URL: 'https://api.mapbox.com',\n get EVENTS_URL() {\n if (!this.API_URL) {\n return null;\n }\n if (this.API_URL.indexOf('https://api.mapbox.cn') === 0) {\n return 'https://events.mapbox.cn/events/v2';\n } else if (this.API_URL.indexOf('https://api.mapbox.com') === 0) {\n return 'https://events.mapbox.com/events/v2';\n } else {\n return null;\n }\n },\n FEEDBACK_URL: 'https://apps.mapbox.com/feedback',\n REQUIRE_ACCESS_TOKEN: true,\n ACCESS_TOKEN: null,\n MAX_PARALLEL_IMAGE_REQUESTS: 16\n};\n\nvar exported$1 = {\n supported: false,\n testSupport: testSupport\n};\nvar glForTesting;\nvar webpCheckComplete = false;\nvar webpImgTest;\nvar webpImgTestOnloadComplete = false;\nif (window$1.document) {\n webpImgTest = window$1.document.createElement('img');\n webpImgTest.onload = function () {\n if (glForTesting) {\n testWebpTextureUpload(glForTesting);\n }\n glForTesting = null;\n webpImgTestOnloadComplete = true;\n };\n webpImgTest.onerror = function () {\n webpCheckComplete = true;\n glForTesting = null;\n };\n webpImgTest.src = 'data:image/webp;base64,UklGRh4AAABXRUJQVlA4TBEAAAAvAQAAAAfQ//73v/+BiOh/AAA=';\n}\nfunction testSupport(gl) {\n if (webpCheckComplete || !webpImgTest) {\n return;\n }\n if (webpImgTestOnloadComplete) {\n testWebpTextureUpload(gl);\n } else {\n glForTesting = gl;\n }\n}\nfunction testWebpTextureUpload(gl) {\n var texture = gl.createTexture();\n gl.bindTexture(gl.TEXTURE_2D, texture);\n try {\n gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, webpImgTest);\n if (gl.isContextLost()) {\n return;\n }\n exported$1.supported = true;\n } catch (e) {\n }\n gl.deleteTexture(texture);\n webpCheckComplete = true;\n}\n\nvar SKU_ID = '01';\nfunction createSkuToken() {\n var TOKEN_VERSION = '1';\n var base62chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';\n var sessionRandomizer = '';\n for (var i = 0; i < 10; i++) {\n sessionRandomizer += base62chars[Math.floor(Math.random() * 62)];\n }\n var expiration = 12 * 60 * 60 * 1000;\n var token = [\n TOKEN_VERSION,\n SKU_ID,\n sessionRandomizer\n ].join('');\n var tokenExpiresAt = Date.now() + expiration;\n return {\n token: token,\n tokenExpiresAt: tokenExpiresAt\n };\n}\n\nvar RequestManager = function RequestManager(transformRequestFn, customAccessToken) {\n this._transformRequestFn = transformRequestFn;\n this._customAccessToken = customAccessToken;\n this._createSkuToken();\n};\nRequestManager.prototype._createSkuToken = function _createSkuToken() {\n var skuToken = createSkuToken();\n this._skuToken = skuToken.token;\n this._skuTokenExpiresAt = skuToken.tokenExpiresAt;\n};\nRequestManager.prototype._isSkuTokenExpired = function _isSkuTokenExpired() {\n return Date.now() > this._skuTokenExpiresAt;\n};\nRequestManager.prototype.transformRequest = function transformRequest(url, type) {\n if (this._transformRequestFn) {\n return this._transformRequestFn(url, type) || { url: url };\n }\n return { url: url };\n};\nRequestManager.prototype.normalizeStyleURL = function normalizeStyleURL(url, accessToken) {\n if (!isMapboxURL(url)) {\n return url;\n }\n var urlObject = parseUrl(url);\n urlObject.path = '/styles/v1' + urlObject.path;\n return this._makeAPIURL(urlObject, this._customAccessToken || accessToken);\n};\nRequestManager.prototype.normalizeGlyphsURL = function normalizeGlyphsURL(url, accessToken) {\n if (!isMapboxURL(url)) {\n return url;\n }\n var urlObject = parseUrl(url);\n urlObject.path = '/fonts/v1' + urlObject.path;\n return this._makeAPIURL(urlObject, this._customAccessToken || accessToken);\n};\nRequestManager.prototype.normalizeSourceURL = function normalizeSourceURL(url, accessToken) {\n if (!isMapboxURL(url)) {\n return url;\n }\n var urlObject = parseUrl(url);\n urlObject.path = '/v4/' + urlObject.authority + '.json';\n urlObject.params.push('secure');\n return this._makeAPIURL(urlObject, this._customAccessToken || accessToken);\n};\nRequestManager.prototype.normalizeSpriteURL = function normalizeSpriteURL(url, format, extension, accessToken) {\n var urlObject = parseUrl(url);\n if (!isMapboxURL(url)) {\n urlObject.path += '' + format + extension;\n return formatUrl(urlObject);\n }\n urlObject.path = '/styles/v1' + urlObject.path + '/sprite' + format + extension;\n return this._makeAPIURL(urlObject, this._customAccessToken || accessToken);\n};\nRequestManager.prototype.normalizeTileURL = function normalizeTileURL(tileURL, tileSize) {\n if (this._isSkuTokenExpired()) {\n this._createSkuToken();\n }\n if (tileURL && !isMapboxURL(tileURL)) {\n return tileURL;\n }\n var urlObject = parseUrl(tileURL);\n var imageExtensionRe = /(\\.(png|jpg)\\d*)(?=$)/;\n var tileURLAPIPrefixRe = /^.+\\/v4\\//;\n var suffix = exported.devicePixelRatio >= 2 || tileSize === 512 ? '@2x' : '';\n var extension = exported$1.supported ? '.webp' : '$1';\n urlObject.path = urlObject.path.replace(imageExtensionRe, '' + suffix + extension);\n urlObject.path = urlObject.path.replace(tileURLAPIPrefixRe, '/');\n urlObject.path = '/v4' + urlObject.path;\n var accessToken = this._customAccessToken || getAccessToken(urlObject.params) || config.ACCESS_TOKEN;\n if (config.REQUIRE_ACCESS_TOKEN && accessToken && this._skuToken) {\n urlObject.params.push('sku=' + this._skuToken);\n }\n return this._makeAPIURL(urlObject, accessToken);\n};\nRequestManager.prototype.canonicalizeTileURL = function canonicalizeTileURL(url, removeAccessToken) {\n var version = '/v4/';\n var extensionRe = /\\.[\\w]+$/;\n var urlObject = parseUrl(url);\n if (!urlObject.path.match(/(^\\/v4\\/)/) || !urlObject.path.match(extensionRe)) {\n return url;\n }\n var result = 'mapbox://tiles/';\n result += urlObject.path.replace(version, '');\n var params = urlObject.params;\n if (removeAccessToken) {\n params = params.filter(function (p) {\n return !p.match(/^access_token=/);\n });\n }\n if (params.length) {\n result += '?' + params.join('&');\n }\n return result;\n};\nRequestManager.prototype.canonicalizeTileset = function canonicalizeTileset(tileJSON, sourceURL) {\n var removeAccessToken = sourceURL ? isMapboxURL(sourceURL) : false;\n var canonical = [];\n for (var i = 0, list = tileJSON.tiles || []; i < list.length; i += 1) {\n var url = list[i];\n if (isMapboxHTTPURL(url)) {\n canonical.push(this.canonicalizeTileURL(url, removeAccessToken));\n } else {\n canonical.push(url);\n }\n }\n return canonical;\n};\nRequestManager.prototype._makeAPIURL = function _makeAPIURL(urlObject, accessToken) {\n var help = 'See https://www.mapbox.com/api-documentation/#access-tokens-and-token-scopes';\n var apiUrlObject = parseUrl(config.API_URL);\n urlObject.protocol = apiUrlObject.protocol;\n urlObject.authority = apiUrlObject.authority;\n if (urlObject.protocol === 'http') {\n var i = urlObject.params.indexOf('secure');\n if (i >= 0) {\n urlObject.params.splice(i, 1);\n }\n }\n if (apiUrlObject.path !== '/') {\n urlObject.path = '' + apiUrlObject.path + urlObject.path;\n }\n if (!config.REQUIRE_ACCESS_TOKEN) {\n return formatUrl(urlObject);\n }\n accessToken = accessToken || config.ACCESS_TOKEN;\n if (!accessToken) {\n throw new Error('An API access token is required to use Mapbox GL. ' + help);\n }\n if (accessToken[0] === 's') {\n throw new Error('Use a public access token (pk.*) with Mapbox GL, not a secret access token (sk.*). ' + help);\n }\n urlObject.params = urlObject.params.filter(function (d) {\n return d.indexOf('access_token') === -1;\n });\n urlObject.params.push('access_token=' + accessToken);\n return formatUrl(urlObject);\n};\nfunction isMapboxURL(url) {\n return url.indexOf('mapbox:') === 0;\n}\nvar mapboxHTTPURLRe = /^((https?:)?\\/\\/)?([^\\/]+\\.)?mapbox\\.c(n|om)(\\/|\\?|$)/i;\nfunction isMapboxHTTPURL(url) {\n return mapboxHTTPURLRe.test(url);\n}\nfunction hasCacheDefeatingSku(url) {\n return url.indexOf('sku=') > 0 && isMapboxHTTPURL(url);\n}\nfunction getAccessToken(params) {\n for (var i = 0, list = params; i < list.length; i += 1) {\n var param = list[i];\n var match = param.match(/^access_token=(.*)$/);\n if (match) {\n return match[1];\n }\n }\n return null;\n}\nvar urlRe = /^(\\w+):\\/\\/([^/?]*)(\\/[^?]+)?\\??(.+)?/;\nfunction parseUrl(url) {\n var parts = url.match(urlRe);\n if (!parts) {\n throw new Error('Unable to parse URL object');\n }\n return {\n protocol: parts[1],\n authority: parts[2],\n path: parts[3] || '/',\n params: parts[4] ? parts[4].split('&') : []\n };\n}\nfunction formatUrl(obj) {\n var params = obj.params.length ? '?' + obj.params.join('&') : '';\n return obj.protocol + '://' + obj.authority + obj.path + params;\n}\nvar telemEventKey = 'mapbox.eventData';\nfunction parseAccessToken(accessToken) {\n if (!accessToken) {\n return null;\n }\n var parts = accessToken.split('.');\n if (!parts || parts.length !== 3) {\n return null;\n }\n try {\n var jsonData = JSON.parse(b64DecodeUnicode(parts[1]));\n return jsonData;\n } catch (e) {\n return null;\n }\n}\nvar TelemetryEvent = function TelemetryEvent(type) {\n this.type = type;\n this.anonId = null;\n this.eventData = {};\n this.queue = [];\n this.pendingRequest = null;\n};\nTelemetryEvent.prototype.getStorageKey = function getStorageKey(domain) {\n var tokenData = parseAccessToken(config.ACCESS_TOKEN);\n var u = '';\n if (tokenData && tokenData['u']) {\n u = b64EncodeUnicode(tokenData['u']);\n } else {\n u = config.ACCESS_TOKEN || '';\n }\n return domain ? telemEventKey + '.' + domain + ':' + u : telemEventKey + ':' + u;\n};\nTelemetryEvent.prototype.fetchEventData = function fetchEventData() {\n var isLocalStorageAvailable = storageAvailable('localStorage');\n var storageKey = this.getStorageKey();\n var uuidKey = this.getStorageKey('uuid');\n if (isLocalStorageAvailable) {\n try {\n var data = window$1.localStorage.getItem(storageKey);\n if (data) {\n this.eventData = JSON.parse(data);\n }\n var uuid = window$1.localStorage.getItem(uuidKey);\n if (uuid) {\n this.anonId = uuid;\n }\n } catch (e) {\n warnOnce('Unable to read from LocalStorage');\n }\n }\n};\nTelemetryEvent.prototype.saveEventData = function saveEventData() {\n var isLocalStorageAvailable = storageAvailable('localStorage');\n var storageKey = this.getStorageKey();\n var uuidKey = this.getStorageKey('uuid');\n if (isLocalStorageAvailable) {\n try {\n window$1.localStorage.setItem(uuidKey, this.anonId);\n if (Object.keys(this.eventData).length >= 1) {\n window$1.localStorage.setItem(storageKey, JSON.stringify(this.eventData));\n }\n } catch (e) {\n warnOnce('Unable to write to LocalStorage');\n }\n }\n};\nTelemetryEvent.prototype.processRequests = function processRequests(_) {\n};\nTelemetryEvent.prototype.postEvent = function postEvent(timestamp, additionalPayload, callback, customAccessToken) {\n var this$1 = this;\n if (!config.EVENTS_URL) {\n return;\n }\n var eventsUrlObject = parseUrl(config.EVENTS_URL);\n eventsUrlObject.params.push('access_token=' + (customAccessToken || config.ACCESS_TOKEN || ''));\n var payload = {\n event: this.type,\n created: new Date(timestamp).toISOString(),\n sdkIdentifier: 'mapbox-gl-js',\n sdkVersion: version,\n skuId: SKU_ID,\n userId: this.anonId\n };\n var finalPayload = additionalPayload ? extend(payload, additionalPayload) : payload;\n var request = {\n url: formatUrl(eventsUrlObject),\n headers: { 'Content-Type': 'text/plain' },\n body: JSON.stringify([finalPayload])\n };\n this.pendingRequest = postData(request, function (error) {\n this$1.pendingRequest = null;\n callback(error);\n this$1.saveEventData();\n this$1.processRequests(customAccessToken);\n });\n};\nTelemetryEvent.prototype.queueRequest = function queueRequest(event, customAccessToken) {\n this.queue.push(event);\n this.processRequests(customAccessToken);\n};\nvar MapLoadEvent = function (TelemetryEvent) {\n function MapLoadEvent() {\n TelemetryEvent.call(this, 'map.load');\n this.success = {};\n this.skuToken = '';\n }\n if (TelemetryEvent)\n MapLoadEvent.__proto__ = TelemetryEvent;\n MapLoadEvent.prototype = Object.create(TelemetryEvent && TelemetryEvent.prototype);\n MapLoadEvent.prototype.constructor = MapLoadEvent;\n MapLoadEvent.prototype.postMapLoadEvent = function postMapLoadEvent(tileUrls, mapId, skuToken, customAccessToken) {\n this.skuToken = skuToken;\n if (config.EVENTS_URL && customAccessToken || config.ACCESS_TOKEN && Array.isArray(tileUrls) && tileUrls.some(function (url) {\n return isMapboxURL(url) || isMapboxHTTPURL(url);\n })) {\n this.queueRequest({\n id: mapId,\n timestamp: Date.now()\n }, customAccessToken);\n }\n };\n MapLoadEvent.prototype.processRequests = function processRequests(customAccessToken) {\n var this$1 = this;\n if (this.pendingRequest || this.queue.length === 0) {\n return;\n }\n var ref = this.queue.shift();\n var id = ref.id;\n var timestamp = ref.timestamp;\n if (id && this.success[id]) {\n return;\n }\n if (!this.anonId) {\n this.fetchEventData();\n }\n if (!validateUuid(this.anonId)) {\n this.anonId = uuid();\n }\n this.postEvent(timestamp, { skuToken: this.skuToken }, function (err) {\n if (!err) {\n if (id) {\n this$1.success[id] = true;\n }\n }\n }, customAccessToken);\n };\n return MapLoadEvent;\n}(TelemetryEvent);\nvar TurnstileEvent = function (TelemetryEvent) {\n function TurnstileEvent(customAccessToken) {\n TelemetryEvent.call(this, 'appUserTurnstile');\n this._customAccessToken = customAccessToken;\n }\n if (TelemetryEvent)\n TurnstileEvent.__proto__ = TelemetryEvent;\n TurnstileEvent.prototype = Object.create(TelemetryEvent && TelemetryEvent.prototype);\n TurnstileEvent.prototype.constructor = TurnstileEvent;\n TurnstileEvent.prototype.postTurnstileEvent = function postTurnstileEvent(tileUrls, customAccessToken) {\n if (config.EVENTS_URL && config.ACCESS_TOKEN && Array.isArray(tileUrls) && tileUrls.some(function (url) {\n return isMapboxURL(url) || isMapboxHTTPURL(url);\n })) {\n this.queueRequest(Date.now(), customAccessToken);\n }\n };\n TurnstileEvent.prototype.processRequests = function processRequests(customAccessToken) {\n var this$1 = this;\n if (this.pendingRequest || this.queue.length === 0) {\n return;\n }\n if (!this.anonId || !this.eventData.lastSuccess || !this.eventData.tokenU) {\n this.fetchEventData();\n }\n var tokenData = parseAccessToken(config.ACCESS_TOKEN);\n var tokenU = tokenData ? tokenData['u'] : config.ACCESS_TOKEN;\n var dueForEvent = tokenU !== this.eventData.tokenU;\n if (!validateUuid(this.anonId)) {\n this.anonId = uuid();\n dueForEvent = true;\n }\n var nextUpdate = this.queue.shift();\n if (this.eventData.lastSuccess) {\n var lastUpdate = new Date(this.eventData.lastSuccess);\n var nextDate = new Date(nextUpdate);\n var daysElapsed = (nextUpdate - this.eventData.lastSuccess) / (24 * 60 * 60 * 1000);\n dueForEvent = dueForEvent || daysElapsed >= 1 || daysElapsed < -1 || lastUpdate.getDate() !== nextDate.getDate();\n } else {\n dueForEvent = true;\n }\n if (!dueForEvent) {\n return this.processRequests();\n }\n this.postEvent(nextUpdate, { 'enabled.telemetry': false }, function (err) {\n if (!err) {\n this$1.eventData.lastSuccess = nextUpdate;\n this$1.eventData.tokenU = tokenU;\n }\n }, customAccessToken);\n };\n return TurnstileEvent;\n}(TelemetryEvent);\nvar turnstileEvent_ = new TurnstileEvent();\nvar postTurnstileEvent = turnstileEvent_.postTurnstileEvent.bind(turnstileEvent_);\nvar mapLoadEvent_ = new MapLoadEvent();\nvar postMapLoadEvent = mapLoadEvent_.postMapLoadEvent.bind(mapLoadEvent_);\n\nvar CACHE_NAME = 'mapbox-tiles';\nvar cacheLimit = 500;\nvar cacheCheckThreshold = 50;\nvar MIN_TIME_UNTIL_EXPIRY = 1000 * 60 * 7;\nvar sharedCache;\nfunction cacheOpen() {\n if (window$1.caches && !sharedCache) {\n sharedCache = window$1.caches.open(CACHE_NAME);\n }\n}\nvar responseConstructorSupportsReadableStream;\nfunction prepareBody(response, callback) {\n if (responseConstructorSupportsReadableStream === undefined) {\n try {\n new Response(new ReadableStream());\n responseConstructorSupportsReadableStream = true;\n } catch (e) {\n responseConstructorSupportsReadableStream = false;\n }\n }\n if (responseConstructorSupportsReadableStream) {\n callback(response.body);\n } else {\n response.blob().then(callback);\n }\n}\nfunction cachePut(request, response, requestTime) {\n cacheOpen();\n if (!sharedCache) {\n return;\n }\n var options = {\n status: response.status,\n statusText: response.statusText,\n headers: new window$1.Headers()\n };\n response.headers.forEach(function (v, k) {\n return options.headers.set(k, v);\n });\n var cacheControl = parseCacheControl(response.headers.get('Cache-Control') || '');\n if (cacheControl['no-store']) {\n return;\n }\n if (cacheControl['max-age']) {\n options.headers.set('Expires', new Date(requestTime + cacheControl['max-age'] * 1000).toUTCString());\n }\n var timeUntilExpiry = new Date(options.headers.get('Expires')).getTime() - requestTime;\n if (timeUntilExpiry < MIN_TIME_UNTIL_EXPIRY) {\n return;\n }\n prepareBody(response, function (body) {\n var clonedResponse = new window$1.Response(body, options);\n cacheOpen();\n if (!sharedCache) {\n return;\n }\n sharedCache.then(function (cache) {\n return cache.put(stripQueryParameters(request.url), clonedResponse);\n }).catch(function (e) {\n return warnOnce(e.message);\n });\n });\n}\nfunction stripQueryParameters(url) {\n var start = url.indexOf('?');\n return start < 0 ? url : url.slice(0, start);\n}\nfunction cacheGet(request, callback) {\n cacheOpen();\n if (!sharedCache) {\n return callback(null);\n }\n var strippedURL = stripQueryParameters(request.url);\n sharedCache.then(function (cache) {\n cache.match(strippedURL).then(function (response) {\n var fresh = isFresh(response);\n cache.delete(strippedURL);\n if (fresh) {\n cache.put(strippedURL, response.clone());\n }\n callback(null, response, fresh);\n }).catch(callback);\n }).catch(callback);\n}\nfunction isFresh(response) {\n if (!response) {\n return false;\n }\n var expires = new Date(response.headers.get('Expires') || 0);\n var cacheControl = parseCacheControl(response.headers.get('Cache-Control') || '');\n return expires > Date.now() && !cacheControl['no-cache'];\n}\nvar globalEntryCounter = Infinity;\nfunction cacheEntryPossiblyAdded(dispatcher) {\n globalEntryCounter++;\n if (globalEntryCounter > cacheCheckThreshold) {\n dispatcher.getActor().send('enforceCacheSizeLimit', cacheLimit);\n globalEntryCounter = 0;\n }\n}\nfunction enforceCacheSizeLimit(limit) {\n cacheOpen();\n if (!sharedCache) {\n return;\n }\n sharedCache.then(function (cache) {\n cache.keys().then(function (keys) {\n for (var i = 0; i < keys.length - limit; i++) {\n cache.delete(keys[i]);\n }\n });\n });\n}\nfunction clearTileCache(callback) {\n var promise = window$1.caches.delete(CACHE_NAME);\n if (callback) {\n promise.catch(callback).then(function () {\n return callback();\n });\n }\n}\nfunction setCacheLimits(limit, checkThreshold) {\n cacheLimit = limit;\n cacheCheckThreshold = checkThreshold;\n}\n\nvar supportsOffscreenCanvas;\nfunction offscreenCanvasSupported() {\n if (supportsOffscreenCanvas == null) {\n supportsOffscreenCanvas = window$1.OffscreenCanvas && new window$1.OffscreenCanvas(1, 1).getContext('2d') && typeof window$1.createImageBitmap === 'function';\n }\n return supportsOffscreenCanvas;\n}\n\nvar ResourceType = {\n Unknown: 'Unknown',\n Style: 'Style',\n Source: 'Source',\n Tile: 'Tile',\n Glyphs: 'Glyphs',\n SpriteImage: 'SpriteImage',\n SpriteJSON: 'SpriteJSON',\n Image: 'Image'\n};\nif (typeof Object.freeze == 'function') {\n Object.freeze(ResourceType);\n}\nvar AJAXError = function (Error) {\n function AJAXError(message, status, url) {\n if (status === 401 && isMapboxHTTPURL(url)) {\n message += ': you may have provided an invalid Mapbox access token. See https://www.mapbox.com/api-documentation/#access-tokens-and-token-scopes';\n }\n Error.call(this, message);\n this.status = status;\n this.url = url;\n this.name = this.constructor.name;\n this.message = message;\n }\n if (Error)\n AJAXError.__proto__ = Error;\n AJAXError.prototype = Object.create(Error && Error.prototype);\n AJAXError.prototype.constructor = AJAXError;\n AJAXError.prototype.toString = function toString() {\n return this.name + ': ' + this.message + ' (' + this.status + '): ' + this.url;\n };\n return AJAXError;\n}(Error);\nvar getReferrer = isWorker() ? function () {\n return self.worker && self.worker.referrer;\n} : function () {\n return (window$1.location.protocol === 'blob:' ? window$1.parent : window$1).location.href;\n};\nvar isFileURL = function (url) {\n return /^file:/.test(url) || /^file:/.test(getReferrer()) && !/^\\w+:/.test(url);\n};\nfunction makeFetchRequest(requestParameters, callback) {\n var controller = new window$1.AbortController();\n var request = new window$1.Request(requestParameters.url, {\n method: requestParameters.method || 'GET',\n body: requestParameters.body,\n credentials: requestParameters.credentials,\n headers: requestParameters.headers,\n referrer: getReferrer(),\n signal: controller.signal\n });\n var complete = false;\n var aborted = false;\n var cacheIgnoringSearch = hasCacheDefeatingSku(request.url);\n if (requestParameters.type === 'json') {\n request.headers.set('Accept', 'application/json');\n }\n var validateOrFetch = function (err, cachedResponse, responseIsFresh) {\n if (aborted) {\n return;\n }\n if (err) {\n if (err.message !== 'SecurityError') {\n warnOnce(err);\n }\n }\n if (cachedResponse && responseIsFresh) {\n return finishRequest(cachedResponse);\n }\n var requestTime = Date.now();\n window$1.fetch(request).then(function (response) {\n if (response.ok) {\n var cacheableResponse = cacheIgnoringSearch ? response.clone() : null;\n return finishRequest(response, cacheableResponse, requestTime);\n } else {\n return callback(new AJAXError(response.statusText, response.status, requestParameters.url));\n }\n }).catch(function (error) {\n if (error.code === 20) {\n return;\n }\n callback(new Error(error.message));\n });\n };\n var finishRequest = function (response, cacheableResponse, requestTime) {\n (requestParameters.type === 'arrayBuffer' ? response.arrayBuffer() : requestParameters.type === 'json' ? response.json() : response.text()).then(function (result) {\n if (aborted) {\n return;\n }\n if (cacheableResponse && requestTime) {\n cachePut(request, cacheableResponse, requestTime);\n }\n complete = true;\n callback(null, result, response.headers.get('Cache-Control'), response.headers.get('Expires'));\n }).catch(function (err) {\n if (!aborted) {\n callback(new Error(err.message));\n }\n });\n };\n if (cacheIgnoringSearch) {\n cacheGet(request, validateOrFetch);\n } else {\n validateOrFetch(null, null);\n }\n return {\n cancel: function () {\n aborted = true;\n if (!complete) {\n controller.abort();\n }\n }\n };\n}\nfunction makeXMLHttpRequest(requestParameters, callback) {\n var xhr = new window$1.XMLHttpRequest();\n xhr.open(requestParameters.method || 'GET', requestParameters.url, true);\n if (requestParameters.type === 'arrayBuffer') {\n xhr.responseType = 'arraybuffer';\n }\n for (var k in requestParameters.headers) {\n xhr.setRequestHeader(k, requestParameters.headers[k]);\n }\n if (requestParameters.type === 'json') {\n xhr.responseType = 'text';\n xhr.setRequestHeader('Accept', 'application/json');\n }\n xhr.withCredentials = requestParameters.credentials === 'include';\n xhr.onerror = function () {\n callback(new Error(xhr.statusText));\n };\n xhr.onload = function () {\n if ((xhr.status >= 200 && xhr.status < 300 || xhr.status === 0) && xhr.response !== null) {\n var data = xhr.response;\n if (requestParameters.type === 'json') {\n try {\n data = JSON.parse(xhr.response);\n } catch (err) {\n return callback(err);\n }\n }\n callback(null, data, xhr.getResponseHeader('Cache-Control'), xhr.getResponseHeader('Expires'));\n } else {\n callback(new AJAXError(xhr.statusText, xhr.status, requestParameters.url));\n }\n };\n xhr.send(requestParameters.body);\n return {\n cancel: function () {\n return xhr.abort();\n }\n };\n}\nvar makeRequest = function (requestParameters, callback) {\n if (!isFileURL(requestParameters.url)) {\n if (window$1.fetch && window$1.Request && window$1.AbortController && window$1.Request.prototype.hasOwnProperty('signal')) {\n return makeFetchRequest(requestParameters, callback);\n }\n if (isWorker() && self.worker && self.worker.actor) {\n var queueOnMainThread = true;\n return self.worker.actor.send('getResource', requestParameters, callback, undefined, queueOnMainThread);\n }\n }\n return makeXMLHttpRequest(requestParameters, callback);\n};\nvar getJSON = function (requestParameters, callback) {\n return makeRequest(extend(requestParameters, { type: 'json' }), callback);\n};\nvar getArrayBuffer = function (requestParameters, callback) {\n return makeRequest(extend(requestParameters, { type: 'arrayBuffer' }), callback);\n};\nvar postData = function (requestParameters, callback) {\n return makeRequest(extend(requestParameters, { method: 'POST' }), callback);\n};\nfunction sameOrigin(url) {\n var a = window$1.document.createElement('a');\n a.href = url;\n return a.protocol === window$1.document.location.protocol && a.host === window$1.document.location.host;\n}\nvar transparentPngUrl = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAC0lEQVQYV2NgAAIAAAUAAarVyFEAAAAASUVORK5CYII=';\nfunction arrayBufferToImage(data, callback, cacheControl, expires) {\n var img = new window$1.Image();\n var URL = window$1.URL;\n img.onload = function () {\n callback(null, img);\n URL.revokeObjectURL(img.src);\n img.onload = null;\n window$1.requestAnimationFrame(function () {\n img.src = transparentPngUrl;\n });\n };\n img.onerror = function () {\n return callback(new Error('Could not load image. Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported.'));\n };\n var blob = new window$1.Blob([new Uint8Array(data)], { type: 'image/png' });\n img.cacheControl = cacheControl;\n img.expires = expires;\n img.src = data.byteLength ? URL.createObjectURL(blob) : transparentPngUrl;\n}\nfunction arrayBufferToImageBitmap(data, callback) {\n var blob = new window$1.Blob([new Uint8Array(data)], { type: 'image/png' });\n window$1.createImageBitmap(blob).then(function (imgBitmap) {\n callback(null, imgBitmap);\n }).catch(function (e) {\n callback(new Error('Could not load image because of ' + e.message + '. Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported.'));\n });\n}\nvar imageQueue, numImageRequests;\nvar resetImageRequestQueue = function () {\n imageQueue = [];\n numImageRequests = 0;\n};\nresetImageRequestQueue();\nvar getImage = function (requestParameters, callback) {\n if (exported$1.supported) {\n if (!requestParameters.headers) {\n requestParameters.headers = {};\n }\n requestParameters.headers.accept = 'image/webp,*/*';\n }\n if (numImageRequests >= config.MAX_PARALLEL_IMAGE_REQUESTS) {\n var queued = {\n requestParameters: requestParameters,\n callback: callback,\n cancelled: false,\n cancel: function cancel() {\n this.cancelled = true;\n }\n };\n imageQueue.push(queued);\n return queued;\n }\n numImageRequests++;\n var advanced = false;\n var advanceImageRequestQueue = function () {\n if (advanced) {\n return;\n }\n advanced = true;\n numImageRequests--;\n while (imageQueue.length && numImageRequests < config.MAX_PARALLEL_IMAGE_REQUESTS) {\n var request = imageQueue.shift();\n var requestParameters = request.requestParameters;\n var callback = request.callback;\n var cancelled = request.cancelled;\n if (!cancelled) {\n request.cancel = getImage(requestParameters, callback).cancel;\n }\n }\n };\n var request = getArrayBuffer(requestParameters, function (err, data, cacheControl, expires) {\n advanceImageRequestQueue();\n if (err) {\n callback(err);\n } else if (data) {\n if (offscreenCanvasSupported()) {\n arrayBufferToImageBitmap(data, callback);\n } else {\n arrayBufferToImage(data, callback, cacheControl, expires);\n }\n }\n });\n return {\n cancel: function () {\n request.cancel();\n advanceImageRequestQueue();\n }\n };\n};\nvar getVideo = function (urls, callback) {\n var video = window$1.document.createElement('video');\n video.muted = true;\n video.onloadstart = function () {\n callback(null, video);\n };\n for (var i = 0; i < urls.length; i++) {\n var s = window$1.document.createElement('source');\n if (!sameOrigin(urls[i])) {\n video.crossOrigin = 'Anonymous';\n }\n s.src = urls[i];\n video.appendChild(s);\n }\n return {\n cancel: function () {\n }\n };\n};\n\nfunction _addEventListener(type, listener, listenerList) {\n var listenerExists = listenerList[type] && listenerList[type].indexOf(listener) !== -1;\n if (!listenerExists) {\n listenerList[type] = listenerList[type] || [];\n listenerList[type].push(listener);\n }\n}\nfunction _removeEventListener(type, listener, listenerList) {\n if (listenerList && listenerList[type]) {\n var index = listenerList[type].indexOf(listener);\n if (index !== -1) {\n listenerList[type].splice(index, 1);\n }\n }\n}\nvar Event = function Event(type, data) {\n if (data === void 0)\n data = {};\n extend(this, data);\n this.type = type;\n};\nvar ErrorEvent = function (Event) {\n function ErrorEvent(error, data) {\n if (data === void 0)\n data = {};\n Event.call(this, 'error', extend({ error: error }, data));\n }\n if (Event)\n ErrorEvent.__proto__ = Event;\n ErrorEvent.prototype = Object.create(Event && Event.prototype);\n ErrorEvent.prototype.constructor = ErrorEvent;\n return ErrorEvent;\n}(Event);\nvar Evented = function Evented() {\n};\nEvented.prototype.on = function on(type, listener) {\n this._listeners = this._listeners || {};\n _addEventListener(type, listener, this._listeners);\n return this;\n};\nEvented.prototype.off = function off(type, listener) {\n _removeEventListener(type, listener, this._listeners);\n _removeEventListener(type, listener, this._oneTimeListeners);\n return this;\n};\nEvented.prototype.once = function once(type, listener) {\n this._oneTimeListeners = this._oneTimeListeners || {};\n _addEventListener(type, listener, this._oneTimeListeners);\n return this;\n};\nEvented.prototype.fire = function fire(event, properties) {\n if (typeof event === 'string') {\n event = new Event(event, properties || {});\n }\n var type = event.type;\n if (this.listens(type)) {\n event.target = this;\n var listeners = this._listeners && this._listeners[type] ? this._listeners[type].slice() : [];\n for (var i = 0, list = listeners; i < list.length; i += 1) {\n var listener = list[i];\n listener.call(this, event);\n }\n var oneTimeListeners = this._oneTimeListeners && this._oneTimeListeners[type] ? this._oneTimeListeners[type].slice() : [];\n for (var i$1 = 0, list$1 = oneTimeListeners; i$1 < list$1.length; i$1 += 1) {\n var listener$1 = list$1[i$1];\n _removeEventListener(type, listener$1, this._oneTimeListeners);\n listener$1.call(this, event);\n }\n var parent = this._eventedParent;\n if (parent) {\n extend(event, typeof this._eventedParentData === 'function' ? this._eventedParentData() : this._eventedParentData);\n parent.fire(event);\n }\n } else if (event instanceof ErrorEvent) {\n console.error(event.error);\n }\n return this;\n};\nEvented.prototype.listens = function listens(type) {\n return this._listeners && this._listeners[type] && this._listeners[type].length > 0 || this._oneTimeListeners && this._oneTimeListeners[type] && this._oneTimeListeners[type].length > 0 || this._eventedParent && this._eventedParent.listens(type);\n};\nEvented.prototype.setEventedParent = function setEventedParent(parent, data) {\n this._eventedParent = parent;\n this._eventedParentData = data;\n return this;\n};\n\nvar $version = 8;\nvar $root = {\n\tversion: {\n\t\trequired: true,\n\t\ttype: \"enum\",\n\t\tvalues: [\n\t\t\t8\n\t\t]\n\t},\n\tname: {\n\t\ttype: \"string\"\n\t},\n\tmetadata: {\n\t\ttype: \"*\"\n\t},\n\tcenter: {\n\t\ttype: \"array\",\n\t\tvalue: \"number\"\n\t},\n\tzoom: {\n\t\ttype: \"number\"\n\t},\n\tbearing: {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tperiod: 360,\n\t\tunits: \"degrees\"\n\t},\n\tpitch: {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tunits: \"degrees\"\n\t},\n\tlight: {\n\t\ttype: \"light\"\n\t},\n\tsources: {\n\t\trequired: true,\n\t\ttype: \"sources\"\n\t},\n\tsprite: {\n\t\ttype: \"string\"\n\t},\n\tglyphs: {\n\t\ttype: \"string\"\n\t},\n\ttransition: {\n\t\ttype: \"transition\"\n\t},\n\tlayers: {\n\t\trequired: true,\n\t\ttype: \"array\",\n\t\tvalue: \"layer\"\n\t}\n};\nvar sources = {\n\t\"*\": {\n\t\ttype: \"source\"\n\t}\n};\nvar source = [\n\t\"source_vector\",\n\t\"source_raster\",\n\t\"source_raster_dem\",\n\t\"source_geojson\",\n\t\"source_video\",\n\t\"source_image\"\n];\nvar source_vector = {\n\ttype: {\n\t\trequired: true,\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvector: {\n\t\t\t}\n\t\t}\n\t},\n\turl: {\n\t\ttype: \"string\"\n\t},\n\ttiles: {\n\t\ttype: \"array\",\n\t\tvalue: \"string\"\n\t},\n\tbounds: {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 4,\n\t\t\"default\": [\n\t\t\t-180,\n\t\t\t-85.051129,\n\t\t\t180,\n\t\t\t85.051129\n\t\t]\n\t},\n\tscheme: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\txyz: {\n\t\t\t},\n\t\t\ttms: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"xyz\"\n\t},\n\tminzoom: {\n\t\ttype: \"number\",\n\t\t\"default\": 0\n\t},\n\tmaxzoom: {\n\t\ttype: \"number\",\n\t\t\"default\": 22\n\t},\n\tattribution: {\n\t\ttype: \"string\"\n\t},\n\tpromoteId: {\n\t\ttype: \"promoteId\"\n\t},\n\tvolatile: {\n\t\ttype: \"boolean\",\n\t\t\"default\": false\n\t},\n\t\"*\": {\n\t\ttype: \"*\"\n\t}\n};\nvar source_raster = {\n\ttype: {\n\t\trequired: true,\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\traster: {\n\t\t\t}\n\t\t}\n\t},\n\turl: {\n\t\ttype: \"string\"\n\t},\n\ttiles: {\n\t\ttype: \"array\",\n\t\tvalue: \"string\"\n\t},\n\tbounds: {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 4,\n\t\t\"default\": [\n\t\t\t-180,\n\t\t\t-85.051129,\n\t\t\t180,\n\t\t\t85.051129\n\t\t]\n\t},\n\tminzoom: {\n\t\ttype: \"number\",\n\t\t\"default\": 0\n\t},\n\tmaxzoom: {\n\t\ttype: \"number\",\n\t\t\"default\": 22\n\t},\n\ttileSize: {\n\t\ttype: \"number\",\n\t\t\"default\": 512,\n\t\tunits: \"pixels\"\n\t},\n\tscheme: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\txyz: {\n\t\t\t},\n\t\t\ttms: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"xyz\"\n\t},\n\tattribution: {\n\t\ttype: \"string\"\n\t},\n\tvolatile: {\n\t\ttype: \"boolean\",\n\t\t\"default\": false\n\t},\n\t\"*\": {\n\t\ttype: \"*\"\n\t}\n};\nvar source_raster_dem = {\n\ttype: {\n\t\trequired: true,\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\t\"raster-dem\": {\n\t\t\t}\n\t\t}\n\t},\n\turl: {\n\t\ttype: \"string\"\n\t},\n\ttiles: {\n\t\ttype: \"array\",\n\t\tvalue: \"string\"\n\t},\n\tbounds: {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 4,\n\t\t\"default\": [\n\t\t\t-180,\n\t\t\t-85.051129,\n\t\t\t180,\n\t\t\t85.051129\n\t\t]\n\t},\n\tminzoom: {\n\t\ttype: \"number\",\n\t\t\"default\": 0\n\t},\n\tmaxzoom: {\n\t\ttype: \"number\",\n\t\t\"default\": 22\n\t},\n\ttileSize: {\n\t\ttype: \"number\",\n\t\t\"default\": 512,\n\t\tunits: \"pixels\"\n\t},\n\tattribution: {\n\t\ttype: \"string\"\n\t},\n\tencoding: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tterrarium: {\n\t\t\t},\n\t\t\tmapbox: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"mapbox\"\n\t},\n\tvolatile: {\n\t\ttype: \"boolean\",\n\t\t\"default\": false\n\t},\n\t\"*\": {\n\t\ttype: \"*\"\n\t}\n};\nvar source_geojson = {\n\ttype: {\n\t\trequired: true,\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tgeojson: {\n\t\t\t}\n\t\t}\n\t},\n\tdata: {\n\t\ttype: \"*\"\n\t},\n\tmaxzoom: {\n\t\ttype: \"number\",\n\t\t\"default\": 18\n\t},\n\tattribution: {\n\t\ttype: \"string\"\n\t},\n\tbuffer: {\n\t\ttype: \"number\",\n\t\t\"default\": 128,\n\t\tmaximum: 512,\n\t\tminimum: 0\n\t},\n\tfilter: {\n\t\ttype: \"*\"\n\t},\n\ttolerance: {\n\t\ttype: \"number\",\n\t\t\"default\": 0.375\n\t},\n\tcluster: {\n\t\ttype: \"boolean\",\n\t\t\"default\": false\n\t},\n\tclusterRadius: {\n\t\ttype: \"number\",\n\t\t\"default\": 50,\n\t\tminimum: 0\n\t},\n\tclusterMaxZoom: {\n\t\ttype: \"number\"\n\t},\n\tclusterMinPoints: {\n\t\ttype: \"number\"\n\t},\n\tclusterProperties: {\n\t\ttype: \"*\"\n\t},\n\tlineMetrics: {\n\t\ttype: \"boolean\",\n\t\t\"default\": false\n\t},\n\tgenerateId: {\n\t\ttype: \"boolean\",\n\t\t\"default\": false\n\t},\n\tpromoteId: {\n\t\ttype: \"promoteId\"\n\t}\n};\nvar source_video = {\n\ttype: {\n\t\trequired: true,\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvideo: {\n\t\t\t}\n\t\t}\n\t},\n\turls: {\n\t\trequired: true,\n\t\ttype: \"array\",\n\t\tvalue: \"string\"\n\t},\n\tcoordinates: {\n\t\trequired: true,\n\t\ttype: \"array\",\n\t\tlength: 4,\n\t\tvalue: {\n\t\t\ttype: \"array\",\n\t\t\tlength: 2,\n\t\t\tvalue: \"number\"\n\t\t}\n\t}\n};\nvar source_image = {\n\ttype: {\n\t\trequired: true,\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\timage: {\n\t\t\t}\n\t\t}\n\t},\n\turl: {\n\t\trequired: true,\n\t\ttype: \"string\"\n\t},\n\tcoordinates: {\n\t\trequired: true,\n\t\ttype: \"array\",\n\t\tlength: 4,\n\t\tvalue: {\n\t\t\ttype: \"array\",\n\t\t\tlength: 2,\n\t\t\tvalue: \"number\"\n\t\t}\n\t}\n};\nvar layer = {\n\tid: {\n\t\ttype: \"string\",\n\t\trequired: true\n\t},\n\ttype: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tfill: {\n\t\t\t},\n\t\t\tline: {\n\t\t\t},\n\t\t\tsymbol: {\n\t\t\t},\n\t\t\tcircle: {\n\t\t\t},\n\t\t\theatmap: {\n\t\t\t},\n\t\t\t\"fill-extrusion\": {\n\t\t\t},\n\t\t\traster: {\n\t\t\t},\n\t\t\thillshade: {\n\t\t\t},\n\t\t\tbackground: {\n\t\t\t}\n\t\t},\n\t\trequired: true\n\t},\n\tmetadata: {\n\t\ttype: \"*\"\n\t},\n\tsource: {\n\t\ttype: \"string\"\n\t},\n\t\"source-layer\": {\n\t\ttype: \"string\"\n\t},\n\tminzoom: {\n\t\ttype: \"number\",\n\t\tminimum: 0,\n\t\tmaximum: 24\n\t},\n\tmaxzoom: {\n\t\ttype: \"number\",\n\t\tminimum: 0,\n\t\tmaximum: 24\n\t},\n\tfilter: {\n\t\ttype: \"filter\"\n\t},\n\tlayout: {\n\t\ttype: \"layout\"\n\t},\n\tpaint: {\n\t\ttype: \"paint\"\n\t}\n};\nvar layout = [\n\t\"layout_fill\",\n\t\"layout_line\",\n\t\"layout_circle\",\n\t\"layout_heatmap\",\n\t\"layout_fill-extrusion\",\n\t\"layout_symbol\",\n\t\"layout_raster\",\n\t\"layout_hillshade\",\n\t\"layout_background\"\n];\nvar layout_background = {\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar layout_fill = {\n\t\"fill-sort-key\": {\n\t\ttype: \"number\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar layout_circle = {\n\t\"circle-sort-key\": {\n\t\ttype: \"number\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar layout_heatmap = {\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar layout_line = {\n\t\"line-cap\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tbutt: {\n\t\t\t},\n\t\t\tround: {\n\t\t\t},\n\t\t\tsquare: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"butt\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"line-join\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tbevel: {\n\t\t\t},\n\t\t\tround: {\n\t\t\t},\n\t\t\tmiter: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"miter\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"line-miter-limit\": {\n\t\ttype: \"number\",\n\t\t\"default\": 2,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"line-join\": \"miter\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"line-round-limit\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1.05,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"line-join\": \"round\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"line-sort-key\": {\n\t\ttype: \"number\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar layout_symbol = {\n\t\"symbol-placement\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tpoint: {\n\t\t\t},\n\t\t\tline: {\n\t\t\t},\n\t\t\t\"line-center\": {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"point\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"symbol-spacing\": {\n\t\ttype: \"number\",\n\t\t\"default\": 250,\n\t\tminimum: 1,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"symbol-placement\": \"line\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"symbol-avoid-edges\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"symbol-sort-key\": {\n\t\ttype: \"number\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"symbol-z-order\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tauto: {\n\t\t\t},\n\t\t\t\"viewport-y\": {\n\t\t\t},\n\t\t\tsource: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"auto\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-allow-overlap\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-ignore-placement\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-optional\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\trequires: [\n\t\t\t\"icon-image\",\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-rotation-alignment\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t},\n\t\t\tauto: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"auto\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-size\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tunits: \"factor of the original icon size\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-text-fit\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tnone: {\n\t\t\t},\n\t\t\twidth: {\n\t\t\t},\n\t\t\theight: {\n\t\t\t},\n\t\t\tboth: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"none\",\n\t\trequires: [\n\t\t\t\"icon-image\",\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-text-fit-padding\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 4,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0,\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"icon-image\",\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"icon-text-fit\": [\n\t\t\t\t\t\"both\",\n\t\t\t\t\t\"width\",\n\t\t\t\t\t\"height\"\n\t\t\t\t]\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-image\": {\n\t\ttype: \"resolvedImage\",\n\t\ttokens: true,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-rotate\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tperiod: 360,\n\t\tunits: \"degrees\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-padding\": {\n\t\ttype: \"number\",\n\t\t\"default\": 2,\n\t\tminimum: 0,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-keep-upright\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\trequires: [\n\t\t\t\"icon-image\",\n\t\t\t{\n\t\t\t\t\"icon-rotation-alignment\": \"map\"\n\t\t\t},\n\t\t\t{\n\t\t\t\t\"symbol-placement\": [\n\t\t\t\t\t\"line\",\n\t\t\t\t\t\"line-center\"\n\t\t\t\t]\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-offset\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tcenter: {\n\t\t\t},\n\t\t\tleft: {\n\t\t\t},\n\t\t\tright: {\n\t\t\t},\n\t\t\ttop: {\n\t\t\t},\n\t\t\tbottom: {\n\t\t\t},\n\t\t\t\"top-left\": {\n\t\t\t},\n\t\t\t\"top-right\": {\n\t\t\t},\n\t\t\t\"bottom-left\": {\n\t\t\t},\n\t\t\t\"bottom-right\": {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"center\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-pitch-alignment\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t},\n\t\t\tauto: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"auto\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-pitch-alignment\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t},\n\t\t\tauto: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"auto\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-rotation-alignment\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t},\n\t\t\tauto: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"auto\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-field\": {\n\t\ttype: \"formatted\",\n\t\t\"default\": \"\",\n\t\ttokens: true,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-font\": {\n\t\ttype: \"array\",\n\t\tvalue: \"string\",\n\t\t\"default\": [\n\t\t\t\"Open Sans Regular\",\n\t\t\t\"Arial Unicode MS Regular\"\n\t\t],\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-size\": {\n\t\ttype: \"number\",\n\t\t\"default\": 16,\n\t\tminimum: 0,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-max-width\": {\n\t\ttype: \"number\",\n\t\t\"default\": 10,\n\t\tminimum: 0,\n\t\tunits: \"ems\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-line-height\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1.2,\n\t\tunits: \"ems\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-letter-spacing\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tunits: \"ems\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-justify\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tauto: {\n\t\t\t},\n\t\t\tleft: {\n\t\t\t},\n\t\t\tcenter: {\n\t\t\t},\n\t\t\tright: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"center\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-radial-offset\": {\n\t\ttype: \"number\",\n\t\tunits: \"ems\",\n\t\t\"default\": 0,\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\t\"property-type\": \"data-driven\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t}\n\t},\n\t\"text-variable-anchor\": {\n\t\ttype: \"array\",\n\t\tvalue: \"enum\",\n\t\tvalues: {\n\t\t\tcenter: {\n\t\t\t},\n\t\t\tleft: {\n\t\t\t},\n\t\t\tright: {\n\t\t\t},\n\t\t\ttop: {\n\t\t\t},\n\t\t\tbottom: {\n\t\t\t},\n\t\t\t\"top-left\": {\n\t\t\t},\n\t\t\t\"top-right\": {\n\t\t\t},\n\t\t\t\"bottom-left\": {\n\t\t\t},\n\t\t\t\"bottom-right\": {\n\t\t\t}\n\t\t},\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"symbol-placement\": [\n\t\t\t\t\t\"point\"\n\t\t\t\t]\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tcenter: {\n\t\t\t},\n\t\t\tleft: {\n\t\t\t},\n\t\t\tright: {\n\t\t\t},\n\t\t\ttop: {\n\t\t\t},\n\t\t\tbottom: {\n\t\t\t},\n\t\t\t\"top-left\": {\n\t\t\t},\n\t\t\t\"top-right\": {\n\t\t\t},\n\t\t\t\"bottom-left\": {\n\t\t\t},\n\t\t\t\"bottom-right\": {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"center\",\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"!\": \"text-variable-anchor\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-max-angle\": {\n\t\ttype: \"number\",\n\t\t\"default\": 45,\n\t\tunits: \"degrees\",\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"symbol-placement\": [\n\t\t\t\t\t\"line\",\n\t\t\t\t\t\"line-center\"\n\t\t\t\t]\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-writing-mode\": {\n\t\ttype: \"array\",\n\t\tvalue: \"enum\",\n\t\tvalues: {\n\t\t\thorizontal: {\n\t\t\t},\n\t\t\tvertical: {\n\t\t\t}\n\t\t},\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"symbol-placement\": [\n\t\t\t\t\t\"point\"\n\t\t\t\t]\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-rotate\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tperiod: 360,\n\t\tunits: \"degrees\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-padding\": {\n\t\ttype: \"number\",\n\t\t\"default\": 2,\n\t\tminimum: 0,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-keep-upright\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": true,\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"text-rotation-alignment\": \"map\"\n\t\t\t},\n\t\t\t{\n\t\t\t\t\"symbol-placement\": [\n\t\t\t\t\t\"line\",\n\t\t\t\t\t\"line-center\"\n\t\t\t\t]\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-transform\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tnone: {\n\t\t\t},\n\t\t\tuppercase: {\n\t\t\t},\n\t\t\tlowercase: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"none\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-offset\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tunits: \"ems\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"!\": \"text-radial-offset\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-allow-overlap\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-ignore-placement\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-optional\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar layout_raster = {\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar layout_hillshade = {\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar filter = {\n\ttype: \"array\",\n\tvalue: \"*\"\n};\nvar filter_operator = {\n\ttype: \"enum\",\n\tvalues: {\n\t\t\"==\": {\n\t\t},\n\t\t\"!=\": {\n\t\t},\n\t\t\">\": {\n\t\t},\n\t\t\">=\": {\n\t\t},\n\t\t\"<\": {\n\t\t},\n\t\t\"<=\": {\n\t\t},\n\t\t\"in\": {\n\t\t},\n\t\t\"!in\": {\n\t\t},\n\t\tall: {\n\t\t},\n\t\tany: {\n\t\t},\n\t\tnone: {\n\t\t},\n\t\thas: {\n\t\t},\n\t\t\"!has\": {\n\t\t},\n\t\twithin: {\n\t\t}\n\t}\n};\nvar geometry_type = {\n\ttype: \"enum\",\n\tvalues: {\n\t\tPoint: {\n\t\t},\n\t\tLineString: {\n\t\t},\n\t\tPolygon: {\n\t\t}\n\t}\n};\nvar function_stop = {\n\ttype: \"array\",\n\tminimum: 0,\n\tmaximum: 24,\n\tvalue: [\n\t\t\"number\",\n\t\t\"color\"\n\t],\n\tlength: 2\n};\nvar expression = {\n\ttype: \"array\",\n\tvalue: \"*\",\n\tminimum: 1\n};\nvar light = {\n\tanchor: {\n\t\ttype: \"enum\",\n\t\t\"default\": \"viewport\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"property-type\": \"data-constant\",\n\t\ttransition: false,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t}\n\t},\n\tposition: {\n\t\ttype: \"array\",\n\t\t\"default\": [\n\t\t\t1.15,\n\t\t\t210,\n\t\t\t30\n\t\t],\n\t\tlength: 3,\n\t\tvalue: \"number\",\n\t\t\"property-type\": \"data-constant\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t}\n\t},\n\tcolor: {\n\t\ttype: \"color\",\n\t\t\"property-type\": \"data-constant\",\n\t\t\"default\": \"#ffffff\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\ttransition: true\n\t},\n\tintensity: {\n\t\ttype: \"number\",\n\t\t\"property-type\": \"data-constant\",\n\t\t\"default\": 0.5,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\ttransition: true\n\t}\n};\nvar paint = [\n\t\"paint_fill\",\n\t\"paint_line\",\n\t\"paint_circle\",\n\t\"paint_heatmap\",\n\t\"paint_fill-extrusion\",\n\t\"paint_symbol\",\n\t\"paint_raster\",\n\t\"paint_hillshade\",\n\t\"paint_background\"\n];\nvar paint_fill = {\n\t\"fill-antialias\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": true,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"fill-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"fill-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"!\": \"fill-pattern\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"fill-outline-color\": {\n\t\ttype: \"color\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"!\": \"fill-pattern\"\n\t\t\t},\n\t\t\t{\n\t\t\t\t\"fill-antialias\": true\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"fill-translate\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"fill-translate-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"map\",\n\t\trequires: [\n\t\t\t\"fill-translate\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"fill-pattern\": {\n\t\ttype: \"resolvedImage\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"cross-faded-data-driven\"\n\t}\n};\nvar paint_line = {\n\t\"line-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"line-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"!\": \"line-pattern\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"line-translate\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"line-translate-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"map\",\n\t\trequires: [\n\t\t\t\"line-translate\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"line-width\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"line-gap-width\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"line-offset\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"line-blur\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"line-dasharray\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"line widths\",\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"!\": \"line-pattern\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"cross-faded\"\n\t},\n\t\"line-pattern\": {\n\t\ttype: \"resolvedImage\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"cross-faded-data-driven\"\n\t},\n\t\"line-gradient\": {\n\t\ttype: \"color\",\n\t\ttransition: false,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"!\": \"line-dasharray\"\n\t\t\t},\n\t\t\t{\n\t\t\t\t\"!\": \"line-pattern\"\n\t\t\t},\n\t\t\t{\n\t\t\t\tsource: \"geojson\",\n\t\t\t\thas: {\n\t\t\t\t\tlineMetrics: true\n\t\t\t\t}\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"line-progress\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"color-ramp\"\n\t}\n};\nvar paint_circle = {\n\t\"circle-radius\": {\n\t\ttype: \"number\",\n\t\t\"default\": 5,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"circle-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"circle-blur\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"circle-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"circle-translate\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"circle-translate-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"map\",\n\t\trequires: [\n\t\t\t\"circle-translate\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"circle-pitch-scale\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"map\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"circle-pitch-alignment\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"viewport\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"circle-stroke-width\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"circle-stroke-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"circle-stroke-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t}\n};\nvar paint_heatmap = {\n\t\"heatmap-radius\": {\n\t\ttype: \"number\",\n\t\t\"default\": 30,\n\t\tminimum: 1,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"heatmap-weight\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\ttransition: false,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"heatmap-intensity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"heatmap-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": [\n\t\t\t\"interpolate\",\n\t\t\t[\n\t\t\t\t\"linear\"\n\t\t\t],\n\t\t\t[\n\t\t\t\t\"heatmap-density\"\n\t\t\t],\n\t\t\t0,\n\t\t\t\"rgba(0, 0, 255, 0)\",\n\t\t\t0.1,\n\t\t\t\"royalblue\",\n\t\t\t0.3,\n\t\t\t\"cyan\",\n\t\t\t0.5,\n\t\t\t\"lime\",\n\t\t\t0.7,\n\t\t\t\"yellow\",\n\t\t\t1,\n\t\t\t\"red\"\n\t\t],\n\t\ttransition: false,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"heatmap-density\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"color-ramp\"\n\t},\n\t\"heatmap-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t}\n};\nvar paint_symbol = {\n\t\"icon-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-halo-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"rgba(0, 0, 0, 0)\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-halo-width\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-halo-blur\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-translate\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-translate-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"map\",\n\t\trequires: [\n\t\t\t\"icon-image\",\n\t\t\t\"icon-translate\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\toverridable: true,\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-halo-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"rgba(0, 0, 0, 0)\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-halo-width\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-halo-blur\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-translate\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-translate-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"map\",\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t\"text-translate\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t}\n};\nvar paint_raster = {\n\t\"raster-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"raster-hue-rotate\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tperiod: 360,\n\t\ttransition: true,\n\t\tunits: \"degrees\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"raster-brightness-min\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"raster-brightness-max\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"raster-saturation\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: -1,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"raster-contrast\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: -1,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"raster-resampling\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tlinear: {\n\t\t\t},\n\t\t\tnearest: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"linear\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"raster-fade-duration\": {\n\t\ttype: \"number\",\n\t\t\"default\": 300,\n\t\tminimum: 0,\n\t\ttransition: false,\n\t\tunits: \"milliseconds\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t}\n};\nvar paint_hillshade = {\n\t\"hillshade-illumination-direction\": {\n\t\ttype: \"number\",\n\t\t\"default\": 335,\n\t\tminimum: 0,\n\t\tmaximum: 359,\n\t\ttransition: false,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"hillshade-illumination-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"viewport\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"hillshade-exaggeration\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0.5,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"hillshade-shadow-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"hillshade-highlight-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#FFFFFF\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"hillshade-accent-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t}\n};\nvar paint_background = {\n\t\"background-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"!\": \"background-pattern\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"background-pattern\": {\n\t\ttype: \"resolvedImage\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"cross-faded\"\n\t},\n\t\"background-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t}\n};\nvar transition = {\n\tduration: {\n\t\ttype: \"number\",\n\t\t\"default\": 300,\n\t\tminimum: 0,\n\t\tunits: \"milliseconds\"\n\t},\n\tdelay: {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\tunits: \"milliseconds\"\n\t}\n};\nvar promoteId = {\n\t\"*\": {\n\t\ttype: \"string\"\n\t}\n};\nvar spec = {\n\t$version: $version,\n\t$root: $root,\n\tsources: sources,\n\tsource: source,\n\tsource_vector: source_vector,\n\tsource_raster: source_raster,\n\tsource_raster_dem: source_raster_dem,\n\tsource_geojson: source_geojson,\n\tsource_video: source_video,\n\tsource_image: source_image,\n\tlayer: layer,\n\tlayout: layout,\n\tlayout_background: layout_background,\n\tlayout_fill: layout_fill,\n\tlayout_circle: layout_circle,\n\tlayout_heatmap: layout_heatmap,\n\t\"layout_fill-extrusion\": {\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n},\n\tlayout_line: layout_line,\n\tlayout_symbol: layout_symbol,\n\tlayout_raster: layout_raster,\n\tlayout_hillshade: layout_hillshade,\n\tfilter: filter,\n\tfilter_operator: filter_operator,\n\tgeometry_type: geometry_type,\n\t\"function\": {\n\texpression: {\n\t\ttype: \"expression\"\n\t},\n\tstops: {\n\t\ttype: \"array\",\n\t\tvalue: \"function_stop\"\n\t},\n\tbase: {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0\n\t},\n\tproperty: {\n\t\ttype: \"string\",\n\t\t\"default\": \"$zoom\"\n\t},\n\ttype: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tidentity: {\n\t\t\t},\n\t\t\texponential: {\n\t\t\t},\n\t\t\tinterval: {\n\t\t\t},\n\t\t\tcategorical: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"exponential\"\n\t},\n\tcolorSpace: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\trgb: {\n\t\t\t},\n\t\t\tlab: {\n\t\t\t},\n\t\t\thcl: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"rgb\"\n\t},\n\t\"default\": {\n\t\ttype: \"*\",\n\t\trequired: false\n\t}\n},\n\tfunction_stop: function_stop,\n\texpression: expression,\n\tlight: light,\n\tpaint: paint,\n\tpaint_fill: paint_fill,\n\t\"paint_fill-extrusion\": {\n\t\"fill-extrusion-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"fill-extrusion-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"!\": \"fill-extrusion-pattern\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"fill-extrusion-translate\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"fill-extrusion-translate-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"map\",\n\t\trequires: [\n\t\t\t\"fill-extrusion-translate\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"fill-extrusion-pattern\": {\n\t\ttype: \"resolvedImage\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"cross-faded-data-driven\"\n\t},\n\t\"fill-extrusion-height\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\tunits: \"meters\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"fill-extrusion-base\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\tunits: \"meters\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t\"fill-extrusion-height\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"fill-extrusion-vertical-gradient\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": true,\n\t\ttransition: false,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t}\n},\n\tpaint_line: paint_line,\n\tpaint_circle: paint_circle,\n\tpaint_heatmap: paint_heatmap,\n\tpaint_symbol: paint_symbol,\n\tpaint_raster: paint_raster,\n\tpaint_hillshade: paint_hillshade,\n\tpaint_background: paint_background,\n\ttransition: transition,\n\t\"property-type\": {\n\t\"data-driven\": {\n\t\ttype: \"property-type\"\n\t},\n\t\"cross-faded\": {\n\t\ttype: \"property-type\"\n\t},\n\t\"cross-faded-data-driven\": {\n\t\ttype: \"property-type\"\n\t},\n\t\"color-ramp\": {\n\t\ttype: \"property-type\"\n\t},\n\t\"data-constant\": {\n\t\ttype: \"property-type\"\n\t},\n\tconstant: {\n\t\ttype: \"property-type\"\n\t}\n},\n\tpromoteId: promoteId\n};\n\nvar ValidationError = function ValidationError(key, value, message, identifier) {\n this.message = (key ? key + ': ' : '') + message;\n if (identifier) {\n this.identifier = identifier;\n }\n if (value !== null && value !== undefined && value.__line__) {\n this.line = value.__line__;\n }\n};\n\nfunction validateConstants(options) {\n var key = options.key;\n var constants = options.value;\n if (constants) {\n return [new ValidationError(key, constants, 'constants have been deprecated as of v8')];\n } else {\n return [];\n }\n}\n\nfunction extend$1 (output) {\n var inputs = [], len = arguments.length - 1;\n while (len-- > 0)\n inputs[len] = arguments[len + 1];\n for (var i = 0, list = inputs; i < list.length; i += 1) {\n var input = list[i];\n for (var k in input) {\n output[k] = input[k];\n }\n }\n return output;\n}\n\nfunction unbundle(value) {\n if (value instanceof Number || value instanceof String || value instanceof Boolean) {\n return value.valueOf();\n } else {\n return value;\n }\n}\nfunction deepUnbundle(value) {\n if (Array.isArray(value)) {\n return value.map(deepUnbundle);\n } else if (value instanceof Object && !(value instanceof Number || value instanceof String || value instanceof Boolean)) {\n var unbundledValue = {};\n for (var key in value) {\n unbundledValue[key] = deepUnbundle(value[key]);\n }\n return unbundledValue;\n }\n return unbundle(value);\n}\n\nvar ParsingError = function (Error) {\n function ParsingError(key, message) {\n Error.call(this, message);\n this.message = message;\n this.key = key;\n }\n if (Error)\n ParsingError.__proto__ = Error;\n ParsingError.prototype = Object.create(Error && Error.prototype);\n ParsingError.prototype.constructor = ParsingError;\n return ParsingError;\n}(Error);\n\nvar Scope = function Scope(parent, bindings) {\n if (bindings === void 0)\n bindings = [];\n this.parent = parent;\n this.bindings = {};\n for (var i = 0, list = bindings; i < list.length; i += 1) {\n var ref = list[i];\n var name = ref[0];\n var expression = ref[1];\n this.bindings[name] = expression;\n }\n};\nScope.prototype.concat = function concat(bindings) {\n return new Scope(this, bindings);\n};\nScope.prototype.get = function get(name) {\n if (this.bindings[name]) {\n return this.bindings[name];\n }\n if (this.parent) {\n return this.parent.get(name);\n }\n throw new Error(name + ' not found in scope.');\n};\nScope.prototype.has = function has(name) {\n if (this.bindings[name]) {\n return true;\n }\n return this.parent ? this.parent.has(name) : false;\n};\n\nvar NullType = { kind: 'null' };\nvar NumberType = { kind: 'number' };\nvar StringType = { kind: 'string' };\nvar BooleanType = { kind: 'boolean' };\nvar ColorType = { kind: 'color' };\nvar ObjectType = { kind: 'object' };\nvar ValueType = { kind: 'value' };\nvar ErrorType = { kind: 'error' };\nvar CollatorType = { kind: 'collator' };\nvar FormattedType = { kind: 'formatted' };\nvar ResolvedImageType = { kind: 'resolvedImage' };\nfunction array(itemType, N) {\n return {\n kind: 'array',\n itemType: itemType,\n N: N\n };\n}\nfunction toString(type) {\n if (type.kind === 'array') {\n var itemType = toString(type.itemType);\n return typeof type.N === 'number' ? 'array<' + itemType + ', ' + type.N + '>' : type.itemType.kind === 'value' ? 'array' : 'array<' + itemType + '>';\n } else {\n return type.kind;\n }\n}\nvar valueMemberTypes = [\n NullType,\n NumberType,\n StringType,\n BooleanType,\n ColorType,\n FormattedType,\n ObjectType,\n array(ValueType),\n ResolvedImageType\n];\nfunction checkSubtype(expected, t) {\n if (t.kind === 'error') {\n return null;\n } else if (expected.kind === 'array') {\n if (t.kind === 'array' && (t.N === 0 && t.itemType.kind === 'value' || !checkSubtype(expected.itemType, t.itemType)) && (typeof expected.N !== 'number' || expected.N === t.N)) {\n return null;\n }\n } else if (expected.kind === t.kind) {\n return null;\n } else if (expected.kind === 'value') {\n for (var i = 0, list = valueMemberTypes; i < list.length; i += 1) {\n var memberType = list[i];\n if (!checkSubtype(memberType, t)) {\n return null;\n }\n }\n }\n return 'Expected ' + toString(expected) + ' but found ' + toString(t) + ' instead.';\n}\nfunction isValidType(provided, allowedTypes) {\n return allowedTypes.some(function (t) {\n return t.kind === provided.kind;\n });\n}\nfunction isValidNativeType(provided, allowedTypes) {\n return allowedTypes.some(function (t) {\n if (t === 'null') {\n return provided === null;\n } else if (t === 'array') {\n return Array.isArray(provided);\n } else if (t === 'object') {\n return provided && !Array.isArray(provided) && typeof provided === 'object';\n } else {\n return t === typeof provided;\n }\n });\n}\n\nvar csscolorparser = createCommonjsModule(function (module, exports) {\nvar kCSSColorTable = {\n 'transparent': [\n 0,\n 0,\n 0,\n 0\n ],\n 'aliceblue': [\n 240,\n 248,\n 255,\n 1\n ],\n 'antiquewhite': [\n 250,\n 235,\n 215,\n 1\n ],\n 'aqua': [\n 0,\n 255,\n 255,\n 1\n ],\n 'aquamarine': [\n 127,\n 255,\n 212,\n 1\n ],\n 'azure': [\n 240,\n 255,\n 255,\n 1\n ],\n 'beige': [\n 245,\n 245,\n 220,\n 1\n ],\n 'bisque': [\n 255,\n 228,\n 196,\n 1\n ],\n 'black': [\n 0,\n 0,\n 0,\n 1\n ],\n 'blanchedalmond': [\n 255,\n 235,\n 205,\n 1\n ],\n 'blue': [\n 0,\n 0,\n 255,\n 1\n ],\n 'blueviolet': [\n 138,\n 43,\n 226,\n 1\n ],\n 'brown': [\n 165,\n 42,\n 42,\n 1\n ],\n 'burlywood': [\n 222,\n 184,\n 135,\n 1\n ],\n 'cadetblue': [\n 95,\n 158,\n 160,\n 1\n ],\n 'chartreuse': [\n 127,\n 255,\n 0,\n 1\n ],\n 'chocolate': [\n 210,\n 105,\n 30,\n 1\n ],\n 'coral': [\n 255,\n 127,\n 80,\n 1\n ],\n 'cornflowerblue': [\n 100,\n 149,\n 237,\n 1\n ],\n 'cornsilk': [\n 255,\n 248,\n 220,\n 1\n ],\n 'crimson': [\n 220,\n 20,\n 60,\n 1\n ],\n 'cyan': [\n 0,\n 255,\n 255,\n 1\n ],\n 'darkblue': [\n 0,\n 0,\n 139,\n 1\n ],\n 'darkcyan': [\n 0,\n 139,\n 139,\n 1\n ],\n 'darkgoldenrod': [\n 184,\n 134,\n 11,\n 1\n ],\n 'darkgray': [\n 169,\n 169,\n 169,\n 1\n ],\n 'darkgreen': [\n 0,\n 100,\n 0,\n 1\n ],\n 'darkgrey': [\n 169,\n 169,\n 169,\n 1\n ],\n 'darkkhaki': [\n 189,\n 183,\n 107,\n 1\n ],\n 'darkmagenta': [\n 139,\n 0,\n 139,\n 1\n ],\n 'darkolivegreen': [\n 85,\n 107,\n 47,\n 1\n ],\n 'darkorange': [\n 255,\n 140,\n 0,\n 1\n ],\n 'darkorchid': [\n 153,\n 50,\n 204,\n 1\n ],\n 'darkred': [\n 139,\n 0,\n 0,\n 1\n ],\n 'darksalmon': [\n 233,\n 150,\n 122,\n 1\n ],\n 'darkseagreen': [\n 143,\n 188,\n 143,\n 1\n ],\n 'darkslateblue': [\n 72,\n 61,\n 139,\n 1\n ],\n 'darkslategray': [\n 47,\n 79,\n 79,\n 1\n ],\n 'darkslategrey': [\n 47,\n 79,\n 79,\n 1\n ],\n 'darkturquoise': [\n 0,\n 206,\n 209,\n 1\n ],\n 'darkviolet': [\n 148,\n 0,\n 211,\n 1\n ],\n 'deeppink': [\n 255,\n 20,\n 147,\n 1\n ],\n 'deepskyblue': [\n 0,\n 191,\n 255,\n 1\n ],\n 'dimgray': [\n 105,\n 105,\n 105,\n 1\n ],\n 'dimgrey': [\n 105,\n 105,\n 105,\n 1\n ],\n 'dodgerblue': [\n 30,\n 144,\n 255,\n 1\n ],\n 'firebrick': [\n 178,\n 34,\n 34,\n 1\n ],\n 'floralwhite': [\n 255,\n 250,\n 240,\n 1\n ],\n 'forestgreen': [\n 34,\n 139,\n 34,\n 1\n ],\n 'fuchsia': [\n 255,\n 0,\n 255,\n 1\n ],\n 'gainsboro': [\n 220,\n 220,\n 220,\n 1\n ],\n 'ghostwhite': [\n 248,\n 248,\n 255,\n 1\n ],\n 'gold': [\n 255,\n 215,\n 0,\n 1\n ],\n 'goldenrod': [\n 218,\n 165,\n 32,\n 1\n ],\n 'gray': [\n 128,\n 128,\n 128,\n 1\n ],\n 'green': [\n 0,\n 128,\n 0,\n 1\n ],\n 'greenyellow': [\n 173,\n 255,\n 47,\n 1\n ],\n 'grey': [\n 128,\n 128,\n 128,\n 1\n ],\n 'honeydew': [\n 240,\n 255,\n 240,\n 1\n ],\n 'hotpink': [\n 255,\n 105,\n 180,\n 1\n ],\n 'indianred': [\n 205,\n 92,\n 92,\n 1\n ],\n 'indigo': [\n 75,\n 0,\n 130,\n 1\n ],\n 'ivory': [\n 255,\n 255,\n 240,\n 1\n ],\n 'khaki': [\n 240,\n 230,\n 140,\n 1\n ],\n 'lavender': [\n 230,\n 230,\n 250,\n 1\n ],\n 'lavenderblush': [\n 255,\n 240,\n 245,\n 1\n ],\n 'lawngreen': [\n 124,\n 252,\n 0,\n 1\n ],\n 'lemonchiffon': [\n 255,\n 250,\n 205,\n 1\n ],\n 'lightblue': [\n 173,\n 216,\n 230,\n 1\n ],\n 'lightcoral': [\n 240,\n 128,\n 128,\n 1\n ],\n 'lightcyan': [\n 224,\n 255,\n 255,\n 1\n ],\n 'lightgoldenrodyellow': [\n 250,\n 250,\n 210,\n 1\n ],\n 'lightgray': [\n 211,\n 211,\n 211,\n 1\n ],\n 'lightgreen': [\n 144,\n 238,\n 144,\n 1\n ],\n 'lightgrey': [\n 211,\n 211,\n 211,\n 1\n ],\n 'lightpink': [\n 255,\n 182,\n 193,\n 1\n ],\n 'lightsalmon': [\n 255,\n 160,\n 122,\n 1\n ],\n 'lightseagreen': [\n 32,\n 178,\n 170,\n 1\n ],\n 'lightskyblue': [\n 135,\n 206,\n 250,\n 1\n ],\n 'lightslategray': [\n 119,\n 136,\n 153,\n 1\n ],\n 'lightslategrey': [\n 119,\n 136,\n 153,\n 1\n ],\n 'lightsteelblue': [\n 176,\n 196,\n 222,\n 1\n ],\n 'lightyellow': [\n 255,\n 255,\n 224,\n 1\n ],\n 'lime': [\n 0,\n 255,\n 0,\n 1\n ],\n 'limegreen': [\n 50,\n 205,\n 50,\n 1\n ],\n 'linen': [\n 250,\n 240,\n 230,\n 1\n ],\n 'magenta': [\n 255,\n 0,\n 255,\n 1\n ],\n 'maroon': [\n 128,\n 0,\n 0,\n 1\n ],\n 'mediumaquamarine': [\n 102,\n 205,\n 170,\n 1\n ],\n 'mediumblue': [\n 0,\n 0,\n 205,\n 1\n ],\n 'mediumorchid': [\n 186,\n 85,\n 211,\n 1\n ],\n 'mediumpurple': [\n 147,\n 112,\n 219,\n 1\n ],\n 'mediumseagreen': [\n 60,\n 179,\n 113,\n 1\n ],\n 'mediumslateblue': [\n 123,\n 104,\n 238,\n 1\n ],\n 'mediumspringgreen': [\n 0,\n 250,\n 154,\n 1\n ],\n 'mediumturquoise': [\n 72,\n 209,\n 204,\n 1\n ],\n 'mediumvioletred': [\n 199,\n 21,\n 133,\n 1\n ],\n 'midnightblue': [\n 25,\n 25,\n 112,\n 1\n ],\n 'mintcream': [\n 245,\n 255,\n 250,\n 1\n ],\n 'mistyrose': [\n 255,\n 228,\n 225,\n 1\n ],\n 'moccasin': [\n 255,\n 228,\n 181,\n 1\n ],\n 'navajowhite': [\n 255,\n 222,\n 173,\n 1\n ],\n 'navy': [\n 0,\n 0,\n 128,\n 1\n ],\n 'oldlace': [\n 253,\n 245,\n 230,\n 1\n ],\n 'olive': [\n 128,\n 128,\n 0,\n 1\n ],\n 'olivedrab': [\n 107,\n 142,\n 35,\n 1\n ],\n 'orange': [\n 255,\n 165,\n 0,\n 1\n ],\n 'orangered': [\n 255,\n 69,\n 0,\n 1\n ],\n 'orchid': [\n 218,\n 112,\n 214,\n 1\n ],\n 'palegoldenrod': [\n 238,\n 232,\n 170,\n 1\n ],\n 'palegreen': [\n 152,\n 251,\n 152,\n 1\n ],\n 'paleturquoise': [\n 175,\n 238,\n 238,\n 1\n ],\n 'palevioletred': [\n 219,\n 112,\n 147,\n 1\n ],\n 'papayawhip': [\n 255,\n 239,\n 213,\n 1\n ],\n 'peachpuff': [\n 255,\n 218,\n 185,\n 1\n ],\n 'peru': [\n 205,\n 133,\n 63,\n 1\n ],\n 'pink': [\n 255,\n 192,\n 203,\n 1\n ],\n 'plum': [\n 221,\n 160,\n 221,\n 1\n ],\n 'powderblue': [\n 176,\n 224,\n 230,\n 1\n ],\n 'purple': [\n 128,\n 0,\n 128,\n 1\n ],\n 'rebeccapurple': [\n 102,\n 51,\n 153,\n 1\n ],\n 'red': [\n 255,\n 0,\n 0,\n 1\n ],\n 'rosybrown': [\n 188,\n 143,\n 143,\n 1\n ],\n 'royalblue': [\n 65,\n 105,\n 225,\n 1\n ],\n 'saddlebrown': [\n 139,\n 69,\n 19,\n 1\n ],\n 'salmon': [\n 250,\n 128,\n 114,\n 1\n ],\n 'sandybrown': [\n 244,\n 164,\n 96,\n 1\n ],\n 'seagreen': [\n 46,\n 139,\n 87,\n 1\n ],\n 'seashell': [\n 255,\n 245,\n 238,\n 1\n ],\n 'sienna': [\n 160,\n 82,\n 45,\n 1\n ],\n 'silver': [\n 192,\n 192,\n 192,\n 1\n ],\n 'skyblue': [\n 135,\n 206,\n 235,\n 1\n ],\n 'slateblue': [\n 106,\n 90,\n 205,\n 1\n ],\n 'slategray': [\n 112,\n 128,\n 144,\n 1\n ],\n 'slategrey': [\n 112,\n 128,\n 144,\n 1\n ],\n 'snow': [\n 255,\n 250,\n 250,\n 1\n ],\n 'springgreen': [\n 0,\n 255,\n 127,\n 1\n ],\n 'steelblue': [\n 70,\n 130,\n 180,\n 1\n ],\n 'tan': [\n 210,\n 180,\n 140,\n 1\n ],\n 'teal': [\n 0,\n 128,\n 128,\n 1\n ],\n 'thistle': [\n 216,\n 191,\n 216,\n 1\n ],\n 'tomato': [\n 255,\n 99,\n 71,\n 1\n ],\n 'turquoise': [\n 64,\n 224,\n 208,\n 1\n ],\n 'violet': [\n 238,\n 130,\n 238,\n 1\n ],\n 'wheat': [\n 245,\n 222,\n 179,\n 1\n ],\n 'white': [\n 255,\n 255,\n 255,\n 1\n ],\n 'whitesmoke': [\n 245,\n 245,\n 245,\n 1\n ],\n 'yellow': [\n 255,\n 255,\n 0,\n 1\n ],\n 'yellowgreen': [\n 154,\n 205,\n 50,\n 1\n ]\n};\nfunction clamp_css_byte(i) {\n i = Math.round(i);\n return i < 0 ? 0 : i > 255 ? 255 : i;\n}\nfunction clamp_css_float(f) {\n return f < 0 ? 0 : f > 1 ? 1 : f;\n}\nfunction parse_css_int(str) {\n if (str[str.length - 1] === '%') {\n return clamp_css_byte(parseFloat(str) / 100 * 255);\n }\n return clamp_css_byte(parseInt(str));\n}\nfunction parse_css_float(str) {\n if (str[str.length - 1] === '%') {\n return clamp_css_float(parseFloat(str) / 100);\n }\n return clamp_css_float(parseFloat(str));\n}\nfunction css_hue_to_rgb(m1, m2, h) {\n if (h < 0) {\n h += 1;\n } else if (h > 1) {\n h -= 1;\n }\n if (h * 6 < 1) {\n return m1 + (m2 - m1) * h * 6;\n }\n if (h * 2 < 1) {\n return m2;\n }\n if (h * 3 < 2) {\n return m1 + (m2 - m1) * (2 / 3 - h) * 6;\n }\n return m1;\n}\nfunction parseCSSColor(css_str) {\n var str = css_str.replace(/ /g, '').toLowerCase();\n if (str in kCSSColorTable) {\n return kCSSColorTable[str].slice();\n }\n if (str[0] === '#') {\n if (str.length === 4) {\n var iv = parseInt(str.substr(1), 16);\n if (!(iv >= 0 && iv <= 4095)) {\n return null;\n }\n return [\n (iv & 3840) >> 4 | (iv & 3840) >> 8,\n iv & 240 | (iv & 240) >> 4,\n iv & 15 | (iv & 15) << 4,\n 1\n ];\n } else if (str.length === 7) {\n var iv = parseInt(str.substr(1), 16);\n if (!(iv >= 0 && iv <= 16777215)) {\n return null;\n }\n return [\n (iv & 16711680) >> 16,\n (iv & 65280) >> 8,\n iv & 255,\n 1\n ];\n }\n return null;\n }\n var op = str.indexOf('('), ep = str.indexOf(')');\n if (op !== -1 && ep + 1 === str.length) {\n var fname = str.substr(0, op);\n var params = str.substr(op + 1, ep - (op + 1)).split(',');\n var alpha = 1;\n switch (fname) {\n case 'rgba':\n if (params.length !== 4) {\n return null;\n }\n alpha = parse_css_float(params.pop());\n case 'rgb':\n if (params.length !== 3) {\n return null;\n }\n return [\n parse_css_int(params[0]),\n parse_css_int(params[1]),\n parse_css_int(params[2]),\n alpha\n ];\n case 'hsla':\n if (params.length !== 4) {\n return null;\n }\n alpha = parse_css_float(params.pop());\n case 'hsl':\n if (params.length !== 3) {\n return null;\n }\n var h = (parseFloat(params[0]) % 360 + 360) % 360 / 360;\n var s = parse_css_float(params[1]);\n var l = parse_css_float(params[2]);\n var m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n var m1 = l * 2 - m2;\n return [\n clamp_css_byte(css_hue_to_rgb(m1, m2, h + 1 / 3) * 255),\n clamp_css_byte(css_hue_to_rgb(m1, m2, h) * 255),\n clamp_css_byte(css_hue_to_rgb(m1, m2, h - 1 / 3) * 255),\n alpha\n ];\n default:\n return null;\n }\n }\n return null;\n}\ntry {\n exports.parseCSSColor = parseCSSColor;\n} catch (e) {\n}\n});\nvar csscolorparser_1 = csscolorparser.parseCSSColor;\n\nvar Color = function Color(r, g, b, a) {\n if (a === void 0)\n a = 1;\n this.r = r;\n this.g = g;\n this.b = b;\n this.a = a;\n};\nColor.parse = function parse(input) {\n if (!input) {\n return undefined;\n }\n if (input instanceof Color) {\n return input;\n }\n if (typeof input !== 'string') {\n return undefined;\n }\n var rgba = csscolorparser_1(input);\n if (!rgba) {\n return undefined;\n }\n return new Color(rgba[0] / 255 * rgba[3], rgba[1] / 255 * rgba[3], rgba[2] / 255 * rgba[3], rgba[3]);\n};\nColor.prototype.toString = function toString() {\n var ref = this.toArray();\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var a = ref[3];\n return 'rgba(' + Math.round(r) + ',' + Math.round(g) + ',' + Math.round(b) + ',' + a + ')';\n};\nColor.prototype.toArray = function toArray() {\n var ref = this;\n var r = ref.r;\n var g = ref.g;\n var b = ref.b;\n var a = ref.a;\n return a === 0 ? [\n 0,\n 0,\n 0,\n 0\n ] : [\n r * 255 / a,\n g * 255 / a,\n b * 255 / a,\n a\n ];\n};\nColor.black = new Color(0, 0, 0, 1);\nColor.white = new Color(1, 1, 1, 1);\nColor.transparent = new Color(0, 0, 0, 0);\nColor.red = new Color(1, 0, 0, 1);\n\nvar Collator = function Collator(caseSensitive, diacriticSensitive, locale) {\n if (caseSensitive) {\n this.sensitivity = diacriticSensitive ? 'variant' : 'case';\n } else {\n this.sensitivity = diacriticSensitive ? 'accent' : 'base';\n }\n this.locale = locale;\n this.collator = new Intl.Collator(this.locale ? this.locale : [], {\n sensitivity: this.sensitivity,\n usage: 'search'\n });\n};\nCollator.prototype.compare = function compare(lhs, rhs) {\n return this.collator.compare(lhs, rhs);\n};\nCollator.prototype.resolvedLocale = function resolvedLocale() {\n return new Intl.Collator(this.locale ? this.locale : []).resolvedOptions().locale;\n};\n\nvar FormattedSection = function FormattedSection(text, image, scale, fontStack, textColor) {\n this.text = text;\n this.image = image;\n this.scale = scale;\n this.fontStack = fontStack;\n this.textColor = textColor;\n};\nvar Formatted = function Formatted(sections) {\n this.sections = sections;\n};\nFormatted.fromString = function fromString(unformatted) {\n return new Formatted([new FormattedSection(unformatted, null, null, null, null)]);\n};\nFormatted.prototype.isEmpty = function isEmpty() {\n if (this.sections.length === 0) {\n return true;\n }\n return !this.sections.some(function (section) {\n return section.text.length !== 0 || section.image && section.image.name.length !== 0;\n });\n};\nFormatted.factory = function factory(text) {\n if (text instanceof Formatted) {\n return text;\n } else {\n return Formatted.fromString(text);\n }\n};\nFormatted.prototype.toString = function toString() {\n if (this.sections.length === 0) {\n return '';\n }\n return this.sections.map(function (section) {\n return section.text;\n }).join('');\n};\nFormatted.prototype.serialize = function serialize() {\n var serialized = ['format'];\n for (var i = 0, list = this.sections; i < list.length; i += 1) {\n var section = list[i];\n if (section.image) {\n serialized.push([\n 'image',\n section.image.name\n ]);\n continue;\n }\n serialized.push(section.text);\n var options = {};\n if (section.fontStack) {\n options['text-font'] = [\n 'literal',\n section.fontStack.split(',')\n ];\n }\n if (section.scale) {\n options['font-scale'] = section.scale;\n }\n if (section.textColor) {\n options['text-color'] = ['rgba'].concat(section.textColor.toArray());\n }\n serialized.push(options);\n }\n return serialized;\n};\n\nvar ResolvedImage = function ResolvedImage(options) {\n this.name = options.name;\n this.available = options.available;\n};\nResolvedImage.prototype.toString = function toString() {\n return this.name;\n};\nResolvedImage.fromString = function fromString(name) {\n if (!name) {\n return null;\n }\n return new ResolvedImage({\n name: name,\n available: false\n });\n};\nResolvedImage.prototype.serialize = function serialize() {\n return [\n 'image',\n this.name\n ];\n};\n\nfunction validateRGBA(r, g, b, a) {\n if (!(typeof r === 'number' && r >= 0 && r <= 255 && typeof g === 'number' && g >= 0 && g <= 255 && typeof b === 'number' && b >= 0 && b <= 255)) {\n var value = typeof a === 'number' ? [\n r,\n g,\n b,\n a\n ] : [\n r,\n g,\n b\n ];\n return 'Invalid rgba value [' + value.join(', ') + ']: \\'r\\', \\'g\\', and \\'b\\' must be between 0 and 255.';\n }\n if (!(typeof a === 'undefined' || typeof a === 'number' && a >= 0 && a <= 1)) {\n return 'Invalid rgba value [' + [\n r,\n g,\n b,\n a\n ].join(', ') + ']: \\'a\\' must be between 0 and 1.';\n }\n return null;\n}\nfunction isValue(mixed) {\n if (mixed === null) {\n return true;\n } else if (typeof mixed === 'string') {\n return true;\n } else if (typeof mixed === 'boolean') {\n return true;\n } else if (typeof mixed === 'number') {\n return true;\n } else if (mixed instanceof Color) {\n return true;\n } else if (mixed instanceof Collator) {\n return true;\n } else if (mixed instanceof Formatted) {\n return true;\n } else if (mixed instanceof ResolvedImage) {\n return true;\n } else if (Array.isArray(mixed)) {\n for (var i = 0, list = mixed; i < list.length; i += 1) {\n var item = list[i];\n if (!isValue(item)) {\n return false;\n }\n }\n return true;\n } else if (typeof mixed === 'object') {\n for (var key in mixed) {\n if (!isValue(mixed[key])) {\n return false;\n }\n }\n return true;\n } else {\n return false;\n }\n}\nfunction typeOf(value) {\n if (value === null) {\n return NullType;\n } else if (typeof value === 'string') {\n return StringType;\n } else if (typeof value === 'boolean') {\n return BooleanType;\n } else if (typeof value === 'number') {\n return NumberType;\n } else if (value instanceof Color) {\n return ColorType;\n } else if (value instanceof Collator) {\n return CollatorType;\n } else if (value instanceof Formatted) {\n return FormattedType;\n } else if (value instanceof ResolvedImage) {\n return ResolvedImageType;\n } else if (Array.isArray(value)) {\n var length = value.length;\n var itemType;\n for (var i = 0, list = value; i < list.length; i += 1) {\n var item = list[i];\n var t = typeOf(item);\n if (!itemType) {\n itemType = t;\n } else if (itemType === t) {\n continue;\n } else {\n itemType = ValueType;\n break;\n }\n }\n return array(itemType || ValueType, length);\n } else {\n return ObjectType;\n }\n}\nfunction toString$1(value) {\n var type = typeof value;\n if (value === null) {\n return '';\n } else if (type === 'string' || type === 'number' || type === 'boolean') {\n return String(value);\n } else if (value instanceof Color || value instanceof Formatted || value instanceof ResolvedImage) {\n return value.toString();\n } else {\n return JSON.stringify(value);\n }\n}\n\nvar Literal = function Literal(type, value) {\n this.type = type;\n this.value = value;\n};\nLiteral.parse = function parse(args, context) {\n if (args.length !== 2) {\n return context.error('\\'literal\\' expression requires exactly one argument, but found ' + (args.length - 1) + ' instead.');\n }\n if (!isValue(args[1])) {\n return context.error('invalid value');\n }\n var value = args[1];\n var type = typeOf(value);\n var expected = context.expectedType;\n if (type.kind === 'array' && type.N === 0 && expected && expected.kind === 'array' && (typeof expected.N !== 'number' || expected.N === 0)) {\n type = expected;\n }\n return new Literal(type, value);\n};\nLiteral.prototype.evaluate = function evaluate() {\n return this.value;\n};\nLiteral.prototype.eachChild = function eachChild() {\n};\nLiteral.prototype.outputDefined = function outputDefined() {\n return true;\n};\nLiteral.prototype.serialize = function serialize() {\n if (this.type.kind === 'array' || this.type.kind === 'object') {\n return [\n 'literal',\n this.value\n ];\n } else if (this.value instanceof Color) {\n return ['rgba'].concat(this.value.toArray());\n } else if (this.value instanceof Formatted) {\n return this.value.serialize();\n } else {\n return this.value;\n }\n};\n\nvar RuntimeError = function RuntimeError(message) {\n this.name = 'ExpressionEvaluationError';\n this.message = message;\n};\nRuntimeError.prototype.toJSON = function toJSON() {\n return this.message;\n};\n\nvar types = {\n string: StringType,\n number: NumberType,\n boolean: BooleanType,\n object: ObjectType\n};\nvar Assertion = function Assertion(type, args) {\n this.type = type;\n this.args = args;\n};\nAssertion.parse = function parse(args, context) {\n if (args.length < 2) {\n return context.error('Expected at least one argument.');\n }\n var i = 1;\n var type;\n var name = args[0];\n if (name === 'array') {\n var itemType;\n if (args.length > 2) {\n var type$1 = args[1];\n if (typeof type$1 !== 'string' || !(type$1 in types) || type$1 === 'object') {\n return context.error('The item type argument of \"array\" must be one of string, number, boolean', 1);\n }\n itemType = types[type$1];\n i++;\n } else {\n itemType = ValueType;\n }\n var N;\n if (args.length > 3) {\n if (args[2] !== null && (typeof args[2] !== 'number' || args[2] < 0 || args[2] !== Math.floor(args[2]))) {\n return context.error('The length argument to \"array\" must be a positive integer literal', 2);\n }\n N = args[2];\n i++;\n }\n type = array(itemType, N);\n } else {\n type = types[name];\n }\n var parsed = [];\n for (; i < args.length; i++) {\n var input = context.parse(args[i], i, ValueType);\n if (!input) {\n return null;\n }\n parsed.push(input);\n }\n return new Assertion(type, parsed);\n};\nAssertion.prototype.evaluate = function evaluate(ctx) {\n for (var i = 0; i < this.args.length; i++) {\n var value = this.args[i].evaluate(ctx);\n var error = checkSubtype(this.type, typeOf(value));\n if (!error) {\n return value;\n } else if (i === this.args.length - 1) {\n throw new RuntimeError('Expected value to be of type ' + toString(this.type) + ', but found ' + toString(typeOf(value)) + ' instead.');\n }\n }\n return null;\n};\nAssertion.prototype.eachChild = function eachChild(fn) {\n this.args.forEach(fn);\n};\nAssertion.prototype.outputDefined = function outputDefined() {\n return this.args.every(function (arg) {\n return arg.outputDefined();\n });\n};\nAssertion.prototype.serialize = function serialize() {\n var type = this.type;\n var serialized = [type.kind];\n if (type.kind === 'array') {\n var itemType = type.itemType;\n if (itemType.kind === 'string' || itemType.kind === 'number' || itemType.kind === 'boolean') {\n serialized.push(itemType.kind);\n var N = type.N;\n if (typeof N === 'number' || this.args.length > 1) {\n serialized.push(N);\n }\n }\n }\n return serialized.concat(this.args.map(function (arg) {\n return arg.serialize();\n }));\n};\n\nvar FormatExpression = function FormatExpression(sections) {\n this.type = FormattedType;\n this.sections = sections;\n};\nFormatExpression.parse = function parse(args, context) {\n if (args.length < 2) {\n return context.error('Expected at least one argument.');\n }\n var firstArg = args[1];\n if (!Array.isArray(firstArg) && typeof firstArg === 'object') {\n return context.error('First argument must be an image or text section.');\n }\n var sections = [];\n var nextTokenMayBeObject = false;\n for (var i = 1; i <= args.length - 1; ++i) {\n var arg = args[i];\n if (nextTokenMayBeObject && typeof arg === 'object' && !Array.isArray(arg)) {\n nextTokenMayBeObject = false;\n var scale = null;\n if (arg['font-scale']) {\n scale = context.parse(arg['font-scale'], 1, NumberType);\n if (!scale) {\n return null;\n }\n }\n var font = null;\n if (arg['text-font']) {\n font = context.parse(arg['text-font'], 1, array(StringType));\n if (!font) {\n return null;\n }\n }\n var textColor = null;\n if (arg['text-color']) {\n textColor = context.parse(arg['text-color'], 1, ColorType);\n if (!textColor) {\n return null;\n }\n }\n var lastExpression = sections[sections.length - 1];\n lastExpression.scale = scale;\n lastExpression.font = font;\n lastExpression.textColor = textColor;\n } else {\n var content = context.parse(args[i], 1, ValueType);\n if (!content) {\n return null;\n }\n var kind = content.type.kind;\n if (kind !== 'string' && kind !== 'value' && kind !== 'null' && kind !== 'resolvedImage') {\n return context.error('Formatted text type must be \\'string\\', \\'value\\', \\'image\\' or \\'null\\'.');\n }\n nextTokenMayBeObject = true;\n sections.push({\n content: content,\n scale: null,\n font: null,\n textColor: null\n });\n }\n }\n return new FormatExpression(sections);\n};\nFormatExpression.prototype.evaluate = function evaluate(ctx) {\n var evaluateSection = function (section) {\n var evaluatedContent = section.content.evaluate(ctx);\n if (typeOf(evaluatedContent) === ResolvedImageType) {\n return new FormattedSection('', evaluatedContent, null, null, null);\n }\n return new FormattedSection(toString$1(evaluatedContent), null, section.scale ? section.scale.evaluate(ctx) : null, section.font ? section.font.evaluate(ctx).join(',') : null, section.textColor ? section.textColor.evaluate(ctx) : null);\n };\n return new Formatted(this.sections.map(evaluateSection));\n};\nFormatExpression.prototype.eachChild = function eachChild(fn) {\n for (var i = 0, list = this.sections; i < list.length; i += 1) {\n var section = list[i];\n fn(section.content);\n if (section.scale) {\n fn(section.scale);\n }\n if (section.font) {\n fn(section.font);\n }\n if (section.textColor) {\n fn(section.textColor);\n }\n }\n};\nFormatExpression.prototype.outputDefined = function outputDefined() {\n return false;\n};\nFormatExpression.prototype.serialize = function serialize() {\n var serialized = ['format'];\n for (var i = 0, list = this.sections; i < list.length; i += 1) {\n var section = list[i];\n serialized.push(section.content.serialize());\n var options = {};\n if (section.scale) {\n options['font-scale'] = section.scale.serialize();\n }\n if (section.font) {\n options['text-font'] = section.font.serialize();\n }\n if (section.textColor) {\n options['text-color'] = section.textColor.serialize();\n }\n serialized.push(options);\n }\n return serialized;\n};\n\nvar ImageExpression = function ImageExpression(input) {\n this.type = ResolvedImageType;\n this.input = input;\n};\nImageExpression.parse = function parse(args, context) {\n if (args.length !== 2) {\n return context.error('Expected two arguments.');\n }\n var name = context.parse(args[1], 1, StringType);\n if (!name) {\n return context.error('No image name provided.');\n }\n return new ImageExpression(name);\n};\nImageExpression.prototype.evaluate = function evaluate(ctx) {\n var evaluatedImageName = this.input.evaluate(ctx);\n var value = ResolvedImage.fromString(evaluatedImageName);\n if (value && ctx.availableImages) {\n value.available = ctx.availableImages.indexOf(evaluatedImageName) > -1;\n }\n return value;\n};\nImageExpression.prototype.eachChild = function eachChild(fn) {\n fn(this.input);\n};\nImageExpression.prototype.outputDefined = function outputDefined() {\n return false;\n};\nImageExpression.prototype.serialize = function serialize() {\n return [\n 'image',\n this.input.serialize()\n ];\n};\n\nvar types$1 = {\n 'to-boolean': BooleanType,\n 'to-color': ColorType,\n 'to-number': NumberType,\n 'to-string': StringType\n};\nvar Coercion = function Coercion(type, args) {\n this.type = type;\n this.args = args;\n};\nCoercion.parse = function parse(args, context) {\n if (args.length < 2) {\n return context.error('Expected at least one argument.');\n }\n var name = args[0];\n if ((name === 'to-boolean' || name === 'to-string') && args.length !== 2) {\n return context.error('Expected one argument.');\n }\n var type = types$1[name];\n var parsed = [];\n for (var i = 1; i < args.length; i++) {\n var input = context.parse(args[i], i, ValueType);\n if (!input) {\n return null;\n }\n parsed.push(input);\n }\n return new Coercion(type, parsed);\n};\nCoercion.prototype.evaluate = function evaluate(ctx) {\n if (this.type.kind === 'boolean') {\n return Boolean(this.args[0].evaluate(ctx));\n } else if (this.type.kind === 'color') {\n var input;\n var error;\n for (var i = 0, list = this.args; i < list.length; i += 1) {\n var arg = list[i];\n input = arg.evaluate(ctx);\n error = null;\n if (input instanceof Color) {\n return input;\n } else if (typeof input === 'string') {\n var c = ctx.parseColor(input);\n if (c) {\n return c;\n }\n } else if (Array.isArray(input)) {\n if (input.length < 3 || input.length > 4) {\n error = 'Invalid rbga value ' + JSON.stringify(input) + ': expected an array containing either three or four numeric values.';\n } else {\n error = validateRGBA(input[0], input[1], input[2], input[3]);\n }\n if (!error) {\n return new Color(input[0] / 255, input[1] / 255, input[2] / 255, input[3]);\n }\n }\n }\n throw new RuntimeError(error || 'Could not parse color from value \\'' + (typeof input === 'string' ? input : String(JSON.stringify(input))) + '\\'');\n } else if (this.type.kind === 'number') {\n var value = null;\n for (var i$1 = 0, list$1 = this.args; i$1 < list$1.length; i$1 += 1) {\n var arg$1 = list$1[i$1];\n value = arg$1.evaluate(ctx);\n if (value === null) {\n return 0;\n }\n var num = Number(value);\n if (isNaN(num)) {\n continue;\n }\n return num;\n }\n throw new RuntimeError('Could not convert ' + JSON.stringify(value) + ' to number.');\n } else if (this.type.kind === 'formatted') {\n return Formatted.fromString(toString$1(this.args[0].evaluate(ctx)));\n } else if (this.type.kind === 'resolvedImage') {\n return ResolvedImage.fromString(toString$1(this.args[0].evaluate(ctx)));\n } else {\n return toString$1(this.args[0].evaluate(ctx));\n }\n};\nCoercion.prototype.eachChild = function eachChild(fn) {\n this.args.forEach(fn);\n};\nCoercion.prototype.outputDefined = function outputDefined() {\n return this.args.every(function (arg) {\n return arg.outputDefined();\n });\n};\nCoercion.prototype.serialize = function serialize() {\n if (this.type.kind === 'formatted') {\n return new FormatExpression([{\n content: this.args[0],\n scale: null,\n font: null,\n textColor: null\n }]).serialize();\n }\n if (this.type.kind === 'resolvedImage') {\n return new ImageExpression(this.args[0]).serialize();\n }\n var serialized = ['to-' + this.type.kind];\n this.eachChild(function (child) {\n serialized.push(child.serialize());\n });\n return serialized;\n};\n\nvar geometryTypes = [\n 'Unknown',\n 'Point',\n 'LineString',\n 'Polygon'\n];\nvar EvaluationContext = function EvaluationContext() {\n this.globals = null;\n this.feature = null;\n this.featureState = null;\n this.formattedSection = null;\n this._parseColorCache = {};\n this.availableImages = null;\n this.canonical = null;\n};\nEvaluationContext.prototype.id = function id() {\n return this.feature && 'id' in this.feature ? this.feature.id : null;\n};\nEvaluationContext.prototype.geometryType = function geometryType() {\n return this.feature ? typeof this.feature.type === 'number' ? geometryTypes[this.feature.type] : this.feature.type : null;\n};\nEvaluationContext.prototype.geometry = function geometry() {\n return this.feature && 'geometry' in this.feature ? this.feature.geometry : null;\n};\nEvaluationContext.prototype.canonicalID = function canonicalID() {\n return this.canonical;\n};\nEvaluationContext.prototype.properties = function properties() {\n return this.feature && this.feature.properties || {};\n};\nEvaluationContext.prototype.parseColor = function parseColor(input) {\n var cached = this._parseColorCache[input];\n if (!cached) {\n cached = this._parseColorCache[input] = Color.parse(input);\n }\n return cached;\n};\n\nvar CompoundExpression = function CompoundExpression(name, type, evaluate, args) {\n this.name = name;\n this.type = type;\n this._evaluate = evaluate;\n this.args = args;\n};\nCompoundExpression.prototype.evaluate = function evaluate(ctx) {\n return this._evaluate(ctx, this.args);\n};\nCompoundExpression.prototype.eachChild = function eachChild(fn) {\n this.args.forEach(fn);\n};\nCompoundExpression.prototype.outputDefined = function outputDefined() {\n return false;\n};\nCompoundExpression.prototype.serialize = function serialize() {\n return [this.name].concat(this.args.map(function (arg) {\n return arg.serialize();\n }));\n};\nCompoundExpression.parse = function parse(args, context) {\n var ref$1;\n var op = args[0];\n var definition = CompoundExpression.definitions[op];\n if (!definition) {\n return context.error('Unknown expression \"' + op + '\". If you wanted a literal array, use [\"literal\", [...]].', 0);\n }\n var type = Array.isArray(definition) ? definition[0] : definition.type;\n var availableOverloads = Array.isArray(definition) ? [[\n definition[1],\n definition[2]\n ]] : definition.overloads;\n var overloads = availableOverloads.filter(function (ref) {\n var signature = ref[0];\n return !Array.isArray(signature) || signature.length === args.length - 1;\n });\n var signatureContext = null;\n for (var i$3 = 0, list = overloads; i$3 < list.length; i$3 += 1) {\n var ref = list[i$3];\n var params = ref[0];\n var evaluate = ref[1];\n signatureContext = new ParsingContext(context.registry, context.path, null, context.scope);\n var parsedArgs = [];\n var argParseFailed = false;\n for (var i = 1; i < args.length; i++) {\n var arg = args[i];\n var expectedType = Array.isArray(params) ? params[i - 1] : params.type;\n var parsed = signatureContext.parse(arg, 1 + parsedArgs.length, expectedType);\n if (!parsed) {\n argParseFailed = true;\n break;\n }\n parsedArgs.push(parsed);\n }\n if (argParseFailed) {\n continue;\n }\n if (Array.isArray(params)) {\n if (params.length !== parsedArgs.length) {\n signatureContext.error('Expected ' + params.length + ' arguments, but found ' + parsedArgs.length + ' instead.');\n continue;\n }\n }\n for (var i$1 = 0; i$1 < parsedArgs.length; i$1++) {\n var expected = Array.isArray(params) ? params[i$1] : params.type;\n var arg$1 = parsedArgs[i$1];\n signatureContext.concat(i$1 + 1).checkSubtype(expected, arg$1.type);\n }\n if (signatureContext.errors.length === 0) {\n return new CompoundExpression(op, type, evaluate, parsedArgs);\n }\n }\n if (overloads.length === 1) {\n (ref$1 = context.errors).push.apply(ref$1, signatureContext.errors);\n } else {\n var expected$1 = overloads.length ? overloads : availableOverloads;\n var signatures = expected$1.map(function (ref) {\n var params = ref[0];\n return stringifySignature(params);\n }).join(' | ');\n var actualTypes = [];\n for (var i$2 = 1; i$2 < args.length; i$2++) {\n var parsed$1 = context.parse(args[i$2], 1 + actualTypes.length);\n if (!parsed$1) {\n return null;\n }\n actualTypes.push(toString(parsed$1.type));\n }\n context.error('Expected arguments of type ' + signatures + ', but found (' + actualTypes.join(', ') + ') instead.');\n }\n return null;\n};\nCompoundExpression.register = function register(registry, definitions) {\n CompoundExpression.definitions = definitions;\n for (var name in definitions) {\n registry[name] = CompoundExpression;\n }\n};\nfunction stringifySignature(signature) {\n if (Array.isArray(signature)) {\n return '(' + signature.map(toString).join(', ') + ')';\n } else {\n return '(' + toString(signature.type) + '...)';\n }\n}\n\nvar CollatorExpression = function CollatorExpression(caseSensitive, diacriticSensitive, locale) {\n this.type = CollatorType;\n this.locale = locale;\n this.caseSensitive = caseSensitive;\n this.diacriticSensitive = diacriticSensitive;\n};\nCollatorExpression.parse = function parse(args, context) {\n if (args.length !== 2) {\n return context.error('Expected one argument.');\n }\n var options = args[1];\n if (typeof options !== 'object' || Array.isArray(options)) {\n return context.error('Collator options argument must be an object.');\n }\n var caseSensitive = context.parse(options['case-sensitive'] === undefined ? false : options['case-sensitive'], 1, BooleanType);\n if (!caseSensitive) {\n return null;\n }\n var diacriticSensitive = context.parse(options['diacritic-sensitive'] === undefined ? false : options['diacritic-sensitive'], 1, BooleanType);\n if (!diacriticSensitive) {\n return null;\n }\n var locale = null;\n if (options['locale']) {\n locale = context.parse(options['locale'], 1, StringType);\n if (!locale) {\n return null;\n }\n }\n return new CollatorExpression(caseSensitive, diacriticSensitive, locale);\n};\nCollatorExpression.prototype.evaluate = function evaluate(ctx) {\n return new Collator(this.caseSensitive.evaluate(ctx), this.diacriticSensitive.evaluate(ctx), this.locale ? this.locale.evaluate(ctx) : null);\n};\nCollatorExpression.prototype.eachChild = function eachChild(fn) {\n fn(this.caseSensitive);\n fn(this.diacriticSensitive);\n if (this.locale) {\n fn(this.locale);\n }\n};\nCollatorExpression.prototype.outputDefined = function outputDefined() {\n return false;\n};\nCollatorExpression.prototype.serialize = function serialize() {\n var options = {};\n options['case-sensitive'] = this.caseSensitive.serialize();\n options['diacritic-sensitive'] = this.diacriticSensitive.serialize();\n if (this.locale) {\n options['locale'] = this.locale.serialize();\n }\n return [\n 'collator',\n options\n ];\n};\n\nvar EXTENT = 8192;\nfunction updateBBox(bbox, coord) {\n bbox[0] = Math.min(bbox[0], coord[0]);\n bbox[1] = Math.min(bbox[1], coord[1]);\n bbox[2] = Math.max(bbox[2], coord[0]);\n bbox[3] = Math.max(bbox[3], coord[1]);\n}\nfunction mercatorXfromLng(lng) {\n return (180 + lng) / 360;\n}\nfunction mercatorYfromLat(lat) {\n return (180 - 180 / Math.PI * Math.log(Math.tan(Math.PI / 4 + lat * Math.PI / 360))) / 360;\n}\nfunction boxWithinBox(bbox1, bbox2) {\n if (bbox1[0] <= bbox2[0]) {\n return false;\n }\n if (bbox1[2] >= bbox2[2]) {\n return false;\n }\n if (bbox1[1] <= bbox2[1]) {\n return false;\n }\n if (bbox1[3] >= bbox2[3]) {\n return false;\n }\n return true;\n}\nfunction getTileCoordinates(p, canonical) {\n var x = mercatorXfromLng(p[0]);\n var y = mercatorYfromLat(p[1]);\n var tilesAtZoom = Math.pow(2, canonical.z);\n return [\n Math.round(x * tilesAtZoom * EXTENT),\n Math.round(y * tilesAtZoom * EXTENT)\n ];\n}\nfunction onBoundary(p, p1, p2) {\n var x1 = p[0] - p1[0];\n var y1 = p[1] - p1[1];\n var x2 = p[0] - p2[0];\n var y2 = p[1] - p2[1];\n return x1 * y2 - x2 * y1 === 0 && x1 * x2 <= 0 && y1 * y2 <= 0;\n}\nfunction rayIntersect(p, p1, p2) {\n return p1[1] > p[1] !== p2[1] > p[1] && p[0] < (p2[0] - p1[0]) * (p[1] - p1[1]) / (p2[1] - p1[1]) + p1[0];\n}\nfunction pointWithinPolygon(point, rings) {\n var inside = false;\n for (var i = 0, len = rings.length; i < len; i++) {\n var ring = rings[i];\n for (var j = 0, len2 = ring.length; j < len2 - 1; j++) {\n if (onBoundary(point, ring[j], ring[j + 1])) {\n return false;\n }\n if (rayIntersect(point, ring[j], ring[j + 1])) {\n inside = !inside;\n }\n }\n }\n return inside;\n}\nfunction pointWithinPolygons(point, polygons) {\n for (var i = 0; i < polygons.length; i++) {\n if (pointWithinPolygon(point, polygons[i])) {\n return true;\n }\n }\n return false;\n}\nfunction perp(v1, v2) {\n return v1[0] * v2[1] - v1[1] * v2[0];\n}\nfunction twoSided(p1, p2, q1, q2) {\n var x1 = p1[0] - q1[0];\n var y1 = p1[1] - q1[1];\n var x2 = p2[0] - q1[0];\n var y2 = p2[1] - q1[1];\n var x3 = q2[0] - q1[0];\n var y3 = q2[1] - q1[1];\n var det1 = x1 * y3 - x3 * y1;\n var det2 = x2 * y3 - x3 * y2;\n if (det1 > 0 && det2 < 0 || det1 < 0 && det2 > 0) {\n return true;\n }\n return false;\n}\nfunction lineIntersectLine(a, b, c, d) {\n var vectorP = [\n b[0] - a[0],\n b[1] - a[1]\n ];\n var vectorQ = [\n d[0] - c[0],\n d[1] - c[1]\n ];\n if (perp(vectorQ, vectorP) === 0) {\n return false;\n }\n if (twoSided(a, b, c, d) && twoSided(c, d, a, b)) {\n return true;\n }\n return false;\n}\nfunction lineIntersectPolygon(p1, p2, polygon) {\n for (var i = 0, list = polygon; i < list.length; i += 1) {\n var ring = list[i];\n for (var j = 0; j < ring.length - 1; ++j) {\n if (lineIntersectLine(p1, p2, ring[j], ring[j + 1])) {\n return true;\n }\n }\n }\n return false;\n}\nfunction lineStringWithinPolygon(line, polygon) {\n for (var i = 0; i < line.length; ++i) {\n if (!pointWithinPolygon(line[i], polygon)) {\n return false;\n }\n }\n for (var i$1 = 0; i$1 < line.length - 1; ++i$1) {\n if (lineIntersectPolygon(line[i$1], line[i$1 + 1], polygon)) {\n return false;\n }\n }\n return true;\n}\nfunction lineStringWithinPolygons(line, polygons) {\n for (var i = 0; i < polygons.length; i++) {\n if (lineStringWithinPolygon(line, polygons[i])) {\n return true;\n }\n }\n return false;\n}\nfunction getTilePolygon(coordinates, bbox, canonical) {\n var polygon = [];\n for (var i = 0; i < coordinates.length; i++) {\n var ring = [];\n for (var j = 0; j < coordinates[i].length; j++) {\n var coord = getTileCoordinates(coordinates[i][j], canonical);\n updateBBox(bbox, coord);\n ring.push(coord);\n }\n polygon.push(ring);\n }\n return polygon;\n}\nfunction getTilePolygons(coordinates, bbox, canonical) {\n var polygons = [];\n for (var i = 0; i < coordinates.length; i++) {\n var polygon = getTilePolygon(coordinates[i], bbox, canonical);\n polygons.push(polygon);\n }\n return polygons;\n}\nfunction updatePoint(p, bbox, polyBBox, worldSize) {\n if (p[0] < polyBBox[0] || p[0] > polyBBox[2]) {\n var halfWorldSize = worldSize * 0.5;\n var shift = p[0] - polyBBox[0] > halfWorldSize ? -worldSize : polyBBox[0] - p[0] > halfWorldSize ? worldSize : 0;\n if (shift === 0) {\n shift = p[0] - polyBBox[2] > halfWorldSize ? -worldSize : polyBBox[2] - p[0] > halfWorldSize ? worldSize : 0;\n }\n p[0] += shift;\n }\n updateBBox(bbox, p);\n}\nfunction resetBBox(bbox) {\n bbox[0] = bbox[1] = Infinity;\n bbox[2] = bbox[3] = -Infinity;\n}\nfunction getTilePoints(geometry, pointBBox, polyBBox, canonical) {\n var worldSize = Math.pow(2, canonical.z) * EXTENT;\n var shifts = [\n canonical.x * EXTENT,\n canonical.y * EXTENT\n ];\n var tilePoints = [];\n for (var i$1 = 0, list$1 = geometry; i$1 < list$1.length; i$1 += 1) {\n var points = list$1[i$1];\n for (var i = 0, list = points; i < list.length; i += 1) {\n var point = list[i];\n var p = [\n point.x + shifts[0],\n point.y + shifts[1]\n ];\n updatePoint(p, pointBBox, polyBBox, worldSize);\n tilePoints.push(p);\n }\n }\n return tilePoints;\n}\nfunction getTileLines(geometry, lineBBox, polyBBox, canonical) {\n var worldSize = Math.pow(2, canonical.z) * EXTENT;\n var shifts = [\n canonical.x * EXTENT,\n canonical.y * EXTENT\n ];\n var tileLines = [];\n for (var i$1 = 0, list$1 = geometry; i$1 < list$1.length; i$1 += 1) {\n var line = list$1[i$1];\n var tileLine = [];\n for (var i = 0, list = line; i < list.length; i += 1) {\n var point = list[i];\n var p = [\n point.x + shifts[0],\n point.y + shifts[1]\n ];\n updateBBox(lineBBox, p);\n tileLine.push(p);\n }\n tileLines.push(tileLine);\n }\n if (lineBBox[2] - lineBBox[0] <= worldSize / 2) {\n resetBBox(lineBBox);\n for (var i$3 = 0, list$3 = tileLines; i$3 < list$3.length; i$3 += 1) {\n var line$1 = list$3[i$3];\n for (var i$2 = 0, list$2 = line$1; i$2 < list$2.length; i$2 += 1) {\n var p$1 = list$2[i$2];\n updatePoint(p$1, lineBBox, polyBBox, worldSize);\n }\n }\n }\n return tileLines;\n}\nfunction pointsWithinPolygons(ctx, polygonGeometry) {\n var pointBBox = [\n Infinity,\n Infinity,\n -Infinity,\n -Infinity\n ];\n var polyBBox = [\n Infinity,\n Infinity,\n -Infinity,\n -Infinity\n ];\n var canonical = ctx.canonicalID();\n if (polygonGeometry.type === 'Polygon') {\n var tilePolygon = getTilePolygon(polygonGeometry.coordinates, polyBBox, canonical);\n var tilePoints = getTilePoints(ctx.geometry(), pointBBox, polyBBox, canonical);\n if (!boxWithinBox(pointBBox, polyBBox)) {\n return false;\n }\n for (var i = 0, list = tilePoints; i < list.length; i += 1) {\n var point = list[i];\n if (!pointWithinPolygon(point, tilePolygon)) {\n return false;\n }\n }\n }\n if (polygonGeometry.type === 'MultiPolygon') {\n var tilePolygons = getTilePolygons(polygonGeometry.coordinates, polyBBox, canonical);\n var tilePoints$1 = getTilePoints(ctx.geometry(), pointBBox, polyBBox, canonical);\n if (!boxWithinBox(pointBBox, polyBBox)) {\n return false;\n }\n for (var i$1 = 0, list$1 = tilePoints$1; i$1 < list$1.length; i$1 += 1) {\n var point$1 = list$1[i$1];\n if (!pointWithinPolygons(point$1, tilePolygons)) {\n return false;\n }\n }\n }\n return true;\n}\nfunction linesWithinPolygons(ctx, polygonGeometry) {\n var lineBBox = [\n Infinity,\n Infinity,\n -Infinity,\n -Infinity\n ];\n var polyBBox = [\n Infinity,\n Infinity,\n -Infinity,\n -Infinity\n ];\n var canonical = ctx.canonicalID();\n if (polygonGeometry.type === 'Polygon') {\n var tilePolygon = getTilePolygon(polygonGeometry.coordinates, polyBBox, canonical);\n var tileLines = getTileLines(ctx.geometry(), lineBBox, polyBBox, canonical);\n if (!boxWithinBox(lineBBox, polyBBox)) {\n return false;\n }\n for (var i = 0, list = tileLines; i < list.length; i += 1) {\n var line = list[i];\n if (!lineStringWithinPolygon(line, tilePolygon)) {\n return false;\n }\n }\n }\n if (polygonGeometry.type === 'MultiPolygon') {\n var tilePolygons = getTilePolygons(polygonGeometry.coordinates, polyBBox, canonical);\n var tileLines$1 = getTileLines(ctx.geometry(), lineBBox, polyBBox, canonical);\n if (!boxWithinBox(lineBBox, polyBBox)) {\n return false;\n }\n for (var i$1 = 0, list$1 = tileLines$1; i$1 < list$1.length; i$1 += 1) {\n var line$1 = list$1[i$1];\n if (!lineStringWithinPolygons(line$1, tilePolygons)) {\n return false;\n }\n }\n }\n return true;\n}\nvar Within = function Within(geojson, geometries) {\n this.type = BooleanType;\n this.geojson = geojson;\n this.geometries = geometries;\n};\nWithin.parse = function parse(args, context) {\n if (args.length !== 2) {\n return context.error('\\'within\\' expression requires exactly one argument, but found ' + (args.length - 1) + ' instead.');\n }\n if (isValue(args[1])) {\n var geojson = args[1];\n if (geojson.type === 'FeatureCollection') {\n for (var i = 0; i < geojson.features.length; ++i) {\n var type = geojson.features[i].geometry.type;\n if (type === 'Polygon' || type === 'MultiPolygon') {\n return new Within(geojson, geojson.features[i].geometry);\n }\n }\n } else if (geojson.type === 'Feature') {\n var type$1 = geojson.geometry.type;\n if (type$1 === 'Polygon' || type$1 === 'MultiPolygon') {\n return new Within(geojson, geojson.geometry);\n }\n } else if (geojson.type === 'Polygon' || geojson.type === 'MultiPolygon') {\n return new Within(geojson, geojson);\n }\n }\n return context.error('\\'within\\' expression requires valid geojson object that contains polygon geometry type.');\n};\nWithin.prototype.evaluate = function evaluate(ctx) {\n if (ctx.geometry() != null && ctx.canonicalID() != null) {\n if (ctx.geometryType() === 'Point') {\n return pointsWithinPolygons(ctx, this.geometries);\n } else if (ctx.geometryType() === 'LineString') {\n return linesWithinPolygons(ctx, this.geometries);\n }\n }\n return false;\n};\nWithin.prototype.eachChild = function eachChild() {\n};\nWithin.prototype.outputDefined = function outputDefined() {\n return true;\n};\nWithin.prototype.serialize = function serialize() {\n return [\n 'within',\n this.geojson\n ];\n};\n\nfunction isFeatureConstant(e) {\n if (e instanceof CompoundExpression) {\n if (e.name === 'get' && e.args.length === 1) {\n return false;\n } else if (e.name === 'feature-state') {\n return false;\n } else if (e.name === 'has' && e.args.length === 1) {\n return false;\n } else if (e.name === 'properties' || e.name === 'geometry-type' || e.name === 'id') {\n return false;\n } else if (/^filter-/.test(e.name)) {\n return false;\n }\n }\n if (e instanceof Within) {\n return false;\n }\n var result = true;\n e.eachChild(function (arg) {\n if (result && !isFeatureConstant(arg)) {\n result = false;\n }\n });\n return result;\n}\nfunction isStateConstant(e) {\n if (e instanceof CompoundExpression) {\n if (e.name === 'feature-state') {\n return false;\n }\n }\n var result = true;\n e.eachChild(function (arg) {\n if (result && !isStateConstant(arg)) {\n result = false;\n }\n });\n return result;\n}\nfunction isGlobalPropertyConstant(e, properties) {\n if (e instanceof CompoundExpression && properties.indexOf(e.name) >= 0) {\n return false;\n }\n var result = true;\n e.eachChild(function (arg) {\n if (result && !isGlobalPropertyConstant(arg, properties)) {\n result = false;\n }\n });\n return result;\n}\n\nvar Var = function Var(name, boundExpression) {\n this.type = boundExpression.type;\n this.name = name;\n this.boundExpression = boundExpression;\n};\nVar.parse = function parse(args, context) {\n if (args.length !== 2 || typeof args[1] !== 'string') {\n return context.error('\\'var\\' expression requires exactly one string literal argument.');\n }\n var name = args[1];\n if (!context.scope.has(name)) {\n return context.error('Unknown variable \"' + name + '\". Make sure \"' + name + '\" has been bound in an enclosing \"let\" expression before using it.', 1);\n }\n return new Var(name, context.scope.get(name));\n};\nVar.prototype.evaluate = function evaluate(ctx) {\n return this.boundExpression.evaluate(ctx);\n};\nVar.prototype.eachChild = function eachChild() {\n};\nVar.prototype.outputDefined = function outputDefined() {\n return false;\n};\nVar.prototype.serialize = function serialize() {\n return [\n 'var',\n this.name\n ];\n};\n\nvar ParsingContext = function ParsingContext(registry, path, expectedType, scope, errors) {\n if (path === void 0)\n path = [];\n if (scope === void 0)\n scope = new Scope();\n if (errors === void 0)\n errors = [];\n this.registry = registry;\n this.path = path;\n this.key = path.map(function (part) {\n return '[' + part + ']';\n }).join('');\n this.scope = scope;\n this.errors = errors;\n this.expectedType = expectedType;\n};\nParsingContext.prototype.parse = function parse(expr, index, expectedType, bindings, options) {\n if (options === void 0)\n options = {};\n if (index) {\n return this.concat(index, expectedType, bindings)._parse(expr, options);\n }\n return this._parse(expr, options);\n};\nParsingContext.prototype._parse = function _parse(expr, options) {\n if (expr === null || typeof expr === 'string' || typeof expr === 'boolean' || typeof expr === 'number') {\n expr = [\n 'literal',\n expr\n ];\n }\n function annotate(parsed, type, typeAnnotation) {\n if (typeAnnotation === 'assert') {\n return new Assertion(type, [parsed]);\n } else if (typeAnnotation === 'coerce') {\n return new Coercion(type, [parsed]);\n } else {\n return parsed;\n }\n }\n if (Array.isArray(expr)) {\n if (expr.length === 0) {\n return this.error('Expected an array with at least one element. If you wanted a literal array, use [\"literal\", []].');\n }\n var op = expr[0];\n if (typeof op !== 'string') {\n this.error('Expression name must be a string, but found ' + typeof op + ' instead. If you wanted a literal array, use [\"literal\", [...]].', 0);\n return null;\n }\n var Expr = this.registry[op];\n if (Expr) {\n var parsed = Expr.parse(expr, this);\n if (!parsed) {\n return null;\n }\n if (this.expectedType) {\n var expected = this.expectedType;\n var actual = parsed.type;\n if ((expected.kind === 'string' || expected.kind === 'number' || expected.kind === 'boolean' || expected.kind === 'object' || expected.kind === 'array') && actual.kind === 'value') {\n parsed = annotate(parsed, expected, options.typeAnnotation || 'assert');\n } else if ((expected.kind === 'color' || expected.kind === 'formatted' || expected.kind === 'resolvedImage') && (actual.kind === 'value' || actual.kind === 'string')) {\n parsed = annotate(parsed, expected, options.typeAnnotation || 'coerce');\n } else if (this.checkSubtype(expected, actual)) {\n return null;\n }\n }\n if (!(parsed instanceof Literal) && parsed.type.kind !== 'resolvedImage' && isConstant(parsed)) {\n var ec = new EvaluationContext();\n try {\n parsed = new Literal(parsed.type, parsed.evaluate(ec));\n } catch (e) {\n this.error(e.message);\n return null;\n }\n }\n return parsed;\n }\n return this.error('Unknown expression \"' + op + '\". If you wanted a literal array, use [\"literal\", [...]].', 0);\n } else if (typeof expr === 'undefined') {\n return this.error('\\'undefined\\' value invalid. Use null instead.');\n } else if (typeof expr === 'object') {\n return this.error('Bare objects invalid. Use [\"literal\", {...}] instead.');\n } else {\n return this.error('Expected an array, but found ' + typeof expr + ' instead.');\n }\n};\nParsingContext.prototype.concat = function concat(index, expectedType, bindings) {\n var path = typeof index === 'number' ? this.path.concat(index) : this.path;\n var scope = bindings ? this.scope.concat(bindings) : this.scope;\n return new ParsingContext(this.registry, path, expectedType || null, scope, this.errors);\n};\nParsingContext.prototype.error = function error(error$1) {\n var keys = [], len = arguments.length - 1;\n while (len-- > 0)\n keys[len] = arguments[len + 1];\n var key = '' + this.key + keys.map(function (k) {\n return '[' + k + ']';\n }).join('');\n this.errors.push(new ParsingError(key, error$1));\n};\nParsingContext.prototype.checkSubtype = function checkSubtype$1(expected, t) {\n var error = checkSubtype(expected, t);\n if (error) {\n this.error(error);\n }\n return error;\n};\nfunction isConstant(expression) {\n if (expression instanceof Var) {\n return isConstant(expression.boundExpression);\n } else if (expression instanceof CompoundExpression && expression.name === 'error') {\n return false;\n } else if (expression instanceof CollatorExpression) {\n return false;\n } else if (expression instanceof Within) {\n return false;\n }\n var isTypeAnnotation = expression instanceof Coercion || expression instanceof Assertion;\n var childrenConstant = true;\n expression.eachChild(function (child) {\n if (isTypeAnnotation) {\n childrenConstant = childrenConstant && isConstant(child);\n } else {\n childrenConstant = childrenConstant && child instanceof Literal;\n }\n });\n if (!childrenConstant) {\n return false;\n }\n return isFeatureConstant(expression) && isGlobalPropertyConstant(expression, [\n 'zoom',\n 'heatmap-density',\n 'line-progress',\n 'accumulated',\n 'is-supported-script'\n ]);\n}\n\nfunction findStopLessThanOrEqualTo(stops, input) {\n var lastIndex = stops.length - 1;\n var lowerIndex = 0;\n var upperIndex = lastIndex;\n var currentIndex = 0;\n var currentValue, nextValue;\n while (lowerIndex <= upperIndex) {\n currentIndex = Math.floor((lowerIndex + upperIndex) / 2);\n currentValue = stops[currentIndex];\n nextValue = stops[currentIndex + 1];\n if (currentValue <= input) {\n if (currentIndex === lastIndex || input < nextValue) {\n return currentIndex;\n }\n lowerIndex = currentIndex + 1;\n } else if (currentValue > input) {\n upperIndex = currentIndex - 1;\n } else {\n throw new RuntimeError('Input is not a number.');\n }\n }\n return 0;\n}\n\nvar Step = function Step(type, input, stops) {\n this.type = type;\n this.input = input;\n this.labels = [];\n this.outputs = [];\n for (var i = 0, list = stops; i < list.length; i += 1) {\n var ref = list[i];\n var label = ref[0];\n var expression = ref[1];\n this.labels.push(label);\n this.outputs.push(expression);\n }\n};\nStep.parse = function parse(args, context) {\n if (args.length - 1 < 4) {\n return context.error('Expected at least 4 arguments, but found only ' + (args.length - 1) + '.');\n }\n if ((args.length - 1) % 2 !== 0) {\n return context.error('Expected an even number of arguments.');\n }\n var input = context.parse(args[1], 1, NumberType);\n if (!input) {\n return null;\n }\n var stops = [];\n var outputType = null;\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n for (var i = 1; i < args.length; i += 2) {\n var label = i === 1 ? -Infinity : args[i];\n var value = args[i + 1];\n var labelKey = i;\n var valueKey = i + 1;\n if (typeof label !== 'number') {\n return context.error('Input/output pairs for \"step\" expressions must be defined using literal numeric values (not computed expressions) for the input values.', labelKey);\n }\n if (stops.length && stops[stops.length - 1][0] >= label) {\n return context.error('Input/output pairs for \"step\" expressions must be arranged with input values in strictly ascending order.', labelKey);\n }\n var parsed = context.parse(value, valueKey, outputType);\n if (!parsed) {\n return null;\n }\n outputType = outputType || parsed.type;\n stops.push([\n label,\n parsed\n ]);\n }\n return new Step(outputType, input, stops);\n};\nStep.prototype.evaluate = function evaluate(ctx) {\n var labels = this.labels;\n var outputs = this.outputs;\n if (labels.length === 1) {\n return outputs[0].evaluate(ctx);\n }\n var value = this.input.evaluate(ctx);\n if (value <= labels[0]) {\n return outputs[0].evaluate(ctx);\n }\n var stopCount = labels.length;\n if (value >= labels[stopCount - 1]) {\n return outputs[stopCount - 1].evaluate(ctx);\n }\n var index = findStopLessThanOrEqualTo(labels, value);\n return outputs[index].evaluate(ctx);\n};\nStep.prototype.eachChild = function eachChild(fn) {\n fn(this.input);\n for (var i = 0, list = this.outputs; i < list.length; i += 1) {\n var expression = list[i];\n fn(expression);\n }\n};\nStep.prototype.outputDefined = function outputDefined() {\n return this.outputs.every(function (out) {\n return out.outputDefined();\n });\n};\nStep.prototype.serialize = function serialize() {\n var serialized = [\n 'step',\n this.input.serialize()\n ];\n for (var i = 0; i < this.labels.length; i++) {\n if (i > 0) {\n serialized.push(this.labels[i]);\n }\n serialized.push(this.outputs[i].serialize());\n }\n return serialized;\n};\n\nfunction number(a, b, t) {\n return a * (1 - t) + b * t;\n}\nfunction color(from, to, t) {\n return new Color(number(from.r, to.r, t), number(from.g, to.g, t), number(from.b, to.b, t), number(from.a, to.a, t));\n}\nfunction array$1(from, to, t) {\n return from.map(function (d, i) {\n return number(d, to[i], t);\n });\n}\n\nvar interpolate = /*#__PURE__*/Object.freeze({\n__proto__: null,\nnumber: number,\ncolor: color,\narray: array$1\n});\n\nvar Xn = 0.95047, Yn = 1, Zn = 1.08883, t0 = 4 / 29, t1 = 6 / 29, t2 = 3 * t1 * t1, t3 = t1 * t1 * t1, deg2rad = Math.PI / 180, rad2deg = 180 / Math.PI;\nfunction xyz2lab(t) {\n return t > t3 ? Math.pow(t, 1 / 3) : t / t2 + t0;\n}\nfunction lab2xyz(t) {\n return t > t1 ? t * t * t : t2 * (t - t0);\n}\nfunction xyz2rgb(x) {\n return 255 * (x <= 0.0031308 ? 12.92 * x : 1.055 * Math.pow(x, 1 / 2.4) - 0.055);\n}\nfunction rgb2xyz(x) {\n x /= 255;\n return x <= 0.04045 ? x / 12.92 : Math.pow((x + 0.055) / 1.055, 2.4);\n}\nfunction rgbToLab(rgbColor) {\n var b = rgb2xyz(rgbColor.r), a = rgb2xyz(rgbColor.g), l = rgb2xyz(rgbColor.b), x = xyz2lab((0.4124564 * b + 0.3575761 * a + 0.1804375 * l) / Xn), y = xyz2lab((0.2126729 * b + 0.7151522 * a + 0.072175 * l) / Yn), z = xyz2lab((0.0193339 * b + 0.119192 * a + 0.9503041 * l) / Zn);\n return {\n l: 116 * y - 16,\n a: 500 * (x - y),\n b: 200 * (y - z),\n alpha: rgbColor.a\n };\n}\nfunction labToRgb(labColor) {\n var y = (labColor.l + 16) / 116, x = isNaN(labColor.a) ? y : y + labColor.a / 500, z = isNaN(labColor.b) ? y : y - labColor.b / 200;\n y = Yn * lab2xyz(y);\n x = Xn * lab2xyz(x);\n z = Zn * lab2xyz(z);\n return new Color(xyz2rgb(3.2404542 * x - 1.5371385 * y - 0.4985314 * z), xyz2rgb(-0.969266 * x + 1.8760108 * y + 0.041556 * z), xyz2rgb(0.0556434 * x - 0.2040259 * y + 1.0572252 * z), labColor.alpha);\n}\nfunction interpolateLab(from, to, t) {\n return {\n l: number(from.l, to.l, t),\n a: number(from.a, to.a, t),\n b: number(from.b, to.b, t),\n alpha: number(from.alpha, to.alpha, t)\n };\n}\nfunction rgbToHcl(rgbColor) {\n var ref = rgbToLab(rgbColor);\n var l = ref.l;\n var a = ref.a;\n var b = ref.b;\n var h = Math.atan2(b, a) * rad2deg;\n return {\n h: h < 0 ? h + 360 : h,\n c: Math.sqrt(a * a + b * b),\n l: l,\n alpha: rgbColor.a\n };\n}\nfunction hclToRgb(hclColor) {\n var h = hclColor.h * deg2rad, c = hclColor.c, l = hclColor.l;\n return labToRgb({\n l: l,\n a: Math.cos(h) * c,\n b: Math.sin(h) * c,\n alpha: hclColor.alpha\n });\n}\nfunction interpolateHue(a, b, t) {\n var d = b - a;\n return a + t * (d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d);\n}\nfunction interpolateHcl(from, to, t) {\n return {\n h: interpolateHue(from.h, to.h, t),\n c: number(from.c, to.c, t),\n l: number(from.l, to.l, t),\n alpha: number(from.alpha, to.alpha, t)\n };\n}\nvar lab = {\n forward: rgbToLab,\n reverse: labToRgb,\n interpolate: interpolateLab\n};\nvar hcl = {\n forward: rgbToHcl,\n reverse: hclToRgb,\n interpolate: interpolateHcl\n};\n\nvar colorSpaces = /*#__PURE__*/Object.freeze({\n__proto__: null,\nlab: lab,\nhcl: hcl\n});\n\nvar Interpolate = function Interpolate(type, operator, interpolation, input, stops) {\n this.type = type;\n this.operator = operator;\n this.interpolation = interpolation;\n this.input = input;\n this.labels = [];\n this.outputs = [];\n for (var i = 0, list = stops; i < list.length; i += 1) {\n var ref = list[i];\n var label = ref[0];\n var expression = ref[1];\n this.labels.push(label);\n this.outputs.push(expression);\n }\n};\nInterpolate.interpolationFactor = function interpolationFactor(interpolation, input, lower, upper) {\n var t = 0;\n if (interpolation.name === 'exponential') {\n t = exponentialInterpolation(input, interpolation.base, lower, upper);\n } else if (interpolation.name === 'linear') {\n t = exponentialInterpolation(input, 1, lower, upper);\n } else if (interpolation.name === 'cubic-bezier') {\n var c = interpolation.controlPoints;\n var ub = new unitbezier(c[0], c[1], c[2], c[3]);\n t = ub.solve(exponentialInterpolation(input, 1, lower, upper));\n }\n return t;\n};\nInterpolate.parse = function parse(args, context) {\n var operator = args[0];\n var interpolation = args[1];\n var input = args[2];\n var rest = args.slice(3);\n if (!Array.isArray(interpolation) || interpolation.length === 0) {\n return context.error('Expected an interpolation type expression.', 1);\n }\n if (interpolation[0] === 'linear') {\n interpolation = { name: 'linear' };\n } else if (interpolation[0] === 'exponential') {\n var base = interpolation[1];\n if (typeof base !== 'number') {\n return context.error('Exponential interpolation requires a numeric base.', 1, 1);\n }\n interpolation = {\n name: 'exponential',\n base: base\n };\n } else if (interpolation[0] === 'cubic-bezier') {\n var controlPoints = interpolation.slice(1);\n if (controlPoints.length !== 4 || controlPoints.some(function (t) {\n return typeof t !== 'number' || t < 0 || t > 1;\n })) {\n return context.error('Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.', 1);\n }\n interpolation = {\n name: 'cubic-bezier',\n controlPoints: controlPoints\n };\n } else {\n return context.error('Unknown interpolation type ' + String(interpolation[0]), 1, 0);\n }\n if (args.length - 1 < 4) {\n return context.error('Expected at least 4 arguments, but found only ' + (args.length - 1) + '.');\n }\n if ((args.length - 1) % 2 !== 0) {\n return context.error('Expected an even number of arguments.');\n }\n input = context.parse(input, 2, NumberType);\n if (!input) {\n return null;\n }\n var stops = [];\n var outputType = null;\n if (operator === 'interpolate-hcl' || operator === 'interpolate-lab') {\n outputType = ColorType;\n } else if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n for (var i = 0; i < rest.length; i += 2) {\n var label = rest[i];\n var value = rest[i + 1];\n var labelKey = i + 3;\n var valueKey = i + 4;\n if (typeof label !== 'number') {\n return context.error('Input/output pairs for \"interpolate\" expressions must be defined using literal numeric values (not computed expressions) for the input values.', labelKey);\n }\n if (stops.length && stops[stops.length - 1][0] >= label) {\n return context.error('Input/output pairs for \"interpolate\" expressions must be arranged with input values in strictly ascending order.', labelKey);\n }\n var parsed = context.parse(value, valueKey, outputType);\n if (!parsed) {\n return null;\n }\n outputType = outputType || parsed.type;\n stops.push([\n label,\n parsed\n ]);\n }\n if (outputType.kind !== 'number' && outputType.kind !== 'color' && !(outputType.kind === 'array' && outputType.itemType.kind === 'number' && typeof outputType.N === 'number')) {\n return context.error('Type ' + toString(outputType) + ' is not interpolatable.');\n }\n return new Interpolate(outputType, operator, interpolation, input, stops);\n};\nInterpolate.prototype.evaluate = function evaluate(ctx) {\n var labels = this.labels;\n var outputs = this.outputs;\n if (labels.length === 1) {\n return outputs[0].evaluate(ctx);\n }\n var value = this.input.evaluate(ctx);\n if (value <= labels[0]) {\n return outputs[0].evaluate(ctx);\n }\n var stopCount = labels.length;\n if (value >= labels[stopCount - 1]) {\n return outputs[stopCount - 1].evaluate(ctx);\n }\n var index = findStopLessThanOrEqualTo(labels, value);\n var lower = labels[index];\n var upper = labels[index + 1];\n var t = Interpolate.interpolationFactor(this.interpolation, value, lower, upper);\n var outputLower = outputs[index].evaluate(ctx);\n var outputUpper = outputs[index + 1].evaluate(ctx);\n if (this.operator === 'interpolate') {\n return interpolate[this.type.kind.toLowerCase()](outputLower, outputUpper, t);\n } else if (this.operator === 'interpolate-hcl') {\n return hcl.reverse(hcl.interpolate(hcl.forward(outputLower), hcl.forward(outputUpper), t));\n } else {\n return lab.reverse(lab.interpolate(lab.forward(outputLower), lab.forward(outputUpper), t));\n }\n};\nInterpolate.prototype.eachChild = function eachChild(fn) {\n fn(this.input);\n for (var i = 0, list = this.outputs; i < list.length; i += 1) {\n var expression = list[i];\n fn(expression);\n }\n};\nInterpolate.prototype.outputDefined = function outputDefined() {\n return this.outputs.every(function (out) {\n return out.outputDefined();\n });\n};\nInterpolate.prototype.serialize = function serialize() {\n var interpolation;\n if (this.interpolation.name === 'linear') {\n interpolation = ['linear'];\n } else if (this.interpolation.name === 'exponential') {\n if (this.interpolation.base === 1) {\n interpolation = ['linear'];\n } else {\n interpolation = [\n 'exponential',\n this.interpolation.base\n ];\n }\n } else {\n interpolation = ['cubic-bezier'].concat(this.interpolation.controlPoints);\n }\n var serialized = [\n this.operator,\n interpolation,\n this.input.serialize()\n ];\n for (var i = 0; i < this.labels.length; i++) {\n serialized.push(this.labels[i], this.outputs[i].serialize());\n }\n return serialized;\n};\nfunction exponentialInterpolation(input, base, lowerValue, upperValue) {\n var difference = upperValue - lowerValue;\n var progress = input - lowerValue;\n if (difference === 0) {\n return 0;\n } else if (base === 1) {\n return progress / difference;\n } else {\n return (Math.pow(base, progress) - 1) / (Math.pow(base, difference) - 1);\n }\n}\n\nvar Coalesce = function Coalesce(type, args) {\n this.type = type;\n this.args = args;\n};\nCoalesce.parse = function parse(args, context) {\n if (args.length < 2) {\n return context.error('Expectected at least one argument.');\n }\n var outputType = null;\n var expectedType = context.expectedType;\n if (expectedType && expectedType.kind !== 'value') {\n outputType = expectedType;\n }\n var parsedArgs = [];\n for (var i = 0, list = args.slice(1); i < list.length; i += 1) {\n var arg = list[i];\n var parsed = context.parse(arg, 1 + parsedArgs.length, outputType, undefined, { typeAnnotation: 'omit' });\n if (!parsed) {\n return null;\n }\n outputType = outputType || parsed.type;\n parsedArgs.push(parsed);\n }\n var needsAnnotation = expectedType && parsedArgs.some(function (arg) {\n return checkSubtype(expectedType, arg.type);\n });\n return needsAnnotation ? new Coalesce(ValueType, parsedArgs) : new Coalesce(outputType, parsedArgs);\n};\nCoalesce.prototype.evaluate = function evaluate(ctx) {\n var result = null;\n var argCount = 0;\n var requestedImageName;\n for (var i = 0, list = this.args; i < list.length; i += 1) {\n var arg = list[i];\n argCount++;\n result = arg.evaluate(ctx);\n if (result && result instanceof ResolvedImage && !result.available) {\n if (!requestedImageName) {\n requestedImageName = result.name;\n }\n result = null;\n if (argCount === this.args.length) {\n result = requestedImageName;\n }\n }\n if (result !== null) {\n break;\n }\n }\n return result;\n};\nCoalesce.prototype.eachChild = function eachChild(fn) {\n this.args.forEach(fn);\n};\nCoalesce.prototype.outputDefined = function outputDefined() {\n return this.args.every(function (arg) {\n return arg.outputDefined();\n });\n};\nCoalesce.prototype.serialize = function serialize() {\n var serialized = ['coalesce'];\n this.eachChild(function (child) {\n serialized.push(child.serialize());\n });\n return serialized;\n};\n\nvar Let = function Let(bindings, result) {\n this.type = result.type;\n this.bindings = [].concat(bindings);\n this.result = result;\n};\nLet.prototype.evaluate = function evaluate(ctx) {\n return this.result.evaluate(ctx);\n};\nLet.prototype.eachChild = function eachChild(fn) {\n for (var i = 0, list = this.bindings; i < list.length; i += 1) {\n var binding = list[i];\n fn(binding[1]);\n }\n fn(this.result);\n};\nLet.parse = function parse(args, context) {\n if (args.length < 4) {\n return context.error('Expected at least 3 arguments, but found ' + (args.length - 1) + ' instead.');\n }\n var bindings = [];\n for (var i = 1; i < args.length - 1; i += 2) {\n var name = args[i];\n if (typeof name !== 'string') {\n return context.error('Expected string, but found ' + typeof name + ' instead.', i);\n }\n if (/[^a-zA-Z0-9_]/.test(name)) {\n return context.error('Variable names must contain only alphanumeric characters or \\'_\\'.', i);\n }\n var value = context.parse(args[i + 1], i + 1);\n if (!value) {\n return null;\n }\n bindings.push([\n name,\n value\n ]);\n }\n var result = context.parse(args[args.length - 1], args.length - 1, context.expectedType, bindings);\n if (!result) {\n return null;\n }\n return new Let(bindings, result);\n};\nLet.prototype.outputDefined = function outputDefined() {\n return this.result.outputDefined();\n};\nLet.prototype.serialize = function serialize() {\n var serialized = ['let'];\n for (var i = 0, list = this.bindings; i < list.length; i += 1) {\n var ref = list[i];\n var name = ref[0];\n var expr = ref[1];\n serialized.push(name, expr.serialize());\n }\n serialized.push(this.result.serialize());\n return serialized;\n};\n\nvar At = function At(type, index, input) {\n this.type = type;\n this.index = index;\n this.input = input;\n};\nAt.parse = function parse(args, context) {\n if (args.length !== 3) {\n return context.error('Expected 2 arguments, but found ' + (args.length - 1) + ' instead.');\n }\n var index = context.parse(args[1], 1, NumberType);\n var input = context.parse(args[2], 2, array(context.expectedType || ValueType));\n if (!index || !input) {\n return null;\n }\n var t = input.type;\n return new At(t.itemType, index, input);\n};\nAt.prototype.evaluate = function evaluate(ctx) {\n var index = this.index.evaluate(ctx);\n var array = this.input.evaluate(ctx);\n if (index < 0) {\n throw new RuntimeError('Array index out of bounds: ' + index + ' < 0.');\n }\n if (index >= array.length) {\n throw new RuntimeError('Array index out of bounds: ' + index + ' > ' + (array.length - 1) + '.');\n }\n if (index !== Math.floor(index)) {\n throw new RuntimeError('Array index must be an integer, but found ' + index + ' instead.');\n }\n return array[index];\n};\nAt.prototype.eachChild = function eachChild(fn) {\n fn(this.index);\n fn(this.input);\n};\nAt.prototype.outputDefined = function outputDefined() {\n return false;\n};\nAt.prototype.serialize = function serialize() {\n return [\n 'at',\n this.index.serialize(),\n this.input.serialize()\n ];\n};\n\nvar In = function In(needle, haystack) {\n this.type = BooleanType;\n this.needle = needle;\n this.haystack = haystack;\n};\nIn.parse = function parse(args, context) {\n if (args.length !== 3) {\n return context.error('Expected 2 arguments, but found ' + (args.length - 1) + ' instead.');\n }\n var needle = context.parse(args[1], 1, ValueType);\n var haystack = context.parse(args[2], 2, ValueType);\n if (!needle || !haystack) {\n return null;\n }\n if (!isValidType(needle.type, [\n BooleanType,\n StringType,\n NumberType,\n NullType,\n ValueType\n ])) {\n return context.error('Expected first argument to be of type boolean, string, number or null, but found ' + toString(needle.type) + ' instead');\n }\n return new In(needle, haystack);\n};\nIn.prototype.evaluate = function evaluate(ctx) {\n var needle = this.needle.evaluate(ctx);\n var haystack = this.haystack.evaluate(ctx);\n if (!haystack) {\n return false;\n }\n if (!isValidNativeType(needle, [\n 'boolean',\n 'string',\n 'number',\n 'null'\n ])) {\n throw new RuntimeError('Expected first argument to be of type boolean, string, number or null, but found ' + toString(typeOf(needle)) + ' instead.');\n }\n if (!isValidNativeType(haystack, [\n 'string',\n 'array'\n ])) {\n throw new RuntimeError('Expected second argument to be of type array or string, but found ' + toString(typeOf(haystack)) + ' instead.');\n }\n return haystack.indexOf(needle) >= 0;\n};\nIn.prototype.eachChild = function eachChild(fn) {\n fn(this.needle);\n fn(this.haystack);\n};\nIn.prototype.outputDefined = function outputDefined() {\n return true;\n};\nIn.prototype.serialize = function serialize() {\n return [\n 'in',\n this.needle.serialize(),\n this.haystack.serialize()\n ];\n};\n\nvar IndexOf = function IndexOf(needle, haystack, fromIndex) {\n this.type = NumberType;\n this.needle = needle;\n this.haystack = haystack;\n this.fromIndex = fromIndex;\n};\nIndexOf.parse = function parse(args, context) {\n if (args.length <= 2 || args.length >= 5) {\n return context.error('Expected 3 or 4 arguments, but found ' + (args.length - 1) + ' instead.');\n }\n var needle = context.parse(args[1], 1, ValueType);\n var haystack = context.parse(args[2], 2, ValueType);\n if (!needle || !haystack) {\n return null;\n }\n if (!isValidType(needle.type, [\n BooleanType,\n StringType,\n NumberType,\n NullType,\n ValueType\n ])) {\n return context.error('Expected first argument to be of type boolean, string, number or null, but found ' + toString(needle.type) + ' instead');\n }\n if (args.length === 4) {\n var fromIndex = context.parse(args[3], 3, NumberType);\n if (!fromIndex) {\n return null;\n }\n return new IndexOf(needle, haystack, fromIndex);\n } else {\n return new IndexOf(needle, haystack);\n }\n};\nIndexOf.prototype.evaluate = function evaluate(ctx) {\n var needle = this.needle.evaluate(ctx);\n var haystack = this.haystack.evaluate(ctx);\n if (!isValidNativeType(needle, [\n 'boolean',\n 'string',\n 'number',\n 'null'\n ])) {\n throw new RuntimeError('Expected first argument to be of type boolean, string, number or null, but found ' + toString(typeOf(needle)) + ' instead.');\n }\n if (!isValidNativeType(haystack, [\n 'string',\n 'array'\n ])) {\n throw new RuntimeError('Expected second argument to be of type array or string, but found ' + toString(typeOf(haystack)) + ' instead.');\n }\n if (this.fromIndex) {\n var fromIndex = this.fromIndex.evaluate(ctx);\n return haystack.indexOf(needle, fromIndex);\n }\n return haystack.indexOf(needle);\n};\nIndexOf.prototype.eachChild = function eachChild(fn) {\n fn(this.needle);\n fn(this.haystack);\n if (this.fromIndex) {\n fn(this.fromIndex);\n }\n};\nIndexOf.prototype.outputDefined = function outputDefined() {\n return false;\n};\nIndexOf.prototype.serialize = function serialize() {\n if (this.fromIndex != null && this.fromIndex !== undefined) {\n var fromIndex = this.fromIndex.serialize();\n return [\n 'index-of',\n this.needle.serialize(),\n this.haystack.serialize(),\n fromIndex\n ];\n }\n return [\n 'index-of',\n this.needle.serialize(),\n this.haystack.serialize()\n ];\n};\n\nvar Match = function Match(inputType, outputType, input, cases, outputs, otherwise) {\n this.inputType = inputType;\n this.type = outputType;\n this.input = input;\n this.cases = cases;\n this.outputs = outputs;\n this.otherwise = otherwise;\n};\nMatch.parse = function parse(args, context) {\n if (args.length < 5) {\n return context.error('Expected at least 4 arguments, but found only ' + (args.length - 1) + '.');\n }\n if (args.length % 2 !== 1) {\n return context.error('Expected an even number of arguments.');\n }\n var inputType;\n var outputType;\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n var cases = {};\n var outputs = [];\n for (var i = 2; i < args.length - 1; i += 2) {\n var labels = args[i];\n var value = args[i + 1];\n if (!Array.isArray(labels)) {\n labels = [labels];\n }\n var labelContext = context.concat(i);\n if (labels.length === 0) {\n return labelContext.error('Expected at least one branch label.');\n }\n for (var i$1 = 0, list = labels; i$1 < list.length; i$1 += 1) {\n var label = list[i$1];\n if (typeof label !== 'number' && typeof label !== 'string') {\n return labelContext.error('Branch labels must be numbers or strings.');\n } else if (typeof label === 'number' && Math.abs(label) > Number.MAX_SAFE_INTEGER) {\n return labelContext.error('Branch labels must be integers no larger than ' + Number.MAX_SAFE_INTEGER + '.');\n } else if (typeof label === 'number' && Math.floor(label) !== label) {\n return labelContext.error('Numeric branch labels must be integer values.');\n } else if (!inputType) {\n inputType = typeOf(label);\n } else if (labelContext.checkSubtype(inputType, typeOf(label))) {\n return null;\n }\n if (typeof cases[String(label)] !== 'undefined') {\n return labelContext.error('Branch labels must be unique.');\n }\n cases[String(label)] = outputs.length;\n }\n var result = context.parse(value, i, outputType);\n if (!result) {\n return null;\n }\n outputType = outputType || result.type;\n outputs.push(result);\n }\n var input = context.parse(args[1], 1, ValueType);\n if (!input) {\n return null;\n }\n var otherwise = context.parse(args[args.length - 1], args.length - 1, outputType);\n if (!otherwise) {\n return null;\n }\n if (input.type.kind !== 'value' && context.concat(1).checkSubtype(inputType, input.type)) {\n return null;\n }\n return new Match(inputType, outputType, input, cases, outputs, otherwise);\n};\nMatch.prototype.evaluate = function evaluate(ctx) {\n var input = this.input.evaluate(ctx);\n var output = typeOf(input) === this.inputType && this.outputs[this.cases[input]] || this.otherwise;\n return output.evaluate(ctx);\n};\nMatch.prototype.eachChild = function eachChild(fn) {\n fn(this.input);\n this.outputs.forEach(fn);\n fn(this.otherwise);\n};\nMatch.prototype.outputDefined = function outputDefined() {\n return this.outputs.every(function (out) {\n return out.outputDefined();\n }) && this.otherwise.outputDefined();\n};\nMatch.prototype.serialize = function serialize() {\n var this$1 = this;\n var serialized = [\n 'match',\n this.input.serialize()\n ];\n var sortedLabels = Object.keys(this.cases).sort();\n var groupedByOutput = [];\n var outputLookup = {};\n for (var i = 0, list = sortedLabels; i < list.length; i += 1) {\n var label = list[i];\n var outputIndex = outputLookup[this.cases[label]];\n if (outputIndex === undefined) {\n outputLookup[this.cases[label]] = groupedByOutput.length;\n groupedByOutput.push([\n this.cases[label],\n [label]\n ]);\n } else {\n groupedByOutput[outputIndex][1].push(label);\n }\n }\n var coerceLabel = function (label) {\n return this$1.inputType.kind === 'number' ? Number(label) : label;\n };\n for (var i$1 = 0, list$1 = groupedByOutput; i$1 < list$1.length; i$1 += 1) {\n var ref = list$1[i$1];\n var outputIndex = ref[0];\n var labels = ref[1];\n if (labels.length === 1) {\n serialized.push(coerceLabel(labels[0]));\n } else {\n serialized.push(labels.map(coerceLabel));\n }\n serialized.push(this.outputs[outputIndex$1].serialize());\n }\n serialized.push(this.otherwise.serialize());\n return serialized;\n};\n\nvar Case = function Case(type, branches, otherwise) {\n this.type = type;\n this.branches = branches;\n this.otherwise = otherwise;\n};\nCase.parse = function parse(args, context) {\n if (args.length < 4) {\n return context.error('Expected at least 3 arguments, but found only ' + (args.length - 1) + '.');\n }\n if (args.length % 2 !== 0) {\n return context.error('Expected an odd number of arguments.');\n }\n var outputType;\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n var branches = [];\n for (var i = 1; i < args.length - 1; i += 2) {\n var test = context.parse(args[i], i, BooleanType);\n if (!test) {\n return null;\n }\n var result = context.parse(args[i + 1], i + 1, outputType);\n if (!result) {\n return null;\n }\n branches.push([\n test,\n result\n ]);\n outputType = outputType || result.type;\n }\n var otherwise = context.parse(args[args.length - 1], args.length - 1, outputType);\n if (!otherwise) {\n return null;\n }\n return new Case(outputType, branches, otherwise);\n};\nCase.prototype.evaluate = function evaluate(ctx) {\n for (var i = 0, list = this.branches; i < list.length; i += 1) {\n var ref = list[i];\n var test = ref[0];\n var expression = ref[1];\n if (test.evaluate(ctx)) {\n return expression.evaluate(ctx);\n }\n }\n return this.otherwise.evaluate(ctx);\n};\nCase.prototype.eachChild = function eachChild(fn) {\n for (var i = 0, list = this.branches; i < list.length; i += 1) {\n var ref = list[i];\n var test = ref[0];\n var expression = ref[1];\n fn(test);\n fn(expression);\n }\n fn(this.otherwise);\n};\nCase.prototype.outputDefined = function outputDefined() {\n return this.branches.every(function (ref) {\n var _ = ref[0];\n var out = ref[1];\n return out.outputDefined();\n }) && this.otherwise.outputDefined();\n};\nCase.prototype.serialize = function serialize() {\n var serialized = ['case'];\n this.eachChild(function (child) {\n serialized.push(child.serialize());\n });\n return serialized;\n};\n\nvar Slice = function Slice(type, input, beginIndex, endIndex) {\n this.type = type;\n this.input = input;\n this.beginIndex = beginIndex;\n this.endIndex = endIndex;\n};\nSlice.parse = function parse(args, context) {\n if (args.length <= 2 || args.length >= 5) {\n return context.error('Expected 3 or 4 arguments, but found ' + (args.length - 1) + ' instead.');\n }\n var input = context.parse(args[1], 1, ValueType);\n var beginIndex = context.parse(args[2], 2, NumberType);\n if (!input || !beginIndex) {\n return null;\n }\n if (!isValidType(input.type, [\n array(ValueType),\n StringType,\n ValueType\n ])) {\n return context.error('Expected first argument to be of type array or string, but found ' + toString(input.type) + ' instead');\n }\n if (args.length === 4) {\n var endIndex = context.parse(args[3], 3, NumberType);\n if (!endIndex) {\n return null;\n }\n return new Slice(input.type, input, beginIndex, endIndex);\n } else {\n return new Slice(input.type, input, beginIndex);\n }\n};\nSlice.prototype.evaluate = function evaluate(ctx) {\n var input = this.input.evaluate(ctx);\n var beginIndex = this.beginIndex.evaluate(ctx);\n if (!isValidNativeType(input, [\n 'string',\n 'array'\n ])) {\n throw new RuntimeError('Expected first argument to be of type array or string, but found ' + toString(typeOf(input)) + ' instead.');\n }\n if (this.endIndex) {\n var endIndex = this.endIndex.evaluate(ctx);\n return input.slice(beginIndex, endIndex);\n }\n return input.slice(beginIndex);\n};\nSlice.prototype.eachChild = function eachChild(fn) {\n fn(this.input);\n fn(this.beginIndex);\n if (this.endIndex) {\n fn(this.endIndex);\n }\n};\nSlice.prototype.outputDefined = function outputDefined() {\n return false;\n};\nSlice.prototype.serialize = function serialize() {\n if (this.endIndex != null && this.endIndex !== undefined) {\n var endIndex = this.endIndex.serialize();\n return [\n 'slice',\n this.input.serialize(),\n this.beginIndex.serialize(),\n endIndex\n ];\n }\n return [\n 'slice',\n this.input.serialize(),\n this.beginIndex.serialize()\n ];\n};\n\nfunction isComparableType(op, type) {\n if (op === '==' || op === '!=') {\n return type.kind === 'boolean' || type.kind === 'string' || type.kind === 'number' || type.kind === 'null' || type.kind === 'value';\n } else {\n return type.kind === 'string' || type.kind === 'number' || type.kind === 'value';\n }\n}\nfunction eq(ctx, a, b) {\n return a === b;\n}\nfunction neq(ctx, a, b) {\n return a !== b;\n}\nfunction lt(ctx, a, b) {\n return a < b;\n}\nfunction gt(ctx, a, b) {\n return a > b;\n}\nfunction lteq(ctx, a, b) {\n return a <= b;\n}\nfunction gteq(ctx, a, b) {\n return a >= b;\n}\nfunction eqCollate(ctx, a, b, c) {\n return c.compare(a, b) === 0;\n}\nfunction neqCollate(ctx, a, b, c) {\n return !eqCollate(ctx, a, b, c);\n}\nfunction ltCollate(ctx, a, b, c) {\n return c.compare(a, b) < 0;\n}\nfunction gtCollate(ctx, a, b, c) {\n return c.compare(a, b) > 0;\n}\nfunction lteqCollate(ctx, a, b, c) {\n return c.compare(a, b) <= 0;\n}\nfunction gteqCollate(ctx, a, b, c) {\n return c.compare(a, b) >= 0;\n}\nfunction makeComparison(op, compareBasic, compareWithCollator) {\n var isOrderComparison = op !== '==' && op !== '!=';\n return function () {\n function Comparison(lhs, rhs, collator) {\n this.type = BooleanType;\n this.lhs = lhs;\n this.rhs = rhs;\n this.collator = collator;\n this.hasUntypedArgument = lhs.type.kind === 'value' || rhs.type.kind === 'value';\n }\n Comparison.parse = function parse(args, context) {\n if (args.length !== 3 && args.length !== 4) {\n return context.error('Expected two or three arguments.');\n }\n var op = args[0];\n var lhs = context.parse(args[1], 1, ValueType);\n if (!lhs) {\n return null;\n }\n if (!isComparableType(op, lhs.type)) {\n return context.concat(1).error('\"' + op + '\" comparisons are not supported for type \\'' + toString(lhs.type) + '\\'.');\n }\n var rhs = context.parse(args[2], 2, ValueType);\n if (!rhs) {\n return null;\n }\n if (!isComparableType(op, rhs.type)) {\n return context.concat(2).error('\"' + op + '\" comparisons are not supported for type \\'' + toString(rhs.type) + '\\'.');\n }\n if (lhs.type.kind !== rhs.type.kind && lhs.type.kind !== 'value' && rhs.type.kind !== 'value') {\n return context.error('Cannot compare types \\'' + toString(lhs.type) + '\\' and \\'' + toString(rhs.type) + '\\'.');\n }\n if (isOrderComparison) {\n if (lhs.type.kind === 'value' && rhs.type.kind !== 'value') {\n lhs = new Assertion(rhs.type, [lhs]);\n } else if (lhs.type.kind !== 'value' && rhs.type.kind === 'value') {\n rhs = new Assertion(lhs.type, [rhs]);\n }\n }\n var collator = null;\n if (args.length === 4) {\n if (lhs.type.kind !== 'string' && rhs.type.kind !== 'string' && lhs.type.kind !== 'value' && rhs.type.kind !== 'value') {\n return context.error('Cannot use collator to compare non-string types.');\n }\n collator = context.parse(args[3], 3, CollatorType);\n if (!collator) {\n return null;\n }\n }\n return new Comparison(lhs, rhs, collator);\n };\n Comparison.prototype.evaluate = function evaluate(ctx) {\n var lhs = this.lhs.evaluate(ctx);\n var rhs = this.rhs.evaluate(ctx);\n if (isOrderComparison && this.hasUntypedArgument) {\n var lt = typeOf(lhs);\n var rt = typeOf(rhs);\n if (lt.kind !== rt.kind || !(lt.kind === 'string' || lt.kind === 'number')) {\n throw new RuntimeError('Expected arguments for \"' + op + '\" to be (string, string) or (number, number), but found (' + lt.kind + ', ' + rt.kind + ') instead.');\n }\n }\n if (this.collator && !isOrderComparison && this.hasUntypedArgument) {\n var lt$1 = typeOf(lhs);\n var rt$1 = typeOf(rhs);\n if (lt$1.kind !== 'string' || rt$1.kind !== 'string') {\n return compareBasic(ctx, lhs, rhs);\n }\n }\n return this.collator ? compareWithCollator(ctx, lhs, rhs, this.collator.evaluate(ctx)) : compareBasic(ctx, lhs, rhs);\n };\n Comparison.prototype.eachChild = function eachChild(fn) {\n fn(this.lhs);\n fn(this.rhs);\n if (this.collator) {\n fn(this.collator);\n }\n };\n Comparison.prototype.outputDefined = function outputDefined() {\n return true;\n };\n Comparison.prototype.serialize = function serialize() {\n var serialized = [op];\n this.eachChild(function (child) {\n serialized.push(child.serialize());\n });\n return serialized;\n };\n return Comparison;\n }();\n}\nvar Equals = makeComparison('==', eq, eqCollate);\nvar NotEquals = makeComparison('!=', neq, neqCollate);\nvar LessThan = makeComparison('<', lt, ltCollate);\nvar GreaterThan = makeComparison('>', gt, gtCollate);\nvar LessThanOrEqual = makeComparison('<=', lteq, lteqCollate);\nvar GreaterThanOrEqual = makeComparison('>=', gteq, gteqCollate);\n\nvar NumberFormat = function NumberFormat(number, locale, currency, minFractionDigits, maxFractionDigits) {\n this.type = StringType;\n this.number = number;\n this.locale = locale;\n this.currency = currency;\n this.minFractionDigits = minFractionDigits;\n this.maxFractionDigits = maxFractionDigits;\n};\nNumberFormat.parse = function parse(args, context) {\n if (args.length !== 3) {\n return context.error('Expected two arguments.');\n }\n var number = context.parse(args[1], 1, NumberType);\n if (!number) {\n return null;\n }\n var options = args[2];\n if (typeof options !== 'object' || Array.isArray(options)) {\n return context.error('NumberFormat options argument must be an object.');\n }\n var locale = null;\n if (options['locale']) {\n locale = context.parse(options['locale'], 1, StringType);\n if (!locale) {\n return null;\n }\n }\n var currency = null;\n if (options['currency']) {\n currency = context.parse(options['currency'], 1, StringType);\n if (!currency) {\n return null;\n }\n }\n var minFractionDigits = null;\n if (options['min-fraction-digits']) {\n minFractionDigits = context.parse(options['min-fraction-digits'], 1, NumberType);\n if (!minFractionDigits) {\n return null;\n }\n }\n var maxFractionDigits = null;\n if (options['max-fraction-digits']) {\n maxFractionDigits = context.parse(options['max-fraction-digits'], 1, NumberType);\n if (!maxFractionDigits) {\n return null;\n }\n }\n return new NumberFormat(number, locale, currency, minFractionDigits, maxFractionDigits);\n};\nNumberFormat.prototype.evaluate = function evaluate(ctx) {\n return new Intl.NumberFormat(this.locale ? this.locale.evaluate(ctx) : [], {\n style: this.currency ? 'currency' : 'decimal',\n currency: this.currency ? this.currency.evaluate(ctx) : undefined,\n minimumFractionDigits: this.minFractionDigits ? this.minFractionDigits.evaluate(ctx) : undefined,\n maximumFractionDigits: this.maxFractionDigits ? this.maxFractionDigits.evaluate(ctx) : undefined\n }).format(this.number.evaluate(ctx));\n};\nNumberFormat.prototype.eachChild = function eachChild(fn) {\n fn(this.number);\n if (this.locale) {\n fn(this.locale);\n }\n if (this.currency) {\n fn(this.currency);\n }\n if (this.minFractionDigits) {\n fn(this.minFractionDigits);\n }\n if (this.maxFractionDigits) {\n fn(this.maxFractionDigits);\n }\n};\nNumberFormat.prototype.outputDefined = function outputDefined() {\n return false;\n};\nNumberFormat.prototype.serialize = function serialize() {\n var options = {};\n if (this.locale) {\n options['locale'] = this.locale.serialize();\n }\n if (this.currency) {\n options['currency'] = this.currency.serialize();\n }\n if (this.minFractionDigits) {\n options['min-fraction-digits'] = this.minFractionDigits.serialize();\n }\n if (this.maxFractionDigits) {\n options['max-fraction-digits'] = this.maxFractionDigits.serialize();\n }\n return [\n 'number-format',\n this.number.serialize(),\n options\n ];\n};\n\nvar Length = function Length(input) {\n this.type = NumberType;\n this.input = input;\n};\nLength.parse = function parse(args, context) {\n if (args.length !== 2) {\n return context.error('Expected 1 argument, but found ' + (args.length - 1) + ' instead.');\n }\n var input = context.parse(args[1], 1);\n if (!input) {\n return null;\n }\n if (input.type.kind !== 'array' && input.type.kind !== 'string' && input.type.kind !== 'value') {\n return context.error('Expected argument of type string or array, but found ' + toString(input.type) + ' instead.');\n }\n return new Length(input);\n};\nLength.prototype.evaluate = function evaluate(ctx) {\n var input = this.input.evaluate(ctx);\n if (typeof input === 'string') {\n return input.length;\n } else if (Array.isArray(input)) {\n return input.length;\n } else {\n throw new RuntimeError('Expected value to be of type string or array, but found ' + toString(typeOf(input)) + ' instead.');\n }\n};\nLength.prototype.eachChild = function eachChild(fn) {\n fn(this.input);\n};\nLength.prototype.outputDefined = function outputDefined() {\n return false;\n};\nLength.prototype.serialize = function serialize() {\n var serialized = ['length'];\n this.eachChild(function (child) {\n serialized.push(child.serialize());\n });\n return serialized;\n};\n\nvar expressions = {\n '==': Equals,\n '!=': NotEquals,\n '>': GreaterThan,\n '<': LessThan,\n '>=': GreaterThanOrEqual,\n '<=': LessThanOrEqual,\n 'array': Assertion,\n 'at': At,\n 'boolean': Assertion,\n 'case': Case,\n 'coalesce': Coalesce,\n 'collator': CollatorExpression,\n 'format': FormatExpression,\n 'image': ImageExpression,\n 'in': In,\n 'index-of': IndexOf,\n 'interpolate': Interpolate,\n 'interpolate-hcl': Interpolate,\n 'interpolate-lab': Interpolate,\n 'length': Length,\n 'let': Let,\n 'literal': Literal,\n 'match': Match,\n 'number': Assertion,\n 'number-format': NumberFormat,\n 'object': Assertion,\n 'slice': Slice,\n 'step': Step,\n 'string': Assertion,\n 'to-boolean': Coercion,\n 'to-color': Coercion,\n 'to-number': Coercion,\n 'to-string': Coercion,\n 'var': Var,\n 'within': Within\n};\nfunction rgba(ctx, ref) {\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var a = ref[3];\n r = r.evaluate(ctx);\n g = g.evaluate(ctx);\n b = b.evaluate(ctx);\n var alpha = a ? a.evaluate(ctx) : 1;\n var error = validateRGBA(r, g, b, alpha);\n if (error) {\n throw new RuntimeError(error);\n }\n return new Color(r / 255 * alpha, g / 255 * alpha, b / 255 * alpha, alpha);\n}\nfunction has(key, obj) {\n return key in obj;\n}\nfunction get(key, obj) {\n var v = obj[key];\n return typeof v === 'undefined' ? null : v;\n}\nfunction binarySearch(v, a, i, j) {\n while (i <= j) {\n var m = i + j >> 1;\n if (a[m] === v) {\n return true;\n }\n if (a[m] > v) {\n j = m - 1;\n } else {\n i = m + 1;\n }\n }\n return false;\n}\nfunction varargs(type) {\n return { type: type };\n}\nCompoundExpression.register(expressions, {\n 'error': [\n ErrorType,\n [StringType],\n function (ctx, ref) {\n var v = ref[0];\n throw new RuntimeError(v.evaluate(ctx));\n }\n ],\n 'typeof': [\n StringType,\n [ValueType],\n function (ctx, ref) {\n var v = ref[0];\n return toString(typeOf(v.evaluate(ctx)));\n }\n ],\n 'to-rgba': [\n array(NumberType, 4),\n [ColorType],\n function (ctx, ref) {\n var v = ref[0];\n return v.evaluate(ctx).toArray();\n }\n ],\n 'rgb': [\n ColorType,\n [\n NumberType,\n NumberType,\n NumberType\n ],\n rgba\n ],\n 'rgba': [\n ColorType,\n [\n NumberType,\n NumberType,\n NumberType,\n NumberType\n ],\n rgba\n ],\n 'has': {\n type: BooleanType,\n overloads: [\n [\n [StringType],\n function (ctx, ref) {\n var key = ref[0];\n return has(key.evaluate(ctx), ctx.properties());\n }\n ],\n [\n [\n StringType,\n ObjectType\n ],\n function (ctx, ref) {\n var key = ref[0];\n var obj = ref[1];\n return has(key.evaluate(ctx), obj.evaluate(ctx));\n }\n ]\n ]\n },\n 'get': {\n type: ValueType,\n overloads: [\n [\n [StringType],\n function (ctx, ref) {\n var key = ref[0];\n return get(key.evaluate(ctx), ctx.properties());\n }\n ],\n [\n [\n StringType,\n ObjectType\n ],\n function (ctx, ref) {\n var key = ref[0];\n var obj = ref[1];\n return get(key.evaluate(ctx), obj.evaluate(ctx));\n }\n ]\n ]\n },\n 'feature-state': [\n ValueType,\n [StringType],\n function (ctx, ref) {\n var key = ref[0];\n return get(key.evaluate(ctx), ctx.featureState || {});\n }\n ],\n 'properties': [\n ObjectType,\n [],\n function (ctx) {\n return ctx.properties();\n }\n ],\n 'geometry-type': [\n StringType,\n [],\n function (ctx) {\n return ctx.geometryType();\n }\n ],\n 'id': [\n ValueType,\n [],\n function (ctx) {\n return ctx.id();\n }\n ],\n 'zoom': [\n NumberType,\n [],\n function (ctx) {\n return ctx.globals.zoom;\n }\n ],\n 'heatmap-density': [\n NumberType,\n [],\n function (ctx) {\n return ctx.globals.heatmapDensity || 0;\n }\n ],\n 'line-progress': [\n NumberType,\n [],\n function (ctx) {\n return ctx.globals.lineProgress || 0;\n }\n ],\n 'accumulated': [\n ValueType,\n [],\n function (ctx) {\n return ctx.globals.accumulated === undefined ? null : ctx.globals.accumulated;\n }\n ],\n '+': [\n NumberType,\n varargs(NumberType),\n function (ctx, args) {\n var result = 0;\n for (var i = 0, list = args; i < list.length; i += 1) {\n var arg = list[i];\n result += arg.evaluate(ctx);\n }\n return result;\n }\n ],\n '*': [\n NumberType,\n varargs(NumberType),\n function (ctx, args) {\n var result = 1;\n for (var i = 0, list = args; i < list.length; i += 1) {\n var arg = list[i];\n result *= arg.evaluate(ctx);\n }\n return result;\n }\n ],\n '-': {\n type: NumberType,\n overloads: [\n [\n [\n NumberType,\n NumberType\n ],\n function (ctx, ref) {\n var a = ref[0];\n var b = ref[1];\n return a.evaluate(ctx) - b.evaluate(ctx);\n }\n ],\n [\n [NumberType],\n function (ctx, ref) {\n var a = ref[0];\n return -a.evaluate(ctx);\n }\n ]\n ]\n },\n '/': [\n NumberType,\n [\n NumberType,\n NumberType\n ],\n function (ctx, ref) {\n var a = ref[0];\n var b = ref[1];\n return a.evaluate(ctx) / b.evaluate(ctx);\n }\n ],\n '%': [\n NumberType,\n [\n NumberType,\n NumberType\n ],\n function (ctx, ref) {\n var a = ref[0];\n var b = ref[1];\n return a.evaluate(ctx) % b.evaluate(ctx);\n }\n ],\n 'ln2': [\n NumberType,\n [],\n function () {\n return Math.LN2;\n }\n ],\n 'pi': [\n NumberType,\n [],\n function () {\n return Math.PI;\n }\n ],\n 'e': [\n NumberType,\n [],\n function () {\n return Math.E;\n }\n ],\n '^': [\n NumberType,\n [\n NumberType,\n NumberType\n ],\n function (ctx, ref) {\n var b = ref[0];\n var e = ref[1];\n return Math.pow(b.evaluate(ctx), e.evaluate(ctx));\n }\n ],\n 'sqrt': [\n NumberType,\n [NumberType],\n function (ctx, ref) {\n var x = ref[0];\n return Math.sqrt(x.evaluate(ctx));\n }\n ],\n 'log10': [\n NumberType,\n [NumberType],\n function (ctx, ref) {\n var n = ref[0];\n return Math.log(n.evaluate(ctx)) / Math.LN10;\n }\n ],\n 'ln': [\n NumberType,\n [NumberType],\n function (ctx, ref) {\n var n = ref[0];\n return Math.log(n.evaluate(ctx));\n }\n ],\n 'log2': [\n NumberType,\n [NumberType],\n function (ctx, ref) {\n var n = ref[0];\n return Math.log(n.evaluate(ctx)) / Math.LN2;\n }\n ],\n 'sin': [\n NumberType,\n [NumberType],\n function (ctx, ref) {\n var n = ref[0];\n return Math.sin(n.evaluate(ctx));\n }\n ],\n 'cos': [\n NumberType,\n [NumberType],\n function (ctx, ref) {\n var n = ref[0];\n return Math.cos(n.evaluate(ctx));\n }\n ],\n 'tan': [\n NumberType,\n [NumberType],\n function (ctx, ref) {\n var n = ref[0];\n return Math.tan(n.evaluate(ctx));\n }\n ],\n 'asin': [\n NumberType,\n [NumberType],\n function (ctx, ref) {\n var n = ref[0];\n return Math.asin(n.evaluate(ctx));\n }\n ],\n 'acos': [\n NumberType,\n [NumberType],\n function (ctx, ref) {\n var n = ref[0];\n return Math.acos(n.evaluate(ctx));\n }\n ],\n 'atan': [\n NumberType,\n [NumberType],\n function (ctx, ref) {\n var n = ref[0];\n return Math.atan(n.evaluate(ctx));\n }\n ],\n 'min': [\n NumberType,\n varargs(NumberType),\n function (ctx, args) {\n return Math.min.apply(Math, args.map(function (arg) {\n return arg.evaluate(ctx);\n }));\n }\n ],\n 'max': [\n NumberType,\n varargs(NumberType),\n function (ctx, args) {\n return Math.max.apply(Math, args.map(function (arg) {\n return arg.evaluate(ctx);\n }));\n }\n ],\n 'abs': [\n NumberType,\n [NumberType],\n function (ctx, ref) {\n var n = ref[0];\n return Math.abs(n.evaluate(ctx));\n }\n ],\n 'round': [\n NumberType,\n [NumberType],\n function (ctx, ref) {\n var n = ref[0];\n var v = n.evaluate(ctx);\n return v < 0 ? -Math.round(-v) : Math.round(v);\n }\n ],\n 'floor': [\n NumberType,\n [NumberType],\n function (ctx, ref) {\n var n = ref[0];\n return Math.floor(n.evaluate(ctx));\n }\n ],\n 'ceil': [\n NumberType,\n [NumberType],\n function (ctx, ref) {\n var n = ref[0];\n return Math.ceil(n.evaluate(ctx));\n }\n ],\n 'filter-==': [\n BooleanType,\n [\n StringType,\n ValueType\n ],\n function (ctx, ref) {\n var k = ref[0];\n var v = ref[1];\n return ctx.properties()[k.value] === v.value;\n }\n ],\n 'filter-id-==': [\n BooleanType,\n [ValueType],\n function (ctx, ref) {\n var v = ref[0];\n return ctx.id() === v.value;\n }\n ],\n 'filter-type-==': [\n BooleanType,\n [StringType],\n function (ctx, ref) {\n var v = ref[0];\n return ctx.geometryType() === v.value;\n }\n ],\n 'filter-<': [\n BooleanType,\n [\n StringType,\n ValueType\n ],\n function (ctx, ref) {\n var k = ref[0];\n var v = ref[1];\n var a = ctx.properties()[k.value];\n var b = v.value;\n return typeof a === typeof b && a < b;\n }\n ],\n 'filter-id-<': [\n BooleanType,\n [ValueType],\n function (ctx, ref) {\n var v = ref[0];\n var a = ctx.id();\n var b = v.value;\n return typeof a === typeof b && a < b;\n }\n ],\n 'filter->': [\n BooleanType,\n [\n StringType,\n ValueType\n ],\n function (ctx, ref) {\n var k = ref[0];\n var v = ref[1];\n var a = ctx.properties()[k.value];\n var b = v.value;\n return typeof a === typeof b && a > b;\n }\n ],\n 'filter-id->': [\n BooleanType,\n [ValueType],\n function (ctx, ref) {\n var v = ref[0];\n var a = ctx.id();\n var b = v.value;\n return typeof a === typeof b && a > b;\n }\n ],\n 'filter-<=': [\n BooleanType,\n [\n StringType,\n ValueType\n ],\n function (ctx, ref) {\n var k = ref[0];\n var v = ref[1];\n var a = ctx.properties()[k.value];\n var b = v.value;\n return typeof a === typeof b && a <= b;\n }\n ],\n 'filter-id-<=': [\n BooleanType,\n [ValueType],\n function (ctx, ref) {\n var v = ref[0];\n var a = ctx.id();\n var b = v.value;\n return typeof a === typeof b && a <= b;\n }\n ],\n 'filter->=': [\n BooleanType,\n [\n StringType,\n ValueType\n ],\n function (ctx, ref) {\n var k = ref[0];\n var v = ref[1];\n var a = ctx.properties()[k.value];\n var b = v.value;\n return typeof a === typeof b && a >= b;\n }\n ],\n 'filter-id->=': [\n BooleanType,\n [ValueType],\n function (ctx, ref) {\n var v = ref[0];\n var a = ctx.id();\n var b = v.value;\n return typeof a === typeof b && a >= b;\n }\n ],\n 'filter-has': [\n BooleanType,\n [ValueType],\n function (ctx, ref) {\n var k = ref[0];\n return k.value in ctx.properties();\n }\n ],\n 'filter-has-id': [\n BooleanType,\n [],\n function (ctx) {\n return ctx.id() !== null && ctx.id() !== undefined;\n }\n ],\n 'filter-type-in': [\n BooleanType,\n [array(StringType)],\n function (ctx, ref) {\n var v = ref[0];\n return v.value.indexOf(ctx.geometryType()) >= 0;\n }\n ],\n 'filter-id-in': [\n BooleanType,\n [array(ValueType)],\n function (ctx, ref) {\n var v = ref[0];\n return v.value.indexOf(ctx.id()) >= 0;\n }\n ],\n 'filter-in-small': [\n BooleanType,\n [\n StringType,\n array(ValueType)\n ],\n function (ctx, ref) {\n var k = ref[0];\n var v = ref[1];\n return v.value.indexOf(ctx.properties()[k.value]) >= 0;\n }\n ],\n 'filter-in-large': [\n BooleanType,\n [\n StringType,\n array(ValueType)\n ],\n function (ctx, ref) {\n var k = ref[0];\n var v = ref[1];\n return binarySearch(ctx.properties()[k.value], v.value, 0, v.value.length - 1);\n }\n ],\n 'all': {\n type: BooleanType,\n overloads: [\n [\n [\n BooleanType,\n BooleanType\n ],\n function (ctx, ref) {\n var a = ref[0];\n var b = ref[1];\n return a.evaluate(ctx) && b.evaluate(ctx);\n }\n ],\n [\n varargs(BooleanType),\n function (ctx, args) {\n for (var i = 0, list = args; i < list.length; i += 1) {\n var arg = list[i];\n if (!arg.evaluate(ctx)) {\n return false;\n }\n }\n return true;\n }\n ]\n ]\n },\n 'any': {\n type: BooleanType,\n overloads: [\n [\n [\n BooleanType,\n BooleanType\n ],\n function (ctx, ref) {\n var a = ref[0];\n var b = ref[1];\n return a.evaluate(ctx) || b.evaluate(ctx);\n }\n ],\n [\n varargs(BooleanType),\n function (ctx, args) {\n for (var i = 0, list = args; i < list.length; i += 1) {\n var arg = list[i];\n if (arg.evaluate(ctx)) {\n return true;\n }\n }\n return false;\n }\n ]\n ]\n },\n '!': [\n BooleanType,\n [BooleanType],\n function (ctx, ref) {\n var b = ref[0];\n return !b.evaluate(ctx);\n }\n ],\n 'is-supported-script': [\n BooleanType,\n [StringType],\n function (ctx, ref) {\n var s = ref[0];\n var isSupportedScript = ctx.globals && ctx.globals.isSupportedScript;\n if (isSupportedScript) {\n return isSupportedScript(s.evaluate(ctx));\n }\n return true;\n }\n ],\n 'upcase': [\n StringType,\n [StringType],\n function (ctx, ref) {\n var s = ref[0];\n return s.evaluate(ctx).toUpperCase();\n }\n ],\n 'downcase': [\n StringType,\n [StringType],\n function (ctx, ref) {\n var s = ref[0];\n return s.evaluate(ctx).toLowerCase();\n }\n ],\n 'concat': [\n StringType,\n varargs(ValueType),\n function (ctx, args) {\n return args.map(function (arg) {\n return toString$1(arg.evaluate(ctx));\n }).join('');\n }\n ],\n 'resolved-locale': [\n StringType,\n [CollatorType],\n function (ctx, ref) {\n var collator = ref[0];\n return collator.evaluate(ctx).resolvedLocale();\n }\n ]\n});\n\nfunction success(value) {\n return {\n result: 'success',\n value: value\n };\n}\nfunction error(value) {\n return {\n result: 'error',\n value: value\n };\n}\n\nfunction supportsPropertyExpression(spec) {\n return spec['property-type'] === 'data-driven' || spec['property-type'] === 'cross-faded-data-driven';\n}\nfunction supportsZoomExpression(spec) {\n return !!spec.expression && spec.expression.parameters.indexOf('zoom') > -1;\n}\nfunction supportsInterpolation(spec) {\n return !!spec.expression && spec.expression.interpolated;\n}\n\nfunction getType(val) {\n if (val instanceof Number) {\n return 'number';\n } else if (val instanceof String) {\n return 'string';\n } else if (val instanceof Boolean) {\n return 'boolean';\n } else if (Array.isArray(val)) {\n return 'array';\n } else if (val === null) {\n return 'null';\n } else {\n return typeof val;\n }\n}\n\nfunction isFunction(value) {\n return typeof value === 'object' && value !== null && !Array.isArray(value);\n}\nfunction identityFunction(x) {\n return x;\n}\nfunction createFunction(parameters, propertySpec) {\n var isColor = propertySpec.type === 'color';\n var zoomAndFeatureDependent = parameters.stops && typeof parameters.stops[0][0] === 'object';\n var featureDependent = zoomAndFeatureDependent || parameters.property !== undefined;\n var zoomDependent = zoomAndFeatureDependent || !featureDependent;\n var type = parameters.type || (supportsInterpolation(propertySpec) ? 'exponential' : 'interval');\n if (isColor) {\n parameters = extend$1({}, parameters);\n if (parameters.stops) {\n parameters.stops = parameters.stops.map(function (stop) {\n return [\n stop[0],\n Color.parse(stop[1])\n ];\n });\n }\n if (parameters.default) {\n parameters.default = Color.parse(parameters.default);\n } else {\n parameters.default = Color.parse(propertySpec.default);\n }\n }\n if (parameters.colorSpace && parameters.colorSpace !== 'rgb' && !colorSpaces[parameters.colorSpace]) {\n throw new Error('Unknown color space: ' + parameters.colorSpace);\n }\n var innerFun;\n var hashedStops;\n var categoricalKeyType;\n if (type === 'exponential') {\n innerFun = evaluateExponentialFunction;\n } else if (type === 'interval') {\n innerFun = evaluateIntervalFunction;\n } else if (type === 'categorical') {\n innerFun = evaluateCategoricalFunction;\n hashedStops = Object.create(null);\n for (var i = 0, list = parameters.stops; i < list.length; i += 1) {\n var stop = list[i];\n hashedStops[stop[0]] = stop[1];\n }\n categoricalKeyType = typeof parameters.stops[0][0];\n } else if (type === 'identity') {\n innerFun = evaluateIdentityFunction;\n } else {\n throw new Error('Unknown function type \"' + type + '\"');\n }\n if (zoomAndFeatureDependent) {\n var featureFunctions = {};\n var zoomStops = [];\n for (var s = 0; s < parameters.stops.length; s++) {\n var stop$1 = parameters.stops[s];\n var zoom = stop$1[0].zoom;\n if (featureFunctions[zoom] === undefined) {\n featureFunctions[zoom] = {\n zoom: zoom,\n type: parameters.type,\n property: parameters.property,\n default: parameters.default,\n stops: []\n };\n zoomStops.push(zoom);\n }\n featureFunctions[zoom].stops.push([\n stop$1[0].value,\n stop$1[1]\n ]);\n }\n var featureFunctionStops = [];\n for (var i$1 = 0, list$1 = zoomStops; i$1 < list$1.length; i$1 += 1) {\n var z = list$1[i$1];\n featureFunctionStops.push([\n featureFunctions[z].zoom,\n createFunction(featureFunctions[z], propertySpec)\n ]);\n }\n var interpolationType = { name: 'linear' };\n return {\n kind: 'composite',\n interpolationType: interpolationType,\n interpolationFactor: Interpolate.interpolationFactor.bind(undefined, interpolationType),\n zoomStops: featureFunctionStops.map(function (s) {\n return s[0];\n }),\n evaluate: function evaluate(ref, properties) {\n var zoom = ref.zoom;\n return evaluateExponentialFunction({\n stops: featureFunctionStops,\n base: parameters.base\n }, propertySpec, zoom).evaluate(zoom, properties);\n }\n };\n } else if (zoomDependent) {\n var interpolationType$1 = type === 'exponential' ? {\n name: 'exponential',\n base: parameters.base !== undefined ? parameters.base : 1\n } : null;\n return {\n kind: 'camera',\n interpolationType: interpolationType$1,\n interpolationFactor: Interpolate.interpolationFactor.bind(undefined, interpolationType$1),\n zoomStops: parameters.stops.map(function (s) {\n return s[0];\n }),\n evaluate: function (ref) {\n var zoom = ref.zoom;\n return innerFun(parameters, propertySpec, zoom, hashedStops, categoricalKeyType);\n }\n };\n } else {\n return {\n kind: 'source',\n evaluate: function evaluate(_, feature) {\n var value = feature && feature.properties ? feature.properties[parameters.property] : undefined;\n if (value === undefined) {\n return coalesce(parameters.default, propertySpec.default);\n }\n return innerFun(parameters, propertySpec, value, hashedStops, categoricalKeyType);\n }\n };\n }\n}\nfunction coalesce(a, b, c) {\n if (a !== undefined) {\n return a;\n }\n if (b !== undefined) {\n return b;\n }\n if (c !== undefined) {\n return c;\n }\n}\nfunction evaluateCategoricalFunction(parameters, propertySpec, input, hashedStops, keyType) {\n var evaluated = typeof input === keyType ? hashedStops[input] : undefined;\n return coalesce(evaluated, parameters.default, propertySpec.default);\n}\nfunction evaluateIntervalFunction(parameters, propertySpec, input) {\n if (getType(input) !== 'number') {\n return coalesce(parameters.default, propertySpec.default);\n }\n var n = parameters.stops.length;\n if (n === 1) {\n return parameters.stops[0][1];\n }\n if (input <= parameters.stops[0][0]) {\n return parameters.stops[0][1];\n }\n if (input >= parameters.stops[n - 1][0]) {\n return parameters.stops[n - 1][1];\n }\n var index = findStopLessThanOrEqualTo(parameters.stops.map(function (stop) {\n return stop[0];\n }), input);\n return parameters.stops[index][1];\n}\nfunction evaluateExponentialFunction(parameters, propertySpec, input) {\n var base = parameters.base !== undefined ? parameters.base : 1;\n if (getType(input) !== 'number') {\n return coalesce(parameters.default, propertySpec.default);\n }\n var n = parameters.stops.length;\n if (n === 1) {\n return parameters.stops[0][1];\n }\n if (input <= parameters.stops[0][0]) {\n return parameters.stops[0][1];\n }\n if (input >= parameters.stops[n - 1][0]) {\n return parameters.stops[n - 1][1];\n }\n var index = findStopLessThanOrEqualTo(parameters.stops.map(function (stop) {\n return stop[0];\n }), input);\n var t = interpolationFactor(input, base, parameters.stops[index][0], parameters.stops[index + 1][0]);\n var outputLower = parameters.stops[index][1];\n var outputUpper = parameters.stops[index + 1][1];\n var interp = interpolate[propertySpec.type] || identityFunction;\n if (parameters.colorSpace && parameters.colorSpace !== 'rgb') {\n var colorspace = colorSpaces[parameters.colorSpace];\n interp = function (a, b) {\n return colorspace.reverse(colorspace.interpolate(colorspace.forward(a), colorspace.forward(b), t));\n };\n }\n if (typeof outputLower.evaluate === 'function') {\n return {\n evaluate: function evaluate() {\n var args = [], len = arguments.length;\n while (len--)\n args[len] = arguments[len];\n var evaluatedLower = outputLower.evaluate.apply(undefined, args);\n var evaluatedUpper = outputUpper.evaluate.apply(undefined, args);\n if (evaluatedLower === undefined || evaluatedUpper === undefined) {\n return undefined;\n }\n return interp(evaluatedLower, evaluatedUpper, t);\n }\n };\n }\n return interp(outputLower, outputUpper, t);\n}\nfunction evaluateIdentityFunction(parameters, propertySpec, input) {\n if (propertySpec.type === 'color') {\n input = Color.parse(input);\n } else if (propertySpec.type === 'formatted') {\n input = Formatted.fromString(input.toString());\n } else if (propertySpec.type === 'resolvedImage') {\n input = ResolvedImage.fromString(input.toString());\n } else if (getType(input) !== propertySpec.type && (propertySpec.type !== 'enum' || !propertySpec.values[input])) {\n input = undefined;\n }\n return coalesce(input, parameters.default, propertySpec.default);\n}\nfunction interpolationFactor(input, base, lowerValue, upperValue) {\n var difference = upperValue - lowerValue;\n var progress = input - lowerValue;\n if (difference === 0) {\n return 0;\n } else if (base === 1) {\n return progress / difference;\n } else {\n return (Math.pow(base, progress) - 1) / (Math.pow(base, difference) - 1);\n }\n}\n\nvar StyleExpression = function StyleExpression(expression, propertySpec) {\n this.expression = expression;\n this._warningHistory = {};\n this._evaluator = new EvaluationContext();\n this._defaultValue = propertySpec ? getDefaultValue(propertySpec) : null;\n this._enumValues = propertySpec && propertySpec.type === 'enum' ? propertySpec.values : null;\n};\nStyleExpression.prototype.evaluateWithoutErrorHandling = function evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection) {\n this._evaluator.globals = globals;\n this._evaluator.feature = feature;\n this._evaluator.featureState = featureState;\n this._evaluator.canonical = canonical;\n this._evaluator.availableImages = availableImages || null;\n this._evaluator.formattedSection = formattedSection;\n return this.expression.evaluate(this._evaluator);\n};\nStyleExpression.prototype.evaluate = function evaluate(globals, feature, featureState, canonical, availableImages, formattedSection) {\n this._evaluator.globals = globals;\n this._evaluator.feature = feature || null;\n this._evaluator.featureState = featureState || null;\n this._evaluator.canonical = canonical;\n this._evaluator.availableImages = availableImages || null;\n this._evaluator.formattedSection = formattedSection || null;\n try {\n var val = this.expression.evaluate(this._evaluator);\n if (val === null || val === undefined || typeof val === 'number' && val !== val) {\n return this._defaultValue;\n }\n if (this._enumValues && !(val in this._enumValues)) {\n throw new RuntimeError('Expected value to be one of ' + Object.keys(this._enumValues).map(function (v) {\n return JSON.stringify(v);\n }).join(', ') + ', but found ' + JSON.stringify(val) + ' instead.');\n }\n return val;\n } catch (e) {\n if (!this._warningHistory[e.message]) {\n this._warningHistory[e.message] = true;\n if (typeof console !== 'undefined') {\n console.warn(e.message);\n }\n }\n return this._defaultValue;\n }\n};\nfunction isExpression(expression) {\n return Array.isArray(expression) && expression.length > 0 && typeof expression[0] === 'string' && expression[0] in expressions;\n}\nfunction createExpression(expression, propertySpec) {\n var parser = new ParsingContext(expressions, [], propertySpec ? getExpectedType(propertySpec) : undefined);\n var parsed = parser.parse(expression, undefined, undefined, undefined, propertySpec && propertySpec.type === 'string' ? { typeAnnotation: 'coerce' } : undefined);\n if (!parsed) {\n return error(parser.errors);\n }\n return success(new StyleExpression(parsed, propertySpec));\n}\nvar ZoomConstantExpression = function ZoomConstantExpression(kind, expression) {\n this.kind = kind;\n this._styleExpression = expression;\n this.isStateDependent = kind !== 'constant' && !isStateConstant(expression.expression);\n};\nZoomConstantExpression.prototype.evaluateWithoutErrorHandling = function evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection) {\n return this._styleExpression.evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection);\n};\nZoomConstantExpression.prototype.evaluate = function evaluate(globals, feature, featureState, canonical, availableImages, formattedSection) {\n return this._styleExpression.evaluate(globals, feature, featureState, canonical, availableImages, formattedSection);\n};\nvar ZoomDependentExpression = function ZoomDependentExpression(kind, expression, zoomStops, interpolationType) {\n this.kind = kind;\n this.zoomStops = zoomStops;\n this._styleExpression = expression;\n this.isStateDependent = kind !== 'camera' && !isStateConstant(expression.expression);\n this.interpolationType = interpolationType;\n};\nZoomDependentExpression.prototype.evaluateWithoutErrorHandling = function evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection) {\n return this._styleExpression.evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection);\n};\nZoomDependentExpression.prototype.evaluate = function evaluate(globals, feature, featureState, canonical, availableImages, formattedSection) {\n return this._styleExpression.evaluate(globals, feature, featureState, canonical, availableImages, formattedSection);\n};\nZoomDependentExpression.prototype.interpolationFactor = function interpolationFactor(input, lower, upper) {\n if (this.interpolationType) {\n return Interpolate.interpolationFactor(this.interpolationType, input, lower, upper);\n } else {\n return 0;\n }\n};\nfunction createPropertyExpression(expression, propertySpec) {\n expression = createExpression(expression, propertySpec);\n if (expression.result === 'error') {\n return expression;\n }\n var parsed = expression.value.expression;\n var isFeatureConstant$1 = isFeatureConstant(parsed);\n if (!isFeatureConstant$1 && !supportsPropertyExpression(propertySpec)) {\n return error([new ParsingError('', 'data expressions not supported')]);\n }\n var isZoomConstant = isGlobalPropertyConstant(parsed, ['zoom']);\n if (!isZoomConstant && !supportsZoomExpression(propertySpec)) {\n return error([new ParsingError('', 'zoom expressions not supported')]);\n }\n var zoomCurve = findZoomCurve(parsed);\n if (!zoomCurve && !isZoomConstant) {\n return error([new ParsingError('', '\"zoom\" expression may only be used as input to a top-level \"step\" or \"interpolate\" expression.')]);\n } else if (zoomCurve instanceof ParsingError) {\n return error([zoomCurve]);\n } else if (zoomCurve instanceof Interpolate && !supportsInterpolation(propertySpec)) {\n return error([new ParsingError('', '\"interpolate\" expressions cannot be used with this property')]);\n }\n if (!zoomCurve) {\n return success(isFeatureConstant$1 ? new ZoomConstantExpression('constant', expression.value) : new ZoomConstantExpression('source', expression.value));\n }\n var interpolationType = zoomCurve instanceof Interpolate ? zoomCurve.interpolation : undefined;\n return success(isFeatureConstant$1 ? new ZoomDependentExpression('camera', expression.value, zoomCurve.labels, interpolationType) : new ZoomDependentExpression('composite', expression.value, zoomCurve.labels, interpolationType));\n}\nvar StylePropertyFunction = function StylePropertyFunction(parameters, specification) {\n this._parameters = parameters;\n this._specification = specification;\n extend$1(this, createFunction(this._parameters, this._specification));\n};\nStylePropertyFunction.deserialize = function deserialize(serialized) {\n return new StylePropertyFunction(serialized._parameters, serialized._specification);\n};\nStylePropertyFunction.serialize = function serialize(input) {\n return {\n _parameters: input._parameters,\n _specification: input._specification\n };\n};\nfunction normalizePropertyExpression(value, specification) {\n if (isFunction(value)) {\n return new StylePropertyFunction(value, specification);\n } else if (isExpression(value)) {\n var expression = createPropertyExpression(value, specification);\n if (expression.result === 'error') {\n throw new Error(expression.value.map(function (err) {\n return err.key + ': ' + err.message;\n }).join(', '));\n }\n return expression.value;\n } else {\n var constant = value;\n if (typeof value === 'string' && specification.type === 'color') {\n constant = Color.parse(value);\n }\n return {\n kind: 'constant',\n evaluate: function () {\n return constant;\n }\n };\n }\n}\nfunction findZoomCurve(expression) {\n var result = null;\n if (expression instanceof Let) {\n result = findZoomCurve(expression.result);\n } else if (expression instanceof Coalesce) {\n for (var i = 0, list = expression.args; i < list.length; i += 1) {\n var arg = list[i];\n result = findZoomCurve(arg);\n if (result) {\n break;\n }\n }\n } else if ((expression instanceof Step || expression instanceof Interpolate) && expression.input instanceof CompoundExpression && expression.input.name === 'zoom') {\n result = expression;\n }\n if (result instanceof ParsingError) {\n return result;\n }\n expression.eachChild(function (child) {\n var childResult = findZoomCurve(child);\n if (childResult instanceof ParsingError) {\n result = childResult;\n } else if (!result && childResult) {\n result = new ParsingError('', '\"zoom\" expression may only be used as input to a top-level \"step\" or \"interpolate\" expression.');\n } else if (result && childResult && result !== childResult) {\n result = new ParsingError('', 'Only one zoom-based \"step\" or \"interpolate\" subexpression may be used in an expression.');\n }\n });\n return result;\n}\nfunction getExpectedType(spec) {\n var types = {\n color: ColorType,\n string: StringType,\n number: NumberType,\n enum: StringType,\n boolean: BooleanType,\n formatted: FormattedType,\n resolvedImage: ResolvedImageType\n };\n if (spec.type === 'array') {\n return array(types[spec.value] || ValueType, spec.length);\n }\n return types[spec.type];\n}\nfunction getDefaultValue(spec) {\n if (spec.type === 'color' && isFunction(spec.default)) {\n return new Color(0, 0, 0, 0);\n } else if (spec.type === 'color') {\n return Color.parse(spec.default) || null;\n } else if (spec.default === undefined) {\n return null;\n } else {\n return spec.default;\n }\n}\n\nfunction validateObject(options) {\n var key = options.key;\n var object = options.value;\n var elementSpecs = options.valueSpec || {};\n var elementValidators = options.objectElementValidators || {};\n var style = options.style;\n var styleSpec = options.styleSpec;\n var errors = [];\n var type = getType(object);\n if (type !== 'object') {\n return [new ValidationError(key, object, 'object expected, ' + type + ' found')];\n }\n for (var objectKey in object) {\n var elementSpecKey = objectKey.split('.')[0];\n var elementSpec = elementSpecs[elementSpecKey] || elementSpecs['*'];\n var validateElement = void 0;\n if (elementValidators[elementSpecKey]) {\n validateElement = elementValidators[elementSpecKey];\n } else if (elementSpecs[elementSpecKey]) {\n validateElement = validate;\n } else if (elementValidators['*']) {\n validateElement = elementValidators['*'];\n } else if (elementSpecs['*']) {\n validateElement = validate;\n } else {\n errors.push(new ValidationError(key, object[objectKey], 'unknown property \"' + objectKey + '\"'));\n continue;\n }\n errors = errors.concat(validateElement({\n key: (key ? key + '.' : key) + objectKey,\n value: object[objectKey],\n valueSpec: elementSpec,\n style: style,\n styleSpec: styleSpec,\n object: object,\n objectKey: objectKey\n }, object));\n }\n for (var elementSpecKey$1 in elementSpecs) {\n if (elementValidators[elementSpecKey$1]) {\n continue;\n }\n if (elementSpecs[elementSpecKey$1].required && elementSpecs[elementSpecKey$1]['default'] === undefined && object[elementSpecKey$1] === undefined) {\n errors.push(new ValidationError(key, object, 'missing required property \"' + elementSpecKey$1 + '\"'));\n }\n }\n return errors;\n}\n\nfunction validateArray(options) {\n var array = options.value;\n var arraySpec = options.valueSpec;\n var style = options.style;\n var styleSpec = options.styleSpec;\n var key = options.key;\n var validateArrayElement = options.arrayElementValidator || validate;\n if (getType(array) !== 'array') {\n return [new ValidationError(key, array, 'array expected, ' + getType(array) + ' found')];\n }\n if (arraySpec.length && array.length !== arraySpec.length) {\n return [new ValidationError(key, array, 'array length ' + arraySpec.length + ' expected, length ' + array.length + ' found')];\n }\n if (arraySpec['min-length'] && array.length < arraySpec['min-length']) {\n return [new ValidationError(key, array, 'array length at least ' + arraySpec['min-length'] + ' expected, length ' + array.length + ' found')];\n }\n var arrayElementSpec = {\n 'type': arraySpec.value,\n 'values': arraySpec.values\n };\n if (styleSpec.$version < 7) {\n arrayElementSpec.function = arraySpec.function;\n }\n if (getType(arraySpec.value) === 'object') {\n arrayElementSpec = arraySpec.value;\n }\n var errors = [];\n for (var i = 0; i < array.length; i++) {\n errors = errors.concat(validateArrayElement({\n array: array,\n arrayIndex: i,\n value: array[i],\n valueSpec: arrayElementSpec,\n style: style,\n styleSpec: styleSpec,\n key: key + '[' + i + ']'\n }));\n }\n return errors;\n}\n\nfunction validateNumber(options) {\n var key = options.key;\n var value = options.value;\n var valueSpec = options.valueSpec;\n var type = getType(value);\n if (type === 'number' && value !== value) {\n type = 'NaN';\n }\n if (type !== 'number') {\n return [new ValidationError(key, value, 'number expected, ' + type + ' found')];\n }\n if ('minimum' in valueSpec && value < valueSpec.minimum) {\n return [new ValidationError(key, value, value + ' is less than the minimum value ' + valueSpec.minimum)];\n }\n if ('maximum' in valueSpec && value > valueSpec.maximum) {\n return [new ValidationError(key, value, value + ' is greater than the maximum value ' + valueSpec.maximum)];\n }\n return [];\n}\n\nfunction validateFunction(options) {\n var functionValueSpec = options.valueSpec;\n var functionType = unbundle(options.value.type);\n var stopKeyType;\n var stopDomainValues = {};\n var previousStopDomainValue;\n var previousStopDomainZoom;\n var isZoomFunction = functionType !== 'categorical' && options.value.property === undefined;\n var isPropertyFunction = !isZoomFunction;\n var isZoomAndPropertyFunction = getType(options.value.stops) === 'array' && getType(options.value.stops[0]) === 'array' && getType(options.value.stops[0][0]) === 'object';\n var errors = validateObject({\n key: options.key,\n value: options.value,\n valueSpec: options.styleSpec.function,\n style: options.style,\n styleSpec: options.styleSpec,\n objectElementValidators: {\n stops: validateFunctionStops,\n default: validateFunctionDefault\n }\n });\n if (functionType === 'identity' && isZoomFunction) {\n errors.push(new ValidationError(options.key, options.value, 'missing required property \"property\"'));\n }\n if (functionType !== 'identity' && !options.value.stops) {\n errors.push(new ValidationError(options.key, options.value, 'missing required property \"stops\"'));\n }\n if (functionType === 'exponential' && options.valueSpec.expression && !supportsInterpolation(options.valueSpec)) {\n errors.push(new ValidationError(options.key, options.value, 'exponential functions not supported'));\n }\n if (options.styleSpec.$version >= 8) {\n if (isPropertyFunction && !supportsPropertyExpression(options.valueSpec)) {\n errors.push(new ValidationError(options.key, options.value, 'property functions not supported'));\n } else if (isZoomFunction && !supportsZoomExpression(options.valueSpec)) {\n errors.push(new ValidationError(options.key, options.value, 'zoom functions not supported'));\n }\n }\n if ((functionType === 'categorical' || isZoomAndPropertyFunction) && options.value.property === undefined) {\n errors.push(new ValidationError(options.key, options.value, '\"property\" property is required'));\n }\n return errors;\n function validateFunctionStops(options) {\n if (functionType === 'identity') {\n return [new ValidationError(options.key, options.value, 'identity function may not have a \"stops\" property')];\n }\n var errors = [];\n var value = options.value;\n errors = errors.concat(validateArray({\n key: options.key,\n value: value,\n valueSpec: options.valueSpec,\n style: options.style,\n styleSpec: options.styleSpec,\n arrayElementValidator: validateFunctionStop\n }));\n if (getType(value) === 'array' && value.length === 0) {\n errors.push(new ValidationError(options.key, value, 'array must have at least one stop'));\n }\n return errors;\n }\n function validateFunctionStop(options) {\n var errors = [];\n var value = options.value;\n var key = options.key;\n if (getType(value) !== 'array') {\n return [new ValidationError(key, value, 'array expected, ' + getType(value) + ' found')];\n }\n if (value.length !== 2) {\n return [new ValidationError(key, value, 'array length 2 expected, length ' + value.length + ' found')];\n }\n if (isZoomAndPropertyFunction) {\n if (getType(value[0]) !== 'object') {\n return [new ValidationError(key, value, 'object expected, ' + getType(value[0]) + ' found')];\n }\n if (value[0].zoom === undefined) {\n return [new ValidationError(key, value, 'object stop key must have zoom')];\n }\n if (value[0].value === undefined) {\n return [new ValidationError(key, value, 'object stop key must have value')];\n }\n if (previousStopDomainZoom && previousStopDomainZoom > unbundle(value[0].zoom)) {\n return [new ValidationError(key, value[0].zoom, 'stop zoom values must appear in ascending order')];\n }\n if (unbundle(value[0].zoom) !== previousStopDomainZoom) {\n previousStopDomainZoom = unbundle(value[0].zoom);\n previousStopDomainValue = undefined;\n stopDomainValues = {};\n }\n errors = errors.concat(validateObject({\n key: key + '[0]',\n value: value[0],\n valueSpec: { zoom: {} },\n style: options.style,\n styleSpec: options.styleSpec,\n objectElementValidators: {\n zoom: validateNumber,\n value: validateStopDomainValue\n }\n }));\n } else {\n errors = errors.concat(validateStopDomainValue({\n key: key + '[0]',\n value: value[0],\n valueSpec: {},\n style: options.style,\n styleSpec: options.styleSpec\n }, value));\n }\n if (isExpression(deepUnbundle(value[1]))) {\n return errors.concat([new ValidationError(key + '[1]', value[1], 'expressions are not allowed in function stops.')]);\n }\n return errors.concat(validate({\n key: key + '[1]',\n value: value[1],\n valueSpec: functionValueSpec,\n style: options.style,\n styleSpec: options.styleSpec\n }));\n }\n function validateStopDomainValue(options, stop) {\n var type = getType(options.value);\n var value = unbundle(options.value);\n var reportValue = options.value !== null ? options.value : stop;\n if (!stopKeyType) {\n stopKeyType = type;\n } else if (type !== stopKeyType) {\n return [new ValidationError(options.key, reportValue, type + ' stop domain type must match previous stop domain type ' + stopKeyType)];\n }\n if (type !== 'number' && type !== 'string' && type !== 'boolean') {\n return [new ValidationError(options.key, reportValue, 'stop domain value must be a number, string, or boolean')];\n }\n if (type !== 'number' && functionType !== 'categorical') {\n var message = 'number expected, ' + type + ' found';\n if (supportsPropertyExpression(functionValueSpec) && functionType === undefined) {\n message += '\\nIf you intended to use a categorical function, specify `\"type\": \"categorical\"`.';\n }\n return [new ValidationError(options.key, reportValue, message)];\n }\n if (functionType === 'categorical' && type === 'number' && (!isFinite(value) || Math.floor(value) !== value)) {\n return [new ValidationError(options.key, reportValue, 'integer expected, found ' + value)];\n }\n if (functionType !== 'categorical' && type === 'number' && previousStopDomainValue !== undefined && value < previousStopDomainValue) {\n return [new ValidationError(options.key, reportValue, 'stop domain values must appear in ascending order')];\n } else {\n previousStopDomainValue = value;\n }\n if (functionType === 'categorical' && value in stopDomainValues) {\n return [new ValidationError(options.key, reportValue, 'stop domain values must be unique')];\n } else {\n stopDomainValues[value] = true;\n }\n return [];\n }\n function validateFunctionDefault(options) {\n return validate({\n key: options.key,\n value: options.value,\n valueSpec: functionValueSpec,\n style: options.style,\n styleSpec: options.styleSpec\n });\n }\n}\n\nfunction validateExpression(options) {\n var expression = (options.expressionContext === 'property' ? createPropertyExpression : createExpression)(deepUnbundle(options.value), options.valueSpec);\n if (expression.result === 'error') {\n return expression.value.map(function (error) {\n return new ValidationError('' + options.key + error.key, options.value, error.message);\n });\n }\n var expressionObj = expression.value.expression || expression.value._styleExpression.expression;\n if (options.expressionContext === 'property' && options.propertyKey === 'text-font' && !expressionObj.outputDefined()) {\n return [new ValidationError(options.key, options.value, 'Invalid data expression for \"' + options.propertyKey + '\". Output values must be contained as literals within the expression.')];\n }\n if (options.expressionContext === 'property' && options.propertyType === 'layout' && !isStateConstant(expressionObj)) {\n return [new ValidationError(options.key, options.value, '\"feature-state\" data expressions are not supported with layout properties.')];\n }\n if (options.expressionContext === 'filter' && !isStateConstant(expressionObj)) {\n return [new ValidationError(options.key, options.value, '\"feature-state\" data expressions are not supported with filters.')];\n }\n if (options.expressionContext && options.expressionContext.indexOf('cluster') === 0) {\n if (!isGlobalPropertyConstant(expressionObj, [\n 'zoom',\n 'feature-state'\n ])) {\n return [new ValidationError(options.key, options.value, '\"zoom\" and \"feature-state\" expressions are not supported with cluster properties.')];\n }\n if (options.expressionContext === 'cluster-initial' && !isFeatureConstant(expressionObj)) {\n return [new ValidationError(options.key, options.value, 'Feature data expressions are not supported with initial expression part of cluster properties.')];\n }\n }\n return [];\n}\n\nfunction validateBoolean(options) {\n var value = options.value;\n var key = options.key;\n var type = getType(value);\n if (type !== 'boolean') {\n return [new ValidationError(key, value, 'boolean expected, ' + type + ' found')];\n }\n return [];\n}\n\nfunction validateColor(options) {\n var key = options.key;\n var value = options.value;\n var type = getType(value);\n if (type !== 'string') {\n return [new ValidationError(key, value, 'color expected, ' + type + ' found')];\n }\n if (csscolorparser_1(value) === null) {\n return [new ValidationError(key, value, 'color expected, \"' + value + '\" found')];\n }\n return [];\n}\n\nfunction validateEnum(options) {\n var key = options.key;\n var value = options.value;\n var valueSpec = options.valueSpec;\n var errors = [];\n if (Array.isArray(valueSpec.values)) {\n if (valueSpec.values.indexOf(unbundle(value)) === -1) {\n errors.push(new ValidationError(key, value, 'expected one of [' + valueSpec.values.join(', ') + '], ' + JSON.stringify(value) + ' found'));\n }\n } else {\n if (Object.keys(valueSpec.values).indexOf(unbundle(value)) === -1) {\n errors.push(new ValidationError(key, value, 'expected one of [' + Object.keys(valueSpec.values).join(', ') + '], ' + JSON.stringify(value) + ' found'));\n }\n }\n return errors;\n}\n\nfunction isExpressionFilter(filter) {\n if (filter === true || filter === false) {\n return true;\n }\n if (!Array.isArray(filter) || filter.length === 0) {\n return false;\n }\n switch (filter[0]) {\n case 'has':\n return filter.length >= 2 && filter[1] !== '$id' && filter[1] !== '$type';\n case 'in':\n return filter.length >= 3 && (typeof filter[1] !== 'string' || Array.isArray(filter[2]));\n case '!in':\n case '!has':\n case 'none':\n return false;\n case '==':\n case '!=':\n case '>':\n case '>=':\n case '<':\n case '<=':\n return filter.length !== 3 || (Array.isArray(filter[1]) || Array.isArray(filter[2]));\n case 'any':\n case 'all':\n for (var i = 0, list = filter.slice(1); i < list.length; i += 1) {\n var f = list[i];\n if (!isExpressionFilter(f) && typeof f !== 'boolean') {\n return false;\n }\n }\n return true;\n default:\n return true;\n }\n}\nvar filterSpec = {\n 'type': 'boolean',\n 'default': false,\n 'transition': false,\n 'property-type': 'data-driven',\n 'expression': {\n 'interpolated': false,\n 'parameters': [\n 'zoom',\n 'feature'\n ]\n }\n};\nfunction createFilter(filter) {\n if (filter === null || filter === undefined) {\n return {\n filter: function () {\n return true;\n },\n needGeometry: false\n };\n }\n if (!isExpressionFilter(filter)) {\n filter = convertFilter(filter);\n }\n var compiled = createExpression(filter, filterSpec);\n if (compiled.result === 'error') {\n throw new Error(compiled.value.map(function (err) {\n return err.key + ': ' + err.message;\n }).join(', '));\n } else {\n var needGeometry = geometryNeeded(filter);\n return {\n filter: function (globalProperties, feature, canonical) {\n return compiled.value.evaluate(globalProperties, feature, {}, canonical);\n },\n needGeometry: needGeometry\n };\n }\n}\nfunction compare(a, b) {\n return a < b ? -1 : a > b ? 1 : 0;\n}\nfunction geometryNeeded(filter) {\n if (!Array.isArray(filter)) {\n return false;\n }\n if (filter[0] === 'within') {\n return true;\n }\n for (var index = 1; index < filter.length; index++) {\n if (geometryNeeded(filter[index])) {\n return true;\n }\n }\n return false;\n}\nfunction convertFilter(filter) {\n if (!filter) {\n return true;\n }\n var op = filter[0];\n if (filter.length <= 1) {\n return op !== 'any';\n }\n var converted = op === '==' ? convertComparisonOp(filter[1], filter[2], '==') : op === '!=' ? convertNegation(convertComparisonOp(filter[1], filter[2], '==')) : op === '<' || op === '>' || op === '<=' || op === '>=' ? convertComparisonOp(filter[1], filter[2], op) : op === 'any' ? convertDisjunctionOp(filter.slice(1)) : op === 'all' ? ['all'].concat(filter.slice(1).map(convertFilter)) : op === 'none' ? ['all'].concat(filter.slice(1).map(convertFilter).map(convertNegation)) : op === 'in' ? convertInOp(filter[1], filter.slice(2)) : op === '!in' ? convertNegation(convertInOp(filter[1], filter.slice(2))) : op === 'has' ? convertHasOp(filter[1]) : op === '!has' ? convertNegation(convertHasOp(filter[1])) : op === 'within' ? filter : true;\n return converted;\n}\nfunction convertComparisonOp(property, value, op) {\n switch (property) {\n case '$type':\n return [\n 'filter-type-' + op,\n value\n ];\n case '$id':\n return [\n 'filter-id-' + op,\n value\n ];\n default:\n return [\n 'filter-' + op,\n property,\n value\n ];\n }\n}\nfunction convertDisjunctionOp(filters) {\n return ['any'].concat(filters.map(convertFilter));\n}\nfunction convertInOp(property, values) {\n if (values.length === 0) {\n return false;\n }\n switch (property) {\n case '$type':\n return [\n 'filter-type-in',\n [\n 'literal',\n values\n ]\n ];\n case '$id':\n return [\n 'filter-id-in',\n [\n 'literal',\n values\n ]\n ];\n default:\n if (values.length > 200 && !values.some(function (v) {\n return typeof v !== typeof values[0];\n })) {\n return [\n 'filter-in-large',\n property,\n [\n 'literal',\n values.sort(compare)\n ]\n ];\n } else {\n return [\n 'filter-in-small',\n property,\n [\n 'literal',\n values\n ]\n ];\n }\n }\n}\nfunction convertHasOp(property) {\n switch (property) {\n case '$type':\n return true;\n case '$id':\n return ['filter-has-id'];\n default:\n return [\n 'filter-has',\n property\n ];\n }\n}\nfunction convertNegation(filter) {\n return [\n '!',\n filter\n ];\n}\n\nfunction validateFilter(options) {\n if (isExpressionFilter(deepUnbundle(options.value))) {\n return validateExpression(extend$1({}, options, {\n expressionContext: 'filter',\n valueSpec: { value: 'boolean' }\n }));\n } else {\n return validateNonExpressionFilter(options);\n }\n}\nfunction validateNonExpressionFilter(options) {\n var value = options.value;\n var key = options.key;\n if (getType(value) !== 'array') {\n return [new ValidationError(key, value, 'array expected, ' + getType(value) + ' found')];\n }\n var styleSpec = options.styleSpec;\n var type;\n var errors = [];\n if (value.length < 1) {\n return [new ValidationError(key, value, 'filter array must have at least 1 element')];\n }\n errors = errors.concat(validateEnum({\n key: key + '[0]',\n value: value[0],\n valueSpec: styleSpec.filter_operator,\n style: options.style,\n styleSpec: options.styleSpec\n }));\n switch (unbundle(value[0])) {\n case '<':\n case '<=':\n case '>':\n case '>=':\n if (value.length >= 2 && unbundle(value[1]) === '$type') {\n errors.push(new ValidationError(key, value, '\"$type\" cannot be use with operator \"' + value[0] + '\"'));\n }\n case '==':\n case '!=':\n if (value.length !== 3) {\n errors.push(new ValidationError(key, value, 'filter array for operator \"' + value[0] + '\" must have 3 elements'));\n }\n case 'in':\n case '!in':\n if (value.length >= 2) {\n type = getType(value[1]);\n if (type !== 'string') {\n errors.push(new ValidationError(key + '[1]', value[1], 'string expected, ' + type + ' found'));\n }\n }\n for (var i = 2; i < value.length; i++) {\n type = getType(value[i]);\n if (unbundle(value[1]) === '$type') {\n errors = errors.concat(validateEnum({\n key: key + '[' + i + ']',\n value: value[i],\n valueSpec: styleSpec.geometry_type,\n style: options.style,\n styleSpec: options.styleSpec\n }));\n } else if (type !== 'string' && type !== 'number' && type !== 'boolean') {\n errors.push(new ValidationError(key + '[' + i + ']', value[i], 'string, number, or boolean expected, ' + type + ' found'));\n }\n }\n break;\n case 'any':\n case 'all':\n case 'none':\n for (var i$1 = 1; i$1 < value.length; i$1++) {\n errors = errors.concat(validateNonExpressionFilter({\n key: key + '[' + i$1 + ']',\n value: value[i$1],\n style: options.style,\n styleSpec: options.styleSpec\n }));\n }\n break;\n case 'has':\n case '!has':\n type = getType(value[1]);\n if (value.length !== 2) {\n errors.push(new ValidationError(key, value, 'filter array for \"' + value[0] + '\" operator must have 2 elements'));\n } else if (type !== 'string') {\n errors.push(new ValidationError(key + '[1]', value[1], 'string expected, ' + type + ' found'));\n }\n break;\n case 'within':\n type = getType(value[1]);\n if (value.length !== 2) {\n errors.push(new ValidationError(key, value, 'filter array for \"' + value[0] + '\" operator must have 2 elements'));\n } else if (type !== 'object') {\n errors.push(new ValidationError(key + '[1]', value[1], 'object expected, ' + type + ' found'));\n }\n break;\n }\n return errors;\n}\n\nfunction validateProperty(options, propertyType) {\n var key = options.key;\n var style = options.style;\n var styleSpec = options.styleSpec;\n var value = options.value;\n var propertyKey = options.objectKey;\n var layerSpec = styleSpec[propertyType + '_' + options.layerType];\n if (!layerSpec) {\n return [];\n }\n var transitionMatch = propertyKey.match(/^(.*)-transition$/);\n if (propertyType === 'paint' && transitionMatch && layerSpec[transitionMatch[1]] && layerSpec[transitionMatch[1]].transition) {\n return validate({\n key: key,\n value: value,\n valueSpec: styleSpec.transition,\n style: style,\n styleSpec: styleSpec\n });\n }\n var valueSpec = options.valueSpec || layerSpec[propertyKey];\n if (!valueSpec) {\n return [new ValidationError(key, value, 'unknown property \"' + propertyKey + '\"')];\n }\n var tokenMatch;\n if (getType(value) === 'string' && supportsPropertyExpression(valueSpec) && !valueSpec.tokens && (tokenMatch = /^{([^}]+)}$/.exec(value))) {\n return [new ValidationError(key, value, '\"' + propertyKey + '\" does not support interpolation syntax\\n' + 'Use an identity property function instead: `{ \"type\": \"identity\", \"property\": ' + JSON.stringify(tokenMatch[1]) + ' }`.')];\n }\n var errors = [];\n if (options.layerType === 'symbol') {\n if (propertyKey === 'text-field' && style && !style.glyphs) {\n errors.push(new ValidationError(key, value, 'use of \"text-field\" requires a style \"glyphs\" property'));\n }\n if (propertyKey === 'text-font' && isFunction(deepUnbundle(value)) && unbundle(value.type) === 'identity') {\n errors.push(new ValidationError(key, value, '\"text-font\" does not support identity functions'));\n }\n }\n return errors.concat(validate({\n key: options.key,\n value: value,\n valueSpec: valueSpec,\n style: style,\n styleSpec: styleSpec,\n expressionContext: 'property',\n propertyType: propertyType,\n propertyKey: propertyKey\n }));\n}\n\nfunction validatePaintProperty(options) {\n return validateProperty(options, 'paint');\n}\n\nfunction validateLayoutProperty(options) {\n return validateProperty(options, 'layout');\n}\n\nfunction validateLayer(options) {\n var errors = [];\n var layer = options.value;\n var key = options.key;\n var style = options.style;\n var styleSpec = options.styleSpec;\n if (!layer.type && !layer.ref) {\n errors.push(new ValidationError(key, layer, 'either \"type\" or \"ref\" is required'));\n }\n var type = unbundle(layer.type);\n var ref = unbundle(layer.ref);\n if (layer.id) {\n var layerId = unbundle(layer.id);\n for (var i = 0; i < options.arrayIndex; i++) {\n var otherLayer = style.layers[i];\n if (unbundle(otherLayer.id) === layerId) {\n errors.push(new ValidationError(key, layer.id, 'duplicate layer id \"' + layer.id + '\", previously used at line ' + otherLayer.id.__line__));\n }\n }\n }\n if ('ref' in layer) {\n [\n 'type',\n 'source',\n 'source-layer',\n 'filter',\n 'layout'\n ].forEach(function (p) {\n if (p in layer) {\n errors.push(new ValidationError(key, layer[p], '\"' + p + '\" is prohibited for ref layers'));\n }\n });\n var parent;\n style.layers.forEach(function (layer) {\n if (unbundle(layer.id) === ref) {\n parent = layer;\n }\n });\n if (!parent) {\n errors.push(new ValidationError(key, layer.ref, 'ref layer \"' + ref + '\" not found'));\n } else if (parent.ref) {\n errors.push(new ValidationError(key, layer.ref, 'ref cannot reference another ref layer'));\n } else {\n type = unbundle(parent.type);\n }\n } else if (type !== 'background') {\n if (!layer.source) {\n errors.push(new ValidationError(key, layer, 'missing required property \"source\"'));\n } else {\n var source = style.sources && style.sources[layer.source];\n var sourceType = source && unbundle(source.type);\n if (!source) {\n errors.push(new ValidationError(key, layer.source, 'source \"' + layer.source + '\" not found'));\n } else if (sourceType === 'vector' && type === 'raster') {\n errors.push(new ValidationError(key, layer.source, 'layer \"' + layer.id + '\" requires a raster source'));\n } else if (sourceType === 'raster' && type !== 'raster') {\n errors.push(new ValidationError(key, layer.source, 'layer \"' + layer.id + '\" requires a vector source'));\n } else if (sourceType === 'vector' && !layer['source-layer']) {\n errors.push(new ValidationError(key, layer, 'layer \"' + layer.id + '\" must specify a \"source-layer\"'));\n } else if (sourceType === 'raster-dem' && type !== 'hillshade') {\n errors.push(new ValidationError(key, layer.source, 'raster-dem source can only be used with layer type \\'hillshade\\'.'));\n } else if (type === 'line' && layer.paint && layer.paint['line-gradient'] && (sourceType !== 'geojson' || !source.lineMetrics)) {\n errors.push(new ValidationError(key, layer, 'layer \"' + layer.id + '\" specifies a line-gradient, which requires a GeoJSON source with `lineMetrics` enabled.'));\n }\n }\n }\n errors = errors.concat(validateObject({\n key: key,\n value: layer,\n valueSpec: styleSpec.layer,\n style: options.style,\n styleSpec: options.styleSpec,\n objectElementValidators: {\n '*': function _() {\n return [];\n },\n type: function type() {\n return validate({\n key: key + '.type',\n value: layer.type,\n valueSpec: styleSpec.layer.type,\n style: options.style,\n styleSpec: options.styleSpec,\n object: layer,\n objectKey: 'type'\n });\n },\n filter: validateFilter,\n layout: function layout(options) {\n return validateObject({\n layer: layer,\n key: options.key,\n value: options.value,\n style: options.style,\n styleSpec: options.styleSpec,\n objectElementValidators: {\n '*': function _(options) {\n return validateLayoutProperty(extend$1({ layerType: type }, options));\n }\n }\n });\n },\n paint: function paint(options) {\n return validateObject({\n layer: layer,\n key: options.key,\n value: options.value,\n style: options.style,\n styleSpec: options.styleSpec,\n objectElementValidators: {\n '*': function _(options) {\n return validatePaintProperty(extend$1({ layerType: type }, options));\n }\n }\n });\n }\n }\n }));\n return errors;\n}\n\nfunction validateString(options) {\n var value = options.value;\n var key = options.key;\n var type = getType(value);\n if (type !== 'string') {\n return [new ValidationError(key, value, 'string expected, ' + type + ' found')];\n }\n return [];\n}\n\nvar objectElementValidators = { promoteId: validatePromoteId };\nfunction validateSource(options) {\n var value = options.value;\n var key = options.key;\n var styleSpec = options.styleSpec;\n var style = options.style;\n if (!value.type) {\n return [new ValidationError(key, value, '\"type\" is required')];\n }\n var type = unbundle(value.type);\n var errors;\n switch (type) {\n case 'vector':\n case 'raster':\n case 'raster-dem':\n errors = validateObject({\n key: key,\n value: value,\n valueSpec: styleSpec['source_' + type.replace('-', '_')],\n style: options.style,\n styleSpec: styleSpec,\n objectElementValidators: objectElementValidators\n });\n return errors;\n case 'geojson':\n errors = validateObject({\n key: key,\n value: value,\n valueSpec: styleSpec.source_geojson,\n style: style,\n styleSpec: styleSpec,\n objectElementValidators: objectElementValidators\n });\n if (value.cluster) {\n for (var prop in value.clusterProperties) {\n var ref = value.clusterProperties[prop];\n var operator = ref[0];\n var mapExpr = ref[1];\n var reduceExpr = typeof operator === 'string' ? [\n operator,\n ['accumulated'],\n [\n 'get',\n prop\n ]\n ] : operator;\n errors.push.apply(errors, validateExpression({\n key: key + '.' + prop + '.map',\n value: mapExpr,\n expressionContext: 'cluster-map'\n }));\n errors.push.apply(errors, validateExpression({\n key: key + '.' + prop + '.reduce',\n value: reduceExpr,\n expressionContext: 'cluster-reduce'\n }));\n }\n }\n return errors;\n case 'video':\n return validateObject({\n key: key,\n value: value,\n valueSpec: styleSpec.source_video,\n style: style,\n styleSpec: styleSpec\n });\n case 'image':\n return validateObject({\n key: key,\n value: value,\n valueSpec: styleSpec.source_image,\n style: style,\n styleSpec: styleSpec\n });\n case 'canvas':\n return [new ValidationError(key, null, 'Please use runtime APIs to add canvas sources, rather than including them in stylesheets.', 'source.canvas')];\n default:\n return validateEnum({\n key: key + '.type',\n value: value.type,\n valueSpec: {\n values: [\n 'vector',\n 'raster',\n 'raster-dem',\n 'geojson',\n 'video',\n 'image'\n ]\n },\n style: style,\n styleSpec: styleSpec\n });\n }\n}\nfunction validatePromoteId(ref) {\n var key = ref.key;\n var value = ref.value;\n if (getType(value) === 'string') {\n return validateString({\n key: key,\n value: value\n });\n } else {\n var errors = [];\n for (var prop in value) {\n errors.push.apply(errors, validateString({\n key: key + '.' + prop,\n value: value[prop]\n }));\n }\n return errors;\n }\n}\n\nfunction validateLight(options) {\n var light = options.value;\n var styleSpec = options.styleSpec;\n var lightSpec = styleSpec.light;\n var style = options.style;\n var errors = [];\n var rootType = getType(light);\n if (light === undefined) {\n return errors;\n } else if (rootType !== 'object') {\n errors = errors.concat([new ValidationError('light', light, 'object expected, ' + rootType + ' found')]);\n return errors;\n }\n for (var key in light) {\n var transitionMatch = key.match(/^(.*)-transition$/);\n if (transitionMatch && lightSpec[transitionMatch[1]] && lightSpec[transitionMatch[1]].transition) {\n errors = errors.concat(validate({\n key: key,\n value: light[key],\n valueSpec: styleSpec.transition,\n style: style,\n styleSpec: styleSpec\n }));\n } else if (lightSpec[key]) {\n errors = errors.concat(validate({\n key: key,\n value: light[key],\n valueSpec: lightSpec[key],\n style: style,\n styleSpec: styleSpec\n }));\n } else {\n errors = errors.concat([new ValidationError(key, light[key], 'unknown property \"' + key + '\"')]);\n }\n }\n return errors;\n}\n\nfunction validateFormatted(options) {\n if (validateString(options).length === 0) {\n return [];\n }\n return validateExpression(options);\n}\n\nfunction validateImage(options) {\n if (validateString(options).length === 0) {\n return [];\n }\n return validateExpression(options);\n}\n\nvar VALIDATORS = {\n '*': function _() {\n return [];\n },\n 'array': validateArray,\n 'boolean': validateBoolean,\n 'number': validateNumber,\n 'color': validateColor,\n 'constants': validateConstants,\n 'enum': validateEnum,\n 'filter': validateFilter,\n 'function': validateFunction,\n 'layer': validateLayer,\n 'object': validateObject,\n 'source': validateSource,\n 'light': validateLight,\n 'string': validateString,\n 'formatted': validateFormatted,\n 'resolvedImage': validateImage\n};\nfunction validate(options) {\n var value = options.value;\n var valueSpec = options.valueSpec;\n var styleSpec = options.styleSpec;\n if (valueSpec.expression && isFunction(unbundle(value))) {\n return validateFunction(options);\n } else if (valueSpec.expression && isExpression(deepUnbundle(value))) {\n return validateExpression(options);\n } else if (valueSpec.type && VALIDATORS[valueSpec.type]) {\n return VALIDATORS[valueSpec.type](options);\n } else {\n var valid = validateObject(extend$1({}, options, { valueSpec: valueSpec.type ? styleSpec[valueSpec.type] : valueSpec }));\n return valid;\n }\n}\n\nfunction validateGlyphsURL (options) {\n var value = options.value;\n var key = options.key;\n var errors = validateString(options);\n if (errors.length) {\n return errors;\n }\n if (value.indexOf('{fontstack}') === -1) {\n errors.push(new ValidationError(key, value, '\"glyphs\" url must include a \"{fontstack}\" token'));\n }\n if (value.indexOf('{range}') === -1) {\n errors.push(new ValidationError(key, value, '\"glyphs\" url must include a \"{range}\" token'));\n }\n return errors;\n}\n\nfunction validateStyleMin(style, styleSpec) {\n if (styleSpec === void 0)\n styleSpec = spec;\n var errors = [];\n errors = errors.concat(validate({\n key: '',\n value: style,\n valueSpec: styleSpec.$root,\n styleSpec: styleSpec,\n style: style,\n objectElementValidators: {\n glyphs: validateGlyphsURL,\n '*': function _() {\n return [];\n }\n }\n }));\n if (style.constants) {\n errors = errors.concat(validateConstants({\n key: 'constants',\n value: style.constants,\n style: style,\n styleSpec: styleSpec\n }));\n }\n return sortErrors(errors);\n}\nvalidateStyleMin.source = wrapCleanErrors(validateSource);\nvalidateStyleMin.light = wrapCleanErrors(validateLight);\nvalidateStyleMin.layer = wrapCleanErrors(validateLayer);\nvalidateStyleMin.filter = wrapCleanErrors(validateFilter);\nvalidateStyleMin.paintProperty = wrapCleanErrors(validatePaintProperty);\nvalidateStyleMin.layoutProperty = wrapCleanErrors(validateLayoutProperty);\nfunction sortErrors(errors) {\n return [].concat(errors).sort(function (a, b) {\n return a.line - b.line;\n });\n}\nfunction wrapCleanErrors(inner) {\n return function () {\n var args = [], len = arguments.length;\n while (len--)\n args[len] = arguments[len];\n return sortErrors(inner.apply(this, args));\n };\n}\n\nvar validateStyle = validateStyleMin;\nvar validateLight$1 = validateStyle.light;\nvar validatePaintProperty$1 = validateStyle.paintProperty;\nvar validateLayoutProperty$1 = validateStyle.layoutProperty;\nfunction emitValidationErrors(emitter, errors) {\n var hasErrors = false;\n if (errors && errors.length) {\n for (var i = 0, list = errors; i < list.length; i += 1) {\n var error = list[i];\n emitter.fire(new ErrorEvent(new Error(error.message)));\n hasErrors = true;\n }\n }\n return hasErrors;\n}\n\nvar gridIndex = GridIndex;\nvar NUM_PARAMS = 3;\nfunction GridIndex(extent, n, padding) {\n var cells = this.cells = [];\n if (extent instanceof ArrayBuffer) {\n this.arrayBuffer = extent;\n var array = new Int32Array(this.arrayBuffer);\n extent = array[0];\n n = array[1];\n padding = array[2];\n this.d = n + 2 * padding;\n for (var k = 0; k < this.d * this.d; k++) {\n var start = array[NUM_PARAMS + k];\n var end = array[NUM_PARAMS + k + 1];\n cells.push(start === end ? null : array.subarray(start, end));\n }\n var keysOffset = array[NUM_PARAMS + cells.length];\n var bboxesOffset = array[NUM_PARAMS + cells.length + 1];\n this.keys = array.subarray(keysOffset, bboxesOffset);\n this.bboxes = array.subarray(bboxesOffset);\n this.insert = this._insertReadonly;\n } else {\n this.d = n + 2 * padding;\n for (var i = 0; i < this.d * this.d; i++) {\n cells.push([]);\n }\n this.keys = [];\n this.bboxes = [];\n }\n this.n = n;\n this.extent = extent;\n this.padding = padding;\n this.scale = n / extent;\n this.uid = 0;\n var p = padding / n * extent;\n this.min = -p;\n this.max = extent + p;\n}\nGridIndex.prototype.insert = function (key, x1, y1, x2, y2) {\n this._forEachCell(x1, y1, x2, y2, this._insertCell, this.uid++);\n this.keys.push(key);\n this.bboxes.push(x1);\n this.bboxes.push(y1);\n this.bboxes.push(x2);\n this.bboxes.push(y2);\n};\nGridIndex.prototype._insertReadonly = function () {\n throw 'Cannot insert into a GridIndex created from an ArrayBuffer.';\n};\nGridIndex.prototype._insertCell = function (x1, y1, x2, y2, cellIndex, uid) {\n this.cells[cellIndex].push(uid);\n};\nGridIndex.prototype.query = function (x1, y1, x2, y2, intersectionTest) {\n var min = this.min;\n var max = this.max;\n if (x1 <= min && y1 <= min && max <= x2 && max <= y2 && !intersectionTest) {\n return Array.prototype.slice.call(this.keys);\n } else {\n var result = [];\n var seenUids = {};\n this._forEachCell(x1, y1, x2, y2, this._queryCell, result, seenUids, intersectionTest);\n return result;\n }\n};\nGridIndex.prototype._queryCell = function (x1, y1, x2, y2, cellIndex, result, seenUids, intersectionTest) {\n var cell = this.cells[cellIndex];\n if (cell !== null) {\n var keys = this.keys;\n var bboxes = this.bboxes;\n for (var u = 0; u < cell.length; u++) {\n var uid = cell[u];\n if (seenUids[uid] === undefined) {\n var offset = uid * 4;\n if (intersectionTest ? intersectionTest(bboxes[offset + 0], bboxes[offset + 1], bboxes[offset + 2], bboxes[offset + 3]) : x1 <= bboxes[offset + 2] && y1 <= bboxes[offset + 3] && x2 >= bboxes[offset + 0] && y2 >= bboxes[offset + 1]) {\n seenUids[uid] = true;\n result.push(keys[uid]);\n } else {\n seenUids[uid] = false;\n }\n }\n }\n }\n};\nGridIndex.prototype._forEachCell = function (x1, y1, x2, y2, fn, arg1, arg2, intersectionTest) {\n var cx1 = this._convertToCellCoord(x1);\n var cy1 = this._convertToCellCoord(y1);\n var cx2 = this._convertToCellCoord(x2);\n var cy2 = this._convertToCellCoord(y2);\n for (var x = cx1; x <= cx2; x++) {\n for (var y = cy1; y <= cy2; y++) {\n var cellIndex = this.d * y + x;\n if (intersectionTest && !intersectionTest(this._convertFromCellCoord(x), this._convertFromCellCoord(y), this._convertFromCellCoord(x + 1), this._convertFromCellCoord(y + 1))) {\n continue;\n }\n if (fn.call(this, x1, y1, x2, y2, cellIndex, arg1, arg2, intersectionTest)) {\n return;\n }\n }\n }\n};\nGridIndex.prototype._convertFromCellCoord = function (x) {\n return (x - this.padding) / this.scale;\n};\nGridIndex.prototype._convertToCellCoord = function (x) {\n return Math.max(0, Math.min(this.d - 1, Math.floor(x * this.scale) + this.padding));\n};\nGridIndex.prototype.toArrayBuffer = function () {\n if (this.arrayBuffer) {\n return this.arrayBuffer;\n }\n var cells = this.cells;\n var metadataLength = NUM_PARAMS + this.cells.length + 1 + 1;\n var totalCellLength = 0;\n for (var i = 0; i < this.cells.length; i++) {\n totalCellLength += this.cells[i].length;\n }\n var array = new Int32Array(metadataLength + totalCellLength + this.keys.length + this.bboxes.length);\n array[0] = this.extent;\n array[1] = this.n;\n array[2] = this.padding;\n var offset = metadataLength;\n for (var k = 0; k < cells.length; k++) {\n var cell = cells[k];\n array[NUM_PARAMS + k] = offset;\n array.set(cell, offset);\n offset += cell.length;\n }\n array[NUM_PARAMS + cells.length] = offset;\n array.set(this.keys, offset);\n offset += this.keys.length;\n array[NUM_PARAMS + cells.length + 1] = offset;\n array.set(this.bboxes, offset);\n offset += this.bboxes.length;\n return array.buffer;\n};\n\nvar ImageData = window$1.ImageData;\nvar ImageBitmap = window$1.ImageBitmap;\nvar registry = {};\nfunction register(name, klass, options) {\n if (options === void 0)\n options = {};\n Object.defineProperty(klass, '_classRegistryKey', {\n value: name,\n writeable: false\n });\n registry[name] = {\n klass: klass,\n omit: options.omit || [],\n shallow: options.shallow || []\n };\n}\nregister('Object', Object);\ngridIndex.serialize = function serialize(grid, transferables) {\n var buffer = grid.toArrayBuffer();\n if (transferables) {\n transferables.push(buffer);\n }\n return { buffer: buffer };\n};\ngridIndex.deserialize = function deserialize(serialized) {\n return new gridIndex(serialized.buffer);\n};\nregister('Grid', gridIndex);\nregister('Color', Color);\nregister('Error', Error);\nregister('ResolvedImage', ResolvedImage);\nregister('StylePropertyFunction', StylePropertyFunction);\nregister('StyleExpression', StyleExpression, { omit: ['_evaluator'] });\nregister('ZoomDependentExpression', ZoomDependentExpression);\nregister('ZoomConstantExpression', ZoomConstantExpression);\nregister('CompoundExpression', CompoundExpression, { omit: ['_evaluate'] });\nfor (var name in expressions) {\n if (expressions[name]._classRegistryKey) {\n continue;\n }\n register('Expression_' + name, expressions[name]);\n}\nfunction isArrayBuffer(val) {\n return val && typeof ArrayBuffer !== 'undefined' && (val instanceof ArrayBuffer || val.constructor && val.constructor.name === 'ArrayBuffer');\n}\nfunction isImageBitmap(val) {\n return ImageBitmap && val instanceof ImageBitmap;\n}\nfunction serialize(input, transferables) {\n if (input === null || input === undefined || typeof input === 'boolean' || typeof input === 'number' || typeof input === 'string' || input instanceof Boolean || input instanceof Number || input instanceof String || input instanceof Date || input instanceof RegExp) {\n return input;\n }\n if (isArrayBuffer(input) || isImageBitmap(input)) {\n if (transferables) {\n transferables.push(input);\n }\n return input;\n }\n if (ArrayBuffer.isView(input)) {\n var view = input;\n if (transferables) {\n transferables.push(view.buffer);\n }\n return view;\n }\n if (input instanceof ImageData) {\n if (transferables) {\n transferables.push(input.data.buffer);\n }\n return input;\n }\n if (Array.isArray(input)) {\n var serialized = [];\n for (var i = 0, list = input; i < list.length; i += 1) {\n var item = list[i];\n serialized.push(serialize(item, transferables));\n }\n return serialized;\n }\n if (typeof input === 'object') {\n var klass = input.constructor;\n var name = klass._classRegistryKey;\n if (!name) {\n throw new Error('can\\'t serialize object of unregistered class');\n }\n var properties = klass.serialize ? klass.serialize(input, transferables) : {};\n if (!klass.serialize) {\n for (var key in input) {\n if (!input.hasOwnProperty(key)) {\n continue;\n }\n if (registry[name].omit.indexOf(key) >= 0) {\n continue;\n }\n var property = input[key];\n properties[key] = registry[name].shallow.indexOf(key) >= 0 ? property : serialize(property, transferables);\n }\n if (input instanceof Error) {\n properties.message = input.message;\n }\n }\n if (properties.$name) {\n throw new Error('$name property is reserved for worker serialization logic.');\n }\n if (name !== 'Object') {\n properties.$name = name;\n }\n return properties;\n }\n throw new Error('can\\'t serialize object of type ' + typeof input);\n}\nfunction deserialize(input) {\n if (input === null || input === undefined || typeof input === 'boolean' || typeof input === 'number' || typeof input === 'string' || input instanceof Boolean || input instanceof Number || input instanceof String || input instanceof Date || input instanceof RegExp || isArrayBuffer(input) || isImageBitmap(input) || ArrayBuffer.isView(input) || input instanceof ImageData) {\n return input;\n }\n if (Array.isArray(input)) {\n return input.map(deserialize);\n }\n if (typeof input === 'object') {\n var name = input.$name || 'Object';\n var ref = registry[name];\n var klass = ref.klass;\n if (!klass) {\n throw new Error('can\\'t deserialize unregistered class ' + name);\n }\n if (klass.deserialize) {\n return klass.deserialize(input);\n }\n var result = Object.create(klass.prototype);\n for (var i = 0, list = Object.keys(input); i < list.length; i += 1) {\n var key = list[i];\n if (key === '$name') {\n continue;\n }\n var value = input[key];\n result[key] = registry[name].shallow.indexOf(key) >= 0 ? value : deserialize(value);\n }\n return result;\n }\n throw new Error('can\\'t deserialize object of type ' + typeof input);\n}\n\nvar ZoomHistory = function ZoomHistory() {\n this.first = true;\n};\nZoomHistory.prototype.update = function update(z, now) {\n var floorZ = Math.floor(z);\n if (this.first) {\n this.first = false;\n this.lastIntegerZoom = floorZ;\n this.lastIntegerZoomTime = 0;\n this.lastZoom = z;\n this.lastFloorZoom = floorZ;\n return true;\n }\n if (this.lastFloorZoom > floorZ) {\n this.lastIntegerZoom = floorZ + 1;\n this.lastIntegerZoomTime = now;\n } else if (this.lastFloorZoom < floorZ) {\n this.lastIntegerZoom = floorZ;\n this.lastIntegerZoomTime = now;\n }\n if (z !== this.lastZoom) {\n this.lastZoom = z;\n this.lastFloorZoom = floorZ;\n return true;\n }\n return false;\n};\n\nvar unicodeBlockLookup = {\n 'Latin-1 Supplement': function (char) {\n return char >= 128 && char <= 255;\n },\n 'Arabic': function (char) {\n return char >= 1536 && char <= 1791;\n },\n 'Arabic Supplement': function (char) {\n return char >= 1872 && char <= 1919;\n },\n 'Arabic Extended-A': function (char) {\n return char >= 2208 && char <= 2303;\n },\n 'Hangul Jamo': function (char) {\n return char >= 4352 && char <= 4607;\n },\n 'Unified Canadian Aboriginal Syllabics': function (char) {\n return char >= 5120 && char <= 5759;\n },\n 'Khmer': function (char) {\n return char >= 6016 && char <= 6143;\n },\n 'Unified Canadian Aboriginal Syllabics Extended': function (char) {\n return char >= 6320 && char <= 6399;\n },\n 'General Punctuation': function (char) {\n return char >= 8192 && char <= 8303;\n },\n 'Letterlike Symbols': function (char) {\n return char >= 8448 && char <= 8527;\n },\n 'Number Forms': function (char) {\n return char >= 8528 && char <= 8591;\n },\n 'Miscellaneous Technical': function (char) {\n return char >= 8960 && char <= 9215;\n },\n 'Control Pictures': function (char) {\n return char >= 9216 && char <= 9279;\n },\n 'Optical Character Recognition': function (char) {\n return char >= 9280 && char <= 9311;\n },\n 'Enclosed Alphanumerics': function (char) {\n return char >= 9312 && char <= 9471;\n },\n 'Geometric Shapes': function (char) {\n return char >= 9632 && char <= 9727;\n },\n 'Miscellaneous Symbols': function (char) {\n return char >= 9728 && char <= 9983;\n },\n 'Miscellaneous Symbols and Arrows': function (char) {\n return char >= 11008 && char <= 11263;\n },\n 'CJK Radicals Supplement': function (char) {\n return char >= 11904 && char <= 12031;\n },\n 'Kangxi Radicals': function (char) {\n return char >= 12032 && char <= 12255;\n },\n 'Ideographic Description Characters': function (char) {\n return char >= 12272 && char <= 12287;\n },\n 'CJK Symbols and Punctuation': function (char) {\n return char >= 12288 && char <= 12351;\n },\n 'Hiragana': function (char) {\n return char >= 12352 && char <= 12447;\n },\n 'Katakana': function (char) {\n return char >= 12448 && char <= 12543;\n },\n 'Bopomofo': function (char) {\n return char >= 12544 && char <= 12591;\n },\n 'Hangul Compatibility Jamo': function (char) {\n return char >= 12592 && char <= 12687;\n },\n 'Kanbun': function (char) {\n return char >= 12688 && char <= 12703;\n },\n 'Bopomofo Extended': function (char) {\n return char >= 12704 && char <= 12735;\n },\n 'CJK Strokes': function (char) {\n return char >= 12736 && char <= 12783;\n },\n 'Katakana Phonetic Extensions': function (char) {\n return char >= 12784 && char <= 12799;\n },\n 'Enclosed CJK Letters and Months': function (char) {\n return char >= 12800 && char <= 13055;\n },\n 'CJK Compatibility': function (char) {\n return char >= 13056 && char <= 13311;\n },\n 'CJK Unified Ideographs Extension A': function (char) {\n return char >= 13312 && char <= 19903;\n },\n 'Yijing Hexagram Symbols': function (char) {\n return char >= 19904 && char <= 19967;\n },\n 'CJK Unified Ideographs': function (char) {\n return char >= 19968 && char <= 40959;\n },\n 'Yi Syllables': function (char) {\n return char >= 40960 && char <= 42127;\n },\n 'Yi Radicals': function (char) {\n return char >= 42128 && char <= 42191;\n },\n 'Hangul Jamo Extended-A': function (char) {\n return char >= 43360 && char <= 43391;\n },\n 'Hangul Syllables': function (char) {\n return char >= 44032 && char <= 55215;\n },\n 'Hangul Jamo Extended-B': function (char) {\n return char >= 55216 && char <= 55295;\n },\n 'Private Use Area': function (char) {\n return char >= 57344 && char <= 63743;\n },\n 'CJK Compatibility Ideographs': function (char) {\n return char >= 63744 && char <= 64255;\n },\n 'Arabic Presentation Forms-A': function (char) {\n return char >= 64336 && char <= 65023;\n },\n 'Vertical Forms': function (char) {\n return char >= 65040 && char <= 65055;\n },\n 'CJK Compatibility Forms': function (char) {\n return char >= 65072 && char <= 65103;\n },\n 'Small Form Variants': function (char) {\n return char >= 65104 && char <= 65135;\n },\n 'Arabic Presentation Forms-B': function (char) {\n return char >= 65136 && char <= 65279;\n },\n 'Halfwidth and Fullwidth Forms': function (char) {\n return char >= 65280 && char <= 65519;\n }\n};\n\nfunction allowsVerticalWritingMode(chars) {\n for (var i = 0, list = chars; i < list.length; i += 1) {\n var char = list[i];\n if (charHasUprightVerticalOrientation(char.charCodeAt(0))) {\n return true;\n }\n }\n return false;\n}\nfunction allowsLetterSpacing(chars) {\n for (var i = 0, list = chars; i < list.length; i += 1) {\n var char = list[i];\n if (!charAllowsLetterSpacing(char.charCodeAt(0))) {\n return false;\n }\n }\n return true;\n}\nfunction charAllowsLetterSpacing(char) {\n if (unicodeBlockLookup['Arabic'](char)) {\n return false;\n }\n if (unicodeBlockLookup['Arabic Supplement'](char)) {\n return false;\n }\n if (unicodeBlockLookup['Arabic Extended-A'](char)) {\n return false;\n }\n if (unicodeBlockLookup['Arabic Presentation Forms-A'](char)) {\n return false;\n }\n if (unicodeBlockLookup['Arabic Presentation Forms-B'](char)) {\n return false;\n }\n return true;\n}\nfunction charAllowsIdeographicBreaking(char) {\n if (char < 11904) {\n return false;\n }\n if (unicodeBlockLookup['Bopomofo Extended'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Bopomofo'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Compatibility Forms'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Compatibility Ideographs'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Compatibility'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Radicals Supplement'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Strokes'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Symbols and Punctuation'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Unified Ideographs Extension A'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Unified Ideographs'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Enclosed CJK Letters and Months'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Halfwidth and Fullwidth Forms'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Hiragana'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Ideographic Description Characters'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Kangxi Radicals'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Katakana Phonetic Extensions'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Katakana'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Vertical Forms'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Yi Radicals'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Yi Syllables'](char)) {\n return true;\n }\n return false;\n}\nfunction charHasUprightVerticalOrientation(char) {\n if (char === 746 || char === 747) {\n return true;\n }\n if (char < 4352) {\n return false;\n }\n if (unicodeBlockLookup['Bopomofo Extended'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Bopomofo'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Compatibility Forms'](char)) {\n if (!(char >= 65097 && char <= 65103)) {\n return true;\n }\n }\n if (unicodeBlockLookup['CJK Compatibility Ideographs'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Compatibility'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Radicals Supplement'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Strokes'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Symbols and Punctuation'](char)) {\n if (!(char >= 12296 && char <= 12305) && !(char >= 12308 && char <= 12319) && char !== 12336) {\n return true;\n }\n }\n if (unicodeBlockLookup['CJK Unified Ideographs Extension A'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Unified Ideographs'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Enclosed CJK Letters and Months'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Hangul Compatibility Jamo'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Hangul Jamo Extended-A'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Hangul Jamo Extended-B'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Hangul Jamo'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Hangul Syllables'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Hiragana'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Ideographic Description Characters'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Kanbun'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Kangxi Radicals'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Katakana Phonetic Extensions'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Katakana'](char)) {\n if (char !== 12540) {\n return true;\n }\n }\n if (unicodeBlockLookup['Halfwidth and Fullwidth Forms'](char)) {\n if (char !== 65288 && char !== 65289 && char !== 65293 && !(char >= 65306 && char <= 65310) && char !== 65339 && char !== 65341 && char !== 65343 && !(char >= 65371 && char <= 65503) && char !== 65507 && !(char >= 65512 && char <= 65519)) {\n return true;\n }\n }\n if (unicodeBlockLookup['Small Form Variants'](char)) {\n if (!(char >= 65112 && char <= 65118) && !(char >= 65123 && char <= 65126)) {\n return true;\n }\n }\n if (unicodeBlockLookup['Unified Canadian Aboriginal Syllabics'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Unified Canadian Aboriginal Syllabics Extended'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Vertical Forms'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Yijing Hexagram Symbols'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Yi Syllables'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Yi Radicals'](char)) {\n return true;\n }\n return false;\n}\nfunction charHasNeutralVerticalOrientation(char) {\n if (unicodeBlockLookup['Latin-1 Supplement'](char)) {\n if (char === 167 || char === 169 || char === 174 || char === 177 || char === 188 || char === 189 || char === 190 || char === 215 || char === 247) {\n return true;\n }\n }\n if (unicodeBlockLookup['General Punctuation'](char)) {\n if (char === 8214 || char === 8224 || char === 8225 || char === 8240 || char === 8241 || char === 8251 || char === 8252 || char === 8258 || char === 8263 || char === 8264 || char === 8265 || char === 8273) {\n return true;\n }\n }\n if (unicodeBlockLookup['Letterlike Symbols'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Number Forms'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Miscellaneous Technical'](char)) {\n if (char >= 8960 && char <= 8967 || char >= 8972 && char <= 8991 || char >= 8996 && char <= 9000 || char === 9003 || char >= 9085 && char <= 9114 || char >= 9150 && char <= 9165 || char === 9167 || char >= 9169 && char <= 9179 || char >= 9186 && char <= 9215) {\n return true;\n }\n }\n if (unicodeBlockLookup['Control Pictures'](char) && char !== 9251) {\n return true;\n }\n if (unicodeBlockLookup['Optical Character Recognition'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Enclosed Alphanumerics'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Geometric Shapes'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Miscellaneous Symbols'](char)) {\n if (!(char >= 9754 && char <= 9759)) {\n return true;\n }\n }\n if (unicodeBlockLookup['Miscellaneous Symbols and Arrows'](char)) {\n if (char >= 11026 && char <= 11055 || char >= 11088 && char <= 11097 || char >= 11192 && char <= 11243) {\n return true;\n }\n }\n if (unicodeBlockLookup['CJK Symbols and Punctuation'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Katakana'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Private Use Area'](char)) {\n return true;\n }\n if (unicodeBlockLookup['CJK Compatibility Forms'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Small Form Variants'](char)) {\n return true;\n }\n if (unicodeBlockLookup['Halfwidth and Fullwidth Forms'](char)) {\n return true;\n }\n if (char === 8734 || char === 8756 || char === 8757 || char >= 9984 && char <= 10087 || char >= 10102 && char <= 10131 || char === 65532 || char === 65533) {\n return true;\n }\n return false;\n}\nfunction charHasRotatedVerticalOrientation(char) {\n return !(charHasUprightVerticalOrientation(char) || charHasNeutralVerticalOrientation(char));\n}\nfunction charInComplexShapingScript(char) {\n return unicodeBlockLookup['Arabic'](char) || unicodeBlockLookup['Arabic Supplement'](char) || unicodeBlockLookup['Arabic Extended-A'](char) || unicodeBlockLookup['Arabic Presentation Forms-A'](char) || unicodeBlockLookup['Arabic Presentation Forms-B'](char);\n}\nfunction charInRTLScript(char) {\n return char >= 1424 && char <= 2303 || unicodeBlockLookup['Arabic Presentation Forms-A'](char) || unicodeBlockLookup['Arabic Presentation Forms-B'](char);\n}\nfunction charInSupportedScript(char, canRenderRTL) {\n if (!canRenderRTL && charInRTLScript(char)) {\n return false;\n }\n if (char >= 2304 && char <= 3583 || char >= 3840 && char <= 4255 || unicodeBlockLookup['Khmer'](char)) {\n return false;\n }\n return true;\n}\nfunction stringContainsRTLText(chars) {\n for (var i = 0, list = chars; i < list.length; i += 1) {\n var char = list[i];\n if (charInRTLScript(char.charCodeAt(0))) {\n return true;\n }\n }\n return false;\n}\nfunction isStringInSupportedScript(chars, canRenderRTL) {\n for (var i = 0, list = chars; i < list.length; i += 1) {\n var char = list[i];\n if (!charInSupportedScript(char.charCodeAt(0), canRenderRTL)) {\n return false;\n }\n }\n return true;\n}\n\nvar status = {\n unavailable: 'unavailable',\n deferred: 'deferred',\n loading: 'loading',\n loaded: 'loaded',\n error: 'error'\n};\nvar _completionCallback = null;\nvar pluginStatus = status.unavailable;\nvar pluginURL = null;\nvar triggerPluginCompletionEvent = function (error) {\n if (error && typeof error === 'string' && error.indexOf('NetworkError') > -1) {\n pluginStatus = status.error;\n }\n if (_completionCallback) {\n _completionCallback(error);\n }\n};\nfunction sendPluginStateToWorker() {\n evented.fire(new Event('pluginStateChange', {\n pluginStatus: pluginStatus,\n pluginURL: pluginURL\n }));\n}\nvar evented = new Evented();\nvar getRTLTextPluginStatus = function () {\n return pluginStatus;\n};\nvar registerForPluginStateChange = function (callback) {\n callback({\n pluginStatus: pluginStatus,\n pluginURL: pluginURL\n });\n evented.on('pluginStateChange', callback);\n return callback;\n};\nvar setRTLTextPlugin = function (url, callback, deferred) {\n if (deferred === void 0)\n deferred = false;\n if (pluginStatus === status.deferred || pluginStatus === status.loading || pluginStatus === status.loaded) {\n throw new Error('setRTLTextPlugin cannot be called multiple times.');\n }\n pluginURL = exported.resolveURL(url);\n pluginStatus = status.deferred;\n _completionCallback = callback;\n sendPluginStateToWorker();\n if (!deferred) {\n downloadRTLTextPlugin();\n }\n};\nvar downloadRTLTextPlugin = function () {\n if (pluginStatus !== status.deferred || !pluginURL) {\n throw new Error('rtl-text-plugin cannot be downloaded unless a pluginURL is specified');\n }\n pluginStatus = status.loading;\n sendPluginStateToWorker();\n if (pluginURL) {\n getArrayBuffer({ url: pluginURL }, function (error) {\n if (error) {\n triggerPluginCompletionEvent(error);\n } else {\n pluginStatus = status.loaded;\n sendPluginStateToWorker();\n }\n });\n }\n};\nvar plugin = {\n applyArabicShaping: null,\n processBidirectionalText: null,\n processStyledBidirectionalText: null,\n isLoaded: function isLoaded() {\n return pluginStatus === status.loaded || plugin.applyArabicShaping != null;\n },\n isLoading: function isLoading() {\n return pluginStatus === status.loading;\n },\n setState: function setState(state) {\n pluginStatus = state.pluginStatus;\n pluginURL = state.pluginURL;\n },\n isParsed: function isParsed() {\n return plugin.applyArabicShaping != null && plugin.processBidirectionalText != null && plugin.processStyledBidirectionalText != null;\n },\n getPluginURL: function getPluginURL() {\n return pluginURL;\n }\n};\nvar lazyLoadRTLTextPlugin = function () {\n if (!plugin.isLoading() && !plugin.isLoaded() && getRTLTextPluginStatus() === 'deferred') {\n downloadRTLTextPlugin();\n }\n};\n\nvar EvaluationParameters = function EvaluationParameters(zoom, options) {\n this.zoom = zoom;\n if (options) {\n this.now = options.now;\n this.fadeDuration = options.fadeDuration;\n this.zoomHistory = options.zoomHistory;\n this.transition = options.transition;\n } else {\n this.now = 0;\n this.fadeDuration = 0;\n this.zoomHistory = new ZoomHistory();\n this.transition = {};\n }\n};\nEvaluationParameters.prototype.isSupportedScript = function isSupportedScript(str) {\n return isStringInSupportedScript(str, plugin.isLoaded());\n};\nEvaluationParameters.prototype.crossFadingFactor = function crossFadingFactor() {\n if (this.fadeDuration === 0) {\n return 1;\n } else {\n return Math.min((this.now - this.zoomHistory.lastIntegerZoomTime) / this.fadeDuration, 1);\n }\n};\nEvaluationParameters.prototype.getCrossfadeParameters = function getCrossfadeParameters() {\n var z = this.zoom;\n var fraction = z - Math.floor(z);\n var t = this.crossFadingFactor();\n return z > this.zoomHistory.lastIntegerZoom ? {\n fromScale: 2,\n toScale: 1,\n t: fraction + (1 - fraction) * t\n } : {\n fromScale: 0.5,\n toScale: 1,\n t: 1 - (1 - t) * fraction\n };\n};\n\nvar PropertyValue = function PropertyValue(property, value) {\n this.property = property;\n this.value = value;\n this.expression = normalizePropertyExpression(value === undefined ? property.specification.default : value, property.specification);\n};\nPropertyValue.prototype.isDataDriven = function isDataDriven() {\n return this.expression.kind === 'source' || this.expression.kind === 'composite';\n};\nPropertyValue.prototype.possiblyEvaluate = function possiblyEvaluate(parameters, canonical, availableImages) {\n return this.property.possiblyEvaluate(this, parameters, canonical, availableImages);\n};\nvar TransitionablePropertyValue = function TransitionablePropertyValue(property) {\n this.property = property;\n this.value = new PropertyValue(property, undefined);\n};\nTransitionablePropertyValue.prototype.transitioned = function transitioned(parameters, prior) {\n return new TransitioningPropertyValue(this.property, this.value, prior, extend({}, parameters.transition, this.transition), parameters.now);\n};\nTransitionablePropertyValue.prototype.untransitioned = function untransitioned() {\n return new TransitioningPropertyValue(this.property, this.value, null, {}, 0);\n};\nvar Transitionable = function Transitionable(properties) {\n this._properties = properties;\n this._values = Object.create(properties.defaultTransitionablePropertyValues);\n};\nTransitionable.prototype.getValue = function getValue(name) {\n return clone(this._values[name].value.value);\n};\nTransitionable.prototype.setValue = function setValue(name, value) {\n if (!this._values.hasOwnProperty(name)) {\n this._values[name] = new TransitionablePropertyValue(this._values[name].property);\n }\n this._values[name].value = new PropertyValue(this._values[name].property, value === null ? undefined : clone(value));\n};\nTransitionable.prototype.getTransition = function getTransition(name) {\n return clone(this._values[name].transition);\n};\nTransitionable.prototype.setTransition = function setTransition(name, value) {\n if (!this._values.hasOwnProperty(name)) {\n this._values[name] = new TransitionablePropertyValue(this._values[name].property);\n }\n this._values[name].transition = clone(value) || undefined;\n};\nTransitionable.prototype.serialize = function serialize() {\n var result = {};\n for (var i = 0, list = Object.keys(this._values); i < list.length; i += 1) {\n var property = list[i];\n var value = this.getValue(property);\n if (value !== undefined) {\n result[property] = value;\n }\n var transition = this.getTransition(property);\n if (transition !== undefined) {\n result[property + '-transition'] = transition;\n }\n }\n return result;\n};\nTransitionable.prototype.transitioned = function transitioned(parameters, prior) {\n var result = new Transitioning(this._properties);\n for (var i = 0, list = Object.keys(this._values); i < list.length; i += 1) {\n var property = list[i];\n result._values[property] = this._values[property].transitioned(parameters, prior._values[property]);\n }\n return result;\n};\nTransitionable.prototype.untransitioned = function untransitioned() {\n var result = new Transitioning(this._properties);\n for (var i = 0, list = Object.keys(this._values); i < list.length; i += 1) {\n var property = list[i];\n result._values[property] = this._values[property].untransitioned();\n }\n return result;\n};\nvar TransitioningPropertyValue = function TransitioningPropertyValue(property, value, prior, transition, now) {\n this.property = property;\n this.value = value;\n this.begin = now + transition.delay || 0;\n this.end = this.begin + transition.duration || 0;\n if (property.specification.transition && (transition.delay || transition.duration)) {\n this.prior = prior;\n }\n};\nTransitioningPropertyValue.prototype.possiblyEvaluate = function possiblyEvaluate(parameters, canonical, availableImages) {\n var now = parameters.now || 0;\n var finalValue = this.value.possiblyEvaluate(parameters, canonical, availableImages);\n var prior = this.prior;\n if (!prior) {\n return finalValue;\n } else if (now > this.end) {\n this.prior = null;\n return finalValue;\n } else if (this.value.isDataDriven()) {\n this.prior = null;\n return finalValue;\n } else if (now < this.begin) {\n return prior.possiblyEvaluate(parameters, canonical, availableImages);\n } else {\n var t = (now - this.begin) / (this.end - this.begin);\n return this.property.interpolate(prior.possiblyEvaluate(parameters, canonical, availableImages), finalValue, easeCubicInOut(t));\n }\n};\nvar Transitioning = function Transitioning(properties) {\n this._properties = properties;\n this._values = Object.create(properties.defaultTransitioningPropertyValues);\n};\nTransitioning.prototype.possiblyEvaluate = function possiblyEvaluate(parameters, canonical, availableImages) {\n var result = new PossiblyEvaluated(this._properties);\n for (var i = 0, list = Object.keys(this._values); i < list.length; i += 1) {\n var property = list[i];\n result._values[property] = this._values[property].possiblyEvaluate(parameters, canonical, availableImages);\n }\n return result;\n};\nTransitioning.prototype.hasTransition = function hasTransition() {\n for (var i = 0, list = Object.keys(this._values); i < list.length; i += 1) {\n var property = list[i];\n if (this._values[property].prior) {\n return true;\n }\n }\n return false;\n};\nvar Layout = function Layout(properties) {\n this._properties = properties;\n this._values = Object.create(properties.defaultPropertyValues);\n};\nLayout.prototype.getValue = function getValue(name) {\n return clone(this._values[name].value);\n};\nLayout.prototype.setValue = function setValue(name, value) {\n this._values[name] = new PropertyValue(this._values[name].property, value === null ? undefined : clone(value));\n};\nLayout.prototype.serialize = function serialize() {\n var result = {};\n for (var i = 0, list = Object.keys(this._values); i < list.length; i += 1) {\n var property = list[i];\n var value = this.getValue(property);\n if (value !== undefined) {\n result[property] = value;\n }\n }\n return result;\n};\nLayout.prototype.possiblyEvaluate = function possiblyEvaluate(parameters, canonical, availableImages) {\n var result = new PossiblyEvaluated(this._properties);\n for (var i = 0, list = Object.keys(this._values); i < list.length; i += 1) {\n var property = list[i];\n result._values[property] = this._values[property].possiblyEvaluate(parameters, canonical, availableImages);\n }\n return result;\n};\nvar PossiblyEvaluatedPropertyValue = function PossiblyEvaluatedPropertyValue(property, value, parameters) {\n this.property = property;\n this.value = value;\n this.parameters = parameters;\n};\nPossiblyEvaluatedPropertyValue.prototype.isConstant = function isConstant() {\n return this.value.kind === 'constant';\n};\nPossiblyEvaluatedPropertyValue.prototype.constantOr = function constantOr(value) {\n if (this.value.kind === 'constant') {\n return this.value.value;\n } else {\n return value;\n }\n};\nPossiblyEvaluatedPropertyValue.prototype.evaluate = function evaluate(feature, featureState, canonical, availableImages) {\n return this.property.evaluate(this.value, this.parameters, feature, featureState, canonical, availableImages);\n};\nvar PossiblyEvaluated = function PossiblyEvaluated(properties) {\n this._properties = properties;\n this._values = Object.create(properties.defaultPossiblyEvaluatedValues);\n};\nPossiblyEvaluated.prototype.get = function get(name) {\n return this._values[name];\n};\nvar DataConstantProperty = function DataConstantProperty(specification) {\n this.specification = specification;\n};\nDataConstantProperty.prototype.possiblyEvaluate = function possiblyEvaluate(value, parameters) {\n return value.expression.evaluate(parameters);\n};\nDataConstantProperty.prototype.interpolate = function interpolate$1(a, b, t) {\n var interp = interpolate[this.specification.type];\n if (interp) {\n return interp(a, b, t);\n } else {\n return a;\n }\n};\nvar DataDrivenProperty = function DataDrivenProperty(specification, overrides) {\n this.specification = specification;\n this.overrides = overrides;\n};\nDataDrivenProperty.prototype.possiblyEvaluate = function possiblyEvaluate(value, parameters, canonical, availableImages) {\n if (value.expression.kind === 'constant' || value.expression.kind === 'camera') {\n return new PossiblyEvaluatedPropertyValue(this, {\n kind: 'constant',\n value: value.expression.evaluate(parameters, null, {}, canonical, availableImages)\n }, parameters);\n } else {\n return new PossiblyEvaluatedPropertyValue(this, value.expression, parameters);\n }\n};\nDataDrivenProperty.prototype.interpolate = function interpolate$2(a, b, t) {\n if (a.value.kind !== 'constant' || b.value.kind !== 'constant') {\n return a;\n }\n if (a.value.value === undefined || b.value.value === undefined) {\n return new PossiblyEvaluatedPropertyValue(this, {\n kind: 'constant',\n value: undefined\n }, a.parameters);\n }\n var interp = interpolate[this.specification.type];\n if (interp) {\n return new PossiblyEvaluatedPropertyValue(this, {\n kind: 'constant',\n value: interp(a.value.value, b.value.value, t)\n }, a.parameters);\n } else {\n return a;\n }\n};\nDataDrivenProperty.prototype.evaluate = function evaluate(value, parameters, feature, featureState, canonical, availableImages) {\n if (value.kind === 'constant') {\n return value.value;\n } else {\n return value.evaluate(parameters, feature, featureState, canonical, availableImages);\n }\n};\nvar CrossFadedDataDrivenProperty = function (DataDrivenProperty) {\n function CrossFadedDataDrivenProperty() {\n DataDrivenProperty.apply(this, arguments);\n }\n if (DataDrivenProperty)\n CrossFadedDataDrivenProperty.__proto__ = DataDrivenProperty;\n CrossFadedDataDrivenProperty.prototype = Object.create(DataDrivenProperty && DataDrivenProperty.prototype);\n CrossFadedDataDrivenProperty.prototype.constructor = CrossFadedDataDrivenProperty;\n CrossFadedDataDrivenProperty.prototype.possiblyEvaluate = function possiblyEvaluate(value, parameters, canonical, availableImages) {\n if (value.value === undefined) {\n return new PossiblyEvaluatedPropertyValue(this, {\n kind: 'constant',\n value: undefined\n }, parameters);\n } else if (value.expression.kind === 'constant') {\n var evaluatedValue = value.expression.evaluate(parameters, null, {}, canonical, availableImages);\n var isImageExpression = value.property.specification.type === 'resolvedImage';\n var constantValue = isImageExpression && typeof evaluatedValue !== 'string' ? evaluatedValue.name : evaluatedValue;\n var constant = this._calculate(constantValue, constantValue, constantValue, parameters);\n return new PossiblyEvaluatedPropertyValue(this, {\n kind: 'constant',\n value: constant\n }, parameters);\n } else if (value.expression.kind === 'camera') {\n var cameraVal = this._calculate(value.expression.evaluate({ zoom: parameters.zoom - 1 }), value.expression.evaluate({ zoom: parameters.zoom }), value.expression.evaluate({ zoom: parameters.zoom + 1 }), parameters);\n return new PossiblyEvaluatedPropertyValue(this, {\n kind: 'constant',\n value: cameraVal\n }, parameters);\n } else {\n return new PossiblyEvaluatedPropertyValue(this, value.expression, parameters);\n }\n };\n CrossFadedDataDrivenProperty.prototype.evaluate = function evaluate(value, globals, feature, featureState, canonical, availableImages) {\n if (value.kind === 'source') {\n var constant = value.evaluate(globals, feature, featureState, canonical, availableImages);\n return this._calculate(constant, constant, constant, globals);\n } else if (value.kind === 'composite') {\n return this._calculate(value.evaluate({ zoom: Math.floor(globals.zoom) - 1 }, feature, featureState), value.evaluate({ zoom: Math.floor(globals.zoom) }, feature, featureState), value.evaluate({ zoom: Math.floor(globals.zoom) + 1 }, feature, featureState), globals);\n } else {\n return value.value;\n }\n };\n CrossFadedDataDrivenProperty.prototype._calculate = function _calculate(min, mid, max, parameters) {\n var z = parameters.zoom;\n return z > parameters.zoomHistory.lastIntegerZoom ? {\n from: min,\n to: mid\n } : {\n from: max,\n to: mid\n };\n };\n CrossFadedDataDrivenProperty.prototype.interpolate = function interpolate(a) {\n return a;\n };\n return CrossFadedDataDrivenProperty;\n}(DataDrivenProperty);\nvar CrossFadedProperty = function CrossFadedProperty(specification) {\n this.specification = specification;\n};\nCrossFadedProperty.prototype.possiblyEvaluate = function possiblyEvaluate(value, parameters, canonical, availableImages) {\n if (value.value === undefined) {\n return undefined;\n } else if (value.expression.kind === 'constant') {\n var constant = value.expression.evaluate(parameters, null, {}, canonical, availableImages);\n return this._calculate(constant, constant, constant, parameters);\n } else {\n return this._calculate(value.expression.evaluate(new EvaluationParameters(Math.floor(parameters.zoom - 1), parameters)), value.expression.evaluate(new EvaluationParameters(Math.floor(parameters.zoom), parameters)), value.expression.evaluate(new EvaluationParameters(Math.floor(parameters.zoom + 1), parameters)), parameters);\n }\n};\nCrossFadedProperty.prototype._calculate = function _calculate(min, mid, max, parameters) {\n var z = parameters.zoom;\n return z > parameters.zoomHistory.lastIntegerZoom ? {\n from: min,\n to: mid\n } : {\n from: max,\n to: mid\n };\n};\nCrossFadedProperty.prototype.interpolate = function interpolate(a) {\n return a;\n};\nvar ColorRampProperty = function ColorRampProperty(specification) {\n this.specification = specification;\n};\nColorRampProperty.prototype.possiblyEvaluate = function possiblyEvaluate(value, parameters, canonical, availableImages) {\n return !!value.expression.evaluate(parameters, null, {}, canonical, availableImages);\n};\nColorRampProperty.prototype.interpolate = function interpolate() {\n return false;\n};\nvar Properties = function Properties(properties) {\n this.properties = properties;\n this.defaultPropertyValues = {};\n this.defaultTransitionablePropertyValues = {};\n this.defaultTransitioningPropertyValues = {};\n this.defaultPossiblyEvaluatedValues = {};\n this.overridableProperties = [];\n for (var property in properties) {\n var prop = properties[property];\n if (prop.specification.overridable) {\n this.overridableProperties.push(property);\n }\n var defaultPropertyValue = this.defaultPropertyValues[property] = new PropertyValue(prop, undefined);\n var defaultTransitionablePropertyValue = this.defaultTransitionablePropertyValues[property] = new TransitionablePropertyValue(prop);\n this.defaultTransitioningPropertyValues[property] = defaultTransitionablePropertyValue.untransitioned();\n this.defaultPossiblyEvaluatedValues[property] = defaultPropertyValue.possiblyEvaluate({});\n }\n};\nregister('DataDrivenProperty', DataDrivenProperty);\nregister('DataConstantProperty', DataConstantProperty);\nregister('CrossFadedDataDrivenProperty', CrossFadedDataDrivenProperty);\nregister('CrossFadedProperty', CrossFadedProperty);\nregister('ColorRampProperty', ColorRampProperty);\n\nvar TRANSITION_SUFFIX = '-transition';\nvar StyleLayer = function (Evented) {\n function StyleLayer(layer, properties) {\n Evented.call(this);\n this.id = layer.id;\n this.type = layer.type;\n this._featureFilter = {\n filter: function () {\n return true;\n },\n needGeometry: false\n };\n if (layer.type === 'custom') {\n return;\n }\n layer = layer;\n this.metadata = layer.metadata;\n this.minzoom = layer.minzoom;\n this.maxzoom = layer.maxzoom;\n if (layer.type !== 'background') {\n this.source = layer.source;\n this.sourceLayer = layer['source-layer'];\n this.filter = layer.filter;\n }\n if (properties.layout) {\n this._unevaluatedLayout = new Layout(properties.layout);\n }\n if (properties.paint) {\n this._transitionablePaint = new Transitionable(properties.paint);\n for (var property in layer.paint) {\n this.setPaintProperty(property, layer.paint[property], { validate: false });\n }\n for (var property$1 in layer.layout) {\n this.setLayoutProperty(property$1, layer.layout[property$1], { validate: false });\n }\n this._transitioningPaint = this._transitionablePaint.untransitioned();\n this.paint = new PossiblyEvaluated(properties.paint);\n }\n }\n if (Evented)\n StyleLayer.__proto__ = Evented;\n StyleLayer.prototype = Object.create(Evented && Evented.prototype);\n StyleLayer.prototype.constructor = StyleLayer;\n StyleLayer.prototype.getCrossfadeParameters = function getCrossfadeParameters() {\n return this._crossfadeParameters;\n };\n StyleLayer.prototype.getLayoutProperty = function getLayoutProperty(name) {\n if (name === 'visibility') {\n return this.visibility;\n }\n return this._unevaluatedLayout.getValue(name);\n };\n StyleLayer.prototype.setLayoutProperty = function setLayoutProperty(name, value, options) {\n if (options === void 0)\n options = {};\n if (value !== null && value !== undefined) {\n var key = 'layers.' + this.id + '.layout.' + name;\n if (this._validate(validateLayoutProperty$1, key, name, value, options)) {\n return;\n }\n }\n if (name === 'visibility') {\n this.visibility = value;\n return;\n }\n this._unevaluatedLayout.setValue(name, value);\n };\n StyleLayer.prototype.getPaintProperty = function getPaintProperty(name) {\n if (endsWith(name, TRANSITION_SUFFIX)) {\n return this._transitionablePaint.getTransition(name.slice(0, -TRANSITION_SUFFIX.length));\n } else {\n return this._transitionablePaint.getValue(name);\n }\n };\n StyleLayer.prototype.setPaintProperty = function setPaintProperty(name, value, options) {\n if (options === void 0)\n options = {};\n if (value !== null && value !== undefined) {\n var key = 'layers.' + this.id + '.paint.' + name;\n if (this._validate(validatePaintProperty$1, key, name, value, options)) {\n return false;\n }\n }\n if (endsWith(name, TRANSITION_SUFFIX)) {\n this._transitionablePaint.setTransition(name.slice(0, -TRANSITION_SUFFIX.length), value || undefined);\n return false;\n } else {\n var transitionable = this._transitionablePaint._values[name];\n var isCrossFadedProperty = transitionable.property.specification['property-type'] === 'cross-faded-data-driven';\n var wasDataDriven = transitionable.value.isDataDriven();\n var oldValue = transitionable.value;\n this._transitionablePaint.setValue(name, value);\n this._handleSpecialPaintPropertyUpdate(name);\n var newValue = this._transitionablePaint._values[name].value;\n var isDataDriven = newValue.isDataDriven();\n return isDataDriven || wasDataDriven || isCrossFadedProperty || this._handleOverridablePaintPropertyUpdate(name, oldValue, newValue);\n }\n };\n StyleLayer.prototype._handleSpecialPaintPropertyUpdate = function _handleSpecialPaintPropertyUpdate(_) {\n };\n StyleLayer.prototype._handleOverridablePaintPropertyUpdate = function _handleOverridablePaintPropertyUpdate(name, oldValue, newValue) {\n return false;\n };\n StyleLayer.prototype.isHidden = function isHidden(zoom) {\n if (this.minzoom && zoom < this.minzoom) {\n return true;\n }\n if (this.maxzoom && zoom >= this.maxzoom) {\n return true;\n }\n return this.visibility === 'none';\n };\n StyleLayer.prototype.updateTransitions = function updateTransitions(parameters) {\n this._transitioningPaint = this._transitionablePaint.transitioned(parameters, this._transitioningPaint);\n };\n StyleLayer.prototype.hasTransition = function hasTransition() {\n return this._transitioningPaint.hasTransition();\n };\n StyleLayer.prototype.recalculate = function recalculate(parameters, availableImages) {\n if (parameters.getCrossfadeParameters) {\n this._crossfadeParameters = parameters.getCrossfadeParameters();\n }\n if (this._unevaluatedLayout) {\n this.layout = this._unevaluatedLayout.possiblyEvaluate(parameters, undefined, availableImages);\n }\n this.paint = this._transitioningPaint.possiblyEvaluate(parameters, undefined, availableImages);\n };\n StyleLayer.prototype.serialize = function serialize() {\n var output = {\n 'id': this.id,\n 'type': this.type,\n 'source': this.source,\n 'source-layer': this.sourceLayer,\n 'metadata': this.metadata,\n 'minzoom': this.minzoom,\n 'maxzoom': this.maxzoom,\n 'filter': this.filter,\n 'layout': this._unevaluatedLayout && this._unevaluatedLayout.serialize(),\n 'paint': this._transitionablePaint && this._transitionablePaint.serialize()\n };\n if (this.visibility) {\n output.layout = output.layout || {};\n output.layout.visibility = this.visibility;\n }\n return filterObject(output, function (value, key) {\n return value !== undefined && !(key === 'layout' && !Object.keys(value).length) && !(key === 'paint' && !Object.keys(value).length);\n });\n };\n StyleLayer.prototype._validate = function _validate(validate, key, name, value, options) {\n if (options === void 0)\n options = {};\n if (options && options.validate === false) {\n return false;\n }\n return emitValidationErrors(this, validate.call(validateStyle, {\n key: key,\n layerType: this.type,\n objectKey: name,\n value: value,\n styleSpec: spec,\n style: {\n glyphs: true,\n sprite: true\n }\n }));\n };\n StyleLayer.prototype.is3D = function is3D() {\n return false;\n };\n StyleLayer.prototype.isTileClipped = function isTileClipped() {\n return false;\n };\n StyleLayer.prototype.hasOffscreenPass = function hasOffscreenPass() {\n return false;\n };\n StyleLayer.prototype.resize = function resize() {\n };\n StyleLayer.prototype.isStateDependent = function isStateDependent() {\n for (var property in this.paint._values) {\n var value = this.paint.get(property);\n if (!(value instanceof PossiblyEvaluatedPropertyValue) || !supportsPropertyExpression(value.property.specification)) {\n continue;\n }\n if ((value.value.kind === 'source' || value.value.kind === 'composite') && value.value.isStateDependent) {\n return true;\n }\n }\n return false;\n };\n return StyleLayer;\n}(Evented);\n\nvar viewTypes = {\n 'Int8': Int8Array,\n 'Uint8': Uint8Array,\n 'Int16': Int16Array,\n 'Uint16': Uint16Array,\n 'Int32': Int32Array,\n 'Uint32': Uint32Array,\n 'Float32': Float32Array\n};\nvar Struct = function Struct(structArray, index) {\n this._structArray = structArray;\n this._pos1 = index * this.size;\n this._pos2 = this._pos1 / 2;\n this._pos4 = this._pos1 / 4;\n this._pos8 = this._pos1 / 8;\n};\nvar DEFAULT_CAPACITY = 128;\nvar RESIZE_MULTIPLIER = 5;\nvar StructArray = function StructArray() {\n this.isTransferred = false;\n this.capacity = -1;\n this.resize(0);\n};\nStructArray.serialize = function serialize(array, transferables) {\n array._trim();\n if (transferables) {\n array.isTransferred = true;\n transferables.push(array.arrayBuffer);\n }\n return {\n length: array.length,\n arrayBuffer: array.arrayBuffer\n };\n};\nStructArray.deserialize = function deserialize(input) {\n var structArray = Object.create(this.prototype);\n structArray.arrayBuffer = input.arrayBuffer;\n structArray.length = input.length;\n structArray.capacity = input.arrayBuffer.byteLength / structArray.bytesPerElement;\n structArray._refreshViews();\n return structArray;\n};\nStructArray.prototype._trim = function _trim() {\n if (this.length !== this.capacity) {\n this.capacity = this.length;\n this.arrayBuffer = this.arrayBuffer.slice(0, this.length * this.bytesPerElement);\n this._refreshViews();\n }\n};\nStructArray.prototype.clear = function clear() {\n this.length = 0;\n};\nStructArray.prototype.resize = function resize(n) {\n this.reserve(n);\n this.length = n;\n};\nStructArray.prototype.reserve = function reserve(n) {\n if (n > this.capacity) {\n this.capacity = Math.max(n, Math.floor(this.capacity * RESIZE_MULTIPLIER), DEFAULT_CAPACITY);\n this.arrayBuffer = new ArrayBuffer(this.capacity * this.bytesPerElement);\n var oldUint8Array = this.uint8;\n this._refreshViews();\n if (oldUint8Array) {\n this.uint8.set(oldUint8Array);\n }\n }\n};\nStructArray.prototype._refreshViews = function _refreshViews() {\n throw new Error('_refreshViews() must be implemented by each concrete StructArray layout');\n};\nfunction createLayout(members, alignment) {\n if (alignment === void 0)\n alignment = 1;\n var offset = 0;\n var maxSize = 0;\n var layoutMembers = members.map(function (member) {\n var typeSize = sizeOf(member.type);\n var memberOffset = offset = align(offset, Math.max(alignment, typeSize));\n var components = member.components || 1;\n maxSize = Math.max(maxSize, typeSize);\n offset += typeSize * components;\n return {\n name: member.name,\n type: member.type,\n components: components,\n offset: memberOffset\n };\n });\n var size = align(offset, Math.max(maxSize, alignment));\n return {\n members: layoutMembers,\n size: size,\n alignment: alignment\n };\n}\nfunction sizeOf(type) {\n return viewTypes[type].BYTES_PER_ELEMENT;\n}\nfunction align(offset, size) {\n return Math.ceil(offset / size) * size;\n}\n\nvar StructArrayLayout2i4 = function (StructArray) {\n function StructArrayLayout2i4() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout2i4.__proto__ = StructArray;\n StructArrayLayout2i4.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout2i4.prototype.constructor = StructArrayLayout2i4;\n StructArrayLayout2i4.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n };\n StructArrayLayout2i4.prototype.emplaceBack = function emplaceBack(v0, v1) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1);\n };\n StructArrayLayout2i4.prototype.emplace = function emplace(i, v0, v1) {\n var o2 = i * 2;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n return i;\n };\n return StructArrayLayout2i4;\n}(StructArray);\nStructArrayLayout2i4.prototype.bytesPerElement = 4;\nregister('StructArrayLayout2i4', StructArrayLayout2i4);\nvar StructArrayLayout4i8 = function (StructArray) {\n function StructArrayLayout4i8() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout4i8.__proto__ = StructArray;\n StructArrayLayout4i8.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout4i8.prototype.constructor = StructArrayLayout4i8;\n StructArrayLayout4i8.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n };\n StructArrayLayout4i8.prototype.emplaceBack = function emplaceBack(v0, v1, v2, v3) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3);\n };\n StructArrayLayout4i8.prototype.emplace = function emplace(i, v0, v1, v2, v3) {\n var o2 = i * 4;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.int16[o2 + 2] = v2;\n this.int16[o2 + 3] = v3;\n return i;\n };\n return StructArrayLayout4i8;\n}(StructArray);\nStructArrayLayout4i8.prototype.bytesPerElement = 8;\nregister('StructArrayLayout4i8', StructArrayLayout4i8);\nvar StructArrayLayout2i4i12 = function (StructArray) {\n function StructArrayLayout2i4i12() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout2i4i12.__proto__ = StructArray;\n StructArrayLayout2i4i12.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout2i4i12.prototype.constructor = StructArrayLayout2i4i12;\n StructArrayLayout2i4i12.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n };\n StructArrayLayout2i4i12.prototype.emplaceBack = function emplaceBack(v0, v1, v2, v3, v4, v5) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5);\n };\n StructArrayLayout2i4i12.prototype.emplace = function emplace(i, v0, v1, v2, v3, v4, v5) {\n var o2 = i * 6;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.int16[o2 + 2] = v2;\n this.int16[o2 + 3] = v3;\n this.int16[o2 + 4] = v4;\n this.int16[o2 + 5] = v5;\n return i;\n };\n return StructArrayLayout2i4i12;\n}(StructArray);\nStructArrayLayout2i4i12.prototype.bytesPerElement = 12;\nregister('StructArrayLayout2i4i12', StructArrayLayout2i4i12);\nvar StructArrayLayout2i4ub8 = function (StructArray) {\n function StructArrayLayout2i4ub8() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout2i4ub8.__proto__ = StructArray;\n StructArrayLayout2i4ub8.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout2i4ub8.prototype.constructor = StructArrayLayout2i4ub8;\n StructArrayLayout2i4ub8.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n };\n StructArrayLayout2i4ub8.prototype.emplaceBack = function emplaceBack(v0, v1, v2, v3, v4, v5) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5);\n };\n StructArrayLayout2i4ub8.prototype.emplace = function emplace(i, v0, v1, v2, v3, v4, v5) {\n var o2 = i * 4;\n var o1 = i * 8;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.uint8[o1 + 4] = v2;\n this.uint8[o1 + 5] = v3;\n this.uint8[o1 + 6] = v4;\n this.uint8[o1 + 7] = v5;\n return i;\n };\n return StructArrayLayout2i4ub8;\n}(StructArray);\nStructArrayLayout2i4ub8.prototype.bytesPerElement = 8;\nregister('StructArrayLayout2i4ub8', StructArrayLayout2i4ub8);\nvar StructArrayLayout2f8 = function (StructArray) {\n function StructArrayLayout2f8() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout2f8.__proto__ = StructArray;\n StructArrayLayout2f8.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout2f8.prototype.constructor = StructArrayLayout2f8;\n StructArrayLayout2f8.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n };\n StructArrayLayout2f8.prototype.emplaceBack = function emplaceBack(v0, v1) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1);\n };\n StructArrayLayout2f8.prototype.emplace = function emplace(i, v0, v1) {\n var o4 = i * 2;\n this.float32[o4 + 0] = v0;\n this.float32[o4 + 1] = v1;\n return i;\n };\n return StructArrayLayout2f8;\n}(StructArray);\nStructArrayLayout2f8.prototype.bytesPerElement = 8;\nregister('StructArrayLayout2f8', StructArrayLayout2f8);\nvar StructArrayLayout10ui20 = function (StructArray) {\n function StructArrayLayout10ui20() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout10ui20.__proto__ = StructArray;\n StructArrayLayout10ui20.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout10ui20.prototype.constructor = StructArrayLayout10ui20;\n StructArrayLayout10ui20.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n };\n StructArrayLayout10ui20.prototype.emplaceBack = function emplaceBack(v0, v1, v2, v3, v4, v5, v6, v7, v8, v9) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8, v9);\n };\n StructArrayLayout10ui20.prototype.emplace = function emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8, v9) {\n var o2 = i * 10;\n this.uint16[o2 + 0] = v0;\n this.uint16[o2 + 1] = v1;\n this.uint16[o2 + 2] = v2;\n this.uint16[o2 + 3] = v3;\n this.uint16[o2 + 4] = v4;\n this.uint16[o2 + 5] = v5;\n this.uint16[o2 + 6] = v6;\n this.uint16[o2 + 7] = v7;\n this.uint16[o2 + 8] = v8;\n this.uint16[o2 + 9] = v9;\n return i;\n };\n return StructArrayLayout10ui20;\n}(StructArray);\nStructArrayLayout10ui20.prototype.bytesPerElement = 20;\nregister('StructArrayLayout10ui20', StructArrayLayout10ui20);\nvar StructArrayLayout4i4ui4i24 = function (StructArray) {\n function StructArrayLayout4i4ui4i24() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout4i4ui4i24.__proto__ = StructArray;\n StructArrayLayout4i4ui4i24.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout4i4ui4i24.prototype.constructor = StructArrayLayout4i4ui4i24;\n StructArrayLayout4i4ui4i24.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n };\n StructArrayLayout4i4ui4i24.prototype.emplaceBack = function emplaceBack(v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11);\n };\n StructArrayLayout4i4ui4i24.prototype.emplace = function emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11) {\n var o2 = i * 12;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.int16[o2 + 2] = v2;\n this.int16[o2 + 3] = v3;\n this.uint16[o2 + 4] = v4;\n this.uint16[o2 + 5] = v5;\n this.uint16[o2 + 6] = v6;\n this.uint16[o2 + 7] = v7;\n this.int16[o2 + 8] = v8;\n this.int16[o2 + 9] = v9;\n this.int16[o2 + 10] = v10;\n this.int16[o2 + 11] = v11;\n return i;\n };\n return StructArrayLayout4i4ui4i24;\n}(StructArray);\nStructArrayLayout4i4ui4i24.prototype.bytesPerElement = 24;\nregister('StructArrayLayout4i4ui4i24', StructArrayLayout4i4ui4i24);\nvar StructArrayLayout3f12 = function (StructArray) {\n function StructArrayLayout3f12() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout3f12.__proto__ = StructArray;\n StructArrayLayout3f12.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout3f12.prototype.constructor = StructArrayLayout3f12;\n StructArrayLayout3f12.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n };\n StructArrayLayout3f12.prototype.emplaceBack = function emplaceBack(v0, v1, v2) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2);\n };\n StructArrayLayout3f12.prototype.emplace = function emplace(i, v0, v1, v2) {\n var o4 = i * 3;\n this.float32[o4 + 0] = v0;\n this.float32[o4 + 1] = v1;\n this.float32[o4 + 2] = v2;\n return i;\n };\n return StructArrayLayout3f12;\n}(StructArray);\nStructArrayLayout3f12.prototype.bytesPerElement = 12;\nregister('StructArrayLayout3f12', StructArrayLayout3f12);\nvar StructArrayLayout1ul4 = function (StructArray) {\n function StructArrayLayout1ul4() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout1ul4.__proto__ = StructArray;\n StructArrayLayout1ul4.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout1ul4.prototype.constructor = StructArrayLayout1ul4;\n StructArrayLayout1ul4.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.uint32 = new Uint32Array(this.arrayBuffer);\n };\n StructArrayLayout1ul4.prototype.emplaceBack = function emplaceBack(v0) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0);\n };\n StructArrayLayout1ul4.prototype.emplace = function emplace(i, v0) {\n var o4 = i * 1;\n this.uint32[o4 + 0] = v0;\n return i;\n };\n return StructArrayLayout1ul4;\n}(StructArray);\nStructArrayLayout1ul4.prototype.bytesPerElement = 4;\nregister('StructArrayLayout1ul4', StructArrayLayout1ul4);\nvar StructArrayLayout6i1ul2ui20 = function (StructArray) {\n function StructArrayLayout6i1ul2ui20() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout6i1ul2ui20.__proto__ = StructArray;\n StructArrayLayout6i1ul2ui20.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout6i1ul2ui20.prototype.constructor = StructArrayLayout6i1ul2ui20;\n StructArrayLayout6i1ul2ui20.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n this.uint32 = new Uint32Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n };\n StructArrayLayout6i1ul2ui20.prototype.emplaceBack = function emplaceBack(v0, v1, v2, v3, v4, v5, v6, v7, v8) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8);\n };\n StructArrayLayout6i1ul2ui20.prototype.emplace = function emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8) {\n var o2 = i * 10;\n var o4 = i * 5;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.int16[o2 + 2] = v2;\n this.int16[o2 + 3] = v3;\n this.int16[o2 + 4] = v4;\n this.int16[o2 + 5] = v5;\n this.uint32[o4 + 3] = v6;\n this.uint16[o2 + 8] = v7;\n this.uint16[o2 + 9] = v8;\n return i;\n };\n return StructArrayLayout6i1ul2ui20;\n}(StructArray);\nStructArrayLayout6i1ul2ui20.prototype.bytesPerElement = 20;\nregister('StructArrayLayout6i1ul2ui20', StructArrayLayout6i1ul2ui20);\nvar StructArrayLayout2i2i2i12 = function (StructArray) {\n function StructArrayLayout2i2i2i12() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout2i2i2i12.__proto__ = StructArray;\n StructArrayLayout2i2i2i12.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout2i2i2i12.prototype.constructor = StructArrayLayout2i2i2i12;\n StructArrayLayout2i2i2i12.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n };\n StructArrayLayout2i2i2i12.prototype.emplaceBack = function emplaceBack(v0, v1, v2, v3, v4, v5) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5);\n };\n StructArrayLayout2i2i2i12.prototype.emplace = function emplace(i, v0, v1, v2, v3, v4, v5) {\n var o2 = i * 6;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.int16[o2 + 2] = v2;\n this.int16[o2 + 3] = v3;\n this.int16[o2 + 4] = v4;\n this.int16[o2 + 5] = v5;\n return i;\n };\n return StructArrayLayout2i2i2i12;\n}(StructArray);\nStructArrayLayout2i2i2i12.prototype.bytesPerElement = 12;\nregister('StructArrayLayout2i2i2i12', StructArrayLayout2i2i2i12);\nvar StructArrayLayout2f1f2i16 = function (StructArray) {\n function StructArrayLayout2f1f2i16() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout2f1f2i16.__proto__ = StructArray;\n StructArrayLayout2f1f2i16.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout2f1f2i16.prototype.constructor = StructArrayLayout2f1f2i16;\n StructArrayLayout2f1f2i16.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n };\n StructArrayLayout2f1f2i16.prototype.emplaceBack = function emplaceBack(v0, v1, v2, v3, v4) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4);\n };\n StructArrayLayout2f1f2i16.prototype.emplace = function emplace(i, v0, v1, v2, v3, v4) {\n var o4 = i * 4;\n var o2 = i * 8;\n this.float32[o4 + 0] = v0;\n this.float32[o4 + 1] = v1;\n this.float32[o4 + 2] = v2;\n this.int16[o2 + 6] = v3;\n this.int16[o2 + 7] = v4;\n return i;\n };\n return StructArrayLayout2f1f2i16;\n}(StructArray);\nStructArrayLayout2f1f2i16.prototype.bytesPerElement = 16;\nregister('StructArrayLayout2f1f2i16', StructArrayLayout2f1f2i16);\nvar StructArrayLayout2ub2f12 = function (StructArray) {\n function StructArrayLayout2ub2f12() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout2ub2f12.__proto__ = StructArray;\n StructArrayLayout2ub2f12.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout2ub2f12.prototype.constructor = StructArrayLayout2ub2f12;\n StructArrayLayout2ub2f12.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n };\n StructArrayLayout2ub2f12.prototype.emplaceBack = function emplaceBack(v0, v1, v2, v3) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3);\n };\n StructArrayLayout2ub2f12.prototype.emplace = function emplace(i, v0, v1, v2, v3) {\n var o1 = i * 12;\n var o4 = i * 3;\n this.uint8[o1 + 0] = v0;\n this.uint8[o1 + 1] = v1;\n this.float32[o4 + 1] = v2;\n this.float32[o4 + 2] = v3;\n return i;\n };\n return StructArrayLayout2ub2f12;\n}(StructArray);\nStructArrayLayout2ub2f12.prototype.bytesPerElement = 12;\nregister('StructArrayLayout2ub2f12', StructArrayLayout2ub2f12);\nvar StructArrayLayout3ui6 = function (StructArray) {\n function StructArrayLayout3ui6() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout3ui6.__proto__ = StructArray;\n StructArrayLayout3ui6.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout3ui6.prototype.constructor = StructArrayLayout3ui6;\n StructArrayLayout3ui6.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n };\n StructArrayLayout3ui6.prototype.emplaceBack = function emplaceBack(v0, v1, v2) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2);\n };\n StructArrayLayout3ui6.prototype.emplace = function emplace(i, v0, v1, v2) {\n var o2 = i * 3;\n this.uint16[o2 + 0] = v0;\n this.uint16[o2 + 1] = v1;\n this.uint16[o2 + 2] = v2;\n return i;\n };\n return StructArrayLayout3ui6;\n}(StructArray);\nStructArrayLayout3ui6.prototype.bytesPerElement = 6;\nregister('StructArrayLayout3ui6', StructArrayLayout3ui6);\nvar StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48 = function (StructArray) {\n function StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48.__proto__ = StructArray;\n StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48.prototype.constructor = StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48;\n StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n this.uint32 = new Uint32Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n };\n StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48.prototype.emplaceBack = function emplaceBack(v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15, v16) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15, v16);\n };\n StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48.prototype.emplace = function emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15, v16) {\n var o2 = i * 24;\n var o4 = i * 12;\n var o1 = i * 48;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.uint16[o2 + 2] = v2;\n this.uint16[o2 + 3] = v3;\n this.uint32[o4 + 2] = v4;\n this.uint32[o4 + 3] = v5;\n this.uint32[o4 + 4] = v6;\n this.uint16[o2 + 10] = v7;\n this.uint16[o2 + 11] = v8;\n this.uint16[o2 + 12] = v9;\n this.float32[o4 + 7] = v10;\n this.float32[o4 + 8] = v11;\n this.uint8[o1 + 36] = v12;\n this.uint8[o1 + 37] = v13;\n this.uint8[o1 + 38] = v14;\n this.uint32[o4 + 10] = v15;\n this.int16[o2 + 22] = v16;\n return i;\n };\n return StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48;\n}(StructArray);\nStructArrayLayout2i2ui3ul3ui2f3ub1ul1i48.prototype.bytesPerElement = 48;\nregister('StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48', StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48);\nvar StructArrayLayout8i15ui1ul4f68 = function (StructArray) {\n function StructArrayLayout8i15ui1ul4f68() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout8i15ui1ul4f68.__proto__ = StructArray;\n StructArrayLayout8i15ui1ul4f68.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout8i15ui1ul4f68.prototype.constructor = StructArrayLayout8i15ui1ul4f68;\n StructArrayLayout8i15ui1ul4f68.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n this.uint32 = new Uint32Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n };\n StructArrayLayout8i15ui1ul4f68.prototype.emplaceBack = function emplaceBack(v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15, v16, v17, v18, v19, v20, v21, v22, v23, v24, v25, v26, v27) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15, v16, v17, v18, v19, v20, v21, v22, v23, v24, v25, v26, v27);\n };\n StructArrayLayout8i15ui1ul4f68.prototype.emplace = function emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15, v16, v17, v18, v19, v20, v21, v22, v23, v24, v25, v26, v27) {\n var o2 = i * 34;\n var o4 = i * 17;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.int16[o2 + 2] = v2;\n this.int16[o2 + 3] = v3;\n this.int16[o2 + 4] = v4;\n this.int16[o2 + 5] = v5;\n this.int16[o2 + 6] = v6;\n this.int16[o2 + 7] = v7;\n this.uint16[o2 + 8] = v8;\n this.uint16[o2 + 9] = v9;\n this.uint16[o2 + 10] = v10;\n this.uint16[o2 + 11] = v11;\n this.uint16[o2 + 12] = v12;\n this.uint16[o2 + 13] = v13;\n this.uint16[o2 + 14] = v14;\n this.uint16[o2 + 15] = v15;\n this.uint16[o2 + 16] = v16;\n this.uint16[o2 + 17] = v17;\n this.uint16[o2 + 18] = v18;\n this.uint16[o2 + 19] = v19;\n this.uint16[o2 + 20] = v20;\n this.uint16[o2 + 21] = v21;\n this.uint16[o2 + 22] = v22;\n this.uint32[o4 + 12] = v23;\n this.float32[o4 + 13] = v24;\n this.float32[o4 + 14] = v25;\n this.float32[o4 + 15] = v26;\n this.float32[o4 + 16] = v27;\n return i;\n };\n return StructArrayLayout8i15ui1ul4f68;\n}(StructArray);\nStructArrayLayout8i15ui1ul4f68.prototype.bytesPerElement = 68;\nregister('StructArrayLayout8i15ui1ul4f68', StructArrayLayout8i15ui1ul4f68);\nvar StructArrayLayout1f4 = function (StructArray) {\n function StructArrayLayout1f4() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout1f4.__proto__ = StructArray;\n StructArrayLayout1f4.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout1f4.prototype.constructor = StructArrayLayout1f4;\n StructArrayLayout1f4.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n };\n StructArrayLayout1f4.prototype.emplaceBack = function emplaceBack(v0) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0);\n };\n StructArrayLayout1f4.prototype.emplace = function emplace(i, v0) {\n var o4 = i * 1;\n this.float32[o4 + 0] = v0;\n return i;\n };\n return StructArrayLayout1f4;\n}(StructArray);\nStructArrayLayout1f4.prototype.bytesPerElement = 4;\nregister('StructArrayLayout1f4', StructArrayLayout1f4);\nvar StructArrayLayout3i6 = function (StructArray) {\n function StructArrayLayout3i6() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout3i6.__proto__ = StructArray;\n StructArrayLayout3i6.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout3i6.prototype.constructor = StructArrayLayout3i6;\n StructArrayLayout3i6.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n };\n StructArrayLayout3i6.prototype.emplaceBack = function emplaceBack(v0, v1, v2) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2);\n };\n StructArrayLayout3i6.prototype.emplace = function emplace(i, v0, v1, v2) {\n var o2 = i * 3;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.int16[o2 + 2] = v2;\n return i;\n };\n return StructArrayLayout3i6;\n}(StructArray);\nStructArrayLayout3i6.prototype.bytesPerElement = 6;\nregister('StructArrayLayout3i6', StructArrayLayout3i6);\nvar StructArrayLayout1ul2ui8 = function (StructArray) {\n function StructArrayLayout1ul2ui8() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout1ul2ui8.__proto__ = StructArray;\n StructArrayLayout1ul2ui8.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout1ul2ui8.prototype.constructor = StructArrayLayout1ul2ui8;\n StructArrayLayout1ul2ui8.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.uint32 = new Uint32Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n };\n StructArrayLayout1ul2ui8.prototype.emplaceBack = function emplaceBack(v0, v1, v2) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2);\n };\n StructArrayLayout1ul2ui8.prototype.emplace = function emplace(i, v0, v1, v2) {\n var o4 = i * 2;\n var o2 = i * 4;\n this.uint32[o4 + 0] = v0;\n this.uint16[o2 + 2] = v1;\n this.uint16[o2 + 3] = v2;\n return i;\n };\n return StructArrayLayout1ul2ui8;\n}(StructArray);\nStructArrayLayout1ul2ui8.prototype.bytesPerElement = 8;\nregister('StructArrayLayout1ul2ui8', StructArrayLayout1ul2ui8);\nvar StructArrayLayout2ui4 = function (StructArray) {\n function StructArrayLayout2ui4() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout2ui4.__proto__ = StructArray;\n StructArrayLayout2ui4.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout2ui4.prototype.constructor = StructArrayLayout2ui4;\n StructArrayLayout2ui4.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n };\n StructArrayLayout2ui4.prototype.emplaceBack = function emplaceBack(v0, v1) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1);\n };\n StructArrayLayout2ui4.prototype.emplace = function emplace(i, v0, v1) {\n var o2 = i * 2;\n this.uint16[o2 + 0] = v0;\n this.uint16[o2 + 1] = v1;\n return i;\n };\n return StructArrayLayout2ui4;\n}(StructArray);\nStructArrayLayout2ui4.prototype.bytesPerElement = 4;\nregister('StructArrayLayout2ui4', StructArrayLayout2ui4);\nvar StructArrayLayout1ui2 = function (StructArray) {\n function StructArrayLayout1ui2() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout1ui2.__proto__ = StructArray;\n StructArrayLayout1ui2.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout1ui2.prototype.constructor = StructArrayLayout1ui2;\n StructArrayLayout1ui2.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n };\n StructArrayLayout1ui2.prototype.emplaceBack = function emplaceBack(v0) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0);\n };\n StructArrayLayout1ui2.prototype.emplace = function emplace(i, v0) {\n var o2 = i * 1;\n this.uint16[o2 + 0] = v0;\n return i;\n };\n return StructArrayLayout1ui2;\n}(StructArray);\nStructArrayLayout1ui2.prototype.bytesPerElement = 2;\nregister('StructArrayLayout1ui2', StructArrayLayout1ui2);\nvar StructArrayLayout4f16 = function (StructArray) {\n function StructArrayLayout4f16() {\n StructArray.apply(this, arguments);\n }\n if (StructArray)\n StructArrayLayout4f16.__proto__ = StructArray;\n StructArrayLayout4f16.prototype = Object.create(StructArray && StructArray.prototype);\n StructArrayLayout4f16.prototype.constructor = StructArrayLayout4f16;\n StructArrayLayout4f16.prototype._refreshViews = function _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n };\n StructArrayLayout4f16.prototype.emplaceBack = function emplaceBack(v0, v1, v2, v3) {\n var i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3);\n };\n StructArrayLayout4f16.prototype.emplace = function emplace(i, v0, v1, v2, v3) {\n var o4 = i * 4;\n this.float32[o4 + 0] = v0;\n this.float32[o4 + 1] = v1;\n this.float32[o4 + 2] = v2;\n this.float32[o4 + 3] = v3;\n return i;\n };\n return StructArrayLayout4f16;\n}(StructArray);\nStructArrayLayout4f16.prototype.bytesPerElement = 16;\nregister('StructArrayLayout4f16', StructArrayLayout4f16);\nvar CollisionBoxStruct = function (Struct) {\n function CollisionBoxStruct() {\n Struct.apply(this, arguments);\n }\n if (Struct)\n CollisionBoxStruct.__proto__ = Struct;\n CollisionBoxStruct.prototype = Object.create(Struct && Struct.prototype);\n CollisionBoxStruct.prototype.constructor = CollisionBoxStruct;\n var prototypeAccessors = {\n anchorPointX: { configurable: true },\n anchorPointY: { configurable: true },\n x1: { configurable: true },\n y1: { configurable: true },\n x2: { configurable: true },\n y2: { configurable: true },\n featureIndex: { configurable: true },\n sourceLayerIndex: { configurable: true },\n bucketIndex: { configurable: true },\n anchorPoint: { configurable: true }\n };\n prototypeAccessors.anchorPointX.get = function () {\n return this._structArray.int16[this._pos2 + 0];\n };\n prototypeAccessors.anchorPointY.get = function () {\n return this._structArray.int16[this._pos2 + 1];\n };\n prototypeAccessors.x1.get = function () {\n return this._structArray.int16[this._pos2 + 2];\n };\n prototypeAccessors.y1.get = function () {\n return this._structArray.int16[this._pos2 + 3];\n };\n prototypeAccessors.x2.get = function () {\n return this._structArray.int16[this._pos2 + 4];\n };\n prototypeAccessors.y2.get = function () {\n return this._structArray.int16[this._pos2 + 5];\n };\n prototypeAccessors.featureIndex.get = function () {\n return this._structArray.uint32[this._pos4 + 3];\n };\n prototypeAccessors.sourceLayerIndex.get = function () {\n return this._structArray.uint16[this._pos2 + 8];\n };\n prototypeAccessors.bucketIndex.get = function () {\n return this._structArray.uint16[this._pos2 + 9];\n };\n prototypeAccessors.anchorPoint.get = function () {\n return new pointGeometry(this.anchorPointX, this.anchorPointY);\n };\n Object.defineProperties(CollisionBoxStruct.prototype, prototypeAccessors);\n return CollisionBoxStruct;\n}(Struct);\nCollisionBoxStruct.prototype.size = 20;\nvar CollisionBoxArray = function (StructArrayLayout6i1ul2ui20) {\n function CollisionBoxArray() {\n StructArrayLayout6i1ul2ui20.apply(this, arguments);\n }\n if (StructArrayLayout6i1ul2ui20)\n CollisionBoxArray.__proto__ = StructArrayLayout6i1ul2ui20;\n CollisionBoxArray.prototype = Object.create(StructArrayLayout6i1ul2ui20 && StructArrayLayout6i1ul2ui20.prototype);\n CollisionBoxArray.prototype.constructor = CollisionBoxArray;\n CollisionBoxArray.prototype.get = function get(index) {\n return new CollisionBoxStruct(this, index);\n };\n return CollisionBoxArray;\n}(StructArrayLayout6i1ul2ui20);\nregister('CollisionBoxArray', CollisionBoxArray);\nvar PlacedSymbolStruct = function (Struct) {\n function PlacedSymbolStruct() {\n Struct.apply(this, arguments);\n }\n if (Struct)\n PlacedSymbolStruct.__proto__ = Struct;\n PlacedSymbolStruct.prototype = Object.create(Struct && Struct.prototype);\n PlacedSymbolStruct.prototype.constructor = PlacedSymbolStruct;\n var prototypeAccessors$1 = {\n anchorX: { configurable: true },\n anchorY: { configurable: true },\n glyphStartIndex: { configurable: true },\n numGlyphs: { configurable: true },\n vertexStartIndex: { configurable: true },\n lineStartIndex: { configurable: true },\n lineLength: { configurable: true },\n segment: { configurable: true },\n lowerSize: { configurable: true },\n upperSize: { configurable: true },\n lineOffsetX: { configurable: true },\n lineOffsetY: { configurable: true },\n writingMode: { configurable: true },\n placedOrientation: { configurable: true },\n hidden: { configurable: true },\n crossTileID: { configurable: true },\n associatedIconIndex: { configurable: true }\n };\n prototypeAccessors$1.anchorX.get = function () {\n return this._structArray.int16[this._pos2 + 0];\n };\n prototypeAccessors$1.anchorY.get = function () {\n return this._structArray.int16[this._pos2 + 1];\n };\n prototypeAccessors$1.glyphStartIndex.get = function () {\n return this._structArray.uint16[this._pos2 + 2];\n };\n prototypeAccessors$1.numGlyphs.get = function () {\n return this._structArray.uint16[this._pos2 + 3];\n };\n prototypeAccessors$1.vertexStartIndex.get = function () {\n return this._structArray.uint32[this._pos4 + 2];\n };\n prototypeAccessors$1.lineStartIndex.get = function () {\n return this._structArray.uint32[this._pos4 + 3];\n };\n prototypeAccessors$1.lineLength.get = function () {\n return this._structArray.uint32[this._pos4 + 4];\n };\n prototypeAccessors$1.segment.get = function () {\n return this._structArray.uint16[this._pos2 + 10];\n };\n prototypeAccessors$1.lowerSize.get = function () {\n return this._structArray.uint16[this._pos2 + 11];\n };\n prototypeAccessors$1.upperSize.get = function () {\n return this._structArray.uint16[this._pos2 + 12];\n };\n prototypeAccessors$1.lineOffsetX.get = function () {\n return this._structArray.float32[this._pos4 + 7];\n };\n prototypeAccessors$1.lineOffsetY.get = function () {\n return this._structArray.float32[this._pos4 + 8];\n };\n prototypeAccessors$1.writingMode.get = function () {\n return this._structArray.uint8[this._pos1 + 36];\n };\n prototypeAccessors$1.placedOrientation.get = function () {\n return this._structArray.uint8[this._pos1 + 37];\n };\n prototypeAccessors$1.placedOrientation.set = function (x) {\n this._structArray.uint8[this._pos1 + 37] = x;\n };\n prototypeAccessors$1.hidden.get = function () {\n return this._structArray.uint8[this._pos1 + 38];\n };\n prototypeAccessors$1.hidden.set = function (x) {\n this._structArray.uint8[this._pos1 + 38] = x;\n };\n prototypeAccessors$1.crossTileID.get = function () {\n return this._structArray.uint32[this._pos4 + 10];\n };\n prototypeAccessors$1.crossTileID.set = function (x) {\n this._structArray.uint32[this._pos4 + 10] = x;\n };\n prototypeAccessors$1.associatedIconIndex.get = function () {\n return this._structArray.int16[this._pos2 + 22];\n };\n Object.defineProperties(PlacedSymbolStruct.prototype, prototypeAccessors$1);\n return PlacedSymbolStruct;\n}(Struct);\nPlacedSymbolStruct.prototype.size = 48;\nvar PlacedSymbolArray = function (StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48) {\n function PlacedSymbolArray() {\n StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48.apply(this, arguments);\n }\n if (StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48)\n PlacedSymbolArray.__proto__ = StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48;\n PlacedSymbolArray.prototype = Object.create(StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48 && StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48.prototype);\n PlacedSymbolArray.prototype.constructor = PlacedSymbolArray;\n PlacedSymbolArray.prototype.get = function get(index) {\n return new PlacedSymbolStruct(this, index);\n };\n return PlacedSymbolArray;\n}(StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48);\nregister('PlacedSymbolArray', PlacedSymbolArray);\nvar SymbolInstanceStruct = function (Struct) {\n function SymbolInstanceStruct() {\n Struct.apply(this, arguments);\n }\n if (Struct)\n SymbolInstanceStruct.__proto__ = Struct;\n SymbolInstanceStruct.prototype = Object.create(Struct && Struct.prototype);\n SymbolInstanceStruct.prototype.constructor = SymbolInstanceStruct;\n var prototypeAccessors$2 = {\n anchorX: { configurable: true },\n anchorY: { configurable: true },\n rightJustifiedTextSymbolIndex: { configurable: true },\n centerJustifiedTextSymbolIndex: { configurable: true },\n leftJustifiedTextSymbolIndex: { configurable: true },\n verticalPlacedTextSymbolIndex: { configurable: true },\n placedIconSymbolIndex: { configurable: true },\n verticalPlacedIconSymbolIndex: { configurable: true },\n key: { configurable: true },\n textBoxStartIndex: { configurable: true },\n textBoxEndIndex: { configurable: true },\n verticalTextBoxStartIndex: { configurable: true },\n verticalTextBoxEndIndex: { configurable: true },\n iconBoxStartIndex: { configurable: true },\n iconBoxEndIndex: { configurable: true },\n verticalIconBoxStartIndex: { configurable: true },\n verticalIconBoxEndIndex: { configurable: true },\n featureIndex: { configurable: true },\n numHorizontalGlyphVertices: { configurable: true },\n numVerticalGlyphVertices: { configurable: true },\n numIconVertices: { configurable: true },\n numVerticalIconVertices: { configurable: true },\n useRuntimeCollisionCircles: { configurable: true },\n crossTileID: { configurable: true },\n textBoxScale: { configurable: true },\n textOffset0: { configurable: true },\n textOffset1: { configurable: true },\n collisionCircleDiameter: { configurable: true }\n };\n prototypeAccessors$2.anchorX.get = function () {\n return this._structArray.int16[this._pos2 + 0];\n };\n prototypeAccessors$2.anchorY.get = function () {\n return this._structArray.int16[this._pos2 + 1];\n };\n prototypeAccessors$2.rightJustifiedTextSymbolIndex.get = function () {\n return this._structArray.int16[this._pos2 + 2];\n };\n prototypeAccessors$2.centerJustifiedTextSymbolIndex.get = function () {\n return this._structArray.int16[this._pos2 + 3];\n };\n prototypeAccessors$2.leftJustifiedTextSymbolIndex.get = function () {\n return this._structArray.int16[this._pos2 + 4];\n };\n prototypeAccessors$2.verticalPlacedTextSymbolIndex.get = function () {\n return this._structArray.int16[this._pos2 + 5];\n };\n prototypeAccessors$2.placedIconSymbolIndex.get = function () {\n return this._structArray.int16[this._pos2 + 6];\n };\n prototypeAccessors$2.verticalPlacedIconSymbolIndex.get = function () {\n return this._structArray.int16[this._pos2 + 7];\n };\n prototypeAccessors$2.key.get = function () {\n return this._structArray.uint16[this._pos2 + 8];\n };\n prototypeAccessors$2.textBoxStartIndex.get = function () {\n return this._structArray.uint16[this._pos2 + 9];\n };\n prototypeAccessors$2.textBoxEndIndex.get = function () {\n return this._structArray.uint16[this._pos2 + 10];\n };\n prototypeAccessors$2.verticalTextBoxStartIndex.get = function () {\n return this._structArray.uint16[this._pos2 + 11];\n };\n prototypeAccessors$2.verticalTextBoxEndIndex.get = function () {\n return this._structArray.uint16[this._pos2 + 12];\n };\n prototypeAccessors$2.iconBoxStartIndex.get = function () {\n return this._structArray.uint16[this._pos2 + 13];\n };\n prototypeAccessors$2.iconBoxEndIndex.get = function () {\n return this._structArray.uint16[this._pos2 + 14];\n };\n prototypeAccessors$2.verticalIconBoxStartIndex.get = function () {\n return this._structArray.uint16[this._pos2 + 15];\n };\n prototypeAccessors$2.verticalIconBoxEndIndex.get = function () {\n return this._structArray.uint16[this._pos2 + 16];\n };\n prototypeAccessors$2.featureIndex.get = function () {\n return this._structArray.uint16[this._pos2 + 17];\n };\n prototypeAccessors$2.numHorizontalGlyphVertices.get = function () {\n return this._structArray.uint16[this._pos2 + 18];\n };\n prototypeAccessors$2.numVerticalGlyphVertices.get = function () {\n return this._structArray.uint16[this._pos2 + 19];\n };\n prototypeAccessors$2.numIconVertices.get = function () {\n return this._structArray.uint16[this._pos2 + 20];\n };\n prototypeAccessors$2.numVerticalIconVertices.get = function () {\n return this._structArray.uint16[this._pos2 + 21];\n };\n prototypeAccessors$2.useRuntimeCollisionCircles.get = function () {\n return this._structArray.uint16[this._pos2 + 22];\n };\n prototypeAccessors$2.crossTileID.get = function () {\n return this._structArray.uint32[this._pos4 + 12];\n };\n prototypeAccessors$2.crossTileID.set = function (x) {\n this._structArray.uint32[this._pos4 + 12] = x;\n };\n prototypeAccessors$2.textBoxScale.get = function () {\n return this._structArray.float32[this._pos4 + 13];\n };\n prototypeAccessors$2.textOffset0.get = function () {\n return this._structArray.float32[this._pos4 + 14];\n };\n prototypeAccessors$2.textOffset1.get = function () {\n return this._structArray.float32[this._pos4 + 15];\n };\n prototypeAccessors$2.collisionCircleDiameter.get = function () {\n return this._structArray.float32[this._pos4 + 16];\n };\n Object.defineProperties(SymbolInstanceStruct.prototype, prototypeAccessors$2);\n return SymbolInstanceStruct;\n}(Struct);\nSymbolInstanceStruct.prototype.size = 68;\nvar SymbolInstanceArray = function (StructArrayLayout8i15ui1ul4f68) {\n function SymbolInstanceArray() {\n StructArrayLayout8i15ui1ul4f68.apply(this, arguments);\n }\n if (StructArrayLayout8i15ui1ul4f68)\n SymbolInstanceArray.__proto__ = StructArrayLayout8i15ui1ul4f68;\n SymbolInstanceArray.prototype = Object.create(StructArrayLayout8i15ui1ul4f68 && StructArrayLayout8i15ui1ul4f68.prototype);\n SymbolInstanceArray.prototype.constructor = SymbolInstanceArray;\n SymbolInstanceArray.prototype.get = function get(index) {\n return new SymbolInstanceStruct(this, index);\n };\n return SymbolInstanceArray;\n}(StructArrayLayout8i15ui1ul4f68);\nregister('SymbolInstanceArray', SymbolInstanceArray);\nvar GlyphOffsetArray = function (StructArrayLayout1f4) {\n function GlyphOffsetArray() {\n StructArrayLayout1f4.apply(this, arguments);\n }\n if (StructArrayLayout1f4)\n GlyphOffsetArray.__proto__ = StructArrayLayout1f4;\n GlyphOffsetArray.prototype = Object.create(StructArrayLayout1f4 && StructArrayLayout1f4.prototype);\n GlyphOffsetArray.prototype.constructor = GlyphOffsetArray;\n GlyphOffsetArray.prototype.getoffsetX = function getoffsetX(index) {\n return this.float32[index * 1 + 0];\n };\n return GlyphOffsetArray;\n}(StructArrayLayout1f4);\nregister('GlyphOffsetArray', GlyphOffsetArray);\nvar SymbolLineVertexArray = function (StructArrayLayout3i6) {\n function SymbolLineVertexArray() {\n StructArrayLayout3i6.apply(this, arguments);\n }\n if (StructArrayLayout3i6)\n SymbolLineVertexArray.__proto__ = StructArrayLayout3i6;\n SymbolLineVertexArray.prototype = Object.create(StructArrayLayout3i6 && StructArrayLayout3i6.prototype);\n SymbolLineVertexArray.prototype.constructor = SymbolLineVertexArray;\n SymbolLineVertexArray.prototype.getx = function getx(index) {\n return this.int16[index * 3 + 0];\n };\n SymbolLineVertexArray.prototype.gety = function gety(index) {\n return this.int16[index * 3 + 1];\n };\n SymbolLineVertexArray.prototype.gettileUnitDistanceFromAnchor = function gettileUnitDistanceFromAnchor(index) {\n return this.int16[index * 3 + 2];\n };\n return SymbolLineVertexArray;\n}(StructArrayLayout3i6);\nregister('SymbolLineVertexArray', SymbolLineVertexArray);\nvar FeatureIndexStruct = function (Struct) {\n function FeatureIndexStruct() {\n Struct.apply(this, arguments);\n }\n if (Struct)\n FeatureIndexStruct.__proto__ = Struct;\n FeatureIndexStruct.prototype = Object.create(Struct && Struct.prototype);\n FeatureIndexStruct.prototype.constructor = FeatureIndexStruct;\n var prototypeAccessors$3 = {\n featureIndex: { configurable: true },\n sourceLayerIndex: { configurable: true },\n bucketIndex: { configurable: true }\n };\n prototypeAccessors$3.featureIndex.get = function () {\n return this._structArray.uint32[this._pos4 + 0];\n };\n prototypeAccessors$3.sourceLayerIndex.get = function () {\n return this._structArray.uint16[this._pos2 + 2];\n };\n prototypeAccessors$3.bucketIndex.get = function () {\n return this._structArray.uint16[this._pos2 + 3];\n };\n Object.defineProperties(FeatureIndexStruct.prototype, prototypeAccessors$3);\n return FeatureIndexStruct;\n}(Struct);\nFeatureIndexStruct.prototype.size = 8;\nvar FeatureIndexArray = function (StructArrayLayout1ul2ui8) {\n function FeatureIndexArray() {\n StructArrayLayout1ul2ui8.apply(this, arguments);\n }\n if (StructArrayLayout1ul2ui8)\n FeatureIndexArray.__proto__ = StructArrayLayout1ul2ui8;\n FeatureIndexArray.prototype = Object.create(StructArrayLayout1ul2ui8 && StructArrayLayout1ul2ui8.prototype);\n FeatureIndexArray.prototype.constructor = FeatureIndexArray;\n FeatureIndexArray.prototype.get = function get(index) {\n return new FeatureIndexStruct(this, index);\n };\n return FeatureIndexArray;\n}(StructArrayLayout1ul2ui8);\nregister('FeatureIndexArray', FeatureIndexArray);\n\nvar layout$1 = createLayout([{\n name: 'a_pos',\n components: 2,\n type: 'Int16'\n }], 4);\nvar members = layout$1.members;\n\nvar SegmentVector = function SegmentVector(segments) {\n if (segments === void 0)\n segments = [];\n this.segments = segments;\n};\nSegmentVector.prototype.prepareSegment = function prepareSegment(numVertices, layoutVertexArray, indexArray, sortKey) {\n var segment = this.segments[this.segments.length - 1];\n if (numVertices > SegmentVector.MAX_VERTEX_ARRAY_LENGTH) {\n warnOnce('Max vertices per segment is ' + SegmentVector.MAX_VERTEX_ARRAY_LENGTH + ': bucket requested ' + numVertices);\n }\n if (!segment || segment.vertexLength + numVertices > SegmentVector.MAX_VERTEX_ARRAY_LENGTH || segment.sortKey !== sortKey) {\n segment = {\n vertexOffset: layoutVertexArray.length,\n primitiveOffset: indexArray.length,\n vertexLength: 0,\n primitiveLength: 0\n };\n if (sortKey !== undefined) {\n segment.sortKey = sortKey;\n }\n this.segments.push(segment);\n }\n return segment;\n};\nSegmentVector.prototype.get = function get() {\n return this.segments;\n};\nSegmentVector.prototype.destroy = function destroy() {\n for (var i = 0, list = this.segments; i < list.length; i += 1) {\n var segment = list[i];\n for (var k in segment.vaos) {\n segment.vaos[k].destroy();\n }\n }\n};\nSegmentVector.simpleSegment = function simpleSegment(vertexOffset, primitiveOffset, vertexLength, primitiveLength) {\n return new SegmentVector([{\n vertexOffset: vertexOffset,\n primitiveOffset: primitiveOffset,\n vertexLength: vertexLength,\n primitiveLength: primitiveLength,\n vaos: {},\n sortKey: 0\n }]);\n};\nSegmentVector.MAX_VERTEX_ARRAY_LENGTH = Math.pow(2, 16) - 1;\nregister('SegmentVector', SegmentVector);\n\nfunction packUint8ToFloat(a, b) {\n a = clamp(Math.floor(a), 0, 255);\n b = clamp(Math.floor(b), 0, 255);\n return 256 * a + b;\n}\n\nvar patternAttributes = createLayout([\n {\n name: 'a_pattern_from',\n components: 4,\n type: 'Uint16'\n },\n {\n name: 'a_pattern_to',\n components: 4,\n type: 'Uint16'\n },\n {\n name: 'a_pixel_ratio_from',\n components: 1,\n type: 'Uint16'\n },\n {\n name: 'a_pixel_ratio_to',\n components: 1,\n type: 'Uint16'\n }\n]);\n\nvar murmurhash3_gc = createCommonjsModule(function (module) {\nfunction murmurhash3_32_gc(key, seed) {\n var remainder, bytes, h1, h1b, c1, c2, k1, i;\n remainder = key.length & 3;\n bytes = key.length - remainder;\n h1 = seed;\n c1 = 3432918353;\n c2 = 461845907;\n i = 0;\n while (i < bytes) {\n k1 = key.charCodeAt(i) & 255 | (key.charCodeAt(++i) & 255) << 8 | (key.charCodeAt(++i) & 255) << 16 | (key.charCodeAt(++i) & 255) << 24;\n ++i;\n k1 = (k1 & 65535) * c1 + (((k1 >>> 16) * c1 & 65535) << 16) & 4294967295;\n k1 = k1 << 15 | k1 >>> 17;\n k1 = (k1 & 65535) * c2 + (((k1 >>> 16) * c2 & 65535) << 16) & 4294967295;\n h1 ^= k1;\n h1 = h1 << 13 | h1 >>> 19;\n h1b = (h1 & 65535) * 5 + (((h1 >>> 16) * 5 & 65535) << 16) & 4294967295;\n h1 = (h1b & 65535) + 27492 + (((h1b >>> 16) + 58964 & 65535) << 16);\n }\n k1 = 0;\n switch (remainder) {\n case 3:\n k1 ^= (key.charCodeAt(i + 2) & 255) << 16;\n case 2:\n k1 ^= (key.charCodeAt(i + 1) & 255) << 8;\n case 1:\n k1 ^= key.charCodeAt(i) & 255;\n k1 = (k1 & 65535) * c1 + (((k1 >>> 16) * c1 & 65535) << 16) & 4294967295;\n k1 = k1 << 15 | k1 >>> 17;\n k1 = (k1 & 65535) * c2 + (((k1 >>> 16) * c2 & 65535) << 16) & 4294967295;\n h1 ^= k1;\n }\n h1 ^= key.length;\n h1 ^= h1 >>> 16;\n h1 = (h1 & 65535) * 2246822507 + (((h1 >>> 16) * 2246822507 & 65535) << 16) & 4294967295;\n h1 ^= h1 >>> 13;\n h1 = (h1 & 65535) * 3266489909 + (((h1 >>> 16) * 3266489909 & 65535) << 16) & 4294967295;\n h1 ^= h1 >>> 16;\n return h1 >>> 0;\n}\n{\n module.exports = murmurhash3_32_gc;\n}\n});\n\nvar murmurhash2_gc = createCommonjsModule(function (module) {\nfunction murmurhash2_32_gc(str, seed) {\n var l = str.length, h = seed ^ l, i = 0, k;\n while (l >= 4) {\n k = str.charCodeAt(i) & 255 | (str.charCodeAt(++i) & 255) << 8 | (str.charCodeAt(++i) & 255) << 16 | (str.charCodeAt(++i) & 255) << 24;\n k = (k & 65535) * 1540483477 + (((k >>> 16) * 1540483477 & 65535) << 16);\n k ^= k >>> 24;\n k = (k & 65535) * 1540483477 + (((k >>> 16) * 1540483477 & 65535) << 16);\n h = (h & 65535) * 1540483477 + (((h >>> 16) * 1540483477 & 65535) << 16) ^ k;\n l -= 4;\n ++i;\n }\n switch (l) {\n case 3:\n h ^= (str.charCodeAt(i + 2) & 255) << 16;\n case 2:\n h ^= (str.charCodeAt(i + 1) & 255) << 8;\n case 1:\n h ^= str.charCodeAt(i) & 255;\n h = (h & 65535) * 1540483477 + (((h >>> 16) * 1540483477 & 65535) << 16);\n }\n h ^= h >>> 13;\n h = (h & 65535) * 1540483477 + (((h >>> 16) * 1540483477 & 65535) << 16);\n h ^= h >>> 15;\n return h >>> 0;\n}\n{\n module.exports = murmurhash2_32_gc;\n}\n});\n\nvar murmurhashJs = murmurhash3_gc;\nvar murmur3_1 = murmurhash3_gc;\nvar murmur2_1 = murmurhash2_gc;\nmurmurhashJs.murmur3 = murmur3_1;\nmurmurhashJs.murmur2 = murmur2_1;\n\nvar FeaturePositionMap = function FeaturePositionMap() {\n this.ids = [];\n this.positions = [];\n this.indexed = false;\n};\nFeaturePositionMap.prototype.add = function add(id, index, start, end) {\n this.ids.push(getNumericId(id));\n this.positions.push(index, start, end);\n};\nFeaturePositionMap.prototype.getPositions = function getPositions(id) {\n var intId = getNumericId(id);\n var i = 0;\n var j = this.ids.length - 1;\n while (i < j) {\n var m = i + j >> 1;\n if (this.ids[m] >= intId) {\n j = m;\n } else {\n i = m + 1;\n }\n }\n var positions = [];\n while (this.ids[i] === intId) {\n var index = this.positions[3 * i];\n var start = this.positions[3 * i + 1];\n var end = this.positions[3 * i + 2];\n positions.push({\n index: index,\n start: start,\n end: end\n });\n i++;\n }\n return positions;\n};\nFeaturePositionMap.serialize = function serialize(map, transferables) {\n var ids = new Float64Array(map.ids);\n var positions = new Uint32Array(map.positions);\n sort(ids, positions, 0, ids.length - 1);\n if (transferables) {\n transferables.push(ids.buffer, positions.buffer);\n }\n return {\n ids: ids,\n positions: positions\n };\n};\nFeaturePositionMap.deserialize = function deserialize(obj) {\n var map = new FeaturePositionMap();\n map.ids = obj.ids;\n map.positions = obj.positions;\n map.indexed = true;\n return map;\n};\nvar MAX_SAFE_INTEGER$1 = Math.pow(2, 53) - 1;\nfunction getNumericId(value) {\n var numValue = +value;\n if (!isNaN(numValue) && numValue <= MAX_SAFE_INTEGER$1) {\n return numValue;\n }\n return murmurhashJs(String(value));\n}\nfunction sort(ids, positions, left, right) {\n while (left < right) {\n var pivot = ids[left + right >> 1];\n var i = left - 1;\n var j = right + 1;\n while (true) {\n do {\n i++;\n } while (ids[i] < pivot);\n do {\n j--;\n } while (ids[j] > pivot);\n if (i >= j) {\n break;\n }\n swap(ids, i, j);\n swap(positions, 3 * i, 3 * j);\n swap(positions, 3 * i + 1, 3 * j + 1);\n swap(positions, 3 * i + 2, 3 * j + 2);\n }\n if (j - left < right - j) {\n sort(ids, positions, left, j);\n left = j + 1;\n } else {\n sort(ids, positions, j + 1, right);\n right = j;\n }\n }\n}\nfunction swap(arr, i, j) {\n var tmp = arr[i];\n arr[i] = arr[j];\n arr[j] = tmp;\n}\nregister('FeaturePositionMap', FeaturePositionMap);\n\nvar Uniform = function Uniform(context, location) {\n this.gl = context.gl;\n this.location = location;\n};\nvar Uniform1i = function (Uniform) {\n function Uniform1i(context, location) {\n Uniform.call(this, context, location);\n this.current = 0;\n }\n if (Uniform)\n Uniform1i.__proto__ = Uniform;\n Uniform1i.prototype = Object.create(Uniform && Uniform.prototype);\n Uniform1i.prototype.constructor = Uniform1i;\n Uniform1i.prototype.set = function set(v) {\n if (this.current !== v) {\n this.current = v;\n this.gl.uniform1i(this.location, v);\n }\n };\n return Uniform1i;\n}(Uniform);\nvar Uniform1f = function (Uniform) {\n function Uniform1f(context, location) {\n Uniform.call(this, context, location);\n this.current = 0;\n }\n if (Uniform)\n Uniform1f.__proto__ = Uniform;\n Uniform1f.prototype = Object.create(Uniform && Uniform.prototype);\n Uniform1f.prototype.constructor = Uniform1f;\n Uniform1f.prototype.set = function set(v) {\n if (this.current !== v) {\n this.current = v;\n this.gl.uniform1f(this.location, v);\n }\n };\n return Uniform1f;\n}(Uniform);\nvar Uniform2f = function (Uniform) {\n function Uniform2f(context, location) {\n Uniform.call(this, context, location);\n this.current = [\n 0,\n 0\n ];\n }\n if (Uniform)\n Uniform2f.__proto__ = Uniform;\n Uniform2f.prototype = Object.create(Uniform && Uniform.prototype);\n Uniform2f.prototype.constructor = Uniform2f;\n Uniform2f.prototype.set = function set(v) {\n if (v[0] !== this.current[0] || v[1] !== this.current[1]) {\n this.current = v;\n this.gl.uniform2f(this.location, v[0], v[1]);\n }\n };\n return Uniform2f;\n}(Uniform);\nvar Uniform3f = function (Uniform) {\n function Uniform3f(context, location) {\n Uniform.call(this, context, location);\n this.current = [\n 0,\n 0,\n 0\n ];\n }\n if (Uniform)\n Uniform3f.__proto__ = Uniform;\n Uniform3f.prototype = Object.create(Uniform && Uniform.prototype);\n Uniform3f.prototype.constructor = Uniform3f;\n Uniform3f.prototype.set = function set(v) {\n if (v[0] !== this.current[0] || v[1] !== this.current[1] || v[2] !== this.current[2]) {\n this.current = v;\n this.gl.uniform3f(this.location, v[0], v[1], v[2]);\n }\n };\n return Uniform3f;\n}(Uniform);\nvar Uniform4f = function (Uniform) {\n function Uniform4f(context, location) {\n Uniform.call(this, context, location);\n this.current = [\n 0,\n 0,\n 0,\n 0\n ];\n }\n if (Uniform)\n Uniform4f.__proto__ = Uniform;\n Uniform4f.prototype = Object.create(Uniform && Uniform.prototype);\n Uniform4f.prototype.constructor = Uniform4f;\n Uniform4f.prototype.set = function set(v) {\n if (v[0] !== this.current[0] || v[1] !== this.current[1] || v[2] !== this.current[2] || v[3] !== this.current[3]) {\n this.current = v;\n this.gl.uniform4f(this.location, v[0], v[1], v[2], v[3]);\n }\n };\n return Uniform4f;\n}(Uniform);\nvar UniformColor = function (Uniform) {\n function UniformColor(context, location) {\n Uniform.call(this, context, location);\n this.current = Color.transparent;\n }\n if (Uniform)\n UniformColor.__proto__ = Uniform;\n UniformColor.prototype = Object.create(Uniform && Uniform.prototype);\n UniformColor.prototype.constructor = UniformColor;\n UniformColor.prototype.set = function set(v) {\n if (v.r !== this.current.r || v.g !== this.current.g || v.b !== this.current.b || v.a !== this.current.a) {\n this.current = v;\n this.gl.uniform4f(this.location, v.r, v.g, v.b, v.a);\n }\n };\n return UniformColor;\n}(Uniform);\nvar emptyMat4 = new Float32Array(16);\nvar UniformMatrix4f = function (Uniform) {\n function UniformMatrix4f(context, location) {\n Uniform.call(this, context, location);\n this.current = emptyMat4;\n }\n if (Uniform)\n UniformMatrix4f.__proto__ = Uniform;\n UniformMatrix4f.prototype = Object.create(Uniform && Uniform.prototype);\n UniformMatrix4f.prototype.constructor = UniformMatrix4f;\n UniformMatrix4f.prototype.set = function set(v) {\n if (v[12] !== this.current[12] || v[0] !== this.current[0]) {\n this.current = v;\n this.gl.uniformMatrix4fv(this.location, false, v);\n return;\n }\n for (var i = 1; i < 16; i++) {\n if (v[i] !== this.current[i]) {\n this.current = v;\n this.gl.uniformMatrix4fv(this.location, false, v);\n break;\n }\n }\n };\n return UniformMatrix4f;\n}(Uniform);\n\nfunction packColor(color) {\n return [\n packUint8ToFloat(255 * color.r, 255 * color.g),\n packUint8ToFloat(255 * color.b, 255 * color.a)\n ];\n}\nvar ConstantBinder = function ConstantBinder(value, names, type) {\n this.value = value;\n this.uniformNames = names.map(function (name) {\n return 'u_' + name;\n });\n this.type = type;\n};\nConstantBinder.prototype.setUniform = function setUniform(uniform, globals, currentValue) {\n uniform.set(currentValue.constantOr(this.value));\n};\nConstantBinder.prototype.getBinding = function getBinding(context, location, _) {\n return this.type === 'color' ? new UniformColor(context, location) : new Uniform1f(context, location);\n};\nvar CrossFadedConstantBinder = function CrossFadedConstantBinder(value, names) {\n this.uniformNames = names.map(function (name) {\n return 'u_' + name;\n });\n this.patternFrom = null;\n this.patternTo = null;\n this.pixelRatioFrom = 1;\n this.pixelRatioTo = 1;\n};\nCrossFadedConstantBinder.prototype.setConstantPatternPositions = function setConstantPatternPositions(posTo, posFrom) {\n this.pixelRatioFrom = posFrom.pixelRatio;\n this.pixelRatioTo = posTo.pixelRatio;\n this.patternFrom = posFrom.tlbr;\n this.patternTo = posTo.tlbr;\n};\nCrossFadedConstantBinder.prototype.setUniform = function setUniform(uniform, globals, currentValue, uniformName) {\n var pos = uniformName === 'u_pattern_to' ? this.patternTo : uniformName === 'u_pattern_from' ? this.patternFrom : uniformName === 'u_pixel_ratio_to' ? this.pixelRatioTo : uniformName === 'u_pixel_ratio_from' ? this.pixelRatioFrom : null;\n if (pos) {\n uniform.set(pos);\n }\n};\nCrossFadedConstantBinder.prototype.getBinding = function getBinding(context, location, name) {\n return name.substr(0, 9) === 'u_pattern' ? new Uniform4f(context, location) : new Uniform1f(context, location);\n};\nvar SourceExpressionBinder = function SourceExpressionBinder(expression, names, type, PaintVertexArray) {\n this.expression = expression;\n this.type = type;\n this.maxValue = 0;\n this.paintVertexAttributes = names.map(function (name) {\n return {\n name: 'a_' + name,\n type: 'Float32',\n components: type === 'color' ? 2 : 1,\n offset: 0\n };\n });\n this.paintVertexArray = new PaintVertexArray();\n};\nSourceExpressionBinder.prototype.populatePaintArray = function populatePaintArray(newLength, feature, imagePositions, canonical, formattedSection) {\n var start = this.paintVertexArray.length;\n var value = this.expression.evaluate(new EvaluationParameters(0), feature, {}, canonical, [], formattedSection);\n this.paintVertexArray.resize(newLength);\n this._setPaintValue(start, newLength, value);\n};\nSourceExpressionBinder.prototype.updatePaintArray = function updatePaintArray(start, end, feature, featureState) {\n var value = this.expression.evaluate({ zoom: 0 }, feature, featureState);\n this._setPaintValue(start, end, value);\n};\nSourceExpressionBinder.prototype._setPaintValue = function _setPaintValue(start, end, value) {\n if (this.type === 'color') {\n var color = packColor(value);\n for (var i = start; i < end; i++) {\n this.paintVertexArray.emplace(i, color[0], color[1]);\n }\n } else {\n for (var i$1 = start; i$1 < end; i$1++) {\n this.paintVertexArray.emplace(i$1, value);\n }\n this.maxValue = Math.max(this.maxValue, Math.abs(value));\n }\n};\nSourceExpressionBinder.prototype.upload = function upload(context) {\n if (this.paintVertexArray && this.paintVertexArray.arrayBuffer) {\n if (this.paintVertexBuffer && this.paintVertexBuffer.buffer) {\n this.paintVertexBuffer.updateData(this.paintVertexArray);\n } else {\n this.paintVertexBuffer = context.createVertexBuffer(this.paintVertexArray, this.paintVertexAttributes, this.expression.isStateDependent);\n }\n }\n};\nSourceExpressionBinder.prototype.destroy = function destroy() {\n if (this.paintVertexBuffer) {\n this.paintVertexBuffer.destroy();\n }\n};\nvar CompositeExpressionBinder = function CompositeExpressionBinder(expression, names, type, useIntegerZoom, zoom, PaintVertexArray) {\n this.expression = expression;\n this.uniformNames = names.map(function (name) {\n return 'u_' + name + '_t';\n });\n this.type = type;\n this.useIntegerZoom = useIntegerZoom;\n this.zoom = zoom;\n this.maxValue = 0;\n this.paintVertexAttributes = names.map(function (name) {\n return {\n name: 'a_' + name,\n type: 'Float32',\n components: type === 'color' ? 4 : 2,\n offset: 0\n };\n });\n this.paintVertexArray = new PaintVertexArray();\n};\nCompositeExpressionBinder.prototype.populatePaintArray = function populatePaintArray(newLength, feature, imagePositions, canonical, formattedSection) {\n var min = this.expression.evaluate(new EvaluationParameters(this.zoom), feature, {}, canonical, [], formattedSection);\n var max = this.expression.evaluate(new EvaluationParameters(this.zoom + 1), feature, {}, canonical, [], formattedSection);\n var start = this.paintVertexArray.length;\n this.paintVertexArray.resize(newLength);\n this._setPaintValue(start, newLength, min, max);\n};\nCompositeExpressionBinder.prototype.updatePaintArray = function updatePaintArray(start, end, feature, featureState) {\n var min = this.expression.evaluate({ zoom: this.zoom }, feature, featureState);\n var max = this.expression.evaluate({ zoom: this.zoom + 1 }, feature, featureState);\n this._setPaintValue(start, end, min, max);\n};\nCompositeExpressionBinder.prototype._setPaintValue = function _setPaintValue(start, end, min, max) {\n if (this.type === 'color') {\n var minColor = packColor(min);\n var maxColor = packColor(max);\n for (var i = start; i < end; i++) {\n this.paintVertexArray.emplace(i, minColor[0], minColor[1], maxColor[0], maxColor[1]);\n }\n } else {\n for (var i$1 = start; i$1 < end; i$1++) {\n this.paintVertexArray.emplace(i$1, min, max);\n }\n this.maxValue = Math.max(this.maxValue, Math.abs(min), Math.abs(max));\n }\n};\nCompositeExpressionBinder.prototype.upload = function upload(context) {\n if (this.paintVertexArray && this.paintVertexArray.arrayBuffer) {\n if (this.paintVertexBuffer && this.paintVertexBuffer.buffer) {\n this.paintVertexBuffer.updateData(this.paintVertexArray);\n } else {\n this.paintVertexBuffer = context.createVertexBuffer(this.paintVertexArray, this.paintVertexAttributes, this.expression.isStateDependent);\n }\n }\n};\nCompositeExpressionBinder.prototype.destroy = function destroy() {\n if (this.paintVertexBuffer) {\n this.paintVertexBuffer.destroy();\n }\n};\nCompositeExpressionBinder.prototype.setUniform = function setUniform(uniform, globals) {\n var currentZoom = this.useIntegerZoom ? Math.floor(globals.zoom) : globals.zoom;\n var factor = clamp(this.expression.interpolationFactor(currentZoom, this.zoom, this.zoom + 1), 0, 1);\n uniform.set(factor);\n};\nCompositeExpressionBinder.prototype.getBinding = function getBinding(context, location, _) {\n return new Uniform1f(context, location);\n};\nvar CrossFadedCompositeBinder = function CrossFadedCompositeBinder(expression, type, useIntegerZoom, zoom, PaintVertexArray, layerId) {\n this.expression = expression;\n this.type = type;\n this.useIntegerZoom = useIntegerZoom;\n this.zoom = zoom;\n this.layerId = layerId;\n this.zoomInPaintVertexArray = new PaintVertexArray();\n this.zoomOutPaintVertexArray = new PaintVertexArray();\n};\nCrossFadedCompositeBinder.prototype.populatePaintArray = function populatePaintArray(length, feature, imagePositions) {\n var start = this.zoomInPaintVertexArray.length;\n this.zoomInPaintVertexArray.resize(length);\n this.zoomOutPaintVertexArray.resize(length);\n this._setPaintValues(start, length, feature.patterns && feature.patterns[this.layerId], imagePositions);\n};\nCrossFadedCompositeBinder.prototype.updatePaintArray = function updatePaintArray(start, end, feature, featureState, imagePositions) {\n this._setPaintValues(start, end, feature.patterns && feature.patterns[this.layerId], imagePositions);\n};\nCrossFadedCompositeBinder.prototype._setPaintValues = function _setPaintValues(start, end, patterns, positions) {\n if (!positions || !patterns) {\n return;\n }\n var min = patterns.min;\n var mid = patterns.mid;\n var max = patterns.max;\n var imageMin = positions[min];\n var imageMid = positions[mid];\n var imageMax = positions[max];\n if (!imageMin || !imageMid || !imageMax) {\n return;\n }\n for (var i = start; i < end; i++) {\n this.zoomInPaintVertexArray.emplace(i, imageMid.tl[0], imageMid.tl[1], imageMid.br[0], imageMid.br[1], imageMin.tl[0], imageMin.tl[1], imageMin.br[0], imageMin.br[1], imageMid.pixelRatio, imageMin.pixelRatio);\n this.zoomOutPaintVertexArray.emplace(i, imageMid.tl[0], imageMid.tl[1], imageMid.br[0], imageMid.br[1], imageMax.tl[0], imageMax.tl[1], imageMax.br[0], imageMax.br[1], imageMid.pixelRatio, imageMax.pixelRatio);\n }\n};\nCrossFadedCompositeBinder.prototype.upload = function upload(context) {\n if (this.zoomInPaintVertexArray && this.zoomInPaintVertexArray.arrayBuffer && this.zoomOutPaintVertexArray && this.zoomOutPaintVertexArray.arrayBuffer) {\n this.zoomInPaintVertexBuffer = context.createVertexBuffer(this.zoomInPaintVertexArray, patternAttributes.members, this.expression.isStateDependent);\n this.zoomOutPaintVertexBuffer = context.createVertexBuffer(this.zoomOutPaintVertexArray, patternAttributes.members, this.expression.isStateDependent);\n }\n};\nCrossFadedCompositeBinder.prototype.destroy = function destroy() {\n if (this.zoomOutPaintVertexBuffer) {\n this.zoomOutPaintVertexBuffer.destroy();\n }\n if (this.zoomInPaintVertexBuffer) {\n this.zoomInPaintVertexBuffer.destroy();\n }\n};\nvar ProgramConfiguration = function ProgramConfiguration(layer, zoom, filterProperties) {\n this.binders = {};\n this._buffers = [];\n var keys = [];\n for (var property in layer.paint._values) {\n if (!filterProperties(property)) {\n continue;\n }\n var value = layer.paint.get(property);\n if (!(value instanceof PossiblyEvaluatedPropertyValue) || !supportsPropertyExpression(value.property.specification)) {\n continue;\n }\n var names = paintAttributeNames(property, layer.type);\n var expression = value.value;\n var type = value.property.specification.type;\n var useIntegerZoom = value.property.useIntegerZoom;\n var propType = value.property.specification['property-type'];\n var isCrossFaded = propType === 'cross-faded' || propType === 'cross-faded-data-driven';\n if (expression.kind === 'constant') {\n this.binders[property] = isCrossFaded ? new CrossFadedConstantBinder(expression.value, names) : new ConstantBinder(expression.value, names, type);\n keys.push('/u_' + property);\n } else if (expression.kind === 'source' || isCrossFaded) {\n var StructArrayLayout = layoutType(property, type, 'source');\n this.binders[property] = isCrossFaded ? new CrossFadedCompositeBinder(expression, type, useIntegerZoom, zoom, StructArrayLayout, layer.id) : new SourceExpressionBinder(expression, names, type, StructArrayLayout);\n keys.push('/a_' + property);\n } else {\n var StructArrayLayout$1 = layoutType(property, type, 'composite');\n this.binders[property] = new CompositeExpressionBinder(expression, names, type, useIntegerZoom, zoom, StructArrayLayout$1);\n keys.push('/z_' + property);\n }\n }\n this.cacheKey = keys.sort().join('');\n};\nProgramConfiguration.prototype.getMaxValue = function getMaxValue(property) {\n var binder = this.binders[property];\n return binder instanceof SourceExpressionBinder || binder instanceof CompositeExpressionBinder ? binder.maxValue : 0;\n};\nProgramConfiguration.prototype.populatePaintArrays = function populatePaintArrays(newLength, feature, imagePositions, canonical, formattedSection) {\n for (var property in this.binders) {\n var binder = this.binders[property];\n if (binder instanceof SourceExpressionBinder || binder instanceof CompositeExpressionBinder || binder instanceof CrossFadedCompositeBinder) {\n binder.populatePaintArray(newLength, feature, imagePositions, canonical, formattedSection);\n }\n }\n};\nProgramConfiguration.prototype.setConstantPatternPositions = function setConstantPatternPositions(posTo, posFrom) {\n for (var property in this.binders) {\n var binder = this.binders[property];\n if (binder instanceof CrossFadedConstantBinder) {\n binder.setConstantPatternPositions(posTo, posFrom);\n }\n }\n};\nProgramConfiguration.prototype.updatePaintArrays = function updatePaintArrays(featureStates, featureMap, vtLayer, layer, imagePositions) {\n var dirty = false;\n for (var id in featureStates) {\n var positions = featureMap.getPositions(id);\n for (var i = 0, list = positions; i < list.length; i += 1) {\n var pos = list[i];\n var feature = vtLayer.feature(pos.index);\n for (var property in this.binders) {\n var binder = this.binders[property];\n if ((binder instanceof SourceExpressionBinder || binder instanceof CompositeExpressionBinder || binder instanceof CrossFadedCompositeBinder) && binder.expression.isStateDependent === true) {\n var value = layer.paint.get(property);\n binder.expression = value.value;\n binder.updatePaintArray(pos.start, pos.end, feature, featureStates[id], imagePositions);\n dirty = true;\n }\n }\n }\n }\n return dirty;\n};\nProgramConfiguration.prototype.defines = function defines() {\n var result = [];\n for (var property in this.binders) {\n var binder = this.binders[property];\n if (binder instanceof ConstantBinder || binder instanceof CrossFadedConstantBinder) {\n result.push.apply(result, binder.uniformNames.map(function (name) {\n return '#define HAS_UNIFORM_' + name;\n }));\n }\n }\n return result;\n};\nProgramConfiguration.prototype.getBinderAttributes = function getBinderAttributes() {\n var result = [];\n for (var property in this.binders) {\n var binder = this.binders[property];\n if (binder instanceof SourceExpressionBinder || binder instanceof CompositeExpressionBinder) {\n for (var i = 0; i < binder.paintVertexAttributes.length; i++) {\n result.push(binder.paintVertexAttributes[i].name);\n }\n } else if (binder instanceof CrossFadedCompositeBinder) {\n for (var i$1 = 0; i$1 < patternAttributes.members.length; i$1++) {\n result.push(patternAttributes.members[i$1].name);\n }\n }\n }\n return result;\n};\nProgramConfiguration.prototype.getBinderUniforms = function getBinderUniforms() {\n var uniforms = [];\n for (var property in this.binders) {\n var binder = this.binders[property];\n if (binder instanceof ConstantBinder || binder instanceof CrossFadedConstantBinder || binder instanceof CompositeExpressionBinder) {\n for (var i = 0, list = binder.uniformNames; i < list.length; i += 1) {\n var uniformName = list[i];\n uniforms.push(uniformName);\n }\n }\n }\n return uniforms;\n};\nProgramConfiguration.prototype.getPaintVertexBuffers = function getPaintVertexBuffers() {\n return this._buffers;\n};\nProgramConfiguration.prototype.getUniforms = function getUniforms(context, locations) {\n var uniforms = [];\n for (var property in this.binders) {\n var binder = this.binders[property];\n if (binder instanceof ConstantBinder || binder instanceof CrossFadedConstantBinder || binder instanceof CompositeExpressionBinder) {\n for (var i = 0, list = binder.uniformNames; i < list.length; i += 1) {\n var name = list[i];\n if (locations[name]) {\n var binding = binder.getBinding(context, locations[name], name);\n uniforms.push({\n name: name,\n property: property,\n binding: binding\n });\n }\n }\n }\n }\n return uniforms;\n};\nProgramConfiguration.prototype.setUniforms = function setUniforms(context, binderUniforms, properties, globals) {\n for (var i = 0, list = binderUniforms; i < list.length; i += 1) {\n var ref = list[i];\n var name = ref.name;\n var property = ref.property;\n var binding = ref.binding;\n this.binders[property].setUniform(binding, globals, properties.get(property), name);\n }\n};\nProgramConfiguration.prototype.updatePaintBuffers = function updatePaintBuffers(crossfade) {\n this._buffers = [];\n for (var property in this.binders) {\n var binder = this.binders[property];\n if (crossfade && binder instanceof CrossFadedCompositeBinder) {\n var patternVertexBuffer = crossfade.fromScale === 2 ? binder.zoomInPaintVertexBuffer : binder.zoomOutPaintVertexBuffer;\n if (patternVertexBuffer) {\n this._buffers.push(patternVertexBuffer);\n }\n } else if ((binder instanceof SourceExpressionBinder || binder instanceof CompositeExpressionBinder) && binder.paintVertexBuffer) {\n this._buffers.push(binder.paintVertexBuffer);\n }\n }\n};\nProgramConfiguration.prototype.upload = function upload(context) {\n for (var property in this.binders) {\n var binder = this.binders[property];\n if (binder instanceof SourceExpressionBinder || binder instanceof CompositeExpressionBinder || binder instanceof CrossFadedCompositeBinder) {\n binder.upload(context);\n }\n }\n this.updatePaintBuffers();\n};\nProgramConfiguration.prototype.destroy = function destroy() {\n for (var property in this.binders) {\n var binder = this.binders[property];\n if (binder instanceof SourceExpressionBinder || binder instanceof CompositeExpressionBinder || binder instanceof CrossFadedCompositeBinder) {\n binder.destroy();\n }\n }\n};\nvar ProgramConfigurationSet = function ProgramConfigurationSet(layers, zoom, filterProperties) {\n if (filterProperties === void 0)\n filterProperties = function () {\n return true;\n };\n this.programConfigurations = {};\n for (var i = 0, list = layers; i < list.length; i += 1) {\n var layer = list[i];\n this.programConfigurations[layer.id] = new ProgramConfiguration(layer, zoom, filterProperties);\n }\n this.needsUpload = false;\n this._featureMap = new FeaturePositionMap();\n this._bufferOffset = 0;\n};\nProgramConfigurationSet.prototype.populatePaintArrays = function populatePaintArrays(length, feature, index, imagePositions, canonical, formattedSection) {\n for (var key in this.programConfigurations) {\n this.programConfigurations[key].populatePaintArrays(length, feature, imagePositions, canonical, formattedSection);\n }\n if (feature.id !== undefined) {\n this._featureMap.add(feature.id, index, this._bufferOffset, length);\n }\n this._bufferOffset = length;\n this.needsUpload = true;\n};\nProgramConfigurationSet.prototype.updatePaintArrays = function updatePaintArrays(featureStates, vtLayer, layers, imagePositions) {\n for (var i = 0, list = layers; i < list.length; i += 1) {\n var layer = list[i];\n this.needsUpload = this.programConfigurations[layer.id].updatePaintArrays(featureStates, this._featureMap, vtLayer, layer, imagePositions) || this.needsUpload;\n }\n};\nProgramConfigurationSet.prototype.get = function get(layerId) {\n return this.programConfigurations[layerId];\n};\nProgramConfigurationSet.prototype.upload = function upload(context) {\n if (!this.needsUpload) {\n return;\n }\n for (var layerId in this.programConfigurations) {\n this.programConfigurations[layerId].upload(context);\n }\n this.needsUpload = false;\n};\nProgramConfigurationSet.prototype.destroy = function destroy() {\n for (var layerId in this.programConfigurations) {\n this.programConfigurations[layerId].destroy();\n }\n};\nfunction paintAttributeNames(property, type) {\n var attributeNameExceptions = {\n 'text-opacity': ['opacity'],\n 'icon-opacity': ['opacity'],\n 'text-color': ['fill_color'],\n 'icon-color': ['fill_color'],\n 'text-halo-color': ['halo_color'],\n 'icon-halo-color': ['halo_color'],\n 'text-halo-blur': ['halo_blur'],\n 'icon-halo-blur': ['halo_blur'],\n 'text-halo-width': ['halo_width'],\n 'icon-halo-width': ['halo_width'],\n 'line-gap-width': ['gapwidth'],\n 'line-pattern': [\n 'pattern_to',\n 'pattern_from',\n 'pixel_ratio_to',\n 'pixel_ratio_from'\n ],\n 'fill-pattern': [\n 'pattern_to',\n 'pattern_from',\n 'pixel_ratio_to',\n 'pixel_ratio_from'\n ],\n 'fill-extrusion-pattern': [\n 'pattern_to',\n 'pattern_from',\n 'pixel_ratio_to',\n 'pixel_ratio_from'\n ]\n };\n return attributeNameExceptions[property] || [property.replace(type + '-', '').replace(/-/g, '_')];\n}\nfunction getLayoutException(property) {\n var propertyExceptions = {\n 'line-pattern': {\n 'source': StructArrayLayout10ui20,\n 'composite': StructArrayLayout10ui20\n },\n 'fill-pattern': {\n 'source': StructArrayLayout10ui20,\n 'composite': StructArrayLayout10ui20\n },\n 'fill-extrusion-pattern': {\n 'source': StructArrayLayout10ui20,\n 'composite': StructArrayLayout10ui20\n }\n };\n return propertyExceptions[property];\n}\nfunction layoutType(property, type, binderType) {\n var defaultLayouts = {\n 'color': {\n 'source': StructArrayLayout2f8,\n 'composite': StructArrayLayout4f16\n },\n 'number': {\n 'source': StructArrayLayout1f4,\n 'composite': StructArrayLayout2f8\n }\n };\n var layoutException = getLayoutException(property);\n return layoutException && layoutException[binderType] || defaultLayouts[type][binderType];\n}\nregister('ConstantBinder', ConstantBinder);\nregister('CrossFadedConstantBinder', CrossFadedConstantBinder);\nregister('SourceExpressionBinder', SourceExpressionBinder);\nregister('CrossFadedCompositeBinder', CrossFadedCompositeBinder);\nregister('CompositeExpressionBinder', CompositeExpressionBinder);\nregister('ProgramConfiguration', ProgramConfiguration, { omit: ['_buffers'] });\nregister('ProgramConfigurationSet', ProgramConfigurationSet);\n\nvar EXTENT$1 = 8192;\n\nvar BITS = 15;\nvar MAX = Math.pow(2, BITS - 1) - 1;\nvar MIN = -MAX - 1;\nfunction loadGeometry(feature) {\n var scale = EXTENT$1 / feature.extent;\n var geometry = feature.loadGeometry();\n for (var r = 0; r < geometry.length; r++) {\n var ring = geometry[r];\n for (var p = 0; p < ring.length; p++) {\n var point = ring[p];\n var x = Math.round(point.x * scale);\n var y = Math.round(point.y * scale);\n point.x = clamp(x, MIN, MAX);\n point.y = clamp(y, MIN, MAX);\n if (x < point.x || x > point.x + 1 || y < point.y || y > point.y + 1) {\n warnOnce('Geometry exceeds allowed extent, reduce your vector tile buffer size');\n }\n }\n }\n return geometry;\n}\n\nfunction toEvaluationFeature(feature, needGeometry) {\n return {\n type: feature.type,\n id: feature.id,\n properties: feature.properties,\n geometry: needGeometry ? loadGeometry(feature) : []\n };\n}\n\nfunction addCircleVertex(layoutVertexArray, x, y, extrudeX, extrudeY) {\n layoutVertexArray.emplaceBack(x * 2 + (extrudeX + 1) / 2, y * 2 + (extrudeY + 1) / 2);\n}\nvar CircleBucket = function CircleBucket(options) {\n this.zoom = options.zoom;\n this.overscaling = options.overscaling;\n this.layers = options.layers;\n this.layerIds = this.layers.map(function (layer) {\n return layer.id;\n });\n this.index = options.index;\n this.hasPattern = false;\n this.layoutVertexArray = new StructArrayLayout2i4();\n this.indexArray = new StructArrayLayout3ui6();\n this.segments = new SegmentVector();\n this.programConfigurations = new ProgramConfigurationSet(options.layers, options.zoom);\n this.stateDependentLayerIds = this.layers.filter(function (l) {\n return l.isStateDependent();\n }).map(function (l) {\n return l.id;\n });\n};\nCircleBucket.prototype.populate = function populate(features, options, canonical) {\n var styleLayer = this.layers[0];\n var bucketFeatures = [];\n var circleSortKey = null;\n if (styleLayer.type === 'circle') {\n circleSortKey = styleLayer.layout.get('circle-sort-key');\n }\n for (var i = 0, list = features; i < list.length; i += 1) {\n var ref = list[i];\n var feature = ref.feature;\n var id = ref.id;\n var index = ref.index;\n var sourceLayerIndex = ref.sourceLayerIndex;\n var needGeometry = this.layers[0]._featureFilter.needGeometry;\n var evaluationFeature = toEvaluationFeature(feature, needGeometry);\n if (!this.layers[0]._featureFilter.filter(new EvaluationParameters(this.zoom), evaluationFeature, canonical)) {\n continue;\n }\n var sortKey = circleSortKey ? circleSortKey.evaluate(evaluationFeature, {}, canonical) : undefined;\n var bucketFeature = {\n id: id,\n properties: feature.properties,\n type: feature.type,\n sourceLayerIndex: sourceLayerIndex,\n index: index,\n geometry: needGeometry ? evaluationFeature.geometry : loadGeometry(feature),\n patterns: {},\n sortKey: sortKey\n };\n bucketFeatures.push(bucketFeature);\n }\n if (circleSortKey) {\n bucketFeatures.sort(function (a, b) {\n return a.sortKey - b.sortKey;\n });\n }\n for (var i$1 = 0, list$1 = bucketFeatures; i$1 < list$1.length; i$1 += 1) {\n var bucketFeature$1 = list$1[i$1];\n var ref$1 = bucketFeature$1;\n var geometry = ref$1.geometry;\n var index$1 = ref$1.index;\n var sourceLayerIndex$1 = ref$1.sourceLayerIndex;\n var feature$1 = features[index$1].feature;\n this.addFeature(bucketFeature$1, geometry, index$1, canonical);\n options.featureIndex.insert(feature$1, geometry, index$1, sourceLayerIndex$1, this.index);\n }\n};\nCircleBucket.prototype.update = function update(states, vtLayer, imagePositions) {\n if (!this.stateDependentLayers.length) {\n return;\n }\n this.programConfigurations.updatePaintArrays(states, vtLayer, this.stateDependentLayers, imagePositions);\n};\nCircleBucket.prototype.isEmpty = function isEmpty() {\n return this.layoutVertexArray.length === 0;\n};\nCircleBucket.prototype.uploadPending = function uploadPending() {\n return !this.uploaded || this.programConfigurations.needsUpload;\n};\nCircleBucket.prototype.upload = function upload(context) {\n if (!this.uploaded) {\n this.layoutVertexBuffer = context.createVertexBuffer(this.layoutVertexArray, members);\n this.indexBuffer = context.createIndexBuffer(this.indexArray);\n }\n this.programConfigurations.upload(context);\n this.uploaded = true;\n};\nCircleBucket.prototype.destroy = function destroy() {\n if (!this.layoutVertexBuffer) {\n return;\n }\n this.layoutVertexBuffer.destroy();\n this.indexBuffer.destroy();\n this.programConfigurations.destroy();\n this.segments.destroy();\n};\nCircleBucket.prototype.addFeature = function addFeature(feature, geometry, index, canonical) {\n for (var i$1 = 0, list$1 = geometry; i$1 < list$1.length; i$1 += 1) {\n var ring = list$1[i$1];\n for (var i = 0, list = ring; i < list.length; i += 1) {\n var point = list[i];\n var x = point.x;\n var y = point.y;\n if (x < 0 || x >= EXTENT$1 || y < 0 || y >= EXTENT$1) {\n continue;\n }\n var segment = this.segments.prepareSegment(4, this.layoutVertexArray, this.indexArray, feature.sortKey);\n var index$1 = segment.vertexLength;\n addCircleVertex(this.layoutVertexArray, x, y, -1, -1);\n addCircleVertex(this.layoutVertexArray, x, y, 1, -1);\n addCircleVertex(this.layoutVertexArray, x, y, 1, 1);\n addCircleVertex(this.layoutVertexArray, x, y, -1, 1);\n this.indexArray.emplaceBack(index$1, index$1 + 1, index$1 + 2);\n this.indexArray.emplaceBack(index$1, index$1 + 3, index$1 + 2);\n segment.vertexLength += 4;\n segment.primitiveLength += 2;\n }\n }\n this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, feature, index, {}, canonical);\n};\nregister('CircleBucket', CircleBucket, { omit: ['layers'] });\n\nfunction polygonIntersectsPolygon(polygonA, polygonB) {\n for (var i = 0; i < polygonA.length; i++) {\n if (polygonContainsPoint(polygonB, polygonA[i])) {\n return true;\n }\n }\n for (var i$1 = 0; i$1 < polygonB.length; i$1++) {\n if (polygonContainsPoint(polygonA, polygonB[i$1])) {\n return true;\n }\n }\n if (lineIntersectsLine(polygonA, polygonB)) {\n return true;\n }\n return false;\n}\nfunction polygonIntersectsBufferedPoint(polygon, point, radius) {\n if (polygonContainsPoint(polygon, point)) {\n return true;\n }\n if (pointIntersectsBufferedLine(point, polygon, radius)) {\n return true;\n }\n return false;\n}\nfunction polygonIntersectsMultiPolygon(polygon, multiPolygon) {\n if (polygon.length === 1) {\n return multiPolygonContainsPoint(multiPolygon, polygon[0]);\n }\n for (var m = 0; m < multiPolygon.length; m++) {\n var ring = multiPolygon[m];\n for (var n = 0; n < ring.length; n++) {\n if (polygonContainsPoint(polygon, ring[n])) {\n return true;\n }\n }\n }\n for (var i = 0; i < polygon.length; i++) {\n if (multiPolygonContainsPoint(multiPolygon, polygon[i])) {\n return true;\n }\n }\n for (var k = 0; k < multiPolygon.length; k++) {\n if (lineIntersectsLine(polygon, multiPolygon[k])) {\n return true;\n }\n }\n return false;\n}\nfunction polygonIntersectsBufferedMultiLine(polygon, multiLine, radius) {\n for (var i = 0; i < multiLine.length; i++) {\n var line = multiLine[i];\n if (polygon.length >= 3) {\n for (var k = 0; k < line.length; k++) {\n if (polygonContainsPoint(polygon, line[k])) {\n return true;\n }\n }\n }\n if (lineIntersectsBufferedLine(polygon, line, radius)) {\n return true;\n }\n }\n return false;\n}\nfunction lineIntersectsBufferedLine(lineA, lineB, radius) {\n if (lineA.length > 1) {\n if (lineIntersectsLine(lineA, lineB)) {\n return true;\n }\n for (var j = 0; j < lineB.length; j++) {\n if (pointIntersectsBufferedLine(lineB[j], lineA, radius)) {\n return true;\n }\n }\n }\n for (var k = 0; k < lineA.length; k++) {\n if (pointIntersectsBufferedLine(lineA[k], lineB, radius)) {\n return true;\n }\n }\n return false;\n}\nfunction lineIntersectsLine(lineA, lineB) {\n if (lineA.length === 0 || lineB.length === 0) {\n return false;\n }\n for (var i = 0; i < lineA.length - 1; i++) {\n var a0 = lineA[i];\n var a1 = lineA[i + 1];\n for (var j = 0; j < lineB.length - 1; j++) {\n var b0 = lineB[j];\n var b1 = lineB[j + 1];\n if (lineSegmentIntersectsLineSegment(a0, a1, b0, b1)) {\n return true;\n }\n }\n }\n return false;\n}\nfunction lineSegmentIntersectsLineSegment(a0, a1, b0, b1) {\n return isCounterClockwise(a0, b0, b1) !== isCounterClockwise(a1, b0, b1) && isCounterClockwise(a0, a1, b0) !== isCounterClockwise(a0, a1, b1);\n}\nfunction pointIntersectsBufferedLine(p, line, radius) {\n var radiusSquared = radius * radius;\n if (line.length === 1) {\n return p.distSqr(line[0]) < radiusSquared;\n }\n for (var i = 1; i < line.length; i++) {\n var v = line[i - 1], w = line[i];\n if (distToSegmentSquared(p, v, w) < radiusSquared) {\n return true;\n }\n }\n return false;\n}\nfunction distToSegmentSquared(p, v, w) {\n var l2 = v.distSqr(w);\n if (l2 === 0) {\n return p.distSqr(v);\n }\n var t = ((p.x - v.x) * (w.x - v.x) + (p.y - v.y) * (w.y - v.y)) / l2;\n if (t < 0) {\n return p.distSqr(v);\n }\n if (t > 1) {\n return p.distSqr(w);\n }\n return p.distSqr(w.sub(v)._mult(t)._add(v));\n}\nfunction multiPolygonContainsPoint(rings, p) {\n var c = false, ring, p1, p2;\n for (var k = 0; k < rings.length; k++) {\n ring = rings[k];\n for (var i = 0, j = ring.length - 1; i < ring.length; j = i++) {\n p1 = ring[i];\n p2 = ring[j];\n if (p1.y > p.y !== p2.y > p.y && p.x < (p2.x - p1.x) * (p.y - p1.y) / (p2.y - p1.y) + p1.x) {\n c = !c;\n }\n }\n }\n return c;\n}\nfunction polygonContainsPoint(ring, p) {\n var c = false;\n for (var i = 0, j = ring.length - 1; i < ring.length; j = i++) {\n var p1 = ring[i];\n var p2 = ring[j];\n if (p1.y > p.y !== p2.y > p.y && p.x < (p2.x - p1.x) * (p.y - p1.y) / (p2.y - p1.y) + p1.x) {\n c = !c;\n }\n }\n return c;\n}\nfunction polygonIntersectsBox(ring, boxX1, boxY1, boxX2, boxY2) {\n for (var i$1 = 0, list = ring; i$1 < list.length; i$1 += 1) {\n var p = list[i$1];\n if (boxX1 <= p.x && boxY1 <= p.y && boxX2 >= p.x && boxY2 >= p.y) {\n return true;\n }\n }\n var corners = [\n new pointGeometry(boxX1, boxY1),\n new pointGeometry(boxX1, boxY2),\n new pointGeometry(boxX2, boxY2),\n new pointGeometry(boxX2, boxY1)\n ];\n if (ring.length > 2) {\n for (var i$2 = 0, list$1 = corners; i$2 < list$1.length; i$2 += 1) {\n var corner = list$1[i$2];\n if (polygonContainsPoint(ring, corner)) {\n return true;\n }\n }\n }\n for (var i = 0; i < ring.length - 1; i++) {\n var p1 = ring[i];\n var p2 = ring[i + 1];\n if (edgeIntersectsBox(p1, p2, corners)) {\n return true;\n }\n }\n return false;\n}\nfunction edgeIntersectsBox(e1, e2, corners) {\n var tl = corners[0];\n var br = corners[2];\n if (e1.x < tl.x && e2.x < tl.x || e1.x > br.x && e2.x > br.x || e1.y < tl.y && e2.y < tl.y || e1.y > br.y && e2.y > br.y) {\n return false;\n }\n var dir = isCounterClockwise(e1, e2, corners[0]);\n return dir !== isCounterClockwise(e1, e2, corners[1]) || dir !== isCounterClockwise(e1, e2, corners[2]) || dir !== isCounterClockwise(e1, e2, corners[3]);\n}\n\nfunction getMaximumPaintValue(property, layer, bucket) {\n var value = layer.paint.get(property).value;\n if (value.kind === 'constant') {\n return value.value;\n } else {\n return bucket.programConfigurations.get(layer.id).getMaxValue(property);\n }\n}\nfunction translateDistance(translate) {\n return Math.sqrt(translate[0] * translate[0] + translate[1] * translate[1]);\n}\nfunction translate(queryGeometry, translate, translateAnchor, bearing, pixelsToTileUnits) {\n if (!translate[0] && !translate[1]) {\n return queryGeometry;\n }\n var pt = pointGeometry.convert(translate)._mult(pixelsToTileUnits);\n if (translateAnchor === 'viewport') {\n pt._rotate(-bearing);\n }\n var translated = [];\n for (var i = 0; i < queryGeometry.length; i++) {\n var point = queryGeometry[i];\n translated.push(point.sub(pt));\n }\n return translated;\n}\n\nvar layout$2 = new Properties({ 'circle-sort-key': new DataDrivenProperty(spec['layout_circle']['circle-sort-key']) });\nvar paint$1 = new Properties({\n 'circle-radius': new DataDrivenProperty(spec['paint_circle']['circle-radius']),\n 'circle-color': new DataDrivenProperty(spec['paint_circle']['circle-color']),\n 'circle-blur': new DataDrivenProperty(spec['paint_circle']['circle-blur']),\n 'circle-opacity': new DataDrivenProperty(spec['paint_circle']['circle-opacity']),\n 'circle-translate': new DataConstantProperty(spec['paint_circle']['circle-translate']),\n 'circle-translate-anchor': new DataConstantProperty(spec['paint_circle']['circle-translate-anchor']),\n 'circle-pitch-scale': new DataConstantProperty(spec['paint_circle']['circle-pitch-scale']),\n 'circle-pitch-alignment': new DataConstantProperty(spec['paint_circle']['circle-pitch-alignment']),\n 'circle-stroke-width': new DataDrivenProperty(spec['paint_circle']['circle-stroke-width']),\n 'circle-stroke-color': new DataDrivenProperty(spec['paint_circle']['circle-stroke-color']),\n 'circle-stroke-opacity': new DataDrivenProperty(spec['paint_circle']['circle-stroke-opacity'])\n});\nvar properties = {\n paint: paint$1,\n layout: layout$2\n};\n\nvar ARRAY_TYPE = typeof Float32Array !== 'undefined' ? Float32Array : Array;\nif (!Math.hypot) {\n Math.hypot = function () {\n var arguments$1 = arguments;\n var y = 0, i = arguments.length;\n while (i--) {\n y += arguments$1[i] * arguments$1[i];\n }\n return Math.sqrt(y);\n };\n}\n\nfunction create() {\n var out = new ARRAY_TYPE(4);\n if (ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n }\n out[0] = 1;\n out[3] = 1;\n return out;\n}\nfunction rotate(out, a, rad) {\n var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3];\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n out[0] = a0 * c + a2 * s;\n out[1] = a1 * c + a3 * s;\n out[2] = a0 * -s + a2 * c;\n out[3] = a1 * -s + a3 * c;\n return out;\n}\n\nfunction create$1() {\n var out = new ARRAY_TYPE(9);\n if (ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n }\n out[0] = 1;\n out[4] = 1;\n out[8] = 1;\n return out;\n}\nfunction fromRotation(out, rad) {\n var s = Math.sin(rad), c = Math.cos(rad);\n out[0] = c;\n out[1] = s;\n out[2] = 0;\n out[3] = -s;\n out[4] = c;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n\nfunction create$2() {\n var out = new ARRAY_TYPE(16);\n if (ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n }\n out[0] = 1;\n out[5] = 1;\n out[10] = 1;\n out[15] = 1;\n return out;\n}\nfunction clone$1(a) {\n var out = new ARRAY_TYPE(16);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n}\nfunction identity(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\nfunction invert(out, a) {\n var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3];\n var a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7];\n var a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11];\n var a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n var b00 = a00 * a11 - a01 * a10;\n var b01 = a00 * a12 - a02 * a10;\n var b02 = a00 * a13 - a03 * a10;\n var b03 = a01 * a12 - a02 * a11;\n var b04 = a01 * a13 - a03 * a11;\n var b05 = a02 * a13 - a03 * a12;\n var b06 = a20 * a31 - a21 * a30;\n var b07 = a20 * a32 - a22 * a30;\n var b08 = a20 * a33 - a23 * a30;\n var b09 = a21 * a32 - a22 * a31;\n var b10 = a21 * a33 - a23 * a31;\n var b11 = a22 * a33 - a23 * a32;\n var det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n if (!det) {\n return null;\n }\n det = 1 / det;\n out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n out[1] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n out[2] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n out[3] = (a22 * b04 - a21 * b05 - a23 * b03) * det;\n out[4] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n out[5] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n out[6] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n out[7] = (a20 * b05 - a22 * b02 + a23 * b01) * det;\n out[8] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n out[9] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n out[10] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n out[11] = (a21 * b02 - a20 * b04 - a23 * b00) * det;\n out[12] = (a11 * b07 - a10 * b09 - a12 * b06) * det;\n out[13] = (a00 * b09 - a01 * b07 + a02 * b06) * det;\n out[14] = (a31 * b01 - a30 * b03 - a32 * b00) * det;\n out[15] = (a20 * b03 - a21 * b01 + a22 * b00) * det;\n return out;\n}\nfunction multiply(out, a, b) {\n var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3];\n var a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7];\n var a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11];\n var a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n var b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3];\n out[0] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[1] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[2] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[3] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[4];\n b1 = b[5];\n b2 = b[6];\n b3 = b[7];\n out[4] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[5] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[6] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[7] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[8];\n b1 = b[9];\n b2 = b[10];\n b3 = b[11];\n out[8] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[9] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[10] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[11] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[12];\n b1 = b[13];\n b2 = b[14];\n b3 = b[15];\n out[12] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[13] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[14] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[15] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n return out;\n}\nfunction translate$1(out, a, v) {\n var x = v[0], y = v[1], z = v[2];\n var a00, a01, a02, a03;\n var a10, a11, a12, a13;\n var a20, a21, a22, a23;\n if (a === out) {\n out[12] = a[0] * x + a[4] * y + a[8] * z + a[12];\n out[13] = a[1] * x + a[5] * y + a[9] * z + a[13];\n out[14] = a[2] * x + a[6] * y + a[10] * z + a[14];\n out[15] = a[3] * x + a[7] * y + a[11] * z + a[15];\n } else {\n a00 = a[0];\n a01 = a[1];\n a02 = a[2];\n a03 = a[3];\n a10 = a[4];\n a11 = a[5];\n a12 = a[6];\n a13 = a[7];\n a20 = a[8];\n a21 = a[9];\n a22 = a[10];\n a23 = a[11];\n out[0] = a00;\n out[1] = a01;\n out[2] = a02;\n out[3] = a03;\n out[4] = a10;\n out[5] = a11;\n out[6] = a12;\n out[7] = a13;\n out[8] = a20;\n out[9] = a21;\n out[10] = a22;\n out[11] = a23;\n out[12] = a00 * x + a10 * y + a20 * z + a[12];\n out[13] = a01 * x + a11 * y + a21 * z + a[13];\n out[14] = a02 * x + a12 * y + a22 * z + a[14];\n out[15] = a03 * x + a13 * y + a23 * z + a[15];\n }\n return out;\n}\nfunction scale(out, a, v) {\n var x = v[0], y = v[1], z = v[2];\n out[0] = a[0] * x;\n out[1] = a[1] * x;\n out[2] = a[2] * x;\n out[3] = a[3] * x;\n out[4] = a[4] * y;\n out[5] = a[5] * y;\n out[6] = a[6] * y;\n out[7] = a[7] * y;\n out[8] = a[8] * z;\n out[9] = a[9] * z;\n out[10] = a[10] * z;\n out[11] = a[11] * z;\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n}\nfunction rotateX(out, a, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n var a10 = a[4];\n var a11 = a[5];\n var a12 = a[6];\n var a13 = a[7];\n var a20 = a[8];\n var a21 = a[9];\n var a22 = a[10];\n var a23 = a[11];\n if (a !== out) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n }\n out[4] = a10 * c + a20 * s;\n out[5] = a11 * c + a21 * s;\n out[6] = a12 * c + a22 * s;\n out[7] = a13 * c + a23 * s;\n out[8] = a20 * c - a10 * s;\n out[9] = a21 * c - a11 * s;\n out[10] = a22 * c - a12 * s;\n out[11] = a23 * c - a13 * s;\n return out;\n}\nfunction rotateZ(out, a, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n var a00 = a[0];\n var a01 = a[1];\n var a02 = a[2];\n var a03 = a[3];\n var a10 = a[4];\n var a11 = a[5];\n var a12 = a[6];\n var a13 = a[7];\n if (a !== out) {\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n }\n out[0] = a00 * c + a10 * s;\n out[1] = a01 * c + a11 * s;\n out[2] = a02 * c + a12 * s;\n out[3] = a03 * c + a13 * s;\n out[4] = a10 * c - a00 * s;\n out[5] = a11 * c - a01 * s;\n out[6] = a12 * c - a02 * s;\n out[7] = a13 * c - a03 * s;\n return out;\n}\nfunction perspective(out, fovy, aspect, near, far) {\n var f = 1 / Math.tan(fovy / 2), nf;\n out[0] = f / aspect;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = f;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[11] = -1;\n out[12] = 0;\n out[13] = 0;\n out[15] = 0;\n if (far != null && far !== Infinity) {\n nf = 1 / (near - far);\n out[10] = (far + near) * nf;\n out[14] = 2 * far * near * nf;\n } else {\n out[10] = -1;\n out[14] = -2 * near;\n }\n return out;\n}\nfunction ortho(out, left, right, bottom, top, near, far) {\n var lr = 1 / (left - right);\n var bt = 1 / (bottom - top);\n var nf = 1 / (near - far);\n out[0] = -2 * lr;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = -2 * bt;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 2 * nf;\n out[11] = 0;\n out[12] = (left + right) * lr;\n out[13] = (top + bottom) * bt;\n out[14] = (far + near) * nf;\n out[15] = 1;\n return out;\n}\nvar mul = multiply;\n\nfunction create$3() {\n var out = new ARRAY_TYPE(3);\n if (ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n }\n return out;\n}\nfunction clone$2(a) {\n var out = new ARRAY_TYPE(3);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n return out;\n}\nfunction add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n return out;\n}\nfunction subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n return out;\n}\nfunction scale$1(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n return out;\n}\nfunction normalize(out, a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var len = x * x + y * y + z * z;\n if (len > 0) {\n len = 1 / Math.sqrt(len);\n }\n out[0] = a[0] * len;\n out[1] = a[1] * len;\n out[2] = a[2] * len;\n return out;\n}\nfunction dot(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n}\nfunction cross(out, a, b) {\n var ax = a[0], ay = a[1], az = a[2];\n var bx = b[0], by = b[1], bz = b[2];\n out[0] = ay * bz - az * by;\n out[1] = az * bx - ax * bz;\n out[2] = ax * by - ay * bx;\n return out;\n}\nfunction transformMat3(out, a, m) {\n var x = a[0], y = a[1], z = a[2];\n out[0] = x * m[0] + y * m[3] + z * m[6];\n out[1] = x * m[1] + y * m[4] + z * m[7];\n out[2] = x * m[2] + y * m[5] + z * m[8];\n return out;\n}\nvar sub = subtract;\nvar forEach = function () {\n var vec = create$3();\n return function (a, stride, offset, count, fn, arg) {\n var i, l;\n if (!stride) {\n stride = 3;\n }\n if (!offset) {\n offset = 0;\n }\n if (count) {\n l = Math.min(count * stride + offset, a.length);\n } else {\n l = a.length;\n }\n for (i = offset; i < l; i += stride) {\n vec[0] = a[i];\n vec[1] = a[i + 1];\n vec[2] = a[i + 2];\n fn(vec, vec, arg);\n a[i] = vec[0];\n a[i + 1] = vec[1];\n a[i + 2] = vec[2];\n }\n return a;\n };\n}();\n\nfunction create$4() {\n var out = new ARRAY_TYPE(4);\n if (ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n }\n return out;\n}\nfunction scale$2(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n return out;\n}\nfunction dot$1(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];\n}\nfunction transformMat4(out, a, m) {\n var x = a[0], y = a[1], z = a[2], w = a[3];\n out[0] = m[0] * x + m[4] * y + m[8] * z + m[12] * w;\n out[1] = m[1] * x + m[5] * y + m[9] * z + m[13] * w;\n out[2] = m[2] * x + m[6] * y + m[10] * z + m[14] * w;\n out[3] = m[3] * x + m[7] * y + m[11] * z + m[15] * w;\n return out;\n}\nvar forEach$1 = function () {\n var vec = create$4();\n return function (a, stride, offset, count, fn, arg) {\n var i, l;\n if (!stride) {\n stride = 4;\n }\n if (!offset) {\n offset = 0;\n }\n if (count) {\n l = Math.min(count * stride + offset, a.length);\n } else {\n l = a.length;\n }\n for (i = offset; i < l; i += stride) {\n vec[0] = a[i];\n vec[1] = a[i + 1];\n vec[2] = a[i + 2];\n vec[3] = a[i + 3];\n fn(vec, vec, arg);\n a[i] = vec[0];\n a[i + 1] = vec[1];\n a[i + 2] = vec[2];\n a[i + 3] = vec[3];\n }\n return a;\n };\n}();\n\nfunction create$5() {\n var out = new ARRAY_TYPE(2);\n if (ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n }\n return out;\n}\nfunction squaredLength(a) {\n var x = a[0], y = a[1];\n return x * x + y * y;\n}\nvar sqrLen = squaredLength;\nvar forEach$2 = function () {\n var vec = create$5();\n return function (a, stride, offset, count, fn, arg) {\n var i, l;\n if (!stride) {\n stride = 2;\n }\n if (!offset) {\n offset = 0;\n }\n if (count) {\n l = Math.min(count * stride + offset, a.length);\n } else {\n l = a.length;\n }\n for (i = offset; i < l; i += stride) {\n vec[0] = a[i];\n vec[1] = a[i + 1];\n fn(vec, vec, arg);\n a[i] = vec[0];\n a[i + 1] = vec[1];\n }\n return a;\n };\n}();\n\nvar CircleStyleLayer = function (StyleLayer) {\n function CircleStyleLayer(layer) {\n StyleLayer.call(this, layer, properties);\n }\n if (StyleLayer)\n CircleStyleLayer.__proto__ = StyleLayer;\n CircleStyleLayer.prototype = Object.create(StyleLayer && StyleLayer.prototype);\n CircleStyleLayer.prototype.constructor = CircleStyleLayer;\n CircleStyleLayer.prototype.createBucket = function createBucket(parameters) {\n return new CircleBucket(parameters);\n };\n CircleStyleLayer.prototype.queryRadius = function queryRadius(bucket) {\n var circleBucket = bucket;\n return getMaximumPaintValue('circle-radius', this, circleBucket) + getMaximumPaintValue('circle-stroke-width', this, circleBucket) + translateDistance(this.paint.get('circle-translate'));\n };\n CircleStyleLayer.prototype.queryIntersectsFeature = function queryIntersectsFeature(queryGeometry, feature, featureState, geometry, zoom, transform, pixelsToTileUnits, pixelPosMatrix) {\n var translatedPolygon = translate(queryGeometry, this.paint.get('circle-translate'), this.paint.get('circle-translate-anchor'), transform.angle, pixelsToTileUnits);\n var radius = this.paint.get('circle-radius').evaluate(feature, featureState);\n var stroke = this.paint.get('circle-stroke-width').evaluate(feature, featureState);\n var size = radius + stroke;\n var alignWithMap = this.paint.get('circle-pitch-alignment') === 'map';\n var transformedPolygon = alignWithMap ? translatedPolygon : projectQueryGeometry(translatedPolygon, pixelPosMatrix);\n var transformedSize = alignWithMap ? size * pixelsToTileUnits : size;\n for (var i$1 = 0, list$1 = geometry; i$1 < list$1.length; i$1 += 1) {\n var ring = list$1[i$1];\n for (var i = 0, list = ring; i < list.length; i += 1) {\n var point = list[i];\n var transformedPoint = alignWithMap ? point : projectPoint(point, pixelPosMatrix);\n var adjustedSize = transformedSize;\n var projectedCenter = transformMat4([], [\n point.x,\n point.y,\n 0,\n 1\n ], pixelPosMatrix);\n if (this.paint.get('circle-pitch-scale') === 'viewport' && this.paint.get('circle-pitch-alignment') === 'map') {\n adjustedSize *= projectedCenter[3] / transform.cameraToCenterDistance;\n } else if (this.paint.get('circle-pitch-scale') === 'map' && this.paint.get('circle-pitch-alignment') === 'viewport') {\n adjustedSize *= transform.cameraToCenterDistance / projectedCenter[3];\n }\n if (polygonIntersectsBufferedPoint(transformedPolygon, transformedPoint, adjustedSize)) {\n return true;\n }\n }\n }\n return false;\n };\n return CircleStyleLayer;\n}(StyleLayer);\nfunction projectPoint(p, pixelPosMatrix) {\n var point = transformMat4([], [\n p.x,\n p.y,\n 0,\n 1\n ], pixelPosMatrix);\n return new pointGeometry(point[0] / point[3], point[1] / point[3]);\n}\nfunction projectQueryGeometry(queryGeometry, pixelPosMatrix) {\n return queryGeometry.map(function (p) {\n return projectPoint(p, pixelPosMatrix);\n });\n}\n\nvar HeatmapBucket = function (CircleBucket) {\n function HeatmapBucket() {\n CircleBucket.apply(this, arguments);\n }\n if (CircleBucket)\n HeatmapBucket.__proto__ = CircleBucket;\n HeatmapBucket.prototype = Object.create(CircleBucket && CircleBucket.prototype);\n HeatmapBucket.prototype.constructor = HeatmapBucket;\n return HeatmapBucket;\n}(CircleBucket);\nregister('HeatmapBucket', HeatmapBucket, { omit: ['layers'] });\n\nfunction createImage(image, ref, channels, data) {\n var width = ref.width;\n var height = ref.height;\n if (!data) {\n data = new Uint8Array(width * height * channels);\n } else if (data instanceof Uint8ClampedArray) {\n data = new Uint8Array(data.buffer);\n } else if (data.length !== width * height * channels) {\n throw new RangeError('mismatched image size');\n }\n image.width = width;\n image.height = height;\n image.data = data;\n return image;\n}\nfunction resizeImage(image, ref, channels) {\n var width = ref.width;\n var height = ref.height;\n if (width === image.width && height === image.height) {\n return;\n }\n var newImage = createImage({}, {\n width: width,\n height: height\n }, channels);\n copyImage(image, newImage, {\n x: 0,\n y: 0\n }, {\n x: 0,\n y: 0\n }, {\n width: Math.min(image.width, width),\n height: Math.min(image.height, height)\n }, channels);\n image.width = width;\n image.height = height;\n image.data = newImage.data;\n}\nfunction copyImage(srcImg, dstImg, srcPt, dstPt, size, channels) {\n if (size.width === 0 || size.height === 0) {\n return dstImg;\n }\n if (size.width > srcImg.width || size.height > srcImg.height || srcPt.x > srcImg.width - size.width || srcPt.y > srcImg.height - size.height) {\n throw new RangeError('out of range source coordinates for image copy');\n }\n if (size.width > dstImg.width || size.height > dstImg.height || dstPt.x > dstImg.width - size.width || dstPt.y > dstImg.height - size.height) {\n throw new RangeError('out of range destination coordinates for image copy');\n }\n var srcData = srcImg.data;\n var dstData = dstImg.data;\n for (var y = 0; y < size.height; y++) {\n var srcOffset = ((srcPt.y + y) * srcImg.width + srcPt.x) * channels;\n var dstOffset = ((dstPt.y + y) * dstImg.width + dstPt.x) * channels;\n for (var i = 0; i < size.width * channels; i++) {\n dstData[dstOffset + i] = srcData[srcOffset + i];\n }\n }\n return dstImg;\n}\nvar AlphaImage = function AlphaImage(size, data) {\n createImage(this, size, 1, data);\n};\nAlphaImage.prototype.resize = function resize(size) {\n resizeImage(this, size, 1);\n};\nAlphaImage.prototype.clone = function clone() {\n return new AlphaImage({\n width: this.width,\n height: this.height\n }, new Uint8Array(this.data));\n};\nAlphaImage.copy = function copy(srcImg, dstImg, srcPt, dstPt, size) {\n copyImage(srcImg, dstImg, srcPt, dstPt, size, 1);\n};\nvar RGBAImage = function RGBAImage(size, data) {\n createImage(this, size, 4, data);\n};\nRGBAImage.prototype.resize = function resize(size) {\n resizeImage(this, size, 4);\n};\nRGBAImage.prototype.replace = function replace(data, copy) {\n if (copy) {\n this.data.set(data);\n } else if (data instanceof Uint8ClampedArray) {\n this.data = new Uint8Array(data.buffer);\n } else {\n this.data = data;\n }\n};\nRGBAImage.prototype.clone = function clone() {\n return new RGBAImage({\n width: this.width,\n height: this.height\n }, new Uint8Array(this.data));\n};\nRGBAImage.copy = function copy(srcImg, dstImg, srcPt, dstPt, size) {\n copyImage(srcImg, dstImg, srcPt, dstPt, size, 4);\n};\nregister('AlphaImage', AlphaImage);\nregister('RGBAImage', RGBAImage);\n\nvar paint$2 = new Properties({\n 'heatmap-radius': new DataDrivenProperty(spec['paint_heatmap']['heatmap-radius']),\n 'heatmap-weight': new DataDrivenProperty(spec['paint_heatmap']['heatmap-weight']),\n 'heatmap-intensity': new DataConstantProperty(spec['paint_heatmap']['heatmap-intensity']),\n 'heatmap-color': new ColorRampProperty(spec['paint_heatmap']['heatmap-color']),\n 'heatmap-opacity': new DataConstantProperty(spec['paint_heatmap']['heatmap-opacity'])\n});\nvar properties$1 = { paint: paint$2 };\n\nfunction renderColorRamp(params) {\n var evaluationGlobals = {};\n var width = params.resolution || 256;\n var height = params.clips ? params.clips.length : 1;\n var image = params.image || new RGBAImage({\n width: width,\n height: height\n });\n var renderPixel = function (stride, index, progress) {\n evaluationGlobals[params.evaluationKey] = progress;\n var pxColor = params.expression.evaluate(evaluationGlobals);\n image.data[stride + index + 0] = Math.floor(pxColor.r * 255 / pxColor.a);\n image.data[stride + index + 1] = Math.floor(pxColor.g * 255 / pxColor.a);\n image.data[stride + index + 2] = Math.floor(pxColor.b * 255 / pxColor.a);\n image.data[stride + index + 3] = Math.floor(pxColor.a * 255);\n };\n if (!params.clips) {\n for (var i = 0, j = 0; i < width; i++, j += 4) {\n var progress = i / (width - 1);\n renderPixel(0, j, progress);\n }\n } else {\n for (var clip = 0, stride = 0; clip < height; ++clip, stride += width * 4) {\n for (var i$1 = 0, j$1 = 0; i$1 < width; i$1++, j$1 += 4) {\n var progress$1 = i$1 / (width - 1);\n var ref = params.clips[clip];\n var start = ref.start;\n var end = ref.end;\n var evaluationProgress = start * (1 - progress$1) + end * progress$1;\n renderPixel(stride, j$1, evaluationProgress);\n }\n }\n }\n return image;\n}\n\nvar HeatmapStyleLayer = function (StyleLayer) {\n function HeatmapStyleLayer(layer) {\n StyleLayer.call(this, layer, properties$1);\n this._updateColorRamp();\n }\n if (StyleLayer)\n HeatmapStyleLayer.__proto__ = StyleLayer;\n HeatmapStyleLayer.prototype = Object.create(StyleLayer && StyleLayer.prototype);\n HeatmapStyleLayer.prototype.constructor = HeatmapStyleLayer;\n HeatmapStyleLayer.prototype.createBucket = function createBucket(options) {\n return new HeatmapBucket(options);\n };\n HeatmapStyleLayer.prototype._handleSpecialPaintPropertyUpdate = function _handleSpecialPaintPropertyUpdate(name) {\n if (name === 'heatmap-color') {\n this._updateColorRamp();\n }\n };\n HeatmapStyleLayer.prototype._updateColorRamp = function _updateColorRamp() {\n var expression = this._transitionablePaint._values['heatmap-color'].value.expression;\n this.colorRamp = renderColorRamp({\n expression: expression,\n evaluationKey: 'heatmapDensity',\n image: this.colorRamp\n });\n this.colorRampTexture = null;\n };\n HeatmapStyleLayer.prototype.resize = function resize() {\n if (this.heatmapFbo) {\n this.heatmapFbo.destroy();\n this.heatmapFbo = null;\n }\n };\n HeatmapStyleLayer.prototype.queryRadius = function queryRadius() {\n return 0;\n };\n HeatmapStyleLayer.prototype.queryIntersectsFeature = function queryIntersectsFeature() {\n return false;\n };\n HeatmapStyleLayer.prototype.hasOffscreenPass = function hasOffscreenPass() {\n return this.paint.get('heatmap-opacity') !== 0 && this.visibility !== 'none';\n };\n return HeatmapStyleLayer;\n}(StyleLayer);\n\nvar paint$3 = new Properties({\n 'hillshade-illumination-direction': new DataConstantProperty(spec['paint_hillshade']['hillshade-illumination-direction']),\n 'hillshade-illumination-anchor': new DataConstantProperty(spec['paint_hillshade']['hillshade-illumination-anchor']),\n 'hillshade-exaggeration': new DataConstantProperty(spec['paint_hillshade']['hillshade-exaggeration']),\n 'hillshade-shadow-color': new DataConstantProperty(spec['paint_hillshade']['hillshade-shadow-color']),\n 'hillshade-highlight-color': new DataConstantProperty(spec['paint_hillshade']['hillshade-highlight-color']),\n 'hillshade-accent-color': new DataConstantProperty(spec['paint_hillshade']['hillshade-accent-color'])\n});\nvar properties$2 = { paint: paint$3 };\n\nvar HillshadeStyleLayer = function (StyleLayer) {\n function HillshadeStyleLayer(layer) {\n StyleLayer.call(this, layer, properties$2);\n }\n if (StyleLayer)\n HillshadeStyleLayer.__proto__ = StyleLayer;\n HillshadeStyleLayer.prototype = Object.create(StyleLayer && StyleLayer.prototype);\n HillshadeStyleLayer.prototype.constructor = HillshadeStyleLayer;\n HillshadeStyleLayer.prototype.hasOffscreenPass = function hasOffscreenPass() {\n return this.paint.get('hillshade-exaggeration') !== 0 && this.visibility !== 'none';\n };\n return HillshadeStyleLayer;\n}(StyleLayer);\n\nvar layout$3 = createLayout([{\n name: 'a_pos',\n components: 2,\n type: 'Int16'\n }], 4);\nvar members$1 = layout$3.members;\n\nvar earcut_1 = earcut;\nvar default_1 = earcut;\nfunction earcut(data, holeIndices, dim) {\n dim = dim || 2;\n var hasHoles = holeIndices && holeIndices.length, outerLen = hasHoles ? holeIndices[0] * dim : data.length, outerNode = linkedList(data, 0, outerLen, dim, true), triangles = [];\n if (!outerNode || outerNode.next === outerNode.prev) {\n return triangles;\n }\n var minX, minY, maxX, maxY, x, y, invSize;\n if (hasHoles) {\n outerNode = eliminateHoles(data, holeIndices, outerNode, dim);\n }\n if (data.length > 80 * dim) {\n minX = maxX = data[0];\n minY = maxY = data[1];\n for (var i = dim; i < outerLen; i += dim) {\n x = data[i];\n y = data[i + 1];\n if (x < minX) {\n minX = x;\n }\n if (y < minY) {\n minY = y;\n }\n if (x > maxX) {\n maxX = x;\n }\n if (y > maxY) {\n maxY = y;\n }\n }\n invSize = Math.max(maxX - minX, maxY - minY);\n invSize = invSize !== 0 ? 1 / invSize : 0;\n }\n earcutLinked(outerNode, triangles, dim, minX, minY, invSize);\n return triangles;\n}\nfunction linkedList(data, start, end, dim, clockwise) {\n var i, last;\n if (clockwise === signedArea(data, start, end, dim) > 0) {\n for (i = start; i < end; i += dim) {\n last = insertNode(i, data[i], data[i + 1], last);\n }\n } else {\n for (i = end - dim; i >= start; i -= dim) {\n last = insertNode(i, data[i], data[i + 1], last);\n }\n }\n if (last && equals(last, last.next)) {\n removeNode(last);\n last = last.next;\n }\n return last;\n}\nfunction filterPoints(start, end) {\n if (!start) {\n return start;\n }\n if (!end) {\n end = start;\n }\n var p = start, again;\n do {\n again = false;\n if (!p.steiner && (equals(p, p.next) || area(p.prev, p, p.next) === 0)) {\n removeNode(p);\n p = end = p.prev;\n if (p === p.next) {\n break;\n }\n again = true;\n } else {\n p = p.next;\n }\n } while (again || p !== end);\n return end;\n}\nfunction earcutLinked(ear, triangles, dim, minX, minY, invSize, pass) {\n if (!ear) {\n return;\n }\n if (!pass && invSize) {\n indexCurve(ear, minX, minY, invSize);\n }\n var stop = ear, prev, next;\n while (ear.prev !== ear.next) {\n prev = ear.prev;\n next = ear.next;\n if (invSize ? isEarHashed(ear, minX, minY, invSize) : isEar(ear)) {\n triangles.push(prev.i / dim);\n triangles.push(ear.i / dim);\n triangles.push(next.i / dim);\n removeNode(ear);\n ear = next.next;\n stop = next.next;\n continue;\n }\n ear = next;\n if (ear === stop) {\n if (!pass) {\n earcutLinked(filterPoints(ear), triangles, dim, minX, minY, invSize, 1);\n } else if (pass === 1) {\n ear = cureLocalIntersections(filterPoints(ear), triangles, dim);\n earcutLinked(ear, triangles, dim, minX, minY, invSize, 2);\n } else if (pass === 2) {\n splitEarcut(ear, triangles, dim, minX, minY, invSize);\n }\n break;\n }\n }\n}\nfunction isEar(ear) {\n var a = ear.prev, b = ear, c = ear.next;\n if (area(a, b, c) >= 0) {\n return false;\n }\n var p = ear.next.next;\n while (p !== ear.prev) {\n if (pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y) && area(p.prev, p, p.next) >= 0) {\n return false;\n }\n p = p.next;\n }\n return true;\n}\nfunction isEarHashed(ear, minX, minY, invSize) {\n var a = ear.prev, b = ear, c = ear.next;\n if (area(a, b, c) >= 0) {\n return false;\n }\n var minTX = a.x < b.x ? a.x < c.x ? a.x : c.x : b.x < c.x ? b.x : c.x, minTY = a.y < b.y ? a.y < c.y ? a.y : c.y : b.y < c.y ? b.y : c.y, maxTX = a.x > b.x ? a.x > c.x ? a.x : c.x : b.x > c.x ? b.x : c.x, maxTY = a.y > b.y ? a.y > c.y ? a.y : c.y : b.y > c.y ? b.y : c.y;\n var minZ = zOrder(minTX, minTY, minX, minY, invSize), maxZ = zOrder(maxTX, maxTY, minX, minY, invSize);\n var p = ear.prevZ, n = ear.nextZ;\n while (p && p.z >= minZ && n && n.z <= maxZ) {\n if (p !== ear.prev && p !== ear.next && pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y) && area(p.prev, p, p.next) >= 0) {\n return false;\n }\n p = p.prevZ;\n if (n !== ear.prev && n !== ear.next && pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, n.x, n.y) && area(n.prev, n, n.next) >= 0) {\n return false;\n }\n n = n.nextZ;\n }\n while (p && p.z >= minZ) {\n if (p !== ear.prev && p !== ear.next && pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y) && area(p.prev, p, p.next) >= 0) {\n return false;\n }\n p = p.prevZ;\n }\n while (n && n.z <= maxZ) {\n if (n !== ear.prev && n !== ear.next && pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, n.x, n.y) && area(n.prev, n, n.next) >= 0) {\n return false;\n }\n n = n.nextZ;\n }\n return true;\n}\nfunction cureLocalIntersections(start, triangles, dim) {\n var p = start;\n do {\n var a = p.prev, b = p.next.next;\n if (!equals(a, b) && intersects(a, p, p.next, b) && locallyInside(a, b) && locallyInside(b, a)) {\n triangles.push(a.i / dim);\n triangles.push(p.i / dim);\n triangles.push(b.i / dim);\n removeNode(p);\n removeNode(p.next);\n p = start = b;\n }\n p = p.next;\n } while (p !== start);\n return filterPoints(p);\n}\nfunction splitEarcut(start, triangles, dim, minX, minY, invSize) {\n var a = start;\n do {\n var b = a.next.next;\n while (b !== a.prev) {\n if (a.i !== b.i && isValidDiagonal(a, b)) {\n var c = splitPolygon(a, b);\n a = filterPoints(a, a.next);\n c = filterPoints(c, c.next);\n earcutLinked(a, triangles, dim, minX, minY, invSize);\n earcutLinked(c, triangles, dim, minX, minY, invSize);\n return;\n }\n b = b.next;\n }\n a = a.next;\n } while (a !== start);\n}\nfunction eliminateHoles(data, holeIndices, outerNode, dim) {\n var queue = [], i, len, start, end, list;\n for (i = 0, len = holeIndices.length; i < len; i++) {\n start = holeIndices[i] * dim;\n end = i < len - 1 ? holeIndices[i + 1] * dim : data.length;\n list = linkedList(data, start, end, dim, false);\n if (list === list.next) {\n list.steiner = true;\n }\n queue.push(getLeftmost(list));\n }\n queue.sort(compareX);\n for (i = 0; i < queue.length; i++) {\n eliminateHole(queue[i], outerNode);\n outerNode = filterPoints(outerNode, outerNode.next);\n }\n return outerNode;\n}\nfunction compareX(a, b) {\n return a.x - b.x;\n}\nfunction eliminateHole(hole, outerNode) {\n outerNode = findHoleBridge(hole, outerNode);\n if (outerNode) {\n var b = splitPolygon(outerNode, hole);\n filterPoints(outerNode, outerNode.next);\n filterPoints(b, b.next);\n }\n}\nfunction findHoleBridge(hole, outerNode) {\n var p = outerNode, hx = hole.x, hy = hole.y, qx = -Infinity, m;\n do {\n if (hy <= p.y && hy >= p.next.y && p.next.y !== p.y) {\n var x = p.x + (hy - p.y) * (p.next.x - p.x) / (p.next.y - p.y);\n if (x <= hx && x > qx) {\n qx = x;\n if (x === hx) {\n if (hy === p.y) {\n return p;\n }\n if (hy === p.next.y) {\n return p.next;\n }\n }\n m = p.x < p.next.x ? p : p.next;\n }\n }\n p = p.next;\n } while (p !== outerNode);\n if (!m) {\n return null;\n }\n if (hx === qx) {\n return m;\n }\n var stop = m, mx = m.x, my = m.y, tanMin = Infinity, tan;\n p = m;\n do {\n if (hx >= p.x && p.x >= mx && hx !== p.x && pointInTriangle(hy < my ? hx : qx, hy, mx, my, hy < my ? qx : hx, hy, p.x, p.y)) {\n tan = Math.abs(hy - p.y) / (hx - p.x);\n if (locallyInside(p, hole) && (tan < tanMin || tan === tanMin && (p.x > m.x || p.x === m.x && sectorContainsSector(m, p)))) {\n m = p;\n tanMin = tan;\n }\n }\n p = p.next;\n } while (p !== stop);\n return m;\n}\nfunction sectorContainsSector(m, p) {\n return area(m.prev, m, p.prev) < 0 && area(p.next, m, m.next) < 0;\n}\nfunction indexCurve(start, minX, minY, invSize) {\n var p = start;\n do {\n if (p.z === null) {\n p.z = zOrder(p.x, p.y, minX, minY, invSize);\n }\n p.prevZ = p.prev;\n p.nextZ = p.next;\n p = p.next;\n } while (p !== start);\n p.prevZ.nextZ = null;\n p.prevZ = null;\n sortLinked(p);\n}\nfunction sortLinked(list) {\n var i, p, q, e, tail, numMerges, pSize, qSize, inSize = 1;\n do {\n p = list;\n list = null;\n tail = null;\n numMerges = 0;\n while (p) {\n numMerges++;\n q = p;\n pSize = 0;\n for (i = 0; i < inSize; i++) {\n pSize++;\n q = q.nextZ;\n if (!q) {\n break;\n }\n }\n qSize = inSize;\n while (pSize > 0 || qSize > 0 && q) {\n if (pSize !== 0 && (qSize === 0 || !q || p.z <= q.z)) {\n e = p;\n p = p.nextZ;\n pSize--;\n } else {\n e = q;\n q = q.nextZ;\n qSize--;\n }\n if (tail) {\n tail.nextZ = e;\n } else {\n list = e;\n }\n e.prevZ = tail;\n tail = e;\n }\n p = q;\n }\n tail.nextZ = null;\n inSize *= 2;\n } while (numMerges > 1);\n return list;\n}\nfunction zOrder(x, y, minX, minY, invSize) {\n x = 32767 * (x - minX) * invSize;\n y = 32767 * (y - minY) * invSize;\n x = (x | x << 8) & 16711935;\n x = (x | x << 4) & 252645135;\n x = (x | x << 2) & 858993459;\n x = (x | x << 1) & 1431655765;\n y = (y | y << 8) & 16711935;\n y = (y | y << 4) & 252645135;\n y = (y | y << 2) & 858993459;\n y = (y | y << 1) & 1431655765;\n return x | y << 1;\n}\nfunction getLeftmost(start) {\n var p = start, leftmost = start;\n do {\n if (p.x < leftmost.x || p.x === leftmost.x && p.y < leftmost.y) {\n leftmost = p;\n }\n p = p.next;\n } while (p !== start);\n return leftmost;\n}\nfunction pointInTriangle(ax, ay, bx, by, cx, cy, px, py) {\n return (cx - px) * (ay - py) - (ax - px) * (cy - py) >= 0 && (ax - px) * (by - py) - (bx - px) * (ay - py) >= 0 && (bx - px) * (cy - py) - (cx - px) * (by - py) >= 0;\n}\nfunction isValidDiagonal(a, b) {\n return a.next.i !== b.i && a.prev.i !== b.i && !intersectsPolygon(a, b) && (locallyInside(a, b) && locallyInside(b, a) && middleInside(a, b) && (area(a.prev, a, b.prev) || area(a, b.prev, b)) || equals(a, b) && area(a.prev, a, a.next) > 0 && area(b.prev, b, b.next) > 0);\n}\nfunction area(p, q, r) {\n return (q.y - p.y) * (r.x - q.x) - (q.x - p.x) * (r.y - q.y);\n}\nfunction equals(p1, p2) {\n return p1.x === p2.x && p1.y === p2.y;\n}\nfunction intersects(p1, q1, p2, q2) {\n var o1 = sign(area(p1, q1, p2));\n var o2 = sign(area(p1, q1, q2));\n var o3 = sign(area(p2, q2, p1));\n var o4 = sign(area(p2, q2, q1));\n if (o1 !== o2 && o3 !== o4) {\n return true;\n }\n if (o1 === 0 && onSegment(p1, p2, q1)) {\n return true;\n }\n if (o2 === 0 && onSegment(p1, q2, q1)) {\n return true;\n }\n if (o3 === 0 && onSegment(p2, p1, q2)) {\n return true;\n }\n if (o4 === 0 && onSegment(p2, q1, q2)) {\n return true;\n }\n return false;\n}\nfunction onSegment(p, q, r) {\n return q.x <= Math.max(p.x, r.x) && q.x >= Math.min(p.x, r.x) && q.y <= Math.max(p.y, r.y) && q.y >= Math.min(p.y, r.y);\n}\nfunction sign(num) {\n return num > 0 ? 1 : num < 0 ? -1 : 0;\n}\nfunction intersectsPolygon(a, b) {\n var p = a;\n do {\n if (p.i !== a.i && p.next.i !== a.i && p.i !== b.i && p.next.i !== b.i && intersects(p, p.next, a, b)) {\n return true;\n }\n p = p.next;\n } while (p !== a);\n return false;\n}\nfunction locallyInside(a, b) {\n return area(a.prev, a, a.next) < 0 ? area(a, b, a.next) >= 0 && area(a, a.prev, b) >= 0 : area(a, b, a.prev) < 0 || area(a, a.next, b) < 0;\n}\nfunction middleInside(a, b) {\n var p = a, inside = false, px = (a.x + b.x) / 2, py = (a.y + b.y) / 2;\n do {\n if (p.y > py !== p.next.y > py && p.next.y !== p.y && px < (p.next.x - p.x) * (py - p.y) / (p.next.y - p.y) + p.x) {\n inside = !inside;\n }\n p = p.next;\n } while (p !== a);\n return inside;\n}\nfunction splitPolygon(a, b) {\n var a2 = new Node(a.i, a.x, a.y), b2 = new Node(b.i, b.x, b.y), an = a.next, bp = b.prev;\n a.next = b;\n b.prev = a;\n a2.next = an;\n an.prev = a2;\n b2.next = a2;\n a2.prev = b2;\n bp.next = b2;\n b2.prev = bp;\n return b2;\n}\nfunction insertNode(i, x, y, last) {\n var p = new Node(i, x, y);\n if (!last) {\n p.prev = p;\n p.next = p;\n } else {\n p.next = last.next;\n p.prev = last;\n last.next.prev = p;\n last.next = p;\n }\n return p;\n}\nfunction removeNode(p) {\n p.next.prev = p.prev;\n p.prev.next = p.next;\n if (p.prevZ) {\n p.prevZ.nextZ = p.nextZ;\n }\n if (p.nextZ) {\n p.nextZ.prevZ = p.prevZ;\n }\n}\nfunction Node(i, x, y) {\n this.i = i;\n this.x = x;\n this.y = y;\n this.prev = null;\n this.next = null;\n this.z = null;\n this.prevZ = null;\n this.nextZ = null;\n this.steiner = false;\n}\nearcut.deviation = function (data, holeIndices, dim, triangles) {\n var hasHoles = holeIndices && holeIndices.length;\n var outerLen = hasHoles ? holeIndices[0] * dim : data.length;\n var polygonArea = Math.abs(signedArea(data, 0, outerLen, dim));\n if (hasHoles) {\n for (var i = 0, len = holeIndices.length; i < len; i++) {\n var start = holeIndices[i] * dim;\n var end = i < len - 1 ? holeIndices[i + 1] * dim : data.length;\n polygonArea -= Math.abs(signedArea(data, start, end, dim));\n }\n }\n var trianglesArea = 0;\n for (i = 0; i < triangles.length; i += 3) {\n var a = triangles[i] * dim;\n var b = triangles[i + 1] * dim;\n var c = triangles[i + 2] * dim;\n trianglesArea += Math.abs((data[a] - data[c]) * (data[b + 1] - data[a + 1]) - (data[a] - data[b]) * (data[c + 1] - data[a + 1]));\n }\n return polygonArea === 0 && trianglesArea === 0 ? 0 : Math.abs((trianglesArea - polygonArea) / polygonArea);\n};\nfunction signedArea(data, start, end, dim) {\n var sum = 0;\n for (var i = start, j = end - dim; i < end; i += dim) {\n sum += (data[j] - data[i]) * (data[i + 1] + data[j + 1]);\n j = i;\n }\n return sum;\n}\nearcut.flatten = function (data) {\n var dim = data[0][0].length, result = {\n vertices: [],\n holes: [],\n dimensions: dim\n }, holeIndex = 0;\n for (var i = 0; i < data.length; i++) {\n for (var j = 0; j < data[i].length; j++) {\n for (var d = 0; d < dim; d++) {\n result.vertices.push(data[i][j][d]);\n }\n }\n if (i > 0) {\n holeIndex += data[i - 1].length;\n result.holes.push(holeIndex);\n }\n }\n return result;\n};\nearcut_1.default = default_1;\n\nfunction quickselect(arr, k, left, right, compare) {\n quickselectStep(arr, k, left || 0, right || arr.length - 1, compare || defaultCompare);\n}\nfunction quickselectStep(arr, k, left, right, compare) {\n while (right > left) {\n if (right - left > 600) {\n var n = right - left + 1;\n var m = k - left + 1;\n var z = Math.log(n);\n var s = 0.5 * Math.exp(2 * z / 3);\n var sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n var newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n var newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n quickselectStep(arr, k, newLeft, newRight, compare);\n }\n var t = arr[k];\n var i = left;\n var j = right;\n swap$1(arr, left, k);\n if (compare(arr[right], t) > 0) {\n swap$1(arr, left, right);\n }\n while (i < j) {\n swap$1(arr, i, j);\n i++;\n j--;\n while (compare(arr[i], t) < 0) {\n i++;\n }\n while (compare(arr[j], t) > 0) {\n j--;\n }\n }\n if (compare(arr[left], t) === 0) {\n swap$1(arr, left, j);\n } else {\n j++;\n swap$1(arr, j, right);\n }\n if (j <= k) {\n left = j + 1;\n }\n if (k <= j) {\n right = j - 1;\n }\n }\n}\nfunction swap$1(arr, i, j) {\n var tmp = arr[i];\n arr[i] = arr[j];\n arr[j] = tmp;\n}\nfunction defaultCompare(a, b) {\n return a < b ? -1 : a > b ? 1 : 0;\n}\n\nfunction classifyRings(rings, maxRings) {\n var len = rings.length;\n if (len <= 1) {\n return [rings];\n }\n var polygons = [];\n var polygon, ccw;\n for (var i = 0; i < len; i++) {\n var area = calculateSignedArea(rings[i]);\n if (area === 0) {\n continue;\n }\n rings[i].area = Math.abs(area);\n if (ccw === undefined) {\n ccw = area < 0;\n }\n if (ccw === area < 0) {\n if (polygon) {\n polygons.push(polygon);\n }\n polygon = [rings[i]];\n } else {\n polygon.push(rings[i]);\n }\n }\n if (polygon) {\n polygons.push(polygon);\n }\n if (maxRings > 1) {\n for (var j = 0; j < polygons.length; j++) {\n if (polygons[j].length <= maxRings) {\n continue;\n }\n quickselect(polygons[j], maxRings, 1, polygons[j].length - 1, compareAreas);\n polygons[j] = polygons[j].slice(0, maxRings);\n }\n }\n return polygons;\n}\nfunction compareAreas(a, b) {\n return b.area - a.area;\n}\n\nfunction hasPattern(type, layers, options) {\n var patterns = options.patternDependencies;\n var hasPattern = false;\n for (var i = 0, list = layers; i < list.length; i += 1) {\n var layer = list[i];\n var patternProperty = layer.paint.get(type + '-pattern');\n if (!patternProperty.isConstant()) {\n hasPattern = true;\n }\n var constantPattern = patternProperty.constantOr(null);\n if (constantPattern) {\n hasPattern = true;\n patterns[constantPattern.to] = true;\n patterns[constantPattern.from] = true;\n }\n }\n return hasPattern;\n}\nfunction addPatternDependencies(type, layers, patternFeature, zoom, options) {\n var patterns = options.patternDependencies;\n for (var i = 0, list = layers; i < list.length; i += 1) {\n var layer = list[i];\n var patternProperty = layer.paint.get(type + '-pattern');\n var patternPropertyValue = patternProperty.value;\n if (patternPropertyValue.kind !== 'constant') {\n var min = patternPropertyValue.evaluate({ zoom: zoom - 1 }, patternFeature, {}, options.availableImages);\n var mid = patternPropertyValue.evaluate({ zoom: zoom }, patternFeature, {}, options.availableImages);\n var max = patternPropertyValue.evaluate({ zoom: zoom + 1 }, patternFeature, {}, options.availableImages);\n min = min && min.name ? min.name : min;\n mid = mid && mid.name ? mid.name : mid;\n max = max && max.name ? max.name : max;\n patterns[min] = true;\n patterns[mid] = true;\n patterns[max] = true;\n patternFeature.patterns[layer.id] = {\n min: min,\n mid: mid,\n max: max\n };\n }\n }\n return patternFeature;\n}\n\nvar EARCUT_MAX_RINGS = 500;\nvar FillBucket = function FillBucket(options) {\n this.zoom = options.zoom;\n this.overscaling = options.overscaling;\n this.layers = options.layers;\n this.layerIds = this.layers.map(function (layer) {\n return layer.id;\n });\n this.index = options.index;\n this.hasPattern = false;\n this.patternFeatures = [];\n this.layoutVertexArray = new StructArrayLayout2i4();\n this.indexArray = new StructArrayLayout3ui6();\n this.indexArray2 = new StructArrayLayout2ui4();\n this.programConfigurations = new ProgramConfigurationSet(options.layers, options.zoom);\n this.segments = new SegmentVector();\n this.segments2 = new SegmentVector();\n this.stateDependentLayerIds = this.layers.filter(function (l) {\n return l.isStateDependent();\n }).map(function (l) {\n return l.id;\n });\n};\nFillBucket.prototype.populate = function populate(features, options, canonical) {\n this.hasPattern = hasPattern('fill', this.layers, options);\n var fillSortKey = this.layers[0].layout.get('fill-sort-key');\n var bucketFeatures = [];\n for (var i = 0, list = features; i < list.length; i += 1) {\n var ref = list[i];\n var feature = ref.feature;\n var id = ref.id;\n var index = ref.index;\n var sourceLayerIndex = ref.sourceLayerIndex;\n var needGeometry = this.layers[0]._featureFilter.needGeometry;\n var evaluationFeature = toEvaluationFeature(feature, needGeometry);\n if (!this.layers[0]._featureFilter.filter(new EvaluationParameters(this.zoom), evaluationFeature, canonical)) {\n continue;\n }\n var sortKey = fillSortKey ? fillSortKey.evaluate(evaluationFeature, {}, canonical, options.availableImages) : undefined;\n var bucketFeature = {\n id: id,\n properties: feature.properties,\n type: feature.type,\n sourceLayerIndex: sourceLayerIndex,\n index: index,\n geometry: needGeometry ? evaluationFeature.geometry : loadGeometry(feature),\n patterns: {},\n sortKey: sortKey\n };\n bucketFeatures.push(bucketFeature);\n }\n if (fillSortKey) {\n bucketFeatures.sort(function (a, b) {\n return a.sortKey - b.sortKey;\n });\n }\n for (var i$1 = 0, list$1 = bucketFeatures; i$1 < list$1.length; i$1 += 1) {\n var bucketFeature$1 = list$1[i$1];\n var ref$1 = bucketFeature$1;\n var geometry = ref$1.geometry;\n var index$1 = ref$1.index;\n var sourceLayerIndex$1 = ref$1.sourceLayerIndex;\n if (this.hasPattern) {\n var patternFeature = addPatternDependencies('fill', this.layers, bucketFeature$1, this.zoom, options);\n this.patternFeatures.push(patternFeature);\n } else {\n this.addFeature(bucketFeature$1, geometry, index$1, canonical, {});\n }\n var feature$1 = features[index$1].feature;\n options.featureIndex.insert(feature$1, geometry, index$1, sourceLayerIndex$1, this.index);\n }\n};\nFillBucket.prototype.update = function update(states, vtLayer, imagePositions) {\n if (!this.stateDependentLayers.length) {\n return;\n }\n this.programConfigurations.updatePaintArrays(states, vtLayer, this.stateDependentLayers, imagePositions);\n};\nFillBucket.prototype.addFeatures = function addFeatures(options, canonical, imagePositions) {\n for (var i = 0, list = this.patternFeatures; i < list.length; i += 1) {\n var feature = list[i];\n this.addFeature(feature, feature.geometry, feature.index, canonical, imagePositions);\n }\n};\nFillBucket.prototype.isEmpty = function isEmpty() {\n return this.layoutVertexArray.length === 0;\n};\nFillBucket.prototype.uploadPending = function uploadPending() {\n return !this.uploaded || this.programConfigurations.needsUpload;\n};\nFillBucket.prototype.upload = function upload(context) {\n if (!this.uploaded) {\n this.layoutVertexBuffer = context.createVertexBuffer(this.layoutVertexArray, members$1);\n this.indexBuffer = context.createIndexBuffer(this.indexArray);\n this.indexBuffer2 = context.createIndexBuffer(this.indexArray2);\n }\n this.programConfigurations.upload(context);\n this.uploaded = true;\n};\nFillBucket.prototype.destroy = function destroy() {\n if (!this.layoutVertexBuffer) {\n return;\n }\n this.layoutVertexBuffer.destroy();\n this.indexBuffer.destroy();\n this.indexBuffer2.destroy();\n this.programConfigurations.destroy();\n this.segments.destroy();\n this.segments2.destroy();\n};\nFillBucket.prototype.addFeature = function addFeature(feature, geometry, index, canonical, imagePositions) {\n for (var i$4 = 0, list$2 = classifyRings(geometry, EARCUT_MAX_RINGS); i$4 < list$2.length; i$4 += 1) {\n var polygon = list$2[i$4];\n var numVertices = 0;\n for (var i$2 = 0, list = polygon; i$2 < list.length; i$2 += 1) {\n var ring = list[i$2];\n numVertices += ring.length;\n }\n var triangleSegment = this.segments.prepareSegment(numVertices, this.layoutVertexArray, this.indexArray);\n var triangleIndex = triangleSegment.vertexLength;\n var flattened = [];\n var holeIndices = [];\n for (var i$3 = 0, list$1 = polygon; i$3 < list$1.length; i$3 += 1) {\n var ring$1 = list$1[i$3];\n if (ring$1.length === 0) {\n continue;\n }\n if (ring$1 !== polygon[0]) {\n holeIndices.push(flattened.length / 2);\n }\n var lineSegment = this.segments2.prepareSegment(ring$1.length, this.layoutVertexArray, this.indexArray2);\n var lineIndex = lineSegment.vertexLength;\n this.layoutVertexArray.emplaceBack(ring$1[0].x, ring$1[0].y);\n this.indexArray2.emplaceBack(lineIndex + ring$1.length - 1, lineIndex);\n flattened.push(ring$1[0].x);\n flattened.push(ring$1[0].y);\n for (var i = 1; i < ring$1.length; i++) {\n this.layoutVertexArray.emplaceBack(ring$1[i].x, ring$1[i].y);\n this.indexArray2.emplaceBack(lineIndex + i - 1, lineIndex + i);\n flattened.push(ring$1[i].x);\n flattened.push(ring$1[i].y);\n }\n lineSegment.vertexLength += ring$1.length;\n lineSegment.primitiveLength += ring$1.length;\n }\n var indices = earcut_1(flattened, holeIndices);\n for (var i$1 = 0; i$1 < indices.length; i$1 += 3) {\n this.indexArray.emplaceBack(triangleIndex + indices[i$1], triangleIndex + indices[i$1 + 1], triangleIndex + indices[i$1 + 2]);\n }\n triangleSegment.vertexLength += numVertices;\n triangleSegment.primitiveLength += indices.length / 3;\n }\n this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, feature, index, imagePositions, canonical);\n};\nregister('FillBucket', FillBucket, {\n omit: [\n 'layers',\n 'patternFeatures'\n ]\n});\n\nvar layout$4 = new Properties({ 'fill-sort-key': new DataDrivenProperty(spec['layout_fill']['fill-sort-key']) });\nvar paint$4 = new Properties({\n 'fill-antialias': new DataConstantProperty(spec['paint_fill']['fill-antialias']),\n 'fill-opacity': new DataDrivenProperty(spec['paint_fill']['fill-opacity']),\n 'fill-color': new DataDrivenProperty(spec['paint_fill']['fill-color']),\n 'fill-outline-color': new DataDrivenProperty(spec['paint_fill']['fill-outline-color']),\n 'fill-translate': new DataConstantProperty(spec['paint_fill']['fill-translate']),\n 'fill-translate-anchor': new DataConstantProperty(spec['paint_fill']['fill-translate-anchor']),\n 'fill-pattern': new CrossFadedDataDrivenProperty(spec['paint_fill']['fill-pattern'])\n});\nvar properties$3 = {\n paint: paint$4,\n layout: layout$4\n};\n\nvar FillStyleLayer = function (StyleLayer) {\n function FillStyleLayer(layer) {\n StyleLayer.call(this, layer, properties$3);\n }\n if (StyleLayer)\n FillStyleLayer.__proto__ = StyleLayer;\n FillStyleLayer.prototype = Object.create(StyleLayer && StyleLayer.prototype);\n FillStyleLayer.prototype.constructor = FillStyleLayer;\n FillStyleLayer.prototype.recalculate = function recalculate(parameters, availableImages) {\n StyleLayer.prototype.recalculate.call(this, parameters, availableImages);\n var outlineColor = this.paint._values['fill-outline-color'];\n if (outlineColor.value.kind === 'constant' && outlineColor.value.value === undefined) {\n this.paint._values['fill-outline-color'] = this.paint._values['fill-color'];\n }\n };\n FillStyleLayer.prototype.createBucket = function createBucket(parameters) {\n return new FillBucket(parameters);\n };\n FillStyleLayer.prototype.queryRadius = function queryRadius() {\n return translateDistance(this.paint.get('fill-translate'));\n };\n FillStyleLayer.prototype.queryIntersectsFeature = function queryIntersectsFeature(queryGeometry, feature, featureState, geometry, zoom, transform, pixelsToTileUnits) {\n var translatedPolygon = translate(queryGeometry, this.paint.get('fill-translate'), this.paint.get('fill-translate-anchor'), transform.angle, pixelsToTileUnits);\n return polygonIntersectsMultiPolygon(translatedPolygon, geometry);\n };\n FillStyleLayer.prototype.isTileClipped = function isTileClipped() {\n return true;\n };\n return FillStyleLayer;\n}(StyleLayer);\n\nvar layout$5 = createLayout([\n {\n name: 'a_pos',\n components: 2,\n type: 'Int16'\n },\n {\n name: 'a_normal_ed',\n components: 4,\n type: 'Int16'\n }\n], 4);\nvar members$2 = layout$5.members;\n\nvar vectortilefeature = VectorTileFeature;\nfunction VectorTileFeature(pbf, end, extent, keys, values) {\n this.properties = {};\n this.extent = extent;\n this.type = 0;\n this._pbf = pbf;\n this._geometry = -1;\n this._keys = keys;\n this._values = values;\n pbf.readFields(readFeature, this, end);\n}\nfunction readFeature(tag, feature, pbf) {\n if (tag == 1) {\n feature.id = pbf.readVarint();\n } else if (tag == 2) {\n readTag(pbf, feature);\n } else if (tag == 3) {\n feature.type = pbf.readVarint();\n } else if (tag == 4) {\n feature._geometry = pbf.pos;\n }\n}\nfunction readTag(pbf, feature) {\n var end = pbf.readVarint() + pbf.pos;\n while (pbf.pos < end) {\n var key = feature._keys[pbf.readVarint()], value = feature._values[pbf.readVarint()];\n feature.properties[key] = value;\n }\n}\nVectorTileFeature.types = [\n 'Unknown',\n 'Point',\n 'LineString',\n 'Polygon'\n];\nVectorTileFeature.prototype.loadGeometry = function () {\n var pbf = this._pbf;\n pbf.pos = this._geometry;\n var end = pbf.readVarint() + pbf.pos, cmd = 1, length = 0, x = 0, y = 0, lines = [], line;\n while (pbf.pos < end) {\n if (length <= 0) {\n var cmdLen = pbf.readVarint();\n cmd = cmdLen & 7;\n length = cmdLen >> 3;\n }\n length--;\n if (cmd === 1 || cmd === 2) {\n x += pbf.readSVarint();\n y += pbf.readSVarint();\n if (cmd === 1) {\n if (line) {\n lines.push(line);\n }\n line = [];\n }\n line.push(new pointGeometry(x, y));\n } else if (cmd === 7) {\n if (line) {\n line.push(line[0].clone());\n }\n } else {\n throw new Error('unknown command ' + cmd);\n }\n }\n if (line) {\n lines.push(line);\n }\n return lines;\n};\nVectorTileFeature.prototype.bbox = function () {\n var pbf = this._pbf;\n pbf.pos = this._geometry;\n var end = pbf.readVarint() + pbf.pos, cmd = 1, length = 0, x = 0, y = 0, x1 = Infinity, x2 = -Infinity, y1 = Infinity, y2 = -Infinity;\n while (pbf.pos < end) {\n if (length <= 0) {\n var cmdLen = pbf.readVarint();\n cmd = cmdLen & 7;\n length = cmdLen >> 3;\n }\n length--;\n if (cmd === 1 || cmd === 2) {\n x += pbf.readSVarint();\n y += pbf.readSVarint();\n if (x < x1) {\n x1 = x;\n }\n if (x > x2) {\n x2 = x;\n }\n if (y < y1) {\n y1 = y;\n }\n if (y > y2) {\n y2 = y;\n }\n } else if (cmd !== 7) {\n throw new Error('unknown command ' + cmd);\n }\n }\n return [\n x1,\n y1,\n x2,\n y2\n ];\n};\nVectorTileFeature.prototype.toGeoJSON = function (x, y, z) {\n var size = this.extent * Math.pow(2, z), x0 = this.extent * x, y0 = this.extent * y, coords = this.loadGeometry(), type = VectorTileFeature.types[this.type], i, j;\n function project(line) {\n for (var j = 0; j < line.length; j++) {\n var p = line[j], y2 = 180 - (p.y + y0) * 360 / size;\n line[j] = [\n (p.x + x0) * 360 / size - 180,\n 360 / Math.PI * Math.atan(Math.exp(y2 * Math.PI / 180)) - 90\n ];\n }\n }\n switch (this.type) {\n case 1:\n var points = [];\n for (i = 0; i < coords.length; i++) {\n points[i] = coords[i][0];\n }\n coords = points;\n project(coords);\n break;\n case 2:\n for (i = 0; i < coords.length; i++) {\n project(coords[i]);\n }\n break;\n case 3:\n coords = classifyRings$1(coords);\n for (i = 0; i < coords.length; i++) {\n for (j = 0; j < coords[i].length; j++) {\n project(coords[i][j]);\n }\n }\n break;\n }\n if (coords.length === 1) {\n coords = coords[0];\n } else {\n type = 'Multi' + type;\n }\n var result = {\n type: 'Feature',\n geometry: {\n type: type,\n coordinates: coords\n },\n properties: this.properties\n };\n if ('id' in this) {\n result.id = this.id;\n }\n return result;\n};\nfunction classifyRings$1(rings) {\n var len = rings.length;\n if (len <= 1) {\n return [rings];\n }\n var polygons = [], polygon, ccw;\n for (var i = 0; i < len; i++) {\n var area = signedArea$1(rings[i]);\n if (area === 0) {\n continue;\n }\n if (ccw === undefined) {\n ccw = area < 0;\n }\n if (ccw === area < 0) {\n if (polygon) {\n polygons.push(polygon);\n }\n polygon = [rings[i]];\n } else {\n polygon.push(rings[i]);\n }\n }\n if (polygon) {\n polygons.push(polygon);\n }\n return polygons;\n}\nfunction signedArea$1(ring) {\n var sum = 0;\n for (var i = 0, len = ring.length, j = len - 1, p1, p2; i < len; j = i++) {\n p1 = ring[i];\n p2 = ring[j];\n sum += (p2.x - p1.x) * (p1.y + p2.y);\n }\n return sum;\n}\n\nvar vectortilelayer = VectorTileLayer;\nfunction VectorTileLayer(pbf, end) {\n this.version = 1;\n this.name = null;\n this.extent = 4096;\n this.length = 0;\n this._pbf = pbf;\n this._keys = [];\n this._values = [];\n this._features = [];\n pbf.readFields(readLayer, this, end);\n this.length = this._features.length;\n}\nfunction readLayer(tag, layer, pbf) {\n if (tag === 15) {\n layer.version = pbf.readVarint();\n } else if (tag === 1) {\n layer.name = pbf.readString();\n } else if (tag === 5) {\n layer.extent = pbf.readVarint();\n } else if (tag === 2) {\n layer._features.push(pbf.pos);\n } else if (tag === 3) {\n layer._keys.push(pbf.readString());\n } else if (tag === 4) {\n layer._values.push(readValueMessage(pbf));\n }\n}\nfunction readValueMessage(pbf) {\n var value = null, end = pbf.readVarint() + pbf.pos;\n while (pbf.pos < end) {\n var tag = pbf.readVarint() >> 3;\n value = tag === 1 ? pbf.readString() : tag === 2 ? pbf.readFloat() : tag === 3 ? pbf.readDouble() : tag === 4 ? pbf.readVarint64() : tag === 5 ? pbf.readVarint() : tag === 6 ? pbf.readSVarint() : tag === 7 ? pbf.readBoolean() : null;\n }\n return value;\n}\nVectorTileLayer.prototype.feature = function (i) {\n if (i < 0 || i >= this._features.length) {\n throw new Error('feature index out of bounds');\n }\n this._pbf.pos = this._features[i];\n var end = this._pbf.readVarint() + this._pbf.pos;\n return new vectortilefeature(this._pbf, end, this.extent, this._keys, this._values);\n};\n\nvar vectortile = VectorTile;\nfunction VectorTile(pbf, end) {\n this.layers = pbf.readFields(readTile, {}, end);\n}\nfunction readTile(tag, layers, pbf) {\n if (tag === 3) {\n var layer = new vectortilelayer(pbf, pbf.readVarint() + pbf.pos);\n if (layer.length) {\n layers[layer.name] = layer;\n }\n }\n}\n\nvar VectorTile$1 = vectortile;\nvar VectorTileFeature$1 = vectortilefeature;\nvar VectorTileLayer$1 = vectortilelayer;\n\nvar vectorTile = {\n\tVectorTile: VectorTile$1,\n\tVectorTileFeature: VectorTileFeature$1,\n\tVectorTileLayer: VectorTileLayer$1\n};\n\nvar vectorTileFeatureTypes = vectorTile.VectorTileFeature.types;\nvar EARCUT_MAX_RINGS$1 = 500;\nvar FACTOR = Math.pow(2, 13);\nfunction addVertex(vertexArray, x, y, nx, ny, nz, t, e) {\n vertexArray.emplaceBack(x, y, Math.floor(nx * FACTOR) * 2 + t, ny * FACTOR * 2, nz * FACTOR * 2, Math.round(e));\n}\nvar FillExtrusionBucket = function FillExtrusionBucket(options) {\n this.zoom = options.zoom;\n this.overscaling = options.overscaling;\n this.layers = options.layers;\n this.layerIds = this.layers.map(function (layer) {\n return layer.id;\n });\n this.index = options.index;\n this.hasPattern = false;\n this.layoutVertexArray = new StructArrayLayout2i4i12();\n this.indexArray = new StructArrayLayout3ui6();\n this.programConfigurations = new ProgramConfigurationSet(options.layers, options.zoom);\n this.segments = new SegmentVector();\n this.stateDependentLayerIds = this.layers.filter(function (l) {\n return l.isStateDependent();\n }).map(function (l) {\n return l.id;\n });\n};\nFillExtrusionBucket.prototype.populate = function populate(features, options, canonical) {\n this.features = [];\n this.hasPattern = hasPattern('fill-extrusion', this.layers, options);\n for (var i = 0, list = features; i < list.length; i += 1) {\n var ref = list[i];\n var feature = ref.feature;\n var id = ref.id;\n var index = ref.index;\n var sourceLayerIndex = ref.sourceLayerIndex;\n var needGeometry = this.layers[0]._featureFilter.needGeometry;\n var evaluationFeature = toEvaluationFeature(feature, needGeometry);\n if (!this.layers[0]._featureFilter.filter(new EvaluationParameters(this.zoom), evaluationFeature, canonical)) {\n continue;\n }\n var bucketFeature = {\n id: id,\n sourceLayerIndex: sourceLayerIndex,\n index: index,\n geometry: needGeometry ? evaluationFeature.geometry : loadGeometry(feature),\n properties: feature.properties,\n type: feature.type,\n patterns: {}\n };\n if (this.hasPattern) {\n this.features.push(addPatternDependencies('fill-extrusion', this.layers, bucketFeature, this.zoom, options));\n } else {\n this.addFeature(bucketFeature, bucketFeature.geometry, index, canonical, {});\n }\n options.featureIndex.insert(feature, bucketFeature.geometry, index, sourceLayerIndex, this.index, true);\n }\n};\nFillExtrusionBucket.prototype.addFeatures = function addFeatures(options, canonical, imagePositions) {\n for (var i = 0, list = this.features; i < list.length; i += 1) {\n var feature = list[i];\n var geometry = feature.geometry;\n this.addFeature(feature, geometry, feature.index, canonical, imagePositions);\n }\n};\nFillExtrusionBucket.prototype.update = function update(states, vtLayer, imagePositions) {\n if (!this.stateDependentLayers.length) {\n return;\n }\n this.programConfigurations.updatePaintArrays(states, vtLayer, this.stateDependentLayers, imagePositions);\n};\nFillExtrusionBucket.prototype.isEmpty = function isEmpty() {\n return this.layoutVertexArray.length === 0;\n};\nFillExtrusionBucket.prototype.uploadPending = function uploadPending() {\n return !this.uploaded || this.programConfigurations.needsUpload;\n};\nFillExtrusionBucket.prototype.upload = function upload(context) {\n if (!this.uploaded) {\n this.layoutVertexBuffer = context.createVertexBuffer(this.layoutVertexArray, members$2);\n this.indexBuffer = context.createIndexBuffer(this.indexArray);\n }\n this.programConfigurations.upload(context);\n this.uploaded = true;\n};\nFillExtrusionBucket.prototype.destroy = function destroy() {\n if (!this.layoutVertexBuffer) {\n return;\n }\n this.layoutVertexBuffer.destroy();\n this.indexBuffer.destroy();\n this.programConfigurations.destroy();\n this.segments.destroy();\n};\nFillExtrusionBucket.prototype.addFeature = function addFeature(feature, geometry, index, canonical, imagePositions) {\n for (var i$4 = 0, list$3 = classifyRings(geometry, EARCUT_MAX_RINGS$1); i$4 < list$3.length; i$4 += 1) {\n var polygon = list$3[i$4];\n var numVertices = 0;\n for (var i$1 = 0, list = polygon; i$1 < list.length; i$1 += 1) {\n var ring = list[i$1];\n numVertices += ring.length;\n }\n var segment = this.segments.prepareSegment(4, this.layoutVertexArray, this.indexArray);\n for (var i$2 = 0, list$1 = polygon; i$2 < list$1.length; i$2 += 1) {\n var ring$1 = list$1[i$2];\n if (ring$1.length === 0) {\n continue;\n }\n if (isEntirelyOutside(ring$1)) {\n continue;\n }\n var edgeDistance = 0;\n for (var p = 0; p < ring$1.length; p++) {\n var p1 = ring$1[p];\n if (p >= 1) {\n var p2 = ring$1[p - 1];\n if (!isBoundaryEdge(p1, p2)) {\n if (segment.vertexLength + 4 > SegmentVector.MAX_VERTEX_ARRAY_LENGTH) {\n segment = this.segments.prepareSegment(4, this.layoutVertexArray, this.indexArray);\n }\n var perp = p1.sub(p2)._perp()._unit();\n var dist = p2.dist(p1);\n if (edgeDistance + dist > 32768) {\n edgeDistance = 0;\n }\n addVertex(this.layoutVertexArray, p1.x, p1.y, perp.x, perp.y, 0, 0, edgeDistance);\n addVertex(this.layoutVertexArray, p1.x, p1.y, perp.x, perp.y, 0, 1, edgeDistance);\n edgeDistance += dist;\n addVertex(this.layoutVertexArray, p2.x, p2.y, perp.x, perp.y, 0, 0, edgeDistance);\n addVertex(this.layoutVertexArray, p2.x, p2.y, perp.x, perp.y, 0, 1, edgeDistance);\n var bottomRight = segment.vertexLength;\n this.indexArray.emplaceBack(bottomRight, bottomRight + 2, bottomRight + 1);\n this.indexArray.emplaceBack(bottomRight + 1, bottomRight + 2, bottomRight + 3);\n segment.vertexLength += 4;\n segment.primitiveLength += 2;\n }\n }\n }\n }\n if (segment.vertexLength + numVertices > SegmentVector.MAX_VERTEX_ARRAY_LENGTH) {\n segment = this.segments.prepareSegment(numVertices, this.layoutVertexArray, this.indexArray);\n }\n if (vectorTileFeatureTypes[feature.type] !== 'Polygon') {\n continue;\n }\n var flattened = [];\n var holeIndices = [];\n var triangleIndex = segment.vertexLength;\n for (var i$3 = 0, list$2 = polygon; i$3 < list$2.length; i$3 += 1) {\n var ring$2 = list$2[i$3];\n if (ring$2.length === 0) {\n continue;\n }\n if (ring$2 !== polygon[0]) {\n holeIndices.push(flattened.length / 2);\n }\n for (var i = 0; i < ring$2.length; i++) {\n var p$1 = ring$2[i];\n addVertex(this.layoutVertexArray, p$1.x, p$1.y, 0, 0, 1, 1, 0);\n flattened.push(p$1.x);\n flattened.push(p$1.y);\n }\n }\n var indices = earcut_1(flattened, holeIndices);\n for (var j = 0; j < indices.length; j += 3) {\n this.indexArray.emplaceBack(triangleIndex + indices[j], triangleIndex + indices[j + 2], triangleIndex + indices[j + 1]);\n }\n segment.primitiveLength += indices.length / 3;\n segment.vertexLength += numVertices;\n }\n this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, feature, index, imagePositions, canonical);\n};\nregister('FillExtrusionBucket', FillExtrusionBucket, {\n omit: [\n 'layers',\n 'features'\n ]\n});\nfunction isBoundaryEdge(p1, p2) {\n return p1.x === p2.x && (p1.x < 0 || p1.x > EXTENT$1) || p1.y === p2.y && (p1.y < 0 || p1.y > EXTENT$1);\n}\nfunction isEntirelyOutside(ring) {\n return ring.every(function (p) {\n return p.x < 0;\n }) || ring.every(function (p) {\n return p.x > EXTENT$1;\n }) || ring.every(function (p) {\n return p.y < 0;\n }) || ring.every(function (p) {\n return p.y > EXTENT$1;\n });\n}\n\nvar paint$5 = new Properties({\n 'fill-extrusion-opacity': new DataConstantProperty(spec['paint_fill-extrusion']['fill-extrusion-opacity']),\n 'fill-extrusion-color': new DataDrivenProperty(spec['paint_fill-extrusion']['fill-extrusion-color']),\n 'fill-extrusion-translate': new DataConstantProperty(spec['paint_fill-extrusion']['fill-extrusion-translate']),\n 'fill-extrusion-translate-anchor': new DataConstantProperty(spec['paint_fill-extrusion']['fill-extrusion-translate-anchor']),\n 'fill-extrusion-pattern': new CrossFadedDataDrivenProperty(spec['paint_fill-extrusion']['fill-extrusion-pattern']),\n 'fill-extrusion-height': new DataDrivenProperty(spec['paint_fill-extrusion']['fill-extrusion-height']),\n 'fill-extrusion-base': new DataDrivenProperty(spec['paint_fill-extrusion']['fill-extrusion-base']),\n 'fill-extrusion-vertical-gradient': new DataConstantProperty(spec['paint_fill-extrusion']['fill-extrusion-vertical-gradient'])\n});\nvar properties$4 = { paint: paint$5 };\n\nvar FillExtrusionStyleLayer = function (StyleLayer) {\n function FillExtrusionStyleLayer(layer) {\n StyleLayer.call(this, layer, properties$4);\n }\n if (StyleLayer)\n FillExtrusionStyleLayer.__proto__ = StyleLayer;\n FillExtrusionStyleLayer.prototype = Object.create(StyleLayer && StyleLayer.prototype);\n FillExtrusionStyleLayer.prototype.constructor = FillExtrusionStyleLayer;\n FillExtrusionStyleLayer.prototype.createBucket = function createBucket(parameters) {\n return new FillExtrusionBucket(parameters);\n };\n FillExtrusionStyleLayer.prototype.queryRadius = function queryRadius() {\n return translateDistance(this.paint.get('fill-extrusion-translate'));\n };\n FillExtrusionStyleLayer.prototype.is3D = function is3D() {\n return true;\n };\n FillExtrusionStyleLayer.prototype.queryIntersectsFeature = function queryIntersectsFeature(queryGeometry, feature, featureState, geometry, zoom, transform, pixelsToTileUnits, pixelPosMatrix) {\n var translatedPolygon = translate(queryGeometry, this.paint.get('fill-extrusion-translate'), this.paint.get('fill-extrusion-translate-anchor'), transform.angle, pixelsToTileUnits);\n var height = this.paint.get('fill-extrusion-height').evaluate(feature, featureState);\n var base = this.paint.get('fill-extrusion-base').evaluate(feature, featureState);\n var projectedQueryGeometry = projectQueryGeometry$1(translatedPolygon, pixelPosMatrix, transform, 0);\n var projected = projectExtrusion(geometry, base, height, pixelPosMatrix);\n var projectedBase = projected[0];\n var projectedTop = projected[1];\n return checkIntersection(projectedBase, projectedTop, projectedQueryGeometry);\n };\n return FillExtrusionStyleLayer;\n}(StyleLayer);\nfunction dot$2(a, b) {\n return a.x * b.x + a.y * b.y;\n}\nfunction getIntersectionDistance(projectedQueryGeometry, projectedFace) {\n if (projectedQueryGeometry.length === 1) {\n var i = 0;\n var a = projectedFace[i++];\n var b;\n while (!b || a.equals(b)) {\n b = projectedFace[i++];\n if (!b) {\n return Infinity;\n }\n }\n for (; i < projectedFace.length; i++) {\n var c = projectedFace[i];\n var p = projectedQueryGeometry[0];\n var ab = b.sub(a);\n var ac = c.sub(a);\n var ap = p.sub(a);\n var dotABAB = dot$2(ab, ab);\n var dotABAC = dot$2(ab, ac);\n var dotACAC = dot$2(ac, ac);\n var dotAPAB = dot$2(ap, ab);\n var dotAPAC = dot$2(ap, ac);\n var denom = dotABAB * dotACAC - dotABAC * dotABAC;\n var v = (dotACAC * dotAPAB - dotABAC * dotAPAC) / denom;\n var w = (dotABAB * dotAPAC - dotABAC * dotAPAB) / denom;\n var u = 1 - v - w;\n var distance = a.z * u + b.z * v + c.z * w;\n if (isFinite(distance)) {\n return distance;\n }\n }\n return Infinity;\n } else {\n var closestDistance = Infinity;\n for (var i$1 = 0, list = projectedFace; i$1 < list.length; i$1 += 1) {\n var p$1 = list[i$1];\n closestDistance = Math.min(closestDistance, p$1.z);\n }\n return closestDistance;\n }\n}\nfunction checkIntersection(projectedBase, projectedTop, projectedQueryGeometry) {\n var closestDistance = Infinity;\n if (polygonIntersectsMultiPolygon(projectedQueryGeometry, projectedTop)) {\n closestDistance = getIntersectionDistance(projectedQueryGeometry, projectedTop[0]);\n }\n for (var r = 0; r < projectedTop.length; r++) {\n var ringTop = projectedTop[r];\n var ringBase = projectedBase[r];\n for (var p = 0; p < ringTop.length - 1; p++) {\n var topA = ringTop[p];\n var topB = ringTop[p + 1];\n var baseA = ringBase[p];\n var baseB = ringBase[p + 1];\n var face = [\n topA,\n topB,\n baseB,\n baseA,\n topA\n ];\n if (polygonIntersectsPolygon(projectedQueryGeometry, face)) {\n closestDistance = Math.min(closestDistance, getIntersectionDistance(projectedQueryGeometry, face));\n }\n }\n }\n return closestDistance === Infinity ? false : closestDistance;\n}\nfunction projectExtrusion(geometry, zBase, zTop, m) {\n var projectedBase = [];\n var projectedTop = [];\n var baseXZ = m[8] * zBase;\n var baseYZ = m[9] * zBase;\n var baseZZ = m[10] * zBase;\n var baseWZ = m[11] * zBase;\n var topXZ = m[8] * zTop;\n var topYZ = m[9] * zTop;\n var topZZ = m[10] * zTop;\n var topWZ = m[11] * zTop;\n for (var i$1 = 0, list$1 = geometry; i$1 < list$1.length; i$1 += 1) {\n var r = list$1[i$1];\n var ringBase = [];\n var ringTop = [];\n for (var i = 0, list = r; i < list.length; i += 1) {\n var p = list[i];\n var x = p.x;\n var y = p.y;\n var sX = m[0] * x + m[4] * y + m[12];\n var sY = m[1] * x + m[5] * y + m[13];\n var sZ = m[2] * x + m[6] * y + m[14];\n var sW = m[3] * x + m[7] * y + m[15];\n var baseX = sX + baseXZ;\n var baseY = sY + baseYZ;\n var baseZ = sZ + baseZZ;\n var baseW = sW + baseWZ;\n var topX = sX + topXZ;\n var topY = sY + topYZ;\n var topZ = sZ + topZZ;\n var topW = sW + topWZ;\n var b = new pointGeometry(baseX / baseW, baseY / baseW);\n b.z = baseZ / baseW;\n ringBase.push(b);\n var t = new pointGeometry(topX / topW, topY / topW);\n t.z = topZ / topW;\n ringTop.push(t);\n }\n projectedBase.push(ringBase);\n projectedTop.push(ringTop);\n }\n return [\n projectedBase,\n projectedTop\n ];\n}\nfunction projectQueryGeometry$1(queryGeometry, pixelPosMatrix, transform, z) {\n var projectedQueryGeometry = [];\n for (var i = 0, list = queryGeometry; i < list.length; i += 1) {\n var p = list[i];\n var v = [\n p.x,\n p.y,\n z,\n 1\n ];\n transformMat4(v, v, pixelPosMatrix);\n projectedQueryGeometry.push(new pointGeometry(v[0] / v[3], v[1] / v[3]));\n }\n return projectedQueryGeometry;\n}\n\nvar lineLayoutAttributes = createLayout([\n {\n name: 'a_pos_normal',\n components: 2,\n type: 'Int16'\n },\n {\n name: 'a_data',\n components: 4,\n type: 'Uint8'\n }\n], 4);\nvar members$3 = lineLayoutAttributes.members;\n\nvar lineLayoutAttributesExt = createLayout([\n {\n name: 'a_uv_x',\n components: 1,\n type: 'Float32'\n },\n {\n name: 'a_split_index',\n components: 1,\n type: 'Float32'\n }\n]);\nvar members$4 = lineLayoutAttributesExt.members;\n\nvar vectorTileFeatureTypes$1 = vectorTile.VectorTileFeature.types;\nvar EXTRUDE_SCALE = 63;\nvar COS_HALF_SHARP_CORNER = Math.cos(75 / 2 * (Math.PI / 180));\nvar SHARP_CORNER_OFFSET = 15;\nvar DEG_PER_TRIANGLE = 20;\nvar LINE_DISTANCE_BUFFER_BITS = 15;\nvar LINE_DISTANCE_SCALE = 1 / 2;\nvar MAX_LINE_DISTANCE = Math.pow(2, LINE_DISTANCE_BUFFER_BITS - 1) / LINE_DISTANCE_SCALE;\nvar LineBucket = function LineBucket(options) {\n var this$1 = this;\n this.zoom = options.zoom;\n this.overscaling = options.overscaling;\n this.layers = options.layers;\n this.layerIds = this.layers.map(function (layer) {\n return layer.id;\n });\n this.index = options.index;\n this.hasPattern = false;\n this.patternFeatures = [];\n this.lineClipsArray = [];\n this.gradients = {};\n this.layers.forEach(function (layer) {\n this$1.gradients[layer.id] = {};\n });\n this.layoutVertexArray = new StructArrayLayout2i4ub8();\n this.layoutVertexArray2 = new StructArrayLayout2f8();\n this.indexArray = new StructArrayLayout3ui6();\n this.programConfigurations = new ProgramConfigurationSet(options.layers, options.zoom);\n this.segments = new SegmentVector();\n this.maxLineLength = 0;\n this.stateDependentLayerIds = this.layers.filter(function (l) {\n return l.isStateDependent();\n }).map(function (l) {\n return l.id;\n });\n};\nLineBucket.prototype.populate = function populate(features, options, canonical) {\n this.hasPattern = hasPattern('line', this.layers, options);\n var lineSortKey = this.layers[0].layout.get('line-sort-key');\n var bucketFeatures = [];\n for (var i = 0, list = features; i < list.length; i += 1) {\n var ref = list[i];\n var feature = ref.feature;\n var id = ref.id;\n var index = ref.index;\n var sourceLayerIndex = ref.sourceLayerIndex;\n var needGeometry = this.layers[0]._featureFilter.needGeometry;\n var evaluationFeature = toEvaluationFeature(feature, needGeometry);\n if (!this.layers[0]._featureFilter.filter(new EvaluationParameters(this.zoom), evaluationFeature, canonical)) {\n continue;\n }\n var sortKey = lineSortKey ? lineSortKey.evaluate(evaluationFeature, {}, canonical) : undefined;\n var bucketFeature = {\n id: id,\n properties: feature.properties,\n type: feature.type,\n sourceLayerIndex: sourceLayerIndex,\n index: index,\n geometry: needGeometry ? evaluationFeature.geometry : loadGeometry(feature),\n patterns: {},\n sortKey: sortKey\n };\n bucketFeatures.push(bucketFeature);\n }\n if (lineSortKey) {\n bucketFeatures.sort(function (a, b) {\n return a.sortKey - b.sortKey;\n });\n }\n for (var i$1 = 0, list$1 = bucketFeatures; i$1 < list$1.length; i$1 += 1) {\n var bucketFeature$1 = list$1[i$1];\n var ref$1 = bucketFeature$1;\n var geometry = ref$1.geometry;\n var index$1 = ref$1.index;\n var sourceLayerIndex$1 = ref$1.sourceLayerIndex;\n if (this.hasPattern) {\n var patternBucketFeature = addPatternDependencies('line', this.layers, bucketFeature$1, this.zoom, options);\n this.patternFeatures.push(patternBucketFeature);\n } else {\n this.addFeature(bucketFeature$1, geometry, index$1, canonical, {});\n }\n var feature$1 = features[index$1].feature;\n options.featureIndex.insert(feature$1, geometry, index$1, sourceLayerIndex$1, this.index);\n }\n};\nLineBucket.prototype.update = function update(states, vtLayer, imagePositions) {\n if (!this.stateDependentLayers.length) {\n return;\n }\n this.programConfigurations.updatePaintArrays(states, vtLayer, this.stateDependentLayers, imagePositions);\n};\nLineBucket.prototype.addFeatures = function addFeatures(options, canonical, imagePositions) {\n for (var i = 0, list = this.patternFeatures; i < list.length; i += 1) {\n var feature = list[i];\n this.addFeature(feature, feature.geometry, feature.index, canonical, imagePositions);\n }\n};\nLineBucket.prototype.isEmpty = function isEmpty() {\n return this.layoutVertexArray.length === 0;\n};\nLineBucket.prototype.uploadPending = function uploadPending() {\n return !this.uploaded || this.programConfigurations.needsUpload;\n};\nLineBucket.prototype.upload = function upload(context) {\n if (!this.uploaded) {\n if (this.layoutVertexArray2.length !== 0) {\n this.layoutVertexBuffer2 = context.createVertexBuffer(this.layoutVertexArray2, members$4);\n }\n this.layoutVertexBuffer = context.createVertexBuffer(this.layoutVertexArray, members$3);\n this.indexBuffer = context.createIndexBuffer(this.indexArray);\n }\n this.programConfigurations.upload(context);\n this.uploaded = true;\n};\nLineBucket.prototype.destroy = function destroy() {\n if (!this.layoutVertexBuffer) {\n return;\n }\n this.layoutVertexBuffer.destroy();\n this.indexBuffer.destroy();\n this.programConfigurations.destroy();\n this.segments.destroy();\n};\nLineBucket.prototype.lineFeatureClips = function lineFeatureClips(feature) {\n if (!!feature.properties && feature.properties.hasOwnProperty('mapbox_clip_start') && feature.properties.hasOwnProperty('mapbox_clip_end')) {\n var start = +feature.properties['mapbox_clip_start'];\n var end = +feature.properties['mapbox_clip_end'];\n return {\n start: start,\n end: end\n };\n }\n};\nLineBucket.prototype.addFeature = function addFeature(feature, geometry, index, canonical, imagePositions) {\n var layout = this.layers[0].layout;\n var join = layout.get('line-join').evaluate(feature, {});\n var cap = layout.get('line-cap');\n var miterLimit = layout.get('line-miter-limit');\n var roundLimit = layout.get('line-round-limit');\n this.lineClips = this.lineFeatureClips(feature);\n for (var i = 0, list = geometry; i < list.length; i += 1) {\n var line = list[i];\n this.addLine(line, feature, join, cap, miterLimit, roundLimit);\n }\n this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, feature, index, imagePositions, canonical);\n};\nLineBucket.prototype.addLine = function addLine(vertices, feature, join, cap, miterLimit, roundLimit) {\n this.distance = 0;\n this.scaledDistance = 0;\n this.totalDistance = 0;\n if (this.lineClips) {\n this.lineClipsArray.push(this.lineClips);\n for (var i = 0; i < vertices.length - 1; i++) {\n this.totalDistance += vertices[i].dist(vertices[i + 1]);\n }\n this.updateScaledDistance();\n this.maxLineLength = Math.max(this.maxLineLength, this.totalDistance);\n }\n var isPolygon = vectorTileFeatureTypes$1[feature.type] === 'Polygon';\n var len = vertices.length;\n while (len >= 2 && vertices[len - 1].equals(vertices[len - 2])) {\n len--;\n }\n var first = 0;\n while (first < len - 1 && vertices[first].equals(vertices[first + 1])) {\n first++;\n }\n if (len < (isPolygon ? 3 : 2)) {\n return;\n }\n if (join === 'bevel') {\n miterLimit = 1.05;\n }\n var sharpCornerOffset = this.overscaling <= 16 ? SHARP_CORNER_OFFSET * EXTENT$1 / (512 * this.overscaling) : 0;\n var segment = this.segments.prepareSegment(len * 10, this.layoutVertexArray, this.indexArray);\n var currentVertex;\n var prevVertex = undefined;\n var nextVertex = undefined;\n var prevNormal = undefined;\n var nextNormal = undefined;\n this.e1 = this.e2 = -1;\n if (isPolygon) {\n currentVertex = vertices[len - 2];\n nextNormal = vertices[first].sub(currentVertex)._unit()._perp();\n }\n for (var i$1 = first; i$1 < len; i$1++) {\n nextVertex = i$1 === len - 1 ? isPolygon ? vertices[first + 1] : undefined : vertices[i$1 + 1];\n if (nextVertex && vertices[i$1].equals(nextVertex)) {\n continue;\n }\n if (nextNormal) {\n prevNormal = nextNormal;\n }\n if (currentVertex) {\n prevVertex = currentVertex;\n }\n currentVertex = vertices[i$1];\n nextNormal = nextVertex ? nextVertex.sub(currentVertex)._unit()._perp() : prevNormal;\n prevNormal = prevNormal || nextNormal;\n var joinNormal = prevNormal.add(nextNormal);\n if (joinNormal.x !== 0 || joinNormal.y !== 0) {\n joinNormal._unit();\n }\n var cosAngle = prevNormal.x * nextNormal.x + prevNormal.y * nextNormal.y;\n var cosHalfAngle = joinNormal.x * nextNormal.x + joinNormal.y * nextNormal.y;\n var miterLength = cosHalfAngle !== 0 ? 1 / cosHalfAngle : Infinity;\n var approxAngle = 2 * Math.sqrt(2 - 2 * cosHalfAngle);\n var isSharpCorner = cosHalfAngle < COS_HALF_SHARP_CORNER && prevVertex && nextVertex;\n var lineTurnsLeft = prevNormal.x * nextNormal.y - prevNormal.y * nextNormal.x > 0;\n if (isSharpCorner && i$1 > first) {\n var prevSegmentLength = currentVertex.dist(prevVertex);\n if (prevSegmentLength > 2 * sharpCornerOffset) {\n var newPrevVertex = currentVertex.sub(currentVertex.sub(prevVertex)._mult(sharpCornerOffset / prevSegmentLength)._round());\n this.updateDistance(prevVertex, newPrevVertex);\n this.addCurrentVertex(newPrevVertex, prevNormal, 0, 0, segment);\n prevVertex = newPrevVertex;\n }\n }\n var middleVertex = prevVertex && nextVertex;\n var currentJoin = middleVertex ? join : isPolygon ? 'butt' : cap;\n if (middleVertex && currentJoin === 'round') {\n if (miterLength < roundLimit) {\n currentJoin = 'miter';\n } else if (miterLength <= 2) {\n currentJoin = 'fakeround';\n }\n }\n if (currentJoin === 'miter' && miterLength > miterLimit) {\n currentJoin = 'bevel';\n }\n if (currentJoin === 'bevel') {\n if (miterLength > 2) {\n currentJoin = 'flipbevel';\n }\n if (miterLength < miterLimit) {\n currentJoin = 'miter';\n }\n }\n if (prevVertex) {\n this.updateDistance(prevVertex, currentVertex);\n }\n if (currentJoin === 'miter') {\n joinNormal._mult(miterLength);\n this.addCurrentVertex(currentVertex, joinNormal, 0, 0, segment);\n } else if (currentJoin === 'flipbevel') {\n if (miterLength > 100) {\n joinNormal = nextNormal.mult(-1);\n } else {\n var bevelLength = miterLength * prevNormal.add(nextNormal).mag() / prevNormal.sub(nextNormal).mag();\n joinNormal._perp()._mult(bevelLength * (lineTurnsLeft ? -1 : 1));\n }\n this.addCurrentVertex(currentVertex, joinNormal, 0, 0, segment);\n this.addCurrentVertex(currentVertex, joinNormal.mult(-1), 0, 0, segment);\n } else if (currentJoin === 'bevel' || currentJoin === 'fakeround') {\n var offset = -Math.sqrt(miterLength * miterLength - 1);\n var offsetA = lineTurnsLeft ? offset : 0;\n var offsetB = lineTurnsLeft ? 0 : offset;\n if (prevVertex) {\n this.addCurrentVertex(currentVertex, prevNormal, offsetA, offsetB, segment);\n }\n if (currentJoin === 'fakeround') {\n var n = Math.round(approxAngle * 180 / Math.PI / DEG_PER_TRIANGLE);\n for (var m = 1; m < n; m++) {\n var t = m / n;\n if (t !== 0.5) {\n var t2 = t - 0.5;\n var A = 1.0904 + cosAngle * (-3.2452 + cosAngle * (3.55645 - cosAngle * 1.43519));\n var B = 0.848013 + cosAngle * (-1.06021 + cosAngle * 0.215638);\n t = t + t * t2 * (t - 1) * (A * t2 * t2 + B);\n }\n var extrude = nextNormal.sub(prevNormal)._mult(t)._add(prevNormal)._unit()._mult(lineTurnsLeft ? -1 : 1);\n this.addHalfVertex(currentVertex, extrude.x, extrude.y, false, lineTurnsLeft, 0, segment);\n }\n }\n if (nextVertex) {\n this.addCurrentVertex(currentVertex, nextNormal, -offsetA, -offsetB, segment);\n }\n } else if (currentJoin === 'butt') {\n this.addCurrentVertex(currentVertex, joinNormal, 0, 0, segment);\n } else if (currentJoin === 'square') {\n var offset$1 = prevVertex ? 1 : -1;\n this.addCurrentVertex(currentVertex, joinNormal, offset$1, offset$1, segment);\n } else if (currentJoin === 'round') {\n if (prevVertex) {\n this.addCurrentVertex(currentVertex, prevNormal, 0, 0, segment);\n this.addCurrentVertex(currentVertex, prevNormal, 1, 1, segment, true);\n }\n if (nextVertex) {\n this.addCurrentVertex(currentVertex, nextNormal, -1, -1, segment, true);\n this.addCurrentVertex(currentVertex, nextNormal, 0, 0, segment);\n }\n }\n if (isSharpCorner && i$1 < len - 1) {\n var nextSegmentLength = currentVertex.dist(nextVertex);\n if (nextSegmentLength > 2 * sharpCornerOffset) {\n var newCurrentVertex = currentVertex.add(nextVertex.sub(currentVertex)._mult(sharpCornerOffset / nextSegmentLength)._round());\n this.updateDistance(currentVertex, newCurrentVertex);\n this.addCurrentVertex(newCurrentVertex, nextNormal, 0, 0, segment);\n currentVertex = newCurrentVertex;\n }\n }\n }\n};\nLineBucket.prototype.addCurrentVertex = function addCurrentVertex(p, normal, endLeft, endRight, segment, round) {\n if (round === void 0)\n round = false;\n var leftX = normal.x + normal.y * endLeft;\n var leftY = normal.y - normal.x * endLeft;\n var rightX = -normal.x + normal.y * endRight;\n var rightY = -normal.y - normal.x * endRight;\n this.addHalfVertex(p, leftX, leftY, round, false, endLeft, segment);\n this.addHalfVertex(p, rightX, rightY, round, true, -endRight, segment);\n if (this.distance > MAX_LINE_DISTANCE / 2 && this.totalDistance === 0) {\n this.distance = 0;\n this.addCurrentVertex(p, normal, endLeft, endRight, segment, round);\n }\n};\nLineBucket.prototype.addHalfVertex = function addHalfVertex(ref, extrudeX, extrudeY, round, up, dir, segment) {\n var x = ref.x;\n var y = ref.y;\n var totalDistance = this.lineClips ? this.scaledDistance * (MAX_LINE_DISTANCE - 1) : this.scaledDistance;\n var linesofarScaled = totalDistance * LINE_DISTANCE_SCALE;\n this.layoutVertexArray.emplaceBack((x << 1) + (round ? 1 : 0), (y << 1) + (up ? 1 : 0), Math.round(EXTRUDE_SCALE * extrudeX) + 128, Math.round(EXTRUDE_SCALE * extrudeY) + 128, (dir === 0 ? 0 : dir < 0 ? -1 : 1) + 1 | (linesofarScaled & 63) << 2, linesofarScaled >> 6);\n if (this.lineClips) {\n var progressRealigned = this.scaledDistance - this.lineClips.start;\n var endClipRealigned = this.lineClips.end - this.lineClips.start;\n var uvX = progressRealigned / endClipRealigned;\n this.layoutVertexArray2.emplaceBack(uvX, this.lineClipsArray.length);\n }\n var e = segment.vertexLength++;\n if (this.e1 >= 0 && this.e2 >= 0) {\n this.indexArray.emplaceBack(this.e1, this.e2, e);\n segment.primitiveLength++;\n }\n if (up) {\n this.e2 = e;\n } else {\n this.e1 = e;\n }\n};\nLineBucket.prototype.updateScaledDistance = function updateScaledDistance() {\n this.scaledDistance = this.lineClips ? this.lineClips.start + (this.lineClips.end - this.lineClips.start) * this.distance / this.totalDistance : this.distance;\n};\nLineBucket.prototype.updateDistance = function updateDistance(prev, next) {\n this.distance += prev.dist(next);\n this.updateScaledDistance();\n};\nregister('LineBucket', LineBucket, {\n omit: [\n 'layers',\n 'patternFeatures'\n ]\n});\n\nvar layout$6 = new Properties({\n 'line-cap': new DataConstantProperty(spec['layout_line']['line-cap']),\n 'line-join': new DataDrivenProperty(spec['layout_line']['line-join']),\n 'line-miter-limit': new DataConstantProperty(spec['layout_line']['line-miter-limit']),\n 'line-round-limit': new DataConstantProperty(spec['layout_line']['line-round-limit']),\n 'line-sort-key': new DataDrivenProperty(spec['layout_line']['line-sort-key'])\n});\nvar paint$6 = new Properties({\n 'line-opacity': new DataDrivenProperty(spec['paint_line']['line-opacity']),\n 'line-color': new DataDrivenProperty(spec['paint_line']['line-color']),\n 'line-translate': new DataConstantProperty(spec['paint_line']['line-translate']),\n 'line-translate-anchor': new DataConstantProperty(spec['paint_line']['line-translate-anchor']),\n 'line-width': new DataDrivenProperty(spec['paint_line']['line-width']),\n 'line-gap-width': new DataDrivenProperty(spec['paint_line']['line-gap-width']),\n 'line-offset': new DataDrivenProperty(spec['paint_line']['line-offset']),\n 'line-blur': new DataDrivenProperty(spec['paint_line']['line-blur']),\n 'line-dasharray': new CrossFadedProperty(spec['paint_line']['line-dasharray']),\n 'line-pattern': new CrossFadedDataDrivenProperty(spec['paint_line']['line-pattern']),\n 'line-gradient': new ColorRampProperty(spec['paint_line']['line-gradient'])\n});\nvar properties$5 = {\n paint: paint$6,\n layout: layout$6\n};\n\nvar LineFloorwidthProperty = function (DataDrivenProperty) {\n function LineFloorwidthProperty() {\n DataDrivenProperty.apply(this, arguments);\n }\n if (DataDrivenProperty)\n LineFloorwidthProperty.__proto__ = DataDrivenProperty;\n LineFloorwidthProperty.prototype = Object.create(DataDrivenProperty && DataDrivenProperty.prototype);\n LineFloorwidthProperty.prototype.constructor = LineFloorwidthProperty;\n LineFloorwidthProperty.prototype.possiblyEvaluate = function possiblyEvaluate(value, parameters) {\n parameters = new EvaluationParameters(Math.floor(parameters.zoom), {\n now: parameters.now,\n fadeDuration: parameters.fadeDuration,\n zoomHistory: parameters.zoomHistory,\n transition: parameters.transition\n });\n return DataDrivenProperty.prototype.possiblyEvaluate.call(this, value, parameters);\n };\n LineFloorwidthProperty.prototype.evaluate = function evaluate(value, globals, feature, featureState) {\n globals = extend({}, globals, { zoom: Math.floor(globals.zoom) });\n return DataDrivenProperty.prototype.evaluate.call(this, value, globals, feature, featureState);\n };\n return LineFloorwidthProperty;\n}(DataDrivenProperty);\nvar lineFloorwidthProperty = new LineFloorwidthProperty(properties$5.paint.properties['line-width'].specification);\nlineFloorwidthProperty.useIntegerZoom = true;\nvar LineStyleLayer = function (StyleLayer) {\n function LineStyleLayer(layer) {\n StyleLayer.call(this, layer, properties$5);\n this.gradientVersion = 0;\n }\n if (StyleLayer)\n LineStyleLayer.__proto__ = StyleLayer;\n LineStyleLayer.prototype = Object.create(StyleLayer && StyleLayer.prototype);\n LineStyleLayer.prototype.constructor = LineStyleLayer;\n LineStyleLayer.prototype._handleSpecialPaintPropertyUpdate = function _handleSpecialPaintPropertyUpdate(name) {\n if (name === 'line-gradient') {\n var expression = this._transitionablePaint._values['line-gradient'].value.expression;\n this.stepInterpolant = expression._styleExpression.expression instanceof Step;\n this.gradientVersion = (this.gradientVersion + 1) % MAX_SAFE_INTEGER;\n }\n };\n LineStyleLayer.prototype.gradientExpression = function gradientExpression() {\n return this._transitionablePaint._values['line-gradient'].value.expression;\n };\n LineStyleLayer.prototype.recalculate = function recalculate(parameters, availableImages) {\n StyleLayer.prototype.recalculate.call(this, parameters, availableImages);\n this.paint._values['line-floorwidth'] = lineFloorwidthProperty.possiblyEvaluate(this._transitioningPaint._values['line-width'].value, parameters);\n };\n LineStyleLayer.prototype.createBucket = function createBucket(parameters) {\n return new LineBucket(parameters);\n };\n LineStyleLayer.prototype.queryRadius = function queryRadius(bucket) {\n var lineBucket = bucket;\n var width = getLineWidth(getMaximumPaintValue('line-width', this, lineBucket), getMaximumPaintValue('line-gap-width', this, lineBucket));\n var offset = getMaximumPaintValue('line-offset', this, lineBucket);\n return width / 2 + Math.abs(offset) + translateDistance(this.paint.get('line-translate'));\n };\n LineStyleLayer.prototype.queryIntersectsFeature = function queryIntersectsFeature(queryGeometry, feature, featureState, geometry, zoom, transform, pixelsToTileUnits) {\n var translatedPolygon = translate(queryGeometry, this.paint.get('line-translate'), this.paint.get('line-translate-anchor'), transform.angle, pixelsToTileUnits);\n var halfWidth = pixelsToTileUnits / 2 * getLineWidth(this.paint.get('line-width').evaluate(feature, featureState), this.paint.get('line-gap-width').evaluate(feature, featureState));\n var lineOffset = this.paint.get('line-offset').evaluate(feature, featureState);\n if (lineOffset) {\n geometry = offsetLine(geometry, lineOffset * pixelsToTileUnits);\n }\n return polygonIntersectsBufferedMultiLine(translatedPolygon, geometry, halfWidth);\n };\n LineStyleLayer.prototype.isTileClipped = function isTileClipped() {\n return true;\n };\n return LineStyleLayer;\n}(StyleLayer);\nfunction getLineWidth(lineWidth, lineGapWidth) {\n if (lineGapWidth > 0) {\n return lineGapWidth + 2 * lineWidth;\n } else {\n return lineWidth;\n }\n}\nfunction offsetLine(rings, offset) {\n var newRings = [];\n var zero = new pointGeometry(0, 0);\n for (var k = 0; k < rings.length; k++) {\n var ring = rings[k];\n var newRing = [];\n for (var i = 0; i < ring.length; i++) {\n var a = ring[i - 1];\n var b = ring[i];\n var c = ring[i + 1];\n var aToB = i === 0 ? zero : b.sub(a)._unit()._perp();\n var bToC = i === ring.length - 1 ? zero : c.sub(b)._unit()._perp();\n var extrude = aToB._add(bToC)._unit();\n var cosHalfAngle = extrude.x * bToC.x + extrude.y * bToC.y;\n extrude._mult(1 / cosHalfAngle);\n newRing.push(extrude._mult(offset)._add(b));\n }\n newRings.push(newRing);\n }\n return newRings;\n}\n\nvar symbolLayoutAttributes = createLayout([\n {\n name: 'a_pos_offset',\n components: 4,\n type: 'Int16'\n },\n {\n name: 'a_data',\n components: 4,\n type: 'Uint16'\n },\n {\n name: 'a_pixeloffset',\n components: 4,\n type: 'Int16'\n }\n], 4);\nvar dynamicLayoutAttributes = createLayout([{\n name: 'a_projected_pos',\n components: 3,\n type: 'Float32'\n }], 4);\nvar placementOpacityAttributes = createLayout([{\n name: 'a_fade_opacity',\n components: 1,\n type: 'Uint32'\n }], 4);\nvar collisionVertexAttributes = createLayout([\n {\n name: 'a_placed',\n components: 2,\n type: 'Uint8'\n },\n {\n name: 'a_shift',\n components: 2,\n type: 'Float32'\n }\n]);\nvar collisionBox = createLayout([\n {\n type: 'Int16',\n name: 'anchorPointX'\n },\n {\n type: 'Int16',\n name: 'anchorPointY'\n },\n {\n type: 'Int16',\n name: 'x1'\n },\n {\n type: 'Int16',\n name: 'y1'\n },\n {\n type: 'Int16',\n name: 'x2'\n },\n {\n type: 'Int16',\n name: 'y2'\n },\n {\n type: 'Uint32',\n name: 'featureIndex'\n },\n {\n type: 'Uint16',\n name: 'sourceLayerIndex'\n },\n {\n type: 'Uint16',\n name: 'bucketIndex'\n }\n]);\nvar collisionBoxLayout = createLayout([\n {\n name: 'a_pos',\n components: 2,\n type: 'Int16'\n },\n {\n name: 'a_anchor_pos',\n components: 2,\n type: 'Int16'\n },\n {\n name: 'a_extrude',\n components: 2,\n type: 'Int16'\n }\n], 4);\nvar collisionCircleLayout = createLayout([\n {\n name: 'a_pos',\n components: 2,\n type: 'Float32'\n },\n {\n name: 'a_radius',\n components: 1,\n type: 'Float32'\n },\n {\n name: 'a_flags',\n components: 2,\n type: 'Int16'\n }\n], 4);\nvar quadTriangle = createLayout([{\n name: 'triangle',\n components: 3,\n type: 'Uint16'\n }]);\nvar placement = createLayout([\n {\n type: 'Int16',\n name: 'anchorX'\n },\n {\n type: 'Int16',\n name: 'anchorY'\n },\n {\n type: 'Uint16',\n name: 'glyphStartIndex'\n },\n {\n type: 'Uint16',\n name: 'numGlyphs'\n },\n {\n type: 'Uint32',\n name: 'vertexStartIndex'\n },\n {\n type: 'Uint32',\n name: 'lineStartIndex'\n },\n {\n type: 'Uint32',\n name: 'lineLength'\n },\n {\n type: 'Uint16',\n name: 'segment'\n },\n {\n type: 'Uint16',\n name: 'lowerSize'\n },\n {\n type: 'Uint16',\n name: 'upperSize'\n },\n {\n type: 'Float32',\n name: 'lineOffsetX'\n },\n {\n type: 'Float32',\n name: 'lineOffsetY'\n },\n {\n type: 'Uint8',\n name: 'writingMode'\n },\n {\n type: 'Uint8',\n name: 'placedOrientation'\n },\n {\n type: 'Uint8',\n name: 'hidden'\n },\n {\n type: 'Uint32',\n name: 'crossTileID'\n },\n {\n type: 'Int16',\n name: 'associatedIconIndex'\n }\n]);\nvar symbolInstance = createLayout([\n {\n type: 'Int16',\n name: 'anchorX'\n },\n {\n type: 'Int16',\n name: 'anchorY'\n },\n {\n type: 'Int16',\n name: 'rightJustifiedTextSymbolIndex'\n },\n {\n type: 'Int16',\n name: 'centerJustifiedTextSymbolIndex'\n },\n {\n type: 'Int16',\n name: 'leftJustifiedTextSymbolIndex'\n },\n {\n type: 'Int16',\n name: 'verticalPlacedTextSymbolIndex'\n },\n {\n type: 'Int16',\n name: 'placedIconSymbolIndex'\n },\n {\n type: 'Int16',\n name: 'verticalPlacedIconSymbolIndex'\n },\n {\n type: 'Uint16',\n name: 'key'\n },\n {\n type: 'Uint16',\n name: 'textBoxStartIndex'\n },\n {\n type: 'Uint16',\n name: 'textBoxEndIndex'\n },\n {\n type: 'Uint16',\n name: 'verticalTextBoxStartIndex'\n },\n {\n type: 'Uint16',\n name: 'verticalTextBoxEndIndex'\n },\n {\n type: 'Uint16',\n name: 'iconBoxStartIndex'\n },\n {\n type: 'Uint16',\n name: 'iconBoxEndIndex'\n },\n {\n type: 'Uint16',\n name: 'verticalIconBoxStartIndex'\n },\n {\n type: 'Uint16',\n name: 'verticalIconBoxEndIndex'\n },\n {\n type: 'Uint16',\n name: 'featureIndex'\n },\n {\n type: 'Uint16',\n name: 'numHorizontalGlyphVertices'\n },\n {\n type: 'Uint16',\n name: 'numVerticalGlyphVertices'\n },\n {\n type: 'Uint16',\n name: 'numIconVertices'\n },\n {\n type: 'Uint16',\n name: 'numVerticalIconVertices'\n },\n {\n type: 'Uint16',\n name: 'useRuntimeCollisionCircles'\n },\n {\n type: 'Uint32',\n name: 'crossTileID'\n },\n {\n type: 'Float32',\n name: 'textBoxScale'\n },\n {\n type: 'Float32',\n components: 2,\n name: 'textOffset'\n },\n {\n type: 'Float32',\n name: 'collisionCircleDiameter'\n }\n]);\nvar glyphOffset = createLayout([{\n type: 'Float32',\n name: 'offsetX'\n }]);\nvar lineVertex = createLayout([\n {\n type: 'Int16',\n name: 'x'\n },\n {\n type: 'Int16',\n name: 'y'\n },\n {\n type: 'Int16',\n name: 'tileUnitDistanceFromAnchor'\n }\n]);\n\nfunction transformText(text, layer, feature) {\n var transform = layer.layout.get('text-transform').evaluate(feature, {});\n if (transform === 'uppercase') {\n text = text.toLocaleUpperCase();\n } else if (transform === 'lowercase') {\n text = text.toLocaleLowerCase();\n }\n if (plugin.applyArabicShaping) {\n text = plugin.applyArabicShaping(text);\n }\n return text;\n}\nfunction transformText$1 (text, layer, feature) {\n text.sections.forEach(function (section) {\n section.text = transformText(section.text, layer, feature);\n });\n return text;\n}\n\nfunction mergeLines (features) {\n var leftIndex = {};\n var rightIndex = {};\n var mergedFeatures = [];\n var mergedIndex = 0;\n function add(k) {\n mergedFeatures.push(features[k]);\n mergedIndex++;\n }\n function mergeFromRight(leftKey, rightKey, geom) {\n var i = rightIndex[leftKey];\n delete rightIndex[leftKey];\n rightIndex[rightKey] = i;\n mergedFeatures[i].geometry[0].pop();\n mergedFeatures[i].geometry[0] = mergedFeatures[i].geometry[0].concat(geom[0]);\n return i;\n }\n function mergeFromLeft(leftKey, rightKey, geom) {\n var i = leftIndex[rightKey];\n delete leftIndex[rightKey];\n leftIndex[leftKey] = i;\n mergedFeatures[i].geometry[0].shift();\n mergedFeatures[i].geometry[0] = geom[0].concat(mergedFeatures[i].geometry[0]);\n return i;\n }\n function getKey(text, geom, onRight) {\n var point = onRight ? geom[0][geom[0].length - 1] : geom[0][0];\n return text + ':' + point.x + ':' + point.y;\n }\n for (var k = 0; k < features.length; k++) {\n var feature = features[k];\n var geom = feature.geometry;\n var text = feature.text ? feature.text.toString() : null;\n if (!text) {\n add(k);\n continue;\n }\n var leftKey = getKey(text, geom), rightKey = getKey(text, geom, true);\n if (leftKey in rightIndex && rightKey in leftIndex && rightIndex[leftKey] !== leftIndex[rightKey]) {\n var j = mergeFromLeft(leftKey, rightKey, geom);\n var i = mergeFromRight(leftKey, rightKey, mergedFeatures[j].geometry);\n delete leftIndex[leftKey];\n delete rightIndex[rightKey];\n rightIndex[getKey(text, mergedFeatures[i].geometry, true)] = i;\n mergedFeatures[j].geometry = null;\n } else if (leftKey in rightIndex) {\n mergeFromRight(leftKey, rightKey, geom);\n } else if (rightKey in leftIndex) {\n mergeFromLeft(leftKey, rightKey, geom);\n } else {\n add(k);\n leftIndex[leftKey] = mergedIndex - 1;\n rightIndex[rightKey] = mergedIndex - 1;\n }\n }\n return mergedFeatures.filter(function (f) {\n return f.geometry;\n });\n}\n\nvar verticalizedCharacterMap = {\n '!': '\\uFE15',\n '#': '\\uFF03',\n '$': '\\uFF04',\n '%': '\\uFF05',\n '&': '\\uFF06',\n '(': '\\uFE35',\n ')': '\\uFE36',\n '*': '\\uFF0A',\n '+': '\\uFF0B',\n ',': '\\uFE10',\n '-': '\\uFE32',\n '.': '\\u30FB',\n '/': '\\uFF0F',\n ':': '\\uFE13',\n ';': '\\uFE14',\n '<': '\\uFE3F',\n '=': '\\uFF1D',\n '>': '\\uFE40',\n '?': '\\uFE16',\n '@': '\\uFF20',\n '[': '\\uFE47',\n '\\\\': '\\uFF3C',\n ']': '\\uFE48',\n '^': '\\uFF3E',\n '_': '︳',\n '`': '\\uFF40',\n '{': '\\uFE37',\n '|': '\\u2015',\n '}': '\\uFE38',\n '~': '\\uFF5E',\n '\\xA2': '\\uFFE0',\n '\\xA3': '\\uFFE1',\n '\\xA5': '\\uFFE5',\n '\\xA6': '\\uFFE4',\n '\\xAC': '\\uFFE2',\n '\\xAF': '\\uFFE3',\n '\\u2013': '\\uFE32',\n '\\u2014': '\\uFE31',\n '\\u2018': '\\uFE43',\n '\\u2019': '\\uFE44',\n '\\u201C': '\\uFE41',\n '\\u201D': '\\uFE42',\n '\\u2026': '\\uFE19',\n '\\u2027': '\\u30FB',\n '\\u20A9': '\\uFFE6',\n '\\u3001': '\\uFE11',\n '\\u3002': '\\uFE12',\n '\\u3008': '\\uFE3F',\n '\\u3009': '\\uFE40',\n '\\u300A': '\\uFE3D',\n '\\u300B': '\\uFE3E',\n '\\u300C': '\\uFE41',\n '\\u300D': '\\uFE42',\n '\\u300E': '\\uFE43',\n '\\u300F': '\\uFE44',\n '\\u3010': '\\uFE3B',\n '\\u3011': '\\uFE3C',\n '\\u3014': '\\uFE39',\n '\\u3015': '\\uFE3A',\n '\\u3016': '\\uFE17',\n '\\u3017': '\\uFE18',\n '\\uFF01': '\\uFE15',\n '\\uFF08': '\\uFE35',\n '\\uFF09': '\\uFE36',\n '\\uFF0C': '\\uFE10',\n '\\uFF0D': '\\uFE32',\n '\\uFF0E': '\\u30FB',\n '\\uFF1A': '\\uFE13',\n '\\uFF1B': '\\uFE14',\n '\\uFF1C': '\\uFE3F',\n '\\uFF1E': '\\uFE40',\n '\\uFF1F': '\\uFE16',\n '\\uFF3B': '\\uFE47',\n '\\uFF3D': '\\uFE48',\n '_': '︳',\n '\\uFF5B': '\\uFE37',\n '\\uFF5C': '\\u2015',\n '\\uFF5D': '\\uFE38',\n '\\uFF5F': '\\uFE35',\n '\\uFF60': '\\uFE36',\n '\\uFF61': '\\uFE12',\n '\\uFF62': '\\uFE41',\n '\\uFF63': '\\uFE42'\n};\nfunction verticalizePunctuation(input) {\n var output = '';\n for (var i = 0; i < input.length; i++) {\n var nextCharCode = input.charCodeAt(i + 1) || null;\n var prevCharCode = input.charCodeAt(i - 1) || null;\n var canReplacePunctuation = (!nextCharCode || !charHasRotatedVerticalOrientation(nextCharCode) || verticalizedCharacterMap[input[i + 1]]) && (!prevCharCode || !charHasRotatedVerticalOrientation(prevCharCode) || verticalizedCharacterMap[input[i - 1]]);\n if (canReplacePunctuation && verticalizedCharacterMap[input[i]]) {\n output += verticalizedCharacterMap[input[i]];\n } else {\n output += input[i];\n }\n }\n return output;\n}\n\nvar ONE_EM = 24;\n\nvar read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m;\n var eLen = nBytes * 8 - mLen - 1;\n var eMax = (1 << eLen) - 1;\n var eBias = eMax >> 1;\n var nBits = -7;\n var i = isLE ? nBytes - 1 : 0;\n var d = isLE ? -1 : 1;\n var s = buffer[offset + i];\n i += d;\n e = s & (1 << -nBits) - 1;\n s >>= -nBits;\n nBits += eLen;\n for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {\n }\n m = e & (1 << -nBits) - 1;\n e >>= -nBits;\n nBits += mLen;\n for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {\n }\n if (e === 0) {\n e = 1 - eBias;\n } else if (e === eMax) {\n return m ? NaN : (s ? -1 : 1) * Infinity;\n } else {\n m = m + Math.pow(2, mLen);\n e = e - eBias;\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen);\n};\nvar write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c;\n var eLen = nBytes * 8 - mLen - 1;\n var eMax = (1 << eLen) - 1;\n var eBias = eMax >> 1;\n var rt = mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0;\n var i = isLE ? 0 : nBytes - 1;\n var d = isLE ? 1 : -1;\n var s = value < 0 || value === 0 && 1 / value < 0 ? 1 : 0;\n value = Math.abs(value);\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0;\n e = eMax;\n } else {\n e = Math.floor(Math.log(value) / Math.LN2);\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--;\n c *= 2;\n }\n if (e + eBias >= 1) {\n value += rt / c;\n } else {\n value += rt * Math.pow(2, 1 - eBias);\n }\n if (value * c >= 2) {\n e++;\n c /= 2;\n }\n if (e + eBias >= eMax) {\n m = 0;\n e = eMax;\n } else if (e + eBias >= 1) {\n m = (value * c - 1) * Math.pow(2, mLen);\n e = e + eBias;\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen);\n e = 0;\n }\n }\n for (; mLen >= 8; buffer[offset + i] = m & 255, i += d, m /= 256, mLen -= 8) {\n }\n e = e << mLen | m;\n eLen += mLen;\n for (; eLen > 0; buffer[offset + i] = e & 255, i += d, e /= 256, eLen -= 8) {\n }\n buffer[offset + i - d] |= s * 128;\n};\n\nvar ieee754 = {\n\tread: read,\n\twrite: write\n};\n\nvar pbf = Pbf;\n\nfunction Pbf(buf) {\n this.buf = ArrayBuffer.isView && ArrayBuffer.isView(buf) ? buf : new Uint8Array(buf || 0);\n this.pos = 0;\n this.type = 0;\n this.length = this.buf.length;\n}\nPbf.Varint = 0;\nPbf.Fixed64 = 1;\nPbf.Bytes = 2;\nPbf.Fixed32 = 5;\nvar SHIFT_LEFT_32 = (1 << 16) * (1 << 16), SHIFT_RIGHT_32 = 1 / SHIFT_LEFT_32;\nvar TEXT_DECODER_MIN_LENGTH = 12;\nvar utf8TextDecoder = typeof TextDecoder === 'undefined' ? null : new TextDecoder('utf8');\nPbf.prototype = {\n destroy: function () {\n this.buf = null;\n },\n readFields: function (readField, result, end) {\n end = end || this.length;\n while (this.pos < end) {\n var val = this.readVarint(), tag = val >> 3, startPos = this.pos;\n this.type = val & 7;\n readField(tag, result, this);\n if (this.pos === startPos) {\n this.skip(val);\n }\n }\n return result;\n },\n readMessage: function (readField, result) {\n return this.readFields(readField, result, this.readVarint() + this.pos);\n },\n readFixed32: function () {\n var val = readUInt32(this.buf, this.pos);\n this.pos += 4;\n return val;\n },\n readSFixed32: function () {\n var val = readInt32(this.buf, this.pos);\n this.pos += 4;\n return val;\n },\n readFixed64: function () {\n var val = readUInt32(this.buf, this.pos) + readUInt32(this.buf, this.pos + 4) * SHIFT_LEFT_32;\n this.pos += 8;\n return val;\n },\n readSFixed64: function () {\n var val = readUInt32(this.buf, this.pos) + readInt32(this.buf, this.pos + 4) * SHIFT_LEFT_32;\n this.pos += 8;\n return val;\n },\n readFloat: function () {\n var val = ieee754.read(this.buf, this.pos, true, 23, 4);\n this.pos += 4;\n return val;\n },\n readDouble: function () {\n var val = ieee754.read(this.buf, this.pos, true, 52, 8);\n this.pos += 8;\n return val;\n },\n readVarint: function (isSigned) {\n var buf = this.buf, val, b;\n b = buf[this.pos++];\n val = b & 127;\n if (b < 128) {\n return val;\n }\n b = buf[this.pos++];\n val |= (b & 127) << 7;\n if (b < 128) {\n return val;\n }\n b = buf[this.pos++];\n val |= (b & 127) << 14;\n if (b < 128) {\n return val;\n }\n b = buf[this.pos++];\n val |= (b & 127) << 21;\n if (b < 128) {\n return val;\n }\n b = buf[this.pos];\n val |= (b & 15) << 28;\n return readVarintRemainder(val, isSigned, this);\n },\n readVarint64: function () {\n return this.readVarint(true);\n },\n readSVarint: function () {\n var num = this.readVarint();\n return num % 2 === 1 ? (num + 1) / -2 : num / 2;\n },\n readBoolean: function () {\n return Boolean(this.readVarint());\n },\n readString: function () {\n var end = this.readVarint() + this.pos;\n var pos = this.pos;\n this.pos = end;\n if (end - pos >= TEXT_DECODER_MIN_LENGTH && utf8TextDecoder) {\n return readUtf8TextDecoder(this.buf, pos, end);\n }\n return readUtf8(this.buf, pos, end);\n },\n readBytes: function () {\n var end = this.readVarint() + this.pos, buffer = this.buf.subarray(this.pos, end);\n this.pos = end;\n return buffer;\n },\n readPackedVarint: function (arr, isSigned) {\n if (this.type !== Pbf.Bytes) {\n return arr.push(this.readVarint(isSigned));\n }\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) {\n arr.push(this.readVarint(isSigned));\n }\n return arr;\n },\n readPackedSVarint: function (arr) {\n if (this.type !== Pbf.Bytes) {\n return arr.push(this.readSVarint());\n }\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) {\n arr.push(this.readSVarint());\n }\n return arr;\n },\n readPackedBoolean: function (arr) {\n if (this.type !== Pbf.Bytes) {\n return arr.push(this.readBoolean());\n }\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) {\n arr.push(this.readBoolean());\n }\n return arr;\n },\n readPackedFloat: function (arr) {\n if (this.type !== Pbf.Bytes) {\n return arr.push(this.readFloat());\n }\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) {\n arr.push(this.readFloat());\n }\n return arr;\n },\n readPackedDouble: function (arr) {\n if (this.type !== Pbf.Bytes) {\n return arr.push(this.readDouble());\n }\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) {\n arr.push(this.readDouble());\n }\n return arr;\n },\n readPackedFixed32: function (arr) {\n if (this.type !== Pbf.Bytes) {\n return arr.push(this.readFixed32());\n }\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) {\n arr.push(this.readFixed32());\n }\n return arr;\n },\n readPackedSFixed32: function (arr) {\n if (this.type !== Pbf.Bytes) {\n return arr.push(this.readSFixed32());\n }\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) {\n arr.push(this.readSFixed32());\n }\n return arr;\n },\n readPackedFixed64: function (arr) {\n if (this.type !== Pbf.Bytes) {\n return arr.push(this.readFixed64());\n }\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) {\n arr.push(this.readFixed64());\n }\n return arr;\n },\n readPackedSFixed64: function (arr) {\n if (this.type !== Pbf.Bytes) {\n return arr.push(this.readSFixed64());\n }\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) {\n arr.push(this.readSFixed64());\n }\n return arr;\n },\n skip: function (val) {\n var type = val & 7;\n if (type === Pbf.Varint) {\n while (this.buf[this.pos++] > 127) {\n }\n } else if (type === Pbf.Bytes) {\n this.pos = this.readVarint() + this.pos;\n } else if (type === Pbf.Fixed32) {\n this.pos += 4;\n } else if (type === Pbf.Fixed64) {\n this.pos += 8;\n } else {\n throw new Error('Unimplemented type: ' + type);\n }\n },\n writeTag: function (tag, type) {\n this.writeVarint(tag << 3 | type);\n },\n realloc: function (min) {\n var length = this.length || 16;\n while (length < this.pos + min) {\n length *= 2;\n }\n if (length !== this.length) {\n var buf = new Uint8Array(length);\n buf.set(this.buf);\n this.buf = buf;\n this.length = length;\n }\n },\n finish: function () {\n this.length = this.pos;\n this.pos = 0;\n return this.buf.subarray(0, this.length);\n },\n writeFixed32: function (val) {\n this.realloc(4);\n writeInt32(this.buf, val, this.pos);\n this.pos += 4;\n },\n writeSFixed32: function (val) {\n this.realloc(4);\n writeInt32(this.buf, val, this.pos);\n this.pos += 4;\n },\n writeFixed64: function (val) {\n this.realloc(8);\n writeInt32(this.buf, val & -1, this.pos);\n writeInt32(this.buf, Math.floor(val * SHIFT_RIGHT_32), this.pos + 4);\n this.pos += 8;\n },\n writeSFixed64: function (val) {\n this.realloc(8);\n writeInt32(this.buf, val & -1, this.pos);\n writeInt32(this.buf, Math.floor(val * SHIFT_RIGHT_32), this.pos + 4);\n this.pos += 8;\n },\n writeVarint: function (val) {\n val = +val || 0;\n if (val > 268435455 || val < 0) {\n writeBigVarint(val, this);\n return;\n }\n this.realloc(4);\n this.buf[this.pos++] = val & 127 | (val > 127 ? 128 : 0);\n if (val <= 127) {\n return;\n }\n this.buf[this.pos++] = (val >>>= 7) & 127 | (val > 127 ? 128 : 0);\n if (val <= 127) {\n return;\n }\n this.buf[this.pos++] = (val >>>= 7) & 127 | (val > 127 ? 128 : 0);\n if (val <= 127) {\n return;\n }\n this.buf[this.pos++] = val >>> 7 & 127;\n },\n writeSVarint: function (val) {\n this.writeVarint(val < 0 ? -val * 2 - 1 : val * 2);\n },\n writeBoolean: function (val) {\n this.writeVarint(Boolean(val));\n },\n writeString: function (str) {\n str = String(str);\n this.realloc(str.length * 4);\n this.pos++;\n var startPos = this.pos;\n this.pos = writeUtf8(this.buf, str, this.pos);\n var len = this.pos - startPos;\n if (len >= 128) {\n makeRoomForExtraLength(startPos, len, this);\n }\n this.pos = startPos - 1;\n this.writeVarint(len);\n this.pos += len;\n },\n writeFloat: function (val) {\n this.realloc(4);\n ieee754.write(this.buf, val, this.pos, true, 23, 4);\n this.pos += 4;\n },\n writeDouble: function (val) {\n this.realloc(8);\n ieee754.write(this.buf, val, this.pos, true, 52, 8);\n this.pos += 8;\n },\n writeBytes: function (buffer) {\n var len = buffer.length;\n this.writeVarint(len);\n this.realloc(len);\n for (var i = 0; i < len; i++) {\n this.buf[this.pos++] = buffer[i];\n }\n },\n writeRawMessage: function (fn, obj) {\n this.pos++;\n var startPos = this.pos;\n fn(obj, this);\n var len = this.pos - startPos;\n if (len >= 128) {\n makeRoomForExtraLength(startPos, len, this);\n }\n this.pos = startPos - 1;\n this.writeVarint(len);\n this.pos += len;\n },\n writeMessage: function (tag, fn, obj) {\n this.writeTag(tag, Pbf.Bytes);\n this.writeRawMessage(fn, obj);\n },\n writePackedVarint: function (tag, arr) {\n if (arr.length) {\n this.writeMessage(tag, writePackedVarint, arr);\n }\n },\n writePackedSVarint: function (tag, arr) {\n if (arr.length) {\n this.writeMessage(tag, writePackedSVarint, arr);\n }\n },\n writePackedBoolean: function (tag, arr) {\n if (arr.length) {\n this.writeMessage(tag, writePackedBoolean, arr);\n }\n },\n writePackedFloat: function (tag, arr) {\n if (arr.length) {\n this.writeMessage(tag, writePackedFloat, arr);\n }\n },\n writePackedDouble: function (tag, arr) {\n if (arr.length) {\n this.writeMessage(tag, writePackedDouble, arr);\n }\n },\n writePackedFixed32: function (tag, arr) {\n if (arr.length) {\n this.writeMessage(tag, writePackedFixed32, arr);\n }\n },\n writePackedSFixed32: function (tag, arr) {\n if (arr.length) {\n this.writeMessage(tag, writePackedSFixed32, arr);\n }\n },\n writePackedFixed64: function (tag, arr) {\n if (arr.length) {\n this.writeMessage(tag, writePackedFixed64, arr);\n }\n },\n writePackedSFixed64: function (tag, arr) {\n if (arr.length) {\n this.writeMessage(tag, writePackedSFixed64, arr);\n }\n },\n writeBytesField: function (tag, buffer) {\n this.writeTag(tag, Pbf.Bytes);\n this.writeBytes(buffer);\n },\n writeFixed32Field: function (tag, val) {\n this.writeTag(tag, Pbf.Fixed32);\n this.writeFixed32(val);\n },\n writeSFixed32Field: function (tag, val) {\n this.writeTag(tag, Pbf.Fixed32);\n this.writeSFixed32(val);\n },\n writeFixed64Field: function (tag, val) {\n this.writeTag(tag, Pbf.Fixed64);\n this.writeFixed64(val);\n },\n writeSFixed64Field: function (tag, val) {\n this.writeTag(tag, Pbf.Fixed64);\n this.writeSFixed64(val);\n },\n writeVarintField: function (tag, val) {\n this.writeTag(tag, Pbf.Varint);\n this.writeVarint(val);\n },\n writeSVarintField: function (tag, val) {\n this.writeTag(tag, Pbf.Varint);\n this.writeSVarint(val);\n },\n writeStringField: function (tag, str) {\n this.writeTag(tag, Pbf.Bytes);\n this.writeString(str);\n },\n writeFloatField: function (tag, val) {\n this.writeTag(tag, Pbf.Fixed32);\n this.writeFloat(val);\n },\n writeDoubleField: function (tag, val) {\n this.writeTag(tag, Pbf.Fixed64);\n this.writeDouble(val);\n },\n writeBooleanField: function (tag, val) {\n this.writeVarintField(tag, Boolean(val));\n }\n};\nfunction readVarintRemainder(l, s, p) {\n var buf = p.buf, h, b;\n b = buf[p.pos++];\n h = (b & 112) >> 4;\n if (b < 128) {\n return toNum(l, h, s);\n }\n b = buf[p.pos++];\n h |= (b & 127) << 3;\n if (b < 128) {\n return toNum(l, h, s);\n }\n b = buf[p.pos++];\n h |= (b & 127) << 10;\n if (b < 128) {\n return toNum(l, h, s);\n }\n b = buf[p.pos++];\n h |= (b & 127) << 17;\n if (b < 128) {\n return toNum(l, h, s);\n }\n b = buf[p.pos++];\n h |= (b & 127) << 24;\n if (b < 128) {\n return toNum(l, h, s);\n }\n b = buf[p.pos++];\n h |= (b & 1) << 31;\n if (b < 128) {\n return toNum(l, h, s);\n }\n throw new Error('Expected varint not more than 10 bytes');\n}\nfunction readPackedEnd(pbf) {\n return pbf.type === Pbf.Bytes ? pbf.readVarint() + pbf.pos : pbf.pos + 1;\n}\nfunction toNum(low, high, isSigned) {\n if (isSigned) {\n return high * 4294967296 + (low >>> 0);\n }\n return (high >>> 0) * 4294967296 + (low >>> 0);\n}\nfunction writeBigVarint(val, pbf) {\n var low, high;\n if (val >= 0) {\n low = val % 4294967296 | 0;\n high = val / 4294967296 | 0;\n } else {\n low = ~(-val % 4294967296);\n high = ~(-val / 4294967296);\n if (low ^ 4294967295) {\n low = low + 1 | 0;\n } else {\n low = 0;\n high = high + 1 | 0;\n }\n }\n if (val >= 18446744073709552000 || val < -18446744073709552000) {\n throw new Error('Given varint doesn\\'t fit into 10 bytes');\n }\n pbf.realloc(10);\n writeBigVarintLow(low, high, pbf);\n writeBigVarintHigh(high, pbf);\n}\nfunction writeBigVarintLow(low, high, pbf) {\n pbf.buf[pbf.pos++] = low & 127 | 128;\n low >>>= 7;\n pbf.buf[pbf.pos++] = low & 127 | 128;\n low >>>= 7;\n pbf.buf[pbf.pos++] = low & 127 | 128;\n low >>>= 7;\n pbf.buf[pbf.pos++] = low & 127 | 128;\n low >>>= 7;\n pbf.buf[pbf.pos] = low & 127;\n}\nfunction writeBigVarintHigh(high, pbf) {\n var lsb = (high & 7) << 4;\n pbf.buf[pbf.pos++] |= lsb | ((high >>>= 3) ? 128 : 0);\n if (!high) {\n return;\n }\n pbf.buf[pbf.pos++] = high & 127 | ((high >>>= 7) ? 128 : 0);\n if (!high) {\n return;\n }\n pbf.buf[pbf.pos++] = high & 127 | ((high >>>= 7) ? 128 : 0);\n if (!high) {\n return;\n }\n pbf.buf[pbf.pos++] = high & 127 | ((high >>>= 7) ? 128 : 0);\n if (!high) {\n return;\n }\n pbf.buf[pbf.pos++] = high & 127 | ((high >>>= 7) ? 128 : 0);\n if (!high) {\n return;\n }\n pbf.buf[pbf.pos++] = high & 127;\n}\nfunction makeRoomForExtraLength(startPos, len, pbf) {\n var extraLen = len <= 16383 ? 1 : len <= 2097151 ? 2 : len <= 268435455 ? 3 : Math.floor(Math.log(len) / (Math.LN2 * 7));\n pbf.realloc(extraLen);\n for (var i = pbf.pos - 1; i >= startPos; i--) {\n pbf.buf[i + extraLen] = pbf.buf[i];\n }\n}\nfunction writePackedVarint(arr, pbf) {\n for (var i = 0; i < arr.length; i++) {\n pbf.writeVarint(arr[i]);\n }\n}\nfunction writePackedSVarint(arr, pbf) {\n for (var i = 0; i < arr.length; i++) {\n pbf.writeSVarint(arr[i]);\n }\n}\nfunction writePackedFloat(arr, pbf) {\n for (var i = 0; i < arr.length; i++) {\n pbf.writeFloat(arr[i]);\n }\n}\nfunction writePackedDouble(arr, pbf) {\n for (var i = 0; i < arr.length; i++) {\n pbf.writeDouble(arr[i]);\n }\n}\nfunction writePackedBoolean(arr, pbf) {\n for (var i = 0; i < arr.length; i++) {\n pbf.writeBoolean(arr[i]);\n }\n}\nfunction writePackedFixed32(arr, pbf) {\n for (var i = 0; i < arr.length; i++) {\n pbf.writeFixed32(arr[i]);\n }\n}\nfunction writePackedSFixed32(arr, pbf) {\n for (var i = 0; i < arr.length; i++) {\n pbf.writeSFixed32(arr[i]);\n }\n}\nfunction writePackedFixed64(arr, pbf) {\n for (var i = 0; i < arr.length; i++) {\n pbf.writeFixed64(arr[i]);\n }\n}\nfunction writePackedSFixed64(arr, pbf) {\n for (var i = 0; i < arr.length; i++) {\n pbf.writeSFixed64(arr[i]);\n }\n}\nfunction readUInt32(buf, pos) {\n return (buf[pos] | buf[pos + 1] << 8 | buf[pos + 2] << 16) + buf[pos + 3] * 16777216;\n}\nfunction writeInt32(buf, val, pos) {\n buf[pos] = val;\n buf[pos + 1] = val >>> 8;\n buf[pos + 2] = val >>> 16;\n buf[pos + 3] = val >>> 24;\n}\nfunction readInt32(buf, pos) {\n return (buf[pos] | buf[pos + 1] << 8 | buf[pos + 2] << 16) + (buf[pos + 3] << 24);\n}\nfunction readUtf8(buf, pos, end) {\n var str = '';\n var i = pos;\n while (i < end) {\n var b0 = buf[i];\n var c = null;\n var bytesPerSequence = b0 > 239 ? 4 : b0 > 223 ? 3 : b0 > 191 ? 2 : 1;\n if (i + bytesPerSequence > end) {\n break;\n }\n var b1, b2, b3;\n if (bytesPerSequence === 1) {\n if (b0 < 128) {\n c = b0;\n }\n } else if (bytesPerSequence === 2) {\n b1 = buf[i + 1];\n if ((b1 & 192) === 128) {\n c = (b0 & 31) << 6 | b1 & 63;\n if (c <= 127) {\n c = null;\n }\n }\n } else if (bytesPerSequence === 3) {\n b1 = buf[i + 1];\n b2 = buf[i + 2];\n if ((b1 & 192) === 128 && (b2 & 192) === 128) {\n c = (b0 & 15) << 12 | (b1 & 63) << 6 | b2 & 63;\n if (c <= 2047 || c >= 55296 && c <= 57343) {\n c = null;\n }\n }\n } else if (bytesPerSequence === 4) {\n b1 = buf[i + 1];\n b2 = buf[i + 2];\n b3 = buf[i + 3];\n if ((b1 & 192) === 128 && (b2 & 192) === 128 && (b3 & 192) === 128) {\n c = (b0 & 15) << 18 | (b1 & 63) << 12 | (b2 & 63) << 6 | b3 & 63;\n if (c <= 65535 || c >= 1114112) {\n c = null;\n }\n }\n }\n if (c === null) {\n c = 65533;\n bytesPerSequence = 1;\n } else if (c > 65535) {\n c -= 65536;\n str += String.fromCharCode(c >>> 10 & 1023 | 55296);\n c = 56320 | c & 1023;\n }\n str += String.fromCharCode(c);\n i += bytesPerSequence;\n }\n return str;\n}\nfunction readUtf8TextDecoder(buf, pos, end) {\n return utf8TextDecoder.decode(buf.subarray(pos, end));\n}\nfunction writeUtf8(buf, str, pos) {\n for (var i = 0, c, lead; i < str.length; i++) {\n c = str.charCodeAt(i);\n if (c > 55295 && c < 57344) {\n if (lead) {\n if (c < 56320) {\n buf[pos++] = 239;\n buf[pos++] = 191;\n buf[pos++] = 189;\n lead = c;\n continue;\n } else {\n c = lead - 55296 << 10 | c - 56320 | 65536;\n lead = null;\n }\n } else {\n if (c > 56319 || i + 1 === str.length) {\n buf[pos++] = 239;\n buf[pos++] = 191;\n buf[pos++] = 189;\n } else {\n lead = c;\n }\n continue;\n }\n } else if (lead) {\n buf[pos++] = 239;\n buf[pos++] = 191;\n buf[pos++] = 189;\n lead = null;\n }\n if (c < 128) {\n buf[pos++] = c;\n } else {\n if (c < 2048) {\n buf[pos++] = c >> 6 | 192;\n } else {\n if (c < 65536) {\n buf[pos++] = c >> 12 | 224;\n } else {\n buf[pos++] = c >> 18 | 240;\n buf[pos++] = c >> 12 & 63 | 128;\n }\n buf[pos++] = c >> 6 & 63 | 128;\n }\n buf[pos++] = c & 63 | 128;\n }\n }\n return pos;\n}\n\nvar border = 3;\nfunction readFontstacks(tag, glyphs, pbf) {\n if (tag === 1) {\n pbf.readMessage(readFontstack, glyphs);\n }\n}\nfunction readFontstack(tag, glyphs, pbf) {\n if (tag === 3) {\n var ref = pbf.readMessage(readGlyph, {});\n var id = ref.id;\n var bitmap = ref.bitmap;\n var width = ref.width;\n var height = ref.height;\n var left = ref.left;\n var top = ref.top;\n var advance = ref.advance;\n glyphs.push({\n id: id,\n bitmap: new AlphaImage({\n width: width + 2 * border,\n height: height + 2 * border\n }, bitmap),\n metrics: {\n width: width,\n height: height,\n left: left,\n top: top,\n advance: advance\n }\n });\n }\n}\nfunction readGlyph(tag, glyph, pbf) {\n if (tag === 1) {\n glyph.id = pbf.readVarint();\n } else if (tag === 2) {\n glyph.bitmap = pbf.readBytes();\n } else if (tag === 3) {\n glyph.width = pbf.readVarint();\n } else if (tag === 4) {\n glyph.height = pbf.readVarint();\n } else if (tag === 5) {\n glyph.left = pbf.readSVarint();\n } else if (tag === 6) {\n glyph.top = pbf.readSVarint();\n } else if (tag === 7) {\n glyph.advance = pbf.readVarint();\n }\n}\nfunction parseGlyphPBF (data) {\n return new pbf(data).readFields(readFontstacks, []);\n}\nvar GLYPH_PBF_BORDER = border;\n\nfunction potpack(boxes) {\n\n // calculate total box area and maximum box width\n var area = 0;\n var maxWidth = 0;\n\n for (var i$1 = 0, list = boxes; i$1 < list.length; i$1 += 1) {\n var box = list[i$1];\n\n area += box.w * box.h;\n maxWidth = Math.max(maxWidth, box.w);\n }\n\n // sort the boxes for insertion by height, descending\n boxes.sort(function (a, b) { return b.h - a.h; });\n\n // aim for a squarish resulting container,\n // slightly adjusted for sub-100% space utilization\n var startWidth = Math.max(Math.ceil(Math.sqrt(area / 0.95)), maxWidth);\n\n // start with a single empty space, unbounded at the bottom\n var spaces = [{x: 0, y: 0, w: startWidth, h: Infinity}];\n\n var width = 0;\n var height = 0;\n\n for (var i$2 = 0, list$1 = boxes; i$2 < list$1.length; i$2 += 1) {\n // look through spaces backwards so that we check smaller spaces first\n var box$1 = list$1[i$2];\n\n for (var i = spaces.length - 1; i >= 0; i--) {\n var space = spaces[i];\n\n // look for empty spaces that can accommodate the current box\n if (box$1.w > space.w || box$1.h > space.h) { continue; }\n\n // found the space; add the box to its top-left corner\n // |-------|-------|\n // | box | |\n // |_______| |\n // | space |\n // |_______________|\n box$1.x = space.x;\n box$1.y = space.y;\n\n height = Math.max(height, box$1.y + box$1.h);\n width = Math.max(width, box$1.x + box$1.w);\n\n if (box$1.w === space.w && box$1.h === space.h) {\n // space matches the box exactly; remove it\n var last = spaces.pop();\n if (i < spaces.length) { spaces[i] = last; }\n\n } else if (box$1.h === space.h) {\n // space matches the box height; update it accordingly\n // |-------|---------------|\n // | box | updated space |\n // |_______|_______________|\n space.x += box$1.w;\n space.w -= box$1.w;\n\n } else if (box$1.w === space.w) {\n // space matches the box width; update it accordingly\n // |---------------|\n // | box |\n // |_______________|\n // | updated space |\n // |_______________|\n space.y += box$1.h;\n space.h -= box$1.h;\n\n } else {\n // otherwise the box splits the space into two spaces\n // |-------|-----------|\n // | box | new space |\n // |_______|___________|\n // | updated space |\n // |___________________|\n spaces.push({\n x: space.x + box$1.w,\n y: space.y,\n w: space.w - box$1.w,\n h: box$1.h\n });\n space.y += box$1.h;\n space.h -= box$1.h;\n }\n break;\n }\n }\n\n return {\n w: width, // container width\n h: height, // container height\n fill: (area / (width * height)) || 0 // space utilization\n };\n}\n\nvar IMAGE_PADDING = 1;\nvar ImagePosition = function ImagePosition(paddedRect, ref) {\n var pixelRatio = ref.pixelRatio;\n var version = ref.version;\n var stretchX = ref.stretchX;\n var stretchY = ref.stretchY;\n var content = ref.content;\n this.paddedRect = paddedRect;\n this.pixelRatio = pixelRatio;\n this.stretchX = stretchX;\n this.stretchY = stretchY;\n this.content = content;\n this.version = version;\n};\nvar prototypeAccessors = {\n tl: { configurable: true },\n br: { configurable: true },\n tlbr: { configurable: true },\n displaySize: { configurable: true }\n};\nprototypeAccessors.tl.get = function () {\n return [\n this.paddedRect.x + IMAGE_PADDING,\n this.paddedRect.y + IMAGE_PADDING\n ];\n};\nprototypeAccessors.br.get = function () {\n return [\n this.paddedRect.x + this.paddedRect.w - IMAGE_PADDING,\n this.paddedRect.y + this.paddedRect.h - IMAGE_PADDING\n ];\n};\nprototypeAccessors.tlbr.get = function () {\n return this.tl.concat(this.br);\n};\nprototypeAccessors.displaySize.get = function () {\n return [\n (this.paddedRect.w - IMAGE_PADDING * 2) / this.pixelRatio,\n (this.paddedRect.h - IMAGE_PADDING * 2) / this.pixelRatio\n ];\n};\nObject.defineProperties(ImagePosition.prototype, prototypeAccessors);\nvar ImageAtlas = function ImageAtlas(icons, patterns) {\n var iconPositions = {}, patternPositions = {};\n this.haveRenderCallbacks = [];\n var bins = [];\n this.addImages(icons, iconPositions, bins);\n this.addImages(patterns, patternPositions, bins);\n var ref = potpack(bins);\n var w = ref.w;\n var h = ref.h;\n var image = new RGBAImage({\n width: w || 1,\n height: h || 1\n });\n for (var id in icons) {\n var src = icons[id];\n var bin = iconPositions[id].paddedRect;\n RGBAImage.copy(src.data, image, {\n x: 0,\n y: 0\n }, {\n x: bin.x + IMAGE_PADDING,\n y: bin.y + IMAGE_PADDING\n }, src.data);\n }\n for (var id$1 in patterns) {\n var src$1 = patterns[id$1];\n var bin$1 = patternPositions[id$1].paddedRect;\n var x = bin$1.x + IMAGE_PADDING, y = bin$1.y + IMAGE_PADDING, w$1 = src$1.data.width, h$1 = src$1.data.height;\n RGBAImage.copy(src$1.data, image, {\n x: 0,\n y: 0\n }, {\n x: x,\n y: y\n }, src$1.data);\n RGBAImage.copy(src$1.data, image, {\n x: 0,\n y: h$1 - 1\n }, {\n x: x,\n y: y - 1\n }, {\n width: w$1,\n height: 1\n });\n RGBAImage.copy(src$1.data, image, {\n x: 0,\n y: 0\n }, {\n x: x,\n y: y + h$1\n }, {\n width: w$1,\n height: 1\n });\n RGBAImage.copy(src$1.data, image, {\n x: w$1 - 1,\n y: 0\n }, {\n x: x - 1,\n y: y\n }, {\n width: 1,\n height: h$1\n });\n RGBAImage.copy(src$1.data, image, {\n x: 0,\n y: 0\n }, {\n x: x + w$1,\n y: y\n }, {\n width: 1,\n height: h$1\n });\n }\n this.image = image;\n this.iconPositions = iconPositions;\n this.patternPositions = patternPositions;\n};\nImageAtlas.prototype.addImages = function addImages(images, positions, bins) {\n for (var id in images) {\n var src = images[id];\n var bin = {\n x: 0,\n y: 0,\n w: src.data.width + 2 * IMAGE_PADDING,\n h: src.data.height + 2 * IMAGE_PADDING\n };\n bins.push(bin);\n positions[id] = new ImagePosition(bin, src);\n if (src.hasRenderCallback) {\n this.haveRenderCallbacks.push(id);\n }\n }\n};\nImageAtlas.prototype.patchUpdatedImages = function patchUpdatedImages(imageManager, texture) {\n imageManager.dispatchRenderCallbacks(this.haveRenderCallbacks);\n for (var name in imageManager.updatedImages) {\n this.patchUpdatedImage(this.iconPositions[name], imageManager.getImage(name), texture);\n this.patchUpdatedImage(this.patternPositions[name], imageManager.getImage(name), texture);\n }\n};\nImageAtlas.prototype.patchUpdatedImage = function patchUpdatedImage(position, image, texture) {\n if (!position || !image) {\n return;\n }\n if (position.version === image.version) {\n return;\n }\n position.version = image.version;\n var ref = position.tl;\n var x = ref[0];\n var y = ref[1];\n texture.update(image.data, undefined, {\n x: x,\n y: y\n });\n};\nregister('ImagePosition', ImagePosition);\nregister('ImageAtlas', ImageAtlas);\n\nvar WritingMode = {\n horizontal: 1,\n vertical: 2,\n horizontalOnly: 3\n};\nvar SHAPING_DEFAULT_OFFSET = -17;\nfunction isEmpty(positionedLines) {\n for (var i = 0, list = positionedLines; i < list.length; i += 1) {\n var line = list[i];\n if (line.positionedGlyphs.length !== 0) {\n return false;\n }\n }\n return true;\n}\nvar PUAbegin = 57344;\nvar PUAend = 63743;\nvar SectionOptions = function SectionOptions() {\n this.scale = 1;\n this.fontStack = '';\n this.imageName = null;\n};\nSectionOptions.forText = function forText(scale, fontStack) {\n var textOptions = new SectionOptions();\n textOptions.scale = scale || 1;\n textOptions.fontStack = fontStack;\n return textOptions;\n};\nSectionOptions.forImage = function forImage(imageName) {\n var imageOptions = new SectionOptions();\n imageOptions.imageName = imageName;\n return imageOptions;\n};\nvar TaggedString = function TaggedString() {\n this.text = '';\n this.sectionIndex = [];\n this.sections = [];\n this.imageSectionID = null;\n};\nTaggedString.fromFeature = function fromFeature(text, defaultFontStack) {\n var result = new TaggedString();\n for (var i = 0; i < text.sections.length; i++) {\n var section = text.sections[i];\n if (!section.image) {\n result.addTextSection(section, defaultFontStack);\n } else {\n result.addImageSection(section);\n }\n }\n return result;\n};\nTaggedString.prototype.length = function length() {\n return this.text.length;\n};\nTaggedString.prototype.getSection = function getSection(index) {\n return this.sections[this.sectionIndex[index]];\n};\nTaggedString.prototype.getSectionIndex = function getSectionIndex(index) {\n return this.sectionIndex[index];\n};\nTaggedString.prototype.getCharCode = function getCharCode(index) {\n return this.text.charCodeAt(index);\n};\nTaggedString.prototype.verticalizePunctuation = function verticalizePunctuation$1() {\n this.text = verticalizePunctuation(this.text);\n};\nTaggedString.prototype.trim = function trim() {\n var beginningWhitespace = 0;\n for (var i = 0; i < this.text.length && whitespace[this.text.charCodeAt(i)]; i++) {\n beginningWhitespace++;\n }\n var trailingWhitespace = this.text.length;\n for (var i$1 = this.text.length - 1; i$1 >= 0 && i$1 >= beginningWhitespace && whitespace[this.text.charCodeAt(i$1)]; i$1--) {\n trailingWhitespace--;\n }\n this.text = this.text.substring(beginningWhitespace, trailingWhitespace);\n this.sectionIndex = this.sectionIndex.slice(beginningWhitespace, trailingWhitespace);\n};\nTaggedString.prototype.substring = function substring(start, end) {\n var substring = new TaggedString();\n substring.text = this.text.substring(start, end);\n substring.sectionIndex = this.sectionIndex.slice(start, end);\n substring.sections = this.sections;\n return substring;\n};\nTaggedString.prototype.toString = function toString() {\n return this.text;\n};\nTaggedString.prototype.getMaxScale = function getMaxScale() {\n var this$1 = this;\n return this.sectionIndex.reduce(function (max, index) {\n return Math.max(max, this$1.sections[index].scale);\n }, 0);\n};\nTaggedString.prototype.addTextSection = function addTextSection(section, defaultFontStack) {\n this.text += section.text;\n this.sections.push(SectionOptions.forText(section.scale, section.fontStack || defaultFontStack));\n var index = this.sections.length - 1;\n for (var i = 0; i < section.text.length; ++i) {\n this.sectionIndex.push(index);\n }\n};\nTaggedString.prototype.addImageSection = function addImageSection(section) {\n var imageName = section.image ? section.image.name : '';\n if (imageName.length === 0) {\n warnOnce('Can\\'t add FormattedSection with an empty image.');\n return;\n }\n var nextImageSectionCharCode = this.getNextImageSectionCharCode();\n if (!nextImageSectionCharCode) {\n warnOnce('Reached maximum number of images ' + (PUAend - PUAbegin + 2));\n return;\n }\n this.text += String.fromCharCode(nextImageSectionCharCode);\n this.sections.push(SectionOptions.forImage(imageName));\n this.sectionIndex.push(this.sections.length - 1);\n};\nTaggedString.prototype.getNextImageSectionCharCode = function getNextImageSectionCharCode() {\n if (!this.imageSectionID) {\n this.imageSectionID = PUAbegin;\n return this.imageSectionID;\n }\n if (this.imageSectionID >= PUAend) {\n return null;\n }\n return ++this.imageSectionID;\n};\nfunction breakLines(input, lineBreakPoints) {\n var lines = [];\n var text = input.text;\n var start = 0;\n for (var i = 0, list = lineBreakPoints; i < list.length; i += 1) {\n var lineBreak = list[i];\n lines.push(input.substring(start, lineBreak));\n start = lineBreak;\n }\n if (start < text.length) {\n lines.push(input.substring(start, text.length));\n }\n return lines;\n}\nfunction shapeText(text, glyphMap, glyphPositions, imagePositions, defaultFontStack, maxWidth, lineHeight, textAnchor, textJustify, spacing, translate, writingMode, allowVerticalPlacement, symbolPlacement, layoutTextSize, layoutTextSizeThisZoom) {\n var logicalInput = TaggedString.fromFeature(text, defaultFontStack);\n if (writingMode === WritingMode.vertical) {\n logicalInput.verticalizePunctuation();\n }\n var lines;\n var processBidirectionalText = plugin.processBidirectionalText;\n var processStyledBidirectionalText = plugin.processStyledBidirectionalText;\n if (processBidirectionalText && logicalInput.sections.length === 1) {\n lines = [];\n var untaggedLines = processBidirectionalText(logicalInput.toString(), determineLineBreaks(logicalInput, spacing, maxWidth, glyphMap, imagePositions, symbolPlacement, layoutTextSize));\n for (var i$1 = 0, list = untaggedLines; i$1 < list.length; i$1 += 1) {\n var line = list[i$1];\n var taggedLine = new TaggedString();\n taggedLine.text = line;\n taggedLine.sections = logicalInput.sections;\n for (var i = 0; i < line.length; i++) {\n taggedLine.sectionIndex.push(0);\n }\n lines.push(taggedLine);\n }\n } else if (processStyledBidirectionalText) {\n lines = [];\n var processedLines = processStyledBidirectionalText(logicalInput.text, logicalInput.sectionIndex, determineLineBreaks(logicalInput, spacing, maxWidth, glyphMap, imagePositions, symbolPlacement, layoutTextSize));\n for (var i$2 = 0, list$1 = processedLines; i$2 < list$1.length; i$2 += 1) {\n var line$1 = list$1[i$2];\n var taggedLine$1 = new TaggedString();\n taggedLine$1.text = line$1[0];\n taggedLine$1.sectionIndex = line$1[1];\n taggedLine$1.sections = logicalInput.sections;\n lines.push(taggedLine$1);\n }\n } else {\n lines = breakLines(logicalInput, determineLineBreaks(logicalInput, spacing, maxWidth, glyphMap, imagePositions, symbolPlacement, layoutTextSize));\n }\n var positionedLines = [];\n var shaping = {\n positionedLines: positionedLines,\n text: logicalInput.toString(),\n top: translate[1],\n bottom: translate[1],\n left: translate[0],\n right: translate[0],\n writingMode: writingMode,\n iconsInText: false,\n verticalizable: false\n };\n shapeLines(shaping, glyphMap, glyphPositions, imagePositions, lines, lineHeight, textAnchor, textJustify, writingMode, spacing, allowVerticalPlacement, layoutTextSizeThisZoom);\n if (isEmpty(positionedLines)) {\n return false;\n }\n return shaping;\n}\nvar whitespace = {};\nwhitespace[9] = true;\nwhitespace[10] = true;\nwhitespace[11] = true;\nwhitespace[12] = true;\nwhitespace[13] = true;\nwhitespace[32] = true;\nvar breakable = {};\nbreakable[10] = true;\nbreakable[32] = true;\nbreakable[38] = true;\nbreakable[40] = true;\nbreakable[41] = true;\nbreakable[43] = true;\nbreakable[45] = true;\nbreakable[47] = true;\nbreakable[173] = true;\nbreakable[183] = true;\nbreakable[8203] = true;\nbreakable[8208] = true;\nbreakable[8211] = true;\nbreakable[8231] = true;\nfunction getGlyphAdvance(codePoint, section, glyphMap, imagePositions, spacing, layoutTextSize) {\n if (!section.imageName) {\n var positions = glyphMap[section.fontStack];\n var glyph = positions && positions[codePoint];\n if (!glyph) {\n return 0;\n }\n return glyph.metrics.advance * section.scale + spacing;\n } else {\n var imagePosition = imagePositions[section.imageName];\n if (!imagePosition) {\n return 0;\n }\n return imagePosition.displaySize[0] * section.scale * ONE_EM / layoutTextSize + spacing;\n }\n}\nfunction determineAverageLineWidth(logicalInput, spacing, maxWidth, glyphMap, imagePositions, layoutTextSize) {\n var totalWidth = 0;\n for (var index = 0; index < logicalInput.length(); index++) {\n var section = logicalInput.getSection(index);\n totalWidth += getGlyphAdvance(logicalInput.getCharCode(index), section, glyphMap, imagePositions, spacing, layoutTextSize);\n }\n var lineCount = Math.max(1, Math.ceil(totalWidth / maxWidth));\n return totalWidth / lineCount;\n}\nfunction calculateBadness(lineWidth, targetWidth, penalty, isLastBreak) {\n var raggedness = Math.pow(lineWidth - targetWidth, 2);\n if (isLastBreak) {\n if (lineWidth < targetWidth) {\n return raggedness / 2;\n } else {\n return raggedness * 2;\n }\n }\n return raggedness + Math.abs(penalty) * penalty;\n}\nfunction calculatePenalty(codePoint, nextCodePoint, penalizableIdeographicBreak) {\n var penalty = 0;\n if (codePoint === 10) {\n penalty -= 10000;\n }\n if (penalizableIdeographicBreak) {\n penalty += 150;\n }\n if (codePoint === 40 || codePoint === 65288) {\n penalty += 50;\n }\n if (nextCodePoint === 41 || nextCodePoint === 65289) {\n penalty += 50;\n }\n return penalty;\n}\nfunction evaluateBreak(breakIndex, breakX, targetWidth, potentialBreaks, penalty, isLastBreak) {\n var bestPriorBreak = null;\n var bestBreakBadness = calculateBadness(breakX, targetWidth, penalty, isLastBreak);\n for (var i = 0, list = potentialBreaks; i < list.length; i += 1) {\n var potentialBreak = list[i];\n var lineWidth = breakX - potentialBreak.x;\n var breakBadness = calculateBadness(lineWidth, targetWidth, penalty, isLastBreak) + potentialBreak.badness;\n if (breakBadness <= bestBreakBadness) {\n bestPriorBreak = potentialBreak;\n bestBreakBadness = breakBadness;\n }\n }\n return {\n index: breakIndex,\n x: breakX,\n priorBreak: bestPriorBreak,\n badness: bestBreakBadness\n };\n}\nfunction leastBadBreaks(lastLineBreak) {\n if (!lastLineBreak) {\n return [];\n }\n return leastBadBreaks(lastLineBreak.priorBreak).concat(lastLineBreak.index);\n}\nfunction determineLineBreaks(logicalInput, spacing, maxWidth, glyphMap, imagePositions, symbolPlacement, layoutTextSize) {\n if (symbolPlacement !== 'point') {\n return [];\n }\n if (!logicalInput) {\n return [];\n }\n var potentialLineBreaks = [];\n var targetWidth = determineAverageLineWidth(logicalInput, spacing, maxWidth, glyphMap, imagePositions, layoutTextSize);\n var hasServerSuggestedBreakpoints = logicalInput.text.indexOf('\\u200B') >= 0;\n var currentX = 0;\n for (var i = 0; i < logicalInput.length(); i++) {\n var section = logicalInput.getSection(i);\n var codePoint = logicalInput.getCharCode(i);\n if (!whitespace[codePoint]) {\n currentX += getGlyphAdvance(codePoint, section, glyphMap, imagePositions, spacing, layoutTextSize);\n }\n if (i < logicalInput.length() - 1) {\n var ideographicBreak = charAllowsIdeographicBreaking(codePoint);\n if (breakable[codePoint] || ideographicBreak || section.imageName) {\n potentialLineBreaks.push(evaluateBreak(i + 1, currentX, targetWidth, potentialLineBreaks, calculatePenalty(codePoint, logicalInput.getCharCode(i + 1), ideographicBreak && hasServerSuggestedBreakpoints), false));\n }\n }\n }\n return leastBadBreaks(evaluateBreak(logicalInput.length(), currentX, targetWidth, potentialLineBreaks, 0, true));\n}\nfunction getAnchorAlignment(anchor) {\n var horizontalAlign = 0.5, verticalAlign = 0.5;\n switch (anchor) {\n case 'right':\n case 'top-right':\n case 'bottom-right':\n horizontalAlign = 1;\n break;\n case 'left':\n case 'top-left':\n case 'bottom-left':\n horizontalAlign = 0;\n break;\n }\n switch (anchor) {\n case 'bottom':\n case 'bottom-right':\n case 'bottom-left':\n verticalAlign = 1;\n break;\n case 'top':\n case 'top-right':\n case 'top-left':\n verticalAlign = 0;\n break;\n }\n return {\n horizontalAlign: horizontalAlign,\n verticalAlign: verticalAlign\n };\n}\nfunction shapeLines(shaping, glyphMap, glyphPositions, imagePositions, lines, lineHeight, textAnchor, textJustify, writingMode, spacing, allowVerticalPlacement, layoutTextSizeThisZoom) {\n var x = 0;\n var y = SHAPING_DEFAULT_OFFSET;\n var maxLineLength = 0;\n var maxLineHeight = 0;\n var justify = textJustify === 'right' ? 1 : textJustify === 'left' ? 0 : 0.5;\n var lineIndex = 0;\n for (var i$1 = 0, list = lines; i$1 < list.length; i$1 += 1) {\n var line = list[i$1];\n line.trim();\n var lineMaxScale = line.getMaxScale();\n var maxLineOffset = (lineMaxScale - 1) * ONE_EM;\n var positionedLine = {\n positionedGlyphs: [],\n lineOffset: 0\n };\n shaping.positionedLines[lineIndex] = positionedLine;\n var positionedGlyphs = positionedLine.positionedGlyphs;\n var lineOffset = 0;\n if (!line.length()) {\n y += lineHeight;\n ++lineIndex;\n continue;\n }\n for (var i = 0; i < line.length(); i++) {\n var section = line.getSection(i);\n var sectionIndex = line.getSectionIndex(i);\n var codePoint = line.getCharCode(i);\n var baselineOffset = 0;\n var metrics = null;\n var rect = null;\n var imageName = null;\n var verticalAdvance = ONE_EM;\n var vertical = !(writingMode === WritingMode.horizontal || !allowVerticalPlacement && !charHasUprightVerticalOrientation(codePoint) || allowVerticalPlacement && (whitespace[codePoint] || charInComplexShapingScript(codePoint)));\n if (!section.imageName) {\n var positions = glyphPositions[section.fontStack];\n var glyphPosition = positions && positions[codePoint];\n if (glyphPosition && glyphPosition.rect) {\n rect = glyphPosition.rect;\n metrics = glyphPosition.metrics;\n } else {\n var glyphs = glyphMap[section.fontStack];\n var glyph = glyphs && glyphs[codePoint];\n if (!glyph) {\n continue;\n }\n metrics = glyph.metrics;\n }\n baselineOffset = (lineMaxScale - section.scale) * ONE_EM;\n } else {\n var imagePosition = imagePositions[section.imageName];\n if (!imagePosition) {\n continue;\n }\n imageName = section.imageName;\n shaping.iconsInText = shaping.iconsInText || true;\n rect = imagePosition.paddedRect;\n var size = imagePosition.displaySize;\n section.scale = section.scale * ONE_EM / layoutTextSizeThisZoom;\n metrics = {\n width: size[0],\n height: size[1],\n left: IMAGE_PADDING,\n top: -GLYPH_PBF_BORDER,\n advance: vertical ? size[1] : size[0]\n };\n var imageOffset = ONE_EM - size[1] * section.scale;\n baselineOffset = maxLineOffset + imageOffset;\n verticalAdvance = metrics.advance;\n var offset = vertical ? size[0] * section.scale - ONE_EM * lineMaxScale : size[1] * section.scale - ONE_EM * lineMaxScale;\n if (offset > 0 && offset > lineOffset) {\n lineOffset = offset;\n }\n }\n if (!vertical) {\n positionedGlyphs.push({\n glyph: codePoint,\n imageName: imageName,\n x: x,\n y: y + baselineOffset,\n vertical: vertical,\n scale: section.scale,\n fontStack: section.fontStack,\n sectionIndex: sectionIndex,\n metrics: metrics,\n rect: rect\n });\n x += metrics.advance * section.scale + spacing;\n } else {\n shaping.verticalizable = true;\n positionedGlyphs.push({\n glyph: codePoint,\n imageName: imageName,\n x: x,\n y: y + baselineOffset,\n vertical: vertical,\n scale: section.scale,\n fontStack: section.fontStack,\n sectionIndex: sectionIndex,\n metrics: metrics,\n rect: rect\n });\n x += verticalAdvance * section.scale + spacing;\n }\n }\n if (positionedGlyphs.length !== 0) {\n var lineLength = x - spacing;\n maxLineLength = Math.max(lineLength, maxLineLength);\n justifyLine(positionedGlyphs, 0, positionedGlyphs.length - 1, justify, lineOffset);\n }\n x = 0;\n var currentLineHeight = lineHeight * lineMaxScale + lineOffset;\n positionedLine.lineOffset = Math.max(lineOffset, maxLineOffset);\n y += currentLineHeight;\n maxLineHeight = Math.max(currentLineHeight, maxLineHeight);\n ++lineIndex;\n }\n var height = y - SHAPING_DEFAULT_OFFSET;\n var ref = getAnchorAlignment(textAnchor);\n var horizontalAlign = ref.horizontalAlign;\n var verticalAlign = ref.verticalAlign;\n align$1(shaping.positionedLines, justify, horizontalAlign, verticalAlign, maxLineLength, maxLineHeight, lineHeight, height, lines.length);\n shaping.top += -verticalAlign * height;\n shaping.bottom = shaping.top + height;\n shaping.left += -horizontalAlign * maxLineLength;\n shaping.right = shaping.left + maxLineLength;\n}\nfunction justifyLine(positionedGlyphs, start, end, justify, lineOffset) {\n if (!justify && !lineOffset) {\n return;\n }\n var lastPositionedGlyph = positionedGlyphs[end];\n var lastAdvance = lastPositionedGlyph.metrics.advance * lastPositionedGlyph.scale;\n var lineIndent = (positionedGlyphs[end].x + lastAdvance) * justify;\n for (var j = start; j <= end; j++) {\n positionedGlyphs[j].x -= lineIndent;\n positionedGlyphs[j].y += lineOffset;\n }\n}\nfunction align$1(positionedLines, justify, horizontalAlign, verticalAlign, maxLineLength, maxLineHeight, lineHeight, blockHeight, lineCount) {\n var shiftX = (justify - horizontalAlign) * maxLineLength;\n var shiftY = 0;\n if (maxLineHeight !== lineHeight) {\n shiftY = -blockHeight * verticalAlign - SHAPING_DEFAULT_OFFSET;\n } else {\n shiftY = (-verticalAlign * lineCount + 0.5) * lineHeight;\n }\n for (var i$1 = 0, list$1 = positionedLines; i$1 < list$1.length; i$1 += 1) {\n var line = list$1[i$1];\n for (var i = 0, list = line.positionedGlyphs; i < list.length; i += 1) {\n var positionedGlyph = list[i];\n positionedGlyph.x += shiftX;\n positionedGlyph.y += shiftY;\n }\n }\n}\nfunction shapeIcon(image, iconOffset, iconAnchor) {\n var ref = getAnchorAlignment(iconAnchor);\n var horizontalAlign = ref.horizontalAlign;\n var verticalAlign = ref.verticalAlign;\n var dx = iconOffset[0];\n var dy = iconOffset[1];\n var x1 = dx - image.displaySize[0] * horizontalAlign;\n var x2 = x1 + image.displaySize[0];\n var y1 = dy - image.displaySize[1] * verticalAlign;\n var y2 = y1 + image.displaySize[1];\n return {\n image: image,\n top: y1,\n bottom: y2,\n left: x1,\n right: x2\n };\n}\nfunction fitIconToText(shapedIcon, shapedText, textFit, padding, iconOffset, fontScale) {\n var image = shapedIcon.image;\n var collisionPadding;\n if (image.content) {\n var content = image.content;\n var pixelRatio = image.pixelRatio || 1;\n collisionPadding = [\n content[0] / pixelRatio,\n content[1] / pixelRatio,\n image.displaySize[0] - content[2] / pixelRatio,\n image.displaySize[1] - content[3] / pixelRatio\n ];\n }\n var textLeft = shapedText.left * fontScale;\n var textRight = shapedText.right * fontScale;\n var top, right, bottom, left;\n if (textFit === 'width' || textFit === 'both') {\n left = iconOffset[0] + textLeft - padding[3];\n right = iconOffset[0] + textRight + padding[1];\n } else {\n left = iconOffset[0] + (textLeft + textRight - image.displaySize[0]) / 2;\n right = left + image.displaySize[0];\n }\n var textTop = shapedText.top * fontScale;\n var textBottom = shapedText.bottom * fontScale;\n if (textFit === 'height' || textFit === 'both') {\n top = iconOffset[1] + textTop - padding[0];\n bottom = iconOffset[1] + textBottom + padding[2];\n } else {\n top = iconOffset[1] + (textTop + textBottom - image.displaySize[1]) / 2;\n bottom = top + image.displaySize[1];\n }\n return {\n image: image,\n top: top,\n right: right,\n bottom: bottom,\n left: left,\n collisionPadding: collisionPadding\n };\n}\n\nvar Anchor = function (Point) {\n function Anchor(x, y, angle, segment) {\n Point.call(this, x, y);\n this.angle = angle;\n if (segment !== undefined) {\n this.segment = segment;\n }\n }\n if (Point)\n Anchor.__proto__ = Point;\n Anchor.prototype = Object.create(Point && Point.prototype);\n Anchor.prototype.constructor = Anchor;\n Anchor.prototype.clone = function clone() {\n return new Anchor(this.x, this.y, this.angle, this.segment);\n };\n return Anchor;\n}(pointGeometry);\nregister('Anchor', Anchor);\n\nvar SIZE_PACK_FACTOR = 128;\nfunction getSizeData(tileZoom, value) {\n var expression = value.expression;\n if (expression.kind === 'constant') {\n var layoutSize = expression.evaluate(new EvaluationParameters(tileZoom + 1));\n return {\n kind: 'constant',\n layoutSize: layoutSize\n };\n } else if (expression.kind === 'source') {\n return { kind: 'source' };\n } else {\n var zoomStops = expression.zoomStops;\n var interpolationType = expression.interpolationType;\n var lower = 0;\n while (lower < zoomStops.length && zoomStops[lower] <= tileZoom) {\n lower++;\n }\n lower = Math.max(0, lower - 1);\n var upper = lower;\n while (upper < zoomStops.length && zoomStops[upper] < tileZoom + 1) {\n upper++;\n }\n upper = Math.min(zoomStops.length - 1, upper);\n var minZoom = zoomStops[lower];\n var maxZoom = zoomStops[upper];\n if (expression.kind === 'composite') {\n return {\n kind: 'composite',\n minZoom: minZoom,\n maxZoom: maxZoom,\n interpolationType: interpolationType\n };\n }\n var minSize = expression.evaluate(new EvaluationParameters(minZoom));\n var maxSize = expression.evaluate(new EvaluationParameters(maxZoom));\n return {\n kind: 'camera',\n minZoom: minZoom,\n maxZoom: maxZoom,\n minSize: minSize,\n maxSize: maxSize,\n interpolationType: interpolationType\n };\n }\n}\nfunction evaluateSizeForFeature(sizeData, ref, ref$1) {\n var uSize = ref.uSize;\n var uSizeT = ref.uSizeT;\n var lowerSize = ref$1.lowerSize;\n var upperSize = ref$1.upperSize;\n if (sizeData.kind === 'source') {\n return lowerSize / SIZE_PACK_FACTOR;\n } else if (sizeData.kind === 'composite') {\n return number(lowerSize / SIZE_PACK_FACTOR, upperSize / SIZE_PACK_FACTOR, uSizeT);\n }\n return uSize;\n}\nfunction evaluateSizeForZoom(sizeData, zoom) {\n var uSizeT = 0;\n var uSize = 0;\n if (sizeData.kind === 'constant') {\n uSize = sizeData.layoutSize;\n } else if (sizeData.kind !== 'source') {\n var interpolationType = sizeData.interpolationType;\n var minZoom = sizeData.minZoom;\n var maxZoom = sizeData.maxZoom;\n var t = !interpolationType ? 0 : clamp(Interpolate.interpolationFactor(interpolationType, zoom, minZoom, maxZoom), 0, 1);\n if (sizeData.kind === 'camera') {\n uSize = number(sizeData.minSize, sizeData.maxSize, t);\n } else {\n uSizeT = t;\n }\n }\n return {\n uSizeT: uSizeT,\n uSize: uSize\n };\n}\n\nvar symbolSize = /*#__PURE__*/Object.freeze({\n__proto__: null,\ngetSizeData: getSizeData,\nevaluateSizeForFeature: evaluateSizeForFeature,\nevaluateSizeForZoom: evaluateSizeForZoom,\nSIZE_PACK_FACTOR: SIZE_PACK_FACTOR\n});\n\nfunction checkMaxAngle(line, anchor, labelLength, windowSize, maxAngle) {\n if (anchor.segment === undefined) {\n return true;\n }\n var p = anchor;\n var index = anchor.segment + 1;\n var anchorDistance = 0;\n while (anchorDistance > -labelLength / 2) {\n index--;\n if (index < 0) {\n return false;\n }\n anchorDistance -= line[index].dist(p);\n p = line[index];\n }\n anchorDistance += line[index].dist(line[index + 1]);\n index++;\n var recentCorners = [];\n var recentAngleDelta = 0;\n while (anchorDistance < labelLength / 2) {\n var prev = line[index - 1];\n var current = line[index];\n var next = line[index + 1];\n if (!next) {\n return false;\n }\n var angleDelta = prev.angleTo(current) - current.angleTo(next);\n angleDelta = Math.abs((angleDelta + 3 * Math.PI) % (Math.PI * 2) - Math.PI);\n recentCorners.push({\n distance: anchorDistance,\n angleDelta: angleDelta\n });\n recentAngleDelta += angleDelta;\n while (anchorDistance - recentCorners[0].distance > windowSize) {\n recentAngleDelta -= recentCorners.shift().angleDelta;\n }\n if (recentAngleDelta > maxAngle) {\n return false;\n }\n index++;\n anchorDistance += current.dist(next);\n }\n return true;\n}\n\nfunction getLineLength(line) {\n var lineLength = 0;\n for (var k = 0; k < line.length - 1; k++) {\n lineLength += line[k].dist(line[k + 1]);\n }\n return lineLength;\n}\nfunction getAngleWindowSize(shapedText, glyphSize, boxScale) {\n return shapedText ? 3 / 5 * glyphSize * boxScale : 0;\n}\nfunction getShapedLabelLength(shapedText, shapedIcon) {\n return Math.max(shapedText ? shapedText.right - shapedText.left : 0, shapedIcon ? shapedIcon.right - shapedIcon.left : 0);\n}\nfunction getCenterAnchor(line, maxAngle, shapedText, shapedIcon, glyphSize, boxScale) {\n var angleWindowSize = getAngleWindowSize(shapedText, glyphSize, boxScale);\n var labelLength = getShapedLabelLength(shapedText, shapedIcon) * boxScale;\n var prevDistance = 0;\n var centerDistance = getLineLength(line) / 2;\n for (var i = 0; i < line.length - 1; i++) {\n var a = line[i], b = line[i + 1];\n var segmentDistance = a.dist(b);\n if (prevDistance + segmentDistance > centerDistance) {\n var t = (centerDistance - prevDistance) / segmentDistance, x = number(a.x, b.x, t), y = number(a.y, b.y, t);\n var anchor = new Anchor(x, y, b.angleTo(a), i);\n anchor._round();\n if (!angleWindowSize || checkMaxAngle(line, anchor, labelLength, angleWindowSize, maxAngle)) {\n return anchor;\n } else {\n return;\n }\n }\n prevDistance += segmentDistance;\n }\n}\nfunction getAnchors(line, spacing, maxAngle, shapedText, shapedIcon, glyphSize, boxScale, overscaling, tileExtent) {\n var angleWindowSize = getAngleWindowSize(shapedText, glyphSize, boxScale);\n var shapedLabelLength = getShapedLabelLength(shapedText, shapedIcon);\n var labelLength = shapedLabelLength * boxScale;\n var isLineContinued = line[0].x === 0 || line[0].x === tileExtent || line[0].y === 0 || line[0].y === tileExtent;\n if (spacing - labelLength < spacing / 4) {\n spacing = labelLength + spacing / 4;\n }\n var fixedExtraOffset = glyphSize * 2;\n var offset = !isLineContinued ? (shapedLabelLength / 2 + fixedExtraOffset) * boxScale * overscaling % spacing : spacing / 2 * overscaling % spacing;\n return resample(line, offset, spacing, angleWindowSize, maxAngle, labelLength, isLineContinued, false, tileExtent);\n}\nfunction resample(line, offset, spacing, angleWindowSize, maxAngle, labelLength, isLineContinued, placeAtMiddle, tileExtent) {\n var halfLabelLength = labelLength / 2;\n var lineLength = getLineLength(line);\n var distance = 0, markedDistance = offset - spacing;\n var anchors = [];\n for (var i = 0; i < line.length - 1; i++) {\n var a = line[i], b = line[i + 1];\n var segmentDist = a.dist(b), angle = b.angleTo(a);\n while (markedDistance + spacing < distance + segmentDist) {\n markedDistance += spacing;\n var t = (markedDistance - distance) / segmentDist, x = number(a.x, b.x, t), y = number(a.y, b.y, t);\n if (x >= 0 && x < tileExtent && y >= 0 && y < tileExtent && markedDistance - halfLabelLength >= 0 && markedDistance + halfLabelLength <= lineLength) {\n var anchor = new Anchor(x, y, angle, i);\n anchor._round();\n if (!angleWindowSize || checkMaxAngle(line, anchor, labelLength, angleWindowSize, maxAngle)) {\n anchors.push(anchor);\n }\n }\n }\n distance += segmentDist;\n }\n if (!placeAtMiddle && !anchors.length && !isLineContinued) {\n anchors = resample(line, distance / 2, spacing, angleWindowSize, maxAngle, labelLength, isLineContinued, true, tileExtent);\n }\n return anchors;\n}\n\nfunction clipLine(lines, x1, y1, x2, y2) {\n var clippedLines = [];\n for (var l = 0; l < lines.length; l++) {\n var line = lines[l];\n var clippedLine = void 0;\n for (var i = 0; i < line.length - 1; i++) {\n var p0 = line[i];\n var p1 = line[i + 1];\n if (p0.x < x1 && p1.x < x1) {\n continue;\n } else if (p0.x < x1) {\n p0 = new pointGeometry(x1, p0.y + (p1.y - p0.y) * ((x1 - p0.x) / (p1.x - p0.x)))._round();\n } else if (p1.x < x1) {\n p1 = new pointGeometry(x1, p0.y + (p1.y - p0.y) * ((x1 - p0.x) / (p1.x - p0.x)))._round();\n }\n if (p0.y < y1 && p1.y < y1) {\n continue;\n } else if (p0.y < y1) {\n p0 = new pointGeometry(p0.x + (p1.x - p0.x) * ((y1 - p0.y) / (p1.y - p0.y)), y1)._round();\n } else if (p1.y < y1) {\n p1 = new pointGeometry(p0.x + (p1.x - p0.x) * ((y1 - p0.y) / (p1.y - p0.y)), y1)._round();\n }\n if (p0.x >= x2 && p1.x >= x2) {\n continue;\n } else if (p0.x >= x2) {\n p0 = new pointGeometry(x2, p0.y + (p1.y - p0.y) * ((x2 - p0.x) / (p1.x - p0.x)))._round();\n } else if (p1.x >= x2) {\n p1 = new pointGeometry(x2, p0.y + (p1.y - p0.y) * ((x2 - p0.x) / (p1.x - p0.x)))._round();\n }\n if (p0.y >= y2 && p1.y >= y2) {\n continue;\n } else if (p0.y >= y2) {\n p0 = new pointGeometry(p0.x + (p1.x - p0.x) * ((y2 - p0.y) / (p1.y - p0.y)), y2)._round();\n } else if (p1.y >= y2) {\n p1 = new pointGeometry(p0.x + (p1.x - p0.x) * ((y2 - p0.y) / (p1.y - p0.y)), y2)._round();\n }\n if (!clippedLine || !p0.equals(clippedLine[clippedLine.length - 1])) {\n clippedLine = [p0];\n clippedLines.push(clippedLine);\n }\n clippedLine.push(p1);\n }\n }\n return clippedLines;\n}\n\nvar border$1 = IMAGE_PADDING;\nfunction getIconQuads(shapedIcon, iconRotate, isSDFIcon, hasIconTextFit) {\n var quads = [];\n var image = shapedIcon.image;\n var pixelRatio = image.pixelRatio;\n var imageWidth = image.paddedRect.w - 2 * border$1;\n var imageHeight = image.paddedRect.h - 2 * border$1;\n var iconWidth = shapedIcon.right - shapedIcon.left;\n var iconHeight = shapedIcon.bottom - shapedIcon.top;\n var stretchX = image.stretchX || [[\n 0,\n imageWidth\n ]];\n var stretchY = image.stretchY || [[\n 0,\n imageHeight\n ]];\n var reduceRanges = function (sum, range) {\n return sum + range[1] - range[0];\n };\n var stretchWidth = stretchX.reduce(reduceRanges, 0);\n var stretchHeight = stretchY.reduce(reduceRanges, 0);\n var fixedWidth = imageWidth - stretchWidth;\n var fixedHeight = imageHeight - stretchHeight;\n var stretchOffsetX = 0;\n var stretchContentWidth = stretchWidth;\n var stretchOffsetY = 0;\n var stretchContentHeight = stretchHeight;\n var fixedOffsetX = 0;\n var fixedContentWidth = fixedWidth;\n var fixedOffsetY = 0;\n var fixedContentHeight = fixedHeight;\n if (image.content && hasIconTextFit) {\n var content = image.content;\n stretchOffsetX = sumWithinRange(stretchX, 0, content[0]);\n stretchOffsetY = sumWithinRange(stretchY, 0, content[1]);\n stretchContentWidth = sumWithinRange(stretchX, content[0], content[2]);\n stretchContentHeight = sumWithinRange(stretchY, content[1], content[3]);\n fixedOffsetX = content[0] - stretchOffsetX;\n fixedOffsetY = content[1] - stretchOffsetY;\n fixedContentWidth = content[2] - content[0] - stretchContentWidth;\n fixedContentHeight = content[3] - content[1] - stretchContentHeight;\n }\n var makeBox = function (left, top, right, bottom) {\n var leftEm = getEmOffset(left.stretch - stretchOffsetX, stretchContentWidth, iconWidth, shapedIcon.left);\n var leftPx = getPxOffset(left.fixed - fixedOffsetX, fixedContentWidth, left.stretch, stretchWidth);\n var topEm = getEmOffset(top.stretch - stretchOffsetY, stretchContentHeight, iconHeight, shapedIcon.top);\n var topPx = getPxOffset(top.fixed - fixedOffsetY, fixedContentHeight, top.stretch, stretchHeight);\n var rightEm = getEmOffset(right.stretch - stretchOffsetX, stretchContentWidth, iconWidth, shapedIcon.left);\n var rightPx = getPxOffset(right.fixed - fixedOffsetX, fixedContentWidth, right.stretch, stretchWidth);\n var bottomEm = getEmOffset(bottom.stretch - stretchOffsetY, stretchContentHeight, iconHeight, shapedIcon.top);\n var bottomPx = getPxOffset(bottom.fixed - fixedOffsetY, fixedContentHeight, bottom.stretch, stretchHeight);\n var tl = new pointGeometry(leftEm, topEm);\n var tr = new pointGeometry(rightEm, topEm);\n var br = new pointGeometry(rightEm, bottomEm);\n var bl = new pointGeometry(leftEm, bottomEm);\n var pixelOffsetTL = new pointGeometry(leftPx / pixelRatio, topPx / pixelRatio);\n var pixelOffsetBR = new pointGeometry(rightPx / pixelRatio, bottomPx / pixelRatio);\n var angle = iconRotate * Math.PI / 180;\n if (angle) {\n var sin = Math.sin(angle), cos = Math.cos(angle), matrix = [\n cos,\n -sin,\n sin,\n cos\n ];\n tl._matMult(matrix);\n tr._matMult(matrix);\n bl._matMult(matrix);\n br._matMult(matrix);\n }\n var x1 = left.stretch + left.fixed;\n var x2 = right.stretch + right.fixed;\n var y1 = top.stretch + top.fixed;\n var y2 = bottom.stretch + bottom.fixed;\n var subRect = {\n x: image.paddedRect.x + border$1 + x1,\n y: image.paddedRect.y + border$1 + y1,\n w: x2 - x1,\n h: y2 - y1\n };\n var minFontScaleX = fixedContentWidth / pixelRatio / iconWidth;\n var minFontScaleY = fixedContentHeight / pixelRatio / iconHeight;\n return {\n tl: tl,\n tr: tr,\n bl: bl,\n br: br,\n tex: subRect,\n writingMode: undefined,\n glyphOffset: [\n 0,\n 0\n ],\n sectionIndex: 0,\n pixelOffsetTL: pixelOffsetTL,\n pixelOffsetBR: pixelOffsetBR,\n minFontScaleX: minFontScaleX,\n minFontScaleY: minFontScaleY,\n isSDF: isSDFIcon\n };\n };\n if (!hasIconTextFit || !image.stretchX && !image.stretchY) {\n quads.push(makeBox({\n fixed: 0,\n stretch: -1\n }, {\n fixed: 0,\n stretch: -1\n }, {\n fixed: 0,\n stretch: imageWidth + 1\n }, {\n fixed: 0,\n stretch: imageHeight + 1\n }));\n } else {\n var xCuts = stretchZonesToCuts(stretchX, fixedWidth, stretchWidth);\n var yCuts = stretchZonesToCuts(stretchY, fixedHeight, stretchHeight);\n for (var xi = 0; xi < xCuts.length - 1; xi++) {\n var x1 = xCuts[xi];\n var x2 = xCuts[xi + 1];\n for (var yi = 0; yi < yCuts.length - 1; yi++) {\n var y1 = yCuts[yi];\n var y2 = yCuts[yi + 1];\n quads.push(makeBox(x1, y1, x2, y2));\n }\n }\n }\n return quads;\n}\nfunction sumWithinRange(ranges, min, max) {\n var sum = 0;\n for (var i = 0, list = ranges; i < list.length; i += 1) {\n var range = list[i];\n sum += Math.max(min, Math.min(max, range[1])) - Math.max(min, Math.min(max, range[0]));\n }\n return sum;\n}\nfunction stretchZonesToCuts(stretchZones, fixedSize, stretchSize) {\n var cuts = [{\n fixed: -border$1,\n stretch: 0\n }];\n for (var i = 0, list = stretchZones; i < list.length; i += 1) {\n var ref = list[i];\n var c1 = ref[0];\n var c2 = ref[1];\n var last = cuts[cuts.length - 1];\n cuts.push({\n fixed: c1 - last.stretch,\n stretch: last.stretch\n });\n cuts.push({\n fixed: c1 - last.stretch,\n stretch: last.stretch + (c2 - c1)\n });\n }\n cuts.push({\n fixed: fixedSize + border$1,\n stretch: stretchSize\n });\n return cuts;\n}\nfunction getEmOffset(stretchOffset, stretchSize, iconSize, iconOffset) {\n return stretchOffset / stretchSize * iconSize + iconOffset;\n}\nfunction getPxOffset(fixedOffset, fixedSize, stretchOffset, stretchSize) {\n return fixedOffset - fixedSize * stretchOffset / stretchSize;\n}\nfunction getGlyphQuads(anchor, shaping, textOffset, layer, alongLine, feature, imageMap, allowVerticalPlacement) {\n var textRotate = layer.layout.get('text-rotate').evaluate(feature, {}) * Math.PI / 180;\n var quads = [];\n for (var i$1 = 0, list$1 = shaping.positionedLines; i$1 < list$1.length; i$1 += 1) {\n var line = list$1[i$1];\n for (var i = 0, list = line.positionedGlyphs; i < list.length; i += 1) {\n var positionedGlyph = list[i];\n if (!positionedGlyph.rect) {\n continue;\n }\n var textureRect = positionedGlyph.rect || {};\n var glyphPadding = 1;\n var rectBuffer = GLYPH_PBF_BORDER + glyphPadding;\n var isSDF = true;\n var pixelRatio = 1;\n var lineOffset = 0;\n var rotateVerticalGlyph = (alongLine || allowVerticalPlacement) && positionedGlyph.vertical;\n var halfAdvance = positionedGlyph.metrics.advance * positionedGlyph.scale / 2;\n if (allowVerticalPlacement && shaping.verticalizable) {\n var scaledGlyphOffset = (positionedGlyph.scale - 1) * ONE_EM;\n var imageOffset = (ONE_EM - positionedGlyph.metrics.width * positionedGlyph.scale) / 2;\n lineOffset = line.lineOffset / 2 - (positionedGlyph.imageName ? -imageOffset : scaledGlyphOffset);\n }\n if (positionedGlyph.imageName) {\n var image = imageMap[positionedGlyph.imageName];\n isSDF = image.sdf;\n pixelRatio = image.pixelRatio;\n rectBuffer = IMAGE_PADDING / pixelRatio;\n }\n var glyphOffset = alongLine ? [\n positionedGlyph.x + halfAdvance,\n positionedGlyph.y\n ] : [\n 0,\n 0\n ];\n var builtInOffset = alongLine ? [\n 0,\n 0\n ] : [\n positionedGlyph.x + halfAdvance + textOffset[0],\n positionedGlyph.y + textOffset[1] - lineOffset\n ];\n var verticalizedLabelOffset = [\n 0,\n 0\n ];\n if (rotateVerticalGlyph) {\n verticalizedLabelOffset = builtInOffset;\n builtInOffset = [\n 0,\n 0\n ];\n }\n var x1 = (positionedGlyph.metrics.left - rectBuffer) * positionedGlyph.scale - halfAdvance + builtInOffset[0];\n var y1 = (-positionedGlyph.metrics.top - rectBuffer) * positionedGlyph.scale + builtInOffset[1];\n var x2 = x1 + textureRect.w * positionedGlyph.scale / pixelRatio;\n var y2 = y1 + textureRect.h * positionedGlyph.scale / pixelRatio;\n var tl = new pointGeometry(x1, y1);\n var tr = new pointGeometry(x2, y1);\n var bl = new pointGeometry(x1, y2);\n var br = new pointGeometry(x2, y2);\n if (rotateVerticalGlyph) {\n var center = new pointGeometry(-halfAdvance, halfAdvance - SHAPING_DEFAULT_OFFSET);\n var verticalRotation = -Math.PI / 2;\n var xHalfWidthOffsetCorrection = ONE_EM / 2 - halfAdvance;\n var yImageOffsetCorrection = positionedGlyph.imageName ? xHalfWidthOffsetCorrection : 0;\n var halfWidthOffsetCorrection = new pointGeometry(5 - SHAPING_DEFAULT_OFFSET - xHalfWidthOffsetCorrection, -yImageOffsetCorrection);\n var verticalOffsetCorrection = new (Function.prototype.bind.apply(pointGeometry, [null].concat(verticalizedLabelOffset)))();\n tl._rotateAround(verticalRotation, center)._add(halfWidthOffsetCorrection)._add(verticalOffsetCorrection);\n tr._rotateAround(verticalRotation, center)._add(halfWidthOffsetCorrection)._add(verticalOffsetCorrection);\n bl._rotateAround(verticalRotation, center)._add(halfWidthOffsetCorrection)._add(verticalOffsetCorrection);\n br._rotateAround(verticalRotation, center)._add(halfWidthOffsetCorrection)._add(verticalOffsetCorrection);\n }\n if (textRotate) {\n var sin = Math.sin(textRotate), cos = Math.cos(textRotate), matrix = [\n cos,\n -sin,\n sin,\n cos\n ];\n tl._matMult(matrix);\n tr._matMult(matrix);\n bl._matMult(matrix);\n br._matMult(matrix);\n }\n var pixelOffsetTL = new pointGeometry(0, 0);\n var pixelOffsetBR = new pointGeometry(0, 0);\n var minFontScaleX = 0;\n var minFontScaleY = 0;\n quads.push({\n tl: tl,\n tr: tr,\n bl: bl,\n br: br,\n tex: textureRect,\n writingMode: shaping.writingMode,\n glyphOffset: glyphOffset,\n sectionIndex: positionedGlyph.sectionIndex,\n isSDF: isSDF,\n pixelOffsetTL: pixelOffsetTL,\n pixelOffsetBR: pixelOffsetBR,\n minFontScaleX: minFontScaleX,\n minFontScaleY: minFontScaleY\n });\n }\n }\n return quads;\n}\n\nvar CollisionFeature = function CollisionFeature(collisionBoxArray, anchor, featureIndex, sourceLayerIndex, bucketIndex, shaped, boxScale, padding, alignLine, rotate) {\n this.boxStartIndex = collisionBoxArray.length;\n if (alignLine) {\n var top = shaped.top;\n var bottom = shaped.bottom;\n var collisionPadding = shaped.collisionPadding;\n if (collisionPadding) {\n top -= collisionPadding[1];\n bottom += collisionPadding[3];\n }\n var height = bottom - top;\n if (height > 0) {\n height = Math.max(10, height);\n this.circleDiameter = height;\n }\n } else {\n var y1 = shaped.top * boxScale - padding;\n var y2 = shaped.bottom * boxScale + padding;\n var x1 = shaped.left * boxScale - padding;\n var x2 = shaped.right * boxScale + padding;\n var collisionPadding$1 = shaped.collisionPadding;\n if (collisionPadding$1) {\n x1 -= collisionPadding$1[0] * boxScale;\n y1 -= collisionPadding$1[1] * boxScale;\n x2 += collisionPadding$1[2] * boxScale;\n y2 += collisionPadding$1[3] * boxScale;\n }\n if (rotate) {\n var tl = new pointGeometry(x1, y1);\n var tr = new pointGeometry(x2, y1);\n var bl = new pointGeometry(x1, y2);\n var br = new pointGeometry(x2, y2);\n var rotateRadians = rotate * Math.PI / 180;\n tl._rotate(rotateRadians);\n tr._rotate(rotateRadians);\n bl._rotate(rotateRadians);\n br._rotate(rotateRadians);\n x1 = Math.min(tl.x, tr.x, bl.x, br.x);\n x2 = Math.max(tl.x, tr.x, bl.x, br.x);\n y1 = Math.min(tl.y, tr.y, bl.y, br.y);\n y2 = Math.max(tl.y, tr.y, bl.y, br.y);\n }\n collisionBoxArray.emplaceBack(anchor.x, anchor.y, x1, y1, x2, y2, featureIndex, sourceLayerIndex, bucketIndex);\n }\n this.boxEndIndex = collisionBoxArray.length;\n};\n\nvar TinyQueue = function TinyQueue(data, compare) {\n if (data === void 0)\n data = [];\n if (compare === void 0)\n compare = defaultCompare$1;\n this.data = data;\n this.length = this.data.length;\n this.compare = compare;\n if (this.length > 0) {\n for (var i = (this.length >> 1) - 1; i >= 0; i--) {\n this._down(i);\n }\n }\n};\nTinyQueue.prototype.push = function push(item) {\n this.data.push(item);\n this.length++;\n this._up(this.length - 1);\n};\nTinyQueue.prototype.pop = function pop() {\n if (this.length === 0) {\n return undefined;\n }\n var top = this.data[0];\n var bottom = this.data.pop();\n this.length--;\n if (this.length > 0) {\n this.data[0] = bottom;\n this._down(0);\n }\n return top;\n};\nTinyQueue.prototype.peek = function peek() {\n return this.data[0];\n};\nTinyQueue.prototype._up = function _up(pos) {\n var ref = this;\n var data = ref.data;\n var compare = ref.compare;\n var item = data[pos];\n while (pos > 0) {\n var parent = pos - 1 >> 1;\n var current = data[parent];\n if (compare(item, current) >= 0) {\n break;\n }\n data[pos] = current;\n pos = parent;\n }\n data[pos] = item;\n};\nTinyQueue.prototype._down = function _down(pos) {\n var ref = this;\n var data = ref.data;\n var compare = ref.compare;\n var halfLength = this.length >> 1;\n var item = data[pos];\n while (pos < halfLength) {\n var left = (pos << 1) + 1;\n var best = data[left];\n var right = left + 1;\n if (right < this.length && compare(data[right], best) < 0) {\n left = right;\n best = data[right];\n }\n if (compare(best, item) >= 0) {\n break;\n }\n data[pos] = best;\n pos = left;\n }\n data[pos] = item;\n};\nfunction defaultCompare$1(a, b) {\n return a < b ? -1 : a > b ? 1 : 0;\n}\n\nfunction findPoleOfInaccessibility (polygonRings, precision, debug) {\n if (precision === void 0)\n precision = 1;\n if (debug === void 0)\n debug = false;\n var minX = Infinity, minY = Infinity, maxX = -Infinity, maxY = -Infinity;\n var outerRing = polygonRings[0];\n for (var i = 0; i < outerRing.length; i++) {\n var p = outerRing[i];\n if (!i || p.x < minX) {\n minX = p.x;\n }\n if (!i || p.y < minY) {\n minY = p.y;\n }\n if (!i || p.x > maxX) {\n maxX = p.x;\n }\n if (!i || p.y > maxY) {\n maxY = p.y;\n }\n }\n var width = maxX - minX;\n var height = maxY - minY;\n var cellSize = Math.min(width, height);\n var h = cellSize / 2;\n var cellQueue = new TinyQueue([], compareMax);\n if (cellSize === 0) {\n return new pointGeometry(minX, minY);\n }\n for (var x = minX; x < maxX; x += cellSize) {\n for (var y = minY; y < maxY; y += cellSize) {\n cellQueue.push(new Cell(x + h, y + h, h, polygonRings));\n }\n }\n var bestCell = getCentroidCell(polygonRings);\n var numProbes = cellQueue.length;\n while (cellQueue.length) {\n var cell = cellQueue.pop();\n if (cell.d > bestCell.d || !bestCell.d) {\n bestCell = cell;\n if (debug) {\n console.log('found best %d after %d probes', Math.round(10000 * cell.d) / 10000, numProbes);\n }\n }\n if (cell.max - bestCell.d <= precision) {\n continue;\n }\n h = cell.h / 2;\n cellQueue.push(new Cell(cell.p.x - h, cell.p.y - h, h, polygonRings));\n cellQueue.push(new Cell(cell.p.x + h, cell.p.y - h, h, polygonRings));\n cellQueue.push(new Cell(cell.p.x - h, cell.p.y + h, h, polygonRings));\n cellQueue.push(new Cell(cell.p.x + h, cell.p.y + h, h, polygonRings));\n numProbes += 4;\n }\n if (debug) {\n console.log('num probes: ' + numProbes);\n console.log('best distance: ' + bestCell.d);\n }\n return bestCell.p;\n}\nfunction compareMax(a, b) {\n return b.max - a.max;\n}\nfunction Cell(x, y, h, polygon) {\n this.p = new pointGeometry(x, y);\n this.h = h;\n this.d = pointToPolygonDist(this.p, polygon);\n this.max = this.d + this.h * Math.SQRT2;\n}\nfunction pointToPolygonDist(p, polygon) {\n var inside = false;\n var minDistSq = Infinity;\n for (var k = 0; k < polygon.length; k++) {\n var ring = polygon[k];\n for (var i = 0, len = ring.length, j = len - 1; i < len; j = i++) {\n var a = ring[i];\n var b = ring[j];\n if (a.y > p.y !== b.y > p.y && p.x < (b.x - a.x) * (p.y - a.y) / (b.y - a.y) + a.x) {\n inside = !inside;\n }\n minDistSq = Math.min(minDistSq, distToSegmentSquared(p, a, b));\n }\n }\n return (inside ? 1 : -1) * Math.sqrt(minDistSq);\n}\nfunction getCentroidCell(polygon) {\n var area = 0;\n var x = 0;\n var y = 0;\n var points = polygon[0];\n for (var i = 0, len = points.length, j = len - 1; i < len; j = i++) {\n var a = points[i];\n var b = points[j];\n var f = a.x * b.y - b.x * a.y;\n x += (a.x + b.x) * f;\n y += (a.y + b.y) * f;\n area += f * 3;\n }\n return new Cell(x / area, y / area, 0, polygon);\n}\n\nvar baselineOffset = 7;\nvar INVALID_TEXT_OFFSET = Number.POSITIVE_INFINITY;\nfunction evaluateVariableOffset(anchor, offset) {\n function fromRadialOffset(anchor, radialOffset) {\n var x = 0, y = 0;\n if (radialOffset < 0) {\n radialOffset = 0;\n }\n var hypotenuse = radialOffset / Math.sqrt(2);\n switch (anchor) {\n case 'top-right':\n case 'top-left':\n y = hypotenuse - baselineOffset;\n break;\n case 'bottom-right':\n case 'bottom-left':\n y = -hypotenuse + baselineOffset;\n break;\n case 'bottom':\n y = -radialOffset + baselineOffset;\n break;\n case 'top':\n y = radialOffset - baselineOffset;\n break;\n }\n switch (anchor) {\n case 'top-right':\n case 'bottom-right':\n x = -hypotenuse;\n break;\n case 'top-left':\n case 'bottom-left':\n x = hypotenuse;\n break;\n case 'left':\n x = radialOffset;\n break;\n case 'right':\n x = -radialOffset;\n break;\n }\n return [\n x,\n y\n ];\n }\n function fromTextOffset(anchor, offsetX, offsetY) {\n var x = 0, y = 0;\n offsetX = Math.abs(offsetX);\n offsetY = Math.abs(offsetY);\n switch (anchor) {\n case 'top-right':\n case 'top-left':\n case 'top':\n y = offsetY - baselineOffset;\n break;\n case 'bottom-right':\n case 'bottom-left':\n case 'bottom':\n y = -offsetY + baselineOffset;\n break;\n }\n switch (anchor) {\n case 'top-right':\n case 'bottom-right':\n case 'right':\n x = -offsetX;\n break;\n case 'top-left':\n case 'bottom-left':\n case 'left':\n x = offsetX;\n break;\n }\n return [\n x,\n y\n ];\n }\n return offset[1] !== INVALID_TEXT_OFFSET ? fromTextOffset(anchor, offset[0], offset[1]) : fromRadialOffset(anchor, offset[0]);\n}\nfunction performSymbolLayout(bucket, glyphMap, glyphPositions, imageMap, imagePositions, showCollisionBoxes, canonical) {\n bucket.createArrays();\n var tileSize = 512 * bucket.overscaling;\n bucket.tilePixelRatio = EXTENT$1 / tileSize;\n bucket.compareText = {};\n bucket.iconsNeedLinear = false;\n var layout = bucket.layers[0].layout;\n var unevaluatedLayoutValues = bucket.layers[0]._unevaluatedLayout._values;\n var sizes = {};\n if (bucket.textSizeData.kind === 'composite') {\n var ref = bucket.textSizeData;\n var minZoom = ref.minZoom;\n var maxZoom = ref.maxZoom;\n sizes.compositeTextSizes = [\n unevaluatedLayoutValues['text-size'].possiblyEvaluate(new EvaluationParameters(minZoom), canonical),\n unevaluatedLayoutValues['text-size'].possiblyEvaluate(new EvaluationParameters(maxZoom), canonical)\n ];\n }\n if (bucket.iconSizeData.kind === 'composite') {\n var ref$1 = bucket.iconSizeData;\n var minZoom$1 = ref$1.minZoom;\n var maxZoom$1 = ref$1.maxZoom;\n sizes.compositeIconSizes = [\n unevaluatedLayoutValues['icon-size'].possiblyEvaluate(new EvaluationParameters(minZoom$1), canonical),\n unevaluatedLayoutValues['icon-size'].possiblyEvaluate(new EvaluationParameters(maxZoom$1), canonical)\n ];\n }\n sizes.layoutTextSize = unevaluatedLayoutValues['text-size'].possiblyEvaluate(new EvaluationParameters(bucket.zoom + 1), canonical);\n sizes.layoutIconSize = unevaluatedLayoutValues['icon-size'].possiblyEvaluate(new EvaluationParameters(bucket.zoom + 1), canonical);\n sizes.textMaxSize = unevaluatedLayoutValues['text-size'].possiblyEvaluate(new EvaluationParameters(18));\n var lineHeight = layout.get('text-line-height') * ONE_EM;\n var textAlongLine = layout.get('text-rotation-alignment') === 'map' && layout.get('symbol-placement') !== 'point';\n var keepUpright = layout.get('text-keep-upright');\n var textSize = layout.get('text-size');\n var loop = function () {\n var feature = list[i$1];\n var fontstack = layout.get('text-font').evaluate(feature, {}, canonical).join(',');\n var layoutTextSizeThisZoom = textSize.evaluate(feature, {}, canonical);\n var layoutTextSize = sizes.layoutTextSize.evaluate(feature, {}, canonical);\n var layoutIconSize = sizes.layoutIconSize.evaluate(feature, {}, canonical);\n var shapedTextOrientations = {\n horizontal: {},\n vertical: undefined\n };\n var text = feature.text;\n var textOffset = [\n 0,\n 0\n ];\n if (text) {\n var unformattedText = text.toString();\n var spacing = layout.get('text-letter-spacing').evaluate(feature, {}, canonical) * ONE_EM;\n var spacingIfAllowed = allowsLetterSpacing(unformattedText) ? spacing : 0;\n var textAnchor = layout.get('text-anchor').evaluate(feature, {}, canonical);\n var variableTextAnchor = layout.get('text-variable-anchor');\n if (!variableTextAnchor) {\n var radialOffset = layout.get('text-radial-offset').evaluate(feature, {}, canonical);\n if (radialOffset) {\n textOffset = evaluateVariableOffset(textAnchor, [\n radialOffset * ONE_EM,\n INVALID_TEXT_OFFSET\n ]);\n } else {\n textOffset = layout.get('text-offset').evaluate(feature, {}, canonical).map(function (t) {\n return t * ONE_EM;\n });\n }\n }\n var textJustify = textAlongLine ? 'center' : layout.get('text-justify').evaluate(feature, {}, canonical);\n var symbolPlacement = layout.get('symbol-placement');\n var maxWidth = symbolPlacement === 'point' ? layout.get('text-max-width').evaluate(feature, {}, canonical) * ONE_EM : 0;\n var addVerticalShapingForPointLabelIfNeeded = function () {\n if (bucket.allowVerticalPlacement && allowsVerticalWritingMode(unformattedText)) {\n shapedTextOrientations.vertical = shapeText(text, glyphMap, glyphPositions, imagePositions, fontstack, maxWidth, lineHeight, textAnchor, 'left', spacingIfAllowed, textOffset, WritingMode.vertical, true, symbolPlacement, layoutTextSize, layoutTextSizeThisZoom);\n }\n };\n if (!textAlongLine && variableTextAnchor) {\n var justifications = textJustify === 'auto' ? variableTextAnchor.map(function (a) {\n return getAnchorJustification(a);\n }) : [textJustify];\n var singleLine = false;\n for (var i = 0; i < justifications.length; i++) {\n var justification = justifications[i];\n if (shapedTextOrientations.horizontal[justification]) {\n continue;\n }\n if (singleLine) {\n shapedTextOrientations.horizontal[justification] = shapedTextOrientations.horizontal[0];\n } else {\n var shaping = shapeText(text, glyphMap, glyphPositions, imagePositions, fontstack, maxWidth, lineHeight, 'center', justification, spacingIfAllowed, textOffset, WritingMode.horizontal, false, symbolPlacement, layoutTextSize, layoutTextSizeThisZoom);\n if (shaping) {\n shapedTextOrientations.horizontal[justification] = shaping;\n singleLine = shaping.positionedLines.length === 1;\n }\n }\n }\n addVerticalShapingForPointLabelIfNeeded();\n } else {\n if (textJustify === 'auto') {\n textJustify = getAnchorJustification(textAnchor);\n }\n var shaping$1 = shapeText(text, glyphMap, glyphPositions, imagePositions, fontstack, maxWidth, lineHeight, textAnchor, textJustify, spacingIfAllowed, textOffset, WritingMode.horizontal, false, symbolPlacement, layoutTextSize, layoutTextSizeThisZoom);\n if (shaping$1) {\n shapedTextOrientations.horizontal[textJustify] = shaping$1;\n }\n addVerticalShapingForPointLabelIfNeeded();\n if (allowsVerticalWritingMode(unformattedText) && textAlongLine && keepUpright) {\n shapedTextOrientations.vertical = shapeText(text, glyphMap, glyphPositions, imagePositions, fontstack, maxWidth, lineHeight, textAnchor, textJustify, spacingIfAllowed, textOffset, WritingMode.vertical, false, symbolPlacement, layoutTextSize, layoutTextSizeThisZoom);\n }\n }\n }\n var shapedIcon = void 0;\n var isSDFIcon = false;\n if (feature.icon && feature.icon.name) {\n var image = imageMap[feature.icon.name];\n if (image) {\n shapedIcon = shapeIcon(imagePositions[feature.icon.name], layout.get('icon-offset').evaluate(feature, {}, canonical), layout.get('icon-anchor').evaluate(feature, {}, canonical));\n isSDFIcon = image.sdf;\n if (bucket.sdfIcons === undefined) {\n bucket.sdfIcons = image.sdf;\n } else if (bucket.sdfIcons !== image.sdf) {\n warnOnce('Style sheet warning: Cannot mix SDF and non-SDF icons in one buffer');\n }\n if (image.pixelRatio !== bucket.pixelRatio) {\n bucket.iconsNeedLinear = true;\n } else if (layout.get('icon-rotate').constantOr(1) !== 0) {\n bucket.iconsNeedLinear = true;\n }\n }\n }\n var shapedText = getDefaultHorizontalShaping(shapedTextOrientations.horizontal) || shapedTextOrientations.vertical;\n bucket.iconsInText = shapedText ? shapedText.iconsInText : false;\n if (shapedText || shapedIcon) {\n addFeature(bucket, feature, shapedTextOrientations, shapedIcon, imageMap, sizes, layoutTextSize, layoutIconSize, textOffset, isSDFIcon, canonical);\n }\n };\n for (var i$1 = 0, list = bucket.features; i$1 < list.length; i$1 += 1)\n loop();\n if (showCollisionBoxes) {\n bucket.generateCollisionDebugBuffers();\n }\n}\nfunction getAnchorJustification(anchor) {\n switch (anchor) {\n case 'right':\n case 'top-right':\n case 'bottom-right':\n return 'right';\n case 'left':\n case 'top-left':\n case 'bottom-left':\n return 'left';\n }\n return 'center';\n}\nfunction addFeature(bucket, feature, shapedTextOrientations, shapedIcon, imageMap, sizes, layoutTextSize, layoutIconSize, textOffset, isSDFIcon, canonical) {\n var textMaxSize = sizes.textMaxSize.evaluate(feature, {});\n if (textMaxSize === undefined) {\n textMaxSize = layoutTextSize;\n }\n var layout = bucket.layers[0].layout;\n var iconOffset = layout.get('icon-offset').evaluate(feature, {}, canonical);\n var defaultHorizontalShaping = getDefaultHorizontalShaping(shapedTextOrientations.horizontal);\n var glyphSize = 24, fontScale = layoutTextSize / glyphSize, textBoxScale = bucket.tilePixelRatio * fontScale, textMaxBoxScale = bucket.tilePixelRatio * textMaxSize / glyphSize, iconBoxScale = bucket.tilePixelRatio * layoutIconSize, symbolMinDistance = bucket.tilePixelRatio * layout.get('symbol-spacing'), textPadding = layout.get('text-padding') * bucket.tilePixelRatio, iconPadding = layout.get('icon-padding') * bucket.tilePixelRatio, textMaxAngle = layout.get('text-max-angle') / 180 * Math.PI, textAlongLine = layout.get('text-rotation-alignment') === 'map' && layout.get('symbol-placement') !== 'point', iconAlongLine = layout.get('icon-rotation-alignment') === 'map' && layout.get('symbol-placement') !== 'point', symbolPlacement = layout.get('symbol-placement'), textRepeatDistance = symbolMinDistance / 2;\n var iconTextFit = layout.get('icon-text-fit');\n var verticallyShapedIcon;\n if (shapedIcon && iconTextFit !== 'none') {\n if (bucket.allowVerticalPlacement && shapedTextOrientations.vertical) {\n verticallyShapedIcon = fitIconToText(shapedIcon, shapedTextOrientations.vertical, iconTextFit, layout.get('icon-text-fit-padding'), iconOffset, fontScale);\n }\n if (defaultHorizontalShaping) {\n shapedIcon = fitIconToText(shapedIcon, defaultHorizontalShaping, iconTextFit, layout.get('icon-text-fit-padding'), iconOffset, fontScale);\n }\n }\n var addSymbolAtAnchor = function (line, anchor) {\n if (anchor.x < 0 || anchor.x >= EXTENT$1 || anchor.y < 0 || anchor.y >= EXTENT$1) {\n return;\n }\n addSymbol(bucket, anchor, line, shapedTextOrientations, shapedIcon, imageMap, verticallyShapedIcon, bucket.layers[0], bucket.collisionBoxArray, feature.index, feature.sourceLayerIndex, bucket.index, textBoxScale, textPadding, textAlongLine, textOffset, iconBoxScale, iconPadding, iconAlongLine, iconOffset, feature, sizes, isSDFIcon, canonical, layoutTextSize);\n };\n if (symbolPlacement === 'line') {\n for (var i$1 = 0, list$1 = clipLine(feature.geometry, 0, 0, EXTENT$1, EXTENT$1); i$1 < list$1.length; i$1 += 1) {\n var line = list$1[i$1];\n var anchors = getAnchors(line, symbolMinDistance, textMaxAngle, shapedTextOrientations.vertical || defaultHorizontalShaping, shapedIcon, glyphSize, textMaxBoxScale, bucket.overscaling, EXTENT$1);\n for (var i = 0, list = anchors; i < list.length; i += 1) {\n var anchor = list[i];\n var shapedText = defaultHorizontalShaping;\n if (!shapedText || !anchorIsTooClose(bucket, shapedText.text, textRepeatDistance, anchor)) {\n addSymbolAtAnchor(line, anchor);\n }\n }\n }\n } else if (symbolPlacement === 'line-center') {\n for (var i$2 = 0, list$2 = feature.geometry; i$2 < list$2.length; i$2 += 1) {\n var line$1 = list$2[i$2];\n if (line$1.length > 1) {\n var anchor$1 = getCenterAnchor(line$1, textMaxAngle, shapedTextOrientations.vertical || defaultHorizontalShaping, shapedIcon, glyphSize, textMaxBoxScale);\n if (anchor$1) {\n addSymbolAtAnchor(line$1, anchor$1);\n }\n }\n }\n } else if (feature.type === 'Polygon') {\n for (var i$3 = 0, list$3 = classifyRings(feature.geometry, 0); i$3 < list$3.length; i$3 += 1) {\n var polygon = list$3[i$3];\n var poi = findPoleOfInaccessibility(polygon, 16);\n addSymbolAtAnchor(polygon[0], new Anchor(poi.x, poi.y, 0));\n }\n } else if (feature.type === 'LineString') {\n for (var i$4 = 0, list$4 = feature.geometry; i$4 < list$4.length; i$4 += 1) {\n var line$2 = list$4[i$4];\n addSymbolAtAnchor(line$2, new Anchor(line$2[0].x, line$2[0].y, 0));\n }\n } else if (feature.type === 'Point') {\n for (var i$6 = 0, list$6 = feature.geometry; i$6 < list$6.length; i$6 += 1) {\n var points = list$6[i$6];\n for (var i$5 = 0, list$5 = points; i$5 < list$5.length; i$5 += 1) {\n var point = list$5[i$5];\n addSymbolAtAnchor([point], new Anchor(point.x, point.y, 0));\n }\n }\n }\n}\nvar MAX_GLYPH_ICON_SIZE = 255;\nvar MAX_PACKED_SIZE = MAX_GLYPH_ICON_SIZE * SIZE_PACK_FACTOR;\nfunction addTextVertices(bucket, anchor, shapedText, imageMap, layer, textAlongLine, feature, textOffset, lineArray, writingMode, placementTypes, placedTextSymbolIndices, placedIconIndex, sizes, canonical) {\n var glyphQuads = getGlyphQuads(anchor, shapedText, textOffset, layer, textAlongLine, feature, imageMap, bucket.allowVerticalPlacement);\n var sizeData = bucket.textSizeData;\n var textSizeData = null;\n if (sizeData.kind === 'source') {\n textSizeData = [SIZE_PACK_FACTOR * layer.layout.get('text-size').evaluate(feature, {})];\n if (textSizeData[0] > MAX_PACKED_SIZE) {\n warnOnce(bucket.layerIds[0] + ': Value for \"text-size\" is >= ' + MAX_GLYPH_ICON_SIZE + '. Reduce your \"text-size\".');\n }\n } else if (sizeData.kind === 'composite') {\n textSizeData = [\n SIZE_PACK_FACTOR * sizes.compositeTextSizes[0].evaluate(feature, {}, canonical),\n SIZE_PACK_FACTOR * sizes.compositeTextSizes[1].evaluate(feature, {}, canonical)\n ];\n if (textSizeData[0] > MAX_PACKED_SIZE || textSizeData[1] > MAX_PACKED_SIZE) {\n warnOnce(bucket.layerIds[0] + ': Value for \"text-size\" is >= ' + MAX_GLYPH_ICON_SIZE + '. Reduce your \"text-size\".');\n }\n }\n bucket.addSymbols(bucket.text, glyphQuads, textSizeData, textOffset, textAlongLine, feature, writingMode, anchor, lineArray.lineStartIndex, lineArray.lineLength, placedIconIndex, canonical);\n for (var i = 0, list = placementTypes; i < list.length; i += 1) {\n var placementType = list[i];\n placedTextSymbolIndices[placementType] = bucket.text.placedSymbolArray.length - 1;\n }\n return glyphQuads.length * 4;\n}\nfunction getDefaultHorizontalShaping(horizontalShaping) {\n for (var justification in horizontalShaping) {\n return horizontalShaping[justification];\n }\n return null;\n}\nfunction addSymbol(bucket, anchor, line, shapedTextOrientations, shapedIcon, imageMap, verticallyShapedIcon, layer, collisionBoxArray, featureIndex, sourceLayerIndex, bucketIndex, textBoxScale, textPadding, textAlongLine, textOffset, iconBoxScale, iconPadding, iconAlongLine, iconOffset, feature, sizes, isSDFIcon, canonical, layoutTextSize) {\n var assign;\n var lineArray = bucket.addToLineVertexArray(anchor, line);\n var textCollisionFeature, iconCollisionFeature, verticalTextCollisionFeature, verticalIconCollisionFeature;\n var numIconVertices = 0;\n var numVerticalIconVertices = 0;\n var numHorizontalGlyphVertices = 0;\n var numVerticalGlyphVertices = 0;\n var placedIconSymbolIndex = -1;\n var verticalPlacedIconSymbolIndex = -1;\n var placedTextSymbolIndices = {};\n var key = murmurhashJs('');\n var textOffset0 = 0;\n var textOffset1 = 0;\n if (layer._unevaluatedLayout.getValue('text-radial-offset') === undefined) {\n assign = layer.layout.get('text-offset').evaluate(feature, {}, canonical).map(function (t) {\n return t * ONE_EM;\n }), textOffset0 = assign[0], textOffset1 = assign[1];\n } else {\n textOffset0 = layer.layout.get('text-radial-offset').evaluate(feature, {}, canonical) * ONE_EM;\n textOffset1 = INVALID_TEXT_OFFSET;\n }\n if (bucket.allowVerticalPlacement && shapedTextOrientations.vertical) {\n var textRotation = layer.layout.get('text-rotate').evaluate(feature, {}, canonical);\n var verticalTextRotation = textRotation + 90;\n var verticalShaping = shapedTextOrientations.vertical;\n verticalTextCollisionFeature = new CollisionFeature(collisionBoxArray, anchor, featureIndex, sourceLayerIndex, bucketIndex, verticalShaping, textBoxScale, textPadding, textAlongLine, verticalTextRotation);\n if (verticallyShapedIcon) {\n verticalIconCollisionFeature = new CollisionFeature(collisionBoxArray, anchor, featureIndex, sourceLayerIndex, bucketIndex, verticallyShapedIcon, iconBoxScale, iconPadding, textAlongLine, verticalTextRotation);\n }\n }\n if (shapedIcon) {\n var iconRotate = layer.layout.get('icon-rotate').evaluate(feature, {});\n var hasIconTextFit = layer.layout.get('icon-text-fit') !== 'none';\n var iconQuads = getIconQuads(shapedIcon, iconRotate, isSDFIcon, hasIconTextFit);\n var verticalIconQuads = verticallyShapedIcon ? getIconQuads(verticallyShapedIcon, iconRotate, isSDFIcon, hasIconTextFit) : undefined;\n iconCollisionFeature = new CollisionFeature(collisionBoxArray, anchor, featureIndex, sourceLayerIndex, bucketIndex, shapedIcon, iconBoxScale, iconPadding, false, iconRotate);\n numIconVertices = iconQuads.length * 4;\n var sizeData = bucket.iconSizeData;\n var iconSizeData = null;\n if (sizeData.kind === 'source') {\n iconSizeData = [SIZE_PACK_FACTOR * layer.layout.get('icon-size').evaluate(feature, {})];\n if (iconSizeData[0] > MAX_PACKED_SIZE) {\n warnOnce(bucket.layerIds[0] + ': Value for \"icon-size\" is >= ' + MAX_GLYPH_ICON_SIZE + '. Reduce your \"icon-size\".');\n }\n } else if (sizeData.kind === 'composite') {\n iconSizeData = [\n SIZE_PACK_FACTOR * sizes.compositeIconSizes[0].evaluate(feature, {}, canonical),\n SIZE_PACK_FACTOR * sizes.compositeIconSizes[1].evaluate(feature, {}, canonical)\n ];\n if (iconSizeData[0] > MAX_PACKED_SIZE || iconSizeData[1] > MAX_PACKED_SIZE) {\n warnOnce(bucket.layerIds[0] + ': Value for \"icon-size\" is >= ' + MAX_GLYPH_ICON_SIZE + '. Reduce your \"icon-size\".');\n }\n }\n bucket.addSymbols(bucket.icon, iconQuads, iconSizeData, iconOffset, iconAlongLine, feature, false, anchor, lineArray.lineStartIndex, lineArray.lineLength, -1, canonical);\n placedIconSymbolIndex = bucket.icon.placedSymbolArray.length - 1;\n if (verticalIconQuads) {\n numVerticalIconVertices = verticalIconQuads.length * 4;\n bucket.addSymbols(bucket.icon, verticalIconQuads, iconSizeData, iconOffset, iconAlongLine, feature, WritingMode.vertical, anchor, lineArray.lineStartIndex, lineArray.lineLength, -1, canonical);\n verticalPlacedIconSymbolIndex = bucket.icon.placedSymbolArray.length - 1;\n }\n }\n for (var justification in shapedTextOrientations.horizontal) {\n var shaping = shapedTextOrientations.horizontal[justification];\n if (!textCollisionFeature) {\n key = murmurhashJs(shaping.text);\n var textRotate = layer.layout.get('text-rotate').evaluate(feature, {}, canonical);\n textCollisionFeature = new CollisionFeature(collisionBoxArray, anchor, featureIndex, sourceLayerIndex, bucketIndex, shaping, textBoxScale, textPadding, textAlongLine, textRotate);\n }\n var singleLine = shaping.positionedLines.length === 1;\n numHorizontalGlyphVertices += addTextVertices(bucket, anchor, shaping, imageMap, layer, textAlongLine, feature, textOffset, lineArray, shapedTextOrientations.vertical ? WritingMode.horizontal : WritingMode.horizontalOnly, singleLine ? Object.keys(shapedTextOrientations.horizontal) : [justification], placedTextSymbolIndices, placedIconSymbolIndex, sizes, canonical);\n if (singleLine) {\n break;\n }\n }\n if (shapedTextOrientations.vertical) {\n numVerticalGlyphVertices += addTextVertices(bucket, anchor, shapedTextOrientations.vertical, imageMap, layer, textAlongLine, feature, textOffset, lineArray, WritingMode.vertical, ['vertical'], placedTextSymbolIndices, verticalPlacedIconSymbolIndex, sizes, canonical);\n }\n var textBoxStartIndex = textCollisionFeature ? textCollisionFeature.boxStartIndex : bucket.collisionBoxArray.length;\n var textBoxEndIndex = textCollisionFeature ? textCollisionFeature.boxEndIndex : bucket.collisionBoxArray.length;\n var verticalTextBoxStartIndex = verticalTextCollisionFeature ? verticalTextCollisionFeature.boxStartIndex : bucket.collisionBoxArray.length;\n var verticalTextBoxEndIndex = verticalTextCollisionFeature ? verticalTextCollisionFeature.boxEndIndex : bucket.collisionBoxArray.length;\n var iconBoxStartIndex = iconCollisionFeature ? iconCollisionFeature.boxStartIndex : bucket.collisionBoxArray.length;\n var iconBoxEndIndex = iconCollisionFeature ? iconCollisionFeature.boxEndIndex : bucket.collisionBoxArray.length;\n var verticalIconBoxStartIndex = verticalIconCollisionFeature ? verticalIconCollisionFeature.boxStartIndex : bucket.collisionBoxArray.length;\n var verticalIconBoxEndIndex = verticalIconCollisionFeature ? verticalIconCollisionFeature.boxEndIndex : bucket.collisionBoxArray.length;\n var collisionCircleDiameter = -1;\n var getCollisionCircleHeight = function (feature, prevHeight) {\n if (feature && feature.circleDiameter) {\n return Math.max(feature.circleDiameter, prevHeight);\n }\n return prevHeight;\n };\n collisionCircleDiameter = getCollisionCircleHeight(textCollisionFeature, collisionCircleDiameter);\n collisionCircleDiameter = getCollisionCircleHeight(verticalTextCollisionFeature, collisionCircleDiameter);\n collisionCircleDiameter = getCollisionCircleHeight(iconCollisionFeature, collisionCircleDiameter);\n collisionCircleDiameter = getCollisionCircleHeight(verticalIconCollisionFeature, collisionCircleDiameter);\n var useRuntimeCollisionCircles = collisionCircleDiameter > -1 ? 1 : 0;\n if (useRuntimeCollisionCircles) {\n collisionCircleDiameter *= layoutTextSize / ONE_EM;\n }\n if (bucket.glyphOffsetArray.length >= SymbolBucket.MAX_GLYPHS) {\n warnOnce('Too many glyphs being rendered in a tile. See https://github.com/mapbox/mapbox-gl-js/issues/2907');\n }\n if (feature.sortKey !== undefined) {\n bucket.addToSortKeyRanges(bucket.symbolInstances.length, feature.sortKey);\n }\n bucket.symbolInstances.emplaceBack(anchor.x, anchor.y, placedTextSymbolIndices.right >= 0 ? placedTextSymbolIndices.right : -1, placedTextSymbolIndices.center >= 0 ? placedTextSymbolIndices.center : -1, placedTextSymbolIndices.left >= 0 ? placedTextSymbolIndices.left : -1, placedTextSymbolIndices.vertical || -1, placedIconSymbolIndex, verticalPlacedIconSymbolIndex, key, textBoxStartIndex, textBoxEndIndex, verticalTextBoxStartIndex, verticalTextBoxEndIndex, iconBoxStartIndex, iconBoxEndIndex, verticalIconBoxStartIndex, verticalIconBoxEndIndex, featureIndex, numHorizontalGlyphVertices, numVerticalGlyphVertices, numIconVertices, numVerticalIconVertices, useRuntimeCollisionCircles, 0, textBoxScale, textOffset0, textOffset1, collisionCircleDiameter);\n}\nfunction anchorIsTooClose(bucket, text, repeatDistance, anchor) {\n var compareText = bucket.compareText;\n if (!(text in compareText)) {\n compareText[text] = [];\n } else {\n var otherAnchors = compareText[text];\n for (var k = otherAnchors.length - 1; k >= 0; k--) {\n if (anchor.dist(otherAnchors[k]) < repeatDistance) {\n return true;\n }\n }\n }\n compareText[text].push(anchor);\n return false;\n}\n\nvar vectorTileFeatureTypes$2 = vectorTile.VectorTileFeature.types;\nvar shaderOpacityAttributes = [{\n name: 'a_fade_opacity',\n components: 1,\n type: 'Uint8',\n offset: 0\n }];\nfunction addVertex$1(array, anchorX, anchorY, ox, oy, tx, ty, sizeVertex, isSDF, pixelOffsetX, pixelOffsetY, minFontScaleX, minFontScaleY) {\n var aSizeX = sizeVertex ? Math.min(MAX_PACKED_SIZE, Math.round(sizeVertex[0])) : 0;\n var aSizeY = sizeVertex ? Math.min(MAX_PACKED_SIZE, Math.round(sizeVertex[1])) : 0;\n array.emplaceBack(anchorX, anchorY, Math.round(ox * 32), Math.round(oy * 32), tx, ty, (aSizeX << 1) + (isSDF ? 1 : 0), aSizeY, pixelOffsetX * 16, pixelOffsetY * 16, minFontScaleX * 256, minFontScaleY * 256);\n}\nfunction addDynamicAttributes(dynamicLayoutVertexArray, p, angle) {\n dynamicLayoutVertexArray.emplaceBack(p.x, p.y, angle);\n dynamicLayoutVertexArray.emplaceBack(p.x, p.y, angle);\n dynamicLayoutVertexArray.emplaceBack(p.x, p.y, angle);\n dynamicLayoutVertexArray.emplaceBack(p.x, p.y, angle);\n}\nfunction containsRTLText(formattedText) {\n for (var i = 0, list = formattedText.sections; i < list.length; i += 1) {\n var section = list[i];\n if (stringContainsRTLText(section.text)) {\n return true;\n }\n }\n return false;\n}\nvar SymbolBuffers = function SymbolBuffers(programConfigurations) {\n this.layoutVertexArray = new StructArrayLayout4i4ui4i24();\n this.indexArray = new StructArrayLayout3ui6();\n this.programConfigurations = programConfigurations;\n this.segments = new SegmentVector();\n this.dynamicLayoutVertexArray = new StructArrayLayout3f12();\n this.opacityVertexArray = new StructArrayLayout1ul4();\n this.placedSymbolArray = new PlacedSymbolArray();\n};\nSymbolBuffers.prototype.isEmpty = function isEmpty() {\n return this.layoutVertexArray.length === 0 && this.indexArray.length === 0 && this.dynamicLayoutVertexArray.length === 0 && this.opacityVertexArray.length === 0;\n};\nSymbolBuffers.prototype.upload = function upload(context, dynamicIndexBuffer, upload$1, update) {\n if (this.isEmpty()) {\n return;\n }\n if (upload$1) {\n this.layoutVertexBuffer = context.createVertexBuffer(this.layoutVertexArray, symbolLayoutAttributes.members);\n this.indexBuffer = context.createIndexBuffer(this.indexArray, dynamicIndexBuffer);\n this.dynamicLayoutVertexBuffer = context.createVertexBuffer(this.dynamicLayoutVertexArray, dynamicLayoutAttributes.members, true);\n this.opacityVertexBuffer = context.createVertexBuffer(this.opacityVertexArray, shaderOpacityAttributes, true);\n this.opacityVertexBuffer.itemSize = 1;\n }\n if (upload$1 || update) {\n this.programConfigurations.upload(context);\n }\n};\nSymbolBuffers.prototype.destroy = function destroy() {\n if (!this.layoutVertexBuffer) {\n return;\n }\n this.layoutVertexBuffer.destroy();\n this.indexBuffer.destroy();\n this.programConfigurations.destroy();\n this.segments.destroy();\n this.dynamicLayoutVertexBuffer.destroy();\n this.opacityVertexBuffer.destroy();\n};\nregister('SymbolBuffers', SymbolBuffers);\nvar CollisionBuffers = function CollisionBuffers(LayoutArray, layoutAttributes, IndexArray) {\n this.layoutVertexArray = new LayoutArray();\n this.layoutAttributes = layoutAttributes;\n this.indexArray = new IndexArray();\n this.segments = new SegmentVector();\n this.collisionVertexArray = new StructArrayLayout2ub2f12();\n};\nCollisionBuffers.prototype.upload = function upload(context) {\n this.layoutVertexBuffer = context.createVertexBuffer(this.layoutVertexArray, this.layoutAttributes);\n this.indexBuffer = context.createIndexBuffer(this.indexArray);\n this.collisionVertexBuffer = context.createVertexBuffer(this.collisionVertexArray, collisionVertexAttributes.members, true);\n};\nCollisionBuffers.prototype.destroy = function destroy() {\n if (!this.layoutVertexBuffer) {\n return;\n }\n this.layoutVertexBuffer.destroy();\n this.indexBuffer.destroy();\n this.segments.destroy();\n this.collisionVertexBuffer.destroy();\n};\nregister('CollisionBuffers', CollisionBuffers);\nvar SymbolBucket = function SymbolBucket(options) {\n this.collisionBoxArray = options.collisionBoxArray;\n this.zoom = options.zoom;\n this.overscaling = options.overscaling;\n this.layers = options.layers;\n this.layerIds = this.layers.map(function (layer) {\n return layer.id;\n });\n this.index = options.index;\n this.pixelRatio = options.pixelRatio;\n this.sourceLayerIndex = options.sourceLayerIndex;\n this.hasPattern = false;\n this.hasRTLText = false;\n this.sortKeyRanges = [];\n this.collisionCircleArray = [];\n this.placementInvProjMatrix = identity([]);\n this.placementViewportMatrix = identity([]);\n var layer = this.layers[0];\n var unevaluatedLayoutValues = layer._unevaluatedLayout._values;\n this.textSizeData = getSizeData(this.zoom, unevaluatedLayoutValues['text-size']);\n this.iconSizeData = getSizeData(this.zoom, unevaluatedLayoutValues['icon-size']);\n var layout = this.layers[0].layout;\n var sortKey = layout.get('symbol-sort-key');\n var zOrder = layout.get('symbol-z-order');\n this.canOverlap = layout.get('text-allow-overlap') || layout.get('icon-allow-overlap') || layout.get('text-ignore-placement') || layout.get('icon-ignore-placement');\n this.sortFeaturesByKey = zOrder !== 'viewport-y' && sortKey.constantOr(1) !== undefined;\n var zOrderByViewportY = zOrder === 'viewport-y' || zOrder === 'auto' && !this.sortFeaturesByKey;\n this.sortFeaturesByY = zOrderByViewportY && this.canOverlap;\n if (layout.get('symbol-placement') === 'point') {\n this.writingModes = layout.get('text-writing-mode').map(function (wm) {\n return WritingMode[wm];\n });\n }\n this.stateDependentLayerIds = this.layers.filter(function (l) {\n return l.isStateDependent();\n }).map(function (l) {\n return l.id;\n });\n this.sourceID = options.sourceID;\n};\nSymbolBucket.prototype.createArrays = function createArrays() {\n this.text = new SymbolBuffers(new ProgramConfigurationSet(this.layers, this.zoom, function (property) {\n return /^text/.test(property);\n }));\n this.icon = new SymbolBuffers(new ProgramConfigurationSet(this.layers, this.zoom, function (property) {\n return /^icon/.test(property);\n }));\n this.glyphOffsetArray = new GlyphOffsetArray();\n this.lineVertexArray = new SymbolLineVertexArray();\n this.symbolInstances = new SymbolInstanceArray();\n};\nSymbolBucket.prototype.calculateGlyphDependencies = function calculateGlyphDependencies(text, stack, textAlongLine, allowVerticalPlacement, doesAllowVerticalWritingMode) {\n for (var i = 0; i < text.length; i++) {\n stack[text.charCodeAt(i)] = true;\n if ((textAlongLine || allowVerticalPlacement) && doesAllowVerticalWritingMode) {\n var verticalChar = verticalizedCharacterMap[text.charAt(i)];\n if (verticalChar) {\n stack[verticalChar.charCodeAt(0)] = true;\n }\n }\n }\n};\nSymbolBucket.prototype.populate = function populate(features, options, canonical) {\n var layer = this.layers[0];\n var layout = layer.layout;\n var textFont = layout.get('text-font');\n var textField = layout.get('text-field');\n var iconImage = layout.get('icon-image');\n var hasText = (textField.value.kind !== 'constant' || textField.value.value instanceof Formatted && !textField.value.value.isEmpty() || textField.value.value.toString().length > 0) && (textFont.value.kind !== 'constant' || textFont.value.value.length > 0);\n var hasIcon = iconImage.value.kind !== 'constant' || !!iconImage.value.value || Object.keys(iconImage.parameters).length > 0;\n var symbolSortKey = layout.get('symbol-sort-key');\n this.features = [];\n if (!hasText && !hasIcon) {\n return;\n }\n var icons = options.iconDependencies;\n var stacks = options.glyphDependencies;\n var availableImages = options.availableImages;\n var globalProperties = new EvaluationParameters(this.zoom);\n for (var i$1 = 0, list$1 = features; i$1 < list$1.length; i$1 += 1) {\n var ref = list$1[i$1];\n var feature = ref.feature;\n var id = ref.id;\n var index = ref.index;\n var sourceLayerIndex = ref.sourceLayerIndex;\n var needGeometry = layer._featureFilter.needGeometry;\n var evaluationFeature = toEvaluationFeature(feature, needGeometry);\n if (!layer._featureFilter.filter(globalProperties, evaluationFeature, canonical)) {\n continue;\n }\n if (!needGeometry) {\n evaluationFeature.geometry = loadGeometry(feature);\n }\n var text = void 0;\n if (hasText) {\n var resolvedTokens = layer.getValueAndResolveTokens('text-field', evaluationFeature, canonical, availableImages);\n var formattedText = Formatted.factory(resolvedTokens);\n if (containsRTLText(formattedText)) {\n this.hasRTLText = true;\n }\n if (!this.hasRTLText || getRTLTextPluginStatus() === 'unavailable' || this.hasRTLText && plugin.isParsed()) {\n text = transformText$1(formattedText, layer, evaluationFeature);\n }\n }\n var icon = void 0;\n if (hasIcon) {\n var resolvedTokens$1 = layer.getValueAndResolveTokens('icon-image', evaluationFeature, canonical, availableImages);\n if (resolvedTokens$1 instanceof ResolvedImage) {\n icon = resolvedTokens$1;\n } else {\n icon = ResolvedImage.fromString(resolvedTokens$1);\n }\n }\n if (!text && !icon) {\n continue;\n }\n var sortKey = this.sortFeaturesByKey ? symbolSortKey.evaluate(evaluationFeature, {}, canonical) : undefined;\n var symbolFeature = {\n id: id,\n text: text,\n icon: icon,\n index: index,\n sourceLayerIndex: sourceLayerIndex,\n geometry: evaluationFeature.geometry,\n properties: feature.properties,\n type: vectorTileFeatureTypes$2[feature.type],\n sortKey: sortKey\n };\n this.features.push(symbolFeature);\n if (icon) {\n icons[icon.name] = true;\n }\n if (text) {\n var fontStack = textFont.evaluate(evaluationFeature, {}, canonical).join(',');\n var textAlongLine = layout.get('text-rotation-alignment') === 'map' && layout.get('symbol-placement') !== 'point';\n this.allowVerticalPlacement = this.writingModes && this.writingModes.indexOf(WritingMode.vertical) >= 0;\n for (var i = 0, list = text.sections; i < list.length; i += 1) {\n var section = list[i];\n if (!section.image) {\n var doesAllowVerticalWritingMode = allowsVerticalWritingMode(text.toString());\n var sectionFont = section.fontStack || fontStack;\n var sectionStack = stacks[sectionFont] = stacks[sectionFont] || {};\n this.calculateGlyphDependencies(section.text, sectionStack, textAlongLine, this.allowVerticalPlacement, doesAllowVerticalWritingMode);\n } else {\n icons[section.image.name] = true;\n }\n }\n }\n }\n if (layout.get('symbol-placement') === 'line') {\n this.features = mergeLines(this.features);\n }\n if (this.sortFeaturesByKey) {\n this.features.sort(function (a, b) {\n return a.sortKey - b.sortKey;\n });\n }\n};\nSymbolBucket.prototype.update = function update(states, vtLayer, imagePositions) {\n if (!this.stateDependentLayers.length) {\n return;\n }\n this.text.programConfigurations.updatePaintArrays(states, vtLayer, this.layers, imagePositions);\n this.icon.programConfigurations.updatePaintArrays(states, vtLayer, this.layers, imagePositions);\n};\nSymbolBucket.prototype.isEmpty = function isEmpty() {\n return this.symbolInstances.length === 0 && !this.hasRTLText;\n};\nSymbolBucket.prototype.uploadPending = function uploadPending() {\n return !this.uploaded || this.text.programConfigurations.needsUpload || this.icon.programConfigurations.needsUpload;\n};\nSymbolBucket.prototype.upload = function upload(context) {\n if (!this.uploaded && this.hasDebugData()) {\n this.textCollisionBox.upload(context);\n this.iconCollisionBox.upload(context);\n }\n this.text.upload(context, this.sortFeaturesByY, !this.uploaded, this.text.programConfigurations.needsUpload);\n this.icon.upload(context, this.sortFeaturesByY, !this.uploaded, this.icon.programConfigurations.needsUpload);\n this.uploaded = true;\n};\nSymbolBucket.prototype.destroyDebugData = function destroyDebugData() {\n this.textCollisionBox.destroy();\n this.iconCollisionBox.destroy();\n};\nSymbolBucket.prototype.destroy = function destroy() {\n this.text.destroy();\n this.icon.destroy();\n if (this.hasDebugData()) {\n this.destroyDebugData();\n }\n};\nSymbolBucket.prototype.addToLineVertexArray = function addToLineVertexArray(anchor, line) {\n var lineStartIndex = this.lineVertexArray.length;\n if (anchor.segment !== undefined) {\n var sumForwardLength = anchor.dist(line[anchor.segment + 1]);\n var sumBackwardLength = anchor.dist(line[anchor.segment]);\n var vertices = {};\n for (var i = anchor.segment + 1; i < line.length; i++) {\n vertices[i] = {\n x: line[i].x,\n y: line[i].y,\n tileUnitDistanceFromAnchor: sumForwardLength\n };\n if (i < line.length - 1) {\n sumForwardLength += line[i + 1].dist(line[i]);\n }\n }\n for (var i$1 = anchor.segment || 0; i$1 >= 0; i$1--) {\n vertices[i$1] = {\n x: line[i$1].x,\n y: line[i$1].y,\n tileUnitDistanceFromAnchor: sumBackwardLength\n };\n if (i$1 > 0) {\n sumBackwardLength += line[i$1 - 1].dist(line[i$1]);\n }\n }\n for (var i$2 = 0; i$2 < line.length; i$2++) {\n var vertex = vertices[i$2];\n this.lineVertexArray.emplaceBack(vertex.x, vertex.y, vertex.tileUnitDistanceFromAnchor);\n }\n }\n return {\n lineStartIndex: lineStartIndex,\n lineLength: this.lineVertexArray.length - lineStartIndex\n };\n};\nSymbolBucket.prototype.addSymbols = function addSymbols(arrays, quads, sizeVertex, lineOffset, alongLine, feature, writingMode, labelAnchor, lineStartIndex, lineLength, associatedIconIndex, canonical) {\n var indexArray = arrays.indexArray;\n var layoutVertexArray = arrays.layoutVertexArray;\n var segment = arrays.segments.prepareSegment(4 * quads.length, layoutVertexArray, indexArray, this.canOverlap ? feature.sortKey : undefined);\n var glyphOffsetArrayStart = this.glyphOffsetArray.length;\n var vertexStartIndex = segment.vertexLength;\n var angle = this.allowVerticalPlacement && writingMode === WritingMode.vertical ? Math.PI / 2 : 0;\n var sections = feature.text && feature.text.sections;\n for (var i = 0; i < quads.length; i++) {\n var ref = quads[i];\n var tl = ref.tl;\n var tr = ref.tr;\n var bl = ref.bl;\n var br = ref.br;\n var tex = ref.tex;\n var pixelOffsetTL = ref.pixelOffsetTL;\n var pixelOffsetBR = ref.pixelOffsetBR;\n var minFontScaleX = ref.minFontScaleX;\n var minFontScaleY = ref.minFontScaleY;\n var glyphOffset = ref.glyphOffset;\n var isSDF = ref.isSDF;\n var sectionIndex = ref.sectionIndex;\n var index = segment.vertexLength;\n var y = glyphOffset[1];\n addVertex$1(layoutVertexArray, labelAnchor.x, labelAnchor.y, tl.x, y + tl.y, tex.x, tex.y, sizeVertex, isSDF, pixelOffsetTL.x, pixelOffsetTL.y, minFontScaleX, minFontScaleY);\n addVertex$1(layoutVertexArray, labelAnchor.x, labelAnchor.y, tr.x, y + tr.y, tex.x + tex.w, tex.y, sizeVertex, isSDF, pixelOffsetBR.x, pixelOffsetTL.y, minFontScaleX, minFontScaleY);\n addVertex$1(layoutVertexArray, labelAnchor.x, labelAnchor.y, bl.x, y + bl.y, tex.x, tex.y + tex.h, sizeVertex, isSDF, pixelOffsetTL.x, pixelOffsetBR.y, minFontScaleX, minFontScaleY);\n addVertex$1(layoutVertexArray, labelAnchor.x, labelAnchor.y, br.x, y + br.y, tex.x + tex.w, tex.y + tex.h, sizeVertex, isSDF, pixelOffsetBR.x, pixelOffsetBR.y, minFontScaleX, minFontScaleY);\n addDynamicAttributes(arrays.dynamicLayoutVertexArray, labelAnchor, angle);\n indexArray.emplaceBack(index, index + 1, index + 2);\n indexArray.emplaceBack(index + 1, index + 2, index + 3);\n segment.vertexLength += 4;\n segment.primitiveLength += 2;\n this.glyphOffsetArray.emplaceBack(glyphOffset[0]);\n if (i === quads.length - 1 || sectionIndex !== quads[i + 1].sectionIndex) {\n arrays.programConfigurations.populatePaintArrays(layoutVertexArray.length, feature, feature.index, {}, canonical, sections && sections[sectionIndex]);\n }\n }\n arrays.placedSymbolArray.emplaceBack(labelAnchor.x, labelAnchor.y, glyphOffsetArrayStart, this.glyphOffsetArray.length - glyphOffsetArrayStart, vertexStartIndex, lineStartIndex, lineLength, labelAnchor.segment, sizeVertex ? sizeVertex[0] : 0, sizeVertex ? sizeVertex[1] : 0, lineOffset[0], lineOffset[1], writingMode, 0, false, 0, associatedIconIndex);\n};\nSymbolBucket.prototype._addCollisionDebugVertex = function _addCollisionDebugVertex(layoutVertexArray, collisionVertexArray, point, anchorX, anchorY, extrude) {\n collisionVertexArray.emplaceBack(0, 0);\n return layoutVertexArray.emplaceBack(point.x, point.y, anchorX, anchorY, Math.round(extrude.x), Math.round(extrude.y));\n};\nSymbolBucket.prototype.addCollisionDebugVertices = function addCollisionDebugVertices(x1, y1, x2, y2, arrays, boxAnchorPoint, symbolInstance) {\n var segment = arrays.segments.prepareSegment(4, arrays.layoutVertexArray, arrays.indexArray);\n var index = segment.vertexLength;\n var layoutVertexArray = arrays.layoutVertexArray;\n var collisionVertexArray = arrays.collisionVertexArray;\n var anchorX = symbolInstance.anchorX;\n var anchorY = symbolInstance.anchorY;\n this._addCollisionDebugVertex(layoutVertexArray, collisionVertexArray, boxAnchorPoint, anchorX, anchorY, new pointGeometry(x1, y1));\n this._addCollisionDebugVertex(layoutVertexArray, collisionVertexArray, boxAnchorPoint, anchorX, anchorY, new pointGeometry(x2, y1));\n this._addCollisionDebugVertex(layoutVertexArray, collisionVertexArray, boxAnchorPoint, anchorX, anchorY, new pointGeometry(x2, y2));\n this._addCollisionDebugVertex(layoutVertexArray, collisionVertexArray, boxAnchorPoint, anchorX, anchorY, new pointGeometry(x1, y2));\n segment.vertexLength += 4;\n var indexArray = arrays.indexArray;\n indexArray.emplaceBack(index, index + 1);\n indexArray.emplaceBack(index + 1, index + 2);\n indexArray.emplaceBack(index + 2, index + 3);\n indexArray.emplaceBack(index + 3, index);\n segment.primitiveLength += 4;\n};\nSymbolBucket.prototype.addDebugCollisionBoxes = function addDebugCollisionBoxes(startIndex, endIndex, symbolInstance, isText) {\n for (var b = startIndex; b < endIndex; b++) {\n var box = this.collisionBoxArray.get(b);\n var x1 = box.x1;\n var y1 = box.y1;\n var x2 = box.x2;\n var y2 = box.y2;\n this.addCollisionDebugVertices(x1, y1, x2, y2, isText ? this.textCollisionBox : this.iconCollisionBox, box.anchorPoint, symbolInstance);\n }\n};\nSymbolBucket.prototype.generateCollisionDebugBuffers = function generateCollisionDebugBuffers() {\n if (this.hasDebugData()) {\n this.destroyDebugData();\n }\n this.textCollisionBox = new CollisionBuffers(StructArrayLayout2i2i2i12, collisionBoxLayout.members, StructArrayLayout2ui4);\n this.iconCollisionBox = new CollisionBuffers(StructArrayLayout2i2i2i12, collisionBoxLayout.members, StructArrayLayout2ui4);\n for (var i = 0; i < this.symbolInstances.length; i++) {\n var symbolInstance = this.symbolInstances.get(i);\n this.addDebugCollisionBoxes(symbolInstance.textBoxStartIndex, symbolInstance.textBoxEndIndex, symbolInstance, true);\n this.addDebugCollisionBoxes(symbolInstance.verticalTextBoxStartIndex, symbolInstance.verticalTextBoxEndIndex, symbolInstance, true);\n this.addDebugCollisionBoxes(symbolInstance.iconBoxStartIndex, symbolInstance.iconBoxEndIndex, symbolInstance, false);\n this.addDebugCollisionBoxes(symbolInstance.verticalIconBoxStartIndex, symbolInstance.verticalIconBoxEndIndex, symbolInstance, false);\n }\n};\nSymbolBucket.prototype._deserializeCollisionBoxesForSymbol = function _deserializeCollisionBoxesForSymbol(collisionBoxArray, textStartIndex, textEndIndex, verticalTextStartIndex, verticalTextEndIndex, iconStartIndex, iconEndIndex, verticalIconStartIndex, verticalIconEndIndex) {\n var collisionArrays = {};\n for (var k = textStartIndex; k < textEndIndex; k++) {\n var box = collisionBoxArray.get(k);\n collisionArrays.textBox = {\n x1: box.x1,\n y1: box.y1,\n x2: box.x2,\n y2: box.y2,\n anchorPointX: box.anchorPointX,\n anchorPointY: box.anchorPointY\n };\n collisionArrays.textFeatureIndex = box.featureIndex;\n break;\n }\n for (var k$1 = verticalTextStartIndex; k$1 < verticalTextEndIndex; k$1++) {\n var box$1 = collisionBoxArray.get(k$1);\n collisionArrays.verticalTextBox = {\n x1: box$1.x1,\n y1: box$1.y1,\n x2: box$1.x2,\n y2: box$1.y2,\n anchorPointX: box$1.anchorPointX,\n anchorPointY: box$1.anchorPointY\n };\n collisionArrays.verticalTextFeatureIndex = box$1.featureIndex;\n break;\n }\n for (var k$2 = iconStartIndex; k$2 < iconEndIndex; k$2++) {\n var box$2 = collisionBoxArray.get(k$2);\n collisionArrays.iconBox = {\n x1: box$2.x1,\n y1: box$2.y1,\n x2: box$2.x2,\n y2: box$2.y2,\n anchorPointX: box$2.anchorPointX,\n anchorPointY: box$2.anchorPointY\n };\n collisionArrays.iconFeatureIndex = box$2.featureIndex;\n break;\n }\n for (var k$3 = verticalIconStartIndex; k$3 < verticalIconEndIndex; k$3++) {\n var box$3 = collisionBoxArray.get(k$3);\n collisionArrays.verticalIconBox = {\n x1: box$3.x1,\n y1: box$3.y1,\n x2: box$3.x2,\n y2: box$3.y2,\n anchorPointX: box$3.anchorPointX,\n anchorPointY: box$3.anchorPointY\n };\n collisionArrays.verticalIconFeatureIndex = box$3.featureIndex;\n break;\n }\n return collisionArrays;\n};\nSymbolBucket.prototype.deserializeCollisionBoxes = function deserializeCollisionBoxes(collisionBoxArray) {\n this.collisionArrays = [];\n for (var i = 0; i < this.symbolInstances.length; i++) {\n var symbolInstance = this.symbolInstances.get(i);\n this.collisionArrays.push(this._deserializeCollisionBoxesForSymbol(collisionBoxArray, symbolInstance.textBoxStartIndex, symbolInstance.textBoxEndIndex, symbolInstance.verticalTextBoxStartIndex, symbolInstance.verticalTextBoxEndIndex, symbolInstance.iconBoxStartIndex, symbolInstance.iconBoxEndIndex, symbolInstance.verticalIconBoxStartIndex, symbolInstance.verticalIconBoxEndIndex));\n }\n};\nSymbolBucket.prototype.hasTextData = function hasTextData() {\n return this.text.segments.get().length > 0;\n};\nSymbolBucket.prototype.hasIconData = function hasIconData() {\n return this.icon.segments.get().length > 0;\n};\nSymbolBucket.prototype.hasDebugData = function hasDebugData() {\n return this.textCollisionBox && this.iconCollisionBox;\n};\nSymbolBucket.prototype.hasTextCollisionBoxData = function hasTextCollisionBoxData() {\n return this.hasDebugData() && this.textCollisionBox.segments.get().length > 0;\n};\nSymbolBucket.prototype.hasIconCollisionBoxData = function hasIconCollisionBoxData() {\n return this.hasDebugData() && this.iconCollisionBox.segments.get().length > 0;\n};\nSymbolBucket.prototype.addIndicesForPlacedSymbol = function addIndicesForPlacedSymbol(iconOrText, placedSymbolIndex) {\n var placedSymbol = iconOrText.placedSymbolArray.get(placedSymbolIndex);\n var endIndex = placedSymbol.vertexStartIndex + placedSymbol.numGlyphs * 4;\n for (var vertexIndex = placedSymbol.vertexStartIndex; vertexIndex < endIndex; vertexIndex += 4) {\n iconOrText.indexArray.emplaceBack(vertexIndex, vertexIndex + 1, vertexIndex + 2);\n iconOrText.indexArray.emplaceBack(vertexIndex + 1, vertexIndex + 2, vertexIndex + 3);\n }\n};\nSymbolBucket.prototype.getSortedSymbolIndexes = function getSortedSymbolIndexes(angle) {\n if (this.sortedAngle === angle && this.symbolInstanceIndexes !== undefined) {\n return this.symbolInstanceIndexes;\n }\n var sin = Math.sin(angle);\n var cos = Math.cos(angle);\n var rotatedYs = [];\n var featureIndexes = [];\n var result = [];\n for (var i = 0; i < this.symbolInstances.length; ++i) {\n result.push(i);\n var symbolInstance = this.symbolInstances.get(i);\n rotatedYs.push(Math.round(sin * symbolInstance.anchorX + cos * symbolInstance.anchorY) | 0);\n featureIndexes.push(symbolInstance.featureIndex);\n }\n result.sort(function (aIndex, bIndex) {\n return rotatedYs[aIndex] - rotatedYs[bIndex] || featureIndexes[bIndex] - featureIndexes[aIndex];\n });\n return result;\n};\nSymbolBucket.prototype.addToSortKeyRanges = function addToSortKeyRanges(symbolInstanceIndex, sortKey) {\n var last = this.sortKeyRanges[this.sortKeyRanges.length - 1];\n if (last && last.sortKey === sortKey) {\n last.symbolInstanceEnd = symbolInstanceIndex + 1;\n } else {\n this.sortKeyRanges.push({\n sortKey: sortKey,\n symbolInstanceStart: symbolInstanceIndex,\n symbolInstanceEnd: symbolInstanceIndex + 1\n });\n }\n};\nSymbolBucket.prototype.sortFeatures = function sortFeatures(angle) {\n var this$1 = this;\n if (!this.sortFeaturesByY) {\n return;\n }\n if (this.sortedAngle === angle) {\n return;\n }\n if (this.text.segments.get().length > 1 || this.icon.segments.get().length > 1) {\n return;\n }\n this.symbolInstanceIndexes = this.getSortedSymbolIndexes(angle);\n this.sortedAngle = angle;\n this.text.indexArray.clear();\n this.icon.indexArray.clear();\n this.featureSortOrder = [];\n for (var i$1 = 0, list = this.symbolInstanceIndexes; i$1 < list.length; i$1 += 1) {\n var i = list[i$1];\n var symbolInstance = this.symbolInstances.get(i);\n this.featureSortOrder.push(symbolInstance.featureIndex);\n [\n symbolInstance.rightJustifiedTextSymbolIndex,\n symbolInstance.centerJustifiedTextSymbolIndex,\n symbolInstance.leftJustifiedTextSymbolIndex\n ].forEach(function (index, i, array) {\n if (index >= 0 && array.indexOf(index) === i) {\n this$1.addIndicesForPlacedSymbol(this$1.text, index);\n }\n });\n if (symbolInstance.verticalPlacedTextSymbolIndex >= 0) {\n this.addIndicesForPlacedSymbol(this.text, symbolInstance.verticalPlacedTextSymbolIndex);\n }\n if (symbolInstance.placedIconSymbolIndex >= 0) {\n this.addIndicesForPlacedSymbol(this.icon, symbolInstance.placedIconSymbolIndex);\n }\n if (symbolInstance.verticalPlacedIconSymbolIndex >= 0) {\n this.addIndicesForPlacedSymbol(this.icon, symbolInstance.verticalPlacedIconSymbolIndex);\n }\n }\n if (this.text.indexBuffer) {\n this.text.indexBuffer.updateData(this.text.indexArray);\n }\n if (this.icon.indexBuffer) {\n this.icon.indexBuffer.updateData(this.icon.indexArray);\n }\n};\nregister('SymbolBucket', SymbolBucket, {\n omit: [\n 'layers',\n 'collisionBoxArray',\n 'features',\n 'compareText'\n ]\n});\nSymbolBucket.MAX_GLYPHS = 65535;\nSymbolBucket.addDynamicAttributes = addDynamicAttributes;\n\nfunction resolveTokens(properties, text) {\n return text.replace(/{([^{}]+)}/g, function (match, key) {\n return key in properties ? String(properties[key]) : '';\n });\n}\n\nvar layout$7 = new Properties({\n 'symbol-placement': new DataConstantProperty(spec['layout_symbol']['symbol-placement']),\n 'symbol-spacing': new DataConstantProperty(spec['layout_symbol']['symbol-spacing']),\n 'symbol-avoid-edges': new DataConstantProperty(spec['layout_symbol']['symbol-avoid-edges']),\n 'symbol-sort-key': new DataDrivenProperty(spec['layout_symbol']['symbol-sort-key']),\n 'symbol-z-order': new DataConstantProperty(spec['layout_symbol']['symbol-z-order']),\n 'icon-allow-overlap': new DataConstantProperty(spec['layout_symbol']['icon-allow-overlap']),\n 'icon-ignore-placement': new DataConstantProperty(spec['layout_symbol']['icon-ignore-placement']),\n 'icon-optional': new DataConstantProperty(spec['layout_symbol']['icon-optional']),\n 'icon-rotation-alignment': new DataConstantProperty(spec['layout_symbol']['icon-rotation-alignment']),\n 'icon-size': new DataDrivenProperty(spec['layout_symbol']['icon-size']),\n 'icon-text-fit': new DataConstantProperty(spec['layout_symbol']['icon-text-fit']),\n 'icon-text-fit-padding': new DataConstantProperty(spec['layout_symbol']['icon-text-fit-padding']),\n 'icon-image': new DataDrivenProperty(spec['layout_symbol']['icon-image']),\n 'icon-rotate': new DataDrivenProperty(spec['layout_symbol']['icon-rotate']),\n 'icon-padding': new DataConstantProperty(spec['layout_symbol']['icon-padding']),\n 'icon-keep-upright': new DataConstantProperty(spec['layout_symbol']['icon-keep-upright']),\n 'icon-offset': new DataDrivenProperty(spec['layout_symbol']['icon-offset']),\n 'icon-anchor': new DataDrivenProperty(spec['layout_symbol']['icon-anchor']),\n 'icon-pitch-alignment': new DataConstantProperty(spec['layout_symbol']['icon-pitch-alignment']),\n 'text-pitch-alignment': new DataConstantProperty(spec['layout_symbol']['text-pitch-alignment']),\n 'text-rotation-alignment': new DataConstantProperty(spec['layout_symbol']['text-rotation-alignment']),\n 'text-field': new DataDrivenProperty(spec['layout_symbol']['text-field']),\n 'text-font': new DataDrivenProperty(spec['layout_symbol']['text-font']),\n 'text-size': new DataDrivenProperty(spec['layout_symbol']['text-size']),\n 'text-max-width': new DataDrivenProperty(spec['layout_symbol']['text-max-width']),\n 'text-line-height': new DataConstantProperty(spec['layout_symbol']['text-line-height']),\n 'text-letter-spacing': new DataDrivenProperty(spec['layout_symbol']['text-letter-spacing']),\n 'text-justify': new DataDrivenProperty(spec['layout_symbol']['text-justify']),\n 'text-radial-offset': new DataDrivenProperty(spec['layout_symbol']['text-radial-offset']),\n 'text-variable-anchor': new DataConstantProperty(spec['layout_symbol']['text-variable-anchor']),\n 'text-anchor': new DataDrivenProperty(spec['layout_symbol']['text-anchor']),\n 'text-max-angle': new DataConstantProperty(spec['layout_symbol']['text-max-angle']),\n 'text-writing-mode': new DataConstantProperty(spec['layout_symbol']['text-writing-mode']),\n 'text-rotate': new DataDrivenProperty(spec['layout_symbol']['text-rotate']),\n 'text-padding': new DataConstantProperty(spec['layout_symbol']['text-padding']),\n 'text-keep-upright': new DataConstantProperty(spec['layout_symbol']['text-keep-upright']),\n 'text-transform': new DataDrivenProperty(spec['layout_symbol']['text-transform']),\n 'text-offset': new DataDrivenProperty(spec['layout_symbol']['text-offset']),\n 'text-allow-overlap': new DataConstantProperty(spec['layout_symbol']['text-allow-overlap']),\n 'text-ignore-placement': new DataConstantProperty(spec['layout_symbol']['text-ignore-placement']),\n 'text-optional': new DataConstantProperty(spec['layout_symbol']['text-optional'])\n});\nvar paint$7 = new Properties({\n 'icon-opacity': new DataDrivenProperty(spec['paint_symbol']['icon-opacity']),\n 'icon-color': new DataDrivenProperty(spec['paint_symbol']['icon-color']),\n 'icon-halo-color': new DataDrivenProperty(spec['paint_symbol']['icon-halo-color']),\n 'icon-halo-width': new DataDrivenProperty(spec['paint_symbol']['icon-halo-width']),\n 'icon-halo-blur': new DataDrivenProperty(spec['paint_symbol']['icon-halo-blur']),\n 'icon-translate': new DataConstantProperty(spec['paint_symbol']['icon-translate']),\n 'icon-translate-anchor': new DataConstantProperty(spec['paint_symbol']['icon-translate-anchor']),\n 'text-opacity': new DataDrivenProperty(spec['paint_symbol']['text-opacity']),\n 'text-color': new DataDrivenProperty(spec['paint_symbol']['text-color'], {\n runtimeType: ColorType,\n getOverride: function (o) {\n return o.textColor;\n },\n hasOverride: function (o) {\n return !!o.textColor;\n }\n }),\n 'text-halo-color': new DataDrivenProperty(spec['paint_symbol']['text-halo-color']),\n 'text-halo-width': new DataDrivenProperty(spec['paint_symbol']['text-halo-width']),\n 'text-halo-blur': new DataDrivenProperty(spec['paint_symbol']['text-halo-blur']),\n 'text-translate': new DataConstantProperty(spec['paint_symbol']['text-translate']),\n 'text-translate-anchor': new DataConstantProperty(spec['paint_symbol']['text-translate-anchor'])\n});\nvar properties$6 = {\n paint: paint$7,\n layout: layout$7\n};\n\nvar FormatSectionOverride = function FormatSectionOverride(defaultValue) {\n this.type = defaultValue.property.overrides ? defaultValue.property.overrides.runtimeType : NullType;\n this.defaultValue = defaultValue;\n};\nFormatSectionOverride.prototype.evaluate = function evaluate(ctx) {\n if (ctx.formattedSection) {\n var overrides = this.defaultValue.property.overrides;\n if (overrides && overrides.hasOverride(ctx.formattedSection)) {\n return overrides.getOverride(ctx.formattedSection);\n }\n }\n if (ctx.feature && ctx.featureState) {\n return this.defaultValue.evaluate(ctx.feature, ctx.featureState);\n }\n return this.defaultValue.property.specification.default;\n};\nFormatSectionOverride.prototype.eachChild = function eachChild(fn) {\n if (!this.defaultValue.isConstant()) {\n var expr = this.defaultValue.value;\n fn(expr._styleExpression.expression);\n }\n};\nFormatSectionOverride.prototype.outputDefined = function outputDefined() {\n return false;\n};\nFormatSectionOverride.prototype.serialize = function serialize() {\n return null;\n};\nregister('FormatSectionOverride', FormatSectionOverride, { omit: ['defaultValue'] });\n\nvar SymbolStyleLayer = function (StyleLayer) {\n function SymbolStyleLayer(layer) {\n StyleLayer.call(this, layer, properties$6);\n }\n if (StyleLayer)\n SymbolStyleLayer.__proto__ = StyleLayer;\n SymbolStyleLayer.prototype = Object.create(StyleLayer && StyleLayer.prototype);\n SymbolStyleLayer.prototype.constructor = SymbolStyleLayer;\n SymbolStyleLayer.prototype.recalculate = function recalculate(parameters, availableImages) {\n StyleLayer.prototype.recalculate.call(this, parameters, availableImages);\n if (this.layout.get('icon-rotation-alignment') === 'auto') {\n if (this.layout.get('symbol-placement') !== 'point') {\n this.layout._values['icon-rotation-alignment'] = 'map';\n } else {\n this.layout._values['icon-rotation-alignment'] = 'viewport';\n }\n }\n if (this.layout.get('text-rotation-alignment') === 'auto') {\n if (this.layout.get('symbol-placement') !== 'point') {\n this.layout._values['text-rotation-alignment'] = 'map';\n } else {\n this.layout._values['text-rotation-alignment'] = 'viewport';\n }\n }\n if (this.layout.get('text-pitch-alignment') === 'auto') {\n this.layout._values['text-pitch-alignment'] = this.layout.get('text-rotation-alignment');\n }\n if (this.layout.get('icon-pitch-alignment') === 'auto') {\n this.layout._values['icon-pitch-alignment'] = this.layout.get('icon-rotation-alignment');\n }\n if (this.layout.get('symbol-placement') === 'point') {\n var writingModes = this.layout.get('text-writing-mode');\n if (writingModes) {\n var deduped = [];\n for (var i = 0, list = writingModes; i < list.length; i += 1) {\n var m = list[i];\n if (deduped.indexOf(m) < 0) {\n deduped.push(m);\n }\n }\n this.layout._values['text-writing-mode'] = deduped;\n } else {\n this.layout._values['text-writing-mode'] = ['horizontal'];\n }\n }\n this._setPaintOverrides();\n };\n SymbolStyleLayer.prototype.getValueAndResolveTokens = function getValueAndResolveTokens(name, feature, canonical, availableImages) {\n var value = this.layout.get(name).evaluate(feature, {}, canonical, availableImages);\n var unevaluated = this._unevaluatedLayout._values[name];\n if (!unevaluated.isDataDriven() && !isExpression(unevaluated.value) && value) {\n return resolveTokens(feature.properties, value);\n }\n return value;\n };\n SymbolStyleLayer.prototype.createBucket = function createBucket(parameters) {\n return new SymbolBucket(parameters);\n };\n SymbolStyleLayer.prototype.queryRadius = function queryRadius() {\n return 0;\n };\n SymbolStyleLayer.prototype.queryIntersectsFeature = function queryIntersectsFeature() {\n return false;\n };\n SymbolStyleLayer.prototype._setPaintOverrides = function _setPaintOverrides() {\n for (var i = 0, list = properties$6.paint.overridableProperties; i < list.length; i += 1) {\n var overridable = list[i];\n if (!SymbolStyleLayer.hasPaintOverride(this.layout, overridable)) {\n continue;\n }\n var overriden = this.paint.get(overridable);\n var override = new FormatSectionOverride(overriden);\n var styleExpression = new StyleExpression(override, overriden.property.specification);\n var expression = null;\n if (overriden.value.kind === 'constant' || overriden.value.kind === 'source') {\n expression = new ZoomConstantExpression('source', styleExpression);\n } else {\n expression = new ZoomDependentExpression('composite', styleExpression, overriden.value.zoomStops, overriden.value._interpolationType);\n }\n this.paint._values[overridable] = new PossiblyEvaluatedPropertyValue(overriden.property, expression, overriden.parameters);\n }\n };\n SymbolStyleLayer.prototype._handleOverridablePaintPropertyUpdate = function _handleOverridablePaintPropertyUpdate(name, oldValue, newValue) {\n if (!this.layout || oldValue.isDataDriven() || newValue.isDataDriven()) {\n return false;\n }\n return SymbolStyleLayer.hasPaintOverride(this.layout, name);\n };\n SymbolStyleLayer.hasPaintOverride = function hasPaintOverride(layout, propertyName) {\n var textField = layout.get('text-field');\n var property = properties$6.paint.properties[propertyName];\n var hasOverrides = false;\n var checkSections = function (sections) {\n for (var i = 0, list = sections; i < list.length; i += 1) {\n var section = list[i];\n if (property.overrides && property.overrides.hasOverride(section)) {\n hasOverrides = true;\n return;\n }\n }\n };\n if (textField.value.kind === 'constant' && textField.value.value instanceof Formatted) {\n checkSections(textField.value.value.sections);\n } else if (textField.value.kind === 'source') {\n var checkExpression = function (expression) {\n if (hasOverrides) {\n return;\n }\n if (expression instanceof Literal && typeOf(expression.value) === FormattedType) {\n var formatted = expression.value;\n checkSections(formatted.sections);\n } else if (expression instanceof FormatExpression) {\n checkSections(expression.sections);\n } else {\n expression.eachChild(checkExpression);\n }\n };\n var expr = textField.value;\n if (expr._styleExpression) {\n checkExpression(expr._styleExpression.expression);\n }\n }\n return hasOverrides;\n };\n return SymbolStyleLayer;\n}(StyleLayer);\n\nvar paint$8 = new Properties({\n 'background-color': new DataConstantProperty(spec['paint_background']['background-color']),\n 'background-pattern': new CrossFadedProperty(spec['paint_background']['background-pattern']),\n 'background-opacity': new DataConstantProperty(spec['paint_background']['background-opacity'])\n});\nvar properties$7 = { paint: paint$8 };\n\nvar BackgroundStyleLayer = function (StyleLayer) {\n function BackgroundStyleLayer(layer) {\n StyleLayer.call(this, layer, properties$7);\n }\n if (StyleLayer)\n BackgroundStyleLayer.__proto__ = StyleLayer;\n BackgroundStyleLayer.prototype = Object.create(StyleLayer && StyleLayer.prototype);\n BackgroundStyleLayer.prototype.constructor = BackgroundStyleLayer;\n return BackgroundStyleLayer;\n}(StyleLayer);\n\nvar paint$9 = new Properties({\n 'raster-opacity': new DataConstantProperty(spec['paint_raster']['raster-opacity']),\n 'raster-hue-rotate': new DataConstantProperty(spec['paint_raster']['raster-hue-rotate']),\n 'raster-brightness-min': new DataConstantProperty(spec['paint_raster']['raster-brightness-min']),\n 'raster-brightness-max': new DataConstantProperty(spec['paint_raster']['raster-brightness-max']),\n 'raster-saturation': new DataConstantProperty(spec['paint_raster']['raster-saturation']),\n 'raster-contrast': new DataConstantProperty(spec['paint_raster']['raster-contrast']),\n 'raster-resampling': new DataConstantProperty(spec['paint_raster']['raster-resampling']),\n 'raster-fade-duration': new DataConstantProperty(spec['paint_raster']['raster-fade-duration'])\n});\nvar properties$8 = { paint: paint$9 };\n\nvar RasterStyleLayer = function (StyleLayer) {\n function RasterStyleLayer(layer) {\n StyleLayer.call(this, layer, properties$8);\n }\n if (StyleLayer)\n RasterStyleLayer.__proto__ = StyleLayer;\n RasterStyleLayer.prototype = Object.create(StyleLayer && StyleLayer.prototype);\n RasterStyleLayer.prototype.constructor = RasterStyleLayer;\n return RasterStyleLayer;\n}(StyleLayer);\n\nfunction validateCustomStyleLayer(layerObject) {\n var errors = [];\n var id = layerObject.id;\n if (id === undefined) {\n errors.push({ message: 'layers.' + id + ': missing required property \"id\"' });\n }\n if (layerObject.render === undefined) {\n errors.push({ message: 'layers.' + id + ': missing required method \"render\"' });\n }\n if (layerObject.renderingMode && layerObject.renderingMode !== '2d' && layerObject.renderingMode !== '3d') {\n errors.push({ message: 'layers.' + id + ': property \"renderingMode\" must be either \"2d\" or \"3d\"' });\n }\n return errors;\n}\nvar CustomStyleLayer = function (StyleLayer) {\n function CustomStyleLayer(implementation) {\n StyleLayer.call(this, implementation, {});\n this.implementation = implementation;\n }\n if (StyleLayer)\n CustomStyleLayer.__proto__ = StyleLayer;\n CustomStyleLayer.prototype = Object.create(StyleLayer && StyleLayer.prototype);\n CustomStyleLayer.prototype.constructor = CustomStyleLayer;\n CustomStyleLayer.prototype.is3D = function is3D() {\n return this.implementation.renderingMode === '3d';\n };\n CustomStyleLayer.prototype.hasOffscreenPass = function hasOffscreenPass() {\n return this.implementation.prerender !== undefined;\n };\n CustomStyleLayer.prototype.recalculate = function recalculate() {\n };\n CustomStyleLayer.prototype.updateTransitions = function updateTransitions() {\n };\n CustomStyleLayer.prototype.hasTransition = function hasTransition() {\n };\n CustomStyleLayer.prototype.serialize = function serialize() {\n };\n CustomStyleLayer.prototype.onAdd = function onAdd(map) {\n if (this.implementation.onAdd) {\n this.implementation.onAdd(map, map.painter.context.gl);\n }\n };\n CustomStyleLayer.prototype.onRemove = function onRemove(map) {\n if (this.implementation.onRemove) {\n this.implementation.onRemove(map, map.painter.context.gl);\n }\n };\n return CustomStyleLayer;\n}(StyleLayer);\n\nvar subclasses = {\n circle: CircleStyleLayer,\n heatmap: HeatmapStyleLayer,\n hillshade: HillshadeStyleLayer,\n fill: FillStyleLayer,\n 'fill-extrusion': FillExtrusionStyleLayer,\n line: LineStyleLayer,\n symbol: SymbolStyleLayer,\n background: BackgroundStyleLayer,\n raster: RasterStyleLayer\n};\nfunction createStyleLayer(layer) {\n if (layer.type === 'custom') {\n return new CustomStyleLayer(layer);\n } else {\n return new subclasses[layer.type](layer);\n }\n}\n\nvar HTMLImageElement = window$1.HTMLImageElement;\nvar HTMLCanvasElement = window$1.HTMLCanvasElement;\nvar HTMLVideoElement = window$1.HTMLVideoElement;\nvar ImageData$1 = window$1.ImageData;\nvar ImageBitmap$1 = window$1.ImageBitmap;\nvar Texture = function Texture(context, image, format, options) {\n this.context = context;\n this.format = format;\n this.texture = context.gl.createTexture();\n this.update(image, options);\n};\nTexture.prototype.update = function update(image, options, position) {\n var width = image.width;\n var height = image.height;\n var resize = (!this.size || this.size[0] !== width || this.size[1] !== height) && !position;\n var ref = this;\n var context = ref.context;\n var gl = context.gl;\n this.useMipmap = Boolean(options && options.useMipmap);\n gl.bindTexture(gl.TEXTURE_2D, this.texture);\n context.pixelStoreUnpackFlipY.set(false);\n context.pixelStoreUnpack.set(1);\n context.pixelStoreUnpackPremultiplyAlpha.set(this.format === gl.RGBA && (!options || options.premultiply !== false));\n if (resize) {\n this.size = [\n width,\n height\n ];\n if (image instanceof HTMLImageElement || image instanceof HTMLCanvasElement || image instanceof HTMLVideoElement || image instanceof ImageData$1 || ImageBitmap$1 && image instanceof ImageBitmap$1) {\n gl.texImage2D(gl.TEXTURE_2D, 0, this.format, this.format, gl.UNSIGNED_BYTE, image);\n } else {\n gl.texImage2D(gl.TEXTURE_2D, 0, this.format, width, height, 0, this.format, gl.UNSIGNED_BYTE, image.data);\n }\n } else {\n var ref$1 = position || {\n x: 0,\n y: 0\n };\n var x = ref$1.x;\n var y = ref$1.y;\n if (image instanceof HTMLImageElement || image instanceof HTMLCanvasElement || image instanceof HTMLVideoElement || image instanceof ImageData$1 || ImageBitmap$1 && image instanceof ImageBitmap$1) {\n gl.texSubImage2D(gl.TEXTURE_2D, 0, x, y, gl.RGBA, gl.UNSIGNED_BYTE, image);\n } else {\n gl.texSubImage2D(gl.TEXTURE_2D, 0, x, y, width, height, gl.RGBA, gl.UNSIGNED_BYTE, image.data);\n }\n }\n if (this.useMipmap && this.isSizePowerOfTwo()) {\n gl.generateMipmap(gl.TEXTURE_2D);\n }\n};\nTexture.prototype.bind = function bind(filter, wrap, minFilter) {\n var ref = this;\n var context = ref.context;\n var gl = context.gl;\n gl.bindTexture(gl.TEXTURE_2D, this.texture);\n if (minFilter === gl.LINEAR_MIPMAP_NEAREST && !this.isSizePowerOfTwo()) {\n minFilter = gl.LINEAR;\n }\n if (filter !== this.filter) {\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, filter);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, minFilter || filter);\n this.filter = filter;\n }\n if (wrap !== this.wrap) {\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, wrap);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, wrap);\n this.wrap = wrap;\n }\n};\nTexture.prototype.isSizePowerOfTwo = function isSizePowerOfTwo() {\n return this.size[0] === this.size[1] && Math.log(this.size[0]) / Math.LN2 % 1 === 0;\n};\nTexture.prototype.destroy = function destroy() {\n var ref = this.context;\n var gl = ref.gl;\n gl.deleteTexture(this.texture);\n this.texture = null;\n};\n\nvar ThrottledInvoker = function ThrottledInvoker(callback) {\n var this$1 = this;\n this._callback = callback;\n this._triggered = false;\n if (typeof MessageChannel !== 'undefined') {\n this._channel = new MessageChannel();\n this._channel.port2.onmessage = function () {\n this$1._triggered = false;\n this$1._callback();\n };\n }\n};\nThrottledInvoker.prototype.trigger = function trigger() {\n var this$1 = this;\n if (!this._triggered) {\n this._triggered = true;\n if (this._channel) {\n this._channel.port1.postMessage(true);\n } else {\n setTimeout(function () {\n this$1._triggered = false;\n this$1._callback();\n }, 0);\n }\n }\n};\nThrottledInvoker.prototype.remove = function remove() {\n delete this._channel;\n this._callback = function () {\n };\n};\n\nvar Actor = function Actor(target, parent, mapId) {\n this.target = target;\n this.parent = parent;\n this.mapId = mapId;\n this.callbacks = {};\n this.tasks = {};\n this.taskQueue = [];\n this.cancelCallbacks = {};\n bindAll([\n 'receive',\n 'process'\n ], this);\n this.invoker = new ThrottledInvoker(this.process);\n this.target.addEventListener('message', this.receive, false);\n this.globalScope = isWorker() ? target : window$1;\n};\nActor.prototype.send = function send(type, data, callback, targetMapId, mustQueue) {\n var this$1 = this;\n if (mustQueue === void 0)\n mustQueue = false;\n var id = Math.round(Math.random() * 1000000000000000000).toString(36).substring(0, 10);\n if (callback) {\n this.callbacks[id] = callback;\n }\n var buffers = isSafari(this.globalScope) ? undefined : [];\n this.target.postMessage({\n id: id,\n type: type,\n hasCallback: !!callback,\n targetMapId: targetMapId,\n mustQueue: mustQueue,\n sourceMapId: this.mapId,\n data: serialize(data, buffers)\n }, buffers);\n return {\n cancel: function () {\n if (callback) {\n delete this$1.callbacks[id];\n }\n this$1.target.postMessage({\n id: id,\n type: '',\n targetMapId: targetMapId,\n sourceMapId: this$1.mapId\n });\n }\n };\n};\nActor.prototype.receive = function receive(message) {\n var data = message.data, id = data.id;\n if (!id) {\n return;\n }\n if (data.targetMapId && this.mapId !== data.targetMapId) {\n return;\n }\n if (data.type === '') {\n delete this.tasks[id];\n var cancel = this.cancelCallbacks[id];\n delete this.cancelCallbacks[id];\n if (cancel) {\n cancel();\n }\n } else {\n if (isWorker() || data.mustQueue) {\n this.tasks[id] = data;\n this.taskQueue.push(id);\n this.invoker.trigger();\n } else {\n this.processTask(id, data);\n }\n }\n};\nActor.prototype.process = function process() {\n if (!this.taskQueue.length) {\n return;\n }\n var id = this.taskQueue.shift();\n var task = this.tasks[id];\n delete this.tasks[id];\n if (this.taskQueue.length) {\n this.invoker.trigger();\n }\n if (!task) {\n return;\n }\n this.processTask(id, task);\n};\nActor.prototype.processTask = function processTask(id, task) {\n var this$1 = this;\n if (task.type === '') {\n var callback = this.callbacks[id];\n delete this.callbacks[id];\n if (callback) {\n if (task.error) {\n callback(deserialize(task.error));\n } else {\n callback(null, deserialize(task.data));\n }\n }\n } else {\n var completed = false;\n var buffers = isSafari(this.globalScope) ? undefined : [];\n var done = task.hasCallback ? function (err, data) {\n completed = true;\n delete this$1.cancelCallbacks[id];\n this$1.target.postMessage({\n id: id,\n type: '',\n sourceMapId: this$1.mapId,\n error: err ? serialize(err) : null,\n data: serialize(data, buffers)\n }, buffers);\n } : function (_) {\n completed = true;\n };\n var callback$1 = null;\n var params = deserialize(task.data);\n if (this.parent[task.type]) {\n callback$1 = this.parent[task.type](task.sourceMapId, params, done);\n } else if (this.parent.getWorkerSource) {\n var keys = task.type.split('.');\n var scope = this.parent.getWorkerSource(task.sourceMapId, keys[0], params.source);\n callback$1 = scope[keys[1]](params, done);\n } else {\n done(new Error('Could not find function ' + task.type));\n }\n if (!completed && callback$1 && callback$1.cancel) {\n this.cancelCallbacks[id] = callback$1.cancel;\n }\n }\n};\nActor.prototype.remove = function remove() {\n this.invoker.remove();\n this.target.removeEventListener('message', this.receive, false);\n};\n\n/**\n * getTileBBox\n *\n * @param {Number} x Tile coordinate x\n * @param {Number} y Tile coordinate y\n * @param {Number} z Tile zoom\n * @returns {String} String of the bounding box\n */\nfunction getTileBBox(x, y, z) {\n // for Google/OSM tile scheme we need to alter the y\n y = (Math.pow(2, z) - y - 1);\n\n var min = getMercCoords(x * 256, y * 256, z),\n max = getMercCoords((x + 1) * 256, (y + 1) * 256, z);\n\n return min[0] + ',' + min[1] + ',' + max[0] + ',' + max[1];\n}\n\n\n/**\n * getMercCoords\n *\n * @param {Number} x Pixel coordinate x\n * @param {Number} y Pixel coordinate y\n * @param {Number} z Tile zoom\n * @returns {Array} [x, y]\n */\nfunction getMercCoords(x, y, z) {\n var resolution = (2 * Math.PI * 6378137 / 256) / Math.pow(2, z),\n merc_x = (x * resolution - 2 * Math.PI * 6378137 / 2.0),\n merc_y = (y * resolution - 2 * Math.PI * 6378137 / 2.0);\n\n return [merc_x, merc_y];\n}\n\nvar LngLatBounds = function LngLatBounds(sw, ne) {\n if (!sw) ; else if (ne) {\n this.setSouthWest(sw).setNorthEast(ne);\n } else if (sw.length === 4) {\n this.setSouthWest([\n sw[0],\n sw[1]\n ]).setNorthEast([\n sw[2],\n sw[3]\n ]);\n } else {\n this.setSouthWest(sw[0]).setNorthEast(sw[1]);\n }\n};\nLngLatBounds.prototype.setNorthEast = function setNorthEast(ne) {\n this._ne = ne instanceof LngLat ? new LngLat(ne.lng, ne.lat) : LngLat.convert(ne);\n return this;\n};\nLngLatBounds.prototype.setSouthWest = function setSouthWest(sw) {\n this._sw = sw instanceof LngLat ? new LngLat(sw.lng, sw.lat) : LngLat.convert(sw);\n return this;\n};\nLngLatBounds.prototype.extend = function extend(obj) {\n var sw = this._sw, ne = this._ne;\n var sw2, ne2;\n if (obj instanceof LngLat) {\n sw2 = obj;\n ne2 = obj;\n } else if (obj instanceof LngLatBounds) {\n sw2 = obj._sw;\n ne2 = obj._ne;\n if (!sw2 || !ne2) {\n return this;\n }\n } else {\n if (Array.isArray(obj)) {\n if (obj.length === 4 || obj.every(Array.isArray)) {\n var lngLatBoundsObj = obj;\n return this.extend(LngLatBounds.convert(lngLatBoundsObj));\n } else {\n var lngLatObj = obj;\n return this.extend(LngLat.convert(lngLatObj));\n }\n }\n return this;\n }\n if (!sw && !ne) {\n this._sw = new LngLat(sw2.lng, sw2.lat);\n this._ne = new LngLat(ne2.lng, ne2.lat);\n } else {\n sw.lng = Math.min(sw2.lng, sw.lng);\n sw.lat = Math.min(sw2.lat, sw.lat);\n ne.lng = Math.max(ne2.lng, ne.lng);\n ne.lat = Math.max(ne2.lat, ne.lat);\n }\n return this;\n};\nLngLatBounds.prototype.getCenter = function getCenter() {\n return new LngLat((this._sw.lng + this._ne.lng) / 2, (this._sw.lat + this._ne.lat) / 2);\n};\nLngLatBounds.prototype.getSouthWest = function getSouthWest() {\n return this._sw;\n};\nLngLatBounds.prototype.getNorthEast = function getNorthEast() {\n return this._ne;\n};\nLngLatBounds.prototype.getNorthWest = function getNorthWest() {\n return new LngLat(this.getWest(), this.getNorth());\n};\nLngLatBounds.prototype.getSouthEast = function getSouthEast() {\n return new LngLat(this.getEast(), this.getSouth());\n};\nLngLatBounds.prototype.getWest = function getWest() {\n return this._sw.lng;\n};\nLngLatBounds.prototype.getSouth = function getSouth() {\n return this._sw.lat;\n};\nLngLatBounds.prototype.getEast = function getEast() {\n return this._ne.lng;\n};\nLngLatBounds.prototype.getNorth = function getNorth() {\n return this._ne.lat;\n};\nLngLatBounds.prototype.toArray = function toArray() {\n return [\n this._sw.toArray(),\n this._ne.toArray()\n ];\n};\nLngLatBounds.prototype.toString = function toString() {\n return 'LngLatBounds(' + this._sw.toString() + ', ' + this._ne.toString() + ')';\n};\nLngLatBounds.prototype.isEmpty = function isEmpty() {\n return !(this._sw && this._ne);\n};\nLngLatBounds.prototype.contains = function contains(lnglat) {\n var ref = LngLat.convert(lnglat);\n var lng = ref.lng;\n var lat = ref.lat;\n var containsLatitude = this._sw.lat <= lat && lat <= this._ne.lat;\n var containsLongitude = this._sw.lng <= lng && lng <= this._ne.lng;\n if (this._sw.lng > this._ne.lng) {\n containsLongitude = this._sw.lng >= lng && lng >= this._ne.lng;\n }\n return containsLatitude && containsLongitude;\n};\nLngLatBounds.convert = function convert(input) {\n if (!input || input instanceof LngLatBounds) {\n return input;\n }\n return new LngLatBounds(input);\n};\n\nvar earthRadius = 6371008.8;\nvar LngLat = function LngLat(lng, lat) {\n if (isNaN(lng) || isNaN(lat)) {\n throw new Error('Invalid LngLat object: (' + lng + ', ' + lat + ')');\n }\n this.lng = +lng;\n this.lat = +lat;\n if (this.lat > 90 || this.lat < -90) {\n throw new Error('Invalid LngLat latitude value: must be between -90 and 90');\n }\n};\nLngLat.prototype.wrap = function wrap$1() {\n return new LngLat(wrap(this.lng, -180, 180), this.lat);\n};\nLngLat.prototype.toArray = function toArray() {\n return [\n this.lng,\n this.lat\n ];\n};\nLngLat.prototype.toString = function toString() {\n return 'LngLat(' + this.lng + ', ' + this.lat + ')';\n};\nLngLat.prototype.distanceTo = function distanceTo(lngLat) {\n var rad = Math.PI / 180;\n var lat1 = this.lat * rad;\n var lat2 = lngLat.lat * rad;\n var a = Math.sin(lat1) * Math.sin(lat2) + Math.cos(lat1) * Math.cos(lat2) * Math.cos((lngLat.lng - this.lng) * rad);\n var maxMeters = earthRadius * Math.acos(Math.min(a, 1));\n return maxMeters;\n};\nLngLat.prototype.toBounds = function toBounds(radius) {\n if (radius === void 0)\n radius = 0;\n var earthCircumferenceInMetersAtEquator = 40075017;\n var latAccuracy = 360 * radius / earthCircumferenceInMetersAtEquator, lngAccuracy = latAccuracy / Math.cos(Math.PI / 180 * this.lat);\n return new LngLatBounds(new LngLat(this.lng - lngAccuracy, this.lat - latAccuracy), new LngLat(this.lng + lngAccuracy, this.lat + latAccuracy));\n};\nLngLat.convert = function convert(input) {\n if (input instanceof LngLat) {\n return input;\n }\n if (Array.isArray(input) && (input.length === 2 || input.length === 3)) {\n return new LngLat(Number(input[0]), Number(input[1]));\n }\n if (!Array.isArray(input) && typeof input === 'object' && input !== null) {\n return new LngLat(Number('lng' in input ? input.lng : input.lon), Number(input.lat));\n }\n throw new Error('`LngLatLike` argument must be specified as a LngLat instance, an object {lng: , lat: }, an object {lon: , lat: }, or an array of [, ]');\n};\n\nvar earthCircumfrence = 2 * Math.PI * earthRadius;\nfunction circumferenceAtLatitude(latitude) {\n return earthCircumfrence * Math.cos(latitude * Math.PI / 180);\n}\nfunction mercatorXfromLng$1(lng) {\n return (180 + lng) / 360;\n}\nfunction mercatorYfromLat$1(lat) {\n return (180 - 180 / Math.PI * Math.log(Math.tan(Math.PI / 4 + lat * Math.PI / 360))) / 360;\n}\nfunction mercatorZfromAltitude(altitude, lat) {\n return altitude / circumferenceAtLatitude(lat);\n}\nfunction lngFromMercatorX(x) {\n return x * 360 - 180;\n}\nfunction latFromMercatorY(y) {\n var y2 = 180 - y * 360;\n return 360 / Math.PI * Math.atan(Math.exp(y2 * Math.PI / 180)) - 90;\n}\nfunction altitudeFromMercatorZ(z, y) {\n return z * circumferenceAtLatitude(latFromMercatorY(y));\n}\nfunction mercatorScale(lat) {\n return 1 / Math.cos(lat * Math.PI / 180);\n}\nvar MercatorCoordinate = function MercatorCoordinate(x, y, z) {\n if (z === void 0)\n z = 0;\n this.x = +x;\n this.y = +y;\n this.z = +z;\n};\nMercatorCoordinate.fromLngLat = function fromLngLat(lngLatLike, altitude) {\n if (altitude === void 0)\n altitude = 0;\n var lngLat = LngLat.convert(lngLatLike);\n return new MercatorCoordinate(mercatorXfromLng$1(lngLat.lng), mercatorYfromLat$1(lngLat.lat), mercatorZfromAltitude(altitude, lngLat.lat));\n};\nMercatorCoordinate.prototype.toLngLat = function toLngLat() {\n return new LngLat(lngFromMercatorX(this.x), latFromMercatorY(this.y));\n};\nMercatorCoordinate.prototype.toAltitude = function toAltitude() {\n return altitudeFromMercatorZ(this.z, this.y);\n};\nMercatorCoordinate.prototype.meterInMercatorCoordinateUnits = function meterInMercatorCoordinateUnits() {\n return 1 / earthCircumfrence * mercatorScale(latFromMercatorY(this.y));\n};\n\nvar CanonicalTileID = function CanonicalTileID(z, x, y) {\n this.z = z;\n this.x = x;\n this.y = y;\n this.key = calculateKey(0, z, z, x, y);\n};\nCanonicalTileID.prototype.equals = function equals(id) {\n return this.z === id.z && this.x === id.x && this.y === id.y;\n};\nCanonicalTileID.prototype.url = function url(urls, scheme) {\n var bbox = getTileBBox(this.x, this.y, this.z);\n var quadkey = getQuadkey(this.z, this.x, this.y);\n return urls[(this.x + this.y) % urls.length].replace('{prefix}', (this.x % 16).toString(16) + (this.y % 16).toString(16)).replace('{z}', String(this.z)).replace('{x}', String(this.x)).replace('{y}', String(scheme === 'tms' ? Math.pow(2, this.z) - this.y - 1 : this.y)).replace('{quadkey}', quadkey).replace('{bbox-epsg-3857}', bbox);\n};\nCanonicalTileID.prototype.getTilePoint = function getTilePoint(coord) {\n var tilesAtZoom = Math.pow(2, this.z);\n return new pointGeometry((coord.x * tilesAtZoom - this.x) * EXTENT$1, (coord.y * tilesAtZoom - this.y) * EXTENT$1);\n};\nCanonicalTileID.prototype.toString = function toString() {\n return this.z + '/' + this.x + '/' + this.y;\n};\nvar UnwrappedTileID = function UnwrappedTileID(wrap, canonical) {\n this.wrap = wrap;\n this.canonical = canonical;\n this.key = calculateKey(wrap, canonical.z, canonical.z, canonical.x, canonical.y);\n};\nvar OverscaledTileID = function OverscaledTileID(overscaledZ, wrap, z, x, y) {\n this.overscaledZ = overscaledZ;\n this.wrap = wrap;\n this.canonical = new CanonicalTileID(z, +x, +y);\n this.key = calculateKey(wrap, overscaledZ, z, x, y);\n};\nOverscaledTileID.prototype.equals = function equals(id) {\n return this.overscaledZ === id.overscaledZ && this.wrap === id.wrap && this.canonical.equals(id.canonical);\n};\nOverscaledTileID.prototype.scaledTo = function scaledTo(targetZ) {\n var zDifference = this.canonical.z - targetZ;\n if (targetZ > this.canonical.z) {\n return new OverscaledTileID(targetZ, this.wrap, this.canonical.z, this.canonical.x, this.canonical.y);\n } else {\n return new OverscaledTileID(targetZ, this.wrap, targetZ, this.canonical.x >> zDifference, this.canonical.y >> zDifference);\n }\n};\nOverscaledTileID.prototype.calculateScaledKey = function calculateScaledKey(targetZ, withWrap) {\n var zDifference = this.canonical.z - targetZ;\n if (targetZ > this.canonical.z) {\n return calculateKey(this.wrap * +withWrap, targetZ, this.canonical.z, this.canonical.x, this.canonical.y);\n } else {\n return calculateKey(this.wrap * +withWrap, targetZ, targetZ, this.canonical.x >> zDifference, this.canonical.y >> zDifference);\n }\n};\nOverscaledTileID.prototype.isChildOf = function isChildOf(parent) {\n if (parent.wrap !== this.wrap) {\n return false;\n }\n var zDifference = this.canonical.z - parent.canonical.z;\n return parent.overscaledZ === 0 || parent.overscaledZ < this.overscaledZ && parent.canonical.x === this.canonical.x >> zDifference && parent.canonical.y === this.canonical.y >> zDifference;\n};\nOverscaledTileID.prototype.children = function children(sourceMaxZoom) {\n if (this.overscaledZ >= sourceMaxZoom) {\n return [new OverscaledTileID(this.overscaledZ + 1, this.wrap, this.canonical.z, this.canonical.x, this.canonical.y)];\n }\n var z = this.canonical.z + 1;\n var x = this.canonical.x * 2;\n var y = this.canonical.y * 2;\n return [\n new OverscaledTileID(z, this.wrap, z, x, y),\n new OverscaledTileID(z, this.wrap, z, x + 1, y),\n new OverscaledTileID(z, this.wrap, z, x, y + 1),\n new OverscaledTileID(z, this.wrap, z, x + 1, y + 1)\n ];\n};\nOverscaledTileID.prototype.isLessThan = function isLessThan(rhs) {\n if (this.wrap < rhs.wrap) {\n return true;\n }\n if (this.wrap > rhs.wrap) {\n return false;\n }\n if (this.overscaledZ < rhs.overscaledZ) {\n return true;\n }\n if (this.overscaledZ > rhs.overscaledZ) {\n return false;\n }\n if (this.canonical.x < rhs.canonical.x) {\n return true;\n }\n if (this.canonical.x > rhs.canonical.x) {\n return false;\n }\n if (this.canonical.y < rhs.canonical.y) {\n return true;\n }\n return false;\n};\nOverscaledTileID.prototype.wrapped = function wrapped() {\n return new OverscaledTileID(this.overscaledZ, 0, this.canonical.z, this.canonical.x, this.canonical.y);\n};\nOverscaledTileID.prototype.unwrapTo = function unwrapTo(wrap) {\n return new OverscaledTileID(this.overscaledZ, wrap, this.canonical.z, this.canonical.x, this.canonical.y);\n};\nOverscaledTileID.prototype.overscaleFactor = function overscaleFactor() {\n return Math.pow(2, this.overscaledZ - this.canonical.z);\n};\nOverscaledTileID.prototype.toUnwrapped = function toUnwrapped() {\n return new UnwrappedTileID(this.wrap, this.canonical);\n};\nOverscaledTileID.prototype.toString = function toString() {\n return this.overscaledZ + '/' + this.canonical.x + '/' + this.canonical.y;\n};\nOverscaledTileID.prototype.getTilePoint = function getTilePoint(coord) {\n return this.canonical.getTilePoint(new MercatorCoordinate(coord.x - this.wrap, coord.y));\n};\nfunction calculateKey(wrap, overscaledZ, z, x, y) {\n wrap *= 2;\n if (wrap < 0) {\n wrap = wrap * -1 - 1;\n }\n var dim = 1 << z;\n return (dim * dim * wrap + dim * y + x).toString(36) + z.toString(36) + overscaledZ.toString(36);\n}\nfunction getQuadkey(z, x, y) {\n var quadkey = '', mask;\n for (var i = z; i > 0; i--) {\n mask = 1 << i - 1;\n quadkey += (x & mask ? 1 : 0) + (y & mask ? 2 : 0);\n }\n return quadkey;\n}\nregister('CanonicalTileID', CanonicalTileID);\nregister('OverscaledTileID', OverscaledTileID, { omit: ['posMatrix'] });\n\nvar DEMData = function DEMData(uid, data, encoding) {\n this.uid = uid;\n if (data.height !== data.width) {\n throw new RangeError('DEM tiles must be square');\n }\n if (encoding && encoding !== 'mapbox' && encoding !== 'terrarium') {\n return warnOnce('\"' + encoding + '\" is not a valid encoding type. Valid types include \"mapbox\" and \"terrarium\".');\n }\n this.stride = data.height;\n var dim = this.dim = data.height - 2;\n this.data = new Uint32Array(data.data.buffer);\n this.encoding = encoding || 'mapbox';\n for (var x = 0; x < dim; x++) {\n this.data[this._idx(-1, x)] = this.data[this._idx(0, x)];\n this.data[this._idx(dim, x)] = this.data[this._idx(dim - 1, x)];\n this.data[this._idx(x, -1)] = this.data[this._idx(x, 0)];\n this.data[this._idx(x, dim)] = this.data[this._idx(x, dim - 1)];\n }\n this.data[this._idx(-1, -1)] = this.data[this._idx(0, 0)];\n this.data[this._idx(dim, -1)] = this.data[this._idx(dim - 1, 0)];\n this.data[this._idx(-1, dim)] = this.data[this._idx(0, dim - 1)];\n this.data[this._idx(dim, dim)] = this.data[this._idx(dim - 1, dim - 1)];\n};\nDEMData.prototype.get = function get(x, y) {\n var pixels = new Uint8Array(this.data.buffer);\n var index = this._idx(x, y) * 4;\n var unpack = this.encoding === 'terrarium' ? this._unpackTerrarium : this._unpackMapbox;\n return unpack(pixels[index], pixels[index + 1], pixels[index + 2]);\n};\nDEMData.prototype.getUnpackVector = function getUnpackVector() {\n return this.encoding === 'terrarium' ? [\n 256,\n 1,\n 1 / 256,\n 32768\n ] : [\n 6553.6,\n 25.6,\n 0.1,\n 10000\n ];\n};\nDEMData.prototype._idx = function _idx(x, y) {\n if (x < -1 || x >= this.dim + 1 || y < -1 || y >= this.dim + 1) {\n throw new RangeError('out of range source coordinates for DEM data');\n }\n return (y + 1) * this.stride + (x + 1);\n};\nDEMData.prototype._unpackMapbox = function _unpackMapbox(r, g, b) {\n return (r * 256 * 256 + g * 256 + b) / 10 - 10000;\n};\nDEMData.prototype._unpackTerrarium = function _unpackTerrarium(r, g, b) {\n return r * 256 + g + b / 256 - 32768;\n};\nDEMData.prototype.getPixels = function getPixels() {\n return new RGBAImage({\n width: this.stride,\n height: this.stride\n }, new Uint8Array(this.data.buffer));\n};\nDEMData.prototype.backfillBorder = function backfillBorder(borderTile, dx, dy) {\n if (this.dim !== borderTile.dim) {\n throw new Error('dem dimension mismatch');\n }\n var xMin = dx * this.dim, xMax = dx * this.dim + this.dim, yMin = dy * this.dim, yMax = dy * this.dim + this.dim;\n switch (dx) {\n case -1:\n xMin = xMax - 1;\n break;\n case 1:\n xMax = xMin + 1;\n break;\n }\n switch (dy) {\n case -1:\n yMin = yMax - 1;\n break;\n case 1:\n yMax = yMin + 1;\n break;\n }\n var ox = -dx * this.dim;\n var oy = -dy * this.dim;\n for (var y = yMin; y < yMax; y++) {\n for (var x = xMin; x < xMax; x++) {\n this.data[this._idx(x, y)] = borderTile.data[this._idx(x + ox, y + oy)];\n }\n }\n};\nregister('DEMData', DEMData);\n\nfunction deserialize$1(input, style) {\n var output = {};\n if (!style) {\n return output;\n }\n var loop = function () {\n var bucket = list$1[i$1];\n var layers = bucket.layerIds.map(function (id) {\n return style.getLayer(id);\n }).filter(Boolean);\n if (layers.length === 0) {\n return;\n }\n bucket.layers = layers;\n if (bucket.stateDependentLayerIds) {\n bucket.stateDependentLayers = bucket.stateDependentLayerIds.map(function (lId) {\n return layers.filter(function (l) {\n return l.id === lId;\n })[0];\n });\n }\n for (var i = 0, list = layers; i < list.length; i += 1) {\n var layer = list[i];\n output[layer.id] = bucket;\n }\n };\n for (var i$1 = 0, list$1 = input; i$1 < list$1.length; i$1 += 1)\n loop();\n return output;\n}\n\nvar DictionaryCoder = function DictionaryCoder(strings) {\n this._stringToNumber = {};\n this._numberToString = [];\n for (var i = 0; i < strings.length; i++) {\n var string = strings[i];\n this._stringToNumber[string] = i;\n this._numberToString[i] = string;\n }\n};\nDictionaryCoder.prototype.encode = function encode(string) {\n return this._stringToNumber[string];\n};\nDictionaryCoder.prototype.decode = function decode(n) {\n return this._numberToString[n];\n};\n\nvar Feature = function Feature(vectorTileFeature, z, x, y, id) {\n this.type = 'Feature';\n this._vectorTileFeature = vectorTileFeature;\n vectorTileFeature._z = z;\n vectorTileFeature._x = x;\n vectorTileFeature._y = y;\n this.properties = vectorTileFeature.properties;\n this.id = id;\n};\nvar prototypeAccessors$1 = { geometry: { configurable: true } };\nprototypeAccessors$1.geometry.get = function () {\n if (this._geometry === undefined) {\n this._geometry = this._vectorTileFeature.toGeoJSON(this._vectorTileFeature._x, this._vectorTileFeature._y, this._vectorTileFeature._z).geometry;\n }\n return this._geometry;\n};\nprototypeAccessors$1.geometry.set = function (g) {\n this._geometry = g;\n};\nFeature.prototype.toJSON = function toJSON() {\n var json = { geometry: this.geometry };\n for (var i in this) {\n if (i === '_geometry' || i === '_vectorTileFeature') {\n continue;\n }\n json[i] = this[i];\n }\n return json;\n};\nObject.defineProperties(Feature.prototype, prototypeAccessors$1);\n\nvar SourceFeatureState = function SourceFeatureState() {\n this.state = {};\n this.stateChanges = {};\n this.deletedStates = {};\n};\nSourceFeatureState.prototype.updateState = function updateState(sourceLayer, featureId, newState) {\n var feature = String(featureId);\n this.stateChanges[sourceLayer] = this.stateChanges[sourceLayer] || {};\n this.stateChanges[sourceLayer][feature] = this.stateChanges[sourceLayer][feature] || {};\n extend(this.stateChanges[sourceLayer][feature], newState);\n if (this.deletedStates[sourceLayer] === null) {\n this.deletedStates[sourceLayer] = {};\n for (var ft in this.state[sourceLayer]) {\n if (ft !== feature) {\n this.deletedStates[sourceLayer][ft] = null;\n }\n }\n } else {\n var featureDeletionQueued = this.deletedStates[sourceLayer] && this.deletedStates[sourceLayer][feature] === null;\n if (featureDeletionQueued) {\n this.deletedStates[sourceLayer][feature] = {};\n for (var prop in this.state[sourceLayer][feature]) {\n if (!newState[prop]) {\n this.deletedStates[sourceLayer][feature][prop] = null;\n }\n }\n } else {\n for (var key in newState) {\n var deletionInQueue = this.deletedStates[sourceLayer] && this.deletedStates[sourceLayer][feature] && this.deletedStates[sourceLayer][feature][key] === null;\n if (deletionInQueue) {\n delete this.deletedStates[sourceLayer][feature][key];\n }\n }\n }\n }\n};\nSourceFeatureState.prototype.removeFeatureState = function removeFeatureState(sourceLayer, featureId, key) {\n var sourceLayerDeleted = this.deletedStates[sourceLayer] === null;\n if (sourceLayerDeleted) {\n return;\n }\n var feature = String(featureId);\n this.deletedStates[sourceLayer] = this.deletedStates[sourceLayer] || {};\n if (key && featureId !== undefined) {\n if (this.deletedStates[sourceLayer][feature] !== null) {\n this.deletedStates[sourceLayer][feature] = this.deletedStates[sourceLayer][feature] || {};\n this.deletedStates[sourceLayer][feature][key] = null;\n }\n } else if (featureId !== undefined) {\n var updateInQueue = this.stateChanges[sourceLayer] && this.stateChanges[sourceLayer][feature];\n if (updateInQueue) {\n this.deletedStates[sourceLayer][feature] = {};\n for (key in this.stateChanges[sourceLayer][feature]) {\n this.deletedStates[sourceLayer][feature][key] = null;\n }\n } else {\n this.deletedStates[sourceLayer][feature] = null;\n }\n } else {\n this.deletedStates[sourceLayer] = null;\n }\n};\nSourceFeatureState.prototype.getState = function getState(sourceLayer, featureId) {\n var feature = String(featureId);\n var base = this.state[sourceLayer] || {};\n var changes = this.stateChanges[sourceLayer] || {};\n var reconciledState = extend({}, base[feature], changes[feature]);\n if (this.deletedStates[sourceLayer] === null) {\n return {};\n } else if (this.deletedStates[sourceLayer]) {\n var featureDeletions = this.deletedStates[sourceLayer][featureId];\n if (featureDeletions === null) {\n return {};\n }\n for (var prop in featureDeletions) {\n delete reconciledState[prop];\n }\n }\n return reconciledState;\n};\nSourceFeatureState.prototype.initializeTileState = function initializeTileState(tile, painter) {\n tile.setFeatureState(this.state, painter);\n};\nSourceFeatureState.prototype.coalesceChanges = function coalesceChanges(tiles, painter) {\n var featuresChanged = {};\n for (var sourceLayer in this.stateChanges) {\n this.state[sourceLayer] = this.state[sourceLayer] || {};\n var layerStates = {};\n for (var feature in this.stateChanges[sourceLayer]) {\n if (!this.state[sourceLayer][feature]) {\n this.state[sourceLayer][feature] = {};\n }\n extend(this.state[sourceLayer][feature], this.stateChanges[sourceLayer][feature]);\n layerStates[feature] = this.state[sourceLayer][feature];\n }\n featuresChanged[sourceLayer] = layerStates;\n }\n for (var sourceLayer$1 in this.deletedStates) {\n this.state[sourceLayer$1] = this.state[sourceLayer$1] || {};\n var layerStates$1 = {};\n if (this.deletedStates[sourceLayer$1] === null) {\n for (var ft in this.state[sourceLayer$1]) {\n layerStates$1[ft] = {};\n this.state[sourceLayer$1][ft] = {};\n }\n } else {\n for (var feature$1 in this.deletedStates[sourceLayer$1]) {\n var deleteWholeFeatureState = this.deletedStates[sourceLayer$1][feature$1] === null;\n if (deleteWholeFeatureState) {\n this.state[sourceLayer$1][feature$1] = {};\n } else {\n for (var i = 0, list = Object.keys(this.deletedStates[sourceLayer$1][feature$1]); i < list.length; i += 1) {\n var key = list[i];\n delete this.state[sourceLayer$1][feature$1][key];\n }\n }\n layerStates$1[feature$1] = this.state[sourceLayer$1][feature$1];\n }\n }\n featuresChanged[sourceLayer$1] = featuresChanged[sourceLayer$1] || {};\n extend(featuresChanged[sourceLayer$1], layerStates$1);\n }\n this.stateChanges = {};\n this.deletedStates = {};\n if (Object.keys(featuresChanged).length === 0) {\n return;\n }\n for (var id in tiles) {\n var tile = tiles[id];\n tile.setFeatureState(featuresChanged, painter);\n }\n};\n\nvar FeatureIndex = function FeatureIndex(tileID, promoteId) {\n this.tileID = tileID;\n this.x = tileID.canonical.x;\n this.y = tileID.canonical.y;\n this.z = tileID.canonical.z;\n this.grid = new gridIndex(EXTENT$1, 16, 0);\n this.grid3D = new gridIndex(EXTENT$1, 16, 0);\n this.featureIndexArray = new FeatureIndexArray();\n this.promoteId = promoteId;\n};\nFeatureIndex.prototype.insert = function insert(feature, geometry, featureIndex, sourceLayerIndex, bucketIndex, is3D) {\n var key = this.featureIndexArray.length;\n this.featureIndexArray.emplaceBack(featureIndex, sourceLayerIndex, bucketIndex);\n var grid = is3D ? this.grid3D : this.grid;\n for (var r = 0; r < geometry.length; r++) {\n var ring = geometry[r];\n var bbox = [\n Infinity,\n Infinity,\n -Infinity,\n -Infinity\n ];\n for (var i = 0; i < ring.length; i++) {\n var p = ring[i];\n bbox[0] = Math.min(bbox[0], p.x);\n bbox[1] = Math.min(bbox[1], p.y);\n bbox[2] = Math.max(bbox[2], p.x);\n bbox[3] = Math.max(bbox[3], p.y);\n }\n if (bbox[0] < EXTENT$1 && bbox[1] < EXTENT$1 && bbox[2] >= 0 && bbox[3] >= 0) {\n grid.insert(key, bbox[0], bbox[1], bbox[2], bbox[3]);\n }\n }\n};\nFeatureIndex.prototype.loadVTLayers = function loadVTLayers() {\n if (!this.vtLayers) {\n this.vtLayers = new vectorTile.VectorTile(new pbf(this.rawTileData)).layers;\n this.sourceLayerCoder = new DictionaryCoder(this.vtLayers ? Object.keys(this.vtLayers).sort() : ['_geojsonTileLayer']);\n }\n return this.vtLayers;\n};\nFeatureIndex.prototype.query = function query(args, styleLayers, serializedLayers, sourceFeatureState) {\n var this$1 = this;\n this.loadVTLayers();\n var params = args.params || {}, pixelsToTileUnits = EXTENT$1 / args.tileSize / args.scale, filter = createFilter(params.filter);\n var queryGeometry = args.queryGeometry;\n var queryPadding = args.queryPadding * pixelsToTileUnits;\n var bounds = getBounds(queryGeometry);\n var matching = this.grid.query(bounds.minX - queryPadding, bounds.minY - queryPadding, bounds.maxX + queryPadding, bounds.maxY + queryPadding);\n var cameraBounds = getBounds(args.cameraQueryGeometry);\n var matching3D = this.grid3D.query(cameraBounds.minX - queryPadding, cameraBounds.minY - queryPadding, cameraBounds.maxX + queryPadding, cameraBounds.maxY + queryPadding, function (bx1, by1, bx2, by2) {\n return polygonIntersectsBox(args.cameraQueryGeometry, bx1 - queryPadding, by1 - queryPadding, bx2 + queryPadding, by2 + queryPadding);\n });\n for (var i = 0, list = matching3D; i < list.length; i += 1) {\n var key = list[i];\n matching.push(key);\n }\n matching.sort(topDownFeatureComparator);\n var result = {};\n var previousIndex;\n var loop = function (k) {\n var index = matching[k];\n if (index === previousIndex) {\n return;\n }\n previousIndex = index;\n var match = this$1.featureIndexArray.get(index);\n var featureGeometry = null;\n this$1.loadMatchingFeature(result, match.bucketIndex, match.sourceLayerIndex, match.featureIndex, filter, params.layers, params.availableImages, styleLayers, serializedLayers, sourceFeatureState, function (feature, styleLayer, featureState) {\n if (!featureGeometry) {\n featureGeometry = loadGeometry(feature);\n }\n return styleLayer.queryIntersectsFeature(queryGeometry, feature, featureState, featureGeometry, this$1.z, args.transform, pixelsToTileUnits, args.pixelPosMatrix);\n });\n };\n for (var k = 0; k < matching.length; k++)\n loop(k);\n return result;\n};\nFeatureIndex.prototype.loadMatchingFeature = function loadMatchingFeature(result, bucketIndex, sourceLayerIndex, featureIndex, filter, filterLayerIDs, availableImages, styleLayers, serializedLayers, sourceFeatureState, intersectionTest) {\n var layerIDs = this.bucketLayerIDs[bucketIndex];\n if (filterLayerIDs && !arraysIntersect(filterLayerIDs, layerIDs)) {\n return;\n }\n var sourceLayerName = this.sourceLayerCoder.decode(sourceLayerIndex);\n var sourceLayer = this.vtLayers[sourceLayerName];\n var feature = sourceLayer.feature(featureIndex);\n if (filter.needGeometry) {\n var evaluationFeature = toEvaluationFeature(feature, true);\n if (!filter.filter(new EvaluationParameters(this.tileID.overscaledZ), evaluationFeature, this.tileID.canonical)) {\n return;\n }\n } else if (!filter.filter(new EvaluationParameters(this.tileID.overscaledZ), feature)) {\n return;\n }\n var id = this.getId(feature, sourceLayerName);\n for (var l = 0; l < layerIDs.length; l++) {\n var layerID = layerIDs[l];\n if (filterLayerIDs && filterLayerIDs.indexOf(layerID) < 0) {\n continue;\n }\n var styleLayer = styleLayers[layerID];\n if (!styleLayer) {\n continue;\n }\n var featureState = {};\n if (id !== undefined && sourceFeatureState) {\n featureState = sourceFeatureState.getState(styleLayer.sourceLayer || '_geojsonTileLayer', id);\n }\n var serializedLayer = extend({}, serializedLayers[layerID]);\n serializedLayer.paint = evaluateProperties(serializedLayer.paint, styleLayer.paint, feature, featureState, availableImages);\n serializedLayer.layout = evaluateProperties(serializedLayer.layout, styleLayer.layout, feature, featureState, availableImages);\n var intersectionZ = !intersectionTest || intersectionTest(feature, styleLayer, featureState);\n if (!intersectionZ) {\n continue;\n }\n var geojsonFeature = new Feature(feature, this.z, this.x, this.y, id);\n geojsonFeature.layer = serializedLayer;\n var layerResult = result[layerID];\n if (layerResult === undefined) {\n layerResult = result[layerID] = [];\n }\n layerResult.push({\n featureIndex: featureIndex,\n feature: geojsonFeature,\n intersectionZ: intersectionZ\n });\n }\n};\nFeatureIndex.prototype.lookupSymbolFeatures = function lookupSymbolFeatures(symbolFeatureIndexes, serializedLayers, bucketIndex, sourceLayerIndex, filterSpec, filterLayerIDs, availableImages, styleLayers) {\n var result = {};\n this.loadVTLayers();\n var filter = createFilter(filterSpec);\n for (var i = 0, list = symbolFeatureIndexes; i < list.length; i += 1) {\n var symbolFeatureIndex = list[i];\n this.loadMatchingFeature(result, bucketIndex, sourceLayerIndex, symbolFeatureIndex, filter, filterLayerIDs, availableImages, styleLayers, serializedLayers);\n }\n return result;\n};\nFeatureIndex.prototype.hasLayer = function hasLayer(id) {\n for (var i$1 = 0, list$1 = this.bucketLayerIDs; i$1 < list$1.length; i$1 += 1) {\n var layerIDs = list$1[i$1];\n for (var i = 0, list = layerIDs; i < list.length; i += 1) {\n var layerID = list[i];\n if (id === layerID) {\n return true;\n }\n }\n }\n return false;\n};\nFeatureIndex.prototype.getId = function getId(feature, sourceLayerId) {\n var id = feature.id;\n if (this.promoteId) {\n var propName = typeof this.promoteId === 'string' ? this.promoteId : this.promoteId[sourceLayerId];\n id = feature.properties[propName];\n if (typeof id === 'boolean') {\n id = Number(id);\n }\n }\n return id;\n};\nregister('FeatureIndex', FeatureIndex, {\n omit: [\n 'rawTileData',\n 'sourceLayerCoder'\n ]\n});\nfunction evaluateProperties(serializedProperties, styleLayerProperties, feature, featureState, availableImages) {\n return mapObject(serializedProperties, function (property, key) {\n var prop = styleLayerProperties instanceof PossiblyEvaluated ? styleLayerProperties.get(key) : null;\n return prop && prop.evaluate ? prop.evaluate(feature, featureState, availableImages) : prop;\n });\n}\nfunction getBounds(geometry) {\n var minX = Infinity;\n var minY = Infinity;\n var maxX = -Infinity;\n var maxY = -Infinity;\n for (var i = 0, list = geometry; i < list.length; i += 1) {\n var p = list[i];\n minX = Math.min(minX, p.x);\n minY = Math.min(minY, p.y);\n maxX = Math.max(maxX, p.x);\n maxY = Math.max(maxY, p.y);\n }\n return {\n minX: minX,\n minY: minY,\n maxX: maxX,\n maxY: maxY\n };\n}\nfunction topDownFeatureComparator(a, b) {\n return b - a;\n}\n\nvar CLOCK_SKEW_RETRY_TIMEOUT = 30000;\nvar Tile = function Tile(tileID, size) {\n this.tileID = tileID;\n this.uid = uniqueId();\n this.uses = 0;\n this.tileSize = size;\n this.buckets = {};\n this.expirationTime = null;\n this.queryPadding = 0;\n this.hasSymbolBuckets = false;\n this.hasRTLText = false;\n this.dependencies = {};\n this.expiredRequestCount = 0;\n this.state = 'loading';\n};\nTile.prototype.registerFadeDuration = function registerFadeDuration(duration) {\n var fadeEndTime = duration + this.timeAdded;\n if (fadeEndTime < exported.now()) {\n return;\n }\n if (this.fadeEndTime && fadeEndTime < this.fadeEndTime) {\n return;\n }\n this.fadeEndTime = fadeEndTime;\n};\nTile.prototype.wasRequested = function wasRequested() {\n return this.state === 'errored' || this.state === 'loaded' || this.state === 'reloading';\n};\nTile.prototype.loadVectorData = function loadVectorData(data, painter, justReloaded) {\n if (this.hasData()) {\n this.unloadVectorData();\n }\n this.state = 'loaded';\n if (!data) {\n this.collisionBoxArray = new CollisionBoxArray();\n return;\n }\n if (data.featureIndex) {\n this.latestFeatureIndex = data.featureIndex;\n if (data.rawTileData) {\n this.latestRawTileData = data.rawTileData;\n this.latestFeatureIndex.rawTileData = data.rawTileData;\n } else if (this.latestRawTileData) {\n this.latestFeatureIndex.rawTileData = this.latestRawTileData;\n }\n }\n this.collisionBoxArray = data.collisionBoxArray;\n this.buckets = deserialize$1(data.buckets, painter.style);\n this.hasSymbolBuckets = false;\n for (var id in this.buckets) {\n var bucket = this.buckets[id];\n if (bucket instanceof SymbolBucket) {\n this.hasSymbolBuckets = true;\n if (justReloaded) {\n bucket.justReloaded = true;\n } else {\n break;\n }\n }\n }\n this.hasRTLText = false;\n if (this.hasSymbolBuckets) {\n for (var id$1 in this.buckets) {\n var bucket$1 = this.buckets[id$1];\n if (bucket$1 instanceof SymbolBucket) {\n if (bucket$1.hasRTLText) {\n this.hasRTLText = true;\n lazyLoadRTLTextPlugin();\n break;\n }\n }\n }\n }\n this.queryPadding = 0;\n for (var id$2 in this.buckets) {\n var bucket$2 = this.buckets[id$2];\n this.queryPadding = Math.max(this.queryPadding, painter.style.getLayer(id$2).queryRadius(bucket$2));\n }\n if (data.imageAtlas) {\n this.imageAtlas = data.imageAtlas;\n }\n if (data.glyphAtlasImage) {\n this.glyphAtlasImage = data.glyphAtlasImage;\n }\n};\nTile.prototype.unloadVectorData = function unloadVectorData() {\n for (var id in this.buckets) {\n this.buckets[id].destroy();\n }\n this.buckets = {};\n if (this.imageAtlasTexture) {\n this.imageAtlasTexture.destroy();\n }\n if (this.imageAtlas) {\n this.imageAtlas = null;\n }\n if (this.glyphAtlasTexture) {\n this.glyphAtlasTexture.destroy();\n }\n this.latestFeatureIndex = null;\n this.state = 'unloaded';\n};\nTile.prototype.getBucket = function getBucket(layer) {\n return this.buckets[layer.id];\n};\nTile.prototype.upload = function upload(context) {\n for (var id in this.buckets) {\n var bucket = this.buckets[id];\n if (bucket.uploadPending()) {\n bucket.upload(context);\n }\n }\n var gl = context.gl;\n if (this.imageAtlas && !this.imageAtlas.uploaded) {\n this.imageAtlasTexture = new Texture(context, this.imageAtlas.image, gl.RGBA);\n this.imageAtlas.uploaded = true;\n }\n if (this.glyphAtlasImage) {\n this.glyphAtlasTexture = new Texture(context, this.glyphAtlasImage, gl.ALPHA);\n this.glyphAtlasImage = null;\n }\n};\nTile.prototype.prepare = function prepare(imageManager) {\n if (this.imageAtlas) {\n this.imageAtlas.patchUpdatedImages(imageManager, this.imageAtlasTexture);\n }\n};\nTile.prototype.queryRenderedFeatures = function queryRenderedFeatures(layers, serializedLayers, sourceFeatureState, queryGeometry, cameraQueryGeometry, scale, params, transform, maxPitchScaleFactor, pixelPosMatrix) {\n if (!this.latestFeatureIndex || !this.latestFeatureIndex.rawTileData) {\n return {};\n }\n return this.latestFeatureIndex.query({\n queryGeometry: queryGeometry,\n cameraQueryGeometry: cameraQueryGeometry,\n scale: scale,\n tileSize: this.tileSize,\n pixelPosMatrix: pixelPosMatrix,\n transform: transform,\n params: params,\n queryPadding: this.queryPadding * maxPitchScaleFactor\n }, layers, serializedLayers, sourceFeatureState);\n};\nTile.prototype.querySourceFeatures = function querySourceFeatures(result, params) {\n var featureIndex = this.latestFeatureIndex;\n if (!featureIndex || !featureIndex.rawTileData) {\n return;\n }\n var vtLayers = featureIndex.loadVTLayers();\n var sourceLayer = params ? params.sourceLayer : '';\n var layer = vtLayers._geojsonTileLayer || vtLayers[sourceLayer];\n if (!layer) {\n return;\n }\n var filter = createFilter(params && params.filter);\n var ref = this.tileID.canonical;\n var z = ref.z;\n var x = ref.x;\n var y = ref.y;\n var coord = {\n z: z,\n x: x,\n y: y\n };\n for (var i = 0; i < layer.length; i++) {\n var feature = layer.feature(i);\n if (filter.needGeometry) {\n var evaluationFeature = toEvaluationFeature(feature, true);\n if (!filter.filter(new EvaluationParameters(this.tileID.overscaledZ), evaluationFeature, this.tileID.canonical)) {\n continue;\n }\n } else if (!filter.filter(new EvaluationParameters(this.tileID.overscaledZ), feature)) {\n continue;\n }\n var id = featureIndex.getId(feature, sourceLayer);\n var geojsonFeature = new Feature(feature, z, x, y, id);\n geojsonFeature.tile = coord;\n result.push(geojsonFeature);\n }\n};\nTile.prototype.hasData = function hasData() {\n return this.state === 'loaded' || this.state === 'reloading' || this.state === 'expired';\n};\nTile.prototype.patternsLoaded = function patternsLoaded() {\n return this.imageAtlas && !!Object.keys(this.imageAtlas.patternPositions).length;\n};\nTile.prototype.setExpiryData = function setExpiryData(data) {\n var prior = this.expirationTime;\n if (data.cacheControl) {\n var parsedCC = parseCacheControl(data.cacheControl);\n if (parsedCC['max-age']) {\n this.expirationTime = Date.now() + parsedCC['max-age'] * 1000;\n }\n } else if (data.expires) {\n this.expirationTime = new Date(data.expires).getTime();\n }\n if (this.expirationTime) {\n var now = Date.now();\n var isExpired = false;\n if (this.expirationTime > now) {\n isExpired = false;\n } else if (!prior) {\n isExpired = true;\n } else if (this.expirationTime < prior) {\n isExpired = true;\n } else {\n var delta = this.expirationTime - prior;\n if (!delta) {\n isExpired = true;\n } else {\n this.expirationTime = now + Math.max(delta, CLOCK_SKEW_RETRY_TIMEOUT);\n }\n }\n if (isExpired) {\n this.expiredRequestCount++;\n this.state = 'expired';\n } else {\n this.expiredRequestCount = 0;\n }\n }\n};\nTile.prototype.getExpiryTimeout = function getExpiryTimeout() {\n if (this.expirationTime) {\n if (this.expiredRequestCount) {\n return 1000 * (1 << Math.min(this.expiredRequestCount - 1, 31));\n } else {\n return Math.min(this.expirationTime - new Date().getTime(), Math.pow(2, 31) - 1);\n }\n }\n};\nTile.prototype.setFeatureState = function setFeatureState(states, painter) {\n if (!this.latestFeatureIndex || !this.latestFeatureIndex.rawTileData || Object.keys(states).length === 0) {\n return;\n }\n var vtLayers = this.latestFeatureIndex.loadVTLayers();\n for (var id in this.buckets) {\n if (!painter.style.hasLayer(id)) {\n continue;\n }\n var bucket = this.buckets[id];\n var sourceLayerId = bucket.layers[0]['sourceLayer'] || '_geojsonTileLayer';\n var sourceLayer = vtLayers[sourceLayerId];\n var sourceLayerStates = states[sourceLayerId];\n if (!sourceLayer || !sourceLayerStates || Object.keys(sourceLayerStates).length === 0) {\n continue;\n }\n bucket.update(sourceLayerStates, sourceLayer, this.imageAtlas && this.imageAtlas.patternPositions || {});\n var layer = painter && painter.style && painter.style.getLayer(id);\n if (layer) {\n this.queryPadding = Math.max(this.queryPadding, layer.queryRadius(bucket));\n }\n }\n};\nTile.prototype.holdingForFade = function holdingForFade() {\n return this.symbolFadeHoldUntil !== undefined;\n};\nTile.prototype.symbolFadeFinished = function symbolFadeFinished() {\n return !this.symbolFadeHoldUntil || this.symbolFadeHoldUntil < exported.now();\n};\nTile.prototype.clearFadeHold = function clearFadeHold() {\n this.symbolFadeHoldUntil = undefined;\n};\nTile.prototype.setHoldDuration = function setHoldDuration(duration) {\n this.symbolFadeHoldUntil = exported.now() + duration;\n};\nTile.prototype.setDependencies = function setDependencies(namespace, dependencies) {\n var index = {};\n for (var i = 0, list = dependencies; i < list.length; i += 1) {\n var dep = list[i];\n index[dep] = true;\n }\n this.dependencies[namespace] = index;\n};\nTile.prototype.hasDependency = function hasDependency(namespaces, keys) {\n for (var i$1 = 0, list$1 = namespaces; i$1 < list$1.length; i$1 += 1) {\n var namespace = list$1[i$1];\n var dependencies = this.dependencies[namespace];\n if (dependencies) {\n for (var i = 0, list = keys; i < list.length; i += 1) {\n var key = list[i];\n if (dependencies[key]) {\n return true;\n }\n }\n }\n }\n return false;\n};\n\nvar refProperties = [\n 'type',\n 'source',\n 'source-layer',\n 'minzoom',\n 'maxzoom',\n 'filter',\n 'layout'\n];\n\nvar performance = window$1.performance;\nvar RequestPerformance = function RequestPerformance(request) {\n this._marks = {\n start: [\n request.url,\n 'start'\n ].join('#'),\n end: [\n request.url,\n 'end'\n ].join('#'),\n measure: request.url.toString()\n };\n performance.mark(this._marks.start);\n};\nRequestPerformance.prototype.finish = function finish() {\n performance.mark(this._marks.end);\n var resourceTimingData = performance.getEntriesByName(this._marks.measure);\n if (resourceTimingData.length === 0) {\n performance.measure(this._marks.measure, this._marks.start, this._marks.end);\n resourceTimingData = performance.getEntriesByName(this._marks.measure);\n performance.clearMarks(this._marks.start);\n performance.clearMarks(this._marks.end);\n performance.clearMeasures(this._marks.measure);\n }\n return resourceTimingData;\n};\n\nexports.Actor = Actor;\nexports.AlphaImage = AlphaImage;\nexports.CanonicalTileID = CanonicalTileID;\nexports.CollisionBoxArray = CollisionBoxArray;\nexports.Color = Color;\nexports.DEMData = DEMData;\nexports.DataConstantProperty = DataConstantProperty;\nexports.DictionaryCoder = DictionaryCoder;\nexports.EXTENT = EXTENT$1;\nexports.ErrorEvent = ErrorEvent;\nexports.EvaluationParameters = EvaluationParameters;\nexports.Event = Event;\nexports.Evented = Evented;\nexports.FeatureIndex = FeatureIndex;\nexports.FillBucket = FillBucket;\nexports.FillExtrusionBucket = FillExtrusionBucket;\nexports.ImageAtlas = ImageAtlas;\nexports.ImagePosition = ImagePosition;\nexports.LineBucket = LineBucket;\nexports.LngLat = LngLat;\nexports.LngLatBounds = LngLatBounds;\nexports.MercatorCoordinate = MercatorCoordinate;\nexports.ONE_EM = ONE_EM;\nexports.OverscaledTileID = OverscaledTileID;\nexports.Point = pointGeometry;\nexports.Point$1 = pointGeometry;\nexports.Properties = Properties;\nexports.Protobuf = pbf;\nexports.RGBAImage = RGBAImage;\nexports.RequestManager = RequestManager;\nexports.RequestPerformance = RequestPerformance;\nexports.ResourceType = ResourceType;\nexports.SegmentVector = SegmentVector;\nexports.SourceFeatureState = SourceFeatureState;\nexports.StructArrayLayout1ui2 = StructArrayLayout1ui2;\nexports.StructArrayLayout2f1f2i16 = StructArrayLayout2f1f2i16;\nexports.StructArrayLayout2i4 = StructArrayLayout2i4;\nexports.StructArrayLayout3ui6 = StructArrayLayout3ui6;\nexports.StructArrayLayout4i8 = StructArrayLayout4i8;\nexports.SymbolBucket = SymbolBucket;\nexports.Texture = Texture;\nexports.Tile = Tile;\nexports.Transitionable = Transitionable;\nexports.Uniform1f = Uniform1f;\nexports.Uniform1i = Uniform1i;\nexports.Uniform2f = Uniform2f;\nexports.Uniform3f = Uniform3f;\nexports.Uniform4f = Uniform4f;\nexports.UniformColor = UniformColor;\nexports.UniformMatrix4f = UniformMatrix4f;\nexports.UnwrappedTileID = UnwrappedTileID;\nexports.ValidationError = ValidationError;\nexports.WritingMode = WritingMode;\nexports.ZoomHistory = ZoomHistory;\nexports.add = add;\nexports.addDynamicAttributes = addDynamicAttributes;\nexports.asyncAll = asyncAll;\nexports.bezier = bezier;\nexports.bindAll = bindAll;\nexports.browser = exported;\nexports.cacheEntryPossiblyAdded = cacheEntryPossiblyAdded;\nexports.clamp = clamp;\nexports.clearTileCache = clearTileCache;\nexports.clipLine = clipLine;\nexports.clone = clone$1;\nexports.clone$1 = clone;\nexports.clone$2 = clone$2;\nexports.collisionCircleLayout = collisionCircleLayout;\nexports.config = config;\nexports.create = create$2;\nexports.create$1 = create$1;\nexports.create$2 = create;\nexports.createCommonjsModule = createCommonjsModule;\nexports.createExpression = createExpression;\nexports.createLayout = createLayout;\nexports.createStyleLayer = createStyleLayer;\nexports.cross = cross;\nexports.deepEqual = deepEqual;\nexports.dot = dot;\nexports.dot$1 = dot$1;\nexports.ease = ease;\nexports.emitValidationErrors = emitValidationErrors;\nexports.endsWith = endsWith;\nexports.enforceCacheSizeLimit = enforceCacheSizeLimit;\nexports.evaluateSizeForFeature = evaluateSizeForFeature;\nexports.evaluateSizeForZoom = evaluateSizeForZoom;\nexports.evaluateVariableOffset = evaluateVariableOffset;\nexports.evented = evented;\nexports.extend = extend;\nexports.featureFilter = createFilter;\nexports.filterObject = filterObject;\nexports.fromRotation = fromRotation;\nexports.getAnchorAlignment = getAnchorAlignment;\nexports.getAnchorJustification = getAnchorJustification;\nexports.getArrayBuffer = getArrayBuffer;\nexports.getImage = getImage;\nexports.getJSON = getJSON;\nexports.getRTLTextPluginStatus = getRTLTextPluginStatus;\nexports.getReferrer = getReferrer;\nexports.getVideo = getVideo;\nexports.identity = identity;\nexports.invert = invert;\nexports.isChar = unicodeBlockLookup;\nexports.isMapboxURL = isMapboxURL;\nexports.keysDifference = keysDifference;\nexports.makeRequest = makeRequest;\nexports.mapObject = mapObject;\nexports.mercatorXfromLng = mercatorXfromLng$1;\nexports.mercatorYfromLat = mercatorYfromLat$1;\nexports.mercatorZfromAltitude = mercatorZfromAltitude;\nexports.mul = mul;\nexports.multiply = multiply;\nexports.mvt = vectorTile;\nexports.nextPowerOfTwo = nextPowerOfTwo;\nexports.normalize = normalize;\nexports.number = number;\nexports.offscreenCanvasSupported = offscreenCanvasSupported;\nexports.ortho = ortho;\nexports.parseGlyphPBF = parseGlyphPBF;\nexports.pbf = pbf;\nexports.performSymbolLayout = performSymbolLayout;\nexports.perspective = perspective;\nexports.pick = pick;\nexports.plugin = plugin;\nexports.polygonIntersectsPolygon = polygonIntersectsPolygon;\nexports.postMapLoadEvent = postMapLoadEvent;\nexports.postTurnstileEvent = postTurnstileEvent;\nexports.potpack = potpack;\nexports.refProperties = refProperties;\nexports.register = register;\nexports.registerForPluginStateChange = registerForPluginStateChange;\nexports.renderColorRamp = renderColorRamp;\nexports.rotate = rotate;\nexports.rotateX = rotateX;\nexports.rotateZ = rotateZ;\nexports.scale = scale;\nexports.scale$1 = scale$2;\nexports.scale$2 = scale$1;\nexports.setCacheLimits = setCacheLimits;\nexports.setRTLTextPlugin = setRTLTextPlugin;\nexports.sphericalToCartesian = sphericalToCartesian;\nexports.sqrLen = sqrLen;\nexports.styleSpec = spec;\nexports.sub = sub;\nexports.symbolSize = symbolSize;\nexports.transformMat3 = transformMat3;\nexports.transformMat4 = transformMat4;\nexports.translate = translate$1;\nexports.triggerPluginCompletionEvent = triggerPluginCompletionEvent;\nexports.uniqueId = uniqueId;\nexports.validateCustomStyleLayer = validateCustomStyleLayer;\nexports.validateLight = validateLight$1;\nexports.validateStyle = validateStyle;\nexports.values = values;\nexports.vectorTile = vectorTile;\nexports.version = version;\nexports.warnOnce = warnOnce;\nexports.webpSupported = exported$1;\nexports.window = window$1;\nexports.wrap = wrap;\n\n});\n\ndefine(['./shared'], function (performance) { 'use strict';\n\nfunction stringify(obj) {\n var type = typeof obj;\n if (type === 'number' || type === 'boolean' || type === 'string' || obj === undefined || obj === null) {\n return JSON.stringify(obj);\n }\n if (Array.isArray(obj)) {\n var str$1 = '[';\n for (var i$1 = 0, list = obj; i$1 < list.length; i$1 += 1) {\n var val = list[i$1];\n str$1 += stringify(val) + ',';\n }\n return str$1 + ']';\n }\n var keys = Object.keys(obj).sort();\n var str = '{';\n for (var i = 0; i < keys.length; i++) {\n str += JSON.stringify(keys[i]) + ':' + stringify(obj[keys[i]]) + ',';\n }\n return str + '}';\n}\nfunction getKey(layer) {\n var key = '';\n for (var i = 0, list = performance.refProperties; i < list.length; i += 1) {\n var k = list[i];\n key += '/' + stringify(layer[k]);\n }\n return key;\n}\nfunction groupByLayout(layers, cachedKeys) {\n var groups = {};\n for (var i = 0; i < layers.length; i++) {\n var k = cachedKeys && cachedKeys[layers[i].id] || getKey(layers[i]);\n if (cachedKeys) {\n cachedKeys[layers[i].id] = k;\n }\n var group = groups[k];\n if (!group) {\n group = groups[k] = [];\n }\n group.push(layers[i]);\n }\n var result = [];\n for (var k$1 in groups) {\n result.push(groups[k$1]);\n }\n return result;\n}\n\nvar StyleLayerIndex = function StyleLayerIndex(layerConfigs) {\n this.keyCache = {};\n if (layerConfigs) {\n this.replace(layerConfigs);\n }\n};\nStyleLayerIndex.prototype.replace = function replace(layerConfigs) {\n this._layerConfigs = {};\n this._layers = {};\n this.update(layerConfigs, []);\n};\nStyleLayerIndex.prototype.update = function update(layerConfigs, removedIds) {\n var this$1 = this;\n for (var i = 0, list = layerConfigs; i < list.length; i += 1) {\n var layerConfig = list[i];\n this._layerConfigs[layerConfig.id] = layerConfig;\n var layer = this._layers[layerConfig.id] = performance.createStyleLayer(layerConfig);\n layer._featureFilter = performance.featureFilter(layer.filter);\n if (this.keyCache[layerConfig.id]) {\n delete this.keyCache[layerConfig.id];\n }\n }\n for (var i$1 = 0, list$1 = removedIds; i$1 < list$1.length; i$1 += 1) {\n var id = list$1[i$1];\n delete this.keyCache[id];\n delete this._layerConfigs[id];\n delete this._layers[id];\n }\n this.familiesBySource = {};\n var groups = groupByLayout(performance.values(this._layerConfigs), this.keyCache);\n for (var i$2 = 0, list$2 = groups; i$2 < list$2.length; i$2 += 1) {\n var layerConfigs$1 = list$2[i$2];\n var layers = layerConfigs$1.map(function (layerConfig) {\n return this$1._layers[layerConfig.id];\n });\n var layer$1 = layers[0];\n if (layer$1.visibility === 'none') {\n continue;\n }\n var sourceId = layer$1.source || '';\n var sourceGroup = this.familiesBySource[sourceId];\n if (!sourceGroup) {\n sourceGroup = this.familiesBySource[sourceId] = {};\n }\n var sourceLayerId = layer$1.sourceLayer || '_geojsonTileLayer';\n var sourceLayerFamilies = sourceGroup[sourceLayerId];\n if (!sourceLayerFamilies) {\n sourceLayerFamilies = sourceGroup[sourceLayerId] = [];\n }\n sourceLayerFamilies.push(layers);\n }\n};\n\nvar padding = 1;\nvar GlyphAtlas = function GlyphAtlas(stacks) {\n var positions = {};\n var bins = [];\n for (var stack in stacks) {\n var glyphs = stacks[stack];\n var stackPositions = positions[stack] = {};\n for (var id in glyphs) {\n var src = glyphs[+id];\n if (!src || src.bitmap.width === 0 || src.bitmap.height === 0) {\n continue;\n }\n var bin = {\n x: 0,\n y: 0,\n w: src.bitmap.width + 2 * padding,\n h: src.bitmap.height + 2 * padding\n };\n bins.push(bin);\n stackPositions[id] = {\n rect: bin,\n metrics: src.metrics\n };\n }\n }\n var ref = performance.potpack(bins);\n var w = ref.w;\n var h = ref.h;\n var image = new performance.AlphaImage({\n width: w || 1,\n height: h || 1\n });\n for (var stack$1 in stacks) {\n var glyphs$1 = stacks[stack$1];\n for (var id$1 in glyphs$1) {\n var src$1 = glyphs$1[+id$1];\n if (!src$1 || src$1.bitmap.width === 0 || src$1.bitmap.height === 0) {\n continue;\n }\n var bin$1 = positions[stack$1][id$1].rect;\n performance.AlphaImage.copy(src$1.bitmap, image, {\n x: 0,\n y: 0\n }, {\n x: bin$1.x + padding,\n y: bin$1.y + padding\n }, src$1.bitmap);\n }\n }\n this.image = image;\n this.positions = positions;\n};\nperformance.register('GlyphAtlas', GlyphAtlas);\n\nvar WorkerTile = function WorkerTile(params) {\n this.tileID = new performance.OverscaledTileID(params.tileID.overscaledZ, params.tileID.wrap, params.tileID.canonical.z, params.tileID.canonical.x, params.tileID.canonical.y);\n this.uid = params.uid;\n this.zoom = params.zoom;\n this.pixelRatio = params.pixelRatio;\n this.tileSize = params.tileSize;\n this.source = params.source;\n this.overscaling = this.tileID.overscaleFactor();\n this.showCollisionBoxes = params.showCollisionBoxes;\n this.collectResourceTiming = !!params.collectResourceTiming;\n this.returnDependencies = !!params.returnDependencies;\n this.promoteId = params.promoteId;\n};\nWorkerTile.prototype.parse = function parse(data, layerIndex, availableImages, actor, callback) {\n var this$1 = this;\n this.status = 'parsing';\n this.data = data;\n this.collisionBoxArray = new performance.CollisionBoxArray();\n var sourceLayerCoder = new performance.DictionaryCoder(Object.keys(data.layers).sort());\n var featureIndex = new performance.FeatureIndex(this.tileID, this.promoteId);\n featureIndex.bucketLayerIDs = [];\n var buckets = {};\n var options = {\n featureIndex: featureIndex,\n iconDependencies: {},\n patternDependencies: {},\n glyphDependencies: {},\n availableImages: availableImages\n };\n var layerFamilies = layerIndex.familiesBySource[this.source];\n for (var sourceLayerId in layerFamilies) {\n var sourceLayer = data.layers[sourceLayerId];\n if (!sourceLayer) {\n continue;\n }\n if (sourceLayer.version === 1) {\n performance.warnOnce('Vector tile source \"' + this.source + '\" layer \"' + sourceLayerId + '\" ' + 'does not use vector tile spec v2 and therefore may have some rendering errors.');\n }\n var sourceLayerIndex = sourceLayerCoder.encode(sourceLayerId);\n var features = [];\n for (var index = 0; index < sourceLayer.length; index++) {\n var feature = sourceLayer.feature(index);\n var id = featureIndex.getId(feature, sourceLayerId);\n features.push({\n feature: feature,\n id: id,\n index: index,\n sourceLayerIndex: sourceLayerIndex\n });\n }\n for (var i = 0, list = layerFamilies[sourceLayerId]; i < list.length; i += 1) {\n var family = list[i];\n var layer = family[0];\n if (layer.minzoom && this.zoom < Math.floor(layer.minzoom)) {\n continue;\n }\n if (layer.maxzoom && this.zoom >= layer.maxzoom) {\n continue;\n }\n if (layer.visibility === 'none') {\n continue;\n }\n recalculateLayers(family, this.zoom, availableImages);\n var bucket = buckets[layer.id] = layer.createBucket({\n index: featureIndex.bucketLayerIDs.length,\n layers: family,\n zoom: this.zoom,\n pixelRatio: this.pixelRatio,\n overscaling: this.overscaling,\n collisionBoxArray: this.collisionBoxArray,\n sourceLayerIndex: sourceLayerIndex,\n sourceID: this.source\n });\n bucket.populate(features, options, this.tileID.canonical);\n featureIndex.bucketLayerIDs.push(family.map(function (l) {\n return l.id;\n }));\n }\n }\n var error;\n var glyphMap;\n var iconMap;\n var patternMap;\n var stacks = performance.mapObject(options.glyphDependencies, function (glyphs) {\n return Object.keys(glyphs).map(Number);\n });\n if (Object.keys(stacks).length) {\n actor.send('getGlyphs', {\n uid: this.uid,\n stacks: stacks\n }, function (err, result) {\n if (!error) {\n error = err;\n glyphMap = result;\n maybePrepare.call(this$1);\n }\n });\n } else {\n glyphMap = {};\n }\n var icons = Object.keys(options.iconDependencies);\n if (icons.length) {\n actor.send('getImages', {\n icons: icons,\n source: this.source,\n tileID: this.tileID,\n type: 'icons'\n }, function (err, result) {\n if (!error) {\n error = err;\n iconMap = result;\n maybePrepare.call(this$1);\n }\n });\n } else {\n iconMap = {};\n }\n var patterns = Object.keys(options.patternDependencies);\n if (patterns.length) {\n actor.send('getImages', {\n icons: patterns,\n source: this.source,\n tileID: this.tileID,\n type: 'patterns'\n }, function (err, result) {\n if (!error) {\n error = err;\n patternMap = result;\n maybePrepare.call(this$1);\n }\n });\n } else {\n patternMap = {};\n }\n maybePrepare.call(this);\n function maybePrepare() {\n if (error) {\n return callback(error);\n } else if (glyphMap && iconMap && patternMap) {\n var glyphAtlas = new GlyphAtlas(glyphMap);\n var imageAtlas = new performance.ImageAtlas(iconMap, patternMap);\n for (var key in buckets) {\n var bucket = buckets[key];\n if (bucket instanceof performance.SymbolBucket) {\n recalculateLayers(bucket.layers, this.zoom, availableImages);\n performance.performSymbolLayout(bucket, glyphMap, glyphAtlas.positions, iconMap, imageAtlas.iconPositions, this.showCollisionBoxes, this.tileID.canonical);\n } else if (bucket.hasPattern && (bucket instanceof performance.LineBucket || bucket instanceof performance.FillBucket || bucket instanceof performance.FillExtrusionBucket)) {\n recalculateLayers(bucket.layers, this.zoom, availableImages);\n bucket.addFeatures(options, this.tileID.canonical, imageAtlas.patternPositions);\n }\n }\n this.status = 'done';\n callback(null, {\n buckets: performance.values(buckets).filter(function (b) {\n return !b.isEmpty();\n }),\n featureIndex: featureIndex,\n collisionBoxArray: this.collisionBoxArray,\n glyphAtlasImage: glyphAtlas.image,\n imageAtlas: imageAtlas,\n glyphMap: this.returnDependencies ? glyphMap : null,\n iconMap: this.returnDependencies ? iconMap : null,\n glyphPositions: this.returnDependencies ? glyphAtlas.positions : null\n });\n }\n }\n};\nfunction recalculateLayers(layers, zoom, availableImages) {\n var parameters = new performance.EvaluationParameters(zoom);\n for (var i = 0, list = layers; i < list.length; i += 1) {\n var layer = list[i];\n layer.recalculate(parameters, availableImages);\n }\n}\n\nfunction loadVectorTile(params, callback) {\n var request = performance.getArrayBuffer(params.request, function (err, data, cacheControl, expires) {\n if (err) {\n callback(err);\n } else if (data) {\n callback(null, {\n vectorTile: new performance.vectorTile.VectorTile(new performance.pbf(data)),\n rawData: data,\n cacheControl: cacheControl,\n expires: expires\n });\n }\n });\n return function () {\n request.cancel();\n callback();\n };\n}\nvar VectorTileWorkerSource = function VectorTileWorkerSource(actor, layerIndex, availableImages, loadVectorData) {\n this.actor = actor;\n this.layerIndex = layerIndex;\n this.availableImages = availableImages;\n this.loadVectorData = loadVectorData || loadVectorTile;\n this.loading = {};\n this.loaded = {};\n};\nVectorTileWorkerSource.prototype.loadTile = function loadTile(params, callback) {\n var this$1 = this;\n var uid = params.uid;\n if (!this.loading) {\n this.loading = {};\n }\n var perf = params && params.request && params.request.collectResourceTiming ? new performance.RequestPerformance(params.request) : false;\n var workerTile = this.loading[uid] = new WorkerTile(params);\n workerTile.abort = this.loadVectorData(params, function (err, response) {\n delete this$1.loading[uid];\n if (err || !response) {\n workerTile.status = 'done';\n this$1.loaded[uid] = workerTile;\n return callback(err);\n }\n var rawTileData = response.rawData;\n var cacheControl = {};\n if (response.expires) {\n cacheControl.expires = response.expires;\n }\n if (response.cacheControl) {\n cacheControl.cacheControl = response.cacheControl;\n }\n var resourceTiming = {};\n if (perf) {\n var resourceTimingData = perf.finish();\n if (resourceTimingData) {\n resourceTiming.resourceTiming = JSON.parse(JSON.stringify(resourceTimingData));\n }\n }\n workerTile.vectorTile = response.vectorTile;\n workerTile.parse(response.vectorTile, this$1.layerIndex, this$1.availableImages, this$1.actor, function (err, result) {\n if (err || !result) {\n return callback(err);\n }\n callback(null, performance.extend({ rawTileData: rawTileData.slice(0) }, result, cacheControl, resourceTiming));\n });\n this$1.loaded = this$1.loaded || {};\n this$1.loaded[uid] = workerTile;\n });\n};\nVectorTileWorkerSource.prototype.reloadTile = function reloadTile(params, callback) {\n var this$1 = this;\n var loaded = this.loaded, uid = params.uid, vtSource = this;\n if (loaded && loaded[uid]) {\n var workerTile = loaded[uid];\n workerTile.showCollisionBoxes = params.showCollisionBoxes;\n var done = function (err, data) {\n var reloadCallback = workerTile.reloadCallback;\n if (reloadCallback) {\n delete workerTile.reloadCallback;\n workerTile.parse(workerTile.vectorTile, vtSource.layerIndex, this$1.availableImages, vtSource.actor, reloadCallback);\n }\n callback(err, data);\n };\n if (workerTile.status === 'parsing') {\n workerTile.reloadCallback = done;\n } else if (workerTile.status === 'done') {\n if (workerTile.vectorTile) {\n workerTile.parse(workerTile.vectorTile, this.layerIndex, this.availableImages, this.actor, done);\n } else {\n done();\n }\n }\n }\n};\nVectorTileWorkerSource.prototype.abortTile = function abortTile(params, callback) {\n var loading = this.loading, uid = params.uid;\n if (loading && loading[uid] && loading[uid].abort) {\n loading[uid].abort();\n delete loading[uid];\n }\n callback();\n};\nVectorTileWorkerSource.prototype.removeTile = function removeTile(params, callback) {\n var loaded = this.loaded, uid = params.uid;\n if (loaded && loaded[uid]) {\n delete loaded[uid];\n }\n callback();\n};\n\nvar ImageBitmap = performance.window.ImageBitmap;\nvar RasterDEMTileWorkerSource = function RasterDEMTileWorkerSource() {\n this.loaded = {};\n};\nRasterDEMTileWorkerSource.prototype.loadTile = function loadTile(params, callback) {\n var uid = params.uid;\n var encoding = params.encoding;\n var rawImageData = params.rawImageData;\n var imagePixels = ImageBitmap && rawImageData instanceof ImageBitmap ? this.getImageData(rawImageData) : rawImageData;\n var dem = new performance.DEMData(uid, imagePixels, encoding);\n this.loaded = this.loaded || {};\n this.loaded[uid] = dem;\n callback(null, dem);\n};\nRasterDEMTileWorkerSource.prototype.getImageData = function getImageData(imgBitmap) {\n if (!this.offscreenCanvas || !this.offscreenCanvasContext) {\n this.offscreenCanvas = new OffscreenCanvas(imgBitmap.width, imgBitmap.height);\n this.offscreenCanvasContext = this.offscreenCanvas.getContext('2d');\n }\n this.offscreenCanvas.width = imgBitmap.width;\n this.offscreenCanvas.height = imgBitmap.height;\n this.offscreenCanvasContext.drawImage(imgBitmap, 0, 0, imgBitmap.width, imgBitmap.height);\n var imgData = this.offscreenCanvasContext.getImageData(-1, -1, imgBitmap.width + 2, imgBitmap.height + 2);\n this.offscreenCanvasContext.clearRect(0, 0, this.offscreenCanvas.width, this.offscreenCanvas.height);\n return new performance.RGBAImage({\n width: imgData.width,\n height: imgData.height\n }, imgData.data);\n};\nRasterDEMTileWorkerSource.prototype.removeTile = function removeTile(params) {\n var loaded = this.loaded, uid = params.uid;\n if (loaded && loaded[uid]) {\n delete loaded[uid];\n }\n};\n\nvar geojsonRewind = rewind;\nfunction rewind(gj, outer) {\n var type = gj && gj.type, i;\n if (type === 'FeatureCollection') {\n for (i = 0; i < gj.features.length; i++) {\n rewind(gj.features[i], outer);\n }\n } else if (type === 'GeometryCollection') {\n for (i = 0; i < gj.geometries.length; i++) {\n rewind(gj.geometries[i], outer);\n }\n } else if (type === 'Feature') {\n rewind(gj.geometry, outer);\n } else if (type === 'Polygon') {\n rewindRings(gj.coordinates, outer);\n } else if (type === 'MultiPolygon') {\n for (i = 0; i < gj.coordinates.length; i++) {\n rewindRings(gj.coordinates[i], outer);\n }\n }\n return gj;\n}\nfunction rewindRings(rings, outer) {\n if (rings.length === 0) {\n return;\n }\n rewindRing(rings[0], outer);\n for (var i = 1; i < rings.length; i++) {\n rewindRing(rings[i], !outer);\n }\n}\nfunction rewindRing(ring, dir) {\n var area = 0;\n for (var i = 0, len = ring.length, j = len - 1; i < len; j = i++) {\n area += (ring[i][0] - ring[j][0]) * (ring[j][1] + ring[i][1]);\n }\n if (area >= 0 !== !!dir) {\n ring.reverse();\n }\n}\n\nvar toGeoJSON = performance.vectorTile.VectorTileFeature.prototype.toGeoJSON;\nvar FeatureWrapper = function FeatureWrapper(feature) {\n this._feature = feature;\n this.extent = performance.EXTENT;\n this.type = feature.type;\n this.properties = feature.tags;\n if ('id' in feature && !isNaN(feature.id)) {\n this.id = parseInt(feature.id, 10);\n }\n};\nFeatureWrapper.prototype.loadGeometry = function loadGeometry() {\n if (this._feature.type === 1) {\n var geometry = [];\n for (var i = 0, list = this._feature.geometry; i < list.length; i += 1) {\n var point = list[i];\n geometry.push([new performance.Point$1(point[0], point[1])]);\n }\n return geometry;\n } else {\n var geometry$1 = [];\n for (var i$2 = 0, list$2 = this._feature.geometry; i$2 < list$2.length; i$2 += 1) {\n var ring = list$2[i$2];\n var newRing = [];\n for (var i$1 = 0, list$1 = ring; i$1 < list$1.length; i$1 += 1) {\n var point$1 = list$1[i$1];\n newRing.push(new performance.Point$1(point$1[0], point$1[1]));\n }\n geometry$1.push(newRing);\n }\n return geometry$1;\n }\n};\nFeatureWrapper.prototype.toGeoJSON = function toGeoJSON$1(x, y, z) {\n return toGeoJSON.call(this, x, y, z);\n};\nvar GeoJSONWrapper = function GeoJSONWrapper(features) {\n this.layers = { '_geojsonTileLayer': this };\n this.name = '_geojsonTileLayer';\n this.extent = performance.EXTENT;\n this.length = features.length;\n this._features = features;\n};\nGeoJSONWrapper.prototype.feature = function feature(i) {\n return new FeatureWrapper(this._features[i]);\n};\n\nvar VectorTileFeature = performance.vectorTile.VectorTileFeature;\nvar geojson_wrapper = GeoJSONWrapper$1;\nfunction GeoJSONWrapper$1(features, options) {\n this.options = options || {};\n this.features = features;\n this.length = features.length;\n}\nGeoJSONWrapper$1.prototype.feature = function (i) {\n return new FeatureWrapper$1(this.features[i], this.options.extent);\n};\nfunction FeatureWrapper$1(feature, extent) {\n this.id = typeof feature.id === 'number' ? feature.id : undefined;\n this.type = feature.type;\n this.rawGeometry = feature.type === 1 ? [feature.geometry] : feature.geometry;\n this.properties = feature.tags;\n this.extent = extent || 4096;\n}\nFeatureWrapper$1.prototype.loadGeometry = function () {\n var rings = this.rawGeometry;\n this.geometry = [];\n for (var i = 0; i < rings.length; i++) {\n var ring = rings[i];\n var newRing = [];\n for (var j = 0; j < ring.length; j++) {\n newRing.push(new performance.Point$1(ring[j][0], ring[j][1]));\n }\n this.geometry.push(newRing);\n }\n return this.geometry;\n};\nFeatureWrapper$1.prototype.bbox = function () {\n if (!this.geometry) {\n this.loadGeometry();\n }\n var rings = this.geometry;\n var x1 = Infinity;\n var x2 = -Infinity;\n var y1 = Infinity;\n var y2 = -Infinity;\n for (var i = 0; i < rings.length; i++) {\n var ring = rings[i];\n for (var j = 0; j < ring.length; j++) {\n var coord = ring[j];\n x1 = Math.min(x1, coord.x);\n x2 = Math.max(x2, coord.x);\n y1 = Math.min(y1, coord.y);\n y2 = Math.max(y2, coord.y);\n }\n }\n return [\n x1,\n y1,\n x2,\n y2\n ];\n};\nFeatureWrapper$1.prototype.toGeoJSON = VectorTileFeature.prototype.toGeoJSON;\n\nvar vtPbf = fromVectorTileJs;\nvar fromVectorTileJs_1 = fromVectorTileJs;\nvar fromGeojsonVt_1 = fromGeojsonVt;\nvar GeoJSONWrapper_1 = geojson_wrapper;\nfunction fromVectorTileJs(tile) {\n var out = new performance.pbf();\n writeTile(tile, out);\n return out.finish();\n}\nfunction fromGeojsonVt(layers, options) {\n options = options || {};\n var l = {};\n for (var k in layers) {\n l[k] = new geojson_wrapper(layers[k].features, options);\n l[k].name = k;\n l[k].version = options.version;\n l[k].extent = options.extent;\n }\n return fromVectorTileJs({ layers: l });\n}\nfunction writeTile(tile, pbf) {\n for (var key in tile.layers) {\n pbf.writeMessage(3, writeLayer, tile.layers[key]);\n }\n}\nfunction writeLayer(layer, pbf) {\n pbf.writeVarintField(15, layer.version || 1);\n pbf.writeStringField(1, layer.name || '');\n pbf.writeVarintField(5, layer.extent || 4096);\n var i;\n var context = {\n keys: [],\n values: [],\n keycache: {},\n valuecache: {}\n };\n for (i = 0; i < layer.length; i++) {\n context.feature = layer.feature(i);\n pbf.writeMessage(2, writeFeature, context);\n }\n var keys = context.keys;\n for (i = 0; i < keys.length; i++) {\n pbf.writeStringField(3, keys[i]);\n }\n var values = context.values;\n for (i = 0; i < values.length; i++) {\n pbf.writeMessage(4, writeValue, values[i]);\n }\n}\nfunction writeFeature(context, pbf) {\n var feature = context.feature;\n if (feature.id !== undefined) {\n pbf.writeVarintField(1, feature.id);\n }\n pbf.writeMessage(2, writeProperties, context);\n pbf.writeVarintField(3, feature.type);\n pbf.writeMessage(4, writeGeometry, feature);\n}\nfunction writeProperties(context, pbf) {\n var feature = context.feature;\n var keys = context.keys;\n var values = context.values;\n var keycache = context.keycache;\n var valuecache = context.valuecache;\n for (var key in feature.properties) {\n var keyIndex = keycache[key];\n if (typeof keyIndex === 'undefined') {\n keys.push(key);\n keyIndex = keys.length - 1;\n keycache[key] = keyIndex;\n }\n pbf.writeVarint(keyIndex);\n var value = feature.properties[key];\n var type = typeof value;\n if (type !== 'string' && type !== 'boolean' && type !== 'number') {\n value = JSON.stringify(value);\n }\n var valueKey = type + ':' + value;\n var valueIndex = valuecache[valueKey];\n if (typeof valueIndex === 'undefined') {\n values.push(value);\n valueIndex = values.length - 1;\n valuecache[valueKey] = valueIndex;\n }\n pbf.writeVarint(valueIndex);\n }\n}\nfunction command(cmd, length) {\n return (length << 3) + (cmd & 7);\n}\nfunction zigzag(num) {\n return num << 1 ^ num >> 31;\n}\nfunction writeGeometry(feature, pbf) {\n var geometry = feature.loadGeometry();\n var type = feature.type;\n var x = 0;\n var y = 0;\n var rings = geometry.length;\n for (var r = 0; r < rings; r++) {\n var ring = geometry[r];\n var count = 1;\n if (type === 1) {\n count = ring.length;\n }\n pbf.writeVarint(command(1, count));\n var lineCount = type === 3 ? ring.length - 1 : ring.length;\n for (var i = 0; i < lineCount; i++) {\n if (i === 1 && type !== 1) {\n pbf.writeVarint(command(2, lineCount - 1));\n }\n var dx = ring[i].x - x;\n var dy = ring[i].y - y;\n pbf.writeVarint(zigzag(dx));\n pbf.writeVarint(zigzag(dy));\n x += dx;\n y += dy;\n }\n if (type === 3) {\n pbf.writeVarint(command(7, 1));\n }\n }\n}\nfunction writeValue(value, pbf) {\n var type = typeof value;\n if (type === 'string') {\n pbf.writeStringField(1, value);\n } else if (type === 'boolean') {\n pbf.writeBooleanField(7, value);\n } else if (type === 'number') {\n if (value % 1 !== 0) {\n pbf.writeDoubleField(3, value);\n } else if (value < 0) {\n pbf.writeSVarintField(6, value);\n } else {\n pbf.writeVarintField(5, value);\n }\n }\n}\nvtPbf.fromVectorTileJs = fromVectorTileJs_1;\nvtPbf.fromGeojsonVt = fromGeojsonVt_1;\nvtPbf.GeoJSONWrapper = GeoJSONWrapper_1;\n\nfunction sortKD(ids, coords, nodeSize, left, right, depth) {\n if (right - left <= nodeSize) {\n return;\n }\n var m = left + right >> 1;\n select(ids, coords, m, left, right, depth % 2);\n sortKD(ids, coords, nodeSize, left, m - 1, depth + 1);\n sortKD(ids, coords, nodeSize, m + 1, right, depth + 1);\n}\nfunction select(ids, coords, k, left, right, inc) {\n while (right > left) {\n if (right - left > 600) {\n var n = right - left + 1;\n var m = k - left + 1;\n var z = Math.log(n);\n var s = 0.5 * Math.exp(2 * z / 3);\n var sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n var newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n var newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n select(ids, coords, k, newLeft, newRight, inc);\n }\n var t = coords[2 * k + inc];\n var i = left;\n var j = right;\n swapItem(ids, coords, left, k);\n if (coords[2 * right + inc] > t) {\n swapItem(ids, coords, left, right);\n }\n while (i < j) {\n swapItem(ids, coords, i, j);\n i++;\n j--;\n while (coords[2 * i + inc] < t) {\n i++;\n }\n while (coords[2 * j + inc] > t) {\n j--;\n }\n }\n if (coords[2 * left + inc] === t) {\n swapItem(ids, coords, left, j);\n } else {\n j++;\n swapItem(ids, coords, j, right);\n }\n if (j <= k) {\n left = j + 1;\n }\n if (k <= j) {\n right = j - 1;\n }\n }\n}\nfunction swapItem(ids, coords, i, j) {\n swap(ids, i, j);\n swap(coords, 2 * i, 2 * j);\n swap(coords, 2 * i + 1, 2 * j + 1);\n}\nfunction swap(arr, i, j) {\n var tmp = arr[i];\n arr[i] = arr[j];\n arr[j] = tmp;\n}\n\nfunction range(ids, coords, minX, minY, maxX, maxY, nodeSize) {\n var stack = [\n 0,\n ids.length - 1,\n 0\n ];\n var result = [];\n var x, y;\n while (stack.length) {\n var axis = stack.pop();\n var right = stack.pop();\n var left = stack.pop();\n if (right - left <= nodeSize) {\n for (var i = left; i <= right; i++) {\n x = coords[2 * i];\n y = coords[2 * i + 1];\n if (x >= minX && x <= maxX && y >= minY && y <= maxY) {\n result.push(ids[i]);\n }\n }\n continue;\n }\n var m = Math.floor((left + right) / 2);\n x = coords[2 * m];\n y = coords[2 * m + 1];\n if (x >= minX && x <= maxX && y >= minY && y <= maxY) {\n result.push(ids[m]);\n }\n var nextAxis = (axis + 1) % 2;\n if (axis === 0 ? minX <= x : minY <= y) {\n stack.push(left);\n stack.push(m - 1);\n stack.push(nextAxis);\n }\n if (axis === 0 ? maxX >= x : maxY >= y) {\n stack.push(m + 1);\n stack.push(right);\n stack.push(nextAxis);\n }\n }\n return result;\n}\n\nfunction within(ids, coords, qx, qy, r, nodeSize) {\n var stack = [\n 0,\n ids.length - 1,\n 0\n ];\n var result = [];\n var r2 = r * r;\n while (stack.length) {\n var axis = stack.pop();\n var right = stack.pop();\n var left = stack.pop();\n if (right - left <= nodeSize) {\n for (var i = left; i <= right; i++) {\n if (sqDist(coords[2 * i], coords[2 * i + 1], qx, qy) <= r2) {\n result.push(ids[i]);\n }\n }\n continue;\n }\n var m = Math.floor((left + right) / 2);\n var x = coords[2 * m];\n var y = coords[2 * m + 1];\n if (sqDist(x, y, qx, qy) <= r2) {\n result.push(ids[m]);\n }\n var nextAxis = (axis + 1) % 2;\n if (axis === 0 ? qx - r <= x : qy - r <= y) {\n stack.push(left);\n stack.push(m - 1);\n stack.push(nextAxis);\n }\n if (axis === 0 ? qx + r >= x : qy + r >= y) {\n stack.push(m + 1);\n stack.push(right);\n stack.push(nextAxis);\n }\n }\n return result;\n}\nfunction sqDist(ax, ay, bx, by) {\n var dx = ax - bx;\n var dy = ay - by;\n return dx * dx + dy * dy;\n}\n\nvar defaultGetX = function (p) {\n return p[0];\n};\nvar defaultGetY = function (p) {\n return p[1];\n};\nvar KDBush = function KDBush(points, getX, getY, nodeSize, ArrayType) {\n if (getX === void 0)\n getX = defaultGetX;\n if (getY === void 0)\n getY = defaultGetY;\n if (nodeSize === void 0)\n nodeSize = 64;\n if (ArrayType === void 0)\n ArrayType = Float64Array;\n this.nodeSize = nodeSize;\n this.points = points;\n var IndexArrayType = points.length < 65536 ? Uint16Array : Uint32Array;\n var ids = this.ids = new IndexArrayType(points.length);\n var coords = this.coords = new ArrayType(points.length * 2);\n for (var i = 0; i < points.length; i++) {\n ids[i] = i;\n coords[2 * i] = getX(points[i]);\n coords[2 * i + 1] = getY(points[i]);\n }\n sortKD(ids, coords, nodeSize, 0, ids.length - 1, 0);\n};\nKDBush.prototype.range = function range$1(minX, minY, maxX, maxY) {\n return range(this.ids, this.coords, minX, minY, maxX, maxY, this.nodeSize);\n};\nKDBush.prototype.within = function within$1(x, y, r) {\n return within(this.ids, this.coords, x, y, r, this.nodeSize);\n};\n\nvar defaultOptions = {\n minZoom: 0,\n maxZoom: 16,\n minPoints: 2,\n radius: 40,\n extent: 512,\n nodeSize: 64,\n log: false,\n generateId: false,\n reduce: null,\n map: function (props) {\n return props;\n }\n};\nvar Supercluster = function Supercluster(options) {\n this.options = extend(Object.create(defaultOptions), options);\n this.trees = new Array(this.options.maxZoom + 1);\n};\nSupercluster.prototype.load = function load(points) {\n var ref = this.options;\n var log = ref.log;\n var minZoom = ref.minZoom;\n var maxZoom = ref.maxZoom;\n var nodeSize = ref.nodeSize;\n if (log) {\n console.time('total time');\n }\n var timerId = 'prepare ' + points.length + ' points';\n if (log) {\n console.time(timerId);\n }\n this.points = points;\n var clusters = [];\n for (var i = 0; i < points.length; i++) {\n if (!points[i].geometry) {\n continue;\n }\n clusters.push(createPointCluster(points[i], i));\n }\n this.trees[maxZoom + 1] = new KDBush(clusters, getX, getY, nodeSize, Float32Array);\n if (log) {\n console.timeEnd(timerId);\n }\n for (var z = maxZoom; z >= minZoom; z--) {\n var now = +Date.now();\n clusters = this._cluster(clusters, z);\n this.trees[z] = new KDBush(clusters, getX, getY, nodeSize, Float32Array);\n if (log) {\n console.log('z%d: %d clusters in %dms', z, clusters.length, +Date.now() - now);\n }\n }\n if (log) {\n console.timeEnd('total time');\n }\n return this;\n};\nSupercluster.prototype.getClusters = function getClusters(bbox, zoom) {\n var minLng = ((bbox[0] + 180) % 360 + 360) % 360 - 180;\n var minLat = Math.max(-90, Math.min(90, bbox[1]));\n var maxLng = bbox[2] === 180 ? 180 : ((bbox[2] + 180) % 360 + 360) % 360 - 180;\n var maxLat = Math.max(-90, Math.min(90, bbox[3]));\n if (bbox[2] - bbox[0] >= 360) {\n minLng = -180;\n maxLng = 180;\n } else if (minLng > maxLng) {\n var easternHem = this.getClusters([\n minLng,\n minLat,\n 180,\n maxLat\n ], zoom);\n var westernHem = this.getClusters([\n -180,\n minLat,\n maxLng,\n maxLat\n ], zoom);\n return easternHem.concat(westernHem);\n }\n var tree = this.trees[this._limitZoom(zoom)];\n var ids = tree.range(lngX(minLng), latY(maxLat), lngX(maxLng), latY(minLat));\n var clusters = [];\n for (var i = 0, list = ids; i < list.length; i += 1) {\n var id = list[i];\n var c = tree.points[id];\n clusters.push(c.numPoints ? getClusterJSON(c) : this.points[c.index]);\n }\n return clusters;\n};\nSupercluster.prototype.getChildren = function getChildren(clusterId) {\n var originId = this._getOriginId(clusterId);\n var originZoom = this._getOriginZoom(clusterId);\n var errorMsg = 'No cluster with the specified id.';\n var index = this.trees[originZoom];\n if (!index) {\n throw new Error(errorMsg);\n }\n var origin = index.points[originId];\n if (!origin) {\n throw new Error(errorMsg);\n }\n var r = this.options.radius / (this.options.extent * Math.pow(2, originZoom - 1));\n var ids = index.within(origin.x, origin.y, r);\n var children = [];\n for (var i = 0, list = ids; i < list.length; i += 1) {\n var id = list[i];\n var c = index.points[id];\n if (c.parentId === clusterId) {\n children.push(c.numPoints ? getClusterJSON(c) : this.points[c.index]);\n }\n }\n if (children.length === 0) {\n throw new Error(errorMsg);\n }\n return children;\n};\nSupercluster.prototype.getLeaves = function getLeaves(clusterId, limit, offset) {\n limit = limit || 10;\n offset = offset || 0;\n var leaves = [];\n this._appendLeaves(leaves, clusterId, limit, offset, 0);\n return leaves;\n};\nSupercluster.prototype.getTile = function getTile(z, x, y) {\n var tree = this.trees[this._limitZoom(z)];\n var z2 = Math.pow(2, z);\n var ref = this.options;\n var extent = ref.extent;\n var radius = ref.radius;\n var p = radius / extent;\n var top = (y - p) / z2;\n var bottom = (y + 1 + p) / z2;\n var tile = { features: [] };\n this._addTileFeatures(tree.range((x - p) / z2, top, (x + 1 + p) / z2, bottom), tree.points, x, y, z2, tile);\n if (x === 0) {\n this._addTileFeatures(tree.range(1 - p / z2, top, 1, bottom), tree.points, z2, y, z2, tile);\n }\n if (x === z2 - 1) {\n this._addTileFeatures(tree.range(0, top, p / z2, bottom), tree.points, -1, y, z2, tile);\n }\n return tile.features.length ? tile : null;\n};\nSupercluster.prototype.getClusterExpansionZoom = function getClusterExpansionZoom(clusterId) {\n var expansionZoom = this._getOriginZoom(clusterId) - 1;\n while (expansionZoom <= this.options.maxZoom) {\n var children = this.getChildren(clusterId);\n expansionZoom++;\n if (children.length !== 1) {\n break;\n }\n clusterId = children[0].properties.cluster_id;\n }\n return expansionZoom;\n};\nSupercluster.prototype._appendLeaves = function _appendLeaves(result, clusterId, limit, offset, skipped) {\n var children = this.getChildren(clusterId);\n for (var i = 0, list = children; i < list.length; i += 1) {\n var child = list[i];\n var props = child.properties;\n if (props && props.cluster) {\n if (skipped + props.point_count <= offset) {\n skipped += props.point_count;\n } else {\n skipped = this._appendLeaves(result, props.cluster_id, limit, offset, skipped);\n }\n } else if (skipped < offset) {\n skipped++;\n } else {\n result.push(child);\n }\n if (result.length === limit) {\n break;\n }\n }\n return skipped;\n};\nSupercluster.prototype._addTileFeatures = function _addTileFeatures(ids, points, x, y, z2, tile) {\n for (var i$1 = 0, list = ids; i$1 < list.length; i$1 += 1) {\n var i = list[i$1];\n var c = points[i];\n var isCluster = c.numPoints;\n var f = {\n type: 1,\n geometry: [[\n Math.round(this.options.extent * (c.x * z2 - x)),\n Math.round(this.options.extent * (c.y * z2 - y))\n ]],\n tags: isCluster ? getClusterProperties(c) : this.points[c.index].properties\n };\n var id = void 0;\n if (isCluster) {\n id = c.id;\n } else if (this.options.generateId) {\n id = c.index;\n } else if (this.points[c.index].id) {\n id = this.points[c.index].id;\n }\n if (id !== undefined) {\n f.id = id;\n }\n tile.features.push(f);\n }\n};\nSupercluster.prototype._limitZoom = function _limitZoom(z) {\n return Math.max(this.options.minZoom, Math.min(+z, this.options.maxZoom + 1));\n};\nSupercluster.prototype._cluster = function _cluster(points, zoom) {\n var clusters = [];\n var ref = this.options;\n var radius = ref.radius;\n var extent = ref.extent;\n var reduce = ref.reduce;\n var minPoints = ref.minPoints;\n var r = radius / (extent * Math.pow(2, zoom));\n for (var i = 0; i < points.length; i++) {\n var p = points[i];\n if (p.zoom <= zoom) {\n continue;\n }\n p.zoom = zoom;\n var tree = this.trees[zoom + 1];\n var neighborIds = tree.within(p.x, p.y, r);\n var numPointsOrigin = p.numPoints || 1;\n var numPoints = numPointsOrigin;\n for (var i$1 = 0, list = neighborIds; i$1 < list.length; i$1 += 1) {\n var neighborId = list[i$1];\n var b = tree.points[neighborId];\n if (b.zoom > zoom) {\n numPoints += b.numPoints || 1;\n }\n }\n if (numPoints >= minPoints) {\n var wx = p.x * numPointsOrigin;\n var wy = p.y * numPointsOrigin;\n var clusterProperties = reduce && numPointsOrigin > 1 ? this._map(p, true) : null;\n var id = (i << 5) + (zoom + 1) + this.points.length;\n for (var i$2 = 0, list$1 = neighborIds; i$2 < list$1.length; i$2 += 1) {\n var neighborId$1 = list$1[i$2];\n var b$1 = tree.points[neighborId$1];\n if (b$1.zoom <= zoom) {\n continue;\n }\n b$1.zoom = zoom;\n var numPoints2 = b$1.numPoints || 1;\n wx += b$1.x * numPoints2;\n wy += b$1.y * numPoints2;\n b$1.parentId = id;\n if (reduce) {\n if (!clusterProperties) {\n clusterProperties = this._map(p, true);\n }\n reduce(clusterProperties, this._map(b$1));\n }\n }\n p.parentId = id;\n clusters.push(createCluster(wx / numPoints, wy / numPoints, id, numPoints, clusterProperties));\n } else {\n clusters.push(p);\n if (numPoints > 1) {\n for (var i$3 = 0, list$2 = neighborIds; i$3 < list$2.length; i$3 += 1) {\n var neighborId$2 = list$2[i$3];\n var b$2 = tree.points[neighborId$2];\n if (b$2.zoom <= zoom) {\n continue;\n }\n b$2.zoom = zoom;\n clusters.push(b$2);\n }\n }\n }\n }\n return clusters;\n};\nSupercluster.prototype._getOriginId = function _getOriginId(clusterId) {\n return clusterId - this.points.length >> 5;\n};\nSupercluster.prototype._getOriginZoom = function _getOriginZoom(clusterId) {\n return (clusterId - this.points.length) % 32;\n};\nSupercluster.prototype._map = function _map(point, clone) {\n if (point.numPoints) {\n return clone ? extend({}, point.properties) : point.properties;\n }\n var original = this.points[point.index].properties;\n var result = this.options.map(original);\n return clone && result === original ? extend({}, result) : result;\n};\nfunction createCluster(x, y, id, numPoints, properties) {\n return {\n x: x,\n y: y,\n zoom: Infinity,\n id: id,\n parentId: -1,\n numPoints: numPoints,\n properties: properties\n };\n}\nfunction createPointCluster(p, id) {\n var ref = p.geometry.coordinates;\n var x = ref[0];\n var y = ref[1];\n return {\n x: lngX(x),\n y: latY(y),\n zoom: Infinity,\n index: id,\n parentId: -1\n };\n}\nfunction getClusterJSON(cluster) {\n return {\n type: 'Feature',\n id: cluster.id,\n properties: getClusterProperties(cluster),\n geometry: {\n type: 'Point',\n coordinates: [\n xLng(cluster.x),\n yLat(cluster.y)\n ]\n }\n };\n}\nfunction getClusterProperties(cluster) {\n var count = cluster.numPoints;\n var abbrev = count >= 10000 ? Math.round(count / 1000) + 'k' : count >= 1000 ? Math.round(count / 100) / 10 + 'k' : count;\n return extend(extend({}, cluster.properties), {\n cluster: true,\n cluster_id: cluster.id,\n point_count: count,\n point_count_abbreviated: abbrev\n });\n}\nfunction lngX(lng) {\n return lng / 360 + 0.5;\n}\nfunction latY(lat) {\n var sin = Math.sin(lat * Math.PI / 180);\n var y = 0.5 - 0.25 * Math.log((1 + sin) / (1 - sin)) / Math.PI;\n return y < 0 ? 0 : y > 1 ? 1 : y;\n}\nfunction xLng(x) {\n return (x - 0.5) * 360;\n}\nfunction yLat(y) {\n var y2 = (180 - y * 360) * Math.PI / 180;\n return 360 * Math.atan(Math.exp(y2)) / Math.PI - 90;\n}\nfunction extend(dest, src) {\n for (var id in src) {\n dest[id] = src[id];\n }\n return dest;\n}\nfunction getX(p) {\n return p.x;\n}\nfunction getY(p) {\n return p.y;\n}\n\nfunction simplify(coords, first, last, sqTolerance) {\n var maxSqDist = sqTolerance;\n var mid = last - first >> 1;\n var minPosToMid = last - first;\n var index;\n var ax = coords[first];\n var ay = coords[first + 1];\n var bx = coords[last];\n var by = coords[last + 1];\n for (var i = first + 3; i < last; i += 3) {\n var d = getSqSegDist(coords[i], coords[i + 1], ax, ay, bx, by);\n if (d > maxSqDist) {\n index = i;\n maxSqDist = d;\n } else if (d === maxSqDist) {\n var posToMid = Math.abs(i - mid);\n if (posToMid < minPosToMid) {\n index = i;\n minPosToMid = posToMid;\n }\n }\n }\n if (maxSqDist > sqTolerance) {\n if (index - first > 3) {\n simplify(coords, first, index, sqTolerance);\n }\n coords[index + 2] = maxSqDist;\n if (last - index > 3) {\n simplify(coords, index, last, sqTolerance);\n }\n }\n}\nfunction getSqSegDist(px, py, x, y, bx, by) {\n var dx = bx - x;\n var dy = by - y;\n if (dx !== 0 || dy !== 0) {\n var t = ((px - x) * dx + (py - y) * dy) / (dx * dx + dy * dy);\n if (t > 1) {\n x = bx;\n y = by;\n } else if (t > 0) {\n x += dx * t;\n y += dy * t;\n }\n }\n dx = px - x;\n dy = py - y;\n return dx * dx + dy * dy;\n}\n\nfunction createFeature(id, type, geom, tags) {\n var feature = {\n id: typeof id === 'undefined' ? null : id,\n type: type,\n geometry: geom,\n tags: tags,\n minX: Infinity,\n minY: Infinity,\n maxX: -Infinity,\n maxY: -Infinity\n };\n calcBBox(feature);\n return feature;\n}\nfunction calcBBox(feature) {\n var geom = feature.geometry;\n var type = feature.type;\n if (type === 'Point' || type === 'MultiPoint' || type === 'LineString') {\n calcLineBBox(feature, geom);\n } else if (type === 'Polygon' || type === 'MultiLineString') {\n for (var i = 0; i < geom.length; i++) {\n calcLineBBox(feature, geom[i]);\n }\n } else if (type === 'MultiPolygon') {\n for (i = 0; i < geom.length; i++) {\n for (var j = 0; j < geom[i].length; j++) {\n calcLineBBox(feature, geom[i][j]);\n }\n }\n }\n}\nfunction calcLineBBox(feature, geom) {\n for (var i = 0; i < geom.length; i += 3) {\n feature.minX = Math.min(feature.minX, geom[i]);\n feature.minY = Math.min(feature.minY, geom[i + 1]);\n feature.maxX = Math.max(feature.maxX, geom[i]);\n feature.maxY = Math.max(feature.maxY, geom[i + 1]);\n }\n}\n\nfunction convert(data, options) {\n var features = [];\n if (data.type === 'FeatureCollection') {\n for (var i = 0; i < data.features.length; i++) {\n convertFeature(features, data.features[i], options, i);\n }\n } else if (data.type === 'Feature') {\n convertFeature(features, data, options);\n } else {\n convertFeature(features, { geometry: data }, options);\n }\n return features;\n}\nfunction convertFeature(features, geojson, options, index) {\n if (!geojson.geometry) {\n return;\n }\n var coords = geojson.geometry.coordinates;\n var type = geojson.geometry.type;\n var tolerance = Math.pow(options.tolerance / ((1 << options.maxZoom) * options.extent), 2);\n var geometry = [];\n var id = geojson.id;\n if (options.promoteId) {\n id = geojson.properties[options.promoteId];\n } else if (options.generateId) {\n id = index || 0;\n }\n if (type === 'Point') {\n convertPoint(coords, geometry);\n } else if (type === 'MultiPoint') {\n for (var i = 0; i < coords.length; i++) {\n convertPoint(coords[i], geometry);\n }\n } else if (type === 'LineString') {\n convertLine(coords, geometry, tolerance, false);\n } else if (type === 'MultiLineString') {\n if (options.lineMetrics) {\n for (i = 0; i < coords.length; i++) {\n geometry = [];\n convertLine(coords[i], geometry, tolerance, false);\n features.push(createFeature(id, 'LineString', geometry, geojson.properties));\n }\n return;\n } else {\n convertLines(coords, geometry, tolerance, false);\n }\n } else if (type === 'Polygon') {\n convertLines(coords, geometry, tolerance, true);\n } else if (type === 'MultiPolygon') {\n for (i = 0; i < coords.length; i++) {\n var polygon = [];\n convertLines(coords[i], polygon, tolerance, true);\n geometry.push(polygon);\n }\n } else if (type === 'GeometryCollection') {\n for (i = 0; i < geojson.geometry.geometries.length; i++) {\n convertFeature(features, {\n id: id,\n geometry: geojson.geometry.geometries[i],\n properties: geojson.properties\n }, options, index);\n }\n return;\n } else {\n throw new Error('Input data is not a valid GeoJSON object.');\n }\n features.push(createFeature(id, type, geometry, geojson.properties));\n}\nfunction convertPoint(coords, out) {\n out.push(projectX(coords[0]));\n out.push(projectY(coords[1]));\n out.push(0);\n}\nfunction convertLine(ring, out, tolerance, isPolygon) {\n var x0, y0;\n var size = 0;\n for (var j = 0; j < ring.length; j++) {\n var x = projectX(ring[j][0]);\n var y = projectY(ring[j][1]);\n out.push(x);\n out.push(y);\n out.push(0);\n if (j > 0) {\n if (isPolygon) {\n size += (x0 * y - x * y0) / 2;\n } else {\n size += Math.sqrt(Math.pow(x - x0, 2) + Math.pow(y - y0, 2));\n }\n }\n x0 = x;\n y0 = y;\n }\n var last = out.length - 3;\n out[2] = 1;\n simplify(out, 0, last, tolerance);\n out[last + 2] = 1;\n out.size = Math.abs(size);\n out.start = 0;\n out.end = out.size;\n}\nfunction convertLines(rings, out, tolerance, isPolygon) {\n for (var i = 0; i < rings.length; i++) {\n var geom = [];\n convertLine(rings[i], geom, tolerance, isPolygon);\n out.push(geom);\n }\n}\nfunction projectX(x) {\n return x / 360 + 0.5;\n}\nfunction projectY(y) {\n var sin = Math.sin(y * Math.PI / 180);\n var y2 = 0.5 - 0.25 * Math.log((1 + sin) / (1 - sin)) / Math.PI;\n return y2 < 0 ? 0 : y2 > 1 ? 1 : y2;\n}\n\nfunction clip(features, scale, k1, k2, axis, minAll, maxAll, options) {\n k1 /= scale;\n k2 /= scale;\n if (minAll >= k1 && maxAll < k2) {\n return features;\n } else if (maxAll < k1 || minAll >= k2) {\n return null;\n }\n var clipped = [];\n for (var i = 0; i < features.length; i++) {\n var feature = features[i];\n var geometry = feature.geometry;\n var type = feature.type;\n var min = axis === 0 ? feature.minX : feature.minY;\n var max = axis === 0 ? feature.maxX : feature.maxY;\n if (min >= k1 && max < k2) {\n clipped.push(feature);\n continue;\n } else if (max < k1 || min >= k2) {\n continue;\n }\n var newGeometry = [];\n if (type === 'Point' || type === 'MultiPoint') {\n clipPoints(geometry, newGeometry, k1, k2, axis);\n } else if (type === 'LineString') {\n clipLine(geometry, newGeometry, k1, k2, axis, false, options.lineMetrics);\n } else if (type === 'MultiLineString') {\n clipLines(geometry, newGeometry, k1, k2, axis, false);\n } else if (type === 'Polygon') {\n clipLines(geometry, newGeometry, k1, k2, axis, true);\n } else if (type === 'MultiPolygon') {\n for (var j = 0; j < geometry.length; j++) {\n var polygon = [];\n clipLines(geometry[j], polygon, k1, k2, axis, true);\n if (polygon.length) {\n newGeometry.push(polygon);\n }\n }\n }\n if (newGeometry.length) {\n if (options.lineMetrics && type === 'LineString') {\n for (j = 0; j < newGeometry.length; j++) {\n clipped.push(createFeature(feature.id, type, newGeometry[j], feature.tags));\n }\n continue;\n }\n if (type === 'LineString' || type === 'MultiLineString') {\n if (newGeometry.length === 1) {\n type = 'LineString';\n newGeometry = newGeometry[0];\n } else {\n type = 'MultiLineString';\n }\n }\n if (type === 'Point' || type === 'MultiPoint') {\n type = newGeometry.length === 3 ? 'Point' : 'MultiPoint';\n }\n clipped.push(createFeature(feature.id, type, newGeometry, feature.tags));\n }\n }\n return clipped.length ? clipped : null;\n}\nfunction clipPoints(geom, newGeom, k1, k2, axis) {\n for (var i = 0; i < geom.length; i += 3) {\n var a = geom[i + axis];\n if (a >= k1 && a <= k2) {\n newGeom.push(geom[i]);\n newGeom.push(geom[i + 1]);\n newGeom.push(geom[i + 2]);\n }\n }\n}\nfunction clipLine(geom, newGeom, k1, k2, axis, isPolygon, trackMetrics) {\n var slice = newSlice(geom);\n var intersect = axis === 0 ? intersectX : intersectY;\n var len = geom.start;\n var segLen, t;\n for (var i = 0; i < geom.length - 3; i += 3) {\n var ax = geom[i];\n var ay = geom[i + 1];\n var az = geom[i + 2];\n var bx = geom[i + 3];\n var by = geom[i + 4];\n var a = axis === 0 ? ax : ay;\n var b = axis === 0 ? bx : by;\n var exited = false;\n if (trackMetrics) {\n segLen = Math.sqrt(Math.pow(ax - bx, 2) + Math.pow(ay - by, 2));\n }\n if (a < k1) {\n if (b > k1) {\n t = intersect(slice, ax, ay, bx, by, k1);\n if (trackMetrics) {\n slice.start = len + segLen * t;\n }\n }\n } else if (a > k2) {\n if (b < k2) {\n t = intersect(slice, ax, ay, bx, by, k2);\n if (trackMetrics) {\n slice.start = len + segLen * t;\n }\n }\n } else {\n addPoint(slice, ax, ay, az);\n }\n if (b < k1 && a >= k1) {\n t = intersect(slice, ax, ay, bx, by, k1);\n exited = true;\n }\n if (b > k2 && a <= k2) {\n t = intersect(slice, ax, ay, bx, by, k2);\n exited = true;\n }\n if (!isPolygon && exited) {\n if (trackMetrics) {\n slice.end = len + segLen * t;\n }\n newGeom.push(slice);\n slice = newSlice(geom);\n }\n if (trackMetrics) {\n len += segLen;\n }\n }\n var last = geom.length - 3;\n ax = geom[last];\n ay = geom[last + 1];\n az = geom[last + 2];\n a = axis === 0 ? ax : ay;\n if (a >= k1 && a <= k2) {\n addPoint(slice, ax, ay, az);\n }\n last = slice.length - 3;\n if (isPolygon && last >= 3 && (slice[last] !== slice[0] || slice[last + 1] !== slice[1])) {\n addPoint(slice, slice[0], slice[1], slice[2]);\n }\n if (slice.length) {\n newGeom.push(slice);\n }\n}\nfunction newSlice(line) {\n var slice = [];\n slice.size = line.size;\n slice.start = line.start;\n slice.end = line.end;\n return slice;\n}\nfunction clipLines(geom, newGeom, k1, k2, axis, isPolygon) {\n for (var i = 0; i < geom.length; i++) {\n clipLine(geom[i], newGeom, k1, k2, axis, isPolygon, false);\n }\n}\nfunction addPoint(out, x, y, z) {\n out.push(x);\n out.push(y);\n out.push(z);\n}\nfunction intersectX(out, ax, ay, bx, by, x) {\n var t = (x - ax) / (bx - ax);\n out.push(x);\n out.push(ay + (by - ay) * t);\n out.push(1);\n return t;\n}\nfunction intersectY(out, ax, ay, bx, by, y) {\n var t = (y - ay) / (by - ay);\n out.push(ax + (bx - ax) * t);\n out.push(y);\n out.push(1);\n return t;\n}\n\nfunction wrap(features, options) {\n var buffer = options.buffer / options.extent;\n var merged = features;\n var left = clip(features, 1, -1 - buffer, buffer, 0, -1, 2, options);\n var right = clip(features, 1, 1 - buffer, 2 + buffer, 0, -1, 2, options);\n if (left || right) {\n merged = clip(features, 1, -buffer, 1 + buffer, 0, -1, 2, options) || [];\n if (left) {\n merged = shiftFeatureCoords(left, 1).concat(merged);\n }\n if (right) {\n merged = merged.concat(shiftFeatureCoords(right, -1));\n }\n }\n return merged;\n}\nfunction shiftFeatureCoords(features, offset) {\n var newFeatures = [];\n for (var i = 0; i < features.length; i++) {\n var feature = features[i], type = feature.type;\n var newGeometry;\n if (type === 'Point' || type === 'MultiPoint' || type === 'LineString') {\n newGeometry = shiftCoords(feature.geometry, offset);\n } else if (type === 'MultiLineString' || type === 'Polygon') {\n newGeometry = [];\n for (var j = 0; j < feature.geometry.length; j++) {\n newGeometry.push(shiftCoords(feature.geometry[j], offset));\n }\n } else if (type === 'MultiPolygon') {\n newGeometry = [];\n for (j = 0; j < feature.geometry.length; j++) {\n var newPolygon = [];\n for (var k = 0; k < feature.geometry[j].length; k++) {\n newPolygon.push(shiftCoords(feature.geometry[j][k], offset));\n }\n newGeometry.push(newPolygon);\n }\n }\n newFeatures.push(createFeature(feature.id, type, newGeometry, feature.tags));\n }\n return newFeatures;\n}\nfunction shiftCoords(points, offset) {\n var newPoints = [];\n newPoints.size = points.size;\n if (points.start !== undefined) {\n newPoints.start = points.start;\n newPoints.end = points.end;\n }\n for (var i = 0; i < points.length; i += 3) {\n newPoints.push(points[i] + offset, points[i + 1], points[i + 2]);\n }\n return newPoints;\n}\n\nfunction transformTile(tile, extent) {\n if (tile.transformed) {\n return tile;\n }\n var z2 = 1 << tile.z, tx = tile.x, ty = tile.y, i, j, k;\n for (i = 0; i < tile.features.length; i++) {\n var feature = tile.features[i], geom = feature.geometry, type = feature.type;\n feature.geometry = [];\n if (type === 1) {\n for (j = 0; j < geom.length; j += 2) {\n feature.geometry.push(transformPoint(geom[j], geom[j + 1], extent, z2, tx, ty));\n }\n } else {\n for (j = 0; j < geom.length; j++) {\n var ring = [];\n for (k = 0; k < geom[j].length; k += 2) {\n ring.push(transformPoint(geom[j][k], geom[j][k + 1], extent, z2, tx, ty));\n }\n feature.geometry.push(ring);\n }\n }\n }\n tile.transformed = true;\n return tile;\n}\nfunction transformPoint(x, y, extent, z2, tx, ty) {\n return [\n Math.round(extent * (x * z2 - tx)),\n Math.round(extent * (y * z2 - ty))\n ];\n}\n\nfunction createTile(features, z, tx, ty, options) {\n var tolerance = z === options.maxZoom ? 0 : options.tolerance / ((1 << z) * options.extent);\n var tile = {\n features: [],\n numPoints: 0,\n numSimplified: 0,\n numFeatures: 0,\n source: null,\n x: tx,\n y: ty,\n z: z,\n transformed: false,\n minX: 2,\n minY: 1,\n maxX: -1,\n maxY: 0\n };\n for (var i = 0; i < features.length; i++) {\n tile.numFeatures++;\n addFeature(tile, features[i], tolerance, options);\n var minX = features[i].minX;\n var minY = features[i].minY;\n var maxX = features[i].maxX;\n var maxY = features[i].maxY;\n if (minX < tile.minX) {\n tile.minX = minX;\n }\n if (minY < tile.minY) {\n tile.minY = minY;\n }\n if (maxX > tile.maxX) {\n tile.maxX = maxX;\n }\n if (maxY > tile.maxY) {\n tile.maxY = maxY;\n }\n }\n return tile;\n}\nfunction addFeature(tile, feature, tolerance, options) {\n var geom = feature.geometry, type = feature.type, simplified = [];\n if (type === 'Point' || type === 'MultiPoint') {\n for (var i = 0; i < geom.length; i += 3) {\n simplified.push(geom[i]);\n simplified.push(geom[i + 1]);\n tile.numPoints++;\n tile.numSimplified++;\n }\n } else if (type === 'LineString') {\n addLine(simplified, geom, tile, tolerance, false, false);\n } else if (type === 'MultiLineString' || type === 'Polygon') {\n for (i = 0; i < geom.length; i++) {\n addLine(simplified, geom[i], tile, tolerance, type === 'Polygon', i === 0);\n }\n } else if (type === 'MultiPolygon') {\n for (var k = 0; k < geom.length; k++) {\n var polygon = geom[k];\n for (i = 0; i < polygon.length; i++) {\n addLine(simplified, polygon[i], tile, tolerance, true, i === 0);\n }\n }\n }\n if (simplified.length) {\n var tags = feature.tags || null;\n if (type === 'LineString' && options.lineMetrics) {\n tags = {};\n for (var key in feature.tags) {\n tags[key] = feature.tags[key];\n }\n tags['mapbox_clip_start'] = geom.start / geom.size;\n tags['mapbox_clip_end'] = geom.end / geom.size;\n }\n var tileFeature = {\n geometry: simplified,\n type: type === 'Polygon' || type === 'MultiPolygon' ? 3 : type === 'LineString' || type === 'MultiLineString' ? 2 : 1,\n tags: tags\n };\n if (feature.id !== null) {\n tileFeature.id = feature.id;\n }\n tile.features.push(tileFeature);\n }\n}\nfunction addLine(result, geom, tile, tolerance, isPolygon, isOuter) {\n var sqTolerance = tolerance * tolerance;\n if (tolerance > 0 && geom.size < (isPolygon ? sqTolerance : tolerance)) {\n tile.numPoints += geom.length / 3;\n return;\n }\n var ring = [];\n for (var i = 0; i < geom.length; i += 3) {\n if (tolerance === 0 || geom[i + 2] > sqTolerance) {\n tile.numSimplified++;\n ring.push(geom[i]);\n ring.push(geom[i + 1]);\n }\n tile.numPoints++;\n }\n if (isPolygon) {\n rewind$1(ring, isOuter);\n }\n result.push(ring);\n}\nfunction rewind$1(ring, clockwise) {\n var area = 0;\n for (var i = 0, len = ring.length, j = len - 2; i < len; j = i, i += 2) {\n area += (ring[i] - ring[j]) * (ring[i + 1] + ring[j + 1]);\n }\n if (area > 0 === clockwise) {\n for (i = 0, len = ring.length; i < len / 2; i += 2) {\n var x = ring[i];\n var y = ring[i + 1];\n ring[i] = ring[len - 2 - i];\n ring[i + 1] = ring[len - 1 - i];\n ring[len - 2 - i] = x;\n ring[len - 1 - i] = y;\n }\n }\n}\n\nfunction geojsonvt(data, options) {\n return new GeoJSONVT(data, options);\n}\nfunction GeoJSONVT(data, options) {\n options = this.options = extend$1(Object.create(this.options), options);\n var debug = options.debug;\n if (debug) {\n console.time('preprocess data');\n }\n if (options.maxZoom < 0 || options.maxZoom > 24) {\n throw new Error('maxZoom should be in the 0-24 range');\n }\n if (options.promoteId && options.generateId) {\n throw new Error('promoteId and generateId cannot be used together.');\n }\n var features = convert(data, options);\n this.tiles = {};\n this.tileCoords = [];\n if (debug) {\n console.timeEnd('preprocess data');\n console.log('index: maxZoom: %d, maxPoints: %d', options.indexMaxZoom, options.indexMaxPoints);\n console.time('generate tiles');\n this.stats = {};\n this.total = 0;\n }\n features = wrap(features, options);\n if (features.length) {\n this.splitTile(features, 0, 0, 0);\n }\n if (debug) {\n if (features.length) {\n console.log('features: %d, points: %d', this.tiles[0].numFeatures, this.tiles[0].numPoints);\n }\n console.timeEnd('generate tiles');\n console.log('tiles generated:', this.total, JSON.stringify(this.stats));\n }\n}\nGeoJSONVT.prototype.options = {\n maxZoom: 14,\n indexMaxZoom: 5,\n indexMaxPoints: 100000,\n tolerance: 3,\n extent: 4096,\n buffer: 64,\n lineMetrics: false,\n promoteId: null,\n generateId: false,\n debug: 0\n};\nGeoJSONVT.prototype.splitTile = function (features, z, x, y, cz, cx, cy) {\n var stack = [\n features,\n z,\n x,\n y\n ], options = this.options, debug = options.debug;\n while (stack.length) {\n y = stack.pop();\n x = stack.pop();\n z = stack.pop();\n features = stack.pop();\n var z2 = 1 << z, id = toID(z, x, y), tile = this.tiles[id];\n if (!tile) {\n if (debug > 1) {\n console.time('creation');\n }\n tile = this.tiles[id] = createTile(features, z, x, y, options);\n this.tileCoords.push({\n z: z,\n x: x,\n y: y\n });\n if (debug) {\n if (debug > 1) {\n console.log('tile z%d-%d-%d (features: %d, points: %d, simplified: %d)', z, x, y, tile.numFeatures, tile.numPoints, tile.numSimplified);\n console.timeEnd('creation');\n }\n var key = 'z' + z;\n this.stats[key] = (this.stats[key] || 0) + 1;\n this.total++;\n }\n }\n tile.source = features;\n if (!cz) {\n if (z === options.indexMaxZoom || tile.numPoints <= options.indexMaxPoints) {\n continue;\n }\n } else {\n if (z === options.maxZoom || z === cz) {\n continue;\n }\n var m = 1 << cz - z;\n if (x !== Math.floor(cx / m) || y !== Math.floor(cy / m)) {\n continue;\n }\n }\n tile.source = null;\n if (features.length === 0) {\n continue;\n }\n if (debug > 1) {\n console.time('clipping');\n }\n var k1 = 0.5 * options.buffer / options.extent, k2 = 0.5 - k1, k3 = 0.5 + k1, k4 = 1 + k1, tl, bl, tr, br, left, right;\n tl = bl = tr = br = null;\n left = clip(features, z2, x - k1, x + k3, 0, tile.minX, tile.maxX, options);\n right = clip(features, z2, x + k2, x + k4, 0, tile.minX, tile.maxX, options);\n features = null;\n if (left) {\n tl = clip(left, z2, y - k1, y + k3, 1, tile.minY, tile.maxY, options);\n bl = clip(left, z2, y + k2, y + k4, 1, tile.minY, tile.maxY, options);\n left = null;\n }\n if (right) {\n tr = clip(right, z2, y - k1, y + k3, 1, tile.minY, tile.maxY, options);\n br = clip(right, z2, y + k2, y + k4, 1, tile.minY, tile.maxY, options);\n right = null;\n }\n if (debug > 1) {\n console.timeEnd('clipping');\n }\n stack.push(tl || [], z + 1, x * 2, y * 2);\n stack.push(bl || [], z + 1, x * 2, y * 2 + 1);\n stack.push(tr || [], z + 1, x * 2 + 1, y * 2);\n stack.push(br || [], z + 1, x * 2 + 1, y * 2 + 1);\n }\n};\nGeoJSONVT.prototype.getTile = function (z, x, y) {\n var options = this.options, extent = options.extent, debug = options.debug;\n if (z < 0 || z > 24) {\n return null;\n }\n var z2 = 1 << z;\n x = (x % z2 + z2) % z2;\n var id = toID(z, x, y);\n if (this.tiles[id]) {\n return transformTile(this.tiles[id], extent);\n }\n if (debug > 1) {\n console.log('drilling down to z%d-%d-%d', z, x, y);\n }\n var z0 = z, x0 = x, y0 = y, parent;\n while (!parent && z0 > 0) {\n z0--;\n x0 = Math.floor(x0 / 2);\n y0 = Math.floor(y0 / 2);\n parent = this.tiles[toID(z0, x0, y0)];\n }\n if (!parent || !parent.source) {\n return null;\n }\n if (debug > 1) {\n console.log('found parent tile z%d-%d-%d', z0, x0, y0);\n }\n if (debug > 1) {\n console.time('drilling down');\n }\n this.splitTile(parent.source, z0, x0, y0, z, x, y);\n if (debug > 1) {\n console.timeEnd('drilling down');\n }\n return this.tiles[id] ? transformTile(this.tiles[id], extent) : null;\n};\nfunction toID(z, x, y) {\n return ((1 << z) * y + x) * 32 + z;\n}\nfunction extend$1(dest, src) {\n for (var i in src) {\n dest[i] = src[i];\n }\n return dest;\n}\n\nfunction loadGeoJSONTile(params, callback) {\n var canonical = params.tileID.canonical;\n if (!this._geoJSONIndex) {\n return callback(null, null);\n }\n var geoJSONTile = this._geoJSONIndex.getTile(canonical.z, canonical.x, canonical.y);\n if (!geoJSONTile) {\n return callback(null, null);\n }\n var geojsonWrapper = new GeoJSONWrapper(geoJSONTile.features);\n var pbf = vtPbf(geojsonWrapper);\n if (pbf.byteOffset !== 0 || pbf.byteLength !== pbf.buffer.byteLength) {\n pbf = new Uint8Array(pbf);\n }\n callback(null, {\n vectorTile: geojsonWrapper,\n rawData: pbf.buffer\n });\n}\nvar GeoJSONWorkerSource = function (VectorTileWorkerSource) {\n function GeoJSONWorkerSource(actor, layerIndex, availableImages, loadGeoJSON) {\n VectorTileWorkerSource.call(this, actor, layerIndex, availableImages, loadGeoJSONTile);\n if (loadGeoJSON) {\n this.loadGeoJSON = loadGeoJSON;\n }\n }\n if (VectorTileWorkerSource)\n GeoJSONWorkerSource.__proto__ = VectorTileWorkerSource;\n GeoJSONWorkerSource.prototype = Object.create(VectorTileWorkerSource && VectorTileWorkerSource.prototype);\n GeoJSONWorkerSource.prototype.constructor = GeoJSONWorkerSource;\n GeoJSONWorkerSource.prototype.loadData = function loadData(params, callback) {\n if (this._pendingCallback) {\n this._pendingCallback(null, { abandoned: true });\n }\n this._pendingCallback = callback;\n this._pendingLoadDataParams = params;\n if (this._state && this._state !== 'Idle') {\n this._state = 'NeedsLoadData';\n } else {\n this._state = 'Coalescing';\n this._loadData();\n }\n };\n GeoJSONWorkerSource.prototype._loadData = function _loadData() {\n var this$1 = this;\n if (!this._pendingCallback || !this._pendingLoadDataParams) {\n return;\n }\n var callback = this._pendingCallback;\n var params = this._pendingLoadDataParams;\n delete this._pendingCallback;\n delete this._pendingLoadDataParams;\n var perf = params && params.request && params.request.collectResourceTiming ? new performance.RequestPerformance(params.request) : false;\n this.loadGeoJSON(params, function (err, data) {\n if (err || !data) {\n return callback(err);\n } else if (typeof data !== 'object') {\n return callback(new Error('Input data given to \\'' + params.source + '\\' is not a valid GeoJSON object.'));\n } else {\n geojsonRewind(data, true);\n try {\n if (params.filter) {\n var compiled = performance.createExpression(params.filter, {\n type: 'boolean',\n 'property-type': 'data-driven',\n overridable: false,\n transition: false\n });\n if (compiled.result === 'error') {\n throw new Error(compiled.value.map(function (err) {\n return err.key + ': ' + err.message;\n }).join(', '));\n }\n var features = data.features.filter(function (feature) {\n return compiled.value.evaluate({ zoom: 0 }, feature);\n });\n data = {\n type: 'FeatureCollection',\n features: features\n };\n }\n this$1._geoJSONIndex = params.cluster ? new Supercluster(getSuperclusterOptions(params)).load(data.features) : geojsonvt(data, params.geojsonVtOptions);\n } catch (err) {\n return callback(err);\n }\n this$1.loaded = {};\n var result = {};\n if (perf) {\n var resourceTimingData = perf.finish();\n if (resourceTimingData) {\n result.resourceTiming = {};\n result.resourceTiming[params.source] = JSON.parse(JSON.stringify(resourceTimingData));\n }\n }\n callback(null, result);\n }\n });\n };\n GeoJSONWorkerSource.prototype.coalesce = function coalesce() {\n if (this._state === 'Coalescing') {\n this._state = 'Idle';\n } else if (this._state === 'NeedsLoadData') {\n this._state = 'Coalescing';\n this._loadData();\n }\n };\n GeoJSONWorkerSource.prototype.reloadTile = function reloadTile(params, callback) {\n var loaded = this.loaded, uid = params.uid;\n if (loaded && loaded[uid]) {\n return VectorTileWorkerSource.prototype.reloadTile.call(this, params, callback);\n } else {\n return this.loadTile(params, callback);\n }\n };\n GeoJSONWorkerSource.prototype.loadGeoJSON = function loadGeoJSON(params, callback) {\n if (params.request) {\n performance.getJSON(params.request, callback);\n } else if (typeof params.data === 'string') {\n try {\n return callback(null, JSON.parse(params.data));\n } catch (e) {\n return callback(new Error('Input data given to \\'' + params.source + '\\' is not a valid GeoJSON object.'));\n }\n } else {\n return callback(new Error('Input data given to \\'' + params.source + '\\' is not a valid GeoJSON object.'));\n }\n };\n GeoJSONWorkerSource.prototype.removeSource = function removeSource(params, callback) {\n if (this._pendingCallback) {\n this._pendingCallback(null, { abandoned: true });\n }\n callback();\n };\n GeoJSONWorkerSource.prototype.getClusterExpansionZoom = function getClusterExpansionZoom(params, callback) {\n try {\n callback(null, this._geoJSONIndex.getClusterExpansionZoom(params.clusterId));\n } catch (e) {\n callback(e);\n }\n };\n GeoJSONWorkerSource.prototype.getClusterChildren = function getClusterChildren(params, callback) {\n try {\n callback(null, this._geoJSONIndex.getChildren(params.clusterId));\n } catch (e) {\n callback(e);\n }\n };\n GeoJSONWorkerSource.prototype.getClusterLeaves = function getClusterLeaves(params, callback) {\n try {\n callback(null, this._geoJSONIndex.getLeaves(params.clusterId, params.limit, params.offset));\n } catch (e) {\n callback(e);\n }\n };\n return GeoJSONWorkerSource;\n}(VectorTileWorkerSource);\nfunction getSuperclusterOptions(ref) {\n var superclusterOptions = ref.superclusterOptions;\n var clusterProperties = ref.clusterProperties;\n if (!clusterProperties || !superclusterOptions) {\n return superclusterOptions;\n }\n var mapExpressions = {};\n var reduceExpressions = {};\n var globals = {\n accumulated: null,\n zoom: 0\n };\n var feature = { properties: null };\n var propertyNames = Object.keys(clusterProperties);\n for (var i = 0, list = propertyNames; i < list.length; i += 1) {\n var key = list[i];\n var ref$1 = clusterProperties[key];\n var operator = ref$1[0];\n var mapExpression = ref$1[1];\n var mapExpressionParsed = performance.createExpression(mapExpression);\n var reduceExpressionParsed = performance.createExpression(typeof operator === 'string' ? [\n operator,\n ['accumulated'],\n [\n 'get',\n key\n ]\n ] : operator);\n mapExpressions[key] = mapExpressionParsed.value;\n reduceExpressions[key] = reduceExpressionParsed.value;\n }\n superclusterOptions.map = function (pointProperties) {\n feature.properties = pointProperties;\n var properties = {};\n for (var i = 0, list = propertyNames; i < list.length; i += 1) {\n var key = list[i];\n properties[key] = mapExpressions[key].evaluate(globals, feature);\n }\n return properties;\n };\n superclusterOptions.reduce = function (accumulated, clusterProperties) {\n feature.properties = clusterProperties;\n for (var i = 0, list = propertyNames; i < list.length; i += 1) {\n var key = list[i];\n globals.accumulated = accumulated[key];\n accumulated[key] = reduceExpressions[key].evaluate(globals, feature);\n }\n };\n return superclusterOptions;\n}\n\nvar Worker = function Worker(self) {\n var this$1 = this;\n this.self = self;\n this.actor = new performance.Actor(self, this);\n this.layerIndexes = {};\n this.availableImages = {};\n this.workerSourceTypes = {\n vector: VectorTileWorkerSource,\n geojson: GeoJSONWorkerSource\n };\n this.workerSources = {};\n this.demWorkerSources = {};\n this.self.registerWorkerSource = function (name, WorkerSource) {\n if (this$1.workerSourceTypes[name]) {\n throw new Error('Worker source with name \"' + name + '\" already registered.');\n }\n this$1.workerSourceTypes[name] = WorkerSource;\n };\n this.self.registerRTLTextPlugin = function (rtlTextPlugin) {\n if (performance.plugin.isParsed()) {\n throw new Error('RTL text plugin already registered.');\n }\n performance.plugin['applyArabicShaping'] = rtlTextPlugin.applyArabicShaping;\n performance.plugin['processBidirectionalText'] = rtlTextPlugin.processBidirectionalText;\n performance.plugin['processStyledBidirectionalText'] = rtlTextPlugin.processStyledBidirectionalText;\n };\n};\nWorker.prototype.setReferrer = function setReferrer(mapID, referrer) {\n this.referrer = referrer;\n};\nWorker.prototype.setImages = function setImages(mapId, images, callback) {\n this.availableImages[mapId] = images;\n for (var workerSource in this.workerSources[mapId]) {\n var ws = this.workerSources[mapId][workerSource];\n for (var source in ws) {\n ws[source].availableImages = images;\n }\n }\n callback();\n};\nWorker.prototype.setLayers = function setLayers(mapId, layers, callback) {\n this.getLayerIndex(mapId).replace(layers);\n callback();\n};\nWorker.prototype.updateLayers = function updateLayers(mapId, params, callback) {\n this.getLayerIndex(mapId).update(params.layers, params.removedIds);\n callback();\n};\nWorker.prototype.loadTile = function loadTile(mapId, params, callback) {\n this.getWorkerSource(mapId, params.type, params.source).loadTile(params, callback);\n};\nWorker.prototype.loadDEMTile = function loadDEMTile(mapId, params, callback) {\n this.getDEMWorkerSource(mapId, params.source).loadTile(params, callback);\n};\nWorker.prototype.reloadTile = function reloadTile(mapId, params, callback) {\n this.getWorkerSource(mapId, params.type, params.source).reloadTile(params, callback);\n};\nWorker.prototype.abortTile = function abortTile(mapId, params, callback) {\n this.getWorkerSource(mapId, params.type, params.source).abortTile(params, callback);\n};\nWorker.prototype.removeTile = function removeTile(mapId, params, callback) {\n this.getWorkerSource(mapId, params.type, params.source).removeTile(params, callback);\n};\nWorker.prototype.removeDEMTile = function removeDEMTile(mapId, params) {\n this.getDEMWorkerSource(mapId, params.source).removeTile(params);\n};\nWorker.prototype.removeSource = function removeSource(mapId, params, callback) {\n if (!this.workerSources[mapId] || !this.workerSources[mapId][params.type] || !this.workerSources[mapId][params.type][params.source]) {\n return;\n }\n var worker = this.workerSources[mapId][params.type][params.source];\n delete this.workerSources[mapId][params.type][params.source];\n if (worker.removeSource !== undefined) {\n worker.removeSource(params, callback);\n } else {\n callback();\n }\n};\nWorker.prototype.loadWorkerSource = function loadWorkerSource(map, params, callback) {\n try {\n this.self.importScripts(params.url);\n callback();\n } catch (e) {\n callback(e.toString());\n }\n};\nWorker.prototype.syncRTLPluginState = function syncRTLPluginState(map, state, callback) {\n try {\n performance.plugin.setState(state);\n var pluginURL = performance.plugin.getPluginURL();\n if (performance.plugin.isLoaded() && !performance.plugin.isParsed() && pluginURL != null) {\n this.self.importScripts(pluginURL);\n var complete = performance.plugin.isParsed();\n var error = complete ? undefined : new Error('RTL Text Plugin failed to import scripts from ' + pluginURL);\n callback(error, complete);\n }\n } catch (e) {\n callback(e.toString());\n }\n};\nWorker.prototype.getAvailableImages = function getAvailableImages(mapId) {\n var availableImages = this.availableImages[mapId];\n if (!availableImages) {\n availableImages = [];\n }\n return availableImages;\n};\nWorker.prototype.getLayerIndex = function getLayerIndex(mapId) {\n var layerIndexes = this.layerIndexes[mapId];\n if (!layerIndexes) {\n layerIndexes = this.layerIndexes[mapId] = new StyleLayerIndex();\n }\n return layerIndexes;\n};\nWorker.prototype.getWorkerSource = function getWorkerSource(mapId, type, source) {\n var this$1 = this;\n if (!this.workerSources[mapId]) {\n this.workerSources[mapId] = {};\n }\n if (!this.workerSources[mapId][type]) {\n this.workerSources[mapId][type] = {};\n }\n if (!this.workerSources[mapId][type][source]) {\n var actor = {\n send: function (type, data, callback) {\n this$1.actor.send(type, data, callback, mapId);\n }\n };\n this.workerSources[mapId][type][source] = new this.workerSourceTypes[type](actor, this.getLayerIndex(mapId), this.getAvailableImages(mapId));\n }\n return this.workerSources[mapId][type][source];\n};\nWorker.prototype.getDEMWorkerSource = function getDEMWorkerSource(mapId, source) {\n if (!this.demWorkerSources[mapId]) {\n this.demWorkerSources[mapId] = {};\n }\n if (!this.demWorkerSources[mapId][source]) {\n this.demWorkerSources[mapId][source] = new RasterDEMTileWorkerSource();\n }\n return this.demWorkerSources[mapId][source];\n};\nWorker.prototype.enforceCacheSizeLimit = function enforceCacheSizeLimit$1(mapId, limit) {\n performance.enforceCacheSizeLimit(limit);\n};\nif (typeof WorkerGlobalScope !== 'undefined' && typeof self !== 'undefined' && self instanceof WorkerGlobalScope) {\n self.worker = new Worker(self);\n}\n\nreturn Worker;\n\n});\n\ndefine(['./shared'], function (performance) { 'use strict';\n\nvar mapboxGlSupported = performance.createCommonjsModule(function (module) {\nif ( module.exports) {\n module.exports = isSupported;\n} else if (window) {\n window.mapboxgl = window.mapboxgl || {};\n window.mapboxgl.supported = isSupported;\n window.mapboxgl.notSupportedReason = notSupportedReason;\n}\nfunction isSupported(options) {\n return !notSupportedReason(options);\n}\nfunction notSupportedReason(options) {\n if (!isBrowser()) {\n return 'not a browser';\n }\n if (!isArraySupported()) {\n return 'insufficent Array support';\n }\n if (!isFunctionSupported()) {\n return 'insufficient Function support';\n }\n if (!isObjectSupported()) {\n return 'insufficient Object support';\n }\n if (!isJSONSupported()) {\n return 'insufficient JSON support';\n }\n if (!isWorkerSupported()) {\n return 'insufficient worker support';\n }\n if (!isUint8ClampedArraySupported()) {\n return 'insufficient Uint8ClampedArray support';\n }\n if (!isArrayBufferSupported()) {\n return 'insufficient ArrayBuffer support';\n }\n if (!isCanvasGetImageDataSupported()) {\n return 'insufficient Canvas/getImageData support';\n }\n if (!isWebGLSupportedCached(options && options.failIfMajorPerformanceCaveat)) {\n return 'insufficient WebGL support';\n }\n}\nfunction isBrowser() {\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\nfunction isArraySupported() {\n return Array.prototype && Array.prototype.every && Array.prototype.filter && Array.prototype.forEach && Array.prototype.indexOf && Array.prototype.lastIndexOf && Array.prototype.map && Array.prototype.some && Array.prototype.reduce && Array.prototype.reduceRight && Array.isArray;\n}\nfunction isFunctionSupported() {\n return Function.prototype && Function.prototype.bind;\n}\nfunction isObjectSupported() {\n return Object.keys && Object.create && Object.getPrototypeOf && Object.getOwnPropertyNames && Object.isSealed && Object.isFrozen && Object.isExtensible && Object.getOwnPropertyDescriptor && Object.defineProperty && Object.defineProperties && Object.seal && Object.freeze && Object.preventExtensions;\n}\nfunction isJSONSupported() {\n return 'JSON' in window && 'parse' in JSON && 'stringify' in JSON;\n}\nfunction isWorkerSupported() {\n if (!('Worker' in window && 'Blob' in window && 'URL' in window)) {\n return false;\n }\n var blob = new Blob([''], { type: 'text/javascript' });\n var workerURL = URL.createObjectURL(blob);\n var supported;\n var worker;\n try {\n worker = new Worker(workerURL);\n supported = true;\n } catch (e) {\n supported = false;\n }\n if (worker) {\n worker.terminate();\n }\n URL.revokeObjectURL(workerURL);\n return supported;\n}\nfunction isUint8ClampedArraySupported() {\n return 'Uint8ClampedArray' in window;\n}\nfunction isArrayBufferSupported() {\n return ArrayBuffer.isView;\n}\nfunction isCanvasGetImageDataSupported() {\n var canvas = document.createElement('canvas');\n canvas.width = canvas.height = 1;\n var context = canvas.getContext('2d');\n if (!context) {\n return false;\n }\n var imageData = context.getImageData(0, 0, 1, 1);\n return imageData && imageData.width === canvas.width;\n}\nvar isWebGLSupportedCache = {};\nfunction isWebGLSupportedCached(failIfMajorPerformanceCaveat) {\n if (isWebGLSupportedCache[failIfMajorPerformanceCaveat] === undefined) {\n isWebGLSupportedCache[failIfMajorPerformanceCaveat] = isWebGLSupported(failIfMajorPerformanceCaveat);\n }\n return isWebGLSupportedCache[failIfMajorPerformanceCaveat];\n}\nisSupported.webGLContextAttributes = {\n antialias: false,\n alpha: true,\n stencil: true,\n depth: true\n};\nfunction getWebGLContext(failIfMajorPerformanceCaveat) {\n var canvas = document.createElement('canvas');\n var attributes = Object.create(isSupported.webGLContextAttributes);\n attributes.failIfMajorPerformanceCaveat = failIfMajorPerformanceCaveat;\n if (canvas.probablySupportsContext) {\n return canvas.probablySupportsContext('webgl', attributes) || canvas.probablySupportsContext('experimental-webgl', attributes);\n } else if (canvas.supportsContext) {\n return canvas.supportsContext('webgl', attributes) || canvas.supportsContext('experimental-webgl', attributes);\n } else {\n return canvas.getContext('webgl', attributes) || canvas.getContext('experimental-webgl', attributes);\n }\n}\nfunction isWebGLSupported(failIfMajorPerformanceCaveat) {\n var gl = getWebGLContext(failIfMajorPerformanceCaveat);\n if (!gl) {\n return false;\n }\n var shader = gl.createShader(gl.VERTEX_SHADER);\n if (!shader || gl.isContextLost()) {\n return false;\n }\n gl.shaderSource(shader, 'void main() {}');\n gl.compileShader(shader);\n return gl.getShaderParameter(shader, gl.COMPILE_STATUS) === true;\n}\n});\n\nvar DOM = {};\nDOM.create = function (tagName, className, container) {\n var el = performance.window.document.createElement(tagName);\n if (className !== undefined) {\n el.className = className;\n }\n if (container) {\n container.appendChild(el);\n }\n return el;\n};\nDOM.createNS = function (namespaceURI, tagName) {\n var el = performance.window.document.createElementNS(namespaceURI, tagName);\n return el;\n};\nvar docStyle = performance.window.document && performance.window.document.documentElement.style;\nfunction testProp(props) {\n if (!docStyle) {\n return props[0];\n }\n for (var i = 0; i < props.length; i++) {\n if (props[i] in docStyle) {\n return props[i];\n }\n }\n return props[0];\n}\nvar selectProp = testProp([\n 'userSelect',\n 'MozUserSelect',\n 'WebkitUserSelect',\n 'msUserSelect'\n]);\nvar userSelect;\nDOM.disableDrag = function () {\n if (docStyle && selectProp) {\n userSelect = docStyle[selectProp];\n docStyle[selectProp] = 'none';\n }\n};\nDOM.enableDrag = function () {\n if (docStyle && selectProp) {\n docStyle[selectProp] = userSelect;\n }\n};\nvar transformProp = testProp([\n 'transform',\n 'WebkitTransform'\n]);\nDOM.setTransform = function (el, value) {\n el.style[transformProp] = value;\n};\nvar passiveSupported = false;\ntry {\n var options$1 = Object.defineProperty({}, 'passive', {\n get: function get() {\n passiveSupported = true;\n }\n });\n performance.window.addEventListener('test', options$1, options$1);\n performance.window.removeEventListener('test', options$1, options$1);\n} catch (err) {\n passiveSupported = false;\n}\nDOM.addEventListener = function (target, type, callback, options) {\n if (options === void 0)\n options = {};\n if ('passive' in options && passiveSupported) {\n target.addEventListener(type, callback, options);\n } else {\n target.addEventListener(type, callback, options.capture);\n }\n};\nDOM.removeEventListener = function (target, type, callback, options) {\n if (options === void 0)\n options = {};\n if ('passive' in options && passiveSupported) {\n target.removeEventListener(type, callback, options);\n } else {\n target.removeEventListener(type, callback, options.capture);\n }\n};\nvar suppressClick = function (e) {\n e.preventDefault();\n e.stopPropagation();\n performance.window.removeEventListener('click', suppressClick, true);\n};\nDOM.suppressClick = function () {\n performance.window.addEventListener('click', suppressClick, true);\n performance.window.setTimeout(function () {\n performance.window.removeEventListener('click', suppressClick, true);\n }, 0);\n};\nDOM.mousePos = function (el, e) {\n var rect = el.getBoundingClientRect();\n return new performance.Point(e.clientX - rect.left - el.clientLeft, e.clientY - rect.top - el.clientTop);\n};\nDOM.touchPos = function (el, touches) {\n var rect = el.getBoundingClientRect(), points = [];\n for (var i = 0; i < touches.length; i++) {\n points.push(new performance.Point(touches[i].clientX - rect.left - el.clientLeft, touches[i].clientY - rect.top - el.clientTop));\n }\n return points;\n};\nDOM.mouseButton = function (e) {\n if (typeof performance.window.InstallTrigger !== 'undefined' && e.button === 2 && e.ctrlKey && performance.window.navigator.platform.toUpperCase().indexOf('MAC') >= 0) {\n return 0;\n }\n return e.button;\n};\nDOM.remove = function (node) {\n if (node.parentNode) {\n node.parentNode.removeChild(node);\n }\n};\n\nfunction loadSprite (baseURL, requestManager, callback) {\n var json, image, error;\n var format = performance.browser.devicePixelRatio > 1 ? '@2x' : '';\n var jsonRequest = performance.getJSON(requestManager.transformRequest(requestManager.normalizeSpriteURL(baseURL, format, '.json'), performance.ResourceType.SpriteJSON), function (err, data) {\n jsonRequest = null;\n if (!error) {\n error = err;\n json = data;\n maybeComplete();\n }\n });\n var imageRequest = performance.getImage(requestManager.transformRequest(requestManager.normalizeSpriteURL(baseURL, format, '.png'), performance.ResourceType.SpriteImage), function (err, img) {\n imageRequest = null;\n if (!error) {\n error = err;\n image = img;\n maybeComplete();\n }\n });\n function maybeComplete() {\n if (error) {\n callback(error);\n } else if (json && image) {\n var imageData = performance.browser.getImageData(image);\n var result = {};\n for (var id in json) {\n var ref = json[id];\n var width = ref.width;\n var height = ref.height;\n var x = ref.x;\n var y = ref.y;\n var sdf = ref.sdf;\n var pixelRatio = ref.pixelRatio;\n var stretchX = ref.stretchX;\n var stretchY = ref.stretchY;\n var content = ref.content;\n var data = new performance.RGBAImage({\n width: width,\n height: height\n });\n performance.RGBAImage.copy(imageData, data, {\n x: x,\n y: y\n }, {\n x: 0,\n y: 0\n }, {\n width: width,\n height: height\n });\n result[id] = {\n data: data,\n pixelRatio: pixelRatio,\n sdf: sdf,\n stretchX: stretchX,\n stretchY: stretchY,\n content: content\n };\n }\n callback(null, result);\n }\n }\n return {\n cancel: function cancel() {\n if (jsonRequest) {\n jsonRequest.cancel();\n jsonRequest = null;\n }\n if (imageRequest) {\n imageRequest.cancel();\n imageRequest = null;\n }\n }\n };\n}\n\nfunction renderStyleImage(image) {\n var userImage = image.userImage;\n if (userImage && userImage.render) {\n var updated = userImage.render();\n if (updated) {\n image.data.replace(new Uint8Array(userImage.data.buffer));\n return true;\n }\n }\n return false;\n}\n\nvar padding = 1;\nvar ImageManager = function (Evented) {\n function ImageManager() {\n Evented.call(this);\n this.images = {};\n this.updatedImages = {};\n this.callbackDispatchedThisFrame = {};\n this.loaded = false;\n this.requestors = [];\n this.patterns = {};\n this.atlasImage = new performance.RGBAImage({\n width: 1,\n height: 1\n });\n this.dirty = true;\n }\n if (Evented)\n ImageManager.__proto__ = Evented;\n ImageManager.prototype = Object.create(Evented && Evented.prototype);\n ImageManager.prototype.constructor = ImageManager;\n ImageManager.prototype.isLoaded = function isLoaded() {\n return this.loaded;\n };\n ImageManager.prototype.setLoaded = function setLoaded(loaded) {\n if (this.loaded === loaded) {\n return;\n }\n this.loaded = loaded;\n if (loaded) {\n for (var i = 0, list = this.requestors; i < list.length; i += 1) {\n var ref = list[i];\n var ids = ref.ids;\n var callback = ref.callback;\n this._notify(ids, callback);\n }\n this.requestors = [];\n }\n };\n ImageManager.prototype.getImage = function getImage(id) {\n return this.images[id];\n };\n ImageManager.prototype.addImage = function addImage(id, image) {\n if (this._validate(id, image)) {\n this.images[id] = image;\n }\n };\n ImageManager.prototype._validate = function _validate(id, image) {\n var valid = true;\n if (!this._validateStretch(image.stretchX, image.data && image.data.width)) {\n this.fire(new performance.ErrorEvent(new Error('Image \"' + id + '\" has invalid \"stretchX\" value')));\n valid = false;\n }\n if (!this._validateStretch(image.stretchY, image.data && image.data.height)) {\n this.fire(new performance.ErrorEvent(new Error('Image \"' + id + '\" has invalid \"stretchY\" value')));\n valid = false;\n }\n if (!this._validateContent(image.content, image)) {\n this.fire(new performance.ErrorEvent(new Error('Image \"' + id + '\" has invalid \"content\" value')));\n valid = false;\n }\n return valid;\n };\n ImageManager.prototype._validateStretch = function _validateStretch(stretch, size) {\n if (!stretch) {\n return true;\n }\n var last = 0;\n for (var i = 0, list = stretch; i < list.length; i += 1) {\n var part = list[i];\n if (part[0] < last || part[1] < part[0] || size < part[1]) {\n return false;\n }\n last = part[1];\n }\n return true;\n };\n ImageManager.prototype._validateContent = function _validateContent(content, image) {\n if (!content) {\n return true;\n }\n if (content.length !== 4) {\n return false;\n }\n if (content[0] < 0 || image.data.width < content[0]) {\n return false;\n }\n if (content[1] < 0 || image.data.height < content[1]) {\n return false;\n }\n if (content[2] < 0 || image.data.width < content[2]) {\n return false;\n }\n if (content[3] < 0 || image.data.height < content[3]) {\n return false;\n }\n if (content[2] < content[0]) {\n return false;\n }\n if (content[3] < content[1]) {\n return false;\n }\n return true;\n };\n ImageManager.prototype.updateImage = function updateImage(id, image) {\n var oldImage = this.images[id];\n image.version = oldImage.version + 1;\n this.images[id] = image;\n this.updatedImages[id] = true;\n };\n ImageManager.prototype.removeImage = function removeImage(id) {\n var image = this.images[id];\n delete this.images[id];\n delete this.patterns[id];\n if (image.userImage && image.userImage.onRemove) {\n image.userImage.onRemove();\n }\n };\n ImageManager.prototype.listImages = function listImages() {\n return Object.keys(this.images);\n };\n ImageManager.prototype.getImages = function getImages(ids, callback) {\n var hasAllDependencies = true;\n if (!this.isLoaded()) {\n for (var i = 0, list = ids; i < list.length; i += 1) {\n var id = list[i];\n if (!this.images[id]) {\n hasAllDependencies = false;\n }\n }\n }\n if (this.isLoaded() || hasAllDependencies) {\n this._notify(ids, callback);\n } else {\n this.requestors.push({\n ids: ids,\n callback: callback\n });\n }\n };\n ImageManager.prototype._notify = function _notify(ids, callback) {\n var response = {};\n for (var i = 0, list = ids; i < list.length; i += 1) {\n var id = list[i];\n if (!this.images[id]) {\n this.fire(new performance.Event('styleimagemissing', { id: id }));\n }\n var image = this.images[id];\n if (image) {\n response[id] = {\n data: image.data.clone(),\n pixelRatio: image.pixelRatio,\n sdf: image.sdf,\n version: image.version,\n stretchX: image.stretchX,\n stretchY: image.stretchY,\n content: image.content,\n hasRenderCallback: Boolean(image.userImage && image.userImage.render)\n };\n } else {\n performance.warnOnce('Image \"' + id + '\" could not be loaded. Please make sure you have added the image with map.addImage() or a \"sprite\" property in your style. You can provide missing images by listening for the \"styleimagemissing\" map event.');\n }\n }\n callback(null, response);\n };\n ImageManager.prototype.getPixelSize = function getPixelSize() {\n var ref = this.atlasImage;\n var width = ref.width;\n var height = ref.height;\n return {\n width: width,\n height: height\n };\n };\n ImageManager.prototype.getPattern = function getPattern(id) {\n var pattern = this.patterns[id];\n var image = this.getImage(id);\n if (!image) {\n return null;\n }\n if (pattern && pattern.position.version === image.version) {\n return pattern.position;\n }\n if (!pattern) {\n var w = image.data.width + padding * 2;\n var h = image.data.height + padding * 2;\n var bin = {\n w: w,\n h: h,\n x: 0,\n y: 0\n };\n var position = new performance.ImagePosition(bin, image);\n this.patterns[id] = {\n bin: bin,\n position: position\n };\n } else {\n pattern.position.version = image.version;\n }\n this._updatePatternAtlas();\n return this.patterns[id].position;\n };\n ImageManager.prototype.bind = function bind(context) {\n var gl = context.gl;\n if (!this.atlasTexture) {\n this.atlasTexture = new performance.Texture(context, this.atlasImage, gl.RGBA);\n } else if (this.dirty) {\n this.atlasTexture.update(this.atlasImage);\n this.dirty = false;\n }\n this.atlasTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n };\n ImageManager.prototype._updatePatternAtlas = function _updatePatternAtlas() {\n var bins = [];\n for (var id in this.patterns) {\n bins.push(this.patterns[id].bin);\n }\n var ref = performance.potpack(bins);\n var w = ref.w;\n var h = ref.h;\n var dst = this.atlasImage;\n dst.resize({\n width: w || 1,\n height: h || 1\n });\n for (var id$1 in this.patterns) {\n var ref$1 = this.patterns[id$1];\n var bin = ref$1.bin;\n var x = bin.x + padding;\n var y = bin.y + padding;\n var src = this.images[id$1].data;\n var w$1 = src.width;\n var h$1 = src.height;\n performance.RGBAImage.copy(src, dst, {\n x: 0,\n y: 0\n }, {\n x: x,\n y: y\n }, {\n width: w$1,\n height: h$1\n });\n performance.RGBAImage.copy(src, dst, {\n x: 0,\n y: h$1 - 1\n }, {\n x: x,\n y: y - 1\n }, {\n width: w$1,\n height: 1\n });\n performance.RGBAImage.copy(src, dst, {\n x: 0,\n y: 0\n }, {\n x: x,\n y: y + h$1\n }, {\n width: w$1,\n height: 1\n });\n performance.RGBAImage.copy(src, dst, {\n x: w$1 - 1,\n y: 0\n }, {\n x: x - 1,\n y: y\n }, {\n width: 1,\n height: h$1\n });\n performance.RGBAImage.copy(src, dst, {\n x: 0,\n y: 0\n }, {\n x: x + w$1,\n y: y\n }, {\n width: 1,\n height: h$1\n });\n }\n this.dirty = true;\n };\n ImageManager.prototype.beginFrame = function beginFrame() {\n this.callbackDispatchedThisFrame = {};\n };\n ImageManager.prototype.dispatchRenderCallbacks = function dispatchRenderCallbacks(ids) {\n for (var i = 0, list = ids; i < list.length; i += 1) {\n var id = list[i];\n if (this.callbackDispatchedThisFrame[id]) {\n continue;\n }\n this.callbackDispatchedThisFrame[id] = true;\n var image = this.images[id];\n var updated = renderStyleImage(image);\n if (updated) {\n this.updateImage(id, image);\n }\n }\n };\n return ImageManager;\n}(performance.Evented);\n\nfunction loadGlyphRange (fontstack, range, urlTemplate, requestManager, callback) {\n var begin = range * 256;\n var end = begin + 255;\n var request = requestManager.transformRequest(requestManager.normalizeGlyphsURL(urlTemplate).replace('{fontstack}', fontstack).replace('{range}', begin + '-' + end), performance.ResourceType.Glyphs);\n performance.getArrayBuffer(request, function (err, data) {\n if (err) {\n callback(err);\n } else if (data) {\n var glyphs = {};\n for (var i = 0, list = performance.parseGlyphPBF(data); i < list.length; i += 1) {\n var glyph = list[i];\n glyphs[glyph.id] = glyph;\n }\n callback(null, glyphs);\n }\n });\n}\n\nvar tinySdf = TinySDF;\nvar default_1 = TinySDF;\nvar INF = 100000000000000000000;\nfunction TinySDF(fontSize, buffer, radius, cutoff, fontFamily, fontWeight) {\n this.fontSize = fontSize || 24;\n this.buffer = buffer === undefined ? 3 : buffer;\n this.cutoff = cutoff || 0.25;\n this.fontFamily = fontFamily || 'sans-serif';\n this.fontWeight = fontWeight || 'normal';\n this.radius = radius || 8;\n var size = this.size = this.fontSize + this.buffer * 2;\n this.canvas = document.createElement('canvas');\n this.canvas.width = this.canvas.height = size;\n this.ctx = this.canvas.getContext('2d');\n this.ctx.font = this.fontWeight + ' ' + this.fontSize + 'px ' + this.fontFamily;\n this.ctx.textBaseline = 'middle';\n this.ctx.fillStyle = 'black';\n this.gridOuter = new Float64Array(size * size);\n this.gridInner = new Float64Array(size * size);\n this.f = new Float64Array(size);\n this.d = new Float64Array(size);\n this.z = new Float64Array(size + 1);\n this.v = new Int16Array(size);\n this.middle = Math.round(size / 2 * (navigator.userAgent.indexOf('Gecko/') >= 0 ? 1.2 : 1));\n}\nTinySDF.prototype.draw = function (char) {\n this.ctx.clearRect(0, 0, this.size, this.size);\n this.ctx.fillText(char, this.buffer, this.middle);\n var imgData = this.ctx.getImageData(0, 0, this.size, this.size);\n var alphaChannel = new Uint8ClampedArray(this.size * this.size);\n for (var i = 0; i < this.size * this.size; i++) {\n var a = imgData.data[i * 4 + 3] / 255;\n this.gridOuter[i] = a === 1 ? 0 : a === 0 ? INF : Math.pow(Math.max(0, 0.5 - a), 2);\n this.gridInner[i] = a === 1 ? INF : a === 0 ? 0 : Math.pow(Math.max(0, a - 0.5), 2);\n }\n edt(this.gridOuter, this.size, this.size, this.f, this.d, this.v, this.z);\n edt(this.gridInner, this.size, this.size, this.f, this.d, this.v, this.z);\n for (i = 0; i < this.size * this.size; i++) {\n var d = this.gridOuter[i] - this.gridInner[i];\n alphaChannel[i] = Math.max(0, Math.min(255, Math.round(255 - 255 * (d / this.radius + this.cutoff))));\n }\n return alphaChannel;\n};\nfunction edt(data, width, height, f, d, v, z) {\n for (var x = 0; x < width; x++) {\n for (var y = 0; y < height; y++) {\n f[y] = data[y * width + x];\n }\n edt1d(f, d, v, z, height);\n for (y = 0; y < height; y++) {\n data[y * width + x] = d[y];\n }\n }\n for (y = 0; y < height; y++) {\n for (x = 0; x < width; x++) {\n f[x] = data[y * width + x];\n }\n edt1d(f, d, v, z, width);\n for (x = 0; x < width; x++) {\n data[y * width + x] = Math.sqrt(d[x]);\n }\n }\n}\nfunction edt1d(f, d, v, z, n) {\n v[0] = 0;\n z[0] = -INF;\n z[1] = +INF;\n for (var q = 1, k = 0; q < n; q++) {\n var s = (f[q] + q * q - (f[v[k]] + v[k] * v[k])) / (2 * q - 2 * v[k]);\n while (s <= z[k]) {\n k--;\n s = (f[q] + q * q - (f[v[k]] + v[k] * v[k])) / (2 * q - 2 * v[k]);\n }\n k++;\n v[k] = q;\n z[k] = s;\n z[k + 1] = +INF;\n }\n for (q = 0, k = 0; q < n; q++) {\n while (z[k + 1] < q) {\n k++;\n }\n d[q] = (q - v[k]) * (q - v[k]) + f[v[k]];\n }\n}\ntinySdf.default = default_1;\n\nvar GlyphManager = function GlyphManager(requestManager, localIdeographFontFamily) {\n this.requestManager = requestManager;\n this.localIdeographFontFamily = localIdeographFontFamily;\n this.entries = {};\n};\nGlyphManager.prototype.setURL = function setURL(url) {\n this.url = url;\n};\nGlyphManager.prototype.getGlyphs = function getGlyphs(glyphs, callback) {\n var this$1 = this;\n var all = [];\n for (var stack in glyphs) {\n for (var i = 0, list = glyphs[stack]; i < list.length; i += 1) {\n var id = list[i];\n all.push({\n stack: stack,\n id: id\n });\n }\n }\n performance.asyncAll(all, function (ref, callback) {\n var stack = ref.stack;\n var id = ref.id;\n var entry = this$1.entries[stack];\n if (!entry) {\n entry = this$1.entries[stack] = {\n glyphs: {},\n requests: {},\n ranges: {}\n };\n }\n var glyph = entry.glyphs[id];\n if (glyph !== undefined) {\n callback(null, {\n stack: stack,\n id: id,\n glyph: glyph\n });\n return;\n }\n glyph = this$1._tinySDF(entry, stack, id);\n if (glyph) {\n entry.glyphs[id] = glyph;\n callback(null, {\n stack: stack,\n id: id,\n glyph: glyph\n });\n return;\n }\n var range = Math.floor(id / 256);\n if (range * 256 > 65535) {\n callback(new Error('glyphs > 65535 not supported'));\n return;\n }\n if (entry.ranges[range]) {\n callback(null, {\n stack: stack,\n id: id,\n glyph: glyph\n });\n return;\n }\n var requests = entry.requests[range];\n if (!requests) {\n requests = entry.requests[range] = [];\n GlyphManager.loadGlyphRange(stack, range, this$1.url, this$1.requestManager, function (err, response) {\n if (response) {\n for (var id in response) {\n if (!this$1._doesCharSupportLocalGlyph(+id)) {\n entry.glyphs[+id] = response[+id];\n }\n }\n entry.ranges[range] = true;\n }\n for (var i = 0, list = requests; i < list.length; i += 1) {\n var cb = list[i];\n cb(err, response);\n }\n delete entry.requests[range];\n });\n }\n requests.push(function (err, result) {\n if (err) {\n callback(err);\n } else if (result) {\n callback(null, {\n stack: stack,\n id: id,\n glyph: result[id] || null\n });\n }\n });\n }, function (err, glyphs) {\n if (err) {\n callback(err);\n } else if (glyphs) {\n var result = {};\n for (var i = 0, list = glyphs; i < list.length; i += 1) {\n var ref = list[i];\n var stack = ref.stack;\n var id = ref.id;\n var glyph = ref.glyph;\n (result[stack] || (result[stack] = {}))[id] = glyph && {\n id: glyph.id,\n bitmap: glyph.bitmap.clone(),\n metrics: glyph.metrics\n };\n }\n callback(null, result);\n }\n });\n};\nGlyphManager.prototype._doesCharSupportLocalGlyph = function _doesCharSupportLocalGlyph(id) {\n return !!this.localIdeographFontFamily && (performance.isChar['CJK Unified Ideographs'](id) || performance.isChar['Hangul Syllables'](id) || performance.isChar['Hiragana'](id) || performance.isChar['Katakana'](id));\n};\nGlyphManager.prototype._tinySDF = function _tinySDF(entry, stack, id) {\n var family = this.localIdeographFontFamily;\n if (!family) {\n return;\n }\n if (!this._doesCharSupportLocalGlyph(id)) {\n return;\n }\n var tinySDF = entry.tinySDF;\n if (!tinySDF) {\n var fontWeight = '400';\n if (/bold/i.test(stack)) {\n fontWeight = '900';\n } else if (/medium/i.test(stack)) {\n fontWeight = '500';\n } else if (/light/i.test(stack)) {\n fontWeight = '200';\n }\n tinySDF = entry.tinySDF = new GlyphManager.TinySDF(24, 3, 8, 0.25, family, fontWeight);\n }\n return {\n id: id,\n bitmap: new performance.AlphaImage({\n width: 30,\n height: 30\n }, tinySDF.draw(String.fromCharCode(id))),\n metrics: {\n width: 24,\n height: 24,\n left: 0,\n top: -8,\n advance: 24\n }\n };\n};\nGlyphManager.loadGlyphRange = loadGlyphRange;\nGlyphManager.TinySDF = tinySdf;\n\nvar LightPositionProperty = function LightPositionProperty() {\n this.specification = performance.styleSpec.light.position;\n};\nLightPositionProperty.prototype.possiblyEvaluate = function possiblyEvaluate(value, parameters) {\n return performance.sphericalToCartesian(value.expression.evaluate(parameters));\n};\nLightPositionProperty.prototype.interpolate = function interpolate$1(a, b, t) {\n return {\n x: performance.number(a.x, b.x, t),\n y: performance.number(a.y, b.y, t),\n z: performance.number(a.z, b.z, t)\n };\n};\nvar properties = new performance.Properties({\n 'anchor': new performance.DataConstantProperty(performance.styleSpec.light.anchor),\n 'position': new LightPositionProperty(),\n 'color': new performance.DataConstantProperty(performance.styleSpec.light.color),\n 'intensity': new performance.DataConstantProperty(performance.styleSpec.light.intensity)\n});\nvar TRANSITION_SUFFIX = '-transition';\nvar Light = function (Evented) {\n function Light(lightOptions) {\n Evented.call(this);\n this._transitionable = new performance.Transitionable(properties);\n this.setLight(lightOptions);\n this._transitioning = this._transitionable.untransitioned();\n }\n if (Evented)\n Light.__proto__ = Evented;\n Light.prototype = Object.create(Evented && Evented.prototype);\n Light.prototype.constructor = Light;\n Light.prototype.getLight = function getLight() {\n return this._transitionable.serialize();\n };\n Light.prototype.setLight = function setLight(light, options) {\n if (options === void 0)\n options = {};\n if (this._validate(performance.validateLight, light, options)) {\n return;\n }\n for (var name in light) {\n var value = light[name];\n if (performance.endsWith(name, TRANSITION_SUFFIX)) {\n this._transitionable.setTransition(name.slice(0, -TRANSITION_SUFFIX.length), value);\n } else {\n this._transitionable.setValue(name, value);\n }\n }\n };\n Light.prototype.updateTransitions = function updateTransitions(parameters) {\n this._transitioning = this._transitionable.transitioned(parameters, this._transitioning);\n };\n Light.prototype.hasTransition = function hasTransition() {\n return this._transitioning.hasTransition();\n };\n Light.prototype.recalculate = function recalculate(parameters) {\n this.properties = this._transitioning.possiblyEvaluate(parameters);\n };\n Light.prototype._validate = function _validate(validate, value, options) {\n if (options && options.validate === false) {\n return false;\n }\n return performance.emitValidationErrors(this, validate.call(performance.validateStyle, performance.extend({\n value: value,\n style: {\n glyphs: true,\n sprite: true\n },\n styleSpec: performance.styleSpec\n })));\n };\n return Light;\n}(performance.Evented);\n\nvar LineAtlas = function LineAtlas(width, height) {\n this.width = width;\n this.height = height;\n this.nextRow = 0;\n this.data = new Uint8Array(this.width * this.height);\n this.dashEntry = {};\n};\nLineAtlas.prototype.getDash = function getDash(dasharray, round) {\n var key = dasharray.join(',') + String(round);\n if (!this.dashEntry[key]) {\n this.dashEntry[key] = this.addDash(dasharray, round);\n }\n return this.dashEntry[key];\n};\nLineAtlas.prototype.getDashRanges = function getDashRanges(dasharray, lineAtlasWidth, stretch) {\n var oddDashArray = dasharray.length % 2 === 1;\n var ranges = [];\n var left = oddDashArray ? -dasharray[dasharray.length - 1] * stretch : 0;\n var right = dasharray[0] * stretch;\n var isDash = true;\n ranges.push({\n left: left,\n right: right,\n isDash: isDash,\n zeroLength: dasharray[0] === 0\n });\n var currentDashLength = dasharray[0];\n for (var i = 1; i < dasharray.length; i++) {\n isDash = !isDash;\n var dashLength = dasharray[i];\n left = currentDashLength * stretch;\n currentDashLength += dashLength;\n right = currentDashLength * stretch;\n ranges.push({\n left: left,\n right: right,\n isDash: isDash,\n zeroLength: dashLength === 0\n });\n }\n return ranges;\n};\nLineAtlas.prototype.addRoundDash = function addRoundDash(ranges, stretch, n) {\n var halfStretch = stretch / 2;\n for (var y = -n; y <= n; y++) {\n var row = this.nextRow + n + y;\n var index = this.width * row;\n var currIndex = 0;\n var range = ranges[currIndex];\n for (var x = 0; x < this.width; x++) {\n if (x / range.right > 1) {\n range = ranges[++currIndex];\n }\n var distLeft = Math.abs(x - range.left);\n var distRight = Math.abs(x - range.right);\n var minDist = Math.min(distLeft, distRight);\n var signedDistance = void 0;\n var distMiddle = y / n * (halfStretch + 1);\n if (range.isDash) {\n var distEdge = halfStretch - Math.abs(distMiddle);\n signedDistance = Math.sqrt(minDist * minDist + distEdge * distEdge);\n } else {\n signedDistance = halfStretch - Math.sqrt(minDist * minDist + distMiddle * distMiddle);\n }\n this.data[index + x] = Math.max(0, Math.min(255, signedDistance + 128));\n }\n }\n};\nLineAtlas.prototype.addRegularDash = function addRegularDash(ranges) {\n for (var i = ranges.length - 1; i >= 0; --i) {\n var part = ranges[i];\n var next = ranges[i + 1];\n if (part.zeroLength) {\n ranges.splice(i, 1);\n } else if (next && next.isDash === part.isDash) {\n next.left = part.left;\n ranges.splice(i, 1);\n }\n }\n var first = ranges[0];\n var last = ranges[ranges.length - 1];\n if (first.isDash === last.isDash) {\n first.left = last.left - this.width;\n last.right = first.right + this.width;\n }\n var index = this.width * this.nextRow;\n var currIndex = 0;\n var range = ranges[currIndex];\n for (var x = 0; x < this.width; x++) {\n if (x / range.right > 1) {\n range = ranges[++currIndex];\n }\n var distLeft = Math.abs(x - range.left);\n var distRight = Math.abs(x - range.right);\n var minDist = Math.min(distLeft, distRight);\n var signedDistance = range.isDash ? minDist : -minDist;\n this.data[index + x] = Math.max(0, Math.min(255, signedDistance + 128));\n }\n};\nLineAtlas.prototype.addDash = function addDash(dasharray, round) {\n var n = round ? 7 : 0;\n var height = 2 * n + 1;\n if (this.nextRow + height > this.height) {\n performance.warnOnce('LineAtlas out of space');\n return null;\n }\n var length = 0;\n for (var i = 0; i < dasharray.length; i++) {\n length += dasharray[i];\n }\n if (length !== 0) {\n var stretch = this.width / length;\n var ranges = this.getDashRanges(dasharray, this.width, stretch);\n if (round) {\n this.addRoundDash(ranges, stretch, n);\n } else {\n this.addRegularDash(ranges);\n }\n }\n var dashEntry = {\n y: (this.nextRow + n + 0.5) / this.height,\n height: 2 * n / this.height,\n width: length\n };\n this.nextRow += height;\n this.dirty = true;\n return dashEntry;\n};\nLineAtlas.prototype.bind = function bind(context) {\n var gl = context.gl;\n if (!this.texture) {\n this.texture = gl.createTexture();\n gl.bindTexture(gl.TEXTURE_2D, this.texture);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.REPEAT);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.REPEAT);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n gl.texImage2D(gl.TEXTURE_2D, 0, gl.ALPHA, this.width, this.height, 0, gl.ALPHA, gl.UNSIGNED_BYTE, this.data);\n } else {\n gl.bindTexture(gl.TEXTURE_2D, this.texture);\n if (this.dirty) {\n this.dirty = false;\n gl.texSubImage2D(gl.TEXTURE_2D, 0, 0, 0, this.width, this.height, gl.ALPHA, gl.UNSIGNED_BYTE, this.data);\n }\n }\n};\n\nvar Dispatcher = function Dispatcher(workerPool, parent) {\n this.workerPool = workerPool;\n this.actors = [];\n this.currentActor = 0;\n this.id = performance.uniqueId();\n var workers = this.workerPool.acquire(this.id);\n for (var i = 0; i < workers.length; i++) {\n var worker = workers[i];\n var actor = new Dispatcher.Actor(worker, parent, this.id);\n actor.name = 'Worker ' + i;\n this.actors.push(actor);\n }\n};\nDispatcher.prototype.broadcast = function broadcast(type, data, cb) {\n cb = cb || function () {\n };\n performance.asyncAll(this.actors, function (actor, done) {\n actor.send(type, data, done);\n }, cb);\n};\nDispatcher.prototype.getActor = function getActor() {\n this.currentActor = (this.currentActor + 1) % this.actors.length;\n return this.actors[this.currentActor];\n};\nDispatcher.prototype.remove = function remove() {\n this.actors.forEach(function (actor) {\n actor.remove();\n });\n this.actors = [];\n this.workerPool.release(this.id);\n};\nDispatcher.Actor = performance.Actor;\n\nfunction loadTileJSON (options, requestManager, callback) {\n var loaded = function (err, tileJSON) {\n if (err) {\n return callback(err);\n } else if (tileJSON) {\n var result = performance.pick(performance.extend(tileJSON, options), [\n 'tiles',\n 'minzoom',\n 'maxzoom',\n 'attribution',\n 'mapbox_logo',\n 'bounds',\n 'scheme',\n 'tileSize',\n 'encoding'\n ]);\n if (tileJSON.vector_layers) {\n result.vectorLayers = tileJSON.vector_layers;\n result.vectorLayerIds = result.vectorLayers.map(function (layer) {\n return layer.id;\n });\n }\n result.tiles = requestManager.canonicalizeTileset(result, options.url);\n callback(null, result);\n }\n };\n if (options.url) {\n return performance.getJSON(requestManager.transformRequest(requestManager.normalizeSourceURL(options.url), performance.ResourceType.Source), loaded);\n } else {\n return performance.browser.frame(function () {\n return loaded(null, options);\n });\n }\n}\n\nvar TileBounds = function TileBounds(bounds, minzoom, maxzoom) {\n this.bounds = performance.LngLatBounds.convert(this.validateBounds(bounds));\n this.minzoom = minzoom || 0;\n this.maxzoom = maxzoom || 24;\n};\nTileBounds.prototype.validateBounds = function validateBounds(bounds) {\n if (!Array.isArray(bounds) || bounds.length !== 4) {\n return [\n -180,\n -90,\n 180,\n 90\n ];\n }\n return [\n Math.max(-180, bounds[0]),\n Math.max(-90, bounds[1]),\n Math.min(180, bounds[2]),\n Math.min(90, bounds[3])\n ];\n};\nTileBounds.prototype.contains = function contains(tileID) {\n var worldSize = Math.pow(2, tileID.z);\n var level = {\n minX: Math.floor(performance.mercatorXfromLng(this.bounds.getWest()) * worldSize),\n minY: Math.floor(performance.mercatorYfromLat(this.bounds.getNorth()) * worldSize),\n maxX: Math.ceil(performance.mercatorXfromLng(this.bounds.getEast()) * worldSize),\n maxY: Math.ceil(performance.mercatorYfromLat(this.bounds.getSouth()) * worldSize)\n };\n var hit = tileID.x >= level.minX && tileID.x < level.maxX && tileID.y >= level.minY && tileID.y < level.maxY;\n return hit;\n};\n\nvar VectorTileSource = function (Evented) {\n function VectorTileSource(id, options, dispatcher, eventedParent) {\n Evented.call(this);\n this.id = id;\n this.dispatcher = dispatcher;\n this.type = 'vector';\n this.minzoom = 0;\n this.maxzoom = 22;\n this.scheme = 'xyz';\n this.tileSize = 512;\n this.reparseOverscaled = true;\n this.isTileClipped = true;\n this._loaded = false;\n performance.extend(this, performance.pick(options, [\n 'url',\n 'scheme',\n 'tileSize',\n 'promoteId'\n ]));\n this._options = performance.extend({ type: 'vector' }, options);\n this._collectResourceTiming = options.collectResourceTiming;\n if (this.tileSize !== 512) {\n throw new Error('vector tile sources must have a tileSize of 512');\n }\n this.setEventedParent(eventedParent);\n }\n if (Evented)\n VectorTileSource.__proto__ = Evented;\n VectorTileSource.prototype = Object.create(Evented && Evented.prototype);\n VectorTileSource.prototype.constructor = VectorTileSource;\n VectorTileSource.prototype.load = function load() {\n var this$1 = this;\n this._loaded = false;\n this.fire(new performance.Event('dataloading', { dataType: 'source' }));\n this._tileJSONRequest = loadTileJSON(this._options, this.map._requestManager, function (err, tileJSON) {\n this$1._tileJSONRequest = null;\n this$1._loaded = true;\n if (err) {\n this$1.fire(new performance.ErrorEvent(err));\n } else if (tileJSON) {\n performance.extend(this$1, tileJSON);\n if (tileJSON.bounds) {\n this$1.tileBounds = new TileBounds(tileJSON.bounds, this$1.minzoom, this$1.maxzoom);\n }\n performance.postTurnstileEvent(tileJSON.tiles, this$1.map._requestManager._customAccessToken);\n performance.postMapLoadEvent(tileJSON.tiles, this$1.map._getMapId(), this$1.map._requestManager._skuToken, this$1.map._requestManager._customAccessToken);\n this$1.fire(new performance.Event('data', {\n dataType: 'source',\n sourceDataType: 'metadata'\n }));\n this$1.fire(new performance.Event('data', {\n dataType: 'source',\n sourceDataType: 'content'\n }));\n }\n });\n };\n VectorTileSource.prototype.loaded = function loaded() {\n return this._loaded;\n };\n VectorTileSource.prototype.hasTile = function hasTile(tileID) {\n return !this.tileBounds || this.tileBounds.contains(tileID.canonical);\n };\n VectorTileSource.prototype.onAdd = function onAdd(map) {\n this.map = map;\n this.load();\n };\n VectorTileSource.prototype.setSourceProperty = function setSourceProperty(callback) {\n if (this._tileJSONRequest) {\n this._tileJSONRequest.cancel();\n }\n callback();\n var sourceCache = this.map.style.sourceCaches[this.id];\n sourceCache.clearTiles();\n this.load();\n };\n VectorTileSource.prototype.setTiles = function setTiles(tiles) {\n var this$1 = this;\n this.setSourceProperty(function () {\n this$1._options.tiles = tiles;\n });\n return this;\n };\n VectorTileSource.prototype.setUrl = function setUrl(url) {\n var this$1 = this;\n this.setSourceProperty(function () {\n this$1.url = url;\n this$1._options.url = url;\n });\n return this;\n };\n VectorTileSource.prototype.onRemove = function onRemove() {\n if (this._tileJSONRequest) {\n this._tileJSONRequest.cancel();\n this._tileJSONRequest = null;\n }\n };\n VectorTileSource.prototype.serialize = function serialize() {\n return performance.extend({}, this._options);\n };\n VectorTileSource.prototype.loadTile = function loadTile(tile, callback) {\n var url = this.map._requestManager.normalizeTileURL(tile.tileID.canonical.url(this.tiles, this.scheme));\n var params = {\n request: this.map._requestManager.transformRequest(url, performance.ResourceType.Tile),\n uid: tile.uid,\n tileID: tile.tileID,\n zoom: tile.tileID.overscaledZ,\n tileSize: this.tileSize * tile.tileID.overscaleFactor(),\n type: this.type,\n source: this.id,\n pixelRatio: performance.browser.devicePixelRatio,\n showCollisionBoxes: this.map.showCollisionBoxes,\n promoteId: this.promoteId\n };\n params.request.collectResourceTiming = this._collectResourceTiming;\n if (!tile.actor || tile.state === 'expired') {\n tile.actor = this.dispatcher.getActor();\n tile.request = tile.actor.send('loadTile', params, done.bind(this));\n } else if (tile.state === 'loading') {\n tile.reloadCallback = callback;\n } else {\n tile.request = tile.actor.send('reloadTile', params, done.bind(this));\n }\n function done(err, data) {\n delete tile.request;\n if (tile.aborted) {\n return callback(null);\n }\n if (err && err.status !== 404) {\n return callback(err);\n }\n if (data && data.resourceTiming) {\n tile.resourceTiming = data.resourceTiming;\n }\n if (this.map._refreshExpiredTiles && data) {\n tile.setExpiryData(data);\n }\n tile.loadVectorData(data, this.map.painter);\n performance.cacheEntryPossiblyAdded(this.dispatcher);\n callback(null);\n if (tile.reloadCallback) {\n this.loadTile(tile, tile.reloadCallback);\n tile.reloadCallback = null;\n }\n }\n };\n VectorTileSource.prototype.abortTile = function abortTile(tile) {\n if (tile.request) {\n tile.request.cancel();\n delete tile.request;\n }\n if (tile.actor) {\n tile.actor.send('abortTile', {\n uid: tile.uid,\n type: this.type,\n source: this.id\n }, undefined);\n }\n };\n VectorTileSource.prototype.unloadTile = function unloadTile(tile) {\n tile.unloadVectorData();\n if (tile.actor) {\n tile.actor.send('removeTile', {\n uid: tile.uid,\n type: this.type,\n source: this.id\n }, undefined);\n }\n };\n VectorTileSource.prototype.hasTransition = function hasTransition() {\n return false;\n };\n return VectorTileSource;\n}(performance.Evented);\n\nvar RasterTileSource = function (Evented) {\n function RasterTileSource(id, options, dispatcher, eventedParent) {\n Evented.call(this);\n this.id = id;\n this.dispatcher = dispatcher;\n this.setEventedParent(eventedParent);\n this.type = 'raster';\n this.minzoom = 0;\n this.maxzoom = 22;\n this.roundZoom = true;\n this.scheme = 'xyz';\n this.tileSize = 512;\n this._loaded = false;\n this._options = performance.extend({ type: 'raster' }, options);\n performance.extend(this, performance.pick(options, [\n 'url',\n 'scheme',\n 'tileSize'\n ]));\n }\n if (Evented)\n RasterTileSource.__proto__ = Evented;\n RasterTileSource.prototype = Object.create(Evented && Evented.prototype);\n RasterTileSource.prototype.constructor = RasterTileSource;\n RasterTileSource.prototype.load = function load() {\n var this$1 = this;\n this._loaded = false;\n this.fire(new performance.Event('dataloading', { dataType: 'source' }));\n this._tileJSONRequest = loadTileJSON(this._options, this.map._requestManager, function (err, tileJSON) {\n this$1._tileJSONRequest = null;\n this$1._loaded = true;\n if (err) {\n this$1.fire(new performance.ErrorEvent(err));\n } else if (tileJSON) {\n performance.extend(this$1, tileJSON);\n if (tileJSON.bounds) {\n this$1.tileBounds = new TileBounds(tileJSON.bounds, this$1.minzoom, this$1.maxzoom);\n }\n performance.postTurnstileEvent(tileJSON.tiles);\n performance.postMapLoadEvent(tileJSON.tiles, this$1.map._getMapId(), this$1.map._requestManager._skuToken);\n this$1.fire(new performance.Event('data', {\n dataType: 'source',\n sourceDataType: 'metadata'\n }));\n this$1.fire(new performance.Event('data', {\n dataType: 'source',\n sourceDataType: 'content'\n }));\n }\n });\n };\n RasterTileSource.prototype.loaded = function loaded() {\n return this._loaded;\n };\n RasterTileSource.prototype.onAdd = function onAdd(map) {\n this.map = map;\n this.load();\n };\n RasterTileSource.prototype.onRemove = function onRemove() {\n if (this._tileJSONRequest) {\n this._tileJSONRequest.cancel();\n this._tileJSONRequest = null;\n }\n };\n RasterTileSource.prototype.serialize = function serialize() {\n return performance.extend({}, this._options);\n };\n RasterTileSource.prototype.hasTile = function hasTile(tileID) {\n return !this.tileBounds || this.tileBounds.contains(tileID.canonical);\n };\n RasterTileSource.prototype.loadTile = function loadTile(tile, callback) {\n var this$1 = this;\n var url = this.map._requestManager.normalizeTileURL(tile.tileID.canonical.url(this.tiles, this.scheme), this.tileSize);\n tile.request = performance.getImage(this.map._requestManager.transformRequest(url, performance.ResourceType.Tile), function (err, img) {\n delete tile.request;\n if (tile.aborted) {\n tile.state = 'unloaded';\n callback(null);\n } else if (err) {\n tile.state = 'errored';\n callback(err);\n } else if (img) {\n if (this$1.map._refreshExpiredTiles) {\n tile.setExpiryData(img);\n }\n delete img.cacheControl;\n delete img.expires;\n var context = this$1.map.painter.context;\n var gl = context.gl;\n tile.texture = this$1.map.painter.getTileTexture(img.width);\n if (tile.texture) {\n tile.texture.update(img, { useMipmap: true });\n } else {\n tile.texture = new performance.Texture(context, img, gl.RGBA, { useMipmap: true });\n tile.texture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE, gl.LINEAR_MIPMAP_NEAREST);\n if (context.extTextureFilterAnisotropic) {\n gl.texParameterf(gl.TEXTURE_2D, context.extTextureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT, context.extTextureFilterAnisotropicMax);\n }\n }\n tile.state = 'loaded';\n performance.cacheEntryPossiblyAdded(this$1.dispatcher);\n callback(null);\n }\n });\n };\n RasterTileSource.prototype.abortTile = function abortTile(tile, callback) {\n if (tile.request) {\n tile.request.cancel();\n delete tile.request;\n }\n callback();\n };\n RasterTileSource.prototype.unloadTile = function unloadTile(tile, callback) {\n if (tile.texture) {\n this.map.painter.saveTileTexture(tile.texture);\n }\n callback();\n };\n RasterTileSource.prototype.hasTransition = function hasTransition() {\n return false;\n };\n return RasterTileSource;\n}(performance.Evented);\n\nvar RasterDEMTileSource = function (RasterTileSource) {\n function RasterDEMTileSource(id, options, dispatcher, eventedParent) {\n RasterTileSource.call(this, id, options, dispatcher, eventedParent);\n this.type = 'raster-dem';\n this.maxzoom = 22;\n this._options = performance.extend({ type: 'raster-dem' }, options);\n this.encoding = options.encoding || 'mapbox';\n }\n if (RasterTileSource)\n RasterDEMTileSource.__proto__ = RasterTileSource;\n RasterDEMTileSource.prototype = Object.create(RasterTileSource && RasterTileSource.prototype);\n RasterDEMTileSource.prototype.constructor = RasterDEMTileSource;\n RasterDEMTileSource.prototype.serialize = function serialize() {\n return {\n type: 'raster-dem',\n url: this.url,\n tileSize: this.tileSize,\n tiles: this.tiles,\n bounds: this.bounds,\n encoding: this.encoding\n };\n };\n RasterDEMTileSource.prototype.loadTile = function loadTile(tile, callback) {\n var url = this.map._requestManager.normalizeTileURL(tile.tileID.canonical.url(this.tiles, this.scheme), this.tileSize);\n tile.request = performance.getImage(this.map._requestManager.transformRequest(url, performance.ResourceType.Tile), imageLoaded.bind(this));\n tile.neighboringTiles = this._getNeighboringTiles(tile.tileID);\n function imageLoaded(err, img) {\n delete tile.request;\n if (tile.aborted) {\n tile.state = 'unloaded';\n callback(null);\n } else if (err) {\n tile.state = 'errored';\n callback(err);\n } else if (img) {\n if (this.map._refreshExpiredTiles) {\n tile.setExpiryData(img);\n }\n delete img.cacheControl;\n delete img.expires;\n var transfer = performance.window.ImageBitmap && img instanceof performance.window.ImageBitmap && performance.offscreenCanvasSupported();\n var rawImageData = transfer ? img : performance.browser.getImageData(img, 1);\n var params = {\n uid: tile.uid,\n coord: tile.tileID,\n source: this.id,\n rawImageData: rawImageData,\n encoding: this.encoding\n };\n if (!tile.actor || tile.state === 'expired') {\n tile.actor = this.dispatcher.getActor();\n tile.actor.send('loadDEMTile', params, done.bind(this));\n }\n }\n }\n function done(err, dem) {\n if (err) {\n tile.state = 'errored';\n callback(err);\n }\n if (dem) {\n tile.dem = dem;\n tile.needsHillshadePrepare = true;\n tile.state = 'loaded';\n callback(null);\n }\n }\n };\n RasterDEMTileSource.prototype._getNeighboringTiles = function _getNeighboringTiles(tileID) {\n var canonical = tileID.canonical;\n var dim = Math.pow(2, canonical.z);\n var px = (canonical.x - 1 + dim) % dim;\n var pxw = canonical.x === 0 ? tileID.wrap - 1 : tileID.wrap;\n var nx = (canonical.x + 1 + dim) % dim;\n var nxw = canonical.x + 1 === dim ? tileID.wrap + 1 : tileID.wrap;\n var neighboringTiles = {};\n neighboringTiles[new performance.OverscaledTileID(tileID.overscaledZ, pxw, canonical.z, px, canonical.y).key] = { backfilled: false };\n neighboringTiles[new performance.OverscaledTileID(tileID.overscaledZ, nxw, canonical.z, nx, canonical.y).key] = { backfilled: false };\n if (canonical.y > 0) {\n neighboringTiles[new performance.OverscaledTileID(tileID.overscaledZ, pxw, canonical.z, px, canonical.y - 1).key] = { backfilled: false };\n neighboringTiles[new performance.OverscaledTileID(tileID.overscaledZ, tileID.wrap, canonical.z, canonical.x, canonical.y - 1).key] = { backfilled: false };\n neighboringTiles[new performance.OverscaledTileID(tileID.overscaledZ, nxw, canonical.z, nx, canonical.y - 1).key] = { backfilled: false };\n }\n if (canonical.y + 1 < dim) {\n neighboringTiles[new performance.OverscaledTileID(tileID.overscaledZ, pxw, canonical.z, px, canonical.y + 1).key] = { backfilled: false };\n neighboringTiles[new performance.OverscaledTileID(tileID.overscaledZ, tileID.wrap, canonical.z, canonical.x, canonical.y + 1).key] = { backfilled: false };\n neighboringTiles[new performance.OverscaledTileID(tileID.overscaledZ, nxw, canonical.z, nx, canonical.y + 1).key] = { backfilled: false };\n }\n return neighboringTiles;\n };\n RasterDEMTileSource.prototype.unloadTile = function unloadTile(tile) {\n if (tile.demTexture) {\n this.map.painter.saveTileTexture(tile.demTexture);\n }\n if (tile.fbo) {\n tile.fbo.destroy();\n delete tile.fbo;\n }\n if (tile.dem) {\n delete tile.dem;\n }\n delete tile.neighboringTiles;\n tile.state = 'unloaded';\n if (tile.actor) {\n tile.actor.send('removeDEMTile', {\n uid: tile.uid,\n source: this.id\n });\n }\n };\n return RasterDEMTileSource;\n}(RasterTileSource);\n\nvar GeoJSONSource = function (Evented) {\n function GeoJSONSource(id, options, dispatcher, eventedParent) {\n Evented.call(this);\n this.id = id;\n this.type = 'geojson';\n this.minzoom = 0;\n this.maxzoom = 18;\n this.tileSize = 512;\n this.isTileClipped = true;\n this.reparseOverscaled = true;\n this._removed = false;\n this._loaded = false;\n this.actor = dispatcher.getActor();\n this.setEventedParent(eventedParent);\n this._data = options.data;\n this._options = performance.extend({}, options);\n this._collectResourceTiming = options.collectResourceTiming;\n this._resourceTiming = [];\n if (options.maxzoom !== undefined) {\n this.maxzoom = options.maxzoom;\n }\n if (options.type) {\n this.type = options.type;\n }\n if (options.attribution) {\n this.attribution = options.attribution;\n }\n this.promoteId = options.promoteId;\n var scale = performance.EXTENT / this.tileSize;\n this.workerOptions = performance.extend({\n source: this.id,\n cluster: options.cluster || false,\n geojsonVtOptions: {\n buffer: (options.buffer !== undefined ? options.buffer : 128) * scale,\n tolerance: (options.tolerance !== undefined ? options.tolerance : 0.375) * scale,\n extent: performance.EXTENT,\n maxZoom: this.maxzoom,\n lineMetrics: options.lineMetrics || false,\n generateId: options.generateId || false\n },\n superclusterOptions: {\n maxZoom: options.clusterMaxZoom !== undefined ? Math.min(options.clusterMaxZoom, this.maxzoom - 1) : this.maxzoom - 1,\n minPoints: Math.max(2, options.clusterMinPoints || 2),\n extent: performance.EXTENT,\n radius: (options.clusterRadius || 50) * scale,\n log: false,\n generateId: options.generateId || false\n },\n clusterProperties: options.clusterProperties,\n filter: options.filter\n }, options.workerOptions);\n }\n if (Evented)\n GeoJSONSource.__proto__ = Evented;\n GeoJSONSource.prototype = Object.create(Evented && Evented.prototype);\n GeoJSONSource.prototype.constructor = GeoJSONSource;\n GeoJSONSource.prototype.load = function load() {\n var this$1 = this;\n this.fire(new performance.Event('dataloading', { dataType: 'source' }));\n this._updateWorkerData(function (err) {\n if (err) {\n this$1.fire(new performance.ErrorEvent(err));\n return;\n }\n var data = {\n dataType: 'source',\n sourceDataType: 'metadata'\n };\n if (this$1._collectResourceTiming && this$1._resourceTiming && this$1._resourceTiming.length > 0) {\n data.resourceTiming = this$1._resourceTiming;\n this$1._resourceTiming = [];\n }\n this$1.fire(new performance.Event('data', data));\n });\n };\n GeoJSONSource.prototype.onAdd = function onAdd(map) {\n this.map = map;\n this.load();\n };\n GeoJSONSource.prototype.setData = function setData(data) {\n var this$1 = this;\n this._data = data;\n this.fire(new performance.Event('dataloading', { dataType: 'source' }));\n this._updateWorkerData(function (err) {\n if (err) {\n this$1.fire(new performance.ErrorEvent(err));\n return;\n }\n var data = {\n dataType: 'source',\n sourceDataType: 'content'\n };\n if (this$1._collectResourceTiming && this$1._resourceTiming && this$1._resourceTiming.length > 0) {\n data.resourceTiming = this$1._resourceTiming;\n this$1._resourceTiming = [];\n }\n this$1.fire(new performance.Event('data', data));\n });\n return this;\n };\n GeoJSONSource.prototype.getClusterExpansionZoom = function getClusterExpansionZoom(clusterId, callback) {\n this.actor.send('geojson.getClusterExpansionZoom', {\n clusterId: clusterId,\n source: this.id\n }, callback);\n return this;\n };\n GeoJSONSource.prototype.getClusterChildren = function getClusterChildren(clusterId, callback) {\n this.actor.send('geojson.getClusterChildren', {\n clusterId: clusterId,\n source: this.id\n }, callback);\n return this;\n };\n GeoJSONSource.prototype.getClusterLeaves = function getClusterLeaves(clusterId, limit, offset, callback) {\n this.actor.send('geojson.getClusterLeaves', {\n source: this.id,\n clusterId: clusterId,\n limit: limit,\n offset: offset\n }, callback);\n return this;\n };\n GeoJSONSource.prototype._updateWorkerData = function _updateWorkerData(callback) {\n var this$1 = this;\n this._loaded = false;\n var options = performance.extend({}, this.workerOptions);\n var data = this._data;\n if (typeof data === 'string') {\n options.request = this.map._requestManager.transformRequest(performance.browser.resolveURL(data), performance.ResourceType.Source);\n options.request.collectResourceTiming = this._collectResourceTiming;\n } else {\n options.data = JSON.stringify(data);\n }\n this.actor.send(this.type + '.loadData', options, function (err, result) {\n if (this$1._removed || result && result.abandoned) {\n return;\n }\n this$1._loaded = true;\n if (result && result.resourceTiming && result.resourceTiming[this$1.id]) {\n this$1._resourceTiming = result.resourceTiming[this$1.id].slice(0);\n }\n this$1.actor.send(this$1.type + '.coalesce', { source: options.source }, null);\n callback(err);\n });\n };\n GeoJSONSource.prototype.loaded = function loaded() {\n return this._loaded;\n };\n GeoJSONSource.prototype.loadTile = function loadTile(tile, callback) {\n var this$1 = this;\n var message = !tile.actor ? 'loadTile' : 'reloadTile';\n tile.actor = this.actor;\n var params = {\n type: this.type,\n uid: tile.uid,\n tileID: tile.tileID,\n zoom: tile.tileID.overscaledZ,\n maxZoom: this.maxzoom,\n tileSize: this.tileSize,\n source: this.id,\n pixelRatio: performance.browser.devicePixelRatio,\n showCollisionBoxes: this.map.showCollisionBoxes,\n promoteId: this.promoteId\n };\n tile.request = this.actor.send(message, params, function (err, data) {\n delete tile.request;\n tile.unloadVectorData();\n if (tile.aborted) {\n return callback(null);\n }\n if (err) {\n return callback(err);\n }\n tile.loadVectorData(data, this$1.map.painter, message === 'reloadTile');\n return callback(null);\n });\n };\n GeoJSONSource.prototype.abortTile = function abortTile(tile) {\n if (tile.request) {\n tile.request.cancel();\n delete tile.request;\n }\n tile.aborted = true;\n };\n GeoJSONSource.prototype.unloadTile = function unloadTile(tile) {\n tile.unloadVectorData();\n this.actor.send('removeTile', {\n uid: tile.uid,\n type: this.type,\n source: this.id\n });\n };\n GeoJSONSource.prototype.onRemove = function onRemove() {\n this._removed = true;\n this.actor.send('removeSource', {\n type: this.type,\n source: this.id\n });\n };\n GeoJSONSource.prototype.serialize = function serialize() {\n return performance.extend({}, this._options, {\n type: this.type,\n data: this._data\n });\n };\n GeoJSONSource.prototype.hasTransition = function hasTransition() {\n return false;\n };\n return GeoJSONSource;\n}(performance.Evented);\n\nvar rasterBoundsAttributes = performance.createLayout([\n {\n name: 'a_pos',\n type: 'Int16',\n components: 2\n },\n {\n name: 'a_texture_pos',\n type: 'Int16',\n components: 2\n }\n]);\n\nvar ImageSource = function (Evented) {\n function ImageSource(id, options, dispatcher, eventedParent) {\n Evented.call(this);\n this.id = id;\n this.dispatcher = dispatcher;\n this.coordinates = options.coordinates;\n this.type = 'image';\n this.minzoom = 0;\n this.maxzoom = 22;\n this.tileSize = 512;\n this.tiles = {};\n this._loaded = false;\n this.setEventedParent(eventedParent);\n this.options = options;\n }\n if (Evented)\n ImageSource.__proto__ = Evented;\n ImageSource.prototype = Object.create(Evented && Evented.prototype);\n ImageSource.prototype.constructor = ImageSource;\n ImageSource.prototype.load = function load(newCoordinates, successCallback) {\n var this$1 = this;\n this._loaded = false;\n this.fire(new performance.Event('dataloading', { dataType: 'source' }));\n this.url = this.options.url;\n performance.getImage(this.map._requestManager.transformRequest(this.url, performance.ResourceType.Image), function (err, image) {\n this$1._loaded = true;\n if (err) {\n this$1.fire(new performance.ErrorEvent(err));\n } else if (image) {\n this$1.image = image;\n if (newCoordinates) {\n this$1.coordinates = newCoordinates;\n }\n if (successCallback) {\n successCallback();\n }\n this$1._finishLoading();\n }\n });\n };\n ImageSource.prototype.loaded = function loaded() {\n return this._loaded;\n };\n ImageSource.prototype.updateImage = function updateImage(options) {\n var this$1 = this;\n if (!this.image || !options.url) {\n return this;\n }\n this.options.url = options.url;\n this.load(options.coordinates, function () {\n this$1.texture = null;\n });\n return this;\n };\n ImageSource.prototype._finishLoading = function _finishLoading() {\n if (this.map) {\n this.setCoordinates(this.coordinates);\n this.fire(new performance.Event('data', {\n dataType: 'source',\n sourceDataType: 'metadata'\n }));\n }\n };\n ImageSource.prototype.onAdd = function onAdd(map) {\n this.map = map;\n this.load();\n };\n ImageSource.prototype.setCoordinates = function setCoordinates(coordinates) {\n var this$1 = this;\n this.coordinates = coordinates;\n var cornerCoords = coordinates.map(performance.MercatorCoordinate.fromLngLat);\n this.tileID = getCoordinatesCenterTileID(cornerCoords);\n this.minzoom = this.maxzoom = this.tileID.z;\n var tileCoords = cornerCoords.map(function (coord) {\n return this$1.tileID.getTilePoint(coord)._round();\n });\n this._boundsArray = new performance.StructArrayLayout4i8();\n this._boundsArray.emplaceBack(tileCoords[0].x, tileCoords[0].y, 0, 0);\n this._boundsArray.emplaceBack(tileCoords[1].x, tileCoords[1].y, performance.EXTENT, 0);\n this._boundsArray.emplaceBack(tileCoords[3].x, tileCoords[3].y, 0, performance.EXTENT);\n this._boundsArray.emplaceBack(tileCoords[2].x, tileCoords[2].y, performance.EXTENT, performance.EXTENT);\n if (this.boundsBuffer) {\n this.boundsBuffer.destroy();\n delete this.boundsBuffer;\n }\n this.fire(new performance.Event('data', {\n dataType: 'source',\n sourceDataType: 'content'\n }));\n return this;\n };\n ImageSource.prototype.prepare = function prepare() {\n if (Object.keys(this.tiles).length === 0 || !this.image) {\n return;\n }\n var context = this.map.painter.context;\n var gl = context.gl;\n if (!this.boundsBuffer) {\n this.boundsBuffer = context.createVertexBuffer(this._boundsArray, rasterBoundsAttributes.members);\n }\n if (!this.boundsSegments) {\n this.boundsSegments = performance.SegmentVector.simpleSegment(0, 0, 4, 2);\n }\n if (!this.texture) {\n this.texture = new performance.Texture(context, this.image, gl.RGBA);\n this.texture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n }\n for (var w in this.tiles) {\n var tile = this.tiles[w];\n if (tile.state !== 'loaded') {\n tile.state = 'loaded';\n tile.texture = this.texture;\n }\n }\n };\n ImageSource.prototype.loadTile = function loadTile(tile, callback) {\n if (this.tileID && this.tileID.equals(tile.tileID.canonical)) {\n this.tiles[String(tile.tileID.wrap)] = tile;\n tile.buckets = {};\n callback(null);\n } else {\n tile.state = 'errored';\n callback(null);\n }\n };\n ImageSource.prototype.serialize = function serialize() {\n return {\n type: 'image',\n url: this.options.url,\n coordinates: this.coordinates\n };\n };\n ImageSource.prototype.hasTransition = function hasTransition() {\n return false;\n };\n return ImageSource;\n}(performance.Evented);\nfunction getCoordinatesCenterTileID(coords) {\n var minX = Infinity;\n var minY = Infinity;\n var maxX = -Infinity;\n var maxY = -Infinity;\n for (var i = 0, list = coords; i < list.length; i += 1) {\n var coord = list[i];\n minX = Math.min(minX, coord.x);\n minY = Math.min(minY, coord.y);\n maxX = Math.max(maxX, coord.x);\n maxY = Math.max(maxY, coord.y);\n }\n var dx = maxX - minX;\n var dy = maxY - minY;\n var dMax = Math.max(dx, dy);\n var zoom = Math.max(0, Math.floor(-Math.log(dMax) / Math.LN2));\n var tilesAtZoom = Math.pow(2, zoom);\n return new performance.CanonicalTileID(zoom, Math.floor((minX + maxX) / 2 * tilesAtZoom), Math.floor((minY + maxY) / 2 * tilesAtZoom));\n}\n\nvar VideoSource = function (ImageSource) {\n function VideoSource(id, options, dispatcher, eventedParent) {\n ImageSource.call(this, id, options, dispatcher, eventedParent);\n this.roundZoom = true;\n this.type = 'video';\n this.options = options;\n }\n if (ImageSource)\n VideoSource.__proto__ = ImageSource;\n VideoSource.prototype = Object.create(ImageSource && ImageSource.prototype);\n VideoSource.prototype.constructor = VideoSource;\n VideoSource.prototype.load = function load() {\n var this$1 = this;\n this._loaded = false;\n var options = this.options;\n this.urls = [];\n for (var i = 0, list = options.urls; i < list.length; i += 1) {\n var url = list[i];\n this.urls.push(this.map._requestManager.transformRequest(url, performance.ResourceType.Source).url);\n }\n performance.getVideo(this.urls, function (err, video) {\n this$1._loaded = true;\n if (err) {\n this$1.fire(new performance.ErrorEvent(err));\n } else if (video) {\n this$1.video = video;\n this$1.video.loop = true;\n this$1.video.addEventListener('playing', function () {\n this$1.map.triggerRepaint();\n });\n if (this$1.map) {\n this$1.video.play();\n }\n this$1._finishLoading();\n }\n });\n };\n VideoSource.prototype.pause = function pause() {\n if (this.video) {\n this.video.pause();\n }\n };\n VideoSource.prototype.play = function play() {\n if (this.video) {\n this.video.play();\n }\n };\n VideoSource.prototype.seek = function seek(seconds) {\n if (this.video) {\n var seekableRange = this.video.seekable;\n if (seconds < seekableRange.start(0) || seconds > seekableRange.end(0)) {\n this.fire(new performance.ErrorEvent(new performance.ValidationError('sources.' + this.id, null, 'Playback for this video can be set only between the ' + seekableRange.start(0) + ' and ' + seekableRange.end(0) + '-second mark.')));\n } else {\n this.video.currentTime = seconds;\n }\n }\n };\n VideoSource.prototype.getVideo = function getVideo() {\n return this.video;\n };\n VideoSource.prototype.onAdd = function onAdd(map) {\n if (this.map) {\n return;\n }\n this.map = map;\n this.load();\n if (this.video) {\n this.video.play();\n this.setCoordinates(this.coordinates);\n }\n };\n VideoSource.prototype.prepare = function prepare() {\n if (Object.keys(this.tiles).length === 0 || this.video.readyState < 2) {\n return;\n }\n var context = this.map.painter.context;\n var gl = context.gl;\n if (!this.boundsBuffer) {\n this.boundsBuffer = context.createVertexBuffer(this._boundsArray, rasterBoundsAttributes.members);\n }\n if (!this.boundsSegments) {\n this.boundsSegments = performance.SegmentVector.simpleSegment(0, 0, 4, 2);\n }\n if (!this.texture) {\n this.texture = new performance.Texture(context, this.video, gl.RGBA);\n this.texture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n } else if (!this.video.paused) {\n this.texture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n gl.texSubImage2D(gl.TEXTURE_2D, 0, 0, 0, gl.RGBA, gl.UNSIGNED_BYTE, this.video);\n }\n for (var w in this.tiles) {\n var tile = this.tiles[w];\n if (tile.state !== 'loaded') {\n tile.state = 'loaded';\n tile.texture = this.texture;\n }\n }\n };\n VideoSource.prototype.serialize = function serialize() {\n return {\n type: 'video',\n urls: this.urls,\n coordinates: this.coordinates\n };\n };\n VideoSource.prototype.hasTransition = function hasTransition() {\n return this.video && !this.video.paused;\n };\n return VideoSource;\n}(ImageSource);\n\nvar CanvasSource = function (ImageSource) {\n function CanvasSource(id, options, dispatcher, eventedParent) {\n ImageSource.call(this, id, options, dispatcher, eventedParent);\n if (!options.coordinates) {\n this.fire(new performance.ErrorEvent(new performance.ValidationError('sources.' + id, null, 'missing required property \"coordinates\"')));\n } else if (!Array.isArray(options.coordinates) || options.coordinates.length !== 4 || options.coordinates.some(function (c) {\n return !Array.isArray(c) || c.length !== 2 || c.some(function (l) {\n return typeof l !== 'number';\n });\n })) {\n this.fire(new performance.ErrorEvent(new performance.ValidationError('sources.' + id, null, '\"coordinates\" property must be an array of 4 longitude/latitude array pairs')));\n }\n if (options.animate && typeof options.animate !== 'boolean') {\n this.fire(new performance.ErrorEvent(new performance.ValidationError('sources.' + id, null, 'optional \"animate\" property must be a boolean value')));\n }\n if (!options.canvas) {\n this.fire(new performance.ErrorEvent(new performance.ValidationError('sources.' + id, null, 'missing required property \"canvas\"')));\n } else if (typeof options.canvas !== 'string' && !(options.canvas instanceof performance.window.HTMLCanvasElement)) {\n this.fire(new performance.ErrorEvent(new performance.ValidationError('sources.' + id, null, '\"canvas\" must be either a string representing the ID of the canvas element from which to read, or an HTMLCanvasElement instance')));\n }\n this.options = options;\n this.animate = options.animate !== undefined ? options.animate : true;\n }\n if (ImageSource)\n CanvasSource.__proto__ = ImageSource;\n CanvasSource.prototype = Object.create(ImageSource && ImageSource.prototype);\n CanvasSource.prototype.constructor = CanvasSource;\n CanvasSource.prototype.load = function load() {\n this._loaded = true;\n if (!this.canvas) {\n this.canvas = this.options.canvas instanceof performance.window.HTMLCanvasElement ? this.options.canvas : performance.window.document.getElementById(this.options.canvas);\n }\n this.width = this.canvas.width;\n this.height = this.canvas.height;\n if (this._hasInvalidDimensions()) {\n this.fire(new performance.ErrorEvent(new Error('Canvas dimensions cannot be less than or equal to zero.')));\n return;\n }\n this.play = function () {\n this._playing = true;\n this.map.triggerRepaint();\n };\n this.pause = function () {\n if (this._playing) {\n this.prepare();\n this._playing = false;\n }\n };\n this._finishLoading();\n };\n CanvasSource.prototype.getCanvas = function getCanvas() {\n return this.canvas;\n };\n CanvasSource.prototype.onAdd = function onAdd(map) {\n this.map = map;\n this.load();\n if (this.canvas) {\n if (this.animate) {\n this.play();\n }\n }\n };\n CanvasSource.prototype.onRemove = function onRemove() {\n this.pause();\n };\n CanvasSource.prototype.prepare = function prepare() {\n var resize = false;\n if (this.canvas.width !== this.width) {\n this.width = this.canvas.width;\n resize = true;\n }\n if (this.canvas.height !== this.height) {\n this.height = this.canvas.height;\n resize = true;\n }\n if (this._hasInvalidDimensions()) {\n return;\n }\n if (Object.keys(this.tiles).length === 0) {\n return;\n }\n var context = this.map.painter.context;\n var gl = context.gl;\n if (!this.boundsBuffer) {\n this.boundsBuffer = context.createVertexBuffer(this._boundsArray, rasterBoundsAttributes.members);\n }\n if (!this.boundsSegments) {\n this.boundsSegments = performance.SegmentVector.simpleSegment(0, 0, 4, 2);\n }\n if (!this.texture) {\n this.texture = new performance.Texture(context, this.canvas, gl.RGBA, { premultiply: true });\n } else if (resize || this._playing) {\n this.texture.update(this.canvas, { premultiply: true });\n }\n for (var w in this.tiles) {\n var tile = this.tiles[w];\n if (tile.state !== 'loaded') {\n tile.state = 'loaded';\n tile.texture = this.texture;\n }\n }\n };\n CanvasSource.prototype.serialize = function serialize() {\n return {\n type: 'canvas',\n coordinates: this.coordinates\n };\n };\n CanvasSource.prototype.hasTransition = function hasTransition() {\n return this._playing;\n };\n CanvasSource.prototype._hasInvalidDimensions = function _hasInvalidDimensions() {\n for (var i = 0, list = [\n this.canvas.width,\n this.canvas.height\n ]; i < list.length; i += 1) {\n var x = list[i];\n if (isNaN(x) || x <= 0) {\n return true;\n }\n }\n return false;\n };\n return CanvasSource;\n}(ImageSource);\n\nvar sourceTypes = {\n vector: VectorTileSource,\n raster: RasterTileSource,\n 'raster-dem': RasterDEMTileSource,\n geojson: GeoJSONSource,\n video: VideoSource,\n image: ImageSource,\n canvas: CanvasSource\n};\nvar create = function (id, specification, dispatcher, eventedParent) {\n var source = new sourceTypes[specification.type](id, specification, dispatcher, eventedParent);\n if (source.id !== id) {\n throw new Error('Expected Source id to be ' + id + ' instead of ' + source.id);\n }\n performance.bindAll([\n 'load',\n 'abort',\n 'unload',\n 'serialize',\n 'prepare'\n ], source);\n return source;\n};\nvar getType = function (name) {\n return sourceTypes[name];\n};\nvar setType = function (name, type) {\n sourceTypes[name] = type;\n};\n\nfunction getPixelPosMatrix(transform, tileID) {\n var t = performance.identity([]);\n performance.translate(t, t, [\n 1,\n 1,\n 0\n ]);\n performance.scale(t, t, [\n transform.width * 0.5,\n transform.height * 0.5,\n 1\n ]);\n return performance.multiply(t, t, transform.calculatePosMatrix(tileID.toUnwrapped()));\n}\nfunction queryIncludes3DLayer(layers, styleLayers, sourceID) {\n if (layers) {\n for (var i = 0, list = layers; i < list.length; i += 1) {\n var layerID = list[i];\n var layer = styleLayers[layerID];\n if (layer && layer.source === sourceID && layer.type === 'fill-extrusion') {\n return true;\n }\n }\n } else {\n for (var key in styleLayers) {\n var layer$1 = styleLayers[key];\n if (layer$1.source === sourceID && layer$1.type === 'fill-extrusion') {\n return true;\n }\n }\n }\n return false;\n}\nfunction queryRenderedFeatures(sourceCache, styleLayers, serializedLayers, queryGeometry, params, transform) {\n var has3DLayer = queryIncludes3DLayer(params && params.layers, styleLayers, sourceCache.id);\n var maxPitchScaleFactor = transform.maxPitchScaleFactor();\n var tilesIn = sourceCache.tilesIn(queryGeometry, maxPitchScaleFactor, has3DLayer);\n tilesIn.sort(sortTilesIn);\n var renderedFeatureLayers = [];\n for (var i = 0, list = tilesIn; i < list.length; i += 1) {\n var tileIn = list[i];\n renderedFeatureLayers.push({\n wrappedTileID: tileIn.tileID.wrapped().key,\n queryResults: tileIn.tile.queryRenderedFeatures(styleLayers, serializedLayers, sourceCache._state, tileIn.queryGeometry, tileIn.cameraQueryGeometry, tileIn.scale, params, transform, maxPitchScaleFactor, getPixelPosMatrix(sourceCache.transform, tileIn.tileID))\n });\n }\n var result = mergeRenderedFeatureLayers(renderedFeatureLayers);\n for (var layerID in result) {\n result[layerID].forEach(function (featureWrapper) {\n var feature = featureWrapper.feature;\n var state = sourceCache.getFeatureState(feature.layer['source-layer'], feature.id);\n feature.source = feature.layer.source;\n if (feature.layer['source-layer']) {\n feature.sourceLayer = feature.layer['source-layer'];\n }\n feature.state = state;\n });\n }\n return result;\n}\nfunction queryRenderedSymbols(styleLayers, serializedLayers, sourceCaches, queryGeometry, params, collisionIndex, retainedQueryData) {\n var result = {};\n var renderedSymbols = collisionIndex.queryRenderedSymbols(queryGeometry);\n var bucketQueryData = [];\n for (var i = 0, list = Object.keys(renderedSymbols).map(Number); i < list.length; i += 1) {\n var bucketInstanceId = list[i];\n bucketQueryData.push(retainedQueryData[bucketInstanceId]);\n }\n bucketQueryData.sort(sortTilesIn);\n var loop = function () {\n var queryData = list$2[i$2];\n var bucketSymbols = queryData.featureIndex.lookupSymbolFeatures(renderedSymbols[queryData.bucketInstanceId], serializedLayers, queryData.bucketIndex, queryData.sourceLayerIndex, params.filter, params.layers, params.availableImages, styleLayers);\n for (var layerID in bucketSymbols) {\n var resultFeatures = result[layerID] = result[layerID] || [];\n var layerSymbols = bucketSymbols[layerID];\n layerSymbols.sort(function (a, b) {\n var featureSortOrder = queryData.featureSortOrder;\n if (featureSortOrder) {\n var sortedA = featureSortOrder.indexOf(a.featureIndex);\n var sortedB = featureSortOrder.indexOf(b.featureIndex);\n return sortedB - sortedA;\n } else {\n return b.featureIndex - a.featureIndex;\n }\n });\n for (var i$1 = 0, list$1 = layerSymbols; i$1 < list$1.length; i$1 += 1) {\n var symbolFeature = list$1[i$1];\n resultFeatures.push(symbolFeature);\n }\n }\n };\n for (var i$2 = 0, list$2 = bucketQueryData; i$2 < list$2.length; i$2 += 1)\n loop();\n var loop$1 = function (layerName) {\n result[layerName].forEach(function (featureWrapper) {\n var feature = featureWrapper.feature;\n var layer = styleLayers[layerName];\n var sourceCache = sourceCaches[layer.source];\n var state = sourceCache.getFeatureState(feature.layer['source-layer'], feature.id);\n feature.source = feature.layer.source;\n if (feature.layer['source-layer']) {\n feature.sourceLayer = feature.layer['source-layer'];\n }\n feature.state = state;\n });\n };\n for (var layerName in result)\n loop$1(layerName);\n return result;\n}\nfunction querySourceFeatures(sourceCache, params) {\n var tiles = sourceCache.getRenderableIds().map(function (id) {\n return sourceCache.getTileByID(id);\n });\n var result = [];\n var dataTiles = {};\n for (var i = 0; i < tiles.length; i++) {\n var tile = tiles[i];\n var dataID = tile.tileID.canonical.key;\n if (!dataTiles[dataID]) {\n dataTiles[dataID] = true;\n tile.querySourceFeatures(result, params);\n }\n }\n return result;\n}\nfunction sortTilesIn(a, b) {\n var idA = a.tileID;\n var idB = b.tileID;\n return idA.overscaledZ - idB.overscaledZ || idA.canonical.y - idB.canonical.y || idA.wrap - idB.wrap || idA.canonical.x - idB.canonical.x;\n}\nfunction mergeRenderedFeatureLayers(tiles) {\n var result = {};\n var wrappedIDLayerMap = {};\n for (var i$1 = 0, list$1 = tiles; i$1 < list$1.length; i$1 += 1) {\n var tile = list$1[i$1];\n var queryResults = tile.queryResults;\n var wrappedID = tile.wrappedTileID;\n var wrappedIDLayers = wrappedIDLayerMap[wrappedID] = wrappedIDLayerMap[wrappedID] || {};\n for (var layerID in queryResults) {\n var tileFeatures = queryResults[layerID];\n var wrappedIDFeatures = wrappedIDLayers[layerID] = wrappedIDLayers[layerID] || {};\n var resultFeatures = result[layerID] = result[layerID] || [];\n for (var i = 0, list = tileFeatures; i < list.length; i += 1) {\n var tileFeature = list[i];\n if (!wrappedIDFeatures[tileFeature.featureIndex]) {\n wrappedIDFeatures[tileFeature.featureIndex] = true;\n resultFeatures.push(tileFeature);\n }\n }\n }\n }\n return result;\n}\n\nvar TileCache = function TileCache(max, onRemove) {\n this.max = max;\n this.onRemove = onRemove;\n this.reset();\n};\nTileCache.prototype.reset = function reset() {\n for (var key in this.data) {\n for (var i = 0, list = this.data[key]; i < list.length; i += 1) {\n var removedData = list[i];\n if (removedData.timeout) {\n clearTimeout(removedData.timeout);\n }\n this.onRemove(removedData.value);\n }\n }\n this.data = {};\n this.order = [];\n return this;\n};\nTileCache.prototype.add = function add(tileID, data, expiryTimeout) {\n var this$1 = this;\n var key = tileID.wrapped().key;\n if (this.data[key] === undefined) {\n this.data[key] = [];\n }\n var dataWrapper = {\n value: data,\n timeout: undefined\n };\n if (expiryTimeout !== undefined) {\n dataWrapper.timeout = setTimeout(function () {\n this$1.remove(tileID, dataWrapper);\n }, expiryTimeout);\n }\n this.data[key].push(dataWrapper);\n this.order.push(key);\n if (this.order.length > this.max) {\n var removedData = this._getAndRemoveByKey(this.order[0]);\n if (removedData) {\n this.onRemove(removedData);\n }\n }\n return this;\n};\nTileCache.prototype.has = function has(tileID) {\n return tileID.wrapped().key in this.data;\n};\nTileCache.prototype.getAndRemove = function getAndRemove(tileID) {\n if (!this.has(tileID)) {\n return null;\n }\n return this._getAndRemoveByKey(tileID.wrapped().key);\n};\nTileCache.prototype._getAndRemoveByKey = function _getAndRemoveByKey(key) {\n var data = this.data[key].shift();\n if (data.timeout) {\n clearTimeout(data.timeout);\n }\n if (this.data[key].length === 0) {\n delete this.data[key];\n }\n this.order.splice(this.order.indexOf(key), 1);\n return data.value;\n};\nTileCache.prototype.getByKey = function getByKey(key) {\n var data = this.data[key];\n return data ? data[0].value : null;\n};\nTileCache.prototype.get = function get(tileID) {\n if (!this.has(tileID)) {\n return null;\n }\n var data = this.data[tileID.wrapped().key][0];\n return data.value;\n};\nTileCache.prototype.remove = function remove(tileID, value) {\n if (!this.has(tileID)) {\n return this;\n }\n var key = tileID.wrapped().key;\n var dataIndex = value === undefined ? 0 : this.data[key].indexOf(value);\n var data = this.data[key][dataIndex];\n this.data[key].splice(dataIndex, 1);\n if (data.timeout) {\n clearTimeout(data.timeout);\n }\n if (this.data[key].length === 0) {\n delete this.data[key];\n }\n this.onRemove(data.value);\n this.order.splice(this.order.indexOf(key), 1);\n return this;\n};\nTileCache.prototype.setMaxSize = function setMaxSize(max) {\n this.max = max;\n while (this.order.length > this.max) {\n var removedData = this._getAndRemoveByKey(this.order[0]);\n if (removedData) {\n this.onRemove(removedData);\n }\n }\n return this;\n};\nTileCache.prototype.filter = function filter(filterFn) {\n var removed = [];\n for (var key in this.data) {\n for (var i = 0, list = this.data[key]; i < list.length; i += 1) {\n var entry = list[i];\n if (!filterFn(entry.value)) {\n removed.push(entry);\n }\n }\n }\n for (var i$1 = 0, list$1 = removed; i$1 < list$1.length; i$1 += 1) {\n var r = list$1[i$1];\n this.remove(r.value.tileID, r);\n }\n};\n\nvar IndexBuffer = function IndexBuffer(context, array, dynamicDraw) {\n this.context = context;\n var gl = context.gl;\n this.buffer = gl.createBuffer();\n this.dynamicDraw = Boolean(dynamicDraw);\n this.context.unbindVAO();\n context.bindElementBuffer.set(this.buffer);\n gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, array.arrayBuffer, this.dynamicDraw ? gl.DYNAMIC_DRAW : gl.STATIC_DRAW);\n if (!this.dynamicDraw) {\n delete array.arrayBuffer;\n }\n};\nIndexBuffer.prototype.bind = function bind() {\n this.context.bindElementBuffer.set(this.buffer);\n};\nIndexBuffer.prototype.updateData = function updateData(array) {\n var gl = this.context.gl;\n this.context.unbindVAO();\n this.bind();\n gl.bufferSubData(gl.ELEMENT_ARRAY_BUFFER, 0, array.arrayBuffer);\n};\nIndexBuffer.prototype.destroy = function destroy() {\n var gl = this.context.gl;\n if (this.buffer) {\n gl.deleteBuffer(this.buffer);\n delete this.buffer;\n }\n};\n\nvar AttributeType = {\n Int8: 'BYTE',\n Uint8: 'UNSIGNED_BYTE',\n Int16: 'SHORT',\n Uint16: 'UNSIGNED_SHORT',\n Int32: 'INT',\n Uint32: 'UNSIGNED_INT',\n Float32: 'FLOAT'\n};\nvar VertexBuffer = function VertexBuffer(context, array, attributes, dynamicDraw) {\n this.length = array.length;\n this.attributes = attributes;\n this.itemSize = array.bytesPerElement;\n this.dynamicDraw = dynamicDraw;\n this.context = context;\n var gl = context.gl;\n this.buffer = gl.createBuffer();\n context.bindVertexBuffer.set(this.buffer);\n gl.bufferData(gl.ARRAY_BUFFER, array.arrayBuffer, this.dynamicDraw ? gl.DYNAMIC_DRAW : gl.STATIC_DRAW);\n if (!this.dynamicDraw) {\n delete array.arrayBuffer;\n }\n};\nVertexBuffer.prototype.bind = function bind() {\n this.context.bindVertexBuffer.set(this.buffer);\n};\nVertexBuffer.prototype.updateData = function updateData(array) {\n var gl = this.context.gl;\n this.bind();\n gl.bufferSubData(gl.ARRAY_BUFFER, 0, array.arrayBuffer);\n};\nVertexBuffer.prototype.enableAttributes = function enableAttributes(gl, program) {\n for (var j = 0; j < this.attributes.length; j++) {\n var member = this.attributes[j];\n var attribIndex = program.attributes[member.name];\n if (attribIndex !== undefined) {\n gl.enableVertexAttribArray(attribIndex);\n }\n }\n};\nVertexBuffer.prototype.setVertexAttribPointers = function setVertexAttribPointers(gl, program, vertexOffset) {\n for (var j = 0; j < this.attributes.length; j++) {\n var member = this.attributes[j];\n var attribIndex = program.attributes[member.name];\n if (attribIndex !== undefined) {\n gl.vertexAttribPointer(attribIndex, member.components, gl[AttributeType[member.type]], false, this.itemSize, member.offset + this.itemSize * (vertexOffset || 0));\n }\n }\n};\nVertexBuffer.prototype.destroy = function destroy() {\n var gl = this.context.gl;\n if (this.buffer) {\n gl.deleteBuffer(this.buffer);\n delete this.buffer;\n }\n};\n\nvar BaseValue = function BaseValue(context) {\n this.gl = context.gl;\n this.default = this.getDefault();\n this.current = this.default;\n this.dirty = false;\n};\nBaseValue.prototype.get = function get() {\n return this.current;\n};\nBaseValue.prototype.set = function set(value) {\n};\nBaseValue.prototype.getDefault = function getDefault() {\n return this.default;\n};\nBaseValue.prototype.setDefault = function setDefault() {\n this.set(this.default);\n};\nvar ClearColor = function (BaseValue) {\n function ClearColor() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n ClearColor.__proto__ = BaseValue;\n ClearColor.prototype = Object.create(BaseValue && BaseValue.prototype);\n ClearColor.prototype.constructor = ClearColor;\n ClearColor.prototype.getDefault = function getDefault() {\n return performance.Color.transparent;\n };\n ClearColor.prototype.set = function set(v) {\n var c = this.current;\n if (v.r === c.r && v.g === c.g && v.b === c.b && v.a === c.a && !this.dirty) {\n return;\n }\n this.gl.clearColor(v.r, v.g, v.b, v.a);\n this.current = v;\n this.dirty = false;\n };\n return ClearColor;\n}(BaseValue);\nvar ClearDepth = function (BaseValue) {\n function ClearDepth() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n ClearDepth.__proto__ = BaseValue;\n ClearDepth.prototype = Object.create(BaseValue && BaseValue.prototype);\n ClearDepth.prototype.constructor = ClearDepth;\n ClearDepth.prototype.getDefault = function getDefault() {\n return 1;\n };\n ClearDepth.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n this.gl.clearDepth(v);\n this.current = v;\n this.dirty = false;\n };\n return ClearDepth;\n}(BaseValue);\nvar ClearStencil = function (BaseValue) {\n function ClearStencil() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n ClearStencil.__proto__ = BaseValue;\n ClearStencil.prototype = Object.create(BaseValue && BaseValue.prototype);\n ClearStencil.prototype.constructor = ClearStencil;\n ClearStencil.prototype.getDefault = function getDefault() {\n return 0;\n };\n ClearStencil.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n this.gl.clearStencil(v);\n this.current = v;\n this.dirty = false;\n };\n return ClearStencil;\n}(BaseValue);\nvar ColorMask = function (BaseValue) {\n function ColorMask() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n ColorMask.__proto__ = BaseValue;\n ColorMask.prototype = Object.create(BaseValue && BaseValue.prototype);\n ColorMask.prototype.constructor = ColorMask;\n ColorMask.prototype.getDefault = function getDefault() {\n return [\n true,\n true,\n true,\n true\n ];\n };\n ColorMask.prototype.set = function set(v) {\n var c = this.current;\n if (v[0] === c[0] && v[1] === c[1] && v[2] === c[2] && v[3] === c[3] && !this.dirty) {\n return;\n }\n this.gl.colorMask(v[0], v[1], v[2], v[3]);\n this.current = v;\n this.dirty = false;\n };\n return ColorMask;\n}(BaseValue);\nvar DepthMask = function (BaseValue) {\n function DepthMask() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n DepthMask.__proto__ = BaseValue;\n DepthMask.prototype = Object.create(BaseValue && BaseValue.prototype);\n DepthMask.prototype.constructor = DepthMask;\n DepthMask.prototype.getDefault = function getDefault() {\n return true;\n };\n DepthMask.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n this.gl.depthMask(v);\n this.current = v;\n this.dirty = false;\n };\n return DepthMask;\n}(BaseValue);\nvar StencilMask = function (BaseValue) {\n function StencilMask() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n StencilMask.__proto__ = BaseValue;\n StencilMask.prototype = Object.create(BaseValue && BaseValue.prototype);\n StencilMask.prototype.constructor = StencilMask;\n StencilMask.prototype.getDefault = function getDefault() {\n return 255;\n };\n StencilMask.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n this.gl.stencilMask(v);\n this.current = v;\n this.dirty = false;\n };\n return StencilMask;\n}(BaseValue);\nvar StencilFunc = function (BaseValue) {\n function StencilFunc() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n StencilFunc.__proto__ = BaseValue;\n StencilFunc.prototype = Object.create(BaseValue && BaseValue.prototype);\n StencilFunc.prototype.constructor = StencilFunc;\n StencilFunc.prototype.getDefault = function getDefault() {\n return {\n func: this.gl.ALWAYS,\n ref: 0,\n mask: 255\n };\n };\n StencilFunc.prototype.set = function set(v) {\n var c = this.current;\n if (v.func === c.func && v.ref === c.ref && v.mask === c.mask && !this.dirty) {\n return;\n }\n this.gl.stencilFunc(v.func, v.ref, v.mask);\n this.current = v;\n this.dirty = false;\n };\n return StencilFunc;\n}(BaseValue);\nvar StencilOp = function (BaseValue) {\n function StencilOp() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n StencilOp.__proto__ = BaseValue;\n StencilOp.prototype = Object.create(BaseValue && BaseValue.prototype);\n StencilOp.prototype.constructor = StencilOp;\n StencilOp.prototype.getDefault = function getDefault() {\n var gl = this.gl;\n return [\n gl.KEEP,\n gl.KEEP,\n gl.KEEP\n ];\n };\n StencilOp.prototype.set = function set(v) {\n var c = this.current;\n if (v[0] === c[0] && v[1] === c[1] && v[2] === c[2] && !this.dirty) {\n return;\n }\n this.gl.stencilOp(v[0], v[1], v[2]);\n this.current = v;\n this.dirty = false;\n };\n return StencilOp;\n}(BaseValue);\nvar StencilTest = function (BaseValue) {\n function StencilTest() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n StencilTest.__proto__ = BaseValue;\n StencilTest.prototype = Object.create(BaseValue && BaseValue.prototype);\n StencilTest.prototype.constructor = StencilTest;\n StencilTest.prototype.getDefault = function getDefault() {\n return false;\n };\n StencilTest.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n var gl = this.gl;\n if (v) {\n gl.enable(gl.STENCIL_TEST);\n } else {\n gl.disable(gl.STENCIL_TEST);\n }\n this.current = v;\n this.dirty = false;\n };\n return StencilTest;\n}(BaseValue);\nvar DepthRange = function (BaseValue) {\n function DepthRange() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n DepthRange.__proto__ = BaseValue;\n DepthRange.prototype = Object.create(BaseValue && BaseValue.prototype);\n DepthRange.prototype.constructor = DepthRange;\n DepthRange.prototype.getDefault = function getDefault() {\n return [\n 0,\n 1\n ];\n };\n DepthRange.prototype.set = function set(v) {\n var c = this.current;\n if (v[0] === c[0] && v[1] === c[1] && !this.dirty) {\n return;\n }\n this.gl.depthRange(v[0], v[1]);\n this.current = v;\n this.dirty = false;\n };\n return DepthRange;\n}(BaseValue);\nvar DepthTest = function (BaseValue) {\n function DepthTest() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n DepthTest.__proto__ = BaseValue;\n DepthTest.prototype = Object.create(BaseValue && BaseValue.prototype);\n DepthTest.prototype.constructor = DepthTest;\n DepthTest.prototype.getDefault = function getDefault() {\n return false;\n };\n DepthTest.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n var gl = this.gl;\n if (v) {\n gl.enable(gl.DEPTH_TEST);\n } else {\n gl.disable(gl.DEPTH_TEST);\n }\n this.current = v;\n this.dirty = false;\n };\n return DepthTest;\n}(BaseValue);\nvar DepthFunc = function (BaseValue) {\n function DepthFunc() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n DepthFunc.__proto__ = BaseValue;\n DepthFunc.prototype = Object.create(BaseValue && BaseValue.prototype);\n DepthFunc.prototype.constructor = DepthFunc;\n DepthFunc.prototype.getDefault = function getDefault() {\n return this.gl.LESS;\n };\n DepthFunc.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n this.gl.depthFunc(v);\n this.current = v;\n this.dirty = false;\n };\n return DepthFunc;\n}(BaseValue);\nvar Blend = function (BaseValue) {\n function Blend() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n Blend.__proto__ = BaseValue;\n Blend.prototype = Object.create(BaseValue && BaseValue.prototype);\n Blend.prototype.constructor = Blend;\n Blend.prototype.getDefault = function getDefault() {\n return false;\n };\n Blend.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n var gl = this.gl;\n if (v) {\n gl.enable(gl.BLEND);\n } else {\n gl.disable(gl.BLEND);\n }\n this.current = v;\n this.dirty = false;\n };\n return Blend;\n}(BaseValue);\nvar BlendFunc = function (BaseValue) {\n function BlendFunc() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n BlendFunc.__proto__ = BaseValue;\n BlendFunc.prototype = Object.create(BaseValue && BaseValue.prototype);\n BlendFunc.prototype.constructor = BlendFunc;\n BlendFunc.prototype.getDefault = function getDefault() {\n var gl = this.gl;\n return [\n gl.ONE,\n gl.ZERO\n ];\n };\n BlendFunc.prototype.set = function set(v) {\n var c = this.current;\n if (v[0] === c[0] && v[1] === c[1] && !this.dirty) {\n return;\n }\n this.gl.blendFunc(v[0], v[1]);\n this.current = v;\n this.dirty = false;\n };\n return BlendFunc;\n}(BaseValue);\nvar BlendColor = function (BaseValue) {\n function BlendColor() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n BlendColor.__proto__ = BaseValue;\n BlendColor.prototype = Object.create(BaseValue && BaseValue.prototype);\n BlendColor.prototype.constructor = BlendColor;\n BlendColor.prototype.getDefault = function getDefault() {\n return performance.Color.transparent;\n };\n BlendColor.prototype.set = function set(v) {\n var c = this.current;\n if (v.r === c.r && v.g === c.g && v.b === c.b && v.a === c.a && !this.dirty) {\n return;\n }\n this.gl.blendColor(v.r, v.g, v.b, v.a);\n this.current = v;\n this.dirty = false;\n };\n return BlendColor;\n}(BaseValue);\nvar BlendEquation = function (BaseValue) {\n function BlendEquation() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n BlendEquation.__proto__ = BaseValue;\n BlendEquation.prototype = Object.create(BaseValue && BaseValue.prototype);\n BlendEquation.prototype.constructor = BlendEquation;\n BlendEquation.prototype.getDefault = function getDefault() {\n return this.gl.FUNC_ADD;\n };\n BlendEquation.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n this.gl.blendEquation(v);\n this.current = v;\n this.dirty = false;\n };\n return BlendEquation;\n}(BaseValue);\nvar CullFace = function (BaseValue) {\n function CullFace() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n CullFace.__proto__ = BaseValue;\n CullFace.prototype = Object.create(BaseValue && BaseValue.prototype);\n CullFace.prototype.constructor = CullFace;\n CullFace.prototype.getDefault = function getDefault() {\n return false;\n };\n CullFace.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n var gl = this.gl;\n if (v) {\n gl.enable(gl.CULL_FACE);\n } else {\n gl.disable(gl.CULL_FACE);\n }\n this.current = v;\n this.dirty = false;\n };\n return CullFace;\n}(BaseValue);\nvar CullFaceSide = function (BaseValue) {\n function CullFaceSide() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n CullFaceSide.__proto__ = BaseValue;\n CullFaceSide.prototype = Object.create(BaseValue && BaseValue.prototype);\n CullFaceSide.prototype.constructor = CullFaceSide;\n CullFaceSide.prototype.getDefault = function getDefault() {\n return this.gl.BACK;\n };\n CullFaceSide.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n this.gl.cullFace(v);\n this.current = v;\n this.dirty = false;\n };\n return CullFaceSide;\n}(BaseValue);\nvar FrontFace = function (BaseValue) {\n function FrontFace() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n FrontFace.__proto__ = BaseValue;\n FrontFace.prototype = Object.create(BaseValue && BaseValue.prototype);\n FrontFace.prototype.constructor = FrontFace;\n FrontFace.prototype.getDefault = function getDefault() {\n return this.gl.CCW;\n };\n FrontFace.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n this.gl.frontFace(v);\n this.current = v;\n this.dirty = false;\n };\n return FrontFace;\n}(BaseValue);\nvar Program = function (BaseValue) {\n function Program() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n Program.__proto__ = BaseValue;\n Program.prototype = Object.create(BaseValue && BaseValue.prototype);\n Program.prototype.constructor = Program;\n Program.prototype.getDefault = function getDefault() {\n return null;\n };\n Program.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n this.gl.useProgram(v);\n this.current = v;\n this.dirty = false;\n };\n return Program;\n}(BaseValue);\nvar ActiveTextureUnit = function (BaseValue) {\n function ActiveTextureUnit() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n ActiveTextureUnit.__proto__ = BaseValue;\n ActiveTextureUnit.prototype = Object.create(BaseValue && BaseValue.prototype);\n ActiveTextureUnit.prototype.constructor = ActiveTextureUnit;\n ActiveTextureUnit.prototype.getDefault = function getDefault() {\n return this.gl.TEXTURE0;\n };\n ActiveTextureUnit.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n this.gl.activeTexture(v);\n this.current = v;\n this.dirty = false;\n };\n return ActiveTextureUnit;\n}(BaseValue);\nvar Viewport = function (BaseValue) {\n function Viewport() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n Viewport.__proto__ = BaseValue;\n Viewport.prototype = Object.create(BaseValue && BaseValue.prototype);\n Viewport.prototype.constructor = Viewport;\n Viewport.prototype.getDefault = function getDefault() {\n var gl = this.gl;\n return [\n 0,\n 0,\n gl.drawingBufferWidth,\n gl.drawingBufferHeight\n ];\n };\n Viewport.prototype.set = function set(v) {\n var c = this.current;\n if (v[0] === c[0] && v[1] === c[1] && v[2] === c[2] && v[3] === c[3] && !this.dirty) {\n return;\n }\n this.gl.viewport(v[0], v[1], v[2], v[3]);\n this.current = v;\n this.dirty = false;\n };\n return Viewport;\n}(BaseValue);\nvar BindFramebuffer = function (BaseValue) {\n function BindFramebuffer() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n BindFramebuffer.__proto__ = BaseValue;\n BindFramebuffer.prototype = Object.create(BaseValue && BaseValue.prototype);\n BindFramebuffer.prototype.constructor = BindFramebuffer;\n BindFramebuffer.prototype.getDefault = function getDefault() {\n return null;\n };\n BindFramebuffer.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n var gl = this.gl;\n gl.bindFramebuffer(gl.FRAMEBUFFER, v);\n this.current = v;\n this.dirty = false;\n };\n return BindFramebuffer;\n}(BaseValue);\nvar BindRenderbuffer = function (BaseValue) {\n function BindRenderbuffer() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n BindRenderbuffer.__proto__ = BaseValue;\n BindRenderbuffer.prototype = Object.create(BaseValue && BaseValue.prototype);\n BindRenderbuffer.prototype.constructor = BindRenderbuffer;\n BindRenderbuffer.prototype.getDefault = function getDefault() {\n return null;\n };\n BindRenderbuffer.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n var gl = this.gl;\n gl.bindRenderbuffer(gl.RENDERBUFFER, v);\n this.current = v;\n this.dirty = false;\n };\n return BindRenderbuffer;\n}(BaseValue);\nvar BindTexture = function (BaseValue) {\n function BindTexture() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n BindTexture.__proto__ = BaseValue;\n BindTexture.prototype = Object.create(BaseValue && BaseValue.prototype);\n BindTexture.prototype.constructor = BindTexture;\n BindTexture.prototype.getDefault = function getDefault() {\n return null;\n };\n BindTexture.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n var gl = this.gl;\n gl.bindTexture(gl.TEXTURE_2D, v);\n this.current = v;\n this.dirty = false;\n };\n return BindTexture;\n}(BaseValue);\nvar BindVertexBuffer = function (BaseValue) {\n function BindVertexBuffer() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n BindVertexBuffer.__proto__ = BaseValue;\n BindVertexBuffer.prototype = Object.create(BaseValue && BaseValue.prototype);\n BindVertexBuffer.prototype.constructor = BindVertexBuffer;\n BindVertexBuffer.prototype.getDefault = function getDefault() {\n return null;\n };\n BindVertexBuffer.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n var gl = this.gl;\n gl.bindBuffer(gl.ARRAY_BUFFER, v);\n this.current = v;\n this.dirty = false;\n };\n return BindVertexBuffer;\n}(BaseValue);\nvar BindElementBuffer = function (BaseValue) {\n function BindElementBuffer() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n BindElementBuffer.__proto__ = BaseValue;\n BindElementBuffer.prototype = Object.create(BaseValue && BaseValue.prototype);\n BindElementBuffer.prototype.constructor = BindElementBuffer;\n BindElementBuffer.prototype.getDefault = function getDefault() {\n return null;\n };\n BindElementBuffer.prototype.set = function set(v) {\n var gl = this.gl;\n gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, v);\n this.current = v;\n this.dirty = false;\n };\n return BindElementBuffer;\n}(BaseValue);\nvar BindVertexArrayOES = function (BaseValue) {\n function BindVertexArrayOES(context) {\n BaseValue.call(this, context);\n this.vao = context.extVertexArrayObject;\n }\n if (BaseValue)\n BindVertexArrayOES.__proto__ = BaseValue;\n BindVertexArrayOES.prototype = Object.create(BaseValue && BaseValue.prototype);\n BindVertexArrayOES.prototype.constructor = BindVertexArrayOES;\n BindVertexArrayOES.prototype.getDefault = function getDefault() {\n return null;\n };\n BindVertexArrayOES.prototype.set = function set(v) {\n if (!this.vao || v === this.current && !this.dirty) {\n return;\n }\n this.vao.bindVertexArrayOES(v);\n this.current = v;\n this.dirty = false;\n };\n return BindVertexArrayOES;\n}(BaseValue);\nvar PixelStoreUnpack = function (BaseValue) {\n function PixelStoreUnpack() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n PixelStoreUnpack.__proto__ = BaseValue;\n PixelStoreUnpack.prototype = Object.create(BaseValue && BaseValue.prototype);\n PixelStoreUnpack.prototype.constructor = PixelStoreUnpack;\n PixelStoreUnpack.prototype.getDefault = function getDefault() {\n return 4;\n };\n PixelStoreUnpack.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n var gl = this.gl;\n gl.pixelStorei(gl.UNPACK_ALIGNMENT, v);\n this.current = v;\n this.dirty = false;\n };\n return PixelStoreUnpack;\n}(BaseValue);\nvar PixelStoreUnpackPremultiplyAlpha = function (BaseValue) {\n function PixelStoreUnpackPremultiplyAlpha() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n PixelStoreUnpackPremultiplyAlpha.__proto__ = BaseValue;\n PixelStoreUnpackPremultiplyAlpha.prototype = Object.create(BaseValue && BaseValue.prototype);\n PixelStoreUnpackPremultiplyAlpha.prototype.constructor = PixelStoreUnpackPremultiplyAlpha;\n PixelStoreUnpackPremultiplyAlpha.prototype.getDefault = function getDefault() {\n return false;\n };\n PixelStoreUnpackPremultiplyAlpha.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n var gl = this.gl;\n gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, v);\n this.current = v;\n this.dirty = false;\n };\n return PixelStoreUnpackPremultiplyAlpha;\n}(BaseValue);\nvar PixelStoreUnpackFlipY = function (BaseValue) {\n function PixelStoreUnpackFlipY() {\n BaseValue.apply(this, arguments);\n }\n if (BaseValue)\n PixelStoreUnpackFlipY.__proto__ = BaseValue;\n PixelStoreUnpackFlipY.prototype = Object.create(BaseValue && BaseValue.prototype);\n PixelStoreUnpackFlipY.prototype.constructor = PixelStoreUnpackFlipY;\n PixelStoreUnpackFlipY.prototype.getDefault = function getDefault() {\n return false;\n };\n PixelStoreUnpackFlipY.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n var gl = this.gl;\n gl.pixelStorei(gl.UNPACK_FLIP_Y_WEBGL, v);\n this.current = v;\n this.dirty = false;\n };\n return PixelStoreUnpackFlipY;\n}(BaseValue);\nvar FramebufferAttachment = function (BaseValue) {\n function FramebufferAttachment(context, parent) {\n BaseValue.call(this, context);\n this.context = context;\n this.parent = parent;\n }\n if (BaseValue)\n FramebufferAttachment.__proto__ = BaseValue;\n FramebufferAttachment.prototype = Object.create(BaseValue && BaseValue.prototype);\n FramebufferAttachment.prototype.constructor = FramebufferAttachment;\n FramebufferAttachment.prototype.getDefault = function getDefault() {\n return null;\n };\n return FramebufferAttachment;\n}(BaseValue);\nvar ColorAttachment = function (FramebufferAttachment) {\n function ColorAttachment() {\n FramebufferAttachment.apply(this, arguments);\n }\n if (FramebufferAttachment)\n ColorAttachment.__proto__ = FramebufferAttachment;\n ColorAttachment.prototype = Object.create(FramebufferAttachment && FramebufferAttachment.prototype);\n ColorAttachment.prototype.constructor = ColorAttachment;\n ColorAttachment.prototype.setDirty = function setDirty() {\n this.dirty = true;\n };\n ColorAttachment.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n this.context.bindFramebuffer.set(this.parent);\n var gl = this.gl;\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, v, 0);\n this.current = v;\n this.dirty = false;\n };\n return ColorAttachment;\n}(FramebufferAttachment);\nvar DepthAttachment = function (FramebufferAttachment) {\n function DepthAttachment() {\n FramebufferAttachment.apply(this, arguments);\n }\n if (FramebufferAttachment)\n DepthAttachment.__proto__ = FramebufferAttachment;\n DepthAttachment.prototype = Object.create(FramebufferAttachment && FramebufferAttachment.prototype);\n DepthAttachment.prototype.constructor = DepthAttachment;\n DepthAttachment.prototype.set = function set(v) {\n if (v === this.current && !this.dirty) {\n return;\n }\n this.context.bindFramebuffer.set(this.parent);\n var gl = this.gl;\n gl.framebufferRenderbuffer(gl.FRAMEBUFFER, gl.DEPTH_ATTACHMENT, gl.RENDERBUFFER, v);\n this.current = v;\n this.dirty = false;\n };\n return DepthAttachment;\n}(FramebufferAttachment);\n\nvar Framebuffer = function Framebuffer(context, width, height, hasDepth) {\n this.context = context;\n this.width = width;\n this.height = height;\n var gl = context.gl;\n var fbo = this.framebuffer = gl.createFramebuffer();\n this.colorAttachment = new ColorAttachment(context, fbo);\n if (hasDepth) {\n this.depthAttachment = new DepthAttachment(context, fbo);\n }\n};\nFramebuffer.prototype.destroy = function destroy() {\n var gl = this.context.gl;\n var texture = this.colorAttachment.get();\n if (texture) {\n gl.deleteTexture(texture);\n }\n if (this.depthAttachment) {\n var renderbuffer = this.depthAttachment.get();\n if (renderbuffer) {\n gl.deleteRenderbuffer(renderbuffer);\n }\n }\n gl.deleteFramebuffer(this.framebuffer);\n};\n\nvar ALWAYS = 519;\nvar DepthMode = function DepthMode(depthFunc, depthMask, depthRange) {\n this.func = depthFunc;\n this.mask = depthMask;\n this.range = depthRange;\n};\nDepthMode.ReadOnly = false;\nDepthMode.ReadWrite = true;\nDepthMode.disabled = new DepthMode(ALWAYS, DepthMode.ReadOnly, [\n 0,\n 1\n]);\n\nvar ALWAYS$1 = 519;\nvar KEEP = 7680;\nvar StencilMode = function StencilMode(test, ref, mask, fail, depthFail, pass) {\n this.test = test;\n this.ref = ref;\n this.mask = mask;\n this.fail = fail;\n this.depthFail = depthFail;\n this.pass = pass;\n};\nStencilMode.disabled = new StencilMode({\n func: ALWAYS$1,\n mask: 0\n}, 0, 0, KEEP, KEEP, KEEP);\n\nvar ZERO = 0;\nvar ONE = 1;\nvar ONE_MINUS_SRC_ALPHA = 771;\nvar ColorMode = function ColorMode(blendFunction, blendColor, mask) {\n this.blendFunction = blendFunction;\n this.blendColor = blendColor;\n this.mask = mask;\n};\nColorMode.Replace = [\n ONE,\n ZERO\n];\nColorMode.disabled = new ColorMode(ColorMode.Replace, performance.Color.transparent, [\n false,\n false,\n false,\n false\n]);\nColorMode.unblended = new ColorMode(ColorMode.Replace, performance.Color.transparent, [\n true,\n true,\n true,\n true\n]);\nColorMode.alphaBlended = new ColorMode([\n ONE,\n ONE_MINUS_SRC_ALPHA\n], performance.Color.transparent, [\n true,\n true,\n true,\n true\n]);\n\nvar BACK = 1029;\nvar CCW = 2305;\nvar CullFaceMode = function CullFaceMode(enable, mode, frontFace) {\n this.enable = enable;\n this.mode = mode;\n this.frontFace = frontFace;\n};\nCullFaceMode.disabled = new CullFaceMode(false, BACK, CCW);\nCullFaceMode.backCCW = new CullFaceMode(true, BACK, CCW);\n\nvar Context = function Context(gl) {\n this.gl = gl;\n this.extVertexArrayObject = this.gl.getExtension('OES_vertex_array_object');\n this.clearColor = new ClearColor(this);\n this.clearDepth = new ClearDepth(this);\n this.clearStencil = new ClearStencil(this);\n this.colorMask = new ColorMask(this);\n this.depthMask = new DepthMask(this);\n this.stencilMask = new StencilMask(this);\n this.stencilFunc = new StencilFunc(this);\n this.stencilOp = new StencilOp(this);\n this.stencilTest = new StencilTest(this);\n this.depthRange = new DepthRange(this);\n this.depthTest = new DepthTest(this);\n this.depthFunc = new DepthFunc(this);\n this.blend = new Blend(this);\n this.blendFunc = new BlendFunc(this);\n this.blendColor = new BlendColor(this);\n this.blendEquation = new BlendEquation(this);\n this.cullFace = new CullFace(this);\n this.cullFaceSide = new CullFaceSide(this);\n this.frontFace = new FrontFace(this);\n this.program = new Program(this);\n this.activeTexture = new ActiveTextureUnit(this);\n this.viewport = new Viewport(this);\n this.bindFramebuffer = new BindFramebuffer(this);\n this.bindRenderbuffer = new BindRenderbuffer(this);\n this.bindTexture = new BindTexture(this);\n this.bindVertexBuffer = new BindVertexBuffer(this);\n this.bindElementBuffer = new BindElementBuffer(this);\n this.bindVertexArrayOES = this.extVertexArrayObject && new BindVertexArrayOES(this);\n this.pixelStoreUnpack = new PixelStoreUnpack(this);\n this.pixelStoreUnpackPremultiplyAlpha = new PixelStoreUnpackPremultiplyAlpha(this);\n this.pixelStoreUnpackFlipY = new PixelStoreUnpackFlipY(this);\n this.extTextureFilterAnisotropic = gl.getExtension('EXT_texture_filter_anisotropic') || gl.getExtension('MOZ_EXT_texture_filter_anisotropic') || gl.getExtension('WEBKIT_EXT_texture_filter_anisotropic');\n if (this.extTextureFilterAnisotropic) {\n this.extTextureFilterAnisotropicMax = gl.getParameter(this.extTextureFilterAnisotropic.MAX_TEXTURE_MAX_ANISOTROPY_EXT);\n }\n this.extTextureHalfFloat = gl.getExtension('OES_texture_half_float');\n if (this.extTextureHalfFloat) {\n gl.getExtension('OES_texture_half_float_linear');\n this.extRenderToTextureHalfFloat = gl.getExtension('EXT_color_buffer_half_float');\n }\n this.extTimerQuery = gl.getExtension('EXT_disjoint_timer_query');\n this.maxTextureSize = gl.getParameter(gl.MAX_TEXTURE_SIZE);\n};\nContext.prototype.setDefault = function setDefault() {\n this.unbindVAO();\n this.clearColor.setDefault();\n this.clearDepth.setDefault();\n this.clearStencil.setDefault();\n this.colorMask.setDefault();\n this.depthMask.setDefault();\n this.stencilMask.setDefault();\n this.stencilFunc.setDefault();\n this.stencilOp.setDefault();\n this.stencilTest.setDefault();\n this.depthRange.setDefault();\n this.depthTest.setDefault();\n this.depthFunc.setDefault();\n this.blend.setDefault();\n this.blendFunc.setDefault();\n this.blendColor.setDefault();\n this.blendEquation.setDefault();\n this.cullFace.setDefault();\n this.cullFaceSide.setDefault();\n this.frontFace.setDefault();\n this.program.setDefault();\n this.activeTexture.setDefault();\n this.bindFramebuffer.setDefault();\n this.pixelStoreUnpack.setDefault();\n this.pixelStoreUnpackPremultiplyAlpha.setDefault();\n this.pixelStoreUnpackFlipY.setDefault();\n};\nContext.prototype.setDirty = function setDirty() {\n this.clearColor.dirty = true;\n this.clearDepth.dirty = true;\n this.clearStencil.dirty = true;\n this.colorMask.dirty = true;\n this.depthMask.dirty = true;\n this.stencilMask.dirty = true;\n this.stencilFunc.dirty = true;\n this.stencilOp.dirty = true;\n this.stencilTest.dirty = true;\n this.depthRange.dirty = true;\n this.depthTest.dirty = true;\n this.depthFunc.dirty = true;\n this.blend.dirty = true;\n this.blendFunc.dirty = true;\n this.blendColor.dirty = true;\n this.blendEquation.dirty = true;\n this.cullFace.dirty = true;\n this.cullFaceSide.dirty = true;\n this.frontFace.dirty = true;\n this.program.dirty = true;\n this.activeTexture.dirty = true;\n this.viewport.dirty = true;\n this.bindFramebuffer.dirty = true;\n this.bindRenderbuffer.dirty = true;\n this.bindTexture.dirty = true;\n this.bindVertexBuffer.dirty = true;\n this.bindElementBuffer.dirty = true;\n if (this.extVertexArrayObject) {\n this.bindVertexArrayOES.dirty = true;\n }\n this.pixelStoreUnpack.dirty = true;\n this.pixelStoreUnpackPremultiplyAlpha.dirty = true;\n this.pixelStoreUnpackFlipY.dirty = true;\n};\nContext.prototype.createIndexBuffer = function createIndexBuffer(array, dynamicDraw) {\n return new IndexBuffer(this, array, dynamicDraw);\n};\nContext.prototype.createVertexBuffer = function createVertexBuffer(array, attributes, dynamicDraw) {\n return new VertexBuffer(this, array, attributes, dynamicDraw);\n};\nContext.prototype.createRenderbuffer = function createRenderbuffer(storageFormat, width, height) {\n var gl = this.gl;\n var rbo = gl.createRenderbuffer();\n this.bindRenderbuffer.set(rbo);\n gl.renderbufferStorage(gl.RENDERBUFFER, storageFormat, width, height);\n this.bindRenderbuffer.set(null);\n return rbo;\n};\nContext.prototype.createFramebuffer = function createFramebuffer(width, height, hasDepth) {\n return new Framebuffer(this, width, height, hasDepth);\n};\nContext.prototype.clear = function clear(ref) {\n var color = ref.color;\n var depth = ref.depth;\n var gl = this.gl;\n var mask = 0;\n if (color) {\n mask |= gl.COLOR_BUFFER_BIT;\n this.clearColor.set(color);\n this.colorMask.set([\n true,\n true,\n true,\n true\n ]);\n }\n if (typeof depth !== 'undefined') {\n mask |= gl.DEPTH_BUFFER_BIT;\n this.depthRange.set([\n 0,\n 1\n ]);\n this.clearDepth.set(depth);\n this.depthMask.set(true);\n }\n gl.clear(mask);\n};\nContext.prototype.setCullFace = function setCullFace(cullFaceMode) {\n if (cullFaceMode.enable === false) {\n this.cullFace.set(false);\n } else {\n this.cullFace.set(true);\n this.cullFaceSide.set(cullFaceMode.mode);\n this.frontFace.set(cullFaceMode.frontFace);\n }\n};\nContext.prototype.setDepthMode = function setDepthMode(depthMode) {\n if (depthMode.func === this.gl.ALWAYS && !depthMode.mask) {\n this.depthTest.set(false);\n } else {\n this.depthTest.set(true);\n this.depthFunc.set(depthMode.func);\n this.depthMask.set(depthMode.mask);\n this.depthRange.set(depthMode.range);\n }\n};\nContext.prototype.setStencilMode = function setStencilMode(stencilMode) {\n if (stencilMode.test.func === this.gl.ALWAYS && !stencilMode.mask) {\n this.stencilTest.set(false);\n } else {\n this.stencilTest.set(true);\n this.stencilMask.set(stencilMode.mask);\n this.stencilOp.set([\n stencilMode.fail,\n stencilMode.depthFail,\n stencilMode.pass\n ]);\n this.stencilFunc.set({\n func: stencilMode.test.func,\n ref: stencilMode.ref,\n mask: stencilMode.test.mask\n });\n }\n};\nContext.prototype.setColorMode = function setColorMode(colorMode) {\n if (performance.deepEqual(colorMode.blendFunction, ColorMode.Replace)) {\n this.blend.set(false);\n } else {\n this.blend.set(true);\n this.blendFunc.set(colorMode.blendFunction);\n this.blendColor.set(colorMode.blendColor);\n }\n this.colorMask.set(colorMode.mask);\n};\nContext.prototype.unbindVAO = function unbindVAO() {\n if (this.extVertexArrayObject) {\n this.bindVertexArrayOES.set(null);\n }\n};\n\nvar SourceCache = function (Evented) {\n function SourceCache(id, options, dispatcher) {\n var this$1 = this;\n Evented.call(this);\n this.id = id;\n this.dispatcher = dispatcher;\n this.on('data', function (e) {\n if (e.dataType === 'source' && e.sourceDataType === 'metadata') {\n this$1._sourceLoaded = true;\n }\n if (this$1._sourceLoaded && !this$1._paused && e.dataType === 'source' && e.sourceDataType === 'content') {\n this$1.reload();\n if (this$1.transform) {\n this$1.update(this$1.transform);\n }\n }\n });\n this.on('error', function () {\n this$1._sourceErrored = true;\n });\n this._source = create(id, options, dispatcher, this);\n this._tiles = {};\n this._cache = new TileCache(0, this._unloadTile.bind(this));\n this._timers = {};\n this._cacheTimers = {};\n this._maxTileCacheSize = null;\n this._loadedParentTiles = {};\n this._coveredTiles = {};\n this._state = new performance.SourceFeatureState();\n }\n if (Evented)\n SourceCache.__proto__ = Evented;\n SourceCache.prototype = Object.create(Evented && Evented.prototype);\n SourceCache.prototype.constructor = SourceCache;\n SourceCache.prototype.onAdd = function onAdd(map) {\n this.map = map;\n this._maxTileCacheSize = map ? map._maxTileCacheSize : null;\n if (this._source && this._source.onAdd) {\n this._source.onAdd(map);\n }\n };\n SourceCache.prototype.onRemove = function onRemove(map) {\n if (this._source && this._source.onRemove) {\n this._source.onRemove(map);\n }\n };\n SourceCache.prototype.loaded = function loaded() {\n if (this._sourceErrored) {\n return true;\n }\n if (!this._sourceLoaded) {\n return false;\n }\n if (!this._source.loaded()) {\n return false;\n }\n for (var t in this._tiles) {\n var tile = this._tiles[t];\n if (tile.state !== 'loaded' && tile.state !== 'errored') {\n return false;\n }\n }\n return true;\n };\n SourceCache.prototype.getSource = function getSource() {\n return this._source;\n };\n SourceCache.prototype.pause = function pause() {\n this._paused = true;\n };\n SourceCache.prototype.resume = function resume() {\n if (!this._paused) {\n return;\n }\n var shouldReload = this._shouldReloadOnResume;\n this._paused = false;\n this._shouldReloadOnResume = false;\n if (shouldReload) {\n this.reload();\n }\n if (this.transform) {\n this.update(this.transform);\n }\n };\n SourceCache.prototype._loadTile = function _loadTile(tile, callback) {\n return this._source.loadTile(tile, callback);\n };\n SourceCache.prototype._unloadTile = function _unloadTile(tile) {\n if (this._source.unloadTile) {\n return this._source.unloadTile(tile, function () {\n });\n }\n };\n SourceCache.prototype._abortTile = function _abortTile(tile) {\n if (this._source.abortTile) {\n return this._source.abortTile(tile, function () {\n });\n }\n };\n SourceCache.prototype.serialize = function serialize() {\n return this._source.serialize();\n };\n SourceCache.prototype.prepare = function prepare(context) {\n if (this._source.prepare) {\n this._source.prepare();\n }\n this._state.coalesceChanges(this._tiles, this.map ? this.map.painter : null);\n for (var i in this._tiles) {\n var tile = this._tiles[i];\n tile.upload(context);\n tile.prepare(this.map.style.imageManager);\n }\n };\n SourceCache.prototype.getIds = function getIds() {\n return performance.values(this._tiles).map(function (tile) {\n return tile.tileID;\n }).sort(compareTileId).map(function (id) {\n return id.key;\n });\n };\n SourceCache.prototype.getRenderableIds = function getRenderableIds(symbolLayer) {\n var this$1 = this;\n var renderables = [];\n for (var id in this._tiles) {\n if (this._isIdRenderable(id, symbolLayer)) {\n renderables.push(this._tiles[id]);\n }\n }\n if (symbolLayer) {\n return renderables.sort(function (a_, b_) {\n var a = a_.tileID;\n var b = b_.tileID;\n var rotatedA = new performance.Point(a.canonical.x, a.canonical.y)._rotate(this$1.transform.angle);\n var rotatedB = new performance.Point(b.canonical.x, b.canonical.y)._rotate(this$1.transform.angle);\n return a.overscaledZ - b.overscaledZ || rotatedB.y - rotatedA.y || rotatedB.x - rotatedA.x;\n }).map(function (tile) {\n return tile.tileID.key;\n });\n }\n return renderables.map(function (tile) {\n return tile.tileID;\n }).sort(compareTileId).map(function (id) {\n return id.key;\n });\n };\n SourceCache.prototype.hasRenderableParent = function hasRenderableParent(tileID) {\n var parentTile = this.findLoadedParent(tileID, 0);\n if (parentTile) {\n return this._isIdRenderable(parentTile.tileID.key);\n }\n return false;\n };\n SourceCache.prototype._isIdRenderable = function _isIdRenderable(id, symbolLayer) {\n return this._tiles[id] && this._tiles[id].hasData() && !this._coveredTiles[id] && (symbolLayer || !this._tiles[id].holdingForFade());\n };\n SourceCache.prototype.reload = function reload() {\n if (this._paused) {\n this._shouldReloadOnResume = true;\n return;\n }\n this._cache.reset();\n for (var i in this._tiles) {\n if (this._tiles[i].state !== 'errored') {\n this._reloadTile(i, 'reloading');\n }\n }\n };\n SourceCache.prototype._reloadTile = function _reloadTile(id, state) {\n var tile = this._tiles[id];\n if (!tile) {\n return;\n }\n if (tile.state !== 'loading') {\n tile.state = state;\n }\n this._loadTile(tile, this._tileLoaded.bind(this, tile, id, state));\n };\n SourceCache.prototype._tileLoaded = function _tileLoaded(tile, id, previousState, err) {\n if (err) {\n tile.state = 'errored';\n if (err.status !== 404) {\n this._source.fire(new performance.ErrorEvent(err, { tile: tile }));\n } else {\n this.update(this.transform);\n }\n return;\n }\n tile.timeAdded = performance.browser.now();\n if (previousState === 'expired') {\n tile.refreshedUponExpiration = true;\n }\n this._setTileReloadTimer(id, tile);\n if (this.getSource().type === 'raster-dem' && tile.dem) {\n this._backfillDEM(tile);\n }\n this._state.initializeTileState(tile, this.map ? this.map.painter : null);\n this._source.fire(new performance.Event('data', {\n dataType: 'source',\n tile: tile,\n coord: tile.tileID\n }));\n };\n SourceCache.prototype._backfillDEM = function _backfillDEM(tile) {\n var renderables = this.getRenderableIds();\n for (var i = 0; i < renderables.length; i++) {\n var borderId = renderables[i];\n if (tile.neighboringTiles && tile.neighboringTiles[borderId]) {\n var borderTile = this.getTileByID(borderId);\n fillBorder(tile, borderTile);\n fillBorder(borderTile, tile);\n }\n }\n function fillBorder(tile, borderTile) {\n tile.needsHillshadePrepare = true;\n var dx = borderTile.tileID.canonical.x - tile.tileID.canonical.x;\n var dy = borderTile.tileID.canonical.y - tile.tileID.canonical.y;\n var dim = Math.pow(2, tile.tileID.canonical.z);\n var borderId = borderTile.tileID.key;\n if (dx === 0 && dy === 0) {\n return;\n }\n if (Math.abs(dy) > 1) {\n return;\n }\n if (Math.abs(dx) > 1) {\n if (Math.abs(dx + dim) === 1) {\n dx += dim;\n } else if (Math.abs(dx - dim) === 1) {\n dx -= dim;\n }\n }\n if (!borderTile.dem || !tile.dem) {\n return;\n }\n tile.dem.backfillBorder(borderTile.dem, dx, dy);\n if (tile.neighboringTiles && tile.neighboringTiles[borderId]) {\n tile.neighboringTiles[borderId].backfilled = true;\n }\n }\n };\n SourceCache.prototype.getTile = function getTile(tileID) {\n return this.getTileByID(tileID.key);\n };\n SourceCache.prototype.getTileByID = function getTileByID(id) {\n return this._tiles[id];\n };\n SourceCache.prototype._retainLoadedChildren = function _retainLoadedChildren(idealTiles, zoom, maxCoveringZoom, retain) {\n for (var id in this._tiles) {\n var tile = this._tiles[id];\n if (retain[id] || !tile.hasData() || tile.tileID.overscaledZ <= zoom || tile.tileID.overscaledZ > maxCoveringZoom) {\n continue;\n }\n var topmostLoadedID = tile.tileID;\n while (tile && tile.tileID.overscaledZ > zoom + 1) {\n var parentID = tile.tileID.scaledTo(tile.tileID.overscaledZ - 1);\n tile = this._tiles[parentID.key];\n if (tile && tile.hasData()) {\n topmostLoadedID = parentID;\n }\n }\n var tileID = topmostLoadedID;\n while (tileID.overscaledZ > zoom) {\n tileID = tileID.scaledTo(tileID.overscaledZ - 1);\n if (idealTiles[tileID.key]) {\n retain[topmostLoadedID.key] = topmostLoadedID;\n break;\n }\n }\n }\n };\n SourceCache.prototype.findLoadedParent = function findLoadedParent(tileID, minCoveringZoom) {\n if (tileID.key in this._loadedParentTiles) {\n var parent = this._loadedParentTiles[tileID.key];\n if (parent && parent.tileID.overscaledZ >= minCoveringZoom) {\n return parent;\n } else {\n return null;\n }\n }\n for (var z = tileID.overscaledZ - 1; z >= minCoveringZoom; z--) {\n var parentTileID = tileID.scaledTo(z);\n var tile = this._getLoadedTile(parentTileID);\n if (tile) {\n return tile;\n }\n }\n };\n SourceCache.prototype._getLoadedTile = function _getLoadedTile(tileID) {\n var tile = this._tiles[tileID.key];\n if (tile && tile.hasData()) {\n return tile;\n }\n var cachedTile = this._cache.getByKey(tileID.wrapped().key);\n return cachedTile;\n };\n SourceCache.prototype.updateCacheSize = function updateCacheSize(transform) {\n var widthInTiles = Math.ceil(transform.width / this._source.tileSize) + 1;\n var heightInTiles = Math.ceil(transform.height / this._source.tileSize) + 1;\n var approxTilesInView = widthInTiles * heightInTiles;\n var commonZoomRange = 5;\n var viewDependentMaxSize = Math.floor(approxTilesInView * commonZoomRange);\n var maxSize = typeof this._maxTileCacheSize === 'number' ? Math.min(this._maxTileCacheSize, viewDependentMaxSize) : viewDependentMaxSize;\n this._cache.setMaxSize(maxSize);\n };\n SourceCache.prototype.handleWrapJump = function handleWrapJump(lng) {\n var prevLng = this._prevLng === undefined ? lng : this._prevLng;\n var lngDifference = lng - prevLng;\n var worldDifference = lngDifference / 360;\n var wrapDelta = Math.round(worldDifference);\n this._prevLng = lng;\n if (wrapDelta) {\n var tiles = {};\n for (var key in this._tiles) {\n var tile = this._tiles[key];\n tile.tileID = tile.tileID.unwrapTo(tile.tileID.wrap + wrapDelta);\n tiles[tile.tileID.key] = tile;\n }\n this._tiles = tiles;\n for (var id in this._timers) {\n clearTimeout(this._timers[id]);\n delete this._timers[id];\n }\n for (var id$1 in this._tiles) {\n var tile$1 = this._tiles[id$1];\n this._setTileReloadTimer(id$1, tile$1);\n }\n }\n };\n SourceCache.prototype.update = function update(transform) {\n var this$1 = this;\n this.transform = transform;\n if (!this._sourceLoaded || this._paused) {\n return;\n }\n this.updateCacheSize(transform);\n this.handleWrapJump(this.transform.center.lng);\n this._coveredTiles = {};\n var idealTileIDs;\n if (!this.used) {\n idealTileIDs = [];\n } else if (this._source.tileID) {\n idealTileIDs = transform.getVisibleUnwrappedCoordinates(this._source.tileID).map(function (unwrapped) {\n return new performance.OverscaledTileID(unwrapped.canonical.z, unwrapped.wrap, unwrapped.canonical.z, unwrapped.canonical.x, unwrapped.canonical.y);\n });\n } else {\n idealTileIDs = transform.coveringTiles({\n tileSize: this._source.tileSize,\n minzoom: this._source.minzoom,\n maxzoom: this._source.maxzoom,\n roundZoom: this._source.roundZoom,\n reparseOverscaled: this._source.reparseOverscaled\n });\n if (this._source.hasTile) {\n idealTileIDs = idealTileIDs.filter(function (coord) {\n return this$1._source.hasTile(coord);\n });\n }\n }\n var zoom = transform.coveringZoomLevel(this._source);\n var minCoveringZoom = Math.max(zoom - SourceCache.maxOverzooming, this._source.minzoom);\n var maxCoveringZoom = Math.max(zoom + SourceCache.maxUnderzooming, this._source.minzoom);\n var retain = this._updateRetainedTiles(idealTileIDs, zoom);\n if (isRasterType(this._source.type)) {\n var parentsForFading = {};\n var fadingTiles = {};\n var ids = Object.keys(retain);\n for (var i = 0, list = ids; i < list.length; i += 1) {\n var id = list[i];\n var tileID = retain[id];\n var tile = this._tiles[id];\n if (!tile || tile.fadeEndTime && tile.fadeEndTime <= performance.browser.now()) {\n continue;\n }\n var parentTile = this.findLoadedParent(tileID, minCoveringZoom);\n if (parentTile) {\n this._addTile(parentTile.tileID);\n parentsForFading[parentTile.tileID.key] = parentTile.tileID;\n }\n fadingTiles[id] = tileID;\n }\n this._retainLoadedChildren(fadingTiles, zoom, maxCoveringZoom, retain);\n for (var id$1 in parentsForFading) {\n if (!retain[id$1]) {\n this._coveredTiles[id$1] = true;\n retain[id$1] = parentsForFading[id$1];\n }\n }\n }\n for (var retainedId in retain) {\n this._tiles[retainedId].clearFadeHold();\n }\n var remove = performance.keysDifference(this._tiles, retain);\n for (var i$1 = 0, list$1 = remove; i$1 < list$1.length; i$1 += 1) {\n var tileID$1 = list$1[i$1];\n var tile$1 = this._tiles[tileID$1];\n if (tile$1.hasSymbolBuckets && !tile$1.holdingForFade()) {\n tile$1.setHoldDuration(this.map._fadeDuration);\n } else if (!tile$1.hasSymbolBuckets || tile$1.symbolFadeFinished()) {\n this._removeTile(tileID$1);\n }\n }\n this._updateLoadedParentTileCache();\n };\n SourceCache.prototype.releaseSymbolFadeTiles = function releaseSymbolFadeTiles() {\n for (var id in this._tiles) {\n if (this._tiles[id].holdingForFade()) {\n this._removeTile(id);\n }\n }\n };\n SourceCache.prototype._updateRetainedTiles = function _updateRetainedTiles(idealTileIDs, zoom) {\n var retain = {};\n var checked = {};\n var minCoveringZoom = Math.max(zoom - SourceCache.maxOverzooming, this._source.minzoom);\n var maxCoveringZoom = Math.max(zoom + SourceCache.maxUnderzooming, this._source.minzoom);\n var missingTiles = {};\n for (var i = 0, list = idealTileIDs; i < list.length; i += 1) {\n var tileID = list[i];\n var tile = this._addTile(tileID);\n retain[tileID.key] = tileID;\n if (tile.hasData()) {\n continue;\n }\n if (zoom < this._source.maxzoom) {\n missingTiles[tileID.key] = tileID;\n }\n }\n this._retainLoadedChildren(missingTiles, zoom, maxCoveringZoom, retain);\n for (var i$1 = 0, list$1 = idealTileIDs; i$1 < list$1.length; i$1 += 1) {\n var tileID$1 = list$1[i$1];\n var tile$1 = this._tiles[tileID$1.key];\n if (tile$1.hasData()) {\n continue;\n }\n if (zoom + 1 > this._source.maxzoom) {\n var childCoord = tileID$1.children(this._source.maxzoom)[0];\n var childTile = this.getTile(childCoord);\n if (!!childTile && childTile.hasData()) {\n retain[childCoord.key] = childCoord;\n continue;\n }\n } else {\n var children = tileID$1.children(this._source.maxzoom);\n if (retain[children[0].key] && retain[children[1].key] && retain[children[2].key] && retain[children[3].key]) {\n continue;\n }\n }\n var parentWasRequested = tile$1.wasRequested();\n for (var overscaledZ = tileID$1.overscaledZ - 1; overscaledZ >= minCoveringZoom; --overscaledZ) {\n var parentId = tileID$1.scaledTo(overscaledZ);\n if (checked[parentId.key]) {\n break;\n }\n checked[parentId.key] = true;\n tile$1 = this.getTile(parentId);\n if (!tile$1 && parentWasRequested) {\n tile$1 = this._addTile(parentId);\n }\n if (tile$1) {\n retain[parentId.key] = parentId;\n parentWasRequested = tile$1.wasRequested();\n if (tile$1.hasData()) {\n break;\n }\n }\n }\n }\n return retain;\n };\n SourceCache.prototype._updateLoadedParentTileCache = function _updateLoadedParentTileCache() {\n this._loadedParentTiles = {};\n for (var tileKey in this._tiles) {\n var path = [];\n var parentTile = void 0;\n var currentId = this._tiles[tileKey].tileID;\n while (currentId.overscaledZ > 0) {\n if (currentId.key in this._loadedParentTiles) {\n parentTile = this._loadedParentTiles[currentId.key];\n break;\n }\n path.push(currentId.key);\n var parentId = currentId.scaledTo(currentId.overscaledZ - 1);\n parentTile = this._getLoadedTile(parentId);\n if (parentTile) {\n break;\n }\n currentId = parentId;\n }\n for (var i = 0, list = path; i < list.length; i += 1) {\n var key = list[i];\n this._loadedParentTiles[key] = parentTile;\n }\n }\n };\n SourceCache.prototype._addTile = function _addTile(tileID) {\n var tile = this._tiles[tileID.key];\n if (tile) {\n return tile;\n }\n tile = this._cache.getAndRemove(tileID);\n if (tile) {\n this._setTileReloadTimer(tileID.key, tile);\n tile.tileID = tileID;\n this._state.initializeTileState(tile, this.map ? this.map.painter : null);\n if (this._cacheTimers[tileID.key]) {\n clearTimeout(this._cacheTimers[tileID.key]);\n delete this._cacheTimers[tileID.key];\n this._setTileReloadTimer(tileID.key, tile);\n }\n }\n var cached = Boolean(tile);\n if (!cached) {\n tile = new performance.Tile(tileID, this._source.tileSize * tileID.overscaleFactor());\n this._loadTile(tile, this._tileLoaded.bind(this, tile, tileID.key, tile.state));\n }\n if (!tile) {\n return null;\n }\n tile.uses++;\n this._tiles[tileID.key] = tile;\n if (!cached) {\n this._source.fire(new performance.Event('dataloading', {\n tile: tile,\n coord: tile.tileID,\n dataType: 'source'\n }));\n }\n return tile;\n };\n SourceCache.prototype._setTileReloadTimer = function _setTileReloadTimer(id, tile) {\n var this$1 = this;\n if (id in this._timers) {\n clearTimeout(this._timers[id]);\n delete this._timers[id];\n }\n var expiryTimeout = tile.getExpiryTimeout();\n if (expiryTimeout) {\n this._timers[id] = setTimeout(function () {\n this$1._reloadTile(id, 'expired');\n delete this$1._timers[id];\n }, expiryTimeout);\n }\n };\n SourceCache.prototype._removeTile = function _removeTile(id) {\n var tile = this._tiles[id];\n if (!tile) {\n return;\n }\n tile.uses--;\n delete this._tiles[id];\n if (this._timers[id]) {\n clearTimeout(this._timers[id]);\n delete this._timers[id];\n }\n if (tile.uses > 0) {\n return;\n }\n if (tile.hasData() && tile.state !== 'reloading') {\n this._cache.add(tile.tileID, tile, tile.getExpiryTimeout());\n } else {\n tile.aborted = true;\n this._abortTile(tile);\n this._unloadTile(tile);\n }\n };\n SourceCache.prototype.clearTiles = function clearTiles() {\n this._shouldReloadOnResume = false;\n this._paused = false;\n for (var id in this._tiles) {\n this._removeTile(id);\n }\n this._cache.reset();\n };\n SourceCache.prototype.tilesIn = function tilesIn(pointQueryGeometry, maxPitchScaleFactor, has3DLayer) {\n var this$1 = this;\n var tileResults = [];\n var transform = this.transform;\n if (!transform) {\n return tileResults;\n }\n var cameraPointQueryGeometry = has3DLayer ? transform.getCameraQueryGeometry(pointQueryGeometry) : pointQueryGeometry;\n var queryGeometry = pointQueryGeometry.map(function (p) {\n return transform.pointCoordinate(p);\n });\n var cameraQueryGeometry = cameraPointQueryGeometry.map(function (p) {\n return transform.pointCoordinate(p);\n });\n var ids = this.getIds();\n var minX = Infinity;\n var minY = Infinity;\n var maxX = -Infinity;\n var maxY = -Infinity;\n for (var i$1 = 0, list = cameraQueryGeometry; i$1 < list.length; i$1 += 1) {\n var p = list[i$1];\n minX = Math.min(minX, p.x);\n minY = Math.min(minY, p.y);\n maxX = Math.max(maxX, p.x);\n maxY = Math.max(maxY, p.y);\n }\n var loop = function (i) {\n var tile = this$1._tiles[ids[i]];\n if (tile.holdingForFade()) {\n return;\n }\n var tileID = tile.tileID;\n var scale = Math.pow(2, transform.zoom - tile.tileID.overscaledZ);\n var queryPadding = maxPitchScaleFactor * tile.queryPadding * performance.EXTENT / tile.tileSize / scale;\n var tileSpaceBounds = [\n tileID.getTilePoint(new performance.MercatorCoordinate(minX, minY)),\n tileID.getTilePoint(new performance.MercatorCoordinate(maxX, maxY))\n ];\n if (tileSpaceBounds[0].x - queryPadding < performance.EXTENT && tileSpaceBounds[0].y - queryPadding < performance.EXTENT && tileSpaceBounds[1].x + queryPadding >= 0 && tileSpaceBounds[1].y + queryPadding >= 0) {\n var tileSpaceQueryGeometry = queryGeometry.map(function (c) {\n return tileID.getTilePoint(c);\n });\n var tileSpaceCameraQueryGeometry = cameraQueryGeometry.map(function (c) {\n return tileID.getTilePoint(c);\n });\n tileResults.push({\n tile: tile,\n tileID: tileID,\n queryGeometry: tileSpaceQueryGeometry,\n cameraQueryGeometry: tileSpaceCameraQueryGeometry,\n scale: scale\n });\n }\n };\n for (var i = 0; i < ids.length; i++)\n loop(i);\n return tileResults;\n };\n SourceCache.prototype.getVisibleCoordinates = function getVisibleCoordinates(symbolLayer) {\n var this$1 = this;\n var coords = this.getRenderableIds(symbolLayer).map(function (id) {\n return this$1._tiles[id].tileID;\n });\n for (var i = 0, list = coords; i < list.length; i += 1) {\n var coord = list[i];\n coord.posMatrix = this.transform.calculatePosMatrix(coord.toUnwrapped());\n }\n return coords;\n };\n SourceCache.prototype.hasTransition = function hasTransition() {\n if (this._source.hasTransition()) {\n return true;\n }\n if (isRasterType(this._source.type)) {\n for (var id in this._tiles) {\n var tile = this._tiles[id];\n if (tile.fadeEndTime !== undefined && tile.fadeEndTime >= performance.browser.now()) {\n return true;\n }\n }\n }\n return false;\n };\n SourceCache.prototype.setFeatureState = function setFeatureState(sourceLayer, featureId, state) {\n sourceLayer = sourceLayer || '_geojsonTileLayer';\n this._state.updateState(sourceLayer, featureId, state);\n };\n SourceCache.prototype.removeFeatureState = function removeFeatureState(sourceLayer, featureId, key) {\n sourceLayer = sourceLayer || '_geojsonTileLayer';\n this._state.removeFeatureState(sourceLayer, featureId, key);\n };\n SourceCache.prototype.getFeatureState = function getFeatureState(sourceLayer, featureId) {\n sourceLayer = sourceLayer || '_geojsonTileLayer';\n return this._state.getState(sourceLayer, featureId);\n };\n SourceCache.prototype.setDependencies = function setDependencies(tileKey, namespace, dependencies) {\n var tile = this._tiles[tileKey];\n if (tile) {\n tile.setDependencies(namespace, dependencies);\n }\n };\n SourceCache.prototype.reloadTilesForDependencies = function reloadTilesForDependencies(namespaces, keys) {\n for (var id in this._tiles) {\n var tile = this._tiles[id];\n if (tile.hasDependency(namespaces, keys)) {\n this._reloadTile(id, 'reloading');\n }\n }\n this._cache.filter(function (tile) {\n return !tile.hasDependency(namespaces, keys);\n });\n };\n return SourceCache;\n}(performance.Evented);\nSourceCache.maxOverzooming = 10;\nSourceCache.maxUnderzooming = 3;\nfunction compareTileId(a, b) {\n var aWrap = Math.abs(a.wrap * 2) - +(a.wrap < 0);\n var bWrap = Math.abs(b.wrap * 2) - +(b.wrap < 0);\n return a.overscaledZ - b.overscaledZ || bWrap - aWrap || b.canonical.y - a.canonical.y || b.canonical.x - a.canonical.x;\n}\nfunction isRasterType(type) {\n return type === 'raster' || type === 'image' || type === 'video';\n}\n\nfunction WebWorker () {\n return new performance.window.Worker(exported.workerUrl);\n}\n\nvar PRELOAD_POOL_ID = 'mapboxgl_preloaded_worker_pool';\nvar WorkerPool = function WorkerPool() {\n this.active = {};\n};\nWorkerPool.prototype.acquire = function acquire(mapId) {\n if (!this.workers) {\n this.workers = [];\n while (this.workers.length < WorkerPool.workerCount) {\n this.workers.push(new WebWorker());\n }\n }\n this.active[mapId] = true;\n return this.workers.slice();\n};\nWorkerPool.prototype.release = function release(mapId) {\n delete this.active[mapId];\n if (this.numActive() === 0) {\n this.workers.forEach(function (w) {\n w.terminate();\n });\n this.workers = null;\n }\n};\nWorkerPool.prototype.isPreloaded = function isPreloaded() {\n return !!this.active[PRELOAD_POOL_ID];\n};\nWorkerPool.prototype.numActive = function numActive() {\n return Object.keys(this.active).length;\n};\nvar availableLogicalProcessors = Math.floor(performance.browser.hardwareConcurrency / 2);\nWorkerPool.workerCount = Math.max(Math.min(availableLogicalProcessors, 6), 1);\n\nvar globalWorkerPool;\nfunction getGlobalWorkerPool() {\n if (!globalWorkerPool) {\n globalWorkerPool = new WorkerPool();\n }\n return globalWorkerPool;\n}\nfunction prewarm() {\n var workerPool = getGlobalWorkerPool();\n workerPool.acquire(PRELOAD_POOL_ID);\n}\nfunction clearPrewarmedResources() {\n var pool = globalWorkerPool;\n if (pool) {\n if (pool.isPreloaded() && pool.numActive() === 1) {\n pool.release(PRELOAD_POOL_ID);\n globalWorkerPool = null;\n } else {\n console.warn('Could not clear WebWorkers since there are active Map instances that still reference it. The pre-warmed WebWorker pool can only be cleared when all map instances have been removed with map.remove()');\n }\n }\n}\n\nfunction deref(layer, parent) {\n var result = {};\n for (var k in layer) {\n if (k !== 'ref') {\n result[k] = layer[k];\n }\n }\n performance.refProperties.forEach(function (k) {\n if (k in parent) {\n result[k] = parent[k];\n }\n });\n return result;\n}\nfunction derefLayers(layers) {\n layers = layers.slice();\n var map = Object.create(null);\n for (var i = 0; i < layers.length; i++) {\n map[layers[i].id] = layers[i];\n }\n for (var i$1 = 0; i$1 < layers.length; i$1++) {\n if ('ref' in layers[i$1]) {\n layers[i$1] = deref(layers[i$1], map[layers[i$1].ref]);\n }\n }\n return layers;\n}\n\nfunction emptyStyle() {\n var style = {};\n var version = performance.styleSpec['$version'];\n for (var styleKey in performance.styleSpec['$root']) {\n var spec = performance.styleSpec['$root'][styleKey];\n if (spec.required) {\n var value = null;\n if (styleKey === 'version') {\n value = version;\n } else {\n if (spec.type === 'array') {\n value = [];\n } else {\n value = {};\n }\n }\n if (value != null) {\n style[styleKey] = value;\n }\n }\n }\n return style;\n}\n\nvar operations = {\n setStyle: 'setStyle',\n addLayer: 'addLayer',\n removeLayer: 'removeLayer',\n setPaintProperty: 'setPaintProperty',\n setLayoutProperty: 'setLayoutProperty',\n setFilter: 'setFilter',\n addSource: 'addSource',\n removeSource: 'removeSource',\n setGeoJSONSourceData: 'setGeoJSONSourceData',\n setLayerZoomRange: 'setLayerZoomRange',\n setLayerProperty: 'setLayerProperty',\n setCenter: 'setCenter',\n setZoom: 'setZoom',\n setBearing: 'setBearing',\n setPitch: 'setPitch',\n setSprite: 'setSprite',\n setGlyphs: 'setGlyphs',\n setTransition: 'setTransition',\n setLight: 'setLight'\n};\nfunction addSource(sourceId, after, commands) {\n commands.push({\n command: operations.addSource,\n args: [\n sourceId,\n after[sourceId]\n ]\n });\n}\nfunction removeSource(sourceId, commands, sourcesRemoved) {\n commands.push({\n command: operations.removeSource,\n args: [sourceId]\n });\n sourcesRemoved[sourceId] = true;\n}\nfunction updateSource(sourceId, after, commands, sourcesRemoved) {\n removeSource(sourceId, commands, sourcesRemoved);\n addSource(sourceId, after, commands);\n}\nfunction canUpdateGeoJSON(before, after, sourceId) {\n var prop;\n for (prop in before[sourceId]) {\n if (!before[sourceId].hasOwnProperty(prop)) {\n continue;\n }\n if (prop !== 'data' && !performance.deepEqual(before[sourceId][prop], after[sourceId][prop])) {\n return false;\n }\n }\n for (prop in after[sourceId]) {\n if (!after[sourceId].hasOwnProperty(prop)) {\n continue;\n }\n if (prop !== 'data' && !performance.deepEqual(before[sourceId][prop], after[sourceId][prop])) {\n return false;\n }\n }\n return true;\n}\nfunction diffSources(before, after, commands, sourcesRemoved) {\n before = before || {};\n after = after || {};\n var sourceId;\n for (sourceId in before) {\n if (!before.hasOwnProperty(sourceId)) {\n continue;\n }\n if (!after.hasOwnProperty(sourceId)) {\n removeSource(sourceId, commands, sourcesRemoved);\n }\n }\n for (sourceId in after) {\n if (!after.hasOwnProperty(sourceId)) {\n continue;\n }\n if (!before.hasOwnProperty(sourceId)) {\n addSource(sourceId, after, commands);\n } else if (!performance.deepEqual(before[sourceId], after[sourceId])) {\n if (before[sourceId].type === 'geojson' && after[sourceId].type === 'geojson' && canUpdateGeoJSON(before, after, sourceId)) {\n commands.push({\n command: operations.setGeoJSONSourceData,\n args: [\n sourceId,\n after[sourceId].data\n ]\n });\n } else {\n updateSource(sourceId, after, commands, sourcesRemoved);\n }\n }\n }\n}\nfunction diffLayerPropertyChanges(before, after, commands, layerId, klass, command) {\n before = before || {};\n after = after || {};\n var prop;\n for (prop in before) {\n if (!before.hasOwnProperty(prop)) {\n continue;\n }\n if (!performance.deepEqual(before[prop], after[prop])) {\n commands.push({\n command: command,\n args: [\n layerId,\n prop,\n after[prop],\n klass\n ]\n });\n }\n }\n for (prop in after) {\n if (!after.hasOwnProperty(prop) || before.hasOwnProperty(prop)) {\n continue;\n }\n if (!performance.deepEqual(before[prop], after[prop])) {\n commands.push({\n command: command,\n args: [\n layerId,\n prop,\n after[prop],\n klass\n ]\n });\n }\n }\n}\nfunction pluckId(layer) {\n return layer.id;\n}\nfunction indexById(group, layer) {\n group[layer.id] = layer;\n return group;\n}\nfunction diffLayers(before, after, commands) {\n before = before || [];\n after = after || [];\n var beforeOrder = before.map(pluckId);\n var afterOrder = after.map(pluckId);\n var beforeIndex = before.reduce(indexById, {});\n var afterIndex = after.reduce(indexById, {});\n var tracker = beforeOrder.slice();\n var clean = Object.create(null);\n var i, d, layerId, beforeLayer, afterLayer, insertBeforeLayerId, prop;\n for (i = 0, d = 0; i < beforeOrder.length; i++) {\n layerId = beforeOrder[i];\n if (!afterIndex.hasOwnProperty(layerId)) {\n commands.push({\n command: operations.removeLayer,\n args: [layerId]\n });\n tracker.splice(tracker.indexOf(layerId, d), 1);\n } else {\n d++;\n }\n }\n for (i = 0, d = 0; i < afterOrder.length; i++) {\n layerId = afterOrder[afterOrder.length - 1 - i];\n if (tracker[tracker.length - 1 - i] === layerId) {\n continue;\n }\n if (beforeIndex.hasOwnProperty(layerId)) {\n commands.push({\n command: operations.removeLayer,\n args: [layerId]\n });\n tracker.splice(tracker.lastIndexOf(layerId, tracker.length - d), 1);\n } else {\n d++;\n }\n insertBeforeLayerId = tracker[tracker.length - i];\n commands.push({\n command: operations.addLayer,\n args: [\n afterIndex[layerId],\n insertBeforeLayerId\n ]\n });\n tracker.splice(tracker.length - i, 0, layerId);\n clean[layerId] = true;\n }\n for (i = 0; i < afterOrder.length; i++) {\n layerId = afterOrder[i];\n beforeLayer = beforeIndex[layerId];\n afterLayer = afterIndex[layerId];\n if (clean[layerId] || performance.deepEqual(beforeLayer, afterLayer)) {\n continue;\n }\n if (!performance.deepEqual(beforeLayer.source, afterLayer.source) || !performance.deepEqual(beforeLayer['source-layer'], afterLayer['source-layer']) || !performance.deepEqual(beforeLayer.type, afterLayer.type)) {\n commands.push({\n command: operations.removeLayer,\n args: [layerId]\n });\n insertBeforeLayerId = tracker[tracker.lastIndexOf(layerId) + 1];\n commands.push({\n command: operations.addLayer,\n args: [\n afterLayer,\n insertBeforeLayerId\n ]\n });\n continue;\n }\n diffLayerPropertyChanges(beforeLayer.layout, afterLayer.layout, commands, layerId, null, operations.setLayoutProperty);\n diffLayerPropertyChanges(beforeLayer.paint, afterLayer.paint, commands, layerId, null, operations.setPaintProperty);\n if (!performance.deepEqual(beforeLayer.filter, afterLayer.filter)) {\n commands.push({\n command: operations.setFilter,\n args: [\n layerId,\n afterLayer.filter\n ]\n });\n }\n if (!performance.deepEqual(beforeLayer.minzoom, afterLayer.minzoom) || !performance.deepEqual(beforeLayer.maxzoom, afterLayer.maxzoom)) {\n commands.push({\n command: operations.setLayerZoomRange,\n args: [\n layerId,\n afterLayer.minzoom,\n afterLayer.maxzoom\n ]\n });\n }\n for (prop in beforeLayer) {\n if (!beforeLayer.hasOwnProperty(prop)) {\n continue;\n }\n if (prop === 'layout' || prop === 'paint' || prop === 'filter' || prop === 'metadata' || prop === 'minzoom' || prop === 'maxzoom') {\n continue;\n }\n if (prop.indexOf('paint.') === 0) {\n diffLayerPropertyChanges(beforeLayer[prop], afterLayer[prop], commands, layerId, prop.slice(6), operations.setPaintProperty);\n } else if (!performance.deepEqual(beforeLayer[prop], afterLayer[prop])) {\n commands.push({\n command: operations.setLayerProperty,\n args: [\n layerId,\n prop,\n afterLayer[prop]\n ]\n });\n }\n }\n for (prop in afterLayer) {\n if (!afterLayer.hasOwnProperty(prop) || beforeLayer.hasOwnProperty(prop)) {\n continue;\n }\n if (prop === 'layout' || prop === 'paint' || prop === 'filter' || prop === 'metadata' || prop === 'minzoom' || prop === 'maxzoom') {\n continue;\n }\n if (prop.indexOf('paint.') === 0) {\n diffLayerPropertyChanges(beforeLayer[prop], afterLayer[prop], commands, layerId, prop.slice(6), operations.setPaintProperty);\n } else if (!performance.deepEqual(beforeLayer[prop], afterLayer[prop])) {\n commands.push({\n command: operations.setLayerProperty,\n args: [\n layerId,\n prop,\n afterLayer[prop]\n ]\n });\n }\n }\n }\n}\nfunction diffStyles(before, after) {\n if (!before) {\n return [{\n command: operations.setStyle,\n args: [after]\n }];\n }\n var commands = [];\n try {\n if (!performance.deepEqual(before.version, after.version)) {\n return [{\n command: operations.setStyle,\n args: [after]\n }];\n }\n if (!performance.deepEqual(before.center, after.center)) {\n commands.push({\n command: operations.setCenter,\n args: [after.center]\n });\n }\n if (!performance.deepEqual(before.zoom, after.zoom)) {\n commands.push({\n command: operations.setZoom,\n args: [after.zoom]\n });\n }\n if (!performance.deepEqual(before.bearing, after.bearing)) {\n commands.push({\n command: operations.setBearing,\n args: [after.bearing]\n });\n }\n if (!performance.deepEqual(before.pitch, after.pitch)) {\n commands.push({\n command: operations.setPitch,\n args: [after.pitch]\n });\n }\n if (!performance.deepEqual(before.sprite, after.sprite)) {\n commands.push({\n command: operations.setSprite,\n args: [after.sprite]\n });\n }\n if (!performance.deepEqual(before.glyphs, after.glyphs)) {\n commands.push({\n command: operations.setGlyphs,\n args: [after.glyphs]\n });\n }\n if (!performance.deepEqual(before.transition, after.transition)) {\n commands.push({\n command: operations.setTransition,\n args: [after.transition]\n });\n }\n if (!performance.deepEqual(before.light, after.light)) {\n commands.push({\n command: operations.setLight,\n args: [after.light]\n });\n }\n var sourcesRemoved = {};\n var removeOrAddSourceCommands = [];\n diffSources(before.sources, after.sources, removeOrAddSourceCommands, sourcesRemoved);\n var beforeLayers = [];\n if (before.layers) {\n before.layers.forEach(function (layer) {\n if (sourcesRemoved[layer.source]) {\n commands.push({\n command: operations.removeLayer,\n args: [layer.id]\n });\n } else {\n beforeLayers.push(layer);\n }\n });\n }\n commands = commands.concat(removeOrAddSourceCommands);\n diffLayers(beforeLayers, after.layers, commands);\n } catch (e) {\n console.warn('Unable to compute style diff:', e);\n commands = [{\n command: operations.setStyle,\n args: [after]\n }];\n }\n return commands;\n}\n\nvar PathInterpolator = function PathInterpolator(points_, padding_) {\n this.reset(points_, padding_);\n};\nPathInterpolator.prototype.reset = function reset(points_, padding_) {\n this.points = points_ || [];\n this._distances = [0];\n for (var i = 1; i < this.points.length; i++) {\n this._distances[i] = this._distances[i - 1] + this.points[i].dist(this.points[i - 1]);\n }\n this.length = this._distances[this._distances.length - 1];\n this.padding = Math.min(padding_ || 0, this.length * 0.5);\n this.paddedLength = this.length - this.padding * 2;\n};\nPathInterpolator.prototype.lerp = function lerp(t) {\n if (this.points.length === 1) {\n return this.points[0];\n }\n t = performance.clamp(t, 0, 1);\n var currentIndex = 1;\n var distOfCurrentIdx = this._distances[currentIndex];\n var distToTarget = t * this.paddedLength + this.padding;\n while (distOfCurrentIdx < distToTarget && currentIndex < this._distances.length) {\n distOfCurrentIdx = this._distances[++currentIndex];\n }\n var idxOfPrevPoint = currentIndex - 1;\n var distOfPrevIdx = this._distances[idxOfPrevPoint];\n var segmentLength = distOfCurrentIdx - distOfPrevIdx;\n var segmentT = segmentLength > 0 ? (distToTarget - distOfPrevIdx) / segmentLength : 0;\n return this.points[idxOfPrevPoint].mult(1 - segmentT).add(this.points[currentIndex].mult(segmentT));\n};\n\nvar GridIndex = function GridIndex(width, height, cellSize) {\n var boxCells = this.boxCells = [];\n var circleCells = this.circleCells = [];\n this.xCellCount = Math.ceil(width / cellSize);\n this.yCellCount = Math.ceil(height / cellSize);\n for (var i = 0; i < this.xCellCount * this.yCellCount; i++) {\n boxCells.push([]);\n circleCells.push([]);\n }\n this.circleKeys = [];\n this.boxKeys = [];\n this.bboxes = [];\n this.circles = [];\n this.width = width;\n this.height = height;\n this.xScale = this.xCellCount / width;\n this.yScale = this.yCellCount / height;\n this.boxUid = 0;\n this.circleUid = 0;\n};\nGridIndex.prototype.keysLength = function keysLength() {\n return this.boxKeys.length + this.circleKeys.length;\n};\nGridIndex.prototype.insert = function insert(key, x1, y1, x2, y2) {\n this._forEachCell(x1, y1, x2, y2, this._insertBoxCell, this.boxUid++);\n this.boxKeys.push(key);\n this.bboxes.push(x1);\n this.bboxes.push(y1);\n this.bboxes.push(x2);\n this.bboxes.push(y2);\n};\nGridIndex.prototype.insertCircle = function insertCircle(key, x, y, radius) {\n this._forEachCell(x - radius, y - radius, x + radius, y + radius, this._insertCircleCell, this.circleUid++);\n this.circleKeys.push(key);\n this.circles.push(x);\n this.circles.push(y);\n this.circles.push(radius);\n};\nGridIndex.prototype._insertBoxCell = function _insertBoxCell(x1, y1, x2, y2, cellIndex, uid) {\n this.boxCells[cellIndex].push(uid);\n};\nGridIndex.prototype._insertCircleCell = function _insertCircleCell(x1, y1, x2, y2, cellIndex, uid) {\n this.circleCells[cellIndex].push(uid);\n};\nGridIndex.prototype._query = function _query(x1, y1, x2, y2, hitTest, predicate) {\n if (x2 < 0 || x1 > this.width || y2 < 0 || y1 > this.height) {\n return hitTest ? false : [];\n }\n var result = [];\n if (x1 <= 0 && y1 <= 0 && this.width <= x2 && this.height <= y2) {\n if (hitTest) {\n return true;\n }\n for (var boxUid = 0; boxUid < this.boxKeys.length; boxUid++) {\n result.push({\n key: this.boxKeys[boxUid],\n x1: this.bboxes[boxUid * 4],\n y1: this.bboxes[boxUid * 4 + 1],\n x2: this.bboxes[boxUid * 4 + 2],\n y2: this.bboxes[boxUid * 4 + 3]\n });\n }\n for (var circleUid = 0; circleUid < this.circleKeys.length; circleUid++) {\n var x = this.circles[circleUid * 3];\n var y = this.circles[circleUid * 3 + 1];\n var radius = this.circles[circleUid * 3 + 2];\n result.push({\n key: this.circleKeys[circleUid],\n x1: x - radius,\n y1: y - radius,\n x2: x + radius,\n y2: y + radius\n });\n }\n return predicate ? result.filter(predicate) : result;\n } else {\n var queryArgs = {\n hitTest: hitTest,\n seenUids: {\n box: {},\n circle: {}\n }\n };\n this._forEachCell(x1, y1, x2, y2, this._queryCell, result, queryArgs, predicate);\n return hitTest ? result.length > 0 : result;\n }\n};\nGridIndex.prototype._queryCircle = function _queryCircle(x, y, radius, hitTest, predicate) {\n var x1 = x - radius;\n var x2 = x + radius;\n var y1 = y - radius;\n var y2 = y + radius;\n if (x2 < 0 || x1 > this.width || y2 < 0 || y1 > this.height) {\n return hitTest ? false : [];\n }\n var result = [];\n var queryArgs = {\n hitTest: hitTest,\n circle: {\n x: x,\n y: y,\n radius: radius\n },\n seenUids: {\n box: {},\n circle: {}\n }\n };\n this._forEachCell(x1, y1, x2, y2, this._queryCellCircle, result, queryArgs, predicate);\n return hitTest ? result.length > 0 : result;\n};\nGridIndex.prototype.query = function query(x1, y1, x2, y2, predicate) {\n return this._query(x1, y1, x2, y2, false, predicate);\n};\nGridIndex.prototype.hitTest = function hitTest(x1, y1, x2, y2, predicate) {\n return this._query(x1, y1, x2, y2, true, predicate);\n};\nGridIndex.prototype.hitTestCircle = function hitTestCircle(x, y, radius, predicate) {\n return this._queryCircle(x, y, radius, true, predicate);\n};\nGridIndex.prototype._queryCell = function _queryCell(x1, y1, x2, y2, cellIndex, result, queryArgs, predicate) {\n var seenUids = queryArgs.seenUids;\n var boxCell = this.boxCells[cellIndex];\n if (boxCell !== null) {\n var bboxes = this.bboxes;\n for (var i = 0, list = boxCell; i < list.length; i += 1) {\n var boxUid = list[i];\n if (!seenUids.box[boxUid]) {\n seenUids.box[boxUid] = true;\n var offset = boxUid * 4;\n if (x1 <= bboxes[offset + 2] && y1 <= bboxes[offset + 3] && x2 >= bboxes[offset + 0] && y2 >= bboxes[offset + 1] && (!predicate || predicate(this.boxKeys[boxUid]))) {\n if (queryArgs.hitTest) {\n result.push(true);\n return true;\n } else {\n result.push({\n key: this.boxKeys[boxUid],\n x1: bboxes[offset],\n y1: bboxes[offset + 1],\n x2: bboxes[offset + 2],\n y2: bboxes[offset + 3]\n });\n }\n }\n }\n }\n }\n var circleCell = this.circleCells[cellIndex];\n if (circleCell !== null) {\n var circles = this.circles;\n for (var i$1 = 0, list$1 = circleCell; i$1 < list$1.length; i$1 += 1) {\n var circleUid = list$1[i$1];\n if (!seenUids.circle[circleUid]) {\n seenUids.circle[circleUid] = true;\n var offset$1 = circleUid * 3;\n if (this._circleAndRectCollide(circles[offset$1], circles[offset$1 + 1], circles[offset$1 + 2], x1, y1, x2, y2) && (!predicate || predicate(this.circleKeys[circleUid]))) {\n if (queryArgs.hitTest) {\n result.push(true);\n return true;\n } else {\n var x = circles[offset$1];\n var y = circles[offset$1 + 1];\n var radius = circles[offset$1 + 2];\n result.push({\n key: this.circleKeys[circleUid],\n x1: x - radius,\n y1: y - radius,\n x2: x + radius,\n y2: y + radius\n });\n }\n }\n }\n }\n }\n};\nGridIndex.prototype._queryCellCircle = function _queryCellCircle(x1, y1, x2, y2, cellIndex, result, queryArgs, predicate) {\n var circle = queryArgs.circle;\n var seenUids = queryArgs.seenUids;\n var boxCell = this.boxCells[cellIndex];\n if (boxCell !== null) {\n var bboxes = this.bboxes;\n for (var i = 0, list = boxCell; i < list.length; i += 1) {\n var boxUid = list[i];\n if (!seenUids.box[boxUid]) {\n seenUids.box[boxUid] = true;\n var offset = boxUid * 4;\n if (this._circleAndRectCollide(circle.x, circle.y, circle.radius, bboxes[offset + 0], bboxes[offset + 1], bboxes[offset + 2], bboxes[offset + 3]) && (!predicate || predicate(this.boxKeys[boxUid]))) {\n result.push(true);\n return true;\n }\n }\n }\n }\n var circleCell = this.circleCells[cellIndex];\n if (circleCell !== null) {\n var circles = this.circles;\n for (var i$1 = 0, list$1 = circleCell; i$1 < list$1.length; i$1 += 1) {\n var circleUid = list$1[i$1];\n if (!seenUids.circle[circleUid]) {\n seenUids.circle[circleUid] = true;\n var offset$1 = circleUid * 3;\n if (this._circlesCollide(circles[offset$1], circles[offset$1 + 1], circles[offset$1 + 2], circle.x, circle.y, circle.radius) && (!predicate || predicate(this.circleKeys[circleUid]))) {\n result.push(true);\n return true;\n }\n }\n }\n }\n};\nGridIndex.prototype._forEachCell = function _forEachCell(x1, y1, x2, y2, fn, arg1, arg2, predicate) {\n var cx1 = this._convertToXCellCoord(x1);\n var cy1 = this._convertToYCellCoord(y1);\n var cx2 = this._convertToXCellCoord(x2);\n var cy2 = this._convertToYCellCoord(y2);\n for (var x = cx1; x <= cx2; x++) {\n for (var y = cy1; y <= cy2; y++) {\n var cellIndex = this.xCellCount * y + x;\n if (fn.call(this, x1, y1, x2, y2, cellIndex, arg1, arg2, predicate)) {\n return;\n }\n }\n }\n};\nGridIndex.prototype._convertToXCellCoord = function _convertToXCellCoord(x) {\n return Math.max(0, Math.min(this.xCellCount - 1, Math.floor(x * this.xScale)));\n};\nGridIndex.prototype._convertToYCellCoord = function _convertToYCellCoord(y) {\n return Math.max(0, Math.min(this.yCellCount - 1, Math.floor(y * this.yScale)));\n};\nGridIndex.prototype._circlesCollide = function _circlesCollide(x1, y1, r1, x2, y2, r2) {\n var dx = x2 - x1;\n var dy = y2 - y1;\n var bothRadii = r1 + r2;\n return bothRadii * bothRadii > dx * dx + dy * dy;\n};\nGridIndex.prototype._circleAndRectCollide = function _circleAndRectCollide(circleX, circleY, radius, x1, y1, x2, y2) {\n var halfRectWidth = (x2 - x1) / 2;\n var distX = Math.abs(circleX - (x1 + halfRectWidth));\n if (distX > halfRectWidth + radius) {\n return false;\n }\n var halfRectHeight = (y2 - y1) / 2;\n var distY = Math.abs(circleY - (y1 + halfRectHeight));\n if (distY > halfRectHeight + radius) {\n return false;\n }\n if (distX <= halfRectWidth || distY <= halfRectHeight) {\n return true;\n }\n var dx = distX - halfRectWidth;\n var dy = distY - halfRectHeight;\n return dx * dx + dy * dy <= radius * radius;\n};\n\nfunction getLabelPlaneMatrix(posMatrix, pitchWithMap, rotateWithMap, transform, pixelsToTileUnits) {\n var m = performance.create();\n if (pitchWithMap) {\n performance.scale(m, m, [\n 1 / pixelsToTileUnits,\n 1 / pixelsToTileUnits,\n 1\n ]);\n if (!rotateWithMap) {\n performance.rotateZ(m, m, transform.angle);\n }\n } else {\n performance.multiply(m, transform.labelPlaneMatrix, posMatrix);\n }\n return m;\n}\nfunction getGlCoordMatrix(posMatrix, pitchWithMap, rotateWithMap, transform, pixelsToTileUnits) {\n if (pitchWithMap) {\n var m = performance.clone(posMatrix);\n performance.scale(m, m, [\n pixelsToTileUnits,\n pixelsToTileUnits,\n 1\n ]);\n if (!rotateWithMap) {\n performance.rotateZ(m, m, -transform.angle);\n }\n return m;\n } else {\n return transform.glCoordMatrix;\n }\n}\nfunction project(point, matrix) {\n var pos = [\n point.x,\n point.y,\n 0,\n 1\n ];\n xyTransformMat4(pos, pos, matrix);\n var w = pos[3];\n return {\n point: new performance.Point(pos[0] / w, pos[1] / w),\n signedDistanceFromCamera: w\n };\n}\nfunction getPerspectiveRatio(cameraToCenterDistance, signedDistanceFromCamera) {\n return 0.5 + 0.5 * (cameraToCenterDistance / signedDistanceFromCamera);\n}\nfunction isVisible(anchorPos, clippingBuffer) {\n var x = anchorPos[0] / anchorPos[3];\n var y = anchorPos[1] / anchorPos[3];\n var inPaddedViewport = x >= -clippingBuffer[0] && x <= clippingBuffer[0] && y >= -clippingBuffer[1] && y <= clippingBuffer[1];\n return inPaddedViewport;\n}\nfunction updateLineLabels(bucket, posMatrix, painter, isText, labelPlaneMatrix, glCoordMatrix, pitchWithMap, keepUpright) {\n var sizeData = isText ? bucket.textSizeData : bucket.iconSizeData;\n var partiallyEvaluatedSize = performance.evaluateSizeForZoom(sizeData, painter.transform.zoom);\n var clippingBuffer = [\n 256 / painter.width * 2 + 1,\n 256 / painter.height * 2 + 1\n ];\n var dynamicLayoutVertexArray = isText ? bucket.text.dynamicLayoutVertexArray : bucket.icon.dynamicLayoutVertexArray;\n dynamicLayoutVertexArray.clear();\n var lineVertexArray = bucket.lineVertexArray;\n var placedSymbols = isText ? bucket.text.placedSymbolArray : bucket.icon.placedSymbolArray;\n var aspectRatio = painter.transform.width / painter.transform.height;\n var useVertical = false;\n for (var s = 0; s < placedSymbols.length; s++) {\n var symbol = placedSymbols.get(s);\n if (symbol.hidden || symbol.writingMode === performance.WritingMode.vertical && !useVertical) {\n hideGlyphs(symbol.numGlyphs, dynamicLayoutVertexArray);\n continue;\n }\n useVertical = false;\n var anchorPos = [\n symbol.anchorX,\n symbol.anchorY,\n 0,\n 1\n ];\n performance.transformMat4(anchorPos, anchorPos, posMatrix);\n if (!isVisible(anchorPos, clippingBuffer)) {\n hideGlyphs(symbol.numGlyphs, dynamicLayoutVertexArray);\n continue;\n }\n var cameraToAnchorDistance = anchorPos[3];\n var perspectiveRatio = getPerspectiveRatio(painter.transform.cameraToCenterDistance, cameraToAnchorDistance);\n var fontSize = performance.evaluateSizeForFeature(sizeData, partiallyEvaluatedSize, symbol);\n var pitchScaledFontSize = pitchWithMap ? fontSize / perspectiveRatio : fontSize * perspectiveRatio;\n var tileAnchorPoint = new performance.Point(symbol.anchorX, symbol.anchorY);\n var anchorPoint = project(tileAnchorPoint, labelPlaneMatrix).point;\n var projectionCache = {};\n var placeUnflipped = placeGlyphsAlongLine(symbol, pitchScaledFontSize, false, keepUpright, posMatrix, labelPlaneMatrix, glCoordMatrix, bucket.glyphOffsetArray, lineVertexArray, dynamicLayoutVertexArray, anchorPoint, tileAnchorPoint, projectionCache, aspectRatio);\n useVertical = placeUnflipped.useVertical;\n if (placeUnflipped.notEnoughRoom || useVertical || placeUnflipped.needsFlipping && placeGlyphsAlongLine(symbol, pitchScaledFontSize, true, keepUpright, posMatrix, labelPlaneMatrix, glCoordMatrix, bucket.glyphOffsetArray, lineVertexArray, dynamicLayoutVertexArray, anchorPoint, tileAnchorPoint, projectionCache, aspectRatio).notEnoughRoom) {\n hideGlyphs(symbol.numGlyphs, dynamicLayoutVertexArray);\n }\n }\n if (isText) {\n bucket.text.dynamicLayoutVertexBuffer.updateData(dynamicLayoutVertexArray);\n } else {\n bucket.icon.dynamicLayoutVertexBuffer.updateData(dynamicLayoutVertexArray);\n }\n}\nfunction placeFirstAndLastGlyph(fontScale, glyphOffsetArray, lineOffsetX, lineOffsetY, flip, anchorPoint, tileAnchorPoint, symbol, lineVertexArray, labelPlaneMatrix, projectionCache) {\n var glyphEndIndex = symbol.glyphStartIndex + symbol.numGlyphs;\n var lineStartIndex = symbol.lineStartIndex;\n var lineEndIndex = symbol.lineStartIndex + symbol.lineLength;\n var firstGlyphOffset = glyphOffsetArray.getoffsetX(symbol.glyphStartIndex);\n var lastGlyphOffset = glyphOffsetArray.getoffsetX(glyphEndIndex - 1);\n var firstPlacedGlyph = placeGlyphAlongLine(fontScale * firstGlyphOffset, lineOffsetX, lineOffsetY, flip, anchorPoint, tileAnchorPoint, symbol.segment, lineStartIndex, lineEndIndex, lineVertexArray, labelPlaneMatrix, projectionCache);\n if (!firstPlacedGlyph) {\n return null;\n }\n var lastPlacedGlyph = placeGlyphAlongLine(fontScale * lastGlyphOffset, lineOffsetX, lineOffsetY, flip, anchorPoint, tileAnchorPoint, symbol.segment, lineStartIndex, lineEndIndex, lineVertexArray, labelPlaneMatrix, projectionCache);\n if (!lastPlacedGlyph) {\n return null;\n }\n return {\n first: firstPlacedGlyph,\n last: lastPlacedGlyph\n };\n}\nfunction requiresOrientationChange(writingMode, firstPoint, lastPoint, aspectRatio) {\n if (writingMode === performance.WritingMode.horizontal) {\n var rise = Math.abs(lastPoint.y - firstPoint.y);\n var run = Math.abs(lastPoint.x - firstPoint.x) * aspectRatio;\n if (rise > run) {\n return { useVertical: true };\n }\n }\n if (writingMode === performance.WritingMode.vertical ? firstPoint.y < lastPoint.y : firstPoint.x > lastPoint.x) {\n return { needsFlipping: true };\n }\n return null;\n}\nfunction placeGlyphsAlongLine(symbol, fontSize, flip, keepUpright, posMatrix, labelPlaneMatrix, glCoordMatrix, glyphOffsetArray, lineVertexArray, dynamicLayoutVertexArray, anchorPoint, tileAnchorPoint, projectionCache, aspectRatio) {\n var fontScale = fontSize / 24;\n var lineOffsetX = symbol.lineOffsetX * fontScale;\n var lineOffsetY = symbol.lineOffsetY * fontScale;\n var placedGlyphs;\n if (symbol.numGlyphs > 1) {\n var glyphEndIndex = symbol.glyphStartIndex + symbol.numGlyphs;\n var lineStartIndex = symbol.lineStartIndex;\n var lineEndIndex = symbol.lineStartIndex + symbol.lineLength;\n var firstAndLastGlyph = placeFirstAndLastGlyph(fontScale, glyphOffsetArray, lineOffsetX, lineOffsetY, flip, anchorPoint, tileAnchorPoint, symbol, lineVertexArray, labelPlaneMatrix, projectionCache);\n if (!firstAndLastGlyph) {\n return { notEnoughRoom: true };\n }\n var firstPoint = project(firstAndLastGlyph.first.point, glCoordMatrix).point;\n var lastPoint = project(firstAndLastGlyph.last.point, glCoordMatrix).point;\n if (keepUpright && !flip) {\n var orientationChange = requiresOrientationChange(symbol.writingMode, firstPoint, lastPoint, aspectRatio);\n if (orientationChange) {\n return orientationChange;\n }\n }\n placedGlyphs = [firstAndLastGlyph.first];\n for (var glyphIndex = symbol.glyphStartIndex + 1; glyphIndex < glyphEndIndex - 1; glyphIndex++) {\n placedGlyphs.push(placeGlyphAlongLine(fontScale * glyphOffsetArray.getoffsetX(glyphIndex), lineOffsetX, lineOffsetY, flip, anchorPoint, tileAnchorPoint, symbol.segment, lineStartIndex, lineEndIndex, lineVertexArray, labelPlaneMatrix, projectionCache));\n }\n placedGlyphs.push(firstAndLastGlyph.last);\n } else {\n if (keepUpright && !flip) {\n var a = project(tileAnchorPoint, posMatrix).point;\n var tileVertexIndex = symbol.lineStartIndex + symbol.segment + 1;\n var tileSegmentEnd = new performance.Point(lineVertexArray.getx(tileVertexIndex), lineVertexArray.gety(tileVertexIndex));\n var projectedVertex = project(tileSegmentEnd, posMatrix);\n var b = projectedVertex.signedDistanceFromCamera > 0 ? projectedVertex.point : projectTruncatedLineSegment(tileAnchorPoint, tileSegmentEnd, a, 1, posMatrix);\n var orientationChange$1 = requiresOrientationChange(symbol.writingMode, a, b, aspectRatio);\n if (orientationChange$1) {\n return orientationChange$1;\n }\n }\n var singleGlyph = placeGlyphAlongLine(fontScale * glyphOffsetArray.getoffsetX(symbol.glyphStartIndex), lineOffsetX, lineOffsetY, flip, anchorPoint, tileAnchorPoint, symbol.segment, symbol.lineStartIndex, symbol.lineStartIndex + symbol.lineLength, lineVertexArray, labelPlaneMatrix, projectionCache);\n if (!singleGlyph) {\n return { notEnoughRoom: true };\n }\n placedGlyphs = [singleGlyph];\n }\n for (var i = 0, list = placedGlyphs; i < list.length; i += 1) {\n var glyph = list[i];\n performance.addDynamicAttributes(dynamicLayoutVertexArray, glyph.point, glyph.angle);\n }\n return {};\n}\nfunction projectTruncatedLineSegment(previousTilePoint, currentTilePoint, previousProjectedPoint, minimumLength, projectionMatrix) {\n var projectedUnitVertex = project(previousTilePoint.add(previousTilePoint.sub(currentTilePoint)._unit()), projectionMatrix).point;\n var projectedUnitSegment = previousProjectedPoint.sub(projectedUnitVertex);\n return previousProjectedPoint.add(projectedUnitSegment._mult(minimumLength / projectedUnitSegment.mag()));\n}\nfunction placeGlyphAlongLine(offsetX, lineOffsetX, lineOffsetY, flip, anchorPoint, tileAnchorPoint, anchorSegment, lineStartIndex, lineEndIndex, lineVertexArray, labelPlaneMatrix, projectionCache) {\n var combinedOffsetX = flip ? offsetX - lineOffsetX : offsetX + lineOffsetX;\n var dir = combinedOffsetX > 0 ? 1 : -1;\n var angle = 0;\n if (flip) {\n dir *= -1;\n angle = Math.PI;\n }\n if (dir < 0) {\n angle += Math.PI;\n }\n var currentIndex = dir > 0 ? lineStartIndex + anchorSegment : lineStartIndex + anchorSegment + 1;\n var current = anchorPoint;\n var prev = anchorPoint;\n var distanceToPrev = 0;\n var currentSegmentDistance = 0;\n var absOffsetX = Math.abs(combinedOffsetX);\n var pathVertices = [];\n while (distanceToPrev + currentSegmentDistance <= absOffsetX) {\n currentIndex += dir;\n if (currentIndex < lineStartIndex || currentIndex >= lineEndIndex) {\n return null;\n }\n prev = current;\n pathVertices.push(current);\n current = projectionCache[currentIndex];\n if (current === undefined) {\n var currentVertex = new performance.Point(lineVertexArray.getx(currentIndex), lineVertexArray.gety(currentIndex));\n var projection = project(currentVertex, labelPlaneMatrix);\n if (projection.signedDistanceFromCamera > 0) {\n current = projectionCache[currentIndex] = projection.point;\n } else {\n var previousLineVertexIndex = currentIndex - dir;\n var previousTilePoint = distanceToPrev === 0 ? tileAnchorPoint : new performance.Point(lineVertexArray.getx(previousLineVertexIndex), lineVertexArray.gety(previousLineVertexIndex));\n current = projectTruncatedLineSegment(previousTilePoint, currentVertex, prev, absOffsetX - distanceToPrev + 1, labelPlaneMatrix);\n }\n }\n distanceToPrev += currentSegmentDistance;\n currentSegmentDistance = prev.dist(current);\n }\n var segmentInterpolationT = (absOffsetX - distanceToPrev) / currentSegmentDistance;\n var prevToCurrent = current.sub(prev);\n var p = prevToCurrent.mult(segmentInterpolationT)._add(prev);\n p._add(prevToCurrent._unit()._perp()._mult(lineOffsetY * dir));\n var segmentAngle = angle + Math.atan2(current.y - prev.y, current.x - prev.x);\n pathVertices.push(p);\n return {\n point: p,\n angle: segmentAngle,\n path: pathVertices\n };\n}\nvar hiddenGlyphAttributes = new Float32Array([\n -Infinity,\n -Infinity,\n 0,\n -Infinity,\n -Infinity,\n 0,\n -Infinity,\n -Infinity,\n 0,\n -Infinity,\n -Infinity,\n 0\n]);\nfunction hideGlyphs(num, dynamicLayoutVertexArray) {\n for (var i = 0; i < num; i++) {\n var offset = dynamicLayoutVertexArray.length;\n dynamicLayoutVertexArray.resize(offset + 4);\n dynamicLayoutVertexArray.float32.set(hiddenGlyphAttributes, offset * 3);\n }\n}\nfunction xyTransformMat4(out, a, m) {\n var x = a[0], y = a[1];\n out[0] = m[0] * x + m[4] * y + m[12];\n out[1] = m[1] * x + m[5] * y + m[13];\n out[3] = m[3] * x + m[7] * y + m[15];\n return out;\n}\n\nvar viewportPadding = 100;\nvar CollisionIndex = function CollisionIndex(transform, grid, ignoredGrid) {\n if (grid === void 0)\n grid = new GridIndex(transform.width + 2 * viewportPadding, transform.height + 2 * viewportPadding, 25);\n if (ignoredGrid === void 0)\n ignoredGrid = new GridIndex(transform.width + 2 * viewportPadding, transform.height + 2 * viewportPadding, 25);\n this.transform = transform;\n this.grid = grid;\n this.ignoredGrid = ignoredGrid;\n this.pitchfactor = Math.cos(transform._pitch) * transform.cameraToCenterDistance;\n this.screenRightBoundary = transform.width + viewportPadding;\n this.screenBottomBoundary = transform.height + viewportPadding;\n this.gridRightBoundary = transform.width + 2 * viewportPadding;\n this.gridBottomBoundary = transform.height + 2 * viewportPadding;\n};\nCollisionIndex.prototype.placeCollisionBox = function placeCollisionBox(collisionBox, allowOverlap, textPixelRatio, posMatrix, collisionGroupPredicate) {\n var projectedPoint = this.projectAndGetPerspectiveRatio(posMatrix, collisionBox.anchorPointX, collisionBox.anchorPointY);\n var tileToViewport = textPixelRatio * projectedPoint.perspectiveRatio;\n var tlX = collisionBox.x1 * tileToViewport + projectedPoint.point.x;\n var tlY = collisionBox.y1 * tileToViewport + projectedPoint.point.y;\n var brX = collisionBox.x2 * tileToViewport + projectedPoint.point.x;\n var brY = collisionBox.y2 * tileToViewport + projectedPoint.point.y;\n if (!this.isInsideGrid(tlX, tlY, brX, brY) || !allowOverlap && this.grid.hitTest(tlX, tlY, brX, brY, collisionGroupPredicate)) {\n return {\n box: [],\n offscreen: false\n };\n }\n return {\n box: [\n tlX,\n tlY,\n brX,\n brY\n ],\n offscreen: this.isOffscreen(tlX, tlY, brX, brY)\n };\n};\nCollisionIndex.prototype.placeCollisionCircles = function placeCollisionCircles(allowOverlap, symbol, lineVertexArray, glyphOffsetArray, fontSize, posMatrix, labelPlaneMatrix, labelToScreenMatrix, showCollisionCircles, pitchWithMap, collisionGroupPredicate, circlePixelDiameter, textPixelPadding) {\n var placedCollisionCircles = [];\n var tileUnitAnchorPoint = new performance.Point(symbol.anchorX, symbol.anchorY);\n var screenAnchorPoint = project(tileUnitAnchorPoint, posMatrix);\n var perspectiveRatio = getPerspectiveRatio(this.transform.cameraToCenterDistance, screenAnchorPoint.signedDistanceFromCamera);\n var labelPlaneFontSize = pitchWithMap ? fontSize / perspectiveRatio : fontSize * perspectiveRatio;\n var labelPlaneFontScale = labelPlaneFontSize / performance.ONE_EM;\n var labelPlaneAnchorPoint = project(tileUnitAnchorPoint, labelPlaneMatrix).point;\n var projectionCache = {};\n var lineOffsetX = symbol.lineOffsetX * labelPlaneFontScale;\n var lineOffsetY = symbol.lineOffsetY * labelPlaneFontScale;\n var firstAndLastGlyph = placeFirstAndLastGlyph(labelPlaneFontScale, glyphOffsetArray, lineOffsetX, lineOffsetY, false, labelPlaneAnchorPoint, tileUnitAnchorPoint, symbol, lineVertexArray, labelPlaneMatrix, projectionCache);\n var collisionDetected = false;\n var inGrid = false;\n var entirelyOffscreen = true;\n if (firstAndLastGlyph) {\n var radius = circlePixelDiameter * 0.5 * perspectiveRatio + textPixelPadding;\n var screenPlaneMin = new performance.Point(-viewportPadding, -viewportPadding);\n var screenPlaneMax = new performance.Point(this.screenRightBoundary, this.screenBottomBoundary);\n var interpolator = new PathInterpolator();\n var first = firstAndLastGlyph.first;\n var last = firstAndLastGlyph.last;\n var projectedPath = [];\n for (var i = first.path.length - 1; i >= 1; i--) {\n projectedPath.push(first.path[i]);\n }\n for (var i$1 = 1; i$1 < last.path.length; i$1++) {\n projectedPath.push(last.path[i$1]);\n }\n var circleDist = radius * 2.5;\n if (labelToScreenMatrix) {\n var screenSpacePath = projectedPath.map(function (p) {\n return project(p, labelToScreenMatrix);\n });\n if (screenSpacePath.some(function (point) {\n return point.signedDistanceFromCamera <= 0;\n })) {\n projectedPath = [];\n } else {\n projectedPath = screenSpacePath.map(function (p) {\n return p.point;\n });\n }\n }\n var segments = [];\n if (projectedPath.length > 0) {\n var minPoint = projectedPath[0].clone();\n var maxPoint = projectedPath[0].clone();\n for (var i$2 = 1; i$2 < projectedPath.length; i$2++) {\n minPoint.x = Math.min(minPoint.x, projectedPath[i$2].x);\n minPoint.y = Math.min(minPoint.y, projectedPath[i$2].y);\n maxPoint.x = Math.max(maxPoint.x, projectedPath[i$2].x);\n maxPoint.y = Math.max(maxPoint.y, projectedPath[i$2].y);\n }\n if (minPoint.x >= screenPlaneMin.x && maxPoint.x <= screenPlaneMax.x && minPoint.y >= screenPlaneMin.y && maxPoint.y <= screenPlaneMax.y) {\n segments = [projectedPath];\n } else if (maxPoint.x < screenPlaneMin.x || minPoint.x > screenPlaneMax.x || maxPoint.y < screenPlaneMin.y || minPoint.y > screenPlaneMax.y) {\n segments = [];\n } else {\n segments = performance.clipLine([projectedPath], screenPlaneMin.x, screenPlaneMin.y, screenPlaneMax.x, screenPlaneMax.y);\n }\n }\n for (var i$4 = 0, list = segments; i$4 < list.length; i$4 += 1) {\n var seg = list[i$4];\n interpolator.reset(seg, radius * 0.25);\n var numCircles = 0;\n if (interpolator.length <= 0.5 * radius) {\n numCircles = 1;\n } else {\n numCircles = Math.ceil(interpolator.paddedLength / circleDist) + 1;\n }\n for (var i$3 = 0; i$3 < numCircles; i$3++) {\n var t = i$3 / Math.max(numCircles - 1, 1);\n var circlePosition = interpolator.lerp(t);\n var centerX = circlePosition.x + viewportPadding;\n var centerY = circlePosition.y + viewportPadding;\n placedCollisionCircles.push(centerX, centerY, radius, 0);\n var x1 = centerX - radius;\n var y1 = centerY - radius;\n var x2 = centerX + radius;\n var y2 = centerY + radius;\n entirelyOffscreen = entirelyOffscreen && this.isOffscreen(x1, y1, x2, y2);\n inGrid = inGrid || this.isInsideGrid(x1, y1, x2, y2);\n if (!allowOverlap) {\n if (this.grid.hitTestCircle(centerX, centerY, radius, collisionGroupPredicate)) {\n collisionDetected = true;\n if (!showCollisionCircles) {\n return {\n circles: [],\n offscreen: false,\n collisionDetected: collisionDetected\n };\n }\n }\n }\n }\n }\n }\n return {\n circles: !showCollisionCircles && collisionDetected || !inGrid ? [] : placedCollisionCircles,\n offscreen: entirelyOffscreen,\n collisionDetected: collisionDetected\n };\n};\nCollisionIndex.prototype.queryRenderedSymbols = function queryRenderedSymbols(viewportQueryGeometry) {\n if (viewportQueryGeometry.length === 0 || this.grid.keysLength() === 0 && this.ignoredGrid.keysLength() === 0) {\n return {};\n }\n var query = [];\n var minX = Infinity;\n var minY = Infinity;\n var maxX = -Infinity;\n var maxY = -Infinity;\n for (var i = 0, list = viewportQueryGeometry; i < list.length; i += 1) {\n var point = list[i];\n var gridPoint = new performance.Point(point.x + viewportPadding, point.y + viewportPadding);\n minX = Math.min(minX, gridPoint.x);\n minY = Math.min(minY, gridPoint.y);\n maxX = Math.max(maxX, gridPoint.x);\n maxY = Math.max(maxY, gridPoint.y);\n query.push(gridPoint);\n }\n var features = this.grid.query(minX, minY, maxX, maxY).concat(this.ignoredGrid.query(minX, minY, maxX, maxY));\n var seenFeatures = {};\n var result = {};\n for (var i$1 = 0, list$1 = features; i$1 < list$1.length; i$1 += 1) {\n var feature = list$1[i$1];\n var featureKey = feature.key;\n if (seenFeatures[featureKey.bucketInstanceId] === undefined) {\n seenFeatures[featureKey.bucketInstanceId] = {};\n }\n if (seenFeatures[featureKey.bucketInstanceId][featureKey.featureIndex]) {\n continue;\n }\n var bbox = [\n new performance.Point(feature.x1, feature.y1),\n new performance.Point(feature.x2, feature.y1),\n new performance.Point(feature.x2, feature.y2),\n new performance.Point(feature.x1, feature.y2)\n ];\n if (!performance.polygonIntersectsPolygon(query, bbox)) {\n continue;\n }\n seenFeatures[featureKey.bucketInstanceId][featureKey.featureIndex] = true;\n if (result[featureKey.bucketInstanceId] === undefined) {\n result[featureKey.bucketInstanceId] = [];\n }\n result[featureKey.bucketInstanceId].push(featureKey.featureIndex);\n }\n return result;\n};\nCollisionIndex.prototype.insertCollisionBox = function insertCollisionBox(collisionBox, ignorePlacement, bucketInstanceId, featureIndex, collisionGroupID) {\n var grid = ignorePlacement ? this.ignoredGrid : this.grid;\n var key = {\n bucketInstanceId: bucketInstanceId,\n featureIndex: featureIndex,\n collisionGroupID: collisionGroupID\n };\n grid.insert(key, collisionBox[0], collisionBox[1], collisionBox[2], collisionBox[3]);\n};\nCollisionIndex.prototype.insertCollisionCircles = function insertCollisionCircles(collisionCircles, ignorePlacement, bucketInstanceId, featureIndex, collisionGroupID) {\n var grid = ignorePlacement ? this.ignoredGrid : this.grid;\n var key = {\n bucketInstanceId: bucketInstanceId,\n featureIndex: featureIndex,\n collisionGroupID: collisionGroupID\n };\n for (var k = 0; k < collisionCircles.length; k += 4) {\n grid.insertCircle(key, collisionCircles[k], collisionCircles[k + 1], collisionCircles[k + 2]);\n }\n};\nCollisionIndex.prototype.projectAndGetPerspectiveRatio = function projectAndGetPerspectiveRatio(posMatrix, x, y) {\n var p = [\n x,\n y,\n 0,\n 1\n ];\n xyTransformMat4(p, p, posMatrix);\n var a = new performance.Point((p[0] / p[3] + 1) / 2 * this.transform.width + viewportPadding, (-p[1] / p[3] + 1) / 2 * this.transform.height + viewportPadding);\n return {\n point: a,\n perspectiveRatio: 0.5 + 0.5 * (this.transform.cameraToCenterDistance / p[3])\n };\n};\nCollisionIndex.prototype.isOffscreen = function isOffscreen(x1, y1, x2, y2) {\n return x2 < viewportPadding || x1 >= this.screenRightBoundary || y2 < viewportPadding || y1 > this.screenBottomBoundary;\n};\nCollisionIndex.prototype.isInsideGrid = function isInsideGrid(x1, y1, x2, y2) {\n return x2 >= 0 && x1 < this.gridRightBoundary && y2 >= 0 && y1 < this.gridBottomBoundary;\n};\nCollisionIndex.prototype.getViewportMatrix = function getViewportMatrix() {\n var m = performance.identity([]);\n performance.translate(m, m, [\n -viewportPadding,\n -viewportPadding,\n 0\n ]);\n return m;\n};\n\nfunction pixelsToTileUnits (tile, pixelValue, z) {\n return pixelValue * (performance.EXTENT / (tile.tileSize * Math.pow(2, z - tile.tileID.overscaledZ)));\n}\n\nvar OpacityState = function OpacityState(prevState, increment, placed, skipFade) {\n if (prevState) {\n this.opacity = Math.max(0, Math.min(1, prevState.opacity + (prevState.placed ? increment : -increment)));\n } else {\n this.opacity = skipFade && placed ? 1 : 0;\n }\n this.placed = placed;\n};\nOpacityState.prototype.isHidden = function isHidden() {\n return this.opacity === 0 && !this.placed;\n};\nvar JointOpacityState = function JointOpacityState(prevState, increment, placedText, placedIcon, skipFade) {\n this.text = new OpacityState(prevState ? prevState.text : null, increment, placedText, skipFade);\n this.icon = new OpacityState(prevState ? prevState.icon : null, increment, placedIcon, skipFade);\n};\nJointOpacityState.prototype.isHidden = function isHidden() {\n return this.text.isHidden() && this.icon.isHidden();\n};\nvar JointPlacement = function JointPlacement(text, icon, skipFade) {\n this.text = text;\n this.icon = icon;\n this.skipFade = skipFade;\n};\nvar CollisionCircleArray = function CollisionCircleArray() {\n this.invProjMatrix = performance.create();\n this.viewportMatrix = performance.create();\n this.circles = [];\n};\nvar RetainedQueryData = function RetainedQueryData(bucketInstanceId, featureIndex, sourceLayerIndex, bucketIndex, tileID) {\n this.bucketInstanceId = bucketInstanceId;\n this.featureIndex = featureIndex;\n this.sourceLayerIndex = sourceLayerIndex;\n this.bucketIndex = bucketIndex;\n this.tileID = tileID;\n};\nvar CollisionGroups = function CollisionGroups(crossSourceCollisions) {\n this.crossSourceCollisions = crossSourceCollisions;\n this.maxGroupID = 0;\n this.collisionGroups = {};\n};\nCollisionGroups.prototype.get = function get(sourceID) {\n if (!this.crossSourceCollisions) {\n if (!this.collisionGroups[sourceID]) {\n var nextGroupID = ++this.maxGroupID;\n this.collisionGroups[sourceID] = {\n ID: nextGroupID,\n predicate: function (key) {\n return key.collisionGroupID === nextGroupID;\n }\n };\n }\n return this.collisionGroups[sourceID];\n } else {\n return {\n ID: 0,\n predicate: null\n };\n }\n};\nfunction calculateVariableLayoutShift(anchor, width, height, textOffset, textBoxScale) {\n var ref = performance.getAnchorAlignment(anchor);\n var horizontalAlign = ref.horizontalAlign;\n var verticalAlign = ref.verticalAlign;\n var shiftX = -(horizontalAlign - 0.5) * width;\n var shiftY = -(verticalAlign - 0.5) * height;\n var offset = performance.evaluateVariableOffset(anchor, textOffset);\n return new performance.Point(shiftX + offset[0] * textBoxScale, shiftY + offset[1] * textBoxScale);\n}\nfunction shiftVariableCollisionBox(collisionBox, shiftX, shiftY, rotateWithMap, pitchWithMap, angle) {\n var x1 = collisionBox.x1;\n var x2 = collisionBox.x2;\n var y1 = collisionBox.y1;\n var y2 = collisionBox.y2;\n var anchorPointX = collisionBox.anchorPointX;\n var anchorPointY = collisionBox.anchorPointY;\n var rotatedOffset = new performance.Point(shiftX, shiftY);\n if (rotateWithMap) {\n rotatedOffset._rotate(pitchWithMap ? angle : -angle);\n }\n return {\n x1: x1 + rotatedOffset.x,\n y1: y1 + rotatedOffset.y,\n x2: x2 + rotatedOffset.x,\n y2: y2 + rotatedOffset.y,\n anchorPointX: anchorPointX,\n anchorPointY: anchorPointY\n };\n}\nvar Placement = function Placement(transform, fadeDuration, crossSourceCollisions, prevPlacement) {\n this.transform = transform.clone();\n this.collisionIndex = new CollisionIndex(this.transform);\n this.placements = {};\n this.opacities = {};\n this.variableOffsets = {};\n this.stale = false;\n this.commitTime = 0;\n this.fadeDuration = fadeDuration;\n this.retainedQueryData = {};\n this.collisionGroups = new CollisionGroups(crossSourceCollisions);\n this.collisionCircleArrays = {};\n this.prevPlacement = prevPlacement;\n if (prevPlacement) {\n prevPlacement.prevPlacement = undefined;\n }\n this.placedOrientations = {};\n};\nPlacement.prototype.getBucketParts = function getBucketParts(results, styleLayer, tile, sortAcrossTiles) {\n var symbolBucket = tile.getBucket(styleLayer);\n var bucketFeatureIndex = tile.latestFeatureIndex;\n if (!symbolBucket || !bucketFeatureIndex || styleLayer.id !== symbolBucket.layerIds[0]) {\n return;\n }\n var collisionBoxArray = tile.collisionBoxArray;\n var layout = symbolBucket.layers[0].layout;\n var scale = Math.pow(2, this.transform.zoom - tile.tileID.overscaledZ);\n var textPixelRatio = tile.tileSize / performance.EXTENT;\n var posMatrix = this.transform.calculatePosMatrix(tile.tileID.toUnwrapped());\n var pitchWithMap = layout.get('text-pitch-alignment') === 'map';\n var rotateWithMap = layout.get('text-rotation-alignment') === 'map';\n var pixelsToTiles = pixelsToTileUnits(tile, 1, this.transform.zoom);\n var textLabelPlaneMatrix = getLabelPlaneMatrix(posMatrix, pitchWithMap, rotateWithMap, this.transform, pixelsToTiles);\n var labelToScreenMatrix = null;\n if (pitchWithMap) {\n var glMatrix = getGlCoordMatrix(posMatrix, pitchWithMap, rotateWithMap, this.transform, pixelsToTiles);\n labelToScreenMatrix = performance.multiply([], this.transform.labelPlaneMatrix, glMatrix);\n }\n this.retainedQueryData[symbolBucket.bucketInstanceId] = new RetainedQueryData(symbolBucket.bucketInstanceId, bucketFeatureIndex, symbolBucket.sourceLayerIndex, symbolBucket.index, tile.tileID);\n var parameters = {\n bucket: symbolBucket,\n layout: layout,\n posMatrix: posMatrix,\n textLabelPlaneMatrix: textLabelPlaneMatrix,\n labelToScreenMatrix: labelToScreenMatrix,\n scale: scale,\n textPixelRatio: textPixelRatio,\n holdingForFade: tile.holdingForFade(),\n collisionBoxArray: collisionBoxArray,\n partiallyEvaluatedTextSize: performance.evaluateSizeForZoom(symbolBucket.textSizeData, this.transform.zoom),\n collisionGroup: this.collisionGroups.get(symbolBucket.sourceID)\n };\n if (sortAcrossTiles) {\n for (var i = 0, list = symbolBucket.sortKeyRanges; i < list.length; i += 1) {\n var range = list[i];\n var sortKey = range.sortKey;\n var symbolInstanceStart = range.symbolInstanceStart;\n var symbolInstanceEnd = range.symbolInstanceEnd;\n results.push({\n sortKey: sortKey,\n symbolInstanceStart: symbolInstanceStart,\n symbolInstanceEnd: symbolInstanceEnd,\n parameters: parameters\n });\n }\n } else {\n results.push({\n symbolInstanceStart: 0,\n symbolInstanceEnd: symbolBucket.symbolInstances.length,\n parameters: parameters\n });\n }\n};\nPlacement.prototype.attemptAnchorPlacement = function attemptAnchorPlacement(anchor, textBox, width, height, textBoxScale, rotateWithMap, pitchWithMap, textPixelRatio, posMatrix, collisionGroup, textAllowOverlap, symbolInstance, bucket, orientation, iconBox) {\n var textOffset = [\n symbolInstance.textOffset0,\n symbolInstance.textOffset1\n ];\n var shift = calculateVariableLayoutShift(anchor, width, height, textOffset, textBoxScale);\n var placedGlyphBoxes = this.collisionIndex.placeCollisionBox(shiftVariableCollisionBox(textBox, shift.x, shift.y, rotateWithMap, pitchWithMap, this.transform.angle), textAllowOverlap, textPixelRatio, posMatrix, collisionGroup.predicate);\n if (iconBox) {\n var placedIconBoxes = this.collisionIndex.placeCollisionBox(shiftVariableCollisionBox(iconBox, shift.x, shift.y, rotateWithMap, pitchWithMap, this.transform.angle), textAllowOverlap, textPixelRatio, posMatrix, collisionGroup.predicate);\n if (placedIconBoxes.box.length === 0) {\n return;\n }\n }\n if (placedGlyphBoxes.box.length > 0) {\n var prevAnchor;\n if (this.prevPlacement && this.prevPlacement.variableOffsets[symbolInstance.crossTileID] && this.prevPlacement.placements[symbolInstance.crossTileID] && this.prevPlacement.placements[symbolInstance.crossTileID].text) {\n prevAnchor = this.prevPlacement.variableOffsets[symbolInstance.crossTileID].anchor;\n }\n this.variableOffsets[symbolInstance.crossTileID] = {\n textOffset: textOffset,\n width: width,\n height: height,\n anchor: anchor,\n textBoxScale: textBoxScale,\n prevAnchor: prevAnchor\n };\n this.markUsedJustification(bucket, anchor, symbolInstance, orientation);\n if (bucket.allowVerticalPlacement) {\n this.markUsedOrientation(bucket, orientation, symbolInstance);\n this.placedOrientations[symbolInstance.crossTileID] = orientation;\n }\n return {\n shift: shift,\n placedGlyphBoxes: placedGlyphBoxes\n };\n }\n};\nPlacement.prototype.placeLayerBucketPart = function placeLayerBucketPart(bucketPart, seenCrossTileIDs, showCollisionBoxes) {\n var this$1 = this;\n var ref = bucketPart.parameters;\n var bucket = ref.bucket;\n var layout = ref.layout;\n var posMatrix = ref.posMatrix;\n var textLabelPlaneMatrix = ref.textLabelPlaneMatrix;\n var labelToScreenMatrix = ref.labelToScreenMatrix;\n var textPixelRatio = ref.textPixelRatio;\n var holdingForFade = ref.holdingForFade;\n var collisionBoxArray = ref.collisionBoxArray;\n var partiallyEvaluatedTextSize = ref.partiallyEvaluatedTextSize;\n var collisionGroup = ref.collisionGroup;\n var textOptional = layout.get('text-optional');\n var iconOptional = layout.get('icon-optional');\n var textAllowOverlap = layout.get('text-allow-overlap');\n var iconAllowOverlap = layout.get('icon-allow-overlap');\n var rotateWithMap = layout.get('text-rotation-alignment') === 'map';\n var pitchWithMap = layout.get('text-pitch-alignment') === 'map';\n var hasIconTextFit = layout.get('icon-text-fit') !== 'none';\n var zOrderByViewportY = layout.get('symbol-z-order') === 'viewport-y';\n var alwaysShowText = textAllowOverlap && (iconAllowOverlap || !bucket.hasIconData() || iconOptional);\n var alwaysShowIcon = iconAllowOverlap && (textAllowOverlap || !bucket.hasTextData() || textOptional);\n if (!bucket.collisionArrays && collisionBoxArray) {\n bucket.deserializeCollisionBoxes(collisionBoxArray);\n }\n var placeSymbol = function (symbolInstance, collisionArrays) {\n if (seenCrossTileIDs[symbolInstance.crossTileID]) {\n return;\n }\n if (holdingForFade) {\n this$1.placements[symbolInstance.crossTileID] = new JointPlacement(false, false, false);\n return;\n }\n var placeText = false;\n var placeIcon = false;\n var offscreen = true;\n var shift = null;\n var placed = {\n box: null,\n offscreen: null\n };\n var placedVerticalText = {\n box: null,\n offscreen: null\n };\n var placedGlyphBoxes = null;\n var placedGlyphCircles = null;\n var placedIconBoxes = null;\n var textFeatureIndex = 0;\n var verticalTextFeatureIndex = 0;\n var iconFeatureIndex = 0;\n if (collisionArrays.textFeatureIndex) {\n textFeatureIndex = collisionArrays.textFeatureIndex;\n } else if (symbolInstance.useRuntimeCollisionCircles) {\n textFeatureIndex = symbolInstance.featureIndex;\n }\n if (collisionArrays.verticalTextFeatureIndex) {\n verticalTextFeatureIndex = collisionArrays.verticalTextFeatureIndex;\n }\n var textBox = collisionArrays.textBox;\n if (textBox) {\n var updatePreviousOrientationIfNotPlaced = function (isPlaced) {\n var previousOrientation = performance.WritingMode.horizontal;\n if (bucket.allowVerticalPlacement && !isPlaced && this$1.prevPlacement) {\n var prevPlacedOrientation = this$1.prevPlacement.placedOrientations[symbolInstance.crossTileID];\n if (prevPlacedOrientation) {\n this$1.placedOrientations[symbolInstance.crossTileID] = prevPlacedOrientation;\n previousOrientation = prevPlacedOrientation;\n this$1.markUsedOrientation(bucket, previousOrientation, symbolInstance);\n }\n }\n return previousOrientation;\n };\n var placeTextForPlacementModes = function (placeHorizontalFn, placeVerticalFn) {\n if (bucket.allowVerticalPlacement && symbolInstance.numVerticalGlyphVertices > 0 && collisionArrays.verticalTextBox) {\n for (var i = 0, list = bucket.writingModes; i < list.length; i += 1) {\n var placementMode = list[i];\n if (placementMode === performance.WritingMode.vertical) {\n placed = placeVerticalFn();\n placedVerticalText = placed;\n } else {\n placed = placeHorizontalFn();\n }\n if (placed && placed.box && placed.box.length) {\n break;\n }\n }\n } else {\n placed = placeHorizontalFn();\n }\n };\n if (!layout.get('text-variable-anchor')) {\n var placeBox = function (collisionTextBox, orientation) {\n var placedFeature = this$1.collisionIndex.placeCollisionBox(collisionTextBox, textAllowOverlap, textPixelRatio, posMatrix, collisionGroup.predicate);\n if (placedFeature && placedFeature.box && placedFeature.box.length) {\n this$1.markUsedOrientation(bucket, orientation, symbolInstance);\n this$1.placedOrientations[symbolInstance.crossTileID] = orientation;\n }\n return placedFeature;\n };\n var placeHorizontal = function () {\n return placeBox(textBox, performance.WritingMode.horizontal);\n };\n var placeVertical = function () {\n var verticalTextBox = collisionArrays.verticalTextBox;\n if (bucket.allowVerticalPlacement && symbolInstance.numVerticalGlyphVertices > 0 && verticalTextBox) {\n return placeBox(verticalTextBox, performance.WritingMode.vertical);\n }\n return {\n box: null,\n offscreen: null\n };\n };\n placeTextForPlacementModes(placeHorizontal, placeVertical);\n updatePreviousOrientationIfNotPlaced(placed && placed.box && placed.box.length);\n } else {\n var anchors = layout.get('text-variable-anchor');\n if (this$1.prevPlacement && this$1.prevPlacement.variableOffsets[symbolInstance.crossTileID]) {\n var prevOffsets = this$1.prevPlacement.variableOffsets[symbolInstance.crossTileID];\n if (anchors.indexOf(prevOffsets.anchor) > 0) {\n anchors = anchors.filter(function (anchor) {\n return anchor !== prevOffsets.anchor;\n });\n anchors.unshift(prevOffsets.anchor);\n }\n }\n var placeBoxForVariableAnchors = function (collisionTextBox, collisionIconBox, orientation) {\n var width = collisionTextBox.x2 - collisionTextBox.x1;\n var height = collisionTextBox.y2 - collisionTextBox.y1;\n var textBoxScale = symbolInstance.textBoxScale;\n var variableIconBox = hasIconTextFit && !iconAllowOverlap ? collisionIconBox : null;\n var placedBox = {\n box: [],\n offscreen: false\n };\n var placementAttempts = textAllowOverlap ? anchors.length * 2 : anchors.length;\n for (var i = 0; i < placementAttempts; ++i) {\n var anchor = anchors[i % anchors.length];\n var allowOverlap = i >= anchors.length;\n var result = this$1.attemptAnchorPlacement(anchor, collisionTextBox, width, height, textBoxScale, rotateWithMap, pitchWithMap, textPixelRatio, posMatrix, collisionGroup, allowOverlap, symbolInstance, bucket, orientation, variableIconBox);\n if (result) {\n placedBox = result.placedGlyphBoxes;\n if (placedBox && placedBox.box && placedBox.box.length) {\n placeText = true;\n shift = result.shift;\n break;\n }\n }\n }\n return placedBox;\n };\n var placeHorizontal$1 = function () {\n return placeBoxForVariableAnchors(textBox, collisionArrays.iconBox, performance.WritingMode.horizontal);\n };\n var placeVertical$1 = function () {\n var verticalTextBox = collisionArrays.verticalTextBox;\n var wasPlaced = placed && placed.box && placed.box.length;\n if (bucket.allowVerticalPlacement && !wasPlaced && symbolInstance.numVerticalGlyphVertices > 0 && verticalTextBox) {\n return placeBoxForVariableAnchors(verticalTextBox, collisionArrays.verticalIconBox, performance.WritingMode.vertical);\n }\n return {\n box: null,\n offscreen: null\n };\n };\n placeTextForPlacementModes(placeHorizontal$1, placeVertical$1);\n if (placed) {\n placeText = placed.box;\n offscreen = placed.offscreen;\n }\n var prevOrientation = updatePreviousOrientationIfNotPlaced(placed && placed.box);\n if (!placeText && this$1.prevPlacement) {\n var prevOffset = this$1.prevPlacement.variableOffsets[symbolInstance.crossTileID];\n if (prevOffset) {\n this$1.variableOffsets[symbolInstance.crossTileID] = prevOffset;\n this$1.markUsedJustification(bucket, prevOffset.anchor, symbolInstance, prevOrientation);\n }\n }\n }\n }\n placedGlyphBoxes = placed;\n placeText = placedGlyphBoxes && placedGlyphBoxes.box && placedGlyphBoxes.box.length > 0;\n offscreen = placedGlyphBoxes && placedGlyphBoxes.offscreen;\n if (symbolInstance.useRuntimeCollisionCircles) {\n var placedSymbol = bucket.text.placedSymbolArray.get(symbolInstance.centerJustifiedTextSymbolIndex);\n var fontSize = performance.evaluateSizeForFeature(bucket.textSizeData, partiallyEvaluatedTextSize, placedSymbol);\n var textPixelPadding = layout.get('text-padding');\n var circlePixelDiameter = symbolInstance.collisionCircleDiameter;\n placedGlyphCircles = this$1.collisionIndex.placeCollisionCircles(textAllowOverlap, placedSymbol, bucket.lineVertexArray, bucket.glyphOffsetArray, fontSize, posMatrix, textLabelPlaneMatrix, labelToScreenMatrix, showCollisionBoxes, pitchWithMap, collisionGroup.predicate, circlePixelDiameter, textPixelPadding);\n placeText = textAllowOverlap || placedGlyphCircles.circles.length > 0 && !placedGlyphCircles.collisionDetected;\n offscreen = offscreen && placedGlyphCircles.offscreen;\n }\n if (collisionArrays.iconFeatureIndex) {\n iconFeatureIndex = collisionArrays.iconFeatureIndex;\n }\n if (collisionArrays.iconBox) {\n var placeIconFeature = function (iconBox) {\n var shiftedIconBox = hasIconTextFit && shift ? shiftVariableCollisionBox(iconBox, shift.x, shift.y, rotateWithMap, pitchWithMap, this$1.transform.angle) : iconBox;\n return this$1.collisionIndex.placeCollisionBox(shiftedIconBox, iconAllowOverlap, textPixelRatio, posMatrix, collisionGroup.predicate);\n };\n if (placedVerticalText && placedVerticalText.box && placedVerticalText.box.length && collisionArrays.verticalIconBox) {\n placedIconBoxes = placeIconFeature(collisionArrays.verticalIconBox);\n placeIcon = placedIconBoxes.box.length > 0;\n } else {\n placedIconBoxes = placeIconFeature(collisionArrays.iconBox);\n placeIcon = placedIconBoxes.box.length > 0;\n }\n offscreen = offscreen && placedIconBoxes.offscreen;\n }\n var iconWithoutText = textOptional || symbolInstance.numHorizontalGlyphVertices === 0 && symbolInstance.numVerticalGlyphVertices === 0;\n var textWithoutIcon = iconOptional || symbolInstance.numIconVertices === 0;\n if (!iconWithoutText && !textWithoutIcon) {\n placeIcon = placeText = placeIcon && placeText;\n } else if (!textWithoutIcon) {\n placeText = placeIcon && placeText;\n } else if (!iconWithoutText) {\n placeIcon = placeIcon && placeText;\n }\n if (placeText && placedGlyphBoxes && placedGlyphBoxes.box) {\n if (placedVerticalText && placedVerticalText.box && verticalTextFeatureIndex) {\n this$1.collisionIndex.insertCollisionBox(placedGlyphBoxes.box, layout.get('text-ignore-placement'), bucket.bucketInstanceId, verticalTextFeatureIndex, collisionGroup.ID);\n } else {\n this$1.collisionIndex.insertCollisionBox(placedGlyphBoxes.box, layout.get('text-ignore-placement'), bucket.bucketInstanceId, textFeatureIndex, collisionGroup.ID);\n }\n }\n if (placeIcon && placedIconBoxes) {\n this$1.collisionIndex.insertCollisionBox(placedIconBoxes.box, layout.get('icon-ignore-placement'), bucket.bucketInstanceId, iconFeatureIndex, collisionGroup.ID);\n }\n if (placedGlyphCircles) {\n if (placeText) {\n this$1.collisionIndex.insertCollisionCircles(placedGlyphCircles.circles, layout.get('text-ignore-placement'), bucket.bucketInstanceId, textFeatureIndex, collisionGroup.ID);\n }\n if (showCollisionBoxes) {\n var id = bucket.bucketInstanceId;\n var circleArray = this$1.collisionCircleArrays[id];\n if (circleArray === undefined) {\n circleArray = this$1.collisionCircleArrays[id] = new CollisionCircleArray();\n }\n for (var i = 0; i < placedGlyphCircles.circles.length; i += 4) {\n circleArray.circles.push(placedGlyphCircles.circles[i + 0]);\n circleArray.circles.push(placedGlyphCircles.circles[i + 1]);\n circleArray.circles.push(placedGlyphCircles.circles[i + 2]);\n circleArray.circles.push(placedGlyphCircles.collisionDetected ? 1 : 0);\n }\n }\n }\n this$1.placements[symbolInstance.crossTileID] = new JointPlacement(placeText || alwaysShowText, placeIcon || alwaysShowIcon, offscreen || bucket.justReloaded);\n seenCrossTileIDs[symbolInstance.crossTileID] = true;\n };\n if (zOrderByViewportY) {\n var symbolIndexes = bucket.getSortedSymbolIndexes(this.transform.angle);\n for (var i = symbolIndexes.length - 1; i >= 0; --i) {\n var symbolIndex = symbolIndexes[i];\n placeSymbol(bucket.symbolInstances.get(symbolIndex), bucket.collisionArrays[symbolIndex]);\n }\n } else {\n for (var i$1 = bucketPart.symbolInstanceStart; i$1 < bucketPart.symbolInstanceEnd; i$1++) {\n placeSymbol(bucket.symbolInstances.get(i$1), bucket.collisionArrays[i$1]);\n }\n }\n if (showCollisionBoxes && bucket.bucketInstanceId in this.collisionCircleArrays) {\n var circleArray = this.collisionCircleArrays[bucket.bucketInstanceId];\n performance.invert(circleArray.invProjMatrix, posMatrix);\n circleArray.viewportMatrix = this.collisionIndex.getViewportMatrix();\n }\n bucket.justReloaded = false;\n};\nPlacement.prototype.markUsedJustification = function markUsedJustification(bucket, placedAnchor, symbolInstance, orientation) {\n var justifications = {\n 'left': symbolInstance.leftJustifiedTextSymbolIndex,\n 'center': symbolInstance.centerJustifiedTextSymbolIndex,\n 'right': symbolInstance.rightJustifiedTextSymbolIndex\n };\n var autoIndex;\n if (orientation === performance.WritingMode.vertical) {\n autoIndex = symbolInstance.verticalPlacedTextSymbolIndex;\n } else {\n autoIndex = justifications[performance.getAnchorJustification(placedAnchor)];\n }\n var indexes = [\n symbolInstance.leftJustifiedTextSymbolIndex,\n symbolInstance.centerJustifiedTextSymbolIndex,\n symbolInstance.rightJustifiedTextSymbolIndex,\n symbolInstance.verticalPlacedTextSymbolIndex\n ];\n for (var i = 0, list = indexes; i < list.length; i += 1) {\n var index = list[i];\n if (index >= 0) {\n if (autoIndex >= 0 && index !== autoIndex) {\n bucket.text.placedSymbolArray.get(index).crossTileID = 0;\n } else {\n bucket.text.placedSymbolArray.get(index).crossTileID = symbolInstance.crossTileID;\n }\n }\n }\n};\nPlacement.prototype.markUsedOrientation = function markUsedOrientation(bucket, orientation, symbolInstance) {\n var horizontal = orientation === performance.WritingMode.horizontal || orientation === performance.WritingMode.horizontalOnly ? orientation : 0;\n var vertical = orientation === performance.WritingMode.vertical ? orientation : 0;\n var horizontalIndexes = [\n symbolInstance.leftJustifiedTextSymbolIndex,\n symbolInstance.centerJustifiedTextSymbolIndex,\n symbolInstance.rightJustifiedTextSymbolIndex\n ];\n for (var i = 0, list = horizontalIndexes; i < list.length; i += 1) {\n var index = list[i];\n bucket.text.placedSymbolArray.get(index).placedOrientation = horizontal;\n }\n if (symbolInstance.verticalPlacedTextSymbolIndex) {\n bucket.text.placedSymbolArray.get(symbolInstance.verticalPlacedTextSymbolIndex).placedOrientation = vertical;\n }\n};\nPlacement.prototype.commit = function commit(now) {\n this.commitTime = now;\n this.zoomAtLastRecencyCheck = this.transform.zoom;\n var prevPlacement = this.prevPlacement;\n var placementChanged = false;\n this.prevZoomAdjustment = prevPlacement ? prevPlacement.zoomAdjustment(this.transform.zoom) : 0;\n var increment = prevPlacement ? prevPlacement.symbolFadeChange(now) : 1;\n var prevOpacities = prevPlacement ? prevPlacement.opacities : {};\n var prevOffsets = prevPlacement ? prevPlacement.variableOffsets : {};\n var prevOrientations = prevPlacement ? prevPlacement.placedOrientations : {};\n for (var crossTileID in this.placements) {\n var jointPlacement = this.placements[crossTileID];\n var prevOpacity = prevOpacities[crossTileID];\n if (prevOpacity) {\n this.opacities[crossTileID] = new JointOpacityState(prevOpacity, increment, jointPlacement.text, jointPlacement.icon);\n placementChanged = placementChanged || jointPlacement.text !== prevOpacity.text.placed || jointPlacement.icon !== prevOpacity.icon.placed;\n } else {\n this.opacities[crossTileID] = new JointOpacityState(null, increment, jointPlacement.text, jointPlacement.icon, jointPlacement.skipFade);\n placementChanged = placementChanged || jointPlacement.text || jointPlacement.icon;\n }\n }\n for (var crossTileID$1 in prevOpacities) {\n var prevOpacity$1 = prevOpacities[crossTileID$1];\n if (!this.opacities[crossTileID$1]) {\n var jointOpacity = new JointOpacityState(prevOpacity$1, increment, false, false);\n if (!jointOpacity.isHidden()) {\n this.opacities[crossTileID$1] = jointOpacity;\n placementChanged = placementChanged || prevOpacity$1.text.placed || prevOpacity$1.icon.placed;\n }\n }\n }\n for (var crossTileID$2 in prevOffsets) {\n if (!this.variableOffsets[crossTileID$2] && this.opacities[crossTileID$2] && !this.opacities[crossTileID$2].isHidden()) {\n this.variableOffsets[crossTileID$2] = prevOffsets[crossTileID$2];\n }\n }\n for (var crossTileID$3 in prevOrientations) {\n if (!this.placedOrientations[crossTileID$3] && this.opacities[crossTileID$3] && !this.opacities[crossTileID$3].isHidden()) {\n this.placedOrientations[crossTileID$3] = prevOrientations[crossTileID$3];\n }\n }\n if (placementChanged) {\n this.lastPlacementChangeTime = now;\n } else if (typeof this.lastPlacementChangeTime !== 'number') {\n this.lastPlacementChangeTime = prevPlacement ? prevPlacement.lastPlacementChangeTime : now;\n }\n};\nPlacement.prototype.updateLayerOpacities = function updateLayerOpacities(styleLayer, tiles) {\n var seenCrossTileIDs = {};\n for (var i = 0, list = tiles; i < list.length; i += 1) {\n var tile = list[i];\n var symbolBucket = tile.getBucket(styleLayer);\n if (symbolBucket && tile.latestFeatureIndex && styleLayer.id === symbolBucket.layerIds[0]) {\n this.updateBucketOpacities(symbolBucket, seenCrossTileIDs, tile.collisionBoxArray);\n }\n }\n};\nPlacement.prototype.updateBucketOpacities = function updateBucketOpacities(bucket, seenCrossTileIDs, collisionBoxArray) {\n var this$1 = this;\n if (bucket.hasTextData()) {\n bucket.text.opacityVertexArray.clear();\n }\n if (bucket.hasIconData()) {\n bucket.icon.opacityVertexArray.clear();\n }\n if (bucket.hasIconCollisionBoxData()) {\n bucket.iconCollisionBox.collisionVertexArray.clear();\n }\n if (bucket.hasTextCollisionBoxData()) {\n bucket.textCollisionBox.collisionVertexArray.clear();\n }\n var layout = bucket.layers[0].layout;\n var duplicateOpacityState = new JointOpacityState(null, 0, false, false, true);\n var textAllowOverlap = layout.get('text-allow-overlap');\n var iconAllowOverlap = layout.get('icon-allow-overlap');\n var variablePlacement = layout.get('text-variable-anchor');\n var rotateWithMap = layout.get('text-rotation-alignment') === 'map';\n var pitchWithMap = layout.get('text-pitch-alignment') === 'map';\n var hasIconTextFit = layout.get('icon-text-fit') !== 'none';\n var defaultOpacityState = new JointOpacityState(null, 0, textAllowOverlap && (iconAllowOverlap || !bucket.hasIconData() || layout.get('icon-optional')), iconAllowOverlap && (textAllowOverlap || !bucket.hasTextData() || layout.get('text-optional')), true);\n if (!bucket.collisionArrays && collisionBoxArray && (bucket.hasIconCollisionBoxData() || bucket.hasTextCollisionBoxData())) {\n bucket.deserializeCollisionBoxes(collisionBoxArray);\n }\n var addOpacities = function (iconOrText, numVertices, opacity) {\n for (var i = 0; i < numVertices / 4; i++) {\n iconOrText.opacityVertexArray.emplaceBack(opacity);\n }\n };\n var loop = function (s) {\n var symbolInstance = bucket.symbolInstances.get(s);\n var numHorizontalGlyphVertices = symbolInstance.numHorizontalGlyphVertices;\n var numVerticalGlyphVertices = symbolInstance.numVerticalGlyphVertices;\n var crossTileID = symbolInstance.crossTileID;\n var isDuplicate = seenCrossTileIDs[crossTileID];\n var opacityState = this$1.opacities[crossTileID];\n if (isDuplicate) {\n opacityState = duplicateOpacityState;\n } else if (!opacityState) {\n opacityState = defaultOpacityState;\n this$1.opacities[crossTileID] = opacityState;\n }\n seenCrossTileIDs[crossTileID] = true;\n var hasText = numHorizontalGlyphVertices > 0 || numVerticalGlyphVertices > 0;\n var hasIcon = symbolInstance.numIconVertices > 0;\n var placedOrientation = this$1.placedOrientations[symbolInstance.crossTileID];\n var horizontalHidden = placedOrientation === performance.WritingMode.vertical;\n var verticalHidden = placedOrientation === performance.WritingMode.horizontal || placedOrientation === performance.WritingMode.horizontalOnly;\n if (hasText) {\n var packedOpacity = packOpacity(opacityState.text);\n var horizontalOpacity = horizontalHidden ? PACKED_HIDDEN_OPACITY : packedOpacity;\n addOpacities(bucket.text, numHorizontalGlyphVertices, horizontalOpacity);\n var verticalOpacity = verticalHidden ? PACKED_HIDDEN_OPACITY : packedOpacity;\n addOpacities(bucket.text, numVerticalGlyphVertices, verticalOpacity);\n var symbolHidden = opacityState.text.isHidden();\n [\n symbolInstance.rightJustifiedTextSymbolIndex,\n symbolInstance.centerJustifiedTextSymbolIndex,\n symbolInstance.leftJustifiedTextSymbolIndex\n ].forEach(function (index) {\n if (index >= 0) {\n bucket.text.placedSymbolArray.get(index).hidden = symbolHidden || horizontalHidden ? 1 : 0;\n }\n });\n if (symbolInstance.verticalPlacedTextSymbolIndex >= 0) {\n bucket.text.placedSymbolArray.get(symbolInstance.verticalPlacedTextSymbolIndex).hidden = symbolHidden || verticalHidden ? 1 : 0;\n }\n var prevOffset = this$1.variableOffsets[symbolInstance.crossTileID];\n if (prevOffset) {\n this$1.markUsedJustification(bucket, prevOffset.anchor, symbolInstance, placedOrientation);\n }\n var prevOrientation = this$1.placedOrientations[symbolInstance.crossTileID];\n if (prevOrientation) {\n this$1.markUsedJustification(bucket, 'left', symbolInstance, prevOrientation);\n this$1.markUsedOrientation(bucket, prevOrientation, symbolInstance);\n }\n }\n if (hasIcon) {\n var packedOpacity$1 = packOpacity(opacityState.icon);\n var useHorizontal = !(hasIconTextFit && symbolInstance.verticalPlacedIconSymbolIndex && horizontalHidden);\n if (symbolInstance.placedIconSymbolIndex >= 0) {\n var horizontalOpacity$1 = useHorizontal ? packedOpacity$1 : PACKED_HIDDEN_OPACITY;\n addOpacities(bucket.icon, symbolInstance.numIconVertices, horizontalOpacity$1);\n bucket.icon.placedSymbolArray.get(symbolInstance.placedIconSymbolIndex).hidden = opacityState.icon.isHidden();\n }\n if (symbolInstance.verticalPlacedIconSymbolIndex >= 0) {\n var verticalOpacity$1 = !useHorizontal ? packedOpacity$1 : PACKED_HIDDEN_OPACITY;\n addOpacities(bucket.icon, symbolInstance.numVerticalIconVertices, verticalOpacity$1);\n bucket.icon.placedSymbolArray.get(symbolInstance.verticalPlacedIconSymbolIndex).hidden = opacityState.icon.isHidden();\n }\n }\n if (bucket.hasIconCollisionBoxData() || bucket.hasTextCollisionBoxData()) {\n var collisionArrays = bucket.collisionArrays[s];\n if (collisionArrays) {\n var shift = new performance.Point(0, 0);\n if (collisionArrays.textBox || collisionArrays.verticalTextBox) {\n var used = true;\n if (variablePlacement) {\n var variableOffset = this$1.variableOffsets[crossTileID];\n if (variableOffset) {\n shift = calculateVariableLayoutShift(variableOffset.anchor, variableOffset.width, variableOffset.height, variableOffset.textOffset, variableOffset.textBoxScale);\n if (rotateWithMap) {\n shift._rotate(pitchWithMap ? this$1.transform.angle : -this$1.transform.angle);\n }\n } else {\n used = false;\n }\n }\n if (collisionArrays.textBox) {\n updateCollisionVertices(bucket.textCollisionBox.collisionVertexArray, opacityState.text.placed, !used || horizontalHidden, shift.x, shift.y);\n }\n if (collisionArrays.verticalTextBox) {\n updateCollisionVertices(bucket.textCollisionBox.collisionVertexArray, opacityState.text.placed, !used || verticalHidden, shift.x, shift.y);\n }\n }\n var verticalIconUsed = Boolean(!verticalHidden && collisionArrays.verticalIconBox);\n if (collisionArrays.iconBox) {\n updateCollisionVertices(bucket.iconCollisionBox.collisionVertexArray, opacityState.icon.placed, verticalIconUsed, hasIconTextFit ? shift.x : 0, hasIconTextFit ? shift.y : 0);\n }\n if (collisionArrays.verticalIconBox) {\n updateCollisionVertices(bucket.iconCollisionBox.collisionVertexArray, opacityState.icon.placed, !verticalIconUsed, hasIconTextFit ? shift.x : 0, hasIconTextFit ? shift.y : 0);\n }\n }\n }\n };\n for (var s = 0; s < bucket.symbolInstances.length; s++)\n loop(s);\n bucket.sortFeatures(this.transform.angle);\n if (this.retainedQueryData[bucket.bucketInstanceId]) {\n this.retainedQueryData[bucket.bucketInstanceId].featureSortOrder = bucket.featureSortOrder;\n }\n if (bucket.hasTextData() && bucket.text.opacityVertexBuffer) {\n bucket.text.opacityVertexBuffer.updateData(bucket.text.opacityVertexArray);\n }\n if (bucket.hasIconData() && bucket.icon.opacityVertexBuffer) {\n bucket.icon.opacityVertexBuffer.updateData(bucket.icon.opacityVertexArray);\n }\n if (bucket.hasIconCollisionBoxData() && bucket.iconCollisionBox.collisionVertexBuffer) {\n bucket.iconCollisionBox.collisionVertexBuffer.updateData(bucket.iconCollisionBox.collisionVertexArray);\n }\n if (bucket.hasTextCollisionBoxData() && bucket.textCollisionBox.collisionVertexBuffer) {\n bucket.textCollisionBox.collisionVertexBuffer.updateData(bucket.textCollisionBox.collisionVertexArray);\n }\n if (bucket.bucketInstanceId in this.collisionCircleArrays) {\n var instance = this.collisionCircleArrays[bucket.bucketInstanceId];\n bucket.placementInvProjMatrix = instance.invProjMatrix;\n bucket.placementViewportMatrix = instance.viewportMatrix;\n bucket.collisionCircleArray = instance.circles;\n delete this.collisionCircleArrays[bucket.bucketInstanceId];\n }\n};\nPlacement.prototype.symbolFadeChange = function symbolFadeChange(now) {\n return this.fadeDuration === 0 ? 1 : (now - this.commitTime) / this.fadeDuration + this.prevZoomAdjustment;\n};\nPlacement.prototype.zoomAdjustment = function zoomAdjustment(zoom) {\n return Math.max(0, (this.transform.zoom - zoom) / 1.5);\n};\nPlacement.prototype.hasTransitions = function hasTransitions(now) {\n return this.stale || now - this.lastPlacementChangeTime < this.fadeDuration;\n};\nPlacement.prototype.stillRecent = function stillRecent(now, zoom) {\n var durationAdjustment = this.zoomAtLastRecencyCheck === zoom ? 1 - this.zoomAdjustment(zoom) : 1;\n this.zoomAtLastRecencyCheck = zoom;\n return this.commitTime + this.fadeDuration * durationAdjustment > now;\n};\nPlacement.prototype.setStale = function setStale() {\n this.stale = true;\n};\nfunction updateCollisionVertices(collisionVertexArray, placed, notUsed, shiftX, shiftY) {\n collisionVertexArray.emplaceBack(placed ? 1 : 0, notUsed ? 1 : 0, shiftX || 0, shiftY || 0);\n collisionVertexArray.emplaceBack(placed ? 1 : 0, notUsed ? 1 : 0, shiftX || 0, shiftY || 0);\n collisionVertexArray.emplaceBack(placed ? 1 : 0, notUsed ? 1 : 0, shiftX || 0, shiftY || 0);\n collisionVertexArray.emplaceBack(placed ? 1 : 0, notUsed ? 1 : 0, shiftX || 0, shiftY || 0);\n}\nvar shift25 = Math.pow(2, 25);\nvar shift24 = Math.pow(2, 24);\nvar shift17 = Math.pow(2, 17);\nvar shift16 = Math.pow(2, 16);\nvar shift9 = Math.pow(2, 9);\nvar shift8 = Math.pow(2, 8);\nvar shift1 = Math.pow(2, 1);\nfunction packOpacity(opacityState) {\n if (opacityState.opacity === 0 && !opacityState.placed) {\n return 0;\n } else if (opacityState.opacity === 1 && opacityState.placed) {\n return 4294967295;\n }\n var targetBit = opacityState.placed ? 1 : 0;\n var opacityBits = Math.floor(opacityState.opacity * 127);\n return opacityBits * shift25 + targetBit * shift24 + opacityBits * shift17 + targetBit * shift16 + opacityBits * shift9 + targetBit * shift8 + opacityBits * shift1 + targetBit;\n}\nvar PACKED_HIDDEN_OPACITY = 0;\n\nvar LayerPlacement = function LayerPlacement(styleLayer) {\n this._sortAcrossTiles = styleLayer.layout.get('symbol-z-order') !== 'viewport-y' && styleLayer.layout.get('symbol-sort-key').constantOr(1) !== undefined;\n this._currentTileIndex = 0;\n this._currentPartIndex = 0;\n this._seenCrossTileIDs = {};\n this._bucketParts = [];\n};\nLayerPlacement.prototype.continuePlacement = function continuePlacement(tiles, placement, showCollisionBoxes, styleLayer, shouldPausePlacement) {\n var bucketParts = this._bucketParts;\n while (this._currentTileIndex < tiles.length) {\n var tile = tiles[this._currentTileIndex];\n placement.getBucketParts(bucketParts, styleLayer, tile, this._sortAcrossTiles);\n this._currentTileIndex++;\n if (shouldPausePlacement()) {\n return true;\n }\n }\n if (this._sortAcrossTiles) {\n this._sortAcrossTiles = false;\n bucketParts.sort(function (a, b) {\n return a.sortKey - b.sortKey;\n });\n }\n while (this._currentPartIndex < bucketParts.length) {\n var bucketPart = bucketParts[this._currentPartIndex];\n placement.placeLayerBucketPart(bucketPart, this._seenCrossTileIDs, showCollisionBoxes);\n this._currentPartIndex++;\n if (shouldPausePlacement()) {\n return true;\n }\n }\n return false;\n};\nvar PauseablePlacement = function PauseablePlacement(transform, order, forceFullPlacement, showCollisionBoxes, fadeDuration, crossSourceCollisions, prevPlacement) {\n this.placement = new Placement(transform, fadeDuration, crossSourceCollisions, prevPlacement);\n this._currentPlacementIndex = order.length - 1;\n this._forceFullPlacement = forceFullPlacement;\n this._showCollisionBoxes = showCollisionBoxes;\n this._done = false;\n};\nPauseablePlacement.prototype.isDone = function isDone() {\n return this._done;\n};\nPauseablePlacement.prototype.continuePlacement = function continuePlacement(order, layers, layerTiles) {\n var this$1 = this;\n var startTime = performance.browser.now();\n var shouldPausePlacement = function () {\n var elapsedTime = performance.browser.now() - startTime;\n return this$1._forceFullPlacement ? false : elapsedTime > 2;\n };\n while (this._currentPlacementIndex >= 0) {\n var layerId = order[this._currentPlacementIndex];\n var layer = layers[layerId];\n var placementZoom = this.placement.collisionIndex.transform.zoom;\n if (layer.type === 'symbol' && (!layer.minzoom || layer.minzoom <= placementZoom) && (!layer.maxzoom || layer.maxzoom > placementZoom)) {\n if (!this._inProgressLayer) {\n this._inProgressLayer = new LayerPlacement(layer);\n }\n var pausePlacement = this._inProgressLayer.continuePlacement(layerTiles[layer.source], this.placement, this._showCollisionBoxes, layer, shouldPausePlacement);\n if (pausePlacement) {\n return;\n }\n delete this._inProgressLayer;\n }\n this._currentPlacementIndex--;\n }\n this._done = true;\n};\nPauseablePlacement.prototype.commit = function commit(now) {\n this.placement.commit(now);\n return this.placement;\n};\n\nvar roundingFactor = 512 / performance.EXTENT / 2;\nvar TileLayerIndex = function TileLayerIndex(tileID, symbolInstances, bucketInstanceId) {\n this.tileID = tileID;\n this.indexedSymbolInstances = {};\n this.bucketInstanceId = bucketInstanceId;\n for (var i = 0; i < symbolInstances.length; i++) {\n var symbolInstance = symbolInstances.get(i);\n var key = symbolInstance.key;\n if (!this.indexedSymbolInstances[key]) {\n this.indexedSymbolInstances[key] = [];\n }\n this.indexedSymbolInstances[key].push({\n crossTileID: symbolInstance.crossTileID,\n coord: this.getScaledCoordinates(symbolInstance, tileID)\n });\n }\n};\nTileLayerIndex.prototype.getScaledCoordinates = function getScaledCoordinates(symbolInstance, childTileID) {\n var zDifference = childTileID.canonical.z - this.tileID.canonical.z;\n var scale = roundingFactor / Math.pow(2, zDifference);\n return {\n x: Math.floor((childTileID.canonical.x * performance.EXTENT + symbolInstance.anchorX) * scale),\n y: Math.floor((childTileID.canonical.y * performance.EXTENT + symbolInstance.anchorY) * scale)\n };\n};\nTileLayerIndex.prototype.findMatches = function findMatches(symbolInstances, newTileID, zoomCrossTileIDs) {\n var tolerance = this.tileID.canonical.z < newTileID.canonical.z ? 1 : Math.pow(2, this.tileID.canonical.z - newTileID.canonical.z);\n for (var i = 0; i < symbolInstances.length; i++) {\n var symbolInstance = symbolInstances.get(i);\n if (symbolInstance.crossTileID) {\n continue;\n }\n var indexedInstances = this.indexedSymbolInstances[symbolInstance.key];\n if (!indexedInstances) {\n continue;\n }\n var scaledSymbolCoord = this.getScaledCoordinates(symbolInstance, newTileID);\n for (var i$1 = 0, list = indexedInstances; i$1 < list.length; i$1 += 1) {\n var thisTileSymbol = list[i$1];\n if (Math.abs(thisTileSymbol.coord.x - scaledSymbolCoord.x) <= tolerance && Math.abs(thisTileSymbol.coord.y - scaledSymbolCoord.y) <= tolerance && !zoomCrossTileIDs[thisTileSymbol.crossTileID]) {\n zoomCrossTileIDs[thisTileSymbol.crossTileID] = true;\n symbolInstance.crossTileID = thisTileSymbol.crossTileID;\n break;\n }\n }\n }\n};\nvar CrossTileIDs = function CrossTileIDs() {\n this.maxCrossTileID = 0;\n};\nCrossTileIDs.prototype.generate = function generate() {\n return ++this.maxCrossTileID;\n};\nvar CrossTileSymbolLayerIndex = function CrossTileSymbolLayerIndex() {\n this.indexes = {};\n this.usedCrossTileIDs = {};\n this.lng = 0;\n};\nCrossTileSymbolLayerIndex.prototype.handleWrapJump = function handleWrapJump(lng) {\n var wrapDelta = Math.round((lng - this.lng) / 360);\n if (wrapDelta !== 0) {\n for (var zoom in this.indexes) {\n var zoomIndexes = this.indexes[zoom];\n var newZoomIndex = {};\n for (var key in zoomIndexes) {\n var index = zoomIndexes[key];\n index.tileID = index.tileID.unwrapTo(index.tileID.wrap + wrapDelta);\n newZoomIndex[index.tileID.key] = index;\n }\n this.indexes[zoom] = newZoomIndex;\n }\n }\n this.lng = lng;\n};\nCrossTileSymbolLayerIndex.prototype.addBucket = function addBucket(tileID, bucket, crossTileIDs) {\n if (this.indexes[tileID.overscaledZ] && this.indexes[tileID.overscaledZ][tileID.key]) {\n if (this.indexes[tileID.overscaledZ][tileID.key].bucketInstanceId === bucket.bucketInstanceId) {\n return false;\n } else {\n this.removeBucketCrossTileIDs(tileID.overscaledZ, this.indexes[tileID.overscaledZ][tileID.key]);\n }\n }\n for (var i = 0; i < bucket.symbolInstances.length; i++) {\n var symbolInstance = bucket.symbolInstances.get(i);\n symbolInstance.crossTileID = 0;\n }\n if (!this.usedCrossTileIDs[tileID.overscaledZ]) {\n this.usedCrossTileIDs[tileID.overscaledZ] = {};\n }\n var zoomCrossTileIDs = this.usedCrossTileIDs[tileID.overscaledZ];\n for (var zoom in this.indexes) {\n var zoomIndexes = this.indexes[zoom];\n if (Number(zoom) > tileID.overscaledZ) {\n for (var id in zoomIndexes) {\n var childIndex = zoomIndexes[id];\n if (childIndex.tileID.isChildOf(tileID)) {\n childIndex.findMatches(bucket.symbolInstances, tileID, zoomCrossTileIDs);\n }\n }\n } else {\n var parentCoord = tileID.scaledTo(Number(zoom));\n var parentIndex = zoomIndexes[parentCoord.key];\n if (parentIndex) {\n parentIndex.findMatches(bucket.symbolInstances, tileID, zoomCrossTileIDs);\n }\n }\n }\n for (var i$1 = 0; i$1 < bucket.symbolInstances.length; i$1++) {\n var symbolInstance$1 = bucket.symbolInstances.get(i$1);\n if (!symbolInstance$1.crossTileID) {\n symbolInstance$1.crossTileID = crossTileIDs.generate();\n zoomCrossTileIDs[symbolInstance$1.crossTileID] = true;\n }\n }\n if (this.indexes[tileID.overscaledZ] === undefined) {\n this.indexes[tileID.overscaledZ] = {};\n }\n this.indexes[tileID.overscaledZ][tileID.key] = new TileLayerIndex(tileID, bucket.symbolInstances, bucket.bucketInstanceId);\n return true;\n};\nCrossTileSymbolLayerIndex.prototype.removeBucketCrossTileIDs = function removeBucketCrossTileIDs(zoom, removedBucket) {\n for (var key in removedBucket.indexedSymbolInstances) {\n for (var i = 0, list = removedBucket.indexedSymbolInstances[key]; i < list.length; i += 1) {\n var symbolInstance = list[i];\n delete this.usedCrossTileIDs[zoom][symbolInstance.crossTileID];\n }\n }\n};\nCrossTileSymbolLayerIndex.prototype.removeStaleBuckets = function removeStaleBuckets(currentIDs) {\n var tilesChanged = false;\n for (var z in this.indexes) {\n var zoomIndexes = this.indexes[z];\n for (var tileKey in zoomIndexes) {\n if (!currentIDs[zoomIndexes[tileKey].bucketInstanceId]) {\n this.removeBucketCrossTileIDs(z, zoomIndexes[tileKey]);\n delete zoomIndexes[tileKey];\n tilesChanged = true;\n }\n }\n }\n return tilesChanged;\n};\nvar CrossTileSymbolIndex = function CrossTileSymbolIndex() {\n this.layerIndexes = {};\n this.crossTileIDs = new CrossTileIDs();\n this.maxBucketInstanceId = 0;\n this.bucketsInCurrentPlacement = {};\n};\nCrossTileSymbolIndex.prototype.addLayer = function addLayer(styleLayer, tiles, lng) {\n var layerIndex = this.layerIndexes[styleLayer.id];\n if (layerIndex === undefined) {\n layerIndex = this.layerIndexes[styleLayer.id] = new CrossTileSymbolLayerIndex();\n }\n var symbolBucketsChanged = false;\n var currentBucketIDs = {};\n layerIndex.handleWrapJump(lng);\n for (var i = 0, list = tiles; i < list.length; i += 1) {\n var tile = list[i];\n var symbolBucket = tile.getBucket(styleLayer);\n if (!symbolBucket || styleLayer.id !== symbolBucket.layerIds[0]) {\n continue;\n }\n if (!symbolBucket.bucketInstanceId) {\n symbolBucket.bucketInstanceId = ++this.maxBucketInstanceId;\n }\n if (layerIndex.addBucket(tile.tileID, symbolBucket, this.crossTileIDs)) {\n symbolBucketsChanged = true;\n }\n currentBucketIDs[symbolBucket.bucketInstanceId] = true;\n }\n if (layerIndex.removeStaleBuckets(currentBucketIDs)) {\n symbolBucketsChanged = true;\n }\n return symbolBucketsChanged;\n};\nCrossTileSymbolIndex.prototype.pruneUnusedLayers = function pruneUnusedLayers(usedLayers) {\n var usedLayerMap = {};\n usedLayers.forEach(function (usedLayer) {\n usedLayerMap[usedLayer] = true;\n });\n for (var layerId in this.layerIndexes) {\n if (!usedLayerMap[layerId]) {\n delete this.layerIndexes[layerId];\n }\n }\n};\n\nvar emitValidationErrors = function (evented, errors) {\n return performance.emitValidationErrors(evented, errors && errors.filter(function (error) {\n return error.identifier !== 'source.canvas';\n }));\n};\nvar supportedDiffOperations = performance.pick(operations, [\n 'addLayer',\n 'removeLayer',\n 'setPaintProperty',\n 'setLayoutProperty',\n 'setFilter',\n 'addSource',\n 'removeSource',\n 'setLayerZoomRange',\n 'setLight',\n 'setTransition',\n 'setGeoJSONSourceData'\n]);\nvar ignoredDiffOperations = performance.pick(operations, [\n 'setCenter',\n 'setZoom',\n 'setBearing',\n 'setPitch'\n]);\nvar empty = emptyStyle();\nvar Style = function (Evented) {\n function Style(map, options) {\n var this$1 = this;\n if (options === void 0)\n options = {};\n Evented.call(this);\n this.map = map;\n this.dispatcher = new Dispatcher(getGlobalWorkerPool(), this);\n this.imageManager = new ImageManager();\n this.imageManager.setEventedParent(this);\n this.glyphManager = new GlyphManager(map._requestManager, options.localIdeographFontFamily);\n this.lineAtlas = new LineAtlas(256, 512);\n this.crossTileSymbolIndex = new CrossTileSymbolIndex();\n this._layers = {};\n this._serializedLayers = {};\n this._order = [];\n this.sourceCaches = {};\n this.zoomHistory = new performance.ZoomHistory();\n this._loaded = false;\n this._availableImages = [];\n this._resetUpdates();\n this.dispatcher.broadcast('setReferrer', performance.getReferrer());\n var self = this;\n this._rtlTextPluginCallback = Style.registerForPluginStateChange(function (event) {\n var state = {\n pluginStatus: event.pluginStatus,\n pluginURL: event.pluginURL\n };\n self.dispatcher.broadcast('syncRTLPluginState', state, function (err, results) {\n performance.triggerPluginCompletionEvent(err);\n if (results) {\n var allComplete = results.every(function (elem) {\n return elem;\n });\n if (allComplete) {\n for (var id in self.sourceCaches) {\n self.sourceCaches[id].reload();\n }\n }\n }\n });\n });\n this.on('data', function (event) {\n if (event.dataType !== 'source' || event.sourceDataType !== 'metadata') {\n return;\n }\n var sourceCache = this$1.sourceCaches[event.sourceId];\n if (!sourceCache) {\n return;\n }\n var source = sourceCache.getSource();\n if (!source || !source.vectorLayerIds) {\n return;\n }\n for (var layerId in this$1._layers) {\n var layer = this$1._layers[layerId];\n if (layer.source === source.id) {\n this$1._validateLayer(layer);\n }\n }\n });\n }\n if (Evented)\n Style.__proto__ = Evented;\n Style.prototype = Object.create(Evented && Evented.prototype);\n Style.prototype.constructor = Style;\n Style.prototype.loadURL = function loadURL(url, options) {\n var this$1 = this;\n if (options === void 0)\n options = {};\n this.fire(new performance.Event('dataloading', { dataType: 'style' }));\n var validate = typeof options.validate === 'boolean' ? options.validate : !performance.isMapboxURL(url);\n url = this.map._requestManager.normalizeStyleURL(url, options.accessToken);\n var request = this.map._requestManager.transformRequest(url, performance.ResourceType.Style);\n this._request = performance.getJSON(request, function (error, json) {\n this$1._request = null;\n if (error) {\n this$1.fire(new performance.ErrorEvent(error));\n } else if (json) {\n this$1._load(json, validate);\n }\n });\n };\n Style.prototype.loadJSON = function loadJSON(json, options) {\n var this$1 = this;\n if (options === void 0)\n options = {};\n this.fire(new performance.Event('dataloading', { dataType: 'style' }));\n this._request = performance.browser.frame(function () {\n this$1._request = null;\n this$1._load(json, options.validate !== false);\n });\n };\n Style.prototype.loadEmpty = function loadEmpty() {\n this.fire(new performance.Event('dataloading', { dataType: 'style' }));\n this._load(empty, false);\n };\n Style.prototype._load = function _load(json, validate) {\n if (validate && emitValidationErrors(this, performance.validateStyle(json))) {\n return;\n }\n this._loaded = true;\n this.stylesheet = json;\n for (var id in json.sources) {\n this.addSource(id, json.sources[id], { validate: false });\n }\n if (json.sprite) {\n this._loadSprite(json.sprite);\n } else {\n this.imageManager.setLoaded(true);\n }\n this.glyphManager.setURL(json.glyphs);\n var layers = derefLayers(this.stylesheet.layers);\n this._order = layers.map(function (layer) {\n return layer.id;\n });\n this._layers = {};\n this._serializedLayers = {};\n for (var i = 0, list = layers; i < list.length; i += 1) {\n var layer = list[i];\n layer = performance.createStyleLayer(layer);\n layer.setEventedParent(this, { layer: { id: layer.id } });\n this._layers[layer.id] = layer;\n this._serializedLayers[layer.id] = layer.serialize();\n }\n this.dispatcher.broadcast('setLayers', this._serializeLayers(this._order));\n this.light = new Light(this.stylesheet.light);\n this.fire(new performance.Event('data', { dataType: 'style' }));\n this.fire(new performance.Event('style.load'));\n };\n Style.prototype._loadSprite = function _loadSprite(url) {\n var this$1 = this;\n this._spriteRequest = loadSprite(url, this.map._requestManager, function (err, images) {\n this$1._spriteRequest = null;\n if (err) {\n this$1.fire(new performance.ErrorEvent(err));\n } else if (images) {\n for (var id in images) {\n this$1.imageManager.addImage(id, images[id]);\n }\n }\n this$1.imageManager.setLoaded(true);\n this$1._availableImages = this$1.imageManager.listImages();\n this$1.dispatcher.broadcast('setImages', this$1._availableImages);\n this$1.fire(new performance.Event('data', { dataType: 'style' }));\n });\n };\n Style.prototype._validateLayer = function _validateLayer(layer) {\n var sourceCache = this.sourceCaches[layer.source];\n if (!sourceCache) {\n return;\n }\n var sourceLayer = layer.sourceLayer;\n if (!sourceLayer) {\n return;\n }\n var source = sourceCache.getSource();\n if (source.type === 'geojson' || source.vectorLayerIds && source.vectorLayerIds.indexOf(sourceLayer) === -1) {\n this.fire(new performance.ErrorEvent(new Error('Source layer \"' + sourceLayer + '\" ' + 'does not exist on source \"' + source.id + '\" ' + 'as specified by style layer \"' + layer.id + '\"')));\n }\n };\n Style.prototype.loaded = function loaded() {\n if (!this._loaded) {\n return false;\n }\n if (Object.keys(this._updatedSources).length) {\n return false;\n }\n for (var id in this.sourceCaches) {\n if (!this.sourceCaches[id].loaded()) {\n return false;\n }\n }\n if (!this.imageManager.isLoaded()) {\n return false;\n }\n return true;\n };\n Style.prototype._serializeLayers = function _serializeLayers(ids) {\n var serializedLayers = [];\n for (var i = 0, list = ids; i < list.length; i += 1) {\n var id = list[i];\n var layer = this._layers[id];\n if (layer.type !== 'custom') {\n serializedLayers.push(layer.serialize());\n }\n }\n return serializedLayers;\n };\n Style.prototype.hasTransitions = function hasTransitions() {\n if (this.light && this.light.hasTransition()) {\n return true;\n }\n for (var id in this.sourceCaches) {\n if (this.sourceCaches[id].hasTransition()) {\n return true;\n }\n }\n for (var id$1 in this._layers) {\n if (this._layers[id$1].hasTransition()) {\n return true;\n }\n }\n return false;\n };\n Style.prototype._checkLoaded = function _checkLoaded() {\n if (!this._loaded) {\n throw new Error('Style is not done loading');\n }\n };\n Style.prototype.update = function update(parameters) {\n if (!this._loaded) {\n return;\n }\n var changed = this._changed;\n if (this._changed) {\n var updatedIds = Object.keys(this._updatedLayers);\n var removedIds = Object.keys(this._removedLayers);\n if (updatedIds.length || removedIds.length) {\n this._updateWorkerLayers(updatedIds, removedIds);\n }\n for (var id in this._updatedSources) {\n var action = this._updatedSources[id];\n if (action === 'reload') {\n this._reloadSource(id);\n } else if (action === 'clear') {\n this._clearSource(id);\n }\n }\n this._updateTilesForChangedImages();\n for (var id$1 in this._updatedPaintProps) {\n this._layers[id$1].updateTransitions(parameters);\n }\n this.light.updateTransitions(parameters);\n this._resetUpdates();\n }\n var sourcesUsedBefore = {};\n for (var sourceId in this.sourceCaches) {\n var sourceCache = this.sourceCaches[sourceId];\n sourcesUsedBefore[sourceId] = sourceCache.used;\n sourceCache.used = false;\n }\n for (var i = 0, list = this._order; i < list.length; i += 1) {\n var layerId = list[i];\n var layer = this._layers[layerId];\n layer.recalculate(parameters, this._availableImages);\n if (!layer.isHidden(parameters.zoom) && layer.source) {\n this.sourceCaches[layer.source].used = true;\n }\n }\n for (var sourceId$1 in sourcesUsedBefore) {\n var sourceCache$1 = this.sourceCaches[sourceId$1];\n if (sourcesUsedBefore[sourceId$1] !== sourceCache$1.used) {\n sourceCache$1.fire(new performance.Event('data', {\n sourceDataType: 'visibility',\n dataType: 'source',\n sourceId: sourceId$1\n }));\n }\n }\n this.light.recalculate(parameters);\n this.z = parameters.zoom;\n if (changed) {\n this.fire(new performance.Event('data', { dataType: 'style' }));\n }\n };\n Style.prototype._updateTilesForChangedImages = function _updateTilesForChangedImages() {\n var changedImages = Object.keys(this._changedImages);\n if (changedImages.length) {\n for (var name in this.sourceCaches) {\n this.sourceCaches[name].reloadTilesForDependencies([\n 'icons',\n 'patterns'\n ], changedImages);\n }\n this._changedImages = {};\n }\n };\n Style.prototype._updateWorkerLayers = function _updateWorkerLayers(updatedIds, removedIds) {\n this.dispatcher.broadcast('updateLayers', {\n layers: this._serializeLayers(updatedIds),\n removedIds: removedIds\n });\n };\n Style.prototype._resetUpdates = function _resetUpdates() {\n this._changed = false;\n this._updatedLayers = {};\n this._removedLayers = {};\n this._updatedSources = {};\n this._updatedPaintProps = {};\n this._changedImages = {};\n };\n Style.prototype.setState = function setState(nextState) {\n var this$1 = this;\n this._checkLoaded();\n if (emitValidationErrors(this, performance.validateStyle(nextState))) {\n return false;\n }\n nextState = performance.clone$1(nextState);\n nextState.layers = derefLayers(nextState.layers);\n var changes = diffStyles(this.serialize(), nextState).filter(function (op) {\n return !(op.command in ignoredDiffOperations);\n });\n if (changes.length === 0) {\n return false;\n }\n var unimplementedOps = changes.filter(function (op) {\n return !(op.command in supportedDiffOperations);\n });\n if (unimplementedOps.length > 0) {\n throw new Error('Unimplemented: ' + unimplementedOps.map(function (op) {\n return op.command;\n }).join(', ') + '.');\n }\n changes.forEach(function (op) {\n if (op.command === 'setTransition') {\n return;\n }\n this$1[op.command].apply(this$1, op.args);\n });\n this.stylesheet = nextState;\n return true;\n };\n Style.prototype.addImage = function addImage(id, image) {\n if (this.getImage(id)) {\n return this.fire(new performance.ErrorEvent(new Error('An image with this name already exists.')));\n }\n this.imageManager.addImage(id, image);\n this._afterImageUpdated(id);\n };\n Style.prototype.updateImage = function updateImage(id, image) {\n this.imageManager.updateImage(id, image);\n };\n Style.prototype.getImage = function getImage(id) {\n return this.imageManager.getImage(id);\n };\n Style.prototype.removeImage = function removeImage(id) {\n if (!this.getImage(id)) {\n return this.fire(new performance.ErrorEvent(new Error('No image with this name exists.')));\n }\n this.imageManager.removeImage(id);\n this._afterImageUpdated(id);\n };\n Style.prototype._afterImageUpdated = function _afterImageUpdated(id) {\n this._availableImages = this.imageManager.listImages();\n this._changedImages[id] = true;\n this._changed = true;\n this.dispatcher.broadcast('setImages', this._availableImages);\n this.fire(new performance.Event('data', { dataType: 'style' }));\n };\n Style.prototype.listImages = function listImages() {\n this._checkLoaded();\n return this.imageManager.listImages();\n };\n Style.prototype.addSource = function addSource(id, source, options) {\n var this$1 = this;\n if (options === void 0)\n options = {};\n this._checkLoaded();\n if (this.sourceCaches[id] !== undefined) {\n throw new Error('There is already a source with this ID');\n }\n if (!source.type) {\n throw new Error('The type property must be defined, but only the following properties were given: ' + Object.keys(source).join(', ') + '.');\n }\n var builtIns = [\n 'vector',\n 'raster',\n 'geojson',\n 'video',\n 'image'\n ];\n var shouldValidate = builtIns.indexOf(source.type) >= 0;\n if (shouldValidate && this._validate(performance.validateStyle.source, 'sources.' + id, source, null, options)) {\n return;\n }\n if (this.map && this.map._collectResourceTiming) {\n source.collectResourceTiming = true;\n }\n var sourceCache = this.sourceCaches[id] = new SourceCache(id, source, this.dispatcher);\n sourceCache.style = this;\n sourceCache.setEventedParent(this, function () {\n return {\n isSourceLoaded: this$1.loaded(),\n source: sourceCache.serialize(),\n sourceId: id\n };\n });\n sourceCache.onAdd(this.map);\n this._changed = true;\n };\n Style.prototype.removeSource = function removeSource(id) {\n this._checkLoaded();\n if (this.sourceCaches[id] === undefined) {\n throw new Error('There is no source with this ID');\n }\n for (var layerId in this._layers) {\n if (this._layers[layerId].source === id) {\n return this.fire(new performance.ErrorEvent(new Error('Source \"' + id + '\" cannot be removed while layer \"' + layerId + '\" is using it.')));\n }\n }\n var sourceCache = this.sourceCaches[id];\n delete this.sourceCaches[id];\n delete this._updatedSources[id];\n sourceCache.fire(new performance.Event('data', {\n sourceDataType: 'metadata',\n dataType: 'source',\n sourceId: id\n }));\n sourceCache.setEventedParent(null);\n sourceCache.clearTiles();\n if (sourceCache.onRemove) {\n sourceCache.onRemove(this.map);\n }\n this._changed = true;\n };\n Style.prototype.setGeoJSONSourceData = function setGeoJSONSourceData(id, data) {\n this._checkLoaded();\n var geojsonSource = this.sourceCaches[id].getSource();\n geojsonSource.setData(data);\n this._changed = true;\n };\n Style.prototype.getSource = function getSource(id) {\n return this.sourceCaches[id] && this.sourceCaches[id].getSource();\n };\n Style.prototype.addLayer = function addLayer(layerObject, before, options) {\n if (options === void 0)\n options = {};\n this._checkLoaded();\n var id = layerObject.id;\n if (this.getLayer(id)) {\n this.fire(new performance.ErrorEvent(new Error('Layer with id \"' + id + '\" already exists on this map')));\n return;\n }\n var layer;\n if (layerObject.type === 'custom') {\n if (emitValidationErrors(this, performance.validateCustomStyleLayer(layerObject))) {\n return;\n }\n layer = performance.createStyleLayer(layerObject);\n } else {\n if (typeof layerObject.source === 'object') {\n this.addSource(id, layerObject.source);\n layerObject = performance.clone$1(layerObject);\n layerObject = performance.extend(layerObject, { source: id });\n }\n if (this._validate(performance.validateStyle.layer, 'layers.' + id, layerObject, { arrayIndex: -1 }, options)) {\n return;\n }\n layer = performance.createStyleLayer(layerObject);\n this._validateLayer(layer);\n layer.setEventedParent(this, { layer: { id: id } });\n this._serializedLayers[layer.id] = layer.serialize();\n }\n var index = before ? this._order.indexOf(before) : this._order.length;\n if (before && index === -1) {\n this.fire(new performance.ErrorEvent(new Error('Layer with id \"' + before + '\" does not exist on this map.')));\n return;\n }\n this._order.splice(index, 0, id);\n this._layerOrderChanged = true;\n this._layers[id] = layer;\n if (this._removedLayers[id] && layer.source && layer.type !== 'custom') {\n var removed = this._removedLayers[id];\n delete this._removedLayers[id];\n if (removed.type !== layer.type) {\n this._updatedSources[layer.source] = 'clear';\n } else {\n this._updatedSources[layer.source] = 'reload';\n this.sourceCaches[layer.source].pause();\n }\n }\n this._updateLayer(layer);\n if (layer.onAdd) {\n layer.onAdd(this.map);\n }\n };\n Style.prototype.moveLayer = function moveLayer(id, before) {\n this._checkLoaded();\n this._changed = true;\n var layer = this._layers[id];\n if (!layer) {\n this.fire(new performance.ErrorEvent(new Error('The layer \\'' + id + '\\' does not exist in the map\\'s style and cannot be moved.')));\n return;\n }\n if (id === before) {\n return;\n }\n var index = this._order.indexOf(id);\n this._order.splice(index, 1);\n var newIndex = before ? this._order.indexOf(before) : this._order.length;\n if (before && newIndex === -1) {\n this.fire(new performance.ErrorEvent(new Error('Layer with id \"' + before + '\" does not exist on this map.')));\n return;\n }\n this._order.splice(newIndex, 0, id);\n this._layerOrderChanged = true;\n };\n Style.prototype.removeLayer = function removeLayer(id) {\n this._checkLoaded();\n var layer = this._layers[id];\n if (!layer) {\n this.fire(new performance.ErrorEvent(new Error('The layer \\'' + id + '\\' does not exist in the map\\'s style and cannot be removed.')));\n return;\n }\n layer.setEventedParent(null);\n var index = this._order.indexOf(id);\n this._order.splice(index, 1);\n this._layerOrderChanged = true;\n this._changed = true;\n this._removedLayers[id] = layer;\n delete this._layers[id];\n delete this._serializedLayers[id];\n delete this._updatedLayers[id];\n delete this._updatedPaintProps[id];\n if (layer.onRemove) {\n layer.onRemove(this.map);\n }\n };\n Style.prototype.getLayer = function getLayer(id) {\n return this._layers[id];\n };\n Style.prototype.hasLayer = function hasLayer(id) {\n return id in this._layers;\n };\n Style.prototype.setLayerZoomRange = function setLayerZoomRange(layerId, minzoom, maxzoom) {\n this._checkLoaded();\n var layer = this.getLayer(layerId);\n if (!layer) {\n this.fire(new performance.ErrorEvent(new Error('The layer \\'' + layerId + '\\' does not exist in the map\\'s style and cannot have zoom extent.')));\n return;\n }\n if (layer.minzoom === minzoom && layer.maxzoom === maxzoom) {\n return;\n }\n if (minzoom != null) {\n layer.minzoom = minzoom;\n }\n if (maxzoom != null) {\n layer.maxzoom = maxzoom;\n }\n this._updateLayer(layer);\n };\n Style.prototype.setFilter = function setFilter(layerId, filter, options) {\n if (options === void 0)\n options = {};\n this._checkLoaded();\n var layer = this.getLayer(layerId);\n if (!layer) {\n this.fire(new performance.ErrorEvent(new Error('The layer \\'' + layerId + '\\' does not exist in the map\\'s style and cannot be filtered.')));\n return;\n }\n if (performance.deepEqual(layer.filter, filter)) {\n return;\n }\n if (filter === null || filter === undefined) {\n layer.filter = undefined;\n this._updateLayer(layer);\n return;\n }\n if (this._validate(performance.validateStyle.filter, 'layers.' + layer.id + '.filter', filter, null, options)) {\n return;\n }\n layer.filter = performance.clone$1(filter);\n this._updateLayer(layer);\n };\n Style.prototype.getFilter = function getFilter(layer) {\n return performance.clone$1(this.getLayer(layer).filter);\n };\n Style.prototype.setLayoutProperty = function setLayoutProperty(layerId, name, value, options) {\n if (options === void 0)\n options = {};\n this._checkLoaded();\n var layer = this.getLayer(layerId);\n if (!layer) {\n this.fire(new performance.ErrorEvent(new Error('The layer \\'' + layerId + '\\' does not exist in the map\\'s style and cannot be styled.')));\n return;\n }\n if (performance.deepEqual(layer.getLayoutProperty(name), value)) {\n return;\n }\n layer.setLayoutProperty(name, value, options);\n this._updateLayer(layer);\n };\n Style.prototype.getLayoutProperty = function getLayoutProperty(layerId, name) {\n var layer = this.getLayer(layerId);\n if (!layer) {\n this.fire(new performance.ErrorEvent(new Error('The layer \\'' + layerId + '\\' does not exist in the map\\'s style.')));\n return;\n }\n return layer.getLayoutProperty(name);\n };\n Style.prototype.setPaintProperty = function setPaintProperty(layerId, name, value, options) {\n if (options === void 0)\n options = {};\n this._checkLoaded();\n var layer = this.getLayer(layerId);\n if (!layer) {\n this.fire(new performance.ErrorEvent(new Error('The layer \\'' + layerId + '\\' does not exist in the map\\'s style and cannot be styled.')));\n return;\n }\n if (performance.deepEqual(layer.getPaintProperty(name), value)) {\n return;\n }\n var requiresRelayout = layer.setPaintProperty(name, value, options);\n if (requiresRelayout) {\n this._updateLayer(layer);\n }\n this._changed = true;\n this._updatedPaintProps[layerId] = true;\n };\n Style.prototype.getPaintProperty = function getPaintProperty(layer, name) {\n return this.getLayer(layer).getPaintProperty(name);\n };\n Style.prototype.setFeatureState = function setFeatureState(target, state) {\n this._checkLoaded();\n var sourceId = target.source;\n var sourceLayer = target.sourceLayer;\n var sourceCache = this.sourceCaches[sourceId];\n if (sourceCache === undefined) {\n this.fire(new performance.ErrorEvent(new Error('The source \\'' + sourceId + '\\' does not exist in the map\\'s style.')));\n return;\n }\n var sourceType = sourceCache.getSource().type;\n if (sourceType === 'geojson' && sourceLayer) {\n this.fire(new performance.ErrorEvent(new Error('GeoJSON sources cannot have a sourceLayer parameter.')));\n return;\n }\n if (sourceType === 'vector' && !sourceLayer) {\n this.fire(new performance.ErrorEvent(new Error('The sourceLayer parameter must be provided for vector source types.')));\n return;\n }\n if (target.id === undefined) {\n this.fire(new performance.ErrorEvent(new Error('The feature id parameter must be provided.')));\n }\n sourceCache.setFeatureState(sourceLayer, target.id, state);\n };\n Style.prototype.removeFeatureState = function removeFeatureState(target, key) {\n this._checkLoaded();\n var sourceId = target.source;\n var sourceCache = this.sourceCaches[sourceId];\n if (sourceCache === undefined) {\n this.fire(new performance.ErrorEvent(new Error('The source \\'' + sourceId + '\\' does not exist in the map\\'s style.')));\n return;\n }\n var sourceType = sourceCache.getSource().type;\n var sourceLayer = sourceType === 'vector' ? target.sourceLayer : undefined;\n if (sourceType === 'vector' && !sourceLayer) {\n this.fire(new performance.ErrorEvent(new Error('The sourceLayer parameter must be provided for vector source types.')));\n return;\n }\n if (key && (typeof target.id !== 'string' && typeof target.id !== 'number')) {\n this.fire(new performance.ErrorEvent(new Error('A feature id is required to remove its specific state property.')));\n return;\n }\n sourceCache.removeFeatureState(sourceLayer, target.id, key);\n };\n Style.prototype.getFeatureState = function getFeatureState(target) {\n this._checkLoaded();\n var sourceId = target.source;\n var sourceLayer = target.sourceLayer;\n var sourceCache = this.sourceCaches[sourceId];\n if (sourceCache === undefined) {\n this.fire(new performance.ErrorEvent(new Error('The source \\'' + sourceId + '\\' does not exist in the map\\'s style.')));\n return;\n }\n var sourceType = sourceCache.getSource().type;\n if (sourceType === 'vector' && !sourceLayer) {\n this.fire(new performance.ErrorEvent(new Error('The sourceLayer parameter must be provided for vector source types.')));\n return;\n }\n if (target.id === undefined) {\n this.fire(new performance.ErrorEvent(new Error('The feature id parameter must be provided.')));\n }\n return sourceCache.getFeatureState(sourceLayer, target.id);\n };\n Style.prototype.getTransition = function getTransition() {\n return performance.extend({\n duration: 300,\n delay: 0\n }, this.stylesheet && this.stylesheet.transition);\n };\n Style.prototype.serialize = function serialize() {\n return performance.filterObject({\n version: this.stylesheet.version,\n name: this.stylesheet.name,\n metadata: this.stylesheet.metadata,\n light: this.stylesheet.light,\n center: this.stylesheet.center,\n zoom: this.stylesheet.zoom,\n bearing: this.stylesheet.bearing,\n pitch: this.stylesheet.pitch,\n sprite: this.stylesheet.sprite,\n glyphs: this.stylesheet.glyphs,\n transition: this.stylesheet.transition,\n sources: performance.mapObject(this.sourceCaches, function (source) {\n return source.serialize();\n }),\n layers: this._serializeLayers(this._order)\n }, function (value) {\n return value !== undefined;\n });\n };\n Style.prototype._updateLayer = function _updateLayer(layer) {\n this._updatedLayers[layer.id] = true;\n if (layer.source && !this._updatedSources[layer.source] && this.sourceCaches[layer.source].getSource().type !== 'raster') {\n this._updatedSources[layer.source] = 'reload';\n this.sourceCaches[layer.source].pause();\n }\n this._changed = true;\n };\n Style.prototype._flattenAndSortRenderedFeatures = function _flattenAndSortRenderedFeatures(sourceResults) {\n var this$1 = this;\n var isLayer3D = function (layerId) {\n return this$1._layers[layerId].type === 'fill-extrusion';\n };\n var layerIndex = {};\n var features3D = [];\n for (var l = this._order.length - 1; l >= 0; l--) {\n var layerId = this._order[l];\n if (isLayer3D(layerId)) {\n layerIndex[layerId] = l;\n for (var i$2 = 0, list$1 = sourceResults; i$2 < list$1.length; i$2 += 1) {\n var sourceResult = list$1[i$2];\n var layerFeatures = sourceResult[layerId];\n if (layerFeatures) {\n for (var i$1 = 0, list = layerFeatures; i$1 < list.length; i$1 += 1) {\n var featureWrapper = list[i$1];\n features3D.push(featureWrapper);\n }\n }\n }\n }\n }\n features3D.sort(function (a, b) {\n return b.intersectionZ - a.intersectionZ;\n });\n var features = [];\n for (var l$1 = this._order.length - 1; l$1 >= 0; l$1--) {\n var layerId$1 = this._order[l$1];\n if (isLayer3D(layerId$1)) {\n for (var i = features3D.length - 1; i >= 0; i--) {\n var topmost3D = features3D[i].feature;\n if (layerIndex[topmost3D.layer.id] < l$1) {\n break;\n }\n features.push(topmost3D);\n features3D.pop();\n }\n } else {\n for (var i$4 = 0, list$3 = sourceResults; i$4 < list$3.length; i$4 += 1) {\n var sourceResult$1 = list$3[i$4];\n var layerFeatures$1 = sourceResult$1[layerId$1];\n if (layerFeatures$1) {\n for (var i$3 = 0, list$2 = layerFeatures$1; i$3 < list$2.length; i$3 += 1) {\n var featureWrapper$1 = list$2[i$3];\n features.push(featureWrapper$1.feature);\n }\n }\n }\n }\n }\n return features;\n };\n Style.prototype.queryRenderedFeatures = function queryRenderedFeatures$1(queryGeometry, params, transform) {\n if (params && params.filter) {\n this._validate(performance.validateStyle.filter, 'queryRenderedFeatures.filter', params.filter, null, params);\n }\n var includedSources = {};\n if (params && params.layers) {\n if (!Array.isArray(params.layers)) {\n this.fire(new performance.ErrorEvent(new Error('parameters.layers must be an Array.')));\n return [];\n }\n for (var i = 0, list = params.layers; i < list.length; i += 1) {\n var layerId = list[i];\n var layer = this._layers[layerId];\n if (!layer) {\n this.fire(new performance.ErrorEvent(new Error('The layer \\'' + layerId + '\\' does not exist in the map\\'s style and cannot be queried for features.')));\n return [];\n }\n includedSources[layer.source] = true;\n }\n }\n var sourceResults = [];\n params.availableImages = this._availableImages;\n for (var id in this.sourceCaches) {\n if (params.layers && !includedSources[id]) {\n continue;\n }\n sourceResults.push(queryRenderedFeatures(this.sourceCaches[id], this._layers, this._serializedLayers, queryGeometry, params, transform));\n }\n if (this.placement) {\n sourceResults.push(queryRenderedSymbols(this._layers, this._serializedLayers, this.sourceCaches, queryGeometry, params, this.placement.collisionIndex, this.placement.retainedQueryData));\n }\n return this._flattenAndSortRenderedFeatures(sourceResults);\n };\n Style.prototype.querySourceFeatures = function querySourceFeatures$1(sourceID, params) {\n if (params && params.filter) {\n this._validate(performance.validateStyle.filter, 'querySourceFeatures.filter', params.filter, null, params);\n }\n var sourceCache = this.sourceCaches[sourceID];\n return sourceCache ? querySourceFeatures(sourceCache, params) : [];\n };\n Style.prototype.addSourceType = function addSourceType(name, SourceType, callback) {\n if (Style.getSourceType(name)) {\n return callback(new Error('A source type called \"' + name + '\" already exists.'));\n }\n Style.setSourceType(name, SourceType);\n if (!SourceType.workerSourceURL) {\n return callback(null, null);\n }\n this.dispatcher.broadcast('loadWorkerSource', {\n name: name,\n url: SourceType.workerSourceURL\n }, callback);\n };\n Style.prototype.getLight = function getLight() {\n return this.light.getLight();\n };\n Style.prototype.setLight = function setLight(lightOptions, options) {\n if (options === void 0)\n options = {};\n this._checkLoaded();\n var light = this.light.getLight();\n var _update = false;\n for (var key in lightOptions) {\n if (!performance.deepEqual(lightOptions[key], light[key])) {\n _update = true;\n break;\n }\n }\n if (!_update) {\n return;\n }\n var parameters = {\n now: performance.browser.now(),\n transition: performance.extend({\n duration: 300,\n delay: 0\n }, this.stylesheet.transition)\n };\n this.light.setLight(lightOptions, options);\n this.light.updateTransitions(parameters);\n };\n Style.prototype._validate = function _validate(validate, key, value, props, options) {\n if (options === void 0)\n options = {};\n if (options && options.validate === false) {\n return false;\n }\n return emitValidationErrors(this, validate.call(performance.validateStyle, performance.extend({\n key: key,\n style: this.serialize(),\n value: value,\n styleSpec: performance.styleSpec\n }, props)));\n };\n Style.prototype._remove = function _remove() {\n if (this._request) {\n this._request.cancel();\n this._request = null;\n }\n if (this._spriteRequest) {\n this._spriteRequest.cancel();\n this._spriteRequest = null;\n }\n performance.evented.off('pluginStateChange', this._rtlTextPluginCallback);\n for (var layerId in this._layers) {\n var layer = this._layers[layerId];\n layer.setEventedParent(null);\n }\n for (var id in this.sourceCaches) {\n this.sourceCaches[id].clearTiles();\n this.sourceCaches[id].setEventedParent(null);\n }\n this.imageManager.setEventedParent(null);\n this.setEventedParent(null);\n this.dispatcher.remove();\n };\n Style.prototype._clearSource = function _clearSource(id) {\n this.sourceCaches[id].clearTiles();\n };\n Style.prototype._reloadSource = function _reloadSource(id) {\n this.sourceCaches[id].resume();\n this.sourceCaches[id].reload();\n };\n Style.prototype._updateSources = function _updateSources(transform) {\n for (var id in this.sourceCaches) {\n this.sourceCaches[id].update(transform);\n }\n };\n Style.prototype._generateCollisionBoxes = function _generateCollisionBoxes() {\n for (var id in this.sourceCaches) {\n this._reloadSource(id);\n }\n };\n Style.prototype._updatePlacement = function _updatePlacement(transform, showCollisionBoxes, fadeDuration, crossSourceCollisions, forceFullPlacement) {\n if (forceFullPlacement === void 0)\n forceFullPlacement = false;\n var symbolBucketsChanged = false;\n var placementCommitted = false;\n var layerTiles = {};\n for (var i = 0, list = this._order; i < list.length; i += 1) {\n var layerID = list[i];\n var styleLayer = this._layers[layerID];\n if (styleLayer.type !== 'symbol') {\n continue;\n }\n if (!layerTiles[styleLayer.source]) {\n var sourceCache = this.sourceCaches[styleLayer.source];\n layerTiles[styleLayer.source] = sourceCache.getRenderableIds(true).map(function (id) {\n return sourceCache.getTileByID(id);\n }).sort(function (a, b) {\n return b.tileID.overscaledZ - a.tileID.overscaledZ || (a.tileID.isLessThan(b.tileID) ? -1 : 1);\n });\n }\n var layerBucketsChanged = this.crossTileSymbolIndex.addLayer(styleLayer, layerTiles[styleLayer.source], transform.center.lng);\n symbolBucketsChanged = symbolBucketsChanged || layerBucketsChanged;\n }\n this.crossTileSymbolIndex.pruneUnusedLayers(this._order);\n forceFullPlacement = forceFullPlacement || this._layerOrderChanged || fadeDuration === 0;\n if (forceFullPlacement || !this.pauseablePlacement || this.pauseablePlacement.isDone() && !this.placement.stillRecent(performance.browser.now(), transform.zoom)) {\n this.pauseablePlacement = new PauseablePlacement(transform, this._order, forceFullPlacement, showCollisionBoxes, fadeDuration, crossSourceCollisions, this.placement);\n this._layerOrderChanged = false;\n }\n if (this.pauseablePlacement.isDone()) {\n this.placement.setStale();\n } else {\n this.pauseablePlacement.continuePlacement(this._order, this._layers, layerTiles);\n if (this.pauseablePlacement.isDone()) {\n this.placement = this.pauseablePlacement.commit(performance.browser.now());\n placementCommitted = true;\n }\n if (symbolBucketsChanged) {\n this.pauseablePlacement.placement.setStale();\n }\n }\n if (placementCommitted || symbolBucketsChanged) {\n for (var i$1 = 0, list$1 = this._order; i$1 < list$1.length; i$1 += 1) {\n var layerID$1 = list$1[i$1];\n var styleLayer$1 = this._layers[layerID$1];\n if (styleLayer$1.type !== 'symbol') {\n continue;\n }\n this.placement.updateLayerOpacities(styleLayer$1, layerTiles[styleLayer$1.source]);\n }\n }\n var needsRerender = !this.pauseablePlacement.isDone() || this.placement.hasTransitions(performance.browser.now());\n return needsRerender;\n };\n Style.prototype._releaseSymbolFadeTiles = function _releaseSymbolFadeTiles() {\n for (var id in this.sourceCaches) {\n this.sourceCaches[id].releaseSymbolFadeTiles();\n }\n };\n Style.prototype.getImages = function getImages(mapId, params, callback) {\n this.imageManager.getImages(params.icons, callback);\n this._updateTilesForChangedImages();\n var sourceCache = this.sourceCaches[params.source];\n if (sourceCache) {\n sourceCache.setDependencies(params.tileID.key, params.type, params.icons);\n }\n };\n Style.prototype.getGlyphs = function getGlyphs(mapId, params, callback) {\n this.glyphManager.getGlyphs(params.stacks, callback);\n };\n Style.prototype.getResource = function getResource(mapId, params, callback) {\n return performance.makeRequest(params, callback);\n };\n return Style;\n}(performance.Evented);\nStyle.getSourceType = getType;\nStyle.setSourceType = setType;\nStyle.registerForPluginStateChange = performance.registerForPluginStateChange;\n\nvar posAttributes = performance.createLayout([{\n name: 'a_pos',\n type: 'Int16',\n components: 2\n }]);\n\nvar preludeFrag = \"#ifdef GL_ES\\nprecision mediump float;\\n#else\\n#if !defined(lowp)\\n#define lowp\\n#endif\\n#if !defined(mediump)\\n#define mediump\\n#endif\\n#if !defined(highp)\\n#define highp\\n#endif\\n#endif\";\n\nvar preludeVert = \"#ifdef GL_ES\\nprecision highp float;\\n#else\\n#if !defined(lowp)\\n#define lowp\\n#endif\\n#if !defined(mediump)\\n#define mediump\\n#endif\\n#if !defined(highp)\\n#define highp\\n#endif\\n#endif\\nvec2 unpack_float(const float packedValue) {int packedIntValue=int(packedValue);int v0=packedIntValue/256;return vec2(v0,packedIntValue-v0*256);}vec2 unpack_opacity(const float packedOpacity) {int intOpacity=int(packedOpacity)/2;return vec2(float(intOpacity)/127.0,mod(packedOpacity,2.0));}vec4 decode_color(const vec2 encodedColor) {return vec4(unpack_float(encodedColor[0])/255.0,unpack_float(encodedColor[1])/255.0\\n);}float unpack_mix_vec2(const vec2 packedValue,const float t) {return mix(packedValue[0],packedValue[1],t);}vec4 unpack_mix_color(const vec4 packedColors,const float t) {vec4 minColor=decode_color(vec2(packedColors[0],packedColors[1]));vec4 maxColor=decode_color(vec2(packedColors[2],packedColors[3]));return mix(minColor,maxColor,t);}vec2 get_pattern_pos(const vec2 pixel_coord_upper,const vec2 pixel_coord_lower,const vec2 pattern_size,const float tile_units_to_pixels,const vec2 pos) {vec2 offset=mod(mod(mod(pixel_coord_upper,pattern_size)*256.0,pattern_size)*256.0+pixel_coord_lower,pattern_size);return (tile_units_to_pixels*pos+offset)/pattern_size;}\";\n\nvar backgroundFrag = \"uniform vec4 u_color;uniform float u_opacity;void main() {gl_FragColor=u_color*u_opacity;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar backgroundVert = \"attribute vec2 a_pos;uniform mat4 u_matrix;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);}\";\n\nvar backgroundPatternFrag = \"uniform vec2 u_pattern_tl_a;uniform vec2 u_pattern_br_a;uniform vec2 u_pattern_tl_b;uniform vec2 u_pattern_br_b;uniform vec2 u_texsize;uniform float u_mix;uniform float u_opacity;uniform sampler2D u_image;varying vec2 v_pos_a;varying vec2 v_pos_b;void main() {vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(u_pattern_tl_a/u_texsize,u_pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(u_pattern_tl_b/u_texsize,u_pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);gl_FragColor=mix(color1,color2,u_mix)*u_opacity;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar backgroundPatternVert = \"uniform mat4 u_matrix;uniform vec2 u_pattern_size_a;uniform vec2 u_pattern_size_b;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform float u_scale_a;uniform float u_scale_b;uniform float u_tile_units_to_pixels;attribute vec2 a_pos;varying vec2 v_pos_a;varying vec2 v_pos_b;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,u_scale_a*u_pattern_size_a,u_tile_units_to_pixels,a_pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,u_scale_b*u_pattern_size_b,u_tile_units_to_pixels,a_pos);}\";\n\nvar circleFrag = \"varying vec3 v_data;\\n#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define mediump float radius\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define highp vec4 stroke_color\\n#pragma mapbox: define mediump float stroke_width\\n#pragma mapbox: define lowp float stroke_opacity\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize mediump float radius\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize highp vec4 stroke_color\\n#pragma mapbox: initialize mediump float stroke_width\\n#pragma mapbox: initialize lowp float stroke_opacity\\nvec2 extrude=v_data.xy;float extrude_length=length(extrude);lowp float antialiasblur=v_data.z;float antialiased_blur=-max(blur,antialiasblur);float opacity_t=smoothstep(0.0,antialiased_blur,extrude_length-1.0);float color_t=stroke_width < 0.01 ? 0.0 : smoothstep(antialiased_blur,0.0,extrude_length-radius/(radius+stroke_width));gl_FragColor=opacity_t*mix(color*opacity,stroke_color*stroke_opacity,color_t);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar circleVert = \"uniform mat4 u_matrix;uniform bool u_scale_with_map;uniform bool u_pitch_with_map;uniform vec2 u_extrude_scale;uniform lowp float u_device_pixel_ratio;uniform highp float u_camera_to_center_distance;attribute vec2 a_pos;varying vec3 v_data;\\n#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define mediump float radius\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define highp vec4 stroke_color\\n#pragma mapbox: define mediump float stroke_width\\n#pragma mapbox: define lowp float stroke_opacity\\nvoid main(void) {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize mediump float radius\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize highp vec4 stroke_color\\n#pragma mapbox: initialize mediump float stroke_width\\n#pragma mapbox: initialize lowp float stroke_opacity\\nvec2 extrude=vec2(mod(a_pos,2.0)*2.0-1.0);vec2 circle_center=floor(a_pos*0.5);if (u_pitch_with_map) {vec2 corner_position=circle_center;if (u_scale_with_map) {corner_position+=extrude*(radius+stroke_width)*u_extrude_scale;} else {vec4 projected_center=u_matrix*vec4(circle_center,0,1);corner_position+=extrude*(radius+stroke_width)*u_extrude_scale*(projected_center.w/u_camera_to_center_distance);}gl_Position=u_matrix*vec4(corner_position,0,1);} else {gl_Position=u_matrix*vec4(circle_center,0,1);if (u_scale_with_map) {gl_Position.xy+=extrude*(radius+stroke_width)*u_extrude_scale*u_camera_to_center_distance;} else {gl_Position.xy+=extrude*(radius+stroke_width)*u_extrude_scale*gl_Position.w;}}lowp float antialiasblur=1.0/u_device_pixel_ratio/(radius+stroke_width);v_data=vec3(extrude.x,extrude.y,antialiasblur);}\";\n\nvar clippingMaskFrag = \"void main() {gl_FragColor=vec4(1.0);}\";\n\nvar clippingMaskVert = \"attribute vec2 a_pos;uniform mat4 u_matrix;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);}\";\n\nvar heatmapFrag = \"uniform highp float u_intensity;varying vec2 v_extrude;\\n#pragma mapbox: define highp float weight\\n#define GAUSS_COEF 0.3989422804014327\\nvoid main() {\\n#pragma mapbox: initialize highp float weight\\nfloat d=-0.5*3.0*3.0*dot(v_extrude,v_extrude);float val=weight*u_intensity*GAUSS_COEF*exp(d);gl_FragColor=vec4(val,1.0,1.0,1.0);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar heatmapVert = \"uniform mat4 u_matrix;uniform float u_extrude_scale;uniform float u_opacity;uniform float u_intensity;attribute vec2 a_pos;varying vec2 v_extrude;\\n#pragma mapbox: define highp float weight\\n#pragma mapbox: define mediump float radius\\nconst highp float ZERO=1.0/255.0/16.0;\\n#define GAUSS_COEF 0.3989422804014327\\nvoid main(void) {\\n#pragma mapbox: initialize highp float weight\\n#pragma mapbox: initialize mediump float radius\\nvec2 unscaled_extrude=vec2(mod(a_pos,2.0)*2.0-1.0);float S=sqrt(-2.0*log(ZERO/weight/u_intensity/GAUSS_COEF))/3.0;v_extrude=S*unscaled_extrude;vec2 extrude=v_extrude*radius*u_extrude_scale;vec4 pos=vec4(floor(a_pos*0.5)+extrude,0,1);gl_Position=u_matrix*pos;}\";\n\nvar heatmapTextureFrag = \"uniform sampler2D u_image;uniform sampler2D u_color_ramp;uniform float u_opacity;varying vec2 v_pos;void main() {float t=texture2D(u_image,v_pos).r;vec4 color=texture2D(u_color_ramp,vec2(t,0.5));gl_FragColor=color*u_opacity;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(0.0);\\n#endif\\n}\";\n\nvar heatmapTextureVert = \"uniform mat4 u_matrix;uniform vec2 u_world;attribute vec2 a_pos;varying vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos*u_world,0,1);v_pos.x=a_pos.x;v_pos.y=1.0-a_pos.y;}\";\n\nvar collisionBoxFrag = \"varying float v_placed;varying float v_notUsed;void main() {float alpha=0.5;gl_FragColor=vec4(1.0,0.0,0.0,1.0)*alpha;if (v_placed > 0.5) {gl_FragColor=vec4(0.0,0.0,1.0,0.5)*alpha;}if (v_notUsed > 0.5) {gl_FragColor*=.1;}}\";\n\nvar collisionBoxVert = \"attribute vec2 a_pos;attribute vec2 a_anchor_pos;attribute vec2 a_extrude;attribute vec2 a_placed;attribute vec2 a_shift;uniform mat4 u_matrix;uniform vec2 u_extrude_scale;uniform float u_camera_to_center_distance;varying float v_placed;varying float v_notUsed;void main() {vec4 projectedPoint=u_matrix*vec4(a_anchor_pos,0,1);highp float camera_to_anchor_distance=projectedPoint.w;highp float collision_perspective_ratio=clamp(0.5+0.5*(u_camera_to_center_distance/camera_to_anchor_distance),0.0,4.0);gl_Position=u_matrix*vec4(a_pos,0.0,1.0);gl_Position.xy+=(a_extrude+a_shift)*u_extrude_scale*gl_Position.w*collision_perspective_ratio;v_placed=a_placed.x;v_notUsed=a_placed.y;}\";\n\nvar collisionCircleFrag = \"varying float v_radius;varying vec2 v_extrude;varying float v_perspective_ratio;varying float v_collision;void main() {float alpha=0.5*min(v_perspective_ratio,1.0);float stroke_radius=0.9*max(v_perspective_ratio,1.0);float distance_to_center=length(v_extrude);float distance_to_edge=abs(distance_to_center-v_radius);float opacity_t=smoothstep(-stroke_radius,0.0,-distance_to_edge);vec4 color=mix(vec4(0.0,0.0,1.0,0.5),vec4(1.0,0.0,0.0,1.0),v_collision);gl_FragColor=color*alpha*opacity_t;}\";\n\nvar collisionCircleVert = \"attribute vec2 a_pos;attribute float a_radius;attribute vec2 a_flags;uniform mat4 u_matrix;uniform mat4 u_inv_matrix;uniform vec2 u_viewport_size;uniform float u_camera_to_center_distance;varying float v_radius;varying vec2 v_extrude;varying float v_perspective_ratio;varying float v_collision;vec3 toTilePosition(vec2 screenPos) {vec4 rayStart=u_inv_matrix*vec4(screenPos,-1.0,1.0);vec4 rayEnd =u_inv_matrix*vec4(screenPos, 1.0,1.0);rayStart.xyz/=rayStart.w;rayEnd.xyz /=rayEnd.w;highp float t=(0.0-rayStart.z)/(rayEnd.z-rayStart.z);return mix(rayStart.xyz,rayEnd.xyz,t);}void main() {vec2 quadCenterPos=a_pos;float radius=a_radius;float collision=a_flags.x;float vertexIdx=a_flags.y;vec2 quadVertexOffset=vec2(mix(-1.0,1.0,float(vertexIdx >=2.0)),mix(-1.0,1.0,float(vertexIdx >=1.0 && vertexIdx <=2.0)));vec2 quadVertexExtent=quadVertexOffset*radius;vec3 tilePos=toTilePosition(quadCenterPos);vec4 clipPos=u_matrix*vec4(tilePos,1.0);highp float camera_to_anchor_distance=clipPos.w;highp float collision_perspective_ratio=clamp(0.5+0.5*(u_camera_to_center_distance/camera_to_anchor_distance),0.0,4.0);float padding_factor=1.2;v_radius=radius;v_extrude=quadVertexExtent*padding_factor;v_perspective_ratio=collision_perspective_ratio;v_collision=collision;gl_Position=vec4(clipPos.xyz/clipPos.w,1.0)+vec4(quadVertexExtent*padding_factor/u_viewport_size*2.0,0.0,0.0);}\";\n\nvar debugFrag = \"uniform highp vec4 u_color;uniform sampler2D u_overlay;varying vec2 v_uv;void main() {vec4 overlay_color=texture2D(u_overlay,v_uv);gl_FragColor=mix(u_color,overlay_color,overlay_color.a);}\";\n\nvar debugVert = \"attribute vec2 a_pos;varying vec2 v_uv;uniform mat4 u_matrix;uniform float u_overlay_scale;void main() {v_uv=a_pos/8192.0;gl_Position=u_matrix*vec4(a_pos*u_overlay_scale,0,1);}\";\n\nvar fillFrag = \"#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize lowp float opacity\\ngl_FragColor=color*opacity;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar fillVert = \"attribute vec2 a_pos;uniform mat4 u_matrix;\\n#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize lowp float opacity\\ngl_Position=u_matrix*vec4(a_pos,0,1);}\";\n\nvar fillOutlineFrag = \"varying vec2 v_pos;\\n#pragma mapbox: define highp vec4 outline_color\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 outline_color\\n#pragma mapbox: initialize lowp float opacity\\nfloat dist=length(v_pos-gl_FragCoord.xy);float alpha=1.0-smoothstep(0.0,1.0,dist);gl_FragColor=outline_color*(alpha*opacity);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar fillOutlineVert = \"attribute vec2 a_pos;uniform mat4 u_matrix;uniform vec2 u_world;varying vec2 v_pos;\\n#pragma mapbox: define highp vec4 outline_color\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 outline_color\\n#pragma mapbox: initialize lowp float opacity\\ngl_Position=u_matrix*vec4(a_pos,0,1);v_pos=(gl_Position.xy/gl_Position.w+1.0)/2.0*u_world;}\";\n\nvar fillOutlinePatternFrag = \"uniform vec2 u_texsize;uniform sampler2D u_image;uniform float u_fade;varying vec2 v_pos_a;varying vec2 v_pos_b;varying vec2 v_pos;\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\nvoid main() {\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(pattern_tl_a/u_texsize,pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(pattern_tl_b/u_texsize,pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);float dist=length(v_pos-gl_FragCoord.xy);float alpha=1.0-smoothstep(0.0,1.0,dist);gl_FragColor=mix(color1,color2,u_fade)*alpha*opacity;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar fillOutlinePatternVert = \"uniform mat4 u_matrix;uniform vec2 u_world;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform vec3 u_scale;attribute vec2 a_pos;varying vec2 v_pos_a;varying vec2 v_pos_b;varying vec2 v_pos;\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\n#pragma mapbox: define lowp float pixel_ratio_from\\n#pragma mapbox: define lowp float pixel_ratio_to\\nvoid main() {\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\n#pragma mapbox: initialize lowp float pixel_ratio_from\\n#pragma mapbox: initialize lowp float pixel_ratio_to\\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;gl_Position=u_matrix*vec4(a_pos,0,1);vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,fromScale*display_size_a,tileRatio,a_pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,toScale*display_size_b,tileRatio,a_pos);v_pos=(gl_Position.xy/gl_Position.w+1.0)/2.0*u_world;}\";\n\nvar fillPatternFrag = \"uniform vec2 u_texsize;uniform float u_fade;uniform sampler2D u_image;varying vec2 v_pos_a;varying vec2 v_pos_b;\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\nvoid main() {\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(pattern_tl_a/u_texsize,pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(pattern_tl_b/u_texsize,pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);gl_FragColor=mix(color1,color2,u_fade)*opacity;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar fillPatternVert = \"uniform mat4 u_matrix;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform vec3 u_scale;attribute vec2 a_pos;varying vec2 v_pos_a;varying vec2 v_pos_b;\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\n#pragma mapbox: define lowp float pixel_ratio_from\\n#pragma mapbox: define lowp float pixel_ratio_to\\nvoid main() {\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\n#pragma mapbox: initialize lowp float pixel_ratio_from\\n#pragma mapbox: initialize lowp float pixel_ratio_to\\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileZoomRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;gl_Position=u_matrix*vec4(a_pos,0,1);v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,fromScale*display_size_a,tileZoomRatio,a_pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,toScale*display_size_b,tileZoomRatio,a_pos);}\";\n\nvar fillExtrusionFrag = \"varying vec4 v_color;void main() {gl_FragColor=v_color;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar fillExtrusionVert = \"uniform mat4 u_matrix;uniform vec3 u_lightcolor;uniform lowp vec3 u_lightpos;uniform lowp float u_lightintensity;uniform float u_vertical_gradient;uniform lowp float u_opacity;attribute vec2 a_pos;attribute vec4 a_normal_ed;varying vec4 v_color;\\n#pragma mapbox: define highp float base\\n#pragma mapbox: define highp float height\\n#pragma mapbox: define highp vec4 color\\nvoid main() {\\n#pragma mapbox: initialize highp float base\\n#pragma mapbox: initialize highp float height\\n#pragma mapbox: initialize highp vec4 color\\nvec3 normal=a_normal_ed.xyz;base=max(0.0,base);height=max(0.0,height);float t=mod(normal.x,2.0);gl_Position=u_matrix*vec4(a_pos,t > 0.0 ? height : base,1);float colorvalue=color.r*0.2126+color.g*0.7152+color.b*0.0722;v_color=vec4(0.0,0.0,0.0,1.0);vec4 ambientlight=vec4(0.03,0.03,0.03,1.0);color+=ambientlight;float directional=clamp(dot(normal/16384.0,u_lightpos),0.0,1.0);directional=mix((1.0-u_lightintensity),max((1.0-colorvalue+u_lightintensity),1.0),directional);if (normal.y !=0.0) {directional*=((1.0-u_vertical_gradient)+(u_vertical_gradient*clamp((t+base)*pow(height/150.0,0.5),mix(0.7,0.98,1.0-u_lightintensity),1.0)));}v_color.r+=clamp(color.r*directional*u_lightcolor.r,mix(0.0,0.3,1.0-u_lightcolor.r),1.0);v_color.g+=clamp(color.g*directional*u_lightcolor.g,mix(0.0,0.3,1.0-u_lightcolor.g),1.0);v_color.b+=clamp(color.b*directional*u_lightcolor.b,mix(0.0,0.3,1.0-u_lightcolor.b),1.0);v_color*=u_opacity;}\";\n\nvar fillExtrusionPatternFrag = \"uniform vec2 u_texsize;uniform float u_fade;uniform sampler2D u_image;varying vec2 v_pos_a;varying vec2 v_pos_b;varying vec4 v_lighting;\\n#pragma mapbox: define lowp float base\\n#pragma mapbox: define lowp float height\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\n#pragma mapbox: define lowp float pixel_ratio_from\\n#pragma mapbox: define lowp float pixel_ratio_to\\nvoid main() {\\n#pragma mapbox: initialize lowp float base\\n#pragma mapbox: initialize lowp float height\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\n#pragma mapbox: initialize lowp float pixel_ratio_from\\n#pragma mapbox: initialize lowp float pixel_ratio_to\\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(pattern_tl_a/u_texsize,pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(pattern_tl_b/u_texsize,pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);vec4 mixedColor=mix(color1,color2,u_fade);gl_FragColor=mixedColor*v_lighting;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar fillExtrusionPatternVert = \"uniform mat4 u_matrix;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform float u_height_factor;uniform vec3 u_scale;uniform float u_vertical_gradient;uniform lowp float u_opacity;uniform vec3 u_lightcolor;uniform lowp vec3 u_lightpos;uniform lowp float u_lightintensity;attribute vec2 a_pos;attribute vec4 a_normal_ed;varying vec2 v_pos_a;varying vec2 v_pos_b;varying vec4 v_lighting;\\n#pragma mapbox: define lowp float base\\n#pragma mapbox: define lowp float height\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\n#pragma mapbox: define lowp float pixel_ratio_from\\n#pragma mapbox: define lowp float pixel_ratio_to\\nvoid main() {\\n#pragma mapbox: initialize lowp float base\\n#pragma mapbox: initialize lowp float height\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\n#pragma mapbox: initialize lowp float pixel_ratio_from\\n#pragma mapbox: initialize lowp float pixel_ratio_to\\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;vec3 normal=a_normal_ed.xyz;float edgedistance=a_normal_ed.w;vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;base=max(0.0,base);height=max(0.0,height);float t=mod(normal.x,2.0);float z=t > 0.0 ? height : base;gl_Position=u_matrix*vec4(a_pos,z,1);vec2 pos=normal.x==1.0 && normal.y==0.0 && normal.z==16384.0\\n? a_pos\\n: vec2(edgedistance,z*u_height_factor);v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,fromScale*display_size_a,tileRatio,pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,toScale*display_size_b,tileRatio,pos);v_lighting=vec4(0.0,0.0,0.0,1.0);float directional=clamp(dot(normal/16383.0,u_lightpos),0.0,1.0);directional=mix((1.0-u_lightintensity),max((0.5+u_lightintensity),1.0),directional);if (normal.y !=0.0) {directional*=((1.0-u_vertical_gradient)+(u_vertical_gradient*clamp((t+base)*pow(height/150.0,0.5),mix(0.7,0.98,1.0-u_lightintensity),1.0)));}v_lighting.rgb+=clamp(directional*u_lightcolor,mix(vec3(0.0),vec3(0.3),1.0-u_lightcolor),vec3(1.0));v_lighting*=u_opacity;}\";\n\nvar hillshadePrepareFrag = \"#ifdef GL_ES\\nprecision highp float;\\n#endif\\nuniform sampler2D u_image;varying vec2 v_pos;uniform vec2 u_dimension;uniform float u_zoom;uniform vec4 u_unpack;float getElevation(vec2 coord,float bias) {vec4 data=texture2D(u_image,coord)*255.0;data.a=-1.0;return dot(data,u_unpack)/4.0;}void main() {vec2 epsilon=1.0/u_dimension;float a=getElevation(v_pos+vec2(-epsilon.x,-epsilon.y),0.0);float b=getElevation(v_pos+vec2(0,-epsilon.y),0.0);float c=getElevation(v_pos+vec2(epsilon.x,-epsilon.y),0.0);float d=getElevation(v_pos+vec2(-epsilon.x,0),0.0);float e=getElevation(v_pos,0.0);float f=getElevation(v_pos+vec2(epsilon.x,0),0.0);float g=getElevation(v_pos+vec2(-epsilon.x,epsilon.y),0.0);float h=getElevation(v_pos+vec2(0,epsilon.y),0.0);float i=getElevation(v_pos+vec2(epsilon.x,epsilon.y),0.0);float exaggerationFactor=u_zoom < 2.0 ? 0.4 : u_zoom < 4.5 ? 0.35 : 0.3;float exaggeration=u_zoom < 15.0 ? (u_zoom-15.0)*exaggerationFactor : 0.0;vec2 deriv=vec2((c+f+f+i)-(a+d+d+g),(g+h+h+i)-(a+b+b+c))/pow(2.0,exaggeration+(19.2562-u_zoom));gl_FragColor=clamp(vec4(deriv.x/2.0+0.5,deriv.y/2.0+0.5,1.0,1.0),0.0,1.0);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar hillshadePrepareVert = \"uniform mat4 u_matrix;uniform vec2 u_dimension;attribute vec2 a_pos;attribute vec2 a_texture_pos;varying vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);highp vec2 epsilon=1.0/u_dimension;float scale=(u_dimension.x-2.0)/u_dimension.x;v_pos=(a_texture_pos/8192.0)*scale+epsilon;}\";\n\nvar hillshadeFrag = \"uniform sampler2D u_image;varying vec2 v_pos;uniform vec2 u_latrange;uniform vec2 u_light;uniform vec4 u_shadow;uniform vec4 u_highlight;uniform vec4 u_accent;\\n#define PI 3.141592653589793\\nvoid main() {vec4 pixel=texture2D(u_image,v_pos);vec2 deriv=((pixel.rg*2.0)-1.0);float scaleFactor=cos(radians((u_latrange[0]-u_latrange[1])*(1.0-v_pos.y)+u_latrange[1]));float slope=atan(1.25*length(deriv)/scaleFactor);float aspect=deriv.x !=0.0 ? atan(deriv.y,-deriv.x) : PI/2.0*(deriv.y > 0.0 ? 1.0 :-1.0);float intensity=u_light.x;float azimuth=u_light.y+PI;float base=1.875-intensity*1.75;float maxValue=0.5*PI;float scaledSlope=intensity !=0.5 ? ((pow(base,slope)-1.0)/(pow(base,maxValue)-1.0))*maxValue : slope;float accent=cos(scaledSlope);vec4 accent_color=(1.0-accent)*u_accent*clamp(intensity*2.0,0.0,1.0);float shade=abs(mod((aspect+azimuth)/PI+0.5,2.0)-1.0);vec4 shade_color=mix(u_shadow,u_highlight,shade)*sin(scaledSlope)*clamp(intensity*2.0,0.0,1.0);gl_FragColor=accent_color*(1.0-shade_color.a)+shade_color;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar hillshadeVert = \"uniform mat4 u_matrix;attribute vec2 a_pos;attribute vec2 a_texture_pos;varying vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);v_pos=a_texture_pos/8192.0;}\";\n\nvar lineFrag = \"uniform lowp float u_device_pixel_ratio;varying vec2 v_width2;varying vec2 v_normal;varying float v_gamma_scale;\\n#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\nfloat dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);gl_FragColor=color*(alpha*opacity);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar lineVert = \"\\n#define scale 0.015873016\\nattribute vec2 a_pos_normal;attribute vec4 a_data;uniform mat4 u_matrix;uniform mediump float u_ratio;uniform vec2 u_units_to_pixels;uniform lowp float u_device_pixel_ratio;varying vec2 v_normal;varying vec2 v_width2;varying float v_gamma_scale;varying highp float v_linesofar;\\n#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define mediump float gapwidth\\n#pragma mapbox: define lowp float offset\\n#pragma mapbox: define mediump float width\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump float gapwidth\\n#pragma mapbox: initialize lowp float offset\\n#pragma mapbox: initialize mediump float width\\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;v_linesofar=(floor(a_data.z/4.0)+a_data.w*64.0)*2.0;vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;float extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;v_width2=vec2(outset,inset);}\";\n\nvar lineGradientFrag = \"uniform lowp float u_device_pixel_ratio;uniform sampler2D u_image;varying vec2 v_width2;varying vec2 v_normal;varying float v_gamma_scale;varying highp vec2 v_uv;\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\nfloat dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);vec4 color=texture2D(u_image,v_uv);gl_FragColor=color*(alpha*opacity);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar lineGradientVert = \"\\n#define scale 0.015873016\\nattribute vec2 a_pos_normal;attribute vec4 a_data;attribute float a_uv_x;attribute float a_split_index;uniform mat4 u_matrix;uniform mediump float u_ratio;uniform lowp float u_device_pixel_ratio;uniform vec2 u_units_to_pixels;uniform float u_image_height;varying vec2 v_normal;varying vec2 v_width2;varying float v_gamma_scale;varying highp vec2 v_uv;\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define mediump float gapwidth\\n#pragma mapbox: define lowp float offset\\n#pragma mapbox: define mediump float width\\nvoid main() {\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump float gapwidth\\n#pragma mapbox: initialize lowp float offset\\n#pragma mapbox: initialize mediump float width\\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;highp float texel_height=1.0/u_image_height;highp float half_texel_height=0.5*texel_height;v_uv=vec2(a_uv_x,a_split_index*texel_height-half_texel_height);vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;float extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;v_width2=vec2(outset,inset);}\";\n\nvar linePatternFrag = \"uniform lowp float u_device_pixel_ratio;uniform vec2 u_texsize;uniform float u_fade;uniform mediump vec3 u_scale;uniform sampler2D u_image;varying vec2 v_normal;varying vec2 v_width2;varying float v_linesofar;varying float v_gamma_scale;varying float v_width;\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\n#pragma mapbox: define lowp float pixel_ratio_from\\n#pragma mapbox: define lowp float pixel_ratio_to\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\n#pragma mapbox: initialize lowp float pixel_ratio_from\\n#pragma mapbox: initialize lowp float pixel_ratio_to\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileZoomRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;vec2 pattern_size_a=vec2(display_size_a.x*fromScale/tileZoomRatio,display_size_a.y);vec2 pattern_size_b=vec2(display_size_b.x*toScale/tileZoomRatio,display_size_b.y);float aspect_a=display_size_a.y/v_width;float aspect_b=display_size_b.y/v_width;float dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);float x_a=mod(v_linesofar/pattern_size_a.x*aspect_a,1.0);float x_b=mod(v_linesofar/pattern_size_b.x*aspect_b,1.0);float y=0.5*v_normal.y+0.5;vec2 texel_size=1.0/u_texsize;vec2 pos_a=mix(pattern_tl_a*texel_size-texel_size,pattern_br_a*texel_size+texel_size,vec2(x_a,y));vec2 pos_b=mix(pattern_tl_b*texel_size-texel_size,pattern_br_b*texel_size+texel_size,vec2(x_b,y));vec4 color=mix(texture2D(u_image,pos_a),texture2D(u_image,pos_b),u_fade);gl_FragColor=color*alpha*opacity;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar linePatternVert = \"\\n#define scale 0.015873016\\n#define LINE_DISTANCE_SCALE 2.0\\nattribute vec2 a_pos_normal;attribute vec4 a_data;uniform mat4 u_matrix;uniform vec2 u_units_to_pixels;uniform mediump float u_ratio;uniform lowp float u_device_pixel_ratio;varying vec2 v_normal;varying vec2 v_width2;varying float v_linesofar;varying float v_gamma_scale;varying float v_width;\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp float offset\\n#pragma mapbox: define mediump float gapwidth\\n#pragma mapbox: define mediump float width\\n#pragma mapbox: define lowp float floorwidth\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\n#pragma mapbox: define lowp float pixel_ratio_from\\n#pragma mapbox: define lowp float pixel_ratio_to\\nvoid main() {\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize lowp float offset\\n#pragma mapbox: initialize mediump float gapwidth\\n#pragma mapbox: initialize mediump float width\\n#pragma mapbox: initialize lowp float floorwidth\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\n#pragma mapbox: initialize lowp float pixel_ratio_from\\n#pragma mapbox: initialize lowp float pixel_ratio_to\\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;float a_linesofar=(floor(a_data.z/4.0)+a_data.w*64.0)*LINE_DISTANCE_SCALE;vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;float extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;v_linesofar=a_linesofar;v_width2=vec2(outset,inset);v_width=floorwidth;}\";\n\nvar lineSDFFrag = \"uniform lowp float u_device_pixel_ratio;uniform sampler2D u_image;uniform float u_sdfgamma;uniform float u_mix;varying vec2 v_normal;varying vec2 v_width2;varying vec2 v_tex_a;varying vec2 v_tex_b;varying float v_gamma_scale;\\n#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define mediump float width\\n#pragma mapbox: define lowp float floorwidth\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump float width\\n#pragma mapbox: initialize lowp float floorwidth\\nfloat dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);float sdfdist_a=texture2D(u_image,v_tex_a).a;float sdfdist_b=texture2D(u_image,v_tex_b).a;float sdfdist=mix(sdfdist_a,sdfdist_b,u_mix);alpha*=smoothstep(0.5-u_sdfgamma/floorwidth,0.5+u_sdfgamma/floorwidth,sdfdist);gl_FragColor=color*(alpha*opacity);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar lineSDFVert = \"\\n#define scale 0.015873016\\n#define LINE_DISTANCE_SCALE 2.0\\nattribute vec2 a_pos_normal;attribute vec4 a_data;uniform mat4 u_matrix;uniform mediump float u_ratio;uniform lowp float u_device_pixel_ratio;uniform vec2 u_patternscale_a;uniform float u_tex_y_a;uniform vec2 u_patternscale_b;uniform float u_tex_y_b;uniform vec2 u_units_to_pixels;varying vec2 v_normal;varying vec2 v_width2;varying vec2 v_tex_a;varying vec2 v_tex_b;varying float v_gamma_scale;\\n#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define mediump float gapwidth\\n#pragma mapbox: define lowp float offset\\n#pragma mapbox: define mediump float width\\n#pragma mapbox: define lowp float floorwidth\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump float gapwidth\\n#pragma mapbox: initialize lowp float offset\\n#pragma mapbox: initialize mediump float width\\n#pragma mapbox: initialize lowp float floorwidth\\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;float a_linesofar=(floor(a_data.z/4.0)+a_data.w*64.0)*LINE_DISTANCE_SCALE;vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;float extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;v_tex_a=vec2(a_linesofar*u_patternscale_a.x/floorwidth,normal.y*u_patternscale_a.y+u_tex_y_a);v_tex_b=vec2(a_linesofar*u_patternscale_b.x/floorwidth,normal.y*u_patternscale_b.y+u_tex_y_b);v_width2=vec2(outset,inset);}\";\n\nvar rasterFrag = \"uniform float u_fade_t;uniform float u_opacity;uniform sampler2D u_image0;uniform sampler2D u_image1;varying vec2 v_pos0;varying vec2 v_pos1;uniform float u_brightness_low;uniform float u_brightness_high;uniform float u_saturation_factor;uniform float u_contrast_factor;uniform vec3 u_spin_weights;void main() {vec4 color0=texture2D(u_image0,v_pos0);vec4 color1=texture2D(u_image1,v_pos1);if (color0.a > 0.0) {color0.rgb=color0.rgb/color0.a;}if (color1.a > 0.0) {color1.rgb=color1.rgb/color1.a;}vec4 color=mix(color0,color1,u_fade_t);color.a*=u_opacity;vec3 rgb=color.rgb;rgb=vec3(dot(rgb,u_spin_weights.xyz),dot(rgb,u_spin_weights.zxy),dot(rgb,u_spin_weights.yzx));float average=(color.r+color.g+color.b)/3.0;rgb+=(average-rgb)*u_saturation_factor;rgb=(rgb-0.5)*u_contrast_factor+0.5;vec3 u_high_vec=vec3(u_brightness_low,u_brightness_low,u_brightness_low);vec3 u_low_vec=vec3(u_brightness_high,u_brightness_high,u_brightness_high);gl_FragColor=vec4(mix(u_high_vec,u_low_vec,rgb)*color.a,color.a);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar rasterVert = \"uniform mat4 u_matrix;uniform vec2 u_tl_parent;uniform float u_scale_parent;uniform float u_buffer_scale;attribute vec2 a_pos;attribute vec2 a_texture_pos;varying vec2 v_pos0;varying vec2 v_pos1;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);v_pos0=(((a_texture_pos/8192.0)-0.5)/u_buffer_scale )+0.5;v_pos1=(v_pos0*u_scale_parent)+u_tl_parent;}\";\n\nvar symbolIconFrag = \"uniform sampler2D u_texture;varying vec2 v_tex;varying float v_fade_opacity;\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize lowp float opacity\\nlowp float alpha=opacity*v_fade_opacity;gl_FragColor=texture2D(u_texture,v_tex)*alpha;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar symbolIconVert = \"const float PI=3.141592653589793;attribute vec4 a_pos_offset;attribute vec4 a_data;attribute vec4 a_pixeloffset;attribute vec3 a_projected_pos;attribute float a_fade_opacity;uniform bool u_is_size_zoom_constant;uniform bool u_is_size_feature_constant;uniform highp float u_size_t;uniform highp float u_size;uniform highp float u_camera_to_center_distance;uniform highp float u_pitch;uniform bool u_rotate_symbol;uniform highp float u_aspect_ratio;uniform float u_fade_change;uniform mat4 u_matrix;uniform mat4 u_label_plane_matrix;uniform mat4 u_coord_matrix;uniform bool u_is_text;uniform bool u_pitch_with_map;uniform vec2 u_texsize;varying vec2 v_tex;varying float v_fade_opacity;\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize lowp float opacity\\nvec2 a_pos=a_pos_offset.xy;vec2 a_offset=a_pos_offset.zw;vec2 a_tex=a_data.xy;vec2 a_size=a_data.zw;float a_size_min=floor(a_size[0]*0.5);vec2 a_pxoffset=a_pixeloffset.xy;vec2 a_minFontScale=a_pixeloffset.zw/256.0;highp float segment_angle=-a_projected_pos[2];float size;if (!u_is_size_zoom_constant && !u_is_size_feature_constant) {size=mix(a_size_min,a_size[1],u_size_t)/128.0;} else if (u_is_size_zoom_constant && !u_is_size_feature_constant) {size=a_size_min/128.0;} else {size=u_size;}vec4 projectedPoint=u_matrix*vec4(a_pos,0,1);highp float camera_to_anchor_distance=projectedPoint.w;highp float distance_ratio=u_pitch_with_map ?\\ncamera_to_anchor_distance/u_camera_to_center_distance :\\nu_camera_to_center_distance/camera_to_anchor_distance;highp float perspective_ratio=clamp(0.5+0.5*distance_ratio,0.0,4.0);size*=perspective_ratio;float fontScale=u_is_text ? size/24.0 : size;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetProjectedPoint=u_matrix*vec4(a_pos+vec2(1,0),0,1);vec2 a=projectedPoint.xy/projectedPoint.w;vec2 b=offsetProjectedPoint.xy/offsetProjectedPoint.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}highp float angle_sin=sin(segment_angle+symbol_rotation);highp float angle_cos=cos(segment_angle+symbol_rotation);mat2 rotation_matrix=mat2(angle_cos,-1.0*angle_sin,angle_sin,angle_cos);vec4 projected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy,0.0,1.0);gl_Position=u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+rotation_matrix*(a_offset/32.0*max(a_minFontScale,fontScale)+a_pxoffset/16.0),0.0,1.0);v_tex=a_tex/u_texsize;vec2 fade_opacity=unpack_opacity(a_fade_opacity);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;v_fade_opacity=max(0.0,min(1.0,fade_opacity[0]+fade_change));}\";\n\nvar symbolSDFFrag = \"#define SDF_PX 8.0\\nuniform bool u_is_halo;uniform sampler2D u_texture;uniform highp float u_gamma_scale;uniform lowp float u_device_pixel_ratio;uniform bool u_is_text;varying vec2 v_data0;varying vec3 v_data1;\\n#pragma mapbox: define highp vec4 fill_color\\n#pragma mapbox: define highp vec4 halo_color\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp float halo_width\\n#pragma mapbox: define lowp float halo_blur\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 fill_color\\n#pragma mapbox: initialize highp vec4 halo_color\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize lowp float halo_width\\n#pragma mapbox: initialize lowp float halo_blur\\nfloat EDGE_GAMMA=0.105/u_device_pixel_ratio;vec2 tex=v_data0.xy;float gamma_scale=v_data1.x;float size=v_data1.y;float fade_opacity=v_data1[2];float fontScale=u_is_text ? size/24.0 : size;lowp vec4 color=fill_color;highp float gamma=EDGE_GAMMA/(fontScale*u_gamma_scale);lowp float buff=(256.0-64.0)/256.0;if (u_is_halo) {color=halo_color;gamma=(halo_blur*1.19/SDF_PX+EDGE_GAMMA)/(fontScale*u_gamma_scale);buff=(6.0-halo_width/fontScale)/SDF_PX;}lowp float dist=texture2D(u_texture,tex).a;highp float gamma_scaled=gamma*gamma_scale;highp float alpha=smoothstep(buff-gamma_scaled,buff+gamma_scaled,dist);gl_FragColor=color*(alpha*opacity*fade_opacity);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar symbolSDFVert = \"const float PI=3.141592653589793;attribute vec4 a_pos_offset;attribute vec4 a_data;attribute vec4 a_pixeloffset;attribute vec3 a_projected_pos;attribute float a_fade_opacity;uniform bool u_is_size_zoom_constant;uniform bool u_is_size_feature_constant;uniform highp float u_size_t;uniform highp float u_size;uniform mat4 u_matrix;uniform mat4 u_label_plane_matrix;uniform mat4 u_coord_matrix;uniform bool u_is_text;uniform bool u_pitch_with_map;uniform highp float u_pitch;uniform bool u_rotate_symbol;uniform highp float u_aspect_ratio;uniform highp float u_camera_to_center_distance;uniform float u_fade_change;uniform vec2 u_texsize;varying vec2 v_data0;varying vec3 v_data1;\\n#pragma mapbox: define highp vec4 fill_color\\n#pragma mapbox: define highp vec4 halo_color\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp float halo_width\\n#pragma mapbox: define lowp float halo_blur\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 fill_color\\n#pragma mapbox: initialize highp vec4 halo_color\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize lowp float halo_width\\n#pragma mapbox: initialize lowp float halo_blur\\nvec2 a_pos=a_pos_offset.xy;vec2 a_offset=a_pos_offset.zw;vec2 a_tex=a_data.xy;vec2 a_size=a_data.zw;float a_size_min=floor(a_size[0]*0.5);vec2 a_pxoffset=a_pixeloffset.xy;highp float segment_angle=-a_projected_pos[2];float size;if (!u_is_size_zoom_constant && !u_is_size_feature_constant) {size=mix(a_size_min,a_size[1],u_size_t)/128.0;} else if (u_is_size_zoom_constant && !u_is_size_feature_constant) {size=a_size_min/128.0;} else {size=u_size;}vec4 projectedPoint=u_matrix*vec4(a_pos,0,1);highp float camera_to_anchor_distance=projectedPoint.w;highp float distance_ratio=u_pitch_with_map ?\\ncamera_to_anchor_distance/u_camera_to_center_distance :\\nu_camera_to_center_distance/camera_to_anchor_distance;highp float perspective_ratio=clamp(0.5+0.5*distance_ratio,0.0,4.0);size*=perspective_ratio;float fontScale=u_is_text ? size/24.0 : size;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetProjectedPoint=u_matrix*vec4(a_pos+vec2(1,0),0,1);vec2 a=projectedPoint.xy/projectedPoint.w;vec2 b=offsetProjectedPoint.xy/offsetProjectedPoint.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}highp float angle_sin=sin(segment_angle+symbol_rotation);highp float angle_cos=cos(segment_angle+symbol_rotation);mat2 rotation_matrix=mat2(angle_cos,-1.0*angle_sin,angle_sin,angle_cos);vec4 projected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy,0.0,1.0);gl_Position=u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+rotation_matrix*(a_offset/32.0*fontScale+a_pxoffset),0.0,1.0);float gamma_scale=gl_Position.w;vec2 fade_opacity=unpack_opacity(a_fade_opacity);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;float interpolated_fade_opacity=max(0.0,min(1.0,fade_opacity[0]+fade_change));v_data0=a_tex/u_texsize;v_data1=vec3(gamma_scale,size,interpolated_fade_opacity);}\";\n\nvar symbolTextAndIconFrag = \"#define SDF_PX 8.0\\n#define SDF 1.0\\n#define ICON 0.0\\nuniform bool u_is_halo;uniform sampler2D u_texture;uniform sampler2D u_texture_icon;uniform highp float u_gamma_scale;uniform lowp float u_device_pixel_ratio;varying vec4 v_data0;varying vec4 v_data1;\\n#pragma mapbox: define highp vec4 fill_color\\n#pragma mapbox: define highp vec4 halo_color\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp float halo_width\\n#pragma mapbox: define lowp float halo_blur\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 fill_color\\n#pragma mapbox: initialize highp vec4 halo_color\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize lowp float halo_width\\n#pragma mapbox: initialize lowp float halo_blur\\nfloat fade_opacity=v_data1[2];if (v_data1.w==ICON) {vec2 tex_icon=v_data0.zw;lowp float alpha=opacity*fade_opacity;gl_FragColor=texture2D(u_texture_icon,tex_icon)*alpha;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\nreturn;}vec2 tex=v_data0.xy;float EDGE_GAMMA=0.105/u_device_pixel_ratio;float gamma_scale=v_data1.x;float size=v_data1.y;float fontScale=size/24.0;lowp vec4 color=fill_color;highp float gamma=EDGE_GAMMA/(fontScale*u_gamma_scale);lowp float buff=(256.0-64.0)/256.0;if (u_is_halo) {color=halo_color;gamma=(halo_blur*1.19/SDF_PX+EDGE_GAMMA)/(fontScale*u_gamma_scale);buff=(6.0-halo_width/fontScale)/SDF_PX;}lowp float dist=texture2D(u_texture,tex).a;highp float gamma_scaled=gamma*gamma_scale;highp float alpha=smoothstep(buff-gamma_scaled,buff+gamma_scaled,dist);gl_FragColor=color*(alpha*opacity*fade_opacity);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}\";\n\nvar symbolTextAndIconVert = \"const float PI=3.141592653589793;attribute vec4 a_pos_offset;attribute vec4 a_data;attribute vec3 a_projected_pos;attribute float a_fade_opacity;uniform bool u_is_size_zoom_constant;uniform bool u_is_size_feature_constant;uniform highp float u_size_t;uniform highp float u_size;uniform mat4 u_matrix;uniform mat4 u_label_plane_matrix;uniform mat4 u_coord_matrix;uniform bool u_is_text;uniform bool u_pitch_with_map;uniform highp float u_pitch;uniform bool u_rotate_symbol;uniform highp float u_aspect_ratio;uniform highp float u_camera_to_center_distance;uniform float u_fade_change;uniform vec2 u_texsize;uniform vec2 u_texsize_icon;varying vec4 v_data0;varying vec4 v_data1;\\n#pragma mapbox: define highp vec4 fill_color\\n#pragma mapbox: define highp vec4 halo_color\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp float halo_width\\n#pragma mapbox: define lowp float halo_blur\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 fill_color\\n#pragma mapbox: initialize highp vec4 halo_color\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize lowp float halo_width\\n#pragma mapbox: initialize lowp float halo_blur\\nvec2 a_pos=a_pos_offset.xy;vec2 a_offset=a_pos_offset.zw;vec2 a_tex=a_data.xy;vec2 a_size=a_data.zw;float a_size_min=floor(a_size[0]*0.5);float is_sdf=a_size[0]-2.0*a_size_min;highp float segment_angle=-a_projected_pos[2];float size;if (!u_is_size_zoom_constant && !u_is_size_feature_constant) {size=mix(a_size_min,a_size[1],u_size_t)/128.0;} else if (u_is_size_zoom_constant && !u_is_size_feature_constant) {size=a_size_min/128.0;} else {size=u_size;}vec4 projectedPoint=u_matrix*vec4(a_pos,0,1);highp float camera_to_anchor_distance=projectedPoint.w;highp float distance_ratio=u_pitch_with_map ?\\ncamera_to_anchor_distance/u_camera_to_center_distance :\\nu_camera_to_center_distance/camera_to_anchor_distance;highp float perspective_ratio=clamp(0.5+0.5*distance_ratio,0.0,4.0);size*=perspective_ratio;float fontScale=size/24.0;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetProjectedPoint=u_matrix*vec4(a_pos+vec2(1,0),0,1);vec2 a=projectedPoint.xy/projectedPoint.w;vec2 b=offsetProjectedPoint.xy/offsetProjectedPoint.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}highp float angle_sin=sin(segment_angle+symbol_rotation);highp float angle_cos=cos(segment_angle+symbol_rotation);mat2 rotation_matrix=mat2(angle_cos,-1.0*angle_sin,angle_sin,angle_cos);vec4 projected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy,0.0,1.0);gl_Position=u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+rotation_matrix*(a_offset/32.0*fontScale),0.0,1.0);float gamma_scale=gl_Position.w;vec2 fade_opacity=unpack_opacity(a_fade_opacity);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;float interpolated_fade_opacity=max(0.0,min(1.0,fade_opacity[0]+fade_change));v_data0.xy=a_tex/u_texsize;v_data0.zw=a_tex/u_texsize_icon;v_data1=vec4(gamma_scale,size,interpolated_fade_opacity,is_sdf);}\";\n\nvar prelude = compile(preludeFrag, preludeVert);\nvar background = compile(backgroundFrag, backgroundVert);\nvar backgroundPattern = compile(backgroundPatternFrag, backgroundPatternVert);\nvar circle = compile(circleFrag, circleVert);\nvar clippingMask = compile(clippingMaskFrag, clippingMaskVert);\nvar heatmap = compile(heatmapFrag, heatmapVert);\nvar heatmapTexture = compile(heatmapTextureFrag, heatmapTextureVert);\nvar collisionBox = compile(collisionBoxFrag, collisionBoxVert);\nvar collisionCircle = compile(collisionCircleFrag, collisionCircleVert);\nvar debug = compile(debugFrag, debugVert);\nvar fill = compile(fillFrag, fillVert);\nvar fillOutline = compile(fillOutlineFrag, fillOutlineVert);\nvar fillOutlinePattern = compile(fillOutlinePatternFrag, fillOutlinePatternVert);\nvar fillPattern = compile(fillPatternFrag, fillPatternVert);\nvar fillExtrusion = compile(fillExtrusionFrag, fillExtrusionVert);\nvar fillExtrusionPattern = compile(fillExtrusionPatternFrag, fillExtrusionPatternVert);\nvar hillshadePrepare = compile(hillshadePrepareFrag, hillshadePrepareVert);\nvar hillshade = compile(hillshadeFrag, hillshadeVert);\nvar line = compile(lineFrag, lineVert);\nvar lineGradient = compile(lineGradientFrag, lineGradientVert);\nvar linePattern = compile(linePatternFrag, linePatternVert);\nvar lineSDF = compile(lineSDFFrag, lineSDFVert);\nvar raster = compile(rasterFrag, rasterVert);\nvar symbolIcon = compile(symbolIconFrag, symbolIconVert);\nvar symbolSDF = compile(symbolSDFFrag, symbolSDFVert);\nvar symbolTextAndIcon = compile(symbolTextAndIconFrag, symbolTextAndIconVert);\nfunction compile(fragmentSource, vertexSource) {\n var re = /#pragma mapbox: ([\\w]+) ([\\w]+) ([\\w]+) ([\\w]+)/g;\n var staticAttributes = vertexSource.match(/attribute ([\\w]+) ([\\w]+)/g);\n var fragmentUniforms = fragmentSource.match(/uniform ([\\w]+) ([\\w]+)([\\s]*)([\\w]*)/g);\n var vertexUniforms = vertexSource.match(/uniform ([\\w]+) ([\\w]+)([\\s]*)([\\w]*)/g);\n var staticUniforms = vertexUniforms ? vertexUniforms.concat(fragmentUniforms) : fragmentUniforms;\n var fragmentPragmas = {};\n fragmentSource = fragmentSource.replace(re, function (match, operation, precision, type, name) {\n fragmentPragmas[name] = true;\n if (operation === 'define') {\n return '\\n#ifndef HAS_UNIFORM_u_' + name + '\\nvarying ' + precision + ' ' + type + ' ' + name + ';\\n#else\\nuniform ' + precision + ' ' + type + ' u_' + name + ';\\n#endif\\n';\n } else {\n return '\\n#ifdef HAS_UNIFORM_u_' + name + '\\n ' + precision + ' ' + type + ' ' + name + ' = u_' + name + ';\\n#endif\\n';\n }\n });\n vertexSource = vertexSource.replace(re, function (match, operation, precision, type, name) {\n var attrType = type === 'float' ? 'vec2' : 'vec4';\n var unpackType = name.match(/color/) ? 'color' : attrType;\n if (fragmentPragmas[name]) {\n if (operation === 'define') {\n return '\\n#ifndef HAS_UNIFORM_u_' + name + '\\nuniform lowp float u_' + name + '_t;\\nattribute ' + precision + ' ' + attrType + ' a_' + name + ';\\nvarying ' + precision + ' ' + type + ' ' + name + ';\\n#else\\nuniform ' + precision + ' ' + type + ' u_' + name + ';\\n#endif\\n';\n } else {\n if (unpackType === 'vec4') {\n return '\\n#ifndef HAS_UNIFORM_u_' + name + '\\n ' + name + ' = a_' + name + ';\\n#else\\n ' + precision + ' ' + type + ' ' + name + ' = u_' + name + ';\\n#endif\\n';\n } else {\n return '\\n#ifndef HAS_UNIFORM_u_' + name + '\\n ' + name + ' = unpack_mix_' + unpackType + '(a_' + name + ', u_' + name + '_t);\\n#else\\n ' + precision + ' ' + type + ' ' + name + ' = u_' + name + ';\\n#endif\\n';\n }\n }\n } else {\n if (operation === 'define') {\n return '\\n#ifndef HAS_UNIFORM_u_' + name + '\\nuniform lowp float u_' + name + '_t;\\nattribute ' + precision + ' ' + attrType + ' a_' + name + ';\\n#else\\nuniform ' + precision + ' ' + type + ' u_' + name + ';\\n#endif\\n';\n } else {\n if (unpackType === 'vec4') {\n return '\\n#ifndef HAS_UNIFORM_u_' + name + '\\n ' + precision + ' ' + type + ' ' + name + ' = a_' + name + ';\\n#else\\n ' + precision + ' ' + type + ' ' + name + ' = u_' + name + ';\\n#endif\\n';\n } else {\n return '\\n#ifndef HAS_UNIFORM_u_' + name + '\\n ' + precision + ' ' + type + ' ' + name + ' = unpack_mix_' + unpackType + '(a_' + name + ', u_' + name + '_t);\\n#else\\n ' + precision + ' ' + type + ' ' + name + ' = u_' + name + ';\\n#endif\\n';\n }\n }\n }\n });\n return {\n fragmentSource: fragmentSource,\n vertexSource: vertexSource,\n staticAttributes: staticAttributes,\n staticUniforms: staticUniforms\n };\n}\n\nvar shaders = /*#__PURE__*/Object.freeze({\n__proto__: null,\nprelude: prelude,\nbackground: background,\nbackgroundPattern: backgroundPattern,\ncircle: circle,\nclippingMask: clippingMask,\nheatmap: heatmap,\nheatmapTexture: heatmapTexture,\ncollisionBox: collisionBox,\ncollisionCircle: collisionCircle,\ndebug: debug,\nfill: fill,\nfillOutline: fillOutline,\nfillOutlinePattern: fillOutlinePattern,\nfillPattern: fillPattern,\nfillExtrusion: fillExtrusion,\nfillExtrusionPattern: fillExtrusionPattern,\nhillshadePrepare: hillshadePrepare,\nhillshade: hillshade,\nline: line,\nlineGradient: lineGradient,\nlinePattern: linePattern,\nlineSDF: lineSDF,\nraster: raster,\nsymbolIcon: symbolIcon,\nsymbolSDF: symbolSDF,\nsymbolTextAndIcon: symbolTextAndIcon\n});\n\nvar VertexArrayObject = function VertexArrayObject() {\n this.boundProgram = null;\n this.boundLayoutVertexBuffer = null;\n this.boundPaintVertexBuffers = [];\n this.boundIndexBuffer = null;\n this.boundVertexOffset = null;\n this.boundDynamicVertexBuffer = null;\n this.vao = null;\n};\nVertexArrayObject.prototype.bind = function bind(context, program, layoutVertexBuffer, paintVertexBuffers, indexBuffer, vertexOffset, dynamicVertexBuffer, dynamicVertexBuffer2) {\n this.context = context;\n var paintBuffersDiffer = this.boundPaintVertexBuffers.length !== paintVertexBuffers.length;\n for (var i = 0; !paintBuffersDiffer && i < paintVertexBuffers.length; i++) {\n if (this.boundPaintVertexBuffers[i] !== paintVertexBuffers[i]) {\n paintBuffersDiffer = true;\n }\n }\n var isFreshBindRequired = !this.vao || this.boundProgram !== program || this.boundLayoutVertexBuffer !== layoutVertexBuffer || paintBuffersDiffer || this.boundIndexBuffer !== indexBuffer || this.boundVertexOffset !== vertexOffset || this.boundDynamicVertexBuffer !== dynamicVertexBuffer || this.boundDynamicVertexBuffer2 !== dynamicVertexBuffer2;\n if (!context.extVertexArrayObject || isFreshBindRequired) {\n this.freshBind(program, layoutVertexBuffer, paintVertexBuffers, indexBuffer, vertexOffset, dynamicVertexBuffer, dynamicVertexBuffer2);\n } else {\n context.bindVertexArrayOES.set(this.vao);\n if (dynamicVertexBuffer) {\n dynamicVertexBuffer.bind();\n }\n if (indexBuffer && indexBuffer.dynamicDraw) {\n indexBuffer.bind();\n }\n if (dynamicVertexBuffer2) {\n dynamicVertexBuffer2.bind();\n }\n }\n};\nVertexArrayObject.prototype.freshBind = function freshBind(program, layoutVertexBuffer, paintVertexBuffers, indexBuffer, vertexOffset, dynamicVertexBuffer, dynamicVertexBuffer2) {\n var numPrevAttributes;\n var numNextAttributes = program.numAttributes;\n var context = this.context;\n var gl = context.gl;\n if (context.extVertexArrayObject) {\n if (this.vao) {\n this.destroy();\n }\n this.vao = context.extVertexArrayObject.createVertexArrayOES();\n context.bindVertexArrayOES.set(this.vao);\n numPrevAttributes = 0;\n this.boundProgram = program;\n this.boundLayoutVertexBuffer = layoutVertexBuffer;\n this.boundPaintVertexBuffers = paintVertexBuffers;\n this.boundIndexBuffer = indexBuffer;\n this.boundVertexOffset = vertexOffset;\n this.boundDynamicVertexBuffer = dynamicVertexBuffer;\n this.boundDynamicVertexBuffer2 = dynamicVertexBuffer2;\n } else {\n numPrevAttributes = context.currentNumAttributes || 0;\n for (var i = numNextAttributes; i < numPrevAttributes; i++) {\n gl.disableVertexAttribArray(i);\n }\n }\n layoutVertexBuffer.enableAttributes(gl, program);\n for (var i$1 = 0, list = paintVertexBuffers; i$1 < list.length; i$1 += 1) {\n var vertexBuffer = list[i$1];\n vertexBuffer.enableAttributes(gl, program);\n }\n if (dynamicVertexBuffer) {\n dynamicVertexBuffer.enableAttributes(gl, program);\n }\n if (dynamicVertexBuffer2) {\n dynamicVertexBuffer2.enableAttributes(gl, program);\n }\n layoutVertexBuffer.bind();\n layoutVertexBuffer.setVertexAttribPointers(gl, program, vertexOffset);\n for (var i$2 = 0, list$1 = paintVertexBuffers; i$2 < list$1.length; i$2 += 1) {\n var vertexBuffer$1 = list$1[i$2];\n vertexBuffer$1.bind();\n vertexBuffer$1.setVertexAttribPointers(gl, program, vertexOffset);\n }\n if (dynamicVertexBuffer) {\n dynamicVertexBuffer.bind();\n dynamicVertexBuffer.setVertexAttribPointers(gl, program, vertexOffset);\n }\n if (indexBuffer) {\n indexBuffer.bind();\n }\n if (dynamicVertexBuffer2) {\n dynamicVertexBuffer2.bind();\n dynamicVertexBuffer2.setVertexAttribPointers(gl, program, vertexOffset);\n }\n context.currentNumAttributes = numNextAttributes;\n};\nVertexArrayObject.prototype.destroy = function destroy() {\n if (this.vao) {\n this.context.extVertexArrayObject.deleteVertexArrayOES(this.vao);\n this.vao = null;\n }\n};\n\nfunction getTokenizedAttributesAndUniforms(array) {\n var result = [];\n for (var i = 0; i < array.length; i++) {\n if (array[i] === null) {\n continue;\n }\n var token = array[i].split(' ');\n result.push(token.pop());\n }\n return result;\n}\nvar Program$1 = function Program(context, name, source, configuration, fixedUniforms, showOverdrawInspector) {\n var gl = context.gl;\n this.program = gl.createProgram();\n var staticAttrInfo = getTokenizedAttributesAndUniforms(source.staticAttributes);\n var dynamicAttrInfo = configuration ? configuration.getBinderAttributes() : [];\n var allAttrInfo = staticAttrInfo.concat(dynamicAttrInfo);\n var staticUniformsInfo = source.staticUniforms ? getTokenizedAttributesAndUniforms(source.staticUniforms) : [];\n var dynamicUniformsInfo = configuration ? configuration.getBinderUniforms() : [];\n var uniformList = staticUniformsInfo.concat(dynamicUniformsInfo);\n var allUniformsInfo = [];\n for (var i$1 = 0, list = uniformList; i$1 < list.length; i$1 += 1) {\n var uniform = list[i$1];\n if (allUniformsInfo.indexOf(uniform) < 0) {\n allUniformsInfo.push(uniform);\n }\n }\n var defines = configuration ? configuration.defines() : [];\n if (showOverdrawInspector) {\n defines.push('#define OVERDRAW_INSPECTOR;');\n }\n var fragmentSource = defines.concat(prelude.fragmentSource, source.fragmentSource).join('\\n');\n var vertexSource = defines.concat(prelude.vertexSource, source.vertexSource).join('\\n');\n var fragmentShader = gl.createShader(gl.FRAGMENT_SHADER);\n if (gl.isContextLost()) {\n this.failedToCreate = true;\n return;\n }\n gl.shaderSource(fragmentShader, fragmentSource);\n gl.compileShader(fragmentShader);\n gl.attachShader(this.program, fragmentShader);\n var vertexShader = gl.createShader(gl.VERTEX_SHADER);\n if (gl.isContextLost()) {\n this.failedToCreate = true;\n return;\n }\n gl.shaderSource(vertexShader, vertexSource);\n gl.compileShader(vertexShader);\n gl.attachShader(this.program, vertexShader);\n this.attributes = {};\n var uniformLocations = {};\n this.numAttributes = allAttrInfo.length;\n for (var i = 0; i < this.numAttributes; i++) {\n if (allAttrInfo[i]) {\n gl.bindAttribLocation(this.program, i, allAttrInfo[i]);\n this.attributes[allAttrInfo[i]] = i;\n }\n }\n gl.linkProgram(this.program);\n gl.deleteShader(vertexShader);\n gl.deleteShader(fragmentShader);\n for (var it = 0; it < allUniformsInfo.length; it++) {\n var uniform$1 = allUniformsInfo[it];\n if (uniform$1 && !uniformLocations[uniform$1]) {\n var uniformLocation = gl.getUniformLocation(this.program, uniform$1);\n if (uniformLocation) {\n uniformLocations[uniform$1] = uniformLocation;\n }\n }\n }\n this.fixedUniforms = fixedUniforms(context, uniformLocations);\n this.binderUniforms = configuration ? configuration.getUniforms(context, uniformLocations) : [];\n};\nProgram$1.prototype.draw = function draw(context, drawMode, depthMode, stencilMode, colorMode, cullFaceMode, uniformValues, layerID, layoutVertexBuffer, indexBuffer, segments, currentProperties, zoom, configuration, dynamicLayoutBuffer, dynamicLayoutBuffer2) {\n var obj;\n var gl = context.gl;\n if (this.failedToCreate) {\n return;\n }\n context.program.set(this.program);\n context.setDepthMode(depthMode);\n context.setStencilMode(stencilMode);\n context.setColorMode(colorMode);\n context.setCullFace(cullFaceMode);\n for (var name in this.fixedUniforms) {\n this.fixedUniforms[name].set(uniformValues[name]);\n }\n if (configuration) {\n configuration.setUniforms(context, this.binderUniforms, currentProperties, { zoom: zoom });\n }\n var primitiveSize = (obj = {}, obj[gl.LINES] = 2, obj[gl.TRIANGLES] = 3, obj[gl.LINE_STRIP] = 1, obj)[drawMode];\n for (var i = 0, list = segments.get(); i < list.length; i += 1) {\n var segment = list[i];\n var vaos = segment.vaos || (segment.vaos = {});\n var vao = vaos[layerID] || (vaos[layerID] = new VertexArrayObject());\n vao.bind(context, this, layoutVertexBuffer, configuration ? configuration.getPaintVertexBuffers() : [], indexBuffer, segment.vertexOffset, dynamicLayoutBuffer, dynamicLayoutBuffer2);\n gl.drawElements(drawMode, segment.primitiveLength * primitiveSize, gl.UNSIGNED_SHORT, segment.primitiveOffset * primitiveSize * 2);\n }\n};\n\nfunction patternUniformValues(crossfade, painter, tile) {\n var tileRatio = 1 / pixelsToTileUnits(tile, 1, painter.transform.tileZoom);\n var numTiles = Math.pow(2, tile.tileID.overscaledZ);\n var tileSizeAtNearestZoom = tile.tileSize * Math.pow(2, painter.transform.tileZoom) / numTiles;\n var pixelX = tileSizeAtNearestZoom * (tile.tileID.canonical.x + tile.tileID.wrap * numTiles);\n var pixelY = tileSizeAtNearestZoom * tile.tileID.canonical.y;\n return {\n 'u_image': 0,\n 'u_texsize': tile.imageAtlasTexture.size,\n 'u_scale': [\n tileRatio,\n crossfade.fromScale,\n crossfade.toScale\n ],\n 'u_fade': crossfade.t,\n 'u_pixel_coord_upper': [\n pixelX >> 16,\n pixelY >> 16\n ],\n 'u_pixel_coord_lower': [\n pixelX & 65535,\n pixelY & 65535\n ]\n };\n}\nfunction bgPatternUniformValues(image, crossfade, painter, tile) {\n var imagePosA = painter.imageManager.getPattern(image.from.toString());\n var imagePosB = painter.imageManager.getPattern(image.to.toString());\n var ref = painter.imageManager.getPixelSize();\n var width = ref.width;\n var height = ref.height;\n var numTiles = Math.pow(2, tile.tileID.overscaledZ);\n var tileSizeAtNearestZoom = tile.tileSize * Math.pow(2, painter.transform.tileZoom) / numTiles;\n var pixelX = tileSizeAtNearestZoom * (tile.tileID.canonical.x + tile.tileID.wrap * numTiles);\n var pixelY = tileSizeAtNearestZoom * tile.tileID.canonical.y;\n return {\n 'u_image': 0,\n 'u_pattern_tl_a': imagePosA.tl,\n 'u_pattern_br_a': imagePosA.br,\n 'u_pattern_tl_b': imagePosB.tl,\n 'u_pattern_br_b': imagePosB.br,\n 'u_texsize': [\n width,\n height\n ],\n 'u_mix': crossfade.t,\n 'u_pattern_size_a': imagePosA.displaySize,\n 'u_pattern_size_b': imagePosB.displaySize,\n 'u_scale_a': crossfade.fromScale,\n 'u_scale_b': crossfade.toScale,\n 'u_tile_units_to_pixels': 1 / pixelsToTileUnits(tile, 1, painter.transform.tileZoom),\n 'u_pixel_coord_upper': [\n pixelX >> 16,\n pixelY >> 16\n ],\n 'u_pixel_coord_lower': [\n pixelX & 65535,\n pixelY & 65535\n ]\n };\n}\n\nvar fillExtrusionUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_lightpos': new performance.Uniform3f(context, locations.u_lightpos),\n 'u_lightintensity': new performance.Uniform1f(context, locations.u_lightintensity),\n 'u_lightcolor': new performance.Uniform3f(context, locations.u_lightcolor),\n 'u_vertical_gradient': new performance.Uniform1f(context, locations.u_vertical_gradient),\n 'u_opacity': new performance.Uniform1f(context, locations.u_opacity)\n };\n};\nvar fillExtrusionPatternUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_lightpos': new performance.Uniform3f(context, locations.u_lightpos),\n 'u_lightintensity': new performance.Uniform1f(context, locations.u_lightintensity),\n 'u_lightcolor': new performance.Uniform3f(context, locations.u_lightcolor),\n 'u_vertical_gradient': new performance.Uniform1f(context, locations.u_vertical_gradient),\n 'u_height_factor': new performance.Uniform1f(context, locations.u_height_factor),\n 'u_image': new performance.Uniform1i(context, locations.u_image),\n 'u_texsize': new performance.Uniform2f(context, locations.u_texsize),\n 'u_pixel_coord_upper': new performance.Uniform2f(context, locations.u_pixel_coord_upper),\n 'u_pixel_coord_lower': new performance.Uniform2f(context, locations.u_pixel_coord_lower),\n 'u_scale': new performance.Uniform3f(context, locations.u_scale),\n 'u_fade': new performance.Uniform1f(context, locations.u_fade),\n 'u_opacity': new performance.Uniform1f(context, locations.u_opacity)\n };\n};\nvar fillExtrusionUniformValues = function (matrix, painter, shouldUseVerticalGradient, opacity) {\n var light = painter.style.light;\n var _lp = light.properties.get('position');\n var lightPos = [\n _lp.x,\n _lp.y,\n _lp.z\n ];\n var lightMat = performance.create$1();\n if (light.properties.get('anchor') === 'viewport') {\n performance.fromRotation(lightMat, -painter.transform.angle);\n }\n performance.transformMat3(lightPos, lightPos, lightMat);\n var lightColor = light.properties.get('color');\n return {\n 'u_matrix': matrix,\n 'u_lightpos': lightPos,\n 'u_lightintensity': light.properties.get('intensity'),\n 'u_lightcolor': [\n lightColor.r,\n lightColor.g,\n lightColor.b\n ],\n 'u_vertical_gradient': +shouldUseVerticalGradient,\n 'u_opacity': opacity\n };\n};\nvar fillExtrusionPatternUniformValues = function (matrix, painter, shouldUseVerticalGradient, opacity, coord, crossfade, tile) {\n return performance.extend(fillExtrusionUniformValues(matrix, painter, shouldUseVerticalGradient, opacity), patternUniformValues(crossfade, painter, tile), { 'u_height_factor': -Math.pow(2, coord.overscaledZ) / tile.tileSize / 8 });\n};\n\nvar fillUniforms = function (context, locations) {\n return { 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix) };\n};\nvar fillPatternUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_image': new performance.Uniform1i(context, locations.u_image),\n 'u_texsize': new performance.Uniform2f(context, locations.u_texsize),\n 'u_pixel_coord_upper': new performance.Uniform2f(context, locations.u_pixel_coord_upper),\n 'u_pixel_coord_lower': new performance.Uniform2f(context, locations.u_pixel_coord_lower),\n 'u_scale': new performance.Uniform3f(context, locations.u_scale),\n 'u_fade': new performance.Uniform1f(context, locations.u_fade)\n };\n};\nvar fillOutlineUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_world': new performance.Uniform2f(context, locations.u_world)\n };\n};\nvar fillOutlinePatternUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_world': new performance.Uniform2f(context, locations.u_world),\n 'u_image': new performance.Uniform1i(context, locations.u_image),\n 'u_texsize': new performance.Uniform2f(context, locations.u_texsize),\n 'u_pixel_coord_upper': new performance.Uniform2f(context, locations.u_pixel_coord_upper),\n 'u_pixel_coord_lower': new performance.Uniform2f(context, locations.u_pixel_coord_lower),\n 'u_scale': new performance.Uniform3f(context, locations.u_scale),\n 'u_fade': new performance.Uniform1f(context, locations.u_fade)\n };\n};\nvar fillUniformValues = function (matrix) {\n return { 'u_matrix': matrix };\n};\nvar fillPatternUniformValues = function (matrix, painter, crossfade, tile) {\n return performance.extend(fillUniformValues(matrix), patternUniformValues(crossfade, painter, tile));\n};\nvar fillOutlineUniformValues = function (matrix, drawingBufferSize) {\n return {\n 'u_matrix': matrix,\n 'u_world': drawingBufferSize\n };\n};\nvar fillOutlinePatternUniformValues = function (matrix, painter, crossfade, tile, drawingBufferSize) {\n return performance.extend(fillPatternUniformValues(matrix, painter, crossfade, tile), { 'u_world': drawingBufferSize });\n};\n\nvar circleUniforms = function (context, locations) {\n return {\n 'u_camera_to_center_distance': new performance.Uniform1f(context, locations.u_camera_to_center_distance),\n 'u_scale_with_map': new performance.Uniform1i(context, locations.u_scale_with_map),\n 'u_pitch_with_map': new performance.Uniform1i(context, locations.u_pitch_with_map),\n 'u_extrude_scale': new performance.Uniform2f(context, locations.u_extrude_scale),\n 'u_device_pixel_ratio': new performance.Uniform1f(context, locations.u_device_pixel_ratio),\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix)\n };\n};\nvar circleUniformValues = function (painter, coord, tile, layer) {\n var transform = painter.transform;\n var pitchWithMap, extrudeScale;\n if (layer.paint.get('circle-pitch-alignment') === 'map') {\n var pixelRatio = pixelsToTileUnits(tile, 1, transform.zoom);\n pitchWithMap = true;\n extrudeScale = [\n pixelRatio,\n pixelRatio\n ];\n } else {\n pitchWithMap = false;\n extrudeScale = transform.pixelsToGLUnits;\n }\n return {\n 'u_camera_to_center_distance': transform.cameraToCenterDistance,\n 'u_scale_with_map': +(layer.paint.get('circle-pitch-scale') === 'map'),\n 'u_matrix': painter.translatePosMatrix(coord.posMatrix, tile, layer.paint.get('circle-translate'), layer.paint.get('circle-translate-anchor')),\n 'u_pitch_with_map': +pitchWithMap,\n 'u_device_pixel_ratio': performance.browser.devicePixelRatio,\n 'u_extrude_scale': extrudeScale\n };\n};\n\nvar collisionUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_camera_to_center_distance': new performance.Uniform1f(context, locations.u_camera_to_center_distance),\n 'u_pixels_to_tile_units': new performance.Uniform1f(context, locations.u_pixels_to_tile_units),\n 'u_extrude_scale': new performance.Uniform2f(context, locations.u_extrude_scale),\n 'u_overscale_factor': new performance.Uniform1f(context, locations.u_overscale_factor)\n };\n};\nvar collisionCircleUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_inv_matrix': new performance.UniformMatrix4f(context, locations.u_inv_matrix),\n 'u_camera_to_center_distance': new performance.Uniform1f(context, locations.u_camera_to_center_distance),\n 'u_viewport_size': new performance.Uniform2f(context, locations.u_viewport_size)\n };\n};\nvar collisionUniformValues = function (matrix, transform, tile) {\n var pixelRatio = pixelsToTileUnits(tile, 1, transform.zoom);\n var scale = Math.pow(2, transform.zoom - tile.tileID.overscaledZ);\n var overscaleFactor = tile.tileID.overscaleFactor();\n return {\n 'u_matrix': matrix,\n 'u_camera_to_center_distance': transform.cameraToCenterDistance,\n 'u_pixels_to_tile_units': pixelRatio,\n 'u_extrude_scale': [\n transform.pixelsToGLUnits[0] / (pixelRatio * scale),\n transform.pixelsToGLUnits[1] / (pixelRatio * scale)\n ],\n 'u_overscale_factor': overscaleFactor\n };\n};\nvar collisionCircleUniformValues = function (matrix, invMatrix, transform) {\n return {\n 'u_matrix': matrix,\n 'u_inv_matrix': invMatrix,\n 'u_camera_to_center_distance': transform.cameraToCenterDistance,\n 'u_viewport_size': [\n transform.width,\n transform.height\n ]\n };\n};\n\nvar debugUniforms = function (context, locations) {\n return {\n 'u_color': new performance.UniformColor(context, locations.u_color),\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_overlay': new performance.Uniform1i(context, locations.u_overlay),\n 'u_overlay_scale': new performance.Uniform1f(context, locations.u_overlay_scale)\n };\n};\nvar debugUniformValues = function (matrix, color, scaleRatio) {\n if (scaleRatio === void 0)\n scaleRatio = 1;\n return {\n 'u_matrix': matrix,\n 'u_color': color,\n 'u_overlay': 0,\n 'u_overlay_scale': scaleRatio\n };\n};\n\nvar clippingMaskUniforms = function (context, locations) {\n return { 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix) };\n};\nvar clippingMaskUniformValues = function (matrix) {\n return { 'u_matrix': matrix };\n};\n\nvar heatmapUniforms = function (context, locations) {\n return {\n 'u_extrude_scale': new performance.Uniform1f(context, locations.u_extrude_scale),\n 'u_intensity': new performance.Uniform1f(context, locations.u_intensity),\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix)\n };\n};\nvar heatmapTextureUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_world': new performance.Uniform2f(context, locations.u_world),\n 'u_image': new performance.Uniform1i(context, locations.u_image),\n 'u_color_ramp': new performance.Uniform1i(context, locations.u_color_ramp),\n 'u_opacity': new performance.Uniform1f(context, locations.u_opacity)\n };\n};\nvar heatmapUniformValues = function (matrix, tile, zoom, intensity) {\n return {\n 'u_matrix': matrix,\n 'u_extrude_scale': pixelsToTileUnits(tile, 1, zoom),\n 'u_intensity': intensity\n };\n};\nvar heatmapTextureUniformValues = function (painter, layer, textureUnit, colorRampUnit) {\n var matrix = performance.create();\n performance.ortho(matrix, 0, painter.width, painter.height, 0, 0, 1);\n var gl = painter.context.gl;\n return {\n 'u_matrix': matrix,\n 'u_world': [\n gl.drawingBufferWidth,\n gl.drawingBufferHeight\n ],\n 'u_image': textureUnit,\n 'u_color_ramp': colorRampUnit,\n 'u_opacity': layer.paint.get('heatmap-opacity')\n };\n};\n\nvar hillshadeUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_image': new performance.Uniform1i(context, locations.u_image),\n 'u_latrange': new performance.Uniform2f(context, locations.u_latrange),\n 'u_light': new performance.Uniform2f(context, locations.u_light),\n 'u_shadow': new performance.UniformColor(context, locations.u_shadow),\n 'u_highlight': new performance.UniformColor(context, locations.u_highlight),\n 'u_accent': new performance.UniformColor(context, locations.u_accent)\n };\n};\nvar hillshadePrepareUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_image': new performance.Uniform1i(context, locations.u_image),\n 'u_dimension': new performance.Uniform2f(context, locations.u_dimension),\n 'u_zoom': new performance.Uniform1f(context, locations.u_zoom),\n 'u_unpack': new performance.Uniform4f(context, locations.u_unpack)\n };\n};\nvar hillshadeUniformValues = function (painter, tile, layer) {\n var shadow = layer.paint.get('hillshade-shadow-color');\n var highlight = layer.paint.get('hillshade-highlight-color');\n var accent = layer.paint.get('hillshade-accent-color');\n var azimuthal = layer.paint.get('hillshade-illumination-direction') * (Math.PI / 180);\n if (layer.paint.get('hillshade-illumination-anchor') === 'viewport') {\n azimuthal -= painter.transform.angle;\n }\n var align = !painter.options.moving;\n return {\n 'u_matrix': painter.transform.calculatePosMatrix(tile.tileID.toUnwrapped(), align),\n 'u_image': 0,\n 'u_latrange': getTileLatRange(painter, tile.tileID),\n 'u_light': [\n layer.paint.get('hillshade-exaggeration'),\n azimuthal\n ],\n 'u_shadow': shadow,\n 'u_highlight': highlight,\n 'u_accent': accent\n };\n};\nvar hillshadeUniformPrepareValues = function (tileID, dem) {\n var stride = dem.stride;\n var matrix = performance.create();\n performance.ortho(matrix, 0, performance.EXTENT, -performance.EXTENT, 0, 0, 1);\n performance.translate(matrix, matrix, [\n 0,\n -performance.EXTENT,\n 0\n ]);\n return {\n 'u_matrix': matrix,\n 'u_image': 1,\n 'u_dimension': [\n stride,\n stride\n ],\n 'u_zoom': tileID.overscaledZ,\n 'u_unpack': dem.getUnpackVector()\n };\n};\nfunction getTileLatRange(painter, tileID) {\n var tilesAtZoom = Math.pow(2, tileID.canonical.z);\n var y = tileID.canonical.y;\n return [\n new performance.MercatorCoordinate(0, y / tilesAtZoom).toLngLat().lat,\n new performance.MercatorCoordinate(0, (y + 1) / tilesAtZoom).toLngLat().lat\n ];\n}\n\nvar lineUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_ratio': new performance.Uniform1f(context, locations.u_ratio),\n 'u_device_pixel_ratio': new performance.Uniform1f(context, locations.u_device_pixel_ratio),\n 'u_units_to_pixels': new performance.Uniform2f(context, locations.u_units_to_pixels)\n };\n};\nvar lineGradientUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_ratio': new performance.Uniform1f(context, locations.u_ratio),\n 'u_device_pixel_ratio': new performance.Uniform1f(context, locations.u_device_pixel_ratio),\n 'u_units_to_pixels': new performance.Uniform2f(context, locations.u_units_to_pixels),\n 'u_image': new performance.Uniform1i(context, locations.u_image),\n 'u_image_height': new performance.Uniform1f(context, locations.u_image_height)\n };\n};\nvar linePatternUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_texsize': new performance.Uniform2f(context, locations.u_texsize),\n 'u_ratio': new performance.Uniform1f(context, locations.u_ratio),\n 'u_device_pixel_ratio': new performance.Uniform1f(context, locations.u_device_pixel_ratio),\n 'u_image': new performance.Uniform1i(context, locations.u_image),\n 'u_units_to_pixels': new performance.Uniform2f(context, locations.u_units_to_pixels),\n 'u_scale': new performance.Uniform3f(context, locations.u_scale),\n 'u_fade': new performance.Uniform1f(context, locations.u_fade)\n };\n};\nvar lineSDFUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_ratio': new performance.Uniform1f(context, locations.u_ratio),\n 'u_device_pixel_ratio': new performance.Uniform1f(context, locations.u_device_pixel_ratio),\n 'u_units_to_pixels': new performance.Uniform2f(context, locations.u_units_to_pixels),\n 'u_patternscale_a': new performance.Uniform2f(context, locations.u_patternscale_a),\n 'u_patternscale_b': new performance.Uniform2f(context, locations.u_patternscale_b),\n 'u_sdfgamma': new performance.Uniform1f(context, locations.u_sdfgamma),\n 'u_image': new performance.Uniform1i(context, locations.u_image),\n 'u_tex_y_a': new performance.Uniform1f(context, locations.u_tex_y_a),\n 'u_tex_y_b': new performance.Uniform1f(context, locations.u_tex_y_b),\n 'u_mix': new performance.Uniform1f(context, locations.u_mix)\n };\n};\nvar lineUniformValues = function (painter, tile, layer) {\n var transform = painter.transform;\n return {\n 'u_matrix': calculateMatrix(painter, tile, layer),\n 'u_ratio': 1 / pixelsToTileUnits(tile, 1, transform.zoom),\n 'u_device_pixel_ratio': performance.browser.devicePixelRatio,\n 'u_units_to_pixels': [\n 1 / transform.pixelsToGLUnits[0],\n 1 / transform.pixelsToGLUnits[1]\n ]\n };\n};\nvar lineGradientUniformValues = function (painter, tile, layer, imageHeight) {\n return performance.extend(lineUniformValues(painter, tile, layer), {\n 'u_image': 0,\n 'u_image_height': imageHeight\n });\n};\nvar linePatternUniformValues = function (painter, tile, layer, crossfade) {\n var transform = painter.transform;\n var tileZoomRatio = calculateTileRatio(tile, transform);\n return {\n 'u_matrix': calculateMatrix(painter, tile, layer),\n 'u_texsize': tile.imageAtlasTexture.size,\n 'u_ratio': 1 / pixelsToTileUnits(tile, 1, transform.zoom),\n 'u_device_pixel_ratio': performance.browser.devicePixelRatio,\n 'u_image': 0,\n 'u_scale': [\n tileZoomRatio,\n crossfade.fromScale,\n crossfade.toScale\n ],\n 'u_fade': crossfade.t,\n 'u_units_to_pixels': [\n 1 / transform.pixelsToGLUnits[0],\n 1 / transform.pixelsToGLUnits[1]\n ]\n };\n};\nvar lineSDFUniformValues = function (painter, tile, layer, dasharray, crossfade) {\n var transform = painter.transform;\n var lineAtlas = painter.lineAtlas;\n var tileRatio = calculateTileRatio(tile, transform);\n var round = layer.layout.get('line-cap') === 'round';\n var posA = lineAtlas.getDash(dasharray.from, round);\n var posB = lineAtlas.getDash(dasharray.to, round);\n var widthA = posA.width * crossfade.fromScale;\n var widthB = posB.width * crossfade.toScale;\n return performance.extend(lineUniformValues(painter, tile, layer), {\n 'u_patternscale_a': [\n tileRatio / widthA,\n -posA.height / 2\n ],\n 'u_patternscale_b': [\n tileRatio / widthB,\n -posB.height / 2\n ],\n 'u_sdfgamma': lineAtlas.width / (Math.min(widthA, widthB) * 256 * performance.browser.devicePixelRatio) / 2,\n 'u_image': 0,\n 'u_tex_y_a': posA.y,\n 'u_tex_y_b': posB.y,\n 'u_mix': crossfade.t\n });\n};\nfunction calculateTileRatio(tile, transform) {\n return 1 / pixelsToTileUnits(tile, 1, transform.tileZoom);\n}\nfunction calculateMatrix(painter, tile, layer) {\n return painter.translatePosMatrix(tile.tileID.posMatrix, tile, layer.paint.get('line-translate'), layer.paint.get('line-translate-anchor'));\n}\n\nvar rasterUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_tl_parent': new performance.Uniform2f(context, locations.u_tl_parent),\n 'u_scale_parent': new performance.Uniform1f(context, locations.u_scale_parent),\n 'u_buffer_scale': new performance.Uniform1f(context, locations.u_buffer_scale),\n 'u_fade_t': new performance.Uniform1f(context, locations.u_fade_t),\n 'u_opacity': new performance.Uniform1f(context, locations.u_opacity),\n 'u_image0': new performance.Uniform1i(context, locations.u_image0),\n 'u_image1': new performance.Uniform1i(context, locations.u_image1),\n 'u_brightness_low': new performance.Uniform1f(context, locations.u_brightness_low),\n 'u_brightness_high': new performance.Uniform1f(context, locations.u_brightness_high),\n 'u_saturation_factor': new performance.Uniform1f(context, locations.u_saturation_factor),\n 'u_contrast_factor': new performance.Uniform1f(context, locations.u_contrast_factor),\n 'u_spin_weights': new performance.Uniform3f(context, locations.u_spin_weights)\n };\n};\nvar rasterUniformValues = function (matrix, parentTL, parentScaleBy, fade, layer) {\n return {\n 'u_matrix': matrix,\n 'u_tl_parent': parentTL,\n 'u_scale_parent': parentScaleBy,\n 'u_buffer_scale': 1,\n 'u_fade_t': fade.mix,\n 'u_opacity': fade.opacity * layer.paint.get('raster-opacity'),\n 'u_image0': 0,\n 'u_image1': 1,\n 'u_brightness_low': layer.paint.get('raster-brightness-min'),\n 'u_brightness_high': layer.paint.get('raster-brightness-max'),\n 'u_saturation_factor': saturationFactor(layer.paint.get('raster-saturation')),\n 'u_contrast_factor': contrastFactor(layer.paint.get('raster-contrast')),\n 'u_spin_weights': spinWeights(layer.paint.get('raster-hue-rotate'))\n };\n};\nfunction spinWeights(angle) {\n angle *= Math.PI / 180;\n var s = Math.sin(angle);\n var c = Math.cos(angle);\n return [\n (2 * c + 1) / 3,\n (-Math.sqrt(3) * s - c + 1) / 3,\n (Math.sqrt(3) * s - c + 1) / 3\n ];\n}\nfunction contrastFactor(contrast) {\n return contrast > 0 ? 1 / (1 - contrast) : 1 + contrast;\n}\nfunction saturationFactor(saturation) {\n return saturation > 0 ? 1 - 1 / (1.001 - saturation) : -saturation;\n}\n\nvar symbolIconUniforms = function (context, locations) {\n return {\n 'u_is_size_zoom_constant': new performance.Uniform1i(context, locations.u_is_size_zoom_constant),\n 'u_is_size_feature_constant': new performance.Uniform1i(context, locations.u_is_size_feature_constant),\n 'u_size_t': new performance.Uniform1f(context, locations.u_size_t),\n 'u_size': new performance.Uniform1f(context, locations.u_size),\n 'u_camera_to_center_distance': new performance.Uniform1f(context, locations.u_camera_to_center_distance),\n 'u_pitch': new performance.Uniform1f(context, locations.u_pitch),\n 'u_rotate_symbol': new performance.Uniform1i(context, locations.u_rotate_symbol),\n 'u_aspect_ratio': new performance.Uniform1f(context, locations.u_aspect_ratio),\n 'u_fade_change': new performance.Uniform1f(context, locations.u_fade_change),\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_label_plane_matrix': new performance.UniformMatrix4f(context, locations.u_label_plane_matrix),\n 'u_coord_matrix': new performance.UniformMatrix4f(context, locations.u_coord_matrix),\n 'u_is_text': new performance.Uniform1i(context, locations.u_is_text),\n 'u_pitch_with_map': new performance.Uniform1i(context, locations.u_pitch_with_map),\n 'u_texsize': new performance.Uniform2f(context, locations.u_texsize),\n 'u_texture': new performance.Uniform1i(context, locations.u_texture)\n };\n};\nvar symbolSDFUniforms = function (context, locations) {\n return {\n 'u_is_size_zoom_constant': new performance.Uniform1i(context, locations.u_is_size_zoom_constant),\n 'u_is_size_feature_constant': new performance.Uniform1i(context, locations.u_is_size_feature_constant),\n 'u_size_t': new performance.Uniform1f(context, locations.u_size_t),\n 'u_size': new performance.Uniform1f(context, locations.u_size),\n 'u_camera_to_center_distance': new performance.Uniform1f(context, locations.u_camera_to_center_distance),\n 'u_pitch': new performance.Uniform1f(context, locations.u_pitch),\n 'u_rotate_symbol': new performance.Uniform1i(context, locations.u_rotate_symbol),\n 'u_aspect_ratio': new performance.Uniform1f(context, locations.u_aspect_ratio),\n 'u_fade_change': new performance.Uniform1f(context, locations.u_fade_change),\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_label_plane_matrix': new performance.UniformMatrix4f(context, locations.u_label_plane_matrix),\n 'u_coord_matrix': new performance.UniformMatrix4f(context, locations.u_coord_matrix),\n 'u_is_text': new performance.Uniform1i(context, locations.u_is_text),\n 'u_pitch_with_map': new performance.Uniform1i(context, locations.u_pitch_with_map),\n 'u_texsize': new performance.Uniform2f(context, locations.u_texsize),\n 'u_texture': new performance.Uniform1i(context, locations.u_texture),\n 'u_gamma_scale': new performance.Uniform1f(context, locations.u_gamma_scale),\n 'u_device_pixel_ratio': new performance.Uniform1f(context, locations.u_device_pixel_ratio),\n 'u_is_halo': new performance.Uniform1i(context, locations.u_is_halo)\n };\n};\nvar symbolTextAndIconUniforms = function (context, locations) {\n return {\n 'u_is_size_zoom_constant': new performance.Uniform1i(context, locations.u_is_size_zoom_constant),\n 'u_is_size_feature_constant': new performance.Uniform1i(context, locations.u_is_size_feature_constant),\n 'u_size_t': new performance.Uniform1f(context, locations.u_size_t),\n 'u_size': new performance.Uniform1f(context, locations.u_size),\n 'u_camera_to_center_distance': new performance.Uniform1f(context, locations.u_camera_to_center_distance),\n 'u_pitch': new performance.Uniform1f(context, locations.u_pitch),\n 'u_rotate_symbol': new performance.Uniform1i(context, locations.u_rotate_symbol),\n 'u_aspect_ratio': new performance.Uniform1f(context, locations.u_aspect_ratio),\n 'u_fade_change': new performance.Uniform1f(context, locations.u_fade_change),\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_label_plane_matrix': new performance.UniformMatrix4f(context, locations.u_label_plane_matrix),\n 'u_coord_matrix': new performance.UniformMatrix4f(context, locations.u_coord_matrix),\n 'u_is_text': new performance.Uniform1i(context, locations.u_is_text),\n 'u_pitch_with_map': new performance.Uniform1i(context, locations.u_pitch_with_map),\n 'u_texsize': new performance.Uniform2f(context, locations.u_texsize),\n 'u_texsize_icon': new performance.Uniform2f(context, locations.u_texsize_icon),\n 'u_texture': new performance.Uniform1i(context, locations.u_texture),\n 'u_texture_icon': new performance.Uniform1i(context, locations.u_texture_icon),\n 'u_gamma_scale': new performance.Uniform1f(context, locations.u_gamma_scale),\n 'u_device_pixel_ratio': new performance.Uniform1f(context, locations.u_device_pixel_ratio),\n 'u_is_halo': new performance.Uniform1i(context, locations.u_is_halo)\n };\n};\nvar symbolIconUniformValues = function (functionType, size, rotateInShader, pitchWithMap, painter, matrix, labelPlaneMatrix, glCoordMatrix, isText, texSize) {\n var transform = painter.transform;\n return {\n 'u_is_size_zoom_constant': +(functionType === 'constant' || functionType === 'source'),\n 'u_is_size_feature_constant': +(functionType === 'constant' || functionType === 'camera'),\n 'u_size_t': size ? size.uSizeT : 0,\n 'u_size': size ? size.uSize : 0,\n 'u_camera_to_center_distance': transform.cameraToCenterDistance,\n 'u_pitch': transform.pitch / 360 * 2 * Math.PI,\n 'u_rotate_symbol': +rotateInShader,\n 'u_aspect_ratio': transform.width / transform.height,\n 'u_fade_change': painter.options.fadeDuration ? painter.symbolFadeChange : 1,\n 'u_matrix': matrix,\n 'u_label_plane_matrix': labelPlaneMatrix,\n 'u_coord_matrix': glCoordMatrix,\n 'u_is_text': +isText,\n 'u_pitch_with_map': +pitchWithMap,\n 'u_texsize': texSize,\n 'u_texture': 0\n };\n};\nvar symbolSDFUniformValues = function (functionType, size, rotateInShader, pitchWithMap, painter, matrix, labelPlaneMatrix, glCoordMatrix, isText, texSize, isHalo) {\n var transform = painter.transform;\n return performance.extend(symbolIconUniformValues(functionType, size, rotateInShader, pitchWithMap, painter, matrix, labelPlaneMatrix, glCoordMatrix, isText, texSize), {\n 'u_gamma_scale': pitchWithMap ? Math.cos(transform._pitch) * transform.cameraToCenterDistance : 1,\n 'u_device_pixel_ratio': performance.browser.devicePixelRatio,\n 'u_is_halo': +isHalo\n });\n};\nvar symbolTextAndIconUniformValues = function (functionType, size, rotateInShader, pitchWithMap, painter, matrix, labelPlaneMatrix, glCoordMatrix, texSizeSDF, texSizeIcon) {\n return performance.extend(symbolSDFUniformValues(functionType, size, rotateInShader, pitchWithMap, painter, matrix, labelPlaneMatrix, glCoordMatrix, true, texSizeSDF, true), {\n 'u_texsize_icon': texSizeIcon,\n 'u_texture_icon': 1\n });\n};\n\nvar backgroundUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_opacity': new performance.Uniform1f(context, locations.u_opacity),\n 'u_color': new performance.UniformColor(context, locations.u_color)\n };\n};\nvar backgroundPatternUniforms = function (context, locations) {\n return {\n 'u_matrix': new performance.UniformMatrix4f(context, locations.u_matrix),\n 'u_opacity': new performance.Uniform1f(context, locations.u_opacity),\n 'u_image': new performance.Uniform1i(context, locations.u_image),\n 'u_pattern_tl_a': new performance.Uniform2f(context, locations.u_pattern_tl_a),\n 'u_pattern_br_a': new performance.Uniform2f(context, locations.u_pattern_br_a),\n 'u_pattern_tl_b': new performance.Uniform2f(context, locations.u_pattern_tl_b),\n 'u_pattern_br_b': new performance.Uniform2f(context, locations.u_pattern_br_b),\n 'u_texsize': new performance.Uniform2f(context, locations.u_texsize),\n 'u_mix': new performance.Uniform1f(context, locations.u_mix),\n 'u_pattern_size_a': new performance.Uniform2f(context, locations.u_pattern_size_a),\n 'u_pattern_size_b': new performance.Uniform2f(context, locations.u_pattern_size_b),\n 'u_scale_a': new performance.Uniform1f(context, locations.u_scale_a),\n 'u_scale_b': new performance.Uniform1f(context, locations.u_scale_b),\n 'u_pixel_coord_upper': new performance.Uniform2f(context, locations.u_pixel_coord_upper),\n 'u_pixel_coord_lower': new performance.Uniform2f(context, locations.u_pixel_coord_lower),\n 'u_tile_units_to_pixels': new performance.Uniform1f(context, locations.u_tile_units_to_pixels)\n };\n};\nvar backgroundUniformValues = function (matrix, opacity, color) {\n return {\n 'u_matrix': matrix,\n 'u_opacity': opacity,\n 'u_color': color\n };\n};\nvar backgroundPatternUniformValues = function (matrix, opacity, painter, image, tile, crossfade) {\n return performance.extend(bgPatternUniformValues(image, crossfade, painter, tile), {\n 'u_matrix': matrix,\n 'u_opacity': opacity\n });\n};\n\nvar programUniforms = {\n fillExtrusion: fillExtrusionUniforms,\n fillExtrusionPattern: fillExtrusionPatternUniforms,\n fill: fillUniforms,\n fillPattern: fillPatternUniforms,\n fillOutline: fillOutlineUniforms,\n fillOutlinePattern: fillOutlinePatternUniforms,\n circle: circleUniforms,\n collisionBox: collisionUniforms,\n collisionCircle: collisionCircleUniforms,\n debug: debugUniforms,\n clippingMask: clippingMaskUniforms,\n heatmap: heatmapUniforms,\n heatmapTexture: heatmapTextureUniforms,\n hillshade: hillshadeUniforms,\n hillshadePrepare: hillshadePrepareUniforms,\n line: lineUniforms,\n lineGradient: lineGradientUniforms,\n linePattern: linePatternUniforms,\n lineSDF: lineSDFUniforms,\n raster: rasterUniforms,\n symbolIcon: symbolIconUniforms,\n symbolSDF: symbolSDFUniforms,\n symbolTextAndIcon: symbolTextAndIconUniforms,\n background: backgroundUniforms,\n backgroundPattern: backgroundPatternUniforms\n};\n\nvar quadTriangles;\nfunction drawCollisionDebug(painter, sourceCache, layer, coords, translate, translateAnchor, isText) {\n var context = painter.context;\n var gl = context.gl;\n var program = painter.useProgram('collisionBox');\n var tileBatches = [];\n var circleCount = 0;\n var circleOffset = 0;\n for (var i = 0; i < coords.length; i++) {\n var coord = coords[i];\n var tile = sourceCache.getTile(coord);\n var bucket = tile.getBucket(layer);\n if (!bucket) {\n continue;\n }\n var posMatrix = coord.posMatrix;\n if (translate[0] !== 0 || translate[1] !== 0) {\n posMatrix = painter.translatePosMatrix(coord.posMatrix, tile, translate, translateAnchor);\n }\n var buffers = isText ? bucket.textCollisionBox : bucket.iconCollisionBox;\n var circleArray = bucket.collisionCircleArray;\n if (circleArray.length > 0) {\n var invTransform = performance.create();\n var transform = posMatrix;\n performance.mul(invTransform, bucket.placementInvProjMatrix, painter.transform.glCoordMatrix);\n performance.mul(invTransform, invTransform, bucket.placementViewportMatrix);\n tileBatches.push({\n circleArray: circleArray,\n circleOffset: circleOffset,\n transform: transform,\n invTransform: invTransform\n });\n circleCount += circleArray.length / 4;\n circleOffset = circleCount;\n }\n if (!buffers) {\n continue;\n }\n program.draw(context, gl.LINES, DepthMode.disabled, StencilMode.disabled, painter.colorModeForRenderPass(), CullFaceMode.disabled, collisionUniformValues(posMatrix, painter.transform, tile), layer.id, buffers.layoutVertexBuffer, buffers.indexBuffer, buffers.segments, null, painter.transform.zoom, null, null, buffers.collisionVertexBuffer);\n }\n if (!isText || !tileBatches.length) {\n return;\n }\n var circleProgram = painter.useProgram('collisionCircle');\n var vertexData = new performance.StructArrayLayout2f1f2i16();\n vertexData.resize(circleCount * 4);\n vertexData._trim();\n var vertexOffset = 0;\n for (var i$2 = 0, list = tileBatches; i$2 < list.length; i$2 += 1) {\n var batch = list[i$2];\n for (var i$1 = 0; i$1 < batch.circleArray.length / 4; i$1++) {\n var circleIdx = i$1 * 4;\n var x = batch.circleArray[circleIdx + 0];\n var y = batch.circleArray[circleIdx + 1];\n var radius = batch.circleArray[circleIdx + 2];\n var collision = batch.circleArray[circleIdx + 3];\n vertexData.emplace(vertexOffset++, x, y, radius, collision, 0);\n vertexData.emplace(vertexOffset++, x, y, radius, collision, 1);\n vertexData.emplace(vertexOffset++, x, y, radius, collision, 2);\n vertexData.emplace(vertexOffset++, x, y, radius, collision, 3);\n }\n }\n if (!quadTriangles || quadTriangles.length < circleCount * 2) {\n quadTriangles = createQuadTriangles(circleCount);\n }\n var indexBuffer = context.createIndexBuffer(quadTriangles, true);\n var vertexBuffer = context.createVertexBuffer(vertexData, performance.collisionCircleLayout.members, true);\n for (var i$3 = 0, list$1 = tileBatches; i$3 < list$1.length; i$3 += 1) {\n var batch$1 = list$1[i$3];\n var uniforms = collisionCircleUniformValues(batch$1.transform, batch$1.invTransform, painter.transform);\n circleProgram.draw(context, gl.TRIANGLES, DepthMode.disabled, StencilMode.disabled, painter.colorModeForRenderPass(), CullFaceMode.disabled, uniforms, layer.id, vertexBuffer, indexBuffer, performance.SegmentVector.simpleSegment(0, batch$1.circleOffset * 2, batch$1.circleArray.length, batch$1.circleArray.length / 2), null, painter.transform.zoom, null, null, null);\n }\n vertexBuffer.destroy();\n indexBuffer.destroy();\n}\nfunction createQuadTriangles(quadCount) {\n var triCount = quadCount * 2;\n var array = new performance.StructArrayLayout3ui6();\n array.resize(triCount);\n array._trim();\n for (var i = 0; i < triCount; i++) {\n var idx = i * 6;\n array.uint16[idx + 0] = i * 4 + 0;\n array.uint16[idx + 1] = i * 4 + 1;\n array.uint16[idx + 2] = i * 4 + 2;\n array.uint16[idx + 3] = i * 4 + 2;\n array.uint16[idx + 4] = i * 4 + 3;\n array.uint16[idx + 5] = i * 4 + 0;\n }\n return array;\n}\n\nvar identityMat4 = performance.identity(new Float32Array(16));\nfunction drawSymbols(painter, sourceCache, layer, coords, variableOffsets) {\n if (painter.renderPass !== 'translucent') {\n return;\n }\n var stencilMode = StencilMode.disabled;\n var colorMode = painter.colorModeForRenderPass();\n var variablePlacement = layer.layout.get('text-variable-anchor');\n if (variablePlacement) {\n updateVariableAnchors(coords, painter, layer, sourceCache, layer.layout.get('text-rotation-alignment'), layer.layout.get('text-pitch-alignment'), variableOffsets);\n }\n if (layer.paint.get('icon-opacity').constantOr(1) !== 0) {\n drawLayerSymbols(painter, sourceCache, layer, coords, false, layer.paint.get('icon-translate'), layer.paint.get('icon-translate-anchor'), layer.layout.get('icon-rotation-alignment'), layer.layout.get('icon-pitch-alignment'), layer.layout.get('icon-keep-upright'), stencilMode, colorMode);\n }\n if (layer.paint.get('text-opacity').constantOr(1) !== 0) {\n drawLayerSymbols(painter, sourceCache, layer, coords, true, layer.paint.get('text-translate'), layer.paint.get('text-translate-anchor'), layer.layout.get('text-rotation-alignment'), layer.layout.get('text-pitch-alignment'), layer.layout.get('text-keep-upright'), stencilMode, colorMode);\n }\n if (sourceCache.map.showCollisionBoxes) {\n drawCollisionDebug(painter, sourceCache, layer, coords, layer.paint.get('text-translate'), layer.paint.get('text-translate-anchor'), true);\n drawCollisionDebug(painter, sourceCache, layer, coords, layer.paint.get('icon-translate'), layer.paint.get('icon-translate-anchor'), false);\n }\n}\nfunction calculateVariableRenderShift(anchor, width, height, textOffset, textBoxScale, renderTextSize) {\n var ref = performance.getAnchorAlignment(anchor);\n var horizontalAlign = ref.horizontalAlign;\n var verticalAlign = ref.verticalAlign;\n var shiftX = -(horizontalAlign - 0.5) * width;\n var shiftY = -(verticalAlign - 0.5) * height;\n var variableOffset = performance.evaluateVariableOffset(anchor, textOffset);\n return new performance.Point((shiftX / textBoxScale + variableOffset[0]) * renderTextSize, (shiftY / textBoxScale + variableOffset[1]) * renderTextSize);\n}\nfunction updateVariableAnchors(coords, painter, layer, sourceCache, rotationAlignment, pitchAlignment, variableOffsets) {\n var tr = painter.transform;\n var rotateWithMap = rotationAlignment === 'map';\n var pitchWithMap = pitchAlignment === 'map';\n for (var i = 0, list = coords; i < list.length; i += 1) {\n var coord = list[i];\n var tile = sourceCache.getTile(coord);\n var bucket = tile.getBucket(layer);\n if (!bucket || !bucket.text || !bucket.text.segments.get().length) {\n continue;\n }\n var sizeData = bucket.textSizeData;\n var size = performance.evaluateSizeForZoom(sizeData, tr.zoom);\n var pixelToTileScale = pixelsToTileUnits(tile, 1, painter.transform.zoom);\n var labelPlaneMatrix = getLabelPlaneMatrix(coord.posMatrix, pitchWithMap, rotateWithMap, painter.transform, pixelToTileScale);\n var updateTextFitIcon = layer.layout.get('icon-text-fit') !== 'none' && bucket.hasIconData();\n if (size) {\n var tileScale = Math.pow(2, tr.zoom - tile.tileID.overscaledZ);\n updateVariableAnchorsForBucket(bucket, rotateWithMap, pitchWithMap, variableOffsets, performance.symbolSize, tr, labelPlaneMatrix, coord.posMatrix, tileScale, size, updateTextFitIcon);\n }\n }\n}\nfunction updateVariableAnchorsForBucket(bucket, rotateWithMap, pitchWithMap, variableOffsets, symbolSize, transform, labelPlaneMatrix, posMatrix, tileScale, size, updateTextFitIcon) {\n var placedSymbols = bucket.text.placedSymbolArray;\n var dynamicTextLayoutVertexArray = bucket.text.dynamicLayoutVertexArray;\n var dynamicIconLayoutVertexArray = bucket.icon.dynamicLayoutVertexArray;\n var placedTextShifts = {};\n dynamicTextLayoutVertexArray.clear();\n for (var s = 0; s < placedSymbols.length; s++) {\n var symbol = placedSymbols.get(s);\n var skipOrientation = bucket.allowVerticalPlacement && !symbol.placedOrientation;\n var variableOffset = !symbol.hidden && symbol.crossTileID && !skipOrientation ? variableOffsets[symbol.crossTileID] : null;\n if (!variableOffset) {\n hideGlyphs(symbol.numGlyphs, dynamicTextLayoutVertexArray);\n } else {\n var tileAnchor = new performance.Point(symbol.anchorX, symbol.anchorY);\n var projectedAnchor = project(tileAnchor, pitchWithMap ? posMatrix : labelPlaneMatrix);\n var perspectiveRatio = getPerspectiveRatio(transform.cameraToCenterDistance, projectedAnchor.signedDistanceFromCamera);\n var renderTextSize = symbolSize.evaluateSizeForFeature(bucket.textSizeData, size, symbol) * perspectiveRatio / performance.ONE_EM;\n if (pitchWithMap) {\n renderTextSize *= bucket.tilePixelRatio / tileScale;\n }\n var width = variableOffset.width;\n var height = variableOffset.height;\n var anchor = variableOffset.anchor;\n var textOffset = variableOffset.textOffset;\n var textBoxScale = variableOffset.textBoxScale;\n var shift = calculateVariableRenderShift(anchor, width, height, textOffset, textBoxScale, renderTextSize);\n var shiftedAnchor = pitchWithMap ? project(tileAnchor.add(shift), labelPlaneMatrix).point : projectedAnchor.point.add(rotateWithMap ? shift.rotate(-transform.angle) : shift);\n var angle = bucket.allowVerticalPlacement && symbol.placedOrientation === performance.WritingMode.vertical ? Math.PI / 2 : 0;\n for (var g = 0; g < symbol.numGlyphs; g++) {\n performance.addDynamicAttributes(dynamicTextLayoutVertexArray, shiftedAnchor, angle);\n }\n if (updateTextFitIcon && symbol.associatedIconIndex >= 0) {\n placedTextShifts[symbol.associatedIconIndex] = {\n shiftedAnchor: shiftedAnchor,\n angle: angle\n };\n }\n }\n }\n if (updateTextFitIcon) {\n dynamicIconLayoutVertexArray.clear();\n var placedIcons = bucket.icon.placedSymbolArray;\n for (var i = 0; i < placedIcons.length; i++) {\n var placedIcon = placedIcons.get(i);\n if (placedIcon.hidden) {\n hideGlyphs(placedIcon.numGlyphs, dynamicIconLayoutVertexArray);\n } else {\n var shift$1 = placedTextShifts[i];\n if (!shift$1) {\n hideGlyphs(placedIcon.numGlyphs, dynamicIconLayoutVertexArray);\n } else {\n for (var g$1 = 0; g$1 < placedIcon.numGlyphs; g$1++) {\n performance.addDynamicAttributes(dynamicIconLayoutVertexArray, shift$1.shiftedAnchor, shift$1.angle);\n }\n }\n }\n }\n bucket.icon.dynamicLayoutVertexBuffer.updateData(dynamicIconLayoutVertexArray);\n }\n bucket.text.dynamicLayoutVertexBuffer.updateData(dynamicTextLayoutVertexArray);\n}\nfunction getSymbolProgramName(isSDF, isText, bucket) {\n if (bucket.iconsInText && isText) {\n return 'symbolTextAndIcon';\n } else if (isSDF) {\n return 'symbolSDF';\n } else {\n return 'symbolIcon';\n }\n}\nfunction drawLayerSymbols(painter, sourceCache, layer, coords, isText, translate, translateAnchor, rotationAlignment, pitchAlignment, keepUpright, stencilMode, colorMode) {\n var context = painter.context;\n var gl = context.gl;\n var tr = painter.transform;\n var rotateWithMap = rotationAlignment === 'map';\n var pitchWithMap = pitchAlignment === 'map';\n var alongLine = rotateWithMap && layer.layout.get('symbol-placement') !== 'point';\n var rotateInShader = rotateWithMap && !pitchWithMap && !alongLine;\n var hasSortKey = layer.layout.get('symbol-sort-key').constantOr(1) !== undefined;\n var sortFeaturesByKey = false;\n var depthMode = painter.depthModeForSublayer(0, DepthMode.ReadOnly);\n var variablePlacement = layer.layout.get('text-variable-anchor');\n var tileRenderState = [];\n for (var i$1 = 0, list$1 = coords; i$1 < list$1.length; i$1 += 1) {\n var coord = list$1[i$1];\n var tile = sourceCache.getTile(coord);\n var bucket = tile.getBucket(layer);\n if (!bucket) {\n continue;\n }\n var buffers = isText ? bucket.text : bucket.icon;\n if (!buffers || !buffers.segments.get().length) {\n continue;\n }\n var programConfiguration = buffers.programConfigurations.get(layer.id);\n var isSDF = isText || bucket.sdfIcons;\n var sizeData = isText ? bucket.textSizeData : bucket.iconSizeData;\n var transformed = pitchWithMap || tr.pitch !== 0;\n var program = painter.useProgram(getSymbolProgramName(isSDF, isText, bucket), programConfiguration);\n var size = performance.evaluateSizeForZoom(sizeData, tr.zoom);\n var texSize = void 0;\n var texSizeIcon = [\n 0,\n 0\n ];\n var atlasTexture = void 0;\n var atlasInterpolation = void 0;\n var atlasTextureIcon = null;\n var atlasInterpolationIcon = void 0;\n if (isText) {\n atlasTexture = tile.glyphAtlasTexture;\n atlasInterpolation = gl.LINEAR;\n texSize = tile.glyphAtlasTexture.size;\n if (bucket.iconsInText) {\n texSizeIcon = tile.imageAtlasTexture.size;\n atlasTextureIcon = tile.imageAtlasTexture;\n var zoomDependentSize = sizeData.kind === 'composite' || sizeData.kind === 'camera';\n atlasInterpolationIcon = transformed || painter.options.rotating || painter.options.zooming || zoomDependentSize ? gl.LINEAR : gl.NEAREST;\n }\n } else {\n var iconScaled = layer.layout.get('icon-size').constantOr(0) !== 1 || bucket.iconsNeedLinear;\n atlasTexture = tile.imageAtlasTexture;\n atlasInterpolation = isSDF || painter.options.rotating || painter.options.zooming || iconScaled || transformed ? gl.LINEAR : gl.NEAREST;\n texSize = tile.imageAtlasTexture.size;\n }\n var s = pixelsToTileUnits(tile, 1, painter.transform.zoom);\n var labelPlaneMatrix = getLabelPlaneMatrix(coord.posMatrix, pitchWithMap, rotateWithMap, painter.transform, s);\n var glCoordMatrix = getGlCoordMatrix(coord.posMatrix, pitchWithMap, rotateWithMap, painter.transform, s);\n var hasVariableAnchors = variablePlacement && bucket.hasTextData();\n var updateTextFitIcon = layer.layout.get('icon-text-fit') !== 'none' && hasVariableAnchors && bucket.hasIconData();\n if (alongLine) {\n updateLineLabels(bucket, coord.posMatrix, painter, isText, labelPlaneMatrix, glCoordMatrix, pitchWithMap, keepUpright);\n }\n var matrix = painter.translatePosMatrix(coord.posMatrix, tile, translate, translateAnchor), uLabelPlaneMatrix = alongLine || isText && variablePlacement || updateTextFitIcon ? identityMat4 : labelPlaneMatrix, uglCoordMatrix = painter.translatePosMatrix(glCoordMatrix, tile, translate, translateAnchor, true);\n var hasHalo = isSDF && layer.paint.get(isText ? 'text-halo-width' : 'icon-halo-width').constantOr(1) !== 0;\n var uniformValues = void 0;\n if (isSDF) {\n if (!bucket.iconsInText) {\n uniformValues = symbolSDFUniformValues(sizeData.kind, size, rotateInShader, pitchWithMap, painter, matrix, uLabelPlaneMatrix, uglCoordMatrix, isText, texSize, true);\n } else {\n uniformValues = symbolTextAndIconUniformValues(sizeData.kind, size, rotateInShader, pitchWithMap, painter, matrix, uLabelPlaneMatrix, uglCoordMatrix, texSize, texSizeIcon);\n }\n } else {\n uniformValues = symbolIconUniformValues(sizeData.kind, size, rotateInShader, pitchWithMap, painter, matrix, uLabelPlaneMatrix, uglCoordMatrix, isText, texSize);\n }\n var state = {\n program: program,\n buffers: buffers,\n uniformValues: uniformValues,\n atlasTexture: atlasTexture,\n atlasTextureIcon: atlasTextureIcon,\n atlasInterpolation: atlasInterpolation,\n atlasInterpolationIcon: atlasInterpolationIcon,\n isSDF: isSDF,\n hasHalo: hasHalo\n };\n if (hasSortKey && bucket.canOverlap) {\n sortFeaturesByKey = true;\n var oldSegments = buffers.segments.get();\n for (var i = 0, list = oldSegments; i < list.length; i += 1) {\n var segment = list[i];\n tileRenderState.push({\n segments: new performance.SegmentVector([segment]),\n sortKey: segment.sortKey,\n state: state\n });\n }\n } else {\n tileRenderState.push({\n segments: buffers.segments,\n sortKey: 0,\n state: state\n });\n }\n }\n if (sortFeaturesByKey) {\n tileRenderState.sort(function (a, b) {\n return a.sortKey - b.sortKey;\n });\n }\n for (var i$2 = 0, list$2 = tileRenderState; i$2 < list$2.length; i$2 += 1) {\n var segmentState = list$2[i$2];\n var state$1 = segmentState.state;\n context.activeTexture.set(gl.TEXTURE0);\n state$1.atlasTexture.bind(state$1.atlasInterpolation, gl.CLAMP_TO_EDGE);\n if (state$1.atlasTextureIcon) {\n context.activeTexture.set(gl.TEXTURE1);\n if (state$1.atlasTextureIcon) {\n state$1.atlasTextureIcon.bind(state$1.atlasInterpolationIcon, gl.CLAMP_TO_EDGE);\n }\n }\n if (state$1.isSDF) {\n var uniformValues$1 = state$1.uniformValues;\n if (state$1.hasHalo) {\n uniformValues$1['u_is_halo'] = 1;\n drawSymbolElements(state$1.buffers, segmentState.segments, layer, painter, state$1.program, depthMode, stencilMode, colorMode, uniformValues$1);\n }\n uniformValues$1['u_is_halo'] = 0;\n }\n drawSymbolElements(state$1.buffers, segmentState.segments, layer, painter, state$1.program, depthMode, stencilMode, colorMode, state$1.uniformValues);\n }\n}\nfunction drawSymbolElements(buffers, segments, layer, painter, program, depthMode, stencilMode, colorMode, uniformValues) {\n var context = painter.context;\n var gl = context.gl;\n program.draw(context, gl.TRIANGLES, depthMode, stencilMode, colorMode, CullFaceMode.disabled, uniformValues, layer.id, buffers.layoutVertexBuffer, buffers.indexBuffer, segments, layer.paint, painter.transform.zoom, buffers.programConfigurations.get(layer.id), buffers.dynamicLayoutVertexBuffer, buffers.opacityVertexBuffer);\n}\n\nfunction drawCircles(painter, sourceCache, layer, coords) {\n if (painter.renderPass !== 'translucent') {\n return;\n }\n var opacity = layer.paint.get('circle-opacity');\n var strokeWidth = layer.paint.get('circle-stroke-width');\n var strokeOpacity = layer.paint.get('circle-stroke-opacity');\n var sortFeaturesByKey = layer.layout.get('circle-sort-key').constantOr(1) !== undefined;\n if (opacity.constantOr(1) === 0 && (strokeWidth.constantOr(1) === 0 || strokeOpacity.constantOr(1) === 0)) {\n return;\n }\n var context = painter.context;\n var gl = context.gl;\n var depthMode = painter.depthModeForSublayer(0, DepthMode.ReadOnly);\n var stencilMode = StencilMode.disabled;\n var colorMode = painter.colorModeForRenderPass();\n var segmentsRenderStates = [];\n for (var i = 0; i < coords.length; i++) {\n var coord = coords[i];\n var tile = sourceCache.getTile(coord);\n var bucket = tile.getBucket(layer);\n if (!bucket) {\n continue;\n }\n var programConfiguration = bucket.programConfigurations.get(layer.id);\n var program = painter.useProgram('circle', programConfiguration);\n var layoutVertexBuffer = bucket.layoutVertexBuffer;\n var indexBuffer = bucket.indexBuffer;\n var uniformValues = circleUniformValues(painter, coord, tile, layer);\n var state = {\n programConfiguration: programConfiguration,\n program: program,\n layoutVertexBuffer: layoutVertexBuffer,\n indexBuffer: indexBuffer,\n uniformValues: uniformValues\n };\n if (sortFeaturesByKey) {\n var oldSegments = bucket.segments.get();\n for (var i$1 = 0, list = oldSegments; i$1 < list.length; i$1 += 1) {\n var segment = list[i$1];\n segmentsRenderStates.push({\n segments: new performance.SegmentVector([segment]),\n sortKey: segment.sortKey,\n state: state\n });\n }\n } else {\n segmentsRenderStates.push({\n segments: bucket.segments,\n sortKey: 0,\n state: state\n });\n }\n }\n if (sortFeaturesByKey) {\n segmentsRenderStates.sort(function (a, b) {\n return a.sortKey - b.sortKey;\n });\n }\n for (var i$2 = 0, list$1 = segmentsRenderStates; i$2 < list$1.length; i$2 += 1) {\n var segmentsState = list$1[i$2];\n var ref = segmentsState.state;\n var programConfiguration$1 = ref.programConfiguration;\n var program$1 = ref.program;\n var layoutVertexBuffer$1 = ref.layoutVertexBuffer;\n var indexBuffer$1 = ref.indexBuffer;\n var uniformValues$1 = ref.uniformValues;\n var segments = segmentsState.segments;\n program$1.draw(context, gl.TRIANGLES, depthMode, stencilMode, colorMode, CullFaceMode.disabled, uniformValues$1, layer.id, layoutVertexBuffer$1, indexBuffer$1, segments, layer.paint, painter.transform.zoom, programConfiguration$1);\n }\n}\n\nfunction drawHeatmap(painter, sourceCache, layer, coords) {\n if (layer.paint.get('heatmap-opacity') === 0) {\n return;\n }\n if (painter.renderPass === 'offscreen') {\n var context = painter.context;\n var gl = context.gl;\n var stencilMode = StencilMode.disabled;\n var colorMode = new ColorMode([\n gl.ONE,\n gl.ONE\n ], performance.Color.transparent, [\n true,\n true,\n true,\n true\n ]);\n bindFramebuffer(context, painter, layer);\n context.clear({ color: performance.Color.transparent });\n for (var i = 0; i < coords.length; i++) {\n var coord = coords[i];\n if (sourceCache.hasRenderableParent(coord)) {\n continue;\n }\n var tile = sourceCache.getTile(coord);\n var bucket = tile.getBucket(layer);\n if (!bucket) {\n continue;\n }\n var programConfiguration = bucket.programConfigurations.get(layer.id);\n var program = painter.useProgram('heatmap', programConfiguration);\n var ref = painter.transform;\n var zoom = ref.zoom;\n program.draw(context, gl.TRIANGLES, DepthMode.disabled, stencilMode, colorMode, CullFaceMode.disabled, heatmapUniformValues(coord.posMatrix, tile, zoom, layer.paint.get('heatmap-intensity')), layer.id, bucket.layoutVertexBuffer, bucket.indexBuffer, bucket.segments, layer.paint, painter.transform.zoom, programConfiguration);\n }\n context.viewport.set([\n 0,\n 0,\n painter.width,\n painter.height\n ]);\n } else if (painter.renderPass === 'translucent') {\n painter.context.setColorMode(painter.colorModeForRenderPass());\n renderTextureToMap(painter, layer);\n }\n}\nfunction bindFramebuffer(context, painter, layer) {\n var gl = context.gl;\n context.activeTexture.set(gl.TEXTURE1);\n context.viewport.set([\n 0,\n 0,\n painter.width / 4,\n painter.height / 4\n ]);\n var fbo = layer.heatmapFbo;\n if (!fbo) {\n var texture = gl.createTexture();\n gl.bindTexture(gl.TEXTURE_2D, texture);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n fbo = layer.heatmapFbo = context.createFramebuffer(painter.width / 4, painter.height / 4, false);\n bindTextureToFramebuffer(context, painter, texture, fbo);\n } else {\n gl.bindTexture(gl.TEXTURE_2D, fbo.colorAttachment.get());\n context.bindFramebuffer.set(fbo.framebuffer);\n }\n}\nfunction bindTextureToFramebuffer(context, painter, texture, fbo) {\n var gl = context.gl;\n var internalFormat = context.extRenderToTextureHalfFloat ? context.extTextureHalfFloat.HALF_FLOAT_OES : gl.UNSIGNED_BYTE;\n gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, painter.width / 4, painter.height / 4, 0, gl.RGBA, internalFormat, null);\n fbo.colorAttachment.set(texture);\n}\nfunction renderTextureToMap(painter, layer) {\n var context = painter.context;\n var gl = context.gl;\n var fbo = layer.heatmapFbo;\n if (!fbo) {\n return;\n }\n context.activeTexture.set(gl.TEXTURE0);\n gl.bindTexture(gl.TEXTURE_2D, fbo.colorAttachment.get());\n context.activeTexture.set(gl.TEXTURE1);\n var colorRampTexture = layer.colorRampTexture;\n if (!colorRampTexture) {\n colorRampTexture = layer.colorRampTexture = new performance.Texture(context, layer.colorRamp, gl.RGBA);\n }\n colorRampTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n painter.useProgram('heatmapTexture').draw(context, gl.TRIANGLES, DepthMode.disabled, StencilMode.disabled, painter.colorModeForRenderPass(), CullFaceMode.disabled, heatmapTextureUniformValues(painter, layer, 0, 1), layer.id, painter.viewportBuffer, painter.quadTriangleIndexBuffer, painter.viewportSegments, layer.paint, painter.transform.zoom);\n}\n\nfunction drawLine(painter, sourceCache, layer, coords) {\n if (painter.renderPass !== 'translucent') {\n return;\n }\n var opacity = layer.paint.get('line-opacity');\n var width = layer.paint.get('line-width');\n if (opacity.constantOr(1) === 0 || width.constantOr(1) === 0) {\n return;\n }\n var depthMode = painter.depthModeForSublayer(0, DepthMode.ReadOnly);\n var colorMode = painter.colorModeForRenderPass();\n var dasharray = layer.paint.get('line-dasharray');\n var patternProperty = layer.paint.get('line-pattern');\n var image = patternProperty.constantOr(1);\n var gradient = layer.paint.get('line-gradient');\n var crossfade = layer.getCrossfadeParameters();\n var programId = image ? 'linePattern' : dasharray ? 'lineSDF' : gradient ? 'lineGradient' : 'line';\n var context = painter.context;\n var gl = context.gl;\n var firstTile = true;\n for (var i = 0, list = coords; i < list.length; i += 1) {\n var coord = list[i];\n var tile = sourceCache.getTile(coord);\n if (image && !tile.patternsLoaded()) {\n continue;\n }\n var bucket = tile.getBucket(layer);\n if (!bucket) {\n continue;\n }\n var programConfiguration = bucket.programConfigurations.get(layer.id);\n var prevProgram = painter.context.program.get();\n var program = painter.useProgram(programId, programConfiguration);\n var programChanged = firstTile || program.program !== prevProgram;\n var constantPattern = patternProperty.constantOr(null);\n if (constantPattern && tile.imageAtlas) {\n var atlas = tile.imageAtlas;\n var posTo = atlas.patternPositions[constantPattern.to.toString()];\n var posFrom = atlas.patternPositions[constantPattern.from.toString()];\n if (posTo && posFrom) {\n programConfiguration.setConstantPatternPositions(posTo, posFrom);\n }\n }\n var uniformValues = image ? linePatternUniformValues(painter, tile, layer, crossfade) : dasharray ? lineSDFUniformValues(painter, tile, layer, dasharray, crossfade) : gradient ? lineGradientUniformValues(painter, tile, layer, bucket.lineClipsArray.length) : lineUniformValues(painter, tile, layer);\n if (image) {\n context.activeTexture.set(gl.TEXTURE0);\n tile.imageAtlasTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n programConfiguration.updatePaintBuffers(crossfade);\n } else if (dasharray && (programChanged || painter.lineAtlas.dirty)) {\n context.activeTexture.set(gl.TEXTURE0);\n painter.lineAtlas.bind(context);\n } else if (gradient) {\n var layerGradient = bucket.gradients[layer.id];\n var gradientTexture = layerGradient.texture;\n if (layer.gradientVersion !== layerGradient.version) {\n var textureResolution = 256;\n if (layer.stepInterpolant) {\n var sourceMaxZoom = sourceCache.getSource().maxzoom;\n var potentialOverzoom = coord.canonical.z === sourceMaxZoom ? Math.ceil(1 << painter.transform.maxZoom - coord.canonical.z) : 1;\n var lineLength = bucket.maxLineLength / performance.EXTENT;\n var maxTilePixelSize = 1024;\n var maxTextureCoverage = lineLength * maxTilePixelSize * potentialOverzoom;\n textureResolution = performance.clamp(performance.nextPowerOfTwo(maxTextureCoverage), 256, context.maxTextureSize);\n }\n layerGradient.gradient = performance.renderColorRamp({\n expression: layer.gradientExpression(),\n evaluationKey: 'lineProgress',\n resolution: textureResolution,\n image: layerGradient.gradient || undefined,\n clips: bucket.lineClipsArray\n });\n if (layerGradient.texture) {\n layerGradient.texture.update(layerGradient.gradient);\n } else {\n layerGradient.texture = new performance.Texture(context, layerGradient.gradient, gl.RGBA);\n }\n layerGradient.version = layer.gradientVersion;\n gradientTexture = layerGradient.texture;\n }\n context.activeTexture.set(gl.TEXTURE0);\n gradientTexture.bind(layer.stepInterpolant ? gl.NEAREST : gl.LINEAR, gl.CLAMP_TO_EDGE);\n }\n program.draw(context, gl.TRIANGLES, depthMode, painter.stencilModeForClipping(coord), colorMode, CullFaceMode.disabled, uniformValues, layer.id, bucket.layoutVertexBuffer, bucket.indexBuffer, bucket.segments, layer.paint, painter.transform.zoom, programConfiguration, bucket.layoutVertexBuffer2);\n firstTile = false;\n }\n}\n\nfunction drawFill(painter, sourceCache, layer, coords) {\n var color = layer.paint.get('fill-color');\n var opacity = layer.paint.get('fill-opacity');\n if (opacity.constantOr(1) === 0) {\n return;\n }\n var colorMode = painter.colorModeForRenderPass();\n var pattern = layer.paint.get('fill-pattern');\n var pass = painter.opaquePassEnabledForLayer() && (!pattern.constantOr(1) && color.constantOr(performance.Color.transparent).a === 1 && opacity.constantOr(0) === 1) ? 'opaque' : 'translucent';\n if (painter.renderPass === pass) {\n var depthMode = painter.depthModeForSublayer(1, painter.renderPass === 'opaque' ? DepthMode.ReadWrite : DepthMode.ReadOnly);\n drawFillTiles(painter, sourceCache, layer, coords, depthMode, colorMode, false);\n }\n if (painter.renderPass === 'translucent' && layer.paint.get('fill-antialias')) {\n var depthMode$1 = painter.depthModeForSublayer(layer.getPaintProperty('fill-outline-color') ? 2 : 0, DepthMode.ReadOnly);\n drawFillTiles(painter, sourceCache, layer, coords, depthMode$1, colorMode, true);\n }\n}\nfunction drawFillTiles(painter, sourceCache, layer, coords, depthMode, colorMode, isOutline) {\n var gl = painter.context.gl;\n var patternProperty = layer.paint.get('fill-pattern');\n var image = patternProperty && patternProperty.constantOr(1);\n var crossfade = layer.getCrossfadeParameters();\n var drawMode, programName, uniformValues, indexBuffer, segments;\n if (!isOutline) {\n programName = image ? 'fillPattern' : 'fill';\n drawMode = gl.TRIANGLES;\n } else {\n programName = image && !layer.getPaintProperty('fill-outline-color') ? 'fillOutlinePattern' : 'fillOutline';\n drawMode = gl.LINES;\n }\n for (var i = 0, list = coords; i < list.length; i += 1) {\n var coord = list[i];\n var tile = sourceCache.getTile(coord);\n if (image && !tile.patternsLoaded()) {\n continue;\n }\n var bucket = tile.getBucket(layer);\n if (!bucket) {\n continue;\n }\n var programConfiguration = bucket.programConfigurations.get(layer.id);\n var program = painter.useProgram(programName, programConfiguration);\n if (image) {\n painter.context.activeTexture.set(gl.TEXTURE0);\n tile.imageAtlasTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n programConfiguration.updatePaintBuffers(crossfade);\n }\n var constantPattern = patternProperty.constantOr(null);\n if (constantPattern && tile.imageAtlas) {\n var atlas = tile.imageAtlas;\n var posTo = atlas.patternPositions[constantPattern.to.toString()];\n var posFrom = atlas.patternPositions[constantPattern.from.toString()];\n if (posTo && posFrom) {\n programConfiguration.setConstantPatternPositions(posTo, posFrom);\n }\n }\n var tileMatrix = painter.translatePosMatrix(coord.posMatrix, tile, layer.paint.get('fill-translate'), layer.paint.get('fill-translate-anchor'));\n if (!isOutline) {\n indexBuffer = bucket.indexBuffer;\n segments = bucket.segments;\n uniformValues = image ? fillPatternUniformValues(tileMatrix, painter, crossfade, tile) : fillUniformValues(tileMatrix);\n } else {\n indexBuffer = bucket.indexBuffer2;\n segments = bucket.segments2;\n var drawingBufferSize = [\n gl.drawingBufferWidth,\n gl.drawingBufferHeight\n ];\n uniformValues = programName === 'fillOutlinePattern' && image ? fillOutlinePatternUniformValues(tileMatrix, painter, crossfade, tile, drawingBufferSize) : fillOutlineUniformValues(tileMatrix, drawingBufferSize);\n }\n program.draw(painter.context, drawMode, depthMode, painter.stencilModeForClipping(coord), colorMode, CullFaceMode.disabled, uniformValues, layer.id, bucket.layoutVertexBuffer, indexBuffer, segments, layer.paint, painter.transform.zoom, programConfiguration);\n }\n}\n\nfunction draw(painter, source, layer, coords) {\n var opacity = layer.paint.get('fill-extrusion-opacity');\n if (opacity === 0) {\n return;\n }\n if (painter.renderPass === 'translucent') {\n var depthMode = new DepthMode(painter.context.gl.LEQUAL, DepthMode.ReadWrite, painter.depthRangeFor3D);\n if (opacity === 1 && !layer.paint.get('fill-extrusion-pattern').constantOr(1)) {\n var colorMode = painter.colorModeForRenderPass();\n drawExtrusionTiles(painter, source, layer, coords, depthMode, StencilMode.disabled, colorMode);\n } else {\n drawExtrusionTiles(painter, source, layer, coords, depthMode, StencilMode.disabled, ColorMode.disabled);\n drawExtrusionTiles(painter, source, layer, coords, depthMode, painter.stencilModeFor3D(), painter.colorModeForRenderPass());\n }\n }\n}\nfunction drawExtrusionTiles(painter, source, layer, coords, depthMode, stencilMode, colorMode) {\n var context = painter.context;\n var gl = context.gl;\n var patternProperty = layer.paint.get('fill-extrusion-pattern');\n var image = patternProperty.constantOr(1);\n var crossfade = layer.getCrossfadeParameters();\n var opacity = layer.paint.get('fill-extrusion-opacity');\n for (var i = 0, list = coords; i < list.length; i += 1) {\n var coord = list[i];\n var tile = source.getTile(coord);\n var bucket = tile.getBucket(layer);\n if (!bucket) {\n continue;\n }\n var programConfiguration = bucket.programConfigurations.get(layer.id);\n var program = painter.useProgram(image ? 'fillExtrusionPattern' : 'fillExtrusion', programConfiguration);\n if (image) {\n painter.context.activeTexture.set(gl.TEXTURE0);\n tile.imageAtlasTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n programConfiguration.updatePaintBuffers(crossfade);\n }\n var constantPattern = patternProperty.constantOr(null);\n if (constantPattern && tile.imageAtlas) {\n var atlas = tile.imageAtlas;\n var posTo = atlas.patternPositions[constantPattern.to.toString()];\n var posFrom = atlas.patternPositions[constantPattern.from.toString()];\n if (posTo && posFrom) {\n programConfiguration.setConstantPatternPositions(posTo, posFrom);\n }\n }\n var matrix = painter.translatePosMatrix(coord.posMatrix, tile, layer.paint.get('fill-extrusion-translate'), layer.paint.get('fill-extrusion-translate-anchor'));\n var shouldUseVerticalGradient = layer.paint.get('fill-extrusion-vertical-gradient');\n var uniformValues = image ? fillExtrusionPatternUniformValues(matrix, painter, shouldUseVerticalGradient, opacity, coord, crossfade, tile) : fillExtrusionUniformValues(matrix, painter, shouldUseVerticalGradient, opacity);\n program.draw(context, context.gl.TRIANGLES, depthMode, stencilMode, colorMode, CullFaceMode.backCCW, uniformValues, layer.id, bucket.layoutVertexBuffer, bucket.indexBuffer, bucket.segments, layer.paint, painter.transform.zoom, programConfiguration);\n }\n}\n\nfunction drawHillshade(painter, sourceCache, layer, tileIDs) {\n if (painter.renderPass !== 'offscreen' && painter.renderPass !== 'translucent') {\n return;\n }\n var context = painter.context;\n var depthMode = painter.depthModeForSublayer(0, DepthMode.ReadOnly);\n var colorMode = painter.colorModeForRenderPass();\n var ref = painter.renderPass === 'translucent' ? painter.stencilConfigForOverlap(tileIDs) : [\n {},\n tileIDs\n ];\n var stencilModes = ref[0];\n var coords = ref[1];\n for (var i = 0, list = coords; i < list.length; i += 1) {\n var coord = list[i];\n var tile = sourceCache.getTile(coord);\n if (tile.needsHillshadePrepare && painter.renderPass === 'offscreen') {\n prepareHillshade(painter, tile, layer, depthMode, StencilMode.disabled, colorMode);\n } else if (painter.renderPass === 'translucent') {\n renderHillshade(painter, tile, layer, depthMode, stencilModes[coord.overscaledZ], colorMode);\n }\n }\n context.viewport.set([\n 0,\n 0,\n painter.width,\n painter.height\n ]);\n}\nfunction renderHillshade(painter, tile, layer, depthMode, stencilMode, colorMode) {\n var context = painter.context;\n var gl = context.gl;\n var fbo = tile.fbo;\n if (!fbo) {\n return;\n }\n var program = painter.useProgram('hillshade');\n context.activeTexture.set(gl.TEXTURE0);\n gl.bindTexture(gl.TEXTURE_2D, fbo.colorAttachment.get());\n var uniformValues = hillshadeUniformValues(painter, tile, layer);\n program.draw(context, gl.TRIANGLES, depthMode, stencilMode, colorMode, CullFaceMode.disabled, uniformValues, layer.id, painter.rasterBoundsBuffer, painter.quadTriangleIndexBuffer, painter.rasterBoundsSegments);\n}\nfunction prepareHillshade(painter, tile, layer, depthMode, stencilMode, colorMode) {\n var context = painter.context;\n var gl = context.gl;\n var dem = tile.dem;\n if (dem && dem.data) {\n var tileSize = dem.dim;\n var textureStride = dem.stride;\n var pixelData = dem.getPixels();\n context.activeTexture.set(gl.TEXTURE1);\n context.pixelStoreUnpackPremultiplyAlpha.set(false);\n tile.demTexture = tile.demTexture || painter.getTileTexture(textureStride);\n if (tile.demTexture) {\n var demTexture = tile.demTexture;\n demTexture.update(pixelData, { premultiply: false });\n demTexture.bind(gl.NEAREST, gl.CLAMP_TO_EDGE);\n } else {\n tile.demTexture = new performance.Texture(context, pixelData, gl.RGBA, { premultiply: false });\n tile.demTexture.bind(gl.NEAREST, gl.CLAMP_TO_EDGE);\n }\n context.activeTexture.set(gl.TEXTURE0);\n var fbo = tile.fbo;\n if (!fbo) {\n var renderTexture = new performance.Texture(context, {\n width: tileSize,\n height: tileSize,\n data: null\n }, gl.RGBA);\n renderTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n fbo = tile.fbo = context.createFramebuffer(tileSize, tileSize, true);\n fbo.colorAttachment.set(renderTexture.texture);\n }\n context.bindFramebuffer.set(fbo.framebuffer);\n context.viewport.set([\n 0,\n 0,\n tileSize,\n tileSize\n ]);\n painter.useProgram('hillshadePrepare').draw(context, gl.TRIANGLES, depthMode, stencilMode, colorMode, CullFaceMode.disabled, hillshadeUniformPrepareValues(tile.tileID, dem), layer.id, painter.rasterBoundsBuffer, painter.quadTriangleIndexBuffer, painter.rasterBoundsSegments);\n tile.needsHillshadePrepare = false;\n }\n}\n\nfunction drawRaster(painter, sourceCache, layer, tileIDs) {\n if (painter.renderPass !== 'translucent') {\n return;\n }\n if (layer.paint.get('raster-opacity') === 0) {\n return;\n }\n if (!tileIDs.length) {\n return;\n }\n var context = painter.context;\n var gl = context.gl;\n var source = sourceCache.getSource();\n var program = painter.useProgram('raster');\n var colorMode = painter.colorModeForRenderPass();\n var ref = source instanceof ImageSource ? [\n {},\n tileIDs\n ] : painter.stencilConfigForOverlap(tileIDs);\n var stencilModes = ref[0];\n var coords = ref[1];\n var minTileZ = coords[coords.length - 1].overscaledZ;\n var align = !painter.options.moving;\n for (var i = 0, list = coords; i < list.length; i += 1) {\n var coord = list[i];\n var depthMode = painter.depthModeForSublayer(coord.overscaledZ - minTileZ, layer.paint.get('raster-opacity') === 1 ? DepthMode.ReadWrite : DepthMode.ReadOnly, gl.LESS);\n var tile = sourceCache.getTile(coord);\n var posMatrix = painter.transform.calculatePosMatrix(coord.toUnwrapped(), align);\n tile.registerFadeDuration(layer.paint.get('raster-fade-duration'));\n var parentTile = sourceCache.findLoadedParent(coord, 0), fade = getFadeValues(tile, parentTile, sourceCache, layer, painter.transform);\n var parentScaleBy = void 0, parentTL = void 0;\n var textureFilter = layer.paint.get('raster-resampling') === 'nearest' ? gl.NEAREST : gl.LINEAR;\n context.activeTexture.set(gl.TEXTURE0);\n tile.texture.bind(textureFilter, gl.CLAMP_TO_EDGE, gl.LINEAR_MIPMAP_NEAREST);\n context.activeTexture.set(gl.TEXTURE1);\n if (parentTile) {\n parentTile.texture.bind(textureFilter, gl.CLAMP_TO_EDGE, gl.LINEAR_MIPMAP_NEAREST);\n parentScaleBy = Math.pow(2, parentTile.tileID.overscaledZ - tile.tileID.overscaledZ);\n parentTL = [\n tile.tileID.canonical.x * parentScaleBy % 1,\n tile.tileID.canonical.y * parentScaleBy % 1\n ];\n } else {\n tile.texture.bind(textureFilter, gl.CLAMP_TO_EDGE, gl.LINEAR_MIPMAP_NEAREST);\n }\n var uniformValues = rasterUniformValues(posMatrix, parentTL || [\n 0,\n 0\n ], parentScaleBy || 1, fade, layer);\n if (source instanceof ImageSource) {\n program.draw(context, gl.TRIANGLES, depthMode, StencilMode.disabled, colorMode, CullFaceMode.disabled, uniformValues, layer.id, source.boundsBuffer, painter.quadTriangleIndexBuffer, source.boundsSegments);\n } else {\n program.draw(context, gl.TRIANGLES, depthMode, stencilModes[coord.overscaledZ], colorMode, CullFaceMode.disabled, uniformValues, layer.id, painter.rasterBoundsBuffer, painter.quadTriangleIndexBuffer, painter.rasterBoundsSegments);\n }\n }\n}\nfunction getFadeValues(tile, parentTile, sourceCache, layer, transform) {\n var fadeDuration = layer.paint.get('raster-fade-duration');\n if (fadeDuration > 0) {\n var now = performance.browser.now();\n var sinceTile = (now - tile.timeAdded) / fadeDuration;\n var sinceParent = parentTile ? (now - parentTile.timeAdded) / fadeDuration : -1;\n var source = sourceCache.getSource();\n var idealZ = transform.coveringZoomLevel({\n tileSize: source.tileSize,\n roundZoom: source.roundZoom\n });\n var fadeIn = !parentTile || Math.abs(parentTile.tileID.overscaledZ - idealZ) > Math.abs(tile.tileID.overscaledZ - idealZ);\n var childOpacity = fadeIn && tile.refreshedUponExpiration ? 1 : performance.clamp(fadeIn ? sinceTile : 1 - sinceParent, 0, 1);\n if (tile.refreshedUponExpiration && sinceTile >= 1) {\n tile.refreshedUponExpiration = false;\n }\n if (parentTile) {\n return {\n opacity: 1,\n mix: 1 - childOpacity\n };\n } else {\n return {\n opacity: childOpacity,\n mix: 0\n };\n }\n } else {\n return {\n opacity: 1,\n mix: 0\n };\n }\n}\n\nfunction drawBackground(painter, sourceCache, layer) {\n var color = layer.paint.get('background-color');\n var opacity = layer.paint.get('background-opacity');\n if (opacity === 0) {\n return;\n }\n var context = painter.context;\n var gl = context.gl;\n var transform = painter.transform;\n var tileSize = transform.tileSize;\n var image = layer.paint.get('background-pattern');\n if (painter.isPatternMissing(image)) {\n return;\n }\n var pass = !image && color.a === 1 && opacity === 1 && painter.opaquePassEnabledForLayer() ? 'opaque' : 'translucent';\n if (painter.renderPass !== pass) {\n return;\n }\n var stencilMode = StencilMode.disabled;\n var depthMode = painter.depthModeForSublayer(0, pass === 'opaque' ? DepthMode.ReadWrite : DepthMode.ReadOnly);\n var colorMode = painter.colorModeForRenderPass();\n var program = painter.useProgram(image ? 'backgroundPattern' : 'background');\n var tileIDs = transform.coveringTiles({ tileSize: tileSize });\n if (image) {\n context.activeTexture.set(gl.TEXTURE0);\n painter.imageManager.bind(painter.context);\n }\n var crossfade = layer.getCrossfadeParameters();\n for (var i = 0, list = tileIDs; i < list.length; i += 1) {\n var tileID = list[i];\n var matrix = painter.transform.calculatePosMatrix(tileID.toUnwrapped());\n var uniformValues = image ? backgroundPatternUniformValues(matrix, opacity, painter, image, {\n tileID: tileID,\n tileSize: tileSize\n }, crossfade) : backgroundUniformValues(matrix, opacity, color);\n program.draw(context, gl.TRIANGLES, depthMode, stencilMode, colorMode, CullFaceMode.disabled, uniformValues, layer.id, painter.tileExtentBuffer, painter.quadTriangleIndexBuffer, painter.tileExtentSegments);\n }\n}\n\nvar topColor = new performance.Color(1, 0, 0, 1);\nvar btmColor = new performance.Color(0, 1, 0, 1);\nvar leftColor = new performance.Color(0, 0, 1, 1);\nvar rightColor = new performance.Color(1, 0, 1, 1);\nvar centerColor = new performance.Color(0, 1, 1, 1);\nfunction drawDebugPadding(painter) {\n var padding = painter.transform.padding;\n var lineWidth = 3;\n drawHorizontalLine(painter, painter.transform.height - (padding.top || 0), lineWidth, topColor);\n drawHorizontalLine(painter, padding.bottom || 0, lineWidth, btmColor);\n drawVerticalLine(painter, padding.left || 0, lineWidth, leftColor);\n drawVerticalLine(painter, painter.transform.width - (padding.right || 0), lineWidth, rightColor);\n var center = painter.transform.centerPoint;\n drawCrosshair(painter, center.x, painter.transform.height - center.y, centerColor);\n}\nfunction drawCrosshair(painter, x, y, color) {\n var size = 20;\n var lineWidth = 2;\n drawDebugSSRect(painter, x - lineWidth / 2, y - size / 2, lineWidth, size, color);\n drawDebugSSRect(painter, x - size / 2, y - lineWidth / 2, size, lineWidth, color);\n}\nfunction drawHorizontalLine(painter, y, lineWidth, color) {\n drawDebugSSRect(painter, 0, y + lineWidth / 2, painter.transform.width, lineWidth, color);\n}\nfunction drawVerticalLine(painter, x, lineWidth, color) {\n drawDebugSSRect(painter, x - lineWidth / 2, 0, lineWidth, painter.transform.height, color);\n}\nfunction drawDebugSSRect(painter, x, y, width, height, color) {\n var context = painter.context;\n var gl = context.gl;\n gl.enable(gl.SCISSOR_TEST);\n gl.scissor(x * performance.browser.devicePixelRatio, y * performance.browser.devicePixelRatio, width * performance.browser.devicePixelRatio, height * performance.browser.devicePixelRatio);\n context.clear({ color: color });\n gl.disable(gl.SCISSOR_TEST);\n}\nfunction drawDebug(painter, sourceCache, coords) {\n for (var i = 0; i < coords.length; i++) {\n drawDebugTile(painter, sourceCache, coords[i]);\n }\n}\nfunction drawDebugTile(painter, sourceCache, coord) {\n var context = painter.context;\n var gl = context.gl;\n var posMatrix = coord.posMatrix;\n var program = painter.useProgram('debug');\n var depthMode = DepthMode.disabled;\n var stencilMode = StencilMode.disabled;\n var colorMode = painter.colorModeForRenderPass();\n var id = '$debug';\n context.activeTexture.set(gl.TEXTURE0);\n painter.emptyTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n program.draw(context, gl.LINE_STRIP, depthMode, stencilMode, colorMode, CullFaceMode.disabled, debugUniformValues(posMatrix, performance.Color.red), id, painter.debugBuffer, painter.tileBorderIndexBuffer, painter.debugSegments);\n var tileRawData = sourceCache.getTileByID(coord.key).latestRawTileData;\n var tileByteLength = tileRawData && tileRawData.byteLength || 0;\n var tileSizeKb = Math.floor(tileByteLength / 1024);\n var tileSize = sourceCache.getTile(coord).tileSize;\n var scaleRatio = 512 / Math.min(tileSize, 512) * (coord.overscaledZ / painter.transform.zoom) * 0.5;\n var tileIdText = coord.canonical.toString();\n if (coord.overscaledZ !== coord.canonical.z) {\n tileIdText += ' => ' + coord.overscaledZ;\n }\n var tileLabel = tileIdText + ' ' + tileSizeKb + 'kb';\n drawTextToOverlay(painter, tileLabel);\n program.draw(context, gl.TRIANGLES, depthMode, stencilMode, ColorMode.alphaBlended, CullFaceMode.disabled, debugUniformValues(posMatrix, performance.Color.transparent, scaleRatio), id, painter.debugBuffer, painter.quadTriangleIndexBuffer, painter.debugSegments);\n}\nfunction drawTextToOverlay(painter, text) {\n painter.initDebugOverlayCanvas();\n var canvas = painter.debugOverlayCanvas;\n var gl = painter.context.gl;\n var ctx2d = painter.debugOverlayCanvas.getContext('2d');\n ctx2d.clearRect(0, 0, canvas.width, canvas.height);\n ctx2d.shadowColor = 'white';\n ctx2d.shadowBlur = 2;\n ctx2d.lineWidth = 1.5;\n ctx2d.strokeStyle = 'white';\n ctx2d.textBaseline = 'top';\n ctx2d.font = 'bold ' + 36 + 'px Open Sans, sans-serif';\n ctx2d.fillText(text, 5, 5);\n ctx2d.strokeText(text, 5, 5);\n painter.debugOverlayTexture.update(canvas);\n painter.debugOverlayTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n}\n\nfunction drawCustom(painter, sourceCache, layer) {\n var context = painter.context;\n var implementation = layer.implementation;\n if (painter.renderPass === 'offscreen') {\n var prerender = implementation.prerender;\n if (prerender) {\n painter.setCustomLayerDefaults();\n context.setColorMode(painter.colorModeForRenderPass());\n prerender.call(implementation, context.gl, painter.transform.customLayerMatrix());\n context.setDirty();\n painter.setBaseState();\n }\n } else if (painter.renderPass === 'translucent') {\n painter.setCustomLayerDefaults();\n context.setColorMode(painter.colorModeForRenderPass());\n context.setStencilMode(StencilMode.disabled);\n var depthMode = implementation.renderingMode === '3d' ? new DepthMode(painter.context.gl.LEQUAL, DepthMode.ReadWrite, painter.depthRangeFor3D) : painter.depthModeForSublayer(0, DepthMode.ReadOnly);\n context.setDepthMode(depthMode);\n implementation.render(context.gl, painter.transform.customLayerMatrix());\n context.setDirty();\n painter.setBaseState();\n context.bindFramebuffer.set(null);\n }\n}\n\nvar draw$1 = {\n symbol: drawSymbols,\n circle: drawCircles,\n heatmap: drawHeatmap,\n line: drawLine,\n fill: drawFill,\n 'fill-extrusion': draw,\n hillshade: drawHillshade,\n raster: drawRaster,\n background: drawBackground,\n debug: drawDebug,\n custom: drawCustom\n};\nvar Painter = function Painter(gl, transform) {\n this.context = new Context(gl);\n this.transform = transform;\n this._tileTextures = {};\n this.setup();\n this.numSublayers = SourceCache.maxUnderzooming + SourceCache.maxOverzooming + 1;\n this.depthEpsilon = 1 / Math.pow(2, 16);\n this.crossTileSymbolIndex = new CrossTileSymbolIndex();\n this.gpuTimers = {};\n};\nPainter.prototype.resize = function resize(width, height) {\n this.width = width * performance.browser.devicePixelRatio;\n this.height = height * performance.browser.devicePixelRatio;\n this.context.viewport.set([\n 0,\n 0,\n this.width,\n this.height\n ]);\n if (this.style) {\n for (var i = 0, list = this.style._order; i < list.length; i += 1) {\n var layerId = list[i];\n this.style._layers[layerId].resize();\n }\n }\n};\nPainter.prototype.setup = function setup() {\n var context = this.context;\n var tileExtentArray = new performance.StructArrayLayout2i4();\n tileExtentArray.emplaceBack(0, 0);\n tileExtentArray.emplaceBack(performance.EXTENT, 0);\n tileExtentArray.emplaceBack(0, performance.EXTENT);\n tileExtentArray.emplaceBack(performance.EXTENT, performance.EXTENT);\n this.tileExtentBuffer = context.createVertexBuffer(tileExtentArray, posAttributes.members);\n this.tileExtentSegments = performance.SegmentVector.simpleSegment(0, 0, 4, 2);\n var debugArray = new performance.StructArrayLayout2i4();\n debugArray.emplaceBack(0, 0);\n debugArray.emplaceBack(performance.EXTENT, 0);\n debugArray.emplaceBack(0, performance.EXTENT);\n debugArray.emplaceBack(performance.EXTENT, performance.EXTENT);\n this.debugBuffer = context.createVertexBuffer(debugArray, posAttributes.members);\n this.debugSegments = performance.SegmentVector.simpleSegment(0, 0, 4, 5);\n var rasterBoundsArray = new performance.StructArrayLayout4i8();\n rasterBoundsArray.emplaceBack(0, 0, 0, 0);\n rasterBoundsArray.emplaceBack(performance.EXTENT, 0, performance.EXTENT, 0);\n rasterBoundsArray.emplaceBack(0, performance.EXTENT, 0, performance.EXTENT);\n rasterBoundsArray.emplaceBack(performance.EXTENT, performance.EXTENT, performance.EXTENT, performance.EXTENT);\n this.rasterBoundsBuffer = context.createVertexBuffer(rasterBoundsArray, rasterBoundsAttributes.members);\n this.rasterBoundsSegments = performance.SegmentVector.simpleSegment(0, 0, 4, 2);\n var viewportArray = new performance.StructArrayLayout2i4();\n viewportArray.emplaceBack(0, 0);\n viewportArray.emplaceBack(1, 0);\n viewportArray.emplaceBack(0, 1);\n viewportArray.emplaceBack(1, 1);\n this.viewportBuffer = context.createVertexBuffer(viewportArray, posAttributes.members);\n this.viewportSegments = performance.SegmentVector.simpleSegment(0, 0, 4, 2);\n var tileLineStripIndices = new performance.StructArrayLayout1ui2();\n tileLineStripIndices.emplaceBack(0);\n tileLineStripIndices.emplaceBack(1);\n tileLineStripIndices.emplaceBack(3);\n tileLineStripIndices.emplaceBack(2);\n tileLineStripIndices.emplaceBack(0);\n this.tileBorderIndexBuffer = context.createIndexBuffer(tileLineStripIndices);\n var quadTriangleIndices = new performance.StructArrayLayout3ui6();\n quadTriangleIndices.emplaceBack(0, 1, 2);\n quadTriangleIndices.emplaceBack(2, 1, 3);\n this.quadTriangleIndexBuffer = context.createIndexBuffer(quadTriangleIndices);\n this.emptyTexture = new performance.Texture(context, {\n width: 1,\n height: 1,\n data: new Uint8Array([\n 0,\n 0,\n 0,\n 0\n ])\n }, context.gl.RGBA);\n var gl = this.context.gl;\n this.stencilClearMode = new StencilMode({\n func: gl.ALWAYS,\n mask: 0\n }, 0, 255, gl.ZERO, gl.ZERO, gl.ZERO);\n};\nPainter.prototype.clearStencil = function clearStencil() {\n var context = this.context;\n var gl = context.gl;\n this.nextStencilID = 1;\n this.currentStencilSource = undefined;\n var matrix = performance.create();\n performance.ortho(matrix, 0, this.width, this.height, 0, 0, 1);\n performance.scale(matrix, matrix, [\n gl.drawingBufferWidth,\n gl.drawingBufferHeight,\n 0\n ]);\n this.useProgram('clippingMask').draw(context, gl.TRIANGLES, DepthMode.disabled, this.stencilClearMode, ColorMode.disabled, CullFaceMode.disabled, clippingMaskUniformValues(matrix), '$clipping', this.viewportBuffer, this.quadTriangleIndexBuffer, this.viewportSegments);\n};\nPainter.prototype._renderTileClippingMasks = function _renderTileClippingMasks(layer, tileIDs) {\n if (this.currentStencilSource === layer.source || !layer.isTileClipped() || !tileIDs || !tileIDs.length) {\n return;\n }\n this.currentStencilSource = layer.source;\n var context = this.context;\n var gl = context.gl;\n if (this.nextStencilID + tileIDs.length > 256) {\n this.clearStencil();\n }\n context.setColorMode(ColorMode.disabled);\n context.setDepthMode(DepthMode.disabled);\n var program = this.useProgram('clippingMask');\n this._tileClippingMaskIDs = {};\n for (var i = 0, list = tileIDs; i < list.length; i += 1) {\n var tileID = list[i];\n var id = this._tileClippingMaskIDs[tileID.key] = this.nextStencilID++;\n program.draw(context, gl.TRIANGLES, DepthMode.disabled, new StencilMode({\n func: gl.ALWAYS,\n mask: 0\n }, id, 255, gl.KEEP, gl.KEEP, gl.REPLACE), ColorMode.disabled, CullFaceMode.disabled, clippingMaskUniformValues(tileID.posMatrix), '$clipping', this.tileExtentBuffer, this.quadTriangleIndexBuffer, this.tileExtentSegments);\n }\n};\nPainter.prototype.stencilModeFor3D = function stencilModeFor3D() {\n this.currentStencilSource = undefined;\n if (this.nextStencilID + 1 > 256) {\n this.clearStencil();\n }\n var id = this.nextStencilID++;\n var gl = this.context.gl;\n return new StencilMode({\n func: gl.NOTEQUAL,\n mask: 255\n }, id, 255, gl.KEEP, gl.KEEP, gl.REPLACE);\n};\nPainter.prototype.stencilModeForClipping = function stencilModeForClipping(tileID) {\n var gl = this.context.gl;\n return new StencilMode({\n func: gl.EQUAL,\n mask: 255\n }, this._tileClippingMaskIDs[tileID.key], 0, gl.KEEP, gl.KEEP, gl.REPLACE);\n};\nPainter.prototype.stencilConfigForOverlap = function stencilConfigForOverlap(tileIDs) {\n var obj;\n var gl = this.context.gl;\n var coords = tileIDs.sort(function (a, b) {\n return b.overscaledZ - a.overscaledZ;\n });\n var minTileZ = coords[coords.length - 1].overscaledZ;\n var stencilValues = coords[0].overscaledZ - minTileZ + 1;\n if (stencilValues > 1) {\n this.currentStencilSource = undefined;\n if (this.nextStencilID + stencilValues > 256) {\n this.clearStencil();\n }\n var zToStencilMode = {};\n for (var i = 0; i < stencilValues; i++) {\n zToStencilMode[i + minTileZ] = new StencilMode({\n func: gl.GEQUAL,\n mask: 255\n }, i + this.nextStencilID, 255, gl.KEEP, gl.KEEP, gl.REPLACE);\n }\n this.nextStencilID += stencilValues;\n return [\n zToStencilMode,\n coords\n ];\n }\n return [\n (obj = {}, obj[minTileZ] = StencilMode.disabled, obj),\n coords\n ];\n};\nPainter.prototype.colorModeForRenderPass = function colorModeForRenderPass() {\n var gl = this.context.gl;\n if (this._showOverdrawInspector) {\n var numOverdrawSteps = 8;\n var a = 1 / numOverdrawSteps;\n return new ColorMode([\n gl.CONSTANT_COLOR,\n gl.ONE\n ], new performance.Color(a, a, a, 0), [\n true,\n true,\n true,\n true\n ]);\n } else if (this.renderPass === 'opaque') {\n return ColorMode.unblended;\n } else {\n return ColorMode.alphaBlended;\n }\n};\nPainter.prototype.depthModeForSublayer = function depthModeForSublayer(n, mask, func) {\n if (!this.opaquePassEnabledForLayer()) {\n return DepthMode.disabled;\n }\n var depth = 1 - ((1 + this.currentLayer) * this.numSublayers + n) * this.depthEpsilon;\n return new DepthMode(func || this.context.gl.LEQUAL, mask, [\n depth,\n depth\n ]);\n};\nPainter.prototype.opaquePassEnabledForLayer = function opaquePassEnabledForLayer() {\n return this.currentLayer < this.opaquePassCutoff;\n};\nPainter.prototype.render = function render(style, options) {\n var this$1 = this;\n this.style = style;\n this.options = options;\n this.lineAtlas = style.lineAtlas;\n this.imageManager = style.imageManager;\n this.glyphManager = style.glyphManager;\n this.symbolFadeChange = style.placement.symbolFadeChange(performance.browser.now());\n this.imageManager.beginFrame();\n var layerIds = this.style._order;\n var sourceCaches = this.style.sourceCaches;\n for (var id in sourceCaches) {\n var sourceCache = sourceCaches[id];\n if (sourceCache.used) {\n sourceCache.prepare(this.context);\n }\n }\n var coordsAscending = {};\n var coordsDescending = {};\n var coordsDescendingSymbol = {};\n for (var id$1 in sourceCaches) {\n var sourceCache$1 = sourceCaches[id$1];\n coordsAscending[id$1] = sourceCache$1.getVisibleCoordinates();\n coordsDescending[id$1] = coordsAscending[id$1].slice().reverse();\n coordsDescendingSymbol[id$1] = sourceCache$1.getVisibleCoordinates(true).reverse();\n }\n this.opaquePassCutoff = Infinity;\n for (var i = 0; i < layerIds.length; i++) {\n var layerId = layerIds[i];\n if (this.style._layers[layerId].is3D()) {\n this.opaquePassCutoff = i;\n break;\n }\n }\n this.renderPass = 'offscreen';\n for (var i$1 = 0, list = layerIds; i$1 < list.length; i$1 += 1) {\n var layerId$1 = list[i$1];\n var layer = this.style._layers[layerId$1];\n if (!layer.hasOffscreenPass() || layer.isHidden(this.transform.zoom)) {\n continue;\n }\n var coords = coordsDescending[layer.source];\n if (layer.type !== 'custom' && !coords.length) {\n continue;\n }\n this.renderLayer(this, sourceCaches[layer.source], layer, coords);\n }\n this.context.bindFramebuffer.set(null);\n this.context.clear({\n color: options.showOverdrawInspector ? performance.Color.black : performance.Color.transparent,\n depth: 1\n });\n this.clearStencil();\n this._showOverdrawInspector = options.showOverdrawInspector;\n this.depthRangeFor3D = [\n 0,\n 1 - (style._order.length + 2) * this.numSublayers * this.depthEpsilon\n ];\n this.renderPass = 'opaque';\n for (this.currentLayer = layerIds.length - 1; this.currentLayer >= 0; this.currentLayer--) {\n var layer$1 = this.style._layers[layerIds[this.currentLayer]];\n var sourceCache$2 = sourceCaches[layer$1.source];\n var coords$1 = coordsAscending[layer$1.source];\n this._renderTileClippingMasks(layer$1, coords$1);\n this.renderLayer(this, sourceCache$2, layer$1, coords$1);\n }\n this.renderPass = 'translucent';\n for (this.currentLayer = 0; this.currentLayer < layerIds.length; this.currentLayer++) {\n var layer$2 = this.style._layers[layerIds[this.currentLayer]];\n var sourceCache$3 = sourceCaches[layer$2.source];\n var coords$2 = (layer$2.type === 'symbol' ? coordsDescendingSymbol : coordsDescending)[layer$2.source];\n this._renderTileClippingMasks(layer$2, coordsAscending[layer$2.source]);\n this.renderLayer(this, sourceCache$3, layer$2, coords$2);\n }\n if (this.options.showTileBoundaries) {\n var selectedSource;\n var sourceCache$4;\n var layers = performance.values(this.style._layers);\n layers.forEach(function (layer) {\n if (layer.source && !layer.isHidden(this$1.transform.zoom)) {\n if (layer.source !== (sourceCache$4 && sourceCache$4.id)) {\n sourceCache$4 = this$1.style.sourceCaches[layer.source];\n }\n if (!selectedSource || selectedSource.getSource().maxzoom < sourceCache$4.getSource().maxzoom) {\n selectedSource = sourceCache$4;\n }\n }\n });\n if (selectedSource) {\n draw$1.debug(this, selectedSource, selectedSource.getVisibleCoordinates());\n }\n }\n if (this.options.showPadding) {\n drawDebugPadding(this);\n }\n this.context.setDefault();\n};\nPainter.prototype.renderLayer = function renderLayer(painter, sourceCache, layer, coords) {\n if (layer.isHidden(this.transform.zoom)) {\n return;\n }\n if (layer.type !== 'background' && layer.type !== 'custom' && !coords.length) {\n return;\n }\n this.id = layer.id;\n this.gpuTimingStart(layer);\n draw$1[layer.type](painter, sourceCache, layer, coords, this.style.placement.variableOffsets);\n this.gpuTimingEnd();\n};\nPainter.prototype.gpuTimingStart = function gpuTimingStart(layer) {\n if (!this.options.gpuTiming) {\n return;\n }\n var ext = this.context.extTimerQuery;\n var layerTimer = this.gpuTimers[layer.id];\n if (!layerTimer) {\n layerTimer = this.gpuTimers[layer.id] = {\n calls: 0,\n cpuTime: 0,\n query: ext.createQueryEXT()\n };\n }\n layerTimer.calls++;\n ext.beginQueryEXT(ext.TIME_ELAPSED_EXT, layerTimer.query);\n};\nPainter.prototype.gpuTimingEnd = function gpuTimingEnd() {\n if (!this.options.gpuTiming) {\n return;\n }\n var ext = this.context.extTimerQuery;\n ext.endQueryEXT(ext.TIME_ELAPSED_EXT);\n};\nPainter.prototype.collectGpuTimers = function collectGpuTimers() {\n var currentLayerTimers = this.gpuTimers;\n this.gpuTimers = {};\n return currentLayerTimers;\n};\nPainter.prototype.queryGpuTimers = function queryGpuTimers(gpuTimers) {\n var layers = {};\n for (var layerId in gpuTimers) {\n var gpuTimer = gpuTimers[layerId];\n var ext = this.context.extTimerQuery;\n var gpuTime = ext.getQueryObjectEXT(gpuTimer.query, ext.QUERY_RESULT_EXT) / (1000 * 1000);\n ext.deleteQueryEXT(gpuTimer.query);\n layers[layerId] = gpuTime;\n }\n return layers;\n};\nPainter.prototype.translatePosMatrix = function translatePosMatrix(matrix, tile, translate, translateAnchor, inViewportPixelUnitsUnits) {\n if (!translate[0] && !translate[1]) {\n return matrix;\n }\n var angle = inViewportPixelUnitsUnits ? translateAnchor === 'map' ? this.transform.angle : 0 : translateAnchor === 'viewport' ? -this.transform.angle : 0;\n if (angle) {\n var sinA = Math.sin(angle);\n var cosA = Math.cos(angle);\n translate = [\n translate[0] * cosA - translate[1] * sinA,\n translate[0] * sinA + translate[1] * cosA\n ];\n }\n var translation = [\n inViewportPixelUnitsUnits ? translate[0] : pixelsToTileUnits(tile, translate[0], this.transform.zoom),\n inViewportPixelUnitsUnits ? translate[1] : pixelsToTileUnits(tile, translate[1], this.transform.zoom),\n 0\n ];\n var translatedMatrix = new Float32Array(16);\n performance.translate(translatedMatrix, matrix, translation);\n return translatedMatrix;\n};\nPainter.prototype.saveTileTexture = function saveTileTexture(texture) {\n var textures = this._tileTextures[texture.size[0]];\n if (!textures) {\n this._tileTextures[texture.size[0]] = [texture];\n } else {\n textures.push(texture);\n }\n};\nPainter.prototype.getTileTexture = function getTileTexture(size) {\n var textures = this._tileTextures[size];\n return textures && textures.length > 0 ? textures.pop() : null;\n};\nPainter.prototype.isPatternMissing = function isPatternMissing(image) {\n if (!image) {\n return false;\n }\n if (!image.from || !image.to) {\n return true;\n }\n var imagePosA = this.imageManager.getPattern(image.from.toString());\n var imagePosB = this.imageManager.getPattern(image.to.toString());\n return !imagePosA || !imagePosB;\n};\nPainter.prototype.useProgram = function useProgram(name, programConfiguration) {\n this.cache = this.cache || {};\n var key = '' + name + (programConfiguration ? programConfiguration.cacheKey : '') + (this._showOverdrawInspector ? '/overdraw' : '');\n if (!this.cache[key]) {\n this.cache[key] = new Program$1(this.context, name, shaders[name], programConfiguration, programUniforms[name], this._showOverdrawInspector);\n }\n return this.cache[key];\n};\nPainter.prototype.setCustomLayerDefaults = function setCustomLayerDefaults() {\n this.context.unbindVAO();\n this.context.cullFace.setDefault();\n this.context.activeTexture.setDefault();\n this.context.pixelStoreUnpack.setDefault();\n this.context.pixelStoreUnpackPremultiplyAlpha.setDefault();\n this.context.pixelStoreUnpackFlipY.setDefault();\n};\nPainter.prototype.setBaseState = function setBaseState() {\n var gl = this.context.gl;\n this.context.cullFace.set(false);\n this.context.viewport.set([\n 0,\n 0,\n this.width,\n this.height\n ]);\n this.context.blendEquation.set(gl.FUNC_ADD);\n};\nPainter.prototype.initDebugOverlayCanvas = function initDebugOverlayCanvas() {\n if (this.debugOverlayCanvas == null) {\n this.debugOverlayCanvas = performance.window.document.createElement('canvas');\n this.debugOverlayCanvas.width = 512;\n this.debugOverlayCanvas.height = 512;\n var gl = this.context.gl;\n this.debugOverlayTexture = new performance.Texture(this.context, this.debugOverlayCanvas, gl.RGBA);\n }\n};\nPainter.prototype.destroy = function destroy() {\n this.emptyTexture.destroy();\n if (this.debugOverlayTexture) {\n this.debugOverlayTexture.destroy();\n }\n};\n\nvar Frustum = function Frustum(points_, planes_) {\n this.points = points_;\n this.planes = planes_;\n};\nFrustum.fromInvProjectionMatrix = function fromInvProjectionMatrix(invProj, worldSize, zoom) {\n var clipSpaceCorners = [\n [\n -1,\n 1,\n -1,\n 1\n ],\n [\n 1,\n 1,\n -1,\n 1\n ],\n [\n 1,\n -1,\n -1,\n 1\n ],\n [\n -1,\n -1,\n -1,\n 1\n ],\n [\n -1,\n 1,\n 1,\n 1\n ],\n [\n 1,\n 1,\n 1,\n 1\n ],\n [\n 1,\n -1,\n 1,\n 1\n ],\n [\n -1,\n -1,\n 1,\n 1\n ]\n ];\n var scale = Math.pow(2, zoom);\n var frustumCoords = clipSpaceCorners.map(function (v) {\n return performance.transformMat4([], v, invProj);\n }).map(function (v) {\n return performance.scale$1([], v, 1 / v[3] / worldSize * scale);\n });\n var frustumPlanePointIndices = [\n [\n 0,\n 1,\n 2\n ],\n [\n 6,\n 5,\n 4\n ],\n [\n 0,\n 3,\n 7\n ],\n [\n 2,\n 1,\n 5\n ],\n [\n 3,\n 2,\n 6\n ],\n [\n 0,\n 4,\n 5\n ]\n ];\n var frustumPlanes = frustumPlanePointIndices.map(function (p) {\n var a = performance.sub([], frustumCoords[p[0]], frustumCoords[p[1]]);\n var b = performance.sub([], frustumCoords[p[2]], frustumCoords[p[1]]);\n var n = performance.normalize([], performance.cross([], a, b));\n var d = -performance.dot(n, frustumCoords[p[1]]);\n return n.concat(d);\n });\n return new Frustum(frustumCoords, frustumPlanes);\n};\nvar Aabb = function Aabb(min_, max_) {\n this.min = min_;\n this.max = max_;\n this.center = performance.scale$2([], performance.add([], this.min, this.max), 0.5);\n};\nAabb.prototype.quadrant = function quadrant(index) {\n var split = [\n index % 2 === 0,\n index < 2\n ];\n var qMin = performance.clone$2(this.min);\n var qMax = performance.clone$2(this.max);\n for (var axis = 0; axis < split.length; axis++) {\n qMin[axis] = split[axis] ? this.min[axis] : this.center[axis];\n qMax[axis] = split[axis] ? this.center[axis] : this.max[axis];\n }\n qMax[2] = this.max[2];\n return new Aabb(qMin, qMax);\n};\nAabb.prototype.distanceX = function distanceX(point) {\n var pointOnAabb = Math.max(Math.min(this.max[0], point[0]), this.min[0]);\n return pointOnAabb - point[0];\n};\nAabb.prototype.distanceY = function distanceY(point) {\n var pointOnAabb = Math.max(Math.min(this.max[1], point[1]), this.min[1]);\n return pointOnAabb - point[1];\n};\nAabb.prototype.intersects = function intersects(frustum) {\n var aabbPoints = [\n [\n this.min[0],\n this.min[1],\n 0,\n 1\n ],\n [\n this.max[0],\n this.min[1],\n 0,\n 1\n ],\n [\n this.max[0],\n this.max[1],\n 0,\n 1\n ],\n [\n this.min[0],\n this.max[1],\n 0,\n 1\n ]\n ];\n var fullyInside = true;\n for (var p = 0; p < frustum.planes.length; p++) {\n var plane = frustum.planes[p];\n var pointsInside = 0;\n for (var i = 0; i < aabbPoints.length; i++) {\n pointsInside += performance.dot$1(plane, aabbPoints[i]) >= 0;\n }\n if (pointsInside === 0) {\n return 0;\n }\n if (pointsInside !== aabbPoints.length) {\n fullyInside = false;\n }\n }\n if (fullyInside) {\n return 2;\n }\n for (var axis = 0; axis < 3; axis++) {\n var projMin = Number.MAX_VALUE;\n var projMax = -Number.MAX_VALUE;\n for (var p$1 = 0; p$1 < frustum.points.length; p$1++) {\n var projectedPoint = frustum.points[p$1][axis] - this.min[axis];\n projMin = Math.min(projMin, projectedPoint);\n projMax = Math.max(projMax, projectedPoint);\n }\n if (projMax < 0 || projMin > this.max[axis] - this.min[axis]) {\n return 0;\n }\n }\n return 1;\n};\n\nvar EdgeInsets = function EdgeInsets(top, bottom, left, right) {\n if (top === void 0)\n top = 0;\n if (bottom === void 0)\n bottom = 0;\n if (left === void 0)\n left = 0;\n if (right === void 0)\n right = 0;\n if (isNaN(top) || top < 0 || isNaN(bottom) || bottom < 0 || isNaN(left) || left < 0 || isNaN(right) || right < 0) {\n throw new Error('Invalid value for edge-insets, top, bottom, left and right must all be numbers');\n }\n this.top = top;\n this.bottom = bottom;\n this.left = left;\n this.right = right;\n};\nEdgeInsets.prototype.interpolate = function interpolate(start, target, t) {\n if (target.top != null && start.top != null) {\n this.top = performance.number(start.top, target.top, t);\n }\n if (target.bottom != null && start.bottom != null) {\n this.bottom = performance.number(start.bottom, target.bottom, t);\n }\n if (target.left != null && start.left != null) {\n this.left = performance.number(start.left, target.left, t);\n }\n if (target.right != null && start.right != null) {\n this.right = performance.number(start.right, target.right, t);\n }\n return this;\n};\nEdgeInsets.prototype.getCenter = function getCenter(width, height) {\n var x = performance.clamp((this.left + width - this.right) / 2, 0, width);\n var y = performance.clamp((this.top + height - this.bottom) / 2, 0, height);\n return new performance.Point(x, y);\n};\nEdgeInsets.prototype.equals = function equals(other) {\n return this.top === other.top && this.bottom === other.bottom && this.left === other.left && this.right === other.right;\n};\nEdgeInsets.prototype.clone = function clone() {\n return new EdgeInsets(this.top, this.bottom, this.left, this.right);\n};\nEdgeInsets.prototype.toJSON = function toJSON() {\n return {\n top: this.top,\n bottom: this.bottom,\n left: this.left,\n right: this.right\n };\n};\n\nvar Transform = function Transform(minZoom, maxZoom, minPitch, maxPitch, renderWorldCopies) {\n this.tileSize = 512;\n this.maxValidLatitude = 85.051129;\n this._renderWorldCopies = renderWorldCopies === undefined ? true : renderWorldCopies;\n this._minZoom = minZoom || 0;\n this._maxZoom = maxZoom || 22;\n this._minPitch = minPitch === undefined || minPitch === null ? 0 : minPitch;\n this._maxPitch = maxPitch === undefined || maxPitch === null ? 60 : maxPitch;\n this.setMaxBounds();\n this.width = 0;\n this.height = 0;\n this._center = new performance.LngLat(0, 0);\n this.zoom = 0;\n this.angle = 0;\n this._fov = 0.6435011087932844;\n this._pitch = 0;\n this._unmodified = true;\n this._edgeInsets = new EdgeInsets();\n this._posMatrixCache = {};\n this._alignedPosMatrixCache = {};\n};\nvar prototypeAccessors = {\n minZoom: { configurable: true },\n maxZoom: { configurable: true },\n minPitch: { configurable: true },\n maxPitch: { configurable: true },\n renderWorldCopies: { configurable: true },\n worldSize: { configurable: true },\n centerOffset: { configurable: true },\n size: { configurable: true },\n bearing: { configurable: true },\n pitch: { configurable: true },\n fov: { configurable: true },\n zoom: { configurable: true },\n center: { configurable: true },\n padding: { configurable: true },\n centerPoint: { configurable: true },\n unmodified: { configurable: true },\n point: { configurable: true }\n};\nTransform.prototype.clone = function clone() {\n var clone = new Transform(this._minZoom, this._maxZoom, this._minPitch, this.maxPitch, this._renderWorldCopies);\n clone.tileSize = this.tileSize;\n clone.latRange = this.latRange;\n clone.width = this.width;\n clone.height = this.height;\n clone._center = this._center;\n clone.zoom = this.zoom;\n clone.angle = this.angle;\n clone._fov = this._fov;\n clone._pitch = this._pitch;\n clone._unmodified = this._unmodified;\n clone._edgeInsets = this._edgeInsets.clone();\n clone._calcMatrices();\n return clone;\n};\nprototypeAccessors.minZoom.get = function () {\n return this._minZoom;\n};\nprototypeAccessors.minZoom.set = function (zoom) {\n if (this._minZoom === zoom) {\n return;\n }\n this._minZoom = zoom;\n this.zoom = Math.max(this.zoom, zoom);\n};\nprototypeAccessors.maxZoom.get = function () {\n return this._maxZoom;\n};\nprototypeAccessors.maxZoom.set = function (zoom) {\n if (this._maxZoom === zoom) {\n return;\n }\n this._maxZoom = zoom;\n this.zoom = Math.min(this.zoom, zoom);\n};\nprototypeAccessors.minPitch.get = function () {\n return this._minPitch;\n};\nprototypeAccessors.minPitch.set = function (pitch) {\n if (this._minPitch === pitch) {\n return;\n }\n this._minPitch = pitch;\n this.pitch = Math.max(this.pitch, pitch);\n};\nprototypeAccessors.maxPitch.get = function () {\n return this._maxPitch;\n};\nprototypeAccessors.maxPitch.set = function (pitch) {\n if (this._maxPitch === pitch) {\n return;\n }\n this._maxPitch = pitch;\n this.pitch = Math.min(this.pitch, pitch);\n};\nprototypeAccessors.renderWorldCopies.get = function () {\n return this._renderWorldCopies;\n};\nprototypeAccessors.renderWorldCopies.set = function (renderWorldCopies) {\n if (renderWorldCopies === undefined) {\n renderWorldCopies = true;\n } else if (renderWorldCopies === null) {\n renderWorldCopies = false;\n }\n this._renderWorldCopies = renderWorldCopies;\n};\nprototypeAccessors.worldSize.get = function () {\n return this.tileSize * this.scale;\n};\nprototypeAccessors.centerOffset.get = function () {\n return this.centerPoint._sub(this.size._div(2));\n};\nprototypeAccessors.size.get = function () {\n return new performance.Point(this.width, this.height);\n};\nprototypeAccessors.bearing.get = function () {\n return -this.angle / Math.PI * 180;\n};\nprototypeAccessors.bearing.set = function (bearing) {\n var b = -performance.wrap(bearing, -180, 180) * Math.PI / 180;\n if (this.angle === b) {\n return;\n }\n this._unmodified = false;\n this.angle = b;\n this._calcMatrices();\n this.rotationMatrix = performance.create$2();\n performance.rotate(this.rotationMatrix, this.rotationMatrix, this.angle);\n};\nprototypeAccessors.pitch.get = function () {\n return this._pitch / Math.PI * 180;\n};\nprototypeAccessors.pitch.set = function (pitch) {\n var p = performance.clamp(pitch, this.minPitch, this.maxPitch) / 180 * Math.PI;\n if (this._pitch === p) {\n return;\n }\n this._unmodified = false;\n this._pitch = p;\n this._calcMatrices();\n};\nprototypeAccessors.fov.get = function () {\n return this._fov / Math.PI * 180;\n};\nprototypeAccessors.fov.set = function (fov) {\n fov = Math.max(0.01, Math.min(60, fov));\n if (this._fov === fov) {\n return;\n }\n this._unmodified = false;\n this._fov = fov / 180 * Math.PI;\n this._calcMatrices();\n};\nprototypeAccessors.zoom.get = function () {\n return this._zoom;\n};\nprototypeAccessors.zoom.set = function (zoom) {\n var z = Math.min(Math.max(zoom, this.minZoom), this.maxZoom);\n if (this._zoom === z) {\n return;\n }\n this._unmodified = false;\n this._zoom = z;\n this.scale = this.zoomScale(z);\n this.tileZoom = Math.floor(z);\n this.zoomFraction = z - this.tileZoom;\n this._constrain();\n this._calcMatrices();\n};\nprototypeAccessors.center.get = function () {\n return this._center;\n};\nprototypeAccessors.center.set = function (center) {\n if (center.lat === this._center.lat && center.lng === this._center.lng) {\n return;\n }\n this._unmodified = false;\n this._center = center;\n this._constrain();\n this._calcMatrices();\n};\nprototypeAccessors.padding.get = function () {\n return this._edgeInsets.toJSON();\n};\nprototypeAccessors.padding.set = function (padding) {\n if (this._edgeInsets.equals(padding)) {\n return;\n }\n this._unmodified = false;\n this._edgeInsets.interpolate(this._edgeInsets, padding, 1);\n this._calcMatrices();\n};\nprototypeAccessors.centerPoint.get = function () {\n return this._edgeInsets.getCenter(this.width, this.height);\n};\nTransform.prototype.isPaddingEqual = function isPaddingEqual(padding) {\n return this._edgeInsets.equals(padding);\n};\nTransform.prototype.interpolatePadding = function interpolatePadding(start, target, t) {\n this._unmodified = false;\n this._edgeInsets.interpolate(start, target, t);\n this._constrain();\n this._calcMatrices();\n};\nTransform.prototype.coveringZoomLevel = function coveringZoomLevel(options) {\n var z = (options.roundZoom ? Math.round : Math.floor)(this.zoom + this.scaleZoom(this.tileSize / options.tileSize));\n return Math.max(0, z);\n};\nTransform.prototype.getVisibleUnwrappedCoordinates = function getVisibleUnwrappedCoordinates(tileID) {\n var result = [new performance.UnwrappedTileID(0, tileID)];\n if (this._renderWorldCopies) {\n var utl = this.pointCoordinate(new performance.Point(0, 0));\n var utr = this.pointCoordinate(new performance.Point(this.width, 0));\n var ubl = this.pointCoordinate(new performance.Point(this.width, this.height));\n var ubr = this.pointCoordinate(new performance.Point(0, this.height));\n var w0 = Math.floor(Math.min(utl.x, utr.x, ubl.x, ubr.x));\n var w1 = Math.floor(Math.max(utl.x, utr.x, ubl.x, ubr.x));\n var extraWorldCopy = 1;\n for (var w = w0 - extraWorldCopy; w <= w1 + extraWorldCopy; w++) {\n if (w === 0) {\n continue;\n }\n result.push(new performance.UnwrappedTileID(w, tileID));\n }\n }\n return result;\n};\nTransform.prototype.coveringTiles = function coveringTiles(options) {\n var z = this.coveringZoomLevel(options);\n var actualZ = z;\n if (options.minzoom !== undefined && z < options.minzoom) {\n return [];\n }\n if (options.maxzoom !== undefined && z > options.maxzoom) {\n z = options.maxzoom;\n }\n var centerCoord = performance.MercatorCoordinate.fromLngLat(this.center);\n var numTiles = Math.pow(2, z);\n var centerPoint = [\n numTiles * centerCoord.x,\n numTiles * centerCoord.y,\n 0\n ];\n var cameraFrustum = Frustum.fromInvProjectionMatrix(this.invProjMatrix, this.worldSize, z);\n var minZoom = options.minzoom || 0;\n if (this.pitch <= 60 && this._edgeInsets.top < 0.1) {\n minZoom = z;\n }\n var radiusOfMaxLvlLodInTiles = 3;\n var newRootTile = function (wrap) {\n return {\n aabb: new Aabb([\n wrap * numTiles,\n 0,\n 0\n ], [\n (wrap + 1) * numTiles,\n numTiles,\n 0\n ]),\n zoom: 0,\n x: 0,\n y: 0,\n wrap: wrap,\n fullyVisible: false\n };\n };\n var stack = [];\n var result = [];\n var maxZoom = z;\n var overscaledZ = options.reparseOverscaled ? actualZ : z;\n if (this._renderWorldCopies) {\n for (var i = 1; i <= 3; i++) {\n stack.push(newRootTile(-i));\n stack.push(newRootTile(i));\n }\n }\n stack.push(newRootTile(0));\n while (stack.length > 0) {\n var it = stack.pop();\n var x = it.x;\n var y = it.y;\n var fullyVisible = it.fullyVisible;\n if (!fullyVisible) {\n var intersectResult = it.aabb.intersects(cameraFrustum);\n if (intersectResult === 0) {\n continue;\n }\n fullyVisible = intersectResult === 2;\n }\n var distanceX = it.aabb.distanceX(centerPoint);\n var distanceY = it.aabb.distanceY(centerPoint);\n var longestDim = Math.max(Math.abs(distanceX), Math.abs(distanceY));\n var distToSplit = radiusOfMaxLvlLodInTiles + (1 << maxZoom - it.zoom) - 2;\n if (it.zoom === maxZoom || longestDim > distToSplit && it.zoom >= minZoom) {\n result.push({\n tileID: new performance.OverscaledTileID(it.zoom === maxZoom ? overscaledZ : it.zoom, it.wrap, it.zoom, x, y),\n distanceSq: performance.sqrLen([\n centerPoint[0] - 0.5 - x,\n centerPoint[1] - 0.5 - y\n ])\n });\n continue;\n }\n for (var i$1 = 0; i$1 < 4; i$1++) {\n var childX = (x << 1) + i$1 % 2;\n var childY = (y << 1) + (i$1 >> 1);\n stack.push({\n aabb: it.aabb.quadrant(i$1),\n zoom: it.zoom + 1,\n x: childX,\n y: childY,\n wrap: it.wrap,\n fullyVisible: fullyVisible\n });\n }\n }\n return result.sort(function (a, b) {\n return a.distanceSq - b.distanceSq;\n }).map(function (a) {\n return a.tileID;\n });\n};\nTransform.prototype.resize = function resize(width, height) {\n this.width = width;\n this.height = height;\n this.pixelsToGLUnits = [\n 2 / width,\n -2 / height\n ];\n this._constrain();\n this._calcMatrices();\n};\nprototypeAccessors.unmodified.get = function () {\n return this._unmodified;\n};\nTransform.prototype.zoomScale = function zoomScale(zoom) {\n return Math.pow(2, zoom);\n};\nTransform.prototype.scaleZoom = function scaleZoom(scale) {\n return Math.log(scale) / Math.LN2;\n};\nTransform.prototype.project = function project(lnglat) {\n var lat = performance.clamp(lnglat.lat, -this.maxValidLatitude, this.maxValidLatitude);\n return new performance.Point(performance.mercatorXfromLng(lnglat.lng) * this.worldSize, performance.mercatorYfromLat(lat) * this.worldSize);\n};\nTransform.prototype.unproject = function unproject(point) {\n return new performance.MercatorCoordinate(point.x / this.worldSize, point.y / this.worldSize).toLngLat();\n};\nprototypeAccessors.point.get = function () {\n return this.project(this.center);\n};\nTransform.prototype.setLocationAtPoint = function setLocationAtPoint(lnglat, point) {\n var a = this.pointCoordinate(point);\n var b = this.pointCoordinate(this.centerPoint);\n var loc = this.locationCoordinate(lnglat);\n var newCenter = new performance.MercatorCoordinate(loc.x - (a.x - b.x), loc.y - (a.y - b.y));\n this.center = this.coordinateLocation(newCenter);\n if (this._renderWorldCopies) {\n this.center = this.center.wrap();\n }\n};\nTransform.prototype.locationPoint = function locationPoint(lnglat) {\n return this.coordinatePoint(this.locationCoordinate(lnglat));\n};\nTransform.prototype.pointLocation = function pointLocation(p) {\n return this.coordinateLocation(this.pointCoordinate(p));\n};\nTransform.prototype.locationCoordinate = function locationCoordinate(lnglat) {\n return performance.MercatorCoordinate.fromLngLat(lnglat);\n};\nTransform.prototype.coordinateLocation = function coordinateLocation(coord) {\n return coord.toLngLat();\n};\nTransform.prototype.pointCoordinate = function pointCoordinate(p) {\n var targetZ = 0;\n var coord0 = [\n p.x,\n p.y,\n 0,\n 1\n ];\n var coord1 = [\n p.x,\n p.y,\n 1,\n 1\n ];\n performance.transformMat4(coord0, coord0, this.pixelMatrixInverse);\n performance.transformMat4(coord1, coord1, this.pixelMatrixInverse);\n var w0 = coord0[3];\n var w1 = coord1[3];\n var x0 = coord0[0] / w0;\n var x1 = coord1[0] / w1;\n var y0 = coord0[1] / w0;\n var y1 = coord1[1] / w1;\n var z0 = coord0[2] / w0;\n var z1 = coord1[2] / w1;\n var t = z0 === z1 ? 0 : (targetZ - z0) / (z1 - z0);\n return new performance.MercatorCoordinate(performance.number(x0, x1, t) / this.worldSize, performance.number(y0, y1, t) / this.worldSize);\n};\nTransform.prototype.coordinatePoint = function coordinatePoint(coord) {\n var p = [\n coord.x * this.worldSize,\n coord.y * this.worldSize,\n 0,\n 1\n ];\n performance.transformMat4(p, p, this.pixelMatrix);\n return new performance.Point(p[0] / p[3], p[1] / p[3]);\n};\nTransform.prototype.getBounds = function getBounds() {\n return new performance.LngLatBounds().extend(this.pointLocation(new performance.Point(0, 0))).extend(this.pointLocation(new performance.Point(this.width, 0))).extend(this.pointLocation(new performance.Point(this.width, this.height))).extend(this.pointLocation(new performance.Point(0, this.height)));\n};\nTransform.prototype.getMaxBounds = function getMaxBounds() {\n if (!this.latRange || this.latRange.length !== 2 || !this.lngRange || this.lngRange.length !== 2) {\n return null;\n }\n return new performance.LngLatBounds([\n this.lngRange[0],\n this.latRange[0]\n ], [\n this.lngRange[1],\n this.latRange[1]\n ]);\n};\nTransform.prototype.setMaxBounds = function setMaxBounds(bounds) {\n if (bounds) {\n this.lngRange = [\n bounds.getWest(),\n bounds.getEast()\n ];\n this.latRange = [\n bounds.getSouth(),\n bounds.getNorth()\n ];\n this._constrain();\n } else {\n this.lngRange = null;\n this.latRange = [\n -this.maxValidLatitude,\n this.maxValidLatitude\n ];\n }\n};\nTransform.prototype.calculatePosMatrix = function calculatePosMatrix(unwrappedTileID, aligned) {\n if (aligned === void 0)\n aligned = false;\n var posMatrixKey = unwrappedTileID.key;\n var cache = aligned ? this._alignedPosMatrixCache : this._posMatrixCache;\n if (cache[posMatrixKey]) {\n return cache[posMatrixKey];\n }\n var canonical = unwrappedTileID.canonical;\n var scale = this.worldSize / this.zoomScale(canonical.z);\n var unwrappedX = canonical.x + Math.pow(2, canonical.z) * unwrappedTileID.wrap;\n var posMatrix = performance.identity(new Float64Array(16));\n performance.translate(posMatrix, posMatrix, [\n unwrappedX * scale,\n canonical.y * scale,\n 0\n ]);\n performance.scale(posMatrix, posMatrix, [\n scale / performance.EXTENT,\n scale / performance.EXTENT,\n 1\n ]);\n performance.multiply(posMatrix, aligned ? this.alignedProjMatrix : this.projMatrix, posMatrix);\n cache[posMatrixKey] = new Float32Array(posMatrix);\n return cache[posMatrixKey];\n};\nTransform.prototype.customLayerMatrix = function customLayerMatrix() {\n return this.mercatorMatrix.slice();\n};\nTransform.prototype._constrain = function _constrain() {\n if (!this.center || !this.width || !this.height || this._constraining) {\n return;\n }\n this._constraining = true;\n var minY = -90;\n var maxY = 90;\n var minX = -180;\n var maxX = 180;\n var sy, sx, x2, y2;\n var size = this.size, unmodified = this._unmodified;\n if (this.latRange) {\n var latRange = this.latRange;\n minY = performance.mercatorYfromLat(latRange[1]) * this.worldSize;\n maxY = performance.mercatorYfromLat(latRange[0]) * this.worldSize;\n sy = maxY - minY < size.y ? size.y / (maxY - minY) : 0;\n }\n if (this.lngRange) {\n var lngRange = this.lngRange;\n minX = performance.mercatorXfromLng(lngRange[0]) * this.worldSize;\n maxX = performance.mercatorXfromLng(lngRange[1]) * this.worldSize;\n sx = maxX - minX < size.x ? size.x / (maxX - minX) : 0;\n }\n var point = this.point;\n var s = Math.max(sx || 0, sy || 0);\n if (s) {\n this.center = this.unproject(new performance.Point(sx ? (maxX + minX) / 2 : point.x, sy ? (maxY + minY) / 2 : point.y));\n this.zoom += this.scaleZoom(s);\n this._unmodified = unmodified;\n this._constraining = false;\n return;\n }\n if (this.latRange) {\n var y = point.y, h2 = size.y / 2;\n if (y - h2 < minY) {\n y2 = minY + h2;\n }\n if (y + h2 > maxY) {\n y2 = maxY - h2;\n }\n }\n if (this.lngRange) {\n var x = point.x, w2 = size.x / 2;\n if (x - w2 < minX) {\n x2 = minX + w2;\n }\n if (x + w2 > maxX) {\n x2 = maxX - w2;\n }\n }\n if (x2 !== undefined || y2 !== undefined) {\n this.center = this.unproject(new performance.Point(x2 !== undefined ? x2 : point.x, y2 !== undefined ? y2 : point.y));\n }\n this._unmodified = unmodified;\n this._constraining = false;\n};\nTransform.prototype._calcMatrices = function _calcMatrices() {\n if (!this.height) {\n return;\n }\n var halfFov = this._fov / 2;\n var offset = this.centerOffset;\n this.cameraToCenterDistance = 0.5 / Math.tan(halfFov) * this.height;\n var groundAngle = Math.PI / 2 + this._pitch;\n var fovAboveCenter = this._fov * (0.5 + offset.y / this.height);\n var topHalfSurfaceDistance = Math.sin(fovAboveCenter) * this.cameraToCenterDistance / Math.sin(performance.clamp(Math.PI - groundAngle - fovAboveCenter, 0.01, Math.PI - 0.01));\n var point = this.point;\n var x = point.x, y = point.y;\n var furthestDistance = Math.cos(Math.PI / 2 - this._pitch) * topHalfSurfaceDistance + this.cameraToCenterDistance;\n var farZ = furthestDistance * 1.01;\n var nearZ = this.height / 50;\n var m = new Float64Array(16);\n performance.perspective(m, this._fov, this.width / this.height, nearZ, farZ);\n m[8] = -offset.x * 2 / this.width;\n m[9] = offset.y * 2 / this.height;\n performance.scale(m, m, [\n 1,\n -1,\n 1\n ]);\n performance.translate(m, m, [\n 0,\n 0,\n -this.cameraToCenterDistance\n ]);\n performance.rotateX(m, m, this._pitch);\n performance.rotateZ(m, m, this.angle);\n performance.translate(m, m, [\n -x,\n -y,\n 0\n ]);\n this.mercatorMatrix = performance.scale([], m, [\n this.worldSize,\n this.worldSize,\n this.worldSize\n ]);\n performance.scale(m, m, [\n 1,\n 1,\n performance.mercatorZfromAltitude(1, this.center.lat) * this.worldSize,\n 1\n ]);\n this.projMatrix = m;\n this.invProjMatrix = performance.invert([], this.projMatrix);\n var xShift = this.width % 2 / 2, yShift = this.height % 2 / 2, angleCos = Math.cos(this.angle), angleSin = Math.sin(this.angle), dx = x - Math.round(x) + angleCos * xShift + angleSin * yShift, dy = y - Math.round(y) + angleCos * yShift + angleSin * xShift;\n var alignedM = new Float64Array(m);\n performance.translate(alignedM, alignedM, [\n dx > 0.5 ? dx - 1 : dx,\n dy > 0.5 ? dy - 1 : dy,\n 0\n ]);\n this.alignedProjMatrix = alignedM;\n m = performance.create();\n performance.scale(m, m, [\n this.width / 2,\n -this.height / 2,\n 1\n ]);\n performance.translate(m, m, [\n 1,\n -1,\n 0\n ]);\n this.labelPlaneMatrix = m;\n m = performance.create();\n performance.scale(m, m, [\n 1,\n -1,\n 1\n ]);\n performance.translate(m, m, [\n -1,\n -1,\n 0\n ]);\n performance.scale(m, m, [\n 2 / this.width,\n 2 / this.height,\n 1\n ]);\n this.glCoordMatrix = m;\n this.pixelMatrix = performance.multiply(new Float64Array(16), this.labelPlaneMatrix, this.projMatrix);\n m = performance.invert(new Float64Array(16), this.pixelMatrix);\n if (!m) {\n throw new Error('failed to invert matrix');\n }\n this.pixelMatrixInverse = m;\n this._posMatrixCache = {};\n this._alignedPosMatrixCache = {};\n};\nTransform.prototype.maxPitchScaleFactor = function maxPitchScaleFactor() {\n if (!this.pixelMatrixInverse) {\n return 1;\n }\n var coord = this.pointCoordinate(new performance.Point(0, 0));\n var p = [\n coord.x * this.worldSize,\n coord.y * this.worldSize,\n 0,\n 1\n ];\n var topPoint = performance.transformMat4(p, p, this.pixelMatrix);\n return topPoint[3] / this.cameraToCenterDistance;\n};\nTransform.prototype.getCameraPoint = function getCameraPoint() {\n var pitch = this._pitch;\n var yOffset = Math.tan(pitch) * (this.cameraToCenterDistance || 1);\n return this.centerPoint.add(new performance.Point(0, yOffset));\n};\nTransform.prototype.getCameraQueryGeometry = function getCameraQueryGeometry(queryGeometry) {\n var c = this.getCameraPoint();\n if (queryGeometry.length === 1) {\n return [\n queryGeometry[0],\n c\n ];\n } else {\n var minX = c.x;\n var minY = c.y;\n var maxX = c.x;\n var maxY = c.y;\n for (var i = 0, list = queryGeometry; i < list.length; i += 1) {\n var p = list[i];\n minX = Math.min(minX, p.x);\n minY = Math.min(minY, p.y);\n maxX = Math.max(maxX, p.x);\n maxY = Math.max(maxY, p.y);\n }\n return [\n new performance.Point(minX, minY),\n new performance.Point(maxX, minY),\n new performance.Point(maxX, maxY),\n new performance.Point(minX, maxY),\n new performance.Point(minX, minY)\n ];\n }\n};\nObject.defineProperties(Transform.prototype, prototypeAccessors);\n\nfunction throttle(fn, time) {\n var pending = false;\n var timerId = null;\n var later = function () {\n timerId = null;\n if (pending) {\n fn();\n timerId = setTimeout(later, time);\n pending = false;\n }\n };\n return function () {\n pending = true;\n if (!timerId) {\n later();\n }\n return timerId;\n };\n}\n\nvar Hash = function Hash(hashName) {\n this._hashName = hashName && encodeURIComponent(hashName);\n performance.bindAll([\n '_getCurrentHash',\n '_onHashChange',\n '_updateHash'\n ], this);\n this._updateHash = throttle(this._updateHashUnthrottled.bind(this), 30 * 1000 / 100);\n};\nHash.prototype.addTo = function addTo(map) {\n this._map = map;\n performance.window.addEventListener('hashchange', this._onHashChange, false);\n this._map.on('moveend', this._updateHash);\n return this;\n};\nHash.prototype.remove = function remove() {\n performance.window.removeEventListener('hashchange', this._onHashChange, false);\n this._map.off('moveend', this._updateHash);\n clearTimeout(this._updateHash());\n delete this._map;\n return this;\n};\nHash.prototype.getHashString = function getHashString(mapFeedback) {\n var center = this._map.getCenter(), zoom = Math.round(this._map.getZoom() * 100) / 100, precision = Math.ceil((zoom * Math.LN2 + Math.log(512 / 360 / 0.5)) / Math.LN10), m = Math.pow(10, precision), lng = Math.round(center.lng * m) / m, lat = Math.round(center.lat * m) / m, bearing = this._map.getBearing(), pitch = this._map.getPitch();\n var hash = '';\n if (mapFeedback) {\n hash += '/' + lng + '/' + lat + '/' + zoom;\n } else {\n hash += zoom + '/' + lat + '/' + lng;\n }\n if (bearing || pitch) {\n hash += '/' + Math.round(bearing * 10) / 10;\n }\n if (pitch) {\n hash += '/' + Math.round(pitch);\n }\n if (this._hashName) {\n var hashName = this._hashName;\n var found = false;\n var parts = performance.window.location.hash.slice(1).split('&').map(function (part) {\n var key = part.split('=')[0];\n if (key === hashName) {\n found = true;\n return key + '=' + hash;\n }\n return part;\n }).filter(function (a) {\n return a;\n });\n if (!found) {\n parts.push(hashName + '=' + hash);\n }\n return '#' + parts.join('&');\n }\n return '#' + hash;\n};\nHash.prototype._getCurrentHash = function _getCurrentHash() {\n var this$1 = this;\n var hash = performance.window.location.hash.replace('#', '');\n if (this._hashName) {\n var keyval;\n hash.split('&').map(function (part) {\n return part.split('=');\n }).forEach(function (part) {\n if (part[0] === this$1._hashName) {\n keyval = part;\n }\n });\n return (keyval ? keyval[1] || '' : '').split('/');\n }\n return hash.split('/');\n};\nHash.prototype._onHashChange = function _onHashChange() {\n var loc = this._getCurrentHash();\n if (loc.length >= 3 && !loc.some(function (v) {\n return isNaN(v);\n })) {\n var bearing = this._map.dragRotate.isEnabled() && this._map.touchZoomRotate.isEnabled() ? +(loc[3] || 0) : this._map.getBearing();\n this._map.jumpTo({\n center: [\n +loc[2],\n +loc[1]\n ],\n zoom: +loc[0],\n bearing: bearing,\n pitch: +(loc[4] || 0)\n });\n return true;\n }\n return false;\n};\nHash.prototype._updateHashUnthrottled = function _updateHashUnthrottled() {\n var location = performance.window.location.href.replace(/(#.+)?$/, this.getHashString());\n try {\n performance.window.history.replaceState(performance.window.history.state, null, location);\n } catch (SecurityError) {\n }\n};\n\nvar defaultInertiaOptions = {\n linearity: 0.3,\n easing: performance.bezier(0, 0, 0.3, 1)\n};\nvar defaultPanInertiaOptions = performance.extend({\n deceleration: 2500,\n maxSpeed: 1400\n}, defaultInertiaOptions);\nvar defaultZoomInertiaOptions = performance.extend({\n deceleration: 20,\n maxSpeed: 1400\n}, defaultInertiaOptions);\nvar defaultBearingInertiaOptions = performance.extend({\n deceleration: 1000,\n maxSpeed: 360\n}, defaultInertiaOptions);\nvar defaultPitchInertiaOptions = performance.extend({\n deceleration: 1000,\n maxSpeed: 90\n}, defaultInertiaOptions);\nvar HandlerInertia = function HandlerInertia(map) {\n this._map = map;\n this.clear();\n};\nHandlerInertia.prototype.clear = function clear() {\n this._inertiaBuffer = [];\n};\nHandlerInertia.prototype.record = function record(settings) {\n this._drainInertiaBuffer();\n this._inertiaBuffer.push({\n time: performance.browser.now(),\n settings: settings\n });\n};\nHandlerInertia.prototype._drainInertiaBuffer = function _drainInertiaBuffer() {\n var inertia = this._inertiaBuffer, now = performance.browser.now(), cutoff = 160;\n while (inertia.length > 0 && now - inertia[0].time > cutoff) {\n inertia.shift();\n }\n};\nHandlerInertia.prototype._onMoveEnd = function _onMoveEnd(panInertiaOptions) {\n this._drainInertiaBuffer();\n if (this._inertiaBuffer.length < 2) {\n return;\n }\n var deltas = {\n zoom: 0,\n bearing: 0,\n pitch: 0,\n pan: new performance.Point(0, 0),\n pinchAround: undefined,\n around: undefined\n };\n for (var i = 0, list = this._inertiaBuffer; i < list.length; i += 1) {\n var ref = list[i];\n var settings = ref.settings;\n deltas.zoom += settings.zoomDelta || 0;\n deltas.bearing += settings.bearingDelta || 0;\n deltas.pitch += settings.pitchDelta || 0;\n if (settings.panDelta) {\n deltas.pan._add(settings.panDelta);\n }\n if (settings.around) {\n deltas.around = settings.around;\n }\n if (settings.pinchAround) {\n deltas.pinchAround = settings.pinchAround;\n }\n }\n var lastEntry = this._inertiaBuffer[this._inertiaBuffer.length - 1];\n var duration = lastEntry.time - this._inertiaBuffer[0].time;\n var easeOptions = {};\n if (deltas.pan.mag()) {\n var result = calculateEasing(deltas.pan.mag(), duration, performance.extend({}, defaultPanInertiaOptions, panInertiaOptions || {}));\n easeOptions.offset = deltas.pan.mult(result.amount / deltas.pan.mag());\n easeOptions.center = this._map.transform.center;\n extendDuration(easeOptions, result);\n }\n if (deltas.zoom) {\n var result$1 = calculateEasing(deltas.zoom, duration, defaultZoomInertiaOptions);\n easeOptions.zoom = this._map.transform.zoom + result$1.amount;\n extendDuration(easeOptions, result$1);\n }\n if (deltas.bearing) {\n var result$2 = calculateEasing(deltas.bearing, duration, defaultBearingInertiaOptions);\n easeOptions.bearing = this._map.transform.bearing + performance.clamp(result$2.amount, -179, 179);\n extendDuration(easeOptions, result$2);\n }\n if (deltas.pitch) {\n var result$3 = calculateEasing(deltas.pitch, duration, defaultPitchInertiaOptions);\n easeOptions.pitch = this._map.transform.pitch + result$3.amount;\n extendDuration(easeOptions, result$3);\n }\n if (easeOptions.zoom || easeOptions.bearing) {\n var last = deltas.pinchAround === undefined ? deltas.around : deltas.pinchAround;\n easeOptions.around = last ? this._map.unproject(last) : this._map.getCenter();\n }\n this.clear();\n return performance.extend(easeOptions, { noMoveStart: true });\n};\nfunction extendDuration(easeOptions, result) {\n if (!easeOptions.duration || easeOptions.duration < result.duration) {\n easeOptions.duration = result.duration;\n easeOptions.easing = result.easing;\n }\n}\nfunction calculateEasing(amount, inertiaDuration, inertiaOptions) {\n var maxSpeed = inertiaOptions.maxSpeed;\n var linearity = inertiaOptions.linearity;\n var deceleration = inertiaOptions.deceleration;\n var speed = performance.clamp(amount * linearity / (inertiaDuration / 1000), -maxSpeed, maxSpeed);\n var duration = Math.abs(speed) / (deceleration * linearity);\n return {\n easing: inertiaOptions.easing,\n duration: duration * 1000,\n amount: speed * (duration / 2)\n };\n}\n\nvar MapMouseEvent = function (Event) {\n function MapMouseEvent(type, map, originalEvent, data) {\n if (data === void 0)\n data = {};\n var point = DOM.mousePos(map.getCanvasContainer(), originalEvent);\n var lngLat = map.unproject(point);\n Event.call(this, type, performance.extend({\n point: point,\n lngLat: lngLat,\n originalEvent: originalEvent\n }, data));\n this._defaultPrevented = false;\n this.target = map;\n }\n if (Event)\n MapMouseEvent.__proto__ = Event;\n MapMouseEvent.prototype = Object.create(Event && Event.prototype);\n MapMouseEvent.prototype.constructor = MapMouseEvent;\n var prototypeAccessors = { defaultPrevented: { configurable: true } };\n MapMouseEvent.prototype.preventDefault = function preventDefault() {\n this._defaultPrevented = true;\n };\n prototypeAccessors.defaultPrevented.get = function () {\n return this._defaultPrevented;\n };\n Object.defineProperties(MapMouseEvent.prototype, prototypeAccessors);\n return MapMouseEvent;\n}(performance.Event);\nvar MapTouchEvent = function (Event) {\n function MapTouchEvent(type, map, originalEvent) {\n var touches = type === 'touchend' ? originalEvent.changedTouches : originalEvent.touches;\n var points = DOM.touchPos(map.getCanvasContainer(), touches);\n var lngLats = points.map(function (t) {\n return map.unproject(t);\n });\n var point = points.reduce(function (prev, curr, i, arr) {\n return prev.add(curr.div(arr.length));\n }, new performance.Point(0, 0));\n var lngLat = map.unproject(point);\n Event.call(this, type, {\n points: points,\n point: point,\n lngLats: lngLats,\n lngLat: lngLat,\n originalEvent: originalEvent\n });\n this._defaultPrevented = false;\n }\n if (Event)\n MapTouchEvent.__proto__ = Event;\n MapTouchEvent.prototype = Object.create(Event && Event.prototype);\n MapTouchEvent.prototype.constructor = MapTouchEvent;\n var prototypeAccessors$1 = { defaultPrevented: { configurable: true } };\n MapTouchEvent.prototype.preventDefault = function preventDefault() {\n this._defaultPrevented = true;\n };\n prototypeAccessors$1.defaultPrevented.get = function () {\n return this._defaultPrevented;\n };\n Object.defineProperties(MapTouchEvent.prototype, prototypeAccessors$1);\n return MapTouchEvent;\n}(performance.Event);\nvar MapWheelEvent = function (Event) {\n function MapWheelEvent(type, map, originalEvent) {\n Event.call(this, type, { originalEvent: originalEvent });\n this._defaultPrevented = false;\n }\n if (Event)\n MapWheelEvent.__proto__ = Event;\n MapWheelEvent.prototype = Object.create(Event && Event.prototype);\n MapWheelEvent.prototype.constructor = MapWheelEvent;\n var prototypeAccessors$2 = { defaultPrevented: { configurable: true } };\n MapWheelEvent.prototype.preventDefault = function preventDefault() {\n this._defaultPrevented = true;\n };\n prototypeAccessors$2.defaultPrevented.get = function () {\n return this._defaultPrevented;\n };\n Object.defineProperties(MapWheelEvent.prototype, prototypeAccessors$2);\n return MapWheelEvent;\n}(performance.Event);\n\nvar MapEventHandler = function MapEventHandler(map, options) {\n this._map = map;\n this._clickTolerance = options.clickTolerance;\n};\nMapEventHandler.prototype.reset = function reset() {\n delete this._mousedownPos;\n};\nMapEventHandler.prototype.wheel = function wheel(e) {\n return this._firePreventable(new MapWheelEvent(e.type, this._map, e));\n};\nMapEventHandler.prototype.mousedown = function mousedown(e, point) {\n this._mousedownPos = point;\n return this._firePreventable(new MapMouseEvent(e.type, this._map, e));\n};\nMapEventHandler.prototype.mouseup = function mouseup(e) {\n this._map.fire(new MapMouseEvent(e.type, this._map, e));\n};\nMapEventHandler.prototype.click = function click(e, point) {\n if (this._mousedownPos && this._mousedownPos.dist(point) >= this._clickTolerance) {\n return;\n }\n this._map.fire(new MapMouseEvent(e.type, this._map, e));\n};\nMapEventHandler.prototype.dblclick = function dblclick(e) {\n return this._firePreventable(new MapMouseEvent(e.type, this._map, e));\n};\nMapEventHandler.prototype.mouseover = function mouseover(e) {\n this._map.fire(new MapMouseEvent(e.type, this._map, e));\n};\nMapEventHandler.prototype.mouseout = function mouseout(e) {\n this._map.fire(new MapMouseEvent(e.type, this._map, e));\n};\nMapEventHandler.prototype.touchstart = function touchstart(e) {\n return this._firePreventable(new MapTouchEvent(e.type, this._map, e));\n};\nMapEventHandler.prototype.touchmove = function touchmove(e) {\n this._map.fire(new MapTouchEvent(e.type, this._map, e));\n};\nMapEventHandler.prototype.touchend = function touchend(e) {\n this._map.fire(new MapTouchEvent(e.type, this._map, e));\n};\nMapEventHandler.prototype.touchcancel = function touchcancel(e) {\n this._map.fire(new MapTouchEvent(e.type, this._map, e));\n};\nMapEventHandler.prototype._firePreventable = function _firePreventable(mapEvent) {\n this._map.fire(mapEvent);\n if (mapEvent.defaultPrevented) {\n return {};\n }\n};\nMapEventHandler.prototype.isEnabled = function isEnabled() {\n return true;\n};\nMapEventHandler.prototype.isActive = function isActive() {\n return false;\n};\nMapEventHandler.prototype.enable = function enable() {\n};\nMapEventHandler.prototype.disable = function disable() {\n};\nvar BlockableMapEventHandler = function BlockableMapEventHandler(map) {\n this._map = map;\n};\nBlockableMapEventHandler.prototype.reset = function reset() {\n this._delayContextMenu = false;\n delete this._contextMenuEvent;\n};\nBlockableMapEventHandler.prototype.mousemove = function mousemove(e) {\n this._map.fire(new MapMouseEvent(e.type, this._map, e));\n};\nBlockableMapEventHandler.prototype.mousedown = function mousedown() {\n this._delayContextMenu = true;\n};\nBlockableMapEventHandler.prototype.mouseup = function mouseup() {\n this._delayContextMenu = false;\n if (this._contextMenuEvent) {\n this._map.fire(new MapMouseEvent('contextmenu', this._map, this._contextMenuEvent));\n delete this._contextMenuEvent;\n }\n};\nBlockableMapEventHandler.prototype.contextmenu = function contextmenu(e) {\n if (this._delayContextMenu) {\n this._contextMenuEvent = e;\n } else {\n this._map.fire(new MapMouseEvent(e.type, this._map, e));\n }\n if (this._map.listens('contextmenu')) {\n e.preventDefault();\n }\n};\nBlockableMapEventHandler.prototype.isEnabled = function isEnabled() {\n return true;\n};\nBlockableMapEventHandler.prototype.isActive = function isActive() {\n return false;\n};\nBlockableMapEventHandler.prototype.enable = function enable() {\n};\nBlockableMapEventHandler.prototype.disable = function disable() {\n};\n\nvar BoxZoomHandler = function BoxZoomHandler(map, options) {\n this._map = map;\n this._el = map.getCanvasContainer();\n this._container = map.getContainer();\n this._clickTolerance = options.clickTolerance || 1;\n};\nBoxZoomHandler.prototype.isEnabled = function isEnabled() {\n return !!this._enabled;\n};\nBoxZoomHandler.prototype.isActive = function isActive() {\n return !!this._active;\n};\nBoxZoomHandler.prototype.enable = function enable() {\n if (this.isEnabled()) {\n return;\n }\n this._enabled = true;\n};\nBoxZoomHandler.prototype.disable = function disable() {\n if (!this.isEnabled()) {\n return;\n }\n this._enabled = false;\n};\nBoxZoomHandler.prototype.mousedown = function mousedown(e, point) {\n if (!this.isEnabled()) {\n return;\n }\n if (!(e.shiftKey && e.button === 0)) {\n return;\n }\n DOM.disableDrag();\n this._startPos = this._lastPos = point;\n this._active = true;\n};\nBoxZoomHandler.prototype.mousemoveWindow = function mousemoveWindow(e, point) {\n if (!this._active) {\n return;\n }\n var pos = point;\n if (this._lastPos.equals(pos) || !this._box && pos.dist(this._startPos) < this._clickTolerance) {\n return;\n }\n var p0 = this._startPos;\n this._lastPos = pos;\n if (!this._box) {\n this._box = DOM.create('div', 'mapboxgl-boxzoom', this._container);\n this._container.classList.add('mapboxgl-crosshair');\n this._fireEvent('boxzoomstart', e);\n }\n var minX = Math.min(p0.x, pos.x), maxX = Math.max(p0.x, pos.x), minY = Math.min(p0.y, pos.y), maxY = Math.max(p0.y, pos.y);\n DOM.setTransform(this._box, 'translate(' + minX + 'px,' + minY + 'px)');\n this._box.style.width = maxX - minX + 'px';\n this._box.style.height = maxY - minY + 'px';\n};\nBoxZoomHandler.prototype.mouseupWindow = function mouseupWindow(e, point) {\n var this$1 = this;\n if (!this._active) {\n return;\n }\n if (e.button !== 0) {\n return;\n }\n var p0 = this._startPos, p1 = point;\n this.reset();\n DOM.suppressClick();\n if (p0.x === p1.x && p0.y === p1.y) {\n this._fireEvent('boxzoomcancel', e);\n } else {\n this._map.fire(new performance.Event('boxzoomend', { originalEvent: e }));\n return {\n cameraAnimation: function (map) {\n return map.fitScreenCoordinates(p0, p1, this$1._map.getBearing(), { linear: true });\n }\n };\n }\n};\nBoxZoomHandler.prototype.keydown = function keydown(e) {\n if (!this._active) {\n return;\n }\n if (e.keyCode === 27) {\n this.reset();\n this._fireEvent('boxzoomcancel', e);\n }\n};\nBoxZoomHandler.prototype.reset = function reset() {\n this._active = false;\n this._container.classList.remove('mapboxgl-crosshair');\n if (this._box) {\n DOM.remove(this._box);\n this._box = null;\n }\n DOM.enableDrag();\n delete this._startPos;\n delete this._lastPos;\n};\nBoxZoomHandler.prototype._fireEvent = function _fireEvent(type, e) {\n return this._map.fire(new performance.Event(type, { originalEvent: e }));\n};\n\nfunction indexTouches(touches, points) {\n var obj = {};\n for (var i = 0; i < touches.length; i++) {\n obj[touches[i].identifier] = points[i];\n }\n return obj;\n}\n\nfunction getCentroid(points) {\n var sum = new performance.Point(0, 0);\n for (var i = 0, list = points; i < list.length; i += 1) {\n var point = list[i];\n sum._add(point);\n }\n return sum.div(points.length);\n}\nvar MAX_TAP_INTERVAL = 500;\nvar MAX_TOUCH_TIME = 500;\nvar MAX_DIST = 30;\nvar SingleTapRecognizer = function SingleTapRecognizer(options) {\n this.reset();\n this.numTouches = options.numTouches;\n};\nSingleTapRecognizer.prototype.reset = function reset() {\n delete this.centroid;\n delete this.startTime;\n delete this.touches;\n this.aborted = false;\n};\nSingleTapRecognizer.prototype.touchstart = function touchstart(e, points, mapTouches) {\n if (this.centroid || mapTouches.length > this.numTouches) {\n this.aborted = true;\n }\n if (this.aborted) {\n return;\n }\n if (this.startTime === undefined) {\n this.startTime = e.timeStamp;\n }\n if (mapTouches.length === this.numTouches) {\n this.centroid = getCentroid(points);\n this.touches = indexTouches(mapTouches, points);\n }\n};\nSingleTapRecognizer.prototype.touchmove = function touchmove(e, points, mapTouches) {\n if (this.aborted || !this.centroid) {\n return;\n }\n var newTouches = indexTouches(mapTouches, points);\n for (var id in this.touches) {\n var prevPos = this.touches[id];\n var pos = newTouches[id];\n if (!pos || pos.dist(prevPos) > MAX_DIST) {\n this.aborted = true;\n }\n }\n};\nSingleTapRecognizer.prototype.touchend = function touchend(e, points, mapTouches) {\n if (!this.centroid || e.timeStamp - this.startTime > MAX_TOUCH_TIME) {\n this.aborted = true;\n }\n if (mapTouches.length === 0) {\n var centroid = !this.aborted && this.centroid;\n this.reset();\n if (centroid) {\n return centroid;\n }\n }\n};\nvar TapRecognizer = function TapRecognizer(options) {\n this.singleTap = new SingleTapRecognizer(options);\n this.numTaps = options.numTaps;\n this.reset();\n};\nTapRecognizer.prototype.reset = function reset() {\n this.lastTime = Infinity;\n delete this.lastTap;\n this.count = 0;\n this.singleTap.reset();\n};\nTapRecognizer.prototype.touchstart = function touchstart(e, points, mapTouches) {\n this.singleTap.touchstart(e, points, mapTouches);\n};\nTapRecognizer.prototype.touchmove = function touchmove(e, points, mapTouches) {\n this.singleTap.touchmove(e, points, mapTouches);\n};\nTapRecognizer.prototype.touchend = function touchend(e, points, mapTouches) {\n var tap = this.singleTap.touchend(e, points, mapTouches);\n if (tap) {\n var soonEnough = e.timeStamp - this.lastTime < MAX_TAP_INTERVAL;\n var closeEnough = !this.lastTap || this.lastTap.dist(tap) < MAX_DIST;\n if (!soonEnough || !closeEnough) {\n this.reset();\n }\n this.count++;\n this.lastTime = e.timeStamp;\n this.lastTap = tap;\n if (this.count === this.numTaps) {\n this.reset();\n return tap;\n }\n }\n};\n\nvar TapZoomHandler = function TapZoomHandler() {\n this._zoomIn = new TapRecognizer({\n numTouches: 1,\n numTaps: 2\n });\n this._zoomOut = new TapRecognizer({\n numTouches: 2,\n numTaps: 1\n });\n this.reset();\n};\nTapZoomHandler.prototype.reset = function reset() {\n this._active = false;\n this._zoomIn.reset();\n this._zoomOut.reset();\n};\nTapZoomHandler.prototype.touchstart = function touchstart(e, points, mapTouches) {\n this._zoomIn.touchstart(e, points, mapTouches);\n this._zoomOut.touchstart(e, points, mapTouches);\n};\nTapZoomHandler.prototype.touchmove = function touchmove(e, points, mapTouches) {\n this._zoomIn.touchmove(e, points, mapTouches);\n this._zoomOut.touchmove(e, points, mapTouches);\n};\nTapZoomHandler.prototype.touchend = function touchend(e, points, mapTouches) {\n var this$1 = this;\n var zoomInPoint = this._zoomIn.touchend(e, points, mapTouches);\n var zoomOutPoint = this._zoomOut.touchend(e, points, mapTouches);\n if (zoomInPoint) {\n this._active = true;\n e.preventDefault();\n setTimeout(function () {\n return this$1.reset();\n }, 0);\n return {\n cameraAnimation: function (map) {\n return map.easeTo({\n duration: 300,\n zoom: map.getZoom() + 1,\n around: map.unproject(zoomInPoint)\n }, { originalEvent: e });\n }\n };\n } else if (zoomOutPoint) {\n this._active = true;\n e.preventDefault();\n setTimeout(function () {\n return this$1.reset();\n }, 0);\n return {\n cameraAnimation: function (map) {\n return map.easeTo({\n duration: 300,\n zoom: map.getZoom() - 1,\n around: map.unproject(zoomOutPoint)\n }, { originalEvent: e });\n }\n };\n }\n};\nTapZoomHandler.prototype.touchcancel = function touchcancel() {\n this.reset();\n};\nTapZoomHandler.prototype.enable = function enable() {\n this._enabled = true;\n};\nTapZoomHandler.prototype.disable = function disable() {\n this._enabled = false;\n this.reset();\n};\nTapZoomHandler.prototype.isEnabled = function isEnabled() {\n return this._enabled;\n};\nTapZoomHandler.prototype.isActive = function isActive() {\n return this._active;\n};\n\nvar LEFT_BUTTON = 0;\nvar RIGHT_BUTTON = 2;\nvar BUTTONS_FLAGS = {};\nBUTTONS_FLAGS[LEFT_BUTTON] = 1;\nBUTTONS_FLAGS[RIGHT_BUTTON] = 2;\nfunction buttonStillPressed(e, button) {\n var flag = BUTTONS_FLAGS[button];\n return e.buttons === undefined || (e.buttons & flag) !== flag;\n}\nvar MouseHandler = function MouseHandler(options) {\n this.reset();\n this._clickTolerance = options.clickTolerance || 1;\n};\nMouseHandler.prototype.reset = function reset() {\n this._active = false;\n this._moved = false;\n delete this._lastPoint;\n delete this._eventButton;\n};\nMouseHandler.prototype._correctButton = function _correctButton(e, button) {\n return false;\n};\nMouseHandler.prototype._move = function _move(lastPoint, point) {\n return {};\n};\nMouseHandler.prototype.mousedown = function mousedown(e, point) {\n if (this._lastPoint) {\n return;\n }\n var eventButton = DOM.mouseButton(e);\n if (!this._correctButton(e, eventButton)) {\n return;\n }\n this._lastPoint = point;\n this._eventButton = eventButton;\n};\nMouseHandler.prototype.mousemoveWindow = function mousemoveWindow(e, point) {\n var lastPoint = this._lastPoint;\n if (!lastPoint) {\n return;\n }\n e.preventDefault();\n if (buttonStillPressed(e, this._eventButton)) {\n this.reset();\n return;\n }\n if (!this._moved && point.dist(lastPoint) < this._clickTolerance) {\n return;\n }\n this._moved = true;\n this._lastPoint = point;\n return this._move(lastPoint, point);\n};\nMouseHandler.prototype.mouseupWindow = function mouseupWindow(e) {\n if (!this._lastPoint) {\n return;\n }\n var eventButton = DOM.mouseButton(e);\n if (eventButton !== this._eventButton) {\n return;\n }\n if (this._moved) {\n DOM.suppressClick();\n }\n this.reset();\n};\nMouseHandler.prototype.enable = function enable() {\n this._enabled = true;\n};\nMouseHandler.prototype.disable = function disable() {\n this._enabled = false;\n this.reset();\n};\nMouseHandler.prototype.isEnabled = function isEnabled() {\n return this._enabled;\n};\nMouseHandler.prototype.isActive = function isActive() {\n return this._active;\n};\nvar MousePanHandler = function (MouseHandler) {\n function MousePanHandler() {\n MouseHandler.apply(this, arguments);\n }\n if (MouseHandler)\n MousePanHandler.__proto__ = MouseHandler;\n MousePanHandler.prototype = Object.create(MouseHandler && MouseHandler.prototype);\n MousePanHandler.prototype.constructor = MousePanHandler;\n MousePanHandler.prototype.mousedown = function mousedown(e, point) {\n MouseHandler.prototype.mousedown.call(this, e, point);\n if (this._lastPoint) {\n this._active = true;\n }\n };\n MousePanHandler.prototype._correctButton = function _correctButton(e, button) {\n return button === LEFT_BUTTON && !e.ctrlKey;\n };\n MousePanHandler.prototype._move = function _move(lastPoint, point) {\n return {\n around: point,\n panDelta: point.sub(lastPoint)\n };\n };\n return MousePanHandler;\n}(MouseHandler);\nvar MouseRotateHandler = function (MouseHandler) {\n function MouseRotateHandler() {\n MouseHandler.apply(this, arguments);\n }\n if (MouseHandler)\n MouseRotateHandler.__proto__ = MouseHandler;\n MouseRotateHandler.prototype = Object.create(MouseHandler && MouseHandler.prototype);\n MouseRotateHandler.prototype.constructor = MouseRotateHandler;\n MouseRotateHandler.prototype._correctButton = function _correctButton(e, button) {\n return button === LEFT_BUTTON && e.ctrlKey || button === RIGHT_BUTTON;\n };\n MouseRotateHandler.prototype._move = function _move(lastPoint, point) {\n var degreesPerPixelMoved = 0.8;\n var bearingDelta = (point.x - lastPoint.x) * degreesPerPixelMoved;\n if (bearingDelta) {\n this._active = true;\n return { bearingDelta: bearingDelta };\n }\n };\n MouseRotateHandler.prototype.contextmenu = function contextmenu(e) {\n e.preventDefault();\n };\n return MouseRotateHandler;\n}(MouseHandler);\nvar MousePitchHandler = function (MouseHandler) {\n function MousePitchHandler() {\n MouseHandler.apply(this, arguments);\n }\n if (MouseHandler)\n MousePitchHandler.__proto__ = MouseHandler;\n MousePitchHandler.prototype = Object.create(MouseHandler && MouseHandler.prototype);\n MousePitchHandler.prototype.constructor = MousePitchHandler;\n MousePitchHandler.prototype._correctButton = function _correctButton(e, button) {\n return button === LEFT_BUTTON && e.ctrlKey || button === RIGHT_BUTTON;\n };\n MousePitchHandler.prototype._move = function _move(lastPoint, point) {\n var degreesPerPixelMoved = -0.5;\n var pitchDelta = (point.y - lastPoint.y) * degreesPerPixelMoved;\n if (pitchDelta) {\n this._active = true;\n return { pitchDelta: pitchDelta };\n }\n };\n MousePitchHandler.prototype.contextmenu = function contextmenu(e) {\n e.preventDefault();\n };\n return MousePitchHandler;\n}(MouseHandler);\n\nvar TouchPanHandler = function TouchPanHandler(options) {\n this._minTouches = 1;\n this._clickTolerance = options.clickTolerance || 1;\n this.reset();\n};\nTouchPanHandler.prototype.reset = function reset() {\n this._active = false;\n this._touches = {};\n this._sum = new performance.Point(0, 0);\n};\nTouchPanHandler.prototype.touchstart = function touchstart(e, points, mapTouches) {\n return this._calculateTransform(e, points, mapTouches);\n};\nTouchPanHandler.prototype.touchmove = function touchmove(e, points, mapTouches) {\n if (!this._active || mapTouches.length < this._minTouches) {\n return;\n }\n e.preventDefault();\n return this._calculateTransform(e, points, mapTouches);\n};\nTouchPanHandler.prototype.touchend = function touchend(e, points, mapTouches) {\n this._calculateTransform(e, points, mapTouches);\n if (this._active && mapTouches.length < this._minTouches) {\n this.reset();\n }\n};\nTouchPanHandler.prototype.touchcancel = function touchcancel() {\n this.reset();\n};\nTouchPanHandler.prototype._calculateTransform = function _calculateTransform(e, points, mapTouches) {\n if (mapTouches.length > 0) {\n this._active = true;\n }\n var touches = indexTouches(mapTouches, points);\n var touchPointSum = new performance.Point(0, 0);\n var touchDeltaSum = new performance.Point(0, 0);\n var touchDeltaCount = 0;\n for (var identifier in touches) {\n var point = touches[identifier];\n var prevPoint = this._touches[identifier];\n if (prevPoint) {\n touchPointSum._add(point);\n touchDeltaSum._add(point.sub(prevPoint));\n touchDeltaCount++;\n touches[identifier] = point;\n }\n }\n this._touches = touches;\n if (touchDeltaCount < this._minTouches || !touchDeltaSum.mag()) {\n return;\n }\n var panDelta = touchDeltaSum.div(touchDeltaCount);\n this._sum._add(panDelta);\n if (this._sum.mag() < this._clickTolerance) {\n return;\n }\n var around = touchPointSum.div(touchDeltaCount);\n return {\n around: around,\n panDelta: panDelta\n };\n};\nTouchPanHandler.prototype.enable = function enable() {\n this._enabled = true;\n};\nTouchPanHandler.prototype.disable = function disable() {\n this._enabled = false;\n this.reset();\n};\nTouchPanHandler.prototype.isEnabled = function isEnabled() {\n return this._enabled;\n};\nTouchPanHandler.prototype.isActive = function isActive() {\n return this._active;\n};\n\nvar TwoTouchHandler = function TwoTouchHandler() {\n this.reset();\n};\nTwoTouchHandler.prototype.reset = function reset() {\n this._active = false;\n delete this._firstTwoTouches;\n};\nTwoTouchHandler.prototype._start = function _start(points) {\n};\nTwoTouchHandler.prototype._move = function _move(points, pinchAround, e) {\n return {};\n};\nTwoTouchHandler.prototype.touchstart = function touchstart(e, points, mapTouches) {\n if (this._firstTwoTouches || mapTouches.length < 2) {\n return;\n }\n this._firstTwoTouches = [\n mapTouches[0].identifier,\n mapTouches[1].identifier\n ];\n this._start([\n points[0],\n points[1]\n ]);\n};\nTwoTouchHandler.prototype.touchmove = function touchmove(e, points, mapTouches) {\n if (!this._firstTwoTouches) {\n return;\n }\n e.preventDefault();\n var ref = this._firstTwoTouches;\n var idA = ref[0];\n var idB = ref[1];\n var a = getTouchById(mapTouches, points, idA);\n var b = getTouchById(mapTouches, points, idB);\n if (!a || !b) {\n return;\n }\n var pinchAround = this._aroundCenter ? null : a.add(b).div(2);\n return this._move([\n a,\n b\n ], pinchAround, e);\n};\nTwoTouchHandler.prototype.touchend = function touchend(e, points, mapTouches) {\n if (!this._firstTwoTouches) {\n return;\n }\n var ref = this._firstTwoTouches;\n var idA = ref[0];\n var idB = ref[1];\n var a = getTouchById(mapTouches, points, idA);\n var b = getTouchById(mapTouches, points, idB);\n if (a && b) {\n return;\n }\n if (this._active) {\n DOM.suppressClick();\n }\n this.reset();\n};\nTwoTouchHandler.prototype.touchcancel = function touchcancel() {\n this.reset();\n};\nTwoTouchHandler.prototype.enable = function enable(options) {\n this._enabled = true;\n this._aroundCenter = !!options && options.around === 'center';\n};\nTwoTouchHandler.prototype.disable = function disable() {\n this._enabled = false;\n this.reset();\n};\nTwoTouchHandler.prototype.isEnabled = function isEnabled() {\n return this._enabled;\n};\nTwoTouchHandler.prototype.isActive = function isActive() {\n return this._active;\n};\nfunction getTouchById(mapTouches, points, identifier) {\n for (var i = 0; i < mapTouches.length; i++) {\n if (mapTouches[i].identifier === identifier) {\n return points[i];\n }\n }\n}\nvar ZOOM_THRESHOLD = 0.1;\nfunction getZoomDelta(distance, lastDistance) {\n return Math.log(distance / lastDistance) / Math.LN2;\n}\nvar TouchZoomHandler = function (TwoTouchHandler) {\n function TouchZoomHandler() {\n TwoTouchHandler.apply(this, arguments);\n }\n if (TwoTouchHandler)\n TouchZoomHandler.__proto__ = TwoTouchHandler;\n TouchZoomHandler.prototype = Object.create(TwoTouchHandler && TwoTouchHandler.prototype);\n TouchZoomHandler.prototype.constructor = TouchZoomHandler;\n TouchZoomHandler.prototype.reset = function reset() {\n TwoTouchHandler.prototype.reset.call(this);\n delete this._distance;\n delete this._startDistance;\n };\n TouchZoomHandler.prototype._start = function _start(points) {\n this._startDistance = this._distance = points[0].dist(points[1]);\n };\n TouchZoomHandler.prototype._move = function _move(points, pinchAround) {\n var lastDistance = this._distance;\n this._distance = points[0].dist(points[1]);\n if (!this._active && Math.abs(getZoomDelta(this._distance, this._startDistance)) < ZOOM_THRESHOLD) {\n return;\n }\n this._active = true;\n return {\n zoomDelta: getZoomDelta(this._distance, lastDistance),\n pinchAround: pinchAround\n };\n };\n return TouchZoomHandler;\n}(TwoTouchHandler);\nvar ROTATION_THRESHOLD = 25;\nfunction getBearingDelta(a, b) {\n return a.angleWith(b) * 180 / Math.PI;\n}\nvar TouchRotateHandler = function (TwoTouchHandler) {\n function TouchRotateHandler() {\n TwoTouchHandler.apply(this, arguments);\n }\n if (TwoTouchHandler)\n TouchRotateHandler.__proto__ = TwoTouchHandler;\n TouchRotateHandler.prototype = Object.create(TwoTouchHandler && TwoTouchHandler.prototype);\n TouchRotateHandler.prototype.constructor = TouchRotateHandler;\n TouchRotateHandler.prototype.reset = function reset() {\n TwoTouchHandler.prototype.reset.call(this);\n delete this._minDiameter;\n delete this._startVector;\n delete this._vector;\n };\n TouchRotateHandler.prototype._start = function _start(points) {\n this._startVector = this._vector = points[0].sub(points[1]);\n this._minDiameter = points[0].dist(points[1]);\n };\n TouchRotateHandler.prototype._move = function _move(points, pinchAround) {\n var lastVector = this._vector;\n this._vector = points[0].sub(points[1]);\n if (!this._active && this._isBelowThreshold(this._vector)) {\n return;\n }\n this._active = true;\n return {\n bearingDelta: getBearingDelta(this._vector, lastVector),\n pinchAround: pinchAround\n };\n };\n TouchRotateHandler.prototype._isBelowThreshold = function _isBelowThreshold(vector) {\n this._minDiameter = Math.min(this._minDiameter, vector.mag());\n var circumference = Math.PI * this._minDiameter;\n var threshold = ROTATION_THRESHOLD / circumference * 360;\n var bearingDeltaSinceStart = getBearingDelta(vector, this._startVector);\n return Math.abs(bearingDeltaSinceStart) < threshold;\n };\n return TouchRotateHandler;\n}(TwoTouchHandler);\nfunction isVertical(vector) {\n return Math.abs(vector.y) > Math.abs(vector.x);\n}\nvar ALLOWED_SINGLE_TOUCH_TIME = 100;\nvar TouchPitchHandler = function (TwoTouchHandler) {\n function TouchPitchHandler() {\n TwoTouchHandler.apply(this, arguments);\n }\n if (TwoTouchHandler)\n TouchPitchHandler.__proto__ = TwoTouchHandler;\n TouchPitchHandler.prototype = Object.create(TwoTouchHandler && TwoTouchHandler.prototype);\n TouchPitchHandler.prototype.constructor = TouchPitchHandler;\n TouchPitchHandler.prototype.reset = function reset() {\n TwoTouchHandler.prototype.reset.call(this);\n this._valid = undefined;\n delete this._firstMove;\n delete this._lastPoints;\n };\n TouchPitchHandler.prototype._start = function _start(points) {\n this._lastPoints = points;\n if (isVertical(points[0].sub(points[1]))) {\n this._valid = false;\n }\n };\n TouchPitchHandler.prototype._move = function _move(points, center, e) {\n var vectorA = points[0].sub(this._lastPoints[0]);\n var vectorB = points[1].sub(this._lastPoints[1]);\n this._valid = this.gestureBeginsVertically(vectorA, vectorB, e.timeStamp);\n if (!this._valid) {\n return;\n }\n this._lastPoints = points;\n this._active = true;\n var yDeltaAverage = (vectorA.y + vectorB.y) / 2;\n var degreesPerPixelMoved = -0.5;\n return { pitchDelta: yDeltaAverage * degreesPerPixelMoved };\n };\n TouchPitchHandler.prototype.gestureBeginsVertically = function gestureBeginsVertically(vectorA, vectorB, timeStamp) {\n if (this._valid !== undefined) {\n return this._valid;\n }\n var threshold = 2;\n var movedA = vectorA.mag() >= threshold;\n var movedB = vectorB.mag() >= threshold;\n if (!movedA && !movedB) {\n return;\n }\n if (!movedA || !movedB) {\n if (this._firstMove === undefined) {\n this._firstMove = timeStamp;\n }\n if (timeStamp - this._firstMove < ALLOWED_SINGLE_TOUCH_TIME) {\n return undefined;\n } else {\n return false;\n }\n }\n var isSameDirection = vectorA.y > 0 === vectorB.y > 0;\n return isVertical(vectorA) && isVertical(vectorB) && isSameDirection;\n };\n return TouchPitchHandler;\n}(TwoTouchHandler);\n\nvar defaultOptions = {\n panStep: 100,\n bearingStep: 15,\n pitchStep: 10\n};\nvar KeyboardHandler = function KeyboardHandler() {\n var stepOptions = defaultOptions;\n this._panStep = stepOptions.panStep;\n this._bearingStep = stepOptions.bearingStep;\n this._pitchStep = stepOptions.pitchStep;\n this._rotationDisabled = false;\n};\nKeyboardHandler.prototype.reset = function reset() {\n this._active = false;\n};\nKeyboardHandler.prototype.keydown = function keydown(e) {\n var this$1 = this;\n if (e.altKey || e.ctrlKey || e.metaKey) {\n return;\n }\n var zoomDir = 0;\n var bearingDir = 0;\n var pitchDir = 0;\n var xDir = 0;\n var yDir = 0;\n switch (e.keyCode) {\n case 61:\n case 107:\n case 171:\n case 187:\n zoomDir = 1;\n break;\n case 189:\n case 109:\n case 173:\n zoomDir = -1;\n break;\n case 37:\n if (e.shiftKey) {\n bearingDir = -1;\n } else {\n e.preventDefault();\n xDir = -1;\n }\n break;\n case 39:\n if (e.shiftKey) {\n bearingDir = 1;\n } else {\n e.preventDefault();\n xDir = 1;\n }\n break;\n case 38:\n if (e.shiftKey) {\n pitchDir = 1;\n } else {\n e.preventDefault();\n yDir = -1;\n }\n break;\n case 40:\n if (e.shiftKey) {\n pitchDir = -1;\n } else {\n e.preventDefault();\n yDir = 1;\n }\n break;\n default:\n return;\n }\n if (this._rotationDisabled) {\n bearingDir = 0;\n pitchDir = 0;\n }\n return {\n cameraAnimation: function (map) {\n var zoom = map.getZoom();\n map.easeTo({\n duration: 300,\n easeId: 'keyboardHandler',\n easing: easeOut,\n zoom: zoomDir ? Math.round(zoom) + zoomDir * (e.shiftKey ? 2 : 1) : zoom,\n bearing: map.getBearing() + bearingDir * this$1._bearingStep,\n pitch: map.getPitch() + pitchDir * this$1._pitchStep,\n offset: [\n -xDir * this$1._panStep,\n -yDir * this$1._panStep\n ],\n center: map.getCenter()\n }, { originalEvent: e });\n }\n };\n};\nKeyboardHandler.prototype.enable = function enable() {\n this._enabled = true;\n};\nKeyboardHandler.prototype.disable = function disable() {\n this._enabled = false;\n this.reset();\n};\nKeyboardHandler.prototype.isEnabled = function isEnabled() {\n return this._enabled;\n};\nKeyboardHandler.prototype.isActive = function isActive() {\n return this._active;\n};\nKeyboardHandler.prototype.disableRotation = function disableRotation() {\n this._rotationDisabled = true;\n};\nKeyboardHandler.prototype.enableRotation = function enableRotation() {\n this._rotationDisabled = false;\n};\nfunction easeOut(t) {\n return t * (2 - t);\n}\n\nvar wheelZoomDelta = 4.000244140625;\nvar defaultZoomRate = 1 / 100;\nvar wheelZoomRate = 1 / 450;\nvar maxScalePerFrame = 2;\nvar ScrollZoomHandler = function ScrollZoomHandler(map, handler) {\n this._map = map;\n this._el = map.getCanvasContainer();\n this._handler = handler;\n this._delta = 0;\n this._defaultZoomRate = defaultZoomRate;\n this._wheelZoomRate = wheelZoomRate;\n performance.bindAll(['_onTimeout'], this);\n};\nScrollZoomHandler.prototype.setZoomRate = function setZoomRate(zoomRate) {\n this._defaultZoomRate = zoomRate;\n};\nScrollZoomHandler.prototype.setWheelZoomRate = function setWheelZoomRate(wheelZoomRate) {\n this._wheelZoomRate = wheelZoomRate;\n};\nScrollZoomHandler.prototype.isEnabled = function isEnabled() {\n return !!this._enabled;\n};\nScrollZoomHandler.prototype.isActive = function isActive() {\n return !!this._active || this._finishTimeout !== undefined;\n};\nScrollZoomHandler.prototype.isZooming = function isZooming() {\n return !!this._zooming;\n};\nScrollZoomHandler.prototype.enable = function enable(options) {\n if (this.isEnabled()) {\n return;\n }\n this._enabled = true;\n this._aroundCenter = options && options.around === 'center';\n};\nScrollZoomHandler.prototype.disable = function disable() {\n if (!this.isEnabled()) {\n return;\n }\n this._enabled = false;\n};\nScrollZoomHandler.prototype.wheel = function wheel(e) {\n if (!this.isEnabled()) {\n return;\n }\n var value = e.deltaMode === performance.window.WheelEvent.DOM_DELTA_LINE ? e.deltaY * 40 : e.deltaY;\n var now = performance.browser.now(), timeDelta = now - (this._lastWheelEventTime || 0);\n this._lastWheelEventTime = now;\n if (value !== 0 && value % wheelZoomDelta === 0) {\n this._type = 'wheel';\n } else if (value !== 0 && Math.abs(value) < 4) {\n this._type = 'trackpad';\n } else if (timeDelta > 400) {\n this._type = null;\n this._lastValue = value;\n this._timeout = setTimeout(this._onTimeout, 40, e);\n } else if (!this._type) {\n this._type = Math.abs(timeDelta * value) < 200 ? 'trackpad' : 'wheel';\n if (this._timeout) {\n clearTimeout(this._timeout);\n this._timeout = null;\n value += this._lastValue;\n }\n }\n if (e.shiftKey && value) {\n value = value / 4;\n }\n if (this._type) {\n this._lastWheelEvent = e;\n this._delta -= value;\n if (!this._active) {\n this._start(e);\n }\n }\n e.preventDefault();\n};\nScrollZoomHandler.prototype._onTimeout = function _onTimeout(initialEvent) {\n this._type = 'wheel';\n this._delta -= this._lastValue;\n if (!this._active) {\n this._start(initialEvent);\n }\n};\nScrollZoomHandler.prototype._start = function _start(e) {\n if (!this._delta) {\n return;\n }\n if (this._frameId) {\n this._frameId = null;\n }\n this._active = true;\n if (!this.isZooming()) {\n this._zooming = true;\n }\n if (this._finishTimeout) {\n clearTimeout(this._finishTimeout);\n delete this._finishTimeout;\n }\n var pos = DOM.mousePos(this._el, e);\n this._around = performance.LngLat.convert(this._aroundCenter ? this._map.getCenter() : this._map.unproject(pos));\n this._aroundPoint = this._map.transform.locationPoint(this._around);\n if (!this._frameId) {\n this._frameId = true;\n this._handler._triggerRenderFrame();\n }\n};\nScrollZoomHandler.prototype.renderFrame = function renderFrame() {\n var this$1 = this;\n if (!this._frameId) {\n return;\n }\n this._frameId = null;\n if (!this.isActive()) {\n return;\n }\n var tr = this._map.transform;\n if (this._delta !== 0) {\n var zoomRate = this._type === 'wheel' && Math.abs(this._delta) > wheelZoomDelta ? this._wheelZoomRate : this._defaultZoomRate;\n var scale = maxScalePerFrame / (1 + Math.exp(-Math.abs(this._delta * zoomRate)));\n if (this._delta < 0 && scale !== 0) {\n scale = 1 / scale;\n }\n var fromScale = typeof this._targetZoom === 'number' ? tr.zoomScale(this._targetZoom) : tr.scale;\n this._targetZoom = Math.min(tr.maxZoom, Math.max(tr.minZoom, tr.scaleZoom(fromScale * scale)));\n if (this._type === 'wheel') {\n this._startZoom = tr.zoom;\n this._easing = this._smoothOutEasing(200);\n }\n this._delta = 0;\n }\n var targetZoom = typeof this._targetZoom === 'number' ? this._targetZoom : tr.zoom;\n var startZoom = this._startZoom;\n var easing = this._easing;\n var finished = false;\n var zoom;\n if (this._type === 'wheel' && startZoom && easing) {\n var t = Math.min((performance.browser.now() - this._lastWheelEventTime) / 200, 1);\n var k = easing(t);\n zoom = performance.number(startZoom, targetZoom, k);\n if (t < 1) {\n if (!this._frameId) {\n this._frameId = true;\n }\n } else {\n finished = true;\n }\n } else {\n zoom = targetZoom;\n finished = true;\n }\n this._active = true;\n if (finished) {\n this._active = false;\n this._finishTimeout = setTimeout(function () {\n this$1._zooming = false;\n this$1._handler._triggerRenderFrame();\n delete this$1._targetZoom;\n delete this$1._finishTimeout;\n }, 200);\n }\n return {\n noInertia: true,\n needsRenderFrame: !finished,\n zoomDelta: zoom - tr.zoom,\n around: this._aroundPoint,\n originalEvent: this._lastWheelEvent\n };\n};\nScrollZoomHandler.prototype._smoothOutEasing = function _smoothOutEasing(duration) {\n var easing = performance.ease;\n if (this._prevEase) {\n var ease = this._prevEase, t = (performance.browser.now() - ease.start) / ease.duration, speed = ease.easing(t + 0.01) - ease.easing(t), x = 0.27 / Math.sqrt(speed * speed + 0.0001) * 0.01, y = Math.sqrt(0.27 * 0.27 - x * x);\n easing = performance.bezier(x, y, 0.25, 1);\n }\n this._prevEase = {\n start: performance.browser.now(),\n duration: duration,\n easing: easing\n };\n return easing;\n};\nScrollZoomHandler.prototype.reset = function reset() {\n this._active = false;\n};\n\nvar DoubleClickZoomHandler = function DoubleClickZoomHandler(clickZoom, TapZoom) {\n this._clickZoom = clickZoom;\n this._tapZoom = TapZoom;\n};\nDoubleClickZoomHandler.prototype.enable = function enable() {\n this._clickZoom.enable();\n this._tapZoom.enable();\n};\nDoubleClickZoomHandler.prototype.disable = function disable() {\n this._clickZoom.disable();\n this._tapZoom.disable();\n};\nDoubleClickZoomHandler.prototype.isEnabled = function isEnabled() {\n return this._clickZoom.isEnabled() && this._tapZoom.isEnabled();\n};\nDoubleClickZoomHandler.prototype.isActive = function isActive() {\n return this._clickZoom.isActive() || this._tapZoom.isActive();\n};\n\nvar ClickZoomHandler = function ClickZoomHandler() {\n this.reset();\n};\nClickZoomHandler.prototype.reset = function reset() {\n this._active = false;\n};\nClickZoomHandler.prototype.dblclick = function dblclick(e, point) {\n e.preventDefault();\n return {\n cameraAnimation: function (map) {\n map.easeTo({\n duration: 300,\n zoom: map.getZoom() + (e.shiftKey ? -1 : 1),\n around: map.unproject(point)\n }, { originalEvent: e });\n }\n };\n};\nClickZoomHandler.prototype.enable = function enable() {\n this._enabled = true;\n};\nClickZoomHandler.prototype.disable = function disable() {\n this._enabled = false;\n this.reset();\n};\nClickZoomHandler.prototype.isEnabled = function isEnabled() {\n return this._enabled;\n};\nClickZoomHandler.prototype.isActive = function isActive() {\n return this._active;\n};\n\nvar TapDragZoomHandler = function TapDragZoomHandler() {\n this._tap = new TapRecognizer({\n numTouches: 1,\n numTaps: 1\n });\n this.reset();\n};\nTapDragZoomHandler.prototype.reset = function reset() {\n this._active = false;\n delete this._swipePoint;\n delete this._swipeTouch;\n delete this._tapTime;\n this._tap.reset();\n};\nTapDragZoomHandler.prototype.touchstart = function touchstart(e, points, mapTouches) {\n if (this._swipePoint) {\n return;\n }\n if (this._tapTime && e.timeStamp - this._tapTime > MAX_TAP_INTERVAL) {\n this.reset();\n }\n if (!this._tapTime) {\n this._tap.touchstart(e, points, mapTouches);\n } else if (mapTouches.length > 0) {\n this._swipePoint = points[0];\n this._swipeTouch = mapTouches[0].identifier;\n }\n};\nTapDragZoomHandler.prototype.touchmove = function touchmove(e, points, mapTouches) {\n if (!this._tapTime) {\n this._tap.touchmove(e, points, mapTouches);\n } else if (this._swipePoint) {\n if (mapTouches[0].identifier !== this._swipeTouch) {\n return;\n }\n var newSwipePoint = points[0];\n var dist = newSwipePoint.y - this._swipePoint.y;\n this._swipePoint = newSwipePoint;\n e.preventDefault();\n this._active = true;\n return { zoomDelta: dist / 128 };\n }\n};\nTapDragZoomHandler.prototype.touchend = function touchend(e, points, mapTouches) {\n if (!this._tapTime) {\n var point = this._tap.touchend(e, points, mapTouches);\n if (point) {\n this._tapTime = e.timeStamp;\n }\n } else if (this._swipePoint) {\n if (mapTouches.length === 0) {\n this.reset();\n }\n }\n};\nTapDragZoomHandler.prototype.touchcancel = function touchcancel() {\n this.reset();\n};\nTapDragZoomHandler.prototype.enable = function enable() {\n this._enabled = true;\n};\nTapDragZoomHandler.prototype.disable = function disable() {\n this._enabled = false;\n this.reset();\n};\nTapDragZoomHandler.prototype.isEnabled = function isEnabled() {\n return this._enabled;\n};\nTapDragZoomHandler.prototype.isActive = function isActive() {\n return this._active;\n};\n\nvar DragPanHandler = function DragPanHandler(el, mousePan, touchPan) {\n this._el = el;\n this._mousePan = mousePan;\n this._touchPan = touchPan;\n};\nDragPanHandler.prototype.enable = function enable(options) {\n this._inertiaOptions = options || {};\n this._mousePan.enable();\n this._touchPan.enable();\n this._el.classList.add('mapboxgl-touch-drag-pan');\n};\nDragPanHandler.prototype.disable = function disable() {\n this._mousePan.disable();\n this._touchPan.disable();\n this._el.classList.remove('mapboxgl-touch-drag-pan');\n};\nDragPanHandler.prototype.isEnabled = function isEnabled() {\n return this._mousePan.isEnabled() && this._touchPan.isEnabled();\n};\nDragPanHandler.prototype.isActive = function isActive() {\n return this._mousePan.isActive() || this._touchPan.isActive();\n};\n\nvar DragRotateHandler = function DragRotateHandler(options, mouseRotate, mousePitch) {\n this._pitchWithRotate = options.pitchWithRotate;\n this._mouseRotate = mouseRotate;\n this._mousePitch = mousePitch;\n};\nDragRotateHandler.prototype.enable = function enable() {\n this._mouseRotate.enable();\n if (this._pitchWithRotate) {\n this._mousePitch.enable();\n }\n};\nDragRotateHandler.prototype.disable = function disable() {\n this._mouseRotate.disable();\n this._mousePitch.disable();\n};\nDragRotateHandler.prototype.isEnabled = function isEnabled() {\n return this._mouseRotate.isEnabled() && (!this._pitchWithRotate || this._mousePitch.isEnabled());\n};\nDragRotateHandler.prototype.isActive = function isActive() {\n return this._mouseRotate.isActive() || this._mousePitch.isActive();\n};\n\nvar TouchZoomRotateHandler = function TouchZoomRotateHandler(el, touchZoom, touchRotate, tapDragZoom) {\n this._el = el;\n this._touchZoom = touchZoom;\n this._touchRotate = touchRotate;\n this._tapDragZoom = tapDragZoom;\n this._rotationDisabled = false;\n this._enabled = true;\n};\nTouchZoomRotateHandler.prototype.enable = function enable(options) {\n this._touchZoom.enable(options);\n if (!this._rotationDisabled) {\n this._touchRotate.enable(options);\n }\n this._tapDragZoom.enable();\n this._el.classList.add('mapboxgl-touch-zoom-rotate');\n};\nTouchZoomRotateHandler.prototype.disable = function disable() {\n this._touchZoom.disable();\n this._touchRotate.disable();\n this._tapDragZoom.disable();\n this._el.classList.remove('mapboxgl-touch-zoom-rotate');\n};\nTouchZoomRotateHandler.prototype.isEnabled = function isEnabled() {\n return this._touchZoom.isEnabled() && (this._rotationDisabled || this._touchRotate.isEnabled()) && this._tapDragZoom.isEnabled();\n};\nTouchZoomRotateHandler.prototype.isActive = function isActive() {\n return this._touchZoom.isActive() || this._touchRotate.isActive() || this._tapDragZoom.isActive();\n};\nTouchZoomRotateHandler.prototype.disableRotation = function disableRotation() {\n this._rotationDisabled = true;\n this._touchRotate.disable();\n};\nTouchZoomRotateHandler.prototype.enableRotation = function enableRotation() {\n this._rotationDisabled = false;\n if (this._touchZoom.isEnabled()) {\n this._touchRotate.enable();\n }\n};\n\nvar isMoving = function (p) {\n return p.zoom || p.drag || p.pitch || p.rotate;\n};\nvar RenderFrameEvent = function (Event) {\n function RenderFrameEvent() {\n Event.apply(this, arguments);\n }\n if (Event)\n RenderFrameEvent.__proto__ = Event;\n RenderFrameEvent.prototype = Object.create(Event && Event.prototype);\n RenderFrameEvent.prototype.constructor = RenderFrameEvent;\n return RenderFrameEvent;\n}(performance.Event);\nfunction hasChange(result) {\n return result.panDelta && result.panDelta.mag() || result.zoomDelta || result.bearingDelta || result.pitchDelta;\n}\nvar HandlerManager = function HandlerManager(map, options) {\n this._map = map;\n this._el = this._map.getCanvasContainer();\n this._handlers = [];\n this._handlersById = {};\n this._changes = [];\n this._inertia = new HandlerInertia(map);\n this._bearingSnap = options.bearingSnap;\n this._previousActiveHandlers = {};\n this._eventsInProgress = {};\n this._addDefaultHandlers(options);\n performance.bindAll([\n 'handleEvent',\n 'handleWindowEvent'\n ], this);\n var el = this._el;\n this._listeners = [\n [\n el,\n 'touchstart',\n { passive: true }\n ],\n [\n el,\n 'touchmove',\n { passive: false }\n ],\n [\n el,\n 'touchend',\n undefined\n ],\n [\n el,\n 'touchcancel',\n undefined\n ],\n [\n el,\n 'mousedown',\n undefined\n ],\n [\n el,\n 'mousemove',\n undefined\n ],\n [\n el,\n 'mouseup',\n undefined\n ],\n [\n performance.window.document,\n 'mousemove',\n { capture: true }\n ],\n [\n performance.window.document,\n 'mouseup',\n undefined\n ],\n [\n el,\n 'mouseover',\n undefined\n ],\n [\n el,\n 'mouseout',\n undefined\n ],\n [\n el,\n 'dblclick',\n undefined\n ],\n [\n el,\n 'click',\n undefined\n ],\n [\n el,\n 'keydown',\n { capture: false }\n ],\n [\n el,\n 'keyup',\n undefined\n ],\n [\n el,\n 'wheel',\n { passive: false }\n ],\n [\n el,\n 'contextmenu',\n undefined\n ],\n [\n performance.window,\n 'blur',\n undefined\n ]\n ];\n for (var i = 0, list = this._listeners; i < list.length; i += 1) {\n var ref = list[i];\n var target = ref[0];\n var type = ref[1];\n var listenerOptions = ref[2];\n DOM.addEventListener(target, type, target === performance.window.document ? this.handleWindowEvent : this.handleEvent, listenerOptions);\n }\n};\nHandlerManager.prototype.destroy = function destroy() {\n for (var i = 0, list = this._listeners; i < list.length; i += 1) {\n var ref = list[i];\n var target = ref[0];\n var type = ref[1];\n var listenerOptions = ref[2];\n DOM.removeEventListener(target, type, target === performance.window.document ? this.handleWindowEvent : this.handleEvent, listenerOptions);\n }\n};\nHandlerManager.prototype._addDefaultHandlers = function _addDefaultHandlers(options) {\n var map = this._map;\n var el = map.getCanvasContainer();\n this._add('mapEvent', new MapEventHandler(map, options));\n var boxZoom = map.boxZoom = new BoxZoomHandler(map, options);\n this._add('boxZoom', boxZoom);\n var tapZoom = new TapZoomHandler();\n var clickZoom = new ClickZoomHandler();\n map.doubleClickZoom = new DoubleClickZoomHandler(clickZoom, tapZoom);\n this._add('tapZoom', tapZoom);\n this._add('clickZoom', clickZoom);\n var tapDragZoom = new TapDragZoomHandler();\n this._add('tapDragZoom', tapDragZoom);\n var touchPitch = map.touchPitch = new TouchPitchHandler();\n this._add('touchPitch', touchPitch);\n var mouseRotate = new MouseRotateHandler(options);\n var mousePitch = new MousePitchHandler(options);\n map.dragRotate = new DragRotateHandler(options, mouseRotate, mousePitch);\n this._add('mouseRotate', mouseRotate, ['mousePitch']);\n this._add('mousePitch', mousePitch, ['mouseRotate']);\n var mousePan = new MousePanHandler(options);\n var touchPan = new TouchPanHandler(options);\n map.dragPan = new DragPanHandler(el, mousePan, touchPan);\n this._add('mousePan', mousePan);\n this._add('touchPan', touchPan, [\n 'touchZoom',\n 'touchRotate'\n ]);\n var touchRotate = new TouchRotateHandler();\n var touchZoom = new TouchZoomHandler();\n map.touchZoomRotate = new TouchZoomRotateHandler(el, touchZoom, touchRotate, tapDragZoom);\n this._add('touchRotate', touchRotate, [\n 'touchPan',\n 'touchZoom'\n ]);\n this._add('touchZoom', touchZoom, [\n 'touchPan',\n 'touchRotate'\n ]);\n var scrollZoom = map.scrollZoom = new ScrollZoomHandler(map, this);\n this._add('scrollZoom', scrollZoom, ['mousePan']);\n var keyboard = map.keyboard = new KeyboardHandler();\n this._add('keyboard', keyboard);\n this._add('blockableMapEvent', new BlockableMapEventHandler(map));\n for (var i = 0, list = [\n 'boxZoom',\n 'doubleClickZoom',\n 'tapDragZoom',\n 'touchPitch',\n 'dragRotate',\n 'dragPan',\n 'touchZoomRotate',\n 'scrollZoom',\n 'keyboard'\n ]; i < list.length; i += 1) {\n var name = list[i];\n if (options.interactive && options[name]) {\n map[name].enable(options[name]);\n }\n }\n};\nHandlerManager.prototype._add = function _add(handlerName, handler, allowed) {\n this._handlers.push({\n handlerName: handlerName,\n handler: handler,\n allowed: allowed\n });\n this._handlersById[handlerName] = handler;\n};\nHandlerManager.prototype.stop = function stop(allowEndAnimation) {\n if (this._updatingCamera) {\n return;\n }\n for (var i = 0, list = this._handlers; i < list.length; i += 1) {\n var ref = list[i];\n var handler = ref.handler;\n handler.reset();\n }\n this._inertia.clear();\n this._fireEvents({}, {}, allowEndAnimation);\n this._changes = [];\n};\nHandlerManager.prototype.isActive = function isActive() {\n for (var i = 0, list = this._handlers; i < list.length; i += 1) {\n var ref = list[i];\n var handler = ref.handler;\n if (handler.isActive()) {\n return true;\n }\n }\n return false;\n};\nHandlerManager.prototype.isZooming = function isZooming() {\n return !!this._eventsInProgress.zoom || this._map.scrollZoom.isZooming();\n};\nHandlerManager.prototype.isRotating = function isRotating() {\n return !!this._eventsInProgress.rotate;\n};\nHandlerManager.prototype.isMoving = function isMoving$1() {\n return Boolean(isMoving(this._eventsInProgress)) || this.isZooming();\n};\nHandlerManager.prototype._blockedByActive = function _blockedByActive(activeHandlers, allowed, myName) {\n for (var name in activeHandlers) {\n if (name === myName) {\n continue;\n }\n if (!allowed || allowed.indexOf(name) < 0) {\n return true;\n }\n }\n return false;\n};\nHandlerManager.prototype.handleWindowEvent = function handleWindowEvent(e) {\n this.handleEvent(e, e.type + 'Window');\n};\nHandlerManager.prototype._getMapTouches = function _getMapTouches(touches) {\n var mapTouches = [];\n for (var i = 0, list = touches; i < list.length; i += 1) {\n var t = list[i];\n var target = t.target;\n if (this._el.contains(target)) {\n mapTouches.push(t);\n }\n }\n return mapTouches;\n};\nHandlerManager.prototype.handleEvent = function handleEvent(e, eventName) {\n if (e.type === 'blur') {\n this.stop(true);\n return;\n }\n this._updatingCamera = true;\n var inputEvent = e.type === 'renderFrame' ? undefined : e;\n var mergedHandlerResult = { needsRenderFrame: false };\n var eventsInProgress = {};\n var activeHandlers = {};\n var mapTouches = e.touches ? this._getMapTouches(e.touches) : undefined;\n var points = mapTouches ? DOM.touchPos(this._el, mapTouches) : DOM.mousePos(this._el, e);\n for (var i = 0, list = this._handlers; i < list.length; i += 1) {\n var ref = list[i];\n var handlerName = ref.handlerName;\n var handler = ref.handler;\n var allowed = ref.allowed;\n if (!handler.isEnabled()) {\n continue;\n }\n var data = void 0;\n if (this._blockedByActive(activeHandlers, allowed, handlerName)) {\n handler.reset();\n } else {\n if (handler[eventName || e.type]) {\n data = handler[eventName || e.type](e, points, mapTouches);\n this.mergeHandlerResult(mergedHandlerResult, eventsInProgress, data, handlerName, inputEvent);\n if (data && data.needsRenderFrame) {\n this._triggerRenderFrame();\n }\n }\n }\n if (data || handler.isActive()) {\n activeHandlers[handlerName] = handler;\n }\n }\n var deactivatedHandlers = {};\n for (var name in this._previousActiveHandlers) {\n if (!activeHandlers[name]) {\n deactivatedHandlers[name] = inputEvent;\n }\n }\n this._previousActiveHandlers = activeHandlers;\n if (Object.keys(deactivatedHandlers).length || hasChange(mergedHandlerResult)) {\n this._changes.push([\n mergedHandlerResult,\n eventsInProgress,\n deactivatedHandlers\n ]);\n this._triggerRenderFrame();\n }\n if (Object.keys(activeHandlers).length || hasChange(mergedHandlerResult)) {\n this._map._stop(true);\n }\n this._updatingCamera = false;\n var cameraAnimation = mergedHandlerResult.cameraAnimation;\n if (cameraAnimation) {\n this._inertia.clear();\n this._fireEvents({}, {}, true);\n this._changes = [];\n cameraAnimation(this._map);\n }\n};\nHandlerManager.prototype.mergeHandlerResult = function mergeHandlerResult(mergedHandlerResult, eventsInProgress, handlerResult, name, e) {\n if (!handlerResult) {\n return;\n }\n performance.extend(mergedHandlerResult, handlerResult);\n var eventData = {\n handlerName: name,\n originalEvent: handlerResult.originalEvent || e\n };\n if (handlerResult.zoomDelta !== undefined) {\n eventsInProgress.zoom = eventData;\n }\n if (handlerResult.panDelta !== undefined) {\n eventsInProgress.drag = eventData;\n }\n if (handlerResult.pitchDelta !== undefined) {\n eventsInProgress.pitch = eventData;\n }\n if (handlerResult.bearingDelta !== undefined) {\n eventsInProgress.rotate = eventData;\n }\n};\nHandlerManager.prototype._applyChanges = function _applyChanges() {\n var combined = {};\n var combinedEventsInProgress = {};\n var combinedDeactivatedHandlers = {};\n for (var i = 0, list = this._changes; i < list.length; i += 1) {\n var ref = list[i];\n var change = ref[0];\n var eventsInProgress = ref[1];\n var deactivatedHandlers = ref[2];\n if (change.panDelta) {\n combined.panDelta = (combined.panDelta || new performance.Point(0, 0))._add(change.panDelta);\n }\n if (change.zoomDelta) {\n combined.zoomDelta = (combined.zoomDelta || 0) + change.zoomDelta;\n }\n if (change.bearingDelta) {\n combined.bearingDelta = (combined.bearingDelta || 0) + change.bearingDelta;\n }\n if (change.pitchDelta) {\n combined.pitchDelta = (combined.pitchDelta || 0) + change.pitchDelta;\n }\n if (change.around !== undefined) {\n combined.around = change.around;\n }\n if (change.pinchAround !== undefined) {\n combined.pinchAround = change.pinchAround;\n }\n if (change.noInertia) {\n combined.noInertia = change.noInertia;\n }\n performance.extend(combinedEventsInProgress, eventsInProgress);\n performance.extend(combinedDeactivatedHandlers, deactivatedHandlers);\n }\n this._updateMapTransform(combined, combinedEventsInProgress, combinedDeactivatedHandlers);\n this._changes = [];\n};\nHandlerManager.prototype._updateMapTransform = function _updateMapTransform(combinedResult, combinedEventsInProgress, deactivatedHandlers) {\n var map = this._map;\n var tr = map.transform;\n if (!hasChange(combinedResult)) {\n return this._fireEvents(combinedEventsInProgress, deactivatedHandlers, true);\n }\n var panDelta = combinedResult.panDelta;\n var zoomDelta = combinedResult.zoomDelta;\n var bearingDelta = combinedResult.bearingDelta;\n var pitchDelta = combinedResult.pitchDelta;\n var around = combinedResult.around;\n var pinchAround = combinedResult.pinchAround;\n if (pinchAround !== undefined) {\n around = pinchAround;\n }\n map._stop(true);\n around = around || map.transform.centerPoint;\n var loc = tr.pointLocation(panDelta ? around.sub(panDelta) : around);\n if (bearingDelta) {\n tr.bearing += bearingDelta;\n }\n if (pitchDelta) {\n tr.pitch += pitchDelta;\n }\n if (zoomDelta) {\n tr.zoom += zoomDelta;\n }\n tr.setLocationAtPoint(loc, around);\n this._map._update();\n if (!combinedResult.noInertia) {\n this._inertia.record(combinedResult);\n }\n this._fireEvents(combinedEventsInProgress, deactivatedHandlers, true);\n};\nHandlerManager.prototype._fireEvents = function _fireEvents(newEventsInProgress, deactivatedHandlers, allowEndAnimation) {\n var this$1 = this;\n var wasMoving = isMoving(this._eventsInProgress);\n var nowMoving = isMoving(newEventsInProgress);\n var startEvents = {};\n for (var eventName in newEventsInProgress) {\n var ref = newEventsInProgress[eventName];\n var originalEvent = ref.originalEvent;\n if (!this._eventsInProgress[eventName]) {\n startEvents[eventName + 'start'] = originalEvent;\n }\n this._eventsInProgress[eventName] = newEventsInProgress[eventName];\n }\n if (!wasMoving && nowMoving) {\n this._fireEvent('movestart', nowMoving.originalEvent);\n }\n for (var name in startEvents) {\n this._fireEvent(name, startEvents[name]);\n }\n if (nowMoving) {\n this._fireEvent('move', nowMoving.originalEvent);\n }\n for (var eventName$1 in newEventsInProgress) {\n var ref$1 = newEventsInProgress[eventName$1];\n var originalEvent$1 = ref$1.originalEvent;\n this._fireEvent(eventName$1, originalEvent$1);\n }\n var endEvents = {};\n var originalEndEvent;\n for (var eventName$2 in this._eventsInProgress) {\n var ref$2 = this._eventsInProgress[eventName$2];\n var handlerName = ref$2.handlerName;\n var originalEvent$2 = ref$2.originalEvent;\n if (!this._handlersById[handlerName].isActive()) {\n delete this._eventsInProgress[eventName$2];\n originalEndEvent = deactivatedHandlers[handlerName] || originalEvent$2;\n endEvents[eventName$2 + 'end'] = originalEndEvent;\n }\n }\n for (var name$1 in endEvents) {\n this._fireEvent(name$1, endEvents[name$1]);\n }\n var stillMoving = isMoving(this._eventsInProgress);\n if (allowEndAnimation && (wasMoving || nowMoving) && !stillMoving) {\n this._updatingCamera = true;\n var inertialEase = this._inertia._onMoveEnd(this._map.dragPan._inertiaOptions);\n var shouldSnapToNorth = function (bearing) {\n return bearing !== 0 && -this$1._bearingSnap < bearing && bearing < this$1._bearingSnap;\n };\n if (inertialEase) {\n if (shouldSnapToNorth(inertialEase.bearing || this._map.getBearing())) {\n inertialEase.bearing = 0;\n }\n this._map.easeTo(inertialEase, { originalEvent: originalEndEvent });\n } else {\n this._map.fire(new performance.Event('moveend', { originalEvent: originalEndEvent }));\n if (shouldSnapToNorth(this._map.getBearing())) {\n this._map.resetNorth();\n }\n }\n this._updatingCamera = false;\n }\n};\nHandlerManager.prototype._fireEvent = function _fireEvent(type, e) {\n this._map.fire(new performance.Event(type, e ? { originalEvent: e } : {}));\n};\nHandlerManager.prototype._requestFrame = function _requestFrame() {\n var this$1 = this;\n this._map.triggerRepaint();\n return this._map._renderTaskQueue.add(function (timeStamp) {\n delete this$1._frameId;\n this$1.handleEvent(new RenderFrameEvent('renderFrame', { timeStamp: timeStamp }));\n this$1._applyChanges();\n });\n};\nHandlerManager.prototype._triggerRenderFrame = function _triggerRenderFrame() {\n if (this._frameId === undefined) {\n this._frameId = this._requestFrame();\n }\n};\n\nvar Camera = function (Evented) {\n function Camera(transform, options) {\n Evented.call(this);\n this._moving = false;\n this._zooming = false;\n this.transform = transform;\n this._bearingSnap = options.bearingSnap;\n performance.bindAll(['_renderFrameCallback'], this);\n }\n if (Evented)\n Camera.__proto__ = Evented;\n Camera.prototype = Object.create(Evented && Evented.prototype);\n Camera.prototype.constructor = Camera;\n Camera.prototype.getCenter = function getCenter() {\n return new performance.LngLat(this.transform.center.lng, this.transform.center.lat);\n };\n Camera.prototype.setCenter = function setCenter(center, eventData) {\n return this.jumpTo({ center: center }, eventData);\n };\n Camera.prototype.panBy = function panBy(offset, options, eventData) {\n offset = performance.Point.convert(offset).mult(-1);\n return this.panTo(this.transform.center, performance.extend({ offset: offset }, options), eventData);\n };\n Camera.prototype.panTo = function panTo(lnglat, options, eventData) {\n return this.easeTo(performance.extend({ center: lnglat }, options), eventData);\n };\n Camera.prototype.getZoom = function getZoom() {\n return this.transform.zoom;\n };\n Camera.prototype.setZoom = function setZoom(zoom, eventData) {\n this.jumpTo({ zoom: zoom }, eventData);\n return this;\n };\n Camera.prototype.zoomTo = function zoomTo(zoom, options, eventData) {\n return this.easeTo(performance.extend({ zoom: zoom }, options), eventData);\n };\n Camera.prototype.zoomIn = function zoomIn(options, eventData) {\n this.zoomTo(this.getZoom() + 1, options, eventData);\n return this;\n };\n Camera.prototype.zoomOut = function zoomOut(options, eventData) {\n this.zoomTo(this.getZoom() - 1, options, eventData);\n return this;\n };\n Camera.prototype.getBearing = function getBearing() {\n return this.transform.bearing;\n };\n Camera.prototype.setBearing = function setBearing(bearing, eventData) {\n this.jumpTo({ bearing: bearing }, eventData);\n return this;\n };\n Camera.prototype.getPadding = function getPadding() {\n return this.transform.padding;\n };\n Camera.prototype.setPadding = function setPadding(padding, eventData) {\n this.jumpTo({ padding: padding }, eventData);\n return this;\n };\n Camera.prototype.rotateTo = function rotateTo(bearing, options, eventData) {\n return this.easeTo(performance.extend({ bearing: bearing }, options), eventData);\n };\n Camera.prototype.resetNorth = function resetNorth(options, eventData) {\n this.rotateTo(0, performance.extend({ duration: 1000 }, options), eventData);\n return this;\n };\n Camera.prototype.resetNorthPitch = function resetNorthPitch(options, eventData) {\n this.easeTo(performance.extend({\n bearing: 0,\n pitch: 0,\n duration: 1000\n }, options), eventData);\n return this;\n };\n Camera.prototype.snapToNorth = function snapToNorth(options, eventData) {\n if (Math.abs(this.getBearing()) < this._bearingSnap) {\n return this.resetNorth(options, eventData);\n }\n return this;\n };\n Camera.prototype.getPitch = function getPitch() {\n return this.transform.pitch;\n };\n Camera.prototype.setPitch = function setPitch(pitch, eventData) {\n this.jumpTo({ pitch: pitch }, eventData);\n return this;\n };\n Camera.prototype.cameraForBounds = function cameraForBounds(bounds, options) {\n bounds = performance.LngLatBounds.convert(bounds);\n var bearing = options && options.bearing || 0;\n return this._cameraForBoxAndBearing(bounds.getNorthWest(), bounds.getSouthEast(), bearing, options);\n };\n Camera.prototype._cameraForBoxAndBearing = function _cameraForBoxAndBearing(p0, p1, bearing, options) {\n var defaultPadding = {\n top: 0,\n bottom: 0,\n right: 0,\n left: 0\n };\n options = performance.extend({\n padding: defaultPadding,\n offset: [\n 0,\n 0\n ],\n maxZoom: this.transform.maxZoom\n }, options);\n if (typeof options.padding === 'number') {\n var p = options.padding;\n options.padding = {\n top: p,\n bottom: p,\n right: p,\n left: p\n };\n }\n options.padding = performance.extend(defaultPadding, options.padding);\n var tr = this.transform;\n var edgePadding = tr.padding;\n var p0world = tr.project(performance.LngLat.convert(p0));\n var p1world = tr.project(performance.LngLat.convert(p1));\n var p0rotated = p0world.rotate(-bearing * Math.PI / 180);\n var p1rotated = p1world.rotate(-bearing * Math.PI / 180);\n var upperRight = new performance.Point(Math.max(p0rotated.x, p1rotated.x), Math.max(p0rotated.y, p1rotated.y));\n var lowerLeft = new performance.Point(Math.min(p0rotated.x, p1rotated.x), Math.min(p0rotated.y, p1rotated.y));\n var size = upperRight.sub(lowerLeft);\n var scaleX = (tr.width - (edgePadding.left + edgePadding.right + options.padding.left + options.padding.right)) / size.x;\n var scaleY = (tr.height - (edgePadding.top + edgePadding.bottom + options.padding.top + options.padding.bottom)) / size.y;\n if (scaleY < 0 || scaleX < 0) {\n performance.warnOnce('Map cannot fit within canvas with the given bounds, padding, and/or offset.');\n return;\n }\n var zoom = Math.min(tr.scaleZoom(tr.scale * Math.min(scaleX, scaleY)), options.maxZoom);\n var offset = typeof options.offset.x === 'number' ? new performance.Point(options.offset.x, options.offset.y) : performance.Point.convert(options.offset);\n var paddingOffsetX = (options.padding.left - options.padding.right) / 2;\n var paddingOffsetY = (options.padding.top - options.padding.bottom) / 2;\n var paddingOffset = new performance.Point(paddingOffsetX, paddingOffsetY);\n var rotatedPaddingOffset = paddingOffset.rotate(bearing * Math.PI / 180);\n var offsetAtInitialZoom = offset.add(rotatedPaddingOffset);\n var offsetAtFinalZoom = offsetAtInitialZoom.mult(tr.scale / tr.zoomScale(zoom));\n var center = tr.unproject(p0world.add(p1world).div(2).sub(offsetAtFinalZoom));\n return {\n center: center,\n zoom: zoom,\n bearing: bearing\n };\n };\n Camera.prototype.fitBounds = function fitBounds(bounds, options, eventData) {\n return this._fitInternal(this.cameraForBounds(bounds, options), options, eventData);\n };\n Camera.prototype.fitScreenCoordinates = function fitScreenCoordinates(p0, p1, bearing, options, eventData) {\n return this._fitInternal(this._cameraForBoxAndBearing(this.transform.pointLocation(performance.Point.convert(p0)), this.transform.pointLocation(performance.Point.convert(p1)), bearing, options), options, eventData);\n };\n Camera.prototype._fitInternal = function _fitInternal(calculatedOptions, options, eventData) {\n if (!calculatedOptions) {\n return this;\n }\n options = performance.extend(calculatedOptions, options);\n delete options.padding;\n return options.linear ? this.easeTo(options, eventData) : this.flyTo(options, eventData);\n };\n Camera.prototype.jumpTo = function jumpTo(options, eventData) {\n this.stop();\n var tr = this.transform;\n var zoomChanged = false, bearingChanged = false, pitchChanged = false;\n if ('zoom' in options && tr.zoom !== +options.zoom) {\n zoomChanged = true;\n tr.zoom = +options.zoom;\n }\n if (options.center !== undefined) {\n tr.center = performance.LngLat.convert(options.center);\n }\n if ('bearing' in options && tr.bearing !== +options.bearing) {\n bearingChanged = true;\n tr.bearing = +options.bearing;\n }\n if ('pitch' in options && tr.pitch !== +options.pitch) {\n pitchChanged = true;\n tr.pitch = +options.pitch;\n }\n if (options.padding != null && !tr.isPaddingEqual(options.padding)) {\n tr.padding = options.padding;\n }\n this.fire(new performance.Event('movestart', eventData)).fire(new performance.Event('move', eventData));\n if (zoomChanged) {\n this.fire(new performance.Event('zoomstart', eventData)).fire(new performance.Event('zoom', eventData)).fire(new performance.Event('zoomend', eventData));\n }\n if (bearingChanged) {\n this.fire(new performance.Event('rotatestart', eventData)).fire(new performance.Event('rotate', eventData)).fire(new performance.Event('rotateend', eventData));\n }\n if (pitchChanged) {\n this.fire(new performance.Event('pitchstart', eventData)).fire(new performance.Event('pitch', eventData)).fire(new performance.Event('pitchend', eventData));\n }\n return this.fire(new performance.Event('moveend', eventData));\n };\n Camera.prototype.easeTo = function easeTo(options, eventData) {\n var this$1 = this;\n this._stop(false, options.easeId);\n options = performance.extend({\n offset: [\n 0,\n 0\n ],\n duration: 500,\n easing: performance.ease\n }, options);\n if (options.animate === false || !options.essential && performance.browser.prefersReducedMotion) {\n options.duration = 0;\n }\n var tr = this.transform, startZoom = this.getZoom(), startBearing = this.getBearing(), startPitch = this.getPitch(), startPadding = this.getPadding(), zoom = 'zoom' in options ? +options.zoom : startZoom, bearing = 'bearing' in options ? this._normalizeBearing(options.bearing, startBearing) : startBearing, pitch = 'pitch' in options ? +options.pitch : startPitch, padding = 'padding' in options ? options.padding : tr.padding;\n var offsetAsPoint = performance.Point.convert(options.offset);\n var pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n var locationAtOffset = tr.pointLocation(pointAtOffset);\n var center = performance.LngLat.convert(options.center || locationAtOffset);\n this._normalizeCenter(center);\n var from = tr.project(locationAtOffset);\n var delta = tr.project(center).sub(from);\n var finalScale = tr.zoomScale(zoom - startZoom);\n var around, aroundPoint;\n if (options.around) {\n around = performance.LngLat.convert(options.around);\n aroundPoint = tr.locationPoint(around);\n }\n var currently = {\n moving: this._moving,\n zooming: this._zooming,\n rotating: this._rotating,\n pitching: this._pitching\n };\n this._zooming = this._zooming || zoom !== startZoom;\n this._rotating = this._rotating || startBearing !== bearing;\n this._pitching = this._pitching || pitch !== startPitch;\n this._padding = !tr.isPaddingEqual(padding);\n this._easeId = options.easeId;\n this._prepareEase(eventData, options.noMoveStart, currently);\n this._ease(function (k) {\n if (this$1._zooming) {\n tr.zoom = performance.number(startZoom, zoom, k);\n }\n if (this$1._rotating) {\n tr.bearing = performance.number(startBearing, bearing, k);\n }\n if (this$1._pitching) {\n tr.pitch = performance.number(startPitch, pitch, k);\n }\n if (this$1._padding) {\n tr.interpolatePadding(startPadding, padding, k);\n pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n }\n if (around) {\n tr.setLocationAtPoint(around, aroundPoint);\n } else {\n var scale = tr.zoomScale(tr.zoom - startZoom);\n var base = zoom > startZoom ? Math.min(2, finalScale) : Math.max(0.5, finalScale);\n var speedup = Math.pow(base, 1 - k);\n var newCenter = tr.unproject(from.add(delta.mult(k * speedup)).mult(scale));\n tr.setLocationAtPoint(tr.renderWorldCopies ? newCenter.wrap() : newCenter, pointAtOffset);\n }\n this$1._fireMoveEvents(eventData);\n }, function (interruptingEaseId) {\n this$1._afterEase(eventData, interruptingEaseId);\n }, options);\n return this;\n };\n Camera.prototype._prepareEase = function _prepareEase(eventData, noMoveStart, currently) {\n if (currently === void 0)\n currently = {};\n this._moving = true;\n if (!noMoveStart && !currently.moving) {\n this.fire(new performance.Event('movestart', eventData));\n }\n if (this._zooming && !currently.zooming) {\n this.fire(new performance.Event('zoomstart', eventData));\n }\n if (this._rotating && !currently.rotating) {\n this.fire(new performance.Event('rotatestart', eventData));\n }\n if (this._pitching && !currently.pitching) {\n this.fire(new performance.Event('pitchstart', eventData));\n }\n };\n Camera.prototype._fireMoveEvents = function _fireMoveEvents(eventData) {\n this.fire(new performance.Event('move', eventData));\n if (this._zooming) {\n this.fire(new performance.Event('zoom', eventData));\n }\n if (this._rotating) {\n this.fire(new performance.Event('rotate', eventData));\n }\n if (this._pitching) {\n this.fire(new performance.Event('pitch', eventData));\n }\n };\n Camera.prototype._afterEase = function _afterEase(eventData, easeId) {\n if (this._easeId && easeId && this._easeId === easeId) {\n return;\n }\n delete this._easeId;\n var wasZooming = this._zooming;\n var wasRotating = this._rotating;\n var wasPitching = this._pitching;\n this._moving = false;\n this._zooming = false;\n this._rotating = false;\n this._pitching = false;\n this._padding = false;\n if (wasZooming) {\n this.fire(new performance.Event('zoomend', eventData));\n }\n if (wasRotating) {\n this.fire(new performance.Event('rotateend', eventData));\n }\n if (wasPitching) {\n this.fire(new performance.Event('pitchend', eventData));\n }\n this.fire(new performance.Event('moveend', eventData));\n };\n Camera.prototype.flyTo = function flyTo(options, eventData) {\n var this$1 = this;\n if (!options.essential && performance.browser.prefersReducedMotion) {\n var coercedOptions = performance.pick(options, [\n 'center',\n 'zoom',\n 'bearing',\n 'pitch',\n 'around'\n ]);\n return this.jumpTo(coercedOptions, eventData);\n }\n this.stop();\n options = performance.extend({\n offset: [\n 0,\n 0\n ],\n speed: 1.2,\n curve: 1.42,\n easing: performance.ease\n }, options);\n var tr = this.transform, startZoom = this.getZoom(), startBearing = this.getBearing(), startPitch = this.getPitch(), startPadding = this.getPadding();\n var zoom = 'zoom' in options ? performance.clamp(+options.zoom, tr.minZoom, tr.maxZoom) : startZoom;\n var bearing = 'bearing' in options ? this._normalizeBearing(options.bearing, startBearing) : startBearing;\n var pitch = 'pitch' in options ? +options.pitch : startPitch;\n var padding = 'padding' in options ? options.padding : tr.padding;\n var scale = tr.zoomScale(zoom - startZoom);\n var offsetAsPoint = performance.Point.convert(options.offset);\n var pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n var locationAtOffset = tr.pointLocation(pointAtOffset);\n var center = performance.LngLat.convert(options.center || locationAtOffset);\n this._normalizeCenter(center);\n var from = tr.project(locationAtOffset);\n var delta = tr.project(center).sub(from);\n var rho = options.curve;\n var w0 = Math.max(tr.width, tr.height), w1 = w0 / scale, u1 = delta.mag();\n if ('minZoom' in options) {\n var minZoom = performance.clamp(Math.min(options.minZoom, startZoom, zoom), tr.minZoom, tr.maxZoom);\n var wMax = w0 / tr.zoomScale(minZoom - startZoom);\n rho = Math.sqrt(wMax / u1 * 2);\n }\n var rho2 = rho * rho;\n function r(i) {\n var b = (w1 * w1 - w0 * w0 + (i ? -1 : 1) * rho2 * rho2 * u1 * u1) / (2 * (i ? w1 : w0) * rho2 * u1);\n return Math.log(Math.sqrt(b * b + 1) - b);\n }\n function sinh(n) {\n return (Math.exp(n) - Math.exp(-n)) / 2;\n }\n function cosh(n) {\n return (Math.exp(n) + Math.exp(-n)) / 2;\n }\n function tanh(n) {\n return sinh(n) / cosh(n);\n }\n var r0 = r(0);\n var w = function (s) {\n return cosh(r0) / cosh(r0 + rho * s);\n };\n var u = function (s) {\n return w0 * ((cosh(r0) * tanh(r0 + rho * s) - sinh(r0)) / rho2) / u1;\n };\n var S = (r(1) - r0) / rho;\n if (Math.abs(u1) < 0.000001 || !isFinite(S)) {\n if (Math.abs(w0 - w1) < 0.000001) {\n return this.easeTo(options, eventData);\n }\n var k = w1 < w0 ? -1 : 1;\n S = Math.abs(Math.log(w1 / w0)) / rho;\n u = function () {\n return 0;\n };\n w = function (s) {\n return Math.exp(k * rho * s);\n };\n }\n if ('duration' in options) {\n options.duration = +options.duration;\n } else {\n var V = 'screenSpeed' in options ? +options.screenSpeed / rho : +options.speed;\n options.duration = 1000 * S / V;\n }\n if (options.maxDuration && options.duration > options.maxDuration) {\n options.duration = 0;\n }\n this._zooming = true;\n this._rotating = startBearing !== bearing;\n this._pitching = pitch !== startPitch;\n this._padding = !tr.isPaddingEqual(padding);\n this._prepareEase(eventData, false);\n this._ease(function (k) {\n var s = k * S;\n var scale = 1 / w(s);\n tr.zoom = k === 1 ? zoom : startZoom + tr.scaleZoom(scale);\n if (this$1._rotating) {\n tr.bearing = performance.number(startBearing, bearing, k);\n }\n if (this$1._pitching) {\n tr.pitch = performance.number(startPitch, pitch, k);\n }\n if (this$1._padding) {\n tr.interpolatePadding(startPadding, padding, k);\n pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n }\n var newCenter = k === 1 ? center : tr.unproject(from.add(delta.mult(u(s))).mult(scale));\n tr.setLocationAtPoint(tr.renderWorldCopies ? newCenter.wrap() : newCenter, pointAtOffset);\n this$1._fireMoveEvents(eventData);\n }, function () {\n return this$1._afterEase(eventData);\n }, options);\n return this;\n };\n Camera.prototype.isEasing = function isEasing() {\n return !!this._easeFrameId;\n };\n Camera.prototype.stop = function stop() {\n return this._stop();\n };\n Camera.prototype._stop = function _stop(allowGestures, easeId) {\n if (this._easeFrameId) {\n this._cancelRenderFrame(this._easeFrameId);\n delete this._easeFrameId;\n delete this._onEaseFrame;\n }\n if (this._onEaseEnd) {\n var onEaseEnd = this._onEaseEnd;\n delete this._onEaseEnd;\n onEaseEnd.call(this, easeId);\n }\n if (!allowGestures) {\n var handlers = this.handlers;\n if (handlers) {\n handlers.stop(false);\n }\n }\n return this;\n };\n Camera.prototype._ease = function _ease(frame, finish, options) {\n if (options.animate === false || options.duration === 0) {\n frame(1);\n finish();\n } else {\n this._easeStart = performance.browser.now();\n this._easeOptions = options;\n this._onEaseFrame = frame;\n this._onEaseEnd = finish;\n this._easeFrameId = this._requestRenderFrame(this._renderFrameCallback);\n }\n };\n Camera.prototype._renderFrameCallback = function _renderFrameCallback() {\n var t = Math.min((performance.browser.now() - this._easeStart) / this._easeOptions.duration, 1);\n this._onEaseFrame(this._easeOptions.easing(t));\n if (t < 1) {\n this._easeFrameId = this._requestRenderFrame(this._renderFrameCallback);\n } else {\n this.stop();\n }\n };\n Camera.prototype._normalizeBearing = function _normalizeBearing(bearing, currentBearing) {\n bearing = performance.wrap(bearing, -180, 180);\n var diff = Math.abs(bearing - currentBearing);\n if (Math.abs(bearing - 360 - currentBearing) < diff) {\n bearing -= 360;\n }\n if (Math.abs(bearing + 360 - currentBearing) < diff) {\n bearing += 360;\n }\n return bearing;\n };\n Camera.prototype._normalizeCenter = function _normalizeCenter(center) {\n var tr = this.transform;\n if (!tr.renderWorldCopies || tr.lngRange) {\n return;\n }\n var delta = center.lng - tr.center.lng;\n center.lng += delta > 180 ? -360 : delta < -180 ? 360 : 0;\n };\n return Camera;\n}(performance.Evented);\n\nvar AttributionControl = function AttributionControl(options) {\n if (options === void 0)\n options = {};\n this.options = options;\n performance.bindAll([\n '_toggleAttribution',\n '_updateEditLink',\n '_updateData',\n '_updateCompact'\n ], this);\n};\nAttributionControl.prototype.getDefaultPosition = function getDefaultPosition() {\n return 'bottom-right';\n};\nAttributionControl.prototype.onAdd = function onAdd(map) {\n var compact = this.options && this.options.compact;\n this._map = map;\n this._container = DOM.create('div', 'mapboxgl-ctrl mapboxgl-ctrl-attrib');\n this._compactButton = DOM.create('button', 'mapboxgl-ctrl-attrib-button', this._container);\n this._compactButton.addEventListener('click', this._toggleAttribution);\n this._setElementTitle(this._compactButton, 'ToggleAttribution');\n this._innerContainer = DOM.create('div', 'mapboxgl-ctrl-attrib-inner', this._container);\n this._innerContainer.setAttribute('role', 'list');\n if (compact) {\n this._container.classList.add('mapboxgl-compact');\n }\n this._updateAttributions();\n this._updateEditLink();\n this._map.on('styledata', this._updateData);\n this._map.on('sourcedata', this._updateData);\n this._map.on('moveend', this._updateEditLink);\n if (compact === undefined) {\n this._map.on('resize', this._updateCompact);\n this._updateCompact();\n }\n return this._container;\n};\nAttributionControl.prototype.onRemove = function onRemove() {\n DOM.remove(this._container);\n this._map.off('styledata', this._updateData);\n this._map.off('sourcedata', this._updateData);\n this._map.off('moveend', this._updateEditLink);\n this._map.off('resize', this._updateCompact);\n this._map = undefined;\n this._attribHTML = undefined;\n};\nAttributionControl.prototype._setElementTitle = function _setElementTitle(element, title) {\n var str = this._map._getUIString('AttributionControl.' + title);\n element.title = str;\n element.setAttribute('aria-label', str);\n};\nAttributionControl.prototype._toggleAttribution = function _toggleAttribution() {\n if (this._container.classList.contains('mapboxgl-compact-show')) {\n this._container.classList.remove('mapboxgl-compact-show');\n this._compactButton.setAttribute('aria-pressed', 'false');\n } else {\n this._container.classList.add('mapboxgl-compact-show');\n this._compactButton.setAttribute('aria-pressed', 'true');\n }\n};\nAttributionControl.prototype._updateEditLink = function _updateEditLink() {\n var editLink = this._editLink;\n if (!editLink) {\n editLink = this._editLink = this._container.querySelector('.mapbox-improve-map');\n }\n var params = [\n {\n key: 'owner',\n value: this.styleOwner\n },\n {\n key: 'id',\n value: this.styleId\n },\n {\n key: 'access_token',\n value: this._map._requestManager._customAccessToken || performance.config.ACCESS_TOKEN\n }\n ];\n if (editLink) {\n var paramString = params.reduce(function (acc, next, i) {\n if (next.value) {\n acc += next.key + '=' + next.value + (i < params.length - 1 ? '&' : '');\n }\n return acc;\n }, '?');\n editLink.href = performance.config.FEEDBACK_URL + '/' + paramString + (this._map._hash ? this._map._hash.getHashString(true) : '');\n editLink.rel = 'noopener nofollow';\n this._setElementTitle(editLink, 'MapFeedback');\n }\n};\nAttributionControl.prototype._updateData = function _updateData(e) {\n if (e && (e.sourceDataType === 'metadata' || e.sourceDataType === 'visibility' || e.dataType === 'style')) {\n this._updateAttributions();\n this._updateEditLink();\n }\n};\nAttributionControl.prototype._updateAttributions = function _updateAttributions() {\n if (!this._map.style) {\n return;\n }\n var attributions = [];\n if (this.options.customAttribution) {\n if (Array.isArray(this.options.customAttribution)) {\n attributions = attributions.concat(this.options.customAttribution.map(function (attribution) {\n if (typeof attribution !== 'string') {\n return '';\n }\n return attribution;\n }));\n } else if (typeof this.options.customAttribution === 'string') {\n attributions.push(this.options.customAttribution);\n }\n }\n if (this._map.style.stylesheet) {\n var stylesheet = this._map.style.stylesheet;\n this.styleOwner = stylesheet.owner;\n this.styleId = stylesheet.id;\n }\n var sourceCaches = this._map.style.sourceCaches;\n for (var id in sourceCaches) {\n var sourceCache = sourceCaches[id];\n if (sourceCache.used) {\n var source = sourceCache.getSource();\n if (source.attribution && attributions.indexOf(source.attribution) < 0) {\n attributions.push(source.attribution);\n }\n }\n }\n attributions.sort(function (a, b) {\n return a.length - b.length;\n });\n attributions = attributions.filter(function (attrib, i) {\n for (var j = i + 1; j < attributions.length; j++) {\n if (attributions[j].indexOf(attrib) >= 0) {\n return false;\n }\n }\n return true;\n });\n var attribHTML = attributions.join(' | ');\n if (attribHTML === this._attribHTML) {\n return;\n }\n this._attribHTML = attribHTML;\n if (attributions.length) {\n this._innerContainer.innerHTML = attribHTML;\n this._container.classList.remove('mapboxgl-attrib-empty');\n } else {\n this._container.classList.add('mapboxgl-attrib-empty');\n }\n this._editLink = null;\n};\nAttributionControl.prototype._updateCompact = function _updateCompact() {\n if (this._map.getCanvasContainer().offsetWidth <= 640) {\n this._container.classList.add('mapboxgl-compact');\n } else {\n this._container.classList.remove('mapboxgl-compact', 'mapboxgl-compact-show');\n }\n};\n\nvar LogoControl = function LogoControl() {\n performance.bindAll(['_updateLogo'], this);\n performance.bindAll(['_updateCompact'], this);\n};\nLogoControl.prototype.onAdd = function onAdd(map) {\n this._map = map;\n this._container = DOM.create('div', 'mapboxgl-ctrl');\n var anchor = DOM.create('a', 'mapboxgl-ctrl-logo');\n anchor.target = '_blank';\n anchor.rel = 'noopener nofollow';\n anchor.href = 'https://www.mapbox.com/';\n anchor.setAttribute('aria-label', this._map._getUIString('LogoControl.Title'));\n anchor.setAttribute('rel', 'noopener nofollow');\n this._container.appendChild(anchor);\n this._container.style.display = 'none';\n this._map.on('sourcedata', this._updateLogo);\n this._updateLogo();\n this._map.on('resize', this._updateCompact);\n this._updateCompact();\n return this._container;\n};\nLogoControl.prototype.onRemove = function onRemove() {\n DOM.remove(this._container);\n this._map.off('sourcedata', this._updateLogo);\n this._map.off('resize', this._updateCompact);\n};\nLogoControl.prototype.getDefaultPosition = function getDefaultPosition() {\n return 'bottom-left';\n};\nLogoControl.prototype._updateLogo = function _updateLogo(e) {\n if (!e || e.sourceDataType === 'metadata') {\n this._container.style.display = this._logoRequired() ? 'block' : 'none';\n }\n};\nLogoControl.prototype._logoRequired = function _logoRequired() {\n if (!this._map.style) {\n return;\n }\n var sourceCaches = this._map.style.sourceCaches;\n for (var id in sourceCaches) {\n var source = sourceCaches[id].getSource();\n if (source.mapbox_logo) {\n return true;\n }\n }\n return false;\n};\nLogoControl.prototype._updateCompact = function _updateCompact() {\n var containerChildren = this._container.children;\n if (containerChildren.length) {\n var anchor = containerChildren[0];\n if (this._map.getCanvasContainer().offsetWidth < 250) {\n anchor.classList.add('mapboxgl-compact');\n } else {\n anchor.classList.remove('mapboxgl-compact');\n }\n }\n};\n\nvar TaskQueue = function TaskQueue() {\n this._queue = [];\n this._id = 0;\n this._cleared = false;\n this._currentlyRunning = false;\n};\nTaskQueue.prototype.add = function add(callback) {\n var id = ++this._id;\n var queue = this._queue;\n queue.push({\n callback: callback,\n id: id,\n cancelled: false\n });\n return id;\n};\nTaskQueue.prototype.remove = function remove(id) {\n var running = this._currentlyRunning;\n var queue = running ? this._queue.concat(running) : this._queue;\n for (var i = 0, list = queue; i < list.length; i += 1) {\n var task = list[i];\n if (task.id === id) {\n task.cancelled = true;\n return;\n }\n }\n};\nTaskQueue.prototype.run = function run(timeStamp) {\n if (timeStamp === void 0)\n timeStamp = 0;\n var queue = this._currentlyRunning = this._queue;\n this._queue = [];\n for (var i = 0, list = queue; i < list.length; i += 1) {\n var task = list[i];\n if (task.cancelled) {\n continue;\n }\n task.callback(timeStamp);\n if (this._cleared) {\n break;\n }\n }\n this._cleared = false;\n this._currentlyRunning = false;\n};\nTaskQueue.prototype.clear = function clear() {\n if (this._currentlyRunning) {\n this._cleared = true;\n }\n this._queue = [];\n};\n\nvar defaultLocale = {\n 'AttributionControl.ToggleAttribution': 'Toggle attribution',\n 'AttributionControl.MapFeedback': 'Map feedback',\n 'FullscreenControl.Enter': 'Enter fullscreen',\n 'FullscreenControl.Exit': 'Exit fullscreen',\n 'GeolocateControl.FindMyLocation': 'Find my location',\n 'GeolocateControl.LocationNotAvailable': 'Location not available',\n 'LogoControl.Title': 'Mapbox logo',\n 'NavigationControl.ResetBearing': 'Reset bearing to north',\n 'NavigationControl.ZoomIn': 'Zoom in',\n 'NavigationControl.ZoomOut': 'Zoom out',\n 'ScaleControl.Feet': 'ft',\n 'ScaleControl.Meters': 'm',\n 'ScaleControl.Kilometers': 'km',\n 'ScaleControl.Miles': 'mi',\n 'ScaleControl.NauticalMiles': 'nm'\n};\n\nvar HTMLImageElement = performance.window.HTMLImageElement;\nvar HTMLElement = performance.window.HTMLElement;\nvar ImageBitmap = performance.window.ImageBitmap;\nvar defaultMinZoom = -2;\nvar defaultMaxZoom = 22;\nvar defaultMinPitch = 0;\nvar defaultMaxPitch = 60;\nvar defaultOptions$1 = {\n center: [\n 0,\n 0\n ],\n zoom: 0,\n bearing: 0,\n pitch: 0,\n minZoom: defaultMinZoom,\n maxZoom: defaultMaxZoom,\n minPitch: defaultMinPitch,\n maxPitch: defaultMaxPitch,\n interactive: true,\n scrollZoom: true,\n boxZoom: true,\n dragRotate: true,\n dragPan: true,\n keyboard: true,\n doubleClickZoom: true,\n touchZoomRotate: true,\n touchPitch: true,\n bearingSnap: 7,\n clickTolerance: 3,\n pitchWithRotate: true,\n hash: false,\n attributionControl: true,\n failIfMajorPerformanceCaveat: false,\n preserveDrawingBuffer: false,\n trackResize: true,\n renderWorldCopies: true,\n refreshExpiredTiles: true,\n maxTileCacheSize: null,\n localIdeographFontFamily: 'sans-serif',\n transformRequest: null,\n accessToken: null,\n fadeDuration: 300,\n crossSourceCollisions: true\n};\nvar Map = function (Camera) {\n function Map(options) {\n var this$1 = this;\n options = performance.extend({}, defaultOptions$1, options);\n if (options.minZoom != null && options.maxZoom != null && options.minZoom > options.maxZoom) {\n throw new Error('maxZoom must be greater than or equal to minZoom');\n }\n if (options.minPitch != null && options.maxPitch != null && options.minPitch > options.maxPitch) {\n throw new Error('maxPitch must be greater than or equal to minPitch');\n }\n if (options.minPitch != null && options.minPitch < defaultMinPitch) {\n throw new Error('minPitch must be greater than or equal to ' + defaultMinPitch);\n }\n if (options.maxPitch != null && options.maxPitch > defaultMaxPitch) {\n throw new Error('maxPitch must be less than or equal to ' + defaultMaxPitch);\n }\n var transform = new Transform(options.minZoom, options.maxZoom, options.minPitch, options.maxPitch, options.renderWorldCopies);\n Camera.call(this, transform, options);\n this._interactive = options.interactive;\n this._maxTileCacheSize = options.maxTileCacheSize;\n this._failIfMajorPerformanceCaveat = options.failIfMajorPerformanceCaveat;\n this._preserveDrawingBuffer = options.preserveDrawingBuffer;\n this._antialias = options.antialias;\n this._trackResize = options.trackResize;\n this._bearingSnap = options.bearingSnap;\n this._refreshExpiredTiles = options.refreshExpiredTiles;\n this._fadeDuration = options.fadeDuration;\n this._crossSourceCollisions = options.crossSourceCollisions;\n this._crossFadingFactor = 1;\n this._collectResourceTiming = options.collectResourceTiming;\n this._renderTaskQueue = new TaskQueue();\n this._controls = [];\n this._mapId = performance.uniqueId();\n this._locale = performance.extend({}, defaultLocale, options.locale);\n this._clickTolerance = options.clickTolerance;\n this._requestManager = new performance.RequestManager(options.transformRequest, options.accessToken);\n if (typeof options.container === 'string') {\n this._container = performance.window.document.getElementById(options.container);\n if (!this._container) {\n throw new Error('Container \\'' + options.container + '\\' not found.');\n }\n } else if (options.container instanceof HTMLElement) {\n this._container = options.container;\n } else {\n throw new Error('Invalid type: \\'container\\' must be a String or HTMLElement.');\n }\n if (options.maxBounds) {\n this.setMaxBounds(options.maxBounds);\n }\n performance.bindAll([\n '_onWindowOnline',\n '_onWindowResize',\n '_onMapScroll',\n '_contextLost',\n '_contextRestored'\n ], this);\n this._setupContainer();\n this._setupPainter();\n if (this.painter === undefined) {\n throw new Error('Failed to initialize WebGL.');\n }\n this.on('move', function () {\n return this$1._update(false);\n });\n this.on('moveend', function () {\n return this$1._update(false);\n });\n this.on('zoom', function () {\n return this$1._update(true);\n });\n if (typeof performance.window !== 'undefined') {\n performance.window.addEventListener('online', this._onWindowOnline, false);\n performance.window.addEventListener('resize', this._onWindowResize, false);\n performance.window.addEventListener('orientationchange', this._onWindowResize, false);\n }\n this.handlers = new HandlerManager(this, options);\n var hashName = typeof options.hash === 'string' && options.hash || undefined;\n this._hash = options.hash && new Hash(hashName).addTo(this);\n if (!this._hash || !this._hash._onHashChange()) {\n this.jumpTo({\n center: options.center,\n zoom: options.zoom,\n bearing: options.bearing,\n pitch: options.pitch\n });\n if (options.bounds) {\n this.resize();\n this.fitBounds(options.bounds, performance.extend({}, options.fitBoundsOptions, { duration: 0 }));\n }\n }\n this.resize();\n this._localIdeographFontFamily = options.localIdeographFontFamily;\n if (options.style) {\n this.setStyle(options.style, { localIdeographFontFamily: options.localIdeographFontFamily });\n }\n if (options.attributionControl) {\n this.addControl(new AttributionControl({ customAttribution: options.customAttribution }));\n }\n this.addControl(new LogoControl(), options.logoPosition);\n this.on('style.load', function () {\n if (this$1.transform.unmodified) {\n this$1.jumpTo(this$1.style.stylesheet);\n }\n });\n this.on('data', function (event) {\n this$1._update(event.dataType === 'style');\n this$1.fire(new performance.Event(event.dataType + 'data', event));\n });\n this.on('dataloading', function (event) {\n this$1.fire(new performance.Event(event.dataType + 'dataloading', event));\n });\n }\n if (Camera)\n Map.__proto__ = Camera;\n Map.prototype = Object.create(Camera && Camera.prototype);\n Map.prototype.constructor = Map;\n var prototypeAccessors = {\n showTileBoundaries: { configurable: true },\n showPadding: { configurable: true },\n showCollisionBoxes: { configurable: true },\n showOverdrawInspector: { configurable: true },\n repaint: { configurable: true },\n vertices: { configurable: true },\n version: { configurable: true }\n };\n Map.prototype._getMapId = function _getMapId() {\n return this._mapId;\n };\n Map.prototype.addControl = function addControl(control, position) {\n if (position === undefined) {\n if (control.getDefaultPosition) {\n position = control.getDefaultPosition();\n } else {\n position = 'top-right';\n }\n }\n if (!control || !control.onAdd) {\n return this.fire(new performance.ErrorEvent(new Error('Invalid argument to map.addControl(). Argument must be a control with onAdd and onRemove methods.')));\n }\n var controlElement = control.onAdd(this);\n this._controls.push(control);\n var positionContainer = this._controlPositions[position];\n if (position.indexOf('bottom') !== -1) {\n positionContainer.insertBefore(controlElement, positionContainer.firstChild);\n } else {\n positionContainer.appendChild(controlElement);\n }\n return this;\n };\n Map.prototype.removeControl = function removeControl(control) {\n if (!control || !control.onRemove) {\n return this.fire(new performance.ErrorEvent(new Error('Invalid argument to map.removeControl(). Argument must be a control with onAdd and onRemove methods.')));\n }\n var ci = this._controls.indexOf(control);\n if (ci > -1) {\n this._controls.splice(ci, 1);\n }\n control.onRemove(this);\n return this;\n };\n Map.prototype.hasControl = function hasControl(control) {\n return this._controls.indexOf(control) > -1;\n };\n Map.prototype.resize = function resize(eventData) {\n var dimensions = this._containerDimensions();\n var width = dimensions[0];\n var height = dimensions[1];\n this._resizeCanvas(width, height);\n this.transform.resize(width, height);\n this.painter.resize(width, height);\n var fireMoving = !this._moving;\n if (fireMoving) {\n this.stop();\n this.fire(new performance.Event('movestart', eventData)).fire(new performance.Event('move', eventData));\n }\n this.fire(new performance.Event('resize', eventData));\n if (fireMoving) {\n this.fire(new performance.Event('moveend', eventData));\n }\n return this;\n };\n Map.prototype.getBounds = function getBounds() {\n return this.transform.getBounds();\n };\n Map.prototype.getMaxBounds = function getMaxBounds() {\n return this.transform.getMaxBounds();\n };\n Map.prototype.setMaxBounds = function setMaxBounds(bounds) {\n this.transform.setMaxBounds(performance.LngLatBounds.convert(bounds));\n return this._update();\n };\n Map.prototype.setMinZoom = function setMinZoom(minZoom) {\n minZoom = minZoom === null || minZoom === undefined ? defaultMinZoom : minZoom;\n if (minZoom >= defaultMinZoom && minZoom <= this.transform.maxZoom) {\n this.transform.minZoom = minZoom;\n this._update();\n if (this.getZoom() < minZoom) {\n this.setZoom(minZoom);\n }\n return this;\n } else {\n throw new Error('minZoom must be between ' + defaultMinZoom + ' and the current maxZoom, inclusive');\n }\n };\n Map.prototype.getMinZoom = function getMinZoom() {\n return this.transform.minZoom;\n };\n Map.prototype.setMaxZoom = function setMaxZoom(maxZoom) {\n maxZoom = maxZoom === null || maxZoom === undefined ? defaultMaxZoom : maxZoom;\n if (maxZoom >= this.transform.minZoom) {\n this.transform.maxZoom = maxZoom;\n this._update();\n if (this.getZoom() > maxZoom) {\n this.setZoom(maxZoom);\n }\n return this;\n } else {\n throw new Error('maxZoom must be greater than the current minZoom');\n }\n };\n Map.prototype.getMaxZoom = function getMaxZoom() {\n return this.transform.maxZoom;\n };\n Map.prototype.setMinPitch = function setMinPitch(minPitch) {\n minPitch = minPitch === null || minPitch === undefined ? defaultMinPitch : minPitch;\n if (minPitch < defaultMinPitch) {\n throw new Error('minPitch must be greater than or equal to ' + defaultMinPitch);\n }\n if (minPitch >= defaultMinPitch && minPitch <= this.transform.maxPitch) {\n this.transform.minPitch = minPitch;\n this._update();\n if (this.getPitch() < minPitch) {\n this.setPitch(minPitch);\n }\n return this;\n } else {\n throw new Error('minPitch must be between ' + defaultMinPitch + ' and the current maxPitch, inclusive');\n }\n };\n Map.prototype.getMinPitch = function getMinPitch() {\n return this.transform.minPitch;\n };\n Map.prototype.setMaxPitch = function setMaxPitch(maxPitch) {\n maxPitch = maxPitch === null || maxPitch === undefined ? defaultMaxPitch : maxPitch;\n if (maxPitch > defaultMaxPitch) {\n throw new Error('maxPitch must be less than or equal to ' + defaultMaxPitch);\n }\n if (maxPitch >= this.transform.minPitch) {\n this.transform.maxPitch = maxPitch;\n this._update();\n if (this.getPitch() > maxPitch) {\n this.setPitch(maxPitch);\n }\n return this;\n } else {\n throw new Error('maxPitch must be greater than the current minPitch');\n }\n };\n Map.prototype.getMaxPitch = function getMaxPitch() {\n return this.transform.maxPitch;\n };\n Map.prototype.getRenderWorldCopies = function getRenderWorldCopies() {\n return this.transform.renderWorldCopies;\n };\n Map.prototype.setRenderWorldCopies = function setRenderWorldCopies(renderWorldCopies) {\n this.transform.renderWorldCopies = renderWorldCopies;\n return this._update();\n };\n Map.prototype.project = function project(lnglat) {\n return this.transform.locationPoint(performance.LngLat.convert(lnglat));\n };\n Map.prototype.unproject = function unproject(point) {\n return this.transform.pointLocation(performance.Point.convert(point));\n };\n Map.prototype.isMoving = function isMoving() {\n return this._moving || this.handlers.isMoving();\n };\n Map.prototype.isZooming = function isZooming() {\n return this._zooming || this.handlers.isZooming();\n };\n Map.prototype.isRotating = function isRotating() {\n return this._rotating || this.handlers.isRotating();\n };\n Map.prototype._createDelegatedListener = function _createDelegatedListener(type, layerId, listener) {\n var this$1 = this;\n var obj;\n if (type === 'mouseenter' || type === 'mouseover') {\n var mousein = false;\n var mousemove = function (e) {\n var features = this$1.getLayer(layerId) ? this$1.queryRenderedFeatures(e.point, { layers: [layerId] }) : [];\n if (!features.length) {\n mousein = false;\n } else if (!mousein) {\n mousein = true;\n listener.call(this$1, new MapMouseEvent(type, this$1, e.originalEvent, { features: features }));\n }\n };\n var mouseout = function () {\n mousein = false;\n };\n return {\n layer: layerId,\n listener: listener,\n delegates: {\n mousemove: mousemove,\n mouseout: mouseout\n }\n };\n } else if (type === 'mouseleave' || type === 'mouseout') {\n var mousein$1 = false;\n var mousemove$1 = function (e) {\n var features = this$1.getLayer(layerId) ? this$1.queryRenderedFeatures(e.point, { layers: [layerId] }) : [];\n if (features.length) {\n mousein$1 = true;\n } else if (mousein$1) {\n mousein$1 = false;\n listener.call(this$1, new MapMouseEvent(type, this$1, e.originalEvent));\n }\n };\n var mouseout$1 = function (e) {\n if (mousein$1) {\n mousein$1 = false;\n listener.call(this$1, new MapMouseEvent(type, this$1, e.originalEvent));\n }\n };\n return {\n layer: layerId,\n listener: listener,\n delegates: {\n mousemove: mousemove$1,\n mouseout: mouseout$1\n }\n };\n } else {\n var delegate = function (e) {\n var features = this$1.getLayer(layerId) ? this$1.queryRenderedFeatures(e.point, { layers: [layerId] }) : [];\n if (features.length) {\n e.features = features;\n listener.call(this$1, e);\n delete e.features;\n }\n };\n return {\n layer: layerId,\n listener: listener,\n delegates: (obj = {}, obj[type] = delegate, obj)\n };\n }\n };\n Map.prototype.on = function on(type, layerId, listener) {\n if (listener === undefined) {\n return Camera.prototype.on.call(this, type, layerId);\n }\n var delegatedListener = this._createDelegatedListener(type, layerId, listener);\n this._delegatedListeners = this._delegatedListeners || {};\n this._delegatedListeners[type] = this._delegatedListeners[type] || [];\n this._delegatedListeners[type].push(delegatedListener);\n for (var event in delegatedListener.delegates) {\n this.on(event, delegatedListener.delegates[event]);\n }\n return this;\n };\n Map.prototype.once = function once(type, layerId, listener) {\n if (listener === undefined) {\n return Camera.prototype.once.call(this, type, layerId);\n }\n var delegatedListener = this._createDelegatedListener(type, layerId, listener);\n for (var event in delegatedListener.delegates) {\n this.once(event, delegatedListener.delegates[event]);\n }\n return this;\n };\n Map.prototype.off = function off(type, layerId, listener) {\n var this$1 = this;\n if (listener === undefined) {\n return Camera.prototype.off.call(this, type, layerId);\n }\n var removeDelegatedListener = function (delegatedListeners) {\n var listeners = delegatedListeners[type];\n for (var i = 0; i < listeners.length; i++) {\n var delegatedListener = listeners[i];\n if (delegatedListener.layer === layerId && delegatedListener.listener === listener) {\n for (var event in delegatedListener.delegates) {\n this$1.off(event, delegatedListener.delegates[event]);\n }\n listeners.splice(i, 1);\n return this$1;\n }\n }\n };\n if (this._delegatedListeners && this._delegatedListeners[type]) {\n removeDelegatedListener(this._delegatedListeners);\n }\n return this;\n };\n Map.prototype.queryRenderedFeatures = function queryRenderedFeatures(geometry, options) {\n if (!this.style) {\n return [];\n }\n if (options === undefined && geometry !== undefined && !(geometry instanceof performance.Point) && !Array.isArray(geometry)) {\n options = geometry;\n geometry = undefined;\n }\n options = options || {};\n geometry = geometry || [\n [\n 0,\n 0\n ],\n [\n this.transform.width,\n this.transform.height\n ]\n ];\n var queryGeometry;\n if (geometry instanceof performance.Point || typeof geometry[0] === 'number') {\n queryGeometry = [performance.Point.convert(geometry)];\n } else {\n var tl = performance.Point.convert(geometry[0]);\n var br = performance.Point.convert(geometry[1]);\n queryGeometry = [\n tl,\n new performance.Point(br.x, tl.y),\n br,\n new performance.Point(tl.x, br.y),\n tl\n ];\n }\n return this.style.queryRenderedFeatures(queryGeometry, options, this.transform);\n };\n Map.prototype.querySourceFeatures = function querySourceFeatures(sourceId, parameters) {\n return this.style.querySourceFeatures(sourceId, parameters);\n };\n Map.prototype.setStyle = function setStyle(style, options) {\n options = performance.extend({}, { localIdeographFontFamily: this._localIdeographFontFamily }, options);\n if (options.diff !== false && options.localIdeographFontFamily === this._localIdeographFontFamily && this.style && style) {\n this._diffStyle(style, options);\n return this;\n } else {\n this._localIdeographFontFamily = options.localIdeographFontFamily;\n return this._updateStyle(style, options);\n }\n };\n Map.prototype._getUIString = function _getUIString(key) {\n var str = this._locale[key];\n if (str == null) {\n throw new Error('Missing UI string \\'' + key + '\\'');\n }\n return str;\n };\n Map.prototype._updateStyle = function _updateStyle(style, options) {\n if (this.style) {\n this.style.setEventedParent(null);\n this.style._remove();\n }\n if (!style) {\n delete this.style;\n return this;\n } else {\n this.style = new Style(this, options || {});\n }\n this.style.setEventedParent(this, { style: this.style });\n if (typeof style === 'string') {\n this.style.loadURL(style);\n } else {\n this.style.loadJSON(style);\n }\n return this;\n };\n Map.prototype._lazyInitEmptyStyle = function _lazyInitEmptyStyle() {\n if (!this.style) {\n this.style = new Style(this, {});\n this.style.setEventedParent(this, { style: this.style });\n this.style.loadEmpty();\n }\n };\n Map.prototype._diffStyle = function _diffStyle(style, options) {\n var this$1 = this;\n if (typeof style === 'string') {\n var url = this._requestManager.normalizeStyleURL(style);\n var request = this._requestManager.transformRequest(url, performance.ResourceType.Style);\n performance.getJSON(request, function (error, json) {\n if (error) {\n this$1.fire(new performance.ErrorEvent(error));\n } else if (json) {\n this$1._updateDiff(json, options);\n }\n });\n } else if (typeof style === 'object') {\n this._updateDiff(style, options);\n }\n };\n Map.prototype._updateDiff = function _updateDiff(style, options) {\n try {\n if (this.style.setState(style)) {\n this._update(true);\n }\n } catch (e) {\n performance.warnOnce('Unable to perform style diff: ' + (e.message || e.error || e) + '. Rebuilding the style from scratch.');\n this._updateStyle(style, options);\n }\n };\n Map.prototype.getStyle = function getStyle() {\n if (this.style) {\n return this.style.serialize();\n }\n };\n Map.prototype.isStyleLoaded = function isStyleLoaded() {\n if (!this.style) {\n return performance.warnOnce('There is no style added to the map.');\n }\n return this.style.loaded();\n };\n Map.prototype.addSource = function addSource(id, source) {\n this._lazyInitEmptyStyle();\n this.style.addSource(id, source);\n return this._update(true);\n };\n Map.prototype.isSourceLoaded = function isSourceLoaded(id) {\n var source = this.style && this.style.sourceCaches[id];\n if (source === undefined) {\n this.fire(new performance.ErrorEvent(new Error('There is no source with ID \\'' + id + '\\'')));\n return;\n }\n return source.loaded();\n };\n Map.prototype.areTilesLoaded = function areTilesLoaded() {\n var sources = this.style && this.style.sourceCaches;\n for (var id in sources) {\n var source = sources[id];\n var tiles = source._tiles;\n for (var t in tiles) {\n var tile = tiles[t];\n if (!(tile.state === 'loaded' || tile.state === 'errored')) {\n return false;\n }\n }\n }\n return true;\n };\n Map.prototype.addSourceType = function addSourceType(name, SourceType, callback) {\n this._lazyInitEmptyStyle();\n return this.style.addSourceType(name, SourceType, callback);\n };\n Map.prototype.removeSource = function removeSource(id) {\n this.style.removeSource(id);\n return this._update(true);\n };\n Map.prototype.getSource = function getSource(id) {\n return this.style.getSource(id);\n };\n Map.prototype.addImage = function addImage(id, image, ref) {\n if (ref === void 0)\n ref = {};\n var pixelRatio = ref.pixelRatio;\n if (pixelRatio === void 0)\n pixelRatio = 1;\n var sdf = ref.sdf;\n if (sdf === void 0)\n sdf = false;\n var stretchX = ref.stretchX;\n var stretchY = ref.stretchY;\n var content = ref.content;\n this._lazyInitEmptyStyle();\n var version = 0;\n if (image instanceof HTMLImageElement || ImageBitmap && image instanceof ImageBitmap) {\n var ref$1 = performance.browser.getImageData(image);\n var width = ref$1.width;\n var height = ref$1.height;\n var data = ref$1.data;\n this.style.addImage(id, {\n data: new performance.RGBAImage({\n width: width,\n height: height\n }, data),\n pixelRatio: pixelRatio,\n stretchX: stretchX,\n stretchY: stretchY,\n content: content,\n sdf: sdf,\n version: version\n });\n } else if (image.width === undefined || image.height === undefined) {\n return this.fire(new performance.ErrorEvent(new Error('Invalid arguments to map.addImage(). The second argument must be an `HTMLImageElement`, `ImageData`, `ImageBitmap`, ' + 'or object with `width`, `height`, and `data` properties with the same format as `ImageData`')));\n } else {\n var width$1 = image.width;\n var height$1 = image.height;\n var data$1 = image.data;\n var userImage = image;\n this.style.addImage(id, {\n data: new performance.RGBAImage({\n width: width$1,\n height: height$1\n }, new Uint8Array(data$1)),\n pixelRatio: pixelRatio,\n stretchX: stretchX,\n stretchY: stretchY,\n content: content,\n sdf: sdf,\n version: version,\n userImage: userImage\n });\n if (userImage.onAdd) {\n userImage.onAdd(this, id);\n }\n }\n };\n Map.prototype.updateImage = function updateImage(id, image) {\n var existingImage = this.style.getImage(id);\n if (!existingImage) {\n return this.fire(new performance.ErrorEvent(new Error('The map has no image with that id. If you are adding a new image use `map.addImage(...)` instead.')));\n }\n var imageData = image instanceof HTMLImageElement || ImageBitmap && image instanceof ImageBitmap ? performance.browser.getImageData(image) : image;\n var width = imageData.width;\n var height = imageData.height;\n var data = imageData.data;\n if (width === undefined || height === undefined) {\n return this.fire(new performance.ErrorEvent(new Error('Invalid arguments to map.updateImage(). The second argument must be an `HTMLImageElement`, `ImageData`, `ImageBitmap`, ' + 'or object with `width`, `height`, and `data` properties with the same format as `ImageData`')));\n }\n if (width !== existingImage.data.width || height !== existingImage.data.height) {\n return this.fire(new performance.ErrorEvent(new Error('The width and height of the updated image must be that same as the previous version of the image')));\n }\n var copy = !(image instanceof HTMLImageElement || ImageBitmap && image instanceof ImageBitmap);\n existingImage.data.replace(data, copy);\n this.style.updateImage(id, existingImage);\n };\n Map.prototype.hasImage = function hasImage(id) {\n if (!id) {\n this.fire(new performance.ErrorEvent(new Error('Missing required image id')));\n return false;\n }\n return !!this.style.getImage(id);\n };\n Map.prototype.removeImage = function removeImage(id) {\n this.style.removeImage(id);\n };\n Map.prototype.loadImage = function loadImage(url, callback) {\n performance.getImage(this._requestManager.transformRequest(url, performance.ResourceType.Image), callback);\n };\n Map.prototype.listImages = function listImages() {\n return this.style.listImages();\n };\n Map.prototype.addLayer = function addLayer(layer, beforeId) {\n this._lazyInitEmptyStyle();\n this.style.addLayer(layer, beforeId);\n return this._update(true);\n };\n Map.prototype.moveLayer = function moveLayer(id, beforeId) {\n this.style.moveLayer(id, beforeId);\n return this._update(true);\n };\n Map.prototype.removeLayer = function removeLayer(id) {\n this.style.removeLayer(id);\n return this._update(true);\n };\n Map.prototype.getLayer = function getLayer(id) {\n return this.style.getLayer(id);\n };\n Map.prototype.setLayerZoomRange = function setLayerZoomRange(layerId, minzoom, maxzoom) {\n this.style.setLayerZoomRange(layerId, minzoom, maxzoom);\n return this._update(true);\n };\n Map.prototype.setFilter = function setFilter(layerId, filter, options) {\n if (options === void 0)\n options = {};\n this.style.setFilter(layerId, filter, options);\n return this._update(true);\n };\n Map.prototype.getFilter = function getFilter(layerId) {\n return this.style.getFilter(layerId);\n };\n Map.prototype.setPaintProperty = function setPaintProperty(layerId, name, value, options) {\n if (options === void 0)\n options = {};\n this.style.setPaintProperty(layerId, name, value, options);\n return this._update(true);\n };\n Map.prototype.getPaintProperty = function getPaintProperty(layerId, name) {\n return this.style.getPaintProperty(layerId, name);\n };\n Map.prototype.setLayoutProperty = function setLayoutProperty(layerId, name, value, options) {\n if (options === void 0)\n options = {};\n this.style.setLayoutProperty(layerId, name, value, options);\n return this._update(true);\n };\n Map.prototype.getLayoutProperty = function getLayoutProperty(layerId, name) {\n return this.style.getLayoutProperty(layerId, name);\n };\n Map.prototype.setLight = function setLight(light, options) {\n if (options === void 0)\n options = {};\n this._lazyInitEmptyStyle();\n this.style.setLight(light, options);\n return this._update(true);\n };\n Map.prototype.getLight = function getLight() {\n return this.style.getLight();\n };\n Map.prototype.setFeatureState = function setFeatureState(feature, state) {\n this.style.setFeatureState(feature, state);\n return this._update();\n };\n Map.prototype.removeFeatureState = function removeFeatureState(target, key) {\n this.style.removeFeatureState(target, key);\n return this._update();\n };\n Map.prototype.getFeatureState = function getFeatureState(feature) {\n return this.style.getFeatureState(feature);\n };\n Map.prototype.getContainer = function getContainer() {\n return this._container;\n };\n Map.prototype.getCanvasContainer = function getCanvasContainer() {\n return this._canvasContainer;\n };\n Map.prototype.getCanvas = function getCanvas() {\n return this._canvas;\n };\n Map.prototype._containerDimensions = function _containerDimensions() {\n var width = 0;\n var height = 0;\n if (this._container) {\n width = this._container.clientWidth || 400;\n height = this._container.clientHeight || 300;\n }\n return [\n width,\n height\n ];\n };\n Map.prototype._detectMissingCSS = function _detectMissingCSS() {\n var computedColor = performance.window.getComputedStyle(this._missingCSSCanary).getPropertyValue('background-color');\n if (computedColor !== 'rgb(250, 128, 114)') {\n performance.warnOnce('This page appears to be missing CSS declarations for ' + 'Mapbox GL JS, which may cause the map to display incorrectly. ' + 'Please ensure your page includes mapbox-gl.css, as described ' + 'in https://www.mapbox.com/mapbox-gl-js/api/.');\n }\n };\n Map.prototype._setupContainer = function _setupContainer() {\n var container = this._container;\n container.classList.add('mapboxgl-map');\n var missingCSSCanary = this._missingCSSCanary = DOM.create('div', 'mapboxgl-canary', container);\n missingCSSCanary.style.visibility = 'hidden';\n this._detectMissingCSS();\n var canvasContainer = this._canvasContainer = DOM.create('div', 'mapboxgl-canvas-container', container);\n if (this._interactive) {\n canvasContainer.classList.add('mapboxgl-interactive');\n }\n this._canvas = DOM.create('canvas', 'mapboxgl-canvas', canvasContainer);\n this._canvas.addEventListener('webglcontextlost', this._contextLost, false);\n this._canvas.addEventListener('webglcontextrestored', this._contextRestored, false);\n this._canvas.setAttribute('tabindex', '0');\n this._canvas.setAttribute('aria-label', 'Map');\n this._canvas.setAttribute('role', 'region');\n var dimensions = this._containerDimensions();\n this._resizeCanvas(dimensions[0], dimensions[1]);\n var controlContainer = this._controlContainer = DOM.create('div', 'mapboxgl-control-container', container);\n var positions = this._controlPositions = {};\n [\n 'top-left',\n 'top-right',\n 'bottom-left',\n 'bottom-right'\n ].forEach(function (positionName) {\n positions[positionName] = DOM.create('div', 'mapboxgl-ctrl-' + positionName, controlContainer);\n });\n this._container.addEventListener('scroll', this._onMapScroll, false);\n };\n Map.prototype._resizeCanvas = function _resizeCanvas(width, height) {\n var pixelRatio = performance.browser.devicePixelRatio || 1;\n this._canvas.width = pixelRatio * width;\n this._canvas.height = pixelRatio * height;\n this._canvas.style.width = width + 'px';\n this._canvas.style.height = height + 'px';\n };\n Map.prototype._setupPainter = function _setupPainter() {\n var attributes = performance.extend({}, mapboxGlSupported.webGLContextAttributes, {\n failIfMajorPerformanceCaveat: this._failIfMajorPerformanceCaveat,\n preserveDrawingBuffer: this._preserveDrawingBuffer,\n antialias: this._antialias || false\n });\n var gl = this._canvas.getContext('webgl', attributes) || this._canvas.getContext('experimental-webgl', attributes);\n if (!gl) {\n this.fire(new performance.ErrorEvent(new Error('Failed to initialize WebGL')));\n return;\n }\n this.painter = new Painter(gl, this.transform);\n performance.webpSupported.testSupport(gl);\n };\n Map.prototype._contextLost = function _contextLost(event) {\n event.preventDefault();\n if (this._frame) {\n this._frame.cancel();\n this._frame = null;\n }\n this.fire(new performance.Event('webglcontextlost', { originalEvent: event }));\n };\n Map.prototype._contextRestored = function _contextRestored(event) {\n this._setupPainter();\n this.resize();\n this._update();\n this.fire(new performance.Event('webglcontextrestored', { originalEvent: event }));\n };\n Map.prototype._onMapScroll = function _onMapScroll(event) {\n if (event.target !== this._container) {\n return;\n }\n this._container.scrollTop = 0;\n this._container.scrollLeft = 0;\n return false;\n };\n Map.prototype.loaded = function loaded() {\n return !this._styleDirty && !this._sourcesDirty && !!this.style && this.style.loaded();\n };\n Map.prototype._update = function _update(updateStyle) {\n if (!this.style) {\n return this;\n }\n this._styleDirty = this._styleDirty || updateStyle;\n this._sourcesDirty = true;\n this.triggerRepaint();\n return this;\n };\n Map.prototype._requestRenderFrame = function _requestRenderFrame(callback) {\n this._update();\n return this._renderTaskQueue.add(callback);\n };\n Map.prototype._cancelRenderFrame = function _cancelRenderFrame(id) {\n this._renderTaskQueue.remove(id);\n };\n Map.prototype._render = function _render(paintStartTimeStamp) {\n var this$1 = this;\n var gpuTimer, frameStartTime = 0;\n var extTimerQuery = this.painter.context.extTimerQuery;\n if (this.listens('gpu-timing-frame')) {\n gpuTimer = extTimerQuery.createQueryEXT();\n extTimerQuery.beginQueryEXT(extTimerQuery.TIME_ELAPSED_EXT, gpuTimer);\n frameStartTime = performance.browser.now();\n }\n this.painter.context.setDirty();\n this.painter.setBaseState();\n this._renderTaskQueue.run(paintStartTimeStamp);\n if (this._removed) {\n return;\n }\n var crossFading = false;\n if (this.style && this._styleDirty) {\n this._styleDirty = false;\n var zoom = this.transform.zoom;\n var now = performance.browser.now();\n this.style.zoomHistory.update(zoom, now);\n var parameters = new performance.EvaluationParameters(zoom, {\n now: now,\n fadeDuration: this._fadeDuration,\n zoomHistory: this.style.zoomHistory,\n transition: this.style.getTransition()\n });\n var factor = parameters.crossFadingFactor();\n if (factor !== 1 || factor !== this._crossFadingFactor) {\n crossFading = true;\n this._crossFadingFactor = factor;\n }\n this.style.update(parameters);\n }\n if (this.style && this._sourcesDirty) {\n this._sourcesDirty = false;\n this.style._updateSources(this.transform);\n }\n this._placementDirty = this.style && this.style._updatePlacement(this.painter.transform, this.showCollisionBoxes, this._fadeDuration, this._crossSourceCollisions);\n this.painter.render(this.style, {\n showTileBoundaries: this.showTileBoundaries,\n showOverdrawInspector: this._showOverdrawInspector,\n rotating: this.isRotating(),\n zooming: this.isZooming(),\n moving: this.isMoving(),\n fadeDuration: this._fadeDuration,\n showPadding: this.showPadding,\n gpuTiming: !!this.listens('gpu-timing-layer')\n });\n this.fire(new performance.Event('render'));\n if (this.loaded() && !this._loaded) {\n this._loaded = true;\n this.fire(new performance.Event('load'));\n }\n if (this.style && (this.style.hasTransitions() || crossFading)) {\n this._styleDirty = true;\n }\n if (this.style && !this._placementDirty) {\n this.style._releaseSymbolFadeTiles();\n }\n if (this.listens('gpu-timing-frame')) {\n var renderCPUTime = performance.browser.now() - frameStartTime;\n extTimerQuery.endQueryEXT(extTimerQuery.TIME_ELAPSED_EXT, gpuTimer);\n setTimeout(function () {\n var renderGPUTime = extTimerQuery.getQueryObjectEXT(gpuTimer, extTimerQuery.QUERY_RESULT_EXT) / (1000 * 1000);\n extTimerQuery.deleteQueryEXT(gpuTimer);\n this$1.fire(new performance.Event('gpu-timing-frame', {\n cpuTime: renderCPUTime,\n gpuTime: renderGPUTime\n }));\n }, 50);\n }\n if (this.listens('gpu-timing-layer')) {\n var frameLayerQueries = this.painter.collectGpuTimers();\n setTimeout(function () {\n var renderedLayerTimes = this$1.painter.queryGpuTimers(frameLayerQueries);\n this$1.fire(new performance.Event('gpu-timing-layer', { layerTimes: renderedLayerTimes }));\n }, 50);\n }\n var somethingDirty = this._sourcesDirty || this._styleDirty || this._placementDirty;\n if (somethingDirty || this._repaint) {\n this.triggerRepaint();\n } else if (!this.isMoving() && this.loaded()) {\n this.fire(new performance.Event('idle'));\n }\n if (this._loaded && !this._fullyLoaded && !somethingDirty) {\n this._fullyLoaded = true;\n }\n return this;\n };\n Map.prototype.remove = function remove() {\n if (this._hash) {\n this._hash.remove();\n }\n for (var i = 0, list = this._controls; i < list.length; i += 1) {\n var control = list[i];\n control.onRemove(this);\n }\n this._controls = [];\n if (this._frame) {\n this._frame.cancel();\n this._frame = null;\n }\n this._renderTaskQueue.clear();\n this.painter.destroy();\n this.handlers.destroy();\n delete this.handlers;\n this.setStyle(null);\n if (typeof performance.window !== 'undefined') {\n performance.window.removeEventListener('resize', this._onWindowResize, false);\n performance.window.removeEventListener('orientationchange', this._onWindowResize, false);\n performance.window.removeEventListener('online', this._onWindowOnline, false);\n }\n var extension = this.painter.context.gl.getExtension('WEBGL_lose_context');\n if (extension && extension.loseContext) {\n extension.loseContext();\n }\n removeNode(this._canvasContainer);\n removeNode(this._controlContainer);\n removeNode(this._missingCSSCanary);\n this._container.classList.remove('mapboxgl-map');\n this._removed = true;\n this.fire(new performance.Event('remove'));\n };\n Map.prototype.triggerRepaint = function triggerRepaint() {\n var this$1 = this;\n if (this.style && !this._frame) {\n this._frame = performance.browser.frame(function (paintStartTimeStamp) {\n this$1._frame = null;\n this$1._render(paintStartTimeStamp);\n });\n }\n };\n Map.prototype._onWindowOnline = function _onWindowOnline() {\n this._update();\n };\n Map.prototype._onWindowResize = function _onWindowResize(event) {\n if (this._trackResize) {\n this.resize({ originalEvent: event })._update();\n }\n };\n prototypeAccessors.showTileBoundaries.get = function () {\n return !!this._showTileBoundaries;\n };\n prototypeAccessors.showTileBoundaries.set = function (value) {\n if (this._showTileBoundaries === value) {\n return;\n }\n this._showTileBoundaries = value;\n this._update();\n };\n prototypeAccessors.showPadding.get = function () {\n return !!this._showPadding;\n };\n prototypeAccessors.showPadding.set = function (value) {\n if (this._showPadding === value) {\n return;\n }\n this._showPadding = value;\n this._update();\n };\n prototypeAccessors.showCollisionBoxes.get = function () {\n return !!this._showCollisionBoxes;\n };\n prototypeAccessors.showCollisionBoxes.set = function (value) {\n if (this._showCollisionBoxes === value) {\n return;\n }\n this._showCollisionBoxes = value;\n if (value) {\n this.style._generateCollisionBoxes();\n } else {\n this._update();\n }\n };\n prototypeAccessors.showOverdrawInspector.get = function () {\n return !!this._showOverdrawInspector;\n };\n prototypeAccessors.showOverdrawInspector.set = function (value) {\n if (this._showOverdrawInspector === value) {\n return;\n }\n this._showOverdrawInspector = value;\n this._update();\n };\n prototypeAccessors.repaint.get = function () {\n return !!this._repaint;\n };\n prototypeAccessors.repaint.set = function (value) {\n if (this._repaint !== value) {\n this._repaint = value;\n this.triggerRepaint();\n }\n };\n prototypeAccessors.vertices.get = function () {\n return !!this._vertices;\n };\n prototypeAccessors.vertices.set = function (value) {\n this._vertices = value;\n this._update();\n };\n Map.prototype._setCacheLimits = function _setCacheLimits(limit, checkThreshold) {\n performance.setCacheLimits(limit, checkThreshold);\n };\n prototypeAccessors.version.get = function () {\n return performance.version;\n };\n Object.defineProperties(Map.prototype, prototypeAccessors);\n return Map;\n}(Camera);\nfunction removeNode(node) {\n if (node.parentNode) {\n node.parentNode.removeChild(node);\n }\n}\n\nvar defaultOptions$2 = {\n showCompass: true,\n showZoom: true,\n visualizePitch: false\n};\nvar NavigationControl = function NavigationControl(options) {\n var this$1 = this;\n this.options = performance.extend({}, defaultOptions$2, options);\n this._container = DOM.create('div', 'mapboxgl-ctrl mapboxgl-ctrl-group');\n this._container.addEventListener('contextmenu', function (e) {\n return e.preventDefault();\n });\n if (this.options.showZoom) {\n performance.bindAll([\n '_setButtonTitle',\n '_updateZoomButtons'\n ], this);\n this._zoomInButton = this._createButton('mapboxgl-ctrl-zoom-in', function (e) {\n return this$1._map.zoomIn({}, { originalEvent: e });\n });\n DOM.create('span', 'mapboxgl-ctrl-icon', this._zoomInButton).setAttribute('aria-hidden', true);\n this._zoomOutButton = this._createButton('mapboxgl-ctrl-zoom-out', function (e) {\n return this$1._map.zoomOut({}, { originalEvent: e });\n });\n DOM.create('span', 'mapboxgl-ctrl-icon', this._zoomOutButton).setAttribute('aria-hidden', true);\n }\n if (this.options.showCompass) {\n performance.bindAll(['_rotateCompassArrow'], this);\n this._compass = this._createButton('mapboxgl-ctrl-compass', function (e) {\n if (this$1.options.visualizePitch) {\n this$1._map.resetNorthPitch({}, { originalEvent: e });\n } else {\n this$1._map.resetNorth({}, { originalEvent: e });\n }\n });\n this._compassIcon = DOM.create('span', 'mapboxgl-ctrl-icon', this._compass);\n this._compassIcon.setAttribute('aria-hidden', true);\n }\n};\nNavigationControl.prototype._updateZoomButtons = function _updateZoomButtons() {\n var zoom = this._map.getZoom();\n var isMax = zoom === this._map.getMaxZoom();\n var isMin = zoom === this._map.getMinZoom();\n this._zoomInButton.disabled = isMax;\n this._zoomOutButton.disabled = isMin;\n this._zoomInButton.setAttribute('aria-disabled', isMax.toString());\n this._zoomOutButton.setAttribute('aria-disabled', isMin.toString());\n};\nNavigationControl.prototype._rotateCompassArrow = function _rotateCompassArrow() {\n var rotate = this.options.visualizePitch ? 'scale(' + 1 / Math.pow(Math.cos(this._map.transform.pitch * (Math.PI / 180)), 0.5) + ') rotateX(' + this._map.transform.pitch + 'deg) rotateZ(' + this._map.transform.angle * (180 / Math.PI) + 'deg)' : 'rotate(' + this._map.transform.angle * (180 / Math.PI) + 'deg)';\n this._compassIcon.style.transform = rotate;\n};\nNavigationControl.prototype.onAdd = function onAdd(map) {\n this._map = map;\n if (this.options.showZoom) {\n this._setButtonTitle(this._zoomInButton, 'ZoomIn');\n this._setButtonTitle(this._zoomOutButton, 'ZoomOut');\n this._map.on('zoom', this._updateZoomButtons);\n this._updateZoomButtons();\n }\n if (this.options.showCompass) {\n this._setButtonTitle(this._compass, 'ResetBearing');\n if (this.options.visualizePitch) {\n this._map.on('pitch', this._rotateCompassArrow);\n }\n this._map.on('rotate', this._rotateCompassArrow);\n this._rotateCompassArrow();\n this._handler = new MouseRotateWrapper(this._map, this._compass, this.options.visualizePitch);\n }\n return this._container;\n};\nNavigationControl.prototype.onRemove = function onRemove() {\n DOM.remove(this._container);\n if (this.options.showZoom) {\n this._map.off('zoom', this._updateZoomButtons);\n }\n if (this.options.showCompass) {\n if (this.options.visualizePitch) {\n this._map.off('pitch', this._rotateCompassArrow);\n }\n this._map.off('rotate', this._rotateCompassArrow);\n this._handler.off();\n delete this._handler;\n }\n delete this._map;\n};\nNavigationControl.prototype._createButton = function _createButton(className, fn) {\n var a = DOM.create('button', className, this._container);\n a.type = 'button';\n a.addEventListener('click', fn);\n return a;\n};\nNavigationControl.prototype._setButtonTitle = function _setButtonTitle(button, title) {\n var str = this._map._getUIString('NavigationControl.' + title);\n button.title = str;\n button.setAttribute('aria-label', str);\n};\nvar MouseRotateWrapper = function MouseRotateWrapper(map, element, pitch) {\n if (pitch === void 0)\n pitch = false;\n this._clickTolerance = 10;\n this.element = element;\n this.mouseRotate = new MouseRotateHandler({ clickTolerance: map.dragRotate._mouseRotate._clickTolerance });\n this.map = map;\n if (pitch) {\n this.mousePitch = new MousePitchHandler({ clickTolerance: map.dragRotate._mousePitch._clickTolerance });\n }\n performance.bindAll([\n 'mousedown',\n 'mousemove',\n 'mouseup',\n 'touchstart',\n 'touchmove',\n 'touchend',\n 'reset'\n ], this);\n DOM.addEventListener(element, 'mousedown', this.mousedown);\n DOM.addEventListener(element, 'touchstart', this.touchstart, { passive: false });\n DOM.addEventListener(element, 'touchmove', this.touchmove);\n DOM.addEventListener(element, 'touchend', this.touchend);\n DOM.addEventListener(element, 'touchcancel', this.reset);\n};\nMouseRotateWrapper.prototype.down = function down(e, point) {\n this.mouseRotate.mousedown(e, point);\n if (this.mousePitch) {\n this.mousePitch.mousedown(e, point);\n }\n DOM.disableDrag();\n};\nMouseRotateWrapper.prototype.move = function move(e, point) {\n var map = this.map;\n var r = this.mouseRotate.mousemoveWindow(e, point);\n if (r && r.bearingDelta) {\n map.setBearing(map.getBearing() + r.bearingDelta);\n }\n if (this.mousePitch) {\n var p = this.mousePitch.mousemoveWindow(e, point);\n if (p && p.pitchDelta) {\n map.setPitch(map.getPitch() + p.pitchDelta);\n }\n }\n};\nMouseRotateWrapper.prototype.off = function off() {\n var element = this.element;\n DOM.removeEventListener(element, 'mousedown', this.mousedown);\n DOM.removeEventListener(element, 'touchstart', this.touchstart, { passive: false });\n DOM.removeEventListener(element, 'touchmove', this.touchmove);\n DOM.removeEventListener(element, 'touchend', this.touchend);\n DOM.removeEventListener(element, 'touchcancel', this.reset);\n this.offTemp();\n};\nMouseRotateWrapper.prototype.offTemp = function offTemp() {\n DOM.enableDrag();\n DOM.removeEventListener(performance.window, 'mousemove', this.mousemove);\n DOM.removeEventListener(performance.window, 'mouseup', this.mouseup);\n};\nMouseRotateWrapper.prototype.mousedown = function mousedown(e) {\n this.down(performance.extend({}, e, {\n ctrlKey: true,\n preventDefault: function () {\n return e.preventDefault();\n }\n }), DOM.mousePos(this.element, e));\n DOM.addEventListener(performance.window, 'mousemove', this.mousemove);\n DOM.addEventListener(performance.window, 'mouseup', this.mouseup);\n};\nMouseRotateWrapper.prototype.mousemove = function mousemove(e) {\n this.move(e, DOM.mousePos(this.element, e));\n};\nMouseRotateWrapper.prototype.mouseup = function mouseup(e) {\n this.mouseRotate.mouseupWindow(e);\n if (this.mousePitch) {\n this.mousePitch.mouseupWindow(e);\n }\n this.offTemp();\n};\nMouseRotateWrapper.prototype.touchstart = function touchstart(e) {\n if (e.targetTouches.length !== 1) {\n this.reset();\n } else {\n this._startPos = this._lastPos = DOM.touchPos(this.element, e.targetTouches)[0];\n this.down({\n type: 'mousedown',\n button: 0,\n ctrlKey: true,\n preventDefault: function () {\n return e.preventDefault();\n }\n }, this._startPos);\n }\n};\nMouseRotateWrapper.prototype.touchmove = function touchmove(e) {\n if (e.targetTouches.length !== 1) {\n this.reset();\n } else {\n this._lastPos = DOM.touchPos(this.element, e.targetTouches)[0];\n this.move({\n preventDefault: function () {\n return e.preventDefault();\n }\n }, this._lastPos);\n }\n};\nMouseRotateWrapper.prototype.touchend = function touchend(e) {\n if (e.targetTouches.length === 0 && this._startPos && this._lastPos && this._startPos.dist(this._lastPos) < this._clickTolerance) {\n this.element.click();\n }\n this.reset();\n};\nMouseRotateWrapper.prototype.reset = function reset() {\n this.mouseRotate.reset();\n if (this.mousePitch) {\n this.mousePitch.reset();\n }\n delete this._startPos;\n delete this._lastPos;\n this.offTemp();\n};\n\nfunction smartWrap (lngLat, priorPos, transform) {\n lngLat = new performance.LngLat(lngLat.lng, lngLat.lat);\n if (priorPos) {\n var left = new performance.LngLat(lngLat.lng - 360, lngLat.lat);\n var right = new performance.LngLat(lngLat.lng + 360, lngLat.lat);\n var delta = transform.locationPoint(lngLat).distSqr(priorPos);\n if (transform.locationPoint(left).distSqr(priorPos) < delta) {\n lngLat = left;\n } else if (transform.locationPoint(right).distSqr(priorPos) < delta) {\n lngLat = right;\n }\n }\n while (Math.abs(lngLat.lng - transform.center.lng) > 180) {\n var pos = transform.locationPoint(lngLat);\n if (pos.x >= 0 && pos.y >= 0 && pos.x <= transform.width && pos.y <= transform.height) {\n break;\n }\n if (lngLat.lng > transform.center.lng) {\n lngLat.lng -= 360;\n } else {\n lngLat.lng += 360;\n }\n }\n return lngLat;\n}\n\nvar anchorTranslate = {\n 'center': 'translate(-50%,-50%)',\n 'top': 'translate(-50%,0)',\n 'top-left': 'translate(0,0)',\n 'top-right': 'translate(-100%,0)',\n 'bottom': 'translate(-50%,-100%)',\n 'bottom-left': 'translate(0,-100%)',\n 'bottom-right': 'translate(-100%,-100%)',\n 'left': 'translate(0,-50%)',\n 'right': 'translate(-100%,-50%)'\n};\nfunction applyAnchorClass(element, anchor, prefix) {\n var classList = element.classList;\n for (var key in anchorTranslate) {\n classList.remove('mapboxgl-' + prefix + '-anchor-' + key);\n }\n classList.add('mapboxgl-' + prefix + '-anchor-' + anchor);\n}\n\nvar Marker = function (Evented) {\n function Marker(options, legacyOptions) {\n Evented.call(this);\n if (options instanceof performance.window.HTMLElement || legacyOptions) {\n options = performance.extend({ element: options }, legacyOptions);\n }\n performance.bindAll([\n '_update',\n '_onMove',\n '_onUp',\n '_addDragHandler',\n '_onMapClick',\n '_onKeyPress'\n ], this);\n this._anchor = options && options.anchor || 'center';\n this._color = options && options.color || '#3FB1CE';\n this._scale = options && options.scale || 1;\n this._draggable = options && options.draggable || false;\n this._clickTolerance = options && options.clickTolerance || 0;\n this._isDragging = false;\n this._state = 'inactive';\n this._rotation = options && options.rotation || 0;\n this._rotationAlignment = options && options.rotationAlignment || 'auto';\n this._pitchAlignment = options && options.pitchAlignment && options.pitchAlignment !== 'auto' ? options.pitchAlignment : this._rotationAlignment;\n if (!options || !options.element) {\n this._defaultMarker = true;\n this._element = DOM.create('div');\n this._element.setAttribute('aria-label', 'Map marker');\n var svg = DOM.createNS('http://www.w3.org/2000/svg', 'svg');\n var defaultHeight = 41;\n var defaultWidth = 27;\n svg.setAttributeNS(null, 'display', 'block');\n svg.setAttributeNS(null, 'height', defaultHeight + 'px');\n svg.setAttributeNS(null, 'width', defaultWidth + 'px');\n svg.setAttributeNS(null, 'viewBox', '0 0 ' + defaultWidth + ' ' + defaultHeight);\n var markerLarge = DOM.createNS('http://www.w3.org/2000/svg', 'g');\n markerLarge.setAttributeNS(null, 'stroke', 'none');\n markerLarge.setAttributeNS(null, 'stroke-width', '1');\n markerLarge.setAttributeNS(null, 'fill', 'none');\n markerLarge.setAttributeNS(null, 'fill-rule', 'evenodd');\n var page1 = DOM.createNS('http://www.w3.org/2000/svg', 'g');\n page1.setAttributeNS(null, 'fill-rule', 'nonzero');\n var shadow = DOM.createNS('http://www.w3.org/2000/svg', 'g');\n shadow.setAttributeNS(null, 'transform', 'translate(3.0, 29.0)');\n shadow.setAttributeNS(null, 'fill', '#000000');\n var ellipses = [\n {\n 'rx': '10.5',\n 'ry': '5.25002273'\n },\n {\n 'rx': '10.5',\n 'ry': '5.25002273'\n },\n {\n 'rx': '9.5',\n 'ry': '4.77275007'\n },\n {\n 'rx': '8.5',\n 'ry': '4.29549936'\n },\n {\n 'rx': '7.5',\n 'ry': '3.81822308'\n },\n {\n 'rx': '6.5',\n 'ry': '3.34094679'\n },\n {\n 'rx': '5.5',\n 'ry': '2.86367051'\n },\n {\n 'rx': '4.5',\n 'ry': '2.38636864'\n }\n ];\n for (var i = 0, list = ellipses; i < list.length; i += 1) {\n var data = list[i];\n var ellipse = DOM.createNS('http://www.w3.org/2000/svg', 'ellipse');\n ellipse.setAttributeNS(null, 'opacity', '0.04');\n ellipse.setAttributeNS(null, 'cx', '10.5');\n ellipse.setAttributeNS(null, 'cy', '5.80029008');\n ellipse.setAttributeNS(null, 'rx', data['rx']);\n ellipse.setAttributeNS(null, 'ry', data['ry']);\n shadow.appendChild(ellipse);\n }\n var background = DOM.createNS('http://www.w3.org/2000/svg', 'g');\n background.setAttributeNS(null, 'fill', this._color);\n var bgPath = DOM.createNS('http://www.w3.org/2000/svg', 'path');\n bgPath.setAttributeNS(null, 'd', 'M27,13.5 C27,19.074644 20.250001,27.000002 14.75,34.500002 C14.016665,35.500004 12.983335,35.500004 12.25,34.500002 C6.7499993,27.000002 0,19.222562 0,13.5 C0,6.0441559 6.0441559,0 13.5,0 C20.955844,0 27,6.0441559 27,13.5 Z');\n background.appendChild(bgPath);\n var border = DOM.createNS('http://www.w3.org/2000/svg', 'g');\n border.setAttributeNS(null, 'opacity', '0.25');\n border.setAttributeNS(null, 'fill', '#000000');\n var borderPath = DOM.createNS('http://www.w3.org/2000/svg', 'path');\n borderPath.setAttributeNS(null, 'd', 'M13.5,0 C6.0441559,0 0,6.0441559 0,13.5 C0,19.222562 6.7499993,27 12.25,34.5 C13,35.522727 14.016664,35.500004 14.75,34.5 C20.250001,27 27,19.074644 27,13.5 C27,6.0441559 20.955844,0 13.5,0 Z M13.5,1 C20.415404,1 26,6.584596 26,13.5 C26,15.898657 24.495584,19.181431 22.220703,22.738281 C19.945823,26.295132 16.705119,30.142167 13.943359,33.908203 C13.743445,34.180814 13.612715,34.322738 13.5,34.441406 C13.387285,34.322738 13.256555,34.180814 13.056641,33.908203 C10.284481,30.127985 7.4148684,26.314159 5.015625,22.773438 C2.6163816,19.232715 1,15.953538 1,13.5 C1,6.584596 6.584596,1 13.5,1 Z');\n border.appendChild(borderPath);\n var maki = DOM.createNS('http://www.w3.org/2000/svg', 'g');\n maki.setAttributeNS(null, 'transform', 'translate(6.0, 7.0)');\n maki.setAttributeNS(null, 'fill', '#FFFFFF');\n var circleContainer = DOM.createNS('http://www.w3.org/2000/svg', 'g');\n circleContainer.setAttributeNS(null, 'transform', 'translate(8.0, 8.0)');\n var circle1 = DOM.createNS('http://www.w3.org/2000/svg', 'circle');\n circle1.setAttributeNS(null, 'fill', '#000000');\n circle1.setAttributeNS(null, 'opacity', '0.25');\n circle1.setAttributeNS(null, 'cx', '5.5');\n circle1.setAttributeNS(null, 'cy', '5.5');\n circle1.setAttributeNS(null, 'r', '5.4999962');\n var circle2 = DOM.createNS('http://www.w3.org/2000/svg', 'circle');\n circle2.setAttributeNS(null, 'fill', '#FFFFFF');\n circle2.setAttributeNS(null, 'cx', '5.5');\n circle2.setAttributeNS(null, 'cy', '5.5');\n circle2.setAttributeNS(null, 'r', '5.4999962');\n circleContainer.appendChild(circle1);\n circleContainer.appendChild(circle2);\n page1.appendChild(shadow);\n page1.appendChild(background);\n page1.appendChild(border);\n page1.appendChild(maki);\n page1.appendChild(circleContainer);\n svg.appendChild(page1);\n svg.setAttributeNS(null, 'height', defaultHeight * this._scale + 'px');\n svg.setAttributeNS(null, 'width', defaultWidth * this._scale + 'px');\n this._element.appendChild(svg);\n this._offset = performance.Point.convert(options && options.offset || [\n 0,\n -14\n ]);\n } else {\n this._element = options.element;\n this._offset = performance.Point.convert(options && options.offset || [\n 0,\n 0\n ]);\n }\n this._element.classList.add('mapboxgl-marker');\n this._element.addEventListener('dragstart', function (e) {\n e.preventDefault();\n });\n this._element.addEventListener('mousedown', function (e) {\n e.preventDefault();\n });\n applyAnchorClass(this._element, this._anchor, 'marker');\n this._popup = null;\n }\n if (Evented)\n Marker.__proto__ = Evented;\n Marker.prototype = Object.create(Evented && Evented.prototype);\n Marker.prototype.constructor = Marker;\n Marker.prototype.addTo = function addTo(map) {\n this.remove();\n this._map = map;\n map.getCanvasContainer().appendChild(this._element);\n map.on('move', this._update);\n map.on('moveend', this._update);\n this.setDraggable(this._draggable);\n this._update();\n this._map.on('click', this._onMapClick);\n return this;\n };\n Marker.prototype.remove = function remove() {\n if (this._map) {\n this._map.off('click', this._onMapClick);\n this._map.off('move', this._update);\n this._map.off('moveend', this._update);\n this._map.off('mousedown', this._addDragHandler);\n this._map.off('touchstart', this._addDragHandler);\n this._map.off('mouseup', this._onUp);\n this._map.off('touchend', this._onUp);\n this._map.off('mousemove', this._onMove);\n this._map.off('touchmove', this._onMove);\n delete this._map;\n }\n DOM.remove(this._element);\n if (this._popup) {\n this._popup.remove();\n }\n return this;\n };\n Marker.prototype.getLngLat = function getLngLat() {\n return this._lngLat;\n };\n Marker.prototype.setLngLat = function setLngLat(lnglat) {\n this._lngLat = performance.LngLat.convert(lnglat);\n this._pos = null;\n if (this._popup) {\n this._popup.setLngLat(this._lngLat);\n }\n this._update();\n return this;\n };\n Marker.prototype.getElement = function getElement() {\n return this._element;\n };\n Marker.prototype.setPopup = function setPopup(popup) {\n if (this._popup) {\n this._popup.remove();\n this._popup = null;\n this._element.removeEventListener('keypress', this._onKeyPress);\n if (!this._originalTabIndex) {\n this._element.removeAttribute('tabindex');\n }\n }\n if (popup) {\n if (!('offset' in popup.options)) {\n var markerHeight = 41 - 5.8 / 2;\n var markerRadius = 13.5;\n var linearOffset = Math.sqrt(Math.pow(markerRadius, 2) / 2);\n popup.options.offset = this._defaultMarker ? {\n 'top': [\n 0,\n 0\n ],\n 'top-left': [\n 0,\n 0\n ],\n 'top-right': [\n 0,\n 0\n ],\n 'bottom': [\n 0,\n -markerHeight\n ],\n 'bottom-left': [\n linearOffset,\n (markerHeight - markerRadius + linearOffset) * -1\n ],\n 'bottom-right': [\n -linearOffset,\n (markerHeight - markerRadius + linearOffset) * -1\n ],\n 'left': [\n markerRadius,\n (markerHeight - markerRadius) * -1\n ],\n 'right': [\n -markerRadius,\n (markerHeight - markerRadius) * -1\n ]\n } : this._offset;\n }\n this._popup = popup;\n if (this._lngLat) {\n this._popup.setLngLat(this._lngLat);\n }\n this._originalTabIndex = this._element.getAttribute('tabindex');\n if (!this._originalTabIndex) {\n this._element.setAttribute('tabindex', '0');\n }\n this._element.addEventListener('keypress', this._onKeyPress);\n }\n return this;\n };\n Marker.prototype._onKeyPress = function _onKeyPress(e) {\n var code = e.code;\n var legacyCode = e.charCode || e.keyCode;\n if (code === 'Space' || code === 'Enter' || legacyCode === 32 || legacyCode === 13) {\n this.togglePopup();\n }\n };\n Marker.prototype._onMapClick = function _onMapClick(e) {\n var targetElement = e.originalEvent.target;\n var element = this._element;\n if (this._popup && (targetElement === element || element.contains(targetElement))) {\n this.togglePopup();\n }\n };\n Marker.prototype.getPopup = function getPopup() {\n return this._popup;\n };\n Marker.prototype.togglePopup = function togglePopup() {\n var popup = this._popup;\n if (!popup) {\n return this;\n } else if (popup.isOpen()) {\n popup.remove();\n } else {\n popup.addTo(this._map);\n }\n return this;\n };\n Marker.prototype._update = function _update(e) {\n if (!this._map) {\n return;\n }\n if (this._map.transform.renderWorldCopies) {\n this._lngLat = smartWrap(this._lngLat, this._pos, this._map.transform);\n }\n this._pos = this._map.project(this._lngLat)._add(this._offset);\n var rotation = '';\n if (this._rotationAlignment === 'viewport' || this._rotationAlignment === 'auto') {\n rotation = 'rotateZ(' + this._rotation + 'deg)';\n } else if (this._rotationAlignment === 'map') {\n rotation = 'rotateZ(' + (this._rotation - this._map.getBearing()) + 'deg)';\n }\n var pitch = '';\n if (this._pitchAlignment === 'viewport' || this._pitchAlignment === 'auto') {\n pitch = 'rotateX(0deg)';\n } else if (this._pitchAlignment === 'map') {\n pitch = 'rotateX(' + this._map.getPitch() + 'deg)';\n }\n if (!e || e.type === 'moveend') {\n this._pos = this._pos.round();\n }\n DOM.setTransform(this._element, anchorTranslate[this._anchor] + ' translate(' + this._pos.x + 'px, ' + this._pos.y + 'px) ' + pitch + ' ' + rotation);\n };\n Marker.prototype.getOffset = function getOffset() {\n return this._offset;\n };\n Marker.prototype.setOffset = function setOffset(offset) {\n this._offset = performance.Point.convert(offset);\n this._update();\n return this;\n };\n Marker.prototype._onMove = function _onMove(e) {\n if (!this._isDragging) {\n var clickTolerance = this._clickTolerance || this._map._clickTolerance;\n this._isDragging = e.point.dist(this._pointerdownPos) >= clickTolerance;\n }\n if (!this._isDragging) {\n return;\n }\n this._pos = e.point.sub(this._positionDelta);\n this._lngLat = this._map.unproject(this._pos);\n this.setLngLat(this._lngLat);\n this._element.style.pointerEvents = 'none';\n if (this._state === 'pending') {\n this._state = 'active';\n this.fire(new performance.Event('dragstart'));\n }\n this.fire(new performance.Event('drag'));\n };\n Marker.prototype._onUp = function _onUp() {\n this._element.style.pointerEvents = 'auto';\n this._positionDelta = null;\n this._pointerdownPos = null;\n this._isDragging = false;\n this._map.off('mousemove', this._onMove);\n this._map.off('touchmove', this._onMove);\n if (this._state === 'active') {\n this.fire(new performance.Event('dragend'));\n }\n this._state = 'inactive';\n };\n Marker.prototype._addDragHandler = function _addDragHandler(e) {\n if (this._element.contains(e.originalEvent.target)) {\n e.preventDefault();\n this._positionDelta = e.point.sub(this._pos).add(this._offset);\n this._pointerdownPos = e.point;\n this._state = 'pending';\n this._map.on('mousemove', this._onMove);\n this._map.on('touchmove', this._onMove);\n this._map.once('mouseup', this._onUp);\n this._map.once('touchend', this._onUp);\n }\n };\n Marker.prototype.setDraggable = function setDraggable(shouldBeDraggable) {\n this._draggable = !!shouldBeDraggable;\n if (this._map) {\n if (shouldBeDraggable) {\n this._map.on('mousedown', this._addDragHandler);\n this._map.on('touchstart', this._addDragHandler);\n } else {\n this._map.off('mousedown', this._addDragHandler);\n this._map.off('touchstart', this._addDragHandler);\n }\n }\n return this;\n };\n Marker.prototype.isDraggable = function isDraggable() {\n return this._draggable;\n };\n Marker.prototype.setRotation = function setRotation(rotation) {\n this._rotation = rotation || 0;\n this._update();\n return this;\n };\n Marker.prototype.getRotation = function getRotation() {\n return this._rotation;\n };\n Marker.prototype.setRotationAlignment = function setRotationAlignment(alignment) {\n this._rotationAlignment = alignment || 'auto';\n this._update();\n return this;\n };\n Marker.prototype.getRotationAlignment = function getRotationAlignment() {\n return this._rotationAlignment;\n };\n Marker.prototype.setPitchAlignment = function setPitchAlignment(alignment) {\n this._pitchAlignment = alignment && alignment !== 'auto' ? alignment : this._rotationAlignment;\n this._update();\n return this;\n };\n Marker.prototype.getPitchAlignment = function getPitchAlignment() {\n return this._pitchAlignment;\n };\n return Marker;\n}(performance.Evented);\n\nvar defaultOptions$3 = {\n positionOptions: {\n enableHighAccuracy: false,\n maximumAge: 0,\n timeout: 6000\n },\n fitBoundsOptions: { maxZoom: 15 },\n trackUserLocation: false,\n showAccuracyCircle: true,\n showUserLocation: true\n};\nvar supportsGeolocation;\nfunction checkGeolocationSupport(callback) {\n if (supportsGeolocation !== undefined) {\n callback(supportsGeolocation);\n } else if (performance.window.navigator.permissions !== undefined) {\n performance.window.navigator.permissions.query({ name: 'geolocation' }).then(function (p) {\n supportsGeolocation = p.state !== 'denied';\n callback(supportsGeolocation);\n });\n } else {\n supportsGeolocation = !!performance.window.navigator.geolocation;\n callback(supportsGeolocation);\n }\n}\nvar numberOfWatches = 0;\nvar noTimeout = false;\nvar GeolocateControl = function (Evented) {\n function GeolocateControl(options) {\n Evented.call(this);\n this.options = performance.extend({}, defaultOptions$3, options);\n performance.bindAll([\n '_onSuccess',\n '_onError',\n '_onZoom',\n '_finish',\n '_setupUI',\n '_updateCamera',\n '_updateMarker'\n ], this);\n }\n if (Evented)\n GeolocateControl.__proto__ = Evented;\n GeolocateControl.prototype = Object.create(Evented && Evented.prototype);\n GeolocateControl.prototype.constructor = GeolocateControl;\n GeolocateControl.prototype.onAdd = function onAdd(map) {\n this._map = map;\n this._container = DOM.create('div', 'mapboxgl-ctrl mapboxgl-ctrl-group');\n checkGeolocationSupport(this._setupUI);\n return this._container;\n };\n GeolocateControl.prototype.onRemove = function onRemove() {\n if (this._geolocationWatchID !== undefined) {\n performance.window.navigator.geolocation.clearWatch(this._geolocationWatchID);\n this._geolocationWatchID = undefined;\n }\n if (this.options.showUserLocation && this._userLocationDotMarker) {\n this._userLocationDotMarker.remove();\n }\n if (this.options.showAccuracyCircle && this._accuracyCircleMarker) {\n this._accuracyCircleMarker.remove();\n }\n DOM.remove(this._container);\n this._map.off('zoom', this._onZoom);\n this._map = undefined;\n numberOfWatches = 0;\n noTimeout = false;\n };\n GeolocateControl.prototype._isOutOfMapMaxBounds = function _isOutOfMapMaxBounds(position) {\n var bounds = this._map.getMaxBounds();\n var coordinates = position.coords;\n return bounds && (coordinates.longitude < bounds.getWest() || coordinates.longitude > bounds.getEast() || coordinates.latitude < bounds.getSouth() || coordinates.latitude > bounds.getNorth());\n };\n GeolocateControl.prototype._setErrorState = function _setErrorState() {\n switch (this._watchState) {\n case 'WAITING_ACTIVE':\n this._watchState = 'ACTIVE_ERROR';\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-active');\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-active-error');\n break;\n case 'ACTIVE_LOCK':\n this._watchState = 'ACTIVE_ERROR';\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-active');\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-active-error');\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-waiting');\n break;\n case 'BACKGROUND':\n this._watchState = 'BACKGROUND_ERROR';\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-background');\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-background-error');\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-waiting');\n break;\n }\n };\n GeolocateControl.prototype._onSuccess = function _onSuccess(position) {\n if (!this._map) {\n return;\n }\n if (this._isOutOfMapMaxBounds(position)) {\n this._setErrorState();\n this.fire(new performance.Event('outofmaxbounds', position));\n this._updateMarker();\n this._finish();\n return;\n }\n if (this.options.trackUserLocation) {\n this._lastKnownPosition = position;\n switch (this._watchState) {\n case 'WAITING_ACTIVE':\n case 'ACTIVE_LOCK':\n case 'ACTIVE_ERROR':\n this._watchState = 'ACTIVE_LOCK';\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-waiting');\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-active-error');\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-active');\n break;\n case 'BACKGROUND':\n case 'BACKGROUND_ERROR':\n this._watchState = 'BACKGROUND';\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-waiting');\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-background-error');\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-background');\n break;\n }\n }\n if (this.options.showUserLocation && this._watchState !== 'OFF') {\n this._updateMarker(position);\n }\n if (!this.options.trackUserLocation || this._watchState === 'ACTIVE_LOCK') {\n this._updateCamera(position);\n }\n if (this.options.showUserLocation) {\n this._dotElement.classList.remove('mapboxgl-user-location-dot-stale');\n }\n this.fire(new performance.Event('geolocate', position));\n this._finish();\n };\n GeolocateControl.prototype._updateCamera = function _updateCamera(position) {\n var center = new performance.LngLat(position.coords.longitude, position.coords.latitude);\n var radius = position.coords.accuracy;\n var bearing = this._map.getBearing();\n var options = performance.extend({ bearing: bearing }, this.options.fitBoundsOptions);\n this._map.fitBounds(center.toBounds(radius), options, { geolocateSource: true });\n };\n GeolocateControl.prototype._updateMarker = function _updateMarker(position) {\n if (position) {\n var center = new performance.LngLat(position.coords.longitude, position.coords.latitude);\n this._accuracyCircleMarker.setLngLat(center).addTo(this._map);\n this._userLocationDotMarker.setLngLat(center).addTo(this._map);\n this._accuracy = position.coords.accuracy;\n if (this.options.showUserLocation && this.options.showAccuracyCircle) {\n this._updateCircleRadius();\n }\n } else {\n this._userLocationDotMarker.remove();\n this._accuracyCircleMarker.remove();\n }\n };\n GeolocateControl.prototype._updateCircleRadius = function _updateCircleRadius() {\n var y = this._map._container.clientHeight / 2;\n var a = this._map.unproject([\n 0,\n y\n ]);\n var b = this._map.unproject([\n 1,\n y\n ]);\n var metersPerPixel = a.distanceTo(b);\n var circleDiameter = Math.ceil(2 * this._accuracy / metersPerPixel);\n this._circleElement.style.width = circleDiameter + 'px';\n this._circleElement.style.height = circleDiameter + 'px';\n };\n GeolocateControl.prototype._onZoom = function _onZoom() {\n if (this.options.showUserLocation && this.options.showAccuracyCircle) {\n this._updateCircleRadius();\n }\n };\n GeolocateControl.prototype._onError = function _onError(error) {\n if (!this._map) {\n return;\n }\n if (this.options.trackUserLocation) {\n if (error.code === 1) {\n this._watchState = 'OFF';\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-waiting');\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-active');\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-active-error');\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-background');\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-background-error');\n this._geolocateButton.disabled = true;\n var title = this._map._getUIString('GeolocateControl.LocationNotAvailable');\n this._geolocateButton.title = title;\n this._geolocateButton.setAttribute('aria-label', title);\n if (this._geolocationWatchID !== undefined) {\n this._clearWatch();\n }\n } else if (error.code === 3 && noTimeout) {\n return;\n } else {\n this._setErrorState();\n }\n }\n if (this._watchState !== 'OFF' && this.options.showUserLocation) {\n this._dotElement.classList.add('mapboxgl-user-location-dot-stale');\n }\n this.fire(new performance.Event('error', error));\n this._finish();\n };\n GeolocateControl.prototype._finish = function _finish() {\n if (this._timeoutId) {\n clearTimeout(this._timeoutId);\n }\n this._timeoutId = undefined;\n };\n GeolocateControl.prototype._setupUI = function _setupUI(supported) {\n var this$1 = this;\n this._container.addEventListener('contextmenu', function (e) {\n return e.preventDefault();\n });\n this._geolocateButton = DOM.create('button', 'mapboxgl-ctrl-geolocate', this._container);\n DOM.create('span', 'mapboxgl-ctrl-icon', this._geolocateButton).setAttribute('aria-hidden', true);\n this._geolocateButton.type = 'button';\n if (supported === false) {\n performance.warnOnce('Geolocation support is not available so the GeolocateControl will be disabled.');\n var title = this._map._getUIString('GeolocateControl.LocationNotAvailable');\n this._geolocateButton.disabled = true;\n this._geolocateButton.title = title;\n this._geolocateButton.setAttribute('aria-label', title);\n } else {\n var title$1 = this._map._getUIString('GeolocateControl.FindMyLocation');\n this._geolocateButton.title = title$1;\n this._geolocateButton.setAttribute('aria-label', title$1);\n }\n if (this.options.trackUserLocation) {\n this._geolocateButton.setAttribute('aria-pressed', 'false');\n this._watchState = 'OFF';\n }\n if (this.options.showUserLocation) {\n this._dotElement = DOM.create('div', 'mapboxgl-user-location-dot');\n this._userLocationDotMarker = new Marker(this._dotElement);\n this._circleElement = DOM.create('div', 'mapboxgl-user-location-accuracy-circle');\n this._accuracyCircleMarker = new Marker({\n element: this._circleElement,\n pitchAlignment: 'map'\n });\n if (this.options.trackUserLocation) {\n this._watchState = 'OFF';\n }\n this._map.on('zoom', this._onZoom);\n }\n this._geolocateButton.addEventListener('click', this.trigger.bind(this));\n this._setup = true;\n if (this.options.trackUserLocation) {\n this._map.on('movestart', function (event) {\n var fromResize = event.originalEvent && event.originalEvent.type === 'resize';\n if (!event.geolocateSource && this$1._watchState === 'ACTIVE_LOCK' && !fromResize) {\n this$1._watchState = 'BACKGROUND';\n this$1._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-background');\n this$1._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-active');\n this$1.fire(new performance.Event('trackuserlocationend'));\n }\n });\n }\n };\n GeolocateControl.prototype.trigger = function trigger() {\n if (!this._setup) {\n performance.warnOnce('Geolocate control triggered before added to a map');\n return false;\n }\n if (this.options.trackUserLocation) {\n switch (this._watchState) {\n case 'OFF':\n this._watchState = 'WAITING_ACTIVE';\n this.fire(new performance.Event('trackuserlocationstart'));\n break;\n case 'WAITING_ACTIVE':\n case 'ACTIVE_LOCK':\n case 'ACTIVE_ERROR':\n case 'BACKGROUND_ERROR':\n numberOfWatches--;\n noTimeout = false;\n this._watchState = 'OFF';\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-waiting');\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-active');\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-active-error');\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-background');\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-background-error');\n this.fire(new performance.Event('trackuserlocationend'));\n break;\n case 'BACKGROUND':\n this._watchState = 'ACTIVE_LOCK';\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-background');\n if (this._lastKnownPosition) {\n this._updateCamera(this._lastKnownPosition);\n }\n this.fire(new performance.Event('trackuserlocationstart'));\n break;\n }\n switch (this._watchState) {\n case 'WAITING_ACTIVE':\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-waiting');\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-active');\n break;\n case 'ACTIVE_LOCK':\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-active');\n break;\n case 'ACTIVE_ERROR':\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-waiting');\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-active-error');\n break;\n case 'BACKGROUND':\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-background');\n break;\n case 'BACKGROUND_ERROR':\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-waiting');\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-background-error');\n break;\n }\n if (this._watchState === 'OFF' && this._geolocationWatchID !== undefined) {\n this._clearWatch();\n } else if (this._geolocationWatchID === undefined) {\n this._geolocateButton.classList.add('mapboxgl-ctrl-geolocate-waiting');\n this._geolocateButton.setAttribute('aria-pressed', 'true');\n numberOfWatches++;\n var positionOptions;\n if (numberOfWatches > 1) {\n positionOptions = {\n maximumAge: 600000,\n timeout: 0\n };\n noTimeout = true;\n } else {\n positionOptions = this.options.positionOptions;\n noTimeout = false;\n }\n this._geolocationWatchID = performance.window.navigator.geolocation.watchPosition(this._onSuccess, this._onError, positionOptions);\n }\n } else {\n performance.window.navigator.geolocation.getCurrentPosition(this._onSuccess, this._onError, this.options.positionOptions);\n this._timeoutId = setTimeout(this._finish, 10000);\n }\n return true;\n };\n GeolocateControl.prototype._clearWatch = function _clearWatch() {\n performance.window.navigator.geolocation.clearWatch(this._geolocationWatchID);\n this._geolocationWatchID = undefined;\n this._geolocateButton.classList.remove('mapboxgl-ctrl-geolocate-waiting');\n this._geolocateButton.setAttribute('aria-pressed', 'false');\n if (this.options.showUserLocation) {\n this._updateMarker(null);\n }\n };\n return GeolocateControl;\n}(performance.Evented);\n\nvar defaultOptions$4 = {\n maxWidth: 100,\n unit: 'metric'\n};\nvar ScaleControl = function ScaleControl(options) {\n this.options = performance.extend({}, defaultOptions$4, options);\n performance.bindAll([\n '_onMove',\n 'setUnit'\n ], this);\n};\nScaleControl.prototype.getDefaultPosition = function getDefaultPosition() {\n return 'bottom-left';\n};\nScaleControl.prototype._onMove = function _onMove() {\n updateScale(this._map, this._container, this.options);\n};\nScaleControl.prototype.onAdd = function onAdd(map) {\n this._map = map;\n this._container = DOM.create('div', 'mapboxgl-ctrl mapboxgl-ctrl-scale', map.getContainer());\n this._map.on('move', this._onMove);\n this._onMove();\n return this._container;\n};\nScaleControl.prototype.onRemove = function onRemove() {\n DOM.remove(this._container);\n this._map.off('move', this._onMove);\n this._map = undefined;\n};\nScaleControl.prototype.setUnit = function setUnit(unit) {\n this.options.unit = unit;\n updateScale(this._map, this._container, this.options);\n};\nfunction updateScale(map, container, options) {\n var maxWidth = options && options.maxWidth || 100;\n var y = map._container.clientHeight / 2;\n var left = map.unproject([\n 0,\n y\n ]);\n var right = map.unproject([\n maxWidth,\n y\n ]);\n var maxMeters = left.distanceTo(right);\n if (options && options.unit === 'imperial') {\n var maxFeet = 3.2808 * maxMeters;\n if (maxFeet > 5280) {\n var maxMiles = maxFeet / 5280;\n setScale(container, maxWidth, maxMiles, map._getUIString('ScaleControl.Miles'));\n } else {\n setScale(container, maxWidth, maxFeet, map._getUIString('ScaleControl.Feet'));\n }\n } else if (options && options.unit === 'nautical') {\n var maxNauticals = maxMeters / 1852;\n setScale(container, maxWidth, maxNauticals, map._getUIString('ScaleControl.NauticalMiles'));\n } else if (maxMeters >= 1000) {\n setScale(container, maxWidth, maxMeters / 1000, map._getUIString('ScaleControl.Kilometers'));\n } else {\n setScale(container, maxWidth, maxMeters, map._getUIString('ScaleControl.Meters'));\n }\n}\nfunction setScale(container, maxWidth, maxDistance, unit) {\n var distance = getRoundNum(maxDistance);\n var ratio = distance / maxDistance;\n container.style.width = maxWidth * ratio + 'px';\n container.innerHTML = distance + ' ' + unit;\n}\nfunction getDecimalRoundNum(d) {\n var multiplier = Math.pow(10, Math.ceil(-Math.log(d) / Math.LN10));\n return Math.round(d * multiplier) / multiplier;\n}\nfunction getRoundNum(num) {\n var pow10 = Math.pow(10, ('' + Math.floor(num)).length - 1);\n var d = num / pow10;\n d = d >= 10 ? 10 : d >= 5 ? 5 : d >= 3 ? 3 : d >= 2 ? 2 : d >= 1 ? 1 : getDecimalRoundNum(d);\n return pow10 * d;\n}\n\nvar FullscreenControl = function FullscreenControl(options) {\n this._fullscreen = false;\n if (options && options.container) {\n if (options.container instanceof performance.window.HTMLElement) {\n this._container = options.container;\n } else {\n performance.warnOnce('Full screen control \\'container\\' must be a DOM element.');\n }\n }\n performance.bindAll([\n '_onClickFullscreen',\n '_changeIcon'\n ], this);\n if ('onfullscreenchange' in performance.window.document) {\n this._fullscreenchange = 'fullscreenchange';\n } else if ('onmozfullscreenchange' in performance.window.document) {\n this._fullscreenchange = 'mozfullscreenchange';\n } else if ('onwebkitfullscreenchange' in performance.window.document) {\n this._fullscreenchange = 'webkitfullscreenchange';\n } else if ('onmsfullscreenchange' in performance.window.document) {\n this._fullscreenchange = 'MSFullscreenChange';\n }\n};\nFullscreenControl.prototype.onAdd = function onAdd(map) {\n this._map = map;\n if (!this._container) {\n this._container = this._map.getContainer();\n }\n this._controlContainer = DOM.create('div', 'mapboxgl-ctrl mapboxgl-ctrl-group');\n if (this._checkFullscreenSupport()) {\n this._setupUI();\n } else {\n this._controlContainer.style.display = 'none';\n performance.warnOnce('This device does not support fullscreen mode.');\n }\n return this._controlContainer;\n};\nFullscreenControl.prototype.onRemove = function onRemove() {\n DOM.remove(this._controlContainer);\n this._map = null;\n performance.window.document.removeEventListener(this._fullscreenchange, this._changeIcon);\n};\nFullscreenControl.prototype._checkFullscreenSupport = function _checkFullscreenSupport() {\n return !!(performance.window.document.fullscreenEnabled || performance.window.document.mozFullScreenEnabled || performance.window.document.msFullscreenEnabled || performance.window.document.webkitFullscreenEnabled);\n};\nFullscreenControl.prototype._setupUI = function _setupUI() {\n var button = this._fullscreenButton = DOM.create('button', 'mapboxgl-ctrl-fullscreen', this._controlContainer);\n DOM.create('span', 'mapboxgl-ctrl-icon', button).setAttribute('aria-hidden', true);\n button.type = 'button';\n this._updateTitle();\n this._fullscreenButton.addEventListener('click', this._onClickFullscreen);\n performance.window.document.addEventListener(this._fullscreenchange, this._changeIcon);\n};\nFullscreenControl.prototype._updateTitle = function _updateTitle() {\n var title = this._getTitle();\n this._fullscreenButton.setAttribute('aria-label', title);\n this._fullscreenButton.title = title;\n};\nFullscreenControl.prototype._getTitle = function _getTitle() {\n return this._map._getUIString(this._isFullscreen() ? 'FullscreenControl.Exit' : 'FullscreenControl.Enter');\n};\nFullscreenControl.prototype._isFullscreen = function _isFullscreen() {\n return this._fullscreen;\n};\nFullscreenControl.prototype._changeIcon = function _changeIcon() {\n var fullscreenElement = performance.window.document.fullscreenElement || performance.window.document.mozFullScreenElement || performance.window.document.webkitFullscreenElement || performance.window.document.msFullscreenElement;\n if (fullscreenElement === this._container !== this._fullscreen) {\n this._fullscreen = !this._fullscreen;\n this._fullscreenButton.classList.toggle('mapboxgl-ctrl-shrink');\n this._fullscreenButton.classList.toggle('mapboxgl-ctrl-fullscreen');\n this._updateTitle();\n }\n};\nFullscreenControl.prototype._onClickFullscreen = function _onClickFullscreen() {\n if (this._isFullscreen()) {\n if (performance.window.document.exitFullscreen) {\n performance.window.document.exitFullscreen();\n } else if (performance.window.document.mozCancelFullScreen) {\n performance.window.document.mozCancelFullScreen();\n } else if (performance.window.document.msExitFullscreen) {\n performance.window.document.msExitFullscreen();\n } else if (performance.window.document.webkitCancelFullScreen) {\n performance.window.document.webkitCancelFullScreen();\n }\n } else if (this._container.requestFullscreen) {\n this._container.requestFullscreen();\n } else if (this._container.mozRequestFullScreen) {\n this._container.mozRequestFullScreen();\n } else if (this._container.msRequestFullscreen) {\n this._container.msRequestFullscreen();\n } else if (this._container.webkitRequestFullscreen) {\n this._container.webkitRequestFullscreen();\n }\n};\n\nvar defaultOptions$5 = {\n closeButton: true,\n closeOnClick: true,\n focusAfterOpen: true,\n className: '',\n maxWidth: '240px'\n};\nvar focusQuerySelector = [\n 'a[href]',\n '[tabindex]:not([tabindex=\\'-1\\'])',\n '[contenteditable]:not([contenteditable=\\'false\\'])',\n 'button:not([disabled])',\n 'input:not([disabled])',\n 'select:not([disabled])',\n 'textarea:not([disabled])'\n].join(', ');\nvar Popup = function (Evented) {\n function Popup(options) {\n Evented.call(this);\n this.options = performance.extend(Object.create(defaultOptions$5), options);\n performance.bindAll([\n '_update',\n '_onClose',\n 'remove',\n '_onMouseMove',\n '_onMouseUp',\n '_onDrag'\n ], this);\n }\n if (Evented)\n Popup.__proto__ = Evented;\n Popup.prototype = Object.create(Evented && Evented.prototype);\n Popup.prototype.constructor = Popup;\n Popup.prototype.addTo = function addTo(map) {\n if (this._map) {\n this.remove();\n }\n this._map = map;\n if (this.options.closeOnClick) {\n this._map.on('click', this._onClose);\n }\n if (this.options.closeOnMove) {\n this._map.on('move', this._onClose);\n }\n this._map.on('remove', this.remove);\n this._update();\n this._focusFirstElement();\n if (this._trackPointer) {\n this._map.on('mousemove', this._onMouseMove);\n this._map.on('mouseup', this._onMouseUp);\n if (this._container) {\n this._container.classList.add('mapboxgl-popup-track-pointer');\n }\n this._map._canvasContainer.classList.add('mapboxgl-track-pointer');\n } else {\n this._map.on('move', this._update);\n }\n this.fire(new performance.Event('open'));\n return this;\n };\n Popup.prototype.isOpen = function isOpen() {\n return !!this._map;\n };\n Popup.prototype.remove = function remove() {\n if (this._content) {\n DOM.remove(this._content);\n }\n if (this._container) {\n DOM.remove(this._container);\n delete this._container;\n }\n if (this._map) {\n this._map.off('move', this._update);\n this._map.off('move', this._onClose);\n this._map.off('click', this._onClose);\n this._map.off('remove', this.remove);\n this._map.off('mousemove', this._onMouseMove);\n this._map.off('mouseup', this._onMouseUp);\n this._map.off('drag', this._onDrag);\n delete this._map;\n }\n this.fire(new performance.Event('close'));\n return this;\n };\n Popup.prototype.getLngLat = function getLngLat() {\n return this._lngLat;\n };\n Popup.prototype.setLngLat = function setLngLat(lnglat) {\n this._lngLat = performance.LngLat.convert(lnglat);\n this._pos = null;\n this._trackPointer = false;\n this._update();\n if (this._map) {\n this._map.on('move', this._update);\n this._map.off('mousemove', this._onMouseMove);\n if (this._container) {\n this._container.classList.remove('mapboxgl-popup-track-pointer');\n }\n this._map._canvasContainer.classList.remove('mapboxgl-track-pointer');\n }\n return this;\n };\n Popup.prototype.trackPointer = function trackPointer() {\n this._trackPointer = true;\n this._pos = null;\n this._update();\n if (this._map) {\n this._map.off('move', this._update);\n this._map.on('mousemove', this._onMouseMove);\n this._map.on('drag', this._onDrag);\n if (this._container) {\n this._container.classList.add('mapboxgl-popup-track-pointer');\n }\n this._map._canvasContainer.classList.add('mapboxgl-track-pointer');\n }\n return this;\n };\n Popup.prototype.getElement = function getElement() {\n return this._container;\n };\n Popup.prototype.setText = function setText(text) {\n return this.setDOMContent(performance.window.document.createTextNode(text));\n };\n Popup.prototype.setHTML = function setHTML(html) {\n var frag = performance.window.document.createDocumentFragment();\n var temp = performance.window.document.createElement('body');\n var child;\n temp.innerHTML = html;\n while (true) {\n child = temp.firstChild;\n if (!child) {\n break;\n }\n frag.appendChild(child);\n }\n return this.setDOMContent(frag);\n };\n Popup.prototype.getMaxWidth = function getMaxWidth() {\n return this._container && this._container.style.maxWidth;\n };\n Popup.prototype.setMaxWidth = function setMaxWidth(maxWidth) {\n this.options.maxWidth = maxWidth;\n this._update();\n return this;\n };\n Popup.prototype.setDOMContent = function setDOMContent(htmlNode) {\n if (this._content) {\n while (this._content.hasChildNodes()) {\n if (this._content.firstChild) {\n this._content.removeChild(this._content.firstChild);\n }\n }\n } else {\n this._content = DOM.create('div', 'mapboxgl-popup-content', this._container);\n }\n this._content.appendChild(htmlNode);\n this._createCloseButton();\n this._update();\n this._focusFirstElement();\n return this;\n };\n Popup.prototype.addClassName = function addClassName(className) {\n if (this._container) {\n this._container.classList.add(className);\n }\n };\n Popup.prototype.removeClassName = function removeClassName(className) {\n if (this._container) {\n this._container.classList.remove(className);\n }\n };\n Popup.prototype.setOffset = function setOffset(offset) {\n this.options.offset = offset;\n this._update();\n return this;\n };\n Popup.prototype.toggleClassName = function toggleClassName(className) {\n if (this._container) {\n return this._container.classList.toggle(className);\n }\n };\n Popup.prototype._createCloseButton = function _createCloseButton() {\n if (this.options.closeButton) {\n this._closeButton = DOM.create('button', 'mapboxgl-popup-close-button', this._content);\n this._closeButton.type = 'button';\n this._closeButton.setAttribute('aria-label', 'Close popup');\n this._closeButton.innerHTML = '×';\n this._closeButton.addEventListener('click', this._onClose);\n }\n };\n Popup.prototype._onMouseUp = function _onMouseUp(event) {\n this._update(event.point);\n };\n Popup.prototype._onMouseMove = function _onMouseMove(event) {\n this._update(event.point);\n };\n Popup.prototype._onDrag = function _onDrag(event) {\n this._update(event.point);\n };\n Popup.prototype._update = function _update(cursor) {\n var this$1 = this;\n var hasPosition = this._lngLat || this._trackPointer;\n if (!this._map || !hasPosition || !this._content) {\n return;\n }\n if (!this._container) {\n this._container = DOM.create('div', 'mapboxgl-popup', this._map.getContainer());\n this._tip = DOM.create('div', 'mapboxgl-popup-tip', this._container);\n this._container.appendChild(this._content);\n if (this.options.className) {\n this.options.className.split(' ').forEach(function (name) {\n return this$1._container.classList.add(name);\n });\n }\n if (this._trackPointer) {\n this._container.classList.add('mapboxgl-popup-track-pointer');\n }\n }\n if (this.options.maxWidth && this._container.style.maxWidth !== this.options.maxWidth) {\n this._container.style.maxWidth = this.options.maxWidth;\n }\n if (this._map.transform.renderWorldCopies && !this._trackPointer) {\n this._lngLat = smartWrap(this._lngLat, this._pos, this._map.transform);\n }\n if (this._trackPointer && !cursor) {\n return;\n }\n var pos = this._pos = this._trackPointer && cursor ? cursor : this._map.project(this._lngLat);\n var anchor = this.options.anchor;\n var offset = normalizeOffset(this.options.offset);\n if (!anchor) {\n var width = this._container.offsetWidth;\n var height = this._container.offsetHeight;\n var anchorComponents;\n if (pos.y + offset.bottom.y < height) {\n anchorComponents = ['top'];\n } else if (pos.y > this._map.transform.height - height) {\n anchorComponents = ['bottom'];\n } else {\n anchorComponents = [];\n }\n if (pos.x < width / 2) {\n anchorComponents.push('left');\n } else if (pos.x > this._map.transform.width - width / 2) {\n anchorComponents.push('right');\n }\n if (anchorComponents.length === 0) {\n anchor = 'bottom';\n } else {\n anchor = anchorComponents.join('-');\n }\n }\n var offsetedPos = pos.add(offset[anchor]).round();\n DOM.setTransform(this._container, anchorTranslate[anchor] + ' translate(' + offsetedPos.x + 'px,' + offsetedPos.y + 'px)');\n applyAnchorClass(this._container, anchor, 'popup');\n };\n Popup.prototype._focusFirstElement = function _focusFirstElement() {\n if (!this.options.focusAfterOpen || !this._container) {\n return;\n }\n var firstFocusable = this._container.querySelector(focusQuerySelector);\n if (firstFocusable) {\n firstFocusable.focus();\n }\n };\n Popup.prototype._onClose = function _onClose() {\n this.remove();\n };\n return Popup;\n}(performance.Evented);\nfunction normalizeOffset(offset) {\n if (!offset) {\n return normalizeOffset(new performance.Point(0, 0));\n } else if (typeof offset === 'number') {\n var cornerOffset = Math.round(Math.sqrt(0.5 * Math.pow(offset, 2)));\n return {\n 'center': new performance.Point(0, 0),\n 'top': new performance.Point(0, offset),\n 'top-left': new performance.Point(cornerOffset, cornerOffset),\n 'top-right': new performance.Point(-cornerOffset, cornerOffset),\n 'bottom': new performance.Point(0, -offset),\n 'bottom-left': new performance.Point(cornerOffset, -cornerOffset),\n 'bottom-right': new performance.Point(-cornerOffset, -cornerOffset),\n 'left': new performance.Point(offset, 0),\n 'right': new performance.Point(-offset, 0)\n };\n } else if (offset instanceof performance.Point || Array.isArray(offset)) {\n var convertedOffset = performance.Point.convert(offset);\n return {\n 'center': convertedOffset,\n 'top': convertedOffset,\n 'top-left': convertedOffset,\n 'top-right': convertedOffset,\n 'bottom': convertedOffset,\n 'bottom-left': convertedOffset,\n 'bottom-right': convertedOffset,\n 'left': convertedOffset,\n 'right': convertedOffset\n };\n } else {\n return {\n 'center': performance.Point.convert(offset['center'] || [\n 0,\n 0\n ]),\n 'top': performance.Point.convert(offset['top'] || [\n 0,\n 0\n ]),\n 'top-left': performance.Point.convert(offset['top-left'] || [\n 0,\n 0\n ]),\n 'top-right': performance.Point.convert(offset['top-right'] || [\n 0,\n 0\n ]),\n 'bottom': performance.Point.convert(offset['bottom'] || [\n 0,\n 0\n ]),\n 'bottom-left': performance.Point.convert(offset['bottom-left'] || [\n 0,\n 0\n ]),\n 'bottom-right': performance.Point.convert(offset['bottom-right'] || [\n 0,\n 0\n ]),\n 'left': performance.Point.convert(offset['left'] || [\n 0,\n 0\n ]),\n 'right': performance.Point.convert(offset['right'] || [\n 0,\n 0\n ])\n };\n }\n}\n\nvar exported = {\n version: performance.version,\n supported: mapboxGlSupported,\n setRTLTextPlugin: performance.setRTLTextPlugin,\n getRTLTextPluginStatus: performance.getRTLTextPluginStatus,\n Map: Map,\n NavigationControl: NavigationControl,\n GeolocateControl: GeolocateControl,\n AttributionControl: AttributionControl,\n ScaleControl: ScaleControl,\n FullscreenControl: FullscreenControl,\n Popup: Popup,\n Marker: Marker,\n Style: Style,\n LngLat: performance.LngLat,\n LngLatBounds: performance.LngLatBounds,\n Point: performance.Point,\n MercatorCoordinate: performance.MercatorCoordinate,\n Evented: performance.Evented,\n config: performance.config,\n prewarm: prewarm,\n clearPrewarmedResources: clearPrewarmedResources,\n get accessToken() {\n return performance.config.ACCESS_TOKEN;\n },\n set accessToken(token) {\n performance.config.ACCESS_TOKEN = token;\n },\n get baseApiUrl() {\n return performance.config.API_URL;\n },\n set baseApiUrl(url) {\n performance.config.API_URL = url;\n },\n get workerCount() {\n return WorkerPool.workerCount;\n },\n set workerCount(count) {\n WorkerPool.workerCount = count;\n },\n get maxParallelImageRequests() {\n return performance.config.MAX_PARALLEL_IMAGE_REQUESTS;\n },\n set maxParallelImageRequests(numRequests) {\n performance.config.MAX_PARALLEL_IMAGE_REQUESTS = numRequests;\n },\n clearStorage: function clearStorage(callback) {\n performance.clearTileCache(callback);\n },\n workerUrl: ''\n};\n\nreturn exported;\n\n});\n\n//\n\nreturn mapboxgl;\n\n})));\n//# sourceMappingURL=mapbox-gl-unminified.js.map\n","'use strict'\n\nmodule.exports = require('./quad')\n","/**\n * @module point-cluster/quad\n *\n * Bucket based quad tree clustering\n */\n\n'use strict'\n\nconst search = require('binary-search-bounds')\nconst clamp = require('clamp')\nconst rect = require('parse-rect')\nconst getBounds = require('array-bounds')\nconst pick = require('pick-by-alias')\nconst defined = require('defined')\nconst flatten = require('flatten-vertex-data')\nconst isObj = require('is-obj')\nconst dtype = require('dtype')\nconst log2 = require('math-log2')\n\nconst MAX_GROUP_ID = 1073741824\n\nmodule.exports = function cluster (srcPoints, options) {\n\tif (!options) options = {}\n\n\tsrcPoints = flatten(srcPoints, 'float64')\n\n\toptions = pick(options, {\n\t\tbounds: 'range bounds dataBox databox',\n\t\tmaxDepth: 'depth maxDepth maxdepth level maxLevel maxlevel levels',\n\t\tdtype: 'type dtype format out dst output destination'\n\t\t// sort: 'sortBy sortby sort',\n\t\t// pick: 'pick levelPoint',\n\t\t// nodeSize: 'node nodeSize minNodeSize minSize size'\n\t})\n\n\t// let nodeSize = defined(options.nodeSize, 1)\n\tlet maxDepth = defined(options.maxDepth, 255)\n\tlet bounds = defined(options.bounds, getBounds(srcPoints, 2))\n\tif (bounds[0] === bounds[2]) bounds[2]++\n\tif (bounds[1] === bounds[3]) bounds[3]++\n\n\tlet points = normalize(srcPoints, bounds)\n\n\t// init variables\n\tlet n = srcPoints.length >>> 1\n\tlet ids\n\tif (!options.dtype) options.dtype = 'array'\n\n\tif (typeof options.dtype === 'string') {\n\t\tids = new (dtype(options.dtype))(n)\n\t}\n\telse if (options.dtype) {\n\t\tids = options.dtype\n\t\tif (Array.isArray(ids)) ids.length = n\n\t}\n\tfor (let i = 0; i < n; ++i) {\n\t\tids[i] = i\n\t}\n\n\t// representative point indexes for levels\n\tlet levels = []\n\n\t// starting indexes of subranges in sub levels, levels.length * 4\n\tlet sublevels = []\n\n\t// unique group ids, sorted in z-curve fashion within levels by shifting bits\n\tlet groups = []\n\n\t// level offsets in `ids`\n\tlet offsets = []\n\n\n\t// sort points\n\tsort(0, 0, 1, ids, 0, 1)\n\n\n\t// return reordered ids with provided methods\n\t// save level offsets in output buffer\n\tlet offset = 0\n\tfor (let level = 0; level < levels.length; level++) {\n\t\tlet levelItems = levels[level]\n\t\tif (ids.set) ids.set(levelItems, offset)\n\t\telse {\n\t\t\tfor (let i = 0, l = levelItems.length; i < l; i++) {\n\t\t\t\tids[i + offset] = levelItems[i]\n\t\t\t}\n\t\t}\n\t\tlet nextOffset = offset + levels[level].length\n\t\toffsets[level] = [offset, nextOffset]\n\t\toffset = nextOffset\n\t}\n\n\tids.range = range\n\n\treturn ids\n\n\n\n\t// FIXME: it is possible to create one typed array heap and reuse that to avoid memory blow\n\tfunction sort (x, y, diam, ids, level, group) {\n\t\tif (!ids.length) return null\n\n\t\t// save first point as level representative\n\t\tlet levelItems = levels[level] || (levels[level] = [])\n\t\tlet levelGroups = groups[level] || (groups[level] = [])\n\t\tlet sublevel = sublevels[level] || (sublevels[level] = [])\n\t\tlet offset = levelItems.length\n\n\t\tlevel++\n\n\t\t// max depth reached - put all items into a first group\n\t\t// alternatively - if group id overflow - avoid proceeding\n\t\tif (level > maxDepth || group > MAX_GROUP_ID) {\n\t\t\tfor (let i = 0; i < ids.length; i++) {\n\t\t\t\tlevelItems.push(ids[i])\n\t\t\t\tlevelGroups.push(group)\n\t\t\t\tsublevel.push(null, null, null, null)\n\t\t\t}\n\n\t\t\treturn offset\n\t\t}\n\n\t\tlevelItems.push(ids[0])\n\t\tlevelGroups.push(group)\n\n\t\tif (ids.length <= 1) {\n\t\t\tsublevel.push(null, null, null, null)\n\t\t\treturn offset\n\t\t}\n\n\n\t\tlet d2 = diam * .5\n\t\tlet cx = x + d2, cy = y + d2\n\n\t\t// distribute points by 4 buckets\n\t\tlet lolo = [], lohi = [], hilo = [], hihi = []\n\n\t\tfor (let i = 1, l = ids.length; i < l; i++) {\n\t\t\tlet idx = ids[i],\n\t\t\t\tx = points[idx * 2],\n\t\t\t\ty = points[idx * 2 + 1]\n\t\t\tx < cx ? (y < cy ? lolo.push(idx) : lohi.push(idx)) : (y < cy ? hilo.push(idx) : hihi.push(idx))\n\t\t}\n\n\t\tgroup <<= 2\n\n\t\tsublevel.push(\n\t\t\tsort(x, y, d2, lolo, level, group),\n\t\t\tsort(x, cy, d2, lohi, level, group + 1),\n\t\t\tsort(cx, y, d2, hilo, level, group + 2),\n\t\t\tsort(cx, cy, d2, hihi, level, group + 3)\n\t\t)\n\n\t\treturn offset\n\t}\n\n\t// get all points within the passed range\n\tfunction range ( ...args ) {\n\t\tlet options\n\n\t\tif (isObj(args[args.length - 1])) {\n\t\t\tlet arg = args.pop()\n\n\t\t\t// detect if that was a rect object\n\t\t\tif (!args.length && (arg.x != null || arg.l != null || arg.left != null)) {\n\t\t\t\targs = [arg]\n\t\t\t\toptions = {}\n\t\t\t}\n\n\t\t\toptions = pick(arg, {\n\t\t\t\tlevel: 'level maxLevel',\n\t\t\t\td: 'd diam diameter r radius px pxSize pixel pixelSize maxD size minSize',\n\t\t\t\tlod: 'lod details ranges offsets'\n\t\t\t})\n\t\t}\n\t\telse {\n\t\t\toptions = {}\n\t\t}\n\n\t\tif (!args.length) args = bounds\n\n\t\tlet box = rect( ...args )\n\n\t\tlet [minX, minY, maxX, maxY] = [\n\t\t\tMath.min(box.x, box.x + box.width),\n\t\t\tMath.min(box.y, box.y + box.height),\n\t\t\tMath.max(box.x, box.x + box.width),\n\t\t\tMath.max(box.y, box.y + box.height)\n\t\t]\n\n\t\tlet [nminX, nminY, nmaxX, nmaxY] = normalize([minX, minY, maxX, maxY], bounds )\n\n\t\tlet maxLevel = defined(options.level, levels.length)\n\n\t\t// limit maxLevel by px size\n\t\tif (options.d != null) {\n\t\t\tlet d\n\t\t\tif (typeof options.d === 'number') d = [options.d, options.d]\n\t\t\telse if (options.d.length) d = options.d\n\n\t\t\tmaxLevel = Math.min(\n\t\t\t\tMath.max(\n\t\t\t\t\tMath.ceil(-log2(Math.abs(d[0]) / (bounds[2] - bounds[0]))),\n\t\t\t\t\tMath.ceil(-log2(Math.abs(d[1]) / (bounds[3] - bounds[1])))\n\t\t\t\t),\n\t\t\t\tmaxLevel\n\t\t\t)\n\t\t}\n\t\tmaxLevel = Math.min(maxLevel, levels.length)\n\n\t\t// return levels of details\n\t\tif (options.lod) {\n\t\t\treturn lod(nminX, nminY, nmaxX, nmaxY, maxLevel)\n\t\t}\n\n\n\n\t\t// do selection ids\n\t\tlet selection = []\n\n\t\t// FIXME: probably we can do LOD here beforehead\n\t\tselect( 0, 0, 1, 0, 0, 1)\n\n\t\tfunction select ( lox, loy, d, level, from, to ) {\n\t\t\tif (from === null || to === null) return\n\n\t\t\tlet hix = lox + d\n\t\t\tlet hiy = loy + d\n\n\t\t\t// if box does not intersect level - ignore\n\t\t\tif ( nminX > hix || nminY > hiy || nmaxX < lox || nmaxY < loy ) return\n\t\t\tif ( level >= maxLevel ) return\n\t\t\tif ( from === to ) return\n\n\t\t\t// if points fall into box range - take it\n\t\t\tlet levelItems = levels[level]\n\n\t\t\tif (to === undefined) to = levelItems.length\n\n\t\t\tfor (let i = from; i < to; i++) {\n\t\t\t\tlet id = levelItems[i]\n\n\t\t\t\tlet px = srcPoints[ id * 2 ]\n\t\t\t\tlet py = srcPoints[ id * 2 + 1 ]\n\n\t\t\t\tif ( px >= minX && px <= maxX && py >= minY && py <= maxY ) {selection.push(id)\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// for every subsection do select\n\t\t\tlet offsets = sublevels[ level ]\n\t\t\tlet off0 = offsets[ from * 4 + 0 ]\n\t\t\tlet off1 = offsets[ from * 4 + 1 ]\n\t\t\tlet off2 = offsets[ from * 4 + 2 ]\n\t\t\tlet off3 = offsets[ from * 4 + 3 ]\n\t\t\tlet end = nextOffset(offsets, from + 1)\n\n\t\t\tlet d2 = d * .5\n\t\t\tlet nextLevel = level + 1\n\t\t\tselect( lox, loy, d2, nextLevel, off0, off1 || off2 || off3 || end)\n\t\t\tselect( lox, loy + d2, d2, nextLevel, off1, off2 || off3 || end)\n\t\t\tselect( lox + d2, loy, d2, nextLevel, off2, off3 || end)\n\t\t\tselect( lox + d2, loy + d2, d2, nextLevel, off3, end)\n\t\t}\n\n\t\tfunction nextOffset(offsets, from) {\n\t\t\tlet offset = null, i = 0\n\t\t\twhile(offset === null) {\n\t\t\t\toffset = offsets[ from * 4 + i ]\n\t\t\t\ti++\n\t\t\t\tif (i > offsets.length) return null\n\t\t\t}\n\t\t\treturn offset\n\t\t}\n\n\t\treturn selection\n\t}\n\n\t// get range offsets within levels to render lods appropriate for zoom level\n\t// TODO: it is possible to store minSize of a point to optimize neede level calc\n\tfunction lod (lox, loy, hix, hiy, maxLevel) {\n\t\tlet ranges = []\n\n\t\tfor (let level = 0; level < maxLevel; level++) {\n\t\t\tlet levelGroups = groups[level]\n\t\t\tlet from = offsets[level][0]\n\n\t\t\tlet levelGroupStart = group(lox, loy, level)\n\t\t\tlet levelGroupEnd = group(hix, hiy, level)\n\n\t\t\t// FIXME: utilize sublevels to speed up search range here\n\t\t\tlet startOffset = search.ge(levelGroups, levelGroupStart)\n\t\t\tlet endOffset = search.gt(levelGroups, levelGroupEnd, startOffset, levelGroups.length - 1)\n\n\t\t\tranges[level] = [startOffset + from, endOffset + from]\n\t\t}\n\n\t\treturn ranges\n\t}\n\n\t// get group id closest to the x,y coordinate, corresponding to a level\n\tfunction group (x, y, level) {\n\t\tlet group = 1\n\n\t\tlet cx = .5, cy = .5\n\t\tlet diam = .5\n\n\t\tfor (let i = 0; i < level; i++) {\n\t\t\tgroup <<= 2\n\n\t\t\tgroup += x < cx ? (y < cy ? 0 : 1) : (y < cy ? 2 : 3)\n\n\t\t\tdiam *= .5\n\n\t\t\tcx += x < cx ? -diam : diam\n\t\t\tcy += y < cy ? -diam : diam\n\t\t}\n\n\t\treturn group\n\t}\n}\n\n\n// normalize points by bounds\nfunction normalize (pts, bounds) {\n\tlet [lox, loy, hix, hiy] = bounds\n\tlet scaleX = 1.0 / (hix - lox)\n\tlet scaleY = 1.0 / (hiy - loy)\n\tlet result = new Array(pts.length)\n\n\tfor (let i = 0, n = pts.length / 2; i < n; i++) {\n\t\tresult[2*i] = clamp((pts[2*i] - lox) * scaleX, 0, 1)\n\t\tresult[2*i+1] = clamp((pts[2*i+1] - loy) * scaleY, 0, 1)\n\t}\n\n\treturn result\n}\n","\nmodule.exports = absolutize\n\n/**\n * redefine `path` with absolute coordinates\n *\n * @param {Array} path\n * @return {Array}\n */\n\nfunction absolutize(path){\n\tvar startX = 0\n\tvar startY = 0\n\tvar x = 0\n\tvar y = 0\n\n\treturn path.map(function(seg){\n\t\tseg = seg.slice()\n\t\tvar type = seg[0]\n\t\tvar command = type.toUpperCase()\n\n\t\t// is relative\n\t\tif (type != command) {\n\t\t\tseg[0] = command\n\t\t\tswitch (type) {\n\t\t\t\tcase 'a':\n\t\t\t\t\tseg[6] += x\n\t\t\t\t\tseg[7] += y\n\t\t\t\t\tbreak\n\t\t\t\tcase 'v':\n\t\t\t\t\tseg[1] += y\n\t\t\t\t\tbreak\n\t\t\t\tcase 'h':\n\t\t\t\t\tseg[1] += x\n\t\t\t\t\tbreak\n\t\t\t\tdefault:\n\t\t\t\t\tfor (var i = 1; i < seg.length;) {\n\t\t\t\t\t\tseg[i++] += x\n\t\t\t\t\t\tseg[i++] += y\n\t\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// update cursor state\n\t\tswitch (command) {\n\t\t\tcase 'Z':\n\t\t\t\tx = startX\n\t\t\t\ty = startY\n\t\t\t\tbreak\n\t\t\tcase 'H':\n\t\t\t\tx = seg[1]\n\t\t\t\tbreak\n\t\t\tcase 'V':\n\t\t\t\ty = seg[1]\n\t\t\t\tbreak\n\t\t\tcase 'M':\n\t\t\t\tx = startX = seg[1]\n\t\t\t\ty = startY = seg[2]\n\t\t\t\tbreak\n\t\t\tdefault:\n\t\t\t\tx = seg[seg.length - 2]\n\t\t\t\ty = seg[seg.length - 1]\n\t\t}\n\n\t\treturn seg\n\t})\n}\n","'use strict'\r\n\r\nmodule.exports = normalize;\r\n\r\nfunction normalize (arr, dim) {\r\n\tif (!arr || arr.length == null) throw Error('Argument should be an array')\r\n\r\n\tif (dim == null) dim = 1\r\n\telse dim = Math.floor(dim)\r\n\r\n\tvar bounds = Array(dim * 2)\r\n\r\n\tfor (var offset = 0; offset < dim; offset++) {\r\n\t\tvar max = -Infinity, min = Infinity, i = offset, l = arr.length;\r\n\r\n\t\tfor (; i < l; i+=dim) {\r\n\t\t\tif (arr[i] > max) max = arr[i];\r\n\t\t\tif (arr[i] < min) min = arr[i];\r\n\t\t}\r\n\r\n\t\tbounds[offset] = min\r\n\t\tbounds[dim + offset] = max\r\n\t}\r\n\r\n\treturn bounds;\r\n}\r\n","'use strict';\nmodule.exports = function (arr, predicate, ctx) {\n\tif (typeof Array.prototype.findIndex === 'function') {\n\t\treturn arr.findIndex(predicate, ctx);\n\t}\n\n\tif (typeof predicate !== 'function') {\n\t\tthrow new TypeError('predicate must be a function');\n\t}\n\n\tvar list = Object(arr);\n\tvar len = list.length;\n\n\tif (len === 0) {\n\t\treturn -1;\n\t}\n\n\tfor (var i = 0; i < len; i++) {\n\t\tif (predicate.call(ctx, list[i], i, list)) {\n\t\t\treturn i;\n\t\t}\n\t}\n\n\treturn -1;\n};\n","'use strict'\r\n\r\nvar getBounds = require('array-bounds')\r\n\r\nmodule.exports = normalize;\r\n\r\nfunction normalize (arr, dim, bounds) {\r\n\tif (!arr || arr.length == null) throw Error('Argument should be an array')\r\n\r\n\tif (dim == null) dim = 1\r\n\tif (bounds == null) bounds = getBounds(arr, dim)\r\n\r\n\tfor (var offset = 0; offset < dim; offset++) {\r\n\t\tvar max = bounds[dim + offset], min = bounds[offset], i = offset, l = arr.length;\r\n\r\n\t\tif (max === Infinity && min === -Infinity) {\r\n\t\t\tfor (i = offset; i < l; i+=dim) {\r\n\t\t\t\tarr[i] = arr[i] === max ? 1 : arr[i] === min ? 0 : .5\r\n\t\t\t}\r\n\t\t}\r\n\t\telse if (max === Infinity) {\r\n\t\t\tfor (i = offset; i < l; i+=dim) {\r\n\t\t\t\tarr[i] = arr[i] === max ? 1 : 0\r\n\t\t\t}\r\n\t\t}\r\n\t\telse if (min === -Infinity) {\r\n\t\t\tfor (i = offset; i < l; i+=dim) {\r\n\t\t\t\tarr[i] = arr[i] === min ? 0 : 1\r\n\t\t\t}\r\n\t\t}\r\n\t\telse {\r\n\t\t\tvar range = max - min\r\n\t\t\tfor (i = offset; i < l; i+=dim) {\r\n\t\t\t\tif (!isNaN(arr[i])) {\r\n\t\t\t\t\tarr[i] = range === 0 ? .5 : (arr[i] - min) / range\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\treturn arr;\r\n}\r\n","\nmodule.exports = function newArray(start, end) {\n var n0 = typeof start === 'number',\n n1 = typeof end === 'number'\n\n if (n0 && !n1) {\n end = start\n start = 0\n } else if (!n0 && !n1) {\n start = 0\n end = 0\n }\n\n start = start|0\n end = end|0\n var len = end-start\n if (len<0)\n throw new Error('array length must be positive')\n \n var a = new Array(len)\n for (var i=0, c=start; i\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the 'Software'), to\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN\n// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION\n// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nfunction _typeof(o) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o; }, _typeof(o); }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nvar _require = require('./internal/errors'),\n _require$codes = _require.codes,\n ERR_AMBIGUOUS_ARGUMENT = _require$codes.ERR_AMBIGUOUS_ARGUMENT,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_INVALID_ARG_VALUE = _require$codes.ERR_INVALID_ARG_VALUE,\n ERR_INVALID_RETURN_VALUE = _require$codes.ERR_INVALID_RETURN_VALUE,\n ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS;\nvar AssertionError = require('./internal/assert/assertion_error');\nvar _require2 = require('util/'),\n inspect = _require2.inspect;\nvar _require$types = require('util/').types,\n isPromise = _require$types.isPromise,\n isRegExp = _require$types.isRegExp;\nvar objectAssign = require('object.assign/polyfill')();\nvar objectIs = require('object-is/polyfill')();\nvar RegExpPrototypeTest = require('call-bind/callBound')('RegExp.prototype.test');\nvar errorCache = new Map();\nvar isDeepEqual;\nvar isDeepStrictEqual;\nvar parseExpressionAt;\nvar findNodeAround;\nvar decoder;\nfunction lazyLoadComparison() {\n var comparison = require('./internal/util/comparisons');\n isDeepEqual = comparison.isDeepEqual;\n isDeepStrictEqual = comparison.isDeepStrictEqual;\n}\n\n// Escape control characters but not \\n and \\t to keep the line breaks and\n// indentation intact.\n// eslint-disable-next-line no-control-regex\nvar escapeSequencesRegExp = /[\\x00-\\x08\\x0b\\x0c\\x0e-\\x1f]/g;\nvar meta = [\"\\\\u0000\", \"\\\\u0001\", \"\\\\u0002\", \"\\\\u0003\", \"\\\\u0004\", \"\\\\u0005\", \"\\\\u0006\", \"\\\\u0007\", '\\\\b', '', '', \"\\\\u000b\", '\\\\f', '', \"\\\\u000e\", \"\\\\u000f\", \"\\\\u0010\", \"\\\\u0011\", \"\\\\u0012\", \"\\\\u0013\", \"\\\\u0014\", \"\\\\u0015\", \"\\\\u0016\", \"\\\\u0017\", \"\\\\u0018\", \"\\\\u0019\", \"\\\\u001a\", \"\\\\u001b\", \"\\\\u001c\", \"\\\\u001d\", \"\\\\u001e\", \"\\\\u001f\"];\nvar escapeFn = function escapeFn(str) {\n return meta[str.charCodeAt(0)];\n};\nvar warned = false;\n\n// The assert module provides functions that throw\n// AssertionError's when particular conditions are not met. The\n// assert module must conform to the following interface.\n\nvar assert = module.exports = ok;\nvar NO_EXCEPTION_SENTINEL = {};\n\n// All of the following functions must throw an AssertionError\n// when a corresponding condition is not met, with a message that\n// may be undefined if not provided. All assertion methods provide\n// both the actual and expected values to the assertion error for\n// display purposes.\n\nfunction innerFail(obj) {\n if (obj.message instanceof Error) throw obj.message;\n throw new AssertionError(obj);\n}\nfunction fail(actual, expected, message, operator, stackStartFn) {\n var argsLen = arguments.length;\n var internalMessage;\n if (argsLen === 0) {\n internalMessage = 'Failed';\n } else if (argsLen === 1) {\n message = actual;\n actual = undefined;\n } else {\n if (warned === false) {\n warned = true;\n var warn = process.emitWarning ? process.emitWarning : console.warn.bind(console);\n warn('assert.fail() with more than one argument is deprecated. ' + 'Please use assert.strictEqual() instead or only pass a message.', 'DeprecationWarning', 'DEP0094');\n }\n if (argsLen === 2) operator = '!=';\n }\n if (message instanceof Error) throw message;\n var errArgs = {\n actual: actual,\n expected: expected,\n operator: operator === undefined ? 'fail' : operator,\n stackStartFn: stackStartFn || fail\n };\n if (message !== undefined) {\n errArgs.message = message;\n }\n var err = new AssertionError(errArgs);\n if (internalMessage) {\n err.message = internalMessage;\n err.generatedMessage = true;\n }\n throw err;\n}\nassert.fail = fail;\n\n// The AssertionError is defined in internal/error.\nassert.AssertionError = AssertionError;\nfunction innerOk(fn, argLen, value, message) {\n if (!value) {\n var generatedMessage = false;\n if (argLen === 0) {\n generatedMessage = true;\n message = 'No value argument passed to `assert.ok()`';\n } else if (message instanceof Error) {\n throw message;\n }\n var err = new AssertionError({\n actual: value,\n expected: true,\n message: message,\n operator: '==',\n stackStartFn: fn\n });\n err.generatedMessage = generatedMessage;\n throw err;\n }\n}\n\n// Pure assertion tests whether a value is truthy, as determined\n// by !!value.\nfunction ok() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n innerOk.apply(void 0, [ok, args.length].concat(args));\n}\nassert.ok = ok;\n\n// The equality assertion tests shallow, coercive equality with ==.\n/* eslint-disable no-restricted-properties */\nassert.equal = function equal(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n // eslint-disable-next-line eqeqeq\n if (actual != expected) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: '==',\n stackStartFn: equal\n });\n }\n};\n\n// The non-equality assertion tests for whether two objects are not\n// equal with !=.\nassert.notEqual = function notEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n // eslint-disable-next-line eqeqeq\n if (actual == expected) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: '!=',\n stackStartFn: notEqual\n });\n }\n};\n\n// The equivalence assertion tests a deep equality relation.\nassert.deepEqual = function deepEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n if (!isDeepEqual(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'deepEqual',\n stackStartFn: deepEqual\n });\n }\n};\n\n// The non-equivalence assertion tests for any deep inequality.\nassert.notDeepEqual = function notDeepEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n if (isDeepEqual(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'notDeepEqual',\n stackStartFn: notDeepEqual\n });\n }\n};\n/* eslint-enable */\n\nassert.deepStrictEqual = function deepStrictEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n if (!isDeepStrictEqual(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'deepStrictEqual',\n stackStartFn: deepStrictEqual\n });\n }\n};\nassert.notDeepStrictEqual = notDeepStrictEqual;\nfunction notDeepStrictEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n if (isDeepStrictEqual(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'notDeepStrictEqual',\n stackStartFn: notDeepStrictEqual\n });\n }\n}\nassert.strictEqual = function strictEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (!objectIs(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'strictEqual',\n stackStartFn: strictEqual\n });\n }\n};\nassert.notStrictEqual = function notStrictEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (objectIs(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'notStrictEqual',\n stackStartFn: notStrictEqual\n });\n }\n};\nvar Comparison = /*#__PURE__*/_createClass(function Comparison(obj, keys, actual) {\n var _this = this;\n _classCallCheck(this, Comparison);\n keys.forEach(function (key) {\n if (key in obj) {\n if (actual !== undefined && typeof actual[key] === 'string' && isRegExp(obj[key]) && RegExpPrototypeTest(obj[key], actual[key])) {\n _this[key] = actual[key];\n } else {\n _this[key] = obj[key];\n }\n }\n });\n});\nfunction compareExceptionKey(actual, expected, key, message, keys, fn) {\n if (!(key in actual) || !isDeepStrictEqual(actual[key], expected[key])) {\n if (!message) {\n // Create placeholder objects to create a nice output.\n var a = new Comparison(actual, keys);\n var b = new Comparison(expected, keys, actual);\n var err = new AssertionError({\n actual: a,\n expected: b,\n operator: 'deepStrictEqual',\n stackStartFn: fn\n });\n err.actual = actual;\n err.expected = expected;\n err.operator = fn.name;\n throw err;\n }\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: fn.name,\n stackStartFn: fn\n });\n }\n}\nfunction expectedException(actual, expected, msg, fn) {\n if (typeof expected !== 'function') {\n if (isRegExp(expected)) return RegExpPrototypeTest(expected, actual);\n // assert.doesNotThrow does not accept objects.\n if (arguments.length === 2) {\n throw new ERR_INVALID_ARG_TYPE('expected', ['Function', 'RegExp'], expected);\n }\n\n // Handle primitives properly.\n if (_typeof(actual) !== 'object' || actual === null) {\n var err = new AssertionError({\n actual: actual,\n expected: expected,\n message: msg,\n operator: 'deepStrictEqual',\n stackStartFn: fn\n });\n err.operator = fn.name;\n throw err;\n }\n var keys = Object.keys(expected);\n // Special handle errors to make sure the name and the message are compared\n // as well.\n if (expected instanceof Error) {\n keys.push('name', 'message');\n } else if (keys.length === 0) {\n throw new ERR_INVALID_ARG_VALUE('error', expected, 'may not be an empty object');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n keys.forEach(function (key) {\n if (typeof actual[key] === 'string' && isRegExp(expected[key]) && RegExpPrototypeTest(expected[key], actual[key])) {\n return;\n }\n compareExceptionKey(actual, expected, key, msg, keys, fn);\n });\n return true;\n }\n // Guard instanceof against arrow functions as they don't have a prototype.\n if (expected.prototype !== undefined && actual instanceof expected) {\n return true;\n }\n if (Error.isPrototypeOf(expected)) {\n return false;\n }\n return expected.call({}, actual) === true;\n}\nfunction getActual(fn) {\n if (typeof fn !== 'function') {\n throw new ERR_INVALID_ARG_TYPE('fn', 'Function', fn);\n }\n try {\n fn();\n } catch (e) {\n return e;\n }\n return NO_EXCEPTION_SENTINEL;\n}\nfunction checkIsPromise(obj) {\n // Accept native ES6 promises and promises that are implemented in a similar\n // way. Do not accept thenables that use a function as `obj` and that have no\n // `catch` handler.\n\n // TODO: thenables are checked up until they have the correct methods,\n // but according to documentation, the `then` method should receive\n // the `fulfill` and `reject` arguments as well or it may be never resolved.\n\n return isPromise(obj) || obj !== null && _typeof(obj) === 'object' && typeof obj.then === 'function' && typeof obj.catch === 'function';\n}\nfunction waitForActual(promiseFn) {\n return Promise.resolve().then(function () {\n var resultPromise;\n if (typeof promiseFn === 'function') {\n // Return a rejected promise if `promiseFn` throws synchronously.\n resultPromise = promiseFn();\n // Fail in case no promise is returned.\n if (!checkIsPromise(resultPromise)) {\n throw new ERR_INVALID_RETURN_VALUE('instance of Promise', 'promiseFn', resultPromise);\n }\n } else if (checkIsPromise(promiseFn)) {\n resultPromise = promiseFn;\n } else {\n throw new ERR_INVALID_ARG_TYPE('promiseFn', ['Function', 'Promise'], promiseFn);\n }\n return Promise.resolve().then(function () {\n return resultPromise;\n }).then(function () {\n return NO_EXCEPTION_SENTINEL;\n }).catch(function (e) {\n return e;\n });\n });\n}\nfunction expectsError(stackStartFn, actual, error, message) {\n if (typeof error === 'string') {\n if (arguments.length === 4) {\n throw new ERR_INVALID_ARG_TYPE('error', ['Object', 'Error', 'Function', 'RegExp'], error);\n }\n if (_typeof(actual) === 'object' && actual !== null) {\n if (actual.message === error) {\n throw new ERR_AMBIGUOUS_ARGUMENT('error/message', \"The error message \\\"\".concat(actual.message, \"\\\" is identical to the message.\"));\n }\n } else if (actual === error) {\n throw new ERR_AMBIGUOUS_ARGUMENT('error/message', \"The error \\\"\".concat(actual, \"\\\" is identical to the message.\"));\n }\n message = error;\n error = undefined;\n } else if (error != null && _typeof(error) !== 'object' && typeof error !== 'function') {\n throw new ERR_INVALID_ARG_TYPE('error', ['Object', 'Error', 'Function', 'RegExp'], error);\n }\n if (actual === NO_EXCEPTION_SENTINEL) {\n var details = '';\n if (error && error.name) {\n details += \" (\".concat(error.name, \")\");\n }\n details += message ? \": \".concat(message) : '.';\n var fnType = stackStartFn.name === 'rejects' ? 'rejection' : 'exception';\n innerFail({\n actual: undefined,\n expected: error,\n operator: stackStartFn.name,\n message: \"Missing expected \".concat(fnType).concat(details),\n stackStartFn: stackStartFn\n });\n }\n if (error && !expectedException(actual, error, message, stackStartFn)) {\n throw actual;\n }\n}\nfunction expectsNoError(stackStartFn, actual, error, message) {\n if (actual === NO_EXCEPTION_SENTINEL) return;\n if (typeof error === 'string') {\n message = error;\n error = undefined;\n }\n if (!error || expectedException(actual, error)) {\n var details = message ? \": \".concat(message) : '.';\n var fnType = stackStartFn.name === 'doesNotReject' ? 'rejection' : 'exception';\n innerFail({\n actual: actual,\n expected: error,\n operator: stackStartFn.name,\n message: \"Got unwanted \".concat(fnType).concat(details, \"\\n\") + \"Actual message: \\\"\".concat(actual && actual.message, \"\\\"\"),\n stackStartFn: stackStartFn\n });\n }\n throw actual;\n}\nassert.throws = function throws(promiseFn) {\n for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n args[_key2 - 1] = arguments[_key2];\n }\n expectsError.apply(void 0, [throws, getActual(promiseFn)].concat(args));\n};\nassert.rejects = function rejects(promiseFn) {\n for (var _len3 = arguments.length, args = new Array(_len3 > 1 ? _len3 - 1 : 0), _key3 = 1; _key3 < _len3; _key3++) {\n args[_key3 - 1] = arguments[_key3];\n }\n return waitForActual(promiseFn).then(function (result) {\n return expectsError.apply(void 0, [rejects, result].concat(args));\n });\n};\nassert.doesNotThrow = function doesNotThrow(fn) {\n for (var _len4 = arguments.length, args = new Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++) {\n args[_key4 - 1] = arguments[_key4];\n }\n expectsNoError.apply(void 0, [doesNotThrow, getActual(fn)].concat(args));\n};\nassert.doesNotReject = function doesNotReject(fn) {\n for (var _len5 = arguments.length, args = new Array(_len5 > 1 ? _len5 - 1 : 0), _key5 = 1; _key5 < _len5; _key5++) {\n args[_key5 - 1] = arguments[_key5];\n }\n return waitForActual(fn).then(function (result) {\n return expectsNoError.apply(void 0, [doesNotReject, result].concat(args));\n });\n};\nassert.ifError = function ifError(err) {\n if (err !== null && err !== undefined) {\n var message = 'ifError got unwanted exception: ';\n if (_typeof(err) === 'object' && typeof err.message === 'string') {\n if (err.message.length === 0 && err.constructor) {\n message += err.constructor.name;\n } else {\n message += err.message;\n }\n } else {\n message += inspect(err);\n }\n var newErr = new AssertionError({\n actual: err,\n expected: null,\n operator: 'ifError',\n message: message,\n stackStartFn: ifError\n });\n\n // Make sure we actually have a stack trace!\n var origStack = err.stack;\n if (typeof origStack === 'string') {\n // This will remove any duplicated frames from the error frames taken\n // from within `ifError` and add the original error frames to the newly\n // created ones.\n var tmp2 = origStack.split('\\n');\n tmp2.shift();\n // Filter all frames existing in err.stack.\n var tmp1 = newErr.stack.split('\\n');\n for (var i = 0; i < tmp2.length; i++) {\n // Find the first occurrence of the frame.\n var pos = tmp1.indexOf(tmp2[i]);\n if (pos !== -1) {\n // Only keep new frames.\n tmp1 = tmp1.slice(0, pos);\n break;\n }\n }\n newErr.stack = \"\".concat(tmp1.join('\\n'), \"\\n\").concat(tmp2.join('\\n'));\n }\n throw newErr;\n }\n};\n\n// Currently in sync with Node.js lib/assert.js\n// https://github.com/nodejs/node/commit/2a871df3dfb8ea663ef5e1f8f62701ec51384ecb\nfunction internalMatch(string, regexp, message, fn, fnName) {\n if (!isRegExp(regexp)) {\n throw new ERR_INVALID_ARG_TYPE('regexp', 'RegExp', regexp);\n }\n var match = fnName === 'match';\n if (typeof string !== 'string' || RegExpPrototypeTest(regexp, string) !== match) {\n if (message instanceof Error) {\n throw message;\n }\n var generatedMessage = !message;\n\n // 'The input was expected to not match the regular expression ' +\n message = message || (typeof string !== 'string' ? 'The \"string\" argument must be of type string. Received type ' + \"\".concat(_typeof(string), \" (\").concat(inspect(string), \")\") : (match ? 'The input did not match the regular expression ' : 'The input was expected to not match the regular expression ') + \"\".concat(inspect(regexp), \". Input:\\n\\n\").concat(inspect(string), \"\\n\"));\n var err = new AssertionError({\n actual: string,\n expected: regexp,\n message: message,\n operator: fnName,\n stackStartFn: fn\n });\n err.generatedMessage = generatedMessage;\n throw err;\n }\n}\nassert.match = function match(string, regexp, message) {\n internalMatch(string, regexp, message, match, 'match');\n};\nassert.doesNotMatch = function doesNotMatch(string, regexp, message) {\n internalMatch(string, regexp, message, doesNotMatch, 'doesNotMatch');\n};\n\n// Expose a strict only variant of assert\nfunction strict() {\n for (var _len6 = arguments.length, args = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) {\n args[_key6] = arguments[_key6];\n }\n innerOk.apply(void 0, [strict, args.length].concat(args));\n}\nassert.strict = objectAssign(strict, assert, {\n equal: assert.strictEqual,\n deepEqual: assert.deepStrictEqual,\n notEqual: assert.notStrictEqual,\n notDeepEqual: assert.notDeepStrictEqual\n});\nassert.strict.strict = assert.strict;","// Currently in sync with Node.js lib/internal/assert/assertion_error.js\n// https://github.com/nodejs/node/commit/0817840f775032169ddd70c85ac059f18ffcc81c\n\n'use strict';\n\nfunction ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }\nfunction _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, \"prototype\", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } else if (call !== void 0) { throw new TypeError(\"Derived constructors may only return object or undefined\"); } return _assertThisInitialized(self); }\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\nfunction _wrapNativeSuper(Class) { var _cache = typeof Map === \"function\" ? new Map() : undefined; _wrapNativeSuper = function _wrapNativeSuper(Class) { if (Class === null || !_isNativeFunction(Class)) return Class; if (typeof Class !== \"function\") { throw new TypeError(\"Super expression must either be null or a function\"); } if (typeof _cache !== \"undefined\") { if (_cache.has(Class)) return _cache.get(Class); _cache.set(Class, Wrapper); } function Wrapper() { return _construct(Class, arguments, _getPrototypeOf(this).constructor); } Wrapper.prototype = Object.create(Class.prototype, { constructor: { value: Wrapper, enumerable: false, writable: true, configurable: true } }); return _setPrototypeOf(Wrapper, Class); }; return _wrapNativeSuper(Class); }\nfunction _construct(Parent, args, Class) { if (_isNativeReflectConstruct()) { _construct = Reflect.construct.bind(); } else { _construct = function _construct(Parent, args, Class) { var a = [null]; a.push.apply(a, args); var Constructor = Function.bind.apply(Parent, a); var instance = new Constructor(); if (Class) _setPrototypeOf(instance, Class.prototype); return instance; }; } return _construct.apply(null, arguments); }\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\nfunction _isNativeFunction(fn) { return Function.toString.call(fn).indexOf(\"[native code]\") !== -1; }\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\nfunction _typeof(o) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o; }, _typeof(o); }\nvar _require = require('util/'),\n inspect = _require.inspect;\nvar _require2 = require('../errors'),\n ERR_INVALID_ARG_TYPE = _require2.codes.ERR_INVALID_ARG_TYPE;\n\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith\nfunction endsWith(str, search, this_len) {\n if (this_len === undefined || this_len > str.length) {\n this_len = str.length;\n }\n return str.substring(this_len - search.length, this_len) === search;\n}\n\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/repeat\nfunction repeat(str, count) {\n count = Math.floor(count);\n if (str.length == 0 || count == 0) return '';\n var maxCount = str.length * count;\n count = Math.floor(Math.log(count) / Math.log(2));\n while (count) {\n str += str;\n count--;\n }\n str += str.substring(0, maxCount - str.length);\n return str;\n}\nvar blue = '';\nvar green = '';\nvar red = '';\nvar white = '';\nvar kReadableOperator = {\n deepStrictEqual: 'Expected values to be strictly deep-equal:',\n strictEqual: 'Expected values to be strictly equal:',\n strictEqualObject: 'Expected \"actual\" to be reference-equal to \"expected\":',\n deepEqual: 'Expected values to be loosely deep-equal:',\n equal: 'Expected values to be loosely equal:',\n notDeepStrictEqual: 'Expected \"actual\" not to be strictly deep-equal to:',\n notStrictEqual: 'Expected \"actual\" to be strictly unequal to:',\n notStrictEqualObject: 'Expected \"actual\" not to be reference-equal to \"expected\":',\n notDeepEqual: 'Expected \"actual\" not to be loosely deep-equal to:',\n notEqual: 'Expected \"actual\" to be loosely unequal to:',\n notIdentical: 'Values identical but not reference-equal:'\n};\n\n// Comparing short primitives should just show === / !== instead of using the\n// diff.\nvar kMaxShortLength = 10;\nfunction copyError(source) {\n var keys = Object.keys(source);\n var target = Object.create(Object.getPrototypeOf(source));\n keys.forEach(function (key) {\n target[key] = source[key];\n });\n Object.defineProperty(target, 'message', {\n value: source.message\n });\n return target;\n}\nfunction inspectValue(val) {\n // The util.inspect default values could be changed. This makes sure the\n // error messages contain the necessary information nevertheless.\n return inspect(val, {\n compact: false,\n customInspect: false,\n depth: 1000,\n maxArrayLength: Infinity,\n // Assert compares only enumerable properties (with a few exceptions).\n showHidden: false,\n // Having a long line as error is better than wrapping the line for\n // comparison for now.\n // TODO(BridgeAR): `breakLength` should be limited as soon as soon as we\n // have meta information about the inspected properties (i.e., know where\n // in what line the property starts and ends).\n breakLength: Infinity,\n // Assert does not detect proxies currently.\n showProxy: false,\n sorted: true,\n // Inspect getters as we also check them when comparing entries.\n getters: true\n });\n}\nfunction createErrDiff(actual, expected, operator) {\n var other = '';\n var res = '';\n var lastPos = 0;\n var end = '';\n var skipped = false;\n var actualInspected = inspectValue(actual);\n var actualLines = actualInspected.split('\\n');\n var expectedLines = inspectValue(expected).split('\\n');\n var i = 0;\n var indicator = '';\n\n // In case both values are objects explicitly mark them as not reference equal\n // for the `strictEqual` operator.\n if (operator === 'strictEqual' && _typeof(actual) === 'object' && _typeof(expected) === 'object' && actual !== null && expected !== null) {\n operator = 'strictEqualObject';\n }\n\n // If \"actual\" and \"expected\" fit on a single line and they are not strictly\n // equal, check further special handling.\n if (actualLines.length === 1 && expectedLines.length === 1 && actualLines[0] !== expectedLines[0]) {\n var inputLength = actualLines[0].length + expectedLines[0].length;\n // If the character length of \"actual\" and \"expected\" together is less than\n // kMaxShortLength and if neither is an object and at least one of them is\n // not `zero`, use the strict equal comparison to visualize the output.\n if (inputLength <= kMaxShortLength) {\n if ((_typeof(actual) !== 'object' || actual === null) && (_typeof(expected) !== 'object' || expected === null) && (actual !== 0 || expected !== 0)) {\n // -0 === +0\n return \"\".concat(kReadableOperator[operator], \"\\n\\n\") + \"\".concat(actualLines[0], \" !== \").concat(expectedLines[0], \"\\n\");\n }\n } else if (operator !== 'strictEqualObject') {\n // If the stderr is a tty and the input length is lower than the current\n // columns per line, add a mismatch indicator below the output. If it is\n // not a tty, use a default value of 80 characters.\n var maxLength = process.stderr && process.stderr.isTTY ? process.stderr.columns : 80;\n if (inputLength < maxLength) {\n while (actualLines[0][i] === expectedLines[0][i]) {\n i++;\n }\n // Ignore the first characters.\n if (i > 2) {\n // Add position indicator for the first mismatch in case it is a\n // single line and the input length is less than the column length.\n indicator = \"\\n \".concat(repeat(' ', i), \"^\");\n i = 0;\n }\n }\n }\n }\n\n // Remove all ending lines that match (this optimizes the output for\n // readability by reducing the number of total changed lines).\n var a = actualLines[actualLines.length - 1];\n var b = expectedLines[expectedLines.length - 1];\n while (a === b) {\n if (i++ < 2) {\n end = \"\\n \".concat(a).concat(end);\n } else {\n other = a;\n }\n actualLines.pop();\n expectedLines.pop();\n if (actualLines.length === 0 || expectedLines.length === 0) break;\n a = actualLines[actualLines.length - 1];\n b = expectedLines[expectedLines.length - 1];\n }\n var maxLines = Math.max(actualLines.length, expectedLines.length);\n // Strict equal with identical objects that are not identical by reference.\n // E.g., assert.deepStrictEqual({ a: Symbol() }, { a: Symbol() })\n if (maxLines === 0) {\n // We have to get the result again. The lines were all removed before.\n var _actualLines = actualInspected.split('\\n');\n\n // Only remove lines in case it makes sense to collapse those.\n // TODO: Accept env to always show the full error.\n if (_actualLines.length > 30) {\n _actualLines[26] = \"\".concat(blue, \"...\").concat(white);\n while (_actualLines.length > 27) {\n _actualLines.pop();\n }\n }\n return \"\".concat(kReadableOperator.notIdentical, \"\\n\\n\").concat(_actualLines.join('\\n'), \"\\n\");\n }\n if (i > 3) {\n end = \"\\n\".concat(blue, \"...\").concat(white).concat(end);\n skipped = true;\n }\n if (other !== '') {\n end = \"\\n \".concat(other).concat(end);\n other = '';\n }\n var printedLines = 0;\n var msg = kReadableOperator[operator] + \"\\n\".concat(green, \"+ actual\").concat(white, \" \").concat(red, \"- expected\").concat(white);\n var skippedMsg = \" \".concat(blue, \"...\").concat(white, \" Lines skipped\");\n for (i = 0; i < maxLines; i++) {\n // Only extra expected lines exist\n var cur = i - lastPos;\n if (actualLines.length < i + 1) {\n // If the last diverging line is more than one line above and the\n // current line is at least line three, add some of the former lines and\n // also add dots to indicate skipped entries.\n if (cur > 1 && i > 2) {\n if (cur > 4) {\n res += \"\\n\".concat(blue, \"...\").concat(white);\n skipped = true;\n } else if (cur > 3) {\n res += \"\\n \".concat(expectedLines[i - 2]);\n printedLines++;\n }\n res += \"\\n \".concat(expectedLines[i - 1]);\n printedLines++;\n }\n // Mark the current line as the last diverging one.\n lastPos = i;\n // Add the expected line to the cache.\n other += \"\\n\".concat(red, \"-\").concat(white, \" \").concat(expectedLines[i]);\n printedLines++;\n // Only extra actual lines exist\n } else if (expectedLines.length < i + 1) {\n // If the last diverging line is more than one line above and the\n // current line is at least line three, add some of the former lines and\n // also add dots to indicate skipped entries.\n if (cur > 1 && i > 2) {\n if (cur > 4) {\n res += \"\\n\".concat(blue, \"...\").concat(white);\n skipped = true;\n } else if (cur > 3) {\n res += \"\\n \".concat(actualLines[i - 2]);\n printedLines++;\n }\n res += \"\\n \".concat(actualLines[i - 1]);\n printedLines++;\n }\n // Mark the current line as the last diverging one.\n lastPos = i;\n // Add the actual line to the result.\n res += \"\\n\".concat(green, \"+\").concat(white, \" \").concat(actualLines[i]);\n printedLines++;\n // Lines diverge\n } else {\n var expectedLine = expectedLines[i];\n var actualLine = actualLines[i];\n // If the lines diverge, specifically check for lines that only diverge by\n // a trailing comma. In that case it is actually identical and we should\n // mark it as such.\n var divergingLines = actualLine !== expectedLine && (!endsWith(actualLine, ',') || actualLine.slice(0, -1) !== expectedLine);\n // If the expected line has a trailing comma but is otherwise identical,\n // add a comma at the end of the actual line. Otherwise the output could\n // look weird as in:\n //\n // [\n // 1 // No comma at the end!\n // + 2\n // ]\n //\n if (divergingLines && endsWith(expectedLine, ',') && expectedLine.slice(0, -1) === actualLine) {\n divergingLines = false;\n actualLine += ',';\n }\n if (divergingLines) {\n // If the last diverging line is more than one line above and the\n // current line is at least line three, add some of the former lines and\n // also add dots to indicate skipped entries.\n if (cur > 1 && i > 2) {\n if (cur > 4) {\n res += \"\\n\".concat(blue, \"...\").concat(white);\n skipped = true;\n } else if (cur > 3) {\n res += \"\\n \".concat(actualLines[i - 2]);\n printedLines++;\n }\n res += \"\\n \".concat(actualLines[i - 1]);\n printedLines++;\n }\n // Mark the current line as the last diverging one.\n lastPos = i;\n // Add the actual line to the result and cache the expected diverging\n // line so consecutive diverging lines show up as +++--- and not +-+-+-.\n res += \"\\n\".concat(green, \"+\").concat(white, \" \").concat(actualLine);\n other += \"\\n\".concat(red, \"-\").concat(white, \" \").concat(expectedLine);\n printedLines += 2;\n // Lines are identical\n } else {\n // Add all cached information to the result before adding other things\n // and reset the cache.\n res += other;\n other = '';\n // If the last diverging line is exactly one line above or if it is the\n // very first line, add the line to the result.\n if (cur === 1 || i === 0) {\n res += \"\\n \".concat(actualLine);\n printedLines++;\n }\n }\n }\n // Inspected object to big (Show ~20 rows max)\n if (printedLines > 20 && i < maxLines - 2) {\n return \"\".concat(msg).concat(skippedMsg, \"\\n\").concat(res, \"\\n\").concat(blue, \"...\").concat(white).concat(other, \"\\n\") + \"\".concat(blue, \"...\").concat(white);\n }\n }\n return \"\".concat(msg).concat(skipped ? skippedMsg : '', \"\\n\").concat(res).concat(other).concat(end).concat(indicator);\n}\nvar AssertionError = /*#__PURE__*/function (_Error, _inspect$custom) {\n _inherits(AssertionError, _Error);\n var _super = _createSuper(AssertionError);\n function AssertionError(options) {\n var _this;\n _classCallCheck(this, AssertionError);\n if (_typeof(options) !== 'object' || options === null) {\n throw new ERR_INVALID_ARG_TYPE('options', 'Object', options);\n }\n var message = options.message,\n operator = options.operator,\n stackStartFn = options.stackStartFn;\n var actual = options.actual,\n expected = options.expected;\n var limit = Error.stackTraceLimit;\n Error.stackTraceLimit = 0;\n if (message != null) {\n _this = _super.call(this, String(message));\n } else {\n if (process.stderr && process.stderr.isTTY) {\n // Reset on each call to make sure we handle dynamically set environment\n // variables correct.\n if (process.stderr && process.stderr.getColorDepth && process.stderr.getColorDepth() !== 1) {\n blue = \"\\x1B[34m\";\n green = \"\\x1B[32m\";\n white = \"\\x1B[39m\";\n red = \"\\x1B[31m\";\n } else {\n blue = '';\n green = '';\n white = '';\n red = '';\n }\n }\n // Prevent the error stack from being visible by duplicating the error\n // in a very close way to the original in case both sides are actually\n // instances of Error.\n if (_typeof(actual) === 'object' && actual !== null && _typeof(expected) === 'object' && expected !== null && 'stack' in actual && actual instanceof Error && 'stack' in expected && expected instanceof Error) {\n actual = copyError(actual);\n expected = copyError(expected);\n }\n if (operator === 'deepStrictEqual' || operator === 'strictEqual') {\n _this = _super.call(this, createErrDiff(actual, expected, operator));\n } else if (operator === 'notDeepStrictEqual' || operator === 'notStrictEqual') {\n // In case the objects are equal but the operator requires unequal, show\n // the first object and say A equals B\n var base = kReadableOperator[operator];\n var res = inspectValue(actual).split('\\n');\n\n // In case \"actual\" is an object, it should not be reference equal.\n if (operator === 'notStrictEqual' && _typeof(actual) === 'object' && actual !== null) {\n base = kReadableOperator.notStrictEqualObject;\n }\n\n // Only remove lines in case it makes sense to collapse those.\n // TODO: Accept env to always show the full error.\n if (res.length > 30) {\n res[26] = \"\".concat(blue, \"...\").concat(white);\n while (res.length > 27) {\n res.pop();\n }\n }\n\n // Only print a single input.\n if (res.length === 1) {\n _this = _super.call(this, \"\".concat(base, \" \").concat(res[0]));\n } else {\n _this = _super.call(this, \"\".concat(base, \"\\n\\n\").concat(res.join('\\n'), \"\\n\"));\n }\n } else {\n var _res = inspectValue(actual);\n var other = '';\n var knownOperators = kReadableOperator[operator];\n if (operator === 'notDeepEqual' || operator === 'notEqual') {\n _res = \"\".concat(kReadableOperator[operator], \"\\n\\n\").concat(_res);\n if (_res.length > 1024) {\n _res = \"\".concat(_res.slice(0, 1021), \"...\");\n }\n } else {\n other = \"\".concat(inspectValue(expected));\n if (_res.length > 512) {\n _res = \"\".concat(_res.slice(0, 509), \"...\");\n }\n if (other.length > 512) {\n other = \"\".concat(other.slice(0, 509), \"...\");\n }\n if (operator === 'deepEqual' || operator === 'equal') {\n _res = \"\".concat(knownOperators, \"\\n\\n\").concat(_res, \"\\n\\nshould equal\\n\\n\");\n } else {\n other = \" \".concat(operator, \" \").concat(other);\n }\n }\n _this = _super.call(this, \"\".concat(_res).concat(other));\n }\n }\n Error.stackTraceLimit = limit;\n _this.generatedMessage = !message;\n Object.defineProperty(_assertThisInitialized(_this), 'name', {\n value: 'AssertionError [ERR_ASSERTION]',\n enumerable: false,\n writable: true,\n configurable: true\n });\n _this.code = 'ERR_ASSERTION';\n _this.actual = actual;\n _this.expected = expected;\n _this.operator = operator;\n if (Error.captureStackTrace) {\n // eslint-disable-next-line no-restricted-syntax\n Error.captureStackTrace(_assertThisInitialized(_this), stackStartFn);\n }\n // Create error message including the error code in the name.\n _this.stack;\n // Reset the name.\n _this.name = 'AssertionError';\n return _possibleConstructorReturn(_this);\n }\n _createClass(AssertionError, [{\n key: \"toString\",\n value: function toString() {\n return \"\".concat(this.name, \" [\").concat(this.code, \"]: \").concat(this.message);\n }\n }, {\n key: _inspect$custom,\n value: function value(recurseTimes, ctx) {\n // This limits the `actual` and `expected` property default inspection to\n // the minimum depth. Otherwise those values would be too verbose compared\n // to the actual error message which contains a combined view of these two\n // input values.\n return inspect(this, _objectSpread(_objectSpread({}, ctx), {}, {\n customInspect: false,\n depth: 0\n }));\n }\n }]);\n return AssertionError;\n}( /*#__PURE__*/_wrapNativeSuper(Error), inspect.custom);\nmodule.exports = AssertionError;","// Currently in sync with Node.js lib/internal/errors.js\n// https://github.com/nodejs/node/commit/3b044962c48fe313905877a96b5d0894a5404f6f\n\n/* eslint node-core/documented-errors: \"error\" */\n/* eslint node-core/alphabetize-errors: \"error\" */\n/* eslint node-core/prefer-util-format-errors: \"error\" */\n\n'use strict';\n\n// The whole point behind this internal module is to allow Node.js to no\n// longer be forced to treat every error message change as a semver-major\n// change. The NodeError classes here all expose a `code` property whose\n// value statically and permanently identifies the error. While the error\n// message may change, the code should not.\nfunction _typeof(o) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o; }, _typeof(o); }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, \"prototype\", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } else if (call !== void 0) { throw new TypeError(\"Derived constructors may only return object or undefined\"); } return _assertThisInitialized(self); }\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\nvar codes = {};\n\n// Lazy loaded\nvar assert;\nvar util;\nfunction createErrorType(code, message, Base) {\n if (!Base) {\n Base = Error;\n }\n function getMessage(arg1, arg2, arg3) {\n if (typeof message === 'string') {\n return message;\n } else {\n return message(arg1, arg2, arg3);\n }\n }\n var NodeError = /*#__PURE__*/function (_Base) {\n _inherits(NodeError, _Base);\n var _super = _createSuper(NodeError);\n function NodeError(arg1, arg2, arg3) {\n var _this;\n _classCallCheck(this, NodeError);\n _this = _super.call(this, getMessage(arg1, arg2, arg3));\n _this.code = code;\n return _this;\n }\n return _createClass(NodeError);\n }(Base);\n codes[code] = NodeError;\n}\n\n// https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js\nfunction oneOf(expected, thing) {\n if (Array.isArray(expected)) {\n var len = expected.length;\n expected = expected.map(function (i) {\n return String(i);\n });\n if (len > 2) {\n return \"one of \".concat(thing, \" \").concat(expected.slice(0, len - 1).join(', '), \", or \") + expected[len - 1];\n } else if (len === 2) {\n return \"one of \".concat(thing, \" \").concat(expected[0], \" or \").concat(expected[1]);\n } else {\n return \"of \".concat(thing, \" \").concat(expected[0]);\n }\n } else {\n return \"of \".concat(thing, \" \").concat(String(expected));\n }\n}\n\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith\nfunction startsWith(str, search, pos) {\n return str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search;\n}\n\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith\nfunction endsWith(str, search, this_len) {\n if (this_len === undefined || this_len > str.length) {\n this_len = str.length;\n }\n return str.substring(this_len - search.length, this_len) === search;\n}\n\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes\nfunction includes(str, search, start) {\n if (typeof start !== 'number') {\n start = 0;\n }\n if (start + search.length > str.length) {\n return false;\n } else {\n return str.indexOf(search, start) !== -1;\n }\n}\ncreateErrorType('ERR_AMBIGUOUS_ARGUMENT', 'The \"%s\" argument is ambiguous. %s', TypeError);\ncreateErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) {\n if (assert === undefined) assert = require('../assert');\n assert(typeof name === 'string', \"'name' must be a string\");\n\n // determiner: 'must be' or 'must not be'\n var determiner;\n if (typeof expected === 'string' && startsWith(expected, 'not ')) {\n determiner = 'must not be';\n expected = expected.replace(/^not /, '');\n } else {\n determiner = 'must be';\n }\n var msg;\n if (endsWith(name, ' argument')) {\n // For cases like 'first argument'\n msg = \"The \".concat(name, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n } else {\n var type = includes(name, '.') ? 'property' : 'argument';\n msg = \"The \\\"\".concat(name, \"\\\" \").concat(type, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n }\n\n // TODO(BridgeAR): Improve the output by showing `null` and similar.\n msg += \". Received type \".concat(_typeof(actual));\n return msg;\n}, TypeError);\ncreateErrorType('ERR_INVALID_ARG_VALUE', function (name, value) {\n var reason = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'is invalid';\n if (util === undefined) util = require('util/');\n var inspected = util.inspect(value);\n if (inspected.length > 128) {\n inspected = \"\".concat(inspected.slice(0, 128), \"...\");\n }\n return \"The argument '\".concat(name, \"' \").concat(reason, \". Received \").concat(inspected);\n}, TypeError, RangeError);\ncreateErrorType('ERR_INVALID_RETURN_VALUE', function (input, name, value) {\n var type;\n if (value && value.constructor && value.constructor.name) {\n type = \"instance of \".concat(value.constructor.name);\n } else {\n type = \"type \".concat(_typeof(value));\n }\n return \"Expected \".concat(input, \" to be returned from the \\\"\").concat(name, \"\\\"\") + \" function but got \".concat(type, \".\");\n}, TypeError);\ncreateErrorType('ERR_MISSING_ARGS', function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n if (assert === undefined) assert = require('../assert');\n assert(args.length > 0, 'At least one arg needs to be specified');\n var msg = 'The ';\n var len = args.length;\n args = args.map(function (a) {\n return \"\\\"\".concat(a, \"\\\"\");\n });\n switch (len) {\n case 1:\n msg += \"\".concat(args[0], \" argument\");\n break;\n case 2:\n msg += \"\".concat(args[0], \" and \").concat(args[1], \" arguments\");\n break;\n default:\n msg += args.slice(0, len - 1).join(', ');\n msg += \", and \".concat(args[len - 1], \" arguments\");\n break;\n }\n return \"\".concat(msg, \" must be specified\");\n}, TypeError);\nmodule.exports.codes = codes;","// Currently in sync with Node.js lib/internal/util/comparisons.js\n// https://github.com/nodejs/node/commit/112cc7c27551254aa2b17098fb774867f05ed0d9\n\n'use strict';\n\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(r, l) { var t = null == r ? null : \"undefined\" != typeof Symbol && r[Symbol.iterator] || r[\"@@iterator\"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nfunction _typeof(o) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o; }, _typeof(o); }\nvar regexFlagsSupported = /a/g.flags !== undefined;\nvar arrayFromSet = function arrayFromSet(set) {\n var array = [];\n set.forEach(function (value) {\n return array.push(value);\n });\n return array;\n};\nvar arrayFromMap = function arrayFromMap(map) {\n var array = [];\n map.forEach(function (value, key) {\n return array.push([key, value]);\n });\n return array;\n};\nvar objectIs = Object.is ? Object.is : require('object-is');\nvar objectGetOwnPropertySymbols = Object.getOwnPropertySymbols ? Object.getOwnPropertySymbols : function () {\n return [];\n};\nvar numberIsNaN = Number.isNaN ? Number.isNaN : require('is-nan');\nfunction uncurryThis(f) {\n return f.call.bind(f);\n}\nvar hasOwnProperty = uncurryThis(Object.prototype.hasOwnProperty);\nvar propertyIsEnumerable = uncurryThis(Object.prototype.propertyIsEnumerable);\nvar objectToString = uncurryThis(Object.prototype.toString);\nvar _require$types = require('util/').types,\n isAnyArrayBuffer = _require$types.isAnyArrayBuffer,\n isArrayBufferView = _require$types.isArrayBufferView,\n isDate = _require$types.isDate,\n isMap = _require$types.isMap,\n isRegExp = _require$types.isRegExp,\n isSet = _require$types.isSet,\n isNativeError = _require$types.isNativeError,\n isBoxedPrimitive = _require$types.isBoxedPrimitive,\n isNumberObject = _require$types.isNumberObject,\n isStringObject = _require$types.isStringObject,\n isBooleanObject = _require$types.isBooleanObject,\n isBigIntObject = _require$types.isBigIntObject,\n isSymbolObject = _require$types.isSymbolObject,\n isFloat32Array = _require$types.isFloat32Array,\n isFloat64Array = _require$types.isFloat64Array;\nfunction isNonIndex(key) {\n if (key.length === 0 || key.length > 10) return true;\n for (var i = 0; i < key.length; i++) {\n var code = key.charCodeAt(i);\n if (code < 48 || code > 57) return true;\n }\n // The maximum size for an array is 2 ** 32 -1.\n return key.length === 10 && key >= Math.pow(2, 32);\n}\nfunction getOwnNonIndexProperties(value) {\n return Object.keys(value).filter(isNonIndex).concat(objectGetOwnPropertySymbols(value).filter(Object.prototype.propertyIsEnumerable.bind(value)));\n}\n\n// Taken from https://github.com/feross/buffer/blob/680e9e5e488f22aac27599a57dc844a6315928dd/index.js\n// original notice:\n/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\nfunction compare(a, b) {\n if (a === b) {\n return 0;\n }\n var x = a.length;\n var y = b.length;\n for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i];\n y = b[i];\n break;\n }\n }\n if (x < y) {\n return -1;\n }\n if (y < x) {\n return 1;\n }\n return 0;\n}\nvar ONLY_ENUMERABLE = undefined;\nvar kStrict = true;\nvar kLoose = false;\nvar kNoIterator = 0;\nvar kIsArray = 1;\nvar kIsSet = 2;\nvar kIsMap = 3;\n\n// Check if they have the same source and flags\nfunction areSimilarRegExps(a, b) {\n return regexFlagsSupported ? a.source === b.source && a.flags === b.flags : RegExp.prototype.toString.call(a) === RegExp.prototype.toString.call(b);\n}\nfunction areSimilarFloatArrays(a, b) {\n if (a.byteLength !== b.byteLength) {\n return false;\n }\n for (var offset = 0; offset < a.byteLength; offset++) {\n if (a[offset] !== b[offset]) {\n return false;\n }\n }\n return true;\n}\nfunction areSimilarTypedArrays(a, b) {\n if (a.byteLength !== b.byteLength) {\n return false;\n }\n return compare(new Uint8Array(a.buffer, a.byteOffset, a.byteLength), new Uint8Array(b.buffer, b.byteOffset, b.byteLength)) === 0;\n}\nfunction areEqualArrayBuffers(buf1, buf2) {\n return buf1.byteLength === buf2.byteLength && compare(new Uint8Array(buf1), new Uint8Array(buf2)) === 0;\n}\nfunction isEqualBoxedPrimitive(val1, val2) {\n if (isNumberObject(val1)) {\n return isNumberObject(val2) && objectIs(Number.prototype.valueOf.call(val1), Number.prototype.valueOf.call(val2));\n }\n if (isStringObject(val1)) {\n return isStringObject(val2) && String.prototype.valueOf.call(val1) === String.prototype.valueOf.call(val2);\n }\n if (isBooleanObject(val1)) {\n return isBooleanObject(val2) && Boolean.prototype.valueOf.call(val1) === Boolean.prototype.valueOf.call(val2);\n }\n if (isBigIntObject(val1)) {\n return isBigIntObject(val2) && BigInt.prototype.valueOf.call(val1) === BigInt.prototype.valueOf.call(val2);\n }\n return isSymbolObject(val2) && Symbol.prototype.valueOf.call(val1) === Symbol.prototype.valueOf.call(val2);\n}\n\n// Notes: Type tags are historical [[Class]] properties that can be set by\n// FunctionTemplate::SetClassName() in C++ or Symbol.toStringTag in JS\n// and retrieved using Object.prototype.toString.call(obj) in JS\n// See https://tc39.github.io/ecma262/#sec-object.prototype.tostring\n// for a list of tags pre-defined in the spec.\n// There are some unspecified tags in the wild too (e.g. typed array tags).\n// Since tags can be altered, they only serve fast failures\n//\n// Typed arrays and buffers are checked by comparing the content in their\n// underlying ArrayBuffer. This optimization requires that it's\n// reasonable to interpret their underlying memory in the same way,\n// which is checked by comparing their type tags.\n// (e.g. a Uint8Array and a Uint16Array with the same memory content\n// could still be different because they will be interpreted differently).\n//\n// For strict comparison, objects should have\n// a) The same built-in type tags\n// b) The same prototypes.\n\nfunction innerDeepEqual(val1, val2, strict, memos) {\n // All identical values are equivalent, as determined by ===.\n if (val1 === val2) {\n if (val1 !== 0) return true;\n return strict ? objectIs(val1, val2) : true;\n }\n\n // Check more closely if val1 and val2 are equal.\n if (strict) {\n if (_typeof(val1) !== 'object') {\n return typeof val1 === 'number' && numberIsNaN(val1) && numberIsNaN(val2);\n }\n if (_typeof(val2) !== 'object' || val1 === null || val2 === null) {\n return false;\n }\n if (Object.getPrototypeOf(val1) !== Object.getPrototypeOf(val2)) {\n return false;\n }\n } else {\n if (val1 === null || _typeof(val1) !== 'object') {\n if (val2 === null || _typeof(val2) !== 'object') {\n // eslint-disable-next-line eqeqeq\n return val1 == val2;\n }\n return false;\n }\n if (val2 === null || _typeof(val2) !== 'object') {\n return false;\n }\n }\n var val1Tag = objectToString(val1);\n var val2Tag = objectToString(val2);\n if (val1Tag !== val2Tag) {\n return false;\n }\n if (Array.isArray(val1)) {\n // Check for sparse arrays and general fast path\n if (val1.length !== val2.length) {\n return false;\n }\n var keys1 = getOwnNonIndexProperties(val1, ONLY_ENUMERABLE);\n var keys2 = getOwnNonIndexProperties(val2, ONLY_ENUMERABLE);\n if (keys1.length !== keys2.length) {\n return false;\n }\n return keyCheck(val1, val2, strict, memos, kIsArray, keys1);\n }\n // [browserify] This triggers on certain types in IE (Map/Set) so we don't\n // wan't to early return out of the rest of the checks. However we can check\n // if the second value is one of these values and the first isn't.\n if (val1Tag === '[object Object]') {\n // return keyCheck(val1, val2, strict, memos, kNoIterator);\n if (!isMap(val1) && isMap(val2) || !isSet(val1) && isSet(val2)) {\n return false;\n }\n }\n if (isDate(val1)) {\n if (!isDate(val2) || Date.prototype.getTime.call(val1) !== Date.prototype.getTime.call(val2)) {\n return false;\n }\n } else if (isRegExp(val1)) {\n if (!isRegExp(val2) || !areSimilarRegExps(val1, val2)) {\n return false;\n }\n } else if (isNativeError(val1) || val1 instanceof Error) {\n // Do not compare the stack as it might differ even though the error itself\n // is otherwise identical.\n if (val1.message !== val2.message || val1.name !== val2.name) {\n return false;\n }\n } else if (isArrayBufferView(val1)) {\n if (!strict && (isFloat32Array(val1) || isFloat64Array(val1))) {\n if (!areSimilarFloatArrays(val1, val2)) {\n return false;\n }\n } else if (!areSimilarTypedArrays(val1, val2)) {\n return false;\n }\n // Buffer.compare returns true, so val1.length === val2.length. If they both\n // only contain numeric keys, we don't need to exam further than checking\n // the symbols.\n var _keys = getOwnNonIndexProperties(val1, ONLY_ENUMERABLE);\n var _keys2 = getOwnNonIndexProperties(val2, ONLY_ENUMERABLE);\n if (_keys.length !== _keys2.length) {\n return false;\n }\n return keyCheck(val1, val2, strict, memos, kNoIterator, _keys);\n } else if (isSet(val1)) {\n if (!isSet(val2) || val1.size !== val2.size) {\n return false;\n }\n return keyCheck(val1, val2, strict, memos, kIsSet);\n } else if (isMap(val1)) {\n if (!isMap(val2) || val1.size !== val2.size) {\n return false;\n }\n return keyCheck(val1, val2, strict, memos, kIsMap);\n } else if (isAnyArrayBuffer(val1)) {\n if (!areEqualArrayBuffers(val1, val2)) {\n return false;\n }\n } else if (isBoxedPrimitive(val1) && !isEqualBoxedPrimitive(val1, val2)) {\n return false;\n }\n return keyCheck(val1, val2, strict, memos, kNoIterator);\n}\nfunction getEnumerables(val, keys) {\n return keys.filter(function (k) {\n return propertyIsEnumerable(val, k);\n });\n}\nfunction keyCheck(val1, val2, strict, memos, iterationType, aKeys) {\n // For all remaining Object pairs, including Array, objects and Maps,\n // equivalence is determined by having:\n // a) The same number of owned enumerable properties\n // b) The same set of keys/indexes (although not necessarily the same order)\n // c) Equivalent values for every corresponding key/index\n // d) For Sets and Maps, equal contents\n // Note: this accounts for both named and indexed properties on Arrays.\n if (arguments.length === 5) {\n aKeys = Object.keys(val1);\n var bKeys = Object.keys(val2);\n\n // The pair must have the same number of owned properties.\n if (aKeys.length !== bKeys.length) {\n return false;\n }\n }\n\n // Cheap key test\n var i = 0;\n for (; i < aKeys.length; i++) {\n if (!hasOwnProperty(val2, aKeys[i])) {\n return false;\n }\n }\n if (strict && arguments.length === 5) {\n var symbolKeysA = objectGetOwnPropertySymbols(val1);\n if (symbolKeysA.length !== 0) {\n var count = 0;\n for (i = 0; i < symbolKeysA.length; i++) {\n var key = symbolKeysA[i];\n if (propertyIsEnumerable(val1, key)) {\n if (!propertyIsEnumerable(val2, key)) {\n return false;\n }\n aKeys.push(key);\n count++;\n } else if (propertyIsEnumerable(val2, key)) {\n return false;\n }\n }\n var symbolKeysB = objectGetOwnPropertySymbols(val2);\n if (symbolKeysA.length !== symbolKeysB.length && getEnumerables(val2, symbolKeysB).length !== count) {\n return false;\n }\n } else {\n var _symbolKeysB = objectGetOwnPropertySymbols(val2);\n if (_symbolKeysB.length !== 0 && getEnumerables(val2, _symbolKeysB).length !== 0) {\n return false;\n }\n }\n }\n if (aKeys.length === 0 && (iterationType === kNoIterator || iterationType === kIsArray && val1.length === 0 || val1.size === 0)) {\n return true;\n }\n\n // Use memos to handle cycles.\n if (memos === undefined) {\n memos = {\n val1: new Map(),\n val2: new Map(),\n position: 0\n };\n } else {\n // We prevent up to two map.has(x) calls by directly retrieving the value\n // and checking for undefined. The map can only contain numbers, so it is\n // safe to check for undefined only.\n var val2MemoA = memos.val1.get(val1);\n if (val2MemoA !== undefined) {\n var val2MemoB = memos.val2.get(val2);\n if (val2MemoB !== undefined) {\n return val2MemoA === val2MemoB;\n }\n }\n memos.position++;\n }\n memos.val1.set(val1, memos.position);\n memos.val2.set(val2, memos.position);\n var areEq = objEquiv(val1, val2, strict, aKeys, memos, iterationType);\n memos.val1.delete(val1);\n memos.val2.delete(val2);\n return areEq;\n}\nfunction setHasEqualElement(set, val1, strict, memo) {\n // Go looking.\n var setValues = arrayFromSet(set);\n for (var i = 0; i < setValues.length; i++) {\n var val2 = setValues[i];\n if (innerDeepEqual(val1, val2, strict, memo)) {\n // Remove the matching element to make sure we do not check that again.\n set.delete(val2);\n return true;\n }\n }\n return false;\n}\n\n// See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Equality_comparisons_and_sameness#Loose_equality_using\n// Sadly it is not possible to detect corresponding values properly in case the\n// type is a string, number, bigint or boolean. The reason is that those values\n// can match lots of different string values (e.g., 1n == '+00001').\nfunction findLooseMatchingPrimitives(prim) {\n switch (_typeof(prim)) {\n case 'undefined':\n return null;\n case 'object':\n // Only pass in null as object!\n return undefined;\n case 'symbol':\n return false;\n case 'string':\n prim = +prim;\n // Loose equal entries exist only if the string is possible to convert to\n // a regular number and not NaN.\n // Fall through\n case 'number':\n if (numberIsNaN(prim)) {\n return false;\n }\n }\n return true;\n}\nfunction setMightHaveLoosePrim(a, b, prim) {\n var altValue = findLooseMatchingPrimitives(prim);\n if (altValue != null) return altValue;\n return b.has(altValue) && !a.has(altValue);\n}\nfunction mapMightHaveLoosePrim(a, b, prim, item, memo) {\n var altValue = findLooseMatchingPrimitives(prim);\n if (altValue != null) {\n return altValue;\n }\n var curB = b.get(altValue);\n if (curB === undefined && !b.has(altValue) || !innerDeepEqual(item, curB, false, memo)) {\n return false;\n }\n return !a.has(altValue) && innerDeepEqual(item, curB, false, memo);\n}\nfunction setEquiv(a, b, strict, memo) {\n // This is a lazily initiated Set of entries which have to be compared\n // pairwise.\n var set = null;\n var aValues = arrayFromSet(a);\n for (var i = 0; i < aValues.length; i++) {\n var val = aValues[i];\n // Note: Checking for the objects first improves the performance for object\n // heavy sets but it is a minor slow down for primitives. As they are fast\n // to check this improves the worst case scenario instead.\n if (_typeof(val) === 'object' && val !== null) {\n if (set === null) {\n set = new Set();\n }\n // If the specified value doesn't exist in the second set its an not null\n // object (or non strict only: a not matching primitive) we'll need to go\n // hunting for something thats deep-(strict-)equal to it. To make this\n // O(n log n) complexity we have to copy these values in a new set first.\n set.add(val);\n } else if (!b.has(val)) {\n if (strict) return false;\n\n // Fast path to detect missing string, symbol, undefined and null values.\n if (!setMightHaveLoosePrim(a, b, val)) {\n return false;\n }\n if (set === null) {\n set = new Set();\n }\n set.add(val);\n }\n }\n if (set !== null) {\n var bValues = arrayFromSet(b);\n for (var _i = 0; _i < bValues.length; _i++) {\n var _val = bValues[_i];\n // We have to check if a primitive value is already\n // matching and only if it's not, go hunting for it.\n if (_typeof(_val) === 'object' && _val !== null) {\n if (!setHasEqualElement(set, _val, strict, memo)) return false;\n } else if (!strict && !a.has(_val) && !setHasEqualElement(set, _val, strict, memo)) {\n return false;\n }\n }\n return set.size === 0;\n }\n return true;\n}\nfunction mapHasEqualEntry(set, map, key1, item1, strict, memo) {\n // To be able to handle cases like:\n // Map([[{}, 'a'], [{}, 'b']]) vs Map([[{}, 'b'], [{}, 'a']])\n // ... we need to consider *all* matching keys, not just the first we find.\n var setValues = arrayFromSet(set);\n for (var i = 0; i < setValues.length; i++) {\n var key2 = setValues[i];\n if (innerDeepEqual(key1, key2, strict, memo) && innerDeepEqual(item1, map.get(key2), strict, memo)) {\n set.delete(key2);\n return true;\n }\n }\n return false;\n}\nfunction mapEquiv(a, b, strict, memo) {\n var set = null;\n var aEntries = arrayFromMap(a);\n for (var i = 0; i < aEntries.length; i++) {\n var _aEntries$i = _slicedToArray(aEntries[i], 2),\n key = _aEntries$i[0],\n item1 = _aEntries$i[1];\n if (_typeof(key) === 'object' && key !== null) {\n if (set === null) {\n set = new Set();\n }\n set.add(key);\n } else {\n // By directly retrieving the value we prevent another b.has(key) check in\n // almost all possible cases.\n var item2 = b.get(key);\n if (item2 === undefined && !b.has(key) || !innerDeepEqual(item1, item2, strict, memo)) {\n if (strict) return false;\n // Fast path to detect missing string, symbol, undefined and null\n // keys.\n if (!mapMightHaveLoosePrim(a, b, key, item1, memo)) return false;\n if (set === null) {\n set = new Set();\n }\n set.add(key);\n }\n }\n }\n if (set !== null) {\n var bEntries = arrayFromMap(b);\n for (var _i2 = 0; _i2 < bEntries.length; _i2++) {\n var _bEntries$_i = _slicedToArray(bEntries[_i2], 2),\n _key = _bEntries$_i[0],\n item = _bEntries$_i[1];\n if (_typeof(_key) === 'object' && _key !== null) {\n if (!mapHasEqualEntry(set, a, _key, item, strict, memo)) return false;\n } else if (!strict && (!a.has(_key) || !innerDeepEqual(a.get(_key), item, false, memo)) && !mapHasEqualEntry(set, a, _key, item, false, memo)) {\n return false;\n }\n }\n return set.size === 0;\n }\n return true;\n}\nfunction objEquiv(a, b, strict, keys, memos, iterationType) {\n // Sets and maps don't have their entries accessible via normal object\n // properties.\n var i = 0;\n if (iterationType === kIsSet) {\n if (!setEquiv(a, b, strict, memos)) {\n return false;\n }\n } else if (iterationType === kIsMap) {\n if (!mapEquiv(a, b, strict, memos)) {\n return false;\n }\n } else if (iterationType === kIsArray) {\n for (; i < a.length; i++) {\n if (hasOwnProperty(a, i)) {\n if (!hasOwnProperty(b, i) || !innerDeepEqual(a[i], b[i], strict, memos)) {\n return false;\n }\n } else if (hasOwnProperty(b, i)) {\n return false;\n } else {\n // Array is sparse.\n var keysA = Object.keys(a);\n for (; i < keysA.length; i++) {\n var key = keysA[i];\n if (!hasOwnProperty(b, key) || !innerDeepEqual(a[key], b[key], strict, memos)) {\n return false;\n }\n }\n if (keysA.length !== Object.keys(b).length) {\n return false;\n }\n return true;\n }\n }\n }\n\n // The pair must have equivalent values for every corresponding key.\n // Possibly expensive deep test:\n for (i = 0; i < keys.length; i++) {\n var _key2 = keys[i];\n if (!innerDeepEqual(a[_key2], b[_key2], strict, memos)) {\n return false;\n }\n }\n return true;\n}\nfunction isDeepEqual(val1, val2) {\n return innerDeepEqual(val1, val2, kLoose);\n}\nfunction isDeepStrictEqual(val1, val2) {\n return innerDeepEqual(val1, val2, kStrict);\n}\nmodule.exports = {\n isDeepEqual: isDeepEqual,\n isDeepStrictEqual: isDeepStrictEqual\n};","const chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\n\n// Use a lookup table to find the index.\nconst lookup = typeof Uint8Array === 'undefined' ? [] : new Uint8Array(256);\nfor (let i = 0; i < chars.length; i++) {\n lookup[chars.charCodeAt(i)] = i;\n}\n\nexport const encode = (arraybuffer: ArrayBuffer): string => {\n let bytes = new Uint8Array(arraybuffer),\n i,\n len = bytes.length,\n base64 = '';\n\n for (i = 0; i < len; i += 3) {\n base64 += chars[bytes[i] >> 2];\n base64 += chars[((bytes[i] & 3) << 4) | (bytes[i + 1] >> 4)];\n base64 += chars[((bytes[i + 1] & 15) << 2) | (bytes[i + 2] >> 6)];\n base64 += chars[bytes[i + 2] & 63];\n }\n\n if (len % 3 === 2) {\n base64 = base64.substring(0, base64.length - 1) + '=';\n } else if (len % 3 === 1) {\n base64 = base64.substring(0, base64.length - 2) + '==';\n }\n\n return base64;\n};\n\nexport const decode = (base64: string): ArrayBuffer => {\n let bufferLength = base64.length * 0.75,\n len = base64.length,\n i,\n p = 0,\n encoded1,\n encoded2,\n encoded3,\n encoded4;\n\n if (base64[base64.length - 1] === '=') {\n bufferLength--;\n if (base64[base64.length - 2] === '=') {\n bufferLength--;\n }\n }\n\n const arraybuffer = new ArrayBuffer(bufferLength),\n bytes = new Uint8Array(arraybuffer);\n\n for (i = 0; i < len; i += 4) {\n encoded1 = lookup[base64.charCodeAt(i)];\n encoded2 = lookup[base64.charCodeAt(i + 1)];\n encoded3 = lookup[base64.charCodeAt(i + 2)];\n encoded4 = lookup[base64.charCodeAt(i + 3)];\n\n bytes[p++] = (encoded1 << 2) | (encoded2 >> 4);\n bytes[p++] = ((encoded2 & 15) << 4) | (encoded3 >> 2);\n bytes[p++] = ((encoded3 & 3) << 6) | (encoded4 & 63);\n }\n\n return arraybuffer;\n};\n","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","\"use strict\"\n\n// (a, y, c, l, h) = (array, y[, cmp, lo, hi])\n\nfunction ge(a, y, c, l, h) {\n var i = h + 1;\n while (l <= h) {\n var m = (l + h) >>> 1, x = a[m];\n var p = (c !== undefined) ? c(x, y) : (x - y);\n if (p >= 0) { i = m; h = m - 1 } else { l = m + 1 }\n }\n return i;\n};\n\nfunction gt(a, y, c, l, h) {\n var i = h + 1;\n while (l <= h) {\n var m = (l + h) >>> 1, x = a[m];\n var p = (c !== undefined) ? c(x, y) : (x - y);\n if (p > 0) { i = m; h = m - 1 } else { l = m + 1 }\n }\n return i;\n};\n\nfunction lt(a, y, c, l, h) {\n var i = l - 1;\n while (l <= h) {\n var m = (l + h) >>> 1, x = a[m];\n var p = (c !== undefined) ? c(x, y) : (x - y);\n if (p < 0) { i = m; l = m + 1 } else { h = m - 1 }\n }\n return i;\n};\n\nfunction le(a, y, c, l, h) {\n var i = l - 1;\n while (l <= h) {\n var m = (l + h) >>> 1, x = a[m];\n var p = (c !== undefined) ? c(x, y) : (x - y);\n if (p <= 0) { i = m; l = m + 1 } else { h = m - 1 }\n }\n return i;\n};\n\nfunction eq(a, y, c, l, h) {\n while (l <= h) {\n var m = (l + h) >>> 1, x = a[m];\n var p = (c !== undefined) ? c(x, y) : (x - y);\n if (p === 0) { return m }\n if (p <= 0) { l = m + 1 } else { h = m - 1 }\n }\n return -1;\n};\n\nfunction norm(a, y, c, l, h, f) {\n if (typeof c === 'function') {\n return f(a, y, c, (l === undefined) ? 0 : l | 0, (h === undefined) ? a.length - 1 : h | 0);\n }\n return f(a, y, undefined, (c === undefined) ? 0 : c | 0, (l === undefined) ? a.length - 1 : l | 0);\n}\n\nmodule.exports = {\n ge: function(a, y, c, l, h) { return norm(a, y, c, l, h, ge)},\n gt: function(a, y, c, l, h) { return norm(a, y, c, l, h, gt)},\n lt: function(a, y, c, l, h) { return norm(a, y, c, l, h, lt)},\n le: function(a, y, c, l, h) { return norm(a, y, c, l, h, le)},\n eq: function(a, y, c, l, h) { return norm(a, y, c, l, h, eq)}\n}\n","/**\n * Bit twiddling hacks for JavaScript.\n *\n * Author: Mikola Lysenko\n *\n * Ported from Stanford bit twiddling hack library:\n * http://graphics.stanford.edu/~seander/bithacks.html\n */\n\n\"use strict\"; \"use restrict\";\n\n//Number of bits in an integer\nvar INT_BITS = 32;\n\n//Constants\nexports.INT_BITS = INT_BITS;\nexports.INT_MAX = 0x7fffffff;\nexports.INT_MIN = -1<<(INT_BITS-1);\n\n//Returns -1, 0, +1 depending on sign of x\nexports.sign = function(v) {\n return (v > 0) - (v < 0);\n}\n\n//Computes absolute value of integer\nexports.abs = function(v) {\n var mask = v >> (INT_BITS-1);\n return (v ^ mask) - mask;\n}\n\n//Computes minimum of integers x and y\nexports.min = function(x, y) {\n return y ^ ((x ^ y) & -(x < y));\n}\n\n//Computes maximum of integers x and y\nexports.max = function(x, y) {\n return x ^ ((x ^ y) & -(x < y));\n}\n\n//Checks if a number is a power of two\nexports.isPow2 = function(v) {\n return !(v & (v-1)) && (!!v);\n}\n\n//Computes log base 2 of v\nexports.log2 = function(v) {\n var r, shift;\n r = (v > 0xFFFF) << 4; v >>>= r;\n shift = (v > 0xFF ) << 3; v >>>= shift; r |= shift;\n shift = (v > 0xF ) << 2; v >>>= shift; r |= shift;\n shift = (v > 0x3 ) << 1; v >>>= shift; r |= shift;\n return r | (v >> 1);\n}\n\n//Computes log base 10 of v\nexports.log10 = function(v) {\n return (v >= 1000000000) ? 9 : (v >= 100000000) ? 8 : (v >= 10000000) ? 7 :\n (v >= 1000000) ? 6 : (v >= 100000) ? 5 : (v >= 10000) ? 4 :\n (v >= 1000) ? 3 : (v >= 100) ? 2 : (v >= 10) ? 1 : 0;\n}\n\n//Counts number of bits\nexports.popCount = function(v) {\n v = v - ((v >>> 1) & 0x55555555);\n v = (v & 0x33333333) + ((v >>> 2) & 0x33333333);\n return ((v + (v >>> 4) & 0xF0F0F0F) * 0x1010101) >>> 24;\n}\n\n//Counts number of trailing zeros\nfunction countTrailingZeros(v) {\n var c = 32;\n v &= -v;\n if (v) c--;\n if (v & 0x0000FFFF) c -= 16;\n if (v & 0x00FF00FF) c -= 8;\n if (v & 0x0F0F0F0F) c -= 4;\n if (v & 0x33333333) c -= 2;\n if (v & 0x55555555) c -= 1;\n return c;\n}\nexports.countTrailingZeros = countTrailingZeros;\n\n//Rounds to next power of 2\nexports.nextPow2 = function(v) {\n v += v === 0;\n --v;\n v |= v >>> 1;\n v |= v >>> 2;\n v |= v >>> 4;\n v |= v >>> 8;\n v |= v >>> 16;\n return v + 1;\n}\n\n//Rounds down to previous power of 2\nexports.prevPow2 = function(v) {\n v |= v >>> 1;\n v |= v >>> 2;\n v |= v >>> 4;\n v |= v >>> 8;\n v |= v >>> 16;\n return v - (v>>>1);\n}\n\n//Computes parity of word\nexports.parity = function(v) {\n v ^= v >>> 16;\n v ^= v >>> 8;\n v ^= v >>> 4;\n v &= 0xf;\n return (0x6996 >>> v) & 1;\n}\n\nvar REVERSE_TABLE = new Array(256);\n\n(function(tab) {\n for(var i=0; i<256; ++i) {\n var v = i, r = i, s = 7;\n for (v >>>= 1; v; v >>>= 1) {\n r <<= 1;\n r |= v & 1;\n --s;\n }\n tab[i] = (r << s) & 0xff;\n }\n})(REVERSE_TABLE);\n\n//Reverse bits in a 32 bit word\nexports.reverse = function(v) {\n return (REVERSE_TABLE[ v & 0xff] << 24) |\n (REVERSE_TABLE[(v >>> 8) & 0xff] << 16) |\n (REVERSE_TABLE[(v >>> 16) & 0xff] << 8) |\n REVERSE_TABLE[(v >>> 24) & 0xff];\n}\n\n//Interleave bits of 2 coordinates with 16 bits. Useful for fast quadtree codes\nexports.interleave2 = function(x, y) {\n x &= 0xFFFF;\n x = (x | (x << 8)) & 0x00FF00FF;\n x = (x | (x << 4)) & 0x0F0F0F0F;\n x = (x | (x << 2)) & 0x33333333;\n x = (x | (x << 1)) & 0x55555555;\n\n y &= 0xFFFF;\n y = (y | (y << 8)) & 0x00FF00FF;\n y = (y | (y << 4)) & 0x0F0F0F0F;\n y = (y | (y << 2)) & 0x33333333;\n y = (y | (y << 1)) & 0x55555555;\n\n return x | (y << 1);\n}\n\n//Extracts the nth interleaved component\nexports.deinterleave2 = function(v, n) {\n v = (v >>> n) & 0x55555555;\n v = (v | (v >>> 1)) & 0x33333333;\n v = (v | (v >>> 2)) & 0x0F0F0F0F;\n v = (v | (v >>> 4)) & 0x00FF00FF;\n v = (v | (v >>> 16)) & 0x000FFFF;\n return (v << 16) >> 16;\n}\n\n\n//Interleave bits of 3 coordinates, each with 10 bits. Useful for fast octree codes\nexports.interleave3 = function(x, y, z) {\n x &= 0x3FF;\n x = (x | (x<<16)) & 4278190335;\n x = (x | (x<<8)) & 251719695;\n x = (x | (x<<4)) & 3272356035;\n x = (x | (x<<2)) & 1227133513;\n\n y &= 0x3FF;\n y = (y | (y<<16)) & 4278190335;\n y = (y | (y<<8)) & 251719695;\n y = (y | (y<<4)) & 3272356035;\n y = (y | (y<<2)) & 1227133513;\n x |= (y << 1);\n \n z &= 0x3FF;\n z = (z | (z<<16)) & 4278190335;\n z = (z | (z<<8)) & 251719695;\n z = (z | (z<<4)) & 3272356035;\n z = (z | (z<<2)) & 1227133513;\n \n return x | (z << 2);\n}\n\n//Extracts nth interleaved component of a 3-tuple\nexports.deinterleave3 = function(v, n) {\n v = (v >>> n) & 1227133513;\n v = (v | (v>>>2)) & 3272356035;\n v = (v | (v>>>4)) & 251719695;\n v = (v | (v>>>8)) & 4278190335;\n v = (v | (v>>>16)) & 0x3FF;\n return (v<<22)>>22;\n}\n\n//Computes next combination in colexicographic order (this is mistakenly called nextPermutation on the bit twiddling hacks page)\nexports.nextCombination = function(v) {\n var t = v | (v - 1);\n return (t + 1) | (((~t & -~t) - 1) >>> (countTrailingZeros(v) + 1));\n}\n\n","'use strict'\r\n\r\nmodule.exports = calcSDF\r\n\r\nvar INF = 1e20\r\n\r\nfunction calcSDF(src, options) {\r\n if (!options) options = {}\r\n\r\n var cutoff = options.cutoff == null ? 0.25 : options.cutoff\r\n var radius = options.radius == null ? 8 : options.radius\r\n var channel = options.channel || 0\r\n var w, h, size, data, intData, stride, ctx, canvas, imgData, i, l\r\n\r\n // handle image container\r\n if (ArrayBuffer.isView(src) || Array.isArray(src)) {\r\n if (!options.width || !options.height) throw Error('For raw data width and height should be provided by options')\r\n w = options.width, h = options.height\r\n data = src\r\n\r\n if (!options.stride) stride = Math.floor(src.length / w / h)\r\n else stride = options.stride\r\n }\r\n else {\r\n if (window.HTMLCanvasElement && src instanceof window.HTMLCanvasElement) {\r\n canvas = src\r\n ctx = canvas.getContext('2d')\r\n w = canvas.width, h = canvas.height\r\n imgData = ctx.getImageData(0, 0, w, h)\r\n data = imgData.data\r\n stride = 4\r\n }\r\n else if (window.CanvasRenderingContext2D && src instanceof window.CanvasRenderingContext2D) {\r\n canvas = src.canvas\r\n ctx = src\r\n w = canvas.width, h = canvas.height\r\n imgData = ctx.getImageData(0, 0, w, h)\r\n data = imgData.data\r\n stride = 4\r\n }\r\n else if (window.ImageData && src instanceof window.ImageData) {\r\n imgData = src\r\n w = src.width, h = src.height\r\n data = imgData.data\r\n stride = 4\r\n }\r\n }\r\n\r\n size = Math.max(w, h)\r\n\r\n //convert int data to floats\r\n if ((window.Uint8ClampedArray && data instanceof window.Uint8ClampedArray) || (window.Uint8Array && data instanceof window.Uint8Array)) {\r\n intData = data\r\n data = Array(w*h)\r\n\r\n for (i = 0, l = Math.floor(intData.length / stride); i < l; i++) {\r\n data[i] = intData[i*stride + channel] / 255\r\n }\r\n }\r\n else {\r\n if (stride !== 1) throw Error('Raw data can have only 1 value per pixel')\r\n }\r\n\r\n // temporary arrays for the distance transform\r\n var gridOuter = Array(w * h)\r\n var gridInner = Array(w * h)\r\n var f = Array(size)\r\n var d = Array(size)\r\n var z = Array(size + 1)\r\n var v = Array(size)\r\n\r\n for (i = 0, l = w * h; i < l; i++) {\r\n var a = data[i]\r\n gridOuter[i] = a === 1 ? 0 : a === 0 ? INF : Math.pow(Math.max(0, 0.5 - a), 2)\r\n gridInner[i] = a === 1 ? INF : a === 0 ? 0 : Math.pow(Math.max(0, a - 0.5), 2)\r\n }\r\n\r\n edt(gridOuter, w, h, f, d, v, z)\r\n edt(gridInner, w, h, f, d, v, z)\r\n\r\n var dist = window.Float32Array ? new Float32Array(w * h) : new Array(w * h)\r\n\r\n for (i = 0, l = w*h; i < l; i++) {\r\n dist[i] = Math.min(Math.max(1 - ( (gridOuter[i] - gridInner[i]) / radius + cutoff), 0), 1)\r\n }\r\n\r\n return dist\r\n}\r\n\r\n// 2D Euclidean distance transform by Felzenszwalb & Huttenlocher https://cs.brown.edu/~pff/dt/\r\nfunction edt(data, width, height, f, d, v, z) {\r\n for (var x = 0; x < width; x++) {\r\n for (var y = 0; y < height; y++) {\r\n f[y] = data[y * width + x]\r\n }\r\n edt1d(f, d, v, z, height)\r\n for (y = 0; y < height; y++) {\r\n data[y * width + x] = d[y]\r\n }\r\n }\r\n for (y = 0; y < height; y++) {\r\n for (x = 0; x < width; x++) {\r\n f[x] = data[y * width + x]\r\n }\r\n edt1d(f, d, v, z, width)\r\n for (x = 0; x < width; x++) {\r\n data[y * width + x] = Math.sqrt(d[x])\r\n }\r\n }\r\n}\r\n\r\n// 1D squared distance transform\r\nfunction edt1d(f, d, v, z, n) {\r\n v[0] = 0;\r\n z[0] = -INF\r\n z[1] = +INF\r\n\r\n for (var q = 1, k = 0; q < n; q++) {\r\n var s = ((f[q] + q * q) - (f[v[k]] + v[k] * v[k])) / (2 * q - 2 * v[k])\r\n while (s <= z[k]) {\r\n k--\r\n s = ((f[q] + q * q) - (f[v[k]] + v[k] * v[k])) / (2 * q - 2 * v[k])\r\n }\r\n k++\r\n v[k] = q\r\n z[k] = s\r\n z[k + 1] = +INF\r\n }\r\n\r\n for (q = 0, k = 0; q < n; q++) {\r\n while (z[k + 1] < q) k++\r\n d[q] = (q - v[k]) * (q - v[k]) + f[v[k]]\r\n }\r\n}\r\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nconst base64 = require('base64-js')\nconst ieee754 = require('ieee754')\nconst customInspectSymbol =\n (typeof Symbol === 'function' && typeof Symbol['for'] === 'function') // eslint-disable-line dot-notation\n ? Symbol['for']('nodejs.util.inspect.custom') // eslint-disable-line dot-notation\n : null\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\nconst K_MAX_LENGTH = 0x7fffffff\nexports.kMaxLength = K_MAX_LENGTH\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Print warning and recommend using `buffer` v4.x which has an Object\n * implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * We report that the browser does not support typed arrays if the are not subclassable\n * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n * for __proto__ and has a buggy typed array implementation.\n */\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport()\n\nif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n typeof console.error === 'function') {\n console.error(\n 'This browser lacks typed array (Uint8Array) support which is required by ' +\n '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n )\n}\n\nfunction typedArraySupport () {\n // Can typed array instances can be augmented?\n try {\n const arr = new Uint8Array(1)\n const proto = { foo: function () { return 42 } }\n Object.setPrototypeOf(proto, Uint8Array.prototype)\n Object.setPrototypeOf(arr, proto)\n return arr.foo() === 42\n } catch (e) {\n return false\n }\n}\n\nObject.defineProperty(Buffer.prototype, 'parent', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.buffer\n }\n})\n\nObject.defineProperty(Buffer.prototype, 'offset', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.byteOffset\n }\n})\n\nfunction createBuffer (length) {\n if (length > K_MAX_LENGTH) {\n throw new RangeError('The value \"' + length + '\" is invalid for option \"size\"')\n }\n // Return an augmented `Uint8Array` instance\n const buf = new Uint8Array(length)\n Object.setPrototypeOf(buf, Buffer.prototype)\n return buf\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new TypeError(\n 'The \"string\" argument must be of type string. Received type number'\n )\n }\n return allocUnsafe(arg)\n }\n return from(arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\nfunction from (value, encodingOrOffset, length) {\n if (typeof value === 'string') {\n return fromString(value, encodingOrOffset)\n }\n\n if (ArrayBuffer.isView(value)) {\n return fromArrayView(value)\n }\n\n if (value == null) {\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n }\n\n if (isInstance(value, ArrayBuffer) ||\n (value && isInstance(value.buffer, ArrayBuffer))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof SharedArrayBuffer !== 'undefined' &&\n (isInstance(value, SharedArrayBuffer) ||\n (value && isInstance(value.buffer, SharedArrayBuffer)))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof value === 'number') {\n throw new TypeError(\n 'The \"value\" argument must not be of type number. Received type number'\n )\n }\n\n const valueOf = value.valueOf && value.valueOf()\n if (valueOf != null && valueOf !== value) {\n return Buffer.from(valueOf, encodingOrOffset, length)\n }\n\n const b = fromObject(value)\n if (b) return b\n\n if (typeof Symbol !== 'undefined' && Symbol.toPrimitive != null &&\n typeof value[Symbol.toPrimitive] === 'function') {\n return Buffer.from(value[Symbol.toPrimitive]('string'), encodingOrOffset, length)\n }\n\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(value, encodingOrOffset, length)\n}\n\n// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n// https://github.com/feross/buffer/pull/148\nObject.setPrototypeOf(Buffer.prototype, Uint8Array.prototype)\nObject.setPrototypeOf(Buffer, Uint8Array)\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be of type number')\n } else if (size < 0) {\n throw new RangeError('The value \"' + size + '\" is invalid for option \"size\"')\n }\n}\n\nfunction alloc (size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(size)\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpreted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(size).fill(fill, encoding)\n : createBuffer(size).fill(fill)\n }\n return createBuffer(size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(size, fill, encoding)\n}\n\nfunction allocUnsafe (size) {\n assertSize(size)\n return createBuffer(size < 0 ? 0 : checked(size) | 0)\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(size)\n}\n\nfunction fromString (string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n\n const length = byteLength(string, encoding) | 0\n let buf = createBuffer(length)\n\n const actual = buf.write(string, encoding)\n\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n buf = buf.slice(0, actual)\n }\n\n return buf\n}\n\nfunction fromArrayLike (array) {\n const length = array.length < 0 ? 0 : checked(array.length) | 0\n const buf = createBuffer(length)\n for (let i = 0; i < length; i += 1) {\n buf[i] = array[i] & 255\n }\n return buf\n}\n\nfunction fromArrayView (arrayView) {\n if (isInstance(arrayView, Uint8Array)) {\n const copy = new Uint8Array(arrayView)\n return fromArrayBuffer(copy.buffer, copy.byteOffset, copy.byteLength)\n }\n return fromArrayLike(arrayView)\n}\n\nfunction fromArrayBuffer (array, byteOffset, length) {\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\"offset\" is outside of buffer bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\"length\" is outside of buffer bounds')\n }\n\n let buf\n if (byteOffset === undefined && length === undefined) {\n buf = new Uint8Array(array)\n } else if (length === undefined) {\n buf = new Uint8Array(array, byteOffset)\n } else {\n buf = new Uint8Array(array, byteOffset, length)\n }\n\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(buf, Buffer.prototype)\n\n return buf\n}\n\nfunction fromObject (obj) {\n if (Buffer.isBuffer(obj)) {\n const len = checked(obj.length) | 0\n const buf = createBuffer(len)\n\n if (buf.length === 0) {\n return buf\n }\n\n obj.copy(buf, 0, 0, len)\n return buf\n }\n\n if (obj.length !== undefined) {\n if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n return createBuffer(0)\n }\n return fromArrayLike(obj)\n }\n\n if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n return fromArrayLike(obj.data)\n }\n}\n\nfunction checked (length) {\n // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= K_MAX_LENGTH) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n }\n return length | 0\n}\n\nfunction SlowBuffer (length) {\n if (+length != length) { // eslint-disable-line eqeqeq\n length = 0\n }\n return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n return b != null && b._isBuffer === true &&\n b !== Buffer.prototype // so Buffer.isBuffer(Buffer.prototype) will be false\n}\n\nBuffer.compare = function compare (a, b) {\n if (isInstance(a, Uint8Array)) a = Buffer.from(a, a.offset, a.byteLength)\n if (isInstance(b, Uint8Array)) b = Buffer.from(b, b.offset, b.byteLength)\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError(\n 'The \"buf1\", \"buf2\" arguments must be one of type Buffer or Uint8Array'\n )\n }\n\n if (a === b) return 0\n\n let x = a.length\n let y = b.length\n\n for (let i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i]\n y = b[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true\n default:\n return false\n }\n}\n\nBuffer.concat = function concat (list, length) {\n if (!Array.isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n\n if (list.length === 0) {\n return Buffer.alloc(0)\n }\n\n let i\n if (length === undefined) {\n length = 0\n for (i = 0; i < list.length; ++i) {\n length += list[i].length\n }\n }\n\n const buffer = Buffer.allocUnsafe(length)\n let pos = 0\n for (i = 0; i < list.length; ++i) {\n let buf = list[i]\n if (isInstance(buf, Uint8Array)) {\n if (pos + buf.length > buffer.length) {\n if (!Buffer.isBuffer(buf)) buf = Buffer.from(buf)\n buf.copy(buffer, pos)\n } else {\n Uint8Array.prototype.set.call(\n buffer,\n buf,\n pos\n )\n }\n } else if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n } else {\n buf.copy(buffer, pos)\n }\n pos += buf.length\n }\n return buffer\n}\n\nfunction byteLength (string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length\n }\n if (ArrayBuffer.isView(string) || isInstance(string, ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n throw new TypeError(\n 'The \"string\" argument must be one of type string, Buffer, or ArrayBuffer. ' +\n 'Received type ' + typeof string\n )\n }\n\n const len = string.length\n const mustMatch = (arguments.length > 2 && arguments[2] === true)\n if (!mustMatch && len === 0) return 0\n\n // Use a for loop to avoid recursion\n let loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len\n case 'utf8':\n case 'utf-8':\n return utf8ToBytes(string).length\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2\n case 'hex':\n return len >>> 1\n case 'base64':\n return base64ToBytes(string).length\n default:\n if (loweredCase) {\n return mustMatch ? -1 : utf8ToBytes(string).length // assume utf8\n }\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n let loweredCase = false\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return ''\n }\n\n if (end === undefined || end > this.length) {\n end = this.length\n }\n\n if (end <= 0) {\n return ''\n }\n\n // Force coercion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0\n start >>>= 0\n\n if (end <= start) {\n return ''\n }\n\n if (!encoding) encoding = 'utf8'\n\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end)\n\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end)\n\n case 'ascii':\n return asciiSlice(this, start, end)\n\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end)\n\n case 'base64':\n return base64Slice(this, start, end)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = (encoding + '').toLowerCase()\n loweredCase = true\n }\n }\n}\n\n// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n// reliably in a browserify context because there could be multiple different\n// copies of the 'buffer' package in use. This method works even for Buffer\n// instances that were created from another copy of the `buffer` package.\n// See: https://github.com/feross/buffer/issues/154\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n const i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n const len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (let i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n const len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (let i = 0; i < len; i += 4) {\n swap(this, i, i + 3)\n swap(this, i + 1, i + 2)\n }\n return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n const len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (let i = 0; i < len; i += 8) {\n swap(this, i, i + 7)\n swap(this, i + 1, i + 6)\n swap(this, i + 2, i + 5)\n swap(this, i + 3, i + 4)\n }\n return this\n}\n\nBuffer.prototype.toString = function toString () {\n const length = this.length\n if (length === 0) return ''\n if (arguments.length === 0) return utf8Slice(this, 0, length)\n return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.toLocaleString = Buffer.prototype.toString\n\nBuffer.prototype.equals = function equals (b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n if (this === b) return true\n return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n let str = ''\n const max = exports.INSPECT_MAX_BYTES\n str = this.toString('hex', 0, max).replace(/(.{2})/g, '$1 ').trim()\n if (this.length > max) str += ' ... '\n return ''\n}\nif (customInspectSymbol) {\n Buffer.prototype[customInspectSymbol] = Buffer.prototype.inspect\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (isInstance(target, Uint8Array)) {\n target = Buffer.from(target, target.offset, target.byteLength)\n }\n if (!Buffer.isBuffer(target)) {\n throw new TypeError(\n 'The \"target\" argument must be one of type Buffer or Uint8Array. ' +\n 'Received type ' + (typeof target)\n )\n }\n\n if (start === undefined) {\n start = 0\n }\n if (end === undefined) {\n end = target ? target.length : 0\n }\n if (thisStart === undefined) {\n thisStart = 0\n }\n if (thisEnd === undefined) {\n thisEnd = this.length\n }\n\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index')\n }\n\n if (thisStart >= thisEnd && start >= end) {\n return 0\n }\n if (thisStart >= thisEnd) {\n return -1\n }\n if (start >= end) {\n return 1\n }\n\n start >>>= 0\n end >>>= 0\n thisStart >>>= 0\n thisEnd >>>= 0\n\n if (this === target) return 0\n\n let x = thisEnd - thisStart\n let y = end - start\n const len = Math.min(x, y)\n\n const thisCopy = this.slice(thisStart, thisEnd)\n const targetCopy = target.slice(start, end)\n\n for (let i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i]\n y = targetCopy[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset\n byteOffset = 0\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000\n }\n byteOffset = +byteOffset // Coerce to Number.\n if (numberIsNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : (buffer.length - 1)\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n if (byteOffset >= buffer.length) {\n if (dir) return -1\n else byteOffset = buffer.length - 1\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0\n else return -1\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding)\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n } else if (typeof val === 'number') {\n val = val & 0xFF // Search for a byte value [0-255]\n if (typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n }\n }\n return arrayIndexOf(buffer, [val], byteOffset, encoding, dir)\n }\n\n throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n let indexSize = 1\n let arrLength = arr.length\n let valLength = val.length\n\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase()\n if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1\n }\n indexSize = 2\n arrLength /= 2\n valLength /= 2\n byteOffset /= 2\n }\n }\n\n function read (buf, i) {\n if (indexSize === 1) {\n return buf[i]\n } else {\n return buf.readUInt16BE(i * indexSize)\n }\n }\n\n let i\n if (dir) {\n let foundIndex = -1\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n } else {\n if (foundIndex !== -1) i -= i - foundIndex\n foundIndex = -1\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n for (i = byteOffset; i >= 0; i--) {\n let found = true\n for (let j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false\n break\n }\n }\n if (found) return i\n }\n }\n\n return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n offset = Number(offset) || 0\n const remaining = buf.length - offset\n if (!length) {\n length = remaining\n } else {\n length = Number(length)\n if (length > remaining) {\n length = remaining\n }\n }\n\n const strLen = string.length\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n let i\n for (i = 0; i < length; ++i) {\n const parsed = parseInt(string.substr(i * 2, 2), 16)\n if (numberIsNaN(parsed)) return i\n buf[offset + i] = parsed\n }\n return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8'\n length = this.length\n offset = 0\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset\n length = this.length\n offset = 0\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset >>> 0\n if (isFinite(length)) {\n length = length >>> 0\n if (encoding === undefined) encoding = 'utf8'\n } else {\n encoding = length\n length = undefined\n }\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n const remaining = this.length - offset\n if (length === undefined || length > remaining) length = remaining\n\n if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds')\n }\n\n if (!encoding) encoding = 'utf8'\n\n let loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length)\n\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length)\n\n case 'ascii':\n case 'latin1':\n case 'binary':\n return asciiWrite(this, string, offset, length)\n\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n }\n}\n\nfunction base64Slice (buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf)\n } else {\n return base64.fromByteArray(buf.slice(start, end))\n }\n}\n\nfunction utf8Slice (buf, start, end) {\n end = Math.min(buf.length, end)\n const res = []\n\n let i = start\n while (i < end) {\n const firstByte = buf[i]\n let codePoint = null\n let bytesPerSequence = (firstByte > 0xEF)\n ? 4\n : (firstByte > 0xDF)\n ? 3\n : (firstByte > 0xBF)\n ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n let secondByte, thirdByte, fourthByte, tempCodePoint\n\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte\n }\n break\n case 2:\n secondByte = buf[i + 1]\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint\n }\n }\n break\n case 3:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint\n }\n }\n break\n case 4:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n fourthByte = buf[i + 3]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint\n }\n }\n }\n }\n\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD\n bytesPerSequence = 1\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000\n res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n codePoint = 0xDC00 | codePoint & 0x3FF\n }\n\n res.push(codePoint)\n i += bytesPerSequence\n }\n\n return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nconst MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n const len = codePoints.length\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n let res = ''\n let i = 0\n while (i < len) {\n res += String.fromCharCode.apply(\n String,\n codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n )\n }\n return res\n}\n\nfunction asciiSlice (buf, start, end) {\n let ret = ''\n end = Math.min(buf.length, end)\n\n for (let i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n let ret = ''\n end = Math.min(buf.length, end)\n\n for (let i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n const len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n let out = ''\n for (let i = start; i < end; ++i) {\n out += hexSliceLookupTable[buf[i]]\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n const bytes = buf.slice(start, end)\n let res = ''\n // If bytes.length is odd, the last 8 bits must be ignored (same as node.js)\n for (let i = 0; i < bytes.length - 1; i += 2) {\n res += String.fromCharCode(bytes[i] + (bytes[i + 1] * 256))\n }\n return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n const len = this.length\n start = ~~start\n end = end === undefined ? len : ~~end\n\n if (start < 0) {\n start += len\n if (start < 0) start = 0\n } else if (start > len) {\n start = len\n }\n\n if (end < 0) {\n end += len\n if (end < 0) end = 0\n } else if (end > len) {\n end = len\n }\n\n if (end < start) end = start\n\n const newBuf = this.subarray(start, end)\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(newBuf, Buffer.prototype)\n\n return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUintLE =\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n let val = this[offset]\n let mul = 1\n let i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUintBE =\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length)\n }\n\n let val = this[offset + --byteLength]\n let mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUint8 =\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUint16LE =\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUint16BE =\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUint32LE =\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return ((this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16)) +\n (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUint32BE =\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] * 0x1000000) +\n ((this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n this[offset + 3])\n}\n\nBuffer.prototype.readBigUInt64LE = defineBigIntMethod(function readBigUInt64LE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const lo = first +\n this[++offset] * 2 ** 8 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 24\n\n const hi = this[++offset] +\n this[++offset] * 2 ** 8 +\n this[++offset] * 2 ** 16 +\n last * 2 ** 24\n\n return BigInt(lo) + (BigInt(hi) << BigInt(32))\n})\n\nBuffer.prototype.readBigUInt64BE = defineBigIntMethod(function readBigUInt64BE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const hi = first * 2 ** 24 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n this[++offset]\n\n const lo = this[++offset] * 2 ** 24 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n last\n\n return (BigInt(hi) << BigInt(32)) + BigInt(lo)\n})\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n let val = this[offset]\n let mul = 1\n let i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n let i = byteLength\n let mul = 1\n let val = this[offset + --i]\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n if (!(this[offset] & 0x80)) return (this[offset])\n return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n const val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n const val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16) |\n (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] << 24) |\n (this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n (this[offset + 3])\n}\n\nBuffer.prototype.readBigInt64LE = defineBigIntMethod(function readBigInt64LE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const val = this[offset + 4] +\n this[offset + 5] * 2 ** 8 +\n this[offset + 6] * 2 ** 16 +\n (last << 24) // Overflow\n\n return (BigInt(val) << BigInt(32)) +\n BigInt(first +\n this[++offset] * 2 ** 8 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 24)\n})\n\nBuffer.prototype.readBigInt64BE = defineBigIntMethod(function readBigInt64BE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const val = (first << 24) + // Overflow\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n this[++offset]\n\n return (BigInt(val) << BigInt(32)) +\n BigInt(this[++offset] * 2 ** 24 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n last)\n})\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUintLE =\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n const maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n let mul = 1\n let i = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUintBE =\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n const maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n let i = byteLength - 1\n let mul = 1\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUint8 =\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeUint16LE =\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeUint16BE =\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeUint32LE =\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeUint32BE =\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nfunction wrtBigUInt64LE (buf, value, offset, min, max) {\n checkIntBI(value, min, max, buf, offset, 7)\n\n let lo = Number(value & BigInt(0xffffffff))\n buf[offset++] = lo\n lo = lo >> 8\n buf[offset++] = lo\n lo = lo >> 8\n buf[offset++] = lo\n lo = lo >> 8\n buf[offset++] = lo\n let hi = Number(value >> BigInt(32) & BigInt(0xffffffff))\n buf[offset++] = hi\n hi = hi >> 8\n buf[offset++] = hi\n hi = hi >> 8\n buf[offset++] = hi\n hi = hi >> 8\n buf[offset++] = hi\n return offset\n}\n\nfunction wrtBigUInt64BE (buf, value, offset, min, max) {\n checkIntBI(value, min, max, buf, offset, 7)\n\n let lo = Number(value & BigInt(0xffffffff))\n buf[offset + 7] = lo\n lo = lo >> 8\n buf[offset + 6] = lo\n lo = lo >> 8\n buf[offset + 5] = lo\n lo = lo >> 8\n buf[offset + 4] = lo\n let hi = Number(value >> BigInt(32) & BigInt(0xffffffff))\n buf[offset + 3] = hi\n hi = hi >> 8\n buf[offset + 2] = hi\n hi = hi >> 8\n buf[offset + 1] = hi\n hi = hi >> 8\n buf[offset] = hi\n return offset + 8\n}\n\nBuffer.prototype.writeBigUInt64LE = defineBigIntMethod(function writeBigUInt64LE (value, offset = 0) {\n return wrtBigUInt64LE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'))\n})\n\nBuffer.prototype.writeBigUInt64BE = defineBigIntMethod(function writeBigUInt64BE (value, offset = 0) {\n return wrtBigUInt64BE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'))\n})\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n const limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n let i = 0\n let mul = 1\n let sub = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n const limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n let i = byteLength - 1\n let mul = 1\n let sub = 0\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n if (value < 0) value = 0xff + value + 1\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (value < 0) value = 0xffffffff + value + 1\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeBigInt64LE = defineBigIntMethod(function writeBigInt64LE (value, offset = 0) {\n return wrtBigUInt64LE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'))\n})\n\nBuffer.prototype.writeBigInt64BE = defineBigIntMethod(function writeBigInt64BE (value, offset = 0) {\n return wrtBigUInt64BE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'))\n})\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4)\n return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8)\n return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n if (!Buffer.isBuffer(target)) throw new TypeError('argument should be a Buffer')\n if (!start) start = 0\n if (!end && end !== 0) end = this.length\n if (targetStart >= target.length) targetStart = target.length\n if (!targetStart) targetStart = 0\n if (end > 0 && end < start) end = start\n\n // Copy 0 bytes; we're done\n if (end === start) return 0\n if (target.length === 0 || this.length === 0) return 0\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds')\n }\n if (start < 0 || start >= this.length) throw new RangeError('Index out of range')\n if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n // Are we oob?\n if (end > this.length) end = this.length\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start\n }\n\n const len = end - start\n\n if (this === target && typeof Uint8Array.prototype.copyWithin === 'function') {\n // Use built-in when available, missing from IE11\n this.copyWithin(targetStart, start, end)\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, end),\n targetStart\n )\n }\n\n return len\n}\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start\n start = 0\n end = this.length\n } else if (typeof end === 'string') {\n encoding = end\n end = this.length\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string')\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n if (val.length === 1) {\n const code = val.charCodeAt(0)\n if ((encoding === 'utf8' && code < 128) ||\n encoding === 'latin1') {\n // Fast path: If `val` fits into a single byte, use that numeric value.\n val = code\n }\n }\n } else if (typeof val === 'number') {\n val = val & 255\n } else if (typeof val === 'boolean') {\n val = Number(val)\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index')\n }\n\n if (end <= start) {\n return this\n }\n\n start = start >>> 0\n end = end === undefined ? this.length : end >>> 0\n\n if (!val) val = 0\n\n let i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n const bytes = Buffer.isBuffer(val)\n ? val\n : Buffer.from(val, encoding)\n const len = bytes.length\n if (len === 0) {\n throw new TypeError('The value \"' + val +\n '\" is invalid for argument \"value\"')\n }\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// CUSTOM ERRORS\n// =============\n\n// Simplified versions from Node, changed for Buffer-only usage\nconst errors = {}\nfunction E (sym, getMessage, Base) {\n errors[sym] = class NodeError extends Base {\n constructor () {\n super()\n\n Object.defineProperty(this, 'message', {\n value: getMessage.apply(this, arguments),\n writable: true,\n configurable: true\n })\n\n // Add the error code to the name to include it in the stack trace.\n this.name = `${this.name} [${sym}]`\n // Access the stack to generate the error message including the error code\n // from the name.\n this.stack // eslint-disable-line no-unused-expressions\n // Reset the name to the actual name.\n delete this.name\n }\n\n get code () {\n return sym\n }\n\n set code (value) {\n Object.defineProperty(this, 'code', {\n configurable: true,\n enumerable: true,\n value,\n writable: true\n })\n }\n\n toString () {\n return `${this.name} [${sym}]: ${this.message}`\n }\n }\n}\n\nE('ERR_BUFFER_OUT_OF_BOUNDS',\n function (name) {\n if (name) {\n return `${name} is outside of buffer bounds`\n }\n\n return 'Attempt to access memory outside buffer bounds'\n }, RangeError)\nE('ERR_INVALID_ARG_TYPE',\n function (name, actual) {\n return `The \"${name}\" argument must be of type number. Received type ${typeof actual}`\n }, TypeError)\nE('ERR_OUT_OF_RANGE',\n function (str, range, input) {\n let msg = `The value of \"${str}\" is out of range.`\n let received = input\n if (Number.isInteger(input) && Math.abs(input) > 2 ** 32) {\n received = addNumericalSeparator(String(input))\n } else if (typeof input === 'bigint') {\n received = String(input)\n if (input > BigInt(2) ** BigInt(32) || input < -(BigInt(2) ** BigInt(32))) {\n received = addNumericalSeparator(received)\n }\n received += 'n'\n }\n msg += ` It must be ${range}. Received ${received}`\n return msg\n }, RangeError)\n\nfunction addNumericalSeparator (val) {\n let res = ''\n let i = val.length\n const start = val[0] === '-' ? 1 : 0\n for (; i >= start + 4; i -= 3) {\n res = `_${val.slice(i - 3, i)}${res}`\n }\n return `${val.slice(0, i)}${res}`\n}\n\n// CHECK FUNCTIONS\n// ===============\n\nfunction checkBounds (buf, offset, byteLength) {\n validateNumber(offset, 'offset')\n if (buf[offset] === undefined || buf[offset + byteLength] === undefined) {\n boundsError(offset, buf.length - (byteLength + 1))\n }\n}\n\nfunction checkIntBI (value, min, max, buf, offset, byteLength) {\n if (value > max || value < min) {\n const n = typeof min === 'bigint' ? 'n' : ''\n let range\n if (byteLength > 3) {\n if (min === 0 || min === BigInt(0)) {\n range = `>= 0${n} and < 2${n} ** ${(byteLength + 1) * 8}${n}`\n } else {\n range = `>= -(2${n} ** ${(byteLength + 1) * 8 - 1}${n}) and < 2 ** ` +\n `${(byteLength + 1) * 8 - 1}${n}`\n }\n } else {\n range = `>= ${min}${n} and <= ${max}${n}`\n }\n throw new errors.ERR_OUT_OF_RANGE('value', range, value)\n }\n checkBounds(buf, offset, byteLength)\n}\n\nfunction validateNumber (value, name) {\n if (typeof value !== 'number') {\n throw new errors.ERR_INVALID_ARG_TYPE(name, 'number', value)\n }\n}\n\nfunction boundsError (value, length, type) {\n if (Math.floor(value) !== value) {\n validateNumber(value, type)\n throw new errors.ERR_OUT_OF_RANGE(type || 'offset', 'an integer', value)\n }\n\n if (length < 0) {\n throw new errors.ERR_BUFFER_OUT_OF_BOUNDS()\n }\n\n throw new errors.ERR_OUT_OF_RANGE(type || 'offset',\n `>= ${type ? 1 : 0} and <= ${length}`,\n value)\n}\n\n// HELPER FUNCTIONS\n// ================\n\nconst INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node takes equal signs as end of the Base64 encoding\n str = str.split('=')[0]\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = str.trim().replace(INVALID_BASE64_RE, '')\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return ''\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '='\n }\n return str\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n let codePoint\n const length = string.length\n let leadSurrogate = null\n const bytes = []\n\n for (let i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i)\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n }\n\n // valid lead\n leadSurrogate = codePoint\n\n continue\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n leadSurrogate = codePoint\n continue\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n }\n\n leadSurrogate = null\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break\n bytes.push(codePoint)\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break\n bytes.push(\n codePoint >> 0x6 | 0xC0,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break\n bytes.push(\n codePoint >> 0xC | 0xE0,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break\n bytes.push(\n codePoint >> 0x12 | 0xF0,\n codePoint >> 0xC & 0x3F | 0x80,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else {\n throw new Error('Invalid code point')\n }\n }\n\n return bytes\n}\n\nfunction asciiToBytes (str) {\n const byteArray = []\n for (let i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF)\n }\n return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n let c, hi, lo\n const byteArray = []\n for (let i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break\n\n c = str.charCodeAt(i)\n hi = c >> 8\n lo = c % 256\n byteArray.push(lo)\n byteArray.push(hi)\n }\n\n return byteArray\n}\n\nfunction base64ToBytes (str) {\n return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n let i\n for (i = 0; i < length; ++i) {\n if ((i + offset >= dst.length) || (i >= src.length)) break\n dst[i + offset] = src[i]\n }\n return i\n}\n\n// ArrayBuffer or Uint8Array objects from other contexts (i.e. iframes) do not pass\n// the `instanceof` check but they should be treated as of that type.\n// See: https://github.com/feross/buffer/issues/166\nfunction isInstance (obj, type) {\n return obj instanceof type ||\n (obj != null && obj.constructor != null && obj.constructor.name != null &&\n obj.constructor.name === type.name)\n}\nfunction numberIsNaN (obj) {\n // For IE11 support\n return obj !== obj // eslint-disable-line no-self-compare\n}\n\n// Create lookup table for `toString('hex')`\n// See: https://github.com/feross/buffer/issues/219\nconst hexSliceLookupTable = (function () {\n const alphabet = '0123456789abcdef'\n const table = new Array(256)\n for (let i = 0; i < 16; ++i) {\n const i16 = i * 16\n for (let j = 0; j < 16; ++j) {\n table[i16 + j] = alphabet[i] + alphabet[j]\n }\n }\n return table\n})()\n\n// Return not function with Error if BigInt not supported\nfunction defineBigIntMethod (fn) {\n return typeof BigInt === 'undefined' ? BufferBigIntNotDefined : fn\n}\n\nfunction BufferBigIntNotDefined () {\n throw new Error('BigInt not supported')\n}\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\n\nvar callBind = require('./');\n\nvar $indexOf = callBind(GetIntrinsic('String.prototype.indexOf'));\n\nmodule.exports = function callBoundIntrinsic(name, allowMissing) {\n\tvar intrinsic = GetIntrinsic(name, !!allowMissing);\n\tif (typeof intrinsic === 'function' && $indexOf(name, '.prototype.') > -1) {\n\t\treturn callBind(intrinsic);\n\t}\n\treturn intrinsic;\n};\n","'use strict';\n\nvar bind = require('function-bind');\nvar GetIntrinsic = require('get-intrinsic');\nvar setFunctionLength = require('set-function-length');\n\nvar $TypeError = require('es-errors/type');\nvar $apply = GetIntrinsic('%Function.prototype.apply%');\nvar $call = GetIntrinsic('%Function.prototype.call%');\nvar $reflectApply = GetIntrinsic('%Reflect.apply%', true) || bind.call($call, $apply);\n\nvar $defineProperty = require('es-define-property');\nvar $max = GetIntrinsic('%Math.max%');\n\nmodule.exports = function callBind(originalFunction) {\n\tif (typeof originalFunction !== 'function') {\n\t\tthrow new $TypeError('a function is required');\n\t}\n\tvar func = $reflectApply(bind, $call, arguments);\n\treturn setFunctionLength(\n\t\tfunc,\n\t\t1 + $max(0, originalFunction.length - (arguments.length - 1)),\n\t\ttrue\n\t);\n};\n\nvar applyBind = function applyBind() {\n\treturn $reflectApply(bind, $apply, arguments);\n};\n\nif ($defineProperty) {\n\t$defineProperty(module.exports, 'apply', { value: applyBind });\n} else {\n\tmodule.exports.apply = applyBind;\n}\n","module.exports = clamp\n\nfunction clamp(value, min, max) {\n return min < max\n ? (value < min ? min : value > max ? max : value)\n : (value < max ? max : value > min ? min : value)\n}\n","/** @module color-id */\r\n\r\n'use strict'\r\n\r\nvar clamp = require('clamp')\r\n\r\nmodule.exports = toNumber\r\nmodule.exports.to = toNumber\r\nmodule.exports.from = fromNumber\r\n\r\nfunction toNumber (rgba, normalized) {\r\n\tif(normalized == null) normalized = true\r\n\r\n\tvar r = rgba[0], g = rgba[1], b = rgba[2], a = rgba[3]\r\n\r\n\tif (a == null) a = normalized ? 1 : 255\r\n\r\n\tif (normalized) {\r\n\t\tr *= 255\r\n\t\tg *= 255\r\n\t\tb *= 255\r\n\t\ta *= 255\r\n\t}\r\n\r\n\tr = clamp(r, 0, 255) & 0xFF\r\n\tg = clamp(g, 0, 255) & 0xFF\r\n\tb = clamp(b, 0, 255) & 0xFF\r\n\ta = clamp(a, 0, 255) & 0xFF\r\n\r\n\t//hi-order shift converts to -1, so we can't use <<24\r\n\tvar n = (r * 0x01000000) + (g << 16) + (b << 8) + (a)\r\n\r\n\treturn n\r\n}\r\n\r\nfunction fromNumber (n, normalized) {\r\n\tn = +n\r\n\r\n\tvar r = n >>> 24\r\n\tvar g = (n & 0x00ff0000) >>> 16\r\n\tvar b = (n & 0x0000ff00) >>> 8\r\n\tvar a = n & 0x000000ff\r\n\r\n\tif (normalized === false) return [r, g, b, a]\r\n\r\n\treturn [r/255, g/255, b/255, a/255]\r\n}\r\n","'use strict'\r\n\r\nmodule.exports = {\r\n\t\"aliceblue\": [240, 248, 255],\r\n\t\"antiquewhite\": [250, 235, 215],\r\n\t\"aqua\": [0, 255, 255],\r\n\t\"aquamarine\": [127, 255, 212],\r\n\t\"azure\": [240, 255, 255],\r\n\t\"beige\": [245, 245, 220],\r\n\t\"bisque\": [255, 228, 196],\r\n\t\"black\": [0, 0, 0],\r\n\t\"blanchedalmond\": [255, 235, 205],\r\n\t\"blue\": [0, 0, 255],\r\n\t\"blueviolet\": [138, 43, 226],\r\n\t\"brown\": [165, 42, 42],\r\n\t\"burlywood\": [222, 184, 135],\r\n\t\"cadetblue\": [95, 158, 160],\r\n\t\"chartreuse\": [127, 255, 0],\r\n\t\"chocolate\": [210, 105, 30],\r\n\t\"coral\": [255, 127, 80],\r\n\t\"cornflowerblue\": [100, 149, 237],\r\n\t\"cornsilk\": [255, 248, 220],\r\n\t\"crimson\": [220, 20, 60],\r\n\t\"cyan\": [0, 255, 255],\r\n\t\"darkblue\": [0, 0, 139],\r\n\t\"darkcyan\": [0, 139, 139],\r\n\t\"darkgoldenrod\": [184, 134, 11],\r\n\t\"darkgray\": [169, 169, 169],\r\n\t\"darkgreen\": [0, 100, 0],\r\n\t\"darkgrey\": [169, 169, 169],\r\n\t\"darkkhaki\": [189, 183, 107],\r\n\t\"darkmagenta\": [139, 0, 139],\r\n\t\"darkolivegreen\": [85, 107, 47],\r\n\t\"darkorange\": [255, 140, 0],\r\n\t\"darkorchid\": [153, 50, 204],\r\n\t\"darkred\": [139, 0, 0],\r\n\t\"darksalmon\": [233, 150, 122],\r\n\t\"darkseagreen\": [143, 188, 143],\r\n\t\"darkslateblue\": [72, 61, 139],\r\n\t\"darkslategray\": [47, 79, 79],\r\n\t\"darkslategrey\": [47, 79, 79],\r\n\t\"darkturquoise\": [0, 206, 209],\r\n\t\"darkviolet\": [148, 0, 211],\r\n\t\"deeppink\": [255, 20, 147],\r\n\t\"deepskyblue\": [0, 191, 255],\r\n\t\"dimgray\": [105, 105, 105],\r\n\t\"dimgrey\": [105, 105, 105],\r\n\t\"dodgerblue\": [30, 144, 255],\r\n\t\"firebrick\": [178, 34, 34],\r\n\t\"floralwhite\": [255, 250, 240],\r\n\t\"forestgreen\": [34, 139, 34],\r\n\t\"fuchsia\": [255, 0, 255],\r\n\t\"gainsboro\": [220, 220, 220],\r\n\t\"ghostwhite\": [248, 248, 255],\r\n\t\"gold\": [255, 215, 0],\r\n\t\"goldenrod\": [218, 165, 32],\r\n\t\"gray\": [128, 128, 128],\r\n\t\"green\": [0, 128, 0],\r\n\t\"greenyellow\": [173, 255, 47],\r\n\t\"grey\": [128, 128, 128],\r\n\t\"honeydew\": [240, 255, 240],\r\n\t\"hotpink\": [255, 105, 180],\r\n\t\"indianred\": [205, 92, 92],\r\n\t\"indigo\": [75, 0, 130],\r\n\t\"ivory\": [255, 255, 240],\r\n\t\"khaki\": [240, 230, 140],\r\n\t\"lavender\": [230, 230, 250],\r\n\t\"lavenderblush\": [255, 240, 245],\r\n\t\"lawngreen\": [124, 252, 0],\r\n\t\"lemonchiffon\": [255, 250, 205],\r\n\t\"lightblue\": [173, 216, 230],\r\n\t\"lightcoral\": [240, 128, 128],\r\n\t\"lightcyan\": [224, 255, 255],\r\n\t\"lightgoldenrodyellow\": [250, 250, 210],\r\n\t\"lightgray\": [211, 211, 211],\r\n\t\"lightgreen\": [144, 238, 144],\r\n\t\"lightgrey\": [211, 211, 211],\r\n\t\"lightpink\": [255, 182, 193],\r\n\t\"lightsalmon\": [255, 160, 122],\r\n\t\"lightseagreen\": [32, 178, 170],\r\n\t\"lightskyblue\": [135, 206, 250],\r\n\t\"lightslategray\": [119, 136, 153],\r\n\t\"lightslategrey\": [119, 136, 153],\r\n\t\"lightsteelblue\": [176, 196, 222],\r\n\t\"lightyellow\": [255, 255, 224],\r\n\t\"lime\": [0, 255, 0],\r\n\t\"limegreen\": [50, 205, 50],\r\n\t\"linen\": [250, 240, 230],\r\n\t\"magenta\": [255, 0, 255],\r\n\t\"maroon\": [128, 0, 0],\r\n\t\"mediumaquamarine\": [102, 205, 170],\r\n\t\"mediumblue\": [0, 0, 205],\r\n\t\"mediumorchid\": [186, 85, 211],\r\n\t\"mediumpurple\": [147, 112, 219],\r\n\t\"mediumseagreen\": [60, 179, 113],\r\n\t\"mediumslateblue\": [123, 104, 238],\r\n\t\"mediumspringgreen\": [0, 250, 154],\r\n\t\"mediumturquoise\": [72, 209, 204],\r\n\t\"mediumvioletred\": [199, 21, 133],\r\n\t\"midnightblue\": [25, 25, 112],\r\n\t\"mintcream\": [245, 255, 250],\r\n\t\"mistyrose\": [255, 228, 225],\r\n\t\"moccasin\": [255, 228, 181],\r\n\t\"navajowhite\": [255, 222, 173],\r\n\t\"navy\": [0, 0, 128],\r\n\t\"oldlace\": [253, 245, 230],\r\n\t\"olive\": [128, 128, 0],\r\n\t\"olivedrab\": [107, 142, 35],\r\n\t\"orange\": [255, 165, 0],\r\n\t\"orangered\": [255, 69, 0],\r\n\t\"orchid\": [218, 112, 214],\r\n\t\"palegoldenrod\": [238, 232, 170],\r\n\t\"palegreen\": [152, 251, 152],\r\n\t\"paleturquoise\": [175, 238, 238],\r\n\t\"palevioletred\": [219, 112, 147],\r\n\t\"papayawhip\": [255, 239, 213],\r\n\t\"peachpuff\": [255, 218, 185],\r\n\t\"peru\": [205, 133, 63],\r\n\t\"pink\": [255, 192, 203],\r\n\t\"plum\": [221, 160, 221],\r\n\t\"powderblue\": [176, 224, 230],\r\n\t\"purple\": [128, 0, 128],\r\n\t\"rebeccapurple\": [102, 51, 153],\r\n\t\"red\": [255, 0, 0],\r\n\t\"rosybrown\": [188, 143, 143],\r\n\t\"royalblue\": [65, 105, 225],\r\n\t\"saddlebrown\": [139, 69, 19],\r\n\t\"salmon\": [250, 128, 114],\r\n\t\"sandybrown\": [244, 164, 96],\r\n\t\"seagreen\": [46, 139, 87],\r\n\t\"seashell\": [255, 245, 238],\r\n\t\"sienna\": [160, 82, 45],\r\n\t\"silver\": [192, 192, 192],\r\n\t\"skyblue\": [135, 206, 235],\r\n\t\"slateblue\": [106, 90, 205],\r\n\t\"slategray\": [112, 128, 144],\r\n\t\"slategrey\": [112, 128, 144],\r\n\t\"snow\": [255, 250, 250],\r\n\t\"springgreen\": [0, 255, 127],\r\n\t\"steelblue\": [70, 130, 180],\r\n\t\"tan\": [210, 180, 140],\r\n\t\"teal\": [0, 128, 128],\r\n\t\"thistle\": [216, 191, 216],\r\n\t\"tomato\": [255, 99, 71],\r\n\t\"turquoise\": [64, 224, 208],\r\n\t\"violet\": [238, 130, 238],\r\n\t\"wheat\": [245, 222, 179],\r\n\t\"white\": [255, 255, 255],\r\n\t\"whitesmoke\": [245, 245, 245],\r\n\t\"yellow\": [255, 255, 0],\r\n\t\"yellowgreen\": [154, 205, 50]\r\n};\r\n","/** @module color-normalize */\r\n\r\n'use strict'\r\n\r\nvar rgba = require('color-rgba')\r\nvar dtype = require('dtype')\r\n\r\nmodule.exports = function normalize (color, type) {\r\n\tif (type === 'float' || !type) type = 'array'\r\n\tif (type === 'uint') type = 'uint8'\r\n\tif (type === 'uint_clamped') type = 'uint8_clamped'\r\n\tvar Ctor = dtype(type)\r\n\tvar output = new Ctor(4)\r\n\r\n\tvar normalize = type !== 'uint8' && type !== 'uint8_clamped'\r\n\r\n\t// attempt to parse non-array arguments\r\n\tif (!color.length || typeof color === 'string') {\r\n\t\tcolor = rgba(color)\r\n\t\tcolor[0] /= 255\r\n\t\tcolor[1] /= 255\r\n\t\tcolor[2] /= 255\r\n\t}\r\n\r\n\t// 0, 1 are possible contradictory values for Arrays:\r\n\t// [1,1,1] input gives [1,1,1] output instead of [1/255,1/255,1/255], which may be collision if input is meant to be uint.\r\n\t// converting [1,1,1] to [1/255,1/255,1/255] in case of float input gives larger mistake since [1,1,1] float is frequent edge value, whereas [0,1,1], [1,1,1] etc. uint inputs are relatively rare\r\n\tif (isInt(color)) {\r\n\t\toutput[0] = color[0]\r\n\t\toutput[1] = color[1]\r\n\t\toutput[2] = color[2]\r\n\t\toutput[3] = color[3] != null ? color[3] : 255\r\n\r\n\t\tif (normalize) {\r\n\t\t\toutput[0] /= 255\r\n\t\t\toutput[1] /= 255\r\n\t\t\toutput[2] /= 255\r\n\t\t\toutput[3] /= 255\r\n\t\t}\r\n\r\n\t\treturn output\r\n\t}\r\n\r\n\tif (!normalize) {\r\n\t\toutput[0] = Math.min(Math.max(Math.floor(color[0] * 255), 0), 255)\r\n\t\toutput[1] = Math.min(Math.max(Math.floor(color[1] * 255), 0), 255)\r\n\t\toutput[2] = Math.min(Math.max(Math.floor(color[2] * 255), 0), 255)\r\n\t\toutput[3] = color[3] == null ? 255 : Math.min(Math.max(Math.floor(color[3] * 255), 0), 255)\r\n\t} else {\r\n\t\toutput[0] = color[0]\r\n\t\toutput[1] = color[1]\r\n\t\toutput[2] = color[2]\r\n\t\toutput[3] = color[3] != null ? color[3] : 1\r\n\t}\r\n\r\n\treturn output\r\n}\r\n\r\nfunction isInt(color) {\r\n\tif (color instanceof Uint8Array || color instanceof Uint8ClampedArray) return true\r\n\r\n\tif (Array.isArray(color) &&\r\n\t\t(color[0] > 1 || color[0] === 0) &&\r\n\t\t(color[1] > 1 || color[1] === 0) &&\r\n\t\t(color[2] > 1 || color[2] === 0) &&\r\n\t\t(!color[3] || color[3] > 1)\r\n\t) return true\r\n\r\n\treturn false\r\n}\r\n","/**\n * @module color-parse\n */\n\n'use strict'\n\nvar names = require('color-name')\n\nmodule.exports = parse\n\n/**\n * Base hues\n * http://dev.w3.org/csswg/css-color/#typedef-named-hue\n */\n//FIXME: use external hue detector\nvar baseHues = {\n\tred: 0,\n\torange: 60,\n\tyellow: 120,\n\tgreen: 180,\n\tblue: 240,\n\tpurple: 300\n}\n\n/**\n * Parse color from the string passed\n *\n * @return {Object} A space indicator `space`, an array `values` and `alpha`\n */\nfunction parse(cstr) {\n\tvar m, parts = [], alpha = 1, space\n\n\tif (typeof cstr === 'string') {\n\t\tcstr = cstr.toLowerCase();\n\n\t\t//keyword\n\t\tif (names[cstr]) {\n\t\t\tparts = names[cstr].slice()\n\t\t\tspace = 'rgb'\n\t\t}\n\n\t\t//reserved words\n\t\telse if (cstr === 'transparent') {\n\t\t\talpha = 0\n\t\t\tspace = 'rgb'\n\t\t\tparts = [0, 0, 0]\n\t\t}\n\n\t\t//hex\n\t\telse if (/^#[A-Fa-f0-9]+$/.test(cstr)) {\n\t\t\tvar base = cstr.slice(1)\n\t\t\tvar size = base.length\n\t\t\tvar isShort = size <= 4\n\t\t\talpha = 1\n\n\t\t\tif (isShort) {\n\t\t\t\tparts = [\n\t\t\t\t\tparseInt(base[0] + base[0], 16),\n\t\t\t\t\tparseInt(base[1] + base[1], 16),\n\t\t\t\t\tparseInt(base[2] + base[2], 16)\n\t\t\t\t]\n\t\t\t\tif (size === 4) {\n\t\t\t\t\talpha = parseInt(base[3] + base[3], 16) / 255\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tparts = [\n\t\t\t\t\tparseInt(base[0] + base[1], 16),\n\t\t\t\t\tparseInt(base[2] + base[3], 16),\n\t\t\t\t\tparseInt(base[4] + base[5], 16)\n\t\t\t\t]\n\t\t\t\tif (size === 8) {\n\t\t\t\t\talpha = parseInt(base[6] + base[7], 16) / 255\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (!parts[0]) parts[0] = 0\n\t\t\tif (!parts[1]) parts[1] = 0\n\t\t\tif (!parts[2]) parts[2] = 0\n\n\t\t\tspace = 'rgb'\n\t\t}\n\n\t\t//color space\n\t\telse if (m = /^((?:rgb|hs[lvb]|hwb|cmyk?|xy[zy]|gray|lab|lchu?v?|[ly]uv|lms)a?)\\s*\\(([^\\)]*)\\)/.exec(cstr)) {\n\t\t\tvar name = m[1]\n\t\t\tvar isRGB = name === 'rgb'\n\t\t\tvar base = name.replace(/a$/, '')\n\t\t\tspace = base\n\t\t\tvar size = base === 'cmyk' ? 4 : base === 'gray' ? 1 : 3\n\t\t\tparts = m[2].trim()\n\t\t\t\t.split(/\\s*[,\\/]\\s*|\\s+/)\n\t\t\t\t.map(function (x, i) {\n\t\t\t\t\t//\n\t\t\t\t\tif (/%$/.test(x)) {\n\t\t\t\t\t\t//alpha\n\t\t\t\t\t\tif (i === size) return parseFloat(x) / 100\n\t\t\t\t\t\t//rgb\n\t\t\t\t\t\tif (base === 'rgb') return parseFloat(x) * 255 / 100\n\t\t\t\t\t\treturn parseFloat(x)\n\t\t\t\t\t}\n\t\t\t\t\t//hue\n\t\t\t\t\telse if (base[i] === 'h') {\n\t\t\t\t\t\t//\n\t\t\t\t\t\tif (/deg$/.test(x)) {\n\t\t\t\t\t\t\treturn parseFloat(x)\n\t\t\t\t\t\t}\n\t\t\t\t\t\t//\n\t\t\t\t\t\telse if (baseHues[x] !== undefined) {\n\t\t\t\t\t\t\treturn baseHues[x]\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\treturn parseFloat(x)\n\t\t\t\t})\n\n\t\t\tif (name === base) parts.push(1)\n\t\t\talpha = (isRGB) ? 1 : (parts[size] === undefined) ? 1 : parts[size]\n\t\t\tparts = parts.slice(0, size)\n\t\t}\n\n\t\t//named channels case\n\t\telse if (cstr.length > 10 && /[0-9](?:\\s|\\/)/.test(cstr)) {\n\t\t\tparts = cstr.match(/([0-9]+)/g).map(function (value) {\n\t\t\t\treturn parseFloat(value)\n\t\t\t})\n\n\t\t\tspace = cstr.match(/([a-z])/ig).join('').toLowerCase()\n\t\t}\n\t}\n\n\t//numeric case\n\telse if (!isNaN(cstr)) {\n\t\tspace = 'rgb'\n\t\tparts = [cstr >>> 16, (cstr & 0x00ff00) >>> 8, cstr & 0x0000ff]\n\t}\n\n\t//array-like\n\telse if (Array.isArray(cstr) || cstr.length) {\n\t\tparts = [cstr[0], cstr[1], cstr[2]]\n\t\tspace = 'rgb'\n\t\talpha = cstr.length === 4 ? cstr[3] : 1\n\t}\n\n\t//object case - detects css cases of rgb and hsl\n\telse if (cstr instanceof Object) {\n\t\tif (cstr.r != null || cstr.red != null || cstr.R != null) {\n\t\t\tspace = 'rgb'\n\t\t\tparts = [\n\t\t\t\tcstr.r || cstr.red || cstr.R || 0,\n\t\t\t\tcstr.g || cstr.green || cstr.G || 0,\n\t\t\t\tcstr.b || cstr.blue || cstr.B || 0\n\t\t\t]\n\t\t}\n\t\telse {\n\t\t\tspace = 'hsl'\n\t\t\tparts = [\n\t\t\t\tcstr.h || cstr.hue || cstr.H || 0,\n\t\t\t\tcstr.s || cstr.saturation || cstr.S || 0,\n\t\t\t\tcstr.l || cstr.lightness || cstr.L || cstr.b || cstr.brightness\n\t\t\t]\n\t\t}\n\n\t\talpha = cstr.a || cstr.alpha || cstr.opacity || 1\n\n\t\tif (cstr.opacity != null) alpha /= 100\n\t}\n\n\treturn {\n\t\tspace: space,\n\t\tvalues: parts,\n\t\talpha: alpha\n\t}\n}\n","/** @module color-rgba */\r\n\r\n'use strict'\r\n\r\nvar parse = require('color-parse')\r\n\r\nmodule.exports = function rgba (color) {\r\n\t// template literals\r\n\tif (Array.isArray(color) && color.raw) color = String.raw.apply(null, arguments)\r\n\r\n\tvar values, i, l\r\n\r\n\t//attempt to parse non-array arguments\r\n\tvar parsed = parse(color)\r\n\r\n\tif (!parsed.space) return []\r\n\r\n\tvar min = [0,0,0], max = parsed.space[0] === 'h' ? [360,100,100] : [255,255,255]\r\n\r\n\tvalues = Array(3)\r\n\tvalues[0] = Math.min(Math.max(parsed.values[0], min[0]), max[0])\r\n\tvalues[1] = Math.min(Math.max(parsed.values[1], min[1]), max[1])\r\n\tvalues[2] = Math.min(Math.max(parsed.values[2], min[2]), max[2])\r\n\r\n\tif (parsed.space[0] === 'h') values = hsl2rgb(values)\r\n\r\n\tvalues.push(Math.min(Math.max(parsed.alpha, 0), 1))\r\n\r\n\treturn values\r\n}\r\n\r\n\r\n// excerpt from color-space/hsl\r\nfunction hsl2rgb(hsl) {\r\n\tvar h = hsl[0]/360, s = hsl[1]/100, l = hsl[2]/100, t1, t2, t3, rgb, val, i=0;\r\n\r\n\tif (s === 0) return val = l * 255, [val, val, val];\r\n\r\n\tt2 = l < 0.5 ? l * (1 + s) : l + s - l * s;\r\n\tt1 = 2 * l - t2;\r\n\r\n\trgb = [0, 0, 0];\r\n\tfor (;i<3;) {\r\n\t\tt3 = h + 1 / 3 * - (i - 1);\r\n\t\tt3 < 0 ? t3++ : t3 > 1 && t3--;\r\n\t\tval = 6 * t3 < 1 ? t1 + (t2 - t1) * 6 * t3 :\r\n\t\t2 * t3 < 1 ? t2 :\r\n\t\t3 * t3 < 2 ? t1 + (t2 - t1) * (2 / 3 - t3) * 6 :\r\n\t\tt1;\r\n\t\trgb[i++] = val * 255;\r\n\t}\r\n\r\n\treturn rgb;\r\n}\r\n","module.exports={\n\t\"jet\":[{\"index\":0,\"rgb\":[0,0,131]},{\"index\":0.125,\"rgb\":[0,60,170]},{\"index\":0.375,\"rgb\":[5,255,255]},{\"index\":0.625,\"rgb\":[255,255,0]},{\"index\":0.875,\"rgb\":[250,0,0]},{\"index\":1,\"rgb\":[128,0,0]}],\n\n\t\"hsv\":[{\"index\":0,\"rgb\":[255,0,0]},{\"index\":0.169,\"rgb\":[253,255,2]},{\"index\":0.173,\"rgb\":[247,255,2]},{\"index\":0.337,\"rgb\":[0,252,4]},{\"index\":0.341,\"rgb\":[0,252,10]},{\"index\":0.506,\"rgb\":[1,249,255]},{\"index\":0.671,\"rgb\":[2,0,253]},{\"index\":0.675,\"rgb\":[8,0,253]},{\"index\":0.839,\"rgb\":[255,0,251]},{\"index\":0.843,\"rgb\":[255,0,245]},{\"index\":1,\"rgb\":[255,0,6]}],\n\n\t\"hot\":[{\"index\":0,\"rgb\":[0,0,0]},{\"index\":0.3,\"rgb\":[230,0,0]},{\"index\":0.6,\"rgb\":[255,210,0]},{\"index\":1,\"rgb\":[255,255,255]}],\n\n\t\"spring\":[{\"index\":0,\"rgb\":[255,0,255]},{\"index\":1,\"rgb\":[255,255,0]}],\n\n\t\"summer\":[{\"index\":0,\"rgb\":[0,128,102]},{\"index\":1,\"rgb\":[255,255,102]}],\n\n\t\"autumn\":[{\"index\":0,\"rgb\":[255,0,0]},{\"index\":1,\"rgb\":[255,255,0]}],\n\n\t\"winter\":[{\"index\":0,\"rgb\":[0,0,255]},{\"index\":1,\"rgb\":[0,255,128]}],\n\n\t\"bone\":[{\"index\":0,\"rgb\":[0,0,0]},{\"index\":0.376,\"rgb\":[84,84,116]},{\"index\":0.753,\"rgb\":[169,200,200]},{\"index\":1,\"rgb\":[255,255,255]}],\n\n\t\"copper\":[{\"index\":0,\"rgb\":[0,0,0]},{\"index\":0.804,\"rgb\":[255,160,102]},{\"index\":1,\"rgb\":[255,199,127]}],\n\n\t\"greys\":[{\"index\":0,\"rgb\":[0,0,0]},{\"index\":1,\"rgb\":[255,255,255]}],\n\n\t\"yignbu\":[{\"index\":0,\"rgb\":[8,29,88]},{\"index\":0.125,\"rgb\":[37,52,148]},{\"index\":0.25,\"rgb\":[34,94,168]},{\"index\":0.375,\"rgb\":[29,145,192]},{\"index\":0.5,\"rgb\":[65,182,196]},{\"index\":0.625,\"rgb\":[127,205,187]},{\"index\":0.75,\"rgb\":[199,233,180]},{\"index\":0.875,\"rgb\":[237,248,217]},{\"index\":1,\"rgb\":[255,255,217]}],\n\n\t\"greens\":[{\"index\":0,\"rgb\":[0,68,27]},{\"index\":0.125,\"rgb\":[0,109,44]},{\"index\":0.25,\"rgb\":[35,139,69]},{\"index\":0.375,\"rgb\":[65,171,93]},{\"index\":0.5,\"rgb\":[116,196,118]},{\"index\":0.625,\"rgb\":[161,217,155]},{\"index\":0.75,\"rgb\":[199,233,192]},{\"index\":0.875,\"rgb\":[229,245,224]},{\"index\":1,\"rgb\":[247,252,245]}],\n\n\t\"yiorrd\":[{\"index\":0,\"rgb\":[128,0,38]},{\"index\":0.125,\"rgb\":[189,0,38]},{\"index\":0.25,\"rgb\":[227,26,28]},{\"index\":0.375,\"rgb\":[252,78,42]},{\"index\":0.5,\"rgb\":[253,141,60]},{\"index\":0.625,\"rgb\":[254,178,76]},{\"index\":0.75,\"rgb\":[254,217,118]},{\"index\":0.875,\"rgb\":[255,237,160]},{\"index\":1,\"rgb\":[255,255,204]}],\n\n\t\"bluered\":[{\"index\":0,\"rgb\":[0,0,255]},{\"index\":1,\"rgb\":[255,0,0]}],\n\n\t\"rdbu\":[{\"index\":0,\"rgb\":[5,10,172]},{\"index\":0.35,\"rgb\":[106,137,247]},{\"index\":0.5,\"rgb\":[190,190,190]},{\"index\":0.6,\"rgb\":[220,170,132]},{\"index\":0.7,\"rgb\":[230,145,90]},{\"index\":1,\"rgb\":[178,10,28]}],\n\n\t\"picnic\":[{\"index\":0,\"rgb\":[0,0,255]},{\"index\":0.1,\"rgb\":[51,153,255]},{\"index\":0.2,\"rgb\":[102,204,255]},{\"index\":0.3,\"rgb\":[153,204,255]},{\"index\":0.4,\"rgb\":[204,204,255]},{\"index\":0.5,\"rgb\":[255,255,255]},{\"index\":0.6,\"rgb\":[255,204,255]},{\"index\":0.7,\"rgb\":[255,153,255]},{\"index\":0.8,\"rgb\":[255,102,204]},{\"index\":0.9,\"rgb\":[255,102,102]},{\"index\":1,\"rgb\":[255,0,0]}],\n\n\t\"rainbow\":[{\"index\":0,\"rgb\":[150,0,90]},{\"index\":0.125,\"rgb\":[0,0,200]},{\"index\":0.25,\"rgb\":[0,25,255]},{\"index\":0.375,\"rgb\":[0,152,255]},{\"index\":0.5,\"rgb\":[44,255,150]},{\"index\":0.625,\"rgb\":[151,255,0]},{\"index\":0.75,\"rgb\":[255,234,0]},{\"index\":0.875,\"rgb\":[255,111,0]},{\"index\":1,\"rgb\":[255,0,0]}],\n\n\t\"portland\":[{\"index\":0,\"rgb\":[12,51,131]},{\"index\":0.25,\"rgb\":[10,136,186]},{\"index\":0.5,\"rgb\":[242,211,56]},{\"index\":0.75,\"rgb\":[242,143,56]},{\"index\":1,\"rgb\":[217,30,30]}],\n\n\t\"blackbody\":[{\"index\":0,\"rgb\":[0,0,0]},{\"index\":0.2,\"rgb\":[230,0,0]},{\"index\":0.4,\"rgb\":[230,210,0]},{\"index\":0.7,\"rgb\":[255,255,255]},{\"index\":1,\"rgb\":[160,200,255]}],\n\n\t\"earth\":[{\"index\":0,\"rgb\":[0,0,130]},{\"index\":0.1,\"rgb\":[0,180,180]},{\"index\":0.2,\"rgb\":[40,210,40]},{\"index\":0.4,\"rgb\":[230,230,50]},{\"index\":0.6,\"rgb\":[120,70,20]},{\"index\":1,\"rgb\":[255,255,255]}],\n\n\t\"electric\":[{\"index\":0,\"rgb\":[0,0,0]},{\"index\":0.15,\"rgb\":[30,0,100]},{\"index\":0.4,\"rgb\":[120,0,100]},{\"index\":0.6,\"rgb\":[160,90,0]},{\"index\":0.8,\"rgb\":[230,200,0]},{\"index\":1,\"rgb\":[255,250,220]}],\n\n\t\"alpha\": [{\"index\":0, \"rgb\": [255,255,255,0]},{\"index\":1, \"rgb\": [255,255,255,1]}],\n\n\t\"viridis\": [{\"index\":0,\"rgb\":[68,1,84]},{\"index\":0.13,\"rgb\":[71,44,122]},{\"index\":0.25,\"rgb\":[59,81,139]},{\"index\":0.38,\"rgb\":[44,113,142]},{\"index\":0.5,\"rgb\":[33,144,141]},{\"index\":0.63,\"rgb\":[39,173,129]},{\"index\":0.75,\"rgb\":[92,200,99]},{\"index\":0.88,\"rgb\":[170,220,50]},{\"index\":1,\"rgb\":[253,231,37]}],\n\n\t\"inferno\": [{\"index\":0,\"rgb\":[0,0,4]},{\"index\":0.13,\"rgb\":[31,12,72]},{\"index\":0.25,\"rgb\":[85,15,109]},{\"index\":0.38,\"rgb\":[136,34,106]},{\"index\":0.5,\"rgb\":[186,54,85]},{\"index\":0.63,\"rgb\":[227,89,51]},{\"index\":0.75,\"rgb\":[249,140,10]},{\"index\":0.88,\"rgb\":[249,201,50]},{\"index\":1,\"rgb\":[252,255,164]}],\n\n\t\"magma\": [{\"index\":0,\"rgb\":[0,0,4]},{\"index\":0.13,\"rgb\":[28,16,68]},{\"index\":0.25,\"rgb\":[79,18,123]},{\"index\":0.38,\"rgb\":[129,37,129]},{\"index\":0.5,\"rgb\":[181,54,122]},{\"index\":0.63,\"rgb\":[229,80,100]},{\"index\":0.75,\"rgb\":[251,135,97]},{\"index\":0.88,\"rgb\":[254,194,135]},{\"index\":1,\"rgb\":[252,253,191]}],\n\n\t\"plasma\": [{\"index\":0,\"rgb\":[13,8,135]},{\"index\":0.13,\"rgb\":[75,3,161]},{\"index\":0.25,\"rgb\":[125,3,168]},{\"index\":0.38,\"rgb\":[168,34,150]},{\"index\":0.5,\"rgb\":[203,70,121]},{\"index\":0.63,\"rgb\":[229,107,93]},{\"index\":0.75,\"rgb\":[248,148,65]},{\"index\":0.88,\"rgb\":[253,195,40]},{\"index\":1,\"rgb\":[240,249,33]}],\n\n\t\"warm\": [{\"index\":0,\"rgb\":[125,0,179]},{\"index\":0.13,\"rgb\":[172,0,187]},{\"index\":0.25,\"rgb\":[219,0,170]},{\"index\":0.38,\"rgb\":[255,0,130]},{\"index\":0.5,\"rgb\":[255,63,74]},{\"index\":0.63,\"rgb\":[255,123,0]},{\"index\":0.75,\"rgb\":[234,176,0]},{\"index\":0.88,\"rgb\":[190,228,0]},{\"index\":1,\"rgb\":[147,255,0]}],\n\n\t\"cool\": [{\"index\":0,\"rgb\":[125,0,179]},{\"index\":0.13,\"rgb\":[116,0,218]},{\"index\":0.25,\"rgb\":[98,74,237]},{\"index\":0.38,\"rgb\":[68,146,231]},{\"index\":0.5,\"rgb\":[0,204,197]},{\"index\":0.63,\"rgb\":[0,247,146]},{\"index\":0.75,\"rgb\":[0,255,88]},{\"index\":0.88,\"rgb\":[40,255,8]},{\"index\":1,\"rgb\":[147,255,0]}],\n\n\t\"rainbow-soft\": [{\"index\":0,\"rgb\":[125,0,179]},{\"index\":0.1,\"rgb\":[199,0,180]},{\"index\":0.2,\"rgb\":[255,0,121]},{\"index\":0.3,\"rgb\":[255,108,0]},{\"index\":0.4,\"rgb\":[222,194,0]},{\"index\":0.5,\"rgb\":[150,255,0]},{\"index\":0.6,\"rgb\":[0,255,55]},{\"index\":0.7,\"rgb\":[0,246,150]},{\"index\":0.8,\"rgb\":[50,167,222]},{\"index\":0.9,\"rgb\":[103,51,235]},{\"index\":1,\"rgb\":[124,0,186]}],\n\n\t\"bathymetry\": [{\"index\":0,\"rgb\":[40,26,44]},{\"index\":0.13,\"rgb\":[59,49,90]},{\"index\":0.25,\"rgb\":[64,76,139]},{\"index\":0.38,\"rgb\":[63,110,151]},{\"index\":0.5,\"rgb\":[72,142,158]},{\"index\":0.63,\"rgb\":[85,174,163]},{\"index\":0.75,\"rgb\":[120,206,163]},{\"index\":0.88,\"rgb\":[187,230,172]},{\"index\":1,\"rgb\":[253,254,204]}],\n\n\t\"cdom\": [{\"index\":0,\"rgb\":[47,15,62]},{\"index\":0.13,\"rgb\":[87,23,86]},{\"index\":0.25,\"rgb\":[130,28,99]},{\"index\":0.38,\"rgb\":[171,41,96]},{\"index\":0.5,\"rgb\":[206,67,86]},{\"index\":0.63,\"rgb\":[230,106,84]},{\"index\":0.75,\"rgb\":[242,149,103]},{\"index\":0.88,\"rgb\":[249,193,135]},{\"index\":1,\"rgb\":[254,237,176]}],\n\n\t\"chlorophyll\": [{\"index\":0,\"rgb\":[18,36,20]},{\"index\":0.13,\"rgb\":[25,63,41]},{\"index\":0.25,\"rgb\":[24,91,59]},{\"index\":0.38,\"rgb\":[13,119,72]},{\"index\":0.5,\"rgb\":[18,148,80]},{\"index\":0.63,\"rgb\":[80,173,89]},{\"index\":0.75,\"rgb\":[132,196,122]},{\"index\":0.88,\"rgb\":[175,221,162]},{\"index\":1,\"rgb\":[215,249,208]}],\n\n\t\"density\": [{\"index\":0,\"rgb\":[54,14,36]},{\"index\":0.13,\"rgb\":[89,23,80]},{\"index\":0.25,\"rgb\":[110,45,132]},{\"index\":0.38,\"rgb\":[120,77,178]},{\"index\":0.5,\"rgb\":[120,113,213]},{\"index\":0.63,\"rgb\":[115,151,228]},{\"index\":0.75,\"rgb\":[134,185,227]},{\"index\":0.88,\"rgb\":[177,214,227]},{\"index\":1,\"rgb\":[230,241,241]}],\n\n\t\"freesurface-blue\": [{\"index\":0,\"rgb\":[30,4,110]},{\"index\":0.13,\"rgb\":[47,14,176]},{\"index\":0.25,\"rgb\":[41,45,236]},{\"index\":0.38,\"rgb\":[25,99,212]},{\"index\":0.5,\"rgb\":[68,131,200]},{\"index\":0.63,\"rgb\":[114,156,197]},{\"index\":0.75,\"rgb\":[157,181,203]},{\"index\":0.88,\"rgb\":[200,208,216]},{\"index\":1,\"rgb\":[241,237,236]}],\n\n\t\"freesurface-red\": [{\"index\":0,\"rgb\":[60,9,18]},{\"index\":0.13,\"rgb\":[100,17,27]},{\"index\":0.25,\"rgb\":[142,20,29]},{\"index\":0.38,\"rgb\":[177,43,27]},{\"index\":0.5,\"rgb\":[192,87,63]},{\"index\":0.63,\"rgb\":[205,125,105]},{\"index\":0.75,\"rgb\":[216,162,148]},{\"index\":0.88,\"rgb\":[227,199,193]},{\"index\":1,\"rgb\":[241,237,236]}],\n\n\t\"oxygen\": [{\"index\":0,\"rgb\":[64,5,5]},{\"index\":0.13,\"rgb\":[106,6,15]},{\"index\":0.25,\"rgb\":[144,26,7]},{\"index\":0.38,\"rgb\":[168,64,3]},{\"index\":0.5,\"rgb\":[188,100,4]},{\"index\":0.63,\"rgb\":[206,136,11]},{\"index\":0.75,\"rgb\":[220,174,25]},{\"index\":0.88,\"rgb\":[231,215,44]},{\"index\":1,\"rgb\":[248,254,105]}],\n\n\t\"par\": [{\"index\":0,\"rgb\":[51,20,24]},{\"index\":0.13,\"rgb\":[90,32,35]},{\"index\":0.25,\"rgb\":[129,44,34]},{\"index\":0.38,\"rgb\":[159,68,25]},{\"index\":0.5,\"rgb\":[182,99,19]},{\"index\":0.63,\"rgb\":[199,134,22]},{\"index\":0.75,\"rgb\":[212,171,35]},{\"index\":0.88,\"rgb\":[221,210,54]},{\"index\":1,\"rgb\":[225,253,75]}],\n\n\t\"phase\": [{\"index\":0,\"rgb\":[145,105,18]},{\"index\":0.13,\"rgb\":[184,71,38]},{\"index\":0.25,\"rgb\":[186,58,115]},{\"index\":0.38,\"rgb\":[160,71,185]},{\"index\":0.5,\"rgb\":[110,97,218]},{\"index\":0.63,\"rgb\":[50,123,164]},{\"index\":0.75,\"rgb\":[31,131,110]},{\"index\":0.88,\"rgb\":[77,129,34]},{\"index\":1,\"rgb\":[145,105,18]}],\n\n\t\"salinity\": [{\"index\":0,\"rgb\":[42,24,108]},{\"index\":0.13,\"rgb\":[33,50,162]},{\"index\":0.25,\"rgb\":[15,90,145]},{\"index\":0.38,\"rgb\":[40,118,137]},{\"index\":0.5,\"rgb\":[59,146,135]},{\"index\":0.63,\"rgb\":[79,175,126]},{\"index\":0.75,\"rgb\":[120,203,104]},{\"index\":0.88,\"rgb\":[193,221,100]},{\"index\":1,\"rgb\":[253,239,154]}],\n\n\t\"temperature\": [{\"index\":0,\"rgb\":[4,35,51]},{\"index\":0.13,\"rgb\":[23,51,122]},{\"index\":0.25,\"rgb\":[85,59,157]},{\"index\":0.38,\"rgb\":[129,79,143]},{\"index\":0.5,\"rgb\":[175,95,130]},{\"index\":0.63,\"rgb\":[222,112,101]},{\"index\":0.75,\"rgb\":[249,146,66]},{\"index\":0.88,\"rgb\":[249,196,65]},{\"index\":1,\"rgb\":[232,250,91]}],\n\n\t\"turbidity\": [{\"index\":0,\"rgb\":[34,31,27]},{\"index\":0.13,\"rgb\":[65,50,41]},{\"index\":0.25,\"rgb\":[98,69,52]},{\"index\":0.38,\"rgb\":[131,89,57]},{\"index\":0.5,\"rgb\":[161,112,59]},{\"index\":0.63,\"rgb\":[185,140,66]},{\"index\":0.75,\"rgb\":[202,174,88]},{\"index\":0.88,\"rgb\":[216,209,126]},{\"index\":1,\"rgb\":[233,246,171]}],\n\n\t\"velocity-blue\": [{\"index\":0,\"rgb\":[17,32,64]},{\"index\":0.13,\"rgb\":[35,52,116]},{\"index\":0.25,\"rgb\":[29,81,156]},{\"index\":0.38,\"rgb\":[31,113,162]},{\"index\":0.5,\"rgb\":[50,144,169]},{\"index\":0.63,\"rgb\":[87,173,176]},{\"index\":0.75,\"rgb\":[149,196,189]},{\"index\":0.88,\"rgb\":[203,221,211]},{\"index\":1,\"rgb\":[254,251,230]}],\n\n\t\"velocity-green\": [{\"index\":0,\"rgb\":[23,35,19]},{\"index\":0.13,\"rgb\":[24,64,38]},{\"index\":0.25,\"rgb\":[11,95,45]},{\"index\":0.38,\"rgb\":[39,123,35]},{\"index\":0.5,\"rgb\":[95,146,12]},{\"index\":0.63,\"rgb\":[152,165,18]},{\"index\":0.75,\"rgb\":[201,186,69]},{\"index\":0.88,\"rgb\":[233,216,137]},{\"index\":1,\"rgb\":[255,253,205]}],\n\n\t\"cubehelix\": [{\"index\":0,\"rgb\":[0,0,0]},{\"index\":0.07,\"rgb\":[22,5,59]},{\"index\":0.13,\"rgb\":[60,4,105]},{\"index\":0.2,\"rgb\":[109,1,135]},{\"index\":0.27,\"rgb\":[161,0,147]},{\"index\":0.33,\"rgb\":[210,2,142]},{\"index\":0.4,\"rgb\":[251,11,123]},{\"index\":0.47,\"rgb\":[255,29,97]},{\"index\":0.53,\"rgb\":[255,54,69]},{\"index\":0.6,\"rgb\":[255,85,46]},{\"index\":0.67,\"rgb\":[255,120,34]},{\"index\":0.73,\"rgb\":[255,157,37]},{\"index\":0.8,\"rgb\":[241,191,57]},{\"index\":0.87,\"rgb\":[224,220,93]},{\"index\":0.93,\"rgb\":[218,241,142]},{\"index\":1,\"rgb\":[227,253,198]}]\n};\n","/*\n * Ben Postlethwaite\n * January 2013\n * License MIT\n */\n'use strict';\n\nvar colorScale = require('./colorScale');\nvar lerp = require('lerp')\n\nmodule.exports = createColormap;\n\nfunction createColormap (spec) {\n /*\n * Default Options\n */\n var indicies, fromrgba, torgba,\n nsteps, cmap, colormap, format,\n nshades, colors, alpha, i;\n\n if ( !spec ) spec = {};\n\n nshades = (spec.nshades || 72) - 1;\n format = spec.format || 'hex';\n\n colormap = spec.colormap;\n if (!colormap) colormap = 'jet';\n\n if (typeof colormap === 'string') {\n colormap = colormap.toLowerCase();\n\n if (!colorScale[colormap]) {\n throw Error(colormap + ' not a supported colorscale');\n }\n\n cmap = colorScale[colormap];\n\n } else if (Array.isArray(colormap)) {\n cmap = colormap.slice();\n\n } else {\n throw Error('unsupported colormap option', colormap);\n }\n\n if (cmap.length > nshades + 1) {\n throw new Error(\n colormap+' map requires nshades to be at least size '+cmap.length\n );\n }\n\n if (!Array.isArray(spec.alpha)) {\n\n if (typeof spec.alpha === 'number') {\n alpha = [spec.alpha, spec.alpha];\n\n } else {\n alpha = [1, 1];\n }\n\n } else if (spec.alpha.length !== 2) {\n alpha = [1, 1];\n\n } else {\n alpha = spec.alpha.slice();\n }\n\n // map index points from 0..1 to 0..n-1\n indicies = cmap.map(function(c) {\n return Math.round(c.index * nshades);\n });\n\n // Add alpha channel to the map\n alpha[0] = Math.min(Math.max(alpha[0], 0), 1);\n alpha[1] = Math.min(Math.max(alpha[1], 0), 1);\n\n var steps = cmap.map(function(c, i) {\n var index = cmap[i].index\n\n var rgba = cmap[i].rgb.slice();\n\n // if user supplies their own map use it\n if (rgba.length === 4 && rgba[3] >= 0 && rgba[3] <= 1) {\n return rgba\n }\n rgba[3] = alpha[0] + (alpha[1] - alpha[0])*index;\n\n return rgba\n })\n\n\n /*\n * map increasing linear values between indicies to\n * linear steps in colorvalues\n */\n var colors = []\n for (i = 0; i < indicies.length-1; ++i) {\n nsteps = indicies[i+1] - indicies[i];\n fromrgba = steps[i];\n torgba = steps[i+1];\n\n for (var j = 0; j < nsteps; j++) {\n var amt = j / nsteps\n colors.push([\n Math.round(lerp(fromrgba[0], torgba[0], amt)),\n Math.round(lerp(fromrgba[1], torgba[1], amt)),\n Math.round(lerp(fromrgba[2], torgba[2], amt)),\n lerp(fromrgba[3], torgba[3], amt)\n ])\n }\n }\n\n //add 1 step as last value\n colors.push(cmap[cmap.length - 1].rgb.concat(alpha[1]))\n\n if (format === 'hex') colors = colors.map( rgb2hex );\n else if (format === 'rgbaString') colors = colors.map( rgbaStr );\n else if (format === 'float') colors = colors.map( rgb2float );\n\n return colors;\n};\n\nfunction rgb2float (rgba) {\n return [\n rgba[0] / 255,\n rgba[1] / 255,\n rgba[2] / 255,\n rgba[3]\n ]\n}\n\nfunction rgb2hex (rgba) {\n var dig, hex = '#';\n for (var i = 0; i < 3; ++i) {\n dig = rgba[i];\n dig = dig.toString(16);\n hex += ('00' + dig).substr( dig.length );\n }\n return hex;\n}\n\nfunction rgbaStr (rgba) {\n return 'rgba(' + rgba.join(',') + ')';\n}\n","module.exports = {\n AFG: 'afghan',\n ALA: '\\\\b\\\\wland',\n ALB: 'albania',\n DZA: 'algeria',\n ASM: '^(?=.*americ).*samoa',\n AND: 'andorra',\n AGO: 'angola',\n AIA: 'anguill?a',\n ATA: 'antarctica',\n ATG: 'antigua',\n ARG: 'argentin',\n ARM: 'armenia',\n ABW: '^(?!.*bonaire).*\\\\baruba',\n AUS: 'australia',\n AUT: '^(?!.*hungary).*austria|\\\\baustri.*\\\\bemp',\n AZE: 'azerbaijan',\n BHS: 'bahamas',\n BHR: 'bahrain',\n BGD: 'bangladesh|^(?=.*east).*paki?stan',\n BRB: 'barbados',\n BLR: 'belarus|byelo',\n BEL: '^(?!.*luxem).*belgium',\n BLZ: 'belize|^(?=.*british).*honduras',\n BEN: 'benin|dahome',\n BMU: 'bermuda',\n BTN: 'bhutan',\n BOL: 'bolivia',\n BES: '^(?=.*bonaire).*eustatius|^(?=.*carib).*netherlands|\\\\bbes.?islands',\n BIH: 'herzegovina|bosnia',\n BWA: 'botswana|bechuana',\n BVT: 'bouvet',\n BRA: 'brazil',\n IOT: 'british.?indian.?ocean',\n BRN: 'brunei',\n BGR: 'bulgaria',\n BFA: 'burkina|\\\\bfaso|upper.?volta',\n BDI: 'burundi',\n CPV: 'verde',\n KHM: 'cambodia|kampuchea|khmer',\n CMR: 'cameroon',\n CAN: 'canada',\n CYM: 'cayman',\n CAF: '\\\\bcentral.african.republic',\n TCD: '\\\\bchad',\n CHL: '\\\\bchile',\n CHN: '^(?!.*\\\\bmac)(?!.*\\\\bhong)(?!.*\\\\btai)(?!.*\\\\brep).*china|^(?=.*peo)(?=.*rep).*china',\n CXR: 'christmas',\n CCK: '\\\\bcocos|keeling',\n COL: 'colombia',\n COM: 'comoro',\n COG: '^(?!.*\\\\bdem)(?!.*\\\\bd[\\\\.]?r)(?!.*kinshasa)(?!.*zaire)(?!.*belg)(?!.*l.opoldville)(?!.*free).*\\\\bcongo',\n COK: '\\\\bcook',\n CRI: 'costa.?rica',\n CIV: 'ivoire|ivory',\n HRV: 'croatia',\n CUB: '\\\\bcuba',\n CUW: '^(?!.*bonaire).*\\\\bcura(c|ç)ao',\n CYP: 'cyprus',\n CSK: 'czechoslovakia',\n CZE: '^(?=.*rep).*czech|czechia|bohemia',\n COD: '\\\\bdem.*congo|congo.*\\\\bdem|congo.*\\\\bd[\\\\.]?r|\\\\bd[\\\\.]?r.*congo|belgian.?congo|congo.?free.?state|kinshasa|zaire|l.opoldville|drc|droc|rdc',\n DNK: 'denmark',\n DJI: 'djibouti',\n DMA: 'dominica(?!n)',\n DOM: 'dominican.rep',\n ECU: 'ecuador',\n EGY: 'egypt',\n SLV: 'el.?salvador',\n GNQ: 'guine.*eq|eq.*guine|^(?=.*span).*guinea',\n ERI: 'eritrea',\n EST: 'estonia',\n ETH: 'ethiopia|abyssinia',\n FLK: 'falkland|malvinas',\n FRO: 'faroe|faeroe',\n FJI: 'fiji',\n FIN: 'finland',\n FRA: '^(?!.*\\\\bdep)(?!.*martinique).*france|french.?republic|\\\\bgaul',\n GUF: '^(?=.*french).*guiana',\n PYF: 'french.?polynesia|tahiti',\n ATF: 'french.?southern',\n GAB: 'gabon',\n GMB: 'gambia',\n GEO: '^(?!.*south).*georgia',\n DDR: 'german.?democratic.?republic|democratic.?republic.*germany|east.germany',\n DEU: '^(?!.*east).*germany|^(?=.*\\\\bfed.*\\\\brep).*german',\n GHA: 'ghana|gold.?coast',\n GIB: 'gibraltar',\n GRC: 'greece|hellenic|hellas',\n GRL: 'greenland',\n GRD: 'grenada',\n GLP: 'guadeloupe',\n GUM: '\\\\bguam',\n GTM: 'guatemala',\n GGY: 'guernsey',\n GIN: '^(?!.*eq)(?!.*span)(?!.*bissau)(?!.*portu)(?!.*new).*guinea',\n GNB: 'bissau|^(?=.*portu).*guinea',\n GUY: 'guyana|british.?guiana',\n HTI: 'haiti',\n HMD: 'heard.*mcdonald',\n VAT: 'holy.?see|vatican|papal.?st',\n HND: '^(?!.*brit).*honduras',\n HKG: 'hong.?kong',\n HUN: '^(?!.*austr).*hungary',\n ISL: 'iceland',\n IND: 'india(?!.*ocea)',\n IDN: 'indonesia',\n IRN: '\\\\biran|persia',\n IRQ: '\\\\biraq|mesopotamia',\n IRL: '(^ireland)|(^republic.*ireland)',\n IMN: '^(?=.*isle).*\\\\bman',\n ISR: 'israel',\n ITA: 'italy',\n JAM: 'jamaica',\n JPN: 'japan',\n JEY: 'jersey',\n JOR: 'jordan',\n KAZ: 'kazak',\n KEN: 'kenya|british.?east.?africa|east.?africa.?prot',\n KIR: 'kiribati',\n PRK: '^(?=.*democrat|people|north|d.*p.*.r).*\\\\bkorea|dprk|korea.*(d.*p.*r)',\n KWT: 'kuwait',\n KGZ: 'kyrgyz|kirghiz',\n LAO: '\\\\blaos?\\\\b',\n LVA: 'latvia',\n LBN: 'lebanon',\n LSO: 'lesotho|basuto',\n LBR: 'liberia',\n LBY: 'libya',\n LIE: 'liechtenstein',\n LTU: 'lithuania',\n LUX: '^(?!.*belg).*luxem',\n MAC: 'maca(o|u)',\n MDG: 'madagascar|malagasy',\n MWI: 'malawi|nyasa',\n MYS: 'malaysia',\n MDV: 'maldive',\n MLI: '\\\\bmali\\\\b',\n MLT: '\\\\bmalta',\n MHL: 'marshall',\n MTQ: 'martinique',\n MRT: 'mauritania',\n MUS: 'mauritius',\n MYT: '\\\\bmayotte',\n MEX: '\\\\bmexic',\n FSM: 'fed.*micronesia|micronesia.*fed',\n MCO: 'monaco',\n MNG: 'mongolia',\n MNE: '^(?!.*serbia).*montenegro',\n MSR: 'montserrat',\n MAR: 'morocco|\\\\bmaroc',\n MOZ: 'mozambique',\n MMR: 'myanmar|burma',\n NAM: 'namibia',\n NRU: 'nauru',\n NPL: 'nepal',\n NLD: '^(?!.*\\\\bant)(?!.*\\\\bcarib).*netherlands',\n ANT: '^(?=.*\\\\bant).*(nether|dutch)',\n NCL: 'new.?caledonia',\n NZL: 'new.?zealand',\n NIC: 'nicaragua',\n NER: '\\\\bniger(?!ia)',\n NGA: 'nigeria',\n NIU: 'niue',\n NFK: 'norfolk',\n MNP: 'mariana',\n NOR: 'norway',\n OMN: '\\\\boman|trucial',\n PAK: '^(?!.*east).*paki?stan',\n PLW: 'palau',\n PSE: 'palestin|\\\\bgaza|west.?bank',\n PAN: 'panama',\n PNG: 'papua|new.?guinea',\n PRY: 'paraguay',\n PER: 'peru',\n PHL: 'philippines',\n PCN: 'pitcairn',\n POL: 'poland',\n PRT: 'portugal',\n PRI: 'puerto.?rico',\n QAT: 'qatar',\n KOR: '^(?!.*d.*p.*r)(?!.*democrat)(?!.*people)(?!.*north).*\\\\bkorea(?!.*d.*p.*r)',\n MDA: 'moldov|b(a|e)ssarabia',\n REU: 'r(e|é)union',\n ROU: 'r(o|u|ou)mania',\n RUS: '\\\\brussia|soviet.?union|u\\\\.?s\\\\.?s\\\\.?r|socialist.?republics',\n RWA: 'rwanda',\n BLM: 'barth(e|é)lemy',\n SHN: 'helena',\n KNA: 'kitts|\\\\bnevis',\n LCA: '\\\\blucia',\n MAF: '^(?=.*collectivity).*martin|^(?=.*france).*martin(?!ique)|^(?=.*french).*martin(?!ique)',\n SPM: 'miquelon',\n VCT: 'vincent',\n WSM: '^(?!.*amer).*samoa',\n SMR: 'san.?marino',\n STP: '\\\\bs(a|ã)o.?tom(e|é)',\n SAU: '\\\\bsa\\\\w*.?arabia',\n SEN: 'senegal',\n SRB: '^(?!.*monte).*serbia',\n SYC: 'seychell',\n SLE: 'sierra',\n SGP: 'singapore',\n SXM: '^(?!.*martin)(?!.*saba).*maarten',\n SVK: '^(?!.*cze).*slovak',\n SVN: 'slovenia',\n SLB: 'solomon',\n SOM: 'somali',\n ZAF: 'south.africa|s\\\\\\\\..?africa',\n SGS: 'south.?georgia|sandwich',\n SSD: '\\\\bs\\\\w*.?sudan',\n ESP: 'spain',\n LKA: 'sri.?lanka|ceylon',\n SDN: '^(?!.*\\\\bs(?!u)).*sudan',\n SUR: 'surinam|dutch.?guiana',\n SJM: 'svalbard',\n SWZ: 'swaziland',\n SWE: 'sweden',\n CHE: 'switz|swiss',\n SYR: 'syria',\n TWN: 'taiwan|taipei|formosa|^(?!.*peo)(?=.*rep).*china',\n TJK: 'tajik',\n THA: 'thailand|\\\\bsiam',\n MKD: 'macedonia|fyrom',\n TLS: '^(?=.*leste).*timor|^(?=.*east).*timor',\n TGO: 'togo',\n TKL: 'tokelau',\n TON: 'tonga',\n TTO: 'trinidad|tobago',\n TUN: 'tunisia',\n TUR: 'turkey',\n TKM: 'turkmen',\n TCA: 'turks',\n TUV: 'tuvalu',\n UGA: 'uganda',\n UKR: 'ukrain',\n ARE: 'emirates|^u\\\\.?a\\\\.?e\\\\.?$|united.?arab.?em',\n GBR: 'united.?kingdom|britain|^u\\\\.?k\\\\.?$',\n TZA: 'tanzania',\n USA: 'united.?states\\\\b(?!.*islands)|\\\\bu\\\\.?s\\\\.?a\\\\.?\\\\b|^\\\\s*u\\\\.?s\\\\.?\\\\b(?!.*islands)',\n UMI: 'minor.?outlying.?is',\n URY: 'uruguay',\n UZB: 'uzbek',\n VUT: 'vanuatu|new.?hebrides',\n VEN: 'venezuela',\n VNM: '^(?!.*republic).*viet.?nam|^(?=.*socialist).*viet.?nam',\n VGB: '^(?=.*\\\\bu\\\\.?\\\\s?k).*virgin|^(?=.*brit).*virgin|^(?=.*kingdom).*virgin',\n VIR: '^(?=.*\\\\bu\\\\.?\\\\s?s).*virgin|^(?=.*states).*virgin',\n WLF: 'futuna|wallis',\n ESH: 'western.sahara',\n YEM: '^(?!.*arab)(?!.*north)(?!.*sana)(?!.*peo)(?!.*dem)(?!.*south)(?!.*aden)(?!.*\\\\bp\\\\.?d\\\\.?r).*yemen',\n YMD: '^(?=.*peo).*yemen|^(?!.*rep)(?=.*dem).*yemen|^(?=.*south).*yemen|^(?=.*aden).*yemen|^(?=.*\\\\bp\\\\.?d\\\\.?r).*yemen',\n YUG: 'yugoslavia',\n ZMB: 'zambia|northern.?rhodesia',\n EAZ: 'zanzibar',\n ZWE: 'zimbabwe|^(?!.*northern).*rhodesia'\n}\n","'use strict'\r\n\r\nmodule.exports = {\r\n\tparse: require('./parse'),\r\n\tstringify: require('./stringify')\r\n}\r\n","'use strict'\r\n\r\nvar sizes = require('css-font-size-keywords')\r\n\r\nmodule.exports = {\r\n\tisSize: function isSize(value) {\r\n\t\treturn /^[\\d\\.]/.test(value)\r\n\t\t\t|| value.indexOf('/') !== -1\r\n\t\t\t|| sizes.indexOf(value) !== -1\r\n\t}\r\n}\r\n","'use strict'\r\n\r\nvar unquote = require('unquote')\r\nvar globalKeywords = require('css-global-keywords')\r\nvar systemFontKeywords = require('css-system-font-keywords')\r\nvar fontWeightKeywords = require('css-font-weight-keywords')\r\nvar fontStyleKeywords = require('css-font-style-keywords')\r\nvar fontStretchKeywords = require('css-font-stretch-keywords')\r\nvar splitBy = require('string-split-by')\r\nvar isSize = require('./lib/util').isSize\r\n\r\n\r\nmodule.exports = parseFont\r\n\r\n\r\nvar cache = parseFont.cache = {}\r\n\r\n\r\nfunction parseFont (value) {\r\n\tif (typeof value !== 'string') throw new Error('Font argument must be a string.')\r\n\r\n\tif (cache[value]) return cache[value]\r\n\r\n\tif (value === '') {\r\n\t\tthrow new Error('Cannot parse an empty string.')\r\n\t}\r\n\r\n\tif (systemFontKeywords.indexOf(value) !== -1) {\r\n\t\treturn cache[value] = {system: value}\r\n\t}\r\n\r\n\tvar font = {\r\n\t\tstyle: 'normal',\r\n\t\tvariant: 'normal',\r\n\t\tweight: 'normal',\r\n\t\tstretch: 'normal',\r\n\t\tlineHeight: 'normal',\r\n\t\tsize: '1rem',\r\n\t\tfamily: ['serif']\r\n\t}\r\n\r\n\tvar tokens = splitBy(value, /\\s+/)\r\n\tvar token\r\n\r\n\twhile (token = tokens.shift()) {\r\n\t\tif (globalKeywords.indexOf(token) !== -1) {\r\n\t\t\t['style', 'variant', 'weight', 'stretch'].forEach(function(prop) {\r\n\t\t\t\tfont[prop] = token\r\n\t\t\t})\r\n\r\n\t\t\treturn cache[value] = font\r\n\t\t}\r\n\r\n\t\tif (fontStyleKeywords.indexOf(token) !== -1) {\r\n\t\t\tfont.style = token\r\n\t\t\tcontinue\r\n\t\t}\r\n\r\n\t\tif (token === 'normal' || token === 'small-caps') {\r\n\t\t\tfont.variant = token\r\n\t\t\tcontinue\r\n\t\t}\r\n\r\n\t\tif (fontStretchKeywords.indexOf(token) !== -1) {\r\n\t\t\tfont.stretch = token\r\n\t\t\tcontinue\r\n\t\t}\r\n\r\n\t\tif (fontWeightKeywords.indexOf(token) !== -1) {\r\n\t\t\tfont.weight = token\r\n\t\t\tcontinue\r\n\t\t}\r\n\r\n\r\n\t\tif (isSize(token)) {\r\n\t\t\tvar parts = splitBy(token, '/')\r\n\t\t\tfont.size = parts[0]\r\n\t\t\tif (parts[1] != null) {\r\n\t\t\t\tfont.lineHeight = parseLineHeight(parts[1])\r\n\t\t\t}\r\n\t\t\telse if (tokens[0] === '/') {\r\n\t\t\t\ttokens.shift()\r\n\t\t\t\tfont.lineHeight = parseLineHeight(tokens.shift())\r\n \t\t\t}\r\n\r\n\t\t\tif (!tokens.length) {\r\n\t\t\t\tthrow new Error('Missing required font-family.')\r\n\t\t\t}\r\n\t\t\tfont.family = splitBy(tokens.join(' '), /\\s*,\\s*/).map(unquote)\r\n\r\n\t\t\treturn cache[value] = font\r\n\t\t}\r\n\r\n\t\tthrow new Error('Unknown or unsupported font token: ' + token)\r\n\t}\r\n\r\n\tthrow new Error('Missing required font-size.')\r\n}\r\n\r\n\r\nfunction parseLineHeight(value) {\r\n\tvar parsed = parseFloat(value)\r\n\tif (parsed.toString() === value) {\r\n\t\treturn parsed\r\n\t}\r\n\treturn value\r\n}\r\n","'use strict'\r\n\r\nvar pick = require('pick-by-alias')\r\nvar isSize = require('./lib/util').isSize\r\n\r\nvar globals = a2o(require('css-global-keywords'))\r\nvar systems = a2o(require('css-system-font-keywords'))\r\nvar weights = a2o(require('css-font-weight-keywords'))\r\nvar styles = a2o(require('css-font-style-keywords'))\r\nvar stretches = a2o(require('css-font-stretch-keywords'))\r\n\r\nvar variants = {'normal': 1, 'small-caps': 1}\r\nvar fams = {\r\n\t'serif': 1,\r\n\t'sans-serif': 1,\r\n\t'monospace': 1,\r\n\t'cursive': 1,\r\n\t'fantasy': 1,\r\n\t'system-ui': 1\r\n}\r\n\r\nvar defaults = {\r\n\tstyle: 'normal',\r\n\tvariant: 'normal',\r\n\tweight: 'normal',\r\n\tstretch: 'normal',\r\n\tsize: '1rem',\r\n\tlineHeight: 'normal',\r\n\tfamily: 'serif'\r\n}\r\n\r\nmodule.exports = function stringifyFont (o) {\r\n\to = pick(o, {\r\n\t\tstyle: 'style fontstyle fontStyle font-style slope distinction',\r\n\t\tvariant: 'variant font-variant fontVariant fontvariant var capitalization',\r\n\t\tweight: 'weight w font-weight fontWeight fontweight',\r\n\t\tstretch: 'stretch font-stretch fontStretch fontstretch width',\r\n\t\tsize: 'size s font-size fontSize fontsize height em emSize',\r\n\t\tlineHeight: 'lh line-height lineHeight lineheight leading',\r\n\t\tfamily: 'font family fontFamily font-family fontfamily type typeface face',\r\n\t\tsystem: 'system reserved default global',\r\n\t})\r\n\r\n\tif (o.system) {\r\n\t\tif (o.system) verify(o.system, systems)\r\n\t\treturn o.system\r\n\t}\r\n\r\n\tverify(o.style, styles)\r\n\tverify(o.variant, variants)\r\n\tverify(o.weight, weights)\r\n\tverify(o.stretch, stretches)\r\n\r\n\t// default root value is medium, but by default it's inherited\r\n\tif (o.size == null) o.size = defaults.size\r\n\tif (typeof o.size === 'number') o.size += 'px'\r\n\r\n\tif (!isSize) throw Error('Bad size value `' + o.size + '`')\r\n\r\n\t// many user-agents use serif, we don't detect that for consistency\r\n\tif (!o.family) o.family = defaults.family\r\n\tif (Array.isArray(o.family)) {\r\n\t\tif (!o.family.length) o.family = [defaults.family]\r\n\t\to.family = o.family.map(function (f) {\r\n\t\t\treturn fams[f] ? f : '\"' + f + '\"'\r\n\t\t}).join(', ')\r\n\t}\r\n\r\n\t// [ [ <'font-style'> || || <'font-weight'> || <'font-stretch'> ]? <'font-size'> [ / <'line-height'> ]? <'font-family'> ]\r\n\tvar result = []\r\n\r\n\tresult.push(o.style)\r\n\tif (o.variant !== o.style) result.push(o.variant)\r\n\r\n\tif (o.weight !== o.variant &&\r\n\t\to.weight !== o.style) result.push(o.weight)\r\n\r\n\tif (o.stretch !== o.weight &&\r\n\t\to.stretch !== o.variant &&\r\n\t\to.stretch !== o.style) result.push(o.stretch)\r\n\r\n\tresult.push(o.size + (o.lineHeight == null || o.lineHeight === 'normal' || (o.lineHeight + '' === '1') ? '' : ('/' + o.lineHeight)))\r\n\tresult.push(o.family)\r\n\r\n\treturn result.filter(Boolean).join(' ')\r\n}\r\n\r\nfunction verify (value, values) {\r\n\tif (value && !values[value] && !globals[value]) throw Error('Unknown keyword `' + value +'`')\r\n\r\n\treturn value\r\n}\r\n\r\n\r\n// ['a', 'b'] -> {a: true, b: true}\r\nfunction a2o (a) {\r\n\tvar o = {}\r\n\tfor (var i = 0; i < a.length; i++) {\r\n\t\to[a[i]] = 1\r\n\t}\r\n\treturn o\r\n}\r\n","\"use strict\";\n\nvar isValue = require(\"type/value/is\")\n , ensureValue = require(\"type/value/ensure\")\n , ensurePlainFunction = require(\"type/plain-function/ensure\")\n , copy = require(\"es5-ext/object/copy\")\n , normalizeOptions = require(\"es5-ext/object/normalize-options\")\n , map = require(\"es5-ext/object/map\");\n\nvar bind = Function.prototype.bind\n , defineProperty = Object.defineProperty\n , hasOwnProperty = Object.prototype.hasOwnProperty\n , define;\n\ndefine = function (name, desc, options) {\n\tvar value = ensureValue(desc) && ensurePlainFunction(desc.value), dgs;\n\tdgs = copy(desc);\n\tdelete dgs.writable;\n\tdelete dgs.value;\n\tdgs.get = function () {\n\t\tif (!options.overwriteDefinition && hasOwnProperty.call(this, name)) return value;\n\t\tdesc.value = bind.call(value, options.resolveContext ? options.resolveContext(this) : this);\n\t\tdefineProperty(this, name, desc);\n\t\treturn this[name];\n\t};\n\treturn dgs;\n};\n\nmodule.exports = function (props/*, options*/) {\n\tvar options = normalizeOptions(arguments[1]);\n\tif (isValue(options.resolveContext)) ensurePlainFunction(options.resolveContext);\n\treturn map(props, function (desc, name) { return define(name, desc, options); });\n};\n","\"use strict\";\n\nvar isValue = require(\"type/value/is\")\n , isPlainFunction = require(\"type/plain-function/is\")\n , assign = require(\"es5-ext/object/assign\")\n , normalizeOpts = require(\"es5-ext/object/normalize-options\")\n , contains = require(\"es5-ext/string/#/contains\");\n\nvar d = (module.exports = function (dscr, value/*, options*/) {\n\tvar c, e, w, options, desc;\n\tif (arguments.length < 2 || typeof dscr !== \"string\") {\n\t\toptions = value;\n\t\tvalue = dscr;\n\t\tdscr = null;\n\t} else {\n\t\toptions = arguments[2];\n\t}\n\tif (isValue(dscr)) {\n\t\tc = contains.call(dscr, \"c\");\n\t\te = contains.call(dscr, \"e\");\n\t\tw = contains.call(dscr, \"w\");\n\t} else {\n\t\tc = w = true;\n\t\te = false;\n\t}\n\n\tdesc = { value: value, configurable: c, enumerable: e, writable: w };\n\treturn !options ? desc : assign(normalizeOpts(options), desc);\n});\n\nd.gs = function (dscr, get, set/*, options*/) {\n\tvar c, e, options, desc;\n\tif (typeof dscr !== \"string\") {\n\t\toptions = set;\n\t\tset = get;\n\t\tget = dscr;\n\t\tdscr = null;\n\t} else {\n\t\toptions = arguments[3];\n\t}\n\tif (!isValue(get)) {\n\t\tget = undefined;\n\t} else if (!isPlainFunction(get)) {\n\t\toptions = get;\n\t\tget = set = undefined;\n\t} else if (!isValue(set)) {\n\t\tset = undefined;\n\t} else if (!isPlainFunction(set)) {\n\t\toptions = set;\n\t\tset = undefined;\n\t}\n\tif (isValue(dscr)) {\n\t\tc = contains.call(dscr, \"c\");\n\t\te = contains.call(dscr, \"e\");\n\t} else {\n\t\tc = true;\n\t\te = false;\n\t}\n\n\tdesc = { get: get, set: set, configurable: c, enumerable: e };\n\treturn !options ? desc : assign(normalizeOpts(options), desc);\n};\n","export default function(a, b) {\n return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n}\n","import ascending from \"./ascending\";\nimport bisector from \"./bisector\";\n\nvar ascendingBisect = bisector(ascending);\nexport var bisectRight = ascendingBisect.right;\nexport var bisectLeft = ascendingBisect.left;\nexport default bisectRight;\n","import ascending from \"./ascending\";\n\nexport default function(compare) {\n if (compare.length === 1) compare = ascendingComparator(compare);\n return {\n left: function(a, x, lo, hi) {\n if (lo == null) lo = 0;\n if (hi == null) hi = a.length;\n while (lo < hi) {\n var mid = lo + hi >>> 1;\n if (compare(a[mid], x) < 0) lo = mid + 1;\n else hi = mid;\n }\n return lo;\n },\n right: function(a, x, lo, hi) {\n if (lo == null) lo = 0;\n if (hi == null) hi = a.length;\n while (lo < hi) {\n var mid = lo + hi >>> 1;\n if (compare(a[mid], x) > 0) hi = mid;\n else lo = mid + 1;\n }\n return lo;\n }\n };\n}\n\nfunction ascendingComparator(f) {\n return function(d, x) {\n return ascending(f(d), x);\n };\n}\n","var array = Array.prototype;\n\nexport var slice = array.slice;\nexport var map = array.map;\n","var e10 = Math.sqrt(50),\n e5 = Math.sqrt(10),\n e2 = Math.sqrt(2);\n\nexport default function(start, stop, count) {\n var reverse,\n i = -1,\n n,\n ticks,\n step;\n\n stop = +stop, start = +start, count = +count;\n if (start === stop && count > 0) return [start];\n if (reverse = stop < start) n = start, start = stop, stop = n;\n if ((step = tickIncrement(start, stop, count)) === 0 || !isFinite(step)) return [];\n\n if (step > 0) {\n start = Math.ceil(start / step);\n stop = Math.floor(stop / step);\n ticks = new Array(n = Math.ceil(stop - start + 1));\n while (++i < n) ticks[i] = (start + i) * step;\n } else {\n start = Math.floor(start * step);\n stop = Math.ceil(stop * step);\n ticks = new Array(n = Math.ceil(start - stop + 1));\n while (++i < n) ticks[i] = (start - i) / step;\n }\n\n if (reverse) ticks.reverse();\n\n return ticks;\n}\n\nexport function tickIncrement(start, stop, count) {\n var step = (stop - start) / Math.max(0, count),\n power = Math.floor(Math.log(step) / Math.LN10),\n error = step / Math.pow(10, power);\n return power >= 0\n ? (error >= e10 ? 10 : error >= e5 ? 5 : error >= e2 ? 2 : 1) * Math.pow(10, power)\n : -Math.pow(10, -power) / (error >= e10 ? 10 : error >= e5 ? 5 : error >= e2 ? 2 : 1);\n}\n\nexport function tickStep(start, stop, count) {\n var step0 = Math.abs(stop - start) / Math.max(0, count),\n step1 = Math.pow(10, Math.floor(Math.log(step0) / Math.LN10)),\n error = step0 / step1;\n if (error >= e10) step1 *= 10;\n else if (error >= e5) step1 *= 5;\n else if (error >= e2) step1 *= 2;\n return stop < start ? -step1 : step1;\n}\n","export default function(values, valueof) {\n var n = values.length,\n i = -1,\n value,\n max;\n\n if (valueof == null) {\n while (++i < n) { // Find the first comparable value.\n if ((value = values[i]) != null && value >= value) {\n max = value;\n while (++i < n) { // Compare the remaining values.\n if ((value = values[i]) != null && value > max) {\n max = value;\n }\n }\n }\n }\n }\n\n else {\n while (++i < n) { // Find the first comparable value.\n if ((value = valueof(values[i], i, values)) != null && value >= value) {\n max = value;\n while (++i < n) { // Compare the remaining values.\n if ((value = valueof(values[i], i, values)) != null && value > max) {\n max = value;\n }\n }\n }\n }\n }\n\n return max;\n}\n","export default function(x) {\n return x === null ? NaN : +x;\n}\n","import number from \"./number\";\n\nexport default function(values, valueof) {\n var n = values.length,\n m = n,\n i = -1,\n value,\n sum = 0;\n\n if (valueof == null) {\n while (++i < n) {\n if (!isNaN(value = number(values[i]))) sum += value;\n else --m;\n }\n }\n\n else {\n while (++i < n) {\n if (!isNaN(value = number(valueof(values[i], i, values)))) sum += value;\n else --m;\n }\n }\n\n if (m) return sum / m;\n}\n","export default function(arrays) {\n var n = arrays.length,\n m,\n i = -1,\n j = 0,\n merged,\n array;\n\n while (++i < n) j += arrays[i].length;\n merged = new Array(j);\n\n while (--n >= 0) {\n array = arrays[n];\n m = array.length;\n while (--m >= 0) {\n merged[--j] = array[m];\n }\n }\n\n return merged;\n}\n","export default function(values, valueof) {\n var n = values.length,\n i = -1,\n value,\n min;\n\n if (valueof == null) {\n while (++i < n) { // Find the first comparable value.\n if ((value = values[i]) != null && value >= value) {\n min = value;\n while (++i < n) { // Compare the remaining values.\n if ((value = values[i]) != null && min > value) {\n min = value;\n }\n }\n }\n }\n }\n\n else {\n while (++i < n) { // Find the first comparable value.\n if ((value = valueof(values[i], i, values)) != null && value >= value) {\n min = value;\n while (++i < n) { // Compare the remaining values.\n if ((value = valueof(values[i], i, values)) != null && min > value) {\n min = value;\n }\n }\n }\n }\n }\n\n return min;\n}\n","export default function(start, stop, step) {\n start = +start, stop = +stop, step = (n = arguments.length) < 2 ? (stop = start, start = 0, 1) : n < 3 ? 1 : +step;\n\n var i = -1,\n n = Math.max(0, Math.ceil((stop - start) / step)) | 0,\n range = new Array(n);\n\n while (++i < n) {\n range[i] = start + i * step;\n }\n\n return range;\n}\n","export default function(values, valueof) {\n var n = values.length,\n i = -1,\n value,\n sum = 0;\n\n if (valueof == null) {\n while (++i < n) {\n if (value = +values[i]) sum += value; // Note: zero and null are equivalent.\n }\n }\n\n else {\n while (++i < n) {\n if (value = +valueof(values[i], i, values)) sum += value;\n }\n }\n\n return sum;\n}\n","export var prefix = \"$\";\n\nfunction Map() {}\n\nMap.prototype = map.prototype = {\n constructor: Map,\n has: function(key) {\n return (prefix + key) in this;\n },\n get: function(key) {\n return this[prefix + key];\n },\n set: function(key, value) {\n this[prefix + key] = value;\n return this;\n },\n remove: function(key) {\n var property = prefix + key;\n return property in this && delete this[property];\n },\n clear: function() {\n for (var property in this) if (property[0] === prefix) delete this[property];\n },\n keys: function() {\n var keys = [];\n for (var property in this) if (property[0] === prefix) keys.push(property.slice(1));\n return keys;\n },\n values: function() {\n var values = [];\n for (var property in this) if (property[0] === prefix) values.push(this[property]);\n return values;\n },\n entries: function() {\n var entries = [];\n for (var property in this) if (property[0] === prefix) entries.push({key: property.slice(1), value: this[property]});\n return entries;\n },\n size: function() {\n var size = 0;\n for (var property in this) if (property[0] === prefix) ++size;\n return size;\n },\n empty: function() {\n for (var property in this) if (property[0] === prefix) return false;\n return true;\n },\n each: function(f) {\n for (var property in this) if (property[0] === prefix) f(this[property], property.slice(1), this);\n }\n};\n\nfunction map(object, f) {\n var map = new Map;\n\n // Copy constructor.\n if (object instanceof Map) object.each(function(value, key) { map.set(key, value); });\n\n // Index array by numeric index or specified key function.\n else if (Array.isArray(object)) {\n var i = -1,\n n = object.length,\n o;\n\n if (f == null) while (++i < n) map.set(i, object[i]);\n else while (++i < n) map.set(f(o = object[i], i, object), o);\n }\n\n // Convert object to map.\n else if (object) for (var key in object) map.set(key, object[key]);\n\n return map;\n}\n\nexport default map;\n","import map from \"./map\";\n\nexport default function() {\n var keys = [],\n sortKeys = [],\n sortValues,\n rollup,\n nest;\n\n function apply(array, depth, createResult, setResult) {\n if (depth >= keys.length) {\n if (sortValues != null) array.sort(sortValues);\n return rollup != null ? rollup(array) : array;\n }\n\n var i = -1,\n n = array.length,\n key = keys[depth++],\n keyValue,\n value,\n valuesByKey = map(),\n values,\n result = createResult();\n\n while (++i < n) {\n if (values = valuesByKey.get(keyValue = key(value = array[i]) + \"\")) {\n values.push(value);\n } else {\n valuesByKey.set(keyValue, [value]);\n }\n }\n\n valuesByKey.each(function(values, key) {\n setResult(result, key, apply(values, depth, createResult, setResult));\n });\n\n return result;\n }\n\n function entries(map, depth) {\n if (++depth > keys.length) return map;\n var array, sortKey = sortKeys[depth - 1];\n if (rollup != null && depth >= keys.length) array = map.entries();\n else array = [], map.each(function(v, k) { array.push({key: k, values: entries(v, depth)}); });\n return sortKey != null ? array.sort(function(a, b) { return sortKey(a.key, b.key); }) : array;\n }\n\n return nest = {\n object: function(array) { return apply(array, 0, createObject, setObject); },\n map: function(array) { return apply(array, 0, createMap, setMap); },\n entries: function(array) { return entries(apply(array, 0, createMap, setMap), 0); },\n key: function(d) { keys.push(d); return nest; },\n sortKeys: function(order) { sortKeys[keys.length - 1] = order; return nest; },\n sortValues: function(order) { sortValues = order; return nest; },\n rollup: function(f) { rollup = f; return nest; }\n };\n}\n\nfunction createObject() {\n return {};\n}\n\nfunction setObject(object, key, value) {\n object[key] = value;\n}\n\nfunction createMap() {\n return map();\n}\n\nfunction setMap(map, key, value) {\n map.set(key, value);\n}\n","import {default as map, prefix} from \"./map\";\n\nfunction Set() {}\n\nvar proto = map.prototype;\n\nSet.prototype = set.prototype = {\n constructor: Set,\n has: proto.has,\n add: function(value) {\n value += \"\";\n this[prefix + value] = value;\n return this;\n },\n remove: proto.remove,\n clear: proto.clear,\n values: proto.keys,\n size: proto.size,\n empty: proto.empty,\n each: proto.each\n};\n\nfunction set(object, f) {\n var set = new Set;\n\n // Copy constructor.\n if (object instanceof Set) object.each(function(value) { set.add(value); });\n\n // Otherwise, assume it’s an array.\n else if (object) {\n var i = -1, n = object.length;\n if (f == null) while (++i < n) set.add(object[i]);\n else while (++i < n) set.add(f(object[i], i, object));\n }\n\n return set;\n}\n\nexport default set;\n","export default function(x, y) {\n var nodes;\n\n if (x == null) x = 0;\n if (y == null) y = 0;\n\n function force() {\n var i,\n n = nodes.length,\n node,\n sx = 0,\n sy = 0;\n\n for (i = 0; i < n; ++i) {\n node = nodes[i], sx += node.x, sy += node.y;\n }\n\n for (sx = sx / n - x, sy = sy / n - y, i = 0; i < n; ++i) {\n node = nodes[i], node.x -= sx, node.y -= sy;\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n };\n\n force.x = function(_) {\n return arguments.length ? (x = +_, force) : x;\n };\n\n force.y = function(_) {\n return arguments.length ? (y = +_, force) : y;\n };\n\n return force;\n}\n","export default function(x) {\n return function() {\n return x;\n };\n}\n","export default function() {\n return (Math.random() - 0.5) * 1e-6;\n}\n","export default function(d) {\n var x = +this._x.call(null, d),\n y = +this._y.call(null, d);\n return add(this.cover(x, y), x, y, d);\n}\n\nfunction add(tree, x, y, d) {\n if (isNaN(x) || isNaN(y)) return tree; // ignore invalid points\n\n var parent,\n node = tree._root,\n leaf = {data: d},\n x0 = tree._x0,\n y0 = tree._y0,\n x1 = tree._x1,\n y1 = tree._y1,\n xm,\n ym,\n xp,\n yp,\n right,\n bottom,\n i,\n j;\n\n // If the tree is empty, initialize the root as a leaf.\n if (!node) return tree._root = leaf, tree;\n\n // Find the existing leaf for the new point, or add it.\n while (node.length) {\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n if (parent = node, !(node = node[i = bottom << 1 | right])) return parent[i] = leaf, tree;\n }\n\n // Is the new point is exactly coincident with the existing point?\n xp = +tree._x.call(null, node.data);\n yp = +tree._y.call(null, node.data);\n if (x === xp && y === yp) return leaf.next = node, parent ? parent[i] = leaf : tree._root = leaf, tree;\n\n // Otherwise, split the leaf node until the old and new point are separated.\n do {\n parent = parent ? parent[i] = new Array(4) : tree._root = new Array(4);\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n } while ((i = bottom << 1 | right) === (j = (yp >= ym) << 1 | (xp >= xm)));\n return parent[j] = node, parent[i] = leaf, tree;\n}\n\nexport function addAll(data) {\n var d, i, n = data.length,\n x,\n y,\n xz = new Array(n),\n yz = new Array(n),\n x0 = Infinity,\n y0 = Infinity,\n x1 = -Infinity,\n y1 = -Infinity;\n\n // Compute the points and their extent.\n for (i = 0; i < n; ++i) {\n if (isNaN(x = +this._x.call(null, d = data[i])) || isNaN(y = +this._y.call(null, d))) continue;\n xz[i] = x;\n yz[i] = y;\n if (x < x0) x0 = x;\n if (x > x1) x1 = x;\n if (y < y0) y0 = y;\n if (y > y1) y1 = y;\n }\n\n // If there were no (valid) points, abort.\n if (x0 > x1 || y0 > y1) return this;\n\n // Expand the tree to cover the new points.\n this.cover(x0, y0).cover(x1, y1);\n\n // Add the new points.\n for (i = 0; i < n; ++i) {\n add(this, xz[i], yz[i], data[i]);\n }\n\n return this;\n}\n","export default function(node, x0, y0, x1, y1) {\n this.node = node;\n this.x0 = x0;\n this.y0 = y0;\n this.x1 = x1;\n this.y1 = y1;\n}\n","export function defaultX(d) {\n return d[0];\n}\n\nexport default function(_) {\n return arguments.length ? (this._x = _, this) : this._x;\n}\n","export function defaultY(d) {\n return d[1];\n}\n\nexport default function(_) {\n return arguments.length ? (this._y = _, this) : this._y;\n}\n","import tree_add, {addAll as tree_addAll} from \"./add.js\";\nimport tree_cover from \"./cover.js\";\nimport tree_data from \"./data.js\";\nimport tree_extent from \"./extent.js\";\nimport tree_find from \"./find.js\";\nimport tree_remove, {removeAll as tree_removeAll} from \"./remove.js\";\nimport tree_root from \"./root.js\";\nimport tree_size from \"./size.js\";\nimport tree_visit from \"./visit.js\";\nimport tree_visitAfter from \"./visitAfter.js\";\nimport tree_x, {defaultX} from \"./x.js\";\nimport tree_y, {defaultY} from \"./y.js\";\n\nexport default function quadtree(nodes, x, y) {\n var tree = new Quadtree(x == null ? defaultX : x, y == null ? defaultY : y, NaN, NaN, NaN, NaN);\n return nodes == null ? tree : tree.addAll(nodes);\n}\n\nfunction Quadtree(x, y, x0, y0, x1, y1) {\n this._x = x;\n this._y = y;\n this._x0 = x0;\n this._y0 = y0;\n this._x1 = x1;\n this._y1 = y1;\n this._root = undefined;\n}\n\nfunction leaf_copy(leaf) {\n var copy = {data: leaf.data}, next = copy;\n while (leaf = leaf.next) next = next.next = {data: leaf.data};\n return copy;\n}\n\nvar treeProto = quadtree.prototype = Quadtree.prototype;\n\ntreeProto.copy = function() {\n var copy = new Quadtree(this._x, this._y, this._x0, this._y0, this._x1, this._y1),\n node = this._root,\n nodes,\n child;\n\n if (!node) return copy;\n\n if (!node.length) return copy._root = leaf_copy(node), copy;\n\n nodes = [{source: node, target: copy._root = new Array(4)}];\n while (node = nodes.pop()) {\n for (var i = 0; i < 4; ++i) {\n if (child = node.source[i]) {\n if (child.length) nodes.push({source: child, target: node.target[i] = new Array(4)});\n else node.target[i] = leaf_copy(child);\n }\n }\n }\n\n return copy;\n};\n\ntreeProto.add = tree_add;\ntreeProto.addAll = tree_addAll;\ntreeProto.cover = tree_cover;\ntreeProto.data = tree_data;\ntreeProto.extent = tree_extent;\ntreeProto.find = tree_find;\ntreeProto.remove = tree_remove;\ntreeProto.removeAll = tree_removeAll;\ntreeProto.root = tree_root;\ntreeProto.size = tree_size;\ntreeProto.visit = tree_visit;\ntreeProto.visitAfter = tree_visitAfter;\ntreeProto.x = tree_x;\ntreeProto.y = tree_y;\n","import constant from \"./constant\";\nimport jiggle from \"./jiggle\";\nimport {quadtree} from \"d3-quadtree\";\n\nfunction x(d) {\n return d.x + d.vx;\n}\n\nfunction y(d) {\n return d.y + d.vy;\n}\n\nexport default function(radius) {\n var nodes,\n radii,\n strength = 1,\n iterations = 1;\n\n if (typeof radius !== \"function\") radius = constant(radius == null ? 1 : +radius);\n\n function force() {\n var i, n = nodes.length,\n tree,\n node,\n xi,\n yi,\n ri,\n ri2;\n\n for (var k = 0; k < iterations; ++k) {\n tree = quadtree(nodes, x, y).visitAfter(prepare);\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n ri = radii[node.index], ri2 = ri * ri;\n xi = node.x + node.vx;\n yi = node.y + node.vy;\n tree.visit(apply);\n }\n }\n\n function apply(quad, x0, y0, x1, y1) {\n var data = quad.data, rj = quad.r, r = ri + rj;\n if (data) {\n if (data.index > node.index) {\n var x = xi - data.x - data.vx,\n y = yi - data.y - data.vy,\n l = x * x + y * y;\n if (l < r * r) {\n if (x === 0) x = jiggle(), l += x * x;\n if (y === 0) y = jiggle(), l += y * y;\n l = (r - (l = Math.sqrt(l))) / l * strength;\n node.vx += (x *= l) * (r = (rj *= rj) / (ri2 + rj));\n node.vy += (y *= l) * r;\n data.vx -= x * (r = 1 - r);\n data.vy -= y * r;\n }\n }\n return;\n }\n return x0 > xi + r || x1 < xi - r || y0 > yi + r || y1 < yi - r;\n }\n }\n\n function prepare(quad) {\n if (quad.data) return quad.r = radii[quad.data.index];\n for (var i = quad.r = 0; i < 4; ++i) {\n if (quad[i] && quad[i].r > quad.r) {\n quad.r = quad[i].r;\n }\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length, node;\n radii = new Array(n);\n for (i = 0; i < n; ++i) node = nodes[i], radii[node.index] = +radius(node, i, nodes);\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.iterations = function(_) {\n return arguments.length ? (iterations = +_, force) : iterations;\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = +_, force) : strength;\n };\n\n force.radius = function(_) {\n return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : radius;\n };\n\n return force;\n}\n","export default function(x, y) {\n if (isNaN(x = +x) || isNaN(y = +y)) return this; // ignore invalid points\n\n var x0 = this._x0,\n y0 = this._y0,\n x1 = this._x1,\n y1 = this._y1;\n\n // If the quadtree has no extent, initialize them.\n // Integer extent are necessary so that if we later double the extent,\n // the existing quadrant boundaries don’t change due to floating point error!\n if (isNaN(x0)) {\n x1 = (x0 = Math.floor(x)) + 1;\n y1 = (y0 = Math.floor(y)) + 1;\n }\n\n // Otherwise, double repeatedly to cover.\n else {\n var z = x1 - x0,\n node = this._root,\n parent,\n i;\n\n while (x0 > x || x >= x1 || y0 > y || y >= y1) {\n i = (y < y0) << 1 | (x < x0);\n parent = new Array(4), parent[i] = node, node = parent, z *= 2;\n switch (i) {\n case 0: x1 = x0 + z, y1 = y0 + z; break;\n case 1: x0 = x1 - z, y1 = y0 + z; break;\n case 2: x1 = x0 + z, y0 = y1 - z; break;\n case 3: x0 = x1 - z, y0 = y1 - z; break;\n }\n }\n\n if (this._root && this._root.length) this._root = node;\n }\n\n this._x0 = x0;\n this._y0 = y0;\n this._x1 = x1;\n this._y1 = y1;\n return this;\n}\n","export default function() {\n var data = [];\n this.visit(function(node) {\n if (!node.length) do data.push(node.data); while (node = node.next)\n });\n return data;\n}\n","export default function(_) {\n return arguments.length\n ? this.cover(+_[0][0], +_[0][1]).cover(+_[1][0], +_[1][1])\n : isNaN(this._x0) ? undefined : [[this._x0, this._y0], [this._x1, this._y1]];\n}\n","import Quad from \"./quad.js\";\n\nexport default function(x, y, radius) {\n var data,\n x0 = this._x0,\n y0 = this._y0,\n x1,\n y1,\n x2,\n y2,\n x3 = this._x1,\n y3 = this._y1,\n quads = [],\n node = this._root,\n q,\n i;\n\n if (node) quads.push(new Quad(node, x0, y0, x3, y3));\n if (radius == null) radius = Infinity;\n else {\n x0 = x - radius, y0 = y - radius;\n x3 = x + radius, y3 = y + radius;\n radius *= radius;\n }\n\n while (q = quads.pop()) {\n\n // Stop searching if this quadrant can’t contain a closer node.\n if (!(node = q.node)\n || (x1 = q.x0) > x3\n || (y1 = q.y0) > y3\n || (x2 = q.x1) < x0\n || (y2 = q.y1) < y0) continue;\n\n // Bisect the current quadrant.\n if (node.length) {\n var xm = (x1 + x2) / 2,\n ym = (y1 + y2) / 2;\n\n quads.push(\n new Quad(node[3], xm, ym, x2, y2),\n new Quad(node[2], x1, ym, xm, y2),\n new Quad(node[1], xm, y1, x2, ym),\n new Quad(node[0], x1, y1, xm, ym)\n );\n\n // Visit the closest quadrant first.\n if (i = (y >= ym) << 1 | (x >= xm)) {\n q = quads[quads.length - 1];\n quads[quads.length - 1] = quads[quads.length - 1 - i];\n quads[quads.length - 1 - i] = q;\n }\n }\n\n // Visit this point. (Visiting coincident points isn’t necessary!)\n else {\n var dx = x - +this._x.call(null, node.data),\n dy = y - +this._y.call(null, node.data),\n d2 = dx * dx + dy * dy;\n if (d2 < radius) {\n var d = Math.sqrt(radius = d2);\n x0 = x - d, y0 = y - d;\n x3 = x + d, y3 = y + d;\n data = node.data;\n }\n }\n }\n\n return data;\n}\n","export default function(d) {\n if (isNaN(x = +this._x.call(null, d)) || isNaN(y = +this._y.call(null, d))) return this; // ignore invalid points\n\n var parent,\n node = this._root,\n retainer,\n previous,\n next,\n x0 = this._x0,\n y0 = this._y0,\n x1 = this._x1,\n y1 = this._y1,\n x,\n y,\n xm,\n ym,\n right,\n bottom,\n i,\n j;\n\n // If the tree is empty, initialize the root as a leaf.\n if (!node) return this;\n\n // Find the leaf node for the point.\n // While descending, also retain the deepest parent with a non-removed sibling.\n if (node.length) while (true) {\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n if (!(parent = node, node = node[i = bottom << 1 | right])) return this;\n if (!node.length) break;\n if (parent[(i + 1) & 3] || parent[(i + 2) & 3] || parent[(i + 3) & 3]) retainer = parent, j = i;\n }\n\n // Find the point to remove.\n while (node.data !== d) if (!(previous = node, node = node.next)) return this;\n if (next = node.next) delete node.next;\n\n // If there are multiple coincident points, remove just the point.\n if (previous) return (next ? previous.next = next : delete previous.next), this;\n\n // If this is the root point, remove it.\n if (!parent) return this._root = next, this;\n\n // Remove this leaf.\n next ? parent[i] = next : delete parent[i];\n\n // If the parent now contains exactly one leaf, collapse superfluous parents.\n if ((node = parent[0] || parent[1] || parent[2] || parent[3])\n && node === (parent[3] || parent[2] || parent[1] || parent[0])\n && !node.length) {\n if (retainer) retainer[j] = node;\n else this._root = node;\n }\n\n return this;\n}\n\nexport function removeAll(data) {\n for (var i = 0, n = data.length; i < n; ++i) this.remove(data[i]);\n return this;\n}\n","export default function() {\n return this._root;\n}\n","export default function() {\n var size = 0;\n this.visit(function(node) {\n if (!node.length) do ++size; while (node = node.next)\n });\n return size;\n}\n","import Quad from \"./quad.js\";\n\nexport default function(callback) {\n var quads = [], q, node = this._root, child, x0, y0, x1, y1;\n if (node) quads.push(new Quad(node, this._x0, this._y0, this._x1, this._y1));\n while (q = quads.pop()) {\n if (!callback(node = q.node, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1) && node.length) {\n var xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;\n if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));\n if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));\n if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));\n if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));\n }\n }\n return this;\n}\n","import Quad from \"./quad.js\";\n\nexport default function(callback) {\n var quads = [], next = [], q;\n if (this._root) quads.push(new Quad(this._root, this._x0, this._y0, this._x1, this._y1));\n while (q = quads.pop()) {\n var node = q.node;\n if (node.length) {\n var child, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1, xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;\n if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));\n if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));\n if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));\n if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));\n }\n next.push(q);\n }\n while (q = next.pop()) {\n callback(q.node, q.x0, q.y0, q.x1, q.y1);\n }\n return this;\n}\n","import constant from \"./constant\";\nimport jiggle from \"./jiggle\";\nimport {map} from \"d3-collection\";\n\nfunction index(d) {\n return d.index;\n}\n\nfunction find(nodeById, nodeId) {\n var node = nodeById.get(nodeId);\n if (!node) throw new Error(\"missing: \" + nodeId);\n return node;\n}\n\nexport default function(links) {\n var id = index,\n strength = defaultStrength,\n strengths,\n distance = constant(30),\n distances,\n nodes,\n count,\n bias,\n iterations = 1;\n\n if (links == null) links = [];\n\n function defaultStrength(link) {\n return 1 / Math.min(count[link.source.index], count[link.target.index]);\n }\n\n function force(alpha) {\n for (var k = 0, n = links.length; k < iterations; ++k) {\n for (var i = 0, link, source, target, x, y, l, b; i < n; ++i) {\n link = links[i], source = link.source, target = link.target;\n x = target.x + target.vx - source.x - source.vx || jiggle();\n y = target.y + target.vy - source.y - source.vy || jiggle();\n l = Math.sqrt(x * x + y * y);\n l = (l - distances[i]) / l * alpha * strengths[i];\n x *= l, y *= l;\n target.vx -= x * (b = bias[i]);\n target.vy -= y * b;\n source.vx += x * (b = 1 - b);\n source.vy += y * b;\n }\n }\n }\n\n function initialize() {\n if (!nodes) return;\n\n var i,\n n = nodes.length,\n m = links.length,\n nodeById = map(nodes, id),\n link;\n\n for (i = 0, count = new Array(n); i < m; ++i) {\n link = links[i], link.index = i;\n if (typeof link.source !== \"object\") link.source = find(nodeById, link.source);\n if (typeof link.target !== \"object\") link.target = find(nodeById, link.target);\n count[link.source.index] = (count[link.source.index] || 0) + 1;\n count[link.target.index] = (count[link.target.index] || 0) + 1;\n }\n\n for (i = 0, bias = new Array(m); i < m; ++i) {\n link = links[i], bias[i] = count[link.source.index] / (count[link.source.index] + count[link.target.index]);\n }\n\n strengths = new Array(m), initializeStrength();\n distances = new Array(m), initializeDistance();\n }\n\n function initializeStrength() {\n if (!nodes) return;\n\n for (var i = 0, n = links.length; i < n; ++i) {\n strengths[i] = +strength(links[i], i, links);\n }\n }\n\n function initializeDistance() {\n if (!nodes) return;\n\n for (var i = 0, n = links.length; i < n; ++i) {\n distances[i] = +distance(links[i], i, links);\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.links = function(_) {\n return arguments.length ? (links = _, initialize(), force) : links;\n };\n\n force.id = function(_) {\n return arguments.length ? (id = _, force) : id;\n };\n\n force.iterations = function(_) {\n return arguments.length ? (iterations = +_, force) : iterations;\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant(+_), initializeStrength(), force) : strength;\n };\n\n force.distance = function(_) {\n return arguments.length ? (distance = typeof _ === \"function\" ? _ : constant(+_), initializeDistance(), force) : distance;\n };\n\n return force;\n}\n","var noop = {value: function() {}};\n\nfunction dispatch() {\n for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {\n if (!(t = arguments[i] + \"\") || (t in _) || /[\\s.]/.test(t)) throw new Error(\"illegal type: \" + t);\n _[t] = [];\n }\n return new Dispatch(_);\n}\n\nfunction Dispatch(_) {\n this._ = _;\n}\n\nfunction parseTypenames(typenames, types) {\n return typenames.trim().split(/^|\\s+/).map(function(t) {\n var name = \"\", i = t.indexOf(\".\");\n if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n if (t && !types.hasOwnProperty(t)) throw new Error(\"unknown type: \" + t);\n return {type: t, name: name};\n });\n}\n\nDispatch.prototype = dispatch.prototype = {\n constructor: Dispatch,\n on: function(typename, callback) {\n var _ = this._,\n T = parseTypenames(typename + \"\", _),\n t,\n i = -1,\n n = T.length;\n\n // If no callback was specified, return the callback of the given type and name.\n if (arguments.length < 2) {\n while (++i < n) if ((t = (typename = T[i]).type) && (t = get(_[t], typename.name))) return t;\n return;\n }\n\n // If a type was specified, set the callback for the given type and name.\n // Otherwise, if a null callback was specified, remove callbacks of the given name.\n if (callback != null && typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n while (++i < n) {\n if (t = (typename = T[i]).type) _[t] = set(_[t], typename.name, callback);\n else if (callback == null) for (t in _) _[t] = set(_[t], typename.name, null);\n }\n\n return this;\n },\n copy: function() {\n var copy = {}, _ = this._;\n for (var t in _) copy[t] = _[t].slice();\n return new Dispatch(copy);\n },\n call: function(type, that) {\n if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];\n if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n },\n apply: function(type, that, args) {\n if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n }\n};\n\nfunction get(type, name) {\n for (var i = 0, n = type.length, c; i < n; ++i) {\n if ((c = type[i]).name === name) {\n return c.value;\n }\n }\n}\n\nfunction set(type, name, callback) {\n for (var i = 0, n = type.length; i < n; ++i) {\n if (type[i].name === name) {\n type[i] = noop, type = type.slice(0, i).concat(type.slice(i + 1));\n break;\n }\n }\n if (callback != null) type.push({name: name, value: callback});\n return type;\n}\n\nexport default dispatch;\n","var frame = 0, // is an animation frame pending?\n timeout = 0, // is a timeout pending?\n interval = 0, // are any timers active?\n pokeDelay = 1000, // how frequently we check for clock skew\n taskHead,\n taskTail,\n clockLast = 0,\n clockNow = 0,\n clockSkew = 0,\n clock = typeof performance === \"object\" && performance.now ? performance : Date,\n setFrame = typeof window === \"object\" && window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : function(f) { setTimeout(f, 17); };\n\nexport function now() {\n return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);\n}\n\nfunction clearNow() {\n clockNow = 0;\n}\n\nexport function Timer() {\n this._call =\n this._time =\n this._next = null;\n}\n\nTimer.prototype = timer.prototype = {\n constructor: Timer,\n restart: function(callback, delay, time) {\n if (typeof callback !== \"function\") throw new TypeError(\"callback is not a function\");\n time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);\n if (!this._next && taskTail !== this) {\n if (taskTail) taskTail._next = this;\n else taskHead = this;\n taskTail = this;\n }\n this._call = callback;\n this._time = time;\n sleep();\n },\n stop: function() {\n if (this._call) {\n this._call = null;\n this._time = Infinity;\n sleep();\n }\n }\n};\n\nexport function timer(callback, delay, time) {\n var t = new Timer;\n t.restart(callback, delay, time);\n return t;\n}\n\nexport function timerFlush() {\n now(); // Get the current time, if not already set.\n ++frame; // Pretend we’ve set an alarm, if we haven’t already.\n var t = taskHead, e;\n while (t) {\n if ((e = clockNow - t._time) >= 0) t._call.call(null, e);\n t = t._next;\n }\n --frame;\n}\n\nfunction wake() {\n clockNow = (clockLast = clock.now()) + clockSkew;\n frame = timeout = 0;\n try {\n timerFlush();\n } finally {\n frame = 0;\n nap();\n clockNow = 0;\n }\n}\n\nfunction poke() {\n var now = clock.now(), delay = now - clockLast;\n if (delay > pokeDelay) clockSkew -= delay, clockLast = now;\n}\n\nfunction nap() {\n var t0, t1 = taskHead, t2, time = Infinity;\n while (t1) {\n if (t1._call) {\n if (time > t1._time) time = t1._time;\n t0 = t1, t1 = t1._next;\n } else {\n t2 = t1._next, t1._next = null;\n t1 = t0 ? t0._next = t2 : taskHead = t2;\n }\n }\n taskTail = t0;\n sleep(time);\n}\n\nfunction sleep(time) {\n if (frame) return; // Soonest alarm already set, or will be.\n if (timeout) timeout = clearTimeout(timeout);\n var delay = time - clockNow; // Strictly less than if we recomputed clockNow.\n if (delay > 24) {\n if (time < Infinity) timeout = setTimeout(wake, time - clock.now() - clockSkew);\n if (interval) interval = clearInterval(interval);\n } else {\n if (!interval) clockLast = clock.now(), interval = setInterval(poke, pokeDelay);\n frame = 1, setFrame(wake);\n }\n}\n","import {dispatch} from \"d3-dispatch\";\nimport {map} from \"d3-collection\";\nimport {timer} from \"d3-timer\";\n\nexport function x(d) {\n return d.x;\n}\n\nexport function y(d) {\n return d.y;\n}\n\nvar initialRadius = 10,\n initialAngle = Math.PI * (3 - Math.sqrt(5));\n\nexport default function(nodes) {\n var simulation,\n alpha = 1,\n alphaMin = 0.001,\n alphaDecay = 1 - Math.pow(alphaMin, 1 / 300),\n alphaTarget = 0,\n velocityDecay = 0.6,\n forces = map(),\n stepper = timer(step),\n event = dispatch(\"tick\", \"end\");\n\n if (nodes == null) nodes = [];\n\n function step() {\n tick();\n event.call(\"tick\", simulation);\n if (alpha < alphaMin) {\n stepper.stop();\n event.call(\"end\", simulation);\n }\n }\n\n function tick(iterations) {\n var i, n = nodes.length, node;\n\n if (iterations === undefined) iterations = 1;\n\n for (var k = 0; k < iterations; ++k) {\n alpha += (alphaTarget - alpha) * alphaDecay;\n\n forces.each(function (force) {\n force(alpha);\n });\n\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n if (node.fx == null) node.x += node.vx *= velocityDecay;\n else node.x = node.fx, node.vx = 0;\n if (node.fy == null) node.y += node.vy *= velocityDecay;\n else node.y = node.fy, node.vy = 0;\n }\n }\n\n return simulation;\n }\n\n function initializeNodes() {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.index = i;\n if (node.fx != null) node.x = node.fx;\n if (node.fy != null) node.y = node.fy;\n if (isNaN(node.x) || isNaN(node.y)) {\n var radius = initialRadius * Math.sqrt(i), angle = i * initialAngle;\n node.x = radius * Math.cos(angle);\n node.y = radius * Math.sin(angle);\n }\n if (isNaN(node.vx) || isNaN(node.vy)) {\n node.vx = node.vy = 0;\n }\n }\n }\n\n function initializeForce(force) {\n if (force.initialize) force.initialize(nodes);\n return force;\n }\n\n initializeNodes();\n\n return simulation = {\n tick: tick,\n\n restart: function() {\n return stepper.restart(step), simulation;\n },\n\n stop: function() {\n return stepper.stop(), simulation;\n },\n\n nodes: function(_) {\n return arguments.length ? (nodes = _, initializeNodes(), forces.each(initializeForce), simulation) : nodes;\n },\n\n alpha: function(_) {\n return arguments.length ? (alpha = +_, simulation) : alpha;\n },\n\n alphaMin: function(_) {\n return arguments.length ? (alphaMin = +_, simulation) : alphaMin;\n },\n\n alphaDecay: function(_) {\n return arguments.length ? (alphaDecay = +_, simulation) : +alphaDecay;\n },\n\n alphaTarget: function(_) {\n return arguments.length ? (alphaTarget = +_, simulation) : alphaTarget;\n },\n\n velocityDecay: function(_) {\n return arguments.length ? (velocityDecay = 1 - _, simulation) : 1 - velocityDecay;\n },\n\n force: function(name, _) {\n return arguments.length > 1 ? ((_ == null ? forces.remove(name) : forces.set(name, initializeForce(_))), simulation) : forces.get(name);\n },\n\n find: function(x, y, radius) {\n var i = 0,\n n = nodes.length,\n dx,\n dy,\n d2,\n node,\n closest;\n\n if (radius == null) radius = Infinity;\n else radius *= radius;\n\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n dx = x - node.x;\n dy = y - node.y;\n d2 = dx * dx + dy * dy;\n if (d2 < radius) closest = node, radius = d2;\n }\n\n return closest;\n },\n\n on: function(name, _) {\n return arguments.length > 1 ? (event.on(name, _), simulation) : event.on(name);\n }\n };\n}\n","import constant from \"./constant\";\nimport jiggle from \"./jiggle\";\nimport {quadtree} from \"d3-quadtree\";\nimport {x, y} from \"./simulation\";\n\nexport default function() {\n var nodes,\n node,\n alpha,\n strength = constant(-30),\n strengths,\n distanceMin2 = 1,\n distanceMax2 = Infinity,\n theta2 = 0.81;\n\n function force(_) {\n var i, n = nodes.length, tree = quadtree(nodes, x, y).visitAfter(accumulate);\n for (alpha = _, i = 0; i < n; ++i) node = nodes[i], tree.visit(apply);\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length, node;\n strengths = new Array(n);\n for (i = 0; i < n; ++i) node = nodes[i], strengths[node.index] = +strength(node, i, nodes);\n }\n\n function accumulate(quad) {\n var strength = 0, q, c, weight = 0, x, y, i;\n\n // For internal nodes, accumulate forces from child quadrants.\n if (quad.length) {\n for (x = y = i = 0; i < 4; ++i) {\n if ((q = quad[i]) && (c = Math.abs(q.value))) {\n strength += q.value, weight += c, x += c * q.x, y += c * q.y;\n }\n }\n quad.x = x / weight;\n quad.y = y / weight;\n }\n\n // For leaf nodes, accumulate forces from coincident quadrants.\n else {\n q = quad;\n q.x = q.data.x;\n q.y = q.data.y;\n do strength += strengths[q.data.index];\n while (q = q.next);\n }\n\n quad.value = strength;\n }\n\n function apply(quad, x1, _, x2) {\n if (!quad.value) return true;\n\n var x = quad.x - node.x,\n y = quad.y - node.y,\n w = x2 - x1,\n l = x * x + y * y;\n\n // Apply the Barnes-Hut approximation if possible.\n // Limit forces for very close nodes; randomize direction if coincident.\n if (w * w / theta2 < l) {\n if (l < distanceMax2) {\n if (x === 0) x = jiggle(), l += x * x;\n if (y === 0) y = jiggle(), l += y * y;\n if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);\n node.vx += x * quad.value * alpha / l;\n node.vy += y * quad.value * alpha / l;\n }\n return true;\n }\n\n // Otherwise, process points directly.\n else if (quad.length || l >= distanceMax2) return;\n\n // Limit forces for very close nodes; randomize direction if coincident.\n if (quad.data !== node || quad.next) {\n if (x === 0) x = jiggle(), l += x * x;\n if (y === 0) y = jiggle(), l += y * y;\n if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);\n }\n\n do if (quad.data !== node) {\n w = strengths[quad.data.index] * alpha / l;\n node.vx += x * w;\n node.vy += y * w;\n } while (quad = quad.next);\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : strength;\n };\n\n force.distanceMin = function(_) {\n return arguments.length ? (distanceMin2 = _ * _, force) : Math.sqrt(distanceMin2);\n };\n\n force.distanceMax = function(_) {\n return arguments.length ? (distanceMax2 = _ * _, force) : Math.sqrt(distanceMax2);\n };\n\n force.theta = function(_) {\n return arguments.length ? (theta2 = _ * _, force) : Math.sqrt(theta2);\n };\n\n return force;\n}\n","import constant from \"./constant\";\n\nexport default function(radius, x, y) {\n var nodes,\n strength = constant(0.1),\n strengths,\n radiuses;\n\n if (typeof radius !== \"function\") radius = constant(+radius);\n if (x == null) x = 0;\n if (y == null) y = 0;\n\n function force(alpha) {\n for (var i = 0, n = nodes.length; i < n; ++i) {\n var node = nodes[i],\n dx = node.x - x || 1e-6,\n dy = node.y - y || 1e-6,\n r = Math.sqrt(dx * dx + dy * dy),\n k = (radiuses[i] - r) * strengths[i] * alpha / r;\n node.vx += dx * k;\n node.vy += dy * k;\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length;\n strengths = new Array(n);\n radiuses = new Array(n);\n for (i = 0; i < n; ++i) {\n radiuses[i] = +radius(nodes[i], i, nodes);\n strengths[i] = isNaN(radiuses[i]) ? 0 : +strength(nodes[i], i, nodes);\n }\n }\n\n force.initialize = function(_) {\n nodes = _, initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : strength;\n };\n\n force.radius = function(_) {\n return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : radius;\n };\n\n force.x = function(_) {\n return arguments.length ? (x = +_, force) : x;\n };\n\n force.y = function(_) {\n return arguments.length ? (y = +_, force) : y;\n };\n\n return force;\n}\n","import constant from \"./constant\";\n\nexport default function(x) {\n var strength = constant(0.1),\n nodes,\n strengths,\n xz;\n\n if (typeof x !== \"function\") x = constant(x == null ? 0 : +x);\n\n function force(alpha) {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.vx += (xz[i] - node.x) * strengths[i] * alpha;\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length;\n strengths = new Array(n);\n xz = new Array(n);\n for (i = 0; i < n; ++i) {\n strengths[i] = isNaN(xz[i] = +x(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : strength;\n };\n\n force.x = function(_) {\n return arguments.length ? (x = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : x;\n };\n\n return force;\n}\n","import constant from \"./constant\";\n\nexport default function(y) {\n var strength = constant(0.1),\n nodes,\n strengths,\n yz;\n\n if (typeof y !== \"function\") y = constant(y == null ? 0 : +y);\n\n function force(alpha) {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.vy += (yz[i] - node.y) * strengths[i] * alpha;\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length;\n strengths = new Array(n);\n yz = new Array(n);\n for (i = 0; i < n; ++i) {\n strengths[i] = isNaN(yz[i] = +y(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : strength;\n };\n\n force.y = function(_) {\n return arguments.length ? (y = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : y;\n };\n\n return force;\n}\n","export default function(x) {\n return Math.abs(x = Math.round(x)) >= 1e21\n ? x.toLocaleString(\"en\").replace(/,/g, \"\")\n : x.toString(10);\n}\n\n// Computes the decimal coefficient and exponent of the specified number x with\n// significant digits p, where x is positive and p is in [1, 21] or undefined.\n// For example, formatDecimalParts(1.23) returns [\"123\", 0].\nexport function formatDecimalParts(x, p) {\n if ((i = (x = p ? x.toExponential(p - 1) : x.toExponential()).indexOf(\"e\")) < 0) return null; // NaN, ±Infinity\n var i, coefficient = x.slice(0, i);\n\n // The string returned by toExponential either has the form \\d\\.\\d+e[-+]\\d+\n // (e.g., 1.2e+3) or the form \\de[-+]\\d+ (e.g., 1e+3).\n return [\n coefficient.length > 1 ? coefficient[0] + coefficient.slice(2) : coefficient,\n +x.slice(i + 1)\n ];\n}\n","// [[fill]align][sign][symbol][0][width][,][.precision][~][type]\nvar re = /^(?:(.)?([<>=^]))?([+\\-( ])?([$#])?(0)?(\\d+)?(,)?(\\.\\d+)?(~)?([a-z%])?$/i;\n\nexport default function formatSpecifier(specifier) {\n if (!(match = re.exec(specifier))) throw new Error(\"invalid format: \" + specifier);\n var match;\n return new FormatSpecifier({\n fill: match[1],\n align: match[2],\n sign: match[3],\n symbol: match[4],\n zero: match[5],\n width: match[6],\n comma: match[7],\n precision: match[8] && match[8].slice(1),\n trim: match[9],\n type: match[10]\n });\n}\n\nformatSpecifier.prototype = FormatSpecifier.prototype; // instanceof\n\nexport function FormatSpecifier(specifier) {\n this.fill = specifier.fill === undefined ? \" \" : specifier.fill + \"\";\n this.align = specifier.align === undefined ? \">\" : specifier.align + \"\";\n this.sign = specifier.sign === undefined ? \"-\" : specifier.sign + \"\";\n this.symbol = specifier.symbol === undefined ? \"\" : specifier.symbol + \"\";\n this.zero = !!specifier.zero;\n this.width = specifier.width === undefined ? undefined : +specifier.width;\n this.comma = !!specifier.comma;\n this.precision = specifier.precision === undefined ? undefined : +specifier.precision;\n this.trim = !!specifier.trim;\n this.type = specifier.type === undefined ? \"\" : specifier.type + \"\";\n}\n\nFormatSpecifier.prototype.toString = function() {\n return this.fill\n + this.align\n + this.sign\n + this.symbol\n + (this.zero ? \"0\" : \"\")\n + (this.width === undefined ? \"\" : Math.max(1, this.width | 0))\n + (this.comma ? \",\" : \"\")\n + (this.precision === undefined ? \"\" : \".\" + Math.max(0, this.precision | 0))\n + (this.trim ? \"~\" : \"\")\n + this.type;\n};\n","import {formatDecimalParts} from \"./formatDecimal.js\";\n\nexport var prefixExponent;\n\nexport default function(x, p) {\n var d = formatDecimalParts(x, p);\n if (!d) return x + \"\";\n var coefficient = d[0],\n exponent = d[1],\n i = exponent - (prefixExponent = Math.max(-8, Math.min(8, Math.floor(exponent / 3))) * 3) + 1,\n n = coefficient.length;\n return i === n ? coefficient\n : i > n ? coefficient + new Array(i - n + 1).join(\"0\")\n : i > 0 ? coefficient.slice(0, i) + \".\" + coefficient.slice(i)\n : \"0.\" + new Array(1 - i).join(\"0\") + formatDecimalParts(x, Math.max(0, p + i - 1))[0]; // less than 1y!\n}\n","import {formatDecimalParts} from \"./formatDecimal.js\";\n\nexport default function(x, p) {\n var d = formatDecimalParts(x, p);\n if (!d) return x + \"\";\n var coefficient = d[0],\n exponent = d[1];\n return exponent < 0 ? \"0.\" + new Array(-exponent).join(\"0\") + coefficient\n : coefficient.length > exponent + 1 ? coefficient.slice(0, exponent + 1) + \".\" + coefficient.slice(exponent + 1)\n : coefficient + new Array(exponent - coefficient.length + 2).join(\"0\");\n}\n","import formatDecimal from \"./formatDecimal.js\";\nimport formatPrefixAuto from \"./formatPrefixAuto.js\";\nimport formatRounded from \"./formatRounded.js\";\n\nexport default {\n \"%\": function(x, p) { return (x * 100).toFixed(p); },\n \"b\": function(x) { return Math.round(x).toString(2); },\n \"c\": function(x) { return x + \"\"; },\n \"d\": formatDecimal,\n \"e\": function(x, p) { return x.toExponential(p); },\n \"f\": function(x, p) { return x.toFixed(p); },\n \"g\": function(x, p) { return x.toPrecision(p); },\n \"o\": function(x) { return Math.round(x).toString(8); },\n \"p\": function(x, p) { return formatRounded(x * 100, p); },\n \"r\": formatRounded,\n \"s\": formatPrefixAuto,\n \"X\": function(x) { return Math.round(x).toString(16).toUpperCase(); },\n \"x\": function(x) { return Math.round(x).toString(16); }\n};\n","export default function(x) {\n return x;\n}\n","import exponent from \"./exponent.js\";\nimport formatGroup from \"./formatGroup.js\";\nimport formatNumerals from \"./formatNumerals.js\";\nimport formatSpecifier from \"./formatSpecifier.js\";\nimport formatTrim from \"./formatTrim.js\";\nimport formatTypes from \"./formatTypes.js\";\nimport {prefixExponent} from \"./formatPrefixAuto.js\";\nimport identity from \"./identity.js\";\n\nvar map = Array.prototype.map,\n prefixes = [\"y\",\"z\",\"a\",\"f\",\"p\",\"n\",\"µ\",\"m\",\"\",\"k\",\"M\",\"G\",\"T\",\"P\",\"E\",\"Z\",\"Y\"];\n\nexport default function(locale) {\n var group = locale.grouping === undefined || locale.thousands === undefined ? identity : formatGroup(map.call(locale.grouping, Number), locale.thousands + \"\"),\n currencyPrefix = locale.currency === undefined ? \"\" : locale.currency[0] + \"\",\n currencySuffix = locale.currency === undefined ? \"\" : locale.currency[1] + \"\",\n decimal = locale.decimal === undefined ? \".\" : locale.decimal + \"\",\n numerals = locale.numerals === undefined ? identity : formatNumerals(map.call(locale.numerals, String)),\n percent = locale.percent === undefined ? \"%\" : locale.percent + \"\",\n minus = locale.minus === undefined ? \"-\" : locale.minus + \"\",\n nan = locale.nan === undefined ? \"NaN\" : locale.nan + \"\";\n\n function newFormat(specifier) {\n specifier = formatSpecifier(specifier);\n\n var fill = specifier.fill,\n align = specifier.align,\n sign = specifier.sign,\n symbol = specifier.symbol,\n zero = specifier.zero,\n width = specifier.width,\n comma = specifier.comma,\n precision = specifier.precision,\n trim = specifier.trim,\n type = specifier.type;\n\n // The \"n\" type is an alias for \",g\".\n if (type === \"n\") comma = true, type = \"g\";\n\n // The \"\" type, and any invalid type, is an alias for \".12~g\".\n else if (!formatTypes[type]) precision === undefined && (precision = 12), trim = true, type = \"g\";\n\n // If zero fill is specified, padding goes after sign and before digits.\n if (zero || (fill === \"0\" && align === \"=\")) zero = true, fill = \"0\", align = \"=\";\n\n // Compute the prefix and suffix.\n // For SI-prefix, the suffix is lazily computed.\n var prefix = symbol === \"$\" ? currencyPrefix : symbol === \"#\" && /[boxX]/.test(type) ? \"0\" + type.toLowerCase() : \"\",\n suffix = symbol === \"$\" ? currencySuffix : /[%p]/.test(type) ? percent : \"\";\n\n // What format function should we use?\n // Is this an integer type?\n // Can this type generate exponential notation?\n var formatType = formatTypes[type],\n maybeSuffix = /[defgprs%]/.test(type);\n\n // Set the default precision if not specified,\n // or clamp the specified precision to the supported range.\n // For significant precision, it must be in [1, 21].\n // For fixed precision, it must be in [0, 20].\n precision = precision === undefined ? 6\n : /[gprs]/.test(type) ? Math.max(1, Math.min(21, precision))\n : Math.max(0, Math.min(20, precision));\n\n function format(value) {\n var valuePrefix = prefix,\n valueSuffix = suffix,\n i, n, c;\n\n if (type === \"c\") {\n valueSuffix = formatType(value) + valueSuffix;\n value = \"\";\n } else {\n value = +value;\n\n // Determine the sign. -0 is not less than 0, but 1 / -0 is!\n var valueNegative = value < 0 || 1 / value < 0;\n\n // Perform the initial formatting.\n value = isNaN(value) ? nan : formatType(Math.abs(value), precision);\n\n // Trim insignificant zeros.\n if (trim) value = formatTrim(value);\n\n // If a negative value rounds to zero after formatting, and no explicit positive sign is requested, hide the sign.\n if (valueNegative && +value === 0 && sign !== \"+\") valueNegative = false;\n\n // Compute the prefix and suffix.\n valuePrefix = (valueNegative ? (sign === \"(\" ? sign : minus) : sign === \"-\" || sign === \"(\" ? \"\" : sign) + valuePrefix;\n valueSuffix = (type === \"s\" ? prefixes[8 + prefixExponent / 3] : \"\") + valueSuffix + (valueNegative && sign === \"(\" ? \")\" : \"\");\n\n // Break the formatted value into the integer “value” part that can be\n // grouped, and fractional or exponential “suffix” part that is not.\n if (maybeSuffix) {\n i = -1, n = value.length;\n while (++i < n) {\n if (c = value.charCodeAt(i), 48 > c || c > 57) {\n valueSuffix = (c === 46 ? decimal + value.slice(i + 1) : value.slice(i)) + valueSuffix;\n value = value.slice(0, i);\n break;\n }\n }\n }\n }\n\n // If the fill character is not \"0\", grouping is applied before padding.\n if (comma && !zero) value = group(value, Infinity);\n\n // Compute the padding.\n var length = valuePrefix.length + value.length + valueSuffix.length,\n padding = length < width ? new Array(width - length + 1).join(fill) : \"\";\n\n // If the fill character is \"0\", grouping is applied after padding.\n if (comma && zero) value = group(padding + value, padding.length ? width - valueSuffix.length : Infinity), padding = \"\";\n\n // Reconstruct the final output based on the desired alignment.\n switch (align) {\n case \"<\": value = valuePrefix + value + valueSuffix + padding; break;\n case \"=\": value = valuePrefix + padding + value + valueSuffix; break;\n case \"^\": value = padding.slice(0, length = padding.length >> 1) + valuePrefix + value + valueSuffix + padding.slice(length); break;\n default: value = padding + valuePrefix + value + valueSuffix; break;\n }\n\n return numerals(value);\n }\n\n format.toString = function() {\n return specifier + \"\";\n };\n\n return format;\n }\n\n function formatPrefix(specifier, value) {\n var f = newFormat((specifier = formatSpecifier(specifier), specifier.type = \"f\", specifier)),\n e = Math.max(-8, Math.min(8, Math.floor(exponent(value) / 3))) * 3,\n k = Math.pow(10, -e),\n prefix = prefixes[8 + e / 3];\n return function(value) {\n return f(k * value) + prefix;\n };\n }\n\n return {\n format: newFormat,\n formatPrefix: formatPrefix\n };\n}\n","import formatLocale from \"./locale.js\";\n\nvar locale;\nexport var format;\nexport var formatPrefix;\n\ndefaultLocale({\n decimal: \".\",\n thousands: \",\",\n grouping: [3],\n currency: [\"$\", \"\"],\n minus: \"-\"\n});\n\nexport default function defaultLocale(definition) {\n locale = formatLocale(definition);\n format = locale.format;\n formatPrefix = locale.formatPrefix;\n return locale;\n}\n","export default function(grouping, thousands) {\n return function(value, width) {\n var i = value.length,\n t = [],\n j = 0,\n g = grouping[0],\n length = 0;\n\n while (i > 0 && g > 0) {\n if (length + g + 1 > width) g = Math.max(1, width - length);\n t.push(value.substring(i -= g, i + g));\n if ((length += g + 1) > width) break;\n g = grouping[j = (j + 1) % grouping.length];\n }\n\n return t.reverse().join(thousands);\n };\n}\n","export default function(numerals) {\n return function(value) {\n return value.replace(/[0-9]/g, function(i) {\n return numerals[+i];\n });\n };\n}\n","// Trims insignificant zeros, e.g., replaces 1.2000k with 1.2k.\nexport default function(s) {\n out: for (var n = s.length, i = 1, i0 = -1, i1; i < n; ++i) {\n switch (s[i]) {\n case \".\": i0 = i1 = i; break;\n case \"0\": if (i0 === 0) i0 = i; i1 = i; break;\n default: if (!+s[i]) break out; if (i0 > 0) i0 = 0; break;\n }\n }\n return i0 > 0 ? s.slice(0, i0) + s.slice(i1 + 1) : s;\n}\n","import {formatDecimalParts} from \"./formatDecimal.js\";\n\nexport default function(x) {\n return x = formatDecimalParts(Math.abs(x)), x ? x[1] : NaN;\n}\n","export var abs = Math.abs;\nexport var atan = Math.atan;\nexport var atan2 = Math.atan2;\nexport var ceil = Math.ceil;\nexport var cos = Math.cos;\nexport var exp = Math.exp;\nexport var floor = Math.floor;\nexport var log = Math.log;\nexport var max = Math.max;\nexport var min = Math.min;\nexport var pow = Math.pow;\nexport var round = Math.round;\nexport var sign = Math.sign || function(x) { return x > 0 ? 1 : x < 0 ? -1 : 0; };\nexport var sin = Math.sin;\nexport var tan = Math.tan;\n\nexport var epsilon = 1e-6;\nexport var epsilon2 = 1e-12;\nexport var pi = Math.PI;\nexport var halfPi = pi / 2;\nexport var quarterPi = pi / 4;\nexport var sqrt1_2 = Math.SQRT1_2;\nexport var sqrt2 = sqrt(2);\nexport var sqrtPi = sqrt(pi);\nexport var tau = pi * 2;\nexport var degrees = 180 / pi;\nexport var radians = pi / 180;\n\nexport function sinci(x) {\n return x ? x / Math.sin(x) : 1;\n}\n\nexport function asin(x) {\n return x > 1 ? halfPi : x < -1 ? -halfPi : Math.asin(x);\n}\n\nexport function acos(x) {\n return x > 1 ? 0 : x < -1 ? pi : Math.acos(x);\n}\n\nexport function sqrt(x) {\n return x > 0 ? Math.sqrt(x) : 0;\n}\n\nexport function tanh(x) {\n x = exp(2 * x);\n return (x - 1) / (x + 1);\n}\n\nexport function sinh(x) {\n return (exp(x) - exp(-x)) / 2;\n}\n\nexport function cosh(x) {\n return (exp(x) + exp(-x)) / 2;\n}\n\nexport function arsinh(x) {\n return log(x + sqrt(x * x + 1));\n}\n\nexport function arcosh(x) {\n return log(x + sqrt(x * x - 1));\n}\n","import {geoProjectionMutator as projectionMutator} from \"d3-geo\";\nimport {abs, asin, atan2, cos, degrees, epsilon, halfPi, log, radians, sin, sqrt, tan} from \"./math.js\";\n\nexport function airyRaw(beta) {\n var tanBeta_2 = tan(beta / 2),\n b = 2 * log(cos(beta / 2)) / (tanBeta_2 * tanBeta_2);\n\n function forward(x, y) {\n var cosx = cos(x),\n cosy = cos(y),\n siny = sin(y),\n cosz = cosy * cosx,\n k = -((1 - cosz ? log((1 + cosz) / 2) / (1 - cosz) : -0.5) + b / (1 + cosz));\n return [k * cosy * sin(x), k * siny];\n }\n\n forward.invert = function(x, y) {\n var r = sqrt(x * x + y * y),\n z = -beta / 2,\n i = 50, delta;\n if (!r) return [0, 0];\n do {\n var z_2 = z / 2,\n cosz_2 = cos(z_2),\n sinz_2 = sin(z_2),\n tanz_2 = sinz_2 / cosz_2,\n lnsecz_2 = -log(abs(cosz_2));\n z -= delta = (2 / tanz_2 * lnsecz_2 - b * tanz_2 - r) / (-lnsecz_2 / (sinz_2 * sinz_2) + 1 - b / (2 * cosz_2 * cosz_2)) * (cosz_2 < 0 ? 0.7 : 1);\n } while (abs(delta) > epsilon && --i > 0);\n var sinz = sin(z);\n return [atan2(x * sinz, r * cos(z)), asin(y * sinz / r)];\n };\n\n return forward;\n}\n\nexport default function() {\n var beta = halfPi,\n m = projectionMutator(airyRaw),\n p = m(beta);\n\n p.radius = function(_) {\n return arguments.length ? m(beta = _ * radians) : beta * degrees;\n };\n\n return p\n .scale(179.976)\n .clipAngle(147);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, acos, cos, epsilon, pi, sin, sinci, sqrt} from \"./math.js\";\n\nexport function aitoffRaw(x, y) {\n var cosy = cos(y), sincia = sinci(acos(cosy * cos(x /= 2)));\n return [2 * cosy * sin(x) * sincia, sin(y) * sincia];\n}\n\n// Abort if [x, y] is not within an ellipse centered at [0, 0] with\n// semi-major axis pi and semi-minor axis pi/2.\naitoffRaw.invert = function(x, y) {\n if (x * x + 4 * y * y > pi * pi + epsilon) return;\n var x1 = x, y1 = y, i = 25;\n do {\n var sinx = sin(x1),\n sinx_2 = sin(x1 / 2),\n cosx_2 = cos(x1 / 2),\n siny = sin(y1),\n cosy = cos(y1),\n sin_2y = sin(2 * y1),\n sin2y = siny * siny,\n cos2y = cosy * cosy,\n sin2x_2 = sinx_2 * sinx_2,\n c = 1 - cos2y * cosx_2 * cosx_2,\n e = c ? acos(cosy * cosx_2) * sqrt(f = 1 / c) : f = 0,\n f,\n fx = 2 * e * cosy * sinx_2 - x,\n fy = e * siny - y,\n dxdx = f * (cos2y * sin2x_2 + e * cosy * cosx_2 * sin2y),\n dxdy = f * (0.5 * sinx * sin_2y - e * 2 * siny * sinx_2),\n dydx = f * 0.25 * (sin_2y * sinx_2 - e * siny * cos2y * sinx),\n dydy = f * (sin2y * cosx_2 + e * sin2x_2 * cosy),\n z = dxdy * dydx - dydy * dxdx;\n if (!z) break;\n var dx = (fy * dxdy - fx * dydy) / z,\n dy = (fx * dydx - fy * dxdx) / z;\n x1 -= dx, y1 -= dy;\n } while ((abs(dx) > epsilon || abs(dy) > epsilon) && --i > 0);\n return [x1, y1];\n};\n\nexport default function() {\n return projection(aitoffRaw)\n .scale(152.63);\n}\n","import {geoProjectionMutator as projectionMutator} from \"d3-geo\";\nimport {abs, atan2, cos, degrees, epsilon, radians, sin, tan} from \"./math.js\";\n\nexport function armadilloRaw(phi0) {\n var sinPhi0 = sin(phi0),\n cosPhi0 = cos(phi0),\n sPhi0 = phi0 >= 0 ? 1 : -1,\n tanPhi0 = tan(sPhi0 * phi0),\n k = (1 + sinPhi0 - cosPhi0) / 2;\n\n function forward(lambda, phi) {\n var cosPhi = cos(phi),\n cosLambda = cos(lambda /= 2);\n return [\n (1 + cosPhi) * sin(lambda),\n (sPhi0 * phi > -atan2(cosLambda, tanPhi0) - 1e-3 ? 0 : -sPhi0 * 10) + k + sin(phi) * cosPhi0 - (1 + cosPhi) * sinPhi0 * cosLambda // TODO D3 core should allow null or [NaN, NaN] to be returned.\n ];\n }\n\n forward.invert = function(x, y) {\n var lambda = 0,\n phi = 0,\n i = 50;\n do {\n var cosLambda = cos(lambda),\n sinLambda = sin(lambda),\n cosPhi = cos(phi),\n sinPhi = sin(phi),\n A = 1 + cosPhi,\n fx = A * sinLambda - x,\n fy = k + sinPhi * cosPhi0 - A * sinPhi0 * cosLambda - y,\n dxdLambda = A * cosLambda / 2,\n dxdPhi = -sinLambda * sinPhi,\n dydLambda = sinPhi0 * A * sinLambda / 2,\n dydPhi = cosPhi0 * cosPhi + sinPhi0 * cosLambda * sinPhi,\n denominator = dxdPhi * dydLambda - dydPhi * dxdLambda,\n dLambda = (fy * dxdPhi - fx * dydPhi) / denominator / 2,\n dPhi = (fx * dydLambda - fy * dxdLambda) / denominator;\n if (abs(dPhi) > 2) dPhi /= 2;\n lambda -= dLambda, phi -= dPhi;\n } while ((abs(dLambda) > epsilon || abs(dPhi) > epsilon) && --i > 0);\n return sPhi0 * phi > -atan2(cos(lambda), tanPhi0) - 1e-3 ? [lambda * 2, phi] : null;\n };\n\n return forward;\n}\n\nexport default function() {\n var phi0 = 20 * radians,\n sPhi0 = phi0 >= 0 ? 1 : -1,\n tanPhi0 = tan(sPhi0 * phi0),\n m = projectionMutator(armadilloRaw),\n p = m(phi0),\n stream_ = p.stream;\n\n p.parallel = function(_) {\n if (!arguments.length) return phi0 * degrees;\n tanPhi0 = tan((sPhi0 = (phi0 = _ * radians) >= 0 ? 1 : -1) * phi0);\n return m(phi0);\n };\n\n p.stream = function(stream) {\n var rotate = p.rotate(),\n rotateStream = stream_(stream),\n sphereStream = (p.rotate([0, 0]), stream_(stream)),\n precision = p.precision();\n p.rotate(rotate);\n rotateStream.sphere = function() {\n sphereStream.polygonStart(), sphereStream.lineStart();\n for (var lambda = sPhi0 * -180; sPhi0 * lambda < 180; lambda += sPhi0 * 90)\n sphereStream.point(lambda, sPhi0 * 90);\n if (phi0) while (sPhi0 * (lambda -= 3 * sPhi0 * precision) >= -180) {\n sphereStream.point(lambda, sPhi0 * -atan2(cos(lambda * radians / 2), tanPhi0) * degrees);\n }\n sphereStream.lineEnd(), sphereStream.polygonEnd();\n };\n return rotateStream;\n };\n\n return p\n .scale(218.695)\n .center([0, 28.0974]);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, arcosh, arsinh, asin, atan2, cos, cosh, sign, sin, sinh, sqrt, tan} from \"./math.js\";\n\nexport function augustRaw(lambda, phi) {\n var tanPhi = tan(phi / 2),\n k = sqrt(1 - tanPhi * tanPhi),\n c = 1 + k * cos(lambda /= 2),\n x = sin(lambda) * k / c,\n y = tanPhi / c,\n x2 = x * x,\n y2 = y * y;\n return [\n 4 / 3 * x * (3 + x2 - 3 * y2),\n 4 / 3 * y * (3 + 3 * x2 - y2)\n ];\n}\n\naugustRaw.invert = function(x, y) {\n x *= 3 / 8, y *= 3 / 8;\n if (!x && abs(y) > 1) return null;\n var x2 = x * x,\n y2 = y * y,\n s = 1 + x2 + y2,\n sin3Eta = sqrt((s - sqrt(s * s - 4 * y * y)) / 2),\n eta = asin(sin3Eta) / 3,\n xi = sin3Eta ? arcosh(abs(y / sin3Eta)) / 3 : arsinh(abs(x)) / 3,\n cosEta = cos(eta),\n coshXi = cosh(xi),\n d = coshXi * coshXi - cosEta * cosEta;\n return [\n sign(x) * 2 * atan2(sinh(xi) * cosEta, 0.25 - d),\n sign(y) * 2 * atan2(coshXi * sin(eta), 0.25 + d)\n ];\n};\n\nexport default function() {\n return projection(augustRaw)\n .scale(66.1603);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, atan, cos, epsilon2, exp, halfPi, log, quarterPi, sign, sin, sqrt, sqrt2, tan} from \"./math.js\";\n\nvar sqrt8 = sqrt(8),\n phi0 = log(1 + sqrt2);\n\nexport function bakerRaw(lambda, phi) {\n var phi0 = abs(phi);\n return phi0 < quarterPi\n ? [lambda, log(tan(quarterPi + phi / 2))]\n : [lambda * cos(phi0) * (2 * sqrt2 - 1 / sin(phi0)), sign(phi) * (2 * sqrt2 * (phi0 - quarterPi) - log(tan(phi0 / 2)))];\n}\n\nbakerRaw.invert = function(x, y) {\n if ((y0 = abs(y)) < phi0) return [x, 2 * atan(exp(y)) - halfPi];\n var phi = quarterPi, i = 25, delta, y0;\n do {\n var cosPhi_2 = cos(phi / 2), tanPhi_2 = tan(phi / 2);\n phi -= delta = (sqrt8 * (phi - quarterPi) - log(tanPhi_2) - y0) / (sqrt8 - cosPhi_2 * cosPhi_2 / (2 * tanPhi_2));\n } while (abs(delta) > epsilon2 && --i > 0);\n return [x / (cos(phi) * (sqrt8 - 1 / sin(phi))), sign(y) * phi];\n};\n\nexport default function() {\n return projection(bakerRaw)\n .scale(112.314);\n}\n","import {geoProjectionMutator as projectionMutator, geoAzimuthalEquidistantRaw as azimuthalEquidistantRaw} from \"d3-geo\";\nimport {abs, acos, asin, atan, atan2, cos, degrees, halfPi, pi, radians, round, sin, sqrt, tan} from \"./math.js\";\n\nexport function berghausRaw(lobes) {\n var k = 2 * pi / lobes;\n\n function forward(lambda, phi) {\n var p = azimuthalEquidistantRaw(lambda, phi);\n if (abs(lambda) > halfPi) { // back hemisphere\n var theta = atan2(p[1], p[0]),\n r = sqrt(p[0] * p[0] + p[1] * p[1]),\n theta0 = k * round((theta - halfPi) / k) + halfPi,\n alpha = atan2(sin(theta -= theta0), 2 - cos(theta)); // angle relative to lobe end\n theta = theta0 + asin(pi / r * sin(alpha)) - alpha;\n p[0] = r * cos(theta);\n p[1] = r * sin(theta);\n }\n return p;\n }\n\n forward.invert = function(x, y) {\n var r = sqrt(x * x + y * y);\n if (r > halfPi) {\n var theta = atan2(y, x),\n theta0 = k * round((theta - halfPi) / k) + halfPi,\n s = theta > theta0 ? -1 : 1,\n A = r * cos(theta0 - theta),\n cotAlpha = 1 / tan(s * acos((A - pi) / sqrt(pi * (pi - 2 * A) + r * r)));\n theta = theta0 + 2 * atan((cotAlpha + s * sqrt(cotAlpha * cotAlpha - 3)) / 3);\n x = r * cos(theta), y = r * sin(theta);\n }\n return azimuthalEquidistantRaw.invert(x, y);\n };\n\n return forward;\n}\n\nexport default function() {\n var lobes = 5,\n m = projectionMutator(berghausRaw),\n p = m(lobes),\n projectionStream = p.stream,\n epsilon = 1e-2,\n cr = -cos(epsilon * radians),\n sr = sin(epsilon * radians);\n\n p.lobes = function(_) {\n return arguments.length ? m(lobes = +_) : lobes;\n };\n\n p.stream = function(stream) {\n var rotate = p.rotate(),\n rotateStream = projectionStream(stream),\n sphereStream = (p.rotate([0, 0]), projectionStream(stream));\n p.rotate(rotate);\n rotateStream.sphere = function() {\n sphereStream.polygonStart(), sphereStream.lineStart();\n for (var i = 0, delta = 360 / lobes, delta0 = 2 * pi / lobes, phi = 90 - 180 / lobes, phi0 = halfPi; i < lobes; ++i, phi -= delta, phi0 -= delta0) {\n sphereStream.point(atan2(sr * cos(phi0), cr) * degrees, asin(sr * sin(phi0)) * degrees);\n if (phi < -90) {\n sphereStream.point(-90, -180 - phi - epsilon);\n sphereStream.point(-90, -180 - phi + epsilon);\n } else {\n sphereStream.point(90, phi + epsilon);\n sphereStream.point(90, phi - epsilon);\n }\n }\n sphereStream.lineEnd(), sphereStream.polygonEnd();\n };\n return rotateStream;\n };\n\n return p\n .scale(87.8076)\n .center([0, 17.1875])\n .clipAngle(180 - 1e-3);\n}\n","import {geoAzimuthalEqualAreaRaw as azimuthalEqualAreaRaw, geoProjectionMutator as projectionMutator} from \"d3-geo\";\nimport {asin, cos, sin} from \"./math.js\";\n\nexport function hammerRaw(A, B) {\n if (arguments.length < 2) B = A;\n if (B === 1) return azimuthalEqualAreaRaw;\n if (B === Infinity) return hammerQuarticAuthalicRaw;\n\n function forward(lambda, phi) {\n var coordinates = azimuthalEqualAreaRaw(lambda / B, phi);\n coordinates[0] *= A;\n return coordinates;\n }\n\n forward.invert = function(x, y) {\n var coordinates = azimuthalEqualAreaRaw.invert(x / A, y);\n coordinates[0] *= B;\n return coordinates;\n };\n\n return forward;\n}\n\nfunction hammerQuarticAuthalicRaw(lambda, phi) {\n return [\n lambda * cos(phi) / cos(phi /= 2),\n 2 * sin(phi)\n ];\n}\n\nhammerQuarticAuthalicRaw.invert = function(x, y) {\n var phi = 2 * asin(y / 2);\n return [\n x * cos(phi / 2) / cos(phi),\n phi\n ];\n};\n\nexport default function() {\n var B = 2,\n m = projectionMutator(hammerRaw),\n p = m(B);\n\n p.coefficient = function(_) {\n if (!arguments.length) return B;\n return m(B = +_);\n };\n\n return p\n .scale(169.529);\n}\n","import {abs, epsilon, epsilon2} from \"./math.js\";\n\n// Approximate Newton-Raphson\n// Solve f(x) = y, start from x\nexport function solve(f, y, x) {\n var steps = 100, delta, f0, f1;\n x = x === undefined ? 0 : +x;\n y = +y;\n do {\n f0 = f(x);\n f1 = f(x + epsilon);\n if (f0 === f1) f1 = f0 + epsilon;\n x -= delta = (-1 * epsilon * (f0 - y)) / (f0 - f1);\n } while (steps-- > 0 && abs(delta) > epsilon);\n return steps < 0 ? NaN : x;\n}\n\n// Approximate Newton-Raphson in 2D\n// Solve f(a,b) = [x,y]\nexport function solve2d(f, MAX_ITERATIONS, eps) {\n if (MAX_ITERATIONS === undefined) MAX_ITERATIONS = 40;\n if (eps === undefined) eps = epsilon2;\n return function(x, y, a, b) {\n var err2, da, db;\n a = a === undefined ? 0 : +a;\n b = b === undefined ? 0 : +b;\n for (var i = 0; i < MAX_ITERATIONS; i++) {\n var p = f(a, b),\n // diffs\n tx = p[0] - x,\n ty = p[1] - y;\n if (abs(tx) < eps && abs(ty) < eps) break; // we're there!\n\n // backtrack if we overshot\n var h = tx * tx + ty * ty;\n if (h > err2) {\n a -= da /= 2;\n b -= db /= 2;\n continue;\n }\n err2 = h;\n\n // partial derivatives\n var ea = (a > 0 ? -1 : 1) * eps,\n eb = (b > 0 ? -1 : 1) * eps,\n pa = f(a + ea, b),\n pb = f(a, b + eb),\n dxa = (pa[0] - p[0]) / ea,\n dya = (pa[1] - p[1]) / ea,\n dxb = (pb[0] - p[0]) / eb,\n dyb = (pb[1] - p[1]) / eb,\n // determinant\n D = dyb * dxa - dya * dxb,\n // newton step — or half-step for small D\n l = (abs(D) < 0.5 ? 0.5 : 1) / D;\n da = (ty * dxb - tx * dyb) * l;\n db = (tx * dya - ty * dxa) * l;\n a += da;\n b += db;\n if (abs(da) < eps && abs(db) < eps) break; // we're crawling\n }\n return [a, b];\n };\n}","import {geoProjection as projection} from \"d3-geo\";\nimport {hammerRaw} from \"./hammer.js\";\nimport {cos, pi, sin} from \"./math.js\";\nimport {solve2d} from \"./newton.js\";\n\n// Bertin 1953 as a modified Briesemeister\n// https://bl.ocks.org/Fil/5b9ee9636dfb6ffa53443c9006beb642\nexport function bertin1953Raw() {\n var hammer = hammerRaw(1.68, 2),\n fu = 1.4, k = 12;\n\n function forward(lambda, phi) {\n\n if (lambda + phi < -fu) {\n var u = (lambda - phi + 1.6) * (lambda + phi + fu) / 8;\n lambda += u;\n phi -= 0.8 * u * sin(phi + pi / 2);\n }\n\n var r = hammer(lambda, phi);\n\n var d = (1 - cos(lambda * phi)) / k;\n\n if (r[1] < 0) {\n r[0] *= 1 + d;\n }\n if (r[1] > 0) {\n r[1] *= 1 + d / 1.5 * r[0] * r[0];\n }\n\n return r;\n }\n \n forward.invert = solve2d(forward);\n return forward;\n}\n\nexport default function() {\n // this projection should not be rotated\n return projection(bertin1953Raw())\n .rotate([-16.5, -42])\n .scale(176.57)\n .center([7.93, 0.09]);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, asin, cos, epsilon, halfPi, pi, sin, sqrt2} from \"./math.js\";\n\nexport function mollweideBromleyTheta(cp, phi) {\n var cpsinPhi = cp * sin(phi), i = 30, delta;\n do phi -= delta = (phi + sin(phi) - cpsinPhi) / (1 + cos(phi));\n while (abs(delta) > epsilon && --i > 0);\n return phi / 2;\n}\n\nexport function mollweideBromleyRaw(cx, cy, cp) {\n\n function forward(lambda, phi) {\n return [cx * lambda * cos(phi = mollweideBromleyTheta(cp, phi)), cy * sin(phi)];\n }\n\n forward.invert = function(x, y) {\n return y = asin(y / cy), [x / (cx * cos(y)), asin((2 * y + sin(2 * y)) / cp)];\n };\n\n return forward;\n}\n\nexport var mollweideRaw = mollweideBromleyRaw(sqrt2 / halfPi, sqrt2, pi);\n\nexport default function() {\n return projection(mollweideRaw)\n .scale(169.529);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {mollweideBromleyTheta} from \"./mollweide.js\";\nimport {abs, cos, epsilon, pi, quarterPi, sin, sqrt2} from \"./math.js\";\n\nvar k = 2.00276,\n w = 1.11072;\n\nexport function boggsRaw(lambda, phi) {\n var theta = mollweideBromleyTheta(pi, phi);\n return [k * lambda / (1 / cos(phi) + w / cos(theta)), (phi + sqrt2 * sin(theta)) / k];\n}\n\nboggsRaw.invert = function(x, y) {\n var ky = k * y, theta = y < 0 ? -quarterPi : quarterPi, i = 25, delta, phi;\n do {\n phi = ky - sqrt2 * sin(theta);\n theta -= delta = (sin(2 * theta) + 2 * theta - pi * sin(phi)) / (2 * cos(2 * theta) + 2 + pi * cos(phi) * sqrt2 * cos(theta));\n } while (abs(delta) > epsilon && --i > 0);\n phi = ky - sqrt2 * sin(theta);\n return [x * (1 / cos(phi) + w / cos(theta)) / k, phi];\n};\n\nexport default function() {\n return projection(boggsRaw)\n .scale(160.857);\n}\n","import {geoProjectionMutator as projectionMutator} from \"d3-geo\";\nimport {degrees, radians} from \"./math.js\";\n\nexport default function(projectAt) {\n var phi0 = 0,\n m = projectionMutator(projectAt),\n p = m(phi0);\n\n p.parallel = function(_) {\n return arguments.length ? m(phi0 = _ * radians) : phi0 * degrees;\n };\n\n return p;\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {cos} from \"./math.js\";\n\nexport function sinusoidalRaw(lambda, phi) {\n return [lambda * cos(phi), phi];\n}\n\nsinusoidalRaw.invert = function(x, y) {\n return [x / cos(y), y];\n};\n\nexport default function() {\n return projection(sinusoidalRaw)\n .scale(152.63);\n}\n","import parallel1 from \"./parallel1.js\";\nimport {atan2, cos, sin, sqrt, tan} from \"./math.js\";\nimport {sinusoidalRaw} from \"./sinusoidal.js\";\n\nexport function bonneRaw(phi0) {\n if (!phi0) return sinusoidalRaw;\n var cotPhi0 = 1 / tan(phi0);\n\n function forward(lambda, phi) {\n var rho = cotPhi0 + phi0 - phi,\n e = rho ? lambda * cos(phi) / rho : rho;\n return [rho * sin(e), cotPhi0 - rho * cos(e)];\n }\n\n forward.invert = function(x, y) {\n var rho = sqrt(x * x + (y = cotPhi0 - y) * y),\n phi = cotPhi0 + phi0 - rho;\n return [rho / cos(phi) * atan2(x, y), phi];\n };\n\n return forward;\n}\n\nexport default function() {\n return parallel1(bonneRaw)\n .scale(123.082)\n .center([0, 26.1441])\n .parallel(45);\n}\n","import {geoProjectionMutator as projectionMutator} from \"d3-geo\";\nimport {atan2, cos, halfPi, sin, sqrt} from \"./math.js\";\n\nexport function bottomleyRaw(sinPsi) {\n\n function forward(lambda, phi) {\n var rho = halfPi - phi,\n eta = rho ? lambda * sinPsi * sin(rho) / rho : rho;\n return [rho * sin(eta) / sinPsi, halfPi - rho * cos(eta)];\n }\n\n forward.invert = function(x, y) {\n var x1 = x * sinPsi,\n y1 = halfPi - y,\n rho = sqrt(x1 * x1 + y1 * y1),\n eta = atan2(x1, y1);\n return [(rho ? rho / sin(rho) : 1) * eta / sinPsi, halfPi - rho];\n };\n\n return forward;\n}\n\nexport default function() {\n var sinPsi = 0.5,\n m = projectionMutator(bottomleyRaw),\n p = m(sinPsi);\n\n p.fraction = function(_) {\n return arguments.length ? m(sinPsi = +_) : sinPsi;\n };\n\n return p\n .scale(158.837);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {pi} from \"./math.js\";\nimport {mollweideBromleyRaw} from \"./mollweide.js\";\n\nexport var bromleyRaw = mollweideBromleyRaw(1, 4 / pi, pi);\n\nexport default function() {\n return projection(bromleyRaw)\n .scale(152.63);\n}\n","import {geoCentroid as centroid, geoProjection as projection, geoRotation as rotation} from \"d3-geo\";\nimport {abs, acos, asin, atan2, cos, epsilon, floor, pi, radians, sin, sqrt} from \"./math.js\";\nimport {solve2d} from \"./newton.js\";\n\n// Azimuthal distance.\nfunction distance(dPhi, c1, s1, c2, s2, dLambda) {\n var cosdLambda = cos(dLambda), r;\n if (abs(dPhi) > 1 || abs(dLambda) > 1) {\n r = acos(s1 * s2 + c1 * c2 * cosdLambda);\n } else {\n var sindPhi = sin(dPhi / 2), sindLambda = sin(dLambda / 2);\n r = 2 * asin(sqrt(sindPhi * sindPhi + c1 * c2 * sindLambda * sindLambda));\n }\n return abs(r) > epsilon ? [r, atan2(c2 * sin(dLambda), c1 * s2 - s1 * c2 * cosdLambda)] : [0, 0];\n}\n\n// Angle opposite a, and contained between sides of lengths b and c.\nfunction angle(b, c, a) {\n return acos((b * b + c * c - a * a) / (2 * b * c));\n}\n\n// Normalize longitude.\nfunction longitude(lambda) {\n return lambda - 2 * pi * floor((lambda + pi) / (2 * pi));\n}\n\nexport function chamberlinRaw(p0, p1, p2) {\n var points = [\n [p0[0], p0[1], sin(p0[1]), cos(p0[1])],\n [p1[0], p1[1], sin(p1[1]), cos(p1[1])],\n [p2[0], p2[1], sin(p2[1]), cos(p2[1])]\n ];\n\n for (var a = points[2], b, i = 0; i < 3; ++i, a = b) {\n b = points[i];\n a.v = distance(b[1] - a[1], a[3], a[2], b[3], b[2], b[0] - a[0]);\n a.point = [0, 0];\n }\n\n var beta0 = angle(points[0].v[0], points[2].v[0], points[1].v[0]),\n beta1 = angle(points[0].v[0], points[1].v[0], points[2].v[0]),\n beta2 = pi - beta0;\n\n points[2].point[1] = 0;\n points[0].point[0] = -(points[1].point[0] = points[0].v[0] / 2);\n\n var mean = [\n points[2].point[0] = points[0].point[0] + points[2].v[0] * cos(beta0),\n 2 * (points[0].point[1] = points[1].point[1] = points[2].v[0] * sin(beta0))\n ];\n\n function forward(lambda, phi) {\n var sinPhi = sin(phi),\n cosPhi = cos(phi),\n v = new Array(3), i;\n\n // Compute distance and azimuth from control points.\n for (i = 0; i < 3; ++i) {\n var p = points[i];\n v[i] = distance(phi - p[1], p[3], p[2], cosPhi, sinPhi, lambda - p[0]);\n if (!v[i][0]) return p.point;\n v[i][1] = longitude(v[i][1] - p.v[1]);\n }\n\n // Arithmetic mean of interception points.\n var point = mean.slice();\n for (i = 0; i < 3; ++i) {\n var j = i == 2 ? 0 : i + 1;\n var a = angle(points[i].v[0], v[i][0], v[j][0]);\n if (v[i][1] < 0) a = -a;\n\n if (!i) {\n point[0] += v[i][0] * cos(a);\n point[1] -= v[i][0] * sin(a);\n } else if (i == 1) {\n a = beta1 - a;\n point[0] -= v[i][0] * cos(a);\n point[1] -= v[i][0] * sin(a);\n } else {\n a = beta2 - a;\n point[0] += v[i][0] * cos(a);\n point[1] += v[i][0] * sin(a);\n }\n }\n\n point[0] /= 3, point[1] /= 3;\n return point;\n }\n\n return forward;\n}\n\nfunction pointRadians(p) {\n return p[0] *= radians, p[1] *= radians, p;\n}\n\nexport function chamberlinAfrica() {\n return chamberlin([0, 22], [45, 22], [22.5, -22])\n .scale(380)\n .center([22.5, 2]);\n}\n\nexport default function chamberlin(p0, p1, p2) { // TODO order matters!\n var c = centroid({type: \"MultiPoint\", coordinates: [p0, p1, p2]}),\n R = [-c[0], -c[1]],\n r = rotation(R),\n f = chamberlinRaw(pointRadians(r(p0)), pointRadians(r(p1)), pointRadians(r(p2)));\n f.invert = solve2d(f);\n var p = projection(f).rotate(R),\n center = p.center;\n\n delete p.rotate;\n\n p.center = function(_) {\n return arguments.length ? center(r(_)) : r.invert(center());\n };\n\n return p\n .clipAngle(90);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {asin, pi, sin, sqrt, sqrtPi} from \"./math.js\";\n\nexport function collignonRaw(lambda, phi) {\n var alpha = sqrt(1 - sin(phi));\n return [(2 / sqrtPi) * lambda * alpha, sqrtPi * (1 - alpha)];\n}\n\ncollignonRaw.invert = function(x, y) {\n var lambda = (lambda = y / sqrtPi - 1) * lambda;\n return [lambda > 0 ? x * sqrt(pi / lambda) / 2 : 0, asin(1 - lambda)];\n};\n\nexport default function() {\n return projection(collignonRaw)\n .scale(95.6464)\n .center([0, 30]);\n}\n","import {asin, atan2, cos, sin, sqrt, tan} from \"./math.js\";\nimport parallel1 from \"./parallel1.js\";\n\nexport function craigRaw(phi0) {\n var tanPhi0 = tan(phi0);\n\n function forward(lambda, phi) {\n return [lambda, (lambda ? lambda / sin(lambda) : 1) * (sin(phi) * cos(lambda) - tanPhi0 * cos(phi))];\n }\n\n forward.invert = tanPhi0 ? function(x, y) {\n if (x) y *= sin(x) / x;\n var cosLambda = cos(x);\n return [x, 2 * atan2(sqrt(cosLambda * cosLambda + tanPhi0 * tanPhi0 - y * y) - cosLambda, tanPhi0 - y)];\n } : function(x, y) {\n return [x, asin(x ? y * tan(x) / x : y)];\n };\n\n return forward;\n}\n\nexport default function() {\n return parallel1(craigRaw)\n .scale(249.828)\n .clipAngle(90);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {asin, cos, sin, sqrt, sqrtPi} from \"./math.js\";\n\nvar sqrt3 = sqrt(3);\n\nexport function crasterRaw(lambda, phi) {\n return [sqrt3 * lambda * (2 * cos(2 * phi / 3) - 1) / sqrtPi, sqrt3 * sqrtPi * sin(phi / 3)];\n}\n\ncrasterRaw.invert = function(x, y) {\n var phi = 3 * asin(y / (sqrt3 * sqrtPi));\n return [sqrtPi * x / (sqrt3 * (2 * cos(2 * phi / 3) - 1)), phi];\n};\n\nexport default function() {\n return projection(crasterRaw)\n .scale(156.19);\n}\n","import {asin, cos, sin} from \"./math.js\";\nimport parallel1 from \"./parallel1.js\";\n\nexport function cylindricalEqualAreaRaw(phi0) {\n var cosPhi0 = cos(phi0);\n\n function forward(lambda, phi) {\n return [lambda * cosPhi0, sin(phi) / cosPhi0];\n }\n\n forward.invert = function(x, y) {\n return [x / cosPhi0, asin(y * cosPhi0)];\n };\n\n return forward;\n}\n\nexport default function() {\n return parallel1(cylindricalEqualAreaRaw)\n .parallel(38.58) // acos(sqrt(width / height / pi)) * radians\n .scale(195.044); // width / (sqrt(width / height / pi) * 2 * pi)\n}\n","import {atan, cos, tan} from \"./math.js\";\nimport parallel1 from \"./parallel1.js\";\n\nexport function cylindricalStereographicRaw(phi0) {\n var cosPhi0 = cos(phi0);\n\n function forward(lambda, phi) {\n return [lambda * cosPhi0, (1 + cosPhi0) * tan(phi / 2)];\n }\n\n forward.invert = function(x, y) {\n return [x / cosPhi0, atan(y / (1 + cosPhi0)) * 2];\n };\n\n return forward;\n}\n\nexport default function() {\n return parallel1(cylindricalStereographicRaw)\n .scale(124.75);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, pi, sqrt} from \"./math.js\";\n\nexport function eckert1Raw(lambda, phi) {\n var alpha = sqrt(8 / (3 * pi));\n return [\n alpha * lambda * (1 - abs(phi) / pi),\n alpha * phi\n ];\n}\n\neckert1Raw.invert = function(x, y) {\n var alpha = sqrt(8 / (3 * pi)),\n phi = y / alpha;\n return [\n x / (alpha * (1 - abs(phi) / pi)),\n phi\n ];\n};\n\nexport default function() {\n return projection(eckert1Raw)\n .scale(165.664);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, asin, pi, sign, sin, sqrt} from \"./math.js\";\n\nexport function eckert2Raw(lambda, phi) {\n var alpha = sqrt(4 - 3 * sin(abs(phi)));\n return [\n 2 / sqrt(6 * pi) * lambda * alpha,\n sign(phi) * sqrt(2 * pi / 3) * (2 - alpha)\n ];\n}\n\neckert2Raw.invert = function(x, y) {\n var alpha = 2 - abs(y) / sqrt(2 * pi / 3);\n return [\n x * sqrt(6 * pi) / (2 * alpha),\n sign(y) * asin((4 - alpha * alpha) / 3)\n ];\n};\n\nexport default function() {\n return projection(eckert2Raw)\n .scale(165.664);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {pi, sqrt} from \"./math.js\";\n\nexport function eckert3Raw(lambda, phi) {\n var k = sqrt(pi * (4 + pi));\n return [\n 2 / k * lambda * (1 + sqrt(1 - 4 * phi * phi / (pi * pi))),\n 4 / k * phi\n ];\n}\n\neckert3Raw.invert = function(x, y) {\n var k = sqrt(pi * (4 + pi)) / 2;\n return [\n x * k / (1 + sqrt(1 - y * y * (4 + pi) / (4 * pi))),\n y * k / 2\n ];\n};\n\nexport default function() {\n return projection(eckert3Raw)\n .scale(180.739);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, asin, cos, epsilon, halfPi, pi, sin, sqrt} from \"./math.js\";\n\nexport function eckert4Raw(lambda, phi) {\n var k = (2 + halfPi) * sin(phi);\n phi /= 2;\n for (var i = 0, delta = Infinity; i < 10 && abs(delta) > epsilon; i++) {\n var cosPhi = cos(phi);\n phi -= delta = (phi + sin(phi) * (cosPhi + 2) - k) / (2 * cosPhi * (1 + cosPhi));\n }\n return [\n 2 / sqrt(pi * (4 + pi)) * lambda * (1 + cos(phi)),\n 2 * sqrt(pi / (4 + pi)) * sin(phi)\n ];\n}\n\neckert4Raw.invert = function(x, y) {\n var A = y * sqrt((4 + pi) / pi) / 2,\n k = asin(A),\n c = cos(k);\n return [\n x / (2 / sqrt(pi * (4 + pi)) * (1 + c)),\n asin((k + A * (c + 2)) / (2 + halfPi))\n ];\n};\n\nexport default function() {\n return projection(eckert4Raw)\n .scale(180.739);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {cos, pi, sqrt} from \"./math.js\";\n\nexport function eckert5Raw(lambda, phi) {\n return [\n lambda * (1 + cos(phi)) / sqrt(2 + pi),\n 2 * phi / sqrt(2 + pi)\n ];\n}\n\neckert5Raw.invert = function(x, y) {\n var k = sqrt(2 + pi),\n phi = y * k / 2;\n return [\n k * x / (1 + cos(phi)),\n phi\n ];\n};\n\nexport default function() {\n return projection(eckert5Raw)\n .scale(173.044);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, asin, cos, epsilon, halfPi, pi, sin, sqrt} from \"./math.js\";\n\nexport function eckert6Raw(lambda, phi) {\n var k = (1 + halfPi) * sin(phi);\n for (var i = 0, delta = Infinity; i < 10 && abs(delta) > epsilon; i++) {\n phi -= delta = (phi + sin(phi) - k) / (1 + cos(phi));\n }\n k = sqrt(2 + pi);\n return [\n lambda * (1 + cos(phi)) / k,\n 2 * phi / k\n ];\n}\n\neckert6Raw.invert = function(x, y) {\n var j = 1 + halfPi,\n k = sqrt(j / 2);\n return [\n x * 2 * k / (1 + cos(y *= k)),\n asin((y + sin(y)) / j)\n ];\n};\n\nexport default function() {\n return projection(eckert6Raw)\n .scale(173.044);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {augustRaw} from \"./august.js\";\nimport {abs, atan, cos, epsilon, halfPi, log, max, min, sin, sqrt, sqrt1_2, sqrt2} from \"./math.js\";\n\nvar eisenlohrK = 3 + 2 * sqrt2;\n\nexport function eisenlohrRaw(lambda, phi) {\n var s0 = sin(lambda /= 2),\n c0 = cos(lambda),\n k = sqrt(cos(phi)),\n c1 = cos(phi /= 2),\n t = sin(phi) / (c1 + sqrt2 * c0 * k),\n c = sqrt(2 / (1 + t * t)),\n v = sqrt((sqrt2 * c1 + (c0 + s0) * k) / (sqrt2 * c1 + (c0 - s0) * k));\n return [\n eisenlohrK * (c * (v - 1 / v) - 2 * log(v)),\n eisenlohrK * (c * t * (v + 1 / v) - 2 * atan(t))\n ];\n}\n\neisenlohrRaw.invert = function(x, y) {\n if (!(p = augustRaw.invert(x / 1.2, y * 1.065))) return null;\n var lambda = p[0], phi = p[1], i = 20, p;\n x /= eisenlohrK, y /= eisenlohrK;\n do {\n var _0 = lambda / 2,\n _1 = phi / 2,\n s0 = sin(_0),\n c0 = cos(_0),\n s1 = sin(_1),\n c1 = cos(_1),\n cos1 = cos(phi),\n k = sqrt(cos1),\n t = s1 / (c1 + sqrt2 * c0 * k),\n t2 = t * t,\n c = sqrt(2 / (1 + t2)),\n v0 = (sqrt2 * c1 + (c0 + s0) * k),\n v1 = (sqrt2 * c1 + (c0 - s0) * k),\n v2 = v0 / v1,\n v = sqrt(v2),\n vm1v = v - 1 / v,\n vp1v = v + 1 / v,\n fx = c * vm1v - 2 * log(v) - x,\n fy = c * t * vp1v - 2 * atan(t) - y,\n deltatDeltaLambda = s1 && sqrt1_2 * k * s0 * t2 / s1,\n deltatDeltaPhi = (sqrt2 * c0 * c1 + k) / (2 * (c1 + sqrt2 * c0 * k) * (c1 + sqrt2 * c0 * k) * k),\n deltacDeltat = -0.5 * t * c * c * c,\n deltacDeltaLambda = deltacDeltat * deltatDeltaLambda,\n deltacDeltaPhi = deltacDeltat * deltatDeltaPhi,\n A = (A = 2 * c1 + sqrt2 * k * (c0 - s0)) * A * v,\n deltavDeltaLambda = (sqrt2 * c0 * c1 * k + cos1) / A,\n deltavDeltaPhi = -(sqrt2 * s0 * s1) / (k * A),\n deltaxDeltaLambda = vm1v * deltacDeltaLambda - 2 * deltavDeltaLambda / v + c * (deltavDeltaLambda + deltavDeltaLambda / v2),\n deltaxDeltaPhi = vm1v * deltacDeltaPhi - 2 * deltavDeltaPhi / v + c * (deltavDeltaPhi + deltavDeltaPhi / v2),\n deltayDeltaLambda = t * vp1v * deltacDeltaLambda - 2 * deltatDeltaLambda / (1 + t2) + c * vp1v * deltatDeltaLambda + c * t * (deltavDeltaLambda - deltavDeltaLambda / v2),\n deltayDeltaPhi = t * vp1v * deltacDeltaPhi - 2 * deltatDeltaPhi / (1 + t2) + c * vp1v * deltatDeltaPhi + c * t * (deltavDeltaPhi - deltavDeltaPhi / v2),\n denominator = deltaxDeltaPhi * deltayDeltaLambda - deltayDeltaPhi * deltaxDeltaLambda;\n if (!denominator) break;\n var deltaLambda = (fy * deltaxDeltaPhi - fx * deltayDeltaPhi) / denominator,\n deltaPhi = (fx * deltayDeltaLambda - fy * deltaxDeltaLambda) / denominator;\n lambda -= deltaLambda;\n phi = max(-halfPi, min(halfPi, phi - deltaPhi));\n } while ((abs(deltaLambda) > epsilon || abs(deltaPhi) > epsilon) && --i > 0);\n return abs(abs(phi) - halfPi) < epsilon ? [0, phi] : i && [lambda, phi];\n};\n\nexport default function() {\n return projection(eisenlohrRaw)\n .scale(62.5271);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {atan, cos, radians, sqrt, tan} from \"./math.js\";\n\nvar faheyK = cos(35 * radians);\n\nexport function faheyRaw(lambda, phi) {\n var t = tan(phi / 2);\n return [lambda * faheyK * sqrt(1 - t * t), (1 + faheyK) * t];\n}\n\nfaheyRaw.invert = function(x, y) {\n var t = y / (1 + faheyK);\n return [x && x / (faheyK * sqrt(1 - t * t)), 2 * atan(t)];\n};\n\nexport default function() {\n return projection(faheyRaw)\n .scale(137.152);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {atan, cos, sqrtPi, tan} from \"./math.js\";\n\nexport function foucautRaw(lambda, phi) {\n var k = phi / 2, cosk = cos(k);\n return [ 2 * lambda / sqrtPi * cos(phi) * cosk * cosk, sqrtPi * tan(k)];\n}\n\nfoucautRaw.invert = function(x, y) {\n var k = atan(y / sqrtPi), cosk = cos(k), phi = 2 * k;\n return [x * sqrtPi / 2 / (cos(phi) * cosk * cosk), phi];\n};\n\nexport default function() {\n return projection(foucautRaw)\n .scale(135.264);\n}\n","import {geoProjectionMutator as projectionMutator} from \"d3-geo\";\nimport {cos, halfPi, pi, sin, sqrt} from \"./math.js\";\nimport {solve} from \"./newton.js\";\n\nexport function foucautSinusoidalRaw(alpha) {\n var beta = 1 - alpha,\n equatorial = raw(pi, 0)[0] - raw(-pi, 0)[0],\n polar = raw(0, halfPi)[1] - raw(0, -halfPi)[1],\n ratio = sqrt(2 * polar / equatorial);\n\n function raw(lambda, phi) {\n var cosphi = cos(phi),\n sinphi = sin(phi);\n return [\n cosphi / (beta + alpha * cosphi) * lambda,\n beta * phi + alpha * sinphi\n ];\n }\n\n function forward(lambda, phi) {\n var p = raw(lambda, phi);\n return [p[0] * ratio, p[1] / ratio];\n }\n\n function forwardMeridian(phi) {\n return forward(0, phi)[1];\n }\n\n forward.invert = function(x, y) {\n var phi = solve(forwardMeridian, y),\n lambda = x / ratio * (alpha + beta / cos(phi));\n return [lambda, phi];\n };\n\n return forward;\n}\n\nexport default function() {\n var alpha = 0.5,\n m = projectionMutator(foucautSinusoidalRaw),\n p = m(alpha);\n\n p.alpha = function(_) {\n return arguments.length ? m(alpha = +_) : alpha;\n };\n\n return p\n .scale(168.725);\n}\n","import {geoEquirectangular, geoOrthographic} from \"d3-geo\";\nimport {asin, atan, degrees, radians, sin, tan} from \"./math.js\";\n\nfunction gilbertForward(point) {\n return [point[0] / 2, asin(tan(point[1] / 2 * radians)) * degrees];\n}\n\nfunction gilbertInvert(point) {\n return [point[0] * 2, 2 * atan(sin(point[1] * radians)) * degrees];\n}\n\nexport default function(projectionType) {\n if (projectionType == null) projectionType = geoOrthographic;\n var projection = projectionType(),\n equirectangular = geoEquirectangular().scale(degrees).precision(0).clipAngle(null).translate([0, 0]); // antimeridian cutting\n\n function gilbert(point) {\n return projection(gilbertForward(point));\n }\n\n if (projection.invert) gilbert.invert = function(point) {\n return gilbertInvert(projection.invert(point));\n };\n\n gilbert.stream = function(stream) {\n var s1 = projection.stream(stream), s0 = equirectangular.stream({\n point: function(lambda, phi) { s1.point(lambda / 2, asin(tan(-phi / 2 * radians)) * degrees); },\n lineStart: function() { s1.lineStart(); },\n lineEnd: function() { s1.lineEnd(); },\n polygonStart: function() { s1.polygonStart(); },\n polygonEnd: function() { s1.polygonEnd(); }\n });\n s0.sphere = s1.sphere;\n return s0;\n };\n\n function property(name) {\n gilbert[name] = function() {\n return arguments.length ? (projection[name].apply(projection, arguments), gilbert) : projection[name]();\n };\n }\n\n gilbert.rotate = function(_) {\n return arguments.length ? (equirectangular.rotate(_), gilbert) : equirectangular.rotate();\n };\n\n gilbert.center = function(_) {\n return arguments.length ? (projection.center(gilbertForward(_)), gilbert) : gilbertInvert(projection.center());\n };\n\n property(\"angle\");\n property(\"clipAngle\");\n property(\"clipExtent\");\n property(\"fitExtent\");\n property(\"fitHeight\");\n property(\"fitSize\");\n property(\"fitWidth\");\n property(\"scale\");\n property(\"translate\");\n property(\"precision\");\n\n return gilbert\n .scale(249.5);\n}\n","import {geoAzimuthalEquidistantRaw as azimuthalEquidistantRaw, geoProjectionMutator as projectionMutator} from \"d3-geo\";\nimport {abs, asin, atan2, cos, degrees, epsilon, epsilon2, halfPi, pi, radians, round, sin, sqrt} from \"./math.js\";\n\nexport function gingeryRaw(rho, n) {\n var k = 2 * pi / n,\n rho2 = rho * rho;\n\n function forward(lambda, phi) {\n var p = azimuthalEquidistantRaw(lambda, phi),\n x = p[0],\n y = p[1],\n r2 = x * x + y * y;\n\n if (r2 > rho2) {\n var r = sqrt(r2),\n theta = atan2(y, x),\n theta0 = k * round(theta / k),\n alpha = theta - theta0,\n rhoCosAlpha = rho * cos(alpha),\n k_ = (rho * sin(alpha) - alpha * sin(rhoCosAlpha)) / (halfPi - rhoCosAlpha),\n s_ = gingeryLength(alpha, k_),\n e = (pi - rho) / gingeryIntegrate(s_, rhoCosAlpha, pi);\n\n x = r;\n var i = 50, delta;\n do {\n x -= delta = (rho + gingeryIntegrate(s_, rhoCosAlpha, x) * e - r) / (s_(x) * e);\n } while (abs(delta) > epsilon && --i > 0);\n\n y = alpha * sin(x);\n if (x < halfPi) y -= k_ * (x - halfPi);\n\n var s = sin(theta0),\n c = cos(theta0);\n p[0] = x * c - y * s;\n p[1] = x * s + y * c;\n }\n return p;\n }\n\n forward.invert = function(x, y) {\n var r2 = x * x + y * y;\n if (r2 > rho2) {\n var r = sqrt(r2),\n theta = atan2(y, x),\n theta0 = k * round(theta / k),\n dTheta = theta - theta0;\n\n x = r * cos(dTheta);\n y = r * sin(dTheta);\n\n var x_halfPi = x - halfPi,\n sinx = sin(x),\n alpha = y / sinx,\n delta = x < halfPi ? Infinity : 0,\n i = 10;\n\n while (true) {\n var rhosinAlpha = rho * sin(alpha),\n rhoCosAlpha = rho * cos(alpha),\n sinRhoCosAlpha = sin(rhoCosAlpha),\n halfPi_RhoCosAlpha = halfPi - rhoCosAlpha,\n k_ = (rhosinAlpha - alpha * sinRhoCosAlpha) / halfPi_RhoCosAlpha,\n s_ = gingeryLength(alpha, k_);\n\n if (abs(delta) < epsilon2 || !--i) break;\n\n alpha -= delta = (alpha * sinx - k_ * x_halfPi - y) / (\n sinx - x_halfPi * 2 * (\n halfPi_RhoCosAlpha * (rhoCosAlpha + alpha * rhosinAlpha * cos(rhoCosAlpha) - sinRhoCosAlpha) -\n rhosinAlpha * (rhosinAlpha - alpha * sinRhoCosAlpha)\n ) / (halfPi_RhoCosAlpha * halfPi_RhoCosAlpha));\n }\n r = rho + gingeryIntegrate(s_, rhoCosAlpha, x) * (pi - rho) / gingeryIntegrate(s_, rhoCosAlpha, pi);\n theta = theta0 + alpha;\n x = r * cos(theta);\n y = r * sin(theta);\n }\n return azimuthalEquidistantRaw.invert(x, y);\n };\n\n return forward;\n}\n\nfunction gingeryLength(alpha, k) {\n return function(x) {\n var y_ = alpha * cos(x);\n if (x < halfPi) y_ -= k;\n return sqrt(1 + y_ * y_);\n };\n}\n\n// Numerical integration: trapezoidal rule.\nfunction gingeryIntegrate(f, a, b) {\n var n = 50,\n h = (b - a) / n,\n s = f(a) + f(b);\n for (var i = 1, x = a; i < n; ++i) s += 2 * f(x += h);\n return s * 0.5 * h;\n}\n\nexport default function() {\n var n = 6,\n rho = 30 * radians,\n cRho = cos(rho),\n sRho = sin(rho),\n m = projectionMutator(gingeryRaw),\n p = m(rho, n),\n stream_ = p.stream,\n epsilon = 1e-2,\n cr = -cos(epsilon * radians),\n sr = sin(epsilon * radians);\n\n p.radius = function(_) {\n if (!arguments.length) return rho * degrees;\n cRho = cos(rho = _ * radians);\n sRho = sin(rho);\n return m(rho, n);\n };\n\n p.lobes = function(_) {\n if (!arguments.length) return n;\n return m(rho, n = +_);\n };\n\n p.stream = function(stream) {\n var rotate = p.rotate(),\n rotateStream = stream_(stream),\n sphereStream = (p.rotate([0, 0]), stream_(stream));\n p.rotate(rotate);\n rotateStream.sphere = function() {\n sphereStream.polygonStart(), sphereStream.lineStart();\n for (var i = 0, delta = 2 * pi / n, phi = 0; i < n; ++i, phi -= delta) {\n sphereStream.point(atan2(sr * cos(phi), cr) * degrees, asin(sr * sin(phi)) * degrees);\n sphereStream.point(atan2(sRho * cos(phi - delta / 2), cRho) * degrees, asin(sRho * sin(phi - delta / 2)) * degrees);\n }\n sphereStream.lineEnd(), sphereStream.polygonEnd();\n };\n return rotateStream;\n };\n\n return p\n .rotate([90, -40])\n .scale(91.7095)\n .clipAngle(180 - 1e-3);\n}\n","import {abs, asin, cos, epsilon, pi, sin, sqrt} from \"./math.js\";\n\nexport default function(a, b, c, d, e, f, g, h) {\n if (arguments.length < 8) h = 0;\n\n function forward(lambda, phi) {\n if (!phi) return [a * lambda / pi, 0];\n var phi2 = phi * phi,\n xB = a + phi2 * (b + phi2 * (c + phi2 * d)),\n yB = phi * (e - 1 + phi2 * (f - h + phi2 * g)),\n m = (xB * xB + yB * yB) / (2 * yB),\n alpha = lambda * asin(xB / m) / pi;\n return [m * sin(alpha), phi * (1 + phi2 * h) + m * (1 - cos(alpha))];\n }\n\n forward.invert = function(x, y) {\n var lambda = pi * x / a,\n phi = y,\n deltaLambda, deltaPhi, i = 50;\n do {\n var phi2 = phi * phi,\n xB = a + phi2 * (b + phi2 * (c + phi2 * d)),\n yB = phi * (e - 1 + phi2 * (f - h + phi2 * g)),\n p = xB * xB + yB * yB,\n q = 2 * yB,\n m = p / q,\n m2 = m * m,\n dAlphadLambda = asin(xB / m) / pi,\n alpha = lambda * dAlphadLambda,\n xB2 = xB * xB,\n dxBdPhi = (2 * b + phi2 * (4 * c + phi2 * 6 * d)) * phi,\n dyBdPhi = e + phi2 * (3 * f + phi2 * 5 * g),\n dpdPhi = 2 * (xB * dxBdPhi + yB * (dyBdPhi - 1)),\n dqdPhi = 2 * (dyBdPhi - 1),\n dmdPhi = (dpdPhi * q - p * dqdPhi) / (q * q),\n cosAlpha = cos(alpha),\n sinAlpha = sin(alpha),\n mcosAlpha = m * cosAlpha,\n msinAlpha = m * sinAlpha,\n dAlphadPhi = ((lambda / pi) * (1 / sqrt(1 - xB2 / m2)) * (dxBdPhi * m - xB * dmdPhi)) / m2,\n fx = msinAlpha - x,\n fy = phi * (1 + phi2 * h) + m - mcosAlpha - y,\n deltaxDeltaPhi = dmdPhi * sinAlpha + mcosAlpha * dAlphadPhi,\n deltaxDeltaLambda = mcosAlpha * dAlphadLambda,\n deltayDeltaPhi = 1 + dmdPhi - (dmdPhi * cosAlpha - msinAlpha * dAlphadPhi),\n deltayDeltaLambda = msinAlpha * dAlphadLambda,\n denominator = deltaxDeltaPhi * deltayDeltaLambda - deltayDeltaPhi * deltaxDeltaLambda;\n if (!denominator) break;\n lambda -= deltaLambda = (fy * deltaxDeltaPhi - fx * deltayDeltaPhi) / denominator;\n phi -= deltaPhi = (fx * deltayDeltaLambda - fy * deltaxDeltaLambda) / denominator;\n } while ((abs(deltaLambda) > epsilon || abs(deltaPhi) > epsilon) && --i > 0);\n return [lambda, phi];\n };\n\n return forward;\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport ginzburgPolyconicRaw from \"./ginzburgPolyconic.js\";\n\nexport var ginzburg4Raw = ginzburgPolyconicRaw(2.8284, -1.6988, 0.75432, -0.18071, 1.76003, -0.38914, 0.042555);\n\nexport default function() {\n return projection(ginzburg4Raw)\n .scale(149.995);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport ginzburgPolyconicRaw from \"./ginzburgPolyconic.js\";\n\nexport var ginzburg5Raw = ginzburgPolyconicRaw(2.583819, -0.835827, 0.170354, -0.038094, 1.543313, -0.411435,0.082742);\n\nexport default function() {\n return projection(ginzburg5Raw)\n .scale(153.93);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport ginzburgPolyconicRaw from \"./ginzburgPolyconic.js\";\nimport {pi} from \"./math.js\";\n\nexport var ginzburg6Raw = ginzburgPolyconicRaw(5 / 6 * pi, -0.62636, -0.0344, 0, 1.3493, -0.05524, 0, 0.045);\n\nexport default function() {\n return projection(ginzburg6Raw)\n .scale(130.945);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, epsilon} from \"./math.js\";\n\nexport function ginzburg8Raw(lambda, phi) {\n var lambda2 = lambda * lambda,\n phi2 = phi * phi;\n return [\n lambda * (1 - 0.162388 * phi2) * (0.87 - 0.000952426 * lambda2 * lambda2),\n phi * (1 + phi2 / 12)\n ];\n}\n\nginzburg8Raw.invert = function(x, y) {\n var lambda = x,\n phi = y,\n i = 50, delta;\n do {\n var phi2 = phi * phi;\n phi -= delta = (phi * (1 + phi2 / 12) - y) / (1 + phi2 / 4);\n } while (abs(delta) > epsilon && --i > 0);\n i = 50;\n x /= 1 -0.162388 * phi2;\n do {\n var lambda4 = (lambda4 = lambda * lambda) * lambda4;\n lambda -= delta = (lambda * (0.87 - 0.000952426 * lambda4) - x) / (0.87 - 0.00476213 * lambda4);\n } while (abs(delta) > epsilon && --i > 0);\n return [lambda, phi];\n};\n\nexport default function() {\n return projection(ginzburg8Raw)\n .scale(131.747);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport ginzburgPolyconicRaw from \"./ginzburgPolyconic.js\";\n\nexport var ginzburg9Raw = ginzburgPolyconicRaw(2.6516, -0.76534, 0.19123, -0.047094, 1.36289, -0.13965,0.031762);\n\nexport default function() {\n return projection(ginzburg9Raw)\n .scale(131.087);\n}\n","import {halfPi, pi} from \"./math.js\";\n\nexport default function(project) {\n var dx = project(halfPi, 0)[0] - project(-halfPi, 0)[0];\n\n function projectSquare(lambda, phi) {\n var s = lambda > 0 ? -0.5 : 0.5,\n point = project(lambda + s * pi, phi);\n point[0] -= s * dx;\n return point;\n }\n\n if (project.invert) projectSquare.invert = function(x, y) {\n var s = x > 0 ? -0.5 : 0.5,\n location = project.invert(x + s * dx, y),\n lambda = location[0] - s * pi;\n if (lambda < -pi) lambda += 2 * pi;\n else if (lambda > pi) lambda -= 2 * pi;\n location[0] = lambda;\n return location;\n };\n\n return projectSquare;\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, asin, atan2, cos, sign, epsilon, epsilon2, halfPi, pi, sin, sqrt} from \"./math.js\";\nimport squareRaw from \"./square.js\";\n\nexport function gringortenRaw(lambda, phi) {\n var sLambda = sign(lambda),\n sPhi = sign(phi),\n cosPhi = cos(phi),\n x = cos(lambda) * cosPhi,\n y = sin(lambda) * cosPhi,\n z = sin(sPhi * phi);\n lambda = abs(atan2(y, z));\n phi = asin(x);\n if (abs(lambda - halfPi) > epsilon) lambda %= halfPi;\n var point = gringortenHexadecant(lambda > pi / 4 ? halfPi - lambda : lambda, phi);\n if (lambda > pi / 4) z = point[0], point[0] = -point[1], point[1] = -z;\n return (point[0] *= sLambda, point[1] *= -sPhi, point);\n}\n\ngringortenRaw.invert = function(x, y) {\n if (abs(x) > 1) x = sign(x) * 2 - x;\n if (abs(y) > 1) y = sign(y) * 2 - y;\n var sx = sign(x),\n sy = sign(y),\n x0 = -sx * x,\n y0 = -sy * y,\n t = y0 / x0 < 1,\n p = gringortenHexadecantInvert(t ? y0 : x0, t ? x0 : y0),\n lambda = p[0],\n phi = p[1],\n cosPhi = cos(phi);\n if (t) lambda = -halfPi - lambda;\n return [sx * (atan2(sin(lambda) * cosPhi, -sin(phi)) + pi), sy * asin(cos(lambda) * cosPhi)];\n};\n\nfunction gringortenHexadecant(lambda, phi) {\n if (phi === halfPi) return [0, 0];\n\n var sinPhi = sin(phi),\n r = sinPhi * sinPhi,\n r2 = r * r,\n j = 1 + r2,\n k = 1 + 3 * r2,\n q = 1 - r2,\n z = asin(1 / sqrt(j)),\n v = q + r * j * z,\n p2 = (1 - sinPhi) / v,\n p = sqrt(p2),\n a2 = p2 * j,\n a = sqrt(a2),\n h = p * q,\n x,\n i;\n\n if (lambda === 0) return [0, -(h + r * a)];\n\n var cosPhi = cos(phi),\n secPhi = 1 / cosPhi,\n drdPhi = 2 * sinPhi * cosPhi,\n dvdPhi = (-3 * r + z * k) * drdPhi,\n dp2dPhi = (-v * cosPhi - (1 - sinPhi) * dvdPhi) / (v * v),\n dpdPhi = (0.5 * dp2dPhi) / p,\n dhdPhi = q * dpdPhi - 2 * r * p * drdPhi,\n dra2dPhi = r * j * dp2dPhi + p2 * k * drdPhi,\n mu = -secPhi * drdPhi,\n nu = -secPhi * dra2dPhi,\n zeta = -2 * secPhi * dhdPhi,\n lambda1 = 4 * lambda / pi,\n delta;\n\n // Slower but accurate bisection method.\n if (lambda > 0.222 * pi || phi < pi / 4 && lambda > 0.175 * pi) {\n x = (h + r * sqrt(a2 * (1 + r2) - h * h)) / (1 + r2);\n if (lambda > pi / 4) return [x, x];\n var x1 = x, x0 = 0.5 * x;\n x = 0.5 * (x0 + x1), i = 50;\n do {\n var g = sqrt(a2 - x * x),\n f = (x * (zeta + mu * g) + nu * asin(x / a)) - lambda1;\n if (!f) break;\n if (f < 0) x0 = x;\n else x1 = x;\n x = 0.5 * (x0 + x1);\n } while (abs(x1 - x0) > epsilon && --i > 0);\n }\n\n // Newton-Raphson.\n else {\n x = epsilon, i = 25;\n do {\n var x2 = x * x,\n g2 = sqrt(a2 - x2),\n zetaMug = zeta + mu * g2,\n f2 = x * zetaMug + nu * asin(x / a) - lambda1,\n df = zetaMug + (nu - mu * x2) / g2;\n x -= delta = g2 ? f2 / df : 0;\n } while (abs(delta) > epsilon && --i > 0);\n }\n\n return [x, -h - r * sqrt(a2 - x * x)];\n}\n\nfunction gringortenHexadecantInvert(x, y) {\n var x0 = 0,\n x1 = 1,\n r = 0.5,\n i = 50;\n\n while (true) {\n var r2 = r * r,\n sinPhi = sqrt(r),\n z = asin(1 / sqrt(1 + r2)),\n v = (1 - r2) + r * (1 + r2) * z,\n p2 = (1 - sinPhi) / v,\n p = sqrt(p2),\n a2 = p2 * (1 + r2),\n h = p * (1 - r2),\n g2 = a2 - x * x,\n g = sqrt(g2),\n y0 = y + h + r * g;\n if (abs(x1 - x0) < epsilon2 || --i === 0 || y0 === 0) break;\n if (y0 > 0) x0 = r;\n else x1 = r;\n r = 0.5 * (x0 + x1);\n }\n\n if (!i) return null;\n\n var phi = asin(sinPhi),\n cosPhi = cos(phi),\n secPhi = 1 / cosPhi,\n drdPhi = 2 * sinPhi * cosPhi,\n dvdPhi = (-3 * r + z * (1 + 3 * r2)) * drdPhi,\n dp2dPhi = (-v * cosPhi - (1 - sinPhi) * dvdPhi) / (v * v),\n dpdPhi = 0.5 * dp2dPhi / p,\n dhdPhi = (1 - r2) * dpdPhi - 2 * r * p * drdPhi,\n zeta = -2 * secPhi * dhdPhi,\n mu = -secPhi * drdPhi,\n nu = -secPhi * (r * (1 + r2) * dp2dPhi + p2 * (1 + 3 * r2) * drdPhi);\n\n return [pi / 4 * (x * (zeta + mu * g) + nu * asin(x / sqrt(a2))), phi];\n}\n\nexport default function() {\n return projection(squareRaw(gringortenRaw))\n .scale(239.75);\n}\n","import {abs, asin, atan, cos, cosh, epsilon, exp, halfPi, log, pi, pow, quarterPi, sign, sin, sinh, sqrt, tan, tanh} from \"./math.js\";\n\n// Returns [sn, cn, dn](u + iv|m).\nexport function ellipticJi(u, v, m) {\n var a, b, c;\n if (!u) {\n b = ellipticJ(v, 1 - m);\n return [\n [0, b[0] / b[1]],\n [1 / b[1], 0],\n [b[2] / b[1], 0]\n ];\n }\n a = ellipticJ(u, m);\n if (!v) return [[a[0], 0], [a[1], 0], [a[2], 0]];\n b = ellipticJ(v, 1 - m);\n c = b[1] * b[1] + m * a[0] * a[0] * b[0] * b[0];\n return [\n [a[0] * b[2] / c, a[1] * a[2] * b[0] * b[1] / c],\n [a[1] * b[1] / c, -a[0] * a[2] * b[0] * b[2] / c],\n [a[2] * b[1] * b[2] / c, -m * a[0] * a[1] * b[0] / c]\n ];\n}\n\n// Returns [sn, cn, dn, ph](u|m).\nexport function ellipticJ(u, m) {\n var ai, b, phi, t, twon;\n if (m < epsilon) {\n t = sin(u);\n b = cos(u);\n ai = m * (u - t * b) / 4;\n return [\n t - ai * b,\n b + ai * t,\n 1 - m * t * t / 2,\n u - ai\n ];\n }\n if (m >= 1 - epsilon) {\n ai = (1 - m) / 4;\n b = cosh(u);\n t = tanh(u);\n phi = 1 / b;\n twon = b * sinh(u);\n return [\n t + ai * (twon - u) / (b * b),\n phi - ai * t * phi * (twon - u),\n phi + ai * t * phi * (twon + u),\n 2 * atan(exp(u)) - halfPi + ai * (twon - u) / b\n ];\n }\n\n var a = [1, 0, 0, 0, 0, 0, 0, 0, 0],\n c = [sqrt(m), 0, 0, 0, 0, 0, 0, 0, 0],\n i = 0;\n b = sqrt(1 - m);\n twon = 1;\n\n while (abs(c[i] / a[i]) > epsilon && i < 8) {\n ai = a[i++];\n c[i] = (ai - b) / 2;\n a[i] = (ai + b) / 2;\n b = sqrt(ai * b);\n twon *= 2;\n }\n\n phi = twon * a[i] * u;\n do {\n t = c[i] * sin(b = phi) / a[i];\n phi = (asin(t) + phi) / 2;\n } while (--i);\n\n return [sin(phi), t = cos(phi), t / cos(phi - b), phi];\n}\n\n// Calculate F(phi+iPsi|m).\n// See Abramowitz and Stegun, 17.4.11.\nexport function ellipticFi(phi, psi, m) {\n var r = abs(phi),\n i = abs(psi),\n sinhPsi = sinh(i);\n if (r) {\n var cscPhi = 1 / sin(r),\n cotPhi2 = 1 / (tan(r) * tan(r)),\n b = -(cotPhi2 + m * (sinhPsi * sinhPsi * cscPhi * cscPhi) - 1 + m),\n c = (m - 1) * cotPhi2,\n cotLambda2 = (-b + sqrt(b * b - 4 * c)) / 2;\n return [\n ellipticF(atan(1 / sqrt(cotLambda2)), m) * sign(phi),\n ellipticF(atan(sqrt((cotLambda2 / cotPhi2 - 1) / m)), 1 - m) * sign(psi)\n ];\n }\n return [\n 0,\n ellipticF(atan(sinhPsi), 1 - m) * sign(psi)\n ];\n}\n\n// Calculate F(phi|m) where m = k² = sin²α.\n// See Abramowitz and Stegun, 17.6.7.\nexport function ellipticF(phi, m) {\n if (!m) return phi;\n if (m === 1) return log(tan(phi / 2 + quarterPi));\n var a = 1,\n b = sqrt(1 - m),\n c = sqrt(m);\n for (var i = 0; abs(c) > epsilon; i++) {\n if (phi % pi) {\n var dPhi = atan(b * tan(phi) / a);\n if (dPhi < 0) dPhi += pi;\n phi += dPhi + ~~(phi / pi) * pi;\n } else phi += phi;\n c = (a + b) / 2;\n b = sqrt(a * b);\n c = ((a = c) - b) / 2;\n }\n return phi / (pow(2, i) * a);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {ellipticF, ellipticFi, ellipticJi} from \"./elliptic.js\";\nimport {abs, atan, atan2, cos, exp, halfPi, log, pi, sin, sqrt, sqrt2, tan} from \"./math.js\";\nimport squareRaw from \"./square.js\";\n\nexport function guyouRaw(lambda, phi) {\n var k_ = (sqrt2 - 1) / (sqrt2 + 1),\n k = sqrt(1 - k_ * k_),\n K = ellipticF(halfPi, k * k),\n f = -1,\n psi = log(tan(pi / 4 + abs(phi) / 2)),\n r = exp(f * psi) / sqrt(k_),\n at = guyouComplexAtan(r * cos(f * lambda), r * sin(f * lambda)),\n t = ellipticFi(at[0], at[1], k * k);\n return [-t[1], (phi >= 0 ? 1 : -1) * (0.5 * K - t[0])];\n}\n\nfunction guyouComplexAtan(x, y) {\n var x2 = x * x,\n y_1 = y + 1,\n t = 1 - x2 - y * y;\n return [\n 0.5 * ((x >= 0 ? halfPi : -halfPi) - atan2(t, 2 * x)),\n -0.25 * log(t * t + 4 * x2) +0.5 * log(y_1 * y_1 + x2)\n ];\n}\n\nfunction guyouComplexDivide(a, b) {\n var denominator = b[0] * b[0] + b[1] * b[1];\n return [\n (a[0] * b[0] + a[1] * b[1]) / denominator,\n (a[1] * b[0] - a[0] * b[1]) / denominator\n ];\n}\n\nguyouRaw.invert = function(x, y) {\n var k_ = (sqrt2 - 1) / (sqrt2 + 1),\n k = sqrt(1 - k_ * k_),\n K = ellipticF(halfPi, k * k),\n f = -1,\n j = ellipticJi(0.5 * K - y, -x, k * k),\n tn = guyouComplexDivide(j[0], j[1]),\n lambda = atan2(tn[1], tn[0]) / f;\n return [\n lambda,\n 2 * atan(exp(0.5 / f * log(k_ * tn[0] * tn[0] + k_ * tn[1] * tn[1]))) - halfPi\n ];\n};\n\nexport default function() {\n return projection(squareRaw(guyouRaw))\n .scale(151.496);\n}\n","import {geoProjectionMutator as projectionMutator, geoCircle} from \"d3-geo\";\nimport {abs, acos, asin, atan2, cos, degrees, epsilon, halfPi, radians, sqrt, sin} from \"./math.js\";\n\nexport function hammerRetroazimuthalRaw(phi0) {\n var sinPhi0 = sin(phi0),\n cosPhi0 = cos(phi0),\n rotate = hammerRetroazimuthalRotation(phi0);\n\n rotate.invert = hammerRetroazimuthalRotation(-phi0);\n\n function forward(lambda, phi) {\n var p = rotate(lambda, phi);\n lambda = p[0], phi = p[1];\n var sinPhi = sin(phi),\n cosPhi = cos(phi),\n cosLambda = cos(lambda),\n z = acos(sinPhi0 * sinPhi + cosPhi0 * cosPhi * cosLambda),\n sinz = sin(z),\n K = abs(sinz) > epsilon ? z / sinz : 1;\n return [\n K * cosPhi0 * sin(lambda),\n (abs(lambda) > halfPi ? K : -K) // rotate for back hemisphere\n * (sinPhi0 * cosPhi - cosPhi0 * sinPhi * cosLambda)\n ];\n }\n\n forward.invert = function(x, y) {\n var rho = sqrt(x * x + y * y),\n sinz = -sin(rho),\n cosz = cos(rho),\n a = rho * cosz,\n b = -y * sinz,\n c = rho * sinPhi0,\n d = sqrt(a * a + b * b - c * c),\n phi = atan2(a * c + b * d, b * c - a * d),\n lambda = (rho > halfPi ? -1 : 1) * atan2(x * sinz, rho * cos(phi) * cosz + y * sin(phi) * sinz);\n return rotate.invert(lambda, phi);\n };\n\n return forward;\n}\n\n// Latitudinal rotation by phi0.\n// Temporary hack until D3 supports arbitrary small-circle clipping origins.\nfunction hammerRetroazimuthalRotation(phi0) {\n var sinPhi0 = sin(phi0),\n cosPhi0 = cos(phi0);\n\n return function(lambda, phi) {\n var cosPhi = cos(phi),\n x = cos(lambda) * cosPhi,\n y = sin(lambda) * cosPhi,\n z = sin(phi);\n return [\n atan2(y, x * cosPhi0 - z * sinPhi0),\n asin(z * cosPhi0 + x * sinPhi0)\n ];\n };\n}\n\nexport default function() {\n var phi0 = 0,\n m = projectionMutator(hammerRetroazimuthalRaw),\n p = m(phi0),\n rotate_ = p.rotate,\n stream_ = p.stream,\n circle = geoCircle();\n\n p.parallel = function(_) {\n if (!arguments.length) return phi0 * degrees;\n var r = p.rotate();\n return m(phi0 = _ * radians).rotate(r);\n };\n\n // Temporary hack; see hammerRetroazimuthalRotation.\n p.rotate = function(_) {\n if (!arguments.length) return (_ = rotate_.call(p), _[1] += phi0 * degrees, _);\n rotate_.call(p, [_[0], _[1] - phi0 * degrees]);\n circle.center([-_[0], -_[1]]);\n return p;\n };\n\n p.stream = function(stream) {\n stream = stream_(stream);\n stream.sphere = function() {\n stream.polygonStart();\n var epsilon = 1e-2,\n ring = circle.radius(90 - epsilon)().coordinates[0],\n n = ring.length - 1,\n i = -1,\n p;\n stream.lineStart();\n while (++i < n) stream.point((p = ring[i])[0], p[1]);\n stream.lineEnd();\n ring = circle.radius(90 + epsilon)().coordinates[0];\n n = ring.length - 1;\n stream.lineStart();\n while (--i >= 0) stream.point((p = ring[i])[0], p[1]);\n stream.lineEnd();\n stream.polygonEnd();\n };\n return stream;\n };\n\n return p\n .scale(79.4187)\n .parallel(45)\n .clipAngle(180 - 1e-3);\n}\n","import {range} from \"d3-array\";\nimport {geoStream, geoProjectionMutator as projectionMutator} from \"d3-geo\";\nimport {collignonRaw} from \"./collignon.js\";\nimport {cylindricalEqualAreaRaw} from \"./cylindricalEqualArea.js\";\nimport {abs, asin, degrees, epsilon, floor, max, min, pi, radians, sqrtPi, tau} from \"./math.js\";\n\nvar K = 3,\n healpixParallel = asin(1 - 1 / K) * degrees,\n healpixLambert = cylindricalEqualAreaRaw(0);\n\nexport function healpixRaw(H) {\n var phi0 = healpixParallel * radians,\n dx = collignonRaw(pi, phi0)[0] - collignonRaw(-pi, phi0)[0],\n y0 = healpixLambert(0, phi0)[1],\n y1 = collignonRaw(0, phi0)[1],\n dy1 = sqrtPi - y1,\n k = tau / H,\n w = 4 / tau,\n h = y0 + (dy1 * dy1 * 4) / tau;\n\n function forward(lambda, phi) {\n var point,\n phi2 = abs(phi);\n if (phi2 > phi0) {\n var i = min(H - 1, max(0, floor((lambda + pi) / k)));\n lambda += pi * (H - 1) / H - i * k;\n point = collignonRaw(lambda, phi2);\n point[0] = point[0] * tau / dx - tau * (H - 1) / (2 * H) + i * tau / H;\n point[1] = y0 + (point[1] - y1) * 4 * dy1 / tau;\n if (phi < 0) point[1] = -point[1];\n } else {\n point = healpixLambert(lambda, phi);\n }\n point[0] *= w, point[1] /= h;\n return point;\n }\n\n forward.invert = function(x, y) {\n x /= w, y *= h;\n var y2 = abs(y);\n if (y2 > y0) {\n var i = min(H - 1, max(0, floor((x + pi) / k)));\n x = (x + pi * (H - 1) / H - i * k) * dx / tau;\n var point = collignonRaw.invert(x, 0.25 * (y2 - y0) * tau / dy1 + y1);\n point[0] -= pi * (H - 1) / H - i * k;\n if (y < 0) point[1] = -point[1];\n return point;\n }\n return healpixLambert.invert(x, y);\n };\n\n return forward;\n}\n\nfunction sphereTop(x, i) {\n return [x, i & 1 ? 90 - epsilon : healpixParallel];\n}\n\nfunction sphereBottom(x, i) {\n return [x, i & 1 ? -90 + epsilon : -healpixParallel];\n}\n\nfunction sphereNudge(d) {\n return [d[0] * (1 - epsilon), d[1]];\n}\n\nfunction sphere(step) {\n var c = [].concat(\n range(-180, 180 + step / 2, step).map(sphereTop),\n range(180, -180 - step / 2, -step).map(sphereBottom)\n );\n return {\n type: \"Polygon\",\n coordinates: [step === 180 ? c.map(sphereNudge) : c]\n };\n}\n\nexport default function() {\n var H = 4,\n m = projectionMutator(healpixRaw),\n p = m(H),\n stream_ = p.stream;\n\n p.lobes = function(_) {\n return arguments.length ? m(H = +_) : H;\n };\n\n p.stream = function(stream) {\n var rotate = p.rotate(),\n rotateStream = stream_(stream),\n sphereStream = (p.rotate([0, 0]), stream_(stream));\n p.rotate(rotate);\n rotateStream.sphere = function() { geoStream(sphere(180 / H), sphereStream); };\n return rotateStream;\n };\n\n return p\n .scale(239.75);\n}\n","import {geoProjectionMutator as projectionMutator} from \"d3-geo\";\nimport {abs, acos, asin, atan2, cos, epsilon2, halfPi, pi, sin, sqrt} from \"./math.js\";\n\nexport function hillRaw(K) {\n var L = 1 + K,\n sinBt = sin(1 / L),\n Bt = asin(sinBt),\n A = 2 * sqrt(pi / (B = pi + 4 * Bt * L)),\n B,\n rho0 = 0.5 * A * (L + sqrt(K * (2 + K))),\n K2 = K * K,\n L2 = L * L;\n\n function forward(lambda, phi) {\n var t = 1 - sin(phi),\n rho,\n omega;\n if (t && t < 2) {\n var theta = halfPi - phi, i = 25, delta;\n do {\n var sinTheta = sin(theta),\n cosTheta = cos(theta),\n Bt_Bt1 = Bt + atan2(sinTheta, L - cosTheta),\n C = 1 + L2 - 2 * L * cosTheta;\n theta -= delta = (theta - K2 * Bt - L * sinTheta + C * Bt_Bt1 -0.5 * t * B) / (2 * L * sinTheta * Bt_Bt1);\n } while (abs(delta) > epsilon2 && --i > 0);\n rho = A * sqrt(C);\n omega = lambda * Bt_Bt1 / pi;\n } else {\n rho = A * (K + t);\n omega = lambda * Bt / pi;\n }\n return [\n rho * sin(omega),\n rho0 - rho * cos(omega)\n ];\n }\n\n forward.invert = function(x, y) {\n var rho2 = x * x + (y -= rho0) * y,\n cosTheta = (1 + L2 - rho2 / (A * A)) / (2 * L),\n theta = acos(cosTheta),\n sinTheta = sin(theta),\n Bt_Bt1 = Bt + atan2(sinTheta, L - cosTheta);\n return [\n asin(x / sqrt(rho2)) * pi / Bt_Bt1,\n asin(1 - 2 * (theta - K2 * Bt - L * sinTheta + (1 + L2 - 2 * L * cosTheta) * Bt_Bt1) / B)\n ];\n };\n\n return forward;\n}\n\nexport default function() {\n var K = 1,\n m = projectionMutator(hillRaw),\n p = m(K);\n\n p.ratio = function(_) {\n return arguments.length ? m(K = +_) : K;\n };\n\n return p\n .scale(167.774)\n .center([0, 18.67]);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {mollweideRaw} from \"./mollweide.js\";\nimport {sinusoidalRaw} from \"./sinusoidal.js\";\n\nexport var sinuMollweidePhi = 0.7109889596207567;\n\nexport var sinuMollweideY = 0.0528035274542;\n\nexport function sinuMollweideRaw(lambda, phi) {\n return phi > -sinuMollweidePhi\n ? (lambda = mollweideRaw(lambda, phi), lambda[1] += sinuMollweideY, lambda)\n : sinusoidalRaw(lambda, phi);\n}\n\nsinuMollweideRaw.invert = function(x, y) {\n return y > -sinuMollweidePhi\n ? mollweideRaw.invert(x, y - sinuMollweideY)\n : sinusoidalRaw.invert(x, y);\n};\n\nexport default function() {\n return projection(sinuMollweideRaw)\n .rotate([-20, -55])\n .scale(164.263)\n .center([0, -5.4036]);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs} from \"./math.js\";\nimport {mollweideRaw} from \"./mollweide.js\";\nimport {sinusoidalRaw} from \"./sinusoidal.js\";\nimport {sinuMollweidePhi, sinuMollweideY} from \"./sinuMollweide.js\";\n\nexport function homolosineRaw(lambda, phi) {\n return abs(phi) > sinuMollweidePhi\n ? (lambda = mollweideRaw(lambda, phi), lambda[1] -= phi > 0 ? sinuMollweideY : -sinuMollweideY, lambda)\n : sinusoidalRaw(lambda, phi);\n}\n\nhomolosineRaw.invert = function(x, y) {\n return abs(y) > sinuMollweidePhi\n ? mollweideRaw.invert(x, y + (y > 0 ? sinuMollweideY : -sinuMollweideY))\n : sinusoidalRaw.invert(x, y);\n};\n\nexport default function() {\n return projection(homolosineRaw)\n .scale(152.63);\n}\n","import { geoProjectionMutator as projectionMutator } from \"d3-geo\";\nimport { asin, cos, degrees, pi, radians, sign, sin, sqrt } from \"./math.js\";\nimport { solve } from \"./newton.js\";\n\nexport function hufnagelRaw(a, b, psiMax, ratio) {\n var k = sqrt(\n (4 * pi) /\n (2 * psiMax +\n (1 + a - b / 2) * sin(2 * psiMax) +\n ((a + b) / 2) * sin(4 * psiMax) +\n (b / 2) * sin(6 * psiMax))\n ),\n c = sqrt(\n ratio *\n sin(psiMax) *\n sqrt((1 + a * cos(2 * psiMax) + b * cos(4 * psiMax)) / (1 + a + b))\n ),\n M = psiMax * mapping(1);\n\n function radius(psi) {\n return sqrt(1 + a * cos(2 * psi) + b * cos(4 * psi));\n }\n\n function mapping(t) {\n var psi = t * psiMax;\n return (\n (2 * psi +\n (1 + a - b / 2) * sin(2 * psi) +\n ((a + b) / 2) * sin(4 * psi) +\n (b / 2) * sin(6 * psi)) /\n psiMax\n );\n }\n\n function inversemapping(psi) {\n return radius(psi) * sin(psi);\n }\n\n var forward = function(lambda, phi) {\n var psi = psiMax * solve(mapping, (M * sin(phi)) / psiMax, phi / pi);\n if (isNaN(psi)) psi = psiMax * sign(phi);\n var kr = k * radius(psi);\n return [((kr * c * lambda) / pi) * cos(psi), (kr / c) * sin(psi)];\n };\n\n forward.invert = function(x, y) {\n var psi = solve(inversemapping, (y * c) / k);\n return [\n (x * pi) / (cos(psi) * k * c * radius(psi)),\n asin((psiMax * mapping(psi / psiMax)) / M)\n ];\n };\n\n if (psiMax === 0) {\n k = sqrt(ratio / pi);\n forward = function(lambda, phi) {\n return [lambda * k, sin(phi) / k];\n };\n forward.invert = function(x, y) {\n return [x / k, asin(y * k)];\n };\n }\n\n return forward;\n}\n\nexport default function() {\n var a = 1,\n b = 0,\n psiMax = 45 * radians,\n ratio = 2,\n mutate = projectionMutator(hufnagelRaw),\n projection = mutate(a, b, psiMax, ratio);\n\n projection.a = function(_) {\n return arguments.length ? mutate((a = +_), b, psiMax, ratio) : a;\n };\n projection.b = function(_) {\n return arguments.length ? mutate(a, (b = +_), psiMax, ratio) : b;\n };\n projection.psiMax = function(_) {\n return arguments.length\n ? mutate(a, b, (psiMax = +_ * radians), ratio)\n : psiMax * degrees;\n };\n projection.ratio = function(_) {\n return arguments.length ? mutate(a, b, psiMax, (ratio = +_)) : ratio;\n };\n\n return projection.scale(180.739);\n}\n","// https://github.com/scijs/integrate-adaptive-simpson\n\n// This algorithm adapted from pseudocode in:\n// http://www.math.utk.edu/~ccollins/refs/Handouts/rich.pdf\nfunction adsimp (f, a, b, fa, fm, fb, V0, tol, maxdepth, depth, state) {\n if (state.nanEncountered) {\n return NaN;\n }\n\n var h, f1, f2, sl, sr, s2, m, V1, V2, err;\n\n h = b - a;\n f1 = f(a + h * 0.25);\n f2 = f(b - h * 0.25);\n\n // Simple check for NaN:\n if (isNaN(f1)) {\n state.nanEncountered = true;\n return;\n }\n\n // Simple check for NaN:\n if (isNaN(f2)) {\n state.nanEncountered = true;\n return;\n }\n\n sl = h * (fa + 4 * f1 + fm) / 12;\n sr = h * (fm + 4 * f2 + fb) / 12;\n s2 = sl + sr;\n err = (s2 - V0) / 15;\n\n if (depth > maxdepth) {\n state.maxDepthCount++;\n return s2 + err;\n } else if (Math.abs(err) < tol) {\n return s2 + err;\n } else {\n m = a + h * 0.5;\n\n V1 = adsimp(f, a, m, fa, f1, fm, sl, tol * 0.5, maxdepth, depth + 1, state);\n\n if (isNaN(V1)) {\n state.nanEncountered = true;\n return NaN;\n }\n\n V2 = adsimp(f, m, b, fm, f2, fb, sr, tol * 0.5, maxdepth, depth + 1, state);\n\n if (isNaN(V2)) {\n state.nanEncountered = true;\n return NaN;\n }\n\n return V1 + V2;\n }\n}\n\nexport function integrate (f, a, b, tol, maxdepth) {\n var state = {\n maxDepthCount: 0,\n nanEncountered: false\n };\n\n if (tol === undefined) {\n tol = 1e-8;\n }\n if (maxdepth === undefined) {\n maxdepth = 20;\n }\n\n var fa = f(a);\n var fm = f(0.5 * (a + b));\n var fb = f(b);\n\n var V0 = (fa + 4 * fm + fb) * (b - a) / 6;\n\n var result = adsimp(f, a, b, fa, fm, fb, V0, tol, maxdepth, 1, state);\n\n/*\n if (state.maxDepthCount > 0 && console && console.warn) {\n console.warn('integrate-adaptive-simpson: Warning: maximum recursion depth (' + maxdepth + ') reached ' + state.maxDepthCount + ' times');\n }\n\n if (state.nanEncountered && console && console.warn) {\n console.warn('integrate-adaptive-simpson: Warning: NaN encountered. Halting early.');\n }\n*/\n\n return result;\n}","import {geoProjectionMutator as projectionMutator} from \"d3-geo\";\nimport {abs, asin, pi, pow, sign, sin} from \"./math.js\";\nimport {integrate} from \"./integrate.js\";\n\nexport function hyperellipticalRaw(alpha, k, gamma) {\n\n function elliptic (f) {\n return alpha + (1 - alpha) * pow(1 - pow(f, k), 1 / k);\n }\n\n function z(f) {\n return integrate(elliptic, 0, f, 1e-4);\n }\n\n var G = 1 / z(1),\n n = 1000,\n m = (1 + 1e-8) * G,\n approx = [];\n for (var i = 0; i <= n; i++)\n approx.push(z(i / n) * m);\n\n function Y(sinphi) {\n var rmin = 0, rmax = n, r = n >> 1;\n do {\n if (approx[r] > sinphi) rmax = r; else rmin = r;\n r = (rmin + rmax) >> 1;\n } while (r > rmin);\n var u = approx[r + 1] - approx[r];\n if (u) u = (sinphi - approx[r + 1]) / u;\n return (r + 1 + u) / n;\n }\n\n var ratio = 2 * Y(1) / pi * G / gamma;\n\n var forward = function(lambda, phi) {\n var y = Y(abs(sin(phi))),\n x = elliptic(y) * lambda;\n y /= ratio;\n return [ x, (phi >= 0) ? y : -y ];\n };\n\n forward.invert = function(x, y) {\n var phi;\n y *= ratio;\n if (abs(y) < 1) phi = sign(y) * asin(z(abs(y)) * G);\n return [ x / elliptic(abs(y)), phi ];\n };\n\n return forward;\n}\n\nexport default function() {\n var alpha = 0,\n k = 2.5,\n gamma = 1.183136, // affine = sqrt(2 * gamma / pi) = 0.8679\n m = projectionMutator(hyperellipticalRaw),\n p = m(alpha, k, gamma);\n\n p.alpha = function(_) {\n return arguments.length ? m(alpha = +_, k, gamma) : alpha;\n };\n\n p.k = function(_) {\n return arguments.length ? m(alpha, k = +_, gamma) : k;\n };\n\n p.gamma = function(_) {\n return arguments.length ? m(alpha, k, gamma = +_) : gamma;\n };\n\n return p\n .scale(152.63);\n}\n","import {merge} from \"d3-array\";\nimport {geoStream, geoProjection as projection} from \"d3-geo\";\nimport {abs, degrees, epsilon, radians} from \"../math.js\";\n\nfunction pointEqual(a, b) {\n return abs(a[0] - b[0]) < epsilon && abs(a[1] - b[1]) < epsilon;\n}\n\nfunction interpolateLine(coordinates, m) {\n var i = -1,\n n = coordinates.length,\n p0 = coordinates[0],\n p1,\n dx,\n dy,\n resampled = [];\n while (++i < n) {\n p1 = coordinates[i];\n dx = (p1[0] - p0[0]) / m;\n dy = (p1[1] - p0[1]) / m;\n for (var j = 0; j < m; ++j) resampled.push([p0[0] + j * dx, p0[1] + j * dy]);\n p0 = p1;\n }\n resampled.push(p1);\n return resampled;\n}\n\nfunction interpolateSphere(lobes) {\n var coordinates = [],\n lobe,\n lambda0, phi0, phi1,\n lambda2, phi2,\n i, n = lobes[0].length;\n\n // Northern Hemisphere\n for (i = 0; i < n; ++i) {\n lobe = lobes[0][i];\n lambda0 = lobe[0][0], phi0 = lobe[0][1], phi1 = lobe[1][1];\n lambda2 = lobe[2][0], phi2 = lobe[2][1];\n coordinates.push(interpolateLine([\n [lambda0 + epsilon, phi0 + epsilon],\n [lambda0 + epsilon, phi1 - epsilon],\n [lambda2 - epsilon, phi1 - epsilon],\n [lambda2 - epsilon, phi2 + epsilon]\n ], 30));\n }\n\n // Southern Hemisphere\n for (i = lobes[1].length - 1; i >= 0; --i) {\n lobe = lobes[1][i];\n lambda0 = lobe[0][0], phi0 = lobe[0][1], phi1 = lobe[1][1];\n lambda2 = lobe[2][0], phi2 = lobe[2][1];\n coordinates.push(interpolateLine([\n [lambda2 - epsilon, phi2 - epsilon],\n [lambda2 - epsilon, phi1 + epsilon],\n [lambda0 + epsilon, phi1 + epsilon],\n [lambda0 + epsilon, phi0 - epsilon]\n ], 30));\n }\n\n return {\n type: \"Polygon\",\n coordinates: [merge(coordinates)]\n };\n}\n\nexport default function(project, lobes, inverse) {\n var sphere, bounds;\n\n function forward(lambda, phi) {\n var sign = phi < 0 ? -1 : +1, lobe = lobes[+(phi < 0)];\n for (var i = 0, n = lobe.length - 1; i < n && lambda > lobe[i][2][0]; ++i);\n var p = project(lambda - lobe[i][1][0], phi);\n p[0] += project(lobe[i][1][0], sign * phi > sign * lobe[i][0][1] ? lobe[i][0][1] : phi)[0];\n return p;\n }\n\n if (inverse) {\n forward.invert = inverse(forward);\n } else if (project.invert) {\n forward.invert = function(x, y) {\n var bound = bounds[+(y < 0)], lobe = lobes[+(y < 0)];\n for (var i = 0, n = bound.length; i < n; ++i) {\n var b = bound[i];\n if (b[0][0] <= x && x < b[1][0] && b[0][1] <= y && y < b[1][1]) {\n var p = project.invert(x - project(lobe[i][1][0], 0)[0], y);\n p[0] += lobe[i][1][0];\n return pointEqual(forward(p[0], p[1]), [x, y]) ? p : null;\n }\n }\n };\n }\n\n var p = projection(forward),\n stream_ = p.stream;\n\n p.stream = function(stream) {\n var rotate = p.rotate(),\n rotateStream = stream_(stream),\n sphereStream = (p.rotate([0, 0]), stream_(stream));\n p.rotate(rotate);\n rotateStream.sphere = function() { geoStream(sphere, sphereStream); };\n return rotateStream;\n };\n \n p.lobes = function(_) {\n if (!arguments.length) return lobes.map(function(lobe) {\n return lobe.map(function(l) {\n return [\n [l[0][0] * degrees, l[0][1] * degrees],\n [l[1][0] * degrees, l[1][1] * degrees],\n [l[2][0] * degrees, l[2][1] * degrees]\n ];\n });\n });\n\n sphere = interpolateSphere(_);\n\n lobes = _.map(function(lobe) {\n return lobe.map(function(l) {\n return [\n [l[0][0] * radians, l[0][1] * radians],\n [l[1][0] * radians, l[1][1] * radians],\n [l[2][0] * radians, l[2][1] * radians]\n ];\n });\n });\n\n bounds = lobes.map(function(lobe) {\n return lobe.map(function(l) {\n var x0 = project(l[0][0], l[0][1])[0],\n x1 = project(l[2][0], l[2][1])[0],\n y0 = project(l[1][0], l[0][1])[1],\n y1 = project(l[1][0], l[1][1])[1],\n t;\n if (y0 > y1) t = y0, y0 = y1, y1 = t;\n return [[x0, y0], [x1, y1]];\n });\n });\n\n return p;\n };\n\n if (lobes != null) p.lobes(lobes);\n\n return p;\n}\n","import {boggsRaw} from \"../boggs.js\";\nimport interrupt from \"./index.js\";\n\nvar lobes = [[ // northern hemisphere\n [[-180, 0], [-100, 90], [ -40, 0]],\n [[ -40, 0], [ 30, 90], [ 180, 0]]\n], [ // southern hemisphere\n [[-180, 0], [-160, -90], [-100, 0]],\n [[-100, 0], [ -60, -90], [ -20, 0]],\n [[ -20, 0], [ 20, -90], [ 80, 0]],\n [[ 80, 0], [ 140, -90], [ 180, 0]]\n]];\n\nexport default function() {\n return interrupt(boggsRaw, lobes)\n .scale(160.857);\n}\n","import {homolosineRaw} from \"../homolosine.js\";\nimport interrupt from \"./index.js\";\n\nvar lobes = [[ // northern hemisphere\n [[-180, 0], [-100, 90], [ -40, 0]],\n [[ -40, 0], [ 30, 90], [ 180, 0]]\n], [ // southern hemisphere\n [[-180, 0], [-160, -90], [-100, 0]],\n [[-100, 0], [ -60, -90], [ -20, 0]],\n [[ -20, 0], [ 20, -90], [ 80, 0]],\n [[ 80, 0], [ 140, -90], [ 180, 0]]\n]];\n\nexport default function() {\n return interrupt(homolosineRaw, lobes)\n .scale(152.63);\n}\n","import {mollweideRaw} from \"../mollweide.js\";\nimport interrupt from \"./index.js\";\n\nvar lobes = [[ // northern hemisphere\n [[-180, 0], [-100, 90], [ -40, 0]],\n [[ -40, 0], [ 30, 90], [ 180, 0]]\n], [ // southern hemisphere\n [[-180, 0], [-160, -90], [-100, 0]],\n [[-100, 0], [ -60, -90], [ -20, 0]],\n [[ -20, 0], [ 20, -90], [ 80, 0]],\n [[ 80, 0], [ 140, -90], [ 180, 0]]\n]];\n\nexport default function() {\n return interrupt(mollweideRaw, lobes)\n .scale(169.529);\n}\n","import {mollweideRaw} from \"../mollweide.js\";\nimport interrupt from \"./index.js\";\n\nvar lobes = [[ // northern hemisphere\n [[-180, 0], [ -90, 90], [ 0, 0]],\n [[ 0, 0], [ 90, 90], [ 180, 0]]\n], [ // southern hemisphere\n [[-180, 0], [ -90, -90], [ 0, 0]],\n [[ 0, 0], [ 90, -90], [ 180, 0]]\n]];\n\nexport default function() {\n return interrupt(mollweideRaw, lobes)\n .scale(169.529)\n .rotate([20, 0]);\n}\n","import {sinuMollweideRaw} from \"../sinuMollweide.js\";\nimport interrupt from \"./index.js\";\nimport {solve2d} from \"../newton.js\";\n\nvar lobes = [[ // northern hemisphere\n [[-180, 35], [ -30, 90], [ 0, 35]],\n [[ 0, 35], [ 30, 90], [ 180, 35]]\n], [ // southern hemisphere\n [[-180, -10], [-102, -90], [ -65, -10]],\n [[ -65, -10], [ 5, -90], [ 77, -10]],\n [[ 77, -10], [ 103, -90], [ 180, -10]]\n]];\n\nexport default function() {\n return interrupt(sinuMollweideRaw, lobes, solve2d)\n .rotate([-20, -55])\n .scale(164.263)\n .center([0, -5.4036]);\n}\n","import {sinusoidalRaw} from \"../sinusoidal.js\";\nimport interrupt from \"./index.js\";\n\nvar lobes = [[ // northern hemisphere\n [[-180, 0], [-110, 90], [ -40, 0]],\n [[ -40, 0], [ 0, 90], [ 40, 0]],\n [[ 40, 0], [ 110, 90], [ 180, 0]]\n], [ // southern hemisphere\n [[-180, 0], [-110, -90], [ -40, 0]],\n [[ -40, 0], [ 0, -90], [ 40, 0]],\n [[ 40, 0], [ 110, -90], [ 180, 0]]\n]];\n\nexport default function() {\n return interrupt(sinusoidalRaw, lobes)\n .scale(152.63)\n .rotate([-20, 0]);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {pi, sqrt, tau} from \"./math.js\";\n\nexport function kavrayskiy7Raw(lambda, phi) {\n return [3 / tau * lambda * sqrt(pi * pi / 3 - phi * phi), phi];\n}\n\nkavrayskiy7Raw.invert = function(x, y) {\n return [tau / 3 * x / sqrt(pi * pi / 3 - y * y), y];\n};\n\nexport default function() {\n return projection(kavrayskiy7Raw)\n .scale(158.837);\n}\n","import {geoProjectionMutator as projectionMutator} from \"d3-geo\";\nimport {abs, asin, atan2, cos, epsilon, halfPi, pow, sign, sin} from \"./math.js\";\n\nexport function lagrangeRaw(n) {\n\n function forward(lambda, phi) {\n if (abs(abs(phi) - halfPi) < epsilon) return [0, phi < 0 ? -2 : 2];\n var sinPhi = sin(phi),\n v = pow((1 + sinPhi) / (1 - sinPhi), n / 2),\n c = 0.5 * (v + 1 / v) + cos(lambda *= n);\n return [\n 2 * sin(lambda) / c,\n (v - 1 / v) / c\n ];\n }\n\n forward.invert = function(x, y) {\n var y0 = abs(y);\n if (abs(y0 - 2) < epsilon) return x ? null : [0, sign(y) * halfPi];\n if (y0 > 2) return null;\n\n x /= 2, y /= 2;\n var x2 = x * x,\n y2 = y * y,\n t = 2 * y / (1 + x2 + y2); // tanh(nPhi)\n t = pow((1 + t) / (1 - t), 1 / n);\n return [\n atan2(2 * x, 1 - x2 - y2) / n,\n asin((t - 1) / (t + 1))\n ];\n };\n\n return forward;\n}\n\nexport default function() {\n var n = 0.5,\n m = projectionMutator(lagrangeRaw),\n p = m(n);\n\n p.spacing = function(_) {\n return arguments.length ? m(n = +_) : n;\n };\n\n return p\n .scale(124.75);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, acos, cos, epsilon, halfPi, sin, pi, sqrt, sqrt2} from \"./math.js\";\n\nvar pi_sqrt2 = pi / sqrt2;\n\nexport function larriveeRaw(lambda, phi) {\n return [\n lambda * (1 + sqrt(cos(phi))) / 2,\n phi / (cos(phi / 2) * cos(lambda / 6))\n ];\n}\n\nlarriveeRaw.invert = function(x, y) {\n var x0 = abs(x),\n y0 = abs(y),\n lambda = epsilon,\n phi = halfPi;\n if (y0 < pi_sqrt2) phi *= y0 / pi_sqrt2;\n else lambda += 6 * acos(pi_sqrt2 / y0);\n for (var i = 0; i < 25; i++) {\n var sinPhi = sin(phi),\n sqrtcosPhi = sqrt(cos(phi)),\n sinPhi_2 = sin(phi / 2),\n cosPhi_2 = cos(phi / 2),\n sinLambda_6 = sin(lambda / 6),\n cosLambda_6 = cos(lambda / 6),\n f0 = 0.5 * lambda * (1 + sqrtcosPhi) - x0,\n f1 = phi / (cosPhi_2 * cosLambda_6) - y0,\n df0dPhi = sqrtcosPhi ? -0.25 * lambda * sinPhi / sqrtcosPhi : 0,\n df0dLambda = 0.5 * (1 + sqrtcosPhi),\n df1dPhi = (1 + 0.5 * phi * sinPhi_2 / cosPhi_2) / (cosPhi_2 * cosLambda_6),\n df1dLambda = (phi / cosPhi_2) * (sinLambda_6 / 6) / (cosLambda_6 * cosLambda_6),\n denom = df0dPhi * df1dLambda - df1dPhi * df0dLambda,\n dPhi = (f0 * df1dLambda - f1 * df0dLambda) / denom,\n dLambda = (f1 * df0dPhi - f0 * df1dPhi) / denom;\n phi -= dPhi;\n lambda -= dLambda;\n if (abs(dPhi) < epsilon && abs(dLambda) < epsilon) break;\n }\n return [x < 0 ? -lambda : lambda, y < 0 ? -phi : phi];\n};\n\nexport default function() {\n return projection(larriveeRaw)\n .scale(97.2672);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, epsilon, pi, sign} from \"./math.js\";\n\nexport function laskowskiRaw(lambda, phi) {\n var lambda2 = lambda * lambda, phi2 = phi * phi;\n return [\n lambda * (0.975534 + phi2 * (-0.119161 + lambda2 * -0.0143059 + phi2 * -0.0547009)),\n phi * (1.00384 + lambda2 * (0.0802894 + phi2 * -0.02855 + lambda2 * 0.000199025) + phi2 * (0.0998909 + phi2 * -0.0491032))\n ];\n}\n\nlaskowskiRaw.invert = function(x, y) {\n var lambda = sign(x) * pi,\n phi = y / 2,\n i = 50;\n do {\n var lambda2 = lambda * lambda,\n phi2 = phi * phi,\n lambdaPhi = lambda * phi,\n fx = lambda * (0.975534 + phi2 * (-0.119161 + lambda2 * -0.0143059 + phi2 * -0.0547009)) - x,\n fy = phi * (1.00384 + lambda2 * (0.0802894 + phi2 * -0.02855 + lambda2 * 0.000199025) + phi2 * (0.0998909 + phi2 * -0.0491032)) - y,\n deltaxDeltaLambda = 0.975534 - phi2 * (0.119161 + 3 * lambda2 * 0.0143059 + phi2 * 0.0547009),\n deltaxDeltaPhi = -lambdaPhi * (2 * 0.119161 + 4 * 0.0547009 * phi2 + 2 * 0.0143059 * lambda2),\n deltayDeltaLambda = lambdaPhi * (2 * 0.0802894 + 4 * 0.000199025 * lambda2 + 2 * -0.02855 * phi2),\n deltayDeltaPhi = 1.00384 + lambda2 * (0.0802894 + 0.000199025 * lambda2) + phi2 * (3 * (0.0998909 - 0.02855 * lambda2) - 5 * 0.0491032 * phi2),\n denominator = deltaxDeltaPhi * deltayDeltaLambda - deltayDeltaPhi * deltaxDeltaLambda,\n deltaLambda = (fy * deltaxDeltaPhi - fx * deltayDeltaPhi) / denominator,\n deltaPhi = (fx * deltayDeltaLambda - fy * deltaxDeltaLambda) / denominator;\n lambda -= deltaLambda, phi -= deltaPhi;\n } while ((abs(deltaLambda) > epsilon || abs(deltaPhi) > epsilon) && --i > 0);\n return i && [lambda, phi];\n};\n\nexport default function() {\n return projection(laskowskiRaw)\n .scale(139.98);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {acos, asin, cos, sign, sin, tan, sqrt, sqrt1_2} from \"./math.js\";\n\nexport function littrowRaw(lambda, phi) {\n return [\n sin(lambda) / cos(phi),\n tan(phi) * cos(lambda)\n ];\n}\n\nlittrowRaw.invert = function(x, y) {\n var x2 = x * x,\n y2 = y * y,\n y2_1 = y2 + 1,\n x2_y2_1 = x2 + y2_1,\n cosPhi = x\n ? sqrt1_2 * sqrt((x2_y2_1 - sqrt(x2_y2_1 * x2_y2_1 - 4 * x2)) / x2)\n : 1 / sqrt(y2_1);\n return [\n asin(x * cosPhi),\n sign(y) * acos(cosPhi)\n ];\n};\n\nexport default function() {\n return projection(littrowRaw)\n .scale(144.049)\n .clipAngle(90 - 1e-3);\n}\n","import parallel1 from \"./parallel1.js\";\nimport {abs, cos, epsilon, halfPi, log, quarterPi, tan} from \"./math.js\";\n\nexport function loximuthalRaw(phi0) {\n var cosPhi0 = cos(phi0),\n tanPhi0 = tan(quarterPi + phi0 / 2);\n\n function forward(lambda, phi) {\n var y = phi - phi0,\n x = abs(y) < epsilon ? lambda * cosPhi0\n : abs(x = quarterPi + phi / 2) < epsilon || abs(abs(x) - halfPi) < epsilon\n ? 0 : lambda * y / log(tan(x) / tanPhi0);\n return [x, y];\n }\n\n forward.invert = function(x, y) {\n var lambda,\n phi = y + phi0;\n return [\n abs(y) < epsilon ? x / cosPhi0\n : (abs(lambda = quarterPi + phi / 2) < epsilon || abs(abs(lambda) - halfPi) < epsilon) ? 0\n : x * log(tan(lambda) / tanPhi0) / y,\n phi\n ];\n };\n\n return forward;\n}\n\nexport default function() {\n return parallel1(loximuthalRaw)\n .parallel(40)\n .scale(158.837);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {atan, exp, log, quarterPi, pi, tan} from \"./math.js\";\n\nexport function millerRaw(lambda, phi) {\n return [lambda, 1.25 * log(tan(quarterPi + 0.4 * phi))];\n}\n\nmillerRaw.invert = function(x, y) {\n return [x, 2.5 * atan(exp(0.8 * y)) - 0.625 * pi];\n};\n\nexport default function() {\n return projection(millerRaw)\n .scale(108.318);\n}\n","import {geoProjection as projection, geoRotation as rotation} from \"d3-geo\";\nimport {abs, asin, atan, atan2, cos, epsilon, sin, sqrt} from \"./math.js\";\n\nexport function modifiedStereographicRaw(C) {\n var m = C.length - 1;\n\n function forward(lambda, phi) {\n var cosPhi = cos(phi),\n k = 2 / (1 + cosPhi * cos(lambda)),\n zr = k * cosPhi * sin(lambda),\n zi = k * sin(phi),\n i = m,\n w = C[i],\n ar = w[0],\n ai = w[1],\n t;\n while (--i >= 0) {\n w = C[i];\n ar = w[0] + zr * (t = ar) - zi * ai;\n ai = w[1] + zr * ai + zi * t;\n }\n ar = zr * (t = ar) - zi * ai;\n ai = zr * ai + zi * t;\n return [ar, ai];\n }\n\n forward.invert = function(x, y) {\n var i = 20,\n zr = x,\n zi = y;\n do {\n var j = m,\n w = C[j],\n ar = w[0],\n ai = w[1],\n br = 0,\n bi = 0,\n t;\n\n while (--j >= 0) {\n w = C[j];\n br = ar + zr * (t = br) - zi * bi;\n bi = ai + zr * bi + zi * t;\n ar = w[0] + zr * (t = ar) - zi * ai;\n ai = w[1] + zr * ai + zi * t;\n }\n br = ar + zr * (t = br) - zi * bi;\n bi = ai + zr * bi + zi * t;\n ar = zr * (t = ar) - zi * ai - x;\n ai = zr * ai + zi * t - y;\n\n var denominator = br * br + bi * bi, deltar, deltai;\n zr -= deltar = (ar * br + ai * bi) / denominator;\n zi -= deltai = (ai * br - ar * bi) / denominator;\n } while (abs(deltar) + abs(deltai) > epsilon * epsilon && --i > 0);\n\n if (i) {\n var rho = sqrt(zr * zr + zi * zi),\n c = 2 * atan(rho * 0.5),\n sinc = sin(c);\n return [atan2(zr * sinc, rho * cos(c)), rho ? asin(zi * sinc / rho) : 0];\n }\n };\n\n return forward;\n}\n\nvar alaska = [[0.9972523, 0], [0.0052513, -0.0041175], [0.0074606, 0.0048125], [-0.0153783, -0.1968253], [0.0636871, -0.1408027], [0.3660976, -0.2937382]],\n gs48 = [[0.98879, 0], [0, 0], [-0.050909, 0], [0, 0], [0.075528, 0]],\n gs50 = [[0.9842990, 0], [0.0211642, 0.0037608], [-0.1036018, -0.0575102], [-0.0329095, -0.0320119], [0.0499471, 0.1223335], [0.0260460, 0.0899805], [0.0007388, -0.1435792], [0.0075848, -0.1334108], [-0.0216473, 0.0776645], [-0.0225161, 0.0853673]],\n miller = [[0.9245, 0], [0, 0], [0.01943, 0]],\n lee = [[0.721316, 0], [0, 0], [-0.00881625, -0.00617325]];\n\nexport function modifiedStereographicAlaska() {\n return modifiedStereographic(alaska, [152, -64])\n .scale(1400)\n .center([-160.908, 62.4864])\n .clipAngle(30)\n .angle(7.8);\n}\n\nexport function modifiedStereographicGs48() {\n return modifiedStereographic(gs48, [95, -38])\n .scale(1000)\n .clipAngle(55)\n .center([-96.5563, 38.8675]);\n}\n\nexport function modifiedStereographicGs50() {\n return modifiedStereographic(gs50, [120, -45])\n .scale(359.513)\n .clipAngle(55)\n .center([-117.474, 53.0628]);\n}\n\nexport function modifiedStereographicMiller() {\n return modifiedStereographic(miller, [-20, -18])\n .scale(209.091)\n .center([20, 16.7214])\n .clipAngle(82);\n}\n\nexport function modifiedStereographicLee() {\n return modifiedStereographic(lee, [165, 10])\n .scale(250)\n .clipAngle(130)\n .center([-165, -10]);\n}\n\nexport default function modifiedStereographic(coefficients, rotate) {\n var p = projection(modifiedStereographicRaw(coefficients)).rotate(rotate).clipAngle(90),\n r = rotation(rotate),\n center = p.center;\n\n delete p.rotate;\n\n p.center = function(_) {\n return arguments.length ? center(r(_)) : r.invert(center());\n };\n\n return p;\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {asin, cos, sin, sqrt} from \"./math.js\";\n\nvar sqrt6 = sqrt(6),\n sqrt7 = sqrt(7);\n\nexport function mtFlatPolarParabolicRaw(lambda, phi) {\n var theta = asin(7 * sin(phi) / (3 * sqrt6));\n return [\n sqrt6 * lambda * (2 * cos(2 * theta / 3) - 1) / sqrt7,\n 9 * sin(theta / 3) / sqrt7\n ];\n}\n\nmtFlatPolarParabolicRaw.invert = function(x, y) {\n var theta = 3 * asin(y * sqrt7 / 9);\n return [\n x * sqrt7 / (sqrt6 * (2 * cos(2 * theta / 3) - 1)),\n asin(sin(theta) * 3 * sqrt6 / 7)\n ];\n};\n\nexport default function() {\n return projection(mtFlatPolarParabolicRaw)\n .scale(164.859);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, asin, cos, epsilon, sin, sqrt, sqrt1_2, sqrt2} from \"./math.js\";\n\nexport function mtFlatPolarQuarticRaw(lambda, phi) {\n var k = (1 + sqrt1_2) * sin(phi),\n theta = phi;\n for (var i = 0, delta; i < 25; i++) {\n theta -= delta = (sin(theta / 2) + sin(theta) - k) / (0.5 * cos(theta / 2) + cos(theta));\n if (abs(delta) < epsilon) break;\n }\n return [\n lambda * (1 + 2 * cos(theta) / cos(theta / 2)) / (3 * sqrt2),\n 2 * sqrt(3) * sin(theta / 2) / sqrt(2 + sqrt2)\n ];\n}\n\nmtFlatPolarQuarticRaw.invert = function(x, y) {\n var sinTheta_2 = y * sqrt(2 + sqrt2) / (2 * sqrt(3)),\n theta = 2 * asin(sinTheta_2);\n return [\n 3 * sqrt2 * x / (1 + 2 * cos(theta) / cos(theta / 2)),\n asin((sinTheta_2 + sin(theta)) / (1 + sqrt1_2))\n ];\n};\n\nexport default function() {\n return projection(mtFlatPolarQuarticRaw)\n .scale(188.209);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, asin, cos, epsilon, halfPi, pi, sin, sqrt} from \"./math.js\";\n\nexport function mtFlatPolarSinusoidalRaw(lambda, phi) {\n var A = sqrt(6 / (4 + pi)),\n k = (1 + pi / 4) * sin(phi),\n theta = phi / 2;\n for (var i = 0, delta; i < 25; i++) {\n theta -= delta = (theta / 2 + sin(theta) - k) / (0.5 + cos(theta));\n if (abs(delta) < epsilon) break;\n }\n return [\n A * (0.5 + cos(theta)) * lambda / 1.5,\n A * theta\n ];\n}\n\nmtFlatPolarSinusoidalRaw.invert = function(x, y) {\n var A = sqrt(6 / (4 + pi)),\n theta = y / A;\n if (abs(abs(theta) - halfPi) < epsilon) theta = theta < 0 ? -halfPi : halfPi;\n return [\n 1.5 * x / (A * (0.5 + cos(theta))),\n asin((theta / 2 + sin(theta)) / (1 + pi / 4))\n ];\n};\n\nexport default function() {\n return projection(mtFlatPolarSinusoidalRaw)\n .scale(166.518);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, epsilon2} from \"./math.js\";\n\nexport function naturalEarth2Raw(lambda, phi) {\n var phi2 = phi * phi, phi4 = phi2 * phi2, phi6 = phi2 * phi4;\n return [\n lambda * (0.84719 - 0.13063 * phi2 + phi6 * phi6 * (-0.04515 + 0.05494 * phi2 - 0.02326 * phi4 + 0.00331 * phi6)),\n phi * (1.01183 + phi4 * phi4 * (-0.02625 + 0.01926 * phi2 - 0.00396 * phi4))\n ];\n}\n\nnaturalEarth2Raw.invert = function(x, y) {\n var phi = y, i = 25, delta, phi2, phi4, phi6;\n do {\n phi2 = phi * phi; phi4 = phi2 * phi2;\n phi -= delta = ((phi * (1.01183 + phi4 * phi4 * (-0.02625 + 0.01926 * phi2 - 0.00396 * phi4))) - y) /\n (1.01183 + phi4 * phi4 * ((9 * -0.02625) + (11 * 0.01926) * phi2 + (13 * -0.00396) * phi4));\n } while (abs(delta) > epsilon2 && --i > 0);\n phi2 = phi * phi; phi4 = phi2 * phi2; phi6 = phi2 * phi4;\n return [\n x / (0.84719 - 0.13063 * phi2 + phi6 * phi6 * (-0.04515 + 0.05494 * phi2 - 0.02326 * phi4 + 0.00331 * phi6)),\n phi\n ];\n};\n\nexport default function() {\n return projection(naturalEarth2Raw)\n .scale(175.295);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, cos, epsilon, tan} from \"./math.js\";\n\nexport function nellHammerRaw(lambda, phi) {\n return [\n lambda * (1 + cos(phi)) / 2,\n 2 * (phi - tan(phi / 2))\n ];\n}\n\nnellHammerRaw.invert = function(x, y) {\n var p = y / 2;\n for (var i = 0, delta = Infinity; i < 10 && abs(delta) > epsilon; ++i) {\n var c = cos(y / 2);\n y -= delta = (y - tan(y / 2) - p) / (1 - 0.5 / (c * c));\n }\n return [\n 2 * x / (1 + cos(y)),\n y\n ];\n};\n\nexport default function() {\n return projection(nellHammerRaw)\n .scale(152.63);\n}\n","import {hammerRaw} from \"../hammer.js\";\nimport interrupt from \"./index.js\";\n\nvar lobes = [[ // northern hemisphere\n [[-180, 0], [-90, 90], [ 0, 0]],\n [[ 0, 0], [ 90, 90], [ 180, 0]]\n], [ // southern hemisphere\n [[-180, 0], [-90, -90], [ 0, 0]],\n [[ 0, 0], [ 90, -90], [180, 0]]\n]];\n\nexport default function() {\n return interrupt(hammerRaw(Infinity), lobes)\n .rotate([20, 0])\n .scale(152.63);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, cos, halfPi, pi, sign, sin, sqrt} from \"./math.js\";\nimport {solve} from \"./newton.js\";\n\n// Based on Torben Jansen's implementation\n// https://beta.observablehq.com/@toja/nicolosi-globular-projection\n// https://beta.observablehq.com/@toja/nicolosi-globular-inverse\n\nexport function nicolosiRaw(lambda, phi) {\n var sinPhi = sin(phi),\n q = cos(phi),\n s = sign(lambda);\n\n if (lambda === 0 || abs(phi) === halfPi) return [0, phi];\n else if (phi === 0) return [lambda, 0];\n else if (abs(lambda) === halfPi) return [lambda * q, halfPi * sinPhi];\n\n var b = pi / (2 * lambda) - (2 * lambda) / pi,\n c = (2 * phi) / pi,\n d = (1 - c * c) / (sinPhi - c);\n\n var b2 = b * b,\n d2 = d * d,\n b2d2 = 1 + b2 / d2,\n d2b2 = 1 + d2 / b2;\n\n var M = ((b * sinPhi) / d - b / 2) / b2d2,\n N = ((d2 * sinPhi) / b2 + d / 2) / d2b2,\n m = M * M + (q * q) / b2d2,\n n = N * N - ((d2 * sinPhi * sinPhi) / b2 + d * sinPhi - 1) / d2b2;\n\n return [\n halfPi * (M + sqrt(m) * s),\n halfPi * (N + sqrt(n < 0 ? 0 : n) * sign(-phi * b) * s)\n ];\n}\n\nnicolosiRaw.invert = function(x, y) {\n\n x /= halfPi;\n y /= halfPi;\n\n var x2 = x * x,\n y2 = y * y,\n x2y2 = x2 + y2,\n pi2 = pi * pi;\n\n return [\n x ? (x2y2 -1 + sqrt((1 - x2y2) * (1 - x2y2) + 4 * x2)) / (2 * x) * halfPi : 0,\n solve(function(phi) {\n return (\n x2y2 * (pi * sin(phi) - 2 * phi) * pi +\n 4 * phi * phi * (y - sin(phi)) +\n 2 * pi * phi -\n pi2 * y\n );\n }, 0)\n ];\n};\n\nexport default function() {\n return projection(nicolosiRaw)\n .scale(127.267);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, epsilon} from \"./math.js\";\n\n// Based on Java implementation by Bojan Savric.\n// https://github.com/OSUCartography/JMapProjLib/blob/master/src/com/jhlabs/map/proj/PattersonProjection.java\n\nvar pattersonK1 = 1.0148,\n pattersonK2 = 0.23185,\n pattersonK3 = -0.14499,\n pattersonK4 = 0.02406,\n pattersonC1 = pattersonK1,\n pattersonC2 = 5 * pattersonK2,\n pattersonC3 = 7 * pattersonK3,\n pattersonC4 = 9 * pattersonK4,\n pattersonYmax = 1.790857183;\n\nexport function pattersonRaw(lambda, phi) {\n var phi2 = phi * phi;\n return [\n lambda,\n phi * (pattersonK1 + phi2 * phi2 * (pattersonK2 + phi2 * (pattersonK3 + pattersonK4 * phi2)))\n ];\n}\n\npattersonRaw.invert = function(x, y) {\n if (y > pattersonYmax) y = pattersonYmax;\n else if (y < -pattersonYmax) y = -pattersonYmax;\n var yc = y, delta;\n\n do { // Newton-Raphson\n var y2 = yc * yc;\n yc -= delta = ((yc * (pattersonK1 + y2 * y2 * (pattersonK2 + y2 * (pattersonK3 + pattersonK4 * y2)))) - y) / (pattersonC1 + y2 * y2 * (pattersonC2 + y2 * (pattersonC3 + pattersonC4 * y2)));\n } while (abs(delta) > epsilon);\n\n return [x, yc];\n};\n\nexport default function() {\n return projection(pattersonRaw)\n .scale(139.319);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, acos, asin, cos, epsilon, halfPi, sign, sin, tan} from \"./math.js\";\n\nexport function polyconicRaw(lambda, phi) {\n if (abs(phi) < epsilon) return [lambda, 0];\n var tanPhi = tan(phi),\n k = lambda * sin(phi);\n return [\n sin(k) / tanPhi,\n phi + (1 - cos(k)) / tanPhi\n ];\n}\n\npolyconicRaw.invert = function(x, y) {\n if (abs(y) < epsilon) return [x, 0];\n var k = x * x + y * y,\n phi = y * 0.5,\n i = 10, delta;\n do {\n var tanPhi = tan(phi),\n secPhi = 1 / cos(phi),\n j = k - 2 * y * phi + phi * phi;\n phi -= delta = (tanPhi * j + 2 * (phi - y)) / (2 + j * secPhi * secPhi + 2 * (phi - y) * tanPhi);\n } while (abs(delta) > epsilon && --i > 0);\n tanPhi = tan(phi);\n return [\n (abs(y) < abs(phi + 1 / tanPhi) ? asin(x * tanPhi) : sign(y) * sign(x) * (acos(abs(x * tanPhi)) + halfPi)) / sin(phi),\n phi\n ];\n};\n\nexport default function() {\n return projection(polyconicRaw)\n .scale(103.74);\n}\n","import {atan2, cos, sin, sqrt} from \"../math.js\";\n\n// Note: 6-element arrays are used to denote the 3x3 affine transform matrix:\n// [a, b, c,\n// d, e, f,\n// 0, 0, 1] - this redundant row is left out.\n\n// Transform matrix for [a0, a1] -> [b0, b1].\nexport default function(a, b) {\n var u = subtract(a[1], a[0]),\n v = subtract(b[1], b[0]),\n phi = angle(u, v),\n s = length(u) / length(v);\n\n return multiply([\n 1, 0, a[0][0],\n 0, 1, a[0][1]\n ], multiply([\n s, 0, 0,\n 0, s, 0\n ], multiply([\n cos(phi), sin(phi), 0,\n -sin(phi), cos(phi), 0\n ], [\n 1, 0, -b[0][0],\n 0, 1, -b[0][1]\n ])));\n}\n\n// Inverts a transform matrix.\nexport function inverse(m) {\n var k = 1 / (m[0] * m[4] - m[1] * m[3]);\n return [\n k * m[4], -k * m[1], k * (m[1] * m[5] - m[2] * m[4]),\n -k * m[3], k * m[0], k * (m[2] * m[3] - m[0] * m[5])\n ];\n}\n\n// Multiplies two 3x2 matrices.\nexport function multiply(a, b) {\n return [\n a[0] * b[0] + a[1] * b[3],\n a[0] * b[1] + a[1] * b[4],\n a[0] * b[2] + a[1] * b[5] + a[2],\n a[3] * b[0] + a[4] * b[3],\n a[3] * b[1] + a[4] * b[4],\n a[3] * b[2] + a[4] * b[5] + a[5]\n ];\n}\n\n// Subtracts 2D vectors.\nfunction subtract(a, b) {\n return [a[0] - b[0], a[1] - b[1]];\n}\n\n// Magnitude of a 2D vector.\nfunction length(v) {\n return sqrt(v[0] * v[0] + v[1] * v[1]);\n}\n\n// Angle between two 2D vectors.\nfunction angle(a, b) {\n return atan2(a[0] * b[1] - a[1] * b[0], a[0] * b[0] + a[1] * b[1]);\n}\n","import {geoBounds as bounds, geoCentroid as centroid, geoInterpolate as interpolate, geoProjection as projection} from \"d3-geo\";\nimport {abs, degrees, epsilon, radians} from \"../math.js\";\nimport {default as matrix, multiply, inverse} from \"./matrix.js\";\n\n// Creates a polyhedral projection.\n// * root: a spanning tree of polygon faces. Nodes are automatically\n// augmented with a transform matrix.\n// * face: a function that returns the appropriate node for a given {lambda, phi}\n// point (radians).\n// * r: rotation angle for root face [deprecated by .angle()].\nexport default function(root, face, r) {\n\n recurse(root, {transform: null});\n\n function recurse(node, parent) {\n node.edges = faceEdges(node.face);\n // Find shared edge.\n if (parent.face) {\n var shared = node.shared = sharedEdge(node.face, parent.face),\n m = matrix(shared.map(parent.project), shared.map(node.project));\n node.transform = parent.transform ? multiply(parent.transform, m) : m;\n // Replace shared edge in parent edges array.\n var edges = parent.edges;\n for (var i = 0, n = edges.length; i < n; ++i) {\n if (pointEqual(shared[0], edges[i][1]) && pointEqual(shared[1], edges[i][0])) edges[i] = node;\n if (pointEqual(shared[0], edges[i][0]) && pointEqual(shared[1], edges[i][1])) edges[i] = node;\n }\n edges = node.edges;\n for (i = 0, n = edges.length; i < n; ++i) {\n if (pointEqual(shared[0], edges[i][0]) && pointEqual(shared[1], edges[i][1])) edges[i] = parent;\n if (pointEqual(shared[0], edges[i][1]) && pointEqual(shared[1], edges[i][0])) edges[i] = parent;\n }\n } else {\n node.transform = parent.transform;\n }\n if (node.children) {\n node.children.forEach(function(child) {\n recurse(child, node);\n });\n }\n return node;\n }\n\n function forward(lambda, phi) {\n var node = face(lambda, phi),\n point = node.project([lambda * degrees, phi * degrees]),\n t;\n if (t = node.transform) {\n return [\n t[0] * point[0] + t[1] * point[1] + t[2],\n -(t[3] * point[0] + t[4] * point[1] + t[5])\n ];\n }\n point[1] = -point[1];\n return point;\n }\n\n // Naive inverse! A faster solution would use bounding boxes, or even a\n // polygonal quadtree.\n if (hasInverse(root)) forward.invert = function(x, y) {\n var coordinates = faceInvert(root, [x, -y]);\n return coordinates && (coordinates[0] *= radians, coordinates[1] *= radians, coordinates);\n };\n\n function faceInvert(node, coordinates) {\n var invert = node.project.invert,\n t = node.transform,\n point = coordinates;\n if (t) {\n t = inverse(t);\n point = [\n t[0] * point[0] + t[1] * point[1] + t[2],\n (t[3] * point[0] + t[4] * point[1] + t[5])\n ];\n }\n if (invert && node === faceDegrees(p = invert(point))) return p;\n var p,\n children = node.children;\n for (var i = 0, n = children && children.length; i < n; ++i) {\n if (p = faceInvert(children[i], coordinates)) return p;\n }\n }\n\n function faceDegrees(coordinates) {\n return face(coordinates[0] * radians, coordinates[1] * radians);\n }\n\n var proj = projection(forward),\n stream_ = proj.stream;\n\n proj.stream = function(stream) {\n var rotate = proj.rotate(),\n rotateStream = stream_(stream),\n sphereStream = (proj.rotate([0, 0]), stream_(stream));\n proj.rotate(rotate);\n rotateStream.sphere = function() {\n sphereStream.polygonStart();\n sphereStream.lineStart();\n outline(sphereStream, root);\n sphereStream.lineEnd();\n sphereStream.polygonEnd();\n };\n return rotateStream;\n };\n\n return proj.angle(r == null ? -30 : r * degrees);\n}\n\nfunction outline(stream, node, parent) {\n var point,\n edges = node.edges,\n n = edges.length,\n edge,\n multiPoint = {type: \"MultiPoint\", coordinates: node.face},\n notPoles = node.face.filter(function(d) { return abs(d[1]) !== 90; }),\n b = bounds({type: \"MultiPoint\", coordinates: notPoles}),\n inside = false,\n j = -1,\n dx = b[1][0] - b[0][0];\n // TODO\n var c = dx === 180 || dx === 360\n ? [(b[0][0] + b[1][0]) / 2, (b[0][1] + b[1][1]) / 2]\n : centroid(multiPoint);\n // First find the shared edge…\n if (parent) while (++j < n) {\n if (edges[j] === parent) break;\n }\n ++j;\n for (var i = 0; i < n; ++i) {\n edge = edges[(i + j) % n];\n if (Array.isArray(edge)) {\n if (!inside) {\n stream.point((point = interpolate(edge[0], c)(epsilon))[0], point[1]);\n inside = true;\n }\n stream.point((point = interpolate(edge[1], c)(epsilon))[0], point[1]);\n } else {\n inside = false;\n if (edge !== parent) outline(stream, edge, node);\n }\n }\n}\n\n// Tests equality of two spherical points.\nfunction pointEqual(a, b) {\n return a && b && a[0] === b[0] && a[1] === b[1];\n}\n\n// Finds a shared edge given two clockwise polygons.\nfunction sharedEdge(a, b) {\n var x, y, n = a.length, found = null;\n for (var i = 0; i < n; ++i) {\n x = a[i];\n for (var j = b.length; --j >= 0;) {\n y = b[j];\n if (x[0] === y[0] && x[1] === y[1]) {\n if (found) return [found, x];\n found = x;\n }\n }\n }\n}\n\n// Converts an array of n face vertices to an array of n + 1 edges.\nfunction faceEdges(face) {\n var n = face.length,\n edges = [];\n for (var a = face[n - 1], i = 0; i < n; ++i) edges.push([a, a = face[i]]);\n return edges;\n}\n\nfunction hasInverse(node) {\n return node.project.invert || node.children && node.children.some(hasInverse);\n}\n","// TODO generate on-the-fly to avoid external modification.\nvar octahedron = [\n [0, 90],\n [-90, 0], [0, 0], [90, 0], [180, 0],\n [0, -90]\n];\n\nexport default [\n [0, 2, 1],\n [0, 3, 2],\n [5, 1, 2],\n [5, 2, 3],\n [0, 1, 4],\n [0, 4, 3],\n [5, 4, 1],\n [5, 3, 4]\n].map(function(face) {\n return face.map(function(i) {\n return octahedron[i];\n });\n});\n","import {geoCentroid as centroid, geoGnomonic as gnomonic} from \"d3-geo\";\nimport {pi} from \"../math.js\";\nimport polyhedral from \"./index.js\";\nimport octahedron from \"./octahedron.js\";\n\nexport default function(faceProjection) {\n\n faceProjection = faceProjection || function(face) {\n var c = centroid({type: \"MultiPoint\", coordinates: face});\n return gnomonic().scale(1).translate([0, 0]).rotate([-c[0], -c[1]]);\n };\n\n var faces = octahedron.map(function(face) {\n return {face: face, project: faceProjection(face)};\n });\n\n [-1, 0, 0, 1, 0, 1, 4, 5].forEach(function(d, i) {\n var node = faces[d];\n node && (node.children || (node.children = [])).push(faces[i]);\n });\n\n return polyhedral(faces[0], function(lambda, phi) {\n return faces[lambda < -pi / 2 ? phi < 0 ? 6 : 4\n : lambda < 0 ? phi < 0 ? 2 : 0\n : lambda < pi / 2 ? phi < 0 ? 3 : 1\n : phi < 0 ? 7 : 5];\n })\n .angle(-30)\n .scale(101.858)\n .center([0, 45]);\n}\n","import {geoCentroid as centroid, geoProjection as projection} from \"d3-geo\";\nimport {collignonRaw} from \"../collignon.js\";\nimport {pi, sqrt} from \"../math.js\";\nimport polyhedral from \"./index.js\";\nimport octahedron from \"./octahedron.js\";\n\nvar kx = 2 / sqrt(3);\n\nfunction collignonK(a, b) {\n var p = collignonRaw(a, b);\n return [p[0] * kx, p[1]];\n}\n\ncollignonK.invert = function(x,y) {\n return collignonRaw.invert(x / kx, y);\n};\n\nexport default function(faceProjection) {\n\n faceProjection = faceProjection || function(face) {\n var c = centroid({type: \"MultiPoint\", coordinates: face});\n return projection(collignonK).translate([0, 0]).scale(1).rotate(c[1] > 0 ? [-c[0], 0] : [180 - c[0], 180]);\n };\n\n var faces = octahedron.map(function(face) {\n return {face: face, project: faceProjection(face)};\n });\n\n [-1, 0, 0, 1, 0, 1, 4, 5].forEach(function(d, i) {\n var node = faces[d];\n node && (node.children || (node.children = [])).push(faces[i]);\n });\n\n return polyhedral(faces[0], function(lambda, phi) {\n return faces[lambda < -pi / 2 ? phi < 0 ? 6 : 4\n : lambda < 0 ? phi < 0 ? 2 : 0\n : lambda < pi / 2 ? phi < 0 ? 3 : 1\n : phi < 0 ? 7 : 5];\n })\n .angle(-30)\n .scale(121.906)\n .center([0, 48.5904]);\n}\n","import {geoCentroid as centroid, geoGnomonic as gnomonic} from \"d3-geo\";\nimport {asin, atan2, cos, degrees, max, min, pi, radians, sin} from \"../math.js\";\nimport polyhedral from \"./index.js\";\nimport octahedron from \"./octahedron.js\";\n\nexport default function(faceProjection) {\n\n faceProjection = faceProjection || function(face) {\n var c = face.length === 6 ? centroid({type: \"MultiPoint\", coordinates: face}) : face[0];\n return gnomonic().scale(1).translate([0, 0]).rotate([-c[0], -c[1]]);\n };\n\n var w5 = octahedron.map(function(face) {\n var xyz = face.map(cartesian),\n n = xyz.length,\n a = xyz[n - 1],\n b,\n hexagon = [];\n for (var i = 0; i < n; ++i) {\n b = xyz[i];\n hexagon.push(spherical([\n a[0] * 0.9486832980505138 + b[0] * 0.31622776601683794,\n a[1] * 0.9486832980505138 + b[1] * 0.31622776601683794,\n a[2] * 0.9486832980505138 + b[2] * 0.31622776601683794\n ]), spherical([\n b[0] * 0.9486832980505138 + a[0] * 0.31622776601683794,\n b[1] * 0.9486832980505138 + a[1] * 0.31622776601683794,\n b[2] * 0.9486832980505138 + a[2] * 0.31622776601683794\n ]));\n a = b;\n }\n return hexagon;\n });\n\n var cornerNormals = [];\n\n var parents = [-1, 0, 0, 1, 0, 1, 4, 5];\n\n w5.forEach(function(hexagon, j) {\n var face = octahedron[j],\n n = face.length,\n normals = cornerNormals[j] = [];\n for (var i = 0; i < n; ++i) {\n w5.push([\n face[i],\n hexagon[(i * 2 + 2) % (2 * n)],\n hexagon[(i * 2 + 1) % (2 * n)]\n ]);\n parents.push(j);\n normals.push(cross(\n cartesian(hexagon[(i * 2 + 2) % (2 * n)]),\n cartesian(hexagon[(i * 2 + 1) % (2 * n)])\n ));\n }\n });\n\n var faces = w5.map(function(face) {\n return {\n project: faceProjection(face),\n face: face\n };\n });\n\n parents.forEach(function(d, i) {\n var parent = faces[d];\n parent && (parent.children || (parent.children = [])).push(faces[i]);\n });\n\n function face(lambda, phi) {\n var cosphi = cos(phi),\n p = [cosphi * cos(lambda), cosphi * sin(lambda), sin(phi)];\n\n var hexagon = lambda < -pi / 2 ? phi < 0 ? 6 : 4\n : lambda < 0 ? phi < 0 ? 2 : 0\n : lambda < pi / 2 ? phi < 0 ? 3 : 1\n : phi < 0 ? 7 : 5;\n\n var n = cornerNormals[hexagon];\n\n return faces[dot(n[0], p) < 0 ? 8 + 3 * hexagon\n : dot(n[1], p) < 0 ? 8 + 3 * hexagon + 1\n : dot(n[2], p) < 0 ? 8 + 3 * hexagon + 2\n : hexagon];\n }\n\n return polyhedral(faces[0], face)\n .angle(-30)\n .scale(110.625)\n .center([0,45]);\n}\n\nfunction dot(a, b) {\n for (var i = 0, n = a.length, s = 0; i < n; ++i) s += a[i] * b[i];\n return s;\n}\n\nfunction cross(a, b) {\n return [\n a[1] * b[2] - a[2] * b[1],\n a[2] * b[0] - a[0] * b[2],\n a[0] * b[1] - a[1] * b[0]\n ];\n}\n\n// Converts 3D Cartesian to spherical coordinates (degrees).\nfunction spherical(cartesian) {\n return [\n atan2(cartesian[1], cartesian[0]) * degrees,\n asin(max(-1, min(1, cartesian[2]))) * degrees\n ];\n}\n\n// Converts spherical coordinates (degrees) to 3D Cartesian.\nfunction cartesian(coordinates) {\n var lambda = coordinates[0] * radians,\n phi = coordinates[1] * radians,\n cosphi = cos(phi);\n return [\n cosphi * cos(lambda),\n cosphi * sin(lambda),\n sin(phi)\n ];\n}\n","export default function() {}\n","import {geoStream} from \"d3-geo\";\nimport noop from \"../noop.js\";\nimport clockwise from \"./clockwise.js\";\nimport contains from \"./contains.js\";\n\nexport default function(object, projection) {\n var stream = projection.stream, project;\n if (!stream) throw new Error(\"invalid projection\");\n switch (object && object.type) {\n case \"Feature\": project = projectFeature; break;\n case \"FeatureCollection\": project = projectFeatureCollection; break;\n default: project = projectGeometry; break;\n }\n return project(object, stream);\n}\n\nfunction projectFeatureCollection(o, stream) {\n return {\n type: \"FeatureCollection\",\n features: o.features.map(function(f) {\n return projectFeature(f, stream);\n })\n };\n}\n\nfunction projectFeature(o, stream) {\n return {\n type: \"Feature\",\n id: o.id,\n properties: o.properties,\n geometry: projectGeometry(o.geometry, stream)\n };\n}\n\nfunction projectGeometryCollection(o, stream) {\n return {\n type: \"GeometryCollection\",\n geometries: o.geometries.map(function(o) {\n return projectGeometry(o, stream);\n })\n };\n}\n\nfunction projectGeometry(o, stream) {\n if (!o) return null;\n if (o.type === \"GeometryCollection\") return projectGeometryCollection(o, stream);\n var sink;\n switch (o.type) {\n case \"Point\": sink = sinkPoint; break;\n case \"MultiPoint\": sink = sinkPoint; break;\n case \"LineString\": sink = sinkLine; break;\n case \"MultiLineString\": sink = sinkLine; break;\n case \"Polygon\": sink = sinkPolygon; break;\n case \"MultiPolygon\": sink = sinkPolygon; break;\n case \"Sphere\": sink = sinkPolygon; break;\n default: return null;\n }\n geoStream(o, stream(sink));\n return sink.result();\n}\n\nvar points = [],\n lines = [];\n\nvar sinkPoint = {\n point: function(x, y) {\n points.push([x, y]);\n },\n result: function() {\n var result = !points.length ? null\n : points.length < 2 ? {type: \"Point\", coordinates: points[0]}\n : {type: \"MultiPoint\", coordinates: points};\n points = [];\n return result;\n }\n};\n\nvar sinkLine = {\n lineStart: noop,\n point: function(x, y) {\n points.push([x, y]);\n },\n lineEnd: function() {\n if (points.length) lines.push(points), points = [];\n },\n result: function() {\n var result = !lines.length ? null\n : lines.length < 2 ? {type: \"LineString\", coordinates: lines[0]}\n : {type: \"MultiLineString\", coordinates: lines};\n lines = [];\n return result;\n }\n};\n\nvar sinkPolygon = {\n polygonStart: noop,\n lineStart: noop,\n point: function(x, y) {\n points.push([x, y]);\n },\n lineEnd: function() {\n var n = points.length;\n if (n) {\n do points.push(points[0].slice()); while (++n < 4);\n lines.push(points), points = [];\n }\n },\n polygonEnd: noop,\n result: function() {\n if (!lines.length) return null;\n var polygons = [],\n holes = [];\n\n // https://github.com/d3/d3/issues/1558\n lines.forEach(function(ring) {\n if (clockwise(ring)) polygons.push([ring]);\n else holes.push(ring);\n });\n\n holes.forEach(function(hole) {\n var point = hole[0];\n polygons.some(function(polygon) {\n if (contains(polygon[0], point)) {\n polygon.push(hole);\n return true;\n }\n }) || polygons.push([hole]);\n });\n\n lines = [];\n\n return !polygons.length ? null\n : polygons.length > 1 ? {type: \"MultiPolygon\", coordinates: polygons}\n : {type: \"Polygon\", coordinates: polygons[0]};\n }\n};\n","export default function(ring) {\n if ((n = ring.length) < 4) return false;\n var i = 0,\n n,\n area = ring[n - 1][1] * ring[0][0] - ring[n - 1][0] * ring[0][1];\n while (++i < n) area += ring[i - 1][1] * ring[i][0] - ring[i - 1][0] * ring[i][1];\n return area <= 0;\n}\n","export default function(ring, point) {\n var x = point[0],\n y = point[1],\n contains = false;\n for (var i = 0, n = ring.length, j = n - 1; i < n; j = i++) {\n var pi = ring[i], xi = pi[0], yi = pi[1],\n pj = ring[j], xj = pj[0], yj = pj[1];\n if (((yi > y) ^ (yj > y)) && (x < (xj - xi) * (y - yi) / (yj - yi) + xi)) contains = !contains;\n }\n return contains;\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, halfPi, pi, sign, sqrt1_2} from \"../math.js\";\n\nexport default function(project) {\n var dx = project(halfPi, 0)[0] - project(-halfPi, 0)[0];\n\n function projectQuincuncial(lambda, phi) {\n var t = abs(lambda) < halfPi,\n p = project(t ? lambda : lambda > 0 ? lambda - pi : lambda + pi, phi),\n x = (p[0] - p[1]) * sqrt1_2,\n y = (p[0] + p[1]) * sqrt1_2;\n if (t) return [x, y];\n var d = dx * sqrt1_2,\n s = x > 0 ^ y > 0 ? -1 : 1;\n return [s * x - sign(y) * d, s * y - sign(x) * d];\n }\n\n if (project.invert) projectQuincuncial.invert = function(x0, y0) {\n var x = (x0 + y0) * sqrt1_2,\n y = (y0 - x0) * sqrt1_2,\n t = abs(x) < 0.5 * dx && abs(y) < 0.5 * dx;\n\n if (!t) {\n var d = dx * sqrt1_2,\n s = x > 0 ^ y > 0 ? -1 : 1,\n x1 = -s * x0 + (y > 0 ? 1 : -1) * d,\n y1 = -s * y0 + (x > 0 ? 1 : -1) * d;\n x = (-x1 - y1) * sqrt1_2;\n y = (x1 - y1) * sqrt1_2;\n }\n\n var p = project.invert(x, y);\n if (!t) p[0] += x > 0 ? pi : -pi;\n return p;\n };\n\n return projection(projectQuincuncial)\n .rotate([-90, -90, 45])\n .clipAngle(180 - 1e-3);\n}\n","import {gringortenRaw} from \"../gringorten.js\";\nimport quincuncial from \"./index.js\";\n\nexport default function() {\n return quincuncial(gringortenRaw)\n .scale(176.423);\n}\n","import {guyouRaw} from \"../guyou.js\";\nimport quincuncial from \"./index.js\";\n\nexport default function() {\n return quincuncial(guyouRaw)\n .scale(111.48);\n}\n","export default function(input, digits) {\n if (!(0 <= (digits = +digits) && digits <= 20)) throw new Error(\"invalid digits\");\n\n function quantizePoint(input) {\n var n = input.length, i = 2, output = new Array(n);\n output[0] = +input[0].toFixed(digits);\n output[1] = +input[1].toFixed(digits);\n while (i < n) output[i] = input[i], ++i;\n return output;\n }\n\n function quantizePoints(input) {\n return input.map(quantizePoint);\n }\n\n function quantizePointsNoDuplicates(input) {\n var point0 = quantizePoint(input[0]);\n var output = [point0];\n for (var i = 1; i < input.length; i++) {\n var point = quantizePoint(input[i]);\n if (point.length > 2 || point[0] != point0[0] || point[1] != point0[1]) {\n output.push(point);\n point0 = point;\n }\n }\n if (output.length === 1 && input.length > 1) {\n output.push(quantizePoint(input[input.length - 1]));\n }\n return output;\n }\n\n function quantizePolygon(input) {\n return input.map(quantizePointsNoDuplicates);\n }\n\n function quantizeGeometry(input) {\n if (input == null) return input;\n var output;\n switch (input.type) {\n case \"GeometryCollection\": output = {type: \"GeometryCollection\", geometries: input.geometries.map(quantizeGeometry)}; break;\n case \"Point\": output = {type: \"Point\", coordinates: quantizePoint(input.coordinates)}; break;\n case \"MultiPoint\": output = {type: input.type, coordinates: quantizePoints(input.coordinates)}; break;\n case \"LineString\": output = {type: input.type, coordinates: quantizePointsNoDuplicates(input.coordinates)}; break;\n case \"MultiLineString\": case \"Polygon\": output = {type: input.type, coordinates: quantizePolygon(input.coordinates)}; break;\n case \"MultiPolygon\": output = {type: \"MultiPolygon\", coordinates: input.coordinates.map(quantizePolygon)}; break;\n default: return input;\n }\n if (input.bbox != null) output.bbox = input.bbox;\n return output;\n }\n\n function quantizeFeature(input) {\n var output = {type: \"Feature\", properties: input.properties, geometry: quantizeGeometry(input.geometry)};\n if (input.id != null) output.id = input.id;\n if (input.bbox != null) output.bbox = input.bbox;\n return output;\n }\n\n if (input != null) switch (input.type) {\n case \"Feature\": return quantizeFeature(input);\n case \"FeatureCollection\": {\n var output = {type: \"FeatureCollection\", features: input.features.map(quantizeFeature)};\n if (input.bbox != null) output.bbox = input.bbox;\n return output;\n }\n default: return quantizeGeometry(input);\n }\n\n return input;\n}\n","import {abs, acos, asin, atan, cos, epsilon, pi, sin, tan} from \"./math.js\";\nimport parallel1 from \"./parallel1.js\";\n\nexport function rectangularPolyconicRaw(phi0) {\n var sinPhi0 = sin(phi0);\n\n function forward(lambda, phi) {\n var A = sinPhi0 ? tan(lambda * sinPhi0 / 2) / sinPhi0 : lambda / 2;\n if (!phi) return [2 * A, -phi0];\n var E = 2 * atan(A * sin(phi)),\n cotPhi = 1 / tan(phi);\n return [\n sin(E) * cotPhi,\n phi + (1 - cos(E)) * cotPhi - phi0\n ];\n }\n\n // TODO return null for points outside outline.\n forward.invert = function(x, y) {\n if (abs(y += phi0) < epsilon) return [sinPhi0 ? 2 * atan(sinPhi0 * x / 2) / sinPhi0 : x, 0];\n var k = x * x + y * y,\n phi = 0,\n i = 10, delta;\n do {\n var tanPhi = tan(phi),\n secPhi = 1 / cos(phi),\n j = k - 2 * y * phi + phi * phi;\n phi -= delta = (tanPhi * j + 2 * (phi - y)) / (2 + j * secPhi * secPhi + 2 * (phi - y) * tanPhi);\n } while (abs(delta) > epsilon && --i > 0);\n var E = x * (tanPhi = tan(phi)),\n A = tan(abs(y) < abs(phi + 1 / tanPhi) ? asin(E) * 0.5 : acos(E) * 0.5 + pi / 4) / sin(phi);\n return [\n sinPhi0 ? 2 * atan(sinPhi0 * A) / sinPhi0 : 2 * A,\n phi\n ];\n };\n\n return forward;\n}\n\nexport default function() {\n return parallel1(rectangularPolyconicRaw)\n .scale(131.215);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, degrees, epsilon2, floor, halfPi, max, min, pi, radians} from \"./math.js\";\n\nvar K = [\n [0.9986, -0.062],\n [1.0000, 0.0000],\n [0.9986, 0.0620],\n [0.9954, 0.1240],\n [0.9900, 0.1860],\n [0.9822, 0.2480],\n [0.9730, 0.3100],\n [0.9600, 0.3720],\n [0.9427, 0.4340],\n [0.9216, 0.4958],\n [0.8962, 0.5571],\n [0.8679, 0.6176],\n [0.8350, 0.6769],\n [0.7986, 0.7346],\n [0.7597, 0.7903],\n [0.7186, 0.8435],\n [0.6732, 0.8936],\n [0.6213, 0.9394],\n [0.5722, 0.9761],\n [0.5322, 1.0000]\n];\n\nK.forEach(function(d) {\n d[1] *= 1.0144;\n});\n\nexport function robinsonRaw(lambda, phi) {\n var i = min(18, abs(phi) * 36 / pi),\n i0 = floor(i),\n di = i - i0,\n ax = (k = K[i0])[0],\n ay = k[1],\n bx = (k = K[++i0])[0],\n by = k[1],\n cx = (k = K[min(19, ++i0)])[0],\n cy = k[1],\n k;\n return [\n lambda * (bx + di * (cx - ax) / 2 + di * di * (cx - 2 * bx + ax) / 2),\n (phi > 0 ? halfPi : -halfPi) * (by + di * (cy - ay) / 2 + di * di * (cy - 2 * by + ay) / 2)\n ];\n}\n\nrobinsonRaw.invert = function(x, y) {\n var yy = y / halfPi,\n phi = yy * 90,\n i = min(18, abs(phi / 5)),\n i0 = max(0, floor(i));\n do {\n var ay = K[i0][1],\n by = K[i0 + 1][1],\n cy = K[min(19, i0 + 2)][1],\n u = cy - ay,\n v = cy - 2 * by + ay,\n t = 2 * (abs(yy) - by) / u,\n c = v / u,\n di = t * (1 - c * t * (1 - 2 * c * t));\n if (di >= 0 || i0 === 1) {\n phi = (y >= 0 ? 5 : -5) * (di + i);\n var j = 50, delta;\n do {\n i = min(18, abs(phi) / 5);\n i0 = floor(i);\n di = i - i0;\n ay = K[i0][1];\n by = K[i0 + 1][1];\n cy = K[min(19, i0 + 2)][1];\n phi -= (delta = (y >= 0 ? halfPi : -halfPi) * (by + di * (cy - ay) / 2 + di * di * (cy - 2 * by + ay) / 2) - y) * degrees;\n } while (abs(delta) > epsilon2 && --j > 0);\n break;\n }\n } while (--i0 >= 0);\n var ax = K[i0][0],\n bx = K[i0 + 1][0],\n cx = K[min(19, i0 + 2)][0];\n return [\n x / (bx + di * (cx - ax) / 2 + di * di * (cx - 2 * bx + ax) / 2),\n phi * radians\n ];\n};\n\nexport default function() {\n return projection(robinsonRaw)\n .scale(152.63);\n}\n","import {geoProjectionMutator as projectionMutator} from \"d3-geo\";\nimport {acos, asin, atan2, cos, degrees, radians, sin, sqrt} from \"./math.js\";\n\nfunction satelliteVerticalRaw(P) {\n function forward(lambda, phi) {\n var cosPhi = cos(phi),\n k = (P - 1) / (P - cosPhi * cos(lambda));\n return [\n k * cosPhi * sin(lambda),\n k * sin(phi)\n ];\n }\n\n forward.invert = function(x, y) {\n var rho2 = x * x + y * y,\n rho = sqrt(rho2),\n sinc = (P - sqrt(1 - rho2 * (P + 1) / (P - 1))) / ((P - 1) / rho + rho / (P - 1));\n return [\n atan2(x * sinc, rho * sqrt(1 - sinc * sinc)),\n rho ? asin(y * sinc / rho) : 0\n ];\n };\n\n return forward;\n}\n\nexport function satelliteRaw(P, omega) {\n var vertical = satelliteVerticalRaw(P);\n if (!omega) return vertical;\n var cosOmega = cos(omega),\n sinOmega = sin(omega);\n\n function forward(lambda, phi) {\n var coordinates = vertical(lambda, phi),\n y = coordinates[1],\n A = y * sinOmega / (P - 1) + cosOmega;\n return [\n coordinates[0] * cosOmega / A,\n y / A\n ];\n }\n\n forward.invert = function(x, y) {\n var k = (P - 1) / (P - 1 - y * sinOmega);\n return vertical.invert(k * x, k * y * cosOmega);\n };\n\n return forward;\n}\n\nexport default function() {\n var distance = 2,\n omega = 0,\n m = projectionMutator(satelliteRaw),\n p = m(distance, omega);\n\n // As a multiple of radius.\n p.distance = function(_) {\n if (!arguments.length) return distance;\n return m(distance = +_, omega);\n };\n\n p.tilt = function(_) {\n if (!arguments.length) return omega * degrees;\n return m(distance, omega = _ * radians);\n };\n\n return p\n .scale(432.147)\n .clipAngle(acos(1 / distance) * degrees - 1e-6);\n}\n","var epsilon = 1e-4,\n epsilonInverse = 1e4,\n x0 = -180, x0e = x0 + epsilon,\n x1 = 180, x1e = x1 - epsilon,\n y0 = -90, y0e = y0 + epsilon,\n y1 = 90, y1e = y1 - epsilon;\n\nfunction nonempty(coordinates) {\n return coordinates.length > 0;\n}\n\nfunction quantize(x) {\n return Math.floor(x * epsilonInverse) / epsilonInverse;\n}\n\nfunction normalizePoint(y) {\n return y === y0 || y === y1 ? [0, y] : [x0, quantize(y)]; // pole or antimeridian?\n}\n\nfunction clampPoint(p) {\n var x = p[0], y = p[1], clamped = false;\n if (x <= x0e) x = x0, clamped = true;\n else if (x >= x1e) x = x1, clamped = true;\n if (y <= y0e) y = y0, clamped = true;\n else if (y >= y1e) y = y1, clamped = true;\n return clamped ? [x, y] : p;\n}\n\nfunction clampPoints(points) {\n return points.map(clampPoint);\n}\n\n// For each ring, detect where it crosses the antimeridian or pole.\nfunction extractFragments(rings, polygon, fragments) {\n for (var j = 0, m = rings.length; j < m; ++j) {\n var ring = rings[j].slice();\n\n // By default, assume that this ring doesn’t need any stitching.\n fragments.push({index: -1, polygon: polygon, ring: ring});\n\n for (var i = 0, n = ring.length; i < n; ++i) {\n var point = ring[i],\n x = point[0],\n y = point[1];\n\n // If this is an antimeridian or polar point…\n if (x <= x0e || x >= x1e || y <= y0e || y >= y1e) {\n ring[i] = clampPoint(point);\n\n // Advance through any antimeridian or polar points…\n for (var k = i + 1; k < n; ++k) {\n var pointk = ring[k],\n xk = pointk[0],\n yk = pointk[1];\n if (xk > x0e && xk < x1e && yk > y0e && yk < y1e) break;\n }\n\n // If this was just a single antimeridian or polar point,\n // we don’t need to cut this ring into a fragment;\n // we can just leave it as-is.\n if (k === i + 1) continue;\n\n // Otherwise, if this is not the first point in the ring,\n // cut the current fragment so that it ends at the current point.\n // The current point is also normalized for later joining.\n if (i) {\n var fragmentBefore = {index: -1, polygon: polygon, ring: ring.slice(0, i + 1)};\n fragmentBefore.ring[fragmentBefore.ring.length - 1] = normalizePoint(y);\n fragments[fragments.length - 1] = fragmentBefore;\n }\n\n // If the ring started with an antimeridian fragment,\n // we can ignore that fragment entirely.\n else fragments.pop();\n\n // If the remainder of the ring is an antimeridian fragment,\n // move on to the next ring.\n if (k >= n) break;\n\n // Otherwise, add the remaining ring fragment and continue.\n fragments.push({index: -1, polygon: polygon, ring: ring = ring.slice(k - 1)});\n ring[0] = normalizePoint(ring[0][1]);\n i = -1;\n n = ring.length;\n }\n }\n }\n}\n\n// Now stitch the fragments back together into rings.\nfunction stitchFragments(fragments) {\n var i, n = fragments.length;\n\n // To connect the fragments start-to-end, create a simple index by end.\n var fragmentByStart = {},\n fragmentByEnd = {},\n fragment,\n start,\n startFragment,\n end,\n endFragment;\n\n // For each fragment…\n for (i = 0; i < n; ++i) {\n fragment = fragments[i];\n start = fragment.ring[0];\n end = fragment.ring[fragment.ring.length - 1];\n\n // If this fragment is closed, add it as a standalone ring.\n if (start[0] === end[0] && start[1] === end[1]) {\n fragment.polygon.push(fragment.ring);\n fragments[i] = null;\n continue;\n }\n\n fragment.index = i;\n fragmentByStart[start] = fragmentByEnd[end] = fragment;\n }\n\n // For each open fragment…\n for (i = 0; i < n; ++i) {\n fragment = fragments[i];\n if (fragment) {\n start = fragment.ring[0];\n end = fragment.ring[fragment.ring.length - 1];\n startFragment = fragmentByEnd[start];\n endFragment = fragmentByStart[end];\n\n delete fragmentByStart[start];\n delete fragmentByEnd[end];\n\n // If this fragment is closed, add it as a standalone ring.\n if (start[0] === end[0] && start[1] === end[1]) {\n fragment.polygon.push(fragment.ring);\n continue;\n }\n\n if (startFragment) {\n delete fragmentByEnd[start];\n delete fragmentByStart[startFragment.ring[0]];\n startFragment.ring.pop(); // drop the shared coordinate\n fragments[startFragment.index] = null;\n fragment = {index: -1, polygon: startFragment.polygon, ring: startFragment.ring.concat(fragment.ring)};\n\n if (startFragment === endFragment) {\n // Connect both ends to this single fragment to create a ring.\n fragment.polygon.push(fragment.ring);\n } else {\n fragment.index = n++;\n fragments.push(fragmentByStart[fragment.ring[0]] = fragmentByEnd[fragment.ring[fragment.ring.length - 1]] = fragment);\n }\n } else if (endFragment) {\n delete fragmentByStart[end];\n delete fragmentByEnd[endFragment.ring[endFragment.ring.length - 1]];\n fragment.ring.pop(); // drop the shared coordinate\n fragment = {index: n++, polygon: endFragment.polygon, ring: fragment.ring.concat(endFragment.ring)};\n fragments[endFragment.index] = null;\n fragments.push(fragmentByStart[fragment.ring[0]] = fragmentByEnd[fragment.ring[fragment.ring.length - 1]] = fragment);\n } else {\n fragment.ring.push(fragment.ring[0]); // close ring\n fragment.polygon.push(fragment.ring);\n }\n }\n }\n}\n\nfunction stitchFeature(input) {\n var output = {type: \"Feature\", geometry: stitchGeometry(input.geometry)};\n if (input.id != null) output.id = input.id;\n if (input.bbox != null) output.bbox = input.bbox;\n if (input.properties != null) output.properties = input.properties;\n return output;\n}\n\nfunction stitchGeometry(input) {\n if (input == null) return input;\n var output, fragments, i, n;\n switch (input.type) {\n case \"GeometryCollection\": output = {type: \"GeometryCollection\", geometries: input.geometries.map(stitchGeometry)}; break;\n case \"Point\": output = {type: \"Point\", coordinates: clampPoint(input.coordinates)}; break;\n case \"MultiPoint\": case \"LineString\": output = {type: input.type, coordinates: clampPoints(input.coordinates)}; break;\n case \"MultiLineString\": output = {type: \"MultiLineString\", coordinates: input.coordinates.map(clampPoints)}; break;\n case \"Polygon\": {\n var polygon = [];\n extractFragments(input.coordinates, polygon, fragments = []);\n stitchFragments(fragments);\n output = {type: \"Polygon\", coordinates: polygon};\n break;\n }\n case \"MultiPolygon\": {\n fragments = [], i = -1, n = input.coordinates.length;\n var polygons = new Array(n);\n while (++i < n) extractFragments(input.coordinates[i], polygons[i] = [], fragments);\n stitchFragments(fragments);\n output = {type: \"MultiPolygon\", coordinates: polygons.filter(nonempty)};\n break;\n }\n default: return input;\n }\n if (input.bbox != null) output.bbox = input.bbox;\n return output;\n}\n\nexport default function(input) {\n if (input == null) return input;\n switch (input.type) {\n case \"Feature\": return stitchFeature(input);\n case \"FeatureCollection\": {\n var output = {type: \"FeatureCollection\", features: input.features.map(stitchFeature)};\n if (input.bbox != null) output.bbox = input.bbox;\n return output;\n }\n default: return stitchGeometry(input);\n }\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {atan, quarterPi, sin, tan} from \"./math.js\";\n\nexport function timesRaw(lambda, phi) {\n var t = tan(phi / 2),\n s = sin(quarterPi * t);\n return [\n lambda * (0.74482 - 0.34588 * s * s),\n 1.70711 * t\n ];\n}\n\ntimesRaw.invert = function(x, y) {\n var t = y / 1.70711,\n s = sin(quarterPi * t);\n return [\n x / (0.74482 - 0.34588 * s * s),\n 2 * atan(t)\n ];\n};\n\nexport default function() {\n return projection(timesRaw)\n .scale(146.153);\n}\n","import {geoInterpolate as interpolate, geoProjection as projection, geoRotation as rotation} from \"d3-geo\";\nimport {asin, degrees, pi, sin, radians} from \"./math.js\";\n\n// Compute the origin as the midpoint of the two reference points.\n// Rotate one of the reference points by the origin.\n// Apply the spherical law of sines to compute gamma rotation.\nexport default function(raw, p0, p1) {\n var i = interpolate(p0, p1),\n o = i(0.5),\n a = rotation([-o[0], -o[1]])(p0),\n b = i.distance / 2,\n y = -asin(sin(a[1] * radians) / sin(b)),\n R = [-o[0], -o[1], -(a[0] > 0 ? pi - y : y) * degrees],\n p = projection(raw(b)).rotate(R),\n r = rotation(R),\n center = p.center;\n\n delete p.rotate;\n\n p.center = function(_) {\n return arguments.length ? center(r(_)) : r.invert(center());\n };\n\n return p\n .clipAngle(90);\n}\n","import {geoGnomonicRaw as gnomonicRaw} from \"d3-geo\";\nimport {cos} from \"./math.js\";\nimport twoPoint from \"./twoPoint.js\";\n\nexport function twoPointAzimuthalRaw(d) {\n var cosd = cos(d);\n\n function forward(lambda, phi) {\n var coordinates = gnomonicRaw(lambda, phi);\n coordinates[0] *= cosd;\n return coordinates;\n }\n\n forward.invert = function(x, y) {\n return gnomonicRaw.invert(x / cosd, y);\n };\n\n return forward;\n}\n\nexport function twoPointAzimuthalUsa() {\n return twoPointAzimuthal([-158, 21.5], [-77, 39])\n .clipAngle(60)\n .scale(400);\n}\n\nexport default function twoPointAzimuthal(p0, p1) {\n return twoPoint(twoPointAzimuthalRaw, p0, p1);\n}\n","import {geoAzimuthalEquidistantRaw as azimuthalEquidistantRaw} from \"d3-geo\";\nimport {acos, atan2, cos, sin, sqrt, tan} from \"./math.js\";\nimport twoPoint from \"./twoPoint.js\";\n\n// TODO clip to ellipse\nexport function twoPointEquidistantRaw(z0) {\n if (!(z0 *= 2)) return azimuthalEquidistantRaw;\n var lambdaa = -z0 / 2,\n lambdab = -lambdaa,\n z02 = z0 * z0,\n tanLambda0 = tan(lambdab),\n S = 0.5 / sin(lambdab);\n\n function forward(lambda, phi) {\n var za = acos(cos(phi) * cos(lambda - lambdaa)),\n zb = acos(cos(phi) * cos(lambda - lambdab)),\n ys = phi < 0 ? -1 : 1;\n za *= za, zb *= zb;\n return [\n (za - zb) / (2 * z0),\n ys * sqrt(4 * z02 * zb - (z02 - za + zb) * (z02 - za + zb)) / (2 * z0)\n ];\n }\n\n forward.invert = function(x, y) {\n var y2 = y * y,\n cosza = cos(sqrt(y2 + (t = x + lambdaa) * t)),\n coszb = cos(sqrt(y2 + (t = x + lambdab) * t)),\n t,\n d;\n return [\n atan2(d = cosza - coszb, t = (cosza + coszb) * tanLambda0),\n (y < 0 ? -1 : 1) * acos(sqrt(t * t + d * d) * S)\n ];\n };\n\n return forward;\n}\n\nexport function twoPointEquidistantUsa() {\n return twoPointEquidistant([-158, 21.5], [-77, 39])\n .clipAngle(130)\n .scale(122.571);\n}\n\nexport default function twoPointEquidistant(p0, p1) {\n return twoPoint(twoPointEquidistantRaw, p0, p1);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, acos, asin, atan, cos, epsilon, halfPi, pi, sign, sin, sqrt, tan} from \"./math.js\";\n\nexport function vanDerGrintenRaw(lambda, phi) {\n if (abs(phi) < epsilon) return [lambda, 0];\n var sinTheta = abs(phi / halfPi),\n theta = asin(sinTheta);\n if (abs(lambda) < epsilon || abs(abs(phi) - halfPi) < epsilon) return [0, sign(phi) * pi * tan(theta / 2)];\n var cosTheta = cos(theta),\n A = abs(pi / lambda - lambda / pi) / 2,\n A2 = A * A,\n G = cosTheta / (sinTheta + cosTheta - 1),\n P = G * (2 / sinTheta - 1),\n P2 = P * P,\n P2_A2 = P2 + A2,\n G_P2 = G - P2,\n Q = A2 + G;\n return [\n sign(lambda) * pi * (A * G_P2 + sqrt(A2 * G_P2 * G_P2 - P2_A2 * (G * G - P2))) / P2_A2,\n sign(phi) * pi * (P * Q - A * sqrt((A2 + 1) * P2_A2 - Q * Q)) / P2_A2\n ];\n}\n\nvanDerGrintenRaw.invert = function(x, y) {\n if (abs(y) < epsilon) return [x, 0];\n if (abs(x) < epsilon) return [0, halfPi * sin(2 * atan(y / pi))];\n var x2 = (x /= pi) * x,\n y2 = (y /= pi) * y,\n x2_y2 = x2 + y2,\n z = x2_y2 * x2_y2,\n c1 = -abs(y) * (1 + x2_y2),\n c2 = c1 - 2 * y2 + x2,\n c3 = -2 * c1 + 1 + 2 * y2 + z,\n d = y2 / c3 + (2 * c2 * c2 * c2 / (c3 * c3 * c3) - 9 * c1 * c2 / (c3 * c3)) / 27,\n a1 = (c1 - c2 * c2 / (3 * c3)) / c3,\n m1 = 2 * sqrt(-a1 / 3),\n theta1 = acos(3 * d / (a1 * m1)) / 3;\n return [\n pi * (x2_y2 - 1 + sqrt(1 + 2 * (x2 - y2) + z)) / (2 * x),\n sign(y) * pi * (-m1 * cos(theta1 + pi / 3) - c2 / (3 * c3))\n ];\n};\n\nexport default function() {\n return projection(vanDerGrintenRaw)\n .scale(79.4183);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, asin, atan, atan2, cos, halfPi, epsilon, pi, sign, sin, sqrt, tan} from \"./math.js\";\n\nexport function vanDerGrinten2Raw(lambda, phi) {\n if (abs(phi) < epsilon) return [lambda, 0];\n var sinTheta = abs(phi / halfPi),\n theta = asin(sinTheta);\n if (abs(lambda) < epsilon || abs(abs(phi) - halfPi) < epsilon) return [0, sign(phi) * pi * tan(theta / 2)];\n var cosTheta = cos(theta),\n A = abs(pi / lambda - lambda / pi) / 2,\n A2 = A * A,\n x1 = cosTheta * (sqrt(1 + A2) - A * cosTheta) / (1 + A2 * sinTheta * sinTheta);\n return [\n sign(lambda) * pi * x1,\n sign(phi) * pi * sqrt(1 - x1 * (2 * A + x1))\n ];\n}\n\nvanDerGrinten2Raw.invert = function(x, y) {\n if (!x) return [0, halfPi * sin(2 * atan(y / pi))];\n var x1 = abs(x / pi),\n A = (1 - x1 * x1 - (y /= pi) * y) / (2 * x1),\n A2 = A * A,\n B = sqrt(A2 + 1);\n return [\n sign(x) * pi * (B - A),\n sign(y) * halfPi * sin(2 * atan2(sqrt((1 - 2 * A * x1) * (A + B) - x1), sqrt(B + A + x1)))\n ];\n};\n\nexport default function() {\n return projection(vanDerGrinten2Raw)\n .scale(79.4183);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, asin, atan, cos, epsilon, halfPi, pi, sign, sin, sqrt, tan} from \"./math.js\";\n\nexport function vanDerGrinten3Raw(lambda, phi) {\n if (abs(phi) < epsilon) return [lambda, 0];\n var sinTheta = phi / halfPi,\n theta = asin(sinTheta);\n if (abs(lambda) < epsilon || abs(abs(phi) - halfPi) < epsilon) return [0, pi * tan(theta / 2)];\n var A = (pi / lambda - lambda / pi) / 2,\n y1 = sinTheta / (1 + cos(theta));\n return [\n pi * (sign(lambda) * sqrt(A * A + 1 - y1 * y1) - A),\n pi * y1\n ];\n}\n\nvanDerGrinten3Raw.invert = function(x, y) {\n if (!y) return [x, 0];\n var y1 = y / pi,\n A = (pi * pi * (1 - y1 * y1) - x * x) / (2 * pi * x);\n return [\n x ? pi * (sign(x) * sqrt(A * A + 1) - A) : 0,\n halfPi * sin(2 * atan(y1))\n ];\n};\n\nexport default function() {\n return projection(vanDerGrinten3Raw)\n .scale(79.4183);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {abs, epsilon, halfPi, pi, sign, sqrt} from \"./math.js\";\n\nexport function vanDerGrinten4Raw(lambda, phi) {\n if (!phi) return [lambda, 0];\n var phi0 = abs(phi);\n if (!lambda || phi0 === halfPi) return [0, phi];\n var B = phi0 / halfPi,\n B2 = B * B,\n C = (8 * B - B2 * (B2 + 2) - 5) / (2 * B2 * (B - 1)),\n C2 = C * C,\n BC = B * C,\n B_C2 = B2 + C2 + 2 * BC,\n B_3C = B + 3 * C,\n lambda0 = lambda / halfPi,\n lambda1 = lambda0 + 1 / lambda0,\n D = sign(abs(lambda) - halfPi) * sqrt(lambda1 * lambda1 - 4),\n D2 = D * D,\n F = B_C2 * (B2 + C2 * D2 - 1) + (1 - B2) * (B2 * (B_3C * B_3C + 4 * C2) + 12 * BC * C2 + 4 * C2 * C2),\n x1 = (D * (B_C2 + C2 - 1) + 2 * sqrt(F)) / (4 * B_C2 + D2);\n return [\n sign(lambda) * halfPi * x1,\n sign(phi) * halfPi * sqrt(1 + D * abs(x1) - x1 * x1)\n ];\n}\n\nvanDerGrinten4Raw.invert = function(x, y) {\n var delta;\n if (!x || !y) return [x, y];\n y /= pi;\n var x1 = sign(x) * x / halfPi,\n D = (x1 * x1 - 1 + 4 * y * y) / abs(x1),\n D2 = D * D,\n B = 2 * y,\n i = 50;\n do {\n var B2 = B * B,\n C = (8 * B - B2 * (B2 + 2) - 5) / (2 * B2 * (B - 1)),\n C_ = (3 * B - B2 * B - 10) / (2 * B2 * B),\n C2 = C * C,\n BC = B * C,\n B_C = B + C,\n B_C2 = B_C * B_C,\n B_3C = B + 3 * C,\n F = B_C2 * (B2 + C2 * D2 - 1) + (1 - B2) * (B2 * (B_3C * B_3C + 4 * C2) + C2 * (12 * BC + 4 * C2)),\n F_ = -2 * B_C * (4 * BC * C2 + (1 - 4 * B2 + 3 * B2 * B2) * (1 + C_) + C2 * (-6 + 14 * B2 - D2 + (-8 + 8 * B2 - 2 * D2) * C_) + BC * (-8 + 12 * B2 + (-10 + 10 * B2 - D2) * C_)),\n sqrtF = sqrt(F),\n f = D * (B_C2 + C2 - 1) + 2 * sqrtF - x1 * (4 * B_C2 + D2),\n f_ = D * (2 * C * C_ + 2 * B_C * (1 + C_)) + F_ / sqrtF - 8 * B_C * (D * (-1 + C2 + B_C2) + 2 * sqrtF) * (1 + C_) / (D2 + 4 * B_C2);\n B -= delta = f / f_;\n } while (delta > epsilon && --i > 0);\n return [\n sign(x) * (sqrt(D * D + 4) + D) * pi / 4,\n halfPi * B\n ];\n};\n\nexport default function() {\n return projection(vanDerGrinten4Raw)\n .scale(127.16);\n}\n","import {geoProjectionMutator as projectionMutator} from \"d3-geo\";\nimport {acos, asin, atan2, cos, degrees, epsilon, halfPi, max, min, pi, radians, sin, sqrt, tan} from \"./math.js\";\n\nfunction wagnerFormula(cx, cy, m1, m2, n) {\n function forward(lambda, phi) {\n var s = m1 * sin(m2 * phi),\n c0 = sqrt(1 - s * s),\n c1 = sqrt(2 / (1 + c0 * cos(lambda *= n)));\n return [\n cx * c0 * c1 * sin(lambda),\n cy * s * c1\n ];\n }\n\n forward.invert = function(x, y) {\n var t1 = x / cx,\n t2 = y / cy,\n p = sqrt(t1 * t1 + t2 * t2),\n c = 2 * asin(p / 2);\n return [\n atan2(x * tan(c), cx * p) / n,\n p && asin(y * sin(c) / (cy * m1 * p)) / m2\n ];\n };\n\n return forward;\n}\n\nexport function wagnerRaw(poleline, parallels, inflation, ratio) {\n // 60 is always used as reference parallel\n var phi1 = pi / 3;\n\n // sanitizing the input values\n // poleline and parallels may approximate but never equal 0\n poleline = max(poleline, epsilon);\n parallels = max(parallels, epsilon);\n // poleline must be <= 90; parallels may approximate but never equal 180\n poleline = min(poleline, halfPi);\n parallels = min(parallels, pi - epsilon);\n // 0 <= inflation <= 99.999\n inflation = max(inflation, 0);\n inflation = min(inflation, 100 - epsilon);\n // ratio > 0.\n // sensible values, i.e. something that renders a map which still can be\n // recognized as world map, are e.g. 20 <= ratio <= 1000.\n ratio = max(ratio, epsilon);\n\n // convert values from boehm notation\n // areal inflation e.g. from 0 to 1 or 20 to 1.2:\n var vinflation = inflation/100 + 1;\n // axial ratio e.g. from 200 to 2:\n var vratio = ratio / 100;\n // the other ones are a bit more complicated...\n var m2 = acos(vinflation * cos(phi1)) / phi1,\n m1 = sin(poleline) / sin(m2 * halfPi),\n n = parallels / pi,\n k = sqrt(vratio * sin(poleline / 2) / sin(parallels / 2)),\n cx = k / sqrt(n * m1 * m2),\n cy = 1 / (k * sqrt(n * m1 * m2));\n\n return wagnerFormula(cx, cy, m1, m2, n);\n}\n\nexport default function wagner() {\n // default values generate wagner8\n var poleline = 65 * radians,\n parallels = 60 * radians,\n inflation = 20,\n ratio = 200,\n mutate = projectionMutator(wagnerRaw),\n projection = mutate(poleline, parallels, inflation, ratio);\n\n projection.poleline = function(_) {\n return arguments.length ? mutate(poleline = +_ * radians, parallels, inflation, ratio) : poleline * degrees;\n };\n\n projection.parallels = function(_) {\n return arguments.length ? mutate(poleline, parallels = +_ * radians, inflation, ratio) : parallels * degrees;\n };\n projection.inflation = function(_) {\n return arguments.length ? mutate(poleline, parallels, inflation = +_, ratio) : inflation;\n };\n projection.ratio = function(_) {\n return arguments.length ? mutate(poleline, parallels, inflation, ratio = +_) : ratio;\n };\n\n return projection\n .scale(163.775);\n}\n\nexport function wagner7() {\n return wagner()\n .poleline(65)\n .parallels(60)\n .inflation(0)\n .ratio(200)\n .scale(172.633);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {sqrt, pi} from \"./math.js\";\nimport {mollweideBromleyRaw} from \"./mollweide.js\";\n\nvar A = 4 * pi + 3 * sqrt(3),\n B = 2 * sqrt(2 * pi * sqrt(3) / A);\n\nexport var wagner4Raw = mollweideBromleyRaw(B * sqrt(3) / pi, B, A / 6);\n\nexport default function() {\n return projection(wagner4Raw)\n .scale(176.84);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {pi, sqrt} from \"./math.js\";\n\nexport function wagner6Raw(lambda, phi) {\n return [lambda * sqrt(1 - 3 * phi * phi / (pi * pi)), phi];\n}\n\nwagner6Raw.invert = function(x, y) {\n return [x / sqrt(1 - 3 * y * y / (pi * pi)), y];\n};\n\nexport default function() {\n return projection(wagner6Raw)\n .scale(152.63);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {asin, atan2, cos, sin, sqrt} from \"./math.js\";\n\nexport function wiechelRaw(lambda, phi) {\n var cosPhi = cos(phi),\n sinPhi = cos(lambda) * cosPhi,\n sin1_Phi = 1 - sinPhi,\n cosLambda = cos(lambda = atan2(sin(lambda) * cosPhi, -sin(phi))),\n sinLambda = sin(lambda);\n cosPhi = sqrt(1 - sinPhi * sinPhi);\n return [\n sinLambda * cosPhi - cosLambda * sin1_Phi,\n -cosLambda * cosPhi - sinLambda * sin1_Phi\n ];\n}\n\nwiechelRaw.invert = function(x, y) {\n var w = (x * x + y * y) / -2,\n k = sqrt(-w * (2 + w)),\n b = y * w + x * k,\n a = x * w - y * k,\n D = sqrt(a * a + b * b);\n return [\n atan2(k * b, D * (1 + w)),\n D ? -asin(k * a / D) : 0\n ];\n};\n\nexport default function() {\n return projection(wiechelRaw)\n .rotate([0, -90, 45])\n .scale(124.75)\n .clipAngle(180 - 1e-3);\n}\n","import {geoProjection as projection} from \"d3-geo\";\nimport {aitoffRaw} from \"./aitoff.js\";\nimport {halfPi, epsilon, sin, cos, sqrt, abs, acos} from \"./math.js\";\n\nexport function winkel3Raw(lambda, phi) {\n var coordinates = aitoffRaw(lambda, phi);\n return [\n (coordinates[0] + lambda / halfPi) / 2,\n (coordinates[1] + phi) / 2\n ];\n}\n\nwinkel3Raw.invert = function(x, y) {\n var lambda = x, phi = y, i = 25;\n do {\n var cosphi = cos(phi),\n sinphi = sin(phi),\n sin_2phi = sin(2 * phi),\n sin2phi = sinphi * sinphi,\n cos2phi = cosphi * cosphi,\n sinlambda = sin(lambda),\n coslambda_2 = cos(lambda / 2),\n sinlambda_2 = sin(lambda / 2),\n sin2lambda_2 = sinlambda_2 * sinlambda_2,\n C = 1 - cos2phi * coslambda_2 * coslambda_2,\n E = C ? acos(cosphi * coslambda_2) * sqrt(F = 1 / C) : F = 0,\n F,\n fx = 0.5 * (2 * E * cosphi * sinlambda_2 + lambda / halfPi) - x,\n fy = 0.5 * (E * sinphi + phi) - y,\n dxdlambda = 0.5 * F * (cos2phi * sin2lambda_2 + E * cosphi * coslambda_2 * sin2phi) + 0.5 / halfPi,\n dxdphi = F * (sinlambda * sin_2phi / 4 - E * sinphi * sinlambda_2),\n dydlambda = 0.125 * F * (sin_2phi * sinlambda_2 - E * sinphi * cos2phi * sinlambda),\n dydphi = 0.5 * F * (sin2phi * coslambda_2 + E * sin2lambda_2 * cosphi) + 0.5,\n denominator = dxdphi * dydlambda - dydphi * dxdlambda,\n dlambda = (fy * dxdphi - fx * dydphi) / denominator,\n dphi = (fx * dydlambda - fy * dxdlambda) / denominator;\n lambda -= dlambda, phi -= dphi;\n } while ((abs(dlambda) > epsilon || abs(dphi) > epsilon) && --i > 0);\n return [lambda, phi];\n};\n\nexport default function() {\n return projection(winkel3Raw)\n .scale(158.837);\n}\n","// Adds floating point numbers with twice the normal precision.\n// Reference: J. R. Shewchuk, Adaptive Precision Floating-Point Arithmetic and\n// Fast Robust Geometric Predicates, Discrete & Computational Geometry 18(3)\n// 305–363 (1997).\n// Code adapted from GeographicLib by Charles F. F. Karney,\n// http://geographiclib.sourceforge.net/\n\nexport default function() {\n return new Adder;\n}\n\nfunction Adder() {\n this.reset();\n}\n\nAdder.prototype = {\n constructor: Adder,\n reset: function() {\n this.s = // rounded value\n this.t = 0; // exact error\n },\n add: function(y) {\n add(temp, y, this.t);\n add(this, temp.s, this.s);\n if (this.s) this.t += temp.t;\n else this.s = temp.t;\n },\n valueOf: function() {\n return this.s;\n }\n};\n\nvar temp = new Adder;\n\nfunction add(adder, a, b) {\n var x = adder.s = a + b,\n bv = x - a,\n av = x - bv;\n adder.t = (a - av) + (b - bv);\n}\n","import adder from \"./adder.js\";\nimport {atan2, cos, quarterPi, radians, sin, tau} from \"./math.js\";\nimport noop from \"./noop.js\";\nimport stream from \"./stream.js\";\n\nexport var areaRingSum = adder();\n\nvar areaSum = adder(),\n lambda00,\n phi00,\n lambda0,\n cosPhi0,\n sinPhi0;\n\nexport var areaStream = {\n point: noop,\n lineStart: noop,\n lineEnd: noop,\n polygonStart: function() {\n areaRingSum.reset();\n areaStream.lineStart = areaRingStart;\n areaStream.lineEnd = areaRingEnd;\n },\n polygonEnd: function() {\n var areaRing = +areaRingSum;\n areaSum.add(areaRing < 0 ? tau + areaRing : areaRing);\n this.lineStart = this.lineEnd = this.point = noop;\n },\n sphere: function() {\n areaSum.add(tau);\n }\n};\n\nfunction areaRingStart() {\n areaStream.point = areaPointFirst;\n}\n\nfunction areaRingEnd() {\n areaPoint(lambda00, phi00);\n}\n\nfunction areaPointFirst(lambda, phi) {\n areaStream.point = areaPoint;\n lambda00 = lambda, phi00 = phi;\n lambda *= radians, phi *= radians;\n lambda0 = lambda, cosPhi0 = cos(phi = phi / 2 + quarterPi), sinPhi0 = sin(phi);\n}\n\nfunction areaPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n phi = phi / 2 + quarterPi; // half the angular distance from south pole\n\n // Spherical excess E for a spherical triangle with vertices: south pole,\n // previous point, current point. Uses a formula derived from Cagnoli’s\n // theorem. See Todhunter, Spherical Trig. (1871), Sec. 103, Eq. (2).\n var dLambda = lambda - lambda0,\n sdLambda = dLambda >= 0 ? 1 : -1,\n adLambda = sdLambda * dLambda,\n cosPhi = cos(phi),\n sinPhi = sin(phi),\n k = sinPhi0 * sinPhi,\n u = cosPhi0 * cosPhi + k * cos(adLambda),\n v = k * sdLambda * sin(adLambda);\n areaRingSum.add(atan2(v, u));\n\n // Advance the previous points.\n lambda0 = lambda, cosPhi0 = cosPhi, sinPhi0 = sinPhi;\n}\n\nexport default function(object) {\n areaSum.reset();\n stream(object, areaStream);\n return areaSum * 2;\n}\n","import adder from \"./adder.js\";\nimport {areaStream, areaRingSum} from \"./area.js\";\nimport {cartesian, cartesianCross, cartesianNormalizeInPlace, spherical} from \"./cartesian.js\";\nimport {abs, degrees, epsilon, radians} from \"./math.js\";\nimport stream from \"./stream.js\";\n\nvar lambda0, phi0, lambda1, phi1, // bounds\n lambda2, // previous lambda-coordinate\n lambda00, phi00, // first point\n p0, // previous 3D point\n deltaSum = adder(),\n ranges,\n range;\n\nvar boundsStream = {\n point: boundsPoint,\n lineStart: boundsLineStart,\n lineEnd: boundsLineEnd,\n polygonStart: function() {\n boundsStream.point = boundsRingPoint;\n boundsStream.lineStart = boundsRingStart;\n boundsStream.lineEnd = boundsRingEnd;\n deltaSum.reset();\n areaStream.polygonStart();\n },\n polygonEnd: function() {\n areaStream.polygonEnd();\n boundsStream.point = boundsPoint;\n boundsStream.lineStart = boundsLineStart;\n boundsStream.lineEnd = boundsLineEnd;\n if (areaRingSum < 0) lambda0 = -(lambda1 = 180), phi0 = -(phi1 = 90);\n else if (deltaSum > epsilon) phi1 = 90;\n else if (deltaSum < -epsilon) phi0 = -90;\n range[0] = lambda0, range[1] = lambda1;\n },\n sphere: function() {\n lambda0 = -(lambda1 = 180), phi0 = -(phi1 = 90);\n }\n};\n\nfunction boundsPoint(lambda, phi) {\n ranges.push(range = [lambda0 = lambda, lambda1 = lambda]);\n if (phi < phi0) phi0 = phi;\n if (phi > phi1) phi1 = phi;\n}\n\nfunction linePoint(lambda, phi) {\n var p = cartesian([lambda * radians, phi * radians]);\n if (p0) {\n var normal = cartesianCross(p0, p),\n equatorial = [normal[1], -normal[0], 0],\n inflection = cartesianCross(equatorial, normal);\n cartesianNormalizeInPlace(inflection);\n inflection = spherical(inflection);\n var delta = lambda - lambda2,\n sign = delta > 0 ? 1 : -1,\n lambdai = inflection[0] * degrees * sign,\n phii,\n antimeridian = abs(delta) > 180;\n if (antimeridian ^ (sign * lambda2 < lambdai && lambdai < sign * lambda)) {\n phii = inflection[1] * degrees;\n if (phii > phi1) phi1 = phii;\n } else if (lambdai = (lambdai + 360) % 360 - 180, antimeridian ^ (sign * lambda2 < lambdai && lambdai < sign * lambda)) {\n phii = -inflection[1] * degrees;\n if (phii < phi0) phi0 = phii;\n } else {\n if (phi < phi0) phi0 = phi;\n if (phi > phi1) phi1 = phi;\n }\n if (antimeridian) {\n if (lambda < lambda2) {\n if (angle(lambda0, lambda) > angle(lambda0, lambda1)) lambda1 = lambda;\n } else {\n if (angle(lambda, lambda1) > angle(lambda0, lambda1)) lambda0 = lambda;\n }\n } else {\n if (lambda1 >= lambda0) {\n if (lambda < lambda0) lambda0 = lambda;\n if (lambda > lambda1) lambda1 = lambda;\n } else {\n if (lambda > lambda2) {\n if (angle(lambda0, lambda) > angle(lambda0, lambda1)) lambda1 = lambda;\n } else {\n if (angle(lambda, lambda1) > angle(lambda0, lambda1)) lambda0 = lambda;\n }\n }\n }\n } else {\n ranges.push(range = [lambda0 = lambda, lambda1 = lambda]);\n }\n if (phi < phi0) phi0 = phi;\n if (phi > phi1) phi1 = phi;\n p0 = p, lambda2 = lambda;\n}\n\nfunction boundsLineStart() {\n boundsStream.point = linePoint;\n}\n\nfunction boundsLineEnd() {\n range[0] = lambda0, range[1] = lambda1;\n boundsStream.point = boundsPoint;\n p0 = null;\n}\n\nfunction boundsRingPoint(lambda, phi) {\n if (p0) {\n var delta = lambda - lambda2;\n deltaSum.add(abs(delta) > 180 ? delta + (delta > 0 ? 360 : -360) : delta);\n } else {\n lambda00 = lambda, phi00 = phi;\n }\n areaStream.point(lambda, phi);\n linePoint(lambda, phi);\n}\n\nfunction boundsRingStart() {\n areaStream.lineStart();\n}\n\nfunction boundsRingEnd() {\n boundsRingPoint(lambda00, phi00);\n areaStream.lineEnd();\n if (abs(deltaSum) > epsilon) lambda0 = -(lambda1 = 180);\n range[0] = lambda0, range[1] = lambda1;\n p0 = null;\n}\n\n// Finds the left-right distance between two longitudes.\n// This is almost the same as (lambda1 - lambda0 + 360°) % 360°, except that we want\n// the distance between ±180° to be 360°.\nfunction angle(lambda0, lambda1) {\n return (lambda1 -= lambda0) < 0 ? lambda1 + 360 : lambda1;\n}\n\nfunction rangeCompare(a, b) {\n return a[0] - b[0];\n}\n\nfunction rangeContains(range, x) {\n return range[0] <= range[1] ? range[0] <= x && x <= range[1] : x < range[0] || range[1] < x;\n}\n\nexport default function(feature) {\n var i, n, a, b, merged, deltaMax, delta;\n\n phi1 = lambda1 = -(lambda0 = phi0 = Infinity);\n ranges = [];\n stream(feature, boundsStream);\n\n // First, sort ranges by their minimum longitudes.\n if (n = ranges.length) {\n ranges.sort(rangeCompare);\n\n // Then, merge any ranges that overlap.\n for (i = 1, a = ranges[0], merged = [a]; i < n; ++i) {\n b = ranges[i];\n if (rangeContains(a, b[0]) || rangeContains(a, b[1])) {\n if (angle(a[0], b[1]) > angle(a[0], a[1])) a[1] = b[1];\n if (angle(b[0], a[1]) > angle(a[0], a[1])) a[0] = b[0];\n } else {\n merged.push(a = b);\n }\n }\n\n // Finally, find the largest gap between the merged ranges.\n // The final bounding box will be the inverse of this gap.\n for (deltaMax = -Infinity, n = merged.length - 1, i = 0, a = merged[n]; i <= n; a = b, ++i) {\n b = merged[i];\n if ((delta = angle(a[1], b[0])) > deltaMax) deltaMax = delta, lambda0 = b[0], lambda1 = a[1];\n }\n }\n\n ranges = range = null;\n\n return lambda0 === Infinity || phi0 === Infinity\n ? [[NaN, NaN], [NaN, NaN]]\n : [[lambda0, phi0], [lambda1, phi1]];\n}\n","import {asin, atan2, cos, sin, sqrt} from \"./math.js\";\n\nexport function spherical(cartesian) {\n return [atan2(cartesian[1], cartesian[0]), asin(cartesian[2])];\n}\n\nexport function cartesian(spherical) {\n var lambda = spherical[0], phi = spherical[1], cosPhi = cos(phi);\n return [cosPhi * cos(lambda), cosPhi * sin(lambda), sin(phi)];\n}\n\nexport function cartesianDot(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n}\n\nexport function cartesianCross(a, b) {\n return [a[1] * b[2] - a[2] * b[1], a[2] * b[0] - a[0] * b[2], a[0] * b[1] - a[1] * b[0]];\n}\n\n// TODO return a\nexport function cartesianAddInPlace(a, b) {\n a[0] += b[0], a[1] += b[1], a[2] += b[2];\n}\n\nexport function cartesianScale(vector, k) {\n return [vector[0] * k, vector[1] * k, vector[2] * k];\n}\n\n// TODO return d\nexport function cartesianNormalizeInPlace(d) {\n var l = sqrt(d[0] * d[0] + d[1] * d[1] + d[2] * d[2]);\n d[0] /= l, d[1] /= l, d[2] /= l;\n}\n","import {asin, atan2, cos, degrees, epsilon, epsilon2, radians, sin, sqrt} from \"./math.js\";\nimport noop from \"./noop.js\";\nimport stream from \"./stream.js\";\n\nvar W0, W1,\n X0, Y0, Z0,\n X1, Y1, Z1,\n X2, Y2, Z2,\n lambda00, phi00, // first point\n x0, y0, z0; // previous point\n\nvar centroidStream = {\n sphere: noop,\n point: centroidPoint,\n lineStart: centroidLineStart,\n lineEnd: centroidLineEnd,\n polygonStart: function() {\n centroidStream.lineStart = centroidRingStart;\n centroidStream.lineEnd = centroidRingEnd;\n },\n polygonEnd: function() {\n centroidStream.lineStart = centroidLineStart;\n centroidStream.lineEnd = centroidLineEnd;\n }\n};\n\n// Arithmetic mean of Cartesian vectors.\nfunction centroidPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos(phi);\n centroidPointCartesian(cosPhi * cos(lambda), cosPhi * sin(lambda), sin(phi));\n}\n\nfunction centroidPointCartesian(x, y, z) {\n ++W0;\n X0 += (x - X0) / W0;\n Y0 += (y - Y0) / W0;\n Z0 += (z - Z0) / W0;\n}\n\nfunction centroidLineStart() {\n centroidStream.point = centroidLinePointFirst;\n}\n\nfunction centroidLinePointFirst(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos(phi);\n x0 = cosPhi * cos(lambda);\n y0 = cosPhi * sin(lambda);\n z0 = sin(phi);\n centroidStream.point = centroidLinePoint;\n centroidPointCartesian(x0, y0, z0);\n}\n\nfunction centroidLinePoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos(phi),\n x = cosPhi * cos(lambda),\n y = cosPhi * sin(lambda),\n z = sin(phi),\n w = atan2(sqrt((w = y0 * z - z0 * y) * w + (w = z0 * x - x0 * z) * w + (w = x0 * y - y0 * x) * w), x0 * x + y0 * y + z0 * z);\n W1 += w;\n X1 += w * (x0 + (x0 = x));\n Y1 += w * (y0 + (y0 = y));\n Z1 += w * (z0 + (z0 = z));\n centroidPointCartesian(x0, y0, z0);\n}\n\nfunction centroidLineEnd() {\n centroidStream.point = centroidPoint;\n}\n\n// See J. E. Brock, The Inertia Tensor for a Spherical Triangle,\n// J. Applied Mechanics 42, 239 (1975).\nfunction centroidRingStart() {\n centroidStream.point = centroidRingPointFirst;\n}\n\nfunction centroidRingEnd() {\n centroidRingPoint(lambda00, phi00);\n centroidStream.point = centroidPoint;\n}\n\nfunction centroidRingPointFirst(lambda, phi) {\n lambda00 = lambda, phi00 = phi;\n lambda *= radians, phi *= radians;\n centroidStream.point = centroidRingPoint;\n var cosPhi = cos(phi);\n x0 = cosPhi * cos(lambda);\n y0 = cosPhi * sin(lambda);\n z0 = sin(phi);\n centroidPointCartesian(x0, y0, z0);\n}\n\nfunction centroidRingPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var cosPhi = cos(phi),\n x = cosPhi * cos(lambda),\n y = cosPhi * sin(lambda),\n z = sin(phi),\n cx = y0 * z - z0 * y,\n cy = z0 * x - x0 * z,\n cz = x0 * y - y0 * x,\n m = sqrt(cx * cx + cy * cy + cz * cz),\n w = asin(m), // line weight = angle\n v = m && -w / m; // area weight multiplier\n X2 += v * cx;\n Y2 += v * cy;\n Z2 += v * cz;\n W1 += w;\n X1 += w * (x0 + (x0 = x));\n Y1 += w * (y0 + (y0 = y));\n Z1 += w * (z0 + (z0 = z));\n centroidPointCartesian(x0, y0, z0);\n}\n\nexport default function(object) {\n W0 = W1 =\n X0 = Y0 = Z0 =\n X1 = Y1 = Z1 =\n X2 = Y2 = Z2 = 0;\n stream(object, centroidStream);\n\n var x = X2,\n y = Y2,\n z = Z2,\n m = x * x + y * y + z * z;\n\n // If the area-weighted ccentroid is undefined, fall back to length-weighted ccentroid.\n if (m < epsilon2) {\n x = X1, y = Y1, z = Z1;\n // If the feature has zero length, fall back to arithmetic mean of point vectors.\n if (W1 < epsilon) x = X0, y = Y0, z = Z0;\n m = x * x + y * y + z * z;\n // If the feature still has an undefined ccentroid, then return.\n if (m < epsilon2) return [NaN, NaN];\n }\n\n return [atan2(y, x) * degrees, asin(z / sqrt(m)) * degrees];\n}\n","export default function(x) {\n return function() {\n return x;\n };\n}\n","import {cartesian, cartesianNormalizeInPlace, spherical} from \"./cartesian.js\";\nimport constant from \"./constant.js\";\nimport {acos, cos, degrees, epsilon, radians, sin, tau} from \"./math.js\";\nimport {rotateRadians} from \"./rotation.js\";\n\n// Generates a circle centered at [0°, 0°], with a given radius and precision.\nexport function circleStream(stream, radius, delta, direction, t0, t1) {\n if (!delta) return;\n var cosRadius = cos(radius),\n sinRadius = sin(radius),\n step = direction * delta;\n if (t0 == null) {\n t0 = radius + direction * tau;\n t1 = radius - step / 2;\n } else {\n t0 = circleRadius(cosRadius, t0);\n t1 = circleRadius(cosRadius, t1);\n if (direction > 0 ? t0 < t1 : t0 > t1) t0 += direction * tau;\n }\n for (var point, t = t0; direction > 0 ? t > t1 : t < t1; t -= step) {\n point = spherical([cosRadius, -sinRadius * cos(t), -sinRadius * sin(t)]);\n stream.point(point[0], point[1]);\n }\n}\n\n// Returns the signed angle of a cartesian point relative to [cosRadius, 0, 0].\nfunction circleRadius(cosRadius, point) {\n point = cartesian(point), point[0] -= cosRadius;\n cartesianNormalizeInPlace(point);\n var radius = acos(-point[1]);\n return ((-point[2] < 0 ? -radius : radius) + tau - epsilon) % tau;\n}\n\nexport default function() {\n var center = constant([0, 0]),\n radius = constant(90),\n precision = constant(6),\n ring,\n rotate,\n stream = {point: point};\n\n function point(x, y) {\n ring.push(x = rotate(x, y));\n x[0] *= degrees, x[1] *= degrees;\n }\n\n function circle() {\n var c = center.apply(this, arguments),\n r = radius.apply(this, arguments) * radians,\n p = precision.apply(this, arguments) * radians;\n ring = [];\n rotate = rotateRadians(-c[0] * radians, -c[1] * radians, 0).invert;\n circleStream(stream, r, p, 1);\n c = {type: \"Polygon\", coordinates: [ring]};\n ring = rotate = null;\n return c;\n }\n\n circle.center = function(_) {\n return arguments.length ? (center = typeof _ === \"function\" ? _ : constant([+_[0], +_[1]]), circle) : center;\n };\n\n circle.radius = function(_) {\n return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant(+_), circle) : radius;\n };\n\n circle.precision = function(_) {\n return arguments.length ? (precision = typeof _ === \"function\" ? _ : constant(+_), circle) : precision;\n };\n\n return circle;\n}\n","import clip from \"./index.js\";\nimport {abs, atan, cos, epsilon, halfPi, pi, sin} from \"../math.js\";\n\nexport default clip(\n function() { return true; },\n clipAntimeridianLine,\n clipAntimeridianInterpolate,\n [-pi, -halfPi]\n);\n\n// Takes a line and cuts into visible segments. Return values: 0 - there were\n// intersections or the line was empty; 1 - no intersections; 2 - there were\n// intersections, and the first and last segments should be rejoined.\nfunction clipAntimeridianLine(stream) {\n var lambda0 = NaN,\n phi0 = NaN,\n sign0 = NaN,\n clean; // no intersections\n\n return {\n lineStart: function() {\n stream.lineStart();\n clean = 1;\n },\n point: function(lambda1, phi1) {\n var sign1 = lambda1 > 0 ? pi : -pi,\n delta = abs(lambda1 - lambda0);\n if (abs(delta - pi) < epsilon) { // line crosses a pole\n stream.point(lambda0, phi0 = (phi0 + phi1) / 2 > 0 ? halfPi : -halfPi);\n stream.point(sign0, phi0);\n stream.lineEnd();\n stream.lineStart();\n stream.point(sign1, phi0);\n stream.point(lambda1, phi0);\n clean = 0;\n } else if (sign0 !== sign1 && delta >= pi) { // line crosses antimeridian\n if (abs(lambda0 - sign0) < epsilon) lambda0 -= sign0 * epsilon; // handle degeneracies\n if (abs(lambda1 - sign1) < epsilon) lambda1 -= sign1 * epsilon;\n phi0 = clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1);\n stream.point(sign0, phi0);\n stream.lineEnd();\n stream.lineStart();\n stream.point(sign1, phi0);\n clean = 0;\n }\n stream.point(lambda0 = lambda1, phi0 = phi1);\n sign0 = sign1;\n },\n lineEnd: function() {\n stream.lineEnd();\n lambda0 = phi0 = NaN;\n },\n clean: function() {\n return 2 - clean; // if intersections, rejoin first and last segments\n }\n };\n}\n\nfunction clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1) {\n var cosPhi0,\n cosPhi1,\n sinLambda0Lambda1 = sin(lambda0 - lambda1);\n return abs(sinLambda0Lambda1) > epsilon\n ? atan((sin(phi0) * (cosPhi1 = cos(phi1)) * sin(lambda1)\n - sin(phi1) * (cosPhi0 = cos(phi0)) * sin(lambda0))\n / (cosPhi0 * cosPhi1 * sinLambda0Lambda1))\n : (phi0 + phi1) / 2;\n}\n\nfunction clipAntimeridianInterpolate(from, to, direction, stream) {\n var phi;\n if (from == null) {\n phi = direction * halfPi;\n stream.point(-pi, phi);\n stream.point(0, phi);\n stream.point(pi, phi);\n stream.point(pi, 0);\n stream.point(pi, -phi);\n stream.point(0, -phi);\n stream.point(-pi, -phi);\n stream.point(-pi, 0);\n stream.point(-pi, phi);\n } else if (abs(from[0] - to[0]) > epsilon) {\n var lambda = from[0] < to[0] ? pi : -pi;\n phi = direction * lambda / 2;\n stream.point(-lambda, phi);\n stream.point(0, phi);\n stream.point(lambda, phi);\n } else {\n stream.point(to[0], to[1]);\n }\n}\n","import noop from \"../noop.js\";\n\nexport default function() {\n var lines = [],\n line;\n return {\n point: function(x, y, m) {\n line.push([x, y, m]);\n },\n lineStart: function() {\n lines.push(line = []);\n },\n lineEnd: noop,\n rejoin: function() {\n if (lines.length > 1) lines.push(lines.pop().concat(lines.shift()));\n },\n result: function() {\n var result = lines;\n lines = [];\n line = null;\n return result;\n }\n };\n}\n","import {cartesian, cartesianAddInPlace, cartesianCross, cartesianDot, cartesianScale, spherical} from \"../cartesian.js\";\nimport {circleStream} from \"../circle.js\";\nimport {abs, cos, epsilon, pi, radians, sqrt} from \"../math.js\";\nimport pointEqual from \"../pointEqual.js\";\nimport clip from \"./index.js\";\n\nexport default function(radius) {\n var cr = cos(radius),\n delta = 6 * radians,\n smallRadius = cr > 0,\n notHemisphere = abs(cr) > epsilon; // TODO optimise for this common case\n\n function interpolate(from, to, direction, stream) {\n circleStream(stream, radius, delta, direction, from, to);\n }\n\n function visible(lambda, phi) {\n return cos(lambda) * cos(phi) > cr;\n }\n\n // Takes a line and cuts into visible segments. Return values used for polygon\n // clipping: 0 - there were intersections or the line was empty; 1 - no\n // intersections 2 - there were intersections, and the first and last segments\n // should be rejoined.\n function clipLine(stream) {\n var point0, // previous point\n c0, // code for previous point\n v0, // visibility of previous point\n v00, // visibility of first point\n clean; // no intersections\n return {\n lineStart: function() {\n v00 = v0 = false;\n clean = 1;\n },\n point: function(lambda, phi) {\n var point1 = [lambda, phi],\n point2,\n v = visible(lambda, phi),\n c = smallRadius\n ? v ? 0 : code(lambda, phi)\n : v ? code(lambda + (lambda < 0 ? pi : -pi), phi) : 0;\n if (!point0 && (v00 = v0 = v)) stream.lineStart();\n if (v !== v0) {\n point2 = intersect(point0, point1);\n if (!point2 || pointEqual(point0, point2) || pointEqual(point1, point2))\n point1[2] = 1;\n }\n if (v !== v0) {\n clean = 0;\n if (v) {\n // outside going in\n stream.lineStart();\n point2 = intersect(point1, point0);\n stream.point(point2[0], point2[1]);\n } else {\n // inside going out\n point2 = intersect(point0, point1);\n stream.point(point2[0], point2[1], 2);\n stream.lineEnd();\n }\n point0 = point2;\n } else if (notHemisphere && point0 && smallRadius ^ v) {\n var t;\n // If the codes for two points are different, or are both zero,\n // and there this segment intersects with the small circle.\n if (!(c & c0) && (t = intersect(point1, point0, true))) {\n clean = 0;\n if (smallRadius) {\n stream.lineStart();\n stream.point(t[0][0], t[0][1]);\n stream.point(t[1][0], t[1][1]);\n stream.lineEnd();\n } else {\n stream.point(t[1][0], t[1][1]);\n stream.lineEnd();\n stream.lineStart();\n stream.point(t[0][0], t[0][1], 3);\n }\n }\n }\n if (v && (!point0 || !pointEqual(point0, point1))) {\n stream.point(point1[0], point1[1]);\n }\n point0 = point1, v0 = v, c0 = c;\n },\n lineEnd: function() {\n if (v0) stream.lineEnd();\n point0 = null;\n },\n // Rejoin first and last segments if there were intersections and the first\n // and last points were visible.\n clean: function() {\n return clean | ((v00 && v0) << 1);\n }\n };\n }\n\n // Intersects the great circle between a and b with the clip circle.\n function intersect(a, b, two) {\n var pa = cartesian(a),\n pb = cartesian(b);\n\n // We have two planes, n1.p = d1 and n2.p = d2.\n // Find intersection line p(t) = c1 n1 + c2 n2 + t (n1 ⨯ n2).\n var n1 = [1, 0, 0], // normal\n n2 = cartesianCross(pa, pb),\n n2n2 = cartesianDot(n2, n2),\n n1n2 = n2[0], // cartesianDot(n1, n2),\n determinant = n2n2 - n1n2 * n1n2;\n\n // Two polar points.\n if (!determinant) return !two && a;\n\n var c1 = cr * n2n2 / determinant,\n c2 = -cr * n1n2 / determinant,\n n1xn2 = cartesianCross(n1, n2),\n A = cartesianScale(n1, c1),\n B = cartesianScale(n2, c2);\n cartesianAddInPlace(A, B);\n\n // Solve |p(t)|^2 = 1.\n var u = n1xn2,\n w = cartesianDot(A, u),\n uu = cartesianDot(u, u),\n t2 = w * w - uu * (cartesianDot(A, A) - 1);\n\n if (t2 < 0) return;\n\n var t = sqrt(t2),\n q = cartesianScale(u, (-w - t) / uu);\n cartesianAddInPlace(q, A);\n q = spherical(q);\n\n if (!two) return q;\n\n // Two intersection points.\n var lambda0 = a[0],\n lambda1 = b[0],\n phi0 = a[1],\n phi1 = b[1],\n z;\n\n if (lambda1 < lambda0) z = lambda0, lambda0 = lambda1, lambda1 = z;\n\n var delta = lambda1 - lambda0,\n polar = abs(delta - pi) < epsilon,\n meridian = polar || delta < epsilon;\n\n if (!polar && phi1 < phi0) z = phi0, phi0 = phi1, phi1 = z;\n\n // Check that the first point is between a and b.\n if (meridian\n ? polar\n ? phi0 + phi1 > 0 ^ q[1] < (abs(q[0] - lambda0) < epsilon ? phi0 : phi1)\n : phi0 <= q[1] && q[1] <= phi1\n : delta > pi ^ (lambda0 <= q[0] && q[0] <= lambda1)) {\n var q1 = cartesianScale(u, (-w + t) / uu);\n cartesianAddInPlace(q1, A);\n return [q, spherical(q1)];\n }\n }\n\n // Generates a 4-bit vector representing the location of a point relative to\n // the small circle's bounding box.\n function code(lambda, phi) {\n var r = smallRadius ? radius : pi - radius,\n code = 0;\n if (lambda < -r) code |= 1; // left\n else if (lambda > r) code |= 2; // right\n if (phi < -r) code |= 4; // below\n else if (phi > r) code |= 8; // above\n return code;\n }\n\n return clip(visible, clipLine, interpolate, smallRadius ? [0, -radius] : [-pi, radius - pi]);\n}\n","import clipBuffer from \"./buffer.js\";\nimport clipRejoin from \"./rejoin.js\";\nimport {epsilon, halfPi} from \"../math.js\";\nimport polygonContains from \"../polygonContains.js\";\nimport {merge} from \"d3-array\";\n\nexport default function(pointVisible, clipLine, interpolate, start) {\n return function(sink) {\n var line = clipLine(sink),\n ringBuffer = clipBuffer(),\n ringSink = clipLine(ringBuffer),\n polygonStarted = false,\n polygon,\n segments,\n ring;\n\n var clip = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: function() {\n clip.point = pointRing;\n clip.lineStart = ringStart;\n clip.lineEnd = ringEnd;\n segments = [];\n polygon = [];\n },\n polygonEnd: function() {\n clip.point = point;\n clip.lineStart = lineStart;\n clip.lineEnd = lineEnd;\n segments = merge(segments);\n var startInside = polygonContains(polygon, start);\n if (segments.length) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n clipRejoin(segments, compareIntersection, startInside, interpolate, sink);\n } else if (startInside) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n sink.lineStart();\n interpolate(null, null, 1, sink);\n sink.lineEnd();\n }\n if (polygonStarted) sink.polygonEnd(), polygonStarted = false;\n segments = polygon = null;\n },\n sphere: function() {\n sink.polygonStart();\n sink.lineStart();\n interpolate(null, null, 1, sink);\n sink.lineEnd();\n sink.polygonEnd();\n }\n };\n\n function point(lambda, phi) {\n if (pointVisible(lambda, phi)) sink.point(lambda, phi);\n }\n\n function pointLine(lambda, phi) {\n line.point(lambda, phi);\n }\n\n function lineStart() {\n clip.point = pointLine;\n line.lineStart();\n }\n\n function lineEnd() {\n clip.point = point;\n line.lineEnd();\n }\n\n function pointRing(lambda, phi) {\n ring.push([lambda, phi]);\n ringSink.point(lambda, phi);\n }\n\n function ringStart() {\n ringSink.lineStart();\n ring = [];\n }\n\n function ringEnd() {\n pointRing(ring[0][0], ring[0][1]);\n ringSink.lineEnd();\n\n var clean = ringSink.clean(),\n ringSegments = ringBuffer.result(),\n i, n = ringSegments.length, m,\n segment,\n point;\n\n ring.pop();\n polygon.push(ring);\n ring = null;\n\n if (!n) return;\n\n // No intersections.\n if (clean & 1) {\n segment = ringSegments[0];\n if ((m = segment.length - 1) > 0) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n sink.lineStart();\n for (i = 0; i < m; ++i) sink.point((point = segment[i])[0], point[1]);\n sink.lineEnd();\n }\n return;\n }\n\n // Rejoin connected segments.\n // TODO reuse ringBuffer.rejoin()?\n if (n > 1 && clean & 2) ringSegments.push(ringSegments.pop().concat(ringSegments.shift()));\n\n segments.push(ringSegments.filter(validSegment));\n }\n\n return clip;\n };\n}\n\nfunction validSegment(segment) {\n return segment.length > 1;\n}\n\n// Intersections are sorted along the clip edge. For both antimeridian cutting\n// and circle clipping, the same comparison is used.\nfunction compareIntersection(a, b) {\n return ((a = a.x)[0] < 0 ? a[1] - halfPi - epsilon : halfPi - a[1])\n - ((b = b.x)[0] < 0 ? b[1] - halfPi - epsilon : halfPi - b[1]);\n}\n","import {abs, epsilon} from \"../math.js\";\nimport clipBuffer from \"./buffer.js\";\nimport clipLine from \"./line.js\";\nimport clipRejoin from \"./rejoin.js\";\nimport {merge} from \"d3-array\";\n\nvar clipMax = 1e9, clipMin = -clipMax;\n\n// TODO Use d3-polygon’s polygonContains here for the ring check?\n// TODO Eliminate duplicate buffering in clipBuffer and polygon.push?\n\nexport default function clipRectangle(x0, y0, x1, y1) {\n\n function visible(x, y) {\n return x0 <= x && x <= x1 && y0 <= y && y <= y1;\n }\n\n function interpolate(from, to, direction, stream) {\n var a = 0, a1 = 0;\n if (from == null\n || (a = corner(from, direction)) !== (a1 = corner(to, direction))\n || comparePoint(from, to) < 0 ^ direction > 0) {\n do stream.point(a === 0 || a === 3 ? x0 : x1, a > 1 ? y1 : y0);\n while ((a = (a + direction + 4) % 4) !== a1);\n } else {\n stream.point(to[0], to[1]);\n }\n }\n\n function corner(p, direction) {\n return abs(p[0] - x0) < epsilon ? direction > 0 ? 0 : 3\n : abs(p[0] - x1) < epsilon ? direction > 0 ? 2 : 1\n : abs(p[1] - y0) < epsilon ? direction > 0 ? 1 : 0\n : direction > 0 ? 3 : 2; // abs(p[1] - y1) < epsilon\n }\n\n function compareIntersection(a, b) {\n return comparePoint(a.x, b.x);\n }\n\n function comparePoint(a, b) {\n var ca = corner(a, 1),\n cb = corner(b, 1);\n return ca !== cb ? ca - cb\n : ca === 0 ? b[1] - a[1]\n : ca === 1 ? a[0] - b[0]\n : ca === 2 ? a[1] - b[1]\n : b[0] - a[0];\n }\n\n return function(stream) {\n var activeStream = stream,\n bufferStream = clipBuffer(),\n segments,\n polygon,\n ring,\n x__, y__, v__, // first point\n x_, y_, v_, // previous point\n first,\n clean;\n\n var clipStream = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: polygonStart,\n polygonEnd: polygonEnd\n };\n\n function point(x, y) {\n if (visible(x, y)) activeStream.point(x, y);\n }\n\n function polygonInside() {\n var winding = 0;\n\n for (var i = 0, n = polygon.length; i < n; ++i) {\n for (var ring = polygon[i], j = 1, m = ring.length, point = ring[0], a0, a1, b0 = point[0], b1 = point[1]; j < m; ++j) {\n a0 = b0, a1 = b1, point = ring[j], b0 = point[0], b1 = point[1];\n if (a1 <= y1) { if (b1 > y1 && (b0 - a0) * (y1 - a1) > (b1 - a1) * (x0 - a0)) ++winding; }\n else { if (b1 <= y1 && (b0 - a0) * (y1 - a1) < (b1 - a1) * (x0 - a0)) --winding; }\n }\n }\n\n return winding;\n }\n\n // Buffer geometry within a polygon and then clip it en masse.\n function polygonStart() {\n activeStream = bufferStream, segments = [], polygon = [], clean = true;\n }\n\n function polygonEnd() {\n var startInside = polygonInside(),\n cleanInside = clean && startInside,\n visible = (segments = merge(segments)).length;\n if (cleanInside || visible) {\n stream.polygonStart();\n if (cleanInside) {\n stream.lineStart();\n interpolate(null, null, 1, stream);\n stream.lineEnd();\n }\n if (visible) {\n clipRejoin(segments, compareIntersection, startInside, interpolate, stream);\n }\n stream.polygonEnd();\n }\n activeStream = stream, segments = polygon = ring = null;\n }\n\n function lineStart() {\n clipStream.point = linePoint;\n if (polygon) polygon.push(ring = []);\n first = true;\n v_ = false;\n x_ = y_ = NaN;\n }\n\n // TODO rather than special-case polygons, simply handle them separately.\n // Ideally, coincident intersection points should be jittered to avoid\n // clipping issues.\n function lineEnd() {\n if (segments) {\n linePoint(x__, y__);\n if (v__ && v_) bufferStream.rejoin();\n segments.push(bufferStream.result());\n }\n clipStream.point = point;\n if (v_) activeStream.lineEnd();\n }\n\n function linePoint(x, y) {\n var v = visible(x, y);\n if (polygon) ring.push([x, y]);\n if (first) {\n x__ = x, y__ = y, v__ = v;\n first = false;\n if (v) {\n activeStream.lineStart();\n activeStream.point(x, y);\n }\n } else {\n if (v && v_) activeStream.point(x, y);\n else {\n var a = [x_ = Math.max(clipMin, Math.min(clipMax, x_)), y_ = Math.max(clipMin, Math.min(clipMax, y_))],\n b = [x = Math.max(clipMin, Math.min(clipMax, x)), y = Math.max(clipMin, Math.min(clipMax, y))];\n if (clipLine(a, b, x0, y0, x1, y1)) {\n if (!v_) {\n activeStream.lineStart();\n activeStream.point(a[0], a[1]);\n }\n activeStream.point(b[0], b[1]);\n if (!v) activeStream.lineEnd();\n clean = false;\n } else if (v) {\n activeStream.lineStart();\n activeStream.point(x, y);\n clean = false;\n }\n }\n }\n x_ = x, y_ = y, v_ = v;\n }\n\n return clipStream;\n };\n}\n","export default function(a, b, x0, y0, x1, y1) {\n var ax = a[0],\n ay = a[1],\n bx = b[0],\n by = b[1],\n t0 = 0,\n t1 = 1,\n dx = bx - ax,\n dy = by - ay,\n r;\n\n r = x0 - ax;\n if (!dx && r > 0) return;\n r /= dx;\n if (dx < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dx > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n\n r = x1 - ax;\n if (!dx && r < 0) return;\n r /= dx;\n if (dx < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dx > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n\n r = y0 - ay;\n if (!dy && r > 0) return;\n r /= dy;\n if (dy < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dy > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n\n r = y1 - ay;\n if (!dy && r < 0) return;\n r /= dy;\n if (dy < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dy > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n\n if (t0 > 0) a[0] = ax + t0 * dx, a[1] = ay + t0 * dy;\n if (t1 < 1) b[0] = ax + t1 * dx, b[1] = ay + t1 * dy;\n return true;\n}\n","import pointEqual from \"../pointEqual.js\";\nimport {epsilon} from \"../math.js\";\n\nfunction Intersection(point, points, other, entry) {\n this.x = point;\n this.z = points;\n this.o = other; // another intersection\n this.e = entry; // is an entry?\n this.v = false; // visited\n this.n = this.p = null; // next & previous\n}\n\n// A generalized polygon clipping algorithm: given a polygon that has been cut\n// into its visible line segments, and rejoins the segments by interpolating\n// along the clip edge.\nexport default function(segments, compareIntersection, startInside, interpolate, stream) {\n var subject = [],\n clip = [],\n i,\n n;\n\n segments.forEach(function(segment) {\n if ((n = segment.length - 1) <= 0) return;\n var n, p0 = segment[0], p1 = segment[n], x;\n\n if (pointEqual(p0, p1)) {\n if (!p0[2] && !p1[2]) {\n stream.lineStart();\n for (i = 0; i < n; ++i) stream.point((p0 = segment[i])[0], p0[1]);\n stream.lineEnd();\n return;\n }\n // handle degenerate cases by moving the point\n p1[0] += 2 * epsilon;\n }\n\n subject.push(x = new Intersection(p0, segment, null, true));\n clip.push(x.o = new Intersection(p0, null, x, false));\n subject.push(x = new Intersection(p1, segment, null, false));\n clip.push(x.o = new Intersection(p1, null, x, true));\n });\n\n if (!subject.length) return;\n\n clip.sort(compareIntersection);\n link(subject);\n link(clip);\n\n for (i = 0, n = clip.length; i < n; ++i) {\n clip[i].e = startInside = !startInside;\n }\n\n var start = subject[0],\n points,\n point;\n\n while (1) {\n // Find first unvisited intersection.\n var current = start,\n isSubject = true;\n while (current.v) if ((current = current.n) === start) return;\n points = current.z;\n stream.lineStart();\n do {\n current.v = current.o.v = true;\n if (current.e) {\n if (isSubject) {\n for (i = 0, n = points.length; i < n; ++i) stream.point((point = points[i])[0], point[1]);\n } else {\n interpolate(current.x, current.n.x, 1, stream);\n }\n current = current.n;\n } else {\n if (isSubject) {\n points = current.p.z;\n for (i = points.length - 1; i >= 0; --i) stream.point((point = points[i])[0], point[1]);\n } else {\n interpolate(current.x, current.p.x, -1, stream);\n }\n current = current.p;\n }\n current = current.o;\n points = current.z;\n isSubject = !isSubject;\n } while (!current.v);\n stream.lineEnd();\n }\n}\n\nfunction link(array) {\n if (!(n = array.length)) return;\n var n,\n i = 0,\n a = array[0],\n b;\n while (++i < n) {\n a.n = b = array[i];\n b.p = a;\n a = b;\n }\n a.n = b = array[0];\n b.p = a;\n}\n","export default function(a, b) {\n\n function compose(x, y) {\n return x = a(x, y), b(x[0], x[1]);\n }\n\n if (a.invert && b.invert) compose.invert = function(x, y) {\n return x = b.invert(x, y), x && a.invert(x[0], x[1]);\n };\n\n return compose;\n}\n","export default function(x) {\n return x;\n}\n","import clipRectangle from \"./rectangle.js\";\n\nexport default function() {\n var x0 = 0,\n y0 = 0,\n x1 = 960,\n y1 = 500,\n cache,\n cacheStream,\n clip;\n\n return clip = {\n stream: function(stream) {\n return cache && cacheStream === stream ? cache : cache = clipRectangle(x0, y0, x1, y1)(cacheStream = stream);\n },\n extent: function(_) {\n return arguments.length ? (x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1], cache = cacheStream = null, clip) : [[x0, y0], [x1, y1]];\n }\n };\n}\n","import adder from \"./adder.js\";\nimport {abs, atan2, cos, radians, sin, sqrt} from \"./math.js\";\nimport noop from \"./noop.js\";\nimport stream from \"./stream.js\";\n\nvar lengthSum = adder(),\n lambda0,\n sinPhi0,\n cosPhi0;\n\nvar lengthStream = {\n sphere: noop,\n point: noop,\n lineStart: lengthLineStart,\n lineEnd: noop,\n polygonStart: noop,\n polygonEnd: noop\n};\n\nfunction lengthLineStart() {\n lengthStream.point = lengthPointFirst;\n lengthStream.lineEnd = lengthLineEnd;\n}\n\nfunction lengthLineEnd() {\n lengthStream.point = lengthStream.lineEnd = noop;\n}\n\nfunction lengthPointFirst(lambda, phi) {\n lambda *= radians, phi *= radians;\n lambda0 = lambda, sinPhi0 = sin(phi), cosPhi0 = cos(phi);\n lengthStream.point = lengthPoint;\n}\n\nfunction lengthPoint(lambda, phi) {\n lambda *= radians, phi *= radians;\n var sinPhi = sin(phi),\n cosPhi = cos(phi),\n delta = abs(lambda - lambda0),\n cosDelta = cos(delta),\n sinDelta = sin(delta),\n x = cosPhi * sinDelta,\n y = cosPhi0 * sinPhi - sinPhi0 * cosPhi * cosDelta,\n z = sinPhi0 * sinPhi + cosPhi0 * cosPhi * cosDelta;\n lengthSum.add(atan2(sqrt(x * x + y * y), z));\n lambda0 = lambda, sinPhi0 = sinPhi, cosPhi0 = cosPhi;\n}\n\nexport default function(object) {\n lengthSum.reset();\n stream(object, lengthStream);\n return +lengthSum;\n}\n","import length from \"./length.js\";\n\nvar coordinates = [null, null],\n object = {type: \"LineString\", coordinates: coordinates};\n\nexport default function(a, b) {\n coordinates[0] = a;\n coordinates[1] = b;\n return length(object);\n}\n","import {default as polygonContains} from \"./polygonContains.js\";\nimport {default as distance} from \"./distance.js\";\nimport {epsilon2, radians} from \"./math.js\";\n\nvar containsObjectType = {\n Feature: function(object, point) {\n return containsGeometry(object.geometry, point);\n },\n FeatureCollection: function(object, point) {\n var features = object.features, i = -1, n = features.length;\n while (++i < n) if (containsGeometry(features[i].geometry, point)) return true;\n return false;\n }\n};\n\nvar containsGeometryType = {\n Sphere: function() {\n return true;\n },\n Point: function(object, point) {\n return containsPoint(object.coordinates, point);\n },\n MultiPoint: function(object, point) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) if (containsPoint(coordinates[i], point)) return true;\n return false;\n },\n LineString: function(object, point) {\n return containsLine(object.coordinates, point);\n },\n MultiLineString: function(object, point) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) if (containsLine(coordinates[i], point)) return true;\n return false;\n },\n Polygon: function(object, point) {\n return containsPolygon(object.coordinates, point);\n },\n MultiPolygon: function(object, point) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) if (containsPolygon(coordinates[i], point)) return true;\n return false;\n },\n GeometryCollection: function(object, point) {\n var geometries = object.geometries, i = -1, n = geometries.length;\n while (++i < n) if (containsGeometry(geometries[i], point)) return true;\n return false;\n }\n};\n\nfunction containsGeometry(geometry, point) {\n return geometry && containsGeometryType.hasOwnProperty(geometry.type)\n ? containsGeometryType[geometry.type](geometry, point)\n : false;\n}\n\nfunction containsPoint(coordinates, point) {\n return distance(coordinates, point) === 0;\n}\n\nfunction containsLine(coordinates, point) {\n var ao, bo, ab;\n for (var i = 0, n = coordinates.length; i < n; i++) {\n bo = distance(coordinates[i], point);\n if (bo === 0) return true;\n if (i > 0) {\n ab = distance(coordinates[i], coordinates[i - 1]);\n if (\n ab > 0 &&\n ao <= ab &&\n bo <= ab &&\n (ao + bo - ab) * (1 - Math.pow((ao - bo) / ab, 2)) < epsilon2 * ab\n )\n return true;\n }\n ao = bo;\n }\n return false;\n}\n\nfunction containsPolygon(coordinates, point) {\n return !!polygonContains(coordinates.map(ringRadians), pointRadians(point));\n}\n\nfunction ringRadians(ring) {\n return ring = ring.map(pointRadians), ring.pop(), ring;\n}\n\nfunction pointRadians(point) {\n return [point[0] * radians, point[1] * radians];\n}\n\nexport default function(object, point) {\n return (object && containsObjectType.hasOwnProperty(object.type)\n ? containsObjectType[object.type]\n : containsGeometry)(object, point);\n}\n","import {range} from \"d3-array\";\nimport {abs, ceil, epsilon} from \"./math.js\";\n\nfunction graticuleX(y0, y1, dy) {\n var y = range(y0, y1 - epsilon, dy).concat(y1);\n return function(x) { return y.map(function(y) { return [x, y]; }); };\n}\n\nfunction graticuleY(x0, x1, dx) {\n var x = range(x0, x1 - epsilon, dx).concat(x1);\n return function(y) { return x.map(function(x) { return [x, y]; }); };\n}\n\nexport default function graticule() {\n var x1, x0, X1, X0,\n y1, y0, Y1, Y0,\n dx = 10, dy = dx, DX = 90, DY = 360,\n x, y, X, Y,\n precision = 2.5;\n\n function graticule() {\n return {type: \"MultiLineString\", coordinates: lines()};\n }\n\n function lines() {\n return range(ceil(X0 / DX) * DX, X1, DX).map(X)\n .concat(range(ceil(Y0 / DY) * DY, Y1, DY).map(Y))\n .concat(range(ceil(x0 / dx) * dx, x1, dx).filter(function(x) { return abs(x % DX) > epsilon; }).map(x))\n .concat(range(ceil(y0 / dy) * dy, y1, dy).filter(function(y) { return abs(y % DY) > epsilon; }).map(y));\n }\n\n graticule.lines = function() {\n return lines().map(function(coordinates) { return {type: \"LineString\", coordinates: coordinates}; });\n };\n\n graticule.outline = function() {\n return {\n type: \"Polygon\",\n coordinates: [\n X(X0).concat(\n Y(Y1).slice(1),\n X(X1).reverse().slice(1),\n Y(Y0).reverse().slice(1))\n ]\n };\n };\n\n graticule.extent = function(_) {\n if (!arguments.length) return graticule.extentMinor();\n return graticule.extentMajor(_).extentMinor(_);\n };\n\n graticule.extentMajor = function(_) {\n if (!arguments.length) return [[X0, Y0], [X1, Y1]];\n X0 = +_[0][0], X1 = +_[1][0];\n Y0 = +_[0][1], Y1 = +_[1][1];\n if (X0 > X1) _ = X0, X0 = X1, X1 = _;\n if (Y0 > Y1) _ = Y0, Y0 = Y1, Y1 = _;\n return graticule.precision(precision);\n };\n\n graticule.extentMinor = function(_) {\n if (!arguments.length) return [[x0, y0], [x1, y1]];\n x0 = +_[0][0], x1 = +_[1][0];\n y0 = +_[0][1], y1 = +_[1][1];\n if (x0 > x1) _ = x0, x0 = x1, x1 = _;\n if (y0 > y1) _ = y0, y0 = y1, y1 = _;\n return graticule.precision(precision);\n };\n\n graticule.step = function(_) {\n if (!arguments.length) return graticule.stepMinor();\n return graticule.stepMajor(_).stepMinor(_);\n };\n\n graticule.stepMajor = function(_) {\n if (!arguments.length) return [DX, DY];\n DX = +_[0], DY = +_[1];\n return graticule;\n };\n\n graticule.stepMinor = function(_) {\n if (!arguments.length) return [dx, dy];\n dx = +_[0], dy = +_[1];\n return graticule;\n };\n\n graticule.precision = function(_) {\n if (!arguments.length) return precision;\n precision = +_;\n x = graticuleX(y0, y1, 90);\n y = graticuleY(x0, x1, precision);\n X = graticuleX(Y0, Y1, 90);\n Y = graticuleY(X0, X1, precision);\n return graticule;\n };\n\n return graticule\n .extentMajor([[-180, -90 + epsilon], [180, 90 - epsilon]])\n .extentMinor([[-180, -80 - epsilon], [180, 80 + epsilon]]);\n}\n\nexport function graticule10() {\n return graticule()();\n}\n","import adder from \"../adder.js\";\nimport {abs} from \"../math.js\";\nimport noop from \"../noop.js\";\n\nvar areaSum = adder(),\n areaRingSum = adder(),\n x00,\n y00,\n x0,\n y0;\n\nvar areaStream = {\n point: noop,\n lineStart: noop,\n lineEnd: noop,\n polygonStart: function() {\n areaStream.lineStart = areaRingStart;\n areaStream.lineEnd = areaRingEnd;\n },\n polygonEnd: function() {\n areaStream.lineStart = areaStream.lineEnd = areaStream.point = noop;\n areaSum.add(abs(areaRingSum));\n areaRingSum.reset();\n },\n result: function() {\n var area = areaSum / 2;\n areaSum.reset();\n return area;\n }\n};\n\nfunction areaRingStart() {\n areaStream.point = areaPointFirst;\n}\n\nfunction areaPointFirst(x, y) {\n areaStream.point = areaPoint;\n x00 = x0 = x, y00 = y0 = y;\n}\n\nfunction areaPoint(x, y) {\n areaRingSum.add(y0 * x - x0 * y);\n x0 = x, y0 = y;\n}\n\nfunction areaRingEnd() {\n areaPoint(x00, y00);\n}\n\nexport default areaStream;\n","import {sqrt} from \"../math.js\";\n\n// TODO Enforce positive area for exterior, negative area for interior?\n\nvar X0 = 0,\n Y0 = 0,\n Z0 = 0,\n X1 = 0,\n Y1 = 0,\n Z1 = 0,\n X2 = 0,\n Y2 = 0,\n Z2 = 0,\n x00,\n y00,\n x0,\n y0;\n\nvar centroidStream = {\n point: centroidPoint,\n lineStart: centroidLineStart,\n lineEnd: centroidLineEnd,\n polygonStart: function() {\n centroidStream.lineStart = centroidRingStart;\n centroidStream.lineEnd = centroidRingEnd;\n },\n polygonEnd: function() {\n centroidStream.point = centroidPoint;\n centroidStream.lineStart = centroidLineStart;\n centroidStream.lineEnd = centroidLineEnd;\n },\n result: function() {\n var centroid = Z2 ? [X2 / Z2, Y2 / Z2]\n : Z1 ? [X1 / Z1, Y1 / Z1]\n : Z0 ? [X0 / Z0, Y0 / Z0]\n : [NaN, NaN];\n X0 = Y0 = Z0 =\n X1 = Y1 = Z1 =\n X2 = Y2 = Z2 = 0;\n return centroid;\n }\n};\n\nfunction centroidPoint(x, y) {\n X0 += x;\n Y0 += y;\n ++Z0;\n}\n\nfunction centroidLineStart() {\n centroidStream.point = centroidPointFirstLine;\n}\n\nfunction centroidPointFirstLine(x, y) {\n centroidStream.point = centroidPointLine;\n centroidPoint(x0 = x, y0 = y);\n}\n\nfunction centroidPointLine(x, y) {\n var dx = x - x0, dy = y - y0, z = sqrt(dx * dx + dy * dy);\n X1 += z * (x0 + x) / 2;\n Y1 += z * (y0 + y) / 2;\n Z1 += z;\n centroidPoint(x0 = x, y0 = y);\n}\n\nfunction centroidLineEnd() {\n centroidStream.point = centroidPoint;\n}\n\nfunction centroidRingStart() {\n centroidStream.point = centroidPointFirstRing;\n}\n\nfunction centroidRingEnd() {\n centroidPointRing(x00, y00);\n}\n\nfunction centroidPointFirstRing(x, y) {\n centroidStream.point = centroidPointRing;\n centroidPoint(x00 = x0 = x, y00 = y0 = y);\n}\n\nfunction centroidPointRing(x, y) {\n var dx = x - x0,\n dy = y - y0,\n z = sqrt(dx * dx + dy * dy);\n\n X1 += z * (x0 + x) / 2;\n Y1 += z * (y0 + y) / 2;\n Z1 += z;\n\n z = y0 * x - x0 * y;\n X2 += z * (x0 + x);\n Y2 += z * (y0 + y);\n Z2 += z * 3;\n centroidPoint(x0 = x, y0 = y);\n}\n\nexport default centroidStream;\n","import {tau} from \"../math.js\";\nimport noop from \"../noop.js\";\n\nexport default function PathContext(context) {\n this._context = context;\n}\n\nPathContext.prototype = {\n _radius: 4.5,\n pointRadius: function(_) {\n return this._radius = _, this;\n },\n polygonStart: function() {\n this._line = 0;\n },\n polygonEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line === 0) this._context.closePath();\n this._point = NaN;\n },\n point: function(x, y) {\n switch (this._point) {\n case 0: {\n this._context.moveTo(x, y);\n this._point = 1;\n break;\n }\n case 1: {\n this._context.lineTo(x, y);\n break;\n }\n default: {\n this._context.moveTo(x + this._radius, y);\n this._context.arc(x, y, this._radius, 0, tau);\n break;\n }\n }\n },\n result: noop\n};\n","import adder from \"../adder.js\";\nimport {sqrt} from \"../math.js\";\nimport noop from \"../noop.js\";\n\nvar lengthSum = adder(),\n lengthRing,\n x00,\n y00,\n x0,\n y0;\n\nvar lengthStream = {\n point: noop,\n lineStart: function() {\n lengthStream.point = lengthPointFirst;\n },\n lineEnd: function() {\n if (lengthRing) lengthPoint(x00, y00);\n lengthStream.point = noop;\n },\n polygonStart: function() {\n lengthRing = true;\n },\n polygonEnd: function() {\n lengthRing = null;\n },\n result: function() {\n var length = +lengthSum;\n lengthSum.reset();\n return length;\n }\n};\n\nfunction lengthPointFirst(x, y) {\n lengthStream.point = lengthPoint;\n x00 = x0 = x, y00 = y0 = y;\n}\n\nfunction lengthPoint(x, y) {\n x0 -= x, y0 -= y;\n lengthSum.add(sqrt(x0 * x0 + y0 * y0));\n x0 = x, y0 = y;\n}\n\nexport default lengthStream;\n","export default function PathString() {\n this._string = [];\n}\n\nPathString.prototype = {\n _radius: 4.5,\n _circle: circle(4.5),\n pointRadius: function(_) {\n if ((_ = +_) !== this._radius) this._radius = _, this._circle = null;\n return this;\n },\n polygonStart: function() {\n this._line = 0;\n },\n polygonEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line === 0) this._string.push(\"Z\");\n this._point = NaN;\n },\n point: function(x, y) {\n switch (this._point) {\n case 0: {\n this._string.push(\"M\", x, \",\", y);\n this._point = 1;\n break;\n }\n case 1: {\n this._string.push(\"L\", x, \",\", y);\n break;\n }\n default: {\n if (this._circle == null) this._circle = circle(this._radius);\n this._string.push(\"M\", x, \",\", y, this._circle);\n break;\n }\n }\n },\n result: function() {\n if (this._string.length) {\n var result = this._string.join(\"\");\n this._string = [];\n return result;\n } else {\n return null;\n }\n }\n};\n\nfunction circle(radius) {\n return \"m0,\" + radius\n + \"a\" + radius + \",\" + radius + \" 0 1,1 0,\" + -2 * radius\n + \"a\" + radius + \",\" + radius + \" 0 1,1 0,\" + 2 * radius\n + \"z\";\n}\n","import identity from \"../identity.js\";\nimport stream from \"../stream.js\";\nimport pathArea from \"./area.js\";\nimport pathBounds from \"./bounds.js\";\nimport pathCentroid from \"./centroid.js\";\nimport PathContext from \"./context.js\";\nimport pathMeasure from \"./measure.js\";\nimport PathString from \"./string.js\";\n\nexport default function(projection, context) {\n var pointRadius = 4.5,\n projectionStream,\n contextStream;\n\n function path(object) {\n if (object) {\n if (typeof pointRadius === \"function\") contextStream.pointRadius(+pointRadius.apply(this, arguments));\n stream(object, projectionStream(contextStream));\n }\n return contextStream.result();\n }\n\n path.area = function(object) {\n stream(object, projectionStream(pathArea));\n return pathArea.result();\n };\n\n path.measure = function(object) {\n stream(object, projectionStream(pathMeasure));\n return pathMeasure.result();\n };\n\n path.bounds = function(object) {\n stream(object, projectionStream(pathBounds));\n return pathBounds.result();\n };\n\n path.centroid = function(object) {\n stream(object, projectionStream(pathCentroid));\n return pathCentroid.result();\n };\n\n path.projection = function(_) {\n return arguments.length ? (projectionStream = _ == null ? (projection = null, identity) : (projection = _).stream, path) : projection;\n };\n\n path.context = function(_) {\n if (!arguments.length) return context;\n contextStream = _ == null ? (context = null, new PathString) : new PathContext(context = _);\n if (typeof pointRadius !== \"function\") contextStream.pointRadius(pointRadius);\n return path;\n };\n\n path.pointRadius = function(_) {\n if (!arguments.length) return pointRadius;\n pointRadius = typeof _ === \"function\" ? _ : (contextStream.pointRadius(+_), +_);\n return path;\n };\n\n return path.projection(projection).context(context);\n}\n","import {degrees, pi, radians} from \"../math.js\";\nimport {projectionMutator} from \"./index.js\";\n\nexport function conicProjection(projectAt) {\n var phi0 = 0,\n phi1 = pi / 3,\n m = projectionMutator(projectAt),\n p = m(phi0, phi1);\n\n p.parallels = function(_) {\n return arguments.length ? m(phi0 = _[0] * radians, phi1 = _[1] * radians) : [phi0 * degrees, phi1 * degrees];\n };\n\n return p;\n}\n","import {abs, asin, atan2, cos, epsilon, pi, sign, sin, sqrt} from \"../math.js\";\nimport {conicProjection} from \"./conic.js\";\nimport {cylindricalEqualAreaRaw} from \"./cylindricalEqualArea.js\";\n\nexport function conicEqualAreaRaw(y0, y1) {\n var sy0 = sin(y0), n = (sy0 + sin(y1)) / 2;\n\n // Are the parallels symmetrical around the Equator?\n if (abs(n) < epsilon) return cylindricalEqualAreaRaw(y0);\n\n var c = 1 + sy0 * (2 * n - sy0), r0 = sqrt(c) / n;\n\n function project(x, y) {\n var r = sqrt(c - 2 * n * sin(y)) / n;\n return [r * sin(x *= n), r0 - r * cos(x)];\n }\n\n project.invert = function(x, y) {\n var r0y = r0 - y,\n l = atan2(x, abs(r0y)) * sign(r0y);\n if (r0y * n < 0)\n l -= pi * sign(x) * sign(r0y);\n return [l / n, asin((c - (x * x + r0y * r0y) * n * n) / (2 * n))];\n };\n\n return project;\n}\n\nexport default function() {\n return conicProjection(conicEqualAreaRaw)\n .scale(155.424)\n .center([0, 33.6442]);\n}\n","import {asin, cos, sin} from \"../math.js\";\n\nexport function cylindricalEqualAreaRaw(phi0) {\n var cosPhi0 = cos(phi0);\n\n function forward(lambda, phi) {\n return [lambda * cosPhi0, sin(phi) / cosPhi0];\n }\n\n forward.invert = function(x, y) {\n return [x / cosPhi0, asin(y * cosPhi0)];\n };\n\n return forward;\n}\n","import conicEqualArea from \"./conicEqualArea.js\";\n\nexport default function() {\n return conicEqualArea()\n .parallels([29.5, 45.5])\n .scale(1070)\n .translate([480, 250])\n .rotate([96, 0])\n .center([-0.6, 38.7]);\n}\n","import {epsilon} from \"../math.js\";\nimport albers from \"./albers.js\";\nimport conicEqualArea from \"./conicEqualArea.js\";\nimport {fitExtent, fitSize, fitWidth, fitHeight} from \"./fit.js\";\n\n// The projections must have mutually exclusive clip regions on the sphere,\n// as this will avoid emitting interleaving lines and polygons.\nfunction multiplex(streams) {\n var n = streams.length;\n return {\n point: function(x, y) { var i = -1; while (++i < n) streams[i].point(x, y); },\n sphere: function() { var i = -1; while (++i < n) streams[i].sphere(); },\n lineStart: function() { var i = -1; while (++i < n) streams[i].lineStart(); },\n lineEnd: function() { var i = -1; while (++i < n) streams[i].lineEnd(); },\n polygonStart: function() { var i = -1; while (++i < n) streams[i].polygonStart(); },\n polygonEnd: function() { var i = -1; while (++i < n) streams[i].polygonEnd(); }\n };\n}\n\n// A composite projection for the United States, configured by default for\n// 960×500. The projection also works quite well at 960×600 if you change the\n// scale to 1285 and adjust the translate accordingly. The set of standard\n// parallels for each region comes from USGS, which is published here:\n// http://egsc.usgs.gov/isb/pubs/MapProjections/projections.html#albers\nexport default function() {\n var cache,\n cacheStream,\n lower48 = albers(), lower48Point,\n alaska = conicEqualArea().rotate([154, 0]).center([-2, 58.5]).parallels([55, 65]), alaskaPoint, // EPSG:3338\n hawaii = conicEqualArea().rotate([157, 0]).center([-3, 19.9]).parallels([8, 18]), hawaiiPoint, // ESRI:102007\n point, pointStream = {point: function(x, y) { point = [x, y]; }};\n\n function albersUsa(coordinates) {\n var x = coordinates[0], y = coordinates[1];\n return point = null,\n (lower48Point.point(x, y), point)\n || (alaskaPoint.point(x, y), point)\n || (hawaiiPoint.point(x, y), point);\n }\n\n albersUsa.invert = function(coordinates) {\n var k = lower48.scale(),\n t = lower48.translate(),\n x = (coordinates[0] - t[0]) / k,\n y = (coordinates[1] - t[1]) / k;\n return (y >= 0.120 && y < 0.234 && x >= -0.425 && x < -0.214 ? alaska\n : y >= 0.166 && y < 0.234 && x >= -0.214 && x < -0.115 ? hawaii\n : lower48).invert(coordinates);\n };\n\n albersUsa.stream = function(stream) {\n return cache && cacheStream === stream ? cache : cache = multiplex([lower48.stream(cacheStream = stream), alaska.stream(stream), hawaii.stream(stream)]);\n };\n\n albersUsa.precision = function(_) {\n if (!arguments.length) return lower48.precision();\n lower48.precision(_), alaska.precision(_), hawaii.precision(_);\n return reset();\n };\n\n albersUsa.scale = function(_) {\n if (!arguments.length) return lower48.scale();\n lower48.scale(_), alaska.scale(_ * 0.35), hawaii.scale(_);\n return albersUsa.translate(lower48.translate());\n };\n\n albersUsa.translate = function(_) {\n if (!arguments.length) return lower48.translate();\n var k = lower48.scale(), x = +_[0], y = +_[1];\n\n lower48Point = lower48\n .translate(_)\n .clipExtent([[x - 0.455 * k, y - 0.238 * k], [x + 0.455 * k, y + 0.238 * k]])\n .stream(pointStream);\n\n alaskaPoint = alaska\n .translate([x - 0.307 * k, y + 0.201 * k])\n .clipExtent([[x - 0.425 * k + epsilon, y + 0.120 * k + epsilon], [x - 0.214 * k - epsilon, y + 0.234 * k - epsilon]])\n .stream(pointStream);\n\n hawaiiPoint = hawaii\n .translate([x - 0.205 * k, y + 0.212 * k])\n .clipExtent([[x - 0.214 * k + epsilon, y + 0.166 * k + epsilon], [x - 0.115 * k - epsilon, y + 0.234 * k - epsilon]])\n .stream(pointStream);\n\n return reset();\n };\n\n albersUsa.fitExtent = function(extent, object) {\n return fitExtent(albersUsa, extent, object);\n };\n\n albersUsa.fitSize = function(size, object) {\n return fitSize(albersUsa, size, object);\n };\n\n albersUsa.fitWidth = function(width, object) {\n return fitWidth(albersUsa, width, object);\n };\n\n albersUsa.fitHeight = function(height, object) {\n return fitHeight(albersUsa, height, object);\n };\n\n function reset() {\n cache = cacheStream = null;\n return albersUsa;\n }\n\n return albersUsa.scale(1070);\n}\n","import {atan, exp, halfPi, log, pi, tan, tau} from \"../math.js\";\nimport rotation from \"../rotation.js\";\nimport projection from \"./index.js\";\n\nexport function mercatorRaw(lambda, phi) {\n return [lambda, log(tan((halfPi + phi) / 2))];\n}\n\nmercatorRaw.invert = function(x, y) {\n return [x, 2 * atan(exp(y)) - halfPi];\n};\n\nexport default function() {\n return mercatorProjection(mercatorRaw)\n .scale(961 / tau);\n}\n\nexport function mercatorProjection(project) {\n var m = projection(project),\n center = m.center,\n scale = m.scale,\n translate = m.translate,\n clipExtent = m.clipExtent,\n x0 = null, y0, x1, y1; // clip extent\n\n m.scale = function(_) {\n return arguments.length ? (scale(_), reclip()) : scale();\n };\n\n m.translate = function(_) {\n return arguments.length ? (translate(_), reclip()) : translate();\n };\n\n m.center = function(_) {\n return arguments.length ? (center(_), reclip()) : center();\n };\n\n m.clipExtent = function(_) {\n return arguments.length ? ((_ == null ? x0 = y0 = x1 = y1 = null : (x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1])), reclip()) : x0 == null ? null : [[x0, y0], [x1, y1]];\n };\n\n function reclip() {\n var k = pi * scale(),\n t = m(rotation(m.rotate()).invert([0, 0]));\n return clipExtent(x0 == null\n ? [[t[0] - k, t[1] - k], [t[0] + k, t[1] + k]] : project === mercatorRaw\n ? [[Math.max(t[0] - k, x0), y0], [Math.min(t[0] + k, x1), y1]]\n : [[x0, Math.max(t[1] - k, y0)], [x1, Math.min(t[1] + k, y1)]]);\n }\n\n return reclip();\n}\n","import {abs, atan, atan2, cos, epsilon, halfPi, log, pi, pow, sign, sin, sqrt, tan} from \"../math.js\";\nimport {conicProjection} from \"./conic.js\";\nimport {mercatorRaw} from \"./mercator.js\";\n\nfunction tany(y) {\n return tan((halfPi + y) / 2);\n}\n\nexport function conicConformalRaw(y0, y1) {\n var cy0 = cos(y0),\n n = y0 === y1 ? sin(y0) : log(cy0 / cos(y1)) / log(tany(y1) / tany(y0)),\n f = cy0 * pow(tany(y0), n) / n;\n\n if (!n) return mercatorRaw;\n\n function project(x, y) {\n if (f > 0) { if (y < -halfPi + epsilon) y = -halfPi + epsilon; }\n else { if (y > halfPi - epsilon) y = halfPi - epsilon; }\n var r = f / pow(tany(y), n);\n return [r * sin(n * x), f - r * cos(n * x)];\n }\n\n project.invert = function(x, y) {\n var fy = f - y, r = sign(n) * sqrt(x * x + fy * fy),\n l = atan2(x, abs(fy)) * sign(fy);\n if (fy * n < 0)\n l -= pi * sign(x) * sign(fy);\n return [l / n, 2 * atan(pow(f / r, 1 / n)) - halfPi];\n };\n\n return project;\n}\n\nexport default function() {\n return conicProjection(conicConformalRaw)\n .scale(109.5)\n .parallels([30, 30]);\n}\n","import {abs, atan2, cos, epsilon, pi, sign, sin, sqrt} from \"../math.js\";\nimport {conicProjection} from \"./conic.js\";\nimport {equirectangularRaw} from \"./equirectangular.js\";\n\nexport function conicEquidistantRaw(y0, y1) {\n var cy0 = cos(y0),\n n = y0 === y1 ? sin(y0) : (cy0 - cos(y1)) / (y1 - y0),\n g = cy0 / n + y0;\n\n if (abs(n) < epsilon) return equirectangularRaw;\n\n function project(x, y) {\n var gy = g - y, nx = n * x;\n return [gy * sin(nx), g - gy * cos(nx)];\n }\n\n project.invert = function(x, y) {\n var gy = g - y,\n l = atan2(x, abs(gy)) * sign(gy);\n if (gy * n < 0)\n l -= pi * sign(x) * sign(gy);\n return [l / n, g - sign(n) * sqrt(x * x + gy * gy)];\n };\n\n return project;\n}\n\nexport default function() {\n return conicProjection(conicEquidistantRaw)\n .scale(131.154)\n .center([0, 13.9389]);\n}\n","import projection from \"./index.js\";\nimport {abs, asin, cos, epsilon2, sin, sqrt} from \"../math.js\";\n\nvar A1 = 1.340264,\n A2 = -0.081106,\n A3 = 0.000893,\n A4 = 0.003796,\n M = sqrt(3) / 2,\n iterations = 12;\n\nexport function equalEarthRaw(lambda, phi) {\n var l = asin(M * sin(phi)), l2 = l * l, l6 = l2 * l2 * l2;\n return [\n lambda * cos(l) / (M * (A1 + 3 * A2 * l2 + l6 * (7 * A3 + 9 * A4 * l2))),\n l * (A1 + A2 * l2 + l6 * (A3 + A4 * l2))\n ];\n}\n\nequalEarthRaw.invert = function(x, y) {\n var l = y, l2 = l * l, l6 = l2 * l2 * l2;\n for (var i = 0, delta, fy, fpy; i < iterations; ++i) {\n fy = l * (A1 + A2 * l2 + l6 * (A3 + A4 * l2)) - y;\n fpy = A1 + 3 * A2 * l2 + l6 * (7 * A3 + 9 * A4 * l2);\n l -= delta = fy / fpy, l2 = l * l, l6 = l2 * l2 * l2;\n if (abs(delta) < epsilon2) break;\n }\n return [\n M * x * (A1 + 3 * A2 * l2 + l6 * (7 * A3 + 9 * A4 * l2)) / cos(l),\n asin(sin(l) / M)\n ];\n};\n\nexport default function() {\n return projection(equalEarthRaw)\n .scale(177.158);\n}\n","import clipRectangle from \"../clip/rectangle.js\";\nimport identity from \"../identity.js\";\nimport {transformer} from \"../transform.js\";\nimport {fitExtent, fitSize, fitWidth, fitHeight} from \"./fit.js\";\nimport {cos, degrees, radians, sin} from \"../math.js\";\n\nexport default function() {\n var k = 1, tx = 0, ty = 0, sx = 1, sy = 1, // scale, translate and reflect\n alpha = 0, ca, sa, // angle\n x0 = null, y0, x1, y1, // clip extent\n kx = 1, ky = 1,\n transform = transformer({\n point: function(x, y) {\n var p = projection([x, y])\n this.stream.point(p[0], p[1]);\n }\n }),\n postclip = identity,\n cache,\n cacheStream;\n\n function reset() {\n kx = k * sx;\n ky = k * sy;\n cache = cacheStream = null;\n return projection;\n }\n\n function projection (p) {\n var x = p[0] * kx, y = p[1] * ky;\n if (alpha) {\n var t = y * ca - x * sa;\n x = x * ca + y * sa;\n y = t;\n } \n return [x + tx, y + ty];\n }\n projection.invert = function(p) {\n var x = p[0] - tx, y = p[1] - ty;\n if (alpha) {\n var t = y * ca + x * sa;\n x = x * ca - y * sa;\n y = t;\n }\n return [x / kx, y / ky];\n };\n projection.stream = function(stream) {\n return cache && cacheStream === stream ? cache : cache = transform(postclip(cacheStream = stream));\n };\n projection.postclip = function(_) {\n return arguments.length ? (postclip = _, x0 = y0 = x1 = y1 = null, reset()) : postclip;\n };\n projection.clipExtent = function(_) {\n return arguments.length ? (postclip = _ == null ? (x0 = y0 = x1 = y1 = null, identity) : clipRectangle(x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1]), reset()) : x0 == null ? null : [[x0, y0], [x1, y1]];\n };\n projection.scale = function(_) {\n return arguments.length ? (k = +_, reset()) : k;\n };\n projection.translate = function(_) {\n return arguments.length ? (tx = +_[0], ty = +_[1], reset()) : [tx, ty];\n }\n projection.angle = function(_) {\n return arguments.length ? (alpha = _ % 360 * radians, sa = sin(alpha), ca = cos(alpha), reset()) : alpha * degrees;\n };\n projection.reflectX = function(_) {\n return arguments.length ? (sx = _ ? -1 : 1, reset()) : sx < 0;\n };\n projection.reflectY = function(_) {\n return arguments.length ? (sy = _ ? -1 : 1, reset()) : sy < 0;\n };\n projection.fitExtent = function(extent, object) {\n return fitExtent(projection, extent, object);\n };\n projection.fitSize = function(size, object) {\n return fitSize(projection, size, object);\n };\n projection.fitWidth = function(width, object) {\n return fitWidth(projection, width, object);\n };\n projection.fitHeight = function(height, object) {\n return fitHeight(projection, height, object);\n };\n\n return projection;\n}\n","import {atan, cos, sin} from \"../math.js\";\nimport {azimuthalInvert} from \"./azimuthal.js\";\nimport projection from \"./index.js\";\n\nexport function stereographicRaw(x, y) {\n var cy = cos(y), k = 1 + cos(x) * cy;\n return [cy * sin(x) / k, sin(y) / k];\n}\n\nstereographicRaw.invert = azimuthalInvert(function(z) {\n return 2 * atan(z);\n});\n\nexport default function() {\n return projection(stereographicRaw)\n .scale(250)\n .clipAngle(142);\n}\n","import {atan, exp, halfPi, log, tan} from \"../math.js\";\nimport {mercatorProjection} from \"./mercator.js\";\n\nexport function transverseMercatorRaw(lambda, phi) {\n return [log(tan((halfPi + phi) / 2)), -lambda];\n}\n\ntransverseMercatorRaw.invert = function(x, y) {\n return [-y, 2 * atan(exp(x)) - halfPi];\n};\n\nexport default function() {\n var m = mercatorProjection(transverseMercatorRaw),\n center = m.center,\n rotate = m.rotate;\n\n m.center = function(_) {\n return arguments.length ? center([-_[1], _[0]]) : (_ = center(), [_[1], -_[0]]);\n };\n\n m.rotate = function(_) {\n return arguments.length ? rotate([_[0], _[1], _.length > 2 ? _[2] + 90 : 90]) : (_ = rotate(), [_[0], _[1], _[2] - 90]);\n };\n\n return rotate([0, 0, 90])\n .scale(159.155);\n}\n","import {asin, atan2, cos, degrees, haversin, radians, sin, sqrt} from \"./math.js\";\n\nexport default function(a, b) {\n var x0 = a[0] * radians,\n y0 = a[1] * radians,\n x1 = b[0] * radians,\n y1 = b[1] * radians,\n cy0 = cos(y0),\n sy0 = sin(y0),\n cy1 = cos(y1),\n sy1 = sin(y1),\n kx0 = cy0 * cos(x0),\n ky0 = cy0 * sin(x0),\n kx1 = cy1 * cos(x1),\n ky1 = cy1 * sin(x1),\n d = 2 * asin(sqrt(haversin(y1 - y0) + cy0 * cy1 * haversin(x1 - x0))),\n k = sin(d);\n\n var interpolate = d ? function(t) {\n var B = sin(t *= d) / k,\n A = sin(d - t) / k,\n x = A * kx0 + B * kx1,\n y = A * ky0 + B * ky1,\n z = A * sy0 + B * sy1;\n return [\n atan2(y, x) * degrees,\n atan2(z, sqrt(x * x + y * y)) * degrees\n ];\n } : function() {\n return [x0 * degrees, y0 * degrees];\n };\n\n interpolate.distance = d;\n\n return interpolate;\n}\n","export var epsilon = 1e-6;\nexport var epsilon2 = 1e-12;\nexport var pi = Math.PI;\nexport var halfPi = pi / 2;\nexport var quarterPi = pi / 4;\nexport var tau = pi * 2;\n\nexport var degrees = 180 / pi;\nexport var radians = pi / 180;\n\nexport var abs = Math.abs;\nexport var atan = Math.atan;\nexport var atan2 = Math.atan2;\nexport var cos = Math.cos;\nexport var ceil = Math.ceil;\nexport var exp = Math.exp;\nexport var floor = Math.floor;\nexport var log = Math.log;\nexport var pow = Math.pow;\nexport var sin = Math.sin;\nexport var sign = Math.sign || function(x) { return x > 0 ? 1 : x < 0 ? -1 : 0; };\nexport var sqrt = Math.sqrt;\nexport var tan = Math.tan;\n\nexport function acos(x) {\n return x > 1 ? 0 : x < -1 ? pi : Math.acos(x);\n}\n\nexport function asin(x) {\n return x > 1 ? halfPi : x < -1 ? -halfPi : Math.asin(x);\n}\n\nexport function haversin(x) {\n return (x = sin(x / 2)) * x;\n}\n","export default function noop() {}\n","import noop from \"../noop.js\";\n\nvar x0 = Infinity,\n y0 = x0,\n x1 = -x0,\n y1 = x1;\n\nvar boundsStream = {\n point: boundsPoint,\n lineStart: noop,\n lineEnd: noop,\n polygonStart: noop,\n polygonEnd: noop,\n result: function() {\n var bounds = [[x0, y0], [x1, y1]];\n x1 = y1 = -(y0 = x0 = Infinity);\n return bounds;\n }\n};\n\nfunction boundsPoint(x, y) {\n if (x < x0) x0 = x;\n if (x > x1) x1 = x;\n if (y < y0) y0 = y;\n if (y > y1) y1 = y;\n}\n\nexport default boundsStream;\n","import {abs, epsilon} from \"./math.js\";\n\nexport default function(a, b) {\n return abs(a[0] - b[0]) < epsilon && abs(a[1] - b[1]) < epsilon;\n}\n","import adder from \"./adder.js\";\nimport {cartesian, cartesianCross, cartesianNormalizeInPlace} from \"./cartesian.js\";\nimport {abs, asin, atan2, cos, epsilon, halfPi, pi, quarterPi, sign, sin, tau} from \"./math.js\";\n\nvar sum = adder();\n\nfunction longitude(point) {\n if (abs(point[0]) <= pi)\n return point[0];\n else\n return sign(point[0]) * ((abs(point[0]) + pi) % tau - pi);\n}\n\nexport default function(polygon, point) {\n var lambda = longitude(point),\n phi = point[1],\n sinPhi = sin(phi),\n normal = [sin(lambda), -cos(lambda), 0],\n angle = 0,\n winding = 0;\n\n sum.reset();\n\n if (sinPhi === 1) phi = halfPi + epsilon;\n else if (sinPhi === -1) phi = -halfPi - epsilon;\n\n for (var i = 0, n = polygon.length; i < n; ++i) {\n if (!(m = (ring = polygon[i]).length)) continue;\n var ring,\n m,\n point0 = ring[m - 1],\n lambda0 = longitude(point0),\n phi0 = point0[1] / 2 + quarterPi,\n sinPhi0 = sin(phi0),\n cosPhi0 = cos(phi0);\n\n for (var j = 0; j < m; ++j, lambda0 = lambda1, sinPhi0 = sinPhi1, cosPhi0 = cosPhi1, point0 = point1) {\n var point1 = ring[j],\n lambda1 = longitude(point1),\n phi1 = point1[1] / 2 + quarterPi,\n sinPhi1 = sin(phi1),\n cosPhi1 = cos(phi1),\n delta = lambda1 - lambda0,\n sign = delta >= 0 ? 1 : -1,\n absDelta = sign * delta,\n antimeridian = absDelta > pi,\n k = sinPhi0 * sinPhi1;\n\n sum.add(atan2(k * sign * sin(absDelta), cosPhi0 * cosPhi1 + k * cos(absDelta)));\n angle += antimeridian ? delta + sign * tau : delta;\n\n // Are the longitudes either side of the point’s meridian (lambda),\n // and are the latitudes smaller than the parallel (phi)?\n if (antimeridian ^ lambda0 >= lambda ^ lambda1 >= lambda) {\n var arc = cartesianCross(cartesian(point0), cartesian(point1));\n cartesianNormalizeInPlace(arc);\n var intersection = cartesianCross(normal, arc);\n cartesianNormalizeInPlace(intersection);\n var phiArc = (antimeridian ^ delta >= 0 ? -1 : 1) * asin(intersection[2]);\n if (phi > phiArc || phi === phiArc && (arc[0] || arc[1])) {\n winding += antimeridian ^ delta >= 0 ? 1 : -1;\n }\n }\n }\n }\n\n // First, determine whether the South pole is inside or outside:\n //\n // It is inside if:\n // * the polygon winds around it in a clockwise direction.\n // * the polygon does not (cumulatively) wind around it, but has a negative\n // (counter-clockwise) area.\n //\n // Second, count the (signed) number of times a segment crosses a lambda\n // from the point to the South pole. If it is zero, then the point is the\n // same side as the South pole.\n\n return (angle < -epsilon || angle < epsilon && sum < -epsilon) ^ (winding & 1);\n}\n","import {asin, atan2, cos, sin, sqrt} from \"../math.js\";\n\nexport function azimuthalRaw(scale) {\n return function(x, y) {\n var cx = cos(x),\n cy = cos(y),\n k = scale(cx * cy);\n return [\n k * cy * sin(x),\n k * sin(y)\n ];\n }\n}\n\nexport function azimuthalInvert(angle) {\n return function(x, y) {\n var z = sqrt(x * x + y * y),\n c = angle(z),\n sc = sin(c),\n cc = cos(c);\n return [\n atan2(x * sc, z * cc),\n asin(z && y * sc / z)\n ];\n }\n}\n","import {asin, sqrt} from \"../math.js\";\nimport {azimuthalRaw, azimuthalInvert} from \"./azimuthal.js\";\nimport projection from \"./index.js\";\n\nexport var azimuthalEqualAreaRaw = azimuthalRaw(function(cxcy) {\n return sqrt(2 / (1 + cxcy));\n});\n\nazimuthalEqualAreaRaw.invert = azimuthalInvert(function(z) {\n return 2 * asin(z / 2);\n});\n\nexport default function() {\n return projection(azimuthalEqualAreaRaw)\n .scale(124.75)\n .clipAngle(180 - 1e-3);\n}\n","import {acos, sin} from \"../math.js\";\nimport {azimuthalRaw, azimuthalInvert} from \"./azimuthal.js\";\nimport projection from \"./index.js\";\n\nexport var azimuthalEquidistantRaw = azimuthalRaw(function(c) {\n return (c = acos(c)) && c / sin(c);\n});\n\nazimuthalEquidistantRaw.invert = azimuthalInvert(function(z) {\n return z;\n});\n\nexport default function() {\n return projection(azimuthalEquidistantRaw)\n .scale(79.4188)\n .clipAngle(180 - 1e-3);\n}\n","import projection from \"./index.js\";\n\nexport function equirectangularRaw(lambda, phi) {\n return [lambda, phi];\n}\n\nequirectangularRaw.invert = equirectangularRaw;\n\nexport default function() {\n return projection(equirectangularRaw)\n .scale(152.63);\n}\n","import {default as geoStream} from \"../stream.js\";\nimport boundsStream from \"../path/bounds.js\";\n\nfunction fit(projection, fitBounds, object) {\n var clip = projection.clipExtent && projection.clipExtent();\n projection.scale(150).translate([0, 0]);\n if (clip != null) projection.clipExtent(null);\n geoStream(object, projection.stream(boundsStream));\n fitBounds(boundsStream.result());\n if (clip != null) projection.clipExtent(clip);\n return projection;\n}\n\nexport function fitExtent(projection, extent, object) {\n return fit(projection, function(b) {\n var w = extent[1][0] - extent[0][0],\n h = extent[1][1] - extent[0][1],\n k = Math.min(w / (b[1][0] - b[0][0]), h / (b[1][1] - b[0][1])),\n x = +extent[0][0] + (w - k * (b[1][0] + b[0][0])) / 2,\n y = +extent[0][1] + (h - k * (b[1][1] + b[0][1])) / 2;\n projection.scale(150 * k).translate([x, y]);\n }, object);\n}\n\nexport function fitSize(projection, size, object) {\n return fitExtent(projection, [[0, 0], size], object);\n}\n\nexport function fitWidth(projection, width, object) {\n return fit(projection, function(b) {\n var w = +width,\n k = w / (b[1][0] - b[0][0]),\n x = (w - k * (b[1][0] + b[0][0])) / 2,\n y = -k * b[0][1];\n projection.scale(150 * k).translate([x, y]);\n }, object);\n}\n\nexport function fitHeight(projection, height, object) {\n return fit(projection, function(b) {\n var h = +height,\n k = h / (b[1][1] - b[0][1]),\n x = -k * b[0][0],\n y = (h - k * (b[1][1] + b[0][1])) / 2;\n projection.scale(150 * k).translate([x, y]);\n }, object);\n}\n","import {atan, cos, sin} from \"../math.js\";\nimport {azimuthalInvert} from \"./azimuthal.js\";\nimport projection from \"./index.js\";\n\nexport function gnomonicRaw(x, y) {\n var cy = cos(y), k = cos(x) * cy;\n return [cy * sin(x) / k, sin(y) / k];\n}\n\ngnomonicRaw.invert = azimuthalInvert(atan);\n\nexport default function() {\n return projection(gnomonicRaw)\n .scale(144.049)\n .clipAngle(60);\n}\n","import {cartesian} from \"../cartesian.js\";\nimport {abs, asin, atan2, cos, epsilon, radians, sqrt} from \"../math.js\";\nimport {transformer} from \"../transform.js\";\n\nvar maxDepth = 16, // maximum depth of subdivision\n cosMinDistance = cos(30 * radians); // cos(minimum angular distance)\n\nexport default function(project, delta2) {\n return +delta2 ? resample(project, delta2) : resampleNone(project);\n}\n\nfunction resampleNone(project) {\n return transformer({\n point: function(x, y) {\n x = project(x, y);\n this.stream.point(x[0], x[1]);\n }\n });\n}\n\nfunction resample(project, delta2) {\n\n function resampleLineTo(x0, y0, lambda0, a0, b0, c0, x1, y1, lambda1, a1, b1, c1, depth, stream) {\n var dx = x1 - x0,\n dy = y1 - y0,\n d2 = dx * dx + dy * dy;\n if (d2 > 4 * delta2 && depth--) {\n var a = a0 + a1,\n b = b0 + b1,\n c = c0 + c1,\n m = sqrt(a * a + b * b + c * c),\n phi2 = asin(c /= m),\n lambda2 = abs(abs(c) - 1) < epsilon || abs(lambda0 - lambda1) < epsilon ? (lambda0 + lambda1) / 2 : atan2(b, a),\n p = project(lambda2, phi2),\n x2 = p[0],\n y2 = p[1],\n dx2 = x2 - x0,\n dy2 = y2 - y0,\n dz = dy * dx2 - dx * dy2;\n if (dz * dz / d2 > delta2 // perpendicular projected distance\n || abs((dx * dx2 + dy * dy2) / d2 - 0.5) > 0.3 // midpoint close to an end\n || a0 * a1 + b0 * b1 + c0 * c1 < cosMinDistance) { // angular distance\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x2, y2, lambda2, a /= m, b /= m, c, depth, stream);\n stream.point(x2, y2);\n resampleLineTo(x2, y2, lambda2, a, b, c, x1, y1, lambda1, a1, b1, c1, depth, stream);\n }\n }\n }\n return function(stream) {\n var lambda00, x00, y00, a00, b00, c00, // first point\n lambda0, x0, y0, a0, b0, c0; // previous point\n\n var resampleStream = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: function() { stream.polygonStart(); resampleStream.lineStart = ringStart; },\n polygonEnd: function() { stream.polygonEnd(); resampleStream.lineStart = lineStart; }\n };\n\n function point(x, y) {\n x = project(x, y);\n stream.point(x[0], x[1]);\n }\n\n function lineStart() {\n x0 = NaN;\n resampleStream.point = linePoint;\n stream.lineStart();\n }\n\n function linePoint(lambda, phi) {\n var c = cartesian([lambda, phi]), p = project(lambda, phi);\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x0 = p[0], y0 = p[1], lambda0 = lambda, a0 = c[0], b0 = c[1], c0 = c[2], maxDepth, stream);\n stream.point(x0, y0);\n }\n\n function lineEnd() {\n resampleStream.point = point;\n stream.lineEnd();\n }\n\n function ringStart() {\n lineStart();\n resampleStream.point = ringPoint;\n resampleStream.lineEnd = ringEnd;\n }\n\n function ringPoint(lambda, phi) {\n linePoint(lambda00 = lambda, phi), x00 = x0, y00 = y0, a00 = a0, b00 = b0, c00 = c0;\n resampleStream.point = linePoint;\n }\n\n function ringEnd() {\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x00, y00, lambda00, a00, b00, c00, maxDepth, stream);\n resampleStream.lineEnd = lineEnd;\n lineEnd();\n }\n\n return resampleStream;\n };\n}\n","import clipAntimeridian from \"../clip/antimeridian.js\";\nimport clipCircle from \"../clip/circle.js\";\nimport clipRectangle from \"../clip/rectangle.js\";\nimport compose from \"../compose.js\";\nimport identity from \"../identity.js\";\nimport {cos, degrees, radians, sin, sqrt} from \"../math.js\";\nimport {rotateRadians} from \"../rotation.js\";\nimport {transformer} from \"../transform.js\";\nimport {fitExtent, fitSize, fitWidth, fitHeight} from \"./fit.js\";\nimport resample from \"./resample.js\";\n\nvar transformRadians = transformer({\n point: function(x, y) {\n this.stream.point(x * radians, y * radians);\n }\n});\n\nfunction transformRotate(rotate) {\n return transformer({\n point: function(x, y) {\n var r = rotate(x, y);\n return this.stream.point(r[0], r[1]);\n }\n });\n}\n\nfunction scaleTranslate(k, dx, dy, sx, sy) {\n function transform(x, y) {\n x *= sx; y *= sy;\n return [dx + k * x, dy - k * y];\n }\n transform.invert = function(x, y) {\n return [(x - dx) / k * sx, (dy - y) / k * sy];\n };\n return transform;\n}\n\nfunction scaleTranslateRotate(k, dx, dy, sx, sy, alpha) {\n var cosAlpha = cos(alpha),\n sinAlpha = sin(alpha),\n a = cosAlpha * k,\n b = sinAlpha * k,\n ai = cosAlpha / k,\n bi = sinAlpha / k,\n ci = (sinAlpha * dy - cosAlpha * dx) / k,\n fi = (sinAlpha * dx + cosAlpha * dy) / k;\n function transform(x, y) {\n x *= sx; y *= sy;\n return [a * x - b * y + dx, dy - b * x - a * y];\n }\n transform.invert = function(x, y) {\n return [sx * (ai * x - bi * y + ci), sy * (fi - bi * x - ai * y)];\n };\n return transform;\n}\n\nexport default function projection(project) {\n return projectionMutator(function() { return project; })();\n}\n\nexport function projectionMutator(projectAt) {\n var project,\n k = 150, // scale\n x = 480, y = 250, // translate\n lambda = 0, phi = 0, // center\n deltaLambda = 0, deltaPhi = 0, deltaGamma = 0, rotate, // pre-rotate\n alpha = 0, // post-rotate angle\n sx = 1, // reflectX\n sy = 1, // reflectX\n theta = null, preclip = clipAntimeridian, // pre-clip angle\n x0 = null, y0, x1, y1, postclip = identity, // post-clip extent\n delta2 = 0.5, // precision\n projectResample,\n projectTransform,\n projectRotateTransform,\n cache,\n cacheStream;\n\n function projection(point) {\n return projectRotateTransform(point[0] * radians, point[1] * radians);\n }\n\n function invert(point) {\n point = projectRotateTransform.invert(point[0], point[1]);\n return point && [point[0] * degrees, point[1] * degrees];\n }\n\n projection.stream = function(stream) {\n return cache && cacheStream === stream ? cache : cache = transformRadians(transformRotate(rotate)(preclip(projectResample(postclip(cacheStream = stream)))));\n };\n\n projection.preclip = function(_) {\n return arguments.length ? (preclip = _, theta = undefined, reset()) : preclip;\n };\n\n projection.postclip = function(_) {\n return arguments.length ? (postclip = _, x0 = y0 = x1 = y1 = null, reset()) : postclip;\n };\n\n projection.clipAngle = function(_) {\n return arguments.length ? (preclip = +_ ? clipCircle(theta = _ * radians) : (theta = null, clipAntimeridian), reset()) : theta * degrees;\n };\n\n projection.clipExtent = function(_) {\n return arguments.length ? (postclip = _ == null ? (x0 = y0 = x1 = y1 = null, identity) : clipRectangle(x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1]), reset()) : x0 == null ? null : [[x0, y0], [x1, y1]];\n };\n\n projection.scale = function(_) {\n return arguments.length ? (k = +_, recenter()) : k;\n };\n\n projection.translate = function(_) {\n return arguments.length ? (x = +_[0], y = +_[1], recenter()) : [x, y];\n };\n\n projection.center = function(_) {\n return arguments.length ? (lambda = _[0] % 360 * radians, phi = _[1] % 360 * radians, recenter()) : [lambda * degrees, phi * degrees];\n };\n\n projection.rotate = function(_) {\n return arguments.length ? (deltaLambda = _[0] % 360 * radians, deltaPhi = _[1] % 360 * radians, deltaGamma = _.length > 2 ? _[2] % 360 * radians : 0, recenter()) : [deltaLambda * degrees, deltaPhi * degrees, deltaGamma * degrees];\n };\n\n projection.angle = function(_) {\n return arguments.length ? (alpha = _ % 360 * radians, recenter()) : alpha * degrees;\n };\n\n projection.reflectX = function(_) {\n return arguments.length ? (sx = _ ? -1 : 1, recenter()) : sx < 0;\n };\n\n projection.reflectY = function(_) {\n return arguments.length ? (sy = _ ? -1 : 1, recenter()) : sy < 0;\n };\n\n projection.precision = function(_) {\n return arguments.length ? (projectResample = resample(projectTransform, delta2 = _ * _), reset()) : sqrt(delta2);\n };\n\n projection.fitExtent = function(extent, object) {\n return fitExtent(projection, extent, object);\n };\n\n projection.fitSize = function(size, object) {\n return fitSize(projection, size, object);\n };\n\n projection.fitWidth = function(width, object) {\n return fitWidth(projection, width, object);\n };\n\n projection.fitHeight = function(height, object) {\n return fitHeight(projection, height, object);\n };\n\n function recenter() {\n var center = scaleTranslateRotate(k, 0, 0, sx, sy, alpha).apply(null, project(lambda, phi)),\n transform = (alpha ? scaleTranslateRotate : scaleTranslate)(k, x - center[0], y - center[1], sx, sy, alpha);\n rotate = rotateRadians(deltaLambda, deltaPhi, deltaGamma);\n projectTransform = compose(project, transform);\n projectRotateTransform = compose(rotate, projectTransform);\n projectResample = resample(projectTransform, delta2);\n return reset();\n }\n\n function reset() {\n cache = cacheStream = null;\n return projection;\n }\n\n return function() {\n project = projectAt.apply(this, arguments);\n projection.invert = project.invert && invert;\n return recenter();\n };\n}\n","import projection from \"./index.js\";\nimport {abs, epsilon} from \"../math.js\";\n\nexport function naturalEarth1Raw(lambda, phi) {\n var phi2 = phi * phi, phi4 = phi2 * phi2;\n return [\n lambda * (0.8707 - 0.131979 * phi2 + phi4 * (-0.013791 + phi4 * (0.003971 * phi2 - 0.001529 * phi4))),\n phi * (1.007226 + phi2 * (0.015085 + phi4 * (-0.044475 + 0.028874 * phi2 - 0.005916 * phi4)))\n ];\n}\n\nnaturalEarth1Raw.invert = function(x, y) {\n var phi = y, i = 25, delta;\n do {\n var phi2 = phi * phi, phi4 = phi2 * phi2;\n phi -= delta = (phi * (1.007226 + phi2 * (0.015085 + phi4 * (-0.044475 + 0.028874 * phi2 - 0.005916 * phi4))) - y) /\n (1.007226 + phi2 * (0.015085 * 3 + phi4 * (-0.044475 * 7 + 0.028874 * 9 * phi2 - 0.005916 * 11 * phi4)));\n } while (abs(delta) > epsilon && --i > 0);\n return [\n x / (0.8707 + (phi2 = phi * phi) * (-0.131979 + phi2 * (-0.013791 + phi2 * phi2 * phi2 * (0.003971 - 0.001529 * phi2)))),\n phi\n ];\n};\n\nexport default function() {\n return projection(naturalEarth1Raw)\n .scale(175.295);\n}\n","import {asin, cos, epsilon, sin} from \"../math.js\";\nimport {azimuthalInvert} from \"./azimuthal.js\";\nimport projection from \"./index.js\";\n\nexport function orthographicRaw(x, y) {\n return [cos(y) * sin(x), sin(y)];\n}\n\northographicRaw.invert = azimuthalInvert(asin);\n\nexport default function() {\n return projection(orthographicRaw)\n .scale(249.5)\n .clipAngle(90 + epsilon);\n}\n","import compose from \"./compose.js\";\nimport {abs, asin, atan2, cos, degrees, pi, radians, sin, tau} from \"./math.js\";\n\nfunction rotationIdentity(lambda, phi) {\n return [abs(lambda) > pi ? lambda + Math.round(-lambda / tau) * tau : lambda, phi];\n}\n\nrotationIdentity.invert = rotationIdentity;\n\nexport function rotateRadians(deltaLambda, deltaPhi, deltaGamma) {\n return (deltaLambda %= tau) ? (deltaPhi || deltaGamma ? compose(rotationLambda(deltaLambda), rotationPhiGamma(deltaPhi, deltaGamma))\n : rotationLambda(deltaLambda))\n : (deltaPhi || deltaGamma ? rotationPhiGamma(deltaPhi, deltaGamma)\n : rotationIdentity);\n}\n\nfunction forwardRotationLambda(deltaLambda) {\n return function(lambda, phi) {\n return lambda += deltaLambda, [lambda > pi ? lambda - tau : lambda < -pi ? lambda + tau : lambda, phi];\n };\n}\n\nfunction rotationLambda(deltaLambda) {\n var rotation = forwardRotationLambda(deltaLambda);\n rotation.invert = forwardRotationLambda(-deltaLambda);\n return rotation;\n}\n\nfunction rotationPhiGamma(deltaPhi, deltaGamma) {\n var cosDeltaPhi = cos(deltaPhi),\n sinDeltaPhi = sin(deltaPhi),\n cosDeltaGamma = cos(deltaGamma),\n sinDeltaGamma = sin(deltaGamma);\n\n function rotation(lambda, phi) {\n var cosPhi = cos(phi),\n x = cos(lambda) * cosPhi,\n y = sin(lambda) * cosPhi,\n z = sin(phi),\n k = z * cosDeltaPhi + x * sinDeltaPhi;\n return [\n atan2(y * cosDeltaGamma - k * sinDeltaGamma, x * cosDeltaPhi - z * sinDeltaPhi),\n asin(k * cosDeltaGamma + y * sinDeltaGamma)\n ];\n }\n\n rotation.invert = function(lambda, phi) {\n var cosPhi = cos(phi),\n x = cos(lambda) * cosPhi,\n y = sin(lambda) * cosPhi,\n z = sin(phi),\n k = z * cosDeltaGamma - y * sinDeltaGamma;\n return [\n atan2(y * cosDeltaGamma + z * sinDeltaGamma, x * cosDeltaPhi + k * sinDeltaPhi),\n asin(k * cosDeltaPhi - x * sinDeltaPhi)\n ];\n };\n\n return rotation;\n}\n\nexport default function(rotate) {\n rotate = rotateRadians(rotate[0] * radians, rotate[1] * radians, rotate.length > 2 ? rotate[2] * radians : 0);\n\n function forward(coordinates) {\n coordinates = rotate(coordinates[0] * radians, coordinates[1] * radians);\n return coordinates[0] *= degrees, coordinates[1] *= degrees, coordinates;\n }\n\n forward.invert = function(coordinates) {\n coordinates = rotate.invert(coordinates[0] * radians, coordinates[1] * radians);\n return coordinates[0] *= degrees, coordinates[1] *= degrees, coordinates;\n };\n\n return forward;\n}\n","function streamGeometry(geometry, stream) {\n if (geometry && streamGeometryType.hasOwnProperty(geometry.type)) {\n streamGeometryType[geometry.type](geometry, stream);\n }\n}\n\nvar streamObjectType = {\n Feature: function(object, stream) {\n streamGeometry(object.geometry, stream);\n },\n FeatureCollection: function(object, stream) {\n var features = object.features, i = -1, n = features.length;\n while (++i < n) streamGeometry(features[i].geometry, stream);\n }\n};\n\nvar streamGeometryType = {\n Sphere: function(object, stream) {\n stream.sphere();\n },\n Point: function(object, stream) {\n object = object.coordinates;\n stream.point(object[0], object[1], object[2]);\n },\n MultiPoint: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) object = coordinates[i], stream.point(object[0], object[1], object[2]);\n },\n LineString: function(object, stream) {\n streamLine(object.coordinates, stream, 0);\n },\n MultiLineString: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) streamLine(coordinates[i], stream, 0);\n },\n Polygon: function(object, stream) {\n streamPolygon(object.coordinates, stream);\n },\n MultiPolygon: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) streamPolygon(coordinates[i], stream);\n },\n GeometryCollection: function(object, stream) {\n var geometries = object.geometries, i = -1, n = geometries.length;\n while (++i < n) streamGeometry(geometries[i], stream);\n }\n};\n\nfunction streamLine(coordinates, stream, closed) {\n var i = -1, n = coordinates.length - closed, coordinate;\n stream.lineStart();\n while (++i < n) coordinate = coordinates[i], stream.point(coordinate[0], coordinate[1], coordinate[2]);\n stream.lineEnd();\n}\n\nfunction streamPolygon(coordinates, stream) {\n var i = -1, n = coordinates.length;\n stream.polygonStart();\n while (++i < n) streamLine(coordinates[i], stream, 1);\n stream.polygonEnd();\n}\n\nexport default function(object, stream) {\n if (object && streamObjectType.hasOwnProperty(object.type)) {\n streamObjectType[object.type](object, stream);\n } else {\n streamGeometry(object, stream);\n }\n}\n","export default function(methods) {\n return {\n stream: transformer(methods)\n };\n}\n\nexport function transformer(methods) {\n return function(stream) {\n var s = new TransformStream;\n for (var key in methods) s[key] = methods[key];\n s.stream = stream;\n return s;\n };\n}\n\nfunction TransformStream() {}\n\nTransformStream.prototype = {\n constructor: TransformStream,\n point: function(x, y) { this.stream.point(x, y); },\n sphere: function() { this.stream.sphere(); },\n lineStart: function() { this.stream.lineStart(); },\n lineEnd: function() { this.stream.lineEnd(); },\n polygonStart: function() { this.stream.polygonStart(); },\n polygonEnd: function() { this.stream.polygonEnd(); }\n};\n","function defaultSeparation(a, b) {\n return a.parent === b.parent ? 1 : 2;\n}\n\nfunction meanX(children) {\n return children.reduce(meanXReduce, 0) / children.length;\n}\n\nfunction meanXReduce(x, c) {\n return x + c.x;\n}\n\nfunction maxY(children) {\n return 1 + children.reduce(maxYReduce, 0);\n}\n\nfunction maxYReduce(y, c) {\n return Math.max(y, c.y);\n}\n\nfunction leafLeft(node) {\n var children;\n while (children = node.children) node = children[0];\n return node;\n}\n\nfunction leafRight(node) {\n var children;\n while (children = node.children) node = children[children.length - 1];\n return node;\n}\n\nexport default function() {\n var separation = defaultSeparation,\n dx = 1,\n dy = 1,\n nodeSize = false;\n\n function cluster(root) {\n var previousNode,\n x = 0;\n\n // First walk, computing the initial x & y values.\n root.eachAfter(function(node) {\n var children = node.children;\n if (children) {\n node.x = meanX(children);\n node.y = maxY(children);\n } else {\n node.x = previousNode ? x += separation(node, previousNode) : 0;\n node.y = 0;\n previousNode = node;\n }\n });\n\n var left = leafLeft(root),\n right = leafRight(root),\n x0 = left.x - separation(left, right) / 2,\n x1 = right.x + separation(right, left) / 2;\n\n // Second walk, normalizing x & y to the desired size.\n return root.eachAfter(nodeSize ? function(node) {\n node.x = (node.x - root.x) * dx;\n node.y = (root.y - node.y) * dy;\n } : function(node) {\n node.x = (node.x - x0) / (x1 - x0) * dx;\n node.y = (1 - (root.y ? node.y / root.y : 1)) * dy;\n });\n }\n\n cluster.separation = function(x) {\n return arguments.length ? (separation = x, cluster) : separation;\n };\n\n cluster.size = function(x) {\n return arguments.length ? (nodeSize = false, dx = +x[0], dy = +x[1], cluster) : (nodeSize ? null : [dx, dy]);\n };\n\n cluster.nodeSize = function(x) {\n return arguments.length ? (nodeSize = true, dx = +x[0], dy = +x[1], cluster) : (nodeSize ? [dx, dy] : null);\n };\n\n return cluster;\n}\n","function count(node) {\n var sum = 0,\n children = node.children,\n i = children && children.length;\n if (!i) sum = 1;\n else while (--i >= 0) sum += children[i].value;\n node.value = sum;\n}\n\nexport default function() {\n return this.eachAfter(count);\n}\n","import node_count from \"./count.js\";\nimport node_each from \"./each.js\";\nimport node_eachBefore from \"./eachBefore.js\";\nimport node_eachAfter from \"./eachAfter.js\";\nimport node_sum from \"./sum.js\";\nimport node_sort from \"./sort.js\";\nimport node_path from \"./path.js\";\nimport node_ancestors from \"./ancestors.js\";\nimport node_descendants from \"./descendants.js\";\nimport node_leaves from \"./leaves.js\";\nimport node_links from \"./links.js\";\n\nexport default function hierarchy(data, children) {\n var root = new Node(data),\n valued = +data.value && (root.value = data.value),\n node,\n nodes = [root],\n child,\n childs,\n i,\n n;\n\n if (children == null) children = defaultChildren;\n\n while (node = nodes.pop()) {\n if (valued) node.value = +node.data.value;\n if ((childs = children(node.data)) && (n = childs.length)) {\n node.children = new Array(n);\n for (i = n - 1; i >= 0; --i) {\n nodes.push(child = node.children[i] = new Node(childs[i]));\n child.parent = node;\n child.depth = node.depth + 1;\n }\n }\n }\n\n return root.eachBefore(computeHeight);\n}\n\nfunction node_copy() {\n return hierarchy(this).eachBefore(copyData);\n}\n\nfunction defaultChildren(d) {\n return d.children;\n}\n\nfunction copyData(node) {\n node.data = node.data.data;\n}\n\nexport function computeHeight(node) {\n var height = 0;\n do node.height = height;\n while ((node = node.parent) && (node.height < ++height));\n}\n\nexport function Node(data) {\n this.data = data;\n this.depth =\n this.height = 0;\n this.parent = null;\n}\n\nNode.prototype = hierarchy.prototype = {\n constructor: Node,\n count: node_count,\n each: node_each,\n eachAfter: node_eachAfter,\n eachBefore: node_eachBefore,\n sum: node_sum,\n sort: node_sort,\n path: node_path,\n ancestors: node_ancestors,\n descendants: node_descendants,\n leaves: node_leaves,\n links: node_links,\n copy: node_copy\n};\n","export default function(callback) {\n var node = this, current, next = [node], children, i, n;\n do {\n current = next.reverse(), next = [];\n while (node = current.pop()) {\n callback(node), children = node.children;\n if (children) for (i = 0, n = children.length; i < n; ++i) {\n next.push(children[i]);\n }\n }\n } while (next.length);\n return this;\n}\n","export default function(callback) {\n var node = this, nodes = [node], next = [], children, i, n;\n while (node = nodes.pop()) {\n next.push(node), children = node.children;\n if (children) for (i = 0, n = children.length; i < n; ++i) {\n nodes.push(children[i]);\n }\n }\n while (node = next.pop()) {\n callback(node);\n }\n return this;\n}\n","export default function(callback) {\n var node = this, nodes = [node], children, i;\n while (node = nodes.pop()) {\n callback(node), children = node.children;\n if (children) for (i = children.length - 1; i >= 0; --i) {\n nodes.push(children[i]);\n }\n }\n return this;\n}\n","export default function(value) {\n return this.eachAfter(function(node) {\n var sum = +value(node.data) || 0,\n children = node.children,\n i = children && children.length;\n while (--i >= 0) sum += children[i].value;\n node.value = sum;\n });\n}\n","export default function(compare) {\n return this.eachBefore(function(node) {\n if (node.children) {\n node.children.sort(compare);\n }\n });\n}\n","export default function(end) {\n var start = this,\n ancestor = leastCommonAncestor(start, end),\n nodes = [start];\n while (start !== ancestor) {\n start = start.parent;\n nodes.push(start);\n }\n var k = nodes.length;\n while (end !== ancestor) {\n nodes.splice(k, 0, end);\n end = end.parent;\n }\n return nodes;\n}\n\nfunction leastCommonAncestor(a, b) {\n if (a === b) return a;\n var aNodes = a.ancestors(),\n bNodes = b.ancestors(),\n c = null;\n a = aNodes.pop();\n b = bNodes.pop();\n while (a === b) {\n c = a;\n a = aNodes.pop();\n b = bNodes.pop();\n }\n return c;\n}\n","export default function() {\n var node = this, nodes = [node];\n while (node = node.parent) {\n nodes.push(node);\n }\n return nodes;\n}\n","export default function() {\n var nodes = [];\n this.each(function(node) {\n nodes.push(node);\n });\n return nodes;\n}\n","export default function() {\n var leaves = [];\n this.eachBefore(function(node) {\n if (!node.children) {\n leaves.push(node);\n }\n });\n return leaves;\n}\n","export default function() {\n var root = this, links = [];\n root.each(function(node) {\n if (node !== root) { // Don’t include the root’s parent, if any.\n links.push({source: node.parent, target: node});\n }\n });\n return links;\n}\n","export var slice = Array.prototype.slice;\n\nexport function shuffle(array) {\n var m = array.length,\n t,\n i;\n\n while (m) {\n i = Math.random() * m-- | 0;\n t = array[m];\n array[m] = array[i];\n array[i] = t;\n }\n\n return array;\n}\n","import {shuffle, slice} from \"../array.js\";\n\nexport default function(circles) {\n var i = 0, n = (circles = shuffle(slice.call(circles))).length, B = [], p, e;\n\n while (i < n) {\n p = circles[i];\n if (e && enclosesWeak(e, p)) ++i;\n else e = encloseBasis(B = extendBasis(B, p)), i = 0;\n }\n\n return e;\n}\n\nfunction extendBasis(B, p) {\n var i, j;\n\n if (enclosesWeakAll(p, B)) return [p];\n\n // If we get here then B must have at least one element.\n for (i = 0; i < B.length; ++i) {\n if (enclosesNot(p, B[i])\n && enclosesWeakAll(encloseBasis2(B[i], p), B)) {\n return [B[i], p];\n }\n }\n\n // If we get here then B must have at least two elements.\n for (i = 0; i < B.length - 1; ++i) {\n for (j = i + 1; j < B.length; ++j) {\n if (enclosesNot(encloseBasis2(B[i], B[j]), p)\n && enclosesNot(encloseBasis2(B[i], p), B[j])\n && enclosesNot(encloseBasis2(B[j], p), B[i])\n && enclosesWeakAll(encloseBasis3(B[i], B[j], p), B)) {\n return [B[i], B[j], p];\n }\n }\n }\n\n // If we get here then something is very wrong.\n throw new Error;\n}\n\nfunction enclosesNot(a, b) {\n var dr = a.r - b.r, dx = b.x - a.x, dy = b.y - a.y;\n return dr < 0 || dr * dr < dx * dx + dy * dy;\n}\n\nfunction enclosesWeak(a, b) {\n var dr = a.r - b.r + 1e-6, dx = b.x - a.x, dy = b.y - a.y;\n return dr > 0 && dr * dr > dx * dx + dy * dy;\n}\n\nfunction enclosesWeakAll(a, B) {\n for (var i = 0; i < B.length; ++i) {\n if (!enclosesWeak(a, B[i])) {\n return false;\n }\n }\n return true;\n}\n\nfunction encloseBasis(B) {\n switch (B.length) {\n case 1: return encloseBasis1(B[0]);\n case 2: return encloseBasis2(B[0], B[1]);\n case 3: return encloseBasis3(B[0], B[1], B[2]);\n }\n}\n\nfunction encloseBasis1(a) {\n return {\n x: a.x,\n y: a.y,\n r: a.r\n };\n}\n\nfunction encloseBasis2(a, b) {\n var x1 = a.x, y1 = a.y, r1 = a.r,\n x2 = b.x, y2 = b.y, r2 = b.r,\n x21 = x2 - x1, y21 = y2 - y1, r21 = r2 - r1,\n l = Math.sqrt(x21 * x21 + y21 * y21);\n return {\n x: (x1 + x2 + x21 / l * r21) / 2,\n y: (y1 + y2 + y21 / l * r21) / 2,\n r: (l + r1 + r2) / 2\n };\n}\n\nfunction encloseBasis3(a, b, c) {\n var x1 = a.x, y1 = a.y, r1 = a.r,\n x2 = b.x, y2 = b.y, r2 = b.r,\n x3 = c.x, y3 = c.y, r3 = c.r,\n a2 = x1 - x2,\n a3 = x1 - x3,\n b2 = y1 - y2,\n b3 = y1 - y3,\n c2 = r2 - r1,\n c3 = r3 - r1,\n d1 = x1 * x1 + y1 * y1 - r1 * r1,\n d2 = d1 - x2 * x2 - y2 * y2 + r2 * r2,\n d3 = d1 - x3 * x3 - y3 * y3 + r3 * r3,\n ab = a3 * b2 - a2 * b3,\n xa = (b2 * d3 - b3 * d2) / (ab * 2) - x1,\n xb = (b3 * c2 - b2 * c3) / ab,\n ya = (a3 * d2 - a2 * d3) / (ab * 2) - y1,\n yb = (a2 * c3 - a3 * c2) / ab,\n A = xb * xb + yb * yb - 1,\n B = 2 * (r1 + xa * xb + ya * yb),\n C = xa * xa + ya * ya - r1 * r1,\n r = -(A ? (B + Math.sqrt(B * B - 4 * A * C)) / (2 * A) : C / B);\n return {\n x: x1 + xa + xb * r,\n y: y1 + ya + yb * r,\n r: r\n };\n}\n","import enclose from \"./enclose.js\";\n\nfunction place(b, a, c) {\n var dx = b.x - a.x, x, a2,\n dy = b.y - a.y, y, b2,\n d2 = dx * dx + dy * dy;\n if (d2) {\n a2 = a.r + c.r, a2 *= a2;\n b2 = b.r + c.r, b2 *= b2;\n if (a2 > b2) {\n x = (d2 + b2 - a2) / (2 * d2);\n y = Math.sqrt(Math.max(0, b2 / d2 - x * x));\n c.x = b.x - x * dx - y * dy;\n c.y = b.y - x * dy + y * dx;\n } else {\n x = (d2 + a2 - b2) / (2 * d2);\n y = Math.sqrt(Math.max(0, a2 / d2 - x * x));\n c.x = a.x + x * dx - y * dy;\n c.y = a.y + x * dy + y * dx;\n }\n } else {\n c.x = a.x + c.r;\n c.y = a.y;\n }\n}\n\nfunction intersects(a, b) {\n var dr = a.r + b.r - 1e-6, dx = b.x - a.x, dy = b.y - a.y;\n return dr > 0 && dr * dr > dx * dx + dy * dy;\n}\n\nfunction score(node) {\n var a = node._,\n b = node.next._,\n ab = a.r + b.r,\n dx = (a.x * b.r + b.x * a.r) / ab,\n dy = (a.y * b.r + b.y * a.r) / ab;\n return dx * dx + dy * dy;\n}\n\nfunction Node(circle) {\n this._ = circle;\n this.next = null;\n this.previous = null;\n}\n\nexport function packEnclose(circles) {\n if (!(n = circles.length)) return 0;\n\n var a, b, c, n, aa, ca, i, j, k, sj, sk;\n\n // Place the first circle.\n a = circles[0], a.x = 0, a.y = 0;\n if (!(n > 1)) return a.r;\n\n // Place the second circle.\n b = circles[1], a.x = -b.r, b.x = a.r, b.y = 0;\n if (!(n > 2)) return a.r + b.r;\n\n // Place the third circle.\n place(b, a, c = circles[2]);\n\n // Initialize the front-chain using the first three circles a, b and c.\n a = new Node(a), b = new Node(b), c = new Node(c);\n a.next = c.previous = b;\n b.next = a.previous = c;\n c.next = b.previous = a;\n\n // Attempt to place each remaining circle…\n pack: for (i = 3; i < n; ++i) {\n place(a._, b._, c = circles[i]), c = new Node(c);\n\n // Find the closest intersecting circle on the front-chain, if any.\n // “Closeness” is determined by linear distance along the front-chain.\n // “Ahead” or “behind” is likewise determined by linear distance.\n j = b.next, k = a.previous, sj = b._.r, sk = a._.r;\n do {\n if (sj <= sk) {\n if (intersects(j._, c._)) {\n b = j, a.next = b, b.previous = a, --i;\n continue pack;\n }\n sj += j._.r, j = j.next;\n } else {\n if (intersects(k._, c._)) {\n a = k, a.next = b, b.previous = a, --i;\n continue pack;\n }\n sk += k._.r, k = k.previous;\n }\n } while (j !== k.next);\n\n // Success! Insert the new circle c between a and b.\n c.previous = a, c.next = b, a.next = b.previous = b = c;\n\n // Compute the new closest circle pair to the centroid.\n aa = score(a);\n while ((c = c.next) !== b) {\n if ((ca = score(c)) < aa) {\n a = c, aa = ca;\n }\n }\n b = a.next;\n }\n\n // Compute the enclosing circle of the front chain.\n a = [b._], c = b; while ((c = c.next) !== b) a.push(c._); c = enclose(a);\n\n // Translate the circles to put the enclosing circle around the origin.\n for (i = 0; i < n; ++i) a = circles[i], a.x -= c.x, a.y -= c.y;\n\n return c.r;\n}\n\nexport default function(circles) {\n packEnclose(circles);\n return circles;\n}\n","export function optional(f) {\n return f == null ? null : required(f);\n}\n\nexport function required(f) {\n if (typeof f !== \"function\") throw new Error;\n return f;\n}\n","export function constantZero() {\n return 0;\n}\n\nexport default function(x) {\n return function() {\n return x;\n };\n}\n","import {packEnclose} from \"./siblings.js\";\nimport {optional} from \"../accessors.js\";\nimport constant, {constantZero} from \"../constant.js\";\n\nfunction defaultRadius(d) {\n return Math.sqrt(d.value);\n}\n\nexport default function() {\n var radius = null,\n dx = 1,\n dy = 1,\n padding = constantZero;\n\n function pack(root) {\n root.x = dx / 2, root.y = dy / 2;\n if (radius) {\n root.eachBefore(radiusLeaf(radius))\n .eachAfter(packChildren(padding, 0.5))\n .eachBefore(translateChild(1));\n } else {\n root.eachBefore(radiusLeaf(defaultRadius))\n .eachAfter(packChildren(constantZero, 1))\n .eachAfter(packChildren(padding, root.r / Math.min(dx, dy)))\n .eachBefore(translateChild(Math.min(dx, dy) / (2 * root.r)));\n }\n return root;\n }\n\n pack.radius = function(x) {\n return arguments.length ? (radius = optional(x), pack) : radius;\n };\n\n pack.size = function(x) {\n return arguments.length ? (dx = +x[0], dy = +x[1], pack) : [dx, dy];\n };\n\n pack.padding = function(x) {\n return arguments.length ? (padding = typeof x === \"function\" ? x : constant(+x), pack) : padding;\n };\n\n return pack;\n}\n\nfunction radiusLeaf(radius) {\n return function(node) {\n if (!node.children) {\n node.r = Math.max(0, +radius(node) || 0);\n }\n };\n}\n\nfunction packChildren(padding, k) {\n return function(node) {\n if (children = node.children) {\n var children,\n i,\n n = children.length,\n r = padding(node) * k || 0,\n e;\n\n if (r) for (i = 0; i < n; ++i) children[i].r += r;\n e = packEnclose(children);\n if (r) for (i = 0; i < n; ++i) children[i].r -= r;\n node.r = e + r;\n }\n };\n}\n\nfunction translateChild(k) {\n return function(node) {\n var parent = node.parent;\n node.r *= k;\n if (parent) {\n node.x = parent.x + k * node.x;\n node.y = parent.y + k * node.y;\n }\n };\n}\n","export default function(node) {\n node.x0 = Math.round(node.x0);\n node.y0 = Math.round(node.y0);\n node.x1 = Math.round(node.x1);\n node.y1 = Math.round(node.y1);\n}\n","export default function(parent, x0, y0, x1, y1) {\n var nodes = parent.children,\n node,\n i = -1,\n n = nodes.length,\n k = parent.value && (x1 - x0) / parent.value;\n\n while (++i < n) {\n node = nodes[i], node.y0 = y0, node.y1 = y1;\n node.x0 = x0, node.x1 = x0 += node.value * k;\n }\n}\n","import roundNode from \"./treemap/round.js\";\nimport treemapDice from \"./treemap/dice.js\";\n\nexport default function() {\n var dx = 1,\n dy = 1,\n padding = 0,\n round = false;\n\n function partition(root) {\n var n = root.height + 1;\n root.x0 =\n root.y0 = padding;\n root.x1 = dx;\n root.y1 = dy / n;\n root.eachBefore(positionNode(dy, n));\n if (round) root.eachBefore(roundNode);\n return root;\n }\n\n function positionNode(dy, n) {\n return function(node) {\n if (node.children) {\n treemapDice(node, node.x0, dy * (node.depth + 1) / n, node.x1, dy * (node.depth + 2) / n);\n }\n var x0 = node.x0,\n y0 = node.y0,\n x1 = node.x1 - padding,\n y1 = node.y1 - padding;\n if (x1 < x0) x0 = x1 = (x0 + x1) / 2;\n if (y1 < y0) y0 = y1 = (y0 + y1) / 2;\n node.x0 = x0;\n node.y0 = y0;\n node.x1 = x1;\n node.y1 = y1;\n };\n }\n\n partition.round = function(x) {\n return arguments.length ? (round = !!x, partition) : round;\n };\n\n partition.size = function(x) {\n return arguments.length ? (dx = +x[0], dy = +x[1], partition) : [dx, dy];\n };\n\n partition.padding = function(x) {\n return arguments.length ? (padding = +x, partition) : padding;\n };\n\n return partition;\n}\n","import {required} from \"./accessors.js\";\nimport {Node, computeHeight} from \"./hierarchy/index.js\";\n\nvar keyPrefix = \"$\", // Protect against keys like “__proto__”.\n preroot = {depth: -1},\n ambiguous = {};\n\nfunction defaultId(d) {\n return d.id;\n}\n\nfunction defaultParentId(d) {\n return d.parentId;\n}\n\nexport default function() {\n var id = defaultId,\n parentId = defaultParentId;\n\n function stratify(data) {\n var d,\n i,\n n = data.length,\n root,\n parent,\n node,\n nodes = new Array(n),\n nodeId,\n nodeKey,\n nodeByKey = {};\n\n for (i = 0; i < n; ++i) {\n d = data[i], node = nodes[i] = new Node(d);\n if ((nodeId = id(d, i, data)) != null && (nodeId += \"\")) {\n nodeKey = keyPrefix + (node.id = nodeId);\n nodeByKey[nodeKey] = nodeKey in nodeByKey ? ambiguous : node;\n }\n }\n\n for (i = 0; i < n; ++i) {\n node = nodes[i], nodeId = parentId(data[i], i, data);\n if (nodeId == null || !(nodeId += \"\")) {\n if (root) throw new Error(\"multiple roots\");\n root = node;\n } else {\n parent = nodeByKey[keyPrefix + nodeId];\n if (!parent) throw new Error(\"missing: \" + nodeId);\n if (parent === ambiguous) throw new Error(\"ambiguous: \" + nodeId);\n if (parent.children) parent.children.push(node);\n else parent.children = [node];\n node.parent = parent;\n }\n }\n\n if (!root) throw new Error(\"no root\");\n root.parent = preroot;\n root.eachBefore(function(node) { node.depth = node.parent.depth + 1; --n; }).eachBefore(computeHeight);\n root.parent = null;\n if (n > 0) throw new Error(\"cycle\");\n\n return root;\n }\n\n stratify.id = function(x) {\n return arguments.length ? (id = required(x), stratify) : id;\n };\n\n stratify.parentId = function(x) {\n return arguments.length ? (parentId = required(x), stratify) : parentId;\n };\n\n return stratify;\n}\n","import {Node} from \"./hierarchy/index.js\";\n\nfunction defaultSeparation(a, b) {\n return a.parent === b.parent ? 1 : 2;\n}\n\n// function radialSeparation(a, b) {\n// return (a.parent === b.parent ? 1 : 2) / a.depth;\n// }\n\n// This function is used to traverse the left contour of a subtree (or\n// subforest). It returns the successor of v on this contour. This successor is\n// either given by the leftmost child of v or by the thread of v. The function\n// returns null if and only if v is on the highest level of its subtree.\nfunction nextLeft(v) {\n var children = v.children;\n return children ? children[0] : v.t;\n}\n\n// This function works analogously to nextLeft.\nfunction nextRight(v) {\n var children = v.children;\n return children ? children[children.length - 1] : v.t;\n}\n\n// Shifts the current subtree rooted at w+. This is done by increasing\n// prelim(w+) and mod(w+) by shift.\nfunction moveSubtree(wm, wp, shift) {\n var change = shift / (wp.i - wm.i);\n wp.c -= change;\n wp.s += shift;\n wm.c += change;\n wp.z += shift;\n wp.m += shift;\n}\n\n// All other shifts, applied to the smaller subtrees between w- and w+, are\n// performed by this function. To prepare the shifts, we have to adjust\n// change(w+), shift(w+), and change(w-).\nfunction executeShifts(v) {\n var shift = 0,\n change = 0,\n children = v.children,\n i = children.length,\n w;\n while (--i >= 0) {\n w = children[i];\n w.z += shift;\n w.m += shift;\n shift += w.s + (change += w.c);\n }\n}\n\n// If vi-’s ancestor is a sibling of v, returns vi-’s ancestor. Otherwise,\n// returns the specified (default) ancestor.\nfunction nextAncestor(vim, v, ancestor) {\n return vim.a.parent === v.parent ? vim.a : ancestor;\n}\n\nfunction TreeNode(node, i) {\n this._ = node;\n this.parent = null;\n this.children = null;\n this.A = null; // default ancestor\n this.a = this; // ancestor\n this.z = 0; // prelim\n this.m = 0; // mod\n this.c = 0; // change\n this.s = 0; // shift\n this.t = null; // thread\n this.i = i; // number\n}\n\nTreeNode.prototype = Object.create(Node.prototype);\n\nfunction treeRoot(root) {\n var tree = new TreeNode(root, 0),\n node,\n nodes = [tree],\n child,\n children,\n i,\n n;\n\n while (node = nodes.pop()) {\n if (children = node._.children) {\n node.children = new Array(n = children.length);\n for (i = n - 1; i >= 0; --i) {\n nodes.push(child = node.children[i] = new TreeNode(children[i], i));\n child.parent = node;\n }\n }\n }\n\n (tree.parent = new TreeNode(null, 0)).children = [tree];\n return tree;\n}\n\n// Node-link tree diagram using the Reingold-Tilford \"tidy\" algorithm\nexport default function() {\n var separation = defaultSeparation,\n dx = 1,\n dy = 1,\n nodeSize = null;\n\n function tree(root) {\n var t = treeRoot(root);\n\n // Compute the layout using Buchheim et al.’s algorithm.\n t.eachAfter(firstWalk), t.parent.m = -t.z;\n t.eachBefore(secondWalk);\n\n // If a fixed node size is specified, scale x and y.\n if (nodeSize) root.eachBefore(sizeNode);\n\n // If a fixed tree size is specified, scale x and y based on the extent.\n // Compute the left-most, right-most, and depth-most nodes for extents.\n else {\n var left = root,\n right = root,\n bottom = root;\n root.eachBefore(function(node) {\n if (node.x < left.x) left = node;\n if (node.x > right.x) right = node;\n if (node.depth > bottom.depth) bottom = node;\n });\n var s = left === right ? 1 : separation(left, right) / 2,\n tx = s - left.x,\n kx = dx / (right.x + s + tx),\n ky = dy / (bottom.depth || 1);\n root.eachBefore(function(node) {\n node.x = (node.x + tx) * kx;\n node.y = node.depth * ky;\n });\n }\n\n return root;\n }\n\n // Computes a preliminary x-coordinate for v. Before that, FIRST WALK is\n // applied recursively to the children of v, as well as the function\n // APPORTION. After spacing out the children by calling EXECUTE SHIFTS, the\n // node v is placed to the midpoint of its outermost children.\n function firstWalk(v) {\n var children = v.children,\n siblings = v.parent.children,\n w = v.i ? siblings[v.i - 1] : null;\n if (children) {\n executeShifts(v);\n var midpoint = (children[0].z + children[children.length - 1].z) / 2;\n if (w) {\n v.z = w.z + separation(v._, w._);\n v.m = v.z - midpoint;\n } else {\n v.z = midpoint;\n }\n } else if (w) {\n v.z = w.z + separation(v._, w._);\n }\n v.parent.A = apportion(v, w, v.parent.A || siblings[0]);\n }\n\n // Computes all real x-coordinates by summing up the modifiers recursively.\n function secondWalk(v) {\n v._.x = v.z + v.parent.m;\n v.m += v.parent.m;\n }\n\n // The core of the algorithm. Here, a new subtree is combined with the\n // previous subtrees. Threads are used to traverse the inside and outside\n // contours of the left and right subtree up to the highest common level. The\n // vertices used for the traversals are vi+, vi-, vo-, and vo+, where the\n // superscript o means outside and i means inside, the subscript - means left\n // subtree and + means right subtree. For summing up the modifiers along the\n // contour, we use respective variables si+, si-, so-, and so+. Whenever two\n // nodes of the inside contours conflict, we compute the left one of the\n // greatest uncommon ancestors using the function ANCESTOR and call MOVE\n // SUBTREE to shift the subtree and prepare the shifts of smaller subtrees.\n // Finally, we add a new thread (if necessary).\n function apportion(v, w, ancestor) {\n if (w) {\n var vip = v,\n vop = v,\n vim = w,\n vom = vip.parent.children[0],\n sip = vip.m,\n sop = vop.m,\n sim = vim.m,\n som = vom.m,\n shift;\n while (vim = nextRight(vim), vip = nextLeft(vip), vim && vip) {\n vom = nextLeft(vom);\n vop = nextRight(vop);\n vop.a = v;\n shift = vim.z + sim - vip.z - sip + separation(vim._, vip._);\n if (shift > 0) {\n moveSubtree(nextAncestor(vim, v, ancestor), v, shift);\n sip += shift;\n sop += shift;\n }\n sim += vim.m;\n sip += vip.m;\n som += vom.m;\n sop += vop.m;\n }\n if (vim && !nextRight(vop)) {\n vop.t = vim;\n vop.m += sim - sop;\n }\n if (vip && !nextLeft(vom)) {\n vom.t = vip;\n vom.m += sip - som;\n ancestor = v;\n }\n }\n return ancestor;\n }\n\n function sizeNode(node) {\n node.x *= dx;\n node.y = node.depth * dy;\n }\n\n tree.separation = function(x) {\n return arguments.length ? (separation = x, tree) : separation;\n };\n\n tree.size = function(x) {\n return arguments.length ? (nodeSize = false, dx = +x[0], dy = +x[1], tree) : (nodeSize ? null : [dx, dy]);\n };\n\n tree.nodeSize = function(x) {\n return arguments.length ? (nodeSize = true, dx = +x[0], dy = +x[1], tree) : (nodeSize ? [dx, dy] : null);\n };\n\n return tree;\n}\n","export default function(parent, x0, y0, x1, y1) {\n var nodes = parent.children,\n node,\n i = -1,\n n = nodes.length,\n k = parent.value && (y1 - y0) / parent.value;\n\n while (++i < n) {\n node = nodes[i], node.x0 = x0, node.x1 = x1;\n node.y0 = y0, node.y1 = y0 += node.value * k;\n }\n}\n","import treemapDice from \"./dice.js\";\nimport treemapSlice from \"./slice.js\";\n\nexport var phi = (1 + Math.sqrt(5)) / 2;\n\nexport function squarifyRatio(ratio, parent, x0, y0, x1, y1) {\n var rows = [],\n nodes = parent.children,\n row,\n nodeValue,\n i0 = 0,\n i1 = 0,\n n = nodes.length,\n dx, dy,\n value = parent.value,\n sumValue,\n minValue,\n maxValue,\n newRatio,\n minRatio,\n alpha,\n beta;\n\n while (i0 < n) {\n dx = x1 - x0, dy = y1 - y0;\n\n // Find the next non-empty node.\n do sumValue = nodes[i1++].value; while (!sumValue && i1 < n);\n minValue = maxValue = sumValue;\n alpha = Math.max(dy / dx, dx / dy) / (value * ratio);\n beta = sumValue * sumValue * alpha;\n minRatio = Math.max(maxValue / beta, beta / minValue);\n\n // Keep adding nodes while the aspect ratio maintains or improves.\n for (; i1 < n; ++i1) {\n sumValue += nodeValue = nodes[i1].value;\n if (nodeValue < minValue) minValue = nodeValue;\n if (nodeValue > maxValue) maxValue = nodeValue;\n beta = sumValue * sumValue * alpha;\n newRatio = Math.max(maxValue / beta, beta / minValue);\n if (newRatio > minRatio) { sumValue -= nodeValue; break; }\n minRatio = newRatio;\n }\n\n // Position and record the row orientation.\n rows.push(row = {value: sumValue, dice: dx < dy, children: nodes.slice(i0, i1)});\n if (row.dice) treemapDice(row, x0, y0, x1, value ? y0 += dy * sumValue / value : y1);\n else treemapSlice(row, x0, y0, value ? x0 += dx * sumValue / value : x1, y1);\n value -= sumValue, i0 = i1;\n }\n\n return rows;\n}\n\nexport default (function custom(ratio) {\n\n function squarify(parent, x0, y0, x1, y1) {\n squarifyRatio(ratio, parent, x0, y0, x1, y1);\n }\n\n squarify.ratio = function(x) {\n return custom((x = +x) > 1 ? x : 1);\n };\n\n return squarify;\n})(phi);\n","import roundNode from \"./round.js\";\nimport squarify from \"./squarify.js\";\nimport {required} from \"../accessors.js\";\nimport constant, {constantZero} from \"../constant.js\";\n\nexport default function() {\n var tile = squarify,\n round = false,\n dx = 1,\n dy = 1,\n paddingStack = [0],\n paddingInner = constantZero,\n paddingTop = constantZero,\n paddingRight = constantZero,\n paddingBottom = constantZero,\n paddingLeft = constantZero;\n\n function treemap(root) {\n root.x0 =\n root.y0 = 0;\n root.x1 = dx;\n root.y1 = dy;\n root.eachBefore(positionNode);\n paddingStack = [0];\n if (round) root.eachBefore(roundNode);\n return root;\n }\n\n function positionNode(node) {\n var p = paddingStack[node.depth],\n x0 = node.x0 + p,\n y0 = node.y0 + p,\n x1 = node.x1 - p,\n y1 = node.y1 - p;\n if (x1 < x0) x0 = x1 = (x0 + x1) / 2;\n if (y1 < y0) y0 = y1 = (y0 + y1) / 2;\n node.x0 = x0;\n node.y0 = y0;\n node.x1 = x1;\n node.y1 = y1;\n if (node.children) {\n p = paddingStack[node.depth + 1] = paddingInner(node) / 2;\n x0 += paddingLeft(node) - p;\n y0 += paddingTop(node) - p;\n x1 -= paddingRight(node) - p;\n y1 -= paddingBottom(node) - p;\n if (x1 < x0) x0 = x1 = (x0 + x1) / 2;\n if (y1 < y0) y0 = y1 = (y0 + y1) / 2;\n tile(node, x0, y0, x1, y1);\n }\n }\n\n treemap.round = function(x) {\n return arguments.length ? (round = !!x, treemap) : round;\n };\n\n treemap.size = function(x) {\n return arguments.length ? (dx = +x[0], dy = +x[1], treemap) : [dx, dy];\n };\n\n treemap.tile = function(x) {\n return arguments.length ? (tile = required(x), treemap) : tile;\n };\n\n treemap.padding = function(x) {\n return arguments.length ? treemap.paddingInner(x).paddingOuter(x) : treemap.paddingInner();\n };\n\n treemap.paddingInner = function(x) {\n return arguments.length ? (paddingInner = typeof x === \"function\" ? x : constant(+x), treemap) : paddingInner;\n };\n\n treemap.paddingOuter = function(x) {\n return arguments.length ? treemap.paddingTop(x).paddingRight(x).paddingBottom(x).paddingLeft(x) : treemap.paddingTop();\n };\n\n treemap.paddingTop = function(x) {\n return arguments.length ? (paddingTop = typeof x === \"function\" ? x : constant(+x), treemap) : paddingTop;\n };\n\n treemap.paddingRight = function(x) {\n return arguments.length ? (paddingRight = typeof x === \"function\" ? x : constant(+x), treemap) : paddingRight;\n };\n\n treemap.paddingBottom = function(x) {\n return arguments.length ? (paddingBottom = typeof x === \"function\" ? x : constant(+x), treemap) : paddingBottom;\n };\n\n treemap.paddingLeft = function(x) {\n return arguments.length ? (paddingLeft = typeof x === \"function\" ? x : constant(+x), treemap) : paddingLeft;\n };\n\n return treemap;\n}\n","export default function(parent, x0, y0, x1, y1) {\n var nodes = parent.children,\n i, n = nodes.length,\n sum, sums = new Array(n + 1);\n\n for (sums[0] = sum = i = 0; i < n; ++i) {\n sums[i + 1] = sum += nodes[i].value;\n }\n\n partition(0, n, parent.value, x0, y0, x1, y1);\n\n function partition(i, j, value, x0, y0, x1, y1) {\n if (i >= j - 1) {\n var node = nodes[i];\n node.x0 = x0, node.y0 = y0;\n node.x1 = x1, node.y1 = y1;\n return;\n }\n\n var valueOffset = sums[i],\n valueTarget = (value / 2) + valueOffset,\n k = i + 1,\n hi = j - 1;\n\n while (k < hi) {\n var mid = k + hi >>> 1;\n if (sums[mid] < valueTarget) k = mid + 1;\n else hi = mid;\n }\n\n if ((valueTarget - sums[k - 1]) < (sums[k] - valueTarget) && i + 1 < k) --k;\n\n var valueLeft = sums[k] - valueOffset,\n valueRight = value - valueLeft;\n\n if ((x1 - x0) > (y1 - y0)) {\n var xk = (x0 * valueRight + x1 * valueLeft) / value;\n partition(i, k, valueLeft, x0, y0, xk, y1);\n partition(k, j, valueRight, xk, y0, x1, y1);\n } else {\n var yk = (y0 * valueRight + y1 * valueLeft) / value;\n partition(i, k, valueLeft, x0, y0, x1, yk);\n partition(k, j, valueRight, x0, yk, x1, y1);\n }\n }\n}\n","import dice from \"./dice.js\";\nimport slice from \"./slice.js\";\n\nexport default function(parent, x0, y0, x1, y1) {\n (parent.depth & 1 ? slice : dice)(parent, x0, y0, x1, y1);\n}\n","import treemapDice from \"./dice.js\";\nimport treemapSlice from \"./slice.js\";\nimport {phi, squarifyRatio} from \"./squarify.js\";\n\nexport default (function custom(ratio) {\n\n function resquarify(parent, x0, y0, x1, y1) {\n if ((rows = parent._squarify) && (rows.ratio === ratio)) {\n var rows,\n row,\n nodes,\n i,\n j = -1,\n n,\n m = rows.length,\n value = parent.value;\n\n while (++j < m) {\n row = rows[j], nodes = row.children;\n for (i = row.value = 0, n = nodes.length; i < n; ++i) row.value += nodes[i].value;\n if (row.dice) treemapDice(row, x0, y0, x1, y0 += (y1 - y0) * row.value / value);\n else treemapSlice(row, x0, y0, x0 += (x1 - x0) * row.value / value, y1);\n value -= row.value;\n }\n } else {\n parent._squarify = rows = squarifyRatio(ratio, parent, x0, y0, x1, y1);\n rows.ratio = ratio;\n }\n }\n\n resquarify.ratio = function(x) {\n return custom((x = +x) > 1 ? x : 1);\n };\n\n return resquarify;\n})(phi);\n","var pi = Math.PI,\n tau = 2 * pi,\n epsilon = 1e-6,\n tauEpsilon = tau - epsilon;\n\nfunction Path() {\n this._x0 = this._y0 = // start of current subpath\n this._x1 = this._y1 = null; // end of current subpath\n this._ = \"\";\n}\n\nfunction path() {\n return new Path;\n}\n\nPath.prototype = path.prototype = {\n constructor: Path,\n moveTo: function(x, y) {\n this._ += \"M\" + (this._x0 = this._x1 = +x) + \",\" + (this._y0 = this._y1 = +y);\n },\n closePath: function() {\n if (this._x1 !== null) {\n this._x1 = this._x0, this._y1 = this._y0;\n this._ += \"Z\";\n }\n },\n lineTo: function(x, y) {\n this._ += \"L\" + (this._x1 = +x) + \",\" + (this._y1 = +y);\n },\n quadraticCurveTo: function(x1, y1, x, y) {\n this._ += \"Q\" + (+x1) + \",\" + (+y1) + \",\" + (this._x1 = +x) + \",\" + (this._y1 = +y);\n },\n bezierCurveTo: function(x1, y1, x2, y2, x, y) {\n this._ += \"C\" + (+x1) + \",\" + (+y1) + \",\" + (+x2) + \",\" + (+y2) + \",\" + (this._x1 = +x) + \",\" + (this._y1 = +y);\n },\n arcTo: function(x1, y1, x2, y2, r) {\n x1 = +x1, y1 = +y1, x2 = +x2, y2 = +y2, r = +r;\n var x0 = this._x1,\n y0 = this._y1,\n x21 = x2 - x1,\n y21 = y2 - y1,\n x01 = x0 - x1,\n y01 = y0 - y1,\n l01_2 = x01 * x01 + y01 * y01;\n\n // Is the radius negative? Error.\n if (r < 0) throw new Error(\"negative radius: \" + r);\n\n // Is this path empty? Move to (x1,y1).\n if (this._x1 === null) {\n this._ += \"M\" + (this._x1 = x1) + \",\" + (this._y1 = y1);\n }\n\n // Or, is (x1,y1) coincident with (x0,y0)? Do nothing.\n else if (!(l01_2 > epsilon));\n\n // Or, are (x0,y0), (x1,y1) and (x2,y2) collinear?\n // Equivalently, is (x1,y1) coincident with (x2,y2)?\n // Or, is the radius zero? Line to (x1,y1).\n else if (!(Math.abs(y01 * x21 - y21 * x01) > epsilon) || !r) {\n this._ += \"L\" + (this._x1 = x1) + \",\" + (this._y1 = y1);\n }\n\n // Otherwise, draw an arc!\n else {\n var x20 = x2 - x0,\n y20 = y2 - y0,\n l21_2 = x21 * x21 + y21 * y21,\n l20_2 = x20 * x20 + y20 * y20,\n l21 = Math.sqrt(l21_2),\n l01 = Math.sqrt(l01_2),\n l = r * Math.tan((pi - Math.acos((l21_2 + l01_2 - l20_2) / (2 * l21 * l01))) / 2),\n t01 = l / l01,\n t21 = l / l21;\n\n // If the start tangent is not coincident with (x0,y0), line to.\n if (Math.abs(t01 - 1) > epsilon) {\n this._ += \"L\" + (x1 + t01 * x01) + \",\" + (y1 + t01 * y01);\n }\n\n this._ += \"A\" + r + \",\" + r + \",0,0,\" + (+(y01 * x20 > x01 * y20)) + \",\" + (this._x1 = x1 + t21 * x21) + \",\" + (this._y1 = y1 + t21 * y21);\n }\n },\n arc: function(x, y, r, a0, a1, ccw) {\n x = +x, y = +y, r = +r, ccw = !!ccw;\n var dx = r * Math.cos(a0),\n dy = r * Math.sin(a0),\n x0 = x + dx,\n y0 = y + dy,\n cw = 1 ^ ccw,\n da = ccw ? a0 - a1 : a1 - a0;\n\n // Is the radius negative? Error.\n if (r < 0) throw new Error(\"negative radius: \" + r);\n\n // Is this path empty? Move to (x0,y0).\n if (this._x1 === null) {\n this._ += \"M\" + x0 + \",\" + y0;\n }\n\n // Or, is (x0,y0) not coincident with the previous point? Line to (x0,y0).\n else if (Math.abs(this._x1 - x0) > epsilon || Math.abs(this._y1 - y0) > epsilon) {\n this._ += \"L\" + x0 + \",\" + y0;\n }\n\n // Is this arc empty? We’re done.\n if (!r) return;\n\n // Does the angle go the wrong way? Flip the direction.\n if (da < 0) da = da % tau + tau;\n\n // Is this a complete circle? Draw two arcs to complete the circle.\n if (da > tauEpsilon) {\n this._ += \"A\" + r + \",\" + r + \",0,1,\" + cw + \",\" + (x - dx) + \",\" + (y - dy) + \"A\" + r + \",\" + r + \",0,1,\" + cw + \",\" + (this._x1 = x0) + \",\" + (this._y1 = y0);\n }\n\n // Is this arc non-empty? Draw an arc!\n else if (da > epsilon) {\n this._ += \"A\" + r + \",\" + r + \",0,\" + (+(da >= pi)) + \",\" + cw + \",\" + (this._x1 = x + r * Math.cos(a1)) + \",\" + (this._y1 = y + r * Math.sin(a1));\n }\n },\n rect: function(x, y, w, h) {\n this._ += \"M\" + (this._x0 = this._x1 = +x) + \",\" + (this._y0 = this._y1 = +y) + \"h\" + (+w) + \"v\" + (+h) + \"h\" + (-w) + \"Z\";\n },\n toString: function() {\n return this._;\n }\n};\n\nexport default path;\n","export var slice = Array.prototype.slice;\n","export default function(x) {\n return function constant() {\n return x;\n };\n}\n","export function x(p) {\n return p[0];\n}\n\nexport function y(p) {\n return p[1];\n}\n","import {path} from \"d3-path\";\nimport {slice} from \"../array.js\";\nimport constant from \"../constant.js\";\nimport {x as pointX, y as pointY} from \"../point.js\";\nimport pointRadial from \"../pointRadial.js\";\n\nfunction linkSource(d) {\n return d.source;\n}\n\nfunction linkTarget(d) {\n return d.target;\n}\n\nfunction link(curve) {\n var source = linkSource,\n target = linkTarget,\n x = pointX,\n y = pointY,\n context = null;\n\n function link() {\n var buffer, argv = slice.call(arguments), s = source.apply(this, argv), t = target.apply(this, argv);\n if (!context) context = buffer = path();\n curve(context, +x.apply(this, (argv[0] = s, argv)), +y.apply(this, argv), +x.apply(this, (argv[0] = t, argv)), +y.apply(this, argv));\n if (buffer) return context = null, buffer + \"\" || null;\n }\n\n link.source = function(_) {\n return arguments.length ? (source = _, link) : source;\n };\n\n link.target = function(_) {\n return arguments.length ? (target = _, link) : target;\n };\n\n link.x = function(_) {\n return arguments.length ? (x = typeof _ === \"function\" ? _ : constant(+_), link) : x;\n };\n\n link.y = function(_) {\n return arguments.length ? (y = typeof _ === \"function\" ? _ : constant(+_), link) : y;\n };\n\n link.context = function(_) {\n return arguments.length ? ((context = _ == null ? null : _), link) : context;\n };\n\n return link;\n}\n\nfunction curveHorizontal(context, x0, y0, x1, y1) {\n context.moveTo(x0, y0);\n context.bezierCurveTo(x0 = (x0 + x1) / 2, y0, x0, y1, x1, y1);\n}\n\nfunction curveVertical(context, x0, y0, x1, y1) {\n context.moveTo(x0, y0);\n context.bezierCurveTo(x0, y0 = (y0 + y1) / 2, x1, y0, x1, y1);\n}\n\nfunction curveRadial(context, x0, y0, x1, y1) {\n var p0 = pointRadial(x0, y0),\n p1 = pointRadial(x0, y0 = (y0 + y1) / 2),\n p2 = pointRadial(x1, y0),\n p3 = pointRadial(x1, y1);\n context.moveTo(p0[0], p0[1]);\n context.bezierCurveTo(p1[0], p1[1], p2[0], p2[1], p3[0], p3[1]);\n}\n\nexport function linkHorizontal() {\n return link(curveHorizontal);\n}\n\nexport function linkVertical() {\n return link(curveVertical);\n}\n\nexport function linkRadial() {\n var l = link(curveRadial);\n l.angle = l.x, delete l.x;\n l.radius = l.y, delete l.y;\n return l;\n}\n","import {\n timeDay,\n timeSunday,\n timeMonday,\n timeThursday,\n timeYear,\n utcDay,\n utcSunday,\n utcMonday,\n utcThursday,\n utcYear\n} from \"d3-time\";\n\nfunction localDate(d) {\n if (0 <= d.y && d.y < 100) {\n var date = new Date(-1, d.m, d.d, d.H, d.M, d.S, d.L);\n date.setFullYear(d.y);\n return date;\n }\n return new Date(d.y, d.m, d.d, d.H, d.M, d.S, d.L);\n}\n\nfunction utcDate(d) {\n if (0 <= d.y && d.y < 100) {\n var date = new Date(Date.UTC(-1, d.m, d.d, d.H, d.M, d.S, d.L));\n date.setUTCFullYear(d.y);\n return date;\n }\n return new Date(Date.UTC(d.y, d.m, d.d, d.H, d.M, d.S, d.L));\n}\n\nfunction newDate(y, m, d) {\n return {y: y, m: m, d: d, H: 0, M: 0, S: 0, L: 0};\n}\n\nexport default function formatLocale(locale) {\n var locale_dateTime = locale.dateTime,\n locale_date = locale.date,\n locale_time = locale.time,\n locale_periods = locale.periods,\n locale_weekdays = locale.days,\n locale_shortWeekdays = locale.shortDays,\n locale_months = locale.months,\n locale_shortMonths = locale.shortMonths;\n\n var periodRe = formatRe(locale_periods),\n periodLookup = formatLookup(locale_periods),\n weekdayRe = formatRe(locale_weekdays),\n weekdayLookup = formatLookup(locale_weekdays),\n shortWeekdayRe = formatRe(locale_shortWeekdays),\n shortWeekdayLookup = formatLookup(locale_shortWeekdays),\n monthRe = formatRe(locale_months),\n monthLookup = formatLookup(locale_months),\n shortMonthRe = formatRe(locale_shortMonths),\n shortMonthLookup = formatLookup(locale_shortMonths);\n\n var formats = {\n \"a\": formatShortWeekday,\n \"A\": formatWeekday,\n \"b\": formatShortMonth,\n \"B\": formatMonth,\n \"c\": null,\n \"d\": formatDayOfMonth,\n \"e\": formatDayOfMonth,\n \"f\": formatMicroseconds,\n \"g\": formatYearISO,\n \"G\": formatFullYearISO,\n \"H\": formatHour24,\n \"I\": formatHour12,\n \"j\": formatDayOfYear,\n \"L\": formatMilliseconds,\n \"m\": formatMonthNumber,\n \"M\": formatMinutes,\n \"p\": formatPeriod,\n \"q\": formatQuarter,\n \"Q\": formatUnixTimestamp,\n \"s\": formatUnixTimestampSeconds,\n \"S\": formatSeconds,\n \"u\": formatWeekdayNumberMonday,\n \"U\": formatWeekNumberSunday,\n \"V\": formatWeekNumberISO,\n \"w\": formatWeekdayNumberSunday,\n \"W\": formatWeekNumberMonday,\n \"x\": null,\n \"X\": null,\n \"y\": formatYear,\n \"Y\": formatFullYear,\n \"Z\": formatZone,\n \"%\": formatLiteralPercent\n };\n\n var utcFormats = {\n \"a\": formatUTCShortWeekday,\n \"A\": formatUTCWeekday,\n \"b\": formatUTCShortMonth,\n \"B\": formatUTCMonth,\n \"c\": null,\n \"d\": formatUTCDayOfMonth,\n \"e\": formatUTCDayOfMonth,\n \"f\": formatUTCMicroseconds,\n \"g\": formatUTCYearISO,\n \"G\": formatUTCFullYearISO,\n \"H\": formatUTCHour24,\n \"I\": formatUTCHour12,\n \"j\": formatUTCDayOfYear,\n \"L\": formatUTCMilliseconds,\n \"m\": formatUTCMonthNumber,\n \"M\": formatUTCMinutes,\n \"p\": formatUTCPeriod,\n \"q\": formatUTCQuarter,\n \"Q\": formatUnixTimestamp,\n \"s\": formatUnixTimestampSeconds,\n \"S\": formatUTCSeconds,\n \"u\": formatUTCWeekdayNumberMonday,\n \"U\": formatUTCWeekNumberSunday,\n \"V\": formatUTCWeekNumberISO,\n \"w\": formatUTCWeekdayNumberSunday,\n \"W\": formatUTCWeekNumberMonday,\n \"x\": null,\n \"X\": null,\n \"y\": formatUTCYear,\n \"Y\": formatUTCFullYear,\n \"Z\": formatUTCZone,\n \"%\": formatLiteralPercent\n };\n\n var parses = {\n \"a\": parseShortWeekday,\n \"A\": parseWeekday,\n \"b\": parseShortMonth,\n \"B\": parseMonth,\n \"c\": parseLocaleDateTime,\n \"d\": parseDayOfMonth,\n \"e\": parseDayOfMonth,\n \"f\": parseMicroseconds,\n \"g\": parseYear,\n \"G\": parseFullYear,\n \"H\": parseHour24,\n \"I\": parseHour24,\n \"j\": parseDayOfYear,\n \"L\": parseMilliseconds,\n \"m\": parseMonthNumber,\n \"M\": parseMinutes,\n \"p\": parsePeriod,\n \"q\": parseQuarter,\n \"Q\": parseUnixTimestamp,\n \"s\": parseUnixTimestampSeconds,\n \"S\": parseSeconds,\n \"u\": parseWeekdayNumberMonday,\n \"U\": parseWeekNumberSunday,\n \"V\": parseWeekNumberISO,\n \"w\": parseWeekdayNumberSunday,\n \"W\": parseWeekNumberMonday,\n \"x\": parseLocaleDate,\n \"X\": parseLocaleTime,\n \"y\": parseYear,\n \"Y\": parseFullYear,\n \"Z\": parseZone,\n \"%\": parseLiteralPercent\n };\n\n // These recursive directive definitions must be deferred.\n formats.x = newFormat(locale_date, formats);\n formats.X = newFormat(locale_time, formats);\n formats.c = newFormat(locale_dateTime, formats);\n utcFormats.x = newFormat(locale_date, utcFormats);\n utcFormats.X = newFormat(locale_time, utcFormats);\n utcFormats.c = newFormat(locale_dateTime, utcFormats);\n\n function newFormat(specifier, formats) {\n return function(date) {\n var string = [],\n i = -1,\n j = 0,\n n = specifier.length,\n c,\n pad,\n format;\n\n if (!(date instanceof Date)) date = new Date(+date);\n\n while (++i < n) {\n if (specifier.charCodeAt(i) === 37) {\n string.push(specifier.slice(j, i));\n if ((pad = pads[c = specifier.charAt(++i)]) != null) c = specifier.charAt(++i);\n else pad = c === \"e\" ? \" \" : \"0\";\n if (format = formats[c]) c = format(date, pad);\n string.push(c);\n j = i + 1;\n }\n }\n\n string.push(specifier.slice(j, i));\n return string.join(\"\");\n };\n }\n\n function newParse(specifier, Z) {\n return function(string) {\n var d = newDate(1900, undefined, 1),\n i = parseSpecifier(d, specifier, string += \"\", 0),\n week, day;\n if (i != string.length) return null;\n\n // If a UNIX timestamp is specified, return it.\n if (\"Q\" in d) return new Date(d.Q);\n if (\"s\" in d) return new Date(d.s * 1000 + (\"L\" in d ? d.L : 0));\n\n // If this is utcParse, never use the local timezone.\n if (Z && !(\"Z\" in d)) d.Z = 0;\n\n // The am-pm flag is 0 for AM, and 1 for PM.\n if (\"p\" in d) d.H = d.H % 12 + d.p * 12;\n\n // If the month was not specified, inherit from the quarter.\n if (d.m === undefined) d.m = \"q\" in d ? d.q : 0;\n\n // Convert day-of-week and week-of-year to day-of-year.\n if (\"V\" in d) {\n if (d.V < 1 || d.V > 53) return null;\n if (!(\"w\" in d)) d.w = 1;\n if (\"Z\" in d) {\n week = utcDate(newDate(d.y, 0, 1)), day = week.getUTCDay();\n week = day > 4 || day === 0 ? utcMonday.ceil(week) : utcMonday(week);\n week = utcDay.offset(week, (d.V - 1) * 7);\n d.y = week.getUTCFullYear();\n d.m = week.getUTCMonth();\n d.d = week.getUTCDate() + (d.w + 6) % 7;\n } else {\n week = localDate(newDate(d.y, 0, 1)), day = week.getDay();\n week = day > 4 || day === 0 ? timeMonday.ceil(week) : timeMonday(week);\n week = timeDay.offset(week, (d.V - 1) * 7);\n d.y = week.getFullYear();\n d.m = week.getMonth();\n d.d = week.getDate() + (d.w + 6) % 7;\n }\n } else if (\"W\" in d || \"U\" in d) {\n if (!(\"w\" in d)) d.w = \"u\" in d ? d.u % 7 : \"W\" in d ? 1 : 0;\n day = \"Z\" in d ? utcDate(newDate(d.y, 0, 1)).getUTCDay() : localDate(newDate(d.y, 0, 1)).getDay();\n d.m = 0;\n d.d = \"W\" in d ? (d.w + 6) % 7 + d.W * 7 - (day + 5) % 7 : d.w + d.U * 7 - (day + 6) % 7;\n }\n\n // If a time zone is specified, all fields are interpreted as UTC and then\n // offset according to the specified time zone.\n if (\"Z\" in d) {\n d.H += d.Z / 100 | 0;\n d.M += d.Z % 100;\n return utcDate(d);\n }\n\n // Otherwise, all fields are in local time.\n return localDate(d);\n };\n }\n\n function parseSpecifier(d, specifier, string, j) {\n var i = 0,\n n = specifier.length,\n m = string.length,\n c,\n parse;\n\n while (i < n) {\n if (j >= m) return -1;\n c = specifier.charCodeAt(i++);\n if (c === 37) {\n c = specifier.charAt(i++);\n parse = parses[c in pads ? specifier.charAt(i++) : c];\n if (!parse || ((j = parse(d, string, j)) < 0)) return -1;\n } else if (c != string.charCodeAt(j++)) {\n return -1;\n }\n }\n\n return j;\n }\n\n function parsePeriod(d, string, i) {\n var n = periodRe.exec(string.slice(i));\n return n ? (d.p = periodLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseShortWeekday(d, string, i) {\n var n = shortWeekdayRe.exec(string.slice(i));\n return n ? (d.w = shortWeekdayLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseWeekday(d, string, i) {\n var n = weekdayRe.exec(string.slice(i));\n return n ? (d.w = weekdayLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseShortMonth(d, string, i) {\n var n = shortMonthRe.exec(string.slice(i));\n return n ? (d.m = shortMonthLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseMonth(d, string, i) {\n var n = monthRe.exec(string.slice(i));\n return n ? (d.m = monthLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n }\n\n function parseLocaleDateTime(d, string, i) {\n return parseSpecifier(d, locale_dateTime, string, i);\n }\n\n function parseLocaleDate(d, string, i) {\n return parseSpecifier(d, locale_date, string, i);\n }\n\n function parseLocaleTime(d, string, i) {\n return parseSpecifier(d, locale_time, string, i);\n }\n\n function formatShortWeekday(d) {\n return locale_shortWeekdays[d.getDay()];\n }\n\n function formatWeekday(d) {\n return locale_weekdays[d.getDay()];\n }\n\n function formatShortMonth(d) {\n return locale_shortMonths[d.getMonth()];\n }\n\n function formatMonth(d) {\n return locale_months[d.getMonth()];\n }\n\n function formatPeriod(d) {\n return locale_periods[+(d.getHours() >= 12)];\n }\n\n function formatQuarter(d) {\n return 1 + ~~(d.getMonth() / 3);\n }\n\n function formatUTCShortWeekday(d) {\n return locale_shortWeekdays[d.getUTCDay()];\n }\n\n function formatUTCWeekday(d) {\n return locale_weekdays[d.getUTCDay()];\n }\n\n function formatUTCShortMonth(d) {\n return locale_shortMonths[d.getUTCMonth()];\n }\n\n function formatUTCMonth(d) {\n return locale_months[d.getUTCMonth()];\n }\n\n function formatUTCPeriod(d) {\n return locale_periods[+(d.getUTCHours() >= 12)];\n }\n\n function formatUTCQuarter(d) {\n return 1 + ~~(d.getUTCMonth() / 3);\n }\n\n return {\n format: function(specifier) {\n var f = newFormat(specifier += \"\", formats);\n f.toString = function() { return specifier; };\n return f;\n },\n parse: function(specifier) {\n var p = newParse(specifier += \"\", false);\n p.toString = function() { return specifier; };\n return p;\n },\n utcFormat: function(specifier) {\n var f = newFormat(specifier += \"\", utcFormats);\n f.toString = function() { return specifier; };\n return f;\n },\n utcParse: function(specifier) {\n var p = newParse(specifier += \"\", true);\n p.toString = function() { return specifier; };\n return p;\n }\n };\n}\n\nvar pads = {\"-\": \"\", \"_\": \" \", \"0\": \"0\"},\n numberRe = /^\\s*\\d+/, // note: ignores next directive\n percentRe = /^%/,\n requoteRe = /[\\\\^$*+?|[\\]().{}]/g;\n\nfunction pad(value, fill, width) {\n var sign = value < 0 ? \"-\" : \"\",\n string = (sign ? -value : value) + \"\",\n length = string.length;\n return sign + (length < width ? new Array(width - length + 1).join(fill) + string : string);\n}\n\nfunction requote(s) {\n return s.replace(requoteRe, \"\\\\$&\");\n}\n\nfunction formatRe(names) {\n return new RegExp(\"^(?:\" + names.map(requote).join(\"|\") + \")\", \"i\");\n}\n\nfunction formatLookup(names) {\n var map = {}, i = -1, n = names.length;\n while (++i < n) map[names[i].toLowerCase()] = i;\n return map;\n}\n\nfunction parseWeekdayNumberSunday(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 1));\n return n ? (d.w = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseWeekdayNumberMonday(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 1));\n return n ? (d.u = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseWeekNumberSunday(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.U = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseWeekNumberISO(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.V = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseWeekNumberMonday(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.W = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseFullYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 4));\n return n ? (d.y = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.y = +n[0] + (+n[0] > 68 ? 1900 : 2000), i + n[0].length) : -1;\n}\n\nfunction parseZone(d, string, i) {\n var n = /^(Z)|([+-]\\d\\d)(?::?(\\d\\d))?/.exec(string.slice(i, i + 6));\n return n ? (d.Z = n[1] ? 0 : -(n[2] + (n[3] || \"00\")), i + n[0].length) : -1;\n}\n\nfunction parseQuarter(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 1));\n return n ? (d.q = n[0] * 3 - 3, i + n[0].length) : -1;\n}\n\nfunction parseMonthNumber(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.m = n[0] - 1, i + n[0].length) : -1;\n}\n\nfunction parseDayOfMonth(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.d = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseDayOfYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 3));\n return n ? (d.m = 0, d.d = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseHour24(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.H = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseMinutes(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.M = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseSeconds(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.S = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseMilliseconds(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 3));\n return n ? (d.L = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseMicroseconds(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 6));\n return n ? (d.L = Math.floor(n[0] / 1000), i + n[0].length) : -1;\n}\n\nfunction parseLiteralPercent(d, string, i) {\n var n = percentRe.exec(string.slice(i, i + 1));\n return n ? i + n[0].length : -1;\n}\n\nfunction parseUnixTimestamp(d, string, i) {\n var n = numberRe.exec(string.slice(i));\n return n ? (d.Q = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseUnixTimestampSeconds(d, string, i) {\n var n = numberRe.exec(string.slice(i));\n return n ? (d.s = +n[0], i + n[0].length) : -1;\n}\n\nfunction formatDayOfMonth(d, p) {\n return pad(d.getDate(), p, 2);\n}\n\nfunction formatHour24(d, p) {\n return pad(d.getHours(), p, 2);\n}\n\nfunction formatHour12(d, p) {\n return pad(d.getHours() % 12 || 12, p, 2);\n}\n\nfunction formatDayOfYear(d, p) {\n return pad(1 + timeDay.count(timeYear(d), d), p, 3);\n}\n\nfunction formatMilliseconds(d, p) {\n return pad(d.getMilliseconds(), p, 3);\n}\n\nfunction formatMicroseconds(d, p) {\n return formatMilliseconds(d, p) + \"000\";\n}\n\nfunction formatMonthNumber(d, p) {\n return pad(d.getMonth() + 1, p, 2);\n}\n\nfunction formatMinutes(d, p) {\n return pad(d.getMinutes(), p, 2);\n}\n\nfunction formatSeconds(d, p) {\n return pad(d.getSeconds(), p, 2);\n}\n\nfunction formatWeekdayNumberMonday(d) {\n var day = d.getDay();\n return day === 0 ? 7 : day;\n}\n\nfunction formatWeekNumberSunday(d, p) {\n return pad(timeSunday.count(timeYear(d) - 1, d), p, 2);\n}\n\nfunction dISO(d) {\n var day = d.getDay();\n return (day >= 4 || day === 0) ? timeThursday(d) : timeThursday.ceil(d);\n}\n\nfunction formatWeekNumberISO(d, p) {\n d = dISO(d);\n return pad(timeThursday.count(timeYear(d), d) + (timeYear(d).getDay() === 4), p, 2);\n}\n\nfunction formatWeekdayNumberSunday(d) {\n return d.getDay();\n}\n\nfunction formatWeekNumberMonday(d, p) {\n return pad(timeMonday.count(timeYear(d) - 1, d), p, 2);\n}\n\nfunction formatYear(d, p) {\n return pad(d.getFullYear() % 100, p, 2);\n}\n\nfunction formatYearISO(d, p) {\n d = dISO(d);\n return pad(d.getFullYear() % 100, p, 2);\n}\n\nfunction formatFullYear(d, p) {\n return pad(d.getFullYear() % 10000, p, 4);\n}\n\nfunction formatFullYearISO(d, p) {\n var day = d.getDay();\n d = (day >= 4 || day === 0) ? timeThursday(d) : timeThursday.ceil(d);\n return pad(d.getFullYear() % 10000, p, 4);\n}\n\nfunction formatZone(d) {\n var z = d.getTimezoneOffset();\n return (z > 0 ? \"-\" : (z *= -1, \"+\"))\n + pad(z / 60 | 0, \"0\", 2)\n + pad(z % 60, \"0\", 2);\n}\n\nfunction formatUTCDayOfMonth(d, p) {\n return pad(d.getUTCDate(), p, 2);\n}\n\nfunction formatUTCHour24(d, p) {\n return pad(d.getUTCHours(), p, 2);\n}\n\nfunction formatUTCHour12(d, p) {\n return pad(d.getUTCHours() % 12 || 12, p, 2);\n}\n\nfunction formatUTCDayOfYear(d, p) {\n return pad(1 + utcDay.count(utcYear(d), d), p, 3);\n}\n\nfunction formatUTCMilliseconds(d, p) {\n return pad(d.getUTCMilliseconds(), p, 3);\n}\n\nfunction formatUTCMicroseconds(d, p) {\n return formatUTCMilliseconds(d, p) + \"000\";\n}\n\nfunction formatUTCMonthNumber(d, p) {\n return pad(d.getUTCMonth() + 1, p, 2);\n}\n\nfunction formatUTCMinutes(d, p) {\n return pad(d.getUTCMinutes(), p, 2);\n}\n\nfunction formatUTCSeconds(d, p) {\n return pad(d.getUTCSeconds(), p, 2);\n}\n\nfunction formatUTCWeekdayNumberMonday(d) {\n var dow = d.getUTCDay();\n return dow === 0 ? 7 : dow;\n}\n\nfunction formatUTCWeekNumberSunday(d, p) {\n return pad(utcSunday.count(utcYear(d) - 1, d), p, 2);\n}\n\nfunction UTCdISO(d) {\n var day = d.getUTCDay();\n return (day >= 4 || day === 0) ? utcThursday(d) : utcThursday.ceil(d);\n}\n\nfunction formatUTCWeekNumberISO(d, p) {\n d = UTCdISO(d);\n return pad(utcThursday.count(utcYear(d), d) + (utcYear(d).getUTCDay() === 4), p, 2);\n}\n\nfunction formatUTCWeekdayNumberSunday(d) {\n return d.getUTCDay();\n}\n\nfunction formatUTCWeekNumberMonday(d, p) {\n return pad(utcMonday.count(utcYear(d) - 1, d), p, 2);\n}\n\nfunction formatUTCYear(d, p) {\n return pad(d.getUTCFullYear() % 100, p, 2);\n}\n\nfunction formatUTCYearISO(d, p) {\n d = UTCdISO(d);\n return pad(d.getUTCFullYear() % 100, p, 2);\n}\n\nfunction formatUTCFullYear(d, p) {\n return pad(d.getUTCFullYear() % 10000, p, 4);\n}\n\nfunction formatUTCFullYearISO(d, p) {\n var day = d.getUTCDay();\n d = (day >= 4 || day === 0) ? utcThursday(d) : utcThursday.ceil(d);\n return pad(d.getUTCFullYear() % 10000, p, 4);\n}\n\nfunction formatUTCZone() {\n return \"+0000\";\n}\n\nfunction formatLiteralPercent() {\n return \"%\";\n}\n\nfunction formatUnixTimestamp(d) {\n return +d;\n}\n\nfunction formatUnixTimestampSeconds(d) {\n return Math.floor(+d / 1000);\n}\n","import formatLocale from \"./locale.js\";\n\nvar locale;\nexport var timeFormat;\nexport var timeParse;\nexport var utcFormat;\nexport var utcParse;\n\ndefaultLocale({\n dateTime: \"%x, %X\",\n date: \"%-m/%-d/%Y\",\n time: \"%-I:%M:%S %p\",\n periods: [\"AM\", \"PM\"],\n days: [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\", \"Friday\", \"Saturday\"],\n shortDays: [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"],\n months: [\"January\", \"February\", \"March\", \"April\", \"May\", \"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"],\n shortMonths: [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\", \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"]\n});\n\nexport default function defaultLocale(definition) {\n locale = formatLocale(definition);\n timeFormat = locale.format;\n timeParse = locale.parse;\n utcFormat = locale.utcFormat;\n utcParse = locale.utcParse;\n return locale;\n}\n","import interval from \"./interval.js\";\nimport {durationDay, durationMinute} from \"./duration.js\";\n\nvar day = interval(function(date) {\n date.setHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setDate(date.getDate() + step);\n}, function(start, end) {\n return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute) / durationDay;\n}, function(date) {\n return date.getDate() - 1;\n});\n\nexport default day;\nexport var days = day.range;\n","export var durationSecond = 1e3;\nexport var durationMinute = 6e4;\nexport var durationHour = 36e5;\nexport var durationDay = 864e5;\nexport var durationWeek = 6048e5;\n","import interval from \"./interval.js\";\n\nvar millisecond = interval(function() {\n // noop\n}, function(date, step) {\n date.setTime(+date + step);\n}, function(start, end) {\n return end - start;\n});\n\n// An optimized implementation for this simple case.\nmillisecond.every = function(k) {\n k = Math.floor(k);\n if (!isFinite(k) || !(k > 0)) return null;\n if (!(k > 1)) return millisecond;\n return interval(function(date) {\n date.setTime(Math.floor(date / k) * k);\n }, function(date, step) {\n date.setTime(+date + step * k);\n }, function(start, end) {\n return (end - start) / k;\n });\n};\n\nexport default millisecond;\nexport var milliseconds = millisecond.range;\n","import interval from \"./interval.js\";\nimport {durationSecond} from \"./duration.js\";\n\nvar second = interval(function(date) {\n date.setTime(date - date.getMilliseconds());\n}, function(date, step) {\n date.setTime(+date + step * durationSecond);\n}, function(start, end) {\n return (end - start) / durationSecond;\n}, function(date) {\n return date.getUTCSeconds();\n});\n\nexport default second;\nexport var seconds = second.range;\n","import interval from \"./interval.js\";\nimport {durationMinute, durationSecond} from \"./duration.js\";\n\nvar minute = interval(function(date) {\n date.setTime(date - date.getMilliseconds() - date.getSeconds() * durationSecond);\n}, function(date, step) {\n date.setTime(+date + step * durationMinute);\n}, function(start, end) {\n return (end - start) / durationMinute;\n}, function(date) {\n return date.getMinutes();\n});\n\nexport default minute;\nexport var minutes = minute.range;\n","import interval from \"./interval.js\";\nimport {durationHour, durationMinute, durationSecond} from \"./duration.js\";\n\nvar hour = interval(function(date) {\n date.setTime(date - date.getMilliseconds() - date.getSeconds() * durationSecond - date.getMinutes() * durationMinute);\n}, function(date, step) {\n date.setTime(+date + step * durationHour);\n}, function(start, end) {\n return (end - start) / durationHour;\n}, function(date) {\n return date.getHours();\n});\n\nexport default hour;\nexport var hours = hour.range;\n","import interval from \"./interval.js\";\n\nvar month = interval(function(date) {\n date.setDate(1);\n date.setHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setMonth(date.getMonth() + step);\n}, function(start, end) {\n return end.getMonth() - start.getMonth() + (end.getFullYear() - start.getFullYear()) * 12;\n}, function(date) {\n return date.getMonth();\n});\n\nexport default month;\nexport var months = month.range;\n","import interval from \"./interval.js\";\nimport {durationMinute} from \"./duration.js\";\n\nvar utcMinute = interval(function(date) {\n date.setUTCSeconds(0, 0);\n}, function(date, step) {\n date.setTime(+date + step * durationMinute);\n}, function(start, end) {\n return (end - start) / durationMinute;\n}, function(date) {\n return date.getUTCMinutes();\n});\n\nexport default utcMinute;\nexport var utcMinutes = utcMinute.range;\n","import interval from \"./interval.js\";\nimport {durationHour} from \"./duration.js\";\n\nvar utcHour = interval(function(date) {\n date.setUTCMinutes(0, 0, 0);\n}, function(date, step) {\n date.setTime(+date + step * durationHour);\n}, function(start, end) {\n return (end - start) / durationHour;\n}, function(date) {\n return date.getUTCHours();\n});\n\nexport default utcHour;\nexport var utcHours = utcHour.range;\n","import interval from \"./interval.js\";\n\nvar utcMonth = interval(function(date) {\n date.setUTCDate(1);\n date.setUTCHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setUTCMonth(date.getUTCMonth() + step);\n}, function(start, end) {\n return end.getUTCMonth() - start.getUTCMonth() + (end.getUTCFullYear() - start.getUTCFullYear()) * 12;\n}, function(date) {\n return date.getUTCMonth();\n});\n\nexport default utcMonth;\nexport var utcMonths = utcMonth.range;\n","var t0 = new Date,\n t1 = new Date;\n\nexport default function newInterval(floori, offseti, count, field) {\n\n function interval(date) {\n return floori(date = arguments.length === 0 ? new Date : new Date(+date)), date;\n }\n\n interval.floor = function(date) {\n return floori(date = new Date(+date)), date;\n };\n\n interval.ceil = function(date) {\n return floori(date = new Date(date - 1)), offseti(date, 1), floori(date), date;\n };\n\n interval.round = function(date) {\n var d0 = interval(date),\n d1 = interval.ceil(date);\n return date - d0 < d1 - date ? d0 : d1;\n };\n\n interval.offset = function(date, step) {\n return offseti(date = new Date(+date), step == null ? 1 : Math.floor(step)), date;\n };\n\n interval.range = function(start, stop, step) {\n var range = [], previous;\n start = interval.ceil(start);\n step = step == null ? 1 : Math.floor(step);\n if (!(start < stop) || !(step > 0)) return range; // also handles Invalid Date\n do range.push(previous = new Date(+start)), offseti(start, step), floori(start);\n while (previous < start && start < stop);\n return range;\n };\n\n interval.filter = function(test) {\n return newInterval(function(date) {\n if (date >= date) while (floori(date), !test(date)) date.setTime(date - 1);\n }, function(date, step) {\n if (date >= date) {\n if (step < 0) while (++step <= 0) {\n while (offseti(date, -1), !test(date)) {} // eslint-disable-line no-empty\n } else while (--step >= 0) {\n while (offseti(date, +1), !test(date)) {} // eslint-disable-line no-empty\n }\n }\n });\n };\n\n if (count) {\n interval.count = function(start, end) {\n t0.setTime(+start), t1.setTime(+end);\n floori(t0), floori(t1);\n return Math.floor(count(t0, t1));\n };\n\n interval.every = function(step) {\n step = Math.floor(step);\n return !isFinite(step) || !(step > 0) ? null\n : !(step > 1) ? interval\n : interval.filter(field\n ? function(d) { return field(d) % step === 0; }\n : function(d) { return interval.count(0, d) % step === 0; });\n };\n }\n\n return interval;\n}\n","import interval from \"./interval.js\";\nimport {durationDay} from \"./duration.js\";\n\nvar utcDay = interval(function(date) {\n date.setUTCHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setUTCDate(date.getUTCDate() + step);\n}, function(start, end) {\n return (end - start) / durationDay;\n}, function(date) {\n return date.getUTCDate() - 1;\n});\n\nexport default utcDay;\nexport var utcDays = utcDay.range;\n","import interval from \"./interval.js\";\nimport {durationWeek} from \"./duration.js\";\n\nfunction utcWeekday(i) {\n return interval(function(date) {\n date.setUTCDate(date.getUTCDate() - (date.getUTCDay() + 7 - i) % 7);\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCDate(date.getUTCDate() + step * 7);\n }, function(start, end) {\n return (end - start) / durationWeek;\n });\n}\n\nexport var utcSunday = utcWeekday(0);\nexport var utcMonday = utcWeekday(1);\nexport var utcTuesday = utcWeekday(2);\nexport var utcWednesday = utcWeekday(3);\nexport var utcThursday = utcWeekday(4);\nexport var utcFriday = utcWeekday(5);\nexport var utcSaturday = utcWeekday(6);\n\nexport var utcSundays = utcSunday.range;\nexport var utcMondays = utcMonday.range;\nexport var utcTuesdays = utcTuesday.range;\nexport var utcWednesdays = utcWednesday.range;\nexport var utcThursdays = utcThursday.range;\nexport var utcFridays = utcFriday.range;\nexport var utcSaturdays = utcSaturday.range;\n","import interval from \"./interval.js\";\n\nvar utcYear = interval(function(date) {\n date.setUTCMonth(0, 1);\n date.setUTCHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setUTCFullYear(date.getUTCFullYear() + step);\n}, function(start, end) {\n return end.getUTCFullYear() - start.getUTCFullYear();\n}, function(date) {\n return date.getUTCFullYear();\n});\n\n// An optimized implementation for this simple case.\nutcYear.every = function(k) {\n return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : interval(function(date) {\n date.setUTCFullYear(Math.floor(date.getUTCFullYear() / k) * k);\n date.setUTCMonth(0, 1);\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCFullYear(date.getUTCFullYear() + step * k);\n });\n};\n\nexport default utcYear;\nexport var utcYears = utcYear.range;\n","import interval from \"./interval.js\";\nimport {durationMinute, durationWeek} from \"./duration.js\";\n\nfunction weekday(i) {\n return interval(function(date) {\n date.setDate(date.getDate() - (date.getDay() + 7 - i) % 7);\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setDate(date.getDate() + step * 7);\n }, function(start, end) {\n return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute) / durationWeek;\n });\n}\n\nexport var sunday = weekday(0);\nexport var monday = weekday(1);\nexport var tuesday = weekday(2);\nexport var wednesday = weekday(3);\nexport var thursday = weekday(4);\nexport var friday = weekday(5);\nexport var saturday = weekday(6);\n\nexport var sundays = sunday.range;\nexport var mondays = monday.range;\nexport var tuesdays = tuesday.range;\nexport var wednesdays = wednesday.range;\nexport var thursdays = thursday.range;\nexport var fridays = friday.range;\nexport var saturdays = saturday.range;\n","import interval from \"./interval.js\";\n\nvar year = interval(function(date) {\n date.setMonth(0, 1);\n date.setHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setFullYear(date.getFullYear() + step);\n}, function(start, end) {\n return end.getFullYear() - start.getFullYear();\n}, function(date) {\n return date.getFullYear();\n});\n\n// An optimized implementation for this simple case.\nyear.every = function(k) {\n return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : interval(function(date) {\n date.setFullYear(Math.floor(date.getFullYear() / k) * k);\n date.setMonth(0, 1);\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setFullYear(date.getFullYear() + step * k);\n });\n};\n\nexport default year;\nexport var years = year.range;\n","'use strict';\n\nvar $defineProperty = require('es-define-property');\n\nvar $SyntaxError = require('es-errors/syntax');\nvar $TypeError = require('es-errors/type');\n\nvar gopd = require('gopd');\n\n/** @type {import('.')} */\nmodule.exports = function defineDataProperty(\n\tobj,\n\tproperty,\n\tvalue\n) {\n\tif (!obj || (typeof obj !== 'object' && typeof obj !== 'function')) {\n\t\tthrow new $TypeError('`obj` must be an object or a function`');\n\t}\n\tif (typeof property !== 'string' && typeof property !== 'symbol') {\n\t\tthrow new $TypeError('`property` must be a string or a symbol`');\n\t}\n\tif (arguments.length > 3 && typeof arguments[3] !== 'boolean' && arguments[3] !== null) {\n\t\tthrow new $TypeError('`nonEnumerable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 4 && typeof arguments[4] !== 'boolean' && arguments[4] !== null) {\n\t\tthrow new $TypeError('`nonWritable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 5 && typeof arguments[5] !== 'boolean' && arguments[5] !== null) {\n\t\tthrow new $TypeError('`nonConfigurable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 6 && typeof arguments[6] !== 'boolean') {\n\t\tthrow new $TypeError('`loose`, if provided, must be a boolean');\n\t}\n\n\tvar nonEnumerable = arguments.length > 3 ? arguments[3] : null;\n\tvar nonWritable = arguments.length > 4 ? arguments[4] : null;\n\tvar nonConfigurable = arguments.length > 5 ? arguments[5] : null;\n\tvar loose = arguments.length > 6 ? arguments[6] : false;\n\n\t/* @type {false | TypedPropertyDescriptor} */\n\tvar desc = !!gopd && gopd(obj, property);\n\n\tif ($defineProperty) {\n\t\t$defineProperty(obj, property, {\n\t\t\tconfigurable: nonConfigurable === null && desc ? desc.configurable : !nonConfigurable,\n\t\t\tenumerable: nonEnumerable === null && desc ? desc.enumerable : !nonEnumerable,\n\t\t\tvalue: value,\n\t\t\twritable: nonWritable === null && desc ? desc.writable : !nonWritable\n\t\t});\n\t} else if (loose || (!nonEnumerable && !nonWritable && !nonConfigurable)) {\n\t\t// must fall back to [[Set]], and was not explicitly asked to make non-enumerable, non-writable, or non-configurable\n\t\tobj[property] = value; // eslint-disable-line no-param-reassign\n\t} else {\n\t\tthrow new $SyntaxError('This environment does not support defining a property as non-configurable, non-writable, or non-enumerable.');\n\t}\n};\n","'use strict';\n\nvar keys = require('object-keys');\nvar hasSymbols = typeof Symbol === 'function' && typeof Symbol('foo') === 'symbol';\n\nvar toStr = Object.prototype.toString;\nvar concat = Array.prototype.concat;\nvar defineDataProperty = require('define-data-property');\n\nvar isFunction = function (fn) {\n\treturn typeof fn === 'function' && toStr.call(fn) === '[object Function]';\n};\n\nvar supportsDescriptors = require('has-property-descriptors')();\n\nvar defineProperty = function (object, name, value, predicate) {\n\tif (name in object) {\n\t\tif (predicate === true) {\n\t\t\tif (object[name] === value) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t} else if (!isFunction(predicate) || !predicate()) {\n\t\t\treturn;\n\t\t}\n\t}\n\n\tif (supportsDescriptors) {\n\t\tdefineDataProperty(object, name, value, true);\n\t} else {\n\t\tdefineDataProperty(object, name, value);\n\t}\n};\n\nvar defineProperties = function (object, map) {\n\tvar predicates = arguments.length > 2 ? arguments[2] : {};\n\tvar props = keys(map);\n\tif (hasSymbols) {\n\t\tprops = concat.call(props, Object.getOwnPropertySymbols(map));\n\t}\n\tfor (var i = 0; i < props.length; i += 1) {\n\t\tdefineProperty(object, props[i], map[props[i]], predicates[props[i]]);\n\t}\n};\n\ndefineProperties.supportsDescriptors = !!supportsDescriptors;\n\nmodule.exports = defineProperties;\n","'use strict';\n\nmodule.exports = function defined() {\n\tfor (var i = 0; i < arguments.length; i++) {\n\t\tif (typeof arguments[i] !== 'undefined') {\n\t\t\treturn arguments[i];\n\t\t}\n\t}\n};\n","'use strict'\r\n\r\n\r\nmodule.exports = kerning\r\n\r\n\r\nvar canvas = kerning.canvas = document.createElement('canvas')\r\nvar ctx = canvas.getContext('2d')\r\nvar asciiPairs = createPairs([32, 126])\r\n\r\nkerning.createPairs = createPairs\r\nkerning.ascii = asciiPairs\r\n\r\n\r\nfunction kerning (family, o) {\r\n\tif (Array.isArray(family)) family = family.join(', ')\r\n\r\n\tvar table = {}, pairs, fs = 16, threshold = .05\r\n\r\n\tif (o) {\r\n\t\tif (o.length === 2 && typeof o[0] === 'number') {\r\n\t\t\tpairs = createPairs(o)\r\n\t\t}\r\n\t\telse if (Array.isArray(o)) {\r\n\t\t\tpairs = o\r\n\t\t}\r\n\t\telse {\r\n\t\t\tif (o.o) pairs = createPairs(o.o)\r\n\t\t\telse if (o.pairs) pairs = o.pairs\r\n\r\n\t\t\tif (o.fontSize) fs = o.fontSize\r\n\t\t\tif (o.threshold != null) threshold = o.threshold\r\n\t\t}\r\n\t}\r\n\r\n\tif (!pairs) pairs = asciiPairs\r\n\r\n\tctx.font = fs + 'px ' + family\r\n\r\n\tfor (var i = 0; i < pairs.length; i++) {\r\n\t\tvar pair = pairs[i]\r\n\t\tvar width = ctx.measureText(pair[0]).width + ctx.measureText(pair[1]).width\r\n\t\tvar kerningWidth = ctx.measureText(pair).width\r\n\t\tif (Math.abs(width - kerningWidth) > fs * threshold) {\r\n\t\t\tvar emWidth = (kerningWidth - width) / fs\r\n\t\t\ttable[pair] = emWidth * 1000\r\n\t\t}\r\n\t}\r\n\r\n\treturn table\r\n}\r\n\r\n\r\nfunction createPairs (range) {\r\n\tvar pairs = []\r\n\r\n for (var i = range[0]; i <= range[1]; i++) {\r\n\t\tvar leftChar = String.fromCharCode(i)\r\n\t\tfor (var j = range[0]; j < range[1]; j++) {\r\n\t\t\tvar rightChar = String.fromCharCode(j)\r\n\t\t\tvar pair = leftChar + rightChar\r\n\r\n\t\t\tpairs.push(pair)\r\n\t\t}\r\n\t}\r\n\r\n\treturn pairs\r\n}\r\n","var abs = require('abs-svg-path')\nvar normalize = require('normalize-svg-path')\n\nvar methods = {\n 'M': 'moveTo',\n 'C': 'bezierCurveTo'\n}\n\nmodule.exports = function(context, segments) {\n context.beginPath()\n\n // Make path easy to reproduce.\n normalize(abs(segments)).forEach(\n function(segment) {\n var command = segment[0]\n var args = segment.slice(1)\n\n // Convert the path command to a context method.\n context[methods[command]].apply(context, args)\n }\n )\n\n context.closePath()\n}\n","\nvar π = Math.PI\nvar _120 = radians(120)\n\nmodule.exports = normalize\n\n/**\n * describe `path` in terms of cubic bézier \n * curves and move commands\n *\n * @param {Array} path\n * @return {Array}\n */\n\nfunction normalize(path){\n\t// init state\n\tvar prev\n\tvar result = []\n\tvar bezierX = 0\n\tvar bezierY = 0\n\tvar startX = 0\n\tvar startY = 0\n\tvar quadX = null\n\tvar quadY = null\n\tvar x = 0\n\tvar y = 0\n\n\tfor (var i = 0, len = path.length; i < len; i++) {\n\t\tvar seg = path[i]\n\t\tvar command = seg[0]\n\t\tswitch (command) {\n\t\t\tcase 'M':\n\t\t\t\tstartX = seg[1]\n\t\t\t\tstartY = seg[2]\n\t\t\t\tbreak\n\t\t\tcase 'A':\n\t\t\t\tseg = arc(x, y,seg[1],seg[2],radians(seg[3]),seg[4],seg[5],seg[6],seg[7])\n\t\t\t\t// split multi part\n\t\t\t\tseg.unshift('C')\n\t\t\t\tif (seg.length > 7) {\n\t\t\t\t\tresult.push(seg.splice(0, 7))\n\t\t\t\t\tseg.unshift('C')\n\t\t\t\t}\n\t\t\t\tbreak\n\t\t\tcase 'S':\n\t\t\t\t// default control point\n\t\t\t\tvar cx = x\n\t\t\t\tvar cy = y\n\t\t\t\tif (prev == 'C' || prev == 'S') {\n\t\t\t\t\tcx += cx - bezierX // reflect the previous command's control\n\t\t\t\t\tcy += cy - bezierY // point relative to the current point\n\t\t\t\t}\n\t\t\t\tseg = ['C', cx, cy, seg[1], seg[2], seg[3], seg[4]]\n\t\t\t\tbreak\n\t\t\tcase 'T':\n\t\t\t\tif (prev == 'Q' || prev == 'T') {\n\t\t\t\t\tquadX = x * 2 - quadX // as with 'S' reflect previous control point\n\t\t\t\t\tquadY = y * 2 - quadY\n\t\t\t\t} else {\n\t\t\t\t\tquadX = x\n\t\t\t\t\tquadY = y\n\t\t\t\t}\n\t\t\t\tseg = quadratic(x, y, quadX, quadY, seg[1], seg[2])\n\t\t\t\tbreak\n\t\t\tcase 'Q':\n\t\t\t\tquadX = seg[1]\n\t\t\t\tquadY = seg[2]\n\t\t\t\tseg = quadratic(x, y, seg[1], seg[2], seg[3], seg[4])\n\t\t\t\tbreak\n\t\t\tcase 'L':\n\t\t\t\tseg = line(x, y, seg[1], seg[2])\n\t\t\t\tbreak\n\t\t\tcase 'H':\n\t\t\t\tseg = line(x, y, seg[1], y)\n\t\t\t\tbreak\n\t\t\tcase 'V':\n\t\t\t\tseg = line(x, y, x, seg[1])\n\t\t\t\tbreak\n\t\t\tcase 'Z':\n\t\t\t\tseg = line(x, y, startX, startY)\n\t\t\t\tbreak\n\t\t}\n\n\t\t// update state\n\t\tprev = command\n\t\tx = seg[seg.length - 2]\n\t\ty = seg[seg.length - 1]\n\t\tif (seg.length > 4) {\n\t\t\tbezierX = seg[seg.length - 4]\n\t\t\tbezierY = seg[seg.length - 3]\n\t\t} else {\n\t\t\tbezierX = x\n\t\t\tbezierY = y\n\t\t}\n\t\tresult.push(seg)\n\t}\n\n\treturn result\n}\n\nfunction line(x1, y1, x2, y2){\n\treturn ['C', x1, y1, x2, y2, x2, y2]\n}\n\nfunction quadratic(x1, y1, cx, cy, x2, y2){\n\treturn [\n\t\t'C',\n\t\tx1/3 + (2/3) * cx,\n\t\ty1/3 + (2/3) * cy,\n\t\tx2/3 + (2/3) * cx,\n\t\ty2/3 + (2/3) * cy,\n\t\tx2,\n\t\ty2\n\t]\n}\n\n// This function is ripped from \n// github.com/DmitryBaranovskiy/raphael/blob/4d97d4/raphael.js#L2216-L2304 \n// which references w3.org/TR/SVG11/implnote.html#ArcImplementationNotes\n// TODO: make it human readable\n\nfunction arc(x1, y1, rx, ry, angle, large_arc_flag, sweep_flag, x2, y2, recursive) {\n\tif (!recursive) {\n\t\tvar xy = rotate(x1, y1, -angle)\n\t\tx1 = xy.x\n\t\ty1 = xy.y\n\t\txy = rotate(x2, y2, -angle)\n\t\tx2 = xy.x\n\t\ty2 = xy.y\n\t\tvar x = (x1 - x2) / 2\n\t\tvar y = (y1 - y2) / 2\n\t\tvar h = (x * x) / (rx * rx) + (y * y) / (ry * ry)\n\t\tif (h > 1) {\n\t\t\th = Math.sqrt(h)\n\t\t\trx = h * rx\n\t\t\try = h * ry\n\t\t}\n\t\tvar rx2 = rx * rx\n\t\tvar ry2 = ry * ry\n\t\tvar k = (large_arc_flag == sweep_flag ? -1 : 1)\n\t\t\t* Math.sqrt(Math.abs((rx2 * ry2 - rx2 * y * y - ry2 * x * x) / (rx2 * y * y + ry2 * x * x)))\n\t\tif (k == Infinity) k = 1 // neutralize\n\t\tvar cx = k * rx * y / ry + (x1 + x2) / 2\n\t\tvar cy = k * -ry * x / rx + (y1 + y2) / 2\n\t\tvar f1 = Math.asin(((y1 - cy) / ry).toFixed(9))\n\t\tvar f2 = Math.asin(((y2 - cy) / ry).toFixed(9))\n\n\t\tf1 = x1 < cx ? π - f1 : f1\n\t\tf2 = x2 < cx ? π - f2 : f2\n\t\tif (f1 < 0) f1 = π * 2 + f1\n\t\tif (f2 < 0) f2 = π * 2 + f2\n\t\tif (sweep_flag && f1 > f2) f1 = f1 - π * 2\n\t\tif (!sweep_flag && f2 > f1) f2 = f2 - π * 2\n\t} else {\n\t\tf1 = recursive[0]\n\t\tf2 = recursive[1]\n\t\tcx = recursive[2]\n\t\tcy = recursive[3]\n\t}\n\t// greater than 120 degrees requires multiple segments\n\tif (Math.abs(f2 - f1) > _120) {\n\t\tvar f2old = f2\n\t\tvar x2old = x2\n\t\tvar y2old = y2\n\t\tf2 = f1 + _120 * (sweep_flag && f2 > f1 ? 1 : -1)\n\t\tx2 = cx + rx * Math.cos(f2)\n\t\ty2 = cy + ry * Math.sin(f2)\n\t\tvar res = arc(x2, y2, rx, ry, angle, 0, sweep_flag, x2old, y2old, [f2, f2old, cx, cy])\n\t}\n\tvar t = Math.tan((f2 - f1) / 4)\n\tvar hx = 4 / 3 * rx * t\n\tvar hy = 4 / 3 * ry * t\n\tvar curve = [\n\t\t2 * x1 - (x1 + hx * Math.sin(f1)),\n\t\t2 * y1 - (y1 - hy * Math.cos(f1)),\n\t\tx2 + hx * Math.sin(f2),\n\t\ty2 - hy * Math.cos(f2),\n\t\tx2,\n\t\ty2\n\t]\n\tif (recursive) return curve\n\tif (res) curve = curve.concat(res)\n\tfor (var i = 0; i < curve.length;) {\n\t\tvar rot = rotate(curve[i], curve[i+1], angle)\n\t\tcurve[i++] = rot.x\n\t\tcurve[i++] = rot.y\n\t}\n\treturn curve\n}\n\nfunction rotate(x, y, rad){\n\treturn {\n\t\tx: x * Math.cos(rad) - y * Math.sin(rad),\n\t\ty: x * Math.sin(rad) + y * Math.cos(rad)\n\t}\n}\n\nfunction radians(degress){\n\treturn degress * (π / 180)\n}\n","module.exports = function(dtype) {\n switch (dtype) {\n case 'int8':\n return Int8Array\n case 'int16':\n return Int16Array\n case 'int32':\n return Int32Array\n case 'uint8':\n return Uint8Array\n case 'uint16':\n return Uint16Array\n case 'uint32':\n return Uint32Array\n case 'float32':\n return Float32Array\n case 'float64':\n return Float64Array\n case 'array':\n return Array\n case 'uint8_clamped':\n return Uint8ClampedArray\n }\n}\n","\"use strict\"\n\nfunction dupe_array(count, value, i) {\n var c = count[i]|0\n if(c <= 0) {\n return []\n }\n var result = new Array(c), j\n if(i === count.length-1) {\n for(j=0; j 0) {\n return dupe_number(count|0, value)\n }\n break\n case \"object\":\n if(typeof (count.length) === \"number\") {\n return dupe_array(count, value, 0)\n }\n break\n }\n return []\n}\n\nmodule.exports = dupe","'use strict';\n\nmodule.exports = earcut;\nmodule.exports.default = earcut;\n\nfunction earcut(data, holeIndices, dim) {\n\n dim = dim || 2;\n\n var hasHoles = holeIndices && holeIndices.length,\n outerLen = hasHoles ? holeIndices[0] * dim : data.length,\n outerNode = linkedList(data, 0, outerLen, dim, true),\n triangles = [];\n\n if (!outerNode || outerNode.next === outerNode.prev) return triangles;\n\n var minX, minY, maxX, maxY, x, y, invSize;\n\n if (hasHoles) outerNode = eliminateHoles(data, holeIndices, outerNode, dim);\n\n // if the shape is not too simple, we'll use z-order curve hash later; calculate polygon bbox\n if (data.length > 80 * dim) {\n minX = maxX = data[0];\n minY = maxY = data[1];\n\n for (var i = dim; i < outerLen; i += dim) {\n x = data[i];\n y = data[i + 1];\n if (x < minX) minX = x;\n if (y < minY) minY = y;\n if (x > maxX) maxX = x;\n if (y > maxY) maxY = y;\n }\n\n // minX, minY and invSize are later used to transform coords into integers for z-order calculation\n invSize = Math.max(maxX - minX, maxY - minY);\n invSize = invSize !== 0 ? 32767 / invSize : 0;\n }\n\n earcutLinked(outerNode, triangles, dim, minX, minY, invSize, 0);\n\n return triangles;\n}\n\n// create a circular doubly linked list from polygon points in the specified winding order\nfunction linkedList(data, start, end, dim, clockwise) {\n var i, last;\n\n if (clockwise === (signedArea(data, start, end, dim) > 0)) {\n for (i = start; i < end; i += dim) last = insertNode(i, data[i], data[i + 1], last);\n } else {\n for (i = end - dim; i >= start; i -= dim) last = insertNode(i, data[i], data[i + 1], last);\n }\n\n if (last && equals(last, last.next)) {\n removeNode(last);\n last = last.next;\n }\n\n return last;\n}\n\n// eliminate colinear or duplicate points\nfunction filterPoints(start, end) {\n if (!start) return start;\n if (!end) end = start;\n\n var p = start,\n again;\n do {\n again = false;\n\n if (!p.steiner && (equals(p, p.next) || area(p.prev, p, p.next) === 0)) {\n removeNode(p);\n p = end = p.prev;\n if (p === p.next) break;\n again = true;\n\n } else {\n p = p.next;\n }\n } while (again || p !== end);\n\n return end;\n}\n\n// main ear slicing loop which triangulates a polygon (given as a linked list)\nfunction earcutLinked(ear, triangles, dim, minX, minY, invSize, pass) {\n if (!ear) return;\n\n // interlink polygon nodes in z-order\n if (!pass && invSize) indexCurve(ear, minX, minY, invSize);\n\n var stop = ear,\n prev, next;\n\n // iterate through ears, slicing them one by one\n while (ear.prev !== ear.next) {\n prev = ear.prev;\n next = ear.next;\n\n if (invSize ? isEarHashed(ear, minX, minY, invSize) : isEar(ear)) {\n // cut off the triangle\n triangles.push(prev.i / dim | 0);\n triangles.push(ear.i / dim | 0);\n triangles.push(next.i / dim | 0);\n\n removeNode(ear);\n\n // skipping the next vertex leads to less sliver triangles\n ear = next.next;\n stop = next.next;\n\n continue;\n }\n\n ear = next;\n\n // if we looped through the whole remaining polygon and can't find any more ears\n if (ear === stop) {\n // try filtering points and slicing again\n if (!pass) {\n earcutLinked(filterPoints(ear), triangles, dim, minX, minY, invSize, 1);\n\n // if this didn't work, try curing all small self-intersections locally\n } else if (pass === 1) {\n ear = cureLocalIntersections(filterPoints(ear), triangles, dim);\n earcutLinked(ear, triangles, dim, minX, minY, invSize, 2);\n\n // as a last resort, try splitting the remaining polygon into two\n } else if (pass === 2) {\n splitEarcut(ear, triangles, dim, minX, minY, invSize);\n }\n\n break;\n }\n }\n}\n\n// check whether a polygon node forms a valid ear with adjacent nodes\nfunction isEar(ear) {\n var a = ear.prev,\n b = ear,\n c = ear.next;\n\n if (area(a, b, c) >= 0) return false; // reflex, can't be an ear\n\n // now make sure we don't have other points inside the potential ear\n var ax = a.x, bx = b.x, cx = c.x, ay = a.y, by = b.y, cy = c.y;\n\n // triangle bbox; min & max are calculated like this for speed\n var x0 = ax < bx ? (ax < cx ? ax : cx) : (bx < cx ? bx : cx),\n y0 = ay < by ? (ay < cy ? ay : cy) : (by < cy ? by : cy),\n x1 = ax > bx ? (ax > cx ? ax : cx) : (bx > cx ? bx : cx),\n y1 = ay > by ? (ay > cy ? ay : cy) : (by > cy ? by : cy);\n\n var p = c.next;\n while (p !== a) {\n if (p.x >= x0 && p.x <= x1 && p.y >= y0 && p.y <= y1 &&\n pointInTriangle(ax, ay, bx, by, cx, cy, p.x, p.y) &&\n area(p.prev, p, p.next) >= 0) return false;\n p = p.next;\n }\n\n return true;\n}\n\nfunction isEarHashed(ear, minX, minY, invSize) {\n var a = ear.prev,\n b = ear,\n c = ear.next;\n\n if (area(a, b, c) >= 0) return false; // reflex, can't be an ear\n\n var ax = a.x, bx = b.x, cx = c.x, ay = a.y, by = b.y, cy = c.y;\n\n // triangle bbox; min & max are calculated like this for speed\n var x0 = ax < bx ? (ax < cx ? ax : cx) : (bx < cx ? bx : cx),\n y0 = ay < by ? (ay < cy ? ay : cy) : (by < cy ? by : cy),\n x1 = ax > bx ? (ax > cx ? ax : cx) : (bx > cx ? bx : cx),\n y1 = ay > by ? (ay > cy ? ay : cy) : (by > cy ? by : cy);\n\n // z-order range for the current triangle bbox;\n var minZ = zOrder(x0, y0, minX, minY, invSize),\n maxZ = zOrder(x1, y1, minX, minY, invSize);\n\n var p = ear.prevZ,\n n = ear.nextZ;\n\n // look for points inside the triangle in both directions\n while (p && p.z >= minZ && n && n.z <= maxZ) {\n if (p.x >= x0 && p.x <= x1 && p.y >= y0 && p.y <= y1 && p !== a && p !== c &&\n pointInTriangle(ax, ay, bx, by, cx, cy, p.x, p.y) && area(p.prev, p, p.next) >= 0) return false;\n p = p.prevZ;\n\n if (n.x >= x0 && n.x <= x1 && n.y >= y0 && n.y <= y1 && n !== a && n !== c &&\n pointInTriangle(ax, ay, bx, by, cx, cy, n.x, n.y) && area(n.prev, n, n.next) >= 0) return false;\n n = n.nextZ;\n }\n\n // look for remaining points in decreasing z-order\n while (p && p.z >= minZ) {\n if (p.x >= x0 && p.x <= x1 && p.y >= y0 && p.y <= y1 && p !== a && p !== c &&\n pointInTriangle(ax, ay, bx, by, cx, cy, p.x, p.y) && area(p.prev, p, p.next) >= 0) return false;\n p = p.prevZ;\n }\n\n // look for remaining points in increasing z-order\n while (n && n.z <= maxZ) {\n if (n.x >= x0 && n.x <= x1 && n.y >= y0 && n.y <= y1 && n !== a && n !== c &&\n pointInTriangle(ax, ay, bx, by, cx, cy, n.x, n.y) && area(n.prev, n, n.next) >= 0) return false;\n n = n.nextZ;\n }\n\n return true;\n}\n\n// go through all polygon nodes and cure small local self-intersections\nfunction cureLocalIntersections(start, triangles, dim) {\n var p = start;\n do {\n var a = p.prev,\n b = p.next.next;\n\n if (!equals(a, b) && intersects(a, p, p.next, b) && locallyInside(a, b) && locallyInside(b, a)) {\n\n triangles.push(a.i / dim | 0);\n triangles.push(p.i / dim | 0);\n triangles.push(b.i / dim | 0);\n\n // remove two nodes involved\n removeNode(p);\n removeNode(p.next);\n\n p = start = b;\n }\n p = p.next;\n } while (p !== start);\n\n return filterPoints(p);\n}\n\n// try splitting polygon into two and triangulate them independently\nfunction splitEarcut(start, triangles, dim, minX, minY, invSize) {\n // look for a valid diagonal that divides the polygon into two\n var a = start;\n do {\n var b = a.next.next;\n while (b !== a.prev) {\n if (a.i !== b.i && isValidDiagonal(a, b)) {\n // split the polygon in two by the diagonal\n var c = splitPolygon(a, b);\n\n // filter colinear points around the cuts\n a = filterPoints(a, a.next);\n c = filterPoints(c, c.next);\n\n // run earcut on each half\n earcutLinked(a, triangles, dim, minX, minY, invSize, 0);\n earcutLinked(c, triangles, dim, minX, minY, invSize, 0);\n return;\n }\n b = b.next;\n }\n a = a.next;\n } while (a !== start);\n}\n\n// link every hole into the outer loop, producing a single-ring polygon without holes\nfunction eliminateHoles(data, holeIndices, outerNode, dim) {\n var queue = [],\n i, len, start, end, list;\n\n for (i = 0, len = holeIndices.length; i < len; i++) {\n start = holeIndices[i] * dim;\n end = i < len - 1 ? holeIndices[i + 1] * dim : data.length;\n list = linkedList(data, start, end, dim, false);\n if (list === list.next) list.steiner = true;\n queue.push(getLeftmost(list));\n }\n\n queue.sort(compareX);\n\n // process holes from left to right\n for (i = 0; i < queue.length; i++) {\n outerNode = eliminateHole(queue[i], outerNode);\n }\n\n return outerNode;\n}\n\nfunction compareX(a, b) {\n return a.x - b.x;\n}\n\n// find a bridge between vertices that connects hole with an outer ring and and link it\nfunction eliminateHole(hole, outerNode) {\n var bridge = findHoleBridge(hole, outerNode);\n if (!bridge) {\n return outerNode;\n }\n\n var bridgeReverse = splitPolygon(bridge, hole);\n\n // filter collinear points around the cuts\n filterPoints(bridgeReverse, bridgeReverse.next);\n return filterPoints(bridge, bridge.next);\n}\n\n// David Eberly's algorithm for finding a bridge between hole and outer polygon\nfunction findHoleBridge(hole, outerNode) {\n var p = outerNode,\n hx = hole.x,\n hy = hole.y,\n qx = -Infinity,\n m;\n\n // find a segment intersected by a ray from the hole's leftmost point to the left;\n // segment's endpoint with lesser x will be potential connection point\n do {\n if (hy <= p.y && hy >= p.next.y && p.next.y !== p.y) {\n var x = p.x + (hy - p.y) * (p.next.x - p.x) / (p.next.y - p.y);\n if (x <= hx && x > qx) {\n qx = x;\n m = p.x < p.next.x ? p : p.next;\n if (x === hx) return m; // hole touches outer segment; pick leftmost endpoint\n }\n }\n p = p.next;\n } while (p !== outerNode);\n\n if (!m) return null;\n\n // look for points inside the triangle of hole point, segment intersection and endpoint;\n // if there are no points found, we have a valid connection;\n // otherwise choose the point of the minimum angle with the ray as connection point\n\n var stop = m,\n mx = m.x,\n my = m.y,\n tanMin = Infinity,\n tan;\n\n p = m;\n\n do {\n if (hx >= p.x && p.x >= mx && hx !== p.x &&\n pointInTriangle(hy < my ? hx : qx, hy, mx, my, hy < my ? qx : hx, hy, p.x, p.y)) {\n\n tan = Math.abs(hy - p.y) / (hx - p.x); // tangential\n\n if (locallyInside(p, hole) &&\n (tan < tanMin || (tan === tanMin && (p.x > m.x || (p.x === m.x && sectorContainsSector(m, p)))))) {\n m = p;\n tanMin = tan;\n }\n }\n\n p = p.next;\n } while (p !== stop);\n\n return m;\n}\n\n// whether sector in vertex m contains sector in vertex p in the same coordinates\nfunction sectorContainsSector(m, p) {\n return area(m.prev, m, p.prev) < 0 && area(p.next, m, m.next) < 0;\n}\n\n// interlink polygon nodes in z-order\nfunction indexCurve(start, minX, minY, invSize) {\n var p = start;\n do {\n if (p.z === 0) p.z = zOrder(p.x, p.y, minX, minY, invSize);\n p.prevZ = p.prev;\n p.nextZ = p.next;\n p = p.next;\n } while (p !== start);\n\n p.prevZ.nextZ = null;\n p.prevZ = null;\n\n sortLinked(p);\n}\n\n// Simon Tatham's linked list merge sort algorithm\n// http://www.chiark.greenend.org.uk/~sgtatham/algorithms/listsort.html\nfunction sortLinked(list) {\n var i, p, q, e, tail, numMerges, pSize, qSize,\n inSize = 1;\n\n do {\n p = list;\n list = null;\n tail = null;\n numMerges = 0;\n\n while (p) {\n numMerges++;\n q = p;\n pSize = 0;\n for (i = 0; i < inSize; i++) {\n pSize++;\n q = q.nextZ;\n if (!q) break;\n }\n qSize = inSize;\n\n while (pSize > 0 || (qSize > 0 && q)) {\n\n if (pSize !== 0 && (qSize === 0 || !q || p.z <= q.z)) {\n e = p;\n p = p.nextZ;\n pSize--;\n } else {\n e = q;\n q = q.nextZ;\n qSize--;\n }\n\n if (tail) tail.nextZ = e;\n else list = e;\n\n e.prevZ = tail;\n tail = e;\n }\n\n p = q;\n }\n\n tail.nextZ = null;\n inSize *= 2;\n\n } while (numMerges > 1);\n\n return list;\n}\n\n// z-order of a point given coords and inverse of the longer side of data bbox\nfunction zOrder(x, y, minX, minY, invSize) {\n // coords are transformed into non-negative 15-bit integer range\n x = (x - minX) * invSize | 0;\n y = (y - minY) * invSize | 0;\n\n x = (x | (x << 8)) & 0x00FF00FF;\n x = (x | (x << 4)) & 0x0F0F0F0F;\n x = (x | (x << 2)) & 0x33333333;\n x = (x | (x << 1)) & 0x55555555;\n\n y = (y | (y << 8)) & 0x00FF00FF;\n y = (y | (y << 4)) & 0x0F0F0F0F;\n y = (y | (y << 2)) & 0x33333333;\n y = (y | (y << 1)) & 0x55555555;\n\n return x | (y << 1);\n}\n\n// find the leftmost node of a polygon ring\nfunction getLeftmost(start) {\n var p = start,\n leftmost = start;\n do {\n if (p.x < leftmost.x || (p.x === leftmost.x && p.y < leftmost.y)) leftmost = p;\n p = p.next;\n } while (p !== start);\n\n return leftmost;\n}\n\n// check if a point lies within a convex triangle\nfunction pointInTriangle(ax, ay, bx, by, cx, cy, px, py) {\n return (cx - px) * (ay - py) >= (ax - px) * (cy - py) &&\n (ax - px) * (by - py) >= (bx - px) * (ay - py) &&\n (bx - px) * (cy - py) >= (cx - px) * (by - py);\n}\n\n// check if a diagonal between two polygon nodes is valid (lies in polygon interior)\nfunction isValidDiagonal(a, b) {\n return a.next.i !== b.i && a.prev.i !== b.i && !intersectsPolygon(a, b) && // dones't intersect other edges\n (locallyInside(a, b) && locallyInside(b, a) && middleInside(a, b) && // locally visible\n (area(a.prev, a, b.prev) || area(a, b.prev, b)) || // does not create opposite-facing sectors\n equals(a, b) && area(a.prev, a, a.next) > 0 && area(b.prev, b, b.next) > 0); // special zero-length case\n}\n\n// signed area of a triangle\nfunction area(p, q, r) {\n return (q.y - p.y) * (r.x - q.x) - (q.x - p.x) * (r.y - q.y);\n}\n\n// check if two points are equal\nfunction equals(p1, p2) {\n return p1.x === p2.x && p1.y === p2.y;\n}\n\n// check if two segments intersect\nfunction intersects(p1, q1, p2, q2) {\n var o1 = sign(area(p1, q1, p2));\n var o2 = sign(area(p1, q1, q2));\n var o3 = sign(area(p2, q2, p1));\n var o4 = sign(area(p2, q2, q1));\n\n if (o1 !== o2 && o3 !== o4) return true; // general case\n\n if (o1 === 0 && onSegment(p1, p2, q1)) return true; // p1, q1 and p2 are collinear and p2 lies on p1q1\n if (o2 === 0 && onSegment(p1, q2, q1)) return true; // p1, q1 and q2 are collinear and q2 lies on p1q1\n if (o3 === 0 && onSegment(p2, p1, q2)) return true; // p2, q2 and p1 are collinear and p1 lies on p2q2\n if (o4 === 0 && onSegment(p2, q1, q2)) return true; // p2, q2 and q1 are collinear and q1 lies on p2q2\n\n return false;\n}\n\n// for collinear points p, q, r, check if point q lies on segment pr\nfunction onSegment(p, q, r) {\n return q.x <= Math.max(p.x, r.x) && q.x >= Math.min(p.x, r.x) && q.y <= Math.max(p.y, r.y) && q.y >= Math.min(p.y, r.y);\n}\n\nfunction sign(num) {\n return num > 0 ? 1 : num < 0 ? -1 : 0;\n}\n\n// check if a polygon diagonal intersects any polygon segments\nfunction intersectsPolygon(a, b) {\n var p = a;\n do {\n if (p.i !== a.i && p.next.i !== a.i && p.i !== b.i && p.next.i !== b.i &&\n intersects(p, p.next, a, b)) return true;\n p = p.next;\n } while (p !== a);\n\n return false;\n}\n\n// check if a polygon diagonal is locally inside the polygon\nfunction locallyInside(a, b) {\n return area(a.prev, a, a.next) < 0 ?\n area(a, b, a.next) >= 0 && area(a, a.prev, b) >= 0 :\n area(a, b, a.prev) < 0 || area(a, a.next, b) < 0;\n}\n\n// check if the middle point of a polygon diagonal is inside the polygon\nfunction middleInside(a, b) {\n var p = a,\n inside = false,\n px = (a.x + b.x) / 2,\n py = (a.y + b.y) / 2;\n do {\n if (((p.y > py) !== (p.next.y > py)) && p.next.y !== p.y &&\n (px < (p.next.x - p.x) * (py - p.y) / (p.next.y - p.y) + p.x))\n inside = !inside;\n p = p.next;\n } while (p !== a);\n\n return inside;\n}\n\n// link two polygon vertices with a bridge; if the vertices belong to the same ring, it splits polygon into two;\n// if one belongs to the outer ring and another to a hole, it merges it into a single ring\nfunction splitPolygon(a, b) {\n var a2 = new Node(a.i, a.x, a.y),\n b2 = new Node(b.i, b.x, b.y),\n an = a.next,\n bp = b.prev;\n\n a.next = b;\n b.prev = a;\n\n a2.next = an;\n an.prev = a2;\n\n b2.next = a2;\n a2.prev = b2;\n\n bp.next = b2;\n b2.prev = bp;\n\n return b2;\n}\n\n// create a node and optionally link it with previous one (in a circular doubly linked list)\nfunction insertNode(i, x, y, last) {\n var p = new Node(i, x, y);\n\n if (!last) {\n p.prev = p;\n p.next = p;\n\n } else {\n p.next = last.next;\n p.prev = last;\n last.next.prev = p;\n last.next = p;\n }\n return p;\n}\n\nfunction removeNode(p) {\n p.next.prev = p.prev;\n p.prev.next = p.next;\n\n if (p.prevZ) p.prevZ.nextZ = p.nextZ;\n if (p.nextZ) p.nextZ.prevZ = p.prevZ;\n}\n\nfunction Node(i, x, y) {\n // vertex index in coordinates array\n this.i = i;\n\n // vertex coordinates\n this.x = x;\n this.y = y;\n\n // previous and next vertex nodes in a polygon ring\n this.prev = null;\n this.next = null;\n\n // z-order curve value\n this.z = 0;\n\n // previous and next nodes in z-order\n this.prevZ = null;\n this.nextZ = null;\n\n // indicates whether this is a steiner point\n this.steiner = false;\n}\n\n// return a percentage difference between the polygon area and its triangulation area;\n// used to verify correctness of triangulation\nearcut.deviation = function (data, holeIndices, dim, triangles) {\n var hasHoles = holeIndices && holeIndices.length;\n var outerLen = hasHoles ? holeIndices[0] * dim : data.length;\n\n var polygonArea = Math.abs(signedArea(data, 0, outerLen, dim));\n if (hasHoles) {\n for (var i = 0, len = holeIndices.length; i < len; i++) {\n var start = holeIndices[i] * dim;\n var end = i < len - 1 ? holeIndices[i + 1] * dim : data.length;\n polygonArea -= Math.abs(signedArea(data, start, end, dim));\n }\n }\n\n var trianglesArea = 0;\n for (i = 0; i < triangles.length; i += 3) {\n var a = triangles[i] * dim;\n var b = triangles[i + 1] * dim;\n var c = triangles[i + 2] * dim;\n trianglesArea += Math.abs(\n (data[a] - data[c]) * (data[b + 1] - data[a + 1]) -\n (data[a] - data[b]) * (data[c + 1] - data[a + 1]));\n }\n\n return polygonArea === 0 && trianglesArea === 0 ? 0 :\n Math.abs((trianglesArea - polygonArea) / polygonArea);\n};\n\nfunction signedArea(data, start, end, dim) {\n var sum = 0;\n for (var i = start, j = end - dim; i < end; i += dim) {\n sum += (data[j] - data[i]) * (data[i + 1] + data[j + 1]);\n j = i;\n }\n return sum;\n}\n\n// turn a polygon in a multi-dimensional array form (e.g. as in GeoJSON) into a form Earcut accepts\nearcut.flatten = function (data) {\n var dim = data[0][0].length,\n result = {vertices: [], holes: [], dimensions: dim},\n holeIndex = 0;\n\n for (var i = 0; i < data.length; i++) {\n for (var j = 0; j < data[i].length; j++) {\n for (var d = 0; d < dim; d++) result.vertices.push(data[i][j][d]);\n }\n if (i > 0) {\n holeIndex += data[i - 1].length;\n result.holes.push(holeIndex);\n }\n }\n return result;\n};\n","var tarjan = require('strongly-connected-components');\n\nmodule.exports = function findCircuits(edges, cb) {\n var circuits = []; // Output\n\n var stack = [];\n var blocked = [];\n var B = {};\n var Ak = [];\n var s;\n\n function unblock(u) {\n blocked[u] = false;\n if(B.hasOwnProperty(u)) {\n Object.keys(B[u]).forEach(function(w) {\n delete B[u][w];\n if(blocked[w]) {unblock(w);}\n });\n }\n }\n\n function circuit(v) {\n var found = false;\n\n stack.push(v);\n blocked[v] = true;\n\n // L1\n var i;\n var w;\n for(i = 0; i < Ak[v].length; i++) {\n w = Ak[v][i];\n if(w === s) {\n output(s, stack);\n found = true;\n } else if(!blocked[w]) {\n found = circuit(w);\n }\n }\n\n // L2\n if(found) {\n unblock(v);\n } else {\n for(i = 0; i < Ak[v].length; i++) {\n w = Ak[v][i];\n var entry = B[w];\n\n if(!entry) {\n entry = {};\n B[w] = entry;\n }\n\n entry[w] = true;\n }\n }\n stack.pop();\n return found;\n }\n\n function output(start, stack) {\n var cycle = [].concat(stack).concat(start);\n if(cb) {\n cb(cycle);\n } else {\n circuits.push(cycle);\n }\n }\n\n function subgraph(minId) {\n // Remove edges with indice smaller than minId\n for(var i = 0; i < edges.length; i++) {\n if(i < minId || !edges[i]) edges[i] = [];\n edges[i] = edges[i].filter(function(i) {\n return i >= minId;\n });\n }\n }\n\n function adjacencyStructureSCC(from) {\n // Make subgraph starting from vertex minId\n subgraph(from);\n var g = edges;\n\n // Find strongly connected components using Tarjan algorithm\n var sccs = tarjan(g);\n\n // Filter out trivial connected components (ie. made of one node)\n var ccs = sccs.components.filter(function(scc) {\n return scc.length > 1;\n });\n\n // Find least vertex\n var leastVertex = Infinity;\n var leastVertexComponent;\n for(var i = 0; i < ccs.length; i++) {\n for(var j = 0; j < ccs[i].length; j++) {\n if(ccs[i][j] < leastVertex) {\n leastVertex = ccs[i][j];\n leastVertexComponent = i;\n }\n }\n }\n\n var cc = ccs[leastVertexComponent];\n\n if(!cc) return false;\n\n // Return the adjacency list of first component\n var adjList = edges.map(function(l, index) {\n if(cc.indexOf(index) === -1) return [];\n return l.filter(function(i) {\n return cc.indexOf(i) !== -1;\n });\n });\n\n return {\n leastVertex: leastVertex,\n adjList: adjList\n };\n }\n\n s = 0;\n var n = edges.length;\n while(s < n) {\n // find strong component with least vertex in\n // subgraph starting from vertex `s`\n var p = adjacencyStructureSCC(s);\n\n // Its least vertex\n s = p.leastVertex;\n // Its adjacency list\n Ak = p.adjList;\n\n if(Ak) {\n for(var i = 0; i < Ak.length; i++) {\n for(var j = 0; j < Ak[i].length; j++) {\n var vertexId = Ak[i][j];\n blocked[+vertexId] = false;\n B[vertexId] = {};\n }\n }\n circuit(s);\n s = s + 1;\n } else {\n s = n;\n }\n\n }\n\n if(cb) {\n return;\n } else {\n return circuits;\n }\n};\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\n\n/** @type {import('.')} */\nvar $defineProperty = GetIntrinsic('%Object.defineProperty%', true) || false;\nif ($defineProperty) {\n\ttry {\n\t\t$defineProperty({}, 'a', { value: 1 });\n\t} catch (e) {\n\t\t// IE 8 has a broken defineProperty\n\t\t$defineProperty = false;\n\t}\n}\n\nmodule.exports = $defineProperty;\n","'use strict';\n\n/** @type {import('./eval')} */\nmodule.exports = EvalError;\n","'use strict';\n\n/** @type {import('.')} */\nmodule.exports = Error;\n","'use strict';\n\n/** @type {import('./range')} */\nmodule.exports = RangeError;\n","'use strict';\n\n/** @type {import('./ref')} */\nmodule.exports = ReferenceError;\n","'use strict';\n\n/** @type {import('./syntax')} */\nmodule.exports = SyntaxError;\n","'use strict';\n\n/** @type {import('./type')} */\nmodule.exports = TypeError;\n","'use strict';\n\n/** @type {import('./uri')} */\nmodule.exports = URIError;\n","// Inspired by Google Closure:\n// http://closure-library.googlecode.com/svn/docs/\n// closure_goog_array_array.js.html#goog.array.clear\n\n\"use strict\";\n\nvar value = require(\"../../object/valid-value\");\n\nmodule.exports = function () {\n\tvalue(this).length = 0;\n\treturn this;\n};\n","\"use strict\";\n\nmodule.exports = require(\"./is-implemented\")() ? Array.from : require(\"./shim\");\n","\"use strict\";\n\nmodule.exports = function () {\n\tvar from = Array.from, arr, result;\n\tif (typeof from !== \"function\") return false;\n\tarr = [\"raz\", \"dwa\"];\n\tresult = from(arr);\n\treturn Boolean(result && result !== arr && result[1] === \"dwa\");\n};\n","\"use strict\";\n\nvar iteratorSymbol = require(\"es6-symbol\").iterator\n , isArguments = require(\"../../function/is-arguments\")\n , isFunction = require(\"../../function/is-function\")\n , toPosInt = require(\"../../number/to-pos-integer\")\n , callable = require(\"../../object/valid-callable\")\n , validValue = require(\"../../object/valid-value\")\n , isValue = require(\"../../object/is-value\")\n , isString = require(\"../../string/is-string\")\n , isArray = Array.isArray\n , call = Function.prototype.call\n , desc = { configurable: true, enumerable: true, writable: true, value: null }\n , defineProperty = Object.defineProperty;\n\n// eslint-disable-next-line complexity, max-lines-per-function\nmodule.exports = function (arrayLike /*, mapFn, thisArg*/) {\n\tvar mapFn = arguments[1]\n\t , thisArg = arguments[2]\n\t , Context\n\t , i\n\t , j\n\t , arr\n\t , length\n\t , code\n\t , iterator\n\t , result\n\t , getIterator\n\t , value;\n\n\tarrayLike = Object(validValue(arrayLike));\n\n\tif (isValue(mapFn)) callable(mapFn);\n\tif (!this || this === Array || !isFunction(this)) {\n\t\t// Result: Plain array\n\t\tif (!mapFn) {\n\t\t\tif (isArguments(arrayLike)) {\n\t\t\t\t// Source: Arguments\n\t\t\t\tlength = arrayLike.length;\n\t\t\t\tif (length !== 1) return Array.apply(null, arrayLike);\n\t\t\t\tarr = new Array(1);\n\t\t\t\tarr[0] = arrayLike[0];\n\t\t\t\treturn arr;\n\t\t\t}\n\t\t\tif (isArray(arrayLike)) {\n\t\t\t\t// Source: Array\n\t\t\t\tarr = new Array((length = arrayLike.length));\n\t\t\t\tfor (i = 0; i < length; ++i) arr[i] = arrayLike[i];\n\t\t\t\treturn arr;\n\t\t\t}\n\t\t}\n\t\tarr = [];\n\t} else {\n\t\t// Result: Non plain array\n\t\tContext = this;\n\t}\n\n\tif (!isArray(arrayLike)) {\n\t\tif ((getIterator = arrayLike[iteratorSymbol]) !== undefined) {\n\t\t\t// Source: Iterator\n\t\t\titerator = callable(getIterator).call(arrayLike);\n\t\t\tif (Context) arr = new Context();\n\t\t\tresult = iterator.next();\n\t\t\ti = 0;\n\t\t\twhile (!result.done) {\n\t\t\t\tvalue = mapFn ? call.call(mapFn, thisArg, result.value, i) : result.value;\n\t\t\t\tif (Context) {\n\t\t\t\t\tdesc.value = value;\n\t\t\t\t\tdefineProperty(arr, i, desc);\n\t\t\t\t} else {\n\t\t\t\t\tarr[i] = value;\n\t\t\t\t}\n\t\t\t\tresult = iterator.next();\n\t\t\t\t++i;\n\t\t\t}\n\t\t\tlength = i;\n\t\t} else if (isString(arrayLike)) {\n\t\t\t// Source: String\n\t\t\tlength = arrayLike.length;\n\t\t\tif (Context) arr = new Context();\n\t\t\tfor (i = 0, j = 0; i < length; ++i) {\n\t\t\t\tvalue = arrayLike[i];\n\t\t\t\tif (i + 1 < length) {\n\t\t\t\t\tcode = value.charCodeAt(0);\n\t\t\t\t\t// eslint-disable-next-line max-depth\n\t\t\t\t\tif (code >= 0xd800 && code <= 0xdbff) value += arrayLike[++i];\n\t\t\t\t}\n\t\t\t\tvalue = mapFn ? call.call(mapFn, thisArg, value, j) : value;\n\t\t\t\tif (Context) {\n\t\t\t\t\tdesc.value = value;\n\t\t\t\t\tdefineProperty(arr, j, desc);\n\t\t\t\t} else {\n\t\t\t\t\tarr[j] = value;\n\t\t\t\t}\n\t\t\t\t++j;\n\t\t\t}\n\t\t\tlength = j;\n\t\t}\n\t}\n\tif (length === undefined) {\n\t\t// Source: array or array-like\n\t\tlength = toPosInt(arrayLike.length);\n\t\tif (Context) arr = new Context(length);\n\t\tfor (i = 0; i < length; ++i) {\n\t\t\tvalue = mapFn ? call.call(mapFn, thisArg, arrayLike[i], i) : arrayLike[i];\n\t\t\tif (Context) {\n\t\t\t\tdesc.value = value;\n\t\t\t\tdefineProperty(arr, i, desc);\n\t\t\t} else {\n\t\t\t\tarr[i] = value;\n\t\t\t}\n\t\t}\n\t}\n\tif (Context) {\n\t\tdesc.value = null;\n\t\tarr.length = length;\n\t}\n\treturn arr;\n};\n","\"use strict\";\n\nvar objToString = Object.prototype.toString\n , id = objToString.call((function () { return arguments; })());\n\nmodule.exports = function (value) { return objToString.call(value) === id; };\n","\"use strict\";\n\nvar objToString = Object.prototype.toString\n , isFunctionStringTag = RegExp.prototype.test.bind(/^[object [A-Za-z0-9]*Function]$/);\n\nmodule.exports = function (value) {\n\treturn typeof value === \"function\" && isFunctionStringTag(objToString.call(value));\n};\n","\"use strict\";\n\n// eslint-disable-next-line no-empty-function\nmodule.exports = function () {};\n","\"use strict\";\n\nmodule.exports = require(\"./is-implemented\")() ? Math.sign : require(\"./shim\");\n","\"use strict\";\n\nmodule.exports = function () {\n\tvar sign = Math.sign;\n\tif (typeof sign !== \"function\") return false;\n\treturn sign(10) === 1 && sign(-20) === -1;\n};\n","\"use strict\";\n\nmodule.exports = function (value) {\n\tvalue = Number(value);\n\tif (isNaN(value) || value === 0) return value;\n\treturn value > 0 ? 1 : -1;\n};\n","\"use strict\";\n\nvar sign = require(\"../math/sign\")\n , abs = Math.abs\n , floor = Math.floor;\n\nmodule.exports = function (value) {\n\tif (isNaN(value)) return 0;\n\tvalue = Number(value);\n\tif (value === 0 || !isFinite(value)) return value;\n\treturn sign(value) * floor(abs(value));\n};\n","\"use strict\";\n\nvar toInteger = require(\"./to-integer\")\n , max = Math.max;\n\nmodule.exports = function (value) { return max(0, toInteger(value)); };\n","// Internal method, used by iteration functions.\n// Calls a function for each key-value pair found in object\n// Optionally takes compareFn to iterate object in specific order\n\n\"use strict\";\n\nvar callable = require(\"./valid-callable\")\n , value = require(\"./valid-value\")\n , bind = Function.prototype.bind\n , call = Function.prototype.call\n , keys = Object.keys\n , objPropertyIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nmodule.exports = function (method, defVal) {\n\treturn function (obj, cb /*, thisArg, compareFn*/) {\n\t\tvar list, thisArg = arguments[2], compareFn = arguments[3];\n\t\tobj = Object(value(obj));\n\t\tcallable(cb);\n\n\t\tlist = keys(obj);\n\t\tif (compareFn) {\n\t\t\tlist.sort(typeof compareFn === \"function\" ? bind.call(compareFn, obj) : undefined);\n\t\t}\n\t\tif (typeof method !== \"function\") method = list[method];\n\t\treturn call.call(method, list, function (key, index) {\n\t\t\tif (!objPropertyIsEnumerable.call(obj, key)) return defVal;\n\t\t\treturn call.call(cb, thisArg, obj[key], key, obj, index);\n\t\t});\n\t};\n};\n","\"use strict\";\n\nmodule.exports = require(\"./is-implemented\")() ? Object.assign : require(\"./shim\");\n","\"use strict\";\n\nmodule.exports = function () {\n\tvar assign = Object.assign, obj;\n\tif (typeof assign !== \"function\") return false;\n\tobj = { foo: \"raz\" };\n\tassign(obj, { bar: \"dwa\" }, { trzy: \"trzy\" });\n\treturn obj.foo + obj.bar + obj.trzy === \"razdwatrzy\";\n};\n","\"use strict\";\n\nvar keys = require(\"../keys\")\n , value = require(\"../valid-value\")\n , max = Math.max;\n\nmodule.exports = function (dest, src /*, …srcn*/) {\n\tvar error, i, length = max(arguments.length, 2), assign;\n\tdest = Object(value(dest));\n\tassign = function (key) {\n\t\ttry {\n\t\t\tdest[key] = src[key];\n\t\t} catch (e) {\n\t\t\tif (!error) error = e;\n\t\t}\n\t};\n\tfor (i = 1; i < length; ++i) {\n\t\tsrc = arguments[i];\n\t\tkeys(src).forEach(assign);\n\t}\n\tif (error !== undefined) throw error;\n\treturn dest;\n};\n","\"use strict\";\n\nvar aFrom = require(\"../array/from\")\n , assign = require(\"./assign\")\n , value = require(\"./valid-value\");\n\nmodule.exports = function (obj /*, propertyNames, options*/) {\n\tvar copy = Object(value(obj)), propertyNames = arguments[1], options = Object(arguments[2]);\n\tif (copy !== obj && !propertyNames) return copy;\n\tvar result = {};\n\tif (propertyNames) {\n\t\taFrom(propertyNames, function (propertyName) {\n\t\t\tif (options.ensure || propertyName in obj) result[propertyName] = obj[propertyName];\n\t\t});\n\t} else {\n\t\tassign(result, obj);\n\t}\n\treturn result;\n};\n","// Workaround for http://code.google.com/p/v8/issues/detail?id=2804\n\n\"use strict\";\n\nvar create = Object.create, shim;\n\nif (!require(\"./set-prototype-of/is-implemented\")()) {\n\tshim = require(\"./set-prototype-of/shim\");\n}\n\nmodule.exports = (function () {\n\tvar nullObject, polyProps, desc;\n\tif (!shim) return create;\n\tif (shim.level !== 1) return create;\n\n\tnullObject = {};\n\tpolyProps = {};\n\tdesc = { configurable: false, enumerable: false, writable: true, value: undefined };\n\tObject.getOwnPropertyNames(Object.prototype).forEach(function (name) {\n\t\tif (name === \"__proto__\") {\n\t\t\tpolyProps[name] = {\n\t\t\t\tconfigurable: true,\n\t\t\t\tenumerable: false,\n\t\t\t\twritable: true,\n\t\t\t\tvalue: undefined\n\t\t\t};\n\t\t\treturn;\n\t\t}\n\t\tpolyProps[name] = desc;\n\t});\n\tObject.defineProperties(nullObject, polyProps);\n\n\tObject.defineProperty(shim, \"nullPolyfill\", {\n\t\tconfigurable: false,\n\t\tenumerable: false,\n\t\twritable: false,\n\t\tvalue: nullObject\n\t});\n\n\treturn function (prototype, props) {\n\t\treturn create(prototype === null ? nullObject : prototype, props);\n\t};\n})();\n","\"use strict\";\n\nmodule.exports = require(\"./_iterate\")(\"forEach\");\n","\"use strict\";\n\nvar isValue = require(\"./is-value\");\n\nvar map = { function: true, object: true };\n\nmodule.exports = function (value) { return (isValue(value) && map[typeof value]) || false; };\n","\"use strict\";\n\nvar _undefined = require(\"../function/noop\")(); // Support ES3 engines\n\nmodule.exports = function (val) { return val !== _undefined && val !== null; };\n","\"use strict\";\n\nmodule.exports = require(\"./is-implemented\")() ? Object.keys : require(\"./shim\");\n","\"use strict\";\n\nmodule.exports = function () {\n\ttry {\n\t\tObject.keys(\"primitive\");\n\t\treturn true;\n\t} catch (e) {\n\t\treturn false;\n\t}\n};\n","\"use strict\";\n\nvar isValue = require(\"../is-value\");\n\nvar keys = Object.keys;\n\nmodule.exports = function (object) { return keys(isValue(object) ? Object(object) : object); };\n","\"use strict\";\n\nvar callable = require(\"./valid-callable\")\n , forEach = require(\"./for-each\")\n , call = Function.prototype.call;\n\nmodule.exports = function (obj, cb /*, thisArg*/) {\n\tvar result = {}, thisArg = arguments[2];\n\tcallable(cb);\n\tforEach(obj, function (value, key, targetObj, index) {\n\t\tresult[key] = call.call(cb, thisArg, value, key, targetObj, index);\n\t});\n\treturn result;\n};\n","\"use strict\";\n\nvar isValue = require(\"./is-value\");\n\nvar forEach = Array.prototype.forEach, create = Object.create;\n\nvar process = function (src, obj) {\n\tvar key;\n\tfor (key in src) obj[key] = src[key];\n};\n\n// eslint-disable-next-line no-unused-vars\nmodule.exports = function (opts1 /*, …options*/) {\n\tvar result = create(null);\n\tforEach.call(arguments, function (options) {\n\t\tif (!isValue(options)) return;\n\t\tprocess(Object(options), result);\n\t});\n\treturn result;\n};\n","\"use strict\";\n\nmodule.exports = require(\"./is-implemented\")() ? Object.setPrototypeOf : require(\"./shim\");\n","\"use strict\";\n\nvar create = Object.create, getPrototypeOf = Object.getPrototypeOf, plainObject = {};\n\nmodule.exports = function (/* CustomCreate*/) {\n\tvar setPrototypeOf = Object.setPrototypeOf, customCreate = arguments[0] || create;\n\tif (typeof setPrototypeOf !== \"function\") return false;\n\treturn getPrototypeOf(setPrototypeOf(customCreate(null), plainObject)) === plainObject;\n};\n","/* eslint no-proto: \"off\" */\n\n// Big thanks to @WebReflection for sorting this out\n// https://gist.github.com/WebReflection/5593554\n\n\"use strict\";\n\nvar isObject = require(\"../is-object\")\n , value = require(\"../valid-value\")\n , objIsPrototypeOf = Object.prototype.isPrototypeOf\n , defineProperty = Object.defineProperty\n , nullDesc = { configurable: true, enumerable: false, writable: true, value: undefined }\n , validate;\n\nvalidate = function (obj, prototype) {\n\tvalue(obj);\n\tif (prototype === null || isObject(prototype)) return obj;\n\tthrow new TypeError(\"Prototype must be null or an object\");\n};\n\nmodule.exports = (function (status) {\n\tvar fn, set;\n\tif (!status) return null;\n\tif (status.level === 2) {\n\t\tif (status.set) {\n\t\t\tset = status.set;\n\t\t\tfn = function (obj, prototype) {\n\t\t\t\tset.call(validate(obj, prototype), prototype);\n\t\t\t\treturn obj;\n\t\t\t};\n\t\t} else {\n\t\t\tfn = function (obj, prototype) {\n\t\t\t\tvalidate(obj, prototype).__proto__ = prototype;\n\t\t\t\treturn obj;\n\t\t\t};\n\t\t}\n\t} else {\n\t\tfn = function self(obj, prototype) {\n\t\t\tvar isNullBase;\n\t\t\tvalidate(obj, prototype);\n\t\t\tisNullBase = objIsPrototypeOf.call(self.nullPolyfill, obj);\n\t\t\tif (isNullBase) delete self.nullPolyfill.__proto__;\n\t\t\tif (prototype === null) prototype = self.nullPolyfill;\n\t\t\tobj.__proto__ = prototype;\n\t\t\tif (isNullBase) defineProperty(self.nullPolyfill, \"__proto__\", nullDesc);\n\t\t\treturn obj;\n\t\t};\n\t}\n\treturn Object.defineProperty(fn, \"level\", {\n\t\tconfigurable: false,\n\t\tenumerable: false,\n\t\twritable: false,\n\t\tvalue: status.level\n\t});\n})(\n\t(function () {\n\t\tvar tmpObj1 = Object.create(null)\n\t\t , tmpObj2 = {}\n\t\t , set\n\t\t , desc = Object.getOwnPropertyDescriptor(Object.prototype, \"__proto__\");\n\n\t\tif (desc) {\n\t\t\ttry {\n\t\t\t\tset = desc.set; // Opera crashes at this point\n\t\t\t\tset.call(tmpObj1, tmpObj2);\n\t\t\t} catch (ignore) {}\n\t\t\tif (Object.getPrototypeOf(tmpObj1) === tmpObj2) return { set: set, level: 2 };\n\t\t}\n\n\t\ttmpObj1.__proto__ = tmpObj2;\n\t\tif (Object.getPrototypeOf(tmpObj1) === tmpObj2) return { level: 2 };\n\n\t\ttmpObj1 = {};\n\t\ttmpObj1.__proto__ = tmpObj2;\n\t\tif (Object.getPrototypeOf(tmpObj1) === tmpObj2) return { level: 1 };\n\n\t\treturn false;\n\t})()\n);\n\nrequire(\"../create\");\n","\"use strict\";\n\nmodule.exports = function (fn) {\n\tif (typeof fn !== \"function\") throw new TypeError(fn + \" is not a function\");\n\treturn fn;\n};\n","\"use strict\";\n\nvar isObject = require(\"./is-object\");\n\nmodule.exports = function (value) {\n\tif (!isObject(value)) throw new TypeError(value + \" is not an Object\");\n\treturn value;\n};\n","\"use strict\";\n\nvar isValue = require(\"./is-value\");\n\nmodule.exports = function (value) {\n\tif (!isValue(value)) throw new TypeError(\"Cannot use null or undefined\");\n\treturn value;\n};\n","\"use strict\";\n\nmodule.exports = require(\"./is-implemented\")() ? String.prototype.contains : require(\"./shim\");\n","\"use strict\";\n\nvar str = \"razdwatrzy\";\n\nmodule.exports = function () {\n\tif (typeof str.contains !== \"function\") return false;\n\treturn str.contains(\"dwa\") === true && str.contains(\"foo\") === false;\n};\n","\"use strict\";\n\nvar indexOf = String.prototype.indexOf;\n\nmodule.exports = function (searchString /*, position*/) {\n\treturn indexOf.call(this, searchString, arguments[1]) > -1;\n};\n","\"use strict\";\n\nvar objToString = Object.prototype.toString, id = objToString.call(\"\");\n\nmodule.exports = function (value) {\n\treturn (\n\t\ttypeof value === \"string\" ||\n\t\t(value &&\n\t\t\ttypeof value === \"object\" &&\n\t\t\t(value instanceof String || objToString.call(value) === id)) ||\n\t\tfalse\n\t);\n};\n","\"use strict\";\n\nvar generated = Object.create(null), random = Math.random;\n\nmodule.exports = function () {\n\tvar str;\n\tdo {\n\t\tstr = random().toString(36).slice(2);\n\t} while (generated[str]);\n\treturn str;\n};\n","\"use strict\";\n\nvar setPrototypeOf = require(\"es5-ext/object/set-prototype-of\")\n , contains = require(\"es5-ext/string/#/contains\")\n , d = require(\"d\")\n , Symbol = require(\"es6-symbol\")\n , Iterator = require(\"./\");\n\nvar defineProperty = Object.defineProperty, ArrayIterator;\n\nArrayIterator = module.exports = function (arr, kind) {\n\tif (!(this instanceof ArrayIterator)) throw new TypeError(\"Constructor requires 'new'\");\n\tIterator.call(this, arr);\n\tif (!kind) kind = \"value\";\n\telse if (contains.call(kind, \"key+value\")) kind = \"key+value\";\n\telse if (contains.call(kind, \"key\")) kind = \"key\";\n\telse kind = \"value\";\n\tdefineProperty(this, \"__kind__\", d(\"\", kind));\n};\nif (setPrototypeOf) setPrototypeOf(ArrayIterator, Iterator);\n\n// Internal %ArrayIteratorPrototype% doesn't expose its constructor\ndelete ArrayIterator.prototype.constructor;\n\nArrayIterator.prototype = Object.create(Iterator.prototype, {\n\t_resolve: d(function (i) {\n\t\tif (this.__kind__ === \"value\") return this.__list__[i];\n\t\tif (this.__kind__ === \"key+value\") return [i, this.__list__[i]];\n\t\treturn i;\n\t})\n});\ndefineProperty(ArrayIterator.prototype, Symbol.toStringTag, d(\"c\", \"Array Iterator\"));\n","\"use strict\";\n\nvar isArguments = require(\"es5-ext/function/is-arguments\")\n , callable = require(\"es5-ext/object/valid-callable\")\n , isString = require(\"es5-ext/string/is-string\")\n , get = require(\"./get\");\n\nvar isArray = Array.isArray, call = Function.prototype.call, some = Array.prototype.some;\n\nmodule.exports = function (iterable, cb /*, thisArg*/) {\n\tvar mode, thisArg = arguments[2], result, doBreak, broken, i, length, char, code;\n\tif (isArray(iterable) || isArguments(iterable)) mode = \"array\";\n\telse if (isString(iterable)) mode = \"string\";\n\telse iterable = get(iterable);\n\n\tcallable(cb);\n\tdoBreak = function () {\n\t\tbroken = true;\n\t};\n\tif (mode === \"array\") {\n\t\tsome.call(iterable, function (value) {\n\t\t\tcall.call(cb, thisArg, value, doBreak);\n\t\t\treturn broken;\n\t\t});\n\t\treturn;\n\t}\n\tif (mode === \"string\") {\n\t\tlength = iterable.length;\n\t\tfor (i = 0; i < length; ++i) {\n\t\t\tchar = iterable[i];\n\t\t\tif (i + 1 < length) {\n\t\t\t\tcode = char.charCodeAt(0);\n\t\t\t\tif (code >= 0xd800 && code <= 0xdbff) char += iterable[++i];\n\t\t\t}\n\t\t\tcall.call(cb, thisArg, char, doBreak);\n\t\t\tif (broken) break;\n\t\t}\n\t\treturn;\n\t}\n\tresult = iterable.next();\n\n\twhile (!result.done) {\n\t\tcall.call(cb, thisArg, result.value, doBreak);\n\t\tif (broken) return;\n\t\tresult = iterable.next();\n\t}\n};\n","\"use strict\";\n\nvar isArguments = require(\"es5-ext/function/is-arguments\")\n , isString = require(\"es5-ext/string/is-string\")\n , ArrayIterator = require(\"./array\")\n , StringIterator = require(\"./string\")\n , iterable = require(\"./valid-iterable\")\n , iteratorSymbol = require(\"es6-symbol\").iterator;\n\nmodule.exports = function (obj) {\n\tif (typeof iterable(obj)[iteratorSymbol] === \"function\") return obj[iteratorSymbol]();\n\tif (isArguments(obj)) return new ArrayIterator(obj);\n\tif (isString(obj)) return new StringIterator(obj);\n\treturn new ArrayIterator(obj);\n};\n","\"use strict\";\n\nvar clear = require(\"es5-ext/array/#/clear\")\n , assign = require(\"es5-ext/object/assign\")\n , callable = require(\"es5-ext/object/valid-callable\")\n , value = require(\"es5-ext/object/valid-value\")\n , d = require(\"d\")\n , autoBind = require(\"d/auto-bind\")\n , Symbol = require(\"es6-symbol\");\n\nvar defineProperty = Object.defineProperty, defineProperties = Object.defineProperties, Iterator;\n\nmodule.exports = Iterator = function (list, context) {\n\tif (!(this instanceof Iterator)) throw new TypeError(\"Constructor requires 'new'\");\n\tdefineProperties(this, {\n\t\t__list__: d(\"w\", value(list)),\n\t\t__context__: d(\"w\", context),\n\t\t__nextIndex__: d(\"w\", 0)\n\t});\n\tif (!context) return;\n\tcallable(context.on);\n\tcontext.on(\"_add\", this._onAdd);\n\tcontext.on(\"_delete\", this._onDelete);\n\tcontext.on(\"_clear\", this._onClear);\n};\n\n// Internal %IteratorPrototype% doesn't expose its constructor\ndelete Iterator.prototype.constructor;\n\ndefineProperties(\n\tIterator.prototype,\n\tassign(\n\t\t{\n\t\t\t_next: d(function () {\n\t\t\t\tvar i;\n\t\t\t\tif (!this.__list__) return undefined;\n\t\t\t\tif (this.__redo__) {\n\t\t\t\t\ti = this.__redo__.shift();\n\t\t\t\t\tif (i !== undefined) return i;\n\t\t\t\t}\n\t\t\t\tif (this.__nextIndex__ < this.__list__.length) return this.__nextIndex__++;\n\t\t\t\tthis._unBind();\n\t\t\t\treturn undefined;\n\t\t\t}),\n\t\t\tnext: d(function () {\n\t\t\t\treturn this._createResult(this._next());\n\t\t\t}),\n\t\t\t_createResult: d(function (i) {\n\t\t\t\tif (i === undefined) return { done: true, value: undefined };\n\t\t\t\treturn { done: false, value: this._resolve(i) };\n\t\t\t}),\n\t\t\t_resolve: d(function (i) {\n\t\t\t\treturn this.__list__[i];\n\t\t\t}),\n\t\t\t_unBind: d(function () {\n\t\t\t\tthis.__list__ = null;\n\t\t\t\tdelete this.__redo__;\n\t\t\t\tif (!this.__context__) return;\n\t\t\t\tthis.__context__.off(\"_add\", this._onAdd);\n\t\t\t\tthis.__context__.off(\"_delete\", this._onDelete);\n\t\t\t\tthis.__context__.off(\"_clear\", this._onClear);\n\t\t\t\tthis.__context__ = null;\n\t\t\t}),\n\t\t\ttoString: d(function () {\n\t\t\t\treturn \"[object \" + (this[Symbol.toStringTag] || \"Object\") + \"]\";\n\t\t\t})\n\t\t},\n\t\tautoBind({\n\t\t\t_onAdd: d(function (index) {\n\t\t\t\tif (index >= this.__nextIndex__) return;\n\t\t\t\t++this.__nextIndex__;\n\t\t\t\tif (!this.__redo__) {\n\t\t\t\t\tdefineProperty(this, \"__redo__\", d(\"c\", [index]));\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tthis.__redo__.forEach(function (redo, i) {\n\t\t\t\t\tif (redo >= index) this.__redo__[i] = ++redo;\n\t\t\t\t}, this);\n\t\t\t\tthis.__redo__.push(index);\n\t\t\t}),\n\t\t\t_onDelete: d(function (index) {\n\t\t\t\tvar i;\n\t\t\t\tif (index >= this.__nextIndex__) return;\n\t\t\t\t--this.__nextIndex__;\n\t\t\t\tif (!this.__redo__) return;\n\t\t\t\ti = this.__redo__.indexOf(index);\n\t\t\t\tif (i !== -1) this.__redo__.splice(i, 1);\n\t\t\t\tthis.__redo__.forEach(function (redo, j) {\n\t\t\t\t\tif (redo > index) this.__redo__[j] = --redo;\n\t\t\t\t}, this);\n\t\t\t}),\n\t\t\t_onClear: d(function () {\n\t\t\t\tif (this.__redo__) clear.call(this.__redo__);\n\t\t\t\tthis.__nextIndex__ = 0;\n\t\t\t})\n\t\t})\n\t)\n);\n\ndefineProperty(\n\tIterator.prototype,\n\tSymbol.iterator,\n\td(function () {\n\t\treturn this;\n\t})\n);\n","\"use strict\";\n\nvar isArguments = require(\"es5-ext/function/is-arguments\")\n , isValue = require(\"es5-ext/object/is-value\")\n , isString = require(\"es5-ext/string/is-string\");\n\nvar iteratorSymbol = require(\"es6-symbol\").iterator\n , isArray = Array.isArray;\n\nmodule.exports = function (value) {\n\tif (!isValue(value)) return false;\n\tif (isArray(value)) return true;\n\tif (isString(value)) return true;\n\tif (isArguments(value)) return true;\n\treturn typeof value[iteratorSymbol] === \"function\";\n};\n","// Thanks @mathiasbynens\n// http://mathiasbynens.be/notes/javascript-unicode#iterating-over-symbols\n\n\"use strict\";\n\nvar setPrototypeOf = require(\"es5-ext/object/set-prototype-of\")\n , d = require(\"d\")\n , Symbol = require(\"es6-symbol\")\n , Iterator = require(\"./\");\n\nvar defineProperty = Object.defineProperty, StringIterator;\n\nStringIterator = module.exports = function (str) {\n\tif (!(this instanceof StringIterator)) throw new TypeError(\"Constructor requires 'new'\");\n\tstr = String(str);\n\tIterator.call(this, str);\n\tdefineProperty(this, \"__length__\", d(\"\", str.length));\n};\nif (setPrototypeOf) setPrototypeOf(StringIterator, Iterator);\n\n// Internal %ArrayIteratorPrototype% doesn't expose its constructor\ndelete StringIterator.prototype.constructor;\n\nStringIterator.prototype = Object.create(Iterator.prototype, {\n\t_next: d(function () {\n\t\tif (!this.__list__) return undefined;\n\t\tif (this.__nextIndex__ < this.__length__) return this.__nextIndex__++;\n\t\tthis._unBind();\n\t\treturn undefined;\n\t}),\n\t_resolve: d(function (i) {\n\t\tvar char = this.__list__[i], code;\n\t\tif (this.__nextIndex__ === this.__length__) return char;\n\t\tcode = char.charCodeAt(0);\n\t\tif (code >= 0xd800 && code <= 0xdbff) return char + this.__list__[this.__nextIndex__++];\n\t\treturn char;\n\t})\n});\ndefineProperty(StringIterator.prototype, Symbol.toStringTag, d(\"c\", \"String Iterator\"));\n","\"use strict\";\n\nvar isIterable = require(\"./is-iterable\");\n\nmodule.exports = function (value) {\n\tif (!isIterable(value)) throw new TypeError(value + \" is not iterable\");\n\treturn value;\n};\n","\"use strict\";\n\nmodule.exports = require(\"./is-implemented\")()\n\t? require(\"ext/global-this\").Symbol\n\t: require(\"./polyfill\");\n","\"use strict\";\n\nvar global = require(\"ext/global-this\")\n , validTypes = { object: true, symbol: true };\n\nmodule.exports = function () {\n\tvar Symbol = global.Symbol;\n\tvar symbol;\n\tif (typeof Symbol !== \"function\") return false;\n\tsymbol = Symbol(\"test symbol\");\n\ttry { String(symbol); }\n\tcatch (e) { return false; }\n\n\t// Return 'true' also for polyfills\n\tif (!validTypes[typeof Symbol.iterator]) return false;\n\tif (!validTypes[typeof Symbol.toPrimitive]) return false;\n\tif (!validTypes[typeof Symbol.toStringTag]) return false;\n\n\treturn true;\n};\n","\"use strict\";\n\nmodule.exports = function (value) {\n\tif (!value) return false;\n\tif (typeof value === \"symbol\") return true;\n\tif (!value.constructor) return false;\n\tif (value.constructor.name !== \"Symbol\") return false;\n\treturn value[value.constructor.toStringTag] === \"Symbol\";\n};\n","\"use strict\";\n\nvar d = require(\"d\");\n\nvar create = Object.create, defineProperty = Object.defineProperty, objPrototype = Object.prototype;\n\nvar created = create(null);\nmodule.exports = function (desc) {\n\tvar postfix = 0, name, ie11BugWorkaround;\n\twhile (created[desc + (postfix || \"\")]) ++postfix;\n\tdesc += postfix || \"\";\n\tcreated[desc] = true;\n\tname = \"@@\" + desc;\n\tdefineProperty(\n\t\tobjPrototype, name,\n\t\td.gs(null, function (value) {\n\t\t\t// For IE11 issue see:\n\t\t\t// https://connect.microsoft.com/IE/feedbackdetail/view/1928508/\n\t\t\t// ie11-broken-getters-on-dom-objects\n\t\t\t// https://github.com/medikoo/es6-symbol/issues/12\n\t\t\tif (ie11BugWorkaround) return;\n\t\t\tie11BugWorkaround = true;\n\t\t\tdefineProperty(this, name, d(value));\n\t\t\tie11BugWorkaround = false;\n\t\t})\n\t);\n\treturn name;\n};\n","\"use strict\";\n\nvar d = require(\"d\")\n , NativeSymbol = require(\"ext/global-this\").Symbol;\n\nmodule.exports = function (SymbolPolyfill) {\n\treturn Object.defineProperties(SymbolPolyfill, {\n\t\t// To ensure proper interoperability with other native functions (e.g. Array.from)\n\t\t// fallback to eventual native implementation of given symbol\n\t\thasInstance: d(\n\t\t\t\"\", (NativeSymbol && NativeSymbol.hasInstance) || SymbolPolyfill(\"hasInstance\")\n\t\t),\n\t\tisConcatSpreadable: d(\n\t\t\t\"\",\n\t\t\t(NativeSymbol && NativeSymbol.isConcatSpreadable) ||\n\t\t\t\tSymbolPolyfill(\"isConcatSpreadable\")\n\t\t),\n\t\titerator: d(\"\", (NativeSymbol && NativeSymbol.iterator) || SymbolPolyfill(\"iterator\")),\n\t\tmatch: d(\"\", (NativeSymbol && NativeSymbol.match) || SymbolPolyfill(\"match\")),\n\t\treplace: d(\"\", (NativeSymbol && NativeSymbol.replace) || SymbolPolyfill(\"replace\")),\n\t\tsearch: d(\"\", (NativeSymbol && NativeSymbol.search) || SymbolPolyfill(\"search\")),\n\t\tspecies: d(\"\", (NativeSymbol && NativeSymbol.species) || SymbolPolyfill(\"species\")),\n\t\tsplit: d(\"\", (NativeSymbol && NativeSymbol.split) || SymbolPolyfill(\"split\")),\n\t\ttoPrimitive: d(\n\t\t\t\"\", (NativeSymbol && NativeSymbol.toPrimitive) || SymbolPolyfill(\"toPrimitive\")\n\t\t),\n\t\ttoStringTag: d(\n\t\t\t\"\", (NativeSymbol && NativeSymbol.toStringTag) || SymbolPolyfill(\"toStringTag\")\n\t\t),\n\t\tunscopables: d(\n\t\t\t\"\", (NativeSymbol && NativeSymbol.unscopables) || SymbolPolyfill(\"unscopables\")\n\t\t)\n\t});\n};\n","\"use strict\";\n\nvar d = require(\"d\")\n , validateSymbol = require(\"../../../validate-symbol\");\n\nvar registry = Object.create(null);\n\nmodule.exports = function (SymbolPolyfill) {\n\treturn Object.defineProperties(SymbolPolyfill, {\n\t\tfor: d(function (key) {\n\t\t\tif (registry[key]) return registry[key];\n\t\t\treturn (registry[key] = SymbolPolyfill(String(key)));\n\t\t}),\n\t\tkeyFor: d(function (symbol) {\n\t\t\tvar key;\n\t\t\tvalidateSymbol(symbol);\n\t\t\tfor (key in registry) {\n\t\t\t\tif (registry[key] === symbol) return key;\n\t\t\t}\n\t\t\treturn undefined;\n\t\t})\n\t});\n};\n","// ES2015 Symbol polyfill for environments that do not (or partially) support it\n\n\"use strict\";\n\nvar d = require(\"d\")\n , validateSymbol = require(\"./validate-symbol\")\n , NativeSymbol = require(\"ext/global-this\").Symbol\n , generateName = require(\"./lib/private/generate-name\")\n , setupStandardSymbols = require(\"./lib/private/setup/standard-symbols\")\n , setupSymbolRegistry = require(\"./lib/private/setup/symbol-registry\");\n\nvar create = Object.create\n , defineProperties = Object.defineProperties\n , defineProperty = Object.defineProperty;\n\nvar SymbolPolyfill, HiddenSymbol, isNativeSafe;\n\nif (typeof NativeSymbol === \"function\") {\n\ttry {\n\t\tString(NativeSymbol());\n\t\tisNativeSafe = true;\n\t} catch (ignore) {}\n} else {\n\tNativeSymbol = null;\n}\n\n// Internal constructor (not one exposed) for creating Symbol instances.\n// This one is used to ensure that `someSymbol instanceof Symbol` always return false\nHiddenSymbol = function Symbol(description) {\n\tif (this instanceof HiddenSymbol) throw new TypeError(\"Symbol is not a constructor\");\n\treturn SymbolPolyfill(description);\n};\n\n// Exposed `Symbol` constructor\n// (returns instances of HiddenSymbol)\nmodule.exports = SymbolPolyfill = function Symbol(description) {\n\tvar symbol;\n\tif (this instanceof Symbol) throw new TypeError(\"Symbol is not a constructor\");\n\tif (isNativeSafe) return NativeSymbol(description);\n\tsymbol = create(HiddenSymbol.prototype);\n\tdescription = description === undefined ? \"\" : String(description);\n\treturn defineProperties(symbol, {\n\t\t__description__: d(\"\", description),\n\t\t__name__: d(\"\", generateName(description))\n\t});\n};\n\nsetupStandardSymbols(SymbolPolyfill);\nsetupSymbolRegistry(SymbolPolyfill);\n\n// Internal tweaks for real symbol producer\ndefineProperties(HiddenSymbol.prototype, {\n\tconstructor: d(SymbolPolyfill),\n\ttoString: d(\"\", function () { return this.__name__; })\n});\n\n// Proper implementation of methods exposed on Symbol.prototype\n// They won't be accessible on produced symbol instances as they derive from HiddenSymbol.prototype\ndefineProperties(SymbolPolyfill.prototype, {\n\ttoString: d(function () { return \"Symbol (\" + validateSymbol(this).__description__ + \")\"; }),\n\tvalueOf: d(function () { return validateSymbol(this); })\n});\ndefineProperty(\n\tSymbolPolyfill.prototype, SymbolPolyfill.toPrimitive,\n\td(\"\", function () {\n\t\tvar symbol = validateSymbol(this);\n\t\tif (typeof symbol === \"symbol\") return symbol;\n\t\treturn symbol.toString();\n\t})\n);\ndefineProperty(SymbolPolyfill.prototype, SymbolPolyfill.toStringTag, d(\"c\", \"Symbol\"));\n\n// Proper implementaton of toPrimitive and toStringTag for returned symbol instances\ndefineProperty(\n\tHiddenSymbol.prototype, SymbolPolyfill.toStringTag,\n\td(\"c\", SymbolPolyfill.prototype[SymbolPolyfill.toStringTag])\n);\n\n// Note: It's important to define `toPrimitive` as last one, as some implementations\n// implement `toPrimitive` natively without implementing `toStringTag` (or other specified symbols)\n// And that may invoke error in definition flow:\n// See: https://github.com/medikoo/es6-symbol/issues/13#issuecomment-164146149\ndefineProperty(\n\tHiddenSymbol.prototype, SymbolPolyfill.toPrimitive,\n\td(\"c\", SymbolPolyfill.prototype[SymbolPolyfill.toPrimitive])\n);\n","\"use strict\";\n\nvar isSymbol = require(\"./is-symbol\");\n\nmodule.exports = function (value) {\n\tif (!isSymbol(value)) throw new TypeError(value + \" is not a symbol\");\n\treturn value;\n};\n","\"use strict\";\n\nmodule.exports = require(\"./is-implemented\")() ? WeakMap : require(\"./polyfill\");\n","\"use strict\";\n\nmodule.exports = function () {\n\tvar weakMap, obj;\n\n\tif (typeof WeakMap !== \"function\") return false;\n\ttry {\n\t\t// WebKit doesn't support arguments and crashes\n\t\tweakMap = new WeakMap([[obj = {}, \"one\"], [{}, \"two\"], [{}, \"three\"]]);\n\t} catch (e) {\n\t\treturn false;\n\t}\n\tif (String(weakMap) !== \"[object WeakMap]\") return false;\n\tif (typeof weakMap.set !== \"function\") return false;\n\tif (weakMap.set({}, 1) !== weakMap) return false;\n\tif (typeof weakMap.delete !== \"function\") return false;\n\tif (typeof weakMap.has !== \"function\") return false;\n\tif (weakMap.get(obj) !== \"one\") return false;\n\n\treturn true;\n};\n","// Exports true if environment provides native `WeakMap` implementation, whatever that is.\n\n\"use strict\";\n\nmodule.exports = (function () {\n\tif (typeof WeakMap !== \"function\") return false;\n\treturn Object.prototype.toString.call(new WeakMap()) === \"[object WeakMap]\";\n}());\n","\"use strict\";\n\nvar isValue = require(\"es5-ext/object/is-value\")\n , setPrototypeOf = require(\"es5-ext/object/set-prototype-of\")\n , object = require(\"es5-ext/object/valid-object\")\n , ensureValue = require(\"es5-ext/object/valid-value\")\n , randomUniq = require(\"es5-ext/string/random-uniq\")\n , d = require(\"d\")\n , getIterator = require(\"es6-iterator/get\")\n , forOf = require(\"es6-iterator/for-of\")\n , toStringTagSymbol = require(\"es6-symbol\").toStringTag\n , isNative = require(\"./is-native-implemented\")\n\n , isArray = Array.isArray, defineProperty = Object.defineProperty\n , objHasOwnProperty = Object.prototype.hasOwnProperty, getPrototypeOf = Object.getPrototypeOf\n , WeakMapPoly;\n\nmodule.exports = WeakMapPoly = function (/* Iterable*/) {\n\tvar iterable = arguments[0], self;\n\n\tif (!(this instanceof WeakMapPoly)) throw new TypeError(\"Constructor requires 'new'\");\n\tself = isNative && setPrototypeOf && (WeakMap !== WeakMapPoly)\n\t\t? setPrototypeOf(new WeakMap(), getPrototypeOf(this)) : this;\n\n\tif (isValue(iterable)) {\n\t\tif (!isArray(iterable)) iterable = getIterator(iterable);\n\t}\n\tdefineProperty(self, \"__weakMapData__\", d(\"c\", \"$weakMap$\" + randomUniq()));\n\tif (!iterable) return self;\n\tforOf(iterable, function (val) {\n\t\tensureValue(val);\n\t\tself.set(val[0], val[1]);\n\t});\n\treturn self;\n};\n\nif (isNative) {\n\tif (setPrototypeOf) setPrototypeOf(WeakMapPoly, WeakMap);\n\tWeakMapPoly.prototype = Object.create(WeakMap.prototype, { constructor: d(WeakMapPoly) });\n}\n\nObject.defineProperties(WeakMapPoly.prototype, {\n\tdelete: d(function (key) {\n\t\tif (objHasOwnProperty.call(object(key), this.__weakMapData__)) {\n\t\t\tdelete key[this.__weakMapData__];\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}),\n\tget: d(function (key) {\n\t\tif (!objHasOwnProperty.call(object(key), this.__weakMapData__)) return undefined;\n\t\treturn key[this.__weakMapData__];\n\t}),\n\thas: d(function (key) {\n\t\treturn objHasOwnProperty.call(object(key), this.__weakMapData__);\n\t}),\n\tset: d(function (key, value) {\n\t\tdefineProperty(object(key), this.__weakMapData__, d(\"c\", value));\n\t\treturn this;\n\t}),\n\ttoString: d(function () {\n\t\treturn \"[object WeakMap]\";\n\t})\n});\ndefineProperty(WeakMapPoly.prototype, toStringTagSymbol, d(\"c\", \"WeakMap\"));\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n ? R.apply\n : function ReflectApply(target, receiver, args) {\n return Function.prototype.apply.call(target, receiver, args);\n }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target)\n .concat(Object.getOwnPropertySymbols(target));\n };\n} else {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target);\n };\n}\n\nfunction ProcessEmitWarning(warning) {\n if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n return value !== value;\n}\n\nfunction EventEmitter() {\n EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\nmodule.exports.once = once;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nfunction checkListener(listener) {\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n}\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n enumerable: true,\n get: function() {\n return defaultMaxListeners;\n },\n set: function(arg) {\n if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n }\n defaultMaxListeners = arg;\n }\n});\n\nEventEmitter.init = function() {\n\n if (this._events === undefined ||\n this._events === Object.getPrototypeOf(this)._events) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n }\n\n this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n }\n this._maxListeners = n;\n return this;\n};\n\nfunction _getMaxListeners(that) {\n if (that._maxListeners === undefined)\n return EventEmitter.defaultMaxListeners;\n return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n return _getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n var args = [];\n for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n var doError = (type === 'error');\n\n var events = this._events;\n if (events !== undefined)\n doError = (doError && events.error === undefined);\n else if (!doError)\n return false;\n\n // If there is no 'error' event listener then throw.\n if (doError) {\n var er;\n if (args.length > 0)\n er = args[0];\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n\n var handler = events[type];\n\n if (handler === undefined)\n return false;\n\n if (typeof handler === 'function') {\n ReflectApply(handler, this, args);\n } else {\n var len = handler.length;\n var listeners = arrayClone(handler, len);\n for (var i = 0; i < len; ++i)\n ReflectApply(listeners[i], this, args);\n }\n\n return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n var m;\n var events;\n var existing;\n\n checkListener(listener);\n\n events = target._events;\n if (events === undefined) {\n events = target._events = Object.create(null);\n target._eventsCount = 0;\n } else {\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (events.newListener !== undefined) {\n target.emit('newListener', type,\n listener.listener ? listener.listener : listener);\n\n // Re-assign `events` because a newListener handler could have caused the\n // this._events to be assigned to a new object\n events = target._events;\n }\n existing = events[type];\n }\n\n if (existing === undefined) {\n // Optimize the case of one listener. Don't need the extra array object.\n existing = events[type] = listener;\n ++target._eventsCount;\n } else {\n if (typeof existing === 'function') {\n // Adding the second element, need to change to array.\n existing = events[type] =\n prepend ? [listener, existing] : [existing, listener];\n // If we've already got an array, just append.\n } else if (prepend) {\n existing.unshift(listener);\n } else {\n existing.push(listener);\n }\n\n // Check for listener leak\n m = _getMaxListeners(target);\n if (m > 0 && existing.length > m && !existing.warned) {\n existing.warned = true;\n // No error code for this since it is a Warning\n // eslint-disable-next-line no-restricted-syntax\n var w = new Error('Possible EventEmitter memory leak detected. ' +\n existing.length + ' ' + String(type) + ' listeners ' +\n 'added. Use emitter.setMaxListeners() to ' +\n 'increase limit');\n w.name = 'MaxListenersExceededWarning';\n w.emitter = target;\n w.type = type;\n w.count = existing.length;\n ProcessEmitWarning(w);\n }\n }\n\n return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n function prependListener(type, listener) {\n return _addListener(this, type, listener, true);\n };\n\nfunction onceWrapper() {\n if (!this.fired) {\n this.target.removeListener(this.type, this.wrapFn);\n this.fired = true;\n if (arguments.length === 0)\n return this.listener.call(this.target);\n return this.listener.apply(this.target, arguments);\n }\n}\n\nfunction _onceWrap(target, type, listener) {\n var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n var wrapped = onceWrapper.bind(state);\n wrapped.listener = listener;\n state.wrapFn = wrapped;\n return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n checkListener(listener);\n this.on(type, _onceWrap(this, type, listener));\n return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n function prependOnceListener(type, listener) {\n checkListener(listener);\n this.prependListener(type, _onceWrap(this, type, listener));\n return this;\n };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n function removeListener(type, listener) {\n var list, events, position, i, originalListener;\n\n checkListener(listener);\n\n events = this._events;\n if (events === undefined)\n return this;\n\n list = events[type];\n if (list === undefined)\n return this;\n\n if (list === listener || list.listener === listener) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else {\n delete events[type];\n if (events.removeListener)\n this.emit('removeListener', type, list.listener || listener);\n }\n } else if (typeof list !== 'function') {\n position = -1;\n\n for (i = list.length - 1; i >= 0; i--) {\n if (list[i] === listener || list[i].listener === listener) {\n originalListener = list[i].listener;\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (position === 0)\n list.shift();\n else {\n spliceOne(list, position);\n }\n\n if (list.length === 1)\n events[type] = list[0];\n\n if (events.removeListener !== undefined)\n this.emit('removeListener', type, originalListener || listener);\n }\n\n return this;\n };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n function removeAllListeners(type) {\n var listeners, events, i;\n\n events = this._events;\n if (events === undefined)\n return this;\n\n // not listening for removeListener, no need to emit\n if (events.removeListener === undefined) {\n if (arguments.length === 0) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n } else if (events[type] !== undefined) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else\n delete events[type];\n }\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n var keys = Object.keys(events);\n var key;\n for (i = 0; i < keys.length; ++i) {\n key = keys[i];\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = Object.create(null);\n this._eventsCount = 0;\n return this;\n }\n\n listeners = events[type];\n\n if (typeof listeners === 'function') {\n this.removeListener(type, listeners);\n } else if (listeners !== undefined) {\n // LIFO order\n for (i = listeners.length - 1; i >= 0; i--) {\n this.removeListener(type, listeners[i]);\n }\n }\n\n return this;\n };\n\nfunction _listeners(target, type, unwrap) {\n var events = target._events;\n\n if (events === undefined)\n return [];\n\n var evlistener = events[type];\n if (evlistener === undefined)\n return [];\n\n if (typeof evlistener === 'function')\n return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n return unwrap ?\n unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n if (typeof emitter.listenerCount === 'function') {\n return emitter.listenerCount(type);\n } else {\n return listenerCount.call(emitter, type);\n }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n var events = this._events;\n\n if (events !== undefined) {\n var evlistener = events[type];\n\n if (typeof evlistener === 'function') {\n return 1;\n } else if (evlistener !== undefined) {\n return evlistener.length;\n }\n }\n\n return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n var copy = new Array(n);\n for (var i = 0; i < n; ++i)\n copy[i] = arr[i];\n return copy;\n}\n\nfunction spliceOne(list, index) {\n for (; index + 1 < list.length; index++)\n list[index] = list[index + 1];\n list.pop();\n}\n\nfunction unwrapListeners(arr) {\n var ret = new Array(arr.length);\n for (var i = 0; i < ret.length; ++i) {\n ret[i] = arr[i].listener || arr[i];\n }\n return ret;\n}\n\nfunction once(emitter, name) {\n return new Promise(function (resolve, reject) {\n function errorListener(err) {\n emitter.removeListener(name, resolver);\n reject(err);\n }\n\n function resolver() {\n if (typeof emitter.removeListener === 'function') {\n emitter.removeListener('error', errorListener);\n }\n resolve([].slice.call(arguments));\n };\n\n eventTargetAgnosticAddListener(emitter, name, resolver, { once: true });\n if (name !== 'error') {\n addErrorHandlerIfEventEmitter(emitter, errorListener, { once: true });\n }\n });\n}\n\nfunction addErrorHandlerIfEventEmitter(emitter, handler, flags) {\n if (typeof emitter.on === 'function') {\n eventTargetAgnosticAddListener(emitter, 'error', handler, flags);\n }\n}\n\nfunction eventTargetAgnosticAddListener(emitter, name, listener, flags) {\n if (typeof emitter.on === 'function') {\n if (flags.once) {\n emitter.once(name, listener);\n } else {\n emitter.on(name, listener);\n }\n } else if (typeof emitter.addEventListener === 'function') {\n // EventTarget does not have `error` event semantics like Node\n // EventEmitters, we do not listen for `error` events here.\n emitter.addEventListener(name, function wrapListener(arg) {\n // IE does not have builtin `{ once: true }` support so we\n // have to do it manually.\n if (flags.once) {\n emitter.removeEventListener(name, wrapListener);\n }\n listener(arg);\n });\n } else {\n throw new TypeError('The \"emitter\" argument must be of type EventEmitter. Received type ' + typeof emitter);\n }\n}\n","var naiveFallback = function () {\n\tif (typeof self === \"object\" && self) return self;\n\tif (typeof window === \"object\" && window) return window;\n\tthrow new Error(\"Unable to resolve global `this`\");\n};\n\nmodule.exports = (function () {\n\tif (this) return this;\n\n\t// Unexpected strict mode (may happen if e.g. bundled into ESM module)\n\n\t// Thanks @mathiasbynens -> https://mathiasbynens.be/notes/globalthis\n\t// In all ES5+ engines global object inherits from Object.prototype\n\t// (if you approached one that doesn't please report)\n\ttry {\n\t\tObject.defineProperty(Object.prototype, \"__global__\", {\n\t\t\tget: function () { return this; },\n\t\t\tconfigurable: true\n\t\t});\n\t} catch (error) {\n\t\t// Unfortunate case of Object.prototype being sealed (via preventExtensions, seal or freeze)\n\t\treturn naiveFallback();\n\t}\n\ttry {\n\t\t// Safari case (window.__global__ is resolved with global context, but __global__ does not)\n\t\tif (!__global__) return naiveFallback();\n\t\treturn __global__;\n\t} finally {\n\t\tdelete Object.prototype.__global__;\n\t}\n})();\n","\"use strict\";\n\nmodule.exports = require(\"./is-implemented\")() ? globalThis : require(\"./implementation\");\n","\"use strict\";\n\nmodule.exports = function () {\n\tif (typeof globalThis !== \"object\") return false;\n\tif (!globalThis) return false;\n\treturn globalThis.Array === Array;\n};\n","'use strict';\n\n// do not edit .js files directly - edit src/index.jst\n\n\n\nmodule.exports = function equal(a, b) {\n if (a === b) return true;\n\n if (a && b && typeof a == 'object' && typeof b == 'object') {\n if (a.constructor !== b.constructor) return false;\n\n var length, i, keys;\n if (Array.isArray(a)) {\n length = a.length;\n if (length != b.length) return false;\n for (i = length; i-- !== 0;)\n if (!equal(a[i], b[i])) return false;\n return true;\n }\n\n\n\n if (a.constructor === RegExp) return a.source === b.source && a.flags === b.flags;\n if (a.valueOf !== Object.prototype.valueOf) return a.valueOf() === b.valueOf();\n if (a.toString !== Object.prototype.toString) return a.toString() === b.toString();\n\n keys = Object.keys(a);\n length = keys.length;\n if (length !== Object.keys(b).length) return false;\n\n for (i = length; i-- !== 0;)\n if (!Object.prototype.hasOwnProperty.call(b, keys[i])) return false;\n\n for (i = length; i-- !== 0;) {\n var key = keys[i];\n\n if (!equal(a[key], b[key])) return false;\n }\n\n return true;\n }\n\n // true if both NaN, false otherwise\n return a!==a && b!==b;\n};\n","/**\n * inspired by is-number \n * but significantly simplified and sped up by ignoring number and string constructors\n * ie these return false:\n * new Number(1)\n * new String('1')\n */\n\n'use strict';\n\nvar allBlankCharCodes = require('is-string-blank');\n\nmodule.exports = function(n) {\n var type = typeof n;\n if(type === 'string') {\n var original = n;\n n = +n;\n // whitespace strings cast to zero - filter them out\n if(n===0 && allBlankCharCodes(original)) return false;\n }\n else if(type !== 'number') return false;\n\n return n - n < 1;\n};\n","/*eslint new-cap:0*/\nvar dtype = require('dtype')\n\nmodule.exports = flattenVertexData\n\nfunction flattenVertexData (data, output, offset) {\n if (!data) throw new TypeError('must specify data as first parameter')\n offset = +(offset || 0) | 0\n\n if (Array.isArray(data) && (data[0] && typeof data[0][0] === 'number')) {\n var dim = data[0].length\n var length = data.length * dim\n var i, j, k, l\n\n // no output specified, create a new typed array\n if (!output || typeof output === 'string') {\n output = new (dtype(output || 'float32'))(length + offset)\n }\n\n var dstLength = output.length - offset\n if (length !== dstLength) {\n throw new Error('source length ' + length + ' (' + dim + 'x' + data.length + ')' +\n ' does not match destination length ' + dstLength)\n }\n\n for (i = 0, k = offset; i < data.length; i++) {\n for (j = 0; j < dim; j++) {\n output[k++] = data[i][j] === null ? NaN : data[i][j]\n }\n }\n } else {\n if (!output || typeof output === 'string') {\n // no output, create a new one\n var Ctor = dtype(output || 'float32')\n\n // handle arrays separately due to possible nulls\n if (Array.isArray(data) || output === 'array') {\n output = new Ctor(data.length + offset)\n for (i = 0, k = offset, l = output.length; k < l; k++, i++) {\n output[k] = data[i] === null ? NaN : data[i]\n }\n } else {\n if (offset === 0) {\n output = new Ctor(data)\n } else {\n output = new Ctor(data.length + offset)\n\n output.set(data, offset)\n }\n }\n } else {\n // store output in existing array\n output.set(data, offset)\n }\n }\n\n return output\n}\n","'use strict'\r\n\r\nvar stringifyFont = require('css-font/stringify')\r\nvar defaultChars = [32, 126]\r\n\r\nmodule.exports = atlas\r\n\r\nfunction atlas(options) {\r\n options = options || {}\r\n\r\n var shape = options.shape ? options.shape : options.canvas ? [options.canvas.width, options.canvas.height] : [512, 512]\r\n var canvas = options.canvas || document.createElement('canvas')\r\n var font = options.font\r\n var step = typeof options.step === 'number' ? [options.step, options.step] : options.step || [32, 32]\r\n var chars = options.chars || defaultChars\r\n\r\n if (font && typeof font !== 'string') font = stringifyFont(font)\r\n\r\n if (!Array.isArray(chars)) {\r\n chars = String(chars).split('')\r\n } else\r\n if (chars.length === 2\r\n && typeof chars[0] === 'number'\r\n && typeof chars[1] === 'number'\r\n ) {\r\n var newchars = []\r\n\r\n for (var i = chars[0], j = 0; i <= chars[1]; i++) {\r\n newchars[j++] = String.fromCharCode(i)\r\n }\r\n\r\n chars = newchars\r\n }\r\n\r\n shape = shape.slice()\r\n canvas.width = shape[0]\r\n canvas.height = shape[1]\r\n\r\n var ctx = canvas.getContext('2d')\r\n\r\n ctx.fillStyle = '#000'\r\n ctx.fillRect(0, 0, canvas.width, canvas.height)\r\n\r\n ctx.font = font\r\n ctx.textAlign = 'center'\r\n ctx.textBaseline = 'middle'\r\n ctx.fillStyle = '#fff'\r\n\r\n var x = step[0] / 2\r\n var y = step[1] / 2\r\n for (var i = 0; i < chars.length; i++) {\r\n ctx.fillText(chars[i], x, y)\r\n if ((x += step[0]) > shape[0] - step[0]/2) (x = step[0]/2), (y += step[1])\r\n }\r\n\r\n return canvas\r\n}\r\n","'use strict'\r\n\r\nmodule.exports = measure\r\n\r\nmeasure.canvas = document.createElement('canvas')\r\nmeasure.cache = {}\r\n\r\nfunction measure (font, o) {\r\n\tif (!o) o = {}\r\n\r\n\tif (typeof font === 'string' || Array.isArray(font)) {\r\n\t\to.family = font\r\n\t}\r\n\r\n\tvar family = Array.isArray(o.family) ? o.family.join(', ') : o.family\r\n\tif (!family) throw Error('`family` must be defined')\r\n\r\n\tvar fs = o.size || o.fontSize || o.em || 48\r\n\tvar weight = o.weight || o.fontWeight || ''\r\n\tvar style = o.style || o.fontStyle || ''\r\n\tvar font = [style, weight, fs].join(' ') + 'px ' + family\r\n\tvar origin = o.origin || 'top'\r\n\r\n\tif (measure.cache[family]) {\r\n\t\t// return more precise values if cache has them\r\n\t\tif (fs <= measure.cache[family].em) {\r\n\t\t\treturn applyOrigin(measure.cache[family], origin)\r\n\t\t}\r\n\t}\r\n\r\n\tvar canvas = o.canvas || measure.canvas\r\n\tvar ctx = canvas.getContext('2d')\r\n\tvar chars = {\r\n\t\tupper: o.upper !== undefined ? o.upper : 'H',\r\n\t\tlower: o.lower !== undefined ? o.lower : 'x',\r\n\t\tdescent: o.descent !== undefined ? o.descent : 'p',\r\n\t\tascent: o.ascent !== undefined ? o.ascent : 'h',\r\n\t\ttittle: o.tittle !== undefined ? o.tittle : 'i',\r\n\t\tovershoot: o.overshoot !== undefined ? o.overshoot : 'O'\r\n\t}\r\n\tvar l = Math.ceil(fs * 1.5)\r\n\tcanvas.height = l\r\n\tcanvas.width = l * .5\r\n\tctx.font = font\r\n\r\n\tvar char = 'H'\r\n\tvar result = {\r\n\t\ttop: 0\r\n\t}\r\n\r\n\t// measure line-height\r\n\tctx.clearRect(0, 0, l, l)\r\n\tctx.textBaseline = 'top'\r\n\tctx.fillStyle = 'black'\r\n\tctx.fillText(char, 0, 0)\r\n\tvar topPx = firstTop(ctx.getImageData(0, 0, l, l))\r\n\tctx.clearRect(0, 0, l, l)\r\n\tctx.textBaseline = 'bottom'\r\n\tctx.fillText(char, 0, l)\r\n\tvar bottomPx = firstTop(ctx.getImageData(0, 0, l, l))\r\n\tresult.lineHeight =\r\n\tresult.bottom = l - bottomPx + topPx\r\n\r\n\t// measure baseline\r\n\tctx.clearRect(0, 0, l, l)\r\n\tctx.textBaseline = 'alphabetic'\r\n\tctx.fillText(char, 0, l)\r\n\tvar baselinePx = firstTop(ctx.getImageData(0, 0, l, l))\r\n\tvar baseline = l - baselinePx - 1 + topPx\r\n\tresult.baseline =\r\n\tresult.alphabetic = baseline\r\n\r\n\t// measure median\r\n\tctx.clearRect(0, 0, l, l)\r\n\tctx.textBaseline = 'middle'\r\n\tctx.fillText(char, 0, l * .5)\r\n\tvar medianPx = firstTop(ctx.getImageData(0, 0, l, l))\r\n\tresult.median =\r\n\tresult.middle = l - medianPx - 1 + topPx - l * .5\r\n\r\n\t// measure hanging\r\n\tctx.clearRect(0, 0, l, l)\r\n\tctx.textBaseline = 'hanging'\r\n\tctx.fillText(char, 0, l * .5)\r\n\tvar hangingPx = firstTop(ctx.getImageData(0, 0, l, l))\r\n\tresult.hanging = l - hangingPx - 1 + topPx - l * .5\r\n\r\n\t// measure ideographic\r\n\tctx.clearRect(0, 0, l, l)\r\n\tctx.textBaseline = 'ideographic'\r\n\tctx.fillText(char, 0, l)\r\n\tvar ideographicPx = firstTop(ctx.getImageData(0, 0, l, l))\r\n\tresult.ideographic = l - ideographicPx - 1 + topPx\r\n\r\n\t// measure cap\r\n\tif (chars.upper) {\r\n\t\tctx.clearRect(0, 0, l, l)\r\n\t\tctx.textBaseline = 'top'\r\n\t\tctx.fillText(chars.upper, 0, 0)\r\n\t\tresult.upper = firstTop(ctx.getImageData(0, 0, l, l))\r\n\t\tresult.capHeight = (result.baseline - result.upper)\r\n\t}\r\n\r\n\t// measure x\r\n\tif (chars.lower) {\r\n\t\tctx.clearRect(0, 0, l, l)\r\n\t\tctx.textBaseline = 'top'\r\n\t\tctx.fillText(chars.lower, 0, 0)\r\n\t\tresult.lower = firstTop(ctx.getImageData(0, 0, l, l))\r\n\t\tresult.xHeight = (result.baseline - result.lower)\r\n\t}\r\n\r\n\t// measure tittle\r\n\tif (chars.tittle) {\r\n\t\tctx.clearRect(0, 0, l, l)\r\n\t\tctx.textBaseline = 'top'\r\n\t\tctx.fillText(chars.tittle, 0, 0)\r\n\t\tresult.tittle = firstTop(ctx.getImageData(0, 0, l, l))\r\n\t}\r\n\r\n\t// measure ascent\r\n\tif (chars.ascent) {\r\n\t\tctx.clearRect(0, 0, l, l)\r\n\t\tctx.textBaseline = 'top'\r\n\t\tctx.fillText(chars.ascent, 0, 0)\r\n\t\tresult.ascent = firstTop(ctx.getImageData(0, 0, l, l))\r\n\t}\r\n\r\n\t// measure descent\r\n\tif (chars.descent) {\r\n\t\tctx.clearRect(0, 0, l, l)\r\n\t\tctx.textBaseline = 'top'\r\n\t\tctx.fillText(chars.descent, 0, 0)\r\n\t\tresult.descent = firstBottom(ctx.getImageData(0, 0, l, l))\r\n\t}\r\n\r\n\t// measure overshoot\r\n\tif (chars.overshoot) {\r\n\t\tctx.clearRect(0, 0, l, l)\r\n\t\tctx.textBaseline = 'top'\r\n\t\tctx.fillText(chars.overshoot, 0, 0)\r\n\t\tvar overshootPx = firstBottom(ctx.getImageData(0, 0, l, l))\r\n\t\tresult.overshoot = overshootPx - baseline\r\n\t}\r\n\r\n\t// normalize result\r\n\tfor (var name in result) {\r\n\t\tresult[name] /= fs\r\n\t}\r\n\r\n\tresult.em = fs\r\n\tmeasure.cache[family] = result\r\n\r\n\treturn applyOrigin(result, origin)\r\n}\r\n\r\nfunction applyOrigin(obj, origin) {\r\n\tvar res = {}\r\n\tif (typeof origin === 'string') origin = obj[origin]\r\n\tfor (var name in obj) {\r\n\t\tif (name === 'em') continue\r\n\t\tres[name] = obj[name] - origin\r\n\t}\r\n\treturn res\r\n}\r\n\r\nfunction firstTop(iData) {\r\n\tvar l = iData.height\r\n\tvar data = iData.data\r\n\tfor (var i = 3; i < data.length; i+=4) {\r\n\t\tif (data[i] !== 0) {\r\n\t\t\treturn Math.floor((i - 3) *.25 / l)\r\n\t\t}\r\n\t}\r\n}\r\n\r\nfunction firstBottom(iData) {\r\n\tvar l = iData.height\r\n\tvar data = iData.data\r\n\tfor (var i = data.length - 1; i > 0; i -= 4) {\r\n\t\tif (data[i] !== 0) {\r\n\t\t\treturn Math.floor((i - 3) *.25 / l)\r\n\t\t}\r\n\t}\r\n}\r\n","'use strict';\n\nvar isCallable = require('is-callable');\n\nvar toStr = Object.prototype.toString;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nvar forEachArray = function forEachArray(array, iterator, receiver) {\n for (var i = 0, len = array.length; i < len; i++) {\n if (hasOwnProperty.call(array, i)) {\n if (receiver == null) {\n iterator(array[i], i, array);\n } else {\n iterator.call(receiver, array[i], i, array);\n }\n }\n }\n};\n\nvar forEachString = function forEachString(string, iterator, receiver) {\n for (var i = 0, len = string.length; i < len; i++) {\n // no such thing as a sparse string.\n if (receiver == null) {\n iterator(string.charAt(i), i, string);\n } else {\n iterator.call(receiver, string.charAt(i), i, string);\n }\n }\n};\n\nvar forEachObject = function forEachObject(object, iterator, receiver) {\n for (var k in object) {\n if (hasOwnProperty.call(object, k)) {\n if (receiver == null) {\n iterator(object[k], k, object);\n } else {\n iterator.call(receiver, object[k], k, object);\n }\n }\n }\n};\n\nvar forEach = function forEach(list, iterator, thisArg) {\n if (!isCallable(iterator)) {\n throw new TypeError('iterator must be a function');\n }\n\n var receiver;\n if (arguments.length >= 3) {\n receiver = thisArg;\n }\n\n if (toStr.call(list) === '[object Array]') {\n forEachArray(list, iterator, receiver);\n } else if (typeof list === 'string') {\n forEachString(list, iterator, receiver);\n } else {\n forEachObject(list, iterator, receiver);\n }\n};\n\nmodule.exports = forEach;\n","'use strict';\n\n/* eslint no-invalid-this: 1 */\n\nvar ERROR_MESSAGE = 'Function.prototype.bind called on incompatible ';\nvar toStr = Object.prototype.toString;\nvar max = Math.max;\nvar funcType = '[object Function]';\n\nvar concatty = function concatty(a, b) {\n var arr = [];\n\n for (var i = 0; i < a.length; i += 1) {\n arr[i] = a[i];\n }\n for (var j = 0; j < b.length; j += 1) {\n arr[j + a.length] = b[j];\n }\n\n return arr;\n};\n\nvar slicy = function slicy(arrLike, offset) {\n var arr = [];\n for (var i = offset || 0, j = 0; i < arrLike.length; i += 1, j += 1) {\n arr[j] = arrLike[i];\n }\n return arr;\n};\n\nvar joiny = function (arr, joiner) {\n var str = '';\n for (var i = 0; i < arr.length; i += 1) {\n str += arr[i];\n if (i + 1 < arr.length) {\n str += joiner;\n }\n }\n return str;\n};\n\nmodule.exports = function bind(that) {\n var target = this;\n if (typeof target !== 'function' || toStr.apply(target) !== funcType) {\n throw new TypeError(ERROR_MESSAGE + target);\n }\n var args = slicy(arguments, 1);\n\n var bound;\n var binder = function () {\n if (this instanceof bound) {\n var result = target.apply(\n this,\n concatty(args, arguments)\n );\n if (Object(result) === result) {\n return result;\n }\n return this;\n }\n return target.apply(\n that,\n concatty(args, arguments)\n );\n\n };\n\n var boundLength = max(0, target.length - args.length);\n var boundArgs = [];\n for (var i = 0; i < boundLength; i++) {\n boundArgs[i] = '$' + i;\n }\n\n bound = Function('binder', 'return function (' + joiny(boundArgs, ',') + '){ return binder.apply(this,arguments); }')(binder);\n\n if (target.prototype) {\n var Empty = function Empty() {};\n Empty.prototype = target.prototype;\n bound.prototype = new Empty();\n Empty.prototype = null;\n }\n\n return bound;\n};\n","'use strict';\n\nvar implementation = require('./implementation');\n\nmodule.exports = Function.prototype.bind || implementation;\n","module.exports = getCanvasContext\nfunction getCanvasContext (type, opts) {\n if (typeof type !== 'string') {\n throw new TypeError('must specify type string')\n }\n\n opts = opts || {}\n\n if (typeof document === 'undefined' && !opts.canvas) {\n return null // check for Node\n }\n\n var canvas = opts.canvas || document.createElement('canvas')\n if (typeof opts.width === 'number') {\n canvas.width = opts.width\n }\n if (typeof opts.height === 'number') {\n canvas.height = opts.height\n }\n\n var attribs = opts\n var gl\n try {\n var names = [ type ]\n // prefix GL contexts\n if (type.indexOf('webgl') === 0) {\n names.push('experimental-' + type)\n }\n\n for (var i = 0; i < names.length; i++) {\n gl = canvas.getContext(names[i], attribs)\n if (gl) return gl\n }\n } catch (e) {\n gl = null\n }\n return (gl || null) // ensure null on fail\n}\n","'use strict';\n\nvar undefined;\n\nvar $Error = require('es-errors');\nvar $EvalError = require('es-errors/eval');\nvar $RangeError = require('es-errors/range');\nvar $ReferenceError = require('es-errors/ref');\nvar $SyntaxError = require('es-errors/syntax');\nvar $TypeError = require('es-errors/type');\nvar $URIError = require('es-errors/uri');\n\nvar $Function = Function;\n\n// eslint-disable-next-line consistent-return\nvar getEvalledConstructor = function (expressionSyntax) {\n\ttry {\n\t\treturn $Function('\"use strict\"; return (' + expressionSyntax + ').constructor;')();\n\t} catch (e) {}\n};\n\nvar $gOPD = Object.getOwnPropertyDescriptor;\nif ($gOPD) {\n\ttry {\n\t\t$gOPD({}, '');\n\t} catch (e) {\n\t\t$gOPD = null; // this is IE 8, which has a broken gOPD\n\t}\n}\n\nvar throwTypeError = function () {\n\tthrow new $TypeError();\n};\nvar ThrowTypeError = $gOPD\n\t? (function () {\n\t\ttry {\n\t\t\t// eslint-disable-next-line no-unused-expressions, no-caller, no-restricted-properties\n\t\t\targuments.callee; // IE 8 does not throw here\n\t\t\treturn throwTypeError;\n\t\t} catch (calleeThrows) {\n\t\t\ttry {\n\t\t\t\t// IE 8 throws on Object.getOwnPropertyDescriptor(arguments, '')\n\t\t\t\treturn $gOPD(arguments, 'callee').get;\n\t\t\t} catch (gOPDthrows) {\n\t\t\t\treturn throwTypeError;\n\t\t\t}\n\t\t}\n\t}())\n\t: throwTypeError;\n\nvar hasSymbols = require('has-symbols')();\nvar hasProto = require('has-proto')();\n\nvar getProto = Object.getPrototypeOf || (\n\thasProto\n\t\t? function (x) { return x.__proto__; } // eslint-disable-line no-proto\n\t\t: null\n);\n\nvar needsEval = {};\n\nvar TypedArray = typeof Uint8Array === 'undefined' || !getProto ? undefined : getProto(Uint8Array);\n\nvar INTRINSICS = {\n\t__proto__: null,\n\t'%AggregateError%': typeof AggregateError === 'undefined' ? undefined : AggregateError,\n\t'%Array%': Array,\n\t'%ArrayBuffer%': typeof ArrayBuffer === 'undefined' ? undefined : ArrayBuffer,\n\t'%ArrayIteratorPrototype%': hasSymbols && getProto ? getProto([][Symbol.iterator]()) : undefined,\n\t'%AsyncFromSyncIteratorPrototype%': undefined,\n\t'%AsyncFunction%': needsEval,\n\t'%AsyncGenerator%': needsEval,\n\t'%AsyncGeneratorFunction%': needsEval,\n\t'%AsyncIteratorPrototype%': needsEval,\n\t'%Atomics%': typeof Atomics === 'undefined' ? undefined : Atomics,\n\t'%BigInt%': typeof BigInt === 'undefined' ? undefined : BigInt,\n\t'%BigInt64Array%': typeof BigInt64Array === 'undefined' ? undefined : BigInt64Array,\n\t'%BigUint64Array%': typeof BigUint64Array === 'undefined' ? undefined : BigUint64Array,\n\t'%Boolean%': Boolean,\n\t'%DataView%': typeof DataView === 'undefined' ? undefined : DataView,\n\t'%Date%': Date,\n\t'%decodeURI%': decodeURI,\n\t'%decodeURIComponent%': decodeURIComponent,\n\t'%encodeURI%': encodeURI,\n\t'%encodeURIComponent%': encodeURIComponent,\n\t'%Error%': $Error,\n\t'%eval%': eval, // eslint-disable-line no-eval\n\t'%EvalError%': $EvalError,\n\t'%Float32Array%': typeof Float32Array === 'undefined' ? undefined : Float32Array,\n\t'%Float64Array%': typeof Float64Array === 'undefined' ? undefined : Float64Array,\n\t'%FinalizationRegistry%': typeof FinalizationRegistry === 'undefined' ? undefined : FinalizationRegistry,\n\t'%Function%': $Function,\n\t'%GeneratorFunction%': needsEval,\n\t'%Int8Array%': typeof Int8Array === 'undefined' ? undefined : Int8Array,\n\t'%Int16Array%': typeof Int16Array === 'undefined' ? undefined : Int16Array,\n\t'%Int32Array%': typeof Int32Array === 'undefined' ? undefined : Int32Array,\n\t'%isFinite%': isFinite,\n\t'%isNaN%': isNaN,\n\t'%IteratorPrototype%': hasSymbols && getProto ? getProto(getProto([][Symbol.iterator]())) : undefined,\n\t'%JSON%': typeof JSON === 'object' ? JSON : undefined,\n\t'%Map%': typeof Map === 'undefined' ? undefined : Map,\n\t'%MapIteratorPrototype%': typeof Map === 'undefined' || !hasSymbols || !getProto ? undefined : getProto(new Map()[Symbol.iterator]()),\n\t'%Math%': Math,\n\t'%Number%': Number,\n\t'%Object%': Object,\n\t'%parseFloat%': parseFloat,\n\t'%parseInt%': parseInt,\n\t'%Promise%': typeof Promise === 'undefined' ? undefined : Promise,\n\t'%Proxy%': typeof Proxy === 'undefined' ? undefined : Proxy,\n\t'%RangeError%': $RangeError,\n\t'%ReferenceError%': $ReferenceError,\n\t'%Reflect%': typeof Reflect === 'undefined' ? undefined : Reflect,\n\t'%RegExp%': RegExp,\n\t'%Set%': typeof Set === 'undefined' ? undefined : Set,\n\t'%SetIteratorPrototype%': typeof Set === 'undefined' || !hasSymbols || !getProto ? undefined : getProto(new Set()[Symbol.iterator]()),\n\t'%SharedArrayBuffer%': typeof SharedArrayBuffer === 'undefined' ? undefined : SharedArrayBuffer,\n\t'%String%': String,\n\t'%StringIteratorPrototype%': hasSymbols && getProto ? getProto(''[Symbol.iterator]()) : undefined,\n\t'%Symbol%': hasSymbols ? Symbol : undefined,\n\t'%SyntaxError%': $SyntaxError,\n\t'%ThrowTypeError%': ThrowTypeError,\n\t'%TypedArray%': TypedArray,\n\t'%TypeError%': $TypeError,\n\t'%Uint8Array%': typeof Uint8Array === 'undefined' ? undefined : Uint8Array,\n\t'%Uint8ClampedArray%': typeof Uint8ClampedArray === 'undefined' ? undefined : Uint8ClampedArray,\n\t'%Uint16Array%': typeof Uint16Array === 'undefined' ? undefined : Uint16Array,\n\t'%Uint32Array%': typeof Uint32Array === 'undefined' ? undefined : Uint32Array,\n\t'%URIError%': $URIError,\n\t'%WeakMap%': typeof WeakMap === 'undefined' ? undefined : WeakMap,\n\t'%WeakRef%': typeof WeakRef === 'undefined' ? undefined : WeakRef,\n\t'%WeakSet%': typeof WeakSet === 'undefined' ? undefined : WeakSet\n};\n\nif (getProto) {\n\ttry {\n\t\tnull.error; // eslint-disable-line no-unused-expressions\n\t} catch (e) {\n\t\t// https://github.com/tc39/proposal-shadowrealm/pull/384#issuecomment-1364264229\n\t\tvar errorProto = getProto(getProto(e));\n\t\tINTRINSICS['%Error.prototype%'] = errorProto;\n\t}\n}\n\nvar doEval = function doEval(name) {\n\tvar value;\n\tif (name === '%AsyncFunction%') {\n\t\tvalue = getEvalledConstructor('async function () {}');\n\t} else if (name === '%GeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('function* () {}');\n\t} else if (name === '%AsyncGeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('async function* () {}');\n\t} else if (name === '%AsyncGenerator%') {\n\t\tvar fn = doEval('%AsyncGeneratorFunction%');\n\t\tif (fn) {\n\t\t\tvalue = fn.prototype;\n\t\t}\n\t} else if (name === '%AsyncIteratorPrototype%') {\n\t\tvar gen = doEval('%AsyncGenerator%');\n\t\tif (gen && getProto) {\n\t\t\tvalue = getProto(gen.prototype);\n\t\t}\n\t}\n\n\tINTRINSICS[name] = value;\n\n\treturn value;\n};\n\nvar LEGACY_ALIASES = {\n\t__proto__: null,\n\t'%ArrayBufferPrototype%': ['ArrayBuffer', 'prototype'],\n\t'%ArrayPrototype%': ['Array', 'prototype'],\n\t'%ArrayProto_entries%': ['Array', 'prototype', 'entries'],\n\t'%ArrayProto_forEach%': ['Array', 'prototype', 'forEach'],\n\t'%ArrayProto_keys%': ['Array', 'prototype', 'keys'],\n\t'%ArrayProto_values%': ['Array', 'prototype', 'values'],\n\t'%AsyncFunctionPrototype%': ['AsyncFunction', 'prototype'],\n\t'%AsyncGenerator%': ['AsyncGeneratorFunction', 'prototype'],\n\t'%AsyncGeneratorPrototype%': ['AsyncGeneratorFunction', 'prototype', 'prototype'],\n\t'%BooleanPrototype%': ['Boolean', 'prototype'],\n\t'%DataViewPrototype%': ['DataView', 'prototype'],\n\t'%DatePrototype%': ['Date', 'prototype'],\n\t'%ErrorPrototype%': ['Error', 'prototype'],\n\t'%EvalErrorPrototype%': ['EvalError', 'prototype'],\n\t'%Float32ArrayPrototype%': ['Float32Array', 'prototype'],\n\t'%Float64ArrayPrototype%': ['Float64Array', 'prototype'],\n\t'%FunctionPrototype%': ['Function', 'prototype'],\n\t'%Generator%': ['GeneratorFunction', 'prototype'],\n\t'%GeneratorPrototype%': ['GeneratorFunction', 'prototype', 'prototype'],\n\t'%Int8ArrayPrototype%': ['Int8Array', 'prototype'],\n\t'%Int16ArrayPrototype%': ['Int16Array', 'prototype'],\n\t'%Int32ArrayPrototype%': ['Int32Array', 'prototype'],\n\t'%JSONParse%': ['JSON', 'parse'],\n\t'%JSONStringify%': ['JSON', 'stringify'],\n\t'%MapPrototype%': ['Map', 'prototype'],\n\t'%NumberPrototype%': ['Number', 'prototype'],\n\t'%ObjectPrototype%': ['Object', 'prototype'],\n\t'%ObjProto_toString%': ['Object', 'prototype', 'toString'],\n\t'%ObjProto_valueOf%': ['Object', 'prototype', 'valueOf'],\n\t'%PromisePrototype%': ['Promise', 'prototype'],\n\t'%PromiseProto_then%': ['Promise', 'prototype', 'then'],\n\t'%Promise_all%': ['Promise', 'all'],\n\t'%Promise_reject%': ['Promise', 'reject'],\n\t'%Promise_resolve%': ['Promise', 'resolve'],\n\t'%RangeErrorPrototype%': ['RangeError', 'prototype'],\n\t'%ReferenceErrorPrototype%': ['ReferenceError', 'prototype'],\n\t'%RegExpPrototype%': ['RegExp', 'prototype'],\n\t'%SetPrototype%': ['Set', 'prototype'],\n\t'%SharedArrayBufferPrototype%': ['SharedArrayBuffer', 'prototype'],\n\t'%StringPrototype%': ['String', 'prototype'],\n\t'%SymbolPrototype%': ['Symbol', 'prototype'],\n\t'%SyntaxErrorPrototype%': ['SyntaxError', 'prototype'],\n\t'%TypedArrayPrototype%': ['TypedArray', 'prototype'],\n\t'%TypeErrorPrototype%': ['TypeError', 'prototype'],\n\t'%Uint8ArrayPrototype%': ['Uint8Array', 'prototype'],\n\t'%Uint8ClampedArrayPrototype%': ['Uint8ClampedArray', 'prototype'],\n\t'%Uint16ArrayPrototype%': ['Uint16Array', 'prototype'],\n\t'%Uint32ArrayPrototype%': ['Uint32Array', 'prototype'],\n\t'%URIErrorPrototype%': ['URIError', 'prototype'],\n\t'%WeakMapPrototype%': ['WeakMap', 'prototype'],\n\t'%WeakSetPrototype%': ['WeakSet', 'prototype']\n};\n\nvar bind = require('function-bind');\nvar hasOwn = require('hasown');\nvar $concat = bind.call(Function.call, Array.prototype.concat);\nvar $spliceApply = bind.call(Function.apply, Array.prototype.splice);\nvar $replace = bind.call(Function.call, String.prototype.replace);\nvar $strSlice = bind.call(Function.call, String.prototype.slice);\nvar $exec = bind.call(Function.call, RegExp.prototype.exec);\n\n/* adapted from https://github.com/lodash/lodash/blob/4.17.15/dist/lodash.js#L6735-L6744 */\nvar rePropName = /[^%.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|%$))/g;\nvar reEscapeChar = /\\\\(\\\\)?/g; /** Used to match backslashes in property paths. */\nvar stringToPath = function stringToPath(string) {\n\tvar first = $strSlice(string, 0, 1);\n\tvar last = $strSlice(string, -1);\n\tif (first === '%' && last !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected closing `%`');\n\t} else if (last === '%' && first !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected opening `%`');\n\t}\n\tvar result = [];\n\t$replace(string, rePropName, function (match, number, quote, subString) {\n\t\tresult[result.length] = quote ? $replace(subString, reEscapeChar, '$1') : number || match;\n\t});\n\treturn result;\n};\n/* end adaptation */\n\nvar getBaseIntrinsic = function getBaseIntrinsic(name, allowMissing) {\n\tvar intrinsicName = name;\n\tvar alias;\n\tif (hasOwn(LEGACY_ALIASES, intrinsicName)) {\n\t\talias = LEGACY_ALIASES[intrinsicName];\n\t\tintrinsicName = '%' + alias[0] + '%';\n\t}\n\n\tif (hasOwn(INTRINSICS, intrinsicName)) {\n\t\tvar value = INTRINSICS[intrinsicName];\n\t\tif (value === needsEval) {\n\t\t\tvalue = doEval(intrinsicName);\n\t\t}\n\t\tif (typeof value === 'undefined' && !allowMissing) {\n\t\t\tthrow new $TypeError('intrinsic ' + name + ' exists, but is not available. Please file an issue!');\n\t\t}\n\n\t\treturn {\n\t\t\talias: alias,\n\t\t\tname: intrinsicName,\n\t\t\tvalue: value\n\t\t};\n\t}\n\n\tthrow new $SyntaxError('intrinsic ' + name + ' does not exist!');\n};\n\nmodule.exports = function GetIntrinsic(name, allowMissing) {\n\tif (typeof name !== 'string' || name.length === 0) {\n\t\tthrow new $TypeError('intrinsic name must be a non-empty string');\n\t}\n\tif (arguments.length > 1 && typeof allowMissing !== 'boolean') {\n\t\tthrow new $TypeError('\"allowMissing\" argument must be a boolean');\n\t}\n\n\tif ($exec(/^%?[^%]*%?$/, name) === null) {\n\t\tthrow new $SyntaxError('`%` may not be present anywhere but at the beginning and end of the intrinsic name');\n\t}\n\tvar parts = stringToPath(name);\n\tvar intrinsicBaseName = parts.length > 0 ? parts[0] : '';\n\n\tvar intrinsic = getBaseIntrinsic('%' + intrinsicBaseName + '%', allowMissing);\n\tvar intrinsicRealName = intrinsic.name;\n\tvar value = intrinsic.value;\n\tvar skipFurtherCaching = false;\n\n\tvar alias = intrinsic.alias;\n\tif (alias) {\n\t\tintrinsicBaseName = alias[0];\n\t\t$spliceApply(parts, $concat([0, 1], alias));\n\t}\n\n\tfor (var i = 1, isOwn = true; i < parts.length; i += 1) {\n\t\tvar part = parts[i];\n\t\tvar first = $strSlice(part, 0, 1);\n\t\tvar last = $strSlice(part, -1);\n\t\tif (\n\t\t\t(\n\t\t\t\t(first === '\"' || first === \"'\" || first === '`')\n\t\t\t\t|| (last === '\"' || last === \"'\" || last === '`')\n\t\t\t)\n\t\t\t&& first !== last\n\t\t) {\n\t\t\tthrow new $SyntaxError('property names with quotes must have matching quotes');\n\t\t}\n\t\tif (part === 'constructor' || !isOwn) {\n\t\t\tskipFurtherCaching = true;\n\t\t}\n\n\t\tintrinsicBaseName += '.' + part;\n\t\tintrinsicRealName = '%' + intrinsicBaseName + '%';\n\n\t\tif (hasOwn(INTRINSICS, intrinsicRealName)) {\n\t\t\tvalue = INTRINSICS[intrinsicRealName];\n\t\t} else if (value != null) {\n\t\t\tif (!(part in value)) {\n\t\t\t\tif (!allowMissing) {\n\t\t\t\t\tthrow new $TypeError('base intrinsic for ' + name + ' exists, but the property is not available.');\n\t\t\t\t}\n\t\t\t\treturn void undefined;\n\t\t\t}\n\t\t\tif ($gOPD && (i + 1) >= parts.length) {\n\t\t\t\tvar desc = $gOPD(value, part);\n\t\t\t\tisOwn = !!desc;\n\n\t\t\t\t// By convention, when a data property is converted to an accessor\n\t\t\t\t// property to emulate a data property that does not suffer from\n\t\t\t\t// the override mistake, that accessor's getter is marked with\n\t\t\t\t// an `originalValue` property. Here, when we detect this, we\n\t\t\t\t// uphold the illusion by pretending to see that original data\n\t\t\t\t// property, i.e., returning the value rather than the getter\n\t\t\t\t// itself.\n\t\t\t\tif (isOwn && 'get' in desc && !('originalValue' in desc.get)) {\n\t\t\t\t\tvalue = desc.get;\n\t\t\t\t} else {\n\t\t\t\t\tvalue = value[part];\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tisOwn = hasOwn(value, part);\n\t\t\t\tvalue = value[part];\n\t\t\t}\n\n\t\t\tif (isOwn && !skipFurtherCaching) {\n\t\t\t\tINTRINSICS[intrinsicRealName] = value;\n\t\t\t}\n\t\t}\n\t}\n\treturn value;\n};\n","module.exports = adjoint;\n\n/**\n * Calculates the adjugate of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nfunction adjoint(out, a) {\n var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n\n out[0] = (a11 * (a22 * a33 - a23 * a32) - a21 * (a12 * a33 - a13 * a32) + a31 * (a12 * a23 - a13 * a22));\n out[1] = -(a01 * (a22 * a33 - a23 * a32) - a21 * (a02 * a33 - a03 * a32) + a31 * (a02 * a23 - a03 * a22));\n out[2] = (a01 * (a12 * a33 - a13 * a32) - a11 * (a02 * a33 - a03 * a32) + a31 * (a02 * a13 - a03 * a12));\n out[3] = -(a01 * (a12 * a23 - a13 * a22) - a11 * (a02 * a23 - a03 * a22) + a21 * (a02 * a13 - a03 * a12));\n out[4] = -(a10 * (a22 * a33 - a23 * a32) - a20 * (a12 * a33 - a13 * a32) + a30 * (a12 * a23 - a13 * a22));\n out[5] = (a00 * (a22 * a33 - a23 * a32) - a20 * (a02 * a33 - a03 * a32) + a30 * (a02 * a23 - a03 * a22));\n out[6] = -(a00 * (a12 * a33 - a13 * a32) - a10 * (a02 * a33 - a03 * a32) + a30 * (a02 * a13 - a03 * a12));\n out[7] = (a00 * (a12 * a23 - a13 * a22) - a10 * (a02 * a23 - a03 * a22) + a20 * (a02 * a13 - a03 * a12));\n out[8] = (a10 * (a21 * a33 - a23 * a31) - a20 * (a11 * a33 - a13 * a31) + a30 * (a11 * a23 - a13 * a21));\n out[9] = -(a00 * (a21 * a33 - a23 * a31) - a20 * (a01 * a33 - a03 * a31) + a30 * (a01 * a23 - a03 * a21));\n out[10] = (a00 * (a11 * a33 - a13 * a31) - a10 * (a01 * a33 - a03 * a31) + a30 * (a01 * a13 - a03 * a11));\n out[11] = -(a00 * (a11 * a23 - a13 * a21) - a10 * (a01 * a23 - a03 * a21) + a20 * (a01 * a13 - a03 * a11));\n out[12] = -(a10 * (a21 * a32 - a22 * a31) - a20 * (a11 * a32 - a12 * a31) + a30 * (a11 * a22 - a12 * a21));\n out[13] = (a00 * (a21 * a32 - a22 * a31) - a20 * (a01 * a32 - a02 * a31) + a30 * (a01 * a22 - a02 * a21));\n out[14] = -(a00 * (a11 * a32 - a12 * a31) - a10 * (a01 * a32 - a02 * a31) + a30 * (a01 * a12 - a02 * a11));\n out[15] = (a00 * (a11 * a22 - a12 * a21) - a10 * (a01 * a22 - a02 * a21) + a20 * (a01 * a12 - a02 * a11));\n return out;\n};","module.exports = clone;\n\n/**\n * Creates a new mat4 initialized with values from an existing matrix\n *\n * @param {mat4} a matrix to clone\n * @returns {mat4} a new 4x4 matrix\n */\nfunction clone(a) {\n var out = new Float32Array(16);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n};","module.exports = copy;\n\n/**\n * Copy the values from one mat4 to another\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nfunction copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n};","module.exports = create;\n\n/**\n * Creates a new identity mat4\n *\n * @returns {mat4} a new 4x4 matrix\n */\nfunction create() {\n var out = new Float32Array(16);\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n};","module.exports = determinant;\n\n/**\n * Calculates the determinant of a mat4\n *\n * @param {mat4} a the source matrix\n * @returns {Number} determinant of a\n */\nfunction determinant(a) {\n var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32;\n\n // Calculate the determinant\n return b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n};","module.exports = fromQuat;\n\n/**\n * Creates a matrix from a quaternion rotation.\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @returns {mat4} out\n */\nfunction fromQuat(out, q) {\n var x = q[0], y = q[1], z = q[2], w = q[3],\n x2 = x + x,\n y2 = y + y,\n z2 = z + z,\n\n xx = x * x2,\n yx = y * x2,\n yy = y * y2,\n zx = z * x2,\n zy = z * y2,\n zz = z * z2,\n wx = w * x2,\n wy = w * y2,\n wz = w * z2;\n\n out[0] = 1 - yy - zz;\n out[1] = yx + wz;\n out[2] = zx - wy;\n out[3] = 0;\n\n out[4] = yx - wz;\n out[5] = 1 - xx - zz;\n out[6] = zy + wx;\n out[7] = 0;\n\n out[8] = zx + wy;\n out[9] = zy - wx;\n out[10] = 1 - xx - yy;\n out[11] = 0;\n\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n\n return out;\n};","module.exports = fromRotation\n\n/**\n * Creates a matrix from a given angle around a given axis\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest)\n * mat4.rotate(dest, dest, rad, axis)\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @param {vec3} axis the axis to rotate around\n * @returns {mat4} out\n */\nfunction fromRotation(out, rad, axis) {\n var s, c, t\n var x = axis[0]\n var y = axis[1]\n var z = axis[2]\n var len = Math.sqrt(x * x + y * y + z * z)\n\n if (Math.abs(len) < 0.000001) {\n return null\n }\n\n len = 1 / len\n x *= len\n y *= len\n z *= len\n\n s = Math.sin(rad)\n c = Math.cos(rad)\n t = 1 - c\n\n // Perform rotation-specific matrix multiplication\n out[0] = x * x * t + c\n out[1] = y * x * t + z * s\n out[2] = z * x * t - y * s\n out[3] = 0\n out[4] = x * y * t - z * s\n out[5] = y * y * t + c\n out[6] = z * y * t + x * s\n out[7] = 0\n out[8] = x * z * t + y * s\n out[9] = y * z * t - x * s\n out[10] = z * z * t + c\n out[11] = 0\n out[12] = 0\n out[13] = 0\n out[14] = 0\n out[15] = 1\n return out\n}\n","module.exports = fromRotationTranslation;\n\n/**\n * Creates a matrix from a quaternion rotation and vector translation\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.translate(dest, vec);\n * var quatMat = mat4.create();\n * quat4.toMat4(quat, quatMat);\n * mat4.multiply(dest, quatMat);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {vec3} v Translation vector\n * @returns {mat4} out\n */\nfunction fromRotationTranslation(out, q, v) {\n // Quaternion math\n var x = q[0], y = q[1], z = q[2], w = q[3],\n x2 = x + x,\n y2 = y + y,\n z2 = z + z,\n\n xx = x * x2,\n xy = x * y2,\n xz = x * z2,\n yy = y * y2,\n yz = y * z2,\n zz = z * z2,\n wx = w * x2,\n wy = w * y2,\n wz = w * z2;\n\n out[0] = 1 - (yy + zz);\n out[1] = xy + wz;\n out[2] = xz - wy;\n out[3] = 0;\n out[4] = xy - wz;\n out[5] = 1 - (xx + zz);\n out[6] = yz + wx;\n out[7] = 0;\n out[8] = xz + wy;\n out[9] = yz - wx;\n out[10] = 1 - (xx + yy);\n out[11] = 0;\n out[12] = v[0];\n out[13] = v[1];\n out[14] = v[2];\n out[15] = 1;\n \n return out;\n};","module.exports = fromScaling\n\n/**\n * Creates a matrix from a vector scaling\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest)\n * mat4.scale(dest, dest, vec)\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {vec3} v Scaling vector\n * @returns {mat4} out\n */\nfunction fromScaling(out, v) {\n out[0] = v[0]\n out[1] = 0\n out[2] = 0\n out[3] = 0\n out[4] = 0\n out[5] = v[1]\n out[6] = 0\n out[7] = 0\n out[8] = 0\n out[9] = 0\n out[10] = v[2]\n out[11] = 0\n out[12] = 0\n out[13] = 0\n out[14] = 0\n out[15] = 1\n return out\n}\n","module.exports = fromTranslation\n\n/**\n * Creates a matrix from a vector translation\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest)\n * mat4.translate(dest, dest, vec)\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {vec3} v Translation vector\n * @returns {mat4} out\n */\nfunction fromTranslation(out, v) {\n out[0] = 1\n out[1] = 0\n out[2] = 0\n out[3] = 0\n out[4] = 0\n out[5] = 1\n out[6] = 0\n out[7] = 0\n out[8] = 0\n out[9] = 0\n out[10] = 1\n out[11] = 0\n out[12] = v[0]\n out[13] = v[1]\n out[14] = v[2]\n out[15] = 1\n return out\n}\n","module.exports = fromXRotation\n\n/**\n * Creates a matrix from the given angle around the X axis\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest)\n * mat4.rotateX(dest, dest, rad)\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nfunction fromXRotation(out, rad) {\n var s = Math.sin(rad),\n c = Math.cos(rad)\n\n // Perform axis-specific matrix multiplication\n out[0] = 1\n out[1] = 0\n out[2] = 0\n out[3] = 0\n out[4] = 0\n out[5] = c\n out[6] = s\n out[7] = 0\n out[8] = 0\n out[9] = -s\n out[10] = c\n out[11] = 0\n out[12] = 0\n out[13] = 0\n out[14] = 0\n out[15] = 1\n return out\n}","module.exports = fromYRotation\n\n/**\n * Creates a matrix from the given angle around the Y axis\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest)\n * mat4.rotateY(dest, dest, rad)\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nfunction fromYRotation(out, rad) {\n var s = Math.sin(rad),\n c = Math.cos(rad)\n\n // Perform axis-specific matrix multiplication\n out[0] = c\n out[1] = 0\n out[2] = -s\n out[3] = 0\n out[4] = 0\n out[5] = 1\n out[6] = 0\n out[7] = 0\n out[8] = s\n out[9] = 0\n out[10] = c\n out[11] = 0\n out[12] = 0\n out[13] = 0\n out[14] = 0\n out[15] = 1\n return out\n}","module.exports = fromZRotation\n\n/**\n * Creates a matrix from the given angle around the Z axis\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest)\n * mat4.rotateZ(dest, dest, rad)\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nfunction fromZRotation(out, rad) {\n var s = Math.sin(rad),\n c = Math.cos(rad)\n\n // Perform axis-specific matrix multiplication\n out[0] = c\n out[1] = s\n out[2] = 0\n out[3] = 0\n out[4] = -s\n out[5] = c\n out[6] = 0\n out[7] = 0\n out[8] = 0\n out[9] = 0\n out[10] = 1\n out[11] = 0\n out[12] = 0\n out[13] = 0\n out[14] = 0\n out[15] = 1\n return out\n}","module.exports = frustum;\n\n/**\n * Generates a frustum matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {Number} left Left bound of the frustum\n * @param {Number} right Right bound of the frustum\n * @param {Number} bottom Bottom bound of the frustum\n * @param {Number} top Top bound of the frustum\n * @param {Number} near Near bound of the frustum\n * @param {Number} far Far bound of the frustum\n * @returns {mat4} out\n */\nfunction frustum(out, left, right, bottom, top, near, far) {\n var rl = 1 / (right - left),\n tb = 1 / (top - bottom),\n nf = 1 / (near - far);\n out[0] = (near * 2) * rl;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = (near * 2) * tb;\n out[6] = 0;\n out[7] = 0;\n out[8] = (right + left) * rl;\n out[9] = (top + bottom) * tb;\n out[10] = (far + near) * nf;\n out[11] = -1;\n out[12] = 0;\n out[13] = 0;\n out[14] = (far * near * 2) * nf;\n out[15] = 0;\n return out;\n};","module.exports = identity;\n\n/**\n * Set a mat4 to the identity matrix\n *\n * @param {mat4} out the receiving matrix\n * @returns {mat4} out\n */\nfunction identity(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n};","module.exports = {\n create: require('./create')\n , clone: require('./clone')\n , copy: require('./copy')\n , identity: require('./identity')\n , transpose: require('./transpose')\n , invert: require('./invert')\n , adjoint: require('./adjoint')\n , determinant: require('./determinant')\n , multiply: require('./multiply')\n , translate: require('./translate')\n , scale: require('./scale')\n , rotate: require('./rotate')\n , rotateX: require('./rotateX')\n , rotateY: require('./rotateY')\n , rotateZ: require('./rotateZ')\n , fromRotation: require('./fromRotation')\n , fromRotationTranslation: require('./fromRotationTranslation')\n , fromScaling: require('./fromScaling')\n , fromTranslation: require('./fromTranslation')\n , fromXRotation: require('./fromXRotation')\n , fromYRotation: require('./fromYRotation')\n , fromZRotation: require('./fromZRotation')\n , fromQuat: require('./fromQuat')\n , frustum: require('./frustum')\n , perspective: require('./perspective')\n , perspectiveFromFieldOfView: require('./perspectiveFromFieldOfView')\n , ortho: require('./ortho')\n , lookAt: require('./lookAt')\n , str: require('./str')\n}\n","module.exports = invert;\n\n/**\n * Inverts a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nfunction invert(out, a) {\n var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n // Calculate the determinant\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n if (!det) { \n return null; \n }\n det = 1.0 / det;\n\n out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n out[1] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n out[2] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n out[3] = (a22 * b04 - a21 * b05 - a23 * b03) * det;\n out[4] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n out[5] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n out[6] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n out[7] = (a20 * b05 - a22 * b02 + a23 * b01) * det;\n out[8] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n out[9] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n out[10] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n out[11] = (a21 * b02 - a20 * b04 - a23 * b00) * det;\n out[12] = (a11 * b07 - a10 * b09 - a12 * b06) * det;\n out[13] = (a00 * b09 - a01 * b07 + a02 * b06) * det;\n out[14] = (a31 * b01 - a30 * b03 - a32 * b00) * det;\n out[15] = (a20 * b03 - a21 * b01 + a22 * b00) * det;\n\n return out;\n};","var identity = require('./identity');\n\nmodule.exports = lookAt;\n\n/**\n * Generates a look-at matrix with the given eye position, focal point, and up axis\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {vec3} eye Position of the viewer\n * @param {vec3} center Point the viewer is looking at\n * @param {vec3} up vec3 pointing up\n * @returns {mat4} out\n */\nfunction lookAt(out, eye, center, up) {\n var x0, x1, x2, y0, y1, y2, z0, z1, z2, len,\n eyex = eye[0],\n eyey = eye[1],\n eyez = eye[2],\n upx = up[0],\n upy = up[1],\n upz = up[2],\n centerx = center[0],\n centery = center[1],\n centerz = center[2];\n\n if (Math.abs(eyex - centerx) < 0.000001 &&\n Math.abs(eyey - centery) < 0.000001 &&\n Math.abs(eyez - centerz) < 0.000001) {\n return identity(out);\n }\n\n z0 = eyex - centerx;\n z1 = eyey - centery;\n z2 = eyez - centerz;\n\n len = 1 / Math.sqrt(z0 * z0 + z1 * z1 + z2 * z2);\n z0 *= len;\n z1 *= len;\n z2 *= len;\n\n x0 = upy * z2 - upz * z1;\n x1 = upz * z0 - upx * z2;\n x2 = upx * z1 - upy * z0;\n len = Math.sqrt(x0 * x0 + x1 * x1 + x2 * x2);\n if (!len) {\n x0 = 0;\n x1 = 0;\n x2 = 0;\n } else {\n len = 1 / len;\n x0 *= len;\n x1 *= len;\n x2 *= len;\n }\n\n y0 = z1 * x2 - z2 * x1;\n y1 = z2 * x0 - z0 * x2;\n y2 = z0 * x1 - z1 * x0;\n\n len = Math.sqrt(y0 * y0 + y1 * y1 + y2 * y2);\n if (!len) {\n y0 = 0;\n y1 = 0;\n y2 = 0;\n } else {\n len = 1 / len;\n y0 *= len;\n y1 *= len;\n y2 *= len;\n }\n\n out[0] = x0;\n out[1] = y0;\n out[2] = z0;\n out[3] = 0;\n out[4] = x1;\n out[5] = y1;\n out[6] = z1;\n out[7] = 0;\n out[8] = x2;\n out[9] = y2;\n out[10] = z2;\n out[11] = 0;\n out[12] = -(x0 * eyex + x1 * eyey + x2 * eyez);\n out[13] = -(y0 * eyex + y1 * eyey + y2 * eyez);\n out[14] = -(z0 * eyex + z1 * eyey + z2 * eyez);\n out[15] = 1;\n\n return out;\n};","module.exports = multiply;\n\n/**\n * Multiplies two mat4's\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the first operand\n * @param {mat4} b the second operand\n * @returns {mat4} out\n */\nfunction multiply(out, a, b) {\n var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n\n // Cache only the current line of the second matrix\n var b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3]; \n out[0] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n out[1] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n out[2] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n out[3] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n b0 = b[4]; b1 = b[5]; b2 = b[6]; b3 = b[7];\n out[4] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n out[5] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n out[6] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n out[7] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n b0 = b[8]; b1 = b[9]; b2 = b[10]; b3 = b[11];\n out[8] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n out[9] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n out[10] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n out[11] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n b0 = b[12]; b1 = b[13]; b2 = b[14]; b3 = b[15];\n out[12] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n out[13] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n out[14] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n out[15] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n return out;\n};","module.exports = ortho;\n\n/**\n * Generates a orthogonal projection matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} left Left bound of the frustum\n * @param {number} right Right bound of the frustum\n * @param {number} bottom Bottom bound of the frustum\n * @param {number} top Top bound of the frustum\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nfunction ortho(out, left, right, bottom, top, near, far) {\n var lr = 1 / (left - right),\n bt = 1 / (bottom - top),\n nf = 1 / (near - far);\n out[0] = -2 * lr;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = -2 * bt;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 2 * nf;\n out[11] = 0;\n out[12] = (left + right) * lr;\n out[13] = (top + bottom) * bt;\n out[14] = (far + near) * nf;\n out[15] = 1;\n return out;\n};","module.exports = perspective;\n\n/**\n * Generates a perspective projection matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} fovy Vertical field of view in radians\n * @param {number} aspect Aspect ratio. typically viewport width/height\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nfunction perspective(out, fovy, aspect, near, far) {\n var f = 1.0 / Math.tan(fovy / 2),\n nf = 1 / (near - far);\n out[0] = f / aspect;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = f;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = (far + near) * nf;\n out[11] = -1;\n out[12] = 0;\n out[13] = 0;\n out[14] = (2 * far * near) * nf;\n out[15] = 0;\n return out;\n};","module.exports = perspectiveFromFieldOfView;\n\n/**\n * Generates a perspective projection matrix with the given field of view.\n * This is primarily useful for generating projection matrices to be used\n * with the still experiemental WebVR API.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} fov Object containing the following values: upDegrees, downDegrees, leftDegrees, rightDegrees\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nfunction perspectiveFromFieldOfView(out, fov, near, far) {\n var upTan = Math.tan(fov.upDegrees * Math.PI/180.0),\n downTan = Math.tan(fov.downDegrees * Math.PI/180.0),\n leftTan = Math.tan(fov.leftDegrees * Math.PI/180.0),\n rightTan = Math.tan(fov.rightDegrees * Math.PI/180.0),\n xScale = 2.0 / (leftTan + rightTan),\n yScale = 2.0 / (upTan + downTan);\n\n out[0] = xScale;\n out[1] = 0.0;\n out[2] = 0.0;\n out[3] = 0.0;\n out[4] = 0.0;\n out[5] = yScale;\n out[6] = 0.0;\n out[7] = 0.0;\n out[8] = -((leftTan - rightTan) * xScale * 0.5);\n out[9] = ((upTan - downTan) * yScale * 0.5);\n out[10] = far / (near - far);\n out[11] = -1.0;\n out[12] = 0.0;\n out[13] = 0.0;\n out[14] = (far * near) / (near - far);\n out[15] = 0.0;\n return out;\n}\n\n","module.exports = rotate;\n\n/**\n * Rotates a mat4 by the given angle\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @param {vec3} axis the axis to rotate around\n * @returns {mat4} out\n */\nfunction rotate(out, a, rad, axis) {\n var x = axis[0], y = axis[1], z = axis[2],\n len = Math.sqrt(x * x + y * y + z * z),\n s, c, t,\n a00, a01, a02, a03,\n a10, a11, a12, a13,\n a20, a21, a22, a23,\n b00, b01, b02,\n b10, b11, b12,\n b20, b21, b22;\n\n if (Math.abs(len) < 0.000001) { return null; }\n \n len = 1 / len;\n x *= len;\n y *= len;\n z *= len;\n\n s = Math.sin(rad);\n c = Math.cos(rad);\n t = 1 - c;\n\n a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3];\n a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7];\n a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11];\n\n // Construct the elements of the rotation matrix\n b00 = x * x * t + c; b01 = y * x * t + z * s; b02 = z * x * t - y * s;\n b10 = x * y * t - z * s; b11 = y * y * t + c; b12 = z * y * t + x * s;\n b20 = x * z * t + y * s; b21 = y * z * t - x * s; b22 = z * z * t + c;\n\n // Perform rotation-specific matrix multiplication\n out[0] = a00 * b00 + a10 * b01 + a20 * b02;\n out[1] = a01 * b00 + a11 * b01 + a21 * b02;\n out[2] = a02 * b00 + a12 * b01 + a22 * b02;\n out[3] = a03 * b00 + a13 * b01 + a23 * b02;\n out[4] = a00 * b10 + a10 * b11 + a20 * b12;\n out[5] = a01 * b10 + a11 * b11 + a21 * b12;\n out[6] = a02 * b10 + a12 * b11 + a22 * b12;\n out[7] = a03 * b10 + a13 * b11 + a23 * b12;\n out[8] = a00 * b20 + a10 * b21 + a20 * b22;\n out[9] = a01 * b20 + a11 * b21 + a21 * b22;\n out[10] = a02 * b20 + a12 * b21 + a22 * b22;\n out[11] = a03 * b20 + a13 * b21 + a23 * b22;\n\n if (a !== out) { // If the source and destination differ, copy the unchanged last row\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n }\n return out;\n};","module.exports = rotateX;\n\n/**\n * Rotates a matrix by the given angle around the X axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nfunction rotateX(out, a, rad) {\n var s = Math.sin(rad),\n c = Math.cos(rad),\n a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7],\n a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n\n if (a !== out) { // If the source and destination differ, copy the unchanged rows\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n }\n\n // Perform axis-specific matrix multiplication\n out[4] = a10 * c + a20 * s;\n out[5] = a11 * c + a21 * s;\n out[6] = a12 * c + a22 * s;\n out[7] = a13 * c + a23 * s;\n out[8] = a20 * c - a10 * s;\n out[9] = a21 * c - a11 * s;\n out[10] = a22 * c - a12 * s;\n out[11] = a23 * c - a13 * s;\n return out;\n};","module.exports = rotateY;\n\n/**\n * Rotates a matrix by the given angle around the Y axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nfunction rotateY(out, a, rad) {\n var s = Math.sin(rad),\n c = Math.cos(rad),\n a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3],\n a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n\n if (a !== out) { // If the source and destination differ, copy the unchanged rows\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n }\n\n // Perform axis-specific matrix multiplication\n out[0] = a00 * c - a20 * s;\n out[1] = a01 * c - a21 * s;\n out[2] = a02 * c - a22 * s;\n out[3] = a03 * c - a23 * s;\n out[8] = a00 * s + a20 * c;\n out[9] = a01 * s + a21 * c;\n out[10] = a02 * s + a22 * c;\n out[11] = a03 * s + a23 * c;\n return out;\n};","module.exports = rotateZ;\n\n/**\n * Rotates a matrix by the given angle around the Z axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nfunction rotateZ(out, a, rad) {\n var s = Math.sin(rad),\n c = Math.cos(rad),\n a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3],\n a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n\n if (a !== out) { // If the source and destination differ, copy the unchanged last row\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n }\n\n // Perform axis-specific matrix multiplication\n out[0] = a00 * c + a10 * s;\n out[1] = a01 * c + a11 * s;\n out[2] = a02 * c + a12 * s;\n out[3] = a03 * c + a13 * s;\n out[4] = a10 * c - a00 * s;\n out[5] = a11 * c - a01 * s;\n out[6] = a12 * c - a02 * s;\n out[7] = a13 * c - a03 * s;\n return out;\n};","module.exports = scale;\n\n/**\n * Scales the mat4 by the dimensions in the given vec3\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to scale\n * @param {vec3} v the vec3 to scale the matrix by\n * @returns {mat4} out\n **/\nfunction scale(out, a, v) {\n var x = v[0], y = v[1], z = v[2];\n\n out[0] = a[0] * x;\n out[1] = a[1] * x;\n out[2] = a[2] * x;\n out[3] = a[3] * x;\n out[4] = a[4] * y;\n out[5] = a[5] * y;\n out[6] = a[6] * y;\n out[7] = a[7] * y;\n out[8] = a[8] * z;\n out[9] = a[9] * z;\n out[10] = a[10] * z;\n out[11] = a[11] * z;\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n};","module.exports = str;\n\n/**\n * Returns a string representation of a mat4\n *\n * @param {mat4} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nfunction str(a) {\n return 'mat4(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ', ' +\n a[4] + ', ' + a[5] + ', ' + a[6] + ', ' + a[7] + ', ' +\n a[8] + ', ' + a[9] + ', ' + a[10] + ', ' + a[11] + ', ' + \n a[12] + ', ' + a[13] + ', ' + a[14] + ', ' + a[15] + ')';\n};","module.exports = translate;\n\n/**\n * Translate a mat4 by the given vector\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to translate\n * @param {vec3} v vector to translate by\n * @returns {mat4} out\n */\nfunction translate(out, a, v) {\n var x = v[0], y = v[1], z = v[2],\n a00, a01, a02, a03,\n a10, a11, a12, a13,\n a20, a21, a22, a23;\n\n if (a === out) {\n out[12] = a[0] * x + a[4] * y + a[8] * z + a[12];\n out[13] = a[1] * x + a[5] * y + a[9] * z + a[13];\n out[14] = a[2] * x + a[6] * y + a[10] * z + a[14];\n out[15] = a[3] * x + a[7] * y + a[11] * z + a[15];\n } else {\n a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3];\n a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7];\n a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11];\n\n out[0] = a00; out[1] = a01; out[2] = a02; out[3] = a03;\n out[4] = a10; out[5] = a11; out[6] = a12; out[7] = a13;\n out[8] = a20; out[9] = a21; out[10] = a22; out[11] = a23;\n\n out[12] = a00 * x + a10 * y + a20 * z + a[12];\n out[13] = a01 * x + a11 * y + a21 * z + a[13];\n out[14] = a02 * x + a12 * y + a22 * z + a[14];\n out[15] = a03 * x + a13 * y + a23 * z + a[15];\n }\n\n return out;\n};","module.exports = transpose;\n\n/**\n * Transpose the values of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nfunction transpose(out, a) {\n // If we are transposing ourselves we can skip a few steps but have to cache some values\n if (out === a) {\n var a01 = a[1], a02 = a[2], a03 = a[3],\n a12 = a[6], a13 = a[7],\n a23 = a[11];\n\n out[1] = a[4];\n out[2] = a[8];\n out[3] = a[12];\n out[4] = a01;\n out[6] = a[9];\n out[7] = a[13];\n out[8] = a02;\n out[9] = a12;\n out[11] = a[14];\n out[12] = a03;\n out[13] = a13;\n out[14] = a23;\n } else {\n out[0] = a[0];\n out[1] = a[4];\n out[2] = a[8];\n out[3] = a[12];\n out[4] = a[1];\n out[5] = a[5];\n out[6] = a[9];\n out[7] = a[13];\n out[8] = a[2];\n out[9] = a[6];\n out[10] = a[10];\n out[11] = a[14];\n out[12] = a[3];\n out[13] = a[7];\n out[14] = a[11];\n out[15] = a[15];\n }\n \n return out;\n};","'use strict'\n\nvar Font = require('css-font')\nvar pick = require('pick-by-alias')\nvar createRegl = require('regl')\nvar createGl = require('gl-util/context')\nvar WeakMap = require('es6-weak-map')\nvar rgba = require('color-normalize')\nvar fontAtlas = require('font-atlas')\nvar pool = require('typedarray-pool')\nvar parseRect = require('parse-rect')\nvar isObj = require('is-plain-obj')\nvar parseUnit = require('parse-unit')\nvar px = require('to-px')\nvar kerning = require('detect-kerning')\nvar extend = require('object-assign')\nvar metrics = require('font-measure')\nvar flatten = require('flatten-vertex-data')\nvar ref = require('bit-twiddle');\nvar nextPow2 = ref.nextPow2;\n\nvar shaderCache = new WeakMap\n\n\n// Safari does not support font-stretch\nvar isStretchSupported = false\nif (document.body) {\n var el = document.body.appendChild(document.createElement('div'))\n el.style.font = 'italic small-caps bold condensed 16px/2 cursive'\n if (getComputedStyle(el).fontStretch) {\n isStretchSupported = true\n }\n document.body.removeChild(el)\n}\n\nvar GlText = function GlText (o) {\n\tif (isRegl(o)) {\n\t\to = {regl: o}\n\t\tthis.gl = o.regl._gl\n\t}\n\telse {\n\t\tthis.gl = createGl(o)\n\t}\n\n\tthis.shader = shaderCache.get(this.gl)\n\n\tif (!this.shader) {\n\t\tthis.regl = o.regl || createRegl({ gl: this.gl })\n\t}\n\telse {\n\t\tthis.regl = this.shader.regl\n\t}\n\n\tthis.charBuffer = this.regl.buffer({ type: 'uint8', usage: 'stream' })\n\tthis.sizeBuffer = this.regl.buffer({ type: 'float', usage: 'stream' })\n\n\tif (!this.shader) {\n\t\tthis.shader = this.createShader()\n\t\tshaderCache.set(this.gl, this.shader)\n\t}\n\n\tthis.batch = []\n\n\t// multiple options initial state\n\tthis.fontSize = []\n\tthis.font = []\n\tthis.fontAtlas = []\n\n\tthis.draw = this.shader.draw.bind(this)\n\tthis.render = function () {\n\t\t// FIXME: add Safari regl report here:\n\t\t// charBuffer and width just do not trigger\n\t\tthis.regl._refresh()\n\t\tthis.draw(this.batch)\n\t}\n\tthis.canvas = this.gl.canvas\n\n\tthis.update(isObj(o) ? o : {})\n};\n\nGlText.prototype.createShader = function createShader () {\n\tvar regl = this.regl\n\n\tvar draw = regl({\n\t\tblend: {\n\t\t\tenable: true,\n\t\t\tcolor: [0,0,0,1],\n\n\t\t\tfunc: {\n\t\t\t\tsrcRGB: 'src alpha',\n\t\t\t\tdstRGB: 'one minus src alpha',\n\t\t\t\tsrcAlpha: 'one minus dst alpha',\n\t\t\t\tdstAlpha: 'one'\n\t\t\t}\n\t\t},\n\t\tstencil: {enable: false},\n\t\tdepth: {enable: false},\n\n\t\tcount: regl.prop('count'),\n\t\toffset: regl.prop('offset'),\n\t\tattributes: {\n\t\t\tcharOffset: {\n\t\t\t\toffset: 4,\n\t\t\t\tstride: 8,\n\t\t\t\tbuffer: regl.this('sizeBuffer')\n\t\t\t},\n\t\t\twidth: {\n\t\t\t\toffset: 0,\n\t\t\t\tstride: 8,\n\t\t\t\tbuffer: regl.this('sizeBuffer')\n\t\t\t},\n\t\t\tchar: regl.this('charBuffer'),\n\t\t\tposition: regl.this('position')\n\t\t},\n\t\tuniforms: {\n\t\t\tatlasSize: function (c, p) { return [p.atlas.width, p.atlas.height]; },\n\t\t\tatlasDim: function (c, p) { return [p.atlas.cols, p.atlas.rows]; },\n\t\t\tatlas: function (c, p) { return p.atlas.texture; },\n\t\t\tcharStep: function (c, p) { return p.atlas.step; },\n\t\t\tem: function (c, p) { return p.atlas.em; },\n\t\t\tcolor: regl.prop('color'),\n\t\t\topacity: regl.prop('opacity'),\n\t\t\tviewport: regl.this('viewportArray'),\n\t\t\tscale: regl.this('scale'),\n\t\t\talign: regl.prop('align'),\n\t\t\tbaseline: regl.prop('baseline'),\n\t\t\ttranslate: regl.this('translate'),\n\t\t\tpositionOffset: regl.prop('positionOffset')\n\t\t},\n\t\tprimitive: 'points',\n\t\tviewport: regl.this('viewport'),\n\n\t\tvert: \"\\n\\t\\t\\tprecision highp float;\\n\\t\\t\\tattribute float width, charOffset, char;\\n\\t\\t\\tattribute vec2 position;\\n\\t\\t\\tuniform float fontSize, charStep, em, align, baseline;\\n\\t\\t\\tuniform vec4 viewport;\\n\\t\\t\\tuniform vec4 color;\\n\\t\\t\\tuniform vec2 atlasSize, atlasDim, scale, translate, positionOffset;\\n\\t\\t\\tvarying vec2 charCoord, charId;\\n\\t\\t\\tvarying float charWidth;\\n\\t\\t\\tvarying vec4 fontColor;\\n\\t\\t\\tvoid main () {\\n\\t\\t\\t\\tvec2 offset = floor(em * (vec2(align + charOffset, baseline)\\n\\t\\t\\t\\t\\t+ vec2(positionOffset.x, -positionOffset.y)))\\n\\t\\t\\t\\t\\t/ (viewport.zw * scale.xy);\\n\\n\\t\\t\\t\\tvec2 position = (position + translate) * scale;\\n\\t\\t\\t\\tposition += offset * scale;\\n\\n\\t\\t\\t\\tcharCoord = position * viewport.zw + viewport.xy;\\n\\n\\t\\t\\t\\tgl_Position = vec4(position * 2. - 1., 0, 1);\\n\\n\\t\\t\\t\\tgl_PointSize = charStep;\\n\\n\\t\\t\\t\\tcharId.x = mod(char, atlasDim.x);\\n\\t\\t\\t\\tcharId.y = floor(char / atlasDim.x);\\n\\n\\t\\t\\t\\tcharWidth = width * em;\\n\\n\\t\\t\\t\\tfontColor = color / 255.;\\n\\t\\t\\t}\",\n\n\t\tfrag: \"\\n\\t\\t\\tprecision highp float;\\n\\t\\t\\tuniform float fontSize, charStep, opacity;\\n\\t\\t\\tuniform vec2 atlasSize;\\n\\t\\t\\tuniform vec4 viewport;\\n\\t\\t\\tuniform sampler2D atlas;\\n\\t\\t\\tvarying vec4 fontColor;\\n\\t\\t\\tvarying vec2 charCoord, charId;\\n\\t\\t\\tvarying float charWidth;\\n\\n\\t\\t\\tfloat lightness(vec4 color) {\\n\\t\\t\\t\\treturn color.r * 0.299 + color.g * 0.587 + color.b * 0.114;\\n\\t\\t\\t}\\n\\n\\t\\t\\tvoid main () {\\n\\t\\t\\t\\tvec2 uv = gl_FragCoord.xy - charCoord + charStep * .5;\\n\\t\\t\\t\\tfloat halfCharStep = floor(charStep * .5 + .5);\\n\\n\\t\\t\\t\\t// invert y and shift by 1px (FF expecially needs that)\\n\\t\\t\\t\\tuv.y = charStep - uv.y;\\n\\n\\t\\t\\t\\t// ignore points outside of character bounding box\\n\\t\\t\\t\\tfloat halfCharWidth = ceil(charWidth * .5);\\n\\t\\t\\t\\tif (floor(uv.x) > halfCharStep + halfCharWidth ||\\n\\t\\t\\t\\t\\tfloor(uv.x) < halfCharStep - halfCharWidth) return;\\n\\n\\t\\t\\t\\tuv += charId * charStep;\\n\\t\\t\\t\\tuv = uv / atlasSize;\\n\\n\\t\\t\\t\\tvec4 color = fontColor;\\n\\t\\t\\t\\tvec4 mask = texture2D(atlas, uv);\\n\\n\\t\\t\\t\\tfloat maskY = lightness(mask);\\n\\t\\t\\t\\t// float colorY = lightness(color);\\n\\t\\t\\t\\tcolor.a *= maskY;\\n\\t\\t\\t\\tcolor.a *= opacity;\\n\\n\\t\\t\\t\\t// color.a += .1;\\n\\n\\t\\t\\t\\t// antialiasing, see yiq color space y-channel formula\\n\\t\\t\\t\\t// color.rgb += (1. - color.rgb) * (1. - mask.rgb);\\n\\n\\t\\t\\t\\tgl_FragColor = color;\\n\\t\\t\\t}\"\n\t})\n\n\t// per font-size atlas\n\tvar atlas = {}\n\n\treturn { regl: regl, draw: draw, atlas: atlas }\n};\n\nGlText.prototype.update = function update (o) {\n\t\tvar this$1 = this;\n\n\tif (typeof o === 'string') { o = { text: o } }\n\telse if (!o) { return }\n\n\t// FIXME: make this a static transform or more general approact\n\to = pick(o, {\n\t\tposition: 'position positions coord coords coordinates',\n\t\tfont: 'font fontFace fontface typeface cssFont css-font family fontFamily',\n\t\tfontSize: 'fontSize fontsize size font-size',\n\t\ttext: 'text texts chars characters value values symbols',\n\t\talign: 'align alignment textAlign textbaseline',\n\t\tbaseline: 'baseline textBaseline textbaseline',\n\t\tdirection: 'dir direction textDirection',\n\t\tcolor: 'color colour fill fill-color fillColor textColor textcolor',\n\t\tkerning: 'kerning kern',\n\t\trange: 'range dataBox',\n\t\tviewport: 'vp viewport viewBox viewbox viewPort',\n\t\topacity: 'opacity alpha transparency visible visibility opaque',\n\t\toffset: 'offset positionOffset padding shift indent indentation'\n\t}, true)\n\n\n\tif (o.opacity != null) {\n\t\tif (Array.isArray(o.opacity)) {\n\t\t\tthis.opacity = o.opacity.map(function (o) { return parseFloat(o); })\n\t\t}\n\t\telse {\n\t\t\tthis.opacity = parseFloat(o.opacity)\n\t\t}\n\t}\n\n\tif (o.viewport != null) {\n\t\tthis.viewport = parseRect(o.viewport)\n\n\t\tthis.viewportArray = [this.viewport.x, this.viewport.y, this.viewport.width, this.viewport.height]\n\n\t}\n\tif (this.viewport == null) {\n\t\tthis.viewport = {\n\t\t\tx: 0, y: 0,\n\t\t\twidth: this.gl.drawingBufferWidth,\n\t\t\theight: this.gl.drawingBufferHeight\n\t\t}\n\t\tthis.viewportArray = [this.viewport.x, this.viewport.y, this.viewport.width, this.viewport.height]\n\t}\n\n\tif (o.kerning != null) { this.kerning = o.kerning }\n\n\tif (o.offset != null) {\n\t\tif (typeof o.offset === 'number') { o.offset = [o.offset, 0] }\n\n\t\tthis.positionOffset = flatten(o.offset)\n\t}\n\n\tif (o.direction) { this.direction = o.direction }\n\n\tif (o.range) {\n\t\tthis.range = o.range\n\t\tthis.scale = [1 / (o.range[2] - o.range[0]), 1 / (o.range[3] - o.range[1])]\n\t\tthis.translate = [-o.range[0], -o.range[1]]\n\t}\n\tif (o.scale) { this.scale = o.scale }\n\tif (o.translate) { this.translate = o.translate }\n\n\t// default scale corresponds to viewport\n\tif (!this.scale) { this.scale = [1 / this.viewport.width, 1 / this.viewport.height] }\n\n\tif (!this.translate) { this.translate = [0, 0] }\n\n\tif (!this.font.length && !o.font) { o.font = GlText.baseFontSize + 'px sans-serif' }\n\n\t// normalize font caching string\n\tvar newFont = false, newFontSize = false\n\n\t// obtain new font data\n\tif (o.font) {\n\t\t(Array.isArray(o.font) ? o.font : [o.font]).forEach(function (font, i) {\n\t\t\t// normalize font\n\t\t\tif (typeof font === 'string') {\n\t\t\t\ttry {\n\t\t\t\t\tfont = Font.parse(font)\n\t\t\t\t} catch (e) {\n\t\t\t\t\tfont = Font.parse(GlText.baseFontSize + 'px ' + font)\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tvar fontStyle = font.style\n\t\t\t\tvar fontWeight = font.weight\n\t\t\t\tvar fontStretch = font.stretch\n\t\t\t\tvar fontVariant = font.variant\n\t\t\t\tfont = Font.parse(Font.stringify(font))\n\t\t\t\tif (fontStyle) font.style = fontStyle\n\t\t\t\tif (fontWeight) font.weight = fontWeight\n\t\t\t\tif (fontStretch) font.stretch = fontStretch\n\t\t\t\tif (fontVariant) font.variant = fontVariant\n\t\t\t}\n\n\t\t\tvar baseString = Font.stringify({\n\t\t\t\tsize: GlText.baseFontSize,\n\t\t\t\tfamily: font.family,\n\t\t\t\tstretch: isStretchSupported ? font.stretch : undefined,\n\t\t\t\tvariant: font.variant,\n\t\t\t\tweight: font.weight,\n\t\t\t\tstyle: font.style\n\t\t\t})\n\n\t\t\tvar unit = parseUnit(font.size)\n\t\t\tvar fs = Math.round(unit[0] * px(unit[1]))\n\t\t\tif (fs !== this$1.fontSize[i]) {\n\t\t\t\tnewFontSize = true\n\t\t\t\tthis$1.fontSize[i] = fs\n\t\t\t}\n\n\t\t\t// calc new font metrics/atlas\n\t\t\tif (!this$1.font[i] || baseString != this$1.font[i].baseString) {\n\t\t\t\tnewFont = true\n\n\t\t\t\t// obtain font cache or create one\n\t\t\t\tthis$1.font[i] = GlText.fonts[baseString]\n\t\t\t\tif (!this$1.font[i]) {\n\t\t\t\t\tvar family = font.family.join(', ')\n\t\t\t\t\tvar style = [font.style]\n\t\t\t\t\tif (font.style != font.variant) { style.push(font.variant) }\n\t\t\t\t\tif (font.variant != font.weight) { style.push(font.weight) }\n\t\t\t\t\tif (isStretchSupported && font.weight != font.stretch) { style.push(font.stretch) }\n\n\t\t\t\t\tthis$1.font[i] = {\n\t\t\t\t\t\tbaseString: baseString,\n\n\t\t\t\t\t\t// typeface\n\t\t\t\t\t\tfamily: family,\n\t\t\t\t\t\tweight: font.weight,\n\t\t\t\t\t\tstretch: font.stretch,\n\t\t\t\t\t\tstyle: font.style,\n\t\t\t\t\t\tvariant: font.variant,\n\n\t\t\t\t\t\t// widths of characters\n\t\t\t\t\t\twidth: {},\n\n\t\t\t\t\t\t// kernin pairs offsets\n\t\t\t\t\t\tkerning: {},\n\n\t\t\t\t\t\tmetrics: metrics(family, {\n\t\t\t\t\t\t\torigin: 'top',\n\t\t\t\t\t\t\tfontSize: GlText.baseFontSize,\n\t\t\t\t\t\t\tfontStyle: style.join(' ')\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\n\t\t\t\t\tGlText.fonts[baseString] = this$1.font[i]\n\t\t\t\t}\n\t\t\t}\n\t\t})\n\t}\n\n\t// FIXME: make independend font-size\n\t// if (o.fontSize) {\n\t// let unit = parseUnit(o.fontSize)\n\t// let fs = Math.round(unit[0] * px(unit[1]))\n\n\t// if (fs != this.fontSize) {\n\t// \tnewFontSize = true\n\t// \tthis.fontSize = fs\n\t// }\n\t// }\n\n\tif (newFont || newFontSize) {\n\t\tthis.font.forEach(function (font, i) {\n\t\t\tvar fontString = Font.stringify({\n\t\t\t\tsize: this$1.fontSize[i],\n\t\t\t\tfamily: font.family,\n\t\t\t\tstretch: isStretchSupported ? font.stretch : undefined,\n\t\t\t\tvariant: font.variant,\n\t\t\t\tweight: font.weight,\n\t\t\t\tstyle: font.style\n\t\t\t})\n\n\t\t\t// calc new font size atlas\n\t\t\tthis$1.fontAtlas[i] = this$1.shader.atlas[fontString]\n\n\t\t\tif (!this$1.fontAtlas[i]) {\n\t\t\t\tvar metrics = font.metrics\n\n\t\t\t\tthis$1.shader.atlas[fontString] =\n\t\t\t\tthis$1.fontAtlas[i] = {\n\t\t\t\t\tfontString: fontString,\n\t\t\t\t\t// even step is better for rendered characters\n\t\t\t\t\tstep: Math.ceil(this$1.fontSize[i] * metrics.bottom * .5) * 2,\n\t\t\t\t\tem: this$1.fontSize[i],\n\t\t\t\t\tcols: 0,\n\t\t\t\t\trows: 0,\n\t\t\t\t\theight: 0,\n\t\t\t\t\twidth: 0,\n\t\t\t\t\tchars: [],\n\t\t\t\t\tids: {},\n\t\t\t\t\ttexture: this$1.regl.texture()\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// bump atlas characters\n\t\t\tif (o.text == null) { o.text = this$1.text }\n\t\t})\n\t}\n\n\t// if multiple positions - duplicate text arguments\n\t// FIXME: this possibly can be done better to avoid array spawn\n\tif (typeof o.text === 'string' && o.position && o.position.length > 2) {\n\t\tvar textArray = Array(o.position.length * .5)\n\t\tfor (var i = 0; i < textArray.length; i++) {\n\t\t\ttextArray[i] = o.text\n\t\t}\n\t\to.text = textArray\n\t}\n\n\t// calculate offsets for the new font/text\n\tvar newAtlasChars\n\tif (o.text != null || newFont) {\n\t\t// FIXME: ignore spaces\n\t\t// text offsets within the text buffer\n\t\tthis.textOffsets = [0]\n\n\t\tif (Array.isArray(o.text)) {\n\t\t\tthis.count = o.text[0].length\n\t\t\tthis.counts = [this.count]\n\t\t\tfor (var i$1 = 1; i$1 < o.text.length; i$1++) {\n\t\t\t\tthis.textOffsets[i$1] = this.textOffsets[i$1 - 1] + o.text[i$1 - 1].length\n\t\t\t\tthis.count += o.text[i$1].length\n\t\t\t\tthis.counts.push(o.text[i$1].length)\n\t\t\t}\n\t\t\tthis.text = o.text.join('')\n\t\t}\n\t\telse {\n\t\t\tthis.text = o.text\n\t\t\tthis.count = this.text.length\n\t\t\tthis.counts = [this.count]\n\t\t}\n\n\t\tnewAtlasChars = []\n\n\t\t// detect & measure new characters\n\t\tthis.font.forEach(function (font, idx) {\n\t\t\tGlText.atlasContext.font = font.baseString\n\n\t\t\tvar atlas = this$1.fontAtlas[idx]\n\n\t\t\tfor (var i = 0; i < this$1.text.length; i++) {\n\t\t\t\tvar char = this$1.text.charAt(i)\n\n\t\t\t\tif (atlas.ids[char] == null) {\n\t\t\t\t\tatlas.ids[char] = atlas.chars.length\n\t\t\t\t\tatlas.chars.push(char)\n\t\t\t\t\tnewAtlasChars.push(char)\n\t\t\t\t}\n\n\t\t\t\tif (font.width[char] == null) {\n\t\t\t\t\tfont.width[char] = GlText.atlasContext.measureText(char).width / GlText.baseFontSize\n\n\t\t\t\t\t// measure kerning pairs for the new character\n\t\t\t\t\tif (this$1.kerning) {\n\t\t\t\t\t\tvar pairs = []\n\t\t\t\t\t\tfor (var baseChar in font.width) {\n\t\t\t\t\t\t\tpairs.push(baseChar + char, char + baseChar)\n\t\t\t\t\t\t}\n\t\t\t\t\t\textend(font.kerning, kerning(font.family, {\n\t\t\t\t\t\t\tpairs: pairs\n\t\t\t\t\t\t}))\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t})\n\t}\n\n\t// create single position buffer (faster than batch or multiple separate instances)\n\tif (o.position) {\n\t\tif (o.position.length > 2) {\n\t\t\tvar flat = !o.position[0].length\n\t\t\tvar positionData = pool.mallocFloat(this.count * 2)\n\t\t\tfor (var i$2 = 0, ptr = 0; i$2 < this.counts.length; i$2++) {\n\t\t\t\tvar count = this.counts[i$2]\n\t\t\t\tif (flat) {\n\t\t\t\t\tfor (var j = 0; j < count; j++) {\n\t\t\t\t\t\tpositionData[ptr++] = o.position[i$2 * 2]\n\t\t\t\t\t\tpositionData[ptr++] = o.position[i$2 * 2 + 1]\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tfor (var j$1 = 0; j$1 < count; j$1++) {\n\t\t\t\t\t\tpositionData[ptr++] = o.position[i$2][0]\n\t\t\t\t\t\tpositionData[ptr++] = o.position[i$2][1]\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (this.position.call) {\n\t\t\t\tthis.position({\n\t\t\t\t\ttype: 'float',\n\t\t\t\t\tdata: positionData\n\t\t\t\t})\n\t\t\t} else {\n\t\t\t\tthis.position = this.regl.buffer({\n\t\t\t\t\ttype: 'float',\n\t\t\t\t\tdata: positionData\n\t\t\t\t})\n\t\t\t}\n\t\t\tpool.freeFloat(positionData)\n\t\t}\n\t\telse {\n\t\t\tif (this.position.destroy) { this.position.destroy() }\n\t\t\tthis.position = {\n\t\t\t\tconstant: o.position\n\t\t\t}\n\t\t}\n\t}\n\n\t// populate text/offset buffers if font/text has changed\n\t// as [charWidth, offset, charWidth, offset...]\n\t// that is in em units since font-size can change often\n\tif (o.text || newFont) {\n\t\tvar charIds = pool.mallocUint8(this.count)\n\t\tvar sizeData = pool.mallocFloat(this.count * 2)\n\t\tthis.textWidth = []\n\n\t\tfor (var i$3 = 0, ptr$1 = 0; i$3 < this.counts.length; i$3++) {\n\t\t\tvar count$1 = this.counts[i$3]\n\t\t\tvar font = this.font[i$3] || this.font[0]\n\t\t\tvar atlas = this.fontAtlas[i$3] || this.fontAtlas[0]\n\n\t\t\tfor (var j$2 = 0; j$2 < count$1; j$2++) {\n\t\t\t\tvar char = this.text.charAt(ptr$1)\n\t\t\t\tvar prevChar = this.text.charAt(ptr$1 - 1)\n\n\t\t\t\tcharIds[ptr$1] = atlas.ids[char]\n\t\t\t\tsizeData[ptr$1 * 2] = font.width[char]\n\n\t\t\t\tif (j$2) {\n\t\t\t\t\tvar prevWidth = sizeData[ptr$1 * 2 - 2]\n\t\t\t\t\tvar currWidth = sizeData[ptr$1 * 2]\n\t\t\t\t\tvar prevOffset = sizeData[ptr$1 * 2 - 1]\n\t\t\t\t\tvar offset = prevOffset + prevWidth * .5 + currWidth * .5;\n\n\t\t\t\t\tif (this.kerning) {\n\t\t\t\t\t\tvar kerning$1 = font.kerning[prevChar + char]\n\t\t\t\t\t\tif (kerning$1) {\n\t\t\t\t\t\t\toffset += kerning$1 * 1e-3\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tsizeData[ptr$1 * 2 + 1] = offset\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tsizeData[ptr$1 * 2 + 1] = sizeData[ptr$1 * 2] * .5\n\t\t\t\t}\n\n\t\t\t\tptr$1++\n\t\t\t}\n\t\t\tthis.textWidth.push(\n\t\t\t\t!sizeData.length ? 0 :\n\t\t\t\t// last offset + half last width\n\t\t\t\tsizeData[ptr$1 * 2 - 2] * .5 + sizeData[ptr$1 * 2 - 1]\n\t\t\t)\n\t\t}\n\n\n\t\t// bump recalc align offset\n\t\tif (!o.align) { o.align = this.align }\n\t\tthis.charBuffer({data: charIds, type: 'uint8', usage: 'stream'})\n\t\tthis.sizeBuffer({data: sizeData, type: 'float', usage: 'stream'})\n\t\tpool.freeUint8(charIds)\n\t\tpool.freeFloat(sizeData)\n\n\t\t// udpate font atlas and texture\n\t\tif (newAtlasChars.length) {\n\t\t\tthis.font.forEach(function (font, i) {\n\t\t\t\tvar atlas = this$1.fontAtlas[i]\n\n\t\t\t\t// FIXME: insert metrics-based ratio here\n\t\t\t\tvar step = atlas.step\n\n\t\t\t\tvar maxCols = Math.floor(GlText.maxAtlasSize / step)\n\t\t\t\tvar cols = Math.min(maxCols, atlas.chars.length)\n\t\t\t\tvar rows = Math.ceil(atlas.chars.length / cols)\n\n\t\t\t\tvar atlasWidth = nextPow2( cols * step )\n\t\t\t\t// let atlasHeight = Math.min(rows * step + step * .5, GlText.maxAtlasSize);\n\t\t\t\tvar atlasHeight = nextPow2( rows * step );\n\n\t\t\t\tatlas.width = atlasWidth\n\t\t\t\tatlas.height = atlasHeight;\n\t\t\t\tatlas.rows = rows\n\t\t\t\tatlas.cols = cols\n\n\t\t\t\tif (!atlas.em) { return }\n\n\t\t\t\tatlas.texture({\n\t\t\t\t\tdata: fontAtlas({\n\t\t\t\t\t\tcanvas: GlText.atlasCanvas,\n\t\t\t\t\t\tfont: atlas.fontString,\n\t\t\t\t\t\tchars: atlas.chars,\n\t\t\t\t\t\tshape: [atlasWidth, atlasHeight],\n\t\t\t\t\t\tstep: [step, step]\n\t\t\t\t\t})\n\t\t\t\t})\n\n\t\t\t})\n\t\t}\n\t}\n\n\tif (o.align) {\n\t\tthis.align = o.align\n\t\tthis.alignOffset = this.textWidth.map(function (textWidth, i) {\n\t\t\tvar align = !Array.isArray(this$1.align) ? this$1.align : this$1.align.length > 1 ? this$1.align[i] : this$1.align[0]\n\n\t\t\tif (typeof align === 'number') { return align }\n\t\t\tswitch (align) {\n\t\t\t\tcase 'right':\n\t\t\t\tcase 'end':\n\t\t\t\t\treturn -textWidth\n\t\t\t\tcase 'center':\n\t\t\t\tcase 'centre':\n\t\t\t\tcase 'middle':\n\t\t\t\t\treturn -textWidth * .5\n\t\t\t}\n\n\t\t\treturn 0\n\t\t})\n\t}\n\n\tif (this.baseline == null && o.baseline == null) {\n\t\to.baseline = 0\n\t}\n\tif (o.baseline != null) {\n\t\tthis.baseline = o.baseline\n\t\tif (!Array.isArray(this.baseline)) { this.baseline = [this.baseline] }\n\t\tthis.baselineOffset = this.baseline.map(function (baseline, i) {\n\t\t\tvar m = (this$1.font[i] || this$1.font[0]).metrics\n\t\t\tvar base = 0\n\n\t\t\tbase += m.bottom * .5\n\n\t\t\tif (typeof baseline === 'number') {\n\t\t\t\tbase += (baseline - m.baseline)\n\t\t\t}\n\t\t\telse {\n\t\t\t\tbase += -m[baseline]\n\t\t\t}\n\n\t\t\tbase *= -1\n\t\t\treturn base\n\t\t})\n\t}\n\n\t// flatten colors to a single uint8 array\n\tif (o.color != null) {\n\t\tif (!o.color) { o.color = 'transparent' }\n\n\t\t// single color\n\t\tif (typeof o.color === 'string' || !isNaN(o.color)) {\n\t\t\tthis.color = rgba(o.color, 'uint8')\n\t\t}\n\t\t// array\n\t\telse {\n\t\t\tvar colorData\n\n\t\t\t// flat array\n\t\t\tif (typeof o.color[0] === 'number' && o.color.length > this.counts.length) {\n\t\t\t\tvar l = o.color.length\n\t\t\t\tcolorData = pool.mallocUint8(l)\n\t\t\t\tvar sub = (o.color.subarray || o.color.slice).bind(o.color)\n\t\t\t\tfor (var i$4 = 0; i$4 < l; i$4 += 4) {\n\t\t\t\t\tcolorData.set(rgba(sub(i$4, i$4 + 4), 'uint8'), i$4)\n\t\t\t\t}\n\t\t\t}\n\t\t\t// nested array\n\t\t\telse {\n\t\t\t\tvar l$1 = o.color.length\n\t\t\t\tcolorData = pool.mallocUint8(l$1 * 4)\n\t\t\t\tfor (var i$5 = 0; i$5 < l$1; i$5++) {\n\t\t\t\t\tcolorData.set(rgba(o.color[i$5] || 0, 'uint8'), i$5 * 4)\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.color = colorData\n\t\t}\n\t}\n\n\t// update render batch\n\tif (o.position || o.text || o.color || o.baseline || o.align || o.font || o.offset || o.opacity) {\n\t\tvar isBatch = (this.color.length > 4)\n\t\t\t|| (this.baselineOffset.length > 1)\n\t\t\t|| (this.align && this.align.length > 1)\n\t\t\t|| (this.fontAtlas.length > 1)\n\t\t\t|| (this.positionOffset.length > 2)\n\t\tif (isBatch) {\n\t\t\tvar length = Math.max(\n\t\t\t\tthis.position.length * .5 || 0,\n\t\t\t\tthis.color.length * .25 || 0,\n\t\t\t\tthis.baselineOffset.length || 0,\n\t\t\t\tthis.alignOffset.length || 0,\n\t\t\t\tthis.font.length || 0,\n\t\t\t\tthis.opacity.length || 0,\n\t\t\t\tthis.positionOffset.length * .5 || 0\n\t\t\t)\n\t\t\tthis.batch = Array(length)\n\t\t\tfor (var i$6 = 0; i$6 < this.batch.length; i$6++) {\n\t\t\t\tthis.batch[i$6] = {\n\t\t\t\t\tcount: this.counts.length > 1 ? this.counts[i$6] : this.counts[0],\n\t\t\t\t\toffset: this.textOffsets.length > 1 ? this.textOffsets[i$6] : this.textOffsets[0],\n\t\t\t\t\tcolor: !this.color ? [0,0,0,255] : this.color.length <= 4 ? this.color : this.color.subarray(i$6 * 4, i$6 * 4 + 4),\n\t\t\t\t\topacity: Array.isArray(this.opacity) ? this.opacity[i$6] : this.opacity,\n\t\t\t\t\tbaseline: this.baselineOffset[i$6] != null ? this.baselineOffset[i$6] : this.baselineOffset[0],\n\t\t\t\t\talign: !this.align ? 0 : this.alignOffset[i$6] != null ? this.alignOffset[i$6] : this.alignOffset[0],\n\t\t\t\t\tatlas: this.fontAtlas[i$6] || this.fontAtlas[0],\n\t\t\t\t\tpositionOffset: this.positionOffset.length > 2 ? this.positionOffset.subarray(i$6 * 2, i$6 * 2 + 2) : this.positionOffset\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t// single-color, single-baseline, single-align batch is faster to render\n\t\telse {\n\t\t\tif (this.count) {\n\t\t\t\tthis.batch = [{\n\t\t\t\t\tcount: this.count,\n\t\t\t\t\toffset: 0,\n\t\t\t\t\tcolor: this.color || [0,0,0,255],\n\t\t\t\t\topacity: Array.isArray(this.opacity) ? this.opacity[0] : this.opacity,\n\t\t\t\t\tbaseline: this.baselineOffset[0],\n\t\t\t\t\talign: this.alignOffset ? this.alignOffset[0] : 0,\n\t\t\t\t\tatlas: this.fontAtlas[0],\n\t\t\t\t\tpositionOffset: this.positionOffset\n\t\t\t\t}]\n\t\t\t}\n\t\t\telse {\n\t\t\t\tthis.batch = []\n\t\t\t}\n\t\t}\n\t}\n};\n\nGlText.prototype.destroy = function destroy () {\n\t// TODO: count instances of atlases and destroy all on null\n};\n\n\n// defaults\nGlText.prototype.kerning = true\nGlText.prototype.position = { constant: new Float32Array(2) }\nGlText.prototype.translate = null\nGlText.prototype.scale = null\nGlText.prototype.font = null\nGlText.prototype.text = ''\nGlText.prototype.positionOffset = [0, 0]\nGlText.prototype.opacity = 1\nGlText.prototype.color = new Uint8Array([0, 0, 0, 255])\nGlText.prototype.alignOffset = [0, 0]\n\n\n// size of an atlas\nGlText.maxAtlasSize = 1024\n\n// font atlas canvas is singleton\nGlText.atlasCanvas = document.createElement('canvas')\nGlText.atlasContext = GlText.atlasCanvas.getContext('2d', {alpha: false})\n\n// font-size used for metrics, atlas step calculation\nGlText.baseFontSize = 64\n\n// fonts storage\nGlText.fonts = {}\n\n// max number of different font atlases/textures cached\n// FIXME: enable atlas size limitation via LRU\n// GlText.atlasCacheSize = 64\n\nfunction isRegl (o) {\n\treturn typeof o === 'function' &&\n\to._gl &&\n\to.prop &&\n\to.texture &&\n\to.buffer\n}\n\n\nmodule.exports = GlText\n\n","/** @module gl-util/context */\r\n'use strict'\r\n\r\nvar pick = require('pick-by-alias')\r\n\r\nmodule.exports = function setContext (o) {\r\n\tif (!o) o = {}\r\n\telse if (typeof o === 'string') o = {container: o}\r\n\r\n\t// HTMLCanvasElement\r\n\tif (isCanvas(o)) {\r\n\t\to = {container: o}\r\n\t}\r\n\t// HTMLElement\r\n\telse if (isElement(o)) {\r\n\t\to = {container: o}\r\n\t}\r\n\t// WebGLContext\r\n\telse if (isContext(o)) {\r\n\t\to = {gl: o}\r\n\t}\r\n\t// options object\r\n\telse {\r\n\t\to = pick(o, {\r\n\t\t\tcontainer: 'container target element el canvas holder parent parentNode wrapper use ref root node',\r\n\t\t\tgl: 'gl context webgl glContext',\r\n\t\t\tattrs: 'attributes attrs contextAttributes',\r\n\t\t\tpixelRatio: 'pixelRatio pxRatio px ratio pxratio pixelratio',\r\n\t\t\twidth: 'w width',\r\n\t\t\theight: 'h height'\r\n\t\t}, true)\r\n\t}\r\n\r\n\tif (!o.pixelRatio) o.pixelRatio = global.pixelRatio || 1\r\n\r\n\t// make sure there is container and canvas\r\n\tif (o.gl) {\r\n\t\treturn o.gl\r\n\t}\r\n\tif (o.canvas) {\r\n\t\to.container = o.canvas.parentNode\r\n\t}\r\n\tif (o.container) {\r\n\t\tif (typeof o.container === 'string') {\r\n\t\t\tvar c = document.querySelector(o.container)\r\n\t\t\tif (!c) throw Error('Element ' + o.container + ' is not found')\r\n\t\t\to.container = c\r\n\t\t}\r\n\t\tif (isCanvas(o.container)) {\r\n\t\t\to.canvas = o.container\r\n\t\t\to.container = o.canvas.parentNode\r\n\t\t}\r\n\t\telse if (!o.canvas) {\r\n\t\t\to.canvas = createCanvas()\r\n\t\t\to.container.appendChild(o.canvas)\r\n\t\t\tresize(o)\r\n\t\t}\r\n\t}\r\n\t// blank new canvas\r\n\telse if (!o.canvas) {\r\n\t\tif (typeof document !== 'undefined') {\r\n\t\t\to.container = document.body || document.documentElement\r\n\t\t\to.canvas = createCanvas()\r\n\t\t\to.container.appendChild(o.canvas)\r\n\t\t\tresize(o)\r\n\t\t}\r\n\t\telse {\r\n\t\t\tthrow Error('Not DOM environment. Use headless-gl.')\r\n\t\t}\r\n\t}\r\n\r\n\t// make sure there is context\r\n\tif (!o.gl) {\r\n\t\t['webgl', 'experimental-webgl', 'webgl-experimental'].some(function (c) {\r\n\t\t\ttry {\r\n\t\t\t\to.gl = o.canvas.getContext(c, o.attrs);\r\n\t\t\t} catch (e) { /* no-op */ }\r\n\t\t\treturn o.gl;\r\n\t\t});\r\n\t}\r\n\r\n\treturn o.gl\r\n}\r\n\r\n\r\nfunction resize (o) {\r\n\tif (o.container) {\r\n\t\tif (o.container == document.body) {\r\n\t\t\tif (!document.body.style.width) o.canvas.width = o.width || (o.pixelRatio * global.innerWidth)\r\n\t\t\tif (!document.body.style.height) o.canvas.height = o.height || (o.pixelRatio * global.innerHeight)\r\n\t\t}\r\n\t\telse {\r\n\t\t\tvar bounds = o.container.getBoundingClientRect()\r\n\t\t\to.canvas.width = o.width || (bounds.right - bounds.left)\r\n\t\t\to.canvas.height = o.height || (bounds.bottom - bounds.top)\r\n\t\t}\r\n\t}\r\n}\r\n\r\nfunction isCanvas (e) {\r\n\treturn typeof e.getContext === 'function'\r\n\t\t&& 'width' in e\r\n\t\t&& 'height' in e\r\n}\r\n\r\nfunction isElement (e) {\r\n\treturn typeof e.nodeName === 'string' &&\r\n\t\ttypeof e.appendChild === 'function' &&\r\n\t\ttypeof e.getBoundingClientRect === 'function'\r\n}\r\n\r\nfunction isContext (e) {\r\n\treturn typeof e.drawArrays === 'function' ||\r\n\t\ttypeof e.drawElements === 'function'\r\n}\r\n\r\nfunction createCanvas () {\r\n\tvar canvas = document.createElement('canvas')\r\n\tcanvas.style.position = 'absolute'\r\n\tcanvas.style.top = 0\r\n\tcanvas.style.left = 0\r\n\r\n\treturn canvas\r\n}\r\n","module.exports = function(strings) {\n if (typeof strings === 'string') strings = [strings]\n var exprs = [].slice.call(arguments,1)\n var parts = []\n for (var i = 0; i < strings.length-1; i++) {\n parts.push(strings[i], exprs[i] || '')\n }\n parts.push(strings[i])\n return parts.join('')\n}\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\n\nvar $gOPD = GetIntrinsic('%Object.getOwnPropertyDescriptor%', true);\n\nif ($gOPD) {\n\ttry {\n\t\t$gOPD([], 'length');\n\t} catch (e) {\n\t\t// IE 8 has a broken gOPD\n\t\t$gOPD = null;\n\t}\n}\n\nmodule.exports = $gOPD;\n","'use strict'\r\n\r\nvar isBrowser = require('is-browser')\r\nvar hasHover\r\n\r\nif (typeof global.matchMedia === 'function') {\r\n\thasHover = !global.matchMedia('(hover: none)').matches\r\n}\r\nelse {\r\n\thasHover = isBrowser\r\n}\r\n\r\nmodule.exports = hasHover\r\n","'use strict'\r\n\r\nvar isBrowser = require('is-browser')\r\n\r\nfunction detect() {\r\n\tvar supported = false\r\n\r\n\ttry {\r\n\t\tvar opts = Object.defineProperty({}, 'passive', {\r\n\t\t\tget: function() {\r\n\t\t\t\tsupported = true\r\n\t\t\t}\r\n\t\t})\r\n\r\n\t\twindow.addEventListener('test', null, opts)\r\n\t\twindow.removeEventListener('test', null, opts)\r\n\t} catch(e) {\r\n\t\tsupported = false\r\n\t}\r\n\r\n\treturn supported\r\n}\r\n\r\nmodule.exports = isBrowser && detect()\r\n","'use strict';\n\nvar $defineProperty = require('es-define-property');\n\nvar hasPropertyDescriptors = function hasPropertyDescriptors() {\n\treturn !!$defineProperty;\n};\n\nhasPropertyDescriptors.hasArrayLengthDefineBug = function hasArrayLengthDefineBug() {\n\t// node v0.6 has a bug where array lengths can be Set but not Defined\n\tif (!$defineProperty) {\n\t\treturn null;\n\t}\n\ttry {\n\t\treturn $defineProperty([], 'length', { value: 1 }).length !== 1;\n\t} catch (e) {\n\t\t// In Firefox 4-22, defining length on an array throws an exception.\n\t\treturn true;\n\t}\n};\n\nmodule.exports = hasPropertyDescriptors;\n","'use strict';\n\nvar test = {\n\t__proto__: null,\n\tfoo: {}\n};\n\nvar $Object = Object;\n\n/** @type {import('.')} */\nmodule.exports = function hasProto() {\n\t// @ts-expect-error: TS errors on an inherited property for some reason\n\treturn { __proto__: test }.foo === test.foo\n\t\t&& !(test instanceof $Object);\n};\n","'use strict';\n\nvar origSymbol = typeof Symbol !== 'undefined' && Symbol;\nvar hasSymbolSham = require('./shams');\n\nmodule.exports = function hasNativeSymbols() {\n\tif (typeof origSymbol !== 'function') { return false; }\n\tif (typeof Symbol !== 'function') { return false; }\n\tif (typeof origSymbol('foo') !== 'symbol') { return false; }\n\tif (typeof Symbol('bar') !== 'symbol') { return false; }\n\n\treturn hasSymbolSham();\n};\n","'use strict';\n\n/* eslint complexity: [2, 18], max-statements: [2, 33] */\nmodule.exports = function hasSymbols() {\n\tif (typeof Symbol !== 'function' || typeof Object.getOwnPropertySymbols !== 'function') { return false; }\n\tif (typeof Symbol.iterator === 'symbol') { return true; }\n\n\tvar obj = {};\n\tvar sym = Symbol('test');\n\tvar symObj = Object(sym);\n\tif (typeof sym === 'string') { return false; }\n\n\tif (Object.prototype.toString.call(sym) !== '[object Symbol]') { return false; }\n\tif (Object.prototype.toString.call(symObj) !== '[object Symbol]') { return false; }\n\n\t// temp disabled per https://github.com/ljharb/object.assign/issues/17\n\t// if (sym instanceof Symbol) { return false; }\n\t// temp disabled per https://github.com/WebReflection/get-own-property-symbols/issues/4\n\t// if (!(symObj instanceof Symbol)) { return false; }\n\n\t// if (typeof Symbol.prototype.toString !== 'function') { return false; }\n\t// if (String(sym) !== Symbol.prototype.toString.call(sym)) { return false; }\n\n\tvar symVal = 42;\n\tobj[sym] = symVal;\n\tfor (sym in obj) { return false; } // eslint-disable-line no-restricted-syntax, no-unreachable-loop\n\tif (typeof Object.keys === 'function' && Object.keys(obj).length !== 0) { return false; }\n\n\tif (typeof Object.getOwnPropertyNames === 'function' && Object.getOwnPropertyNames(obj).length !== 0) { return false; }\n\n\tvar syms = Object.getOwnPropertySymbols(obj);\n\tif (syms.length !== 1 || syms[0] !== sym) { return false; }\n\n\tif (!Object.prototype.propertyIsEnumerable.call(obj, sym)) { return false; }\n\n\tif (typeof Object.getOwnPropertyDescriptor === 'function') {\n\t\tvar descriptor = Object.getOwnPropertyDescriptor(obj, sym);\n\t\tif (descriptor.value !== symVal || descriptor.enumerable !== true) { return false; }\n\t}\n\n\treturn true;\n};\n","'use strict';\n\nvar hasSymbols = require('has-symbols/shams');\n\n/** @type {import('.')} */\nmodule.exports = function hasToStringTagShams() {\n\treturn hasSymbols() && !!Symbol.toStringTag;\n};\n","'use strict';\n\nvar call = Function.prototype.call;\nvar $hasOwn = Object.prototype.hasOwnProperty;\nvar bind = require('function-bind');\n\n/** @type {import('.')} */\nmodule.exports = bind.call(call, $hasOwn);\n","'use strict';\n\nvar reactIs = require('react-is');\n\n/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n '$$typeof': true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n '$$typeof': true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {};\nTYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS;\nTYPE_STATICS[reactIs.Memo] = MEMO_STATICS;\n\nfunction getStatics(component) {\n // React v16.11 and below\n if (reactIs.isMemo(component)) {\n return MEMO_STATICS;\n } // React v16.12 and above\n\n\n return TYPE_STATICS[component['$$typeof']] || REACT_STATICS;\n}\n\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') {\n // don't hoist over string (html) components\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n var targetStatics = getStatics(targetComponent);\n var sourceStatics = getStatics(sourceComponent);\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n\n if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n\n try {\n // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n }\n\n return targetComponent;\n}\n\nmodule.exports = hoistNonReactStatics;\n","/** @license React v16.13.1\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';var b=\"function\"===typeof Symbol&&Symbol.for,c=b?Symbol.for(\"react.element\"):60103,d=b?Symbol.for(\"react.portal\"):60106,e=b?Symbol.for(\"react.fragment\"):60107,f=b?Symbol.for(\"react.strict_mode\"):60108,g=b?Symbol.for(\"react.profiler\"):60114,h=b?Symbol.for(\"react.provider\"):60109,k=b?Symbol.for(\"react.context\"):60110,l=b?Symbol.for(\"react.async_mode\"):60111,m=b?Symbol.for(\"react.concurrent_mode\"):60111,n=b?Symbol.for(\"react.forward_ref\"):60112,p=b?Symbol.for(\"react.suspense\"):60113,q=b?\nSymbol.for(\"react.suspense_list\"):60120,r=b?Symbol.for(\"react.memo\"):60115,t=b?Symbol.for(\"react.lazy\"):60116,v=b?Symbol.for(\"react.block\"):60121,w=b?Symbol.for(\"react.fundamental\"):60117,x=b?Symbol.for(\"react.responder\"):60118,y=b?Symbol.for(\"react.scope\"):60119;\nfunction z(a){if(\"object\"===typeof a&&null!==a){var u=a.$$typeof;switch(u){case c:switch(a=a.type,a){case l:case m:case e:case g:case f:case p:return a;default:switch(a=a&&a.$$typeof,a){case k:case n:case t:case r:case h:return a;default:return u}}case d:return u}}}function A(a){return z(a)===m}exports.AsyncMode=l;exports.ConcurrentMode=m;exports.ContextConsumer=k;exports.ContextProvider=h;exports.Element=c;exports.ForwardRef=n;exports.Fragment=e;exports.Lazy=t;exports.Memo=r;exports.Portal=d;\nexports.Profiler=g;exports.StrictMode=f;exports.Suspense=p;exports.isAsyncMode=function(a){return A(a)||z(a)===l};exports.isConcurrentMode=A;exports.isContextConsumer=function(a){return z(a)===k};exports.isContextProvider=function(a){return z(a)===h};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===c};exports.isForwardRef=function(a){return z(a)===n};exports.isFragment=function(a){return z(a)===e};exports.isLazy=function(a){return z(a)===t};\nexports.isMemo=function(a){return z(a)===r};exports.isPortal=function(a){return z(a)===d};exports.isProfiler=function(a){return z(a)===g};exports.isStrictMode=function(a){return z(a)===f};exports.isSuspense=function(a){return z(a)===p};\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===e||a===m||a===g||a===f||a===p||a===q||\"object\"===typeof a&&null!==a&&(a.$$typeof===t||a.$$typeof===r||a.$$typeof===h||a.$$typeof===k||a.$$typeof===n||a.$$typeof===w||a.$$typeof===x||a.$$typeof===y||a.$$typeof===v)};exports.typeOf=z;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh */\nexports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = ((value * c) - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n }\n}\n","'use strict';\n\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar callBound = require('call-bind/callBound');\n\nvar $toString = callBound('Object.prototype.toString');\n\nvar isStandardArguments = function isArguments(value) {\n\tif (hasToStringTag && value && typeof value === 'object' && Symbol.toStringTag in value) {\n\t\treturn false;\n\t}\n\treturn $toString(value) === '[object Arguments]';\n};\n\nvar isLegacyArguments = function isArguments(value) {\n\tif (isStandardArguments(value)) {\n\t\treturn true;\n\t}\n\treturn value !== null &&\n\t\ttypeof value === 'object' &&\n\t\ttypeof value.length === 'number' &&\n\t\tvalue.length >= 0 &&\n\t\t$toString(value) !== '[object Array]' &&\n\t\t$toString(value.callee) === '[object Function]';\n};\n\nvar supportsStandardArguments = (function () {\n\treturn isStandardArguments(arguments);\n}());\n\nisStandardArguments.isLegacyArguments = isLegacyArguments; // for tests\n\nmodule.exports = supportsStandardArguments ? isStandardArguments : isLegacyArguments;\n","module.exports = true;","'use strict';\n\nvar fnToStr = Function.prototype.toString;\nvar reflectApply = typeof Reflect === 'object' && Reflect !== null && Reflect.apply;\nvar badArrayLike;\nvar isCallableMarker;\nif (typeof reflectApply === 'function' && typeof Object.defineProperty === 'function') {\n\ttry {\n\t\tbadArrayLike = Object.defineProperty({}, 'length', {\n\t\t\tget: function () {\n\t\t\t\tthrow isCallableMarker;\n\t\t\t}\n\t\t});\n\t\tisCallableMarker = {};\n\t\t// eslint-disable-next-line no-throw-literal\n\t\treflectApply(function () { throw 42; }, null, badArrayLike);\n\t} catch (_) {\n\t\tif (_ !== isCallableMarker) {\n\t\t\treflectApply = null;\n\t\t}\n\t}\n} else {\n\treflectApply = null;\n}\n\nvar constructorRegex = /^\\s*class\\b/;\nvar isES6ClassFn = function isES6ClassFunction(value) {\n\ttry {\n\t\tvar fnStr = fnToStr.call(value);\n\t\treturn constructorRegex.test(fnStr);\n\t} catch (e) {\n\t\treturn false; // not a function\n\t}\n};\n\nvar tryFunctionObject = function tryFunctionToStr(value) {\n\ttry {\n\t\tif (isES6ClassFn(value)) { return false; }\n\t\tfnToStr.call(value);\n\t\treturn true;\n\t} catch (e) {\n\t\treturn false;\n\t}\n};\nvar toStr = Object.prototype.toString;\nvar objectClass = '[object Object]';\nvar fnClass = '[object Function]';\nvar genClass = '[object GeneratorFunction]';\nvar ddaClass = '[object HTMLAllCollection]'; // IE 11\nvar ddaClass2 = '[object HTML document.all class]';\nvar ddaClass3 = '[object HTMLCollection]'; // IE 9-10\nvar hasToStringTag = typeof Symbol === 'function' && !!Symbol.toStringTag; // better: use `has-tostringtag`\n\nvar isIE68 = !(0 in [,]); // eslint-disable-line no-sparse-arrays, comma-spacing\n\nvar isDDA = function isDocumentDotAll() { return false; };\nif (typeof document === 'object') {\n\t// Firefox 3 canonicalizes DDA to undefined when it's not accessed directly\n\tvar all = document.all;\n\tif (toStr.call(all) === toStr.call(document.all)) {\n\t\tisDDA = function isDocumentDotAll(value) {\n\t\t\t/* globals document: false */\n\t\t\t// in IE 6-8, typeof document.all is \"object\" and it's truthy\n\t\t\tif ((isIE68 || !value) && (typeof value === 'undefined' || typeof value === 'object')) {\n\t\t\t\ttry {\n\t\t\t\t\tvar str = toStr.call(value);\n\t\t\t\t\treturn (\n\t\t\t\t\t\tstr === ddaClass\n\t\t\t\t\t\t|| str === ddaClass2\n\t\t\t\t\t\t|| str === ddaClass3 // opera 12.16\n\t\t\t\t\t\t|| str === objectClass // IE 6-8\n\t\t\t\t\t) && value('') == null; // eslint-disable-line eqeqeq\n\t\t\t\t} catch (e) { /**/ }\n\t\t\t}\n\t\t\treturn false;\n\t\t};\n\t}\n}\n\nmodule.exports = reflectApply\n\t? function isCallable(value) {\n\t\tif (isDDA(value)) { return true; }\n\t\tif (!value) { return false; }\n\t\tif (typeof value !== 'function' && typeof value !== 'object') { return false; }\n\t\ttry {\n\t\t\treflectApply(value, null, badArrayLike);\n\t\t} catch (e) {\n\t\t\tif (e !== isCallableMarker) { return false; }\n\t\t}\n\t\treturn !isES6ClassFn(value) && tryFunctionObject(value);\n\t}\n\t: function isCallable(value) {\n\t\tif (isDDA(value)) { return true; }\n\t\tif (!value) { return false; }\n\t\tif (typeof value !== 'function' && typeof value !== 'object') { return false; }\n\t\tif (hasToStringTag) { return tryFunctionObject(value); }\n\t\tif (isES6ClassFn(value)) { return false; }\n\t\tvar strClass = toStr.call(value);\n\t\tif (strClass !== fnClass && strClass !== genClass && !(/^\\[object HTML/).test(strClass)) { return false; }\n\t\treturn tryFunctionObject(value);\n\t};\n","'use strict';\n\nvar toStr = Object.prototype.toString;\nvar fnToStr = Function.prototype.toString;\nvar isFnRegex = /^\\s*(?:function)?\\*/;\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar getProto = Object.getPrototypeOf;\nvar getGeneratorFunc = function () { // eslint-disable-line consistent-return\n\tif (!hasToStringTag) {\n\t\treturn false;\n\t}\n\ttry {\n\t\treturn Function('return function*() {}')();\n\t} catch (e) {\n\t}\n};\nvar GeneratorFunction;\n\nmodule.exports = function isGeneratorFunction(fn) {\n\tif (typeof fn !== 'function') {\n\t\treturn false;\n\t}\n\tif (isFnRegex.test(fnToStr.call(fn))) {\n\t\treturn true;\n\t}\n\tif (!hasToStringTag) {\n\t\tvar str = toStr.call(fn);\n\t\treturn str === '[object GeneratorFunction]';\n\t}\n\tif (!getProto) {\n\t\treturn false;\n\t}\n\tif (typeof GeneratorFunction === 'undefined') {\n\t\tvar generatorFunc = getGeneratorFunc();\n\t\tGeneratorFunction = generatorFunc ? getProto(generatorFunc) : false;\n\t}\n\treturn getProto(fn) === GeneratorFunction;\n};\n","'use strict';\nmodule.exports = typeof navigator !== 'undefined' &&\n\t(/MSIE/.test(navigator.userAgent) || /Trident\\//.test(navigator.appVersion));\n","'use strict'\n\nmodule.exports = isMobile\nmodule.exports.isMobile = isMobile\nmodule.exports.default = isMobile\n\nconst mobileRE = /(android|bb\\d+|meego).+mobile|armv7l|avantgo|bada\\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\\/|plucker|pocket|psp|series[46]0|samsungbrowser.*mobile|symbian|treo|up\\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino/i\nconst notMobileRE = /CrOS/\n\nconst tabletRE = /android|ipad|playbook|silk/i\n\nfunction isMobile (opts) {\n if (!opts) opts = {}\n let ua = opts.ua\n if (!ua && typeof navigator !== 'undefined') ua = navigator.userAgent\n if (ua && ua.headers && typeof ua.headers['user-agent'] === 'string') {\n ua = ua.headers['user-agent']\n }\n if (typeof ua !== 'string') return false\n\n let result =\n (mobileRE.test(ua) && !notMobileRE.test(ua)) ||\n (!!opts.tablet && tabletRE.test(ua))\n\n if (\n !result &&\n opts.tablet &&\n opts.featureDetect &&\n navigator &&\n navigator.maxTouchPoints > 1 &&\n ua.indexOf('Macintosh') !== -1 &&\n ua.indexOf('Safari') !== -1\n ) {\n result = true\n }\n\n return result\n}\n","'use strict';\n\n/* http://www.ecma-international.org/ecma-262/6.0/#sec-number.isnan */\n\nmodule.exports = function isNaN(value) {\n\treturn value !== value;\n};\n","'use strict';\n\nvar callBind = require('call-bind');\nvar define = require('define-properties');\n\nvar implementation = require('./implementation');\nvar getPolyfill = require('./polyfill');\nvar shim = require('./shim');\n\nvar polyfill = callBind(getPolyfill(), Number);\n\n/* http://www.ecma-international.org/ecma-262/6.0/#sec-number.isnan */\n\ndefine(polyfill, {\n\tgetPolyfill: getPolyfill,\n\timplementation: implementation,\n\tshim: shim\n});\n\nmodule.exports = polyfill;\n","'use strict';\n\nvar implementation = require('./implementation');\n\nmodule.exports = function getPolyfill() {\n\tif (Number.isNaN && Number.isNaN(NaN) && !Number.isNaN('a')) {\n\t\treturn Number.isNaN;\n\t}\n\treturn implementation;\n};\n","'use strict';\n\nvar define = require('define-properties');\nvar getPolyfill = require('./polyfill');\n\n/* http://www.ecma-international.org/ecma-262/6.0/#sec-number.isnan */\n\nmodule.exports = function shimNumberIsNaN() {\n\tvar polyfill = getPolyfill();\n\tdefine(Number, { isNaN: polyfill }, {\n\t\tisNaN: function testIsNaN() {\n\t\t\treturn Number.isNaN !== polyfill;\n\t\t}\n\t});\n\treturn polyfill;\n};\n","'use strict';\nmodule.exports = function (x) {\n\tvar type = typeof x;\n\treturn x !== null && (type === 'object' || type === 'function');\n};\n","'use strict';\nvar toString = Object.prototype.toString;\n\nmodule.exports = function (x) {\n\tvar prototype;\n\treturn toString.call(x) === '[object Object]' && (prototype = Object.getPrototypeOf(x), prototype === null || prototype === Object.getPrototypeOf({}));\n};\n","'use strict';\r\n\r\n/**\r\n * Is this string all whitespace?\r\n * This solution kind of makes my brain hurt, but it's significantly faster\r\n * than !str.trim() or any other solution I could find.\r\n *\r\n * whitespace codes from: http://en.wikipedia.org/wiki/Whitespace_character\r\n * and verified with:\r\n *\r\n * for(var i = 0; i < 65536; i++) {\r\n * var s = String.fromCharCode(i);\r\n * if(+s===0 && !s.trim()) console.log(i, s);\r\n * }\r\n *\r\n * which counts a couple of these as *not* whitespace, but finds nothing else\r\n * that *is* whitespace. Note that charCodeAt stops at 16 bits, but it appears\r\n * that there are no whitespace characters above this, and code points above\r\n * this do not map onto white space characters.\r\n */\r\n\r\nmodule.exports = function(str){\r\n var l = str.length,\r\n a;\r\n for(var i = 0; i < l; i++) {\r\n a = str.charCodeAt(i);\r\n if((a < 9 || a > 13) && (a !== 32) && (a !== 133) && (a !== 160) &&\r\n (a !== 5760) && (a !== 6158) && (a < 8192 || a > 8205) &&\r\n (a !== 8232) && (a !== 8233) && (a !== 8239) && (a !== 8287) &&\r\n (a !== 8288) && (a !== 12288) && (a !== 65279)) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n}\r\n","'use strict'\r\n\r\nmodule.exports = function isPath(str) {\r\n\tif (typeof str !== 'string') return false\r\n\r\n\tstr = str.trim()\r\n\r\n\t// https://www.w3.org/TR/SVG/paths.html#PathDataBNF\r\n\tif (/^[mzlhvcsqta]\\s*[-+.0-9][^mlhvzcsqta]+/i.test(str) && /[\\dz]$/i.test(str) && str.length > 4) return true\r\n\r\n\treturn false\r\n}\r\n","'use strict';\n\nvar whichTypedArray = require('which-typed-array');\n\n/** @type {import('.')} */\nmodule.exports = function isTypedArray(value) {\n\treturn !!whichTypedArray(value);\n};\n","function lerp(v0, v1, t) {\n return v0*(1-t)+v1*t\n}\nmodule.exports = lerp","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView');\n\nmodule.exports = DataView;\n","var hashClear = require('./_hashClear'),\n hashDelete = require('./_hashDelete'),\n hashGet = require('./_hashGet'),\n hashHas = require('./_hashHas'),\n hashSet = require('./_hashSet');\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nmodule.exports = Hash;\n","var listCacheClear = require('./_listCacheClear'),\n listCacheDelete = require('./_listCacheDelete'),\n listCacheGet = require('./_listCacheGet'),\n listCacheHas = require('./_listCacheHas'),\n listCacheSet = require('./_listCacheSet');\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nmodule.exports = ListCache;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nmodule.exports = Map;\n","var mapCacheClear = require('./_mapCacheClear'),\n mapCacheDelete = require('./_mapCacheDelete'),\n mapCacheGet = require('./_mapCacheGet'),\n mapCacheHas = require('./_mapCacheHas'),\n mapCacheSet = require('./_mapCacheSet');\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nmodule.exports = MapCache;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Promise = getNative(root, 'Promise');\n\nmodule.exports = Promise;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nmodule.exports = Set;\n","var MapCache = require('./_MapCache'),\n setCacheAdd = require('./_setCacheAdd'),\n setCacheHas = require('./_setCacheHas');\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\nmodule.exports = SetCache;\n","var ListCache = require('./_ListCache'),\n stackClear = require('./_stackClear'),\n stackDelete = require('./_stackDelete'),\n stackGet = require('./_stackGet'),\n stackHas = require('./_stackHas'),\n stackSet = require('./_stackSet');\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nmodule.exports = Stack;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nmodule.exports = Uint8Array;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nmodule.exports = WeakMap;\n","/**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\nfunction arrayEach(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (iteratee(array[index], index, array) === false) {\n break;\n }\n }\n return array;\n}\n\nmodule.exports = arrayEach;\n","/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\nmodule.exports = arrayFilter;\n","var baseTimes = require('./_baseTimes'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isIndex = require('./_isIndex'),\n isTypedArray = require('./isTypedArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = arrayLikeKeys;\n","/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length,\n result = Array(length);\n\n while (++index < length) {\n result[index] = iteratee(array[index], index, array);\n }\n return result;\n}\n\nmodule.exports = arrayMap;\n","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\nmodule.exports = arrayPush;\n","/**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\nfunction arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n}\n\nmodule.exports = arraySome;\n","var baseAssignValue = require('./_baseAssignValue'),\n eq = require('./eq');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n var objValue = object[key];\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n}\n\nmodule.exports = assignValue;\n","var eq = require('./eq');\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\nmodule.exports = assocIndexOf;\n","var copyObject = require('./_copyObject'),\n keys = require('./keys');\n\n/**\n * The base implementation of `_.assign` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssign(object, source) {\n return object && copyObject(source, keys(source), object);\n}\n\nmodule.exports = baseAssign;\n","var copyObject = require('./_copyObject'),\n keysIn = require('./keysIn');\n\n/**\n * The base implementation of `_.assignIn` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssignIn(object, source) {\n return object && copyObject(source, keysIn(source), object);\n}\n\nmodule.exports = baseAssignIn;\n","var defineProperty = require('./_defineProperty');\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n if (key == '__proto__' && defineProperty) {\n defineProperty(object, key, {\n 'configurable': true,\n 'enumerable': true,\n 'value': value,\n 'writable': true\n });\n } else {\n object[key] = value;\n }\n}\n\nmodule.exports = baseAssignValue;\n","var Stack = require('./_Stack'),\n arrayEach = require('./_arrayEach'),\n assignValue = require('./_assignValue'),\n baseAssign = require('./_baseAssign'),\n baseAssignIn = require('./_baseAssignIn'),\n cloneBuffer = require('./_cloneBuffer'),\n copyArray = require('./_copyArray'),\n copySymbols = require('./_copySymbols'),\n copySymbolsIn = require('./_copySymbolsIn'),\n getAllKeys = require('./_getAllKeys'),\n getAllKeysIn = require('./_getAllKeysIn'),\n getTag = require('./_getTag'),\n initCloneArray = require('./_initCloneArray'),\n initCloneByTag = require('./_initCloneByTag'),\n initCloneObject = require('./_initCloneObject'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isMap = require('./isMap'),\n isObject = require('./isObject'),\n isSet = require('./isSet'),\n keys = require('./keys'),\n keysIn = require('./keysIn');\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_FLAT_FLAG = 2,\n CLONE_SYMBOLS_FLAG = 4;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\ncloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\ncloneableTags[boolTag] = cloneableTags[dateTag] =\ncloneableTags[float32Tag] = cloneableTags[float64Tag] =\ncloneableTags[int8Tag] = cloneableTags[int16Tag] =\ncloneableTags[int32Tag] = cloneableTags[mapTag] =\ncloneableTags[numberTag] = cloneableTags[objectTag] =\ncloneableTags[regexpTag] = cloneableTags[setTag] =\ncloneableTags[stringTag] = cloneableTags[symbolTag] =\ncloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\ncloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\ncloneableTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Deep clone\n * 2 - Flatten inherited properties\n * 4 - Clone symbols\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\nfunction baseClone(value, bitmask, customizer, key, object, stack) {\n var result,\n isDeep = bitmask & CLONE_DEEP_FLAG,\n isFlat = bitmask & CLONE_FLAT_FLAG,\n isFull = bitmask & CLONE_SYMBOLS_FLAG;\n\n if (customizer) {\n result = object ? customizer(value, key, object, stack) : customizer(value);\n }\n if (result !== undefined) {\n return result;\n }\n if (!isObject(value)) {\n return value;\n }\n var isArr = isArray(value);\n if (isArr) {\n result = initCloneArray(value);\n if (!isDeep) {\n return copyArray(value, result);\n }\n } else {\n var tag = getTag(value),\n isFunc = tag == funcTag || tag == genTag;\n\n if (isBuffer(value)) {\n return cloneBuffer(value, isDeep);\n }\n if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n result = (isFlat || isFunc) ? {} : initCloneObject(value);\n if (!isDeep) {\n return isFlat\n ? copySymbolsIn(value, baseAssignIn(result, value))\n : copySymbols(value, baseAssign(result, value));\n }\n } else {\n if (!cloneableTags[tag]) {\n return object ? value : {};\n }\n result = initCloneByTag(value, tag, isDeep);\n }\n }\n // Check for circular references and return its corresponding clone.\n stack || (stack = new Stack);\n var stacked = stack.get(value);\n if (stacked) {\n return stacked;\n }\n stack.set(value, result);\n\n if (isSet(value)) {\n value.forEach(function(subValue) {\n result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));\n });\n } else if (isMap(value)) {\n value.forEach(function(subValue, key) {\n result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n }\n\n var keysFunc = isFull\n ? (isFlat ? getAllKeysIn : getAllKeys)\n : (isFlat ? keysIn : keys);\n\n var props = isArr ? undefined : keysFunc(value);\n arrayEach(props || value, function(subValue, key) {\n if (props) {\n key = subValue;\n subValue = value[key];\n }\n // Recursively populate clone (susceptible to call stack limits).\n assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n return result;\n}\n\nmodule.exports = baseClone;\n","var isObject = require('./isObject');\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nvar baseCreate = (function() {\n function object() {}\n return function(proto) {\n if (!isObject(proto)) {\n return {};\n }\n if (objectCreate) {\n return objectCreate(proto);\n }\n object.prototype = proto;\n var result = new object;\n object.prototype = undefined;\n return result;\n };\n}());\n\nmodule.exports = baseCreate;\n","var baseForOwn = require('./_baseForOwn'),\n createBaseEach = require('./_createBaseEach');\n\n/**\n * The base implementation of `_.forEach` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\nvar baseEach = createBaseEach(baseForOwn);\n\nmodule.exports = baseEach;\n","var createBaseFor = require('./_createBaseFor');\n\n/**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseFor = createBaseFor();\n\nmodule.exports = baseFor;\n","var baseFor = require('./_baseFor'),\n keys = require('./keys');\n\n/**\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForOwn(object, iteratee) {\n return object && baseFor(object, iteratee, keys);\n}\n\nmodule.exports = baseForOwn;\n","var castPath = require('./_castPath'),\n toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\nfunction baseGet(object, path) {\n path = castPath(path, object);\n\n var index = 0,\n length = path.length;\n\n while (object != null && index < length) {\n object = object[toKey(path[index++])];\n }\n return (index && index == length) ? object : undefined;\n}\n\nmodule.exports = baseGet;\n","var arrayPush = require('./_arrayPush'),\n isArray = require('./isArray');\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\nmodule.exports = baseGetAllKeys;\n","var Symbol = require('./_Symbol'),\n getRawTag = require('./_getRawTag'),\n objectToString = require('./_objectToString');\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nmodule.exports = baseGetTag;\n","/**\n * The base implementation of `_.hasIn` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHasIn(object, key) {\n return object != null && key in Object(object);\n}\n\nmodule.exports = baseHasIn;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nmodule.exports = baseIsArguments;\n","var baseIsEqualDeep = require('./_baseIsEqualDeep'),\n isObjectLike = require('./isObjectLike');\n\n/**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n}\n\nmodule.exports = baseIsEqual;\n","var Stack = require('./_Stack'),\n equalArrays = require('./_equalArrays'),\n equalByTag = require('./_equalByTag'),\n equalObjects = require('./_equalObjects'),\n getTag = require('./_getTag'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isTypedArray = require('./isTypedArray');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n\n stack || (stack = new Stack);\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n}\n\nmodule.exports = baseIsEqualDeep;\n","var getTag = require('./_getTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]';\n\n/**\n * The base implementation of `_.isMap` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n */\nfunction baseIsMap(value) {\n return isObjectLike(value) && getTag(value) == mapTag;\n}\n\nmodule.exports = baseIsMap;\n","var Stack = require('./_Stack'),\n baseIsEqual = require('./_baseIsEqual');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * The base implementation of `_.isMatch` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Array} matchData The property names, values, and compare flags to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n */\nfunction baseIsMatch(object, source, matchData, customizer) {\n var index = matchData.length,\n length = index,\n noCustomizer = !customizer;\n\n if (object == null) {\n return !length;\n }\n object = Object(object);\n while (index--) {\n var data = matchData[index];\n if ((noCustomizer && data[2])\n ? data[1] !== object[data[0]]\n : !(data[0] in object)\n ) {\n return false;\n }\n }\n while (++index < length) {\n data = matchData[index];\n var key = data[0],\n objValue = object[key],\n srcValue = data[1];\n\n if (noCustomizer && data[2]) {\n if (objValue === undefined && !(key in object)) {\n return false;\n }\n } else {\n var stack = new Stack;\n if (customizer) {\n var result = customizer(objValue, srcValue, key, object, source, stack);\n }\n if (!(result === undefined\n ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG, customizer, stack)\n : result\n )) {\n return false;\n }\n }\n }\n return true;\n}\n\nmodule.exports = baseIsMatch;\n","var isFunction = require('./isFunction'),\n isMasked = require('./_isMasked'),\n isObject = require('./isObject'),\n toSource = require('./_toSource');\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\nmodule.exports = baseIsNative;\n","var getTag = require('./_getTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar setTag = '[object Set]';\n\n/**\n * The base implementation of `_.isSet` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n */\nfunction baseIsSet(value) {\n return isObjectLike(value) && getTag(value) == setTag;\n}\n\nmodule.exports = baseIsSet;\n","var baseGetTag = require('./_baseGetTag'),\n isLength = require('./isLength'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nmodule.exports = baseIsTypedArray;\n","var baseMatches = require('./_baseMatches'),\n baseMatchesProperty = require('./_baseMatchesProperty'),\n identity = require('./identity'),\n isArray = require('./isArray'),\n property = require('./property');\n\n/**\n * The base implementation of `_.iteratee`.\n *\n * @private\n * @param {*} [value=_.identity] The value to convert to an iteratee.\n * @returns {Function} Returns the iteratee.\n */\nfunction baseIteratee(value) {\n // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9.\n // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details.\n if (typeof value == 'function') {\n return value;\n }\n if (value == null) {\n return identity;\n }\n if (typeof value == 'object') {\n return isArray(value)\n ? baseMatchesProperty(value[0], value[1])\n : baseMatches(value);\n }\n return property(value);\n}\n\nmodule.exports = baseIteratee;\n","var isPrototype = require('./_isPrototype'),\n nativeKeys = require('./_nativeKeys');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = baseKeys;\n","var isObject = require('./isObject'),\n isPrototype = require('./_isPrototype'),\n nativeKeysIn = require('./_nativeKeysIn');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeysIn(object) {\n if (!isObject(object)) {\n return nativeKeysIn(object);\n }\n var isProto = isPrototype(object),\n result = [];\n\n for (var key in object) {\n if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = baseKeysIn;\n","var baseEach = require('./_baseEach'),\n isArrayLike = require('./isArrayLike');\n\n/**\n * The base implementation of `_.map` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction baseMap(collection, iteratee) {\n var index = -1,\n result = isArrayLike(collection) ? Array(collection.length) : [];\n\n baseEach(collection, function(value, key, collection) {\n result[++index] = iteratee(value, key, collection);\n });\n return result;\n}\n\nmodule.exports = baseMap;\n","var baseIsMatch = require('./_baseIsMatch'),\n getMatchData = require('./_getMatchData'),\n matchesStrictComparable = require('./_matchesStrictComparable');\n\n/**\n * The base implementation of `_.matches` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property values to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatches(source) {\n var matchData = getMatchData(source);\n if (matchData.length == 1 && matchData[0][2]) {\n return matchesStrictComparable(matchData[0][0], matchData[0][1]);\n }\n return function(object) {\n return object === source || baseIsMatch(object, source, matchData);\n };\n}\n\nmodule.exports = baseMatches;\n","var baseIsEqual = require('./_baseIsEqual'),\n get = require('./get'),\n hasIn = require('./hasIn'),\n isKey = require('./_isKey'),\n isStrictComparable = require('./_isStrictComparable'),\n matchesStrictComparable = require('./_matchesStrictComparable'),\n toKey = require('./_toKey');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`.\n *\n * @private\n * @param {string} path The path of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatchesProperty(path, srcValue) {\n if (isKey(path) && isStrictComparable(srcValue)) {\n return matchesStrictComparable(toKey(path), srcValue);\n }\n return function(object) {\n var objValue = get(object, path);\n return (objValue === undefined && objValue === srcValue)\n ? hasIn(object, path)\n : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG);\n };\n}\n\nmodule.exports = baseMatchesProperty;\n","/**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction baseProperty(key) {\n return function(object) {\n return object == null ? undefined : object[key];\n };\n}\n\nmodule.exports = baseProperty;\n","var baseGet = require('./_baseGet');\n\n/**\n * A specialized version of `baseProperty` which supports deep paths.\n *\n * @private\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction basePropertyDeep(path) {\n return function(object) {\n return baseGet(object, path);\n };\n}\n\nmodule.exports = basePropertyDeep;\n","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\nmodule.exports = baseTimes;\n","var Symbol = require('./_Symbol'),\n arrayMap = require('./_arrayMap'),\n isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value;\n }\n if (isArray(value)) {\n // Recursively convert values (susceptible to call stack limits).\n return arrayMap(value, baseToString) + '';\n }\n if (isSymbol(value)) {\n return symbolToString ? symbolToString.call(value) : '';\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = baseToString;\n","/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\nmodule.exports = baseUnary;\n","/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\nmodule.exports = cacheHas;\n","var identity = require('./identity');\n\n/**\n * Casts `value` to `identity` if it's not a function.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {Function} Returns cast function.\n */\nfunction castFunction(value) {\n return typeof value == 'function' ? value : identity;\n}\n\nmodule.exports = castFunction;\n","var isArray = require('./isArray'),\n isKey = require('./_isKey'),\n stringToPath = require('./_stringToPath'),\n toString = require('./toString');\n\n/**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\nfunction castPath(value, object) {\n if (isArray(value)) {\n return value;\n }\n return isKey(value, object) ? [value] : stringToPath(toString(value));\n}\n\nmodule.exports = castPath;\n","var Uint8Array = require('./_Uint8Array');\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n return result;\n}\n\nmodule.exports = cloneArrayBuffer;\n","var root = require('./_root');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined;\n\n/**\n * Creates a clone of `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\nfunction cloneBuffer(buffer, isDeep) {\n if (isDeep) {\n return buffer.slice();\n }\n var length = buffer.length,\n result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\n\n buffer.copy(result);\n return result;\n}\n\nmodule.exports = cloneBuffer;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer');\n\n/**\n * Creates a clone of `dataView`.\n *\n * @private\n * @param {Object} dataView The data view to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned data view.\n */\nfunction cloneDataView(dataView, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n}\n\nmodule.exports = cloneDataView;\n","/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\nfunction cloneRegExp(regexp) {\n var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n result.lastIndex = regexp.lastIndex;\n return result;\n}\n\nmodule.exports = cloneRegExp;\n","var Symbol = require('./_Symbol');\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\nfunction cloneSymbol(symbol) {\n return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n}\n\nmodule.exports = cloneSymbol;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer');\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nmodule.exports = cloneTypedArray;\n","/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction copyArray(source, array) {\n var index = -1,\n length = source.length;\n\n array || (array = Array(length));\n while (++index < length) {\n array[index] = source[index];\n }\n return array;\n}\n\nmodule.exports = copyArray;\n","var assignValue = require('./_assignValue'),\n baseAssignValue = require('./_baseAssignValue');\n\n/**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\nfunction copyObject(source, props, object, customizer) {\n var isNew = !object;\n object || (object = {});\n\n var index = -1,\n length = props.length;\n\n while (++index < length) {\n var key = props[index];\n\n var newValue = customizer\n ? customizer(object[key], source[key], key, object, source)\n : undefined;\n\n if (newValue === undefined) {\n newValue = source[key];\n }\n if (isNew) {\n baseAssignValue(object, key, newValue);\n } else {\n assignValue(object, key, newValue);\n }\n }\n return object;\n}\n\nmodule.exports = copyObject;\n","var copyObject = require('./_copyObject'),\n getSymbols = require('./_getSymbols');\n\n/**\n * Copies own symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbols(source, object) {\n return copyObject(source, getSymbols(source), object);\n}\n\nmodule.exports = copySymbols;\n","var copyObject = require('./_copyObject'),\n getSymbolsIn = require('./_getSymbolsIn');\n\n/**\n * Copies own and inherited symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbolsIn(source, object) {\n return copyObject(source, getSymbolsIn(source), object);\n}\n\nmodule.exports = copySymbolsIn;\n","var root = require('./_root');\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nmodule.exports = coreJsData;\n","var isArrayLike = require('./isArrayLike');\n\n/**\n * Creates a `baseEach` or `baseEachRight` function.\n *\n * @private\n * @param {Function} eachFunc The function to iterate over a collection.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseEach(eachFunc, fromRight) {\n return function(collection, iteratee) {\n if (collection == null) {\n return collection;\n }\n if (!isArrayLike(collection)) {\n return eachFunc(collection, iteratee);\n }\n var length = collection.length,\n index = fromRight ? length : -1,\n iterable = Object(collection);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (iteratee(iterable[index], index, iterable) === false) {\n break;\n }\n }\n return collection;\n };\n}\n\nmodule.exports = createBaseEach;\n","/**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseFor(fromRight) {\n return function(object, iteratee, keysFunc) {\n var index = -1,\n iterable = Object(object),\n props = keysFunc(object),\n length = props.length;\n\n while (length--) {\n var key = props[fromRight ? length : ++index];\n if (iteratee(iterable[key], key, iterable) === false) {\n break;\n }\n }\n return object;\n };\n}\n\nmodule.exports = createBaseFor;\n","var getNative = require('./_getNative');\n\nvar defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n}());\n\nmodule.exports = defineProperty;\n","var SetCache = require('./_SetCache'),\n arraySome = require('./_arraySome'),\n cacheHas = require('./_cacheHas');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Check that cyclic values are equal.\n var arrStacked = stack.get(array);\n var othStacked = stack.get(other);\n if (arrStacked && othStacked) {\n return arrStacked == other && othStacked == array;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n}\n\nmodule.exports = equalArrays;\n","var Symbol = require('./_Symbol'),\n Uint8Array = require('./_Uint8Array'),\n eq = require('./eq'),\n equalArrays = require('./_equalArrays'),\n mapToArray = require('./_mapToArray'),\n setToArray = require('./_setToArray');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]';\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n}\n\nmodule.exports = equalByTag;\n","var getAllKeys = require('./_getAllKeys');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Check that cyclic values are equal.\n var objStacked = stack.get(object);\n var othStacked = stack.get(other);\n if (objStacked && othStacked) {\n return objStacked == other && othStacked == object;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n}\n\nmodule.exports = equalObjects;\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n","var baseGetAllKeys = require('./_baseGetAllKeys'),\n getSymbols = require('./_getSymbols'),\n keys = require('./keys');\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\nmodule.exports = getAllKeys;\n","var baseGetAllKeys = require('./_baseGetAllKeys'),\n getSymbolsIn = require('./_getSymbolsIn'),\n keysIn = require('./keysIn');\n\n/**\n * Creates an array of own and inherited enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeysIn(object) {\n return baseGetAllKeys(object, keysIn, getSymbolsIn);\n}\n\nmodule.exports = getAllKeysIn;\n","var isKeyable = require('./_isKeyable');\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\nmodule.exports = getMapData;\n","var isStrictComparable = require('./_isStrictComparable'),\n keys = require('./keys');\n\n/**\n * Gets the property names, values, and compare flags of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the match data of `object`.\n */\nfunction getMatchData(object) {\n var result = keys(object),\n length = result.length;\n\n while (length--) {\n var key = result[length],\n value = object[key];\n\n result[length] = [key, value, isStrictComparable(value)];\n }\n return result;\n}\n\nmodule.exports = getMatchData;\n","var baseIsNative = require('./_baseIsNative'),\n getValue = require('./_getValue');\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n","var overArg = require('./_overArg');\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nmodule.exports = getPrototype;\n","var Symbol = require('./_Symbol');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nmodule.exports = getRawTag;\n","var arrayFilter = require('./_arrayFilter'),\n stubArray = require('./stubArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\nmodule.exports = getSymbols;\n","var arrayPush = require('./_arrayPush'),\n getPrototype = require('./_getPrototype'),\n getSymbols = require('./_getSymbols'),\n stubArray = require('./stubArray');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own and inherited enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) {\n var result = [];\n while (object) {\n arrayPush(result, getSymbols(object));\n object = getPrototype(object);\n }\n return result;\n};\n\nmodule.exports = getSymbolsIn;\n","var DataView = require('./_DataView'),\n Map = require('./_Map'),\n Promise = require('./_Promise'),\n Set = require('./_Set'),\n WeakMap = require('./_WeakMap'),\n baseGetTag = require('./_baseGetTag'),\n toSource = require('./_toSource');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n setTag = '[object Set]',\n weakMapTag = '[object WeakMap]';\n\nvar dataViewTag = '[object DataView]';\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\nmodule.exports = getTag;\n","/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\nmodule.exports = getValue;\n","var castPath = require('./_castPath'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isIndex = require('./_isIndex'),\n isLength = require('./isLength'),\n toKey = require('./_toKey');\n\n/**\n * Checks if `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\nfunction hasPath(object, path, hasFunc) {\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n result = false;\n\n while (++index < length) {\n var key = toKey(path[index]);\n if (!(result = object != null && hasFunc(object, key))) {\n break;\n }\n object = object[key];\n }\n if (result || ++index != length) {\n return result;\n }\n length = object == null ? 0 : object.length;\n return !!length && isLength(length) && isIndex(key, length) &&\n (isArray(object) || isArguments(object));\n}\n\nmodule.exports = hasPath;\n","var nativeCreate = require('./_nativeCreate');\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\nmodule.exports = hashClear;\n","/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\nmodule.exports = hashDelete;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nmodule.exports = hashGet;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nmodule.exports = hashHas;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\nmodule.exports = hashSet;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\nfunction initCloneArray(array) {\n var length = array.length,\n result = new array.constructor(length);\n\n // Add properties assigned by `RegExp#exec`.\n if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n result.index = array.index;\n result.input = array.input;\n }\n return result;\n}\n\nmodule.exports = initCloneArray;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer'),\n cloneDataView = require('./_cloneDataView'),\n cloneRegExp = require('./_cloneRegExp'),\n cloneSymbol = require('./_cloneSymbol'),\n cloneTypedArray = require('./_cloneTypedArray');\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneByTag(object, tag, isDeep) {\n var Ctor = object.constructor;\n switch (tag) {\n case arrayBufferTag:\n return cloneArrayBuffer(object);\n\n case boolTag:\n case dateTag:\n return new Ctor(+object);\n\n case dataViewTag:\n return cloneDataView(object, isDeep);\n\n case float32Tag: case float64Tag:\n case int8Tag: case int16Tag: case int32Tag:\n case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n return cloneTypedArray(object, isDeep);\n\n case mapTag:\n return new Ctor;\n\n case numberTag:\n case stringTag:\n return new Ctor(object);\n\n case regexpTag:\n return cloneRegExp(object);\n\n case setTag:\n return new Ctor;\n\n case symbolTag:\n return cloneSymbol(object);\n }\n}\n\nmodule.exports = initCloneByTag;\n","var baseCreate = require('./_baseCreate'),\n getPrototype = require('./_getPrototype'),\n isPrototype = require('./_isPrototype');\n\n/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n return (typeof object.constructor == 'function' && !isPrototype(object))\n ? baseCreate(getPrototype(object))\n : {};\n}\n\nmodule.exports = initCloneObject;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\nmodule.exports = isIndex;\n","var isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n if (isArray(value)) {\n return false;\n }\n var type = typeof value;\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n value == null || isSymbol(value)) {\n return true;\n }\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n (object != null && value in Object(object));\n}\n\nmodule.exports = isKey;\n","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\nmodule.exports = isKeyable;\n","var coreJsData = require('./_coreJsData');\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\nmodule.exports = isMasked;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\nmodule.exports = isPrototype;\n","var isObject = require('./isObject');\n\n/**\n * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` if suitable for strict\n * equality comparisons, else `false`.\n */\nfunction isStrictComparable(value) {\n return value === value && !isObject(value);\n}\n\nmodule.exports = isStrictComparable;\n","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\nmodule.exports = listCacheClear;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\nmodule.exports = listCacheDelete;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\nmodule.exports = listCacheGet;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\nmodule.exports = listCacheHas;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\nmodule.exports = listCacheSet;\n","var Hash = require('./_Hash'),\n ListCache = require('./_ListCache'),\n Map = require('./_Map');\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\nmodule.exports = mapCacheClear;\n","var getMapData = require('./_getMapData');\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\nmodule.exports = mapCacheDelete;\n","var getMapData = require('./_getMapData');\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\nmodule.exports = mapCacheGet;\n","var getMapData = require('./_getMapData');\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\nmodule.exports = mapCacheHas;\n","var getMapData = require('./_getMapData');\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\nmodule.exports = mapCacheSet;\n","/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n}\n\nmodule.exports = mapToArray;\n","/**\n * A specialized version of `matchesProperty` for source values suitable\n * for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction matchesStrictComparable(key, srcValue) {\n return function(object) {\n if (object == null) {\n return false;\n }\n return object[key] === srcValue &&\n (srcValue !== undefined || (key in Object(object)));\n };\n}\n\nmodule.exports = matchesStrictComparable;\n","var memoize = require('./memoize');\n\n/** Used as the maximum memoize cache size. */\nvar MAX_MEMOIZE_SIZE = 500;\n\n/**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\nfunction memoizeCapped(func) {\n var result = memoize(func, function(key) {\n if (cache.size === MAX_MEMOIZE_SIZE) {\n cache.clear();\n }\n return key;\n });\n\n var cache = result.cache;\n return result;\n}\n\nmodule.exports = memoizeCapped;\n","var getNative = require('./_getNative');\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nmodule.exports = nativeCreate;\n","var overArg = require('./_overArg');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\nmodule.exports = nativeKeys;\n","/**\n * This function is like\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * except that it includes inherited enumerable properties.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction nativeKeysIn(object) {\n var result = [];\n if (object != null) {\n for (var key in Object(object)) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = nativeKeysIn;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n // Use `util.types` for Node.js 10+.\n var types = freeModule && freeModule.require && freeModule.require('util').types;\n\n if (types) {\n return types;\n }\n\n // Legacy `process.binding('util')` for Node.js < 10.\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\nmodule.exports = nodeUtil;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nmodule.exports = objectToString;\n","/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\nmodule.exports = overArg;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nmodule.exports = root;\n","/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n}\n\nmodule.exports = setCacheAdd;\n","/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\nmodule.exports = setCacheHas;\n","/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n}\n\nmodule.exports = setToArray;\n","var ListCache = require('./_ListCache');\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\nmodule.exports = stackClear;\n","/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\nmodule.exports = stackDelete;\n","/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\nmodule.exports = stackGet;\n","/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\nmodule.exports = stackHas;\n","var ListCache = require('./_ListCache'),\n Map = require('./_Map'),\n MapCache = require('./_MapCache');\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\nmodule.exports = stackSet;\n","var memoizeCapped = require('./_memoizeCapped');\n\n/** Used to match property names within property paths. */\nvar rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoizeCapped(function(string) {\n var result = [];\n if (string.charCodeAt(0) === 46 /* . */) {\n result.push('');\n }\n string.replace(rePropName, function(match, number, quote, subString) {\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n });\n return result;\n});\n\nmodule.exports = stringToPath;\n","var isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = toKey;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\nmodule.exports = toSource;\n","var baseClone = require('./_baseClone');\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * This method is like `_.clone` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @returns {*} Returns the deep cloned value.\n * @see _.clone\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var deep = _.cloneDeep(objects);\n * console.log(deep[0] === objects[0]);\n * // => false\n */\nfunction cloneDeep(value) {\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);\n}\n\nmodule.exports = cloneDeep;\n","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\nmodule.exports = eq;\n","var baseForOwn = require('./_baseForOwn'),\n castFunction = require('./_castFunction');\n\n/**\n * Iterates over own enumerable string keyed properties of an object and\n * invokes `iteratee` for each property. The iteratee is invoked with three\n * arguments: (value, key, object). Iteratee functions may exit iteration\n * early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 0.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forOwnRight\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forOwn(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a' then 'b' (iteration order is not guaranteed).\n */\nfunction forOwn(object, iteratee) {\n return object && baseForOwn(object, castFunction(iteratee));\n}\n\nmodule.exports = forOwn;\n","var baseGet = require('./_baseGet');\n\n/**\n * Gets the value at `path` of `object`. If the resolved value is\n * `undefined`, the `defaultValue` is returned in its place.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.get(object, 'a[0].b.c');\n * // => 3\n *\n * _.get(object, ['a', '0', 'b', 'c']);\n * // => 3\n *\n * _.get(object, 'a.b.c', 'default');\n * // => 'default'\n */\nfunction get(object, path, defaultValue) {\n var result = object == null ? undefined : baseGet(object, path);\n return result === undefined ? defaultValue : result;\n}\n\nmodule.exports = get;\n","var baseHasIn = require('./_baseHasIn'),\n hasPath = require('./_hasPath');\n\n/**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\nfunction hasIn(object, path) {\n return object != null && hasPath(object, path, baseHasIn);\n}\n\nmodule.exports = hasIn;\n","/**\n * This method returns the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\nfunction identity(value) {\n return value;\n}\n\nmodule.exports = identity;\n","var baseIsArguments = require('./_baseIsArguments'),\n isObjectLike = require('./isObjectLike');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\nmodule.exports = isArguments;\n","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nmodule.exports = isArray;\n","var isFunction = require('./isFunction'),\n isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n","var root = require('./_root'),\n stubFalse = require('./stubFalse');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nmodule.exports = isBuffer;\n","var baseGetTag = require('./_baseGetTag'),\n isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nmodule.exports = isFunction;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n","var baseIsMap = require('./_baseIsMap'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsMap = nodeUtil && nodeUtil.isMap;\n\n/**\n * Checks if `value` is classified as a `Map` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n * @example\n *\n * _.isMap(new Map);\n * // => true\n *\n * _.isMap(new WeakMap);\n * // => false\n */\nvar isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\n\nmodule.exports = isMap;\n","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n","var baseGetTag = require('./_baseGetTag'),\n getPrototype = require('./_getPrototype'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\n\n/**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @static\n * @memberOf _\n * @since 0.8.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\nfunction isPlainObject(value) {\n if (!isObjectLike(value) || baseGetTag(value) != objectTag) {\n return false;\n }\n var proto = getPrototype(value);\n if (proto === null) {\n return true;\n }\n var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\n return typeof Ctor == 'function' && Ctor instanceof Ctor &&\n funcToString.call(Ctor) == objectCtorString;\n}\n\nmodule.exports = isPlainObject;\n","var baseIsSet = require('./_baseIsSet'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsSet = nodeUtil && nodeUtil.isSet;\n\n/**\n * Checks if `value` is classified as a `Set` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n * @example\n *\n * _.isSet(new Set);\n * // => true\n *\n * _.isSet(new WeakSet);\n * // => false\n */\nvar isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\n\nmodule.exports = isSet;\n","var baseGetTag = require('./_baseGetTag'),\n isArray = require('./isArray'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar stringTag = '[object String]';\n\n/**\n * Checks if `value` is classified as a `String` primitive or object.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a string, else `false`.\n * @example\n *\n * _.isString('abc');\n * // => true\n *\n * _.isString(1);\n * // => false\n */\nfunction isString(value) {\n return typeof value == 'string' ||\n (!isArray(value) && isObjectLike(value) && baseGetTag(value) == stringTag);\n}\n\nmodule.exports = isString;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nmodule.exports = isSymbol;\n","var baseIsTypedArray = require('./_baseIsTypedArray'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nmodule.exports = isTypedArray;\n","var arrayLikeKeys = require('./_arrayLikeKeys'),\n baseKeys = require('./_baseKeys'),\n isArrayLike = require('./isArrayLike');\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\nmodule.exports = keys;\n","var arrayLikeKeys = require('./_arrayLikeKeys'),\n baseKeysIn = require('./_baseKeysIn'),\n isArrayLike = require('./isArrayLike');\n\n/**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\nfunction keysIn(object) {\n return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n}\n\nmodule.exports = keysIn;\n","var arrayMap = require('./_arrayMap'),\n baseIteratee = require('./_baseIteratee'),\n baseMap = require('./_baseMap'),\n isArray = require('./isArray');\n\n/**\n * Creates an array of values by running each element in `collection` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`.\n *\n * The guarded methods are:\n * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`,\n * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`,\n * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`,\n * `template`, `trim`, `trimEnd`, `trimStart`, and `words`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * _.map([4, 8], square);\n * // => [16, 64]\n *\n * _.map({ 'a': 4, 'b': 8 }, square);\n * // => [16, 64] (iteration order is not guaranteed)\n *\n * var users = [\n * { 'user': 'barney' },\n * { 'user': 'fred' }\n * ];\n *\n * // The `_.property` iteratee shorthand.\n * _.map(users, 'user');\n * // => ['barney', 'fred']\n */\nfunction map(collection, iteratee) {\n var func = isArray(collection) ? arrayMap : baseMap;\n return func(collection, baseIteratee(iteratee, 3));\n}\n\nmodule.exports = map;\n","var MapCache = require('./_MapCache');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result) || cache;\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nmodule.exports = memoize;\n","var baseProperty = require('./_baseProperty'),\n basePropertyDeep = require('./_basePropertyDeep'),\n isKey = require('./_isKey'),\n toKey = require('./_toKey');\n\n/**\n * Creates a function that returns the value at `path` of a given object.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n * @example\n *\n * var objects = [\n * { 'a': { 'b': 2 } },\n * { 'a': { 'b': 1 } }\n * ];\n *\n * _.map(objects, _.property('a.b'));\n * // => [2, 1]\n *\n * _.map(_.sortBy(objects, _.property(['a', 'b'])), 'a.b');\n * // => [1, 2]\n */\nfunction property(path) {\n return isKey(path) ? baseProperty(toKey(path)) : basePropertyDeep(path);\n}\n\nmodule.exports = property;\n","/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\nmodule.exports = stubArray;\n","/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nmodule.exports = stubFalse;\n","var baseToString = require('./_baseToString');\n\n/**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n return value == null ? '' : baseToString(value);\n}\n\nmodule.exports = toString;\n","'use strict';\nmodule.exports = Math.log2 || function (x) {\n\treturn Math.log(x) * Math.LOG2E;\n};\n","//! moment.js\n//! version : 2.30.1\n//! authors : Tim Wood, Iskren Chernev, Moment.js contributors\n//! license : MIT\n//! momentjs.com\n\n;(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n global.moment = factory()\n}(this, (function () { 'use strict';\n\n var hookCallback;\n\n function hooks() {\n return hookCallback.apply(null, arguments);\n }\n\n // This is done to register the method called with moment()\n // without creating circular dependencies.\n function setHookCallback(callback) {\n hookCallback = callback;\n }\n\n function isArray(input) {\n return (\n input instanceof Array ||\n Object.prototype.toString.call(input) === '[object Array]'\n );\n }\n\n function isObject(input) {\n // IE8 will treat undefined and null as object if it wasn't for\n // input != null\n return (\n input != null &&\n Object.prototype.toString.call(input) === '[object Object]'\n );\n }\n\n function hasOwnProp(a, b) {\n return Object.prototype.hasOwnProperty.call(a, b);\n }\n\n function isObjectEmpty(obj) {\n if (Object.getOwnPropertyNames) {\n return Object.getOwnPropertyNames(obj).length === 0;\n } else {\n var k;\n for (k in obj) {\n if (hasOwnProp(obj, k)) {\n return false;\n }\n }\n return true;\n }\n }\n\n function isUndefined(input) {\n return input === void 0;\n }\n\n function isNumber(input) {\n return (\n typeof input === 'number' ||\n Object.prototype.toString.call(input) === '[object Number]'\n );\n }\n\n function isDate(input) {\n return (\n input instanceof Date ||\n Object.prototype.toString.call(input) === '[object Date]'\n );\n }\n\n function map(arr, fn) {\n var res = [],\n i,\n arrLen = arr.length;\n for (i = 0; i < arrLen; ++i) {\n res.push(fn(arr[i], i));\n }\n return res;\n }\n\n function extend(a, b) {\n for (var i in b) {\n if (hasOwnProp(b, i)) {\n a[i] = b[i];\n }\n }\n\n if (hasOwnProp(b, 'toString')) {\n a.toString = b.toString;\n }\n\n if (hasOwnProp(b, 'valueOf')) {\n a.valueOf = b.valueOf;\n }\n\n return a;\n }\n\n function createUTC(input, format, locale, strict) {\n return createLocalOrUTC(input, format, locale, strict, true).utc();\n }\n\n function defaultParsingFlags() {\n // We need to deep clone this object.\n return {\n empty: false,\n unusedTokens: [],\n unusedInput: [],\n overflow: -2,\n charsLeftOver: 0,\n nullInput: false,\n invalidEra: null,\n invalidMonth: null,\n invalidFormat: false,\n userInvalidated: false,\n iso: false,\n parsedDateParts: [],\n era: null,\n meridiem: null,\n rfc2822: false,\n weekdayMismatch: false,\n };\n }\n\n function getParsingFlags(m) {\n if (m._pf == null) {\n m._pf = defaultParsingFlags();\n }\n return m._pf;\n }\n\n var some;\n if (Array.prototype.some) {\n some = Array.prototype.some;\n } else {\n some = function (fun) {\n var t = Object(this),\n len = t.length >>> 0,\n i;\n\n for (i = 0; i < len; i++) {\n if (i in t && fun.call(this, t[i], i, t)) {\n return true;\n }\n }\n\n return false;\n };\n }\n\n function isValid(m) {\n var flags = null,\n parsedParts = false,\n isNowValid = m._d && !isNaN(m._d.getTime());\n if (isNowValid) {\n flags = getParsingFlags(m);\n parsedParts = some.call(flags.parsedDateParts, function (i) {\n return i != null;\n });\n isNowValid =\n flags.overflow < 0 &&\n !flags.empty &&\n !flags.invalidEra &&\n !flags.invalidMonth &&\n !flags.invalidWeekday &&\n !flags.weekdayMismatch &&\n !flags.nullInput &&\n !flags.invalidFormat &&\n !flags.userInvalidated &&\n (!flags.meridiem || (flags.meridiem && parsedParts));\n if (m._strict) {\n isNowValid =\n isNowValid &&\n flags.charsLeftOver === 0 &&\n flags.unusedTokens.length === 0 &&\n flags.bigHour === undefined;\n }\n }\n if (Object.isFrozen == null || !Object.isFrozen(m)) {\n m._isValid = isNowValid;\n } else {\n return isNowValid;\n }\n return m._isValid;\n }\n\n function createInvalid(flags) {\n var m = createUTC(NaN);\n if (flags != null) {\n extend(getParsingFlags(m), flags);\n } else {\n getParsingFlags(m).userInvalidated = true;\n }\n\n return m;\n }\n\n // Plugins that add properties should also add the key here (null value),\n // so we can properly clone ourselves.\n var momentProperties = (hooks.momentProperties = []),\n updateInProgress = false;\n\n function copyConfig(to, from) {\n var i,\n prop,\n val,\n momentPropertiesLen = momentProperties.length;\n\n if (!isUndefined(from._isAMomentObject)) {\n to._isAMomentObject = from._isAMomentObject;\n }\n if (!isUndefined(from._i)) {\n to._i = from._i;\n }\n if (!isUndefined(from._f)) {\n to._f = from._f;\n }\n if (!isUndefined(from._l)) {\n to._l = from._l;\n }\n if (!isUndefined(from._strict)) {\n to._strict = from._strict;\n }\n if (!isUndefined(from._tzm)) {\n to._tzm = from._tzm;\n }\n if (!isUndefined(from._isUTC)) {\n to._isUTC = from._isUTC;\n }\n if (!isUndefined(from._offset)) {\n to._offset = from._offset;\n }\n if (!isUndefined(from._pf)) {\n to._pf = getParsingFlags(from);\n }\n if (!isUndefined(from._locale)) {\n to._locale = from._locale;\n }\n\n if (momentPropertiesLen > 0) {\n for (i = 0; i < momentPropertiesLen; i++) {\n prop = momentProperties[i];\n val = from[prop];\n if (!isUndefined(val)) {\n to[prop] = val;\n }\n }\n }\n\n return to;\n }\n\n // Moment prototype object\n function Moment(config) {\n copyConfig(this, config);\n this._d = new Date(config._d != null ? config._d.getTime() : NaN);\n if (!this.isValid()) {\n this._d = new Date(NaN);\n }\n // Prevent infinite loop in case updateOffset creates new moment\n // objects.\n if (updateInProgress === false) {\n updateInProgress = true;\n hooks.updateOffset(this);\n updateInProgress = false;\n }\n }\n\n function isMoment(obj) {\n return (\n obj instanceof Moment || (obj != null && obj._isAMomentObject != null)\n );\n }\n\n function warn(msg) {\n if (\n hooks.suppressDeprecationWarnings === false &&\n typeof console !== 'undefined' &&\n console.warn\n ) {\n console.warn('Deprecation warning: ' + msg);\n }\n }\n\n function deprecate(msg, fn) {\n var firstTime = true;\n\n return extend(function () {\n if (hooks.deprecationHandler != null) {\n hooks.deprecationHandler(null, msg);\n }\n if (firstTime) {\n var args = [],\n arg,\n i,\n key,\n argLen = arguments.length;\n for (i = 0; i < argLen; i++) {\n arg = '';\n if (typeof arguments[i] === 'object') {\n arg += '\\n[' + i + '] ';\n for (key in arguments[0]) {\n if (hasOwnProp(arguments[0], key)) {\n arg += key + ': ' + arguments[0][key] + ', ';\n }\n }\n arg = arg.slice(0, -2); // Remove trailing comma and space\n } else {\n arg = arguments[i];\n }\n args.push(arg);\n }\n warn(\n msg +\n '\\nArguments: ' +\n Array.prototype.slice.call(args).join('') +\n '\\n' +\n new Error().stack\n );\n firstTime = false;\n }\n return fn.apply(this, arguments);\n }, fn);\n }\n\n var deprecations = {};\n\n function deprecateSimple(name, msg) {\n if (hooks.deprecationHandler != null) {\n hooks.deprecationHandler(name, msg);\n }\n if (!deprecations[name]) {\n warn(msg);\n deprecations[name] = true;\n }\n }\n\n hooks.suppressDeprecationWarnings = false;\n hooks.deprecationHandler = null;\n\n function isFunction(input) {\n return (\n (typeof Function !== 'undefined' && input instanceof Function) ||\n Object.prototype.toString.call(input) === '[object Function]'\n );\n }\n\n function set(config) {\n var prop, i;\n for (i in config) {\n if (hasOwnProp(config, i)) {\n prop = config[i];\n if (isFunction(prop)) {\n this[i] = prop;\n } else {\n this['_' + i] = prop;\n }\n }\n }\n this._config = config;\n // Lenient ordinal parsing accepts just a number in addition to\n // number + (possibly) stuff coming from _dayOfMonthOrdinalParse.\n // TODO: Remove \"ordinalParse\" fallback in next major release.\n this._dayOfMonthOrdinalParseLenient = new RegExp(\n (this._dayOfMonthOrdinalParse.source || this._ordinalParse.source) +\n '|' +\n /\\d{1,2}/.source\n );\n }\n\n function mergeConfigs(parentConfig, childConfig) {\n var res = extend({}, parentConfig),\n prop;\n for (prop in childConfig) {\n if (hasOwnProp(childConfig, prop)) {\n if (isObject(parentConfig[prop]) && isObject(childConfig[prop])) {\n res[prop] = {};\n extend(res[prop], parentConfig[prop]);\n extend(res[prop], childConfig[prop]);\n } else if (childConfig[prop] != null) {\n res[prop] = childConfig[prop];\n } else {\n delete res[prop];\n }\n }\n }\n for (prop in parentConfig) {\n if (\n hasOwnProp(parentConfig, prop) &&\n !hasOwnProp(childConfig, prop) &&\n isObject(parentConfig[prop])\n ) {\n // make sure changes to properties don't modify parent config\n res[prop] = extend({}, res[prop]);\n }\n }\n return res;\n }\n\n function Locale(config) {\n if (config != null) {\n this.set(config);\n }\n }\n\n var keys;\n\n if (Object.keys) {\n keys = Object.keys;\n } else {\n keys = function (obj) {\n var i,\n res = [];\n for (i in obj) {\n if (hasOwnProp(obj, i)) {\n res.push(i);\n }\n }\n return res;\n };\n }\n\n var defaultCalendar = {\n sameDay: '[Today at] LT',\n nextDay: '[Tomorrow at] LT',\n nextWeek: 'dddd [at] LT',\n lastDay: '[Yesterday at] LT',\n lastWeek: '[Last] dddd [at] LT',\n sameElse: 'L',\n };\n\n function calendar(key, mom, now) {\n var output = this._calendar[key] || this._calendar['sameElse'];\n return isFunction(output) ? output.call(mom, now) : output;\n }\n\n function zeroFill(number, targetLength, forceSign) {\n var absNumber = '' + Math.abs(number),\n zerosToFill = targetLength - absNumber.length,\n sign = number >= 0;\n return (\n (sign ? (forceSign ? '+' : '') : '-') +\n Math.pow(10, Math.max(0, zerosToFill)).toString().substr(1) +\n absNumber\n );\n }\n\n var formattingTokens =\n /(\\[[^\\[]*\\])|(\\\\)?([Hh]mm(ss)?|Mo|MM?M?M?|Do|DDDo|DD?D?D?|ddd?d?|do?|w[o|w]?|W[o|W]?|Qo?|N{1,5}|YYYYYY|YYYYY|YYYY|YY|y{2,4}|yo?|gg(ggg?)?|GG(GGG?)?|e|E|a|A|hh?|HH?|kk?|mm?|ss?|S{1,9}|x|X|zz?|ZZ?|.)/g,\n localFormattingTokens = /(\\[[^\\[]*\\])|(\\\\)?(LTS|LT|LL?L?L?|l{1,4})/g,\n formatFunctions = {},\n formatTokenFunctions = {};\n\n // token: 'M'\n // padded: ['MM', 2]\n // ordinal: 'Mo'\n // callback: function () { this.month() + 1 }\n function addFormatToken(token, padded, ordinal, callback) {\n var func = callback;\n if (typeof callback === 'string') {\n func = function () {\n return this[callback]();\n };\n }\n if (token) {\n formatTokenFunctions[token] = func;\n }\n if (padded) {\n formatTokenFunctions[padded[0]] = function () {\n return zeroFill(func.apply(this, arguments), padded[1], padded[2]);\n };\n }\n if (ordinal) {\n formatTokenFunctions[ordinal] = function () {\n return this.localeData().ordinal(\n func.apply(this, arguments),\n token\n );\n };\n }\n }\n\n function removeFormattingTokens(input) {\n if (input.match(/\\[[\\s\\S]/)) {\n return input.replace(/^\\[|\\]$/g, '');\n }\n return input.replace(/\\\\/g, '');\n }\n\n function makeFormatFunction(format) {\n var array = format.match(formattingTokens),\n i,\n length;\n\n for (i = 0, length = array.length; i < length; i++) {\n if (formatTokenFunctions[array[i]]) {\n array[i] = formatTokenFunctions[array[i]];\n } else {\n array[i] = removeFormattingTokens(array[i]);\n }\n }\n\n return function (mom) {\n var output = '',\n i;\n for (i = 0; i < length; i++) {\n output += isFunction(array[i])\n ? array[i].call(mom, format)\n : array[i];\n }\n return output;\n };\n }\n\n // format date using native date object\n function formatMoment(m, format) {\n if (!m.isValid()) {\n return m.localeData().invalidDate();\n }\n\n format = expandFormat(format, m.localeData());\n formatFunctions[format] =\n formatFunctions[format] || makeFormatFunction(format);\n\n return formatFunctions[format](m);\n }\n\n function expandFormat(format, locale) {\n var i = 5;\n\n function replaceLongDateFormatTokens(input) {\n return locale.longDateFormat(input) || input;\n }\n\n localFormattingTokens.lastIndex = 0;\n while (i >= 0 && localFormattingTokens.test(format)) {\n format = format.replace(\n localFormattingTokens,\n replaceLongDateFormatTokens\n );\n localFormattingTokens.lastIndex = 0;\n i -= 1;\n }\n\n return format;\n }\n\n var defaultLongDateFormat = {\n LTS: 'h:mm:ss A',\n LT: 'h:mm A',\n L: 'MM/DD/YYYY',\n LL: 'MMMM D, YYYY',\n LLL: 'MMMM D, YYYY h:mm A',\n LLLL: 'dddd, MMMM D, YYYY h:mm A',\n };\n\n function longDateFormat(key) {\n var format = this._longDateFormat[key],\n formatUpper = this._longDateFormat[key.toUpperCase()];\n\n if (format || !formatUpper) {\n return format;\n }\n\n this._longDateFormat[key] = formatUpper\n .match(formattingTokens)\n .map(function (tok) {\n if (\n tok === 'MMMM' ||\n tok === 'MM' ||\n tok === 'DD' ||\n tok === 'dddd'\n ) {\n return tok.slice(1);\n }\n return tok;\n })\n .join('');\n\n return this._longDateFormat[key];\n }\n\n var defaultInvalidDate = 'Invalid date';\n\n function invalidDate() {\n return this._invalidDate;\n }\n\n var defaultOrdinal = '%d',\n defaultDayOfMonthOrdinalParse = /\\d{1,2}/;\n\n function ordinal(number) {\n return this._ordinal.replace('%d', number);\n }\n\n var defaultRelativeTime = {\n future: 'in %s',\n past: '%s ago',\n s: 'a few seconds',\n ss: '%d seconds',\n m: 'a minute',\n mm: '%d minutes',\n h: 'an hour',\n hh: '%d hours',\n d: 'a day',\n dd: '%d days',\n w: 'a week',\n ww: '%d weeks',\n M: 'a month',\n MM: '%d months',\n y: 'a year',\n yy: '%d years',\n };\n\n function relativeTime(number, withoutSuffix, string, isFuture) {\n var output = this._relativeTime[string];\n return isFunction(output)\n ? output(number, withoutSuffix, string, isFuture)\n : output.replace(/%d/i, number);\n }\n\n function pastFuture(diff, output) {\n var format = this._relativeTime[diff > 0 ? 'future' : 'past'];\n return isFunction(format) ? format(output) : format.replace(/%s/i, output);\n }\n\n var aliases = {\n D: 'date',\n dates: 'date',\n date: 'date',\n d: 'day',\n days: 'day',\n day: 'day',\n e: 'weekday',\n weekdays: 'weekday',\n weekday: 'weekday',\n E: 'isoWeekday',\n isoweekdays: 'isoWeekday',\n isoweekday: 'isoWeekday',\n DDD: 'dayOfYear',\n dayofyears: 'dayOfYear',\n dayofyear: 'dayOfYear',\n h: 'hour',\n hours: 'hour',\n hour: 'hour',\n ms: 'millisecond',\n milliseconds: 'millisecond',\n millisecond: 'millisecond',\n m: 'minute',\n minutes: 'minute',\n minute: 'minute',\n M: 'month',\n months: 'month',\n month: 'month',\n Q: 'quarter',\n quarters: 'quarter',\n quarter: 'quarter',\n s: 'second',\n seconds: 'second',\n second: 'second',\n gg: 'weekYear',\n weekyears: 'weekYear',\n weekyear: 'weekYear',\n GG: 'isoWeekYear',\n isoweekyears: 'isoWeekYear',\n isoweekyear: 'isoWeekYear',\n w: 'week',\n weeks: 'week',\n week: 'week',\n W: 'isoWeek',\n isoweeks: 'isoWeek',\n isoweek: 'isoWeek',\n y: 'year',\n years: 'year',\n year: 'year',\n };\n\n function normalizeUnits(units) {\n return typeof units === 'string'\n ? aliases[units] || aliases[units.toLowerCase()]\n : undefined;\n }\n\n function normalizeObjectUnits(inputObject) {\n var normalizedInput = {},\n normalizedProp,\n prop;\n\n for (prop in inputObject) {\n if (hasOwnProp(inputObject, prop)) {\n normalizedProp = normalizeUnits(prop);\n if (normalizedProp) {\n normalizedInput[normalizedProp] = inputObject[prop];\n }\n }\n }\n\n return normalizedInput;\n }\n\n var priorities = {\n date: 9,\n day: 11,\n weekday: 11,\n isoWeekday: 11,\n dayOfYear: 4,\n hour: 13,\n millisecond: 16,\n minute: 14,\n month: 8,\n quarter: 7,\n second: 15,\n weekYear: 1,\n isoWeekYear: 1,\n week: 5,\n isoWeek: 5,\n year: 1,\n };\n\n function getPrioritizedUnits(unitsObj) {\n var units = [],\n u;\n for (u in unitsObj) {\n if (hasOwnProp(unitsObj, u)) {\n units.push({ unit: u, priority: priorities[u] });\n }\n }\n units.sort(function (a, b) {\n return a.priority - b.priority;\n });\n return units;\n }\n\n var match1 = /\\d/, // 0 - 9\n match2 = /\\d\\d/, // 00 - 99\n match3 = /\\d{3}/, // 000 - 999\n match4 = /\\d{4}/, // 0000 - 9999\n match6 = /[+-]?\\d{6}/, // -999999 - 999999\n match1to2 = /\\d\\d?/, // 0 - 99\n match3to4 = /\\d\\d\\d\\d?/, // 999 - 9999\n match5to6 = /\\d\\d\\d\\d\\d\\d?/, // 99999 - 999999\n match1to3 = /\\d{1,3}/, // 0 - 999\n match1to4 = /\\d{1,4}/, // 0 - 9999\n match1to6 = /[+-]?\\d{1,6}/, // -999999 - 999999\n matchUnsigned = /\\d+/, // 0 - inf\n matchSigned = /[+-]?\\d+/, // -inf - inf\n matchOffset = /Z|[+-]\\d\\d:?\\d\\d/gi, // +00:00 -00:00 +0000 -0000 or Z\n matchShortOffset = /Z|[+-]\\d\\d(?::?\\d\\d)?/gi, // +00 -00 +00:00 -00:00 +0000 -0000 or Z\n matchTimestamp = /[+-]?\\d+(\\.\\d{1,3})?/, // 123456789 123456789.123\n // any word (or two) characters or numbers including two/three word month in arabic.\n // includes scottish gaelic two word and hyphenated months\n matchWord =\n /[0-9]{0,256}['a-z\\u00A0-\\u05FF\\u0700-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFF07\\uFF10-\\uFFEF]{1,256}|[\\u0600-\\u06FF\\/]{1,256}(\\s*?[\\u0600-\\u06FF]{1,256}){1,2}/i,\n match1to2NoLeadingZero = /^[1-9]\\d?/, // 1-99\n match1to2HasZero = /^([1-9]\\d|\\d)/, // 0-99\n regexes;\n\n regexes = {};\n\n function addRegexToken(token, regex, strictRegex) {\n regexes[token] = isFunction(regex)\n ? regex\n : function (isStrict, localeData) {\n return isStrict && strictRegex ? strictRegex : regex;\n };\n }\n\n function getParseRegexForToken(token, config) {\n if (!hasOwnProp(regexes, token)) {\n return new RegExp(unescapeFormat(token));\n }\n\n return regexes[token](config._strict, config._locale);\n }\n\n // Code from http://stackoverflow.com/questions/3561493/is-there-a-regexp-escape-function-in-javascript\n function unescapeFormat(s) {\n return regexEscape(\n s\n .replace('\\\\', '')\n .replace(\n /\\\\(\\[)|\\\\(\\])|\\[([^\\]\\[]*)\\]|\\\\(.)/g,\n function (matched, p1, p2, p3, p4) {\n return p1 || p2 || p3 || p4;\n }\n )\n );\n }\n\n function regexEscape(s) {\n return s.replace(/[-\\/\\\\^$*+?.()|[\\]{}]/g, '\\\\$&');\n }\n\n function absFloor(number) {\n if (number < 0) {\n // -0 -> 0\n return Math.ceil(number) || 0;\n } else {\n return Math.floor(number);\n }\n }\n\n function toInt(argumentForCoercion) {\n var coercedNumber = +argumentForCoercion,\n value = 0;\n\n if (coercedNumber !== 0 && isFinite(coercedNumber)) {\n value = absFloor(coercedNumber);\n }\n\n return value;\n }\n\n var tokens = {};\n\n function addParseToken(token, callback) {\n var i,\n func = callback,\n tokenLen;\n if (typeof token === 'string') {\n token = [token];\n }\n if (isNumber(callback)) {\n func = function (input, array) {\n array[callback] = toInt(input);\n };\n }\n tokenLen = token.length;\n for (i = 0; i < tokenLen; i++) {\n tokens[token[i]] = func;\n }\n }\n\n function addWeekParseToken(token, callback) {\n addParseToken(token, function (input, array, config, token) {\n config._w = config._w || {};\n callback(input, config._w, config, token);\n });\n }\n\n function addTimeToArrayFromToken(token, input, config) {\n if (input != null && hasOwnProp(tokens, token)) {\n tokens[token](input, config._a, config, token);\n }\n }\n\n function isLeapYear(year) {\n return (year % 4 === 0 && year % 100 !== 0) || year % 400 === 0;\n }\n\n var YEAR = 0,\n MONTH = 1,\n DATE = 2,\n HOUR = 3,\n MINUTE = 4,\n SECOND = 5,\n MILLISECOND = 6,\n WEEK = 7,\n WEEKDAY = 8;\n\n // FORMATTING\n\n addFormatToken('Y', 0, 0, function () {\n var y = this.year();\n return y <= 9999 ? zeroFill(y, 4) : '+' + y;\n });\n\n addFormatToken(0, ['YY', 2], 0, function () {\n return this.year() % 100;\n });\n\n addFormatToken(0, ['YYYY', 4], 0, 'year');\n addFormatToken(0, ['YYYYY', 5], 0, 'year');\n addFormatToken(0, ['YYYYYY', 6, true], 0, 'year');\n\n // PARSING\n\n addRegexToken('Y', matchSigned);\n addRegexToken('YY', match1to2, match2);\n addRegexToken('YYYY', match1to4, match4);\n addRegexToken('YYYYY', match1to6, match6);\n addRegexToken('YYYYYY', match1to6, match6);\n\n addParseToken(['YYYYY', 'YYYYYY'], YEAR);\n addParseToken('YYYY', function (input, array) {\n array[YEAR] =\n input.length === 2 ? hooks.parseTwoDigitYear(input) : toInt(input);\n });\n addParseToken('YY', function (input, array) {\n array[YEAR] = hooks.parseTwoDigitYear(input);\n });\n addParseToken('Y', function (input, array) {\n array[YEAR] = parseInt(input, 10);\n });\n\n // HELPERS\n\n function daysInYear(year) {\n return isLeapYear(year) ? 366 : 365;\n }\n\n // HOOKS\n\n hooks.parseTwoDigitYear = function (input) {\n return toInt(input) + (toInt(input) > 68 ? 1900 : 2000);\n };\n\n // MOMENTS\n\n var getSetYear = makeGetSet('FullYear', true);\n\n function getIsLeapYear() {\n return isLeapYear(this.year());\n }\n\n function makeGetSet(unit, keepTime) {\n return function (value) {\n if (value != null) {\n set$1(this, unit, value);\n hooks.updateOffset(this, keepTime);\n return this;\n } else {\n return get(this, unit);\n }\n };\n }\n\n function get(mom, unit) {\n if (!mom.isValid()) {\n return NaN;\n }\n\n var d = mom._d,\n isUTC = mom._isUTC;\n\n switch (unit) {\n case 'Milliseconds':\n return isUTC ? d.getUTCMilliseconds() : d.getMilliseconds();\n case 'Seconds':\n return isUTC ? d.getUTCSeconds() : d.getSeconds();\n case 'Minutes':\n return isUTC ? d.getUTCMinutes() : d.getMinutes();\n case 'Hours':\n return isUTC ? d.getUTCHours() : d.getHours();\n case 'Date':\n return isUTC ? d.getUTCDate() : d.getDate();\n case 'Day':\n return isUTC ? d.getUTCDay() : d.getDay();\n case 'Month':\n return isUTC ? d.getUTCMonth() : d.getMonth();\n case 'FullYear':\n return isUTC ? d.getUTCFullYear() : d.getFullYear();\n default:\n return NaN; // Just in case\n }\n }\n\n function set$1(mom, unit, value) {\n var d, isUTC, year, month, date;\n\n if (!mom.isValid() || isNaN(value)) {\n return;\n }\n\n d = mom._d;\n isUTC = mom._isUTC;\n\n switch (unit) {\n case 'Milliseconds':\n return void (isUTC\n ? d.setUTCMilliseconds(value)\n : d.setMilliseconds(value));\n case 'Seconds':\n return void (isUTC ? d.setUTCSeconds(value) : d.setSeconds(value));\n case 'Minutes':\n return void (isUTC ? d.setUTCMinutes(value) : d.setMinutes(value));\n case 'Hours':\n return void (isUTC ? d.setUTCHours(value) : d.setHours(value));\n case 'Date':\n return void (isUTC ? d.setUTCDate(value) : d.setDate(value));\n // case 'Day': // Not real\n // return void (isUTC ? d.setUTCDay(value) : d.setDay(value));\n // case 'Month': // Not used because we need to pass two variables\n // return void (isUTC ? d.setUTCMonth(value) : d.setMonth(value));\n case 'FullYear':\n break; // See below ...\n default:\n return; // Just in case\n }\n\n year = value;\n month = mom.month();\n date = mom.date();\n date = date === 29 && month === 1 && !isLeapYear(year) ? 28 : date;\n void (isUTC\n ? d.setUTCFullYear(year, month, date)\n : d.setFullYear(year, month, date));\n }\n\n // MOMENTS\n\n function stringGet(units) {\n units = normalizeUnits(units);\n if (isFunction(this[units])) {\n return this[units]();\n }\n return this;\n }\n\n function stringSet(units, value) {\n if (typeof units === 'object') {\n units = normalizeObjectUnits(units);\n var prioritized = getPrioritizedUnits(units),\n i,\n prioritizedLen = prioritized.length;\n for (i = 0; i < prioritizedLen; i++) {\n this[prioritized[i].unit](units[prioritized[i].unit]);\n }\n } else {\n units = normalizeUnits(units);\n if (isFunction(this[units])) {\n return this[units](value);\n }\n }\n return this;\n }\n\n function mod(n, x) {\n return ((n % x) + x) % x;\n }\n\n var indexOf;\n\n if (Array.prototype.indexOf) {\n indexOf = Array.prototype.indexOf;\n } else {\n indexOf = function (o) {\n // I know\n var i;\n for (i = 0; i < this.length; ++i) {\n if (this[i] === o) {\n return i;\n }\n }\n return -1;\n };\n }\n\n function daysInMonth(year, month) {\n if (isNaN(year) || isNaN(month)) {\n return NaN;\n }\n var modMonth = mod(month, 12);\n year += (month - modMonth) / 12;\n return modMonth === 1\n ? isLeapYear(year)\n ? 29\n : 28\n : 31 - ((modMonth % 7) % 2);\n }\n\n // FORMATTING\n\n addFormatToken('M', ['MM', 2], 'Mo', function () {\n return this.month() + 1;\n });\n\n addFormatToken('MMM', 0, 0, function (format) {\n return this.localeData().monthsShort(this, format);\n });\n\n addFormatToken('MMMM', 0, 0, function (format) {\n return this.localeData().months(this, format);\n });\n\n // PARSING\n\n addRegexToken('M', match1to2, match1to2NoLeadingZero);\n addRegexToken('MM', match1to2, match2);\n addRegexToken('MMM', function (isStrict, locale) {\n return locale.monthsShortRegex(isStrict);\n });\n addRegexToken('MMMM', function (isStrict, locale) {\n return locale.monthsRegex(isStrict);\n });\n\n addParseToken(['M', 'MM'], function (input, array) {\n array[MONTH] = toInt(input) - 1;\n });\n\n addParseToken(['MMM', 'MMMM'], function (input, array, config, token) {\n var month = config._locale.monthsParse(input, token, config._strict);\n // if we didn't find a month name, mark the date as invalid.\n if (month != null) {\n array[MONTH] = month;\n } else {\n getParsingFlags(config).invalidMonth = input;\n }\n });\n\n // LOCALES\n\n var defaultLocaleMonths =\n 'January_February_March_April_May_June_July_August_September_October_November_December'.split(\n '_'\n ),\n defaultLocaleMonthsShort =\n 'Jan_Feb_Mar_Apr_May_Jun_Jul_Aug_Sep_Oct_Nov_Dec'.split('_'),\n MONTHS_IN_FORMAT = /D[oD]?(\\[[^\\[\\]]*\\]|\\s)+MMMM?/,\n defaultMonthsShortRegex = matchWord,\n defaultMonthsRegex = matchWord;\n\n function localeMonths(m, format) {\n if (!m) {\n return isArray(this._months)\n ? this._months\n : this._months['standalone'];\n }\n return isArray(this._months)\n ? this._months[m.month()]\n : this._months[\n (this._months.isFormat || MONTHS_IN_FORMAT).test(format)\n ? 'format'\n : 'standalone'\n ][m.month()];\n }\n\n function localeMonthsShort(m, format) {\n if (!m) {\n return isArray(this._monthsShort)\n ? this._monthsShort\n : this._monthsShort['standalone'];\n }\n return isArray(this._monthsShort)\n ? this._monthsShort[m.month()]\n : this._monthsShort[\n MONTHS_IN_FORMAT.test(format) ? 'format' : 'standalone'\n ][m.month()];\n }\n\n function handleStrictParse(monthName, format, strict) {\n var i,\n ii,\n mom,\n llc = monthName.toLocaleLowerCase();\n if (!this._monthsParse) {\n // this is not used\n this._monthsParse = [];\n this._longMonthsParse = [];\n this._shortMonthsParse = [];\n for (i = 0; i < 12; ++i) {\n mom = createUTC([2000, i]);\n this._shortMonthsParse[i] = this.monthsShort(\n mom,\n ''\n ).toLocaleLowerCase();\n this._longMonthsParse[i] = this.months(mom, '').toLocaleLowerCase();\n }\n }\n\n if (strict) {\n if (format === 'MMM') {\n ii = indexOf.call(this._shortMonthsParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._longMonthsParse, llc);\n return ii !== -1 ? ii : null;\n }\n } else {\n if (format === 'MMM') {\n ii = indexOf.call(this._shortMonthsParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._longMonthsParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._longMonthsParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._shortMonthsParse, llc);\n return ii !== -1 ? ii : null;\n }\n }\n }\n\n function localeMonthsParse(monthName, format, strict) {\n var i, mom, regex;\n\n if (this._monthsParseExact) {\n return handleStrictParse.call(this, monthName, format, strict);\n }\n\n if (!this._monthsParse) {\n this._monthsParse = [];\n this._longMonthsParse = [];\n this._shortMonthsParse = [];\n }\n\n // TODO: add sorting\n // Sorting makes sure if one month (or abbr) is a prefix of another\n // see sorting in computeMonthsParse\n for (i = 0; i < 12; i++) {\n // make the regex if we don't have it already\n mom = createUTC([2000, i]);\n if (strict && !this._longMonthsParse[i]) {\n this._longMonthsParse[i] = new RegExp(\n '^' + this.months(mom, '').replace('.', '') + '$',\n 'i'\n );\n this._shortMonthsParse[i] = new RegExp(\n '^' + this.monthsShort(mom, '').replace('.', '') + '$',\n 'i'\n );\n }\n if (!strict && !this._monthsParse[i]) {\n regex =\n '^' + this.months(mom, '') + '|^' + this.monthsShort(mom, '');\n this._monthsParse[i] = new RegExp(regex.replace('.', ''), 'i');\n }\n // test the regex\n if (\n strict &&\n format === 'MMMM' &&\n this._longMonthsParse[i].test(monthName)\n ) {\n return i;\n } else if (\n strict &&\n format === 'MMM' &&\n this._shortMonthsParse[i].test(monthName)\n ) {\n return i;\n } else if (!strict && this._monthsParse[i].test(monthName)) {\n return i;\n }\n }\n }\n\n // MOMENTS\n\n function setMonth(mom, value) {\n if (!mom.isValid()) {\n // No op\n return mom;\n }\n\n if (typeof value === 'string') {\n if (/^\\d+$/.test(value)) {\n value = toInt(value);\n } else {\n value = mom.localeData().monthsParse(value);\n // TODO: Another silent failure?\n if (!isNumber(value)) {\n return mom;\n }\n }\n }\n\n var month = value,\n date = mom.date();\n\n date = date < 29 ? date : Math.min(date, daysInMonth(mom.year(), month));\n void (mom._isUTC\n ? mom._d.setUTCMonth(month, date)\n : mom._d.setMonth(month, date));\n return mom;\n }\n\n function getSetMonth(value) {\n if (value != null) {\n setMonth(this, value);\n hooks.updateOffset(this, true);\n return this;\n } else {\n return get(this, 'Month');\n }\n }\n\n function getDaysInMonth() {\n return daysInMonth(this.year(), this.month());\n }\n\n function monthsShortRegex(isStrict) {\n if (this._monthsParseExact) {\n if (!hasOwnProp(this, '_monthsRegex')) {\n computeMonthsParse.call(this);\n }\n if (isStrict) {\n return this._monthsShortStrictRegex;\n } else {\n return this._monthsShortRegex;\n }\n } else {\n if (!hasOwnProp(this, '_monthsShortRegex')) {\n this._monthsShortRegex = defaultMonthsShortRegex;\n }\n return this._monthsShortStrictRegex && isStrict\n ? this._monthsShortStrictRegex\n : this._monthsShortRegex;\n }\n }\n\n function monthsRegex(isStrict) {\n if (this._monthsParseExact) {\n if (!hasOwnProp(this, '_monthsRegex')) {\n computeMonthsParse.call(this);\n }\n if (isStrict) {\n return this._monthsStrictRegex;\n } else {\n return this._monthsRegex;\n }\n } else {\n if (!hasOwnProp(this, '_monthsRegex')) {\n this._monthsRegex = defaultMonthsRegex;\n }\n return this._monthsStrictRegex && isStrict\n ? this._monthsStrictRegex\n : this._monthsRegex;\n }\n }\n\n function computeMonthsParse() {\n function cmpLenRev(a, b) {\n return b.length - a.length;\n }\n\n var shortPieces = [],\n longPieces = [],\n mixedPieces = [],\n i,\n mom,\n shortP,\n longP;\n for (i = 0; i < 12; i++) {\n // make the regex if we don't have it already\n mom = createUTC([2000, i]);\n shortP = regexEscape(this.monthsShort(mom, ''));\n longP = regexEscape(this.months(mom, ''));\n shortPieces.push(shortP);\n longPieces.push(longP);\n mixedPieces.push(longP);\n mixedPieces.push(shortP);\n }\n // Sorting makes sure if one month (or abbr) is a prefix of another it\n // will match the longer piece.\n shortPieces.sort(cmpLenRev);\n longPieces.sort(cmpLenRev);\n mixedPieces.sort(cmpLenRev);\n\n this._monthsRegex = new RegExp('^(' + mixedPieces.join('|') + ')', 'i');\n this._monthsShortRegex = this._monthsRegex;\n this._monthsStrictRegex = new RegExp(\n '^(' + longPieces.join('|') + ')',\n 'i'\n );\n this._monthsShortStrictRegex = new RegExp(\n '^(' + shortPieces.join('|') + ')',\n 'i'\n );\n }\n\n function createDate(y, m, d, h, M, s, ms) {\n // can't just apply() to create a date:\n // https://stackoverflow.com/q/181348\n var date;\n // the date constructor remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n // preserve leap years using a full 400 year cycle, then reset\n date = new Date(y + 400, m, d, h, M, s, ms);\n if (isFinite(date.getFullYear())) {\n date.setFullYear(y);\n }\n } else {\n date = new Date(y, m, d, h, M, s, ms);\n }\n\n return date;\n }\n\n function createUTCDate(y) {\n var date, args;\n // the Date.UTC function remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n args = Array.prototype.slice.call(arguments);\n // preserve leap years using a full 400 year cycle, then reset\n args[0] = y + 400;\n date = new Date(Date.UTC.apply(null, args));\n if (isFinite(date.getUTCFullYear())) {\n date.setUTCFullYear(y);\n }\n } else {\n date = new Date(Date.UTC.apply(null, arguments));\n }\n\n return date;\n }\n\n // start-of-first-week - start-of-year\n function firstWeekOffset(year, dow, doy) {\n var // first-week day -- which january is always in the first week (4 for iso, 1 for other)\n fwd = 7 + dow - doy,\n // first-week day local weekday -- which local weekday is fwd\n fwdlw = (7 + createUTCDate(year, 0, fwd).getUTCDay() - dow) % 7;\n\n return -fwdlw + fwd - 1;\n }\n\n // https://en.wikipedia.org/wiki/ISO_week_date#Calculating_a_date_given_the_year.2C_week_number_and_weekday\n function dayOfYearFromWeeks(year, week, weekday, dow, doy) {\n var localWeekday = (7 + weekday - dow) % 7,\n weekOffset = firstWeekOffset(year, dow, doy),\n dayOfYear = 1 + 7 * (week - 1) + localWeekday + weekOffset,\n resYear,\n resDayOfYear;\n\n if (dayOfYear <= 0) {\n resYear = year - 1;\n resDayOfYear = daysInYear(resYear) + dayOfYear;\n } else if (dayOfYear > daysInYear(year)) {\n resYear = year + 1;\n resDayOfYear = dayOfYear - daysInYear(year);\n } else {\n resYear = year;\n resDayOfYear = dayOfYear;\n }\n\n return {\n year: resYear,\n dayOfYear: resDayOfYear,\n };\n }\n\n function weekOfYear(mom, dow, doy) {\n var weekOffset = firstWeekOffset(mom.year(), dow, doy),\n week = Math.floor((mom.dayOfYear() - weekOffset - 1) / 7) + 1,\n resWeek,\n resYear;\n\n if (week < 1) {\n resYear = mom.year() - 1;\n resWeek = week + weeksInYear(resYear, dow, doy);\n } else if (week > weeksInYear(mom.year(), dow, doy)) {\n resWeek = week - weeksInYear(mom.year(), dow, doy);\n resYear = mom.year() + 1;\n } else {\n resYear = mom.year();\n resWeek = week;\n }\n\n return {\n week: resWeek,\n year: resYear,\n };\n }\n\n function weeksInYear(year, dow, doy) {\n var weekOffset = firstWeekOffset(year, dow, doy),\n weekOffsetNext = firstWeekOffset(year + 1, dow, doy);\n return (daysInYear(year) - weekOffset + weekOffsetNext) / 7;\n }\n\n // FORMATTING\n\n addFormatToken('w', ['ww', 2], 'wo', 'week');\n addFormatToken('W', ['WW', 2], 'Wo', 'isoWeek');\n\n // PARSING\n\n addRegexToken('w', match1to2, match1to2NoLeadingZero);\n addRegexToken('ww', match1to2, match2);\n addRegexToken('W', match1to2, match1to2NoLeadingZero);\n addRegexToken('WW', match1to2, match2);\n\n addWeekParseToken(\n ['w', 'ww', 'W', 'WW'],\n function (input, week, config, token) {\n week[token.substr(0, 1)] = toInt(input);\n }\n );\n\n // HELPERS\n\n // LOCALES\n\n function localeWeek(mom) {\n return weekOfYear(mom, this._week.dow, this._week.doy).week;\n }\n\n var defaultLocaleWeek = {\n dow: 0, // Sunday is the first day of the week.\n doy: 6, // The week that contains Jan 6th is the first week of the year.\n };\n\n function localeFirstDayOfWeek() {\n return this._week.dow;\n }\n\n function localeFirstDayOfYear() {\n return this._week.doy;\n }\n\n // MOMENTS\n\n function getSetWeek(input) {\n var week = this.localeData().week(this);\n return input == null ? week : this.add((input - week) * 7, 'd');\n }\n\n function getSetISOWeek(input) {\n var week = weekOfYear(this, 1, 4).week;\n return input == null ? week : this.add((input - week) * 7, 'd');\n }\n\n // FORMATTING\n\n addFormatToken('d', 0, 'do', 'day');\n\n addFormatToken('dd', 0, 0, function (format) {\n return this.localeData().weekdaysMin(this, format);\n });\n\n addFormatToken('ddd', 0, 0, function (format) {\n return this.localeData().weekdaysShort(this, format);\n });\n\n addFormatToken('dddd', 0, 0, function (format) {\n return this.localeData().weekdays(this, format);\n });\n\n addFormatToken('e', 0, 0, 'weekday');\n addFormatToken('E', 0, 0, 'isoWeekday');\n\n // PARSING\n\n addRegexToken('d', match1to2);\n addRegexToken('e', match1to2);\n addRegexToken('E', match1to2);\n addRegexToken('dd', function (isStrict, locale) {\n return locale.weekdaysMinRegex(isStrict);\n });\n addRegexToken('ddd', function (isStrict, locale) {\n return locale.weekdaysShortRegex(isStrict);\n });\n addRegexToken('dddd', function (isStrict, locale) {\n return locale.weekdaysRegex(isStrict);\n });\n\n addWeekParseToken(['dd', 'ddd', 'dddd'], function (input, week, config, token) {\n var weekday = config._locale.weekdaysParse(input, token, config._strict);\n // if we didn't get a weekday name, mark the date as invalid\n if (weekday != null) {\n week.d = weekday;\n } else {\n getParsingFlags(config).invalidWeekday = input;\n }\n });\n\n addWeekParseToken(['d', 'e', 'E'], function (input, week, config, token) {\n week[token] = toInt(input);\n });\n\n // HELPERS\n\n function parseWeekday(input, locale) {\n if (typeof input !== 'string') {\n return input;\n }\n\n if (!isNaN(input)) {\n return parseInt(input, 10);\n }\n\n input = locale.weekdaysParse(input);\n if (typeof input === 'number') {\n return input;\n }\n\n return null;\n }\n\n function parseIsoWeekday(input, locale) {\n if (typeof input === 'string') {\n return locale.weekdaysParse(input) % 7 || 7;\n }\n return isNaN(input) ? null : input;\n }\n\n // LOCALES\n function shiftWeekdays(ws, n) {\n return ws.slice(n, 7).concat(ws.slice(0, n));\n }\n\n var defaultLocaleWeekdays =\n 'Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday'.split('_'),\n defaultLocaleWeekdaysShort = 'Sun_Mon_Tue_Wed_Thu_Fri_Sat'.split('_'),\n defaultLocaleWeekdaysMin = 'Su_Mo_Tu_We_Th_Fr_Sa'.split('_'),\n defaultWeekdaysRegex = matchWord,\n defaultWeekdaysShortRegex = matchWord,\n defaultWeekdaysMinRegex = matchWord;\n\n function localeWeekdays(m, format) {\n var weekdays = isArray(this._weekdays)\n ? this._weekdays\n : this._weekdays[\n m && m !== true && this._weekdays.isFormat.test(format)\n ? 'format'\n : 'standalone'\n ];\n return m === true\n ? shiftWeekdays(weekdays, this._week.dow)\n : m\n ? weekdays[m.day()]\n : weekdays;\n }\n\n function localeWeekdaysShort(m) {\n return m === true\n ? shiftWeekdays(this._weekdaysShort, this._week.dow)\n : m\n ? this._weekdaysShort[m.day()]\n : this._weekdaysShort;\n }\n\n function localeWeekdaysMin(m) {\n return m === true\n ? shiftWeekdays(this._weekdaysMin, this._week.dow)\n : m\n ? this._weekdaysMin[m.day()]\n : this._weekdaysMin;\n }\n\n function handleStrictParse$1(weekdayName, format, strict) {\n var i,\n ii,\n mom,\n llc = weekdayName.toLocaleLowerCase();\n if (!this._weekdaysParse) {\n this._weekdaysParse = [];\n this._shortWeekdaysParse = [];\n this._minWeekdaysParse = [];\n\n for (i = 0; i < 7; ++i) {\n mom = createUTC([2000, 1]).day(i);\n this._minWeekdaysParse[i] = this.weekdaysMin(\n mom,\n ''\n ).toLocaleLowerCase();\n this._shortWeekdaysParse[i] = this.weekdaysShort(\n mom,\n ''\n ).toLocaleLowerCase();\n this._weekdaysParse[i] = this.weekdays(mom, '').toLocaleLowerCase();\n }\n }\n\n if (strict) {\n if (format === 'dddd') {\n ii = indexOf.call(this._weekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else if (format === 'ddd') {\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._minWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n }\n } else {\n if (format === 'dddd') {\n ii = indexOf.call(this._weekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._minWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else if (format === 'ddd') {\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._weekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._minWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._minWeekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._weekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n }\n }\n }\n\n function localeWeekdaysParse(weekdayName, format, strict) {\n var i, mom, regex;\n\n if (this._weekdaysParseExact) {\n return handleStrictParse$1.call(this, weekdayName, format, strict);\n }\n\n if (!this._weekdaysParse) {\n this._weekdaysParse = [];\n this._minWeekdaysParse = [];\n this._shortWeekdaysParse = [];\n this._fullWeekdaysParse = [];\n }\n\n for (i = 0; i < 7; i++) {\n // make the regex if we don't have it already\n\n mom = createUTC([2000, 1]).day(i);\n if (strict && !this._fullWeekdaysParse[i]) {\n this._fullWeekdaysParse[i] = new RegExp(\n '^' + this.weekdays(mom, '').replace('.', '\\\\.?') + '$',\n 'i'\n );\n this._shortWeekdaysParse[i] = new RegExp(\n '^' + this.weekdaysShort(mom, '').replace('.', '\\\\.?') + '$',\n 'i'\n );\n this._minWeekdaysParse[i] = new RegExp(\n '^' + this.weekdaysMin(mom, '').replace('.', '\\\\.?') + '$',\n 'i'\n );\n }\n if (!this._weekdaysParse[i]) {\n regex =\n '^' +\n this.weekdays(mom, '') +\n '|^' +\n this.weekdaysShort(mom, '') +\n '|^' +\n this.weekdaysMin(mom, '');\n this._weekdaysParse[i] = new RegExp(regex.replace('.', ''), 'i');\n }\n // test the regex\n if (\n strict &&\n format === 'dddd' &&\n this._fullWeekdaysParse[i].test(weekdayName)\n ) {\n return i;\n } else if (\n strict &&\n format === 'ddd' &&\n this._shortWeekdaysParse[i].test(weekdayName)\n ) {\n return i;\n } else if (\n strict &&\n format === 'dd' &&\n this._minWeekdaysParse[i].test(weekdayName)\n ) {\n return i;\n } else if (!strict && this._weekdaysParse[i].test(weekdayName)) {\n return i;\n }\n }\n }\n\n // MOMENTS\n\n function getSetDayOfWeek(input) {\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n\n var day = get(this, 'Day');\n if (input != null) {\n input = parseWeekday(input, this.localeData());\n return this.add(input - day, 'd');\n } else {\n return day;\n }\n }\n\n function getSetLocaleDayOfWeek(input) {\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n var weekday = (this.day() + 7 - this.localeData()._week.dow) % 7;\n return input == null ? weekday : this.add(input - weekday, 'd');\n }\n\n function getSetISODayOfWeek(input) {\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n\n // behaves the same as moment#day except\n // as a getter, returns 7 instead of 0 (1-7 range instead of 0-6)\n // as a setter, sunday should belong to the previous week.\n\n if (input != null) {\n var weekday = parseIsoWeekday(input, this.localeData());\n return this.day(this.day() % 7 ? weekday : weekday - 7);\n } else {\n return this.day() || 7;\n }\n }\n\n function weekdaysRegex(isStrict) {\n if (this._weekdaysParseExact) {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n computeWeekdaysParse.call(this);\n }\n if (isStrict) {\n return this._weekdaysStrictRegex;\n } else {\n return this._weekdaysRegex;\n }\n } else {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n this._weekdaysRegex = defaultWeekdaysRegex;\n }\n return this._weekdaysStrictRegex && isStrict\n ? this._weekdaysStrictRegex\n : this._weekdaysRegex;\n }\n }\n\n function weekdaysShortRegex(isStrict) {\n if (this._weekdaysParseExact) {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n computeWeekdaysParse.call(this);\n }\n if (isStrict) {\n return this._weekdaysShortStrictRegex;\n } else {\n return this._weekdaysShortRegex;\n }\n } else {\n if (!hasOwnProp(this, '_weekdaysShortRegex')) {\n this._weekdaysShortRegex = defaultWeekdaysShortRegex;\n }\n return this._weekdaysShortStrictRegex && isStrict\n ? this._weekdaysShortStrictRegex\n : this._weekdaysShortRegex;\n }\n }\n\n function weekdaysMinRegex(isStrict) {\n if (this._weekdaysParseExact) {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n computeWeekdaysParse.call(this);\n }\n if (isStrict) {\n return this._weekdaysMinStrictRegex;\n } else {\n return this._weekdaysMinRegex;\n }\n } else {\n if (!hasOwnProp(this, '_weekdaysMinRegex')) {\n this._weekdaysMinRegex = defaultWeekdaysMinRegex;\n }\n return this._weekdaysMinStrictRegex && isStrict\n ? this._weekdaysMinStrictRegex\n : this._weekdaysMinRegex;\n }\n }\n\n function computeWeekdaysParse() {\n function cmpLenRev(a, b) {\n return b.length - a.length;\n }\n\n var minPieces = [],\n shortPieces = [],\n longPieces = [],\n mixedPieces = [],\n i,\n mom,\n minp,\n shortp,\n longp;\n for (i = 0; i < 7; i++) {\n // make the regex if we don't have it already\n mom = createUTC([2000, 1]).day(i);\n minp = regexEscape(this.weekdaysMin(mom, ''));\n shortp = regexEscape(this.weekdaysShort(mom, ''));\n longp = regexEscape(this.weekdays(mom, ''));\n minPieces.push(minp);\n shortPieces.push(shortp);\n longPieces.push(longp);\n mixedPieces.push(minp);\n mixedPieces.push(shortp);\n mixedPieces.push(longp);\n }\n // Sorting makes sure if one weekday (or abbr) is a prefix of another it\n // will match the longer piece.\n minPieces.sort(cmpLenRev);\n shortPieces.sort(cmpLenRev);\n longPieces.sort(cmpLenRev);\n mixedPieces.sort(cmpLenRev);\n\n this._weekdaysRegex = new RegExp('^(' + mixedPieces.join('|') + ')', 'i');\n this._weekdaysShortRegex = this._weekdaysRegex;\n this._weekdaysMinRegex = this._weekdaysRegex;\n\n this._weekdaysStrictRegex = new RegExp(\n '^(' + longPieces.join('|') + ')',\n 'i'\n );\n this._weekdaysShortStrictRegex = new RegExp(\n '^(' + shortPieces.join('|') + ')',\n 'i'\n );\n this._weekdaysMinStrictRegex = new RegExp(\n '^(' + minPieces.join('|') + ')',\n 'i'\n );\n }\n\n // FORMATTING\n\n function hFormat() {\n return this.hours() % 12 || 12;\n }\n\n function kFormat() {\n return this.hours() || 24;\n }\n\n addFormatToken('H', ['HH', 2], 0, 'hour');\n addFormatToken('h', ['hh', 2], 0, hFormat);\n addFormatToken('k', ['kk', 2], 0, kFormat);\n\n addFormatToken('hmm', 0, 0, function () {\n return '' + hFormat.apply(this) + zeroFill(this.minutes(), 2);\n });\n\n addFormatToken('hmmss', 0, 0, function () {\n return (\n '' +\n hFormat.apply(this) +\n zeroFill(this.minutes(), 2) +\n zeroFill(this.seconds(), 2)\n );\n });\n\n addFormatToken('Hmm', 0, 0, function () {\n return '' + this.hours() + zeroFill(this.minutes(), 2);\n });\n\n addFormatToken('Hmmss', 0, 0, function () {\n return (\n '' +\n this.hours() +\n zeroFill(this.minutes(), 2) +\n zeroFill(this.seconds(), 2)\n );\n });\n\n function meridiem(token, lowercase) {\n addFormatToken(token, 0, 0, function () {\n return this.localeData().meridiem(\n this.hours(),\n this.minutes(),\n lowercase\n );\n });\n }\n\n meridiem('a', true);\n meridiem('A', false);\n\n // PARSING\n\n function matchMeridiem(isStrict, locale) {\n return locale._meridiemParse;\n }\n\n addRegexToken('a', matchMeridiem);\n addRegexToken('A', matchMeridiem);\n addRegexToken('H', match1to2, match1to2HasZero);\n addRegexToken('h', match1to2, match1to2NoLeadingZero);\n addRegexToken('k', match1to2, match1to2NoLeadingZero);\n addRegexToken('HH', match1to2, match2);\n addRegexToken('hh', match1to2, match2);\n addRegexToken('kk', match1to2, match2);\n\n addRegexToken('hmm', match3to4);\n addRegexToken('hmmss', match5to6);\n addRegexToken('Hmm', match3to4);\n addRegexToken('Hmmss', match5to6);\n\n addParseToken(['H', 'HH'], HOUR);\n addParseToken(['k', 'kk'], function (input, array, config) {\n var kInput = toInt(input);\n array[HOUR] = kInput === 24 ? 0 : kInput;\n });\n addParseToken(['a', 'A'], function (input, array, config) {\n config._isPm = config._locale.isPM(input);\n config._meridiem = input;\n });\n addParseToken(['h', 'hh'], function (input, array, config) {\n array[HOUR] = toInt(input);\n getParsingFlags(config).bigHour = true;\n });\n addParseToken('hmm', function (input, array, config) {\n var pos = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos));\n array[MINUTE] = toInt(input.substr(pos));\n getParsingFlags(config).bigHour = true;\n });\n addParseToken('hmmss', function (input, array, config) {\n var pos1 = input.length - 4,\n pos2 = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos1));\n array[MINUTE] = toInt(input.substr(pos1, 2));\n array[SECOND] = toInt(input.substr(pos2));\n getParsingFlags(config).bigHour = true;\n });\n addParseToken('Hmm', function (input, array, config) {\n var pos = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos));\n array[MINUTE] = toInt(input.substr(pos));\n });\n addParseToken('Hmmss', function (input, array, config) {\n var pos1 = input.length - 4,\n pos2 = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos1));\n array[MINUTE] = toInt(input.substr(pos1, 2));\n array[SECOND] = toInt(input.substr(pos2));\n });\n\n // LOCALES\n\n function localeIsPM(input) {\n // IE8 Quirks Mode & IE7 Standards Mode do not allow accessing strings like arrays\n // Using charAt should be more compatible.\n return (input + '').toLowerCase().charAt(0) === 'p';\n }\n\n var defaultLocaleMeridiemParse = /[ap]\\.?m?\\.?/i,\n // Setting the hour should keep the time, because the user explicitly\n // specified which hour they want. So trying to maintain the same hour (in\n // a new timezone) makes sense. Adding/subtracting hours does not follow\n // this rule.\n getSetHour = makeGetSet('Hours', true);\n\n function localeMeridiem(hours, minutes, isLower) {\n if (hours > 11) {\n return isLower ? 'pm' : 'PM';\n } else {\n return isLower ? 'am' : 'AM';\n }\n }\n\n var baseConfig = {\n calendar: defaultCalendar,\n longDateFormat: defaultLongDateFormat,\n invalidDate: defaultInvalidDate,\n ordinal: defaultOrdinal,\n dayOfMonthOrdinalParse: defaultDayOfMonthOrdinalParse,\n relativeTime: defaultRelativeTime,\n\n months: defaultLocaleMonths,\n monthsShort: defaultLocaleMonthsShort,\n\n week: defaultLocaleWeek,\n\n weekdays: defaultLocaleWeekdays,\n weekdaysMin: defaultLocaleWeekdaysMin,\n weekdaysShort: defaultLocaleWeekdaysShort,\n\n meridiemParse: defaultLocaleMeridiemParse,\n };\n\n // internal storage for locale config files\n var locales = {},\n localeFamilies = {},\n globalLocale;\n\n function commonPrefix(arr1, arr2) {\n var i,\n minl = Math.min(arr1.length, arr2.length);\n for (i = 0; i < minl; i += 1) {\n if (arr1[i] !== arr2[i]) {\n return i;\n }\n }\n return minl;\n }\n\n function normalizeLocale(key) {\n return key ? key.toLowerCase().replace('_', '-') : key;\n }\n\n // pick the locale from the array\n // try ['en-au', 'en-gb'] as 'en-au', 'en-gb', 'en', as in move through the list trying each\n // substring from most specific to least, but move to the next array item if it's a more specific variant than the current root\n function chooseLocale(names) {\n var i = 0,\n j,\n next,\n locale,\n split;\n\n while (i < names.length) {\n split = normalizeLocale(names[i]).split('-');\n j = split.length;\n next = normalizeLocale(names[i + 1]);\n next = next ? next.split('-') : null;\n while (j > 0) {\n locale = loadLocale(split.slice(0, j).join('-'));\n if (locale) {\n return locale;\n }\n if (\n next &&\n next.length >= j &&\n commonPrefix(split, next) >= j - 1\n ) {\n //the next array item is better than a shallower substring of this one\n break;\n }\n j--;\n }\n i++;\n }\n return globalLocale;\n }\n\n function isLocaleNameSane(name) {\n // Prevent names that look like filesystem paths, i.e contain '/' or '\\'\n // Ensure name is available and function returns boolean\n return !!(name && name.match('^[^/\\\\\\\\]*$'));\n }\n\n function loadLocale(name) {\n var oldLocale = null,\n aliasedRequire;\n // TODO: Find a better way to register and load all the locales in Node\n if (\n locales[name] === undefined &&\n typeof module !== 'undefined' &&\n module &&\n module.exports &&\n isLocaleNameSane(name)\n ) {\n try {\n oldLocale = globalLocale._abbr;\n aliasedRequire = require;\n aliasedRequire('./locale/' + name);\n getSetGlobalLocale(oldLocale);\n } catch (e) {\n // mark as not found to avoid repeating expensive file require call causing high CPU\n // when trying to find en-US, en_US, en-us for every format call\n locales[name] = null; // null means not found\n }\n }\n return locales[name];\n }\n\n // This function will load locale and then set the global locale. If\n // no arguments are passed in, it will simply return the current global\n // locale key.\n function getSetGlobalLocale(key, values) {\n var data;\n if (key) {\n if (isUndefined(values)) {\n data = getLocale(key);\n } else {\n data = defineLocale(key, values);\n }\n\n if (data) {\n // moment.duration._locale = moment._locale = data;\n globalLocale = data;\n } else {\n if (typeof console !== 'undefined' && console.warn) {\n //warn user if arguments are passed but the locale could not be set\n console.warn(\n 'Locale ' + key + ' not found. Did you forget to load it?'\n );\n }\n }\n }\n\n return globalLocale._abbr;\n }\n\n function defineLocale(name, config) {\n if (config !== null) {\n var locale,\n parentConfig = baseConfig;\n config.abbr = name;\n if (locales[name] != null) {\n deprecateSimple(\n 'defineLocaleOverride',\n 'use moment.updateLocale(localeName, config) to change ' +\n 'an existing locale. moment.defineLocale(localeName, ' +\n 'config) should only be used for creating a new locale ' +\n 'See http://momentjs.com/guides/#/warnings/define-locale/ for more info.'\n );\n parentConfig = locales[name]._config;\n } else if (config.parentLocale != null) {\n if (locales[config.parentLocale] != null) {\n parentConfig = locales[config.parentLocale]._config;\n } else {\n locale = loadLocale(config.parentLocale);\n if (locale != null) {\n parentConfig = locale._config;\n } else {\n if (!localeFamilies[config.parentLocale]) {\n localeFamilies[config.parentLocale] = [];\n }\n localeFamilies[config.parentLocale].push({\n name: name,\n config: config,\n });\n return null;\n }\n }\n }\n locales[name] = new Locale(mergeConfigs(parentConfig, config));\n\n if (localeFamilies[name]) {\n localeFamilies[name].forEach(function (x) {\n defineLocale(x.name, x.config);\n });\n }\n\n // backwards compat for now: also set the locale\n // make sure we set the locale AFTER all child locales have been\n // created, so we won't end up with the child locale set.\n getSetGlobalLocale(name);\n\n return locales[name];\n } else {\n // useful for testing\n delete locales[name];\n return null;\n }\n }\n\n function updateLocale(name, config) {\n if (config != null) {\n var locale,\n tmpLocale,\n parentConfig = baseConfig;\n\n if (locales[name] != null && locales[name].parentLocale != null) {\n // Update existing child locale in-place to avoid memory-leaks\n locales[name].set(mergeConfigs(locales[name]._config, config));\n } else {\n // MERGE\n tmpLocale = loadLocale(name);\n if (tmpLocale != null) {\n parentConfig = tmpLocale._config;\n }\n config = mergeConfigs(parentConfig, config);\n if (tmpLocale == null) {\n // updateLocale is called for creating a new locale\n // Set abbr so it will have a name (getters return\n // undefined otherwise).\n config.abbr = name;\n }\n locale = new Locale(config);\n locale.parentLocale = locales[name];\n locales[name] = locale;\n }\n\n // backwards compat for now: also set the locale\n getSetGlobalLocale(name);\n } else {\n // pass null for config to unupdate, useful for tests\n if (locales[name] != null) {\n if (locales[name].parentLocale != null) {\n locales[name] = locales[name].parentLocale;\n if (name === getSetGlobalLocale()) {\n getSetGlobalLocale(name);\n }\n } else if (locales[name] != null) {\n delete locales[name];\n }\n }\n }\n return locales[name];\n }\n\n // returns locale data\n function getLocale(key) {\n var locale;\n\n if (key && key._locale && key._locale._abbr) {\n key = key._locale._abbr;\n }\n\n if (!key) {\n return globalLocale;\n }\n\n if (!isArray(key)) {\n //short-circuit everything else\n locale = loadLocale(key);\n if (locale) {\n return locale;\n }\n key = [key];\n }\n\n return chooseLocale(key);\n }\n\n function listLocales() {\n return keys(locales);\n }\n\n function checkOverflow(m) {\n var overflow,\n a = m._a;\n\n if (a && getParsingFlags(m).overflow === -2) {\n overflow =\n a[MONTH] < 0 || a[MONTH] > 11\n ? MONTH\n : a[DATE] < 1 || a[DATE] > daysInMonth(a[YEAR], a[MONTH])\n ? DATE\n : a[HOUR] < 0 ||\n a[HOUR] > 24 ||\n (a[HOUR] === 24 &&\n (a[MINUTE] !== 0 ||\n a[SECOND] !== 0 ||\n a[MILLISECOND] !== 0))\n ? HOUR\n : a[MINUTE] < 0 || a[MINUTE] > 59\n ? MINUTE\n : a[SECOND] < 0 || a[SECOND] > 59\n ? SECOND\n : a[MILLISECOND] < 0 || a[MILLISECOND] > 999\n ? MILLISECOND\n : -1;\n\n if (\n getParsingFlags(m)._overflowDayOfYear &&\n (overflow < YEAR || overflow > DATE)\n ) {\n overflow = DATE;\n }\n if (getParsingFlags(m)._overflowWeeks && overflow === -1) {\n overflow = WEEK;\n }\n if (getParsingFlags(m)._overflowWeekday && overflow === -1) {\n overflow = WEEKDAY;\n }\n\n getParsingFlags(m).overflow = overflow;\n }\n\n return m;\n }\n\n // iso 8601 regex\n // 0000-00-00 0000-W00 or 0000-W00-0 + T + 00 or 00:00 or 00:00:00 or 00:00:00.000 + +00:00 or +0000 or +00)\n var extendedIsoRegex =\n /^\\s*((?:[+-]\\d{6}|\\d{4})-(?:\\d\\d-\\d\\d|W\\d\\d-\\d|W\\d\\d|\\d\\d\\d|\\d\\d))(?:(T| )(\\d\\d(?::\\d\\d(?::\\d\\d(?:[.,]\\d+)?)?)?)([+-]\\d\\d(?::?\\d\\d)?|\\s*Z)?)?$/,\n basicIsoRegex =\n /^\\s*((?:[+-]\\d{6}|\\d{4})(?:\\d\\d\\d\\d|W\\d\\d\\d|W\\d\\d|\\d\\d\\d|\\d\\d|))(?:(T| )(\\d\\d(?:\\d\\d(?:\\d\\d(?:[.,]\\d+)?)?)?)([+-]\\d\\d(?::?\\d\\d)?|\\s*Z)?)?$/,\n tzRegex = /Z|[+-]\\d\\d(?::?\\d\\d)?/,\n isoDates = [\n ['YYYYYY-MM-DD', /[+-]\\d{6}-\\d\\d-\\d\\d/],\n ['YYYY-MM-DD', /\\d{4}-\\d\\d-\\d\\d/],\n ['GGGG-[W]WW-E', /\\d{4}-W\\d\\d-\\d/],\n ['GGGG-[W]WW', /\\d{4}-W\\d\\d/, false],\n ['YYYY-DDD', /\\d{4}-\\d{3}/],\n ['YYYY-MM', /\\d{4}-\\d\\d/, false],\n ['YYYYYYMMDD', /[+-]\\d{10}/],\n ['YYYYMMDD', /\\d{8}/],\n ['GGGG[W]WWE', /\\d{4}W\\d{3}/],\n ['GGGG[W]WW', /\\d{4}W\\d{2}/, false],\n ['YYYYDDD', /\\d{7}/],\n ['YYYYMM', /\\d{6}/, false],\n ['YYYY', /\\d{4}/, false],\n ],\n // iso time formats and regexes\n isoTimes = [\n ['HH:mm:ss.SSSS', /\\d\\d:\\d\\d:\\d\\d\\.\\d+/],\n ['HH:mm:ss,SSSS', /\\d\\d:\\d\\d:\\d\\d,\\d+/],\n ['HH:mm:ss', /\\d\\d:\\d\\d:\\d\\d/],\n ['HH:mm', /\\d\\d:\\d\\d/],\n ['HHmmss.SSSS', /\\d\\d\\d\\d\\d\\d\\.\\d+/],\n ['HHmmss,SSSS', /\\d\\d\\d\\d\\d\\d,\\d+/],\n ['HHmmss', /\\d\\d\\d\\d\\d\\d/],\n ['HHmm', /\\d\\d\\d\\d/],\n ['HH', /\\d\\d/],\n ],\n aspNetJsonRegex = /^\\/?Date\\((-?\\d+)/i,\n // RFC 2822 regex: For details see https://tools.ietf.org/html/rfc2822#section-3.3\n rfc2822 =\n /^(?:(Mon|Tue|Wed|Thu|Fri|Sat|Sun),?\\s)?(\\d{1,2})\\s(Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)\\s(\\d{2,4})\\s(\\d\\d):(\\d\\d)(?::(\\d\\d))?\\s(?:(UT|GMT|[ECMP][SD]T)|([Zz])|([+-]\\d{4}))$/,\n obsOffsets = {\n UT: 0,\n GMT: 0,\n EDT: -4 * 60,\n EST: -5 * 60,\n CDT: -5 * 60,\n CST: -6 * 60,\n MDT: -6 * 60,\n MST: -7 * 60,\n PDT: -7 * 60,\n PST: -8 * 60,\n };\n\n // date from iso format\n function configFromISO(config) {\n var i,\n l,\n string = config._i,\n match = extendedIsoRegex.exec(string) || basicIsoRegex.exec(string),\n allowTime,\n dateFormat,\n timeFormat,\n tzFormat,\n isoDatesLen = isoDates.length,\n isoTimesLen = isoTimes.length;\n\n if (match) {\n getParsingFlags(config).iso = true;\n for (i = 0, l = isoDatesLen; i < l; i++) {\n if (isoDates[i][1].exec(match[1])) {\n dateFormat = isoDates[i][0];\n allowTime = isoDates[i][2] !== false;\n break;\n }\n }\n if (dateFormat == null) {\n config._isValid = false;\n return;\n }\n if (match[3]) {\n for (i = 0, l = isoTimesLen; i < l; i++) {\n if (isoTimes[i][1].exec(match[3])) {\n // match[2] should be 'T' or space\n timeFormat = (match[2] || ' ') + isoTimes[i][0];\n break;\n }\n }\n if (timeFormat == null) {\n config._isValid = false;\n return;\n }\n }\n if (!allowTime && timeFormat != null) {\n config._isValid = false;\n return;\n }\n if (match[4]) {\n if (tzRegex.exec(match[4])) {\n tzFormat = 'Z';\n } else {\n config._isValid = false;\n return;\n }\n }\n config._f = dateFormat + (timeFormat || '') + (tzFormat || '');\n configFromStringAndFormat(config);\n } else {\n config._isValid = false;\n }\n }\n\n function extractFromRFC2822Strings(\n yearStr,\n monthStr,\n dayStr,\n hourStr,\n minuteStr,\n secondStr\n ) {\n var result = [\n untruncateYear(yearStr),\n defaultLocaleMonthsShort.indexOf(monthStr),\n parseInt(dayStr, 10),\n parseInt(hourStr, 10),\n parseInt(minuteStr, 10),\n ];\n\n if (secondStr) {\n result.push(parseInt(secondStr, 10));\n }\n\n return result;\n }\n\n function untruncateYear(yearStr) {\n var year = parseInt(yearStr, 10);\n if (year <= 49) {\n return 2000 + year;\n } else if (year <= 999) {\n return 1900 + year;\n }\n return year;\n }\n\n function preprocessRFC2822(s) {\n // Remove comments and folding whitespace and replace multiple-spaces with a single space\n return s\n .replace(/\\([^()]*\\)|[\\n\\t]/g, ' ')\n .replace(/(\\s\\s+)/g, ' ')\n .replace(/^\\s\\s*/, '')\n .replace(/\\s\\s*$/, '');\n }\n\n function checkWeekday(weekdayStr, parsedInput, config) {\n if (weekdayStr) {\n // TODO: Replace the vanilla JS Date object with an independent day-of-week check.\n var weekdayProvided = defaultLocaleWeekdaysShort.indexOf(weekdayStr),\n weekdayActual = new Date(\n parsedInput[0],\n parsedInput[1],\n parsedInput[2]\n ).getDay();\n if (weekdayProvided !== weekdayActual) {\n getParsingFlags(config).weekdayMismatch = true;\n config._isValid = false;\n return false;\n }\n }\n return true;\n }\n\n function calculateOffset(obsOffset, militaryOffset, numOffset) {\n if (obsOffset) {\n return obsOffsets[obsOffset];\n } else if (militaryOffset) {\n // the only allowed military tz is Z\n return 0;\n } else {\n var hm = parseInt(numOffset, 10),\n m = hm % 100,\n h = (hm - m) / 100;\n return h * 60 + m;\n }\n }\n\n // date and time from ref 2822 format\n function configFromRFC2822(config) {\n var match = rfc2822.exec(preprocessRFC2822(config._i)),\n parsedArray;\n if (match) {\n parsedArray = extractFromRFC2822Strings(\n match[4],\n match[3],\n match[2],\n match[5],\n match[6],\n match[7]\n );\n if (!checkWeekday(match[1], parsedArray, config)) {\n return;\n }\n\n config._a = parsedArray;\n config._tzm = calculateOffset(match[8], match[9], match[10]);\n\n config._d = createUTCDate.apply(null, config._a);\n config._d.setUTCMinutes(config._d.getUTCMinutes() - config._tzm);\n\n getParsingFlags(config).rfc2822 = true;\n } else {\n config._isValid = false;\n }\n }\n\n // date from 1) ASP.NET, 2) ISO, 3) RFC 2822 formats, or 4) optional fallback if parsing isn't strict\n function configFromString(config) {\n var matched = aspNetJsonRegex.exec(config._i);\n if (matched !== null) {\n config._d = new Date(+matched[1]);\n return;\n }\n\n configFromISO(config);\n if (config._isValid === false) {\n delete config._isValid;\n } else {\n return;\n }\n\n configFromRFC2822(config);\n if (config._isValid === false) {\n delete config._isValid;\n } else {\n return;\n }\n\n if (config._strict) {\n config._isValid = false;\n } else {\n // Final attempt, use Input Fallback\n hooks.createFromInputFallback(config);\n }\n }\n\n hooks.createFromInputFallback = deprecate(\n 'value provided is not in a recognized RFC2822 or ISO format. moment construction falls back to js Date(), ' +\n 'which is not reliable across all browsers and versions. Non RFC2822/ISO date formats are ' +\n 'discouraged. Please refer to http://momentjs.com/guides/#/warnings/js-date/ for more info.',\n function (config) {\n config._d = new Date(config._i + (config._useUTC ? ' UTC' : ''));\n }\n );\n\n // Pick the first defined of two or three arguments.\n function defaults(a, b, c) {\n if (a != null) {\n return a;\n }\n if (b != null) {\n return b;\n }\n return c;\n }\n\n function currentDateArray(config) {\n // hooks is actually the exported moment object\n var nowValue = new Date(hooks.now());\n if (config._useUTC) {\n return [\n nowValue.getUTCFullYear(),\n nowValue.getUTCMonth(),\n nowValue.getUTCDate(),\n ];\n }\n return [nowValue.getFullYear(), nowValue.getMonth(), nowValue.getDate()];\n }\n\n // convert an array to a date.\n // the array should mirror the parameters below\n // note: all values past the year are optional and will default to the lowest possible value.\n // [year, month, day , hour, minute, second, millisecond]\n function configFromArray(config) {\n var i,\n date,\n input = [],\n currentDate,\n expectedWeekday,\n yearToUse;\n\n if (config._d) {\n return;\n }\n\n currentDate = currentDateArray(config);\n\n //compute day of the year from weeks and weekdays\n if (config._w && config._a[DATE] == null && config._a[MONTH] == null) {\n dayOfYearFromWeekInfo(config);\n }\n\n //if the day of the year is set, figure out what it is\n if (config._dayOfYear != null) {\n yearToUse = defaults(config._a[YEAR], currentDate[YEAR]);\n\n if (\n config._dayOfYear > daysInYear(yearToUse) ||\n config._dayOfYear === 0\n ) {\n getParsingFlags(config)._overflowDayOfYear = true;\n }\n\n date = createUTCDate(yearToUse, 0, config._dayOfYear);\n config._a[MONTH] = date.getUTCMonth();\n config._a[DATE] = date.getUTCDate();\n }\n\n // Default to current date.\n // * if no year, month, day of month are given, default to today\n // * if day of month is given, default month and year\n // * if month is given, default only year\n // * if year is given, don't default anything\n for (i = 0; i < 3 && config._a[i] == null; ++i) {\n config._a[i] = input[i] = currentDate[i];\n }\n\n // Zero out whatever was not defaulted, including time\n for (; i < 7; i++) {\n config._a[i] = input[i] =\n config._a[i] == null ? (i === 2 ? 1 : 0) : config._a[i];\n }\n\n // Check for 24:00:00.000\n if (\n config._a[HOUR] === 24 &&\n config._a[MINUTE] === 0 &&\n config._a[SECOND] === 0 &&\n config._a[MILLISECOND] === 0\n ) {\n config._nextDay = true;\n config._a[HOUR] = 0;\n }\n\n config._d = (config._useUTC ? createUTCDate : createDate).apply(\n null,\n input\n );\n expectedWeekday = config._useUTC\n ? config._d.getUTCDay()\n : config._d.getDay();\n\n // Apply timezone offset from input. The actual utcOffset can be changed\n // with parseZone.\n if (config._tzm != null) {\n config._d.setUTCMinutes(config._d.getUTCMinutes() - config._tzm);\n }\n\n if (config._nextDay) {\n config._a[HOUR] = 24;\n }\n\n // check for mismatching day of week\n if (\n config._w &&\n typeof config._w.d !== 'undefined' &&\n config._w.d !== expectedWeekday\n ) {\n getParsingFlags(config).weekdayMismatch = true;\n }\n }\n\n function dayOfYearFromWeekInfo(config) {\n var w, weekYear, week, weekday, dow, doy, temp, weekdayOverflow, curWeek;\n\n w = config._w;\n if (w.GG != null || w.W != null || w.E != null) {\n dow = 1;\n doy = 4;\n\n // TODO: We need to take the current isoWeekYear, but that depends on\n // how we interpret now (local, utc, fixed offset). So create\n // a now version of current config (take local/utc/offset flags, and\n // create now).\n weekYear = defaults(\n w.GG,\n config._a[YEAR],\n weekOfYear(createLocal(), 1, 4).year\n );\n week = defaults(w.W, 1);\n weekday = defaults(w.E, 1);\n if (weekday < 1 || weekday > 7) {\n weekdayOverflow = true;\n }\n } else {\n dow = config._locale._week.dow;\n doy = config._locale._week.doy;\n\n curWeek = weekOfYear(createLocal(), dow, doy);\n\n weekYear = defaults(w.gg, config._a[YEAR], curWeek.year);\n\n // Default to current week.\n week = defaults(w.w, curWeek.week);\n\n if (w.d != null) {\n // weekday -- low day numbers are considered next week\n weekday = w.d;\n if (weekday < 0 || weekday > 6) {\n weekdayOverflow = true;\n }\n } else if (w.e != null) {\n // local weekday -- counting starts from beginning of week\n weekday = w.e + dow;\n if (w.e < 0 || w.e > 6) {\n weekdayOverflow = true;\n }\n } else {\n // default to beginning of week\n weekday = dow;\n }\n }\n if (week < 1 || week > weeksInYear(weekYear, dow, doy)) {\n getParsingFlags(config)._overflowWeeks = true;\n } else if (weekdayOverflow != null) {\n getParsingFlags(config)._overflowWeekday = true;\n } else {\n temp = dayOfYearFromWeeks(weekYear, week, weekday, dow, doy);\n config._a[YEAR] = temp.year;\n config._dayOfYear = temp.dayOfYear;\n }\n }\n\n // constant that refers to the ISO standard\n hooks.ISO_8601 = function () {};\n\n // constant that refers to the RFC 2822 form\n hooks.RFC_2822 = function () {};\n\n // date from string and format string\n function configFromStringAndFormat(config) {\n // TODO: Move this to another part of the creation flow to prevent circular deps\n if (config._f === hooks.ISO_8601) {\n configFromISO(config);\n return;\n }\n if (config._f === hooks.RFC_2822) {\n configFromRFC2822(config);\n return;\n }\n config._a = [];\n getParsingFlags(config).empty = true;\n\n // This array is used to make a Date, either with `new Date` or `Date.UTC`\n var string = '' + config._i,\n i,\n parsedInput,\n tokens,\n token,\n skipped,\n stringLength = string.length,\n totalParsedInputLength = 0,\n era,\n tokenLen;\n\n tokens =\n expandFormat(config._f, config._locale).match(formattingTokens) || [];\n tokenLen = tokens.length;\n for (i = 0; i < tokenLen; i++) {\n token = tokens[i];\n parsedInput = (string.match(getParseRegexForToken(token, config)) ||\n [])[0];\n if (parsedInput) {\n skipped = string.substr(0, string.indexOf(parsedInput));\n if (skipped.length > 0) {\n getParsingFlags(config).unusedInput.push(skipped);\n }\n string = string.slice(\n string.indexOf(parsedInput) + parsedInput.length\n );\n totalParsedInputLength += parsedInput.length;\n }\n // don't parse if it's not a known token\n if (formatTokenFunctions[token]) {\n if (parsedInput) {\n getParsingFlags(config).empty = false;\n } else {\n getParsingFlags(config).unusedTokens.push(token);\n }\n addTimeToArrayFromToken(token, parsedInput, config);\n } else if (config._strict && !parsedInput) {\n getParsingFlags(config).unusedTokens.push(token);\n }\n }\n\n // add remaining unparsed input length to the string\n getParsingFlags(config).charsLeftOver =\n stringLength - totalParsedInputLength;\n if (string.length > 0) {\n getParsingFlags(config).unusedInput.push(string);\n }\n\n // clear _12h flag if hour is <= 12\n if (\n config._a[HOUR] <= 12 &&\n getParsingFlags(config).bigHour === true &&\n config._a[HOUR] > 0\n ) {\n getParsingFlags(config).bigHour = undefined;\n }\n\n getParsingFlags(config).parsedDateParts = config._a.slice(0);\n getParsingFlags(config).meridiem = config._meridiem;\n // handle meridiem\n config._a[HOUR] = meridiemFixWrap(\n config._locale,\n config._a[HOUR],\n config._meridiem\n );\n\n // handle era\n era = getParsingFlags(config).era;\n if (era !== null) {\n config._a[YEAR] = config._locale.erasConvertYear(era, config._a[YEAR]);\n }\n\n configFromArray(config);\n checkOverflow(config);\n }\n\n function meridiemFixWrap(locale, hour, meridiem) {\n var isPm;\n\n if (meridiem == null) {\n // nothing to do\n return hour;\n }\n if (locale.meridiemHour != null) {\n return locale.meridiemHour(hour, meridiem);\n } else if (locale.isPM != null) {\n // Fallback\n isPm = locale.isPM(meridiem);\n if (isPm && hour < 12) {\n hour += 12;\n }\n if (!isPm && hour === 12) {\n hour = 0;\n }\n return hour;\n } else {\n // this is not supposed to happen\n return hour;\n }\n }\n\n // date from string and array of format strings\n function configFromStringAndArray(config) {\n var tempConfig,\n bestMoment,\n scoreToBeat,\n i,\n currentScore,\n validFormatFound,\n bestFormatIsValid = false,\n configfLen = config._f.length;\n\n if (configfLen === 0) {\n getParsingFlags(config).invalidFormat = true;\n config._d = new Date(NaN);\n return;\n }\n\n for (i = 0; i < configfLen; i++) {\n currentScore = 0;\n validFormatFound = false;\n tempConfig = copyConfig({}, config);\n if (config._useUTC != null) {\n tempConfig._useUTC = config._useUTC;\n }\n tempConfig._f = config._f[i];\n configFromStringAndFormat(tempConfig);\n\n if (isValid(tempConfig)) {\n validFormatFound = true;\n }\n\n // if there is any input that was not parsed add a penalty for that format\n currentScore += getParsingFlags(tempConfig).charsLeftOver;\n\n //or tokens\n currentScore += getParsingFlags(tempConfig).unusedTokens.length * 10;\n\n getParsingFlags(tempConfig).score = currentScore;\n\n if (!bestFormatIsValid) {\n if (\n scoreToBeat == null ||\n currentScore < scoreToBeat ||\n validFormatFound\n ) {\n scoreToBeat = currentScore;\n bestMoment = tempConfig;\n if (validFormatFound) {\n bestFormatIsValid = true;\n }\n }\n } else {\n if (currentScore < scoreToBeat) {\n scoreToBeat = currentScore;\n bestMoment = tempConfig;\n }\n }\n }\n\n extend(config, bestMoment || tempConfig);\n }\n\n function configFromObject(config) {\n if (config._d) {\n return;\n }\n\n var i = normalizeObjectUnits(config._i),\n dayOrDate = i.day === undefined ? i.date : i.day;\n config._a = map(\n [i.year, i.month, dayOrDate, i.hour, i.minute, i.second, i.millisecond],\n function (obj) {\n return obj && parseInt(obj, 10);\n }\n );\n\n configFromArray(config);\n }\n\n function createFromConfig(config) {\n var res = new Moment(checkOverflow(prepareConfig(config)));\n if (res._nextDay) {\n // Adding is smart enough around DST\n res.add(1, 'd');\n res._nextDay = undefined;\n }\n\n return res;\n }\n\n function prepareConfig(config) {\n var input = config._i,\n format = config._f;\n\n config._locale = config._locale || getLocale(config._l);\n\n if (input === null || (format === undefined && input === '')) {\n return createInvalid({ nullInput: true });\n }\n\n if (typeof input === 'string') {\n config._i = input = config._locale.preparse(input);\n }\n\n if (isMoment(input)) {\n return new Moment(checkOverflow(input));\n } else if (isDate(input)) {\n config._d = input;\n } else if (isArray(format)) {\n configFromStringAndArray(config);\n } else if (format) {\n configFromStringAndFormat(config);\n } else {\n configFromInput(config);\n }\n\n if (!isValid(config)) {\n config._d = null;\n }\n\n return config;\n }\n\n function configFromInput(config) {\n var input = config._i;\n if (isUndefined(input)) {\n config._d = new Date(hooks.now());\n } else if (isDate(input)) {\n config._d = new Date(input.valueOf());\n } else if (typeof input === 'string') {\n configFromString(config);\n } else if (isArray(input)) {\n config._a = map(input.slice(0), function (obj) {\n return parseInt(obj, 10);\n });\n configFromArray(config);\n } else if (isObject(input)) {\n configFromObject(config);\n } else if (isNumber(input)) {\n // from milliseconds\n config._d = new Date(input);\n } else {\n hooks.createFromInputFallback(config);\n }\n }\n\n function createLocalOrUTC(input, format, locale, strict, isUTC) {\n var c = {};\n\n if (format === true || format === false) {\n strict = format;\n format = undefined;\n }\n\n if (locale === true || locale === false) {\n strict = locale;\n locale = undefined;\n }\n\n if (\n (isObject(input) && isObjectEmpty(input)) ||\n (isArray(input) && input.length === 0)\n ) {\n input = undefined;\n }\n // object construction must be done this way.\n // https://github.com/moment/moment/issues/1423\n c._isAMomentObject = true;\n c._useUTC = c._isUTC = isUTC;\n c._l = locale;\n c._i = input;\n c._f = format;\n c._strict = strict;\n\n return createFromConfig(c);\n }\n\n function createLocal(input, format, locale, strict) {\n return createLocalOrUTC(input, format, locale, strict, false);\n }\n\n var prototypeMin = deprecate(\n 'moment().min is deprecated, use moment.max instead. http://momentjs.com/guides/#/warnings/min-max/',\n function () {\n var other = createLocal.apply(null, arguments);\n if (this.isValid() && other.isValid()) {\n return other < this ? this : other;\n } else {\n return createInvalid();\n }\n }\n ),\n prototypeMax = deprecate(\n 'moment().max is deprecated, use moment.min instead. http://momentjs.com/guides/#/warnings/min-max/',\n function () {\n var other = createLocal.apply(null, arguments);\n if (this.isValid() && other.isValid()) {\n return other > this ? this : other;\n } else {\n return createInvalid();\n }\n }\n );\n\n // Pick a moment m from moments so that m[fn](other) is true for all\n // other. This relies on the function fn to be transitive.\n //\n // moments should either be an array of moment objects or an array, whose\n // first element is an array of moment objects.\n function pickBy(fn, moments) {\n var res, i;\n if (moments.length === 1 && isArray(moments[0])) {\n moments = moments[0];\n }\n if (!moments.length) {\n return createLocal();\n }\n res = moments[0];\n for (i = 1; i < moments.length; ++i) {\n if (!moments[i].isValid() || moments[i][fn](res)) {\n res = moments[i];\n }\n }\n return res;\n }\n\n // TODO: Use [].sort instead?\n function min() {\n var args = [].slice.call(arguments, 0);\n\n return pickBy('isBefore', args);\n }\n\n function max() {\n var args = [].slice.call(arguments, 0);\n\n return pickBy('isAfter', args);\n }\n\n var now = function () {\n return Date.now ? Date.now() : +new Date();\n };\n\n var ordering = [\n 'year',\n 'quarter',\n 'month',\n 'week',\n 'day',\n 'hour',\n 'minute',\n 'second',\n 'millisecond',\n ];\n\n function isDurationValid(m) {\n var key,\n unitHasDecimal = false,\n i,\n orderLen = ordering.length;\n for (key in m) {\n if (\n hasOwnProp(m, key) &&\n !(\n indexOf.call(ordering, key) !== -1 &&\n (m[key] == null || !isNaN(m[key]))\n )\n ) {\n return false;\n }\n }\n\n for (i = 0; i < orderLen; ++i) {\n if (m[ordering[i]]) {\n if (unitHasDecimal) {\n return false; // only allow non-integers for smallest unit\n }\n if (parseFloat(m[ordering[i]]) !== toInt(m[ordering[i]])) {\n unitHasDecimal = true;\n }\n }\n }\n\n return true;\n }\n\n function isValid$1() {\n return this._isValid;\n }\n\n function createInvalid$1() {\n return createDuration(NaN);\n }\n\n function Duration(duration) {\n var normalizedInput = normalizeObjectUnits(duration),\n years = normalizedInput.year || 0,\n quarters = normalizedInput.quarter || 0,\n months = normalizedInput.month || 0,\n weeks = normalizedInput.week || normalizedInput.isoWeek || 0,\n days = normalizedInput.day || 0,\n hours = normalizedInput.hour || 0,\n minutes = normalizedInput.minute || 0,\n seconds = normalizedInput.second || 0,\n milliseconds = normalizedInput.millisecond || 0;\n\n this._isValid = isDurationValid(normalizedInput);\n\n // representation for dateAddRemove\n this._milliseconds =\n +milliseconds +\n seconds * 1e3 + // 1000\n minutes * 6e4 + // 1000 * 60\n hours * 1000 * 60 * 60; //using 1000 * 60 * 60 instead of 36e5 to avoid floating point rounding errors https://github.com/moment/moment/issues/2978\n // Because of dateAddRemove treats 24 hours as different from a\n // day when working around DST, we need to store them separately\n this._days = +days + weeks * 7;\n // It is impossible to translate months into days without knowing\n // which months you are are talking about, so we have to store\n // it separately.\n this._months = +months + quarters * 3 + years * 12;\n\n this._data = {};\n\n this._locale = getLocale();\n\n this._bubble();\n }\n\n function isDuration(obj) {\n return obj instanceof Duration;\n }\n\n function absRound(number) {\n if (number < 0) {\n return Math.round(-1 * number) * -1;\n } else {\n return Math.round(number);\n }\n }\n\n // compare two arrays, return the number of differences\n function compareArrays(array1, array2, dontConvert) {\n var len = Math.min(array1.length, array2.length),\n lengthDiff = Math.abs(array1.length - array2.length),\n diffs = 0,\n i;\n for (i = 0; i < len; i++) {\n if (\n (dontConvert && array1[i] !== array2[i]) ||\n (!dontConvert && toInt(array1[i]) !== toInt(array2[i]))\n ) {\n diffs++;\n }\n }\n return diffs + lengthDiff;\n }\n\n // FORMATTING\n\n function offset(token, separator) {\n addFormatToken(token, 0, 0, function () {\n var offset = this.utcOffset(),\n sign = '+';\n if (offset < 0) {\n offset = -offset;\n sign = '-';\n }\n return (\n sign +\n zeroFill(~~(offset / 60), 2) +\n separator +\n zeroFill(~~offset % 60, 2)\n );\n });\n }\n\n offset('Z', ':');\n offset('ZZ', '');\n\n // PARSING\n\n addRegexToken('Z', matchShortOffset);\n addRegexToken('ZZ', matchShortOffset);\n addParseToken(['Z', 'ZZ'], function (input, array, config) {\n config._useUTC = true;\n config._tzm = offsetFromString(matchShortOffset, input);\n });\n\n // HELPERS\n\n // timezone chunker\n // '+10:00' > ['10', '00']\n // '-1530' > ['-15', '30']\n var chunkOffset = /([\\+\\-]|\\d\\d)/gi;\n\n function offsetFromString(matcher, string) {\n var matches = (string || '').match(matcher),\n chunk,\n parts,\n minutes;\n\n if (matches === null) {\n return null;\n }\n\n chunk = matches[matches.length - 1] || [];\n parts = (chunk + '').match(chunkOffset) || ['-', 0, 0];\n minutes = +(parts[1] * 60) + toInt(parts[2]);\n\n return minutes === 0 ? 0 : parts[0] === '+' ? minutes : -minutes;\n }\n\n // Return a moment from input, that is local/utc/zone equivalent to model.\n function cloneWithOffset(input, model) {\n var res, diff;\n if (model._isUTC) {\n res = model.clone();\n diff =\n (isMoment(input) || isDate(input)\n ? input.valueOf()\n : createLocal(input).valueOf()) - res.valueOf();\n // Use low-level api, because this fn is low-level api.\n res._d.setTime(res._d.valueOf() + diff);\n hooks.updateOffset(res, false);\n return res;\n } else {\n return createLocal(input).local();\n }\n }\n\n function getDateOffset(m) {\n // On Firefox.24 Date#getTimezoneOffset returns a floating point.\n // https://github.com/moment/moment/pull/1871\n return -Math.round(m._d.getTimezoneOffset());\n }\n\n // HOOKS\n\n // This function will be called whenever a moment is mutated.\n // It is intended to keep the offset in sync with the timezone.\n hooks.updateOffset = function () {};\n\n // MOMENTS\n\n // keepLocalTime = true means only change the timezone, without\n // affecting the local hour. So 5:31:26 +0300 --[utcOffset(2, true)]-->\n // 5:31:26 +0200 It is possible that 5:31:26 doesn't exist with offset\n // +0200, so we adjust the time as needed, to be valid.\n //\n // Keeping the time actually adds/subtracts (one hour)\n // from the actual represented time. That is why we call updateOffset\n // a second time. In case it wants us to change the offset again\n // _changeInProgress == true case, then we have to adjust, because\n // there is no such time in the given timezone.\n function getSetOffset(input, keepLocalTime, keepMinutes) {\n var offset = this._offset || 0,\n localAdjust;\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n if (input != null) {\n if (typeof input === 'string') {\n input = offsetFromString(matchShortOffset, input);\n if (input === null) {\n return this;\n }\n } else if (Math.abs(input) < 16 && !keepMinutes) {\n input = input * 60;\n }\n if (!this._isUTC && keepLocalTime) {\n localAdjust = getDateOffset(this);\n }\n this._offset = input;\n this._isUTC = true;\n if (localAdjust != null) {\n this.add(localAdjust, 'm');\n }\n if (offset !== input) {\n if (!keepLocalTime || this._changeInProgress) {\n addSubtract(\n this,\n createDuration(input - offset, 'm'),\n 1,\n false\n );\n } else if (!this._changeInProgress) {\n this._changeInProgress = true;\n hooks.updateOffset(this, true);\n this._changeInProgress = null;\n }\n }\n return this;\n } else {\n return this._isUTC ? offset : getDateOffset(this);\n }\n }\n\n function getSetZone(input, keepLocalTime) {\n if (input != null) {\n if (typeof input !== 'string') {\n input = -input;\n }\n\n this.utcOffset(input, keepLocalTime);\n\n return this;\n } else {\n return -this.utcOffset();\n }\n }\n\n function setOffsetToUTC(keepLocalTime) {\n return this.utcOffset(0, keepLocalTime);\n }\n\n function setOffsetToLocal(keepLocalTime) {\n if (this._isUTC) {\n this.utcOffset(0, keepLocalTime);\n this._isUTC = false;\n\n if (keepLocalTime) {\n this.subtract(getDateOffset(this), 'm');\n }\n }\n return this;\n }\n\n function setOffsetToParsedOffset() {\n if (this._tzm != null) {\n this.utcOffset(this._tzm, false, true);\n } else if (typeof this._i === 'string') {\n var tZone = offsetFromString(matchOffset, this._i);\n if (tZone != null) {\n this.utcOffset(tZone);\n } else {\n this.utcOffset(0, true);\n }\n }\n return this;\n }\n\n function hasAlignedHourOffset(input) {\n if (!this.isValid()) {\n return false;\n }\n input = input ? createLocal(input).utcOffset() : 0;\n\n return (this.utcOffset() - input) % 60 === 0;\n }\n\n function isDaylightSavingTime() {\n return (\n this.utcOffset() > this.clone().month(0).utcOffset() ||\n this.utcOffset() > this.clone().month(5).utcOffset()\n );\n }\n\n function isDaylightSavingTimeShifted() {\n if (!isUndefined(this._isDSTShifted)) {\n return this._isDSTShifted;\n }\n\n var c = {},\n other;\n\n copyConfig(c, this);\n c = prepareConfig(c);\n\n if (c._a) {\n other = c._isUTC ? createUTC(c._a) : createLocal(c._a);\n this._isDSTShifted =\n this.isValid() && compareArrays(c._a, other.toArray()) > 0;\n } else {\n this._isDSTShifted = false;\n }\n\n return this._isDSTShifted;\n }\n\n function isLocal() {\n return this.isValid() ? !this._isUTC : false;\n }\n\n function isUtcOffset() {\n return this.isValid() ? this._isUTC : false;\n }\n\n function isUtc() {\n return this.isValid() ? this._isUTC && this._offset === 0 : false;\n }\n\n // ASP.NET json date format regex\n var aspNetRegex = /^(-|\\+)?(?:(\\d*)[. ])?(\\d+):(\\d+)(?::(\\d+)(\\.\\d*)?)?$/,\n // from http://docs.closure-library.googlecode.com/git/closure_goog_date_date.js.source.html\n // somewhat more in line with 4.4.3.2 2004 spec, but allows decimal anywhere\n // and further modified to allow for strings containing both week and day\n isoRegex =\n /^(-|\\+)?P(?:([-+]?[0-9,.]*)Y)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)W)?(?:([-+]?[0-9,.]*)D)?(?:T(?:([-+]?[0-9,.]*)H)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)S)?)?$/;\n\n function createDuration(input, key) {\n var duration = input,\n // matching against regexp is expensive, do it on demand\n match = null,\n sign,\n ret,\n diffRes;\n\n if (isDuration(input)) {\n duration = {\n ms: input._milliseconds,\n d: input._days,\n M: input._months,\n };\n } else if (isNumber(input) || !isNaN(+input)) {\n duration = {};\n if (key) {\n duration[key] = +input;\n } else {\n duration.milliseconds = +input;\n }\n } else if ((match = aspNetRegex.exec(input))) {\n sign = match[1] === '-' ? -1 : 1;\n duration = {\n y: 0,\n d: toInt(match[DATE]) * sign,\n h: toInt(match[HOUR]) * sign,\n m: toInt(match[MINUTE]) * sign,\n s: toInt(match[SECOND]) * sign,\n ms: toInt(absRound(match[MILLISECOND] * 1000)) * sign, // the millisecond decimal point is included in the match\n };\n } else if ((match = isoRegex.exec(input))) {\n sign = match[1] === '-' ? -1 : 1;\n duration = {\n y: parseIso(match[2], sign),\n M: parseIso(match[3], sign),\n w: parseIso(match[4], sign),\n d: parseIso(match[5], sign),\n h: parseIso(match[6], sign),\n m: parseIso(match[7], sign),\n s: parseIso(match[8], sign),\n };\n } else if (duration == null) {\n // checks for null or undefined\n duration = {};\n } else if (\n typeof duration === 'object' &&\n ('from' in duration || 'to' in duration)\n ) {\n diffRes = momentsDifference(\n createLocal(duration.from),\n createLocal(duration.to)\n );\n\n duration = {};\n duration.ms = diffRes.milliseconds;\n duration.M = diffRes.months;\n }\n\n ret = new Duration(duration);\n\n if (isDuration(input) && hasOwnProp(input, '_locale')) {\n ret._locale = input._locale;\n }\n\n if (isDuration(input) && hasOwnProp(input, '_isValid')) {\n ret._isValid = input._isValid;\n }\n\n return ret;\n }\n\n createDuration.fn = Duration.prototype;\n createDuration.invalid = createInvalid$1;\n\n function parseIso(inp, sign) {\n // We'd normally use ~~inp for this, but unfortunately it also\n // converts floats to ints.\n // inp may be undefined, so careful calling replace on it.\n var res = inp && parseFloat(inp.replace(',', '.'));\n // apply sign while we're at it\n return (isNaN(res) ? 0 : res) * sign;\n }\n\n function positiveMomentsDifference(base, other) {\n var res = {};\n\n res.months =\n other.month() - base.month() + (other.year() - base.year()) * 12;\n if (base.clone().add(res.months, 'M').isAfter(other)) {\n --res.months;\n }\n\n res.milliseconds = +other - +base.clone().add(res.months, 'M');\n\n return res;\n }\n\n function momentsDifference(base, other) {\n var res;\n if (!(base.isValid() && other.isValid())) {\n return { milliseconds: 0, months: 0 };\n }\n\n other = cloneWithOffset(other, base);\n if (base.isBefore(other)) {\n res = positiveMomentsDifference(base, other);\n } else {\n res = positiveMomentsDifference(other, base);\n res.milliseconds = -res.milliseconds;\n res.months = -res.months;\n }\n\n return res;\n }\n\n // TODO: remove 'name' arg after deprecation is removed\n function createAdder(direction, name) {\n return function (val, period) {\n var dur, tmp;\n //invert the arguments, but complain about it\n if (period !== null && !isNaN(+period)) {\n deprecateSimple(\n name,\n 'moment().' +\n name +\n '(period, number) is deprecated. Please use moment().' +\n name +\n '(number, period). ' +\n 'See http://momentjs.com/guides/#/warnings/add-inverted-param/ for more info.'\n );\n tmp = val;\n val = period;\n period = tmp;\n }\n\n dur = createDuration(val, period);\n addSubtract(this, dur, direction);\n return this;\n };\n }\n\n function addSubtract(mom, duration, isAdding, updateOffset) {\n var milliseconds = duration._milliseconds,\n days = absRound(duration._days),\n months = absRound(duration._months);\n\n if (!mom.isValid()) {\n // No op\n return;\n }\n\n updateOffset = updateOffset == null ? true : updateOffset;\n\n if (months) {\n setMonth(mom, get(mom, 'Month') + months * isAdding);\n }\n if (days) {\n set$1(mom, 'Date', get(mom, 'Date') + days * isAdding);\n }\n if (milliseconds) {\n mom._d.setTime(mom._d.valueOf() + milliseconds * isAdding);\n }\n if (updateOffset) {\n hooks.updateOffset(mom, days || months);\n }\n }\n\n var add = createAdder(1, 'add'),\n subtract = createAdder(-1, 'subtract');\n\n function isString(input) {\n return typeof input === 'string' || input instanceof String;\n }\n\n // type MomentInput = Moment | Date | string | number | (number | string)[] | MomentInputObject | void; // null | undefined\n function isMomentInput(input) {\n return (\n isMoment(input) ||\n isDate(input) ||\n isString(input) ||\n isNumber(input) ||\n isNumberOrStringArray(input) ||\n isMomentInputObject(input) ||\n input === null ||\n input === undefined\n );\n }\n\n function isMomentInputObject(input) {\n var objectTest = isObject(input) && !isObjectEmpty(input),\n propertyTest = false,\n properties = [\n 'years',\n 'year',\n 'y',\n 'months',\n 'month',\n 'M',\n 'days',\n 'day',\n 'd',\n 'dates',\n 'date',\n 'D',\n 'hours',\n 'hour',\n 'h',\n 'minutes',\n 'minute',\n 'm',\n 'seconds',\n 'second',\n 's',\n 'milliseconds',\n 'millisecond',\n 'ms',\n ],\n i,\n property,\n propertyLen = properties.length;\n\n for (i = 0; i < propertyLen; i += 1) {\n property = properties[i];\n propertyTest = propertyTest || hasOwnProp(input, property);\n }\n\n return objectTest && propertyTest;\n }\n\n function isNumberOrStringArray(input) {\n var arrayTest = isArray(input),\n dataTypeTest = false;\n if (arrayTest) {\n dataTypeTest =\n input.filter(function (item) {\n return !isNumber(item) && isString(input);\n }).length === 0;\n }\n return arrayTest && dataTypeTest;\n }\n\n function isCalendarSpec(input) {\n var objectTest = isObject(input) && !isObjectEmpty(input),\n propertyTest = false,\n properties = [\n 'sameDay',\n 'nextDay',\n 'lastDay',\n 'nextWeek',\n 'lastWeek',\n 'sameElse',\n ],\n i,\n property;\n\n for (i = 0; i < properties.length; i += 1) {\n property = properties[i];\n propertyTest = propertyTest || hasOwnProp(input, property);\n }\n\n return objectTest && propertyTest;\n }\n\n function getCalendarFormat(myMoment, now) {\n var diff = myMoment.diff(now, 'days', true);\n return diff < -6\n ? 'sameElse'\n : diff < -1\n ? 'lastWeek'\n : diff < 0\n ? 'lastDay'\n : diff < 1\n ? 'sameDay'\n : diff < 2\n ? 'nextDay'\n : diff < 7\n ? 'nextWeek'\n : 'sameElse';\n }\n\n function calendar$1(time, formats) {\n // Support for single parameter, formats only overload to the calendar function\n if (arguments.length === 1) {\n if (!arguments[0]) {\n time = undefined;\n formats = undefined;\n } else if (isMomentInput(arguments[0])) {\n time = arguments[0];\n formats = undefined;\n } else if (isCalendarSpec(arguments[0])) {\n formats = arguments[0];\n time = undefined;\n }\n }\n // We want to compare the start of today, vs this.\n // Getting start-of-today depends on whether we're local/utc/offset or not.\n var now = time || createLocal(),\n sod = cloneWithOffset(now, this).startOf('day'),\n format = hooks.calendarFormat(this, sod) || 'sameElse',\n output =\n formats &&\n (isFunction(formats[format])\n ? formats[format].call(this, now)\n : formats[format]);\n\n return this.format(\n output || this.localeData().calendar(format, this, createLocal(now))\n );\n }\n\n function clone() {\n return new Moment(this);\n }\n\n function isAfter(input, units) {\n var localInput = isMoment(input) ? input : createLocal(input);\n if (!(this.isValid() && localInput.isValid())) {\n return false;\n }\n units = normalizeUnits(units) || 'millisecond';\n if (units === 'millisecond') {\n return this.valueOf() > localInput.valueOf();\n } else {\n return localInput.valueOf() < this.clone().startOf(units).valueOf();\n }\n }\n\n function isBefore(input, units) {\n var localInput = isMoment(input) ? input : createLocal(input);\n if (!(this.isValid() && localInput.isValid())) {\n return false;\n }\n units = normalizeUnits(units) || 'millisecond';\n if (units === 'millisecond') {\n return this.valueOf() < localInput.valueOf();\n } else {\n return this.clone().endOf(units).valueOf() < localInput.valueOf();\n }\n }\n\n function isBetween(from, to, units, inclusivity) {\n var localFrom = isMoment(from) ? from : createLocal(from),\n localTo = isMoment(to) ? to : createLocal(to);\n if (!(this.isValid() && localFrom.isValid() && localTo.isValid())) {\n return false;\n }\n inclusivity = inclusivity || '()';\n return (\n (inclusivity[0] === '('\n ? this.isAfter(localFrom, units)\n : !this.isBefore(localFrom, units)) &&\n (inclusivity[1] === ')'\n ? this.isBefore(localTo, units)\n : !this.isAfter(localTo, units))\n );\n }\n\n function isSame(input, units) {\n var localInput = isMoment(input) ? input : createLocal(input),\n inputMs;\n if (!(this.isValid() && localInput.isValid())) {\n return false;\n }\n units = normalizeUnits(units) || 'millisecond';\n if (units === 'millisecond') {\n return this.valueOf() === localInput.valueOf();\n } else {\n inputMs = localInput.valueOf();\n return (\n this.clone().startOf(units).valueOf() <= inputMs &&\n inputMs <= this.clone().endOf(units).valueOf()\n );\n }\n }\n\n function isSameOrAfter(input, units) {\n return this.isSame(input, units) || this.isAfter(input, units);\n }\n\n function isSameOrBefore(input, units) {\n return this.isSame(input, units) || this.isBefore(input, units);\n }\n\n function diff(input, units, asFloat) {\n var that, zoneDelta, output;\n\n if (!this.isValid()) {\n return NaN;\n }\n\n that = cloneWithOffset(input, this);\n\n if (!that.isValid()) {\n return NaN;\n }\n\n zoneDelta = (that.utcOffset() - this.utcOffset()) * 6e4;\n\n units = normalizeUnits(units);\n\n switch (units) {\n case 'year':\n output = monthDiff(this, that) / 12;\n break;\n case 'month':\n output = monthDiff(this, that);\n break;\n case 'quarter':\n output = monthDiff(this, that) / 3;\n break;\n case 'second':\n output = (this - that) / 1e3;\n break; // 1000\n case 'minute':\n output = (this - that) / 6e4;\n break; // 1000 * 60\n case 'hour':\n output = (this - that) / 36e5;\n break; // 1000 * 60 * 60\n case 'day':\n output = (this - that - zoneDelta) / 864e5;\n break; // 1000 * 60 * 60 * 24, negate dst\n case 'week':\n output = (this - that - zoneDelta) / 6048e5;\n break; // 1000 * 60 * 60 * 24 * 7, negate dst\n default:\n output = this - that;\n }\n\n return asFloat ? output : absFloor(output);\n }\n\n function monthDiff(a, b) {\n if (a.date() < b.date()) {\n // end-of-month calculations work correct when the start month has more\n // days than the end month.\n return -monthDiff(b, a);\n }\n // difference in months\n var wholeMonthDiff = (b.year() - a.year()) * 12 + (b.month() - a.month()),\n // b is in (anchor - 1 month, anchor + 1 month)\n anchor = a.clone().add(wholeMonthDiff, 'months'),\n anchor2,\n adjust;\n\n if (b - anchor < 0) {\n anchor2 = a.clone().add(wholeMonthDiff - 1, 'months');\n // linear across the month\n adjust = (b - anchor) / (anchor - anchor2);\n } else {\n anchor2 = a.clone().add(wholeMonthDiff + 1, 'months');\n // linear across the month\n adjust = (b - anchor) / (anchor2 - anchor);\n }\n\n //check for negative zero, return zero if negative zero\n return -(wholeMonthDiff + adjust) || 0;\n }\n\n hooks.defaultFormat = 'YYYY-MM-DDTHH:mm:ssZ';\n hooks.defaultFormatUtc = 'YYYY-MM-DDTHH:mm:ss[Z]';\n\n function toString() {\n return this.clone().locale('en').format('ddd MMM DD YYYY HH:mm:ss [GMT]ZZ');\n }\n\n function toISOString(keepOffset) {\n if (!this.isValid()) {\n return null;\n }\n var utc = keepOffset !== true,\n m = utc ? this.clone().utc() : this;\n if (m.year() < 0 || m.year() > 9999) {\n return formatMoment(\n m,\n utc\n ? 'YYYYYY-MM-DD[T]HH:mm:ss.SSS[Z]'\n : 'YYYYYY-MM-DD[T]HH:mm:ss.SSSZ'\n );\n }\n if (isFunction(Date.prototype.toISOString)) {\n // native implementation is ~50x faster, use it when we can\n if (utc) {\n return this.toDate().toISOString();\n } else {\n return new Date(this.valueOf() + this.utcOffset() * 60 * 1000)\n .toISOString()\n .replace('Z', formatMoment(m, 'Z'));\n }\n }\n return formatMoment(\n m,\n utc ? 'YYYY-MM-DD[T]HH:mm:ss.SSS[Z]' : 'YYYY-MM-DD[T]HH:mm:ss.SSSZ'\n );\n }\n\n /**\n * Return a human readable representation of a moment that can\n * also be evaluated to get a new moment which is the same\n *\n * @link https://nodejs.org/dist/latest/docs/api/util.html#util_custom_inspect_function_on_objects\n */\n function inspect() {\n if (!this.isValid()) {\n return 'moment.invalid(/* ' + this._i + ' */)';\n }\n var func = 'moment',\n zone = '',\n prefix,\n year,\n datetime,\n suffix;\n if (!this.isLocal()) {\n func = this.utcOffset() === 0 ? 'moment.utc' : 'moment.parseZone';\n zone = 'Z';\n }\n prefix = '[' + func + '(\"]';\n year = 0 <= this.year() && this.year() <= 9999 ? 'YYYY' : 'YYYYYY';\n datetime = '-MM-DD[T]HH:mm:ss.SSS';\n suffix = zone + '[\")]';\n\n return this.format(prefix + year + datetime + suffix);\n }\n\n function format(inputString) {\n if (!inputString) {\n inputString = this.isUtc()\n ? hooks.defaultFormatUtc\n : hooks.defaultFormat;\n }\n var output = formatMoment(this, inputString);\n return this.localeData().postformat(output);\n }\n\n function from(time, withoutSuffix) {\n if (\n this.isValid() &&\n ((isMoment(time) && time.isValid()) || createLocal(time).isValid())\n ) {\n return createDuration({ to: this, from: time })\n .locale(this.locale())\n .humanize(!withoutSuffix);\n } else {\n return this.localeData().invalidDate();\n }\n }\n\n function fromNow(withoutSuffix) {\n return this.from(createLocal(), withoutSuffix);\n }\n\n function to(time, withoutSuffix) {\n if (\n this.isValid() &&\n ((isMoment(time) && time.isValid()) || createLocal(time).isValid())\n ) {\n return createDuration({ from: this, to: time })\n .locale(this.locale())\n .humanize(!withoutSuffix);\n } else {\n return this.localeData().invalidDate();\n }\n }\n\n function toNow(withoutSuffix) {\n return this.to(createLocal(), withoutSuffix);\n }\n\n // If passed a locale key, it will set the locale for this\n // instance. Otherwise, it will return the locale configuration\n // variables for this instance.\n function locale(key) {\n var newLocaleData;\n\n if (key === undefined) {\n return this._locale._abbr;\n } else {\n newLocaleData = getLocale(key);\n if (newLocaleData != null) {\n this._locale = newLocaleData;\n }\n return this;\n }\n }\n\n var lang = deprecate(\n 'moment().lang() is deprecated. Instead, use moment().localeData() to get the language configuration. Use moment().locale() to change languages.',\n function (key) {\n if (key === undefined) {\n return this.localeData();\n } else {\n return this.locale(key);\n }\n }\n );\n\n function localeData() {\n return this._locale;\n }\n\n var MS_PER_SECOND = 1000,\n MS_PER_MINUTE = 60 * MS_PER_SECOND,\n MS_PER_HOUR = 60 * MS_PER_MINUTE,\n MS_PER_400_YEARS = (365 * 400 + 97) * 24 * MS_PER_HOUR;\n\n // actual modulo - handles negative numbers (for dates before 1970):\n function mod$1(dividend, divisor) {\n return ((dividend % divisor) + divisor) % divisor;\n }\n\n function localStartOfDate(y, m, d) {\n // the date constructor remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n // preserve leap years using a full 400 year cycle, then reset\n return new Date(y + 400, m, d) - MS_PER_400_YEARS;\n } else {\n return new Date(y, m, d).valueOf();\n }\n }\n\n function utcStartOfDate(y, m, d) {\n // Date.UTC remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n // preserve leap years using a full 400 year cycle, then reset\n return Date.UTC(y + 400, m, d) - MS_PER_400_YEARS;\n } else {\n return Date.UTC(y, m, d);\n }\n }\n\n function startOf(units) {\n var time, startOfDate;\n units = normalizeUnits(units);\n if (units === undefined || units === 'millisecond' || !this.isValid()) {\n return this;\n }\n\n startOfDate = this._isUTC ? utcStartOfDate : localStartOfDate;\n\n switch (units) {\n case 'year':\n time = startOfDate(this.year(), 0, 1);\n break;\n case 'quarter':\n time = startOfDate(\n this.year(),\n this.month() - (this.month() % 3),\n 1\n );\n break;\n case 'month':\n time = startOfDate(this.year(), this.month(), 1);\n break;\n case 'week':\n time = startOfDate(\n this.year(),\n this.month(),\n this.date() - this.weekday()\n );\n break;\n case 'isoWeek':\n time = startOfDate(\n this.year(),\n this.month(),\n this.date() - (this.isoWeekday() - 1)\n );\n break;\n case 'day':\n case 'date':\n time = startOfDate(this.year(), this.month(), this.date());\n break;\n case 'hour':\n time = this._d.valueOf();\n time -= mod$1(\n time + (this._isUTC ? 0 : this.utcOffset() * MS_PER_MINUTE),\n MS_PER_HOUR\n );\n break;\n case 'minute':\n time = this._d.valueOf();\n time -= mod$1(time, MS_PER_MINUTE);\n break;\n case 'second':\n time = this._d.valueOf();\n time -= mod$1(time, MS_PER_SECOND);\n break;\n }\n\n this._d.setTime(time);\n hooks.updateOffset(this, true);\n return this;\n }\n\n function endOf(units) {\n var time, startOfDate;\n units = normalizeUnits(units);\n if (units === undefined || units === 'millisecond' || !this.isValid()) {\n return this;\n }\n\n startOfDate = this._isUTC ? utcStartOfDate : localStartOfDate;\n\n switch (units) {\n case 'year':\n time = startOfDate(this.year() + 1, 0, 1) - 1;\n break;\n case 'quarter':\n time =\n startOfDate(\n this.year(),\n this.month() - (this.month() % 3) + 3,\n 1\n ) - 1;\n break;\n case 'month':\n time = startOfDate(this.year(), this.month() + 1, 1) - 1;\n break;\n case 'week':\n time =\n startOfDate(\n this.year(),\n this.month(),\n this.date() - this.weekday() + 7\n ) - 1;\n break;\n case 'isoWeek':\n time =\n startOfDate(\n this.year(),\n this.month(),\n this.date() - (this.isoWeekday() - 1) + 7\n ) - 1;\n break;\n case 'day':\n case 'date':\n time = startOfDate(this.year(), this.month(), this.date() + 1) - 1;\n break;\n case 'hour':\n time = this._d.valueOf();\n time +=\n MS_PER_HOUR -\n mod$1(\n time + (this._isUTC ? 0 : this.utcOffset() * MS_PER_MINUTE),\n MS_PER_HOUR\n ) -\n 1;\n break;\n case 'minute':\n time = this._d.valueOf();\n time += MS_PER_MINUTE - mod$1(time, MS_PER_MINUTE) - 1;\n break;\n case 'second':\n time = this._d.valueOf();\n time += MS_PER_SECOND - mod$1(time, MS_PER_SECOND) - 1;\n break;\n }\n\n this._d.setTime(time);\n hooks.updateOffset(this, true);\n return this;\n }\n\n function valueOf() {\n return this._d.valueOf() - (this._offset || 0) * 60000;\n }\n\n function unix() {\n return Math.floor(this.valueOf() / 1000);\n }\n\n function toDate() {\n return new Date(this.valueOf());\n }\n\n function toArray() {\n var m = this;\n return [\n m.year(),\n m.month(),\n m.date(),\n m.hour(),\n m.minute(),\n m.second(),\n m.millisecond(),\n ];\n }\n\n function toObject() {\n var m = this;\n return {\n years: m.year(),\n months: m.month(),\n date: m.date(),\n hours: m.hours(),\n minutes: m.minutes(),\n seconds: m.seconds(),\n milliseconds: m.milliseconds(),\n };\n }\n\n function toJSON() {\n // new Date(NaN).toJSON() === null\n return this.isValid() ? this.toISOString() : null;\n }\n\n function isValid$2() {\n return isValid(this);\n }\n\n function parsingFlags() {\n return extend({}, getParsingFlags(this));\n }\n\n function invalidAt() {\n return getParsingFlags(this).overflow;\n }\n\n function creationData() {\n return {\n input: this._i,\n format: this._f,\n locale: this._locale,\n isUTC: this._isUTC,\n strict: this._strict,\n };\n }\n\n addFormatToken('N', 0, 0, 'eraAbbr');\n addFormatToken('NN', 0, 0, 'eraAbbr');\n addFormatToken('NNN', 0, 0, 'eraAbbr');\n addFormatToken('NNNN', 0, 0, 'eraName');\n addFormatToken('NNNNN', 0, 0, 'eraNarrow');\n\n addFormatToken('y', ['y', 1], 'yo', 'eraYear');\n addFormatToken('y', ['yy', 2], 0, 'eraYear');\n addFormatToken('y', ['yyy', 3], 0, 'eraYear');\n addFormatToken('y', ['yyyy', 4], 0, 'eraYear');\n\n addRegexToken('N', matchEraAbbr);\n addRegexToken('NN', matchEraAbbr);\n addRegexToken('NNN', matchEraAbbr);\n addRegexToken('NNNN', matchEraName);\n addRegexToken('NNNNN', matchEraNarrow);\n\n addParseToken(\n ['N', 'NN', 'NNN', 'NNNN', 'NNNNN'],\n function (input, array, config, token) {\n var era = config._locale.erasParse(input, token, config._strict);\n if (era) {\n getParsingFlags(config).era = era;\n } else {\n getParsingFlags(config).invalidEra = input;\n }\n }\n );\n\n addRegexToken('y', matchUnsigned);\n addRegexToken('yy', matchUnsigned);\n addRegexToken('yyy', matchUnsigned);\n addRegexToken('yyyy', matchUnsigned);\n addRegexToken('yo', matchEraYearOrdinal);\n\n addParseToken(['y', 'yy', 'yyy', 'yyyy'], YEAR);\n addParseToken(['yo'], function (input, array, config, token) {\n var match;\n if (config._locale._eraYearOrdinalRegex) {\n match = input.match(config._locale._eraYearOrdinalRegex);\n }\n\n if (config._locale.eraYearOrdinalParse) {\n array[YEAR] = config._locale.eraYearOrdinalParse(input, match);\n } else {\n array[YEAR] = parseInt(input, 10);\n }\n });\n\n function localeEras(m, format) {\n var i,\n l,\n date,\n eras = this._eras || getLocale('en')._eras;\n for (i = 0, l = eras.length; i < l; ++i) {\n switch (typeof eras[i].since) {\n case 'string':\n // truncate time\n date = hooks(eras[i].since).startOf('day');\n eras[i].since = date.valueOf();\n break;\n }\n\n switch (typeof eras[i].until) {\n case 'undefined':\n eras[i].until = +Infinity;\n break;\n case 'string':\n // truncate time\n date = hooks(eras[i].until).startOf('day').valueOf();\n eras[i].until = date.valueOf();\n break;\n }\n }\n return eras;\n }\n\n function localeErasParse(eraName, format, strict) {\n var i,\n l,\n eras = this.eras(),\n name,\n abbr,\n narrow;\n eraName = eraName.toUpperCase();\n\n for (i = 0, l = eras.length; i < l; ++i) {\n name = eras[i].name.toUpperCase();\n abbr = eras[i].abbr.toUpperCase();\n narrow = eras[i].narrow.toUpperCase();\n\n if (strict) {\n switch (format) {\n case 'N':\n case 'NN':\n case 'NNN':\n if (abbr === eraName) {\n return eras[i];\n }\n break;\n\n case 'NNNN':\n if (name === eraName) {\n return eras[i];\n }\n break;\n\n case 'NNNNN':\n if (narrow === eraName) {\n return eras[i];\n }\n break;\n }\n } else if ([name, abbr, narrow].indexOf(eraName) >= 0) {\n return eras[i];\n }\n }\n }\n\n function localeErasConvertYear(era, year) {\n var dir = era.since <= era.until ? +1 : -1;\n if (year === undefined) {\n return hooks(era.since).year();\n } else {\n return hooks(era.since).year() + (year - era.offset) * dir;\n }\n }\n\n function getEraName() {\n var i,\n l,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (eras[i].since <= val && val <= eras[i].until) {\n return eras[i].name;\n }\n if (eras[i].until <= val && val <= eras[i].since) {\n return eras[i].name;\n }\n }\n\n return '';\n }\n\n function getEraNarrow() {\n var i,\n l,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (eras[i].since <= val && val <= eras[i].until) {\n return eras[i].narrow;\n }\n if (eras[i].until <= val && val <= eras[i].since) {\n return eras[i].narrow;\n }\n }\n\n return '';\n }\n\n function getEraAbbr() {\n var i,\n l,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (eras[i].since <= val && val <= eras[i].until) {\n return eras[i].abbr;\n }\n if (eras[i].until <= val && val <= eras[i].since) {\n return eras[i].abbr;\n }\n }\n\n return '';\n }\n\n function getEraYear() {\n var i,\n l,\n dir,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n dir = eras[i].since <= eras[i].until ? +1 : -1;\n\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (\n (eras[i].since <= val && val <= eras[i].until) ||\n (eras[i].until <= val && val <= eras[i].since)\n ) {\n return (\n (this.year() - hooks(eras[i].since).year()) * dir +\n eras[i].offset\n );\n }\n }\n\n return this.year();\n }\n\n function erasNameRegex(isStrict) {\n if (!hasOwnProp(this, '_erasNameRegex')) {\n computeErasParse.call(this);\n }\n return isStrict ? this._erasNameRegex : this._erasRegex;\n }\n\n function erasAbbrRegex(isStrict) {\n if (!hasOwnProp(this, '_erasAbbrRegex')) {\n computeErasParse.call(this);\n }\n return isStrict ? this._erasAbbrRegex : this._erasRegex;\n }\n\n function erasNarrowRegex(isStrict) {\n if (!hasOwnProp(this, '_erasNarrowRegex')) {\n computeErasParse.call(this);\n }\n return isStrict ? this._erasNarrowRegex : this._erasRegex;\n }\n\n function matchEraAbbr(isStrict, locale) {\n return locale.erasAbbrRegex(isStrict);\n }\n\n function matchEraName(isStrict, locale) {\n return locale.erasNameRegex(isStrict);\n }\n\n function matchEraNarrow(isStrict, locale) {\n return locale.erasNarrowRegex(isStrict);\n }\n\n function matchEraYearOrdinal(isStrict, locale) {\n return locale._eraYearOrdinalRegex || matchUnsigned;\n }\n\n function computeErasParse() {\n var abbrPieces = [],\n namePieces = [],\n narrowPieces = [],\n mixedPieces = [],\n i,\n l,\n erasName,\n erasAbbr,\n erasNarrow,\n eras = this.eras();\n\n for (i = 0, l = eras.length; i < l; ++i) {\n erasName = regexEscape(eras[i].name);\n erasAbbr = regexEscape(eras[i].abbr);\n erasNarrow = regexEscape(eras[i].narrow);\n\n namePieces.push(erasName);\n abbrPieces.push(erasAbbr);\n narrowPieces.push(erasNarrow);\n mixedPieces.push(erasName);\n mixedPieces.push(erasAbbr);\n mixedPieces.push(erasNarrow);\n }\n\n this._erasRegex = new RegExp('^(' + mixedPieces.join('|') + ')', 'i');\n this._erasNameRegex = new RegExp('^(' + namePieces.join('|') + ')', 'i');\n this._erasAbbrRegex = new RegExp('^(' + abbrPieces.join('|') + ')', 'i');\n this._erasNarrowRegex = new RegExp(\n '^(' + narrowPieces.join('|') + ')',\n 'i'\n );\n }\n\n // FORMATTING\n\n addFormatToken(0, ['gg', 2], 0, function () {\n return this.weekYear() % 100;\n });\n\n addFormatToken(0, ['GG', 2], 0, function () {\n return this.isoWeekYear() % 100;\n });\n\n function addWeekYearFormatToken(token, getter) {\n addFormatToken(0, [token, token.length], 0, getter);\n }\n\n addWeekYearFormatToken('gggg', 'weekYear');\n addWeekYearFormatToken('ggggg', 'weekYear');\n addWeekYearFormatToken('GGGG', 'isoWeekYear');\n addWeekYearFormatToken('GGGGG', 'isoWeekYear');\n\n // ALIASES\n\n // PARSING\n\n addRegexToken('G', matchSigned);\n addRegexToken('g', matchSigned);\n addRegexToken('GG', match1to2, match2);\n addRegexToken('gg', match1to2, match2);\n addRegexToken('GGGG', match1to4, match4);\n addRegexToken('gggg', match1to4, match4);\n addRegexToken('GGGGG', match1to6, match6);\n addRegexToken('ggggg', match1to6, match6);\n\n addWeekParseToken(\n ['gggg', 'ggggg', 'GGGG', 'GGGGG'],\n function (input, week, config, token) {\n week[token.substr(0, 2)] = toInt(input);\n }\n );\n\n addWeekParseToken(['gg', 'GG'], function (input, week, config, token) {\n week[token] = hooks.parseTwoDigitYear(input);\n });\n\n // MOMENTS\n\n function getSetWeekYear(input) {\n return getSetWeekYearHelper.call(\n this,\n input,\n this.week(),\n this.weekday() + this.localeData()._week.dow,\n this.localeData()._week.dow,\n this.localeData()._week.doy\n );\n }\n\n function getSetISOWeekYear(input) {\n return getSetWeekYearHelper.call(\n this,\n input,\n this.isoWeek(),\n this.isoWeekday(),\n 1,\n 4\n );\n }\n\n function getISOWeeksInYear() {\n return weeksInYear(this.year(), 1, 4);\n }\n\n function getISOWeeksInISOWeekYear() {\n return weeksInYear(this.isoWeekYear(), 1, 4);\n }\n\n function getWeeksInYear() {\n var weekInfo = this.localeData()._week;\n return weeksInYear(this.year(), weekInfo.dow, weekInfo.doy);\n }\n\n function getWeeksInWeekYear() {\n var weekInfo = this.localeData()._week;\n return weeksInYear(this.weekYear(), weekInfo.dow, weekInfo.doy);\n }\n\n function getSetWeekYearHelper(input, week, weekday, dow, doy) {\n var weeksTarget;\n if (input == null) {\n return weekOfYear(this, dow, doy).year;\n } else {\n weeksTarget = weeksInYear(input, dow, doy);\n if (week > weeksTarget) {\n week = weeksTarget;\n }\n return setWeekAll.call(this, input, week, weekday, dow, doy);\n }\n }\n\n function setWeekAll(weekYear, week, weekday, dow, doy) {\n var dayOfYearData = dayOfYearFromWeeks(weekYear, week, weekday, dow, doy),\n date = createUTCDate(dayOfYearData.year, 0, dayOfYearData.dayOfYear);\n\n this.year(date.getUTCFullYear());\n this.month(date.getUTCMonth());\n this.date(date.getUTCDate());\n return this;\n }\n\n // FORMATTING\n\n addFormatToken('Q', 0, 'Qo', 'quarter');\n\n // PARSING\n\n addRegexToken('Q', match1);\n addParseToken('Q', function (input, array) {\n array[MONTH] = (toInt(input) - 1) * 3;\n });\n\n // MOMENTS\n\n function getSetQuarter(input) {\n return input == null\n ? Math.ceil((this.month() + 1) / 3)\n : this.month((input - 1) * 3 + (this.month() % 3));\n }\n\n // FORMATTING\n\n addFormatToken('D', ['DD', 2], 'Do', 'date');\n\n // PARSING\n\n addRegexToken('D', match1to2, match1to2NoLeadingZero);\n addRegexToken('DD', match1to2, match2);\n addRegexToken('Do', function (isStrict, locale) {\n // TODO: Remove \"ordinalParse\" fallback in next major release.\n return isStrict\n ? locale._dayOfMonthOrdinalParse || locale._ordinalParse\n : locale._dayOfMonthOrdinalParseLenient;\n });\n\n addParseToken(['D', 'DD'], DATE);\n addParseToken('Do', function (input, array) {\n array[DATE] = toInt(input.match(match1to2)[0]);\n });\n\n // MOMENTS\n\n var getSetDayOfMonth = makeGetSet('Date', true);\n\n // FORMATTING\n\n addFormatToken('DDD', ['DDDD', 3], 'DDDo', 'dayOfYear');\n\n // PARSING\n\n addRegexToken('DDD', match1to3);\n addRegexToken('DDDD', match3);\n addParseToken(['DDD', 'DDDD'], function (input, array, config) {\n config._dayOfYear = toInt(input);\n });\n\n // HELPERS\n\n // MOMENTS\n\n function getSetDayOfYear(input) {\n var dayOfYear =\n Math.round(\n (this.clone().startOf('day') - this.clone().startOf('year')) / 864e5\n ) + 1;\n return input == null ? dayOfYear : this.add(input - dayOfYear, 'd');\n }\n\n // FORMATTING\n\n addFormatToken('m', ['mm', 2], 0, 'minute');\n\n // PARSING\n\n addRegexToken('m', match1to2, match1to2HasZero);\n addRegexToken('mm', match1to2, match2);\n addParseToken(['m', 'mm'], MINUTE);\n\n // MOMENTS\n\n var getSetMinute = makeGetSet('Minutes', false);\n\n // FORMATTING\n\n addFormatToken('s', ['ss', 2], 0, 'second');\n\n // PARSING\n\n addRegexToken('s', match1to2, match1to2HasZero);\n addRegexToken('ss', match1to2, match2);\n addParseToken(['s', 'ss'], SECOND);\n\n // MOMENTS\n\n var getSetSecond = makeGetSet('Seconds', false);\n\n // FORMATTING\n\n addFormatToken('S', 0, 0, function () {\n return ~~(this.millisecond() / 100);\n });\n\n addFormatToken(0, ['SS', 2], 0, function () {\n return ~~(this.millisecond() / 10);\n });\n\n addFormatToken(0, ['SSS', 3], 0, 'millisecond');\n addFormatToken(0, ['SSSS', 4], 0, function () {\n return this.millisecond() * 10;\n });\n addFormatToken(0, ['SSSSS', 5], 0, function () {\n return this.millisecond() * 100;\n });\n addFormatToken(0, ['SSSSSS', 6], 0, function () {\n return this.millisecond() * 1000;\n });\n addFormatToken(0, ['SSSSSSS', 7], 0, function () {\n return this.millisecond() * 10000;\n });\n addFormatToken(0, ['SSSSSSSS', 8], 0, function () {\n return this.millisecond() * 100000;\n });\n addFormatToken(0, ['SSSSSSSSS', 9], 0, function () {\n return this.millisecond() * 1000000;\n });\n\n // PARSING\n\n addRegexToken('S', match1to3, match1);\n addRegexToken('SS', match1to3, match2);\n addRegexToken('SSS', match1to3, match3);\n\n var token, getSetMillisecond;\n for (token = 'SSSS'; token.length <= 9; token += 'S') {\n addRegexToken(token, matchUnsigned);\n }\n\n function parseMs(input, array) {\n array[MILLISECOND] = toInt(('0.' + input) * 1000);\n }\n\n for (token = 'S'; token.length <= 9; token += 'S') {\n addParseToken(token, parseMs);\n }\n\n getSetMillisecond = makeGetSet('Milliseconds', false);\n\n // FORMATTING\n\n addFormatToken('z', 0, 0, 'zoneAbbr');\n addFormatToken('zz', 0, 0, 'zoneName');\n\n // MOMENTS\n\n function getZoneAbbr() {\n return this._isUTC ? 'UTC' : '';\n }\n\n function getZoneName() {\n return this._isUTC ? 'Coordinated Universal Time' : '';\n }\n\n var proto = Moment.prototype;\n\n proto.add = add;\n proto.calendar = calendar$1;\n proto.clone = clone;\n proto.diff = diff;\n proto.endOf = endOf;\n proto.format = format;\n proto.from = from;\n proto.fromNow = fromNow;\n proto.to = to;\n proto.toNow = toNow;\n proto.get = stringGet;\n proto.invalidAt = invalidAt;\n proto.isAfter = isAfter;\n proto.isBefore = isBefore;\n proto.isBetween = isBetween;\n proto.isSame = isSame;\n proto.isSameOrAfter = isSameOrAfter;\n proto.isSameOrBefore = isSameOrBefore;\n proto.isValid = isValid$2;\n proto.lang = lang;\n proto.locale = locale;\n proto.localeData = localeData;\n proto.max = prototypeMax;\n proto.min = prototypeMin;\n proto.parsingFlags = parsingFlags;\n proto.set = stringSet;\n proto.startOf = startOf;\n proto.subtract = subtract;\n proto.toArray = toArray;\n proto.toObject = toObject;\n proto.toDate = toDate;\n proto.toISOString = toISOString;\n proto.inspect = inspect;\n if (typeof Symbol !== 'undefined' && Symbol.for != null) {\n proto[Symbol.for('nodejs.util.inspect.custom')] = function () {\n return 'Moment<' + this.format() + '>';\n };\n }\n proto.toJSON = toJSON;\n proto.toString = toString;\n proto.unix = unix;\n proto.valueOf = valueOf;\n proto.creationData = creationData;\n proto.eraName = getEraName;\n proto.eraNarrow = getEraNarrow;\n proto.eraAbbr = getEraAbbr;\n proto.eraYear = getEraYear;\n proto.year = getSetYear;\n proto.isLeapYear = getIsLeapYear;\n proto.weekYear = getSetWeekYear;\n proto.isoWeekYear = getSetISOWeekYear;\n proto.quarter = proto.quarters = getSetQuarter;\n proto.month = getSetMonth;\n proto.daysInMonth = getDaysInMonth;\n proto.week = proto.weeks = getSetWeek;\n proto.isoWeek = proto.isoWeeks = getSetISOWeek;\n proto.weeksInYear = getWeeksInYear;\n proto.weeksInWeekYear = getWeeksInWeekYear;\n proto.isoWeeksInYear = getISOWeeksInYear;\n proto.isoWeeksInISOWeekYear = getISOWeeksInISOWeekYear;\n proto.date = getSetDayOfMonth;\n proto.day = proto.days = getSetDayOfWeek;\n proto.weekday = getSetLocaleDayOfWeek;\n proto.isoWeekday = getSetISODayOfWeek;\n proto.dayOfYear = getSetDayOfYear;\n proto.hour = proto.hours = getSetHour;\n proto.minute = proto.minutes = getSetMinute;\n proto.second = proto.seconds = getSetSecond;\n proto.millisecond = proto.milliseconds = getSetMillisecond;\n proto.utcOffset = getSetOffset;\n proto.utc = setOffsetToUTC;\n proto.local = setOffsetToLocal;\n proto.parseZone = setOffsetToParsedOffset;\n proto.hasAlignedHourOffset = hasAlignedHourOffset;\n proto.isDST = isDaylightSavingTime;\n proto.isLocal = isLocal;\n proto.isUtcOffset = isUtcOffset;\n proto.isUtc = isUtc;\n proto.isUTC = isUtc;\n proto.zoneAbbr = getZoneAbbr;\n proto.zoneName = getZoneName;\n proto.dates = deprecate(\n 'dates accessor is deprecated. Use date instead.',\n getSetDayOfMonth\n );\n proto.months = deprecate(\n 'months accessor is deprecated. Use month instead',\n getSetMonth\n );\n proto.years = deprecate(\n 'years accessor is deprecated. Use year instead',\n getSetYear\n );\n proto.zone = deprecate(\n 'moment().zone is deprecated, use moment().utcOffset instead. http://momentjs.com/guides/#/warnings/zone/',\n getSetZone\n );\n proto.isDSTShifted = deprecate(\n 'isDSTShifted is deprecated. See http://momentjs.com/guides/#/warnings/dst-shifted/ for more information',\n isDaylightSavingTimeShifted\n );\n\n function createUnix(input) {\n return createLocal(input * 1000);\n }\n\n function createInZone() {\n return createLocal.apply(null, arguments).parseZone();\n }\n\n function preParsePostFormat(string) {\n return string;\n }\n\n var proto$1 = Locale.prototype;\n\n proto$1.calendar = calendar;\n proto$1.longDateFormat = longDateFormat;\n proto$1.invalidDate = invalidDate;\n proto$1.ordinal = ordinal;\n proto$1.preparse = preParsePostFormat;\n proto$1.postformat = preParsePostFormat;\n proto$1.relativeTime = relativeTime;\n proto$1.pastFuture = pastFuture;\n proto$1.set = set;\n proto$1.eras = localeEras;\n proto$1.erasParse = localeErasParse;\n proto$1.erasConvertYear = localeErasConvertYear;\n proto$1.erasAbbrRegex = erasAbbrRegex;\n proto$1.erasNameRegex = erasNameRegex;\n proto$1.erasNarrowRegex = erasNarrowRegex;\n\n proto$1.months = localeMonths;\n proto$1.monthsShort = localeMonthsShort;\n proto$1.monthsParse = localeMonthsParse;\n proto$1.monthsRegex = monthsRegex;\n proto$1.monthsShortRegex = monthsShortRegex;\n proto$1.week = localeWeek;\n proto$1.firstDayOfYear = localeFirstDayOfYear;\n proto$1.firstDayOfWeek = localeFirstDayOfWeek;\n\n proto$1.weekdays = localeWeekdays;\n proto$1.weekdaysMin = localeWeekdaysMin;\n proto$1.weekdaysShort = localeWeekdaysShort;\n proto$1.weekdaysParse = localeWeekdaysParse;\n\n proto$1.weekdaysRegex = weekdaysRegex;\n proto$1.weekdaysShortRegex = weekdaysShortRegex;\n proto$1.weekdaysMinRegex = weekdaysMinRegex;\n\n proto$1.isPM = localeIsPM;\n proto$1.meridiem = localeMeridiem;\n\n function get$1(format, index, field, setter) {\n var locale = getLocale(),\n utc = createUTC().set(setter, index);\n return locale[field](utc, format);\n }\n\n function listMonthsImpl(format, index, field) {\n if (isNumber(format)) {\n index = format;\n format = undefined;\n }\n\n format = format || '';\n\n if (index != null) {\n return get$1(format, index, field, 'month');\n }\n\n var i,\n out = [];\n for (i = 0; i < 12; i++) {\n out[i] = get$1(format, i, field, 'month');\n }\n return out;\n }\n\n // ()\n // (5)\n // (fmt, 5)\n // (fmt)\n // (true)\n // (true, 5)\n // (true, fmt, 5)\n // (true, fmt)\n function listWeekdaysImpl(localeSorted, format, index, field) {\n if (typeof localeSorted === 'boolean') {\n if (isNumber(format)) {\n index = format;\n format = undefined;\n }\n\n format = format || '';\n } else {\n format = localeSorted;\n index = format;\n localeSorted = false;\n\n if (isNumber(format)) {\n index = format;\n format = undefined;\n }\n\n format = format || '';\n }\n\n var locale = getLocale(),\n shift = localeSorted ? locale._week.dow : 0,\n i,\n out = [];\n\n if (index != null) {\n return get$1(format, (index + shift) % 7, field, 'day');\n }\n\n for (i = 0; i < 7; i++) {\n out[i] = get$1(format, (i + shift) % 7, field, 'day');\n }\n return out;\n }\n\n function listMonths(format, index) {\n return listMonthsImpl(format, index, 'months');\n }\n\n function listMonthsShort(format, index) {\n return listMonthsImpl(format, index, 'monthsShort');\n }\n\n function listWeekdays(localeSorted, format, index) {\n return listWeekdaysImpl(localeSorted, format, index, 'weekdays');\n }\n\n function listWeekdaysShort(localeSorted, format, index) {\n return listWeekdaysImpl(localeSorted, format, index, 'weekdaysShort');\n }\n\n function listWeekdaysMin(localeSorted, format, index) {\n return listWeekdaysImpl(localeSorted, format, index, 'weekdaysMin');\n }\n\n getSetGlobalLocale('en', {\n eras: [\n {\n since: '0001-01-01',\n until: +Infinity,\n offset: 1,\n name: 'Anno Domini',\n narrow: 'AD',\n abbr: 'AD',\n },\n {\n since: '0000-12-31',\n until: -Infinity,\n offset: 1,\n name: 'Before Christ',\n narrow: 'BC',\n abbr: 'BC',\n },\n ],\n dayOfMonthOrdinalParse: /\\d{1,2}(th|st|nd|rd)/,\n ordinal: function (number) {\n var b = number % 10,\n output =\n toInt((number % 100) / 10) === 1\n ? 'th'\n : b === 1\n ? 'st'\n : b === 2\n ? 'nd'\n : b === 3\n ? 'rd'\n : 'th';\n return number + output;\n },\n });\n\n // Side effect imports\n\n hooks.lang = deprecate(\n 'moment.lang is deprecated. Use moment.locale instead.',\n getSetGlobalLocale\n );\n hooks.langData = deprecate(\n 'moment.langData is deprecated. Use moment.localeData instead.',\n getLocale\n );\n\n var mathAbs = Math.abs;\n\n function abs() {\n var data = this._data;\n\n this._milliseconds = mathAbs(this._milliseconds);\n this._days = mathAbs(this._days);\n this._months = mathAbs(this._months);\n\n data.milliseconds = mathAbs(data.milliseconds);\n data.seconds = mathAbs(data.seconds);\n data.minutes = mathAbs(data.minutes);\n data.hours = mathAbs(data.hours);\n data.months = mathAbs(data.months);\n data.years = mathAbs(data.years);\n\n return this;\n }\n\n function addSubtract$1(duration, input, value, direction) {\n var other = createDuration(input, value);\n\n duration._milliseconds += direction * other._milliseconds;\n duration._days += direction * other._days;\n duration._months += direction * other._months;\n\n return duration._bubble();\n }\n\n // supports only 2.0-style add(1, 's') or add(duration)\n function add$1(input, value) {\n return addSubtract$1(this, input, value, 1);\n }\n\n // supports only 2.0-style subtract(1, 's') or subtract(duration)\n function subtract$1(input, value) {\n return addSubtract$1(this, input, value, -1);\n }\n\n function absCeil(number) {\n if (number < 0) {\n return Math.floor(number);\n } else {\n return Math.ceil(number);\n }\n }\n\n function bubble() {\n var milliseconds = this._milliseconds,\n days = this._days,\n months = this._months,\n data = this._data,\n seconds,\n minutes,\n hours,\n years,\n monthsFromDays;\n\n // if we have a mix of positive and negative values, bubble down first\n // check: https://github.com/moment/moment/issues/2166\n if (\n !(\n (milliseconds >= 0 && days >= 0 && months >= 0) ||\n (milliseconds <= 0 && days <= 0 && months <= 0)\n )\n ) {\n milliseconds += absCeil(monthsToDays(months) + days) * 864e5;\n days = 0;\n months = 0;\n }\n\n // The following code bubbles up values, see the tests for\n // examples of what that means.\n data.milliseconds = milliseconds % 1000;\n\n seconds = absFloor(milliseconds / 1000);\n data.seconds = seconds % 60;\n\n minutes = absFloor(seconds / 60);\n data.minutes = minutes % 60;\n\n hours = absFloor(minutes / 60);\n data.hours = hours % 24;\n\n days += absFloor(hours / 24);\n\n // convert days to months\n monthsFromDays = absFloor(daysToMonths(days));\n months += monthsFromDays;\n days -= absCeil(monthsToDays(monthsFromDays));\n\n // 12 months -> 1 year\n years = absFloor(months / 12);\n months %= 12;\n\n data.days = days;\n data.months = months;\n data.years = years;\n\n return this;\n }\n\n function daysToMonths(days) {\n // 400 years have 146097 days (taking into account leap year rules)\n // 400 years have 12 months === 4800\n return (days * 4800) / 146097;\n }\n\n function monthsToDays(months) {\n // the reverse of daysToMonths\n return (months * 146097) / 4800;\n }\n\n function as(units) {\n if (!this.isValid()) {\n return NaN;\n }\n var days,\n months,\n milliseconds = this._milliseconds;\n\n units = normalizeUnits(units);\n\n if (units === 'month' || units === 'quarter' || units === 'year') {\n days = this._days + milliseconds / 864e5;\n months = this._months + daysToMonths(days);\n switch (units) {\n case 'month':\n return months;\n case 'quarter':\n return months / 3;\n case 'year':\n return months / 12;\n }\n } else {\n // handle milliseconds separately because of floating point math errors (issue #1867)\n days = this._days + Math.round(monthsToDays(this._months));\n switch (units) {\n case 'week':\n return days / 7 + milliseconds / 6048e5;\n case 'day':\n return days + milliseconds / 864e5;\n case 'hour':\n return days * 24 + milliseconds / 36e5;\n case 'minute':\n return days * 1440 + milliseconds / 6e4;\n case 'second':\n return days * 86400 + milliseconds / 1000;\n // Math.floor prevents floating point math errors here\n case 'millisecond':\n return Math.floor(days * 864e5) + milliseconds;\n default:\n throw new Error('Unknown unit ' + units);\n }\n }\n }\n\n function makeAs(alias) {\n return function () {\n return this.as(alias);\n };\n }\n\n var asMilliseconds = makeAs('ms'),\n asSeconds = makeAs('s'),\n asMinutes = makeAs('m'),\n asHours = makeAs('h'),\n asDays = makeAs('d'),\n asWeeks = makeAs('w'),\n asMonths = makeAs('M'),\n asQuarters = makeAs('Q'),\n asYears = makeAs('y'),\n valueOf$1 = asMilliseconds;\n\n function clone$1() {\n return createDuration(this);\n }\n\n function get$2(units) {\n units = normalizeUnits(units);\n return this.isValid() ? this[units + 's']() : NaN;\n }\n\n function makeGetter(name) {\n return function () {\n return this.isValid() ? this._data[name] : NaN;\n };\n }\n\n var milliseconds = makeGetter('milliseconds'),\n seconds = makeGetter('seconds'),\n minutes = makeGetter('minutes'),\n hours = makeGetter('hours'),\n days = makeGetter('days'),\n months = makeGetter('months'),\n years = makeGetter('years');\n\n function weeks() {\n return absFloor(this.days() / 7);\n }\n\n var round = Math.round,\n thresholds = {\n ss: 44, // a few seconds to seconds\n s: 45, // seconds to minute\n m: 45, // minutes to hour\n h: 22, // hours to day\n d: 26, // days to month/week\n w: null, // weeks to month\n M: 11, // months to year\n };\n\n // helper function for moment.fn.from, moment.fn.fromNow, and moment.duration.fn.humanize\n function substituteTimeAgo(string, number, withoutSuffix, isFuture, locale) {\n return locale.relativeTime(number || 1, !!withoutSuffix, string, isFuture);\n }\n\n function relativeTime$1(posNegDuration, withoutSuffix, thresholds, locale) {\n var duration = createDuration(posNegDuration).abs(),\n seconds = round(duration.as('s')),\n minutes = round(duration.as('m')),\n hours = round(duration.as('h')),\n days = round(duration.as('d')),\n months = round(duration.as('M')),\n weeks = round(duration.as('w')),\n years = round(duration.as('y')),\n a =\n (seconds <= thresholds.ss && ['s', seconds]) ||\n (seconds < thresholds.s && ['ss', seconds]) ||\n (minutes <= 1 && ['m']) ||\n (minutes < thresholds.m && ['mm', minutes]) ||\n (hours <= 1 && ['h']) ||\n (hours < thresholds.h && ['hh', hours]) ||\n (days <= 1 && ['d']) ||\n (days < thresholds.d && ['dd', days]);\n\n if (thresholds.w != null) {\n a =\n a ||\n (weeks <= 1 && ['w']) ||\n (weeks < thresholds.w && ['ww', weeks]);\n }\n a = a ||\n (months <= 1 && ['M']) ||\n (months < thresholds.M && ['MM', months]) ||\n (years <= 1 && ['y']) || ['yy', years];\n\n a[2] = withoutSuffix;\n a[3] = +posNegDuration > 0;\n a[4] = locale;\n return substituteTimeAgo.apply(null, a);\n }\n\n // This function allows you to set the rounding function for relative time strings\n function getSetRelativeTimeRounding(roundingFunction) {\n if (roundingFunction === undefined) {\n return round;\n }\n if (typeof roundingFunction === 'function') {\n round = roundingFunction;\n return true;\n }\n return false;\n }\n\n // This function allows you to set a threshold for relative time strings\n function getSetRelativeTimeThreshold(threshold, limit) {\n if (thresholds[threshold] === undefined) {\n return false;\n }\n if (limit === undefined) {\n return thresholds[threshold];\n }\n thresholds[threshold] = limit;\n if (threshold === 's') {\n thresholds.ss = limit - 1;\n }\n return true;\n }\n\n function humanize(argWithSuffix, argThresholds) {\n if (!this.isValid()) {\n return this.localeData().invalidDate();\n }\n\n var withSuffix = false,\n th = thresholds,\n locale,\n output;\n\n if (typeof argWithSuffix === 'object') {\n argThresholds = argWithSuffix;\n argWithSuffix = false;\n }\n if (typeof argWithSuffix === 'boolean') {\n withSuffix = argWithSuffix;\n }\n if (typeof argThresholds === 'object') {\n th = Object.assign({}, thresholds, argThresholds);\n if (argThresholds.s != null && argThresholds.ss == null) {\n th.ss = argThresholds.s - 1;\n }\n }\n\n locale = this.localeData();\n output = relativeTime$1(this, !withSuffix, th, locale);\n\n if (withSuffix) {\n output = locale.pastFuture(+this, output);\n }\n\n return locale.postformat(output);\n }\n\n var abs$1 = Math.abs;\n\n function sign(x) {\n return (x > 0) - (x < 0) || +x;\n }\n\n function toISOString$1() {\n // for ISO strings we do not use the normal bubbling rules:\n // * milliseconds bubble up until they become hours\n // * days do not bubble at all\n // * months bubble up until they become years\n // This is because there is no context-free conversion between hours and days\n // (think of clock changes)\n // and also not between days and months (28-31 days per month)\n if (!this.isValid()) {\n return this.localeData().invalidDate();\n }\n\n var seconds = abs$1(this._milliseconds) / 1000,\n days = abs$1(this._days),\n months = abs$1(this._months),\n minutes,\n hours,\n years,\n s,\n total = this.asSeconds(),\n totalSign,\n ymSign,\n daysSign,\n hmsSign;\n\n if (!total) {\n // this is the same as C#'s (Noda) and python (isodate)...\n // but not other JS (goog.date)\n return 'P0D';\n }\n\n // 3600 seconds -> 60 minutes -> 1 hour\n minutes = absFloor(seconds / 60);\n hours = absFloor(minutes / 60);\n seconds %= 60;\n minutes %= 60;\n\n // 12 months -> 1 year\n years = absFloor(months / 12);\n months %= 12;\n\n // inspired by https://github.com/dordille/moment-isoduration/blob/master/moment.isoduration.js\n s = seconds ? seconds.toFixed(3).replace(/\\.?0+$/, '') : '';\n\n totalSign = total < 0 ? '-' : '';\n ymSign = sign(this._months) !== sign(total) ? '-' : '';\n daysSign = sign(this._days) !== sign(total) ? '-' : '';\n hmsSign = sign(this._milliseconds) !== sign(total) ? '-' : '';\n\n return (\n totalSign +\n 'P' +\n (years ? ymSign + years + 'Y' : '') +\n (months ? ymSign + months + 'M' : '') +\n (days ? daysSign + days + 'D' : '') +\n (hours || minutes || seconds ? 'T' : '') +\n (hours ? hmsSign + hours + 'H' : '') +\n (minutes ? hmsSign + minutes + 'M' : '') +\n (seconds ? hmsSign + s + 'S' : '')\n );\n }\n\n var proto$2 = Duration.prototype;\n\n proto$2.isValid = isValid$1;\n proto$2.abs = abs;\n proto$2.add = add$1;\n proto$2.subtract = subtract$1;\n proto$2.as = as;\n proto$2.asMilliseconds = asMilliseconds;\n proto$2.asSeconds = asSeconds;\n proto$2.asMinutes = asMinutes;\n proto$2.asHours = asHours;\n proto$2.asDays = asDays;\n proto$2.asWeeks = asWeeks;\n proto$2.asMonths = asMonths;\n proto$2.asQuarters = asQuarters;\n proto$2.asYears = asYears;\n proto$2.valueOf = valueOf$1;\n proto$2._bubble = bubble;\n proto$2.clone = clone$1;\n proto$2.get = get$2;\n proto$2.milliseconds = milliseconds;\n proto$2.seconds = seconds;\n proto$2.minutes = minutes;\n proto$2.hours = hours;\n proto$2.days = days;\n proto$2.weeks = weeks;\n proto$2.months = months;\n proto$2.years = years;\n proto$2.humanize = humanize;\n proto$2.toISOString = toISOString$1;\n proto$2.toString = toISOString$1;\n proto$2.toJSON = toISOString$1;\n proto$2.locale = locale;\n proto$2.localeData = localeData;\n\n proto$2.toIsoString = deprecate(\n 'toIsoString() is deprecated. Please use toISOString() instead (notice the capitals)',\n toISOString$1\n );\n proto$2.lang = lang;\n\n // FORMATTING\n\n addFormatToken('X', 0, 0, 'unix');\n addFormatToken('x', 0, 0, 'valueOf');\n\n // PARSING\n\n addRegexToken('x', matchSigned);\n addRegexToken('X', matchTimestamp);\n addParseToken('X', function (input, array, config) {\n config._d = new Date(parseFloat(input) * 1000);\n });\n addParseToken('x', function (input, array, config) {\n config._d = new Date(toInt(input));\n });\n\n //! moment.js\n\n hooks.version = '2.30.1';\n\n setHookCallback(createLocal);\n\n hooks.fn = proto;\n hooks.min = min;\n hooks.max = max;\n hooks.now = now;\n hooks.utc = createUTC;\n hooks.unix = createUnix;\n hooks.months = listMonths;\n hooks.isDate = isDate;\n hooks.locale = getSetGlobalLocale;\n hooks.invalid = createInvalid;\n hooks.duration = createDuration;\n hooks.isMoment = isMoment;\n hooks.weekdays = listWeekdays;\n hooks.parseZone = createInZone;\n hooks.localeData = getLocale;\n hooks.isDuration = isDuration;\n hooks.monthsShort = listMonthsShort;\n hooks.weekdaysMin = listWeekdaysMin;\n hooks.defineLocale = defineLocale;\n hooks.updateLocale = updateLocale;\n hooks.locales = listLocales;\n hooks.weekdaysShort = listWeekdaysShort;\n hooks.normalizeUnits = normalizeUnits;\n hooks.relativeTimeRounding = getSetRelativeTimeRounding;\n hooks.relativeTimeThreshold = getSetRelativeTimeThreshold;\n hooks.calendarFormat = getCalendarFormat;\n hooks.prototype = proto;\n\n // currently HTML5 input type only supports 24-hour formats\n hooks.HTML5_FMT = {\n DATETIME_LOCAL: 'YYYY-MM-DDTHH:mm', // \n DATETIME_LOCAL_SECONDS: 'YYYY-MM-DDTHH:mm:ss', // \n DATETIME_LOCAL_MS: 'YYYY-MM-DDTHH:mm:ss.SSS', // \n DATE: 'YYYY-MM-DD', // \n TIME: 'HH:mm', // \n TIME_SECONDS: 'HH:mm:ss', // \n TIME_MS: 'HH:mm:ss.SSS', // \n WEEK: 'GGGG-[W]WW', // \n MONTH: 'YYYY-MM', // \n };\n\n return hooks;\n\n})));\n","'use strict'\n\nmodule.exports = mouseListen\n\nvar mouse = require('mouse-event')\n\nfunction mouseListen (element, callback) {\n if (!callback) {\n callback = element\n element = window\n }\n\n var buttonState = 0\n var x = 0\n var y = 0\n var mods = {\n shift: false,\n alt: false,\n control: false,\n meta: false\n }\n var attached = false\n\n function updateMods (ev) {\n var changed = false\n if ('altKey' in ev) {\n changed = changed || ev.altKey !== mods.alt\n mods.alt = !!ev.altKey\n }\n if ('shiftKey' in ev) {\n changed = changed || ev.shiftKey !== mods.shift\n mods.shift = !!ev.shiftKey\n }\n if ('ctrlKey' in ev) {\n changed = changed || ev.ctrlKey !== mods.control\n mods.control = !!ev.ctrlKey\n }\n if ('metaKey' in ev) {\n changed = changed || ev.metaKey !== mods.meta\n mods.meta = !!ev.metaKey\n }\n return changed\n }\n\n function handleEvent (nextButtons, ev) {\n var nextX = mouse.x(ev)\n var nextY = mouse.y(ev)\n if ('buttons' in ev) {\n nextButtons = ev.buttons | 0\n }\n if (nextButtons !== buttonState ||\n nextX !== x ||\n nextY !== y ||\n updateMods(ev)) {\n buttonState = nextButtons | 0\n x = nextX || 0\n y = nextY || 0\n callback && callback(buttonState, x, y, mods)\n }\n }\n\n function clearState (ev) {\n handleEvent(0, ev)\n }\n\n function handleBlur () {\n if (buttonState ||\n x ||\n y ||\n mods.shift ||\n mods.alt ||\n mods.meta ||\n mods.control) {\n x = y = 0\n buttonState = 0\n mods.shift = mods.alt = mods.control = mods.meta = false\n callback && callback(0, 0, 0, mods)\n }\n }\n\n function handleMods (ev) {\n if (updateMods(ev)) {\n callback && callback(buttonState, x, y, mods)\n }\n }\n\n function handleMouseMove (ev) {\n if (mouse.buttons(ev) === 0) {\n handleEvent(0, ev)\n } else {\n handleEvent(buttonState, ev)\n }\n }\n\n function handleMouseDown (ev) {\n handleEvent(buttonState | mouse.buttons(ev), ev)\n }\n\n function handleMouseUp (ev) {\n handleEvent(buttonState & ~mouse.buttons(ev), ev)\n }\n\n function attachListeners () {\n if (attached) {\n return\n }\n attached = true\n\n element.addEventListener('mousemove', handleMouseMove)\n\n element.addEventListener('mousedown', handleMouseDown)\n\n element.addEventListener('mouseup', handleMouseUp)\n\n element.addEventListener('mouseleave', clearState)\n element.addEventListener('mouseenter', clearState)\n element.addEventListener('mouseout', clearState)\n element.addEventListener('mouseover', clearState)\n\n element.addEventListener('blur', handleBlur)\n\n element.addEventListener('keyup', handleMods)\n element.addEventListener('keydown', handleMods)\n element.addEventListener('keypress', handleMods)\n\n if (element !== window) {\n window.addEventListener('blur', handleBlur)\n\n window.addEventListener('keyup', handleMods)\n window.addEventListener('keydown', handleMods)\n window.addEventListener('keypress', handleMods)\n }\n }\n\n function detachListeners () {\n if (!attached) {\n return\n }\n attached = false\n\n element.removeEventListener('mousemove', handleMouseMove)\n\n element.removeEventListener('mousedown', handleMouseDown)\n\n element.removeEventListener('mouseup', handleMouseUp)\n\n element.removeEventListener('mouseleave', clearState)\n element.removeEventListener('mouseenter', clearState)\n element.removeEventListener('mouseout', clearState)\n element.removeEventListener('mouseover', clearState)\n\n element.removeEventListener('blur', handleBlur)\n\n element.removeEventListener('keyup', handleMods)\n element.removeEventListener('keydown', handleMods)\n element.removeEventListener('keypress', handleMods)\n\n if (element !== window) {\n window.removeEventListener('blur', handleBlur)\n\n window.removeEventListener('keyup', handleMods)\n window.removeEventListener('keydown', handleMods)\n window.removeEventListener('keypress', handleMods)\n }\n }\n\n // Attach listeners\n attachListeners()\n\n var result = {\n element: element\n }\n\n Object.defineProperties(result, {\n enabled: {\n get: function () { return attached },\n set: function (f) {\n if (f) {\n attachListeners()\n } else {\n detachListeners()\n }\n },\n enumerable: true\n },\n buttons: {\n get: function () { return buttonState },\n enumerable: true\n },\n x: {\n get: function () { return x },\n enumerable: true\n },\n y: {\n get: function () { return y },\n enumerable: true\n },\n mods: {\n get: function () { return mods },\n enumerable: true\n }\n })\n\n return result\n}\n","var rootPosition = { left: 0, top: 0 }\n\nmodule.exports = mouseEventOffset\nfunction mouseEventOffset (ev, target, out) {\n target = target || ev.currentTarget || ev.srcElement\n if (!Array.isArray(out)) {\n out = [ 0, 0 ]\n }\n var cx = ev.clientX || 0\n var cy = ev.clientY || 0\n var rect = getBoundingClientOffset(target)\n out[0] = cx - rect.left\n out[1] = cy - rect.top\n return out\n}\n\nfunction getBoundingClientOffset (element) {\n if (element === window ||\n element === document ||\n element === document.body) {\n return rootPosition\n } else {\n return element.getBoundingClientRect()\n }\n}\n","'use strict'\n\nfunction mouseButtons(ev) {\n if(typeof ev === 'object') {\n if('buttons' in ev) {\n return ev.buttons\n } else if('which' in ev) {\n var b = ev.which\n if(b === 2) {\n return 4\n } else if(b === 3) {\n return 2\n } else if(b > 0) {\n return 1<<(b-1)\n }\n } else if('button' in ev) {\n var b = ev.button\n if(b === 1) {\n return 4\n } else if(b === 2) {\n return 2\n } else if(b >= 0) {\n return 1< 0) {\n\t\t\t\t\tschedule(notify,self);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tcatch (err) {\n\t\t\treject.call(new MakeDefWrapper(self),err);\n\t\t}\n\t}\n\n\tfunction reject(msg) {\n\t\tvar self = this;\n\n\t\t// already triggered?\n\t\tif (self.triggered) { return; }\n\n\t\tself.triggered = true;\n\n\t\t// unwrap\n\t\tif (self.def) {\n\t\t\tself = self.def;\n\t\t}\n\n\t\tself.msg = msg;\n\t\tself.state = 2;\n\t\tif (self.chain.length > 0) {\n\t\t\tschedule(notify,self);\n\t\t}\n\t}\n\n\tfunction iteratePromises(Constructor,arr,resolver,rejecter) {\n\t\tfor (var idx=0; idx 4) {\r\n bezierX = seg[seg.length - 4]\r\n bezierY = seg[seg.length - 3]\r\n } else {\r\n bezierX = x\r\n bezierY = y\r\n }\r\n result.push(seg)\r\n }\r\n\r\n return result\r\n}\r\n\r\nfunction line(x1, y1, x2, y2){\r\n return ['C', x1, y1, x2, y2, x2, y2]\r\n}\r\n\r\nfunction quadratic(x1, y1, cx, cy, x2, y2){\r\n return [\r\n 'C',\r\n x1/3 + (2/3) * cx,\r\n y1/3 + (2/3) * cy,\r\n x2/3 + (2/3) * cx,\r\n y2/3 + (2/3) * cy,\r\n x2,\r\n y2\r\n ]\r\n}\r\n","/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc'); // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","var hasMap = typeof Map === 'function' && Map.prototype;\nvar mapSizeDescriptor = Object.getOwnPropertyDescriptor && hasMap ? Object.getOwnPropertyDescriptor(Map.prototype, 'size') : null;\nvar mapSize = hasMap && mapSizeDescriptor && typeof mapSizeDescriptor.get === 'function' ? mapSizeDescriptor.get : null;\nvar mapForEach = hasMap && Map.prototype.forEach;\nvar hasSet = typeof Set === 'function' && Set.prototype;\nvar setSizeDescriptor = Object.getOwnPropertyDescriptor && hasSet ? Object.getOwnPropertyDescriptor(Set.prototype, 'size') : null;\nvar setSize = hasSet && setSizeDescriptor && typeof setSizeDescriptor.get === 'function' ? setSizeDescriptor.get : null;\nvar setForEach = hasSet && Set.prototype.forEach;\nvar hasWeakMap = typeof WeakMap === 'function' && WeakMap.prototype;\nvar weakMapHas = hasWeakMap ? WeakMap.prototype.has : null;\nvar hasWeakSet = typeof WeakSet === 'function' && WeakSet.prototype;\nvar weakSetHas = hasWeakSet ? WeakSet.prototype.has : null;\nvar hasWeakRef = typeof WeakRef === 'function' && WeakRef.prototype;\nvar weakRefDeref = hasWeakRef ? WeakRef.prototype.deref : null;\nvar booleanValueOf = Boolean.prototype.valueOf;\nvar objectToString = Object.prototype.toString;\nvar functionToString = Function.prototype.toString;\nvar $match = String.prototype.match;\nvar $slice = String.prototype.slice;\nvar $replace = String.prototype.replace;\nvar $toUpperCase = String.prototype.toUpperCase;\nvar $toLowerCase = String.prototype.toLowerCase;\nvar $test = RegExp.prototype.test;\nvar $concat = Array.prototype.concat;\nvar $join = Array.prototype.join;\nvar $arrSlice = Array.prototype.slice;\nvar $floor = Math.floor;\nvar bigIntValueOf = typeof BigInt === 'function' ? BigInt.prototype.valueOf : null;\nvar gOPS = Object.getOwnPropertySymbols;\nvar symToString = typeof Symbol === 'function' && typeof Symbol.iterator === 'symbol' ? Symbol.prototype.toString : null;\nvar hasShammedSymbols = typeof Symbol === 'function' && typeof Symbol.iterator === 'object';\n// ie, `has-tostringtag/shams\nvar toStringTag = typeof Symbol === 'function' && Symbol.toStringTag && (typeof Symbol.toStringTag === hasShammedSymbols ? 'object' : 'symbol')\n ? Symbol.toStringTag\n : null;\nvar isEnumerable = Object.prototype.propertyIsEnumerable;\n\nvar gPO = (typeof Reflect === 'function' ? Reflect.getPrototypeOf : Object.getPrototypeOf) || (\n [].__proto__ === Array.prototype // eslint-disable-line no-proto\n ? function (O) {\n return O.__proto__; // eslint-disable-line no-proto\n }\n : null\n);\n\nfunction addNumericSeparator(num, str) {\n if (\n num === Infinity\n || num === -Infinity\n || num !== num\n || (num && num > -1000 && num < 1000)\n || $test.call(/e/, str)\n ) {\n return str;\n }\n var sepRegex = /[0-9](?=(?:[0-9]{3})+(?![0-9]))/g;\n if (typeof num === 'number') {\n var int = num < 0 ? -$floor(-num) : $floor(num); // trunc(num)\n if (int !== num) {\n var intStr = String(int);\n var dec = $slice.call(str, intStr.length + 1);\n return $replace.call(intStr, sepRegex, '$&_') + '.' + $replace.call($replace.call(dec, /([0-9]{3})/g, '$&_'), /_$/, '');\n }\n }\n return $replace.call(str, sepRegex, '$&_');\n}\n\nvar utilInspect = require('./util.inspect');\nvar inspectCustom = utilInspect.custom;\nvar inspectSymbol = isSymbol(inspectCustom) ? inspectCustom : null;\n\nvar quotes = {\n __proto__: null,\n 'double': '\"',\n single: \"'\"\n};\nvar quoteREs = {\n __proto__: null,\n 'double': /([\"\\\\])/g,\n single: /(['\\\\])/g\n};\n\nmodule.exports = function inspect_(obj, options, depth, seen) {\n var opts = options || {};\n\n if (has(opts, 'quoteStyle') && !has(quotes, opts.quoteStyle)) {\n throw new TypeError('option \"quoteStyle\" must be \"single\" or \"double\"');\n }\n if (\n has(opts, 'maxStringLength') && (typeof opts.maxStringLength === 'number'\n ? opts.maxStringLength < 0 && opts.maxStringLength !== Infinity\n : opts.maxStringLength !== null\n )\n ) {\n throw new TypeError('option \"maxStringLength\", if provided, must be a positive integer, Infinity, or `null`');\n }\n var customInspect = has(opts, 'customInspect') ? opts.customInspect : true;\n if (typeof customInspect !== 'boolean' && customInspect !== 'symbol') {\n throw new TypeError('option \"customInspect\", if provided, must be `true`, `false`, or `\\'symbol\\'`');\n }\n\n if (\n has(opts, 'indent')\n && opts.indent !== null\n && opts.indent !== '\\t'\n && !(parseInt(opts.indent, 10) === opts.indent && opts.indent > 0)\n ) {\n throw new TypeError('option \"indent\" must be \"\\\\t\", an integer > 0, or `null`');\n }\n if (has(opts, 'numericSeparator') && typeof opts.numericSeparator !== 'boolean') {\n throw new TypeError('option \"numericSeparator\", if provided, must be `true` or `false`');\n }\n var numericSeparator = opts.numericSeparator;\n\n if (typeof obj === 'undefined') {\n return 'undefined';\n }\n if (obj === null) {\n return 'null';\n }\n if (typeof obj === 'boolean') {\n return obj ? 'true' : 'false';\n }\n\n if (typeof obj === 'string') {\n return inspectString(obj, opts);\n }\n if (typeof obj === 'number') {\n if (obj === 0) {\n return Infinity / obj > 0 ? '0' : '-0';\n }\n var str = String(obj);\n return numericSeparator ? addNumericSeparator(obj, str) : str;\n }\n if (typeof obj === 'bigint') {\n var bigIntStr = String(obj) + 'n';\n return numericSeparator ? addNumericSeparator(obj, bigIntStr) : bigIntStr;\n }\n\n var maxDepth = typeof opts.depth === 'undefined' ? 5 : opts.depth;\n if (typeof depth === 'undefined') { depth = 0; }\n if (depth >= maxDepth && maxDepth > 0 && typeof obj === 'object') {\n return isArray(obj) ? '[Array]' : '[Object]';\n }\n\n var indent = getIndent(opts, depth);\n\n if (typeof seen === 'undefined') {\n seen = [];\n } else if (indexOf(seen, obj) >= 0) {\n return '[Circular]';\n }\n\n function inspect(value, from, noIndent) {\n if (from) {\n seen = $arrSlice.call(seen);\n seen.push(from);\n }\n if (noIndent) {\n var newOpts = {\n depth: opts.depth\n };\n if (has(opts, 'quoteStyle')) {\n newOpts.quoteStyle = opts.quoteStyle;\n }\n return inspect_(value, newOpts, depth + 1, seen);\n }\n return inspect_(value, opts, depth + 1, seen);\n }\n\n if (typeof obj === 'function' && !isRegExp(obj)) { // in older engines, regexes are callable\n var name = nameOf(obj);\n var keys = arrObjKeys(obj, inspect);\n return '[Function' + (name ? ': ' + name : ' (anonymous)') + ']' + (keys.length > 0 ? ' { ' + $join.call(keys, ', ') + ' }' : '');\n }\n if (isSymbol(obj)) {\n var symString = hasShammedSymbols ? $replace.call(String(obj), /^(Symbol\\(.*\\))_[^)]*$/, '$1') : symToString.call(obj);\n return typeof obj === 'object' && !hasShammedSymbols ? markBoxed(symString) : symString;\n }\n if (isElement(obj)) {\n var s = '<' + $toLowerCase.call(String(obj.nodeName));\n var attrs = obj.attributes || [];\n for (var i = 0; i < attrs.length; i++) {\n s += ' ' + attrs[i].name + '=' + wrapQuotes(quote(attrs[i].value), 'double', opts);\n }\n s += '>';\n if (obj.childNodes && obj.childNodes.length) { s += '...'; }\n s += '';\n return s;\n }\n if (isArray(obj)) {\n if (obj.length === 0) { return '[]'; }\n var xs = arrObjKeys(obj, inspect);\n if (indent && !singleLineValues(xs)) {\n return '[' + indentedJoin(xs, indent) + ']';\n }\n return '[ ' + $join.call(xs, ', ') + ' ]';\n }\n if (isError(obj)) {\n var parts = arrObjKeys(obj, inspect);\n if (!('cause' in Error.prototype) && 'cause' in obj && !isEnumerable.call(obj, 'cause')) {\n return '{ [' + String(obj) + '] ' + $join.call($concat.call('[cause]: ' + inspect(obj.cause), parts), ', ') + ' }';\n }\n if (parts.length === 0) { return '[' + String(obj) + ']'; }\n return '{ [' + String(obj) + '] ' + $join.call(parts, ', ') + ' }';\n }\n if (typeof obj === 'object' && customInspect) {\n if (inspectSymbol && typeof obj[inspectSymbol] === 'function' && utilInspect) {\n return utilInspect(obj, { depth: maxDepth - depth });\n } else if (customInspect !== 'symbol' && typeof obj.inspect === 'function') {\n return obj.inspect();\n }\n }\n if (isMap(obj)) {\n var mapParts = [];\n if (mapForEach) {\n mapForEach.call(obj, function (value, key) {\n mapParts.push(inspect(key, obj, true) + ' => ' + inspect(value, obj));\n });\n }\n return collectionOf('Map', mapSize.call(obj), mapParts, indent);\n }\n if (isSet(obj)) {\n var setParts = [];\n if (setForEach) {\n setForEach.call(obj, function (value) {\n setParts.push(inspect(value, obj));\n });\n }\n return collectionOf('Set', setSize.call(obj), setParts, indent);\n }\n if (isWeakMap(obj)) {\n return weakCollectionOf('WeakMap');\n }\n if (isWeakSet(obj)) {\n return weakCollectionOf('WeakSet');\n }\n if (isWeakRef(obj)) {\n return weakCollectionOf('WeakRef');\n }\n if (isNumber(obj)) {\n return markBoxed(inspect(Number(obj)));\n }\n if (isBigInt(obj)) {\n return markBoxed(inspect(bigIntValueOf.call(obj)));\n }\n if (isBoolean(obj)) {\n return markBoxed(booleanValueOf.call(obj));\n }\n if (isString(obj)) {\n return markBoxed(inspect(String(obj)));\n }\n // note: in IE 8, sometimes `global !== window` but both are the prototypes of each other\n /* eslint-env browser */\n if (typeof window !== 'undefined' && obj === window) {\n return '{ [object Window] }';\n }\n if (\n (typeof globalThis !== 'undefined' && obj === globalThis)\n || (typeof global !== 'undefined' && obj === global)\n ) {\n return '{ [object globalThis] }';\n }\n if (!isDate(obj) && !isRegExp(obj)) {\n var ys = arrObjKeys(obj, inspect);\n var isPlainObject = gPO ? gPO(obj) === Object.prototype : obj instanceof Object || obj.constructor === Object;\n var protoTag = obj instanceof Object ? '' : 'null prototype';\n var stringTag = !isPlainObject && toStringTag && Object(obj) === obj && toStringTag in obj ? $slice.call(toStr(obj), 8, -1) : protoTag ? 'Object' : '';\n var constructorTag = isPlainObject || typeof obj.constructor !== 'function' ? '' : obj.constructor.name ? obj.constructor.name + ' ' : '';\n var tag = constructorTag + (stringTag || protoTag ? '[' + $join.call($concat.call([], stringTag || [], protoTag || []), ': ') + '] ' : '');\n if (ys.length === 0) { return tag + '{}'; }\n if (indent) {\n return tag + '{' + indentedJoin(ys, indent) + '}';\n }\n return tag + '{ ' + $join.call(ys, ', ') + ' }';\n }\n return String(obj);\n};\n\nfunction wrapQuotes(s, defaultStyle, opts) {\n var style = opts.quoteStyle || defaultStyle;\n var quoteChar = quotes[style];\n return quoteChar + s + quoteChar;\n}\n\nfunction quote(s) {\n return $replace.call(String(s), /\"/g, '"');\n}\n\nfunction isArray(obj) { return toStr(obj) === '[object Array]' && (!toStringTag || !(typeof obj === 'object' && toStringTag in obj)); }\nfunction isDate(obj) { return toStr(obj) === '[object Date]' && (!toStringTag || !(typeof obj === 'object' && toStringTag in obj)); }\nfunction isRegExp(obj) { return toStr(obj) === '[object RegExp]' && (!toStringTag || !(typeof obj === 'object' && toStringTag in obj)); }\nfunction isError(obj) { return toStr(obj) === '[object Error]' && (!toStringTag || !(typeof obj === 'object' && toStringTag in obj)); }\nfunction isString(obj) { return toStr(obj) === '[object String]' && (!toStringTag || !(typeof obj === 'object' && toStringTag in obj)); }\nfunction isNumber(obj) { return toStr(obj) === '[object Number]' && (!toStringTag || !(typeof obj === 'object' && toStringTag in obj)); }\nfunction isBoolean(obj) { return toStr(obj) === '[object Boolean]' && (!toStringTag || !(typeof obj === 'object' && toStringTag in obj)); }\n\n// Symbol and BigInt do have Symbol.toStringTag by spec, so that can't be used to eliminate false positives\nfunction isSymbol(obj) {\n if (hasShammedSymbols) {\n return obj && typeof obj === 'object' && obj instanceof Symbol;\n }\n if (typeof obj === 'symbol') {\n return true;\n }\n if (!obj || typeof obj !== 'object' || !symToString) {\n return false;\n }\n try {\n symToString.call(obj);\n return true;\n } catch (e) {}\n return false;\n}\n\nfunction isBigInt(obj) {\n if (!obj || typeof obj !== 'object' || !bigIntValueOf) {\n return false;\n }\n try {\n bigIntValueOf.call(obj);\n return true;\n } catch (e) {}\n return false;\n}\n\nvar hasOwn = Object.prototype.hasOwnProperty || function (key) { return key in this; };\nfunction has(obj, key) {\n return hasOwn.call(obj, key);\n}\n\nfunction toStr(obj) {\n return objectToString.call(obj);\n}\n\nfunction nameOf(f) {\n if (f.name) { return f.name; }\n var m = $match.call(functionToString.call(f), /^function\\s*([\\w$]+)/);\n if (m) { return m[1]; }\n return null;\n}\n\nfunction indexOf(xs, x) {\n if (xs.indexOf) { return xs.indexOf(x); }\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) { return i; }\n }\n return -1;\n}\n\nfunction isMap(x) {\n if (!mapSize || !x || typeof x !== 'object') {\n return false;\n }\n try {\n mapSize.call(x);\n try {\n setSize.call(x);\n } catch (s) {\n return true;\n }\n return x instanceof Map; // core-js workaround, pre-v2.5.0\n } catch (e) {}\n return false;\n}\n\nfunction isWeakMap(x) {\n if (!weakMapHas || !x || typeof x !== 'object') {\n return false;\n }\n try {\n weakMapHas.call(x, weakMapHas);\n try {\n weakSetHas.call(x, weakSetHas);\n } catch (s) {\n return true;\n }\n return x instanceof WeakMap; // core-js workaround, pre-v2.5.0\n } catch (e) {}\n return false;\n}\n\nfunction isWeakRef(x) {\n if (!weakRefDeref || !x || typeof x !== 'object') {\n return false;\n }\n try {\n weakRefDeref.call(x);\n return true;\n } catch (e) {}\n return false;\n}\n\nfunction isSet(x) {\n if (!setSize || !x || typeof x !== 'object') {\n return false;\n }\n try {\n setSize.call(x);\n try {\n mapSize.call(x);\n } catch (m) {\n return true;\n }\n return x instanceof Set; // core-js workaround, pre-v2.5.0\n } catch (e) {}\n return false;\n}\n\nfunction isWeakSet(x) {\n if (!weakSetHas || !x || typeof x !== 'object') {\n return false;\n }\n try {\n weakSetHas.call(x, weakSetHas);\n try {\n weakMapHas.call(x, weakMapHas);\n } catch (s) {\n return true;\n }\n return x instanceof WeakSet; // core-js workaround, pre-v2.5.0\n } catch (e) {}\n return false;\n}\n\nfunction isElement(x) {\n if (!x || typeof x !== 'object') { return false; }\n if (typeof HTMLElement !== 'undefined' && x instanceof HTMLElement) {\n return true;\n }\n return typeof x.nodeName === 'string' && typeof x.getAttribute === 'function';\n}\n\nfunction inspectString(str, opts) {\n if (str.length > opts.maxStringLength) {\n var remaining = str.length - opts.maxStringLength;\n var trailer = '... ' + remaining + ' more character' + (remaining > 1 ? 's' : '');\n return inspectString($slice.call(str, 0, opts.maxStringLength), opts) + trailer;\n }\n var quoteRE = quoteREs[opts.quoteStyle || 'single'];\n quoteRE.lastIndex = 0;\n // eslint-disable-next-line no-control-regex\n var s = $replace.call($replace.call(str, quoteRE, '\\\\$1'), /[\\x00-\\x1f]/g, lowbyte);\n return wrapQuotes(s, 'single', opts);\n}\n\nfunction lowbyte(c) {\n var n = c.charCodeAt(0);\n var x = {\n 8: 'b',\n 9: 't',\n 10: 'n',\n 12: 'f',\n 13: 'r'\n }[n];\n if (x) { return '\\\\' + x; }\n return '\\\\x' + (n < 0x10 ? '0' : '') + $toUpperCase.call(n.toString(16));\n}\n\nfunction markBoxed(str) {\n return 'Object(' + str + ')';\n}\n\nfunction weakCollectionOf(type) {\n return type + ' { ? }';\n}\n\nfunction collectionOf(type, size, entries, indent) {\n var joinedEntries = indent ? indentedJoin(entries, indent) : $join.call(entries, ', ');\n return type + ' (' + size + ') {' + joinedEntries + '}';\n}\n\nfunction singleLineValues(xs) {\n for (var i = 0; i < xs.length; i++) {\n if (indexOf(xs[i], '\\n') >= 0) {\n return false;\n }\n }\n return true;\n}\n\nfunction getIndent(opts, depth) {\n var baseIndent;\n if (opts.indent === '\\t') {\n baseIndent = '\\t';\n } else if (typeof opts.indent === 'number' && opts.indent > 0) {\n baseIndent = $join.call(Array(opts.indent + 1), ' ');\n } else {\n return null;\n }\n return {\n base: baseIndent,\n prev: $join.call(Array(depth + 1), baseIndent)\n };\n}\n\nfunction indentedJoin(xs, indent) {\n if (xs.length === 0) { return ''; }\n var lineJoiner = '\\n' + indent.prev + indent.base;\n return lineJoiner + $join.call(xs, ',' + lineJoiner) + '\\n' + indent.prev;\n}\n\nfunction arrObjKeys(obj, inspect) {\n var isArr = isArray(obj);\n var xs = [];\n if (isArr) {\n xs.length = obj.length;\n for (var i = 0; i < obj.length; i++) {\n xs[i] = has(obj, i) ? inspect(obj[i], obj) : '';\n }\n }\n var syms = typeof gOPS === 'function' ? gOPS(obj) : [];\n var symMap;\n if (hasShammedSymbols) {\n symMap = {};\n for (var k = 0; k < syms.length; k++) {\n symMap['$' + syms[k]] = syms[k];\n }\n }\n\n for (var key in obj) { // eslint-disable-line no-restricted-syntax\n if (!has(obj, key)) { continue; } // eslint-disable-line no-restricted-syntax, no-continue\n if (isArr && String(Number(key)) === key && key < obj.length) { continue; } // eslint-disable-line no-restricted-syntax, no-continue\n if (hasShammedSymbols && symMap['$' + key] instanceof Symbol) {\n // this is to prevent shammed Symbols, which are stored as strings, from being included in the string key section\n continue; // eslint-disable-line no-restricted-syntax, no-continue\n } else if ($test.call(/[^\\w$]/, key)) {\n xs.push(inspect(key, obj) + ': ' + inspect(obj[key], obj));\n } else {\n xs.push(key + ': ' + inspect(obj[key], obj));\n }\n }\n if (typeof gOPS === 'function') {\n for (var j = 0; j < syms.length; j++) {\n if (isEnumerable.call(obj, syms[j])) {\n xs.push('[' + inspect(syms[j]) + ']: ' + inspect(obj[syms[j]], obj));\n }\n }\n }\n return xs;\n}\n","'use strict';\n\nvar numberIsNaN = function (value) {\n\treturn value !== value;\n};\n\nmodule.exports = function is(a, b) {\n\tif (a === 0 && b === 0) {\n\t\treturn 1 / a === 1 / b;\n\t}\n\tif (a === b) {\n\t\treturn true;\n\t}\n\tif (numberIsNaN(a) && numberIsNaN(b)) {\n\t\treturn true;\n\t}\n\treturn false;\n};\n\n","'use strict';\n\nvar define = require('define-properties');\nvar callBind = require('call-bind');\n\nvar implementation = require('./implementation');\nvar getPolyfill = require('./polyfill');\nvar shim = require('./shim');\n\nvar polyfill = callBind(getPolyfill(), Object);\n\ndefine(polyfill, {\n\tgetPolyfill: getPolyfill,\n\timplementation: implementation,\n\tshim: shim\n});\n\nmodule.exports = polyfill;\n","'use strict';\n\nvar implementation = require('./implementation');\n\nmodule.exports = function getPolyfill() {\n\treturn typeof Object.is === 'function' ? Object.is : implementation;\n};\n","'use strict';\n\nvar getPolyfill = require('./polyfill');\nvar define = require('define-properties');\n\nmodule.exports = function shimObjectIs() {\n\tvar polyfill = getPolyfill();\n\tdefine(Object, { is: polyfill }, {\n\t\tis: function testObjectIs() {\n\t\t\treturn Object.is !== polyfill;\n\t\t}\n\t});\n\treturn polyfill;\n};\n","'use strict';\n\nvar keysShim;\nif (!Object.keys) {\n\t// modified from https://github.com/es-shims/es5-shim\n\tvar has = Object.prototype.hasOwnProperty;\n\tvar toStr = Object.prototype.toString;\n\tvar isArgs = require('./isArguments'); // eslint-disable-line global-require\n\tvar isEnumerable = Object.prototype.propertyIsEnumerable;\n\tvar hasDontEnumBug = !isEnumerable.call({ toString: null }, 'toString');\n\tvar hasProtoEnumBug = isEnumerable.call(function () {}, 'prototype');\n\tvar dontEnums = [\n\t\t'toString',\n\t\t'toLocaleString',\n\t\t'valueOf',\n\t\t'hasOwnProperty',\n\t\t'isPrototypeOf',\n\t\t'propertyIsEnumerable',\n\t\t'constructor'\n\t];\n\tvar equalsConstructorPrototype = function (o) {\n\t\tvar ctor = o.constructor;\n\t\treturn ctor && ctor.prototype === o;\n\t};\n\tvar excludedKeys = {\n\t\t$applicationCache: true,\n\t\t$console: true,\n\t\t$external: true,\n\t\t$frame: true,\n\t\t$frameElement: true,\n\t\t$frames: true,\n\t\t$innerHeight: true,\n\t\t$innerWidth: true,\n\t\t$onmozfullscreenchange: true,\n\t\t$onmozfullscreenerror: true,\n\t\t$outerHeight: true,\n\t\t$outerWidth: true,\n\t\t$pageXOffset: true,\n\t\t$pageYOffset: true,\n\t\t$parent: true,\n\t\t$scrollLeft: true,\n\t\t$scrollTop: true,\n\t\t$scrollX: true,\n\t\t$scrollY: true,\n\t\t$self: true,\n\t\t$webkitIndexedDB: true,\n\t\t$webkitStorageInfo: true,\n\t\t$window: true\n\t};\n\tvar hasAutomationEqualityBug = (function () {\n\t\t/* global window */\n\t\tif (typeof window === 'undefined') { return false; }\n\t\tfor (var k in window) {\n\t\t\ttry {\n\t\t\t\tif (!excludedKeys['$' + k] && has.call(window, k) && window[k] !== null && typeof window[k] === 'object') {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tequalsConstructorPrototype(window[k]);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t\treturn false;\n\t}());\n\tvar equalsConstructorPrototypeIfNotBuggy = function (o) {\n\t\t/* global window */\n\t\tif (typeof window === 'undefined' || !hasAutomationEqualityBug) {\n\t\t\treturn equalsConstructorPrototype(o);\n\t\t}\n\t\ttry {\n\t\t\treturn equalsConstructorPrototype(o);\n\t\t} catch (e) {\n\t\t\treturn false;\n\t\t}\n\t};\n\n\tkeysShim = function keys(object) {\n\t\tvar isObject = object !== null && typeof object === 'object';\n\t\tvar isFunction = toStr.call(object) === '[object Function]';\n\t\tvar isArguments = isArgs(object);\n\t\tvar isString = isObject && toStr.call(object) === '[object String]';\n\t\tvar theKeys = [];\n\n\t\tif (!isObject && !isFunction && !isArguments) {\n\t\t\tthrow new TypeError('Object.keys called on a non-object');\n\t\t}\n\n\t\tvar skipProto = hasProtoEnumBug && isFunction;\n\t\tif (isString && object.length > 0 && !has.call(object, 0)) {\n\t\t\tfor (var i = 0; i < object.length; ++i) {\n\t\t\t\ttheKeys.push(String(i));\n\t\t\t}\n\t\t}\n\n\t\tif (isArguments && object.length > 0) {\n\t\t\tfor (var j = 0; j < object.length; ++j) {\n\t\t\t\ttheKeys.push(String(j));\n\t\t\t}\n\t\t} else {\n\t\t\tfor (var name in object) {\n\t\t\t\tif (!(skipProto && name === 'prototype') && has.call(object, name)) {\n\t\t\t\t\ttheKeys.push(String(name));\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (hasDontEnumBug) {\n\t\t\tvar skipConstructor = equalsConstructorPrototypeIfNotBuggy(object);\n\n\t\t\tfor (var k = 0; k < dontEnums.length; ++k) {\n\t\t\t\tif (!(skipConstructor && dontEnums[k] === 'constructor') && has.call(object, dontEnums[k])) {\n\t\t\t\t\ttheKeys.push(dontEnums[k]);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn theKeys;\n\t};\n}\nmodule.exports = keysShim;\n","'use strict';\n\nvar slice = Array.prototype.slice;\nvar isArgs = require('./isArguments');\n\nvar origKeys = Object.keys;\nvar keysShim = origKeys ? function keys(o) { return origKeys(o); } : require('./implementation');\n\nvar originalKeys = Object.keys;\n\nkeysShim.shim = function shimObjectKeys() {\n\tif (Object.keys) {\n\t\tvar keysWorksWithArguments = (function () {\n\t\t\t// Safari 5.0 bug\n\t\t\tvar args = Object.keys(arguments);\n\t\t\treturn args && args.length === arguments.length;\n\t\t}(1, 2));\n\t\tif (!keysWorksWithArguments) {\n\t\t\tObject.keys = function keys(object) { // eslint-disable-line func-name-matching\n\t\t\t\tif (isArgs(object)) {\n\t\t\t\t\treturn originalKeys(slice.call(object));\n\t\t\t\t}\n\t\t\t\treturn originalKeys(object);\n\t\t\t};\n\t\t}\n\t} else {\n\t\tObject.keys = keysShim;\n\t}\n\treturn Object.keys || keysShim;\n};\n\nmodule.exports = keysShim;\n","'use strict';\n\nvar toStr = Object.prototype.toString;\n\nmodule.exports = function isArguments(value) {\n\tvar str = toStr.call(value);\n\tvar isArgs = str === '[object Arguments]';\n\tif (!isArgs) {\n\t\tisArgs = str !== '[object Array]' &&\n\t\t\tvalue !== null &&\n\t\t\ttypeof value === 'object' &&\n\t\t\ttypeof value.length === 'number' &&\n\t\t\tvalue.length >= 0 &&\n\t\t\ttoStr.call(value.callee) === '[object Function]';\n\t}\n\treturn isArgs;\n};\n","'use strict';\n\n// modified from https://github.com/es-shims/es6-shim\nvar objectKeys = require('object-keys');\nvar hasSymbols = require('has-symbols/shams')();\nvar callBound = require('call-bind/callBound');\nvar toObject = Object;\nvar $push = callBound('Array.prototype.push');\nvar $propIsEnumerable = callBound('Object.prototype.propertyIsEnumerable');\nvar originalGetSymbols = hasSymbols ? Object.getOwnPropertySymbols : null;\n\n// eslint-disable-next-line no-unused-vars\nmodule.exports = function assign(target, source1) {\n\tif (target == null) { throw new TypeError('target must be an object'); }\n\tvar to = toObject(target); // step 1\n\tif (arguments.length === 1) {\n\t\treturn to; // step 2\n\t}\n\tfor (var s = 1; s < arguments.length; ++s) {\n\t\tvar from = toObject(arguments[s]); // step 3.a.i\n\n\t\t// step 3.a.ii:\n\t\tvar keys = objectKeys(from);\n\t\tvar getSymbols = hasSymbols && (Object.getOwnPropertySymbols || originalGetSymbols);\n\t\tif (getSymbols) {\n\t\t\tvar syms = getSymbols(from);\n\t\t\tfor (var j = 0; j < syms.length; ++j) {\n\t\t\t\tvar key = syms[j];\n\t\t\t\tif ($propIsEnumerable(from, key)) {\n\t\t\t\t\t$push(keys, key);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// step 3.a.iii:\n\t\tfor (var i = 0; i < keys.length; ++i) {\n\t\t\tvar nextKey = keys[i];\n\t\t\tif ($propIsEnumerable(from, nextKey)) { // step 3.a.iii.2\n\t\t\t\tvar propValue = from[nextKey]; // step 3.a.iii.2.a\n\t\t\t\tto[nextKey] = propValue; // step 3.a.iii.2.b\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to; // step 4\n};\n","'use strict';\n\nvar implementation = require('./implementation');\n\nvar lacksProperEnumerationOrder = function () {\n\tif (!Object.assign) {\n\t\treturn false;\n\t}\n\t/*\n\t * v8, specifically in node 4.x, has a bug with incorrect property enumeration order\n\t * note: this does not detect the bug unless there's 20 characters\n\t */\n\tvar str = 'abcdefghijklmnopqrst';\n\tvar letters = str.split('');\n\tvar map = {};\n\tfor (var i = 0; i < letters.length; ++i) {\n\t\tmap[letters[i]] = letters[i];\n\t}\n\tvar obj = Object.assign({}, map);\n\tvar actual = '';\n\tfor (var k in obj) {\n\t\tactual += k;\n\t}\n\treturn str !== actual;\n};\n\nvar assignHasPendingExceptions = function () {\n\tif (!Object.assign || !Object.preventExtensions) {\n\t\treturn false;\n\t}\n\t/*\n\t * Firefox 37 still has \"pending exception\" logic in its Object.assign implementation,\n\t * which is 72% slower than our shim, and Firefox 40's native implementation.\n\t */\n\tvar thrower = Object.preventExtensions({ 1: 2 });\n\ttry {\n\t\tObject.assign(thrower, 'xy');\n\t} catch (e) {\n\t\treturn thrower[1] === 'y';\n\t}\n\treturn false;\n};\n\nmodule.exports = function getPolyfill() {\n\tif (!Object.assign) {\n\t\treturn implementation;\n\t}\n\tif (lacksProperEnumerationOrder()) {\n\t\treturn implementation;\n\t}\n\tif (assignHasPendingExceptions()) {\n\t\treturn implementation;\n\t}\n\treturn Object.assign;\n};\n","'use strict'\r\n\r\n/**\r\n * @module parenthesis\r\n */\r\n\r\nfunction parse (str, opts) {\r\n\t// pretend non-string parsed per-se\r\n\tif (typeof str !== 'string') return [str]\r\n\r\n\tvar res = [str]\r\n\r\n\tif (typeof opts === 'string' || Array.isArray(opts)) {\r\n\t\topts = {brackets: opts}\r\n\t}\r\n\telse if (!opts) opts = {}\r\n\r\n\tvar brackets = opts.brackets ? (Array.isArray(opts.brackets) ? opts.brackets : [opts.brackets]) : ['{}', '[]', '()']\r\n\r\n\tvar escape = opts.escape || '___'\r\n\r\n\tvar flat = !!opts.flat\r\n\r\n\tbrackets.forEach(function (bracket) {\r\n\t\t// create parenthesis regex\r\n\t\tvar pRE = new RegExp(['\\\\', bracket[0], '[^\\\\', bracket[0], '\\\\', bracket[1], ']*\\\\', bracket[1]].join(''))\r\n\r\n\t\tvar ids = []\r\n\r\n\t\tfunction replaceToken(token, idx, str){\r\n\t\t\t// save token to res\r\n\t\t\tvar refId = res.push(token.slice(bracket[0].length, -bracket[1].length)) - 1\r\n\r\n\t\t\tids.push(refId)\r\n\r\n\t\t\treturn escape + refId + escape\r\n\t\t}\r\n\r\n\t\tres.forEach(function (str, i) {\r\n\t\t\tvar prevStr\r\n\r\n\t\t\t// replace paren tokens till there’s none\r\n\t\t\tvar a = 0\r\n\t\t\twhile (str != prevStr) {\r\n\t\t\t\tprevStr = str\r\n\t\t\t\tstr = str.replace(pRE, replaceToken)\r\n\t\t\t\tif (a++ > 10e3) throw Error('References have circular dependency. Please, check them.')\r\n\t\t\t}\r\n\r\n\t\t\tres[i] = str\r\n\t\t})\r\n\r\n\t\t// wrap found refs to brackets\r\n\t\tids = ids.reverse()\r\n\t\tres = res.map(function (str) {\r\n\t\t\tids.forEach(function (id) {\r\n\t\t\t\tstr = str.replace(new RegExp('(\\\\' + escape + id + '\\\\' + escape + ')', 'g'), bracket[0] + '$1' + bracket[1])\r\n\t\t\t})\r\n\t\t\treturn str\r\n\t\t})\r\n\t})\r\n\r\n\tvar re = new RegExp('\\\\' + escape + '([0-9]+)' + '\\\\' + escape)\r\n\r\n\t// transform references to tree\r\n\tfunction nest (str, refs, escape) {\r\n\t\tvar res = [], match\r\n\r\n\t\tvar a = 0\r\n\t\twhile (match = re.exec(str)) {\r\n\t\t\tif (a++ > 10e3) throw Error('Circular references in parenthesis')\r\n\r\n\t\t\tres.push(str.slice(0, match.index))\r\n\r\n\t\t\tres.push(nest(refs[match[1]], refs))\r\n\r\n\t\t\tstr = str.slice(match.index + match[0].length)\r\n\t\t}\r\n\r\n\t\tres.push(str)\r\n\r\n\t\treturn res\r\n\t}\r\n\r\n\treturn flat ? res : nest(res[0], res)\r\n}\r\n\r\nfunction stringify (arg, opts) {\r\n\tif (opts && opts.flat) {\r\n\t\tvar escape = opts && opts.escape || '___'\r\n\r\n\t\tvar str = arg[0], prevStr\r\n\r\n\t\t// pretend bad string stringified with no parentheses\r\n\t\tif (!str) return ''\r\n\r\n\r\n\t\tvar re = new RegExp('\\\\' + escape + '([0-9]+)' + '\\\\' + escape)\r\n\r\n\t\tvar a = 0\r\n\t\twhile (str != prevStr) {\r\n\t\t\tif (a++ > 10e3) throw Error('Circular references in ' + arg)\r\n\t\t\tprevStr = str\r\n\t\t\tstr = str.replace(re, replaceRef)\r\n\t\t}\r\n\r\n\t\treturn str\r\n\t}\r\n\r\n\treturn arg.reduce(function f (prev, curr) {\r\n\t\tif (Array.isArray(curr)) {\r\n\t\t\tcurr = curr.reduce(f, '')\r\n\t\t}\r\n\t\treturn prev + curr\r\n\t}, '')\r\n\r\n\tfunction replaceRef(match, idx){\r\n\t\tif (arg[idx] == null) throw Error('Reference ' + idx + 'is undefined')\r\n\t\treturn arg[idx]\r\n\t}\r\n}\r\n\r\nfunction parenthesis (arg, opts) {\r\n\tif (Array.isArray(arg)) {\r\n\t\treturn stringify(arg, opts)\r\n\t}\r\n\telse {\r\n\t\treturn parse(arg, opts)\r\n\t}\r\n}\r\n\r\nparenthesis.parse = parse\r\nparenthesis.stringify = stringify\r\n\r\nmodule.exports = parenthesis\r\n","'use strict'\r\n\r\nvar pick = require('pick-by-alias')\r\n\r\nmodule.exports = parseRect\r\n\r\nfunction parseRect (arg) {\r\n var rect\r\n\r\n // direct arguments sequence\r\n if (arguments.length > 1) {\r\n arg = arguments\r\n }\r\n\r\n // svg viewbox\r\n if (typeof arg === 'string') {\r\n arg = arg.split(/\\s/).map(parseFloat)\r\n }\r\n else if (typeof arg === 'number') {\r\n arg = [arg]\r\n }\r\n\r\n // 0, 0, 100, 100 - array-like\r\n if (arg.length && typeof arg[0] === 'number') {\r\n // [w, w]\r\n if (arg.length === 1) {\r\n rect = {\r\n width: arg[0],\r\n height: arg[0],\r\n x: 0, y: 0\r\n }\r\n }\r\n // [w, h]\r\n else if (arg.length === 2) {\r\n rect = {\r\n width: arg[0],\r\n height: arg[1],\r\n x: 0, y: 0\r\n }\r\n }\r\n // [l, t, r, b]\r\n else {\r\n rect = {\r\n x: arg[0],\r\n y: arg[1],\r\n width: (arg[2] - arg[0]) || 0,\r\n height: (arg[3] - arg[1]) || 0\r\n }\r\n }\r\n }\r\n // {x, y, w, h} or {l, t, b, r}\r\n else if (arg) {\r\n arg = pick(arg, {\r\n left: 'x l left Left',\r\n top: 'y t top Top',\r\n width: 'w width W Width',\r\n height: 'h height W Width',\r\n bottom: 'b bottom Bottom',\r\n right: 'r right Right'\r\n })\r\n\r\n rect = {\r\n x: arg.left || 0,\r\n y: arg.top || 0\r\n }\r\n\r\n if (arg.width == null) {\r\n if (arg.right) rect.width = arg.right - rect.x\r\n else rect.width = 0\r\n }\r\n else {\r\n rect.width = arg.width\r\n }\r\n\r\n if (arg.height == null) {\r\n if (arg.bottom) rect.height = arg.bottom - rect.y\r\n else rect.height = 0\r\n }\r\n else {\r\n rect.height = arg.height\r\n }\r\n }\r\n\r\n return rect\r\n}\r\n","\nmodule.exports = parse\n\n/**\n * expected argument lengths\n * @type {Object}\n */\n\nvar length = {a: 7, c: 6, h: 1, l: 2, m: 2, q: 4, s: 4, t: 2, v: 1, z: 0}\n\n/**\n * segment pattern\n * @type {RegExp}\n */\n\nvar segment = /([astvzqmhlc])([^astvzqmhlc]*)/ig\n\n/**\n * parse an svg path data string. Generates an Array\n * of commands where each command is an Array of the\n * form `[command, arg1, arg2, ...]`\n *\n * @param {String} path\n * @return {Array}\n */\n\nfunction parse(path) {\n\tvar data = []\n\tpath.replace(segment, function(_, command, args){\n\t\tvar type = command.toLowerCase()\n\t\targs = parseValues(args)\n\n\t\t// overloaded moveTo\n\t\tif (type == 'm' && args.length > 2) {\n\t\t\tdata.push([command].concat(args.splice(0, 2)))\n\t\t\ttype = 'l'\n\t\t\tcommand = command == 'm' ? 'l' : 'L'\n\t\t}\n\n\t\twhile (true) {\n\t\t\tif (args.length == length[type]) {\n\t\t\t\targs.unshift(command)\n\t\t\t\treturn data.push(args)\n\t\t\t}\n\t\t\tif (args.length < length[type]) throw new Error('malformed path data')\n\t\t\tdata.push([command].concat(args.splice(0, length[type])))\n\t\t}\n\t})\n\treturn data\n}\n\nvar number = /-?[0-9]*\\.?[0-9]+(?:e[-+]?\\d+)?/ig\n\nfunction parseValues(args) {\n\tvar numbers = args.match(number)\n\treturn numbers ? numbers.map(Number) : []\n}\n","module.exports = function parseUnit(str, out) {\n if (!out)\n out = [ 0, '' ]\n\n str = String(str)\n var num = parseFloat(str, 10)\n out[0] = num\n out[1] = str.match(/[\\d.\\-\\+]*\\s*(.*)/)[1] || ''\n return out\n}","if performance? and performance.now\n module.exports = -> performance.now()\nelse if process? and process.hrtime\n module.exports = -> (getNanoSeconds() - nodeLoadTime) / 1e6\n hrtime = process.hrtime\n getNanoSeconds = ->\n hr = hrtime()\n hr[0] * 1e9 + hr[1]\n moduleLoadTime = getNanoSeconds()\n upTime = process.uptime() * 1e9\n nodeLoadTime = moduleLoadTime - upTime\nelse if Date.now\n module.exports = -> Date.now() - loadTime\n loadTime = Date.now()\nelse\n module.exports = -> new Date().getTime() - loadTime\n loadTime = new Date().getTime()\n","'use strict'\r\n\r\n\r\nmodule.exports = function pick (src, props, keepRest) {\r\n\tvar result = {}, prop, i\r\n\r\n\tif (typeof props === 'string') props = toList(props)\r\n\tif (Array.isArray(props)) {\r\n\t\tvar res = {}\r\n\t\tfor (i = 0; i < props.length; i++) {\r\n\t\t\tres[props[i]] = true\r\n\t\t}\r\n\t\tprops = res\r\n\t}\r\n\r\n\t// convert strings to lists\r\n\tfor (prop in props) {\r\n\t\tprops[prop] = toList(props[prop])\r\n\t}\r\n\r\n\t// keep-rest strategy requires unmatched props to be preserved\r\n\tvar occupied = {}\r\n\r\n\tfor (prop in props) {\r\n\t\tvar aliases = props[prop]\r\n\r\n\t\tif (Array.isArray(aliases)) {\r\n\t\t\tfor (i = 0; i < aliases.length; i++) {\r\n\t\t\t\tvar alias = aliases[i]\r\n\r\n\t\t\t\tif (keepRest) {\r\n\t\t\t\t\toccupied[alias] = true\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (alias in src) {\r\n\t\t\t\t\tresult[prop] = src[alias]\r\n\r\n\t\t\t\t\tif (keepRest) {\r\n\t\t\t\t\t\tfor (var j = i; j < aliases.length; j++) {\r\n\t\t\t\t\t\t\toccupied[aliases[j]] = true\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tbreak\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\telse if (prop in src) {\r\n\t\t\tif (props[prop]) {\r\n\t\t\t\tresult[prop] = src[prop]\r\n\t\t\t}\r\n\r\n\t\t\tif (keepRest) {\r\n\t\t\t\toccupied[prop] = true\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tif (keepRest) {\r\n\t\tfor (prop in src) {\r\n\t\t\tif (occupied[prop]) continue\r\n\t\t\tresult[prop] = src[prop]\r\n\t\t}\r\n\t}\r\n\r\n\treturn result\r\n}\r\n\r\nvar CACHE = {}\r\n\r\nfunction toList(arg) {\r\n\tif (CACHE[arg]) return CACHE[arg]\r\n\tif (typeof arg === 'string') {\r\n\t\targ = CACHE[arg] = arg.split(/\\s*,\\s*|\\s+/)\r\n\t}\r\n\treturn arg\r\n}\r\n","'use strict';\n\nvar Lib = require('../src/lib');\nvar rules = {\n \"X,X div\": \"direction:ltr;font-family:\\\"Open Sans\\\",verdana,arial,sans-serif;margin:0;padding:0;\",\n \"X input,X button\": \"font-family:\\\"Open Sans\\\",verdana,arial,sans-serif;\",\n \"X input:focus,X button:focus\": \"outline:none;\",\n \"X a\": \"text-decoration:none;\",\n \"X a:hover\": \"text-decoration:none;\",\n \"X .crisp\": \"shape-rendering:crispEdges;\",\n \"X .user-select-none\": \"-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none;\",\n \"X svg\": \"overflow:hidden;\",\n \"X svg a\": \"fill:#447adb;\",\n \"X svg a:hover\": \"fill:#3c6dc5;\",\n \"X .main-svg\": \"position:absolute;top:0;left:0;pointer-events:none;\",\n \"X .main-svg .draglayer\": \"pointer-events:all;\",\n \"X .cursor-default\": \"cursor:default;\",\n \"X .cursor-pointer\": \"cursor:pointer;\",\n \"X .cursor-crosshair\": \"cursor:crosshair;\",\n \"X .cursor-move\": \"cursor:move;\",\n \"X .cursor-col-resize\": \"cursor:col-resize;\",\n \"X .cursor-row-resize\": \"cursor:row-resize;\",\n \"X .cursor-ns-resize\": \"cursor:ns-resize;\",\n \"X .cursor-ew-resize\": \"cursor:ew-resize;\",\n \"X .cursor-sw-resize\": \"cursor:sw-resize;\",\n \"X .cursor-s-resize\": \"cursor:s-resize;\",\n \"X .cursor-se-resize\": \"cursor:se-resize;\",\n \"X .cursor-w-resize\": \"cursor:w-resize;\",\n \"X .cursor-e-resize\": \"cursor:e-resize;\",\n \"X .cursor-nw-resize\": \"cursor:nw-resize;\",\n \"X .cursor-n-resize\": \"cursor:n-resize;\",\n \"X .cursor-ne-resize\": \"cursor:ne-resize;\",\n \"X .cursor-grab\": \"cursor:-webkit-grab;cursor:grab;\",\n \"X .modebar\": \"position:absolute;top:2px;right:2px;\",\n \"X .ease-bg\": \"-webkit-transition:background-color .3s ease 0s;-moz-transition:background-color .3s ease 0s;-ms-transition:background-color .3s ease 0s;-o-transition:background-color .3s ease 0s;transition:background-color .3s ease 0s;\",\n \"X .modebar--hover>:not(.watermark)\": \"opacity:0;-webkit-transition:opacity .3s ease 0s;-moz-transition:opacity .3s ease 0s;-ms-transition:opacity .3s ease 0s;-o-transition:opacity .3s ease 0s;transition:opacity .3s ease 0s;\",\n \"X:hover .modebar--hover .modebar-group\": \"opacity:1;\",\n \"X .modebar-group\": \"float:left;display:inline-block;box-sizing:border-box;padding-left:8px;position:relative;vertical-align:middle;white-space:nowrap;\",\n \"X .modebar-btn\": \"position:relative;font-size:16px;padding:3px 4px;height:22px;cursor:pointer;line-height:normal;box-sizing:border-box;\",\n \"X .modebar-btn svg\": \"position:relative;top:2px;\",\n \"X .modebar.vertical\": \"display:flex;flex-direction:column;flex-wrap:wrap;align-content:flex-end;max-height:100%;\",\n \"X .modebar.vertical svg\": \"top:-1px;\",\n \"X .modebar.vertical .modebar-group\": \"display:block;float:none;padding-left:0px;padding-bottom:8px;\",\n \"X .modebar.vertical .modebar-group .modebar-btn\": \"display:block;text-align:center;\",\n \"X [data-title]:before,X [data-title]:after\": \"position:absolute;-webkit-transform:translate3d(0, 0, 0);-moz-transform:translate3d(0, 0, 0);-ms-transform:translate3d(0, 0, 0);-o-transform:translate3d(0, 0, 0);transform:translate3d(0, 0, 0);display:none;opacity:0;z-index:1001;pointer-events:none;top:110%;right:50%;\",\n \"X [data-title]:hover:before,X [data-title]:hover:after\": \"display:block;opacity:1;\",\n \"X [data-title]:before\": \"content:\\\"\\\";position:absolute;background:rgba(0,0,0,0);border:6px solid rgba(0,0,0,0);z-index:1002;margin-top:-12px;border-bottom-color:#69738a;margin-right:-6px;\",\n \"X [data-title]:after\": \"content:attr(data-title);background:#69738a;color:#fff;padding:8px 10px;font-size:12px;line-height:12px;white-space:nowrap;margin-right:-18px;border-radius:2px;\",\n \"X .vertical [data-title]:before,X .vertical [data-title]:after\": \"top:0%;right:200%;\",\n \"X .vertical [data-title]:before\": \"border:6px solid rgba(0,0,0,0);border-left-color:#69738a;margin-top:8px;margin-right:-30px;\",\n Y: \"font-family:\\\"Open Sans\\\",verdana,arial,sans-serif;position:fixed;top:50px;right:20px;z-index:10000;font-size:10pt;max-width:180px;\",\n \"Y p\": \"margin:0;\",\n \"Y .notifier-note\": \"min-width:180px;max-width:250px;border:1px solid #fff;z-index:3000;margin:0;background-color:#8c97af;background-color:rgba(140,151,175,.9);color:#fff;padding:10px;overflow-wrap:break-word;word-wrap:break-word;-ms-hyphens:auto;-webkit-hyphens:auto;hyphens:auto;\",\n \"Y .notifier-close\": \"color:#fff;opacity:.8;float:right;padding:0 5px;background:none;border:none;font-size:20px;font-weight:bold;line-height:20px;\",\n \"Y .notifier-close:hover\": \"color:#444;text-decoration:none;cursor:pointer;\"\n};\n\nfor(var selector in rules) {\n var fullSelector = selector.replace(/^,/,' ,')\n .replace(/X/g, '.js-plotly-plot .plotly')\n .replace(/Y/g, '.plotly-notifier');\n Lib.addStyleRule(fullSelector, rules[selector]);\n}\n","'use strict';\n\nmodule.exports = require('../src/transforms/aggregate');\n","'use strict';\n\nmodule.exports = require('../src/traces/bar');\n","'use strict';\n\nmodule.exports = require('../src/traces/barpolar');\n","'use strict';\n\nmodule.exports = require('../src/traces/box');\n","'use strict';\n\nmodule.exports = require('../src/components/calendars');\n","'use strict';\n\nmodule.exports = require('../src/traces/candlestick');\n","'use strict';\n\nmodule.exports = require('../src/traces/carpet');\n","'use strict';\n\nmodule.exports = require('../src/traces/choropleth');\n","'use strict';\n\nmodule.exports = require('../src/traces/choroplethmap');\n","'use strict';\n\nmodule.exports = require('../src/traces/choroplethmapbox');\n","'use strict';\n\nmodule.exports = require('../src/traces/cone');\n","'use strict';\n\nmodule.exports = require('../src/traces/contour');\n","'use strict';\n\nmodule.exports = require('../src/traces/contourcarpet');\n","'use strict';\n\nmodule.exports = require('../src/core');\n","'use strict';\n\nmodule.exports = require('../src/traces/densitymap');\n","'use strict';\n\nmodule.exports = require('../src/traces/densitymapbox');\n","'use strict';\n\nmodule.exports = require('../src/transforms/filter');\n","'use strict';\n\nmodule.exports = require('../src/traces/funnel');\n","'use strict';\n\nmodule.exports = require('../src/traces/funnelarea');\n","'use strict';\n\nmodule.exports = require('../src/transforms/groupby');\n","'use strict';\n\nmodule.exports = require('../src/traces/heatmap');\n","'use strict';\n\nmodule.exports = require('../src/traces/heatmapgl');\n","'use strict';\n\nmodule.exports = require('../src/traces/histogram');\n","'use strict';\n\nmodule.exports = require('../src/traces/histogram2d');\n","'use strict';\n\nmodule.exports = require('../src/traces/histogram2dcontour');\n","'use strict';\n\nmodule.exports = require('../src/traces/icicle');\n","'use strict';\n\nmodule.exports = require('../src/traces/image');\n","'use strict';\n\nvar Plotly = require('./core');\n\nPlotly.register([\n // traces\n require('./bar'),\n require('./box'),\n require('./heatmap'),\n require('./histogram'),\n require('./histogram2d'),\n require('./histogram2dcontour'),\n require('./contour'),\n require('./scatterternary'),\n require('./violin'),\n require('./funnel'),\n require('./waterfall'),\n require('./image'),\n require('./pie'),\n require('./sunburst'),\n require('./treemap'),\n require('./icicle'),\n require('./funnelarea'),\n require('./scatter3d'),\n require('./surface'),\n require('./isosurface'),\n require('./volume'),\n require('./mesh3d'),\n require('./cone'),\n require('./streamtube'),\n require('./scattergeo'),\n require('./choropleth'),\n require('./scattergl'),\n require('./splom'),\n require('./pointcloud'),\n require('./heatmapgl'),\n require('./parcoords'),\n require('./parcats'),\n require('./scattermapbox'),\n require('./choroplethmapbox'),\n require('./densitymapbox'),\n require('./scattermap'),\n require('./choroplethmap'),\n require('./densitymap'),\n require('./sankey'),\n require('./indicator'),\n require('./table'),\n require('./carpet'),\n require('./scattercarpet'),\n require('./contourcarpet'),\n require('./ohlc'),\n require('./candlestick'),\n require('./scatterpolar'),\n require('./scatterpolargl'),\n require('./barpolar'),\n require('./scattersmith'),\n\n // transforms\n require('./aggregate'),\n require('./filter'),\n require('./groupby'),\n require('./sort'),\n\n // components\n require('./calendars'),\n]);\n\nmodule.exports = Plotly;\n","'use strict';\n\nmodule.exports = require('../src/traces/indicator');\n","'use strict';\n\nmodule.exports = require('../src/traces/isosurface');\n","'use strict';\n\nmodule.exports = require('../src/traces/mesh3d');\n","'use strict';\n\nmodule.exports = require('../src/traces/ohlc');\n","'use strict';\n\nmodule.exports = require('../src/traces/parcats');\n","'use strict';\n\nmodule.exports = require('../src/traces/parcoords');\n","'use strict';\n\nmodule.exports = require('../src/traces/pie');\n","'use strict';\n\nmodule.exports = require('../src/traces/pointcloud');\n","'use strict';\n\nmodule.exports = require('../src/traces/sankey');\n","'use strict';\n\nmodule.exports = require('../src/traces/scatter3d');\n","'use strict';\n\nmodule.exports = require('../src/traces/scattercarpet');\n","'use strict';\n\nmodule.exports = require('../src/traces/scattergeo');\n","'use strict';\n\nmodule.exports = require('../src/traces/scattergl');\n","'use strict';\n\nmodule.exports = require('../src/traces/scattermap');\n","'use strict';\n\nmodule.exports = require('../src/traces/scattermapbox');\n","'use strict';\n\nmodule.exports = require('../src/traces/scatterpolar');\n","'use strict';\n\nmodule.exports = require('../src/traces/scatterpolargl');\n","'use strict';\n\nmodule.exports = require('../src/traces/scattersmith');\n","'use strict';\n\nmodule.exports = require('../src/traces/scatterternary');\n","'use strict';\n\nmodule.exports = require('../src/transforms/sort');\n","'use strict';\n\nmodule.exports = require('../src/traces/splom');\n","'use strict';\n\nmodule.exports = require('../src/traces/streamtube');\n","'use strict';\n\nmodule.exports = require('../src/traces/sunburst');\n","'use strict';\n\nmodule.exports = require('../src/traces/surface');\n","'use strict';\n\nmodule.exports = require('../src/traces/table');\n","'use strict';\n\nmodule.exports = require('../src/traces/treemap');\n","'use strict';\n\nmodule.exports = require('../src/traces/violin');\n","'use strict';\n\nmodule.exports = require('../src/traces/volume');\n","'use strict';\n\nmodule.exports = require('../src/traces/waterfall');\n","/** @module color-normalize */\r\n\r\n'use strict'\r\n\r\nvar rgba = require('color-rgba')\r\nvar clamp = require('clamp')\r\nvar dtype = require('dtype')\r\n\r\nmodule.exports = function normalize (color, type) {\r\n\tif (type === 'float' || !type) type = 'array'\r\n\tif (type === 'uint') type = 'uint8'\r\n\tif (type === 'uint_clamped') type = 'uint8_clamped'\r\n\tvar Ctor = dtype(type)\r\n\tvar output = new Ctor(4)\r\n\r\n\tvar normalize = type !== 'uint8' && type !== 'uint8_clamped'\r\n\r\n\t// attempt to parse non-array arguments\r\n\tif (!color.length || typeof color === 'string') {\r\n\t\tcolor = rgba(color)\r\n\t\tcolor[0] /= 255\r\n\t\tcolor[1] /= 255\r\n\t\tcolor[2] /= 255\r\n\t}\r\n\r\n\t// 0, 1 are possible contradictory values for Arrays:\r\n\t// [1,1,1] input gives [1,1,1] output instead of [1/255,1/255,1/255], which may be collision if input is meant to be uint.\r\n\t// converting [1,1,1] to [1/255,1/255,1/255] in case of float input gives larger mistake since [1,1,1] float is frequent edge value, whereas [0,1,1], [1,1,1] etc. uint inputs are relatively rare\r\n\tif (isInt(color)) {\r\n\t\toutput[0] = color[0]\r\n\t\toutput[1] = color[1]\r\n\t\toutput[2] = color[2]\r\n\t\toutput[3] = color[3] != null ? color[3] : 255\r\n\r\n\t\tif (normalize) {\r\n\t\t\toutput[0] /= 255\r\n\t\t\toutput[1] /= 255\r\n\t\t\toutput[2] /= 255\r\n\t\t\toutput[3] /= 255\r\n\t\t}\r\n\r\n\t\treturn output\r\n\t}\r\n\r\n\tif (!normalize) {\r\n\t\toutput[0] = clamp(Math.floor(color[0] * 255), 0, 255)\r\n\t\toutput[1] = clamp(Math.floor(color[1] * 255), 0, 255)\r\n\t\toutput[2] = clamp(Math.floor(color[2] * 255), 0, 255)\r\n\t\toutput[3] = color[3] == null ? 255 : clamp(Math.floor(color[3] * 255), 0, 255)\r\n\t} else {\r\n\t\toutput[0] = color[0]\r\n\t\toutput[1] = color[1]\r\n\t\toutput[2] = color[2]\r\n\t\toutput[3] = color[3] != null ? color[3] : 1\r\n\t}\r\n\r\n\treturn output\r\n}\r\n\r\nfunction isInt(color) {\r\n\tif (color instanceof Uint8Array || color instanceof Uint8ClampedArray) return true\r\n\r\n\tif (Array.isArray(color) &&\r\n\t\t(color[0] > 1 || color[0] === 0) &&\r\n\t\t(color[1] > 1 || color[1] === 0) &&\r\n\t\t(color[2] > 1 || color[2] === 0) &&\r\n\t\t(!color[3] || color[3] > 1)\r\n\t) return true\r\n\r\n\treturn false\r\n}\r\n","/**\n * @module color-parse\n */\n\n'use strict'\n\nvar names = require('color-name')\n\nmodule.exports = parse\n\n/**\n * Base hues\n * http://dev.w3.org/csswg/css-color/#typedef-named-hue\n */\n//FIXME: use external hue detector\nvar baseHues = {\n\tred: 0,\n\torange: 60,\n\tyellow: 120,\n\tgreen: 180,\n\tblue: 240,\n\tpurple: 300\n}\n\n/**\n * Parse color from the string passed\n *\n * @return {Object} A space indicator `space`, an array `values` and `alpha`\n */\nfunction parse(cstr) {\n\tvar m, parts = [], alpha = 1, space\n\n\tif (typeof cstr === 'string') {\n\t\tcstr = cstr.toLowerCase();\n\n\t\t//keyword\n\t\tif (names[cstr]) {\n\t\t\tparts = names[cstr].slice()\n\t\t\tspace = 'rgb'\n\t\t}\n\n\t\t//reserved words\n\t\telse if (cstr === 'transparent') {\n\t\t\talpha = 0\n\t\t\tspace = 'rgb'\n\t\t\tparts = [0, 0, 0]\n\t\t}\n\n\t\t//hex\n\t\telse if (/^#[A-Fa-f0-9]+$/.test(cstr)) {\n\t\t\tvar base = cstr.slice(1)\n\t\t\tvar size = base.length\n\t\t\tvar isShort = size <= 4\n\t\t\talpha = 1\n\n\t\t\tif (isShort) {\n\t\t\t\tparts = [\n\t\t\t\t\tparseInt(base[0] + base[0], 16),\n\t\t\t\t\tparseInt(base[1] + base[1], 16),\n\t\t\t\t\tparseInt(base[2] + base[2], 16)\n\t\t\t\t]\n\t\t\t\tif (size === 4) {\n\t\t\t\t\talpha = parseInt(base[3] + base[3], 16) / 255\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tparts = [\n\t\t\t\t\tparseInt(base[0] + base[1], 16),\n\t\t\t\t\tparseInt(base[2] + base[3], 16),\n\t\t\t\t\tparseInt(base[4] + base[5], 16)\n\t\t\t\t]\n\t\t\t\tif (size === 8) {\n\t\t\t\t\talpha = parseInt(base[6] + base[7], 16) / 255\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (!parts[0]) parts[0] = 0\n\t\t\tif (!parts[1]) parts[1] = 0\n\t\t\tif (!parts[2]) parts[2] = 0\n\n\t\t\tspace = 'rgb'\n\t\t}\n\n\t\t//color space\n\t\telse if (m = /^((?:rgb|hs[lvb]|hwb|cmyk?|xy[zy]|gray|lab|lchu?v?|[ly]uv|lms)a?)\\s*\\(([^\\)]*)\\)/.exec(cstr)) {\n\t\t\tvar name = m[1]\n\t\t\tvar isRGB = name === 'rgb'\n\t\t\tvar base = name.replace(/a$/, '')\n\t\t\tspace = base\n\t\t\tvar size = base === 'cmyk' ? 4 : base === 'gray' ? 1 : 3\n\t\t\tparts = m[2].trim()\n\t\t\t\t.split(/\\s*[,\\/]\\s*|\\s+/)\n\t\t\t\t.map(function (x, i) {\n\t\t\t\t\t//\n\t\t\t\t\tif (/%$/.test(x)) {\n\t\t\t\t\t\t//alpha\n\t\t\t\t\t\tif (i === size) return parseFloat(x) / 100\n\t\t\t\t\t\t//rgb\n\t\t\t\t\t\tif (base === 'rgb') return parseFloat(x) * 255 / 100\n\t\t\t\t\t\treturn parseFloat(x)\n\t\t\t\t\t}\n\t\t\t\t\t//hue\n\t\t\t\t\telse if (base[i] === 'h') {\n\t\t\t\t\t\t//\n\t\t\t\t\t\tif (/deg$/.test(x)) {\n\t\t\t\t\t\t\treturn parseFloat(x)\n\t\t\t\t\t\t}\n\t\t\t\t\t\t//\n\t\t\t\t\t\telse if (baseHues[x] !== undefined) {\n\t\t\t\t\t\t\treturn baseHues[x]\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\treturn parseFloat(x)\n\t\t\t\t})\n\n\t\t\tif (name === base) parts.push(1)\n\t\t\talpha = (isRGB) ? 1 : (parts[size] === undefined) ? 1 : parts[size]\n\t\t\tparts = parts.slice(0, size)\n\t\t}\n\n\t\t//named channels case\n\t\telse if (cstr.length > 10 && /[0-9](?:\\s|\\/)/.test(cstr)) {\n\t\t\tparts = cstr.match(/([0-9]+)/g).map(function (value) {\n\t\t\t\treturn parseFloat(value)\n\t\t\t})\n\n\t\t\tspace = cstr.match(/([a-z])/ig).join('').toLowerCase()\n\t\t}\n\t}\n\n\t//numeric case\n\telse if (!isNaN(cstr)) {\n\t\tspace = 'rgb'\n\t\tparts = [cstr >>> 16, (cstr & 0x00ff00) >>> 8, cstr & 0x0000ff]\n\t}\n\n\t//array-like\n\telse if (Array.isArray(cstr) || cstr.length) {\n\t\tparts = [cstr[0], cstr[1], cstr[2]]\n\t\tspace = 'rgb'\n\t\talpha = cstr.length === 4 ? cstr[3] : 1\n\t}\n\n\t//object case - detects css cases of rgb and hsl\n\telse if (cstr instanceof Object) {\n\t\tif (cstr.r != null || cstr.red != null || cstr.R != null) {\n\t\t\tspace = 'rgb'\n\t\t\tparts = [\n\t\t\t\tcstr.r || cstr.red || cstr.R || 0,\n\t\t\t\tcstr.g || cstr.green || cstr.G || 0,\n\t\t\t\tcstr.b || cstr.blue || cstr.B || 0\n\t\t\t]\n\t\t}\n\t\telse {\n\t\t\tspace = 'hsl'\n\t\t\tparts = [\n\t\t\t\tcstr.h || cstr.hue || cstr.H || 0,\n\t\t\t\tcstr.s || cstr.saturation || cstr.S || 0,\n\t\t\t\tcstr.l || cstr.lightness || cstr.L || cstr.b || cstr.brightness\n\t\t\t]\n\t\t}\n\n\t\talpha = cstr.a || cstr.alpha || cstr.opacity || 1\n\n\t\tif (cstr.opacity != null) alpha /= 100\n\t}\n\n\treturn {\n\t\tspace: space,\n\t\tvalues: parts,\n\t\talpha: alpha\n\t}\n}\n","/** @module color-rgba */\r\n\r\n'use strict'\r\n\r\nvar parse = require('color-parse')\r\n\r\nmodule.exports = function rgba (color) {\r\n\t// template literals\r\n\tif (Array.isArray(color) && color.raw) color = String.raw.apply(null, arguments)\r\n\r\n\tvar values, i, l\r\n\r\n\t//attempt to parse non-array arguments\r\n\tvar parsed = parse(color)\r\n\r\n\tif (!parsed.space) return []\r\n\r\n\tvar min = [0,0,0], max = parsed.space[0] === 'h' ? [360,100,100] : [255,255,255]\r\n\r\n\tvalues = Array(3)\r\n\tvalues[0] = Math.min(Math.max(parsed.values[0], min[0]), max[0])\r\n\tvalues[1] = Math.min(Math.max(parsed.values[1], min[1]), max[1])\r\n\tvalues[2] = Math.min(Math.max(parsed.values[2], min[2]), max[2])\r\n\r\n\tif (parsed.space[0] === 'h') values = hsl2rgb(values)\r\n\r\n\tvalues.push(Math.min(Math.max(parsed.alpha, 0), 1))\r\n\r\n\treturn values\r\n}\r\n\r\n\r\n// excerpt from color-space/hsl\r\nfunction hsl2rgb(hsl) {\r\n\tvar h = hsl[0]/360, s = hsl[1]/100, l = hsl[2]/100, t1, t2, t3, rgb, val, i=0;\r\n\r\n\tif (s === 0) return val = l * 255, [val, val, val];\r\n\r\n\tt2 = l < 0.5 ? l * (1 + s) : l + s - l * s;\r\n\tt1 = 2 * l - t2;\r\n\r\n\trgb = [0, 0, 0];\r\n\tfor (;i<3;) {\r\n\t\tt3 = h + 1 / 3 * - (i - 1);\r\n\t\tt3 < 0 ? t3++ : t3 > 1 && t3--;\r\n\t\tval = 6 * t3 < 1 ? t1 + (t2 - t1) * 6 * t3 :\r\n\t\t2 * t3 < 1 ? t2 :\r\n\t\t3 * t3 < 2 ? t1 + (t2 - t1) * (2 / 3 - t3) * 6 :\r\n\t\tt1;\r\n\t\trgb[i++] = val * 255;\r\n\t}\r\n\r\n\treturn rgb;\r\n}\r\n","/** @module color-rgba */\n\n'use strict'\n\nvar parse = require('color-parse')\nvar hsl = require('color-space/hsl')\nvar clamp = require('clamp')\n\nmodule.exports = function rgba (color) {\n\tvar values, i, l\n\n\t//attempt to parse non-array arguments\n\tvar parsed = parse(color)\n\n\tif (!parsed.space) return []\n\n\tvalues = Array(3)\n\tvalues[0] = clamp(parsed.values[0], 0, 255)\n\tvalues[1] = clamp(parsed.values[1], 0, 255)\n\tvalues[2] = clamp(parsed.values[2], 0, 255)\n\n\tif (parsed.space[0] === 'h') {\n\t\tvalues = hsl.rgb(values)\n\t}\n\n\tvalues.push(clamp(parsed.alpha, 0, 1))\n\n\treturn values\n}\n","/**\n * @module color-parse\n */\n\n'use strict'\n\nvar names = require('color-name')\n\nmodule.exports = parse\n\n/**\n * Base hues\n * http://dev.w3.org/csswg/css-color/#typedef-named-hue\n */\n//FIXME: use external hue detector\nvar baseHues = {\n\tred: 0,\n\torange: 60,\n\tyellow: 120,\n\tgreen: 180,\n\tblue: 240,\n\tpurple: 300\n}\n\n/**\n * Parse color from the string passed\n *\n * @return {Object} A space indicator `space`, an array `values` and `alpha`\n */\nfunction parse(cstr) {\n\tvar m, parts = [], alpha = 1, space\n\n\tif (typeof cstr === 'string') {\n\t\tcstr = cstr.toLowerCase();\n\n\t\t//keyword\n\t\tif (names[cstr]) {\n\t\t\tparts = names[cstr].slice()\n\t\t\tspace = 'rgb'\n\t\t}\n\n\t\t//reserved words\n\t\telse if (cstr === 'transparent') {\n\t\t\talpha = 0\n\t\t\tspace = 'rgb'\n\t\t\tparts = [0, 0, 0]\n\t\t}\n\n\t\t//hex\n\t\telse if (/^#[A-Fa-f0-9]+$/.test(cstr)) {\n\t\t\tvar base = cstr.slice(1)\n\t\t\tvar size = base.length\n\t\t\tvar isShort = size <= 4\n\t\t\talpha = 1\n\n\t\t\tif (isShort) {\n\t\t\t\tparts = [\n\t\t\t\t\tparseInt(base[0] + base[0], 16),\n\t\t\t\t\tparseInt(base[1] + base[1], 16),\n\t\t\t\t\tparseInt(base[2] + base[2], 16)\n\t\t\t\t]\n\t\t\t\tif (size === 4) {\n\t\t\t\t\talpha = parseInt(base[3] + base[3], 16) / 255\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tparts = [\n\t\t\t\t\tparseInt(base[0] + base[1], 16),\n\t\t\t\t\tparseInt(base[2] + base[3], 16),\n\t\t\t\t\tparseInt(base[4] + base[5], 16)\n\t\t\t\t]\n\t\t\t\tif (size === 8) {\n\t\t\t\t\talpha = parseInt(base[6] + base[7], 16) / 255\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (!parts[0]) parts[0] = 0\n\t\t\tif (!parts[1]) parts[1] = 0\n\t\t\tif (!parts[2]) parts[2] = 0\n\n\t\t\tspace = 'rgb'\n\t\t}\n\n\t\t//color space\n\t\telse if (m = /^((?:rgb|hs[lvb]|hwb|cmyk?|xy[zy]|gray|lab|lchu?v?|[ly]uv|lms)a?)\\s*\\(([^\\)]*)\\)/.exec(cstr)) {\n\t\t\tvar name = m[1]\n\t\t\tvar isRGB = name === 'rgb'\n\t\t\tvar base = name.replace(/a$/, '')\n\t\t\tspace = base\n\t\t\tvar size = base === 'cmyk' ? 4 : base === 'gray' ? 1 : 3\n\t\t\tparts = m[2].trim()\n\t\t\t\t.split(/\\s*[,\\/]\\s*|\\s+/)\n\t\t\t\t.map(function (x, i) {\n\t\t\t\t\t//\n\t\t\t\t\tif (/%$/.test(x)) {\n\t\t\t\t\t\t//alpha\n\t\t\t\t\t\tif (i === size) return parseFloat(x) / 100\n\t\t\t\t\t\t//rgb\n\t\t\t\t\t\tif (base === 'rgb') return parseFloat(x) * 255 / 100\n\t\t\t\t\t\treturn parseFloat(x)\n\t\t\t\t\t}\n\t\t\t\t\t//hue\n\t\t\t\t\telse if (base[i] === 'h') {\n\t\t\t\t\t\t//\n\t\t\t\t\t\tif (/deg$/.test(x)) {\n\t\t\t\t\t\t\treturn parseFloat(x)\n\t\t\t\t\t\t}\n\t\t\t\t\t\t//\n\t\t\t\t\t\telse if (baseHues[x] !== undefined) {\n\t\t\t\t\t\t\treturn baseHues[x]\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\treturn parseFloat(x)\n\t\t\t\t})\n\n\t\t\tif (name === base) parts.push(1)\n\t\t\talpha = (isRGB) ? 1 : (parts[size] === undefined) ? 1 : parts[size]\n\t\t\tparts = parts.slice(0, size)\n\t\t}\n\n\t\t//named channels case\n\t\telse if (cstr.length > 10 && /[0-9](?:\\s|\\/)/.test(cstr)) {\n\t\t\tparts = cstr.match(/([0-9]+)/g).map(function (value) {\n\t\t\t\treturn parseFloat(value)\n\t\t\t})\n\n\t\t\tspace = cstr.match(/([a-z])/ig).join('').toLowerCase()\n\t\t}\n\t}\n\n\t//numeric case\n\telse if (!isNaN(cstr)) {\n\t\tspace = 'rgb'\n\t\tparts = [cstr >>> 16, (cstr & 0x00ff00) >>> 8, cstr & 0x0000ff]\n\t}\n\n\t//array-like\n\telse if (Array.isArray(cstr) || cstr.length) {\n\t\tparts = [cstr[0], cstr[1], cstr[2]]\n\t\tspace = 'rgb'\n\t\talpha = cstr.length === 4 ? cstr[3] : 1\n\t}\n\n\t//object case - detects css cases of rgb and hsl\n\telse if (cstr instanceof Object) {\n\t\tif (cstr.r != null || cstr.red != null || cstr.R != null) {\n\t\t\tspace = 'rgb'\n\t\t\tparts = [\n\t\t\t\tcstr.r || cstr.red || cstr.R || 0,\n\t\t\t\tcstr.g || cstr.green || cstr.G || 0,\n\t\t\t\tcstr.b || cstr.blue || cstr.B || 0\n\t\t\t]\n\t\t}\n\t\telse {\n\t\t\tspace = 'hsl'\n\t\t\tparts = [\n\t\t\t\tcstr.h || cstr.hue || cstr.H || 0,\n\t\t\t\tcstr.s || cstr.saturation || cstr.S || 0,\n\t\t\t\tcstr.l || cstr.lightness || cstr.L || cstr.b || cstr.brightness\n\t\t\t]\n\t\t}\n\n\t\talpha = cstr.a || cstr.alpha || cstr.opacity || 1\n\n\t\tif (cstr.opacity != null) alpha /= 100\n\t}\n\n\treturn {\n\t\tspace: space,\n\t\tvalues: parts,\n\t\talpha: alpha\n\t}\n}\n","/**\n * @module color-space/hsl\n */\n'use strict'\n\nvar rgb = require('./rgb');\n\nmodule.exports = {\n\tname: 'hsl',\n\tmin: [0,0,0],\n\tmax: [360,100,100],\n\tchannel: ['hue', 'saturation', 'lightness'],\n\talias: ['HSL'],\n\n\trgb: function(hsl) {\n\t\tvar h = hsl[0] / 360,\n\t\t\t\ts = hsl[1] / 100,\n\t\t\t\tl = hsl[2] / 100,\n\t\t\t\tt1, t2, t3, rgb, val;\n\n\t\tif (s === 0) {\n\t\t\tval = l * 255;\n\t\t\treturn [val, val, val];\n\t\t}\n\n\t\tif (l < 0.5) {\n\t\t\tt2 = l * (1 + s);\n\t\t}\n\t\telse {\n\t\t\tt2 = l + s - l * s;\n\t\t}\n\t\tt1 = 2 * l - t2;\n\n\t\trgb = [0, 0, 0];\n\t\tfor (var i = 0; i < 3; i++) {\n\t\t\tt3 = h + 1 / 3 * - (i - 1);\n\t\t\tif (t3 < 0) {\n\t\t\t\tt3++;\n\t\t\t}\n\t\t\telse if (t3 > 1) {\n\t\t\t\tt3--;\n\t\t\t}\n\n\t\t\tif (6 * t3 < 1) {\n\t\t\t\tval = t1 + (t2 - t1) * 6 * t3;\n\t\t\t}\n\t\t\telse if (2 * t3 < 1) {\n\t\t\t\tval = t2;\n\t\t\t}\n\t\t\telse if (3 * t3 < 2) {\n\t\t\t\tval = t1 + (t2 - t1) * (2 / 3 - t3) * 6;\n\t\t\t}\n\t\t\telse {\n\t\t\t\tval = t1;\n\t\t\t}\n\n\t\t\trgb[i] = val * 255;\n\t\t}\n\n\t\treturn rgb;\n\t}\n};\n\n\n//extend rgb\nrgb.hsl = function(rgb) {\n\tvar r = rgb[0]/255,\n\t\t\tg = rgb[1]/255,\n\t\t\tb = rgb[2]/255,\n\t\t\tmin = Math.min(r, g, b),\n\t\t\tmax = Math.max(r, g, b),\n\t\t\tdelta = max - min,\n\t\t\th, s, l;\n\n\tif (max === min) {\n\t\th = 0;\n\t}\n\telse if (r === max) {\n\t\th = (g - b) / delta;\n\t}\n\telse if (g === max) {\n\t\th = 2 + (b - r) / delta;\n\t}\n\telse if (b === max) {\n\t\th = 4 + (r - g)/ delta;\n\t}\n\n\th = Math.min(h * 60, 360);\n\n\tif (h < 0) {\n\t\th += 360;\n\t}\n\n\tl = (min + max) / 2;\n\n\tif (max === min) {\n\t\ts = 0;\n\t}\n\telse if (l <= 0.5) {\n\t\ts = delta / (max + min);\n\t}\n\telse {\n\t\ts = delta / (2 - max - min);\n\t}\n\n\treturn [h, s * 100, l * 100];\n};\n","/**\n * RGB space.\n *\n * @module color-space/rgb\n */\n'use strict'\n\nmodule.exports = {\n\tname: 'rgb',\n\tmin: [0,0,0],\n\tmax: [255,255,255],\n\tchannel: ['red', 'green', 'blue'],\n\talias: ['RGB']\n};\n","'use strict';\n\n/**\n * All paths are tuned for maximum scalability of the arrowhead,\n * ie throughout arrowwidth=0.3..3 the head is joined smoothly\n * to the line, with the line coming from the left and ending at (0, 0).\n *\n * `backoff` is the distance to move the arrowhead and the end of the line,\n * in order that the arrowhead points to the desired place, either at\n * the tip of the arrow or (in the case of circle or square)\n * the center of the symbol.\n *\n * `noRotate`, if truthy, says that this arrowhead should not rotate with the\n * arrow. That's the case for squares, which should always be straight, and\n * circles, for which it's irrelevant.\n */\n\nmodule.exports = [\n // no arrow\n {\n path: '',\n backoff: 0\n },\n // wide with flat back\n {\n path: 'M-2.4,-3V3L0.6,0Z',\n backoff: 0.6\n },\n // narrower with flat back\n {\n path: 'M-3.7,-2.5V2.5L1.3,0Z',\n backoff: 1.3\n },\n // barbed\n {\n path: 'M-4.45,-3L-1.65,-0.2V0.2L-4.45,3L1.55,0Z',\n backoff: 1.55\n },\n // wide line-drawn\n {\n path: 'M-2.2,-2.2L-0.2,-0.2V0.2L-2.2,2.2L-1.4,3L1.6,0L-1.4,-3Z',\n backoff: 1.6\n },\n // narrower line-drawn\n {\n path: 'M-4.4,-2.1L-0.6,-0.2V0.2L-4.4,2.1L-4,3L2,0L-4,-3Z',\n backoff: 2\n },\n // circle\n {\n path: 'M2,0A2,2 0 1,1 0,-2A2,2 0 0,1 2,0Z',\n backoff: 0,\n noRotate: true\n },\n // square\n {\n path: 'M2,2V-2H-2V2Z',\n backoff: 0,\n noRotate: true\n }\n];\n","'use strict';\n\nvar ARROWPATHS = require('./arrow_paths');\nvar fontAttrs = require('../../plots/font_attributes');\nvar cartesianConstants = require('../../plots/cartesian/constants');\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\nvar axisPlaceableObjs = require('../../constants/axis_placeable_objects');\n\nfunction arrowAxisRefDescription(axis) {\n return [\n 'In order for absolute positioning of the arrow to work, *a' + axis +\n 'ref* must be exactly the same as *' + axis + 'ref*, otherwise *a' + axis +\n 'ref* will revert to *pixel* (explained next).',\n 'For relative positioning, *a' + axis + 'ref* can be set to *pixel*,',\n 'in which case the *a' + axis + '* value is specified in pixels',\n 'relative to *' + axis + '*.',\n 'Absolute positioning is useful',\n 'for trendline annotations which should continue to indicate',\n 'the correct trend when zoomed. Relative positioning is useful',\n 'for specifying the text offset for an annotated point.'\n ].join(' ');\n}\n\nfunction arrowCoordinateDescription(axis, lower, upper) {\n return [\n 'Sets the', axis, 'component of the arrow tail about the arrow head.',\n 'If `a' + axis + 'ref` is `pixel`, a positive (negative)',\n 'component corresponds to an arrow pointing',\n 'from', upper, 'to', lower, '(' + lower, 'to', upper + ').',\n 'If `a' + axis + 'ref` is not `pixel` and is exactly the same as `' + axis + 'ref`,',\n 'this is an absolute value on that axis,',\n 'like `' + axis + '`, specified in the same coordinates as `' + axis + 'ref`.'\n ].join(' ');\n}\n\nmodule.exports = templatedArray('annotation', {\n visible: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc+arraydraw',\n description: [\n 'Determines whether or not this annotation is visible.'\n ].join(' ')\n },\n\n text: {\n valType: 'string',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the text associated with this annotation.',\n 'Plotly uses a subset of HTML tags to do things like',\n 'newline (
), bold (), italics (),',\n 'hyperlinks (). Tags , , , , ',\n ' are also supported.'\n ].join(' ')\n },\n textangle: {\n valType: 'angle',\n dflt: 0,\n editType: 'calc+arraydraw',\n description: [\n 'Sets the angle at which the `text` is drawn',\n 'with respect to the horizontal.'\n ].join(' ')\n },\n font: fontAttrs({\n editType: 'calc+arraydraw',\n colorEditType: 'arraydraw',\n description: 'Sets the annotation text font.'\n }),\n width: {\n valType: 'number',\n min: 1,\n dflt: null,\n editType: 'calc+arraydraw',\n description: [\n 'Sets an explicit width for the text box. null (default) lets the',\n 'text set the box width. Wider text will be clipped.',\n 'There is no automatic wrapping; use
to start a new line.'\n ].join(' ')\n },\n height: {\n valType: 'number',\n min: 1,\n dflt: null,\n editType: 'calc+arraydraw',\n description: [\n 'Sets an explicit height for the text box. null (default) lets the',\n 'text set the box height. Taller text will be clipped.'\n ].join(' ')\n },\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n editType: 'arraydraw',\n description: 'Sets the opacity of the annotation (text + arrow).'\n },\n align: {\n valType: 'enumerated',\n values: ['left', 'center', 'right'],\n dflt: 'center',\n editType: 'arraydraw',\n description: [\n 'Sets the horizontal alignment of the `text` within the box.',\n 'Has an effect only if `text` spans two or more lines',\n '(i.e. `text` contains one or more
HTML tags) or if an',\n 'explicit width is set to override the text width.'\n ].join(' ')\n },\n valign: {\n valType: 'enumerated',\n values: ['top', 'middle', 'bottom'],\n dflt: 'middle',\n editType: 'arraydraw',\n description: [\n 'Sets the vertical alignment of the `text` within the box.',\n 'Has an effect only if an explicit height is set to override',\n 'the text height.'\n ].join(' ')\n },\n bgcolor: {\n valType: 'color',\n dflt: 'rgba(0,0,0,0)',\n editType: 'arraydraw',\n description: 'Sets the background color of the annotation.'\n },\n bordercolor: {\n valType: 'color',\n dflt: 'rgba(0,0,0,0)',\n editType: 'arraydraw',\n description: [\n 'Sets the color of the border enclosing the annotation `text`.'\n ].join(' ')\n },\n borderpad: {\n valType: 'number',\n min: 0,\n dflt: 1,\n editType: 'calc+arraydraw',\n description: [\n 'Sets the padding (in px) between the `text`',\n 'and the enclosing border.'\n ].join(' ')\n },\n borderwidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n editType: 'calc+arraydraw',\n description: [\n 'Sets the width (in px) of the border enclosing',\n 'the annotation `text`.'\n ].join(' ')\n },\n // arrow\n showarrow: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc+arraydraw',\n description: [\n 'Determines whether or not the annotation is drawn with an arrow.',\n 'If *true*, `text` is placed near the arrow\\'s tail.',\n 'If *false*, `text` lines up with the `x` and `y` provided.'\n ].join(' ')\n },\n arrowcolor: {\n valType: 'color',\n editType: 'arraydraw',\n description: 'Sets the color of the annotation arrow.'\n },\n arrowhead: {\n valType: 'integer',\n min: 0,\n max: ARROWPATHS.length,\n dflt: 1,\n editType: 'arraydraw',\n description: 'Sets the end annotation arrow head style.'\n },\n startarrowhead: {\n valType: 'integer',\n min: 0,\n max: ARROWPATHS.length,\n dflt: 1,\n editType: 'arraydraw',\n description: 'Sets the start annotation arrow head style.'\n },\n arrowside: {\n valType: 'flaglist',\n flags: ['end', 'start'],\n extras: ['none'],\n dflt: 'end',\n editType: 'arraydraw',\n description: 'Sets the annotation arrow head position.'\n },\n arrowsize: {\n valType: 'number',\n min: 0.3,\n dflt: 1,\n editType: 'calc+arraydraw',\n description: [\n 'Sets the size of the end annotation arrow head, relative to `arrowwidth`.',\n 'A value of 1 (default) gives a head about 3x as wide as the line.'\n ].join(' ')\n },\n startarrowsize: {\n valType: 'number',\n min: 0.3,\n dflt: 1,\n editType: 'calc+arraydraw',\n description: [\n 'Sets the size of the start annotation arrow head, relative to `arrowwidth`.',\n 'A value of 1 (default) gives a head about 3x as wide as the line.'\n ].join(' ')\n },\n arrowwidth: {\n valType: 'number',\n min: 0.1,\n editType: 'calc+arraydraw',\n description: 'Sets the width (in px) of annotation arrow line.'\n },\n standoff: {\n valType: 'number',\n min: 0,\n dflt: 0,\n editType: 'calc+arraydraw',\n description: [\n 'Sets a distance, in pixels, to move the end arrowhead away from the',\n 'position it is pointing at, for example to point at the edge of',\n 'a marker independent of zoom. Note that this shortens the arrow',\n 'from the `ax` / `ay` vector, in contrast to `xshift` / `yshift`',\n 'which moves everything by this amount.'\n ].join(' ')\n },\n startstandoff: {\n valType: 'number',\n min: 0,\n dflt: 0,\n editType: 'calc+arraydraw',\n description: [\n 'Sets a distance, in pixels, to move the start arrowhead away from the',\n 'position it is pointing at, for example to point at the edge of',\n 'a marker independent of zoom. Note that this shortens the arrow',\n 'from the `ax` / `ay` vector, in contrast to `xshift` / `yshift`',\n 'which moves everything by this amount.'\n ].join(' ')\n },\n ax: {\n valType: 'any',\n editType: 'calc+arraydraw',\n description: [\n arrowCoordinateDescription('x', 'left', 'right')\n ].join(' ')\n },\n ay: {\n valType: 'any',\n editType: 'calc+arraydraw',\n description: [\n arrowCoordinateDescription('y', 'top', 'bottom')\n ].join(' ')\n },\n axref: {\n valType: 'enumerated',\n dflt: 'pixel',\n values: [\n 'pixel',\n cartesianConstants.idRegex.x.toString()\n ],\n editType: 'calc',\n description: [\n 'Indicates in what coordinates the tail of the',\n 'annotation (ax,ay) is specified.',\n axisPlaceableObjs.axisRefDescription('x', 'left', 'right'),\n arrowAxisRefDescription('x')\n ].join(' ')\n },\n ayref: {\n valType: 'enumerated',\n dflt: 'pixel',\n values: [\n 'pixel',\n cartesianConstants.idRegex.y.toString()\n ],\n editType: 'calc',\n description: [\n 'Indicates in what coordinates the tail of the',\n 'annotation (ax,ay) is specified.',\n axisPlaceableObjs.axisRefDescription('y', 'bottom', 'top'),\n arrowAxisRefDescription('y')\n ].join(' ')\n },\n // positioning\n xref: {\n valType: 'enumerated',\n values: [\n 'paper',\n cartesianConstants.idRegex.x.toString()\n ],\n editType: 'calc',\n description: [\n 'Sets the annotation\\'s x coordinate axis.',\n axisPlaceableObjs.axisRefDescription('x', 'left', 'right'),\n ].join(' ')\n },\n x: {\n valType: 'any',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the annotation\\'s x position.',\n 'If the axis `type` is *log*, then you must take the',\n 'log of your desired range.',\n 'If the axis `type` is *date*, it should be date strings,',\n 'like date data, though Date objects and unix milliseconds',\n 'will be accepted and converted to strings.',\n 'If the axis `type` is *category*, it should be numbers,',\n 'using the scale where each category is assigned a serial',\n 'number from zero in the order it appears.'\n ].join(' ')\n },\n xanchor: {\n valType: 'enumerated',\n values: ['auto', 'left', 'center', 'right'],\n dflt: 'auto',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the text box\\'s horizontal position anchor',\n 'This anchor binds the `x` position to the *left*, *center*',\n 'or *right* of the annotation.',\n 'For example, if `x` is set to 1, `xref` to *paper* and',\n '`xanchor` to *right* then the right-most portion of the',\n 'annotation lines up with the right-most edge of the',\n 'plotting area.',\n 'If *auto*, the anchor is equivalent to *center* for',\n 'data-referenced annotations or if there is an arrow,',\n 'whereas for paper-referenced with no arrow, the anchor picked',\n 'corresponds to the closest side.'\n ].join(' ')\n },\n xshift: {\n valType: 'number',\n dflt: 0,\n editType: 'calc+arraydraw',\n description: [\n 'Shifts the position of the whole annotation and arrow to the',\n 'right (positive) or left (negative) by this many pixels.'\n ].join(' ')\n },\n yref: {\n valType: 'enumerated',\n values: [\n 'paper',\n cartesianConstants.idRegex.y.toString()\n ],\n editType: 'calc',\n description: [\n 'Sets the annotation\\'s y coordinate axis.',\n axisPlaceableObjs.axisRefDescription('y', 'bottom', 'top'),\n ].join(' ')\n },\n y: {\n valType: 'any',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the annotation\\'s y position.',\n 'If the axis `type` is *log*, then you must take the',\n 'log of your desired range.',\n 'If the axis `type` is *date*, it should be date strings,',\n 'like date data, though Date objects and unix milliseconds',\n 'will be accepted and converted to strings.',\n 'If the axis `type` is *category*, it should be numbers,',\n 'using the scale where each category is assigned a serial',\n 'number from zero in the order it appears.'\n ].join(' ')\n },\n yanchor: {\n valType: 'enumerated',\n values: ['auto', 'top', 'middle', 'bottom'],\n dflt: 'auto',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the text box\\'s vertical position anchor',\n 'This anchor binds the `y` position to the *top*, *middle*',\n 'or *bottom* of the annotation.',\n 'For example, if `y` is set to 1, `yref` to *paper* and',\n '`yanchor` to *top* then the top-most portion of the',\n 'annotation lines up with the top-most edge of the',\n 'plotting area.',\n 'If *auto*, the anchor is equivalent to *middle* for',\n 'data-referenced annotations or if there is an arrow,',\n 'whereas for paper-referenced with no arrow, the anchor picked',\n 'corresponds to the closest side.'\n ].join(' ')\n },\n yshift: {\n valType: 'number',\n dflt: 0,\n editType: 'calc+arraydraw',\n description: [\n 'Shifts the position of the whole annotation and arrow up',\n '(positive) or down (negative) by this many pixels.'\n ].join(' ')\n },\n clicktoshow: {\n valType: 'enumerated',\n values: [false, 'onoff', 'onout'],\n dflt: false,\n editType: 'arraydraw',\n description: [\n 'Makes this annotation respond to clicks on the plot.',\n 'If you click a data point that exactly matches the `x` and `y`',\n 'values of this annotation, and it is hidden (visible: false),',\n 'it will appear. In *onoff* mode, you must click the same point',\n 'again to make it disappear, so if you click multiple points,',\n 'you can show multiple annotations. In *onout* mode, a click',\n 'anywhere else in the plot (on another data point or not) will',\n 'hide this annotation.',\n 'If you need to show/hide this annotation in response to different',\n '`x` or `y` values, you can set `xclick` and/or `yclick`. This is',\n 'useful for example to label the side of a bar. To label markers',\n 'though, `standoff` is preferred over `xclick` and `yclick`.'\n ].join(' ')\n },\n xclick: {\n valType: 'any',\n editType: 'arraydraw',\n description: [\n 'Toggle this annotation when clicking a data point whose `x` value',\n 'is `xclick` rather than the annotation\\'s `x` value.'\n ].join(' ')\n },\n yclick: {\n valType: 'any',\n editType: 'arraydraw',\n description: [\n 'Toggle this annotation when clicking a data point whose `y` value',\n 'is `yclick` rather than the annotation\\'s `y` value.'\n ].join(' ')\n },\n hovertext: {\n valType: 'string',\n editType: 'arraydraw',\n description: [\n 'Sets text to appear when hovering over this annotation.',\n 'If omitted or blank, no hover label will appear.'\n ].join(' ')\n },\n hoverlabel: {\n bgcolor: {\n valType: 'color',\n editType: 'arraydraw',\n description: [\n 'Sets the background color of the hover label.',\n 'By default uses the annotation\\'s `bgcolor` made opaque,',\n 'or white if it was transparent.'\n ].join(' ')\n },\n bordercolor: {\n valType: 'color',\n editType: 'arraydraw',\n description: [\n 'Sets the border color of the hover label.',\n 'By default uses either dark grey or white, for maximum',\n 'contrast with `hoverlabel.bgcolor`.'\n ].join(' ')\n },\n font: fontAttrs({\n editType: 'arraydraw',\n description: [\n 'Sets the hover label text font.',\n 'By default uses the global hover font and size,',\n 'with color from `hoverlabel.bordercolor`.'\n ].join(' ')\n }),\n editType: 'arraydraw'\n },\n captureevents: {\n valType: 'boolean',\n editType: 'arraydraw',\n description: [\n 'Determines whether the annotation text box captures mouse move',\n 'and click events, or allows those events to pass through to data',\n 'points in the plot that may be behind the annotation. By default',\n '`captureevents` is *false* unless `hovertext` is provided.',\n 'If you use the event `plotly_clickannotation` without `hovertext`',\n 'you must explicitly enable `captureevents`.'\n ].join(' ')\n },\n editType: 'calc',\n\n _deprecated: {\n ref: {\n valType: 'string',\n editType: 'calc',\n description: [\n 'Obsolete. Set `xref` and `yref` separately instead.'\n ].join(' ')\n }\n }\n});\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\n\nvar draw = require('./draw').draw;\n\n\nmodule.exports = function calcAutorange(gd) {\n var fullLayout = gd._fullLayout;\n var annotationList = Lib.filterVisible(fullLayout.annotations);\n\n if(annotationList.length && gd._fullData.length) {\n return Lib.syncOrAsync([draw, annAutorange], gd);\n }\n};\n\nfunction annAutorange(gd) {\n var fullLayout = gd._fullLayout;\n\n // find the bounding boxes for each of these annotations'\n // relative to their anchor points\n // use the arrow and the text bg rectangle,\n // as the whole anno may include hidden text in its bbox\n Lib.filterVisible(fullLayout.annotations).forEach(function(ann) {\n var xa = Axes.getFromId(gd, ann.xref);\n var ya = Axes.getFromId(gd, ann.yref);\n var xRefType = Axes.getRefType(ann.xref);\n var yRefType = Axes.getRefType(ann.yref);\n\n ann._extremes = {};\n if(xRefType === 'range') calcAxisExpansion(ann, xa);\n if(yRefType === 'range') calcAxisExpansion(ann, ya);\n });\n}\n\nfunction calcAxisExpansion(ann, ax) {\n var axId = ax._id;\n var letter = axId.charAt(0);\n var pos = ann[letter];\n var apos = ann['a' + letter];\n var ref = ann[letter + 'ref'];\n var aref = ann['a' + letter + 'ref'];\n var padplus = ann['_' + letter + 'padplus'];\n var padminus = ann['_' + letter + 'padminus'];\n var shift = {x: 1, y: -1}[letter] * ann[letter + 'shift'];\n var headSize = 3 * ann.arrowsize * ann.arrowwidth || 0;\n var headPlus = headSize + shift;\n var headMinus = headSize - shift;\n var startHeadSize = 3 * ann.startarrowsize * ann.arrowwidth || 0;\n var startHeadPlus = startHeadSize + shift;\n var startHeadMinus = startHeadSize - shift;\n var extremes;\n\n if(aref === ref) {\n // expand for the arrowhead (padded by arrowhead)\n var extremeArrowHead = Axes.findExtremes(ax, [ax.r2c(pos)], {\n ppadplus: headPlus,\n ppadminus: headMinus\n });\n // again for the textbox (padded by textbox)\n var extremeText = Axes.findExtremes(ax, [ax.r2c(apos)], {\n ppadplus: Math.max(padplus, startHeadPlus),\n ppadminus: Math.max(padminus, startHeadMinus)\n });\n extremes = {\n min: [extremeArrowHead.min[0], extremeText.min[0]],\n max: [extremeArrowHead.max[0], extremeText.max[0]]\n };\n } else {\n startHeadPlus = apos ? startHeadPlus + apos : startHeadPlus;\n startHeadMinus = apos ? startHeadMinus - apos : startHeadMinus;\n extremes = Axes.findExtremes(ax, [ax.r2c(pos)], {\n ppadplus: Math.max(padplus, headPlus, startHeadPlus),\n ppadminus: Math.max(padminus, headMinus, startHeadMinus)\n });\n }\n\n ann._extremes[axId] = extremes;\n}\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\nvar arrayEditor = require('../../plot_api/plot_template').arrayEditor;\n\nmodule.exports = {\n hasClickToShow: hasClickToShow,\n onClick: onClick\n};\n\n/*\n * hasClickToShow: does the given hoverData have ANY annotations which will\n * turn ON if we click here? (used by hover events to set cursor)\n *\n * gd: graphDiv\n * hoverData: a hoverData array, as included with the *plotly_hover* or\n * *plotly_click* events in the `points` attribute\n *\n * returns: boolean\n */\nfunction hasClickToShow(gd, hoverData) {\n var sets = getToggleSets(gd, hoverData);\n return sets.on.length > 0 || sets.explicitOff.length > 0;\n}\n\n/*\n * onClick: perform the toggling (via Plotly.update) implied by clicking\n * at this hoverData\n *\n * gd: graphDiv\n * hoverData: a hoverData array, as included with the *plotly_hover* or\n * *plotly_click* events in the `points` attribute\n *\n * returns: Promise that the update is complete\n */\nfunction onClick(gd, hoverData) {\n var toggleSets = getToggleSets(gd, hoverData);\n var onSet = toggleSets.on;\n var offSet = toggleSets.off.concat(toggleSets.explicitOff);\n var update = {};\n var annotationsOut = gd._fullLayout.annotations;\n var i, editHelpers;\n\n if(!(onSet.length || offSet.length)) return;\n\n for(i = 0; i < onSet.length; i++) {\n editHelpers = arrayEditor(gd.layout, 'annotations', annotationsOut[onSet[i]]);\n editHelpers.modifyItem('visible', true);\n Lib.extendFlat(update, editHelpers.getUpdateObj());\n }\n\n for(i = 0; i < offSet.length; i++) {\n editHelpers = arrayEditor(gd.layout, 'annotations', annotationsOut[offSet[i]]);\n editHelpers.modifyItem('visible', false);\n Lib.extendFlat(update, editHelpers.getUpdateObj());\n }\n\n return Registry.call('update', gd, {}, update);\n}\n\n/*\n * getToggleSets: find the annotations which will turn on or off at this\n * hoverData\n *\n * gd: graphDiv\n * hoverData: a hoverData array, as included with the *plotly_hover* or\n * *plotly_click* events in the `points` attribute\n *\n * returns: {\n * on: Array (indices of annotations to turn on),\n * off: Array (indices to turn off because you're not hovering on them),\n * explicitOff: Array (indices to turn off because you *are* hovering on them)\n * }\n */\nfunction getToggleSets(gd, hoverData) {\n var annotations = gd._fullLayout.annotations;\n var onSet = [];\n var offSet = [];\n var explicitOffSet = [];\n var hoverLen = (hoverData || []).length;\n\n var i, j, anni, showMode, pointj, xa, ya, toggleType;\n\n for(i = 0; i < annotations.length; i++) {\n anni = annotations[i];\n showMode = anni.clicktoshow;\n\n if(showMode) {\n for(j = 0; j < hoverLen; j++) {\n pointj = hoverData[j];\n xa = pointj.xaxis;\n ya = pointj.yaxis;\n\n if(xa._id === anni.xref &&\n ya._id === anni.yref &&\n xa.d2r(pointj.x) === clickData2r(anni._xclick, xa) &&\n ya.d2r(pointj.y) === clickData2r(anni._yclick, ya)\n ) {\n // match! toggle this annotation\n // regardless of its clicktoshow mode\n // but if it's onout mode, off is implicit\n if(anni.visible) {\n if(showMode === 'onout') toggleType = offSet;\n else toggleType = explicitOffSet;\n } else {\n toggleType = onSet;\n }\n toggleType.push(i);\n break;\n }\n }\n\n if(j === hoverLen) {\n // no match - only turn this annotation OFF, and only if\n // showmode is 'onout'\n if(anni.visible && showMode === 'onout') offSet.push(i);\n }\n }\n }\n\n return {on: onSet, off: offSet, explicitOff: explicitOffSet};\n}\n\n// to handle log axes until v3\nfunction clickData2r(d, ax) {\n return ax.type === 'log' ? ax.l2r(d) : ax.d2r(d);\n}\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../color');\n\n// defaults common to 'annotations' and 'annotations3d'\nmodule.exports = function handleAnnotationCommonDefaults(annIn, annOut, fullLayout, coerce) {\n coerce('opacity');\n var bgColor = coerce('bgcolor');\n\n var borderColor = coerce('bordercolor');\n var borderOpacity = Color.opacity(borderColor);\n\n coerce('borderpad');\n\n var borderWidth = coerce('borderwidth');\n var showArrow = coerce('showarrow');\n\n coerce('text', showArrow ? ' ' : fullLayout._dfltTitle.annotation);\n coerce('textangle');\n Lib.coerceFont(coerce, 'font', fullLayout.font);\n\n coerce('width');\n coerce('align');\n\n var h = coerce('height');\n if(h) coerce('valign');\n\n if(showArrow) {\n var arrowside = coerce('arrowside');\n var arrowhead;\n var arrowsize;\n\n if(arrowside.indexOf('end') !== -1) {\n arrowhead = coerce('arrowhead');\n arrowsize = coerce('arrowsize');\n }\n\n if(arrowside.indexOf('start') !== -1) {\n coerce('startarrowhead', arrowhead);\n coerce('startarrowsize', arrowsize);\n }\n coerce('arrowcolor', borderOpacity ? annOut.bordercolor : Color.defaultLine);\n coerce('arrowwidth', ((borderOpacity && borderWidth) || 1) * 2);\n coerce('standoff');\n coerce('startstandoff');\n }\n\n var hoverText = coerce('hovertext');\n var globalHoverLabel = fullLayout.hoverlabel || {};\n\n if(hoverText) {\n var hoverBG = coerce('hoverlabel.bgcolor', globalHoverLabel.bgcolor ||\n (Color.opacity(bgColor) ? Color.rgb(bgColor) : Color.defaultLine)\n );\n\n var hoverBorder = coerce('hoverlabel.bordercolor', globalHoverLabel.bordercolor ||\n Color.contrast(hoverBG)\n );\n\n var fontDflt = Lib.extendFlat({}, globalHoverLabel.font);\n if(!fontDflt.color) {\n fontDflt.color = hoverBorder;\n }\n\n Lib.coerceFont(coerce, 'hoverlabel.font', fontDflt);\n }\n\n coerce('captureevents', !!hoverText);\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar toLogRange = require('../../lib/to_log_range');\n\n/*\n * convertCoords: when converting an axis between log and linear\n * you need to alter any annotations on that axis to keep them\n * pointing at the same data point.\n * In v3.0 this will become obsolete\n *\n * gd: the plot div\n * ax: the axis being changed\n * newType: the type it's getting\n * doExtra: function(attr, val) from inside relayout that sets the attribute.\n * Use this to make the changes as it's aware if any other changes in the\n * same relayout call should override this conversion.\n */\nmodule.exports = function convertCoords(gd, ax, newType, doExtra) {\n ax = ax || {};\n\n var toLog = (newType === 'log') && (ax.type === 'linear');\n var fromLog = (newType === 'linear') && (ax.type === 'log');\n\n if(!(toLog || fromLog)) return;\n\n var annotations = gd._fullLayout.annotations;\n var axLetter = ax._id.charAt(0);\n var ann;\n var attrPrefix;\n\n function convert(attr) {\n var currentVal = ann[attr];\n var newVal = null;\n\n if(toLog) newVal = toLogRange(currentVal, ax.range);\n else newVal = Math.pow(10, currentVal);\n\n // if conversion failed, delete the value so it gets a default value\n if(!isNumeric(newVal)) newVal = null;\n\n doExtra(attrPrefix + attr, newVal);\n }\n\n for(var i = 0; i < annotations.length; i++) {\n ann = annotations[i];\n attrPrefix = 'annotations[' + i + '].';\n\n if(ann[axLetter + 'ref'] === ax._id) convert(axLetter);\n if(ann['a' + axLetter + 'ref'] === ax._id) convert('a' + axLetter);\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar handleAnnotationCommonDefaults = require('./common_defaults');\nvar attributes = require('./attributes');\n\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n handleArrayContainerDefaults(layoutIn, layoutOut, {\n name: 'annotations',\n handleItemDefaults: handleAnnotationDefaults\n });\n};\n\nfunction handleAnnotationDefaults(annIn, annOut, fullLayout) {\n function coerce(attr, dflt) {\n return Lib.coerce(annIn, annOut, attributes, attr, dflt);\n }\n\n var visible = coerce('visible');\n var clickToShow = coerce('clicktoshow');\n\n if(!(visible || clickToShow)) return;\n\n handleAnnotationCommonDefaults(annIn, annOut, fullLayout, coerce);\n\n var showArrow = annOut.showarrow;\n\n // positioning\n var axLetters = ['x', 'y'];\n var arrowPosDflt = [-10, -30];\n var gdMock = {_fullLayout: fullLayout};\n\n for(var i = 0; i < 2; i++) {\n var axLetter = axLetters[i];\n\n // xref, yref\n var axRef = Axes.coerceRef(annIn, annOut, gdMock, axLetter, '', 'paper');\n\n if(axRef !== 'paper') {\n var ax = Axes.getFromId(gdMock, axRef);\n ax._annIndices.push(annOut._index);\n }\n\n // x, y\n Axes.coercePosition(annOut, gdMock, coerce, axRef, axLetter, 0.5);\n\n if(showArrow) {\n var arrowPosAttr = 'a' + axLetter;\n // axref, ayref\n var aaxRef = Axes.coerceRef(annIn, annOut, gdMock, arrowPosAttr, 'pixel',\n ['pixel', 'paper']);\n\n // for now the arrow can only be on the same axis or specified as pixels\n // TODO: sometime it might be interesting to allow it to be on *any* axis\n // but that would require updates to drawing & autorange code and maybe more\n if(aaxRef !== 'pixel' && aaxRef !== axRef) {\n aaxRef = annOut[arrowPosAttr] = 'pixel';\n }\n\n // ax, ay\n var aDflt = (aaxRef === 'pixel') ? arrowPosDflt[i] : 0.4;\n Axes.coercePosition(annOut, gdMock, coerce, aaxRef, arrowPosAttr, aDflt);\n }\n\n // xanchor, yanchor\n coerce(axLetter + 'anchor');\n\n // xshift, yshift\n coerce(axLetter + 'shift');\n }\n\n // if you have one coordinate you should have both\n Lib.noneOrAll(annIn, annOut, ['x', 'y']);\n\n // if you have one part of arrow length you should have both\n if(showArrow) {\n Lib.noneOrAll(annIn, annOut, ['ax', 'ay']);\n }\n\n if(clickToShow) {\n var xClick = coerce('xclick');\n var yClick = coerce('yclick');\n\n // put the actual click data to bind to into private attributes\n // so we don't have to do this little bit of logic on every hover event\n annOut._xclick = (xClick === undefined) ?\n annOut.x :\n Axes.cleanPosition(xClick, gdMock, annOut.xref);\n annOut._yclick = (yClick === undefined) ?\n annOut.y :\n Axes.cleanPosition(yClick, gdMock, annOut.yref);\n }\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Registry = require('../../registry');\nvar Plots = require('../../plots/plots');\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar Axes = require('../../plots/cartesian/axes');\nvar Color = require('../color');\nvar Drawing = require('../drawing');\nvar Fx = require('../fx');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar setCursor = require('../../lib/setcursor');\nvar dragElement = require('../dragelement');\nvar arrayEditor = require('../../plot_api/plot_template').arrayEditor;\n\nvar drawArrowHead = require('./draw_arrow_head');\n\n// Annotations are stored in gd.layout.annotations, an array of objects\n// index can point to one item in this array,\n// or non-numeric to simply add a new one\n// or -1 to modify all existing\n// opt can be the full options object, or one key (to be set to value)\n// or undefined to simply redraw\n// if opt is blank, val can be 'add' or a full options object to add a new\n// annotation at that point in the array, or 'remove' to delete this one\n\nmodule.exports = {\n draw: draw,\n drawOne: drawOne,\n drawRaw: drawRaw\n};\n\n/*\n * draw: draw all annotations without any new modifications\n */\nfunction draw(gd) {\n var fullLayout = gd._fullLayout;\n\n fullLayout._infolayer.selectAll('.annotation').remove();\n\n for(var i = 0; i < fullLayout.annotations.length; i++) {\n if(fullLayout.annotations[i].visible) {\n drawOne(gd, i);\n }\n }\n\n return Plots.previousPromises(gd);\n}\n\n/*\n * drawOne: draw a single cartesian or paper-ref annotation, potentially with modifications\n *\n * index (int): the annotation to draw\n */\nfunction drawOne(gd, index) {\n var fullLayout = gd._fullLayout;\n var options = fullLayout.annotations[index] || {};\n var xa = Axes.getFromId(gd, options.xref);\n var ya = Axes.getFromId(gd, options.yref);\n\n if(xa) xa.setScale();\n if(ya) ya.setScale();\n\n drawRaw(gd, options, index, false, xa, ya);\n}\n\n// Convert pixels to the coordinates relevant for the axis referred to. For\n// example, for paper it would convert to a value normalized by the dimension of\n// the plot.\n// axDomainRef: if true and axa defined, draws relative to axis domain,\n// otherwise draws relative to data (if axa defined) or paper (if not).\nfunction shiftPosition(axa, dAx, axLetter, gs, options) {\n var optAx = options[axLetter];\n var axRef = options[axLetter + 'ref'];\n var vertical = axLetter.indexOf('y') !== -1;\n var axDomainRef = Axes.getRefType(axRef) === 'domain';\n var gsDim = vertical ? gs.h : gs.w;\n if(axa) {\n if(axDomainRef) {\n // here optAx normalized to length of axis (e.g., normally in range\n // 0 to 1). But dAx is in pixels. So we normalize dAx to length of\n // axis before doing the math.\n return optAx + (vertical ? -dAx : dAx) / axa._length;\n } else {\n return axa.p2r(axa.r2p(optAx) + dAx);\n }\n } else {\n return optAx + (vertical ? -dAx : dAx) / gsDim;\n }\n}\n\n/**\n * drawRaw: draw a single annotation, potentially with modifications\n *\n * @param {DOM element} gd\n * @param {object} options : this annotation's fullLayout options\n * @param {integer} index : index in 'annotations' container of the annotation to draw\n * @param {string} subplotId : id of the annotation's subplot\n * - use false for 2d (i.e. cartesian or paper-ref) annotations\n * @param {object | undefined} xa : full x-axis object to compute subplot pos-to-px\n * @param {object | undefined} ya : ... y-axis\n */\nfunction drawRaw(gd, options, index, subplotId, xa, ya) {\n var fullLayout = gd._fullLayout;\n var gs = gd._fullLayout._size;\n var edits = gd._context.edits;\n\n var className, containerStr;\n\n if(subplotId) {\n className = 'annotation-' + subplotId;\n containerStr = subplotId + '.annotations';\n } else {\n className = 'annotation';\n containerStr = 'annotations';\n }\n\n var editHelpers = arrayEditor(gd.layout, containerStr, options);\n var modifyBase = editHelpers.modifyBase;\n var modifyItem = editHelpers.modifyItem;\n var getUpdateObj = editHelpers.getUpdateObj;\n\n // remove the existing annotation if there is one\n fullLayout._infolayer\n .selectAll('.' + className + '[data-index=\"' + index + '\"]')\n .remove();\n\n var annClipID = 'clip' + fullLayout._uid + '_ann' + index;\n\n // this annotation is gone - quit now after deleting it\n // TODO: use d3 idioms instead of deleting and redrawing every time\n if(!options._input || options.visible === false) {\n d3.selectAll('#' + annClipID).remove();\n return;\n }\n\n // calculated pixel positions\n // x & y each will get text, head, and tail as appropriate\n var annPosPx = {x: {}, y: {}};\n var textangle = +options.textangle || 0;\n\n // create the components\n // made a single group to contain all, so opacity can work right\n // with border/arrow together this could handle a whole bunch of\n // cleanup at this point, but works for now\n var annGroup = fullLayout._infolayer.append('g')\n .classed(className, true)\n .attr('data-index', String(index))\n .style('opacity', options.opacity);\n\n // another group for text+background so that they can rotate together\n var annTextGroup = annGroup.append('g')\n .classed('annotation-text-g', true);\n\n var editTextPosition = edits[options.showarrow ? 'annotationTail' : 'annotationPosition'];\n var textEvents = options.captureevents || edits.annotationText || editTextPosition;\n\n function makeEventData(initialEvent) {\n var eventData = {\n index: index,\n annotation: options._input,\n fullAnnotation: options,\n event: initialEvent\n };\n if(subplotId) {\n eventData.subplotId = subplotId;\n }\n return eventData;\n }\n\n var annTextGroupInner = annTextGroup.append('g')\n .style('pointer-events', textEvents ? 'all' : null)\n .call(setCursor, 'pointer')\n .on('click', function() {\n gd._dragging = false;\n gd.emit('plotly_clickannotation', makeEventData(d3.event));\n });\n\n if(options.hovertext) {\n annTextGroupInner\n .on('mouseover', function() {\n var hoverOptions = options.hoverlabel;\n var hoverFont = hoverOptions.font;\n var bBox = this.getBoundingClientRect();\n var bBoxRef = gd.getBoundingClientRect();\n\n Fx.loneHover({\n x0: bBox.left - bBoxRef.left,\n x1: bBox.right - bBoxRef.left,\n y: (bBox.top + bBox.bottom) / 2 - bBoxRef.top,\n text: options.hovertext,\n color: hoverOptions.bgcolor,\n borderColor: hoverOptions.bordercolor,\n fontFamily: hoverFont.family,\n fontSize: hoverFont.size,\n fontColor: hoverFont.color,\n fontWeight: hoverFont.weight,\n fontStyle: hoverFont.style,\n fontVariant: hoverFont.variant,\n fontShadow: hoverFont.fontShadow,\n fontLineposition: hoverFont.fontLineposition,\n fontTextcase: hoverFont.fontTextcase,\n }, {\n container: fullLayout._hoverlayer.node(),\n outerContainer: fullLayout._paper.node(),\n gd: gd\n });\n })\n .on('mouseout', function() {\n Fx.loneUnhover(fullLayout._hoverlayer.node());\n });\n }\n\n var borderwidth = options.borderwidth;\n var borderpad = options.borderpad;\n var borderfull = borderwidth + borderpad;\n\n var annTextBG = annTextGroupInner.append('rect')\n .attr('class', 'bg')\n .style('stroke-width', borderwidth + 'px')\n .call(Color.stroke, options.bordercolor)\n .call(Color.fill, options.bgcolor);\n\n var isSizeConstrained = options.width || options.height;\n\n var annTextClip = fullLayout._topclips\n .selectAll('#' + annClipID)\n .data(isSizeConstrained ? [0] : []);\n\n annTextClip.enter().append('clipPath')\n .classed('annclip', true)\n .attr('id', annClipID)\n .append('rect');\n annTextClip.exit().remove();\n\n var font = options.font;\n\n var text = fullLayout._meta ?\n Lib.templateString(options.text, fullLayout._meta) :\n options.text;\n\n var annText = annTextGroupInner.append('text')\n .classed('annotation-text', true)\n .text(text);\n\n function textLayout(s) {\n s.call(Drawing.font, font)\n .attr({\n 'text-anchor': {\n left: 'start',\n right: 'end'\n }[options.align] || 'middle'\n });\n\n svgTextUtils.convertToTspans(s, gd, drawGraphicalElements);\n return s;\n }\n\n function drawGraphicalElements() {\n // if the text has *only* a link, make the whole box into a link\n var anchor3 = annText.selectAll('a');\n if(anchor3.size() === 1 && anchor3.text() === annText.text()) {\n var wholeLink = annTextGroupInner.insert('a', ':first-child').attr({\n 'xlink:xlink:href': anchor3.attr('xlink:href'),\n 'xlink:xlink:show': anchor3.attr('xlink:show')\n })\n .style({cursor: 'pointer'});\n\n wholeLink.node().appendChild(annTextBG.node());\n }\n\n var mathjaxGroup = annTextGroupInner.select('.annotation-text-math-group');\n var hasMathjax = !mathjaxGroup.empty();\n var anntextBB = Drawing.bBox(\n (hasMathjax ? mathjaxGroup : annText).node());\n var textWidth = anntextBB.width;\n var textHeight = anntextBB.height;\n var annWidth = options.width || textWidth;\n var annHeight = options.height || textHeight;\n var outerWidth = Math.round(annWidth + 2 * borderfull);\n var outerHeight = Math.round(annHeight + 2 * borderfull);\n\n function shiftFraction(v, anchor) {\n if(anchor === 'auto') {\n if(v < 1 / 3) anchor = 'left';\n else if(v > 2 / 3) anchor = 'right';\n else anchor = 'center';\n }\n return {\n center: 0,\n middle: 0,\n left: 0.5,\n bottom: -0.5,\n right: -0.5,\n top: 0.5\n }[anchor];\n }\n\n var annotationIsOffscreen = false;\n var letters = ['x', 'y'];\n\n for(var i = 0; i < letters.length; i++) {\n var axLetter = letters[i];\n var axRef = options[axLetter + 'ref'] || axLetter;\n var tailRef = options['a' + axLetter + 'ref'];\n var ax = {x: xa, y: ya}[axLetter];\n var dimAngle = (textangle + (axLetter === 'x' ? 0 : -90)) * Math.PI / 180;\n // note that these two can be either positive or negative\n var annSizeFromWidth = outerWidth * Math.cos(dimAngle);\n var annSizeFromHeight = outerHeight * Math.sin(dimAngle);\n // but this one is the positive total size\n var annSize = Math.abs(annSizeFromWidth) + Math.abs(annSizeFromHeight);\n var anchor = options[axLetter + 'anchor'];\n var overallShift = options[axLetter + 'shift'] * (axLetter === 'x' ? 1 : -1);\n var posPx = annPosPx[axLetter];\n var basePx;\n var textPadShift;\n var alignPosition;\n var autoAlignFraction;\n var textShift;\n var axRefType = Axes.getRefType(axRef);\n\n /*\n * calculate the *primary* pixel position\n * which is the arrowhead if there is one,\n * otherwise the text anchor point\n */\n if(ax && (axRefType !== 'domain')) {\n // check if annotation is off screen, to bypass DOM manipulations\n var posFraction = ax.r2fraction(options[axLetter]);\n if(posFraction < 0 || posFraction > 1) {\n if(tailRef === axRef) {\n posFraction = ax.r2fraction(options['a' + axLetter]);\n if(posFraction < 0 || posFraction > 1) {\n annotationIsOffscreen = true;\n }\n } else {\n annotationIsOffscreen = true;\n }\n }\n basePx = ax._offset + ax.r2p(options[axLetter]);\n autoAlignFraction = 0.5;\n } else {\n var axRefTypeEqDomain = axRefType === 'domain';\n if(axLetter === 'x') {\n alignPosition = options[axLetter];\n basePx = axRefTypeEqDomain ?\n ax._offset + ax._length * alignPosition :\n basePx = gs.l + gs.w * alignPosition;\n } else {\n alignPosition = 1 - options[axLetter];\n basePx = axRefTypeEqDomain ?\n ax._offset + ax._length * alignPosition :\n basePx = gs.t + gs.h * alignPosition;\n }\n autoAlignFraction = options.showarrow ? 0.5 : alignPosition;\n }\n\n // now translate this into pixel positions of head, tail, and text\n // as well as paddings for autorange\n if(options.showarrow) {\n posPx.head = basePx;\n\n var arrowLength = options['a' + axLetter];\n\n // with an arrow, the text rotates around the anchor point\n textShift = annSizeFromWidth * shiftFraction(0.5, options.xanchor) -\n annSizeFromHeight * shiftFraction(0.5, options.yanchor);\n\n if(tailRef === axRef) {\n // In the case tailRefType is 'domain' or 'paper', the arrow's\n // position is set absolutely, which is consistent with how\n // it behaves when its position is set in data ('range')\n // coordinates.\n var tailRefType = Axes.getRefType(tailRef);\n if(tailRefType === 'domain') {\n if(axLetter === 'y') {\n arrowLength = 1 - arrowLength;\n }\n posPx.tail = ax._offset + ax._length * arrowLength;\n } else if(tailRefType === 'paper') {\n if(axLetter === 'y') {\n arrowLength = 1 - arrowLength;\n posPx.tail = gs.t + gs.h * arrowLength;\n } else {\n posPx.tail = gs.l + gs.w * arrowLength;\n }\n } else {\n // assumed tailRef is range or paper referenced\n posPx.tail = ax._offset + ax.r2p(arrowLength);\n }\n // tail is range- or domain-referenced: autorange pads the\n // text in px from the tail\n textPadShift = textShift;\n } else {\n posPx.tail = basePx + arrowLength;\n // tail is specified in px from head, so autorange also pads vs head\n textPadShift = textShift + arrowLength;\n }\n\n posPx.text = posPx.tail + textShift;\n\n // constrain pixel/paper referenced so the draggers are at least\n // partially visible\n var maxPx = fullLayout[(axLetter === 'x') ? 'width' : 'height'];\n if(axRef === 'paper') {\n posPx.head = Lib.constrain(posPx.head, 1, maxPx - 1);\n }\n if(tailRef === 'pixel') {\n var shiftPlus = -Math.max(posPx.tail - 3, posPx.text);\n var shiftMinus = Math.min(posPx.tail + 3, posPx.text) - maxPx;\n if(shiftPlus > 0) {\n posPx.tail += shiftPlus;\n posPx.text += shiftPlus;\n } else if(shiftMinus > 0) {\n posPx.tail -= shiftMinus;\n posPx.text -= shiftMinus;\n }\n }\n\n posPx.tail += overallShift;\n posPx.head += overallShift;\n } else {\n // with no arrow, the text rotates and *then* we put the anchor\n // relative to the new bounding box\n textShift = annSize * shiftFraction(autoAlignFraction, anchor);\n textPadShift = textShift;\n posPx.text = basePx + textShift;\n }\n\n posPx.text += overallShift;\n textShift += overallShift;\n textPadShift += overallShift;\n\n // padplus/minus are used by autorange\n options['_' + axLetter + 'padplus'] = (annSize / 2) + textPadShift;\n options['_' + axLetter + 'padminus'] = (annSize / 2) - textPadShift;\n\n // size/shift are used during dragging\n options['_' + axLetter + 'size'] = annSize;\n options['_' + axLetter + 'shift'] = textShift;\n }\n\n if(annotationIsOffscreen) {\n annTextGroupInner.remove();\n return;\n }\n\n var xShift = 0;\n var yShift = 0;\n\n if(options.align !== 'left') {\n xShift = (annWidth - textWidth) * (options.align === 'center' ? 0.5 : 1);\n }\n if(options.valign !== 'top') {\n yShift = (annHeight - textHeight) * (options.valign === 'middle' ? 0.5 : 1);\n }\n\n if(hasMathjax) {\n mathjaxGroup.select('svg').attr({\n x: borderfull + xShift - 1,\n y: borderfull + yShift\n })\n .call(Drawing.setClipUrl, isSizeConstrained ? annClipID : null, gd);\n } else {\n var texty = borderfull + yShift - anntextBB.top;\n var textx = borderfull + xShift - anntextBB.left;\n\n annText.call(svgTextUtils.positionText, textx, texty)\n .call(Drawing.setClipUrl, isSizeConstrained ? annClipID : null, gd);\n }\n\n annTextClip.select('rect').call(Drawing.setRect, borderfull, borderfull,\n annWidth, annHeight);\n\n annTextBG.call(Drawing.setRect, borderwidth / 2, borderwidth / 2,\n outerWidth - borderwidth, outerHeight - borderwidth);\n\n annTextGroupInner.call(Drawing.setTranslate,\n Math.round(annPosPx.x.text - outerWidth / 2),\n Math.round(annPosPx.y.text - outerHeight / 2));\n\n /*\n * rotate text and background\n * we already calculated the text center position *as rotated*\n * because we needed that for autoranging anyway, so now whether\n * we have an arrow or not, we rotate about the text center.\n */\n annTextGroup.attr({transform: 'rotate(' + textangle + ',' +\n annPosPx.x.text + ',' + annPosPx.y.text + ')'});\n\n /*\n * add the arrow\n * uses options[arrowwidth,arrowcolor,arrowhead] for styling\n * dx and dy are normally zero, but when you are dragging the textbox\n * while the head stays put, dx and dy are the pixel offsets\n */\n var drawArrow = function(dx, dy) {\n annGroup\n .selectAll('.annotation-arrow-g')\n .remove();\n\n var headX = annPosPx.x.head;\n var headY = annPosPx.y.head;\n var tailX = annPosPx.x.tail + dx;\n var tailY = annPosPx.y.tail + dy;\n var textX = annPosPx.x.text + dx;\n var textY = annPosPx.y.text + dy;\n\n // find the edge of the text box, where we'll start the arrow:\n // create transform matrix to rotate the text box corners\n var transform = Lib.rotationXYMatrix(textangle, textX, textY);\n var applyTransform = Lib.apply2DTransform(transform);\n var applyTransform2 = Lib.apply2DTransform2(transform);\n\n // calculate and transform bounding box\n var width = +annTextBG.attr('width');\n var height = +annTextBG.attr('height');\n var xLeft = textX - 0.5 * width;\n var xRight = xLeft + width;\n var yTop = textY - 0.5 * height;\n var yBottom = yTop + height;\n var edges = [\n [xLeft, yTop, xLeft, yBottom],\n [xLeft, yBottom, xRight, yBottom],\n [xRight, yBottom, xRight, yTop],\n [xRight, yTop, xLeft, yTop]\n ].map(applyTransform2);\n\n // Remove the line if it ends inside the box. Use ray\n // casting for rotated boxes: see which edges intersect a\n // line from the arrowhead to far away and reduce with xor\n // to get the parity of the number of intersections.\n if(edges.reduce(function(a, x) {\n return a ^\n !!Lib.segmentsIntersect(headX, headY, headX + 1e6, headY + 1e6,\n x[0], x[1], x[2], x[3]);\n }, false)) {\n // no line or arrow - so quit drawArrow now\n return;\n }\n\n edges.forEach(function(x) {\n var p = Lib.segmentsIntersect(tailX, tailY, headX, headY,\n x[0], x[1], x[2], x[3]);\n if(p) {\n tailX = p.x;\n tailY = p.y;\n }\n });\n\n var strokewidth = options.arrowwidth;\n var arrowColor = options.arrowcolor;\n var arrowSide = options.arrowside;\n\n var arrowGroup = annGroup.append('g')\n .style({opacity: Color.opacity(arrowColor)})\n .classed('annotation-arrow-g', true);\n\n var arrow = arrowGroup.append('path')\n .attr('d', 'M' + tailX + ',' + tailY + 'L' + headX + ',' + headY)\n .style('stroke-width', strokewidth + 'px')\n .call(Color.stroke, Color.rgb(arrowColor));\n\n drawArrowHead(arrow, arrowSide, options);\n\n // the arrow dragger is a small square right at the head, then a line to the tail,\n // all expanded by a stroke width of 6px plus the arrow line width\n if(edits.annotationPosition && arrow.node().parentNode && !subplotId) {\n var arrowDragHeadX = headX;\n var arrowDragHeadY = headY;\n if(options.standoff) {\n var arrowLength = Math.sqrt(Math.pow(headX - tailX, 2) + Math.pow(headY - tailY, 2));\n arrowDragHeadX += options.standoff * (tailX - headX) / arrowLength;\n arrowDragHeadY += options.standoff * (tailY - headY) / arrowLength;\n }\n var arrowDrag = arrowGroup.append('path')\n .classed('annotation-arrow', true)\n .classed('anndrag', true)\n .classed('cursor-move', true)\n .attr({\n d: 'M3,3H-3V-3H3ZM0,0L' + (tailX - arrowDragHeadX) + ',' + (tailY - arrowDragHeadY),\n transform: strTranslate(arrowDragHeadX, arrowDragHeadY)\n })\n .style('stroke-width', (strokewidth + 6) + 'px')\n .call(Color.stroke, 'rgba(0,0,0,0)')\n .call(Color.fill, 'rgba(0,0,0,0)');\n\n var annx0, anny0;\n\n // dragger for the arrow & head: translates the whole thing\n // (head/tail/text) all together\n dragElement.init({\n element: arrowDrag.node(),\n gd: gd,\n prepFn: function() {\n var pos = Drawing.getTranslate(annTextGroupInner);\n\n annx0 = pos.x;\n anny0 = pos.y;\n if(xa && xa.autorange) {\n modifyBase(xa._name + '.autorange', true);\n }\n if(ya && ya.autorange) {\n modifyBase(ya._name + '.autorange', true);\n }\n },\n moveFn: function(dx, dy) {\n var annxy0 = applyTransform(annx0, anny0);\n var xcenter = annxy0[0] + dx;\n var ycenter = annxy0[1] + dy;\n annTextGroupInner.call(Drawing.setTranslate, xcenter, ycenter);\n\n modifyItem('x',\n shiftPosition(xa, dx, 'x', gs, options));\n modifyItem('y',\n shiftPosition(ya, dy, 'y', gs, options));\n\n // for these 2 calls to shiftPosition, it is assumed xa, ya are\n // defined, so gsDim will not be used, but we put it in\n // anyways for consistency\n if(options.axref === options.xref) {\n modifyItem('ax', shiftPosition(xa, dx, 'ax', gs, options));\n }\n\n if(options.ayref === options.yref) {\n modifyItem('ay', shiftPosition(ya, dy, 'ay', gs, options));\n }\n\n arrowGroup.attr('transform', strTranslate(dx, dy));\n annTextGroup.attr({\n transform: 'rotate(' + textangle + ',' +\n xcenter + ',' + ycenter + ')'\n });\n },\n doneFn: function() {\n Registry.call('_guiRelayout', gd, getUpdateObj());\n var notesBox = document.querySelector('.js-notes-box-panel');\n if(notesBox) notesBox.redraw(notesBox.selectedObj);\n }\n });\n }\n };\n\n if(options.showarrow) drawArrow(0, 0);\n\n // user dragging the annotation (text, not arrow)\n if(editTextPosition) {\n var baseTextTransform;\n\n // dragger for the textbox: if there's an arrow, just drag the\n // textbox and tail, leave the head untouched\n dragElement.init({\n element: annTextGroupInner.node(),\n gd: gd,\n prepFn: function() {\n baseTextTransform = annTextGroup.attr('transform');\n },\n moveFn: function(dx, dy) {\n var csr = 'pointer';\n if(options.showarrow) {\n // for these 2 calls to shiftPosition, it is assumed xa, ya are\n // defined, so gsDim will not be used, but we put it in\n // anyways for consistency\n if(options.axref === options.xref) {\n modifyItem('ax', shiftPosition(xa, dx, 'ax', gs, options));\n } else {\n modifyItem('ax', options.ax + dx);\n }\n\n if(options.ayref === options.yref) {\n modifyItem('ay', shiftPosition(ya, dy, 'ay', gs.w, options));\n } else {\n modifyItem('ay', options.ay + dy);\n }\n\n drawArrow(dx, dy);\n } else if(!subplotId) {\n var xUpdate, yUpdate;\n if(xa) {\n // shiftPosition will not execute code where xa was\n // undefined, so we use to calculate xUpdate too\n xUpdate = shiftPosition(xa, dx, 'x', gs, options);\n } else {\n var widthFraction = options._xsize / gs.w;\n var xLeft = options.x + (options._xshift - options.xshift) / gs.w - widthFraction / 2;\n\n xUpdate = dragElement.align(xLeft + dx / gs.w,\n widthFraction, 0, 1, options.xanchor);\n }\n\n if(ya) {\n // shiftPosition will not execute code where ya was\n // undefined, so we use to calculate yUpdate too\n yUpdate = shiftPosition(ya, dy, 'y', gs, options);\n } else {\n var heightFraction = options._ysize / gs.h;\n var yBottom = options.y - (options._yshift + options.yshift) / gs.h - heightFraction / 2;\n\n yUpdate = dragElement.align(yBottom - dy / gs.h,\n heightFraction, 0, 1, options.yanchor);\n }\n modifyItem('x', xUpdate);\n modifyItem('y', yUpdate);\n if(!xa || !ya) {\n csr = dragElement.getCursor(\n xa ? 0.5 : xUpdate,\n ya ? 0.5 : yUpdate,\n options.xanchor, options.yanchor\n );\n }\n } else return;\n\n annTextGroup.attr({\n transform: strTranslate(dx, dy) + baseTextTransform\n });\n\n setCursor(annTextGroupInner, csr);\n },\n clickFn: function(_, initialEvent) {\n if(options.captureevents) {\n gd.emit('plotly_clickannotation', makeEventData(initialEvent));\n }\n },\n doneFn: function() {\n setCursor(annTextGroupInner);\n Registry.call('_guiRelayout', gd, getUpdateObj());\n var notesBox = document.querySelector('.js-notes-box-panel');\n if(notesBox) notesBox.redraw(notesBox.selectedObj);\n }\n });\n }\n }\n\n if(edits.annotationText) {\n annText.call(svgTextUtils.makeEditable, {delegate: annTextGroupInner, gd: gd})\n .call(textLayout)\n .on('edit', function(_text) {\n options.text = _text;\n\n this.call(textLayout);\n\n modifyItem('text', _text);\n\n if(xa && xa.autorange) {\n modifyBase(xa._name + '.autorange', true);\n }\n if(ya && ya.autorange) {\n modifyBase(ya._name + '.autorange', true);\n }\n\n Registry.call('_guiRelayout', gd, getUpdateObj());\n });\n } else annText.call(textLayout);\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Color = require('../color');\n\nvar ARROWPATHS = require('./arrow_paths');\n\nvar Lib = require('../../lib');\nvar strScale = Lib.strScale;\nvar strRotate = Lib.strRotate;\nvar strTranslate = Lib.strTranslate;\n\n/**\n * Add arrowhead(s) to a path or line element\n *\n * @param {d3.selection} el3: a d3-selected line or path element\n *\n * @param {string} ends: 'none', 'start', 'end', or 'start+end' for which ends get arrowheads\n *\n * @param {object} options: style information. Must have all the following:\n * @param {number} options.arrowhead: end head style - see ./arrow_paths\n * @param {number} options.startarrowhead: start head style - see ./arrow_paths\n * @param {number} options.arrowsize: relative size of the end head vs line width\n * @param {number} options.startarrowsize: relative size of the start head vs line width\n * @param {number} options.standoff: distance in px to move the end arrow point from its target\n * @param {number} options.startstandoff: distance in px to move the start arrow point from its target\n * @param {number} options.arrowwidth: width of the arrow line\n * @param {string} options.arrowcolor: color of the arrow line, for the head to match\n * Note that the opacity of this color is ignored, as it's assumed the container\n * of both the line and head has opacity applied to it so there isn't greater opacity\n * where they overlap.\n */\nmodule.exports = function drawArrowHead(el3, ends, options) {\n var el = el3.node();\n var headStyle = ARROWPATHS[options.arrowhead || 0];\n var startHeadStyle = ARROWPATHS[options.startarrowhead || 0];\n var scale = (options.arrowwidth || 1) * (options.arrowsize || 1);\n var startScale = (options.arrowwidth || 1) * (options.startarrowsize || 1);\n var doStart = ends.indexOf('start') >= 0;\n var doEnd = ends.indexOf('end') >= 0;\n var backOff = headStyle.backoff * scale + options.standoff;\n var startBackOff = startHeadStyle.backoff * startScale + options.startstandoff;\n\n var start, end, startRot, endRot;\n\n if(el.nodeName === 'line') {\n start = {x: +el3.attr('x1'), y: +el3.attr('y1')};\n end = {x: +el3.attr('x2'), y: +el3.attr('y2')};\n\n var dx = start.x - end.x;\n var dy = start.y - end.y;\n\n startRot = Math.atan2(dy, dx);\n endRot = startRot + Math.PI;\n if(backOff && startBackOff) {\n if(backOff + startBackOff > Math.sqrt(dx * dx + dy * dy)) {\n hideLine();\n return;\n }\n }\n\n if(backOff) {\n if(backOff * backOff > dx * dx + dy * dy) {\n hideLine();\n return;\n }\n var backOffX = backOff * Math.cos(startRot);\n var backOffY = backOff * Math.sin(startRot);\n\n end.x += backOffX;\n end.y += backOffY;\n el3.attr({x2: end.x, y2: end.y});\n }\n\n if(startBackOff) {\n if(startBackOff * startBackOff > dx * dx + dy * dy) {\n hideLine();\n return;\n }\n var startBackOffX = startBackOff * Math.cos(startRot);\n var startbackOffY = startBackOff * Math.sin(startRot);\n\n start.x -= startBackOffX;\n start.y -= startbackOffY;\n el3.attr({x1: start.x, y1: start.y});\n }\n } else if(el.nodeName === 'path') {\n var pathlen = el.getTotalLength();\n // using dash to hide the backOff region of the path.\n // if we ever allow dash for the arrow we'll have to\n // do better than this hack... maybe just manually\n // combine the two\n var dashArray = '';\n\n if(pathlen < backOff + startBackOff) {\n hideLine();\n return;\n }\n\n\n var start0 = el.getPointAtLength(0);\n var dstart = el.getPointAtLength(0.1);\n\n startRot = Math.atan2(start0.y - dstart.y, start0.x - dstart.x);\n start = el.getPointAtLength(Math.min(startBackOff, pathlen));\n\n dashArray = '0px,' + startBackOff + 'px,';\n\n var end0 = el.getPointAtLength(pathlen);\n var dend = el.getPointAtLength(pathlen - 0.1);\n\n endRot = Math.atan2(end0.y - dend.y, end0.x - dend.x);\n end = el.getPointAtLength(Math.max(0, pathlen - backOff));\n\n var shortening = dashArray ? startBackOff + backOff : backOff;\n dashArray += (pathlen - shortening) + 'px,' + pathlen + 'px';\n\n el3.style('stroke-dasharray', dashArray);\n }\n\n function hideLine() { el3.style('stroke-dasharray', '0px,100px'); }\n\n function drawhead(arrowHeadStyle, p, rot, arrowScale) {\n if(!arrowHeadStyle.path) return;\n if(arrowHeadStyle.noRotate) rot = 0;\n\n d3.select(el.parentNode).append('path')\n .attr({\n class: el3.attr('class'),\n d: arrowHeadStyle.path,\n transform:\n strTranslate(p.x, p.y) +\n strRotate(rot * 180 / Math.PI) +\n strScale(arrowScale)\n })\n .style({\n fill: Color.rgb(options.arrowcolor),\n 'stroke-width': 0\n });\n }\n\n if(doStart) drawhead(startHeadStyle, start, startRot, startScale);\n if(doEnd) drawhead(headStyle, end, endRot, scale);\n};\n","'use strict';\n\nvar drawModule = require('./draw');\nvar clickModule = require('./click');\n\nmodule.exports = {\n moduleType: 'component',\n name: 'annotations',\n\n layoutAttributes: require('./attributes'),\n supplyLayoutDefaults: require('./defaults'),\n includeBasePlot: require('../../plots/cartesian/include_components')('annotations'),\n\n calcAutorange: require('./calc_autorange'),\n draw: drawModule.draw,\n drawOne: drawModule.drawOne,\n drawRaw: drawModule.drawRaw,\n\n hasClickToShow: clickModule.hasClickToShow,\n onClick: clickModule.onClick,\n\n convertCoords: require('./convert_coords')\n};\n","'use strict';\n\nvar annAttrs = require('../annotations/attributes');\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\n\nmodule.exports = overrideAll(templatedArray('annotation', {\n visible: annAttrs.visible,\n x: {\n valType: 'any',\n description: [\n 'Sets the annotation\\'s x position.'\n ].join(' ')\n },\n y: {\n valType: 'any',\n description: [\n 'Sets the annotation\\'s y position.'\n ].join(' ')\n },\n z: {\n valType: 'any',\n description: [\n 'Sets the annotation\\'s z position.'\n ].join(' ')\n },\n ax: {\n valType: 'number',\n description: [\n 'Sets the x component of the arrow tail about the arrow head (in pixels).'\n ].join(' ')\n },\n ay: {\n valType: 'number',\n description: [\n 'Sets the y component of the arrow tail about the arrow head (in pixels).'\n ].join(' ')\n },\n\n xanchor: annAttrs.xanchor,\n xshift: annAttrs.xshift,\n yanchor: annAttrs.yanchor,\n yshift: annAttrs.yshift,\n\n text: annAttrs.text,\n textangle: annAttrs.textangle,\n font: annAttrs.font,\n width: annAttrs.width,\n height: annAttrs.height,\n opacity: annAttrs.opacity,\n align: annAttrs.align,\n valign: annAttrs.valign,\n bgcolor: annAttrs.bgcolor,\n bordercolor: annAttrs.bordercolor,\n borderpad: annAttrs.borderpad,\n borderwidth: annAttrs.borderwidth,\n showarrow: annAttrs.showarrow,\n arrowcolor: annAttrs.arrowcolor,\n arrowhead: annAttrs.arrowhead,\n startarrowhead: annAttrs.startarrowhead,\n arrowside: annAttrs.arrowside,\n arrowsize: annAttrs.arrowsize,\n startarrowsize: annAttrs.startarrowsize,\n arrowwidth: annAttrs.arrowwidth,\n standoff: annAttrs.standoff,\n startstandoff: annAttrs.startstandoff,\n hovertext: annAttrs.hovertext,\n hoverlabel: annAttrs.hoverlabel,\n captureevents: annAttrs.captureevents,\n\n // maybes later?\n // clicktoshow: annAttrs.clicktoshow,\n // xclick: annAttrs.xclick,\n // yclick: annAttrs.yclick,\n\n // not needed!\n // axref: 'pixel'\n // ayref: 'pixel'\n // xref: 'x'\n // yref: 'y\n // zref: 'z'\n}), 'calc', 'from-root');\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\n\nmodule.exports = function convert(scene) {\n var fullSceneLayout = scene.fullSceneLayout;\n var anns = fullSceneLayout.annotations;\n\n for(var i = 0; i < anns.length; i++) {\n mockAnnAxes(anns[i], scene);\n }\n\n scene.fullLayout._infolayer\n .selectAll('.annotation-' + scene.id)\n .remove();\n};\n\nfunction mockAnnAxes(ann, scene) {\n var fullSceneLayout = scene.fullSceneLayout;\n var domain = fullSceneLayout.domain;\n var size = scene.fullLayout._size;\n\n var base = {\n // this gets fill in on render\n pdata: null,\n\n // to get setConvert to not execute cleanly\n type: 'linear',\n\n // don't try to update them on `editable: true`\n autorange: false,\n\n // set infinite range so that annotation draw routine\n // does not try to remove 'outside-range' annotations,\n // this case is handled in the render loop\n range: [-Infinity, Infinity]\n };\n\n ann._xa = {};\n Lib.extendFlat(ann._xa, base);\n Axes.setConvert(ann._xa);\n ann._xa._offset = size.l + domain.x[0] * size.w;\n ann._xa.l2p = function() {\n return 0.5 * (1 + ann._pdata[0] / ann._pdata[3]) * size.w * (domain.x[1] - domain.x[0]);\n };\n\n ann._ya = {};\n Lib.extendFlat(ann._ya, base);\n Axes.setConvert(ann._ya);\n ann._ya._offset = size.t + (1 - domain.y[1]) * size.h;\n ann._ya.l2p = function() {\n return 0.5 * (1 - ann._pdata[1] / ann._pdata[3]) * size.h * (domain.y[1] - domain.y[0]);\n };\n}\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\nvar handleAnnotationCommonDefaults = require('../annotations/common_defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function handleDefaults(sceneLayoutIn, sceneLayoutOut, opts) {\n handleArrayContainerDefaults(sceneLayoutIn, sceneLayoutOut, {\n name: 'annotations',\n handleItemDefaults: handleAnnotationDefaults,\n fullLayout: opts.fullLayout\n });\n};\n\nfunction handleAnnotationDefaults(annIn, annOut, sceneLayout, opts) {\n function coerce(attr, dflt) {\n return Lib.coerce(annIn, annOut, attributes, attr, dflt);\n }\n\n function coercePosition(axLetter) {\n var axName = axLetter + 'axis';\n\n // mock in such way that getFromId grabs correct 3D axis\n var gdMock = { _fullLayout: {} };\n gdMock._fullLayout[axName] = sceneLayout[axName];\n\n return Axes.coercePosition(annOut, gdMock, coerce, axLetter, axLetter, 0.5);\n }\n\n\n var visible = coerce('visible');\n if(!visible) return;\n\n handleAnnotationCommonDefaults(annIn, annOut, opts.fullLayout, coerce);\n\n coercePosition('x');\n coercePosition('y');\n coercePosition('z');\n\n // if you have one coordinate you should all three\n Lib.noneOrAll(annIn, annOut, ['x', 'y', 'z']);\n\n // hard-set here for completeness\n annOut.xref = 'x';\n annOut.yref = 'y';\n annOut.zref = 'z';\n\n coerce('xanchor');\n coerce('yanchor');\n coerce('xshift');\n coerce('yshift');\n\n if(annOut.showarrow) {\n annOut.axref = 'pixel';\n annOut.ayref = 'pixel';\n\n // TODO maybe default values should be bigger than the 2D case?\n coerce('ax', -10);\n coerce('ay', -30);\n\n // if you have one part of arrow length you should have both\n Lib.noneOrAll(annIn, annOut, ['ax', 'ay']);\n }\n}\n","'use strict';\n\nvar drawRaw = require('../annotations/draw').drawRaw;\nvar project = require('../../plots/gl3d/project');\nvar axLetters = ['x', 'y', 'z'];\n\nmodule.exports = function draw(scene) {\n var fullSceneLayout = scene.fullSceneLayout;\n var dataScale = scene.dataScale;\n var anns = fullSceneLayout.annotations;\n\n for(var i = 0; i < anns.length; i++) {\n var ann = anns[i];\n var annotationIsOffscreen = false;\n\n for(var j = 0; j < 3; j++) {\n var axLetter = axLetters[j];\n var pos = ann[axLetter];\n var ax = fullSceneLayout[axLetter + 'axis'];\n var posFraction = ax.r2fraction(pos);\n\n if(posFraction < 0 || posFraction > 1) {\n annotationIsOffscreen = true;\n break;\n }\n }\n\n if(annotationIsOffscreen) {\n scene.fullLayout._infolayer\n .select('.annotation-' + scene.id + '[data-index=\"' + i + '\"]')\n .remove();\n } else {\n ann._pdata = project(scene.glplot.cameraParams, [\n fullSceneLayout.xaxis.r2l(ann.x) * dataScale[0],\n fullSceneLayout.yaxis.r2l(ann.y) * dataScale[1],\n fullSceneLayout.zaxis.r2l(ann.z) * dataScale[2]\n ]);\n\n drawRaw(scene.graphDiv, ann, i, scene.id, ann._xa, ann._ya);\n }\n }\n};\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\n\nmodule.exports = {\n moduleType: 'component',\n name: 'annotations3d',\n\n schema: {\n subplots: {\n scene: {annotations: require('./attributes')}\n }\n },\n\n layoutAttributes: require('./attributes'),\n handleDefaults: require('./defaults'),\n includeBasePlot: includeGL3D,\n\n convert: require('./convert'),\n draw: require('./draw')\n};\n\nfunction includeGL3D(layoutIn, layoutOut) {\n var GL3D = Registry.subplotsRegistry.gl3d;\n if(!GL3D) return;\n\n var attrRegex = GL3D.attrRegex;\n\n var keys = Object.keys(layoutIn);\n for(var i = 0; i < keys.length; i++) {\n var k = keys[i];\n if(attrRegex.test(k) && (layoutIn[k].annotations || []).length) {\n Lib.pushUnique(layoutOut._basePlotModules, GL3D);\n Lib.pushUnique(layoutOut._subplots.gl3d, k);\n }\n }\n}\n","'use strict';\n\n// a trimmed down version of:\n// https://github.com/alexcjohnson/world-calendars/blob/master/dist/index.js\n\nmodule.exports = require('world-calendars/dist/main');\n\nrequire('world-calendars/dist/plus');\n\nrequire('world-calendars/dist/calendars/chinese');\nrequire('world-calendars/dist/calendars/coptic');\nrequire('world-calendars/dist/calendars/discworld');\nrequire('world-calendars/dist/calendars/ethiopian');\nrequire('world-calendars/dist/calendars/hebrew');\nrequire('world-calendars/dist/calendars/islamic');\nrequire('world-calendars/dist/calendars/julian');\nrequire('world-calendars/dist/calendars/mayan');\nrequire('world-calendars/dist/calendars/nanakshahi');\nrequire('world-calendars/dist/calendars/nepali');\nrequire('world-calendars/dist/calendars/persian');\nrequire('world-calendars/dist/calendars/taiwan');\nrequire('world-calendars/dist/calendars/thai');\nrequire('world-calendars/dist/calendars/ummalqura');\n","'use strict';\n\nvar calendars = require('./calendars');\n\nvar Lib = require('../../lib');\nvar constants = require('../../constants/numerical');\n\nvar EPOCHJD = constants.EPOCHJD;\nvar ONEDAY = constants.ONEDAY;\n\nvar attributes = {\n valType: 'enumerated',\n values: Lib.sortObjectKeys(calendars.calendars),\n editType: 'calc',\n dflt: 'gregorian'\n};\n\nvar handleDefaults = function(contIn, contOut, attr, dflt) {\n var attrs = {};\n attrs[attr] = attributes;\n\n return Lib.coerce(contIn, contOut, attrs, attr, dflt);\n};\n\nvar handleTraceDefaults = function(traceIn, traceOut, coords, layout) {\n for(var i = 0; i < coords.length; i++) {\n handleDefaults(traceIn, traceOut, coords[i] + 'calendar', layout.calendar);\n }\n};\n\n// each calendar needs its own default canonical tick. I would love to use\n// 2000-01-01 (or even 0000-01-01) for them all but they don't necessarily\n// all support either of those dates. Instead I'll use the most significant\n// number they *do* support, biased toward the present day.\nvar CANONICAL_TICK = {\n chinese: '2000-01-01',\n coptic: '2000-01-01',\n discworld: '2000-01-01',\n ethiopian: '2000-01-01',\n hebrew: '5000-01-01',\n islamic: '1000-01-01',\n julian: '2000-01-01',\n mayan: '5000-01-01',\n nanakshahi: '1000-01-01',\n nepali: '2000-01-01',\n persian: '1000-01-01',\n jalali: '1000-01-01',\n taiwan: '1000-01-01',\n thai: '2000-01-01',\n ummalqura: '1400-01-01'\n};\n\n// Start on a Sunday - for week ticks\n// Discworld and Mayan calendars don't have 7-day weeks but we're going to give them\n// 7-day week ticks so start on our Sundays.\n// If anyone really cares we can customize the auto tick spacings for these calendars.\nvar CANONICAL_SUNDAY = {\n chinese: '2000-01-02',\n coptic: '2000-01-03',\n discworld: '2000-01-03',\n ethiopian: '2000-01-05',\n hebrew: '5000-01-01',\n islamic: '1000-01-02',\n julian: '2000-01-03',\n mayan: '5000-01-01',\n nanakshahi: '1000-01-05',\n nepali: '2000-01-05',\n persian: '1000-01-01',\n jalali: '1000-01-01',\n taiwan: '1000-01-04',\n thai: '2000-01-04',\n ummalqura: '1400-01-06'\n};\n\nvar DFLTRANGE = {\n chinese: ['2000-01-01', '2001-01-01'],\n coptic: ['1700-01-01', '1701-01-01'],\n discworld: ['1800-01-01', '1801-01-01'],\n ethiopian: ['2000-01-01', '2001-01-01'],\n hebrew: ['5700-01-01', '5701-01-01'],\n islamic: ['1400-01-01', '1401-01-01'],\n julian: ['2000-01-01', '2001-01-01'],\n mayan: ['5200-01-01', '5201-01-01'],\n nanakshahi: ['0500-01-01', '0501-01-01'],\n nepali: ['2000-01-01', '2001-01-01'],\n persian: ['1400-01-01', '1401-01-01'],\n jalali: ['1400-01-01', '1401-01-01'],\n taiwan: ['0100-01-01', '0101-01-01'],\n thai: ['2500-01-01', '2501-01-01'],\n ummalqura: ['1400-01-01', '1401-01-01']\n};\n\n/*\n * convert d3 templates to world-calendars templates, so our users only need\n * to know d3's specifiers. Map space padding to no padding, and unknown fields\n * to an ugly placeholder\n */\nvar UNKNOWN = '##';\nvar d3ToWorldCalendars = {\n d: {0: 'dd', '-': 'd'}, // 2-digit or unpadded day of month\n e: {0: 'd', '-': 'd'}, // alternate, always unpadded day of month\n a: {0: 'D', '-': 'D'}, // short weekday name\n A: {0: 'DD', '-': 'DD'}, // full weekday name\n j: {0: 'oo', '-': 'o'}, // 3-digit or unpadded day of the year\n W: {0: 'ww', '-': 'w'}, // 2-digit or unpadded week of the year (Monday first)\n m: {0: 'mm', '-': 'm'}, // 2-digit or unpadded month number\n b: {0: 'M', '-': 'M'}, // short month name\n B: {0: 'MM', '-': 'MM'}, // full month name\n y: {0: 'yy', '-': 'yy'}, // 2-digit year (map unpadded to zero-padded)\n Y: {0: 'yyyy', '-': 'yyyy'}, // 4-digit year (map unpadded to zero-padded)\n U: UNKNOWN, // Sunday-first week of the year\n w: UNKNOWN, // day of the week [0(sunday),6]\n // combined format, we replace the date part with the world-calendar version\n // and the %X stays there for d3 to handle with time parts\n c: {0: 'D M d %X yyyy', '-': 'D M d %X yyyy'},\n x: {0: 'mm/dd/yyyy', '-': 'mm/dd/yyyy'}\n};\n\nfunction worldCalFmt(fmt, x, calendar) {\n var dateJD = Math.floor((x + 0.05) / ONEDAY) + EPOCHJD;\n var cDate = getCal(calendar).fromJD(dateJD);\n var i = 0;\n var modifier, directive, directiveLen, directiveObj, replacementPart;\n\n while((i = fmt.indexOf('%', i)) !== -1) {\n modifier = fmt.charAt(i + 1);\n if(modifier === '0' || modifier === '-' || modifier === '_') {\n directiveLen = 3;\n directive = fmt.charAt(i + 2);\n if(modifier === '_') modifier = '-';\n } else {\n directive = modifier;\n modifier = '0';\n directiveLen = 2;\n }\n directiveObj = d3ToWorldCalendars[directive];\n if(!directiveObj) {\n i += directiveLen;\n } else {\n // code is recognized as a date part but world-calendars doesn't support it\n if(directiveObj === UNKNOWN) replacementPart = UNKNOWN;\n\n // format the cDate according to the translated directive\n else replacementPart = cDate.formatDate(directiveObj[modifier]);\n\n fmt = fmt.substr(0, i) + replacementPart + fmt.substr(i + directiveLen);\n i += replacementPart.length;\n }\n }\n return fmt;\n}\n\n// cache world calendars, so we don't have to reinstantiate\n// during each date-time conversion\nvar allCals = {};\nfunction getCal(calendar) {\n var calendarObj = allCals[calendar];\n if(calendarObj) return calendarObj;\n\n calendarObj = allCals[calendar] = calendars.instance(calendar);\n return calendarObj;\n}\n\nfunction makeAttrs(description) {\n return Lib.extendFlat({}, attributes, { description: description });\n}\n\nfunction makeTraceAttrsDescription(coord) {\n return 'Sets the calendar system to use with `' + coord + '` date data.';\n}\n\nvar xAttrs = {\n xcalendar: makeAttrs(makeTraceAttrsDescription('x'))\n};\n\nvar xyAttrs = Lib.extendFlat({}, xAttrs, {\n ycalendar: makeAttrs(makeTraceAttrsDescription('y'))\n});\n\nvar xyzAttrs = Lib.extendFlat({}, xyAttrs, {\n zcalendar: makeAttrs(makeTraceAttrsDescription('z'))\n});\n\nvar axisAttrs = makeAttrs([\n 'Sets the calendar system to use for `range` and `tick0`',\n 'if this is a date axis. This does not set the calendar for',\n 'interpreting data on this axis, that\\'s specified in the trace',\n 'or via the global `layout.calendar`'\n].join(' '));\n\nmodule.exports = {\n moduleType: 'component',\n name: 'calendars',\n\n schema: {\n traces: {\n scatter: xyAttrs,\n bar: xyAttrs,\n box: xyAttrs,\n heatmap: xyAttrs,\n contour: xyAttrs,\n histogram: xyAttrs,\n histogram2d: xyAttrs,\n histogram2dcontour: xyAttrs,\n scatter3d: xyzAttrs,\n surface: xyzAttrs,\n mesh3d: xyzAttrs,\n scattergl: xyAttrs,\n ohlc: xAttrs,\n candlestick: xAttrs\n },\n layout: {\n calendar: makeAttrs([\n 'Sets the default calendar system to use for interpreting and',\n 'displaying dates throughout the plot.'\n ].join(' '))\n },\n subplots: {\n xaxis: {calendar: axisAttrs},\n yaxis: {calendar: axisAttrs},\n scene: {\n xaxis: {calendar: axisAttrs},\n // TODO: it's actually redundant to include yaxis and zaxis here\n // because in the scene attributes these are the same object so merging\n // into one merges into them all. However, I left them in for parity with\n // cartesian, where yaxis is unused until we Plotschema.get() when we\n // use its presence or absence to determine whether to delete attributes\n // from yaxis if they only apply to x (rangeselector/rangeslider)\n yaxis: {calendar: axisAttrs},\n zaxis: {calendar: axisAttrs}\n },\n polar: {\n radialaxis: {calendar: axisAttrs}\n }\n },\n transforms: {\n filter: {\n valuecalendar: makeAttrs([\n 'WARNING: All transforms are deprecated and may be removed from the API in next major version.',\n 'Sets the calendar system to use for `value`, if it is a date.'\n ].join(' ')),\n targetcalendar: makeAttrs([\n 'WARNING: All transforms are deprecated and may be removed from the API in next major version.',\n 'Sets the calendar system to use for `target`, if it is an',\n 'array of dates. If `target` is a string (eg *x*) we use the',\n 'corresponding trace attribute (eg `xcalendar`) if it exists,',\n 'even if `targetcalendar` is provided.'\n ].join(' '))\n }\n }\n },\n\n layoutAttributes: attributes,\n\n handleDefaults: handleDefaults,\n handleTraceDefaults: handleTraceDefaults,\n\n CANONICAL_SUNDAY: CANONICAL_SUNDAY,\n CANONICAL_TICK: CANONICAL_TICK,\n DFLTRANGE: DFLTRANGE,\n\n getCal: getCal,\n worldCalFmt: worldCalFmt\n};\n","'use strict';\n\n\n// IMPORTANT - default colors should be in hex for compatibility\nexports.defaults = [\n '#1f77b4', // muted blue\n '#ff7f0e', // safety orange\n '#2ca02c', // cooked asparagus green\n '#d62728', // brick red\n '#9467bd', // muted purple\n '#8c564b', // chestnut brown\n '#e377c2', // raspberry yogurt pink\n '#7f7f7f', // middle gray\n '#bcbd22', // curry yellow-green\n '#17becf' // blue-teal\n];\n\nexports.defaultLine = '#444';\n\nexports.lightLine = '#eee';\n\nexports.background = '#fff';\n\nexports.borderLine = '#BEC8D9';\n\n// with axis.color and Color.interp we aren't using lightLine\n// itself anymore, instead interpolating between axis.color\n// and the background color using tinycolor.mix. lightFraction\n// gives back exactly lightLine if the other colors are defaults.\nexports.lightFraction = 100 * (0xe - 0x4) / (0xf - 0x4);\n","'use strict';\n\nvar tinycolor = require('tinycolor2');\nvar isNumeric = require('fast-isnumeric');\nvar isTypedArray = require('../../lib/array').isTypedArray;\n\nvar color = module.exports = {};\n\nvar colorAttrs = require('./attributes');\ncolor.defaults = colorAttrs.defaults;\nvar defaultLine = color.defaultLine = colorAttrs.defaultLine;\ncolor.lightLine = colorAttrs.lightLine;\nvar background = color.background = colorAttrs.background;\n\n/*\n * tinyRGB: turn a tinycolor into an rgb string, but\n * unlike the built-in tinycolor.toRgbString this never includes alpha\n */\ncolor.tinyRGB = function(tc) {\n var c = tc.toRgb();\n return 'rgb(' + Math.round(c.r) + ', ' +\n Math.round(c.g) + ', ' + Math.round(c.b) + ')';\n};\n\ncolor.rgb = function(cstr) { return color.tinyRGB(tinycolor(cstr)); };\n\ncolor.opacity = function(cstr) { return cstr ? tinycolor(cstr).getAlpha() : 0; };\n\ncolor.addOpacity = function(cstr, op) {\n var c = tinycolor(cstr).toRgb();\n return 'rgba(' + Math.round(c.r) + ', ' +\n Math.round(c.g) + ', ' + Math.round(c.b) + ', ' + op + ')';\n};\n\n// combine two colors into one apparent color\n// if back has transparency or is missing,\n// color.background is assumed behind it\ncolor.combine = function(front, back) {\n var fc = tinycolor(front).toRgb();\n if(fc.a === 1) return tinycolor(front).toRgbString();\n\n var bc = tinycolor(back || background).toRgb();\n var bcflat = bc.a === 1 ? bc : {\n r: 255 * (1 - bc.a) + bc.r * bc.a,\n g: 255 * (1 - bc.a) + bc.g * bc.a,\n b: 255 * (1 - bc.a) + bc.b * bc.a\n };\n var fcflat = {\n r: bcflat.r * (1 - fc.a) + fc.r * fc.a,\n g: bcflat.g * (1 - fc.a) + fc.g * fc.a,\n b: bcflat.b * (1 - fc.a) + fc.b * fc.a\n };\n return tinycolor(fcflat).toRgbString();\n};\n\n/*\n * Linearly interpolate between two colors at a normalized interpolation position (0 to 1).\n *\n * Ignores alpha channel values.\n * The resulting color is computed as: factor * first + (1 - factor) * second.\n */\ncolor.interpolate = function(first, second, factor) {\n var fc = tinycolor(first).toRgb();\n var sc = tinycolor(second).toRgb();\n\n var ic = {\n r: factor * fc.r + (1 - factor) * sc.r,\n g: factor * fc.g + (1 - factor) * sc.g,\n b: factor * fc.b + (1 - factor) * sc.b,\n };\n\n return tinycolor(ic).toRgbString();\n};\n\n/*\n * Create a color that contrasts with cstr.\n *\n * If cstr is a dark color, we lighten it; if it's light, we darken.\n *\n * If lightAmount / darkAmount are used, we adjust by these percentages,\n * otherwise we go all the way to white or black.\n */\ncolor.contrast = function(cstr, lightAmount, darkAmount) {\n var tc = tinycolor(cstr);\n\n if(tc.getAlpha() !== 1) tc = tinycolor(color.combine(cstr, background));\n\n var newColor = tc.isDark() ?\n (lightAmount ? tc.lighten(lightAmount) : background) :\n (darkAmount ? tc.darken(darkAmount) : defaultLine);\n\n return newColor.toString();\n};\n\ncolor.stroke = function(s, c) {\n var tc = tinycolor(c);\n s.style({stroke: color.tinyRGB(tc), 'stroke-opacity': tc.getAlpha()});\n};\n\ncolor.fill = function(s, c) {\n var tc = tinycolor(c);\n s.style({\n fill: color.tinyRGB(tc),\n 'fill-opacity': tc.getAlpha()\n });\n};\n\n// search container for colors with the deprecated rgb(fractions) format\n// and convert them to rgb(0-255 values)\ncolor.clean = function(container) {\n if(!container || typeof container !== 'object') return;\n\n var keys = Object.keys(container);\n var i, j, key, val;\n\n for(i = 0; i < keys.length; i++) {\n key = keys[i];\n val = container[key];\n\n if(key.substr(key.length - 5) === 'color') {\n // only sanitize keys that end in \"color\" or \"colorscale\"\n\n if(Array.isArray(val)) {\n for(j = 0; j < val.length; j++) val[j] = cleanOne(val[j]);\n } else container[key] = cleanOne(val);\n } else if(key.substr(key.length - 10) === 'colorscale' && Array.isArray(val)) {\n // colorscales have the format [[0, color1], [frac, color2], ... [1, colorN]]\n\n for(j = 0; j < val.length; j++) {\n if(Array.isArray(val[j])) val[j][1] = cleanOne(val[j][1]);\n }\n } else if(Array.isArray(val)) {\n // recurse into arrays of objects, and plain objects\n\n var el0 = val[0];\n if(!Array.isArray(el0) && el0 && typeof el0 === 'object') {\n for(j = 0; j < val.length; j++) color.clean(val[j]);\n }\n } else if(val && typeof val === 'object' && !isTypedArray(val)) color.clean(val);\n }\n};\n\nfunction cleanOne(val) {\n if(isNumeric(val) || typeof val !== 'string') return val;\n\n var valTrim = val.trim();\n if(valTrim.substr(0, 3) !== 'rgb') return val;\n\n var match = valTrim.match(/^rgba?\\s*\\(([^()]*)\\)$/);\n if(!match) return val;\n\n var parts = match[1].trim().split(/\\s*[\\s,]\\s*/);\n var rgba = valTrim.charAt(3) === 'a' && parts.length === 4;\n if(!rgba && parts.length !== 3) return val;\n\n for(var i = 0; i < parts.length; i++) {\n if(!parts[i].length) return val;\n parts[i] = Number(parts[i]);\n\n if(!(parts[i] >= 0)) {\n // all parts must be non-negative numbers\n\n return val;\n }\n\n if(i === 3) {\n // alpha>1 gets clipped to 1\n\n if(parts[i] > 1) parts[i] = 1;\n } else if(parts[i] >= 1) {\n // r, g, b must be < 1 (ie 1 itself is not allowed)\n\n return val;\n }\n }\n\n var rgbStr = Math.round(parts[0] * 255) + ', ' +\n Math.round(parts[1] * 255) + ', ' +\n Math.round(parts[2] * 255);\n\n if(rgba) return 'rgba(' + rgbStr + ', ' + parts[3] + ')';\n return 'rgb(' + rgbStr + ')';\n}\n","'use strict';\n\nvar axesAttrs = require('../../plots/cartesian/layout_attributes');\nvar fontAttrs = require('../../plots/font_attributes');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\n\n\nmodule.exports = overrideAll({\n orientation: {\n valType: 'enumerated',\n values: ['h', 'v'],\n dflt: 'v',\n description: 'Sets the orientation of the colorbar.'\n },\n thicknessmode: {\n valType: 'enumerated',\n values: ['fraction', 'pixels'],\n dflt: 'pixels',\n description: [\n 'Determines whether this color bar\\'s thickness',\n '(i.e. the measure in the constant color direction)',\n 'is set in units of plot *fraction* or in *pixels*.',\n 'Use `thickness` to set the value.'\n ].join(' ')\n },\n thickness: {\n valType: 'number',\n min: 0,\n dflt: 30,\n description: [\n 'Sets the thickness of the color bar',\n 'This measure excludes the size of the padding, ticks and labels.'\n ].join(' ')\n },\n lenmode: {\n valType: 'enumerated',\n values: ['fraction', 'pixels'],\n dflt: 'fraction',\n description: [\n 'Determines whether this color bar\\'s length',\n '(i.e. the measure in the color variation direction)',\n 'is set in units of plot *fraction* or in *pixels.',\n 'Use `len` to set the value.'\n ].join(' ')\n },\n len: {\n valType: 'number',\n min: 0,\n dflt: 1,\n description: [\n 'Sets the length of the color bar',\n 'This measure excludes the padding of both ends.',\n 'That is, the color bar length is this length minus the',\n 'padding on both ends.'\n ].join(' ')\n },\n x: {\n valType: 'number',\n description: [\n 'Sets the x position with respect to `xref` of the color bar (in plot fraction).',\n 'When `xref` is *paper*, defaults to 1.02 when `orientation` is *v* and',\n '0.5 when `orientation` is *h*.',\n 'When `xref` is *container*, defaults to *1* when `orientation` is *v* and',\n '0.5 when `orientation` is *h*.',\n 'Must be between *0* and *1* if `xref` is *container*',\n 'and between *-2* and *3* if `xref` is *paper*.'\n ].join(' ')\n },\n xref: {\n valType: 'enumerated',\n dflt: 'paper',\n values: ['container', 'paper'],\n editType: 'layoutstyle',\n description: [\n 'Sets the container `x` refers to.',\n '*container* spans the entire `width` of the plot.',\n '*paper* refers to the width of the plotting area only.'\n ].join(' ')\n },\n xanchor: {\n valType: 'enumerated',\n values: ['left', 'center', 'right'],\n description: [\n 'Sets this color bar\\'s horizontal position anchor.',\n 'This anchor binds the `x` position to the *left*, *center*',\n 'or *right* of the color bar.',\n 'Defaults to *left* when `orientation` is *v* and',\n '*center* when `orientation` is *h*.'\n ].join(' ')\n },\n xpad: {\n valType: 'number',\n min: 0,\n dflt: 10,\n description: 'Sets the amount of padding (in px) along the x direction.'\n },\n y: {\n valType: 'number',\n description: [\n 'Sets the y position with respect to `yref` of the color bar (in plot fraction).',\n 'When `yref` is *paper*, defaults to 0.5 when `orientation` is *v* and',\n '1.02 when `orientation` is *h*.',\n 'When `yref` is *container*, defaults to 0.5 when `orientation` is *v* and',\n '1 when `orientation` is *h*.',\n 'Must be between *0* and *1* if `yref` is *container*',\n 'and between *-2* and *3* if `yref` is *paper*.'\n ].join(' ')\n },\n yref: {\n valType: 'enumerated',\n dflt: 'paper',\n values: ['container', 'paper'],\n editType: 'layoutstyle',\n description: [\n 'Sets the container `y` refers to.',\n '*container* spans the entire `height` of the plot.',\n '*paper* refers to the height of the plotting area only.'\n ].join(' '),\n },\n yanchor: {\n valType: 'enumerated',\n values: ['top', 'middle', 'bottom'],\n description: [\n 'Sets this color bar\\'s vertical position anchor',\n 'This anchor binds the `y` position to the *top*, *middle*',\n 'or *bottom* of the color bar.',\n 'Defaults to *middle* when `orientation` is *v* and',\n '*bottom* when `orientation` is *h*.'\n ].join(' ')\n },\n ypad: {\n valType: 'number',\n min: 0,\n dflt: 10,\n description: 'Sets the amount of padding (in px) along the y direction.'\n },\n // a possible line around the bar itself\n outlinecolor: axesAttrs.linecolor,\n outlinewidth: axesAttrs.linewidth,\n // Should outlinewidth have {dflt: 0} ?\n // another possible line outside the padding and tick labels\n bordercolor: axesAttrs.linecolor,\n borderwidth: {\n valType: 'number',\n min: 0,\n dflt: 0,\n description: [\n 'Sets the width (in px) or the border enclosing this color bar.'\n ].join(' ')\n },\n bgcolor: {\n valType: 'color',\n dflt: 'rgba(0,0,0,0)',\n description: 'Sets the color of padded area.'\n },\n // tick and title properties named and function exactly as in axes\n tickmode: axesAttrs.minor.tickmode,\n nticks: axesAttrs.nticks,\n tick0: axesAttrs.tick0,\n dtick: axesAttrs.dtick,\n tickvals: axesAttrs.tickvals,\n ticktext: axesAttrs.ticktext,\n ticks: extendFlat({}, axesAttrs.ticks, {dflt: ''}),\n ticklabeloverflow: extendFlat({}, axesAttrs.ticklabeloverflow, {\n description: [\n 'Determines how we handle tick labels that would overflow either the graph div or the domain of the axis.',\n 'The default value for inside tick labels is *hide past domain*.',\n 'In other cases the default is *hide past div*.'\n ].join(' ')\n }),\n\n // ticklabelposition: not used directly, as values depend on orientation\n // left/right options are for x axes, and top/bottom options are for y axes\n ticklabelposition: {\n valType: 'enumerated',\n values: [\n 'outside', 'inside',\n 'outside top', 'inside top',\n 'outside left', 'inside left',\n 'outside right', 'inside right',\n 'outside bottom', 'inside bottom'\n ],\n dflt: 'outside',\n description: [\n 'Determines where tick labels are drawn relative to the ticks.',\n 'Left and right options are used when `orientation` is *h*,',\n 'top and bottom when `orientation` is *v*.'\n ].join(' ')\n },\n\n ticklen: axesAttrs.ticklen,\n tickwidth: axesAttrs.tickwidth,\n tickcolor: axesAttrs.tickcolor,\n ticklabelstep: axesAttrs.ticklabelstep,\n showticklabels: axesAttrs.showticklabels,\n labelalias: axesAttrs.labelalias,\n tickfont: fontAttrs({\n description: 'Sets the color bar\\'s tick label font'\n }),\n tickangle: axesAttrs.tickangle,\n tickformat: axesAttrs.tickformat,\n tickformatstops: axesAttrs.tickformatstops,\n tickprefix: axesAttrs.tickprefix,\n showtickprefix: axesAttrs.showtickprefix,\n ticksuffix: axesAttrs.ticksuffix,\n showticksuffix: axesAttrs.showticksuffix,\n separatethousands: axesAttrs.separatethousands,\n exponentformat: axesAttrs.exponentformat,\n minexponent: axesAttrs.minexponent,\n showexponent: axesAttrs.showexponent,\n title: {\n text: {\n valType: 'string',\n description: [\n 'Sets the title of the color bar.',\n 'Note that before the existence of `title.text`, the title\\'s',\n 'contents used to be defined as the `title` attribute itself.',\n 'This behavior has been deprecated.'\n ].join(' ')\n },\n font: fontAttrs({\n description: [\n 'Sets this color bar\\'s title font.',\n 'Note that the title\\'s font used to be set',\n 'by the now deprecated `titlefont` attribute.'\n ].join(' ')\n }),\n side: {\n valType: 'enumerated',\n values: ['right', 'top', 'bottom'],\n description: [\n 'Determines the location of color bar\\'s title',\n 'with respect to the color bar.',\n 'Defaults to *top* when `orientation` if *v* and ',\n 'defaults to *right* when `orientation` if *h*.',\n 'Note that the title\\'s location used to be set',\n 'by the now deprecated `titleside` attribute.'\n ].join(' ')\n }\n },\n\n _deprecated: {\n title: {\n valType: 'string',\n description: [\n 'Deprecated in favor of color bar\\'s `title.text`.',\n 'Note that value of color bar\\'s `title` is no longer a simple',\n '*string* but a set of sub-attributes.'\n ].join(' ')\n },\n titlefont: fontAttrs({\n description: 'Deprecated in favor of color bar\\'s `title.font`.'\n }),\n titleside: {\n valType: 'enumerated',\n values: ['right', 'top', 'bottom'],\n dflt: 'top',\n description: 'Deprecated in favor of color bar\\'s `title.side`.'\n }\n }\n}, 'colorbars', 'from-root');\n","'use strict';\n\nmodule.exports = {\n cn: {\n colorbar: 'colorbar',\n cbbg: 'cbbg',\n cbfill: 'cbfill',\n cbfills: 'cbfills',\n cbline: 'cbline',\n cblines: 'cblines',\n cbaxis: 'cbaxis',\n cbtitleunshift: 'cbtitleunshift',\n cbtitle: 'cbtitle',\n cboutline: 'cboutline',\n crisp: 'crisp',\n jsPlaceholder: 'js-placeholder'\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Template = require('../../plot_api/plot_template');\n\nvar handleTickValueDefaults = require('../../plots/cartesian/tick_value_defaults');\nvar handleTickMarkDefaults = require('../../plots/cartesian/tick_mark_defaults');\nvar handleTickLabelDefaults = require('../../plots/cartesian/tick_label_defaults');\nvar handlePrefixSuffixDefaults = require('../../plots/cartesian/prefix_suffix_defaults');\n\nvar attributes = require('./attributes');\n\nmodule.exports = function colorbarDefaults(containerIn, containerOut, layout) {\n var colorbarOut = Template.newContainer(containerOut, 'colorbar');\n var colorbarIn = containerIn.colorbar || {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(colorbarIn, colorbarOut, attributes, attr, dflt);\n }\n\n var margin = layout.margin || {t: 0, b: 0, l: 0, r: 0};\n var w = layout.width - margin.l - margin.r;\n var h = layout.height - margin.t - margin.b;\n\n var orientation = coerce('orientation');\n var isVertical = orientation === 'v';\n\n var thicknessmode = coerce('thicknessmode');\n coerce('thickness', (thicknessmode === 'fraction') ?\n 30 / (isVertical ? w : h) :\n 30\n );\n\n var lenmode = coerce('lenmode');\n coerce('len', (lenmode === 'fraction') ?\n 1 :\n isVertical ? h : w\n );\n\n var yref = coerce('yref');\n var xref = coerce('xref');\n\n var isPaperY = yref === 'paper';\n var isPaperX = xref === 'paper';\n\n var defaultX, defaultY, defaultYAnchor;\n var defaultXAnchor = 'left';\n\n if(isVertical) {\n defaultYAnchor = 'middle';\n defaultXAnchor = isPaperX ? 'left' : 'right';\n defaultX = isPaperX ? 1.02 : 1;\n defaultY = 0.5;\n } else {\n defaultYAnchor = isPaperY ? 'bottom' : 'top';\n defaultXAnchor = 'center';\n defaultX = 0.5;\n defaultY = isPaperY ? 1.02 : 1;\n }\n\n Lib.coerce(colorbarIn, colorbarOut, {\n x: {\n valType: 'number',\n min: isPaperX ? -2 : 0,\n max: isPaperX ? 3 : 1,\n dflt: defaultX,\n }\n }, 'x');\n\n Lib.coerce(colorbarIn, colorbarOut, {\n y: {\n valType: 'number',\n min: isPaperY ? -2 : 0,\n max: isPaperY ? 3 : 1,\n dflt: defaultY,\n }\n }, 'y');\n\n coerce('xanchor', defaultXAnchor);\n coerce('xpad');\n coerce('yanchor', defaultYAnchor);\n coerce('ypad');\n Lib.noneOrAll(colorbarIn, colorbarOut, ['x', 'y']);\n\n coerce('outlinecolor');\n coerce('outlinewidth');\n coerce('bordercolor');\n coerce('borderwidth');\n coerce('bgcolor');\n\n var ticklabelposition = Lib.coerce(colorbarIn, colorbarOut, {\n ticklabelposition: {\n valType: 'enumerated',\n dflt: 'outside',\n values: isVertical ? [\n 'outside', 'inside',\n 'outside top', 'inside top',\n 'outside bottom', 'inside bottom'\n ] : [\n 'outside', 'inside',\n 'outside left', 'inside left',\n 'outside right', 'inside right'\n ]\n }\n }, 'ticklabelposition');\n\n coerce('ticklabeloverflow', ticklabelposition.indexOf('inside') !== -1 ? 'hide past domain' : 'hide past div');\n\n handleTickValueDefaults(colorbarIn, colorbarOut, coerce, 'linear');\n\n var font = layout.font;\n var opts = {\n noAutotickangles: true,\n noTicklabelshift: true,\n noTicklabelstandoff: true,\n outerTicks: false,\n font: font\n };\n if(ticklabelposition.indexOf('inside') !== -1) {\n opts.bgColor = 'black'; // could we instead use the average of colors in the scale?\n }\n handlePrefixSuffixDefaults(colorbarIn, colorbarOut, coerce, 'linear', opts);\n handleTickLabelDefaults(colorbarIn, colorbarOut, coerce, 'linear', opts);\n handleTickMarkDefaults(colorbarIn, colorbarOut, coerce, 'linear', opts);\n\n coerce('title.text', layout._dfltTitle.colorbar);\n\n var tickFont = colorbarOut.showticklabels ? colorbarOut.tickfont : font;\n\n var dfltTitleFont = Lib.extendFlat({}, font, {\n family: tickFont.family,\n size: Lib.bigFont(tickFont.size)\n });\n Lib.coerceFont(coerce, 'title.font', dfltTitleFont);\n coerce('title.side', isVertical ? 'top' : 'right');\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar tinycolor = require('tinycolor2');\n\nvar Plots = require('../../plots/plots');\nvar Registry = require('../../registry');\nvar Axes = require('../../plots/cartesian/axes');\nvar dragElement = require('../dragelement');\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar setCursor = require('../../lib/setcursor');\nvar Drawing = require('../drawing');\nvar Color = require('../color');\nvar Titles = require('../titles');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar flipScale = require('../colorscale/helpers').flipScale;\n\nvar handleAxisDefaults = require('../../plots/cartesian/axis_defaults');\nvar handleAxisPositionDefaults = require('../../plots/cartesian/position_defaults');\nvar axisLayoutAttrs = require('../../plots/cartesian/layout_attributes');\n\nvar alignmentConstants = require('../../constants/alignment');\nvar LINE_SPACING = alignmentConstants.LINE_SPACING;\nvar FROM_TL = alignmentConstants.FROM_TL;\nvar FROM_BR = alignmentConstants.FROM_BR;\n\nvar cn = require('./constants').cn;\n\nfunction draw(gd) {\n var fullLayout = gd._fullLayout;\n\n var colorBars = fullLayout._infolayer\n .selectAll('g.' + cn.colorbar)\n .data(makeColorBarData(gd), function(opts) { return opts._id; });\n\n colorBars.enter().append('g')\n .attr('class', function(opts) { return opts._id; })\n .classed(cn.colorbar, true);\n\n colorBars.each(function(opts) {\n var g = d3.select(this);\n\n Lib.ensureSingle(g, 'rect', cn.cbbg);\n Lib.ensureSingle(g, 'g', cn.cbfills);\n Lib.ensureSingle(g, 'g', cn.cblines);\n Lib.ensureSingle(g, 'g', cn.cbaxis, function(s) { s.classed(cn.crisp, true); });\n Lib.ensureSingle(g, 'g', cn.cbtitleunshift, function(s) { s.append('g').classed(cn.cbtitle, true); });\n Lib.ensureSingle(g, 'rect', cn.cboutline);\n\n var done = drawColorBar(g, opts, gd);\n if(done && done.then) (gd._promises || []).push(done);\n\n if(gd._context.edits.colorbarPosition) {\n makeEditable(g, opts, gd);\n }\n });\n\n colorBars.exit()\n .each(function(opts) { Plots.autoMargin(gd, opts._id); })\n .remove();\n\n colorBars.order();\n}\n\nfunction makeColorBarData(gd) {\n var fullLayout = gd._fullLayout;\n var calcdata = gd.calcdata;\n var out = [];\n\n // single out item\n var opts;\n // colorbar attr parent container\n var cont;\n // trace attr container\n var trace;\n // colorbar options\n var cbOpt;\n\n function initOpts(opts) {\n return extendFlat(opts, {\n // fillcolor can be a d3 scale, domain is z values, range is colors\n // or leave it out for no fill,\n // or set to a string constant for single-color fill\n _fillcolor: null,\n // line.color has the same options as fillcolor\n _line: {color: null, width: null, dash: null},\n // levels of lines to draw.\n // note that this DOES NOT determine the extent of the bar\n // that's given by the domain of fillcolor\n // (or line.color if no fillcolor domain)\n _levels: {start: null, end: null, size: null},\n // separate fill levels (for example, heatmap coloring of a\n // contour map) if this is omitted, fillcolors will be\n // evaluated halfway between levels\n _filllevels: null,\n // for continuous colorscales: fill with a gradient instead of explicit levels\n // value should be the colorscale [[0, c0], [v1, c1], ..., [1, cEnd]]\n _fillgradient: null,\n // when using a gradient, we need the data range specified separately\n _zrange: null\n });\n }\n\n function calcOpts() {\n if(typeof cbOpt.calc === 'function') {\n cbOpt.calc(gd, trace, opts);\n } else {\n opts._fillgradient = cont.reversescale ?\n flipScale(cont.colorscale) :\n cont.colorscale;\n opts._zrange = [cont[cbOpt.min], cont[cbOpt.max]];\n }\n }\n\n for(var i = 0; i < calcdata.length; i++) {\n var cd = calcdata[i];\n trace = cd[0].trace;\n if(!trace._module) continue;\n var moduleOpts = trace._module.colorbar;\n\n if(trace.visible === true && moduleOpts) {\n var allowsMultiplotCbs = Array.isArray(moduleOpts);\n var cbOpts = allowsMultiplotCbs ? moduleOpts : [moduleOpts];\n\n for(var j = 0; j < cbOpts.length; j++) {\n cbOpt = cbOpts[j];\n var contName = cbOpt.container;\n cont = contName ? trace[contName] : trace;\n\n if(cont && cont.showscale) {\n opts = initOpts(cont.colorbar);\n opts._id = 'cb' + trace.uid + (allowsMultiplotCbs && contName ? '-' + contName : '');\n opts._traceIndex = trace.index;\n opts._propPrefix = (contName ? contName + '.' : '') + 'colorbar.';\n opts._meta = trace._meta;\n calcOpts();\n out.push(opts);\n }\n }\n }\n }\n\n for(var k in fullLayout._colorAxes) {\n cont = fullLayout[k];\n\n if(cont.showscale) {\n var colorAxOpts = fullLayout._colorAxes[k];\n\n opts = initOpts(cont.colorbar);\n opts._id = 'cb' + k;\n opts._propPrefix = k + '.colorbar.';\n opts._meta = fullLayout._meta;\n\n cbOpt = {min: 'cmin', max: 'cmax'};\n if(colorAxOpts[0] !== 'heatmap') {\n trace = colorAxOpts[1];\n cbOpt.calc = trace._module.colorbar.calc;\n }\n\n calcOpts();\n out.push(opts);\n }\n }\n\n return out;\n}\n\nfunction drawColorBar(g, opts, gd) {\n var isVertical = opts.orientation === 'v';\n var len = opts.len;\n var lenmode = opts.lenmode;\n var thickness = opts.thickness;\n var thicknessmode = opts.thicknessmode;\n var outlinewidth = opts.outlinewidth;\n var borderwidth = opts.borderwidth;\n var bgcolor = opts.bgcolor;\n var xanchor = opts.xanchor;\n var yanchor = opts.yanchor;\n var xpad = opts.xpad;\n var ypad = opts.ypad;\n var optsX = opts.x;\n var optsY = isVertical ? opts.y : 1 - opts.y;\n\n var isPaperY = opts.yref === 'paper';\n var isPaperX = opts.xref === 'paper';\n\n var fullLayout = gd._fullLayout;\n var gs = fullLayout._size;\n\n var fillColor = opts._fillcolor;\n var line = opts._line;\n var title = opts.title;\n var titleSide = title.side;\n\n var zrange = opts._zrange ||\n d3.extent((typeof fillColor === 'function' ? fillColor : line.color).domain());\n\n var lineColormap = typeof line.color === 'function' ?\n line.color :\n function() { return line.color; };\n var fillColormap = typeof fillColor === 'function' ?\n fillColor :\n function() { return fillColor; };\n\n var levelsIn = opts._levels;\n var levelsOut = calcLevels(gd, opts, zrange);\n var fillLevels = levelsOut.fill;\n var lineLevels = levelsOut.line;\n\n // we calculate pixel sizes based on the specified graph size,\n // not the actual (in case something pushed the margins around)\n // which is a little odd but avoids an odd iterative effect\n // when the colorbar itself is pushing the margins.\n // but then the fractional size is calculated based on the\n // actual graph size, so that the axes will size correctly.\n var thickPx = Math.round(thickness * (thicknessmode === 'fraction' ? (isVertical ? gs.w : gs.h) : 1));\n var thickFrac = thickPx / (isVertical ? gs.w : gs.h);\n var lenPx = Math.round(len * (lenmode === 'fraction' ? (isVertical ? gs.h : gs.w) : 1));\n var lenFrac = lenPx / (isVertical ? gs.h : gs.w);\n\n var posW = isPaperX ? gs.w : gd._fullLayout.width;\n var posH = isPaperY ? gs.h : gd._fullLayout.height;\n\n // x positioning: do it initially just for left anchor,\n // then fix at the end (since we don't know the width yet)\n var uPx = Math.round(isVertical ?\n optsX * posW + xpad :\n optsY * posH + ypad\n );\n\n var xRatio = {center: 0.5, right: 1}[xanchor] || 0;\n var yRatio = {top: 1, middle: 0.5}[yanchor] || 0;\n\n // for dragging... this is getting a little muddled...\n var uFrac = isVertical ?\n optsX - xRatio * thickFrac :\n optsY - yRatio * thickFrac;\n\n // y/x positioning (for v/h) we can do correctly from the start\n var vFrac = isVertical ?\n optsY - yRatio * lenFrac :\n optsX - xRatio * lenFrac;\n\n var vPx = Math.round(isVertical ?\n posH * (1 - vFrac) :\n posW * vFrac\n );\n\n // stash a few things for makeEditable\n opts._lenFrac = lenFrac;\n opts._thickFrac = thickFrac;\n opts._uFrac = uFrac;\n opts._vFrac = vFrac;\n\n // stash mocked axis for contour label formatting\n var ax = opts._axis = mockColorBarAxis(gd, opts, zrange);\n\n // position can't go in through supplyDefaults\n // because that restricts it to [0,1]\n ax.position = thickFrac + (isVertical ?\n optsX + xpad / gs.w :\n optsY + ypad / gs.h\n );\n\n var topOrBottom = ['top', 'bottom'].indexOf(titleSide) !== -1;\n\n if(isVertical && topOrBottom) {\n ax.title.side = titleSide;\n ax.titlex = optsX + xpad / gs.w;\n ax.titley = vFrac + (title.side === 'top' ? lenFrac - ypad / gs.h : ypad / gs.h);\n }\n\n if(!isVertical && !topOrBottom) {\n ax.title.side = titleSide;\n ax.titley = optsY + ypad / gs.h;\n ax.titlex = vFrac + xpad / gs.w; // right side\n }\n\n if(line.color && opts.tickmode === 'auto') {\n ax.tickmode = 'linear';\n ax.tick0 = levelsIn.start;\n var dtick = levelsIn.size;\n // expand if too many contours, so we don't get too many ticks\n var autoNtick = Lib.constrain(lenPx / 50, 4, 15) + 1;\n var dtFactor = (zrange[1] - zrange[0]) / ((opts.nticks || autoNtick) * dtick);\n if(dtFactor > 1) {\n var dtexp = Math.pow(10, Math.floor(Math.log(dtFactor) / Math.LN10));\n dtick *= dtexp * Lib.roundUp(dtFactor / dtexp, [2, 5, 10]);\n // if the contours are at round multiples, reset tick0\n // so they're still at round multiples. Otherwise,\n // keep the first label on the first contour level\n if((Math.abs(levelsIn.start) / levelsIn.size + 1e-6) % 1 < 2e-6) {\n ax.tick0 = 0;\n }\n }\n ax.dtick = dtick;\n }\n\n // set domain after init, because we may want to\n // allow it outside [0,1]\n ax.domain = isVertical ? [\n vFrac + ypad / gs.h,\n vFrac + lenFrac - ypad / gs.h\n ] : [\n vFrac + xpad / gs.w,\n vFrac + lenFrac - xpad / gs.w\n ];\n\n ax.setScale();\n\n g.attr('transform', strTranslate(Math.round(gs.l), Math.round(gs.t)));\n\n var titleCont = g.select('.' + cn.cbtitleunshift)\n .attr('transform', strTranslate(-Math.round(gs.l), -Math.round(gs.t)));\n\n var ticklabelposition = ax.ticklabelposition;\n var titleFontSize = ax.title.font.size;\n\n var axLayer = g.select('.' + cn.cbaxis);\n var titleEl;\n var titleHeight = 0;\n var titleWidth = 0;\n\n function drawTitle(titleClass, titleOpts) {\n var dfltTitleOpts = {\n propContainer: ax,\n propName: opts._propPrefix + 'title',\n traceIndex: opts._traceIndex,\n _meta: opts._meta,\n placeholder: fullLayout._dfltTitle.colorbar,\n containerGroup: g.select('.' + cn.cbtitle)\n };\n\n // this class-to-rotate thing with convertToTspans is\n // getting hackier and hackier... delete groups with the\n // wrong class (in case earlier the colorbar was drawn on\n // a different side, I think?)\n var otherClass = titleClass.charAt(0) === 'h' ?\n titleClass.substr(1) :\n 'h' + titleClass;\n g.selectAll('.' + otherClass + ',.' + otherClass + '-math-group').remove();\n\n Titles.draw(gd, titleClass, extendFlat(dfltTitleOpts, titleOpts || {}));\n }\n\n function drawDummyTitle() {\n // draw the title so we know how much room it needs\n // when we squish the axis.\n // On vertical colorbars this only applies to top or bottom titles, not right side.\n // On horizontal colorbars this only applies to right, etc.\n\n if(\n (isVertical && topOrBottom) ||\n (!isVertical && !topOrBottom)\n ) {\n var x, y;\n\n if(titleSide === 'top') {\n x = xpad + gs.l + posW * optsX;\n y = ypad + gs.t + posH * (1 - vFrac - lenFrac) + 3 + titleFontSize * 0.75;\n }\n\n if(titleSide === 'bottom') {\n x = xpad + gs.l + posW * optsX;\n y = ypad + gs.t + posH * (1 - vFrac) - 3 - titleFontSize * 0.25;\n }\n\n if(titleSide === 'right') {\n y = ypad + gs.t + posH * optsY + 3 + titleFontSize * 0.75;\n x = xpad + gs.l + posW * vFrac;\n }\n\n drawTitle(ax._id + 'title', {\n attributes: {x: x, y: y, 'text-anchor': isVertical ? 'start' : 'middle'}\n });\n }\n }\n\n function drawCbTitle() {\n if(\n (isVertical && !topOrBottom) ||\n (!isVertical && topOrBottom)\n ) {\n var pos = ax.position || 0;\n var mid = ax._offset + ax._length / 2;\n var x, y;\n\n if(titleSide === 'right') {\n y = mid;\n x = gs.l + posW * pos + 10 + titleFontSize * (\n ax.showticklabels ? 1 : 0.5\n );\n } else {\n x = mid;\n\n if(titleSide === 'bottom') {\n y = gs.t + posH * pos + 10 + (\n ticklabelposition.indexOf('inside') === -1 ?\n ax.tickfont.size :\n 0\n ) + (\n ax.ticks !== 'intside' ?\n opts.ticklen || 0 :\n 0\n );\n }\n\n if(titleSide === 'top') {\n var nlines = title.text.split('
').length;\n y = gs.t + posH * pos + 10 - thickPx - LINE_SPACING * titleFontSize * nlines;\n }\n }\n\n drawTitle((isVertical ?\n // the 'h' + is a hack to get around the fact that\n // convertToTspans rotates any 'y...' class by 90 degrees.\n // TODO: find a better way to control this.\n 'h' :\n 'v'\n ) + ax._id + 'title', {\n avoid: {\n selection: d3.select(gd).selectAll('g.' + ax._id + 'tick'),\n side: titleSide,\n offsetTop: isVertical ? 0 : gs.t,\n offsetLeft: isVertical ? gs.l : 0,\n maxShift: isVertical ? fullLayout.width : fullLayout.height\n },\n attributes: {x: x, y: y, 'text-anchor': 'middle'},\n transform: {rotate: isVertical ? -90 : 0, offset: 0}\n });\n }\n }\n\n function drawAxis() {\n if(\n (!isVertical && !topOrBottom) ||\n (isVertical && topOrBottom)\n ) {\n // squish the axis top to make room for the title\n var titleGroup = g.select('.' + cn.cbtitle);\n var titleText = titleGroup.select('text');\n var titleTrans = [-outlinewidth / 2, outlinewidth / 2];\n var mathJaxNode = titleGroup\n .select('.h' + ax._id + 'title-math-group')\n .node();\n var lineSize = 15.6;\n if(titleText.node()) {\n lineSize = parseInt(titleText.node().style.fontSize, 10) * LINE_SPACING;\n }\n\n var bb;\n if(mathJaxNode) {\n bb = Drawing.bBox(mathJaxNode);\n titleWidth = bb.width;\n titleHeight = bb.height;\n if(titleHeight > lineSize) {\n // not entirely sure how mathjax is doing\n // vertical alignment, but this seems to work.\n titleTrans[1] -= (titleHeight - lineSize) / 2;\n }\n } else if(titleText.node() && !titleText.classed(cn.jsPlaceholder)) {\n bb = Drawing.bBox(titleText.node());\n titleWidth = bb.width;\n titleHeight = bb.height;\n }\n\n if(isVertical) {\n if(titleHeight) {\n // buffer btwn colorbar and title\n // TODO: configurable\n titleHeight += 5;\n\n if(titleSide === 'top') {\n ax.domain[1] -= titleHeight / gs.h;\n titleTrans[1] *= -1;\n } else {\n ax.domain[0] += titleHeight / gs.h;\n var nlines = svgTextUtils.lineCount(titleText);\n titleTrans[1] += (1 - nlines) * lineSize;\n }\n\n titleGroup.attr('transform', strTranslate(titleTrans[0], titleTrans[1]));\n ax.setScale();\n }\n } else { // horizontal colorbars\n if(titleWidth) {\n if(titleSide === 'right') {\n ax.domain[0] += (titleWidth + titleFontSize / 2) / gs.w;\n }\n\n titleGroup.attr('transform', strTranslate(titleTrans[0], titleTrans[1]));\n ax.setScale();\n }\n }\n }\n\n g.selectAll('.' + cn.cbfills + ',.' + cn.cblines)\n .attr('transform', isVertical ?\n strTranslate(0, Math.round(gs.h * (1 - ax.domain[1]))) :\n strTranslate(Math.round(gs.w * ax.domain[0]), 0)\n );\n\n axLayer.attr('transform', isVertical ?\n strTranslate(0, Math.round(-gs.t)) :\n strTranslate(Math.round(-gs.l), 0)\n );\n\n var fills = g.select('.' + cn.cbfills)\n .selectAll('rect.' + cn.cbfill)\n .attr('style', '')\n .data(fillLevels);\n fills.enter().append('rect')\n .classed(cn.cbfill, true)\n .attr('style', '');\n fills.exit().remove();\n\n var zBounds = zrange\n .map(ax.c2p)\n .map(Math.round)\n .sort(function(a, b) { return a - b; });\n\n fills.each(function(d, i) {\n var z = [\n (i === 0) ? zrange[0] : (fillLevels[i] + fillLevels[i - 1]) / 2,\n (i === fillLevels.length - 1) ? zrange[1] : (fillLevels[i] + fillLevels[i + 1]) / 2\n ]\n .map(ax.c2p)\n .map(Math.round);\n\n // offset the side adjoining the next rectangle so they\n // overlap, to prevent antialiasing gaps\n if(isVertical) {\n z[1] = Lib.constrain(z[1] + (z[1] > z[0]) ? 1 : -1, zBounds[0], zBounds[1]);\n } /* else {\n // TODO: horizontal case\n } */\n\n // Colorbar cannot currently support opacities so we\n // use an opaque fill even when alpha channels present\n var fillEl = d3.select(this)\n .attr(isVertical ? 'x' : 'y', uPx)\n .attr(isVertical ? 'y' : 'x', d3.min(z))\n .attr(isVertical ? 'width' : 'height', Math.max(thickPx, 2))\n .attr(isVertical ? 'height' : 'width', Math.max(d3.max(z) - d3.min(z), 2));\n\n if(opts._fillgradient) {\n Drawing.gradient(fillEl, gd, opts._id, isVertical ? 'vertical' : 'horizontalreversed', opts._fillgradient, 'fill');\n } else {\n // tinycolor can't handle exponents and\n // at this scale, removing it makes no difference.\n var colorString = fillColormap(d).replace('e-', '');\n fillEl.attr('fill', tinycolor(colorString).toHexString());\n }\n });\n\n var lines = g.select('.' + cn.cblines)\n .selectAll('path.' + cn.cbline)\n .data(line.color && line.width ? lineLevels : []);\n lines.enter().append('path')\n .classed(cn.cbline, true);\n lines.exit().remove();\n lines.each(function(d) {\n var a = uPx;\n var b = (Math.round(ax.c2p(d)) + (line.width / 2) % 1);\n\n d3.select(this)\n .attr('d', 'M' +\n (isVertical ? a + ',' + b : b + ',' + a) +\n (isVertical ? 'h' : 'v') +\n thickPx\n )\n .call(Drawing.lineGroupStyle, line.width, lineColormap(d), line.dash);\n });\n\n // force full redraw of labels and ticks\n axLayer.selectAll('g.' + ax._id + 'tick,path').remove();\n\n var shift = uPx + thickPx +\n (outlinewidth || 0) / 2 - (opts.ticks === 'outside' ? 1 : 0);\n\n var vals = Axes.calcTicks(ax);\n var tickSign = Axes.getTickSigns(ax)[2];\n\n Axes.drawTicks(gd, ax, {\n vals: ax.ticks === 'inside' ? Axes.clipEnds(ax, vals) : vals,\n layer: axLayer,\n path: Axes.makeTickPath(ax, shift, tickSign),\n transFn: Axes.makeTransTickFn(ax)\n });\n\n return Axes.drawLabels(gd, ax, {\n vals: vals,\n layer: axLayer,\n transFn: Axes.makeTransTickLabelFn(ax),\n labelFns: Axes.makeLabelFns(ax, shift)\n });\n }\n\n // wait for the axis & title to finish rendering before\n // continuing positioning\n // TODO: why are we redrawing multiple times now with this?\n // I guess autoMargin doesn't like being post-promise?\n function positionCB() {\n var bb;\n var innerThickness = thickPx + outlinewidth / 2;\n if(ticklabelposition.indexOf('inside') === -1) {\n bb = Drawing.bBox(axLayer.node());\n innerThickness += isVertical ? bb.width : bb.height;\n }\n\n titleEl = titleCont.select('text');\n\n var titleWidth = 0;\n\n var topSideVertical = isVertical && titleSide === 'top';\n var rightSideHorizontal = !isVertical && titleSide === 'right';\n\n var moveY = 0;\n\n if(titleEl.node() && !titleEl.classed(cn.jsPlaceholder)) {\n var _titleHeight;\n\n var mathJaxNode = titleCont.select('.h' + ax._id + 'title-math-group').node();\n if(mathJaxNode && (\n (isVertical && topOrBottom) ||\n (!isVertical && !topOrBottom)\n )) {\n bb = Drawing.bBox(mathJaxNode);\n titleWidth = bb.width;\n _titleHeight = bb.height;\n } else {\n // note: the formula below works for all title sides,\n // (except for top/bottom mathjax, above)\n // but the weird gs.l is because the titleunshift\n // transform gets removed by Drawing.bBox\n bb = Drawing.bBox(titleCont.node());\n titleWidth = bb.right - gs.l - (isVertical ? uPx : vPx);\n _titleHeight = bb.bottom - gs.t - (isVertical ? vPx : uPx);\n\n if(\n !isVertical && titleSide === 'top'\n ) {\n innerThickness += bb.height;\n moveY = bb.height;\n }\n }\n\n if(rightSideHorizontal) {\n titleEl.attr('transform', strTranslate(titleWidth / 2 + titleFontSize / 2, 0));\n\n titleWidth *= 2;\n }\n\n innerThickness = Math.max(innerThickness,\n isVertical ? titleWidth : _titleHeight\n );\n }\n\n var outerThickness = (isVertical ?\n xpad :\n ypad\n ) * 2 + innerThickness + borderwidth + outlinewidth / 2;\n\n var hColorbarMoveTitle = 0;\n if(!isVertical && title.text && yanchor === 'bottom' && optsY <= 0) {\n hColorbarMoveTitle = outerThickness / 2;\n\n outerThickness += hColorbarMoveTitle;\n moveY += hColorbarMoveTitle;\n }\n fullLayout._hColorbarMoveTitle = hColorbarMoveTitle;\n fullLayout._hColorbarMoveCBTitle = moveY;\n\n var extraW = borderwidth + outlinewidth;\n\n // TODO - are these the correct positions?\n var lx = (isVertical ? uPx : vPx) - extraW / 2 - (isVertical ? xpad : 0);\n var ly = (isVertical ? vPx : uPx) - (isVertical ? lenPx : ypad + moveY - hColorbarMoveTitle);\n\n g.select('.' + cn.cbbg)\n .attr('x', lx)\n .attr('y', ly)\n .attr(isVertical ? 'width' : 'height', Math.max(outerThickness - hColorbarMoveTitle, 2))\n .attr(isVertical ? 'height' : 'width', Math.max(lenPx + extraW, 2))\n .call(Color.fill, bgcolor)\n .call(Color.stroke, opts.bordercolor)\n .style('stroke-width', borderwidth);\n\n var moveX = rightSideHorizontal ? Math.max(titleWidth - 10, 0) : 0;\n\n g.selectAll('.' + cn.cboutline)\n .attr('x', (isVertical ? uPx : vPx + xpad) + moveX)\n .attr('y', (isVertical ? vPx + ypad - lenPx : uPx) + (topSideVertical ? titleHeight : 0))\n .attr(isVertical ? 'width' : 'height', Math.max(thickPx, 2))\n .attr(isVertical ? 'height' : 'width', Math.max(lenPx - (isVertical ?\n 2 * ypad + titleHeight :\n 2 * xpad + moveX\n ), 2))\n .call(Color.stroke, opts.outlinecolor)\n .style({\n fill: 'none',\n 'stroke-width': outlinewidth\n });\n\n var xShift = ((isVertical ? xRatio * outerThickness : 0));\n var yShift = ((isVertical ? 0 : (1 - yRatio) * outerThickness - moveY));\n xShift = isPaperX ? gs.l - xShift : -xShift;\n yShift = isPaperY ? gs.t - yShift : -yShift;\n\n g.attr('transform', strTranslate(\n xShift,\n yShift\n ));\n\n if(!isVertical && (\n borderwidth || (\n tinycolor(bgcolor).getAlpha() &&\n !tinycolor.equals(fullLayout.paper_bgcolor, bgcolor)\n )\n )) {\n // for horizontal colorbars when there is a border line or having different background color\n // hide/adjust x positioning for the first/last tick labels if they go outside the border\n var tickLabels = axLayer.selectAll('text');\n var numTicks = tickLabels[0].length;\n\n var border = g.select('.' + cn.cbbg).node();\n var oBb = Drawing.bBox(border);\n var oTr = Drawing.getTranslate(g);\n\n var TEXTPAD = 2;\n\n tickLabels.each(function(d, i) {\n var first = 0;\n var last = numTicks - 1;\n if(i === first || i === last) {\n var iBb = Drawing.bBox(this);\n var iTr = Drawing.getTranslate(this);\n var deltaX;\n\n if(i === last) {\n var iRight = iBb.right + iTr.x;\n var oRight = oBb.right + oTr.x + vPx - borderwidth - TEXTPAD + optsX;\n\n deltaX = oRight - iRight;\n if(deltaX > 0) deltaX = 0;\n } else if(i === first) {\n var iLeft = iBb.left + iTr.x;\n var oLeft = oBb.left + oTr.x + vPx + borderwidth + TEXTPAD;\n\n deltaX = oLeft - iLeft;\n if(deltaX < 0) deltaX = 0;\n }\n\n if(deltaX) {\n if(numTicks < 3) { // adjust position\n this.setAttribute('transform',\n 'translate(' + deltaX + ',0) ' +\n this.getAttribute('transform')\n );\n } else { // hide\n this.setAttribute('visibility', 'hidden');\n }\n }\n }\n });\n }\n\n // auto margin adjustment\n var marginOpts = {};\n var lFrac = FROM_TL[xanchor];\n var rFrac = FROM_BR[xanchor];\n var tFrac = FROM_TL[yanchor];\n var bFrac = FROM_BR[yanchor];\n\n var extraThickness = outerThickness - thickPx;\n if(isVertical) {\n if(lenmode === 'pixels') {\n marginOpts.y = optsY;\n marginOpts.t = lenPx * tFrac;\n marginOpts.b = lenPx * bFrac;\n } else {\n marginOpts.t = marginOpts.b = 0;\n marginOpts.yt = optsY + len * tFrac;\n marginOpts.yb = optsY - len * bFrac;\n }\n\n if(thicknessmode === 'pixels') {\n marginOpts.x = optsX;\n marginOpts.l = outerThickness * lFrac;\n marginOpts.r = outerThickness * rFrac;\n } else {\n marginOpts.l = extraThickness * lFrac;\n marginOpts.r = extraThickness * rFrac;\n marginOpts.xl = optsX - thickness * lFrac;\n marginOpts.xr = optsX + thickness * rFrac;\n }\n } else { // horizontal colorbars\n if(lenmode === 'pixels') {\n marginOpts.x = optsX;\n marginOpts.l = lenPx * lFrac;\n marginOpts.r = lenPx * rFrac;\n } else {\n marginOpts.l = marginOpts.r = 0;\n marginOpts.xl = optsX + len * lFrac;\n marginOpts.xr = optsX - len * rFrac;\n }\n\n if(thicknessmode === 'pixels') {\n marginOpts.y = 1 - optsY;\n marginOpts.t = outerThickness * tFrac;\n marginOpts.b = outerThickness * bFrac;\n } else {\n marginOpts.t = extraThickness * tFrac;\n marginOpts.b = extraThickness * bFrac;\n marginOpts.yt = optsY - thickness * tFrac;\n marginOpts.yb = optsY + thickness * bFrac;\n }\n }\n var sideY = opts.y < 0.5 ? 'b' : 't';\n var sideX = opts.x < 0.5 ? 'l' : 'r';\n\n gd._fullLayout._reservedMargin[opts._id] = {};\n var possibleReservedMargins = {\n r: (fullLayout.width - lx - xShift),\n l: lx + marginOpts.r,\n b: (fullLayout.height - ly - yShift),\n t: ly + marginOpts.b\n };\n\n if(isPaperX && isPaperY) {\n Plots.autoMargin(gd, opts._id, marginOpts);\n } else if(isPaperX) {\n gd._fullLayout._reservedMargin[opts._id][sideY] = possibleReservedMargins[sideY];\n } else if(isPaperY) {\n gd._fullLayout._reservedMargin[opts._id][sideX] = possibleReservedMargins[sideX];\n } else {\n if(isVertical) {\n gd._fullLayout._reservedMargin[opts._id][sideX] = possibleReservedMargins[sideX];\n } else {\n gd._fullLayout._reservedMargin[opts._id][sideY] = possibleReservedMargins[sideY];\n }\n }\n }\n\n return Lib.syncOrAsync([\n Plots.previousPromises,\n drawDummyTitle,\n drawAxis,\n drawCbTitle,\n Plots.previousPromises,\n positionCB\n ], gd);\n}\n\nfunction makeEditable(g, opts, gd) {\n var isVertical = opts.orientation === 'v';\n var fullLayout = gd._fullLayout;\n var gs = fullLayout._size;\n var t0, xf, yf;\n\n dragElement.init({\n element: g.node(),\n gd: gd,\n prepFn: function() {\n t0 = g.attr('transform');\n setCursor(g);\n },\n moveFn: function(dx, dy) {\n g.attr('transform', t0 + strTranslate(dx, dy));\n\n xf = dragElement.align(\n (isVertical ? opts._uFrac : opts._vFrac) + (dx / gs.w),\n isVertical ? opts._thickFrac : opts._lenFrac,\n 0, 1, opts.xanchor);\n yf = dragElement.align(\n (isVertical ? opts._vFrac : (1 - opts._uFrac)) - (dy / gs.h),\n isVertical ? opts._lenFrac : opts._thickFrac,\n 0, 1, opts.yanchor);\n\n var csr = dragElement.getCursor(xf, yf, opts.xanchor, opts.yanchor);\n setCursor(g, csr);\n },\n doneFn: function() {\n setCursor(g);\n\n if(xf !== undefined && yf !== undefined) {\n var update = {};\n update[opts._propPrefix + 'x'] = xf;\n update[opts._propPrefix + 'y'] = yf;\n if(opts._traceIndex !== undefined) {\n Registry.call('_guiRestyle', gd, update, opts._traceIndex);\n } else {\n Registry.call('_guiRelayout', gd, update);\n }\n }\n }\n });\n}\n\nfunction calcLevels(gd, opts, zrange) {\n var levelsIn = opts._levels;\n var lineLevels = [];\n var fillLevels = [];\n var l;\n var i;\n\n var l0 = levelsIn.end + levelsIn.size / 100;\n var ls = levelsIn.size;\n var zr0 = (1.001 * zrange[0] - 0.001 * zrange[1]);\n var zr1 = (1.001 * zrange[1] - 0.001 * zrange[0]);\n\n for(i = 0; i < 1e5; i++) {\n l = levelsIn.start + i * ls;\n if(ls > 0 ? (l >= l0) : (l <= l0)) break;\n if(l > zr0 && l < zr1) lineLevels.push(l);\n }\n\n if(opts._fillgradient) {\n fillLevels = [0];\n } else if(typeof opts._fillcolor === 'function') {\n var fillLevelsIn = opts._filllevels;\n\n if(fillLevelsIn) {\n l0 = fillLevelsIn.end + fillLevelsIn.size / 100;\n ls = fillLevelsIn.size;\n for(i = 0; i < 1e5; i++) {\n l = fillLevelsIn.start + i * ls;\n if(ls > 0 ? (l >= l0) : (l <= l0)) break;\n if(l > zrange[0] && l < zrange[1]) fillLevels.push(l);\n }\n } else {\n fillLevels = lineLevels.map(function(v) {\n return v - levelsIn.size / 2;\n });\n fillLevels.push(fillLevels[fillLevels.length - 1] + levelsIn.size);\n }\n } else if(opts._fillcolor && typeof opts._fillcolor === 'string') {\n // doesn't matter what this value is, with a single value\n // we'll make a single fill rect covering the whole bar\n fillLevels = [0];\n }\n\n if(levelsIn.size < 0) {\n lineLevels.reverse();\n fillLevels.reverse();\n }\n\n return {line: lineLevels, fill: fillLevels};\n}\n\nfunction mockColorBarAxis(gd, opts, zrange) {\n var fullLayout = gd._fullLayout;\n\n var isVertical = opts.orientation === 'v';\n\n var cbAxisIn = {\n type: 'linear',\n range: zrange,\n tickmode: opts.tickmode,\n nticks: opts.nticks,\n tick0: opts.tick0,\n dtick: opts.dtick,\n tickvals: opts.tickvals,\n ticktext: opts.ticktext,\n ticks: opts.ticks,\n ticklen: opts.ticklen,\n tickwidth: opts.tickwidth,\n tickcolor: opts.tickcolor,\n showticklabels: opts.showticklabels,\n labelalias: opts.labelalias,\n ticklabelposition: opts.ticklabelposition,\n ticklabeloverflow: opts.ticklabeloverflow,\n ticklabelstep: opts.ticklabelstep,\n tickfont: opts.tickfont,\n tickangle: opts.tickangle,\n tickformat: opts.tickformat,\n exponentformat: opts.exponentformat,\n minexponent: opts.minexponent,\n separatethousands: opts.separatethousands,\n showexponent: opts.showexponent,\n showtickprefix: opts.showtickprefix,\n tickprefix: opts.tickprefix,\n showticksuffix: opts.showticksuffix,\n ticksuffix: opts.ticksuffix,\n title: opts.title,\n showline: true,\n anchor: 'free',\n side: isVertical ? 'right' : 'bottom',\n position: 1\n };\n\n var letter = isVertical ? 'y' : 'x';\n\n var cbAxisOut = {\n type: 'linear',\n _id: letter + opts._id\n };\n\n var axisOptions = {\n letter: letter,\n font: fullLayout.font,\n noAutotickangles: letter === 'y',\n noHover: true,\n noTickson: true,\n noTicklabelmode: true,\n noInsideRange: true,\n calendar: fullLayout.calendar // not really necessary (yet?)\n };\n\n function coerce(attr, dflt) {\n return Lib.coerce(cbAxisIn, cbAxisOut, axisLayoutAttrs, attr, dflt);\n }\n\n handleAxisDefaults(cbAxisIn, cbAxisOut, coerce, axisOptions, fullLayout);\n handleAxisPositionDefaults(cbAxisIn, cbAxisOut, coerce, axisOptions);\n\n return cbAxisOut;\n}\n\nmodule.exports = {\n draw: draw\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\n\nmodule.exports = function hasColorbar(container) {\n return Lib.isPlainObject(container.colorbar);\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'component',\n name: 'colorbar',\n\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n\n draw: require('./draw').draw,\n hasColorbar: require('./has_colorbar')\n};\n","'use strict';\n\nvar colorbarAttrs = require('../colorbar/attributes');\nvar counterRegex = require('../../lib/regex').counter;\nvar sortObjectKeys = require('../../lib/sort_object_keys');\n\nvar palettes = require('./scales.js').scales;\nvar paletteStr = sortObjectKeys(palettes);\n\nfunction code(s) {\n return '`' + s + '`';\n}\n\n/**\n * Make colorscale attribute declarations for\n *\n * - colorscale,\n * - (c|z)auto, (c|z)min, (c|z)max,\n * - autocolorscale, reversescale,\n * - showscale (optionally)\n * - color (optionally)\n *\n * @param {string} context (dflt: '', i.e. from trace root):\n * the container this is in ('', *marker*, *marker.line* etc)\n *\n * @param {object} opts:\n * - cLetter {string} (dflt: 'c'):\n * leading letter for 'min', 'max and 'auto' attribute (either 'z' or 'c')\n *\n * - colorAttr {string} (dflt: 'z' if `cLetter: 'z'`, 'color' if `cLetter: 'c'`):\n * (for descriptions) sets the name of the color attribute that maps to the colorscale.\n *\n * N.B. if `colorAttr: 'color'`, we include the `color` declaration here.\n *\n * - onlyIfNumerical {string} (dflt: false' if `cLetter: 'z'`, true if `cLetter: 'c'`):\n * (for descriptions) set to true if colorscale attribute only\n *\n * - colorscaleDflt {string}:\n * overrides the colorscale dflt\n *\n * - autoColorDflt {boolean} (dflt true):\n * normally autocolorscale.dflt is `true`, but pass `false` to override\n *\n * - noScale {boolean} (dflt: true if `context: 'marker.line'`, false otherwise):\n * set to `false` to not include showscale attribute (e.g. for 'marker.line')\n *\n * - showScaleDflt {boolean} (dflt: true if `cLetter: 'z'`, false otherwise)\n *\n * - editTypeOverride {boolean} (dflt: ''):\n * most of these attributes already require a recalc, but the ones that do not\n * have editType *style* or *plot* unless you override (presumably with *calc*)\n *\n * - anim {boolean) (dflt: undefined): is 'color' animatable?\n *\n * @return {object}\n */\nmodule.exports = function colorScaleAttrs(context, opts) {\n context = context || '';\n opts = opts || {};\n\n var cLetter = opts.cLetter || 'c';\n var onlyIfNumerical = ('onlyIfNumerical' in opts) ? opts.onlyIfNumerical : Boolean(context);\n var noScale = ('noScale' in opts) ? opts.noScale : context === 'marker.line';\n var showScaleDflt = ('showScaleDflt' in opts) ? opts.showScaleDflt : cLetter === 'z';\n var colorscaleDflt = typeof opts.colorscaleDflt === 'string' ? palettes[opts.colorscaleDflt] : null;\n var editTypeOverride = opts.editTypeOverride || '';\n var contextHead = context ? (context + '.') : '';\n\n var colorAttr, colorAttrFull;\n\n if('colorAttr' in opts) {\n colorAttr = opts.colorAttr;\n colorAttrFull = opts.colorAttr;\n } else {\n colorAttr = {z: 'z', c: 'color'}[cLetter];\n colorAttrFull = 'in ' + code(contextHead + colorAttr);\n }\n\n var effectDesc = onlyIfNumerical ?\n ' Has an effect only if ' + colorAttrFull + ' is set to a numerical array.' :\n '';\n\n var auto = cLetter + 'auto';\n var min = cLetter + 'min';\n var max = cLetter + 'max';\n var mid = cLetter + 'mid';\n var autoFull = code(contextHead + auto);\n var minFull = code(contextHead + min);\n var maxFull = code(contextHead + max);\n var minmaxFull = minFull + ' and ' + maxFull;\n var autoImpliedEdits = {};\n autoImpliedEdits[min] = autoImpliedEdits[max] = undefined;\n var minmaxImpliedEdits = {};\n minmaxImpliedEdits[auto] = false;\n\n var attrs = {};\n\n if(colorAttr === 'color') {\n attrs.color = {\n valType: 'color',\n arrayOk: true,\n editType: editTypeOverride || 'style',\n description: [\n 'Sets the', context, 'color.',\n 'It accepts either a specific color',\n 'or an array of numbers that are mapped to the colorscale',\n 'relative to the max and min values of the array or relative to',\n minmaxFull, 'if set.'\n ].join(' ')\n };\n\n if(opts.anim) {\n attrs.color.anim = true;\n }\n }\n\n attrs[auto] = {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n impliedEdits: autoImpliedEdits,\n description: [\n 'Determines whether or not the color domain is computed',\n 'with respect to the input data (here ' + colorAttrFull + ') or the bounds set in',\n minmaxFull + effectDesc,\n 'Defaults to `false` when', minmaxFull, 'are set by the user.'\n ].join(' ')\n };\n\n attrs[min] = {\n valType: 'number',\n dflt: null,\n editType: editTypeOverride || 'plot',\n impliedEdits: minmaxImpliedEdits,\n description: [\n 'Sets the lower bound of the color domain.' + effectDesc,\n 'Value should have the same units as', colorAttrFull,\n 'and if set,', maxFull, 'must be set as well.'\n ].join(' ')\n };\n\n attrs[max] = {\n valType: 'number',\n dflt: null,\n editType: editTypeOverride || 'plot',\n impliedEdits: minmaxImpliedEdits,\n description: [\n 'Sets the upper bound of the color domain.' + effectDesc,\n 'Value should have the same units as', colorAttrFull,\n 'and if set,', minFull, 'must be set as well.'\n ].join(' ')\n };\n\n attrs[mid] = {\n valType: 'number',\n dflt: null,\n editType: 'calc',\n impliedEdits: autoImpliedEdits,\n description: [\n 'Sets the mid-point of the color domain by scaling', minFull,\n 'and/or', maxFull, 'to be equidistant to this point.' + effectDesc,\n 'Value should have the same units as', colorAttrFull + '.',\n 'Has no effect when', autoFull, 'is `false`.'\n ].join(' ')\n };\n\n attrs.colorscale = {\n valType: 'colorscale',\n editType: 'calc',\n dflt: colorscaleDflt,\n impliedEdits: {autocolorscale: false},\n description: [\n 'Sets the colorscale.' + effectDesc,\n 'The colorscale must be an array containing',\n 'arrays mapping a normalized value to an',\n 'rgb, rgba, hex, hsl, hsv, or named color string.',\n 'At minimum, a mapping for the lowest (0) and highest (1)',\n 'values are required. For example,',\n '`[[0, \\'rgb(0,0,255)\\'], [1, \\'rgb(255,0,0)\\']]`.',\n 'To control the bounds of the colorscale in color space,',\n 'use', minmaxFull + '.',\n 'Alternatively, `colorscale` may be a palette name string',\n 'of the following list: ' + paletteStr + '.'\n ].join(' ')\n };\n\n attrs.autocolorscale = {\n valType: 'boolean',\n // gets overrode in 'heatmap' & 'surface' for backwards comp.\n dflt: opts.autoColorDflt === false ? false : true,\n editType: 'calc',\n impliedEdits: {colorscale: undefined},\n description: [\n 'Determines whether the colorscale is a default palette (`autocolorscale: true`)',\n 'or the palette determined by', code(contextHead + 'colorscale') + '.' + effectDesc,\n 'In case `colorscale` is unspecified or `autocolorscale` is true, the default',\n 'palette will be chosen according to whether numbers in the `color` array are',\n 'all positive, all negative or mixed.'\n ].join(' ')\n };\n\n attrs.reversescale = {\n valType: 'boolean',\n dflt: false,\n editType: 'plot',\n description: [\n 'Reverses the color mapping if true.' + effectDesc,\n 'If true,', minFull, 'will correspond to the last color',\n 'in the array and', maxFull, 'will correspond to the first color.'\n ].join(' ')\n };\n\n if(!noScale) {\n attrs.showscale = {\n valType: 'boolean',\n dflt: showScaleDflt,\n editType: 'calc',\n description: [\n 'Determines whether or not a colorbar is displayed for this trace.' + effectDesc\n ].join(' ')\n };\n\n attrs.colorbar = colorbarAttrs;\n }\n\n if(!opts.noColorAxis) {\n attrs.coloraxis = {\n valType: 'subplotid',\n regex: counterRegex('coloraxis'),\n dflt: null,\n editType: 'calc',\n description: [\n 'Sets a reference to a shared color axis.',\n 'References to these shared color axes are *coloraxis*, *coloraxis2*, *coloraxis3*, etc.',\n 'Settings for these shared color axes are set in the layout, under',\n '`layout.coloraxis`, `layout.coloraxis2`, etc.',\n 'Note that multiple color scales can be linked to the same color axis.'\n ].join(' ')\n };\n }\n\n return attrs;\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar extractOpts = require('./helpers').extractOpts;\n\nmodule.exports = function calc(gd, trace, opts) {\n var fullLayout = gd._fullLayout;\n var vals = opts.vals;\n var containerStr = opts.containerStr;\n\n var container = containerStr ?\n Lib.nestedProperty(trace, containerStr).get() :\n trace;\n\n var cOpts = extractOpts(container);\n var auto = cOpts.auto !== false;\n var min = cOpts.min;\n var max = cOpts.max;\n var mid = cOpts.mid;\n\n var minVal = function() { return Lib.aggNums(Math.min, null, vals); };\n var maxVal = function() { return Lib.aggNums(Math.max, null, vals); };\n\n if(min === undefined) {\n min = minVal();\n } else if(auto) {\n if(container._colorAx && isNumeric(min)) {\n min = Math.min(min, minVal());\n } else {\n min = minVal();\n }\n }\n\n if(max === undefined) {\n max = maxVal();\n } else if(auto) {\n if(container._colorAx && isNumeric(max)) {\n max = Math.max(max, maxVal());\n } else {\n max = maxVal();\n }\n }\n\n if(auto && mid !== undefined) {\n if(max - mid > mid - min) {\n min = mid - (max - mid);\n } else if(max - mid < mid - min) {\n max = mid + (mid - min);\n }\n }\n\n if(min === max) {\n min -= 0.5;\n max += 0.5;\n }\n\n cOpts._sync('min', min);\n cOpts._sync('max', max);\n\n if(cOpts.autocolorscale) {\n var scl;\n if(min * max < 0) scl = fullLayout.colorscale.diverging;\n else if(min >= 0) scl = fullLayout.colorscale.sequential;\n else scl = fullLayout.colorscale.sequentialminus;\n cOpts._sync('colorscale', scl);\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar hasColorscale = require('./helpers').hasColorscale;\nvar extractOpts = require('./helpers').extractOpts;\n\nmodule.exports = function crossTraceDefaults(fullData, fullLayout) {\n function replace(cont, k) {\n var val = cont['_' + k];\n if(val !== undefined) {\n cont[k] = val;\n }\n }\n\n function relinkColorAttrs(outerCont, cbOpt) {\n var cont = cbOpt.container ?\n Lib.nestedProperty(outerCont, cbOpt.container).get() :\n outerCont;\n\n if(cont) {\n if(cont.coloraxis) {\n // stash ref to color axis\n cont._colorAx = fullLayout[cont.coloraxis];\n } else {\n var cOpts = extractOpts(cont);\n var isAuto = cOpts.auto;\n\n if(isAuto || cOpts.min === undefined) {\n replace(cont, cbOpt.min);\n }\n if(isAuto || cOpts.max === undefined) {\n replace(cont, cbOpt.max);\n }\n if(cOpts.autocolorscale) {\n replace(cont, 'colorscale');\n }\n }\n }\n }\n\n for(var i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n var cbOpts = trace._module.colorbar;\n\n if(cbOpts) {\n if(Array.isArray(cbOpts)) {\n for(var j = 0; j < cbOpts.length; j++) {\n relinkColorAttrs(trace, cbOpts[j]);\n }\n } else {\n relinkColorAttrs(trace, cbOpts);\n }\n }\n\n if(hasColorscale(trace, 'marker.line')) {\n relinkColorAttrs(trace, {\n container: 'marker.line',\n min: 'cmin',\n max: 'cmax'\n });\n }\n }\n\n for(var k in fullLayout._colorAxes) {\n relinkColorAttrs(fullLayout[k], {min: 'cmin', max: 'cmax'});\n }\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar hasColorbar = require('../colorbar/has_colorbar');\nvar colorbarDefaults = require('../colorbar/defaults');\n\nvar isValidScale = require('./scales').isValid;\nvar traceIs = require('../../registry').traceIs;\n\nfunction npMaybe(parentCont, prefix) {\n var containerStr = prefix.slice(0, prefix.length - 1);\n return prefix ?\n Lib.nestedProperty(parentCont, containerStr).get() || {} :\n parentCont;\n}\n\n/**\n * Colorscale / colorbar default handler\n *\n * @param {object} parentContIn : user (input) parent container (e.g. trace or layout coloraxis object)\n * @param {object} parentContOut : full parent container\n * @param {object} layout : (full) layout object\n * @param {fn} coerce : Lib.coerce wrapper\n * @param {object} opts :\n * - prefix {string} : attr string prefix to colorscale container from parent root\n * - cLetter {string} : 'c or 'z' color letter\n */\nmodule.exports = function colorScaleDefaults(parentContIn, parentContOut, layout, coerce, opts) {\n var prefix = opts.prefix;\n var cLetter = opts.cLetter;\n var inTrace = '_module' in parentContOut;\n var containerIn = npMaybe(parentContIn, prefix);\n var containerOut = npMaybe(parentContOut, prefix);\n var template = npMaybe(parentContOut._template || {}, prefix) || {};\n\n // colorScaleDefaults wrapper called if-ever we need to reset the colorscale\n // attributes for containers that were linked to invalid color axes\n var thisFn = function() {\n delete parentContIn.coloraxis;\n delete parentContOut.coloraxis;\n return colorScaleDefaults(parentContIn, parentContOut, layout, coerce, opts);\n };\n\n if(inTrace) {\n var colorAxes = layout._colorAxes || {};\n var colorAx = coerce(prefix + 'coloraxis');\n\n if(colorAx) {\n var colorbarVisuals = (\n traceIs(parentContOut, 'contour') &&\n Lib.nestedProperty(parentContOut, 'contours.coloring').get()\n ) || 'heatmap';\n\n var stash = colorAxes[colorAx];\n\n if(stash) {\n stash[2].push(thisFn);\n\n if(stash[0] !== colorbarVisuals) {\n stash[0] = false;\n Lib.warn([\n 'Ignoring coloraxis:', colorAx, 'setting',\n 'as it is linked to incompatible colorscales.'\n ].join(' '));\n }\n } else {\n // stash:\n // - colorbar visual 'type'\n // - colorbar options to help in Colorbar.draw\n // - list of colorScaleDefaults wrapper functions\n colorAxes[colorAx] = [colorbarVisuals, parentContOut, [thisFn]];\n }\n return;\n }\n }\n\n var minIn = containerIn[cLetter + 'min'];\n var maxIn = containerIn[cLetter + 'max'];\n var validMinMax = isNumeric(minIn) && isNumeric(maxIn) && (minIn < maxIn);\n var auto = coerce(prefix + cLetter + 'auto', !validMinMax);\n\n if(auto) {\n coerce(prefix + cLetter + 'mid');\n } else {\n coerce(prefix + cLetter + 'min');\n coerce(prefix + cLetter + 'max');\n }\n\n // handles both the trace case (autocolorscale is false by default) and\n // the marker and marker.line case (autocolorscale is true by default)\n var sclIn = containerIn.colorscale;\n var sclTemplate = template.colorscale;\n var autoColorscaleDflt;\n if(sclIn !== undefined) autoColorscaleDflt = !isValidScale(sclIn);\n if(sclTemplate !== undefined) autoColorscaleDflt = !isValidScale(sclTemplate);\n coerce(prefix + 'autocolorscale', autoColorscaleDflt);\n\n coerce(prefix + 'colorscale');\n coerce(prefix + 'reversescale');\n\n if(prefix !== 'marker.line.') {\n // handles both the trace case where the dflt is listed in attributes and\n // the marker case where the dflt is determined by hasColorbar\n var showScaleDflt;\n if(prefix && inTrace) showScaleDflt = hasColorbar(containerIn);\n\n var showScale = coerce(prefix + 'showscale', showScaleDflt);\n if(showScale) {\n if(prefix && template) containerOut._template = template;\n colorbarDefaults(containerIn, containerOut, layout);\n }\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar tinycolor = require('tinycolor2');\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar Color = require('../color');\n\nvar isValidScale = require('./scales').isValid;\n\nfunction hasColorscale(trace, containerStr, colorKey) {\n var container = containerStr ?\n Lib.nestedProperty(trace, containerStr).get() || {} :\n trace;\n\n var color = container[colorKey || 'color'];\n if(color && color._inputArray) color = color._inputArray;\n\n var isArrayWithOneNumber = false;\n if(Lib.isArrayOrTypedArray(color)) {\n for(var i = 0; i < color.length; i++) {\n if(isNumeric(color[i])) {\n isArrayWithOneNumber = true;\n break;\n }\n }\n }\n\n return (\n Lib.isPlainObject(container) && (\n isArrayWithOneNumber ||\n container.showscale === true ||\n (isNumeric(container.cmin) && isNumeric(container.cmax)) ||\n isValidScale(container.colorscale) ||\n Lib.isPlainObject(container.colorbar)\n )\n );\n}\n\nvar constantAttrs = ['showscale', 'autocolorscale', 'colorscale', 'reversescale', 'colorbar'];\nvar letterAttrs = ['min', 'max', 'mid', 'auto'];\n\n/**\n * Extract 'c' / 'z', trace / color axis colorscale options\n *\n * Note that it would be nice to replace all z* with c* equivalents in v3\n *\n * @param {object} cont : attribute container\n * @return {object}:\n * - min: cmin or zmin\n * - max: cmax or zmax\n * - mid: cmid or zmid\n * - auto: cauto or zauto\n * - *scale: *scale attrs\n * - colorbar: colorbar\n * - _sync: function syncing attr and underscore dual (useful when calc'ing min/max)\n */\nfunction extractOpts(cont) {\n var colorAx = cont._colorAx;\n var cont2 = colorAx ? colorAx : cont;\n var out = {};\n var cLetter;\n var i, k;\n\n for(i = 0; i < constantAttrs.length; i++) {\n k = constantAttrs[i];\n out[k] = cont2[k];\n }\n\n if(colorAx) {\n cLetter = 'c';\n for(i = 0; i < letterAttrs.length; i++) {\n k = letterAttrs[i];\n out[k] = cont2['c' + k];\n }\n } else {\n var k2;\n for(i = 0; i < letterAttrs.length; i++) {\n k = letterAttrs[i];\n k2 = 'c' + k;\n if(k2 in cont2) {\n out[k] = cont2[k2];\n continue;\n }\n k2 = 'z' + k;\n if(k2 in cont2) {\n out[k] = cont2[k2];\n }\n }\n cLetter = k2.charAt(0);\n }\n\n out._sync = function(k, v) {\n var k2 = letterAttrs.indexOf(k) !== -1 ? cLetter + k : k;\n cont2[k2] = cont2['_' + k2] = v;\n };\n\n return out;\n}\n\n/**\n * Extract colorscale into numeric domain and color range.\n *\n * @param {object} cont colorscale container (e.g. trace, marker)\n * - colorscale {array of arrays}\n * - cmin/zmin {number}\n * - cmax/zmax {number}\n * - reversescale {boolean}\n *\n * @return {object}\n * - domain {array}\n * - range {array}\n */\nfunction extractScale(cont) {\n var cOpts = extractOpts(cont);\n var cmin = cOpts.min;\n var cmax = cOpts.max;\n\n var scl = cOpts.reversescale ?\n flipScale(cOpts.colorscale) :\n cOpts.colorscale;\n\n var N = scl.length;\n var domain = new Array(N);\n var range = new Array(N);\n\n for(var i = 0; i < N; i++) {\n var si = scl[i];\n domain[i] = cmin + si[0] * (cmax - cmin);\n range[i] = si[1];\n }\n\n return {domain: domain, range: range};\n}\n\nfunction flipScale(scl) {\n var N = scl.length;\n var sclNew = new Array(N);\n\n for(var i = N - 1, j = 0; i >= 0; i--, j++) {\n var si = scl[i];\n sclNew[j] = [1 - si[0], si[1]];\n }\n return sclNew;\n}\n\n/**\n * General colorscale function generator.\n *\n * @param {object} specs output of Colorscale.extractScale or precomputed domain, range.\n * - domain {array}\n * - range {array}\n *\n * @param {object} opts\n * - noNumericCheck {boolean} if true, scale func bypasses numeric checks\n * - returnArray {boolean} if true, scale func return 4-item array instead of color strings\n *\n * @return {function}\n */\nfunction makeColorScaleFunc(specs, opts) {\n opts = opts || {};\n\n var domain = specs.domain;\n var range = specs.range;\n var N = range.length;\n var _range = new Array(N);\n\n for(var i = 0; i < N; i++) {\n var rgba = tinycolor(range[i]).toRgb();\n _range[i] = [rgba.r, rgba.g, rgba.b, rgba.a];\n }\n\n var _sclFunc = d3.scale.linear()\n .domain(domain)\n .range(_range)\n .clamp(true);\n\n var noNumericCheck = opts.noNumericCheck;\n var returnArray = opts.returnArray;\n var sclFunc;\n\n if(noNumericCheck && returnArray) {\n sclFunc = _sclFunc;\n } else if(noNumericCheck) {\n sclFunc = function(v) {\n return colorArray2rbga(_sclFunc(v));\n };\n } else if(returnArray) {\n sclFunc = function(v) {\n if(isNumeric(v)) return _sclFunc(v);\n else if(tinycolor(v).isValid()) return v;\n else return Color.defaultLine;\n };\n } else {\n sclFunc = function(v) {\n if(isNumeric(v)) return colorArray2rbga(_sclFunc(v));\n else if(tinycolor(v).isValid()) return v;\n else return Color.defaultLine;\n };\n }\n\n // colorbar draw looks into the d3 scale closure for domain and range\n sclFunc.domain = _sclFunc.domain;\n sclFunc.range = function() { return range; };\n\n return sclFunc;\n}\n\nfunction makeColorScaleFuncFromTrace(trace, opts) {\n return makeColorScaleFunc(extractScale(trace), opts);\n}\n\nfunction colorArray2rbga(colorArray) {\n var colorObj = {\n r: colorArray[0],\n g: colorArray[1],\n b: colorArray[2],\n a: colorArray[3]\n };\n\n return tinycolor(colorObj).toRgbString();\n}\n\nmodule.exports = {\n hasColorscale: hasColorscale,\n extractOpts: extractOpts,\n extractScale: extractScale,\n flipScale: flipScale,\n makeColorScaleFunc: makeColorScaleFunc,\n makeColorScaleFuncFromTrace: makeColorScaleFuncFromTrace\n};\n","'use strict';\n\nvar scales = require('./scales');\nvar helpers = require('./helpers');\n\nmodule.exports = {\n moduleType: 'component',\n name: 'colorscale',\n\n attributes: require('./attributes'),\n layoutAttributes: require('./layout_attributes'),\n\n supplyLayoutDefaults: require('./layout_defaults'),\n handleDefaults: require('./defaults'),\n crossTraceDefaults: require('./cross_trace_defaults'),\n\n calc: require('./calc'),\n\n // ./scales.js is required in lib/coerce.js ;\n // it needs to be a separate module to avoid a circular dependency\n scales: scales.scales,\n defaultScale: scales.defaultScale,\n getScale: scales.get,\n isValidScale: scales.isValid,\n\n hasColorscale: helpers.hasColorscale,\n extractOpts: helpers.extractOpts,\n extractScale: helpers.extractScale,\n flipScale: helpers.flipScale,\n makeColorScaleFunc: helpers.makeColorScaleFunc,\n makeColorScaleFuncFromTrace: helpers.makeColorScaleFuncFromTrace\n};\n","'use strict';\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar colorScaleAttrs = require('./attributes');\nvar scales = require('./scales').scales;\n\nvar msg = 'Note that `autocolorscale` must be true for this attribute to work.';\n\nmodule.exports = {\n editType: 'calc',\n\n colorscale: {\n editType: 'calc',\n\n sequential: {\n valType: 'colorscale',\n dflt: scales.Reds,\n editType: 'calc',\n description: [\n 'Sets the default sequential colorscale for positive values.',\n msg\n ].join(' ')\n },\n sequentialminus: {\n valType: 'colorscale',\n dflt: scales.Blues,\n editType: 'calc',\n description: [\n 'Sets the default sequential colorscale for negative values.',\n msg\n ].join(' ')\n },\n diverging: {\n valType: 'colorscale',\n dflt: scales.RdBu,\n editType: 'calc',\n description: [\n 'Sets the default diverging colorscale.',\n msg\n ].join(' ')\n }\n },\n\n coloraxis: extendFlat({\n // not really a 'subplot' attribute container,\n // but this is the flag we use to denote attributes that\n // support yaxis, yaxis2, yaxis3, ... counters\n _isSubplotObj: true,\n editType: 'calc',\n description: [\n ''\n ].join(' ')\n }, colorScaleAttrs('', {\n colorAttr: 'corresponding trace color array(s)',\n noColorAxis: true,\n showScaleDflt: true\n }))\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Template = require('../../plot_api/plot_template');\n\nvar colorScaleAttrs = require('./layout_attributes');\nvar colorScaleDefaults = require('./defaults');\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, colorScaleAttrs, attr, dflt);\n }\n\n coerce('colorscale.sequential');\n coerce('colorscale.sequentialminus');\n coerce('colorscale.diverging');\n\n var colorAxes = layoutOut._colorAxes;\n var colorAxIn, colorAxOut;\n\n function coerceAx(attr, dflt) {\n return Lib.coerce(colorAxIn, colorAxOut, colorScaleAttrs.coloraxis, attr, dflt);\n }\n\n for(var k in colorAxes) {\n var stash = colorAxes[k];\n\n if(stash[0]) {\n colorAxIn = layoutIn[k] || {};\n colorAxOut = Template.newContainer(layoutOut, k, 'coloraxis');\n colorAxOut._name = k;\n colorScaleDefaults(colorAxIn, colorAxOut, layoutOut, coerceAx, {prefix: '', cLetter: 'c'});\n } else {\n // re-coerce colorscale attributes w/o coloraxis\n for(var i = 0; i < stash[2].length; i++) {\n stash[2][i]();\n }\n delete layoutOut._colorAxes[k];\n }\n }\n};\n","'use strict';\n\nvar tinycolor = require('tinycolor2');\n\nvar scales = {\n Greys: [\n [0, 'rgb(0,0,0)'], [1, 'rgb(255,255,255)']\n ],\n\n YlGnBu: [\n [0, 'rgb(8,29,88)'], [0.125, 'rgb(37,52,148)'],\n [0.25, 'rgb(34,94,168)'], [0.375, 'rgb(29,145,192)'],\n [0.5, 'rgb(65,182,196)'], [0.625, 'rgb(127,205,187)'],\n [0.75, 'rgb(199,233,180)'], [0.875, 'rgb(237,248,217)'],\n [1, 'rgb(255,255,217)']\n ],\n\n Greens: [\n [0, 'rgb(0,68,27)'], [0.125, 'rgb(0,109,44)'],\n [0.25, 'rgb(35,139,69)'], [0.375, 'rgb(65,171,93)'],\n [0.5, 'rgb(116,196,118)'], [0.625, 'rgb(161,217,155)'],\n [0.75, 'rgb(199,233,192)'], [0.875, 'rgb(229,245,224)'],\n [1, 'rgb(247,252,245)']\n ],\n\n YlOrRd: [\n [0, 'rgb(128,0,38)'], [0.125, 'rgb(189,0,38)'],\n [0.25, 'rgb(227,26,28)'], [0.375, 'rgb(252,78,42)'],\n [0.5, 'rgb(253,141,60)'], [0.625, 'rgb(254,178,76)'],\n [0.75, 'rgb(254,217,118)'], [0.875, 'rgb(255,237,160)'],\n [1, 'rgb(255,255,204)']\n ],\n\n Bluered: [\n [0, 'rgb(0,0,255)'], [1, 'rgb(255,0,0)']\n ],\n\n // modified RdBu based on\n // http://www.kennethmoreland.com/color-maps/\n RdBu: [\n [0, 'rgb(5,10,172)'], [0.35, 'rgb(106,137,247)'],\n [0.5, 'rgb(190,190,190)'], [0.6, 'rgb(220,170,132)'],\n [0.7, 'rgb(230,145,90)'], [1, 'rgb(178,10,28)']\n ],\n\n // Scale for non-negative numeric values\n Reds: [\n [0, 'rgb(220,220,220)'], [0.2, 'rgb(245,195,157)'],\n [0.4, 'rgb(245,160,105)'], [1, 'rgb(178,10,28)']\n ],\n\n // Scale for non-positive numeric values\n Blues: [\n [0, 'rgb(5,10,172)'], [0.35, 'rgb(40,60,190)'],\n [0.5, 'rgb(70,100,245)'], [0.6, 'rgb(90,120,245)'],\n [0.7, 'rgb(106,137,247)'], [1, 'rgb(220,220,220)']\n ],\n\n Picnic: [\n [0, 'rgb(0,0,255)'], [0.1, 'rgb(51,153,255)'],\n [0.2, 'rgb(102,204,255)'], [0.3, 'rgb(153,204,255)'],\n [0.4, 'rgb(204,204,255)'], [0.5, 'rgb(255,255,255)'],\n [0.6, 'rgb(255,204,255)'], [0.7, 'rgb(255,153,255)'],\n [0.8, 'rgb(255,102,204)'], [0.9, 'rgb(255,102,102)'],\n [1, 'rgb(255,0,0)']\n ],\n\n Rainbow: [\n [0, 'rgb(150,0,90)'], [0.125, 'rgb(0,0,200)'],\n [0.25, 'rgb(0,25,255)'], [0.375, 'rgb(0,152,255)'],\n [0.5, 'rgb(44,255,150)'], [0.625, 'rgb(151,255,0)'],\n [0.75, 'rgb(255,234,0)'], [0.875, 'rgb(255,111,0)'],\n [1, 'rgb(255,0,0)']\n ],\n\n Portland: [\n [0, 'rgb(12,51,131)'], [0.25, 'rgb(10,136,186)'],\n [0.5, 'rgb(242,211,56)'], [0.75, 'rgb(242,143,56)'],\n [1, 'rgb(217,30,30)']\n ],\n\n Jet: [\n [0, 'rgb(0,0,131)'], [0.125, 'rgb(0,60,170)'],\n [0.375, 'rgb(5,255,255)'], [0.625, 'rgb(255,255,0)'],\n [0.875, 'rgb(250,0,0)'], [1, 'rgb(128,0,0)']\n ],\n\n Hot: [\n [0, 'rgb(0,0,0)'], [0.3, 'rgb(230,0,0)'],\n [0.6, 'rgb(255,210,0)'], [1, 'rgb(255,255,255)']\n ],\n\n Blackbody: [\n [0, 'rgb(0,0,0)'], [0.2, 'rgb(230,0,0)'],\n [0.4, 'rgb(230,210,0)'], [0.7, 'rgb(255,255,255)'],\n [1, 'rgb(160,200,255)']\n ],\n\n Earth: [\n [0, 'rgb(0,0,130)'], [0.1, 'rgb(0,180,180)'],\n [0.2, 'rgb(40,210,40)'], [0.4, 'rgb(230,230,50)'],\n [0.6, 'rgb(120,70,20)'], [1, 'rgb(255,255,255)']\n ],\n\n Electric: [\n [0, 'rgb(0,0,0)'], [0.15, 'rgb(30,0,100)'],\n [0.4, 'rgb(120,0,100)'], [0.6, 'rgb(160,90,0)'],\n [0.8, 'rgb(230,200,0)'], [1, 'rgb(255,250,220)']\n ],\n\n Viridis: [\n [0, '#440154'], [0.06274509803921569, '#48186a'],\n [0.12549019607843137, '#472d7b'], [0.18823529411764706, '#424086'],\n [0.25098039215686274, '#3b528b'], [0.3137254901960784, '#33638d'],\n [0.3764705882352941, '#2c728e'], [0.4392156862745098, '#26828e'],\n [0.5019607843137255, '#21918c'], [0.5647058823529412, '#1fa088'],\n [0.6274509803921569, '#28ae80'], [0.6901960784313725, '#3fbc73'],\n [0.7529411764705882, '#5ec962'], [0.8156862745098039, '#84d44b'],\n [0.8784313725490196, '#addc30'], [0.9411764705882353, '#d8e219'],\n [1, '#fde725']\n ],\n\n Cividis: [\n [0.000000, 'rgb(0,32,76)'], [0.058824, 'rgb(0,42,102)'],\n [0.117647, 'rgb(0,52,110)'], [0.176471, 'rgb(39,63,108)'],\n [0.235294, 'rgb(60,74,107)'], [0.294118, 'rgb(76,85,107)'],\n [0.352941, 'rgb(91,95,109)'], [0.411765, 'rgb(104,106,112)'],\n [0.470588, 'rgb(117,117,117)'], [0.529412, 'rgb(131,129,120)'],\n [0.588235, 'rgb(146,140,120)'], [0.647059, 'rgb(161,152,118)'],\n [0.705882, 'rgb(176,165,114)'], [0.764706, 'rgb(192,177,109)'],\n [0.823529, 'rgb(209,191,102)'], [0.882353, 'rgb(225,204,92)'],\n [0.941176, 'rgb(243,219,79)'], [1.000000, 'rgb(255,233,69)']\n ]\n};\n\nvar defaultScale = scales.RdBu;\n\nfunction getScale(scl, dflt) {\n if(!dflt) dflt = defaultScale;\n if(!scl) return dflt;\n\n function parseScale() {\n try {\n scl = scales[scl] || JSON.parse(scl);\n } catch(e) {\n scl = dflt;\n }\n }\n\n if(typeof scl === 'string') {\n parseScale();\n // occasionally scl is double-JSON encoded...\n if(typeof scl === 'string') parseScale();\n }\n\n if(!isValidScaleArray(scl)) return dflt;\n return scl;\n}\n\n\nfunction isValidScaleArray(scl) {\n var highestVal = 0;\n\n if(!Array.isArray(scl) || scl.length < 2) return false;\n\n if(!scl[0] || !scl[scl.length - 1]) return false;\n\n if(+scl[0][0] !== 0 || +scl[scl.length - 1][0] !== 1) return false;\n\n for(var i = 0; i < scl.length; i++) {\n var si = scl[i];\n\n if(si.length !== 2 || +si[0] < highestVal || !tinycolor(si[1]).isValid()) {\n return false;\n }\n\n highestVal = +si[0];\n }\n\n return true;\n}\n\nfunction isValidScale(scl) {\n if(scales[scl] !== undefined) return true;\n else return isValidScaleArray(scl);\n}\n\nmodule.exports = {\n scales: scales,\n defaultScale: defaultScale,\n\n get: getScale,\n isValid: isValidScale\n};\n","'use strict';\n\n\n// for automatic alignment on dragging, <1/3 means left align,\n// >2/3 means right, and between is center. Pick the right fraction\n// based on where you are, and return the fraction corresponding to\n// that position on the object\nmodule.exports = function align(v, dv, v0, v1, anchor) {\n var vmin = (v - v0) / (v1 - v0);\n var vmax = vmin + dv / (v1 - v0);\n var vc = (vmin + vmax) / 2;\n\n // explicitly specified anchor\n if(anchor === 'left' || anchor === 'bottom') return vmin;\n if(anchor === 'center' || anchor === 'middle') return vc;\n if(anchor === 'right' || anchor === 'top') return vmax;\n\n // automatic based on position\n if(vmin < (2 / 3) - vc) return vmin;\n if(vmax > (4 / 3) - vc) return vmax;\n return vc;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\n\n// set cursors pointing toward the closest corner/side,\n// to indicate alignment\n// x and y are 0-1, fractions of the plot area\nvar cursorset = [\n ['sw-resize', 's-resize', 'se-resize'],\n ['w-resize', 'move', 'e-resize'],\n ['nw-resize', 'n-resize', 'ne-resize']\n];\n\nmodule.exports = function getCursor(x, y, xanchor, yanchor) {\n if(xanchor === 'left') x = 0;\n else if(xanchor === 'center') x = 1;\n else if(xanchor === 'right') x = 2;\n else x = Lib.constrain(Math.floor(x * 3), 0, 2);\n\n if(yanchor === 'bottom') y = 0;\n else if(yanchor === 'middle') y = 1;\n else if(yanchor === 'top') y = 2;\n else y = Lib.constrain(Math.floor(y * 3), 0, 2);\n\n return cursorset[y][x];\n};\n","'use strict';\n\nexports.selectMode = function(dragmode) {\n return (\n dragmode === 'lasso' ||\n dragmode === 'select'\n );\n};\n\nexports.drawMode = function(dragmode) {\n return (\n dragmode === 'drawclosedpath' ||\n dragmode === 'drawopenpath' ||\n dragmode === 'drawline' ||\n dragmode === 'drawrect' ||\n dragmode === 'drawcircle'\n );\n};\n\nexports.openMode = function(dragmode) {\n return (\n dragmode === 'drawline' ||\n dragmode === 'drawopenpath'\n );\n};\n\nexports.rectMode = function(dragmode) {\n return (\n dragmode === 'select' ||\n dragmode === 'drawline' ||\n dragmode === 'drawrect' ||\n dragmode === 'drawcircle'\n );\n};\n\nexports.freeMode = function(dragmode) {\n return (\n dragmode === 'lasso' ||\n dragmode === 'drawclosedpath' ||\n dragmode === 'drawopenpath'\n );\n};\n\nexports.selectingOrDrawing = function(dragmode) {\n return (\n exports.freeMode(dragmode) ||\n exports.rectMode(dragmode)\n );\n};\n","'use strict';\n\nvar mouseOffset = require('mouse-event-offset');\nvar hasHover = require('has-hover');\nvar supportsPassive = require('has-passive-events');\n\nvar removeElement = require('../../lib').removeElement;\nvar constants = require('../../plots/cartesian/constants');\n\nvar dragElement = module.exports = {};\n\ndragElement.align = require('./align');\ndragElement.getCursor = require('./cursor');\n\nvar unhover = require('./unhover');\ndragElement.unhover = unhover.wrapped;\ndragElement.unhoverRaw = unhover.raw;\n\n/**\n * Abstracts click & drag interactions\n *\n * During the interaction, a \"coverSlip\" element - a transparent\n * div covering the whole page - is created, which has two key effects:\n * - Lets you drag beyond the boundaries of the plot itself without\n * dropping (but if you drag all the way out of the browser window the\n * interaction will end)\n * - Freezes the cursor: whatever mouse cursor the drag element had when the\n * interaction started gets copied to the coverSlip for use until mouseup\n *\n * If the user executes a drag bigger than MINDRAG, callbacks will fire as:\n * prepFn, moveFn (1 or more times), doneFn\n * If the user does not drag enough, prepFn and clickFn will fire.\n *\n * Note: If you cancel contextmenu, clickFn will fire even with a right click\n * (unlike native events) so you'll get a `plotly_click` event. Cancel context eg:\n * gd.addEventListener('contextmenu', function(e) { e.preventDefault(); });\n * TODO: we should probably turn this into a `config` parameter, so we can fix it\n * such that if you *don't* cancel contextmenu, we can prevent partial drags, which\n * put you in a weird state.\n *\n * If the user clicks multiple times quickly, clickFn will fire each time\n * but numClicks will increase to help you recognize doubleclicks.\n *\n * @param {object} options with keys:\n * element (required) the DOM element to drag\n * prepFn (optional) function(event, startX, startY)\n * executed on mousedown\n * startX and startY are the clientX and clientY pixel position\n * of the mousedown event\n * moveFn (optional) function(dx, dy)\n * executed on move, ONLY after we've exceeded MINDRAG\n * (we keep executing moveFn if you move back to where you started)\n * dx and dy are the net pixel offset of the drag,\n * dragged is true/false, has the mouse moved enough to\n * constitute a drag\n * doneFn (optional) function(e)\n * executed on mouseup, ONLY if we exceeded MINDRAG (so you can be\n * sure that moveFn has been called at least once)\n * numClicks is how many clicks we've registered within\n * a doubleclick time\n * e is the original mouseup event\n * clickFn (optional) function(numClicks, e)\n * executed on mouseup if we have NOT exceeded MINDRAG (ie moveFn\n * has not been called at all)\n * numClicks is how many clicks we've registered within\n * a doubleclick time\n * e is the original mousedown event\n * clampFn (optional, function(dx, dy) return [dx2, dy2])\n * Provide custom clamping function for small displacements.\n * By default, clamping is done using `minDrag` to x and y displacements\n * independently.\n */\ndragElement.init = function init(options) {\n var gd = options.gd;\n var numClicks = 1;\n var doubleClickDelay = gd._context.doubleClickDelay;\n var element = options.element;\n\n var startX,\n startY,\n newMouseDownTime,\n cursor,\n dragCover,\n initialEvent,\n initialTarget,\n rightClick;\n\n if(!gd._mouseDownTime) gd._mouseDownTime = 0;\n\n element.style.pointerEvents = 'all';\n\n element.onmousedown = onStart;\n\n if(!supportsPassive) {\n element.ontouchstart = onStart;\n } else {\n if(element._ontouchstart) {\n element.removeEventListener('touchstart', element._ontouchstart);\n }\n element._ontouchstart = onStart;\n element.addEventListener('touchstart', onStart, {passive: false});\n }\n\n function _clampFn(dx, dy, minDrag) {\n if(Math.abs(dx) < minDrag) dx = 0;\n if(Math.abs(dy) < minDrag) dy = 0;\n return [dx, dy];\n }\n\n var clampFn = options.clampFn || _clampFn;\n\n function onStart(e) {\n // make dragging and dragged into properties of gd\n // so that others can look at and modify them\n gd._dragged = false;\n gd._dragging = true;\n var offset = pointerOffset(e);\n startX = offset[0];\n startY = offset[1];\n initialTarget = e.target;\n initialEvent = e;\n rightClick = e.buttons === 2 || e.ctrlKey;\n\n // fix Fx.hover for touch events\n if(typeof e.clientX === 'undefined' && typeof e.clientY === 'undefined') {\n e.clientX = startX;\n e.clientY = startY;\n }\n\n newMouseDownTime = (new Date()).getTime();\n if(newMouseDownTime - gd._mouseDownTime < doubleClickDelay) {\n // in a click train\n numClicks += 1;\n } else {\n // new click train\n numClicks = 1;\n gd._mouseDownTime = newMouseDownTime;\n }\n\n if(options.prepFn) options.prepFn(e, startX, startY);\n\n if(hasHover && !rightClick) {\n dragCover = coverSlip();\n dragCover.style.cursor = window.getComputedStyle(element).cursor;\n } else if(!hasHover) {\n // document acts as a dragcover for mobile, bc we can't create dragcover dynamically\n dragCover = document;\n cursor = window.getComputedStyle(document.documentElement).cursor;\n document.documentElement.style.cursor = window.getComputedStyle(element).cursor;\n }\n\n document.addEventListener('mouseup', onDone);\n document.addEventListener('touchend', onDone);\n\n if(options.dragmode !== false) {\n e.preventDefault();\n document.addEventListener('mousemove', onMove);\n document.addEventListener('touchmove', onMove, {passive: false});\n }\n\n return;\n }\n\n function onMove(e) {\n e.preventDefault();\n\n var offset = pointerOffset(e);\n var minDrag = options.minDrag || constants.MINDRAG;\n var dxdy = clampFn(offset[0] - startX, offset[1] - startY, minDrag);\n var dx = dxdy[0];\n var dy = dxdy[1];\n\n if(dx || dy) {\n gd._dragged = true;\n dragElement.unhover(gd, e);\n }\n\n if(gd._dragged && options.moveFn && !rightClick) {\n gd._dragdata = {\n element: element,\n dx: dx,\n dy: dy\n };\n options.moveFn(dx, dy);\n }\n\n return;\n }\n\n function onDone(e) {\n delete gd._dragdata;\n\n if(options.dragmode !== false) {\n e.preventDefault();\n document.removeEventListener('mousemove', onMove);\n document.removeEventListener('touchmove', onMove);\n }\n\n document.removeEventListener('mouseup', onDone);\n document.removeEventListener('touchend', onDone);\n\n if(hasHover) {\n removeElement(dragCover);\n } else if(cursor) {\n dragCover.documentElement.style.cursor = cursor;\n cursor = null;\n }\n\n if(!gd._dragging) {\n gd._dragged = false;\n return;\n }\n gd._dragging = false;\n\n // don't count as a dblClick unless the mouseUp is also within\n // the dblclick delay\n if((new Date()).getTime() - gd._mouseDownTime > doubleClickDelay) {\n numClicks = Math.max(numClicks - 1, 1);\n }\n\n if(gd._dragged) {\n if(options.doneFn) options.doneFn();\n } else {\n if(options.clickFn) options.clickFn(numClicks, initialEvent);\n\n // If we haven't dragged, this should be a click. But because of the\n // coverSlip changing the element, the natural system might not generate one,\n // so we need to make our own. But right clicks don't normally generate\n // click events, only contextmenu events, which happen on mousedown.\n if(!rightClick) {\n var e2;\n\n try {\n e2 = new MouseEvent('click', e);\n } catch(err) {\n var offset = pointerOffset(e);\n e2 = document.createEvent('MouseEvents');\n e2.initMouseEvent('click',\n e.bubbles, e.cancelable,\n e.view, e.detail,\n e.screenX, e.screenY,\n offset[0], offset[1],\n e.ctrlKey, e.altKey, e.shiftKey, e.metaKey,\n e.button, e.relatedTarget);\n }\n\n initialTarget.dispatchEvent(e2);\n }\n }\n\n gd._dragging = false;\n gd._dragged = false;\n return;\n }\n};\n\nfunction coverSlip() {\n var cover = document.createElement('div');\n\n cover.className = 'dragcover';\n var cStyle = cover.style;\n cStyle.position = 'fixed';\n cStyle.left = 0;\n cStyle.right = 0;\n cStyle.top = 0;\n cStyle.bottom = 0;\n cStyle.zIndex = 999999999;\n cStyle.background = 'none';\n\n document.body.appendChild(cover);\n\n return cover;\n}\n\ndragElement.coverSlip = coverSlip;\n\nfunction pointerOffset(e) {\n return mouseOffset(\n e.changedTouches ? e.changedTouches[0] : e,\n document.body\n );\n}\n","'use strict';\n\nvar Events = require('../../lib/events');\nvar throttle = require('../../lib/throttle');\nvar getGraphDiv = require('../../lib/dom').getGraphDiv;\n\nvar hoverConstants = require('../fx/constants');\n\nvar unhover = module.exports = {};\n\nunhover.wrapped = function(gd, evt, subplot) {\n gd = getGraphDiv(gd);\n\n // Important, clear any queued hovers\n if(gd._fullLayout) {\n throttle.clear(gd._fullLayout._uid + hoverConstants.HOVERID);\n }\n\n unhover.raw(gd, evt, subplot);\n};\n\n\n// remove hover effects on mouse out, and emit unhover event\nunhover.raw = function raw(gd, evt) {\n var fullLayout = gd._fullLayout;\n var oldhoverdata = gd._hoverdata;\n\n if(!evt) evt = {};\n if(evt.target && !gd._dragged &&\n Events.triggerHandler(gd, 'plotly_beforehover', evt) === false) {\n return;\n }\n\n fullLayout._hoverlayer.selectAll('g').remove();\n fullLayout._hoverlayer.selectAll('line').remove();\n fullLayout._hoverlayer.selectAll('circle').remove();\n gd._hoverdata = undefined;\n\n if(evt.target && oldhoverdata) {\n gd.emit('plotly_unhover', {\n event: evt,\n points: oldhoverdata\n });\n }\n};\n","'use strict';\n\nexports.dash = {\n valType: 'string',\n // string type usually doesn't take values... this one should really be\n // a special type or at least a special coercion function, from the GUI\n // you only get these values but elsewhere the user can supply a list of\n // dash lengths in px, and it will be honored\n values: ['solid', 'dot', 'dash', 'longdash', 'dashdot', 'longdashdot'],\n dflt: 'solid',\n editType: 'style',\n description: [\n 'Sets the dash style of lines. Set to a dash type string',\n '(*solid*, *dot*, *dash*, *longdash*, *dashdot*, or *longdashdot*)',\n 'or a dash length list in px (eg *5px,10px,2px,2px*).'\n ].join(' ')\n};\n\nexports.pattern = {\n shape: {\n valType: 'enumerated',\n values: ['', '/', '\\\\', 'x', '-', '|', '+', '.'],\n dflt: '',\n arrayOk: true,\n editType: 'style',\n description: [\n 'Sets the shape of the pattern fill.',\n 'By default, no pattern is used for filling the area.',\n ].join(' ')\n },\n fillmode: {\n valType: 'enumerated',\n values: ['replace', 'overlay'],\n dflt: 'replace',\n editType: 'style',\n description: [\n 'Determines whether `marker.color` should be used',\n 'as a default to `bgcolor` or a `fgcolor`.'\n ].join(' ')\n },\n bgcolor: {\n valType: 'color',\n arrayOk: true,\n editType: 'style',\n description: [\n 'When there is no colorscale sets the color of background pattern fill.',\n 'Defaults to a `marker.color` background when `fillmode` is *overlay*.',\n 'Otherwise, defaults to a transparent background.'\n ].join(' ')\n },\n fgcolor: {\n valType: 'color',\n arrayOk: true,\n editType: 'style',\n description: [\n 'When there is no colorscale sets the color of foreground pattern fill.',\n 'Defaults to a `marker.color` background when `fillmode` is *replace*.',\n 'Otherwise, defaults to dark grey or white',\n 'to increase contrast with the `bgcolor`.',\n ].join(' ')\n },\n fgopacity: {\n valType: 'number',\n editType: 'style',\n min: 0,\n max: 1,\n description: [\n 'Sets the opacity of the foreground pattern fill.',\n 'Defaults to a 0.5 when `fillmode` is *overlay*.',\n 'Otherwise, defaults to 1.'\n ].join(' ')\n },\n size: {\n valType: 'number',\n min: 0,\n dflt: 8,\n arrayOk: true,\n editType: 'style',\n description: [\n 'Sets the size of unit squares of the pattern fill in pixels,',\n 'which corresponds to the interval of repetition of the pattern.',\n ].join(' ')\n },\n solidity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0.3,\n arrayOk: true,\n editType: 'style',\n description: [\n 'Sets the solidity of the pattern fill.',\n 'Solidity is roughly the fraction of the area filled by the pattern.',\n 'Solidity of 0 shows only the background color without pattern',\n 'and solidty of 1 shows only the foreground color without pattern.',\n ].join(' ')\n },\n editType: 'style',\n description: [\n 'Sets the pattern within the marker.'\n ].join(' '),\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\nvar numberFormat = Lib.numberFormat;\nvar isNumeric = require('fast-isnumeric');\nvar tinycolor = require('tinycolor2');\n\nvar Registry = require('../../registry');\nvar Color = require('../color');\nvar Colorscale = require('../colorscale');\nvar strTranslate = Lib.strTranslate;\nvar svgTextUtils = require('../../lib/svg_text_utils');\n\nvar xmlnsNamespaces = require('../../constants/xmlns_namespaces');\nvar alignment = require('../../constants/alignment');\nvar LINE_SPACING = alignment.LINE_SPACING;\nvar DESELECTDIM = require('../../constants/interactions').DESELECTDIM;\n\nvar subTypes = require('../../traces/scatter/subtypes');\nvar makeBubbleSizeFn = require('../../traces/scatter/make_bubble_size_func');\nvar appendArrayPointValue = require('../../components/fx/helpers').appendArrayPointValue;\n\nvar drawing = module.exports = {};\n\n// -----------------------------------------------------\n// styling functions for plot elements\n// -----------------------------------------------------\n\ndrawing.font = function(s, font) {\n var variant = font.variant;\n var style = font.style;\n var weight = font.weight;\n var color = font.color;\n var size = font.size;\n var family = font.family;\n var shadow = font.shadow;\n var lineposition = font.lineposition;\n var textcase = font.textcase;\n\n if(family) s.style('font-family', family);\n if(size + 1) s.style('font-size', size + 'px');\n if(color) s.call(Color.fill, color);\n\n if(weight) s.style('font-weight', weight);\n if(style) s.style('font-style', style);\n if(variant) s.style('font-variant', variant);\n\n if(textcase) s.style('text-transform', dropNone(textcase2transform(textcase)));\n if(shadow) s.style('text-shadow', shadow === 'auto' ? svgTextUtils.makeTextShadow(Color.contrast(color)) : dropNone(shadow));\n if(lineposition) s.style('text-decoration-line', dropNone(lineposition2decorationLine(lineposition)));\n};\n\nfunction dropNone(a) {\n return a === 'none' ? undefined : a;\n}\n\nvar textcase2transformOptions = {\n normal: 'none',\n lower: 'lowercase',\n upper: 'uppercase',\n 'word caps': 'capitalize'\n};\n\nfunction textcase2transform(textcase) {\n return textcase2transformOptions[textcase];\n}\n\nfunction lineposition2decorationLine(lineposition) {\n return (\n lineposition\n .replace('under', 'underline')\n .replace('over', 'overline')\n .replace('through', 'line-through')\n .split('+')\n .join(' ')\n );\n}\n\n/*\n * Positioning helpers\n * Note: do not use `setPosition` with nodes modified by\n * `svgTextUtils.convertToTspans`. Use `svgTextUtils.positionText`\n * instead, so that elements get updated to match.\n */\ndrawing.setPosition = function(s, x, y) { s.attr('x', x).attr('y', y); };\ndrawing.setSize = function(s, w, h) { s.attr('width', w).attr('height', h); };\ndrawing.setRect = function(s, x, y, w, h) {\n s.call(drawing.setPosition, x, y).call(drawing.setSize, w, h);\n};\n\n/** Translate node\n *\n * @param {object} d : calcdata point item\n * @param {sel} sel : d3 selction of node to translate\n * @param {object} xa : corresponding full xaxis object\n * @param {object} ya : corresponding full yaxis object\n *\n * @return {boolean} :\n * true if selection got translated\n * false if selection could not get translated\n */\ndrawing.translatePoint = function(d, sel, xa, ya) {\n var x = xa.c2p(d.x);\n var y = ya.c2p(d.y);\n\n if(isNumeric(x) && isNumeric(y) && sel.node()) {\n // for multiline text this works better\n if(sel.node().nodeName === 'text') {\n sel.attr('x', x).attr('y', y);\n } else {\n sel.attr('transform', strTranslate(x, y));\n }\n } else {\n return false;\n }\n\n return true;\n};\n\ndrawing.translatePoints = function(s, xa, ya) {\n s.each(function(d) {\n var sel = d3.select(this);\n drawing.translatePoint(d, sel, xa, ya);\n });\n};\n\ndrawing.hideOutsideRangePoint = function(d, sel, xa, ya, xcalendar, ycalendar) {\n sel.attr(\n 'display',\n (xa.isPtWithinRange(d, xcalendar) && ya.isPtWithinRange(d, ycalendar)) ? null : 'none'\n );\n};\n\ndrawing.hideOutsideRangePoints = function(traceGroups, subplot) {\n if(!subplot._hasClipOnAxisFalse) return;\n\n var xa = subplot.xaxis;\n var ya = subplot.yaxis;\n\n traceGroups.each(function(d) {\n var trace = d[0].trace;\n var xcalendar = trace.xcalendar;\n var ycalendar = trace.ycalendar;\n var selector = Registry.traceIs(trace, 'bar-like') ? '.bartext' : '.point,.textpoint';\n\n traceGroups.selectAll(selector).each(function(d) {\n drawing.hideOutsideRangePoint(d, d3.select(this), xa, ya, xcalendar, ycalendar);\n });\n });\n};\n\ndrawing.crispRound = function(gd, lineWidth, dflt) {\n // for lines that disable antialiasing we want to\n // make sure the width is an integer, and at least 1 if it's nonzero\n\n if(!lineWidth || !isNumeric(lineWidth)) return dflt || 0;\n\n // but not for static plots - these don't get antialiased anyway.\n if(gd._context.staticPlot) return lineWidth;\n\n if(lineWidth < 1) return 1;\n return Math.round(lineWidth);\n};\n\ndrawing.singleLineStyle = function(d, s, lw, lc, ld) {\n s.style('fill', 'none');\n var line = (((d || [])[0] || {}).trace || {}).line || {};\n var lw1 = lw || line.width || 0;\n var dash = ld || line.dash || '';\n\n Color.stroke(s, lc || line.color);\n drawing.dashLine(s, dash, lw1);\n};\n\ndrawing.lineGroupStyle = function(s, lw, lc, ld) {\n s.style('fill', 'none')\n .each(function(d) {\n var line = (((d || [])[0] || {}).trace || {}).line || {};\n var lw1 = lw || line.width || 0;\n var dash = ld || line.dash || '';\n\n d3.select(this)\n .call(Color.stroke, lc || line.color)\n .call(drawing.dashLine, dash, lw1);\n });\n};\n\ndrawing.dashLine = function(s, dash, lineWidth) {\n lineWidth = +lineWidth || 0;\n\n dash = drawing.dashStyle(dash, lineWidth);\n\n s.style({\n 'stroke-dasharray': dash,\n 'stroke-width': lineWidth + 'px'\n });\n};\n\ndrawing.dashStyle = function(dash, lineWidth) {\n lineWidth = +lineWidth || 1;\n var dlw = Math.max(lineWidth, 3);\n\n if(dash === 'solid') dash = '';\n else if(dash === 'dot') dash = dlw + 'px,' + dlw + 'px';\n else if(dash === 'dash') dash = (3 * dlw) + 'px,' + (3 * dlw) + 'px';\n else if(dash === 'longdash') dash = (5 * dlw) + 'px,' + (5 * dlw) + 'px';\n else if(dash === 'dashdot') {\n dash = (3 * dlw) + 'px,' + dlw + 'px,' + dlw + 'px,' + dlw + 'px';\n } else if(dash === 'longdashdot') {\n dash = (5 * dlw) + 'px,' + (2 * dlw) + 'px,' + dlw + 'px,' + (2 * dlw) + 'px';\n }\n // otherwise user wrote the dasharray themselves - leave it be\n\n return dash;\n};\n\nfunction setFillStyle(sel, trace, gd, forLegend) {\n var markerPattern = trace.fillpattern;\n var fillgradient = trace.fillgradient;\n var patternShape = markerPattern && drawing.getPatternAttr(markerPattern.shape, 0, '');\n if(patternShape) {\n var patternBGColor = drawing.getPatternAttr(markerPattern.bgcolor, 0, null);\n var patternFGColor = drawing.getPatternAttr(markerPattern.fgcolor, 0, null);\n var patternFGOpacity = markerPattern.fgopacity;\n var patternSize = drawing.getPatternAttr(markerPattern.size, 0, 8);\n var patternSolidity = drawing.getPatternAttr(markerPattern.solidity, 0, 0.3);\n var patternID = trace.uid;\n drawing.pattern(sel, 'point', gd, patternID,\n patternShape, patternSize, patternSolidity,\n undefined, markerPattern.fillmode,\n patternBGColor, patternFGColor, patternFGOpacity\n );\n } else if(fillgradient && fillgradient.type !== 'none') {\n var direction = fillgradient.type;\n var gradientID = 'scatterfill-' + trace.uid;\n if(forLegend) {\n gradientID = 'legendfill-' + trace.uid;\n }\n\n if(!forLegend && (fillgradient.start !== undefined || fillgradient.stop !== undefined)) {\n var start, stop;\n if(direction === 'horizontal') {\n start = {\n x: fillgradient.start,\n y: 0,\n };\n stop = {\n x: fillgradient.stop,\n y: 0,\n };\n } else if(direction === 'vertical') {\n start = {\n x: 0,\n y: fillgradient.start,\n };\n stop = {\n x: 0,\n y: fillgradient.stop,\n };\n }\n\n start.x = trace._xA.c2p(\n (start.x === undefined) ? trace._extremes.x.min[0].val : start.x, true\n );\n start.y = trace._yA.c2p(\n (start.y === undefined) ? trace._extremes.y.min[0].val : start.y, true\n );\n\n stop.x = trace._xA.c2p(\n (stop.x === undefined) ? trace._extremes.x.max[0].val : stop.x, true\n );\n stop.y = trace._yA.c2p(\n (stop.y === undefined) ? trace._extremes.y.max[0].val : stop.y, true\n );\n sel.call(gradientWithBounds, gd, gradientID, 'linear', fillgradient.colorscale, 'fill', start, stop, true, false);\n } else {\n if(direction === 'horizontal') {\n direction = direction + 'reversed';\n }\n sel.call(drawing.gradient, gd, gradientID, direction, fillgradient.colorscale, 'fill');\n }\n } else if(trace.fillcolor) {\n sel.call(Color.fill, trace.fillcolor);\n }\n}\n\n// Same as fillGroupStyle, except in this case the selection may be a transition\ndrawing.singleFillStyle = function(sel, gd) {\n var node = d3.select(sel.node());\n var data = node.data();\n var trace = ((data[0] || [])[0] || {}).trace || {};\n setFillStyle(sel, trace, gd, false);\n};\n\ndrawing.fillGroupStyle = function(s, gd, forLegend) {\n s.style('stroke-width', 0)\n .each(function(d) {\n var shape = d3.select(this);\n // N.B. 'd' won't be a calcdata item when\n // fill !== 'none' on a segment-less and marker-less trace\n if(d[0].trace) {\n setFillStyle(shape, d[0].trace, gd, forLegend);\n }\n });\n};\n\nvar SYMBOLDEFS = require('./symbol_defs');\n\ndrawing.symbolNames = [];\ndrawing.symbolFuncs = [];\ndrawing.symbolBackOffs = [];\ndrawing.symbolNeedLines = {};\ndrawing.symbolNoDot = {};\ndrawing.symbolNoFill = {};\ndrawing.symbolList = [];\n\nObject.keys(SYMBOLDEFS).forEach(function(k) {\n var symDef = SYMBOLDEFS[k];\n var n = symDef.n;\n drawing.symbolList.push(\n n,\n String(n),\n k,\n\n n + 100,\n String(n + 100),\n k + '-open'\n );\n drawing.symbolNames[n] = k;\n drawing.symbolFuncs[n] = symDef.f;\n drawing.symbolBackOffs[n] = symDef.backoff || 0;\n\n if(symDef.needLine) {\n drawing.symbolNeedLines[n] = true;\n }\n if(symDef.noDot) {\n drawing.symbolNoDot[n] = true;\n } else {\n drawing.symbolList.push(\n n + 200,\n String(n + 200),\n k + '-dot',\n\n n + 300,\n String(n + 300),\n k + '-open-dot'\n );\n }\n if(symDef.noFill) {\n drawing.symbolNoFill[n] = true;\n }\n});\n\nvar MAXSYMBOL = drawing.symbolNames.length;\n// add a dot in the middle of the symbol\nvar DOTPATH = 'M0,0.5L0.5,0L0,-0.5L-0.5,0Z';\n\ndrawing.symbolNumber = function(v) {\n if(isNumeric(v)) {\n v = +v;\n } else if(typeof v === 'string') {\n var vbase = 0;\n if(v.indexOf('-open') > 0) {\n vbase = 100;\n v = v.replace('-open', '');\n }\n if(v.indexOf('-dot') > 0) {\n vbase += 200;\n v = v.replace('-dot', '');\n }\n v = drawing.symbolNames.indexOf(v);\n if(v >= 0) { v += vbase; }\n }\n\n return (v % 100 >= MAXSYMBOL || v >= 400) ?\n 0 : Math.floor(Math.max(v, 0));\n};\n\nfunction makePointPath(symbolNumber, r, t, s) {\n var base = symbolNumber % 100;\n return drawing.symbolFuncs[base](r, t, s) + (symbolNumber >= 200 ? DOTPATH : '');\n}\n\nvar stopFormatter = numberFormat('~f');\nvar gradientInfo = {\n radial: {type: 'radial'},\n radialreversed: {type: 'radial', reversed: true},\n horizontal: {type: 'linear', start: {x: 1, y: 0}, stop: {x: 0, y: 0}},\n horizontalreversed: {type: 'linear', start: {x: 1, y: 0}, stop: {x: 0, y: 0}, reversed: true},\n vertical: {type: 'linear', start: {x: 0, y: 1}, stop: {x: 0, y: 0}},\n verticalreversed: {type: 'linear', start: {x: 0, y: 1}, stop: {x: 0, y: 0}, reversed: true}\n};\n\n/**\n * gradient: create and apply a gradient fill\n *\n * @param {object} sel: d3 selection to apply this gradient to\n * You can use `selection.call(Drawing.gradient, ...)`\n * @param {DOM element} gd: the graph div `sel` is part of\n * @param {string} gradientID: a unique (within this plot) identifier\n * for this gradient, so that we don't create unnecessary definitions\n * @param {string} type: 'radial', 'horizontal', or 'vertical', optionally with\n * 'reversed' at the end. Normally radial goes center to edge,\n * horizontal goes right to left, and vertical goes bottom to top\n * @param {array} colorscale: as in attribute values, [[fraction, color], ...]\n * @param {string} prop: the property to apply to, 'fill' or 'stroke'\n */\ndrawing.gradient = function(sel, gd, gradientID, type, colorscale, prop) {\n var info = gradientInfo[type];\n return gradientWithBounds(\n sel, gd, gradientID, info.type, colorscale, prop, info.start, info.stop, false, info.reversed\n );\n};\n\n/**\n * gradient_with_bounds: create and apply a gradient fill for defined start and stop positions\n *\n * @param {object} sel: d3 selection to apply this gradient to\n * You can use `selection.call(Drawing.gradient, ...)`\n * @param {DOM element} gd: the graph div `sel` is part of\n * @param {string} gradientID: a unique (within this plot) identifier\n * for this gradient, so that we don't create unnecessary definitions\n * @param {string} type: 'radial' or 'linear'. Radial goes center to edge,\n * horizontal goes as defined by start and stop\n * @param {array} colorscale: as in attribute values, [[fraction, color], ...]\n * @param {string} prop: the property to apply to, 'fill' or 'stroke'\n * @param {object} start: start point for linear gradients, { x: number, y: number }.\n * Ignored if type is 'radial'.\n * @param {object} stop: stop point for linear gradients, { x: number, y: number }.\n * Ignored if type is 'radial'.\n * @param {boolean} inUserSpace: If true, start and stop give absolute values in the plot.\n * If false, start and stop are fractions of the traces extent along each axis.\n * @param {boolean} reversed: If true, the gradient is reversed between normal start and stop,\n * i.e., the colorscale is applied in order from stop to start for linear, from edge\n * to center for radial gradients.\n */\nfunction gradientWithBounds(sel, gd, gradientID, type, colorscale, prop, start, stop, inUserSpace, reversed) {\n var len = colorscale.length;\n\n var info;\n if(type === 'linear') {\n info = {\n node: 'linearGradient',\n attrs: {\n x1: start.x,\n y1: start.y,\n x2: stop.x,\n y2: stop.y,\n gradientUnits: inUserSpace ? 'userSpaceOnUse' : 'objectBoundingBox',\n },\n reversed: reversed,\n };\n } else if(type === 'radial') {\n info = {\n node: 'radialGradient',\n reversed: reversed,\n };\n }\n\n var colorStops = new Array(len);\n for(var i = 0; i < len; i++) {\n if(info.reversed) {\n colorStops[len - 1 - i] = [stopFormatter((1 - colorscale[i][0]) * 100), colorscale[i][1]];\n } else {\n colorStops[i] = [stopFormatter(colorscale[i][0] * 100), colorscale[i][1]];\n }\n }\n\n var fullLayout = gd._fullLayout;\n var fullID = 'g' + fullLayout._uid + '-' + gradientID;\n\n var gradient = fullLayout._defs.select('.gradients')\n .selectAll('#' + fullID)\n .data([type + colorStops.join(';')], Lib.identity);\n\n gradient.exit().remove();\n\n gradient.enter()\n .append(info.node)\n .each(function() {\n var el = d3.select(this);\n if(info.attrs) el.attr(info.attrs);\n\n el.attr('id', fullID);\n\n var stops = el.selectAll('stop')\n .data(colorStops);\n stops.exit().remove();\n stops.enter().append('stop');\n\n stops.each(function(d) {\n var tc = tinycolor(d[1]);\n d3.select(this).attr({\n offset: d[0] + '%',\n 'stop-color': Color.tinyRGB(tc),\n 'stop-opacity': tc.getAlpha()\n });\n });\n });\n\n sel.style(prop, getFullUrl(fullID, gd))\n .style(prop + '-opacity', null);\n\n sel.classed('gradient_filled', true);\n}\n\n/**\n * pattern: create and apply a pattern fill\n *\n * @param {object} sel: d3 selection to apply this pattern to\n * You can use `selection.call(Drawing.pattern, ...)`\n * @param {string} calledBy: option to know the caller component\n * @param {DOM element} gd: the graph div `sel` is part of\n * @param {string} patternID: a unique (within this plot) identifier\n * for this pattern, so that we don't create unnecessary definitions\n * @param {number} size: size of unit squares for repetition of this pattern\n * @param {number} solidity: how solid lines of this pattern are\n * @param {string} mcc: color when painted with colorscale\n * @param {string} fillmode: fillmode for this pattern\n * @param {string} bgcolor: background color for this pattern\n * @param {string} fgcolor: foreground color for this pattern\n * @param {number} fgopacity: foreground opacity for this pattern\n */\ndrawing.pattern = function(sel, calledBy, gd, patternID, shape, size, solidity, mcc, fillmode, bgcolor, fgcolor, fgopacity) {\n var isLegend = calledBy === 'legend';\n\n if(mcc) {\n if(fillmode === 'overlay') {\n bgcolor = mcc;\n fgcolor = Color.contrast(bgcolor);\n } else {\n bgcolor = undefined;\n fgcolor = mcc;\n }\n }\n\n var fullLayout = gd._fullLayout;\n var fullID = 'p' + fullLayout._uid + '-' + patternID;\n var width, height;\n\n // linear interpolation\n var linearFn = function(x, x0, x1, y0, y1) {\n return y0 + (y1 - y0) * (x - x0) / (x1 - x0);\n };\n\n var path, linewidth, radius;\n var patternTag;\n var patternAttrs = {};\n\n var fgC = tinycolor(fgcolor);\n var fgRGB = Color.tinyRGB(fgC);\n var fgAlpha = fgC.getAlpha();\n var opacity = fgopacity * fgAlpha;\n\n switch(shape) {\n case '/':\n width = size * Math.sqrt(2);\n height = size * Math.sqrt(2);\n path = 'M-' + (width / 4) + ',' + (height / 4) + 'l' + (width / 2) + ',-' + (height / 2) +\n 'M0,' + height + 'L' + width + ',0' +\n 'M' + (width / 4 * 3) + ',' + (height / 4 * 5) + 'l' + (width / 2) + ',-' + (height / 2);\n linewidth = solidity * size;\n patternTag = 'path';\n patternAttrs = {\n d: path,\n opacity: opacity,\n stroke: fgRGB,\n 'stroke-width': linewidth + 'px'\n };\n break;\n case '\\\\':\n width = size * Math.sqrt(2);\n height = size * Math.sqrt(2);\n path = 'M' + (width / 4 * 3) + ',-' + (height / 4) + 'l' + (width / 2) + ',' + (height / 2) +\n 'M0,0L' + width + ',' + height +\n 'M-' + (width / 4) + ',' + (height / 4 * 3) + 'l' + (width / 2) + ',' + (height / 2);\n linewidth = solidity * size;\n patternTag = 'path';\n patternAttrs = {\n d: path,\n opacity: opacity,\n stroke: fgRGB,\n 'stroke-width': linewidth + 'px'\n };\n break;\n case 'x':\n width = size * Math.sqrt(2);\n height = size * Math.sqrt(2);\n path = 'M-' + (width / 4) + ',' + (height / 4) + 'l' + (width / 2) + ',-' + (height / 2) +\n 'M0,' + height + 'L' + width + ',0' +\n 'M' + (width / 4 * 3) + ',' + (height / 4 * 5) + 'l' + (width / 2) + ',-' + (height / 2) +\n 'M' + (width / 4 * 3) + ',-' + (height / 4) + 'l' + (width / 2) + ',' + (height / 2) +\n 'M0,0L' + width + ',' + height +\n 'M-' + (width / 4) + ',' + (height / 4 * 3) + 'l' + (width / 2) + ',' + (height / 2);\n linewidth = size - size * Math.sqrt(1.0 - solidity);\n patternTag = 'path';\n patternAttrs = {\n d: path,\n opacity: opacity,\n stroke: fgRGB,\n 'stroke-width': linewidth + 'px'\n };\n break;\n case '|':\n width = size;\n height = size;\n patternTag = 'path';\n path = 'M' + (width / 2) + ',0L' + (width / 2) + ',' + height;\n linewidth = solidity * size;\n patternTag = 'path';\n patternAttrs = {\n d: path,\n opacity: opacity,\n stroke: fgRGB,\n 'stroke-width': linewidth + 'px'\n };\n break;\n case '-':\n width = size;\n height = size;\n patternTag = 'path';\n path = 'M0,' + (height / 2) + 'L' + width + ',' + (height / 2);\n linewidth = solidity * size;\n patternTag = 'path';\n patternAttrs = {\n d: path,\n opacity: opacity,\n stroke: fgRGB,\n 'stroke-width': linewidth + 'px'\n };\n break;\n case '+':\n width = size;\n height = size;\n patternTag = 'path';\n path = 'M' + (width / 2) + ',0L' + (width / 2) + ',' + height +\n 'M0,' + (height / 2) + 'L' + width + ',' + (height / 2);\n linewidth = size - size * Math.sqrt(1.0 - solidity);\n patternTag = 'path';\n patternAttrs = {\n d: path,\n opacity: opacity,\n stroke: fgRGB,\n 'stroke-width': linewidth + 'px'\n };\n break;\n case '.':\n width = size;\n height = size;\n if(solidity < Math.PI / 4) {\n radius = Math.sqrt(solidity * size * size / Math.PI);\n } else {\n radius = linearFn(solidity, Math.PI / 4, 1.0, size / 2, size / Math.sqrt(2));\n }\n patternTag = 'circle';\n patternAttrs = {\n cx: width / 2,\n cy: height / 2,\n r: radius,\n opacity: opacity,\n fill: fgRGB\n };\n break;\n }\n\n var str = [\n shape || 'noSh',\n bgcolor || 'noBg',\n fgcolor || 'noFg',\n size,\n solidity\n ].join(';');\n\n var pattern = fullLayout._defs.select('.patterns')\n .selectAll('#' + fullID)\n .data([str], Lib.identity);\n\n pattern.exit().remove();\n\n pattern.enter()\n .append('pattern')\n .each(function() {\n var el = d3.select(this);\n\n el.attr({\n id: fullID,\n width: width + 'px',\n height: height + 'px',\n patternUnits: 'userSpaceOnUse',\n // for legends scale down patterns just a bit so that default size (i.e 8) nicely fit in small icons\n patternTransform: isLegend ? 'scale(0.8)' : ''\n });\n\n if(bgcolor) {\n var bgC = tinycolor(bgcolor);\n var bgRGB = Color.tinyRGB(bgC);\n var bgAlpha = bgC.getAlpha();\n\n var rects = el.selectAll('rect').data([0]);\n rects.exit().remove();\n rects.enter()\n .append('rect')\n .attr({\n width: width + 'px',\n height: height + 'px',\n fill: bgRGB,\n 'fill-opacity': bgAlpha,\n });\n }\n\n var patterns = el.selectAll(patternTag).data([0]);\n patterns.exit().remove();\n patterns.enter()\n .append(patternTag)\n .attr(patternAttrs);\n });\n\n sel.style('fill', getFullUrl(fullID, gd))\n .style('fill-opacity', null);\n\n sel.classed('pattern_filled', true);\n};\n\n/*\n * Make the gradients container and clear out any previous gradients.\n * We never collect all the gradients we need in one place,\n * so we can't ever remove gradients that have stopped being useful,\n * except all at once before a full redraw.\n * The upside of this is arbitrary points can share gradient defs\n */\ndrawing.initGradients = function(gd) {\n var fullLayout = gd._fullLayout;\n\n var gradientsGroup = Lib.ensureSingle(fullLayout._defs, 'g', 'gradients');\n gradientsGroup.selectAll('linearGradient,radialGradient').remove();\n\n d3.select(gd).selectAll('.gradient_filled').classed('gradient_filled', false);\n};\n\ndrawing.initPatterns = function(gd) {\n var fullLayout = gd._fullLayout;\n\n var patternsGroup = Lib.ensureSingle(fullLayout._defs, 'g', 'patterns');\n patternsGroup.selectAll('pattern').remove();\n\n d3.select(gd).selectAll('.pattern_filled').classed('pattern_filled', false);\n};\n\ndrawing.getPatternAttr = function(mp, i, dflt) {\n if(mp && Lib.isArrayOrTypedArray(mp)) {\n return i < mp.length ? mp[i] : dflt;\n }\n return mp;\n};\n\ndrawing.pointStyle = function(s, trace, gd, pt) {\n if(!s.size()) return;\n\n var fns = drawing.makePointStyleFns(trace);\n\n s.each(function(d) {\n drawing.singlePointStyle(d, d3.select(this), trace, fns, gd, pt);\n });\n};\n\ndrawing.singlePointStyle = function(d, sel, trace, fns, gd, pt) {\n var marker = trace.marker;\n var markerLine = marker.line;\n\n if(pt && pt.i >= 0 && d.i === undefined) d.i = pt.i;\n\n sel.style('opacity',\n fns.selectedOpacityFn ? fns.selectedOpacityFn(d) :\n (d.mo === undefined ? marker.opacity : d.mo)\n );\n\n if(fns.ms2mrc) {\n var r;\n\n // handle multi-trace graph edit case\n if(d.ms === 'various' || marker.size === 'various') {\n r = 3;\n } else {\n r = fns.ms2mrc(d.ms);\n }\n\n // store the calculated size so hover can use it\n d.mrc = r;\n\n if(fns.selectedSizeFn) {\n r = d.mrc = fns.selectedSizeFn(d);\n }\n\n // turn the symbol into a sanitized number\n var x = drawing.symbolNumber(d.mx || marker.symbol) || 0;\n\n // save if this marker is open\n // because that impacts how to handle colors\n d.om = x % 200 >= 100;\n\n var angle = getMarkerAngle(d, trace);\n var standoff = getMarkerStandoff(d, trace);\n\n sel.attr('d', makePointPath(x, r, angle, standoff));\n }\n\n var perPointGradient = false;\n var fillColor, lineColor, lineWidth;\n\n // 'so' is suspected outliers, for box plots\n if(d.so) {\n lineWidth = markerLine.outlierwidth;\n lineColor = markerLine.outliercolor;\n fillColor = marker.outliercolor;\n } else {\n var markerLineWidth = (markerLine || {}).width;\n\n lineWidth = (\n d.mlw + 1 ||\n markerLineWidth + 1 ||\n // TODO: we need the latter for legends... can we get rid of it?\n (d.trace ? (d.trace.marker.line || {}).width : 0) + 1\n ) - 1 || 0;\n\n if('mlc' in d) lineColor = d.mlcc = fns.lineScale(d.mlc);\n // weird case: array wasn't long enough to apply to every point\n else if(Lib.isArrayOrTypedArray(markerLine.color)) lineColor = Color.defaultLine;\n else lineColor = markerLine.color;\n\n if(Lib.isArrayOrTypedArray(marker.color)) {\n fillColor = Color.defaultLine;\n perPointGradient = true;\n }\n\n if('mc' in d) {\n fillColor = d.mcc = fns.markerScale(d.mc);\n } else {\n fillColor = marker.color || marker.colors || 'rgba(0,0,0,0)';\n }\n\n if(fns.selectedColorFn) {\n fillColor = fns.selectedColorFn(d);\n }\n }\n\n if(d.om) {\n // open markers can't have zero linewidth, default to 1px,\n // and use fill color as stroke color\n sel.call(Color.stroke, fillColor)\n .style({\n 'stroke-width': (lineWidth || 1) + 'px',\n fill: 'none'\n });\n } else {\n sel.style('stroke-width', (d.isBlank ? 0 : lineWidth) + 'px');\n\n var markerGradient = marker.gradient;\n\n var gradientType = d.mgt;\n if(gradientType) perPointGradient = true;\n else gradientType = markerGradient && markerGradient.type;\n\n // for legend - arrays will propagate through here, but we don't need\n // to treat it as per-point.\n if(Lib.isArrayOrTypedArray(gradientType)) {\n gradientType = gradientType[0];\n if(!gradientInfo[gradientType]) gradientType = 0;\n }\n\n var markerPattern = marker.pattern;\n var patternShape = markerPattern && drawing.getPatternAttr(markerPattern.shape, d.i, '');\n\n if(gradientType && gradientType !== 'none') {\n var gradientColor = d.mgc;\n if(gradientColor) perPointGradient = true;\n else gradientColor = markerGradient.color;\n\n var gradientID = trace.uid;\n if(perPointGradient) gradientID += '-' + d.i;\n\n drawing.gradient(sel, gd, gradientID, gradientType,\n [[0, gradientColor], [1, fillColor]], 'fill');\n } else if(patternShape) {\n var perPointPattern = false;\n var fgcolor = markerPattern.fgcolor;\n if(!fgcolor && pt && pt.color) {\n fgcolor = pt.color;\n perPointPattern = true;\n }\n var patternFGColor = drawing.getPatternAttr(fgcolor, d.i, (pt && pt.color) || null);\n\n var patternBGColor = drawing.getPatternAttr(markerPattern.bgcolor, d.i, null);\n var patternFGOpacity = markerPattern.fgopacity;\n var patternSize = drawing.getPatternAttr(markerPattern.size, d.i, 8);\n var patternSolidity = drawing.getPatternAttr(markerPattern.solidity, d.i, 0.3);\n perPointPattern = perPointPattern || d.mcc ||\n Lib.isArrayOrTypedArray(markerPattern.shape) ||\n Lib.isArrayOrTypedArray(markerPattern.bgcolor) ||\n Lib.isArrayOrTypedArray(markerPattern.fgcolor) ||\n Lib.isArrayOrTypedArray(markerPattern.size) ||\n Lib.isArrayOrTypedArray(markerPattern.solidity);\n\n var patternID = trace.uid;\n if(perPointPattern) patternID += '-' + d.i;\n\n drawing.pattern(\n sel, 'point', gd, patternID,\n patternShape, patternSize, patternSolidity,\n d.mcc, markerPattern.fillmode,\n patternBGColor, patternFGColor, patternFGOpacity\n );\n } else {\n Lib.isArrayOrTypedArray(fillColor) ? Color.fill(sel, fillColor[d.i]) : Color.fill(sel, fillColor);\n }\n\n if(lineWidth) {\n Color.stroke(sel, lineColor);\n }\n }\n};\n\ndrawing.makePointStyleFns = function(trace) {\n var out = {};\n var marker = trace.marker;\n\n // allow array marker and marker line colors to be\n // scaled by given max and min to colorscales\n out.markerScale = drawing.tryColorscale(marker, '');\n out.lineScale = drawing.tryColorscale(marker, 'line');\n\n if(Registry.traceIs(trace, 'symbols')) {\n out.ms2mrc = subTypes.isBubble(trace) ?\n makeBubbleSizeFn(trace) :\n function() { return (marker.size || 6) / 2; };\n }\n\n if(trace.selectedpoints) {\n Lib.extendFlat(out, drawing.makeSelectedPointStyleFns(trace));\n }\n\n return out;\n};\n\ndrawing.makeSelectedPointStyleFns = function(trace) {\n var out = {};\n\n var selectedAttrs = trace.selected || {};\n var unselectedAttrs = trace.unselected || {};\n\n var marker = trace.marker || {};\n var selectedMarker = selectedAttrs.marker || {};\n var unselectedMarker = unselectedAttrs.marker || {};\n\n var mo = marker.opacity;\n var smo = selectedMarker.opacity;\n var usmo = unselectedMarker.opacity;\n var smoIsDefined = smo !== undefined;\n var usmoIsDefined = usmo !== undefined;\n\n if(Lib.isArrayOrTypedArray(mo) || smoIsDefined || usmoIsDefined) {\n out.selectedOpacityFn = function(d) {\n var base = d.mo === undefined ? marker.opacity : d.mo;\n\n if(d.selected) {\n return smoIsDefined ? smo : base;\n } else {\n return usmoIsDefined ? usmo : DESELECTDIM * base;\n }\n };\n }\n\n var mc = marker.color;\n var smc = selectedMarker.color;\n var usmc = unselectedMarker.color;\n\n if(smc || usmc) {\n out.selectedColorFn = function(d) {\n var base = d.mcc || mc;\n\n if(d.selected) {\n return smc || base;\n } else {\n return usmc || base;\n }\n };\n }\n\n var ms = marker.size;\n var sms = selectedMarker.size;\n var usms = unselectedMarker.size;\n var smsIsDefined = sms !== undefined;\n var usmsIsDefined = usms !== undefined;\n\n if(Registry.traceIs(trace, 'symbols') && (smsIsDefined || usmsIsDefined)) {\n out.selectedSizeFn = function(d) {\n var base = d.mrc || ms / 2;\n\n if(d.selected) {\n return smsIsDefined ? sms / 2 : base;\n } else {\n return usmsIsDefined ? usms / 2 : base;\n }\n };\n }\n\n return out;\n};\n\ndrawing.makeSelectedTextStyleFns = function(trace) {\n var out = {};\n\n var selectedAttrs = trace.selected || {};\n var unselectedAttrs = trace.unselected || {};\n\n var textFont = trace.textfont || {};\n var selectedTextFont = selectedAttrs.textfont || {};\n var unselectedTextFont = unselectedAttrs.textfont || {};\n\n var tc = textFont.color;\n var stc = selectedTextFont.color;\n var utc = unselectedTextFont.color;\n\n out.selectedTextColorFn = function(d) {\n var base = d.tc || tc;\n\n if(d.selected) {\n return stc || base;\n } else {\n if(utc) return utc;\n else return stc ? base : Color.addOpacity(base, DESELECTDIM);\n }\n };\n\n return out;\n};\n\ndrawing.selectedPointStyle = function(s, trace) {\n if(!s.size() || !trace.selectedpoints) return;\n\n var fns = drawing.makeSelectedPointStyleFns(trace);\n var marker = trace.marker || {};\n var seq = [];\n\n if(fns.selectedOpacityFn) {\n seq.push(function(pt, d) {\n pt.style('opacity', fns.selectedOpacityFn(d));\n });\n }\n\n if(fns.selectedColorFn) {\n seq.push(function(pt, d) {\n Color.fill(pt, fns.selectedColorFn(d));\n });\n }\n\n if(fns.selectedSizeFn) {\n seq.push(function(pt, d) {\n var mx = d.mx || marker.symbol || 0;\n var mrc2 = fns.selectedSizeFn(d);\n\n pt.attr('d', makePointPath(drawing.symbolNumber(mx), mrc2, getMarkerAngle(d, trace), getMarkerStandoff(d, trace)));\n\n // save for Drawing.selectedTextStyle\n d.mrc2 = mrc2;\n });\n }\n\n if(seq.length) {\n s.each(function(d) {\n var pt = d3.select(this);\n for(var i = 0; i < seq.length; i++) {\n seq[i](pt, d);\n }\n });\n }\n};\n\ndrawing.tryColorscale = function(marker, prefix) {\n var cont = prefix ? Lib.nestedProperty(marker, prefix).get() : marker;\n\n if(cont) {\n var colorArray = cont.color;\n if((cont.colorscale || cont._colorAx) && Lib.isArrayOrTypedArray(colorArray)) {\n return Colorscale.makeColorScaleFuncFromTrace(cont);\n }\n }\n return Lib.identity;\n};\n\nvar TEXTOFFSETSIGN = {\n start: 1, end: -1, middle: 0, bottom: 1, top: -1\n};\n\nfunction textPointPosition(s, textPosition, fontSize, markerRadius, dontTouchParent) {\n var group = d3.select(s.node().parentNode);\n\n var v = textPosition.indexOf('top') !== -1 ?\n 'top' :\n textPosition.indexOf('bottom') !== -1 ? 'bottom' : 'middle';\n var h = textPosition.indexOf('left') !== -1 ?\n 'end' :\n textPosition.indexOf('right') !== -1 ? 'start' : 'middle';\n\n // if markers are shown, offset a little more than\n // the nominal marker size\n // ie 2/1.6 * nominal, bcs some markers are a bit bigger\n var r = markerRadius ? markerRadius / 0.8 + 1 : 0;\n\n var numLines = (svgTextUtils.lineCount(s) - 1) * LINE_SPACING + 1;\n var dx = TEXTOFFSETSIGN[h] * r;\n var dy = fontSize * 0.75 + TEXTOFFSETSIGN[v] * r +\n (TEXTOFFSETSIGN[v] - 1) * numLines * fontSize / 2;\n\n // fix the overall text group position\n s.attr('text-anchor', h);\n if(!dontTouchParent) {\n group.attr('transform', strTranslate(dx, dy));\n }\n}\n\nfunction extracTextFontSize(d, trace) {\n var fontSize = d.ts || trace.textfont.size;\n return (isNumeric(fontSize) && fontSize > 0) ? fontSize : 0;\n}\n\n// draw text at points\ndrawing.textPointStyle = function(s, trace, gd) {\n if(!s.size()) return;\n\n var selectedTextColorFn;\n if(trace.selectedpoints) {\n var fns = drawing.makeSelectedTextStyleFns(trace);\n selectedTextColorFn = fns.selectedTextColorFn;\n }\n\n var texttemplate = trace.texttemplate;\n var fullLayout = gd._fullLayout;\n\n s.each(function(d) {\n var p = d3.select(this);\n\n var text = texttemplate ?\n Lib.extractOption(d, trace, 'txt', 'texttemplate') :\n Lib.extractOption(d, trace, 'tx', 'text');\n\n if(!text && text !== 0) {\n p.remove();\n return;\n }\n\n if(texttemplate) {\n var fn = trace._module.formatLabels;\n var labels = fn ? fn(d, trace, fullLayout) : {};\n var pointValues = {};\n appendArrayPointValue(pointValues, trace, d.i);\n var meta = trace._meta || {};\n text = Lib.texttemplateString(text, labels, fullLayout._d3locale, pointValues, d, meta);\n }\n\n var pos = d.tp || trace.textposition;\n var fontSize = extracTextFontSize(d, trace);\n var fontColor = selectedTextColorFn ?\n selectedTextColorFn(d) :\n (d.tc || trace.textfont.color);\n\n p.call(drawing.font, {\n family: d.tf || trace.textfont.family,\n weight: d.tw || trace.textfont.weight,\n style: d.ty || trace.textfont.style,\n variant: d.tv || trace.textfont.variant,\n textcase: d.tC || trace.textfont.textcase,\n lineposition: d.tE || trace.textfont.lineposition,\n shadow: d.tS || trace.textfont.shadow,\n size: fontSize,\n color: fontColor\n })\n .text(text)\n .call(svgTextUtils.convertToTspans, gd)\n .call(textPointPosition, pos, fontSize, d.mrc);\n });\n};\n\ndrawing.selectedTextStyle = function(s, trace) {\n if(!s.size() || !trace.selectedpoints) return;\n\n var fns = drawing.makeSelectedTextStyleFns(trace);\n\n s.each(function(d) {\n var tx = d3.select(this);\n var tc = fns.selectedTextColorFn(d);\n var tp = d.tp || trace.textposition;\n var fontSize = extracTextFontSize(d, trace);\n\n Color.fill(tx, tc);\n var dontTouchParent = Registry.traceIs(trace, 'bar-like');\n textPointPosition(tx, tp, fontSize, d.mrc2 || d.mrc, dontTouchParent);\n });\n};\n\n// generalized Catmull-Rom splines, per\n// http://www.cemyuksel.com/research/catmullrom_param/catmullrom.pdf\nvar CatmullRomExp = 0.5;\ndrawing.smoothopen = function(pts, smoothness) {\n if(pts.length < 3) { return 'M' + pts.join('L');}\n var path = 'M' + pts[0];\n var tangents = [];\n var i;\n for(i = 1; i < pts.length - 1; i++) {\n tangents.push(makeTangent(pts[i - 1], pts[i], pts[i + 1], smoothness));\n }\n path += 'Q' + tangents[0][0] + ' ' + pts[1];\n for(i = 2; i < pts.length - 1; i++) {\n path += 'C' + tangents[i - 2][1] + ' ' + tangents[i - 1][0] + ' ' + pts[i];\n }\n path += 'Q' + tangents[pts.length - 3][1] + ' ' + pts[pts.length - 1];\n return path;\n};\n\ndrawing.smoothclosed = function(pts, smoothness) {\n if(pts.length < 3) { return 'M' + pts.join('L') + 'Z'; }\n var path = 'M' + pts[0];\n var pLast = pts.length - 1;\n var tangents = [makeTangent(pts[pLast], pts[0], pts[1], smoothness)];\n var i;\n for(i = 1; i < pLast; i++) {\n tangents.push(makeTangent(pts[i - 1], pts[i], pts[i + 1], smoothness));\n }\n tangents.push(\n makeTangent(pts[pLast - 1], pts[pLast], pts[0], smoothness)\n );\n\n for(i = 1; i <= pLast; i++) {\n path += 'C' + tangents[i - 1][1] + ' ' + tangents[i][0] + ' ' + pts[i];\n }\n path += 'C' + tangents[pLast][1] + ' ' + tangents[0][0] + ' ' + pts[0] + 'Z';\n return path;\n};\n\nvar lastDrawnX, lastDrawnY;\n\nfunction roundEnd(pt, isY, isLastPoint) {\n if(isLastPoint) pt = applyBackoff(pt);\n\n return isY ? roundY(pt[1]) : roundX(pt[0]);\n}\n\nfunction roundX(p) {\n var v = d3.round(p, 2);\n lastDrawnX = v;\n return v;\n}\n\nfunction roundY(p) {\n var v = d3.round(p, 2);\n lastDrawnY = v;\n return v;\n}\n\nfunction makeTangent(prevpt, thispt, nextpt, smoothness) {\n var d1x = prevpt[0] - thispt[0];\n var d1y = prevpt[1] - thispt[1];\n var d2x = nextpt[0] - thispt[0];\n var d2y = nextpt[1] - thispt[1];\n var d1a = Math.pow(d1x * d1x + d1y * d1y, CatmullRomExp / 2);\n var d2a = Math.pow(d2x * d2x + d2y * d2y, CatmullRomExp / 2);\n var numx = (d2a * d2a * d1x - d1a * d1a * d2x) * smoothness;\n var numy = (d2a * d2a * d1y - d1a * d1a * d2y) * smoothness;\n var denom1 = 3 * d2a * (d1a + d2a);\n var denom2 = 3 * d1a * (d1a + d2a);\n return [\n [\n roundX(thispt[0] + (denom1 && numx / denom1)),\n roundY(thispt[1] + (denom1 && numy / denom1))\n ], [\n roundX(thispt[0] - (denom2 && numx / denom2)),\n roundY(thispt[1] - (denom2 && numy / denom2))\n ]\n ];\n}\n\n// step paths - returns a generator function for paths\n// with the given step shape\nvar STEPPATH = {\n hv: function(p0, p1, isLastPoint) {\n return 'H' +\n roundX(p1[0]) + 'V' +\n roundEnd(p1, 1, isLastPoint);\n },\n vh: function(p0, p1, isLastPoint) {\n return 'V' +\n roundY(p1[1]) + 'H' +\n roundEnd(p1, 0, isLastPoint);\n },\n hvh: function(p0, p1, isLastPoint) {\n return 'H' +\n roundX((p0[0] + p1[0]) / 2) + 'V' +\n roundY(p1[1]) + 'H' +\n roundEnd(p1, 0, isLastPoint);\n },\n vhv: function(p0, p1, isLastPoint) {\n return 'V' +\n roundY((p0[1] + p1[1]) / 2) + 'H' +\n roundX(p1[0]) + 'V' +\n roundEnd(p1, 1, isLastPoint);\n }\n};\nvar STEPLINEAR = function(p0, p1, isLastPoint) {\n return 'L' +\n roundEnd(p1, 0, isLastPoint) + ',' +\n roundEnd(p1, 1, isLastPoint);\n};\ndrawing.steps = function(shape) {\n var onestep = STEPPATH[shape] || STEPLINEAR;\n return function(pts) {\n var path = 'M' + roundX(pts[0][0]) + ',' + roundY(pts[0][1]);\n var len = pts.length;\n for(var i = 1; i < len; i++) {\n path += onestep(pts[i - 1], pts[i], i === len - 1);\n }\n return path;\n };\n};\n\nfunction applyBackoff(pt, start) {\n var backoff = pt.backoff;\n var trace = pt.trace;\n var d = pt.d;\n var i = pt.i;\n\n if(backoff && trace &&\n trace.marker &&\n trace.marker.angle % 360 === 0 &&\n trace.line &&\n trace.line.shape !== 'spline'\n ) {\n var arrayBackoff = Lib.isArrayOrTypedArray(backoff);\n var end = pt;\n\n var x1 = start ? start[0] : lastDrawnX || 0;\n var y1 = start ? start[1] : lastDrawnY || 0;\n\n var x2 = end[0];\n var y2 = end[1];\n\n var dx = x2 - x1;\n var dy = y2 - y1;\n\n var t = Math.atan2(dy, dx);\n\n var b = arrayBackoff ? backoff[i] : backoff;\n\n if(b === 'auto') {\n var endI = end.i;\n if(trace.type === 'scatter') endI--; // Why we need this hack?\n\n var endMarker = end.marker;\n var endMarkerSymbol = endMarker.symbol;\n if(Lib.isArrayOrTypedArray(endMarkerSymbol)) endMarkerSymbol = endMarkerSymbol[endI];\n\n var endMarkerSize = endMarker.size;\n if(Lib.isArrayOrTypedArray(endMarkerSize)) endMarkerSize = endMarkerSize[endI];\n\n b = endMarker ? drawing.symbolBackOffs[drawing.symbolNumber(endMarkerSymbol)] * endMarkerSize : 0;\n b += drawing.getMarkerStandoff(d[endI], trace) || 0;\n }\n\n var x = x2 - b * Math.cos(t);\n var y = y2 - b * Math.sin(t);\n\n if(\n ((x <= x2 && x >= x1) || (x >= x2 && x <= x1)) &&\n ((y <= y2 && y >= y1) || (y >= y2 && y <= y1))\n ) {\n pt = [x, y];\n }\n }\n\n return pt;\n}\n\ndrawing.applyBackoff = applyBackoff;\n\n// off-screen svg render testing element, shared by the whole page\n// uses the id 'js-plotly-tester' and stores it in drawing.tester\ndrawing.makeTester = function() {\n var tester = Lib.ensureSingleById(d3.select('body'), 'svg', 'js-plotly-tester', function(s) {\n s.attr(xmlnsNamespaces.svgAttrs)\n .style({\n position: 'absolute',\n left: '-10000px',\n top: '-10000px',\n width: '9000px',\n height: '9000px',\n 'z-index': '1'\n });\n });\n\n // browsers differ on how they describe the bounding rect of\n // the svg if its contents spill over... so make a 1x1px\n // reference point we can measure off of.\n var testref = Lib.ensureSingle(tester, 'path', 'js-reference-point', function(s) {\n s.attr('d', 'M0,0H1V1H0Z')\n .style({\n 'stroke-width': 0,\n fill: 'black'\n });\n });\n\n drawing.tester = tester;\n drawing.testref = testref;\n};\n\n/*\n * use our offscreen tester to get a clientRect for an element,\n * in a reference frame where it isn't translated (or transformed) and\n * its anchor point is at (0,0)\n * always returns a copy of the bbox, so the caller can modify it safely\n *\n * @param {SVGElement} node: the element to measure. If possible this should be\n * a or MathJax element that's already passed through\n * `convertToTspans` because in that case we can cache the results, but it's\n * possible to pass in any svg element.\n *\n * @param {boolean} inTester: is this element already in `drawing.tester`?\n * If you are measuring a dummy element, rather than one you really intend\n * to use on the plot, making it in `drawing.tester` in the first place\n * allows us to test faster because it cuts out cloning and appending it.\n *\n * @param {string} hash: for internal use only, if we already know the cache key\n * for this element beforehand.\n *\n * @return {object}: a plain object containing the width, height, left, right,\n * top, and bottom of `node`\n */\ndrawing.savedBBoxes = {};\nvar savedBBoxesCount = 0;\nvar maxSavedBBoxes = 10000;\n\ndrawing.bBox = function(node, inTester, hash) {\n /*\n * Cache elements we've already measured so we don't have to\n * remeasure the same thing many times\n * We have a few bBox callers though who pass a node larger than\n * a or a MathJax , such as an axis group containing many labels.\n * These will not generate a hash (unless we figure out an appropriate\n * hash key for them) and thus we will not hash them.\n */\n if(!hash) hash = nodeHash(node);\n var out;\n if(hash) {\n out = drawing.savedBBoxes[hash];\n if(out) return Lib.extendFlat({}, out);\n } else if(node.childNodes.length === 1) {\n /*\n * If we have only one child element, which is itself hashable, make\n * a new hash from this element plus its x,y,transform\n * These bounding boxes *include* x,y,transform - mostly for use by\n * callers trying to avoid overlaps (ie titles)\n */\n var innerNode = node.childNodes[0];\n\n hash = nodeHash(innerNode);\n if(hash) {\n var x = +innerNode.getAttribute('x') || 0;\n var y = +innerNode.getAttribute('y') || 0;\n var transform = innerNode.getAttribute('transform');\n\n if(!transform) {\n // in this case, just varying x and y, don't bother caching\n // the final bBox because the alteration is quick.\n var innerBB = drawing.bBox(innerNode, false, hash);\n if(x) {\n innerBB.left += x;\n innerBB.right += x;\n }\n if(y) {\n innerBB.top += y;\n innerBB.bottom += y;\n }\n return innerBB;\n }\n /*\n * else we have a transform - rather than make a complicated\n * (and error-prone and probably slow) transform parser/calculator,\n * just continue on calculating the boundingClientRect of the group\n * and use the new composite hash to cache it.\n * That said, `innerNode.transform.baseVal` is an array of\n * `SVGTransform` objects, that *do* seem to have a nice matrix\n * multiplication interface that we could use to avoid making\n * another getBoundingClientRect call...\n */\n hash += '~' + x + '~' + y + '~' + transform;\n\n out = drawing.savedBBoxes[hash];\n if(out) return Lib.extendFlat({}, out);\n }\n }\n var testNode, tester;\n if(inTester) {\n testNode = node;\n } else {\n tester = drawing.tester.node();\n\n // copy the node to test into the tester\n testNode = node.cloneNode(true);\n tester.appendChild(testNode);\n }\n\n // standardize its position (and newline tspans if any)\n d3.select(testNode)\n .attr('transform', null)\n .call(svgTextUtils.positionText, 0, 0);\n\n var testRect = testNode.getBoundingClientRect();\n var refRect = drawing.testref\n .node()\n .getBoundingClientRect();\n\n if(!inTester) tester.removeChild(testNode);\n\n var bb = {\n height: testRect.height,\n width: testRect.width,\n left: testRect.left - refRect.left,\n top: testRect.top - refRect.top,\n right: testRect.right - refRect.left,\n bottom: testRect.bottom - refRect.top\n };\n\n // make sure we don't have too many saved boxes,\n // or a long session could overload on memory\n // by saving boxes for long-gone elements\n if(savedBBoxesCount >= maxSavedBBoxes) {\n drawing.savedBBoxes = {};\n savedBBoxesCount = 0;\n }\n\n // cache this bbox\n if(hash) drawing.savedBBoxes[hash] = bb;\n savedBBoxesCount++;\n\n return Lib.extendFlat({}, bb);\n};\n\n// capture everything about a node (at least in our usage) that\n// impacts its bounding box, given that bBox clears x, y, and transform\nfunction nodeHash(node) {\n var inputText = node.getAttribute('data-unformatted');\n if(inputText === null) return;\n return inputText +\n node.getAttribute('data-math') +\n node.getAttribute('text-anchor') +\n node.getAttribute('style');\n}\n\n/**\n * Set clipPath URL in a way that work for all situations.\n *\n * In details, graphs on pages with HTML tags need to prepend\n * the clip path ids with the page's base url EXCEPT during toImage exports.\n *\n * @param {d3 selection} s : node to add clip-path attribute\n * @param {string} localId : local clip-path (w/o base url) id\n * @param {DOM element || object} gd\n * - context._baseUrl {string}\n * - context._exportedPlot {boolean}\n */\ndrawing.setClipUrl = function(s, localId, gd) {\n s.attr('clip-path', getFullUrl(localId, gd));\n};\n\nfunction getFullUrl(localId, gd) {\n if(!localId) return null;\n\n var context = gd._context;\n var baseUrl = context._exportedPlot ? '' : (context._baseUrl || '');\n return baseUrl ?\n 'url(\\'' + baseUrl + '#' + localId + '\\')' :\n 'url(#' + localId + ')';\n}\n\ndrawing.getTranslate = function(element) {\n // Note the separator [^\\d] between x and y in this regex\n // We generally use ',' but IE will convert it to ' '\n var re = /.*\\btranslate\\((-?\\d*\\.?\\d*)[^-\\d]*(-?\\d*\\.?\\d*)[^\\d].*/;\n var getter = element.attr ? 'attr' : 'getAttribute';\n var transform = element[getter]('transform') || '';\n\n var translate = transform.replace(re, function(match, p1, p2) {\n return [p1, p2].join(' ');\n })\n .split(' ');\n\n return {\n x: +translate[0] || 0,\n y: +translate[1] || 0\n };\n};\n\ndrawing.setTranslate = function(element, x, y) {\n var re = /(\\btranslate\\(.*?\\);?)/;\n var getter = element.attr ? 'attr' : 'getAttribute';\n var setter = element.attr ? 'attr' : 'setAttribute';\n var transform = element[getter]('transform') || '';\n\n x = x || 0;\n y = y || 0;\n\n transform = transform.replace(re, '').trim();\n transform += strTranslate(x, y);\n transform = transform.trim();\n\n element[setter]('transform', transform);\n\n return transform;\n};\n\ndrawing.getScale = function(element) {\n var re = /.*\\bscale\\((\\d*\\.?\\d*)[^\\d]*(\\d*\\.?\\d*)[^\\d].*/;\n var getter = element.attr ? 'attr' : 'getAttribute';\n var transform = element[getter]('transform') || '';\n\n var translate = transform.replace(re, function(match, p1, p2) {\n return [p1, p2].join(' ');\n })\n .split(' ');\n\n return {\n x: +translate[0] || 1,\n y: +translate[1] || 1\n };\n};\n\ndrawing.setScale = function(element, x, y) {\n var re = /(\\bscale\\(.*?\\);?)/;\n var getter = element.attr ? 'attr' : 'getAttribute';\n var setter = element.attr ? 'attr' : 'setAttribute';\n var transform = element[getter]('transform') || '';\n\n x = x || 1;\n y = y || 1;\n\n transform = transform.replace(re, '').trim();\n transform += 'scale(' + x + ',' + y + ')';\n transform = transform.trim();\n\n element[setter]('transform', transform);\n\n return transform;\n};\n\nvar SCALE_RE = /\\s*sc.*/;\n\ndrawing.setPointGroupScale = function(selection, xScale, yScale) {\n xScale = xScale || 1;\n yScale = yScale || 1;\n\n if(!selection) return;\n\n // The same scale transform for every point:\n var scale = (xScale === 1 && yScale === 1) ?\n '' :\n 'scale(' + xScale + ',' + yScale + ')';\n\n selection.each(function() {\n var t = (this.getAttribute('transform') || '').replace(SCALE_RE, '');\n t += scale;\n t = t.trim();\n this.setAttribute('transform', t);\n });\n};\n\nvar TEXT_POINT_LAST_TRANSLATION_RE = /translate\\([^)]*\\)\\s*$/;\n\ndrawing.setTextPointsScale = function(selection, xScale, yScale) {\n if(!selection) return;\n\n selection.each(function() {\n var transforms;\n var el = d3.select(this);\n var text = el.select('text');\n\n if(!text.node()) return;\n\n var x = parseFloat(text.attr('x') || 0);\n var y = parseFloat(text.attr('y') || 0);\n\n var existingTransform = (el.attr('transform') || '').match(TEXT_POINT_LAST_TRANSLATION_RE);\n\n if(xScale === 1 && yScale === 1) {\n transforms = [];\n } else {\n transforms = [\n strTranslate(x, y),\n 'scale(' + xScale + ',' + yScale + ')',\n strTranslate(-x, -y),\n ];\n }\n\n if(existingTransform) {\n transforms.push(existingTransform);\n }\n\n el.attr('transform', transforms.join(''));\n });\n};\n\nfunction getMarkerStandoff(d, trace) {\n var standoff;\n\n if(d) standoff = d.mf;\n\n if(standoff === undefined) {\n standoff = trace.marker ? trace.marker.standoff || 0 : 0;\n }\n\n if(!trace._geo && !trace._xA) {\n // case of legends\n return -standoff;\n }\n\n return standoff;\n}\n\ndrawing.getMarkerStandoff = getMarkerStandoff;\n\nvar atan2 = Math.atan2;\nvar cos = Math.cos;\nvar sin = Math.sin;\n\nfunction rotate(t, xy) {\n var x = xy[0];\n var y = xy[1];\n return [\n x * cos(t) - y * sin(t),\n x * sin(t) + y * cos(t)\n ];\n}\n\nvar previousLon;\nvar previousLat;\nvar previousX;\nvar previousY;\nvar previousI;\nvar previousTraceUid;\n\nfunction getMarkerAngle(d, trace) {\n var angle = d.ma;\n\n if(angle === undefined) {\n angle = trace.marker.angle;\n if(!angle || Lib.isArrayOrTypedArray(angle)) {\n angle = 0;\n }\n }\n\n var x, y;\n var ref = trace.marker.angleref;\n if(ref === 'previous' || ref === 'north') {\n if(trace._geo) {\n var p = trace._geo.project(d.lonlat);\n x = p[0];\n y = p[1];\n } else {\n var xa = trace._xA;\n var ya = trace._yA;\n if(xa && ya) {\n x = xa.c2p(d.x);\n y = ya.c2p(d.y);\n } else {\n // case of legends\n return 90;\n }\n }\n\n if(trace._geo) {\n var lon = d.lonlat[0];\n var lat = d.lonlat[1];\n\n var north = trace._geo.project([\n lon,\n lat + 1e-5 // epsilon\n ]);\n\n var east = trace._geo.project([\n lon + 1e-5, // epsilon\n lat\n ]);\n\n var u = atan2(\n east[1] - y,\n east[0] - x\n );\n\n var v = atan2(\n north[1] - y,\n north[0] - x\n );\n\n var t;\n if(ref === 'north') {\n t = angle / 180 * Math.PI;\n // To use counter-clockwise angles i.e.\n // East: 90, West: -90\n // to facilitate wind visualisations\n // in future we should use t = -t here.\n } else if(ref === 'previous') {\n var lon1 = lon / 180 * Math.PI;\n var lat1 = lat / 180 * Math.PI;\n var lon2 = previousLon / 180 * Math.PI;\n var lat2 = previousLat / 180 * Math.PI;\n\n var dLon = lon2 - lon1;\n\n var deltaY = cos(lat2) * sin(dLon);\n var deltaX = sin(lat2) * cos(lat1) - cos(lat2) * sin(lat1) * cos(dLon);\n\n t = -atan2(\n deltaY,\n deltaX\n ) - Math.PI;\n\n previousLon = lon;\n previousLat = lat;\n }\n\n var A = rotate(u, [cos(t), 0]);\n var B = rotate(v, [sin(t), 0]);\n\n angle = atan2(\n A[1] + B[1],\n A[0] + B[0]\n ) / Math.PI * 180;\n\n if(ref === 'previous' && !(\n previousTraceUid === trace.uid &&\n d.i === previousI + 1\n )) {\n angle = null;\n }\n }\n\n if(ref === 'previous' && !trace._geo) {\n if(\n previousTraceUid === trace.uid &&\n d.i === previousI + 1 &&\n isNumeric(x) &&\n isNumeric(y)\n ) {\n var dX = x - previousX;\n var dY = y - previousY;\n\n var shape = trace.line ? trace.line.shape || '' : '';\n\n var lastShapeChar = shape.slice(shape.length - 1);\n if(lastShapeChar === 'h') dY = 0;\n if(lastShapeChar === 'v') dX = 0;\n\n angle += atan2(dY, dX) / Math.PI * 180 + 90;\n } else {\n angle = null;\n }\n }\n }\n\n previousX = x;\n previousY = y;\n previousI = d.i;\n previousTraceUid = trace.uid;\n\n return angle;\n}\n\ndrawing.getMarkerAngle = getMarkerAngle;\n","'use strict';\n\nvar parseSvgPath = require('parse-svg-path');\nvar round = require('@plotly/d3').round;\n\n/** Marker symbol definitions\n * users can specify markers either by number or name\n * add 100 (or '-open') and you get an open marker\n * open markers have no fill and use line color as the stroke color\n * add 200 (or '-dot') and you get a dot in the middle\n * add both and you get both\n */\n\n\nvar emptyPath = 'M0,0Z';\nvar sqrt2 = Math.sqrt(2);\nvar sqrt3 = Math.sqrt(3);\nvar PI = Math.PI;\nvar cos = Math.cos;\nvar sin = Math.sin;\n\nmodule.exports = {\n circle: {\n n: 0,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rs = round(r, 2);\n var circle = 'M' + rs + ',0A' + rs + ',' + rs + ' 0 1,1 0,-' + rs + 'A' + rs + ',' + rs + ' 0 0,1 ' + rs + ',0Z';\n return standoff ? align(angle, standoff, circle) : circle;\n }\n },\n square: {\n n: 1,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rs = round(r, 2);\n return align(angle, standoff, 'M' + rs + ',' + rs + 'H-' + rs + 'V-' + rs + 'H' + rs + 'Z');\n }\n },\n diamond: {\n n: 2,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rd = round(r * 1.3, 2);\n return align(angle, standoff, 'M' + rd + ',0L0,' + rd + 'L-' + rd + ',0L0,-' + rd + 'Z');\n }\n },\n cross: {\n n: 3,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rc = round(r * 0.4, 2);\n var rc2 = round(r * 1.2, 2);\n return align(angle, standoff, 'M' + rc2 + ',' + rc + 'H' + rc + 'V' + rc2 + 'H-' + rc +\n 'V' + rc + 'H-' + rc2 + 'V-' + rc + 'H-' + rc + 'V-' + rc2 +\n 'H' + rc + 'V-' + rc + 'H' + rc2 + 'Z');\n }\n },\n x: {\n n: 4,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rx = round(r * 0.8 / sqrt2, 2);\n var ne = 'l' + rx + ',' + rx;\n var se = 'l' + rx + ',-' + rx;\n var sw = 'l-' + rx + ',-' + rx;\n var nw = 'l-' + rx + ',' + rx;\n return align(angle, standoff, 'M0,' + rx + ne + se + sw + se + sw + nw + sw + nw + ne + nw + ne + 'Z');\n }\n },\n 'triangle-up': {\n n: 5,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rt = round(r * 2 / sqrt3, 2);\n var r2 = round(r / 2, 2);\n var rs = round(r, 2);\n return align(angle, standoff, 'M-' + rt + ',' + r2 + 'H' + rt + 'L0,-' + rs + 'Z');\n }\n },\n 'triangle-down': {\n n: 6,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rt = round(r * 2 / sqrt3, 2);\n var r2 = round(r / 2, 2);\n var rs = round(r, 2);\n return align(angle, standoff, 'M-' + rt + ',-' + r2 + 'H' + rt + 'L0,' + rs + 'Z');\n }\n },\n 'triangle-left': {\n n: 7,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rt = round(r * 2 / sqrt3, 2);\n var r2 = round(r / 2, 2);\n var rs = round(r, 2);\n return align(angle, standoff, 'M' + r2 + ',-' + rt + 'V' + rt + 'L-' + rs + ',0Z');\n }\n },\n 'triangle-right': {\n n: 8,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rt = round(r * 2 / sqrt3, 2);\n var r2 = round(r / 2, 2);\n var rs = round(r, 2);\n return align(angle, standoff, 'M-' + r2 + ',-' + rt + 'V' + rt + 'L' + rs + ',0Z');\n }\n },\n 'triangle-ne': {\n n: 9,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var r1 = round(r * 0.6, 2);\n var r2 = round(r * 1.2, 2);\n return align(angle, standoff, 'M-' + r2 + ',-' + r1 + 'H' + r1 + 'V' + r2 + 'Z');\n }\n },\n 'triangle-se': {\n n: 10,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var r1 = round(r * 0.6, 2);\n var r2 = round(r * 1.2, 2);\n return align(angle, standoff, 'M' + r1 + ',-' + r2 + 'V' + r1 + 'H-' + r2 + 'Z');\n }\n },\n 'triangle-sw': {\n n: 11,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var r1 = round(r * 0.6, 2);\n var r2 = round(r * 1.2, 2);\n return align(angle, standoff, 'M' + r2 + ',' + r1 + 'H-' + r1 + 'V-' + r2 + 'Z');\n }\n },\n 'triangle-nw': {\n n: 12,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var r1 = round(r * 0.6, 2);\n var r2 = round(r * 1.2, 2);\n return align(angle, standoff, 'M-' + r1 + ',' + r2 + 'V-' + r1 + 'H' + r2 + 'Z');\n }\n },\n pentagon: {\n n: 13,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var x1 = round(r * 0.951, 2);\n var x2 = round(r * 0.588, 2);\n var y0 = round(-r, 2);\n var y1 = round(r * -0.309, 2);\n var y2 = round(r * 0.809, 2);\n return align(angle, standoff, 'M' + x1 + ',' + y1 + 'L' + x2 + ',' + y2 + 'H-' + x2 +\n 'L-' + x1 + ',' + y1 + 'L0,' + y0 + 'Z');\n }\n },\n hexagon: {\n n: 14,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var y0 = round(r, 2);\n var y1 = round(r / 2, 2);\n var x = round(r * sqrt3 / 2, 2);\n return align(angle, standoff, 'M' + x + ',-' + y1 + 'V' + y1 + 'L0,' + y0 +\n 'L-' + x + ',' + y1 + 'V-' + y1 + 'L0,-' + y0 + 'Z');\n }\n },\n hexagon2: {\n n: 15,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var x0 = round(r, 2);\n var x1 = round(r / 2, 2);\n var y = round(r * sqrt3 / 2, 2);\n return align(angle, standoff, 'M-' + x1 + ',' + y + 'H' + x1 + 'L' + x0 +\n ',0L' + x1 + ',-' + y + 'H-' + x1 + 'L-' + x0 + ',0Z');\n }\n },\n octagon: {\n n: 16,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var a = round(r * 0.924, 2);\n var b = round(r * 0.383, 2);\n return align(angle, standoff, 'M-' + b + ',-' + a + 'H' + b + 'L' + a + ',-' + b + 'V' + b +\n 'L' + b + ',' + a + 'H-' + b + 'L-' + a + ',' + b + 'V-' + b + 'Z');\n }\n },\n star: {\n n: 17,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rs = r * 1.4;\n var x1 = round(rs * 0.225, 2);\n var x2 = round(rs * 0.951, 2);\n var x3 = round(rs * 0.363, 2);\n var x4 = round(rs * 0.588, 2);\n var y0 = round(-rs, 2);\n var y1 = round(rs * -0.309, 2);\n var y3 = round(rs * 0.118, 2);\n var y4 = round(rs * 0.809, 2);\n var y5 = round(rs * 0.382, 2);\n return align(angle, standoff, 'M' + x1 + ',' + y1 + 'H' + x2 + 'L' + x3 + ',' + y3 +\n 'L' + x4 + ',' + y4 + 'L0,' + y5 + 'L-' + x4 + ',' + y4 +\n 'L-' + x3 + ',' + y3 + 'L-' + x2 + ',' + y1 + 'H-' + x1 +\n 'L0,' + y0 + 'Z');\n }\n },\n hexagram: {\n n: 18,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var y = round(r * 0.66, 2);\n var x1 = round(r * 0.38, 2);\n var x2 = round(r * 0.76, 2);\n return align(angle, standoff, 'M-' + x2 + ',0l-' + x1 + ',-' + y + 'h' + x2 +\n 'l' + x1 + ',-' + y + 'l' + x1 + ',' + y + 'h' + x2 +\n 'l-' + x1 + ',' + y + 'l' + x1 + ',' + y + 'h-' + x2 +\n 'l-' + x1 + ',' + y + 'l-' + x1 + ',-' + y + 'h-' + x2 + 'Z');\n }\n },\n 'star-triangle-up': {\n n: 19,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var x = round(r * sqrt3 * 0.8, 2);\n var y1 = round(r * 0.8, 2);\n var y2 = round(r * 1.6, 2);\n var rc = round(r * 4, 2);\n var aPart = 'A ' + rc + ',' + rc + ' 0 0 1 ';\n return align(angle, standoff, 'M-' + x + ',' + y1 + aPart + x + ',' + y1 +\n aPart + '0,-' + y2 + aPart + '-' + x + ',' + y1 + 'Z');\n }\n },\n 'star-triangle-down': {\n n: 20,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var x = round(r * sqrt3 * 0.8, 2);\n var y1 = round(r * 0.8, 2);\n var y2 = round(r * 1.6, 2);\n var rc = round(r * 4, 2);\n var aPart = 'A ' + rc + ',' + rc + ' 0 0 1 ';\n return align(angle, standoff, 'M' + x + ',-' + y1 + aPart + '-' + x + ',-' + y1 +\n aPart + '0,' + y2 + aPart + x + ',-' + y1 + 'Z');\n }\n },\n 'star-square': {\n n: 21,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rp = round(r * 1.1, 2);\n var rc = round(r * 2, 2);\n var aPart = 'A ' + rc + ',' + rc + ' 0 0 1 ';\n return align(angle, standoff, 'M-' + rp + ',-' + rp + aPart + '-' + rp + ',' + rp +\n aPart + rp + ',' + rp + aPart + rp + ',-' + rp +\n aPart + '-' + rp + ',-' + rp + 'Z');\n }\n },\n 'star-diamond': {\n n: 22,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rp = round(r * 1.4, 2);\n var rc = round(r * 1.9, 2);\n var aPart = 'A ' + rc + ',' + rc + ' 0 0 1 ';\n return align(angle, standoff, 'M-' + rp + ',0' + aPart + '0,' + rp +\n aPart + rp + ',0' + aPart + '0,-' + rp +\n aPart + '-' + rp + ',0' + 'Z');\n }\n },\n 'diamond-tall': {\n n: 23,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var x = round(r * 0.7, 2);\n var y = round(r * 1.4, 2);\n return align(angle, standoff, 'M0,' + y + 'L' + x + ',0L0,-' + y + 'L-' + x + ',0Z');\n }\n },\n 'diamond-wide': {\n n: 24,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var x = round(r * 1.4, 2);\n var y = round(r * 0.7, 2);\n return align(angle, standoff, 'M0,' + y + 'L' + x + ',0L0,-' + y + 'L-' + x + ',0Z');\n }\n },\n hourglass: {\n n: 25,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rs = round(r, 2);\n return align(angle, standoff, 'M' + rs + ',' + rs + 'H-' + rs + 'L' + rs + ',-' + rs + 'H-' + rs + 'Z');\n },\n noDot: true\n },\n bowtie: {\n n: 26,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rs = round(r, 2);\n return align(angle, standoff, 'M' + rs + ',' + rs + 'V-' + rs + 'L-' + rs + ',' + rs + 'V-' + rs + 'Z');\n },\n noDot: true\n },\n 'circle-cross': {\n n: 27,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rs = round(r, 2);\n return align(angle, standoff, 'M0,' + rs + 'V-' + rs + 'M' + rs + ',0H-' + rs +\n 'M' + rs + ',0A' + rs + ',' + rs + ' 0 1,1 0,-' + rs +\n 'A' + rs + ',' + rs + ' 0 0,1 ' + rs + ',0Z');\n },\n needLine: true,\n noDot: true\n },\n 'circle-x': {\n n: 28,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rs = round(r, 2);\n var rc = round(r / sqrt2, 2);\n return align(angle, standoff, 'M' + rc + ',' + rc + 'L-' + rc + ',-' + rc +\n 'M' + rc + ',-' + rc + 'L-' + rc + ',' + rc +\n 'M' + rs + ',0A' + rs + ',' + rs + ' 0 1,1 0,-' + rs +\n 'A' + rs + ',' + rs + ' 0 0,1 ' + rs + ',0Z');\n },\n needLine: true,\n noDot: true\n },\n 'square-cross': {\n n: 29,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rs = round(r, 2);\n return align(angle, standoff, 'M0,' + rs + 'V-' + rs + 'M' + rs + ',0H-' + rs +\n 'M' + rs + ',' + rs + 'H-' + rs + 'V-' + rs + 'H' + rs + 'Z');\n },\n needLine: true,\n noDot: true\n },\n 'square-x': {\n n: 30,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rs = round(r, 2);\n return align(angle, standoff, 'M' + rs + ',' + rs + 'L-' + rs + ',-' + rs +\n 'M' + rs + ',-' + rs + 'L-' + rs + ',' + rs +\n 'M' + rs + ',' + rs + 'H-' + rs + 'V-' + rs + 'H' + rs + 'Z');\n },\n needLine: true,\n noDot: true\n },\n 'diamond-cross': {\n n: 31,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rd = round(r * 1.3, 2);\n return align(angle, standoff, 'M' + rd + ',0L0,' + rd + 'L-' + rd + ',0L0,-' + rd + 'Z' +\n 'M0,-' + rd + 'V' + rd + 'M-' + rd + ',0H' + rd);\n },\n needLine: true,\n noDot: true\n },\n 'diamond-x': {\n n: 32,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rd = round(r * 1.3, 2);\n var r2 = round(r * 0.65, 2);\n return align(angle, standoff, 'M' + rd + ',0L0,' + rd + 'L-' + rd + ',0L0,-' + rd + 'Z' +\n 'M-' + r2 + ',-' + r2 + 'L' + r2 + ',' + r2 +\n 'M-' + r2 + ',' + r2 + 'L' + r2 + ',-' + r2);\n },\n needLine: true,\n noDot: true\n },\n 'cross-thin': {\n n: 33,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rc = round(r * 1.4, 2);\n return align(angle, standoff, 'M0,' + rc + 'V-' + rc + 'M' + rc + ',0H-' + rc);\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'x-thin': {\n n: 34,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rx = round(r, 2);\n return align(angle, standoff, 'M' + rx + ',' + rx + 'L-' + rx + ',-' + rx +\n 'M' + rx + ',-' + rx + 'L-' + rx + ',' + rx);\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n asterisk: {\n n: 35,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rc = round(r * 1.2, 2);\n var rs = round(r * 0.85, 2);\n return align(angle, standoff, 'M0,' + rc + 'V-' + rc + 'M' + rc + ',0H-' + rc +\n 'M' + rs + ',' + rs + 'L-' + rs + ',-' + rs +\n 'M' + rs + ',-' + rs + 'L-' + rs + ',' + rs);\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n hash: {\n n: 36,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var r1 = round(r / 2, 2);\n var r2 = round(r, 2);\n\n return align(angle, standoff, 'M' + r1 + ',' + r2 + 'V-' + r2 +\n 'M' + (r1 - r2) + ',-' + r2 + 'V' + r2 +\n 'M' + r2 + ',' + r1 + 'H-' + r2 +\n 'M-' + r2 + ',' + (r1 - r2) + 'H' + r2);\n },\n needLine: true,\n noFill: true\n },\n 'y-up': {\n n: 37,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var x = round(r * 1.2, 2);\n var y0 = round(r * 1.6, 2);\n var y1 = round(r * 0.8, 2);\n return align(angle, standoff, 'M-' + x + ',' + y1 + 'L0,0M' + x + ',' + y1 + 'L0,0M0,-' + y0 + 'L0,0');\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'y-down': {\n n: 38,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var x = round(r * 1.2, 2);\n var y0 = round(r * 1.6, 2);\n var y1 = round(r * 0.8, 2);\n return align(angle, standoff, 'M-' + x + ',-' + y1 + 'L0,0M' + x + ',-' + y1 + 'L0,0M0,' + y0 + 'L0,0');\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'y-left': {\n n: 39,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var y = round(r * 1.2, 2);\n var x0 = round(r * 1.6, 2);\n var x1 = round(r * 0.8, 2);\n return align(angle, standoff, 'M' + x1 + ',' + y + 'L0,0M' + x1 + ',-' + y + 'L0,0M-' + x0 + ',0L0,0');\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'y-right': {\n n: 40,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var y = round(r * 1.2, 2);\n var x0 = round(r * 1.6, 2);\n var x1 = round(r * 0.8, 2);\n return align(angle, standoff, 'M-' + x1 + ',' + y + 'L0,0M-' + x1 + ',-' + y + 'L0,0M' + x0 + ',0L0,0');\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'line-ew': {\n n: 41,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rc = round(r * 1.4, 2);\n return align(angle, standoff, 'M' + rc + ',0H-' + rc);\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'line-ns': {\n n: 42,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rc = round(r * 1.4, 2);\n return align(angle, standoff, 'M0,' + rc + 'V-' + rc);\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'line-ne': {\n n: 43,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rx = round(r, 2);\n return align(angle, standoff, 'M' + rx + ',-' + rx + 'L-' + rx + ',' + rx);\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'line-nw': {\n n: 44,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rx = round(r, 2);\n return align(angle, standoff, 'M' + rx + ',' + rx + 'L-' + rx + ',-' + rx);\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'arrow-up': {\n n: 45,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rx = round(r, 2);\n var ry = round(r * 2, 2);\n return align(angle, standoff, 'M0,0L-' + rx + ',' + ry + 'H' + rx + 'Z');\n },\n backoff: 1,\n noDot: true\n },\n 'arrow-down': {\n n: 46,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rx = round(r, 2);\n var ry = round(r * 2, 2);\n return align(angle, standoff, 'M0,0L-' + rx + ',-' + ry + 'H' + rx + 'Z');\n },\n noDot: true\n },\n 'arrow-left': {\n n: 47,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rx = round(r * 2, 2);\n var ry = round(r, 2);\n return align(angle, standoff, 'M0,0L' + rx + ',-' + ry + 'V' + ry + 'Z');\n },\n noDot: true\n },\n 'arrow-right': {\n n: 48,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rx = round(r * 2, 2);\n var ry = round(r, 2);\n return align(angle, standoff, 'M0,0L-' + rx + ',-' + ry + 'V' + ry + 'Z');\n },\n noDot: true\n },\n 'arrow-bar-up': {\n n: 49,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rx = round(r, 2);\n var ry = round(r * 2, 2);\n return align(angle, standoff, 'M-' + rx + ',0H' + rx + 'M0,0L-' + rx + ',' + ry + 'H' + rx + 'Z');\n },\n backoff: 1,\n needLine: true,\n noDot: true\n },\n 'arrow-bar-down': {\n n: 50,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rx = round(r, 2);\n var ry = round(r * 2, 2);\n return align(angle, standoff, 'M-' + rx + ',0H' + rx + 'M0,0L-' + rx + ',-' + ry + 'H' + rx + 'Z');\n },\n needLine: true,\n noDot: true\n },\n 'arrow-bar-left': {\n n: 51,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rx = round(r * 2, 2);\n var ry = round(r, 2);\n return align(angle, standoff, 'M0,-' + ry + 'V' + ry + 'M0,0L' + rx + ',-' + ry + 'V' + ry + 'Z');\n },\n needLine: true,\n noDot: true\n },\n 'arrow-bar-right': {\n n: 52,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var rx = round(r * 2, 2);\n var ry = round(r, 2);\n return align(angle, standoff, 'M0,-' + ry + 'V' + ry + 'M0,0L-' + rx + ',-' + ry + 'V' + ry + 'Z');\n },\n needLine: true,\n noDot: true\n },\n arrow: {\n n: 53,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var headAngle = PI / 2.5; // 36 degrees - golden ratio\n var x = 2 * r * cos(headAngle);\n var y = 2 * r * sin(headAngle);\n\n return align(angle, standoff,\n 'M0,0' +\n 'L' + -x + ',' + y +\n 'L' + x + ',' + y +\n 'Z'\n );\n },\n backoff: 0.9,\n noDot: true\n },\n 'arrow-wide': {\n n: 54,\n f: function(r, angle, standoff) {\n if(skipAngle(angle)) return emptyPath;\n\n var headAngle = PI / 4; // 90 degrees\n var x = 2 * r * cos(headAngle);\n var y = 2 * r * sin(headAngle);\n\n return align(angle, standoff,\n 'M0,0' +\n 'L' + -x + ',' + y +\n 'A ' + 2 * r + ',' + 2 * r + ' 0 0 1 ' + x + ',' + y +\n 'Z'\n );\n },\n backoff: 0.4,\n noDot: true\n }\n};\n\nfunction skipAngle(angle) {\n return angle === null;\n}\n\nvar lastPathIn, lastPathOut;\nvar lastAngle, lastStandoff;\n\nfunction align(angle, standoff, path) {\n if((!angle || angle % 360 === 0) && !standoff) return path;\n\n if(\n lastAngle === angle &&\n lastStandoff === standoff &&\n lastPathIn === path\n ) return lastPathOut;\n\n lastAngle = angle;\n lastStandoff = standoff;\n lastPathIn = path;\n\n function rotate(t, xy) {\n var cosT = cos(t);\n var sinT = sin(t);\n\n var x = xy[0];\n var y = xy[1] + (standoff || 0);\n return [\n x * cosT - y * sinT,\n x * sinT + y * cosT\n ];\n }\n\n var t = angle / 180 * PI;\n\n var x = 0;\n var y = 0;\n var cmd = parseSvgPath(path);\n var str = '';\n\n for(var i = 0; i < cmd.length; i++) {\n var cmdI = cmd[i];\n var op = cmdI[0];\n\n var x0 = x;\n var y0 = y;\n\n if(op === 'M' || op === 'L') {\n x = +cmdI[1];\n y = +cmdI[2];\n } else if(op === 'm' || op === 'l') {\n x += +cmdI[1];\n y += +cmdI[2];\n } else if(op === 'H') {\n x = +cmdI[1];\n } else if(op === 'h') {\n x += +cmdI[1];\n } else if(op === 'V') {\n y = +cmdI[1];\n } else if(op === 'v') {\n y += +cmdI[1];\n } else if(op === 'A') {\n x = +cmdI[1];\n y = +cmdI[2];\n\n var E = rotate(t, [+cmdI[6], +cmdI[7]]);\n cmdI[6] = E[0];\n cmdI[7] = E[1];\n cmdI[3] = +cmdI[3] + angle;\n }\n\n // change from H, V, h, v to L or l\n if(op === 'H' || op === 'V') op = 'L';\n if(op === 'h' || op === 'v') op = 'l';\n\n if(op === 'm' || op === 'l') {\n x -= x0;\n y -= y0;\n }\n\n var B = rotate(t, [x, y]);\n\n if(op === 'H' || op === 'V') op = 'L';\n\n\n if(\n op === 'M' || op === 'L' ||\n op === 'm' || op === 'l'\n ) {\n cmdI[1] = B[0];\n cmdI[2] = B[1];\n }\n cmdI[0] = op;\n\n str += cmdI[0] + cmdI.slice(1).join(',');\n }\n\n lastPathOut = str;\n\n return str;\n}\n","'use strict';\n\n\nmodule.exports = {\n visible: {\n valType: 'boolean',\n editType: 'calc',\n description: [\n 'Determines whether or not this set of error bars is visible.'\n ].join(' ')\n },\n type: {\n valType: 'enumerated',\n values: ['percent', 'constant', 'sqrt', 'data'],\n editType: 'calc',\n description: [\n 'Determines the rule used to generate the error bars.',\n\n 'If *constant`, the bar lengths are of a constant value.',\n 'Set this constant in `value`.',\n\n 'If *percent*, the bar lengths correspond to a percentage of',\n 'underlying data. Set this percentage in `value`.',\n\n 'If *sqrt*, the bar lengths correspond to the square of the',\n 'underlying data.',\n\n 'If *data*, the bar lengths are set with data set `array`.'\n ].join(' ')\n },\n symmetric: {\n valType: 'boolean',\n editType: 'calc',\n description: [\n 'Determines whether or not the error bars have the same length',\n 'in both direction',\n '(top/bottom for vertical bars, left/right for horizontal bars.'\n ].join(' ')\n },\n array: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the data corresponding the length of each error bar.',\n 'Values are plotted relative to the underlying data.'\n ].join(' ')\n },\n arrayminus: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the data corresponding the length of each error bar in the',\n 'bottom (left) direction for vertical (horizontal) bars',\n 'Values are plotted relative to the underlying data.'\n ].join(' ')\n },\n value: {\n valType: 'number',\n min: 0,\n dflt: 10,\n editType: 'calc',\n description: [\n 'Sets the value of either the percentage',\n '(if `type` is set to *percent*) or the constant',\n '(if `type` is set to *constant*) corresponding to the lengths of',\n 'the error bars.'\n ].join(' ')\n },\n valueminus: {\n valType: 'number',\n min: 0,\n dflt: 10,\n editType: 'calc',\n description: [\n 'Sets the value of either the percentage',\n '(if `type` is set to *percent*) or the constant',\n '(if `type` is set to *constant*) corresponding to the lengths of',\n 'the error bars in the',\n 'bottom (left) direction for vertical (horizontal) bars'\n ].join(' ')\n },\n traceref: {\n valType: 'integer',\n min: 0,\n dflt: 0,\n editType: 'style'\n },\n tracerefminus: {\n valType: 'integer',\n min: 0,\n dflt: 0,\n editType: 'style'\n },\n copy_ystyle: {\n valType: 'boolean',\n editType: 'plot'\n },\n copy_zstyle: {\n valType: 'boolean',\n editType: 'style'\n },\n color: {\n valType: 'color',\n editType: 'style',\n description: 'Sets the stoke color of the error bars.'\n },\n thickness: {\n valType: 'number',\n min: 0,\n dflt: 2,\n editType: 'style',\n description: 'Sets the thickness (in px) of the error bars.'\n },\n width: {\n valType: 'number',\n min: 0,\n editType: 'plot',\n description: [\n 'Sets the width (in px) of the cross-bar at both ends',\n 'of the error bars.'\n ].join(' ')\n },\n editType: 'calc',\n\n _deprecated: {\n opacity: {\n valType: 'number',\n editType: 'style',\n description: [\n 'Obsolete.',\n 'Use the alpha channel in error bar `color` to set the opacity.'\n ].join(' ')\n }\n }\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Registry = require('../../registry');\nvar Axes = require('../../plots/cartesian/axes');\nvar Lib = require('../../lib');\n\nvar makeComputeError = require('./compute_error');\n\nmodule.exports = function calc(gd) {\n var calcdata = gd.calcdata;\n\n for(var i = 0; i < calcdata.length; i++) {\n var calcTrace = calcdata[i];\n var trace = calcTrace[0].trace;\n\n if(trace.visible === true && Registry.traceIs(trace, 'errorBarsOK')) {\n var xa = Axes.getFromId(gd, trace.xaxis);\n var ya = Axes.getFromId(gd, trace.yaxis);\n calcOneAxis(calcTrace, trace, xa, 'x');\n calcOneAxis(calcTrace, trace, ya, 'y');\n }\n }\n};\n\nfunction calcOneAxis(calcTrace, trace, axis, coord) {\n var opts = trace['error_' + coord] || {};\n var isVisible = (opts.visible && ['linear', 'log'].indexOf(axis.type) !== -1);\n var vals = [];\n\n if(!isVisible) return;\n\n var computeError = makeComputeError(opts);\n\n for(var i = 0; i < calcTrace.length; i++) {\n var calcPt = calcTrace[i];\n\n var iIn = calcPt.i;\n\n // for types that don't include `i` in each calcdata point\n if(iIn === undefined) iIn = i;\n\n // for stacked area inserted points\n // TODO: errorbars have been tested cursorily with stacked area,\n // but not thoroughly. It's not even really clear what you want to do:\n // Should it just be calculated based on that trace's size data?\n // Should you add errors from below in quadrature?\n // And what about normalization, where in principle the errors shrink\n // again when you get up to the top end?\n // One option would be to forbid errorbars with stacking until we\n // decide how to handle these questions.\n else if(iIn === null) continue;\n\n var calcCoord = calcPt[coord];\n\n if(!isNumeric(axis.c2l(calcCoord))) continue;\n\n var errors = computeError(calcCoord, iIn);\n if(isNumeric(errors[0]) && isNumeric(errors[1])) {\n var shoe = calcPt[coord + 's'] = calcCoord - errors[0];\n var hat = calcPt[coord + 'h'] = calcCoord + errors[1];\n vals.push(shoe, hat);\n }\n }\n\n var axId = axis._id;\n var baseExtremes = trace._extremes[axId];\n var extremes = Axes.findExtremes(\n axis,\n vals,\n Lib.extendFlat({tozero: baseExtremes.opts.tozero}, {padded: true})\n );\n baseExtremes.min = baseExtremes.min.concat(extremes.min);\n baseExtremes.max = baseExtremes.max.concat(extremes.max);\n}\n","'use strict';\n\n\n/**\n * Error bar computing function generator\n *\n * N.B. The generated function does not clean the dataPt entries. Non-numeric\n * entries result in undefined error magnitudes.\n *\n * @param {object} opts error bar attributes\n *\n * @return {function} :\n * @param {numeric} dataPt data point from where to compute the error magnitude\n * @param {number} index index of dataPt in its corresponding data array\n * @return {array}\n * - error[0] : error magnitude in the negative direction\n * - error[1] : \" \" \" \" positive \"\n */\nmodule.exports = function makeComputeError(opts) {\n var type = opts.type;\n var symmetric = opts.symmetric;\n\n if(type === 'data') {\n var array = opts.array || [];\n\n if(symmetric) {\n return function computeError(dataPt, index) {\n var val = +(array[index]);\n return [val, val];\n };\n } else {\n var arrayminus = opts.arrayminus || [];\n return function computeError(dataPt, index) {\n var val = +array[index];\n var valMinus = +arrayminus[index];\n // in case one is present and the other is missing, fill in 0\n // so we still see the present one. Mostly useful during manual\n // data entry.\n if(!isNaN(val) || !isNaN(valMinus)) {\n return [valMinus || 0, val || 0];\n }\n return [NaN, NaN];\n };\n }\n } else {\n var computeErrorValue = makeComputeErrorValue(type, opts.value);\n var computeErrorValueMinus = makeComputeErrorValue(type, opts.valueminus);\n\n if(symmetric || opts.valueminus === undefined) {\n return function computeError(dataPt) {\n var val = computeErrorValue(dataPt);\n return [val, val];\n };\n } else {\n return function computeError(dataPt) {\n return [\n computeErrorValueMinus(dataPt),\n computeErrorValue(dataPt)\n ];\n };\n }\n }\n};\n\n/**\n * Compute error bar magnitude (for all types except data)\n *\n * @param {string} type error bar type\n * @param {numeric} value error bar value\n *\n * @return {function} :\n * @param {numeric} dataPt\n */\nfunction makeComputeErrorValue(type, value) {\n if(type === 'percent') {\n return function(dataPt) {\n return Math.abs(dataPt * value / 100);\n };\n }\n if(type === 'constant') {\n return function() {\n return Math.abs(value);\n };\n }\n if(type === 'sqrt') {\n return function(dataPt) {\n return Math.sqrt(Math.abs(dataPt));\n };\n }\n}\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Template = require('../../plot_api/plot_template');\n\nvar attributes = require('./attributes');\n\n\nmodule.exports = function(traceIn, traceOut, defaultColor, opts) {\n var objName = 'error_' + opts.axis;\n var containerOut = Template.newContainer(traceOut, objName);\n var containerIn = traceIn[objName] || {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(containerIn, containerOut, attributes, attr, dflt);\n }\n\n var hasErrorBars = (\n containerIn.array !== undefined ||\n containerIn.value !== undefined ||\n containerIn.type === 'sqrt'\n );\n\n var visible = coerce('visible', hasErrorBars);\n\n if(visible === false) return;\n\n var type = coerce('type', 'array' in containerIn ? 'data' : 'percent');\n var symmetric = true;\n\n if(type !== 'sqrt') {\n symmetric = coerce('symmetric',\n !((type === 'data' ? 'arrayminus' : 'valueminus') in containerIn));\n }\n\n if(type === 'data') {\n coerce('array');\n coerce('traceref');\n if(!symmetric) {\n coerce('arrayminus');\n coerce('tracerefminus');\n }\n } else if(type === 'percent' || type === 'constant') {\n coerce('value');\n if(!symmetric) coerce('valueminus');\n }\n\n var copyAttr = 'copy_' + opts.inherit + 'style';\n if(opts.inherit) {\n var inheritObj = traceOut['error_' + opts.inherit];\n if((inheritObj || {}).visible) {\n coerce(copyAttr, !(containerIn.color ||\n isNumeric(containerIn.thickness) ||\n isNumeric(containerIn.width)));\n }\n }\n if(!opts.inherit || !containerOut[copyAttr]) {\n coerce('color', defaultColor);\n coerce('thickness');\n coerce('width', Registry.traceIs(traceOut, 'gl3d') ? 0 : 4);\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\n\nvar attributes = require('./attributes');\n\nvar xyAttrs = {\n error_x: Lib.extendFlat({}, attributes),\n error_y: Lib.extendFlat({}, attributes)\n};\ndelete xyAttrs.error_x.copy_zstyle;\ndelete xyAttrs.error_y.copy_zstyle;\ndelete xyAttrs.error_y.copy_ystyle;\n\nvar xyzAttrs = {\n error_x: Lib.extendFlat({}, attributes),\n error_y: Lib.extendFlat({}, attributes),\n error_z: Lib.extendFlat({}, attributes)\n};\ndelete xyzAttrs.error_x.copy_ystyle;\ndelete xyzAttrs.error_y.copy_ystyle;\ndelete xyzAttrs.error_z.copy_ystyle;\ndelete xyzAttrs.error_z.copy_zstyle;\n\nmodule.exports = {\n moduleType: 'component',\n name: 'errorbars',\n\n schema: {\n traces: {\n scatter: xyAttrs,\n bar: xyAttrs,\n histogram: xyAttrs,\n scatter3d: overrideAll(xyzAttrs, 'calc', 'nested'),\n scattergl: overrideAll(xyAttrs, 'calc', 'nested')\n }\n },\n\n supplyDefaults: require('./defaults'),\n\n calc: require('./calc'),\n makeComputeError: require('./compute_error'),\n\n plot: require('./plot'),\n style: require('./style'),\n hoverInfo: hoverInfo\n};\n\nfunction hoverInfo(calcPoint, trace, hoverPoint) {\n if((trace.error_y || {}).visible) {\n hoverPoint.yerr = calcPoint.yh - calcPoint.y;\n if(!trace.error_y.symmetric) hoverPoint.yerrneg = calcPoint.y - calcPoint.ys;\n }\n if((trace.error_x || {}).visible) {\n hoverPoint.xerr = calcPoint.xh - calcPoint.x;\n if(!trace.error_x.symmetric) hoverPoint.xerrneg = calcPoint.x - calcPoint.xs;\n }\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar Drawing = require('../drawing');\nvar subTypes = require('../../traces/scatter/subtypes');\n\nmodule.exports = function plot(gd, traces, plotinfo, transitionOpts) {\n var isNew;\n\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n var hasAnimation = transitionOpts && transitionOpts.duration > 0;\n var isStatic = gd._context.staticPlot;\n\n traces.each(function(d) {\n var trace = d[0].trace;\n // || {} is in case the trace (specifically scatterternary)\n // doesn't support error bars at all, but does go through\n // the scatter.plot mechanics, which calls ErrorBars.plot\n // internally\n var xObj = trace.error_x || {};\n var yObj = trace.error_y || {};\n\n var keyFunc;\n\n if(trace.ids) {\n keyFunc = function(d) {return d.id;};\n }\n\n var sparse = (\n subTypes.hasMarkers(trace) &&\n trace.marker.maxdisplayed > 0\n );\n\n if(!yObj.visible && !xObj.visible) d = [];\n\n var errorbars = d3.select(this).selectAll('g.errorbar')\n .data(d, keyFunc);\n\n errorbars.exit().remove();\n\n if(!d.length) return;\n\n if(!xObj.visible) errorbars.selectAll('path.xerror').remove();\n if(!yObj.visible) errorbars.selectAll('path.yerror').remove();\n\n errorbars.style('opacity', 1);\n\n var enter = errorbars.enter().append('g')\n .classed('errorbar', true);\n\n if(hasAnimation) {\n enter.style('opacity', 0).transition()\n .duration(transitionOpts.duration)\n .style('opacity', 1);\n }\n\n Drawing.setClipUrl(errorbars, plotinfo.layerClipId, gd);\n\n errorbars.each(function(d) {\n var errorbar = d3.select(this);\n var coords = errorCoords(d, xa, ya);\n\n if(sparse && !d.vis) return;\n\n var path;\n\n var yerror = errorbar.select('path.yerror');\n if(yObj.visible && isNumeric(coords.x) &&\n isNumeric(coords.yh) &&\n isNumeric(coords.ys)) {\n var yw = yObj.width;\n\n path = 'M' + (coords.x - yw) + ',' +\n coords.yh + 'h' + (2 * yw) + // hat\n 'm-' + yw + ',0V' + coords.ys; // bar\n\n\n if(!coords.noYS) path += 'm-' + yw + ',0h' + (2 * yw); // shoe\n\n isNew = !yerror.size();\n\n if(isNew) {\n yerror = errorbar.append('path')\n .style('vector-effect', isStatic ? 'none' : 'non-scaling-stroke')\n .classed('yerror', true);\n } else if(hasAnimation) {\n yerror = yerror\n .transition()\n .duration(transitionOpts.duration)\n .ease(transitionOpts.easing);\n }\n\n yerror.attr('d', path);\n } else yerror.remove();\n\n var xerror = errorbar.select('path.xerror');\n if(xObj.visible && isNumeric(coords.y) &&\n isNumeric(coords.xh) &&\n isNumeric(coords.xs)) {\n var xw = (xObj.copy_ystyle ? yObj : xObj).width;\n\n path = 'M' + coords.xh + ',' +\n (coords.y - xw) + 'v' + (2 * xw) + // hat\n 'm0,-' + xw + 'H' + coords.xs; // bar\n\n if(!coords.noXS) path += 'm0,-' + xw + 'v' + (2 * xw); // shoe\n\n isNew = !xerror.size();\n\n if(isNew) {\n xerror = errorbar.append('path')\n .style('vector-effect', isStatic ? 'none' : 'non-scaling-stroke')\n .classed('xerror', true);\n } else if(hasAnimation) {\n xerror = xerror\n .transition()\n .duration(transitionOpts.duration)\n .ease(transitionOpts.easing);\n }\n\n xerror.attr('d', path);\n } else xerror.remove();\n });\n });\n};\n\n// compute the coordinates of the error-bar objects\nfunction errorCoords(d, xa, ya) {\n var out = {\n x: xa.c2p(d.x),\n y: ya.c2p(d.y)\n };\n\n // calculate the error bar size and hat and shoe locations\n if(d.yh !== undefined) {\n out.yh = ya.c2p(d.yh);\n out.ys = ya.c2p(d.ys);\n\n // if the shoes go off-scale (ie log scale, error bars past zero)\n // clip the bar and hide the shoes\n if(!isNumeric(out.ys)) {\n out.noYS = true;\n out.ys = ya.c2p(d.ys, true);\n }\n }\n\n if(d.xh !== undefined) {\n out.xh = xa.c2p(d.xh);\n out.xs = xa.c2p(d.xs);\n\n if(!isNumeric(out.xs)) {\n out.noXS = true;\n out.xs = xa.c2p(d.xs, true);\n }\n }\n\n return out;\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Color = require('../color');\n\n\nmodule.exports = function style(traces) {\n traces.each(function(d) {\n var trace = d[0].trace;\n var yObj = trace.error_y || {};\n var xObj = trace.error_x || {};\n\n var s = d3.select(this);\n\n s.selectAll('path.yerror')\n .style('stroke-width', yObj.thickness + 'px')\n .call(Color.stroke, yObj.color);\n\n if(xObj.copy_ystyle) xObj = yObj;\n\n s.selectAll('path.xerror')\n .style('stroke-width', xObj.thickness + 'px')\n .call(Color.stroke, xObj.color);\n });\n};\n","'use strict';\n\nvar fontAttrs = require('../../plots/font_attributes');\nvar hoverLabelAttrs = require('./layout_attributes').hoverlabel;\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nmodule.exports = {\n hoverlabel: {\n bgcolor: extendFlat({}, hoverLabelAttrs.bgcolor, {\n arrayOk: true,\n description: 'Sets the background color of the hover labels for this trace'\n }),\n bordercolor: extendFlat({}, hoverLabelAttrs.bordercolor, {\n arrayOk: true,\n description: 'Sets the border color of the hover labels for this trace.'\n }),\n font: fontAttrs({\n arrayOk: true,\n editType: 'none',\n description: 'Sets the font used in hover labels.'\n }),\n align: extendFlat({}, hoverLabelAttrs.align, {arrayOk: true}),\n namelength: extendFlat({}, hoverLabelAttrs.namelength, {arrayOk: true}),\n editType: 'none'\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\n\nmodule.exports = function calc(gd) {\n var calcdata = gd.calcdata;\n var fullLayout = gd._fullLayout;\n\n function makeCoerceHoverInfo(trace) {\n return function(val) {\n return Lib.coerceHoverinfo({hoverinfo: val}, {_module: trace._module}, fullLayout);\n };\n }\n\n for(var i = 0; i < calcdata.length; i++) {\n var cd = calcdata[i];\n var trace = cd[0].trace;\n\n // don't include hover calc fields for pie traces\n // as calcdata items might be sorted by value and\n // won't match the data array order.\n if(Registry.traceIs(trace, 'pie-like')) continue;\n\n var fillFn = Registry.traceIs(trace, '2dMap') ? paste : Lib.fillArray;\n\n fillFn(trace.hoverinfo, cd, 'hi', makeCoerceHoverInfo(trace));\n\n if(trace.hovertemplate) fillFn(trace.hovertemplate, cd, 'ht');\n\n if(!trace.hoverlabel) continue;\n\n fillFn(trace.hoverlabel.bgcolor, cd, 'hbg');\n fillFn(trace.hoverlabel.bordercolor, cd, 'hbc');\n fillFn(trace.hoverlabel.font.size, cd, 'hts');\n fillFn(trace.hoverlabel.font.color, cd, 'htc');\n fillFn(trace.hoverlabel.font.family, cd, 'htf');\n fillFn(trace.hoverlabel.font.weight, cd, 'htw');\n fillFn(trace.hoverlabel.font.style, cd, 'hty');\n fillFn(trace.hoverlabel.font.variant, cd, 'htv');\n fillFn(trace.hoverlabel.namelength, cd, 'hnl');\n fillFn(trace.hoverlabel.align, cd, 'hta');\n }\n};\n\nfunction paste(traceAttr, cd, cdAttr, fn) {\n fn = fn || Lib.identity;\n\n if(Array.isArray(traceAttr)) {\n cd[0][cdAttr] = fn(traceAttr);\n }\n}\n","'use strict';\n\nvar Registry = require('../../registry');\nvar hover = require('./hover').hover;\n\nmodule.exports = function click(gd, evt, subplot) {\n var annotationsDone = Registry.getComponentMethod('annotations', 'onClick')(gd, gd._hoverdata);\n\n // fallback to fail-safe in case the plot type's hover method doesn't pass the subplot.\n // Ternary, for example, didn't, but it was caught because tested.\n if(subplot !== undefined) {\n // The true flag at the end causes it to re-run the hover computation to figure out *which*\n // point is being clicked. Without this, clicking is somewhat unreliable.\n hover(gd, evt, subplot, true);\n }\n\n function emitClick() { gd.emit('plotly_click', {points: gd._hoverdata, event: evt}); }\n\n if(gd._hoverdata && evt && evt.target) {\n if(annotationsDone && annotationsDone.then) {\n annotationsDone.then(emitClick);\n } else emitClick();\n\n // why do we get a double event without this???\n if(evt.stopImmediatePropagation) evt.stopImmediatePropagation();\n }\n};\n","'use strict';\n\nmodule.exports = {\n // hover labels for multiple horizontal bars get tilted by this angle\n YANGLE: 60,\n\n // size and display constants for hover text\n\n // pixel size of hover arrows\n HOVERARROWSIZE: 6,\n // pixels padding around text\n HOVERTEXTPAD: 3,\n // hover font\n HOVERFONTSIZE: 13,\n HOVERFONT: 'Arial, sans-serif',\n\n // minimum time (msec) between hover calls\n HOVERMINTIME: 50,\n\n // ID suffix (with fullLayout._uid) for hover events in the throttle cache\n HOVERID: '-hover'\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar attributes = require('./attributes');\nvar handleHoverLabelDefaults = require('./hoverlabel_defaults');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var opts = Lib.extendFlat({}, layout.hoverlabel);\n if(traceOut.hovertemplate) opts.namelength = -1;\n\n handleHoverLabelDefaults(traceIn, traceOut, coerce, opts);\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\n// look for either subplot or xaxis and yaxis attributes\n// does not handle splom case\nexports.getSubplot = function(trace) {\n return trace.subplot || (trace.xaxis + trace.yaxis) || trace.geo;\n};\n\n// is trace in given list of subplots?\n// does handle splom case\nexports.isTraceInSubplots = function(trace, subplots) {\n if(trace.type === 'splom') {\n var xaxes = trace.xaxes || [];\n var yaxes = trace.yaxes || [];\n for(var i = 0; i < xaxes.length; i++) {\n for(var j = 0; j < yaxes.length; j++) {\n if(subplots.indexOf(xaxes[i] + yaxes[j]) !== -1) {\n return true;\n }\n }\n }\n return false;\n }\n\n return subplots.indexOf(exports.getSubplot(trace)) !== -1;\n};\n\n// convenience functions for mapping all relevant axes\nexports.flat = function(subplots, v) {\n var out = new Array(subplots.length);\n for(var i = 0; i < subplots.length; i++) {\n out[i] = v;\n }\n return out;\n};\n\nexports.p2c = function(axArray, v) {\n var out = new Array(axArray.length);\n for(var i = 0; i < axArray.length; i++) {\n out[i] = axArray[i].p2c(v);\n }\n return out;\n};\n\nexports.getDistanceFunction = function(mode, dx, dy, dxy) {\n if(mode === 'closest') return dxy || exports.quadrature(dx, dy);\n return mode.charAt(0) === 'x' ? dx : dy;\n};\n\nexports.getClosest = function(cd, distfn, pointData) {\n // do we already have a point number? (array mode only)\n if(pointData.index !== false) {\n if(pointData.index >= 0 && pointData.index < cd.length) {\n pointData.distance = 0;\n } else pointData.index = false;\n } else {\n // apply the distance function to each data point\n // this is the longest loop... if this bogs down, we may need\n // to create pre-sorted data (by x or y), not sure how to\n // do this for 'closest'\n for(var i = 0; i < cd.length; i++) {\n var newDistance = distfn(cd[i]);\n if(newDistance <= pointData.distance) {\n pointData.index = i;\n pointData.distance = newDistance;\n }\n }\n }\n return pointData;\n};\n\n/*\n * pseudo-distance function for hover effects on areas: inside the region\n * distance is finite (`passVal`), outside it's Infinity.\n *\n * @param {number} v0: signed difference between the current position and the left edge\n * @param {number} v1: signed difference between the current position and the right edge\n * @param {number} passVal: the value to return on success\n */\nexports.inbox = function(v0, v1, passVal) {\n return (v0 * v1 < 0 || v0 === 0) ? passVal : Infinity;\n};\n\nexports.quadrature = function(dx, dy) {\n return function(di) {\n var x = dx(di);\n var y = dy(di);\n return Math.sqrt(x * x + y * y);\n };\n};\n\n/** Fill event data point object for hover and selection.\n * Invokes _module.eventData if present.\n *\n * N.B. note that point 'index' corresponds to input data array index\n * whereas 'number' is its post-transform version.\n *\n * If the hovered/selected pt corresponds to an multiple input points\n * (e.g. for histogram and transformed traces), 'pointNumbers` and 'pointIndices'\n * are include in the event data.\n *\n * @param {object} pt\n * @param {object} trace\n * @param {object} cd\n * @return {object}\n */\nexports.makeEventData = function(pt, trace, cd) {\n // hover uses 'index', select uses 'pointNumber'\n var pointNumber = 'index' in pt ? pt.index : pt.pointNumber;\n\n var out = {\n data: trace._input,\n fullData: trace,\n curveNumber: trace.index,\n pointNumber: pointNumber\n };\n\n if(trace._indexToPoints) {\n var pointIndices = trace._indexToPoints[pointNumber];\n\n if(pointIndices.length === 1) {\n out.pointIndex = pointIndices[0];\n } else {\n out.pointIndices = pointIndices;\n }\n } else {\n out.pointIndex = pointNumber;\n }\n\n if(trace._module.eventData) {\n out = trace._module.eventData(out, pt, trace, cd, pointNumber);\n } else {\n if('xVal' in pt) out.x = pt.xVal;\n else if('x' in pt) out.x = pt.x;\n\n if('yVal' in pt) out.y = pt.yVal;\n else if('y' in pt) out.y = pt.y;\n\n if(pt.xa) out.xaxis = pt.xa;\n if(pt.ya) out.yaxis = pt.ya;\n if(pt.zLabelVal !== undefined) out.z = pt.zLabelVal;\n }\n\n exports.appendArrayPointValue(out, trace, pointNumber);\n\n return out;\n};\n\n/** Appends values inside array attributes corresponding to given point number\n *\n * @param {object} pointData : point data object (gets mutated here)\n * @param {object} trace : full trace object\n * @param {number|Array(number)} pointNumber : point number. May be a length-2 array\n * [row, col] to dig into 2D arrays\n */\nexports.appendArrayPointValue = function(pointData, trace, pointNumber) {\n var arrayAttrs = trace._arrayAttrs;\n\n if(!arrayAttrs) {\n return;\n }\n\n for(var i = 0; i < arrayAttrs.length; i++) {\n var astr = arrayAttrs[i];\n var key = getPointKey(astr);\n\n if(pointData[key] === undefined) {\n var val = Lib.nestedProperty(trace, astr).get();\n var pointVal = getPointData(val, pointNumber);\n\n if(pointVal !== undefined) pointData[key] = pointVal;\n }\n }\n};\n\n/**\n * Appends values inside array attributes corresponding to given point number array\n * For use when pointData references a plot entity that arose (or potentially arose)\n * from multiple points in the input data\n *\n * @param {object} pointData : point data object (gets mutated here)\n * @param {object} trace : full trace object\n * @param {Array(number)|Array(Array(number))} pointNumbers : Array of point numbers.\n * Each entry in the array may itself be a length-2 array [row, col] to dig into 2D arrays\n */\nexports.appendArrayMultiPointValues = function(pointData, trace, pointNumbers) {\n var arrayAttrs = trace._arrayAttrs;\n\n if(!arrayAttrs) {\n return;\n }\n\n for(var i = 0; i < arrayAttrs.length; i++) {\n var astr = arrayAttrs[i];\n var key = getPointKey(astr);\n\n if(pointData[key] === undefined) {\n var val = Lib.nestedProperty(trace, astr).get();\n var keyVal = new Array(pointNumbers.length);\n\n for(var j = 0; j < pointNumbers.length; j++) {\n keyVal[j] = getPointData(val, pointNumbers[j]);\n }\n pointData[key] = keyVal;\n }\n }\n};\n\nvar pointKeyMap = {\n ids: 'id',\n locations: 'location',\n labels: 'label',\n values: 'value',\n 'marker.colors': 'color',\n parents: 'parent'\n};\n\nfunction getPointKey(astr) {\n return pointKeyMap[astr] || astr;\n}\n\nfunction getPointData(val, pointNumber) {\n if(Array.isArray(pointNumber)) {\n if(Array.isArray(val) && Array.isArray(val[pointNumber[0]])) {\n return val[pointNumber[0]][pointNumber[1]];\n }\n } else {\n return val[pointNumber];\n }\n}\n\nvar xyHoverMode = {\n x: true,\n y: true\n};\n\nvar unifiedHoverMode = {\n 'x unified': true,\n 'y unified': true\n};\n\nexports.isUnifiedHover = function(hovermode) {\n if(typeof hovermode !== 'string') return false;\n return !!unifiedHoverMode[hovermode];\n};\n\nexports.isXYhover = function(hovermode) {\n if(typeof hovermode !== 'string') return false;\n return !!xyHoverMode[hovermode];\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar isNumeric = require('fast-isnumeric');\nvar tinycolor = require('tinycolor2');\n\nvar Lib = require('../../lib');\nvar pushUnique = Lib.pushUnique;\nvar strTranslate = Lib.strTranslate;\nvar strRotate = Lib.strRotate;\nvar Events = require('../../lib/events');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar overrideCursor = require('../../lib/override_cursor');\nvar Drawing = require('../drawing');\nvar Color = require('../color');\nvar dragElement = require('../dragelement');\nvar Axes = require('../../plots/cartesian/axes');\nvar zindexSeparator = require('../../plots/cartesian/constants').zindexSeparator;\nvar Registry = require('../../registry');\n\nvar helpers = require('./helpers');\nvar constants = require('./constants');\n\nvar legendSupplyDefaults = require('../legend/defaults');\nvar legendDraw = require('../legend/draw');\n\n// hover labels for multiple horizontal bars get tilted by some angle,\n// then need to be offset differently if they overlap\nvar YANGLE = constants.YANGLE;\nvar YA_RADIANS = Math.PI * YANGLE / 180;\n\n// expansion of projected height\nvar YFACTOR = 1 / Math.sin(YA_RADIANS);\n\n// to make the appropriate post-rotation x offset,\n// you need both x and y offsets\nvar YSHIFTX = Math.cos(YA_RADIANS);\nvar YSHIFTY = Math.sin(YA_RADIANS);\n\n// size and display constants for hover text\nvar HOVERARROWSIZE = constants.HOVERARROWSIZE;\nvar HOVERTEXTPAD = constants.HOVERTEXTPAD;\n\nvar multipleHoverPoints = {\n box: true,\n ohlc: true,\n violin: true,\n candlestick: true\n};\n\nvar cartesianScatterPoints = {\n scatter: true,\n scattergl: true,\n splom: true\n};\n\nfunction distanceSort(a, b) {\n return a.distance - b.distance;\n}\n\n// fx.hover: highlight data on hover\n// evt can be a mousemove event, or an object with data about what points\n// to hover on\n// {xpx,ypx[,hovermode]} - pixel locations from top left\n// (with optional overriding hovermode)\n// {xval,yval[,hovermode]} - data values\n// [{curveNumber,(pointNumber|xval and/or yval)}] -\n// array of specific points to highlight\n// pointNumber is a single integer if gd.data[curveNumber] is 1D,\n// or a two-element array if it's 2D\n// xval and yval are data values,\n// 1D data may specify either or both,\n// 2D data must specify both\n// subplot is an id string (default \"xy\")\n// makes use of gl.hovermode, which can be:\n// x (find the points with the closest x values, ie a column),\n// closest (find the single closest point)\n// internally there are two more that occasionally get used:\n// y (pick out a row - only used for multiple horizontal bar charts)\n// array (used when the user specifies an explicit\n// array of points to hover on)\n//\n// We wrap the hovers in a timer, to limit their frequency.\n// The actual rendering is done by private function _hover.\nexports.hover = function hover(gd, evt, subplot, noHoverEvent) {\n gd = Lib.getGraphDiv(gd);\n // The 'target' property changes when bubbling out of Shadow DOM.\n // Throttling can delay reading the target, so we save the current value.\n var eventTarget = evt.target;\n Lib.throttle(\n gd._fullLayout._uid + constants.HOVERID,\n constants.HOVERMINTIME,\n function() { _hover(gd, evt, subplot, noHoverEvent, eventTarget); }\n );\n};\n\n/*\n * Draw a single hover item or an array of hover item in a pre-existing svg container somewhere\n * hoverItem should have keys:\n * - x and y (or x0, x1, y0, and y1):\n * the pixel position to mark, relative to opts.container\n * - xLabel, yLabel, zLabel, text, and name:\n * info to go in the label\n * - color:\n * the background color for the label.\n * - idealAlign (optional):\n * 'left' or 'right' for which side of the x/y box to try to put this on first\n * - borderColor (optional):\n * color for the border, defaults to strongest contrast with color\n * - fontFamily (optional):\n * string, the font for this label, defaults to constants.HOVERFONT\n * - fontSize (optional):\n * the label font size, defaults to constants.HOVERFONTSIZE\n * - fontColor (optional):\n * defaults to borderColor\n * opts should have keys:\n * - bgColor:\n * the background color this is against, used if the trace is\n * non-opaque, and for the name, which goes outside the box\n * - container:\n * a or element to add the hover label to\n * - outerContainer:\n * normally a parent of `container`, sets the bounding box to use to\n * constrain the hover label and determine whether to show it on the left or right\n * opts can have optional keys:\n * - anchorIndex:\n the index of the hover item used as an anchor for positioning.\n The other hover items will be pushed up or down to prevent overlap.\n */\nexports.loneHover = function loneHover(hoverItems, opts) {\n var multiHover = true;\n if(!Array.isArray(hoverItems)) {\n multiHover = false;\n hoverItems = [hoverItems];\n }\n\n var gd = opts.gd;\n var gTop = getTopOffset(gd);\n var gLeft = getLeftOffset(gd);\n\n var pointsData = hoverItems.map(function(hoverItem) {\n var _x0 = hoverItem._x0 || hoverItem.x0 || hoverItem.x || 0;\n var _x1 = hoverItem._x1 || hoverItem.x1 || hoverItem.x || 0;\n var _y0 = hoverItem._y0 || hoverItem.y0 || hoverItem.y || 0;\n var _y1 = hoverItem._y1 || hoverItem.y1 || hoverItem.y || 0;\n\n var eventData = hoverItem.eventData;\n if(eventData) {\n var x0 = Math.min(_x0, _x1);\n var x1 = Math.max(_x0, _x1);\n var y0 = Math.min(_y0, _y1);\n var y1 = Math.max(_y0, _y1);\n\n var trace = hoverItem.trace;\n if(Registry.traceIs(trace, 'gl3d')) {\n var container = gd._fullLayout[trace.scene]._scene.container;\n var dx = container.offsetLeft;\n var dy = container.offsetTop;\n x0 += dx;\n x1 += dx;\n y0 += dy;\n y1 += dy;\n } // TODO: handle heatmapgl\n\n eventData.bbox = {\n x0: x0 + gLeft,\n x1: x1 + gLeft,\n y0: y0 + gTop,\n y1: y1 + gTop\n };\n\n if(opts.inOut_bbox) {\n opts.inOut_bbox.push(eventData.bbox);\n }\n } else {\n eventData = false;\n }\n\n return {\n color: hoverItem.color || Color.defaultLine,\n x0: hoverItem.x0 || hoverItem.x || 0,\n x1: hoverItem.x1 || hoverItem.x || 0,\n y0: hoverItem.y0 || hoverItem.y || 0,\n y1: hoverItem.y1 || hoverItem.y || 0,\n xLabel: hoverItem.xLabel,\n yLabel: hoverItem.yLabel,\n zLabel: hoverItem.zLabel,\n text: hoverItem.text,\n name: hoverItem.name,\n idealAlign: hoverItem.idealAlign,\n\n // optional extra bits of styling\n borderColor: hoverItem.borderColor,\n fontFamily: hoverItem.fontFamily,\n fontSize: hoverItem.fontSize,\n fontColor: hoverItem.fontColor,\n fontWeight: hoverItem.fontWeight,\n fontStyle: hoverItem.fontStyle,\n fontVariant: hoverItem.fontVariant,\n nameLength: hoverItem.nameLength,\n textAlign: hoverItem.textAlign,\n\n // filler to make createHoverText happy\n trace: hoverItem.trace || {\n index: 0,\n hoverinfo: ''\n },\n xa: {_offset: 0},\n ya: {_offset: 0},\n index: 0,\n\n hovertemplate: hoverItem.hovertemplate || false,\n hovertemplateLabels: hoverItem.hovertemplateLabels || false,\n\n eventData: eventData\n };\n });\n\n var rotateLabels = false;\n\n var hoverText = createHoverText(pointsData, {\n gd: gd,\n hovermode: 'closest',\n rotateLabels: rotateLabels,\n bgColor: opts.bgColor || Color.background,\n container: d3.select(opts.container),\n outerContainer: opts.outerContainer || opts.container\n });\n var hoverLabel = hoverText.hoverLabels;\n\n // Fix vertical overlap\n var tooltipSpacing = 5;\n var lastBottomY = 0;\n var anchor = 0;\n hoverLabel\n .sort(function(a, b) {return a.y0 - b.y0;})\n .each(function(d, i) {\n var topY = d.y0 - d.by / 2;\n\n if((topY - tooltipSpacing) < lastBottomY) {\n d.offset = (lastBottomY - topY) + tooltipSpacing;\n } else {\n d.offset = 0;\n }\n\n lastBottomY = topY + d.by + d.offset;\n\n if(i === opts.anchorIndex || 0) anchor = d.offset;\n })\n .each(function(d) {\n d.offset -= anchor;\n });\n\n var scaleX = gd._fullLayout._invScaleX;\n var scaleY = gd._fullLayout._invScaleY;\n alignHoverText(hoverLabel, rotateLabels, scaleX, scaleY);\n\n return multiHover ? hoverLabel : hoverLabel.node();\n};\n\n// The actual implementation is here:\nfunction _hover(gd, evt, subplot, noHoverEvent, eventTarget) {\n if(!subplot) subplot = 'xy';\n\n if(typeof subplot === 'string') {\n // drop zindex from subplot id\n subplot = subplot.split(zindexSeparator)[0];\n }\n\n // if the user passed in an array of subplots,\n // use those instead of finding overlayed plots\n var subplots = Array.isArray(subplot) ? subplot : [subplot];\n\n var spId;\n\n var fullLayout = gd._fullLayout;\n var hoversubplots = fullLayout.hoversubplots;\n var plots = fullLayout._plots || [];\n var plotinfo = plots[subplot];\n var hasCartesian = fullLayout._has('cartesian');\n\n var hovermode = evt.hovermode || fullLayout.hovermode;\n var hovermodeHasX = (hovermode || '').charAt(0) === 'x';\n var hovermodeHasY = (hovermode || '').charAt(0) === 'y';\n\n var firstXaxis;\n var firstYaxis;\n\n if(hasCartesian && (hovermodeHasX || hovermodeHasY) && hoversubplots === 'axis') {\n var subplotsLength = subplots.length;\n for(var p = 0; p < subplotsLength; p++) {\n spId = subplots[p];\n if(plots[spId]) {\n // 'cartesian' case\n\n firstXaxis = Axes.getFromId(gd, spId, 'x');\n firstYaxis = Axes.getFromId(gd, spId, 'y');\n\n var subplotsWith = (\n hovermodeHasX ? firstXaxis : firstYaxis\n )._subplotsWith;\n\n if(subplotsWith && subplotsWith.length) {\n for(var q = 0; q < subplotsWith.length; q++) {\n pushUnique(subplots, subplotsWith[q]);\n }\n }\n }\n }\n }\n\n // list of all overlaid subplots to look at\n if(plotinfo && hoversubplots !== 'single') {\n var overlayedSubplots = plotinfo.overlays.map(function(pi) {\n return pi.id;\n });\n\n subplots = subplots.concat(overlayedSubplots);\n }\n\n var len = subplots.length;\n var xaArray = new Array(len);\n var yaArray = new Array(len);\n var supportsCompare = false;\n\n for(var i = 0; i < len; i++) {\n spId = subplots[i];\n\n if(plots[spId]) {\n // 'cartesian' case\n supportsCompare = true;\n xaArray[i] = plots[spId].xaxis;\n yaArray[i] = plots[spId].yaxis;\n } else if(fullLayout[spId] && fullLayout[spId]._subplot) {\n // other subplot types\n var _subplot = fullLayout[spId]._subplot;\n xaArray[i] = _subplot.xaxis;\n yaArray[i] = _subplot.yaxis;\n } else {\n Lib.warn('Unrecognized subplot: ' + spId);\n return;\n }\n }\n\n if(hovermode && !supportsCompare) hovermode = 'closest';\n\n if(['x', 'y', 'closest', 'x unified', 'y unified'].indexOf(hovermode) === -1 || !gd.calcdata ||\n gd.querySelector('.zoombox') || gd._dragging) {\n return dragElement.unhoverRaw(gd, evt);\n }\n\n var hoverdistance = fullLayout.hoverdistance;\n if(hoverdistance === -1) hoverdistance = Infinity;\n\n var spikedistance = fullLayout.spikedistance;\n if(spikedistance === -1) spikedistance = Infinity;\n\n // hoverData: the set of candidate points we've found to highlight\n var hoverData = [];\n\n // searchData: the data to search in. Mostly this is just a copy of\n // gd.calcdata, filtered to the subplot and overlays we're on\n // but if a point array is supplied it will be a mapping\n // of indicated curves\n var searchData = [];\n\n // [x|y]valArray: the axis values of the hover event\n // mapped onto each of the currently selected overlaid subplots\n var xvalArray, yvalArray;\n\n var itemnum, curvenum, cd, trace, subplotId, subploti, _mode,\n xval, yval, pointData, closedataPreviousLength;\n\n // spikePoints: the set of candidate points we've found to draw spikes to\n var spikePoints = {\n hLinePoint: null,\n vLinePoint: null\n };\n\n // does subplot have one (or more) horizontal traces?\n // This is used to determine whether we rotate the labels or not\n var hasOneHorizontalTrace = false;\n\n // Figure out what we're hovering on:\n // mouse location or user-supplied data\n\n if(Array.isArray(evt)) {\n // user specified an array of points to highlight\n hovermode = 'array';\n for(itemnum = 0; itemnum < evt.length; itemnum++) {\n cd = gd.calcdata[evt[itemnum].curveNumber || 0];\n if(cd) {\n trace = cd[0].trace;\n if(cd[0].trace.hoverinfo !== 'skip') {\n searchData.push(cd);\n if(trace.orientation === 'h') {\n hasOneHorizontalTrace = true;\n }\n }\n }\n }\n } else {\n // take into account zorder\n var zorderedCalcdata = gd.calcdata.slice();\n zorderedCalcdata.sort(function(a, b) {\n var aZorder = a[0].trace.zorder || 0;\n var bZorder = b[0].trace.zorder || 0;\n return aZorder - bZorder;\n });\n\n for(curvenum = 0; curvenum < zorderedCalcdata.length; curvenum++) {\n cd = zorderedCalcdata[curvenum];\n trace = cd[0].trace;\n if(trace.hoverinfo !== 'skip' && helpers.isTraceInSubplots(trace, subplots)) {\n searchData.push(cd);\n if(trace.orientation === 'h') {\n hasOneHorizontalTrace = true;\n }\n }\n }\n\n // [x|y]px: the pixels (from top left) of the mouse location\n // on the currently selected plot area\n // add pointerX|Y property for drawing the spikes in spikesnap 'cursor' situation\n var hasUserCalledHover = !eventTarget;\n var xpx, ypx;\n\n if(hasUserCalledHover) {\n if('xpx' in evt) xpx = evt.xpx;\n else xpx = xaArray[0]._length / 2;\n\n if('ypx' in evt) ypx = evt.ypx;\n else ypx = yaArray[0]._length / 2;\n } else {\n // fire the beforehover event and quit if it returns false\n // note that we're only calling this on real mouse events, so\n // manual calls to fx.hover will always run.\n if(Events.triggerHandler(gd, 'plotly_beforehover', evt) === false) {\n return;\n }\n\n var dbb = eventTarget.getBoundingClientRect();\n\n xpx = evt.clientX - dbb.left;\n ypx = evt.clientY - dbb.top;\n\n fullLayout._calcInverseTransform(gd);\n var transformedCoords = Lib.apply3DTransform(fullLayout._invTransform)(xpx, ypx);\n\n xpx = transformedCoords[0];\n ypx = transformedCoords[1];\n\n // in case hover was called from mouseout into hovertext,\n // it's possible you're not actually over the plot anymore\n if(xpx < 0 || xpx > xaArray[0]._length || ypx < 0 || ypx > yaArray[0]._length) {\n return dragElement.unhoverRaw(gd, evt);\n }\n }\n\n evt.pointerX = xpx + xaArray[0]._offset;\n evt.pointerY = ypx + yaArray[0]._offset;\n\n if('xval' in evt) xvalArray = helpers.flat(subplots, evt.xval);\n else xvalArray = helpers.p2c(xaArray, xpx);\n\n if('yval' in evt) yvalArray = helpers.flat(subplots, evt.yval);\n else yvalArray = helpers.p2c(yaArray, ypx);\n\n if(!isNumeric(xvalArray[0]) || !isNumeric(yvalArray[0])) {\n Lib.warn('Fx.hover failed', evt, gd);\n return dragElement.unhoverRaw(gd, evt);\n }\n }\n\n // the pixel distance to beat as a matching point\n // in 'x' or 'y' mode this resets for each trace\n var distance = Infinity;\n\n // find the closest point in each trace\n // this is minimum dx and/or dy, depending on mode\n // and the pixel position for the label (labelXpx, labelYpx)\n function findHoverPoints(customXVal, customYVal) {\n for(curvenum = 0; curvenum < searchData.length; curvenum++) {\n cd = searchData[curvenum];\n\n // filter out invisible or broken data\n if(!cd || !cd[0] || !cd[0].trace) continue;\n\n trace = cd[0].trace;\n\n if(trace.visible !== true || trace._length === 0) continue;\n\n // Explicitly bail out for these two. I don't know how to otherwise prevent\n // the rest of this function from running and failing\n if(['carpet', 'contourcarpet'].indexOf(trace._module.name) !== -1) continue;\n\n // within one trace mode can sometimes be overridden\n _mode = hovermode;\n if(helpers.isUnifiedHover(_mode)) {\n _mode = _mode.charAt(0);\n }\n\n if(trace.type === 'splom') {\n // splom traces do not generate overlay subplots,\n // it is safe to assume here splom traces correspond to the 0th subplot\n subploti = 0;\n subplotId = subplots[subploti];\n } else {\n subplotId = helpers.getSubplot(trace);\n subploti = subplots.indexOf(subplotId);\n }\n\n // container for new point, also used to pass info into module.hoverPoints\n pointData = {\n // trace properties\n cd: cd,\n trace: trace,\n xa: xaArray[subploti],\n ya: yaArray[subploti],\n\n // max distances for hover and spikes - for points that want to show but do not\n // want to override other points, set distance/spikeDistance equal to max*Distance\n // and it will not get filtered out but it will be guaranteed to have a greater\n // distance than any point that calculated a real distance.\n maxHoverDistance: hoverdistance,\n maxSpikeDistance: spikedistance,\n\n // point properties - override all of these\n index: false, // point index in trace - only used by plotly.js hoverdata consumers\n distance: Math.min(distance, hoverdistance), // pixel distance or pseudo-distance\n\n // distance/pseudo-distance for spikes. This distance should always be calculated\n // as if in \"closest\" mode, and should only be set if this point should\n // generate a spike.\n spikeDistance: Infinity,\n\n // in some cases the spikes have different positioning from the hover label\n // they don't need x0/x1, just one position\n xSpike: undefined,\n ySpike: undefined,\n\n // where and how to display the hover label\n color: Color.defaultLine, // trace color\n name: trace.name,\n x0: undefined,\n x1: undefined,\n y0: undefined,\n y1: undefined,\n xLabelVal: undefined,\n yLabelVal: undefined,\n zLabelVal: undefined,\n text: undefined\n };\n\n // add ref to subplot object (non-cartesian case)\n if(fullLayout[subplotId]) {\n pointData.subplot = fullLayout[subplotId]._subplot;\n }\n // add ref to splom scene\n if(fullLayout._splomScenes && fullLayout._splomScenes[trace.uid]) {\n pointData.scene = fullLayout._splomScenes[trace.uid];\n }\n\n // for a highlighting array, figure out what\n // we're searching for with this element\n if(_mode === 'array') {\n var selection = evt[curvenum];\n if('pointNumber' in selection) {\n pointData.index = selection.pointNumber;\n _mode = 'closest';\n } else {\n _mode = '';\n if('xval' in selection) {\n xval = selection.xval;\n _mode = 'x';\n }\n if('yval' in selection) {\n yval = selection.yval;\n _mode = _mode ? 'closest' : 'y';\n }\n }\n } else if(customXVal !== undefined && customYVal !== undefined) {\n xval = customXVal;\n yval = customYVal;\n } else {\n xval = xvalArray[subploti];\n yval = yvalArray[subploti];\n }\n\n closedataPreviousLength = hoverData.length;\n\n // Now if there is range to look in, find the points to hover.\n if(hoverdistance !== 0) {\n if(trace._module && trace._module.hoverPoints) {\n var newPoints = trace._module.hoverPoints(pointData, xval, yval, _mode, {\n finiteRange: true,\n hoverLayer: fullLayout._hoverlayer,\n\n // options for splom when hovering on same axis\n hoversubplots: hoversubplots,\n gd: gd\n });\n\n if(newPoints) {\n var newPoint;\n for(var newPointNum = 0; newPointNum < newPoints.length; newPointNum++) {\n newPoint = newPoints[newPointNum];\n if(isNumeric(newPoint.x0) && isNumeric(newPoint.y0)) {\n hoverData.push(cleanPoint(newPoint, hovermode));\n }\n }\n }\n } else {\n Lib.log('Unrecognized trace type in hover:', trace);\n }\n }\n\n // in closest mode, remove any existing (farther) points\n // and don't look any farther than this latest point (or points, some\n // traces like box & violin make multiple hover labels at once)\n if(hovermode === 'closest' && hoverData.length > closedataPreviousLength) {\n hoverData.splice(0, closedataPreviousLength);\n distance = hoverData[0].distance;\n }\n\n // Now if there is range to look in, find the points to draw the spikelines\n // Do it only if there is no hoverData\n if(hasCartesian && (spikedistance !== 0)) {\n if(hoverData.length === 0) {\n pointData.distance = spikedistance;\n pointData.index = false;\n var closestPoints = trace._module.hoverPoints(pointData, xval, yval, 'closest', {\n hoverLayer: fullLayout._hoverlayer\n });\n if(closestPoints) {\n closestPoints = closestPoints.filter(function(point) {\n // some hover points, like scatter fills, do not allow spikes,\n // so will generate a hover point but without a valid spikeDistance\n return point.spikeDistance <= spikedistance;\n });\n }\n if(closestPoints && closestPoints.length) {\n var tmpPoint;\n var closestVPoints = closestPoints.filter(function(point) {\n return point.xa.showspikes && point.xa.spikesnap !== 'hovered data';\n });\n if(closestVPoints.length) {\n var closestVPt = closestVPoints[0];\n if(isNumeric(closestVPt.x0) && isNumeric(closestVPt.y0)) {\n tmpPoint = fillSpikePoint(closestVPt);\n if(!spikePoints.vLinePoint || (spikePoints.vLinePoint.spikeDistance > tmpPoint.spikeDistance)) {\n spikePoints.vLinePoint = tmpPoint;\n }\n }\n }\n\n var closestHPoints = closestPoints.filter(function(point) {\n return point.ya.showspikes && point.ya.spikesnap !== 'hovered data';\n });\n if(closestHPoints.length) {\n var closestHPt = closestHPoints[0];\n if(isNumeric(closestHPt.x0) && isNumeric(closestHPt.y0)) {\n tmpPoint = fillSpikePoint(closestHPt);\n if(!spikePoints.hLinePoint || (spikePoints.hLinePoint.spikeDistance > tmpPoint.spikeDistance)) {\n spikePoints.hLinePoint = tmpPoint;\n }\n }\n }\n }\n }\n }\n }\n }\n\n findHoverPoints();\n\n function selectClosestPoint(pointsData, spikedistance, spikeOnWinning) {\n var resultPoint = null;\n var minDistance = Infinity;\n var thisSpikeDistance;\n\n for(var i = 0; i < pointsData.length; i++) {\n if(firstXaxis && firstXaxis._id !== pointsData[i].xa._id) continue;\n if(firstYaxis && firstYaxis._id !== pointsData[i].ya._id) continue;\n\n thisSpikeDistance = pointsData[i].spikeDistance;\n if(spikeOnWinning && i === 0) thisSpikeDistance = -Infinity;\n\n if(thisSpikeDistance <= minDistance && thisSpikeDistance <= spikedistance) {\n resultPoint = pointsData[i];\n minDistance = thisSpikeDistance;\n }\n }\n return resultPoint;\n }\n\n function fillSpikePoint(point) {\n if(!point) return null;\n return {\n xa: point.xa,\n ya: point.ya,\n x: point.xSpike !== undefined ? point.xSpike : (point.x0 + point.x1) / 2,\n y: point.ySpike !== undefined ? point.ySpike : (point.y0 + point.y1) / 2,\n distance: point.distance,\n spikeDistance: point.spikeDistance,\n curveNumber: point.trace.index,\n color: point.color,\n pointNumber: point.index\n };\n }\n\n var spikelineOpts = {\n fullLayout: fullLayout,\n container: fullLayout._hoverlayer,\n event: evt\n };\n var oldspikepoints = gd._spikepoints;\n var newspikepoints = {\n vLinePoint: spikePoints.vLinePoint,\n hLinePoint: spikePoints.hLinePoint\n };\n gd._spikepoints = newspikepoints;\n\n var sortHoverData = function() {\n // When sorting keep the points in the main subplot at the top\n // then add points in other subplots\n\n var hoverDataInSubplot = hoverData.filter(function(a) {\n return (\n (firstXaxis && firstXaxis._id === a.xa._id) &&\n (firstYaxis && firstYaxis._id === a.ya._id)\n );\n });\n\n var hoverDataOutSubplot = hoverData.filter(function(a) {\n return !(\n (firstXaxis && firstXaxis._id === a.xa._id) &&\n (firstYaxis && firstYaxis._id === a.ya._id)\n );\n });\n\n hoverDataInSubplot.sort(distanceSort);\n hoverDataOutSubplot.sort(distanceSort);\n hoverData = hoverDataInSubplot.concat(hoverDataOutSubplot);\n\n // move period positioned points and box/bar-like traces to the end of the list\n hoverData = orderRangePoints(hoverData, hovermode);\n };\n sortHoverData();\n\n var axLetter = hovermode.charAt(0);\n var spikeOnWinning = (axLetter === 'x' || axLetter === 'y') && hoverData[0] && cartesianScatterPoints[hoverData[0].trace.type];\n\n // Now if it is not restricted by spikedistance option, set the points to draw the spikelines\n if(hasCartesian && (spikedistance !== 0)) {\n if(hoverData.length !== 0) {\n var tmpHPointData = hoverData.filter(function(point) {\n return point.ya.showspikes;\n });\n var tmpHPoint = selectClosestPoint(tmpHPointData, spikedistance, spikeOnWinning);\n spikePoints.hLinePoint = fillSpikePoint(tmpHPoint);\n\n var tmpVPointData = hoverData.filter(function(point) {\n return point.xa.showspikes;\n });\n var tmpVPoint = selectClosestPoint(tmpVPointData, spikedistance, spikeOnWinning);\n spikePoints.vLinePoint = fillSpikePoint(tmpVPoint);\n }\n }\n\n // if hoverData is empty check for the spikes to draw and quit if there are none\n if(hoverData.length === 0) {\n var result = dragElement.unhoverRaw(gd, evt);\n if(hasCartesian && ((spikePoints.hLinePoint !== null) || (spikePoints.vLinePoint !== null))) {\n if(spikesChanged(oldspikepoints)) {\n createSpikelines(gd, spikePoints, spikelineOpts);\n }\n }\n return result;\n }\n\n if(hasCartesian) {\n if(spikesChanged(oldspikepoints)) {\n createSpikelines(gd, spikePoints, spikelineOpts);\n }\n }\n\n if(\n helpers.isXYhover(_mode) &&\n hoverData[0].length !== 0 &&\n hoverData[0].trace.type !== 'splom' // TODO: add support for splom\n ) {\n // pick winning point\n var winningPoint = hoverData[0];\n // discard other points\n if(multipleHoverPoints[winningPoint.trace.type]) {\n hoverData = hoverData.filter(function(d) {\n return d.trace.index === winningPoint.trace.index;\n });\n } else {\n hoverData = [winningPoint];\n }\n var initLen = hoverData.length;\n\n var winX = getCoord('x', winningPoint, fullLayout);\n var winY = getCoord('y', winningPoint, fullLayout);\n\n // in compare mode, select every point at position\n findHoverPoints(winX, winY);\n\n var finalPoints = [];\n var seen = {};\n var id = 0;\n var insert = function(newHd) {\n var key = multipleHoverPoints[newHd.trace.type] ? hoverDataKey(newHd) : newHd.trace.index;\n if(!seen[key]) {\n id++;\n seen[key] = id;\n finalPoints.push(newHd);\n } else {\n var oldId = seen[key] - 1;\n var oldHd = finalPoints[oldId];\n if(oldId > 0 &&\n Math.abs(newHd.distance) <\n Math.abs(oldHd.distance)\n ) {\n // replace with closest\n finalPoints[oldId] = newHd;\n }\n }\n };\n\n var k;\n // insert the winnig point(s) first\n for(k = 0; k < initLen; k++) {\n insert(hoverData[k]);\n }\n // override from the end\n for(k = hoverData.length - 1; k > initLen - 1; k--) {\n insert(hoverData[k]);\n }\n hoverData = finalPoints;\n sortHoverData();\n }\n\n // lastly, emit custom hover/unhover events\n var oldhoverdata = gd._hoverdata;\n var newhoverdata = [];\n\n var gTop = getTopOffset(gd);\n var gLeft = getLeftOffset(gd);\n\n // pull out just the data that's useful to\n // other people and send it to the event\n for(itemnum = 0; itemnum < hoverData.length; itemnum++) {\n var pt = hoverData[itemnum];\n var eventData = helpers.makeEventData(pt, pt.trace, pt.cd);\n\n if(pt.hovertemplate !== false) {\n var ht = false;\n if(pt.cd[pt.index] && pt.cd[pt.index].ht) {\n ht = pt.cd[pt.index].ht;\n }\n pt.hovertemplate = ht || pt.trace.hovertemplate || false;\n }\n\n if(pt.xa && pt.ya) {\n var _x0 = pt.x0 + pt.xa._offset;\n var _x1 = pt.x1 + pt.xa._offset;\n var _y0 = pt.y0 + pt.ya._offset;\n var _y1 = pt.y1 + pt.ya._offset;\n\n var x0 = Math.min(_x0, _x1);\n var x1 = Math.max(_x0, _x1);\n var y0 = Math.min(_y0, _y1);\n var y1 = Math.max(_y0, _y1);\n\n eventData.bbox = {\n x0: x0 + gLeft,\n x1: x1 + gLeft,\n y0: y0 + gTop,\n y1: y1 + gTop\n };\n }\n\n pt.eventData = [eventData];\n newhoverdata.push(eventData);\n }\n\n gd._hoverdata = newhoverdata;\n\n var rotateLabels = (\n (hovermode === 'y' && (searchData.length > 1 || hoverData.length > 1)) ||\n (hovermode === 'closest' && hasOneHorizontalTrace && hoverData.length > 1)\n );\n\n var bgColor = Color.combine(\n fullLayout.plot_bgcolor || Color.background,\n fullLayout.paper_bgcolor\n );\n\n var hoverText = createHoverText(hoverData, {\n gd: gd,\n hovermode: hovermode,\n rotateLabels: rotateLabels,\n bgColor: bgColor,\n container: fullLayout._hoverlayer,\n outerContainer: fullLayout._paper.node(),\n commonLabelOpts: fullLayout.hoverlabel,\n hoverdistance: fullLayout.hoverdistance\n });\n var hoverLabels = hoverText.hoverLabels;\n\n if(!helpers.isUnifiedHover(hovermode)) {\n hoverAvoidOverlaps(hoverLabels, rotateLabels, fullLayout, hoverText.commonLabelBoundingBox);\n alignHoverText(hoverLabels, rotateLabels, fullLayout._invScaleX, fullLayout._invScaleY);\n } // TODO: tagName hack is needed to appease geo.js's hack of using eventTarget=true\n // we should improve the \"fx\" API so other plots can use it without these hack.\n if(eventTarget && eventTarget.tagName) {\n var hasClickToShow = Registry.getComponentMethod('annotations', 'hasClickToShow')(gd, newhoverdata);\n overrideCursor(d3.select(eventTarget), hasClickToShow ? 'pointer' : '');\n }\n\n // don't emit events if called manually\n if(!eventTarget || noHoverEvent || !hoverChanged(gd, evt, oldhoverdata)) return;\n\n if(oldhoverdata) {\n gd.emit('plotly_unhover', {\n event: evt,\n points: oldhoverdata\n });\n }\n\n gd.emit('plotly_hover', {\n event: evt,\n points: gd._hoverdata,\n xaxes: xaArray,\n yaxes: yaArray,\n xvals: xvalArray,\n yvals: yvalArray\n });\n}\n\nfunction hoverDataKey(d) {\n return [d.trace.index, d.index, d.x0, d.y0, d.name, d.attr, d.xa ? d.xa._id : '', d.ya ? d.ya._id : ''].join(',');\n}\n\nvar EXTRA_STRING_REGEX = /([\\s\\S]*)<\\/extra>/;\n\nfunction createHoverText(hoverData, opts) {\n var gd = opts.gd;\n var fullLayout = gd._fullLayout;\n var hovermode = opts.hovermode;\n var rotateLabels = opts.rotateLabels;\n var bgColor = opts.bgColor;\n var container = opts.container;\n var outerContainer = opts.outerContainer;\n var commonLabelOpts = opts.commonLabelOpts || {};\n // Early exit if no labels are drawn\n if(hoverData.length === 0) return [[]];\n\n // opts.fontFamily/Size are used for the common label\n // and as defaults for each hover label, though the individual labels\n // can override this.\n var fontFamily = opts.fontFamily || constants.HOVERFONT;\n var fontSize = opts.fontSize || constants.HOVERFONTSIZE;\n var fontWeight = opts.fontWeight || fullLayout.font.weight;\n var fontStyle = opts.fontStyle || fullLayout.font.style;\n var fontVariant = opts.fontVariant || fullLayout.font.variant;\n var fontTextcase = opts.fontTextcase || fullLayout.font.textcase;\n var fontLineposition = opts.fontLineposition || fullLayout.font.lineposition;\n var fontShadow = opts.fontShadow || fullLayout.font.shadow;\n\n var c0 = hoverData[0];\n var xa = c0.xa;\n var ya = c0.ya;\n var axLetter = hovermode.charAt(0);\n var axLabel = axLetter + 'Label';\n var t0 = c0[axLabel];\n\n // search in array for the label\n if(t0 === undefined && xa.type === 'multicategory') {\n for(var q = 0; q < hoverData.length; q++) {\n t0 = hoverData[q][axLabel];\n if(t0 !== undefined) break;\n }\n }\n\n var outerContainerBB = getBoundingClientRect(gd, outerContainer);\n var outerTop = outerContainerBB.top;\n var outerWidth = outerContainerBB.width;\n var outerHeight = outerContainerBB.height;\n\n // show the common label, if any, on the axis\n // never show a common label in array mode,\n // even if sometimes there could be one\n var showCommonLabel = (\n (t0 !== undefined) &&\n (c0.distance <= opts.hoverdistance) &&\n (hovermode === 'x' || hovermode === 'y')\n );\n\n // all hover traces hoverinfo must contain the hovermode\n // to have common labels\n if(showCommonLabel) {\n var allHaveZ = true;\n var i, traceHoverinfo;\n for(i = 0; i < hoverData.length; i++) {\n if(allHaveZ && hoverData[i].zLabel === undefined) allHaveZ = false;\n\n traceHoverinfo = hoverData[i].hoverinfo || hoverData[i].trace.hoverinfo;\n if(traceHoverinfo) {\n var parts = Array.isArray(traceHoverinfo) ? traceHoverinfo : traceHoverinfo.split('+');\n if(parts.indexOf('all') === -1 &&\n parts.indexOf(hovermode) === -1) {\n showCommonLabel = false;\n break;\n }\n }\n }\n\n // xyz labels put all info in their main label, so have no need of a common label\n if(allHaveZ) showCommonLabel = false;\n }\n\n var commonLabel = container.selectAll('g.axistext')\n .data(showCommonLabel ? [0] : []);\n commonLabel.enter().append('g')\n .classed('axistext', true);\n commonLabel.exit().remove();\n\n // set rect (without arrow) behind label below for later collision detection\n var commonLabelRect = {\n minX: 0,\n maxX: 0,\n minY: 0,\n maxY: 0\n };\n commonLabel.each(function() {\n var label = d3.select(this);\n var lpath = Lib.ensureSingle(label, 'path', '', function(s) {\n s.style({'stroke-width': '1px'});\n });\n var ltext = Lib.ensureSingle(label, 'text', '', function(s) {\n // prohibit tex interpretation until we can handle\n // tex and regular text together\n s.attr('data-notex', 1);\n });\n\n var commonBgColor = commonLabelOpts.bgcolor || Color.defaultLine;\n var commonStroke = commonLabelOpts.bordercolor || Color.contrast(commonBgColor);\n var contrastColor = Color.contrast(commonBgColor);\n var commonLabelOptsFont = commonLabelOpts.font;\n var commonLabelFont = {\n weight: commonLabelOptsFont.weight || fontWeight,\n style: commonLabelOptsFont.style || fontStyle,\n variant: commonLabelOptsFont.variant || fontVariant,\n textcase: commonLabelOptsFont.textcase || fontTextcase,\n lineposition: commonLabelOptsFont.lineposition || fontLineposition,\n shadow: commonLabelOptsFont.shadow || fontShadow,\n family: commonLabelOptsFont.family || fontFamily,\n size: commonLabelOptsFont.size || fontSize,\n color: commonLabelOptsFont.color || contrastColor\n };\n\n lpath.style({\n fill: commonBgColor,\n stroke: commonStroke\n });\n\n ltext.text(t0)\n .call(Drawing.font, commonLabelFont)\n .call(svgTextUtils.positionText, 0, 0)\n .call(svgTextUtils.convertToTspans, gd);\n\n label.attr('transform', '');\n\n var tbb = getBoundingClientRect(gd, ltext.node());\n var lx, ly;\n\n if(hovermode === 'x') {\n var topsign = xa.side === 'top' ? '-' : '';\n\n ltext.attr('text-anchor', 'middle')\n .call(svgTextUtils.positionText, 0, (xa.side === 'top' ?\n (outerTop - tbb.bottom - HOVERARROWSIZE - HOVERTEXTPAD) :\n (outerTop - tbb.top + HOVERARROWSIZE + HOVERTEXTPAD)));\n\n lx = xa._offset + (c0.x0 + c0.x1) / 2;\n ly = ya._offset + (xa.side === 'top' ? 0 : ya._length);\n\n var halfWidth = tbb.width / 2 + HOVERTEXTPAD;\n\n var tooltipMidX = lx;\n if(lx < halfWidth) {\n tooltipMidX = halfWidth;\n } else if(lx > (fullLayout.width - halfWidth)) {\n tooltipMidX = fullLayout.width - halfWidth;\n }\n\n lpath.attr('d', 'M' + (lx - tooltipMidX) + ',0' +\n 'L' + (lx - tooltipMidX + HOVERARROWSIZE) + ',' + topsign + HOVERARROWSIZE +\n 'H' + halfWidth +\n 'v' + topsign + (HOVERTEXTPAD * 2 + tbb.height) +\n 'H' + (-halfWidth) +\n 'V' + topsign + HOVERARROWSIZE +\n 'H' + (lx - tooltipMidX - HOVERARROWSIZE) +\n 'Z');\n\n lx = tooltipMidX;\n commonLabelRect.minX = lx - halfWidth;\n commonLabelRect.maxX = lx + halfWidth;\n if(xa.side === 'top') {\n // label on negative y side\n commonLabelRect.minY = ly - (HOVERTEXTPAD * 2 + tbb.height);\n commonLabelRect.maxY = ly - HOVERTEXTPAD;\n } else {\n commonLabelRect.minY = ly + HOVERTEXTPAD;\n commonLabelRect.maxY = ly + (HOVERTEXTPAD * 2 + tbb.height);\n }\n } else {\n var anchor;\n var sgn;\n var leftsign;\n if(ya.side === 'right') {\n anchor = 'start';\n sgn = 1;\n leftsign = '';\n lx = xa._offset + xa._length;\n } else {\n anchor = 'end';\n sgn = -1;\n leftsign = '-';\n lx = xa._offset;\n }\n\n ly = ya._offset + (c0.y0 + c0.y1) / 2;\n\n ltext.attr('text-anchor', anchor);\n\n lpath.attr('d', 'M0,0' +\n 'L' + leftsign + HOVERARROWSIZE + ',' + HOVERARROWSIZE +\n 'V' + (HOVERTEXTPAD + tbb.height / 2) +\n 'h' + leftsign + (HOVERTEXTPAD * 2 + tbb.width) +\n 'V-' + (HOVERTEXTPAD + tbb.height / 2) +\n 'H' + leftsign + HOVERARROWSIZE + 'V-' + HOVERARROWSIZE + 'Z');\n\n commonLabelRect.minY = ly - (HOVERTEXTPAD + tbb.height / 2);\n commonLabelRect.maxY = ly + (HOVERTEXTPAD + tbb.height / 2);\n if(ya.side === 'right') {\n commonLabelRect.minX = lx + HOVERARROWSIZE;\n commonLabelRect.maxX = lx + HOVERARROWSIZE + (HOVERTEXTPAD * 2 + tbb.width);\n } else {\n // label on negative x side\n commonLabelRect.minX = lx - HOVERARROWSIZE - (HOVERTEXTPAD * 2 + tbb.width);\n commonLabelRect.maxX = lx - HOVERARROWSIZE;\n }\n\n var halfHeight = tbb.height / 2;\n var lty = outerTop - tbb.top - halfHeight;\n var clipId = 'clip' + fullLayout._uid + 'commonlabel' + ya._id;\n var clipPath;\n\n if(lx < (tbb.width + 2 * HOVERTEXTPAD + HOVERARROWSIZE)) {\n clipPath = 'M-' + (HOVERARROWSIZE + HOVERTEXTPAD) + '-' + halfHeight +\n 'h-' + (tbb.width - HOVERTEXTPAD) +\n 'V' + halfHeight +\n 'h' + (tbb.width - HOVERTEXTPAD) + 'Z';\n\n var ltx = tbb.width - lx + HOVERTEXTPAD;\n svgTextUtils.positionText(ltext, ltx, lty);\n\n // shift each line (except the longest) so that start-of-line\n // is always visible\n if(anchor === 'end') {\n ltext.selectAll('tspan').each(function() {\n var s = d3.select(this);\n var dummy = Drawing.tester.append('text')\n .text(s.text())\n .call(Drawing.font, commonLabelFont);\n var dummyBB = getBoundingClientRect(gd, dummy.node());\n if(Math.round(dummyBB.width) < Math.round(tbb.width)) {\n s.attr('x', ltx - dummyBB.width);\n }\n dummy.remove();\n });\n }\n } else {\n svgTextUtils.positionText(ltext, sgn * (HOVERTEXTPAD + HOVERARROWSIZE), lty);\n clipPath = null;\n }\n\n var textClip = fullLayout._topclips.selectAll('#' + clipId).data(clipPath ? [0] : []);\n textClip.enter().append('clipPath').attr('id', clipId).append('path');\n textClip.exit().remove();\n textClip.select('path').attr('d', clipPath);\n Drawing.setClipUrl(ltext, clipPath ? clipId : null, gd);\n }\n\n label.attr('transform', strTranslate(lx, ly));\n });\n\n // Show a single hover label\n if(helpers.isUnifiedHover(hovermode)) {\n // Delete leftover hover labels from other hovermodes\n container.selectAll('g.hovertext').remove();\n var groupedHoverData = hoverData.filter(function(data) {return data.hoverinfo !== 'none';});\n // Return early if nothing is hovered on\n if(groupedHoverData.length === 0) return [];\n\n // mock legend\n var hoverlabel = fullLayout.hoverlabel;\n var font = hoverlabel.font;\n var mockLayoutIn = {\n showlegend: true,\n legend: {\n title: {text: t0, font: font},\n font: font,\n bgcolor: hoverlabel.bgcolor,\n bordercolor: hoverlabel.bordercolor,\n borderwidth: 1,\n tracegroupgap: 7,\n traceorder: fullLayout.legend ? fullLayout.legend.traceorder : undefined,\n orientation: 'v'\n }\n };\n var mockLayoutOut = {\n font: font\n };\n legendSupplyDefaults(mockLayoutIn, mockLayoutOut, gd._fullData);\n var mockLegend = mockLayoutOut.legend;\n\n // prepare items for the legend\n mockLegend.entries = [];\n for(var j = 0; j < groupedHoverData.length; j++) {\n var pt = groupedHoverData[j];\n if(pt.hoverinfo === 'none') continue;\n\n var texts = getHoverLabelText(pt, true, hovermode, fullLayout, t0);\n var text = texts[0];\n var name = texts[1];\n\n pt.name = name;\n if(name !== '') {\n pt.text = name + ' : ' + text;\n } else {\n pt.text = text;\n }\n\n // pass through marker's calcdata to style legend items\n var cd = pt.cd[pt.index];\n if(cd) {\n if(cd.mc) pt.mc = cd.mc;\n if(cd.mcc) pt.mc = cd.mcc;\n if(cd.mlc) pt.mlc = cd.mlc;\n if(cd.mlcc) pt.mlc = cd.mlcc;\n if(cd.mlw) pt.mlw = cd.mlw;\n if(cd.mrc) pt.mrc = cd.mrc;\n if(cd.dir) pt.dir = cd.dir;\n }\n pt._distinct = true;\n\n mockLegend.entries.push([pt]);\n }\n mockLegend.entries.sort(function(a, b) { return a[0].trace.index - b[0].trace.index;});\n mockLegend.layer = container;\n\n // Draw unified hover label\n mockLegend._inHover = true;\n mockLegend._groupTitleFont = hoverlabel.grouptitlefont;\n\n legendDraw(gd, mockLegend);\n\n // Position the hover\n var legendContainer = container.select('g.legend');\n var tbb = getBoundingClientRect(gd, legendContainer.node());\n var tWidth = tbb.width + 2 * HOVERTEXTPAD;\n var tHeight = tbb.height + 2 * HOVERTEXTPAD;\n var winningPoint = groupedHoverData[0];\n var avgX = (winningPoint.x0 + winningPoint.x1) / 2;\n var avgY = (winningPoint.y0 + winningPoint.y1) / 2;\n // When a scatter (or e.g. heatmap) point wins, it's OK for the hovelabel to occlude the bar and other points.\n var pointWon = !(\n Registry.traceIs(winningPoint.trace, 'bar-like') ||\n Registry.traceIs(winningPoint.trace, 'box-violin')\n );\n\n var lyBottom, lyTop;\n if(axLetter === 'y') {\n if(pointWon) {\n lyTop = avgY - HOVERTEXTPAD;\n lyBottom = avgY + HOVERTEXTPAD;\n } else {\n lyTop = Math.min.apply(null, groupedHoverData.map(function(c) { return Math.min(c.y0, c.y1); }));\n lyBottom = Math.max.apply(null, groupedHoverData.map(function(c) { return Math.max(c.y0, c.y1); }));\n }\n } else {\n lyTop = lyBottom = Lib.mean(groupedHoverData.map(function(c) { return (c.y0 + c.y1) / 2; })) - tHeight / 2;\n }\n\n var lxRight, lxLeft;\n if(axLetter === 'x') {\n if(pointWon) {\n lxRight = avgX + HOVERTEXTPAD;\n lxLeft = avgX - HOVERTEXTPAD;\n } else {\n lxRight = Math.max.apply(null, groupedHoverData.map(function(c) { return Math.max(c.x0, c.x1); }));\n lxLeft = Math.min.apply(null, groupedHoverData.map(function(c) { return Math.min(c.x0, c.x1); }));\n }\n } else {\n lxRight = lxLeft = Lib.mean(groupedHoverData.map(function(c) { return (c.x0 + c.x1) / 2; })) - tWidth / 2;\n }\n\n var xOffset = xa._offset;\n var yOffset = ya._offset;\n lyBottom += yOffset;\n lxRight += xOffset;\n lxLeft += xOffset - tWidth;\n lyTop += yOffset - tHeight;\n\n var lx, ly; // top and left positions of the hover box\n\n // horizontal alignment to end up on screen\n if(lxRight + tWidth < outerWidth && lxRight >= 0) {\n lx = lxRight;\n } else if(lxLeft + tWidth < outerWidth && lxLeft >= 0) {\n lx = lxLeft;\n } else if(xOffset + tWidth < outerWidth) {\n lx = xOffset; // subplot left corner\n } else {\n // closest left or right side of the paper\n if(lxRight - avgX < avgX - lxLeft + tWidth) {\n lx = outerWidth - tWidth;\n } else {\n lx = 0;\n }\n }\n lx += HOVERTEXTPAD;\n\n // vertical alignement to end up on screen\n if(lyBottom + tHeight < outerHeight && lyBottom >= 0) {\n ly = lyBottom;\n } else if(lyTop + tHeight < outerHeight && lyTop >= 0) {\n ly = lyTop;\n } else if(yOffset + tHeight < outerHeight) {\n ly = yOffset; // subplot top corner\n } else {\n // closest top or bottom side of the paper\n if(lyBottom - avgY < avgY - lyTop + tHeight) {\n ly = outerHeight - tHeight;\n } else {\n ly = 0;\n }\n }\n ly += HOVERTEXTPAD;\n\n legendContainer.attr('transform', strTranslate(lx - 1, ly - 1));\n return legendContainer;\n }\n\n // show all the individual labels\n\n // first create the objects\n var hoverLabels = container.selectAll('g.hovertext')\n .data(hoverData, function(d) {\n // N.B. when multiple items have the same result key-function value,\n // only the first of those items in hoverData gets rendered\n return hoverDataKey(d);\n });\n hoverLabels.enter().append('g')\n .classed('hovertext', true)\n .each(function() {\n var g = d3.select(this);\n // trace name label (rect and text.name)\n g.append('rect')\n .call(Color.fill, Color.addOpacity(bgColor, 0.8));\n g.append('text').classed('name', true);\n // trace data label (path and text.nums)\n g.append('path')\n .style('stroke-width', '1px');\n g.append('text').classed('nums', true)\n .call(Drawing.font, {\n weight: fontWeight,\n style: fontStyle,\n variant: fontVariant,\n textcase: fontTextcase,\n lineposition: fontLineposition,\n shadow: fontShadow,\n family: fontFamily,\n size: fontSize\n });\n });\n hoverLabels.exit().remove();\n\n // then put the text in, position the pointer to the data,\n // and figure out sizes\n hoverLabels.each(function(d) {\n var g = d3.select(this).attr('transform', '');\n\n var dColor = d.color;\n if(Array.isArray(dColor)) {\n dColor = dColor[d.eventData[0].pointNumber];\n }\n\n // combine possible non-opaque trace color with bgColor\n var color0 = d.bgcolor || dColor;\n // color for 'nums' part of the label\n var numsColor = Color.combine(\n Color.opacity(color0) ? color0 : Color.defaultLine,\n bgColor\n );\n // color for 'name' part of the label\n var nameColor = Color.combine(\n Color.opacity(dColor) ? dColor : Color.defaultLine,\n bgColor\n );\n // find a contrasting color for border and text\n var contrastColor = d.borderColor || Color.contrast(numsColor);\n\n var texts = getHoverLabelText(d, showCommonLabel, hovermode, fullLayout, t0, g);\n var text = texts[0];\n var name = texts[1];\n\n // main label\n var tx = g.select('text.nums')\n .call(Drawing.font, {\n family: d.fontFamily || fontFamily,\n size: d.fontSize || fontSize,\n color: d.fontColor || contrastColor,\n weight: d.fontWeight || fontWeight,\n style: d.fontStyle || fontStyle,\n variant: d.fontVariant || fontVariant,\n textcase: d.fontTextcase || fontTextcase,\n lineposition: d.fontLineposition || fontLineposition,\n shadow: d.fontShadow || fontShadow,\n })\n .text(text)\n .attr('data-notex', 1)\n .call(svgTextUtils.positionText, 0, 0)\n .call(svgTextUtils.convertToTspans, gd);\n\n var tx2 = g.select('text.name');\n var tx2width = 0;\n var tx2height = 0;\n\n // secondary label for non-empty 'name'\n if(name && name !== text) {\n tx2.call(Drawing.font, {\n family: d.fontFamily || fontFamily,\n size: d.fontSize || fontSize,\n color: nameColor,\n weight: d.fontWeight || fontWeight,\n style: d.fontStyle || fontStyle,\n variant: d.fontVariant || fontVariant,\n textcase: d.fontTextcase || fontTextcase,\n lineposition: d.fontLineposition || fontLineposition,\n shadow: d.fontShadow || fontShadow,\n }).text(name)\n .attr('data-notex', 1)\n .call(svgTextUtils.positionText, 0, 0)\n .call(svgTextUtils.convertToTspans, gd);\n\n var t2bb = getBoundingClientRect(gd, tx2.node());\n tx2width = t2bb.width + 2 * HOVERTEXTPAD;\n tx2height = t2bb.height + 2 * HOVERTEXTPAD;\n } else {\n tx2.remove();\n g.select('rect').remove();\n }\n\n g.select('path').style({\n fill: numsColor,\n stroke: contrastColor\n });\n\n var htx = d.xa._offset + (d.x0 + d.x1) / 2;\n var hty = d.ya._offset + (d.y0 + d.y1) / 2;\n var dx = Math.abs(d.x1 - d.x0);\n var dy = Math.abs(d.y1 - d.y0);\n\n var tbb = getBoundingClientRect(gd, tx.node());\n var tbbWidth = tbb.width / fullLayout._invScaleX;\n var tbbHeight = tbb.height / fullLayout._invScaleY;\n\n d.ty0 = (outerTop - tbb.top) / fullLayout._invScaleY;\n d.bx = tbbWidth + 2 * HOVERTEXTPAD;\n d.by = Math.max(tbbHeight + 2 * HOVERTEXTPAD, tx2height);\n d.anchor = 'start';\n d.txwidth = tbbWidth;\n d.tx2width = tx2width;\n d.offset = 0;\n\n var txTotalWidth = (tbbWidth + HOVERARROWSIZE + HOVERTEXTPAD + tx2width) * fullLayout._invScaleX;\n var anchorStartOK, anchorEndOK;\n\n if(rotateLabels) {\n d.pos = htx;\n anchorStartOK = hty + dy / 2 + txTotalWidth <= outerHeight;\n anchorEndOK = hty - dy / 2 - txTotalWidth >= 0;\n if((d.idealAlign === 'top' || !anchorStartOK) && anchorEndOK) {\n hty -= dy / 2;\n d.anchor = 'end';\n } else if(anchorStartOK) {\n hty += dy / 2;\n d.anchor = 'start';\n } else {\n d.anchor = 'middle';\n }\n d.crossPos = hty;\n } else {\n d.pos = hty;\n anchorStartOK = htx + dx / 2 + txTotalWidth <= outerWidth;\n anchorEndOK = htx - dx / 2 - txTotalWidth >= 0;\n\n if((d.idealAlign === 'left' || !anchorStartOK) && anchorEndOK) {\n htx -= dx / 2;\n d.anchor = 'end';\n } else if(anchorStartOK) {\n htx += dx / 2;\n d.anchor = 'start';\n } else {\n d.anchor = 'middle';\n\n var txHalfWidth = txTotalWidth / 2;\n var overflowR = htx + txHalfWidth - outerWidth;\n var overflowL = htx - txHalfWidth;\n if(overflowR > 0) htx -= overflowR;\n if(overflowL < 0) htx += -overflowL;\n }\n d.crossPos = htx;\n }\n\n tx.attr('text-anchor', d.anchor);\n if(tx2width) tx2.attr('text-anchor', d.anchor);\n g.attr('transform', strTranslate(htx, hty) +\n (rotateLabels ? strRotate(YANGLE) : ''));\n });\n\n return {\n hoverLabels: hoverLabels,\n commonLabelBoundingBox: commonLabelRect\n };\n}\n\nfunction getHoverLabelText(d, showCommonLabel, hovermode, fullLayout, t0, g) {\n var name = '';\n var text = '';\n // to get custom 'name' labels pass cleanPoint\n if(d.nameOverride !== undefined) d.name = d.nameOverride;\n\n if(d.name) {\n if(d.trace._meta) {\n d.name = Lib.templateString(d.name, d.trace._meta);\n }\n name = plainText(d.name, d.nameLength);\n }\n\n var h0 = hovermode.charAt(0);\n var h1 = h0 === 'x' ? 'y' : 'x';\n\n if(d.zLabel !== undefined) {\n if(d.xLabel !== undefined) text += 'x: ' + d.xLabel + '
';\n if(d.yLabel !== undefined) text += 'y: ' + d.yLabel + '
';\n if(\n d.trace.type !== 'choropleth' &&\n d.trace.type !== 'choroplethmapbox' &&\n d.trace.type !== 'choroplethmap'\n ) {\n text += (text ? 'z: ' : '') + d.zLabel;\n }\n } else if(showCommonLabel && d[h0 + 'Label'] === t0) {\n text = d[h1 + 'Label'] || '';\n } else if(d.xLabel === undefined) {\n if(d.yLabel !== undefined && d.trace.type !== 'scattercarpet') {\n text = d.yLabel;\n }\n } else if(d.yLabel === undefined) text = d.xLabel;\n else text = '(' + d.xLabel + ', ' + d.yLabel + ')';\n\n if((d.text || d.text === 0) && !Array.isArray(d.text)) {\n text += (text ? '
' : '') + d.text;\n }\n\n // used by other modules (initially just ternary) that\n // manage their own hoverinfo independent of cleanPoint\n // the rest of this will still apply, so such modules\n // can still put things in (x|y|z)Label, text, and name\n // and hoverinfo will still determine their visibility\n if(d.extraText !== undefined) text += (text ? '
' : '') + d.extraText;\n\n // if 'text' is empty at this point,\n // and hovertemplate is not defined,\n // put 'name' in main label and don't show secondary label\n if(g && text === '' && !d.hovertemplate) {\n // if 'name' is also empty, remove entire label\n if(name === '') g.remove();\n text = name;\n }\n\n // hovertemplate\n var hovertemplate = d.hovertemplate || false;\n if(hovertemplate) {\n var labels = d.hovertemplateLabels || d;\n\n if(d[h0 + 'Label'] !== t0) {\n labels[h0 + 'other'] = labels[h0 + 'Val'];\n labels[h0 + 'otherLabel'] = labels[h0 + 'Label'];\n }\n\n text = Lib.hovertemplateString(\n hovertemplate,\n labels,\n fullLayout._d3locale,\n d.eventData[0] || {},\n d.trace._meta\n );\n\n text = text.replace(EXTRA_STRING_REGEX, function(match, extra) {\n // assign name for secondary text label\n name = plainText(extra, d.nameLength);\n // remove from main text label\n return '';\n });\n }\n return [text, name];\n}\n\n// Make groups of touching points, and within each group\n// move each point so that no labels overlap, but the average\n// label position is the same as it was before moving. Incidentally,\n// this is equivalent to saying all the labels are on equal linear\n// springs about their initial position. Initially, each point is\n// its own group, but as we find overlaps we will clump the points.\n//\n// Also, there are hard constraints at the edges of the graphs,\n// that push all groups to the middle so they are visible. I don't\n// know what happens if the group spans all the way from one edge to\n// the other, though it hardly matters - there's just too much\n// information then.\nfunction hoverAvoidOverlaps(hoverLabels, rotateLabels, fullLayout, commonLabelBoundingBox) {\n var axKey = rotateLabels ? 'xa' : 'ya';\n var crossAxKey = rotateLabels ? 'ya' : 'xa';\n var nummoves = 0;\n var axSign = 1;\n var nLabels = hoverLabels.size();\n\n // make groups of touching points\n var pointgroups = new Array(nLabels);\n var k = 0;\n\n // get extent of axis hover label\n var axisLabelMinX = commonLabelBoundingBox.minX;\n var axisLabelMaxX = commonLabelBoundingBox.maxX;\n var axisLabelMinY = commonLabelBoundingBox.minY;\n var axisLabelMaxY = commonLabelBoundingBox.maxY;\n\n var pX = function(x) { return x * fullLayout._invScaleX; };\n var pY = function(y) { return y * fullLayout._invScaleY; };\n\n hoverLabels.each(function(d) {\n var ax = d[axKey];\n var crossAx = d[crossAxKey];\n var axIsX = ax._id.charAt(0) === 'x';\n var rng = ax.range;\n\n if(k === 0 && rng && ((rng[0] > rng[1]) !== axIsX)) {\n axSign = -1;\n }\n var pmin = 0;\n var pmax = (axIsX ? fullLayout.width : fullLayout.height);\n // in hovermode avoid overlap between hover labels and axis label\n if(fullLayout.hovermode === 'x' || fullLayout.hovermode === 'y') {\n // extent of rect behind hover label on cross axis:\n var offsets = getHoverLabelOffsets(d, rotateLabels);\n var anchor = d.anchor;\n var horzSign = anchor === 'end' ? -1 : 1;\n var labelMin;\n var labelMax;\n if(anchor === 'middle') {\n // use extent of centered rect either on x or y axis depending on current axis\n labelMin = d.crossPos + (axIsX ? pY(offsets.y - d.by / 2) : pX(d.bx / 2 + d.tx2width / 2));\n labelMax = labelMin + (axIsX ? pY(d.by) : pX(d.bx));\n } else {\n // use extend of path (see alignHoverText function) without arrow\n if(axIsX) {\n labelMin = d.crossPos + pY(HOVERARROWSIZE + offsets.y) - pY(d.by / 2 - HOVERARROWSIZE);\n labelMax = labelMin + pY(d.by);\n } else {\n var startX = pX(horzSign * HOVERARROWSIZE + offsets.x);\n var endX = startX + pX(horzSign * d.bx);\n labelMin = d.crossPos + Math.min(startX, endX);\n labelMax = d.crossPos + Math.max(startX, endX);\n }\n }\n\n if(axIsX) {\n if(axisLabelMinY !== undefined && axisLabelMaxY !== undefined && Math.min(labelMax, axisLabelMaxY) - Math.max(labelMin, axisLabelMinY) > 1) {\n // has at least 1 pixel overlap with axis label\n if(crossAx.side === 'left') {\n pmin = crossAx._mainLinePosition;\n pmax = fullLayout.width;\n } else {\n pmax = crossAx._mainLinePosition;\n }\n }\n } else {\n if(axisLabelMinX !== undefined && axisLabelMaxX !== undefined && Math.min(labelMax, axisLabelMaxX) - Math.max(labelMin, axisLabelMinX) > 1) {\n // has at least 1 pixel overlap with axis label\n if(crossAx.side === 'top') {\n pmin = crossAx._mainLinePosition;\n pmax = fullLayout.height;\n } else {\n pmax = crossAx._mainLinePosition;\n }\n }\n }\n }\n\n pointgroups[k++] = [{\n datum: d,\n traceIndex: d.trace.index,\n dp: 0,\n pos: d.pos,\n posref: d.posref,\n size: d.by * (axIsX ? YFACTOR : 1) / 2,\n pmin: pmin,\n pmax: pmax\n }];\n });\n\n pointgroups.sort(function(a, b) {\n return (a[0].posref - b[0].posref) ||\n // for equal positions, sort trace indices increasing or decreasing\n // depending on whether the axis is reversed or not... so stacked\n // traces will generally keep their order even if one trace adds\n // nothing to the stack.\n (axSign * (b[0].traceIndex - a[0].traceIndex));\n });\n\n var donepositioning, topOverlap, bottomOverlap, i, j, pti, sumdp;\n\n function constrainGroup(grp) {\n var minPt = grp[0];\n var maxPt = grp[grp.length - 1];\n\n // overlap with the top - positive vals are overlaps\n topOverlap = minPt.pmin - minPt.pos - minPt.dp + minPt.size;\n\n // overlap with the bottom - positive vals are overlaps\n bottomOverlap = maxPt.pos + maxPt.dp + maxPt.size - minPt.pmax;\n\n // check for min overlap first, so that we always\n // see the largest labels\n // allow for .01px overlap, so we don't get an\n // infinite loop from rounding errors\n if(topOverlap > 0.01) {\n for(j = grp.length - 1; j >= 0; j--) grp[j].dp += topOverlap;\n donepositioning = false;\n }\n if(bottomOverlap < 0.01) return;\n if(topOverlap < -0.01) {\n // make sure we're not pushing back and forth\n for(j = grp.length - 1; j >= 0; j--) grp[j].dp -= bottomOverlap;\n donepositioning = false;\n }\n if(!donepositioning) return;\n\n // no room to fix positioning, delete off-screen points\n\n // first see how many points we need to delete\n var deleteCount = 0;\n for(i = 0; i < grp.length; i++) {\n pti = grp[i];\n if(pti.pos + pti.dp + pti.size > minPt.pmax) deleteCount++;\n }\n\n // start by deleting points whose data is off screen\n for(i = grp.length - 1; i >= 0; i--) {\n if(deleteCount <= 0) break;\n pti = grp[i];\n\n // pos has already been constrained to [pmin,pmax]\n // so look for points close to that to delete\n if(pti.pos > minPt.pmax - 1) {\n pti.del = true;\n deleteCount--;\n }\n }\n for(i = 0; i < grp.length; i++) {\n if(deleteCount <= 0) break;\n pti = grp[i];\n\n // pos has already been constrained to [pmin,pmax]\n // so look for points close to that to delete\n if(pti.pos < minPt.pmin + 1) {\n pti.del = true;\n deleteCount--;\n\n // shift the whole group minus into this new space\n bottomOverlap = pti.size * 2;\n for(j = grp.length - 1; j >= 0; j--) grp[j].dp -= bottomOverlap;\n }\n }\n // then delete points that go off the bottom\n for(i = grp.length - 1; i >= 0; i--) {\n if(deleteCount <= 0) break;\n pti = grp[i];\n if(pti.pos + pti.dp + pti.size > minPt.pmax) {\n pti.del = true;\n deleteCount--;\n }\n }\n }\n\n // loop through groups, combining them if they overlap,\n // until nothing moves\n while(!donepositioning && nummoves <= nLabels) {\n // to avoid infinite loops, don't move more times\n // than there are traces\n nummoves++;\n\n // assume nothing will move in this iteration,\n // reverse this if it does\n donepositioning = true;\n i = 0;\n while(i < pointgroups.length - 1) {\n // the higher (g0) and lower (g1) point group\n var g0 = pointgroups[i];\n var g1 = pointgroups[i + 1];\n\n // the lowest point in the higher group (p0)\n // the highest point in the lower group (p1)\n var p0 = g0[g0.length - 1];\n var p1 = g1[0];\n topOverlap = p0.pos + p0.dp + p0.size - p1.pos - p1.dp + p1.size;\n\n if(topOverlap > 0.01) {\n // push the new point(s) added to this group out of the way\n for(j = g1.length - 1; j >= 0; j--) g1[j].dp += topOverlap;\n\n // add them to the group\n g0.push.apply(g0, g1);\n pointgroups.splice(i + 1, 1);\n\n // adjust for minimum average movement\n sumdp = 0;\n for(j = g0.length - 1; j >= 0; j--) sumdp += g0[j].dp;\n bottomOverlap = sumdp / g0.length;\n for(j = g0.length - 1; j >= 0; j--) g0[j].dp -= bottomOverlap;\n donepositioning = false;\n } else i++;\n }\n\n // check if we're going off the plot on either side and fix\n pointgroups.forEach(constrainGroup);\n }\n\n // now put these offsets into hoverData\n for(i = pointgroups.length - 1; i >= 0; i--) {\n var grp = pointgroups[i];\n for(j = grp.length - 1; j >= 0; j--) {\n var pt = grp[j];\n var hoverPt = pt.datum;\n hoverPt.offset = pt.dp;\n hoverPt.del = pt.del;\n }\n }\n}\n\nfunction getHoverLabelOffsets(hoverLabel, rotateLabels) {\n var offsetX = 0;\n var offsetY = hoverLabel.offset;\n\n if(rotateLabels) {\n offsetY *= -YSHIFTY;\n offsetX = hoverLabel.offset * YSHIFTX;\n }\n\n return {\n x: offsetX,\n y: offsetY\n };\n}\n\n/**\n * Calculate the shift in x for text and text2 elements\n */\nfunction getTextShiftX(hoverLabel) {\n var alignShift = {start: 1, end: -1, middle: 0}[hoverLabel.anchor];\n var textShiftX = alignShift * (HOVERARROWSIZE + HOVERTEXTPAD);\n var text2ShiftX = textShiftX + alignShift * (hoverLabel.txwidth + HOVERTEXTPAD);\n\n var isMiddle = hoverLabel.anchor === 'middle';\n if(isMiddle) {\n textShiftX -= hoverLabel.tx2width / 2;\n text2ShiftX += hoverLabel.txwidth / 2 + HOVERTEXTPAD;\n }\n\n return {\n alignShift: alignShift,\n textShiftX: textShiftX,\n text2ShiftX: text2ShiftX\n };\n}\n\nfunction alignHoverText(hoverLabels, rotateLabels, scaleX, scaleY) {\n var pX = function(x) { return x * scaleX; };\n var pY = function(y) { return y * scaleY; };\n\n // finally set the text positioning relative to the data and draw the\n // box around it\n hoverLabels.each(function(d) {\n var g = d3.select(this);\n if(d.del) return g.remove();\n\n var tx = g.select('text.nums');\n var anchor = d.anchor;\n var horzSign = anchor === 'end' ? -1 : 1;\n var shiftX = getTextShiftX(d);\n var offsets = getHoverLabelOffsets(d, rotateLabels);\n var offsetX = offsets.x;\n var offsetY = offsets.y;\n\n var isMiddle = anchor === 'middle';\n\n g.select('path')\n .attr('d', isMiddle ?\n // middle aligned: rect centered on data\n ('M-' + pX(d.bx / 2 + d.tx2width / 2) + ',' + pY(offsetY - d.by / 2) +\n 'h' + pX(d.bx) + 'v' + pY(d.by) + 'h-' + pX(d.bx) + 'Z') :\n // left or right aligned: side rect with arrow to data\n ('M0,0L' + pX(horzSign * HOVERARROWSIZE + offsetX) + ',' + pY(HOVERARROWSIZE + offsetY) +\n 'v' + pY(d.by / 2 - HOVERARROWSIZE) +\n 'h' + pX(horzSign * d.bx) +\n 'v-' + pY(d.by) +\n 'H' + pX(horzSign * HOVERARROWSIZE + offsetX) +\n 'V' + pY(offsetY - HOVERARROWSIZE) +\n 'Z'));\n\n var posX = offsetX + shiftX.textShiftX;\n var posY = offsetY + d.ty0 - d.by / 2 + HOVERTEXTPAD;\n var textAlign = d.textAlign || 'auto';\n\n if(textAlign !== 'auto') {\n if(textAlign === 'left' && anchor !== 'start') {\n tx.attr('text-anchor', 'start');\n posX = isMiddle ?\n -d.bx / 2 - d.tx2width / 2 + HOVERTEXTPAD :\n -d.bx - HOVERTEXTPAD;\n } else if(textAlign === 'right' && anchor !== 'end') {\n tx.attr('text-anchor', 'end');\n posX = isMiddle ?\n d.bx / 2 - d.tx2width / 2 - HOVERTEXTPAD :\n d.bx + HOVERTEXTPAD;\n }\n }\n\n tx.call(svgTextUtils.positionText, pX(posX), pY(posY));\n\n if(d.tx2width) {\n g.select('text.name')\n .call(svgTextUtils.positionText,\n pX(shiftX.text2ShiftX + shiftX.alignShift * HOVERTEXTPAD + offsetX),\n pY(offsetY + d.ty0 - d.by / 2 + HOVERTEXTPAD));\n g.select('rect')\n .call(Drawing.setRect,\n pX(shiftX.text2ShiftX + (shiftX.alignShift - 1) * d.tx2width / 2 + offsetX),\n pY(offsetY - d.by / 2 - 1),\n pX(d.tx2width), pY(d.by + 2));\n }\n });\n}\n\nfunction cleanPoint(d, hovermode) {\n var index = d.index;\n var trace = d.trace || {};\n var cd0 = d.cd[0];\n var cd = d.cd[index] || {};\n\n function pass(v) {\n return v || (isNumeric(v) && v === 0);\n }\n\n var getVal = Array.isArray(index) ?\n function(calcKey, traceKey) {\n var v = Lib.castOption(cd0, index, calcKey);\n return pass(v) ? v : Lib.extractOption({}, trace, '', traceKey);\n } :\n function(calcKey, traceKey) {\n return Lib.extractOption(cd, trace, calcKey, traceKey);\n };\n\n function fill(key, calcKey, traceKey) {\n var val = getVal(calcKey, traceKey);\n if(pass(val)) d[key] = val;\n }\n\n fill('hoverinfo', 'hi', 'hoverinfo');\n fill('bgcolor', 'hbg', 'hoverlabel.bgcolor');\n fill('borderColor', 'hbc', 'hoverlabel.bordercolor');\n fill('fontFamily', 'htf', 'hoverlabel.font.family');\n fill('fontSize', 'hts', 'hoverlabel.font.size');\n fill('fontColor', 'htc', 'hoverlabel.font.color');\n fill('fontWeight', 'htw', 'hoverlabel.font.weight');\n fill('fontStyle', 'hty', 'hoverlabel.font.style');\n fill('fontVariant', 'htv', 'hoverlabel.font.variant');\n fill('nameLength', 'hnl', 'hoverlabel.namelength');\n fill('textAlign', 'hta', 'hoverlabel.align');\n\n d.posref = (hovermode === 'y' || (hovermode === 'closest' && trace.orientation === 'h')) ?\n (d.xa._offset + (d.x0 + d.x1) / 2) :\n (d.ya._offset + (d.y0 + d.y1) / 2);\n\n // then constrain all the positions to be on the plot\n d.x0 = Lib.constrain(d.x0, 0, d.xa._length);\n d.x1 = Lib.constrain(d.x1, 0, d.xa._length);\n d.y0 = Lib.constrain(d.y0, 0, d.ya._length);\n d.y1 = Lib.constrain(d.y1, 0, d.ya._length);\n\n // and convert the x and y label values into formatted text\n if(d.xLabelVal !== undefined) {\n d.xLabel = ('xLabel' in d) ? d.xLabel : Axes.hoverLabelText(d.xa, d.xLabelVal, trace.xhoverformat);\n d.xVal = d.xa.c2d(d.xLabelVal);\n }\n if(d.yLabelVal !== undefined) {\n d.yLabel = ('yLabel' in d) ? d.yLabel : Axes.hoverLabelText(d.ya, d.yLabelVal, trace.yhoverformat);\n d.yVal = d.ya.c2d(d.yLabelVal);\n }\n\n // Traces like heatmaps generate the zLabel in their hoverPoints function\n if(d.zLabelVal !== undefined && d.zLabel === undefined) {\n d.zLabel = String(d.zLabelVal);\n }\n\n // for box means and error bars, add the range to the label\n if(!isNaN(d.xerr) && !(d.xa.type === 'log' && d.xerr <= 0)) {\n var xeText = Axes.tickText(d.xa, d.xa.c2l(d.xerr), 'hover').text;\n if(d.xerrneg !== undefined) {\n d.xLabel += ' +' + xeText + ' / -' +\n Axes.tickText(d.xa, d.xa.c2l(d.xerrneg), 'hover').text;\n } else d.xLabel += ' ± ' + xeText;\n\n // small distance penalty for error bars, so that if there are\n // traces with errors and some without, the error bar label will\n // hoist up to the point\n if(hovermode === 'x') d.distance += 1;\n }\n if(!isNaN(d.yerr) && !(d.ya.type === 'log' && d.yerr <= 0)) {\n var yeText = Axes.tickText(d.ya, d.ya.c2l(d.yerr), 'hover').text;\n if(d.yerrneg !== undefined) {\n d.yLabel += ' +' + yeText + ' / -' +\n Axes.tickText(d.ya, d.ya.c2l(d.yerrneg), 'hover').text;\n } else d.yLabel += ' ± ' + yeText;\n\n if(hovermode === 'y') d.distance += 1;\n }\n\n var infomode = d.hoverinfo || d.trace.hoverinfo;\n\n if(infomode && infomode !== 'all') {\n infomode = Array.isArray(infomode) ? infomode : infomode.split('+');\n if(infomode.indexOf('x') === -1) d.xLabel = undefined;\n if(infomode.indexOf('y') === -1) d.yLabel = undefined;\n if(infomode.indexOf('z') === -1) d.zLabel = undefined;\n if(infomode.indexOf('text') === -1) d.text = undefined;\n if(infomode.indexOf('name') === -1) d.name = undefined;\n }\n\n return d;\n}\n\nfunction createSpikelines(gd, closestPoints, opts) {\n var container = opts.container;\n var fullLayout = opts.fullLayout;\n var gs = fullLayout._size;\n var evt = opts.event;\n var showY = !!closestPoints.hLinePoint;\n var showX = !!closestPoints.vLinePoint;\n\n var xa, ya;\n\n // Remove old spikeline items\n container.selectAll('.spikeline').remove();\n\n if(!(showX || showY)) return;\n\n var contrastColor = Color.combine(fullLayout.plot_bgcolor, fullLayout.paper_bgcolor);\n\n // Horizontal line (to y-axis)\n if(showY) {\n var hLinePoint = closestPoints.hLinePoint;\n var hLinePointX, hLinePointY;\n\n xa = hLinePoint && hLinePoint.xa;\n ya = hLinePoint && hLinePoint.ya;\n var ySnap = ya.spikesnap;\n\n if(ySnap === 'cursor') {\n hLinePointX = evt.pointerX;\n hLinePointY = evt.pointerY;\n } else {\n hLinePointX = xa._offset + hLinePoint.x;\n hLinePointY = ya._offset + hLinePoint.y;\n }\n var dfltHLineColor = tinycolor.readability(hLinePoint.color, contrastColor) < 1.5 ?\n Color.contrast(contrastColor) : hLinePoint.color;\n var yMode = ya.spikemode;\n var yThickness = ya.spikethickness;\n var yColor = ya.spikecolor || dfltHLineColor;\n var xEdge = Axes.getPxPosition(gd, ya);\n var xBase, xEndSpike;\n\n if(yMode.indexOf('toaxis') !== -1 || yMode.indexOf('across') !== -1) {\n if(yMode.indexOf('toaxis') !== -1) {\n xBase = xEdge;\n xEndSpike = hLinePointX;\n }\n if(yMode.indexOf('across') !== -1) {\n var xAcross0 = ya._counterDomainMin;\n var xAcross1 = ya._counterDomainMax;\n if(ya.anchor === 'free') {\n xAcross0 = Math.min(xAcross0, ya.position);\n xAcross1 = Math.max(xAcross1, ya.position);\n }\n xBase = gs.l + xAcross0 * gs.w;\n xEndSpike = gs.l + xAcross1 * gs.w;\n }\n\n // Foreground horizontal line (to y-axis)\n container.insert('line', ':first-child')\n .attr({\n x1: xBase,\n x2: xEndSpike,\n y1: hLinePointY,\n y2: hLinePointY,\n 'stroke-width': yThickness,\n stroke: yColor,\n 'stroke-dasharray': Drawing.dashStyle(ya.spikedash, yThickness)\n })\n .classed('spikeline', true)\n .classed('crisp', true);\n\n // Background horizontal Line (to y-axis)\n container.insert('line', ':first-child')\n .attr({\n x1: xBase,\n x2: xEndSpike,\n y1: hLinePointY,\n y2: hLinePointY,\n 'stroke-width': yThickness + 2,\n stroke: contrastColor\n })\n .classed('spikeline', true)\n .classed('crisp', true);\n }\n // Y axis marker\n if(yMode.indexOf('marker') !== -1) {\n container.insert('circle', ':first-child')\n .attr({\n cx: xEdge + (ya.side !== 'right' ? yThickness : -yThickness),\n cy: hLinePointY,\n r: yThickness,\n fill: yColor\n })\n .classed('spikeline', true);\n }\n }\n\n if(showX) {\n var vLinePoint = closestPoints.vLinePoint;\n var vLinePointX, vLinePointY;\n\n xa = vLinePoint && vLinePoint.xa;\n ya = vLinePoint && vLinePoint.ya;\n var xSnap = xa.spikesnap;\n\n if(xSnap === 'cursor') {\n vLinePointX = evt.pointerX;\n vLinePointY = evt.pointerY;\n } else {\n vLinePointX = xa._offset + vLinePoint.x;\n vLinePointY = ya._offset + vLinePoint.y;\n }\n var dfltVLineColor = tinycolor.readability(vLinePoint.color, contrastColor) < 1.5 ?\n Color.contrast(contrastColor) : vLinePoint.color;\n var xMode = xa.spikemode;\n var xThickness = xa.spikethickness;\n var xColor = xa.spikecolor || dfltVLineColor;\n var yEdge = Axes.getPxPosition(gd, xa);\n var yBase, yEndSpike;\n\n if(xMode.indexOf('toaxis') !== -1 || xMode.indexOf('across') !== -1) {\n if(xMode.indexOf('toaxis') !== -1) {\n yBase = yEdge;\n yEndSpike = vLinePointY;\n }\n if(xMode.indexOf('across') !== -1) {\n var yAcross0 = xa._counterDomainMin;\n var yAcross1 = xa._counterDomainMax;\n if(xa.anchor === 'free') {\n yAcross0 = Math.min(yAcross0, xa.position);\n yAcross1 = Math.max(yAcross1, xa.position);\n }\n yBase = gs.t + (1 - yAcross1) * gs.h;\n yEndSpike = gs.t + (1 - yAcross0) * gs.h;\n }\n\n // Foreground vertical line (to x-axis)\n container.insert('line', ':first-child')\n .attr({\n x1: vLinePointX,\n x2: vLinePointX,\n y1: yBase,\n y2: yEndSpike,\n 'stroke-width': xThickness,\n stroke: xColor,\n 'stroke-dasharray': Drawing.dashStyle(xa.spikedash, xThickness)\n })\n .classed('spikeline', true)\n .classed('crisp', true);\n\n // Background vertical line (to x-axis)\n container.insert('line', ':first-child')\n .attr({\n x1: vLinePointX,\n x2: vLinePointX,\n y1: yBase,\n y2: yEndSpike,\n 'stroke-width': xThickness + 2,\n stroke: contrastColor\n })\n .classed('spikeline', true)\n .classed('crisp', true);\n }\n\n // X axis marker\n if(xMode.indexOf('marker') !== -1) {\n container.insert('circle', ':first-child')\n .attr({\n cx: vLinePointX,\n cy: yEdge - (xa.side !== 'top' ? xThickness : -xThickness),\n r: xThickness,\n fill: xColor\n })\n .classed('spikeline', true);\n }\n }\n}\n\nfunction hoverChanged(gd, evt, oldhoverdata) {\n // don't emit any events if nothing changed\n if(!oldhoverdata || oldhoverdata.length !== gd._hoverdata.length) return true;\n\n for(var i = oldhoverdata.length - 1; i >= 0; i--) {\n var oldPt = oldhoverdata[i];\n var newPt = gd._hoverdata[i];\n\n if(oldPt.curveNumber !== newPt.curveNumber ||\n String(oldPt.pointNumber) !== String(newPt.pointNumber) ||\n String(oldPt.pointNumbers) !== String(newPt.pointNumbers)\n ) {\n return true;\n }\n }\n return false;\n}\n\nfunction spikesChanged(gd, oldspikepoints) {\n // don't relayout the plot because of new spikelines if spikelines points didn't change\n if(!oldspikepoints) return true;\n if(oldspikepoints.vLinePoint !== gd._spikepoints.vLinePoint ||\n oldspikepoints.hLinePoint !== gd._spikepoints.hLinePoint\n ) return true;\n return false;\n}\n\nfunction plainText(s, len) {\n return svgTextUtils.plainText(s || '', {\n len: len,\n allowedTags: ['br', 'sub', 'sup', 'b', 'i', 'em', 's', 'u']\n });\n}\n\nfunction orderRangePoints(hoverData, hovermode) {\n var axLetter = hovermode.charAt(0);\n\n var first = [];\n var second = [];\n var last = [];\n\n for(var i = 0; i < hoverData.length; i++) {\n var d = hoverData[i];\n\n if(\n Registry.traceIs(d.trace, 'bar-like') ||\n Registry.traceIs(d.trace, 'box-violin')\n ) {\n last.push(d);\n } else if(d.trace[axLetter + 'period']) {\n second.push(d);\n } else {\n first.push(d);\n }\n }\n\n return first.concat(second).concat(last);\n}\n\nfunction getCoord(axLetter, winningPoint, fullLayout) {\n var ax = winningPoint[axLetter + 'a'];\n var val = winningPoint[axLetter + 'Val'];\n\n var cd0 = winningPoint.cd[0];\n\n if(ax.type === 'category' || ax.type === 'multicategory') val = ax._categoriesMap[val];\n else if(ax.type === 'date') {\n var periodalignment = winningPoint.trace[axLetter + 'periodalignment'];\n if(periodalignment) {\n var d = winningPoint.cd[winningPoint.index];\n\n var start = d[axLetter + 'Start'];\n if(start === undefined) start = d[axLetter];\n\n var end = d[axLetter + 'End'];\n if(end === undefined) end = d[axLetter];\n\n var diff = end - start;\n\n if(periodalignment === 'end') {\n val += diff;\n } else if(periodalignment === 'middle') {\n val += diff / 2;\n }\n }\n\n val = ax.d2c(val);\n }\n\n if(cd0 && cd0.t && cd0.t.posLetter === ax._id) {\n if(\n fullLayout.boxmode === 'group' ||\n fullLayout.violinmode === 'group'\n ) {\n val += cd0.t.dPos;\n }\n }\n\n return val;\n}\n\n// Top/left hover offsets relative to graph div. As long as hover content is\n// a sibling of the graph div, it will be positioned correctly relative to\n// the offset parent, whatever that may be.\nfunction getTopOffset(gd) { return gd.offsetTop + gd.clientTop; }\nfunction getLeftOffset(gd) { return gd.offsetLeft + gd.clientLeft; }\n\nfunction getBoundingClientRect(gd, node) {\n var fullLayout = gd._fullLayout;\n\n var rect = node.getBoundingClientRect();\n\n var x0 = rect.left;\n var y0 = rect.top;\n var x1 = x0 + rect.width;\n var y1 = y0 + rect.height;\n\n var A = Lib.apply3DTransform(fullLayout._invTransform)(x0, y0);\n var B = Lib.apply3DTransform(fullLayout._invTransform)(x1, y1);\n\n var Ax = A[0];\n var Ay = A[1];\n var Bx = B[0];\n var By = B[1];\n\n return {\n x: Ax,\n y: Ay,\n width: Bx - Ax,\n height: By - Ay,\n top: Math.min(Ay, By),\n left: Math.min(Ax, Bx),\n right: Math.max(Ax, Bx),\n bottom: Math.max(Ay, By),\n };\n}\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../color');\nvar isUnifiedHover = require('./helpers').isUnifiedHover;\n\nmodule.exports = function handleHoverLabelDefaults(contIn, contOut, coerce, opts) {\n opts = opts || {};\n\n var hasLegend = contOut.legend;\n\n function inheritFontAttr(attr) {\n if(!opts.font[attr]) {\n opts.font[attr] = hasLegend ? contOut.legend.font[attr] : contOut.font[attr];\n }\n }\n\n // In unified hover, inherit from layout.legend if available or layout\n if(contOut && isUnifiedHover(contOut.hovermode)) {\n if(!opts.font) opts.font = {};\n inheritFontAttr('size');\n inheritFontAttr('family');\n inheritFontAttr('color');\n inheritFontAttr('weight');\n inheritFontAttr('style');\n inheritFontAttr('variant');\n\n if(hasLegend) {\n if(!opts.bgcolor) opts.bgcolor = Color.combine(contOut.legend.bgcolor, contOut.paper_bgcolor);\n if(!opts.bordercolor) opts.bordercolor = contOut.legend.bordercolor;\n } else {\n if(!opts.bgcolor) opts.bgcolor = contOut.paper_bgcolor;\n }\n }\n\n coerce('hoverlabel.bgcolor', opts.bgcolor);\n coerce('hoverlabel.bordercolor', opts.bordercolor);\n coerce('hoverlabel.namelength', opts.namelength);\n Lib.coerceFont(coerce, 'hoverlabel.font', opts.font);\n coerce('hoverlabel.align', opts.align);\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar layoutAttributes = require('./layout_attributes');\n\nmodule.exports = function handleHoverModeDefaults(layoutIn, layoutOut) {\n function coerce(attr, dflt) {\n // don't coerce if it is already coerced in other place e.g. in cartesian defaults\n if(layoutOut[attr] !== undefined) return layoutOut[attr];\n\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n\n coerce('clickmode');\n coerce('hoversubplots');\n return coerce('hovermode');\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\nvar dragElement = require('../dragelement');\nvar helpers = require('./helpers');\nvar layoutAttributes = require('./layout_attributes');\nvar hoverModule = require('./hover');\n\nmodule.exports = {\n moduleType: 'component',\n name: 'fx',\n\n constants: require('./constants'),\n schema: {\n layout: layoutAttributes\n },\n\n attributes: require('./attributes'),\n layoutAttributes: layoutAttributes,\n\n supplyLayoutGlobalDefaults: require('./layout_global_defaults'),\n supplyDefaults: require('./defaults'),\n supplyLayoutDefaults: require('./layout_defaults'),\n\n calc: require('./calc'),\n\n getDistanceFunction: helpers.getDistanceFunction,\n getClosest: helpers.getClosest,\n inbox: helpers.inbox,\n quadrature: helpers.quadrature,\n appendArrayPointValue: helpers.appendArrayPointValue,\n\n castHoverOption: castHoverOption,\n castHoverinfo: castHoverinfo,\n\n hover: hoverModule.hover,\n unhover: dragElement.unhover,\n\n loneHover: hoverModule.loneHover,\n loneUnhover: loneUnhover,\n\n click: require('./click')\n};\n\nfunction loneUnhover(containerOrSelection) {\n // duck type whether the arg is a d3 selection because ie9 doesn't\n // handle instanceof like modern browsers do.\n var selection = Lib.isD3Selection(containerOrSelection) ?\n containerOrSelection :\n d3.select(containerOrSelection);\n\n selection.selectAll('g.hovertext').remove();\n selection.selectAll('.spikeline').remove();\n}\n\n// helpers for traces that use Fx.loneHover\n\nfunction castHoverOption(trace, ptNumber, attr) {\n return Lib.castOption(trace, ptNumber, 'hoverlabel.' + attr);\n}\n\nfunction castHoverinfo(trace, fullLayout, ptNumber) {\n function _coerce(val) {\n return Lib.coerceHoverinfo({hoverinfo: val}, {_module: trace._module}, fullLayout);\n }\n\n return Lib.castOption(trace, ptNumber, 'hoverinfo', _coerce);\n}\n","'use strict';\n\nvar constants = require('./constants');\n\nvar fontAttrs = require('../../plots/font_attributes');\n\nvar font = fontAttrs({\n editType: 'none',\n description: 'Sets the default hover label font used by all traces on the graph.'\n});\nfont.family.dflt = constants.HOVERFONT;\nfont.size.dflt = constants.HOVERFONTSIZE;\n\nmodule.exports = {\n clickmode: {\n valType: 'flaglist',\n flags: ['event', 'select'],\n dflt: 'event',\n editType: 'plot',\n extras: ['none'],\n description: [\n 'Determines the mode of single click interactions.',\n '*event* is the default value and emits the `plotly_click`',\n 'event. In addition this mode emits the `plotly_selected` event',\n 'in drag modes *lasso* and *select*, but with no event data attached',\n '(kept for compatibility reasons).',\n 'The *select* flag enables selecting single',\n 'data points via click. This mode also supports persistent selections,',\n 'meaning that pressing Shift while clicking, adds to / subtracts from an',\n 'existing selection. *select* with `hovermode`: *x* can be confusing, consider',\n 'explicitly setting `hovermode`: *closest* when using this feature.',\n 'Selection events are sent accordingly as long as *event* flag is set as well.',\n 'When the *event* flag is missing, `plotly_click` and `plotly_selected`',\n 'events are not fired.'\n ].join(' ')\n },\n dragmode: {\n valType: 'enumerated',\n values: [\n 'zoom',\n 'pan',\n 'select',\n 'lasso',\n 'drawclosedpath',\n 'drawopenpath',\n 'drawline',\n 'drawrect',\n 'drawcircle',\n 'orbit',\n 'turntable',\n false\n ],\n dflt: 'zoom',\n editType: 'modebar',\n description: [\n 'Determines the mode of drag interactions.',\n '*select* and *lasso* apply only to scatter traces with',\n 'markers or text. *orbit* and *turntable* apply only to',\n '3D scenes.'\n ].join(' ')\n },\n hovermode: {\n valType: 'enumerated',\n values: ['x', 'y', 'closest', false, 'x unified', 'y unified'],\n dflt: 'closest',\n editType: 'modebar',\n description: [\n 'Determines the mode of hover interactions.',\n 'If *closest*, a single hoverlabel will appear',\n 'for the *closest* point within the `hoverdistance`.',\n 'If *x* (or *y*), multiple hoverlabels will appear for multiple points',\n 'at the *closest* x- (or y-) coordinate within the `hoverdistance`,',\n 'with the caveat that no more than one hoverlabel will appear per trace.',\n 'If *x unified* (or *y unified*), a single hoverlabel will appear',\n 'multiple points at the closest x- (or y-) coordinate within the `hoverdistance`',\n 'with the caveat that no more than one hoverlabel will appear per trace.',\n 'In this mode, spikelines are enabled by default perpendicular to the specified axis.',\n 'If false, hover interactions are disabled.'\n ].join(' ')\n },\n hoversubplots: {\n valType: 'enumerated',\n values: ['single', 'overlaying', 'axis'],\n dflt: 'overlaying',\n editType: 'none',\n description: [\n 'Determines expansion of hover effects to other subplots',\n 'If *single* just the axis pair of the primary point is included without overlaying subplots.',\n 'If *overlaying* all subplots using the main axis and occupying the same space are included.',\n 'If *axis*, also include stacked subplots using the same axis',\n 'when `hovermode` is set to *x*, *x unified*, *y* or *y unified*.',\n ].join(' ')\n },\n hoverdistance: {\n valType: 'integer',\n min: -1,\n dflt: 20,\n editType: 'none',\n description: [\n 'Sets the default distance (in pixels) to look for data',\n 'to add hover labels (-1 means no cutoff, 0 means no looking for data).',\n 'This is only a real distance for hovering on point-like objects,',\n 'like scatter points. For area-like objects (bars, scatter fills, etc)',\n 'hovering is on inside the area and off outside, but these objects',\n 'will not supersede hover on point-like objects in case of conflict.'\n ].join(' ')\n },\n spikedistance: {\n valType: 'integer',\n min: -1,\n dflt: -1,\n editType: 'none',\n description: [\n 'Sets the default distance (in pixels) to look for data to draw',\n 'spikelines to (-1 means no cutoff, 0 means no looking for data).',\n 'As with hoverdistance, distance does not apply to area-like objects.',\n 'In addition, some objects can be hovered on but will not generate',\n 'spikelines, such as scatter fills.'\n ].join(' ')\n },\n hoverlabel: {\n bgcolor: {\n valType: 'color',\n editType: 'none',\n description: [\n 'Sets the background color of all hover labels on graph'\n ].join(' ')\n },\n bordercolor: {\n valType: 'color',\n editType: 'none',\n description: [\n 'Sets the border color of all hover labels on graph.'\n ].join(' ')\n },\n font: font,\n grouptitlefont: fontAttrs({\n editType: 'none',\n description: [\n 'Sets the font for group titles in hover (unified modes).',\n 'Defaults to `hoverlabel.font`.'\n ].join(' ')\n }),\n align: {\n valType: 'enumerated',\n values: ['left', 'right', 'auto'],\n dflt: 'auto',\n editType: 'none',\n description: [\n 'Sets the horizontal alignment of the text content within hover label box.',\n 'Has an effect only if the hover label text spans more two or more lines'\n ].join(' ')\n },\n namelength: {\n valType: 'integer',\n min: -1,\n dflt: 15,\n editType: 'none',\n description: [\n 'Sets the default length (in number of characters) of the trace name in',\n 'the hover labels for all traces. -1 shows the whole name',\n 'regardless of length. 0-3 shows the first 0-3 characters, and',\n 'an integer >3 will show the whole name if it is less than that',\n 'many characters, but if it is longer, will truncate to',\n '`namelength - 3` characters and add an ellipsis.'\n ].join(' ')\n },\n\n editType: 'none'\n },\n selectdirection: {\n valType: 'enumerated',\n values: ['h', 'v', 'd', 'any'],\n dflt: 'any',\n description: [\n 'When `dragmode` is set to *select*, this limits the selection of the drag to',\n 'horizontal, vertical or diagonal. *h* only allows horizontal selection,',\n '*v* only vertical, *d* only diagonal and *any* sets no limit.'\n ].join(' '),\n editType: 'none'\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar layoutAttributes = require('./layout_attributes');\nvar handleHoverModeDefaults = require('./hovermode_defaults');\nvar handleHoverLabelDefaults = require('./hoverlabel_defaults');\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n\n var hoverMode = handleHoverModeDefaults(layoutIn, layoutOut);\n if(hoverMode) {\n coerce('hoverdistance');\n coerce('spikedistance');\n }\n\n var dragMode = coerce('dragmode');\n if(dragMode === 'select') coerce('selectdirection');\n\n // if only mapbox, map or geo subplots is present on graph,\n // reset 'zoom' dragmode to 'pan' until 'zoom' is implemented,\n // so that the correct modebar button is active\n var hasMapbox = layoutOut._has('mapbox');\n var hasMap = layoutOut._has('map');\n var hasGeo = layoutOut._has('geo');\n var len = layoutOut._basePlotModules.length;\n\n if(layoutOut.dragmode === 'zoom' && (\n ((hasMapbox || hasMap || hasGeo) && len === 1) ||\n ((hasMapbox || hasMap) && hasGeo && len === 2)\n )) {\n layoutOut.dragmode = 'pan';\n }\n\n handleHoverLabelDefaults(layoutIn, layoutOut, coerce);\n\n Lib.coerceFont(coerce, 'hoverlabel.grouptitlefont', layoutOut.hoverlabel.font);\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar handleHoverLabelDefaults = require('./hoverlabel_defaults');\nvar layoutAttributes = require('./layout_attributes');\n\nmodule.exports = function supplyLayoutGlobalDefaults(layoutIn, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n\n handleHoverLabelDefaults(layoutIn, layoutOut, coerce);\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar counterRegex = require('../../lib/regex').counter;\nvar domainAttrs = require('../../plots/domain').attributes;\nvar cartesianIdRegex = require('../../plots/cartesian/constants').idRegex;\nvar Template = require('../../plot_api/plot_template');\n\nvar gridAttrs = {\n rows: {\n valType: 'integer',\n min: 1,\n editType: 'plot',\n description: [\n 'The number of rows in the grid. If you provide a 2D `subplots`',\n 'array or a `yaxes` array, its length is used as the default.',\n 'But it\\'s also possible to have a different length, if you',\n 'want to leave a row at the end for non-cartesian subplots.'\n ].join(' ')\n },\n roworder: {\n valType: 'enumerated',\n values: ['top to bottom', 'bottom to top'],\n dflt: 'top to bottom',\n editType: 'plot',\n description: [\n 'Is the first row the top or the bottom? Note that columns',\n 'are always enumerated from left to right.'\n ].join(' ')\n },\n columns: {\n valType: 'integer',\n min: 1,\n editType: 'plot',\n description: [\n 'The number of columns in the grid. If you provide a 2D `subplots`',\n 'array, the length of its longest row is used as the default.',\n 'If you give an `xaxes` array, its length is used as the default.',\n 'But it\\'s also possible to have a different length, if you',\n 'want to leave a row at the end for non-cartesian subplots.'\n ].join(' ')\n },\n subplots: {\n valType: 'info_array',\n freeLength: true,\n dimensions: 2,\n items: {valType: 'enumerated', values: [counterRegex('xy').toString(), ''], editType: 'plot'},\n editType: 'plot',\n description: [\n 'Used for freeform grids, where some axes may be shared across subplots',\n 'but others are not. Each entry should be a cartesian subplot id, like',\n '*xy* or *x3y2*, or ** to leave that cell empty. You may reuse x axes',\n 'within the same column, and y axes within the same row.',\n 'Non-cartesian subplots and traces that support `domain` can place themselves',\n 'in this grid separately using the `gridcell` attribute.'\n ].join(' ')\n },\n xaxes: {\n valType: 'info_array',\n freeLength: true,\n items: {valType: 'enumerated', values: [cartesianIdRegex.x.toString(), ''], editType: 'plot'},\n editType: 'plot',\n description: [\n 'Used with `yaxes` when the x and y axes are shared across columns and rows.',\n 'Each entry should be an x axis id like *x*, *x2*, etc., or ** to',\n 'not put an x axis in that column. Entries other than ** must be unique.',\n 'Ignored if `subplots` is present. If missing but `yaxes` is present,',\n 'will generate consecutive IDs.'\n ].join(' ')\n },\n yaxes: {\n valType: 'info_array',\n freeLength: true,\n items: {valType: 'enumerated', values: [cartesianIdRegex.y.toString(), ''], editType: 'plot'},\n editType: 'plot',\n description: [\n 'Used with `yaxes` when the x and y axes are shared across columns and rows.',\n 'Each entry should be an y axis id like *y*, *y2*, etc., or ** to',\n 'not put a y axis in that row. Entries other than ** must be unique.',\n 'Ignored if `subplots` is present. If missing but `xaxes` is present,',\n 'will generate consecutive IDs.'\n ].join(' ')\n },\n pattern: {\n valType: 'enumerated',\n values: ['independent', 'coupled'],\n dflt: 'coupled',\n editType: 'plot',\n description: [\n 'If no `subplots`, `xaxes`, or `yaxes` are given but we do have `rows` and `columns`,',\n 'we can generate defaults using consecutive axis IDs, in two ways:',\n '*coupled* gives one x axis per column and one y axis per row.',\n '*independent* uses a new xy pair for each cell, left-to-right across each row',\n 'then iterating rows according to `roworder`.'\n ].join(' ')\n },\n xgap: {\n valType: 'number',\n min: 0,\n max: 1,\n editType: 'plot',\n description: [\n 'Horizontal space between grid cells, expressed as a fraction',\n 'of the total width available to one cell. Defaults to 0.1',\n 'for coupled-axes grids and 0.2 for independent grids.'\n ].join(' ')\n },\n ygap: {\n valType: 'number',\n min: 0,\n max: 1,\n editType: 'plot',\n description: [\n 'Vertical space between grid cells, expressed as a fraction',\n 'of the total height available to one cell. Defaults to 0.1',\n 'for coupled-axes grids and 0.3 for independent grids.'\n ].join(' ')\n },\n domain: domainAttrs({name: 'grid', editType: 'plot', noGridCell: true}, {\n description: [\n 'The first and last cells end exactly at the domain',\n 'edges, with no grout around the edges.'\n ].join(' ')\n }),\n xside: {\n valType: 'enumerated',\n values: ['bottom', 'bottom plot', 'top plot', 'top'],\n dflt: 'bottom plot',\n editType: 'plot',\n description: [\n 'Sets where the x axis labels and titles go. *bottom* means',\n 'the very bottom of the grid. *bottom plot* is the lowest plot',\n 'that each x axis is used in. *top* and *top plot* are similar.'\n ].join(' ')\n },\n yside: {\n valType: 'enumerated',\n values: ['left', 'left plot', 'right plot', 'right'],\n dflt: 'left plot',\n editType: 'plot',\n description: [\n 'Sets where the y axis labels and titles go. *left* means',\n 'the very left edge of the grid. *left plot* is the leftmost plot',\n 'that each y axis is used in. *right* and *right plot* are similar.'\n ].join(' ')\n },\n editType: 'plot'\n};\n\nfunction getAxes(layout, grid, axLetter) {\n var gridVal = grid[axLetter + 'axes'];\n var splomVal = Object.keys((layout._splomAxes || {})[axLetter] || {});\n\n if(Array.isArray(gridVal)) return gridVal;\n if(splomVal.length) return splomVal;\n}\n\n// the shape of the grid - this needs to be done BEFORE supplyDataDefaults\n// so that non-subplot traces can place themselves in the grid\nfunction sizeDefaults(layoutIn, layoutOut) {\n var gridIn = layoutIn.grid || {};\n var xAxes = getAxes(layoutOut, gridIn, 'x');\n var yAxes = getAxes(layoutOut, gridIn, 'y');\n\n if(!layoutIn.grid && !xAxes && !yAxes) return;\n\n var hasSubplotGrid = Array.isArray(gridIn.subplots) && Array.isArray(gridIn.subplots[0]);\n var hasXaxes = Array.isArray(xAxes);\n var hasYaxes = Array.isArray(yAxes);\n var isSplomGenerated = (\n hasXaxes && xAxes !== gridIn.xaxes &&\n hasYaxes && yAxes !== gridIn.yaxes\n );\n\n var dfltRows, dfltColumns;\n\n if(hasSubplotGrid) {\n dfltRows = gridIn.subplots.length;\n dfltColumns = gridIn.subplots[0].length;\n } else {\n if(hasYaxes) dfltRows = yAxes.length;\n if(hasXaxes) dfltColumns = xAxes.length;\n }\n\n var gridOut = Template.newContainer(layoutOut, 'grid');\n\n function coerce(attr, dflt) {\n return Lib.coerce(gridIn, gridOut, gridAttrs, attr, dflt);\n }\n\n var rows = coerce('rows', dfltRows);\n var columns = coerce('columns', dfltColumns);\n\n if(!(rows * columns > 1)) {\n delete layoutOut.grid;\n return;\n }\n\n if(!hasSubplotGrid && !hasXaxes && !hasYaxes) {\n var useDefaultSubplots = coerce('pattern') === 'independent';\n if(useDefaultSubplots) hasSubplotGrid = true;\n }\n gridOut._hasSubplotGrid = hasSubplotGrid;\n\n var rowOrder = coerce('roworder');\n var reversed = rowOrder === 'top to bottom';\n\n var dfltGapX = hasSubplotGrid ? 0.2 : 0.1;\n var dfltGapY = hasSubplotGrid ? 0.3 : 0.1;\n\n var dfltSideX, dfltSideY;\n if(isSplomGenerated && layoutOut._splomGridDflt) {\n dfltSideX = layoutOut._splomGridDflt.xside;\n dfltSideY = layoutOut._splomGridDflt.yside;\n }\n\n gridOut._domains = {\n x: fillGridPositions('x', coerce, dfltGapX, dfltSideX, columns),\n y: fillGridPositions('y', coerce, dfltGapY, dfltSideY, rows, reversed)\n };\n}\n\n// coerce x or y sizing attributes and return an array of domains for this direction\nfunction fillGridPositions(axLetter, coerce, dfltGap, dfltSide, len, reversed) {\n var dirGap = coerce(axLetter + 'gap', dfltGap);\n var domain = coerce('domain.' + axLetter);\n coerce(axLetter + 'side', dfltSide);\n\n var out = new Array(len);\n var start = domain[0];\n var step = (domain[1] - start) / (len - dirGap);\n var cellDomain = step * (1 - dirGap);\n for(var i = 0; i < len; i++) {\n var cellStart = start + step * i;\n out[reversed ? (len - 1 - i) : i] = [cellStart, cellStart + cellDomain];\n }\n return out;\n}\n\n// the (cartesian) contents of the grid - this needs to happen AFTER supplyDataDefaults\n// so that we know what cartesian subplots are available\nfunction contentDefaults(layoutIn, layoutOut) {\n var gridOut = layoutOut.grid;\n // make sure we got to the end of handleGridSizing\n if(!gridOut || !gridOut._domains) return;\n\n var gridIn = layoutIn.grid || {};\n var subplots = layoutOut._subplots;\n var hasSubplotGrid = gridOut._hasSubplotGrid;\n var rows = gridOut.rows;\n var columns = gridOut.columns;\n var useDefaultSubplots = gridOut.pattern === 'independent';\n\n var i, j, xId, yId, subplotId, subplotsOut, yPos;\n\n var axisMap = gridOut._axisMap = {};\n\n if(hasSubplotGrid) {\n var subplotsIn = gridIn.subplots || [];\n subplotsOut = gridOut.subplots = new Array(rows);\n var index = 1;\n\n for(i = 0; i < rows; i++) {\n var rowOut = subplotsOut[i] = new Array(columns);\n var rowIn = subplotsIn[i] || [];\n for(j = 0; j < columns; j++) {\n if(useDefaultSubplots) {\n subplotId = (index === 1) ? 'xy' : ('x' + index + 'y' + index);\n index++;\n } else subplotId = rowIn[j];\n\n rowOut[j] = '';\n\n if(subplots.cartesian.indexOf(subplotId) !== -1) {\n yPos = subplotId.indexOf('y');\n xId = subplotId.slice(0, yPos);\n yId = subplotId.slice(yPos);\n if((axisMap[xId] !== undefined && axisMap[xId] !== j) ||\n (axisMap[yId] !== undefined && axisMap[yId] !== i)\n ) {\n continue;\n }\n\n rowOut[j] = subplotId;\n axisMap[xId] = j;\n axisMap[yId] = i;\n }\n }\n }\n } else {\n var xAxes = getAxes(layoutOut, gridIn, 'x');\n var yAxes = getAxes(layoutOut, gridIn, 'y');\n gridOut.xaxes = fillGridAxes(xAxes, subplots.xaxis, columns, axisMap, 'x');\n gridOut.yaxes = fillGridAxes(yAxes, subplots.yaxis, rows, axisMap, 'y');\n }\n\n var anchors = gridOut._anchors = {};\n var reversed = gridOut.roworder === 'top to bottom';\n\n for(var axisId in axisMap) {\n var axLetter = axisId.charAt(0);\n var side = gridOut[axLetter + 'side'];\n\n var i0, inc, iFinal;\n\n if(side.length < 8) {\n // grid edge - ie not \"* plot\" - make these as free axes\n // since we're not guaranteed to have a subplot there at all\n anchors[axisId] = 'free';\n } else if(axLetter === 'x') {\n if((side.charAt(0) === 't') === reversed) {\n i0 = 0;\n inc = 1;\n iFinal = rows;\n } else {\n i0 = rows - 1;\n inc = -1;\n iFinal = -1;\n }\n if(hasSubplotGrid) {\n var column = axisMap[axisId];\n for(i = i0; i !== iFinal; i += inc) {\n subplotId = subplotsOut[i][column];\n if(!subplotId) continue;\n yPos = subplotId.indexOf('y');\n if(subplotId.slice(0, yPos) === axisId) {\n anchors[axisId] = subplotId.slice(yPos);\n break;\n }\n }\n } else {\n for(i = i0; i !== iFinal; i += inc) {\n yId = gridOut.yaxes[i];\n if(subplots.cartesian.indexOf(axisId + yId) !== -1) {\n anchors[axisId] = yId;\n break;\n }\n }\n }\n } else {\n if((side.charAt(0) === 'l')) {\n i0 = 0;\n inc = 1;\n iFinal = columns;\n } else {\n i0 = columns - 1;\n inc = -1;\n iFinal = -1;\n }\n if(hasSubplotGrid) {\n var row = axisMap[axisId];\n for(i = i0; i !== iFinal; i += inc) {\n subplotId = subplotsOut[row][i];\n if(!subplotId) continue;\n yPos = subplotId.indexOf('y');\n if(subplotId.slice(yPos) === axisId) {\n anchors[axisId] = subplotId.slice(0, yPos);\n break;\n }\n }\n } else {\n for(i = i0; i !== iFinal; i += inc) {\n xId = gridOut.xaxes[i];\n if(subplots.cartesian.indexOf(xId + axisId) !== -1) {\n anchors[axisId] = xId;\n break;\n }\n }\n }\n }\n }\n}\n\nfunction fillGridAxes(axesIn, axesAllowed, len, axisMap, axLetter) {\n var out = new Array(len);\n var i;\n\n function fillOneAxis(i, axisId) {\n if(axesAllowed.indexOf(axisId) !== -1 && axisMap[axisId] === undefined) {\n out[i] = axisId;\n axisMap[axisId] = i;\n } else out[i] = '';\n }\n\n if(Array.isArray(axesIn)) {\n for(i = 0; i < len; i++) {\n fillOneAxis(i, axesIn[i]);\n }\n } else {\n // default axis list is the first `len` axis ids\n fillOneAxis(0, axLetter);\n for(i = 1; i < len; i++) {\n fillOneAxis(i, axLetter + (i + 1));\n }\n }\n\n return out;\n}\n\nmodule.exports = {\n moduleType: 'component',\n name: 'grid',\n\n schema: {\n layout: {grid: gridAttrs}\n },\n\n layoutAttributes: gridAttrs,\n sizeDefaults: sizeDefaults,\n contentDefaults: contentDefaults\n};\n","'use strict';\n\nvar cartesianConstants = require('../../plots/cartesian/constants');\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\nvar axisPlaceableObjs = require('../../constants/axis_placeable_objects');\n\n\nmodule.exports = templatedArray('image', {\n visible: {\n valType: 'boolean',\n dflt: true,\n editType: 'arraydraw',\n description: [\n 'Determines whether or not this image is visible.'\n ].join(' ')\n },\n\n source: {\n valType: 'string',\n editType: 'arraydraw',\n description: [\n 'Specifies the URL of the image to be used.',\n 'The URL must be accessible from the domain where the',\n 'plot code is run, and can be either relative or absolute.'\n\n ].join(' ')\n },\n\n layer: {\n valType: 'enumerated',\n values: ['below', 'above'],\n dflt: 'above',\n editType: 'arraydraw',\n description: [\n 'Specifies whether images are drawn below or above traces.',\n 'When `xref` and `yref` are both set to `paper`,',\n 'image is drawn below the entire plot area.'\n ].join(' ')\n },\n\n sizex: {\n valType: 'number',\n dflt: 0,\n editType: 'arraydraw',\n description: [\n 'Sets the image container size horizontally.',\n 'The image will be sized based on the `position` value.',\n 'When `xref` is set to `paper`, units are sized relative',\n 'to the plot width.',\n 'When `xref` ends with ` domain`, units are sized relative',\n 'to the axis width.',\n ].join(' ')\n },\n\n sizey: {\n valType: 'number',\n dflt: 0,\n editType: 'arraydraw',\n description: [\n 'Sets the image container size vertically.',\n 'The image will be sized based on the `position` value.',\n 'When `yref` is set to `paper`, units are sized relative',\n 'to the plot height.',\n 'When `yref` ends with ` domain`, units are sized relative',\n 'to the axis height.'\n ].join(' ')\n },\n\n sizing: {\n valType: 'enumerated',\n values: ['fill', 'contain', 'stretch'],\n dflt: 'contain',\n editType: 'arraydraw',\n description: [\n 'Specifies which dimension of the image to constrain.'\n ].join(' ')\n },\n\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n editType: 'arraydraw',\n description: 'Sets the opacity of the image.'\n },\n\n x: {\n valType: 'any',\n dflt: 0,\n editType: 'arraydraw',\n description: [\n 'Sets the image\\'s x position.',\n 'When `xref` is set to `paper`, units are sized relative',\n 'to the plot height.',\n 'See `xref` for more info'\n ].join(' ')\n },\n\n y: {\n valType: 'any',\n dflt: 0,\n editType: 'arraydraw',\n description: [\n 'Sets the image\\'s y position.',\n 'When `yref` is set to `paper`, units are sized relative',\n 'to the plot height.',\n 'See `yref` for more info'\n ].join(' ')\n },\n\n xanchor: {\n valType: 'enumerated',\n values: ['left', 'center', 'right'],\n dflt: 'left',\n editType: 'arraydraw',\n description: 'Sets the anchor for the x position'\n },\n\n yanchor: {\n valType: 'enumerated',\n values: ['top', 'middle', 'bottom'],\n dflt: 'top',\n editType: 'arraydraw',\n description: 'Sets the anchor for the y position.'\n },\n\n xref: {\n valType: 'enumerated',\n values: [\n 'paper',\n cartesianConstants.idRegex.x.toString()\n ],\n dflt: 'paper',\n editType: 'arraydraw',\n description: [\n 'Sets the images\\'s x coordinate axis.',\n axisPlaceableObjs.axisRefDescription('x', 'left', 'right'),\n ].join(' ')\n },\n\n yref: {\n valType: 'enumerated',\n values: [\n 'paper',\n cartesianConstants.idRegex.y.toString()\n ],\n dflt: 'paper',\n editType: 'arraydraw',\n description: [\n 'Sets the images\\'s y coordinate axis.',\n axisPlaceableObjs.axisRefDescription('y', 'bottom', 'top'),\n ].join(' ')\n },\n editType: 'arraydraw'\n});\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar toLogRange = require('../../lib/to_log_range');\n\n/*\n * convertCoords: when converting an axis between log and linear\n * you need to alter any images on that axis to keep them\n * pointing at the same data point.\n * In v3.0 this will become obsolete (or perhaps size will still need conversion?)\n * we convert size by declaring that the maximum extent *in data units* should be\n * the same, assuming the image is anchored by its center (could remove that restriction\n * if we think it's important) even though the actual left and right values will not be\n * quite the same since the scale becomes nonlinear (and central anchor means the pixel\n * center of the image, not the data units center)\n *\n * gd: the plot div\n * ax: the axis being changed\n * newType: the type it's getting\n * doExtra: function(attr, val) from inside relayout that sets the attribute.\n * Use this to make the changes as it's aware if any other changes in the\n * same relayout call should override this conversion.\n */\nmodule.exports = function convertCoords(gd, ax, newType, doExtra) {\n ax = ax || {};\n\n var toLog = (newType === 'log') && (ax.type === 'linear');\n var fromLog = (newType === 'linear') && (ax.type === 'log');\n\n if(!(toLog || fromLog)) return;\n\n var images = gd._fullLayout.images;\n var axLetter = ax._id.charAt(0);\n var image;\n var attrPrefix;\n\n for(var i = 0; i < images.length; i++) {\n image = images[i];\n attrPrefix = 'images[' + i + '].';\n\n if(image[axLetter + 'ref'] === ax._id) {\n var currentPos = image[axLetter];\n var currentSize = image['size' + axLetter];\n var newPos = null;\n var newSize = null;\n\n if(toLog) {\n newPos = toLogRange(currentPos, ax.range);\n\n // this is the inverse of the conversion we do in fromLog below\n // so that the conversion is reversible (notice the fromLog conversion\n // is like sinh, and this one looks like arcsinh)\n var dx = currentSize / Math.pow(10, newPos) / 2;\n newSize = 2 * Math.log(dx + Math.sqrt(1 + dx * dx)) / Math.LN10;\n } else {\n newPos = Math.pow(10, currentPos);\n newSize = newPos * (Math.pow(10, currentSize / 2) - Math.pow(10, -currentSize / 2));\n }\n\n // if conversion failed, delete the value so it can get a default later on\n if(!isNumeric(newPos)) {\n newPos = null;\n newSize = null;\n } else if(!isNumeric(newSize)) newSize = null;\n\n doExtra(attrPrefix + axLetter, newPos);\n doExtra(attrPrefix + 'size' + axLetter, newSize);\n }\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar attributes = require('./attributes');\nvar name = 'images';\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n var opts = {\n name: name,\n handleItemDefaults: imageDefaults\n };\n\n handleArrayContainerDefaults(layoutIn, layoutOut, opts);\n};\n\n\nfunction imageDefaults(imageIn, imageOut, fullLayout) {\n function coerce(attr, dflt) {\n return Lib.coerce(imageIn, imageOut, attributes, attr, dflt);\n }\n\n var source = coerce('source');\n var visible = coerce('visible', !!source);\n\n if(!visible) return imageOut;\n\n coerce('layer');\n coerce('xanchor');\n coerce('yanchor');\n coerce('sizex');\n coerce('sizey');\n coerce('sizing');\n coerce('opacity');\n\n var gdMock = { _fullLayout: fullLayout };\n var axLetters = ['x', 'y'];\n\n for(var i = 0; i < 2; i++) {\n // 'paper' is the fallback axref\n var axLetter = axLetters[i];\n var axRef = Axes.coerceRef(imageIn, imageOut, gdMock, axLetter, 'paper', undefined);\n\n if(axRef !== 'paper') {\n var ax = Axes.getFromId(gdMock, axRef);\n ax._imgIndices.push(imageOut._index);\n }\n\n Axes.coercePosition(imageOut, gdMock, coerce, axRef, axLetter, 0);\n }\n\n return imageOut;\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Drawing = require('../drawing');\nvar Axes = require('../../plots/cartesian/axes');\nvar axisIds = require('../../plots/cartesian/axis_ids');\nvar xmlnsNamespaces = require('../../constants/xmlns_namespaces');\n\nmodule.exports = function draw(gd) {\n var fullLayout = gd._fullLayout;\n var imageDataAbove = [];\n var imageDataSubplot = {};\n var imageDataBelow = [];\n var subplot;\n var i;\n\n // Sort into top, subplot, and bottom layers\n for(i = 0; i < fullLayout.images.length; i++) {\n var img = fullLayout.images[i];\n\n if(img.visible) {\n if(img.layer === 'below' && img.xref !== 'paper' && img.yref !== 'paper') {\n subplot = axisIds.ref2id(img.xref) + axisIds.ref2id(img.yref);\n\n var plotinfo = fullLayout._plots[subplot];\n\n if(!plotinfo) {\n // Fall back to _imageLowerLayer in case the requested subplot doesn't exist.\n // This can happen if you reference the image to an x / y axis combination\n // that doesn't have any data on it (and layer is below)\n imageDataBelow.push(img);\n continue;\n }\n\n if(plotinfo.mainplot) {\n subplot = plotinfo.mainplot.id;\n }\n\n if(!imageDataSubplot[subplot]) {\n imageDataSubplot[subplot] = [];\n }\n imageDataSubplot[subplot].push(img);\n } else if(img.layer === 'above') {\n imageDataAbove.push(img);\n } else {\n imageDataBelow.push(img);\n }\n }\n }\n\n\n var anchors = {\n x: {\n left: { sizing: 'xMin', offset: 0 },\n center: { sizing: 'xMid', offset: -1 / 2 },\n right: { sizing: 'xMax', offset: -1 }\n },\n y: {\n top: { sizing: 'YMin', offset: 0 },\n middle: { sizing: 'YMid', offset: -1 / 2 },\n bottom: { sizing: 'YMax', offset: -1 }\n }\n };\n\n\n // Images must be converted to dataURL's for exporting.\n function setImage(d) {\n var thisImage = d3.select(this);\n\n if(this._imgSrc === d.source) {\n return;\n }\n\n thisImage.attr('xmlns', xmlnsNamespaces.svg);\n\n if(d.source && d.source.slice(0, 5) === 'data:') {\n thisImage.attr('xlink:href', d.source);\n this._imgSrc = d.source;\n } else {\n var imagePromise = new Promise(function(resolve) {\n var img = new Image();\n this.img = img;\n\n // If not set, a `tainted canvas` error is thrown\n img.setAttribute('crossOrigin', 'anonymous');\n img.onerror = errorHandler;\n img.onload = function() {\n var canvas = document.createElement('canvas');\n canvas.width = this.width;\n canvas.height = this.height;\n\n var ctx = canvas.getContext('2d', {willReadFrequently: true});\n ctx.drawImage(this, 0, 0);\n\n var dataURL = canvas.toDataURL('image/png');\n\n thisImage.attr('xlink:href', dataURL);\n\n // resolve promise in onload handler instead of on 'load' to support IE11\n // see https://github.com/plotly/plotly.js/issues/1685\n // for more details\n resolve();\n };\n\n thisImage.on('error', errorHandler);\n\n img.src = d.source;\n this._imgSrc = d.source;\n\n function errorHandler() {\n thisImage.remove();\n resolve();\n }\n }.bind(this));\n\n gd._promises.push(imagePromise);\n }\n }\n\n function applyAttributes(d) {\n var thisImage = d3.select(this);\n\n // Axes if specified\n var xa = Axes.getFromId(gd, d.xref);\n var ya = Axes.getFromId(gd, d.yref);\n var xIsDomain = Axes.getRefType(d.xref) === 'domain';\n var yIsDomain = Axes.getRefType(d.yref) === 'domain';\n\n var size = fullLayout._size;\n var width, height;\n if(xa !== undefined) {\n width = ((typeof(d.xref) === 'string') && xIsDomain) ?\n xa._length * d.sizex :\n Math.abs(xa.l2p(d.sizex) - xa.l2p(0));\n } else {\n width = d.sizex * size.w;\n }\n if(ya !== undefined) {\n height = ((typeof(d.yref) === 'string') && yIsDomain) ?\n ya._length * d.sizey :\n Math.abs(ya.l2p(d.sizey) - ya.l2p(0));\n } else {\n height = d.sizey * size.h;\n }\n\n // Offsets for anchor positioning\n var xOffset = width * anchors.x[d.xanchor].offset;\n var yOffset = height * anchors.y[d.yanchor].offset;\n\n var sizing = anchors.x[d.xanchor].sizing + anchors.y[d.yanchor].sizing;\n\n // Final positions\n var xPos, yPos;\n if(xa !== undefined) {\n xPos = ((typeof(d.xref) === 'string') && xIsDomain) ?\n xa._length * d.x + xa._offset :\n xa.r2p(d.x) + xa._offset;\n } else {\n xPos = d.x * size.w + size.l;\n }\n xPos += xOffset;\n if(ya !== undefined) {\n yPos = ((typeof(d.yref) === 'string') && yIsDomain) ?\n // consistent with \"paper\" yref value, where positive values\n // move up the page\n ya._length * (1 - d.y) + ya._offset :\n ya.r2p(d.y) + ya._offset;\n } else {\n yPos = size.h - d.y * size.h + size.t;\n }\n yPos += yOffset;\n\n // Construct the proper aspectRatio attribute\n switch(d.sizing) {\n case 'fill':\n sizing += ' slice';\n break;\n\n case 'stretch':\n sizing = 'none';\n break;\n }\n\n thisImage.attr({\n x: xPos,\n y: yPos,\n width: width,\n height: height,\n preserveAspectRatio: sizing,\n opacity: d.opacity\n });\n\n\n // Set proper clipping on images\n var xId = xa && (Axes.getRefType(d.xref) !== 'domain') ? xa._id : '';\n var yId = ya && (Axes.getRefType(d.yref) !== 'domain') ? ya._id : '';\n var clipAxes = xId + yId;\n\n Drawing.setClipUrl(\n thisImage,\n clipAxes ? ('clip' + fullLayout._uid + clipAxes) : null,\n gd\n );\n }\n\n var imagesBelow = fullLayout._imageLowerLayer.selectAll('image')\n .data(imageDataBelow);\n var imagesAbove = fullLayout._imageUpperLayer.selectAll('image')\n .data(imageDataAbove);\n\n imagesBelow.enter().append('image');\n imagesAbove.enter().append('image');\n\n imagesBelow.exit().remove();\n imagesAbove.exit().remove();\n\n imagesBelow.each(function(d) {\n setImage.bind(this)(d);\n applyAttributes.bind(this)(d);\n });\n imagesAbove.each(function(d) {\n setImage.bind(this)(d);\n applyAttributes.bind(this)(d);\n });\n\n var allSubplots = Object.keys(fullLayout._plots);\n for(i = 0; i < allSubplots.length; i++) {\n subplot = allSubplots[i];\n var subplotObj = fullLayout._plots[subplot];\n\n // filter out overlaid plots (which have their images on the main plot)\n // and gl2d plots (which don't support below images, at least not yet)\n if(!subplotObj.imagelayer) continue;\n\n var imagesOnSubplot = subplotObj.imagelayer.selectAll('image')\n // even if there are no images on this subplot, we need to run\n // enter and exit in case there were previously\n .data(imageDataSubplot[subplot] || []);\n\n imagesOnSubplot.enter().append('image');\n imagesOnSubplot.exit().remove();\n\n imagesOnSubplot.each(function(d) {\n setImage.bind(this)(d);\n applyAttributes.bind(this)(d);\n });\n }\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'component',\n name: 'images',\n\n layoutAttributes: require('./attributes'),\n supplyLayoutDefaults: require('./defaults'),\n includeBasePlot: require('../../plots/cartesian/include_components')('images'),\n\n draw: require('./draw'),\n\n convertCoords: require('./convert_coords')\n};\n","'use strict';\n\nvar fontAttrs = require('../../plots/font_attributes');\nvar colorAttrs = require('../color/attributes');\n\n\nmodule.exports = {\n // not really a 'subplot' attribute container,\n // but this is the flag we use to denote attributes that\n // support yaxis, yaxis2, yaxis3, ... counters\n _isSubplotObj: true,\n\n visible: {\n valType: 'boolean',\n dflt: true,\n editType: 'legend',\n description: [\n 'Determines whether or not this legend is visible.'\n ].join(' ')\n },\n\n bgcolor: {\n valType: 'color',\n editType: 'legend',\n description: [\n 'Sets the legend background color.',\n 'Defaults to `layout.paper_bgcolor`.'\n ].join(' ')\n },\n bordercolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n editType: 'legend',\n description: 'Sets the color of the border enclosing the legend.'\n },\n borderwidth: {\n valType: 'number',\n min: 0,\n dflt: 0,\n editType: 'legend',\n description: 'Sets the width (in px) of the border enclosing the legend.'\n },\n font: fontAttrs({\n editType: 'legend',\n description: 'Sets the font used to text the legend items.'\n }),\n grouptitlefont: fontAttrs({\n editType: 'legend',\n description: [\n 'Sets the font for group titles in legend.',\n 'Defaults to `legend.font` with its size increased about 10%.'\n ].join(' ')\n }),\n orientation: {\n valType: 'enumerated',\n values: ['v', 'h'],\n dflt: 'v',\n editType: 'legend',\n description: 'Sets the orientation of the legend.'\n },\n traceorder: {\n valType: 'flaglist',\n flags: ['reversed', 'grouped'],\n extras: ['normal'],\n editType: 'legend',\n description: [\n 'Determines the order at which the legend items are displayed.',\n\n 'If *normal*, the items are displayed top-to-bottom in the same',\n 'order as the input data.',\n\n 'If *reversed*, the items are displayed in the opposite order',\n 'as *normal*.',\n\n 'If *grouped*, the items are displayed in groups',\n '(when a trace `legendgroup` is provided).',\n\n 'if *grouped+reversed*, the items are displayed in the opposite order',\n 'as *grouped*.'\n ].join(' ')\n },\n tracegroupgap: {\n valType: 'number',\n min: 0,\n dflt: 10,\n editType: 'legend',\n description: [\n 'Sets the amount of vertical space (in px) between legend groups.'\n ].join(' ')\n },\n entrywidth: {\n valType: 'number',\n min: 0,\n editType: 'legend',\n description: [\n 'Sets the width (in px or fraction) of the legend.',\n 'Use 0 to size the entry based on the text width,',\n 'when `entrywidthmode` is set to *pixels*.'\n ].join(' ')\n },\n entrywidthmode: {\n valType: 'enumerated',\n values: ['fraction', 'pixels'],\n dflt: 'pixels',\n editType: 'legend',\n description: 'Determines what entrywidth means.',\n },\n indentation: {\n valType: 'number',\n min: -15,\n dflt: 0,\n editType: 'legend',\n description: 'Sets the indentation (in px) of the legend entries.',\n },\n itemsizing: {\n valType: 'enumerated',\n values: ['trace', 'constant'],\n dflt: 'trace',\n editType: 'legend',\n description: [\n 'Determines if the legend items symbols scale with their corresponding *trace* attributes',\n 'or remain *constant* independent of the symbol size on the graph.'\n ].join(' ')\n },\n itemwidth: {\n valType: 'number',\n min: 30,\n dflt: 30,\n editType: 'legend',\n description: 'Sets the width (in px) of the legend item symbols (the part other than the title.text).',\n },\n itemclick: {\n valType: 'enumerated',\n values: ['toggle', 'toggleothers', false],\n dflt: 'toggle',\n editType: 'legend',\n description: [\n 'Determines the behavior on legend item click.',\n '*toggle* toggles the visibility of the item clicked on the graph.',\n '*toggleothers* makes the clicked item the sole visible item on the graph.',\n '*false* disables legend item click interactions.'\n ].join(' ')\n },\n itemdoubleclick: {\n valType: 'enumerated',\n values: ['toggle', 'toggleothers', false],\n dflt: 'toggleothers',\n editType: 'legend',\n description: [\n 'Determines the behavior on legend item double-click.',\n '*toggle* toggles the visibility of the item clicked on the graph.',\n '*toggleothers* makes the clicked item the sole visible item on the graph.',\n '*false* disables legend item double-click interactions.'\n ].join(' ')\n },\n groupclick: {\n valType: 'enumerated',\n values: ['toggleitem', 'togglegroup'],\n dflt: 'togglegroup',\n editType: 'legend',\n description: [\n 'Determines the behavior on legend group item click.',\n '*toggleitem* toggles the visibility of the individual item clicked on the graph.',\n '*togglegroup* toggles the visibility of all items in the same legendgroup as the item clicked on the graph.'\n ].join(' ')\n },\n x: {\n valType: 'number',\n editType: 'legend',\n description: [\n 'Sets the x position with respect to `xref` (in normalized coordinates) of the legend.',\n 'When `xref` is *paper*, defaults to *1.02* for vertical legends and',\n 'defaults to *0* for horizontal legends.',\n 'When `xref` is *container*, defaults to *1* for vertical legends and',\n 'defaults to *0* for horizontal legends.',\n 'Must be between *0* and *1* if `xref` is *container*.',\n 'and between *-2* and *3* if `xref` is *paper*.'\n ].join(' ')\n },\n xref: {\n valType: 'enumerated',\n dflt: 'paper',\n values: ['container', 'paper'],\n editType: 'layoutstyle',\n description: [\n 'Sets the container `x` refers to.',\n '*container* spans the entire `width` of the plot.',\n '*paper* refers to the width of the plotting area only.'\n ].join(' ')\n },\n xanchor: {\n valType: 'enumerated',\n values: ['auto', 'left', 'center', 'right'],\n dflt: 'left',\n editType: 'legend',\n description: [\n 'Sets the legend\\'s horizontal position anchor.',\n 'This anchor binds the `x` position to the *left*, *center*',\n 'or *right* of the legend.',\n 'Value *auto* anchors legends to the right for `x` values greater than or equal to 2/3,',\n 'anchors legends to the left for `x` values less than or equal to 1/3 and',\n 'anchors legends with respect to their center otherwise.'\n ].join(' ')\n },\n y: {\n valType: 'number',\n editType: 'legend',\n description: [\n 'Sets the y position with respect to `yref` (in normalized coordinates) of the legend.',\n 'When `yref` is *paper*, defaults to *1* for vertical legends,',\n 'defaults to *-0.1* for horizontal legends on graphs w/o range sliders and',\n 'defaults to *1.1* for horizontal legends on graph with one or multiple range sliders.',\n 'When `yref` is *container*, defaults to *1*.',\n 'Must be between *0* and *1* if `yref` is *container*',\n 'and between *-2* and *3* if `yref` is *paper*.'\n ].join(' ')\n },\n yref: {\n valType: 'enumerated',\n dflt: 'paper',\n values: ['container', 'paper'],\n editType: 'layoutstyle',\n description: [\n 'Sets the container `y` refers to.',\n '*container* spans the entire `height` of the plot.',\n '*paper* refers to the height of the plotting area only.'\n ].join(' ')\n },\n yanchor: {\n valType: 'enumerated',\n values: ['auto', 'top', 'middle', 'bottom'],\n editType: 'legend',\n description: [\n 'Sets the legend\\'s vertical position anchor',\n 'This anchor binds the `y` position to the *top*, *middle*',\n 'or *bottom* of the legend.',\n 'Value *auto* anchors legends at their bottom for `y` values less than or equal to 1/3,',\n 'anchors legends to at their top for `y` values greater than or equal to 2/3 and',\n 'anchors legends with respect to their middle otherwise.'\n ].join(' ')\n },\n uirevision: {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of legend-driven changes in trace and pie label',\n 'visibility. Defaults to `layout.uirevision`.'\n ].join(' ')\n },\n valign: {\n valType: 'enumerated',\n values: ['top', 'middle', 'bottom'],\n dflt: 'middle',\n editType: 'legend',\n description: [\n 'Sets the vertical alignment of the symbols with respect to their associated text.',\n ].join(' ')\n },\n title: {\n text: {\n valType: 'string',\n dflt: '',\n editType: 'legend',\n description: [\n 'Sets the title of the legend.'\n ].join(' ')\n },\n font: fontAttrs({\n editType: 'legend',\n description: [\n 'Sets this legend\\'s title font.',\n 'Defaults to `legend.font` with its size increased about 20%.'\n ].join(' '),\n }),\n side: {\n valType: 'enumerated',\n values: ['top', 'left', 'top left', 'top center', 'top right'],\n editType: 'legend',\n description: [\n 'Determines the location of legend\\'s title',\n 'with respect to the legend items.',\n 'Defaulted to *top* with `orientation` is *h*.',\n 'Defaulted to *left* with `orientation` is *v*.',\n 'The *top left* options could be used to expand',\n 'top center and top right are for horizontal alignment',\n 'legend area in both x and y sides.'\n ].join(' ')\n },\n editType: 'legend',\n },\n editType: 'legend'\n};\n","'use strict';\n\nmodule.exports = {\n scrollBarWidth: 6,\n scrollBarMinHeight: 20,\n scrollBarColor: '#808BA4',\n scrollBarMargin: 4,\n scrollBarEnterAttrs: {rx: 20, ry: 3, width: 0, height: 0},\n\n // number of px between legend title and (left) side of legend (always in x direction and from inner border)\n titlePad: 2,\n // number of px between each legend item (x and/or y direction)\n itemGap: 5\n};\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Template = require('../../plot_api/plot_template');\n\nvar plotsAttrs = require('../../plots/attributes');\nvar attributes = require('./attributes');\nvar basePlotLayoutAttributes = require('../../plots/layout_attributes');\nvar helpers = require('./helpers');\n\nfunction groupDefaults(legendId, layoutIn, layoutOut, fullData) {\n var containerIn = layoutIn[legendId] || {};\n var containerOut = Template.newContainer(layoutOut, legendId);\n\n function coerce(attr, dflt) {\n return Lib.coerce(containerIn, containerOut, attributes, attr, dflt);\n }\n\n // N.B. unified hover needs to inherit from font, bgcolor & bordercolor even when legend.visible is false\n var itemFont = Lib.coerceFont(coerce, 'font', layoutOut.font);\n coerce('bgcolor', layoutOut.paper_bgcolor);\n coerce('bordercolor');\n\n var visible = coerce('visible');\n if(!visible) return;\n\n var trace;\n var traceCoerce = function(attr, dflt) {\n var traceIn = trace._input;\n var traceOut = trace;\n return Lib.coerce(traceIn, traceOut, plotsAttrs, attr, dflt);\n };\n\n var globalFont = layoutOut.font || {};\n var grouptitlefont = Lib.coerceFont(coerce, 'grouptitlefont', globalFont, { overrideDflt: {\n size: Math.round(globalFont.size * 1.1)\n }});\n\n var legendTraceCount = 0;\n var legendReallyHasATrace = false;\n var defaultOrder = 'normal';\n\n var shapesWithLegend = (layoutOut.shapes || []).filter(function(d) { return d.showlegend; });\n\n var allLegendItems = fullData.concat(shapesWithLegend).filter(function(d) {\n return legendId === (d.legend || 'legend');\n });\n\n for(var i = 0; i < allLegendItems.length; i++) {\n trace = allLegendItems[i];\n\n if(!trace.visible) continue;\n\n var isShape = trace._isShape;\n\n // Note that we explicitly count any trace that is either shown or\n // *would* be shown by default, toward the two traces you need to\n // ensure the legend is shown by default, because this can still help\n // disambiguate.\n if(trace.showlegend || (\n trace._dfltShowLegend && !(\n trace._module &&\n trace._module.attributes &&\n trace._module.attributes.showlegend &&\n trace._module.attributes.showlegend.dflt === false\n )\n )) {\n legendTraceCount++;\n if(trace.showlegend) {\n legendReallyHasATrace = true;\n // Always show the legend by default if there's a pie,\n // or if there's only one trace but it's explicitly shown\n if(!isShape && Registry.traceIs(trace, 'pie-like') ||\n trace._input.showlegend === true\n ) {\n legendTraceCount++;\n }\n }\n\n Lib.coerceFont(traceCoerce, 'legendgrouptitle.font', grouptitlefont);\n }\n\n if((!isShape && Registry.traceIs(trace, 'bar') && layoutOut.barmode === 'stack') ||\n ['tonextx', 'tonexty'].indexOf(trace.fill) !== -1) {\n defaultOrder = helpers.isGrouped({traceorder: defaultOrder}) ?\n 'grouped+reversed' : 'reversed';\n }\n\n if(trace.legendgroup !== undefined && trace.legendgroup !== '') {\n defaultOrder = helpers.isReversed({traceorder: defaultOrder}) ?\n 'reversed+grouped' : 'grouped';\n }\n }\n\n var showLegend = Lib.coerce(layoutIn, layoutOut,\n basePlotLayoutAttributes, 'showlegend',\n legendReallyHasATrace && (legendTraceCount > (legendId === 'legend' ? 1 : 0)));\n\n // delete legend\n if(showLegend === false) layoutOut[legendId] = undefined;\n\n if(showLegend === false && !containerIn.uirevision) return;\n\n coerce('uirevision', layoutOut.uirevision);\n\n if(showLegend === false) return;\n\n coerce('borderwidth');\n\n var orientation = coerce('orientation');\n\n var yref = coerce('yref');\n var xref = coerce('xref');\n\n var isHorizontal = orientation === 'h';\n var isPaperY = yref === 'paper';\n var isPaperX = xref === 'paper';\n var defaultX, defaultY, defaultYAnchor;\n var defaultXAnchor = 'left';\n\n if(isHorizontal) {\n defaultX = 0;\n\n if(Registry.getComponentMethod('rangeslider', 'isVisible')(layoutIn.xaxis)) {\n if(isPaperY) {\n defaultY = 1.1;\n defaultYAnchor = 'bottom';\n } else {\n defaultY = 1;\n defaultYAnchor = 'top';\n }\n } else {\n // maybe use y=1.1 / yanchor=bottom as above\n // to avoid https://github.com/plotly/plotly.js/issues/1199\n // in v3\n if(isPaperY) {\n defaultY = -0.1;\n defaultYAnchor = 'top';\n } else {\n defaultY = 0;\n defaultYAnchor = 'bottom';\n }\n }\n } else {\n defaultY = 1;\n defaultYAnchor = 'auto';\n if(isPaperX) {\n defaultX = 1.02;\n } else {\n defaultX = 1;\n defaultXAnchor = 'right';\n }\n }\n\n Lib.coerce(containerIn, containerOut, {\n x: {\n valType: 'number',\n editType: 'legend',\n min: isPaperX ? -2 : 0,\n max: isPaperX ? 3 : 1,\n dflt: defaultX,\n }\n }, 'x');\n\n Lib.coerce(containerIn, containerOut, {\n y: {\n valType: 'number',\n editType: 'legend',\n min: isPaperY ? -2 : 0,\n max: isPaperY ? 3 : 1,\n dflt: defaultY,\n }\n }, 'y');\n\n coerce('traceorder', defaultOrder);\n if(helpers.isGrouped(layoutOut[legendId])) coerce('tracegroupgap');\n\n coerce('entrywidth');\n coerce('entrywidthmode');\n coerce('indentation');\n coerce('itemsizing');\n coerce('itemwidth');\n\n coerce('itemclick');\n coerce('itemdoubleclick');\n coerce('groupclick');\n\n coerce('xanchor', defaultXAnchor);\n coerce('yanchor', defaultYAnchor);\n coerce('valign');\n Lib.noneOrAll(containerIn, containerOut, ['x', 'y']);\n\n var titleText = coerce('title.text');\n if(titleText) {\n coerce('title.side', isHorizontal ? 'left' : 'top');\n var dfltTitleFont = Lib.extendFlat({}, itemFont, {\n size: Lib.bigFont(itemFont.size)\n });\n\n Lib.coerceFont(coerce, 'title.font', dfltTitleFont);\n }\n}\n\nmodule.exports = function legendDefaults(layoutIn, layoutOut, fullData) {\n var i;\n\n var allLegendsData = fullData.slice();\n\n // shapes could also show up in legends\n var shapes = layoutOut.shapes;\n if(shapes) {\n for(i = 0; i < shapes.length; i++) {\n var shape = shapes[i];\n if(!shape.showlegend) continue;\n\n var mockTrace = {\n _input: shape._input,\n visible: shape.visible,\n showlegend: shape.showlegend,\n legend: shape.legend\n };\n\n allLegendsData.push(mockTrace);\n }\n }\n\n var legends = ['legend'];\n for(i = 0; i < allLegendsData.length; i++) {\n Lib.pushUnique(legends, allLegendsData[i].legend);\n }\n\n layoutOut._legends = [];\n for(i = 0; i < legends.length; i++) {\n var legendId = legends[i];\n\n groupDefaults(legendId, layoutIn, layoutOut, allLegendsData);\n\n if(\n layoutOut[legendId] &&\n layoutOut[legendId].visible\n ) {\n layoutOut[legendId]._id = legendId;\n }\n\n layoutOut._legends.push(legendId);\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Lib = require('../../lib');\nvar Plots = require('../../plots/plots');\nvar Registry = require('../../registry');\nvar Events = require('../../lib/events');\nvar dragElement = require('../dragelement');\nvar Drawing = require('../drawing');\nvar Color = require('../color');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar handleClick = require('./handle_click');\n\nvar constants = require('./constants');\nvar alignmentConstants = require('../../constants/alignment');\nvar LINE_SPACING = alignmentConstants.LINE_SPACING;\nvar FROM_TL = alignmentConstants.FROM_TL;\nvar FROM_BR = alignmentConstants.FROM_BR;\n\nvar getLegendData = require('./get_legend_data');\nvar style = require('./style');\nvar helpers = require('./helpers');\n\nvar MAIN_TITLE = 1;\n\nvar LEGEND_PATTERN = /^legend[0-9]*$/;\n\nmodule.exports = function draw(gd, opts) {\n if(opts) {\n drawOne(gd, opts);\n } else {\n var fullLayout = gd._fullLayout;\n var newLegends = fullLayout._legends;\n\n // remove old legends that won't stay on the graph\n var oldLegends = fullLayout._infolayer.selectAll('[class^=\"legend\"]');\n\n oldLegends.each(function() {\n var el = d3.select(this);\n var classes = el.attr('class');\n var cls = classes.split(' ')[0];\n if(cls.match(LEGEND_PATTERN) && newLegends.indexOf(cls) === -1) {\n el.remove();\n }\n });\n\n // draw/update new legends\n for(var i = 0; i < newLegends.length; i++) {\n var legendId = newLegends[i];\n var legendObj = gd._fullLayout[legendId];\n drawOne(gd, legendObj);\n }\n }\n};\n\n// After legend dimensions are calculated the title can be aligned horizontally left, center, right\nfunction horizontalAlignTitle(titleEl, legendObj, bw) {\n if((legendObj.title.side !== 'top center') && (legendObj.title.side !== 'top right')) return;\n\n var font = legendObj.title.font;\n var lineHeight = font.size * LINE_SPACING;\n var titleOffset = 0;\n var textNode = titleEl.node();\n\n var width = Drawing.bBox(textNode).width; // width of the title text\n\n if(legendObj.title.side === 'top center') {\n titleOffset = 0.5 * (legendObj._width - 2 * bw - 2 * constants.titlePad - width);\n } else if(legendObj.title.side === 'top right') {\n titleOffset = legendObj._width - 2 * bw - 2 * constants.titlePad - width;\n }\n\n svgTextUtils.positionText(titleEl,\n bw + constants.titlePad + titleOffset,\n bw + lineHeight\n );\n}\n\n\nfunction drawOne(gd, opts) {\n var legendObj = opts || {};\n\n var fullLayout = gd._fullLayout;\n var legendId = getId(legendObj);\n\n var clipId, layer;\n\n var inHover = legendObj._inHover;\n if(inHover) {\n layer = legendObj.layer;\n clipId = 'hover';\n } else {\n layer = fullLayout._infolayer;\n clipId = legendId;\n }\n if(!layer) return;\n clipId += fullLayout._uid;\n\n if(!gd._legendMouseDownTime) gd._legendMouseDownTime = 0;\n\n var legendData;\n if(!inHover) {\n var calcdata = (gd.calcdata || []).slice();\n\n var shapes = fullLayout.shapes;\n for(var i = 0; i < shapes.length; i++) {\n var shape = shapes[i];\n if(!shape.showlegend) continue;\n\n var shapeLegend = {\n _isShape: true,\n _fullInput: shape,\n index: shape._index,\n name: shape.name || shape.label.text || ('shape ' + shape._index),\n legend: shape.legend,\n legendgroup: shape.legendgroup,\n legendgrouptitle: shape.legendgrouptitle,\n legendrank: shape.legendrank,\n legendwidth: shape.legendwidth,\n showlegend: shape.showlegend,\n visible: shape.visible,\n opacity: shape.opacity,\n mode: shape.type === 'line' ? 'lines' : 'markers',\n line: shape.line,\n marker: {\n line: shape.line,\n color: shape.fillcolor,\n size: 12,\n symbol:\n shape.type === 'rect' ? 'square' :\n shape.type === 'circle' ? 'circle' :\n // case of path\n 'hexagon2'\n },\n };\n\n calcdata.push([{ trace: shapeLegend }]);\n }\n\n legendData = fullLayout.showlegend && getLegendData(calcdata, legendObj, fullLayout._legends.length > 1);\n } else {\n if(!legendObj.entries) return;\n legendData = getLegendData(legendObj.entries, legendObj);\n }\n\n var hiddenSlices = fullLayout.hiddenlabels || [];\n\n if(!inHover && (!fullLayout.showlegend || !legendData.length)) {\n layer.selectAll('.' + legendId).remove();\n fullLayout._topdefs.select('#' + clipId).remove();\n return Plots.autoMargin(gd, legendId);\n }\n\n var legend = Lib.ensureSingle(layer, 'g', legendId, function(s) {\n if(!inHover) s.attr('pointer-events', 'all');\n });\n\n var clipPath = Lib.ensureSingleById(fullLayout._topdefs, 'clipPath', clipId, function(s) {\n s.append('rect');\n });\n\n var bg = Lib.ensureSingle(legend, 'rect', 'bg', function(s) {\n s.attr('shape-rendering', 'crispEdges');\n });\n bg.call(Color.stroke, legendObj.bordercolor)\n .call(Color.fill, legendObj.bgcolor)\n .style('stroke-width', legendObj.borderwidth + 'px');\n\n var scrollBox = Lib.ensureSingle(legend, 'g', 'scrollbox');\n\n var title = legendObj.title;\n legendObj._titleWidth = 0;\n legendObj._titleHeight = 0;\n var titleEl;\n if(title.text) {\n titleEl = Lib.ensureSingle(scrollBox, 'text', legendId + 'titletext');\n titleEl.attr('text-anchor', 'start')\n .call(Drawing.font, title.font)\n .text(title.text);\n\n textLayout(titleEl, scrollBox, gd, legendObj, MAIN_TITLE); // handle mathjax or multi-line text and compute title height\n } else {\n scrollBox.selectAll('.' + legendId + 'titletext').remove();\n }\n\n var scrollBar = Lib.ensureSingle(legend, 'rect', 'scrollbar', function(s) {\n s.attr(constants.scrollBarEnterAttrs)\n .call(Color.fill, constants.scrollBarColor);\n });\n\n var groups = scrollBox.selectAll('g.groups').data(legendData);\n groups.enter().append('g').attr('class', 'groups');\n groups.exit().remove();\n\n var traces = groups.selectAll('g.traces').data(Lib.identity);\n traces.enter().append('g').attr('class', 'traces');\n traces.exit().remove();\n\n traces.style('opacity', function(d) {\n var trace = d[0].trace;\n if(Registry.traceIs(trace, 'pie-like')) {\n return hiddenSlices.indexOf(d[0].label) !== -1 ? 0.5 : 1;\n } else {\n return trace.visible === 'legendonly' ? 0.5 : 1;\n }\n })\n .each(function() { d3.select(this).call(drawTexts, gd, legendObj); })\n .call(style, gd, legendObj)\n .each(function() { if(!inHover) d3.select(this).call(setupTraceToggle, gd, legendId); });\n\n Lib.syncOrAsync([\n Plots.previousPromises,\n function() { return computeLegendDimensions(gd, groups, traces, legendObj); },\n function() {\n var gs = fullLayout._size;\n var bw = legendObj.borderwidth;\n var isPaperX = legendObj.xref === 'paper';\n var isPaperY = legendObj.yref === 'paper';\n\n // re-calculate title position after legend width is derived. To allow for horizontal alignment\n if(title.text) {\n horizontalAlignTitle(titleEl, legendObj, bw);\n }\n\n if(!inHover) {\n var lx, ly;\n\n if(isPaperX) {\n lx = gs.l + gs.w * legendObj.x - FROM_TL[getXanchor(legendObj)] * legendObj._width;\n } else {\n lx = fullLayout.width * legendObj.x - FROM_TL[getXanchor(legendObj)] * legendObj._width;\n }\n\n if(isPaperY) {\n ly = gs.t + gs.h * (1 - legendObj.y) - FROM_TL[getYanchor(legendObj)] * legendObj._effHeight;\n } else {\n ly = fullLayout.height * (1 - legendObj.y) - FROM_TL[getYanchor(legendObj)] * legendObj._effHeight;\n }\n\n var expMargin = expandMargin(gd, legendId, lx, ly);\n\n // IF expandMargin return a Promise (which is truthy),\n // we're under a doAutoMargin redraw, so we don't have to\n // draw the remaining pieces below\n if(expMargin) return;\n\n if(fullLayout.margin.autoexpand) {\n var lx0 = lx;\n var ly0 = ly;\n\n lx = isPaperX ? Lib.constrain(lx, 0, fullLayout.width - legendObj._width) : lx0;\n ly = isPaperY ? Lib.constrain(ly, 0, fullLayout.height - legendObj._effHeight) : ly0;\n\n if(lx !== lx0) {\n Lib.log('Constrain ' + legendId + '.x to make legend fit inside graph');\n }\n if(ly !== ly0) {\n Lib.log('Constrain ' + legendId + '.y to make legend fit inside graph');\n }\n }\n\n // Set size and position of all the elements that make up a legend:\n // legend, background and border, scroll box and scroll bar as well as title\n Drawing.setTranslate(legend, lx, ly);\n }\n\n // to be safe, remove previous listeners\n scrollBar.on('.drag', null);\n legend.on('wheel', null);\n\n if(inHover || legendObj._height <= legendObj._maxHeight || gd._context.staticPlot) {\n // if scrollbar should not be shown.\n var height = legendObj._effHeight;\n\n // if unified hover, let it be its full size\n if(inHover) height = legendObj._height;\n\n bg.attr({\n width: legendObj._width - bw,\n height: height - bw,\n x: bw / 2,\n y: bw / 2\n });\n\n Drawing.setTranslate(scrollBox, 0, 0);\n\n clipPath.select('rect').attr({\n width: legendObj._width - 2 * bw,\n height: height - 2 * bw,\n x: bw,\n y: bw\n });\n\n Drawing.setClipUrl(scrollBox, clipId, gd);\n\n Drawing.setRect(scrollBar, 0, 0, 0, 0);\n delete legendObj._scrollY;\n } else {\n var scrollBarHeight = Math.max(constants.scrollBarMinHeight,\n legendObj._effHeight * legendObj._effHeight / legendObj._height);\n var scrollBarYMax = legendObj._effHeight -\n scrollBarHeight -\n 2 * constants.scrollBarMargin;\n var scrollBoxYMax = legendObj._height - legendObj._effHeight;\n var scrollRatio = scrollBarYMax / scrollBoxYMax;\n\n var scrollBoxY = Math.min(legendObj._scrollY || 0, scrollBoxYMax);\n\n // increase the background and clip-path width\n // by the scrollbar width and margin\n bg.attr({\n width: legendObj._width -\n 2 * bw +\n constants.scrollBarWidth +\n constants.scrollBarMargin,\n height: legendObj._effHeight - bw,\n x: bw / 2,\n y: bw / 2\n });\n\n clipPath.select('rect').attr({\n width: legendObj._width -\n 2 * bw +\n constants.scrollBarWidth +\n constants.scrollBarMargin,\n height: legendObj._effHeight - 2 * bw,\n x: bw,\n y: bw + scrollBoxY\n });\n\n Drawing.setClipUrl(scrollBox, clipId, gd);\n\n scrollHandler(scrollBoxY, scrollBarHeight, scrollRatio);\n\n // scroll legend by mousewheel or touchpad swipe up/down\n legend.on('wheel', function() {\n scrollBoxY = Lib.constrain(\n legendObj._scrollY +\n ((d3.event.deltaY / scrollBarYMax) * scrollBoxYMax),\n 0, scrollBoxYMax);\n scrollHandler(scrollBoxY, scrollBarHeight, scrollRatio);\n if(scrollBoxY !== 0 && scrollBoxY !== scrollBoxYMax) {\n d3.event.preventDefault();\n }\n });\n\n var eventY0, eventY1, scrollBoxY0;\n\n var getScrollBarDragY = function(scrollBoxY0, eventY0, eventY1) {\n var y = ((eventY1 - eventY0) / scrollRatio) + scrollBoxY0;\n return Lib.constrain(y, 0, scrollBoxYMax);\n };\n\n var getNaturalDragY = function(scrollBoxY0, eventY0, eventY1) {\n var y = ((eventY0 - eventY1) / scrollRatio) + scrollBoxY0;\n return Lib.constrain(y, 0, scrollBoxYMax);\n };\n\n // scroll legend by dragging scrollBAR\n var scrollBarDrag = d3.behavior.drag()\n .on('dragstart', function() {\n var e = d3.event.sourceEvent;\n if(e.type === 'touchstart') {\n eventY0 = e.changedTouches[0].clientY;\n } else {\n eventY0 = e.clientY;\n }\n scrollBoxY0 = scrollBoxY;\n })\n .on('drag', function() {\n var e = d3.event.sourceEvent;\n if(e.buttons === 2 || e.ctrlKey) return;\n if(e.type === 'touchmove') {\n eventY1 = e.changedTouches[0].clientY;\n } else {\n eventY1 = e.clientY;\n }\n scrollBoxY = getScrollBarDragY(scrollBoxY0, eventY0, eventY1);\n scrollHandler(scrollBoxY, scrollBarHeight, scrollRatio);\n });\n scrollBar.call(scrollBarDrag);\n\n // scroll legend by touch-dragging scrollBOX\n var scrollBoxTouchDrag = d3.behavior.drag()\n .on('dragstart', function() {\n var e = d3.event.sourceEvent;\n if(e.type === 'touchstart') {\n eventY0 = e.changedTouches[0].clientY;\n scrollBoxY0 = scrollBoxY;\n }\n })\n .on('drag', function() {\n var e = d3.event.sourceEvent;\n if(e.type === 'touchmove') {\n eventY1 = e.changedTouches[0].clientY;\n scrollBoxY = getNaturalDragY(scrollBoxY0, eventY0, eventY1);\n scrollHandler(scrollBoxY, scrollBarHeight, scrollRatio);\n }\n });\n scrollBox.call(scrollBoxTouchDrag);\n }\n\n function scrollHandler(scrollBoxY, scrollBarHeight, scrollRatio) {\n legendObj._scrollY = gd._fullLayout[legendId]._scrollY = scrollBoxY;\n Drawing.setTranslate(scrollBox, 0, -scrollBoxY);\n\n Drawing.setRect(\n scrollBar,\n legendObj._width,\n constants.scrollBarMargin + scrollBoxY * scrollRatio,\n constants.scrollBarWidth,\n scrollBarHeight\n );\n clipPath.select('rect').attr('y', bw + scrollBoxY);\n }\n\n if(gd._context.edits.legendPosition) {\n var xf, yf, x0, y0;\n\n legend.classed('cursor-move', true);\n\n dragElement.init({\n element: legend.node(),\n gd: gd,\n prepFn: function(e) {\n if(e.target === scrollBar.node()) {\n return;\n }\n var transform = Drawing.getTranslate(legend);\n x0 = transform.x;\n y0 = transform.y;\n },\n moveFn: function(dx, dy) {\n if(x0 !== undefined && y0 !== undefined) {\n var newX = x0 + dx;\n var newY = y0 + dy;\n\n Drawing.setTranslate(legend, newX, newY);\n xf = dragElement.align(newX, legendObj._width, gs.l, gs.l + gs.w, legendObj.xanchor);\n yf = dragElement.align(newY + legendObj._height, -legendObj._height, gs.t + gs.h, gs.t, legendObj.yanchor);\n }\n },\n doneFn: function() {\n if(xf !== undefined && yf !== undefined) {\n var obj = {};\n obj[legendId + '.x'] = xf;\n obj[legendId + '.y'] = yf;\n Registry.call('_guiRelayout', gd, obj);\n }\n },\n clickFn: function(numClicks, e) {\n var clickedTrace = layer.selectAll('g.traces').filter(function() {\n var bbox = this.getBoundingClientRect();\n return (\n e.clientX >= bbox.left && e.clientX <= bbox.right &&\n e.clientY >= bbox.top && e.clientY <= bbox.bottom\n );\n });\n if(clickedTrace.size() > 0) {\n clickOrDoubleClick(gd, legend, clickedTrace, numClicks, e);\n }\n }\n });\n }\n }], gd);\n}\n\nfunction getTraceWidth(d, legendObj, textGap) {\n var legendItem = d[0];\n var legendWidth = legendItem.width;\n var mode = legendObj.entrywidthmode;\n\n var traceLegendWidth = legendItem.trace.legendwidth || legendObj.entrywidth;\n\n if(mode === 'fraction') return legendObj._maxWidth * traceLegendWidth;\n\n return textGap + (traceLegendWidth || legendWidth);\n}\n\nfunction clickOrDoubleClick(gd, legend, legendItem, numClicks, evt) {\n var trace = legendItem.data()[0][0].trace;\n var evtData = {\n event: evt,\n node: legendItem.node(),\n curveNumber: trace.index,\n expandedIndex: trace._expandedIndex,\n data: gd.data,\n layout: gd.layout,\n frames: gd._transitionData._frames,\n config: gd._context,\n fullData: gd._fullData,\n fullLayout: gd._fullLayout\n };\n\n if(trace._group) {\n evtData.group = trace._group;\n }\n if(Registry.traceIs(trace, 'pie-like')) {\n evtData.label = legendItem.datum()[0].label;\n }\n var clickVal = Events.triggerHandler(gd, 'plotly_legendclick', evtData);\n if(numClicks === 1) {\n if(clickVal === false) return;\n legend._clickTimeout = setTimeout(function() {\n if(!gd._fullLayout) return;\n handleClick(legendItem, gd, numClicks);\n }, gd._context.doubleClickDelay);\n } else if(numClicks === 2) {\n if(legend._clickTimeout) clearTimeout(legend._clickTimeout);\n gd._legendMouseDownTime = 0;\n\n var dblClickVal = Events.triggerHandler(gd, 'plotly_legenddoubleclick', evtData);\n // Activate default double click behaviour only when both single click and double click values are not false\n if(dblClickVal !== false && clickVal !== false) handleClick(legendItem, gd, numClicks);\n }\n}\n\nfunction drawTexts(g, gd, legendObj) {\n var legendId = getId(legendObj);\n var legendItem = g.data()[0][0];\n var trace = legendItem.trace;\n var isPieLike = Registry.traceIs(trace, 'pie-like');\n var isEditable = !legendObj._inHover && gd._context.edits.legendText && !isPieLike;\n var maxNameLength = legendObj._maxNameLength;\n\n var name, font;\n if(legendItem.groupTitle) {\n name = legendItem.groupTitle.text;\n font = legendItem.groupTitle.font;\n } else {\n font = legendObj.font;\n if(!legendObj.entries) {\n name = isPieLike ? legendItem.label : trace.name;\n if(trace._meta) {\n name = Lib.templateString(name, trace._meta);\n }\n } else {\n name = legendItem.text;\n }\n }\n\n var textEl = Lib.ensureSingle(g, 'text', legendId + 'text');\n\n textEl.attr('text-anchor', 'start')\n .call(Drawing.font, font)\n .text(isEditable ? ensureLength(name, maxNameLength) : name);\n\n var textGap = legendObj.indentation + legendObj.itemwidth + constants.itemGap * 2;\n svgTextUtils.positionText(textEl, textGap, 0);\n\n if(isEditable) {\n textEl.call(svgTextUtils.makeEditable, {gd: gd, text: name})\n .call(textLayout, g, gd, legendObj)\n .on('edit', function(newName) {\n this.text(ensureLength(newName, maxNameLength))\n .call(textLayout, g, gd, legendObj);\n\n var fullInput = legendItem.trace._fullInput || {};\n var update = {};\n\n if(Registry.hasTransform(fullInput, 'groupby')) {\n var groupbyIndices = Registry.getTransformIndices(fullInput, 'groupby');\n var _index = groupbyIndices[groupbyIndices.length - 1];\n\n var kcont = Lib.keyedContainer(fullInput, 'transforms[' + _index + '].styles', 'target', 'value.name');\n\n kcont.set(legendItem.trace._group, newName);\n\n update = kcont.constructUpdate();\n } else {\n update.name = newName;\n }\n\n if(fullInput._isShape) {\n return Registry.call('_guiRelayout', gd, 'shapes[' + trace.index + '].name', update.name);\n } else {\n return Registry.call('_guiRestyle', gd, update, trace.index);\n }\n });\n } else {\n textLayout(textEl, g, gd, legendObj);\n }\n}\n\n/*\n * Make sure we have a reasonably clickable region.\n * If this string is missing or very short, pad it with spaces out to at least\n * 4 characters, up to the max length of other labels, on the assumption that\n * most characters are wider than spaces so a string of spaces will usually be\n * no wider than the real labels.\n */\nfunction ensureLength(str, maxLength) {\n var targetLength = Math.max(4, maxLength);\n if(str && str.trim().length >= targetLength / 2) return str;\n str = str || '';\n for(var i = targetLength - str.length; i > 0; i--) str += ' ';\n return str;\n}\n\nfunction setupTraceToggle(g, gd, legendId) {\n var doubleClickDelay = gd._context.doubleClickDelay;\n var newMouseDownTime;\n var numClicks = 1;\n\n var traceToggle = Lib.ensureSingle(g, 'rect', legendId + 'toggle', function(s) {\n if(!gd._context.staticPlot) {\n s.style('cursor', 'pointer').attr('pointer-events', 'all');\n }\n s.call(Color.fill, 'rgba(0,0,0,0)');\n });\n\n if(gd._context.staticPlot) return;\n\n traceToggle.on('mousedown', function() {\n newMouseDownTime = (new Date()).getTime();\n if(newMouseDownTime - gd._legendMouseDownTime < doubleClickDelay) {\n // in a click train\n numClicks += 1;\n } else {\n // new click train\n numClicks = 1;\n gd._legendMouseDownTime = newMouseDownTime;\n }\n });\n traceToggle.on('mouseup', function() {\n if(gd._dragged || gd._editing) return;\n var legend = gd._fullLayout[legendId];\n\n if((new Date()).getTime() - gd._legendMouseDownTime > doubleClickDelay) {\n numClicks = Math.max(numClicks - 1, 1);\n }\n\n clickOrDoubleClick(gd, legend, g, numClicks, d3.event);\n });\n}\n\nfunction textLayout(s, g, gd, legendObj, aTitle) {\n if(legendObj._inHover) s.attr('data-notex', true); // do not process MathJax for unified hover\n svgTextUtils.convertToTspans(s, gd, function() {\n computeTextDimensions(g, gd, legendObj, aTitle);\n });\n}\n\nfunction computeTextDimensions(g, gd, legendObj, aTitle) {\n var legendItem = g.data()[0][0];\n if(!legendObj._inHover && legendItem && !legendItem.trace.showlegend) {\n g.remove();\n return;\n }\n\n var mathjaxGroup = g.select('g[class*=math-group]');\n var mathjaxNode = mathjaxGroup.node();\n\n var legendId = getId(legendObj);\n if(!legendObj) {\n legendObj = gd._fullLayout[legendId];\n }\n var bw = legendObj.borderwidth;\n var font;\n if(aTitle === MAIN_TITLE) {\n font = legendObj.title.font;\n } else if(legendItem.groupTitle) {\n font = legendItem.groupTitle.font;\n } else {\n font = legendObj.font;\n }\n var lineHeight = font.size * LINE_SPACING;\n var height, width;\n\n if(mathjaxNode) {\n var mathjaxBB = Drawing.bBox(mathjaxNode);\n\n height = mathjaxBB.height;\n width = mathjaxBB.width;\n\n if(aTitle === MAIN_TITLE) {\n Drawing.setTranslate(mathjaxGroup, bw, bw + height * 0.75);\n } else { // legend item\n Drawing.setTranslate(mathjaxGroup, 0, height * 0.25);\n }\n } else {\n var cls = '.' + legendId + (\n aTitle === MAIN_TITLE ? 'title' : ''\n ) + 'text';\n\n var textEl = g.select(cls);\n\n var textLines = svgTextUtils.lineCount(textEl);\n var textNode = textEl.node();\n\n height = lineHeight * textLines;\n width = textNode ? Drawing.bBox(textNode).width : 0;\n\n // approximation to height offset to center the font\n // to avoid getBoundingClientRect\n if(aTitle === MAIN_TITLE) {\n if(legendObj.title.side === 'left') {\n // add extra space between legend title and itmes\n width += constants.itemGap * 2;\n }\n\n svgTextUtils.positionText(textEl,\n bw + constants.titlePad,\n bw + lineHeight\n );\n } else { // legend item\n var x = constants.itemGap * 2 + legendObj.indentation + legendObj.itemwidth;\n if(legendItem.groupTitle) {\n x = constants.itemGap;\n width -= legendObj.indentation + legendObj.itemwidth;\n }\n\n svgTextUtils.positionText(textEl,\n x,\n -lineHeight * ((textLines - 1) / 2 - 0.3)\n );\n }\n }\n\n if(aTitle === MAIN_TITLE) {\n legendObj._titleWidth = width;\n legendObj._titleHeight = height;\n } else { // legend item\n legendItem.lineHeight = lineHeight;\n legendItem.height = Math.max(height, 16) + 3;\n legendItem.width = width;\n }\n}\n\nfunction getTitleSize(legendObj) {\n var w = 0;\n var h = 0;\n\n var side = legendObj.title.side;\n if(side) {\n if(side.indexOf('left') !== -1) {\n w = legendObj._titleWidth;\n }\n if(side.indexOf('top') !== -1) {\n h = legendObj._titleHeight;\n }\n }\n\n return [w, h];\n}\n\n/*\n * Computes in fullLayout[legendId]:\n *\n * - _height: legend height including items past scrollbox height\n * - _maxHeight: maximum legend height before scrollbox is required\n * - _effHeight: legend height w/ or w/o scrollbox\n *\n * - _width: legend width\n * - _maxWidth (for orientation:h only): maximum width before starting new row\n */\nfunction computeLegendDimensions(gd, groups, traces, legendObj) {\n var fullLayout = gd._fullLayout;\n var legendId = getId(legendObj);\n if(!legendObj) {\n legendObj = fullLayout[legendId];\n }\n var gs = fullLayout._size;\n\n var isVertical = helpers.isVertical(legendObj);\n var isGrouped = helpers.isGrouped(legendObj);\n var isFraction = legendObj.entrywidthmode === 'fraction';\n\n var bw = legendObj.borderwidth;\n var bw2 = 2 * bw;\n var itemGap = constants.itemGap;\n var textGap = legendObj.indentation + legendObj.itemwidth + itemGap * 2;\n var endPad = 2 * (bw + itemGap);\n\n var yanchor = getYanchor(legendObj);\n var isBelowPlotArea = legendObj.y < 0 || (legendObj.y === 0 && yanchor === 'top');\n var isAbovePlotArea = legendObj.y > 1 || (legendObj.y === 1 && yanchor === 'bottom');\n\n var traceGroupGap = legendObj.tracegroupgap;\n var legendGroupWidths = {};\n\n // - if below/above plot area, give it the maximum potential margin-push value\n // - otherwise, extend the height of the plot area\n legendObj._maxHeight = Math.max(\n (isBelowPlotArea || isAbovePlotArea) ? fullLayout.height / 2 : gs.h,\n 30\n );\n\n var toggleRectWidth = 0;\n legendObj._width = 0;\n legendObj._height = 0;\n var titleSize = getTitleSize(legendObj);\n\n if(isVertical) {\n traces.each(function(d) {\n var h = d[0].height;\n Drawing.setTranslate(this,\n bw + titleSize[0],\n bw + titleSize[1] + legendObj._height + h / 2 + itemGap\n );\n legendObj._height += h;\n legendObj._width = Math.max(legendObj._width, d[0].width);\n });\n\n toggleRectWidth = textGap + legendObj._width;\n legendObj._width += itemGap + textGap + bw2;\n legendObj._height += endPad;\n\n if(isGrouped) {\n groups.each(function(d, i) {\n Drawing.setTranslate(this, 0, i * legendObj.tracegroupgap);\n });\n legendObj._height += (legendObj._lgroupsLength - 1) * legendObj.tracegroupgap;\n }\n } else {\n var xanchor = getXanchor(legendObj);\n var isLeftOfPlotArea = legendObj.x < 0 || (legendObj.x === 0 && xanchor === 'right');\n var isRightOfPlotArea = legendObj.x > 1 || (legendObj.x === 1 && xanchor === 'left');\n var isBeyondPlotAreaY = isAbovePlotArea || isBelowPlotArea;\n var hw = fullLayout.width / 2;\n\n // - if placed within x-margins, extend the width of the plot area\n // - else if below/above plot area and anchored in the margin, extend to opposite margin,\n // - otherwise give it the maximum potential margin-push value\n legendObj._maxWidth = Math.max(\n isLeftOfPlotArea ? ((isBeyondPlotAreaY && xanchor === 'left') ? gs.l + gs.w : hw) :\n isRightOfPlotArea ? ((isBeyondPlotAreaY && xanchor === 'right') ? gs.r + gs.w : hw) :\n gs.w,\n 2 * textGap);\n var maxItemWidth = 0;\n var combinedItemWidth = 0;\n traces.each(function(d) {\n var w = getTraceWidth(d, legendObj, textGap);\n maxItemWidth = Math.max(maxItemWidth, w);\n combinedItemWidth += w;\n });\n\n toggleRectWidth = null;\n var maxRowWidth = 0;\n\n if(isGrouped) {\n var maxGroupHeightInRow = 0;\n var groupOffsetX = 0;\n var groupOffsetY = 0;\n groups.each(function() {\n var maxWidthInGroup = 0;\n var offsetY = 0;\n d3.select(this).selectAll('g.traces').each(function(d) {\n var w = getTraceWidth(d, legendObj, textGap);\n var h = d[0].height;\n\n Drawing.setTranslate(this,\n titleSize[0],\n titleSize[1] + bw + itemGap + h / 2 + offsetY\n );\n offsetY += h;\n maxWidthInGroup = Math.max(maxWidthInGroup, w);\n legendGroupWidths[d[0].trace.legendgroup] = maxWidthInGroup;\n });\n\n var next = maxWidthInGroup + itemGap;\n\n // horizontal_wrapping\n if(\n // not on the first column already\n groupOffsetX > 0 &&\n\n // goes beyound limit\n next + bw + groupOffsetX > legendObj._maxWidth\n ) {\n maxRowWidth = Math.max(maxRowWidth, groupOffsetX);\n groupOffsetX = 0;\n groupOffsetY += maxGroupHeightInRow + traceGroupGap;\n maxGroupHeightInRow = offsetY;\n } else {\n maxGroupHeightInRow = Math.max(maxGroupHeightInRow, offsetY);\n }\n\n Drawing.setTranslate(this, groupOffsetX, groupOffsetY);\n\n groupOffsetX += next;\n });\n\n legendObj._width = Math.max(maxRowWidth, groupOffsetX) + bw;\n legendObj._height = groupOffsetY + maxGroupHeightInRow + endPad;\n } else {\n var nTraces = traces.size();\n var oneRowLegend = (combinedItemWidth + bw2 + (nTraces - 1) * itemGap) < legendObj._maxWidth;\n\n var maxItemHeightInRow = 0;\n var offsetX = 0;\n var offsetY = 0;\n var rowWidth = 0;\n traces.each(function(d) {\n var h = d[0].height;\n var w = getTraceWidth(d, legendObj, textGap, isGrouped);\n var next = (oneRowLegend ? w : maxItemWidth);\n\n if(!isFraction) {\n next += itemGap;\n }\n\n if((next + bw + offsetX - itemGap) >= legendObj._maxWidth) {\n maxRowWidth = Math.max(maxRowWidth, rowWidth);\n offsetX = 0;\n offsetY += maxItemHeightInRow;\n legendObj._height += maxItemHeightInRow;\n maxItemHeightInRow = 0;\n }\n\n Drawing.setTranslate(this,\n titleSize[0] + bw + offsetX,\n titleSize[1] + bw + offsetY + h / 2 + itemGap\n );\n\n rowWidth = offsetX + w + itemGap;\n offsetX += next;\n maxItemHeightInRow = Math.max(maxItemHeightInRow, h);\n });\n\n if(oneRowLegend) {\n legendObj._width = offsetX + bw2;\n legendObj._height = maxItemHeightInRow + endPad;\n } else {\n legendObj._width = Math.max(maxRowWidth, rowWidth) + bw2;\n legendObj._height += maxItemHeightInRow + endPad;\n }\n }\n }\n\n legendObj._width = Math.ceil(\n Math.max(\n legendObj._width + titleSize[0],\n legendObj._titleWidth + 2 * (bw + constants.titlePad)\n )\n );\n\n legendObj._height = Math.ceil(\n Math.max(\n legendObj._height + titleSize[1],\n legendObj._titleHeight + 2 * (bw + constants.itemGap)\n )\n );\n\n legendObj._effHeight = Math.min(legendObj._height, legendObj._maxHeight);\n\n var edits = gd._context.edits;\n var isEditable = edits.legendText || edits.legendPosition;\n traces.each(function(d) {\n var traceToggle = d3.select(this).select('.' + legendId + 'toggle');\n var h = d[0].height;\n var legendgroup = d[0].trace.legendgroup;\n var traceWidth = getTraceWidth(d, legendObj, textGap);\n if(isGrouped && legendgroup !== '') {\n traceWidth = legendGroupWidths[legendgroup];\n }\n var w = isEditable ? textGap : (toggleRectWidth || traceWidth);\n if(!isVertical && !isFraction) {\n w += itemGap / 2;\n }\n Drawing.setRect(traceToggle, 0, -h / 2, w, h);\n });\n}\n\nfunction expandMargin(gd, legendId, lx, ly) {\n var fullLayout = gd._fullLayout;\n var legendObj = fullLayout[legendId];\n var xanchor = getXanchor(legendObj);\n var yanchor = getYanchor(legendObj);\n\n var isPaperX = legendObj.xref === 'paper';\n var isPaperY = legendObj.yref === 'paper';\n\n gd._fullLayout._reservedMargin[legendId] = {};\n var sideY = legendObj.y < 0.5 ? 'b' : 't';\n var sideX = legendObj.x < 0.5 ? 'l' : 'r';\n var possibleReservedMargins = {\n r: (fullLayout.width - lx),\n l: lx + legendObj._width,\n b: (fullLayout.height - ly),\n t: ly + legendObj._effHeight\n };\n\n if(isPaperX && isPaperY) {\n return Plots.autoMargin(gd, legendId, {\n x: legendObj.x,\n y: legendObj.y,\n l: legendObj._width * (FROM_TL[xanchor]),\n r: legendObj._width * (FROM_BR[xanchor]),\n b: legendObj._effHeight * (FROM_BR[yanchor]),\n t: legendObj._effHeight * (FROM_TL[yanchor])\n });\n } else if(isPaperX) {\n gd._fullLayout._reservedMargin[legendId][sideY] = possibleReservedMargins[sideY];\n } else if(isPaperY) {\n gd._fullLayout._reservedMargin[legendId][sideX] = possibleReservedMargins[sideX];\n } else {\n if(legendObj.orientation === 'v') {\n gd._fullLayout._reservedMargin[legendId][sideX] = possibleReservedMargins[sideX];\n } else {\n gd._fullLayout._reservedMargin[legendId][sideY] = possibleReservedMargins[sideY];\n }\n }\n}\n\nfunction getXanchor(legendObj) {\n return Lib.isRightAnchor(legendObj) ? 'right' :\n Lib.isCenterAnchor(legendObj) ? 'center' :\n 'left';\n}\n\nfunction getYanchor(legendObj) {\n return Lib.isBottomAnchor(legendObj) ? 'bottom' :\n Lib.isMiddleAnchor(legendObj) ? 'middle' :\n 'top';\n}\n\nfunction getId(legendObj) {\n return legendObj._id || 'legend';\n}\n","'use strict';\n\nvar Registry = require('../../registry');\nvar helpers = require('./helpers');\n\nmodule.exports = function getLegendData(calcdata, opts, hasMultipleLegends) {\n var inHover = opts._inHover;\n var grouped = helpers.isGrouped(opts);\n var reversed = helpers.isReversed(opts);\n\n var lgroupToTraces = {};\n var lgroups = [];\n var hasOneNonBlankGroup = false;\n var slicesShown = {};\n var lgroupi = 0;\n var maxNameLength = 0;\n var i, j;\n\n function addOneItem(legendId, legendGroup, legendItem) {\n if(opts.visible === false) return;\n if(hasMultipleLegends && legendId !== opts._id) return;\n\n // each '' legend group is treated as a separate group\n if(legendGroup === '' || !helpers.isGrouped(opts)) {\n // TODO: check this against fullData legendgroups?\n var uniqueGroup = '~~i' + lgroupi;\n lgroups.push(uniqueGroup);\n lgroupToTraces[uniqueGroup] = [legendItem];\n lgroupi++;\n } else if(lgroups.indexOf(legendGroup) === -1) {\n lgroups.push(legendGroup);\n hasOneNonBlankGroup = true;\n lgroupToTraces[legendGroup] = [legendItem];\n } else {\n lgroupToTraces[legendGroup].push(legendItem);\n }\n }\n\n // build an { legendgroup: [cd0, cd0], ... } object\n for(i = 0; i < calcdata.length; i++) {\n var cd = calcdata[i];\n var cd0 = cd[0];\n var trace = cd0.trace;\n var lid = trace.legend;\n var lgroup = trace.legendgroup;\n\n if(!inHover && (!trace.visible || !trace.showlegend)) continue;\n\n if(Registry.traceIs(trace, 'pie-like')) {\n if(!slicesShown[lgroup]) slicesShown[lgroup] = {};\n\n for(j = 0; j < cd.length; j++) {\n var labelj = cd[j].label;\n\n if(!slicesShown[lgroup][labelj]) {\n addOneItem(lid, lgroup, {\n label: labelj,\n color: cd[j].color,\n i: cd[j].i,\n trace: trace,\n pts: cd[j].pts\n });\n\n slicesShown[lgroup][labelj] = true;\n maxNameLength = Math.max(maxNameLength, (labelj || '').length);\n }\n }\n } else {\n addOneItem(lid, lgroup, cd0);\n maxNameLength = Math.max(maxNameLength, (trace.name || '').length);\n }\n }\n\n // won't draw a legend in this case\n if(!lgroups.length) return [];\n\n // collapse all groups into one if all groups are blank\n var shouldCollapse = !hasOneNonBlankGroup || !grouped;\n\n var legendData = [];\n for(i = 0; i < lgroups.length; i++) {\n var t = lgroupToTraces[lgroups[i]];\n if(shouldCollapse) {\n legendData.push(t[0]);\n } else {\n legendData.push(t);\n }\n }\n if(shouldCollapse) legendData = [legendData];\n\n for(i = 0; i < legendData.length; i++) {\n // find minimum rank within group\n var groupMinRank = Infinity;\n for(j = 0; j < legendData[i].length; j++) {\n var rank = legendData[i][j].trace.legendrank;\n if(groupMinRank > rank) groupMinRank = rank;\n }\n\n // record on first group element\n legendData[i][0]._groupMinRank = groupMinRank;\n legendData[i][0]._preGroupSort = i;\n }\n\n var orderFn1 = function(a, b) {\n return (\n (a[0]._groupMinRank - b[0]._groupMinRank) ||\n (a[0]._preGroupSort - b[0]._preGroupSort) // fallback for old Chrome < 70 https://bugs.chromium.org/p/v8/issues/detail?id=90\n );\n };\n\n var orderFn2 = function(a, b) {\n return (\n (a.trace.legendrank - b.trace.legendrank) ||\n (a._preSort - b._preSort) // fallback for old Chrome < 70 https://bugs.chromium.org/p/v8/issues/detail?id=90\n );\n };\n\n // sort considering minimum group legendrank\n legendData.forEach(function(a, k) { a[0]._preGroupSort = k; });\n legendData.sort(orderFn1);\n for(i = 0; i < legendData.length; i++) {\n // sort considering trace.legendrank and legend.traceorder\n legendData[i].forEach(function(a, k) { a._preSort = k; });\n legendData[i].sort(orderFn2);\n\n var firstItemTrace = legendData[i][0].trace;\n\n var groupTitle = null;\n // get group title text\n for(j = 0; j < legendData[i].length; j++) {\n var gt = legendData[i][j].trace.legendgrouptitle;\n if(gt && gt.text) {\n groupTitle = gt;\n if(inHover) gt.font = opts._groupTitleFont;\n break;\n }\n }\n\n // reverse order\n if(reversed) legendData[i].reverse();\n\n if(groupTitle) {\n var hasPieLike = false;\n for(j = 0; j < legendData[i].length; j++) {\n if(Registry.traceIs(legendData[i][j].trace, 'pie-like')) {\n hasPieLike = true;\n break;\n }\n }\n\n // set group title text\n legendData[i].unshift({\n i: -1,\n groupTitle: groupTitle,\n noClick: hasPieLike,\n trace: {\n showlegend: firstItemTrace.showlegend,\n legendgroup: firstItemTrace.legendgroup,\n visible: opts.groupclick === 'toggleitem' ? true : firstItemTrace.visible\n }\n });\n }\n\n // rearrange lgroupToTraces into a d3-friendly array of arrays\n for(j = 0; j < legendData[i].length; j++) {\n legendData[i][j] = [\n legendData[i][j]\n ];\n }\n }\n\n // number of legend groups - needed in legend/draw.js\n opts._lgroupsLength = legendData.length;\n // maximum name/label length - needed in legend/draw.js\n opts._maxNameLength = maxNameLength;\n\n return legendData;\n};\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar pushUnique = Lib.pushUnique;\n\nvar SHOWISOLATETIP = true;\n\nmodule.exports = function handleClick(g, gd, numClicks) {\n var fullLayout = gd._fullLayout;\n\n if(gd._dragged || gd._editing) return;\n\n var itemClick = fullLayout.legend.itemclick;\n var itemDoubleClick = fullLayout.legend.itemdoubleclick;\n var groupClick = fullLayout.legend.groupclick;\n\n if(numClicks === 1 && itemClick === 'toggle' && itemDoubleClick === 'toggleothers' &&\n SHOWISOLATETIP && gd.data && gd._context.showTips\n ) {\n Lib.notifier(Lib._(gd, 'Double-click on legend to isolate one trace'), 'long');\n SHOWISOLATETIP = false;\n } else {\n SHOWISOLATETIP = false;\n }\n\n var mode;\n if(numClicks === 1) mode = itemClick;\n else if(numClicks === 2) mode = itemDoubleClick;\n if(!mode) return;\n\n var toggleGroup = groupClick === 'togglegroup';\n\n var hiddenSlices = fullLayout.hiddenlabels ?\n fullLayout.hiddenlabels.slice() :\n [];\n\n var legendItem = g.data()[0][0];\n if(legendItem.groupTitle && legendItem.noClick) return;\n\n var fullData = gd._fullData;\n var shapesWithLegend = (fullLayout.shapes || []).filter(function(d) { return d.showlegend; });\n var allLegendItems = fullData.concat(shapesWithLegend);\n\n var fullTrace = legendItem.trace;\n if(fullTrace._isShape) {\n fullTrace = fullTrace._fullInput;\n }\n\n var legendgroup = fullTrace.legendgroup;\n\n var i, j, kcont, key, keys, val;\n var dataUpdate = {};\n var dataIndices = [];\n var carrs = [];\n var carrIdx = [];\n\n function insertDataUpdate(traceIndex, value) {\n var attrIndex = dataIndices.indexOf(traceIndex);\n var valueArray = dataUpdate.visible;\n if(!valueArray) {\n valueArray = dataUpdate.visible = [];\n }\n\n if(dataIndices.indexOf(traceIndex) === -1) {\n dataIndices.push(traceIndex);\n attrIndex = dataIndices.length - 1;\n }\n\n valueArray[attrIndex] = value;\n\n return attrIndex;\n }\n\n var updatedShapes = (fullLayout.shapes || []).map(function(d) {\n return d._input;\n });\n\n var shapesUpdated = false;\n\n function insertShapesUpdate(shapeIndex, value) {\n updatedShapes[shapeIndex].visible = value;\n shapesUpdated = true;\n }\n\n function setVisibility(fullTrace, visibility) {\n if(legendItem.groupTitle && !toggleGroup) return;\n\n var fullInput = fullTrace._fullInput || fullTrace;\n var isShape = fullInput._isShape;\n var index = fullInput.index;\n if(index === undefined) index = fullInput._index;\n\n if(Registry.hasTransform(fullInput, 'groupby')) {\n var kcont = carrs[index];\n if(!kcont) {\n var groupbyIndices = Registry.getTransformIndices(fullInput, 'groupby');\n var lastGroupbyIndex = groupbyIndices[groupbyIndices.length - 1];\n kcont = Lib.keyedContainer(fullInput, 'transforms[' + lastGroupbyIndex + '].styles', 'target', 'value.visible');\n carrs[index] = kcont;\n }\n\n var curState = kcont.get(fullTrace._group);\n\n // If not specified, assume visible. This happens if there are other style\n // properties set for a group but not the visibility. There are many similar\n // ways to do this (e.g. why not just `curState = fullTrace.visible`??? The\n // answer is: because it breaks other things like groupby trace names in\n // subtle ways.)\n if(curState === undefined) {\n curState = true;\n }\n\n if(curState !== false) {\n // true -> legendonly. All others toggle to true:\n kcont.set(fullTrace._group, visibility);\n }\n carrIdx[index] = insertDataUpdate(index, fullInput.visible === false ? false : true);\n } else {\n // false -> false (not possible since will not be visible in legend)\n // true -> legendonly\n // legendonly -> true\n var nextVisibility = fullInput.visible === false ? false : visibility;\n\n if(isShape) {\n insertShapesUpdate(index, nextVisibility);\n } else {\n insertDataUpdate(index, nextVisibility);\n }\n }\n }\n\n var thisLegend = fullTrace.legend;\n\n var fullInput = fullTrace._fullInput;\n var isShape = fullInput && fullInput._isShape;\n\n if(!isShape && Registry.traceIs(fullTrace, 'pie-like')) {\n var thisLabel = legendItem.label;\n var thisLabelIndex = hiddenSlices.indexOf(thisLabel);\n\n if(mode === 'toggle') {\n if(thisLabelIndex === -1) hiddenSlices.push(thisLabel);\n else hiddenSlices.splice(thisLabelIndex, 1);\n } else if(mode === 'toggleothers') {\n var changed = thisLabelIndex !== -1;\n var unhideList = [];\n for(i = 0; i < gd.calcdata.length; i++) {\n var cdi = gd.calcdata[i];\n for(j = 0; j < cdi.length; j++) {\n var d = cdi[j];\n var dLabel = d.label;\n\n // ensure we toggle slices that are in this legend)\n if(thisLegend === cdi[0].trace.legend) {\n if(thisLabel !== dLabel) {\n if(hiddenSlices.indexOf(dLabel) === -1) changed = true;\n pushUnique(hiddenSlices, dLabel);\n unhideList.push(dLabel);\n }\n }\n }\n }\n\n if(!changed) {\n for(var q = 0; q < unhideList.length; q++) {\n var pos = hiddenSlices.indexOf(unhideList[q]);\n if(pos !== -1) {\n hiddenSlices.splice(pos, 1);\n }\n }\n }\n }\n\n Registry.call('_guiRelayout', gd, 'hiddenlabels', hiddenSlices);\n } else {\n var hasLegendgroup = legendgroup && legendgroup.length;\n var traceIndicesInGroup = [];\n var tracei;\n if(hasLegendgroup) {\n for(i = 0; i < allLegendItems.length; i++) {\n tracei = allLegendItems[i];\n if(!tracei.visible) continue;\n if(tracei.legendgroup === legendgroup) {\n traceIndicesInGroup.push(i);\n }\n }\n }\n\n if(mode === 'toggle') {\n var nextVisibility;\n\n switch(fullTrace.visible) {\n case true:\n nextVisibility = 'legendonly';\n break;\n case false:\n nextVisibility = false;\n break;\n case 'legendonly':\n nextVisibility = true;\n break;\n }\n\n if(hasLegendgroup) {\n if(toggleGroup) {\n for(i = 0; i < allLegendItems.length; i++) {\n var item = allLegendItems[i];\n if(item.visible !== false && item.legendgroup === legendgroup) {\n setVisibility(item, nextVisibility);\n }\n }\n } else {\n setVisibility(fullTrace, nextVisibility);\n }\n } else {\n setVisibility(fullTrace, nextVisibility);\n }\n } else if(mode === 'toggleothers') {\n // Compute the clicked index. expandedIndex does what we want for expanded traces\n // but also culls hidden traces. That means we have some work to do.\n var isClicked, isInGroup, notInLegend, otherState, _item;\n var isIsolated = true;\n for(i = 0; i < allLegendItems.length; i++) {\n _item = allLegendItems[i];\n isClicked = _item === fullTrace;\n notInLegend = _item.showlegend !== true;\n if(isClicked || notInLegend) continue;\n\n isInGroup = (hasLegendgroup && _item.legendgroup === legendgroup);\n\n if(!isInGroup && _item.legend === thisLegend && _item.visible === true && !Registry.traceIs(_item, 'notLegendIsolatable')) {\n isIsolated = false;\n break;\n }\n }\n\n for(i = 0; i < allLegendItems.length; i++) {\n _item = allLegendItems[i];\n\n // False is sticky; we don't change it. Also ensure we don't change states of itmes in other legend\n if(_item.visible === false || _item.legend !== thisLegend) continue;\n\n if(Registry.traceIs(_item, 'notLegendIsolatable')) {\n continue;\n }\n\n switch(fullTrace.visible) {\n case 'legendonly':\n setVisibility(_item, true);\n break;\n case true:\n otherState = isIsolated ? true : 'legendonly';\n isClicked = _item === fullTrace;\n // N.B. consider traces that have a set legendgroup as toggleable\n notInLegend = (_item.showlegend !== true && !_item.legendgroup);\n isInGroup = isClicked || (hasLegendgroup && _item.legendgroup === legendgroup);\n setVisibility(_item, (isInGroup || notInLegend) ? true : otherState);\n break;\n }\n }\n }\n\n for(i = 0; i < carrs.length; i++) {\n kcont = carrs[i];\n if(!kcont) continue;\n var update = kcont.constructUpdate();\n\n var updateKeys = Object.keys(update);\n for(j = 0; j < updateKeys.length; j++) {\n key = updateKeys[j];\n val = dataUpdate[key] = dataUpdate[key] || [];\n val[carrIdx[i]] = update[key];\n }\n }\n\n // The length of the value arrays should be equal and any unspecified\n // values should be explicitly undefined for them to get properly culled\n // as updates and not accidentally reset to the default value. This fills\n // out sparse arrays with the required number of undefined values:\n keys = Object.keys(dataUpdate);\n for(i = 0; i < keys.length; i++) {\n key = keys[i];\n for(j = 0; j < dataIndices.length; j++) {\n // Use hasOwnProperty to protect against falsy values:\n if(!dataUpdate[key].hasOwnProperty(j)) {\n dataUpdate[key][j] = undefined;\n }\n }\n }\n\n if(shapesUpdated) {\n Registry.call('_guiUpdate', gd, dataUpdate, {shapes: updatedShapes}, dataIndices);\n } else {\n Registry.call('_guiRestyle', gd, dataUpdate, dataIndices);\n }\n }\n};\n","'use strict';\n\nexports.isGrouped = function isGrouped(legendLayout) {\n return (legendLayout.traceorder || '').indexOf('grouped') !== -1;\n};\n\nexports.isVertical = function isVertical(legendLayout) {\n return legendLayout.orientation !== 'h';\n};\n\nexports.isReversed = function isReversed(legendLayout) {\n return (legendLayout.traceorder || '').indexOf('reversed') !== -1;\n};\n","'use strict';\n\n\nmodule.exports = {\n moduleType: 'component',\n name: 'legend',\n\n layoutAttributes: require('./attributes'),\n supplyLayoutDefaults: require('./defaults'),\n\n draw: require('./draw'),\n style: require('./style')\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar Drawing = require('../drawing');\nvar Color = require('../color');\nvar extractOpts = require('../colorscale/helpers').extractOpts;\n\nvar subTypes = require('../../traces/scatter/subtypes');\nvar stylePie = require('../../traces/pie/style_one');\nvar pieCastOption = require('../../traces/pie/helpers').castOption;\n\nvar constants = require('./constants');\n\nvar CST_MARKER_SIZE = 12;\nvar CST_LINE_WIDTH = 5;\nvar CST_MARKER_LINE_WIDTH = 2;\nvar MAX_LINE_WIDTH = 10;\nvar MAX_MARKER_LINE_WIDTH = 5;\n\nmodule.exports = function style(s, gd, legend) {\n var fullLayout = gd._fullLayout;\n if(!legend) legend = fullLayout.legend;\n var constantItemSizing = legend.itemsizing === 'constant';\n var itemWidth = legend.itemwidth;\n var centerPos = (itemWidth + constants.itemGap * 2) / 2;\n var centerTransform = strTranslate(centerPos, 0);\n\n var boundLineWidth = function(mlw, cont, max, cst) {\n var v;\n if(mlw + 1) {\n v = mlw;\n } else if(cont && cont.width > 0) {\n v = cont.width;\n } else {\n return 0;\n }\n return constantItemSizing ? cst : Math.min(v, max);\n };\n\n s.each(function(d) {\n var traceGroup = d3.select(this);\n\n var layers = Lib.ensureSingle(traceGroup, 'g', 'layers');\n layers.style('opacity', d[0].trace.opacity);\n\n var indentation = legend.indentation;\n var valign = legend.valign;\n var lineHeight = d[0].lineHeight;\n var height = d[0].height;\n if((valign === 'middle' && indentation === 0) || !lineHeight || !height) {\n layers.attr('transform', null);\n } else {\n var factor = {top: 1, bottom: -1}[valign];\n var markerOffsetY = (factor * (0.5 * (lineHeight - height + 3))) || 0;\n var markerOffsetX = legend.indentation;\n layers.attr('transform', strTranslate(markerOffsetX, markerOffsetY));\n }\n\n var fill = layers\n .selectAll('g.legendfill')\n .data([d]);\n fill.enter().append('g')\n .classed('legendfill', true);\n\n var line = layers\n .selectAll('g.legendlines')\n .data([d]);\n line.enter().append('g')\n .classed('legendlines', true);\n\n var symbol = layers\n .selectAll('g.legendsymbols')\n .data([d]);\n symbol.enter().append('g')\n .classed('legendsymbols', true);\n\n symbol.selectAll('g.legendpoints')\n .data([d])\n .enter().append('g')\n .classed('legendpoints', true);\n })\n .each(styleSpatial)\n .each(styleWaterfalls)\n .each(styleFunnels)\n .each(styleBars)\n .each(styleBoxes)\n .each(styleFunnelareas)\n .each(stylePies)\n .each(styleLines)\n .each(stylePoints)\n .each(styleCandles)\n .each(styleOHLC);\n\n function styleLines(d) {\n var styleGuide = getStyleGuide(d);\n var showFill = styleGuide.showFill;\n var showLine = styleGuide.showLine;\n var showGradientLine = styleGuide.showGradientLine;\n var showGradientFill = styleGuide.showGradientFill;\n var anyFill = styleGuide.anyFill;\n var anyLine = styleGuide.anyLine;\n\n var d0 = d[0];\n var trace = d0.trace;\n var dMod, tMod;\n\n var cOpts = extractOpts(trace);\n var colorscale = cOpts.colorscale;\n var reversescale = cOpts.reversescale;\n\n var fillStyle = function(s) {\n if(s.size()) {\n if(showFill) {\n Drawing.fillGroupStyle(s, gd, true);\n } else {\n var gradientID = 'legendfill-' + trace.uid;\n Drawing.gradient(s, gd, gradientID,\n getGradientDirection(reversescale),\n colorscale, 'fill');\n }\n }\n };\n\n var lineGradient = function(s) {\n if(s.size()) {\n var gradientID = 'legendline-' + trace.uid;\n Drawing.lineGroupStyle(s);\n Drawing.gradient(s, gd, gradientID,\n getGradientDirection(reversescale),\n colorscale, 'stroke');\n }\n };\n\n // with fill and no markers or text, move the line and fill up a bit\n // so it's more centered\n\n var pathStart = (subTypes.hasMarkers(trace) || !anyFill) ? 'M5,0' :\n // with a line leave it slightly below center, to leave room for the\n // line thickness and because the line is usually more prominent\n anyLine ? 'M5,-2' : 'M5,-3';\n\n var this3 = d3.select(this);\n\n var fill = this3.select('.legendfill').selectAll('path')\n .data(showFill || showGradientFill ? [d] : []);\n fill.enter().append('path').classed('js-fill', true);\n fill.exit().remove();\n fill.attr('d', pathStart + 'h' + itemWidth + 'v6h-' + itemWidth + 'z')\n .call(fillStyle);\n\n if(showLine || showGradientLine) {\n var lw = boundLineWidth(undefined, trace.line, MAX_LINE_WIDTH, CST_LINE_WIDTH);\n tMod = Lib.minExtend(trace, {line: {width: lw}});\n dMod = [Lib.minExtend(d0, {trace: tMod})];\n }\n\n var line = this3.select('.legendlines').selectAll('path')\n .data(showLine || showGradientLine ? [dMod] : []);\n line.enter().append('path').classed('js-line', true);\n line.exit().remove();\n\n // this is ugly... but you can't apply a gradient to a perfectly\n // horizontal or vertical line. Presumably because then\n // the system doesn't know how to scale vertical variation, even\n // though there *is* no vertical variation in this case.\n // so add an invisibly small angle to the line\n // This issue (and workaround) exist across (Mac) Chrome, FF, and Safari\n line.attr('d', pathStart + (showGradientLine ? 'l' + itemWidth + ',0.0001' : 'h' + itemWidth))\n .call(showLine ? Drawing.lineGroupStyle : lineGradient);\n }\n\n function stylePoints(d) {\n var styleGuide = getStyleGuide(d);\n var anyFill = styleGuide.anyFill;\n var anyLine = styleGuide.anyLine;\n var showLine = styleGuide.showLine;\n var showMarker = styleGuide.showMarker;\n\n var d0 = d[0];\n var trace = d0.trace;\n var showText = !showMarker && !anyLine && !anyFill && subTypes.hasText(trace);\n var dMod, tMod;\n\n // 'scatter3d' don't use gd.calcdata,\n // use d0.trace to infer arrayOk attributes\n\n function boundVal(attrIn, arrayToValFn, bounds, cst) {\n var valIn = Lib.nestedProperty(trace, attrIn).get();\n var valToBound = (Lib.isArrayOrTypedArray(valIn) && arrayToValFn) ?\n arrayToValFn(valIn) :\n valIn;\n\n if(constantItemSizing && valToBound && cst !== undefined) {\n valToBound = cst;\n }\n\n if(bounds) {\n if(valToBound < bounds[0]) return bounds[0];\n else if(valToBound > bounds[1]) return bounds[1];\n }\n return valToBound;\n }\n\n function pickFirst(array) {\n if(d0._distinct && d0.index && array[d0.index]) return array[d0.index];\n return array[0];\n }\n\n // constrain text, markers, etc so they'll fit on the legend\n if(showMarker || showText || showLine) {\n var dEdit = {};\n var tEdit = {};\n\n if(showMarker) {\n dEdit.mc = boundVal('marker.color', pickFirst);\n dEdit.mx = boundVal('marker.symbol', pickFirst);\n dEdit.mo = boundVal('marker.opacity', Lib.mean, [0.2, 1]);\n dEdit.mlc = boundVal('marker.line.color', pickFirst);\n dEdit.mlw = boundVal('marker.line.width', Lib.mean, [0, 5], CST_MARKER_LINE_WIDTH);\n tEdit.marker = {\n sizeref: 1,\n sizemin: 1,\n sizemode: 'diameter'\n };\n\n var ms = boundVal('marker.size', Lib.mean, [2, 16], CST_MARKER_SIZE);\n dEdit.ms = ms;\n tEdit.marker.size = ms;\n }\n\n if(showLine) {\n tEdit.line = {\n width: boundVal('line.width', pickFirst, [0, 10], CST_LINE_WIDTH)\n };\n }\n\n if(showText) {\n dEdit.tx = 'Aa';\n dEdit.tp = boundVal('textposition', pickFirst);\n dEdit.ts = 10;\n dEdit.tc = boundVal('textfont.color', pickFirst);\n dEdit.tf = boundVal('textfont.family', pickFirst);\n dEdit.tw = boundVal('textfont.weight', pickFirst);\n dEdit.ty = boundVal('textfont.style', pickFirst);\n dEdit.tv = boundVal('textfont.variant', pickFirst);\n dEdit.tC = boundVal('textfont.textcase', pickFirst);\n dEdit.tE = boundVal('textfont.lineposition', pickFirst);\n dEdit.tS = boundVal('textfont.shadow', pickFirst);\n }\n\n dMod = [Lib.minExtend(d0, dEdit)];\n tMod = Lib.minExtend(trace, tEdit);\n\n // always show legend items in base state\n tMod.selectedpoints = null;\n\n // never show texttemplate\n tMod.texttemplate = null;\n }\n\n var ptgroup = d3.select(this).select('g.legendpoints');\n\n var pts = ptgroup.selectAll('path.scatterpts')\n .data(showMarker ? dMod : []);\n // make sure marker is on the bottom, in case it enters after text\n pts.enter().insert('path', ':first-child')\n .classed('scatterpts', true)\n .attr('transform', centerTransform);\n pts.exit().remove();\n pts.call(Drawing.pointStyle, tMod, gd);\n\n // 'mrc' is set in pointStyle and used in textPointStyle:\n // constrain it here\n if(showMarker) dMod[0].mrc = 3;\n\n var txt = ptgroup.selectAll('g.pointtext')\n .data(showText ? dMod : []);\n txt.enter()\n .append('g').classed('pointtext', true)\n .append('text').attr('transform', centerTransform);\n txt.exit().remove();\n txt.selectAll('text').call(Drawing.textPointStyle, tMod, gd);\n }\n\n function styleWaterfalls(d) {\n var trace = d[0].trace;\n var isWaterfall = trace.type === 'waterfall';\n\n if(d[0]._distinct && isWaterfall) {\n var cont = d[0].trace[d[0].dir].marker;\n d[0].mc = cont.color;\n d[0].mlw = cont.line.width;\n d[0].mlc = cont.line.color;\n return styleBarLike(d, this, 'waterfall');\n }\n\n var ptsData = [];\n if(trace.visible && isWaterfall) {\n ptsData = d[0].hasTotals ?\n [['increasing', 'M-6,-6V6H0Z'], ['totals', 'M6,6H0L-6,-6H-0Z'], ['decreasing', 'M6,6V-6H0Z']] :\n [['increasing', 'M-6,-6V6H6Z'], ['decreasing', 'M6,6V-6H-6Z']];\n }\n\n var pts = d3.select(this).select('g.legendpoints')\n .selectAll('path.legendwaterfall')\n .data(ptsData);\n pts.enter().append('path').classed('legendwaterfall', true)\n .attr('transform', centerTransform)\n .style('stroke-miterlimit', 1);\n pts.exit().remove();\n\n pts.each(function(dd) {\n var pt = d3.select(this);\n var cont = trace[dd[0]].marker;\n var lw = boundLineWidth(undefined, cont.line, MAX_MARKER_LINE_WIDTH, CST_MARKER_LINE_WIDTH);\n\n pt.attr('d', dd[1])\n .style('stroke-width', lw + 'px')\n .call(Color.fill, cont.color);\n\n if(lw) {\n pt.call(Color.stroke, cont.line.color);\n }\n });\n }\n\n function styleBars(d) {\n styleBarLike(d, this);\n }\n\n function styleFunnels(d) {\n styleBarLike(d, this, 'funnel');\n }\n\n function styleBarLike(d, lThis, desiredType) {\n var trace = d[0].trace;\n var marker = trace.marker || {};\n var markerLine = marker.line || {};\n\n // If bar has rounded corners, round corners of legend icon\n var pathStr = marker.cornerradius ?\n 'M6,3a3,3,0,0,1-3,3H-3a3,3,0,0,1-3-3V-3a3,3,0,0,1,3-3H3a3,3,0,0,1,3,3Z' : // Square with rounded corners\n 'M6,6H-6V-6H6Z'; // Normal square\n\n var isVisible = (!desiredType) ? Registry.traceIs(trace, 'bar') :\n (trace.visible && trace.type === desiredType);\n\n var barpath = d3.select(lThis).select('g.legendpoints')\n .selectAll('path.legend' + desiredType)\n .data(isVisible ? [d] : []);\n barpath.enter().append('path').classed('legend' + desiredType, true)\n .attr('d', pathStr)\n .attr('transform', centerTransform);\n barpath.exit().remove();\n\n barpath.each(function(d) {\n var p = d3.select(this);\n var d0 = d[0];\n var w = boundLineWidth(d0.mlw, marker.line, MAX_MARKER_LINE_WIDTH, CST_MARKER_LINE_WIDTH);\n\n p.style('stroke-width', w + 'px');\n\n var mcc = d0.mcc;\n if(!legend._inHover && 'mc' in d0) {\n // not in unified hover but\n // for legend use the color in the middle of scale\n var cOpts = extractOpts(marker);\n var mid = cOpts.mid;\n if(mid === undefined) mid = (cOpts.max + cOpts.min) / 2;\n mcc = Drawing.tryColorscale(marker, '')(mid);\n }\n var fillColor = mcc || d0.mc || marker.color;\n\n var markerPattern = marker.pattern;\n var patternShape = markerPattern && Drawing.getPatternAttr(markerPattern.shape, 0, '');\n\n if(patternShape) {\n var patternBGColor = Drawing.getPatternAttr(markerPattern.bgcolor, 0, null);\n var patternFGColor = Drawing.getPatternAttr(markerPattern.fgcolor, 0, null);\n var patternFGOpacity = markerPattern.fgopacity;\n var patternSize = dimAttr(markerPattern.size, 8, 10);\n var patternSolidity = dimAttr(markerPattern.solidity, 0.5, 1);\n var patternID = 'legend-' + trace.uid;\n p.call(\n Drawing.pattern, 'legend', gd, patternID,\n patternShape, patternSize, patternSolidity,\n mcc, markerPattern.fillmode,\n patternBGColor, patternFGColor, patternFGOpacity\n );\n } else {\n p.call(Color.fill, fillColor);\n }\n\n if(w) Color.stroke(p, d0.mlc || markerLine.color);\n });\n }\n\n function styleBoxes(d) {\n var trace = d[0].trace;\n\n var pts = d3.select(this).select('g.legendpoints')\n .selectAll('path.legendbox')\n .data(trace.visible && Registry.traceIs(trace, 'box-violin') ? [d] : []);\n pts.enter().append('path').classed('legendbox', true)\n // if we want the median bar, prepend M6,0H-6\n .attr('d', 'M6,6H-6V-6H6Z')\n .attr('transform', centerTransform);\n pts.exit().remove();\n\n pts.each(function() {\n var p = d3.select(this);\n\n if((trace.boxpoints === 'all' || trace.points === 'all') &&\n Color.opacity(trace.fillcolor) === 0 && Color.opacity((trace.line || {}).color) === 0\n ) {\n var tMod = Lib.minExtend(trace, {\n marker: {\n size: constantItemSizing ? CST_MARKER_SIZE : Lib.constrain(trace.marker.size, 2, 16),\n sizeref: 1,\n sizemin: 1,\n sizemode: 'diameter'\n }\n });\n pts.call(Drawing.pointStyle, tMod, gd);\n } else {\n var w = boundLineWidth(undefined, trace.line, MAX_MARKER_LINE_WIDTH, CST_MARKER_LINE_WIDTH);\n\n p.style('stroke-width', w + 'px')\n .call(Color.fill, trace.fillcolor);\n\n if(w) Color.stroke(p, trace.line.color);\n }\n });\n }\n\n function styleCandles(d) {\n var trace = d[0].trace;\n\n var pts = d3.select(this).select('g.legendpoints')\n .selectAll('path.legendcandle')\n .data(trace.visible && trace.type === 'candlestick' ? [d, d] : []);\n pts.enter().append('path').classed('legendcandle', true)\n .attr('d', function(_, i) {\n if(i) return 'M-15,0H-8M-8,6V-6H8Z'; // increasing\n return 'M15,0H8M8,-6V6H-8Z'; // decreasing\n })\n .attr('transform', centerTransform)\n .style('stroke-miterlimit', 1);\n pts.exit().remove();\n\n pts.each(function(_, i) {\n var p = d3.select(this);\n var cont = trace[i ? 'increasing' : 'decreasing'];\n var w = boundLineWidth(undefined, cont.line, MAX_MARKER_LINE_WIDTH, CST_MARKER_LINE_WIDTH);\n\n p.style('stroke-width', w + 'px')\n .call(Color.fill, cont.fillcolor);\n\n if(w) Color.stroke(p, cont.line.color);\n });\n }\n\n function styleOHLC(d) {\n var trace = d[0].trace;\n\n var pts = d3.select(this).select('g.legendpoints')\n .selectAll('path.legendohlc')\n .data(trace.visible && trace.type === 'ohlc' ? [d, d] : []);\n pts.enter().append('path').classed('legendohlc', true)\n .attr('d', function(_, i) {\n if(i) return 'M-15,0H0M-8,-6V0'; // increasing\n return 'M15,0H0M8,6V0'; // decreasing\n })\n .attr('transform', centerTransform)\n .style('stroke-miterlimit', 1);\n pts.exit().remove();\n\n pts.each(function(_, i) {\n var p = d3.select(this);\n var cont = trace[i ? 'increasing' : 'decreasing'];\n var w = boundLineWidth(undefined, cont.line, MAX_MARKER_LINE_WIDTH, CST_MARKER_LINE_WIDTH);\n\n p.style('fill', 'none')\n .call(Drawing.dashLine, cont.line.dash, w);\n\n if(w) Color.stroke(p, cont.line.color);\n });\n }\n\n function stylePies(d) {\n stylePieLike(d, this, 'pie');\n }\n\n function styleFunnelareas(d) {\n stylePieLike(d, this, 'funnelarea');\n }\n\n function stylePieLike(d, lThis, desiredType) {\n var d0 = d[0];\n var trace = d0.trace;\n\n var isVisible = (!desiredType) ? Registry.traceIs(trace, desiredType) :\n (trace.visible && trace.type === desiredType);\n\n var pts = d3.select(lThis).select('g.legendpoints')\n .selectAll('path.legend' + desiredType)\n .data(isVisible ? [d] : []);\n pts.enter().append('path').classed('legend' + desiredType, true)\n .attr('d', 'M6,6H-6V-6H6Z')\n .attr('transform', centerTransform);\n pts.exit().remove();\n\n if(pts.size()) {\n var cont = trace.marker || {};\n var lw = boundLineWidth(pieCastOption(cont.line.width, d0.pts), cont.line, MAX_MARKER_LINE_WIDTH, CST_MARKER_LINE_WIDTH);\n\n var opt = 'pieLike';\n var tMod = Lib.minExtend(trace, {marker: {line: {width: lw}}}, opt);\n var d0Mod = Lib.minExtend(d0, {trace: tMod}, opt);\n\n stylePie(pts, d0Mod, tMod, gd);\n }\n }\n\n function styleSpatial(d) { // i.e. maninly traces having z and colorscale\n var trace = d[0].trace;\n\n var useGradient;\n var ptsData = [];\n if(trace.visible) {\n switch(trace.type) {\n case 'histogram2d' :\n case 'heatmap' :\n ptsData = [\n ['M-15,-2V4H15V-2Z'] // similar to contour\n ];\n useGradient = true;\n break;\n case 'choropleth' :\n case 'choroplethmapbox' :\n case 'choroplethmap' :\n ptsData = [\n ['M-6,-6V6H6V-6Z']\n ];\n useGradient = true;\n break;\n case 'densitymapbox' :\n case 'densitymap' :\n ptsData = [\n ['M-6,0 a6,6 0 1,0 12,0 a 6,6 0 1,0 -12,0']\n ];\n useGradient = 'radial';\n break;\n case 'cone' :\n ptsData = [\n ['M-6,2 A2,2 0 0,0 -6,6 V6L6,4Z'],\n ['M-6,-6 A2,2 0 0,0 -6,-2 L6,-4Z'],\n ['M-6,-2 A2,2 0 0,0 -6,2 L6,0Z']\n ];\n useGradient = false;\n break;\n case 'streamtube' :\n ptsData = [\n ['M-6,2 A2,2 0 0,0 -6,6 H6 A2,2 0 0,1 6,2 Z'],\n ['M-6,-6 A2,2 0 0,0 -6,-2 H6 A2,2 0 0,1 6,-6 Z'],\n ['M-6,-2 A2,2 0 0,0 -6,2 H6 A2,2 0 0,1 6,-2 Z']\n ];\n useGradient = false;\n break;\n case 'surface' :\n ptsData = [\n ['M-6,-6 A2,3 0 0,0 -6,0 H6 A2,3 0 0,1 6,-6 Z'],\n ['M-6,1 A2,3 0 0,1 -6,6 H6 A2,3 0 0,0 6,0 Z']\n ];\n useGradient = true;\n break;\n case 'mesh3d' :\n ptsData = [\n ['M-6,6H0L-6,-6Z'],\n ['M6,6H0L6,-6Z'],\n ['M-6,-6H6L0,6Z']\n ];\n useGradient = false;\n break;\n case 'volume' :\n ptsData = [\n ['M-6,6H0L-6,-6Z'],\n ['M6,6H0L6,-6Z'],\n ['M-6,-6H6L0,6Z']\n ];\n useGradient = true;\n break;\n case 'isosurface':\n ptsData = [\n ['M-6,6H0L-6,-6Z'],\n ['M6,6H0L6,-6Z'],\n ['M-6,-6 A12,24 0 0,0 6,-6 L0,6Z']\n ];\n useGradient = false;\n break;\n }\n }\n\n var pts = d3.select(this).select('g.legendpoints')\n .selectAll('path.legend3dandfriends')\n .data(ptsData);\n pts.enter().append('path').classed('legend3dandfriends', true)\n .attr('transform', centerTransform)\n .style('stroke-miterlimit', 1);\n pts.exit().remove();\n\n pts.each(function(dd, i) {\n var pt = d3.select(this);\n\n var cOpts = extractOpts(trace);\n var colorscale = cOpts.colorscale;\n var reversescale = cOpts.reversescale;\n var fillGradient = function(s) {\n if(s.size()) {\n var gradientID = 'legendfill-' + trace.uid;\n Drawing.gradient(s, gd, gradientID,\n getGradientDirection(reversescale, useGradient === 'radial'),\n colorscale, 'fill');\n }\n };\n\n var fillColor;\n if(!colorscale) {\n var color = trace.vertexcolor || trace.facecolor || trace.color;\n fillColor = Lib.isArrayOrTypedArray(color) ? (color[i] || color[0]) : color;\n } else {\n if(!useGradient) {\n var len = colorscale.length;\n fillColor =\n i === 0 ? colorscale[reversescale ? len - 1 : 0][1] : // minimum\n i === 1 ? colorscale[reversescale ? 0 : len - 1][1] : // maximum\n colorscale[Math.floor((len - 1) / 2)][1]; // middle\n }\n }\n\n pt.attr('d', dd[0]);\n if(fillColor) {\n pt.call(Color.fill, fillColor);\n } else {\n pt.call(fillGradient);\n }\n });\n }\n};\n\nfunction getGradientDirection(reversescale, isRadial) {\n var str = isRadial ? 'radial' : 'horizontal';\n return str + (reversescale ? '' : 'reversed');\n}\n\nfunction getStyleGuide(d) {\n var trace = d[0].trace;\n var contours = trace.contours;\n var showLine = subTypes.hasLines(trace);\n var showMarker = subTypes.hasMarkers(trace);\n\n var showFill = trace.visible && trace.fill && trace.fill !== 'none';\n var showGradientLine = false;\n var showGradientFill = false;\n\n if(contours) {\n var coloring = contours.coloring;\n\n if(coloring === 'lines') {\n showGradientLine = true;\n } else {\n showLine = coloring === 'none' || coloring === 'heatmap' || contours.showlines;\n }\n\n if(contours.type === 'constraint') {\n showFill = contours._operation !== '=';\n } else if(coloring === 'fill' || coloring === 'heatmap') {\n showGradientFill = true;\n }\n }\n return {\n showMarker: showMarker,\n showLine: showLine,\n showFill: showFill,\n showGradientLine: showGradientLine,\n showGradientFill: showGradientFill,\n anyLine: showLine || showGradientLine,\n anyFill: showFill || showGradientFill,\n };\n}\n\nfunction dimAttr(v, dflt, max) {\n if(v && Lib.isArrayOrTypedArray(v)) return dflt;\n if(v > max) return max;\n return v;\n}\n","'use strict';\n\nvar constants = require('./constants');\n\nmodule.exports = {\n editType: 'modebar',\n\n orientation: {\n valType: 'enumerated',\n values: ['v', 'h'],\n dflt: 'h',\n editType: 'modebar',\n description: 'Sets the orientation of the modebar.'\n },\n bgcolor: {\n valType: 'color',\n editType: 'modebar',\n description: 'Sets the background color of the modebar.'\n },\n color: {\n valType: 'color',\n editType: 'modebar',\n description: 'Sets the color of the icons in the modebar.'\n },\n activecolor: {\n valType: 'color',\n editType: 'modebar',\n description: 'Sets the color of the active or hovered on icons in the modebar.'\n },\n uirevision: {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes related to the modebar,',\n 'including `hovermode`, `dragmode`, and `showspikes` at both the',\n 'root level and inside subplots. Defaults to `layout.uirevision`.'\n ].join(' ')\n },\n add: {\n valType: 'string',\n arrayOk: true,\n dflt: '',\n editType: 'modebar',\n description: [\n 'Determines which predefined modebar buttons to add.',\n 'Please note that these buttons will only be shown if they are',\n 'compatible with all trace types used in a graph.',\n 'Similar to `config.modeBarButtonsToAdd` option.',\n 'This may include *' + constants.backButtons.join('*, *') + '*.'\n ].join(' ')\n },\n remove: {\n valType: 'string',\n arrayOk: true,\n dflt: '',\n editType: 'modebar',\n description: [\n 'Determines which predefined modebar buttons to remove.',\n 'Similar to `config.modeBarButtonsToRemove` option.',\n 'This may include *' + constants.foreButtons.join('*, *') + '*.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Plots = require('../../plots/plots');\nvar axisIds = require('../../plots/cartesian/axis_ids');\nvar Icons = require('../../fonts/ploticon');\nvar eraseActiveShape = require('../shapes/draw').eraseActiveShape;\nvar Lib = require('../../lib');\nvar _ = Lib._;\n\nvar modeBarButtons = module.exports = {};\n\n/**\n * ModeBar buttons configuration\n *\n * @param {string} name\n * name / id of the buttons (for tracking)\n * @param {string} title\n * text that appears while hovering over the button,\n * enter null, false or '' for no hover text\n * @param {string} icon\n * svg icon object associated with the button\n * can be linked to Plotly.Icons to use the default plotly icons\n * @param {string} [gravity]\n * icon positioning\n * @param {function} click\n * click handler associated with the button, a function of\n * 'gd' (the main graph object) and\n * 'ev' (the event object)\n * @param {string} [attr]\n * attribute associated with button,\n * use this with 'val' to keep track of the state\n * @param {*} [val]\n * initial 'attr' value, can be a function of gd\n * @param {boolean} [toggle]\n * is the button a toggle button?\n */\nmodeBarButtons.toImage = {\n name: 'toImage',\n title: function(gd) {\n var opts = gd._context.toImageButtonOptions || {};\n var format = opts.format || 'png';\n return format === 'png' ?\n _(gd, 'Download plot as a png') : // legacy text\n _(gd, 'Download plot'); // generic non-PNG text\n },\n icon: Icons.camera,\n click: function(gd) {\n var toImageButtonOptions = gd._context.toImageButtonOptions;\n var opts = {format: toImageButtonOptions.format || 'png'};\n\n Lib.notifier(_(gd, 'Taking snapshot - this may take a few seconds'), 'long');\n\n if(opts.format !== 'svg' && Lib.isIE()) {\n Lib.notifier(_(gd, 'IE only supports svg. Changing format to svg.'), 'long');\n opts.format = 'svg';\n }\n\n ['filename', 'width', 'height', 'scale'].forEach(function(key) {\n if(key in toImageButtonOptions) {\n opts[key] = toImageButtonOptions[key];\n }\n });\n\n Registry.call('downloadImage', gd, opts)\n .then(function(filename) {\n Lib.notifier(_(gd, 'Snapshot succeeded') + ' - ' + filename, 'long');\n })\n .catch(function() {\n Lib.notifier(_(gd, 'Sorry, there was a problem downloading your snapshot!'), 'long');\n });\n }\n};\n\nmodeBarButtons.sendDataToCloud = {\n name: 'sendDataToCloud',\n title: function(gd) { return _(gd, 'Edit in Chart Studio'); },\n icon: Icons.disk,\n click: function(gd) {\n Plots.sendDataToCloud(gd);\n }\n};\n\nmodeBarButtons.editInChartStudio = {\n name: 'editInChartStudio',\n title: function(gd) { return _(gd, 'Edit in Chart Studio'); },\n icon: Icons.pencil,\n click: function(gd) {\n Plots.sendDataToCloud(gd);\n }\n};\n\nmodeBarButtons.zoom2d = {\n name: 'zoom2d',\n _cat: 'zoom',\n title: function(gd) { return _(gd, 'Zoom'); },\n attr: 'dragmode',\n val: 'zoom',\n icon: Icons.zoombox,\n click: handleCartesian\n};\n\nmodeBarButtons.pan2d = {\n name: 'pan2d',\n _cat: 'pan',\n title: function(gd) { return _(gd, 'Pan'); },\n attr: 'dragmode',\n val: 'pan',\n icon: Icons.pan,\n click: handleCartesian\n};\n\nmodeBarButtons.select2d = {\n name: 'select2d',\n _cat: 'select',\n title: function(gd) { return _(gd, 'Box Select'); },\n attr: 'dragmode',\n val: 'select',\n icon: Icons.selectbox,\n click: handleCartesian\n};\n\nmodeBarButtons.lasso2d = {\n name: 'lasso2d',\n _cat: 'lasso',\n title: function(gd) { return _(gd, 'Lasso Select'); },\n attr: 'dragmode',\n val: 'lasso',\n icon: Icons.lasso,\n click: handleCartesian\n};\n\nmodeBarButtons.drawclosedpath = {\n name: 'drawclosedpath',\n title: function(gd) { return _(gd, 'Draw closed freeform'); },\n attr: 'dragmode',\n val: 'drawclosedpath',\n icon: Icons.drawclosedpath,\n click: handleCartesian\n};\n\nmodeBarButtons.drawopenpath = {\n name: 'drawopenpath',\n title: function(gd) { return _(gd, 'Draw open freeform'); },\n attr: 'dragmode',\n val: 'drawopenpath',\n icon: Icons.drawopenpath,\n click: handleCartesian\n};\n\nmodeBarButtons.drawline = {\n name: 'drawline',\n title: function(gd) { return _(gd, 'Draw line'); },\n attr: 'dragmode',\n val: 'drawline',\n icon: Icons.drawline,\n click: handleCartesian\n};\n\nmodeBarButtons.drawrect = {\n name: 'drawrect',\n title: function(gd) { return _(gd, 'Draw rectangle'); },\n attr: 'dragmode',\n val: 'drawrect',\n icon: Icons.drawrect,\n click: handleCartesian\n};\n\nmodeBarButtons.drawcircle = {\n name: 'drawcircle',\n title: function(gd) { return _(gd, 'Draw circle'); },\n attr: 'dragmode',\n val: 'drawcircle',\n icon: Icons.drawcircle,\n click: handleCartesian\n};\n\nmodeBarButtons.eraseshape = {\n name: 'eraseshape',\n title: function(gd) { return _(gd, 'Erase active shape'); },\n icon: Icons.eraseshape,\n click: eraseActiveShape\n};\n\nmodeBarButtons.zoomIn2d = {\n name: 'zoomIn2d',\n _cat: 'zoomin',\n title: function(gd) { return _(gd, 'Zoom in'); },\n attr: 'zoom',\n val: 'in',\n icon: Icons.zoom_plus,\n click: handleCartesian\n};\n\nmodeBarButtons.zoomOut2d = {\n name: 'zoomOut2d',\n _cat: 'zoomout',\n title: function(gd) { return _(gd, 'Zoom out'); },\n attr: 'zoom',\n val: 'out',\n icon: Icons.zoom_minus,\n click: handleCartesian\n};\n\nmodeBarButtons.autoScale2d = {\n name: 'autoScale2d',\n _cat: 'autoscale',\n title: function(gd) { return _(gd, 'Autoscale'); },\n attr: 'zoom',\n val: 'auto',\n icon: Icons.autoscale,\n click: handleCartesian\n};\n\nmodeBarButtons.resetScale2d = {\n name: 'resetScale2d',\n _cat: 'resetscale',\n title: function(gd) { return _(gd, 'Reset axes'); },\n attr: 'zoom',\n val: 'reset',\n icon: Icons.home,\n click: handleCartesian\n};\n\nmodeBarButtons.hoverClosestCartesian = {\n name: 'hoverClosestCartesian',\n _cat: 'hoverclosest',\n title: function(gd) { return _(gd, 'Show closest data on hover'); },\n attr: 'hovermode',\n val: 'closest',\n icon: Icons.tooltip_basic,\n gravity: 'ne',\n click: handleCartesian\n};\n\nmodeBarButtons.hoverCompareCartesian = {\n name: 'hoverCompareCartesian',\n _cat: 'hoverCompare',\n title: function(gd) { return _(gd, 'Compare data on hover'); },\n attr: 'hovermode',\n val: function(gd) {\n return gd._fullLayout._isHoriz ? 'y' : 'x';\n },\n icon: Icons.tooltip_compare,\n gravity: 'ne',\n click: handleCartesian\n};\n\nfunction handleCartesian(gd, ev) {\n var button = ev.currentTarget;\n var astr = button.getAttribute('data-attr');\n var val = button.getAttribute('data-val') || true;\n var fullLayout = gd._fullLayout;\n var aobj = {};\n var axList = axisIds.list(gd, null, true);\n var allSpikesEnabled = fullLayout._cartesianSpikesEnabled;\n\n var ax, i;\n\n if(astr === 'zoom') {\n var mag = (val === 'in') ? 0.5 : 2;\n var r0 = (1 + mag) / 2;\n var r1 = (1 - mag) / 2;\n var axName;\n\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n\n if(!ax.fixedrange) {\n axName = ax._name;\n if(val === 'auto') {\n aobj[axName + '.autorange'] = true;\n } else if(val === 'reset') {\n if(ax._rangeInitial0 === undefined && ax._rangeInitial1 === undefined) {\n aobj[axName + '.autorange'] = true;\n } else if(ax._rangeInitial0 === undefined) {\n aobj[axName + '.autorange'] = ax._autorangeInitial;\n aobj[axName + '.range'] = [null, ax._rangeInitial1];\n } else if(ax._rangeInitial1 === undefined) {\n aobj[axName + '.range'] = [ax._rangeInitial0, null];\n aobj[axName + '.autorange'] = ax._autorangeInitial;\n } else {\n aobj[axName + '.range'] = [ax._rangeInitial0, ax._rangeInitial1];\n }\n\n // N.B. \"reset\" also resets showspikes\n if(ax._showSpikeInitial !== undefined) {\n aobj[axName + '.showspikes'] = ax._showSpikeInitial;\n if(allSpikesEnabled === 'on' && !ax._showSpikeInitial) {\n allSpikesEnabled = 'off';\n }\n }\n } else {\n var rangeNow = [\n ax.r2l(ax.range[0]),\n ax.r2l(ax.range[1]),\n ];\n\n var rangeNew = [\n r0 * rangeNow[0] + r1 * rangeNow[1],\n r0 * rangeNow[1] + r1 * rangeNow[0]\n ];\n\n aobj[axName + '.range[0]'] = ax.l2r(rangeNew[0]);\n aobj[axName + '.range[1]'] = ax.l2r(rangeNew[1]);\n }\n }\n }\n } else {\n // if ALL traces have orientation 'h', 'hovermode': 'x' otherwise: 'y'\n if(astr === 'hovermode' && (val === 'x' || val === 'y')) {\n val = fullLayout._isHoriz ? 'y' : 'x';\n button.setAttribute('data-val', val);\n }\n\n aobj[astr] = val;\n }\n\n fullLayout._cartesianSpikesEnabled = allSpikesEnabled;\n\n Registry.call('_guiRelayout', gd, aobj);\n}\n\nmodeBarButtons.zoom3d = {\n name: 'zoom3d',\n _cat: 'zoom',\n title: function(gd) { return _(gd, 'Zoom'); },\n attr: 'scene.dragmode',\n val: 'zoom',\n icon: Icons.zoombox,\n click: handleDrag3d\n};\n\nmodeBarButtons.pan3d = {\n name: 'pan3d',\n _cat: 'pan',\n title: function(gd) { return _(gd, 'Pan'); },\n attr: 'scene.dragmode',\n val: 'pan',\n icon: Icons.pan,\n click: handleDrag3d\n};\n\nmodeBarButtons.orbitRotation = {\n name: 'orbitRotation',\n title: function(gd) { return _(gd, 'Orbital rotation'); },\n attr: 'scene.dragmode',\n val: 'orbit',\n icon: Icons['3d_rotate'],\n click: handleDrag3d\n};\n\nmodeBarButtons.tableRotation = {\n name: 'tableRotation',\n title: function(gd) { return _(gd, 'Turntable rotation'); },\n attr: 'scene.dragmode',\n val: 'turntable',\n icon: Icons['z-axis'],\n click: handleDrag3d\n};\n\nfunction handleDrag3d(gd, ev) {\n var button = ev.currentTarget;\n var attr = button.getAttribute('data-attr');\n var val = button.getAttribute('data-val') || true;\n var sceneIds = gd._fullLayout._subplots.gl3d || [];\n var layoutUpdate = {};\n\n var parts = attr.split('.');\n\n for(var i = 0; i < sceneIds.length; i++) {\n layoutUpdate[sceneIds[i] + '.' + parts[1]] = val;\n }\n\n // for multi-type subplots\n var val2d = (val === 'pan') ? val : 'zoom';\n layoutUpdate.dragmode = val2d;\n\n Registry.call('_guiRelayout', gd, layoutUpdate);\n}\n\nmodeBarButtons.resetCameraDefault3d = {\n name: 'resetCameraDefault3d',\n _cat: 'resetCameraDefault',\n title: function(gd) { return _(gd, 'Reset camera to default'); },\n attr: 'resetDefault',\n icon: Icons.home,\n click: handleCamera3d\n};\n\nmodeBarButtons.resetCameraLastSave3d = {\n name: 'resetCameraLastSave3d',\n _cat: 'resetCameraLastSave',\n title: function(gd) { return _(gd, 'Reset camera to last save'); },\n attr: 'resetLastSave',\n icon: Icons.movie,\n click: handleCamera3d\n};\n\nfunction handleCamera3d(gd, ev) {\n var button = ev.currentTarget;\n var attr = button.getAttribute('data-attr');\n var resetLastSave = attr === 'resetLastSave';\n var resetDefault = attr === 'resetDefault';\n\n var fullLayout = gd._fullLayout;\n var sceneIds = fullLayout._subplots.gl3d || [];\n var aobj = {};\n\n for(var i = 0; i < sceneIds.length; i++) {\n var sceneId = sceneIds[i];\n var camera = sceneId + '.camera';\n var aspectratio = sceneId + '.aspectratio';\n var aspectmode = sceneId + '.aspectmode';\n var scene = fullLayout[sceneId]._scene;\n var didUpdate;\n\n if(resetLastSave) {\n aobj[camera + '.up'] = scene.viewInitial.up;\n aobj[camera + '.eye'] = scene.viewInitial.eye;\n aobj[camera + '.center'] = scene.viewInitial.center;\n didUpdate = true;\n } else if(resetDefault) {\n aobj[camera + '.up'] = null;\n aobj[camera + '.eye'] = null;\n aobj[camera + '.center'] = null;\n didUpdate = true;\n }\n\n if(didUpdate) {\n aobj[aspectratio + '.x'] = scene.viewInitial.aspectratio.x;\n aobj[aspectratio + '.y'] = scene.viewInitial.aspectratio.y;\n aobj[aspectratio + '.z'] = scene.viewInitial.aspectratio.z;\n aobj[aspectmode] = scene.viewInitial.aspectmode;\n }\n }\n\n Registry.call('_guiRelayout', gd, aobj);\n}\n\nmodeBarButtons.hoverClosest3d = {\n name: 'hoverClosest3d',\n _cat: 'hoverclosest',\n title: function(gd) { return _(gd, 'Toggle show closest data on hover'); },\n attr: 'hovermode',\n val: null,\n toggle: true,\n icon: Icons.tooltip_basic,\n gravity: 'ne',\n click: handleHover3d\n};\n\nfunction getNextHover3d(gd, ev) {\n var button = ev.currentTarget;\n var val = button._previousVal;\n var fullLayout = gd._fullLayout;\n var sceneIds = fullLayout._subplots.gl3d || [];\n\n var axes = ['xaxis', 'yaxis', 'zaxis'];\n\n // initialize 'current spike' object to be stored in the DOM\n var currentSpikes = {};\n var layoutUpdate = {};\n\n if(val) {\n layoutUpdate = val;\n button._previousVal = null;\n } else {\n for(var i = 0; i < sceneIds.length; i++) {\n var sceneId = sceneIds[i];\n var sceneLayout = fullLayout[sceneId];\n\n var hovermodeAStr = sceneId + '.hovermode';\n currentSpikes[hovermodeAStr] = sceneLayout.hovermode;\n layoutUpdate[hovermodeAStr] = false;\n\n // copy all the current spike attrs\n for(var j = 0; j < 3; j++) {\n var axis = axes[j];\n var spikeAStr = sceneId + '.' + axis + '.showspikes';\n layoutUpdate[spikeAStr] = false;\n currentSpikes[spikeAStr] = sceneLayout[axis].showspikes;\n }\n }\n\n button._previousVal = currentSpikes;\n }\n return layoutUpdate;\n}\n\nfunction handleHover3d(gd, ev) {\n var layoutUpdate = getNextHover3d(gd, ev);\n Registry.call('_guiRelayout', gd, layoutUpdate);\n}\n\nmodeBarButtons.zoomInGeo = {\n name: 'zoomInGeo',\n _cat: 'zoomin',\n title: function(gd) { return _(gd, 'Zoom in'); },\n attr: 'zoom',\n val: 'in',\n icon: Icons.zoom_plus,\n click: handleGeo\n};\n\nmodeBarButtons.zoomOutGeo = {\n name: 'zoomOutGeo',\n _cat: 'zoomout',\n title: function(gd) { return _(gd, 'Zoom out'); },\n attr: 'zoom',\n val: 'out',\n icon: Icons.zoom_minus,\n click: handleGeo\n};\n\nmodeBarButtons.resetGeo = {\n name: 'resetGeo',\n _cat: 'reset',\n title: function(gd) { return _(gd, 'Reset'); },\n attr: 'reset',\n val: null,\n icon: Icons.autoscale,\n click: handleGeo\n};\n\nmodeBarButtons.hoverClosestGeo = {\n name: 'hoverClosestGeo',\n _cat: 'hoverclosest',\n title: function(gd) { return _(gd, 'Toggle show closest data on hover'); },\n attr: 'hovermode',\n val: null,\n toggle: true,\n icon: Icons.tooltip_basic,\n gravity: 'ne',\n click: toggleHover\n};\n\nfunction handleGeo(gd, ev) {\n var button = ev.currentTarget;\n var attr = button.getAttribute('data-attr');\n var val = button.getAttribute('data-val') || true;\n var fullLayout = gd._fullLayout;\n var geoIds = fullLayout._subplots.geo || [];\n\n for(var i = 0; i < geoIds.length; i++) {\n var id = geoIds[i];\n var geoLayout = fullLayout[id];\n\n if(attr === 'zoom') {\n var scale = geoLayout.projection.scale;\n var newScale = (val === 'in') ? 2 * scale : 0.5 * scale;\n\n Registry.call('_guiRelayout', gd, id + '.projection.scale', newScale);\n }\n }\n\n if(attr === 'reset') {\n resetView(gd, 'geo');\n }\n}\n\nmodeBarButtons.hoverClosestGl2d = {\n name: 'hoverClosestGl2d',\n _cat: 'hoverclosest',\n title: function(gd) { return _(gd, 'Toggle show closest data on hover'); },\n attr: 'hovermode',\n val: null,\n toggle: true,\n icon: Icons.tooltip_basic,\n gravity: 'ne',\n click: toggleHover\n};\n\nmodeBarButtons.hoverClosestPie = {\n name: 'hoverClosestPie',\n _cat: 'hoverclosest',\n title: function(gd) { return _(gd, 'Toggle show closest data on hover'); },\n attr: 'hovermode',\n val: 'closest',\n icon: Icons.tooltip_basic,\n gravity: 'ne',\n click: toggleHover\n};\n\nfunction getNextHover(gd) {\n var fullLayout = gd._fullLayout;\n\n if(fullLayout.hovermode) return false;\n\n if(fullLayout._has('cartesian')) {\n return fullLayout._isHoriz ? 'y' : 'x';\n }\n return 'closest';\n}\n\nfunction toggleHover(gd) {\n var newHover = getNextHover(gd);\n Registry.call('_guiRelayout', gd, 'hovermode', newHover);\n}\n\nmodeBarButtons.resetViewSankey = {\n name: 'resetSankeyGroup',\n title: function(gd) { return _(gd, 'Reset view'); },\n icon: Icons.home,\n click: function(gd) {\n var aObj = {\n 'node.groups': [],\n 'node.x': [],\n 'node.y': []\n };\n for(var i = 0; i < gd._fullData.length; i++) {\n var viewInitial = gd._fullData[i]._viewInitial;\n aObj['node.groups'].push(viewInitial.node.groups.slice());\n aObj['node.x'].push(viewInitial.node.x.slice());\n aObj['node.y'].push(viewInitial.node.y.slice());\n }\n Registry.call('restyle', gd, aObj);\n }\n};\n\n// buttons when more then one plot types are present\n\nmodeBarButtons.toggleHover = {\n name: 'toggleHover',\n title: function(gd) { return _(gd, 'Toggle show closest data on hover'); },\n attr: 'hovermode',\n val: null,\n toggle: true,\n icon: Icons.tooltip_basic,\n gravity: 'ne',\n click: function(gd, ev) {\n var layoutUpdate = getNextHover3d(gd, ev);\n layoutUpdate.hovermode = getNextHover(gd);\n\n Registry.call('_guiRelayout', gd, layoutUpdate);\n }\n};\n\nmodeBarButtons.resetViews = {\n name: 'resetViews',\n title: function(gd) { return _(gd, 'Reset views'); },\n icon: Icons.home,\n click: function(gd, ev) {\n var button = ev.currentTarget;\n\n button.setAttribute('data-attr', 'zoom');\n button.setAttribute('data-val', 'reset');\n handleCartesian(gd, ev);\n\n button.setAttribute('data-attr', 'resetLastSave');\n handleCamera3d(gd, ev);\n\n resetView(gd, 'geo');\n resetView(gd, 'mapbox');\n resetView(gd, 'map');\n }\n};\n\nmodeBarButtons.toggleSpikelines = {\n name: 'toggleSpikelines',\n title: function(gd) { return _(gd, 'Toggle Spike Lines'); },\n icon: Icons.spikeline,\n attr: '_cartesianSpikesEnabled',\n val: 'on',\n click: function(gd) {\n var fullLayout = gd._fullLayout;\n var allSpikesEnabled = fullLayout._cartesianSpikesEnabled;\n\n fullLayout._cartesianSpikesEnabled = allSpikesEnabled === 'on' ? 'off' : 'on';\n Registry.call('_guiRelayout', gd, setSpikelineVisibility(gd));\n }\n};\n\nfunction setSpikelineVisibility(gd) {\n var fullLayout = gd._fullLayout;\n var areSpikesOn = fullLayout._cartesianSpikesEnabled === 'on';\n var axList = axisIds.list(gd, null, true);\n var aobj = {};\n\n for(var i = 0; i < axList.length; i++) {\n var ax = axList[i];\n aobj[ax._name + '.showspikes'] = areSpikesOn ? true : ax._showSpikeInitial;\n }\n\n return aobj;\n}\n\nmodeBarButtons.resetViewMapbox = {\n name: 'resetViewMapbox',\n _cat: 'resetView',\n title: function(gd) { return _(gd, 'Reset view'); },\n attr: 'reset',\n icon: Icons.home,\n click: function(gd) {\n resetView(gd, 'mapbox');\n }\n};\n\nmodeBarButtons.resetViewMap = {\n name: 'resetViewMap',\n _cat: 'resetView',\n title: function(gd) { return _(gd, 'Reset view'); },\n attr: 'reset',\n icon: Icons.home,\n click: function(gd) {\n resetView(gd, 'map');\n }\n};\n\nmodeBarButtons.zoomInMapbox = {\n name: 'zoomInMapbox',\n _cat: 'zoomin',\n title: function(gd) { return _(gd, 'Zoom in'); },\n attr: 'zoom',\n val: 'in',\n icon: Icons.zoom_plus,\n click: handleMapboxZoom\n};\n\nmodeBarButtons.zoomInMap = {\n name: 'zoomInMap',\n _cat: 'zoomin',\n title: function(gd) { return _(gd, 'Zoom in'); },\n attr: 'zoom',\n val: 'in',\n icon: Icons.zoom_plus,\n click: handleMapZoom\n};\n\nmodeBarButtons.zoomOutMapbox = {\n name: 'zoomOutMapbox',\n _cat: 'zoomout',\n title: function(gd) { return _(gd, 'Zoom out'); },\n attr: 'zoom',\n val: 'out',\n icon: Icons.zoom_minus,\n click: handleMapboxZoom\n};\n\nmodeBarButtons.zoomOutMap = {\n name: 'zoomOutMap',\n _cat: 'zoomout',\n title: function(gd) { return _(gd, 'Zoom out'); },\n attr: 'zoom',\n val: 'out',\n icon: Icons.zoom_minus,\n click: handleMapZoom\n};\n\nfunction handleMapboxZoom(gd, ev) {\n _handleMapZoom(gd, ev, 'mapbox');\n}\n\nfunction handleMapZoom(gd, ev) {\n _handleMapZoom(gd, ev, 'map');\n}\n\nfunction _handleMapZoom(gd, ev, mapType) {\n var button = ev.currentTarget;\n var val = button.getAttribute('data-val');\n var fullLayout = gd._fullLayout;\n var subplotIds = fullLayout._subplots[mapType] || [];\n var scalar = 1.05;\n var aObj = {};\n\n for(var i = 0; i < subplotIds.length; i++) {\n var id = subplotIds[i];\n var current = fullLayout[id].zoom;\n var next = (val === 'in') ? scalar * current : current / scalar;\n aObj[id + '.zoom'] = next;\n }\n\n Registry.call('_guiRelayout', gd, aObj);\n}\n\nfunction resetView(gd, subplotType) {\n var fullLayout = gd._fullLayout;\n var subplotIds = fullLayout._subplots[subplotType] || [];\n var aObj = {};\n\n for(var i = 0; i < subplotIds.length; i++) {\n var id = subplotIds[i];\n var subplotObj = fullLayout[id]._subplot;\n var viewInitial = subplotObj.viewInitial;\n var viewKeys = Object.keys(viewInitial);\n\n for(var j = 0; j < viewKeys.length; j++) {\n var key = viewKeys[j];\n aObj[id + '.' + key] = viewInitial[key];\n }\n }\n\n Registry.call('_guiRelayout', gd, aObj);\n}\n","'use strict';\n\nvar modeBarButtons = require('./buttons');\nvar buttonList = Object.keys(modeBarButtons);\n\nvar DRAW_MODES = [\n 'drawline',\n 'drawopenpath',\n 'drawclosedpath',\n 'drawcircle',\n 'drawrect',\n 'eraseshape'\n];\n\nvar backButtons = [\n 'v1hovermode',\n 'hoverclosest',\n 'hovercompare',\n 'togglehover',\n 'togglespikelines'\n].concat(DRAW_MODES);\n\nvar foreButtons = [];\nvar addToForeButtons = function(b) {\n if(backButtons.indexOf(b._cat || b.name) !== -1) return;\n // for convenience add lowercase shotname e.g. zoomin as well fullname zoomInGeo\n var name = b.name;\n var _cat = (b._cat || b.name).toLowerCase();\n if(foreButtons.indexOf(name) === -1) foreButtons.push(name);\n if(foreButtons.indexOf(_cat) === -1) foreButtons.push(_cat);\n};\nbuttonList.forEach(function(k) {\n addToForeButtons(modeBarButtons[k]);\n});\nforeButtons.sort();\n\nmodule.exports = {\n DRAW_MODES: DRAW_MODES,\n backButtons: backButtons,\n foreButtons: foreButtons\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../color');\nvar Template = require('../../plot_api/plot_template');\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n var containerIn = layoutIn.modebar || {};\n var containerOut = Template.newContainer(layoutOut, 'modebar');\n\n function coerce(attr, dflt) {\n return Lib.coerce(containerIn, containerOut, attributes, attr, dflt);\n }\n\n coerce('orientation');\n coerce('bgcolor', Color.addOpacity(layoutOut.paper_bgcolor, 0.5));\n var defaultColor = Color.contrast(Color.rgb(layoutOut.modebar.bgcolor));\n coerce('color', Color.addOpacity(defaultColor, 0.3));\n coerce('activecolor', Color.addOpacity(defaultColor, 0.7));\n coerce('uirevision', layoutOut.uirevision);\n coerce('add');\n coerce('remove');\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'component',\n name: 'modebar',\n\n layoutAttributes: require('./attributes'),\n supplyLayoutDefaults: require('./defaults'),\n\n manage: require('./manage')\n};\n","'use strict';\n\nvar axisIds = require('../../plots/cartesian/axis_ids');\nvar scatterSubTypes = require('../../traces/scatter/subtypes');\nvar Registry = require('../../registry');\nvar isUnifiedHover = require('../fx/helpers').isUnifiedHover;\n\nvar createModeBar = require('./modebar');\nvar modeBarButtons = require('./buttons');\nvar DRAW_MODES = require('./constants').DRAW_MODES;\nvar extendDeep = require('../../lib').extendDeep;\n\n/**\n * ModeBar wrapper around 'create' and 'update',\n * chooses buttons to pass to ModeBar constructor based on\n * plot type and plot config.\n *\n * @param {object} gd main plot object\n *\n */\nmodule.exports = function manageModeBar(gd) {\n var fullLayout = gd._fullLayout;\n var context = gd._context;\n var modeBar = fullLayout._modeBar;\n\n if(!context.displayModeBar && !context.watermark) {\n if(modeBar) {\n modeBar.destroy();\n delete fullLayout._modeBar;\n }\n return;\n }\n\n if(!Array.isArray(context.modeBarButtonsToRemove)) {\n throw new Error([\n '*modeBarButtonsToRemove* configuration options',\n 'must be an array.'\n ].join(' '));\n }\n\n if(!Array.isArray(context.modeBarButtonsToAdd)) {\n throw new Error([\n '*modeBarButtonsToAdd* configuration options',\n 'must be an array.'\n ].join(' '));\n }\n\n var customButtons = context.modeBarButtons;\n var buttonGroups;\n\n if(Array.isArray(customButtons) && customButtons.length) {\n buttonGroups = fillCustomButton(customButtons);\n } else if(!context.displayModeBar && context.watermark) {\n buttonGroups = [];\n } else {\n buttonGroups = getButtonGroups(gd);\n }\n\n if(modeBar) modeBar.update(gd, buttonGroups);\n else fullLayout._modeBar = createModeBar(gd, buttonGroups);\n};\n\n// logic behind which buttons are displayed by default\nfunction getButtonGroups(gd) {\n var fullLayout = gd._fullLayout;\n var fullData = gd._fullData;\n var context = gd._context;\n\n function match(name, B) {\n if(typeof B === 'string') {\n if(B.toLowerCase() === name.toLowerCase()) return true;\n } else {\n var v0 = B.name;\n var v1 = (B._cat || B.name);\n\n if(v0 === name || v1 === name.toLowerCase()) return true;\n }\n return false;\n }\n\n var layoutAdd = fullLayout.modebar.add;\n if(typeof layoutAdd === 'string') layoutAdd = [layoutAdd];\n\n var layoutRemove = fullLayout.modebar.remove;\n if(typeof layoutRemove === 'string') layoutRemove = [layoutRemove];\n\n var buttonsToAdd = context.modeBarButtonsToAdd.concat(\n layoutAdd.filter(function(e) {\n for(var i = 0; i < context.modeBarButtonsToRemove.length; i++) {\n if(match(e, context.modeBarButtonsToRemove[i])) return false;\n }\n return true;\n })\n );\n\n var buttonsToRemove = context.modeBarButtonsToRemove.concat(\n layoutRemove.filter(function(e) {\n for(var i = 0; i < context.modeBarButtonsToAdd.length; i++) {\n if(match(e, context.modeBarButtonsToAdd[i])) return false;\n }\n return true;\n })\n );\n\n var hasCartesian = fullLayout._has('cartesian');\n var hasGL3D = fullLayout._has('gl3d');\n var hasGeo = fullLayout._has('geo');\n var hasPie = fullLayout._has('pie');\n var hasFunnelarea = fullLayout._has('funnelarea');\n var hasGL2D = fullLayout._has('gl2d');\n var hasTernary = fullLayout._has('ternary');\n var hasMapbox = fullLayout._has('mapbox');\n var hasMap = fullLayout._has('map');\n var hasPolar = fullLayout._has('polar');\n var hasSmith = fullLayout._has('smith');\n var hasSankey = fullLayout._has('sankey');\n var allAxesFixed = areAllAxesFixed(fullLayout);\n var hasUnifiedHoverLabel = isUnifiedHover(fullLayout.hovermode);\n\n var groups = [];\n\n function addGroup(newGroup) {\n if(!newGroup.length) return;\n\n var out = [];\n\n for(var i = 0; i < newGroup.length; i++) {\n var name = newGroup[i];\n var B = modeBarButtons[name];\n var v0 = B.name.toLowerCase();\n var v1 = (B._cat || B.name).toLowerCase();\n var found = false;\n for(var q = 0; q < buttonsToRemove.length; q++) {\n var t = buttonsToRemove[q].toLowerCase();\n if(t === v0 || t === v1) {\n found = true;\n break;\n }\n }\n if(found) continue;\n out.push(modeBarButtons[name]);\n }\n\n groups.push(out);\n }\n\n // buttons common to all plot types\n var commonGroup = ['toImage'];\n if(context.showEditInChartStudio) commonGroup.push('editInChartStudio');\n else if(context.showSendToCloud) commonGroup.push('sendDataToCloud');\n addGroup(commonGroup);\n\n var zoomGroup = [];\n var hoverGroup = [];\n var resetGroup = [];\n var dragModeGroup = [];\n\n if((hasCartesian || hasGL2D || hasPie || hasFunnelarea || hasTernary) + hasGeo + hasGL3D + hasMapbox + hasMap + hasPolar + hasSmith > 1) {\n // graphs with more than one plot types get 'union buttons'\n // which reset the view or toggle hover labels across all subplots.\n hoverGroup = ['toggleHover'];\n resetGroup = ['resetViews'];\n } else if(hasGeo) {\n zoomGroup = ['zoomInGeo', 'zoomOutGeo'];\n hoverGroup = ['hoverClosestGeo'];\n resetGroup = ['resetGeo'];\n } else if(hasGL3D) {\n hoverGroup = ['hoverClosest3d'];\n resetGroup = ['resetCameraDefault3d', 'resetCameraLastSave3d'];\n } else if(hasMapbox) {\n zoomGroup = ['zoomInMapbox', 'zoomOutMapbox'];\n hoverGroup = ['toggleHover'];\n resetGroup = ['resetViewMapbox'];\n } else if(hasMap) {\n zoomGroup = ['zoomInMap', 'zoomOutMap'];\n hoverGroup = ['toggleHover'];\n resetGroup = ['resetViewMap'];\n } else if(hasGL2D) {\n hoverGroup = ['hoverClosestGl2d'];\n } else if(hasPie) {\n hoverGroup = ['hoverClosestPie'];\n } else if(hasSankey) {\n hoverGroup = ['hoverClosestCartesian', 'hoverCompareCartesian'];\n resetGroup = ['resetViewSankey'];\n } else { // hasPolar, hasSmith, hasTernary\n // always show at least one hover icon.\n hoverGroup = ['toggleHover'];\n }\n // if we have cartesian, allow switching between closest and compare\n // regardless of what other types are on the plot, since they'll all\n // just treat any truthy hovermode as 'closest'\n if(hasCartesian) {\n hoverGroup.push('toggleSpikelines', 'hoverClosestCartesian', 'hoverCompareCartesian');\n }\n if(hasNoHover(fullData) || hasUnifiedHoverLabel) {\n hoverGroup = [];\n }\n\n if((hasCartesian || hasGL2D) && !allAxesFixed) {\n zoomGroup = ['zoomIn2d', 'zoomOut2d', 'autoScale2d'];\n if(resetGroup[0] !== 'resetViews') resetGroup = ['resetScale2d'];\n }\n\n if(hasGL3D) {\n dragModeGroup = ['zoom3d', 'pan3d', 'orbitRotation', 'tableRotation'];\n } else if(((hasCartesian || hasGL2D) && !allAxesFixed) || hasTernary) {\n dragModeGroup = ['zoom2d', 'pan2d'];\n } else if(hasMapbox || hasMap || hasGeo) {\n dragModeGroup = ['pan2d'];\n } else if(hasPolar) {\n dragModeGroup = ['zoom2d'];\n }\n if(isSelectable(fullData)) {\n dragModeGroup.push('select2d', 'lasso2d');\n }\n\n var enabledHoverGroup = [];\n var enableHover = function(a) {\n // return if already added\n if(enabledHoverGroup.indexOf(a) !== -1) return;\n // should be in hoverGroup\n if(hoverGroup.indexOf(a) !== -1) {\n enabledHoverGroup.push(a);\n }\n };\n if(Array.isArray(buttonsToAdd)) {\n var newList = [];\n for(var i = 0; i < buttonsToAdd.length; i++) {\n var b = buttonsToAdd[i];\n if(typeof b === 'string') {\n b = b.toLowerCase();\n\n if(DRAW_MODES.indexOf(b) !== -1) {\n // accept pre-defined drag modes i.e. shape drawing features as string\n if(\n fullLayout._has('mapbox') || fullLayout._has('map') || // draw shapes in paper coordinate (could be improved in future to support data coordinate, when there is no pitch)\n fullLayout._has('cartesian') // draw shapes in data coordinate\n ) {\n dragModeGroup.push(b);\n }\n } else if(b === 'togglespikelines') {\n enableHover('toggleSpikelines');\n } else if(b === 'togglehover') {\n enableHover('toggleHover');\n } else if(b === 'hovercompare') {\n enableHover('hoverCompareCartesian');\n } else if(b === 'hoverclosest') {\n enableHover('hoverClosestCartesian');\n enableHover('hoverClosestGeo');\n enableHover('hoverClosest3d');\n enableHover('hoverClosestGl2d');\n enableHover('hoverClosestPie');\n } else if(b === 'v1hovermode') {\n enableHover('hoverClosestCartesian');\n enableHover('hoverCompareCartesian');\n enableHover('hoverClosestGeo');\n enableHover('hoverClosest3d');\n enableHover('hoverClosestGl2d');\n enableHover('hoverClosestPie');\n }\n } else newList.push(b);\n }\n buttonsToAdd = newList;\n }\n\n addGroup(dragModeGroup);\n addGroup(zoomGroup.concat(resetGroup));\n addGroup(enabledHoverGroup);\n\n return appendButtonsToGroups(groups, buttonsToAdd);\n}\n\nfunction areAllAxesFixed(fullLayout) {\n var axList = axisIds.list({_fullLayout: fullLayout}, null, true);\n\n for(var i = 0; i < axList.length; i++) {\n if(!axList[i].fixedrange) {\n return false;\n }\n }\n\n return true;\n}\n\n// look for traces that support selection\n// to be updated as we add more selectPoints handlers\nfunction isSelectable(fullData) {\n var selectable = false;\n\n for(var i = 0; i < fullData.length; i++) {\n if(selectable) break;\n\n var trace = fullData[i];\n\n if(!trace._module || !trace._module.selectPoints) continue;\n\n if(Registry.traceIs(trace, 'scatter-like')) {\n if(scatterSubTypes.hasMarkers(trace) || scatterSubTypes.hasText(trace)) {\n selectable = true;\n }\n } else if(Registry.traceIs(trace, 'box-violin')) {\n if(trace.boxpoints === 'all' || trace.points === 'all') {\n selectable = true;\n }\n } else {\n // assume that in general if the trace module has selectPoints,\n // then it's selectable. Scatter is an exception to this because it must\n // have markers or text, not just be a scatter type.\n\n selectable = true;\n }\n }\n\n return selectable;\n}\n\n// check whether all trace are 'noHover'\nfunction hasNoHover(fullData) {\n for(var i = 0; i < fullData.length; i++) {\n if(!Registry.traceIs(fullData[i], 'noHover')) return false;\n }\n return true;\n}\n\nfunction appendButtonsToGroups(groups, buttons) {\n if(buttons.length) {\n if(Array.isArray(buttons[0])) {\n for(var i = 0; i < buttons.length; i++) {\n groups.push(buttons[i]);\n }\n } else groups.push(buttons);\n }\n\n return groups;\n}\n\n// fill in custom buttons referring to default mode bar buttons\nfunction fillCustomButton(originalModeBarButtons) {\n var customButtons = extendDeep([], originalModeBarButtons);\n\n for(var i = 0; i < customButtons.length; i++) {\n var buttonGroup = customButtons[i];\n\n for(var j = 0; j < buttonGroup.length; j++) {\n var button = buttonGroup[j];\n\n if(typeof button === 'string') {\n if(modeBarButtons[button] !== undefined) {\n customButtons[i][j] = modeBarButtons[button];\n } else {\n throw new Error([\n '*modeBarButtons* configuration options',\n 'invalid button name'\n ].join(' '));\n }\n }\n }\n }\n\n return customButtons;\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar Icons = require('../../fonts/ploticon');\nvar version = require('../../version').version;\n\nvar Parser = new DOMParser();\n\n/**\n * UI controller for interactive plots\n * @Class\n * @Param {object} opts\n * @Param {object} opts.buttons nested arrays of grouped buttons config objects\n * @Param {object} opts.container container div to append modeBar\n * @Param {object} opts.graphInfo primary plot object containing data and layout\n */\nfunction ModeBar(opts) {\n this.container = opts.container;\n this.element = document.createElement('div');\n\n this.update(opts.graphInfo, opts.buttons);\n\n this.container.appendChild(this.element);\n}\n\nvar proto = ModeBar.prototype;\n\n/**\n * Update modeBar (buttons and logo)\n *\n * @param {object} graphInfo primary plot object containing data and layout\n * @param {array of arrays} buttons nested arrays of grouped buttons to initialize\n *\n */\nproto.update = function(graphInfo, buttons) {\n this.graphInfo = graphInfo;\n\n var context = this.graphInfo._context;\n var fullLayout = this.graphInfo._fullLayout;\n var modeBarId = 'modebar-' + fullLayout._uid;\n\n this.element.setAttribute('id', modeBarId);\n this._uid = modeBarId;\n\n this.element.className = 'modebar';\n if(context.displayModeBar === 'hover') this.element.className += ' modebar--hover ease-bg';\n\n if(fullLayout.modebar.orientation === 'v') {\n this.element.className += ' vertical';\n buttons = buttons.reverse();\n }\n\n var style = fullLayout.modebar;\n var bgSelector = context.displayModeBar === 'hover' ? '.js-plotly-plot .plotly:hover ' : '';\n\n Lib.deleteRelatedStyleRule(modeBarId);\n Lib.addRelatedStyleRule(modeBarId, bgSelector + '#' + modeBarId + ' .modebar-group', 'background-color: ' + style.bgcolor);\n Lib.addRelatedStyleRule(modeBarId, '#' + modeBarId + ' .modebar-btn .icon path', 'fill: ' + style.color);\n Lib.addRelatedStyleRule(modeBarId, '#' + modeBarId + ' .modebar-btn:hover .icon path', 'fill: ' + style.activecolor);\n Lib.addRelatedStyleRule(modeBarId, '#' + modeBarId + ' .modebar-btn.active .icon path', 'fill: ' + style.activecolor);\n\n // if buttons or logo have changed, redraw modebar interior\n var needsNewButtons = !this.hasButtons(buttons);\n var needsNewLogo = (this.hasLogo !== context.displaylogo);\n var needsNewLocale = (this.locale !== context.locale);\n\n this.locale = context.locale;\n\n if(needsNewButtons || needsNewLogo || needsNewLocale) {\n this.removeAllButtons();\n\n this.updateButtons(buttons);\n\n if(context.watermark || context.displaylogo) {\n var logoGroup = this.getLogo();\n if(context.watermark) {\n logoGroup.className = logoGroup.className + ' watermark';\n }\n\n if(fullLayout.modebar.orientation === 'v') {\n this.element.insertBefore(logoGroup, this.element.childNodes[0]);\n } else {\n this.element.appendChild(logoGroup);\n }\n\n this.hasLogo = true;\n }\n }\n\n this.updateActiveButton();\n};\n\nproto.updateButtons = function(buttons) {\n var _this = this;\n\n this.buttons = buttons;\n this.buttonElements = [];\n this.buttonsNames = [];\n\n this.buttons.forEach(function(buttonGroup) {\n var group = _this.createGroup();\n\n buttonGroup.forEach(function(buttonConfig) {\n var buttonName = buttonConfig.name;\n if(!buttonName) {\n throw new Error('must provide button \\'name\\' in button config');\n }\n if(_this.buttonsNames.indexOf(buttonName) !== -1) {\n throw new Error('button name \\'' + buttonName + '\\' is taken');\n }\n _this.buttonsNames.push(buttonName);\n\n var button = _this.createButton(buttonConfig);\n _this.buttonElements.push(button);\n group.appendChild(button);\n });\n\n _this.element.appendChild(group);\n });\n};\n\n/**\n * Empty div for containing a group of buttons\n * @Return {HTMLelement}\n */\nproto.createGroup = function() {\n var group = document.createElement('div');\n group.className = 'modebar-group';\n return group;\n};\n\n/**\n * Create a new button div and set constant and configurable attributes\n * @Param {object} config (see ./buttons.js for more info)\n * @Return {HTMLelement}\n */\nproto.createButton = function(config) {\n var _this = this;\n var button = document.createElement('a');\n\n button.setAttribute('rel', 'tooltip');\n button.className = 'modebar-btn';\n\n var title = config.title;\n if(title === undefined) title = config.name;\n // for localization: allow title to be a callable that takes gd as arg\n else if(typeof title === 'function') title = title(this.graphInfo);\n\n if(title || title === 0) button.setAttribute('data-title', title);\n\n if(config.attr !== undefined) button.setAttribute('data-attr', config.attr);\n\n var val = config.val;\n if(val !== undefined) {\n if(typeof val === 'function') val = val(this.graphInfo);\n button.setAttribute('data-val', val);\n }\n\n var click = config.click;\n if(typeof click !== 'function') {\n throw new Error('must provide button \\'click\\' function in button config');\n } else {\n button.addEventListener('click', function(ev) {\n config.click(_this.graphInfo, ev);\n\n // only needed for 'hoverClosestGeo' which does not call relayout\n _this.updateActiveButton(ev.currentTarget);\n });\n }\n\n button.setAttribute('data-toggle', config.toggle || false);\n if(config.toggle) d3.select(button).classed('active', true);\n\n var icon = config.icon;\n if(typeof icon === 'function') {\n button.appendChild(icon());\n } else {\n button.appendChild(this.createIcon(icon || Icons.question));\n }\n button.setAttribute('data-gravity', config.gravity || 'n');\n\n return button;\n};\n\n/**\n * Add an icon to a button\n * @Param {object} thisIcon\n * @Param {number} thisIcon.width\n * @Param {string} thisIcon.path\n * @Param {string} thisIcon.color\n * @Return {HTMLelement}\n */\nproto.createIcon = function(thisIcon) {\n var iconHeight = isNumeric(thisIcon.height) ?\n Number(thisIcon.height) :\n thisIcon.ascent - thisIcon.descent;\n var svgNS = 'http://www.w3.org/2000/svg';\n var icon;\n\n if(thisIcon.path) {\n icon = document.createElementNS(svgNS, 'svg');\n icon.setAttribute('viewBox', [0, 0, thisIcon.width, iconHeight].join(' '));\n icon.setAttribute('class', 'icon');\n\n var path = document.createElementNS(svgNS, 'path');\n path.setAttribute('d', thisIcon.path);\n\n if(thisIcon.transform) {\n path.setAttribute('transform', thisIcon.transform);\n } else if(thisIcon.ascent !== undefined) {\n // Legacy icon transform calculation\n path.setAttribute('transform', 'matrix(1 0 0 -1 0 ' + thisIcon.ascent + ')');\n }\n\n icon.appendChild(path);\n }\n\n if(thisIcon.svg) {\n var svgDoc = Parser.parseFromString(thisIcon.svg, 'application/xml');\n icon = svgDoc.childNodes[0];\n }\n\n icon.setAttribute('height', '1em');\n icon.setAttribute('width', '1em');\n\n return icon;\n};\n\n/**\n * Updates active button with attribute specified in layout\n * @Param {object} graphInfo plot object containing data and layout\n * @Return {HTMLelement}\n */\nproto.updateActiveButton = function(buttonClicked) {\n var fullLayout = this.graphInfo._fullLayout;\n var dataAttrClicked = (buttonClicked !== undefined) ?\n buttonClicked.getAttribute('data-attr') :\n null;\n\n this.buttonElements.forEach(function(button) {\n var thisval = button.getAttribute('data-val') || true;\n var dataAttr = button.getAttribute('data-attr');\n var isToggleButton = (button.getAttribute('data-toggle') === 'true');\n var button3 = d3.select(button);\n\n // Use 'data-toggle' and 'buttonClicked' to toggle buttons\n // that have no one-to-one equivalent in fullLayout\n if(isToggleButton) {\n if(dataAttr === dataAttrClicked) {\n button3.classed('active', !button3.classed('active'));\n }\n } else {\n var val = (dataAttr === null) ?\n dataAttr :\n Lib.nestedProperty(fullLayout, dataAttr).get();\n\n button3.classed('active', val === thisval);\n }\n });\n};\n\n/**\n * Check if modeBar is configured as button configuration argument\n *\n * @Param {object} buttons 2d array of grouped button config objects\n * @Return {boolean}\n */\nproto.hasButtons = function(buttons) {\n var currentButtons = this.buttons;\n\n if(!currentButtons) return false;\n\n if(buttons.length !== currentButtons.length) return false;\n\n for(var i = 0; i < buttons.length; ++i) {\n if(buttons[i].length !== currentButtons[i].length) return false;\n for(var j = 0; j < buttons[i].length; j++) {\n if(buttons[i][j].name !== currentButtons[i][j].name) return false;\n }\n }\n\n return true;\n};\n\nfunction jsVersion(str) {\n return str + ' (v' + version + ')';\n}\n\n/**\n * @return {HTMLDivElement} The logo image wrapped in a group\n */\nproto.getLogo = function() {\n var group = this.createGroup();\n var a = document.createElement('a');\n\n a.href = 'https://plotly.com/';\n a.target = '_blank';\n a.setAttribute('data-title', jsVersion(Lib._(this.graphInfo, 'Produced with Plotly.js')));\n a.className = 'modebar-btn plotlyjsicon modebar-btn--logo';\n\n a.appendChild(this.createIcon(Icons.newplotlylogo));\n\n group.appendChild(a);\n return group;\n};\n\nproto.removeAllButtons = function() {\n while(this.element.firstChild) {\n this.element.removeChild(this.element.firstChild);\n }\n\n this.hasLogo = false;\n};\n\nproto.destroy = function() {\n Lib.removeElement(this.container.querySelector('.modebar'));\n Lib.deleteRelatedStyleRule(this._uid);\n};\n\nfunction createModeBar(gd, buttons) {\n var fullLayout = gd._fullLayout;\n\n var modeBar = new ModeBar({\n graphInfo: gd,\n container: fullLayout._modebardiv.node(),\n buttons: buttons\n });\n\n if(fullLayout._privateplot) {\n d3.select(modeBar.element).append('span')\n .classed('badge-private float--left', true)\n .text('PRIVATE');\n }\n\n return modeBar;\n}\n\nmodule.exports = createModeBar;\n","'use strict';\n\nvar fontAttrs = require('../../plots/font_attributes');\nvar colorAttrs = require('../color/attributes');\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\n\nvar buttonAttrs = templatedArray('button', {\n visible: {\n valType: 'boolean',\n dflt: true,\n editType: 'plot',\n description: 'Determines whether or not this button is visible.'\n },\n step: {\n valType: 'enumerated',\n values: ['month', 'year', 'day', 'hour', 'minute', 'second', 'all'],\n dflt: 'month',\n editType: 'plot',\n description: [\n 'The unit of measurement that the `count` value will set the range by.'\n ].join(' ')\n },\n stepmode: {\n valType: 'enumerated',\n values: ['backward', 'todate'],\n dflt: 'backward',\n editType: 'plot',\n description: [\n 'Sets the range update mode.',\n 'If *backward*, the range update shifts the start of range',\n 'back *count* times *step* milliseconds.',\n 'If *todate*, the range update shifts the start of range',\n 'back to the first timestamp from *count* times',\n '*step* milliseconds back.',\n 'For example, with `step` set to *year* and `count` set to *1*',\n 'the range update shifts the start of the range back to',\n 'January 01 of the current year.',\n 'Month and year *todate* are currently available only',\n 'for the built-in (Gregorian) calendar.'\n ].join(' ')\n },\n count: {\n valType: 'number',\n min: 0,\n dflt: 1,\n editType: 'plot',\n description: [\n 'Sets the number of steps to take to update the range.',\n 'Use with `step` to specify the update interval.'\n ].join(' ')\n },\n label: {\n valType: 'string',\n editType: 'plot',\n description: 'Sets the text label to appear on the button.'\n },\n editType: 'plot',\n description: [\n 'Sets the specifications for each buttons.',\n 'By default, a range selector comes with no buttons.'\n ].join(' ')\n});\n\nmodule.exports = {\n visible: {\n valType: 'boolean',\n editType: 'plot',\n description: [\n 'Determines whether or not this range selector is visible.',\n 'Note that range selectors are only available for x axes of',\n '`type` set to or auto-typed to *date*.'\n ].join(' ')\n },\n\n buttons: buttonAttrs,\n\n x: {\n valType: 'number',\n min: -2,\n max: 3,\n editType: 'plot',\n description: 'Sets the x position (in normalized coordinates) of the range selector.'\n },\n xanchor: {\n valType: 'enumerated',\n values: ['auto', 'left', 'center', 'right'],\n dflt: 'left',\n editType: 'plot',\n description: [\n 'Sets the range selector\\'s horizontal position anchor.',\n 'This anchor binds the `x` position to the *left*, *center*',\n 'or *right* of the range selector.'\n ].join(' ')\n },\n y: {\n valType: 'number',\n min: -2,\n max: 3,\n editType: 'plot',\n description: 'Sets the y position (in normalized coordinates) of the range selector.'\n },\n yanchor: {\n valType: 'enumerated',\n values: ['auto', 'top', 'middle', 'bottom'],\n dflt: 'bottom',\n editType: 'plot',\n description: [\n 'Sets the range selector\\'s vertical position anchor',\n 'This anchor binds the `y` position to the *top*, *middle*',\n 'or *bottom* of the range selector.'\n ].join(' ')\n },\n\n font: fontAttrs({\n editType: 'plot',\n description: 'Sets the font of the range selector button text.'\n }),\n\n bgcolor: {\n valType: 'color',\n dflt: colorAttrs.lightLine,\n editType: 'plot',\n description: 'Sets the background color of the range selector buttons.'\n },\n activecolor: {\n valType: 'color',\n editType: 'plot',\n description: 'Sets the background color of the active range selector button.'\n },\n bordercolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n editType: 'plot',\n description: 'Sets the color of the border enclosing the range selector.'\n },\n borderwidth: {\n valType: 'number',\n min: 0,\n dflt: 0,\n editType: 'plot',\n description: 'Sets the width (in px) of the border enclosing the range selector.'\n },\n editType: 'plot'\n};\n","'use strict';\n\n\nmodule.exports = {\n\n // 'y' position pad above counter axis domain\n yPad: 0.02,\n\n // minimum button width (regardless of text size)\n minButtonWidth: 30,\n\n // buttons rect radii\n rx: 3,\n ry: 3,\n\n // light fraction used to compute the 'activecolor' default\n lightAmount: 25,\n darkAmount: 10\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../color');\nvar Template = require('../../plot_api/plot_template');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar attributes = require('./attributes');\nvar constants = require('./constants');\n\n\nmodule.exports = function handleDefaults(containerIn, containerOut, layout, counterAxes, calendar) {\n var selectorIn = containerIn.rangeselector || {};\n var selectorOut = Template.newContainer(containerOut, 'rangeselector');\n\n function coerce(attr, dflt) {\n return Lib.coerce(selectorIn, selectorOut, attributes, attr, dflt);\n }\n\n var buttons = handleArrayContainerDefaults(selectorIn, selectorOut, {\n name: 'buttons',\n handleItemDefaults: buttonDefaults,\n calendar: calendar\n });\n\n var visible = coerce('visible', buttons.length > 0);\n if(visible) {\n var posDflt = getPosDflt(containerOut, layout, counterAxes);\n coerce('x', posDflt[0]);\n coerce('y', posDflt[1]);\n Lib.noneOrAll(containerIn, containerOut, ['x', 'y']);\n\n coerce('xanchor');\n coerce('yanchor');\n\n Lib.coerceFont(coerce, 'font', layout.font);\n\n var bgColor = coerce('bgcolor');\n coerce('activecolor', Color.contrast(bgColor, constants.lightAmount, constants.darkAmount));\n coerce('bordercolor');\n coerce('borderwidth');\n }\n};\n\nfunction buttonDefaults(buttonIn, buttonOut, selectorOut, opts) {\n var calendar = opts.calendar;\n\n function coerce(attr, dflt) {\n return Lib.coerce(buttonIn, buttonOut, attributes.buttons, attr, dflt);\n }\n\n var visible = coerce('visible');\n\n if(visible) {\n var step = coerce('step');\n if(step !== 'all') {\n if(calendar && calendar !== 'gregorian' && (step === 'month' || step === 'year')) {\n buttonOut.stepmode = 'backward';\n } else {\n coerce('stepmode');\n }\n\n coerce('count');\n }\n\n coerce('label');\n }\n}\n\nfunction getPosDflt(containerOut, layout, counterAxes) {\n var anchoredList = counterAxes.filter(function(ax) {\n return layout[ax].anchor === containerOut._id;\n });\n\n var posY = 0;\n for(var i = 0; i < anchoredList.length; i++) {\n var domain = layout[anchoredList[i]].domain;\n if(domain) posY = Math.max(domain[1], posY);\n }\n\n return [containerOut.domain[0], posY + constants.yPad];\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Registry = require('../../registry');\nvar Plots = require('../../plots/plots');\nvar Color = require('../color');\nvar Drawing = require('../drawing');\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar axisIds = require('../../plots/cartesian/axis_ids');\n\nvar alignmentConstants = require('../../constants/alignment');\nvar LINE_SPACING = alignmentConstants.LINE_SPACING;\nvar FROM_TL = alignmentConstants.FROM_TL;\nvar FROM_BR = alignmentConstants.FROM_BR;\n\nvar constants = require('./constants');\nvar getUpdateObject = require('./get_update_object');\n\nmodule.exports = function draw(gd) {\n var fullLayout = gd._fullLayout;\n\n var selectors = fullLayout._infolayer.selectAll('.rangeselector')\n .data(makeSelectorData(gd), selectorKeyFunc);\n\n selectors.enter().append('g')\n .classed('rangeselector', true);\n\n selectors.exit().remove();\n\n selectors.style({\n cursor: 'pointer',\n 'pointer-events': 'all'\n });\n\n selectors.each(function(d) {\n var selector = d3.select(this);\n var axisLayout = d;\n var selectorLayout = axisLayout.rangeselector;\n\n var buttons = selector.selectAll('g.button')\n .data(Lib.filterVisible(selectorLayout.buttons));\n\n buttons.enter().append('g')\n .classed('button', true);\n\n buttons.exit().remove();\n\n buttons.each(function(d) {\n var button = d3.select(this);\n var update = getUpdateObject(axisLayout, d);\n\n d._isActive = isActive(axisLayout, d, update);\n\n button.call(drawButtonRect, selectorLayout, d);\n button.call(drawButtonText, selectorLayout, d, gd);\n\n button.on('click', function() {\n if(gd._dragged) return;\n\n Registry.call('_guiRelayout', gd, update);\n });\n\n button.on('mouseover', function() {\n d._isHovered = true;\n button.call(drawButtonRect, selectorLayout, d);\n });\n\n button.on('mouseout', function() {\n d._isHovered = false;\n button.call(drawButtonRect, selectorLayout, d);\n });\n });\n\n reposition(gd, buttons, selectorLayout, axisLayout._name, selector);\n });\n};\n\nfunction makeSelectorData(gd) {\n var axes = axisIds.list(gd, 'x', true);\n var data = [];\n\n for(var i = 0; i < axes.length; i++) {\n var axis = axes[i];\n\n if(axis.rangeselector && axis.rangeselector.visible) {\n data.push(axis);\n }\n }\n\n return data;\n}\n\nfunction selectorKeyFunc(d) {\n return d._id;\n}\n\nfunction isActive(axisLayout, opts, update) {\n if(opts.step === 'all') {\n return axisLayout.autorange === true;\n } else {\n var keys = Object.keys(update);\n\n return (\n axisLayout.range[0] === update[keys[0]] &&\n axisLayout.range[1] === update[keys[1]]\n );\n }\n}\n\nfunction drawButtonRect(button, selectorLayout, d) {\n var rect = Lib.ensureSingle(button, 'rect', 'selector-rect', function(s) {\n s.attr('shape-rendering', 'crispEdges');\n });\n\n rect.attr({\n rx: constants.rx,\n ry: constants.ry\n });\n\n rect.call(Color.stroke, selectorLayout.bordercolor)\n .call(Color.fill, getFillColor(selectorLayout, d))\n .style('stroke-width', selectorLayout.borderwidth + 'px');\n}\n\nfunction getFillColor(selectorLayout, d) {\n return (d._isActive || d._isHovered) ?\n selectorLayout.activecolor :\n selectorLayout.bgcolor;\n}\n\nfunction drawButtonText(button, selectorLayout, d, gd) {\n function textLayout(s) {\n svgTextUtils.convertToTspans(s, gd);\n }\n\n var text = Lib.ensureSingle(button, 'text', 'selector-text', function(s) {\n s.attr('text-anchor', 'middle');\n });\n\n text.call(Drawing.font, selectorLayout.font)\n .text(getLabel(d, gd._fullLayout._meta))\n .call(textLayout);\n}\n\nfunction getLabel(opts, _meta) {\n if(opts.label) {\n return _meta ?\n Lib.templateString(opts.label, _meta) :\n opts.label;\n }\n\n if(opts.step === 'all') return 'all';\n\n return opts.count + opts.step.charAt(0);\n}\n\nfunction reposition(gd, buttons, opts, axName, selector) {\n var width = 0;\n var height = 0;\n\n var borderWidth = opts.borderwidth;\n\n buttons.each(function() {\n var button = d3.select(this);\n var text = button.select('.selector-text');\n\n var tHeight = opts.font.size * LINE_SPACING;\n var hEff = Math.max(tHeight * svgTextUtils.lineCount(text), 16) + 3;\n\n height = Math.max(height, hEff);\n });\n\n buttons.each(function() {\n var button = d3.select(this);\n var rect = button.select('.selector-rect');\n var text = button.select('.selector-text');\n\n var tWidth = text.node() && Drawing.bBox(text.node()).width;\n var tHeight = opts.font.size * LINE_SPACING;\n var tLines = svgTextUtils.lineCount(text);\n\n var wEff = Math.max(tWidth + 10, constants.minButtonWidth);\n\n // TODO add MathJax support\n\n // TODO add buttongap attribute\n\n button.attr('transform', strTranslate(borderWidth + width, borderWidth));\n\n rect.attr({\n x: 0,\n y: 0,\n width: wEff,\n height: height\n });\n\n svgTextUtils.positionText(text, wEff / 2,\n height / 2 - ((tLines - 1) * tHeight / 2) + 3);\n\n width += wEff + 5;\n });\n\n var graphSize = gd._fullLayout._size;\n var lx = graphSize.l + graphSize.w * opts.x;\n var ly = graphSize.t + graphSize.h * (1 - opts.y);\n\n var xanchor = 'left';\n if(Lib.isRightAnchor(opts)) {\n lx -= width;\n xanchor = 'right';\n }\n if(Lib.isCenterAnchor(opts)) {\n lx -= width / 2;\n xanchor = 'center';\n }\n\n var yanchor = 'top';\n if(Lib.isBottomAnchor(opts)) {\n ly -= height;\n yanchor = 'bottom';\n }\n if(Lib.isMiddleAnchor(opts)) {\n ly -= height / 2;\n yanchor = 'middle';\n }\n\n width = Math.ceil(width);\n height = Math.ceil(height);\n lx = Math.round(lx);\n ly = Math.round(ly);\n\n Plots.autoMargin(gd, axName + '-range-selector', {\n x: opts.x,\n y: opts.y,\n l: width * FROM_TL[xanchor],\n r: width * FROM_BR[xanchor],\n b: height * FROM_BR[yanchor],\n t: height * FROM_TL[yanchor]\n });\n\n selector.attr('transform', strTranslate(lx, ly));\n}\n","'use strict';\n\nvar d3Time = require('d3-time');\nvar titleCase = require('../../lib').titleCase;\n\nmodule.exports = function getUpdateObject(axisLayout, buttonLayout) {\n var axName = axisLayout._name;\n var update = {};\n\n if(buttonLayout.step === 'all') {\n update[axName + '.autorange'] = true;\n } else {\n var xrange = getXRange(axisLayout, buttonLayout);\n\n update[axName + '.range[0]'] = xrange[0];\n update[axName + '.range[1]'] = xrange[1];\n }\n\n return update;\n};\n\nfunction getXRange(axisLayout, buttonLayout) {\n var currentRange = axisLayout.range;\n var base = new Date(axisLayout.r2l(currentRange[1]));\n var step = buttonLayout.step;\n\n var utcStep = d3Time['utc' + titleCase(step)];\n\n var count = buttonLayout.count;\n var range0;\n\n switch(buttonLayout.stepmode) {\n case 'backward':\n range0 = axisLayout.l2r(+utcStep.offset(base, -count));\n break;\n\n case 'todate':\n var base2 = utcStep.offset(base, -count);\n\n range0 = axisLayout.l2r(+utcStep.ceil(base2));\n break;\n }\n\n var range1 = currentRange[1];\n\n return [range0, range1];\n}\n","'use strict';\n\nmodule.exports = {\n moduleType: 'component',\n name: 'rangeselector',\n\n schema: {\n subplots: {\n xaxis: {rangeselector: require('./attributes')}\n }\n },\n\n layoutAttributes: require('./attributes'),\n handleDefaults: require('./defaults'),\n\n draw: require('./draw')\n};\n","'use strict';\n\nvar colorAttributes = require('../color/attributes');\n\nmodule.exports = {\n bgcolor: {\n valType: 'color',\n dflt: colorAttributes.background,\n editType: 'plot',\n description: 'Sets the background color of the range slider.'\n },\n bordercolor: {\n valType: 'color',\n dflt: colorAttributes.defaultLine,\n editType: 'plot',\n description: 'Sets the border color of the range slider.'\n },\n borderwidth: {\n valType: 'integer',\n dflt: 0,\n min: 0,\n editType: 'plot',\n description: 'Sets the border width of the range slider.'\n },\n autorange: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n impliedEdits: {'range[0]': undefined, 'range[1]': undefined},\n description: [\n 'Determines whether or not the range slider range is',\n 'computed in relation to the input data.',\n 'If `range` is provided, then `autorange` is set to *false*.'\n ].join(' ')\n },\n range: {\n valType: 'info_array',\n items: [\n {valType: 'any', editType: 'calc', impliedEdits: {'^autorange': false}},\n {valType: 'any', editType: 'calc', impliedEdits: {'^autorange': false}}\n ],\n editType: 'calc',\n impliedEdits: {autorange: false},\n description: [\n 'Sets the range of the range slider.',\n 'If not set, defaults to the full xaxis range.',\n 'If the axis `type` is *log*, then you must take the',\n 'log of your desired range.',\n 'If the axis `type` is *date*, it should be date strings,',\n 'like date data, though Date objects and unix milliseconds',\n 'will be accepted and converted to strings.',\n 'If the axis `type` is *category*, it should be numbers,',\n 'using the scale where each category is assigned a serial',\n 'number from zero in the order it appears.'\n ].join(' ')\n },\n thickness: {\n valType: 'number',\n dflt: 0.15,\n min: 0,\n max: 1,\n editType: 'plot',\n description: [\n 'The height of the range slider as a fraction of the',\n 'total plot area height.'\n ].join(' ')\n },\n visible: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether or not the range slider will be visible.',\n 'If visible, perpendicular axes will be set to `fixedrange`'\n ].join(' ')\n },\n editType: 'calc'\n};\n","'use strict';\n\nvar listAxes = require('../../plots/cartesian/axis_ids').list;\nvar getAutoRange = require('../../plots/cartesian/autorange').getAutoRange;\nvar constants = require('./constants');\n\nmodule.exports = function calcAutorange(gd) {\n var axes = listAxes(gd, 'x', true);\n\n // Compute new slider range using axis autorange if necessary.\n //\n // Copy back range to input range slider container to skip\n // this step in subsequent draw calls.\n\n for(var i = 0; i < axes.length; i++) {\n var ax = axes[i];\n var opts = ax[constants.name];\n\n if(opts && opts.visible && opts.autorange) {\n opts._input.autorange = true;\n opts._input.range = opts.range = getAutoRange(gd, ax);\n }\n }\n};\n","'use strict';\n\nmodule.exports = {\n\n // attribute container name\n name: 'rangeslider',\n\n // class names\n\n containerClassName: 'rangeslider-container',\n bgClassName: 'rangeslider-bg',\n rangePlotClassName: 'rangeslider-rangeplot',\n\n maskMinClassName: 'rangeslider-mask-min',\n maskMaxClassName: 'rangeslider-mask-max',\n slideBoxClassName: 'rangeslider-slidebox',\n\n grabberMinClassName: 'rangeslider-grabber-min',\n grabAreaMinClassName: 'rangeslider-grabarea-min',\n handleMinClassName: 'rangeslider-handle-min',\n\n grabberMaxClassName: 'rangeslider-grabber-max',\n grabAreaMaxClassName: 'rangeslider-grabarea-max',\n handleMaxClassName: 'rangeslider-handle-max',\n\n maskMinOppAxisClassName: 'rangeslider-mask-min-opp-axis',\n maskMaxOppAxisClassName: 'rangeslider-mask-max-opp-axis',\n\n // style constants\n\n maskColor: 'rgba(0,0,0,0.4)',\n maskOppAxisColor: 'rgba(0,0,0,0.2)',\n\n slideBoxFill: 'transparent',\n slideBoxCursor: 'ew-resize',\n\n grabAreaFill: 'transparent',\n grabAreaCursor: 'col-resize',\n grabAreaWidth: 10,\n\n handleWidth: 4,\n handleRadius: 1,\n handleStrokeWidth: 1,\n\n extraPad: 15\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Template = require('../../plot_api/plot_template');\nvar axisIds = require('../../plots/cartesian/axis_ids');\n\nvar attributes = require('./attributes');\nvar oppAxisAttrs = require('./oppaxis_attributes');\n\nmodule.exports = function handleDefaults(layoutIn, layoutOut, axName) {\n var axIn = layoutIn[axName];\n var axOut = layoutOut[axName];\n\n if(!(axIn.rangeslider || layoutOut._requestRangeslider[axOut._id])) return;\n\n // not super proud of this (maybe store _ in axis object instead\n if(!Lib.isPlainObject(axIn.rangeslider)) {\n axIn.rangeslider = {};\n }\n\n var containerIn = axIn.rangeslider;\n var containerOut = Template.newContainer(axOut, 'rangeslider');\n\n function coerce(attr, dflt) {\n return Lib.coerce(containerIn, containerOut, attributes, attr, dflt);\n }\n\n var rangeContainerIn, rangeContainerOut;\n function coerceRange(attr, dflt) {\n return Lib.coerce(rangeContainerIn, rangeContainerOut, oppAxisAttrs, attr, dflt);\n }\n\n var visible = coerce('visible');\n if(!visible) return;\n\n coerce('bgcolor', layoutOut.plot_bgcolor);\n coerce('bordercolor');\n coerce('borderwidth');\n coerce('thickness');\n\n coerce('autorange', !axOut.isValidRange(containerIn.range));\n coerce('range');\n\n var subplots = layoutOut._subplots;\n if(subplots) {\n var yIds = subplots.cartesian\n .filter(function(subplotId) {\n return subplotId.substr(0, subplotId.indexOf('y')) === axisIds.name2id(axName);\n })\n .map(function(subplotId) {\n return subplotId.substr(subplotId.indexOf('y'), subplotId.length);\n });\n var yNames = Lib.simpleMap(yIds, axisIds.id2name);\n for(var i = 0; i < yNames.length; i++) {\n var yName = yNames[i];\n\n rangeContainerIn = containerIn[yName] || {};\n rangeContainerOut = Template.newContainer(containerOut, yName, 'yaxis');\n\n var yAxOut = layoutOut[yName];\n\n var rangemodeDflt;\n if(rangeContainerIn.range && yAxOut.isValidRange(rangeContainerIn.range)) {\n rangemodeDflt = 'fixed';\n }\n\n var rangeMode = coerceRange('rangemode', rangemodeDflt);\n if(rangeMode !== 'match') {\n coerceRange('range', yAxOut.range.slice());\n }\n }\n }\n\n // to map back range slider (auto) range\n containerOut._input = containerIn;\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Registry = require('../../registry');\nvar Plots = require('../../plots/plots');\n\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar Drawing = require('../drawing');\nvar Color = require('../color');\nvar Titles = require('../titles');\n\nvar Cartesian = require('../../plots/cartesian');\nvar axisIDs = require('../../plots/cartesian/axis_ids');\n\nvar dragElement = require('../dragelement');\nvar setCursor = require('../../lib/setcursor');\n\nvar constants = require('./constants');\n\nmodule.exports = function(gd) {\n var fullLayout = gd._fullLayout;\n var rangeSliderData = fullLayout._rangeSliderData;\n for(var i = 0; i < rangeSliderData.length; i++) {\n var opts = rangeSliderData[i][constants.name];\n // fullLayout._uid may not exist when we call makeData\n opts._clipId = opts._id + '-' + fullLayout._uid;\n }\n\n /*\n * \n * \n * < .... range plot />\n * \n * \n * \n * \n * \n * \n * \n * \n * \n *\n * ...\n */\n\n function keyFunction(axisOpts) {\n return axisOpts._name;\n }\n\n var rangeSliders = fullLayout._infolayer\n .selectAll('g.' + constants.containerClassName)\n .data(rangeSliderData, keyFunction);\n\n // remove exiting sliders and their corresponding clip paths\n rangeSliders.exit().each(function(axisOpts) {\n var opts = axisOpts[constants.name];\n fullLayout._topdefs.select('#' + opts._clipId).remove();\n }).remove();\n\n // return early if no range slider is visible\n if(rangeSliderData.length === 0) return;\n\n rangeSliders.enter().append('g')\n .classed(constants.containerClassName, true)\n .attr('pointer-events', 'all');\n\n // for all present range sliders\n rangeSliders.each(function(axisOpts) {\n var rangeSlider = d3.select(this);\n var opts = axisOpts[constants.name];\n var oppAxisOpts = fullLayout[axisIDs.id2name(axisOpts.anchor)];\n var oppAxisRangeOpts = opts[axisIDs.id2name(axisOpts.anchor)];\n\n // update range\n // Expand slider range to the axis range\n if(opts.range) {\n var rng = Lib.simpleMap(opts.range, axisOpts.r2l);\n var axRng = Lib.simpleMap(axisOpts.range, axisOpts.r2l);\n var newRng;\n\n if(axRng[0] < axRng[1]) {\n newRng = [\n Math.min(rng[0], axRng[0]),\n Math.max(rng[1], axRng[1])\n ];\n } else {\n newRng = [\n Math.max(rng[0], axRng[0]),\n Math.min(rng[1], axRng[1])\n ];\n }\n\n opts.range = opts._input.range = Lib.simpleMap(newRng, axisOpts.l2r);\n }\n\n axisOpts.cleanRange('rangeslider.range');\n\n // update range slider dimensions\n\n var gs = fullLayout._size;\n var domain = axisOpts.domain;\n\n opts._width = gs.w * (domain[1] - domain[0]);\n\n var x = Math.round(gs.l + (gs.w * domain[0]));\n\n var y = Math.round(\n gs.t + gs.h * (1 - axisOpts._counterDomainMin) +\n (axisOpts.side === 'bottom' ? axisOpts._depth : 0) +\n opts._offsetShift + constants.extraPad\n );\n\n rangeSlider.attr('transform', strTranslate(x, y));\n\n // update data <--> pixel coordinate conversion methods\n\n opts._rl = Lib.simpleMap(opts.range, axisOpts.r2l);\n var rl0 = opts._rl[0];\n var rl1 = opts._rl[1];\n var drl = rl1 - rl0;\n\n opts.p2d = function(v) {\n return (v / opts._width) * drl + rl0;\n };\n\n opts.d2p = function(v) {\n return (v - rl0) / drl * opts._width;\n };\n\n if(axisOpts.rangebreaks) {\n var rsBreaks = axisOpts.locateBreaks(rl0, rl1);\n\n if(rsBreaks.length) {\n var j, brk;\n\n var lBreaks = 0;\n for(j = 0; j < rsBreaks.length; j++) {\n brk = rsBreaks[j];\n lBreaks += (brk.max - brk.min);\n }\n\n // TODO fix for reversed-range axes !!!\n\n // compute slope and piecewise offsets\n var m2 = opts._width / (rl1 - rl0 - lBreaks);\n var _B = [-m2 * rl0];\n for(j = 0; j < rsBreaks.length; j++) {\n brk = rsBreaks[j];\n _B.push(_B[_B.length - 1] - m2 * (brk.max - brk.min));\n }\n\n opts.d2p = function(v) {\n var b = _B[0];\n for(var j = 0; j < rsBreaks.length; j++) {\n var brk = rsBreaks[j];\n if(v >= brk.max) b = _B[j + 1];\n else if(v < brk.min) break;\n }\n return b + m2 * v;\n };\n\n // fill pixel (i.e. 'p') min/max here,\n // to not have to loop through the _rangebreaks twice during `p2d`\n for(j = 0; j < rsBreaks.length; j++) {\n brk = rsBreaks[j];\n brk.pmin = opts.d2p(brk.min);\n brk.pmax = opts.d2p(brk.max);\n }\n\n opts.p2d = function(v) {\n var b = _B[0];\n for(var j = 0; j < rsBreaks.length; j++) {\n var brk = rsBreaks[j];\n if(v >= brk.pmax) b = _B[j + 1];\n else if(v < brk.pmin) break;\n }\n return (v - b) / m2;\n };\n }\n }\n\n if(oppAxisRangeOpts.rangemode !== 'match') {\n var range0OppAxis = oppAxisOpts.r2l(oppAxisRangeOpts.range[0]);\n var range1OppAxis = oppAxisOpts.r2l(oppAxisRangeOpts.range[1]);\n var distOppAxis = range1OppAxis - range0OppAxis;\n\n opts.d2pOppAxis = function(v) {\n return (v - range0OppAxis) / distOppAxis * opts._height;\n };\n }\n\n // update inner nodes\n\n rangeSlider\n .call(drawBg, gd, axisOpts, opts)\n .call(addClipPath, gd, axisOpts, opts)\n .call(drawRangePlot, gd, axisOpts, opts)\n .call(drawMasks, gd, axisOpts, opts, oppAxisRangeOpts)\n .call(drawSlideBox, gd, axisOpts, opts)\n .call(drawGrabbers, gd, axisOpts, opts);\n\n // setup drag element\n setupDragElement(rangeSlider, gd, axisOpts, opts);\n\n // update current range\n setPixelRange(rangeSlider, gd, axisOpts, opts, oppAxisOpts, oppAxisRangeOpts);\n\n // title goes next to range slider instead of tick labels, so\n // just take it over and draw it from here\n if(axisOpts.side === 'bottom') {\n Titles.draw(gd, axisOpts._id + 'title', {\n propContainer: axisOpts,\n propName: axisOpts._name + '.title',\n placeholder: fullLayout._dfltTitle.x,\n attributes: {\n x: axisOpts._offset + axisOpts._length / 2,\n y: y + opts._height + opts._offsetShift + 10 + 1.5 * axisOpts.title.font.size,\n 'text-anchor': 'middle'\n }\n });\n }\n });\n};\n\nfunction eventX(event) {\n if(typeof event.clientX === 'number') {\n return event.clientX;\n }\n if(event.touches && event.touches.length > 0) {\n return event.touches[0].clientX;\n }\n return 0;\n}\n\nfunction setupDragElement(rangeSlider, gd, axisOpts, opts) {\n if(gd._context.staticPlot) return;\n\n var slideBox = rangeSlider.select('rect.' + constants.slideBoxClassName).node();\n var grabAreaMin = rangeSlider.select('rect.' + constants.grabAreaMinClassName).node();\n var grabAreaMax = rangeSlider.select('rect.' + constants.grabAreaMaxClassName).node();\n\n function mouseDownHandler() {\n var event = d3.event;\n var target = event.target;\n var startX = eventX(event);\n var offsetX = startX - rangeSlider.node().getBoundingClientRect().left;\n var minVal = opts.d2p(axisOpts._rl[0]);\n var maxVal = opts.d2p(axisOpts._rl[1]);\n\n var dragCover = dragElement.coverSlip();\n\n this.addEventListener('touchmove', mouseMove);\n this.addEventListener('touchend', mouseUp);\n dragCover.addEventListener('mousemove', mouseMove);\n dragCover.addEventListener('mouseup', mouseUp);\n\n function mouseMove(e) {\n var clientX = eventX(e);\n var delta = +clientX - startX;\n var pixelMin, pixelMax, cursor;\n\n switch(target) {\n case slideBox:\n cursor = 'ew-resize';\n if(minVal + delta > axisOpts._length || maxVal + delta < 0) {\n return;\n }\n pixelMin = minVal + delta;\n pixelMax = maxVal + delta;\n break;\n\n case grabAreaMin:\n cursor = 'col-resize';\n if(minVal + delta > axisOpts._length) {\n return;\n }\n pixelMin = minVal + delta;\n pixelMax = maxVal;\n break;\n\n case grabAreaMax:\n cursor = 'col-resize';\n if(maxVal + delta < 0) {\n return;\n }\n pixelMin = minVal;\n pixelMax = maxVal + delta;\n break;\n\n default:\n cursor = 'ew-resize';\n pixelMin = offsetX;\n pixelMax = offsetX + delta;\n break;\n }\n\n if(pixelMax < pixelMin) {\n var tmp = pixelMax;\n pixelMax = pixelMin;\n pixelMin = tmp;\n }\n\n opts._pixelMin = pixelMin;\n opts._pixelMax = pixelMax;\n\n setCursor(d3.select(dragCover), cursor);\n setDataRange(rangeSlider, gd, axisOpts, opts);\n }\n\n function mouseUp() {\n dragCover.removeEventListener('mousemove', mouseMove);\n dragCover.removeEventListener('mouseup', mouseUp);\n this.removeEventListener('touchmove', mouseMove);\n this.removeEventListener('touchend', mouseUp);\n Lib.removeElement(dragCover);\n }\n }\n\n rangeSlider.on('mousedown', mouseDownHandler);\n rangeSlider.on('touchstart', mouseDownHandler);\n}\n\nfunction setDataRange(rangeSlider, gd, axisOpts, opts) {\n function clamp(v) {\n return axisOpts.l2r(Lib.constrain(v, opts._rl[0], opts._rl[1]));\n }\n\n var dataMin = clamp(opts.p2d(opts._pixelMin));\n var dataMax = clamp(opts.p2d(opts._pixelMax));\n\n window.requestAnimationFrame(function() {\n Registry.call('_guiRelayout', gd, axisOpts._name + '.range', [dataMin, dataMax]);\n });\n}\n\nfunction setPixelRange(rangeSlider, gd, axisOpts, opts, oppAxisOpts, oppAxisRangeOpts) {\n var hw2 = constants.handleWidth / 2;\n\n function clamp(v) {\n return Lib.constrain(v, 0, opts._width);\n }\n\n function clampOppAxis(v) {\n return Lib.constrain(v, 0, opts._height);\n }\n\n function clampHandle(v) {\n return Lib.constrain(v, -hw2, opts._width + hw2);\n }\n\n var pixelMin = clamp(opts.d2p(axisOpts._rl[0]));\n var pixelMax = clamp(opts.d2p(axisOpts._rl[1]));\n\n rangeSlider.select('rect.' + constants.slideBoxClassName)\n .attr('x', pixelMin)\n .attr('width', pixelMax - pixelMin);\n\n rangeSlider.select('rect.' + constants.maskMinClassName)\n .attr('width', pixelMin);\n\n rangeSlider.select('rect.' + constants.maskMaxClassName)\n .attr('x', pixelMax)\n .attr('width', opts._width - pixelMax);\n\n if(oppAxisRangeOpts.rangemode !== 'match') {\n var pixelMinOppAxis = opts._height - clampOppAxis(opts.d2pOppAxis(oppAxisOpts._rl[1]));\n var pixelMaxOppAxis = opts._height - clampOppAxis(opts.d2pOppAxis(oppAxisOpts._rl[0]));\n\n rangeSlider.select('rect.' + constants.maskMinOppAxisClassName)\n .attr('x', pixelMin)\n .attr('height', pixelMinOppAxis)\n .attr('width', pixelMax - pixelMin);\n\n rangeSlider.select('rect.' + constants.maskMaxOppAxisClassName)\n .attr('x', pixelMin)\n .attr('y', pixelMaxOppAxis)\n .attr('height', opts._height - pixelMaxOppAxis)\n .attr('width', pixelMax - pixelMin);\n\n rangeSlider.select('rect.' + constants.slideBoxClassName)\n .attr('y', pixelMinOppAxis)\n .attr('height', pixelMaxOppAxis - pixelMinOppAxis);\n }\n\n // add offset for crispier corners\n // https://github.com/plotly/plotly.js/pull/1409\n var offset = 0.5;\n\n var xMin = Math.round(clampHandle(pixelMin - hw2)) - offset;\n var xMax = Math.round(clampHandle(pixelMax - hw2)) + offset;\n\n rangeSlider.select('g.' + constants.grabberMinClassName)\n .attr('transform', strTranslate(xMin, offset));\n\n rangeSlider.select('g.' + constants.grabberMaxClassName)\n .attr('transform', strTranslate(xMax, offset));\n}\n\nfunction drawBg(rangeSlider, gd, axisOpts, opts) {\n var bg = Lib.ensureSingle(rangeSlider, 'rect', constants.bgClassName, function(s) {\n s.attr({\n x: 0,\n y: 0,\n 'shape-rendering': 'crispEdges'\n });\n });\n\n var borderCorrect = (opts.borderwidth % 2) === 0 ?\n opts.borderwidth :\n opts.borderwidth - 1;\n\n var offsetShift = -opts._offsetShift;\n var lw = Drawing.crispRound(gd, opts.borderwidth);\n\n bg.attr({\n width: opts._width + borderCorrect,\n height: opts._height + borderCorrect,\n transform: strTranslate(offsetShift, offsetShift),\n 'stroke-width': lw\n })\n .call(Color.stroke, opts.bordercolor)\n .call(Color.fill, opts.bgcolor);\n}\n\nfunction addClipPath(rangeSlider, gd, axisOpts, opts) {\n var fullLayout = gd._fullLayout;\n\n var clipPath = Lib.ensureSingleById(fullLayout._topdefs, 'clipPath', opts._clipId, function(s) {\n s.append('rect').attr({ x: 0, y: 0 });\n });\n\n clipPath.select('rect').attr({\n width: opts._width,\n height: opts._height\n });\n}\n\nfunction drawRangePlot(rangeSlider, gd, axisOpts, opts) {\n var calcData = gd.calcdata;\n\n var rangePlots = rangeSlider.selectAll('g.' + constants.rangePlotClassName)\n .data(axisOpts._subplotsWith, Lib.identity);\n\n rangePlots.enter().append('g')\n .attr('class', function(id) { return constants.rangePlotClassName + ' ' + id; })\n .call(Drawing.setClipUrl, opts._clipId, gd);\n\n rangePlots.order();\n\n rangePlots.exit().remove();\n\n var mainplotinfo;\n\n rangePlots.each(function(id, i) {\n var plotgroup = d3.select(this);\n var isMainPlot = (i === 0);\n\n var oppAxisOpts = axisIDs.getFromId(gd, id, 'y');\n var oppAxisName = oppAxisOpts._name;\n var oppAxisRangeOpts = opts[oppAxisName];\n\n var mockFigure = {\n data: [],\n layout: {\n xaxis: {\n type: axisOpts.type,\n domain: [0, 1],\n range: opts.range.slice(),\n calendar: axisOpts.calendar\n },\n width: opts._width,\n height: opts._height,\n margin: { t: 0, b: 0, l: 0, r: 0 }\n },\n _context: gd._context\n };\n\n if(axisOpts.rangebreaks) {\n mockFigure.layout.xaxis.rangebreaks = axisOpts.rangebreaks;\n }\n\n mockFigure.layout[oppAxisName] = {\n type: oppAxisOpts.type,\n domain: [0, 1],\n range: oppAxisRangeOpts.rangemode !== 'match' ? oppAxisRangeOpts.range.slice() : oppAxisOpts.range.slice(),\n calendar: oppAxisOpts.calendar\n };\n\n if(oppAxisOpts.rangebreaks) {\n mockFigure.layout[oppAxisName].rangebreaks = oppAxisOpts.rangebreaks;\n }\n\n Plots.supplyDefaults(mockFigure);\n\n var xa = mockFigure._fullLayout.xaxis;\n var ya = mockFigure._fullLayout[oppAxisName];\n\n xa.clearCalc();\n xa.setScale();\n ya.clearCalc();\n ya.setScale();\n\n var plotinfo = {\n id: id,\n plotgroup: plotgroup,\n xaxis: xa,\n yaxis: ya,\n isRangePlot: true\n };\n\n if(isMainPlot) mainplotinfo = plotinfo;\n else {\n plotinfo.mainplot = 'xy';\n plotinfo.mainplotinfo = mainplotinfo;\n }\n\n Cartesian.rangePlot(gd, plotinfo, filterRangePlotCalcData(calcData, id));\n });\n}\n\nfunction filterRangePlotCalcData(calcData, subplotId) {\n var out = [];\n\n for(var i = 0; i < calcData.length; i++) {\n var calcTrace = calcData[i];\n var trace = calcTrace[0].trace;\n\n if(trace.xaxis + trace.yaxis === subplotId) {\n out.push(calcTrace);\n }\n }\n\n return out;\n}\n\nfunction drawMasks(rangeSlider, gd, axisOpts, opts, oppAxisRangeOpts) {\n var maskMin = Lib.ensureSingle(rangeSlider, 'rect', constants.maskMinClassName, function(s) {\n s.attr({\n x: 0,\n y: 0,\n 'shape-rendering': 'crispEdges'\n });\n });\n\n maskMin\n .attr('height', opts._height)\n .call(Color.fill, constants.maskColor);\n\n var maskMax = Lib.ensureSingle(rangeSlider, 'rect', constants.maskMaxClassName, function(s) {\n s.attr({\n y: 0,\n 'shape-rendering': 'crispEdges'\n });\n });\n\n maskMax\n .attr('height', opts._height)\n .call(Color.fill, constants.maskColor);\n\n // masks used for oppAxis zoom\n if(oppAxisRangeOpts.rangemode !== 'match') {\n var maskMinOppAxis = Lib.ensureSingle(rangeSlider, 'rect', constants.maskMinOppAxisClassName, function(s) {\n s.attr({\n y: 0,\n 'shape-rendering': 'crispEdges'\n });\n });\n\n maskMinOppAxis\n .attr('width', opts._width)\n .call(Color.fill, constants.maskOppAxisColor);\n\n var maskMaxOppAxis = Lib.ensureSingle(rangeSlider, 'rect', constants.maskMaxOppAxisClassName, function(s) {\n s.attr({\n y: 0,\n 'shape-rendering': 'crispEdges'\n });\n });\n\n maskMaxOppAxis\n .attr('width', opts._width)\n .style('border-top', constants.maskOppBorder)\n .call(Color.fill, constants.maskOppAxisColor);\n }\n}\n\nfunction drawSlideBox(rangeSlider, gd, axisOpts, opts) {\n if(gd._context.staticPlot) return;\n\n var slideBox = Lib.ensureSingle(rangeSlider, 'rect', constants.slideBoxClassName, function(s) {\n s.attr({\n y: 0,\n cursor: constants.slideBoxCursor,\n 'shape-rendering': 'crispEdges'\n });\n });\n\n slideBox.attr({\n height: opts._height,\n fill: constants.slideBoxFill\n });\n}\n\nfunction drawGrabbers(rangeSlider, gd, axisOpts, opts) {\n // \n var grabberMin = Lib.ensureSingle(rangeSlider, 'g', constants.grabberMinClassName);\n var grabberMax = Lib.ensureSingle(rangeSlider, 'g', constants.grabberMaxClassName);\n\n // \n var handleFixAttrs = {\n x: 0,\n width: constants.handleWidth,\n rx: constants.handleRadius,\n fill: Color.background,\n stroke: Color.defaultLine,\n 'stroke-width': constants.handleStrokeWidth,\n 'shape-rendering': 'crispEdges'\n };\n var handleDynamicAttrs = {\n y: Math.round(opts._height / 4),\n height: Math.round(opts._height / 2),\n };\n var handleMin = Lib.ensureSingle(grabberMin, 'rect', constants.handleMinClassName, function(s) {\n s.attr(handleFixAttrs);\n });\n handleMin.attr(handleDynamicAttrs);\n\n var handleMax = Lib.ensureSingle(grabberMax, 'rect', constants.handleMaxClassName, function(s) {\n s.attr(handleFixAttrs);\n });\n handleMax.attr(handleDynamicAttrs);\n\n // \n var grabAreaFixAttrs = {\n width: constants.grabAreaWidth,\n x: 0,\n y: 0,\n fill: constants.grabAreaFill,\n cursor: !gd._context.staticPlot ? constants.grabAreaCursor : undefined,\n };\n\n var grabAreaMin = Lib.ensureSingle(grabberMin, 'rect', constants.grabAreaMinClassName, function(s) {\n s.attr(grabAreaFixAttrs);\n });\n grabAreaMin.attr('height', opts._height);\n\n var grabAreaMax = Lib.ensureSingle(grabberMax, 'rect', constants.grabAreaMaxClassName, function(s) {\n s.attr(grabAreaFixAttrs);\n });\n grabAreaMax.attr('height', opts._height);\n}\n","'use strict';\n\nvar axisIDs = require('../../plots/cartesian/axis_ids');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar constants = require('./constants');\nvar LINE_SPACING = require('../../constants/alignment').LINE_SPACING;\nvar name = constants.name;\n\nfunction isVisible(ax) {\n var rangeSlider = ax && ax[name];\n return rangeSlider && rangeSlider.visible;\n}\nexports.isVisible = isVisible;\n\nexports.makeData = function(fullLayout) {\n var axes = axisIDs.list({ _fullLayout: fullLayout }, 'x', true);\n var margin = fullLayout.margin;\n var rangeSliderData = [];\n\n if(!fullLayout._has('gl2d')) {\n for(var i = 0; i < axes.length; i++) {\n var ax = axes[i];\n\n if(isVisible(ax)) {\n rangeSliderData.push(ax);\n\n var opts = ax[name];\n opts._id = name + ax._id;\n opts._height = (fullLayout.height - margin.b - margin.t) * opts.thickness;\n opts._offsetShift = Math.floor(opts.borderwidth / 2);\n }\n }\n }\n\n fullLayout._rangeSliderData = rangeSliderData;\n};\n\nexports.autoMarginOpts = function(gd, ax) {\n var fullLayout = gd._fullLayout;\n var opts = ax[name];\n var axLetter = ax._id.charAt(0);\n\n var bottomDepth = 0;\n var titleHeight = 0;\n if(ax.side === 'bottom') {\n bottomDepth = ax._depth;\n if(ax.title.text !== fullLayout._dfltTitle[axLetter]) {\n // as in rangeslider/draw.js\n titleHeight = 1.5 * ax.title.font.size + 10 + opts._offsetShift;\n // multi-line extra bump\n var extraLines = (ax.title.text.match(svgTextUtils.BR_TAG_ALL) || []).length;\n titleHeight += extraLines * ax.title.font.size * LINE_SPACING;\n }\n }\n\n return {\n x: 0,\n y: ax._counterDomainMin,\n l: 0,\n r: 0,\n t: 0,\n b: opts._height + bottomDepth + Math.max(fullLayout.margin.b, titleHeight),\n pad: constants.extraPad + opts._offsetShift * 2\n };\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar attrs = require('./attributes');\nvar oppAxisAttrs = require('./oppaxis_attributes');\nvar helpers = require('./helpers');\n\nmodule.exports = {\n moduleType: 'component',\n name: 'rangeslider',\n\n schema: {\n subplots: {\n xaxis: {\n rangeslider: Lib.extendFlat({}, attrs, {\n yaxis: oppAxisAttrs\n })\n }\n }\n },\n\n layoutAttributes: require('./attributes'),\n handleDefaults: require('./defaults'),\n calcAutorange: require('./calc_autorange'),\n draw: require('./draw'),\n isVisible: helpers.isVisible,\n makeData: helpers.makeData,\n autoMarginOpts: helpers.autoMarginOpts\n};\n","'use strict';\n\nmodule.exports = {\n // not really a 'subplot' attribute container,\n // but this is the flag we use to denote attributes that\n // support yaxis, yaxis2, yaxis3, ... counters\n _isSubplotObj: true,\n\n rangemode: {\n valType: 'enumerated',\n values: ['auto', 'fixed', 'match'],\n dflt: 'match',\n editType: 'calc',\n description: [\n 'Determines whether or not the range of this axis in',\n 'the rangeslider use the same value than in the main plot',\n 'when zooming in/out.',\n 'If *auto*, the autorange will be used.',\n 'If *fixed*, the `range` is used.',\n 'If *match*, the current range of the corresponding y-axis on the main subplot is used.'\n ].join(' ')\n },\n range: {\n valType: 'info_array',\n items: [\n {valType: 'any', editType: 'plot'},\n {valType: 'any', editType: 'plot'}\n ],\n editType: 'plot',\n description: [\n 'Sets the range of this axis for the rangeslider.'\n ].join(' ')\n },\n editType: 'calc'\n};\n","'use strict';\n\nvar annAttrs = require('../annotations/attributes');\nvar scatterLineAttrs = require('../../traces/scatter/attributes').line;\nvar dash = require('../drawing/attributes').dash;\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\nvar axisPlaceableObjs = require('../../constants/axis_placeable_objects');\n\nmodule.exports = overrideAll(templatedArray('selection', {\n type: {\n valType: 'enumerated',\n values: ['rect', 'path'],\n description: [\n 'Specifies the selection type to be drawn.',\n\n 'If *rect*, a rectangle is drawn linking',\n '(`x0`,`y0`), (`x1`,`y0`), (`x1`,`y1`) and (`x0`,`y1`).',\n\n 'If *path*, draw a custom SVG path using `path`.'\n ].join(' ')\n },\n\n xref: extendFlat({}, annAttrs.xref, {\n description: [\n 'Sets the selection\\'s x coordinate axis.',\n axisPlaceableObjs.axisRefDescription('x', 'left', 'right')\n ].join(' ')\n }),\n\n yref: extendFlat({}, annAttrs.yref, {\n description: [\n 'Sets the selection\\'s x coordinate axis.',\n axisPlaceableObjs.axisRefDescription('y', 'bottom', 'top')\n ].join(' ')\n }),\n\n x0: {\n valType: 'any',\n description: 'Sets the selection\\'s starting x position.'\n },\n x1: {\n valType: 'any',\n description: 'Sets the selection\\'s end x position.'\n },\n\n y0: {\n valType: 'any',\n description: 'Sets the selection\\'s starting y position.'\n },\n y1: {\n valType: 'any',\n description: 'Sets the selection\\'s end y position.'\n },\n\n path: {\n valType: 'string',\n editType: 'arraydraw',\n description: [\n 'For `type` *path* - a valid SVG path similar to `shapes.path` in data coordinates.',\n 'Allowed segments are: M, L and Z.'\n ].join(' ')\n },\n\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0.7,\n editType: 'arraydraw',\n description: 'Sets the opacity of the selection.'\n },\n\n line: {\n color: scatterLineAttrs.color,\n width: extendFlat({}, scatterLineAttrs.width, {\n min: 1,\n dflt: 1\n }),\n dash: extendFlat({}, dash, {\n dflt: 'dot'\n })\n },\n}), 'arraydraw', 'from-root');\n","'use strict';\n\nmodule.exports = {\n // max pixels off straight before a lasso select line counts as bent\n BENDPX: 1.5,\n\n // smallest dimension allowed for a select box\n MINSELECT: 12,\n\n // throttling limit (ms) for selectPoints calls\n SELECTDELAY: 100,\n\n // cache ID suffix for throttle\n SELECTID: '-select',\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar attributes = require('./attributes');\nvar helpers = require('../shapes/helpers');\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n handleArrayContainerDefaults(layoutIn, layoutOut, {\n name: 'selections',\n handleItemDefaults: handleSelectionDefaults\n });\n\n // Drop rect selections with undefined x0, y0, x1, x1 values.\n // In future we may accept partially defined rects e.g.\n // a case with only x0 and x1 may be used to define\n // [-Infinity, +Infinity] range on the y axis, etc.\n var selections = layoutOut.selections;\n for(var i = 0; i < selections.length; i++) {\n var selection = selections[i];\n if(!selection) continue;\n if(selection.path === undefined) {\n if(\n selection.x0 === undefined ||\n selection.x1 === undefined ||\n selection.y0 === undefined ||\n selection.y1 === undefined\n ) {\n layoutOut.selections[i] = null;\n }\n }\n }\n};\n\nfunction handleSelectionDefaults(selectionIn, selectionOut, fullLayout) {\n function coerce(attr, dflt) {\n return Lib.coerce(selectionIn, selectionOut, attributes, attr, dflt);\n }\n\n var path = coerce('path');\n var dfltType = path ? 'path' : 'rect';\n var selectionType = coerce('type', dfltType);\n var noPath = selectionType !== 'path';\n if(noPath) delete selectionOut.path;\n\n coerce('opacity');\n coerce('line.color');\n coerce('line.width');\n coerce('line.dash');\n\n // positioning\n var axLetters = ['x', 'y'];\n for(var i = 0; i < 2; i++) {\n var axLetter = axLetters[i];\n var gdMock = {_fullLayout: fullLayout};\n var ax;\n var pos2r;\n var r2pos;\n\n // xref, yref\n var axRef = Axes.coerceRef(selectionIn, selectionOut, gdMock, axLetter);\n\n // axRefType is 'range' for selections\n ax = Axes.getFromId(gdMock, axRef);\n ax._selectionIndices.push(selectionOut._index);\n r2pos = helpers.rangeToShapePosition(ax);\n pos2r = helpers.shapePositionToRange(ax);\n\n // Coerce x0, x1, y0, y1\n if(noPath) {\n // hack until V3.0 when log has regular range behavior - make it look like other\n // ranges to send to coerce, then put it back after\n // this is all to give reasonable default position behavior on log axes, which is\n // a pretty unimportant edge case so we could just ignore this.\n var attr0 = axLetter + '0';\n var attr1 = axLetter + '1';\n var in0 = selectionIn[attr0];\n var in1 = selectionIn[attr1];\n selectionIn[attr0] = pos2r(selectionIn[attr0], true);\n selectionIn[attr1] = pos2r(selectionIn[attr1], true);\n\n Axes.coercePosition(selectionOut, gdMock, coerce, axRef, attr0);\n Axes.coercePosition(selectionOut, gdMock, coerce, axRef, attr1);\n\n var p0 = selectionOut[attr0];\n var p1 = selectionOut[attr1];\n\n if(p0 !== undefined && p1 !== undefined) {\n // hack part 2\n selectionOut[attr0] = r2pos(p0);\n selectionOut[attr1] = r2pos(p1);\n selectionIn[attr0] = in0;\n selectionIn[attr1] = in1;\n }\n }\n }\n\n if(noPath) {\n Lib.noneOrAll(selectionIn, selectionOut, ['x0', 'x1', 'y0', 'y1']);\n }\n}\n","'use strict';\n\nvar readPaths = require('../shapes/draw_newshape/helpers').readPaths;\nvar displayOutlines = require('../shapes/display_outlines');\n\nvar clearOutlineControllers = require('../shapes/handle_outline').clearOutlineControllers;\n\nvar Color = require('../color');\nvar Drawing = require('../drawing');\nvar arrayEditor = require('../../plot_api/plot_template').arrayEditor;\n\nvar helpers = require('../shapes/helpers');\nvar getPathString = helpers.getPathString;\n\n\n// Selections are stored in gd.layout.selections, an array of objects\n// index can point to one item in this array,\n// or non-numeric to simply add a new one\n// or -1 to modify all existing\n// opt can be the full options object, or one key (to be set to value)\n// or undefined to simply redraw\n// if opt is blank, val can be 'add' or a full options object to add a new\n// annotation at that point in the array, or 'remove' to delete this one\n\nmodule.exports = {\n draw: draw,\n drawOne: drawOne,\n activateLastSelection: activateLastSelection\n};\n\nfunction draw(gd) {\n var fullLayout = gd._fullLayout;\n\n clearOutlineControllers(gd);\n\n // Remove previous selections before drawing new selections in fullLayout.selections\n fullLayout._selectionLayer.selectAll('path').remove();\n\n for(var k in fullLayout._plots) {\n var selectionLayer = fullLayout._plots[k].selectionLayer;\n if(selectionLayer) selectionLayer.selectAll('path').remove();\n }\n\n for(var i = 0; i < fullLayout.selections.length; i++) {\n drawOne(gd, i);\n }\n}\n\nfunction couldHaveActiveSelection(gd) {\n return gd._context.editSelection;\n}\n\nfunction drawOne(gd, index) {\n // remove the existing selection if there is one.\n // because indices can change, we need to look in all selection layers\n gd._fullLayout._paperdiv\n .selectAll('.selectionlayer [data-index=\"' + index + '\"]')\n .remove();\n\n var o = helpers.makeSelectionsOptionsAndPlotinfo(gd, index);\n var options = o.options;\n var plotinfo = o.plotinfo;\n\n // this selection is gone - quit now after deleting it\n // TODO: use d3 idioms instead of deleting and redrawing every time\n if(!options._input) return;\n\n drawSelection(gd._fullLayout._selectionLayer);\n\n function drawSelection(selectionLayer) {\n var d = getPathString(gd, options);\n var attrs = {\n 'data-index': index,\n 'fill-rule': 'evenodd',\n d: d\n };\n\n var opacity = options.opacity;\n var fillColor = 'rgba(0,0,0,0)';\n var lineColor = options.line.color || Color.contrast(gd._fullLayout.plot_bgcolor);\n var lineWidth = options.line.width;\n var lineDash = options.line.dash;\n if(!lineWidth) {\n // ensure invisible border to activate the selection\n lineWidth = 5;\n lineDash = 'solid';\n }\n\n var isActiveSelection = couldHaveActiveSelection(gd) &&\n gd._fullLayout._activeSelectionIndex === index;\n\n if(isActiveSelection) {\n fillColor = gd._fullLayout.activeselection.fillcolor;\n opacity = gd._fullLayout.activeselection.opacity;\n }\n\n var allPaths = [];\n for(var sensory = 1; sensory >= 0; sensory--) {\n var path = selectionLayer.append('path')\n .attr(attrs)\n .style('opacity', sensory ? 0.1 : opacity)\n .call(Color.stroke, lineColor)\n .call(Color.fill, fillColor)\n // make it easier to select senory background path\n .call(Drawing.dashLine,\n sensory ? 'solid' : lineDash,\n sensory ? 4 + lineWidth : lineWidth\n );\n\n setClipPath(path, gd, options);\n\n if(isActiveSelection) {\n var editHelpers = arrayEditor(gd.layout, 'selections', options);\n\n path.style({\n cursor: 'move',\n });\n\n var dragOptions = {\n element: path.node(),\n plotinfo: plotinfo,\n gd: gd,\n editHelpers: editHelpers,\n isActiveSelection: true // i.e. to enable controllers\n };\n\n var polygons = readPaths(d, gd);\n // display polygons on the screen\n displayOutlines(polygons, path, dragOptions);\n } else {\n path.style('pointer-events', sensory ? 'all' : 'none');\n }\n\n allPaths[sensory] = path;\n }\n\n var forePath = allPaths[0];\n var backPath = allPaths[1];\n\n backPath.node().addEventListener('click', function() { return activateSelection(gd, forePath); });\n }\n}\n\nfunction setClipPath(selectionPath, gd, selectionOptions) {\n var clipAxes = selectionOptions.xref + selectionOptions.yref;\n\n Drawing.setClipUrl(\n selectionPath,\n 'clip' + gd._fullLayout._uid + clipAxes,\n gd\n );\n}\n\n\nfunction activateSelection(gd, path) {\n if(!couldHaveActiveSelection(gd)) return;\n\n var element = path.node();\n var id = +element.getAttribute('data-index');\n if(id >= 0) {\n // deactivate if already active\n if(id === gd._fullLayout._activeSelectionIndex) {\n deactivateSelection(gd);\n return;\n }\n\n gd._fullLayout._activeSelectionIndex = id;\n gd._fullLayout._deactivateSelection = deactivateSelection;\n draw(gd);\n }\n}\n\nfunction activateLastSelection(gd) {\n if(!couldHaveActiveSelection(gd)) return;\n\n var id = gd._fullLayout.selections.length - 1;\n gd._fullLayout._activeSelectionIndex = id;\n gd._fullLayout._deactivateSelection = deactivateSelection;\n draw(gd);\n}\n\nfunction deactivateSelection(gd) {\n if(!couldHaveActiveSelection(gd)) return;\n\n var id = gd._fullLayout._activeSelectionIndex;\n if(id >= 0) {\n clearOutlineControllers(gd);\n delete gd._fullLayout._activeSelectionIndex;\n draw(gd);\n }\n}\n","'use strict';\n\nvar dash = require('../../drawing/attributes').dash;\nvar extendFlat = require('../../../lib/extend').extendFlat;\n\nmodule.exports = {\n newselection: {\n mode: {\n valType: 'enumerated',\n values: ['immediate', 'gradual'],\n dflt: 'immediate',\n editType: 'none',\n description: [\n 'Describes how a new selection is created.',\n 'If `immediate`, a new selection is created after first mouse up.',\n 'If `gradual`, a new selection is not created after first mouse.',\n 'By adding to and subtracting from the initial selection,',\n 'this option allows declaring extra outlines of the selection.'\n ].join(' ')\n },\n\n line: {\n color: {\n valType: 'color',\n editType: 'none',\n description: [\n 'Sets the line color.',\n 'By default uses either dark grey or white',\n 'to increase contrast with background color.'\n ].join(' ')\n },\n width: {\n valType: 'number',\n min: 1,\n dflt: 1,\n editType: 'none',\n description: 'Sets the line width (in px).'\n },\n dash: extendFlat({}, dash, {\n dflt: 'dot',\n editType: 'none'\n }),\n editType: 'none'\n },\n\n // no drawdirection here noting that layout.selectdirection is used instead.\n\n editType: 'none'\n },\n\n activeselection: {\n fillcolor: {\n valType: 'color',\n dflt: 'rgba(0,0,0,0)',\n editType: 'none',\n description: 'Sets the color filling the active selection\\' interior.'\n },\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0.5,\n editType: 'none',\n description: 'Sets the opacity of the active selection.'\n },\n editType: 'none'\n }\n};\n","'use strict';\n\nmodule.exports = function supplyDrawNewSelectionDefaults(layoutIn, layoutOut, coerce) {\n coerce('newselection.mode');\n\n var newselectionLineWidth = coerce('newselection.line.width');\n if(newselectionLineWidth) {\n coerce('newselection.line.color');\n coerce('newselection.line.dash');\n }\n\n coerce('activeselection.fillcolor');\n coerce('activeselection.opacity');\n};\n","'use strict';\n\nvar dragHelpers = require('../../dragelement/helpers');\nvar selectMode = dragHelpers.selectMode;\n\nvar handleOutline = require('../../shapes/handle_outline');\nvar clearOutline = handleOutline.clearOutline;\n\nvar helpers = require('../../shapes/draw_newshape/helpers');\nvar readPaths = helpers.readPaths;\nvar writePaths = helpers.writePaths;\nvar fixDatesForPaths = helpers.fixDatesForPaths;\n\nmodule.exports = function newSelections(outlines, dragOptions) {\n if(!outlines.length) return;\n var e = outlines[0][0]; // pick first\n if(!e) return;\n var d = e.getAttribute('d');\n\n var gd = dragOptions.gd;\n var newStyle = gd._fullLayout.newselection;\n\n var plotinfo = dragOptions.plotinfo;\n var xaxis = plotinfo.xaxis;\n var yaxis = plotinfo.yaxis;\n\n var isActiveSelection = dragOptions.isActiveSelection;\n var dragmode = dragOptions.dragmode;\n\n var selections = (gd.layout || {}).selections || [];\n\n if(!selectMode(dragmode) && isActiveSelection !== undefined) {\n var id = gd._fullLayout._activeSelectionIndex;\n if(id < selections.length) {\n switch(gd._fullLayout.selections[id].type) {\n case 'rect':\n dragmode = 'select';\n break;\n case 'path':\n dragmode = 'lasso';\n break;\n }\n }\n }\n\n var polygons = readPaths(d, gd, plotinfo, isActiveSelection);\n\n var newSelection = {\n xref: xaxis._id,\n yref: yaxis._id,\n\n opacity: newStyle.opacity,\n line: {\n color: newStyle.line.color,\n width: newStyle.line.width,\n dash: newStyle.line.dash\n }\n };\n\n var cell;\n // rect can be in one cell\n // only define cell if there is single cell\n if(polygons.length === 1) cell = polygons[0];\n\n if(\n cell &&\n cell.length === 5 && // ensure we only have 4 corners for a rect\n dragmode === 'select'\n ) {\n newSelection.type = 'rect';\n newSelection.x0 = cell[0][1];\n newSelection.y0 = cell[0][2];\n newSelection.x1 = cell[2][1];\n newSelection.y1 = cell[2][2];\n } else {\n newSelection.type = 'path';\n if(xaxis && yaxis) fixDatesForPaths(polygons, xaxis, yaxis);\n newSelection.path = writePaths(polygons);\n cell = null;\n }\n\n clearOutline(gd);\n\n var editHelpers = dragOptions.editHelpers;\n var modifyItem = (editHelpers || {}).modifyItem;\n\n var allSelections = [];\n for(var q = 0; q < selections.length; q++) {\n var beforeEdit = gd._fullLayout.selections[q];\n if(!beforeEdit) {\n allSelections[q] = beforeEdit;\n continue;\n }\n\n allSelections[q] = beforeEdit._input;\n\n if(\n isActiveSelection !== undefined &&\n q === gd._fullLayout._activeSelectionIndex\n ) {\n var afterEdit = newSelection;\n\n switch(beforeEdit.type) {\n case 'rect':\n modifyItem('x0', afterEdit.x0);\n modifyItem('x1', afterEdit.x1);\n modifyItem('y0', afterEdit.y0);\n modifyItem('y1', afterEdit.y1);\n break;\n\n case 'path':\n modifyItem('path', afterEdit.path);\n break;\n }\n }\n }\n\n if(isActiveSelection === undefined) {\n allSelections.push(newSelection); // add new selection\n return allSelections;\n }\n\n return editHelpers ? editHelpers.getUpdateObj() : {};\n};\n","'use strict';\n\nvar strTranslate = require('../../lib').strTranslate;\n\n// in v3 (once log ranges are fixed),\n// we'll be able to p2r here for all axis types\nfunction p2r(ax, v) {\n switch(ax.type) {\n case 'log':\n return ax.p2d(v);\n case 'date':\n return ax.p2r(v, 0, ax.calendar);\n default:\n return ax.p2r(v);\n }\n}\n\nfunction r2p(ax, v) {\n switch(ax.type) {\n case 'log':\n return ax.d2p(v);\n case 'date':\n return ax.r2p(v, 0, ax.calendar);\n default:\n return ax.r2p(v);\n }\n}\n\nfunction axValue(ax) {\n var index = (ax._id.charAt(0) === 'y') ? 1 : 0;\n return function(v) { return p2r(ax, v[index]); };\n}\n\nfunction getTransform(plotinfo) {\n return strTranslate(\n plotinfo.xaxis._offset,\n plotinfo.yaxis._offset\n );\n}\n\nmodule.exports = {\n p2r: p2r,\n r2p: r2p,\n axValue: axValue,\n getTransform: getTransform\n};\n","'use strict';\n\nvar drawModule = require('./draw');\nvar select = require('./select');\n\nmodule.exports = {\n moduleType: 'component',\n name: 'selections',\n\n layoutAttributes: require('./attributes'),\n supplyLayoutDefaults: require('./defaults'),\n supplyDrawNewSelectionDefaults: require('./draw_newselection/defaults'),\n includeBasePlot: require('../../plots/cartesian/include_components')('selections'),\n\n draw: drawModule.draw,\n drawOne: drawModule.drawOne,\n\n reselect: select.reselect,\n prepSelect: select.prepSelect,\n clearOutline: select.clearOutline,\n clearSelectionsCache: select.clearSelectionsCache,\n selectOnClick: select.selectOnClick\n};\n","'use strict';\n\nvar polybool = require('polybooljs');\nvar pointInPolygon = require('point-in-polygon/nested'); // could we use contains lib/polygon instead?\n\nvar Registry = require('../../registry');\nvar dashStyle = require('../drawing').dashStyle;\nvar Color = require('../color');\nvar Fx = require('../fx');\nvar makeEventData = require('../fx/helpers').makeEventData;\nvar dragHelpers = require('../dragelement/helpers');\nvar freeMode = dragHelpers.freeMode;\nvar rectMode = dragHelpers.rectMode;\nvar drawMode = dragHelpers.drawMode;\nvar openMode = dragHelpers.openMode;\nvar selectMode = dragHelpers.selectMode;\n\nvar shapeHelpers = require('../shapes/helpers');\nvar shapeConstants = require('../shapes/constants');\n\nvar displayOutlines = require('../shapes/display_outlines');\nvar clearOutline = require('../shapes/handle_outline').clearOutline;\n\nvar newShapeHelpers = require('../shapes/draw_newshape/helpers');\nvar handleEllipse = newShapeHelpers.handleEllipse;\nvar readPaths = newShapeHelpers.readPaths;\n\nvar newShapes = require('../shapes/draw_newshape/newshapes').newShapes;\n\nvar newSelections = require('./draw_newselection/newselections');\nvar activateLastSelection = require('./draw').activateLastSelection;\n\nvar Lib = require('../../lib');\nvar ascending = Lib.sorterAsc;\nvar libPolygon = require('../../lib/polygon');\nvar throttle = require('../../lib/throttle');\nvar getFromId = require('../../plots/cartesian/axis_ids').getFromId;\nvar clearGlCanvases = require('../../lib/clear_gl_canvases');\n\nvar redrawReglTraces = require('../../plot_api/subroutines').redrawReglTraces;\n\nvar constants = require('./constants');\nvar MINSELECT = constants.MINSELECT;\n\nvar filteredPolygon = libPolygon.filter;\nvar polygonTester = libPolygon.tester;\n\nvar helpers = require('./helpers');\nvar p2r = helpers.p2r;\nvar axValue = helpers.axValue;\nvar getTransform = helpers.getTransform;\n\nfunction hasSubplot(dragOptions) {\n // N.B. subplot may be falsy e.g zero sankey index!\n return dragOptions.subplot !== undefined;\n}\n\nfunction prepSelect(evt, startX, startY, dragOptions, mode) {\n var isCartesian = !hasSubplot(dragOptions);\n\n var isFreeMode = freeMode(mode);\n var isRectMode = rectMode(mode);\n var isOpenMode = openMode(mode);\n var isDrawMode = drawMode(mode);\n var isSelectMode = selectMode(mode);\n\n var isLine = mode === 'drawline';\n var isEllipse = mode === 'drawcircle';\n var isLineOrEllipse = isLine || isEllipse; // cases with two start & end positions\n\n var gd = dragOptions.gd;\n var fullLayout = gd._fullLayout;\n var immediateSelect = isSelectMode && fullLayout.newselection.mode === 'immediate' &&\n isCartesian; // N.B. only cartesian subplots have persistent selection\n\n var zoomLayer = fullLayout._zoomlayer;\n var dragBBox = dragOptions.element.getBoundingClientRect();\n var plotinfo = dragOptions.plotinfo;\n var transform = getTransform(plotinfo);\n var x0 = startX - dragBBox.left;\n var y0 = startY - dragBBox.top;\n\n fullLayout._calcInverseTransform(gd);\n var transformedCoords = Lib.apply3DTransform(fullLayout._invTransform)(x0, y0);\n x0 = transformedCoords[0];\n y0 = transformedCoords[1];\n var scaleX = fullLayout._invScaleX;\n var scaleY = fullLayout._invScaleY;\n\n var x1 = x0;\n var y1 = y0;\n var path0 = 'M' + x0 + ',' + y0;\n var xAxis = dragOptions.xaxes[0];\n var yAxis = dragOptions.yaxes[0];\n var pw = xAxis._length;\n var ph = yAxis._length;\n\n var subtract = evt.altKey &&\n !(drawMode(mode) && isOpenMode);\n\n var filterPoly, selectionTesters, mergedPolygons, currentPolygon;\n var i, searchInfo, eventData;\n\n coerceSelectionsCache(evt, gd, dragOptions);\n\n if(isFreeMode) {\n filterPoly = filteredPolygon([[x0, y0]], constants.BENDPX);\n }\n\n var outlines = zoomLayer.selectAll('path.select-outline-' + plotinfo.id).data([1]);\n var newStyle = isDrawMode ?\n fullLayout.newshape :\n fullLayout.newselection;\n\n if(isDrawMode) {\n dragOptions.hasText = newStyle.label.text || newStyle.label.texttemplate;\n }\n\n var fillC = (isDrawMode && !isOpenMode) ? newStyle.fillcolor : 'rgba(0,0,0,0)';\n\n var strokeC = newStyle.line.color || (\n isCartesian ?\n Color.contrast(gd._fullLayout.plot_bgcolor) :\n '#7f7f7f' // non-cartesian subplot\n );\n\n outlines.enter()\n .append('path')\n .attr('class', 'select-outline select-outline-' + plotinfo.id)\n .style({\n opacity: isDrawMode ? newStyle.opacity / 2 : 1,\n 'stroke-dasharray': dashStyle(newStyle.line.dash, newStyle.line.width),\n 'stroke-width': newStyle.line.width + 'px',\n 'shape-rendering': 'crispEdges'\n })\n .call(Color.stroke, strokeC)\n .call(Color.fill, fillC)\n .attr('fill-rule', 'evenodd')\n .classed('cursor-move', isDrawMode ? true : false)\n .attr('transform', transform)\n .attr('d', path0 + 'Z');\n\n var corners = zoomLayer.append('path')\n .attr('class', 'zoombox-corners')\n .style({\n fill: Color.background,\n stroke: Color.defaultLine,\n 'stroke-width': 1\n })\n .attr('transform', transform)\n .attr('d', 'M0,0Z');\n\n // create & style group for text label\n if(isDrawMode && dragOptions.hasText) {\n var shapeGroup = zoomLayer.select('.label-temp');\n if(shapeGroup.empty()) {\n shapeGroup = zoomLayer.append('g')\n .classed('label-temp', true)\n .classed('select-outline', true)\n .style({ opacity: 0.8 });\n }\n }\n\n var throttleID = fullLayout._uid + constants.SELECTID;\n var selection = [];\n\n // find the traces to search for selection points\n var searchTraces = determineSearchTraces(gd, dragOptions.xaxes,\n dragOptions.yaxes, dragOptions.subplot);\n\n if(immediateSelect && !evt.shiftKey) {\n dragOptions._clearSubplotSelections = function() {\n if(!isCartesian) return;\n\n var xRef = xAxis._id;\n var yRef = yAxis._id;\n deselectSubplot(gd, xRef, yRef, searchTraces);\n\n var selections = (gd.layout || {}).selections || [];\n var list = [];\n var selectionErased = false;\n for(var q = 0; q < selections.length; q++) {\n var s = fullLayout.selections[q];\n if(\n s.xref !== xRef ||\n s.yref !== yRef\n ) {\n list.push(selections[q]);\n } else {\n selectionErased = true;\n }\n }\n\n if(selectionErased) {\n gd._fullLayout._noEmitSelectedAtStart = true;\n\n Registry.call('_guiRelayout', gd, {\n selections: list\n });\n }\n };\n }\n\n var fillRangeItems = getFillRangeItems(dragOptions);\n\n dragOptions.moveFn = function(dx0, dy0) {\n if(dragOptions._clearSubplotSelections) {\n dragOptions._clearSubplotSelections();\n dragOptions._clearSubplotSelections = undefined;\n }\n\n x1 = Math.max(0, Math.min(pw, scaleX * dx0 + x0));\n y1 = Math.max(0, Math.min(ph, scaleY * dy0 + y0));\n\n var dx = Math.abs(x1 - x0);\n var dy = Math.abs(y1 - y0);\n\n if(isRectMode) {\n var direction;\n var start, end;\n\n if(isSelectMode) {\n var q = fullLayout.selectdirection;\n\n if(q === 'any') {\n if(dy < Math.min(dx * 0.6, MINSELECT)) {\n direction = 'h';\n } else if(dx < Math.min(dy * 0.6, MINSELECT)) {\n direction = 'v';\n } else {\n direction = 'd';\n }\n } else {\n direction = q;\n }\n\n switch(direction) {\n case 'h':\n start = isEllipse ? ph / 2 : 0;\n end = ph;\n break;\n case 'v':\n start = isEllipse ? pw / 2 : 0;\n end = pw;\n break;\n }\n }\n\n if(isDrawMode) {\n switch(fullLayout.newshape.drawdirection) {\n case 'vertical':\n direction = 'h';\n start = isEllipse ? ph / 2 : 0;\n end = ph;\n break;\n case 'horizontal':\n direction = 'v';\n start = isEllipse ? pw / 2 : 0;\n end = pw;\n break;\n case 'ortho':\n if(dx < dy) {\n direction = 'h';\n start = y0;\n end = y1;\n } else {\n direction = 'v';\n start = x0;\n end = x1;\n }\n break;\n default: // i.e. case of 'diagonal'\n direction = 'd';\n }\n }\n\n if(direction === 'h') {\n // horizontal motion\n currentPolygon = isLineOrEllipse ?\n handleEllipse(isEllipse, [x1, start], [x1, end]) : // using x1 instead of x0 allows adjusting the line while drawing\n [[x0, start], [x0, end], [x1, end], [x1, start]]; // make a vertical box\n\n currentPolygon.xmin = isLineOrEllipse ? x1 : Math.min(x0, x1);\n currentPolygon.xmax = isLineOrEllipse ? x1 : Math.max(x0, x1);\n currentPolygon.ymin = Math.min(start, end);\n currentPolygon.ymax = Math.max(start, end);\n // extras to guide users in keeping a straight selection\n corners.attr('d', 'M' + currentPolygon.xmin + ',' + (y0 - MINSELECT) +\n 'h-4v' + (2 * MINSELECT) + 'h4Z' +\n 'M' + (currentPolygon.xmax - 1) + ',' + (y0 - MINSELECT) +\n 'h4v' + (2 * MINSELECT) + 'h-4Z');\n } else if(direction === 'v') {\n // vertical motion\n currentPolygon = isLineOrEllipse ?\n handleEllipse(isEllipse, [start, y1], [end, y1]) : // using y1 instead of y0 allows adjusting the line while drawing\n [[start, y0], [start, y1], [end, y1], [end, y0]]; // make a horizontal box\n\n currentPolygon.xmin = Math.min(start, end);\n currentPolygon.xmax = Math.max(start, end);\n currentPolygon.ymin = isLineOrEllipse ? y1 : Math.min(y0, y1);\n currentPolygon.ymax = isLineOrEllipse ? y1 : Math.max(y0, y1);\n corners.attr('d', 'M' + (x0 - MINSELECT) + ',' + currentPolygon.ymin +\n 'v-4h' + (2 * MINSELECT) + 'v4Z' +\n 'M' + (x0 - MINSELECT) + ',' + (currentPolygon.ymax - 1) +\n 'v4h' + (2 * MINSELECT) + 'v-4Z');\n } else if(direction === 'd') {\n // diagonal motion\n currentPolygon = isLineOrEllipse ?\n handleEllipse(isEllipse, [x0, y0], [x1, y1]) :\n [[x0, y0], [x0, y1], [x1, y1], [x1, y0]];\n\n currentPolygon.xmin = Math.min(x0, x1);\n currentPolygon.xmax = Math.max(x0, x1);\n currentPolygon.ymin = Math.min(y0, y1);\n currentPolygon.ymax = Math.max(y0, y1);\n corners.attr('d', 'M0,0Z');\n }\n } else if(isFreeMode) {\n filterPoly.addPt([x1, y1]);\n currentPolygon = filterPoly.filtered;\n }\n\n // create outline & tester\n if(dragOptions.selectionDefs && dragOptions.selectionDefs.length) {\n mergedPolygons = mergePolygons(dragOptions.mergedPolygons, currentPolygon, subtract);\n\n currentPolygon.subtract = subtract;\n selectionTesters = multiTester(dragOptions.selectionDefs.concat([currentPolygon]));\n } else {\n mergedPolygons = [currentPolygon];\n selectionTesters = polygonTester(currentPolygon);\n }\n\n // display polygons on the screen\n displayOutlines(convertPoly(mergedPolygons, isOpenMode), outlines, dragOptions);\n\n if(isSelectMode) {\n var _res = reselect(gd, false);\n var extraPoints = _res.eventData ? _res.eventData.points.slice() : [];\n\n _res = reselect(gd, false, selectionTesters, searchTraces, dragOptions);\n selectionTesters = _res.selectionTesters;\n eventData = _res.eventData;\n\n var poly;\n if(filterPoly) {\n poly = filterPoly.filtered;\n } else {\n poly = castMultiPolygon(mergedPolygons);\n }\n\n throttle.throttle(\n throttleID,\n constants.SELECTDELAY,\n function() {\n selection = _doSelect(selectionTesters, searchTraces);\n\n var newPoints = selection.slice();\n\n for(var w = 0; w < extraPoints.length; w++) {\n var p = extraPoints[w];\n var found = false;\n for(var u = 0; u < newPoints.length; u++) {\n if(\n newPoints[u].curveNumber === p.curveNumber &&\n newPoints[u].pointNumber === p.pointNumber\n ) {\n found = true;\n break;\n }\n }\n if(!found) newPoints.push(p);\n }\n\n if(newPoints.length) {\n if(!eventData) eventData = {};\n eventData.points = newPoints;\n }\n\n fillRangeItems(eventData, poly);\n\n emitSelecting(gd, eventData);\n }\n );\n }\n };\n\n dragOptions.clickFn = function(numClicks, evt) {\n corners.remove();\n\n if(gd._fullLayout._activeShapeIndex >= 0) {\n gd._fullLayout._deactivateShape(gd);\n return;\n }\n if(isDrawMode) return;\n\n var clickmode = fullLayout.clickmode;\n\n throttle.done(throttleID).then(function() {\n throttle.clear(throttleID);\n if(numClicks === 2) {\n // clear selection on doubleclick\n outlines.remove();\n for(i = 0; i < searchTraces.length; i++) {\n searchInfo = searchTraces[i];\n searchInfo._module.selectPoints(searchInfo, false);\n }\n\n updateSelectedState(gd, searchTraces);\n\n clearSelectionsCache(dragOptions);\n\n emitDeselect(gd);\n\n if(searchTraces.length) {\n var clickedXaxis = searchTraces[0].xaxis;\n var clickedYaxis = searchTraces[0].yaxis;\n\n if(clickedXaxis && clickedYaxis) {\n // drop selections in the clicked subplot\n var subSelections = [];\n var allSelections = gd._fullLayout.selections;\n for(var k = 0; k < allSelections.length; k++) {\n var s = allSelections[k];\n if(!s) continue; // also drop null selections if any\n\n if(\n s.xref !== clickedXaxis._id ||\n s.yref !== clickedYaxis._id\n ) {\n subSelections.push(s);\n }\n }\n\n if(subSelections.length < allSelections.length) {\n gd._fullLayout._noEmitSelectedAtStart = true;\n\n Registry.call('_guiRelayout', gd, {\n selections: subSelections\n });\n }\n }\n }\n } else {\n if(clickmode.indexOf('select') > -1) {\n selectOnClick(evt, gd, dragOptions.xaxes, dragOptions.yaxes,\n dragOptions.subplot, dragOptions, outlines);\n }\n\n if(clickmode === 'event') {\n // TODO: remove in v3 - this was probably never intended to work as it does,\n // but in case anyone depends on it we don't want to break it now.\n // Note that click-to-select introduced pre v3 also emitts proper\n // event data when clickmode is having 'select' in its flag list.\n emitSelected(gd, undefined);\n }\n }\n\n Fx.click(gd, evt, plotinfo.id);\n }).catch(Lib.error);\n };\n\n dragOptions.doneFn = function() {\n corners.remove();\n\n throttle.done(throttleID).then(function() {\n throttle.clear(throttleID);\n\n if(!immediateSelect && currentPolygon && dragOptions.selectionDefs) {\n // save last polygons\n currentPolygon.subtract = subtract;\n dragOptions.selectionDefs.push(currentPolygon);\n\n // we have to keep reference to arrays container\n dragOptions.mergedPolygons.length = 0;\n [].push.apply(dragOptions.mergedPolygons, mergedPolygons);\n }\n\n if(immediateSelect || isDrawMode) {\n clearSelectionsCache(dragOptions, immediateSelect);\n }\n\n if(dragOptions.doneFnCompleted) {\n dragOptions.doneFnCompleted(selection);\n }\n\n if(isSelectMode) {\n emitSelected(gd, eventData);\n }\n }).catch(Lib.error);\n };\n}\n\nfunction selectOnClick(evt, gd, xAxes, yAxes, subplot, dragOptions, polygonOutlines) {\n var hoverData = gd._hoverdata;\n var fullLayout = gd._fullLayout;\n var clickmode = fullLayout.clickmode;\n var sendEvents = clickmode.indexOf('event') > -1;\n var selection = [];\n var searchTraces, searchInfo, currentSelectionDef, selectionTesters, traceSelection;\n var thisTracesSelection, pointOrBinSelected, subtract, eventData, i;\n\n if(isHoverDataSet(hoverData)) {\n coerceSelectionsCache(evt, gd, dragOptions);\n searchTraces = determineSearchTraces(gd, xAxes, yAxes, subplot);\n var clickedPtInfo = extractClickedPtInfo(hoverData, searchTraces);\n var isBinnedTrace = clickedPtInfo.pointNumbers.length > 0;\n\n\n // Note: potentially costly operation isPointOrBinSelected is\n // called as late as possible through the use of an assignment\n // in an if condition.\n if(isBinnedTrace ?\n isOnlyThisBinSelected(searchTraces, clickedPtInfo) :\n isOnlyOnePointSelected(searchTraces) &&\n (pointOrBinSelected = isPointOrBinSelected(clickedPtInfo))) {\n if(polygonOutlines) polygonOutlines.remove();\n for(i = 0; i < searchTraces.length; i++) {\n searchInfo = searchTraces[i];\n searchInfo._module.selectPoints(searchInfo, false);\n }\n\n updateSelectedState(gd, searchTraces);\n\n clearSelectionsCache(dragOptions);\n\n if(sendEvents) {\n emitDeselect(gd);\n }\n } else {\n subtract = evt.shiftKey &&\n (pointOrBinSelected !== undefined ?\n pointOrBinSelected :\n isPointOrBinSelected(clickedPtInfo));\n currentSelectionDef = newPointSelectionDef(clickedPtInfo.pointNumber, clickedPtInfo.searchInfo, subtract);\n\n var allSelectionDefs = dragOptions.selectionDefs.concat([currentSelectionDef]);\n selectionTesters = multiTester(allSelectionDefs, selectionTesters);\n\n for(i = 0; i < searchTraces.length; i++) {\n traceSelection = searchTraces[i]._module.selectPoints(searchTraces[i], selectionTesters);\n thisTracesSelection = fillSelectionItem(traceSelection, searchTraces[i]);\n\n if(selection.length) {\n for(var j = 0; j < thisTracesSelection.length; j++) {\n selection.push(thisTracesSelection[j]);\n }\n } else selection = thisTracesSelection;\n }\n\n eventData = {points: selection};\n updateSelectedState(gd, searchTraces, eventData);\n\n if(currentSelectionDef && dragOptions) {\n dragOptions.selectionDefs.push(currentSelectionDef);\n }\n\n if(polygonOutlines) {\n var polygons = dragOptions.mergedPolygons;\n var isOpenMode = openMode(dragOptions.dragmode);\n\n // display polygons on the screen\n displayOutlines(convertPoly(polygons, isOpenMode), polygonOutlines, dragOptions);\n }\n\n if(sendEvents) {\n emitSelected(gd, eventData);\n }\n }\n }\n}\n\n/**\n * Constructs a new point selection definition object.\n */\nfunction newPointSelectionDef(pointNumber, searchInfo, subtract) {\n return {\n pointNumber: pointNumber,\n searchInfo: searchInfo,\n subtract: !!subtract\n };\n}\n\nfunction isPointSelectionDef(o) {\n return 'pointNumber' in o && 'searchInfo' in o;\n}\n\n/*\n * Constructs a new point number tester.\n */\nfunction newPointNumTester(pointSelectionDef) {\n return {\n xmin: 0,\n xmax: 0,\n ymin: 0,\n ymax: 0,\n pts: [],\n contains: function(pt, omitFirstEdge, pointNumber, searchInfo) {\n var idxWantedTrace = pointSelectionDef.searchInfo.cd[0].trace._expandedIndex;\n var idxActualTrace = searchInfo.cd[0].trace._expandedIndex;\n return idxActualTrace === idxWantedTrace &&\n pointNumber === pointSelectionDef.pointNumber;\n },\n isRect: false,\n degenerate: false,\n subtract: !!pointSelectionDef.subtract\n };\n}\n\n/**\n * Wraps multiple selection testers.\n *\n * @param {Array} list - An array of selection testers.\n *\n * @return a selection tester object with a contains function\n * that can be called to evaluate a point against all wrapped\n * selection testers that were passed in list.\n */\nfunction multiTester(list) {\n if(!list.length) return;\n\n var testers = [];\n var xmin = isPointSelectionDef(list[0]) ? 0 : list[0][0][0];\n var xmax = xmin;\n var ymin = isPointSelectionDef(list[0]) ? 0 : list[0][0][1];\n var ymax = ymin;\n\n for(var i = 0; i < list.length; i++) {\n if(isPointSelectionDef(list[i])) {\n testers.push(newPointNumTester(list[i]));\n } else {\n var tester = polygonTester(list[i]);\n tester.subtract = !!list[i].subtract;\n testers.push(tester);\n\n xmin = Math.min(xmin, tester.xmin);\n xmax = Math.max(xmax, tester.xmax);\n ymin = Math.min(ymin, tester.ymin);\n ymax = Math.max(ymax, tester.ymax);\n }\n }\n\n /**\n * Tests if the given point is within this tester.\n *\n * @param {Array} pt - [0] is the x coordinate, [1] is the y coordinate of the point.\n * @param {*} arg - An optional parameter to pass down to wrapped testers.\n * @param {number} pointNumber - The point number of the point within the underlying data array.\n * @param {number} searchInfo - An object identifying the trace the point is contained in.\n *\n * @return {boolean} true if point is considered to be selected, false otherwise.\n */\n function contains(pt, arg, pointNumber, searchInfo) {\n var contained = false;\n for(var i = 0; i < testers.length; i++) {\n if(testers[i].contains(pt, arg, pointNumber, searchInfo)) {\n // if contained by subtract tester - exclude the point\n contained = !testers[i].subtract;\n }\n }\n\n return contained;\n }\n\n return {\n xmin: xmin,\n xmax: xmax,\n ymin: ymin,\n ymax: ymax,\n pts: [],\n contains: contains,\n isRect: false,\n degenerate: false\n };\n}\n\nfunction coerceSelectionsCache(evt, gd, dragOptions) {\n var fullLayout = gd._fullLayout;\n var plotinfo = dragOptions.plotinfo;\n var dragmode = dragOptions.dragmode;\n\n var selectingOnSameSubplot = (\n fullLayout._lastSelectedSubplot &&\n fullLayout._lastSelectedSubplot === plotinfo.id\n );\n\n var hasModifierKey = (evt.shiftKey || evt.altKey) &&\n !(drawMode(dragmode) && openMode(dragmode));\n\n if(\n selectingOnSameSubplot &&\n hasModifierKey &&\n plotinfo.selection &&\n plotinfo.selection.selectionDefs &&\n !dragOptions.selectionDefs\n ) {\n // take over selection definitions from prev mode, if any\n dragOptions.selectionDefs = plotinfo.selection.selectionDefs;\n dragOptions.mergedPolygons = plotinfo.selection.mergedPolygons;\n } else if(!hasModifierKey || !plotinfo.selection) {\n clearSelectionsCache(dragOptions);\n }\n\n // clear selection outline when selecting a different subplot\n if(!selectingOnSameSubplot) {\n clearOutline(gd);\n fullLayout._lastSelectedSubplot = plotinfo.id;\n }\n}\n\nfunction hasActiveShape(gd) {\n return gd._fullLayout._activeShapeIndex >= 0;\n}\n\nfunction hasActiveSelection(gd) {\n return gd._fullLayout._activeSelectionIndex >= 0;\n}\n\nfunction clearSelectionsCache(dragOptions, immediateSelect) {\n var dragmode = dragOptions.dragmode;\n var plotinfo = dragOptions.plotinfo;\n\n var gd = dragOptions.gd;\n if(hasActiveShape(gd)) {\n gd._fullLayout._deactivateShape(gd);\n }\n if(hasActiveSelection(gd)) {\n gd._fullLayout._deactivateSelection(gd);\n }\n\n var fullLayout = gd._fullLayout;\n var zoomLayer = fullLayout._zoomlayer;\n\n var isDrawMode = drawMode(dragmode);\n var isSelectMode = selectMode(dragmode);\n\n if(isDrawMode || isSelectMode) {\n var outlines = zoomLayer.selectAll('.select-outline-' + plotinfo.id);\n if(outlines && gd._fullLayout._outlining) {\n // add shape\n var shapes;\n if(isDrawMode) {\n shapes = newShapes(outlines, dragOptions);\n }\n if(shapes) {\n Registry.call('_guiRelayout', gd, {\n shapes: shapes\n });\n }\n\n // add selection\n var selections;\n if(\n isSelectMode &&\n !hasSubplot(dragOptions) // only allow cartesian - no maps for now\n ) {\n selections = newSelections(outlines, dragOptions);\n }\n if(selections) {\n gd._fullLayout._noEmitSelectedAtStart = true;\n\n Registry.call('_guiRelayout', gd, {\n selections: selections\n }).then(function() {\n if(immediateSelect) { activateLastSelection(gd); }\n });\n }\n\n gd._fullLayout._outlining = false;\n }\n }\n\n plotinfo.selection = {};\n plotinfo.selection.selectionDefs = dragOptions.selectionDefs = [];\n plotinfo.selection.mergedPolygons = dragOptions.mergedPolygons = [];\n}\n\nfunction getAxId(ax) {\n return ax._id;\n}\n\nfunction determineSearchTraces(gd, xAxes, yAxes, subplot) {\n if(!gd.calcdata) return [];\n\n var searchTraces = [];\n var xAxisIds = xAxes.map(getAxId);\n var yAxisIds = yAxes.map(getAxId);\n var cd, trace, i;\n\n for(i = 0; i < gd.calcdata.length; i++) {\n cd = gd.calcdata[i];\n trace = cd[0].trace;\n\n if(trace.visible !== true || !trace._module || !trace._module.selectPoints) continue;\n\n if(\n hasSubplot({subplot: subplot}) &&\n (trace.subplot === subplot || trace.geo === subplot)\n ) {\n searchTraces.push(createSearchInfo(trace._module, cd, xAxes[0], yAxes[0]));\n } else if(trace.type === 'splom') {\n // FIXME: make sure we don't have more than single axis for splom\n if(trace._xaxes[xAxisIds[0]] && trace._yaxes[yAxisIds[0]]) {\n var info = createSearchInfo(trace._module, cd, xAxes[0], yAxes[0]);\n info.scene = gd._fullLayout._splomScenes[trace.uid];\n searchTraces.push(info);\n }\n } else if(trace.type === 'sankey') {\n var sankeyInfo = createSearchInfo(trace._module, cd, xAxes[0], yAxes[0]);\n searchTraces.push(sankeyInfo);\n } else {\n if(xAxisIds.indexOf(trace.xaxis) === -1 && (!trace._xA || !trace._xA.overlaying)) continue;\n if(yAxisIds.indexOf(trace.yaxis) === -1 && (!trace._yA || !trace._yA.overlaying)) continue;\n\n searchTraces.push(createSearchInfo(trace._module, cd,\n getFromId(gd, trace.xaxis), getFromId(gd, trace.yaxis)));\n }\n }\n\n return searchTraces;\n}\n\nfunction createSearchInfo(module, calcData, xaxis, yaxis) {\n return {\n _module: module,\n cd: calcData,\n xaxis: xaxis,\n yaxis: yaxis\n };\n}\n\nfunction isHoverDataSet(hoverData) {\n return hoverData &&\n Array.isArray(hoverData) &&\n hoverData[0].hoverOnBox !== true;\n}\n\nfunction extractClickedPtInfo(hoverData, searchTraces) {\n var hoverDatum = hoverData[0];\n var pointNumber = -1;\n var pointNumbers = [];\n var searchInfo, i;\n\n for(i = 0; i < searchTraces.length; i++) {\n searchInfo = searchTraces[i];\n if(hoverDatum.fullData._expandedIndex === searchInfo.cd[0].trace._expandedIndex) {\n // Special case for box (and violin)\n if(hoverDatum.hoverOnBox === true) {\n break;\n }\n\n // Hint: in some traces like histogram, one graphical element\n // doesn't correspond to one particular data point, but to\n // bins of data points. Thus, hoverDatum can have a binNumber\n // property instead of pointNumber.\n if(hoverDatum.pointNumber !== undefined) {\n pointNumber = hoverDatum.pointNumber;\n } else if(hoverDatum.binNumber !== undefined) {\n pointNumber = hoverDatum.binNumber;\n pointNumbers = hoverDatum.pointNumbers;\n }\n\n break;\n }\n }\n\n return {\n pointNumber: pointNumber,\n pointNumbers: pointNumbers,\n searchInfo: searchInfo\n };\n}\n\nfunction isPointOrBinSelected(clickedPtInfo) {\n var trace = clickedPtInfo.searchInfo.cd[0].trace;\n var ptNum = clickedPtInfo.pointNumber;\n var ptNums = clickedPtInfo.pointNumbers;\n var ptNumsSet = ptNums.length > 0;\n\n // When pointsNumbers is set (e.g. histogram's binning),\n // it is assumed that when the first point of\n // a bin is selected, all others are as well\n var ptNumToTest = ptNumsSet ? ptNums[0] : ptNum;\n\n // TODO potential performance improvement\n // Primarily we need this function to determine if a click adds\n // or subtracts from a selection.\n // In cases `trace.selectedpoints` is a huge array, indexOf\n // might be slow. One remedy would be to introduce a hash somewhere.\n return trace.selectedpoints ? trace.selectedpoints.indexOf(ptNumToTest) > -1 : false;\n}\n\nfunction isOnlyThisBinSelected(searchTraces, clickedPtInfo) {\n var tracesWithSelectedPts = [];\n var searchInfo, trace, isSameTrace, i;\n\n for(i = 0; i < searchTraces.length; i++) {\n searchInfo = searchTraces[i];\n if(searchInfo.cd[0].trace.selectedpoints && searchInfo.cd[0].trace.selectedpoints.length > 0) {\n tracesWithSelectedPts.push(searchInfo);\n }\n }\n\n if(tracesWithSelectedPts.length === 1) {\n isSameTrace = tracesWithSelectedPts[0] === clickedPtInfo.searchInfo;\n if(isSameTrace) {\n trace = clickedPtInfo.searchInfo.cd[0].trace;\n if(trace.selectedpoints.length === clickedPtInfo.pointNumbers.length) {\n for(i = 0; i < clickedPtInfo.pointNumbers.length; i++) {\n if(trace.selectedpoints.indexOf(clickedPtInfo.pointNumbers[i]) < 0) {\n return false;\n }\n }\n return true;\n }\n }\n }\n\n return false;\n}\n\nfunction isOnlyOnePointSelected(searchTraces) {\n var len = 0;\n var searchInfo, trace, i;\n\n for(i = 0; i < searchTraces.length; i++) {\n searchInfo = searchTraces[i];\n trace = searchInfo.cd[0].trace;\n if(trace.selectedpoints) {\n if(trace.selectedpoints.length > 1) return false;\n\n len += trace.selectedpoints.length;\n if(len > 1) return false;\n }\n }\n\n return len === 1;\n}\n\nfunction updateSelectedState(gd, searchTraces, eventData) {\n var i;\n\n // before anything else, update preGUI if necessary\n for(i = 0; i < searchTraces.length; i++) {\n var fullInputTrace = searchTraces[i].cd[0].trace._fullInput;\n var tracePreGUI = gd._fullLayout._tracePreGUI[fullInputTrace.uid] || {};\n if(tracePreGUI.selectedpoints === undefined) {\n tracePreGUI.selectedpoints = fullInputTrace._input.selectedpoints || null;\n }\n }\n\n var trace;\n if(eventData) {\n var pts = eventData.points || [];\n for(i = 0; i < searchTraces.length; i++) {\n trace = searchTraces[i].cd[0].trace;\n trace._input.selectedpoints = trace._fullInput.selectedpoints = [];\n if(trace._fullInput !== trace) trace.selectedpoints = [];\n }\n\n for(var k = 0; k < pts.length; k++) {\n var pt = pts[k];\n var data = pt.data;\n var fullData = pt.fullData;\n var pointIndex = pt.pointIndex;\n var pointIndices = pt.pointIndices;\n if(pointIndices) {\n [].push.apply(data.selectedpoints, pointIndices);\n if(trace._fullInput !== trace) {\n [].push.apply(fullData.selectedpoints, pointIndices);\n }\n } else {\n data.selectedpoints.push(pointIndex);\n if(trace._fullInput !== trace) {\n fullData.selectedpoints.push(pointIndex);\n }\n }\n }\n } else {\n for(i = 0; i < searchTraces.length; i++) {\n trace = searchTraces[i].cd[0].trace;\n delete trace.selectedpoints;\n delete trace._input.selectedpoints;\n if(trace._fullInput !== trace) {\n delete trace._fullInput.selectedpoints;\n }\n }\n }\n\n updateReglSelectedState(gd, searchTraces);\n}\n\nfunction updateReglSelectedState(gd, searchTraces) {\n var hasRegl = false;\n\n for(var i = 0; i < searchTraces.length; i++) {\n var searchInfo = searchTraces[i];\n var cd = searchInfo.cd;\n\n if(Registry.traceIs(cd[0].trace, 'regl')) {\n hasRegl = true;\n }\n\n var _module = searchInfo._module;\n var fn = _module.styleOnSelect || _module.style;\n if(fn) {\n fn(gd, cd, cd[0].node3);\n if(cd[0].nodeRangePlot3) fn(gd, cd, cd[0].nodeRangePlot3);\n }\n }\n\n if(hasRegl) {\n clearGlCanvases(gd);\n redrawReglTraces(gd);\n }\n}\n\nfunction mergePolygons(list, poly, subtract) {\n var fn = subtract ?\n polybool.difference :\n polybool.union;\n\n var res = fn({\n regions: list\n }, {\n regions: [poly]\n });\n\n var allPolygons = res.regions.reverse();\n\n for(var i = 0; i < allPolygons.length; i++) {\n var polygon = allPolygons[i];\n\n polygon.subtract = getSubtract(polygon, allPolygons.slice(0, i));\n }\n\n return allPolygons;\n}\n\nfunction fillSelectionItem(selection, searchInfo) {\n if(Array.isArray(selection)) {\n var cd = searchInfo.cd;\n var trace = searchInfo.cd[0].trace;\n\n for(var i = 0; i < selection.length; i++) {\n selection[i] = makeEventData(selection[i], trace, cd);\n }\n }\n\n return selection;\n}\n\nfunction convertPoly(polygonsIn, isOpenMode) { // add M and L command to draft positions\n var polygonsOut = [];\n for(var i = 0; i < polygonsIn.length; i++) {\n polygonsOut[i] = [];\n for(var j = 0; j < polygonsIn[i].length; j++) {\n polygonsOut[i][j] = [];\n polygonsOut[i][j][0] = j ? 'L' : 'M';\n for(var k = 0; k < polygonsIn[i][j].length; k++) {\n polygonsOut[i][j].push(\n polygonsIn[i][j][k]\n );\n }\n }\n\n if(!isOpenMode) {\n polygonsOut[i].push([\n 'Z',\n polygonsOut[i][0][1], // initial x\n polygonsOut[i][0][2] // initial y\n ]);\n }\n }\n\n return polygonsOut;\n}\n\nfunction _doSelect(selectionTesters, searchTraces) {\n var allSelections = [];\n\n var thisSelection;\n var traceSelections = [];\n var traceSelection;\n for(var i = 0; i < searchTraces.length; i++) {\n var searchInfo = searchTraces[i];\n\n traceSelection = searchInfo._module.selectPoints(searchInfo, selectionTesters);\n traceSelections.push(traceSelection);\n\n thisSelection = fillSelectionItem(traceSelection, searchInfo);\n\n allSelections = allSelections.concat(thisSelection);\n }\n\n return allSelections;\n}\n\nfunction reselect(gd, mayEmitSelected, selectionTesters, searchTraces, dragOptions) {\n var hadSearchTraces = !!searchTraces;\n var plotinfo, xRef, yRef;\n if(dragOptions) {\n plotinfo = dragOptions.plotinfo;\n xRef = dragOptions.xaxes[0]._id;\n yRef = dragOptions.yaxes[0]._id;\n }\n\n var allSelections = [];\n var allSearchTraces = [];\n\n // select layout.selection polygons\n var layoutPolygons = getLayoutPolygons(gd);\n\n // add draft outline polygons to layoutPolygons\n var fullLayout = gd._fullLayout;\n if(plotinfo) {\n var zoomLayer = fullLayout._zoomlayer;\n var mode = fullLayout.dragmode;\n var isDrawMode = drawMode(mode);\n var isSelectMode = selectMode(mode);\n if(isDrawMode || isSelectMode) {\n var xaxis = getFromId(gd, xRef, 'x');\n var yaxis = getFromId(gd, yRef, 'y');\n if(xaxis && yaxis) {\n var outlines = zoomLayer.selectAll('.select-outline-' + plotinfo.id);\n if(outlines && gd._fullLayout._outlining) {\n if(outlines.length) {\n var e = outlines[0][0]; // pick first\n var d = e.getAttribute('d');\n var outlinePolys = readPaths(d, gd, plotinfo);\n\n var draftPolygons = [];\n for(var u = 0; u < outlinePolys.length; u++) {\n var p = outlinePolys[u];\n var polygon = [];\n for(var t = 0; t < p.length; t++) {\n polygon.push([\n convert(xaxis, p[t][1]),\n convert(yaxis, p[t][2])\n ]);\n }\n\n polygon.xref = xRef;\n polygon.yref = yRef;\n polygon.subtract = getSubtract(polygon, draftPolygons);\n\n draftPolygons.push(polygon);\n }\n\n layoutPolygons = layoutPolygons.concat(draftPolygons);\n }\n }\n }\n }\n }\n\n var subplots = (xRef && yRef) ? [xRef + yRef] :\n fullLayout._subplots.cartesian;\n\n epmtySplomSelectionBatch(gd);\n\n var seenSplom = {};\n\n for(var i = 0; i < subplots.length; i++) {\n var subplot = subplots[i];\n var yAt = subplot.indexOf('y');\n var _xRef = subplot.slice(0, yAt);\n var _yRef = subplot.slice(yAt);\n\n var _selectionTesters = (xRef && yRef) ? selectionTesters : undefined;\n _selectionTesters = addTester(layoutPolygons, _xRef, _yRef, _selectionTesters);\n\n if(_selectionTesters) {\n var _searchTraces = searchTraces;\n if(!hadSearchTraces) {\n var _xA = getFromId(gd, _xRef, 'x');\n var _yA = getFromId(gd, _yRef, 'y');\n\n _searchTraces = determineSearchTraces(\n gd,\n [_xA],\n [_yA],\n subplot\n );\n\n for(var w = 0; w < _searchTraces.length; w++) {\n var s = _searchTraces[w];\n var cd0 = s.cd[0];\n var trace = cd0.trace;\n\n if(s._module.name === 'scattergl' && !cd0.t.xpx) {\n var x = trace.x;\n var y = trace.y;\n var len = trace._length;\n // generate stash for scattergl\n cd0.t.xpx = [];\n cd0.t.ypx = [];\n for(var j = 0; j < len; j++) {\n cd0.t.xpx[j] = _xA.c2p(x[j]);\n cd0.t.ypx[j] = _yA.c2p(y[j]);\n }\n }\n\n if(s._module.name === 'splom') {\n if(!seenSplom[trace.uid]) {\n seenSplom[trace.uid] = true;\n }\n }\n }\n }\n var selection = _doSelect(_selectionTesters, _searchTraces);\n\n allSelections = allSelections.concat(selection);\n allSearchTraces = allSearchTraces.concat(_searchTraces);\n }\n }\n\n var eventData = {points: allSelections};\n updateSelectedState(gd, allSearchTraces, eventData);\n\n var clickmode = fullLayout.clickmode;\n var sendEvents = clickmode.indexOf('event') > -1 && mayEmitSelected;\n\n if(\n !plotinfo && // get called from plot_api & plots\n mayEmitSelected\n ) {\n var activePolygons = getLayoutPolygons(gd, true);\n\n if(activePolygons.length) {\n var xref = activePolygons[0].xref;\n var yref = activePolygons[0].yref;\n if(xref && yref) {\n var poly = castMultiPolygon(activePolygons);\n\n var fillRangeItems = makeFillRangeItems([\n getFromId(gd, xref, 'x'),\n getFromId(gd, yref, 'y')\n ]);\n\n fillRangeItems(eventData, poly);\n }\n }\n\n if(gd._fullLayout._noEmitSelectedAtStart) {\n gd._fullLayout._noEmitSelectedAtStart = false;\n } else {\n if(sendEvents) emitSelected(gd, eventData);\n }\n\n fullLayout._reselect = false;\n }\n\n if(\n !plotinfo && // get called from plot_api & plots\n fullLayout._deselect\n ) {\n var deselect = fullLayout._deselect;\n xRef = deselect.xref;\n yRef = deselect.yref;\n\n if(!subplotSelected(xRef, yRef, allSearchTraces)) {\n deselectSubplot(gd, xRef, yRef, searchTraces);\n }\n\n if(sendEvents) {\n if(eventData.points.length) {\n emitSelected(gd, eventData);\n } else {\n emitDeselect(gd);\n }\n }\n\n fullLayout._deselect = false;\n }\n\n return {\n eventData: eventData,\n selectionTesters: selectionTesters\n };\n}\n\nfunction epmtySplomSelectionBatch(gd) {\n var cd = gd.calcdata;\n if(!cd) return;\n\n for(var i = 0; i < cd.length; i++) {\n var cd0 = cd[i][0];\n var trace = cd0.trace;\n var splomScenes = gd._fullLayout._splomScenes;\n if(splomScenes) {\n var scene = splomScenes[trace.uid];\n if(scene) {\n scene.selectBatch = [];\n }\n }\n }\n}\n\nfunction subplotSelected(xRef, yRef, searchTraces) {\n for(var i = 0; i < searchTraces.length; i++) {\n var s = searchTraces[i];\n if(\n (s.xaxis && s.xaxis._id === xRef) &&\n (s.yaxis && s.yaxis._id === yRef)\n ) {\n return true;\n }\n }\n return false;\n}\n\nfunction deselectSubplot(gd, xRef, yRef, searchTraces) {\n searchTraces = determineSearchTraces(\n gd,\n [getFromId(gd, xRef, 'x')],\n [getFromId(gd, yRef, 'y')],\n xRef + yRef\n );\n\n for(var k = 0; k < searchTraces.length; k++) {\n var searchInfo = searchTraces[k];\n searchInfo._module.selectPoints(searchInfo, false);\n }\n\n updateSelectedState(gd, searchTraces);\n}\n\nfunction addTester(layoutPolygons, xRef, yRef, selectionTesters) {\n var mergedPolygons;\n\n for(var i = 0; i < layoutPolygons.length; i++) {\n var currentPolygon = layoutPolygons[i];\n if(xRef !== currentPolygon.xref || yRef !== currentPolygon.yref) continue;\n\n if(mergedPolygons) {\n var subtract = !!currentPolygon.subtract;\n mergedPolygons = mergePolygons(mergedPolygons, currentPolygon, subtract);\n selectionTesters = multiTester(mergedPolygons);\n } else {\n mergedPolygons = [currentPolygon];\n selectionTesters = polygonTester(currentPolygon);\n }\n }\n\n return selectionTesters;\n}\n\nfunction getLayoutPolygons(gd, onlyActiveOnes) {\n var allPolygons = [];\n\n var fullLayout = gd._fullLayout;\n var allSelections = fullLayout.selections;\n var len = allSelections.length;\n\n for(var i = 0; i < len; i++) {\n if(onlyActiveOnes && i !== fullLayout._activeSelectionIndex) continue;\n\n var selection = allSelections[i];\n if(!selection) continue;\n\n var xref = selection.xref;\n var yref = selection.yref;\n\n var xaxis = getFromId(gd, xref, 'x');\n var yaxis = getFromId(gd, yref, 'y');\n\n var xmin, xmax, ymin, ymax;\n\n var polygon;\n if(selection.type === 'rect') {\n polygon = [];\n\n var x0 = convert(xaxis, selection.x0);\n var x1 = convert(xaxis, selection.x1);\n var y0 = convert(yaxis, selection.y0);\n var y1 = convert(yaxis, selection.y1);\n polygon = [[x0, y0], [x0, y1], [x1, y1], [x1, y0]];\n\n xmin = Math.min(x0, x1);\n xmax = Math.max(x0, x1);\n ymin = Math.min(y0, y1);\n ymax = Math.max(y0, y1);\n\n polygon.xmin = xmin;\n polygon.xmax = xmax;\n polygon.ymin = ymin;\n polygon.ymax = ymax;\n\n polygon.xref = xref;\n polygon.yref = yref;\n\n polygon.subtract = false;\n polygon.isRect = true;\n\n allPolygons.push(polygon);\n } else if(selection.type === 'path') {\n var segments = selection.path.split('Z');\n\n var multiPolygons = [];\n for(var j = 0; j < segments.length; j++) {\n var path = segments[j];\n if(!path) continue;\n path += 'Z';\n\n var allX = shapeHelpers.extractPathCoords(path, shapeConstants.paramIsX, 'raw');\n var allY = shapeHelpers.extractPathCoords(path, shapeConstants.paramIsY, 'raw');\n\n xmin = Infinity;\n xmax = -Infinity;\n ymin = Infinity;\n ymax = -Infinity;\n\n polygon = [];\n\n for(var k = 0; k < allX.length; k++) {\n var x = convert(xaxis, allX[k]);\n var y = convert(yaxis, allY[k]);\n\n polygon.push([x, y]);\n\n xmin = Math.min(x, xmin);\n xmax = Math.max(x, xmax);\n ymin = Math.min(y, ymin);\n ymax = Math.max(y, ymax);\n }\n\n polygon.xmin = xmin;\n polygon.xmax = xmax;\n polygon.ymin = ymin;\n polygon.ymax = ymax;\n\n polygon.xref = xref;\n polygon.yref = yref;\n polygon.subtract = getSubtract(polygon, multiPolygons);\n\n multiPolygons.push(polygon);\n allPolygons.push(polygon);\n }\n }\n }\n\n return allPolygons;\n}\n\nfunction getSubtract(polygon, previousPolygons) {\n var subtract = false;\n for(var i = 0; i < previousPolygons.length; i++) {\n var previousPolygon = previousPolygons[i];\n\n // find out if a point of polygon is inside previous polygons\n for(var k = 0; k < polygon.length; k++) {\n if(pointInPolygon(polygon[k], previousPolygon)) {\n subtract = !subtract;\n break;\n }\n }\n }\n return subtract;\n}\n\nfunction convert(ax, d) {\n if(ax.type === 'date') d = d.replace('_', ' ');\n return ax.type === 'log' ? ax.c2p(d) : ax.r2p(d, null, ax.calendar);\n}\n\nfunction castMultiPolygon(allPolygons) {\n var len = allPolygons.length;\n\n // descibe multi polygons in one polygon\n var p = [];\n for(var i = 0; i < len; i++) {\n var polygon = allPolygons[i];\n p = p.concat(polygon);\n\n // add starting vertex to close\n // which indicates next polygon\n p = p.concat([polygon[0]]);\n }\n\n return computeRectAndRanges(p);\n}\n\nfunction computeRectAndRanges(poly) {\n poly.isRect = poly.length === 5 &&\n poly[0][0] === poly[4][0] &&\n poly[0][1] === poly[4][1] &&\n (\n poly[0][0] === poly[1][0] &&\n poly[2][0] === poly[3][0] &&\n poly[0][1] === poly[3][1] &&\n poly[1][1] === poly[2][1]\n ) ||\n (\n poly[0][1] === poly[1][1] &&\n poly[2][1] === poly[3][1] &&\n poly[0][0] === poly[3][0] &&\n poly[1][0] === poly[2][0]\n );\n\n if(poly.isRect) {\n poly.xmin = Math.min(poly[0][0], poly[2][0]);\n poly.xmax = Math.max(poly[0][0], poly[2][0]);\n poly.ymin = Math.min(poly[0][1], poly[2][1]);\n poly.ymax = Math.max(poly[0][1], poly[2][1]);\n }\n\n return poly;\n}\n\nfunction makeFillRangeItems(allAxes) {\n return function(eventData, poly) {\n var range;\n var lassoPoints;\n\n for(var i = 0; i < allAxes.length; i++) {\n var ax = allAxes[i];\n var id = ax._id;\n var axLetter = id.charAt(0);\n\n if(poly.isRect) {\n if(!range) range = {};\n var min = poly[axLetter + 'min'];\n var max = poly[axLetter + 'max'];\n\n if(min !== undefined && max !== undefined) {\n range[id] = [\n p2r(ax, min),\n p2r(ax, max)\n ].sort(ascending);\n }\n } else {\n if(!lassoPoints) lassoPoints = {};\n lassoPoints[id] = poly.map(axValue(ax));\n }\n }\n\n if(range) {\n eventData.range = range;\n }\n\n if(lassoPoints) {\n eventData.lassoPoints = lassoPoints;\n }\n };\n}\n\nfunction getFillRangeItems(dragOptions) {\n var plotinfo = dragOptions.plotinfo;\n\n return (\n plotinfo.fillRangeItems || // allow subplots (i.e. geo, mapbox, map, sankey) to override fillRangeItems routine\n makeFillRangeItems(dragOptions.xaxes.concat(dragOptions.yaxes))\n );\n}\n\nfunction emitSelecting(gd, eventData) {\n gd.emit('plotly_selecting', eventData);\n}\n\nfunction emitSelected(gd, eventData) {\n if(eventData) {\n eventData.selections = (gd.layout || {}).selections || [];\n }\n\n gd.emit('plotly_selected', eventData);\n}\n\nfunction emitDeselect(gd) {\n gd.emit('plotly_deselect', null);\n}\n\nmodule.exports = {\n reselect: reselect,\n prepSelect: prepSelect,\n clearOutline: clearOutline,\n clearSelectionsCache: clearSelectionsCache,\n selectOnClick: selectOnClick\n};\n","'use strict';\n\nvar annAttrs = require('../annotations/attributes');\nvar fontAttrs = require('../../plots/font_attributes');\nvar scatterLineAttrs = require('../../traces/scatter/attributes').line;\nvar dash = require('../drawing/attributes').dash;\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\nvar axisPlaceableObjs = require('../../constants/axis_placeable_objects');\nvar basePlotAttributes = require('../../plots/attributes');\nvar shapeTexttemplateAttrs = require('../../plots/template_attributes').shapeTexttemplateAttrs;\nvar shapeLabelTexttemplateVars = require('./label_texttemplate');\n\nmodule.exports = templatedArray('shape', {\n visible: extendFlat({}, basePlotAttributes.visible, {\n editType: 'calc+arraydraw',\n description: [\n 'Determines whether or not this shape is visible.',\n 'If *legendonly*, the shape is not drawn,',\n 'but can appear as a legend item',\n '(provided that the legend itself is visible).'\n ].join(' ')\n }),\n\n showlegend: {\n valType: 'boolean',\n dflt: false,\n editType: 'calc+arraydraw',\n description: [\n 'Determines whether or not this',\n 'shape is shown in the legend.'\n ].join(' ')\n },\n\n legend: extendFlat({}, basePlotAttributes.legend, {\n editType: 'calc+arraydraw',\n description: [\n 'Sets the reference to a legend to show this shape in.',\n 'References to these legends are *legend*, *legend2*, *legend3*, etc.',\n 'Settings for these legends are set in the layout, under',\n '`layout.legend`, `layout.legend2`, etc.'\n ].join(' ')\n }),\n\n legendgroup: extendFlat({}, basePlotAttributes.legendgroup, {\n editType: 'calc+arraydraw',\n description: [\n 'Sets the legend group for this shape.',\n 'Traces and shapes part of the same legend group hide/show at the same time',\n 'when toggling legend items.'\n ].join(' ')\n }),\n\n legendgrouptitle: {\n text: extendFlat({}, basePlotAttributes.legendgrouptitle.text, {\n editType: 'calc+arraydraw'\n }),\n font: fontAttrs({\n editType: 'calc+arraydraw',\n description: [\n 'Sets this legend group\\'s title font.'\n ].join(' '),\n }),\n editType: 'calc+arraydraw',\n },\n\n legendrank: extendFlat({}, basePlotAttributes.legendrank, {\n editType: 'calc+arraydraw',\n description: [\n 'Sets the legend rank for this shape.',\n 'Items and groups with smaller ranks are presented on top/left side while',\n 'with *reversed* `legend.traceorder` they are on bottom/right side.',\n 'The default legendrank is 1000,',\n 'so that you can use ranks less than 1000 to place certain items before all unranked items,',\n 'and ranks greater than 1000 to go after all unranked items.',\n 'When having unranked or equal rank items shapes would be displayed after traces',\n 'i.e. according to their order in data and layout.'\n ].join(' ')\n }),\n\n legendwidth: extendFlat({}, basePlotAttributes.legendwidth, {\n editType: 'calc+arraydraw',\n description: 'Sets the width (in px or fraction) of the legend for this shape.',\n }),\n\n type: {\n valType: 'enumerated',\n values: ['circle', 'rect', 'path', 'line'],\n editType: 'calc+arraydraw',\n description: [\n 'Specifies the shape type to be drawn.',\n\n 'If *line*, a line is drawn from (`x0`,`y0`) to (`x1`,`y1`)',\n 'with respect to the axes\\' sizing mode.',\n\n 'If *circle*, a circle is drawn from',\n '((`x0`+`x1`)/2, (`y0`+`y1`)/2))',\n 'with radius',\n '(|(`x0`+`x1`)/2 - `x0`|, |(`y0`+`y1`)/2 -`y0`)|)',\n 'with respect to the axes\\' sizing mode.',\n\n 'If *rect*, a rectangle is drawn linking',\n '(`x0`,`y0`), (`x1`,`y0`), (`x1`,`y1`), (`x0`,`y1`), (`x0`,`y0`)',\n 'with respect to the axes\\' sizing mode.',\n\n 'If *path*, draw a custom SVG path using `path`.',\n 'with respect to the axes\\' sizing mode.'\n ].join(' ')\n },\n\n layer: {\n valType: 'enumerated',\n values: ['below', 'above', 'between'],\n dflt: 'above',\n editType: 'arraydraw',\n description: [\n 'Specifies whether shapes are drawn below gridlines (*below*),',\n 'between gridlines and traces (*between*) or above traces (*above*).'\n ].join(' ')\n },\n\n xref: extendFlat({}, annAttrs.xref, {\n description: [\n 'Sets the shape\\'s x coordinate axis.',\n axisPlaceableObjs.axisRefDescription('x', 'left', 'right')\n ].join(' ')\n }),\n xsizemode: {\n valType: 'enumerated',\n values: ['scaled', 'pixel'],\n dflt: 'scaled',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the shapes\\'s sizing mode along the x axis.',\n 'If set to *scaled*, `x0`, `x1` and x coordinates within `path` refer to',\n 'data values on the x axis or a fraction of the plot area\\'s width',\n '(`xref` set to *paper*).',\n 'If set to *pixel*, `xanchor` specifies the x position in terms',\n 'of data or plot fraction but `x0`, `x1` and x coordinates within `path`',\n 'are pixels relative to `xanchor`. This way, the shape can have',\n 'a fixed width while maintaining a position relative to data or',\n 'plot fraction.'\n ].join(' ')\n },\n xanchor: {\n valType: 'any',\n editType: 'calc+arraydraw',\n description: [\n 'Only relevant in conjunction with `xsizemode` set to *pixel*.',\n 'Specifies the anchor point on the x axis to which `x0`, `x1`',\n 'and x coordinates within `path` are relative to.',\n 'E.g. useful to attach a pixel sized shape to a certain data value.',\n 'No effect when `xsizemode` not set to *pixel*.'\n ].join(' ')\n },\n x0: {\n valType: 'any',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the shape\\'s starting x position.',\n 'See `type` and `xsizemode` for more info.'\n ].join(' ')\n },\n x1: {\n valType: 'any',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the shape\\'s end x position.',\n 'See `type` and `xsizemode` for more info.'\n ].join(' ')\n },\n x0shift: {\n valType: 'number',\n dflt: 0,\n min: -1,\n max: 1,\n editType: 'calc',\n description: [\n 'Shifts `x0` away from the center of the category when `xref` is a *category* or',\n '*multicategory* axis. -0.5 corresponds to the start of the category and 0.5',\n 'corresponds to the end of the category.'\n ].join(' ')\n },\n x1shift: {\n valType: 'number',\n dflt: 0,\n min: -1,\n max: 1,\n editType: 'calc',\n description: [\n 'Shifts `x1` away from the center of the category when `xref` is a *category* or',\n '*multicategory* axis. -0.5 corresponds to the start of the category and 0.5',\n 'corresponds to the end of the category.'\n ].join(' ')\n },\n yref: extendFlat({}, annAttrs.yref, {\n description: [\n 'Sets the shape\\'s y coordinate axis.',\n axisPlaceableObjs.axisRefDescription('y', 'bottom', 'top')\n ].join(' ')\n }),\n ysizemode: {\n valType: 'enumerated',\n values: ['scaled', 'pixel'],\n dflt: 'scaled',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the shapes\\'s sizing mode along the y axis.',\n 'If set to *scaled*, `y0`, `y1` and y coordinates within `path` refer to',\n 'data values on the y axis or a fraction of the plot area\\'s height',\n '(`yref` set to *paper*).',\n 'If set to *pixel*, `yanchor` specifies the y position in terms',\n 'of data or plot fraction but `y0`, `y1` and y coordinates within `path`',\n 'are pixels relative to `yanchor`. This way, the shape can have',\n 'a fixed height while maintaining a position relative to data or',\n 'plot fraction.'\n ].join(' ')\n },\n yanchor: {\n valType: 'any',\n editType: 'calc+arraydraw',\n description: [\n 'Only relevant in conjunction with `ysizemode` set to *pixel*.',\n 'Specifies the anchor point on the y axis to which `y0`, `y1`',\n 'and y coordinates within `path` are relative to.',\n 'E.g. useful to attach a pixel sized shape to a certain data value.',\n 'No effect when `ysizemode` not set to *pixel*.'\n ].join(' ')\n },\n y0: {\n valType: 'any',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the shape\\'s starting y position.',\n 'See `type` and `ysizemode` for more info.'\n ].join(' ')\n },\n y1: {\n valType: 'any',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the shape\\'s end y position.',\n 'See `type` and `ysizemode` for more info.'\n ].join(' ')\n },\n y0shift: {\n valType: 'number',\n dflt: 0,\n min: -1,\n max: 1,\n editType: 'calc',\n description: [\n 'Shifts `y0` away from the center of the category when `yref` is a *category* or',\n '*multicategory* axis. -0.5 corresponds to the start of the category and 0.5',\n 'corresponds to the end of the category.'\n ].join(' ')\n },\n y1shift: {\n valType: 'number',\n dflt: 0,\n min: -1,\n max: 1,\n editType: 'calc',\n description: [\n 'Shifts `y1` away from the center of the category when `yref` is a *category* or',\n '*multicategory* axis. -0.5 corresponds to the start of the category and 0.5',\n 'corresponds to the end of the category.'\n ].join(' ')\n },\n path: {\n valType: 'string',\n editType: 'calc+arraydraw',\n description: [\n 'For `type` *path* - a valid SVG path with the pixel values',\n 'replaced by data values in `xsizemode`/`ysizemode` being *scaled*',\n 'and taken unmodified as pixels relative to `xanchor` and `yanchor`',\n 'in case of *pixel* size mode.',\n 'There are a few restrictions / quirks',\n 'only absolute instructions, not relative. So the allowed segments',\n 'are: M, L, H, V, Q, C, T, S, and Z',\n 'arcs (A) are not allowed because radius rx and ry are relative.',\n\n 'In the future we could consider supporting relative commands,',\n 'but we would have to decide on how to handle date and log axes.',\n 'Note that even as is, Q and C Bezier paths that are smooth on',\n 'linear axes may not be smooth on log, and vice versa.',\n 'no chained \"polybezier\" commands - specify the segment type for',\n 'each one.',\n\n 'On category axes, values are numbers scaled to the serial numbers',\n 'of categories because using the categories themselves there would',\n 'be no way to describe fractional positions',\n 'On data axes: because space and T are both normal components of path',\n 'strings, we can\\'t use either to separate date from time parts.',\n 'Therefore we\\'ll use underscore for this purpose:',\n '2015-02-21_13:45:56.789'\n ].join(' ')\n },\n\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n editType: 'arraydraw',\n description: 'Sets the opacity of the shape.'\n },\n line: {\n color: extendFlat({}, scatterLineAttrs.color, {editType: 'arraydraw'}),\n width: extendFlat({}, scatterLineAttrs.width, {editType: 'calc+arraydraw'}),\n dash: extendFlat({}, dash, {editType: 'arraydraw'}),\n editType: 'calc+arraydraw'\n },\n fillcolor: {\n valType: 'color',\n dflt: 'rgba(0,0,0,0)',\n editType: 'arraydraw',\n description: [\n 'Sets the color filling the shape\\'s interior. Only applies to closed shapes.'\n ].join(' ')\n },\n fillrule: {\n valType: 'enumerated',\n values: ['evenodd', 'nonzero'],\n dflt: 'evenodd',\n editType: 'arraydraw',\n description: [\n 'Determines which regions of complex paths constitute the interior.',\n 'For more info please visit https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/fill-rule'\n ].join(' ')\n },\n editable: {\n valType: 'boolean',\n dflt: false,\n editType: 'calc+arraydraw',\n description: [\n 'Determines whether the shape could be activated for edit or not.',\n 'Has no effect when the older editable shapes mode is enabled via',\n '`config.editable` or `config.edits.shapePosition`.'\n ].join(' ')\n },\n label: {\n text: {\n valType: 'string',\n dflt: '',\n editType: 'arraydraw',\n description: [\n 'Sets the text to display with shape.',\n 'It is also used for legend item if `name` is not provided.'\n ].join(' ')\n },\n texttemplate: shapeTexttemplateAttrs({}, {keys: Object.keys(shapeLabelTexttemplateVars)}),\n font: fontAttrs({\n editType: 'calc+arraydraw',\n colorEditType: 'arraydraw',\n description: 'Sets the shape label text font.'\n }),\n textposition: {\n valType: 'enumerated',\n values: [\n 'top left', 'top center', 'top right',\n 'middle left', 'middle center', 'middle right',\n 'bottom left', 'bottom center', 'bottom right',\n 'start', 'middle', 'end',\n ],\n editType: 'arraydraw',\n description: [\n 'Sets the position of the label text relative to the shape.',\n 'Supported values for rectangles, circles and paths are',\n '*top left*, *top center*, *top right*, *middle left*,',\n '*middle center*, *middle right*, *bottom left*, *bottom center*,',\n 'and *bottom right*.',\n 'Supported values for lines are *start*, *middle*, and *end*.',\n 'Default: *middle center* for rectangles, circles, and paths; *middle* for lines.',\n ].join(' ')\n },\n textangle: {\n valType: 'angle',\n dflt: 'auto',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the angle at which the label text is drawn',\n 'with respect to the horizontal. For lines, angle *auto*',\n 'is the same angle as the line. For all other shapes,',\n 'angle *auto* is horizontal.'\n ].join(' ')\n },\n xanchor: {\n valType: 'enumerated',\n values: ['auto', 'left', 'center', 'right'],\n dflt: 'auto',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the label\\'s horizontal position anchor',\n 'This anchor binds the specified `textposition` to the *left*, *center*',\n 'or *right* of the label text.',\n 'For example, if `textposition` is set to *top right* and',\n '`xanchor` to *right* then the right-most portion of the',\n 'label text lines up with the right-most edge of the',\n 'shape.',\n ].join(' '),\n },\n yanchor: {\n valType: 'enumerated',\n values: ['top', 'middle', 'bottom'],\n editType: 'calc+arraydraw',\n description: [\n 'Sets the label\\'s vertical position anchor',\n 'This anchor binds the specified `textposition` to the *top*, *middle*',\n 'or *bottom* of the label text.',\n 'For example, if `textposition` is set to *top right* and',\n '`yanchor` to *top* then the top-most portion of the',\n 'label text lines up with the top-most edge of the',\n 'shape.',\n ].join(' ')\n },\n padding: {\n valType: 'number',\n dflt: 3,\n min: 0,\n editType: 'arraydraw',\n description: 'Sets padding (in px) between edge of label and edge of shape.'\n },\n editType: 'arraydraw'\n },\n editType: 'arraydraw'\n});\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\n\nvar constants = require('./constants');\nvar helpers = require('./helpers');\n\n\nmodule.exports = function calcAutorange(gd) {\n var fullLayout = gd._fullLayout;\n var shapeList = Lib.filterVisible(fullLayout.shapes);\n\n if(!shapeList.length || !gd._fullData.length) return;\n\n for(var i = 0; i < shapeList.length; i++) {\n var shape = shapeList[i];\n shape._extremes = {};\n\n var ax; var bounds;\n var xRefType = Axes.getRefType(shape.xref);\n var yRefType = Axes.getRefType(shape.yref);\n\n // paper and axis domain referenced shapes don't affect autorange\n if(shape.xref !== 'paper' && xRefType !== 'domain') {\n ax = Axes.getFromId(gd, shape.xref);\n\n bounds = shapeBounds(ax, shape, constants.paramIsX);\n if(bounds) {\n shape._extremes[ax._id] = Axes.findExtremes(ax, bounds, calcXPaddingOptions(shape));\n }\n }\n\n if(shape.yref !== 'paper' && yRefType !== 'domain') {\n ax = Axes.getFromId(gd, shape.yref);\n\n bounds = shapeBounds(ax, shape, constants.paramIsY);\n if(bounds) {\n shape._extremes[ax._id] = Axes.findExtremes(ax, bounds, calcYPaddingOptions(shape));\n }\n }\n }\n};\n\nfunction calcXPaddingOptions(shape) {\n return calcPaddingOptions(shape.line.width, shape.xsizemode, shape.x0, shape.x1, shape.path, false);\n}\n\nfunction calcYPaddingOptions(shape) {\n return calcPaddingOptions(shape.line.width, shape.ysizemode, shape.y0, shape.y1, shape.path, true);\n}\n\nfunction calcPaddingOptions(lineWidth, sizeMode, v0, v1, path, isYAxis) {\n var ppad = lineWidth / 2;\n var axisDirectionReverted = isYAxis;\n\n if(sizeMode === 'pixel') {\n var coords = path ?\n helpers.extractPathCoords(path, isYAxis ? constants.paramIsY : constants.paramIsX) :\n [v0, v1];\n var maxValue = Lib.aggNums(Math.max, null, coords);\n var minValue = Lib.aggNums(Math.min, null, coords);\n var beforePad = minValue < 0 ? Math.abs(minValue) + ppad : ppad;\n var afterPad = maxValue > 0 ? maxValue + ppad : ppad;\n\n return {\n ppad: ppad,\n ppadplus: axisDirectionReverted ? beforePad : afterPad,\n ppadminus: axisDirectionReverted ? afterPad : beforePad\n };\n } else {\n return {ppad: ppad};\n }\n}\n\nfunction shapeBounds(ax, shape, paramsToUse) {\n var dim = ax._id.charAt(0) === 'x' ? 'x' : 'y';\n var isCategory = ax.type === 'category' || ax.type === 'multicategory';\n var v0;\n var v1;\n var shiftStart = 0;\n var shiftEnd = 0;\n\n var convertVal = isCategory ? ax.r2c : ax.d2c;\n\n var isSizeModeScale = shape[dim + 'sizemode'] === 'scaled';\n if(isSizeModeScale) {\n v0 = shape[dim + '0'];\n v1 = shape[dim + '1'];\n if(isCategory) {\n shiftStart = shape[dim + '0shift'];\n shiftEnd = shape[dim + '1shift'];\n }\n } else {\n v0 = shape[dim + 'anchor'];\n v1 = shape[dim + 'anchor'];\n }\n\n if(v0 !== undefined) return [convertVal(v0) + shiftStart, convertVal(v1) + shiftEnd];\n if(!shape.path) return;\n\n var min = Infinity;\n var max = -Infinity;\n var segments = shape.path.match(constants.segmentRE);\n var i;\n var segment;\n var drawnParam;\n var params;\n var val;\n\n if(ax.type === 'date') convertVal = helpers.decodeDate(convertVal);\n\n for(i = 0; i < segments.length; i++) {\n segment = segments[i];\n drawnParam = paramsToUse[segment.charAt(0)].drawn;\n if(drawnParam === undefined) continue;\n\n params = segments[i].substr(1).match(constants.paramRE);\n if(!params || params.length < drawnParam) continue;\n\n val = convertVal(params[drawnParam]);\n if(val < min) min = val;\n if(val > max) max = val;\n }\n if(max >= min) return [min, max];\n}\n","'use strict';\n\n\nmodule.exports = {\n segmentRE: /[MLHVQCTSZ][^MLHVQCTSZ]*/g,\n paramRE: /[^\\s,]+/g,\n\n // which numbers in each path segment are x (or y) values\n // drawn is which param is a drawn point, as opposed to a\n // control point (which doesn't count toward autorange.\n // TODO: this means curved paths could extend beyond the\n // autorange bounds. This is a bit tricky to get right\n // unless we revert to bounding boxes, but perhaps there's\n // a calculation we could do...)\n paramIsX: {\n M: {0: true, drawn: 0},\n L: {0: true, drawn: 0},\n H: {0: true, drawn: 0},\n V: {},\n Q: {0: true, 2: true, drawn: 2},\n C: {0: true, 2: true, 4: true, drawn: 4},\n T: {0: true, drawn: 0},\n S: {0: true, 2: true, drawn: 2},\n // A: {0: true, 5: true},\n Z: {}\n },\n\n paramIsY: {\n M: {1: true, drawn: 1},\n L: {1: true, drawn: 1},\n H: {},\n V: {0: true, drawn: 0},\n Q: {1: true, 3: true, drawn: 3},\n C: {1: true, 3: true, 5: true, drawn: 5},\n T: {1: true, drawn: 1},\n S: {1: true, 3: true, drawn: 5},\n // A: {1: true, 6: true},\n Z: {}\n },\n\n numParams: {\n M: 2,\n L: 2,\n H: 1,\n V: 1,\n Q: 4,\n C: 6,\n T: 2,\n S: 4,\n // A: 7,\n Z: 0\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar attributes = require('./attributes');\nvar helpers = require('./helpers');\n\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n handleArrayContainerDefaults(layoutIn, layoutOut, {\n name: 'shapes',\n handleItemDefaults: handleShapeDefaults\n });\n};\n\nfunction dfltLabelYanchor(isLine, labelTextPosition) {\n // If shape is a line, default y-anchor is 'bottom' (so that text is above line by default)\n // Otherwise, default y-anchor is equal to y-component of `textposition`\n // (so that text is positioned inside shape bounding box by default)\n return isLine ? 'bottom' :\n labelTextPosition.indexOf('top') !== -1 ? 'top' :\n labelTextPosition.indexOf('bottom') !== -1 ? 'bottom' : 'middle';\n}\n\nfunction handleShapeDefaults(shapeIn, shapeOut, fullLayout) {\n function coerce(attr, dflt) {\n return Lib.coerce(shapeIn, shapeOut, attributes, attr, dflt);\n }\n\n shapeOut._isShape = true;\n\n var visible = coerce('visible');\n if(!visible) return;\n\n var showlegend = coerce('showlegend');\n if(showlegend) {\n coerce('legend');\n coerce('legendwidth');\n coerce('legendgroup');\n coerce('legendgrouptitle.text');\n Lib.coerceFont(coerce, 'legendgrouptitle.font');\n coerce('legendrank');\n }\n\n var path = coerce('path');\n var dfltType = path ? 'path' : 'rect';\n var shapeType = coerce('type', dfltType);\n var noPath = shapeType !== 'path';\n if(noPath) delete shapeOut.path;\n\n coerce('editable');\n coerce('layer');\n coerce('opacity');\n coerce('fillcolor');\n coerce('fillrule');\n var lineWidth = coerce('line.width');\n if(lineWidth) {\n coerce('line.color');\n coerce('line.dash');\n }\n\n var xSizeMode = coerce('xsizemode');\n var ySizeMode = coerce('ysizemode');\n\n // positioning\n var axLetters = ['x', 'y'];\n for(var i = 0; i < 2; i++) {\n var axLetter = axLetters[i];\n var attrAnchor = axLetter + 'anchor';\n var sizeMode = axLetter === 'x' ? xSizeMode : ySizeMode;\n var gdMock = {_fullLayout: fullLayout};\n var ax;\n var pos2r;\n var r2pos;\n\n // xref, yref\n var axRef = Axes.coerceRef(shapeIn, shapeOut, gdMock, axLetter, undefined,\n 'paper');\n var axRefType = Axes.getRefType(axRef);\n\n if(axRefType === 'range') {\n ax = Axes.getFromId(gdMock, axRef);\n ax._shapeIndices.push(shapeOut._index);\n r2pos = helpers.rangeToShapePosition(ax);\n pos2r = helpers.shapePositionToRange(ax);\n if(ax.type === 'category' || ax.type === 'multicategory') {\n coerce(axLetter + '0shift');\n coerce(axLetter + '1shift');\n }\n } else {\n pos2r = r2pos = Lib.identity;\n }\n\n // Coerce x0, x1, y0, y1\n if(noPath) {\n var dflt0 = 0.25;\n var dflt1 = 0.75;\n\n // hack until V3.0 when log has regular range behavior - make it look like other\n // ranges to send to coerce, then put it back after\n // this is all to give reasonable default position behavior on log axes, which is\n // a pretty unimportant edge case so we could just ignore this.\n var attr0 = axLetter + '0';\n var attr1 = axLetter + '1';\n var in0 = shapeIn[attr0];\n var in1 = shapeIn[attr1];\n shapeIn[attr0] = pos2r(shapeIn[attr0], true);\n shapeIn[attr1] = pos2r(shapeIn[attr1], true);\n\n if(sizeMode === 'pixel') {\n coerce(attr0, 0);\n coerce(attr1, 10);\n } else {\n Axes.coercePosition(shapeOut, gdMock, coerce, axRef, attr0, dflt0);\n Axes.coercePosition(shapeOut, gdMock, coerce, axRef, attr1, dflt1);\n }\n\n // hack part 2\n shapeOut[attr0] = r2pos(shapeOut[attr0]);\n shapeOut[attr1] = r2pos(shapeOut[attr1]);\n shapeIn[attr0] = in0;\n shapeIn[attr1] = in1;\n }\n\n // Coerce xanchor and yanchor\n if(sizeMode === 'pixel') {\n // Hack for log axis described above\n var inAnchor = shapeIn[attrAnchor];\n shapeIn[attrAnchor] = pos2r(shapeIn[attrAnchor], true);\n\n Axes.coercePosition(shapeOut, gdMock, coerce, axRef, attrAnchor, 0.25);\n\n // Hack part 2\n shapeOut[attrAnchor] = r2pos(shapeOut[attrAnchor]);\n shapeIn[attrAnchor] = inAnchor;\n }\n }\n\n if(noPath) {\n Lib.noneOrAll(shapeIn, shapeOut, ['x0', 'x1', 'y0', 'y1']);\n }\n\n // Label options\n var isLine = shapeType === 'line';\n var labelTextTemplate, labelText;\n if(noPath) { labelTextTemplate = coerce('label.texttemplate'); }\n if(!labelTextTemplate) { labelText = coerce('label.text'); }\n if(labelText || labelTextTemplate) {\n coerce('label.textangle');\n var labelTextPosition = coerce('label.textposition', isLine ? 'middle' : 'middle center');\n coerce('label.xanchor');\n coerce('label.yanchor', dfltLabelYanchor(isLine, labelTextPosition));\n coerce('label.padding');\n Lib.coerceFont(coerce, 'label.font', fullLayout.font);\n }\n}\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar svgTextUtils = require('../../lib/svg_text_utils');\n\nvar Drawing = require('../drawing');\n\nvar readPaths = require('./draw_newshape/helpers').readPaths;\nvar helpers = require('./helpers');\nvar getPathString = helpers.getPathString;\nvar shapeLabelTexttemplateVars = require('./label_texttemplate');\n\nvar FROM_TL = require('../../constants/alignment').FROM_TL;\n\n\nmodule.exports = function drawLabel(gd, index, options, shapeGroup) {\n // Remove existing label\n shapeGroup.selectAll('.shape-label').remove();\n\n // If no label text or texttemplate, return\n if(!(options.label.text || options.label.texttemplate)) return;\n\n // Text template overrides text\n var text;\n if(options.label.texttemplate) {\n var templateValues = {};\n if(options.type !== 'path') {\n var _xa = Axes.getFromId(gd, options.xref);\n var _ya = Axes.getFromId(gd, options.yref);\n for(var key in shapeLabelTexttemplateVars) {\n var val = shapeLabelTexttemplateVars[key](options, _xa, _ya);\n if(val !== undefined) templateValues[key] = val;\n }\n }\n text = Lib.texttemplateStringForShapes(options.label.texttemplate,\n {},\n gd._fullLayout._d3locale,\n templateValues);\n } else {\n text = options.label.text;\n }\n\n var labelGroupAttrs = {\n 'data-index': index,\n };\n var font = options.label.font;\n\n var labelTextAttrs = {\n 'data-notex': 1\n };\n\n var labelGroup = shapeGroup.append('g')\n .attr(labelGroupAttrs)\n .classed('shape-label', true);\n var labelText = labelGroup.append('text')\n .attr(labelTextAttrs)\n .classed('shape-label-text', true)\n .text(text);\n\n // Get x and y bounds of shape\n var shapex0, shapex1, shapey0, shapey1;\n if(options.path) {\n // If shape is defined as a path, get the\n // min and max bounds across all polygons in path\n var d = getPathString(gd, options);\n var polygons = readPaths(d, gd);\n shapex0 = Infinity;\n shapey0 = Infinity;\n shapex1 = -Infinity;\n shapey1 = -Infinity;\n for(var i = 0; i < polygons.length; i++) {\n for(var j = 0; j < polygons[i].length; j++) {\n var p = polygons[i][j];\n for(var k = 1; k < p.length; k += 2) {\n var _x = p[k];\n var _y = p[k + 1];\n\n shapex0 = Math.min(shapex0, _x);\n shapex1 = Math.max(shapex1, _x);\n shapey0 = Math.min(shapey0, _y);\n shapey1 = Math.max(shapey1, _y);\n }\n }\n }\n } else {\n // Otherwise, we use the x and y bounds defined in the shape options\n // and convert them to pixel coordinates\n // Setup conversion functions\n var xa = Axes.getFromId(gd, options.xref);\n var xShiftStart = options.x0shift;\n var xShiftEnd = options.x1shift;\n var xRefType = Axes.getRefType(options.xref);\n var ya = Axes.getFromId(gd, options.yref);\n var yShiftStart = options.y0shift;\n var yShiftEnd = options.y1shift;\n var yRefType = Axes.getRefType(options.yref);\n var x2p = function(v, shift) {\n var dataToPixel = helpers.getDataToPixel(gd, xa, shift, false, xRefType);\n return dataToPixel(v);\n };\n var y2p = function(v, shift) {\n var dataToPixel = helpers.getDataToPixel(gd, ya, shift, true, yRefType);\n return dataToPixel(v);\n };\n shapex0 = x2p(options.x0, xShiftStart);\n shapex1 = x2p(options.x1, xShiftEnd);\n shapey0 = y2p(options.y0, yShiftStart);\n shapey1 = y2p(options.y1, yShiftEnd);\n }\n\n // Handle `auto` angle\n var textangle = options.label.textangle;\n if(textangle === 'auto') {\n if(options.type === 'line') {\n // Auto angle for line is same angle as line\n textangle = calcTextAngle(shapex0, shapey0, shapex1, shapey1);\n } else {\n // Auto angle for all other shapes is 0\n textangle = 0;\n }\n }\n\n // Do an initial render so we can get the text bounding box height\n labelText.call(function(s) {\n s.call(Drawing.font, font).attr({});\n svgTextUtils.convertToTspans(s, gd);\n return s;\n });\n var textBB = Drawing.bBox(labelText.node());\n\n // Calculate correct (x,y) for text\n // We also determine true xanchor since xanchor depends on position when set to 'auto'\n var textPos = calcTextPosition(shapex0, shapey0, shapex1, shapey1, options, textangle, textBB);\n var textx = textPos.textx;\n var texty = textPos.texty;\n var xanchor = textPos.xanchor;\n\n // Update (x,y) position, xanchor, and angle\n labelText.attr({\n 'text-anchor': {\n left: 'start',\n center: 'middle',\n right: 'end'\n }[xanchor],\n y: texty,\n x: textx,\n transform: 'rotate(' + textangle + ',' + textx + ',' + texty + ')'\n }).call(svgTextUtils.positionText, textx, texty);\n};\n\nfunction calcTextAngle(shapex0, shapey0, shapex1, shapey1) {\n var dy, dx;\n dx = Math.abs(shapex1 - shapex0);\n if(shapex1 >= shapex0) {\n dy = shapey0 - shapey1;\n } else {\n dy = shapey1 - shapey0;\n }\n return -180 / Math.PI * Math.atan2(dy, dx);\n}\n\nfunction calcTextPosition(shapex0, shapey0, shapex1, shapey1, shapeOptions, actualTextAngle, textBB) {\n var textPosition = shapeOptions.label.textposition;\n var textAngle = shapeOptions.label.textangle;\n var textPadding = shapeOptions.label.padding;\n var shapeType = shapeOptions.type;\n var textAngleRad = Math.PI / 180 * actualTextAngle;\n var sinA = Math.sin(textAngleRad);\n var cosA = Math.cos(textAngleRad);\n var xanchor = shapeOptions.label.xanchor;\n var yanchor = shapeOptions.label.yanchor;\n\n var textx, texty, paddingX, paddingY;\n\n // Text position functions differently for lines vs. other shapes\n if(shapeType === 'line') {\n // Set base position for start vs. center vs. end of line (default is 'center')\n if(textPosition === 'start') {\n textx = shapex0;\n texty = shapey0;\n } else if(textPosition === 'end') {\n textx = shapex1;\n texty = shapey1;\n } else { // Default: center\n textx = (shapex0 + shapex1) / 2;\n texty = (shapey0 + shapey1) / 2;\n }\n\n // Set xanchor if xanchor is 'auto'\n if(xanchor === 'auto') {\n if(textPosition === 'start') {\n if(textAngle === 'auto') {\n if(shapex1 > shapex0) xanchor = 'left';\n else if(shapex1 < shapex0) xanchor = 'right';\n else xanchor = 'center';\n } else {\n if(shapex1 > shapex0) xanchor = 'right';\n else if(shapex1 < shapex0) xanchor = 'left';\n else xanchor = 'center';\n }\n } else if(textPosition === 'end') {\n if(textAngle === 'auto') {\n if(shapex1 > shapex0) xanchor = 'right';\n else if(shapex1 < shapex0) xanchor = 'left';\n else xanchor = 'center';\n } else {\n if(shapex1 > shapex0) xanchor = 'left';\n else if(shapex1 < shapex0) xanchor = 'right';\n else xanchor = 'center';\n }\n } else {\n xanchor = 'center';\n }\n }\n\n // Special case for padding when angle is 'auto' for lines\n // Padding should be treated as an orthogonal offset in this case\n // Otherwise, padding is just a simple x and y offset\n var paddingConstantsX = { left: 1, center: 0, right: -1 };\n var paddingConstantsY = { bottom: -1, middle: 0, top: 1 };\n if(textAngle === 'auto') {\n // Set direction to apply padding (based on `yanchor` only)\n var paddingDirection = paddingConstantsY[yanchor];\n paddingX = -textPadding * sinA * paddingDirection;\n paddingY = textPadding * cosA * paddingDirection;\n } else {\n // Set direction to apply padding (based on `xanchor` and `yanchor`)\n var paddingDirectionX = paddingConstantsX[xanchor];\n var paddingDirectionY = paddingConstantsY[yanchor];\n paddingX = textPadding * paddingDirectionX;\n paddingY = textPadding * paddingDirectionY;\n }\n textx = textx + paddingX;\n texty = texty + paddingY;\n } else {\n // Text position for shapes that are not lines\n // calc horizontal position\n // Horizontal needs a little extra padding to look balanced\n paddingX = textPadding + 3;\n if(textPosition.indexOf('right') !== -1) {\n textx = Math.max(shapex0, shapex1) - paddingX;\n if(xanchor === 'auto') xanchor = 'right';\n } else if(textPosition.indexOf('left') !== -1) {\n textx = Math.min(shapex0, shapex1) + paddingX;\n if(xanchor === 'auto') xanchor = 'left';\n } else { // Default: center\n textx = (shapex0 + shapex1) / 2;\n if(xanchor === 'auto') xanchor = 'center';\n }\n\n // calc vertical position\n if(textPosition.indexOf('top') !== -1) {\n texty = Math.min(shapey0, shapey1);\n } else if(textPosition.indexOf('bottom') !== -1) {\n texty = Math.max(shapey0, shapey1);\n } else {\n texty = (shapey0 + shapey1) / 2;\n }\n // Apply padding\n paddingY = textPadding;\n if(yanchor === 'bottom') {\n texty = texty - paddingY;\n } else if(yanchor === 'top') {\n texty = texty + paddingY;\n }\n }\n\n // Shift vertical (& horizontal) position according to `yanchor`\n var shiftFraction = FROM_TL[yanchor];\n // Adjust so that text is anchored at top of first line rather than at baseline of first line\n var baselineAdjust = shapeOptions.label.font.size;\n var textHeight = textBB.height;\n var xshift = (textHeight * shiftFraction - baselineAdjust) * sinA;\n var yshift = -(textHeight * shiftFraction - baselineAdjust) * cosA;\n\n return { textx: textx + xshift, texty: texty + yshift, xanchor: xanchor };\n}\n","'use strict';\n\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\n\nvar dragElement = require('../dragelement');\nvar dragHelpers = require('../dragelement/helpers');\nvar drawMode = dragHelpers.drawMode;\nvar selectMode = dragHelpers.selectMode;\n\nvar Registry = require('../../registry');\nvar Color = require('../color');\n\nvar constants = require('./draw_newshape/constants');\nvar i000 = constants.i000;\nvar i090 = constants.i090;\nvar i180 = constants.i180;\nvar i270 = constants.i270;\n\nvar handleOutline = require('./handle_outline');\nvar clearOutlineControllers = handleOutline.clearOutlineControllers;\n\nvar helpers = require('./draw_newshape/helpers');\nvar pointsOnRectangle = helpers.pointsOnRectangle;\nvar pointsOnEllipse = helpers.pointsOnEllipse;\nvar writePaths = helpers.writePaths;\nvar newShapes = require('./draw_newshape/newshapes').newShapes;\nvar createShapeObj = require('./draw_newshape/newshapes').createShapeObj;\nvar newSelections = require('../selections/draw_newselection/newselections');\nvar drawLabel = require('./display_labels');\n\n\nmodule.exports = function displayOutlines(polygons, outlines, dragOptions, nCalls) {\n if(!nCalls) nCalls = 0;\n\n var gd = dragOptions.gd;\n\n function redraw() {\n // recursive call\n displayOutlines(polygons, outlines, dragOptions, nCalls++);\n\n if(pointsOnEllipse(polygons[0]) || dragOptions.hasText) {\n update({redrawing: true});\n }\n }\n\n function update(opts) {\n var updateObject = {};\n\n if(dragOptions.isActiveShape !== undefined) {\n dragOptions.isActiveShape = false; // i.e. to disable shape controllers\n updateObject = newShapes(outlines, dragOptions);\n }\n\n if(dragOptions.isActiveSelection !== undefined) {\n dragOptions.isActiveSelection = false; // i.e. to disable selection controllers\n updateObject = newSelections(outlines, dragOptions);\n\n gd._fullLayout._reselect = true;\n }\n\n if(Object.keys(updateObject).length) {\n Registry.call((opts || {}).redrawing ? 'relayout' : '_guiRelayout', gd, updateObject);\n }\n }\n\n var fullLayout = gd._fullLayout;\n var zoomLayer = fullLayout._zoomlayer;\n\n var dragmode = dragOptions.dragmode;\n var isDrawMode = drawMode(dragmode);\n var isSelectMode = selectMode(dragmode);\n\n if(isDrawMode || isSelectMode) {\n gd._fullLayout._outlining = true;\n }\n\n clearOutlineControllers(gd);\n\n // make outline\n outlines.attr('d', writePaths(polygons));\n\n // add controllers\n var vertexDragOptions;\n var groupDragOptions;\n var indexI; // cell index\n var indexJ; // vertex or cell-controller index\n var copyPolygons;\n\n if(!nCalls && (\n dragOptions.isActiveShape ||\n dragOptions.isActiveSelection\n )) {\n copyPolygons = recordPositions([], polygons);\n\n var g = zoomLayer.append('g').attr('class', 'outline-controllers');\n addVertexControllers(g);\n addGroupControllers();\n }\n\n // draw label\n if(isDrawMode && dragOptions.hasText) {\n var shapeGroup = zoomLayer.select('.label-temp');\n var shapeOptions = createShapeObj(outlines, dragOptions, dragOptions.dragmode);\n drawLabel(gd, 'label-temp', shapeOptions, shapeGroup);\n }\n\n function startDragVertex(evt) {\n indexI = +evt.srcElement.getAttribute('data-i');\n indexJ = +evt.srcElement.getAttribute('data-j');\n\n vertexDragOptions[indexI][indexJ].moveFn = moveVertexController;\n }\n\n function moveVertexController(dx, dy) {\n if(!polygons.length) return;\n\n var x0 = copyPolygons[indexI][indexJ][1];\n var y0 = copyPolygons[indexI][indexJ][2];\n\n var cell = polygons[indexI];\n var len = cell.length;\n if(pointsOnRectangle(cell)) {\n var _dx = dx;\n var _dy = dy;\n if(dragOptions.isActiveSelection) {\n // handle an edge contoller for rect selections\n var nextPoint = getNextPoint(cell, indexJ);\n if(nextPoint[1] === cell[indexJ][1]) { // a vertical edge\n _dy = 0;\n } else { // a horizontal edge\n _dx = 0;\n }\n }\n\n for(var q = 0; q < len; q++) {\n if(q === indexJ) continue;\n\n // move other corners of rectangle\n var pos = cell[q];\n\n if(pos[1] === cell[indexJ][1]) {\n pos[1] = x0 + _dx;\n }\n\n if(pos[2] === cell[indexJ][2]) {\n pos[2] = y0 + _dy;\n }\n }\n // move the corner\n cell[indexJ][1] = x0 + _dx;\n cell[indexJ][2] = y0 + _dy;\n\n if(!pointsOnRectangle(cell)) {\n // reject result to rectangles with ensure areas\n for(var j = 0; j < len; j++) {\n for(var k = 0; k < cell[j].length; k++) {\n cell[j][k] = copyPolygons[indexI][j][k];\n }\n }\n }\n } else { // other polylines\n cell[indexJ][1] = x0 + dx;\n cell[indexJ][2] = y0 + dy;\n }\n\n redraw();\n }\n\n function endDragVertexController() {\n update();\n }\n\n function removeVertex() {\n if(!polygons.length) return;\n if(!polygons[indexI]) return;\n if(!polygons[indexI].length) return;\n\n var newPolygon = [];\n for(var j = 0; j < polygons[indexI].length; j++) {\n if(j !== indexJ) {\n newPolygon.push(\n polygons[indexI][j]\n );\n }\n }\n\n if(newPolygon.length > 1 && !(\n newPolygon.length === 2 && newPolygon[1][0] === 'Z')\n ) {\n if(indexJ === 0) {\n newPolygon[0][0] = 'M';\n }\n\n polygons[indexI] = newPolygon;\n\n redraw();\n update();\n }\n }\n\n function clickVertexController(numClicks, evt) {\n if(numClicks === 2) {\n indexI = +evt.srcElement.getAttribute('data-i');\n indexJ = +evt.srcElement.getAttribute('data-j');\n\n var cell = polygons[indexI];\n if(\n !pointsOnRectangle(cell) &&\n !pointsOnEllipse(cell)\n ) {\n removeVertex();\n }\n }\n }\n\n function addVertexControllers(g) {\n vertexDragOptions = [];\n\n for(var i = 0; i < polygons.length; i++) {\n var cell = polygons[i];\n\n var onRect = pointsOnRectangle(cell);\n var onEllipse = !onRect && pointsOnEllipse(cell);\n\n vertexDragOptions[i] = [];\n var len = cell.length;\n for(var j = 0; j < len; j++) {\n if(cell[j][0] === 'Z') continue;\n\n if(onEllipse &&\n j !== i000 &&\n j !== i090 &&\n j !== i180 &&\n j !== i270\n ) {\n continue;\n }\n\n var rectSelection = onRect && dragOptions.isActiveSelection;\n var nextPoint;\n if(rectSelection) nextPoint = getNextPoint(cell, j);\n\n var x = cell[j][1];\n var y = cell[j][2];\n\n var vertex = g.append(rectSelection ? 'rect' : 'circle')\n .attr('data-i', i)\n .attr('data-j', j)\n .style({\n fill: Color.background,\n stroke: Color.defaultLine,\n 'stroke-width': 1,\n 'shape-rendering': 'crispEdges',\n });\n\n if(rectSelection) {\n // convert a vertex controller to an edge controller for rect selections\n var dx = nextPoint[1] - x;\n var dy = nextPoint[2] - y;\n\n var width = dy ? 5 : Math.max(Math.min(25, Math.abs(dx) - 5), 5);\n var height = dx ? 5 : Math.max(Math.min(25, Math.abs(dy) - 5), 5);\n\n vertex.classed(dy ? 'cursor-ew-resize' : 'cursor-ns-resize', true)\n .attr('width', width)\n .attr('height', height)\n .attr('x', x - width / 2)\n .attr('y', y - height / 2)\n .attr('transform', strTranslate(dx / 2, dy / 2));\n } else {\n vertex.classed('cursor-grab', true)\n .attr('r', 5)\n .attr('cx', x)\n .attr('cy', y);\n }\n\n vertexDragOptions[i][j] = {\n element: vertex.node(),\n gd: gd,\n prepFn: startDragVertex,\n doneFn: endDragVertexController,\n clickFn: clickVertexController\n };\n\n dragElement.init(vertexDragOptions[i][j]);\n }\n }\n }\n\n function moveGroup(dx, dy) {\n if(!polygons.length) return;\n\n for(var i = 0; i < polygons.length; i++) {\n for(var j = 0; j < polygons[i].length; j++) {\n for(var k = 0; k + 2 < polygons[i][j].length; k += 2) {\n polygons[i][j][k + 1] = copyPolygons[i][j][k + 1] + dx;\n polygons[i][j][k + 2] = copyPolygons[i][j][k + 2] + dy;\n }\n }\n }\n }\n\n function moveGroupController(dx, dy) {\n moveGroup(dx, dy);\n\n redraw();\n }\n\n function startDragGroupController(evt) {\n indexI = +evt.srcElement.getAttribute('data-i');\n if(!indexI) indexI = 0; // ensure non-existing move button get zero index\n\n groupDragOptions[indexI].moveFn = moveGroupController;\n }\n\n function endDragGroupController() {\n update();\n }\n\n function clickGroupController(numClicks) {\n if(numClicks === 2) {\n eraseActiveSelection(gd);\n }\n }\n\n function addGroupControllers() {\n groupDragOptions = [];\n\n if(!polygons.length) return;\n\n var i = 0;\n groupDragOptions[i] = {\n element: outlines[0][0],\n gd: gd,\n prepFn: startDragGroupController,\n doneFn: endDragGroupController,\n clickFn: clickGroupController\n };\n\n dragElement.init(groupDragOptions[i]);\n }\n};\n\nfunction recordPositions(polygonsOut, polygonsIn) {\n for(var i = 0; i < polygonsIn.length; i++) {\n var cell = polygonsIn[i];\n polygonsOut[i] = [];\n for(var j = 0; j < cell.length; j++) {\n polygonsOut[i][j] = [];\n for(var k = 0; k < cell[j].length; k++) {\n polygonsOut[i][j][k] = cell[j][k];\n }\n }\n }\n return polygonsOut;\n}\n\nfunction getNextPoint(cell, j) {\n var x = cell[j][1];\n var y = cell[j][2];\n var len = cell.length;\n var nextJ, nextX, nextY;\n nextJ = (j + 1) % len;\n nextX = cell[nextJ][1];\n nextY = cell[nextJ][2];\n\n // avoid potential double points (closing points)\n if(nextX === x && nextY === y) {\n nextJ = (j + 2) % len;\n nextX = cell[nextJ][1];\n nextY = cell[nextJ][2];\n }\n\n return [nextJ, nextX, nextY];\n}\n\nfunction eraseActiveSelection(gd) {\n // Do not allow removal of selections on other dragmodes.\n // This ensures the user could still double click to\n // deselect all trace.selectedpoints,\n // if that's what they wanted.\n // Also double click to zoom back won't result in\n // any surprising selection removal.\n if(!selectMode(gd._fullLayout.dragmode)) return;\n\n clearOutlineControllers(gd);\n\n var id = gd._fullLayout._activeSelectionIndex;\n var selections = (gd.layout || {}).selections || [];\n if(id < selections.length) {\n var list = [];\n for(var q = 0; q < selections.length; q++) {\n if(q !== id) {\n list.push(selections[q]);\n }\n }\n\n delete gd._fullLayout._activeSelectionIndex;\n\n var erasedSelection = gd._fullLayout.selections[id];\n gd._fullLayout._deselect = {\n xref: erasedSelection.xref,\n yref: erasedSelection.yref\n };\n\n Registry.call('_guiRelayout', gd, {\n selections: list\n });\n }\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\n\nvar readPaths = require('./draw_newshape/helpers').readPaths;\nvar displayOutlines = require('./display_outlines');\nvar drawLabel = require('./display_labels');\n\nvar clearOutlineControllers = require('./handle_outline').clearOutlineControllers;\n\nvar Color = require('../color');\nvar Drawing = require('../drawing');\nvar arrayEditor = require('../../plot_api/plot_template').arrayEditor;\n\nvar dragElement = require('../dragelement');\nvar setCursor = require('../../lib/setcursor');\n\nvar constants = require('./constants');\nvar helpers = require('./helpers');\nvar getPathString = helpers.getPathString;\n\n\n// Shapes are stored in gd.layout.shapes, an array of objects\n// index can point to one item in this array,\n// or non-numeric to simply add a new one\n// or -1 to modify all existing\n// opt can be the full options object, or one key (to be set to value)\n// or undefined to simply redraw\n// if opt is blank, val can be 'add' or a full options object to add a new\n// annotation at that point in the array, or 'remove' to delete this one\n\nmodule.exports = {\n draw: draw,\n drawOne: drawOne,\n eraseActiveShape: eraseActiveShape,\n drawLabel: drawLabel,\n};\n\nfunction draw(gd) {\n var fullLayout = gd._fullLayout;\n\n // Remove previous shapes before drawing new in shapes in fullLayout.shapes\n fullLayout._shapeUpperLayer.selectAll('path').remove();\n fullLayout._shapeLowerLayer.selectAll('path').remove();\n fullLayout._shapeUpperLayer.selectAll('text').remove();\n fullLayout._shapeLowerLayer.selectAll('text').remove();\n\n for(var k in fullLayout._plots) {\n var shapelayer = fullLayout._plots[k].shapelayer;\n if(shapelayer) {\n shapelayer.selectAll('path').remove();\n shapelayer.selectAll('text').remove();\n }\n }\n\n for(var i = 0; i < fullLayout.shapes.length; i++) {\n if(fullLayout.shapes[i].visible === true) {\n drawOne(gd, i);\n }\n }\n\n // may need to resurrect this if we put text (LaTeX) in shapes\n // return Plots.previousPromises(gd);\n}\n\nfunction shouldSkipEdits(gd) {\n return !!gd._fullLayout._outlining;\n}\n\nfunction couldHaveActiveShape(gd) {\n // for now keep config.editable: true as it was before shape-drawing PR\n return !gd._context.edits.shapePosition;\n}\n\nfunction drawOne(gd, index) {\n // remove the existing shape if there is one.\n // because indices can change, we need to look in all shape layers\n gd._fullLayout._paperdiv\n .selectAll('.shapelayer [data-index=\"' + index + '\"]')\n .remove();\n\n var o = helpers.makeShapesOptionsAndPlotinfo(gd, index);\n var options = o.options;\n var plotinfo = o.plotinfo;\n\n // this shape is gone - quit now after deleting it\n // TODO: use d3 idioms instead of deleting and redrawing every time\n if(!options._input || options.visible !== true) return;\n\n if(options.layer === 'above') {\n drawShape(gd._fullLayout._shapeUpperLayer);\n } else if(options.xref === 'paper' || options.yref === 'paper') {\n drawShape(gd._fullLayout._shapeLowerLayer);\n } else if(options.layer === 'between') {\n drawShape(plotinfo.shapelayerBetween);\n } else {\n if(plotinfo._hadPlotinfo) {\n var mainPlot = plotinfo.mainplotinfo || plotinfo;\n drawShape(mainPlot.shapelayer);\n } else {\n // Fall back to _shapeLowerLayer in case the requested subplot doesn't exist.\n // This can happen if you reference the shape to an x / y axis combination\n // that doesn't have any data on it (and layer is below)\n drawShape(gd._fullLayout._shapeLowerLayer);\n }\n }\n\n function drawShape(shapeLayer) {\n var d = getPathString(gd, options);\n var attrs = {\n 'data-index': index,\n 'fill-rule': options.fillrule,\n d: d\n };\n\n var opacity = options.opacity;\n var fillColor = options.fillcolor;\n var lineColor = options.line.width ? options.line.color : 'rgba(0,0,0,0)';\n var lineWidth = options.line.width;\n var lineDash = options.line.dash;\n if(!lineWidth && options.editable === true) {\n // ensure invisible border to activate the shape\n lineWidth = 5;\n lineDash = 'solid';\n }\n\n var isOpen = d[d.length - 1] !== 'Z';\n\n var isActiveShape = couldHaveActiveShape(gd) &&\n options.editable && gd._fullLayout._activeShapeIndex === index;\n\n if(isActiveShape) {\n fillColor = isOpen ? 'rgba(0,0,0,0)' :\n gd._fullLayout.activeshape.fillcolor;\n\n opacity = gd._fullLayout.activeshape.opacity;\n }\n\n var shapeGroup = shapeLayer.append('g')\n .classed('shape-group', true)\n .attr({ 'data-index': index });\n\n var path = shapeGroup.append('path')\n .attr(attrs)\n .style('opacity', opacity)\n .call(Color.stroke, lineColor)\n .call(Color.fill, fillColor)\n .call(Drawing.dashLine, lineDash, lineWidth);\n\n setClipPath(shapeGroup, gd, options);\n\n // Draw or clear the label\n drawLabel(gd, index, options, shapeGroup);\n\n var editHelpers;\n if(isActiveShape || gd._context.edits.shapePosition) editHelpers = arrayEditor(gd.layout, 'shapes', options);\n\n if(isActiveShape) {\n path.style({\n cursor: 'move',\n });\n\n var dragOptions = {\n element: path.node(),\n plotinfo: plotinfo,\n gd: gd,\n editHelpers: editHelpers,\n hasText: options.label.text || options.label.texttemplate,\n isActiveShape: true // i.e. to enable controllers\n };\n\n var polygons = readPaths(d, gd);\n // display polygons on the screen\n displayOutlines(polygons, path, dragOptions);\n } else {\n if(gd._context.edits.shapePosition) {\n setupDragElement(gd, path, options, index, shapeLayer, editHelpers);\n } else if(options.editable === true) {\n path.style('pointer-events',\n (isOpen || Color.opacity(fillColor) * opacity <= 0.5) ? 'stroke' : 'all'\n );\n }\n }\n path.node().addEventListener('click', function() { return activateShape(gd, path); });\n }\n}\n\nfunction setClipPath(shapePath, gd, shapeOptions) {\n // note that for layer=\"below\" the clipAxes can be different from the\n // subplot we're drawing this in. This could cause problems if the shape\n // spans two subplots. See https://github.com/plotly/plotly.js/issues/1452\n //\n // if axis is 'paper' or an axis with \" domain\" appended, then there is no\n // clip axis\n var clipAxes = (shapeOptions.xref + shapeOptions.yref).replace(/paper/g, '').replace(/[xyz][1-9]* *domain/g, '');\n\n Drawing.setClipUrl(\n shapePath,\n clipAxes ? 'clip' + gd._fullLayout._uid + clipAxes : null,\n gd\n );\n}\n\nfunction setupDragElement(gd, shapePath, shapeOptions, index, shapeLayer, editHelpers) {\n var MINWIDTH = 10;\n var MINHEIGHT = 10;\n\n var xPixelSized = shapeOptions.xsizemode === 'pixel';\n var yPixelSized = shapeOptions.ysizemode === 'pixel';\n var isLine = shapeOptions.type === 'line';\n var isPath = shapeOptions.type === 'path';\n\n var modifyItem = editHelpers.modifyItem;\n\n var x0, y0, x1, y1, xAnchor, yAnchor;\n var n0, s0, w0, e0, optN, optS, optW, optE;\n var pathIn;\n\n var shapeGroup = d3.select(shapePath.node().parentNode);\n\n // setup conversion functions\n var xa = Axes.getFromId(gd, shapeOptions.xref);\n var xRefType = Axes.getRefType(shapeOptions.xref);\n var ya = Axes.getFromId(gd, shapeOptions.yref);\n var yRefType = Axes.getRefType(shapeOptions.yref);\n var shiftXStart = shapeOptions.x0shift;\n var shiftXEnd = shapeOptions.x1shift;\n var shiftYStart = shapeOptions.y0shift;\n var shiftYEnd = shapeOptions.y1shift;\n var x2p = function(v, shift) {\n var dataToPixel = helpers.getDataToPixel(gd, xa, shift, false, xRefType);\n return dataToPixel(v);\n };\n var y2p = function(v, shift) {\n var dataToPixel = helpers.getDataToPixel(gd, ya, shift, true, yRefType);\n return dataToPixel(v);\n };\n var p2x = helpers.getPixelToData(gd, xa, false, xRefType);\n var p2y = helpers.getPixelToData(gd, ya, true, yRefType);\n\n var sensoryElement = obtainSensoryElement();\n var dragOptions = {\n element: sensoryElement.node(),\n gd: gd,\n prepFn: startDrag,\n doneFn: endDrag,\n clickFn: abortDrag\n };\n var dragMode;\n\n dragElement.init(dragOptions);\n\n sensoryElement.node().onmousemove = updateDragMode;\n\n function obtainSensoryElement() {\n return isLine ? createLineDragHandles() : shapePath;\n }\n\n function createLineDragHandles() {\n var minSensoryWidth = 10;\n var sensoryWidth = Math.max(shapeOptions.line.width, minSensoryWidth);\n\n // Helper shapes group\n // Note that by setting the `data-index` attr, it is ensured that\n // the helper group is purged in this modules `draw` function\n var g = shapeLayer.append('g')\n .attr('data-index', index)\n .attr('drag-helper', true);\n\n // Helper path for moving\n g.append('path')\n .attr('d', shapePath.attr('d'))\n .style({\n cursor: 'move',\n 'stroke-width': sensoryWidth,\n 'stroke-opacity': '0' // ensure not visible\n });\n\n // Helper circles for resizing\n var circleStyle = {\n 'fill-opacity': '0' // ensure not visible\n };\n var circleRadius = Math.max(sensoryWidth / 2, minSensoryWidth);\n\n g.append('circle')\n .attr({\n 'data-line-point': 'start-point',\n cx: xPixelSized ? x2p(shapeOptions.xanchor) + shapeOptions.x0 : x2p(shapeOptions.x0, shiftXStart),\n cy: yPixelSized ? y2p(shapeOptions.yanchor) - shapeOptions.y0 : y2p(shapeOptions.y0, shiftYStart),\n r: circleRadius\n })\n .style(circleStyle)\n .classed('cursor-grab', true);\n\n g.append('circle')\n .attr({\n 'data-line-point': 'end-point',\n cx: xPixelSized ? x2p(shapeOptions.xanchor) + shapeOptions.x1 : x2p(shapeOptions.x1, shiftXEnd),\n cy: yPixelSized ? y2p(shapeOptions.yanchor) - shapeOptions.y1 : y2p(shapeOptions.y1, shiftYEnd),\n r: circleRadius\n })\n .style(circleStyle)\n .classed('cursor-grab', true);\n\n return g;\n }\n\n function updateDragMode(evt) {\n if(shouldSkipEdits(gd)) {\n dragMode = null;\n return;\n }\n\n if(isLine) {\n if(evt.target.tagName === 'path') {\n dragMode = 'move';\n } else {\n dragMode = evt.target.attributes['data-line-point'].value === 'start-point' ?\n 'resize-over-start-point' : 'resize-over-end-point';\n }\n } else {\n // element might not be on screen at time of setup,\n // so obtain bounding box here\n var dragBBox = dragOptions.element.getBoundingClientRect();\n\n // choose 'move' or 'resize'\n // based on initial position of cursor within the drag element\n var w = dragBBox.right - dragBBox.left;\n var h = dragBBox.bottom - dragBBox.top;\n var x = evt.clientX - dragBBox.left;\n var y = evt.clientY - dragBBox.top;\n var cursor = (!isPath && w > MINWIDTH && h > MINHEIGHT && !evt.shiftKey) ?\n dragElement.getCursor(x / w, 1 - y / h) :\n 'move';\n\n setCursor(shapePath, cursor);\n\n // possible values 'move', 'sw', 'w', 'se', 'e', 'ne', 'n', 'nw' and 'w'\n dragMode = cursor.split('-')[0];\n }\n }\n\n function startDrag(evt) {\n if(shouldSkipEdits(gd)) return;\n\n // setup update strings and initial values\n if(xPixelSized) {\n xAnchor = x2p(shapeOptions.xanchor);\n }\n if(yPixelSized) {\n yAnchor = y2p(shapeOptions.yanchor);\n }\n\n if(shapeOptions.type === 'path') {\n pathIn = shapeOptions.path;\n } else {\n x0 = xPixelSized ? shapeOptions.x0 : x2p(shapeOptions.x0);\n y0 = yPixelSized ? shapeOptions.y0 : y2p(shapeOptions.y0);\n x1 = xPixelSized ? shapeOptions.x1 : x2p(shapeOptions.x1);\n y1 = yPixelSized ? shapeOptions.y1 : y2p(shapeOptions.y1);\n }\n\n if(x0 < x1) {\n w0 = x0;\n optW = 'x0';\n e0 = x1;\n optE = 'x1';\n } else {\n w0 = x1;\n optW = 'x1';\n e0 = x0;\n optE = 'x0';\n }\n\n // For fixed size shapes take opposing direction of y-axis into account.\n // Hint: For data sized shapes this is done by the y2p function.\n if((!yPixelSized && y0 < y1) || (yPixelSized && y0 > y1)) {\n n0 = y0;\n optN = 'y0';\n s0 = y1;\n optS = 'y1';\n } else {\n n0 = y1;\n optN = 'y1';\n s0 = y0;\n optS = 'y0';\n }\n\n // setup dragMode and the corresponding handler\n updateDragMode(evt);\n renderVisualCues(shapeLayer, shapeOptions);\n deactivateClipPathTemporarily(shapePath, shapeOptions, gd);\n dragOptions.moveFn = (dragMode === 'move') ? moveShape : resizeShape;\n dragOptions.altKey = evt.altKey;\n }\n\n function endDrag() {\n if(shouldSkipEdits(gd)) return;\n\n setCursor(shapePath);\n removeVisualCues(shapeLayer);\n\n // Don't rely on clipPath being activated during re-layout\n setClipPath(shapePath, gd, shapeOptions);\n Registry.call('_guiRelayout', gd, editHelpers.getUpdateObj());\n }\n\n function abortDrag() {\n if(shouldSkipEdits(gd)) return;\n\n removeVisualCues(shapeLayer);\n }\n\n function moveShape(dx, dy) {\n if(shapeOptions.type === 'path') {\n var noOp = function(coord) { return coord; };\n var moveX = noOp;\n var moveY = noOp;\n\n if(xPixelSized) {\n modifyItem('xanchor', shapeOptions.xanchor = p2x(xAnchor + dx));\n } else {\n moveX = function moveX(x) { return p2x(x2p(x) + dx); };\n if(xa && xa.type === 'date') moveX = helpers.encodeDate(moveX);\n }\n\n if(yPixelSized) {\n modifyItem('yanchor', shapeOptions.yanchor = p2y(yAnchor + dy));\n } else {\n moveY = function moveY(y) { return p2y(y2p(y) + dy); };\n if(ya && ya.type === 'date') moveY = helpers.encodeDate(moveY);\n }\n\n modifyItem('path', shapeOptions.path = movePath(pathIn, moveX, moveY));\n } else {\n if(xPixelSized) {\n modifyItem('xanchor', shapeOptions.xanchor = p2x(xAnchor + dx));\n } else {\n modifyItem('x0', shapeOptions.x0 = p2x(x0 + dx));\n modifyItem('x1', shapeOptions.x1 = p2x(x1 + dx));\n }\n\n if(yPixelSized) {\n modifyItem('yanchor', shapeOptions.yanchor = p2y(yAnchor + dy));\n } else {\n modifyItem('y0', shapeOptions.y0 = p2y(y0 + dy));\n modifyItem('y1', shapeOptions.y1 = p2y(y1 + dy));\n }\n }\n\n shapePath.attr('d', getPathString(gd, shapeOptions));\n renderVisualCues(shapeLayer, shapeOptions);\n drawLabel(gd, index, shapeOptions, shapeGroup);\n }\n\n function resizeShape(dx, dy) {\n if(isPath) {\n // TODO: implement path resize, don't forget to update dragMode code\n var noOp = function(coord) { return coord; };\n var moveX = noOp;\n var moveY = noOp;\n\n if(xPixelSized) {\n modifyItem('xanchor', shapeOptions.xanchor = p2x(xAnchor + dx));\n } else {\n moveX = function moveX(x) { return p2x(x2p(x) + dx); };\n if(xa && xa.type === 'date') moveX = helpers.encodeDate(moveX);\n }\n\n if(yPixelSized) {\n modifyItem('yanchor', shapeOptions.yanchor = p2y(yAnchor + dy));\n } else {\n moveY = function moveY(y) { return p2y(y2p(y) + dy); };\n if(ya && ya.type === 'date') moveY = helpers.encodeDate(moveY);\n }\n\n modifyItem('path', shapeOptions.path = movePath(pathIn, moveX, moveY));\n } else if(isLine) {\n if(dragMode === 'resize-over-start-point') {\n var newX0 = x0 + dx;\n var newY0 = yPixelSized ? y0 - dy : y0 + dy;\n modifyItem('x0', shapeOptions.x0 = xPixelSized ? newX0 : p2x(newX0));\n modifyItem('y0', shapeOptions.y0 = yPixelSized ? newY0 : p2y(newY0));\n } else if(dragMode === 'resize-over-end-point') {\n var newX1 = x1 + dx;\n var newY1 = yPixelSized ? y1 - dy : y1 + dy;\n modifyItem('x1', shapeOptions.x1 = xPixelSized ? newX1 : p2x(newX1));\n modifyItem('y1', shapeOptions.y1 = yPixelSized ? newY1 : p2y(newY1));\n }\n } else {\n var has = function(str) { return dragMode.indexOf(str) !== -1; };\n var hasN = has('n');\n var hasS = has('s');\n var hasW = has('w');\n var hasE = has('e');\n\n var newN = hasN ? n0 + dy : n0;\n var newS = hasS ? s0 + dy : s0;\n var newW = hasW ? w0 + dx : w0;\n var newE = hasE ? e0 + dx : e0;\n\n if(yPixelSized) {\n // Do things in opposing direction for y-axis.\n // Hint: for data-sized shapes the reversal of axis direction is done in p2y.\n if(hasN) newN = n0 - dy;\n if(hasS) newS = s0 - dy;\n }\n\n // Update shape eventually. Again, be aware of the\n // opposing direction of the y-axis of fixed size shapes.\n if(\n (!yPixelSized && newS - newN > MINHEIGHT) ||\n (yPixelSized && newN - newS > MINHEIGHT)\n ) {\n modifyItem(optN, shapeOptions[optN] = yPixelSized ? newN : p2y(newN));\n modifyItem(optS, shapeOptions[optS] = yPixelSized ? newS : p2y(newS));\n }\n if(newE - newW > MINWIDTH) {\n modifyItem(optW, shapeOptions[optW] = xPixelSized ? newW : p2x(newW));\n modifyItem(optE, shapeOptions[optE] = xPixelSized ? newE : p2x(newE));\n }\n }\n\n shapePath.attr('d', getPathString(gd, shapeOptions));\n renderVisualCues(shapeLayer, shapeOptions);\n drawLabel(gd, index, shapeOptions, shapeGroup);\n }\n\n function renderVisualCues(shapeLayer, shapeOptions) {\n if(xPixelSized || yPixelSized) {\n renderAnchor();\n }\n\n function renderAnchor() {\n var isNotPath = shapeOptions.type !== 'path';\n\n // d3 join with dummy data to satisfy d3 data-binding\n var visualCues = shapeLayer.selectAll('.visual-cue').data([0]);\n\n // Enter\n var strokeWidth = 1;\n visualCues.enter()\n .append('path')\n .attr({\n fill: '#fff',\n 'fill-rule': 'evenodd',\n stroke: '#000',\n 'stroke-width': strokeWidth\n })\n .classed('visual-cue', true);\n\n // Update\n var posX = x2p(\n xPixelSized ?\n shapeOptions.xanchor :\n Lib.midRange(\n isNotPath ?\n [shapeOptions.x0, shapeOptions.x1] :\n helpers.extractPathCoords(shapeOptions.path, constants.paramIsX))\n );\n var posY = y2p(\n yPixelSized ?\n shapeOptions.yanchor :\n Lib.midRange(\n isNotPath ?\n [shapeOptions.y0, shapeOptions.y1] :\n helpers.extractPathCoords(shapeOptions.path, constants.paramIsY))\n );\n\n posX = helpers.roundPositionForSharpStrokeRendering(posX, strokeWidth);\n posY = helpers.roundPositionForSharpStrokeRendering(posY, strokeWidth);\n\n if(xPixelSized && yPixelSized) {\n var crossPath = 'M' + (posX - 1 - strokeWidth) + ',' + (posY - 1 - strokeWidth) +\n 'h-8v2h8 v8h2v-8 h8v-2h-8 v-8h-2 Z';\n visualCues.attr('d', crossPath);\n } else if(xPixelSized) {\n var vBarPath = 'M' + (posX - 1 - strokeWidth) + ',' + (posY - 9 - strokeWidth) +\n 'v18 h2 v-18 Z';\n visualCues.attr('d', vBarPath);\n } else {\n var hBarPath = 'M' + (posX - 9 - strokeWidth) + ',' + (posY - 1 - strokeWidth) +\n 'h18 v2 h-18 Z';\n visualCues.attr('d', hBarPath);\n }\n }\n }\n\n function removeVisualCues(shapeLayer) {\n shapeLayer.selectAll('.visual-cue').remove();\n }\n\n function deactivateClipPathTemporarily(shapePath, shapeOptions, gd) {\n var xref = shapeOptions.xref;\n var yref = shapeOptions.yref;\n var xa = Axes.getFromId(gd, xref);\n var ya = Axes.getFromId(gd, yref);\n\n var clipAxes = '';\n if(xref !== 'paper' && !xa.autorange) clipAxes += xref;\n if(yref !== 'paper' && !ya.autorange) clipAxes += yref;\n\n Drawing.setClipUrl(\n shapePath,\n clipAxes ? 'clip' + gd._fullLayout._uid + clipAxes : null,\n gd\n );\n }\n}\n\nfunction movePath(pathIn, moveX, moveY) {\n return pathIn.replace(constants.segmentRE, function(segment) {\n var paramNumber = 0;\n var segmentType = segment.charAt(0);\n var xParams = constants.paramIsX[segmentType];\n var yParams = constants.paramIsY[segmentType];\n var nParams = constants.numParams[segmentType];\n\n var paramString = segment.substr(1).replace(constants.paramRE, function(param) {\n if(paramNumber >= nParams) return param;\n\n if(xParams[paramNumber]) param = moveX(param);\n else if(yParams[paramNumber]) param = moveY(param);\n\n paramNumber++;\n\n return param;\n });\n\n return segmentType + paramString;\n });\n}\n\nfunction activateShape(gd, path) {\n if(!couldHaveActiveShape(gd)) return;\n\n var element = path.node();\n var id = +element.getAttribute('data-index');\n if(id >= 0) {\n // deactivate if already active\n if(id === gd._fullLayout._activeShapeIndex) {\n deactivateShape(gd);\n return;\n }\n\n gd._fullLayout._activeShapeIndex = id;\n gd._fullLayout._deactivateShape = deactivateShape;\n draw(gd);\n }\n}\n\nfunction deactivateShape(gd) {\n if(!couldHaveActiveShape(gd)) return;\n\n var id = gd._fullLayout._activeShapeIndex;\n if(id >= 0) {\n clearOutlineControllers(gd);\n delete gd._fullLayout._activeShapeIndex;\n draw(gd);\n }\n}\n\nfunction eraseActiveShape(gd) {\n if(!couldHaveActiveShape(gd)) return;\n\n clearOutlineControllers(gd);\n\n var id = gd._fullLayout._activeShapeIndex;\n var shapes = (gd.layout || {}).shapes || [];\n if(id < shapes.length) {\n var list = [];\n for(var q = 0; q < shapes.length; q++) {\n if(q !== id) {\n list.push(shapes[q]);\n }\n }\n\n delete gd._fullLayout._activeShapeIndex;\n\n return Registry.call('_guiRelayout', gd, {\n shapes: list\n });\n }\n}\n","'use strict';\n\nvar overrideAll = require('../../../plot_api/edit_types').overrideAll;\nvar basePlotAttributes = require('../../../plots/attributes');\nvar fontAttrs = require('../../../plots/font_attributes');\nvar dash = require('../../drawing/attributes').dash;\nvar extendFlat = require('../../../lib/extend').extendFlat;\nvar shapeTexttemplateAttrs = require('../../../plots/template_attributes').shapeTexttemplateAttrs;\nvar shapeLabelTexttemplateVars = require('../label_texttemplate');\n\nmodule.exports = overrideAll({\n newshape: {\n visible: extendFlat({}, basePlotAttributes.visible, {\n description: [\n 'Determines whether or not new shape is visible.',\n 'If *legendonly*, the shape is not drawn,',\n 'but can appear as a legend item',\n '(provided that the legend itself is visible).'\n ].join(' ')\n }),\n\n showlegend: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether or not new',\n 'shape is shown in the legend.'\n ].join(' ')\n },\n\n legend: extendFlat({}, basePlotAttributes.legend, {\n description: [\n 'Sets the reference to a legend to show new shape in.',\n 'References to these legends are *legend*, *legend2*, *legend3*, etc.',\n 'Settings for these legends are set in the layout, under',\n '`layout.legend`, `layout.legend2`, etc.'\n ].join(' ')\n }),\n\n legendgroup: extendFlat({}, basePlotAttributes.legendgroup, {\n description: [\n 'Sets the legend group for new shape.',\n 'Traces and shapes part of the same legend group hide/show at the same time',\n 'when toggling legend items.'\n ].join(' ')\n }),\n\n legendgrouptitle: {\n text: extendFlat({}, basePlotAttributes.legendgrouptitle.text, {\n }),\n font: fontAttrs({\n description: [\n 'Sets this legend group\\'s title font.'\n ].join(' '),\n })\n },\n\n legendrank: extendFlat({}, basePlotAttributes.legendrank, {\n description: [\n 'Sets the legend rank for new shape.',\n 'Items and groups with smaller ranks are presented on top/left side while',\n 'with *reversed* `legend.traceorder` they are on bottom/right side.',\n 'The default legendrank is 1000,',\n 'so that you can use ranks less than 1000 to place certain items before all unranked items,',\n 'and ranks greater than 1000 to go after all unranked items.'\n ].join(' ')\n }),\n\n legendwidth: extendFlat({}, basePlotAttributes.legendwidth, {\n description: 'Sets the width (in px or fraction) of the legend for new shape.',\n }),\n\n line: {\n color: {\n valType: 'color',\n description: [\n 'Sets the line color.',\n 'By default uses either dark grey or white',\n 'to increase contrast with background color.'\n ].join(' ')\n },\n width: {\n valType: 'number',\n min: 0,\n dflt: 4,\n description: 'Sets the line width (in px).'\n },\n dash: extendFlat({}, dash, {\n dflt: 'solid',\n })\n },\n fillcolor: {\n valType: 'color',\n dflt: 'rgba(0,0,0,0)',\n description: [\n 'Sets the color filling new shapes\\' interior.',\n 'Please note that if using a fillcolor with alpha greater than half,',\n 'drag inside the active shape starts moving the shape underneath,',\n 'otherwise a new shape could be started over.'\n ].join(' ')\n },\n fillrule: {\n valType: 'enumerated',\n values: ['evenodd', 'nonzero'],\n dflt: 'evenodd',\n description: [\n 'Determines the path\\'s interior.',\n 'For more info please visit https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/fill-rule'\n ].join(' ')\n },\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n description: 'Sets the opacity of new shapes.'\n },\n layer: {\n valType: 'enumerated',\n values: ['below', 'above', 'between'],\n dflt: 'above',\n description: [\n 'Specifies whether new shapes are drawn below gridlines (*below*),',\n 'between gridlines and traces (*between*) or above traces (*above*).'\n ].join(' ')\n },\n drawdirection: {\n valType: 'enumerated',\n values: ['ortho', 'horizontal', 'vertical', 'diagonal'],\n dflt: 'diagonal',\n description: [\n 'When `dragmode` is set to *drawrect*, *drawline* or *drawcircle*',\n 'this limits the drag to be horizontal, vertical or diagonal.',\n 'Using *diagonal* there is no limit e.g. in drawing lines in any direction.',\n '*ortho* limits the draw to be either horizontal or vertical.',\n '*horizontal* allows horizontal extend.',\n '*vertical* allows vertical extend.'\n ].join(' ')\n },\n\n name: extendFlat({}, basePlotAttributes.name, {\n description: [\n 'Sets new shape name.',\n 'The name appears as the legend item.'\n ].join(' ')\n }),\n\n label: {\n text: {\n valType: 'string',\n dflt: '',\n description: [\n 'Sets the text to display with the new shape.',\n 'It is also used for legend item if `name` is not provided.'\n ].join(' ')\n },\n texttemplate: shapeTexttemplateAttrs({newshape: true}, {keys: Object.keys(shapeLabelTexttemplateVars)}),\n font: fontAttrs({\n description: 'Sets the new shape label text font.'\n }),\n textposition: {\n valType: 'enumerated',\n values: [\n 'top left', 'top center', 'top right',\n 'middle left', 'middle center', 'middle right',\n 'bottom left', 'bottom center', 'bottom right',\n 'start', 'middle', 'end',\n ],\n description: [\n 'Sets the position of the label text relative to the new shape.',\n 'Supported values for rectangles, circles and paths are',\n '*top left*, *top center*, *top right*, *middle left*,',\n '*middle center*, *middle right*, *bottom left*, *bottom center*,',\n 'and *bottom right*.',\n 'Supported values for lines are *start*, *middle*, and *end*.',\n 'Default: *middle center* for rectangles, circles, and paths; *middle* for lines.',\n ].join(' ')\n },\n textangle: {\n valType: 'angle',\n dflt: 'auto',\n description: [\n 'Sets the angle at which the label text is drawn',\n 'with respect to the horizontal. For lines, angle *auto*',\n 'is the same angle as the line. For all other shapes,',\n 'angle *auto* is horizontal.'\n ].join(' ')\n },\n xanchor: {\n valType: 'enumerated',\n values: ['auto', 'left', 'center', 'right'],\n dflt: 'auto',\n description: [\n 'Sets the label\\'s horizontal position anchor',\n 'This anchor binds the specified `textposition` to the *left*, *center*',\n 'or *right* of the label text.',\n 'For example, if `textposition` is set to *top right* and',\n '`xanchor` to *right* then the right-most portion of the',\n 'label text lines up with the right-most edge of the',\n 'new shape.',\n ].join(' '),\n },\n yanchor: {\n valType: 'enumerated',\n values: ['top', 'middle', 'bottom'],\n description: [\n 'Sets the label\\'s vertical position anchor',\n 'This anchor binds the specified `textposition` to the *top*, *middle*',\n 'or *bottom* of the label text.',\n 'For example, if `textposition` is set to *top right* and',\n '`yanchor` to *top* then the top-most portion of the',\n 'label text lines up with the top-most edge of the',\n 'new shape.',\n ].join(' ')\n },\n padding: {\n valType: 'number',\n dflt: 3,\n min: 0,\n description: 'Sets padding (in px) between edge of label and edge of new shape.'\n }\n }\n },\n\n activeshape: {\n fillcolor: {\n valType: 'color',\n dflt: 'rgb(255,0,255)',\n description: 'Sets the color filling the active shape\\' interior.'\n },\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0.5,\n description: 'Sets the opacity of the active shape.'\n }\n }\n}, 'none', 'from-root');\n","'use strict';\n\nvar CIRCLE_SIDES = 32; // should be divisible by 4\n\nmodule.exports = {\n CIRCLE_SIDES: CIRCLE_SIDES,\n i000: 0,\n i090: CIRCLE_SIDES / 4,\n i180: CIRCLE_SIDES / 2,\n i270: CIRCLE_SIDES / 4 * 3,\n cos45: Math.cos(Math.PI / 4),\n sin45: Math.sin(Math.PI / 4),\n SQRT2: Math.sqrt(2)\n};\n","'use strict';\n\nvar Color = require('../../color');\nvar Lib = require('../../../lib');\n\n\nfunction dfltLabelYanchor(isLine, labelTextPosition) {\n // If shape is a line, default y-anchor is 'bottom' (so that text is above line by default)\n // Otherwise, default y-anchor is equal to y-component of `textposition`\n // (so that text is positioned inside shape bounding box by default)\n return isLine ? 'bottom' :\n labelTextPosition.indexOf('top') !== -1 ? 'top' :\n labelTextPosition.indexOf('bottom') !== -1 ? 'bottom' : 'middle';\n}\n\nmodule.exports = function supplyDrawNewShapeDefaults(layoutIn, layoutOut, coerce) {\n coerce('newshape.visible');\n coerce('newshape.name');\n coerce('newshape.showlegend');\n coerce('newshape.legend');\n coerce('newshape.legendwidth');\n coerce('newshape.legendgroup');\n coerce('newshape.legendgrouptitle.text');\n Lib.coerceFont(coerce, 'newshape.legendgrouptitle.font');\n coerce('newshape.legendrank');\n\n coerce('newshape.drawdirection');\n coerce('newshape.layer');\n coerce('newshape.fillcolor');\n coerce('newshape.fillrule');\n coerce('newshape.opacity');\n var newshapeLineWidth = coerce('newshape.line.width');\n if(newshapeLineWidth) {\n var bgcolor = (layoutIn || {}).plot_bgcolor || '#FFF';\n coerce('newshape.line.color', Color.contrast(bgcolor));\n coerce('newshape.line.dash');\n }\n\n var isLine = layoutIn.dragmode === 'drawline';\n var labelText = coerce('newshape.label.text');\n var labelTextTemplate = coerce('newshape.label.texttemplate');\n if(labelText || labelTextTemplate) {\n coerce('newshape.label.textangle');\n var labelTextPosition = coerce('newshape.label.textposition', isLine ? 'middle' : 'middle center');\n coerce('newshape.label.xanchor');\n coerce('newshape.label.yanchor', dfltLabelYanchor(isLine, labelTextPosition));\n coerce('newshape.label.padding');\n Lib.coerceFont(coerce, 'newshape.label.font', layoutOut.font);\n }\n\n coerce('activeshape.fillcolor');\n coerce('activeshape.opacity');\n};\n","'use strict';\n\nvar parseSvgPath = require('parse-svg-path');\n\nvar constants = require('./constants');\nvar CIRCLE_SIDES = constants.CIRCLE_SIDES;\nvar SQRT2 = constants.SQRT2;\n\nvar cartesianHelpers = require('../../selections/helpers');\nvar p2r = cartesianHelpers.p2r;\nvar r2p = cartesianHelpers.r2p;\n\nvar iC = [0, 3, 4, 5, 6, 1, 2];\nvar iQS = [0, 3, 4, 1, 2];\n\nexports.writePaths = function(polygons) {\n var nI = polygons.length;\n if(!nI) return 'M0,0Z';\n\n var str = '';\n for(var i = 0; i < nI; i++) {\n var nJ = polygons[i].length;\n for(var j = 0; j < nJ; j++) {\n var w = polygons[i][j][0];\n if(w === 'Z') {\n str += 'Z';\n } else {\n var nK = polygons[i][j].length;\n for(var k = 0; k < nK; k++) {\n var realK = k;\n if(w === 'Q' || w === 'S') {\n realK = iQS[k];\n } else if(w === 'C') {\n realK = iC[k];\n }\n\n str += polygons[i][j][realK];\n if(k > 0 && k < nK - 1) {\n str += ',';\n }\n }\n }\n }\n }\n\n return str;\n};\n\nexports.readPaths = function(str, gd, plotinfo, isActiveShape) {\n var cmd = parseSvgPath(str);\n\n var polys = [];\n var n = -1;\n var newPoly = function() {\n n++;\n polys[n] = [];\n };\n\n var k;\n var x = 0;\n var y = 0;\n var initX;\n var initY;\n var recStart = function() {\n initX = x;\n initY = y;\n };\n\n recStart();\n for(var i = 0; i < cmd.length; i++) {\n var newPos = [];\n\n var x1, x2, y1, y2; // i.e. extra params for curves\n\n var c = cmd[i][0];\n var w = c;\n switch(c) {\n case 'M':\n newPoly();\n x = +cmd[i][1];\n y = +cmd[i][2];\n newPos.push([w, x, y]);\n\n recStart();\n break;\n\n case 'Q':\n case 'S':\n x1 = +cmd[i][1];\n y1 = +cmd[i][2];\n x = +cmd[i][3];\n y = +cmd[i][4];\n newPos.push([w, x, y, x1, y1]); // -> iQS order\n break;\n\n case 'C':\n x1 = +cmd[i][1];\n y1 = +cmd[i][2];\n x2 = +cmd[i][3];\n y2 = +cmd[i][4];\n x = +cmd[i][5];\n y = +cmd[i][6];\n newPos.push([w, x, y, x1, y1, x2, y2]); // -> iC order\n break;\n\n case 'T':\n case 'L':\n x = +cmd[i][1];\n y = +cmd[i][2];\n newPos.push([w, x, y]);\n break;\n\n case 'H':\n w = 'L'; // convert to line (for now)\n x = +cmd[i][1];\n newPos.push([w, x, y]);\n break;\n\n case 'V':\n w = 'L'; // convert to line (for now)\n y = +cmd[i][1];\n newPos.push([w, x, y]);\n break;\n\n case 'A':\n w = 'L'; // convert to line to handle circle\n var rx = +cmd[i][1];\n var ry = +cmd[i][2];\n if(!+cmd[i][4]) {\n rx = -rx;\n ry = -ry;\n }\n\n var cenX = x - rx;\n var cenY = y;\n for(k = 1; k <= CIRCLE_SIDES / 2; k++) {\n var t = 2 * Math.PI * k / CIRCLE_SIDES;\n newPos.push([\n w,\n cenX + rx * Math.cos(t),\n cenY + ry * Math.sin(t)\n ]);\n }\n break;\n\n case 'Z':\n if(x !== initX || y !== initY) {\n x = initX;\n y = initY;\n newPos.push([w, x, y]);\n }\n break;\n }\n\n var domain = (plotinfo || {}).domain;\n var size = gd._fullLayout._size;\n var xPixelSized = plotinfo && plotinfo.xsizemode === 'pixel';\n var yPixelSized = plotinfo && plotinfo.ysizemode === 'pixel';\n var noOffset = isActiveShape === false;\n\n for(var j = 0; j < newPos.length; j++) {\n for(k = 0; k + 2 < 7; k += 2) {\n var _x = newPos[j][k + 1];\n var _y = newPos[j][k + 2];\n\n if(_x === undefined || _y === undefined) continue;\n // keep track of end point for Z\n x = _x;\n y = _y;\n\n if(plotinfo) {\n if(plotinfo.xaxis && plotinfo.xaxis.p2r) {\n if(noOffset) _x -= plotinfo.xaxis._offset;\n if(xPixelSized) {\n _x = r2p(plotinfo.xaxis, plotinfo.xanchor) + _x;\n } else {\n _x = p2r(plotinfo.xaxis, _x);\n }\n } else {\n if(noOffset) _x -= size.l;\n if(domain) _x = domain.x[0] + _x / size.w;\n else _x = _x / size.w;\n }\n\n if(plotinfo.yaxis && plotinfo.yaxis.p2r) {\n if(noOffset) _y -= plotinfo.yaxis._offset;\n if(yPixelSized) {\n _y = r2p(plotinfo.yaxis, plotinfo.yanchor) - _y;\n } else {\n _y = p2r(plotinfo.yaxis, _y);\n }\n } else {\n if(noOffset) _y -= size.t;\n if(domain) _y = domain.y[1] - _y / size.h;\n else _y = 1 - _y / size.h;\n }\n }\n\n newPos[j][k + 1] = _x;\n newPos[j][k + 2] = _y;\n }\n polys[n].push(\n newPos[j].slice()\n );\n }\n }\n\n return polys;\n};\n\nfunction almostEq(a, b) {\n return Math.abs(a - b) <= 1e-6;\n}\n\nfunction dist(a, b) {\n var dx = b[1] - a[1];\n var dy = b[2] - a[2];\n return Math.sqrt(\n dx * dx +\n dy * dy\n );\n}\n\nexports.pointsOnRectangle = function(cell) {\n var len = cell.length;\n if(len !== 5) return false;\n\n for(var j = 1; j < 3; j++) {\n var e01 = cell[0][j] - cell[1][j];\n var e32 = cell[3][j] - cell[2][j];\n\n if(!almostEq(e01, e32)) return false;\n\n var e03 = cell[0][j] - cell[3][j];\n var e12 = cell[1][j] - cell[2][j];\n if(!almostEq(e03, e12)) return false;\n }\n\n // N.B. rotated rectangles are not valid rects since rotation is not supported in shapes for now.\n if(\n !almostEq(cell[0][1], cell[1][1]) &&\n !almostEq(cell[0][1], cell[3][1])\n ) return false;\n\n // reject cases with zero area\n return !!(\n dist(cell[0], cell[1]) *\n dist(cell[0], cell[3])\n );\n};\n\nexports.pointsOnEllipse = function(cell) {\n var len = cell.length;\n if(len !== CIRCLE_SIDES + 1) return false;\n\n // opposite diagonals should be the same\n len = CIRCLE_SIDES;\n for(var i = 0; i < len; i++) {\n var k = (len * 2 - i) % len;\n\n var k2 = (len / 2 + k) % len;\n var i2 = (len / 2 + i) % len;\n\n if(!almostEq(\n dist(cell[i], cell[i2]),\n dist(cell[k], cell[k2])\n )) return false;\n }\n return true;\n};\n\nexports.handleEllipse = function(isEllipse, start, end) {\n if(!isEllipse) return [start, end]; // i.e. case of line\n\n var pos = exports.ellipseOver({\n x0: start[0],\n y0: start[1],\n x1: end[0],\n y1: end[1]\n });\n\n var cx = (pos.x1 + pos.x0) / 2;\n var cy = (pos.y1 + pos.y0) / 2;\n var rx = (pos.x1 - pos.x0) / 2;\n var ry = (pos.y1 - pos.y0) / 2;\n\n // make a circle when one dimension is zero\n if(!rx) rx = ry = ry / SQRT2;\n if(!ry) ry = rx = rx / SQRT2;\n\n var cell = [];\n for(var i = 0; i < CIRCLE_SIDES; i++) {\n var t = i * 2 * Math.PI / CIRCLE_SIDES;\n cell.push([\n cx + rx * Math.cos(t),\n cy + ry * Math.sin(t),\n ]);\n }\n return cell;\n};\n\nexports.ellipseOver = function(pos) {\n var x0 = pos.x0;\n var y0 = pos.y0;\n var x1 = pos.x1;\n var y1 = pos.y1;\n\n var dx = x1 - x0;\n var dy = y1 - y0;\n\n x0 -= dx;\n y0 -= dy;\n\n var cx = (x0 + x1) / 2;\n var cy = (y0 + y1) / 2;\n\n var scale = SQRT2;\n dx *= scale;\n dy *= scale;\n\n return {\n x0: cx - dx,\n y0: cy - dy,\n x1: cx + dx,\n y1: cy + dy\n };\n};\n\nexports.fixDatesForPaths = function(polygons, xaxis, yaxis) {\n var xIsDate = xaxis.type === 'date';\n var yIsDate = yaxis.type === 'date';\n if(!xIsDate && !yIsDate) return polygons;\n\n for(var i = 0; i < polygons.length; i++) {\n for(var j = 0; j < polygons[i].length; j++) {\n for(var k = 0; k + 2 < polygons[i][j].length; k += 2) {\n if(xIsDate) polygons[i][j][k + 1] = polygons[i][j][k + 1].replace(' ', '_');\n if(yIsDate) polygons[i][j][k + 2] = polygons[i][j][k + 2].replace(' ', '_');\n }\n }\n }\n\n return polygons;\n};\n","'use strict';\n\nvar dragHelpers = require('../../dragelement/helpers');\nvar drawMode = dragHelpers.drawMode;\nvar openMode = dragHelpers.openMode;\n\nvar constants = require('./constants');\nvar i000 = constants.i000;\nvar i090 = constants.i090;\nvar i180 = constants.i180;\nvar i270 = constants.i270;\nvar cos45 = constants.cos45;\nvar sin45 = constants.sin45;\n\nvar cartesianHelpers = require('../../selections/helpers');\nvar p2r = cartesianHelpers.p2r;\nvar r2p = cartesianHelpers.r2p;\n\nvar handleOutline = require('.././handle_outline');\nvar clearOutline = handleOutline.clearOutline;\n\nvar helpers = require('./helpers');\nvar readPaths = helpers.readPaths;\nvar writePaths = helpers.writePaths;\nvar ellipseOver = helpers.ellipseOver;\nvar fixDatesForPaths = helpers.fixDatesForPaths;\n\nfunction newShapes(outlines, dragOptions) {\n if(!outlines.length) return;\n var e = outlines[0][0]; // pick first\n if(!e) return;\n\n var gd = dragOptions.gd;\n\n var isActiveShape = dragOptions.isActiveShape;\n var dragmode = dragOptions.dragmode;\n\n var shapes = (gd.layout || {}).shapes || [];\n\n if(!drawMode(dragmode) && isActiveShape !== undefined) {\n var id = gd._fullLayout._activeShapeIndex;\n if(id < shapes.length) {\n switch(gd._fullLayout.shapes[id].type) {\n case 'rect':\n dragmode = 'drawrect';\n break;\n case 'circle':\n dragmode = 'drawcircle';\n break;\n case 'line':\n dragmode = 'drawline';\n break;\n case 'path':\n var path = shapes[id].path || '';\n if(path[path.length - 1] === 'Z') {\n dragmode = 'drawclosedpath';\n } else {\n dragmode = 'drawopenpath';\n }\n break;\n }\n }\n }\n\n var newShape = createShapeObj(outlines, dragOptions, dragmode);\n\n clearOutline(gd);\n\n var editHelpers = dragOptions.editHelpers;\n var modifyItem = (editHelpers || {}).modifyItem;\n\n var allShapes = [];\n for(var q = 0; q < shapes.length; q++) {\n var beforeEdit = gd._fullLayout.shapes[q];\n allShapes[q] = beforeEdit._input;\n\n if(\n isActiveShape !== undefined &&\n q === gd._fullLayout._activeShapeIndex\n ) {\n var afterEdit = newShape;\n\n switch(beforeEdit.type) {\n case 'line':\n case 'rect':\n case 'circle':\n modifyItem('x0', afterEdit.x0 - (beforeEdit.x0shift || 0));\n modifyItem('x1', afterEdit.x1 - (beforeEdit.x1shift || 0));\n modifyItem('y0', afterEdit.y0 - (beforeEdit.y0shift || 0));\n modifyItem('y1', afterEdit.y1 - (beforeEdit.y1shift || 0));\n break;\n\n case 'path':\n modifyItem('path', afterEdit.path);\n break;\n }\n }\n }\n\n if(isActiveShape === undefined) {\n allShapes.push(newShape); // add new shape\n return allShapes;\n }\n\n return editHelpers ? editHelpers.getUpdateObj() : {};\n}\n\nfunction createShapeObj(outlines, dragOptions, dragmode) {\n var e = outlines[0][0]; // pick first outline\n var gd = dragOptions.gd;\n\n var d = e.getAttribute('d');\n var newStyle = gd._fullLayout.newshape;\n var plotinfo = dragOptions.plotinfo;\n var isActiveShape = dragOptions.isActiveShape;\n\n var xaxis = plotinfo.xaxis;\n var yaxis = plotinfo.yaxis;\n var xPaper = !!plotinfo.domain || !plotinfo.xaxis;\n var yPaper = !!plotinfo.domain || !plotinfo.yaxis;\n\n var isOpenMode = openMode(dragmode);\n var polygons = readPaths(d, gd, plotinfo, isActiveShape);\n\n var newShape = {\n editable: true,\n\n visible: newStyle.visible,\n name: newStyle.name,\n showlegend: newStyle.showlegend,\n legend: newStyle.legend,\n legendwidth: newStyle.legendwidth,\n legendgroup: newStyle.legendgroup,\n legendgrouptitle: {\n text: newStyle.legendgrouptitle.text,\n font: newStyle.legendgrouptitle.font\n },\n legendrank: newStyle.legendrank,\n\n label: newStyle.label,\n\n xref: xPaper ? 'paper' : xaxis._id,\n yref: yPaper ? 'paper' : yaxis._id,\n\n layer: newStyle.layer,\n opacity: newStyle.opacity,\n line: {\n color: newStyle.line.color,\n width: newStyle.line.width,\n dash: newStyle.line.dash\n }\n };\n\n if(!isOpenMode) {\n newShape.fillcolor = newStyle.fillcolor;\n newShape.fillrule = newStyle.fillrule;\n }\n\n var cell;\n // line, rect and circle can be in one cell\n // only define cell if there is single cell\n if(polygons.length === 1) cell = polygons[0];\n\n if(\n cell &&\n cell.length === 5 && // ensure we only have 4 corners for a rect\n dragmode === 'drawrect'\n ) {\n newShape.type = 'rect';\n newShape.x0 = cell[0][1];\n newShape.y0 = cell[0][2];\n newShape.x1 = cell[2][1];\n newShape.y1 = cell[2][2];\n } else if(\n cell &&\n dragmode === 'drawline'\n ) {\n newShape.type = 'line';\n newShape.x0 = cell[0][1];\n newShape.y0 = cell[0][2];\n newShape.x1 = cell[1][1];\n newShape.y1 = cell[1][2];\n } else if(\n cell &&\n dragmode === 'drawcircle'\n ) {\n newShape.type = 'circle'; // an ellipse!\n\n var xA = cell[i000][1];\n var xB = cell[i090][1];\n var xC = cell[i180][1];\n var xD = cell[i270][1];\n\n var yA = cell[i000][2];\n var yB = cell[i090][2];\n var yC = cell[i180][2];\n var yD = cell[i270][2];\n\n var xDateOrLog = plotinfo.xaxis && (\n plotinfo.xaxis.type === 'date' ||\n plotinfo.xaxis.type === 'log'\n );\n\n var yDateOrLog = plotinfo.yaxis && (\n plotinfo.yaxis.type === 'date' ||\n plotinfo.yaxis.type === 'log'\n );\n\n if(xDateOrLog) {\n xA = r2p(plotinfo.xaxis, xA);\n xB = r2p(plotinfo.xaxis, xB);\n xC = r2p(plotinfo.xaxis, xC);\n xD = r2p(plotinfo.xaxis, xD);\n }\n\n if(yDateOrLog) {\n yA = r2p(plotinfo.yaxis, yA);\n yB = r2p(plotinfo.yaxis, yB);\n yC = r2p(plotinfo.yaxis, yC);\n yD = r2p(plotinfo.yaxis, yD);\n }\n\n var x0 = (xB + xD) / 2;\n var y0 = (yA + yC) / 2;\n var rx = (xD - xB + xC - xA) / 2;\n var ry = (yD - yB + yC - yA) / 2;\n var pos = ellipseOver({\n x0: x0,\n y0: y0,\n x1: x0 + rx * cos45,\n y1: y0 + ry * sin45\n });\n\n if(xDateOrLog) {\n pos.x0 = p2r(plotinfo.xaxis, pos.x0);\n pos.x1 = p2r(plotinfo.xaxis, pos.x1);\n }\n\n if(yDateOrLog) {\n pos.y0 = p2r(plotinfo.yaxis, pos.y0);\n pos.y1 = p2r(plotinfo.yaxis, pos.y1);\n }\n\n newShape.x0 = pos.x0;\n newShape.y0 = pos.y0;\n newShape.x1 = pos.x1;\n newShape.y1 = pos.y1;\n } else {\n newShape.type = 'path';\n if(xaxis && yaxis) fixDatesForPaths(polygons, xaxis, yaxis);\n newShape.path = writePaths(polygons);\n cell = null;\n }\n return newShape;\n}\n\nmodule.exports = {\n newShapes: newShapes,\n createShapeObj: createShapeObj,\n};\n","'use strict';\n\nfunction clearOutlineControllers(gd) {\n var zoomLayer = gd._fullLayout._zoomlayer;\n if(zoomLayer) {\n zoomLayer.selectAll('.outline-controllers').remove();\n }\n}\n\nfunction clearOutline(gd) {\n var zoomLayer = gd._fullLayout._zoomlayer;\n if(zoomLayer) {\n // until we get around to persistent selections, remove the outline\n // here. The selection itself will be removed when the plot redraws\n // at the end.\n zoomLayer.selectAll('.select-outline').remove();\n }\n\n gd._fullLayout._outlining = false;\n}\n\nmodule.exports = {\n clearOutlineControllers: clearOutlineControllers,\n clearOutline: clearOutline\n};\n","'use strict';\n\nvar constants = require('./constants');\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\n\n// special position conversion functions... category axis positions can't be\n// specified by their data values, because they don't make a continuous mapping.\n// so these have to be specified in terms of the category serial numbers,\n// but can take fractional values. Other axis types we specify position based on\n// the actual data values.\n// TODO: in V3.0 (when log axis ranges are in data units) range and shape position\n// will be identical, so rangeToShapePosition and shapePositionToRange can be\n// removed entirely.\n\nexports.rangeToShapePosition = function(ax) {\n return (ax.type === 'log') ? ax.r2d : function(v) { return v; };\n};\n\nexports.shapePositionToRange = function(ax) {\n return (ax.type === 'log') ? ax.d2r : function(v) { return v; };\n};\n\nexports.decodeDate = function(convertToPx) {\n return function(v) {\n if(v.replace) v = v.replace('_', ' ');\n return convertToPx(v);\n };\n};\n\nexports.encodeDate = function(convertToDate) {\n return function(v) { return convertToDate(v).replace(' ', '_'); };\n};\n\nexports.extractPathCoords = function(path, paramsToUse, isRaw) {\n var extractedCoordinates = [];\n\n var segments = path.match(constants.segmentRE);\n segments.forEach(function(segment) {\n var relevantParamIdx = paramsToUse[segment.charAt(0)].drawn;\n if(relevantParamIdx === undefined) return;\n\n var params = segment.substr(1).match(constants.paramRE);\n if(!params || params.length < relevantParamIdx) return;\n\n var str = params[relevantParamIdx];\n var pos = isRaw ? str : Lib.cleanNumber(str);\n\n extractedCoordinates.push(pos);\n });\n\n return extractedCoordinates;\n};\n\nexports.getDataToPixel = function(gd, axis, shift, isVertical, refType) {\n var gs = gd._fullLayout._size;\n var dataToPixel;\n\n if(axis) {\n if(refType === 'domain') {\n dataToPixel = function(v) {\n return axis._length * (isVertical ? (1 - v) : v) + axis._offset;\n };\n } else {\n var d2r = exports.shapePositionToRange(axis);\n\n dataToPixel = function(v) {\n var shiftPixels = getPixelShift(axis, shift);\n return axis._offset + axis.r2p(d2r(v, true)) + shiftPixels;\n };\n\n if(axis.type === 'date') dataToPixel = exports.decodeDate(dataToPixel);\n }\n } else if(isVertical) {\n dataToPixel = function(v) { return gs.t + gs.h * (1 - v); };\n } else {\n dataToPixel = function(v) { return gs.l + gs.w * v; };\n }\n\n return dataToPixel;\n};\n\nexports.getPixelToData = function(gd, axis, isVertical, opt) {\n var gs = gd._fullLayout._size;\n var pixelToData;\n\n if(axis) {\n if(opt === 'domain') {\n pixelToData = function(p) {\n var q = (p - axis._offset) / axis._length;\n return isVertical ? 1 - q : q;\n };\n } else {\n var r2d = exports.rangeToShapePosition(axis);\n pixelToData = function(p) { return r2d(axis.p2r(p - axis._offset)); };\n }\n } else if(isVertical) {\n pixelToData = function(p) { return 1 - (p - gs.t) / gs.h; };\n } else {\n pixelToData = function(p) { return (p - gs.l) / gs.w; };\n }\n\n return pixelToData;\n};\n\n/**\n * Based on the given stroke width, rounds the passed\n * position value to represent either a full or half pixel.\n *\n * In case of an odd stroke width (e.g. 1), this measure ensures\n * that a stroke positioned at the returned position isn't rendered\n * blurry due to anti-aliasing.\n *\n * In case of an even stroke width (e.g. 2), this measure ensures\n * that the position value is transformed to a full pixel value\n * so that anti-aliasing doesn't take effect either.\n *\n * @param {number} pos The raw position value to be transformed\n * @param {number} strokeWidth The stroke width\n * @returns {number} either an integer or a .5 decimal number\n */\nexports.roundPositionForSharpStrokeRendering = function(pos, strokeWidth) {\n var strokeWidthIsOdd = Math.round(strokeWidth % 2) === 1;\n var posValAsInt = Math.round(pos);\n\n return strokeWidthIsOdd ? posValAsInt + 0.5 : posValAsInt;\n};\n\nexports.makeShapesOptionsAndPlotinfo = function(gd, index) {\n var options = gd._fullLayout.shapes[index] || {};\n\n var plotinfo = gd._fullLayout._plots[options.xref + options.yref];\n var hasPlotinfo = !!plotinfo;\n if(hasPlotinfo) {\n plotinfo._hadPlotinfo = true;\n } else {\n plotinfo = {};\n if(options.xref && options.xref !== 'paper') plotinfo.xaxis = gd._fullLayout[options.xref + 'axis'];\n if(options.yref && options.yref !== 'paper') plotinfo.yaxis = gd._fullLayout[options.yref + 'axis'];\n }\n\n plotinfo.xsizemode = options.xsizemode;\n plotinfo.ysizemode = options.ysizemode;\n plotinfo.xanchor = options.xanchor;\n plotinfo.yanchor = options.yanchor;\n\n return {\n options: options,\n plotinfo: plotinfo\n };\n};\n\n// TODO: move to selections helpers?\nexports.makeSelectionsOptionsAndPlotinfo = function(gd, index) {\n var options = gd._fullLayout.selections[index] || {};\n\n var plotinfo = gd._fullLayout._plots[options.xref + options.yref];\n var hasPlotinfo = !!plotinfo;\n if(hasPlotinfo) {\n plotinfo._hadPlotinfo = true;\n } else {\n plotinfo = {};\n if(options.xref) plotinfo.xaxis = gd._fullLayout[options.xref + 'axis'];\n if(options.yref) plotinfo.yaxis = gd._fullLayout[options.yref + 'axis'];\n }\n\n return {\n options: options,\n plotinfo: plotinfo\n };\n};\n\n\nexports.getPathString = function(gd, options) {\n var type = options.type;\n var xRefType = Axes.getRefType(options.xref);\n var yRefType = Axes.getRefType(options.yref);\n var xa = Axes.getFromId(gd, options.xref);\n var ya = Axes.getFromId(gd, options.yref);\n var gs = gd._fullLayout._size;\n var x2r, x2p, y2r, y2p;\n var xShiftStart = getPixelShift(xa, options.x0shift);\n var xShiftEnd = getPixelShift(xa, options.x1shift);\n var yShiftStart = getPixelShift(ya, options.y0shift);\n var yShiftEnd = getPixelShift(ya, options.y1shift);\n var x0, x1, y0, y1;\n\n if(xa) {\n if(xRefType === 'domain') {\n x2p = function(v) { return xa._offset + xa._length * v; };\n } else {\n x2r = exports.shapePositionToRange(xa);\n x2p = function(v) { return xa._offset + xa.r2p(x2r(v, true)); };\n }\n } else {\n x2p = function(v) { return gs.l + gs.w * v; };\n }\n\n if(ya) {\n if(yRefType === 'domain') {\n y2p = function(v) { return ya._offset + ya._length * (1 - v); };\n } else {\n y2r = exports.shapePositionToRange(ya);\n y2p = function(v) { return ya._offset + ya.r2p(y2r(v, true)); };\n }\n } else {\n y2p = function(v) { return gs.t + gs.h * (1 - v); };\n }\n\n if(type === 'path') {\n if(xa && xa.type === 'date') x2p = exports.decodeDate(x2p);\n if(ya && ya.type === 'date') y2p = exports.decodeDate(y2p);\n return convertPath(options, x2p, y2p);\n }\n if(options.xsizemode === 'pixel') {\n var xAnchorPos = x2p(options.xanchor);\n x0 = xAnchorPos + options.x0 + xShiftStart;\n x1 = xAnchorPos + options.x1 + xShiftEnd;\n } else {\n x0 = x2p(options.x0) + xShiftStart;\n x1 = x2p(options.x1) + xShiftEnd;\n }\n\n if(options.ysizemode === 'pixel') {\n var yAnchorPos = y2p(options.yanchor);\n y0 = yAnchorPos - options.y0 + yShiftStart;\n y1 = yAnchorPos - options.y1 + yShiftEnd;\n } else {\n y0 = y2p(options.y0) + yShiftStart;\n y1 = y2p(options.y1) + yShiftEnd;\n }\n\n if(type === 'line') return 'M' + x0 + ',' + y0 + 'L' + x1 + ',' + y1;\n if(type === 'rect') return 'M' + x0 + ',' + y0 + 'H' + x1 + 'V' + y1 + 'H' + x0 + 'Z';\n\n // circle\n var cx = (x0 + x1) / 2;\n var cy = (y0 + y1) / 2;\n var rx = Math.abs(cx - x0);\n var ry = Math.abs(cy - y0);\n var rArc = 'A' + rx + ',' + ry;\n var rightPt = (cx + rx) + ',' + cy;\n var topPt = cx + ',' + (cy - ry);\n return 'M' + rightPt + rArc + ' 0 1,1 ' + topPt +\n rArc + ' 0 0,1 ' + rightPt + 'Z';\n};\n\n\nfunction convertPath(options, x2p, y2p) {\n var pathIn = options.path;\n var xSizemode = options.xsizemode;\n var ySizemode = options.ysizemode;\n var xAnchor = options.xanchor;\n var yAnchor = options.yanchor;\n\n return pathIn.replace(constants.segmentRE, function(segment) {\n var paramNumber = 0;\n var segmentType = segment.charAt(0);\n var xParams = constants.paramIsX[segmentType];\n var yParams = constants.paramIsY[segmentType];\n var nParams = constants.numParams[segmentType];\n\n var paramString = segment.substr(1).replace(constants.paramRE, function(param) {\n if(xParams[paramNumber]) {\n if(xSizemode === 'pixel') param = x2p(xAnchor) + Number(param);\n else param = x2p(param);\n } else if(yParams[paramNumber]) {\n if(ySizemode === 'pixel') param = y2p(yAnchor) - Number(param);\n else param = y2p(param);\n }\n paramNumber++;\n\n if(paramNumber > nParams) param = 'X';\n return param;\n });\n\n if(paramNumber > nParams) {\n paramString = paramString.replace(/[\\s,]*X.*/, '');\n Lib.log('Ignoring extra params in segment ' + segment);\n }\n\n return segmentType + paramString;\n });\n}\n\nfunction getPixelShift(axis, shift) {\n shift = shift || 0;\n var shiftPixels = 0;\n if(shift && axis && (axis.type === 'category' || axis.type === 'multicategory')) {\n shiftPixels = (axis.r2p(1) - axis.r2p(0)) * shift;\n }\n return shiftPixels;\n}\n","'use strict';\n\nvar drawModule = require('./draw');\n\nmodule.exports = {\n moduleType: 'component',\n name: 'shapes',\n\n layoutAttributes: require('./attributes'),\n supplyLayoutDefaults: require('./defaults'),\n supplyDrawNewShapeDefaults: require('./draw_newshape/defaults'),\n includeBasePlot: require('../../plots/cartesian/include_components')('shapes'),\n\n calcAutorange: require('./calc_autorange'),\n draw: drawModule.draw,\n drawOne: drawModule.drawOne\n};\n","'use strict';\n\n// Wrapper functions to handle paper-referenced shapes, which have no axis\n\nfunction d2l(v, axis) {\n return axis ? axis.d2l(v) : v;\n}\n\nfunction l2d(v, axis) {\n return axis ? axis.l2d(v) : v;\n}\n\n\nfunction x0Fn(shape) { return shape.x0; }\nfunction x1Fn(shape) { return shape.x1; }\nfunction y0Fn(shape) { return shape.y0; }\nfunction y1Fn(shape) { return shape.y1; }\n\nfunction x0shiftFn(shape) { return shape.x0shift || 0; }\nfunction x1shiftFn(shape) { return shape.x1shift || 0; }\nfunction y0shiftFn(shape) { return shape.y0shift || 0; }\nfunction y1shiftFn(shape) { return shape.y1shift || 0; }\n\nfunction dxFn(shape, xa) {\n return d2l(shape.x1, xa) + x1shiftFn(shape) - d2l(shape.x0, xa) - x0shiftFn(shape);\n}\n\nfunction dyFn(shape, xa, ya) {\n return d2l(shape.y1, ya) + y1shiftFn(shape) - d2l(shape.y0, ya) - y0shiftFn(shape);\n}\n\nfunction widthFn(shape, xa) {\n return Math.abs(dxFn(shape, xa));\n}\n\nfunction heightFn(shape, xa, ya) {\n return Math.abs(dyFn(shape, xa, ya));\n}\n\nfunction lengthFn(shape, xa, ya) {\n return (shape.type !== 'line') ? undefined :\n Math.sqrt(\n Math.pow(dxFn(shape, xa), 2) +\n Math.pow(dyFn(shape, xa, ya), 2)\n );\n}\n\nfunction xcenterFn(shape, xa) {\n return l2d((d2l(shape.x1, xa) + x1shiftFn(shape) + d2l(shape.x0, xa) + x0shiftFn(shape)) / 2, xa);\n}\n\nfunction ycenterFn(shape, xa, ya) {\n return l2d((d2l(shape.y1, ya) + y1shiftFn(shape) + d2l(shape.y0, ya) + y0shiftFn(shape)) / 2, ya);\n}\n\nfunction slopeFn(shape, xa, ya) {\n return (shape.type !== 'line') ? undefined : (\n dyFn(shape, xa, ya) / dxFn(shape, xa)\n );\n}\n\nmodule.exports = {\n x0: x0Fn,\n x1: x1Fn,\n y0: y0Fn,\n y1: y1Fn,\n slope: slopeFn,\n dx: dxFn,\n dy: dyFn,\n width: widthFn,\n height: heightFn,\n length: lengthFn,\n xcenter: xcenterFn,\n ycenter: ycenterFn,\n};\n","'use strict';\n\nvar fontAttrs = require('../../plots/font_attributes');\nvar padAttrs = require('../../plots/pad_attributes');\nvar extendDeepAll = require('../../lib/extend').extendDeepAll;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar animationAttrs = require('../../plots/animation_attributes');\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\nvar constants = require('./constants');\n\nvar stepsAttrs = templatedArray('step', {\n visible: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Determines whether or not this step is included in the slider.'\n ].join(' ')\n },\n method: {\n valType: 'enumerated',\n values: ['restyle', 'relayout', 'animate', 'update', 'skip'],\n dflt: 'restyle',\n description: [\n 'Sets the Plotly method to be called when the slider value is changed.',\n 'If the `skip` method is used, the API slider will function as normal',\n 'but will perform no API calls and will not bind automatically to state',\n 'updates. This may be used to create a component interface and attach to',\n 'slider events manually via JavaScript.'\n ].join(' ')\n },\n args: {\n valType: 'info_array',\n freeLength: true,\n items: [\n { valType: 'any' },\n { valType: 'any' },\n { valType: 'any' }\n ],\n description: [\n 'Sets the arguments values to be passed to the Plotly',\n 'method set in `method` on slide.'\n ].join(' ')\n },\n label: {\n valType: 'string',\n description: 'Sets the text label to appear on the slider'\n },\n value: {\n valType: 'string',\n description: [\n 'Sets the value of the slider step, used to refer to the step programatically.',\n 'Defaults to the slider label if not provided.'\n ].join(' ')\n },\n execute: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'When true, the API method is executed. When false, all other behaviors are the same',\n 'and command execution is skipped. This may be useful when hooking into, for example,',\n 'the `plotly_sliderchange` method and executing the API command manually without losing',\n 'the benefit of the slider automatically binding to the state of the plot through the',\n 'specification of `method` and `args`.'\n ].join(' ')\n }\n});\n\nmodule.exports = overrideAll(templatedArray('slider', {\n visible: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Determines whether or not the slider is visible.'\n ].join(' ')\n },\n\n active: {\n valType: 'number',\n min: 0,\n dflt: 0,\n description: [\n 'Determines which button (by index starting from 0) is',\n 'considered active.'\n ].join(' ')\n },\n\n steps: stepsAttrs,\n\n lenmode: {\n valType: 'enumerated',\n values: ['fraction', 'pixels'],\n dflt: 'fraction',\n description: [\n 'Determines whether this slider length',\n 'is set in units of plot *fraction* or in *pixels.',\n 'Use `len` to set the value.'\n ].join(' ')\n },\n len: {\n valType: 'number',\n min: 0,\n dflt: 1,\n description: [\n 'Sets the length of the slider',\n 'This measure excludes the padding of both ends.',\n 'That is, the slider\\'s length is this length minus the',\n 'padding on both ends.'\n ].join(' ')\n },\n x: {\n valType: 'number',\n min: -2,\n max: 3,\n dflt: 0,\n description: 'Sets the x position (in normalized coordinates) of the slider.'\n },\n pad: extendDeepAll(padAttrs({editType: 'arraydraw'}), {\n description: 'Set the padding of the slider component along each side.'\n }, {t: {dflt: 20}}),\n xanchor: {\n valType: 'enumerated',\n values: ['auto', 'left', 'center', 'right'],\n dflt: 'left',\n description: [\n 'Sets the slider\\'s horizontal position anchor.',\n 'This anchor binds the `x` position to the *left*, *center*',\n 'or *right* of the range selector.'\n ].join(' ')\n },\n y: {\n valType: 'number',\n min: -2,\n max: 3,\n dflt: 0,\n description: 'Sets the y position (in normalized coordinates) of the slider.'\n },\n yanchor: {\n valType: 'enumerated',\n values: ['auto', 'top', 'middle', 'bottom'],\n dflt: 'top',\n description: [\n 'Sets the slider\\'s vertical position anchor',\n 'This anchor binds the `y` position to the *top*, *middle*',\n 'or *bottom* of the range selector.'\n ].join(' ')\n },\n\n transition: {\n duration: {\n valType: 'number',\n min: 0,\n dflt: 150,\n description: 'Sets the duration of the slider transition'\n },\n easing: {\n valType: 'enumerated',\n values: animationAttrs.transition.easing.values,\n dflt: 'cubic-in-out',\n description: 'Sets the easing function of the slider transition'\n }\n },\n\n currentvalue: {\n visible: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Shows the currently-selected value above the slider.'\n ].join(' ')\n },\n\n xanchor: {\n valType: 'enumerated',\n values: ['left', 'center', 'right'],\n dflt: 'left',\n description: [\n 'The alignment of the value readout relative to the length of the slider.'\n ].join(' ')\n },\n\n offset: {\n valType: 'number',\n dflt: 10,\n description: [\n 'The amount of space, in pixels, between the current value label',\n 'and the slider.'\n ].join(' ')\n },\n\n prefix: {\n valType: 'string',\n description: 'When currentvalue.visible is true, this sets the prefix of the label.'\n },\n\n suffix: {\n valType: 'string',\n description: 'When currentvalue.visible is true, this sets the suffix of the label.'\n },\n\n font: fontAttrs({\n description: 'Sets the font of the current value label text.'\n })\n },\n\n font: fontAttrs({\n description: 'Sets the font of the slider step labels.'\n }),\n\n activebgcolor: {\n valType: 'color',\n dflt: constants.gripBgActiveColor,\n description: [\n 'Sets the background color of the slider grip',\n 'while dragging.'\n ].join(' ')\n },\n bgcolor: {\n valType: 'color',\n dflt: constants.railBgColor,\n description: 'Sets the background color of the slider.'\n },\n bordercolor: {\n valType: 'color',\n dflt: constants.railBorderColor,\n description: 'Sets the color of the border enclosing the slider.'\n },\n borderwidth: {\n valType: 'number',\n min: 0,\n dflt: constants.railBorderWidth,\n description: 'Sets the width (in px) of the border enclosing the slider.'\n },\n ticklen: {\n valType: 'number',\n min: 0,\n dflt: constants.tickLength,\n description: 'Sets the length in pixels of step tick marks'\n },\n tickcolor: {\n valType: 'color',\n dflt: constants.tickColor,\n description: 'Sets the color of the border enclosing the slider.'\n },\n tickwidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n description: 'Sets the tick width (in px).'\n },\n minorticklen: {\n valType: 'number',\n min: 0,\n dflt: constants.minorTickLength,\n description: 'Sets the length in pixels of minor step tick marks'\n }\n}), 'arraydraw', 'from-root');\n","'use strict';\n\n\nmodule.exports = {\n\n // layout attribute name\n name: 'sliders',\n\n // class names\n containerClassName: 'slider-container',\n groupClassName: 'slider-group',\n inputAreaClass: 'slider-input-area',\n railRectClass: 'slider-rail-rect',\n railTouchRectClass: 'slider-rail-touch-rect',\n gripRectClass: 'slider-grip-rect',\n tickRectClass: 'slider-tick-rect',\n inputProxyClass: 'slider-input-proxy',\n labelsClass: 'slider-labels',\n labelGroupClass: 'slider-label-group',\n labelClass: 'slider-label',\n currentValueClass: 'slider-current-value',\n\n railHeight: 5,\n\n // DOM attribute name in button group keeping track\n // of active update menu\n menuIndexAttrName: 'slider-active-index',\n\n // id root pass to Plots.autoMargin\n autoMarginIdRoot: 'slider-',\n\n // min item width / height\n minWidth: 30,\n minHeight: 30,\n\n // padding around item text\n textPadX: 40,\n\n // arrow offset off right edge\n arrowOffsetX: 4,\n\n railRadius: 2,\n railWidth: 5,\n railBorder: 4,\n railBorderWidth: 1,\n railBorderColor: '#bec8d9',\n railBgColor: '#f8fafc',\n\n // The distance of the rail from the edge of the touchable area\n // Slightly less than the step inset because of the curved edges\n // of the rail\n railInset: 8,\n\n // The distance from the extremal tick marks to the edge of the\n // touchable area. This is basically the same as the grip radius,\n // but for other styles it wouldn't really need to be.\n stepInset: 10,\n\n gripRadius: 10,\n gripWidth: 20,\n gripHeight: 20,\n gripBorder: 20,\n gripBorderWidth: 1,\n gripBorderColor: '#bec8d9',\n gripBgColor: '#f6f8fa',\n gripBgActiveColor: '#dbdde0',\n\n labelPadding: 8,\n labelOffset: 0,\n\n tickWidth: 1,\n tickColor: '#333',\n tickOffset: 25,\n tickLength: 7,\n\n minorTickOffset: 25,\n minorTickColor: '#333',\n minorTickLength: 4,\n\n // Extra space below the current value label:\n currentValuePadding: 8,\n currentValueInset: 0,\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar attributes = require('./attributes');\nvar constants = require('./constants');\n\nvar name = constants.name;\nvar stepAttrs = attributes.steps;\n\n\nmodule.exports = function slidersDefaults(layoutIn, layoutOut) {\n handleArrayContainerDefaults(layoutIn, layoutOut, {\n name: name,\n handleItemDefaults: sliderDefaults\n });\n};\n\nfunction sliderDefaults(sliderIn, sliderOut, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(sliderIn, sliderOut, attributes, attr, dflt);\n }\n\n var steps = handleArrayContainerDefaults(sliderIn, sliderOut, {\n name: 'steps',\n handleItemDefaults: stepDefaults\n });\n\n var stepCount = 0;\n for(var i = 0; i < steps.length; i++) {\n if(steps[i].visible) stepCount++;\n }\n\n var visible;\n // If it has fewer than two options, it's not really a slider\n if(stepCount < 2) visible = sliderOut.visible = false;\n else visible = coerce('visible');\n if(!visible) return;\n\n sliderOut._stepCount = stepCount;\n var visSteps = sliderOut._visibleSteps = Lib.filterVisible(steps);\n\n var active = coerce('active');\n if(!(steps[active] || {}).visible) sliderOut.active = visSteps[0]._index;\n\n coerce('x');\n coerce('y');\n Lib.noneOrAll(sliderIn, sliderOut, ['x', 'y']);\n\n coerce('xanchor');\n coerce('yanchor');\n\n coerce('len');\n coerce('lenmode');\n\n coerce('pad.t');\n coerce('pad.r');\n coerce('pad.b');\n coerce('pad.l');\n\n Lib.coerceFont(coerce, 'font', layoutOut.font);\n\n var currentValueIsVisible = coerce('currentvalue.visible');\n\n if(currentValueIsVisible) {\n coerce('currentvalue.xanchor');\n coerce('currentvalue.prefix');\n coerce('currentvalue.suffix');\n coerce('currentvalue.offset');\n\n Lib.coerceFont(coerce, 'currentvalue.font', sliderOut.font);\n }\n\n coerce('transition.duration');\n coerce('transition.easing');\n\n coerce('bgcolor');\n coerce('activebgcolor');\n coerce('bordercolor');\n coerce('borderwidth');\n coerce('ticklen');\n coerce('tickwidth');\n coerce('tickcolor');\n coerce('minorticklen');\n}\n\nfunction stepDefaults(valueIn, valueOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(valueIn, valueOut, stepAttrs, attr, dflt);\n }\n\n var visible;\n if(valueIn.method !== 'skip' && !Array.isArray(valueIn.args)) {\n visible = valueOut.visible = false;\n } else visible = coerce('visible');\n\n if(visible) {\n coerce('method');\n coerce('args');\n var label = coerce('label', 'step-' + valueOut._index);\n coerce('value', label);\n coerce('execute');\n }\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Plots = require('../../plots/plots');\nvar Color = require('../color');\nvar Drawing = require('../drawing');\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar arrayEditor = require('../../plot_api/plot_template').arrayEditor;\n\nvar constants = require('./constants');\nvar alignmentConstants = require('../../constants/alignment');\nvar LINE_SPACING = alignmentConstants.LINE_SPACING;\nvar FROM_TL = alignmentConstants.FROM_TL;\nvar FROM_BR = alignmentConstants.FROM_BR;\n\nmodule.exports = function draw(gd) {\n var staticPlot = gd._context.staticPlot;\n var fullLayout = gd._fullLayout;\n var sliderData = makeSliderData(fullLayout, gd);\n\n // draw a container for *all* sliders:\n var sliders = fullLayout._infolayer\n .selectAll('g.' + constants.containerClassName)\n .data(sliderData.length > 0 ? [0] : []);\n\n sliders.enter().append('g')\n .classed(constants.containerClassName, true)\n .style('cursor', staticPlot ? null : 'ew-resize');\n\n function clearSlider(sliderOpts) {\n if(sliderOpts._commandObserver) {\n sliderOpts._commandObserver.remove();\n delete sliderOpts._commandObserver;\n }\n\n // Most components don't need to explicitly remove autoMargin, because\n // marginPushers does this - but slider updates don't go through\n // a full replot so we need to explicitly remove it.\n Plots.autoMargin(gd, autoMarginId(sliderOpts));\n }\n\n sliders.exit().each(function() {\n d3.select(this).selectAll('g.' + constants.groupClassName)\n .each(clearSlider);\n })\n .remove();\n\n // Return early if no menus visible:\n if(sliderData.length === 0) return;\n\n var sliderGroups = sliders.selectAll('g.' + constants.groupClassName)\n .data(sliderData, keyFunction);\n\n sliderGroups.enter().append('g')\n .classed(constants.groupClassName, true);\n\n sliderGroups.exit()\n .each(clearSlider)\n .remove();\n\n // Find the dimensions of the sliders:\n for(var i = 0; i < sliderData.length; i++) {\n var sliderOpts = sliderData[i];\n findDimensions(gd, sliderOpts);\n }\n\n sliderGroups.each(function(sliderOpts) {\n var gSlider = d3.select(this);\n\n computeLabelSteps(sliderOpts);\n\n Plots.manageCommandObserver(gd, sliderOpts, sliderOpts._visibleSteps, function(data) {\n // NB: Same as below. This is *not* always the same as sliderOpts since\n // if a new set of steps comes in, the reference in this callback would\n // be invalid. We need to refetch it from the slider group, which is\n // the join data that creates this slider. So if this slider still exists,\n // the group should be valid, *to the best of my knowledge.* If not,\n // we'd have to look it up by d3 data join index/key.\n var opts = gSlider.data()[0];\n\n if(opts.active === data.index) return;\n if(opts._dragging) return;\n\n setActive(gd, gSlider, opts, data.index, false, true);\n });\n\n drawSlider(gd, d3.select(this), sliderOpts);\n });\n};\n\nfunction autoMarginId(sliderOpts) {\n return constants.autoMarginIdRoot + sliderOpts._index;\n}\n\n// This really only just filters by visibility:\nfunction makeSliderData(fullLayout, gd) {\n var contOpts = fullLayout[constants.name];\n var sliderData = [];\n\n for(var i = 0; i < contOpts.length; i++) {\n var item = contOpts[i];\n if(!item.visible) continue;\n item._gd = gd;\n sliderData.push(item);\n }\n\n return sliderData;\n}\n\n// This is set in the defaults step:\nfunction keyFunction(opts) {\n return opts._index;\n}\n\n// Compute the dimensions (mutates sliderOpts):\nfunction findDimensions(gd, sliderOpts) {\n var sliderLabels = Drawing.tester.selectAll('g.' + constants.labelGroupClass)\n .data(sliderOpts._visibleSteps);\n\n sliderLabels.enter().append('g')\n .classed(constants.labelGroupClass, true);\n\n // loop over fake buttons to find width / height\n var maxLabelWidth = 0;\n var labelHeight = 0;\n sliderLabels.each(function(stepOpts) {\n var labelGroup = d3.select(this);\n\n var text = drawLabel(labelGroup, {step: stepOpts}, sliderOpts);\n\n var textNode = text.node();\n if(textNode) {\n var bBox = Drawing.bBox(textNode);\n labelHeight = Math.max(labelHeight, bBox.height);\n maxLabelWidth = Math.max(maxLabelWidth, bBox.width);\n }\n });\n\n sliderLabels.remove();\n\n var dims = sliderOpts._dims = {};\n\n dims.inputAreaWidth = Math.max(\n constants.railWidth,\n constants.gripHeight\n );\n\n // calculate some overall dimensions - some of these are needed for\n // calculating the currentValue dimensions\n var graphSize = gd._fullLayout._size;\n dims.lx = graphSize.l + graphSize.w * sliderOpts.x;\n dims.ly = graphSize.t + graphSize.h * (1 - sliderOpts.y);\n\n if(sliderOpts.lenmode === 'fraction') {\n // fraction:\n dims.outerLength = Math.round(graphSize.w * sliderOpts.len);\n } else {\n // pixels:\n dims.outerLength = sliderOpts.len;\n }\n\n // The length of the rail, *excluding* padding on either end:\n dims.inputAreaStart = 0;\n dims.inputAreaLength = Math.round(dims.outerLength - sliderOpts.pad.l - sliderOpts.pad.r);\n\n var textableInputLength = dims.inputAreaLength - 2 * constants.stepInset;\n var availableSpacePerLabel = textableInputLength / (sliderOpts._stepCount - 1);\n var computedSpacePerLabel = maxLabelWidth + constants.labelPadding;\n dims.labelStride = Math.max(1, Math.ceil(computedSpacePerLabel / availableSpacePerLabel));\n dims.labelHeight = labelHeight;\n\n // loop over all possible values for currentValue to find the\n // area we need for it\n dims.currentValueMaxWidth = 0;\n dims.currentValueHeight = 0;\n dims.currentValueTotalHeight = 0;\n dims.currentValueMaxLines = 1;\n\n if(sliderOpts.currentvalue.visible) {\n // Get the dimensions of the current value label:\n var dummyGroup = Drawing.tester.append('g');\n\n sliderLabels.each(function(stepOpts) {\n var curValPrefix = drawCurrentValue(dummyGroup, sliderOpts, stepOpts.label);\n var curValSize = (curValPrefix.node() && Drawing.bBox(curValPrefix.node())) || {width: 0, height: 0};\n var lines = svgTextUtils.lineCount(curValPrefix);\n dims.currentValueMaxWidth = Math.max(dims.currentValueMaxWidth, Math.ceil(curValSize.width));\n dims.currentValueHeight = Math.max(dims.currentValueHeight, Math.ceil(curValSize.height));\n dims.currentValueMaxLines = Math.max(dims.currentValueMaxLines, lines);\n });\n\n dims.currentValueTotalHeight = dims.currentValueHeight + sliderOpts.currentvalue.offset;\n\n dummyGroup.remove();\n }\n\n dims.height = dims.currentValueTotalHeight + constants.tickOffset + sliderOpts.ticklen + constants.labelOffset + dims.labelHeight + sliderOpts.pad.t + sliderOpts.pad.b;\n\n var xanchor = 'left';\n if(Lib.isRightAnchor(sliderOpts)) {\n dims.lx -= dims.outerLength;\n xanchor = 'right';\n }\n if(Lib.isCenterAnchor(sliderOpts)) {\n dims.lx -= dims.outerLength / 2;\n xanchor = 'center';\n }\n\n var yanchor = 'top';\n if(Lib.isBottomAnchor(sliderOpts)) {\n dims.ly -= dims.height;\n yanchor = 'bottom';\n }\n if(Lib.isMiddleAnchor(sliderOpts)) {\n dims.ly -= dims.height / 2;\n yanchor = 'middle';\n }\n\n dims.outerLength = Math.ceil(dims.outerLength);\n dims.height = Math.ceil(dims.height);\n dims.lx = Math.round(dims.lx);\n dims.ly = Math.round(dims.ly);\n\n var marginOpts = {\n y: sliderOpts.y,\n b: dims.height * FROM_BR[yanchor],\n t: dims.height * FROM_TL[yanchor]\n };\n\n if(sliderOpts.lenmode === 'fraction') {\n marginOpts.l = 0;\n marginOpts.xl = sliderOpts.x - sliderOpts.len * FROM_TL[xanchor];\n marginOpts.r = 0;\n marginOpts.xr = sliderOpts.x + sliderOpts.len * FROM_BR[xanchor];\n } else {\n marginOpts.x = sliderOpts.x;\n marginOpts.l = dims.outerLength * FROM_TL[xanchor];\n marginOpts.r = dims.outerLength * FROM_BR[xanchor];\n }\n\n Plots.autoMargin(gd, autoMarginId(sliderOpts), marginOpts);\n}\n\nfunction drawSlider(gd, sliderGroup, sliderOpts) {\n // This is related to the other long notes in this file regarding what happens\n // when slider steps disappear. This particular fix handles what happens when\n // the *current* slider step is removed. The drawing functions will error out\n // when they fail to find it, so the fix for now is that it will just draw the\n // slider in the first position but will not execute the command.\n if(!((sliderOpts.steps[sliderOpts.active] || {}).visible)) {\n sliderOpts.active = sliderOpts._visibleSteps[0]._index;\n }\n\n // These are carefully ordered for proper z-ordering:\n sliderGroup\n .call(drawCurrentValue, sliderOpts)\n .call(drawRail, sliderOpts)\n .call(drawLabelGroup, sliderOpts)\n .call(drawTicks, sliderOpts)\n .call(drawTouchRect, gd, sliderOpts)\n .call(drawGrip, gd, sliderOpts);\n\n var dims = sliderOpts._dims;\n\n // Position the rectangle:\n Drawing.setTranslate(sliderGroup, dims.lx + sliderOpts.pad.l, dims.ly + sliderOpts.pad.t);\n\n sliderGroup.call(setGripPosition, sliderOpts, false);\n sliderGroup.call(drawCurrentValue, sliderOpts);\n}\n\nfunction drawCurrentValue(sliderGroup, sliderOpts, valueOverride) {\n if(!sliderOpts.currentvalue.visible) return;\n\n var dims = sliderOpts._dims;\n var x0, textAnchor;\n\n switch(sliderOpts.currentvalue.xanchor) {\n case 'right':\n // This is anchored left and adjusted by the width of the longest label\n // so that the prefix doesn't move. The goal of this is to emphasize\n // what's actually changing and make the update less distracting.\n x0 = dims.inputAreaLength - constants.currentValueInset - dims.currentValueMaxWidth;\n textAnchor = 'left';\n break;\n case 'center':\n x0 = dims.inputAreaLength * 0.5;\n textAnchor = 'middle';\n break;\n default:\n x0 = constants.currentValueInset;\n textAnchor = 'left';\n }\n\n var text = Lib.ensureSingle(sliderGroup, 'text', constants.labelClass, function(s) {\n s.attr({\n 'text-anchor': textAnchor,\n 'data-notex': 1\n });\n });\n\n var str = sliderOpts.currentvalue.prefix ? sliderOpts.currentvalue.prefix : '';\n\n if(typeof valueOverride === 'string') {\n str += valueOverride;\n } else {\n var curVal = sliderOpts.steps[sliderOpts.active].label;\n var _meta = sliderOpts._gd._fullLayout._meta;\n if(_meta) curVal = Lib.templateString(curVal, _meta);\n str += curVal;\n }\n\n if(sliderOpts.currentvalue.suffix) {\n str += sliderOpts.currentvalue.suffix;\n }\n\n text.call(Drawing.font, sliderOpts.currentvalue.font)\n .text(str)\n .call(svgTextUtils.convertToTspans, sliderOpts._gd);\n\n var lines = svgTextUtils.lineCount(text);\n\n var y0 = (dims.currentValueMaxLines + 1 - lines) *\n sliderOpts.currentvalue.font.size * LINE_SPACING;\n\n svgTextUtils.positionText(text, x0, y0);\n\n return text;\n}\n\nfunction drawGrip(sliderGroup, gd, sliderOpts) {\n var grip = Lib.ensureSingle(sliderGroup, 'rect', constants.gripRectClass, function(s) {\n s.call(attachGripEvents, gd, sliderGroup, sliderOpts)\n .style('pointer-events', 'all');\n });\n\n grip.attr({\n width: constants.gripWidth,\n height: constants.gripHeight,\n rx: constants.gripRadius,\n ry: constants.gripRadius,\n })\n .call(Color.stroke, sliderOpts.bordercolor)\n .call(Color.fill, sliderOpts.bgcolor)\n .style('stroke-width', sliderOpts.borderwidth + 'px');\n}\n\nfunction drawLabel(item, data, sliderOpts) {\n var text = Lib.ensureSingle(item, 'text', constants.labelClass, function(s) {\n s.attr({\n 'text-anchor': 'middle',\n 'data-notex': 1\n });\n });\n\n var tx = data.step.label;\n var _meta = sliderOpts._gd._fullLayout._meta;\n if(_meta) tx = Lib.templateString(tx, _meta);\n\n text.call(Drawing.font, sliderOpts.font)\n .text(tx)\n .call(svgTextUtils.convertToTspans, sliderOpts._gd);\n\n return text;\n}\n\nfunction drawLabelGroup(sliderGroup, sliderOpts) {\n var labels = Lib.ensureSingle(sliderGroup, 'g', constants.labelsClass);\n var dims = sliderOpts._dims;\n\n var labelItems = labels.selectAll('g.' + constants.labelGroupClass)\n .data(dims.labelSteps);\n\n labelItems.enter().append('g')\n .classed(constants.labelGroupClass, true);\n\n labelItems.exit().remove();\n\n labelItems.each(function(d) {\n var item = d3.select(this);\n\n item.call(drawLabel, d, sliderOpts);\n\n Drawing.setTranslate(item,\n normalizedValueToPosition(sliderOpts, d.fraction),\n constants.tickOffset +\n sliderOpts.ticklen +\n // position is the baseline of the top line of text only, even\n // if the label spans multiple lines\n sliderOpts.font.size * LINE_SPACING +\n constants.labelOffset +\n dims.currentValueTotalHeight\n );\n });\n}\n\nfunction handleInput(gd, sliderGroup, sliderOpts, normalizedPosition, doTransition) {\n var quantizedPosition = Math.round(normalizedPosition * (sliderOpts._stepCount - 1));\n var quantizedIndex = sliderOpts._visibleSteps[quantizedPosition]._index;\n\n if(quantizedIndex !== sliderOpts.active) {\n setActive(gd, sliderGroup, sliderOpts, quantizedIndex, true, doTransition);\n }\n}\n\nfunction setActive(gd, sliderGroup, sliderOpts, index, doCallback, doTransition) {\n var previousActive = sliderOpts.active;\n sliderOpts.active = index;\n\n // due to templating, it's possible this slider doesn't even exist yet\n arrayEditor(gd.layout, constants.name, sliderOpts)\n .applyUpdate('active', index);\n\n var step = sliderOpts.steps[sliderOpts.active];\n\n sliderGroup.call(setGripPosition, sliderOpts, doTransition);\n sliderGroup.call(drawCurrentValue, sliderOpts);\n\n gd.emit('plotly_sliderchange', {\n slider: sliderOpts,\n step: sliderOpts.steps[sliderOpts.active],\n interaction: doCallback,\n previousActive: previousActive\n });\n\n if(step && step.method && doCallback) {\n if(sliderGroup._nextMethod) {\n // If we've already queued up an update, just overwrite it with the most recent:\n sliderGroup._nextMethod.step = step;\n sliderGroup._nextMethod.doCallback = doCallback;\n sliderGroup._nextMethod.doTransition = doTransition;\n } else {\n sliderGroup._nextMethod = {step: step, doCallback: doCallback, doTransition: doTransition};\n sliderGroup._nextMethodRaf = window.requestAnimationFrame(function() {\n var _step = sliderGroup._nextMethod.step;\n if(!_step.method) return;\n\n if(_step.execute) {\n Plots.executeAPICommand(gd, _step.method, _step.args);\n }\n\n sliderGroup._nextMethod = null;\n sliderGroup._nextMethodRaf = null;\n });\n }\n }\n}\n\nfunction attachGripEvents(item, gd, sliderGroup) {\n if(gd._context.staticPlot) return;\n\n var node = sliderGroup.node();\n var $gd = d3.select(gd);\n\n // NB: This is *not* the same as sliderOpts itself! These callbacks\n // are in a closure so this array won't actually be correct if the\n // steps have changed since this was initialized. The sliderGroup,\n // however, has not changed since that *is* the slider, so it must\n // be present to receive mouse events.\n function getSliderOpts() {\n return sliderGroup.data()[0];\n }\n\n function mouseDownHandler() {\n var sliderOpts = getSliderOpts();\n gd.emit('plotly_sliderstart', {slider: sliderOpts});\n\n var grip = sliderGroup.select('.' + constants.gripRectClass);\n\n d3.event.stopPropagation();\n d3.event.preventDefault();\n grip.call(Color.fill, sliderOpts.activebgcolor);\n\n var normalizedPosition = positionToNormalizedValue(sliderOpts, d3.mouse(node)[0]);\n handleInput(gd, sliderGroup, sliderOpts, normalizedPosition, true);\n sliderOpts._dragging = true;\n\n function mouseMoveHandler() {\n var sliderOpts = getSliderOpts();\n var normalizedPosition = positionToNormalizedValue(sliderOpts, d3.mouse(node)[0]);\n handleInput(gd, sliderGroup, sliderOpts, normalizedPosition, false);\n }\n\n $gd.on('mousemove', mouseMoveHandler);\n $gd.on('touchmove', mouseMoveHandler);\n\n function mouseUpHandler() {\n var sliderOpts = getSliderOpts();\n sliderOpts._dragging = false;\n grip.call(Color.fill, sliderOpts.bgcolor);\n $gd.on('mouseup', null);\n $gd.on('mousemove', null);\n $gd.on('touchend', null);\n $gd.on('touchmove', null);\n\n gd.emit('plotly_sliderend', {\n slider: sliderOpts,\n step: sliderOpts.steps[sliderOpts.active]\n });\n }\n\n $gd.on('mouseup', mouseUpHandler);\n $gd.on('touchend', mouseUpHandler);\n }\n\n item.on('mousedown', mouseDownHandler);\n item.on('touchstart', mouseDownHandler);\n}\n\nfunction drawTicks(sliderGroup, sliderOpts) {\n var tick = sliderGroup.selectAll('rect.' + constants.tickRectClass)\n .data(sliderOpts._visibleSteps);\n var dims = sliderOpts._dims;\n\n tick.enter().append('rect')\n .classed(constants.tickRectClass, true);\n\n tick.exit().remove();\n\n tick.attr({\n width: sliderOpts.tickwidth + 'px',\n 'shape-rendering': 'crispEdges'\n });\n\n tick.each(function(d, i) {\n var isMajor = i % dims.labelStride === 0;\n var item = d3.select(this);\n\n item\n .attr({height: isMajor ? sliderOpts.ticklen : sliderOpts.minorticklen})\n .call(Color.fill, isMajor ? sliderOpts.tickcolor : sliderOpts.tickcolor);\n\n Drawing.setTranslate(item,\n normalizedValueToPosition(sliderOpts, i / (sliderOpts._stepCount - 1)) - 0.5 * sliderOpts.tickwidth,\n (isMajor ? constants.tickOffset : constants.minorTickOffset) + dims.currentValueTotalHeight\n );\n });\n}\n\nfunction computeLabelSteps(sliderOpts) {\n var dims = sliderOpts._dims;\n dims.labelSteps = [];\n var nsteps = sliderOpts._stepCount;\n\n for(var i = 0; i < nsteps; i += dims.labelStride) {\n dims.labelSteps.push({\n fraction: i / (nsteps - 1),\n step: sliderOpts._visibleSteps[i]\n });\n }\n}\n\nfunction setGripPosition(sliderGroup, sliderOpts, doTransition) {\n var grip = sliderGroup.select('rect.' + constants.gripRectClass);\n\n var quantizedIndex = 0;\n for(var i = 0; i < sliderOpts._stepCount; i++) {\n if(sliderOpts._visibleSteps[i]._index === sliderOpts.active) {\n quantizedIndex = i;\n break;\n }\n }\n\n var x = normalizedValueToPosition(sliderOpts, quantizedIndex / (sliderOpts._stepCount - 1));\n\n // If this is true, then *this component* is already invoking its own command\n // and has triggered its own animation.\n if(sliderOpts._invokingCommand) return;\n\n var el = grip;\n if(doTransition && sliderOpts.transition.duration > 0) {\n el = el.transition()\n .duration(sliderOpts.transition.duration)\n .ease(sliderOpts.transition.easing);\n }\n\n // Drawing.setTranslate doesn't work here because of the transition duck-typing.\n // It's also not necessary because there are no other transitions to preserve.\n el.attr('transform', strTranslate(x - constants.gripWidth * 0.5, sliderOpts._dims.currentValueTotalHeight));\n}\n\n// Convert a number from [0-1] to a pixel position relative to the slider group container:\nfunction normalizedValueToPosition(sliderOpts, normalizedPosition) {\n var dims = sliderOpts._dims;\n return dims.inputAreaStart + constants.stepInset +\n (dims.inputAreaLength - 2 * constants.stepInset) * Math.min(1, Math.max(0, normalizedPosition));\n}\n\n// Convert a position relative to the slider group to a nubmer in [0, 1]\nfunction positionToNormalizedValue(sliderOpts, position) {\n var dims = sliderOpts._dims;\n return Math.min(1, Math.max(0, (position - constants.stepInset - dims.inputAreaStart) / (dims.inputAreaLength - 2 * constants.stepInset - 2 * dims.inputAreaStart)));\n}\n\nfunction drawTouchRect(sliderGroup, gd, sliderOpts) {\n var dims = sliderOpts._dims;\n var rect = Lib.ensureSingle(sliderGroup, 'rect', constants.railTouchRectClass, function(s) {\n s.call(attachGripEvents, gd, sliderGroup, sliderOpts)\n .style('pointer-events', 'all');\n });\n\n rect.attr({\n width: dims.inputAreaLength,\n height: Math.max(dims.inputAreaWidth, constants.tickOffset + sliderOpts.ticklen + dims.labelHeight)\n })\n .call(Color.fill, sliderOpts.bgcolor)\n .attr('opacity', 0);\n\n Drawing.setTranslate(rect, 0, dims.currentValueTotalHeight);\n}\n\nfunction drawRail(sliderGroup, sliderOpts) {\n var dims = sliderOpts._dims;\n var computedLength = dims.inputAreaLength - constants.railInset * 2;\n var rect = Lib.ensureSingle(sliderGroup, 'rect', constants.railRectClass);\n\n rect.attr({\n width: computedLength,\n height: constants.railWidth,\n rx: constants.railRadius,\n ry: constants.railRadius,\n 'shape-rendering': 'crispEdges'\n })\n .call(Color.stroke, sliderOpts.bordercolor)\n .call(Color.fill, sliderOpts.bgcolor)\n .style('stroke-width', sliderOpts.borderwidth + 'px');\n\n Drawing.setTranslate(rect,\n constants.railInset,\n (dims.inputAreaWidth - constants.railWidth) * 0.5 + dims.currentValueTotalHeight\n );\n}\n","'use strict';\n\nvar constants = require('./constants');\n\nmodule.exports = {\n moduleType: 'component',\n name: constants.name,\n\n layoutAttributes: require('./attributes'),\n supplyLayoutDefaults: require('./defaults'),\n\n draw: require('./draw')\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar Plots = require('../../plots/plots');\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar Drawing = require('../drawing');\nvar Color = require('../color');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar interactConstants = require('../../constants/interactions');\n\nvar OPPOSITE_SIDE = require('../../constants/alignment').OPPOSITE_SIDE;\nvar numStripRE = / [XY][0-9]* /;\nvar SUBTITLE_PADDING_MATHJAX_EM = 1.6;\nvar SUBTITLE_PADDING_EM = 1.6;\n\n/**\n * Titles - (re)draw titles on the axes and plot:\n * @param {DOM element} gd - the graphDiv\n * @param {string} titleClass - the css class of this title\n * @param {object} options - how and what to draw\n * propContainer - the layout object containing `title` and `titlefont`\n * attributes that apply to this title\n * propName - the full name of the title property (for Plotly.relayout)\n * [traceIndex] - include only if this property applies to one trace\n * (such as a colorbar title) - then editing pipes to Plotly.restyle\n * instead of Plotly.relayout\n * placeholder - placeholder text for an empty editable title\n * [avoid] {object} - include if this title should move to avoid other elements\n * selection - d3 selection of elements to avoid\n * side - which direction to move if there is a conflict\n * [offsetLeft] - if these elements are subject to a translation\n * wrt the title element\n * [offsetTop]\n * attributes {object} - position and alignment attributes\n * x - pixels\n * y - pixels\n * text-anchor - start|middle|end\n * transform {object} - how to transform the title after positioning\n * rotate - degrees\n * offset - shift up/down in the rotated frame (unused?)\n * containerGroup - if an svg element already exists to hold this\n * title, include here. Otherwise it will go in fullLayout._infolayer\n * _meta {object (optional} - meta key-value to for title with\n * Lib.templateString, default to fullLayout._meta, if not provided\n *\n * @return {selection} d3 selection of title container group\n */\nfunction draw(gd, titleClass, options) {\n var fullLayout = gd._fullLayout;\n\n var cont = options.propContainer;\n var prop = options.propName;\n var placeholder = options.placeholder;\n var traceIndex = options.traceIndex;\n var avoid = options.avoid || {};\n var attributes = options.attributes;\n var transform = options.transform;\n var group = options.containerGroup;\n var opacity = 1;\n var title = cont.title;\n var txt = (title && title.text ? title.text : '').trim();\n var titleIsPlaceholder = false;\n\n var font = title && title.font ? title.font : {};\n var fontFamily = font.family;\n var fontSize = font.size;\n var fontColor = font.color;\n var fontWeight = font.weight;\n var fontStyle = font.style;\n var fontVariant = font.variant;\n var fontTextcase = font.textcase;\n var fontLineposition = font.lineposition;\n var fontShadow = font.shadow;\n\n // Get subtitle properties\n var subtitleProp = options.subtitlePropName;\n var subtitleEnabled = !!subtitleProp;\n var subtitlePlaceholder = options.subtitlePlaceholder;\n var subtitle = (cont.title || {}).subtitle || {text: '', font: {}};\n var subtitleTxt = subtitle.text.trim();\n var subtitleIsPlaceholder = false;\n var subtitleOpacity = 1;\n\n var subtitleFont = subtitle.font;\n var subFontFamily = subtitleFont.family;\n var subFontSize = subtitleFont.size;\n var subFontColor = subtitleFont.color;\n var subFontWeight = subtitleFont.weight;\n var subFontStyle = subtitleFont.style;\n var subFontVariant = subtitleFont.variant;\n var subFontTextcase = subtitleFont.textcase;\n var subFontLineposition = subtitleFont.lineposition;\n var subFontShadow = subtitleFont.shadow;\n\n // only make this title editable if we positively identify its property\n // as one that has editing enabled.\n // Subtitle is editable if and only if title is editable\n var editAttr;\n if(prop === 'title.text') editAttr = 'titleText';\n else if(prop.indexOf('axis') !== -1) editAttr = 'axisTitleText';\n else if(prop.indexOf('colorbar' !== -1)) editAttr = 'colorbarTitleText';\n var editable = gd._context.edits[editAttr];\n\n function matchesPlaceholder(text, placeholder) {\n if(text === undefined || placeholder === undefined) return false;\n // look for placeholder text while stripping out numbers from eg X2, Y3\n // this is just for backward compatibility with the old version that had\n // \"Click to enter X2 title\" and may have gotten saved in some old plots,\n // we don't want this to show up when these are displayed.\n return text.replace(numStripRE, ' % ') === placeholder.replace(numStripRE, ' % ');\n }\n\n if(txt === '') opacity = 0;\n else if(matchesPlaceholder(txt, placeholder)) {\n if(!editable) txt = '';\n opacity = 0.2;\n titleIsPlaceholder = true;\n }\n\n if(subtitleEnabled) {\n if(subtitleTxt === '') subtitleOpacity = 0;\n else if(matchesPlaceholder(subtitleTxt, subtitlePlaceholder)) {\n if(!editable) subtitleTxt = '';\n subtitleOpacity = 0.2;\n subtitleIsPlaceholder = true;\n }\n }\n\n if(options._meta) {\n txt = Lib.templateString(txt, options._meta);\n } else if(fullLayout._meta) {\n txt = Lib.templateString(txt, fullLayout._meta);\n }\n\n var elShouldExist = txt || subtitleTxt || editable;\n\n var hColorbarMoveTitle;\n if(!group) {\n group = Lib.ensureSingle(fullLayout._infolayer, 'g', 'g-' + titleClass);\n hColorbarMoveTitle = fullLayout._hColorbarMoveTitle;\n }\n\n var el = group.selectAll('text.' + titleClass)\n .data(elShouldExist ? [0] : []);\n el.enter().append('text');\n el.text(txt)\n // this is hacky, but convertToTspans uses the class\n // to determine whether to rotate mathJax...\n // so we need to clear out any old class and put the\n // correct one (only relevant for colorbars, at least\n // for now) - ie don't use .classed\n .attr('class', titleClass);\n el.exit().remove();\n\n var subtitleEl = null;\n var subtitleClass = titleClass + '-subtitle';\n var subtitleElShouldExist = subtitleTxt || editable;\n\n if(subtitleEnabled && subtitleElShouldExist) {\n subtitleEl = group.selectAll('text.' + subtitleClass)\n .data(subtitleElShouldExist ? [0] : []);\n subtitleEl.enter().append('text');\n subtitleEl.text(subtitleTxt).attr('class', subtitleClass);\n subtitleEl.exit().remove();\n }\n\n\n if(!elShouldExist) return group;\n\n function titleLayout(titleEl, subtitleEl) {\n Lib.syncOrAsync([drawTitle, scootTitle], { title: titleEl, subtitle: subtitleEl });\n }\n\n function drawTitle(titleAndSubtitleEls) {\n var titleEl = titleAndSubtitleEls.title;\n var subtitleEl = titleAndSubtitleEls.subtitle;\n\n var transformVal;\n\n if(!transform && hColorbarMoveTitle) {\n transform = {};\n }\n\n if(transform) {\n transformVal = '';\n if(transform.rotate) {\n transformVal += 'rotate(' + [transform.rotate, attributes.x, attributes.y] + ')';\n }\n if(transform.offset || hColorbarMoveTitle) {\n transformVal += strTranslate(0, (transform.offset || 0) - (hColorbarMoveTitle || 0));\n }\n } else {\n transformVal = null;\n }\n\n titleEl.attr('transform', transformVal);\n\n // Callback to adjust the subtitle position after mathjax is rendered\n // Mathjax is rendered asynchronously, which is why this step needs to be\n // passed as a callback\n function adjustSubtitlePosition(titleElMathGroup) {\n if(!titleElMathGroup) return;\n\n var subtitleElement = d3.select(titleElMathGroup.node().parentNode).select('.' + subtitleClass);\n if(!subtitleElement.empty()) {\n var titleElMathBbox = titleElMathGroup.node().getBBox();\n if(titleElMathBbox.height) {\n // Position subtitle based on bottom of Mathjax title\n var subtitleY = titleElMathBbox.y + titleElMathBbox.height + (SUBTITLE_PADDING_MATHJAX_EM * subFontSize);\n subtitleElement.attr('y', subtitleY);\n }\n }\n }\n\n titleEl.style('opacity', opacity * Color.opacity(fontColor))\n .call(Drawing.font, {\n color: Color.rgb(fontColor),\n size: d3.round(fontSize, 2),\n family: fontFamily,\n weight: fontWeight,\n style: fontStyle,\n variant: fontVariant,\n textcase: fontTextcase,\n shadow: fontShadow,\n lineposition: fontLineposition,\n })\n .attr(attributes)\n .call(svgTextUtils.convertToTspans, gd, adjustSubtitlePosition);\n\n if(subtitleEl) {\n // Set subtitle y position based on bottom of title\n // We need to check the Mathjax group as well, in case the Mathjax\n // has already rendered\n var titleElMathGroup = group.select('.' + titleClass + '-math-group');\n var titleElBbox = titleEl.node().getBBox();\n var titleElMathBbox = titleElMathGroup.node() ? titleElMathGroup.node().getBBox() : undefined;\n var subtitleY = titleElMathBbox ? titleElMathBbox.y + titleElMathBbox.height + (SUBTITLE_PADDING_MATHJAX_EM * subFontSize) : titleElBbox.y + titleElBbox.height + (SUBTITLE_PADDING_EM * subFontSize);\n\n var subtitleAttributes = Lib.extendFlat({}, attributes, {\n y: subtitleY\n });\n\n subtitleEl.attr('transform', transformVal);\n subtitleEl.style('opacity', subtitleOpacity * Color.opacity(subFontColor))\n .call(Drawing.font, {\n color: Color.rgb(subFontColor),\n size: d3.round(subFontSize, 2),\n family: subFontFamily,\n weight: subFontWeight,\n style: subFontStyle,\n variant: subFontVariant,\n textcase: subFontTextcase,\n shadow: subFontShadow,\n lineposition: subFontLineposition,\n })\n .attr(subtitleAttributes)\n .call(svgTextUtils.convertToTspans, gd);\n }\n\n return Plots.previousPromises(gd);\n }\n\n function scootTitle(titleAndSubtitleEls) {\n var titleElIn = titleAndSubtitleEls.title;\n var titleGroup = d3.select(titleElIn.node().parentNode);\n\n if(avoid && avoid.selection && avoid.side && txt) {\n titleGroup.attr('transform', null);\n\n // move toward avoid.side (= left, right, top, bottom) if needed\n // can include pad (pixels, default 2)\n var backside = OPPOSITE_SIDE[avoid.side];\n var shiftSign = (avoid.side === 'left' || avoid.side === 'top') ? -1 : 1;\n var pad = isNumeric(avoid.pad) ? avoid.pad : 2;\n\n var titlebb = Drawing.bBox(titleGroup.node());\n\n // Account for reservedMargins\n var reservedMargins = {t: 0, b: 0, l: 0, r: 0};\n var margins = gd._fullLayout._reservedMargin;\n for(var key in margins) {\n for(var side in margins[key]) {\n var val = margins[key][side];\n reservedMargins[side] = Math.max(reservedMargins[side], val);\n }\n }\n var paperbb = {\n left: reservedMargins.l,\n top: reservedMargins.t,\n right: fullLayout.width - reservedMargins.r,\n bottom: fullLayout.height - reservedMargins.b\n };\n\n var maxshift = avoid.maxShift ||\n shiftSign * (paperbb[avoid.side] - titlebb[avoid.side]);\n var shift = 0;\n\n // Prevent the title going off the paper\n if(maxshift < 0) {\n shift = maxshift;\n } else {\n // so we don't have to offset each avoided element,\n // give the title the opposite offset\n var offsetLeft = avoid.offsetLeft || 0;\n var offsetTop = avoid.offsetTop || 0;\n titlebb.left -= offsetLeft;\n titlebb.right -= offsetLeft;\n titlebb.top -= offsetTop;\n titlebb.bottom -= offsetTop;\n\n // iterate over a set of elements (avoid.selection)\n // to avoid collisions with\n avoid.selection.each(function() {\n var avoidbb = Drawing.bBox(this);\n\n if(Lib.bBoxIntersect(titlebb, avoidbb, pad)) {\n shift = Math.max(shift, shiftSign * (\n avoidbb[avoid.side] - titlebb[backside]) + pad);\n }\n });\n shift = Math.min(maxshift, shift);\n // Keeping track of this for calculation of full axis size if needed\n cont._titleScoot = Math.abs(shift);\n }\n\n if(shift > 0 || maxshift < 0) {\n var shiftTemplate = {\n left: [-shift, 0],\n right: [shift, 0],\n top: [0, -shift],\n bottom: [0, shift]\n }[avoid.side];\n titleGroup.attr('transform', strTranslate(shiftTemplate[0], shiftTemplate[1]));\n }\n }\n }\n\n el.call(titleLayout, subtitleEl);\n\n function setPlaceholder(element, placeholderText) {\n element.text(placeholderText)\n .on('mouseover.opacity', function() {\n d3.select(this).transition()\n .duration(interactConstants.SHOW_PLACEHOLDER).style('opacity', 1);\n })\n .on('mouseout.opacity', function() {\n d3.select(this).transition()\n .duration(interactConstants.HIDE_PLACEHOLDER).style('opacity', 0);\n });\n }\n\n if(editable) {\n if(!txt) {\n setPlaceholder(el, placeholder);\n titleIsPlaceholder = true;\n } else el.on('.opacity', null);\n\n el.call(svgTextUtils.makeEditable, {gd: gd})\n .on('edit', function(text) {\n if(traceIndex !== undefined) {\n Registry.call('_guiRestyle', gd, prop, text, traceIndex);\n } else {\n Registry.call('_guiRelayout', gd, prop, text);\n }\n })\n .on('cancel', function() {\n this.text(this.attr('data-unformatted'))\n .call(titleLayout);\n })\n .on('input', function(d) {\n this.text(d || ' ')\n .call(svgTextUtils.positionText, attributes.x, attributes.y);\n });\n\n if(subtitleEnabled) {\n // Adjust subtitle position now that title placeholder has been added\n // Only adjust if subtitle is enabled and title text was originally empty\n if(subtitleEnabled && !txt) {\n var titleElBbox = el.node().getBBox();\n var subtitleY = titleElBbox.y + titleElBbox.height + (SUBTITLE_PADDING_EM * subFontSize);\n subtitleEl.attr('y', subtitleY);\n }\n\n if(!subtitleTxt) {\n setPlaceholder(subtitleEl, subtitlePlaceholder);\n subtitleIsPlaceholder = true;\n } else subtitleEl.on('.opacity', null);\n subtitleEl.call(svgTextUtils.makeEditable, {gd: gd})\n .on('edit', function(text) {\n Registry.call('_guiRelayout', gd, 'title.subtitle.text', text);\n })\n .on('cancel', function() {\n this.text(this.attr('data-unformatted'))\n .call(titleLayout);\n })\n .on('input', function(d) {\n this.text(d || ' ')\n .call(svgTextUtils.positionText, subtitleEl.attr('x'), subtitleEl.attr('y'));\n });\n }\n }\n\n el.classed('js-placeholder', titleIsPlaceholder);\n if(subtitleEl) subtitleEl.classed('js-placeholder', subtitleIsPlaceholder);\n\n return group;\n}\n\nmodule.exports = {\n draw: draw,\n SUBTITLE_PADDING_EM: SUBTITLE_PADDING_EM,\n SUBTITLE_PADDING_MATHJAX_EM: SUBTITLE_PADDING_MATHJAX_EM,\n};\n","'use strict';\n\nvar fontAttrs = require('../../plots/font_attributes');\nvar colorAttrs = require('../color/attributes');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar padAttrs = require('../../plots/pad_attributes');\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\n\nvar buttonsAttrs = templatedArray('button', {\n visible: {\n valType: 'boolean',\n description: 'Determines whether or not this button is visible.'\n },\n method: {\n valType: 'enumerated',\n values: ['restyle', 'relayout', 'animate', 'update', 'skip'],\n dflt: 'restyle',\n description: [\n 'Sets the Plotly method to be called on click.',\n 'If the `skip` method is used, the API updatemenu will function as normal',\n 'but will perform no API calls and will not bind automatically to state',\n 'updates. This may be used to create a component interface and attach to',\n 'updatemenu events manually via JavaScript.'\n ].join(' ')\n },\n args: {\n valType: 'info_array',\n freeLength: true,\n items: [\n {valType: 'any'},\n {valType: 'any'},\n {valType: 'any'}\n ],\n description: [\n 'Sets the arguments values to be passed to the Plotly',\n 'method set in `method` on click.'\n ].join(' ')\n },\n args2: {\n valType: 'info_array',\n freeLength: true,\n items: [\n {valType: 'any'},\n {valType: 'any'},\n {valType: 'any'}\n ],\n description: [\n 'Sets a 2nd set of `args`,',\n 'these arguments values are passed to the Plotly',\n 'method set in `method` when clicking this button while in the active state.',\n 'Use this to create toggle buttons.'\n ].join(' ')\n },\n label: {\n valType: 'string',\n dflt: '',\n description: 'Sets the text label to appear on the button.'\n },\n execute: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'When true, the API method is executed. When false, all other behaviors are the same',\n 'and command execution is skipped. This may be useful when hooking into, for example,',\n 'the `plotly_buttonclicked` method and executing the API command manually without losing',\n 'the benefit of the updatemenu automatically binding to the state of the plot through the',\n 'specification of `method` and `args`.'\n ].join(' ')\n }\n});\n\nmodule.exports = overrideAll(templatedArray('updatemenu', {\n _arrayAttrRegexps: [/^updatemenus\\[(0|[1-9][0-9]+)\\]\\.buttons/],\n\n visible: {\n valType: 'boolean',\n description: [\n 'Determines whether or not the update menu is visible.'\n ].join(' ')\n },\n\n type: {\n valType: 'enumerated',\n values: ['dropdown', 'buttons'],\n dflt: 'dropdown',\n description: [\n 'Determines whether the buttons are accessible via a dropdown menu',\n 'or whether the buttons are stacked horizontally or vertically'\n ].join(' ')\n },\n\n direction: {\n valType: 'enumerated',\n values: ['left', 'right', 'up', 'down'],\n dflt: 'down',\n description: [\n 'Determines the direction in which the buttons are laid out, whether',\n 'in a dropdown menu or a row/column of buttons. For `left` and `up`,',\n 'the buttons will still appear in left-to-right or top-to-bottom order',\n 'respectively.'\n ].join(' ')\n },\n\n active: {\n valType: 'integer',\n min: -1,\n dflt: 0,\n description: [\n 'Determines which button (by index starting from 0) is',\n 'considered active.'\n ].join(' ')\n },\n\n showactive: {\n valType: 'boolean',\n dflt: true,\n description: 'Highlights active dropdown item or active button if true.'\n },\n\n buttons: buttonsAttrs,\n\n x: {\n valType: 'number',\n min: -2,\n max: 3,\n dflt: -0.05,\n description: 'Sets the x position (in normalized coordinates) of the update menu.'\n },\n xanchor: {\n valType: 'enumerated',\n values: ['auto', 'left', 'center', 'right'],\n dflt: 'right',\n description: [\n 'Sets the update menu\\'s horizontal position anchor.',\n 'This anchor binds the `x` position to the *left*, *center*',\n 'or *right* of the range selector.'\n ].join(' ')\n },\n y: {\n valType: 'number',\n min: -2,\n max: 3,\n dflt: 1,\n description: 'Sets the y position (in normalized coordinates) of the update menu.'\n },\n yanchor: {\n valType: 'enumerated',\n values: ['auto', 'top', 'middle', 'bottom'],\n dflt: 'top',\n description: [\n 'Sets the update menu\\'s vertical position anchor',\n 'This anchor binds the `y` position to the *top*, *middle*',\n 'or *bottom* of the range selector.'\n ].join(' ')\n },\n\n pad: extendFlat(padAttrs({editType: 'arraydraw'}), {\n description: 'Sets the padding around the buttons or dropdown menu.'\n }),\n\n font: fontAttrs({\n description: 'Sets the font of the update menu button text.'\n }),\n\n bgcolor: {\n valType: 'color',\n description: 'Sets the background color of the update menu buttons.'\n },\n bordercolor: {\n valType: 'color',\n dflt: colorAttrs.borderLine,\n description: 'Sets the color of the border enclosing the update menu.'\n },\n borderwidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n editType: 'arraydraw',\n description: 'Sets the width (in px) of the border enclosing the update menu.'\n }\n}), 'arraydraw', 'from-root');\n","'use strict';\n\n\nmodule.exports = {\n\n // layout attribute name\n name: 'updatemenus',\n\n // class names\n containerClassName: 'updatemenu-container',\n headerGroupClassName: 'updatemenu-header-group',\n headerClassName: 'updatemenu-header',\n headerArrowClassName: 'updatemenu-header-arrow',\n dropdownButtonGroupClassName: 'updatemenu-dropdown-button-group',\n dropdownButtonClassName: 'updatemenu-dropdown-button',\n buttonClassName: 'updatemenu-button',\n itemRectClassName: 'updatemenu-item-rect',\n itemTextClassName: 'updatemenu-item-text',\n\n // DOM attribute name in button group keeping track\n // of active update menu\n menuIndexAttrName: 'updatemenu-active-index',\n\n // id root pass to Plots.autoMargin\n autoMarginIdRoot: 'updatemenu-',\n\n // options when 'active: -1'\n blankHeaderOpts: { label: ' ' },\n\n // min item width / height\n minWidth: 30,\n minHeight: 30,\n\n // padding around item text\n textPadX: 24,\n arrowPadX: 16,\n\n // item rect radii\n rx: 2,\n ry: 2,\n\n // item text x offset off left edge\n textOffsetX: 12,\n\n // item text y offset (w.r.t. middle)\n textOffsetY: 3,\n\n // arrow offset off right edge\n arrowOffsetX: 4,\n\n // gap between header and buttons\n gapButtonHeader: 5,\n\n // gap between between buttons\n gapButton: 2,\n\n // color given to active buttons\n activeColor: '#F4FAFF',\n\n // color given to hovered buttons\n hoverColor: '#F4FAFF',\n\n // symbol for menu open arrow\n arrowSymbol: {\n left: '◄',\n right: '►',\n up: '▲',\n down: '▼'\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar attributes = require('./attributes');\nvar constants = require('./constants');\n\nvar name = constants.name;\nvar buttonAttrs = attributes.buttons;\n\n\nmodule.exports = function updateMenusDefaults(layoutIn, layoutOut) {\n var opts = {\n name: name,\n handleItemDefaults: menuDefaults\n };\n\n handleArrayContainerDefaults(layoutIn, layoutOut, opts);\n};\n\nfunction menuDefaults(menuIn, menuOut, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(menuIn, menuOut, attributes, attr, dflt);\n }\n\n var buttons = handleArrayContainerDefaults(menuIn, menuOut, {\n name: 'buttons',\n handleItemDefaults: buttonDefaults\n });\n\n var visible = coerce('visible', buttons.length > 0);\n if(!visible) return;\n\n coerce('active');\n coerce('direction');\n coerce('type');\n coerce('showactive');\n\n coerce('x');\n coerce('y');\n Lib.noneOrAll(menuIn, menuOut, ['x', 'y']);\n\n coerce('xanchor');\n coerce('yanchor');\n\n coerce('pad.t');\n coerce('pad.r');\n coerce('pad.b');\n coerce('pad.l');\n\n Lib.coerceFont(coerce, 'font', layoutOut.font);\n\n coerce('bgcolor', layoutOut.paper_bgcolor);\n coerce('bordercolor');\n coerce('borderwidth');\n}\n\nfunction buttonDefaults(buttonIn, buttonOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(buttonIn, buttonOut, buttonAttrs, attr, dflt);\n }\n\n var visible = coerce('visible',\n (buttonIn.method === 'skip' || Array.isArray(buttonIn.args)));\n if(visible) {\n coerce('method');\n coerce('args');\n coerce('args2');\n coerce('label');\n coerce('execute');\n }\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Plots = require('../../plots/plots');\nvar Color = require('../color');\nvar Drawing = require('../drawing');\nvar Lib = require('../../lib');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar arrayEditor = require('../../plot_api/plot_template').arrayEditor;\n\nvar LINE_SPACING = require('../../constants/alignment').LINE_SPACING;\n\nvar constants = require('./constants');\nvar ScrollBox = require('./scrollbox');\n\nmodule.exports = function draw(gd) {\n var fullLayout = gd._fullLayout;\n var menuData = Lib.filterVisible(fullLayout[constants.name]);\n\n /* Update menu data is bound to the header-group.\n * The items in the header group are always present.\n *\n * Upon clicking on a header its corresponding button\n * data is bound to the button-group.\n *\n * We draw all headers in one group before all buttons\n * so that the buttons *always* appear above the headers.\n *\n * Note that only one set of buttons are visible at once.\n *\n * \n *\n * \n * \n * \n * \n * \n * \n * ...\n *\n * \n * \n * \n * ...\n */\n\n function clearAutoMargin(menuOpts) {\n Plots.autoMargin(gd, autoMarginId(menuOpts));\n }\n\n // draw update menu container\n var menus = fullLayout._menulayer\n .selectAll('g.' + constants.containerClassName)\n .data(menuData.length > 0 ? [0] : []);\n\n menus.enter().append('g')\n .classed(constants.containerClassName, true)\n .style('cursor', 'pointer');\n\n menus.exit().each(function() {\n // Most components don't need to explicitly remove autoMargin, because\n // marginPushers does this - but updatemenu updates don't go through\n // a full replot so we need to explicitly remove it.\n // This is for removing *all* updatemenus, removing individuals is\n // handled below, in headerGroups.exit\n d3.select(this).selectAll('g.' + constants.headerGroupClassName)\n .each(clearAutoMargin);\n }).remove();\n\n // return early if no update menus are visible\n if(menuData.length === 0) return;\n\n // join header group\n var headerGroups = menus.selectAll('g.' + constants.headerGroupClassName)\n .data(menuData, keyFunction);\n\n headerGroups.enter().append('g')\n .classed(constants.headerGroupClassName, true);\n\n // draw dropdown button container\n var gButton = Lib.ensureSingle(menus, 'g', constants.dropdownButtonGroupClassName, function(s) {\n s.style('pointer-events', 'all');\n });\n\n // find dimensions before plotting anything (this mutates menuOpts)\n for(var i = 0; i < menuData.length; i++) {\n var menuOpts = menuData[i];\n findDimensions(gd, menuOpts);\n }\n\n // setup scrollbox\n var scrollBoxId = 'updatemenus' + fullLayout._uid;\n var scrollBox = new ScrollBox(gd, gButton, scrollBoxId);\n\n // remove exiting header, remove dropped buttons and reset margins\n if(headerGroups.enter().size()) {\n // make sure gButton is on top of all headers\n gButton.node().parentNode.appendChild(gButton.node());\n gButton.call(removeAllButtons);\n }\n\n headerGroups.exit().each(function(menuOpts) {\n gButton.call(removeAllButtons);\n clearAutoMargin(menuOpts);\n }).remove();\n\n // draw headers!\n headerGroups.each(function(menuOpts) {\n var gHeader = d3.select(this);\n\n var _gButton = menuOpts.type === 'dropdown' ? gButton : null;\n\n Plots.manageCommandObserver(gd, menuOpts, menuOpts.buttons, function(data) {\n setActive(gd, menuOpts, menuOpts.buttons[data.index], gHeader, _gButton, scrollBox, data.index, true);\n });\n\n if(menuOpts.type === 'dropdown') {\n drawHeader(gd, gHeader, gButton, scrollBox, menuOpts);\n\n // if this menu is active, update the dropdown container\n if(isActive(gButton, menuOpts)) {\n drawButtons(gd, gHeader, gButton, scrollBox, menuOpts);\n }\n } else {\n drawButtons(gd, gHeader, null, null, menuOpts);\n }\n });\n};\n\n// Note that '_index' is set at the default step,\n// it corresponds to the menu index in the user layout update menu container.\n// Because a menu can be set invisible,\n// this is a more 'consistent' field than the index in the menuData.\nfunction keyFunction(menuOpts) {\n return menuOpts._index;\n}\n\nfunction isFolded(gButton) {\n return +gButton.attr(constants.menuIndexAttrName) === -1;\n}\n\nfunction isActive(gButton, menuOpts) {\n return +gButton.attr(constants.menuIndexAttrName) === menuOpts._index;\n}\n\nfunction setActive(gd, menuOpts, buttonOpts, gHeader, gButton, scrollBox, buttonIndex, isSilentUpdate) {\n // update 'active' attribute in menuOpts\n menuOpts.active = buttonIndex;\n\n // due to templating, it's possible this slider doesn't even exist yet\n arrayEditor(gd.layout, constants.name, menuOpts)\n .applyUpdate('active', buttonIndex);\n\n if(menuOpts.type === 'buttons') {\n drawButtons(gd, gHeader, null, null, menuOpts);\n } else if(menuOpts.type === 'dropdown') {\n // fold up buttons and redraw header\n gButton.attr(constants.menuIndexAttrName, '-1');\n\n drawHeader(gd, gHeader, gButton, scrollBox, menuOpts);\n\n if(!isSilentUpdate) {\n drawButtons(gd, gHeader, gButton, scrollBox, menuOpts);\n }\n }\n}\n\nfunction drawHeader(gd, gHeader, gButton, scrollBox, menuOpts) {\n var header = Lib.ensureSingle(gHeader, 'g', constants.headerClassName, function(s) {\n s.style('pointer-events', 'all');\n });\n\n var dims = menuOpts._dims;\n var active = menuOpts.active;\n var headerOpts = menuOpts.buttons[active] || constants.blankHeaderOpts;\n var posOpts = { y: menuOpts.pad.t, yPad: 0, x: menuOpts.pad.l, xPad: 0, index: 0 };\n var positionOverrides = {\n width: dims.headerWidth,\n height: dims.headerHeight\n };\n\n header\n .call(drawItem, menuOpts, headerOpts, gd)\n .call(setItemPosition, menuOpts, posOpts, positionOverrides);\n\n // draw drop arrow at the right edge\n var arrow = Lib.ensureSingle(gHeader, 'text', constants.headerArrowClassName, function(s) {\n s.attr('text-anchor', 'end')\n .call(Drawing.font, menuOpts.font)\n .text(constants.arrowSymbol[menuOpts.direction]);\n });\n\n arrow.attr({\n x: dims.headerWidth - constants.arrowOffsetX + menuOpts.pad.l,\n y: dims.headerHeight / 2 + constants.textOffsetY + menuOpts.pad.t\n });\n\n header.on('click', function() {\n gButton.call(removeAllButtons,\n String(isActive(gButton, menuOpts) ? -1 : menuOpts._index)\n );\n\n drawButtons(gd, gHeader, gButton, scrollBox, menuOpts);\n });\n\n header.on('mouseover', function() {\n header.call(styleOnMouseOver);\n });\n\n header.on('mouseout', function() {\n header.call(styleOnMouseOut, menuOpts);\n });\n\n // translate header group\n Drawing.setTranslate(gHeader, dims.lx, dims.ly);\n}\n\nfunction drawButtons(gd, gHeader, gButton, scrollBox, menuOpts) {\n // If this is a set of buttons, set pointer events = all since we play\n // some minor games with which container is which in order to simplify\n // the drawing of *either* buttons or menus\n if(!gButton) {\n gButton = gHeader;\n gButton.attr('pointer-events', 'all');\n }\n\n var buttonData = (!isFolded(gButton) || menuOpts.type === 'buttons') ?\n menuOpts.buttons :\n [];\n\n var klass = menuOpts.type === 'dropdown' ? constants.dropdownButtonClassName : constants.buttonClassName;\n\n var buttons = gButton.selectAll('g.' + klass)\n .data(Lib.filterVisible(buttonData));\n\n var enter = buttons.enter().append('g')\n .classed(klass, true);\n\n var exit = buttons.exit();\n\n if(menuOpts.type === 'dropdown') {\n enter.attr('opacity', '0')\n .transition()\n .attr('opacity', '1');\n\n exit.transition()\n .attr('opacity', '0')\n .remove();\n } else {\n exit.remove();\n }\n\n var x0 = 0;\n var y0 = 0;\n var dims = menuOpts._dims;\n\n var isVertical = ['up', 'down'].indexOf(menuOpts.direction) !== -1;\n\n if(menuOpts.type === 'dropdown') {\n if(isVertical) {\n y0 = dims.headerHeight + constants.gapButtonHeader;\n } else {\n x0 = dims.headerWidth + constants.gapButtonHeader;\n }\n }\n\n if(menuOpts.type === 'dropdown' && menuOpts.direction === 'up') {\n y0 = -constants.gapButtonHeader + constants.gapButton - dims.openHeight;\n }\n\n if(menuOpts.type === 'dropdown' && menuOpts.direction === 'left') {\n x0 = -constants.gapButtonHeader + constants.gapButton - dims.openWidth;\n }\n\n var posOpts = {\n x: dims.lx + x0 + menuOpts.pad.l,\n y: dims.ly + y0 + menuOpts.pad.t,\n yPad: constants.gapButton,\n xPad: constants.gapButton,\n index: 0,\n };\n\n var scrollBoxPosition = {\n l: posOpts.x + menuOpts.borderwidth,\n t: posOpts.y + menuOpts.borderwidth\n };\n\n buttons.each(function(buttonOpts, buttonIndex) {\n var button = d3.select(this);\n\n button\n .call(drawItem, menuOpts, buttonOpts, gd)\n .call(setItemPosition, menuOpts, posOpts);\n\n button.on('click', function() {\n // skip `dragend` events\n if(d3.event.defaultPrevented) return;\n\n if(buttonOpts.execute) {\n if(buttonOpts.args2 && menuOpts.active === buttonIndex) {\n setActive(gd, menuOpts, buttonOpts, gHeader, gButton, scrollBox, -1);\n Plots.executeAPICommand(gd, buttonOpts.method, buttonOpts.args2);\n } else {\n setActive(gd, menuOpts, buttonOpts, gHeader, gButton, scrollBox, buttonIndex);\n Plots.executeAPICommand(gd, buttonOpts.method, buttonOpts.args);\n }\n }\n\n gd.emit('plotly_buttonclicked', {menu: menuOpts, button: buttonOpts, active: menuOpts.active});\n });\n\n button.on('mouseover', function() {\n button.call(styleOnMouseOver);\n });\n\n button.on('mouseout', function() {\n button.call(styleOnMouseOut, menuOpts);\n buttons.call(styleButtons, menuOpts);\n });\n });\n\n buttons.call(styleButtons, menuOpts);\n\n if(isVertical) {\n scrollBoxPosition.w = Math.max(dims.openWidth, dims.headerWidth);\n scrollBoxPosition.h = posOpts.y - scrollBoxPosition.t;\n } else {\n scrollBoxPosition.w = posOpts.x - scrollBoxPosition.l;\n scrollBoxPosition.h = Math.max(dims.openHeight, dims.headerHeight);\n }\n\n scrollBoxPosition.direction = menuOpts.direction;\n\n if(scrollBox) {\n if(buttons.size()) {\n drawScrollBox(gd, gHeader, gButton, scrollBox, menuOpts, scrollBoxPosition);\n } else {\n hideScrollBox(scrollBox);\n }\n }\n}\n\nfunction drawScrollBox(gd, gHeader, gButton, scrollBox, menuOpts, position) {\n // enable the scrollbox\n var direction = menuOpts.direction;\n var isVertical = (direction === 'up' || direction === 'down');\n var dims = menuOpts._dims;\n\n var active = menuOpts.active;\n var translateX, translateY;\n var i;\n if(isVertical) {\n translateY = 0;\n for(i = 0; i < active; i++) {\n translateY += dims.heights[i] + constants.gapButton;\n }\n } else {\n translateX = 0;\n for(i = 0; i < active; i++) {\n translateX += dims.widths[i] + constants.gapButton;\n }\n }\n\n scrollBox.enable(position, translateX, translateY);\n\n if(scrollBox.hbar) {\n scrollBox.hbar\n .attr('opacity', '0')\n .transition()\n .attr('opacity', '1');\n }\n\n if(scrollBox.vbar) {\n scrollBox.vbar\n .attr('opacity', '0')\n .transition()\n .attr('opacity', '1');\n }\n}\n\nfunction hideScrollBox(scrollBox) {\n var hasHBar = !!scrollBox.hbar;\n var hasVBar = !!scrollBox.vbar;\n\n if(hasHBar) {\n scrollBox.hbar\n .transition()\n .attr('opacity', '0')\n .each('end', function() {\n hasHBar = false;\n if(!hasVBar) scrollBox.disable();\n });\n }\n\n if(hasVBar) {\n scrollBox.vbar\n .transition()\n .attr('opacity', '0')\n .each('end', function() {\n hasVBar = false;\n if(!hasHBar) scrollBox.disable();\n });\n }\n}\n\nfunction drawItem(item, menuOpts, itemOpts, gd) {\n item.call(drawItemRect, menuOpts)\n .call(drawItemText, menuOpts, itemOpts, gd);\n}\n\nfunction drawItemRect(item, menuOpts) {\n var rect = Lib.ensureSingle(item, 'rect', constants.itemRectClassName, function(s) {\n s.attr({\n rx: constants.rx,\n ry: constants.ry,\n 'shape-rendering': 'crispEdges'\n });\n });\n\n rect.call(Color.stroke, menuOpts.bordercolor)\n .call(Color.fill, menuOpts.bgcolor)\n .style('stroke-width', menuOpts.borderwidth + 'px');\n}\n\nfunction drawItemText(item, menuOpts, itemOpts, gd) {\n var text = Lib.ensureSingle(item, 'text', constants.itemTextClassName, function(s) {\n s.attr({\n 'text-anchor': 'start',\n 'data-notex': 1\n });\n });\n\n var tx = itemOpts.label;\n var _meta = gd._fullLayout._meta;\n if(_meta) tx = Lib.templateString(tx, _meta);\n\n text.call(Drawing.font, menuOpts.font)\n .text(tx)\n .call(svgTextUtils.convertToTspans, gd);\n}\n\nfunction styleButtons(buttons, menuOpts) {\n var active = menuOpts.active;\n\n buttons.each(function(buttonOpts, i) {\n var button = d3.select(this);\n\n if(i === active && menuOpts.showactive) {\n button.select('rect.' + constants.itemRectClassName)\n .call(Color.fill, constants.activeColor);\n }\n });\n}\n\nfunction styleOnMouseOver(item) {\n item.select('rect.' + constants.itemRectClassName)\n .call(Color.fill, constants.hoverColor);\n}\n\nfunction styleOnMouseOut(item, menuOpts) {\n item.select('rect.' + constants.itemRectClassName)\n .call(Color.fill, menuOpts.bgcolor);\n}\n\n// find item dimensions (this mutates menuOpts)\nfunction findDimensions(gd, menuOpts) {\n var dims = menuOpts._dims = {\n width1: 0,\n height1: 0,\n heights: [],\n widths: [],\n totalWidth: 0,\n totalHeight: 0,\n openWidth: 0,\n openHeight: 0,\n lx: 0,\n ly: 0\n };\n\n var fakeButtons = Drawing.tester.selectAll('g.' + constants.dropdownButtonClassName)\n .data(Lib.filterVisible(menuOpts.buttons));\n\n fakeButtons.enter().append('g')\n .classed(constants.dropdownButtonClassName, true);\n\n var isVertical = ['up', 'down'].indexOf(menuOpts.direction) !== -1;\n\n // loop over fake buttons to find width / height\n fakeButtons.each(function(buttonOpts, i) {\n var button = d3.select(this);\n\n button.call(drawItem, menuOpts, buttonOpts, gd);\n\n var text = button.select('.' + constants.itemTextClassName);\n\n // width is given by max width of all buttons\n var tWidth = text.node() && Drawing.bBox(text.node()).width;\n var wEff = Math.max(tWidth + constants.textPadX, constants.minWidth);\n\n // height is determined by item text\n var tHeight = menuOpts.font.size * LINE_SPACING;\n var tLines = svgTextUtils.lineCount(text);\n var hEff = Math.max(tHeight * tLines, constants.minHeight) + constants.textOffsetY;\n\n hEff = Math.ceil(hEff);\n wEff = Math.ceil(wEff);\n\n // Store per-item sizes since a row of horizontal buttons, for example,\n // don't all need to be the same width:\n dims.widths[i] = wEff;\n dims.heights[i] = hEff;\n\n // Height and width of individual element:\n dims.height1 = Math.max(dims.height1, hEff);\n dims.width1 = Math.max(dims.width1, wEff);\n\n if(isVertical) {\n dims.totalWidth = Math.max(dims.totalWidth, wEff);\n dims.openWidth = dims.totalWidth;\n dims.totalHeight += hEff + constants.gapButton;\n dims.openHeight += hEff + constants.gapButton;\n } else {\n dims.totalWidth += wEff + constants.gapButton;\n dims.openWidth += wEff + constants.gapButton;\n dims.totalHeight = Math.max(dims.totalHeight, hEff);\n dims.openHeight = dims.totalHeight;\n }\n });\n\n if(isVertical) {\n dims.totalHeight -= constants.gapButton;\n } else {\n dims.totalWidth -= constants.gapButton;\n }\n\n\n dims.headerWidth = dims.width1 + constants.arrowPadX;\n dims.headerHeight = dims.height1;\n\n if(menuOpts.type === 'dropdown') {\n if(isVertical) {\n dims.width1 += constants.arrowPadX;\n dims.totalHeight = dims.height1;\n } else {\n dims.totalWidth = dims.width1;\n }\n dims.totalWidth += constants.arrowPadX;\n }\n\n fakeButtons.remove();\n\n var paddedWidth = dims.totalWidth + menuOpts.pad.l + menuOpts.pad.r;\n var paddedHeight = dims.totalHeight + menuOpts.pad.t + menuOpts.pad.b;\n\n var graphSize = gd._fullLayout._size;\n dims.lx = graphSize.l + graphSize.w * menuOpts.x;\n dims.ly = graphSize.t + graphSize.h * (1 - menuOpts.y);\n\n var xanchor = 'left';\n if(Lib.isRightAnchor(menuOpts)) {\n dims.lx -= paddedWidth;\n xanchor = 'right';\n }\n if(Lib.isCenterAnchor(menuOpts)) {\n dims.lx -= paddedWidth / 2;\n xanchor = 'center';\n }\n\n var yanchor = 'top';\n if(Lib.isBottomAnchor(menuOpts)) {\n dims.ly -= paddedHeight;\n yanchor = 'bottom';\n }\n if(Lib.isMiddleAnchor(menuOpts)) {\n dims.ly -= paddedHeight / 2;\n yanchor = 'middle';\n }\n\n dims.totalWidth = Math.ceil(dims.totalWidth);\n dims.totalHeight = Math.ceil(dims.totalHeight);\n dims.lx = Math.round(dims.lx);\n dims.ly = Math.round(dims.ly);\n\n Plots.autoMargin(gd, autoMarginId(menuOpts), {\n x: menuOpts.x,\n y: menuOpts.y,\n l: paddedWidth * ({right: 1, center: 0.5}[xanchor] || 0),\n r: paddedWidth * ({left: 1, center: 0.5}[xanchor] || 0),\n b: paddedHeight * ({top: 1, middle: 0.5}[yanchor] || 0),\n t: paddedHeight * ({bottom: 1, middle: 0.5}[yanchor] || 0)\n });\n}\n\nfunction autoMarginId(menuOpts) {\n return constants.autoMarginIdRoot + menuOpts._index;\n}\n\n// set item positions (mutates posOpts)\nfunction setItemPosition(item, menuOpts, posOpts, overrideOpts) {\n overrideOpts = overrideOpts || {};\n var rect = item.select('.' + constants.itemRectClassName);\n var text = item.select('.' + constants.itemTextClassName);\n var borderWidth = menuOpts.borderwidth;\n var index = posOpts.index;\n var dims = menuOpts._dims;\n\n Drawing.setTranslate(item, borderWidth + posOpts.x, borderWidth + posOpts.y);\n\n var isVertical = ['up', 'down'].indexOf(menuOpts.direction) !== -1;\n var finalHeight = overrideOpts.height || (isVertical ? dims.heights[index] : dims.height1);\n\n rect.attr({\n x: 0,\n y: 0,\n width: overrideOpts.width || (isVertical ? dims.width1 : dims.widths[index]),\n height: finalHeight\n });\n\n var tHeight = menuOpts.font.size * LINE_SPACING;\n var tLines = svgTextUtils.lineCount(text);\n var spanOffset = ((tLines - 1) * tHeight / 2);\n\n svgTextUtils.positionText(text, constants.textOffsetX,\n finalHeight / 2 - spanOffset + constants.textOffsetY);\n\n if(isVertical) {\n posOpts.y += dims.heights[index] + posOpts.yPad;\n } else {\n posOpts.x += dims.widths[index] + posOpts.xPad;\n }\n\n posOpts.index++;\n}\n\nfunction removeAllButtons(gButton, newMenuIndexAttr) {\n gButton\n .attr(constants.menuIndexAttrName, newMenuIndexAttr || '-1')\n .selectAll('g.' + constants.dropdownButtonClassName).remove();\n}\n","'use strict';\n\nvar constants = require('./constants');\n\nmodule.exports = {\n moduleType: 'component',\n name: constants.name,\n\n layoutAttributes: require('./attributes'),\n supplyLayoutDefaults: require('./defaults'),\n\n draw: require('./draw')\n};\n","'use strict';\n\nmodule.exports = ScrollBox;\n\nvar d3 = require('@plotly/d3');\n\nvar Color = require('../color');\nvar Drawing = require('../drawing');\n\nvar Lib = require('../../lib');\n\n/**\n * Helper class to setup a scroll box\n *\n * @class\n * @param gd Plotly's graph div\n * @param container Container to be scroll-boxed (as a D3 selection)\n * @param {string} id Id for the clip path to implement the scroll box\n */\nfunction ScrollBox(gd, container, id) {\n this.gd = gd;\n this.container = container;\n this.id = id;\n\n // See ScrollBox.prototype.enable for further definition\n this.position = null; // scrollbox position\n this.translateX = null; // scrollbox horizontal translation\n this.translateY = null; // scrollbox vertical translation\n this.hbar = null; // horizontal scrollbar D3 selection\n this.vbar = null; // vertical scrollbar D3 selection\n\n // element to capture pointer events\n this.bg = this.container.selectAll('rect.scrollbox-bg').data([0]);\n\n this.bg.exit()\n .on('.drag', null)\n .on('wheel', null)\n .remove();\n\n this.bg.enter().append('rect')\n .classed('scrollbox-bg', true)\n .style('pointer-events', 'all')\n .attr({\n opacity: 0,\n x: 0,\n y: 0,\n width: 0,\n height: 0\n });\n}\n\n// scroll bar dimensions\nScrollBox.barWidth = 2;\nScrollBox.barLength = 20;\nScrollBox.barRadius = 2;\nScrollBox.barPad = 1;\nScrollBox.barColor = '#808BA4';\n\n/**\n * If needed, setup a clip path and scrollbars\n *\n * @method\n * @param {Object} position\n * @param {number} position.l Left side position (in pixels)\n * @param {number} position.t Top side (in pixels)\n * @param {number} position.w Width (in pixels)\n * @param {number} position.h Height (in pixels)\n * @param {string} [position.direction='down']\n * Either 'down', 'left', 'right' or 'up'\n * @param {number} [translateX=0] Horizontal offset (in pixels)\n * @param {number} [translateY=0] Vertical offset (in pixels)\n */\nScrollBox.prototype.enable = function enable(position, translateX, translateY) {\n var fullLayout = this.gd._fullLayout;\n var fullWidth = fullLayout.width;\n var fullHeight = fullLayout.height;\n\n // compute position of scrollbox\n this.position = position;\n\n var l = this.position.l;\n var w = this.position.w;\n var t = this.position.t;\n var h = this.position.h;\n var direction = this.position.direction;\n var isDown = (direction === 'down');\n var isLeft = (direction === 'left');\n var isRight = (direction === 'right');\n var isUp = (direction === 'up');\n var boxW = w;\n var boxH = h;\n var boxL, boxR;\n var boxT, boxB;\n\n if(!isDown && !isLeft && !isRight && !isUp) {\n this.position.direction = 'down';\n isDown = true;\n }\n\n var isVertical = isDown || isUp;\n if(isVertical) {\n boxL = l;\n boxR = boxL + boxW;\n\n if(isDown) {\n // anchor to top side\n boxT = t;\n boxB = Math.min(boxT + boxH, fullHeight);\n boxH = boxB - boxT;\n } else {\n // anchor to bottom side\n boxB = t + boxH;\n boxT = Math.max(boxB - boxH, 0);\n boxH = boxB - boxT;\n }\n } else {\n boxT = t;\n boxB = boxT + boxH;\n\n if(isLeft) {\n // anchor to right side\n boxR = l + boxW;\n boxL = Math.max(boxR - boxW, 0);\n boxW = boxR - boxL;\n } else {\n // anchor to left side\n boxL = l;\n boxR = Math.min(boxL + boxW, fullWidth);\n boxW = boxR - boxL;\n }\n }\n\n this._box = {\n l: boxL,\n t: boxT,\n w: boxW,\n h: boxH\n };\n\n // compute position of horizontal scroll bar\n var needsHorizontalScrollBar = (w > boxW);\n var hbarW = ScrollBox.barLength + 2 * ScrollBox.barPad;\n var hbarH = ScrollBox.barWidth + 2 * ScrollBox.barPad;\n // draw horizontal scrollbar on the bottom side\n var hbarL = l;\n var hbarT = t + h;\n\n if(hbarT + hbarH > fullHeight) hbarT = fullHeight - hbarH;\n\n var hbar = this.container.selectAll('rect.scrollbar-horizontal').data(\n (needsHorizontalScrollBar) ? [0] : []);\n\n hbar.exit()\n .on('.drag', null)\n .remove();\n\n hbar.enter().append('rect')\n .classed('scrollbar-horizontal', true)\n .call(Color.fill, ScrollBox.barColor);\n\n if(needsHorizontalScrollBar) {\n this.hbar = hbar.attr({\n rx: ScrollBox.barRadius,\n ry: ScrollBox.barRadius,\n x: hbarL,\n y: hbarT,\n width: hbarW,\n height: hbarH\n });\n\n // hbar center moves between hbarXMin and hbarXMin + hbarTranslateMax\n this._hbarXMin = hbarL + hbarW / 2;\n this._hbarTranslateMax = boxW - hbarW;\n } else {\n delete this.hbar;\n delete this._hbarXMin;\n delete this._hbarTranslateMax;\n }\n\n // compute position of vertical scroll bar\n var needsVerticalScrollBar = (h > boxH);\n var vbarW = ScrollBox.barWidth + 2 * ScrollBox.barPad;\n var vbarH = ScrollBox.barLength + 2 * ScrollBox.barPad;\n // draw vertical scrollbar on the right side\n var vbarL = l + w;\n var vbarT = t;\n\n if(vbarL + vbarW > fullWidth) vbarL = fullWidth - vbarW;\n\n var vbar = this.container.selectAll('rect.scrollbar-vertical').data(\n (needsVerticalScrollBar) ? [0] : []);\n\n vbar.exit()\n .on('.drag', null)\n .remove();\n\n vbar.enter().append('rect')\n .classed('scrollbar-vertical', true)\n .call(Color.fill, ScrollBox.barColor);\n\n if(needsVerticalScrollBar) {\n this.vbar = vbar.attr({\n rx: ScrollBox.barRadius,\n ry: ScrollBox.barRadius,\n x: vbarL,\n y: vbarT,\n width: vbarW,\n height: vbarH\n });\n\n // vbar center moves between vbarYMin and vbarYMin + vbarTranslateMax\n this._vbarYMin = vbarT + vbarH / 2;\n this._vbarTranslateMax = boxH - vbarH;\n } else {\n delete this.vbar;\n delete this._vbarYMin;\n delete this._vbarTranslateMax;\n }\n\n // setup a clip path (if scroll bars are needed)\n var clipId = this.id;\n var clipL = boxL - 0.5;\n var clipR = (needsVerticalScrollBar) ? boxR + vbarW + 0.5 : boxR + 0.5;\n var clipT = boxT - 0.5;\n var clipB = (needsHorizontalScrollBar) ? boxB + hbarH + 0.5 : boxB + 0.5;\n\n var clipPath = fullLayout._topdefs.selectAll('#' + clipId)\n .data((needsHorizontalScrollBar || needsVerticalScrollBar) ? [0] : []);\n\n clipPath.exit().remove();\n\n clipPath.enter()\n .append('clipPath').attr('id', clipId)\n .append('rect');\n\n if(needsHorizontalScrollBar || needsVerticalScrollBar) {\n this._clipRect = clipPath.select('rect').attr({\n x: Math.floor(clipL),\n y: Math.floor(clipT),\n width: Math.ceil(clipR) - Math.floor(clipL),\n height: Math.ceil(clipB) - Math.floor(clipT)\n });\n\n this.container.call(Drawing.setClipUrl, clipId, this.gd);\n\n this.bg.attr({\n x: l,\n y: t,\n width: w,\n height: h\n });\n } else {\n this.bg.attr({\n width: 0,\n height: 0\n });\n this.container\n .on('wheel', null)\n .on('.drag', null)\n .call(Drawing.setClipUrl, null);\n delete this._clipRect;\n }\n\n // set up drag listeners (if scroll bars are needed)\n if(needsHorizontalScrollBar || needsVerticalScrollBar) {\n var onBoxDrag = d3.behavior.drag()\n .on('dragstart', function() {\n d3.event.sourceEvent.preventDefault();\n })\n .on('drag', this._onBoxDrag.bind(this));\n\n this.container\n .on('wheel', null)\n .on('wheel', this._onBoxWheel.bind(this))\n .on('.drag', null)\n .call(onBoxDrag);\n\n var onBarDrag = d3.behavior.drag()\n .on('dragstart', function() {\n d3.event.sourceEvent.preventDefault();\n d3.event.sourceEvent.stopPropagation();\n })\n .on('drag', this._onBarDrag.bind(this));\n\n if(needsHorizontalScrollBar) {\n this.hbar\n .on('.drag', null)\n .call(onBarDrag);\n }\n\n if(needsVerticalScrollBar) {\n this.vbar\n .on('.drag', null)\n .call(onBarDrag);\n }\n }\n\n // set scrollbox translation\n this.setTranslate(translateX, translateY);\n};\n\n/**\n * If present, remove clip-path and scrollbars\n *\n * @method\n */\nScrollBox.prototype.disable = function disable() {\n if(this.hbar || this.vbar) {\n this.bg.attr({\n width: 0,\n height: 0\n });\n this.container\n .on('wheel', null)\n .on('.drag', null)\n .call(Drawing.setClipUrl, null);\n delete this._clipRect;\n }\n\n if(this.hbar) {\n this.hbar.on('.drag', null);\n this.hbar.remove();\n delete this.hbar;\n delete this._hbarXMin;\n delete this._hbarTranslateMax;\n }\n\n if(this.vbar) {\n this.vbar.on('.drag', null);\n this.vbar.remove();\n delete this.vbar;\n delete this._vbarYMin;\n delete this._vbarTranslateMax;\n }\n};\n\n/**\n * Handles scroll box drag events\n *\n * @method\n */\nScrollBox.prototype._onBoxDrag = function _onBoxDrag() {\n var translateX = this.translateX;\n var translateY = this.translateY;\n\n if(this.hbar) {\n translateX -= d3.event.dx;\n }\n\n if(this.vbar) {\n translateY -= d3.event.dy;\n }\n\n this.setTranslate(translateX, translateY);\n};\n\n/**\n * Handles scroll box wheel events\n *\n * @method\n */\nScrollBox.prototype._onBoxWheel = function _onBoxWheel() {\n var translateX = this.translateX;\n var translateY = this.translateY;\n\n if(this.hbar) {\n translateX += d3.event.deltaY;\n }\n\n if(this.vbar) {\n translateY += d3.event.deltaY;\n }\n\n this.setTranslate(translateX, translateY);\n};\n\n/**\n * Handles scroll bar drag events\n *\n * @method\n */\nScrollBox.prototype._onBarDrag = function _onBarDrag() {\n var translateX = this.translateX;\n var translateY = this.translateY;\n\n if(this.hbar) {\n var xMin = translateX + this._hbarXMin;\n var xMax = xMin + this._hbarTranslateMax;\n var x = Lib.constrain(d3.event.x, xMin, xMax);\n var xf = (x - xMin) / (xMax - xMin);\n\n var translateXMax = this.position.w - this._box.w;\n\n translateX = xf * translateXMax;\n }\n\n if(this.vbar) {\n var yMin = translateY + this._vbarYMin;\n var yMax = yMin + this._vbarTranslateMax;\n var y = Lib.constrain(d3.event.y, yMin, yMax);\n var yf = (y - yMin) / (yMax - yMin);\n\n var translateYMax = this.position.h - this._box.h;\n\n translateY = yf * translateYMax;\n }\n\n this.setTranslate(translateX, translateY);\n};\n\n/**\n * Set clip path and scroll bar translate transform\n *\n * @method\n * @param {number} [translateX=0] Horizontal offset (in pixels)\n * @param {number} [translateY=0] Vertical offset (in pixels)\n */\nScrollBox.prototype.setTranslate = function setTranslate(translateX, translateY) {\n // store translateX and translateY (needed by mouse event handlers)\n var translateXMax = this.position.w - this._box.w;\n var translateYMax = this.position.h - this._box.h;\n\n translateX = Lib.constrain(translateX || 0, 0, translateXMax);\n translateY = Lib.constrain(translateY || 0, 0, translateYMax);\n\n this.translateX = translateX;\n this.translateY = translateY;\n\n this.container.call(Drawing.setTranslate,\n this._box.l - this.position.l - translateX,\n this._box.t - this.position.t - translateY);\n\n if(this._clipRect) {\n this._clipRect.attr({\n x: Math.floor(this.position.l + translateX - 0.5),\n y: Math.floor(this.position.t + translateY - 0.5)\n });\n }\n\n if(this.hbar) {\n var xf = translateX / translateXMax;\n\n this.hbar.call(Drawing.setTranslate,\n translateX + xf * this._hbarTranslateMax,\n translateY);\n }\n\n if(this.vbar) {\n var yf = translateY / translateYMax;\n\n this.vbar.call(Drawing.setTranslate,\n translateX,\n translateY + yf * this._vbarTranslateMax);\n }\n};\n","'use strict';\n\n// fraction of some size to get to a named position\nmodule.exports = {\n // from bottom left: this is the origin of our paper-reference\n // positioning system\n FROM_BL: {\n left: 0,\n center: 0.5,\n right: 1,\n bottom: 0,\n middle: 0.5,\n top: 1\n },\n // from top left: this is the screen pixel positioning origin\n FROM_TL: {\n left: 0,\n center: 0.5,\n right: 1,\n bottom: 1,\n middle: 0.5,\n top: 0\n },\n // from bottom right: sometimes you just need the opposite of ^^\n FROM_BR: {\n left: 1,\n center: 0.5,\n right: 0,\n bottom: 0,\n middle: 0.5,\n top: 1\n },\n // multiple of fontSize to get the vertical offset between lines\n LINE_SPACING: 1.3,\n\n // multiple of fontSize to shift from the baseline\n // to the cap (captical letter) line\n // (to use when we don't calculate this shift from Drawing.bBox)\n // This is an approximation since in reality cap height can differ\n // from font to font. However, according to Wikipedia\n // an \"average\" font might have a cap height of 70% of the em\n // https://en.wikipedia.org/wiki/Em_(typography)#History\n CAP_SHIFT: 0.70,\n\n // half the cap height (distance between baseline and cap line)\n // of an \"average\" font (for more info see above).\n MID_SHIFT: 0.35,\n\n OPPOSITE_SIDE: {\n left: 'right',\n right: 'left',\n top: 'bottom',\n bottom: 'top'\n }\n};\n","'use strict';\n\nmodule.exports = {\n axisRefDescription: function(axisname, lower, upper) {\n return [\n 'If set to a', axisname, 'axis id (e.g. *' + axisname + '* or',\n '*' + axisname + '2*), the `' + axisname + '` position refers to a',\n axisname, 'coordinate. If set to *paper*, the `' + axisname + '`',\n 'position refers to the distance from the', lower, 'of the plotting',\n 'area in normalized coordinates where *0* (*1*) corresponds to the',\n lower, '(' + upper + '). If set to a', axisname, 'axis ID followed by',\n '*domain* (separated by a space), the position behaves like for',\n '*paper*, but refers to the distance in fractions of the domain',\n 'length from the', lower, 'of the domain of that axis: e.g.,',\n '*' + axisname + '2 domain* refers to the domain of the second',\n axisname, ' axis and a', axisname, 'position of 0.5 refers to the',\n 'point between the', lower, 'and the', upper, 'of the domain of the',\n 'second', axisname, 'axis.',\n ].join(' ');\n }\n};\n","'use strict';\n\nmodule.exports = {\n INCREASING: {\n COLOR: '#3D9970',\n SYMBOL: '▲'\n },\n DECREASING: {\n COLOR: '#FF4136',\n SYMBOL: '▼'\n }\n};\n","'use strict';\n\nmodule.exports = {\n FORMAT_LINK: 'https://github.com/d3/d3-format/tree/v1.4.5#d3-format',\n DATE_FORMAT_LINK: 'https://github.com/d3/d3-time-format/tree/v2.2.3#locale_format'\n};\n","'use strict';\n\nmodule.exports = {\n COMPARISON_OPS: ['=', '!=', '<', '>=', '>', '<='],\n COMPARISON_OPS2: ['=', '<', '>=', '>', '<='],\n INTERVAL_OPS: ['[]', '()', '[)', '(]', '][', ')(', '](', ')['],\n SET_OPS: ['{}', '}{'],\n CONSTRAINT_REDUCTION: {\n // for contour constraints, open/closed endpoints are equivalent\n '=': '=',\n\n '<': '<',\n '<=': '<',\n\n '>': '>',\n '>=': '>',\n\n '[]': '[]',\n '()': '[]',\n '[)': '[]',\n '(]': '[]',\n\n '][': '][',\n ')(': '][',\n '](': '][',\n ')[': ']['\n }\n};\n","'use strict';\n\nmodule.exports = {\n solid: [[], 0],\n dot: [[0.5, 1], 200],\n dash: [[0.5, 1], 50],\n longdash: [[0.5, 1], 10],\n dashdot: [[0.5, 0.625, 0.875, 1], 50],\n longdashdot: [[0.5, 0.7, 0.8, 1], 10]\n};\n","'use strict';\n\nmodule.exports = {\n circle: '●',\n 'circle-open': '○',\n square: '■',\n 'square-open': '□',\n diamond: '◆',\n 'diamond-open': '◇',\n cross: '+',\n x: '❌'\n};\n","'use strict';\n\n\nmodule.exports = {\n /**\n * Timing information for interactive elements\n */\n SHOW_PLACEHOLDER: 100,\n HIDE_PLACEHOLDER: 1000,\n\n // opacity dimming fraction for points that are not in selection\n DESELECTDIM: 0.2\n};\n","'use strict';\n\n\nmodule.exports = {\n /**\n * Standardize all missing data in calcdata to use undefined\n * never null or NaN.\n * That way we can use !==undefined, or !== BADNUM,\n * to test for real data\n */\n BADNUM: undefined,\n\n /*\n * Limit certain operations to well below floating point max value\n * to avoid glitches: Make sure that even when you multiply it by the\n * number of pixels on a giant screen it still works\n */\n FP_SAFE: Number.MAX_VALUE * 1e-4,\n\n /*\n * conversion of date units to milliseconds\n * year and month constants are marked \"AVG\"\n * to remind us that not all years and months\n * have the same length\n */\n ONEMAXYEAR: 31622400000, // 366 * ONEDAY\n ONEAVGYEAR: 31557600000, // 365.25 days\n ONEMINYEAR: 31536000000, // 365 * ONEDAY\n ONEMAXQUARTER: 7948800000, // 92 * ONEDAY\n ONEAVGQUARTER: 7889400000, // 1/4 of ONEAVGYEAR\n ONEMINQUARTER: 7689600000, // 89 * ONEDAY\n ONEMAXMONTH: 2678400000, // 31 * ONEDAY\n ONEAVGMONTH: 2629800000, // 1/12 of ONEAVGYEAR\n ONEMINMONTH: 2419200000, // 28 * ONEDAY\n ONEWEEK: 604800000, // 7 * ONEDAY\n ONEDAY: 86400000, // 24 * ONEHOUR\n ONEHOUR: 3600000,\n ONEMIN: 60000,\n ONESEC: 1000,\n ONEMILLI: 1,\n ONEMICROSEC: 0.001,\n /*\n * For fast conversion btwn world calendars and epoch ms, the Julian Day Number\n * of the unix epoch. From calendars.instance().newDate(1970, 1, 1).toJD()\n */\n EPOCHJD: 2440587.5,\n\n /*\n * Are two values nearly equal? Compare to 1PPM\n */\n ALMOST_EQUAL: 1 - 1e-6,\n\n /*\n * If we're asked to clip a non-positive log value, how far off-screen\n * do we put it?\n */\n LOG_CLIP: 10,\n\n /*\n * not a number, but for displaying numbers: the \"minus sign\" symbol is\n * wider than the regular ascii dash \"-\"\n */\n MINUS_SIGN: '\\u2212'\n};\n","'use strict';\n\n// Pixelated image rendering\n// The actual CSS declaration is prepended with fallbacks for older browsers.\n// NB. IE's `-ms-interpolation-mode` works only with not with SVG \n// https://developer.mozilla.org/en-US/docs/Web/CSS/image-rendering\n// https://caniuse.com/?search=image-rendering\n// http://phrogz.net/tmp/canvas_image_zoom.html\n\nexports.CSS_DECLARATIONS = [\n ['image-rendering', 'optimizeSpeed'],\n ['image-rendering', '-moz-crisp-edges'],\n ['image-rendering', '-o-crisp-edges'],\n ['image-rendering', '-webkit-optimize-contrast'],\n ['image-rendering', 'optimize-contrast'],\n ['image-rendering', 'crisp-edges'],\n ['image-rendering', 'pixelated']\n];\n\nexports.STYLE = exports.CSS_DECLARATIONS.map(function(d) {\n return d.join(': ') + '; ';\n}).join('');\n","'use strict';\n\n\nexports.xmlns = 'http://www.w3.org/2000/xmlns/';\nexports.svg = 'http://www.w3.org/2000/svg';\nexports.xlink = 'http://www.w3.org/1999/xlink';\n\n// the 'old' d3 quirk got fix in v3.5.7\n// https://github.com/mbostock/d3/commit/a6f66e9dd37f764403fc7c1f26be09ab4af24fed\nexports.svgAttrs = {\n xmlns: exports.svg,\n 'xmlns:xlink': exports.xlink\n};\n","'use strict';\n\nexports.version = require('./version').version;\n\n// inject promise polyfill\nrequire('native-promise-only');\n\n// inject plot css\nrequire('../build/plotcss');\n\n// include registry module and expose register method\nvar Registry = require('./registry');\nvar register = exports.register = Registry.register;\n\n// expose plot api methods\nvar plotApi = require('./plot_api');\nvar methodNames = Object.keys(plotApi);\nfor(var i = 0; i < methodNames.length; i++) {\n var name = methodNames[i];\n // _ -> private API methods, but still registered for internal use\n if(name.charAt(0) !== '_') exports[name] = plotApi[name];\n register({\n moduleType: 'apiMethod',\n name: name,\n fn: plotApi[name]\n });\n}\n\n// scatter is the only trace included by default\nregister(require('./traces/scatter'));\n\n// register all registrable components modules\nregister([\n require('./components/annotations'),\n require('./components/annotations3d'),\n require('./components/selections'),\n require('./components/shapes'),\n require('./components/images'),\n require('./components/updatemenus'),\n require('./components/sliders'),\n require('./components/rangeslider'),\n require('./components/rangeselector'),\n require('./components/grid'),\n require('./components/errorbars'),\n require('./components/colorscale'),\n require('./components/colorbar'),\n require('./components/legend'), // legend needs to come after shape | legend defaults depends on shapes\n require('./components/fx'), // fx needs to come after legend | unified hover defaults depends on legends\n require('./components/modebar')\n]);\n\n// locales en and en-US are required for default behavior\nregister([\n require('./locale-en'),\n require('./locale-en-us')\n]);\n\n// locales that are present in the window should be loaded\nif(window.PlotlyLocales && Array.isArray(window.PlotlyLocales)) {\n register(window.PlotlyLocales);\n delete window.PlotlyLocales;\n}\n\n// plot icons\nexports.Icons = require('./fonts/ploticon');\n\n// unofficial 'beta' plot methods, use at your own risk\nvar Fx = require('./components/fx');\nvar Plots = require('./plots/plots');\n\nexports.Plots = {\n resize: Plots.resize,\n graphJson: Plots.graphJson,\n sendDataToCloud: Plots.sendDataToCloud\n};\nexports.Fx = {\n hover: Fx.hover,\n unhover: Fx.unhover,\n loneHover: Fx.loneHover,\n loneUnhover: Fx.loneUnhover\n};\nexports.Snapshot = require('./snapshot');\nexports.PlotSchema = require('./plot_api/plot_schema');\n","'use strict';\n\nmodule.exports = {\n undo: {\n width: 857.1,\n height: 1000,\n path: 'm857 350q0-87-34-166t-91-137-137-92-166-34q-96 0-183 41t-147 114q-4 6-4 13t5 11l76 77q6 5 14 5 9-1 13-7 41-53 100-82t126-29q58 0 110 23t92 61 61 91 22 111-22 111-61 91-92 61-110 23q-55 0-105-20t-90-57l77-77q17-16 8-38-10-23-33-23h-250q-15 0-25 11t-11 25v250q0 24 22 33 22 10 39-8l72-72q60 57 137 88t159 31q87 0 166-34t137-92 91-137 34-166z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n home: {\n width: 928.6,\n height: 1000,\n path: 'm786 296v-267q0-15-11-26t-25-10h-214v214h-143v-214h-214q-15 0-25 10t-11 26v267q0 1 0 2t0 2l321 264 321-264q1-1 1-4z m124 39l-34-41q-5-5-12-6h-2q-7 0-12 3l-386 322-386-322q-7-4-13-4-7 2-12 7l-35 41q-4 5-3 13t6 12l401 334q18 15 42 15t43-15l136-114v109q0 8 5 13t13 5h107q8 0 13-5t5-13v-227l122-102q5-5 6-12t-4-13z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n 'camera-retro': {\n width: 1000,\n height: 1000,\n path: 'm518 386q0 8-5 13t-13 5q-37 0-63-27t-26-63q0-8 5-13t13-5 12 5 5 13q0 23 16 38t38 16q8 0 13 5t5 13z m125-73q0-59-42-101t-101-42-101 42-42 101 42 101 101 42 101-42 42-101z m-572-320h858v71h-858v-71z m643 320q0 89-62 152t-152 62-151-62-63-152 63-151 151-63 152 63 62 151z m-571 358h214v72h-214v-72z m-72-107h858v143h-462l-36-71h-360v-72z m929 143v-714q0-30-21-51t-50-21h-858q-29 0-50 21t-21 51v714q0 30 21 51t50 21h858q29 0 50-21t21-51z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n zoombox: {\n width: 1000,\n height: 1000,\n path: 'm1000-25l-250 251c40 63 63 138 63 218 0 224-182 406-407 406-224 0-406-182-406-406s183-406 407-406c80 0 155 22 218 62l250-250 125 125z m-812 250l0 438 437 0 0-438-437 0z m62 375l313 0 0-312-313 0 0 312z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n pan: {\n width: 1000,\n height: 1000,\n path: 'm1000 350l-187 188 0-125-250 0 0 250 125 0-188 187-187-187 125 0 0-250-250 0 0 125-188-188 186-187 0 125 252 0 0-250-125 0 187-188 188 188-125 0 0 250 250 0 0-126 187 188z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n zoom_plus: {\n width: 875,\n height: 1000,\n path: 'm1 787l0-875 875 0 0 875-875 0z m687-500l-187 0 0-187-125 0 0 187-188 0 0 125 188 0 0 187 125 0 0-187 187 0 0-125z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n zoom_minus: {\n width: 875,\n height: 1000,\n path: 'm0 788l0-876 875 0 0 876-875 0z m688-500l-500 0 0 125 500 0 0-125z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n autoscale: {\n width: 1000,\n height: 1000,\n path: 'm250 850l-187 0-63 0 0-62 0-188 63 0 0 188 187 0 0 62z m688 0l-188 0 0-62 188 0 0-188 62 0 0 188 0 62-62 0z m-875-938l0 188-63 0 0-188 0-62 63 0 187 0 0 62-187 0z m875 188l0-188-188 0 0-62 188 0 62 0 0 62 0 188-62 0z m-125 188l-1 0-93-94-156 156 156 156 92-93 2 0 0 250-250 0 0-2 93-92-156-156-156 156 94 92 0 2-250 0 0-250 0 0 93 93 157-156-157-156-93 94 0 0 0-250 250 0 0 0-94 93 156 157 156-157-93-93 0 0 250 0 0 250z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n tooltip_basic: {\n width: 1500,\n height: 1000,\n path: 'm375 725l0 0-375-375 375-374 0-1 1125 0 0 750-1125 0z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n tooltip_compare: {\n width: 1125,\n height: 1000,\n path: 'm187 786l0 2-187-188 188-187 0 0 937 0 0 373-938 0z m0-499l0 1-187-188 188-188 0 0 937 0 0 376-938-1z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n plotlylogo: {\n width: 1542,\n height: 1000,\n path: 'm0-10h182v-140h-182v140z m228 146h183v-286h-183v286z m225 714h182v-1000h-182v1000z m225-285h182v-715h-182v715z m225 142h183v-857h-183v857z m231-428h182v-429h-182v429z m225-291h183v-138h-183v138z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n 'z-axis': {\n width: 1000,\n height: 1000,\n path: 'm833 5l-17 108v41l-130-65 130-66c0 0 0 38 0 39 0-1 36-14 39-25 4-15-6-22-16-30-15-12-39-16-56-20-90-22-187-23-279-23-261 0-341 34-353 59 3 60 228 110 228 110-140-8-351-35-351-116 0-120 293-142 474-142 155 0 477 22 477 142 0 50-74 79-163 96z m-374 94c-58-5-99-21-99-40 0-24 65-43 144-43 79 0 143 19 143 43 0 19-42 34-98 40v216h87l-132 135-133-135h88v-216z m167 515h-136v1c16 16 31 34 46 52l84 109v54h-230v-71h124v-1c-16-17-28-32-44-51l-89-114v-51h245v72z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n '3d_rotate': {\n width: 1000,\n height: 1000,\n path: 'm922 660c-5 4-9 7-14 11-359 263-580-31-580-31l-102 28 58-400c0 1 1 1 2 2 118 108 351 249 351 249s-62 27-100 42c88 83 222 183 347 122 16-8 30-17 44-27-2 1-4 2-6 4z m36-329c0 0 64 229-88 296-62 27-124 14-175-11 157-78 225-208 249-266 8-19 11-31 11-31 2 5 6 15 11 32-5-13-8-20-8-20z m-775-239c70-31 117-50 198-32-121 80-199 346-199 346l-96-15-58-12c0 0 55-226 155-287z m603 133l-317-139c0 0 4-4 19-14 7-5 24-15 24-15s-177-147-389 4c235-287 536-112 536-112l31-22 100 299-4-1z m-298-153c6-4 14-9 24-15 0 0-17 10-24 15z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n camera: {\n width: 1000,\n height: 1000,\n path: 'm500 450c-83 0-150-67-150-150 0-83 67-150 150-150 83 0 150 67 150 150 0 83-67 150-150 150z m400 150h-120c-16 0-34 13-39 29l-31 93c-6 15-23 28-40 28h-340c-16 0-34-13-39-28l-31-94c-6-15-23-28-40-28h-120c-55 0-100-45-100-100v-450c0-55 45-100 100-100h800c55 0 100 45 100 100v450c0 55-45 100-100 100z m-400-550c-138 0-250 112-250 250 0 138 112 250 250 250 138 0 250-112 250-250 0-138-112-250-250-250z m365 380c-19 0-35 16-35 35 0 19 16 35 35 35 19 0 35-16 35-35 0-19-16-35-35-35z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n movie: {\n width: 1000,\n height: 1000,\n path: 'm938 413l-188-125c0 37-17 71-44 94 64 38 107 107 107 187 0 121-98 219-219 219-121 0-219-98-219-219 0-61 25-117 66-156h-115c30 33 49 76 49 125 0 103-84 187-187 187s-188-84-188-187c0-57 26-107 65-141-38-22-65-62-65-109v-250c0-70 56-126 125-126h500c69 0 125 56 125 126l188-126c34 0 62 28 62 63v375c0 35-28 63-62 63z m-750 0c-69 0-125 56-125 125s56 125 125 125 125-56 125-125-56-125-125-125z m406-1c-87 0-157 70-157 157 0 86 70 156 157 156s156-70 156-156-70-157-156-157z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n question: {\n width: 857.1,\n height: 1000,\n path: 'm500 82v107q0 8-5 13t-13 5h-107q-8 0-13-5t-5-13v-107q0-8 5-13t13-5h107q8 0 13 5t5 13z m143 375q0 49-31 91t-77 65-95 23q-136 0-207-119-9-14 4-24l74-55q4-4 10-4 9 0 14 7 30 38 48 51 19 14 48 14 27 0 48-15t21-33q0-21-11-34t-38-25q-35-16-65-48t-29-70v-20q0-8 5-13t13-5h107q8 0 13 5t5 13q0 10 12 27t30 28q18 10 28 16t25 19 25 27 16 34 7 45z m214-107q0-117-57-215t-156-156-215-58-216 58-155 156-58 215 58 215 155 156 216 58 215-58 156-156 57-215z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n disk: {\n width: 857.1,\n height: 1000,\n path: 'm214-7h429v214h-429v-214z m500 0h72v500q0 8-6 21t-11 20l-157 156q-5 6-19 12t-22 5v-232q0-22-15-38t-38-16h-322q-22 0-37 16t-16 38v232h-72v-714h72v232q0 22 16 38t37 16h465q22 0 38-16t15-38v-232z m-214 518v178q0 8-5 13t-13 5h-107q-7 0-13-5t-5-13v-178q0-8 5-13t13-5h107q7 0 13 5t5 13z m357-18v-518q0-22-15-38t-38-16h-750q-23 0-38 16t-16 38v750q0 22 16 38t38 16h517q23 0 50-12t42-26l156-157q16-15 27-42t11-49z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n drawopenpath: {\n width: 70,\n height: 70,\n path: 'M33.21,85.65a7.31,7.31,0,0,1-2.59-.48c-8.16-3.11-9.27-19.8-9.88-41.3-.1-3.58-.19-6.68-.35-9-.15-2.1-.67-3.48-1.43-3.79-2.13-.88-7.91,2.32-12,5.86L3,32.38c1.87-1.64,11.55-9.66,18.27-6.9,2.13.87,4.75,3.14,5.17,9,.17,2.43.26,5.59.36,9.25a224.17,224.17,0,0,0,1.5,23.4c1.54,10.76,4,12.22,4.48,12.4.84.32,2.79-.46,5.76-3.59L43,80.07C41.53,81.57,37.68,85.64,33.21,85.65ZM74.81,69a11.34,11.34,0,0,0,6.09-6.72L87.26,44.5,74.72,32,56.9,38.35c-2.37.86-5.57,3.42-6.61,6L38.65,72.14l8.42,8.43ZM55,46.27a7.91,7.91,0,0,1,3.64-3.17l14.8-5.3,8,8L76.11,60.6l-.06.19a6.37,6.37,0,0,1-3,3.43L48.25,74.59,44.62,71Zm16.57,7.82A6.9,6.9,0,1,0,64.64,61,6.91,6.91,0,0,0,71.54,54.09Zm-4.05,0a2.85,2.85,0,1,1-2.85-2.85A2.86,2.86,0,0,1,67.49,54.09Zm-4.13,5.22L60.5,56.45,44.26,72.7l2.86,2.86ZM97.83,35.67,84.14,22l-8.57,8.57L89.26,44.24Zm-13.69-8,8,8-2.85,2.85-8-8Z',\n transform: 'matrix(1 0 0 1 -15 -15)'\n },\n drawclosedpath: {\n width: 90,\n height: 90,\n path: 'M88.41,21.12a26.56,26.56,0,0,0-36.18,0l-2.07,2-2.07-2a26.57,26.57,0,0,0-36.18,0,23.74,23.74,0,0,0,0,34.8L48,90.12a3.22,3.22,0,0,0,4.42,0l36-34.21a23.73,23.73,0,0,0,0-34.79ZM84,51.24,50.16,83.35,16.35,51.25a17.28,17.28,0,0,1,0-25.47,20,20,0,0,1,27.3,0l4.29,4.07a3.23,3.23,0,0,0,4.44,0l4.29-4.07a20,20,0,0,1,27.3,0,17.27,17.27,0,0,1,0,25.46ZM66.76,47.68h-33v6.91h33ZM53.35,35H46.44V68h6.91Z',\n transform: 'matrix(1 0 0 1 -5 -5)'\n },\n lasso: {\n width: 1031,\n height: 1000,\n path: 'm1018 538c-36 207-290 336-568 286-277-48-473-256-436-463 10-57 36-108 76-151-13-66 11-137 68-183 34-28 75-41 114-42l-55-70 0 0c-2-1-3-2-4-3-10-14-8-34 5-45 14-11 34-8 45 4 1 1 2 3 2 5l0 0 113 140c16 11 31 24 45 40 4 3 6 7 8 11 48-3 100 0 151 9 278 48 473 255 436 462z m-624-379c-80 14-149 48-197 96 42 42 109 47 156 9 33-26 47-66 41-105z m-187-74c-19 16-33 37-39 60 50-32 109-55 174-68-42-25-95-24-135 8z m360 75c-34-7-69-9-102-8 8 62-16 128-68 170-73 59-175 54-244-5-9 20-16 40-20 61-28 159 121 317 333 354s407-60 434-217c28-159-121-318-333-355z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n selectbox: {\n width: 1000,\n height: 1000,\n path: 'm0 850l0-143 143 0 0 143-143 0z m286 0l0-143 143 0 0 143-143 0z m285 0l0-143 143 0 0 143-143 0z m286 0l0-143 143 0 0 143-143 0z m-857-286l0-143 143 0 0 143-143 0z m857 0l0-143 143 0 0 143-143 0z m-857-285l0-143 143 0 0 143-143 0z m857 0l0-143 143 0 0 143-143 0z m-857-286l0-143 143 0 0 143-143 0z m286 0l0-143 143 0 0 143-143 0z m285 0l0-143 143 0 0 143-143 0z m286 0l0-143 143 0 0 143-143 0z',\n transform: 'matrix(1 0 0 -1 0 850)'\n },\n drawline: {\n width: 70,\n height: 70,\n path: 'M60.64,62.3a11.29,11.29,0,0,0,6.09-6.72l6.35-17.72L60.54,25.31l-17.82,6.4c-2.36.86-5.57,3.41-6.6,6L24.48,65.5l8.42,8.42ZM40.79,39.63a7.89,7.89,0,0,1,3.65-3.17l14.79-5.31,8,8L61.94,54l-.06.19a6.44,6.44,0,0,1-3,3.43L34.07,68l-3.62-3.63Zm16.57,7.81a6.9,6.9,0,1,0-6.89,6.9A6.9,6.9,0,0,0,57.36,47.44Zm-4,0a2.86,2.86,0,1,1-2.85-2.85A2.86,2.86,0,0,1,53.32,47.44Zm-4.13,5.22L46.33,49.8,30.08,66.05l2.86,2.86ZM83.65,29,70,15.34,61.4,23.9,75.09,37.59ZM70,21.06l8,8-2.84,2.85-8-8ZM87,80.49H10.67V87H87Z',\n transform: 'matrix(1 0 0 1 -15 -15)'\n },\n drawrect: {\n width: 80,\n height: 80,\n path: 'M78,22V79H21V22H78m9-9H12V88H87V13ZM68,46.22H31V54H68ZM53,32H45.22V69H53Z',\n transform: 'matrix(1 0 0 1 -10 -10)'\n },\n drawcircle: {\n width: 80,\n height: 80,\n path: 'M50,84.72C26.84,84.72,8,69.28,8,50.3S26.84,15.87,50,15.87,92,31.31,92,50.3,73.16,84.72,50,84.72Zm0-60.59c-18.6,0-33.74,11.74-33.74,26.17S31.4,76.46,50,76.46,83.74,64.72,83.74,50.3,68.6,24.13,50,24.13Zm17.15,22h-34v7.11h34Zm-13.8-13H46.24v34h7.11Z',\n transform: 'matrix(1 0 0 1 -10 -10)'\n },\n eraseshape: {\n width: 80,\n height: 80,\n path: 'M82.77,78H31.85L6,49.57,31.85,21.14H82.77a8.72,8.72,0,0,1,8.65,8.77V69.24A8.72,8.72,0,0,1,82.77,78ZM35.46,69.84H82.77a.57.57,0,0,0,.49-.6V29.91a.57.57,0,0,0-.49-.61H35.46L17,49.57Zm32.68-34.7-24,24,5,5,24-24Zm-19,.53-5,5,24,24,5-5Z',\n transform: 'matrix(1 0 0 1 -10 -10)'\n },\n spikeline: {\n width: 1000,\n height: 1000,\n path: 'M512 409c0-57-46-104-103-104-57 0-104 47-104 104 0 57 47 103 104 103 57 0 103-46 103-103z m-327-39l92 0 0 92-92 0z m-185 0l92 0 0 92-92 0z m370-186l92 0 0 93-92 0z m0-184l92 0 0 92-92 0z',\n transform: 'matrix(1.5 0 0 -1.5 0 850)'\n },\n pencil: {\n width: 1792,\n height: 1792,\n path: 'M491 1536l91-91-235-235-91 91v107h128v128h107zm523-928q0-22-22-22-10 0-17 7l-542 542q-7 7-7 17 0 22 22 22 10 0 17-7l542-542q7-7 7-17zm-54-192l416 416-832 832h-416v-416zm683 96q0 53-37 90l-166 166-416-416 166-165q36-38 90-38 53 0 91 38l235 234q37 39 37 91z',\n transform: 'matrix(1 0 0 1 0 1)'\n },\n newplotlylogo: {\n name: 'newplotlylogo',\n svg: [\n '',\n '',\n ' ',\n '',\n ' plotly-logomark',\n ' ',\n ' ',\n ' ',\n ' ',\n ' ',\n ' ',\n ' ',\n ' ',\n ' ',\n ' ',\n ' ',\n ' ',\n ' ',\n ''\n ].join('')\n }\n};\n","'use strict';\n\n\n/**\n * Determine the position anchor property of x/y xanchor/yanchor components.\n *\n * - values < 1/3 align the low side at that fraction,\n * - values [1/3, 2/3] align the center at that fraction,\n * - values > 2/3 align the right at that fraction.\n */\n\n\nexports.isLeftAnchor = function isLeftAnchor(opts) {\n return (\n opts.xanchor === 'left' ||\n (opts.xanchor === 'auto' && opts.x <= 1 / 3)\n );\n};\n\nexports.isCenterAnchor = function isCenterAnchor(opts) {\n return (\n opts.xanchor === 'center' ||\n (opts.xanchor === 'auto' && opts.x > 1 / 3 && opts.x < 2 / 3)\n );\n};\n\nexports.isRightAnchor = function isRightAnchor(opts) {\n return (\n opts.xanchor === 'right' ||\n (opts.xanchor === 'auto' && opts.x >= 2 / 3)\n );\n};\n\nexports.isTopAnchor = function isTopAnchor(opts) {\n return (\n opts.yanchor === 'top' ||\n (opts.yanchor === 'auto' && opts.y >= 2 / 3)\n );\n};\n\nexports.isMiddleAnchor = function isMiddleAnchor(opts) {\n return (\n opts.yanchor === 'middle' ||\n (opts.yanchor === 'auto' && opts.y > 1 / 3 && opts.y < 2 / 3)\n );\n};\n\nexports.isBottomAnchor = function isBottomAnchor(opts) {\n return (\n opts.yanchor === 'bottom' ||\n (opts.yanchor === 'auto' && opts.y <= 1 / 3)\n );\n};\n","'use strict';\n\nvar modModule = require('./mod');\nvar mod = modModule.mod;\nvar modHalf = modModule.modHalf;\n\nvar PI = Math.PI;\nvar twoPI = 2 * PI;\n\nfunction deg2rad(deg) { return deg / 180 * PI; }\n\nfunction rad2deg(rad) { return rad / PI * 180; }\n\n/**\n * is sector a full circle?\n * ... this comes up a lot in SVG path-drawing routines\n *\n * N.B. we consider all sectors that span more that 2pi 'full' circles\n *\n * @param {2-item array} aBnds : angular bounds in *radians*\n * @return {boolean}\n */\nfunction isFullCircle(aBnds) {\n return Math.abs(aBnds[1] - aBnds[0]) > twoPI - 1e-14;\n}\n\n/**\n * angular delta between angle 'a' and 'b'\n * solution taken from: https://stackoverflow.com/a/2007279\n *\n * @param {number} a : first angle in *radians*\n * @param {number} b : second angle in *radians*\n * @return {number} angular delta in *radians*\n */\nfunction angleDelta(a, b) {\n return modHalf(b - a, twoPI);\n}\n\n/**\n * angular distance between angle 'a' and 'b'\n *\n * @param {number} a : first angle in *radians*\n * @param {number} b : second angle in *radians*\n * @return {number} angular distance in *radians*\n */\nfunction angleDist(a, b) {\n return Math.abs(angleDelta(a, b));\n}\n\n/**\n * is angle inside sector?\n *\n * @param {number} a : angle to test in *radians*\n * @param {2-item array} aBnds : sector's angular bounds in *radians*\n * @param {boolean}\n */\nfunction isAngleInsideSector(a, aBnds) {\n if(isFullCircle(aBnds)) return true;\n\n var s0, s1;\n\n if(aBnds[0] < aBnds[1]) {\n s0 = aBnds[0];\n s1 = aBnds[1];\n } else {\n s0 = aBnds[1];\n s1 = aBnds[0];\n }\n\n s0 = mod(s0, twoPI);\n s1 = mod(s1, twoPI);\n if(s0 > s1) s1 += twoPI;\n\n var a0 = mod(a, twoPI);\n var a1 = a0 + twoPI;\n\n return (a0 >= s0 && a0 <= s1) || (a1 >= s0 && a1 <= s1);\n}\n\n/**\n * is pt (r,a) inside sector?\n *\n * @param {number} r : pt's radial coordinate\n * @param {number} a : pt's angular coordinate in *radians*\n * @param {2-item array} rBnds : sector's radial bounds\n * @param {2-item array} aBnds : sector's angular bounds in *radians*\n * @return {boolean}\n */\nfunction isPtInsideSector(r, a, rBnds, aBnds) {\n if(!isAngleInsideSector(a, aBnds)) return false;\n\n var r0, r1;\n\n if(rBnds[0] < rBnds[1]) {\n r0 = rBnds[0];\n r1 = rBnds[1];\n } else {\n r0 = rBnds[1];\n r1 = rBnds[0];\n }\n\n return r >= r0 && r <= r1;\n}\n\n// common to pathArc, pathSector and pathAnnulus\nfunction _path(r0, r1, a0, a1, cx, cy, isClosed) {\n cx = cx || 0;\n cy = cy || 0;\n\n var isCircle = isFullCircle([a0, a1]);\n var aStart, aMid, aEnd;\n var rStart, rEnd;\n\n if(isCircle) {\n aStart = 0;\n aMid = PI;\n aEnd = twoPI;\n } else {\n if(a0 < a1) {\n aStart = a0;\n aEnd = a1;\n } else {\n aStart = a1;\n aEnd = a0;\n }\n }\n\n if(r0 < r1) {\n rStart = r0;\n rEnd = r1;\n } else {\n rStart = r1;\n rEnd = r0;\n }\n\n // N.B. svg coordinates here, where y increases downward\n function pt(r, a) {\n return [r * Math.cos(a) + cx, cy - r * Math.sin(a)];\n }\n\n var largeArc = Math.abs(aEnd - aStart) <= PI ? 0 : 1;\n function arc(r, a, cw) {\n return 'A' + [r, r] + ' ' + [0, largeArc, cw] + ' ' + pt(r, a);\n }\n\n var p;\n\n if(isCircle) {\n if(rStart === null) {\n p = 'M' + pt(rEnd, aStart) +\n arc(rEnd, aMid, 0) +\n arc(rEnd, aEnd, 0) + 'Z';\n } else {\n p = 'M' + pt(rStart, aStart) +\n arc(rStart, aMid, 0) +\n arc(rStart, aEnd, 0) + 'Z' +\n 'M' + pt(rEnd, aStart) +\n arc(rEnd, aMid, 1) +\n arc(rEnd, aEnd, 1) + 'Z';\n }\n } else {\n if(rStart === null) {\n p = 'M' + pt(rEnd, aStart) + arc(rEnd, aEnd, 0);\n if(isClosed) p += 'L0,0Z';\n } else {\n p = 'M' + pt(rStart, aStart) +\n 'L' + pt(rEnd, aStart) +\n arc(rEnd, aEnd, 0) +\n 'L' + pt(rStart, aEnd) +\n arc(rStart, aStart, 1) + 'Z';\n }\n }\n\n return p;\n}\n\n/**\n * path an arc\n *\n * @param {number} r : radius\n * @param {number} a0 : first angular coordinate in *radians*\n * @param {number} a1 : second angular coordinate in *radians*\n * @param {number (optional)} cx : x coordinate of center\n * @param {number (optional)} cy : y coordinate of center\n * @return {string} svg path\n */\nfunction pathArc(r, a0, a1, cx, cy) {\n return _path(null, r, a0, a1, cx, cy, 0);\n}\n\n/**\n * path a sector\n *\n * @param {number} r : radius\n * @param {number} a0 : first angular coordinate in *radians*\n * @param {number} a1 : second angular coordinate in *radians*\n * @param {number (optional)} cx : x coordinate of center\n * @param {number (optional)} cy : y coordinate of center\n * @return {string} svg path\n */\nfunction pathSector(r, a0, a1, cx, cy) {\n return _path(null, r, a0, a1, cx, cy, 1);\n}\n\n/**\n * path an annulus\n *\n * @param {number} r0 : first radial coordinate\n * @param {number} r1 : second radial coordinate\n * @param {number} a0 : first angular coordinate in *radians*\n * @param {number} a1 : second angular coordinate in *radians*\n * @param {number (optional)} cx : x coordinate of center\n * @param {number (optional)} cy : y coordinate of center\n * @return {string} svg path\n */\nfunction pathAnnulus(r0, r1, a0, a1, cx, cy) {\n return _path(r0, r1, a0, a1, cx, cy, 1);\n}\n\nmodule.exports = {\n deg2rad: deg2rad,\n rad2deg: rad2deg,\n angleDelta: angleDelta,\n angleDist: angleDist,\n isFullCircle: isFullCircle,\n isAngleInsideSector: isAngleInsideSector,\n isPtInsideSector: isPtInsideSector,\n pathArc: pathArc,\n pathSector: pathSector,\n pathAnnulus: pathAnnulus\n};\n","'use strict';\nvar b64decode = require('base64-arraybuffer').decode;\n\nvar isPlainObject = require('./is_plain_object');\n\nvar isArray = Array.isArray;\n\nvar ab = ArrayBuffer;\nvar dv = DataView;\n\nfunction isTypedArray(a) {\n return ab.isView(a) && !(a instanceof dv);\n}\nexports.isTypedArray = isTypedArray;\n\nfunction isArrayOrTypedArray(a) {\n return isArray(a) || isTypedArray(a);\n}\nexports.isArrayOrTypedArray = isArrayOrTypedArray;\n\n/*\n * Test whether an input object is 1D.\n *\n * Assumes we already know the object is an array.\n *\n * Looks only at the first element, if the dimensionality is\n * not consistent we won't figure that out here.\n */\nfunction isArray1D(a) {\n return !isArrayOrTypedArray(a[0]);\n}\nexports.isArray1D = isArray1D;\n\n/*\n * Ensures an array has the right amount of storage space. If it doesn't\n * exist, it creates an array. If it does exist, it returns it if too\n * short or truncates it in-place.\n *\n * The goal is to just reuse memory to avoid a bit of excessive garbage\n * collection.\n */\nexports.ensureArray = function(out, n) {\n // TODO: typed array support here? This is only used in\n // traces/carpet/compute_control_points\n if(!isArray(out)) out = [];\n\n // If too long, truncate. (If too short, it will grow\n // automatically so we don't care about that case)\n out.length = n;\n\n return out;\n};\n\nvar typedArrays = {\n u1c: typeof Uint8ClampedArray === 'undefined' ? undefined :\n Uint8ClampedArray, // not supported in numpy?\n\n i1: typeof Int8Array === 'undefined' ? undefined :\n Int8Array,\n\n u1: typeof Uint8Array === 'undefined' ? undefined :\n Uint8Array,\n\n i2: typeof Int16Array === 'undefined' ? undefined :\n Int16Array,\n\n u2: typeof Uint16Array === 'undefined' ? undefined :\n Uint16Array,\n\n i4: typeof Int32Array === 'undefined' ? undefined :\n Int32Array,\n\n u4: typeof Uint32Array === 'undefined' ? undefined :\n Uint32Array,\n\n f4: typeof Float32Array === 'undefined' ? undefined :\n Float32Array,\n\n f8: typeof Float64Array === 'undefined' ? undefined :\n Float64Array,\n\n /* TODO: potentially add Big Int\n\n i8: typeof BigInt64Array === 'undefined' ? undefined :\n BigInt64Array,\n\n u8: typeof BigUint64Array === 'undefined' ? undefined :\n BigUint64Array,\n */\n};\n\ntypedArrays.uint8c = typedArrays.u1c;\ntypedArrays.uint8 = typedArrays.u1;\ntypedArrays.int8 = typedArrays.i1;\ntypedArrays.uint16 = typedArrays.u2;\ntypedArrays.int16 = typedArrays.i2;\ntypedArrays.uint32 = typedArrays.u4;\ntypedArrays.int32 = typedArrays.i4;\ntypedArrays.float32 = typedArrays.f4;\ntypedArrays.float64 = typedArrays.f8;\n\nfunction isArrayBuffer(a) {\n return a.constructor === ArrayBuffer;\n}\nexports.isArrayBuffer = isArrayBuffer;\n\nexports.decodeTypedArraySpec = function(vIn) {\n var out = [];\n var v = coerceTypedArraySpec(vIn);\n var dtype = v.dtype;\n\n var T = typedArrays[dtype];\n if(!T) throw new Error('Error in dtype: \"' + dtype + '\"');\n var BYTES_PER_ELEMENT = T.BYTES_PER_ELEMENT;\n\n var buffer = v.bdata;\n if(!isArrayBuffer(buffer)) {\n buffer = b64decode(buffer);\n }\n var shape = v.shape === undefined ?\n // detect 1-d length\n [buffer.byteLength / BYTES_PER_ELEMENT] :\n // convert number to string and split to array\n ('' + v.shape).split(',');\n\n shape.reverse(); // i.e. to match numpy order\n var ndim = shape.length;\n\n var nj, j;\n var ni = +shape[0];\n\n var rowBytes = BYTES_PER_ELEMENT * ni;\n var pos = 0;\n\n if(ndim === 1) {\n out = new T(buffer);\n } else if(ndim === 2) {\n nj = +shape[1];\n for(j = 0; j < nj; j++) {\n out[j] = new T(buffer, pos, ni);\n pos += rowBytes;\n }\n } else if(ndim === 3) {\n nj = +shape[1];\n var nk = +shape[2];\n for(var k = 0; k < nk; k++) {\n out[k] = [];\n for(j = 0; j < nj; j++) {\n out[k][j] = new T(buffer, pos, ni);\n pos += rowBytes;\n }\n }\n } else {\n throw new Error('ndim: ' + ndim + 'is not supported with the shape:\"' + v.shape + '\"');\n }\n\n // attach bdata, dtype & shape to array for json export\n out.bdata = v.bdata;\n out.dtype = v.dtype;\n out.shape = shape.reverse().join(',');\n\n vIn._inputArray = out;\n\n return out;\n};\n\nexports.isTypedArraySpec = function(v) {\n return (\n isPlainObject(v) &&\n v.hasOwnProperty('dtype') && (typeof v.dtype === 'string') &&\n\n v.hasOwnProperty('bdata') && (typeof v.bdata === 'string' || isArrayBuffer(v.bdata)) &&\n\n (v.shape === undefined || (\n v.hasOwnProperty('shape') && (typeof v.shape === 'string' || typeof v.shape === 'number')\n ))\n );\n};\n\nfunction coerceTypedArraySpec(v) {\n return {\n bdata: v.bdata,\n dtype: v.dtype,\n shape: v.shape\n };\n}\n\n/*\n * TypedArray-compatible concatenation of n arrays\n * if all arrays are the same type it will preserve that type,\n * otherwise it falls back on Array.\n * Also tries to avoid copying, in case one array has zero length\n * But never mutates an existing array\n */\nexports.concat = function() {\n var args = [];\n var allArray = true;\n var totalLen = 0;\n\n var _constructor, arg0, i, argi, posi, leni, out, j;\n\n for(i = 0; i < arguments.length; i++) {\n argi = arguments[i];\n leni = argi.length;\n if(leni) {\n if(arg0) args.push(argi);\n else {\n arg0 = argi;\n posi = leni;\n }\n\n if(isArray(argi)) {\n _constructor = false;\n } else {\n allArray = false;\n if(!totalLen) {\n _constructor = argi.constructor;\n } else if(_constructor !== argi.constructor) {\n // TODO: in principle we could upgrade here,\n // ie keep typed array but convert all to Float64Array?\n _constructor = false;\n }\n }\n\n totalLen += leni;\n }\n }\n\n if(!totalLen) return [];\n if(!args.length) return arg0;\n\n if(allArray) return arg0.concat.apply(arg0, args);\n if(_constructor) {\n // matching typed arrays\n out = new _constructor(totalLen);\n out.set(arg0);\n for(i = 0; i < args.length; i++) {\n argi = args[i];\n out.set(argi, posi);\n posi += argi.length;\n }\n return out;\n }\n\n // mismatched types or Array + typed\n out = new Array(totalLen);\n for(j = 0; j < arg0.length; j++) out[j] = arg0[j];\n for(i = 0; i < args.length; i++) {\n argi = args[i];\n for(j = 0; j < argi.length; j++) out[posi + j] = argi[j];\n posi += j;\n }\n return out;\n};\n\nexports.maxRowLength = function(z) {\n return _rowLength(z, Math.max, 0);\n};\n\nexports.minRowLength = function(z) {\n return _rowLength(z, Math.min, Infinity);\n};\n\nfunction _rowLength(z, fn, len0) {\n if(isArrayOrTypedArray(z)) {\n if(isArrayOrTypedArray(z[0])) {\n var len = len0;\n for(var i = 0; i < z.length; i++) {\n len = fn(len, z[i].length);\n }\n return len;\n } else {\n return z.length;\n }\n }\n return 0;\n}\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar BADNUM = require('../constants/numerical').BADNUM;\n\n// precompile for speed\nvar JUNK = /^['\"%,$#\\s']+|[, ]|['\"%,$#\\s']+$/g;\n\n/**\n * cleanNumber: remove common leading and trailing cruft\n * Always returns either a number or BADNUM.\n */\nmodule.exports = function cleanNumber(v) {\n if(typeof v === 'string') {\n v = v.replace(JUNK, '');\n }\n\n if(isNumeric(v)) return Number(v);\n\n return BADNUM;\n};\n","'use strict';\n\n/**\n * Clear gl frame (if any). This is a common pattern as\n * we usually set `preserveDrawingBuffer: true` during\n * gl context creation (e.g. via `reglUtils.prepare`).\n *\n * @param {DOM node or object} gd : graph div object\n */\nmodule.exports = function clearGlCanvases(gd) {\n var fullLayout = gd._fullLayout;\n\n if(fullLayout._glcanvas && fullLayout._glcanvas.size()) {\n fullLayout._glcanvas.each(function(d) {\n if(d.regl) d.regl.clear({color: true, depth: true});\n });\n }\n};\n","'use strict';\n\n/**\n * Clear responsive handlers (if any).\n *\n * @param {DOM node or object} gd : graph div object\n */\nmodule.exports = function clearResponsive(gd) {\n if(gd._responsiveChartHandler) {\n window.removeEventListener('resize', gd._responsiveChartHandler);\n delete gd._responsiveChartHandler;\n }\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar tinycolor = require('tinycolor2');\n\nvar extendFlat = require('./extend').extendFlat;\n\nvar baseTraceAttrs = require('../plots/attributes');\nvar colorscales = require('../components/colorscale/scales');\nvar Color = require('../components/color');\nvar DESELECTDIM = require('../constants/interactions').DESELECTDIM;\n\nvar nestedProperty = require('./nested_property');\nvar counterRegex = require('./regex').counter;\nvar modHalf = require('./mod').modHalf;\nvar isArrayOrTypedArray = require('./array').isArrayOrTypedArray;\nvar isTypedArraySpec = require('./array').isTypedArraySpec;\nvar decodeTypedArraySpec = require('./array').decodeTypedArraySpec;\n\nexports.valObjectMeta = {\n data_array: {\n // You can use *dflt=[] to force said array to exist though.\n description: [\n 'An {array} of data.',\n 'The value must represent an {array} or it will be ignored,',\n 'but this array can be provided in several forms:',\n '(1) a regular {array} object',\n '(2) a typed array (e.g. Float32Array)',\n '(3) an object with keys dtype, bdata, and optionally shape.',\n 'In this 3rd form, dtype is one of',\n '*f8*, *f4*.',\n '*i4*, *u4*,',\n '*i2*, *u2*,',\n '*i1*, *u1* or *u1c* for Uint8ClampedArray.',\n 'In addition to shorthand `dtype` above one could also use the following forms:',\n '*float64*, *float32*,',\n '*int32*, *uint32*,',\n '*int16*, *uint16*,',\n '*int8*, *uint8* or *uint8c* for Uint8ClampedArray.',\n '`bdata` is either a base64-encoded string or the ArrayBuffer of',\n 'an integer or float typed array.',\n 'For either multi-dimensional arrays you must also',\n 'provide its dimensions separated by comma via `shape`.',\n 'For example using `dtype`: *f4* and `shape`: *5,100* you can',\n 'declare a 2-D array that has 5 rows and 100 columns',\n 'containing float32 values i.e. 4 bits per value.',\n '`shape` is optional for one dimensional arrays.'\n ].join(' '),\n requiredOpts: [],\n otherOpts: ['dflt'],\n coerceFunction: function(v, propOut, dflt) {\n propOut.set(\n isArrayOrTypedArray(v) ? v :\n isTypedArraySpec(v) ? decodeTypedArraySpec(v) :\n dflt\n );\n }\n },\n enumerated: {\n description: [\n 'Enumerated value type. The available values are listed',\n 'in `values`.'\n ].join(' '),\n requiredOpts: ['values'],\n otherOpts: ['dflt', 'coerceNumber', 'arrayOk'],\n coerceFunction: function(v, propOut, dflt, opts) {\n if(opts.coerceNumber) v = +v;\n if(opts.values.indexOf(v) === -1) propOut.set(dflt);\n else propOut.set(v);\n },\n validateFunction: function(v, opts) {\n if(opts.coerceNumber) v = +v;\n\n var values = opts.values;\n for(var i = 0; i < values.length; i++) {\n var k = String(values[i]);\n\n if((k.charAt(0) === '/' && k.charAt(k.length - 1) === '/')) {\n var regex = new RegExp(k.substr(1, k.length - 2));\n if(regex.test(v)) return true;\n } else if(v === values[i]) return true;\n }\n return false;\n }\n },\n boolean: {\n description: 'A boolean (true/false) value.',\n requiredOpts: [],\n otherOpts: ['dflt'],\n coerceFunction: function(v, propOut, dflt) {\n if(v === true || v === false) propOut.set(v);\n else propOut.set(dflt);\n }\n },\n number: {\n description: [\n 'A number or a numeric value',\n '(e.g. a number inside a string).',\n 'When applicable, values greater (less) than `max` (`min`)',\n 'are coerced to the `dflt`.'\n ].join(' '),\n requiredOpts: [],\n otherOpts: ['dflt', 'min', 'max', 'arrayOk'],\n coerceFunction: function(v, propOut, dflt, opts) {\n if(isTypedArraySpec(v)) v = decodeTypedArraySpec(v);\n\n if(!isNumeric(v) ||\n (opts.min !== undefined && v < opts.min) ||\n (opts.max !== undefined && v > opts.max)) {\n propOut.set(dflt);\n } else propOut.set(+v);\n }\n },\n integer: {\n description: [\n 'An integer or an integer inside a string.',\n 'When applicable, values greater (less) than `max` (`min`)',\n 'are coerced to the `dflt`.'\n ].join(' '),\n requiredOpts: [],\n otherOpts: ['dflt', 'min', 'max', 'arrayOk', 'extras'],\n coerceFunction: function(v, propOut, dflt, opts) {\n if((opts.extras || []).indexOf(v) !== -1) {\n propOut.set(v);\n return;\n }\n\n if(isTypedArraySpec(v)) v = decodeTypedArraySpec(v);\n\n if(v % 1 || !isNumeric(v) ||\n (opts.min !== undefined && v < opts.min) ||\n (opts.max !== undefined && v > opts.max)) {\n propOut.set(dflt);\n } else propOut.set(+v);\n }\n },\n string: {\n description: [\n 'A string value.',\n 'Numbers are converted to strings except for attributes with',\n '`strict` set to true.'\n ].join(' '),\n requiredOpts: [],\n // TODO 'values shouldn't be in there (edge case: 'dash' in Scatter)\n otherOpts: ['dflt', 'noBlank', 'strict', 'arrayOk', 'values'],\n coerceFunction: function(v, propOut, dflt, opts) {\n if(typeof v !== 'string') {\n var okToCoerce = (typeof v === 'number');\n\n if(opts.strict === true || !okToCoerce) propOut.set(dflt);\n else propOut.set(String(v));\n } else if(opts.noBlank && !v) propOut.set(dflt);\n else propOut.set(v);\n }\n },\n color: {\n description: [\n 'A string describing color.',\n 'Supported formats:',\n '- hex (e.g. \\'#d3d3d3\\')',\n '- rgb (e.g. \\'rgb(255, 0, 0)\\')',\n '- rgba (e.g. \\'rgb(255, 0, 0, 0.5)\\')',\n '- hsl (e.g. \\'hsl(0, 100%, 50%)\\')',\n '- hsv (e.g. \\'hsv(0, 100%, 100%)\\')',\n '- named colors (full list: http://www.w3.org/TR/css3-color/#svg-color)'\n ].join(' '),\n requiredOpts: [],\n otherOpts: ['dflt', 'arrayOk'],\n coerceFunction: function(v, propOut, dflt) {\n if(isTypedArraySpec(v)) v = decodeTypedArraySpec(v);\n\n if(tinycolor(v).isValid()) propOut.set(v);\n else propOut.set(dflt);\n }\n },\n colorlist: {\n description: [\n 'A list of colors.',\n 'Must be an {array} containing valid colors.',\n ].join(' '),\n requiredOpts: [],\n otherOpts: ['dflt'],\n coerceFunction: function(v, propOut, dflt) {\n function isColor(color) {\n return tinycolor(color).isValid();\n }\n if(!Array.isArray(v) || !v.length) propOut.set(dflt);\n else if(v.every(isColor)) propOut.set(v);\n else propOut.set(dflt);\n }\n },\n colorscale: {\n description: [\n 'A Plotly colorscale either picked by a name:',\n '(any of', Object.keys(colorscales.scales).join(', '), ')',\n 'customized as an {array} of 2-element {arrays} where',\n 'the first element is the normalized color level value',\n '(starting at *0* and ending at *1*),',\n 'and the second item is a valid color string.'\n ].join(' '),\n requiredOpts: [],\n otherOpts: ['dflt'],\n coerceFunction: function(v, propOut, dflt) {\n propOut.set(colorscales.get(v, dflt));\n }\n },\n angle: {\n description: [\n 'A number (in degree) between -180 and 180.'\n ].join(' '),\n requiredOpts: [],\n otherOpts: ['dflt', 'arrayOk'],\n coerceFunction: function(v, propOut, dflt) {\n if(isTypedArraySpec(v)) v = decodeTypedArraySpec(v);\n\n if(v === 'auto') propOut.set('auto');\n else if(!isNumeric(v)) propOut.set(dflt);\n else propOut.set(modHalf(+v, 360));\n }\n },\n subplotid: {\n description: [\n 'An id string of a subplot type (given by dflt), optionally',\n 'followed by an integer >1. e.g. if dflt=\\'geo\\', we can have',\n '\\'geo\\', \\'geo2\\', \\'geo3\\', ...'\n ].join(' '),\n requiredOpts: ['dflt'],\n otherOpts: ['regex'],\n coerceFunction: function(v, propOut, dflt, opts) {\n var regex = opts.regex || counterRegex(dflt);\n if(typeof v === 'string' && regex.test(v)) {\n propOut.set(v);\n return;\n }\n propOut.set(dflt);\n },\n validateFunction: function(v, opts) {\n var dflt = opts.dflt;\n\n if(v === dflt) return true;\n if(typeof v !== 'string') return false;\n if(counterRegex(dflt).test(v)) return true;\n\n return false;\n }\n },\n flaglist: {\n description: [\n 'A string representing a combination of flags',\n '(order does not matter here).',\n 'Combine any of the available `flags` with *+*.',\n '(e.g. (\\'lines+markers\\')).',\n 'Values in `extras` cannot be combined.'\n ].join(' '),\n requiredOpts: ['flags'],\n otherOpts: ['dflt', 'extras', 'arrayOk'],\n coerceFunction: function(v, propOut, dflt, opts) {\n if((opts.extras || []).indexOf(v) !== -1) {\n propOut.set(v);\n return;\n }\n if(typeof v !== 'string') {\n propOut.set(dflt);\n return;\n }\n var vParts = v.split('+');\n var i = 0;\n while(i < vParts.length) {\n var vi = vParts[i];\n if(opts.flags.indexOf(vi) === -1 || vParts.indexOf(vi) < i) {\n vParts.splice(i, 1);\n } else i++;\n }\n if(!vParts.length) propOut.set(dflt);\n else propOut.set(vParts.join('+'));\n }\n },\n any: {\n description: 'Any type.',\n requiredOpts: [],\n otherOpts: ['dflt', 'values', 'arrayOk'],\n coerceFunction: function(v, propOut, dflt) {\n if(v === undefined) {\n propOut.set(dflt);\n } else {\n propOut.set(\n isTypedArraySpec(v) ? decodeTypedArraySpec(v) :\n v\n );\n }\n }\n },\n info_array: {\n description: [\n 'An {array} of plot information.'\n ].join(' '),\n requiredOpts: ['items'],\n // set `dimensions=2` for a 2D array or '1-2' for either\n // `items` may be a single object instead of an array, in which case\n // `freeLength` must be true.\n // if `dimensions='1-2'` and items is a 1D array, then the value can\n // either be a matching 1D array or an array of such matching 1D arrays\n otherOpts: ['dflt', 'freeLength', 'dimensions'],\n coerceFunction: function(v, propOut, dflt, opts) {\n // simplified coerce function just for array items\n function coercePart(v, opts, dflt) {\n var out;\n var propPart = {set: function(v) { out = v; }};\n\n if(dflt === undefined) dflt = opts.dflt;\n\n exports.valObjectMeta[opts.valType].coerceFunction(v, propPart, dflt, opts);\n\n return out;\n }\n\n if(isTypedArraySpec(v)) v = decodeTypedArraySpec(v);\n\n if(!isArrayOrTypedArray(v)) {\n propOut.set(dflt);\n return;\n }\n\n var twoD = opts.dimensions === 2 || (opts.dimensions === '1-2' && Array.isArray(v) && isArrayOrTypedArray(v[0]));\n\n var items = opts.items;\n var vOut = [];\n var arrayItems = Array.isArray(items);\n var arrayItems2D = arrayItems && twoD && isArrayOrTypedArray(items[0]);\n var innerItemsOnly = twoD && arrayItems && !arrayItems2D;\n var len = (arrayItems && !innerItemsOnly) ? items.length : v.length;\n\n var i, j, row, item, len2, vNew;\n\n dflt = Array.isArray(dflt) ? dflt : [];\n\n if(twoD) {\n for(i = 0; i < len; i++) {\n vOut[i] = [];\n row = isArrayOrTypedArray(v[i]) ? v[i] : [];\n if(innerItemsOnly) len2 = items.length;\n else if(arrayItems) len2 = items[i].length;\n else len2 = row.length;\n\n for(j = 0; j < len2; j++) {\n if(innerItemsOnly) item = items[j];\n else if(arrayItems) item = items[i][j];\n else item = items;\n\n vNew = coercePart(row[j], item, (dflt[i] || [])[j]);\n if(vNew !== undefined) vOut[i][j] = vNew;\n }\n }\n } else {\n for(i = 0; i < len; i++) {\n vNew = coercePart(v[i], arrayItems ? items[i] : items, dflt[i]);\n if(vNew !== undefined) vOut[i] = vNew;\n }\n }\n\n propOut.set(vOut);\n },\n validateFunction: function(v, opts) {\n if(!isArrayOrTypedArray(v)) return false;\n\n var items = opts.items;\n var arrayItems = Array.isArray(items);\n var twoD = opts.dimensions === 2;\n\n // when free length is off, input and declared lengths must match\n if(!opts.freeLength && v.length !== items.length) return false;\n\n // valid when all input items are valid\n for(var i = 0; i < v.length; i++) {\n if(twoD) {\n if(!isArrayOrTypedArray(v[i]) || (!opts.freeLength && v[i].length !== items[i].length)) {\n return false;\n }\n for(var j = 0; j < v[i].length; j++) {\n if(!validate(v[i][j], arrayItems ? items[i][j] : items)) {\n return false;\n }\n }\n } else if(!validate(v[i], arrayItems ? items[i] : items)) return false;\n }\n\n return true;\n }\n }\n};\n\n/**\n * Ensures that container[attribute] has a valid value.\n *\n * attributes[attribute] is an object with possible keys:\n * - valType: data_array, enumerated, boolean, ... as in valObjectMeta\n * - values: (enumerated only) array of allowed vals\n * - min, max: (number, integer only) inclusive bounds on allowed vals\n * either or both may be omitted\n * - dflt: if attribute is invalid or missing, use this default\n * if dflt is provided as an argument to lib.coerce it takes precedence\n * as a convenience, returns the value it finally set\n */\nexports.coerce = function(containerIn, containerOut, attributes, attribute, dflt) {\n var opts = nestedProperty(attributes, attribute).get();\n var propIn = nestedProperty(containerIn, attribute);\n var propOut = nestedProperty(containerOut, attribute);\n var v = propIn.get();\n\n var template = containerOut._template;\n if(v === undefined && template) {\n v = nestedProperty(template, attribute).get();\n // already used the template value, so short-circuit the second check\n template = 0;\n }\n\n if(dflt === undefined) dflt = opts.dflt;\n\n if(opts.arrayOk) {\n if(isArrayOrTypedArray(v)) {\n /**\n * arrayOk: value MAY be an array, then we do no value checking\n * at this point, because it can be more complicated than the\n * individual form (eg. some array vals can be numbers, even if the\n * single values must be color strings)\n */\n\n propOut.set(v);\n return v;\n } else {\n if(isTypedArraySpec(v)) {\n v = decodeTypedArraySpec(v);\n propOut.set(v);\n return v;\n }\n }\n }\n\n var coerceFunction = exports.valObjectMeta[opts.valType].coerceFunction;\n coerceFunction(v, propOut, dflt, opts);\n\n var out = propOut.get();\n // in case v was provided but invalid, try the template again so it still\n // overrides the regular default\n if(template && out === dflt && !validate(v, opts)) {\n v = nestedProperty(template, attribute).get();\n coerceFunction(v, propOut, dflt, opts);\n out = propOut.get();\n }\n return out;\n};\n\n/**\n * Variation on coerce\n *\n * Uses coerce to get attribute value if user input is valid,\n * returns attribute default if user input it not valid or\n * returns false if there is no user input.\n */\nexports.coerce2 = function(containerIn, containerOut, attributes, attribute, dflt) {\n var propIn = nestedProperty(containerIn, attribute);\n var propOut = exports.coerce(containerIn, containerOut, attributes, attribute, dflt);\n var valIn = propIn.get();\n\n return (valIn !== undefined && valIn !== null) ? propOut : false;\n};\n\n/*\n * Shortcut to coerce the three font attributes\n *\n * 'coerce' is a lib.coerce wrapper with implied first three arguments\n */\nexports.coerceFont = function(coerce, attr, dfltObj, opts) {\n if(!opts) opts = {};\n dfltObj = extendFlat({}, dfltObj);\n dfltObj = extendFlat(dfltObj, opts.overrideDflt || {});\n\n var out = {\n family: coerce(attr + '.family', dfltObj.family),\n size: coerce(attr + '.size', dfltObj.size),\n color: coerce(attr + '.color', dfltObj.color),\n weight: coerce(attr + '.weight', dfltObj.weight),\n style: coerce(attr + '.style', dfltObj.style),\n };\n\n if(!opts.noFontVariant) out.variant = coerce(attr + '.variant', dfltObj.variant);\n if(!opts.noFontLineposition) out.lineposition = coerce(attr + '.lineposition', dfltObj.lineposition);\n if(!opts.noFontTextcase) out.textcase = coerce(attr + '.textcase', dfltObj.textcase);\n if(!opts.noFontShadow) {\n var dfltShadow = dfltObj.shadow;\n if(dfltShadow === 'none' && opts.autoShadowDflt) {\n dfltShadow = 'auto';\n }\n out.shadow = coerce(attr + '.shadow', dfltShadow);\n }\n\n return out;\n};\n\n/*\n * Shortcut to coerce the pattern attributes\n */\nexports.coercePattern = function(coerce, attr, markerColor, hasMarkerColorscale) {\n var shape = coerce(attr + '.shape');\n if(shape) {\n coerce(attr + '.solidity');\n coerce(attr + '.size');\n var fillmode = coerce(attr + '.fillmode');\n var isOverlay = fillmode === 'overlay';\n\n if(!hasMarkerColorscale) {\n var bgcolor = coerce(attr + '.bgcolor', isOverlay ?\n markerColor :\n undefined\n );\n\n coerce(attr + '.fgcolor', isOverlay ?\n Color.contrast(bgcolor) :\n markerColor\n );\n }\n\n coerce(attr + '.fgopacity', isOverlay ?\n 0.5 :\n 1\n );\n }\n};\n\n/** Coerce shortcut for 'hoverinfo'\n * handling 1-vs-multi-trace dflt logic\n *\n * @param {object} traceIn : user trace object\n * @param {object} traceOut : full trace object (requires _module ref)\n * @param {object} layoutOut : full layout object (require _dataLength ref)\n * @return {any} : the coerced value\n */\nexports.coerceHoverinfo = function(traceIn, traceOut, layoutOut) {\n var moduleAttrs = traceOut._module.attributes;\n var attrs = moduleAttrs.hoverinfo ? moduleAttrs : baseTraceAttrs;\n\n var valObj = attrs.hoverinfo;\n var dflt;\n\n if(layoutOut._dataLength === 1) {\n var flags = valObj.dflt === 'all' ?\n valObj.flags.slice() :\n valObj.dflt.split('+');\n\n flags.splice(flags.indexOf('name'), 1);\n dflt = flags.join('+');\n }\n\n return exports.coerce(traceIn, traceOut, attrs, 'hoverinfo', dflt);\n};\n\n/** Coerce shortcut for [un]selected.marker.opacity,\n * which has special default logic, to ensure that it corresponds to the\n * default selection behavior while allowing to be overtaken by any other\n * [un]selected attribute.\n *\n * N.B. This must be called *after* coercing all the other [un]selected attrs,\n * to give the intended result.\n *\n * @param {object} traceOut : fullData item\n * @param {function} coerce : lib.coerce wrapper with implied first three arguments\n */\nexports.coerceSelectionMarkerOpacity = function(traceOut, coerce) {\n if(!traceOut.marker) return;\n\n var mo = traceOut.marker.opacity;\n // you can still have a `marker` container with no markers if there's text\n if(mo === undefined) return;\n\n var smoDflt;\n var usmoDflt;\n\n // Don't give [un]selected.marker.opacity a default value if\n // marker.opacity is an array: handle this during style step.\n //\n // Only give [un]selected.marker.opacity a default value if you don't\n // set any other [un]selected attributes.\n if(!isArrayOrTypedArray(mo) && !traceOut.selected && !traceOut.unselected) {\n smoDflt = mo;\n usmoDflt = DESELECTDIM * mo;\n }\n\n coerce('selected.marker.opacity', smoDflt);\n coerce('unselected.marker.opacity', usmoDflt);\n};\n\nfunction validate(value, opts) {\n var valObjectDef = exports.valObjectMeta[opts.valType];\n\n if(opts.arrayOk && isArrayOrTypedArray(value)) return true;\n\n if(valObjectDef.validateFunction) {\n return valObjectDef.validateFunction(value, opts);\n }\n\n var failed = {};\n var out = failed;\n var propMock = { set: function(v) { out = v; } };\n\n // 'failed' just something mutable that won't be === anything else\n\n valObjectDef.coerceFunction(value, propMock, failed, opts);\n return out !== failed;\n}\nexports.validate = validate;\n","'use strict';\n\nvar timeFormat = require('d3-time-format').timeFormat;\nvar isNumeric = require('fast-isnumeric');\n\nvar Loggers = require('./loggers');\nvar mod = require('./mod').mod;\n\nvar constants = require('../constants/numerical');\nvar BADNUM = constants.BADNUM;\nvar ONEDAY = constants.ONEDAY;\nvar ONEHOUR = constants.ONEHOUR;\nvar ONEMIN = constants.ONEMIN;\nvar ONESEC = constants.ONESEC;\nvar EPOCHJD = constants.EPOCHJD;\n\nvar Registry = require('../registry');\n\nvar utcFormat = require('d3-time-format').utcFormat;\n\nvar DATETIME_REGEXP = /^\\s*(-?\\d\\d\\d\\d|\\d\\d)(-(\\d?\\d)(-(\\d?\\d)([ Tt]([01]?\\d|2[0-3])(:([0-5]\\d)(:([0-5]\\d(\\.\\d+)?))?(Z|z|[+\\-]\\d\\d(:?\\d\\d)?)?)?)?)?)?\\s*$/m;\n// special regex for chinese calendars to support yyyy-mmi-dd etc for intercalary months\nvar DATETIME_REGEXP_CN = /^\\s*(-?\\d\\d\\d\\d|\\d\\d)(-(\\d?\\di?)(-(\\d?\\d)([ Tt]([01]?\\d|2[0-3])(:([0-5]\\d)(:([0-5]\\d(\\.\\d+)?))?(Z|z|[+\\-]\\d\\d(:?\\d\\d)?)?)?)?)?)?\\s*$/m;\n\n// for 2-digit years, the first year we map them onto\nvar YFIRST = new Date().getFullYear() - 70;\n\nfunction isWorldCalendar(calendar) {\n return (\n calendar &&\n Registry.componentsRegistry.calendars &&\n typeof calendar === 'string' && calendar !== 'gregorian'\n );\n}\n\n/*\n * dateTick0: get the canonical tick for this calendar\n *\n * integer weekdays : Saturday: 0, Sunday: 1, Monday: 2, etc.\n */\nexports.dateTick0 = function(calendar, dayOfWeek) {\n var tick0 = _dateTick0(calendar, !!dayOfWeek);\n if(dayOfWeek < 2) return tick0;\n\n var v = exports.dateTime2ms(tick0, calendar);\n v += ONEDAY * (dayOfWeek - 1); // shift Sunday to Monday, etc.\n return exports.ms2DateTime(v, 0, calendar);\n};\n\n/*\n * _dateTick0: get the canonical tick for this calendar\n *\n * bool sunday is for week ticks, shift it to a Sunday.\n */\nfunction _dateTick0(calendar, sunday) {\n if(isWorldCalendar(calendar)) {\n return sunday ?\n Registry.getComponentMethod('calendars', 'CANONICAL_SUNDAY')[calendar] :\n Registry.getComponentMethod('calendars', 'CANONICAL_TICK')[calendar];\n } else {\n return sunday ? '2000-01-02' : '2000-01-01';\n }\n}\n\n/*\n * dfltRange: for each calendar, give a valid default range\n */\nexports.dfltRange = function(calendar) {\n if(isWorldCalendar(calendar)) {\n return Registry.getComponentMethod('calendars', 'DFLTRANGE')[calendar];\n } else {\n return ['2000-01-01', '2001-01-01'];\n }\n};\n\n// is an object a javascript date?\nexports.isJSDate = function(v) {\n return typeof v === 'object' && v !== null && typeof v.getTime === 'function';\n};\n\n// The absolute limits of our date-time system\n// This is a little weird: we use MIN_MS and MAX_MS in dateTime2ms\n// but we use dateTime2ms to calculate them (after defining it!)\nvar MIN_MS, MAX_MS;\n\n/**\n * dateTime2ms - turn a date object or string s into milliseconds\n * (relative to 1970-01-01, per javascript standard)\n * optional calendar (string) to use a non-gregorian calendar\n *\n * Returns BADNUM if it doesn't find a date\n *\n * strings should have the form:\n *\n * -?YYYY-mm-ddHH:MM:SS.sss?\n *\n * : space (our normal standard) or T or t (ISO-8601)\n * : Z, z, [+\\-]HH:?MM or [+\\-]HH and we THROW IT AWAY\n * this format comes from https://tools.ietf.org/html/rfc3339#section-5.6\n * and 4.2.5.1 Difference between local time and UTC of day (ISO-8601)\n * but we allow it even with a space as the separator\n *\n * May truncate after any full field, and sss can be any length\n * even >3 digits, though javascript dates truncate to milliseconds,\n * we keep as much as javascript numeric precision can hold, but we only\n * report back up to 100 microsecond precision, because most dates support\n * this precision (close to 1970 support more, very far away support less)\n *\n * Expanded to support negative years to -9999 but you must always\n * give 4 digits, except for 2-digit positive years which we assume are\n * near the present time.\n * Note that we follow ISO 8601:2004: there *is* a year 0, which\n * is 1BC/BCE, and -1===2BC etc.\n *\n * World calendars: not all of these *have* agreed extensions to this full range,\n * if you have another calendar system but want a date range outside its validity,\n * you can use a gregorian date string prefixed with 'G' or 'g'.\n *\n * Where to cut off 2-digit years between 1900s and 2000s?\n * from https://docs.microsoft.com/en-us/office/troubleshoot/excel/two-digit-year-numbers#the-2029-rule:\n * 1930-2029 (the most retro of all...)\n * but in my mac chrome from eg. d=new Date(Date.parse('8/19/50')):\n * 1950-2049\n * by Java, from http://stackoverflow.com/questions/2024273/:\n * now-80 - now+19\n * or FileMaker Pro, from\n * https://fmhelp.filemaker.com/help/18/fmp/en/index.html#page/FMP_Help/dates-with-two-digit-years.html:\n * now-70 - now+29\n * but python strptime etc, via\n * http://docs.python.org/py3k/library/time.html:\n * 1969-2068 (super forward-looking, but static, not sliding!)\n *\n * lets go with now-70 to now+29, and if anyone runs into this problem\n * they can learn the hard way not to use 2-digit years, as no choice we\n * make now will cover all possibilities. mostly this will all be taken\n * care of in initial parsing, should only be an issue for hand-entered data\n * currently (2016) this range is:\n * 1946-2045\n */\nexports.dateTime2ms = function(s, calendar) {\n // first check if s is a date object\n if(exports.isJSDate(s)) {\n // Convert to the UTC milliseconds that give the same\n // hours as this date has in the local timezone\n var tzOffset = s.getTimezoneOffset() * ONEMIN;\n var offsetTweak = (s.getUTCMinutes() - s.getMinutes()) * ONEMIN +\n (s.getUTCSeconds() - s.getSeconds()) * ONESEC +\n (s.getUTCMilliseconds() - s.getMilliseconds());\n\n if(offsetTweak) {\n var comb = 3 * ONEMIN;\n tzOffset = tzOffset - comb / 2 + mod(offsetTweak - tzOffset + comb / 2, comb);\n }\n s = Number(s) - tzOffset;\n if(s >= MIN_MS && s <= MAX_MS) return s;\n return BADNUM;\n }\n // otherwise only accept strings and numbers\n if(typeof s !== 'string' && typeof s !== 'number') return BADNUM;\n\n s = String(s);\n\n var isWorld = isWorldCalendar(calendar);\n\n // to handle out-of-range dates in international calendars, accept\n // 'G' as a prefix to force the built-in gregorian calendar.\n var s0 = s.charAt(0);\n if(isWorld && (s0 === 'G' || s0 === 'g')) {\n s = s.substr(1);\n calendar = '';\n }\n\n var isChinese = isWorld && calendar.substr(0, 7) === 'chinese';\n\n var match = s.match(isChinese ? DATETIME_REGEXP_CN : DATETIME_REGEXP);\n if(!match) return BADNUM;\n var y = match[1];\n var m = match[3] || '1';\n var d = Number(match[5] || 1);\n var H = Number(match[7] || 0);\n var M = Number(match[9] || 0);\n var S = Number(match[11] || 0);\n\n if(isWorld) {\n // disallow 2-digit years for world calendars\n if(y.length === 2) return BADNUM;\n y = Number(y);\n\n var cDate;\n try {\n var calInstance = Registry.getComponentMethod('calendars', 'getCal')(calendar);\n if(isChinese) {\n var isIntercalary = m.charAt(m.length - 1) === 'i';\n m = parseInt(m, 10);\n cDate = calInstance.newDate(y, calInstance.toMonthIndex(y, m, isIntercalary), d);\n } else {\n cDate = calInstance.newDate(y, Number(m), d);\n }\n } catch(e) { return BADNUM; } // Invalid ... date\n\n if(!cDate) return BADNUM;\n\n return ((cDate.toJD() - EPOCHJD) * ONEDAY) +\n (H * ONEHOUR) + (M * ONEMIN) + (S * ONESEC);\n }\n\n if(y.length === 2) {\n y = (Number(y) + 2000 - YFIRST) % 100 + YFIRST;\n } else y = Number(y);\n\n // new Date uses months from 0; subtract 1 here just so we\n // don't have to do it again during the validity test below\n m -= 1;\n\n // javascript takes new Date(0..99,m,d) to mean 1900-1999, so\n // to support years 0-99 we need to use setFullYear explicitly\n // Note that 2000 is a leap year.\n var date = new Date(Date.UTC(2000, m, d, H, M));\n date.setUTCFullYear(y);\n\n if(date.getUTCMonth() !== m) return BADNUM;\n if(date.getUTCDate() !== d) return BADNUM;\n\n return date.getTime() + S * ONESEC;\n};\n\nMIN_MS = exports.MIN_MS = exports.dateTime2ms('-9999');\nMAX_MS = exports.MAX_MS = exports.dateTime2ms('9999-12-31 23:59:59.9999');\n\n// is string s a date? (see above)\nexports.isDateTime = function(s, calendar) {\n return (exports.dateTime2ms(s, calendar) !== BADNUM);\n};\n\n// pad a number with zeroes, to given # of digits before the decimal point\nfunction lpad(val, digits) {\n return String(val + Math.pow(10, digits)).substr(1);\n}\n\n/**\n * Turn ms into string of the form YYYY-mm-dd HH:MM:SS.ssss\n * Crop any trailing zeros in time, except never stop right after hours\n * (we could choose to crop '-01' from date too but for now we always\n * show the whole date)\n * Optional range r is the data range that applies, also in ms.\n * If rng is big, the later parts of time will be omitted\n */\nvar NINETYDAYS = 90 * ONEDAY;\nvar THREEHOURS = 3 * ONEHOUR;\nvar FIVEMIN = 5 * ONEMIN;\nexports.ms2DateTime = function(ms, r, calendar) {\n if(typeof ms !== 'number' || !(ms >= MIN_MS && ms <= MAX_MS)) return BADNUM;\n\n if(!r) r = 0;\n\n var msecTenths = Math.floor(mod(ms + 0.05, 1) * 10);\n var msRounded = Math.round(ms - msecTenths / 10);\n var dateStr, h, m, s, msec10, d;\n\n if(isWorldCalendar(calendar)) {\n var dateJD = Math.floor(msRounded / ONEDAY) + EPOCHJD;\n var timeMs = Math.floor(mod(ms, ONEDAY));\n try {\n dateStr = Registry.getComponentMethod('calendars', 'getCal')(calendar)\n .fromJD(dateJD).formatDate('yyyy-mm-dd');\n } catch(e) {\n // invalid date in this calendar - fall back to Gyyyy-mm-dd\n dateStr = utcFormat('G%Y-%m-%d')(new Date(msRounded));\n }\n\n // yyyy does NOT guarantee 4-digit years. YYYY mostly does, but does\n // other things for a few calendars, so we can't trust it. Just pad\n // it manually (after the '-' if there is one)\n if(dateStr.charAt(0) === '-') {\n while(dateStr.length < 11) dateStr = '-0' + dateStr.substr(1);\n } else {\n while(dateStr.length < 10) dateStr = '0' + dateStr;\n }\n\n // TODO: if this is faster, we could use this block for extracting\n // the time components of regular gregorian too\n h = (r < NINETYDAYS) ? Math.floor(timeMs / ONEHOUR) : 0;\n m = (r < NINETYDAYS) ? Math.floor((timeMs % ONEHOUR) / ONEMIN) : 0;\n s = (r < THREEHOURS) ? Math.floor((timeMs % ONEMIN) / ONESEC) : 0;\n msec10 = (r < FIVEMIN) ? (timeMs % ONESEC) * 10 + msecTenths : 0;\n } else {\n d = new Date(msRounded);\n\n dateStr = utcFormat('%Y-%m-%d')(d);\n\n // <90 days: add hours and minutes - never *only* add hours\n h = (r < NINETYDAYS) ? d.getUTCHours() : 0;\n m = (r < NINETYDAYS) ? d.getUTCMinutes() : 0;\n // <3 hours: add seconds\n s = (r < THREEHOURS) ? d.getUTCSeconds() : 0;\n // <5 minutes: add ms (plus one extra digit, this is msec*10)\n msec10 = (r < FIVEMIN) ? d.getUTCMilliseconds() * 10 + msecTenths : 0;\n }\n\n return includeTime(dateStr, h, m, s, msec10);\n};\n\n// For converting old-style milliseconds to date strings,\n// we use the local timezone rather than UTC like we use\n// everywhere else, both for backward compatibility and\n// because that's how people mostly use javasript date objects.\n// Clip one extra day off our date range though so we can't get\n// thrown beyond the range by the timezone shift.\nexports.ms2DateTimeLocal = function(ms) {\n if(!(ms >= MIN_MS + ONEDAY && ms <= MAX_MS - ONEDAY)) return BADNUM;\n\n var msecTenths = Math.floor(mod(ms + 0.05, 1) * 10);\n var d = new Date(Math.round(ms - msecTenths / 10));\n var dateStr = timeFormat('%Y-%m-%d')(d);\n var h = d.getHours();\n var m = d.getMinutes();\n var s = d.getSeconds();\n var msec10 = d.getUTCMilliseconds() * 10 + msecTenths;\n\n return includeTime(dateStr, h, m, s, msec10);\n};\n\nfunction includeTime(dateStr, h, m, s, msec10) {\n // include each part that has nonzero data in or after it\n if(h || m || s || msec10) {\n dateStr += ' ' + lpad(h, 2) + ':' + lpad(m, 2);\n if(s || msec10) {\n dateStr += ':' + lpad(s, 2);\n if(msec10) {\n var digits = 4;\n while(msec10 % 10 === 0) {\n digits -= 1;\n msec10 /= 10;\n }\n dateStr += '.' + lpad(msec10, digits);\n }\n }\n }\n return dateStr;\n}\n\n// normalize date format to date string, in case it starts as\n// a Date object or milliseconds\n// optional dflt is the return value if cleaning fails\nexports.cleanDate = function(v, dflt, calendar) {\n // let us use cleanDate to provide a missing default without an error\n if(v === BADNUM) return dflt;\n if(exports.isJSDate(v) || (typeof v === 'number' && isFinite(v))) {\n // do not allow milliseconds (old) or jsdate objects (inherently\n // described as gregorian dates) with world calendars\n if(isWorldCalendar(calendar)) {\n Loggers.error('JS Dates and milliseconds are incompatible with world calendars', v);\n return dflt;\n }\n\n // NOTE: if someone puts in a year as a number rather than a string,\n // this will mistakenly convert it thinking it's milliseconds from 1970\n // that is: '2012' -> Jan. 1, 2012, but 2012 -> 2012 epoch milliseconds\n v = exports.ms2DateTimeLocal(+v);\n if(!v && dflt !== undefined) return dflt;\n } else if(!exports.isDateTime(v, calendar)) {\n Loggers.error('unrecognized date', v);\n return dflt;\n }\n return v;\n};\n\n/*\n * Date formatting for ticks and hovertext\n */\n\n/*\n * modDateFormat: Support world calendars, and add two items to\n * d3's vocabulary:\n * %{n}f where n is the max number of digits of fractional seconds\n * %h formats: half of the year as a decimal number [1,2]\n */\nvar fracMatch = /%\\d?f/g;\nvar halfYearMatch = /%h/g;\nvar quarterToHalfYear = {\n 1: '1',\n 2: '1',\n 3: '2',\n 4: '2',\n};\nfunction modDateFormat(fmt, x, formatter, calendar) {\n fmt = fmt.replace(fracMatch, function(match) {\n var digits = Math.min(+(match.charAt(1)) || 6, 6);\n var fracSecs = ((x / 1000 % 1) + 2)\n .toFixed(digits)\n .substr(2).replace(/0+$/, '') || '0';\n return fracSecs;\n });\n\n var d = new Date(Math.floor(x + 0.05));\n\n fmt = fmt.replace(halfYearMatch, function() {\n return quarterToHalfYear[formatter('%q')(d)];\n });\n\n if(isWorldCalendar(calendar)) {\n try {\n fmt = Registry.getComponentMethod('calendars', 'worldCalFmt')(fmt, x, calendar);\n } catch(e) {\n return 'Invalid';\n }\n }\n return formatter(fmt)(d);\n}\n\n/*\n * formatTime: create a time string from:\n * x: milliseconds\n * tr: tickround ('M', 'S', or # digits)\n * only supports UTC times (where every day is 24 hours and 0 is at midnight)\n */\nvar MAXSECONDS = [59, 59.9, 59.99, 59.999, 59.9999];\nfunction formatTime(x, tr) {\n var timePart = mod(x + 0.05, ONEDAY);\n\n var timeStr = lpad(Math.floor(timePart / ONEHOUR), 2) + ':' +\n lpad(mod(Math.floor(timePart / ONEMIN), 60), 2);\n\n if(tr !== 'M') {\n if(!isNumeric(tr)) tr = 0; // should only be 'S'\n\n /*\n * this is a weird one - and shouldn't come up unless people\n * monkey with tick0 in weird ways, but we need to do something!\n * IN PARTICULAR we had better not display garbage (see below)\n * for numbers we always round to the nearest increment of the\n * precision we're showing, and this seems like the right way to\n * handle seconds and milliseconds, as they have a decimal point\n * and people will interpret that to mean rounding like numbers.\n * but for larger increments we floor the value: it's always\n * 2013 until the ball drops on the new year. We could argue about\n * which field it is where we start rounding (should 12:08:59\n * round to 12:09 if we're stopping at minutes?) but for now I'll\n * say we round seconds but floor everything else. BUT that means\n * we need to never round up to 60 seconds, ie 23:59:60\n */\n var sec = Math.min(mod(x / ONESEC, 60), MAXSECONDS[tr]);\n\n var secStr = (100 + sec).toFixed(tr).substr(1);\n if(tr > 0) {\n secStr = secStr.replace(/0+$/, '').replace(/[\\.]$/, '');\n }\n\n timeStr += ':' + secStr;\n }\n return timeStr;\n}\n\n/*\n * formatDate: turn a date into tick or hover label text.\n *\n * x: milliseconds, the value to convert\n * fmt: optional, an explicit format string (d3 format, even for world calendars)\n * tr: tickround ('y', 'm', 'd', 'M', 'S', or # digits)\n * used if no explicit fmt is provided\n * formatter: locale-aware d3 date formatter for standard gregorian calendars\n * should be the result of exports.getD3DateFormat(gd)\n * calendar: optional string, the world calendar system to use\n *\n * returns the date/time as a string, potentially with the leading portion\n * on a separate line (after '\\n')\n * Note that this means if you provide an explicit format which includes '\\n'\n * the axis may choose to strip things after it when they don't change from\n * one tick to the next (as it does with automatic formatting)\n */\nexports.formatDate = function(x, fmt, tr, formatter, calendar, extraFormat) {\n calendar = isWorldCalendar(calendar) && calendar;\n\n if(!fmt) {\n if(tr === 'y') fmt = extraFormat.year;\n else if(tr === 'm') fmt = extraFormat.month;\n else if(tr === 'd') {\n fmt = extraFormat.dayMonth + '\\n' + extraFormat.year;\n } else {\n return formatTime(x, tr) + '\\n' + modDateFormat(extraFormat.dayMonthYear, x, formatter, calendar);\n }\n }\n\n return modDateFormat(fmt, x, formatter, calendar);\n};\n\n/*\n * incrementMonth: make a new milliseconds value from the given one,\n * having changed the month\n *\n * special case for world calendars: multiples of 12 are treated as years,\n * even for calendar systems that don't have (always or ever) 12 months/year\n * TODO: perhaps we need a different code for year increments to support this?\n *\n * ms (number): the initial millisecond value\n * dMonth (int): the (signed) number of months to shift\n * calendar (string): the calendar system to use\n *\n * changing month does not (and CANNOT) always preserve day, since\n * months have different lengths. The worst example of this is:\n * d = new Date(1970,0,31); d.setMonth(1) -> Feb 31 turns into Mar 3\n *\n * But we want to be able to iterate over the last day of each month,\n * regardless of what its number is.\n * So shift 3 days forward, THEN set the new month, then unshift:\n * 1/31 -> 2/28 (or 29) -> 3/31 -> 4/30 -> ...\n *\n * Note that odd behavior still exists if you start from the 26th-28th:\n * 1/28 -> 2/28 -> 3/31\n * but at least you can't shift any dates into the wrong month,\n * and ticks on these days incrementing by month would be very unusual\n */\nvar THREEDAYS = 3 * ONEDAY;\nexports.incrementMonth = function(ms, dMonth, calendar) {\n calendar = isWorldCalendar(calendar) && calendar;\n\n // pull time out and operate on pure dates, then add time back at the end\n // this gives maximum precision - not that we *normally* care if we're\n // incrementing by month, but better to be safe!\n var timeMs = mod(ms, ONEDAY);\n ms = Math.round(ms - timeMs);\n\n if(calendar) {\n try {\n var dateJD = Math.round(ms / ONEDAY) + EPOCHJD;\n var calInstance = Registry.getComponentMethod('calendars', 'getCal')(calendar);\n var cDate = calInstance.fromJD(dateJD);\n\n if(dMonth % 12) calInstance.add(cDate, dMonth, 'm');\n else calInstance.add(cDate, dMonth / 12, 'y');\n\n return (cDate.toJD() - EPOCHJD) * ONEDAY + timeMs;\n } catch(e) {\n Loggers.error('invalid ms ' + ms + ' in calendar ' + calendar);\n // then keep going in gregorian even though the result will be 'Invalid'\n }\n }\n\n var y = new Date(ms + THREEDAYS);\n return y.setUTCMonth(y.getUTCMonth() + dMonth) + timeMs - THREEDAYS;\n};\n\n/*\n * findExactDates: what fraction of data is exact days, months, or years?\n *\n * data: array of millisecond values\n * calendar (string) the calendar to test against\n */\nexports.findExactDates = function(data, calendar) {\n var exactYears = 0;\n var exactMonths = 0;\n var exactDays = 0;\n var blankCount = 0;\n var d;\n var di;\n\n var calInstance = (\n isWorldCalendar(calendar) &&\n Registry.getComponentMethod('calendars', 'getCal')(calendar)\n );\n\n for(var i = 0; i < data.length; i++) {\n di = data[i];\n\n // not date data at all\n if(!isNumeric(di)) {\n blankCount ++;\n continue;\n }\n\n // not an exact date\n if(di % ONEDAY) continue;\n\n if(calInstance) {\n try {\n d = calInstance.fromJD(di / ONEDAY + EPOCHJD);\n if(d.day() === 1) {\n if(d.month() === 1) exactYears++;\n else exactMonths++;\n } else exactDays++;\n } catch(e) {\n // invalid date in this calendar - ignore it here.\n }\n } else {\n d = new Date(di);\n if(d.getUTCDate() === 1) {\n if(d.getUTCMonth() === 0) exactYears++;\n else exactMonths++;\n } else exactDays++;\n }\n }\n exactMonths += exactYears;\n exactDays += exactMonths;\n\n var dataCount = data.length - blankCount;\n\n return {\n exactYears: exactYears / dataCount,\n exactMonths: exactMonths / dataCount,\n exactDays: exactDays / dataCount\n };\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar loggers = require('./loggers');\nvar matrix = require('./matrix');\nvar mat4X4 = require('gl-mat4');\n\n/**\n * Allow referencing a graph DOM element either directly\n * or by its id string\n *\n * @param {HTMLDivElement|string} gd: a graph element or its id\n *\n * @returns {HTMLDivElement} the DOM element of the graph\n */\nfunction getGraphDiv(gd) {\n var gdElement;\n\n if(typeof gd === 'string') {\n gdElement = document.getElementById(gd);\n\n if(gdElement === null) {\n throw new Error('No DOM element with id \\'' + gd + '\\' exists on the page.');\n }\n\n return gdElement;\n } else if(gd === null || gd === undefined) {\n throw new Error('DOM element provided is null or undefined');\n }\n\n // otherwise assume that gd is a DOM element\n return gd;\n}\n\nfunction isPlotDiv(el) {\n var el3 = d3.select(el);\n return el3.node() instanceof HTMLElement &&\n el3.size() &&\n el3.classed('js-plotly-plot');\n}\n\nfunction removeElement(el) {\n var elParent = el && el.parentNode;\n if(elParent) elParent.removeChild(el);\n}\n\n/**\n * for dynamically adding style rules\n * makes one stylesheet that contains all rules added\n * by all calls to this function\n */\nfunction addStyleRule(selector, styleString) {\n addRelatedStyleRule('global', selector, styleString);\n}\n\n/**\n * for dynamically adding style rules\n * to a stylesheet uniquely identified by a uid\n */\nfunction addRelatedStyleRule(uid, selector, styleString) {\n var id = 'plotly.js-style-' + uid;\n var style = document.getElementById(id);\n if(!style) {\n style = document.createElement('style');\n style.setAttribute('id', id);\n // WebKit hack :(\n style.appendChild(document.createTextNode(''));\n document.head.appendChild(style);\n }\n var styleSheet = style.sheet;\n\n if(styleSheet.insertRule) {\n styleSheet.insertRule(selector + '{' + styleString + '}', 0);\n } else if(styleSheet.addRule) {\n styleSheet.addRule(selector, styleString, 0);\n } else loggers.warn('addStyleRule failed');\n}\n\n/**\n * to remove from the page a stylesheet identified by a given uid\n */\nfunction deleteRelatedStyleRule(uid) {\n var id = 'plotly.js-style-' + uid;\n var style = document.getElementById(id);\n if(style) removeElement(style);\n}\n\nfunction getFullTransformMatrix(element) {\n var allElements = getElementAndAncestors(element);\n // the identity matrix\n var out = [\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n ];\n allElements.forEach(function(e) {\n var t = getElementTransformMatrix(e);\n if(t) {\n var m = matrix.convertCssMatrix(t);\n out = mat4X4.multiply(out, out, m);\n }\n });\n return out;\n}\n\n/**\n * extracts and parses the 2d css style transform matrix from some element\n */\nfunction getElementTransformMatrix(element) {\n var style = window.getComputedStyle(element, null);\n var transform = (\n style.getPropertyValue('-webkit-transform') ||\n style.getPropertyValue('-moz-transform') ||\n style.getPropertyValue('-ms-transform') ||\n style.getPropertyValue('-o-transform') ||\n style.getPropertyValue('transform')\n );\n\n if(transform === 'none') return null;\n // the transform is a string in the form of matrix(a, b, ...) or matrix3d(...)\n return transform\n .replace('matrix', '')\n .replace('3d', '')\n .slice(1, -1)\n .split(',')\n .map(function(n) { return +n; });\n}\n/**\n * retrieve all DOM elements that are ancestors of the specified one (including itself)\n */\nfunction getElementAndAncestors(element) {\n var allElements = [];\n while(isTransformableElement(element)) {\n allElements.push(element);\n element = element.parentNode;\n if(typeof ShadowRoot === 'function' && element instanceof ShadowRoot) {\n element = element.host;\n }\n }\n return allElements;\n}\n\nfunction isTransformableElement(element) {\n return element && (element instanceof Element || element instanceof HTMLElement);\n}\n\nfunction equalDomRects(a, b) {\n return (\n a && b &&\n a.top === b.top &&\n a.left === b.left &&\n a.right === b.right &&\n a.bottom === b.bottom\n );\n}\n\nmodule.exports = {\n getGraphDiv: getGraphDiv,\n isPlotDiv: isPlotDiv,\n removeElement: removeElement,\n addStyleRule: addStyleRule,\n addRelatedStyleRule: addRelatedStyleRule,\n deleteRelatedStyleRule: deleteRelatedStyleRule,\n getFullTransformMatrix: getFullTransformMatrix,\n getElementTransformMatrix: getElementTransformMatrix,\n getElementAndAncestors: getElementAndAncestors,\n equalDomRects: equalDomRects\n};\n","'use strict';\n\n/* global jQuery:false */\n\nvar EventEmitter = require('events').EventEmitter;\n\nvar Events = {\n\n init: function(plotObj) {\n /*\n * If we have already instantiated an emitter for this plot\n * return early.\n */\n if(plotObj._ev instanceof EventEmitter) return plotObj;\n\n var ev = new EventEmitter();\n var internalEv = new EventEmitter();\n\n /*\n * Assign to plot._ev while we still live in a land\n * where plot is a DOM element with stuff attached to it.\n * In the future we can make plot the event emitter itself.\n */\n plotObj._ev = ev;\n\n /*\n * Create a second event handler that will manage events *internally*.\n * This allows parts of plotly to respond to thing like relayout without\n * having to use the user-facing event handler. They cannot peacefully\n * coexist on the same handler because a user invoking\n * plotObj.removeAllListeners() would detach internal events, breaking\n * plotly.\n */\n plotObj._internalEv = internalEv;\n\n /*\n * Assign bound methods from the ev to the plot object. These methods\n * will reference the 'this' of plot._ev even though they are methods\n * of plot. This will keep the event machinery away from the plot object\n * which currently is often a DOM element but presents an API that will\n * continue to function when plot becomes an emitter. Not all EventEmitter\n * methods have been bound to `plot` as some do not currently add value to\n * the Plotly event API.\n */\n plotObj.on = ev.on.bind(ev);\n plotObj.once = ev.once.bind(ev);\n plotObj.removeListener = ev.removeListener.bind(ev);\n plotObj.removeAllListeners = ev.removeAllListeners.bind(ev);\n\n /*\n * Create functions for managing internal events. These are *only* triggered\n * by the mirroring of external events via the emit function.\n */\n plotObj._internalOn = internalEv.on.bind(internalEv);\n plotObj._internalOnce = internalEv.once.bind(internalEv);\n plotObj._removeInternalListener = internalEv.removeListener.bind(internalEv);\n plotObj._removeAllInternalListeners = internalEv.removeAllListeners.bind(internalEv);\n\n /*\n * We must wrap emit to continue to support JQuery events. The idea\n * is to check to see if the user is using JQuery events, if they are\n * we emit JQuery events to trigger user handlers as well as the EventEmitter\n * events.\n */\n plotObj.emit = function(event, data) {\n if(typeof jQuery !== 'undefined') {\n jQuery(plotObj).trigger(event, data);\n }\n\n ev.emit(event, data);\n internalEv.emit(event, data);\n };\n\n return plotObj;\n },\n\n /*\n * This function behaves like jQuery's triggerHandler. It calls\n * all handlers for a particular event and returns the return value\n * of the LAST handler. This function also triggers jQuery's\n * triggerHandler for backwards compatibility.\n */\n triggerHandler: function(plotObj, event, data) {\n var jQueryHandlerValue;\n var nodeEventHandlerValue;\n\n /*\n * If jQuery exists run all its handlers for this event and\n * collect the return value of the LAST handler function\n */\n if(typeof jQuery !== 'undefined') {\n jQueryHandlerValue = jQuery(plotObj).triggerHandler(event, data);\n }\n\n /*\n * Now run all the node style event handlers\n */\n var ev = plotObj._ev;\n if(!ev) return jQueryHandlerValue;\n\n var handlers = ev._events[event];\n if(!handlers) return jQueryHandlerValue;\n\n // making sure 'this' is the EventEmitter instance\n function apply(handler) {\n // The 'once' case, we can't just call handler() as we need\n // the return value here. So,\n // - remove handler\n // - call listener and grab return value!\n // - stash 'fired' key to not call handler twice\n if(handler.listener) {\n ev.removeListener(event, handler.listener);\n if(!handler.fired) {\n handler.fired = true;\n return handler.listener.apply(ev, [data]);\n }\n } else {\n return handler.apply(ev, [data]);\n }\n }\n\n // handlers can be function or an array of functions\n handlers = Array.isArray(handlers) ? handlers : [handlers];\n\n var i;\n for(i = 0; i < handlers.length - 1; i++) {\n apply(handlers[i]);\n }\n // now call the final handler and collect its value\n nodeEventHandlerValue = apply(handlers[i]);\n\n /*\n * Return either the jQuery handler value if it exists or the\n * nodeEventHandler value. jQuery event value supersedes nodejs\n * events for backwards compatibility reasons.\n */\n return jQueryHandlerValue !== undefined ?\n jQueryHandlerValue :\n nodeEventHandlerValue;\n },\n\n purge: function(plotObj) {\n delete plotObj._ev;\n delete plotObj.on;\n delete plotObj.once;\n delete plotObj.removeListener;\n delete plotObj.removeAllListeners;\n delete plotObj.emit;\n\n delete plotObj._ev;\n delete plotObj._internalEv;\n delete plotObj._internalOn;\n delete plotObj._internalOnce;\n delete plotObj._removeInternalListener;\n delete plotObj._removeAllInternalListeners;\n\n return plotObj;\n }\n\n};\n\nmodule.exports = Events;\n","'use strict';\n\nvar isPlainObject = require('./is_plain_object.js');\nvar isArray = Array.isArray;\n\nfunction primitivesLoopSplice(source, target) {\n var i, value;\n for(i = 0; i < source.length; i++) {\n value = source[i];\n if(value !== null && typeof(value) === 'object') {\n return false;\n }\n if(value !== void(0)) {\n target[i] = value;\n }\n }\n return true;\n}\n\nexports.extendFlat = function() {\n return _extend(arguments, false, false, false);\n};\n\nexports.extendDeep = function() {\n return _extend(arguments, true, false, false);\n};\n\nexports.extendDeepAll = function() {\n return _extend(arguments, true, true, false);\n};\n\nexports.extendDeepNoArrays = function() {\n return _extend(arguments, true, false, true);\n};\n\n/*\n * Inspired by https://github.com/justmoon/node-extend/blob/master/index.js\n * All credit to the jQuery authors for perfecting this amazing utility.\n *\n * API difference with jQuery version:\n * - No optional boolean (true -> deep extend) first argument,\n * use `extendFlat` for first-level only extend and\n * use `extendDeep` for a deep extend.\n *\n * Other differences with jQuery version:\n * - Uses a modern (and faster) isPlainObject routine.\n * - Expected to work with object {} and array [] arguments only.\n * - Does not check for circular structure.\n * FYI: jQuery only does a check across one level.\n * Warning: this might result in infinite loops.\n *\n */\nfunction _extend(inputs, isDeep, keepAllKeys, noArrayCopies) {\n var target = inputs[0];\n var length = inputs.length;\n\n var input, key, src, copy, copyIsArray, clone, allPrimitives;\n\n // TODO does this do the right thing for typed arrays?\n\n if(length === 2 && isArray(target) && isArray(inputs[1]) && target.length === 0) {\n allPrimitives = primitivesLoopSplice(inputs[1], target);\n\n if(allPrimitives) {\n return target;\n } else {\n target.splice(0, target.length); // reset target and continue to next block\n }\n }\n\n for(var i = 1; i < length; i++) {\n input = inputs[i];\n\n for(key in input) {\n src = target[key];\n copy = input[key];\n\n if(noArrayCopies && isArray(copy)) {\n // Stop early and just transfer the array if array copies are disallowed:\n\n target[key] = copy;\n } else if(isDeep && copy && (isPlainObject(copy) || (copyIsArray = isArray(copy)))) {\n // recurse if we're merging plain objects or arrays\n\n if(copyIsArray) {\n copyIsArray = false;\n clone = src && isArray(src) ? src : [];\n } else {\n clone = src && isPlainObject(src) ? src : {};\n }\n\n // never move original objects, clone them\n target[key] = _extend([clone, copy], isDeep, keepAllKeys, noArrayCopies);\n } else if(typeof copy !== 'undefined' || keepAllKeys) {\n // don't bring in undefined values, except for extendDeepAll\n\n target[key] = copy;\n }\n }\n }\n\n return target;\n}\n","'use strict';\n\n\n/**\n * Return news array containing only the unique items\n * found in input array.\n *\n * IMPORTANT: Note that items are considered unique\n * if `String({})` is unique. For example;\n *\n * Lib.filterUnique([ { a: 1 }, { b: 2 } ])\n *\n * returns [{ a: 1 }]\n *\n * and\n *\n * Lib.filterUnique([ '1', 1 ])\n *\n * returns ['1']\n *\n *\n * @param {array} array base array\n * @return {array} new filtered array\n */\nmodule.exports = function filterUnique(array) {\n var seen = {};\n var out = [];\n var j = 0;\n\n for(var i = 0; i < array.length; i++) {\n var item = array[i];\n\n if(seen[item] !== 1) {\n seen[item] = 1;\n out[j++] = item;\n }\n }\n\n return out;\n};\n","'use strict';\n\n/** Filter out object items with visible !== true\n * insider array container.\n *\n * @param {array of objects} container\n * @return {array of objects} of length <= container\n *\n */\nmodule.exports = function filterVisible(container) {\n var filterFn = isCalcData(container) ? calcDataFilter : baseFilter;\n var out = [];\n\n for(var i = 0; i < container.length; i++) {\n var item = container[i];\n if(filterFn(item)) out.push(item);\n }\n\n return out;\n};\n\nfunction baseFilter(item) {\n return item.visible === true;\n}\n\nfunction calcDataFilter(item) {\n var trace = item[0].trace;\n return trace.visible === true && trace._length !== 0;\n}\n\nfunction isCalcData(cont) {\n return (\n Array.isArray(cont) &&\n Array.isArray(cont[0]) &&\n cont[0][0] &&\n cont[0][0].trace\n );\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar countryRegex = require('country-regex');\nvar { area: turfArea } = require('@turf/area');\nvar { centroid: turfCentroid } = require('@turf/centroid');\nvar { bbox: turfBbox } = require('@turf/bbox');\n\nvar identity = require('./identity');\nvar loggers = require('./loggers');\nvar isPlainObject = require('./is_plain_object');\nvar nestedProperty = require('./nested_property');\nvar polygon = require('./polygon');\n\n// make list of all country iso3 ids from at runtime\nvar countryIds = Object.keys(countryRegex);\n\nvar locationmodeToIdFinder = {\n 'ISO-3': identity,\n 'USA-states': identity,\n 'country names': countryNameToISO3\n};\n\nfunction countryNameToISO3(countryName) {\n for(var i = 0; i < countryIds.length; i++) {\n var iso3 = countryIds[i];\n var regex = new RegExp(countryRegex[iso3]);\n\n if(regex.test(countryName.trim().toLowerCase())) return iso3;\n }\n\n loggers.log('Unrecognized country name: ' + countryName + '.');\n\n return false;\n}\n\nfunction locationToFeature(locationmode, location, features) {\n if(!location || typeof location !== 'string') return false;\n\n var locationId = locationmodeToIdFinder[locationmode](location);\n var filteredFeatures;\n var f, i;\n\n if(locationId) {\n if(locationmode === 'USA-states') {\n // Filter out features out in USA\n //\n // This is important as the Natural Earth files\n // include state/provinces from USA, Canada, Australia and Brazil\n // which have some overlay in their two-letter ids. For example,\n // 'WA' is used for both Washington state and Western Australia.\n filteredFeatures = [];\n for(i = 0; i < features.length; i++) {\n f = features[i];\n if(f.properties && f.properties.gu && f.properties.gu === 'USA') {\n filteredFeatures.push(f);\n }\n }\n } else {\n filteredFeatures = features;\n }\n\n for(i = 0; i < filteredFeatures.length; i++) {\n f = filteredFeatures[i];\n if(f.id === locationId) return f;\n }\n\n loggers.log([\n 'Location with id', locationId,\n 'does not have a matching topojson feature at this resolution.'\n ].join(' '));\n }\n\n return false;\n}\n\nfunction feature2polygons(feature) {\n var geometry = feature.geometry;\n var coords = geometry.coordinates;\n var loc = feature.id;\n\n var polygons = [];\n var appendPolygon, j, k, m;\n\n function doesCrossAntiMerdian(pts) {\n for(var l = 0; l < pts.length - 1; l++) {\n if(pts[l][0] > 0 && pts[l + 1][0] < 0) return l;\n }\n return null;\n }\n\n if(loc === 'RUS' || loc === 'FJI') {\n // Russia and Fiji have landmasses that cross the antimeridian,\n // we need to add +360 to their longitude coordinates, so that\n // polygon 'contains' doesn't get confused when crossing the antimeridian.\n //\n // Note that other countries have polygons on either side of the antimeridian\n // (e.g. some Aleutian island for the USA), but those don't confuse\n // the 'contains' method; these are skipped here.\n appendPolygon = function(_pts) {\n var pts;\n\n if(doesCrossAntiMerdian(_pts) === null) {\n pts = _pts;\n } else {\n pts = new Array(_pts.length);\n for(m = 0; m < _pts.length; m++) {\n // do not mutate calcdata[i][j].geojson !!\n pts[m] = [\n _pts[m][0] < 0 ? _pts[m][0] + 360 : _pts[m][0],\n _pts[m][1]\n ];\n }\n }\n\n polygons.push(polygon.tester(pts));\n };\n } else if(loc === 'ATA') {\n // Antarctica has a landmass that wraps around every longitudes which\n // confuses the 'contains' methods.\n appendPolygon = function(pts) {\n var crossAntiMeridianIndex = doesCrossAntiMerdian(pts);\n\n // polygon that do not cross anti-meridian need no special handling\n if(crossAntiMeridianIndex === null) {\n return polygons.push(polygon.tester(pts));\n }\n\n // stitch polygon by adding pt over South Pole,\n // so that it covers the projected region covers all latitudes\n //\n // Note that the algorithm below only works for polygons that\n // start and end on longitude -180 (like the ones built by\n // https://github.com/etpinard/sane-topojson).\n var stitch = new Array(pts.length + 1);\n var si = 0;\n\n for(m = 0; m < pts.length; m++) {\n if(m > crossAntiMeridianIndex) {\n stitch[si++] = [pts[m][0] + 360, pts[m][1]];\n } else if(m === crossAntiMeridianIndex) {\n stitch[si++] = pts[m];\n stitch[si++] = [pts[m][0], -90];\n } else {\n stitch[si++] = pts[m];\n }\n }\n\n // polygon.tester by default appends pt[0] to the points list,\n // we must remove it here, to avoid a jump in longitude from 180 to -180,\n // that would confuse the 'contains' method\n var tester = polygon.tester(stitch);\n tester.pts.pop();\n polygons.push(tester);\n };\n } else {\n // otherwise using same array ref is fine\n appendPolygon = function(pts) {\n polygons.push(polygon.tester(pts));\n };\n }\n\n switch(geometry.type) {\n case 'MultiPolygon':\n for(j = 0; j < coords.length; j++) {\n for(k = 0; k < coords[j].length; k++) {\n appendPolygon(coords[j][k]);\n }\n }\n break;\n case 'Polygon':\n for(j = 0; j < coords.length; j++) {\n appendPolygon(coords[j]);\n }\n break;\n }\n\n return polygons;\n}\n\nfunction getTraceGeojson(trace) {\n var g = trace.geojson;\n var PlotlyGeoAssets = window.PlotlyGeoAssets || {};\n var geojsonIn = typeof g === 'string' ? PlotlyGeoAssets[g] : g;\n\n // This should not happen, but just in case something goes\n // really wrong when fetching the GeoJSON\n if(!isPlainObject(geojsonIn)) {\n loggers.error('Oops ... something went wrong when fetching ' + g);\n return false;\n }\n\n return geojsonIn;\n}\n\nfunction extractTraceFeature(calcTrace) {\n var trace = calcTrace[0].trace;\n\n var geojsonIn = getTraceGeojson(trace);\n if(!geojsonIn) return false;\n\n var lookup = {};\n var featuresOut = [];\n var i;\n\n for(i = 0; i < trace._length; i++) {\n var cdi = calcTrace[i];\n if(cdi.loc || cdi.loc === 0) {\n lookup[cdi.loc] = cdi;\n }\n }\n\n function appendFeature(fIn) {\n var id = nestedProperty(fIn, trace.featureidkey || 'id').get();\n var cdi = lookup[id];\n\n if(cdi) {\n var geometry = fIn.geometry;\n\n if(geometry.type === 'Polygon' || geometry.type === 'MultiPolygon') {\n var fOut = {\n type: 'Feature',\n id: id,\n geometry: geometry,\n properties: {}\n };\n\n // Compute centroid, add it to the properties\n if (fOut.geometry.coordinates.length > 0) {\n fOut.properties.ct = findCentroid(fOut);\n } else {\n fOut.properties.ct = [NaN, NaN];\n }\n\n // Mutate in in/out features into calcdata\n cdi.fIn = fIn;\n cdi.fOut = fOut;\n\n featuresOut.push(fOut);\n } else {\n loggers.log([\n 'Location', cdi.loc, 'does not have a valid GeoJSON geometry.',\n 'Traces with locationmode *geojson-id* only support',\n '*Polygon* and *MultiPolygon* geometries.'\n ].join(' '));\n }\n }\n\n // remove key from lookup, so that we can track (if any)\n // the locations that did not have a corresponding GeoJSON feature\n delete lookup[id];\n }\n\n switch(geojsonIn.type) {\n case 'FeatureCollection':\n var featuresIn = geojsonIn.features;\n for(i = 0; i < featuresIn.length; i++) {\n appendFeature(featuresIn[i]);\n }\n break;\n case 'Feature':\n appendFeature(geojsonIn);\n break;\n default:\n loggers.warn([\n 'Invalid GeoJSON type', (geojsonIn.type || 'none') + '.',\n 'Traces with locationmode *geojson-id* only support',\n '*FeatureCollection* and *Feature* types.'\n ].join(' '));\n return false;\n }\n\n for(var loc in lookup) {\n loggers.log([\n 'Location *' + loc + '*',\n 'does not have a matching feature with id-key',\n '*' + trace.featureidkey + '*.'\n ].join(' '));\n }\n\n return featuresOut;\n}\n\n// TODO this find the centroid of the polygon of maxArea\n// (just like we currently do for geo choropleth polygons),\n// maybe instead it would make more sense to compute the centroid\n// of each polygon and consider those on hover/select\nfunction findCentroid(feature) {\n var geometry = feature.geometry;\n var poly;\n\n if(geometry.type === 'MultiPolygon') {\n var coords = geometry.coordinates;\n var maxArea = 0;\n\n for(var i = 0; i < coords.length; i++) {\n var polyi = {type: 'Polygon', coordinates: coords[i]};\n var area = turfArea(polyi);\n if(area > maxArea) {\n maxArea = area;\n poly = polyi;\n }\n }\n } else {\n poly = geometry;\n }\n\n return turfCentroid(poly).geometry.coordinates;\n}\n\nfunction fetchTraceGeoData(calcData) {\n var PlotlyGeoAssets = window.PlotlyGeoAssets || {};\n var promises = [];\n\n function fetch(url) {\n return new Promise(function(resolve, reject) {\n d3.json(url, function(err, d) {\n if(err) {\n delete PlotlyGeoAssets[url];\n var msg = err.status === 404 ?\n ('GeoJSON at URL \"' + url + '\" does not exist.') :\n ('Unexpected error while fetching from ' + url);\n return reject(new Error(msg));\n }\n\n PlotlyGeoAssets[url] = d;\n return resolve(d);\n });\n });\n }\n\n function wait(url) {\n return new Promise(function(resolve, reject) {\n var cnt = 0;\n var interval = setInterval(function() {\n if(PlotlyGeoAssets[url] && PlotlyGeoAssets[url] !== 'pending') {\n clearInterval(interval);\n return resolve(PlotlyGeoAssets[url]);\n }\n if(cnt > 100) {\n clearInterval(interval);\n return reject('Unexpected error while fetching from ' + url);\n }\n cnt++;\n }, 50);\n });\n }\n\n for(var i = 0; i < calcData.length; i++) {\n var trace = calcData[i][0].trace;\n var url = trace.geojson;\n\n if(typeof url === 'string') {\n if(!PlotlyGeoAssets[url]) {\n PlotlyGeoAssets[url] = 'pending';\n promises.push(fetch(url));\n } else if(PlotlyGeoAssets[url] === 'pending') {\n promises.push(wait(url));\n }\n }\n }\n\n return promises;\n}\n\n// TODO `turf/bbox` gives wrong result when the input feature/geometry\n// crosses the anti-meridian. We should try to implement our own bbox logic.\nfunction computeBbox(d) {\n return turfBbox(d);\n}\n\nmodule.exports = {\n locationToFeature: locationToFeature,\n feature2polygons: feature2polygons,\n getTraceGeojson: getTraceGeojson,\n extractTraceFeature: extractTraceFeature,\n fetchTraceGeoData: fetchTraceGeoData,\n computeBbox: computeBbox\n};\n","'use strict';\n\nvar BADNUM = require('../constants/numerical').BADNUM;\n\n/**\n * Convert calcTrace to GeoJSON 'MultiLineString' coordinate arrays\n *\n * @param {object} calcTrace\n * gd.calcdata item.\n * Note that calcTrace[i].lonlat is assumed to be defined\n *\n * @return {array}\n * return line coords array (or array of arrays)\n *\n */\nexports.calcTraceToLineCoords = function(calcTrace) {\n var trace = calcTrace[0].trace;\n var connectgaps = trace.connectgaps;\n\n var coords = [];\n var lineString = [];\n\n for(var i = 0; i < calcTrace.length; i++) {\n var calcPt = calcTrace[i];\n var lonlat = calcPt.lonlat;\n\n if(lonlat[0] !== BADNUM) {\n lineString.push(lonlat);\n } else if(!connectgaps && lineString.length > 0) {\n coords.push(lineString);\n lineString = [];\n }\n }\n\n if(lineString.length > 0) {\n coords.push(lineString);\n }\n\n return coords;\n};\n\n\n/**\n * Make line ('LineString' or 'MultiLineString') GeoJSON\n *\n * @param {array} coords\n * results form calcTraceToLineCoords\n * @return {object} out\n * GeoJSON object\n *\n */\nexports.makeLine = function(coords) {\n if(coords.length === 1) {\n return {\n type: 'LineString',\n coordinates: coords[0]\n };\n } else {\n return {\n type: 'MultiLineString',\n coordinates: coords\n };\n }\n};\n\n/**\n * Make polygon ('Polygon' or 'MultiPolygon') GeoJSON\n *\n * @param {array} coords\n * results form calcTraceToLineCoords\n * @return {object} out\n * GeoJSON object\n */\nexports.makePolygon = function(coords) {\n if(coords.length === 1) {\n return {\n type: 'Polygon',\n coordinates: coords\n };\n } else {\n var _coords = new Array(coords.length);\n\n for(var i = 0; i < coords.length; i++) {\n _coords[i] = [coords[i]];\n }\n\n return {\n type: 'MultiPolygon',\n coordinates: _coords\n };\n }\n};\n\n/**\n * Make blank GeoJSON\n *\n * @return {object}\n * Blank GeoJSON object\n *\n */\nexports.makeBlank = function() {\n return {\n type: 'Point',\n coordinates: []\n };\n};\n","'use strict';\n\nvar mod = require('./mod').mod;\n\n/*\n * look for intersection of two line segments\n * (1->2 and 3->4) - returns array [x,y] if they do, null if not\n */\nexports.segmentsIntersect = segmentsIntersect;\nfunction segmentsIntersect(x1, y1, x2, y2, x3, y3, x4, y4) {\n var a = x2 - x1;\n var b = x3 - x1;\n var c = x4 - x3;\n var d = y2 - y1;\n var e = y3 - y1;\n var f = y4 - y3;\n var det = a * f - c * d;\n // parallel lines? intersection is undefined\n // ignore the case where they are colinear\n if(det === 0) return null;\n var t = (b * f - c * e) / det;\n var u = (b * d - a * e) / det;\n // segments do not intersect?\n if(u < 0 || u > 1 || t < 0 || t > 1) return null;\n\n return {x: x1 + a * t, y: y1 + d * t};\n}\n\n/*\n * find the minimum distance between two line segments (1->2 and 3->4)\n */\nexports.segmentDistance = function segmentDistance(x1, y1, x2, y2, x3, y3, x4, y4) {\n if(segmentsIntersect(x1, y1, x2, y2, x3, y3, x4, y4)) return 0;\n\n // the two segments and their lengths squared\n var x12 = x2 - x1;\n var y12 = y2 - y1;\n var x34 = x4 - x3;\n var y34 = y4 - y3;\n var ll12 = x12 * x12 + y12 * y12;\n var ll34 = x34 * x34 + y34 * y34;\n\n // calculate distance squared, then take the sqrt at the very end\n var dist2 = Math.min(\n perpDistance2(x12, y12, ll12, x3 - x1, y3 - y1),\n perpDistance2(x12, y12, ll12, x4 - x1, y4 - y1),\n perpDistance2(x34, y34, ll34, x1 - x3, y1 - y3),\n perpDistance2(x34, y34, ll34, x2 - x3, y2 - y3)\n );\n\n return Math.sqrt(dist2);\n};\n\n/*\n * distance squared from segment ab to point c\n * [xab, yab] is the vector b-a\n * [xac, yac] is the vector c-a\n * llab is the length squared of (b-a), just to simplify calculation\n */\nfunction perpDistance2(xab, yab, llab, xac, yac) {\n var fcAB = (xac * xab + yac * yab);\n if(fcAB < 0) {\n // point c is closer to point a\n return xac * xac + yac * yac;\n } else if(fcAB > llab) {\n // point c is closer to point b\n var xbc = xac - xab;\n var ybc = yac - yab;\n return xbc * xbc + ybc * ybc;\n } else {\n // perpendicular distance is the shortest\n var crossProduct = xac * yab - yac * xab;\n return crossProduct * crossProduct / llab;\n }\n}\n\n// a very short-term cache for getTextLocation, just because\n// we're often looping over the same locations multiple times\n// invalidated as soon as we look at a different path\nvar locationCache, workingPath, workingTextWidth;\n\n// turn a path and position along it into x, y, and angle for the given text\nexports.getTextLocation = function getTextLocation(path, totalPathLen, positionOnPath, textWidth) {\n if(path !== workingPath || textWidth !== workingTextWidth) {\n locationCache = {};\n workingPath = path;\n workingTextWidth = textWidth;\n }\n if(locationCache[positionOnPath]) {\n return locationCache[positionOnPath];\n }\n\n // for the angle, use points on the path separated by the text width\n // even though due to curvature, the text will cover a bit more than that\n var p0 = path.getPointAtLength(mod(positionOnPath - textWidth / 2, totalPathLen));\n var p1 = path.getPointAtLength(mod(positionOnPath + textWidth / 2, totalPathLen));\n // note: atan handles 1/0 nicely\n var theta = Math.atan((p1.y - p0.y) / (p1.x - p0.x));\n // center the text at 2/3 of the center position plus 1/3 the p0/p1 midpoint\n // that's the average position of this segment, assuming it's roughly quadratic\n var pCenter = path.getPointAtLength(mod(positionOnPath, totalPathLen));\n var x = (pCenter.x * 4 + p0.x + p1.x) / 6;\n var y = (pCenter.y * 4 + p0.y + p1.y) / 6;\n\n var out = {x: x, y: y, theta: theta};\n locationCache[positionOnPath] = out;\n return out;\n};\n\nexports.clearLocationCache = function() {\n workingPath = null;\n};\n\n/*\n * Find the segment of `path` that's within the visible area\n * given by `bounds` {left, right, top, bottom}, to within a\n * precision of `buffer` px\n *\n * returns: undefined if nothing is visible, else object:\n * {\n * min: position where the path first enters bounds, or 0 if it\n * starts within bounds\n * max: position where the path last exits bounds, or the path length\n * if it finishes within bounds\n * len: max - min, ie the length of visible path\n * total: the total path length - just included so the caller doesn't\n * need to call path.getTotalLength() again\n * isClosed: true iff the start and end points of the path are both visible\n * and are at the same point\n * }\n *\n * Works by starting from either end and repeatedly finding the distance from\n * that point to the plot area, and if it's outside the plot, moving along the\n * path by that distance (because the plot must be at least that far away on\n * the path). Note that if a path enters, exits, and re-enters the plot, we\n * will not capture this behavior.\n */\nexports.getVisibleSegment = function getVisibleSegment(path, bounds, buffer) {\n var left = bounds.left;\n var right = bounds.right;\n var top = bounds.top;\n var bottom = bounds.bottom;\n\n var pMin = 0;\n var pTotal = path.getTotalLength();\n var pMax = pTotal;\n\n var pt0, ptTotal;\n\n function getDistToPlot(len) {\n var pt = path.getPointAtLength(len);\n\n // hold on to the start and end points for `closed`\n if(len === 0) pt0 = pt;\n else if(len === pTotal) ptTotal = pt;\n\n var dx = (pt.x < left) ? left - pt.x : (pt.x > right ? pt.x - right : 0);\n var dy = (pt.y < top) ? top - pt.y : (pt.y > bottom ? pt.y - bottom : 0);\n return Math.sqrt(dx * dx + dy * dy);\n }\n\n var distToPlot = getDistToPlot(pMin);\n while(distToPlot) {\n pMin += distToPlot + buffer;\n if(pMin > pMax) return;\n distToPlot = getDistToPlot(pMin);\n }\n\n distToPlot = getDistToPlot(pMax);\n while(distToPlot) {\n pMax -= distToPlot + buffer;\n if(pMin > pMax) return;\n distToPlot = getDistToPlot(pMax);\n }\n\n return {\n min: pMin,\n max: pMax,\n len: pMax - pMin,\n total: pTotal,\n isClosed: pMin === 0 && pMax === pTotal &&\n Math.abs(pt0.x - ptTotal.x) < 0.1 &&\n Math.abs(pt0.y - ptTotal.y) < 0.1\n };\n};\n\n/**\n * Find point on SVG path corresponding to a given constraint coordinate\n *\n * @param {SVGPathElement} path\n * @param {Number} val : constraint coordinate value\n * @param {String} coord : 'x' or 'y' the constraint coordinate\n * @param {Object} opts :\n * - {Number} pathLength : supply total path length before hand\n * - {Number} tolerance\n * - {Number} iterationLimit\n * @return {SVGPoint}\n */\nexports.findPointOnPath = function findPointOnPath(path, val, coord, opts) {\n opts = opts || {};\n\n var pathLength = opts.pathLength || path.getTotalLength();\n var tolerance = opts.tolerance || 1e-3;\n var iterationLimit = opts.iterationLimit || 30;\n\n // if path starts at a val greater than the path tail (like on vertical violins),\n // we must flip the sign of the computed diff.\n var mul = path.getPointAtLength(0)[coord] > path.getPointAtLength(pathLength)[coord] ? -1 : 1;\n\n var i = 0;\n var b0 = 0;\n var b1 = pathLength;\n var mid;\n var pt;\n var diff;\n\n while(i < iterationLimit) {\n mid = (b0 + b1) / 2;\n pt = path.getPointAtLength(mid);\n diff = pt[coord] - val;\n\n if(Math.abs(diff) < tolerance) {\n return pt;\n } else {\n if(mul * diff > 0) {\n b1 = mid;\n } else {\n b0 = mid;\n }\n i++;\n }\n }\n return pt;\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar tinycolor = require('tinycolor2');\nvar rgba = require('color-normalize');\n\nvar Colorscale = require('../components/colorscale');\nvar colorDflt = require('../components/color/attributes').defaultLine;\nvar isArrayOrTypedArray = require('./array').isArrayOrTypedArray;\n\nvar colorDfltRgba = rgba(colorDflt);\nvar opacityDflt = 1;\n\nfunction calculateColor(colorIn, opacityIn) {\n var colorOut = colorIn;\n colorOut[3] *= opacityIn;\n return colorOut;\n}\n\nfunction validateColor(colorIn) {\n if(isNumeric(colorIn)) return colorDfltRgba;\n\n var colorOut = rgba(colorIn);\n\n return colorOut.length ? colorOut : colorDfltRgba;\n}\n\nfunction validateOpacity(opacityIn) {\n return isNumeric(opacityIn) ? opacityIn : opacityDflt;\n}\n\nfunction formatColor(containerIn, opacityIn, len) {\n var colorIn = containerIn.color;\n if(colorIn && colorIn._inputArray) colorIn = colorIn._inputArray;\n\n var isArrayColorIn = isArrayOrTypedArray(colorIn);\n var isArrayOpacityIn = isArrayOrTypedArray(opacityIn);\n var cOpts = Colorscale.extractOpts(containerIn);\n var colorOut = [];\n\n var sclFunc, getColor, getOpacity, colori, opacityi;\n\n if(cOpts.colorscale !== undefined) {\n sclFunc = Colorscale.makeColorScaleFuncFromTrace(containerIn);\n } else {\n sclFunc = validateColor;\n }\n\n if(isArrayColorIn) {\n getColor = function(c, i) {\n // FIXME: there is double work, considering that sclFunc does the opposite\n return c[i] === undefined ? colorDfltRgba : rgba(sclFunc(c[i]));\n };\n } else getColor = validateColor;\n\n if(isArrayOpacityIn) {\n getOpacity = function(o, i) {\n return o[i] === undefined ? opacityDflt : validateOpacity(o[i]);\n };\n } else getOpacity = validateOpacity;\n\n if(isArrayColorIn || isArrayOpacityIn) {\n for(var i = 0; i < len; i++) {\n colori = getColor(colorIn, i);\n opacityi = getOpacity(opacityIn, i);\n colorOut[i] = calculateColor(colori, opacityi);\n }\n } else colorOut = calculateColor(rgba(colorIn), opacityIn);\n\n return colorOut;\n}\n\nfunction parseColorScale(cont) {\n var cOpts = Colorscale.extractOpts(cont);\n\n var colorscale = cOpts.colorscale;\n if(cOpts.reversescale) colorscale = Colorscale.flipScale(cOpts.colorscale);\n\n return colorscale.map(function(elem) {\n var index = elem[0];\n var color = tinycolor(elem[1]);\n var rgb = color.toRgb();\n return {\n index: index,\n rgb: [rgb.r, rgb.g, rgb.b, rgb.a]\n };\n });\n}\n\nmodule.exports = {\n formatColor: formatColor,\n parseColorScale: parseColorScale\n};\n","'use strict';\n\nvar identity = require('./identity');\n\nfunction wrap(d) {return [d];}\n\nmodule.exports = {\n\n // The D3 data binding concept and the General Update Pattern promotes the idea of\n // traversing into the scenegraph by using the `.data(fun, keyFun)` call.\n // The `fun` is most often a `repeat`, ie. the elements beneath a `` element need\n // access to the same data, or a `descend`, which fans a scenegraph node into a bunch of\n // of elements, e.g. points, lines, rows, requiring an array as input.\n // The role of the `keyFun` is to identify what elements are being entered/exited/updated,\n // otherwise D3 reverts to using a plain index which would screw up `transition`s.\n keyFun: function(d) {return d.key;},\n repeat: wrap,\n descend: identity,\n\n // Plotly.js uses a convention of storing the actual contents of the `calcData` as the\n // element zero of a container array. These helpers are just used for clarity as a\n // newcomer to the codebase may not know what the `[0]` is, and whether there can be further\n // elements (not atm).\n wrap: wrap,\n unwrap: function(d) {return d[0];}\n};\n","'use strict';\n\n// Simple helper functions\n// none of these need any external deps\n\nmodule.exports = function identity(d) { return d; };\n","'use strict';\n\nmodule.exports = function incrementNumeric(x, delta) {\n if(!delta) return x;\n\n // Note 1:\n // 0.3 != 0.1 + 0.2 == 0.30000000000000004\n // but 0.3 == (10 * 0.1 + 10 * 0.2) / 10\n // Attempt to use integer steps to increment\n var scale = 1 / Math.abs(delta);\n var newX = (scale > 1) ? (\n scale * x +\n scale * delta\n ) / scale : x + delta;\n\n // Note 2:\n // now we may also consider rounding to cover few more edge cases\n // e.g. 0.3 * 3 = 0.8999999999999999\n var lenX1 = String(newX).length;\n if(lenX1 > 16) {\n var lenDt = String(delta).length;\n var lenX0 = String(x).length;\n\n if(lenX1 >= lenX0 + lenDt) { // likely a rounding error!\n var s = parseFloat(newX).toPrecision(12);\n if(s.indexOf('e+') === -1) newX = +s;\n }\n }\n\n return newX;\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar utcFormat = require('d3-time-format').utcFormat;\nvar d3Format = require('d3-format').format;\nvar isNumeric = require('fast-isnumeric');\n\nvar numConstants = require('../constants/numerical');\nvar MAX_SAFE = numConstants.FP_SAFE;\nvar MIN_SAFE = -MAX_SAFE;\nvar BADNUM = numConstants.BADNUM;\n\nvar lib = module.exports = {};\n\nlib.adjustFormat = function adjustFormat(formatStr) {\n if(\n !formatStr ||\n /^\\d[.]\\df/.test(formatStr) ||\n /[.]\\d%/.test(formatStr)\n ) return formatStr;\n\n if(formatStr === '0.f') return '~f';\n if(/^\\d%/.test(formatStr)) return '~%';\n if(/^\\ds/.test(formatStr)) return '~s';\n\n // try adding tilde to the start of format in order to trim\n if(!(/^[~,.0$]/.test(formatStr)) && /[&fps]/.test(formatStr)) return '~' + formatStr;\n\n return formatStr;\n};\n\nvar seenBadFormats = {};\nlib.warnBadFormat = function(f) {\n var key = String(f);\n if(!seenBadFormats[key]) {\n seenBadFormats[key] = 1;\n lib.warn('encountered bad format: \"' + key + '\"');\n }\n};\n\nlib.noFormat = function(value) {\n return String(value);\n};\n\nlib.numberFormat = function(formatStr) {\n var fn;\n try {\n fn = d3Format(lib.adjustFormat(formatStr));\n } catch(e) {\n lib.warnBadFormat(formatStr);\n return lib.noFormat;\n }\n\n return fn;\n};\n\nlib.nestedProperty = require('./nested_property');\nlib.keyedContainer = require('./keyed_container');\nlib.relativeAttr = require('./relative_attr');\nlib.isPlainObject = require('./is_plain_object');\nlib.toLogRange = require('./to_log_range');\nlib.relinkPrivateKeys = require('./relink_private');\n\nvar arrayModule = require('./array');\nlib.isArrayBuffer = arrayModule.isArrayBuffer;\nlib.isTypedArray = arrayModule.isTypedArray;\nlib.isArrayOrTypedArray = arrayModule.isArrayOrTypedArray;\nlib.isArray1D = arrayModule.isArray1D;\nlib.ensureArray = arrayModule.ensureArray;\nlib.concat = arrayModule.concat;\nlib.maxRowLength = arrayModule.maxRowLength;\nlib.minRowLength = arrayModule.minRowLength;\n\nvar modModule = require('./mod');\nlib.mod = modModule.mod;\nlib.modHalf = modModule.modHalf;\n\nvar coerceModule = require('./coerce');\nlib.valObjectMeta = coerceModule.valObjectMeta;\nlib.coerce = coerceModule.coerce;\nlib.coerce2 = coerceModule.coerce2;\nlib.coerceFont = coerceModule.coerceFont;\nlib.coercePattern = coerceModule.coercePattern;\nlib.coerceHoverinfo = coerceModule.coerceHoverinfo;\nlib.coerceSelectionMarkerOpacity = coerceModule.coerceSelectionMarkerOpacity;\nlib.validate = coerceModule.validate;\n\nvar datesModule = require('./dates');\nlib.dateTime2ms = datesModule.dateTime2ms;\nlib.isDateTime = datesModule.isDateTime;\nlib.ms2DateTime = datesModule.ms2DateTime;\nlib.ms2DateTimeLocal = datesModule.ms2DateTimeLocal;\nlib.cleanDate = datesModule.cleanDate;\nlib.isJSDate = datesModule.isJSDate;\nlib.formatDate = datesModule.formatDate;\nlib.incrementMonth = datesModule.incrementMonth;\nlib.dateTick0 = datesModule.dateTick0;\nlib.dfltRange = datesModule.dfltRange;\nlib.findExactDates = datesModule.findExactDates;\nlib.MIN_MS = datesModule.MIN_MS;\nlib.MAX_MS = datesModule.MAX_MS;\n\nvar searchModule = require('./search');\nlib.findBin = searchModule.findBin;\nlib.sorterAsc = searchModule.sorterAsc;\nlib.sorterDes = searchModule.sorterDes;\nlib.distinctVals = searchModule.distinctVals;\nlib.roundUp = searchModule.roundUp;\nlib.sort = searchModule.sort;\nlib.findIndexOfMin = searchModule.findIndexOfMin;\n\nlib.sortObjectKeys = require('./sort_object_keys');\n\nvar statsModule = require('./stats');\nlib.aggNums = statsModule.aggNums;\nlib.len = statsModule.len;\nlib.mean = statsModule.mean;\nlib.geometricMean = statsModule.geometricMean;\nlib.median = statsModule.median;\nlib.midRange = statsModule.midRange;\nlib.variance = statsModule.variance;\nlib.stdev = statsModule.stdev;\nlib.interp = statsModule.interp;\n\nvar matrixModule = require('./matrix');\nlib.init2dArray = matrixModule.init2dArray;\nlib.transposeRagged = matrixModule.transposeRagged;\nlib.dot = matrixModule.dot;\nlib.translationMatrix = matrixModule.translationMatrix;\nlib.rotationMatrix = matrixModule.rotationMatrix;\nlib.rotationXYMatrix = matrixModule.rotationXYMatrix;\nlib.apply3DTransform = matrixModule.apply3DTransform;\nlib.apply2DTransform = matrixModule.apply2DTransform;\nlib.apply2DTransform2 = matrixModule.apply2DTransform2;\nlib.convertCssMatrix = matrixModule.convertCssMatrix;\nlib.inverseTransformMatrix = matrixModule.inverseTransformMatrix;\n\nvar anglesModule = require('./angles');\nlib.deg2rad = anglesModule.deg2rad;\nlib.rad2deg = anglesModule.rad2deg;\nlib.angleDelta = anglesModule.angleDelta;\nlib.angleDist = anglesModule.angleDist;\nlib.isFullCircle = anglesModule.isFullCircle;\nlib.isAngleInsideSector = anglesModule.isAngleInsideSector;\nlib.isPtInsideSector = anglesModule.isPtInsideSector;\nlib.pathArc = anglesModule.pathArc;\nlib.pathSector = anglesModule.pathSector;\nlib.pathAnnulus = anglesModule.pathAnnulus;\n\nvar anchorUtils = require('./anchor_utils');\nlib.isLeftAnchor = anchorUtils.isLeftAnchor;\nlib.isCenterAnchor = anchorUtils.isCenterAnchor;\nlib.isRightAnchor = anchorUtils.isRightAnchor;\nlib.isTopAnchor = anchorUtils.isTopAnchor;\nlib.isMiddleAnchor = anchorUtils.isMiddleAnchor;\nlib.isBottomAnchor = anchorUtils.isBottomAnchor;\n\nvar geom2dModule = require('./geometry2d');\nlib.segmentsIntersect = geom2dModule.segmentsIntersect;\nlib.segmentDistance = geom2dModule.segmentDistance;\nlib.getTextLocation = geom2dModule.getTextLocation;\nlib.clearLocationCache = geom2dModule.clearLocationCache;\nlib.getVisibleSegment = geom2dModule.getVisibleSegment;\nlib.findPointOnPath = geom2dModule.findPointOnPath;\n\nvar extendModule = require('./extend');\nlib.extendFlat = extendModule.extendFlat;\nlib.extendDeep = extendModule.extendDeep;\nlib.extendDeepAll = extendModule.extendDeepAll;\nlib.extendDeepNoArrays = extendModule.extendDeepNoArrays;\n\nvar loggersModule = require('./loggers');\nlib.log = loggersModule.log;\nlib.warn = loggersModule.warn;\nlib.error = loggersModule.error;\n\nvar regexModule = require('./regex');\nlib.counterRegex = regexModule.counter;\n\nvar throttleModule = require('./throttle');\nlib.throttle = throttleModule.throttle;\nlib.throttleDone = throttleModule.done;\nlib.clearThrottle = throttleModule.clear;\n\nvar domModule = require('./dom');\nlib.getGraphDiv = domModule.getGraphDiv;\nlib.isPlotDiv = domModule.isPlotDiv;\nlib.removeElement = domModule.removeElement;\nlib.addStyleRule = domModule.addStyleRule;\nlib.addRelatedStyleRule = domModule.addRelatedStyleRule;\nlib.deleteRelatedStyleRule = domModule.deleteRelatedStyleRule;\nlib.getFullTransformMatrix = domModule.getFullTransformMatrix;\nlib.getElementTransformMatrix = domModule.getElementTransformMatrix;\nlib.getElementAndAncestors = domModule.getElementAndAncestors;\nlib.equalDomRects = domModule.equalDomRects;\n\nlib.clearResponsive = require('./clear_responsive');\nlib.preserveDrawingBuffer = require('./preserve_drawing_buffer');\n\nlib.makeTraceGroups = require('./make_trace_groups');\n\nlib._ = require('./localize');\n\nlib.notifier = require('./notifier');\n\nlib.filterUnique = require('./filter_unique');\nlib.filterVisible = require('./filter_visible');\nlib.pushUnique = require('./push_unique');\n\nlib.increment = require('./increment');\n\nlib.cleanNumber = require('./clean_number');\n\nlib.ensureNumber = function ensureNumber(v) {\n if(!isNumeric(v)) return BADNUM;\n v = Number(v);\n return (v > MAX_SAFE || v < MIN_SAFE) ? BADNUM : v;\n};\n\n/**\n * Is v a valid array index? Accepts numeric strings as well as numbers.\n *\n * @param {any} v: the value to test\n * @param {Optional[integer]} len: the array length we are indexing\n *\n * @return {bool}: v is a valid array index\n */\nlib.isIndex = function(v, len) {\n if(len !== undefined && v >= len) return false;\n return isNumeric(v) && (v >= 0) && (v % 1 === 0);\n};\n\nlib.noop = require('./noop');\nlib.identity = require('./identity');\n\n/**\n * create an array of length 'cnt' filled with 'v' at all indices\n *\n * @param {any} v\n * @param {number} cnt\n * @return {array}\n */\nlib.repeat = function(v, cnt) {\n var out = new Array(cnt);\n for(var i = 0; i < cnt; i++) {\n out[i] = v;\n }\n return out;\n};\n\n/**\n * swap x and y of the same attribute in container cont\n * specify attr with a ? in place of x/y\n * you can also swap other things than x/y by providing part1 and part2\n */\nlib.swapAttrs = function(cont, attrList, part1, part2) {\n if(!part1) part1 = 'x';\n if(!part2) part2 = 'y';\n for(var i = 0; i < attrList.length; i++) {\n var attr = attrList[i];\n var xp = lib.nestedProperty(cont, attr.replace('?', part1));\n var yp = lib.nestedProperty(cont, attr.replace('?', part2));\n var temp = xp.get();\n xp.set(yp.get());\n yp.set(temp);\n }\n};\n\n/**\n * SVG painter's algo worked around with reinsertion\n */\nlib.raiseToTop = function raiseToTop(elem) {\n elem.parentNode.appendChild(elem);\n};\n\n/**\n * cancel a possibly pending transition; returned selection may be used by caller\n */\nlib.cancelTransition = function(selection) {\n return selection.transition().duration(0);\n};\n\n// constrain - restrict a number v to be between v0 and v1\nlib.constrain = function(v, v0, v1) {\n if(v0 > v1) return Math.max(v1, Math.min(v0, v));\n return Math.max(v0, Math.min(v1, v));\n};\n\n/**\n * do two bounding boxes from getBoundingClientRect,\n * ie {left,right,top,bottom,width,height}, overlap?\n * takes optional padding pixels\n */\nlib.bBoxIntersect = function(a, b, pad) {\n pad = pad || 0;\n return (a.left <= b.right + pad &&\n b.left <= a.right + pad &&\n a.top <= b.bottom + pad &&\n b.top <= a.bottom + pad);\n};\n\n/*\n * simpleMap: alternative to Array.map that only\n * passes on the element and up to 2 extra args you\n * provide (but not the array index or the whole array)\n *\n * array: the array to map it to\n * func: the function to apply\n * x1, x2: optional extra args\n */\nlib.simpleMap = function(array, func, x1, x2, opts) {\n var len = array.length;\n var out = new Array(len);\n for(var i = 0; i < len; i++) out[i] = func(array[i], x1, x2, opts);\n return out;\n};\n\n/**\n * Random string generator\n *\n * @param {object} existing\n * pass in strings to avoid as keys with truthy values\n * @param {int} bits\n * bits of information in the output string, default 24\n * @param {int} base\n * base of string representation, default 16. Should be a power of 2.\n */\nlib.randstr = function randstr(existing, bits, base, _recursion) {\n if(!base) base = 16;\n if(bits === undefined) bits = 24;\n if(bits <= 0) return '0';\n\n var digits = Math.log(Math.pow(2, bits)) / Math.log(base);\n var res = '';\n var i, b, x;\n\n for(i = 2; digits === Infinity; i *= 2) {\n digits = Math.log(Math.pow(2, bits / i)) / Math.log(base) * i;\n }\n\n var rem = digits - Math.floor(digits);\n\n for(i = 0; i < Math.floor(digits); i++) {\n x = Math.floor(Math.random() * base).toString(base);\n res = x + res;\n }\n\n if(rem) {\n b = Math.pow(base, rem);\n x = Math.floor(Math.random() * b).toString(base);\n res = x + res;\n }\n\n var parsed = parseInt(res, base);\n if((existing && existing[res]) ||\n (parsed !== Infinity && parsed >= Math.pow(2, bits))) {\n if(_recursion > 10) {\n lib.warn('randstr failed uniqueness');\n return res;\n }\n return randstr(existing, bits, base, (_recursion || 0) + 1);\n } else return res;\n};\n\nlib.OptionControl = function(opt, optname) {\n /*\n * An environment to contain all option setters and\n * getters that collectively modify opts.\n *\n * You can call up opts from any function in new object\n * as this.optname || this.opt\n *\n * See FitOpts for example of usage\n */\n if(!opt) opt = {};\n if(!optname) optname = 'opt';\n\n var self = {};\n self.optionList = [];\n\n self._newoption = function(optObj) {\n optObj[optname] = opt;\n self[optObj.name] = optObj;\n self.optionList.push(optObj);\n };\n\n self['_' + optname] = opt;\n return self;\n};\n\n/**\n * lib.smooth: smooth arrayIn by convolving with\n * a hann window with given full width at half max\n * bounce the ends in, so the output has the same length as the input\n */\nlib.smooth = function(arrayIn, FWHM) {\n FWHM = Math.round(FWHM) || 0; // only makes sense for integers\n if(FWHM < 2) return arrayIn;\n\n var alen = arrayIn.length;\n var alen2 = 2 * alen;\n var wlen = 2 * FWHM - 1;\n var w = new Array(wlen);\n var arrayOut = new Array(alen);\n var i;\n var j;\n var k;\n var v;\n\n // first make the window array\n for(i = 0; i < wlen; i++) {\n w[i] = (1 - Math.cos(Math.PI * (i + 1) / FWHM)) / (2 * FWHM);\n }\n\n // now do the convolution\n for(i = 0; i < alen; i++) {\n v = 0;\n for(j = 0; j < wlen; j++) {\n k = i + j + 1 - FWHM;\n\n // multibounce\n if(k < -alen) k -= alen2 * Math.round(k / alen2);\n else if(k >= alen2) k -= alen2 * Math.floor(k / alen2);\n\n // single bounce\n if(k < 0) k = - 1 - k;\n else if(k >= alen) k = alen2 - 1 - k;\n\n v += arrayIn[k] * w[j];\n }\n arrayOut[i] = v;\n }\n\n return arrayOut;\n};\n\n/**\n * syncOrAsync: run a sequence of functions synchronously\n * as long as its returns are not promises (ie have no .then)\n * includes one argument arg to send to all functions...\n * this is mainly just to prevent us having to make wrapper functions\n * when the only purpose of the wrapper is to reference gd\n * and a final step to be executed at the end\n * TODO: if there's an error and everything is sync,\n * this doesn't happen yet because we want to make sure\n * that it gets reported\n */\nlib.syncOrAsync = function(sequence, arg, finalStep) {\n var ret, fni;\n\n function continueAsync() {\n return lib.syncOrAsync(sequence, arg, finalStep);\n }\n\n while(sequence.length) {\n fni = sequence.splice(0, 1)[0];\n ret = fni(arg);\n\n if(ret && ret.then) {\n return ret.then(continueAsync);\n }\n }\n\n return finalStep && finalStep(arg);\n};\n\n\n/**\n * Helper to strip trailing slash, from\n * http://stackoverflow.com/questions/6680825/return-string-without-trailing-slash\n */\nlib.stripTrailingSlash = function(str) {\n if(str.substr(-1) === '/') return str.substr(0, str.length - 1);\n return str;\n};\n\nlib.noneOrAll = function(containerIn, containerOut, attrList) {\n /**\n * some attributes come together, so if you have one of them\n * in the input, you should copy the default values of the others\n * to the input as well.\n */\n if(!containerIn) return;\n\n var hasAny = false;\n var hasAll = true;\n var i;\n var val;\n\n for(i = 0; i < attrList.length; i++) {\n val = containerIn[attrList[i]];\n if(val !== undefined && val !== null) hasAny = true;\n else hasAll = false;\n }\n\n if(hasAny && !hasAll) {\n for(i = 0; i < attrList.length; i++) {\n containerIn[attrList[i]] = containerOut[attrList[i]];\n }\n }\n};\n\n/** merges calcdata field (given by cdAttr) with traceAttr values\n *\n * N.B. Loop over minimum of cd.length and traceAttr.length\n * i.e. it does not try to fill in beyond traceAttr.length-1\n *\n * @param {array} traceAttr : trace attribute\n * @param {object} cd : calcdata trace\n * @param {string} cdAttr : calcdata key\n */\nlib.mergeArray = function(traceAttr, cd, cdAttr, fn) {\n var hasFn = typeof fn === 'function';\n if(lib.isArrayOrTypedArray(traceAttr)) {\n var imax = Math.min(traceAttr.length, cd.length);\n for(var i = 0; i < imax; i++) {\n var v = traceAttr[i];\n cd[i][cdAttr] = hasFn ? fn(v) : v;\n }\n }\n};\n\n// cast numbers to positive numbers, returns 0 if not greater than 0\nlib.mergeArrayCastPositive = function(traceAttr, cd, cdAttr) {\n return lib.mergeArray(traceAttr, cd, cdAttr, function(v) {\n var w = +v;\n return !isFinite(w) ? 0 : w > 0 ? w : 0;\n });\n};\n\n/** fills calcdata field (given by cdAttr) with traceAttr values\n * or function of traceAttr values (e.g. some fallback)\n *\n * N.B. Loops over all cd items.\n *\n * @param {array} traceAttr : trace attribute\n * @param {object} cd : calcdata trace\n * @param {string} cdAttr : calcdata key\n * @param {function} [fn] : optional function to apply to each array item\n */\nlib.fillArray = function(traceAttr, cd, cdAttr, fn) {\n fn = fn || lib.identity;\n\n if(lib.isArrayOrTypedArray(traceAttr)) {\n for(var i = 0; i < cd.length; i++) {\n cd[i][cdAttr] = fn(traceAttr[i]);\n }\n }\n};\n\n/** Handler for trace-wide vs per-point options\n *\n * @param {object} trace : (full) trace object\n * @param {number} ptNumber : index of the point in question\n * @param {string} astr : attribute string\n * @param {function} [fn] : optional function to apply to each array item\n *\n * @return {any}\n */\nlib.castOption = function(trace, ptNumber, astr, fn) {\n fn = fn || lib.identity;\n\n var val = lib.nestedProperty(trace, astr).get();\n\n if(lib.isArrayOrTypedArray(val)) {\n if(Array.isArray(ptNumber) && lib.isArrayOrTypedArray(val[ptNumber[0]])) {\n return fn(val[ptNumber[0]][ptNumber[1]]);\n } else {\n return fn(val[ptNumber]);\n }\n } else {\n return val;\n }\n};\n\n/** Extract option from calcdata item, correctly falling back to\n * trace value if not found.\n *\n * @param {object} calcPt : calcdata[i][j] item\n * @param {object} trace : (full) trace object\n * @param {string} calcKey : calcdata key\n * @param {string} traceKey : aka trace attribute string\n * @return {any}\n */\nlib.extractOption = function(calcPt, trace, calcKey, traceKey) {\n if(calcKey in calcPt) return calcPt[calcKey];\n\n // fallback to trace value,\n // must check if value isn't itself an array\n // which means the trace attribute has a corresponding\n // calcdata key, but its value is falsy\n var traceVal = lib.nestedProperty(trace, traceKey).get();\n if(!Array.isArray(traceVal)) return traceVal;\n};\n\nfunction makePtIndex2PtNumber(indexToPoints) {\n var ptIndex2ptNumber = {};\n for(var k in indexToPoints) {\n var pts = indexToPoints[k];\n for(var j = 0; j < pts.length; j++) {\n ptIndex2ptNumber[pts[j]] = +k;\n }\n }\n return ptIndex2ptNumber;\n}\n\n/** Tag selected calcdata items\n *\n * N.B. note that point 'index' corresponds to input data array index\n * whereas 'number' is its post-transform version.\n *\n * @param {array} calcTrace\n * @param {object} trace\n * - selectedpoints {array}\n * - _indexToPoints {object}\n * @param {ptNumber2cdIndex} ptNumber2cdIndex (optional)\n * optional map object for trace types that do not have 1-to-1 point number to\n * calcdata item index correspondence (e.g. histogram)\n */\nlib.tagSelected = function(calcTrace, trace, ptNumber2cdIndex) {\n var selectedpoints = trace.selectedpoints;\n var indexToPoints = trace._indexToPoints;\n var ptIndex2ptNumber;\n\n // make pt index-to-number map object, which takes care of transformed traces\n if(indexToPoints) {\n ptIndex2ptNumber = makePtIndex2PtNumber(indexToPoints);\n }\n\n function isCdIndexValid(v) {\n return v !== undefined && v < calcTrace.length;\n }\n\n for(var i = 0; i < selectedpoints.length; i++) {\n var ptIndex = selectedpoints[i];\n\n if(lib.isIndex(ptIndex) ||\n (lib.isArrayOrTypedArray(ptIndex) && lib.isIndex(ptIndex[0]) && lib.isIndex(ptIndex[1]))\n ) {\n var ptNumber = ptIndex2ptNumber ? ptIndex2ptNumber[ptIndex] : ptIndex;\n var cdIndex = ptNumber2cdIndex ? ptNumber2cdIndex[ptNumber] : ptNumber;\n\n if(isCdIndexValid(cdIndex)) {\n calcTrace[cdIndex].selected = 1;\n }\n }\n }\n};\n\nlib.selIndices2selPoints = function(trace) {\n var selectedpoints = trace.selectedpoints;\n var indexToPoints = trace._indexToPoints;\n\n if(indexToPoints) {\n var ptIndex2ptNumber = makePtIndex2PtNumber(indexToPoints);\n var out = [];\n\n for(var i = 0; i < selectedpoints.length; i++) {\n var ptIndex = selectedpoints[i];\n if(lib.isIndex(ptIndex)) {\n var ptNumber = ptIndex2ptNumber[ptIndex];\n if(lib.isIndex(ptNumber)) {\n out.push(ptNumber);\n }\n }\n }\n\n return out;\n } else {\n return selectedpoints;\n }\n};\n\n/** Returns target as set by 'target' transform attribute\n *\n * @param {object} trace : full trace object\n * @param {object} transformOpts : transform option object\n * - target (string} :\n * either an attribute string referencing an array in the trace object, or\n * a set array.\n *\n * @return {array or false} : the target array (NOT a copy!!) or false if invalid\n */\nlib.getTargetArray = function(trace, transformOpts) {\n var target = transformOpts.target;\n\n if(typeof target === 'string' && target) {\n var array = lib.nestedProperty(trace, target).get();\n return lib.isArrayOrTypedArray(array) ? array : false;\n } else if(lib.isArrayOrTypedArray(target)) {\n return target;\n }\n\n return false;\n};\n\n/**\n * modified version of jQuery's extend to strip out private objs and functions,\n * and cut arrays down to first or 1 elements\n * because extend-like algorithms are hella slow\n * obj2 is assumed to already be clean of these things (including no arrays)\n */\nfunction minExtend(obj1, obj2, opt) {\n var objOut = {};\n if(typeof obj2 !== 'object') obj2 = {};\n\n var arrayLen = opt === 'pieLike' ? -1 : 3;\n\n var keys = Object.keys(obj1);\n var i, k, v;\n\n for(i = 0; i < keys.length; i++) {\n k = keys[i];\n v = obj1[k];\n if(k.charAt(0) === '_' || typeof v === 'function') continue;\n else if(k === 'module') objOut[k] = v;\n else if(Array.isArray(v)) {\n if(k === 'colorscale' || arrayLen === -1) {\n objOut[k] = v.slice();\n } else {\n objOut[k] = v.slice(0, arrayLen);\n }\n } else if(lib.isTypedArray(v)) {\n if(arrayLen === -1) {\n objOut[k] = v.subarray();\n } else {\n objOut[k] = v.subarray(0, arrayLen);\n }\n } else if(v && (typeof v === 'object')) objOut[k] = minExtend(obj1[k], obj2[k], opt);\n else objOut[k] = v;\n }\n\n keys = Object.keys(obj2);\n for(i = 0; i < keys.length; i++) {\n k = keys[i];\n v = obj2[k];\n if(typeof v !== 'object' || !(k in objOut) || typeof objOut[k] !== 'object') {\n objOut[k] = v;\n }\n }\n\n return objOut;\n}\nlib.minExtend = minExtend;\n\nlib.titleCase = function(s) {\n return s.charAt(0).toUpperCase() + s.substr(1);\n};\n\nlib.containsAny = function(s, fragments) {\n for(var i = 0; i < fragments.length; i++) {\n if(s.indexOf(fragments[i]) !== -1) return true;\n }\n return false;\n};\n\nlib.isIE = function() {\n return typeof window.navigator.msSaveBlob !== 'undefined';\n};\n\nvar IS_SAFARI_REGEX = /Version\\/[\\d\\.]+.*Safari/;\nlib.isSafari = function() {\n return IS_SAFARI_REGEX.test(window.navigator.userAgent);\n};\n\nvar IS_IOS_REGEX = /iPad|iPhone|iPod/;\nlib.isIOS = function() {\n return IS_IOS_REGEX.test(window.navigator.userAgent);\n};\n\nvar FIREFOX_VERSION_REGEX = /Firefox\\/(\\d+)\\.\\d+/;\nlib.getFirefoxVersion = function() {\n var match = FIREFOX_VERSION_REGEX.exec(window.navigator.userAgent);\n if(match && match.length === 2) {\n var versionInt = parseInt(match[1]);\n if(!isNaN(versionInt)) {\n return versionInt;\n }\n }\n return null;\n};\n\nlib.isD3Selection = function(obj) {\n return obj instanceof d3.selection;\n};\n\n/**\n * Append element to DOM only if not present.\n *\n * @param {d3 selection} parent : parent selection of the element in question\n * @param {string} nodeType : node type of element to append\n * @param {string} className (optional) : class name of element in question\n * @param {fn} enterFn (optional) : optional fn applied to entering elements only\n * @return {d3 selection} selection of new layer\n *\n * Previously, we were using the following pattern:\n *\n * ```\n * var sel = parent.selectAll('.' + className)\n * .data([0]);\n *\n * sel.enter().append(nodeType)\n * .classed(className, true);\n *\n * return sel;\n * ```\n *\n * in numerous places in our codebase to achieve the same behavior.\n *\n * The logic below performs much better, mostly as we are using\n * `.select` instead `.selectAll` that is `querySelector` instead of\n * `querySelectorAll`.\n *\n */\nlib.ensureSingle = function(parent, nodeType, className, enterFn) {\n var sel = parent.select(nodeType + (className ? '.' + className : ''));\n if(sel.size()) return sel;\n\n var layer = parent.append(nodeType);\n if(className) layer.classed(className, true);\n if(enterFn) layer.call(enterFn);\n\n return layer;\n};\n\n/**\n * Same as Lib.ensureSingle, but using id as selector.\n * This version is mostly used for clipPath nodes.\n *\n * @param {d3 selection} parent : parent selection of the element in question\n * @param {string} nodeType : node type of element to append\n * @param {string} id : id of element in question\n * @param {fn} enterFn (optional) : optional fn applied to entering elements only\n * @return {d3 selection} selection of new layer\n */\nlib.ensureSingleById = function(parent, nodeType, id, enterFn) {\n var sel = parent.select(nodeType + '#' + id);\n if(sel.size()) return sel;\n\n var layer = parent.append(nodeType).attr('id', id);\n if(enterFn) layer.call(enterFn);\n\n return layer;\n};\n\n/**\n * Converts a string path to an object.\n *\n * When given a string containing an array element, it will create a `null`\n * filled array of the given size.\n *\n * @example\n * lib.objectFromPath('nested.test[2].path', 'value');\n * // returns { nested: { test: [null, null, { path: 'value' }]}\n *\n * @param {string} path to nested value\n * @param {*} any value to be set\n *\n * @return {Object} the constructed object with a full nested path\n */\nlib.objectFromPath = function(path, value) {\n var keys = path.split('.');\n var tmpObj;\n var obj = tmpObj = {};\n\n for(var i = 0; i < keys.length; i++) {\n var key = keys[i];\n var el = null;\n\n var parts = keys[i].match(/(.*)\\[([0-9]+)\\]/);\n\n if(parts) {\n key = parts[1];\n el = parts[2];\n\n tmpObj = tmpObj[key] = [];\n\n if(i === keys.length - 1) {\n tmpObj[el] = value;\n } else {\n tmpObj[el] = {};\n }\n\n tmpObj = tmpObj[el];\n } else {\n if(i === keys.length - 1) {\n tmpObj[key] = value;\n } else {\n tmpObj[key] = {};\n }\n\n tmpObj = tmpObj[key];\n }\n }\n\n return obj;\n};\n\n/**\n * Iterate through an object in-place, converting dotted properties to objects.\n *\n * Examples:\n *\n * lib.expandObjectPaths({'nested.test.path': 'value'});\n * => { nested: { test: {path: 'value'}}}\n *\n * It also handles array notation, e.g.:\n *\n * lib.expandObjectPaths({'foo[1].bar': 'value'});\n * => { foo: [null, {bar: value}] }\n *\n * It handles merges the results when two properties are specified in parallel:\n *\n * lib.expandObjectPaths({'foo[1].bar': 10, 'foo[0].bar': 20});\n * => { foo: [{bar: 10}, {bar: 20}] }\n *\n * It does NOT, however, merge multiple multiply-nested arrays::\n *\n * lib.expandObjectPaths({'marker[1].range[1]': 5, 'marker[1].range[0]': 4})\n * => { marker: [null, {range: 4}] }\n */\n\n// Store this to avoid recompiling regex on *every* prop since this may happen many\n// many times for animations. Could maybe be inside the function. Not sure about\n// scoping vs. recompilation tradeoff, but at least it's not just inlining it into\n// the inner loop.\nvar dottedPropertyRegex = /^([^\\[\\.]+)\\.(.+)?/;\nvar indexedPropertyRegex = /^([^\\.]+)\\[([0-9]+)\\](\\.)?(.+)?/;\n\nfunction notValid(prop) {\n // guard against polluting __proto__ and other internals getters and setters\n return prop.slice(0, 2) === '__';\n}\n\nlib.expandObjectPaths = function(data) {\n var match, key, prop, datum, idx, dest, trailingPath;\n if(typeof data === 'object' && !Array.isArray(data)) {\n for(key in data) {\n if(data.hasOwnProperty(key)) {\n if((match = key.match(dottedPropertyRegex))) {\n datum = data[key];\n prop = match[1];\n if(notValid(prop)) continue;\n\n delete data[key];\n\n data[prop] = lib.extendDeepNoArrays(data[prop] || {}, lib.objectFromPath(key, lib.expandObjectPaths(datum))[prop]);\n } else if((match = key.match(indexedPropertyRegex))) {\n datum = data[key];\n\n prop = match[1];\n if(notValid(prop)) continue;\n\n idx = parseInt(match[2]);\n\n delete data[key];\n\n data[prop] = data[prop] || [];\n\n if(match[3] === '.') {\n // This is the case where theere are subsequent properties into which\n // we must recurse, e.g. transforms[0].value\n trailingPath = match[4];\n dest = data[prop][idx] = data[prop][idx] || {};\n\n // NB: Extend deep no arrays prevents this from working on multiple\n // nested properties in the same object, e.g.\n //\n // {\n // foo[0].bar[1].range\n // foo[0].bar[0].range\n // }\n //\n // In this case, the extendDeepNoArrays will overwrite one array with\n // the other, so that both properties *will not* be present in the\n // result. Fixing this would require a more intelligent tracking\n // of changes and merging than extendDeepNoArrays currently accomplishes.\n lib.extendDeepNoArrays(dest, lib.objectFromPath(trailingPath, lib.expandObjectPaths(datum)));\n } else {\n // This is the case where this property is the end of the line,\n // e.g. xaxis.range[0]\n\n if(notValid(prop)) continue;\n data[prop][idx] = lib.expandObjectPaths(datum);\n }\n } else {\n if(notValid(key)) continue;\n data[key] = lib.expandObjectPaths(data[key]);\n }\n }\n }\n }\n\n return data;\n};\n\n/**\n * Converts value to string separated by the provided separators.\n *\n * @example\n * lib.numSeparate(2016, '.,');\n * // returns '2016'\n *\n * @example\n * lib.numSeparate(3000, '.,', true);\n * // returns '3,000'\n *\n * @example\n * lib.numSeparate(1234.56, '|,')\n * // returns '1,234|56'\n *\n * @param {string|number} value the value to be converted\n * @param {string} separators string of decimal, then thousands separators\n * @param {boolean} separatethousands boolean, 4-digit integers are separated if true\n *\n * @return {string} the value that has been separated\n */\nlib.numSeparate = function(value, separators, separatethousands) {\n if(!separatethousands) separatethousands = false;\n\n if(typeof separators !== 'string' || separators.length === 0) {\n throw new Error('Separator string required for formatting!');\n }\n\n if(typeof value === 'number') {\n value = String(value);\n }\n\n var thousandsRe = /(\\d+)(\\d{3})/;\n var decimalSep = separators.charAt(0);\n var thouSep = separators.charAt(1);\n\n var x = value.split('.');\n var x1 = x[0];\n var x2 = x.length > 1 ? decimalSep + x[1] : '';\n\n // Years are ignored for thousands separators\n if(thouSep && (x.length > 1 || x1.length > 4 || separatethousands)) {\n while(thousandsRe.test(x1)) {\n x1 = x1.replace(thousandsRe, '$1' + thouSep + '$2');\n }\n }\n\n return x1 + x2;\n};\n\nlib.TEMPLATE_STRING_REGEX = /%{([^\\s%{}:]*)([:|\\|][^}]*)?}/g;\nvar SIMPLE_PROPERTY_REGEX = /^\\w*$/;\n\n/**\n * Substitute values from an object into a string\n *\n * Examples:\n * Lib.templateString('name: %{trace}', {trace: 'asdf'}) --> 'name: asdf'\n * Lib.templateString('name: %{trace[0].name}', {trace: [{name: 'asdf'}]}) --> 'name: asdf'\n *\n * @param {string} input string containing %{...} template strings\n * @param {obj} data object containing substitution values\n *\n * @return {string} templated string\n */\nlib.templateString = function(string, obj) {\n // Not all that useful, but cache nestedProperty instantiation\n // just in case it speeds things up *slightly*:\n var getterCache = {};\n\n return string.replace(lib.TEMPLATE_STRING_REGEX, function(dummy, key) {\n var v;\n if(SIMPLE_PROPERTY_REGEX.test(key)) {\n v = obj[key];\n } else {\n getterCache[key] = getterCache[key] || lib.nestedProperty(obj, key).get;\n v = getterCache[key]();\n }\n return lib.isValidTextValue(v) ? v : '';\n });\n};\n\nvar hovertemplateWarnings = {\n max: 10,\n count: 0,\n name: 'hovertemplate'\n};\nlib.hovertemplateString = function() {\n return templateFormatString.apply(hovertemplateWarnings, arguments);\n};\n\nvar texttemplateWarnings = {\n max: 10,\n count: 0,\n name: 'texttemplate'\n};\nlib.texttemplateString = function() {\n return templateFormatString.apply(texttemplateWarnings, arguments);\n};\n\n// Regex for parsing multiplication and division operations applied to a template key\n// Used for shape.label.texttemplate\n// Matches a key name (non-whitespace characters), followed by a * or / character, followed by a number\n// For example, the following strings are matched: `x0*2`, `slope/1.60934`, `y1*2.54`\nvar MULT_DIV_REGEX = /^(\\S+)([\\*\\/])(-?\\d+(\\.\\d+)?)$/;\nfunction multDivParser(inputStr) {\n var match = inputStr.match(MULT_DIV_REGEX);\n if(match) return { key: match[1], op: match[2], number: Number(match[3]) };\n return { key: inputStr, op: null, number: null };\n}\nvar texttemplateWarningsForShapes = {\n max: 10,\n count: 0,\n name: 'texttemplate',\n parseMultDiv: true,\n};\nlib.texttemplateStringForShapes = function() {\n return templateFormatString.apply(texttemplateWarningsForShapes, arguments);\n};\n\nvar TEMPLATE_STRING_FORMAT_SEPARATOR = /^[:|\\|]/;\n/**\n * Substitute values from an object into a string and optionally formats them using d3-format,\n * or fallback to associated labels.\n *\n * Examples:\n * Lib.hovertemplateString('name: %{trace}', {trace: 'asdf'}) --> 'name: asdf'\n * Lib.hovertemplateString('name: %{trace[0].name}', {trace: [{name: 'asdf'}]}) --> 'name: asdf'\n * Lib.hovertemplateString('price: %{y:$.2f}', {y: 1}) --> 'price: $1.00'\n *\n * @param {string} input string containing %{...:...} template strings\n * @param {obj} data object containing fallback text when no formatting is specified, ex.: {yLabel: 'formattedYValue'}\n * @param {obj} d3 locale\n * @param {obj} data objects containing substitution values\n *\n * @return {string} templated string\n */\nfunction templateFormatString(string, labels, d3locale) {\n var opts = this;\n var args = arguments;\n if(!labels) labels = {};\n // Not all that useful, but cache nestedProperty instantiation\n // just in case it speeds things up *slightly*:\n var getterCache = {};\n\n return string.replace(lib.TEMPLATE_STRING_REGEX, function(match, rawKey, format) {\n var isOther =\n rawKey === 'xother' ||\n rawKey === 'yother';\n\n var isSpaceOther =\n rawKey === '_xother' ||\n rawKey === '_yother';\n\n var isSpaceOtherSpace =\n rawKey === '_xother_' ||\n rawKey === '_yother_';\n\n var isOtherSpace =\n rawKey === 'xother_' ||\n rawKey === 'yother_';\n\n var hasOther = isOther || isSpaceOther || isOtherSpace || isSpaceOtherSpace;\n\n var key = rawKey;\n if(isSpaceOther || isSpaceOtherSpace) key = key.substring(1);\n if(isOtherSpace || isSpaceOtherSpace) key = key.substring(0, key.length - 1);\n\n // Shape labels support * and / operators in template string\n // Parse these if the parseMultDiv param is set to true\n var parsedOp = null;\n var parsedNumber = null;\n if(opts.parseMultDiv) {\n var _match = multDivParser(key);\n key = _match.key;\n parsedOp = _match.op;\n parsedNumber = _match.number;\n }\n\n var value;\n if(hasOther) {\n value = labels[key];\n if(value === undefined) return '';\n } else {\n var obj, i;\n for(i = 3; i < args.length; i++) {\n obj = args[i];\n if(!obj) continue;\n if(obj.hasOwnProperty(key)) {\n value = obj[key];\n break;\n }\n\n if(!SIMPLE_PROPERTY_REGEX.test(key)) {\n value = lib.nestedProperty(obj, key).get();\n value = getterCache[key] || lib.nestedProperty(obj, key).get();\n if(value) getterCache[key] = value;\n }\n if(value !== undefined) break;\n }\n }\n\n // Apply mult/div operation (if applicable)\n if(value !== undefined) {\n if(parsedOp === '*') value *= parsedNumber;\n if(parsedOp === '/') value /= parsedNumber;\n }\n\n if(value === undefined && opts) {\n if(opts.count < opts.max) {\n lib.warn('Variable \\'' + key + '\\' in ' + opts.name + ' could not be found!');\n value = match;\n }\n\n if(opts.count === opts.max) {\n lib.warn('Too many ' + opts.name + ' warnings - additional warnings will be suppressed');\n }\n opts.count++;\n\n return match;\n }\n\n if(format) {\n var fmt;\n if(format[0] === ':') {\n fmt = d3locale ? d3locale.numberFormat : lib.numberFormat;\n if(value !== '') { // e.g. skip missing data on heatmap\n value = fmt(format.replace(TEMPLATE_STRING_FORMAT_SEPARATOR, ''))(value);\n }\n }\n\n if(format[0] === '|') {\n fmt = d3locale ? d3locale.timeFormat : utcFormat;\n var ms = lib.dateTime2ms(value);\n value = lib.formatDate(ms, format.replace(TEMPLATE_STRING_FORMAT_SEPARATOR, ''), false, fmt);\n }\n } else {\n var keyLabel = key + 'Label';\n if(labels.hasOwnProperty(keyLabel)) value = labels[keyLabel];\n }\n\n if(hasOther) {\n value = '(' + value + ')';\n if(isSpaceOther || isSpaceOtherSpace) value = ' ' + value;\n if(isOtherSpace || isSpaceOtherSpace) value = value + ' ';\n }\n\n return value;\n });\n}\n\n/*\n * alphanumeric string sort, tailored for subplot IDs like scene2, scene10, x10y13 etc\n */\nvar char0 = 48;\nvar char9 = 57;\nlib.subplotSort = function(a, b) {\n var l = Math.min(a.length, b.length) + 1;\n var numA = 0;\n var numB = 0;\n for(var i = 0; i < l; i++) {\n var charA = a.charCodeAt(i) || 0;\n var charB = b.charCodeAt(i) || 0;\n var isNumA = charA >= char0 && charA <= char9;\n var isNumB = charB >= char0 && charB <= char9;\n\n if(isNumA) numA = 10 * numA + charA - char0;\n if(isNumB) numB = 10 * numB + charB - char0;\n\n if(!isNumA || !isNumB) {\n if(numA !== numB) return numA - numB;\n if(charA !== charB) return charA - charB;\n }\n }\n return numB - numA;\n};\n\n// repeatable pseudorandom generator\nvar randSeed = 2000000000;\n\nlib.seedPseudoRandom = function() {\n randSeed = 2000000000;\n};\n\nlib.pseudoRandom = function() {\n var lastVal = randSeed;\n randSeed = (69069 * randSeed + 1) % 4294967296;\n // don't let consecutive vals be too close together\n // gets away from really trying to be random, in favor of better local uniformity\n if(Math.abs(randSeed - lastVal) < 429496729) return lib.pseudoRandom();\n return randSeed / 4294967296;\n};\n\n\n/** Fill hover 'pointData' container with 'correct' hover text value\n *\n * - If trace hoverinfo contains a 'text' flag and hovertext is not set,\n * the text elements will be seen in the hover labels.\n *\n * - If trace hoverinfo contains a 'text' flag and hovertext is set,\n * hovertext takes precedence over text\n * i.e. the hoverinfo elements will be seen in the hover labels\n *\n * @param {object} calcPt\n * @param {object} trace\n * @param {object || array} contOut (mutated here)\n */\nlib.fillText = function(calcPt, trace, contOut) {\n var fill = Array.isArray(contOut) ?\n function(v) { contOut.push(v); } :\n function(v) { contOut.text = v; };\n\n var htx = lib.extractOption(calcPt, trace, 'htx', 'hovertext');\n if(lib.isValidTextValue(htx)) return fill(htx);\n\n var tx = lib.extractOption(calcPt, trace, 'tx', 'text');\n if(lib.isValidTextValue(tx)) return fill(tx);\n};\n\n// accept all truthy values and 0 (which gets cast to '0' in the hover labels)\nlib.isValidTextValue = function(v) {\n return v || v === 0;\n};\n\n/**\n * @param {number} ratio\n * @param {number} n (number of decimal places)\n */\nlib.formatPercent = function(ratio, n) {\n n = n || 0;\n var str = (Math.round(100 * ratio * Math.pow(10, n)) * Math.pow(0.1, n)).toFixed(n) + '%';\n for(var i = 0; i < n; i++) {\n if(str.indexOf('.') !== -1) {\n str = str.replace('0%', '%');\n str = str.replace('.%', '%');\n }\n }\n return str;\n};\n\nlib.isHidden = function(gd) {\n var display = window.getComputedStyle(gd).display;\n return !display || display === 'none';\n};\n\nlib.strTranslate = function(x, y) {\n return (x || y) ? 'translate(' + x + ',' + y + ')' : '';\n};\n\nlib.strRotate = function(a) {\n return a ? 'rotate(' + a + ')' : '';\n};\n\nlib.strScale = function(s) {\n return s !== 1 ? 'scale(' + s + ')' : '';\n};\n\n/** Return transform text for bar bar-like rectangles and pie-like slices\n * @param {object} transform\n * - targetX: desired position on the x-axis\n * - targetY: desired position on the y-axis\n * - textX: text middle position on the x-axis\n * - textY: text middle position on the y-axis\n * - anchorX: (optional) text anchor position on the x-axis (computed from textX), zero for middle anchor\n * - anchorY: (optional) text anchor position on the y-axis (computed from textY), zero for middle anchor\n * - scale: (optional) scale applied after translate\n * - rotate: (optional) rotation applied after scale\n * - noCenter: when defined no extra arguments needed in rotation\n */\nlib.getTextTransform = function(transform) {\n var noCenter = transform.noCenter;\n var textX = transform.textX;\n var textY = transform.textY;\n var targetX = transform.targetX;\n var targetY = transform.targetY;\n var anchorX = transform.anchorX || 0;\n var anchorY = transform.anchorY || 0;\n var rotate = transform.rotate;\n var scale = transform.scale;\n if(!scale) scale = 0;\n else if(scale > 1) scale = 1;\n\n return (\n lib.strTranslate(\n targetX - scale * (textX + anchorX),\n targetY - scale * (textY + anchorY)\n ) +\n lib.strScale(scale) +\n (rotate ?\n 'rotate(' + rotate +\n (noCenter ? '' : ' ' + textX + ' ' + textY) +\n ')' : ''\n )\n );\n};\n\nlib.setTransormAndDisplay = function(s, transform) {\n s.attr('transform', lib.getTextTransform(transform));\n s.style('display', transform.scale ? null : 'none');\n};\n\nlib.ensureUniformFontSize = function(gd, baseFont) {\n var out = lib.extendFlat({}, baseFont);\n out.size = Math.max(\n baseFont.size,\n gd._fullLayout.uniformtext.minsize || 0\n );\n return out;\n};\n\n/**\n * provide a human-readable list e.g. \"A, B, C and D\" with an ending separator\n *\n * @param {array} arr : the array to join\n * @param {string} mainSeparator : main separator\n * @param {string} lastSeparator : last separator\n *\n * @return {string} : joined list\n */\nlib.join2 = function(arr, mainSeparator, lastSeparator) {\n var len = arr.length;\n if(len > 1) {\n return arr.slice(0, -1).join(mainSeparator) + lastSeparator + arr[len - 1];\n }\n return arr.join(mainSeparator);\n};\n\nlib.bigFont = function(size) {\n return Math.round(1.2 * size);\n};\n\nvar firefoxVersion = lib.getFirefoxVersion();\n// see https://bugzilla.mozilla.org/show_bug.cgi?id=1684973\nvar isProblematicFirefox = firefoxVersion !== null && firefoxVersion < 86;\n\n/**\n * Return the mouse position from the last event registered by D3.\n * @returns An array with two numbers, representing the x and y coordinates of the mouse pointer\n * at the event relative to the targeted node.\n */\nlib.getPositionFromD3Event = function() {\n if(isProblematicFirefox) {\n // layerX and layerY are non-standard, so we only fallback to them when we have to:\n return [\n d3.event.layerX,\n d3.event.layerY\n ];\n } else {\n return [\n d3.event.offsetX,\n d3.event.offsetY\n ];\n }\n};\n","'use strict';\n\n// more info: http://stackoverflow.com/questions/18531624/isplainobject-thing\nmodule.exports = function isPlainObject(obj) {\n // We need to be a little less strict in the `imagetest` container because\n // of how async image requests are handled.\n //\n // N.B. isPlainObject(new Constructor()) will return true in `imagetest`\n if(window && window.process && window.process.versions) {\n return Object.prototype.toString.call(obj) === '[object Object]';\n }\n\n return (\n Object.prototype.toString.call(obj) === '[object Object]' &&\n Object.getPrototypeOf(obj).hasOwnProperty('hasOwnProperty')\n );\n};\n","'use strict';\n\nvar nestedProperty = require('./nested_property');\n\nvar SIMPLE_PROPERTY_REGEX = /^\\w*$/;\n\n// bitmask for deciding what's updated. Sometimes the name needs to be updated,\n// sometimes the value needs to be updated, and sometimes both do. This is just\n// a simple way to track what's updated such that it's a simple OR operation to\n// assimilate new updates.\n//\n// The only exception is the UNSET bit that tracks when we need to explicitly\n// unset and remove the property. This concrn arises because of the special\n// way in which nestedProperty handles null/undefined. When you specify `null`,\n// it prunes any unused items in the tree. I ran into some issues with it getting\n// null vs undefined confused, so UNSET is just a bit that forces the property\n// update to send `null`, removing the property explicitly rather than setting\n// it to undefined.\nvar NONE = 0;\nvar NAME = 1;\nvar VALUE = 2;\nvar BOTH = 3;\nvar UNSET = 4;\n\nmodule.exports = function keyedContainer(baseObj, path, keyName, valueName) {\n keyName = keyName || 'name';\n valueName = valueName || 'value';\n var i, arr, baseProp;\n var changeTypes = {};\n\n if(path && path.length) {\n baseProp = nestedProperty(baseObj, path);\n arr = baseProp.get();\n } else {\n arr = baseObj;\n }\n\n path = path || '';\n\n // Construct an index:\n var indexLookup = {};\n if(arr) {\n for(i = 0; i < arr.length; i++) {\n indexLookup[arr[i][keyName]] = i;\n }\n }\n\n var isSimpleValueProp = SIMPLE_PROPERTY_REGEX.test(valueName);\n\n var obj = {\n set: function(name, value) {\n var changeType = value === null ? UNSET : NONE;\n\n // create the base array if necessary\n if(!arr) {\n if(!baseProp || changeType === UNSET) return;\n\n arr = [];\n baseProp.set(arr);\n }\n\n var idx = indexLookup[name];\n if(idx === undefined) {\n if(changeType === UNSET) return;\n\n changeType = changeType | BOTH;\n idx = arr.length;\n indexLookup[name] = idx;\n } else if(value !== (isSimpleValueProp ? arr[idx][valueName] : nestedProperty(arr[idx], valueName).get())) {\n changeType = changeType | VALUE;\n }\n\n var newValue = arr[idx] = arr[idx] || {};\n newValue[keyName] = name;\n\n if(isSimpleValueProp) {\n newValue[valueName] = value;\n } else {\n nestedProperty(newValue, valueName).set(value);\n }\n\n // If it's not an unset, force that bit to be unset. This is all related to the fact\n // that undefined and null are a bit specially implemented in nestedProperties.\n if(value !== null) {\n changeType = changeType & ~UNSET;\n }\n\n changeTypes[idx] = changeTypes[idx] | changeType;\n\n return obj;\n },\n get: function(name) {\n if(!arr) return;\n\n var idx = indexLookup[name];\n\n if(idx === undefined) {\n return undefined;\n } else if(isSimpleValueProp) {\n return arr[idx][valueName];\n } else {\n return nestedProperty(arr[idx], valueName).get();\n }\n },\n rename: function(name, newName) {\n var idx = indexLookup[name];\n\n if(idx === undefined) return obj;\n changeTypes[idx] = changeTypes[idx] | NAME;\n\n indexLookup[newName] = idx;\n delete indexLookup[name];\n\n arr[idx][keyName] = newName;\n\n return obj;\n },\n remove: function(name) {\n var idx = indexLookup[name];\n\n if(idx === undefined) return obj;\n\n var object = arr[idx];\n if(Object.keys(object).length > 2) {\n // This object contains more than just the key/value, so unset\n // the value without modifying the entry otherwise:\n changeTypes[idx] = changeTypes[idx] | VALUE;\n return obj.set(name, null);\n }\n\n if(isSimpleValueProp) {\n for(i = idx; i < arr.length; i++) {\n changeTypes[i] = changeTypes[i] | BOTH;\n }\n for(i = idx; i < arr.length; i++) {\n indexLookup[arr[i][keyName]]--;\n }\n arr.splice(idx, 1);\n delete(indexLookup[name]);\n } else {\n // Perform this update *strictly* so we can check whether the result's\n // been pruned. If so, it's a removal. If not, it's a value unset only.\n nestedProperty(object, valueName).set(null);\n\n // Now check if the top level nested property has any keys left. If so,\n // the object still has values so we only want to unset the key. If not,\n // the entire object can be removed since there's no other data.\n // var topLevelKeys = Object.keys(object[valueName.split('.')[0]] || []);\n\n changeTypes[idx] = changeTypes[idx] | VALUE | UNSET;\n }\n\n return obj;\n },\n constructUpdate: function() {\n var astr, idx;\n var update = {};\n var changed = Object.keys(changeTypes);\n for(var i = 0; i < changed.length; i++) {\n idx = changed[i];\n astr = path + '[' + idx + ']';\n if(arr[idx]) {\n if(changeTypes[idx] & NAME) {\n update[astr + '.' + keyName] = arr[idx][keyName];\n }\n if(changeTypes[idx] & VALUE) {\n if(isSimpleValueProp) {\n update[astr + '.' + valueName] = (changeTypes[idx] & UNSET) ? null : arr[idx][valueName];\n } else {\n update[astr + '.' + valueName] = (changeTypes[idx] & UNSET) ? null : nestedProperty(arr[idx], valueName).get();\n }\n }\n } else {\n update[astr] = null;\n }\n }\n\n return update;\n }\n };\n\n return obj;\n};\n","'use strict';\n\nvar Registry = require('../registry');\n\n/**\n * localize: translate a string for the current locale\n *\n * @param {object} gd: the graphDiv for context\n * gd._context.locale determines the language (& optional region/country)\n * the dictionary for each locale may either be supplied in\n * gd._context.locales or globally via Plotly.register\n * @param {string} s: the string to translate\n */\nmodule.exports = function localize(gd, s) {\n var locale = gd._context.locale;\n\n /*\n * Priority of lookup:\n * contextDicts[locale],\n * registeredDicts[locale],\n * contextDicts[baseLocale], (if baseLocale is distinct)\n * registeredDicts[baseLocale]\n * Return the first translation we find.\n * This way if you have a regionalization you are allowed to specify\n * only what's different from the base locale, everything else will\n * fall back on the base.\n */\n for(var i = 0; i < 2; i++) {\n var locales = gd._context.locales;\n for(var j = 0; j < 2; j++) {\n var dict = (locales[locale] || {}).dictionary;\n if(dict) {\n var out = dict[s];\n if(out) return out;\n }\n locales = Registry.localeRegistry;\n }\n\n var baseLocale = locale.split('-')[0];\n if(baseLocale === locale) break;\n locale = baseLocale;\n }\n\n return s;\n};\n","'use strict';\n\n/* eslint-disable no-console */\n\nvar dfltConfig = require('../plot_api/plot_config').dfltConfig;\n\nvar notifier = require('./notifier');\n\nvar loggers = module.exports = {};\n\n/**\n * ------------------------------------------\n * debugging tools\n * ------------------------------------------\n */\n\nloggers.log = function() {\n var i;\n\n if(dfltConfig.logging > 1) {\n var messages = ['LOG:'];\n for(i = 0; i < arguments.length; i++) {\n messages.push(arguments[i]);\n }\n console.trace.apply(console, messages);\n }\n\n if(dfltConfig.notifyOnLogging > 1) {\n var lines = [];\n for(i = 0; i < arguments.length; i++) {\n lines.push(arguments[i]);\n }\n notifier(lines.join('
'), 'long');\n }\n};\n\nloggers.warn = function() {\n var i;\n\n if(dfltConfig.logging > 0) {\n var messages = ['WARN:'];\n for(i = 0; i < arguments.length; i++) {\n messages.push(arguments[i]);\n }\n console.trace.apply(console, messages);\n }\n\n if(dfltConfig.notifyOnLogging > 0) {\n var lines = [];\n for(i = 0; i < arguments.length; i++) {\n lines.push(arguments[i]);\n }\n notifier(lines.join('
'), 'stick');\n }\n};\n\nloggers.error = function() {\n var i;\n\n if(dfltConfig.logging > 0) {\n var messages = ['ERROR:'];\n for(i = 0; i < arguments.length; i++) {\n messages.push(arguments[i]);\n }\n console.error.apply(console, messages);\n }\n\n if(dfltConfig.notifyOnLogging > 0) {\n var lines = [];\n for(i = 0; i < arguments.length; i++) {\n lines.push(arguments[i]);\n }\n notifier(lines.join('
'), 'stick');\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\n/**\n * General helper to manage trace groups based on calcdata\n *\n * @param {d3.selection} traceLayer: a selection containing a single group\n * to draw these traces into\n * @param {array} cdModule: array of calcdata items for this\n * module and subplot combination. Assumes the calcdata item for each\n * trace is an array with the fullData trace attached to the first item.\n * @param {string} cls: the class attribute to give each trace group\n * so you can give multiple classes separated by spaces\n */\nmodule.exports = function makeTraceGroups(traceLayer, cdModule, cls) {\n var traces = traceLayer.selectAll('g.' + cls.replace(/\\s/g, '.'))\n .data(cdModule, function(cd) { return cd[0].trace.uid; });\n\n traces.exit().remove();\n\n traces.enter().append('g')\n .attr('class', cls);\n\n traces.order();\n\n // stash ref node to trace group in calcdata,\n // useful for (fast) styleOnSelect\n var k = traceLayer.classed('rangeplot') ? 'nodeRangePlot3' : 'node3';\n traces.each(function(cd) { cd[0][k] = d3.select(this); });\n\n return traces;\n};\n","'use strict';\n\nvar mat4X4 = require('gl-mat4');\n\nexports.init2dArray = function(rowLength, colLength) {\n var array = new Array(rowLength);\n for(var i = 0; i < rowLength; i++) array[i] = new Array(colLength);\n return array;\n};\n\n/**\n * transpose a (possibly ragged) 2d array z. inspired by\n * http://stackoverflow.com/questions/17428587/\n * transposing-a-2d-array-in-javascript\n */\nexports.transposeRagged = function(z) {\n var maxlen = 0;\n var zlen = z.length;\n var i, j;\n // Maximum row length:\n for(i = 0; i < zlen; i++) maxlen = Math.max(maxlen, z[i].length);\n\n var t = new Array(maxlen);\n for(i = 0; i < maxlen; i++) {\n t[i] = new Array(zlen);\n for(j = 0; j < zlen; j++) t[i][j] = z[j][i];\n }\n\n return t;\n};\n\n// our own dot function so that we don't need to include numeric\nexports.dot = function(x, y) {\n if(!(x.length && y.length) || x.length !== y.length) return null;\n\n var len = x.length;\n var out;\n var i;\n\n if(x[0].length) {\n // mat-vec or mat-mat\n out = new Array(len);\n for(i = 0; i < len; i++) out[i] = exports.dot(x[i], y);\n } else if(y[0].length) {\n // vec-mat\n var yTranspose = exports.transposeRagged(y);\n out = new Array(yTranspose.length);\n for(i = 0; i < yTranspose.length; i++) out[i] = exports.dot(x, yTranspose[i]);\n } else {\n // vec-vec\n out = 0;\n for(i = 0; i < len; i++) out += x[i] * y[i];\n }\n\n return out;\n};\n\n// translate by (x,y)\nexports.translationMatrix = function(x, y) {\n return [[1, 0, x], [0, 1, y], [0, 0, 1]];\n};\n\n// rotate by alpha around (0,0)\nexports.rotationMatrix = function(alpha) {\n var a = alpha * Math.PI / 180;\n return [[Math.cos(a), -Math.sin(a), 0],\n [Math.sin(a), Math.cos(a), 0],\n [0, 0, 1]];\n};\n\n// rotate by alpha around (x,y)\nexports.rotationXYMatrix = function(a, x, y) {\n return exports.dot(\n exports.dot(exports.translationMatrix(x, y),\n exports.rotationMatrix(a)),\n exports.translationMatrix(-x, -y));\n};\n\n// applies a 3D transformation matrix to either x, y and z params\n// Note: z is optional\nexports.apply3DTransform = function(transform) {\n return function() {\n var args = arguments;\n var xyz = arguments.length === 1 ? args[0] : [args[0], args[1], args[2] || 0];\n return exports.dot(transform, [xyz[0], xyz[1], xyz[2], 1]).slice(0, 3);\n };\n};\n\n// applies a 2D transformation matrix to either x and y params or an [x,y] array\nexports.apply2DTransform = function(transform) {\n return function() {\n var args = arguments;\n if(args.length === 3) {\n args = args[0];\n } // from map\n var xy = arguments.length === 1 ? args[0] : [args[0], args[1]];\n return exports.dot(transform, [xy[0], xy[1], 1]).slice(0, 2);\n };\n};\n\n// applies a 2D transformation matrix to an [x1,y1,x2,y2] array (to transform a segment)\nexports.apply2DTransform2 = function(transform) {\n var at = exports.apply2DTransform(transform);\n return function(xys) {\n return at(xys.slice(0, 2)).concat(at(xys.slice(2, 4)));\n };\n};\n\nexports.convertCssMatrix = function(m) {\n if(m) {\n var len = m.length;\n if(len === 16) return m;\n if(len === 6) {\n // converts a 2x3 css transform matrix to a 4x4 matrix see https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix\n return [\n m[0], m[1], 0, 0,\n m[2], m[3], 0, 0,\n 0, 0, 1, 0,\n m[4], m[5], 0, 1\n ];\n }\n }\n return [\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1\n ];\n};\n\n// find the inverse for a 4x4 affine transform matrix\nexports.inverseTransformMatrix = function(m) {\n var out = [];\n mat4X4.invert(out, m);\n return [\n [out[0], out[1], out[2], out[3]],\n [out[4], out[5], out[6], out[7]],\n [out[8], out[9], out[10], out[11]],\n [out[12], out[13], out[14], out[15]]\n ];\n};\n","'use strict';\n\n/**\n * sanitized modulus function that always returns in the range [0, d)\n * rather than (-d, 0] if v is negative\n */\nfunction mod(v, d) {\n var out = v % d;\n return out < 0 ? out + d : out;\n}\n\n/**\n * sanitized modulus function that always returns in the range [-d/2, d/2]\n * rather than (-d, 0] if v is negative\n */\nfunction modHalf(v, d) {\n return Math.abs(v) > (d / 2) ?\n v - Math.round(v / d) * d :\n v;\n}\n\nmodule.exports = {\n mod: mod,\n modHalf: modHalf\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar isArrayOrTypedArray = require('./array').isArrayOrTypedArray;\n\n/**\n * convert a string s (such as 'xaxis.range[0]')\n * representing a property of nested object into set and get methods\n * also return the string and object so we don't have to keep track of them\n * allows [-1] for an array index, to set a property inside all elements\n * of an array\n * eg if obj = {arr: [{a: 1}, {a: 2}]}\n * you can do p = nestedProperty(obj, 'arr[-1].a')\n * but you cannot set the array itself this way, to do that\n * just set the whole array.\n * eg if obj = {arr: [1, 2, 3]}\n * you can't do nestedProperty(obj, 'arr[-1]').set(5)\n * but you can do nestedProperty(obj, 'arr').set([5, 5, 5])\n */\nmodule.exports = function nestedProperty(container, propStr) {\n if(isNumeric(propStr)) propStr = String(propStr);\n else if(typeof propStr !== 'string' ||\n propStr.substr(propStr.length - 4) === '[-1]') {\n throw 'bad property string';\n }\n\n var propParts = propStr.split('.');\n var indexed;\n var indices;\n var i, j;\n\n for(j = 0; j < propParts.length; j++) {\n // guard against polluting __proto__ and other internals\n if(String(propParts[j]).slice(0, 2) === '__') {\n throw 'bad property string';\n }\n }\n\n // check for parts of the nesting hierarchy that are numbers (ie array elements)\n j = 0;\n while(j < propParts.length) {\n // look for non-bracket chars, then any number of [##] blocks\n indexed = String(propParts[j]).match(/^([^\\[\\]]*)((\\[\\-?[0-9]*\\])+)$/);\n if(indexed) {\n if(indexed[1]) propParts[j] = indexed[1];\n // allow propStr to start with bracketed array indices\n else if(j === 0) propParts.splice(0, 1);\n else throw 'bad property string';\n\n indices = indexed[2]\n .substr(1, indexed[2].length - 2)\n .split('][');\n\n for(i = 0; i < indices.length; i++) {\n j++;\n propParts.splice(j, 0, Number(indices[i]));\n }\n }\n j++;\n }\n\n if(typeof container !== 'object') {\n return badContainer(container, propStr, propParts);\n }\n\n return {\n set: npSet(container, propParts, propStr),\n get: npGet(container, propParts),\n astr: propStr,\n parts: propParts,\n obj: container\n };\n};\n\nfunction npGet(cont, parts) {\n return function() {\n var curCont = cont;\n var curPart;\n var allSame;\n var out;\n var i;\n var j;\n\n for(i = 0; i < parts.length - 1; i++) {\n curPart = parts[i];\n if(curPart === -1) {\n allSame = true;\n out = [];\n for(j = 0; j < curCont.length; j++) {\n out[j] = npGet(curCont[j], parts.slice(i + 1))();\n if(out[j] !== out[0]) allSame = false;\n }\n return allSame ? out[0] : out;\n }\n if(typeof curPart === 'number' && !isArrayOrTypedArray(curCont)) {\n return undefined;\n }\n curCont = curCont[curPart];\n if(typeof curCont !== 'object' || curCont === null) {\n return undefined;\n }\n }\n\n // only hit this if parts.length === 1\n if(typeof curCont !== 'object' || curCont === null) return undefined;\n\n out = curCont[parts[i]];\n if(out === null) return undefined;\n return out;\n };\n}\n\n/*\n * Can this value be deleted? We can delete `undefined`, and `null` except INSIDE an\n * *args* array.\n *\n * Previously we also deleted some `{}` and `[]`, in order to try and make set/unset\n * a net noop; but this causes far more complication than it's worth, and still had\n * lots of exceptions. See https://github.com/plotly/plotly.js/issues/1410\n *\n * *args* arrays get passed directly to API methods and we should respect null if\n * the user put it there, but otherwise null is deleted as we use it as code\n * in restyle/relayout/update for \"delete this value\" whereas undefined means\n * \"ignore this edit\"\n */\nvar ARGS_PATTERN = /(^|\\.)args\\[/;\nfunction isDeletable(val, propStr) {\n return (val === undefined) || (val === null && !propStr.match(ARGS_PATTERN));\n}\n\nfunction npSet(cont, parts, propStr) {\n return function(val) {\n var curCont = cont;\n var propPart = '';\n var containerLevels = [[cont, propPart]];\n var toDelete = isDeletable(val, propStr);\n var curPart;\n var i;\n\n for(i = 0; i < parts.length - 1; i++) {\n curPart = parts[i];\n\n if(typeof curPart === 'number' && !isArrayOrTypedArray(curCont)) {\n throw 'array index but container is not an array';\n }\n\n // handle special -1 array index\n if(curPart === -1) {\n toDelete = !setArrayAll(curCont, parts.slice(i + 1), val, propStr);\n if(toDelete) break;\n else return;\n }\n\n if(!checkNewContainer(curCont, curPart, parts[i + 1], toDelete)) {\n break;\n }\n\n curCont = curCont[curPart];\n\n if(typeof curCont !== 'object' || curCont === null) {\n throw 'container is not an object';\n }\n\n propPart = joinPropStr(propPart, curPart);\n\n containerLevels.push([curCont, propPart]);\n }\n\n if(toDelete) {\n if(i === parts.length - 1) {\n delete curCont[parts[i]];\n\n // The one bit of pruning we still do: drop `undefined` from the end of arrays.\n // In case someone has already unset previous items, continue until we hit a\n // non-undefined value.\n if(Array.isArray(curCont) && +parts[i] === curCont.length - 1) {\n while(curCont.length && curCont[curCont.length - 1] === undefined) {\n curCont.pop();\n }\n }\n }\n } else curCont[parts[i]] = val;\n };\n}\n\nfunction joinPropStr(propStr, newPart) {\n var toAdd = newPart;\n if(isNumeric(newPart)) toAdd = '[' + newPart + ']';\n else if(propStr) toAdd = '.' + newPart;\n\n return propStr + toAdd;\n}\n\n// handle special -1 array index\nfunction setArrayAll(containerArray, innerParts, val, propStr) {\n var arrayVal = isArrayOrTypedArray(val);\n var allSet = true;\n var thisVal = val;\n var thisPropStr = propStr.replace('-1', 0);\n var deleteThis = arrayVal ? false : isDeletable(val, thisPropStr);\n var firstPart = innerParts[0];\n var i;\n\n for(i = 0; i < containerArray.length; i++) {\n thisPropStr = propStr.replace('-1', i);\n if(arrayVal) {\n thisVal = val[i % val.length];\n deleteThis = isDeletable(thisVal, thisPropStr);\n }\n if(deleteThis) allSet = false;\n if(!checkNewContainer(containerArray, i, firstPart, deleteThis)) {\n continue;\n }\n npSet(containerArray[i], innerParts, propStr.replace('-1', i))(thisVal);\n }\n return allSet;\n}\n\n/**\n * make new sub-container as needed.\n * returns false if there's no container and none is needed\n * because we're only deleting an attribute\n */\nfunction checkNewContainer(container, part, nextPart, toDelete) {\n if(container[part] === undefined) {\n if(toDelete) return false;\n\n if(typeof nextPart === 'number') container[part] = [];\n else container[part] = {};\n }\n return true;\n}\n\nfunction badContainer(container, propStr, propParts) {\n return {\n set: function() { throw 'bad container'; },\n get: function() {},\n astr: propStr,\n parts: propParts,\n obj: container\n };\n}\n","'use strict';\n\n// Simple helper functions\n// none of these need any external deps\n\nmodule.exports = function noop() {};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar NOTEDATA = [];\n\n/**\n * notifier\n * @param {String} text The person's user name\n * @param {Number} [delay=1000] The delay time in milliseconds\n * or 'long' which provides 2000 ms delay time.\n * @return {undefined} this function does not return a value\n */\nmodule.exports = function(text, displayLength) {\n if(NOTEDATA.indexOf(text) !== -1) return;\n\n NOTEDATA.push(text);\n\n var ts = 1000;\n if(isNumeric(displayLength)) ts = displayLength;\n else if(displayLength === 'long') ts = 3000;\n\n var notifierContainer = d3.select('body')\n .selectAll('.plotly-notifier')\n .data([0]);\n notifierContainer.enter()\n .append('div')\n .classed('plotly-notifier', true);\n\n var notes = notifierContainer.selectAll('.notifier-note').data(NOTEDATA);\n\n function killNote(transition) {\n transition\n .duration(700)\n .style('opacity', 0)\n .each('end', function(thisText) {\n var thisIndex = NOTEDATA.indexOf(thisText);\n if(thisIndex !== -1) NOTEDATA.splice(thisIndex, 1);\n d3.select(this).remove();\n });\n }\n\n notes.enter().append('div')\n .classed('notifier-note', true)\n .style('opacity', 0)\n .each(function(thisText) {\n var note = d3.select(this);\n\n note.append('button')\n .classed('notifier-close', true)\n .html('×')\n .on('click', function() {\n note.transition().call(killNote);\n });\n\n var p = note.append('p');\n var lines = thisText.split(//g);\n for(var i = 0; i < lines.length; i++) {\n if(i) p.append('br');\n p.append('span').text(lines[i]);\n }\n\n if(displayLength === 'stick') {\n note.transition()\n .duration(350)\n .style('opacity', 1);\n } else {\n note.transition()\n .duration(700)\n .style('opacity', 1)\n .transition()\n .delay(ts)\n .call(killNote);\n }\n });\n};\n","'use strict';\n\nvar setCursor = require('./setcursor');\n\nvar STASHATTR = 'data-savedcursor';\nvar NO_CURSOR = '!!';\n\n/*\n * works with our CSS cursor classes (see css/_cursor.scss)\n * to override a previous cursor set on d3 single-element selections,\n * by moving the name of the original cursor to the data-savedcursor attr.\n * omit cursor to revert to the previously set value.\n */\nmodule.exports = function overrideCursor(el3, csr) {\n var savedCursor = el3.attr(STASHATTR);\n if(csr) {\n if(!savedCursor) {\n var classes = (el3.attr('class') || '').split(' ');\n for(var i = 0; i < classes.length; i++) {\n var cls = classes[i];\n if(cls.indexOf('cursor-') === 0) {\n el3.attr(STASHATTR, cls.substr(7))\n .classed(cls, false);\n }\n }\n if(!el3.attr(STASHATTR)) {\n el3.attr(STASHATTR, NO_CURSOR);\n }\n }\n setCursor(el3, csr);\n } else if(savedCursor) {\n el3.attr(STASHATTR, null);\n\n if(savedCursor === NO_CURSOR) setCursor(el3);\n else setCursor(el3, savedCursor);\n }\n};\n","'use strict';\n\nvar dot = require('./matrix').dot;\nvar BADNUM = require('../constants/numerical').BADNUM;\n\nvar polygon = module.exports = {};\n\n/**\n * Turn an array of [x, y] pairs into a polygon object\n * that can test if points are inside it\n *\n * @param ptsIn Array of [x, y] pairs\n *\n * @returns polygon Object {xmin, xmax, ymin, ymax, pts, contains}\n * (x|y)(min|max) are the bounding rect of the polygon\n * pts is the original array, with the first pair repeated at the end\n * contains is a function: (pt, omitFirstEdge)\n * pt is the [x, y] pair to test\n * omitFirstEdge truthy means points exactly on the first edge don't\n * count. This is for use adding one polygon to another so we\n * don't double-count the edge where they meet.\n * returns boolean: is pt inside the polygon (including on its edges)\n */\npolygon.tester = function tester(ptsIn) {\n var pts = ptsIn.slice();\n var xmin = pts[0][0];\n var xmax = xmin;\n var ymin = pts[0][1];\n var ymax = ymin;\n var i;\n\n if(\n pts[pts.length - 1][0] !== pts[0][0] ||\n pts[pts.length - 1][1] !== pts[0][1]\n ) {\n // close the polygon\n pts.push(pts[0]);\n }\n\n for(i = 1; i < pts.length; i++) {\n xmin = Math.min(xmin, pts[i][0]);\n xmax = Math.max(xmax, pts[i][0]);\n ymin = Math.min(ymin, pts[i][1]);\n ymax = Math.max(ymax, pts[i][1]);\n }\n\n // do we have a rectangle? Handle this here, so we can use the same\n // tester for the rectangular case without sacrificing speed\n\n var isRect = false;\n var rectFirstEdgeTest;\n\n if(pts.length === 5) {\n if(pts[0][0] === pts[1][0]) { // vert, horz, vert, horz\n if(pts[2][0] === pts[3][0] &&\n pts[0][1] === pts[3][1] &&\n pts[1][1] === pts[2][1]) {\n isRect = true;\n rectFirstEdgeTest = function(pt) { return pt[0] === pts[0][0]; };\n }\n } else if(pts[0][1] === pts[1][1]) { // horz, vert, horz, vert\n if(pts[2][1] === pts[3][1] &&\n pts[0][0] === pts[3][0] &&\n pts[1][0] === pts[2][0]) {\n isRect = true;\n rectFirstEdgeTest = function(pt) { return pt[1] === pts[0][1]; };\n }\n }\n }\n\n function rectContains(pt, omitFirstEdge) {\n var x = pt[0];\n var y = pt[1];\n\n if(x === BADNUM || x < xmin || x > xmax || y === BADNUM || y < ymin || y > ymax) {\n // pt is outside the bounding box of polygon\n return false;\n }\n if(omitFirstEdge && rectFirstEdgeTest(pt)) return false;\n\n return true;\n }\n\n function contains(pt, omitFirstEdge) {\n var x = pt[0];\n var y = pt[1];\n\n if(x === BADNUM || x < xmin || x > xmax || y === BADNUM || y < ymin || y > ymax) {\n // pt is outside the bounding box of polygon\n return false;\n }\n\n var imax = pts.length;\n var x1 = pts[0][0];\n var y1 = pts[0][1];\n var crossings = 0;\n var i;\n var x0;\n var y0;\n var xmini;\n var ycross;\n\n for(i = 1; i < imax; i++) {\n // find all crossings of a vertical line upward from pt with\n // polygon segments\n // crossings exactly at xmax don't count, unless the point is\n // exactly on the segment, then it counts as inside.\n x0 = x1;\n y0 = y1;\n x1 = pts[i][0];\n y1 = pts[i][1];\n xmini = Math.min(x0, x1);\n\n if(x < xmini || x > Math.max(x0, x1) || y > Math.max(y0, y1)) {\n // outside the bounding box of this segment, it's only a crossing\n // if it's below the box.\n\n continue;\n } else if(y < Math.min(y0, y1)) {\n // don't count the left-most point of the segment as a crossing\n // because we don't want to double-count adjacent crossings\n // UNLESS the polygon turns past vertical at exactly this x\n // Note that this is repeated below, but we can't factor it out\n // because\n if(x !== xmini) crossings++;\n } else {\n // inside the bounding box, check the actual line intercept\n\n // vertical segment - we know already that the point is exactly\n // on the segment, so mark the crossing as exactly at the point.\n if(x1 === x0) ycross = y;\n // any other angle\n else ycross = y0 + (x - x0) * (y1 - y0) / (x1 - x0);\n\n // exactly on the edge: counts as inside the polygon, unless it's the\n // first edge and we're omitting it.\n if(y === ycross) {\n if(i === 1 && omitFirstEdge) return false;\n return true;\n }\n\n if(y <= ycross && x !== xmini) crossings++;\n }\n }\n\n // if we've gotten this far, odd crossings means inside, even is outside\n return crossings % 2 === 1;\n }\n\n // detect if poly is degenerate\n var degenerate = true;\n var lastPt = pts[0];\n for(i = 1; i < pts.length; i++) {\n if(lastPt[0] !== pts[i][0] || lastPt[1] !== pts[i][1]) {\n degenerate = false;\n break;\n }\n }\n\n return {\n xmin: xmin,\n xmax: xmax,\n ymin: ymin,\n ymax: ymax,\n pts: pts,\n contains: isRect ? rectContains : contains,\n isRect: isRect,\n degenerate: degenerate\n };\n};\n\n/**\n * Test if a segment of a points array is bent or straight\n *\n * @param pts Array of [x, y] pairs\n * @param start the index of the proposed start of the straight section\n * @param end the index of the proposed end point\n * @param tolerance the max distance off the line connecting start and end\n * before the line counts as bent\n * @returns boolean: true means this segment is bent, false means straight\n */\npolygon.isSegmentBent = function isSegmentBent(pts, start, end, tolerance) {\n var startPt = pts[start];\n var segment = [pts[end][0] - startPt[0], pts[end][1] - startPt[1]];\n var segmentSquared = dot(segment, segment);\n var segmentLen = Math.sqrt(segmentSquared);\n var unitPerp = [-segment[1] / segmentLen, segment[0] / segmentLen];\n var i;\n var part;\n var partParallel;\n\n for(i = start + 1; i < end; i++) {\n part = [pts[i][0] - startPt[0], pts[i][1] - startPt[1]];\n partParallel = dot(part, segment);\n\n if(partParallel < 0 || partParallel > segmentSquared ||\n Math.abs(dot(part, unitPerp)) > tolerance) return true;\n }\n return false;\n};\n\n/**\n * Make a filtering polygon, to minimize the number of segments\n *\n * @param pts Array of [x, y] pairs (must start with at least 1 pair)\n * @param tolerance the maximum deviation from straight allowed for\n * removing points to simplify the polygon\n *\n * @returns Object {addPt, raw, filtered}\n * addPt is a function(pt: [x, y] pair) to add a raw point and\n * continue filtering\n * raw is all the input points\n * filtered is the resulting filtered Array of [x, y] pairs\n */\npolygon.filter = function filter(pts, tolerance) {\n var ptsFiltered = [pts[0]];\n var doneRawIndex = 0;\n var doneFilteredIndex = 0;\n\n function addPt(pt) {\n pts.push(pt);\n var prevFilterLen = ptsFiltered.length;\n var iLast = doneRawIndex;\n ptsFiltered.splice(doneFilteredIndex + 1);\n\n for(var i = iLast + 1; i < pts.length; i++) {\n if(i === pts.length - 1 || polygon.isSegmentBent(pts, iLast, i + 1, tolerance)) {\n ptsFiltered.push(pts[i]);\n if(ptsFiltered.length < prevFilterLen - 2) {\n doneRawIndex = i;\n doneFilteredIndex = ptsFiltered.length - 1;\n }\n iLast = i;\n }\n }\n }\n\n if(pts.length > 1) {\n var lastPt = pts.pop();\n addPt(lastPt);\n }\n\n return {\n addPt: addPt,\n raw: pts,\n filtered: ptsFiltered\n };\n};\n","'use strict';\n\nvar showNoWebGlMsg = require('./show_no_webgl_msg');\n\n// Note that this module should be ONLY required into\n// files corresponding to regl trace modules\n// so that bundles with non-regl only don't include\n// regl and all its bytes.\nvar createRegl = require('regl');\n\n/**\n * Idempotent version of createRegl. Create regl instances\n * in the correct canvases with the correct attributes and\n * options\n *\n * @param {DOM node or object} gd : graph div object\n * @param {array} extensions : list of extension to pass to createRegl\n *\n * @return {boolean} true if all createRegl calls succeeded, false otherwise\n */\nmodule.exports = function prepareRegl(gd, extensions, reglPrecompiled) {\n var fullLayout = gd._fullLayout;\n var success = true;\n\n fullLayout._glcanvas.each(function(d) {\n if(d.regl) {\n d.regl.preloadCachedCode(reglPrecompiled);\n return;\n }\n // only parcoords needs pick layer\n if(d.pick && !fullLayout._has('parcoords')) return;\n\n try {\n d.regl = createRegl({\n canvas: this,\n attributes: {\n antialias: !d.pick,\n preserveDrawingBuffer: true\n },\n pixelRatio: gd._context.plotGlPixelRatio || global.devicePixelRatio,\n extensions: extensions || [],\n cachedCode: reglPrecompiled || {}\n });\n } catch(e) {\n success = false;\n }\n\n if(!d.regl) success = false;\n\n if(success) {\n this.addEventListener('webglcontextlost', function(event) {\n if(gd && gd.emit) {\n gd.emit('plotly_webglcontextlost', {\n event: event,\n layer: d.key\n });\n }\n }, false);\n }\n });\n\n if(!success) {\n showNoWebGlMsg({container: fullLayout._glcontainer.node()});\n }\n return success;\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar isMobileOrTablet = require('is-mobile');\n\nmodule.exports = function preserveDrawingBuffer(opts) {\n var ua;\n\n if(opts && opts.hasOwnProperty('userAgent')) {\n ua = opts.userAgent;\n } else {\n ua = getUserAgent();\n }\n\n if(typeof ua !== 'string') return true;\n\n var enable = isMobileOrTablet({\n ua: { headers: {'user-agent': ua }},\n tablet: true,\n featureDetect: false\n });\n\n if(!enable) {\n var allParts = ua.split(' ');\n for(var i = 1; i < allParts.length; i++) {\n var part = allParts[i];\n if(part.indexOf('Safari') !== -1) {\n // find Safari version\n for(var k = i - 1; k > -1; k--) {\n var prevPart = allParts[k];\n if(prevPart.substr(0, 8) === 'Version/') {\n var v = prevPart.substr(8).split('.')[0];\n if(isNumeric(v)) v = +v;\n if(v >= 13) return true;\n }\n }\n }\n }\n }\n\n return enable;\n};\n\nfunction getUserAgent() {\n // similar to https://github.com/juliangruber/is-mobile/blob/91ca39ccdd4cfc5edfb5391e2515b923a730fbea/index.js#L14-L17\n var ua;\n if(typeof navigator !== 'undefined') {\n ua = navigator.userAgent;\n }\n\n if(\n ua &&\n ua.headers &&\n typeof ua.headers['user-agent'] === 'string'\n ) {\n ua = ua.headers['user-agent'];\n }\n\n return ua;\n}\n","'use strict';\n\n/**\n * Push array with unique items\n *\n * Ignores falsy items, except 0 so we can use it to construct arrays of indices.\n *\n * @param {array} array\n * array to be filled\n * @param {any} item\n * item to be or not to be inserted\n * @return {array}\n * ref to array (now possibly containing one more item)\n *\n */\nmodule.exports = function pushUnique(array, item) {\n if(item instanceof RegExp) {\n var itemStr = item.toString();\n for(var i = 0; i < array.length; i++) {\n if(array[i] instanceof RegExp && array[i].toString() === itemStr) {\n return array;\n }\n }\n array.push(item);\n } else if((item || item === 0) && array.indexOf(item) === -1) array.push(item);\n\n return array;\n};\n","'use strict';\n\nvar Lib = require('../lib');\nvar dfltConfig = require('../plot_api/plot_config').dfltConfig;\n\n/**\n * Copy arg array *without* removing `undefined` values from objects.\n *\n * @param gd\n * @param args\n * @returns {Array}\n */\nfunction copyArgArray(gd, args) {\n var copy = [];\n var arg;\n\n for(var i = 0; i < args.length; i++) {\n arg = args[i];\n\n if(arg === gd) copy[i] = arg;\n else if(typeof arg === 'object') {\n copy[i] = Array.isArray(arg) ?\n Lib.extendDeep([], arg) :\n Lib.extendDeepAll({}, arg);\n } else copy[i] = arg;\n }\n\n return copy;\n}\n\n\n// -----------------------------------------------------\n// Undo/Redo queue for plots\n// -----------------------------------------------------\n\n\nvar queue = {};\n\n// TODO: disable/enable undo and redo buttons appropriately\n\n/**\n * Add an item to the undoQueue for a graphDiv\n *\n * @param gd\n * @param undoFunc Function undo this operation\n * @param undoArgs Args to supply undoFunc with\n * @param redoFunc Function to redo this operation\n * @param redoArgs Args to supply redoFunc with\n */\nqueue.add = function(gd, undoFunc, undoArgs, redoFunc, redoArgs) {\n var queueObj,\n queueIndex;\n\n // make sure we have the queue and our position in it\n gd.undoQueue = gd.undoQueue || {index: 0, queue: [], sequence: false};\n queueIndex = gd.undoQueue.index;\n\n // if we're already playing an undo or redo, or if this is an auto operation\n // (like pane resize... any others?) then we don't save this to the undo queue\n if(gd.autoplay) {\n if(!gd.undoQueue.inSequence) gd.autoplay = false;\n return;\n }\n\n // if we're not in a sequence or are just starting, we need a new queue item\n if(!gd.undoQueue.sequence || gd.undoQueue.beginSequence) {\n queueObj = {undo: {calls: [], args: []}, redo: {calls: [], args: []}};\n gd.undoQueue.queue.splice(queueIndex, gd.undoQueue.queue.length - queueIndex, queueObj);\n gd.undoQueue.index += 1;\n } else {\n queueObj = gd.undoQueue.queue[queueIndex - 1];\n }\n gd.undoQueue.beginSequence = false;\n\n // we unshift to handle calls for undo in a forward for loop later\n if(queueObj) {\n queueObj.undo.calls.unshift(undoFunc);\n queueObj.undo.args.unshift(undoArgs);\n queueObj.redo.calls.push(redoFunc);\n queueObj.redo.args.push(redoArgs);\n }\n\n if(gd.undoQueue.queue.length > dfltConfig.queueLength) {\n gd.undoQueue.queue.shift();\n gd.undoQueue.index--;\n }\n};\n\n/**\n * Begin a sequence of undoQueue changes\n *\n * @param gd\n */\nqueue.startSequence = function(gd) {\n gd.undoQueue = gd.undoQueue || {index: 0, queue: [], sequence: false};\n gd.undoQueue.sequence = true;\n gd.undoQueue.beginSequence = true;\n};\n\n/**\n * Stop a sequence of undoQueue changes\n *\n * Call this *after* you're sure your undo chain has ended\n *\n * @param gd\n */\nqueue.stopSequence = function(gd) {\n gd.undoQueue = gd.undoQueue || {index: 0, queue: [], sequence: false};\n gd.undoQueue.sequence = false;\n gd.undoQueue.beginSequence = false;\n};\n\n/**\n * Move one step back in the undo queue, and undo the object there.\n *\n * @param gd\n */\nqueue.undo = function undo(gd) {\n var queueObj, i;\n\n if(gd.undoQueue === undefined ||\n isNaN(gd.undoQueue.index) ||\n gd.undoQueue.index <= 0) {\n return;\n }\n\n // index is pointing to next *forward* queueObj, point to the one we're undoing\n gd.undoQueue.index--;\n\n // get the queueObj for instructions on how to undo\n queueObj = gd.undoQueue.queue[gd.undoQueue.index];\n\n // this sequence keeps things from adding to the queue during undo/redo\n gd.undoQueue.inSequence = true;\n for(i = 0; i < queueObj.undo.calls.length; i++) {\n queue.plotDo(gd, queueObj.undo.calls[i], queueObj.undo.args[i]);\n }\n gd.undoQueue.inSequence = false;\n gd.autoplay = false;\n};\n\n/**\n * Redo the current object in the undo, then move forward in the queue.\n *\n * @param gd\n */\nqueue.redo = function redo(gd) {\n var queueObj, i;\n\n if(gd.undoQueue === undefined ||\n isNaN(gd.undoQueue.index) ||\n gd.undoQueue.index >= gd.undoQueue.queue.length) {\n return;\n }\n\n // get the queueObj for instructions on how to undo\n queueObj = gd.undoQueue.queue[gd.undoQueue.index];\n\n // this sequence keeps things from adding to the queue during undo/redo\n gd.undoQueue.inSequence = true;\n for(i = 0; i < queueObj.redo.calls.length; i++) {\n queue.plotDo(gd, queueObj.redo.calls[i], queueObj.redo.args[i]);\n }\n gd.undoQueue.inSequence = false;\n gd.autoplay = false;\n\n // index is pointing to the thing we just redid, move it\n gd.undoQueue.index++;\n};\n\n/**\n * Called by undo/redo to make the actual changes.\n *\n * Not meant to be called publically, but included for mocking out in tests.\n *\n * @param gd\n * @param func\n * @param args\n */\nqueue.plotDo = function(gd, func, args) {\n gd.autoplay = true;\n\n // this *won't* copy gd and it preserves `undefined` properties!\n args = copyArgArray(gd, args);\n\n // call the supplied function\n func.apply(null, args);\n};\n\nmodule.exports = queue;\n","'use strict';\n\n/*\n * make a regex for matching counter ids/names ie xaxis, xaxis2, xaxis10...\n *\n * @param {string} head: the head of the pattern, eg 'x' matches 'x', 'x2', 'x10' etc.\n * 'xy' is a special case for cartesian subplots: it matches 'x2y3' etc\n * @param {Optional(string)} tail: a fixed piece after the id\n * eg counterRegex('scene', '.annotations') for scene2.annotations etc.\n * @param {boolean} openEnded: if true, the string may continue past the match.\n * @param {boolean} matchBeginning: if false, the string may start before the match.\n */\nexports.counter = function(head, tail, openEnded, matchBeginning) {\n var fullTail = (tail || '') + (openEnded ? '' : '$');\n var startWithPrefix = matchBeginning === false ? '' : '^';\n if(head === 'xy') {\n return new RegExp(startWithPrefix + 'x([2-9]|[1-9][0-9]+)?y([2-9]|[1-9][0-9]+)?' + fullTail);\n }\n return new RegExp(startWithPrefix + head + '([2-9]|[1-9][0-9]+)?' + fullTail);\n};\n","'use strict';\n\n// ASCEND: chop off the last nesting level - either [] or . - to ascend\n// the attribute tree. the remaining attrString is in match[1]\nvar ASCEND = /^(.*)(\\.[^\\.\\[\\]]+|\\[\\d\\])$/;\n\n// SIMPLEATTR: is this an un-nested attribute? (no dots or brackets)\nvar SIMPLEATTR = /^[^\\.\\[\\]]+$/;\n\n/*\n * calculate a relative attribute string, similar to a relative path\n *\n * @param {string} baseAttr:\n * an attribute string, such as 'annotations[3].x'. The \"current location\"\n * is the attribute string minus the last component ('annotations[3]')\n * @param {string} relativeAttr:\n * a route to the desired attribute string, using '^' to ascend\n *\n * @return {string} attrString:\n * for example:\n * relativeAttr('annotations[3].x', 'y') = 'annotations[3].y'\n * relativeAttr('annotations[3].x', '^[2].z') = 'annotations[2].z'\n * relativeAttr('annotations[3].x', '^^margin') = 'margin'\n * relativeAttr('annotations[3].x', '^^margin.r') = 'margin.r'\n */\nmodule.exports = function(baseAttr, relativeAttr) {\n while(relativeAttr) {\n var match = baseAttr.match(ASCEND);\n\n if(match) baseAttr = match[1];\n else if(baseAttr.match(SIMPLEATTR)) baseAttr = '';\n else throw new Error('bad relativeAttr call:' + [baseAttr, relativeAttr]);\n\n if(relativeAttr.charAt(0) === '^') relativeAttr = relativeAttr.slice(1);\n else break;\n }\n\n if(baseAttr && relativeAttr.charAt(0) !== '[') {\n return baseAttr + '.' + relativeAttr;\n }\n return baseAttr + relativeAttr;\n};\n","'use strict';\n\nvar isArrayOrTypedArray = require('./array').isArrayOrTypedArray;\nvar isPlainObject = require('./is_plain_object');\n\n/**\n * Relink private _keys and keys with a function value from one container\n * to the new container.\n * Relink means copying if object is pass-by-value and adding a reference\n * if object is pass-by-ref.\n * This prevents deepCopying massive structures like a webgl context.\n */\nmodule.exports = function relinkPrivateKeys(toContainer, fromContainer) {\n for(var k in fromContainer) {\n var fromVal = fromContainer[k];\n var toVal = toContainer[k];\n\n if(toVal === fromVal) continue;\n\n if(k.charAt(0) === '_' || typeof fromVal === 'function') {\n // if it already exists at this point, it's something\n // that we recreate each time around, so ignore it\n if(k in toContainer) continue;\n\n toContainer[k] = fromVal;\n } else if(isArrayOrTypedArray(fromVal) && isArrayOrTypedArray(toVal) && isPlainObject(fromVal[0])) {\n // filter out data_array items that can contain user objects\n // most of the time the toVal === fromVal check will catch these early\n // but if the user makes new ones we also don't want to recurse in.\n if(k === 'customdata' || k === 'ids') continue;\n\n // recurse into arrays containers\n var minLen = Math.min(fromVal.length, toVal.length);\n for(var j = 0; j < minLen; j++) {\n if((toVal[j] !== fromVal[j]) && isPlainObject(fromVal[j]) && isPlainObject(toVal[j])) {\n relinkPrivateKeys(toVal[j], fromVal[j]);\n }\n }\n } else if(isPlainObject(fromVal) && isPlainObject(toVal)) {\n // recurse into objects, but only if they still exist\n relinkPrivateKeys(toVal, fromVal);\n\n if(!Object.keys(toVal).length) delete toContainer[k];\n }\n }\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar loggers = require('./loggers');\nvar identity = require('./identity');\nvar BADNUM = require('../constants/numerical').BADNUM;\n\n// don't trust floating point equality - fraction of bin size to call\n// \"on the line\" and ensure that they go the right way specified by\n// linelow\nvar roundingError = 1e-9;\n\n\n/**\n * findBin - find the bin for val - note that it can return outside the\n * bin range any pos. or neg. integer for linear bins, or -1 or\n * bins.length-1 for explicit.\n * bins is either an object {start,size,end} or an array length #bins+1\n * bins can be either increasing or decreasing but must be monotonic\n * for linear bins, we can just calculate. For listed bins, run a binary\n * search linelow (truthy) says the bin boundary should be attributed to\n * the lower bin rather than the default upper bin\n */\nexports.findBin = function(val, bins, linelow) {\n if(isNumeric(bins.start)) {\n return linelow ?\n Math.ceil((val - bins.start) / bins.size - roundingError) - 1 :\n Math.floor((val - bins.start) / bins.size + roundingError);\n } else {\n var n1 = 0;\n var n2 = bins.length;\n var c = 0;\n var binSize = (n2 > 1) ? (bins[n2 - 1] - bins[0]) / (n2 - 1) : 1;\n var n, test;\n if(binSize >= 0) {\n test = linelow ? lessThan : lessOrEqual;\n } else {\n test = linelow ? greaterOrEqual : greaterThan;\n }\n val += binSize * roundingError * (linelow ? -1 : 1) * (binSize >= 0 ? 1 : -1);\n // c is just to avoid infinite loops if there's an error\n while(n1 < n2 && c++ < 100) {\n n = Math.floor((n1 + n2) / 2);\n if(test(bins[n], val)) n1 = n + 1;\n else n2 = n;\n }\n if(c > 90) loggers.log('Long binary search...');\n return n1 - 1;\n }\n};\n\nfunction lessThan(a, b) { return a < b; }\nfunction lessOrEqual(a, b) { return a <= b; }\nfunction greaterThan(a, b) { return a > b; }\nfunction greaterOrEqual(a, b) { return a >= b; }\n\nexports.sorterAsc = function(a, b) { return a - b; };\nexports.sorterDes = function(a, b) { return b - a; };\n\n/**\n * find distinct values in an array, lumping together ones that appear to\n * just be off by a rounding error\n * return the distinct values and the minimum difference between any two\n */\nexports.distinctVals = function(valsIn) {\n var vals = valsIn.slice(); // otherwise we sort the original array...\n vals.sort(exports.sorterAsc); // undefined listed in the end - also works on IE11\n\n var last;\n for(last = vals.length - 1; last > -1; last--) {\n if(vals[last] !== BADNUM) break;\n }\n\n var minDiff = (vals[last] - vals[0]) || 1;\n var errDiff = minDiff / (last || 1) / 10000;\n var newVals = [];\n var preV;\n for(var i = 0; i <= last; i++) {\n var v = vals[i];\n\n // make sure values aren't just off by a rounding error\n var diff = v - preV;\n\n if(preV === undefined) {\n newVals.push(v);\n preV = v;\n } else if(diff > errDiff) {\n minDiff = Math.min(minDiff, diff);\n\n newVals.push(v);\n preV = v;\n }\n }\n\n return {vals: newVals, minDiff: minDiff};\n};\n\n/**\n * return the smallest element from (sorted) array arrayIn that's bigger than val,\n * or (reverse) the largest element smaller than val\n * used to find the best tick given the minimum (non-rounded) tick\n * particularly useful for date/time where things are not powers of 10\n * binary search is probably overkill here...\n */\nexports.roundUp = function(val, arrayIn, reverse) {\n var low = 0;\n var high = arrayIn.length - 1;\n var mid;\n var c = 0;\n var dlow = reverse ? 0 : 1;\n var dhigh = reverse ? 1 : 0;\n var rounded = reverse ? Math.ceil : Math.floor;\n // c is just to avoid infinite loops if there's an error\n while(low < high && c++ < 100) {\n mid = rounded((low + high) / 2);\n if(arrayIn[mid] <= val) low = mid + dlow;\n else high = mid - dhigh;\n }\n return arrayIn[low];\n};\n\n/**\n * Tweak to Array.sort(sortFn) that improves performance for pre-sorted arrays\n *\n * Note that newer browsers (such as Chrome v70+) are starting to pick up\n * on pre-sorted arrays which may render the following optimization unnecessary\n * in the future.\n *\n * Motivation: sometimes we need to sort arrays but the input is likely to\n * already be sorted. Browsers don't seem to pick up on pre-sorted arrays,\n * and in fact Chrome is actually *slower* sorting pre-sorted arrays than purely\n * random arrays. FF is at least faster if the array is pre-sorted, but still\n * not as fast as it could be.\n * Here's how this plays out sorting a length-1e6 array:\n *\n * Calls to Sort FN | Chrome bare | FF bare | Chrome tweak | FF tweak\n * | v68.0 Mac | v61.0 Mac| |\n * ------------------+---------------+-----------+----------------+------------\n * ordered | 30.4e6 | 10.1e6 | 1e6 | 1e6\n * reversed | 29.4e6 | 9.9e6 | 1e6 + reverse | 1e6 + reverse\n * random | ~21e6 | ~18.7e6 | ~21e6 | ~18.7e6\n *\n * So this is a substantial win for pre-sorted (ordered or exactly reversed)\n * arrays. Including this wrapper on an unsorted array adds a penalty that will\n * in general be only a few calls to the sort function. The only case this\n * penalty will be significant is if the array is mostly sorted but there are\n * a few unsorted items near the end, but the penalty is still at most N calls\n * out of (for N=1e6) ~20N total calls\n *\n * @param {Array} array: the array, to be sorted in place\n * @param {function} sortFn: As in Array.sort, function(a, b) that puts\n * item a before item b if the return is negative, a after b if positive,\n * and no change if zero.\n * @return {Array}: the original array, sorted in place.\n */\nexports.sort = function(array, sortFn) {\n var notOrdered = 0;\n var notReversed = 0;\n for(var i = 1; i < array.length; i++) {\n var pairOrder = sortFn(array[i], array[i - 1]);\n if(pairOrder < 0) notOrdered = 1;\n else if(pairOrder > 0) notReversed = 1;\n if(notOrdered && notReversed) return array.sort(sortFn);\n }\n return notReversed ? array : array.reverse();\n};\n\n/**\n * find index in array 'arr' that minimizes 'fn'\n *\n * @param {array} arr : array where to search\n * @param {fn (optional)} fn : function to minimize,\n * if not given, fn is the identity function\n * @return {integer}\n */\nexports.findIndexOfMin = function(arr, fn) {\n fn = fn || identity;\n\n var min = Infinity;\n var ind;\n\n for(var i = 0; i < arr.length; i++) {\n var v = fn(arr[i]);\n if(v < min) {\n min = v;\n ind = i;\n }\n }\n return ind;\n};\n","'use strict';\n\n// works with our CSS cursor classes (see css/_cursor.scss)\n// to apply cursors to d3 single-element selections.\n// omit cursor to revert to the default.\nmodule.exports = function setCursor(el3, csr) {\n (el3.attr('class') || '').split(' ').forEach(function(cls) {\n if(cls.indexOf('cursor-') === 0) el3.classed(cls, false);\n });\n\n if(csr) el3.classed('cursor-' + csr, true);\n};\n","'use strict';\n\nvar Color = require('../components/color');\n\nvar noop = function() {};\n\n\n/**\n * Prints a no webgl error message into the scene container\n * @param {scene instance} scene\n *\n * Expects 'scene' to have property 'container'\n *\n */\nmodule.exports = function showNoWebGlMsg(scene) {\n for(var prop in scene) {\n if(typeof scene[prop] === 'function') scene[prop] = noop;\n }\n\n scene.destroy = function() {\n scene.container.parentNode.removeChild(scene.container);\n };\n\n var div = document.createElement('div');\n div.className = 'no-webgl';\n div.style.cursor = 'pointer';\n div.style.fontSize = '24px';\n div.style.color = Color.defaults[0];\n div.style.position = 'absolute';\n div.style.left = div.style.top = '0px';\n div.style.width = div.style.height = '100%';\n div.style['background-color'] = Color.lightLine;\n div.style['z-index'] = 30;\n\n var p = document.createElement('p');\n p.textContent = 'WebGL is not supported by your browser - visit https://get.webgl.org for more info';\n p.style.position = 'relative';\n p.style.top = '50%';\n p.style.left = '50%';\n p.style.height = '30%';\n p.style.width = '50%';\n p.style.margin = '-15% 0 0 -25%';\n\n div.appendChild(p);\n scene.container.appendChild(div);\n scene.container.style.background = '#FFFFFF';\n scene.container.onclick = function() {\n window.open('https://get.webgl.org');\n };\n\n // return before setting up camera and onrender methods\n return false;\n};\n","'use strict';\n\nmodule.exports = function sortObjectKeys(obj) {\n return Object.keys(obj).sort();\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar isArrayOrTypedArray = require('./array').isArrayOrTypedArray;\n\n/**\n * aggNums() returns the result of an aggregate function applied to an array of\n * values, where non-numerical values have been tossed out.\n *\n * @param {function} f - aggregation function (e.g., Math.min)\n * @param {Number} v - initial value (continuing from previous calls)\n * if there's no continuing value, use null for selector-type\n * functions (max,min), or 0 for summations\n * @param {Array} a - array to aggregate (may be nested, we will recurse,\n * but all elements must have the same dimension)\n * @param {Number} len - maximum length of a to aggregate\n * @return {Number} - result of f applied to a starting from v\n */\nexports.aggNums = function(f, v, a, len) {\n var i,\n b;\n if(!len || len > a.length) len = a.length;\n if(!isNumeric(v)) v = false;\n if(isArrayOrTypedArray(a[0])) {\n b = new Array(len);\n for(i = 0; i < len; i++) b[i] = exports.aggNums(f, v, a[i]);\n a = b;\n }\n\n for(i = 0; i < len; i++) {\n if(!isNumeric(v)) v = a[i];\n else if(isNumeric(a[i])) v = f(+v, +a[i]);\n }\n return v;\n};\n\n/**\n * mean & std dev functions using aggNums, so it handles non-numerics nicely\n * even need to use aggNums instead of .length, to toss out non-numerics\n */\nexports.len = function(data) {\n return exports.aggNums(function(a) { return a + 1; }, 0, data);\n};\n\nexports.mean = function(data, len) {\n if(!len) len = exports.len(data);\n return exports.aggNums(function(a, b) { return a + b; }, 0, data) / len;\n};\n\nexports.geometricMean = function(data, len) {\n if(!len) len = exports.len(data);\n return Math.pow(exports.aggNums(function(a, b) { return a * b; }, 1, data), 1 / len);\n};\n\nexports.midRange = function(numArr) {\n if(numArr === undefined || numArr.length === 0) return undefined;\n return (exports.aggNums(Math.max, null, numArr) + exports.aggNums(Math.min, null, numArr)) / 2;\n};\n\nexports.variance = function(data, len, mean) {\n if(!len) len = exports.len(data);\n if(!isNumeric(mean)) mean = exports.mean(data, len);\n\n return exports.aggNums(function(a, b) {\n return a + Math.pow(b - mean, 2);\n }, 0, data) / len;\n};\n\nexports.stdev = function(data, len, mean) {\n return Math.sqrt(exports.variance(data, len, mean));\n};\n\n/**\n * median of a finite set of numbers\n * reference page: https://en.wikipedia.org/wiki/Median#Finite_set_of_numbers\n**/\nexports.median = function(data) {\n var b = data.slice().sort();\n return exports.interp(b, 0.5);\n};\n\n/**\n * interp() computes a percentile (quantile) for a given distribution.\n * We interpolate the distribution (to compute quantiles, we follow method #10 here:\n * http://jse.amstat.org/v14n3/langford.html).\n * Typically the index or rank (n * arr.length) may be non-integer.\n * For reference: ends are clipped to the extreme values in the array;\n * For box plots: index you get is half a point too high (see\n * http://en.wikipedia.org/wiki/Percentile#Nearest_rank) but note that this definition\n * indexes from 1 rather than 0, so we subtract 1/2 (instead of add).\n *\n * @param {Array} arr - This array contains the values that make up the distribution.\n * @param {Number} n - Between 0 and 1, n = p/100 is such that we compute the p^th percentile.\n * For example, the 50th percentile (or median) corresponds to n = 0.5\n * @return {Number} - percentile\n */\nexports.interp = function(arr, n) {\n if(!isNumeric(n)) throw 'n should be a finite number';\n n = n * arr.length - 0.5;\n if(n < 0) return arr[0];\n if(n > arr.length - 1) return arr[arr.length - 1];\n var frac = n % 1;\n return frac * arr[Math.ceil(n)] + (1 - frac) * arr[Math.floor(n)];\n};\n","'use strict';\n\nvar rgba = require('color-normalize');\n\nfunction str2RgbaArray(color) {\n if(!color) return [0, 0, 0, 1];\n return rgba(color);\n}\n\nmodule.exports = str2RgbaArray;\n","'use strict';\n\nvar constants = require('../constants/pixelated_image');\nvar Drawing = require('../components/drawing');\nvar Lib = require('../lib');\n\nvar _supportsPixelated = null;\n\n/**\n * Check browser support for pixelated image rendering\n *\n * @return {boolean}\n */\nfunction supportsPixelatedImage() {\n if(_supportsPixelated !== null) { // only run the feature detection once\n return _supportsPixelated;\n }\n\n _supportsPixelated = false;\n\n // @see https://github.com/plotly/plotly.js/issues/6604\n var unsupportedBrowser = Lib.isIE() || Lib.isSafari() || Lib.isIOS();\n\n if(window.navigator.userAgent && !unsupportedBrowser) {\n var declarations = Array.from(constants.CSS_DECLARATIONS).reverse();\n\n var supports = (window.CSS && window.CSS.supports) || window.supportsCSS;\n if(typeof supports === 'function') {\n _supportsPixelated = declarations.some(function(d) {\n return supports.apply(null, d);\n });\n } else {\n var image3 = Drawing.tester.append('image')\n .attr('style', constants.STYLE);\n\n var cStyles = window.getComputedStyle(image3.node());\n var imageRendering = cStyles.imageRendering;\n\n _supportsPixelated = declarations.some(function(d) {\n var value = d[1];\n return (\n imageRendering === value ||\n imageRendering === value.toLowerCase()\n );\n });\n\n image3.remove();\n }\n }\n\n return _supportsPixelated;\n}\n\nmodule.exports = supportsPixelatedImage;\n","'use strict';\n\n/* global MathJax:false */\n\nvar d3 = require('@plotly/d3');\n\nvar Lib = require('../lib');\nvar strTranslate = Lib.strTranslate;\nvar xmlnsNamespaces = require('../constants/xmlns_namespaces');\nvar LINE_SPACING = require('../constants/alignment').LINE_SPACING;\n\n// text converter\n\nvar FIND_TEX = /([^$]*)([$]+[^$]*[$]+)([^$]*)/;\n\nexports.convertToTspans = function(_context, gd, _callback) {\n var str = _context.text();\n\n // Until we get tex integrated more fully (so it can be used along with non-tex)\n // allow some elements to prohibit it by attaching 'data-notex' to the original\n var tex = (!_context.attr('data-notex')) &&\n gd && gd._context.typesetMath &&\n (typeof MathJax !== 'undefined') &&\n str.match(FIND_TEX);\n\n var parent = d3.select(_context.node().parentNode);\n if(parent.empty()) return;\n var svgClass = (_context.attr('class')) ? _context.attr('class').split(' ')[0] : 'text';\n svgClass += '-math';\n parent.selectAll('svg.' + svgClass).remove();\n parent.selectAll('g.' + svgClass + '-group').remove();\n _context.style('display', null)\n .attr({\n // some callers use data-unformatted *from the element* in 'cancel'\n // so we need it here even if we're going to turn it into math\n // these two (plus style and text-anchor attributes) form the key we're\n // going to use for Drawing.bBox\n 'data-unformatted': str,\n 'data-math': 'N'\n });\n\n function showText() {\n if(!parent.empty()) {\n svgClass = _context.attr('class') + '-math';\n parent.select('svg.' + svgClass).remove();\n }\n _context.text('')\n .style('white-space', 'pre');\n\n var hasLink = buildSVGText(_context.node(), str);\n\n if(hasLink) {\n // at least in Chrome, pointer-events does not seem\n // to be honored in children of elements\n // so if we have an anchor, we have to make the\n // whole element respond\n _context.style('pointer-events', 'all');\n }\n\n exports.positionText(_context);\n\n if(_callback) _callback.call(_context);\n }\n\n if(tex) {\n ((gd && gd._promises) || []).push(new Promise(function(resolve) {\n _context.style('display', 'none');\n var fontSize = parseInt(_context.node().style.fontSize, 10);\n var config = {fontSize: fontSize};\n\n texToSVG(tex[2], config, function(_svgEl, _glyphDefs, _svgBBox) {\n parent.selectAll('svg.' + svgClass).remove();\n parent.selectAll('g.' + svgClass + '-group').remove();\n\n var newSvg = _svgEl && _svgEl.select('svg');\n if(!newSvg || !newSvg.node()) {\n showText();\n resolve();\n return;\n }\n\n var mathjaxGroup = parent.append('g')\n .classed(svgClass + '-group', true)\n .attr({\n 'pointer-events': 'none',\n 'data-unformatted': str,\n 'data-math': 'Y'\n });\n\n mathjaxGroup.node().appendChild(newSvg.node());\n\n // stitch the glyph defs\n if(_glyphDefs && _glyphDefs.node()) {\n newSvg.node().insertBefore(_glyphDefs.node().cloneNode(true),\n newSvg.node().firstChild);\n }\n\n var w0 = _svgBBox.width;\n var h0 = _svgBBox.height;\n\n newSvg.attr({\n class: svgClass,\n height: h0,\n preserveAspectRatio: 'xMinYMin meet'\n })\n .style({overflow: 'visible', 'pointer-events': 'none'});\n\n var fill = _context.node().style.fill || 'black';\n var g = newSvg.select('g');\n g.attr({fill: fill, stroke: fill});\n\n var bb = g.node().getBoundingClientRect();\n var w = bb.width;\n var h = bb.height;\n\n if(w > w0 || h > h0) {\n // this happen in firefox v82+ | see https://bugzilla.mozilla.org/show_bug.cgi?id=1709251 addressed\n // temporary fix:\n newSvg.style('overflow', 'hidden');\n bb = newSvg.node().getBoundingClientRect();\n w = bb.width;\n h = bb.height;\n }\n\n var x = +_context.attr('x');\n var y = +_context.attr('y');\n\n // font baseline is about 1/4 fontSize below centerline\n var textHeight = fontSize || _context.node().getBoundingClientRect().height;\n var dy = -textHeight / 4;\n\n if(svgClass[0] === 'y') {\n mathjaxGroup.attr({\n transform: 'rotate(' + [-90, x, y] +\n ')' + strTranslate(-w / 2, dy - h / 2)\n });\n } else if(svgClass[0] === 'l') {\n y = dy - h / 2;\n } else if(svgClass[0] === 'a' && svgClass.indexOf('atitle') !== 0) {\n x = 0;\n y = dy;\n } else {\n var anchor = _context.attr('text-anchor');\n\n x = x - w * (\n anchor === 'middle' ? 0.5 :\n anchor === 'end' ? 1 : 0\n );\n y = y + dy - h / 2;\n }\n\n newSvg.attr({\n x: x,\n y: y\n });\n\n if(_callback) _callback.call(_context, mathjaxGroup);\n resolve(mathjaxGroup);\n });\n }));\n } else showText();\n\n return _context;\n};\n\n\n// MathJax\n\nvar LT_MATCH = /(<|<|<)/g;\nvar GT_MATCH = /(>|>|>)/g;\n\nfunction cleanEscapesForTex(s) {\n return s.replace(LT_MATCH, '\\\\lt ')\n .replace(GT_MATCH, '\\\\gt ');\n}\n\nvar inlineMath = [['$', '$'], ['\\\\(', '\\\\)']];\n\nfunction texToSVG(_texString, _config, _callback) {\n var MathJaxVersion = parseInt(\n (MathJax.version || '').split('.')[0]\n );\n\n if(\n MathJaxVersion !== 2 &&\n MathJaxVersion !== 3\n ) {\n Lib.warn('No MathJax version:', MathJax.version);\n return;\n }\n\n var originalRenderer,\n originalConfig,\n originalProcessSectionDelay,\n tmpDiv;\n\n var setConfig2 = function() {\n originalConfig = Lib.extendDeepAll({}, MathJax.Hub.config);\n\n originalProcessSectionDelay = MathJax.Hub.processSectionDelay;\n if(MathJax.Hub.processSectionDelay !== undefined) {\n // MathJax 2.5+ but not 3+\n MathJax.Hub.processSectionDelay = 0;\n }\n\n return MathJax.Hub.Config({\n messageStyle: 'none',\n tex2jax: {\n inlineMath: inlineMath\n },\n displayAlign: 'left',\n });\n };\n\n var setConfig3 = function() {\n originalConfig = Lib.extendDeepAll({}, MathJax.config);\n\n if(!MathJax.config.tex) {\n MathJax.config.tex = {};\n }\n\n MathJax.config.tex.inlineMath = inlineMath;\n };\n\n var setRenderer2 = function() {\n originalRenderer = MathJax.Hub.config.menuSettings.renderer;\n if(originalRenderer !== 'SVG') {\n return MathJax.Hub.setRenderer('SVG');\n }\n };\n\n var setRenderer3 = function() {\n originalRenderer = MathJax.config.startup.output;\n if(originalRenderer !== 'svg') {\n MathJax.config.startup.output = 'svg';\n }\n };\n\n var initiateMathJax = function() {\n var randomID = 'math-output-' + Lib.randstr({}, 64);\n tmpDiv = d3.select('body').append('div')\n .attr({id: randomID})\n .style({\n visibility: 'hidden',\n position: 'absolute',\n 'font-size': _config.fontSize + 'px'\n })\n .text(cleanEscapesForTex(_texString));\n\n var tmpNode = tmpDiv.node();\n\n return MathJaxVersion === 2 ?\n MathJax.Hub.Typeset(tmpNode) :\n MathJax.typeset([tmpNode]);\n };\n\n var finalizeMathJax = function() {\n var sel = tmpDiv.select(\n MathJaxVersion === 2 ? '.MathJax_SVG' : '.MathJax'\n );\n\n var node = !sel.empty() && tmpDiv.select('svg').node();\n if(!node) {\n Lib.log('There was an error in the tex syntax.', _texString);\n _callback();\n } else {\n var nodeBBox = node.getBoundingClientRect();\n var glyphDefs;\n if(MathJaxVersion === 2) {\n glyphDefs = d3.select('body').select('#MathJax_SVG_glyphs');\n } else {\n glyphDefs = sel.select('defs');\n }\n _callback(sel, glyphDefs, nodeBBox);\n }\n\n tmpDiv.remove();\n };\n\n var resetRenderer2 = function() {\n if(originalRenderer !== 'SVG') {\n return MathJax.Hub.setRenderer(originalRenderer);\n }\n };\n\n var resetRenderer3 = function() {\n if(originalRenderer !== 'svg') {\n MathJax.config.startup.output = originalRenderer;\n }\n };\n\n var resetConfig2 = function() {\n if(originalProcessSectionDelay !== undefined) {\n MathJax.Hub.processSectionDelay = originalProcessSectionDelay;\n }\n return MathJax.Hub.Config(originalConfig);\n };\n\n var resetConfig3 = function() {\n MathJax.config = originalConfig;\n };\n\n if(MathJaxVersion === 2) {\n MathJax.Hub.Queue(\n setConfig2,\n setRenderer2,\n initiateMathJax,\n finalizeMathJax,\n resetRenderer2,\n resetConfig2\n );\n } else if(MathJaxVersion === 3) {\n setConfig3();\n setRenderer3();\n MathJax.startup.defaultReady();\n\n MathJax.startup.promise.then(function() {\n initiateMathJax();\n finalizeMathJax();\n\n resetRenderer3();\n resetConfig3();\n });\n }\n}\n\nvar TAG_STYLES = {\n // would like to use baseline-shift for sub/sup but FF doesn't support it\n // so we need to use dy along with the uber hacky shift-back-to\n // baseline below\n sup: 'font-size:70%',\n sub: 'font-size:70%',\n s: 'text-decoration:line-through',\n u: 'text-decoration:underline',\n b: 'font-weight:bold',\n i: 'font-style:italic',\n a: 'cursor:pointer',\n span: '',\n em: 'font-style:italic;font-weight:bold'\n};\n\n// baseline shifts for sub and sup\nvar SHIFT_DY = {\n sub: '0.3em',\n sup: '-0.6em'\n};\n// reset baseline by adding a tspan (empty except for a zero-width space)\n// with dy of -70% * SHIFT_DY (because font-size=70%)\nvar RESET_DY = {\n sub: '-0.21em',\n sup: '0.42em'\n};\nvar ZERO_WIDTH_SPACE = '\\u200b';\n\n/*\n * Whitelist of protocols in user-supplied urls. Mostly we want to avoid javascript\n * and related attack vectors. The empty items are there for IE, that in various\n * versions treats relative paths as having different flavors of no protocol, while\n * other browsers have these explicitly inherit the protocol of the page they're in.\n */\nvar PROTOCOLS = ['http:', 'https:', 'mailto:', '', undefined, ':'];\n\nvar NEWLINES = exports.NEWLINES = /(\\r\\n?|\\n)/g;\n\nvar SPLIT_TAGS = /(<[^<>]*>)/;\n\nvar ONE_TAG = /<(\\/?)([^ >]*)(\\s+(.*))?>/i;\n\nvar BR_TAG = //i;\nexports.BR_TAG_ALL = //gi;\n\n/*\n * style and href: pull them out of either single or double quotes. Also\n * - target: (_blank|_self|_parent|_top|framename)\n * note that you can't use target to get a popup but if you use popup,\n * a `framename` will be passed along as the name of the popup window.\n * per the spec, cannot contain whitespace.\n * for backward compatibility we default to '_blank'\n * - popup: a custom one for us to enable popup (new window) links. String\n * for window.open -> strWindowFeatures, like 'menubar=yes,width=500,height=550'\n * note that at least in Chrome, you need to give at least one property\n * in this string or the page will open in a new tab anyway. We follow this\n * convention and will not make a popup if this string is empty.\n * per the spec, cannot contain whitespace.\n *\n * Because we hack in other attributes with style (sub & sup), drop any trailing\n * semicolon in user-supplied styles so we can consistently append the tag-dependent style\n *\n * These are for tag attributes; Chrome anyway will convert entities in\n * attribute values, but not in attribute names\n * you can test this by for example:\n * > p = document.createElement('p')\n * > p.innerHTML = 'Hi'\n * > p.innerHTML\n * <- 'Hi'\n */\nvar STYLEMATCH = /(^|[\\s\"'])style\\s*=\\s*(\"([^\"]*);?\"|'([^']*);?')/i;\nvar HREFMATCH = /(^|[\\s\"'])href\\s*=\\s*(\"([^\"]*)\"|'([^']*)')/i;\nvar TARGETMATCH = /(^|[\\s\"'])target\\s*=\\s*(\"([^\"\\s]*)\"|'([^'\\s]*)')/i;\nvar POPUPMATCH = /(^|[\\s\"'])popup\\s*=\\s*(\"([\\w=,]*)\"|'([\\w=,]*)')/i;\n\n// dedicated matcher for these quoted regexes, that can return their results\n// in two different places\nfunction getQuotedMatch(_str, re) {\n if(!_str) return null;\n var match = _str.match(re);\n var result = match && (match[3] || match[4]);\n return result && convertEntities(result);\n}\n\nvar COLORMATCH = /(^|;)\\s*color:/;\n\n/**\n * Strip string of tags\n *\n * @param {string} _str : input string\n * @param {object} opts :\n * - len {number} max length of output string\n * - allowedTags {array} list of pseudo-html tags to NOT strip\n * @return {string}\n */\nexports.plainText = function(_str, opts) {\n opts = opts || {};\n\n var len = (opts.len !== undefined && opts.len !== -1) ? opts.len : Infinity;\n var allowedTags = opts.allowedTags !== undefined ? opts.allowedTags : ['br'];\n\n var ellipsis = '...';\n var eLen = ellipsis.length;\n\n var oldParts = _str.split(SPLIT_TAGS);\n var newParts = [];\n var prevTag = '';\n var l = 0;\n\n for(var i = 0; i < oldParts.length; i++) {\n var p = oldParts[i];\n var match = p.match(ONE_TAG);\n var tagType = match && match[2].toLowerCase();\n\n if(tagType) {\n // N.B. tags do not count towards string length\n if(allowedTags.indexOf(tagType) !== -1) {\n newParts.push(p);\n prevTag = tagType;\n }\n } else {\n var pLen = p.length;\n\n if((l + pLen) < len) {\n newParts.push(p);\n l += pLen;\n } else if(l < len) {\n var pLen2 = len - l;\n\n if(prevTag && (prevTag !== 'br' || pLen2 <= eLen || pLen <= eLen)) {\n newParts.pop();\n }\n\n if(len > eLen) {\n newParts.push(p.substr(0, pLen2 - eLen) + ellipsis);\n } else {\n newParts.push(p.substr(0, pLen2));\n }\n break;\n }\n\n prevTag = '';\n }\n }\n\n return newParts.join('');\n};\n\n/*\n * N.B. HTML entities are listed without the leading '&' and trailing ';'\n * https://www.freeformatter.com/html-entities.html\n *\n * FWIW if we wanted to support the full set, it has 2261 entries:\n * https://www.w3.org/TR/html5/entities.json\n * though I notice that some of these are duplicates and/or are missing \";\"\n * eg: \"&\", \"&\", \"&\", and \"&\" all map to \"&\"\n * We no longer need to include numeric entities here, these are now handled\n * by String.fromCodePoint/fromCharCode\n *\n * Anyway the only ones that are really important to allow are the HTML special\n * chars <, >, and &, because these ones can trigger special processing if not\n * replaced by the corresponding entity.\n */\nvar entityToUnicode = {\n mu: 'μ',\n amp: '&',\n lt: '<',\n gt: '>',\n nbsp: ' ',\n times: '×',\n plusmn: '±',\n deg: '°'\n};\n\n// NOTE: in general entities can contain uppercase too (so [a-zA-Z]) but all the\n// ones we support use only lowercase. If we ever change that, update the regex.\nvar ENTITY_MATCH = /&(#\\d+|#x[\\da-fA-F]+|[a-z]+);/g;\nfunction convertEntities(_str) {\n return _str.replace(ENTITY_MATCH, function(fullMatch, innerMatch) {\n var outChar;\n if(innerMatch.charAt(0) === '#') {\n // cannot use String.fromCodePoint in IE\n outChar = fromCodePoint(\n innerMatch.charAt(1) === 'x' ?\n parseInt(innerMatch.substr(2), 16) :\n parseInt(innerMatch.substr(1), 10)\n );\n } else outChar = entityToUnicode[innerMatch];\n\n // as in regular HTML, if we didn't decode the entity just\n // leave the raw text in place.\n return outChar || fullMatch;\n });\n}\nexports.convertEntities = convertEntities;\n\nfunction fromCodePoint(code) {\n // Don't allow overflow. In Chrome this turns into � but I feel like it's\n // more useful to just not convert it at all.\n if(code > 0x10FFFF) return;\n var stringFromCodePoint = String.fromCodePoint;\n if(stringFromCodePoint) return stringFromCodePoint(code);\n\n // IE doesn't have String.fromCodePoint\n // see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/fromCodePoint\n var stringFromCharCode = String.fromCharCode;\n if(code <= 0xFFFF) return stringFromCharCode(code);\n return stringFromCharCode(\n (code >> 10) + 0xD7C0,\n (code % 0x400) + 0xDC00\n );\n}\n\n/*\n * buildSVGText: convert our pseudo-html into SVG tspan elements, and attach these\n * to containerNode\n *\n * @param {svg text element} containerNode: the node to insert this text into\n * @param {string} str: the pseudo-html string to convert to svg\n *\n * @returns {bool}: does the result contain any links? We need to handle the text element\n * somewhat differently if it does, so just keep track of this when it happens.\n */\nfunction buildSVGText(containerNode, str) {\n /*\n * Normalize behavior between IE and others wrt newlines and whitespace:pre\n * this combination makes IE barf https://github.com/plotly/plotly.js/issues/746\n * Chrome and FF display \\n, \\r, or \\r\\n as a space in this mode.\n * I feel like at some point we turned these into
but currently we don't so\n * I'm just going to cement what we do now in Chrome and FF\n */\n str = str.replace(NEWLINES, ' ');\n\n var hasLink = false;\n\n // as we're building the text, keep track of what elements we're nested inside\n // nodeStack will be an array of {node, type, style, href, target, popup}\n // where only type: 'a' gets the last 3 and node is only added when it's created\n var nodeStack = [];\n var currentNode;\n var currentLine = -1;\n\n function newLine() {\n currentLine++;\n\n var lineNode = document.createElementNS(xmlnsNamespaces.svg, 'tspan');\n d3.select(lineNode).attr({\n class: 'line',\n dy: (currentLine * LINE_SPACING) + 'em'\n });\n containerNode.appendChild(lineNode);\n\n currentNode = lineNode;\n\n var oldNodeStack = nodeStack;\n nodeStack = [{node: lineNode}];\n\n if(oldNodeStack.length > 1) {\n for(var i = 1; i < oldNodeStack.length; i++) {\n enterNode(oldNodeStack[i]);\n }\n }\n }\n\n function enterNode(nodeSpec) {\n var type = nodeSpec.type;\n var nodeAttrs = {};\n var nodeType;\n\n if(type === 'a') {\n nodeType = 'a';\n var target = nodeSpec.target;\n var href = nodeSpec.href;\n var popup = nodeSpec.popup;\n if(href) {\n nodeAttrs = {\n 'xlink:xlink:show': (target === '_blank' || target.charAt(0) !== '_') ? 'new' : 'replace',\n target: target,\n 'xlink:xlink:href': href\n };\n if(popup) {\n // security: href and target are not inserted as code but\n // as attributes. popup is, but limited to /[A-Za-z0-9_=,]/\n nodeAttrs.onclick = 'window.open(this.href.baseVal,this.target.baseVal,\"' +\n popup + '\");return false;';\n }\n }\n } else nodeType = 'tspan';\n\n if(nodeSpec.style) nodeAttrs.style = nodeSpec.style;\n\n var newNode = document.createElementNS(xmlnsNamespaces.svg, nodeType);\n\n if(type === 'sup' || type === 'sub') {\n addTextNode(currentNode, ZERO_WIDTH_SPACE);\n currentNode.appendChild(newNode);\n\n var resetter = document.createElementNS(xmlnsNamespaces.svg, 'tspan');\n addTextNode(resetter, ZERO_WIDTH_SPACE);\n d3.select(resetter).attr('dy', RESET_DY[type]);\n nodeAttrs.dy = SHIFT_DY[type];\n\n currentNode.appendChild(newNode);\n currentNode.appendChild(resetter);\n } else {\n currentNode.appendChild(newNode);\n }\n\n d3.select(newNode).attr(nodeAttrs);\n\n currentNode = nodeSpec.node = newNode;\n nodeStack.push(nodeSpec);\n }\n\n function addTextNode(node, text) {\n node.appendChild(document.createTextNode(text));\n }\n\n function exitNode(type) {\n // A bare closing tag can't close the root node. If we encounter this it\n // means there's an extra closing tag that can just be ignored:\n if(nodeStack.length === 1) {\n Lib.log('Ignoring unexpected end tag .', str);\n return;\n }\n\n var innerNode = nodeStack.pop();\n\n if(type !== innerNode.type) {\n Lib.log('Start tag <' + innerNode.type + '> doesnt match end tag <' +\n type + '>. Pretending it did match.', str);\n }\n currentNode = nodeStack[nodeStack.length - 1].node;\n }\n\n var hasLines = BR_TAG.test(str);\n\n if(hasLines) newLine();\n else {\n currentNode = containerNode;\n nodeStack = [{node: containerNode}];\n }\n\n var parts = str.split(SPLIT_TAGS);\n for(var i = 0; i < parts.length; i++) {\n var parti = parts[i];\n var match = parti.match(ONE_TAG);\n var tagType = match && match[2].toLowerCase();\n var tagStyle = TAG_STYLES[tagType];\n\n if(tagType === 'br') {\n newLine();\n } else if(tagStyle === undefined) {\n addTextNode(currentNode, convertEntities(parti));\n } else {\n // tag - open or close\n if(match[1]) {\n exitNode(tagType);\n } else {\n var extra = match[4];\n\n var nodeSpec = {type: tagType};\n\n // now add style, from both the tag name and any extra css\n // Most of the svg css that users will care about is just like html,\n // but font color is different (uses fill). Let our users ignore this.\n var css = getQuotedMatch(extra, STYLEMATCH);\n if(css) {\n css = css.replace(COLORMATCH, '$1 fill:');\n if(tagStyle) css += ';' + tagStyle;\n } else if(tagStyle) css = tagStyle;\n\n if(css) nodeSpec.style = css;\n\n if(tagType === 'a') {\n hasLink = true;\n\n var href = getQuotedMatch(extra, HREFMATCH);\n\n if(href) {\n var safeHref = sanitizeHref(href);\n if(safeHref) {\n nodeSpec.href = safeHref;\n nodeSpec.target = getQuotedMatch(extra, TARGETMATCH) || '_blank';\n nodeSpec.popup = getQuotedMatch(extra, POPUPMATCH);\n }\n }\n }\n\n enterNode(nodeSpec);\n }\n }\n }\n\n return hasLink;\n}\n\nfunction sanitizeHref(href) {\n var decodedHref = encodeURI(decodeURI(href));\n var dummyAnchor1 = document.createElement('a');\n var dummyAnchor2 = document.createElement('a');\n dummyAnchor1.href = href;\n dummyAnchor2.href = decodedHref;\n\n var p1 = dummyAnchor1.protocol;\n var p2 = dummyAnchor2.protocol;\n\n // check safe protocols\n if(\n PROTOCOLS.indexOf(p1) !== -1 &&\n PROTOCOLS.indexOf(p2) !== -1\n ) {\n return decodedHref;\n } else {\n return '';\n }\n}\n\n/*\n * sanitizeHTML: port of buildSVGText aimed at providing a clean subset of HTML\n * @param {string} str: the html string to clean\n * @returns {string}: a cleaned and normalized version of the input,\n * supporting only a small subset of html\n */\nexports.sanitizeHTML = function sanitizeHTML(str) {\n str = str.replace(NEWLINES, ' ');\n\n var rootNode = document.createElement('p');\n var currentNode = rootNode;\n var nodeStack = [];\n\n var parts = str.split(SPLIT_TAGS);\n for(var i = 0; i < parts.length; i++) {\n var parti = parts[i];\n var match = parti.match(ONE_TAG);\n var tagType = match && match[2].toLowerCase();\n\n if(tagType in TAG_STYLES) {\n if(match[1]) {\n if(nodeStack.length) {\n currentNode = nodeStack.pop();\n }\n } else {\n var extra = match[4];\n\n var css = getQuotedMatch(extra, STYLEMATCH);\n var nodeAttrs = css ? {style: css} : {};\n\n if(tagType === 'a') {\n var href = getQuotedMatch(extra, HREFMATCH);\n\n if(href) {\n var safeHref = sanitizeHref(href);\n if(safeHref) {\n nodeAttrs.href = safeHref;\n var target = getQuotedMatch(extra, TARGETMATCH);\n if(target) {\n nodeAttrs.target = target;\n }\n }\n }\n }\n\n var newNode = document.createElement(tagType);\n currentNode.appendChild(newNode);\n d3.select(newNode).attr(nodeAttrs);\n\n currentNode = newNode;\n nodeStack.push(newNode);\n }\n } else {\n currentNode.appendChild(\n document.createTextNode(convertEntities(parti))\n );\n }\n }\n var key = 'innerHTML'; // i.e. to avoid pass test-syntax\n return rootNode[key];\n};\n\nexports.lineCount = function lineCount(s) {\n return s.selectAll('tspan.line').size() || 1;\n};\n\nexports.positionText = function positionText(s, x, y) {\n return s.each(function() {\n var text = d3.select(this);\n\n function setOrGet(attr, val) {\n if(val === undefined) {\n val = text.attr(attr);\n if(val === null) {\n text.attr(attr, 0);\n val = 0;\n }\n } else text.attr(attr, val);\n return val;\n }\n\n var thisX = setOrGet('x', x);\n var thisY = setOrGet('y', y);\n\n if(this.nodeName === 'text') {\n text.selectAll('tspan.line').attr({x: thisX, y: thisY});\n }\n });\n};\n\nfunction alignHTMLWith(_base, container, options) {\n var alignH = options.horizontalAlign;\n var alignV = options.verticalAlign || 'top';\n var bRect = _base.node().getBoundingClientRect();\n var cRect = container.node().getBoundingClientRect();\n var thisRect;\n var getTop;\n var getLeft;\n\n if(alignV === 'bottom') {\n getTop = function() { return bRect.bottom - thisRect.height; };\n } else if(alignV === 'middle') {\n getTop = function() { return bRect.top + (bRect.height - thisRect.height) / 2; };\n } else { // default: top\n getTop = function() { return bRect.top; };\n }\n\n if(alignH === 'right') {\n getLeft = function() { return bRect.right - thisRect.width; };\n } else if(alignH === 'center') {\n getLeft = function() { return bRect.left + (bRect.width - thisRect.width) / 2; };\n } else { // default: left\n getLeft = function() { return bRect.left; };\n }\n\n return function() {\n thisRect = this.node().getBoundingClientRect();\n\n var x0 = getLeft() - cRect.left;\n var y0 = getTop() - cRect.top;\n var gd = options.gd || {};\n if(options.gd) {\n gd._fullLayout._calcInverseTransform(gd);\n var transformedCoords = Lib.apply3DTransform(gd._fullLayout._invTransform)(x0, y0);\n x0 = transformedCoords[0];\n y0 = transformedCoords[1];\n }\n\n this.style({\n top: y0 + 'px',\n left: x0 + 'px',\n 'z-index': 1000\n });\n return this;\n };\n}\n\nvar onePx = '1px ';\n\nexports.makeTextShadow = function(color) {\n var x = onePx;\n var y = onePx;\n var b = onePx;\n return x + y + b + color + ', ' +\n '-' + x + '-' + y + b + color + ', ' +\n x + '-' + y + b + color + ', ' +\n '-' + x + y + b + color;\n};\n\n/*\n * Editable title\n * @param {d3.selection} context: the element being edited. Normally text,\n * but if it isn't, you should provide the styling options\n * @param {object} options:\n * @param {div} options.gd: graphDiv\n * @param {d3.selection} options.delegate: item to bind events to if not this\n * @param {boolean} options.immediate: start editing now (true) or on click (false, default)\n * @param {string} options.fill: font color if not as shown\n * @param {string} options.background: background color if not as shown\n * @param {string} options.text: initial text, if not as shown\n * @param {string} options.horizontalAlign: alignment of the edit box wrt. the bound element\n * @param {string} options.verticalAlign: alignment of the edit box wrt. the bound element\n */\n\nexports.makeEditable = function(context, options) {\n var gd = options.gd;\n var _delegate = options.delegate;\n var dispatch = d3.dispatch('edit', 'input', 'cancel');\n var handlerElement = _delegate || context;\n\n context.style({'pointer-events': _delegate ? 'none' : 'all'});\n\n if(context.size() !== 1) throw new Error('boo');\n\n function handleClick() {\n appendEditable();\n context.style({opacity: 0});\n // also hide any mathjax svg\n var svgClass = handlerElement.attr('class');\n var mathjaxClass;\n if(svgClass) mathjaxClass = '.' + svgClass.split(' ')[0] + '-math-group';\n else mathjaxClass = '[class*=-math-group]';\n if(mathjaxClass) {\n d3.select(context.node().parentNode).select(mathjaxClass).style({opacity: 0});\n }\n }\n\n function selectElementContents(_el) {\n var el = _el.node();\n var range = document.createRange();\n range.selectNodeContents(el);\n var sel = window.getSelection();\n sel.removeAllRanges();\n sel.addRange(range);\n el.focus();\n }\n\n function appendEditable() {\n var plotDiv = d3.select(gd);\n var container = plotDiv.select('.svg-container');\n var div = container.append('div');\n var cStyle = context.node().style;\n var fontSize = parseFloat(cStyle.fontSize || 12);\n\n var initialText = options.text;\n if(initialText === undefined) initialText = context.attr('data-unformatted');\n\n div.classed('plugin-editable editable', true)\n .style({\n position: 'absolute',\n 'font-family': cStyle.fontFamily || 'Arial',\n 'font-size': fontSize,\n color: options.fill || cStyle.fill || 'black',\n opacity: 1,\n 'background-color': options.background || 'transparent',\n outline: '#ffffff33 1px solid',\n margin: [-fontSize / 8 + 1, 0, 0, -1].join('px ') + 'px',\n padding: '0',\n 'box-sizing': 'border-box'\n })\n .attr({contenteditable: true})\n .text(initialText)\n .call(alignHTMLWith(context, container, options))\n .on('blur', function() {\n gd._editing = false;\n context.text(this.textContent)\n .style({opacity: 1});\n var svgClass = d3.select(this).attr('class');\n var mathjaxClass;\n if(svgClass) mathjaxClass = '.' + svgClass.split(' ')[0] + '-math-group';\n else mathjaxClass = '[class*=-math-group]';\n if(mathjaxClass) {\n d3.select(context.node().parentNode).select(mathjaxClass).style({opacity: 0});\n }\n var text = this.textContent;\n d3.select(this).transition().duration(0).remove();\n d3.select(document).on('mouseup', null);\n dispatch.edit.call(context, text);\n })\n .on('focus', function() {\n var editDiv = this;\n gd._editing = true;\n d3.select(document).on('mouseup', function() {\n if(d3.event.target === editDiv) return false;\n if(document.activeElement === div.node()) div.node().blur();\n });\n })\n .on('keyup', function() {\n if(d3.event.which === 27) {\n gd._editing = false;\n context.style({opacity: 1});\n d3.select(this)\n .style({opacity: 0})\n .on('blur', function() { return false; })\n .transition().remove();\n dispatch.cancel.call(context, this.textContent);\n } else {\n dispatch.input.call(context, this.textContent);\n d3.select(this).call(alignHTMLWith(context, container, options));\n }\n })\n .on('keydown', function() {\n if(d3.event.which === 13) this.blur();\n })\n .call(selectElementContents);\n }\n\n if(options.immediate) handleClick();\n else handlerElement.on('click', handleClick);\n\n return d3.rebind(context, dispatch, 'on');\n};\n","'use strict';\n\nvar timerCache = {};\n\n/**\n * Throttle a callback. `callback` executes synchronously only if\n * more than `minInterval` milliseconds have already elapsed since the latest\n * call (if any). Otherwise we wait until `minInterval` is over and execute the\n * last callback received while waiting.\n * So the first and last events in a train are always executed (eventually)\n * but some of the events in the middle can be dropped.\n *\n * @param {string} id: an identifier to mark events to throttle together\n * @param {number} minInterval: minimum time, in milliseconds, between\n * invocations of `callback`\n * @param {function} callback: the function to throttle. `callback` itself\n * should be a purely synchronous function.\n */\nexports.throttle = function throttle(id, minInterval, callback) {\n var cache = timerCache[id];\n var now = Date.now();\n\n if(!cache) {\n /*\n * Throw out old items before making a new one, to prevent the cache\n * getting overgrown, for example from old plots that have been replaced.\n * 1 minute age is arbitrary.\n */\n for(var idi in timerCache) {\n if(timerCache[idi].ts < now - 60000) {\n delete timerCache[idi];\n }\n }\n cache = timerCache[id] = {ts: 0, timer: null};\n }\n\n _clearTimeout(cache);\n\n function exec() {\n callback();\n cache.ts = Date.now();\n if(cache.onDone) {\n cache.onDone();\n cache.onDone = null;\n }\n }\n\n if(now > cache.ts + minInterval) {\n exec();\n return;\n }\n\n cache.timer = setTimeout(function() {\n exec();\n cache.timer = null;\n }, minInterval);\n};\n\nexports.done = function(id) {\n var cache = timerCache[id];\n if(!cache || !cache.timer) return Promise.resolve();\n\n return new Promise(function(resolve) {\n var previousOnDone = cache.onDone;\n cache.onDone = function onDone() {\n if(previousOnDone) previousOnDone();\n resolve();\n cache.onDone = null;\n };\n });\n};\n\n/**\n * Clear the throttle cache for one or all timers\n * @param {optional string} id:\n * if provided, clear just this timer\n * if omitted, clear all timers (mainly useful for testing)\n */\nexports.clear = function(id) {\n if(id) {\n _clearTimeout(timerCache[id]);\n delete timerCache[id];\n } else {\n for(var idi in timerCache) exports.clear(idi);\n }\n};\n\nfunction _clearTimeout(cache) {\n if(cache && cache.timer !== null) {\n clearTimeout(cache.timer);\n cache.timer = null;\n }\n}\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\n/**\n * convert a linear value into a logged value, folding negative numbers into\n * the given range\n */\nmodule.exports = function toLogRange(val, range) {\n if(val > 0) return Math.log(val) / Math.LN10;\n\n // move a negative value reference to a log axis - just put the\n // result at the lowest range value on the plot (or if the range also went negative,\n // one millionth of the top of the range)\n var newVal = Math.log(Math.min(range[0], range[1])) / Math.LN10;\n if(!isNumeric(newVal)) newVal = Math.log(Math.max(range[0], range[1])) / Math.LN10 - 6;\n return newVal;\n};\n","'use strict';\n\nvar topojsonUtils = module.exports = {};\n\nvar locationmodeToLayer = require('../plots/geo/constants').locationmodeToLayer;\nvar topojsonFeature = require('topojson-client').feature;\n\ntopojsonUtils.getTopojsonName = function(geoLayout) {\n return [\n geoLayout.scope.replace(/ /g, '-'), '_',\n geoLayout.resolution.toString(), 'm'\n ].join('');\n};\n\ntopojsonUtils.getTopojsonPath = function(topojsonURL, topojsonName) {\n return topojsonURL + topojsonName + '.json';\n};\n\ntopojsonUtils.getTopojsonFeatures = function(trace, topojson) {\n var layer = locationmodeToLayer[trace.locationmode];\n var obj = topojson.objects[layer];\n\n return topojsonFeature(topojson, obj).features;\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'locale',\n name: 'en-US',\n dictionary: {\n 'Click to enter Colorscale title': 'Click to enter Colorscale title'\n },\n format: {\n date: '%m/%d/%Y'\n }\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'locale',\n name: 'en',\n dictionary: {\n 'Click to enter Colorscale title': 'Click to enter Colourscale title'\n },\n format: {\n days: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],\n shortDays: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n months: [\n 'January', 'February', 'March', 'April', 'May', 'June',\n 'July', 'August', 'September', 'October', 'November', 'December'\n ],\n shortMonths: [\n 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',\n 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'\n ],\n periods: ['AM', 'PM'],\n dateTime: '%a %b %e %X %Y',\n date: '%d/%m/%Y',\n time: '%H:%M:%S',\n decimal: '.',\n thousands: ',',\n grouping: [3],\n currency: ['$', ''],\n year: '%Y',\n month: '%b %Y',\n dayMonth: '%b %-d',\n dayMonthYear: '%b %-d, %Y'\n }\n};\n","'use strict';\n\nvar Registry = require('../registry');\n\n/*\n * containerArrayMatch: does this attribute string point into a\n * layout container array?\n *\n * @param {String} astr: an attribute string, like *annotations[2].text*\n *\n * @returns {Object | false} Returns false if `astr` doesn't match a container\n * array. If it does, returns:\n * {array: {String}, index: {Number}, property: {String}}\n * ie the attribute string for the array, the index within the array (or ''\n * if the whole array) and the property within that (or '' if the whole array\n * or the whole object)\n */\nmodule.exports = function containerArrayMatch(astr) {\n var rootContainers = Registry.layoutArrayContainers;\n var regexpContainers = Registry.layoutArrayRegexes;\n var rootPart = astr.split('[')[0];\n var arrayStr;\n var match;\n\n // look for regexp matches first, because they may be nested inside root matches\n // eg updatemenus[i].buttons is nested inside updatemenus\n for(var i = 0; i < regexpContainers.length; i++) {\n match = astr.match(regexpContainers[i]);\n if(match && match.index === 0) {\n arrayStr = match[0];\n break;\n }\n }\n\n // now look for root matches\n if(!arrayStr) arrayStr = rootContainers[rootContainers.indexOf(rootPart)];\n\n if(!arrayStr) return false;\n\n var tail = astr.substr(arrayStr.length);\n if(!tail) return {array: arrayStr, index: '', property: ''};\n\n match = tail.match(/^\\[(0|[1-9][0-9]*)\\](\\.(.+))?$/);\n if(!match) return false;\n\n return {array: arrayStr, index: Number(match[1]), property: match[3] || ''};\n};\n","'use strict';\n\nvar extendFlat = require('../lib/extend').extendFlat;\nvar isPlainObject = require('../lib/is_plain_object');\n\nvar traceOpts = {\n valType: 'flaglist',\n extras: ['none'],\n flags: ['calc', 'clearAxisTypes', 'plot', 'style', 'markerSize', 'colorbars'],\n description: [\n 'trace attributes should include an `editType` string matching this flaglist.',\n '*calc* is the most extensive: a full (re)plot starting by clearing `gd.calcdata`',\n 'to force it to be regenerated',\n '*clearAxisTypes* resets the types of the axes this trace is on, because new data could',\n 'cause the automatic axis type detection to change. Log type will not be cleared, as that',\n 'is never automatically chosen so must have been user-specified.',\n '*plot* (re)plots but without first clearing `gd.calcdata`.',\n '*style* only calls `module.style` (or module.editStyle) for all trace modules and redraws the legend.',\n '*markerSize* is like *style*, but propagate axis-range changes due to scatter `marker.size`',\n '*colorbars* only redraws colorbars.'\n ].join(' ')\n};\n\nvar layoutOpts = {\n valType: 'flaglist',\n extras: ['none'],\n flags: [\n 'calc', 'plot', 'legend', 'ticks', 'axrange',\n 'layoutstyle', 'modebar', 'camera', 'arraydraw', 'colorbars'\n ],\n description: [\n 'layout attributes should include an `editType` string matching this flaglist.',\n '*calc* is the most extensive: a full (re)plot starting by clearing `gd.calcdata`',\n 'to force it to be regenerated',\n '*plot* (re)plots but without first clearing `gd.calcdata`.',\n '*legend* only redraws the legend.',\n '*ticks* only redraws axis ticks, labels, and gridlines.',\n '*axrange* minimal sequence when updating axis ranges.',\n '*layoutstyle* reapplies global and SVG cartesian axis styles.',\n '*modebar* just updates the modebar.',\n '*camera* just updates the camera settings for gl3d scenes.',\n '*arraydraw* allows component arrays to invoke the redraw routines just for the',\n 'component(s) that changed.',\n '*colorbars* only redraws colorbars.'\n ].join(' ')\n};\n\n// flags for inside restyle/relayout include a few extras\n// that shouldn't be used in attributes, to deal with certain\n// combinations and conditionals efficiently\nvar traceEditTypeFlags = traceOpts.flags.slice()\n .concat(['fullReplot']);\n\nvar layoutEditTypeFlags = layoutOpts.flags.slice()\n .concat('layoutReplot');\n\nmodule.exports = {\n traces: traceOpts,\n layout: layoutOpts,\n /*\n * default (all false) edit flags for restyle (traces)\n * creates a new object each call, so the caller can mutate freely\n */\n traceFlags: function() { return falseObj(traceEditTypeFlags); },\n\n /*\n * default (all false) edit flags for relayout\n * creates a new object each call, so the caller can mutate freely\n */\n layoutFlags: function() { return falseObj(layoutEditTypeFlags); },\n\n /*\n * update `flags` with the `editType` values found in `attr`\n */\n update: function(flags, attr) {\n var editType = attr.editType;\n if(editType && editType !== 'none') {\n var editTypeParts = editType.split('+');\n for(var i = 0; i < editTypeParts.length; i++) {\n flags[editTypeParts[i]] = true;\n }\n }\n },\n\n overrideAll: overrideAll\n};\n\nfunction falseObj(keys) {\n var out = {};\n for(var i = 0; i < keys.length; i++) out[keys[i]] = false;\n return out;\n}\n\n/**\n * For attributes that are largely copied from elsewhere into a plot type that doesn't\n * support partial redraws - overrides the editType field of all attributes in the object\n *\n * @param {object} attrs: the attributes to override. Will not be mutated.\n * @param {string} editTypeOverride: the new editType to use\n * @param {'nested'|'from-root'} overrideContainers:\n * - 'nested' will override editType for nested containers but not the root.\n * - 'from-root' will also override editType of the root container.\n * Containers below the absolute top level (trace or layout root) DO need an\n * editType even if they are not `valObject`s themselves (eg `scatter.marker`)\n * to handle the case where you edit the whole container.\n *\n * @return {object} a new attributes object with `editType` modified as directed\n */\nfunction overrideAll(attrs, editTypeOverride, overrideContainers) {\n var out = extendFlat({}, attrs);\n for(var key in out) {\n var attr = out[key];\n if(isPlainObject(attr)) {\n out[key] = overrideOne(attr, editTypeOverride, overrideContainers, key);\n }\n }\n if(overrideContainers === 'from-root') out.editType = editTypeOverride;\n\n return out;\n}\n\nfunction overrideOne(attr, editTypeOverride, overrideContainers, key) {\n if(attr.valType) {\n var out = extendFlat({}, attr);\n out.editType = editTypeOverride;\n\n if(Array.isArray(attr.items)) {\n out.items = new Array(attr.items.length);\n for(var i = 0; i < attr.items.length; i++) {\n out.items[i] = overrideOne(attr.items[i], editTypeOverride, 'from-root');\n }\n }\n return out;\n } else {\n // don't provide an editType for the _deprecated container\n return overrideAll(attr, editTypeOverride,\n (key.charAt(0) === '_') ? 'nested' : 'from-root');\n }\n}\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar m4FromQuat = require('gl-mat4/fromQuat');\n\nvar Registry = require('../registry');\nvar Lib = require('../lib');\nvar Plots = require('../plots/plots');\nvar AxisIds = require('../plots/cartesian/axis_ids');\nvar Color = require('../components/color');\n\nvar cleanId = AxisIds.cleanId;\nvar getFromTrace = AxisIds.getFromTrace;\nvar traceIs = Registry.traceIs;\n\n// clear the promise queue if one of them got rejected\nexports.clearPromiseQueue = function(gd) {\n if(Array.isArray(gd._promises) && gd._promises.length > 0) {\n Lib.log('Clearing previous rejected promises from queue.');\n }\n\n gd._promises = [];\n};\n\n// make a few changes to the layout right away\n// before it gets used for anything\n// backward compatibility and cleanup of nonstandard options\nexports.cleanLayout = function(layout) {\n var i, j;\n\n if(!layout) layout = {};\n\n // cannot have (x|y)axis1, numbering goes axis, axis2, axis3...\n if(layout.xaxis1) {\n if(!layout.xaxis) layout.xaxis = layout.xaxis1;\n delete layout.xaxis1;\n }\n if(layout.yaxis1) {\n if(!layout.yaxis) layout.yaxis = layout.yaxis1;\n delete layout.yaxis1;\n }\n if(layout.scene1) {\n if(!layout.scene) layout.scene = layout.scene1;\n delete layout.scene1;\n }\n\n var axisAttrRegex = (Plots.subplotsRegistry.cartesian || {}).attrRegex;\n var polarAttrRegex = (Plots.subplotsRegistry.polar || {}).attrRegex;\n var ternaryAttrRegex = (Plots.subplotsRegistry.ternary || {}).attrRegex;\n var sceneAttrRegex = (Plots.subplotsRegistry.gl3d || {}).attrRegex;\n\n var keys = Object.keys(layout);\n for(i = 0; i < keys.length; i++) {\n var key = keys[i];\n\n if(axisAttrRegex && axisAttrRegex.test(key)) {\n // modifications to cartesian axes\n\n var ax = layout[key];\n if(ax.anchor && ax.anchor !== 'free') {\n ax.anchor = cleanId(ax.anchor);\n }\n if(ax.overlaying) ax.overlaying = cleanId(ax.overlaying);\n\n // old method of axis type - isdate and islog (before category existed)\n if(!ax.type) {\n if(ax.isdate) ax.type = 'date';\n else if(ax.islog) ax.type = 'log';\n else if(ax.isdate === false && ax.islog === false) ax.type = 'linear';\n }\n if(ax.autorange === 'withzero' || ax.autorange === 'tozero') {\n ax.autorange = true;\n ax.rangemode = 'tozero';\n }\n\n if(ax.insiderange) delete ax.range;\n\n delete ax.islog;\n delete ax.isdate;\n delete ax.categories; // replaced by _categories\n\n // prune empty domain arrays made before the new nestedProperty\n if(emptyContainer(ax, 'domain')) delete ax.domain;\n\n // autotick -> tickmode\n if(ax.autotick !== undefined) {\n if(ax.tickmode === undefined) {\n ax.tickmode = ax.autotick ? 'auto' : 'linear';\n }\n delete ax.autotick;\n }\n\n cleanTitle(ax);\n } else if(polarAttrRegex && polarAttrRegex.test(key)) {\n // modifications for polar\n\n var polar = layout[key];\n cleanTitle(polar.radialaxis);\n } else if(ternaryAttrRegex && ternaryAttrRegex.test(key)) {\n // modifications for ternary\n\n var ternary = layout[key];\n cleanTitle(ternary.aaxis);\n cleanTitle(ternary.baxis);\n cleanTitle(ternary.caxis);\n } else if(sceneAttrRegex && sceneAttrRegex.test(key)) {\n // modifications for 3D scenes\n\n var scene = layout[key];\n\n // clean old Camera coords\n var cameraposition = scene.cameraposition;\n\n if(Array.isArray(cameraposition) && cameraposition[0].length === 4) {\n var rotation = cameraposition[0];\n var center = cameraposition[1];\n var radius = cameraposition[2];\n var mat = m4FromQuat([], rotation);\n var eye = [];\n\n for(j = 0; j < 3; ++j) {\n eye[j] = center[j] + radius * mat[2 + 4 * j];\n }\n\n scene.camera = {\n eye: {x: eye[0], y: eye[1], z: eye[2]},\n center: {x: center[0], y: center[1], z: center[2]},\n up: {x: 0, y: 0, z: 1} // we just ignore calculating camera z up in this case\n };\n\n delete scene.cameraposition;\n }\n\n // clean axis titles\n cleanTitle(scene.xaxis);\n cleanTitle(scene.yaxis);\n cleanTitle(scene.zaxis);\n }\n }\n\n var annotationsLen = Array.isArray(layout.annotations) ? layout.annotations.length : 0;\n for(i = 0; i < annotationsLen; i++) {\n var ann = layout.annotations[i];\n\n if(!Lib.isPlainObject(ann)) continue;\n\n if(ann.ref) {\n if(ann.ref === 'paper') {\n ann.xref = 'paper';\n ann.yref = 'paper';\n } else if(ann.ref === 'data') {\n ann.xref = 'x';\n ann.yref = 'y';\n }\n delete ann.ref;\n }\n\n cleanAxRef(ann, 'xref');\n cleanAxRef(ann, 'yref');\n }\n\n var shapesLen = Array.isArray(layout.shapes) ? layout.shapes.length : 0;\n for(i = 0; i < shapesLen; i++) {\n var shape = layout.shapes[i];\n\n if(!Lib.isPlainObject(shape)) continue;\n\n cleanAxRef(shape, 'xref');\n cleanAxRef(shape, 'yref');\n }\n\n var imagesLen = Array.isArray(layout.images) ? layout.images.length : 0;\n for(i = 0; i < imagesLen; i++) {\n var image = layout.images[i];\n\n if(!Lib.isPlainObject(image)) continue;\n\n cleanAxRef(image, 'xref');\n cleanAxRef(image, 'yref');\n }\n\n var legend = layout.legend;\n if(legend) {\n // check for old-style legend positioning (x or y is +/- 100)\n if(legend.x > 3) {\n legend.x = 1.02;\n legend.xanchor = 'left';\n } else if(legend.x < -2) {\n legend.x = -0.02;\n legend.xanchor = 'right';\n }\n\n if(legend.y > 3) {\n legend.y = 1.02;\n legend.yanchor = 'bottom';\n } else if(legend.y < -2) {\n legend.y = -0.02;\n legend.yanchor = 'top';\n }\n }\n\n // clean plot title\n cleanTitle(layout);\n\n /*\n * Moved from rotate -> orbit for dragmode\n */\n if(layout.dragmode === 'rotate') layout.dragmode = 'orbit';\n\n // sanitize rgb(fractions) and rgba(fractions) that old tinycolor\n // supported, but new tinycolor does not because they're not valid css\n Color.clean(layout);\n\n // clean the layout container in layout.template\n if(layout.template && layout.template.layout) {\n exports.cleanLayout(layout.template.layout);\n }\n\n return layout;\n};\n\nfunction cleanAxRef(container, attr) {\n var valIn = container[attr];\n var axLetter = attr.charAt(0);\n if(valIn && valIn !== 'paper') {\n container[attr] = cleanId(valIn, axLetter, true);\n }\n}\n\n/**\n * Cleans up old title attribute structure (flat) in favor of the new one (nested).\n *\n * @param {Object} titleContainer - an object potentially including deprecated title attributes\n */\nfunction cleanTitle(titleContainer) {\n if(titleContainer) {\n // title -> title.text\n // (although title used to be a string attribute,\n // numbers are accepted as well)\n if(typeof titleContainer.title === 'string' || typeof titleContainer.title === 'number') {\n titleContainer.title = {\n text: titleContainer.title\n };\n }\n\n rewireAttr('titlefont', 'font');\n rewireAttr('titleposition', 'position');\n rewireAttr('titleside', 'side');\n rewireAttr('titleoffset', 'offset');\n }\n\n function rewireAttr(oldAttrName, newAttrName) {\n var oldAttrSet = titleContainer[oldAttrName];\n var newAttrSet = titleContainer.title && titleContainer.title[newAttrName];\n\n if(oldAttrSet && !newAttrSet) {\n // Ensure title object exists\n if(!titleContainer.title) {\n titleContainer.title = {};\n }\n\n titleContainer.title[newAttrName] = titleContainer[oldAttrName];\n delete titleContainer[oldAttrName];\n }\n }\n}\n\n/*\n * cleanData: Make a few changes to the data for backward compatibility\n * before it gets used for anything. Modifies the data traces users provide.\n *\n * Important: if you're going to add something here that modifies a data array,\n * update it in place so the new array === the old one.\n */\nexports.cleanData = function(data) {\n for(var tracei = 0; tracei < data.length; tracei++) {\n var trace = data[tracei];\n var i;\n\n // use xbins to bin data in x, and ybins to bin data in y\n if(trace.type === 'histogramy' && 'xbins' in trace && !('ybins' in trace)) {\n trace.ybins = trace.xbins;\n delete trace.xbins;\n }\n\n // error_y.opacity is obsolete - merge into color\n if(trace.error_y && 'opacity' in trace.error_y) {\n var dc = Color.defaults;\n var yeColor = trace.error_y.color || (traceIs(trace, 'bar') ?\n Color.defaultLine :\n dc[tracei % dc.length]);\n trace.error_y.color = Color.addOpacity(\n Color.rgb(yeColor),\n Color.opacity(yeColor) * trace.error_y.opacity);\n delete trace.error_y.opacity;\n }\n\n // convert bardir to orientation, and put the data into\n // the axes it's eventually going to be used with\n if('bardir' in trace) {\n if(trace.bardir === 'h' && (traceIs(trace, 'bar') ||\n trace.type.substr(0, 9) === 'histogram')) {\n trace.orientation = 'h';\n exports.swapXYData(trace);\n }\n delete trace.bardir;\n }\n\n // now we have only one 1D histogram type, and whether\n // it uses x or y data depends on trace.orientation\n if(trace.type === 'histogramy') exports.swapXYData(trace);\n if(trace.type === 'histogramx' || trace.type === 'histogramy') {\n trace.type = 'histogram';\n }\n\n // scl->scale, reversescl->reversescale\n if('scl' in trace && !('colorscale' in trace)) {\n trace.colorscale = trace.scl;\n delete trace.scl;\n }\n if('reversescl' in trace && !('reversescale' in trace)) {\n trace.reversescale = trace.reversescl;\n delete trace.reversescl;\n }\n\n // axis ids x1 -> x, y1-> y\n if(trace.xaxis) trace.xaxis = cleanId(trace.xaxis, 'x');\n if(trace.yaxis) trace.yaxis = cleanId(trace.yaxis, 'y');\n\n // scene ids scene1 -> scene\n if(traceIs(trace, 'gl3d') && trace.scene) {\n trace.scene = Plots.subplotsRegistry.gl3d.cleanId(trace.scene);\n }\n\n if(!traceIs(trace, 'pie-like') && !traceIs(trace, 'bar-like')) {\n if(Array.isArray(trace.textposition)) {\n for(i = 0; i < trace.textposition.length; i++) {\n trace.textposition[i] = cleanTextPosition(trace.textposition[i]);\n }\n } else if(trace.textposition) {\n trace.textposition = cleanTextPosition(trace.textposition);\n }\n }\n\n // fix typo in colorscale definition\n var _module = Registry.getModule(trace);\n if(_module && _module.colorbar) {\n var containerName = _module.colorbar.container;\n var container = containerName ? trace[containerName] : trace;\n if(container && container.colorscale) {\n if(container.colorscale === 'YIGnBu') container.colorscale = 'YlGnBu';\n if(container.colorscale === 'YIOrRd') container.colorscale = 'YlOrRd';\n }\n }\n\n // fix typo in surface 'highlight*' definitions\n if(trace.type === 'surface' && Lib.isPlainObject(trace.contours)) {\n var dims = ['x', 'y', 'z'];\n\n for(i = 0; i < dims.length; i++) {\n var opts = trace.contours[dims[i]];\n\n if(!Lib.isPlainObject(opts)) continue;\n\n if(opts.highlightColor) {\n opts.highlightcolor = opts.highlightColor;\n delete opts.highlightColor;\n }\n\n if(opts.highlightWidth) {\n opts.highlightwidth = opts.highlightWidth;\n delete opts.highlightWidth;\n }\n }\n }\n\n // fixes from converting finance from transforms to real trace types\n if(trace.type === 'candlestick' || trace.type === 'ohlc') {\n var increasingShowlegend = (trace.increasing || {}).showlegend !== false;\n var decreasingShowlegend = (trace.decreasing || {}).showlegend !== false;\n var increasingName = cleanFinanceDir(trace.increasing);\n var decreasingName = cleanFinanceDir(trace.decreasing);\n\n // now figure out something smart to do with the separate direction\n // names we removed\n if((increasingName !== false) && (decreasingName !== false)) {\n // both sub-names existed: base name previously had no effect\n // so ignore it and try to find a shared part of the sub-names\n\n var newName = commonPrefix(\n increasingName, decreasingName,\n increasingShowlegend, decreasingShowlegend\n );\n // if no common part, leave whatever name was (or wasn't) there\n if(newName) trace.name = newName;\n } else if((increasingName || decreasingName) && !trace.name) {\n // one sub-name existed but not the base name - just use the sub-name\n trace.name = increasingName || decreasingName;\n }\n }\n\n // transforms backward compatibility fixes\n if(Array.isArray(trace.transforms)) {\n var transforms = trace.transforms;\n\n for(i = 0; i < transforms.length; i++) {\n var transform = transforms[i];\n\n if(!Lib.isPlainObject(transform)) continue;\n\n switch(transform.type) {\n case 'filter':\n if(transform.filtersrc) {\n transform.target = transform.filtersrc;\n delete transform.filtersrc;\n }\n\n if(transform.calendar) {\n if(!transform.valuecalendar) {\n transform.valuecalendar = transform.calendar;\n }\n delete transform.calendar;\n }\n break;\n\n case 'groupby':\n // Name has changed from `style` to `styles`, so use `style` but prefer `styles`:\n transform.styles = transform.styles || transform.style;\n\n if(transform.styles && !Array.isArray(transform.styles)) {\n var prevStyles = transform.styles;\n var styleKeys = Object.keys(prevStyles);\n\n transform.styles = [];\n for(var j = 0; j < styleKeys.length; j++) {\n transform.styles.push({\n target: styleKeys[j],\n value: prevStyles[styleKeys[j]]\n });\n }\n }\n break;\n }\n }\n }\n\n // prune empty containers made before the new nestedProperty\n if(emptyContainer(trace, 'line')) delete trace.line;\n if('marker' in trace) {\n if(emptyContainer(trace.marker, 'line')) delete trace.marker.line;\n if(emptyContainer(trace, 'marker')) delete trace.marker;\n }\n\n // sanitize rgb(fractions) and rgba(fractions) that old tinycolor\n // supported, but new tinycolor does not because they're not valid css\n Color.clean(trace);\n\n // remove obsolete autobin(x|y) attributes, but only if true\n // if false, this needs to happen in Histogram.calc because it\n // can be a one-time autobin so we need to know the results before\n // we can push them back into the trace.\n if(trace.autobinx) {\n delete trace.autobinx;\n delete trace.xbins;\n }\n if(trace.autobiny) {\n delete trace.autobiny;\n delete trace.ybins;\n }\n\n cleanTitle(trace);\n if(trace.colorbar) cleanTitle(trace.colorbar);\n if(trace.marker && trace.marker.colorbar) cleanTitle(trace.marker.colorbar);\n if(trace.line && trace.line.colorbar) cleanTitle(trace.line.colorbar);\n if(trace.aaxis) cleanTitle(trace.aaxis);\n if(trace.baxis) cleanTitle(trace.baxis);\n }\n};\n\nfunction cleanFinanceDir(dirContainer) {\n if(!Lib.isPlainObject(dirContainer)) return false;\n\n var dirName = dirContainer.name;\n\n delete dirContainer.name;\n delete dirContainer.showlegend;\n\n return (typeof dirName === 'string' || typeof dirName === 'number') && String(dirName);\n}\n\nfunction commonPrefix(name1, name2, show1, show2) {\n // if only one is shown in the legend, use that\n if(show1 && !show2) return name1;\n if(show2 && !show1) return name2;\n\n // if both or neither are in the legend, check if one is blank (or whitespace)\n // and use the other one\n // note that hover labels can still use the name even if the legend doesn't\n if(!name1.trim()) return name2;\n if(!name2.trim()) return name1;\n\n var minLen = Math.min(name1.length, name2.length);\n var i;\n for(i = 0; i < minLen; i++) {\n if(name1.charAt(i) !== name2.charAt(i)) break;\n }\n\n var out = name1.substr(0, i);\n return out.trim();\n}\n\n// textposition - support partial attributes (ie just 'top')\n// and incorrect use of middle / center etc.\nfunction cleanTextPosition(textposition) {\n var posY = 'middle';\n var posX = 'center';\n\n if(typeof textposition === 'string') {\n if(textposition.indexOf('top') !== -1) posY = 'top';\n else if(textposition.indexOf('bottom') !== -1) posY = 'bottom';\n\n if(textposition.indexOf('left') !== -1) posX = 'left';\n else if(textposition.indexOf('right') !== -1) posX = 'right';\n }\n\n return posY + ' ' + posX;\n}\n\nfunction emptyContainer(outer, innerStr) {\n return (innerStr in outer) &&\n (typeof outer[innerStr] === 'object') &&\n (Object.keys(outer[innerStr]).length === 0);\n}\n\n\n// swap all the data and data attributes associated with x and y\nexports.swapXYData = function(trace) {\n var i;\n Lib.swapAttrs(trace, ['?', '?0', 'd?', '?bins', 'nbins?', 'autobin?', '?src', 'error_?']);\n if(Array.isArray(trace.z) && Array.isArray(trace.z[0])) {\n if(trace.transpose) delete trace.transpose;\n else trace.transpose = true;\n }\n if(trace.error_x && trace.error_y) {\n var errorY = trace.error_y;\n var copyYstyle = ('copy_ystyle' in errorY) ?\n errorY.copy_ystyle :\n !(errorY.color || errorY.thickness || errorY.width);\n Lib.swapAttrs(trace, ['error_?.copy_ystyle']);\n if(copyYstyle) {\n Lib.swapAttrs(trace, ['error_?.color', 'error_?.thickness', 'error_?.width']);\n }\n }\n if(typeof trace.hoverinfo === 'string') {\n var hoverInfoParts = trace.hoverinfo.split('+');\n for(i = 0; i < hoverInfoParts.length; i++) {\n if(hoverInfoParts[i] === 'x') hoverInfoParts[i] = 'y';\n else if(hoverInfoParts[i] === 'y') hoverInfoParts[i] = 'x';\n }\n trace.hoverinfo = hoverInfoParts.join('+');\n }\n};\n\n// coerce traceIndices input to array of trace indices\nexports.coerceTraceIndices = function(gd, traceIndices) {\n if(isNumeric(traceIndices)) {\n return [traceIndices];\n } else if(!Array.isArray(traceIndices) || !traceIndices.length) {\n return gd.data.map(function(_, i) { return i; });\n } else if(Array.isArray(traceIndices)) {\n var traceIndicesOut = [];\n for(var i = 0; i < traceIndices.length; i++) {\n if(Lib.isIndex(traceIndices[i], gd.data.length)) {\n traceIndicesOut.push(traceIndices[i]);\n } else {\n Lib.warn('trace index (', traceIndices[i], ') is not a number or is out of bounds');\n }\n }\n return traceIndicesOut;\n }\n\n return traceIndices;\n};\n\n/**\n * Manages logic around array container item creation / deletion / update\n * that nested property alone can't handle.\n *\n * @param {Object} np\n * nested property of update attribute string about trace or layout object\n * @param {*} newVal\n * update value passed to restyle / relayout / update\n * @param {Object} undoit\n * undo hash (N.B. undoit may be mutated here).\n *\n */\nexports.manageArrayContainers = function(np, newVal, undoit) {\n var obj = np.obj;\n var parts = np.parts;\n var pLength = parts.length;\n var pLast = parts[pLength - 1];\n\n var pLastIsNumber = isNumeric(pLast);\n\n if(pLastIsNumber && newVal === null) {\n // delete item\n\n // Clear item in array container when new value is null\n var contPath = parts.slice(0, pLength - 1).join('.');\n var cont = Lib.nestedProperty(obj, contPath).get();\n cont.splice(pLast, 1);\n\n // Note that nested property clears null / undefined at end of\n // array container, but not within them.\n } else if(pLastIsNumber && np.get() === undefined) {\n // create item\n\n // When adding a new item, make sure undo command will remove it\n if(np.get() === undefined) undoit[np.astr] = null;\n\n np.set(newVal);\n } else {\n // update item\n\n // If the last part of attribute string isn't a number,\n // np.set is all we need.\n np.set(newVal);\n }\n};\n\n/*\n * Match the part to strip off to turn an attribute into its parent\n * really it should be either '.some_characters' or '[number]'\n * but we're a little more permissive here and match either\n * '.not_brackets_or_dot' or '[not_brackets_or_dot]'\n */\nvar ATTR_TAIL_RE = /(\\.[^\\[\\]\\.]+|\\[[^\\[\\]\\.]+\\])$/;\n\nfunction getParent(attr) {\n var tail = attr.search(ATTR_TAIL_RE);\n if(tail > 0) return attr.substr(0, tail);\n}\n\n/*\n * hasParent: does an attribute object contain a parent of the given attribute?\n * for example, given 'images[2].x' do we also have 'images' or 'images[2]'?\n *\n * @param {Object} aobj\n * update object, whose keys are attribute strings and values are their new settings\n * @param {string} attr\n * the attribute string to test against\n * @returns {Boolean}\n * is a parent of attr present in aobj?\n */\nexports.hasParent = function(aobj, attr) {\n var attrParent = getParent(attr);\n while(attrParent) {\n if(attrParent in aobj) return true;\n attrParent = getParent(attrParent);\n }\n return false;\n};\n\n/**\n * Empty out types for all axes containing these traces so we auto-set them again\n *\n * @param {object} gd\n * @param {[integer]} traces: trace indices to search for axes to clear the types of\n * @param {object} layoutUpdate: any update being done concurrently to the layout,\n * which may supercede clearing the axis types\n */\nvar axLetters = ['x', 'y', 'z'];\nexports.clearAxisTypes = function(gd, traces, layoutUpdate) {\n for(var i = 0; i < traces.length; i++) {\n var trace = gd._fullData[i];\n for(var j = 0; j < 3; j++) {\n var ax = getFromTrace(gd, trace, axLetters[j]);\n\n // do not clear log type - that's never an auto result so must have been intentional\n if(ax && ax.type !== 'log') {\n var axAttr = ax._name;\n var sceneName = ax._id.substr(1);\n if(sceneName.substr(0, 5) === 'scene') {\n if(layoutUpdate[sceneName] !== undefined) continue;\n axAttr = sceneName + '.' + axAttr;\n }\n var typeAttr = axAttr + '.type';\n\n if(layoutUpdate[axAttr] === undefined && layoutUpdate[typeAttr] === undefined) {\n Lib.nestedProperty(gd.layout, typeAttr).set(null);\n }\n }\n }\n }\n};\n","'use strict';\n\nvar main = require('./plot_api');\n\nexports._doPlot = main._doPlot;\nexports.newPlot = main.newPlot;\nexports.restyle = main.restyle;\nexports.relayout = main.relayout;\nexports.redraw = main.redraw;\nexports.update = main.update;\nexports._guiRestyle = main._guiRestyle;\nexports._guiRelayout = main._guiRelayout;\nexports._guiUpdate = main._guiUpdate;\nexports._storeDirectGUIEdit = main._storeDirectGUIEdit;\nexports.react = main.react;\nexports.extendTraces = main.extendTraces;\nexports.prependTraces = main.prependTraces;\nexports.addTraces = main.addTraces;\nexports.deleteTraces = main.deleteTraces;\nexports.moveTraces = main.moveTraces;\nexports.purge = main.purge;\nexports.addFrames = main.addFrames;\nexports.deleteFrames = main.deleteFrames;\nexports.animate = main.animate;\nexports.setPlotConfig = main.setPlotConfig;\n\nvar getGraphDiv = require('../lib/dom').getGraphDiv;\nvar eraseActiveShape = require('../components/shapes/draw').eraseActiveShape;\nexports.deleteActiveShape = function(gd) {\n return eraseActiveShape(getGraphDiv(gd));\n};\n\nexports.toImage = require('./to_image');\nexports.validate = require('./validate');\nexports.downloadImage = require('../snapshot/download');\n\nvar templateApi = require('./template_api');\nexports.makeTemplate = templateApi.makeTemplate;\nexports.validateTemplate = templateApi.validateTemplate;\n","'use strict';\n\nvar isPlainObject = require('../lib/is_plain_object');\nvar noop = require('../lib/noop');\nvar Loggers = require('../lib/loggers');\nvar sorterAsc = require('../lib/search').sorterAsc;\nvar Registry = require('../registry');\n\n\nexports.containerArrayMatch = require('./container_array_match');\n\nvar isAddVal = exports.isAddVal = function isAddVal(val) {\n return val === 'add' || isPlainObject(val);\n};\n\nvar isRemoveVal = exports.isRemoveVal = function isRemoveVal(val) {\n return val === null || val === 'remove';\n};\n\n/*\n * applyContainerArrayChanges: for managing arrays of layout components in relayout\n * handles them all with a consistent interface.\n *\n * Here are the supported actions -> relayout calls -> edits we get here\n * (as prepared in _relayout):\n *\n * add an empty obj -> {'annotations[2]': 'add'} -> {2: {'': 'add'}}\n * add a specific obj -> {'annotations[2]': {attrs}} -> {2: {'': {attrs}}}\n * delete an obj -> {'annotations[2]': 'remove'} -> {2: {'': 'remove'}}\n * -> {'annotations[2]': null} -> {2: {'': null}}\n * delete the whole array -> {'annotations': 'remove'} -> {'': {'': 'remove'}}\n * -> {'annotations': null} -> {'': {'': null}}\n * edit an object -> {'annotations[2].text': 'boo'} -> {2: {'text': 'boo'}}\n *\n * You can combine many edits to different objects. Objects are added and edited\n * in ascending order, then removed in descending order.\n * For example, starting with [a, b, c], if you want to:\n * - replace b with d:\n * {'annotations[1]': d, 'annotations[2]': null} (b is item 2 after adding d)\n * - add a new item d between a and b, and edit b:\n * {'annotations[1]': d, 'annotations[2].x': newX} (b is item 2 after adding d)\n * - delete b and edit c:\n * {'annotations[1]': null, 'annotations[2].x': newX} (c is edited before b is removed)\n *\n * You CANNOT combine adding/deleting an item at index `i` with edits to the same index `i`\n * You CANNOT combine replacing/deleting the whole array with anything else (for the same array).\n *\n * @param {HTMLDivElement} gd\n * the DOM element of the graph container div\n * @param {Lib.nestedProperty} componentType: the array we are editing\n * @param {Object} edits\n * the changes to make; keys are indices to edit, values are themselves objects:\n * {attr: newValue} of changes to make to that index (with add/remove behavior\n * in special values of the empty attr)\n * @param {Object} flags\n * the flags for which actions we're going to perform to display these (and\n * any other) changes. If we're already `recalc`ing, we don't need to redraw\n * individual items\n * @param {function} _nestedProperty\n * a (possibly modified for gui edits) nestedProperty constructor\n * The modified version takes a 3rd argument, for a prefix to the attribute\n * string necessary for storing GUI edits\n *\n * @returns {bool} `true` if it managed to complete drawing of the changes\n * `false` would mean the parent should replot.\n */\nexports.applyContainerArrayChanges = function applyContainerArrayChanges(gd, np, edits, flags, _nestedProperty) {\n var componentType = np.astr;\n var supplyComponentDefaults = Registry.getComponentMethod(componentType, 'supplyLayoutDefaults');\n var draw = Registry.getComponentMethod(componentType, 'draw');\n var drawOne = Registry.getComponentMethod(componentType, 'drawOne');\n var replotLater = flags.replot || flags.recalc || (supplyComponentDefaults === noop) || (draw === noop);\n var layout = gd.layout;\n var fullLayout = gd._fullLayout;\n\n if(edits['']) {\n if(Object.keys(edits).length > 1) {\n Loggers.warn('Full array edits are incompatible with other edits',\n componentType);\n }\n\n var fullVal = edits[''][''];\n\n if(isRemoveVal(fullVal)) np.set(null);\n else if(Array.isArray(fullVal)) np.set(fullVal);\n else {\n Loggers.warn('Unrecognized full array edit value', componentType, fullVal);\n return true;\n }\n\n if(replotLater) return false;\n\n supplyComponentDefaults(layout, fullLayout);\n draw(gd);\n return true;\n }\n\n var componentNums = Object.keys(edits).map(Number).sort(sorterAsc);\n var componentArrayIn = np.get();\n var componentArray = componentArrayIn || [];\n // componentArrayFull is used just to keep splices in line between\n // full and input arrays, so private keys can be copied over after\n // redoing supplyDefaults\n // TODO: this assumes componentArray is in gd.layout - which will not be\n // true after we extend this to restyle\n var componentArrayFull = _nestedProperty(fullLayout, componentType).get();\n\n var deletes = [];\n var firstIndexChange = -1;\n var maxIndex = componentArray.length;\n var i;\n var j;\n var componentNum;\n var objEdits;\n var objKeys;\n var objVal;\n var adding, prefix;\n\n // first make the add and edit changes\n for(i = 0; i < componentNums.length; i++) {\n componentNum = componentNums[i];\n objEdits = edits[componentNum];\n objKeys = Object.keys(objEdits);\n objVal = objEdits[''],\n adding = isAddVal(objVal);\n\n if(componentNum < 0 || componentNum > componentArray.length - (adding ? 0 : 1)) {\n Loggers.warn('index out of range', componentType, componentNum);\n continue;\n }\n\n if(objVal !== undefined) {\n if(objKeys.length > 1) {\n Loggers.warn(\n 'Insertion & removal are incompatible with edits to the same index.',\n componentType, componentNum);\n }\n\n if(isRemoveVal(objVal)) {\n deletes.push(componentNum);\n } else if(adding) {\n if(objVal === 'add') objVal = {};\n componentArray.splice(componentNum, 0, objVal);\n if(componentArrayFull) componentArrayFull.splice(componentNum, 0, {});\n } else {\n Loggers.warn('Unrecognized full object edit value',\n componentType, componentNum, objVal);\n }\n\n if(firstIndexChange === -1) firstIndexChange = componentNum;\n } else {\n for(j = 0; j < objKeys.length; j++) {\n prefix = componentType + '[' + componentNum + '].';\n _nestedProperty(componentArray[componentNum], objKeys[j], prefix)\n .set(objEdits[objKeys[j]]);\n }\n }\n }\n\n // now do deletes\n for(i = deletes.length - 1; i >= 0; i--) {\n componentArray.splice(deletes[i], 1);\n // TODO: this drops private keys that had been stored in componentArrayFull\n // does this have any ill effects?\n if(componentArrayFull) componentArrayFull.splice(deletes[i], 1);\n }\n\n if(!componentArray.length) np.set(null);\n else if(!componentArrayIn) np.set(componentArray);\n\n if(replotLater) return false;\n\n supplyComponentDefaults(layout, fullLayout);\n\n // finally draw all the components we need to\n // if we added or removed any, redraw all after it\n if(drawOne !== noop) {\n var indicesToDraw;\n if(firstIndexChange === -1) {\n // there's no re-indexing to do, so only redraw components that changed\n indicesToDraw = componentNums;\n } else {\n // in case the component array was shortened, we still need do call\n // drawOne on the latter items so they get properly removed\n maxIndex = Math.max(componentArray.length, maxIndex);\n indicesToDraw = [];\n for(i = 0; i < componentNums.length; i++) {\n componentNum = componentNums[i];\n if(componentNum >= firstIndexChange) break;\n indicesToDraw.push(componentNum);\n }\n for(i = firstIndexChange; i < maxIndex; i++) {\n indicesToDraw.push(i);\n }\n }\n for(i = 0; i < indicesToDraw.length; i++) {\n drawOne(gd, indicesToDraw[i]);\n }\n } else draw(gd);\n\n return true;\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar isNumeric = require('fast-isnumeric');\nvar hasHover = require('has-hover');\n\nvar Lib = require('../lib');\nvar nestedProperty = Lib.nestedProperty;\n\nvar Events = require('../lib/events');\nvar Queue = require('../lib/queue');\n\nvar Registry = require('../registry');\nvar PlotSchema = require('./plot_schema');\nvar Plots = require('../plots/plots');\n\nvar Axes = require('../plots/cartesian/axes');\nvar handleRangeDefaults = require('../plots/cartesian/range_defaults');\n\nvar cartesianLayoutAttributes = require('../plots/cartesian/layout_attributes');\nvar Drawing = require('../components/drawing');\nvar Color = require('../components/color');\nvar initInteractions = require('../plots/cartesian/graph_interact').initInteractions;\nvar xmlnsNamespaces = require('../constants/xmlns_namespaces');\nvar clearOutline = require('../components/selections').clearOutline;\n\nvar dfltConfig = require('./plot_config').dfltConfig;\nvar manageArrays = require('./manage_arrays');\nvar helpers = require('./helpers');\nvar subroutines = require('./subroutines');\nvar editTypes = require('./edit_types');\n\nvar AX_NAME_PATTERN = require('../plots/cartesian/constants').AX_NAME_PATTERN;\n\nvar numericNameWarningCount = 0;\nvar numericNameWarningCountLimit = 5;\n\n/**\n * Internal plot-creation function\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n * @param {array of objects} data\n * array of traces, containing the data and display information for each trace\n * @param {object} layout\n * object describing the overall display of the plot,\n * all the stuff that doesn't pertain to any individual trace\n * @param {object} config\n * configuration options (see ./plot_config.js for more info)\n *\n * OR\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n * @param {object} figure\n * object containing `data`, `layout`, `config`, and `frames` members\n *\n */\nfunction _doPlot(gd, data, layout, config) {\n var frames;\n\n gd = Lib.getGraphDiv(gd);\n\n // Events.init is idempotent and bails early if gd has already been init'd\n Events.init(gd);\n\n if(Lib.isPlainObject(data)) {\n var obj = data;\n data = obj.data;\n layout = obj.layout;\n config = obj.config;\n frames = obj.frames;\n }\n\n var okToPlot = Events.triggerHandler(gd, 'plotly_beforeplot', [data, layout, config]);\n if(okToPlot === false) return Promise.reject();\n\n // if there's no data or layout, and this isn't yet a plotly plot\n // container, log a warning to help plotly.js users debug\n if(!data && !layout && !Lib.isPlotDiv(gd)) {\n Lib.warn('Calling _doPlot as if redrawing ' +\n 'but this container doesn\\'t yet have a plot.', gd);\n }\n\n function addFrames() {\n if(frames) {\n return exports.addFrames(gd, frames);\n }\n }\n\n // transfer configuration options to gd until we move over to\n // a more OO like model\n setPlotContext(gd, config);\n\n if(!layout) layout = {};\n\n // hook class for plots main container (in case of plotly.js\n // this won't be #embedded-graph or .js-tab-contents)\n d3.select(gd).classed('js-plotly-plot', true);\n\n // off-screen getBoundingClientRect testing space,\n // in #js-plotly-tester (and stored as Drawing.tester)\n // so we can share cached text across tabs\n Drawing.makeTester();\n\n // collect promises for any async actions during plotting\n // any part of the plotting code can push to gd._promises, then\n // before we move to the next step, we check that they're all\n // complete, and empty out the promise list again.\n if(!Array.isArray(gd._promises)) gd._promises = [];\n\n var graphWasEmpty = ((gd.data || []).length === 0 && Array.isArray(data));\n\n // if there is already data on the graph, append the new data\n // if you only want to redraw, pass a non-array for data\n if(Array.isArray(data)) {\n helpers.cleanData(data);\n\n if(graphWasEmpty) gd.data = data;\n else gd.data.push.apply(gd.data, data);\n\n // for routines outside graph_obj that want a clean tab\n // (rather than appending to an existing one) gd.empty\n // is used to determine whether to make a new tab\n gd.empty = false;\n }\n\n if(!gd.layout || graphWasEmpty) {\n gd.layout = helpers.cleanLayout(layout);\n }\n\n Plots.supplyDefaults(gd);\n\n var fullLayout = gd._fullLayout;\n var hasCartesian = fullLayout._has('cartesian');\n\n // so we don't try to re-call _doPlot from inside\n // legend and colorbar, if margins changed\n fullLayout._replotting = true;\n\n // make or remake the framework if we need to\n if(graphWasEmpty || fullLayout._shouldCreateBgLayer) {\n makePlotFramework(gd);\n\n if(fullLayout._shouldCreateBgLayer) {\n delete fullLayout._shouldCreateBgLayer;\n }\n }\n\n // clear gradient and pattern defs on each .plot call, because we know we'll loop through all traces\n Drawing.initGradients(gd);\n Drawing.initPatterns(gd);\n\n // save initial show spikes once per graph\n if(graphWasEmpty) Axes.saveShowSpikeInitial(gd);\n\n // prepare the data and find the autorange\n\n // generate calcdata, if we need to\n // to force redoing calcdata, just delete it before calling _doPlot\n var recalc = !gd.calcdata || gd.calcdata.length !== (gd._fullData || []).length;\n if(recalc) Plots.doCalcdata(gd);\n\n // in case it has changed, attach fullData traces to calcdata\n for(var i = 0; i < gd.calcdata.length; i++) {\n gd.calcdata[i][0].trace = gd._fullData[i];\n }\n\n // make the figure responsive\n if(gd._context.responsive) {\n if(!gd._responsiveChartHandler) {\n // Keep a reference to the resize handler to purge it down the road\n gd._responsiveChartHandler = function() { if(!Lib.isHidden(gd)) Plots.resize(gd); };\n\n // Listen to window resize\n window.addEventListener('resize', gd._responsiveChartHandler);\n }\n } else {\n Lib.clearResponsive(gd);\n }\n\n /*\n * start async-friendly code - now we're actually drawing things\n */\n\n var oldMargins = Lib.extendFlat({}, fullLayout._size);\n\n // draw framework first so that margin-pushing\n // components can position themselves correctly\n var drawFrameworkCalls = 0;\n function drawFramework() {\n var basePlotModules = fullLayout._basePlotModules;\n\n for(var i = 0; i < basePlotModules.length; i++) {\n if(basePlotModules[i].drawFramework) {\n basePlotModules[i].drawFramework(gd);\n }\n }\n\n if(!fullLayout._glcanvas && fullLayout._has('gl')) {\n fullLayout._glcanvas = fullLayout._glcontainer.selectAll('.gl-canvas').data([{\n key: 'contextLayer',\n context: true,\n pick: false\n }, {\n key: 'focusLayer',\n context: false,\n pick: false\n }, {\n key: 'pickLayer',\n context: false,\n pick: true\n }], function(d) { return d.key; });\n\n fullLayout._glcanvas.enter().append('canvas')\n .attr('class', function(d) {\n return 'gl-canvas gl-canvas-' + d.key.replace('Layer', '');\n })\n .style({\n position: 'absolute',\n top: 0,\n left: 0,\n overflow: 'visible',\n 'pointer-events': 'none'\n });\n }\n\n var plotGlPixelRatio = gd._context.plotGlPixelRatio;\n if(fullLayout._glcanvas) {\n fullLayout._glcanvas\n .attr('width', fullLayout.width * plotGlPixelRatio)\n .attr('height', fullLayout.height * plotGlPixelRatio)\n .style('width', fullLayout.width + 'px')\n .style('height', fullLayout.height + 'px');\n\n var regl = fullLayout._glcanvas.data()[0].regl;\n if(regl) {\n // Unfortunately, this can happen when relayouting to large\n // width/height on some browsers.\n if(Math.floor(fullLayout.width * plotGlPixelRatio) !== regl._gl.drawingBufferWidth ||\n Math.floor(fullLayout.height * plotGlPixelRatio) !== regl._gl.drawingBufferHeight\n ) {\n var msg = 'WebGL context buffer and canvas dimensions do not match due to browser/WebGL bug.';\n if(drawFrameworkCalls) {\n Lib.error(msg);\n } else {\n Lib.log(msg + ' Clearing graph and plotting again.');\n Plots.cleanPlot([], {}, gd._fullData, fullLayout);\n Plots.supplyDefaults(gd);\n fullLayout = gd._fullLayout;\n Plots.doCalcdata(gd);\n drawFrameworkCalls++;\n return drawFramework();\n }\n }\n }\n }\n\n if(fullLayout.modebar.orientation === 'h') {\n fullLayout._modebardiv\n .style('height', null)\n .style('width', '100%');\n } else {\n fullLayout._modebardiv\n .style('width', null)\n .style('height', fullLayout.height + 'px');\n }\n\n return Plots.previousPromises(gd);\n }\n\n // draw anything that can affect margins.\n function marginPushers() {\n // First reset the list of things that are allowed to change the margins\n // So any deleted traces or components will be wiped out of the\n // automargin calculation.\n // This means *every* margin pusher must be listed here, even if it\n // doesn't actually try to push the margins until later.\n Plots.clearAutoMarginIds(gd);\n\n subroutines.drawMarginPushers(gd);\n Axes.allowAutoMargin(gd);\n if(gd._fullLayout.title.text && gd._fullLayout.title.automargin) Plots.allowAutoMargin(gd, 'title.automargin');\n\n // TODO can this be moved elsewhere?\n if(fullLayout._has('pie')) {\n var fullData = gd._fullData;\n for(var i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n if(trace.type === 'pie' && trace.automargin) {\n Plots.allowAutoMargin(gd, 'pie.' + trace.uid + '.automargin');\n }\n }\n }\n\n Plots.doAutoMargin(gd);\n return Plots.previousPromises(gd);\n }\n\n // in case the margins changed, draw margin pushers again\n function marginPushersAgain() {\n if(!Plots.didMarginChange(oldMargins, fullLayout._size)) return;\n\n return Lib.syncOrAsync([\n marginPushers,\n subroutines.layoutStyles\n ], gd);\n }\n\n function positionAndAutorange() {\n if(!recalc) {\n doAutoRangeAndConstraints();\n return;\n }\n\n // TODO: autosize extra for text markers and images\n // see https://github.com/plotly/plotly.js/issues/1111\n return Lib.syncOrAsync([\n Registry.getComponentMethod('shapes', 'calcAutorange'),\n Registry.getComponentMethod('annotations', 'calcAutorange'),\n doAutoRangeAndConstraints\n ], gd);\n }\n\n function doAutoRangeAndConstraints() {\n if(gd._transitioning) return;\n\n subroutines.doAutoRangeAndConstraints(gd);\n\n // store initial ranges *after* enforcing constraints, otherwise\n // we will never look like we're at the initial ranges\n if(graphWasEmpty) Axes.saveRangeInitial(gd);\n\n // this one is different from shapes/annotations calcAutorange\n // the others incorporate those components into ax._extremes,\n // this one actually sets the ranges in rangesliders.\n Registry.getComponentMethod('rangeslider', 'calcAutorange')(gd);\n }\n\n // draw ticks, titles, and calculate axis scaling (._b, ._m)\n function drawAxes() {\n return Axes.draw(gd, graphWasEmpty ? '' : 'redraw');\n }\n\n var seq = [\n Plots.previousPromises,\n addFrames,\n drawFramework,\n marginPushers,\n marginPushersAgain\n ];\n\n if(hasCartesian) seq.push(positionAndAutorange);\n\n seq.push(subroutines.layoutStyles);\n if(hasCartesian) {\n seq.push(\n drawAxes,\n function insideTickLabelsAutorange(gd) {\n var insideTickLabelsUpdaterange = gd._fullLayout._insideTickLabelsUpdaterange;\n if(insideTickLabelsUpdaterange) {\n gd._fullLayout._insideTickLabelsUpdaterange = undefined;\n\n return relayout(gd, insideTickLabelsUpdaterange).then(function() {\n Axes.saveRangeInitial(gd, true);\n });\n }\n }\n );\n }\n\n seq.push(\n subroutines.drawData,\n subroutines.finalDraw,\n initInteractions,\n Plots.addLinks,\n Plots.rehover,\n Plots.redrag,\n Plots.reselect,\n // TODO: doAutoMargin is only needed here for axis automargin, which\n // happens outside of marginPushers where all the other automargins are\n // calculated. Would be much better to separate margin calculations from\n // component drawing - see https://github.com/plotly/plotly.js/issues/2704\n Plots.doAutoMargin,\n Plots.previousPromises\n );\n\n // even if everything we did was synchronous, return a promise\n // so that the caller doesn't care which route we took\n var plotDone = Lib.syncOrAsync(seq, gd);\n if(!plotDone || !plotDone.then) plotDone = Promise.resolve();\n\n return plotDone.then(function() {\n emitAfterPlot(gd);\n return gd;\n });\n}\n\nfunction emitAfterPlot(gd) {\n var fullLayout = gd._fullLayout;\n\n if(fullLayout._redrawFromAutoMarginCount) {\n fullLayout._redrawFromAutoMarginCount--;\n } else {\n gd.emit('plotly_afterplot');\n }\n}\n\nfunction setPlotConfig(obj) {\n return Lib.extendFlat(dfltConfig, obj);\n}\n\nfunction setBackground(gd, bgColor) {\n try {\n gd._fullLayout._paper.style('background', bgColor);\n } catch(e) {\n Lib.error(e);\n }\n}\n\nfunction opaqueSetBackground(gd, bgColor) {\n var blend = Color.combine(bgColor, 'white');\n setBackground(gd, blend);\n}\n\nfunction setPlotContext(gd, config) {\n if(!gd._context) {\n gd._context = Lib.extendDeep({}, dfltConfig);\n\n // stash href, used to make robust clipPath URLs\n var base = d3.select('base');\n gd._context._baseUrl = base.size() && base.attr('href') ?\n window.location.href.split('#')[0] :\n '';\n }\n\n var context = gd._context;\n\n var i, keys, key;\n\n if(config) {\n keys = Object.keys(config);\n for(i = 0; i < keys.length; i++) {\n key = keys[i];\n if(key === 'editable' || key === 'edits') continue;\n if(key in context) {\n if(key === 'setBackground' && config[key] === 'opaque') {\n context[key] = opaqueSetBackground;\n } else {\n context[key] = config[key];\n }\n }\n }\n\n // map plot3dPixelRatio to plotGlPixelRatio for backward compatibility\n if(config.plot3dPixelRatio && !context.plotGlPixelRatio) {\n context.plotGlPixelRatio = context.plot3dPixelRatio;\n }\n\n // now deal with editable and edits - first editable overrides\n // everything, then edits refines\n var editable = config.editable;\n if(editable !== undefined) {\n // we're not going to *use* context.editable, we're only going to\n // use context.edits... but keep it for the record\n context.editable = editable;\n\n keys = Object.keys(context.edits);\n for(i = 0; i < keys.length; i++) {\n context.edits[keys[i]] = editable;\n }\n }\n if(config.edits) {\n keys = Object.keys(config.edits);\n for(i = 0; i < keys.length; i++) {\n key = keys[i];\n if(key in context.edits) {\n context.edits[key] = config.edits[key];\n }\n }\n }\n\n // not part of the user-facing config options\n context._exportedPlot = config._exportedPlot;\n }\n\n // staticPlot forces a bunch of others:\n if(context.staticPlot) {\n context.editable = false;\n context.edits = {};\n context.autosizable = false;\n context.scrollZoom = false;\n context.doubleClick = false;\n context.showTips = false;\n context.showLink = false;\n context.displayModeBar = false;\n }\n\n // make sure hover-only devices have mode bar visible\n if(context.displayModeBar === 'hover' && !hasHover) {\n context.displayModeBar = true;\n }\n\n // default and fallback for setBackground\n if(context.setBackground === 'transparent' || typeof context.setBackground !== 'function') {\n context.setBackground = setBackground;\n }\n\n // Check if gd has a specified widht/height to begin with\n context._hasZeroHeight = context._hasZeroHeight || gd.clientHeight === 0;\n context._hasZeroWidth = context._hasZeroWidth || gd.clientWidth === 0;\n\n // fill context._scrollZoom helper to help manage scrollZoom flaglist\n var szIn = context.scrollZoom;\n var szOut = context._scrollZoom = {};\n if(szIn === true) {\n szOut.cartesian = 1;\n szOut.gl3d = 1;\n szOut.geo = 1;\n szOut.mapbox = 1;\n szOut.map = 1;\n } else if(typeof szIn === 'string') {\n var parts = szIn.split('+');\n for(i = 0; i < parts.length; i++) {\n szOut[parts[i]] = 1;\n }\n } else if(szIn !== false) {\n szOut.gl3d = 1;\n szOut.geo = 1;\n szOut.mapbox = 1;\n szOut.map = 1;\n }\n}\n\n\n// convenience function to force a full redraw, mostly for use by plotly.js\nfunction redraw(gd) {\n gd = Lib.getGraphDiv(gd);\n\n if(!Lib.isPlotDiv(gd)) {\n throw new Error('This element is not a Plotly plot: ' + gd);\n }\n\n helpers.cleanData(gd.data);\n helpers.cleanLayout(gd.layout);\n\n gd.calcdata = undefined;\n return exports._doPlot(gd).then(function() {\n gd.emit('plotly_redraw');\n return gd;\n });\n}\n\n/**\n * Convenience function to make idempotent plot option obvious to users.\n *\n * @param gd\n * @param {Object[]} data\n * @param {Object} layout\n * @param {Object} config\n */\nfunction newPlot(gd, data, layout, config) {\n gd = Lib.getGraphDiv(gd);\n\n // remove gl contexts\n Plots.cleanPlot([], {}, gd._fullData || [], gd._fullLayout || {});\n\n Plots.purge(gd);\n return exports._doPlot(gd, data, layout, config);\n}\n\n/**\n * Wrap negative indicies to their positive counterparts.\n *\n * @param {Number[]} indices An array of indices\n * @param {Number} maxIndex The maximum index allowable (arr.length - 1)\n */\nfunction positivifyIndices(indices, maxIndex) {\n var parentLength = maxIndex + 1;\n var positiveIndices = [];\n var i;\n var index;\n\n for(i = 0; i < indices.length; i++) {\n index = indices[i];\n if(index < 0) {\n positiveIndices.push(parentLength + index);\n } else {\n positiveIndices.push(index);\n }\n }\n return positiveIndices;\n}\n\n/**\n * Ensures that an index array for manipulating gd.data is valid.\n *\n * Intended for use with addTraces, deleteTraces, and moveTraces.\n *\n * @param gd\n * @param indices\n * @param arrayName\n */\nfunction assertIndexArray(gd, indices, arrayName) {\n var i,\n index;\n\n for(i = 0; i < indices.length; i++) {\n index = indices[i];\n\n // validate that indices are indeed integers\n if(index !== parseInt(index, 10)) {\n throw new Error('all values in ' + arrayName + ' must be integers');\n }\n\n // check that all indices are in bounds for given gd.data array length\n if(index >= gd.data.length || index < -gd.data.length) {\n throw new Error(arrayName + ' must be valid indices for gd.data.');\n }\n\n // check that indices aren't repeated\n if(indices.indexOf(index, i + 1) > -1 ||\n index >= 0 && indices.indexOf(-gd.data.length + index) > -1 ||\n index < 0 && indices.indexOf(gd.data.length + index) > -1) {\n throw new Error('each index in ' + arrayName + ' must be unique.');\n }\n }\n}\n\n/**\n * Private function used by Plotly.moveTraces to check input args\n *\n * @param gd\n * @param currentIndices\n * @param newIndices\n */\nfunction checkMoveTracesArgs(gd, currentIndices, newIndices) {\n // check that gd has attribute 'data' and 'data' is array\n if(!Array.isArray(gd.data)) {\n throw new Error('gd.data must be an array.');\n }\n\n // validate currentIndices array\n if(typeof currentIndices === 'undefined') {\n throw new Error('currentIndices is a required argument.');\n } else if(!Array.isArray(currentIndices)) {\n currentIndices = [currentIndices];\n }\n assertIndexArray(gd, currentIndices, 'currentIndices');\n\n // validate newIndices array if it exists\n if(typeof newIndices !== 'undefined' && !Array.isArray(newIndices)) {\n newIndices = [newIndices];\n }\n if(typeof newIndices !== 'undefined') {\n assertIndexArray(gd, newIndices, 'newIndices');\n }\n\n // check currentIndices and newIndices are the same length if newIdices exists\n if(typeof newIndices !== 'undefined' && currentIndices.length !== newIndices.length) {\n throw new Error('current and new indices must be of equal length.');\n }\n}\n/**\n * A private function to reduce the type checking clutter in addTraces.\n *\n * @param gd\n * @param traces\n * @param newIndices\n */\nfunction checkAddTracesArgs(gd, traces, newIndices) {\n var i, value;\n\n // check that gd has attribute 'data' and 'data' is array\n if(!Array.isArray(gd.data)) {\n throw new Error('gd.data must be an array.');\n }\n\n // make sure traces exists\n if(typeof traces === 'undefined') {\n throw new Error('traces must be defined.');\n }\n\n // make sure traces is an array\n if(!Array.isArray(traces)) {\n traces = [traces];\n }\n\n // make sure each value in traces is an object\n for(i = 0; i < traces.length; i++) {\n value = traces[i];\n if(typeof value !== 'object' || (Array.isArray(value) || value === null)) {\n throw new Error('all values in traces array must be non-array objects');\n }\n }\n\n // make sure we have an index for each trace\n if(typeof newIndices !== 'undefined' && !Array.isArray(newIndices)) {\n newIndices = [newIndices];\n }\n if(typeof newIndices !== 'undefined' && newIndices.length !== traces.length) {\n throw new Error(\n 'if indices is specified, traces.length must equal indices.length'\n );\n }\n}\n\n/**\n * A private function to reduce the type checking clutter in spliceTraces.\n * Get all update Properties from gd.data. Validate inputs and outputs.\n * Used by prependTrace and extendTraces\n *\n * @param gd\n * @param update\n * @param indices\n * @param maxPoints\n */\nfunction assertExtendTracesArgs(gd, update, indices, maxPoints) {\n var maxPointsIsObject = Lib.isPlainObject(maxPoints);\n\n if(!Array.isArray(gd.data)) {\n throw new Error('gd.data must be an array');\n }\n if(!Lib.isPlainObject(update)) {\n throw new Error('update must be a key:value object');\n }\n\n if(typeof indices === 'undefined') {\n throw new Error('indices must be an integer or array of integers');\n }\n\n assertIndexArray(gd, indices, 'indices');\n\n for(var key in update) {\n /*\n * Verify that the attribute to be updated contains as many trace updates\n * as indices. Failure must result in throw and no-op\n */\n if(!Array.isArray(update[key]) || update[key].length !== indices.length) {\n throw new Error('attribute ' + key + ' must be an array of length equal to indices array length');\n }\n\n /*\n * if maxPoints is an object it must match keys and array lengths of 'update' 1:1\n */\n if(maxPointsIsObject &&\n (!(key in maxPoints) || !Array.isArray(maxPoints[key]) ||\n maxPoints[key].length !== update[key].length)) {\n throw new Error('when maxPoints is set as a key:value object it must contain a 1:1 ' +\n 'corrispondence with the keys and number of traces in the update object');\n }\n }\n}\n\n/**\n * A private function to reduce the type checking clutter in spliceTraces.\n *\n * @param {Object|HTMLDivElement} gd\n * @param {Object} update\n * @param {Number[]} indices\n * @param {Number||Object} maxPoints\n * @return {Object[]}\n */\nfunction getExtendProperties(gd, update, indices, maxPoints) {\n var maxPointsIsObject = Lib.isPlainObject(maxPoints);\n var updateProps = [];\n var trace, target, prop, insert, maxp;\n\n // allow scalar index to represent a single trace position\n if(!Array.isArray(indices)) indices = [indices];\n\n // negative indices are wrapped around to their positive value. Equivalent to python indexing.\n indices = positivifyIndices(indices, gd.data.length - 1);\n\n // loop through all update keys and traces and harvest validated data.\n for(var key in update) {\n for(var j = 0; j < indices.length; j++) {\n /*\n * Choose the trace indexed by the indices map argument and get the prop setter-getter\n * instance that references the key and value for this particular trace.\n */\n trace = gd.data[indices[j]];\n prop = nestedProperty(trace, key);\n\n /*\n * Target is the existing gd.data.trace.dataArray value like \"x\" or \"marker.size\"\n * Target must exist as an Array to allow the extend operation to be performed.\n */\n target = prop.get();\n insert = update[key][j];\n\n if(!Lib.isArrayOrTypedArray(insert)) {\n throw new Error('attribute: ' + key + ' index: ' + j + ' must be an array');\n }\n if(!Lib.isArrayOrTypedArray(target)) {\n throw new Error('cannot extend missing or non-array attribute: ' + key);\n }\n if(target.constructor !== insert.constructor) {\n throw new Error('cannot extend array with an array of a different type: ' + key);\n }\n\n /*\n * maxPoints may be an object map or a scalar. If object select the key:value, else\n * Use the scalar maxPoints for all key and trace combinations.\n */\n maxp = maxPointsIsObject ? maxPoints[key][j] : maxPoints;\n\n // could have chosen null here, -1 just tells us to not take a window\n if(!isNumeric(maxp)) maxp = -1;\n\n /*\n * Wrap the nestedProperty in an object containing required data\n * for lengthening and windowing this particular trace - key combination.\n * Flooring maxp mirrors the behaviour of floats in the Array.slice JSnative function.\n */\n updateProps.push({\n prop: prop,\n target: target,\n insert: insert,\n maxp: Math.floor(maxp)\n });\n }\n }\n\n // all target and insertion data now validated\n return updateProps;\n}\n\n/**\n * A private function to key Extend and Prepend traces DRY\n *\n * @param {Object|HTMLDivElement} gd\n * @param {Object} update\n * @param {Number[]} indices\n * @param {Number||Object} maxPoints\n * @param {Function} updateArray\n * @return {Object}\n */\nfunction spliceTraces(gd, update, indices, maxPoints, updateArray) {\n assertExtendTracesArgs(gd, update, indices, maxPoints);\n\n var updateProps = getExtendProperties(gd, update, indices, maxPoints);\n var undoUpdate = {};\n var undoPoints = {};\n\n for(var i = 0; i < updateProps.length; i++) {\n var prop = updateProps[i].prop;\n var maxp = updateProps[i].maxp;\n\n // return new array and remainder\n var out = updateArray(updateProps[i].target, updateProps[i].insert, maxp);\n prop.set(out[0]);\n\n // build the inverse update object for the undo operation\n if(!Array.isArray(undoUpdate[prop.astr])) undoUpdate[prop.astr] = [];\n undoUpdate[prop.astr].push(out[1]);\n\n // build the matching maxPoints undo object containing original trace lengths\n if(!Array.isArray(undoPoints[prop.astr])) undoPoints[prop.astr] = [];\n undoPoints[prop.astr].push(updateProps[i].target.length);\n }\n\n return {update: undoUpdate, maxPoints: undoPoints};\n}\n\nfunction concatTypedArray(arr0, arr1) {\n var arr2 = new arr0.constructor(arr0.length + arr1.length);\n arr2.set(arr0);\n arr2.set(arr1, arr0.length);\n return arr2;\n}\n\n/**\n * extend && prepend traces at indices with update arrays, window trace lengths to maxPoints\n *\n * Extend and Prepend have identical APIs. Prepend inserts an array at the head while Extend\n * inserts an array off the tail. Prepend truncates the tail of the array - counting maxPoints\n * from the head, whereas Extend truncates the head of the array, counting backward maxPoints\n * from the tail.\n *\n * If maxPoints is undefined, nonNumeric, negative or greater than extended trace length no\n * truncation / windowing will be performed. If its zero, well the whole trace is truncated.\n *\n * @param {Object|HTMLDivElement} gd The graph div\n * @param {Object} update The key:array map of target attributes to extend\n * @param {Number|Number[]} indices The locations of traces to be extended\n * @param {Number|Object} [maxPoints] Number of points for trace window after lengthening.\n *\n */\nfunction extendTraces(gd, update, indices, maxPoints) {\n gd = Lib.getGraphDiv(gd);\n\n function updateArray(target, insert, maxp) {\n var newArray, remainder;\n\n if(Lib.isTypedArray(target)) {\n if(maxp < 0) {\n var none = new target.constructor(0);\n var both = concatTypedArray(target, insert);\n\n if(maxp < 0) {\n newArray = both;\n remainder = none;\n } else {\n newArray = none;\n remainder = both;\n }\n } else {\n newArray = new target.constructor(maxp);\n remainder = new target.constructor(target.length + insert.length - maxp);\n\n if(maxp === insert.length) {\n newArray.set(insert);\n remainder.set(target);\n } else if(maxp < insert.length) {\n var numberOfItemsFromInsert = insert.length - maxp;\n\n newArray.set(insert.subarray(numberOfItemsFromInsert));\n remainder.set(target);\n remainder.set(insert.subarray(0, numberOfItemsFromInsert), target.length);\n } else {\n var numberOfItemsFromTarget = maxp - insert.length;\n var targetBegin = target.length - numberOfItemsFromTarget;\n\n newArray.set(target.subarray(targetBegin));\n newArray.set(insert, numberOfItemsFromTarget);\n remainder.set(target.subarray(0, targetBegin));\n }\n }\n } else {\n newArray = target.concat(insert);\n remainder = (maxp >= 0 && maxp < newArray.length) ?\n newArray.splice(0, newArray.length - maxp) :\n [];\n }\n\n return [newArray, remainder];\n }\n\n var undo = spliceTraces(gd, update, indices, maxPoints, updateArray);\n var promise = exports.redraw(gd);\n var undoArgs = [gd, undo.update, indices, undo.maxPoints];\n Queue.add(gd, exports.prependTraces, undoArgs, extendTraces, arguments);\n\n return promise;\n}\n\nfunction prependTraces(gd, update, indices, maxPoints) {\n gd = Lib.getGraphDiv(gd);\n\n function updateArray(target, insert, maxp) {\n var newArray, remainder;\n\n if(Lib.isTypedArray(target)) {\n if(maxp <= 0) {\n var none = new target.constructor(0);\n var both = concatTypedArray(insert, target);\n\n if(maxp < 0) {\n newArray = both;\n remainder = none;\n } else {\n newArray = none;\n remainder = both;\n }\n } else {\n newArray = new target.constructor(maxp);\n remainder = new target.constructor(target.length + insert.length - maxp);\n\n if(maxp === insert.length) {\n newArray.set(insert);\n remainder.set(target);\n } else if(maxp < insert.length) {\n var numberOfItemsFromInsert = insert.length - maxp;\n\n newArray.set(insert.subarray(0, numberOfItemsFromInsert));\n remainder.set(insert.subarray(numberOfItemsFromInsert));\n remainder.set(target, numberOfItemsFromInsert);\n } else {\n var numberOfItemsFromTarget = maxp - insert.length;\n\n newArray.set(insert);\n newArray.set(target.subarray(0, numberOfItemsFromTarget), insert.length);\n remainder.set(target.subarray(numberOfItemsFromTarget));\n }\n }\n } else {\n newArray = insert.concat(target);\n remainder = (maxp >= 0 && maxp < newArray.length) ?\n newArray.splice(maxp, newArray.length) :\n [];\n }\n\n return [newArray, remainder];\n }\n\n var undo = spliceTraces(gd, update, indices, maxPoints, updateArray);\n var promise = exports.redraw(gd);\n var undoArgs = [gd, undo.update, indices, undo.maxPoints];\n Queue.add(gd, exports.extendTraces, undoArgs, prependTraces, arguments);\n\n return promise;\n}\n\n/**\n * Add data traces to an existing graph div.\n *\n * @param {Object|HTMLDivElement} gd The graph div\n * @param {Object[]} gd.data The array of traces we're adding to\n * @param {Object[]|Object} traces The object or array of objects to add\n * @param {Number[]|Number} [newIndices=[gd.data.length]] Locations to add traces\n *\n */\nfunction addTraces(gd, traces, newIndices) {\n gd = Lib.getGraphDiv(gd);\n\n var currentIndices = [];\n var undoFunc = exports.deleteTraces;\n var redoFunc = addTraces;\n var undoArgs = [gd, currentIndices];\n var redoArgs = [gd, traces]; // no newIndices here\n var i;\n var promise;\n\n // all validation is done elsewhere to remove clutter here\n checkAddTracesArgs(gd, traces, newIndices);\n\n // make sure traces is an array\n if(!Array.isArray(traces)) {\n traces = [traces];\n }\n\n // make sure traces do not repeat existing ones\n traces = traces.map(function(trace) {\n return Lib.extendFlat({}, trace);\n });\n\n helpers.cleanData(traces);\n\n // add the traces to gd.data (no redrawing yet!)\n for(i = 0; i < traces.length; i++) {\n gd.data.push(traces[i]);\n }\n\n // to continue, we need to call moveTraces which requires currentIndices\n for(i = 0; i < traces.length; i++) {\n currentIndices.push(-traces.length + i);\n }\n\n // if the user didn't define newIndices, they just want the traces appended\n // i.e., we can simply redraw and be done\n if(typeof newIndices === 'undefined') {\n promise = exports.redraw(gd);\n Queue.add(gd, undoFunc, undoArgs, redoFunc, redoArgs);\n return promise;\n }\n\n // make sure indices is property defined\n if(!Array.isArray(newIndices)) {\n newIndices = [newIndices];\n }\n\n try {\n // this is redundant, but necessary to not catch later possible errors!\n checkMoveTracesArgs(gd, currentIndices, newIndices);\n } catch(error) {\n // something went wrong, reset gd to be safe and rethrow error\n gd.data.splice(gd.data.length - traces.length, traces.length);\n throw error;\n }\n\n // if we're here, the user has defined specific places to place the new traces\n // this requires some extra work that moveTraces will do\n Queue.startSequence(gd);\n Queue.add(gd, undoFunc, undoArgs, redoFunc, redoArgs);\n promise = exports.moveTraces(gd, currentIndices, newIndices);\n Queue.stopSequence(gd);\n return promise;\n}\n\n/**\n * Delete traces at `indices` from gd.data array.\n *\n * @param {Object|HTMLDivElement} gd The graph div\n * @param {Object[]} gd.data The array of traces we're removing from\n * @param {Number|Number[]} indices The indices\n */\nfunction deleteTraces(gd, indices) {\n gd = Lib.getGraphDiv(gd);\n\n var traces = [];\n var undoFunc = exports.addTraces;\n var redoFunc = deleteTraces;\n var undoArgs = [gd, traces, indices];\n var redoArgs = [gd, indices];\n var i;\n var deletedTrace;\n\n // make sure indices are defined\n if(typeof indices === 'undefined') {\n throw new Error('indices must be an integer or array of integers.');\n } else if(!Array.isArray(indices)) {\n indices = [indices];\n }\n assertIndexArray(gd, indices, 'indices');\n\n // convert negative indices to positive indices\n indices = positivifyIndices(indices, gd.data.length - 1);\n\n // we want descending here so that splicing later doesn't affect indexing\n indices.sort(Lib.sorterDes);\n for(i = 0; i < indices.length; i += 1) {\n deletedTrace = gd.data.splice(indices[i], 1)[0];\n traces.push(deletedTrace);\n }\n\n var promise = exports.redraw(gd);\n Queue.add(gd, undoFunc, undoArgs, redoFunc, redoArgs);\n\n return promise;\n}\n\n/**\n * Move traces at currentIndices array to locations in newIndices array.\n *\n * If newIndices is omitted, currentIndices will be moved to the end. E.g.,\n * these are equivalent:\n *\n * Plotly.moveTraces(gd, [1, 2, 3], [-3, -2, -1])\n * Plotly.moveTraces(gd, [1, 2, 3])\n *\n * @param {Object|HTMLDivElement} gd The graph div\n * @param {Object[]} gd.data The array of traces we're removing from\n * @param {Number|Number[]} currentIndices The locations of traces to be moved\n * @param {Number|Number[]} [newIndices] The locations to move traces to\n *\n * Example calls:\n *\n * // move trace i to location x\n * Plotly.moveTraces(gd, i, x)\n *\n * // move trace i to end of array\n * Plotly.moveTraces(gd, i)\n *\n * // move traces i, j, k to end of array (i != j != k)\n * Plotly.moveTraces(gd, [i, j, k])\n *\n * // move traces [i, j, k] to [x, y, z] (i != j != k) (x != y != z)\n * Plotly.moveTraces(gd, [i, j, k], [x, y, z])\n *\n * // reorder all traces (assume there are 5--a, b, c, d, e)\n * Plotly.moveTraces(gd, [b, d, e, a, c]) // same as 'move to end'\n */\nfunction moveTraces(gd, currentIndices, newIndices) {\n gd = Lib.getGraphDiv(gd);\n\n var newData = [];\n var movingTraceMap = [];\n var undoFunc = moveTraces;\n var redoFunc = moveTraces;\n var undoArgs = [gd, newIndices, currentIndices];\n var redoArgs = [gd, currentIndices, newIndices];\n var i;\n\n // to reduce complexity here, check args elsewhere\n // this throws errors where appropriate\n checkMoveTracesArgs(gd, currentIndices, newIndices);\n\n // make sure currentIndices is an array\n currentIndices = Array.isArray(currentIndices) ? currentIndices : [currentIndices];\n\n // if undefined, define newIndices to point to the end of gd.data array\n if(typeof newIndices === 'undefined') {\n newIndices = [];\n for(i = 0; i < currentIndices.length; i++) {\n newIndices.push(-currentIndices.length + i);\n }\n }\n\n // make sure newIndices is an array if it's user-defined\n newIndices = Array.isArray(newIndices) ? newIndices : [newIndices];\n\n // convert negative indices to positive indices (they're the same length)\n currentIndices = positivifyIndices(currentIndices, gd.data.length - 1);\n newIndices = positivifyIndices(newIndices, gd.data.length - 1);\n\n // at this point, we've coerced the index arrays into predictable forms\n\n // get the traces that aren't being moved around\n for(i = 0; i < gd.data.length; i++) {\n // if index isn't in currentIndices, include it in ignored!\n if(currentIndices.indexOf(i) === -1) {\n newData.push(gd.data[i]);\n }\n }\n\n // get a mapping of indices to moving traces\n for(i = 0; i < currentIndices.length; i++) {\n movingTraceMap.push({newIndex: newIndices[i], trace: gd.data[currentIndices[i]]});\n }\n\n // reorder this mapping by newIndex, ascending\n movingTraceMap.sort(function(a, b) {\n return a.newIndex - b.newIndex;\n });\n\n // now, add the moving traces back in, in order!\n for(i = 0; i < movingTraceMap.length; i += 1) {\n newData.splice(movingTraceMap[i].newIndex, 0, movingTraceMap[i].trace);\n }\n\n gd.data = newData;\n\n var promise = exports.redraw(gd);\n Queue.add(gd, undoFunc, undoArgs, redoFunc, redoArgs);\n\n return promise;\n}\n\n/**\n * restyle: update trace attributes of an existing plot\n *\n * Can be called two ways.\n *\n * Signature 1:\n * @param {String | HTMLDivElement} gd\n * the id or DOM element of the graph container div\n * @param {String} astr\n * attribute string (like `'marker.symbol'`) to update\n * @param {*} val\n * value to give this attribute\n * @param {Number[] | Number} [traces]\n * integer or array of integers for the traces to alter (all if omitted)\n *\n * Signature 2:\n * @param {String | HTMLDivElement} gd\n * (as in signature 1)\n * @param {Object} aobj\n * attribute object `{astr1: val1, astr2: val2 ...}`\n * allows setting multiple attributes simultaneously\n * @param {Number[] | Number} [traces]\n * (as in signature 1)\n *\n * `val` (or `val1`, `val2` ... in the object form) can be an array,\n * to apply different values to each trace.\n *\n * If the array is too short, it will wrap around (useful for\n * style files that want to specify cyclical default values).\n */\nfunction restyle(gd, astr, val, _traces) {\n gd = Lib.getGraphDiv(gd);\n helpers.clearPromiseQueue(gd);\n\n var aobj = {};\n if(typeof astr === 'string') aobj[astr] = val;\n else if(Lib.isPlainObject(astr)) {\n // the 3-arg form\n aobj = Lib.extendFlat({}, astr);\n if(_traces === undefined) _traces = val;\n } else {\n Lib.warn('Restyle fail.', astr, val, _traces);\n return Promise.reject();\n }\n\n if(Object.keys(aobj).length) gd.changed = true;\n\n var traces = helpers.coerceTraceIndices(gd, _traces);\n\n var specs = _restyle(gd, aobj, traces);\n var flags = specs.flags;\n\n // clear calcdata and/or axis types if required so they get regenerated\n if(flags.calc) gd.calcdata = undefined;\n if(flags.clearAxisTypes) helpers.clearAxisTypes(gd, traces, {});\n\n // fill in redraw sequence\n var seq = [];\n\n if(flags.fullReplot) {\n seq.push(exports._doPlot);\n } else {\n seq.push(Plots.previousPromises);\n\n // maybe only call Plots.supplyDataDefaults in the splom case,\n // to skip over long and slow axes defaults\n Plots.supplyDefaults(gd);\n\n if(flags.markerSize) {\n Plots.doCalcdata(gd);\n addAxRangeSequence(seq);\n\n // TODO\n // if all axes have autorange:false, then\n // proceed to subroutines.doTraceStyle(),\n // otherwise we must go through addAxRangeSequence,\n // which in general must redraws 'all' axes\n }\n\n if(flags.style) seq.push(subroutines.doTraceStyle);\n if(flags.colorbars) seq.push(subroutines.doColorBars);\n\n seq.push(emitAfterPlot);\n }\n\n seq.push(\n Plots.rehover,\n Plots.redrag,\n Plots.reselect\n );\n\n Queue.add(gd,\n restyle, [gd, specs.undoit, specs.traces],\n restyle, [gd, specs.redoit, specs.traces]\n );\n\n var plotDone = Lib.syncOrAsync(seq, gd);\n if(!plotDone || !plotDone.then) plotDone = Promise.resolve();\n\n return plotDone.then(function() {\n gd.emit('plotly_restyle', specs.eventData);\n return gd;\n });\n}\n\n// for undo: undefined initial vals must be turned into nulls\n// so that we unset rather than ignore them\nfunction undefinedToNull(val) {\n if(val === undefined) return null;\n return val;\n}\n\n/**\n * Factory function to wrap nestedProperty with GUI edits if necessary\n * with GUI edits we add an optional prefix to the nestedProperty constructor\n * to prepend to the attribute string in the preGUI store.\n */\nfunction makeNP(preGUI, guiEditFlag) {\n if(!guiEditFlag) return nestedProperty;\n\n return function(container, attr, prefix) {\n var np = nestedProperty(container, attr);\n var npSet = np.set;\n np.set = function(val) {\n var fullAttr = (prefix || '') + attr;\n storeCurrent(fullAttr, np.get(), val, preGUI);\n npSet(val);\n };\n return np;\n };\n}\n\nfunction storeCurrent(attr, val, newVal, preGUI) {\n if(Array.isArray(val) || Array.isArray(newVal)) {\n var arrayVal = Array.isArray(val) ? val : [];\n var arrayNew = Array.isArray(newVal) ? newVal : [];\n var maxLen = Math.max(arrayVal.length, arrayNew.length);\n for(var i = 0; i < maxLen; i++) {\n storeCurrent(attr + '[' + i + ']', arrayVal[i], arrayNew[i], preGUI);\n }\n } else if(Lib.isPlainObject(val) || Lib.isPlainObject(newVal)) {\n var objVal = Lib.isPlainObject(val) ? val : {};\n var objNew = Lib.isPlainObject(newVal) ? newVal : {};\n var objBoth = Lib.extendFlat({}, objVal, objNew);\n for(var key in objBoth) {\n storeCurrent(attr + '.' + key, objVal[key], objNew[key], preGUI);\n }\n } else if(preGUI[attr] === undefined) {\n preGUI[attr] = undefinedToNull(val);\n }\n}\n\n/**\n * storeDirectGUIEdit: for routines that skip restyle/relayout and mock it\n * by emitting a plotly_restyle or plotly_relayout event, this routine\n * keeps track of the initial state in _preGUI for use by uirevision\n * Does *not* apply these changes to data/layout - that's the responsibility\n * of the calling routine.\n *\n * @param {object} container: the input attributes container (eg `layout` or a `trace`)\n * @param {object} preGUI: where original values should be stored, either\n * `layout._preGUI` or `layout._tracePreGUI[uid]`\n * @param {object} edits: the {attr: val} object as normally passed to `relayout` etc\n */\nfunction _storeDirectGUIEdit(container, preGUI, edits) {\n for(var attr in edits) {\n var np = nestedProperty(container, attr);\n storeCurrent(attr, np.get(), edits[attr], preGUI);\n }\n}\n\nfunction _restyle(gd, aobj, traces) {\n var fullLayout = gd._fullLayout;\n var fullData = gd._fullData;\n var data = gd.data;\n var guiEditFlag = fullLayout._guiEditing;\n var layoutNP = makeNP(fullLayout._preGUI, guiEditFlag);\n var eventData = Lib.extendDeepAll({}, aobj);\n var i;\n\n cleanDeprecatedAttributeKeys(aobj);\n\n // initialize flags\n var flags = editTypes.traceFlags();\n\n // copies of the change (and previous values of anything affected)\n // for the undo / redo queue\n var redoit = {};\n var undoit = {};\n var axlist;\n\n // make a new empty vals array for undoit\n function a0() { return traces.map(function() { return undefined; }); }\n\n // for autoranging multiple axes\n function addToAxlist(axid) {\n var axName = Axes.id2name(axid);\n if(axlist.indexOf(axName) === -1) axlist.push(axName);\n }\n\n function autorangeAttr(axName) { return 'LAYOUT' + axName + '.autorange'; }\n\n function rangeAttr(axName) { return 'LAYOUT' + axName + '.range'; }\n\n function getFullTrace(traceIndex) {\n // usually fullData maps 1:1 onto data, but with groupby transforms\n // the fullData index can be greater. Take the *first* matching trace.\n for(var j = traceIndex; j < fullData.length; j++) {\n if(fullData[j]._input === data[traceIndex]) return fullData[j];\n }\n // should never get here - and if we *do* it should cause an error\n // later on undefined fullTrace is passed to nestedProperty.\n }\n\n // for attrs that interact (like scales & autoscales), save the\n // old vals before making the change\n // val=undefined will not set a value, just record what the value was.\n // val=null will delete the attribute\n // attr can be an array to set several at once (all to the same val)\n function doextra(attr, val, i) {\n if(Array.isArray(attr)) {\n attr.forEach(function(a) { doextra(a, val, i); });\n return;\n }\n // quit if explicitly setting this elsewhere\n if(attr in aobj || helpers.hasParent(aobj, attr)) return;\n\n var extraparam;\n if(attr.substr(0, 6) === 'LAYOUT') {\n extraparam = layoutNP(gd.layout, attr.replace('LAYOUT', ''));\n } else {\n var tracei = traces[i];\n var preGUI = fullLayout._tracePreGUI[getFullTrace(tracei)._fullInput.uid];\n extraparam = makeNP(preGUI, guiEditFlag)(data[tracei], attr);\n }\n\n if(!(attr in undoit)) {\n undoit[attr] = a0();\n }\n if(undoit[attr][i] === undefined) {\n undoit[attr][i] = undefinedToNull(extraparam.get());\n }\n if(val !== undefined) {\n extraparam.set(val);\n }\n }\n\n function allBins(binAttr) {\n return function(j) {\n return fullData[j][binAttr];\n };\n }\n\n function arrayBins(binAttr) {\n return function(vij, j) {\n return vij === false ? fullData[traces[j]][binAttr] : null;\n };\n }\n\n // now make the changes to gd.data (and occasionally gd.layout)\n // and figure out what kind of graphics update we need to do\n for(var ai in aobj) {\n if(helpers.hasParent(aobj, ai)) {\n throw new Error('cannot set ' + ai + ' and a parent attribute simultaneously');\n }\n\n var vi = aobj[ai];\n var cont;\n var contFull;\n var param;\n var oldVal;\n var newVal;\n var valObject;\n\n // Backward compatibility shim for turning histogram autobin on,\n // or freezing previous autobinned values.\n // Replace obsolete `autobin(x|y): true` with `(x|y)bins: null`\n // and `autobin(x|y): false` with the `(x|y)bins` in `fullData`\n if(ai === 'autobinx' || ai === 'autobiny') {\n ai = ai.charAt(ai.length - 1) + 'bins';\n if(Array.isArray(vi)) vi = vi.map(arrayBins(ai));\n else if(vi === false) vi = traces.map(allBins(ai));\n else vi = null;\n }\n\n redoit[ai] = vi;\n\n if(ai.substr(0, 6) === 'LAYOUT') {\n param = layoutNP(gd.layout, ai.replace('LAYOUT', ''));\n undoit[ai] = [undefinedToNull(param.get())];\n // since we're allowing val to be an array, allow it here too,\n // even though that's meaningless\n param.set(Array.isArray(vi) ? vi[0] : vi);\n // ironically, the layout attrs in restyle only require replot,\n // not relayout\n flags.calc = true;\n continue;\n }\n\n // set attribute in gd.data\n undoit[ai] = a0();\n for(i = 0; i < traces.length; i++) {\n cont = data[traces[i]];\n contFull = getFullTrace(traces[i]);\n var preGUI = fullLayout._tracePreGUI[contFull._fullInput.uid];\n param = makeNP(preGUI, guiEditFlag)(cont, ai);\n oldVal = param.get();\n newVal = Array.isArray(vi) ? vi[i % vi.length] : vi;\n\n if(newVal === undefined) continue;\n\n var finalPart = param.parts[param.parts.length - 1];\n var prefix = ai.substr(0, ai.length - finalPart.length - 1);\n var prefixDot = prefix ? prefix + '.' : '';\n var innerContFull = prefix ?\n nestedProperty(contFull, prefix).get() : contFull;\n\n valObject = PlotSchema.getTraceValObject(contFull, param.parts);\n\n if(valObject && valObject.impliedEdits && newVal !== null) {\n for(var impliedKey in valObject.impliedEdits) {\n doextra(Lib.relativeAttr(ai, impliedKey), valObject.impliedEdits[impliedKey], i);\n }\n } else if((finalPart === 'thicknessmode' || finalPart === 'lenmode') &&\n oldVal !== newVal &&\n (newVal === 'fraction' || newVal === 'pixels') &&\n innerContFull\n ) {\n // changing colorbar size modes,\n // make the resulting size not change\n // note that colorbar fractional sizing is based on the\n // original plot size, before anything (like a colorbar)\n // increases the margins\n\n var gs = fullLayout._size;\n var orient = innerContFull.orient;\n var topOrBottom = (orient === 'top') || (orient === 'bottom');\n if(finalPart === 'thicknessmode') {\n var thicknorm = topOrBottom ? gs.h : gs.w;\n doextra(prefixDot + 'thickness', innerContFull.thickness *\n (newVal === 'fraction' ? 1 / thicknorm : thicknorm), i);\n } else {\n var lennorm = topOrBottom ? gs.w : gs.h;\n doextra(prefixDot + 'len', innerContFull.len *\n (newVal === 'fraction' ? 1 / lennorm : lennorm), i);\n }\n } else if(ai === 'type' && (\n (newVal === 'pie') !== (oldVal === 'pie') ||\n (newVal === 'funnelarea') !== (oldVal === 'funnelarea')\n )) {\n var labelsTo = 'x';\n var valuesTo = 'y';\n if((newVal === 'bar' || oldVal === 'bar') && cont.orientation === 'h') {\n labelsTo = 'y';\n valuesTo = 'x';\n }\n Lib.swapAttrs(cont, ['?', '?src'], 'labels', labelsTo);\n Lib.swapAttrs(cont, ['d?', '?0'], 'label', labelsTo);\n Lib.swapAttrs(cont, ['?', '?src'], 'values', valuesTo);\n\n if(oldVal === 'pie' || oldVal === 'funnelarea') {\n nestedProperty(cont, 'marker.color')\n .set(nestedProperty(cont, 'marker.colors').get());\n\n // super kludgy - but if all pies are gone we won't remove them otherwise\n fullLayout._pielayer.selectAll('g.trace').remove();\n } else if(Registry.traceIs(cont, 'cartesian')) {\n nestedProperty(cont, 'marker.colors')\n .set(nestedProperty(cont, 'marker.color').get());\n }\n }\n\n undoit[ai][i] = undefinedToNull(oldVal);\n // set the new value - if val is an array, it's one el per trace\n // first check for attributes that get more complex alterations\n var swapAttrs = [\n 'swapxy', 'swapxyaxes', 'orientation', 'orientationaxes'\n ];\n if(swapAttrs.indexOf(ai) !== -1) {\n // setting an orientation: make sure it's changing\n // before we swap everything else\n if(ai === 'orientation') {\n param.set(newVal);\n // obnoxious that we need this level of coupling... but in order to\n // properly handle setting orientation to `null` we need to mimic\n // the logic inside Bars.supplyDefaults for default orientation\n var defaultOrientation = (cont.x && !cont.y) ? 'h' : 'v';\n if((param.get() || defaultOrientation) === contFull.orientation) {\n continue;\n }\n } else if(ai === 'orientationaxes') {\n // orientationaxes has no value,\n // it flips everything and the axes\n\n cont.orientation =\n {v: 'h', h: 'v'}[contFull.orientation];\n }\n helpers.swapXYData(cont);\n flags.calc = flags.clearAxisTypes = true;\n } else if(Plots.dataArrayContainers.indexOf(param.parts[0]) !== -1) {\n // TODO: use manageArrays.applyContainerArrayChanges here too\n helpers.manageArrayContainers(param, newVal, undoit);\n flags.calc = true;\n } else {\n if(valObject) {\n // must redo calcdata when restyling array values of arrayOk attributes\n // ... but no need to this for regl-based traces\n if(valObject.arrayOk &&\n !Registry.traceIs(contFull, 'regl') &&\n (Lib.isArrayOrTypedArray(newVal) || Lib.isArrayOrTypedArray(oldVal))\n ) {\n flags.calc = true;\n } else editTypes.update(flags, valObject);\n } else {\n /*\n * if we couldn't find valObject, assume a full recalc.\n * This can happen if you're changing type and making\n * some other edits too, so the modules we're\n * looking at don't have these attributes in them.\n */\n flags.calc = true;\n }\n\n // all the other ones, just modify that one attribute\n param.set(newVal);\n }\n }\n\n // swap the data attributes of the relevant x and y axes?\n if(['swapxyaxes', 'orientationaxes'].indexOf(ai) !== -1) {\n Axes.swap(gd, traces);\n }\n\n // swap hovermode if set to \"compare x/y data\"\n if(ai === 'orientationaxes') {\n var hovermode = nestedProperty(gd.layout, 'hovermode');\n var h = hovermode.get();\n if(h === 'x') {\n hovermode.set('y');\n } else if(h === 'y') {\n hovermode.set('x');\n } else if(h === 'x unified') {\n hovermode.set('y unified');\n } else if(h === 'y unified') {\n hovermode.set('x unified');\n }\n }\n\n // Major enough changes deserve autoscale and\n // non-reversed axes so people don't get confused\n //\n // Note: autobin (or its new analog bin clearing) is not included here\n // since we're not pushing bins back to gd.data, so if we have bin\n // info it was explicitly provided by the user.\n if(['orientation', 'type'].indexOf(ai) !== -1) {\n axlist = [];\n for(i = 0; i < traces.length; i++) {\n var trace = data[traces[i]];\n\n if(Registry.traceIs(trace, 'cartesian')) {\n addToAxlist(trace.xaxis || 'x');\n addToAxlist(trace.yaxis || 'y');\n }\n }\n\n doextra(axlist.map(autorangeAttr), true, 0);\n doextra(axlist.map(rangeAttr), [0, 1], 0);\n }\n }\n\n if(flags.calc || flags.plot) {\n flags.fullReplot = true;\n }\n\n return {\n flags: flags,\n undoit: undoit,\n redoit: redoit,\n traces: traces,\n eventData: Lib.extendDeepNoArrays([], [eventData, traces])\n };\n}\n\n/**\n * Converts deprecated attribute keys to\n * the current API to ensure backwards compatibility.\n *\n * This is needed for the update mechanism to determine which\n * subroutines to run based on the actual attribute\n * definitions (that don't include the deprecated ones).\n *\n * E.g. Maps {'xaxis.title': 'A chart'} to {'xaxis.title.text': 'A chart'}\n * and {titlefont: {...}} to {'title.font': {...}}.\n *\n * @param aobj\n */\nfunction cleanDeprecatedAttributeKeys(aobj) {\n var oldAxisTitleRegex = Lib.counterRegex('axis', '\\.title', false, false);\n var colorbarRegex = /colorbar\\.title$/;\n var keys = Object.keys(aobj);\n var i, key, value;\n\n for(i = 0; i < keys.length; i++) {\n key = keys[i];\n value = aobj[key];\n\n if((key === 'title' || oldAxisTitleRegex.test(key) || colorbarRegex.test(key)) &&\n (typeof value === 'string' || typeof value === 'number')) {\n replace(key, key.replace('title', 'title.text'));\n } else if(key.indexOf('titlefont') > -1 && key.indexOf('grouptitlefont') === -1) {\n replace(key, key.replace('titlefont', 'title.font'));\n } else if(key.indexOf('titleposition') > -1) {\n replace(key, key.replace('titleposition', 'title.position'));\n } else if(key.indexOf('titleside') > -1) {\n replace(key, key.replace('titleside', 'title.side'));\n } else if(key.indexOf('titleoffset') > -1) {\n replace(key, key.replace('titleoffset', 'title.offset'));\n }\n }\n\n function replace(oldAttrStr, newAttrStr) {\n aobj[newAttrStr] = aobj[oldAttrStr];\n delete aobj[oldAttrStr];\n }\n}\n\n/**\n * relayout: update layout attributes of an existing plot\n *\n * Can be called two ways:\n *\n * Signature 1:\n * @param {String | HTMLDivElement} gd\n * the id or dom element of the graph container div\n * @param {String} astr\n * attribute string (like `'xaxis.range[0]'`) to update\n * @param {*} val\n * value to give this attribute\n *\n * Signature 2:\n * @param {String | HTMLDivElement} gd\n * (as in signature 1)\n * @param {Object} aobj\n * attribute object `{astr1: val1, astr2: val2 ...}`\n * allows setting multiple attributes simultaneously\n */\nfunction relayout(gd, astr, val) {\n gd = Lib.getGraphDiv(gd);\n helpers.clearPromiseQueue(gd);\n\n var aobj = {};\n if(typeof astr === 'string') {\n aobj[astr] = val;\n } else if(Lib.isPlainObject(astr)) {\n aobj = Lib.extendFlat({}, astr);\n } else {\n Lib.warn('Relayout fail.', astr, val);\n return Promise.reject();\n }\n\n if(Object.keys(aobj).length) gd.changed = true;\n\n var specs = _relayout(gd, aobj);\n var flags = specs.flags;\n\n // clear calcdata if required\n if(flags.calc) gd.calcdata = undefined;\n\n // fill in redraw sequence\n\n // even if we don't have anything left in aobj,\n // something may have happened within relayout that we\n // need to wait for\n var seq = [Plots.previousPromises];\n if(flags.layoutReplot) {\n seq.push(subroutines.layoutReplot);\n } else if(Object.keys(aobj).length) {\n axRangeSupplyDefaultsByPass(gd, flags, specs) || Plots.supplyDefaults(gd);\n\n if(flags.legend) seq.push(subroutines.doLegend);\n if(flags.layoutstyle) seq.push(subroutines.layoutStyles);\n if(flags.axrange) addAxRangeSequence(seq, specs.rangesAltered);\n if(flags.ticks) seq.push(subroutines.doTicksRelayout);\n if(flags.modebar) seq.push(subroutines.doModeBar);\n if(flags.camera) seq.push(subroutines.doCamera);\n if(flags.colorbars) seq.push(subroutines.doColorBars);\n\n seq.push(emitAfterPlot);\n }\n\n seq.push(\n Plots.rehover,\n Plots.redrag,\n Plots.reselect\n );\n\n Queue.add(gd,\n relayout, [gd, specs.undoit],\n relayout, [gd, specs.redoit]\n );\n\n var plotDone = Lib.syncOrAsync(seq, gd);\n if(!plotDone || !plotDone.then) plotDone = Promise.resolve(gd);\n\n return plotDone.then(function() {\n gd.emit('plotly_relayout', specs.eventData);\n return gd;\n });\n}\n\n// Optimization mostly for large splom traces where\n// Plots.supplyDefaults can take > 100ms\nfunction axRangeSupplyDefaultsByPass(gd, flags, specs) {\n var fullLayout = gd._fullLayout;\n\n if(!flags.axrange) return false;\n\n for(var k in flags) {\n if(k !== 'axrange' && flags[k]) return false;\n }\n\n var axIn, axOut;\n var coerce = function(attr, dflt) {\n return Lib.coerce(axIn, axOut, cartesianLayoutAttributes, attr, dflt);\n };\n\n var options = {}; // passing empty options for now!\n\n for(var axId in specs.rangesAltered) {\n var axName = Axes.id2name(axId);\n axIn = gd.layout[axName];\n axOut = fullLayout[axName];\n\n handleRangeDefaults(axIn, axOut, coerce, options);\n\n if(axOut._matchGroup) {\n for(var axId2 in axOut._matchGroup) {\n if(axId2 !== axId) {\n var ax2 = fullLayout[Axes.id2name(axId2)];\n ax2.autorange = axOut.autorange;\n ax2.range = axOut.range.slice();\n ax2._input.range = axOut.range.slice();\n }\n }\n }\n }\n\n return true;\n}\n\nfunction addAxRangeSequence(seq, rangesAltered) {\n // N.B. leave as sequence of subroutines (for now) instead of\n // subroutine of its own so that finalDraw always gets\n // executed after drawData\n var drawAxes = rangesAltered ?\n function(gd) {\n var axIds = [];\n var skipTitle = true;\n\n for(var id in rangesAltered) {\n var ax = Axes.getFromId(gd, id);\n axIds.push(id);\n\n if((ax.ticklabelposition || '').indexOf('inside') !== -1) {\n if(ax._anchorAxis) {\n axIds.push(ax._anchorAxis._id);\n }\n }\n\n if(ax._matchGroup) {\n for(var id2 in ax._matchGroup) {\n if(!rangesAltered[id2]) {\n axIds.push(id2);\n }\n }\n }\n }\n\n return Axes.draw(gd, axIds, {skipTitle: skipTitle});\n } :\n function(gd) {\n return Axes.draw(gd, 'redraw');\n };\n\n seq.push(\n clearOutline,\n subroutines.doAutoRangeAndConstraints,\n drawAxes,\n subroutines.drawData,\n subroutines.finalDraw\n );\n}\n\nvar AX_RANGE_RE = /^[xyz]axis[0-9]*\\.range(\\[[0|1]\\])?$/;\nvar AX_AUTORANGE_RE = /^[xyz]axis[0-9]*\\.autorange$/;\nvar AX_DOMAIN_RE = /^[xyz]axis[0-9]*\\.domain(\\[[0|1]\\])?$/;\n\nfunction _relayout(gd, aobj) {\n var layout = gd.layout;\n var fullLayout = gd._fullLayout;\n var guiEditFlag = fullLayout._guiEditing;\n var layoutNP = makeNP(fullLayout._preGUI, guiEditFlag);\n var keys = Object.keys(aobj);\n var axes = Axes.list(gd);\n var eventData = Lib.extendDeepAll({}, aobj);\n var arrayEdits = {};\n\n var arrayStr, i, j;\n\n cleanDeprecatedAttributeKeys(aobj);\n keys = Object.keys(aobj);\n\n // look for 'allaxes', split out into all axes\n // in case of 3D the axis are nested within a scene which is held in _id\n for(i = 0; i < keys.length; i++) {\n if(keys[i].indexOf('allaxes') === 0) {\n for(j = 0; j < axes.length; j++) {\n var scene = axes[j]._id.substr(1);\n var axisAttr = (scene.indexOf('scene') !== -1) ? (scene + '.') : '';\n var newkey = keys[i].replace('allaxes', axisAttr + axes[j]._name);\n\n if(!aobj[newkey]) aobj[newkey] = aobj[keys[i]];\n }\n\n delete aobj[keys[i]];\n }\n }\n\n // initialize flags\n var flags = editTypes.layoutFlags();\n\n // copies of the change (and previous values of anything affected)\n // for the undo / redo queue\n var redoit = {};\n var undoit = {};\n\n // for attrs that interact (like scales & autoscales), save the\n // old vals before making the change\n // val=undefined will not set a value, just record what the value was.\n // attr can be an array to set several at once (all to the same val)\n function doextra(attr, val) {\n if(Array.isArray(attr)) {\n attr.forEach(function(a) { doextra(a, val); });\n return;\n }\n\n // if we have another value for this attribute (explicitly or\n // via a parent) do not override with this auto-generated extra\n if(attr in aobj || helpers.hasParent(aobj, attr)) return;\n\n var p = layoutNP(layout, attr);\n if(!(attr in undoit)) {\n undoit[attr] = undefinedToNull(p.get());\n }\n if(val !== undefined) p.set(val);\n }\n\n // for constraint enforcement: keep track of all axes (as {id: name})\n // we're editing the (auto)range of, so we can tell the others constrained\n // to scale with them that it's OK for them to shrink\n var rangesAltered = {};\n var ax;\n\n function recordAlteredAxis(pleafPlus) {\n var axId = Axes.name2id(pleafPlus.split('.')[0]);\n rangesAltered[axId] = 1;\n return axId;\n }\n\n // alter gd.layout\n for(var ai in aobj) {\n if(helpers.hasParent(aobj, ai)) {\n throw new Error('cannot set ' + ai + ' and a parent attribute simultaneously');\n }\n\n var p = layoutNP(layout, ai);\n var vi = aobj[ai];\n var plen = p.parts.length;\n // p.parts may end with an index integer if the property is an array\n var pend = plen - 1;\n while(pend > 0 && typeof p.parts[pend] !== 'string') pend--;\n // last property in chain (leaf node)\n var pleaf = p.parts[pend];\n // leaf plus immediate parent\n var pleafPlus = p.parts[pend - 1] + '.' + pleaf;\n // trunk nodes (everything except the leaf)\n var ptrunk = p.parts.slice(0, pend).join('.');\n var parentIn = nestedProperty(gd.layout, ptrunk).get();\n var parentFull = nestedProperty(fullLayout, ptrunk).get();\n var vOld = p.get();\n\n if(vi === undefined) continue;\n\n redoit[ai] = vi;\n\n // axis reverse is special - it is its own inverse\n // op and has no flag.\n undoit[ai] = (pleaf === 'reverse') ? vi : undefinedToNull(vOld);\n\n var valObject = PlotSchema.getLayoutValObject(fullLayout, p.parts);\n\n if(valObject && valObject.impliedEdits && vi !== null) {\n for(var impliedKey in valObject.impliedEdits) {\n doextra(Lib.relativeAttr(ai, impliedKey), valObject.impliedEdits[impliedKey]);\n }\n }\n\n // Setting width or height to null must reset the graph's width / height\n // back to its initial value as computed during the first pass in Plots.plotAutoSize.\n //\n // To do so, we must manually set them back here using the _initialAutoSize cache.\n // can't use impliedEdits for this because behavior depends on vi\n if(['width', 'height'].indexOf(ai) !== -1) {\n if(vi) {\n doextra('autosize', null);\n // currently we don't support autosize one dim only - so\n // explicitly set the other one. Note that doextra will\n // ignore this if the same relayout call also provides oppositeAttr\n var oppositeAttr = ai === 'height' ? 'width' : 'height';\n doextra(oppositeAttr, fullLayout[oppositeAttr]);\n } else {\n fullLayout[ai] = gd._initialAutoSize[ai];\n }\n } else if(ai === 'autosize') {\n // depends on vi here too, so again can't use impliedEdits\n doextra('width', vi ? null : fullLayout.width);\n doextra('height', vi ? null : fullLayout.height);\n } else if(pleafPlus.match(AX_RANGE_RE)) {\n // check autorange vs range\n\n recordAlteredAxis(pleafPlus);\n nestedProperty(fullLayout, ptrunk + '._inputRange').set(null);\n } else if(pleafPlus.match(AX_AUTORANGE_RE)) {\n recordAlteredAxis(pleafPlus);\n nestedProperty(fullLayout, ptrunk + '._inputRange').set(null);\n var axFull = nestedProperty(fullLayout, ptrunk).get();\n if(axFull._inputDomain) {\n // if we're autoranging and this axis has a constrained domain,\n // reset it so we don't get locked into a shrunken size\n axFull._input.domain = axFull._inputDomain.slice();\n }\n } else if(pleafPlus.match(AX_DOMAIN_RE)) {\n nestedProperty(fullLayout, ptrunk + '._inputDomain').set(null);\n }\n\n // toggling axis type between log and linear: we need to convert\n // positions for components that are still using linearized values,\n // not data values like newer components.\n // previously we did this for log <-> not-log, but now only do it\n // for log <-> linear\n if(pleaf === 'type') {\n ax = parentIn;\n var toLog = parentFull.type === 'linear' && vi === 'log';\n var fromLog = parentFull.type === 'log' && vi === 'linear';\n\n if(toLog || fromLog) {\n if(!ax || !ax.range) {\n // 2D never gets here, but 3D does\n // I don't think this is needed, but left here in case there\n // are edge cases I'm not thinking of.\n doextra(ptrunk + '.autorange', true);\n } else if(!parentFull.autorange) {\n // toggling log without autorange: need to also recalculate ranges\n // because log axes use linearized values for range endpoints\n var r0 = ax.range[0];\n var r1 = ax.range[1];\n if(toLog) {\n // if both limits are negative, autorange\n if(r0 <= 0 && r1 <= 0) {\n doextra(ptrunk + '.autorange', true);\n }\n // if one is negative, set it 6 orders below the other.\n if(r0 <= 0) r0 = r1 / 1e6;\n else if(r1 <= 0) r1 = r0 / 1e6;\n // now set the range values as appropriate\n doextra(ptrunk + '.range[0]', Math.log(r0) / Math.LN10);\n doextra(ptrunk + '.range[1]', Math.log(r1) / Math.LN10);\n } else {\n doextra(ptrunk + '.range[0]', Math.pow(10, r0));\n doextra(ptrunk + '.range[1]', Math.pow(10, r1));\n }\n } else if(toLog) {\n // just make sure the range is positive and in the right\n // order, it'll get recalculated later\n ax.range = (ax.range[1] > ax.range[0]) ? [1, 2] : [2, 1];\n }\n\n // clear polar view initial stash for radial range so that\n // value get recomputed in correct units\n if(Array.isArray(fullLayout._subplots.polar) &&\n fullLayout._subplots.polar.length &&\n fullLayout[p.parts[0]] &&\n p.parts[1] === 'radialaxis'\n ) {\n delete fullLayout[p.parts[0]]._subplot.viewInitial['radialaxis.range'];\n }\n\n // Annotations and images also need to convert to/from linearized coords\n // Shapes do not need this :)\n Registry.getComponentMethod('annotations', 'convertCoords')(gd, parentFull, vi, doextra);\n Registry.getComponentMethod('images', 'convertCoords')(gd, parentFull, vi, doextra);\n } else {\n // any other type changes: the range from the previous type\n // will not make sense, so autorange it.\n doextra(ptrunk + '.autorange', true);\n doextra(ptrunk + '.range', null);\n }\n nestedProperty(fullLayout, ptrunk + '._inputRange').set(null);\n } else if(pleaf.match(AX_NAME_PATTERN)) {\n var fullProp = nestedProperty(fullLayout, ai).get();\n var newType = (vi || {}).type;\n\n // This can potentially cause strange behavior if the autotype is not\n // numeric (linear, because we don't auto-log) but the previous type\n // was log. That's a very strange edge case though\n if(!newType || newType === '-') newType = 'linear';\n Registry.getComponentMethod('annotations', 'convertCoords')(gd, fullProp, newType, doextra);\n Registry.getComponentMethod('images', 'convertCoords')(gd, fullProp, newType, doextra);\n }\n\n // alter gd.layout\n\n // collect array component edits for execution all together\n // so we can ensure consistent behavior adding/removing items\n // and order-independence for add/remove/edit all together in\n // one relayout call\n var containerArrayMatch = manageArrays.containerArrayMatch(ai);\n if(containerArrayMatch) {\n arrayStr = containerArrayMatch.array;\n i = containerArrayMatch.index;\n var propStr = containerArrayMatch.property;\n var updateValObject = valObject || {editType: 'calc'};\n\n if(i !== '' && propStr === '') {\n // special handling of undoit if we're adding or removing an element\n // ie 'annotations[2]' which can be {...} (add) or null,\n // does not work when replacing the entire array\n if(manageArrays.isAddVal(vi)) {\n undoit[ai] = null;\n } else if(manageArrays.isRemoveVal(vi)) {\n undoit[ai] = (nestedProperty(layout, arrayStr).get() || [])[i];\n } else {\n Lib.warn('unrecognized full object value', aobj);\n }\n }\n editTypes.update(flags, updateValObject);\n\n // prepare the edits object we'll send to applyContainerArrayChanges\n if(!arrayEdits[arrayStr]) arrayEdits[arrayStr] = {};\n var objEdits = arrayEdits[arrayStr][i];\n if(!objEdits) objEdits = arrayEdits[arrayStr][i] = {};\n objEdits[propStr] = vi;\n\n delete aobj[ai];\n } else if(pleaf === 'reverse') {\n // handle axis reversal explicitly, as there's no 'reverse' attribute\n\n if(parentIn.range) parentIn.range.reverse();\n else {\n doextra(ptrunk + '.autorange', true);\n parentIn.range = [1, 0];\n }\n\n if(parentFull.autorange) flags.calc = true;\n else flags.plot = true;\n } else {\n if(ai === 'dragmode' && ((vi === false && vOld !== false) || (vi !== false && vOld === false))) {\n flags.plot = true;\n } else if((fullLayout._has('scatter-like') && fullLayout._has('regl')) &&\n (ai === 'dragmode' &&\n (vi === 'lasso' || vi === 'select') &&\n !(vOld === 'lasso' || vOld === 'select'))\n ) {\n flags.plot = true;\n } else if(fullLayout._has('gl2d')) {\n flags.plot = true;\n } else if(valObject) editTypes.update(flags, valObject);\n else flags.calc = true;\n\n p.set(vi);\n }\n }\n\n // now we've collected component edits - execute them all together\n for(arrayStr in arrayEdits) {\n var finished = manageArrays.applyContainerArrayChanges(gd,\n layoutNP(layout, arrayStr), arrayEdits[arrayStr], flags, layoutNP);\n if(!finished) flags.plot = true;\n }\n\n // figure out if we need to recalculate axis constraints\n for(var axId in rangesAltered) {\n ax = Axes.getFromId(gd, axId);\n var group = ax && ax._constraintGroup;\n if(group) {\n // Always recalc if we're changing constrained ranges.\n // Otherwise it's possible to violate the constraints by\n // specifying arbitrary ranges for all axes in the group.\n // this way some ranges may expand beyond what's specified,\n // as they do at first draw, to satisfy the constraints.\n flags.calc = true;\n for(var groupAxId in group) {\n if(!rangesAltered[groupAxId]) {\n Axes.getFromId(gd, groupAxId)._constraintShrinkable = true;\n }\n }\n }\n }\n\n // If the autosize changed or height or width was explicitly specified,\n // this triggers a redraw\n // TODO: do we really need special aobj.height/width handling here?\n // couldn't editType do this?\n if(updateAutosize(gd) || aobj.height || aobj.width) flags.plot = true;\n\n // update shape legends\n var shapes = fullLayout.shapes;\n for(i = 0; i < shapes.length; i++) {\n if(shapes[i].showlegend) {\n flags.calc = true;\n break;\n }\n }\n\n if(flags.plot || flags.calc) {\n flags.layoutReplot = true;\n }\n\n // now all attribute mods are done, as are\n // redo and undo so we can save them\n\n return {\n flags: flags,\n rangesAltered: rangesAltered,\n undoit: undoit,\n redoit: redoit,\n eventData: eventData\n };\n}\n\n/*\n * updateAutosize: we made a change, does it change the autosize result?\n * puts the new size into fullLayout\n * returns true if either height or width changed\n */\nfunction updateAutosize(gd) {\n var fullLayout = gd._fullLayout;\n var oldWidth = fullLayout.width;\n var oldHeight = fullLayout.height;\n\n // calculate autosizing\n if(gd.layout.autosize) Plots.plotAutoSize(gd, gd.layout, fullLayout);\n\n return (fullLayout.width !== oldWidth) || (fullLayout.height !== oldHeight);\n}\n\n/**\n * update: update trace and layout attributes of an existing plot\n *\n * @param {String | HTMLDivElement} gd\n * the id or DOM element of the graph container div\n * @param {Object} traceUpdate\n * attribute object `{astr1: val1, astr2: val2 ...}`\n * corresponding to updates in the plot's traces\n * @param {Object} layoutUpdate\n * attribute object `{astr1: val1, astr2: val2 ...}`\n * corresponding to updates in the plot's layout\n * @param {Number[] | Number} [traces]\n * integer or array of integers for the traces to alter (all if omitted)\n *\n */\nfunction update(gd, traceUpdate, layoutUpdate, _traces) {\n gd = Lib.getGraphDiv(gd);\n helpers.clearPromiseQueue(gd);\n\n if(!Lib.isPlainObject(traceUpdate)) traceUpdate = {};\n if(!Lib.isPlainObject(layoutUpdate)) layoutUpdate = {};\n\n if(Object.keys(traceUpdate).length) gd.changed = true;\n if(Object.keys(layoutUpdate).length) gd.changed = true;\n\n var traces = helpers.coerceTraceIndices(gd, _traces);\n\n var restyleSpecs = _restyle(gd, Lib.extendFlat({}, traceUpdate), traces);\n var restyleFlags = restyleSpecs.flags;\n\n var relayoutSpecs = _relayout(gd, Lib.extendFlat({}, layoutUpdate));\n var relayoutFlags = relayoutSpecs.flags;\n\n // clear calcdata and/or axis types if required\n if(restyleFlags.calc || relayoutFlags.calc) gd.calcdata = undefined;\n if(restyleFlags.clearAxisTypes) helpers.clearAxisTypes(gd, traces, layoutUpdate);\n\n // fill in redraw sequence\n var seq = [];\n\n if(relayoutFlags.layoutReplot) {\n // N.B. works fine when both\n // relayoutFlags.layoutReplot and restyleFlags.fullReplot are true\n seq.push(subroutines.layoutReplot);\n } else if(restyleFlags.fullReplot) {\n seq.push(exports._doPlot);\n } else {\n seq.push(Plots.previousPromises);\n axRangeSupplyDefaultsByPass(gd, relayoutFlags, relayoutSpecs) || Plots.supplyDefaults(gd);\n\n if(restyleFlags.style) seq.push(subroutines.doTraceStyle);\n if(restyleFlags.colorbars || relayoutFlags.colorbars) seq.push(subroutines.doColorBars);\n if(relayoutFlags.legend) seq.push(subroutines.doLegend);\n if(relayoutFlags.layoutstyle) seq.push(subroutines.layoutStyles);\n if(relayoutFlags.axrange) addAxRangeSequence(seq, relayoutSpecs.rangesAltered);\n if(relayoutFlags.ticks) seq.push(subroutines.doTicksRelayout);\n if(relayoutFlags.modebar) seq.push(subroutines.doModeBar);\n if(relayoutFlags.camera) seq.push(subroutines.doCamera);\n\n seq.push(emitAfterPlot);\n }\n\n seq.push(\n Plots.rehover,\n Plots.redrag,\n Plots.reselect\n );\n\n Queue.add(gd,\n update, [gd, restyleSpecs.undoit, relayoutSpecs.undoit, restyleSpecs.traces],\n update, [gd, restyleSpecs.redoit, relayoutSpecs.redoit, restyleSpecs.traces]\n );\n\n var plotDone = Lib.syncOrAsync(seq, gd);\n if(!plotDone || !plotDone.then) plotDone = Promise.resolve(gd);\n\n return plotDone.then(function() {\n gd.emit('plotly_update', {\n data: restyleSpecs.eventData,\n layout: relayoutSpecs.eventData\n });\n\n return gd;\n });\n}\n\n/*\n * internal-use-only restyle/relayout/update variants that record the initial\n * values in (fullLayout|fullTrace)._preGUI so changes can be persisted across\n * Plotly.react data updates, dependent on uirevision attributes\n */\nfunction guiEdit(func) {\n return function wrappedEdit(gd) {\n gd._fullLayout._guiEditing = true;\n var p = func.apply(null, arguments);\n gd._fullLayout._guiEditing = false;\n return p;\n };\n}\n\n// For connecting edited layout attributes to uirevision attrs\n// If no `attr` we use `match[1] + '.uirevision'`\n// Ordered by most common edits first, to minimize our search time\nvar layoutUIControlPatterns = [\n {pattern: /^hiddenlabels/, attr: 'legend.uirevision'},\n {pattern: /^((x|y)axis\\d*)\\.((auto)?range|title\\.text)/},\n\n // showspikes and modes include those nested inside scenes\n {pattern: /axis\\d*\\.showspikes$/, attr: 'modebar.uirevision'},\n {pattern: /(hover|drag)mode$/, attr: 'modebar.uirevision'},\n\n {pattern: /^(scene\\d*)\\.camera/},\n {pattern: /^(geo\\d*)\\.(projection|center|fitbounds)/},\n {pattern: /^(ternary\\d*\\.[abc]axis)\\.(min|title\\.text)$/},\n {pattern: /^(polar\\d*\\.radialaxis)\\.((auto)?range|angle|title\\.text)/},\n {pattern: /^(polar\\d*\\.angularaxis)\\.rotation/},\n {pattern: /^(mapbox\\d*)\\.(center|zoom|bearing|pitch)/},\n {pattern: /^(map\\d*)\\.(center|zoom|bearing|pitch)/},\n\n {pattern: /^legend\\.(x|y)$/, attr: 'editrevision'},\n {pattern: /^(shapes|annotations)/, attr: 'editrevision'},\n {pattern: /^title\\.text$/, attr: 'editrevision'}\n];\n\n// same for trace attributes: if `attr` is given it's in layout,\n// or with no `attr` we use `trace.uirevision`\nvar traceUIControlPatterns = [\n {pattern: /^selectedpoints$/, attr: 'selectionrevision'},\n // \"visible\" includes trace.transforms[i].styles[j].value.visible\n {pattern: /(^|value\\.)visible$/, attr: 'legend.uirevision'},\n {pattern: /^dimensions\\[\\d+\\]\\.constraintrange/},\n {pattern: /^node\\.(x|y|groups)/}, // for Sankey nodes\n {pattern: /^level$/}, // for Sunburst, Treemap and Icicle traces\n\n // below this you must be in editable: true mode\n // TODO: I still put name and title with `trace.uirevision`\n // reasonable or should these be `editrevision`?\n // Also applies to axis titles up in the layout section\n\n // \"name\" also includes transform.styles\n {pattern: /(^|value\\.)name$/},\n // including nested colorbar attributes (ie marker.colorbar)\n {pattern: /colorbar\\.title\\.text$/},\n {pattern: /colorbar\\.(x|y)$/, attr: 'editrevision'}\n];\n\nfunction findUIPattern(key, patternSpecs) {\n for(var i = 0; i < patternSpecs.length; i++) {\n var spec = patternSpecs[i];\n var match = key.match(spec.pattern);\n if(match) {\n var head = match[1] || '';\n return {head: head, tail: key.substr(head.length + 1), attr: spec.attr};\n }\n }\n}\n\n// We're finding the new uirevision before supplyDefaults, so do the\n// inheritance manually. Note that only `undefined` inherits - other\n// falsy values are returned.\nfunction getNewRev(revAttr, container) {\n var newRev = nestedProperty(container, revAttr).get();\n if(newRev !== undefined) return newRev;\n\n var parts = revAttr.split('.');\n parts.pop();\n while(parts.length > 1) {\n parts.pop();\n newRev = nestedProperty(container, parts.join('.') + '.uirevision').get();\n if(newRev !== undefined) return newRev;\n }\n\n return container.uirevision;\n}\n\nfunction getFullTraceIndexFromUid(uid, fullData) {\n for(var i = 0; i < fullData.length; i++) {\n if(fullData[i]._fullInput.uid === uid) return i;\n }\n return -1;\n}\n\nfunction getTraceIndexFromUid(uid, data, tracei) {\n for(var i = 0; i < data.length; i++) {\n if(data[i].uid === uid) return i;\n }\n // fall back on trace order, but only if user didn't provide a uid for that trace\n return (!data[tracei] || data[tracei].uid) ? -1 : tracei;\n}\n\nfunction valsMatch(v1, v2) {\n var v1IsObj = Lib.isPlainObject(v1);\n var v1IsArray = Array.isArray(v1);\n if(v1IsObj || v1IsArray) {\n return (\n (v1IsObj && Lib.isPlainObject(v2)) ||\n (v1IsArray && Array.isArray(v2))\n ) && JSON.stringify(v1) === JSON.stringify(v2);\n }\n return v1 === v2;\n}\n\nfunction applyUIRevisions(data, layout, oldFullData, oldFullLayout) {\n var layoutPreGUI = oldFullLayout._preGUI;\n var key, revAttr, oldRev, newRev, match, preGUIVal, newNP, newVal, head, tail;\n var bothInheritAutorange = [];\n var newAutorangeIn = {};\n var newRangeAccepted = {};\n for(key in layoutPreGUI) {\n match = findUIPattern(key, layoutUIControlPatterns);\n if(match) {\n head = match.head;\n tail = match.tail;\n revAttr = match.attr || (head + '.uirevision');\n oldRev = nestedProperty(oldFullLayout, revAttr).get();\n newRev = oldRev && getNewRev(revAttr, layout);\n\n if(newRev && (newRev === oldRev)) {\n preGUIVal = layoutPreGUI[key];\n if(preGUIVal === null) preGUIVal = undefined;\n newNP = nestedProperty(layout, key);\n newVal = newNP.get();\n\n if(valsMatch(newVal, preGUIVal)) {\n if(newVal === undefined && tail === 'autorange') {\n bothInheritAutorange.push(head);\n }\n newNP.set(undefinedToNull(nestedProperty(oldFullLayout, key).get()));\n continue;\n } else if(tail === 'autorange' || tail.substr(0, 6) === 'range[') {\n // Special case for (auto)range since we push it back into the layout\n // so all null should be treated equivalently to autorange: true with any range\n var pre0 = layoutPreGUI[head + '.range[0]'];\n var pre1 = layoutPreGUI[head + '.range[1]'];\n var preAuto = layoutPreGUI[head + '.autorange'];\n if(preAuto || (preAuto === null && pre0 === null && pre1 === null)) {\n // Only read the input layout once and stash the result,\n // so we get it before we start modifying it\n if(!(head in newAutorangeIn)) {\n var newContainer = nestedProperty(layout, head).get();\n newAutorangeIn[head] = newContainer && (\n newContainer.autorange ||\n (newContainer.autorange !== false && (\n !newContainer.range || newContainer.range.length !== 2)\n )\n );\n }\n if(newAutorangeIn[head]) {\n newNP.set(undefinedToNull(nestedProperty(oldFullLayout, key).get()));\n continue;\n }\n }\n }\n }\n } else {\n Lib.warn('unrecognized GUI edit: ' + key);\n }\n // if we got this far, the new value was accepted as the new starting\n // point (either because it changed or revision changed)\n // so remove it from _preGUI for next time.\n delete layoutPreGUI[key];\n\n if(match && match.tail.substr(0, 6) === 'range[') {\n newRangeAccepted[match.head] = 1;\n }\n }\n\n // More special logic for `autorange`, since it interacts with `range`:\n // If the new figure's matching `range` was kept, and `autorange`\n // wasn't supplied explicitly in either the original or the new figure,\n // we shouldn't alter that - but we may just have done that, so fix it.\n for(var i = 0; i < bothInheritAutorange.length; i++) {\n var axAttr = bothInheritAutorange[i];\n if(newRangeAccepted[axAttr]) {\n var newAx = nestedProperty(layout, axAttr).get();\n if(newAx) delete newAx.autorange;\n }\n }\n\n // Now traces - try to match them up by uid (in case we added/deleted in\n // the middle), then fall back on index.\n var allTracePreGUI = oldFullLayout._tracePreGUI;\n for(var uid in allTracePreGUI) {\n var tracePreGUI = allTracePreGUI[uid];\n var newTrace = null;\n var fullInput;\n for(key in tracePreGUI) {\n // wait until we know we have preGUI values to look for traces\n // but if we don't find both, stop looking at this uid\n if(!newTrace) {\n var fulli = getFullTraceIndexFromUid(uid, oldFullData);\n if(fulli < 0) {\n // Somehow we didn't even have this trace in oldFullData...\n // I guess this could happen with `deleteTraces` or something\n delete allTracePreGUI[uid];\n break;\n }\n var fullTrace = oldFullData[fulli];\n fullInput = fullTrace._fullInput;\n\n var newTracei = getTraceIndexFromUid(uid, data, fullInput.index);\n if(newTracei < 0) {\n // No match in new data\n delete allTracePreGUI[uid];\n break;\n }\n newTrace = data[newTracei];\n }\n\n match = findUIPattern(key, traceUIControlPatterns);\n if(match) {\n if(match.attr) {\n oldRev = nestedProperty(oldFullLayout, match.attr).get();\n newRev = oldRev && getNewRev(match.attr, layout);\n } else {\n oldRev = fullInput.uirevision;\n // inheritance for trace.uirevision is simple, just layout.uirevision\n newRev = newTrace.uirevision;\n if(newRev === undefined) newRev = layout.uirevision;\n }\n\n if(newRev && newRev === oldRev) {\n preGUIVal = tracePreGUI[key];\n if(preGUIVal === null) preGUIVal = undefined;\n newNP = nestedProperty(newTrace, key);\n newVal = newNP.get();\n if(valsMatch(newVal, preGUIVal)) {\n newNP.set(undefinedToNull(nestedProperty(fullInput, key).get()));\n continue;\n }\n }\n } else {\n Lib.warn('unrecognized GUI edit: ' + key + ' in trace uid ' + uid);\n }\n delete tracePreGUI[key];\n }\n }\n}\n\n/**\n * Plotly.react:\n * A plot/update method that takes the full plot state (same API as plot/newPlot)\n * and diffs to determine the minimal update pathway\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n * @param {array of objects} data\n * array of traces, containing the data and display information for each trace\n * @param {object} layout\n * object describing the overall display of the plot,\n * all the stuff that doesn't pertain to any individual trace\n * @param {object} config\n * configuration options (see ./plot_config.js for more info)\n *\n * OR\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n * @param {object} figure\n * object containing `data`, `layout`, `config`, and `frames` members\n *\n */\nfunction react(gd, data, layout, config) {\n var frames, plotDone;\n\n function addFrames() { return exports.addFrames(gd, frames); }\n\n gd = Lib.getGraphDiv(gd);\n helpers.clearPromiseQueue(gd);\n\n var oldFullData = gd._fullData;\n var oldFullLayout = gd._fullLayout;\n\n // you can use this as the initial draw as well as to update\n if(!Lib.isPlotDiv(gd) || !oldFullData || !oldFullLayout) {\n plotDone = exports.newPlot(gd, data, layout, config);\n } else {\n if(Lib.isPlainObject(data)) {\n var obj = data;\n data = obj.data;\n layout = obj.layout;\n config = obj.config;\n frames = obj.frames;\n }\n\n var configChanged = false;\n // assume that if there's a config at all, we're reacting to it too,\n // and completely replace the previous config\n if(config) {\n var oldConfig = Lib.extendDeep({}, gd._context);\n gd._context = undefined;\n setPlotContext(gd, config);\n configChanged = diffConfig(oldConfig, gd._context);\n }\n\n gd.data = data || [];\n helpers.cleanData(gd.data);\n gd.layout = layout || {};\n helpers.cleanLayout(gd.layout);\n\n applyUIRevisions(gd.data, gd.layout, oldFullData, oldFullLayout);\n\n // \"true\" skips updating calcdata and remapping arrays from calcTransforms,\n // which supplyDefaults usually does at the end, but we may need to NOT do\n // if the diff (which we haven't determined yet) says we'll recalc\n Plots.supplyDefaults(gd, {skipUpdateCalc: true});\n\n var newFullData = gd._fullData;\n var newFullLayout = gd._fullLayout;\n var immutable = newFullLayout.datarevision === undefined;\n var transition = newFullLayout.transition;\n\n var relayoutFlags = diffLayout(gd, oldFullLayout, newFullLayout, immutable, transition);\n var newDataRevision = relayoutFlags.newDataRevision;\n var restyleFlags = diffData(gd, oldFullData, newFullData, immutable, transition, newDataRevision);\n\n // TODO: how to translate this part of relayout to Plotly.react?\n // // Setting width or height to null must reset the graph's width / height\n // // back to its initial value as computed during the first pass in Plots.plotAutoSize.\n // //\n // // To do so, we must manually set them back here using the _initialAutoSize cache.\n // if(['width', 'height'].indexOf(ai) !== -1 && vi === null) {\n // fullLayout[ai] = gd._initialAutoSize[ai];\n // }\n\n if(updateAutosize(gd)) relayoutFlags.layoutReplot = true;\n\n // clear calcdata and empty categories if required\n if(restyleFlags.calc || relayoutFlags.calc) {\n gd.calcdata = undefined;\n var allNames = Object.getOwnPropertyNames(newFullLayout);\n for(var q = 0; q < allNames.length; q++) {\n var name = allNames[q];\n var start = name.substring(0, 5);\n if(start === 'xaxis' || start === 'yaxis') {\n var emptyCategories = newFullLayout[name]._emptyCategories;\n if(emptyCategories) emptyCategories();\n }\n }\n // otherwise do the calcdata updates and calcTransform array remaps that we skipped earlier\n } else {\n Plots.supplyDefaultsUpdateCalc(gd.calcdata, newFullData);\n }\n\n // Note: what restyle/relayout use impliedEdits and clearAxisTypes for\n // must be handled by the user when using Plotly.react.\n\n // fill in redraw sequence\n var seq = [];\n\n if(frames) {\n gd._transitionData = {};\n Plots.createTransitionData(gd);\n seq.push(addFrames);\n }\n\n // Transition pathway,\n // only used when 'transition' is set by user and\n // when at least one animatable attribute has changed,\n // N.B. config changed aren't animatable\n if(newFullLayout.transition && !configChanged && (restyleFlags.anim || relayoutFlags.anim)) {\n if(relayoutFlags.ticks) seq.push(subroutines.doTicksRelayout);\n\n Plots.doCalcdata(gd);\n subroutines.doAutoRangeAndConstraints(gd);\n\n seq.push(function() {\n return Plots.transitionFromReact(gd, restyleFlags, relayoutFlags, oldFullLayout);\n });\n } else if(restyleFlags.fullReplot || relayoutFlags.layoutReplot || configChanged) {\n gd._fullLayout._skipDefaults = true;\n seq.push(exports._doPlot);\n } else {\n for(var componentType in relayoutFlags.arrays) {\n var indices = relayoutFlags.arrays[componentType];\n if(indices.length) {\n var drawOne = Registry.getComponentMethod(componentType, 'drawOne');\n if(drawOne !== Lib.noop) {\n for(var i = 0; i < indices.length; i++) {\n drawOne(gd, indices[i]);\n }\n } else {\n var draw = Registry.getComponentMethod(componentType, 'draw');\n if(draw === Lib.noop) {\n throw new Error('cannot draw components: ' + componentType);\n }\n draw(gd);\n }\n }\n }\n\n seq.push(Plots.previousPromises);\n if(restyleFlags.style) seq.push(subroutines.doTraceStyle);\n if(restyleFlags.colorbars || relayoutFlags.colorbars) seq.push(subroutines.doColorBars);\n if(relayoutFlags.legend) seq.push(subroutines.doLegend);\n if(relayoutFlags.layoutstyle) seq.push(subroutines.layoutStyles);\n if(relayoutFlags.axrange) addAxRangeSequence(seq);\n if(relayoutFlags.ticks) seq.push(subroutines.doTicksRelayout);\n if(relayoutFlags.modebar) seq.push(subroutines.doModeBar);\n if(relayoutFlags.camera) seq.push(subroutines.doCamera);\n seq.push(emitAfterPlot);\n }\n\n seq.push(\n Plots.rehover,\n Plots.redrag,\n Plots.reselect\n );\n\n plotDone = Lib.syncOrAsync(seq, gd);\n if(!plotDone || !plotDone.then) plotDone = Promise.resolve(gd);\n }\n\n return plotDone.then(function() {\n gd.emit('plotly_react', {\n data: data,\n layout: layout\n });\n\n return gd;\n });\n}\n\nfunction diffData(gd, oldFullData, newFullData, immutable, transition, newDataRevision) {\n var sameTraceLength = oldFullData.length === newFullData.length;\n\n if(!transition && !sameTraceLength) {\n return {\n fullReplot: true,\n calc: true\n };\n }\n\n var flags = editTypes.traceFlags();\n flags.arrays = {};\n flags.nChanges = 0;\n flags.nChangesAnim = 0;\n\n var i, trace;\n\n function getTraceValObject(parts) {\n var out = PlotSchema.getTraceValObject(trace, parts);\n if(!trace._module.animatable && out.anim) {\n out.anim = false;\n }\n return out;\n }\n\n var diffOpts = {\n getValObject: getTraceValObject,\n flags: flags,\n immutable: immutable,\n transition: transition,\n newDataRevision: newDataRevision,\n gd: gd\n };\n\n var seenUIDs = {};\n\n for(i = 0; i < oldFullData.length; i++) {\n if(newFullData[i]) {\n trace = newFullData[i]._fullInput;\n if(Plots.hasMakesDataTransform(trace)) trace = newFullData[i];\n if(seenUIDs[trace.uid]) continue;\n seenUIDs[trace.uid] = 1;\n\n getDiffFlags(oldFullData[i]._fullInput, trace, [], diffOpts);\n }\n }\n\n if(flags.calc || flags.plot) {\n flags.fullReplot = true;\n }\n\n if(transition && flags.nChanges && flags.nChangesAnim) {\n flags.anim = (flags.nChanges === flags.nChangesAnim) && sameTraceLength ? 'all' : 'some';\n }\n\n return flags;\n}\n\nfunction diffLayout(gd, oldFullLayout, newFullLayout, immutable, transition) {\n var flags = editTypes.layoutFlags();\n flags.arrays = {};\n flags.rangesAltered = {};\n flags.nChanges = 0;\n flags.nChangesAnim = 0;\n\n function getLayoutValObject(parts) {\n return PlotSchema.getLayoutValObject(newFullLayout, parts);\n }\n\n var diffOpts = {\n getValObject: getLayoutValObject,\n flags: flags,\n immutable: immutable,\n transition: transition,\n gd: gd\n };\n\n getDiffFlags(oldFullLayout, newFullLayout, [], diffOpts);\n\n if(flags.plot || flags.calc) {\n flags.layoutReplot = true;\n }\n\n if(transition && flags.nChanges && flags.nChangesAnim) {\n flags.anim = flags.nChanges === flags.nChangesAnim ? 'all' : 'some';\n }\n\n return flags;\n}\n\nfunction getDiffFlags(oldContainer, newContainer, outerparts, opts) {\n var valObject, key, astr;\n\n var getValObject = opts.getValObject;\n var flags = opts.flags;\n var immutable = opts.immutable;\n var inArray = opts.inArray;\n var arrayIndex = opts.arrayIndex;\n\n function changed() {\n var editType = valObject.editType;\n if(inArray && editType.indexOf('arraydraw') !== -1) {\n Lib.pushUnique(flags.arrays[inArray], arrayIndex);\n return;\n }\n editTypes.update(flags, valObject);\n\n if(editType !== 'none') {\n flags.nChanges++;\n }\n\n // track animatable changes\n if(opts.transition && valObject.anim) {\n flags.nChangesAnim++;\n }\n\n // track cartesian axes with altered ranges\n if(AX_RANGE_RE.test(astr) || AX_AUTORANGE_RE.test(astr)) {\n flags.rangesAltered[outerparts[0]] = 1;\n }\n\n // clear _inputDomain on cartesian axes with altered domains\n if(AX_DOMAIN_RE.test(astr)) {\n nestedProperty(newContainer, '_inputDomain').set(null);\n }\n\n // track datarevision changes\n if(key === 'datarevision') {\n flags.newDataRevision = 1;\n }\n }\n\n function valObjectCanBeDataArray(valObject) {\n return valObject.valType === 'data_array' || valObject.arrayOk;\n }\n\n for(key in oldContainer) {\n // short-circuit based on previous calls or previous keys that already maximized the pathway\n if(flags.calc && !opts.transition) return;\n\n var oldVal = oldContainer[key];\n var newVal = newContainer[key];\n var parts = outerparts.concat(key);\n astr = parts.join('.');\n\n if(key.charAt(0) === '_' || typeof oldVal === 'function' || oldVal === newVal) continue;\n\n // FIXME: ax.tick0 and dtick get filled in during plotting (except for geo subplots),\n // and unlike other auto values they don't make it back into the input,\n // so newContainer won't have them.\n if((key === 'tick0' || key === 'dtick') && outerparts[0] !== 'geo') {\n var tickMode = newContainer.tickmode;\n if(tickMode === 'auto' || tickMode === 'array' || !tickMode) continue;\n }\n // FIXME: Similarly for axis ranges for 3D\n // contourcarpet doesn't HAVE zmin/zmax, they're just auto-added. It needs them.\n if(key === 'range' && newContainer.autorange) continue;\n if((key === 'zmin' || key === 'zmax') && newContainer.type === 'contourcarpet') continue;\n\n valObject = getValObject(parts);\n\n // in case type changed, we may not even *have* a valObject.\n if(!valObject) continue;\n\n if(valObject._compareAsJSON && JSON.stringify(oldVal) === JSON.stringify(newVal)) continue;\n\n var valType = valObject.valType;\n var i;\n\n var canBeDataArray = valObjectCanBeDataArray(valObject);\n var wasArray = Array.isArray(oldVal);\n var nowArray = Array.isArray(newVal);\n\n // hack for traces that modify the data in supplyDefaults, like\n // converting 1D to 2D arrays, which will always create new objects\n if(wasArray && nowArray) {\n var inputKey = '_input_' + key;\n var oldValIn = oldContainer[inputKey];\n var newValIn = newContainer[inputKey];\n if(Array.isArray(oldValIn) && oldValIn === newValIn) continue;\n }\n\n if(newVal === undefined) {\n if(canBeDataArray && wasArray) flags.calc = true;\n else changed();\n } else if(valObject._isLinkedToArray) {\n var arrayEditIndices = [];\n var extraIndices = false;\n if(!inArray) flags.arrays[key] = arrayEditIndices;\n\n var minLen = Math.min(oldVal.length, newVal.length);\n var maxLen = Math.max(oldVal.length, newVal.length);\n if(minLen !== maxLen) {\n if(valObject.editType === 'arraydraw') {\n extraIndices = true;\n } else {\n changed();\n continue;\n }\n }\n\n for(i = 0; i < minLen; i++) {\n getDiffFlags(oldVal[i], newVal[i], parts.concat(i),\n // add array indices, but not if we're already in an array\n Lib.extendFlat({inArray: key, arrayIndex: i}, opts));\n }\n\n // put this at the end so that we know our collected array indices are sorted\n // but the check for length changes happens up front so we can short-circuit\n // diffing if appropriate\n if(extraIndices) {\n for(i = minLen; i < maxLen; i++) {\n arrayEditIndices.push(i);\n }\n }\n } else if(!valType && Lib.isPlainObject(oldVal)) {\n getDiffFlags(oldVal, newVal, parts, opts);\n } else if(canBeDataArray) {\n if(wasArray && nowArray) {\n // don't try to diff two data arrays. If immutable we know the data changed,\n // if not, assume it didn't and let `layout.datarevision` tell us if it did\n if(immutable) {\n flags.calc = true;\n }\n\n // look for animatable attributes when the data changed\n if(immutable || opts.newDataRevision) {\n changed();\n }\n } else if(wasArray !== nowArray) {\n flags.calc = true;\n } else changed();\n } else if(wasArray && nowArray) {\n // info array, colorscale, 'any' - these are short, just stringify.\n // I don't *think* that covers up any real differences post-validation, does it?\n // otherwise we need to dive in 1 (info_array) or 2 (colorscale) levels and compare\n // all elements.\n if(oldVal.length !== newVal.length || String(oldVal) !== String(newVal)) {\n changed();\n }\n } else {\n changed();\n }\n }\n\n for(key in newContainer) {\n if(!(key in oldContainer || key.charAt(0) === '_' || typeof newContainer[key] === 'function')) {\n valObject = getValObject(outerparts.concat(key));\n\n if(valObjectCanBeDataArray(valObject) && Array.isArray(newContainer[key])) {\n flags.calc = true;\n return;\n } else changed();\n }\n }\n}\n\n/*\n * simple diff for config - for now, just treat all changes as equivalent\n */\nfunction diffConfig(oldConfig, newConfig) {\n var key;\n\n for(key in oldConfig) {\n if(key.charAt(0) === '_') continue;\n var oldVal = oldConfig[key];\n var newVal = newConfig[key];\n if(oldVal !== newVal) {\n if(Lib.isPlainObject(oldVal) && Lib.isPlainObject(newVal)) {\n if(diffConfig(oldVal, newVal)) {\n return true;\n }\n } else if(Array.isArray(oldVal) && Array.isArray(newVal)) {\n if(oldVal.length !== newVal.length) {\n return true;\n }\n for(var i = 0; i < oldVal.length; i++) {\n if(oldVal[i] !== newVal[i]) {\n if(Lib.isPlainObject(oldVal[i]) && Lib.isPlainObject(newVal[i])) {\n if(diffConfig(oldVal[i], newVal[i])) {\n return true;\n }\n } else {\n return true;\n }\n }\n }\n } else {\n return true;\n }\n }\n }\n}\n\n/**\n * Animate to a frame, sequence of frame, frame group, or frame definition\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n *\n * @param {string or object or array of strings or array of objects} frameOrGroupNameOrFrameList\n * a single frame, array of frames, or group to which to animate. The intent is\n * inferred by the type of the input. Valid inputs are:\n *\n * - string, e.g. 'groupname': animate all frames of a given `group` in the order\n * in which they are defined via `Plotly.addFrames`.\n *\n * - array of strings, e.g. ['frame1', frame2']: a list of frames by name to which\n * to animate in sequence\n *\n * - object: {data: ...}: a frame definition to which to animate. The frame is not\n * and does not need to be added via `Plotly.addFrames`. It may contain any of\n * the properties of a frame, including `data`, `layout`, and `traces`. The\n * frame is used as provided and does not use the `baseframe` property.\n *\n * - array of objects, e.g. [{data: ...}, {data: ...}]: a list of frame objects,\n * each following the same rules as a single `object`.\n *\n * @param {object} animationOpts\n * configuration for the animation\n */\nfunction animate(gd, frameOrGroupNameOrFrameList, animationOpts) {\n gd = Lib.getGraphDiv(gd);\n\n if(!Lib.isPlotDiv(gd)) {\n throw new Error(\n 'This element is not a Plotly plot: ' + gd + '. It\\'s likely that you\\'ve failed ' +\n 'to create a plot before animating it. For more details, see ' +\n 'https://plotly.com/javascript/animations/'\n );\n }\n\n var trans = gd._transitionData;\n\n // This is the queue of frames that will be animated as soon as possible. They\n // are popped immediately upon the *start* of a transition:\n if(!trans._frameQueue) {\n trans._frameQueue = [];\n }\n\n animationOpts = Plots.supplyAnimationDefaults(animationOpts);\n var transitionOpts = animationOpts.transition;\n var frameOpts = animationOpts.frame;\n\n // Since frames are popped immediately, an empty queue only means all frames have\n // *started* to transition, not that the animation is complete. To solve that,\n // track a separate counter that increments at the same time as frames are added\n // to the queue, but decrements only when the transition is complete.\n if(trans._frameWaitingCnt === undefined) {\n trans._frameWaitingCnt = 0;\n }\n\n function getTransitionOpts(i) {\n if(Array.isArray(transitionOpts)) {\n if(i >= transitionOpts.length) {\n return transitionOpts[0];\n } else {\n return transitionOpts[i];\n }\n } else {\n return transitionOpts;\n }\n }\n\n function getFrameOpts(i) {\n if(Array.isArray(frameOpts)) {\n if(i >= frameOpts.length) {\n return frameOpts[0];\n } else {\n return frameOpts[i];\n }\n } else {\n return frameOpts;\n }\n }\n\n // Execute a callback after the wrapper function has been called n times.\n // This is used to defer the resolution until a transition has resolved *and*\n // the frame has completed. If it's not done this way, then we get a race\n // condition in which the animation might resolve before a transition is complete\n // or vice versa.\n function callbackOnNthTime(cb, n) {\n var cnt = 0;\n return function() {\n if(cb && ++cnt === n) {\n return cb();\n }\n };\n }\n\n return new Promise(function(resolve, reject) {\n function discardExistingFrames() {\n if(trans._frameQueue.length === 0) {\n return;\n }\n\n while(trans._frameQueue.length) {\n var next = trans._frameQueue.pop();\n if(next.onInterrupt) {\n next.onInterrupt();\n }\n }\n\n gd.emit('plotly_animationinterrupted', []);\n }\n\n function queueFrames(frameList) {\n if(frameList.length === 0) return;\n\n for(var i = 0; i < frameList.length; i++) {\n var computedFrame;\n\n if(frameList[i].type === 'byname') {\n // If it's a named frame, compute it:\n computedFrame = Plots.computeFrame(gd, frameList[i].name);\n } else {\n // Otherwise we must have been given a simple object, so treat\n // the input itself as the computed frame.\n computedFrame = frameList[i].data;\n }\n\n var frameOpts = getFrameOpts(i);\n var transitionOpts = getTransitionOpts(i);\n\n // It doesn't make much sense for the transition duration to be greater than\n // the frame duration, so limit it:\n transitionOpts.duration = Math.min(transitionOpts.duration, frameOpts.duration);\n\n var nextFrame = {\n frame: computedFrame,\n name: frameList[i].name,\n frameOpts: frameOpts,\n transitionOpts: transitionOpts,\n };\n if(i === frameList.length - 1) {\n // The last frame in this .animate call stores the promise resolve\n // and reject callbacks. This is how we ensure that the animation\n // loop (which may exist as a result of a *different* .animate call)\n // still resolves or rejecdts this .animate call's promise. once it's\n // complete.\n nextFrame.onComplete = callbackOnNthTime(resolve, 2);\n nextFrame.onInterrupt = reject;\n }\n\n trans._frameQueue.push(nextFrame);\n }\n\n // Set it as never having transitioned to a frame. This will cause the animation\n // loop to immediately transition to the next frame (which, for immediate mode,\n // is the first frame in the list since all others would have been discarded\n // below)\n if(animationOpts.mode === 'immediate') {\n trans._lastFrameAt = -Infinity;\n }\n\n // Only it's not already running, start a RAF loop. This could be avoided in the\n // case that there's only one frame, but it significantly complicated the logic\n // and only sped things up by about 5% or so for a lorenz attractor simulation.\n // It would be a fine thing to implement, but the benefit of that optimization\n // doesn't seem worth the extra complexity.\n if(!trans._animationRaf) {\n beginAnimationLoop();\n }\n }\n\n function stopAnimationLoop() {\n gd.emit('plotly_animated');\n\n // Be sure to unset also since it's how we know whether a loop is already running:\n window.cancelAnimationFrame(trans._animationRaf);\n trans._animationRaf = null;\n }\n\n function nextFrame() {\n if(trans._currentFrame && trans._currentFrame.onComplete) {\n // Execute the callback and unset it to ensure it doesn't\n // accidentally get called twice\n trans._currentFrame.onComplete();\n }\n\n var newFrame = trans._currentFrame = trans._frameQueue.shift();\n\n if(newFrame) {\n // Since it's sometimes necessary to do deep digging into frame data,\n // we'll consider it not 100% impossible for nulls or numbers to sneak through,\n // so check when casting the name, just to be absolutely certain:\n var stringName = newFrame.name ? newFrame.name.toString() : null;\n gd._fullLayout._currentFrame = stringName;\n\n trans._lastFrameAt = Date.now();\n trans._timeToNext = newFrame.frameOpts.duration;\n\n // This is simply called and it's left to .transition to decide how to manage\n // interrupting current transitions. That means we don't need to worry about\n // how it resolves or what happens after this:\n Plots.transition(gd,\n newFrame.frame.data,\n newFrame.frame.layout,\n helpers.coerceTraceIndices(gd, newFrame.frame.traces),\n newFrame.frameOpts,\n newFrame.transitionOpts\n ).then(function() {\n if(newFrame.onComplete) {\n newFrame.onComplete();\n }\n });\n\n gd.emit('plotly_animatingframe', {\n name: stringName,\n frame: newFrame.frame,\n animation: {\n frame: newFrame.frameOpts,\n transition: newFrame.transitionOpts,\n }\n });\n } else {\n // If there are no more frames, then stop the RAF loop:\n stopAnimationLoop();\n }\n }\n\n function beginAnimationLoop() {\n gd.emit('plotly_animating');\n\n // If no timer is running, then set last frame = long ago so that the next\n // frame is immediately transitioned:\n trans._lastFrameAt = -Infinity;\n trans._timeToNext = 0;\n trans._runningTransitions = 0;\n trans._currentFrame = null;\n\n var doFrame = function() {\n // This *must* be requested before nextFrame since nextFrame may decide\n // to cancel it if there's nothing more to animated:\n trans._animationRaf = window.requestAnimationFrame(doFrame);\n\n // Check if we're ready for a new frame:\n if(Date.now() - trans._lastFrameAt > trans._timeToNext) {\n nextFrame();\n }\n };\n\n doFrame();\n }\n\n // This is an animate-local counter that helps match up option input list\n // items with the particular frame.\n var configCounter = 0;\n function setTransitionConfig(frame) {\n if(Array.isArray(transitionOpts)) {\n if(configCounter >= transitionOpts.length) {\n frame.transitionOpts = transitionOpts[configCounter];\n } else {\n frame.transitionOpts = transitionOpts[0];\n }\n } else {\n frame.transitionOpts = transitionOpts;\n }\n configCounter++;\n return frame;\n }\n\n // Disambiguate what's sort of frames have been received\n var i, frame;\n var frameList = [];\n var allFrames = frameOrGroupNameOrFrameList === undefined || frameOrGroupNameOrFrameList === null;\n var isFrameArray = Array.isArray(frameOrGroupNameOrFrameList);\n var isSingleFrame = !allFrames && !isFrameArray && Lib.isPlainObject(frameOrGroupNameOrFrameList);\n\n if(isSingleFrame) {\n // In this case, a simple object has been passed to animate.\n frameList.push({\n type: 'object',\n data: setTransitionConfig(Lib.extendFlat({}, frameOrGroupNameOrFrameList))\n });\n } else if(allFrames || ['string', 'number'].indexOf(typeof frameOrGroupNameOrFrameList) !== -1) {\n // In this case, null or undefined has been passed so that we want to\n // animate *all* currently defined frames\n for(i = 0; i < trans._frames.length; i++) {\n frame = trans._frames[i];\n\n if(!frame) continue;\n\n if(allFrames || String(frame.group) === String(frameOrGroupNameOrFrameList)) {\n frameList.push({\n type: 'byname',\n name: String(frame.name),\n data: setTransitionConfig({name: frame.name})\n });\n }\n }\n } else if(isFrameArray) {\n for(i = 0; i < frameOrGroupNameOrFrameList.length; i++) {\n var frameOrName = frameOrGroupNameOrFrameList[i];\n if(['number', 'string'].indexOf(typeof frameOrName) !== -1) {\n frameOrName = String(frameOrName);\n // In this case, there's an array and this frame is a string name:\n frameList.push({\n type: 'byname',\n name: frameOrName,\n data: setTransitionConfig({name: frameOrName})\n });\n } else if(Lib.isPlainObject(frameOrName)) {\n frameList.push({\n type: 'object',\n data: setTransitionConfig(Lib.extendFlat({}, frameOrName))\n });\n }\n }\n }\n\n // Verify that all of these frames actually exist; return and reject if not:\n for(i = 0; i < frameList.length; i++) {\n frame = frameList[i];\n if(frame.type === 'byname' && !trans._frameHash[frame.data.name]) {\n Lib.warn('animate failure: frame not found: \"' + frame.data.name + '\"');\n reject();\n return;\n }\n }\n\n // If the mode is either next or immediate, then all currently queued frames must\n // be dumped and the corresponding .animate promises rejected.\n if(['next', 'immediate'].indexOf(animationOpts.mode) !== -1) {\n discardExistingFrames();\n }\n\n if(animationOpts.direction === 'reverse') {\n frameList.reverse();\n }\n\n var currentFrame = gd._fullLayout._currentFrame;\n if(currentFrame && animationOpts.fromcurrent) {\n var idx = -1;\n for(i = 0; i < frameList.length; i++) {\n frame = frameList[i];\n if(frame.type === 'byname' && frame.name === currentFrame) {\n idx = i;\n break;\n }\n }\n\n if(idx > 0 && idx < frameList.length - 1) {\n var filteredFrameList = [];\n for(i = 0; i < frameList.length; i++) {\n frame = frameList[i];\n if(frameList[i].type !== 'byname' || i > idx) {\n filteredFrameList.push(frame);\n }\n }\n frameList = filteredFrameList;\n }\n }\n\n if(frameList.length > 0) {\n queueFrames(frameList);\n } else {\n // This is the case where there were simply no frames. It's a little strange\n // since there's not much to do:\n gd.emit('plotly_animated');\n resolve();\n }\n });\n}\n\n/**\n * Register new frames\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n *\n * @param {array of objects} frameList\n * list of frame definitions, in which each object includes any of:\n * - name: {string} name of frame to add\n * - data: {array of objects} trace data\n * - layout {object} layout definition\n * - traces {array} trace indices\n * - baseframe {string} name of frame from which this frame gets defaults\n *\n * @param {array of integers} indices\n * an array of integer indices matching the respective frames in `frameList`. If not\n * provided, an index will be provided in serial order. If already used, the frame\n * will be overwritten.\n */\nfunction addFrames(gd, frameList, indices) {\n gd = Lib.getGraphDiv(gd);\n\n if(frameList === null || frameList === undefined) {\n return Promise.resolve();\n }\n\n if(!Lib.isPlotDiv(gd)) {\n throw new Error(\n 'This element is not a Plotly plot: ' + gd + '. It\\'s likely that you\\'ve failed ' +\n 'to create a plot before adding frames. For more details, see ' +\n 'https://plotly.com/javascript/animations/'\n );\n }\n\n var i, frame, j, idx;\n var _frames = gd._transitionData._frames;\n var _frameHash = gd._transitionData._frameHash;\n\n\n if(!Array.isArray(frameList)) {\n throw new Error('addFrames failure: frameList must be an Array of frame definitions' + frameList);\n }\n\n // Create a sorted list of insertions since we run into lots of problems if these\n // aren't in ascending order of index:\n //\n // Strictly for sorting. Make sure this is guaranteed to never collide with any\n // already-exisisting indices:\n var bigIndex = _frames.length + frameList.length * 2;\n\n var insertions = [];\n var _frameHashLocal = {};\n for(i = frameList.length - 1; i >= 0; i--) {\n if(!Lib.isPlainObject(frameList[i])) continue;\n\n // The entire logic for checking for this type of name collision can be removed once we migrate to ES6 and\n // use a Map instead of an Object instance, as Map keys aren't converted to strings.\n var lookupName = frameList[i].name;\n var name = (_frameHash[lookupName] || _frameHashLocal[lookupName] || {}).name;\n var newName = frameList[i].name;\n var collisionPresent = _frameHash[name] || _frameHashLocal[name];\n\n if(name && newName && typeof newName === 'number' && collisionPresent && numericNameWarningCount < numericNameWarningCountLimit) {\n numericNameWarningCount++;\n\n Lib.warn('addFrames: overwriting frame \"' + (_frameHash[name] || _frameHashLocal[name]).name +\n '\" with a frame whose name of type \"number\" also equates to \"' +\n name + '\". This is valid but may potentially lead to unexpected ' +\n 'behavior since all plotly.js frame names are stored internally ' +\n 'as strings.');\n\n if(numericNameWarningCount === numericNameWarningCountLimit) {\n Lib.warn('addFrames: This API call has yielded too many of these warnings. ' +\n 'For the rest of this call, further warnings about numeric frame ' +\n 'names will be suppressed.');\n }\n }\n\n _frameHashLocal[lookupName] = {name: lookupName};\n\n insertions.push({\n frame: Plots.supplyFrameDefaults(frameList[i]),\n index: (indices && indices[i] !== undefined && indices[i] !== null) ? indices[i] : bigIndex + i\n });\n }\n\n // Sort this, taking note that undefined insertions end up at the end:\n insertions.sort(function(a, b) {\n if(a.index > b.index) return -1;\n if(a.index < b.index) return 1;\n return 0;\n });\n\n var ops = [];\n var revops = [];\n var frameCount = _frames.length;\n\n for(i = insertions.length - 1; i >= 0; i--) {\n frame = insertions[i].frame;\n\n if(typeof frame.name === 'number') {\n Lib.warn('Warning: addFrames accepts frames with numeric names, but the numbers are' +\n 'implicitly cast to strings');\n }\n\n if(!frame.name) {\n // Repeatedly assign a default name, incrementing the counter each time until\n // we get a name that's not in the hashed lookup table:\n while(_frameHash[(frame.name = 'frame ' + gd._transitionData._counter++)]);\n }\n\n if(_frameHash[frame.name]) {\n // If frame is present, overwrite its definition:\n for(j = 0; j < _frames.length; j++) {\n if((_frames[j] || {}).name === frame.name) break;\n }\n ops.push({type: 'replace', index: j, value: frame});\n revops.unshift({type: 'replace', index: j, value: _frames[j]});\n } else {\n // Otherwise insert it at the end of the list:\n idx = Math.max(0, Math.min(insertions[i].index, frameCount));\n\n ops.push({type: 'insert', index: idx, value: frame});\n revops.unshift({type: 'delete', index: idx});\n frameCount++;\n }\n }\n\n var undoFunc = Plots.modifyFrames;\n var redoFunc = Plots.modifyFrames;\n var undoArgs = [gd, revops];\n var redoArgs = [gd, ops];\n\n if(Queue) Queue.add(gd, undoFunc, undoArgs, redoFunc, redoArgs);\n\n return Plots.modifyFrames(gd, ops);\n}\n\n/**\n * Delete frame\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n *\n * @param {array of integers} frameList\n * list of integer indices of frames to be deleted\n */\nfunction deleteFrames(gd, frameList) {\n gd = Lib.getGraphDiv(gd);\n\n if(!Lib.isPlotDiv(gd)) {\n throw new Error('This element is not a Plotly plot: ' + gd);\n }\n\n var i, idx;\n var _frames = gd._transitionData._frames;\n var ops = [];\n var revops = [];\n\n if(!frameList) {\n frameList = [];\n for(i = 0; i < _frames.length; i++) {\n frameList.push(i);\n }\n }\n\n frameList = frameList.slice();\n frameList.sort();\n\n for(i = frameList.length - 1; i >= 0; i--) {\n idx = frameList[i];\n ops.push({type: 'delete', index: idx});\n revops.unshift({type: 'insert', index: idx, value: _frames[idx]});\n }\n\n var undoFunc = Plots.modifyFrames;\n var redoFunc = Plots.modifyFrames;\n var undoArgs = [gd, revops];\n var redoArgs = [gd, ops];\n\n if(Queue) Queue.add(gd, undoFunc, undoArgs, redoFunc, redoArgs);\n\n return Plots.modifyFrames(gd, ops);\n}\n\n/**\n * Purge a graph container div back to its initial pre-_doPlot state\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n */\nfunction purge(gd) {\n gd = Lib.getGraphDiv(gd);\n\n var fullLayout = gd._fullLayout || {};\n var fullData = gd._fullData || [];\n\n // remove gl contexts\n Plots.cleanPlot([], {}, fullData, fullLayout);\n\n // purge properties\n Plots.purge(gd);\n\n // purge event emitter methods\n Events.purge(gd);\n\n // remove plot container\n if(fullLayout._container) fullLayout._container.remove();\n\n // in contrast to _doPlots.purge which does NOT clear _context!\n delete gd._context;\n\n return gd;\n}\n\n// determines if the graph div requires a recalculation of its inverse matrix transforms by comparing old + new bounding boxes.\nfunction calcInverseTransform(gd) {\n var fullLayout = gd._fullLayout;\n\n var newBBox = gd.getBoundingClientRect();\n if(Lib.equalDomRects(newBBox, fullLayout._lastBBox)) return;\n\n var m = fullLayout._invTransform = Lib.inverseTransformMatrix(Lib.getFullTransformMatrix(gd));\n fullLayout._invScaleX = Math.sqrt(m[0][0] * m[0][0] + m[0][1] * m[0][1] + m[0][2] * m[0][2]);\n fullLayout._invScaleY = Math.sqrt(m[1][0] * m[1][0] + m[1][1] * m[1][1] + m[1][2] * m[1][2]);\n fullLayout._lastBBox = newBBox;\n}\n\n// -------------------------------------------------------\n// makePlotFramework: Create the plot container and axes\n// -------------------------------------------------------\nfunction makePlotFramework(gd) {\n var gd3 = d3.select(gd);\n var fullLayout = gd._fullLayout;\n\n fullLayout._calcInverseTransform = calcInverseTransform;\n fullLayout._calcInverseTransform(gd);\n\n // Plot container\n fullLayout._container = gd3.selectAll('.plot-container').data([0]);\n fullLayout._container.enter()\n .insert('div', ':first-child')\n .classed('plot-container', true)\n .classed('plotly', true);\n\n // Make the svg container\n fullLayout._paperdiv = fullLayout._container.selectAll('.svg-container').data([0]);\n fullLayout._paperdiv.enter().append('div')\n .classed('user-select-none', true)\n .classed('svg-container', true)\n .style('position', 'relative');\n\n // Make the graph containers\n // start fresh each time we get here, so we know the order comes out\n // right, rather than enter/exit which can muck up the order\n // TODO: sort out all the ordering so we don't have to\n // explicitly delete anything\n // FIXME: parcoords reuses this object, not the best pattern\n fullLayout._glcontainer = fullLayout._paperdiv.selectAll('.gl-container')\n .data([{}]);\n\n fullLayout._glcontainer.enter().append('div')\n .classed('gl-container', true);\n\n fullLayout._paperdiv.selectAll('.main-svg').remove();\n fullLayout._paperdiv.select('.modebar-container').remove();\n\n fullLayout._paper = fullLayout._paperdiv.insert('svg', ':first-child')\n .classed('main-svg', true);\n\n fullLayout._toppaper = fullLayout._paperdiv.append('svg')\n .classed('main-svg', true);\n\n fullLayout._modebardiv = fullLayout._paperdiv.append('div');\n delete fullLayout._modeBar;\n\n fullLayout._hoverpaper = fullLayout._paperdiv.append('svg')\n .classed('main-svg', true);\n\n if(!fullLayout._uid) {\n var otherUids = {};\n d3.selectAll('defs').each(function() {\n if(this.id) otherUids[this.id.split('-')[1]] = 1;\n });\n fullLayout._uid = Lib.randstr(otherUids);\n }\n\n fullLayout._paperdiv.selectAll('.main-svg')\n .attr(xmlnsNamespaces.svgAttrs);\n\n fullLayout._defs = fullLayout._paper.append('defs')\n .attr('id', 'defs-' + fullLayout._uid);\n\n fullLayout._clips = fullLayout._defs.append('g')\n .classed('clips', true);\n\n fullLayout._topdefs = fullLayout._toppaper.append('defs')\n .attr('id', 'topdefs-' + fullLayout._uid);\n\n fullLayout._topclips = fullLayout._topdefs.append('g')\n .classed('clips', true);\n\n fullLayout._bgLayer = fullLayout._paper.append('g')\n .classed('bglayer', true);\n\n fullLayout._draggers = fullLayout._paper.append('g')\n .classed('draglayer', true);\n\n // lower shape/image layer - note that this is behind\n // all subplots data/grids but above the backgrounds\n // except inset subplots, whose backgrounds are drawn\n // inside their own group so that they appear above\n // the data for the main subplot\n // lower shapes and images which are fully referenced to\n // a subplot still get drawn within the subplot's group\n // so they will work correctly on insets\n var layerBelow = fullLayout._paper.append('g')\n .classed('layer-below', true);\n fullLayout._imageLowerLayer = layerBelow.append('g')\n .classed('imagelayer', true);\n fullLayout._shapeLowerLayer = layerBelow.append('g')\n .classed('shapelayer', true);\n\n // single cartesian layer for the whole plot\n fullLayout._cartesianlayer = fullLayout._paper.append('g').classed('cartesianlayer', true);\n\n // single polar layer for the whole plot\n fullLayout._polarlayer = fullLayout._paper.append('g').classed('polarlayer', true);\n\n // single smith layer for the whole plot\n fullLayout._smithlayer = fullLayout._paper.append('g').classed('smithlayer', true);\n\n // single ternary layer for the whole plot\n fullLayout._ternarylayer = fullLayout._paper.append('g').classed('ternarylayer', true);\n\n // single geo layer for the whole plot\n fullLayout._geolayer = fullLayout._paper.append('g').classed('geolayer', true);\n\n // single funnelarea layer for the whole plot\n fullLayout._funnelarealayer = fullLayout._paper.append('g').classed('funnelarealayer', true);\n\n // single pie layer for the whole plot\n fullLayout._pielayer = fullLayout._paper.append('g').classed('pielayer', true);\n\n // single treemap layer for the whole plot\n fullLayout._iciclelayer = fullLayout._paper.append('g').classed('iciclelayer', true);\n\n // single treemap layer for the whole plot\n fullLayout._treemaplayer = fullLayout._paper.append('g').classed('treemaplayer', true);\n\n // single sunburst layer for the whole plot\n fullLayout._sunburstlayer = fullLayout._paper.append('g').classed('sunburstlayer', true);\n\n // single indicator layer for the whole plot\n fullLayout._indicatorlayer = fullLayout._toppaper.append('g').classed('indicatorlayer', true);\n\n // fill in image server scrape-svg\n fullLayout._glimages = fullLayout._paper.append('g').classed('glimages', true);\n\n // lastly upper shapes, info (legend, annotations) and hover layers go on top\n // these are in a different svg element normally, but get collapsed into a single\n // svg when exporting (after inserting 3D)\n // upper shapes/images are only those drawn above the whole plot, including subplots\n var layerAbove = fullLayout._toppaper.append('g')\n .classed('layer-above', true);\n fullLayout._imageUpperLayer = layerAbove.append('g')\n .classed('imagelayer', true);\n fullLayout._shapeUpperLayer = layerAbove.append('g')\n .classed('shapelayer', true);\n\n fullLayout._selectionLayer = fullLayout._toppaper.append('g').classed('selectionlayer', true);\n fullLayout._infolayer = fullLayout._toppaper.append('g').classed('infolayer', true);\n fullLayout._menulayer = fullLayout._toppaper.append('g').classed('menulayer', true);\n fullLayout._zoomlayer = fullLayout._toppaper.append('g').classed('zoomlayer', true);\n fullLayout._hoverlayer = fullLayout._hoverpaper.append('g').classed('hoverlayer', true);\n\n // Make the modebar container\n fullLayout._modebardiv\n .classed('modebar-container', true)\n .style('position', 'absolute')\n .style('top', '0px')\n .style('right', '0px');\n\n gd.emit('plotly_framework');\n}\n\nexports.animate = animate;\nexports.addFrames = addFrames;\nexports.deleteFrames = deleteFrames;\n\nexports.addTraces = addTraces;\nexports.deleteTraces = deleteTraces;\nexports.extendTraces = extendTraces;\nexports.moveTraces = moveTraces;\nexports.prependTraces = prependTraces;\n\nexports.newPlot = newPlot;\nexports._doPlot = _doPlot;\nexports.purge = purge;\n\nexports.react = react;\nexports.redraw = redraw;\nexports.relayout = relayout;\nexports.restyle = restyle;\n\nexports.setPlotConfig = setPlotConfig;\n\nexports.update = update;\n\nexports._guiRelayout = guiEdit(relayout);\nexports._guiRestyle = guiEdit(restyle);\nexports._guiUpdate = guiEdit(update);\n\nexports._storeDirectGUIEdit = _storeDirectGUIEdit;\n","'use strict';\n\n/**\n * This will be transferred over to gd and overridden by\n * config args to Plotly.newPlot.\n *\n * The defaults are the appropriate settings for plotly.js,\n * so we get the right experience without any config argument.\n *\n * N.B. the config options are not coerced using Lib.coerce so keys\n * like `valType` and `values` are only set for documentation purposes\n * at the moment.\n */\n\nvar configAttributes = {\n staticPlot: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether the graphs are interactive or not.',\n 'If *false*, no interactivity, for export or image generation.'\n ].join(' ')\n },\n\n typesetMath: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Determines whether math should be typeset or not,',\n 'when MathJax (either v2 or v3) is present on the page.'\n ].join(' ')\n },\n\n plotlyServerURL: {\n valType: 'string',\n dflt: '',\n description: [\n 'When set it determines base URL for',\n 'the \\'Edit in Chart Studio\\' `showEditInChartStudio`/`showSendToCloud` mode bar button',\n 'and the showLink/sendData on-graph link.',\n 'To enable sending your data to Chart Studio Cloud, you need to',\n 'set both `plotlyServerURL` to \\'https://chart-studio.plotly.com\\' and',\n 'also set `showSendToCloud` to true.'\n ].join(' ')\n },\n\n editable: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether the graph is editable or not.',\n 'Sets all pieces of `edits`',\n 'unless a separate `edits` config item overrides individual parts.'\n ].join(' ')\n },\n edits: {\n annotationPosition: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines if the main anchor of the annotation is editable.',\n 'The main anchor corresponds to the',\n 'text (if no arrow) or the arrow (which drags the whole thing leaving',\n 'the arrow length & direction unchanged).'\n ].join(' ')\n },\n annotationTail: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Has only an effect for annotations with arrows.',\n 'Enables changing the length and direction of the arrow.'\n ].join(' ')\n },\n annotationText: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables editing annotation text.'\n },\n axisTitleText: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables editing axis title text.'\n },\n colorbarPosition: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables moving colorbars.'\n },\n colorbarTitleText: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables editing colorbar title text.'\n },\n legendPosition: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables moving the legend.'\n },\n legendText: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables editing the trace name fields from the legend'\n },\n shapePosition: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables moving shapes.'\n },\n titleText: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables editing the global layout title.'\n }\n },\n\n editSelection: {\n valType: 'boolean',\n dflt: true,\n description: 'Enables moving selections.'\n },\n\n autosizable: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether the graphs are plotted with respect to',\n 'layout.autosize:true and infer its container size.'\n ].join(' ')\n },\n responsive: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether to change the layout size when window is resized.',\n 'In v3, this option will be removed and will always be true.'\n ].join(' ')\n },\n fillFrame: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'When `layout.autosize` is turned on, determines whether the graph',\n 'fills the container (the default) or the screen (if set to *true*).'\n ].join(' ')\n },\n frameMargins: {\n valType: 'number',\n dflt: 0,\n min: 0,\n max: 0.5,\n description: [\n 'When `layout.autosize` is turned on, set the frame margins',\n 'in fraction of the graph size.'\n ].join(' ')\n },\n\n scrollZoom: {\n valType: 'flaglist',\n flags: ['cartesian', 'gl3d', 'geo', 'mapbox', 'map'],\n extras: [true, false],\n dflt: 'gl3d+geo+map',\n description: [\n 'Determines whether mouse wheel or two-finger scroll zooms is enable.',\n 'Turned on by default for gl3d, geo, mapbox and map subplots',\n '(as these subplot types do not have zoombox via pan),',\n 'but turned off by default for cartesian subplots.',\n 'Set `scrollZoom` to *false* to disable scrolling for all subplots.'\n ].join(' ')\n },\n doubleClick: {\n valType: 'enumerated',\n values: [false, 'reset', 'autosize', 'reset+autosize'],\n dflt: 'reset+autosize',\n description: [\n 'Sets the double click interaction mode.',\n 'Has an effect only in cartesian plots.',\n 'If *false*, double click is disable.',\n 'If *reset*, double click resets the axis ranges to their initial values.',\n 'If *autosize*, double click set the axis ranges to their autorange values.',\n 'If *reset+autosize*, the odd double clicks resets the axis ranges',\n 'to their initial values and even double clicks set the axis ranges',\n 'to their autorange values.'\n ].join(' ')\n },\n doubleClickDelay: {\n valType: 'number',\n dflt: 300,\n min: 0,\n description: [\n 'Sets the delay for registering a double-click in ms.',\n 'This is the time interval (in ms) between first mousedown and',\n '2nd mouseup to constitute a double-click.',\n 'This setting propagates to all on-subplot double clicks',\n '(except for geo, mapbox and map) and on-legend double clicks.'\n ].join(' ')\n },\n\n showAxisDragHandles: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Set to *false* to omit cartesian axis pan/zoom drag handles.'\n ].join(' ')\n },\n showAxisRangeEntryBoxes: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Set to *false* to omit direct range entry at the pan/zoom drag points,',\n 'note that `showAxisDragHandles` must be enabled to have an effect.'\n ].join(' ')\n },\n\n showTips: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Determines whether or not tips are shown while interacting',\n 'with the resulting graphs.'\n ].join(' ')\n },\n\n showLink: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether a link to Chart Studio Cloud is displayed',\n 'at the bottom right corner of resulting graphs.',\n 'Use with `sendData` and `linkText`.'\n ].join(' ')\n },\n linkText: {\n valType: 'string',\n dflt: 'Edit chart',\n noBlank: true,\n description: [\n 'Sets the text appearing in the `showLink` link.'\n ].join(' ')\n },\n sendData: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'If *showLink* is true, does it contain data',\n 'just link to a Chart Studio Cloud file?'\n ].join(' ')\n },\n showSources: {\n valType: 'any',\n dflt: false,\n description: [\n 'Adds a source-displaying function to show sources on',\n 'the resulting graphs.'\n ].join(' ')\n },\n\n displayModeBar: {\n valType: 'enumerated',\n values: ['hover', true, false],\n dflt: 'hover',\n description: [\n 'Determines the mode bar display mode.',\n 'If *true*, the mode bar is always visible.',\n 'If *false*, the mode bar is always hidden.',\n 'If *hover*, the mode bar is visible while the mouse cursor',\n 'is on the graph container.'\n ].join(' ')\n },\n showSendToCloud: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Should we include a ModeBar button, labeled \"Edit in Chart Studio\",',\n 'that sends this chart to chart-studio.plotly.com (formerly plot.ly) or another plotly server',\n 'as specified by `plotlyServerURL` for editing, export, etc? Prior to version 1.43.0',\n 'this button was included by default, now it is opt-in using this flag.',\n 'Note that this button can (depending on `plotlyServerURL` being set) send your data',\n 'to an external server. However that server does not persist your data',\n 'until you arrive at the Chart Studio and explicitly click \"Save\".'\n ].join(' ')\n },\n showEditInChartStudio: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Same as `showSendToCloud`, but use a pencil icon instead of a floppy-disk.',\n 'Note that if both `showSendToCloud` and `showEditInChartStudio` are turned,',\n 'only `showEditInChartStudio` will be honored.'\n ].join(' ')\n },\n modeBarButtonsToRemove: {\n valType: 'any',\n dflt: [],\n description: [\n 'Remove mode bar buttons by name.',\n 'See ./components/modebar/buttons.js for the list of names.'\n ].join(' ')\n },\n modeBarButtonsToAdd: {\n valType: 'any',\n dflt: [],\n description: [\n 'Add mode bar button using config objects',\n 'See ./components/modebar/buttons.js for list of arguments.',\n 'To enable predefined modebar buttons e.g. shape drawing, hover and spikelines,',\n 'simply provide their string name(s). This could include:',\n '*v1hovermode*, *hoverclosest*, *hovercompare*, *togglehover*, *togglespikelines*,',\n '*drawline*, *drawopenpath*, *drawclosedpath*, *drawcircle*, *drawrect* and *eraseshape*.',\n 'Please note that these predefined buttons will only be shown if they are compatible',\n 'with all trace types used in a graph.'\n ].join(' ')\n },\n modeBarButtons: {\n valType: 'any',\n dflt: false,\n description: [\n 'Define fully custom mode bar buttons as nested array,',\n 'where the outer arrays represents button groups, and',\n 'the inner arrays have buttons config objects or names of default buttons',\n 'See ./components/modebar/buttons.js for more info.'\n ].join(' ')\n },\n toImageButtonOptions: {\n valType: 'any',\n dflt: {},\n description: [\n 'Statically override options for toImage modebar button',\n 'allowed keys are format, filename, width, height, scale',\n 'see ../components/modebar/buttons.js'\n ].join(' ')\n },\n displaylogo: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Determines whether or not the plotly logo is displayed',\n 'on the end of the mode bar.'\n ].join(' ')\n },\n watermark: {\n valType: 'boolean',\n dflt: false,\n description: 'watermark the images with the company\\'s logo'\n },\n\n plotGlPixelRatio: {\n valType: 'number',\n dflt: 2,\n min: 1,\n max: 4,\n description: [\n 'Set the pixel ratio during WebGL image export.',\n 'This config option was formerly named `plot3dPixelRatio`',\n 'which is now deprecated.'\n ].join(' ')\n },\n\n setBackground: {\n valType: 'any',\n dflt: 'transparent',\n description: [\n 'Set function to add the background color (i.e. `layout.paper_color`)',\n 'to a different container.',\n 'This function take the graph div as first argument and the current background',\n 'color as second argument.',\n 'Alternatively, set to string *opaque* to ensure there is white behind it.'\n ].join(' ')\n },\n\n topojsonURL: {\n valType: 'string',\n noBlank: true,\n dflt: 'https://cdn.plot.ly/',\n description: [\n 'Set the URL to topojson used in geo charts.',\n 'By default, the topojson files are fetched from cdn.plot.ly.',\n 'For example, set this option to:',\n '/dist/topojson/',\n 'to render geographical feature using the topojson files',\n 'that ship with the plotly.js module.'\n ].join(' ')\n },\n\n mapboxAccessToken: {\n valType: 'string',\n dflt: null,\n description: [\n 'Mapbox access token (required to plot mapbox trace types)',\n 'If using an Mapbox Atlas server, set this option to \\'\\'',\n 'so that plotly.js won\\'t attempt to authenticate to the public Mapbox server.'\n ].join(' ')\n },\n\n logging: {\n valType: 'integer',\n min: 0,\n max: 2,\n dflt: 1,\n description: [\n 'Turn all console logging on or off (errors will be thrown)',\n 'This should ONLY be set via Plotly.setPlotConfig',\n 'Available levels:',\n '0: no logs',\n '1: warnings and errors, but not informational messages',\n '2: verbose logs'\n ].join(' ')\n },\n\n notifyOnLogging: {\n valType: 'integer',\n min: 0,\n max: 2,\n dflt: 0,\n description: [\n 'Set on-graph logging (notifier) level',\n 'This should ONLY be set via Plotly.setPlotConfig',\n 'Available levels:',\n '0: no on-graph logs',\n '1: warnings and errors, but not informational messages',\n '2: verbose logs'\n ].join(' ')\n },\n\n queueLength: {\n valType: 'integer',\n min: 0,\n dflt: 0,\n description: 'Sets the length of the undo/redo queue.'\n },\n\n globalTransforms: {\n valType: 'any',\n dflt: [],\n description: [\n 'Set global transform to be applied to all traces with no',\n 'specification needed'\n ].join(' ')\n },\n\n locale: {\n valType: 'string',\n dflt: 'en-US',\n description: [\n 'Which localization should we use?',\n 'Should be a string like \\'en\\' or \\'en-US\\'.'\n ].join(' ')\n },\n\n locales: {\n valType: 'any',\n dflt: {},\n description: [\n 'Localization definitions',\n 'Locales can be provided either here (specific to one chart) or globally',\n 'by registering them as modules.',\n 'Should be an object of objects {locale: {dictionary: {...}, format: {...}}}',\n '{',\n ' da: {',\n ' dictionary: {\\'Reset axes\\': \\'Nulstil aksler\\', ...},',\n ' format: {months: [...], shortMonths: [...]}',\n ' },',\n ' ...',\n '}',\n 'All parts are optional. When looking for translation or format fields, we',\n 'look first for an exact match in a config locale, then in a registered',\n 'module. If those fail, we strip off any regionalization (\\'en-US\\' -> \\'en\\')',\n 'and try each (config, registry) again. The final fallback for translation',\n 'is untranslated (which is US English) and for formats is the base English',\n '(the only consequence being the last fallback date format %x is DD/MM/YYYY',\n 'instead of MM/DD/YYYY). Currently `grouping` and `currency` are ignored',\n 'for our automatic number formatting, but can be used in custom formats.'\n ].join(' ')\n }\n};\n\nvar dfltConfig = {};\n\nfunction crawl(src, target) {\n for(var k in src) {\n var obj = src[k];\n if(obj.valType) {\n target[k] = obj.dflt;\n } else {\n if(!target[k]) {\n target[k] = {};\n }\n crawl(obj, target[k]);\n }\n }\n}\n\ncrawl(configAttributes, dfltConfig);\n\nmodule.exports = {\n configAttributes: configAttributes,\n dfltConfig: dfltConfig\n};\n","'use strict';\n\nvar Registry = require('../registry');\nvar Lib = require('../lib');\n\nvar baseAttributes = require('../plots/attributes');\nvar baseLayoutAttributes = require('../plots/layout_attributes');\nvar frameAttributes = require('../plots/frame_attributes');\nvar animationAttributes = require('../plots/animation_attributes');\nvar configAttributes = require('./plot_config').configAttributes;\n\nvar editTypes = require('./edit_types');\n\nvar extendDeepAll = Lib.extendDeepAll;\nvar isPlainObject = Lib.isPlainObject;\nvar isArrayOrTypedArray = Lib.isArrayOrTypedArray;\nvar nestedProperty = Lib.nestedProperty;\nvar valObjectMeta = Lib.valObjectMeta;\n\nvar IS_SUBPLOT_OBJ = '_isSubplotObj';\nvar IS_LINKED_TO_ARRAY = '_isLinkedToArray';\nvar ARRAY_ATTR_REGEXPS = '_arrayAttrRegexps';\nvar DEPRECATED = '_deprecated';\nvar UNDERSCORE_ATTRS = [IS_SUBPLOT_OBJ, IS_LINKED_TO_ARRAY, ARRAY_ATTR_REGEXPS, DEPRECATED];\n\nexports.IS_SUBPLOT_OBJ = IS_SUBPLOT_OBJ;\nexports.IS_LINKED_TO_ARRAY = IS_LINKED_TO_ARRAY;\nexports.DEPRECATED = DEPRECATED;\nexports.UNDERSCORE_ATTRS = UNDERSCORE_ATTRS;\n\n/** Outputs the full plotly.js plot schema\n *\n * @return {object}\n * - defs\n * - traces\n * - layout\n * - transforms\n * - frames\n * - animations\n * - config\n */\nexports.get = function() {\n var traces = {};\n\n Registry.allTypes.forEach(function(type) {\n traces[type] = getTraceAttributes(type);\n });\n\n var transforms = {};\n\n Object.keys(Registry.transformsRegistry).forEach(function(type) {\n transforms[type] = getTransformAttributes(type);\n });\n\n return {\n defs: {\n valObjects: valObjectMeta,\n metaKeys: UNDERSCORE_ATTRS.concat(['description', 'role', 'editType', 'impliedEdits']),\n editType: {\n traces: editTypes.traces,\n layout: editTypes.layout\n },\n impliedEdits: {\n description: [\n 'Sometimes when an attribute is changed, other attributes',\n 'must be altered as well in order to achieve the intended',\n 'result. For example, when `range` is specified, it is',\n 'important to set `autorange` to `false` or the new `range`',\n 'value would be lost in the redraw. `impliedEdits` is the',\n 'mechanism to do this: `impliedEdits: {autorange: false}`.',\n 'Each key is a relative paths to the attribute string to',\n 'change, using *^* to ascend into the parent container,',\n 'for example `range[0]` has `impliedEdits: {*^autorange*: false}`.',\n 'A value of `undefined` means that the attribute will not be',\n 'changed, but its previous value should be recorded in case',\n 'we want to reverse this change later. For example, `autorange`',\n 'has `impliedEdits: {*range[0]*: undefined, *range[1]*:undefined}',\n 'because the range will likely be changed by redraw.'\n ].join(' ')\n }\n },\n\n traces: traces,\n layout: getLayoutAttributes(),\n\n transforms: transforms,\n\n frames: getFramesAttributes(),\n animation: formatAttributes(animationAttributes),\n\n config: formatAttributes(configAttributes)\n };\n};\n\n/**\n * Crawl the attribute tree, recursively calling a callback function\n *\n * @param {object} attrs\n * The node of the attribute tree (e.g. the root) from which recursion originates\n * @param {Function} callback\n * A callback function with the signature:\n * @callback callback\n * @param {object} attr an attribute\n * @param {String} attrName name string\n * @param {object[]} attrs all the attributes\n * @param {Number} level the recursion level, 0 at the root\n * @param {String} fullAttrString full attribute name (ie 'marker.line')\n * @param {Number} [specifiedLevel]\n * The level in the tree, in order to let the callback function detect descend or backtrack,\n * typically unsupplied (implied 0), just used by the self-recursive call.\n * The necessity arises because the tree traversal is not controlled by callback return values.\n * The decision to not use callback return values for controlling tree pruning arose from\n * the goal of keeping the crawler backwards compatible. Observe that one of the pruning conditions\n * precedes the callback call.\n * @param {string} [attrString]\n * the path to the current attribute, as an attribute string (ie 'marker.line')\n * typically unsupplied, but you may supply it if you want to disambiguate which attrs tree you\n * are starting from\n *\n * @return {object} transformOut\n * copy of transformIn that contains attribute defaults\n */\nexports.crawl = function(attrs, callback, specifiedLevel, attrString) {\n var level = specifiedLevel || 0;\n attrString = attrString || '';\n\n Object.keys(attrs).forEach(function(attrName) {\n var attr = attrs[attrName];\n\n if(UNDERSCORE_ATTRS.indexOf(attrName) !== -1) return;\n\n var fullAttrString = (attrString ? attrString + '.' : '') + attrName;\n callback(attr, attrName, attrs, level, fullAttrString);\n\n if(exports.isValObject(attr)) return;\n\n if(isPlainObject(attr) && attrName !== 'impliedEdits') {\n exports.crawl(attr, callback, level + 1, fullAttrString);\n }\n });\n};\n\n/** Is object a value object (or a container object)?\n *\n * @param {object} obj\n * @return {boolean}\n * returns true for a valid value object and\n * false for tree nodes in the attribute hierarchy\n */\nexports.isValObject = function(obj) {\n return obj && obj.valType !== undefined;\n};\n\n/**\n * Find all data array attributes in a given trace object - including\n * `arrayOk` attributes.\n *\n * @param {object} trace\n * full trace object that contains a reference to `_module.attributes`\n *\n * @return {array} arrayAttributes\n * list of array attributes for the given trace\n */\nexports.findArrayAttributes = function(trace) {\n var arrayAttributes = [];\n var stack = [];\n var isArrayStack = [];\n var baseContainer, baseAttrName;\n\n function callback(attr, attrName, attrs, level) {\n stack = stack.slice(0, level).concat([attrName]);\n isArrayStack = isArrayStack.slice(0, level).concat([attr && attr._isLinkedToArray]);\n\n var splittableAttr = (\n attr &&\n (attr.valType === 'data_array' || attr.arrayOk === true) &&\n !(stack[level - 1] === 'colorbar' && (attrName === 'ticktext' || attrName === 'tickvals'))\n );\n\n // Manually exclude 'colorbar.tickvals' and 'colorbar.ticktext' for now\n // which are declared as `valType: 'data_array'` but scale independently of\n // the coordinate arrays.\n //\n // Down the road, we might want to add a schema field (e.g `uncorrelatedArray: true`)\n // to distinguish attributes of the likes.\n\n if(!splittableAttr) return;\n\n crawlIntoTrace(baseContainer, 0, '');\n }\n\n function crawlIntoTrace(container, i, astrPartial) {\n var item = container[stack[i]];\n var newAstrPartial = astrPartial + stack[i];\n if(i === stack.length - 1) {\n if(isArrayOrTypedArray(item)) {\n arrayAttributes.push(baseAttrName + newAstrPartial);\n }\n } else {\n if(isArrayStack[i]) {\n if(Array.isArray(item)) {\n for(var j = 0; j < item.length; j++) {\n if(isPlainObject(item[j])) {\n crawlIntoTrace(item[j], i + 1, newAstrPartial + '[' + j + '].');\n }\n }\n }\n } else if(isPlainObject(item)) {\n crawlIntoTrace(item, i + 1, newAstrPartial + '.');\n }\n }\n }\n\n baseContainer = trace;\n baseAttrName = '';\n exports.crawl(baseAttributes, callback);\n if(trace._module && trace._module.attributes) {\n exports.crawl(trace._module.attributes, callback);\n }\n\n var transforms = trace.transforms;\n if(transforms) {\n for(var i = 0; i < transforms.length; i++) {\n var transform = transforms[i];\n var module = transform._module;\n\n if(module) {\n baseAttrName = 'transforms[' + i + '].';\n baseContainer = transform;\n\n exports.crawl(module.attributes, callback);\n }\n }\n }\n\n return arrayAttributes;\n};\n\n/*\n * Find the valObject for one attribute in an existing trace\n *\n * @param {object} trace\n * full trace object that contains a reference to `_module.attributes`\n * @param {object} parts\n * an array of parts, like ['transforms', 1, 'value']\n * typically from nestedProperty(...).parts\n *\n * @return {object|false}\n * the valObject for this attribute, or the last found parent\n * in some cases the innermost valObject will not exist, for example\n * `valType: 'any'` attributes where we might set a part of the attribute.\n * In that case, stop at the deepest valObject we *do* find.\n */\nexports.getTraceValObject = function(trace, parts) {\n var head = parts[0];\n var i = 1; // index to start recursing from\n var moduleAttrs, valObject;\n\n if(head === 'transforms') {\n if(parts.length === 1) {\n return baseAttributes.transforms;\n }\n var transforms = trace.transforms;\n if(!Array.isArray(transforms) || !transforms.length) return false;\n var tNum = parts[1];\n if(!isIndex(tNum) || tNum >= transforms.length) {\n return false;\n }\n moduleAttrs = (Registry.transformsRegistry[transforms[tNum].type] || {}).attributes;\n valObject = moduleAttrs && moduleAttrs[parts[2]];\n i = 3; // start recursing only inside the transform\n } else {\n // first look in the module for this trace\n // components have already merged their trace attributes in here\n var _module = trace._module;\n if(!_module) _module = (Registry.modules[trace.type || baseAttributes.type.dflt] || {})._module;\n if(!_module) return false;\n\n moduleAttrs = _module.attributes;\n valObject = moduleAttrs && moduleAttrs[head];\n\n // then look in the subplot attributes\n if(!valObject) {\n var subplotModule = _module.basePlotModule;\n if(subplotModule && subplotModule.attributes) {\n valObject = subplotModule.attributes[head];\n }\n }\n\n // finally look in the global attributes\n if(!valObject) valObject = baseAttributes[head];\n }\n\n return recurseIntoValObject(valObject, parts, i);\n};\n\n/*\n * Find the valObject for one layout attribute\n *\n * @param {array} parts\n * an array of parts, like ['annotations', 1, 'x']\n * typically from nestedProperty(...).parts\n *\n * @return {object|false}\n * the valObject for this attribute, or the last found parent\n * in some cases the innermost valObject will not exist, for example\n * `valType: 'any'` attributes where we might set a part of the attribute.\n * In that case, stop at the deepest valObject we *do* find.\n */\nexports.getLayoutValObject = function(fullLayout, parts) {\n var valObject = layoutHeadAttr(fullLayout, parts[0]);\n\n return recurseIntoValObject(valObject, parts, 1);\n};\n\nfunction layoutHeadAttr(fullLayout, head) {\n var i, key, _module, attributes;\n\n // look for attributes of the subplot types used on the plot\n var basePlotModules = fullLayout._basePlotModules;\n if(basePlotModules) {\n var out;\n for(i = 0; i < basePlotModules.length; i++) {\n _module = basePlotModules[i];\n if(_module.attrRegex && _module.attrRegex.test(head)) {\n // if a module defines overrides, these take precedence\n // initially this is to allow gl2d different editTypes from svg cartesian\n if(_module.layoutAttrOverrides) return _module.layoutAttrOverrides;\n\n // otherwise take the first attributes we find\n if(!out && _module.layoutAttributes) out = _module.layoutAttributes;\n }\n\n // a module can also override the behavior of base (and component) module layout attrs\n // again see gl2d for initial use case\n var baseOverrides = _module.baseLayoutAttrOverrides;\n if(baseOverrides && head in baseOverrides) return baseOverrides[head];\n }\n if(out) return out;\n }\n\n // look for layout attributes contributed by traces on the plot\n var modules = fullLayout._modules;\n if(modules) {\n for(i = 0; i < modules.length; i++) {\n attributes = modules[i].layoutAttributes;\n if(attributes && head in attributes) {\n return attributes[head];\n }\n }\n }\n\n /*\n * Next look in components.\n * Components that define a schema have already merged this into\n * base and subplot attribute defs, so ignore these.\n * Others (older style) all put all their attributes\n * inside a container matching the module `name`\n * eg `attributes` (array) or `legend` (object)\n */\n for(key in Registry.componentsRegistry) {\n _module = Registry.componentsRegistry[key];\n if(_module.name === 'colorscale' && head.indexOf('coloraxis') === 0) {\n return _module.layoutAttributes[head];\n } else if(!_module.schema && (head === _module.name)) {\n return _module.layoutAttributes;\n }\n }\n\n if(head in baseLayoutAttributes) return baseLayoutAttributes[head];\n\n return false;\n}\n\nfunction recurseIntoValObject(valObject, parts, i) {\n if(!valObject) return false;\n\n if(valObject._isLinkedToArray) {\n // skip array index, abort if we try to dive into an array without an index\n if(isIndex(parts[i])) i++;\n else if(i < parts.length) return false;\n }\n\n // now recurse as far as we can. Occasionally we have an attribute\n // setting an internal part below what's in the schema; just return\n // the innermost schema item we find.\n for(; i < parts.length; i++) {\n var newValObject = valObject[parts[i]];\n if(isPlainObject(newValObject)) valObject = newValObject;\n else break;\n\n if(i === parts.length - 1) break;\n\n if(valObject._isLinkedToArray) {\n i++;\n if(!isIndex(parts[i])) return false;\n } else if(valObject.valType === 'info_array') {\n i++;\n var index = parts[i];\n if(!isIndex(index)) return false;\n\n var items = valObject.items;\n if(Array.isArray(items)) {\n if(index >= items.length) return false;\n if(valObject.dimensions === 2) {\n i++;\n if(parts.length === i) return valObject;\n var index2 = parts[i];\n if(!isIndex(index2)) return false;\n valObject = items[index][index2];\n } else valObject = items[index];\n } else {\n valObject = items;\n }\n }\n }\n\n return valObject;\n}\n\n// note: this is different from Lib.isIndex, this one doesn't accept numeric\n// strings, only actual numbers.\nfunction isIndex(val) {\n return val === Math.round(val) && val >= 0;\n}\n\nfunction getTraceAttributes(type) {\n var _module, basePlotModule;\n\n _module = Registry.modules[type]._module,\n basePlotModule = _module.basePlotModule;\n\n var attributes = {};\n\n // make 'type' the first attribute in the object\n attributes.type = null;\n\n var copyBaseAttributes = extendDeepAll({}, baseAttributes);\n var copyModuleAttributes = extendDeepAll({}, _module.attributes);\n\n // prune global-level trace attributes that are already defined in a trace\n exports.crawl(copyModuleAttributes, function(attr, attrName, attrs, level, fullAttrString) {\n nestedProperty(copyBaseAttributes, fullAttrString).set(undefined);\n // Prune undefined attributes\n if(attr === undefined) nestedProperty(copyModuleAttributes, fullAttrString).set(undefined);\n });\n\n // base attributes (same for all trace types)\n extendDeepAll(attributes, copyBaseAttributes);\n\n // prune-out base attributes based on trace module categories\n if(Registry.traceIs(type, 'noOpacity')) {\n delete attributes.opacity;\n }\n if(!Registry.traceIs(type, 'showLegend')) {\n delete attributes.showlegend;\n delete attributes.legendgroup;\n }\n if(Registry.traceIs(type, 'noHover')) {\n delete attributes.hoverinfo;\n delete attributes.hoverlabel;\n }\n if(!_module.selectPoints) {\n delete attributes.selectedpoints;\n }\n\n // module attributes\n extendDeepAll(attributes, copyModuleAttributes);\n\n // subplot attributes\n if(basePlotModule.attributes) {\n extendDeepAll(attributes, basePlotModule.attributes);\n }\n\n // 'type' gets overwritten by baseAttributes; reset it here\n attributes.type = type;\n\n var out = {\n meta: _module.meta || {},\n categories: _module.categories || {},\n animatable: Boolean(_module.animatable),\n type: type,\n attributes: formatAttributes(attributes),\n };\n\n // trace-specific layout attributes\n if(_module.layoutAttributes) {\n var layoutAttributes = {};\n\n extendDeepAll(layoutAttributes, _module.layoutAttributes);\n out.layoutAttributes = formatAttributes(layoutAttributes);\n }\n\n // drop anim:true in non-animatable modules\n if(!_module.animatable) {\n exports.crawl(out, function(attr) {\n if(exports.isValObject(attr) && 'anim' in attr) {\n delete attr.anim;\n }\n });\n }\n\n return out;\n}\n\nfunction getLayoutAttributes() {\n var layoutAttributes = {};\n var key, _module;\n\n // global layout attributes\n extendDeepAll(layoutAttributes, baseLayoutAttributes);\n\n // add base plot module layout attributes\n for(key in Registry.subplotsRegistry) {\n _module = Registry.subplotsRegistry[key];\n\n if(!_module.layoutAttributes) continue;\n\n if(Array.isArray(_module.attr)) {\n for(var i = 0; i < _module.attr.length; i++) {\n handleBasePlotModule(layoutAttributes, _module, _module.attr[i]);\n }\n } else {\n var astr = _module.attr === 'subplot' ? _module.name : _module.attr;\n handleBasePlotModule(layoutAttributes, _module, astr);\n }\n }\n\n // add registered components layout attributes\n for(key in Registry.componentsRegistry) {\n _module = Registry.componentsRegistry[key];\n var schema = _module.schema;\n\n if(schema && (schema.subplots || schema.layout)) {\n /*\n * Components with defined schema have already been merged in at register time\n * but a few components define attributes that apply only to xaxis\n * not yaxis (rangeselector, rangeslider) - delete from y schema.\n * Note that the input attributes for xaxis/yaxis are the same object\n * so it's not possible to only add them to xaxis from the start.\n * If we ever have such asymmetry the other way, or anywhere else,\n * we will need to extend both this code and mergeComponentAttrsToSubplot\n * (which will not find yaxis only for example)\n */\n var subplots = schema.subplots;\n if(subplots && subplots.xaxis && !subplots.yaxis) {\n for(var xkey in subplots.xaxis) {\n delete layoutAttributes.yaxis[xkey];\n }\n }\n\n /*\n * Also some attributes e.g. shift & autoshift only implemented on the yaxis\n * at the moment. Remove them from the xaxis.\n */\n delete layoutAttributes.xaxis.shift;\n delete layoutAttributes.xaxis.autoshift;\n } else if(_module.name === 'colorscale') {\n extendDeepAll(layoutAttributes, _module.layoutAttributes);\n } else if(_module.layoutAttributes) {\n // older style without schema need to be explicitly merged in now\n insertAttrs(layoutAttributes, _module.layoutAttributes, _module.name);\n }\n }\n\n return {\n layoutAttributes: formatAttributes(layoutAttributes)\n };\n}\n\nfunction getTransformAttributes(type) {\n var _module = Registry.transformsRegistry[type];\n var attributes = extendDeepAll({}, _module.attributes);\n\n // add registered components transform attributes\n Object.keys(Registry.componentsRegistry).forEach(function(k) {\n var _module = Registry.componentsRegistry[k];\n\n if(_module.schema && _module.schema.transforms && _module.schema.transforms[type]) {\n Object.keys(_module.schema.transforms[type]).forEach(function(v) {\n insertAttrs(attributes, _module.schema.transforms[type][v], v);\n });\n }\n });\n\n return {\n attributes: formatAttributes(attributes)\n };\n}\n\nfunction getFramesAttributes() {\n var attrs = {\n frames: extendDeepAll({}, frameAttributes)\n };\n\n formatAttributes(attrs);\n\n return attrs.frames;\n}\n\nfunction formatAttributes(attrs) {\n mergeValTypeAndRole(attrs);\n formatArrayContainers(attrs);\n stringify(attrs);\n\n return attrs;\n}\n\nfunction mergeValTypeAndRole(attrs) {\n function makeSrcAttr(attrName) {\n return {\n valType: 'string',\n description: 'Sets the source reference on Chart Studio Cloud for `' + attrName + '`.',\n editType: 'none'\n };\n }\n\n function callback(attr, attrName, attrs) {\n if(exports.isValObject(attr)) {\n if(attr.arrayOk === true || attr.valType === 'data_array') {\n // all 'arrayOk' and 'data_array' attrs have a corresponding 'src' attr\n attrs[attrName + 'src'] = makeSrcAttr(attrName);\n }\n } else if(isPlainObject(attr)) {\n // all attrs container objects get role 'object'\n attr.role = 'object';\n }\n }\n\n exports.crawl(attrs, callback);\n}\n\nfunction formatArrayContainers(attrs) {\n function callback(attr, attrName, attrs) {\n if(!attr) return;\n\n var itemName = attr[IS_LINKED_TO_ARRAY];\n\n if(!itemName) return;\n\n delete attr[IS_LINKED_TO_ARRAY];\n\n attrs[attrName] = { items: {} };\n attrs[attrName].items[itemName] = attr;\n attrs[attrName].role = 'object';\n }\n\n exports.crawl(attrs, callback);\n}\n\n// this can take around 10ms and should only be run from PlotSchema.get(),\n// to ensure JSON.stringify(PlotSchema.get()) gives the intended result.\nfunction stringify(attrs) {\n function walk(attr) {\n for(var k in attr) {\n if(isPlainObject(attr[k])) {\n walk(attr[k]);\n } else if(Array.isArray(attr[k])) {\n for(var i = 0; i < attr[k].length; i++) {\n walk(attr[k][i]);\n }\n } else {\n // as JSON.stringify(/test/) // => {}\n if(attr[k] instanceof RegExp) {\n attr[k] = attr[k].toString();\n }\n }\n }\n }\n\n walk(attrs);\n}\n\n\nfunction handleBasePlotModule(layoutAttributes, _module, astr) {\n var np = nestedProperty(layoutAttributes, astr);\n var attrs = extendDeepAll({}, _module.layoutAttributes);\n\n attrs[IS_SUBPLOT_OBJ] = true;\n np.set(attrs);\n}\n\nfunction insertAttrs(baseAttrs, newAttrs, astr) {\n var np = nestedProperty(baseAttrs, astr);\n\n np.set(extendDeepAll(np.get() || {}, newAttrs));\n}\n","'use strict';\n\nvar Lib = require('../lib');\nvar plotAttributes = require('../plots/attributes');\n\nvar TEMPLATEITEMNAME = 'templateitemname';\n\nvar templateAttrs = {\n name: {\n valType: 'string',\n editType: 'none',\n description: [\n 'When used in a template, named items are created in the output figure',\n 'in addition to any items the figure already has in this array.',\n 'You can modify these items in the output figure by making your own',\n 'item with `templateitemname` matching this `name`',\n 'alongside your modifications (including `visible: false` or',\n '`enabled: false` to hide it).',\n 'Has no effect outside of a template.'\n ].join(' ')\n }\n};\ntemplateAttrs[TEMPLATEITEMNAME] = {\n valType: 'string',\n editType: 'calc',\n description: [\n 'Used to refer to a named item in this array in the template. Named',\n 'items from the template will be created even without a matching item',\n 'in the input figure, but you can modify one by making an item with',\n '`templateitemname` matching its `name`, alongside your modifications',\n '(including `visible: false` or `enabled: false` to hide it).',\n 'If there is no template or no matching item, this item will be',\n 'hidden unless you explicitly show it with `visible: true`.'\n ].join(' ')\n};\n\n/**\n * templatedArray: decorate an attributes object with templating (and array)\n * properties.\n *\n * @param {string} name: the singular form of the array name. Sets\n * `_isLinkedToArray` to this, so the schema knows to treat this as an array.\n * @param {object} attrs: the item attributes. Since all callers are expected\n * to be constructing this object on the spot, we mutate it here for\n * performance, rather than extending a new object with it.\n *\n * @returns {object}: the decorated `attrs` object\n */\nexports.templatedArray = function(name, attrs) {\n attrs._isLinkedToArray = name;\n attrs.name = templateAttrs.name;\n attrs[TEMPLATEITEMNAME] = templateAttrs[TEMPLATEITEMNAME];\n return attrs;\n};\n\n/**\n * traceTemplater: logic for matching traces to trace templates\n *\n * @param {object} dataTemplate: collection of {traceType: [{template}, ...]}\n * ie each type the template applies to contains a list of template objects,\n * to be provided cyclically to data traces of that type.\n *\n * @returns {object}: {newTrace}, a function:\n * newTrace(traceIn): that takes the input traceIn, coerces its type, then\n * uses that type to find the next template to apply. returns the output\n * traceOut with template attached, ready to continue supplyDefaults.\n */\nexports.traceTemplater = function(dataTemplate) {\n var traceCounts = {};\n var traceType, typeTemplates;\n\n for(traceType in dataTemplate) {\n typeTemplates = dataTemplate[traceType];\n if(Array.isArray(typeTemplates) && typeTemplates.length) {\n traceCounts[traceType] = 0;\n }\n }\n\n function newTrace(traceIn) {\n traceType = Lib.coerce(traceIn, {}, plotAttributes, 'type');\n var traceOut = {type: traceType, _template: null};\n if(traceType in traceCounts) {\n typeTemplates = dataTemplate[traceType];\n // cycle through traces in the template set for this type\n var typei = traceCounts[traceType] % typeTemplates.length;\n traceCounts[traceType]++;\n traceOut._template = typeTemplates[typei];\n } else {\n // TODO: anything we should do for types missing from the template?\n // try to apply some other type? Or just bail as we do here?\n // Actually I think yes, we should apply other types; would be nice\n // if all scatter* could inherit from each other, and if histogram\n // could inherit from bar, etc... but how to specify this? And do we\n // compose them, or if a type is present require it to be complete?\n // Actually this could apply to layout too - 3D annotations\n // inheriting from 2D, axes of different types inheriting from each\n // other...\n }\n return traceOut;\n }\n\n return {\n newTrace: newTrace\n // TODO: function to figure out what's left & what didn't work\n };\n};\n\n/**\n * newContainer: Create a new sub-container inside `container` and propagate any\n * applicable template to it. If there's no template, still propagates\n * `undefined` so relinkPrivate will not retain an old template!\n *\n * @param {object} container: the outer container, should already have _template\n * if there *is* a template for this plot\n * @param {string} name: the key of the new container to make\n * @param {string} baseName: if applicable, a base attribute to take the\n * template from, ie for xaxis3 the base would be xaxis\n *\n * @returns {object}: an object for inclusion _full*, empty except for the\n * appropriate template piece\n */\nexports.newContainer = function(container, name, baseName) {\n var template = container._template;\n var part = template && (template[name] || (baseName && template[baseName]));\n if(!Lib.isPlainObject(part)) part = null;\n\n var out = container[name] = {_template: part};\n return out;\n};\n\n/**\n * arrayTemplater: special logic for templating both defaults and specific items\n * in a container array (annotations etc)\n *\n * @param {object} container: the outer container, should already have _template\n * if there *is* a template for this plot\n * @param {string} name: the name of the array to template (ie 'annotations')\n * will be used to find default ('annotationdefaults' object) and specific\n * ('annotations' array) template specs.\n * @param {string} inclusionAttr: the attribute determining this item's\n * inclusion in the output, usually 'visible' or 'enabled'\n *\n * @returns {object}: {newItem, defaultItems}, both functions:\n * newItem(itemIn): create an output item, bare except for the correct\n * template and name(s), as the base for supplyDefaults\n * defaultItems(): to be called after all newItem calls, return any\n * specific template items that have not already beeen included,\n * also as bare output items ready for supplyDefaults.\n */\nexports.arrayTemplater = function(container, name, inclusionAttr) {\n var template = container._template;\n var defaultsTemplate = template && template[arrayDefaultKey(name)];\n var templateItems = template && template[name];\n if(!Array.isArray(templateItems) || !templateItems.length) {\n templateItems = [];\n }\n\n var usedNames = {};\n\n function newItem(itemIn) {\n // include name and templateitemname in the output object for ALL\n // container array items. Note: you could potentially use different\n // name and templateitemname, if you're using one template to make\n // another template. templateitemname would be the name in the original\n // template, and name is the new \"subclassed\" item name.\n var out = {name: itemIn.name, _input: itemIn};\n var templateItemName = out[TEMPLATEITEMNAME] = itemIn[TEMPLATEITEMNAME];\n\n // no itemname: use the default template\n if(!validItemName(templateItemName)) {\n out._template = defaultsTemplate;\n return out;\n }\n\n // look for an item matching this itemname\n // note these do not inherit from the default template, only the item.\n for(var i = 0; i < templateItems.length; i++) {\n var templateItem = templateItems[i];\n if(templateItem.name === templateItemName) {\n // Note: it's OK to use a template item more than once\n // but using it at least once will stop it from generating\n // a default item at the end.\n usedNames[templateItemName] = 1;\n out._template = templateItem;\n return out;\n }\n }\n\n // Didn't find a matching template item, so since this item is intended\n // to only be modifications it's most likely broken. Hide it unless\n // it's explicitly marked visible - in which case it gets NO template,\n // not even the default.\n out[inclusionAttr] = itemIn[inclusionAttr] || false;\n // special falsy value we can look for in validateTemplate\n out._template = false;\n return out;\n }\n\n function defaultItems() {\n var out = [];\n for(var i = 0; i < templateItems.length; i++) {\n var templateItem = templateItems[i];\n var name = templateItem.name;\n // only allow named items to be added as defaults,\n // and only allow each name once\n if(validItemName(name) && !usedNames[name]) {\n var outi = {\n _template: templateItem,\n name: name,\n _input: {_templateitemname: name}\n };\n outi[TEMPLATEITEMNAME] = templateItem[TEMPLATEITEMNAME];\n out.push(outi);\n usedNames[name] = 1;\n }\n }\n return out;\n }\n\n return {\n newItem: newItem,\n defaultItems: defaultItems\n };\n};\n\nfunction validItemName(name) {\n return name && typeof name === 'string';\n}\n\nfunction arrayDefaultKey(name) {\n var lastChar = name.length - 1;\n if(name.charAt(lastChar) !== 's') {\n Lib.warn('bad argument to arrayDefaultKey: ' + name);\n }\n return name.substr(0, name.length - 1) + 'defaults';\n}\nexports.arrayDefaultKey = arrayDefaultKey;\n\n/**\n * arrayEditor: helper for editing array items that may have come from\n * template defaults (in which case they will not exist in the input yet)\n *\n * @param {object} parentIn: the input container (eg gd.layout)\n * @param {string} containerStr: the attribute string for the container inside\n * `parentIn`.\n * @param {object} itemOut: the _full* item (eg gd._fullLayout.annotations[0])\n * that we'll be editing. Assumed to have been created by `arrayTemplater`.\n *\n * @returns {object}: {modifyBase, modifyItem, getUpdateObj, applyUpdate}, all functions:\n * modifyBase(attr, value): Add an update that's *not* related to the item.\n * `attr` is the full attribute string.\n * modifyItem(attr, value): Add an update to the item. `attr` is just the\n * portion of the attribute string inside the item.\n * getUpdateObj(): Get the final constructed update object, to use in\n * `restyle` or `relayout`. Also resets the update object in case this\n * update was canceled.\n * applyUpdate(attr, value): optionally add an update `attr: value`,\n * then apply it to `parent` which should be the parent of `containerIn`,\n * ie the object to which `containerStr` is the attribute string.\n */\nexports.arrayEditor = function(parentIn, containerStr, itemOut) {\n var lengthIn = (Lib.nestedProperty(parentIn, containerStr).get() || []).length;\n var index = itemOut._index;\n // Check that we are indeed off the end of this container.\n // Otherwise a devious user could put a key `_templateitemname` in their\n // own input and break lots of things.\n var templateItemName = (index >= lengthIn) && (itemOut._input || {})._templateitemname;\n if(templateItemName) index = lengthIn;\n var itemStr = containerStr + '[' + index + ']';\n\n var update;\n function resetUpdate() {\n update = {};\n if(templateItemName) {\n update[itemStr] = {};\n update[itemStr][TEMPLATEITEMNAME] = templateItemName;\n }\n }\n resetUpdate();\n\n function modifyBase(attr, value) {\n update[attr] = value;\n }\n\n function modifyItem(attr, value) {\n if(templateItemName) {\n // we're making a new object: edit that object\n Lib.nestedProperty(update[itemStr], attr).set(value);\n } else {\n // we're editing an existing object: include *just* the edit\n update[itemStr + '.' + attr] = value;\n }\n }\n\n function getUpdateObj() {\n var updateOut = update;\n resetUpdate();\n return updateOut;\n }\n\n function applyUpdate(attr, value) {\n if(attr) modifyItem(attr, value);\n var updateToApply = getUpdateObj();\n for(var key in updateToApply) {\n Lib.nestedProperty(parentIn, key).set(updateToApply[key]);\n }\n }\n\n return {\n modifyBase: modifyBase,\n modifyItem: modifyItem,\n getUpdateObj: getUpdateObj,\n applyUpdate: applyUpdate\n };\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Registry = require('../registry');\nvar Plots = require('../plots/plots');\n\nvar Lib = require('../lib');\nvar svgTextUtils = require('../lib/svg_text_utils');\nvar clearGlCanvases = require('../lib/clear_gl_canvases');\n\nvar Color = require('../components/color');\nvar Drawing = require('../components/drawing');\nvar Titles = require('../components/titles');\nvar ModeBar = require('../components/modebar');\n\nvar Axes = require('../plots/cartesian/axes');\nvar alignmentConstants = require('../constants/alignment');\nvar axisConstraints = require('../plots/cartesian/constraints');\nvar enforceAxisConstraints = axisConstraints.enforce;\nvar cleanAxisConstraints = axisConstraints.clean;\nvar doAutoRange = require('../plots/cartesian/autorange').doAutoRange;\n\nvar SVG_TEXT_ANCHOR_START = 'start';\nvar SVG_TEXT_ANCHOR_MIDDLE = 'middle';\nvar SVG_TEXT_ANCHOR_END = 'end';\n\nvar zindexSeparator = require('../plots/cartesian/constants').zindexSeparator;\n\nexports.layoutStyles = function(gd) {\n return Lib.syncOrAsync([Plots.doAutoMargin, lsInner], gd);\n};\n\nfunction overlappingDomain(xDomain, yDomain, domains) {\n for(var i = 0; i < domains.length; i++) {\n var existingX = domains[i][0];\n var existingY = domains[i][1];\n\n if(existingX[0] >= xDomain[1] || existingX[1] <= xDomain[0]) {\n continue;\n }\n if(existingY[0] < yDomain[1] && existingY[1] > yDomain[0]) {\n return true;\n }\n }\n return false;\n}\n\nfunction lsInner(gd) {\n var fullLayout = gd._fullLayout;\n var gs = fullLayout._size;\n var pad = gs.p;\n var axList = Axes.list(gd, '', true);\n var i, subplot, plotinfo, ax, xa, ya;\n\n fullLayout._paperdiv.style({\n width: (gd._context.responsive && fullLayout.autosize && !gd._context._hasZeroWidth && !gd.layout.width) ? '100%' : fullLayout.width + 'px',\n height: (gd._context.responsive && fullLayout.autosize && !gd._context._hasZeroHeight && !gd.layout.height) ? '100%' : fullLayout.height + 'px'\n })\n .selectAll('.main-svg')\n .call(Drawing.setSize, fullLayout.width, fullLayout.height);\n gd._context.setBackground(gd, fullLayout.paper_bgcolor);\n\n exports.drawMainTitle(gd);\n ModeBar.manage(gd);\n\n // _has('cartesian') means SVG specifically, not GL2D - but GL2D\n // can still get here because it makes some of the SVG structure\n // for shared features like selections.\n if(!fullLayout._has('cartesian')) {\n return Plots.previousPromises(gd);\n }\n\n function getLinePosition(ax, counterAx, side) {\n var lwHalf = ax._lw / 2;\n\n if(ax._id.charAt(0) === 'x') {\n if(!counterAx) return gs.t + gs.h * (1 - (ax.position || 0)) + (lwHalf % 1);\n else if(side === 'top') return counterAx._offset - pad - lwHalf;\n return counterAx._offset + counterAx._length + pad + lwHalf;\n }\n\n if(!counterAx) return gs.l + gs.w * (ax.position || 0) + (lwHalf % 1);\n else if(side === 'right') return counterAx._offset + counterAx._length + pad + lwHalf;\n return counterAx._offset - pad - lwHalf;\n }\n\n // some preparation of axis position info\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n\n var counterAx = ax._anchorAxis;\n\n // clear axis line positions, to be set in the subplot loop below\n ax._linepositions = {};\n\n // stash crispRounded linewidth so we don't need to pass gd all over the place\n ax._lw = Drawing.crispRound(gd, ax.linewidth, 1);\n\n // figure out the main axis line and main mirror line position.\n // it's easier to follow the logic if we handle these separately from\n // ax._linepositions, which are only used by mirror=allticks\n // for non-main-subplot ticks, and mirror=all(ticks)? for zero line\n // hiding logic\n ax._mainLinePosition = getLinePosition(ax, counterAx, ax.side);\n ax._mainMirrorPosition = (ax.mirror && counterAx) ?\n getLinePosition(ax, counterAx,\n alignmentConstants.OPPOSITE_SIDE[ax.side]) : null;\n }\n\n // figure out which backgrounds we need to draw,\n // and in which layers to put them\n var lowerBackgroundIDs = [];\n var backgroundIds = [];\n var lowerDomains = [];\n // no need to draw background when paper and plot color are the same color,\n // activate mode just for large splom (which benefit the most from this\n // optimization), but this could apply to all cartesian subplots.\n var noNeedForBg = (\n Color.opacity(fullLayout.paper_bgcolor) === 1 &&\n Color.opacity(fullLayout.plot_bgcolor) === 1 &&\n fullLayout.paper_bgcolor === fullLayout.plot_bgcolor\n );\n\n for(subplot in fullLayout._plots) {\n plotinfo = fullLayout._plots[subplot];\n\n if(plotinfo.mainplot) {\n // mainplot is a reference to the main plot this one is overlaid on\n // so if it exists, this is an overlaid plot and we don't need to\n // give it its own background\n if(plotinfo.bg) {\n plotinfo.bg.remove();\n }\n plotinfo.bg = undefined;\n } else {\n var xDomain = plotinfo.xaxis.domain;\n var yDomain = plotinfo.yaxis.domain;\n var plotgroup = plotinfo.plotgroup;\n\n if(overlappingDomain(xDomain, yDomain, lowerDomains) && subplot.indexOf(zindexSeparator) === -1) {\n var pgNode = plotgroup.node();\n var plotgroupBg = plotinfo.bg = Lib.ensureSingle(plotgroup, 'rect', 'bg');\n pgNode.insertBefore(plotgroupBg.node(), pgNode.childNodes[0]);\n backgroundIds.push(subplot);\n } else {\n plotgroup.select('rect.bg').remove();\n lowerDomains.push([xDomain, yDomain]);\n if(!noNeedForBg) {\n lowerBackgroundIDs.push(subplot);\n backgroundIds.push(subplot);\n }\n }\n }\n }\n\n // now create all the lower-layer backgrounds at once now that\n // we have the list of subplots that need them\n var lowerBackgrounds = fullLayout._bgLayer.selectAll('.bg')\n .data(lowerBackgroundIDs);\n\n lowerBackgrounds.enter().append('rect')\n .classed('bg', true);\n\n lowerBackgrounds.exit().remove();\n\n lowerBackgrounds.each(function(subplot) {\n fullLayout._plots[subplot].bg = d3.select(this);\n });\n\n // style all backgrounds\n for(i = 0; i < backgroundIds.length; i++) {\n plotinfo = fullLayout._plots[backgroundIds[i]];\n xa = plotinfo.xaxis;\n ya = plotinfo.yaxis;\n\n if(plotinfo.bg && xa._offset !== undefined && ya._offset !== undefined) {\n plotinfo.bg\n .call(Drawing.setRect,\n xa._offset - pad, ya._offset - pad,\n xa._length + 2 * pad, ya._length + 2 * pad)\n .call(Color.fill, fullLayout.plot_bgcolor)\n .style('stroke-width', 0);\n }\n }\n\n if(!fullLayout._hasOnlyLargeSploms) {\n for(subplot in fullLayout._plots) {\n plotinfo = fullLayout._plots[subplot];\n xa = plotinfo.xaxis;\n ya = plotinfo.yaxis;\n\n // Clip so that data only shows up on the plot area.\n var clipId = plotinfo.clipId = 'clip' + fullLayout._uid + subplot + 'plot';\n\n var plotClip = Lib.ensureSingleById(fullLayout._clips, 'clipPath', clipId, function(s) {\n s.classed('plotclip', true)\n .append('rect');\n });\n\n plotinfo.clipRect = plotClip.select('rect').attr({\n width: xa._length,\n height: ya._length\n });\n\n Drawing.setTranslate(plotinfo.plot, xa._offset, ya._offset);\n\n var plotClipId;\n var layerClipId;\n\n if(plotinfo._hasClipOnAxisFalse) {\n plotClipId = null;\n layerClipId = clipId;\n } else {\n plotClipId = clipId;\n layerClipId = null;\n }\n\n Drawing.setClipUrl(plotinfo.plot, plotClipId, gd);\n\n // stash layer clipId value (null or same as clipId)\n // to DRY up Drawing.setClipUrl calls on trace-module and trace layers\n // downstream\n plotinfo.layerClipId = layerClipId;\n }\n }\n\n var xLinesXLeft, xLinesXRight, xLinesYBottom, xLinesYTop,\n leftYLineWidth, rightYLineWidth;\n var yLinesYBottom, yLinesYTop, yLinesXLeft, yLinesXRight,\n connectYBottom, connectYTop;\n var extraSubplot;\n\n function xLinePath(y) {\n return 'M' + xLinesXLeft + ',' + y + 'H' + xLinesXRight;\n }\n\n function xLinePathFree(y) {\n return 'M' + xa._offset + ',' + y + 'h' + xa._length;\n }\n\n function yLinePath(x) {\n return 'M' + x + ',' + yLinesYTop + 'V' + yLinesYBottom;\n }\n\n function yLinePathFree(x) {\n if(ya._shift !== undefined) {\n x += ya._shift;\n }\n return 'M' + x + ',' + ya._offset + 'v' + ya._length;\n }\n\n function mainPath(ax, pathFn, pathFnFree) {\n if(!ax.showline || subplot !== ax._mainSubplot) return '';\n if(!ax._anchorAxis) return pathFnFree(ax._mainLinePosition);\n var out = pathFn(ax._mainLinePosition);\n if(ax.mirror) out += pathFn(ax._mainMirrorPosition);\n return out;\n }\n\n for(subplot in fullLayout._plots) {\n plotinfo = fullLayout._plots[subplot];\n xa = plotinfo.xaxis;\n ya = plotinfo.yaxis;\n\n /*\n * x lines get longer where they meet y lines, to make a crisp corner.\n * The x lines get the padding (margin.pad) plus the y line width to\n * fill up the corner nicely. Free x lines are excluded - they always\n * span exactly the data area of the plot\n *\n * | XXXXX\n * | XXXXX\n * |\n * +------\n * x1\n * -----\n * x2\n */\n var xPath = 'M0,0';\n if(shouldShowLinesOrTicks(xa, subplot)) {\n leftYLineWidth = findCounterAxisLineWidth(xa, 'left', ya, axList);\n xLinesXLeft = xa._offset - (leftYLineWidth ? (pad + leftYLineWidth) : 0);\n rightYLineWidth = findCounterAxisLineWidth(xa, 'right', ya, axList);\n xLinesXRight = xa._offset + xa._length + (rightYLineWidth ? (pad + rightYLineWidth) : 0);\n xLinesYBottom = getLinePosition(xa, ya, 'bottom');\n xLinesYTop = getLinePosition(xa, ya, 'top');\n\n // save axis line positions for extra ticks to reference\n // each subplot that gets ticks from \"allticks\" gets an entry:\n // [left or bottom, right or top]\n extraSubplot = (!xa._anchorAxis || subplot !== xa._mainSubplot);\n if(extraSubplot && (xa.mirror === 'allticks' || xa.mirror === 'all')) {\n xa._linepositions[subplot] = [xLinesYBottom, xLinesYTop];\n }\n\n xPath = mainPath(xa, xLinePath, xLinePathFree);\n if(extraSubplot && xa.showline && (xa.mirror === 'all' || xa.mirror === 'allticks')) {\n xPath += xLinePath(xLinesYBottom) + xLinePath(xLinesYTop);\n }\n\n plotinfo.xlines\n .style('stroke-width', xa._lw + 'px')\n .call(Color.stroke, xa.showline ?\n xa.linecolor : 'rgba(0,0,0,0)');\n }\n plotinfo.xlines.attr('d', xPath);\n\n /*\n * y lines that meet x axes get longer only by margin.pad, because\n * the x axes fill in the corner space. Free y axes, like free x axes,\n * always span exactly the data area of the plot\n *\n * | | XXXX\n * y2| y1| XXXX\n * | | XXXX\n * |\n * +-----\n */\n var yPath = 'M0,0';\n if(shouldShowLinesOrTicks(ya, subplot)) {\n connectYBottom = findCounterAxisLineWidth(ya, 'bottom', xa, axList);\n yLinesYBottom = ya._offset + ya._length + (connectYBottom ? pad : 0);\n connectYTop = findCounterAxisLineWidth(ya, 'top', xa, axList);\n yLinesYTop = ya._offset - (connectYTop ? pad : 0);\n yLinesXLeft = getLinePosition(ya, xa, 'left');\n yLinesXRight = getLinePosition(ya, xa, 'right');\n\n extraSubplot = (!ya._anchorAxis || subplot !== ya._mainSubplot);\n if(extraSubplot && (ya.mirror === 'allticks' || ya.mirror === 'all')) {\n ya._linepositions[subplot] = [yLinesXLeft, yLinesXRight];\n }\n\n yPath = mainPath(ya, yLinePath, yLinePathFree);\n if(extraSubplot && ya.showline && (ya.mirror === 'all' || ya.mirror === 'allticks')) {\n yPath += yLinePath(yLinesXLeft) + yLinePath(yLinesXRight);\n }\n\n plotinfo.ylines\n .style('stroke-width', ya._lw + 'px')\n .call(Color.stroke, ya.showline ?\n ya.linecolor : 'rgba(0,0,0,0)');\n }\n plotinfo.ylines.attr('d', yPath);\n }\n\n Axes.makeClipPaths(gd);\n\n return Plots.previousPromises(gd);\n}\n\nfunction shouldShowLinesOrTicks(ax, subplot) {\n return (ax.ticks || ax.showline) &&\n (subplot === ax._mainSubplot || ax.mirror === 'all' || ax.mirror === 'allticks');\n}\n\n/*\n * should we draw a line on counterAx at this side of ax?\n * It's assumed that counterAx is known to overlay the subplot we're working on\n * but it may not be its main axis.\n */\nfunction shouldShowLineThisSide(ax, side, counterAx) {\n // does counterAx get a line at all?\n if(!counterAx.showline || !counterAx._lw) return false;\n\n // are we drawing *all* lines for counterAx?\n if(counterAx.mirror === 'all' || counterAx.mirror === 'allticks') return true;\n\n var anchorAx = counterAx._anchorAxis;\n\n // is this a free axis? free axes can only have a subplot side-line with all(ticks)? mirroring\n if(!anchorAx) return false;\n\n // in order to handle cases where the user forgot to anchor this axis correctly\n // (because its default anchor has the same domain on the relevant end)\n // check whether the relevant position is the same.\n var sideIndex = alignmentConstants.FROM_BL[side];\n if(counterAx.side === side) {\n return anchorAx.domain[sideIndex] === ax.domain[sideIndex];\n }\n return counterAx.mirror && anchorAx.domain[1 - sideIndex] === ax.domain[1 - sideIndex];\n}\n\n/*\n * Is there another axis intersecting `side` end of `ax`?\n * First look at `counterAx` (the axis for this subplot),\n * then at all other potential counteraxes on or overlaying this subplot.\n * Take the line width from the first one that has a line.\n */\nfunction findCounterAxisLineWidth(ax, side, counterAx, axList) {\n if(shouldShowLineThisSide(ax, side, counterAx)) {\n return counterAx._lw;\n }\n for(var i = 0; i < axList.length; i++) {\n var axi = axList[i];\n if(axi._mainAxis === counterAx._mainAxis && shouldShowLineThisSide(ax, side, axi)) {\n return axi._lw;\n }\n }\n return 0;\n}\n\nexports.drawMainTitle = function(gd) {\n var title = gd._fullLayout.title;\n var fullLayout = gd._fullLayout;\n var textAnchor = getMainTitleTextAnchor(fullLayout);\n var dy = getMainTitleDy(fullLayout);\n var y = getMainTitleY(fullLayout, dy);\n var x = getMainTitleX(fullLayout, textAnchor);\n\n Titles.draw(gd, 'gtitle', {\n propContainer: fullLayout,\n propName: 'title.text',\n subtitlePropName: 'title.subtitle.text',\n placeholder: fullLayout._dfltTitle.plot,\n subtitlePlaceholder: fullLayout._dfltTitle.subtitle,\n attributes: ({\n x: x,\n y: y,\n 'text-anchor': textAnchor,\n dy: dy\n }),\n });\n\n if(title.text && title.automargin) {\n var titleObj = d3.selectAll('.gtitle');\n var titleHeight = Drawing.bBox(d3.selectAll('.g-gtitle').node()).height;\n var pushMargin = needsMarginPush(gd, title, titleHeight);\n if(pushMargin > 0) {\n applyTitleAutoMargin(gd, y, pushMargin, titleHeight);\n // Re-position the title once we know where it needs to be\n titleObj.attr({\n x: x,\n y: y,\n 'text-anchor': textAnchor,\n dy: getMainTitleDyAdj(title.yanchor)\n }).call(svgTextUtils.positionText, x, y);\n\n var extraLines = (title.text.match(svgTextUtils.BR_TAG_ALL) || []).length;\n if(extraLines) {\n var delta = alignmentConstants.LINE_SPACING * extraLines + alignmentConstants.MID_SHIFT;\n if(title.y === 0) {\n delta = -delta;\n }\n\n titleObj.selectAll('.line').each(function() {\n var newDy = +(this.getAttribute('dy')).slice(0, -2) - delta + 'em';\n this.setAttribute('dy', newDy);\n });\n }\n\n // If there is a subtitle\n var subtitleObj = d3.selectAll('.gtitle-subtitle');\n if(subtitleObj.node()) {\n // Get bottom edge of title bounding box\n var titleBB = titleObj.node().getBBox();\n var titleBottom = titleBB.y + titleBB.height;\n var subtitleY = titleBottom + Titles.SUBTITLE_PADDING_EM * title.subtitle.font.size;\n subtitleObj.attr({\n x: x,\n y: subtitleY,\n 'text-anchor': textAnchor,\n dy: getMainTitleDyAdj(title.yanchor)\n }).call(svgTextUtils.positionText, x, subtitleY);\n }\n }\n }\n};\n\n\nfunction isOutsideContainer(gd, title, position, y, titleHeight) {\n var plotHeight = title.yref === 'paper' ? gd._fullLayout._size.h : gd._fullLayout.height;\n var yPosTop = Lib.isTopAnchor(title) ? y : y - titleHeight; // Standardize to the top of the title\n var yPosRel = position === 'b' ? plotHeight - yPosTop : yPosTop; // Position relative to the top or bottom of plot\n if((Lib.isTopAnchor(title) && position === 't') || Lib.isBottomAnchor(title) && position === 'b') {\n return false;\n } else {\n return yPosRel < titleHeight;\n }\n}\n\nfunction containerPushVal(position, titleY, titleYanchor, height, titleDepth) {\n var push = 0;\n if(titleYanchor === 'middle') {\n push += titleDepth / 2;\n }\n if(position === 't') {\n if(titleYanchor === 'top') {\n push += titleDepth;\n }\n push += (height - titleY * height);\n } else {\n if(titleYanchor === 'bottom') {\n push += titleDepth;\n }\n push += titleY * height;\n }\n return push;\n}\n\nfunction needsMarginPush(gd, title, titleHeight) {\n var titleY = title.y;\n var titleYanchor = title.yanchor;\n var position = titleY > 0.5 ? 't' : 'b';\n var curMargin = gd._fullLayout.margin[position];\n var pushMargin = 0;\n if(title.yref === 'paper') {\n pushMargin = (\n titleHeight +\n title.pad.t +\n title.pad.b\n );\n } else if(title.yref === 'container') {\n pushMargin = (\n containerPushVal(position, titleY, titleYanchor, gd._fullLayout.height, titleHeight) +\n title.pad.t +\n title.pad.b\n );\n }\n if(pushMargin > curMargin) {\n return pushMargin;\n }\n return 0;\n}\n\nfunction applyTitleAutoMargin(gd, y, pushMargin, titleHeight) {\n var titleID = 'title.automargin';\n var title = gd._fullLayout.title;\n var position = title.y > 0.5 ? 't' : 'b';\n var push = {\n x: title.x,\n y: title.y,\n t: 0,\n b: 0\n };\n var reservedPush = {};\n\n if(title.yref === 'paper' && isOutsideContainer(gd, title, position, y, titleHeight)) {\n push[position] = pushMargin;\n } else if(title.yref === 'container') {\n reservedPush[position] = pushMargin;\n gd._fullLayout._reservedMargin[titleID] = reservedPush;\n }\n Plots.allowAutoMargin(gd, titleID);\n Plots.autoMargin(gd, titleID, push);\n}\n\nfunction getMainTitleX(fullLayout, textAnchor) {\n var title = fullLayout.title;\n var gs = fullLayout._size;\n var hPadShift = 0;\n\n if(textAnchor === SVG_TEXT_ANCHOR_START) {\n hPadShift = title.pad.l;\n } else if(textAnchor === SVG_TEXT_ANCHOR_END) {\n hPadShift = -title.pad.r;\n }\n\n switch(title.xref) {\n case 'paper':\n return gs.l + gs.w * title.x + hPadShift;\n case 'container':\n default:\n return fullLayout.width * title.x + hPadShift;\n }\n}\n\nfunction getMainTitleY(fullLayout, dy) {\n var title = fullLayout.title;\n var gs = fullLayout._size;\n var vPadShift = 0;\n if(dy === '0em' || !dy) {\n vPadShift = -title.pad.b;\n } else if(dy === alignmentConstants.CAP_SHIFT + 'em') {\n vPadShift = title.pad.t;\n }\n\n if(title.y === 'auto') {\n return gs.t / 2;\n } else {\n switch(title.yref) {\n case 'paper':\n return gs.t + gs.h - gs.h * title.y + vPadShift;\n case 'container':\n default:\n return fullLayout.height - fullLayout.height * title.y + vPadShift;\n }\n }\n}\n\nfunction getMainTitleDyAdj(yanchor) {\n if(yanchor === 'top') {\n return alignmentConstants.CAP_SHIFT + 0.3 + 'em';\n } else if(yanchor === 'bottom') {\n return '-0.3em';\n } else {\n return alignmentConstants.MID_SHIFT + 'em';\n }\n}\n\nfunction getMainTitleTextAnchor(fullLayout) {\n var title = fullLayout.title;\n\n var textAnchor = SVG_TEXT_ANCHOR_MIDDLE;\n if(Lib.isRightAnchor(title)) {\n textAnchor = SVG_TEXT_ANCHOR_END;\n } else if(Lib.isLeftAnchor(title)) {\n textAnchor = SVG_TEXT_ANCHOR_START;\n }\n\n return textAnchor;\n}\n\nfunction getMainTitleDy(fullLayout) {\n var title = fullLayout.title;\n\n var dy = '0em';\n if(Lib.isTopAnchor(title)) {\n dy = alignmentConstants.CAP_SHIFT + 'em';\n } else if(Lib.isMiddleAnchor(title)) {\n dy = alignmentConstants.MID_SHIFT + 'em';\n }\n\n return dy;\n}\n\nexports.doTraceStyle = function(gd) {\n var calcdata = gd.calcdata;\n var editStyleCalls = [];\n var i;\n\n for(i = 0; i < calcdata.length; i++) {\n var cd = calcdata[i];\n var cd0 = cd[0] || {};\n var trace = cd0.trace || {};\n var _module = trace._module || {};\n\n // See if we need to do arraysToCalcdata\n // call it regardless of what change we made, in case\n // supplyDefaults brought in an array that was already\n // in gd.data but not in gd._fullData previously\n var arraysToCalcdata = _module.arraysToCalcdata;\n if(arraysToCalcdata) arraysToCalcdata(cd, trace);\n\n var editStyle = _module.editStyle;\n if(editStyle) editStyleCalls.push({fn: editStyle, cd0: cd0});\n }\n\n if(editStyleCalls.length) {\n for(i = 0; i < editStyleCalls.length; i++) {\n var edit = editStyleCalls[i];\n edit.fn(gd, edit.cd0);\n }\n clearGlCanvases(gd);\n exports.redrawReglTraces(gd);\n }\n\n Plots.style(gd);\n Registry.getComponentMethod('legend', 'draw')(gd);\n\n return Plots.previousPromises(gd);\n};\n\nexports.doColorBars = function(gd) {\n Registry.getComponentMethod('colorbar', 'draw')(gd);\n return Plots.previousPromises(gd);\n};\n\n// force plot() to redo the layout and replot with the modified layout\nexports.layoutReplot = function(gd) {\n var layout = gd.layout;\n gd.layout = undefined;\n return Registry.call('_doPlot', gd, '', layout);\n};\n\nexports.doLegend = function(gd) {\n Registry.getComponentMethod('legend', 'draw')(gd);\n return Plots.previousPromises(gd);\n};\n\nexports.doTicksRelayout = function(gd) {\n Axes.draw(gd, 'redraw');\n\n if(gd._fullLayout._hasOnlyLargeSploms) {\n Registry.subplotsRegistry.splom.updateGrid(gd);\n clearGlCanvases(gd);\n exports.redrawReglTraces(gd);\n }\n\n exports.drawMainTitle(gd);\n return Plots.previousPromises(gd);\n};\n\nexports.doModeBar = function(gd) {\n var fullLayout = gd._fullLayout;\n\n ModeBar.manage(gd);\n\n for(var i = 0; i < fullLayout._basePlotModules.length; i++) {\n var updateFx = fullLayout._basePlotModules[i].updateFx;\n if(updateFx) updateFx(gd);\n }\n\n return Plots.previousPromises(gd);\n};\n\nexports.doCamera = function(gd) {\n var fullLayout = gd._fullLayout;\n var sceneIds = fullLayout._subplots.gl3d;\n\n for(var i = 0; i < sceneIds.length; i++) {\n var sceneLayout = fullLayout[sceneIds[i]];\n var scene = sceneLayout._scene;\n\n scene.setViewport(sceneLayout);\n }\n};\n\nexports.drawData = function(gd) {\n var fullLayout = gd._fullLayout;\n\n clearGlCanvases(gd);\n\n // loop over the base plot modules present on graph\n var basePlotModules = fullLayout._basePlotModules;\n for(var i = 0; i < basePlotModules.length; i++) {\n basePlotModules[i].plot(gd);\n }\n\n exports.redrawReglTraces(gd);\n\n // styling separate from drawing\n Plots.style(gd);\n\n // draw components that can be drawn on axes,\n // and that do not push the margins\n Registry.getComponentMethod('selections', 'draw')(gd);\n Registry.getComponentMethod('shapes', 'draw')(gd);\n Registry.getComponentMethod('annotations', 'draw')(gd);\n Registry.getComponentMethod('images', 'draw')(gd);\n\n // Mark the first render as complete\n fullLayout._replotting = false;\n\n return Plots.previousPromises(gd);\n};\n\n// Draw (or redraw) all regl-based traces in one go,\n// useful during drag and selection where buffers of targeted traces are updated,\n// but all traces need to be redrawn following clearGlCanvases.\n//\n// Note that _module.plot for regl trace does NOT draw things\n// on the canvas, they only update the buffers.\n// Drawing is perform here.\n//\n// TODO try adding per-subplot option using gl.SCISSOR_TEST for\n// non-overlaying, disjoint subplots.\n//\n// TODO try to include parcoords in here.\n// https://github.com/plotly/plotly.js/issues/3069\nexports.redrawReglTraces = function(gd) {\n var fullLayout = gd._fullLayout;\n\n if(fullLayout._has('regl')) {\n var fullData = gd._fullData;\n var cartesianIds = [];\n var polarIds = [];\n var i, sp;\n\n if(fullLayout._hasOnlyLargeSploms) {\n fullLayout._splomGrid.draw();\n }\n\n // N.B.\n // - Loop over fullData (not _splomScenes) to preserve splom trace-to-trace ordering\n // - Fill list if subplot ids (instead of fullLayout._subplots) to handle cases where all traces\n // of a given module are `visible !== true`\n for(i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n\n if(trace.visible === true && trace._length !== 0) {\n if(trace.type === 'splom') {\n fullLayout._splomScenes[trace.uid].draw();\n } else if(trace.type === 'scattergl') {\n Lib.pushUnique(cartesianIds, trace.xaxis + trace.yaxis);\n } else if(trace.type === 'scatterpolargl') {\n Lib.pushUnique(polarIds, trace.subplot);\n }\n }\n }\n\n for(i = 0; i < cartesianIds.length; i++) {\n sp = fullLayout._plots[cartesianIds[i]];\n if(sp._scene) sp._scene.draw();\n }\n\n for(i = 0; i < polarIds.length; i++) {\n sp = fullLayout[polarIds[i]]._subplot;\n if(sp._scene) sp._scene.draw();\n }\n }\n};\n\nexports.doAutoRangeAndConstraints = function(gd) {\n var axList = Axes.list(gd, '', true);\n var ax;\n\n var autoRangeDone = {};\n\n for(var i = 0; i < axList.length; i++) {\n ax = axList[i];\n\n if(!autoRangeDone[ax._id]) {\n autoRangeDone[ax._id] = 1;\n cleanAxisConstraints(gd, ax);\n doAutoRange(gd, ax);\n\n // For matching axes, just propagate this autorange to the group.\n // The extra arg to doAutoRange avoids recalculating the range,\n // since doAutoRange by itself accounts for all matching axes. but\n // there are other side-effects of doAutoRange that we still want.\n var matchGroup = ax._matchGroup;\n if(matchGroup) {\n for(var id2 in matchGroup) {\n var ax2 = Axes.getFromId(gd, id2);\n doAutoRange(gd, ax2, ax.range);\n autoRangeDone[id2] = 1;\n }\n }\n }\n }\n\n enforceAxisConstraints(gd);\n};\n\n// An initial paint must be completed before these components can be\n// correctly sized and the whole plot re-margined. fullLayout._replotting must\n// be set to false before these will work properly.\nexports.finalDraw = function(gd) {\n // TODO: rangesliders really belong in marginPushers but they need to be\n // drawn after data - can we at least get the margin pushing part separated\n // out and done earlier?\n Registry.getComponentMethod('rangeslider', 'draw')(gd);\n // TODO: rangeselector only needs to be here (in addition to drawMarginPushers)\n // because the margins need to be fully determined before we can call\n // autorange and update axis ranges (which rangeselector needs to know which\n // button is active). Can we break out its automargin step from its draw step?\n Registry.getComponentMethod('rangeselector', 'draw')(gd);\n};\n\nexports.drawMarginPushers = function(gd) {\n Registry.getComponentMethod('legend', 'draw')(gd);\n Registry.getComponentMethod('rangeselector', 'draw')(gd);\n Registry.getComponentMethod('sliders', 'draw')(gd);\n Registry.getComponentMethod('updatemenus', 'draw')(gd);\n Registry.getComponentMethod('colorbar', 'draw')(gd);\n};\n","'use strict';\n\nvar Lib = require('../lib');\nvar isPlainObject = Lib.isPlainObject;\nvar PlotSchema = require('./plot_schema');\nvar Plots = require('../plots/plots');\nvar plotAttributes = require('../plots/attributes');\nvar Template = require('./plot_template');\nvar dfltConfig = require('./plot_config').dfltConfig;\n\n/**\n * Plotly.makeTemplate: create a template off an existing figure to reuse\n * style attributes on other figures.\n *\n * Note: separated from the rest of templates because otherwise we get circular\n * references due to PlotSchema.\n *\n * @param {object|DOM element|string} figure: The figure to base the template on\n * should contain a trace array `figure.data`\n * and a layout object `figure.layout`\n * @returns {object} template: the extracted template - can then be used as\n * `layout.template` in another figure.\n */\nexports.makeTemplate = function(figure) {\n figure = Lib.isPlainObject(figure) ? figure : Lib.getGraphDiv(figure);\n figure = Lib.extendDeep({_context: dfltConfig}, {data: figure.data, layout: figure.layout});\n Plots.supplyDefaults(figure);\n var data = figure.data || [];\n var layout = figure.layout || {};\n // copy over a few items to help follow the schema\n layout._basePlotModules = figure._fullLayout._basePlotModules;\n layout._modules = figure._fullLayout._modules;\n\n var template = {\n data: {},\n layout: {}\n };\n\n /*\n * Note: we do NOT validate template values, we just take what's in the\n * user inputs data and layout, not the validated values in fullData and\n * fullLayout. Even if we were to validate here, there's no guarantee that\n * these values would still be valid when applied to a new figure, which\n * may contain different trace modes, different axes, etc. So it's\n * important that when applying a template we still validate the template\n * values, rather than just using them as defaults.\n */\n\n data.forEach(function(trace) {\n // TODO: What if no style info is extracted for this trace. We may\n // not want an empty object as the null value.\n // TODO: allow transforms to contribute to templates?\n // as it stands they are ignored, which may be for the best...\n\n var traceTemplate = {};\n walkStyleKeys(trace, traceTemplate, getTraceInfo.bind(null, trace));\n\n var traceType = Lib.coerce(trace, {}, plotAttributes, 'type');\n var typeTemplates = template.data[traceType];\n if(!typeTemplates) typeTemplates = template.data[traceType] = [];\n typeTemplates.push(traceTemplate);\n });\n\n walkStyleKeys(layout, template.layout, getLayoutInfo.bind(null, layout));\n\n /*\n * Compose the new template with an existing one to the same effect\n *\n * NOTE: there's a possibility of slightly different behavior: if the plot\n * has an invalid value and the old template has a valid value for the same\n * attribute, the plot will use the old template value but this routine\n * will pull the invalid value (resulting in the original default).\n * In the general case it's not possible to solve this with a single value,\n * since valid options can be context-dependent. It could be solved with\n * a *list* of values, but that would be huge complexity for little gain.\n */\n delete template.layout.template;\n var oldTemplate = layout.template;\n if(isPlainObject(oldTemplate)) {\n var oldLayoutTemplate = oldTemplate.layout;\n\n var i, traceType, oldTypeTemplates, oldTypeLen, typeTemplates, typeLen;\n\n if(isPlainObject(oldLayoutTemplate)) {\n mergeTemplates(oldLayoutTemplate, template.layout);\n }\n var oldDataTemplate = oldTemplate.data;\n if(isPlainObject(oldDataTemplate)) {\n for(traceType in template.data) {\n oldTypeTemplates = oldDataTemplate[traceType];\n if(Array.isArray(oldTypeTemplates)) {\n typeTemplates = template.data[traceType];\n typeLen = typeTemplates.length;\n oldTypeLen = oldTypeTemplates.length;\n for(i = 0; i < typeLen; i++) {\n mergeTemplates(oldTypeTemplates[i % oldTypeLen], typeTemplates[i]);\n }\n for(i = typeLen; i < oldTypeLen; i++) {\n typeTemplates.push(Lib.extendDeep({}, oldTypeTemplates[i]));\n }\n }\n }\n for(traceType in oldDataTemplate) {\n if(!(traceType in template.data)) {\n template.data[traceType] = Lib.extendDeep([], oldDataTemplate[traceType]);\n }\n }\n }\n }\n\n return template;\n};\n\nfunction mergeTemplates(oldTemplate, newTemplate) {\n // we don't care about speed here, just make sure we have a totally\n // distinct object from the previous template\n oldTemplate = Lib.extendDeep({}, oldTemplate);\n\n // sort keys so we always get annotationdefaults before annotations etc\n // so arrayTemplater will work right\n var oldKeys = Object.keys(oldTemplate).sort();\n var i, j;\n\n function mergeOne(oldVal, newVal, key) {\n if(isPlainObject(newVal) && isPlainObject(oldVal)) {\n mergeTemplates(oldVal, newVal);\n } else if(Array.isArray(newVal) && Array.isArray(oldVal)) {\n // Note: omitted `inclusionAttr` from arrayTemplater here,\n // it's irrelevant as we only want the resulting `_template`.\n var templater = Template.arrayTemplater({_template: oldTemplate}, key);\n for(j = 0; j < newVal.length; j++) {\n var item = newVal[j];\n var oldItem = templater.newItem(item)._template;\n if(oldItem) mergeTemplates(oldItem, item);\n }\n var defaultItems = templater.defaultItems();\n for(j = 0; j < defaultItems.length; j++) newVal.push(defaultItems[j]._template);\n\n // templateitemname only applies to receiving plots\n for(j = 0; j < newVal.length; j++) delete newVal[j].templateitemname;\n }\n }\n\n for(i = 0; i < oldKeys.length; i++) {\n var key = oldKeys[i];\n var oldVal = oldTemplate[key];\n if(key in newTemplate) {\n mergeOne(oldVal, newTemplate[key], key);\n } else newTemplate[key] = oldVal;\n\n // if this is a base key from the old template (eg xaxis), look for\n // extended keys (eg xaxis2) in the new template to merge into\n if(getBaseKey(key) === key) {\n for(var key2 in newTemplate) {\n var baseKey2 = getBaseKey(key2);\n if(key2 !== baseKey2 && baseKey2 === key && !(key2 in oldTemplate)) {\n mergeOne(oldVal, newTemplate[key2], key);\n }\n }\n }\n }\n}\n\nfunction getBaseKey(key) {\n return key.replace(/[0-9]+$/, '');\n}\n\nfunction walkStyleKeys(parent, templateOut, getAttributeInfo, path, basePath) {\n var pathAttr = basePath && getAttributeInfo(basePath);\n for(var key in parent) {\n var child = parent[key];\n var nextPath = getNextPath(parent, key, path);\n var nextBasePath = getNextPath(parent, key, basePath);\n var attr = getAttributeInfo(nextBasePath);\n if(!attr) {\n var baseKey = getBaseKey(key);\n if(baseKey !== key) {\n nextBasePath = getNextPath(parent, baseKey, basePath);\n attr = getAttributeInfo(nextBasePath);\n }\n }\n\n // we'll get an attr if path starts with a valid part, then has an\n // invalid ending. Make sure we got all the way to the end.\n if(pathAttr && (pathAttr === attr)) continue;\n\n if(!attr || attr._noTemplating ||\n attr.valType === 'data_array' ||\n (attr.arrayOk && Array.isArray(child))\n ) {\n continue;\n }\n\n if(!attr.valType && isPlainObject(child)) {\n walkStyleKeys(child, templateOut, getAttributeInfo, nextPath, nextBasePath);\n } else if(attr._isLinkedToArray && Array.isArray(child)) {\n var dfltDone = false;\n var namedIndex = 0;\n var usedNames = {};\n for(var i = 0; i < child.length; i++) {\n var item = child[i];\n if(isPlainObject(item)) {\n var name = item.name;\n if(name) {\n if(!usedNames[name]) {\n // named array items: allow all attributes except data arrays\n walkStyleKeys(item, templateOut, getAttributeInfo,\n getNextPath(child, namedIndex, nextPath),\n getNextPath(child, namedIndex, nextBasePath));\n namedIndex++;\n usedNames[name] = 1;\n }\n } else if(!dfltDone) {\n var dfltKey = Template.arrayDefaultKey(key);\n var dfltPath = getNextPath(parent, dfltKey, path);\n\n // getAttributeInfo will fail if we try to use dfltKey directly.\n // Instead put this item into the next array element, then\n // pull it out and move it to dfltKey.\n var pathInArray = getNextPath(child, namedIndex, nextPath);\n walkStyleKeys(item, templateOut, getAttributeInfo, pathInArray,\n getNextPath(child, namedIndex, nextBasePath));\n var itemPropInArray = Lib.nestedProperty(templateOut, pathInArray);\n var dfltProp = Lib.nestedProperty(templateOut, dfltPath);\n dfltProp.set(itemPropInArray.get());\n itemPropInArray.set(null);\n\n dfltDone = true;\n }\n }\n }\n } else {\n var templateProp = Lib.nestedProperty(templateOut, nextPath);\n templateProp.set(child);\n }\n }\n}\n\nfunction getLayoutInfo(layout, path) {\n return PlotSchema.getLayoutValObject(\n layout, Lib.nestedProperty({}, path).parts\n );\n}\n\nfunction getTraceInfo(trace, path) {\n return PlotSchema.getTraceValObject(\n trace, Lib.nestedProperty({}, path).parts\n );\n}\n\nfunction getNextPath(parent, key, path) {\n var nextPath;\n if(!path) nextPath = key;\n else if(Array.isArray(parent)) nextPath = path + '[' + key + ']';\n else nextPath = path + '.' + key;\n\n return nextPath;\n}\n\n/**\n * validateTemplate: Test for consistency between the given figure and\n * a template, either already included in the figure or given separately.\n * Note that not every issue we identify here is necessarily a problem,\n * it depends on what you're using the template for.\n *\n * @param {object|DOM element} figure: the plot, with {data, layout} members,\n * to test the template against\n * @param {Optional(object)} template: the template, with its own {data, layout},\n * to test. If omitted, we will look for a template already attached as the\n * plot's `layout.template` attribute.\n *\n * @returns {array} array of error objects each containing:\n * - {string} code\n * error code ('missing', 'unused', 'reused', 'noLayout', 'noData')\n * - {string} msg\n * a full readable description of the issue.\n */\nexports.validateTemplate = function(figureIn, template) {\n var figure = Lib.extendDeep({}, {\n _context: dfltConfig,\n data: figureIn.data,\n layout: figureIn.layout\n });\n var layout = figure.layout || {};\n if(!isPlainObject(template)) template = layout.template || {};\n var layoutTemplate = template.layout;\n var dataTemplate = template.data;\n var errorList = [];\n\n figure.layout = layout;\n figure.layout.template = template;\n Plots.supplyDefaults(figure);\n\n var fullLayout = figure._fullLayout;\n var fullData = figure._fullData;\n\n var layoutPaths = {};\n function crawlLayoutForContainers(obj, paths) {\n for(var key in obj) {\n if(key.charAt(0) !== '_' && isPlainObject(obj[key])) {\n var baseKey = getBaseKey(key);\n var nextPaths = [];\n var i;\n for(i = 0; i < paths.length; i++) {\n nextPaths.push(getNextPath(obj, key, paths[i]));\n if(baseKey !== key) nextPaths.push(getNextPath(obj, baseKey, paths[i]));\n }\n for(i = 0; i < nextPaths.length; i++) {\n layoutPaths[nextPaths[i]] = 1;\n }\n crawlLayoutForContainers(obj[key], nextPaths);\n }\n }\n }\n\n function crawlLayoutTemplateForContainers(obj, path) {\n for(var key in obj) {\n if(key.indexOf('defaults') === -1 && isPlainObject(obj[key])) {\n var nextPath = getNextPath(obj, key, path);\n if(layoutPaths[nextPath]) {\n crawlLayoutTemplateForContainers(obj[key], nextPath);\n } else {\n errorList.push({code: 'unused', path: nextPath});\n }\n }\n }\n }\n\n if(!isPlainObject(layoutTemplate)) {\n errorList.push({code: 'layout'});\n } else {\n crawlLayoutForContainers(fullLayout, ['layout']);\n crawlLayoutTemplateForContainers(layoutTemplate, 'layout');\n }\n\n if(!isPlainObject(dataTemplate)) {\n errorList.push({code: 'data'});\n } else {\n var typeCount = {};\n var traceType;\n for(var i = 0; i < fullData.length; i++) {\n var fullTrace = fullData[i];\n traceType = fullTrace.type;\n typeCount[traceType] = (typeCount[traceType] || 0) + 1;\n if(!fullTrace._fullInput._template) {\n // this takes care of the case of traceType in the data but not\n // the template\n errorList.push({\n code: 'missing',\n index: fullTrace._fullInput.index,\n traceType: traceType\n });\n }\n }\n for(traceType in dataTemplate) {\n var templateCount = dataTemplate[traceType].length;\n var dataCount = typeCount[traceType] || 0;\n if(templateCount > dataCount) {\n errorList.push({\n code: 'unused',\n traceType: traceType,\n templateCount: templateCount,\n dataCount: dataCount\n });\n } else if(dataCount > templateCount) {\n errorList.push({\n code: 'reused',\n traceType: traceType,\n templateCount: templateCount,\n dataCount: dataCount\n });\n }\n }\n }\n\n // _template: false is when someone tried to modify an array item\n // but there was no template with matching name\n function crawlForMissingTemplates(obj, path) {\n for(var key in obj) {\n if(key.charAt(0) === '_') continue;\n var val = obj[key];\n var nextPath = getNextPath(obj, key, path);\n if(isPlainObject(val)) {\n if(Array.isArray(obj) && val._template === false && val.templateitemname) {\n errorList.push({\n code: 'missing',\n path: nextPath,\n templateitemname: val.templateitemname\n });\n }\n crawlForMissingTemplates(val, nextPath);\n } else if(Array.isArray(val) && hasPlainObject(val)) {\n crawlForMissingTemplates(val, nextPath);\n }\n }\n }\n crawlForMissingTemplates({data: fullData, layout: fullLayout}, '');\n\n if(errorList.length) return errorList.map(format);\n};\n\nfunction hasPlainObject(arr) {\n for(var i = 0; i < arr.length; i++) {\n if(isPlainObject(arr[i])) return true;\n }\n}\n\nfunction format(opts) {\n var msg;\n switch(opts.code) {\n case 'data':\n msg = 'The template has no key data.';\n break;\n case 'layout':\n msg = 'The template has no key layout.';\n break;\n case 'missing':\n if(opts.path) {\n msg = 'There are no templates for item ' + opts.path +\n ' with name ' + opts.templateitemname;\n } else {\n msg = 'There are no templates for trace ' + opts.index +\n ', of type ' + opts.traceType + '.';\n }\n break;\n case 'unused':\n if(opts.path) {\n msg = 'The template item at ' + opts.path +\n ' was not used in constructing the plot.';\n } else if(opts.dataCount) {\n msg = 'Some of the templates of type ' + opts.traceType +\n ' were not used. The template has ' + opts.templateCount +\n ' traces, the data only has ' + opts.dataCount +\n ' of this type.';\n } else {\n msg = 'The template has ' + opts.templateCount +\n ' traces of type ' + opts.traceType +\n ' but there are none in the data.';\n }\n break;\n case 'reused':\n msg = 'Some of the templates of type ' + opts.traceType +\n ' were used more than once. The template has ' +\n opts.templateCount + ' traces, the data has ' +\n opts.dataCount + ' of this type.';\n break;\n }\n opts.msg = msg;\n\n return opts;\n}\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar plotApi = require('./plot_api');\nvar plots = require('../plots/plots');\nvar Lib = require('../lib');\n\nvar helpers = require('../snapshot/helpers');\nvar toSVG = require('../snapshot/tosvg');\nvar svgToImg = require('../snapshot/svgtoimg');\nvar version = require('../version').version;\n\nvar attrs = {\n format: {\n valType: 'enumerated',\n values: ['png', 'jpeg', 'webp', 'svg', 'full-json'],\n dflt: 'png',\n description: 'Sets the format of exported image.'\n },\n width: {\n valType: 'number',\n min: 1,\n description: [\n 'Sets the exported image width.',\n 'Defaults to the value found in `layout.width`',\n 'If set to *null*, the exported image width will match the current graph width.'\n ].join(' ')\n },\n height: {\n valType: 'number',\n min: 1,\n description: [\n 'Sets the exported image height.',\n 'Defaults to the value found in `layout.height`',\n 'If set to *null*, the exported image height will match the current graph height.'\n ].join(' ')\n },\n scale: {\n valType: 'number',\n min: 0,\n dflt: 1,\n description: [\n 'Sets a scaling for the generated image.',\n 'If set, all features of a graphs (e.g. text, line width)',\n 'are scaled, unlike simply setting',\n 'a bigger *width* and *height*.'\n ].join(' ')\n },\n setBackground: {\n valType: 'any',\n dflt: false,\n description: [\n 'Sets the image background mode.',\n 'By default, the image background is determined by `layout.paper_bgcolor`,',\n 'the *transparent* mode.',\n 'One might consider setting `setBackground` to *opaque*',\n 'when exporting a *jpeg* image as JPEGs do not support opacity.'\n ].join(' ')\n },\n imageDataOnly: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether or not the return value is prefixed by',\n 'the image format\\'s corresponding \\'data:image;\\' spec.'\n ].join(' ')\n }\n};\n\n/** Plotly.toImage\n *\n * @param {object | string | HTML div} gd\n * can either be a data/layout/config object\n * or an existing graph
\n * or an id to an existing graph
\n * @param {object} opts (see above)\n * @return {promise}\n */\nfunction toImage(gd, opts) {\n opts = opts || {};\n\n var data;\n var layout;\n var config;\n var fullLayout;\n\n if(Lib.isPlainObject(gd)) {\n data = gd.data || [];\n layout = gd.layout || {};\n config = gd.config || {};\n fullLayout = {};\n } else {\n gd = Lib.getGraphDiv(gd);\n data = Lib.extendDeep([], gd.data);\n layout = Lib.extendDeep({}, gd.layout);\n config = gd._context;\n fullLayout = gd._fullLayout || {};\n }\n\n function isImpliedOrValid(attr) {\n return !(attr in opts) || Lib.validate(opts[attr], attrs[attr]);\n }\n\n if((!isImpliedOrValid('width') && opts.width !== null) ||\n (!isImpliedOrValid('height') && opts.height !== null)) {\n throw new Error('Height and width should be pixel values.');\n }\n\n if(!isImpliedOrValid('format')) {\n throw new Error('Export format is not ' + Lib.join2(attrs.format.values, ', ', ' or ') + '.');\n }\n\n var fullOpts = {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(opts, fullOpts, attrs, attr, dflt);\n }\n\n var format = coerce('format');\n var width = coerce('width');\n var height = coerce('height');\n var scale = coerce('scale');\n var setBackground = coerce('setBackground');\n var imageDataOnly = coerce('imageDataOnly');\n\n // put the cloned div somewhere off screen before attaching to DOM\n var clonedGd = document.createElement('div');\n clonedGd.style.position = 'absolute';\n clonedGd.style.left = '-5000px';\n document.body.appendChild(clonedGd);\n\n // extend layout with image options\n var layoutImage = Lib.extendFlat({}, layout);\n if(width) {\n layoutImage.width = width;\n } else if(opts.width === null && isNumeric(fullLayout.width)) {\n layoutImage.width = fullLayout.width;\n }\n if(height) {\n layoutImage.height = height;\n } else if(opts.height === null && isNumeric(fullLayout.height)) {\n layoutImage.height = fullLayout.height;\n }\n\n // extend config for static plot\n var configImage = Lib.extendFlat({}, config, {\n _exportedPlot: true,\n staticPlot: true,\n setBackground: setBackground\n });\n\n var redrawFunc = helpers.getRedrawFunc(clonedGd);\n\n function wait() {\n return new Promise(function(resolve) {\n setTimeout(resolve, helpers.getDelay(clonedGd._fullLayout));\n });\n }\n\n function convert() {\n return new Promise(function(resolve, reject) {\n var svg = toSVG(clonedGd, format, scale);\n var width = clonedGd._fullLayout.width;\n var height = clonedGd._fullLayout.height;\n\n function cleanup() {\n plotApi.purge(clonedGd);\n document.body.removeChild(clonedGd);\n }\n\n if(format === 'full-json') {\n var json = plots.graphJson(clonedGd, false, 'keepdata', 'object', true, true);\n json.version = version;\n json = JSON.stringify(json);\n cleanup();\n if(imageDataOnly) {\n return resolve(json);\n } else {\n return resolve(helpers.encodeJSON(json));\n }\n }\n\n cleanup();\n\n if(format === 'svg') {\n if(imageDataOnly) {\n return resolve(svg);\n } else {\n return resolve(helpers.encodeSVG(svg));\n }\n }\n\n var canvas = document.createElement('canvas');\n canvas.id = Lib.randstr();\n\n svgToImg({\n format: format,\n width: width,\n height: height,\n scale: scale,\n canvas: canvas,\n svg: svg,\n // ask svgToImg to return a Promise\n // rather than EventEmitter\n // leave EventEmitter for backward\n // compatibility\n promise: true\n })\n .then(resolve)\n .catch(reject);\n });\n }\n\n function urlToImageData(url) {\n if(imageDataOnly) {\n return url.replace(helpers.IMAGE_URL_PREFIX, '');\n } else {\n return url;\n }\n }\n\n return new Promise(function(resolve, reject) {\n plotApi.newPlot(clonedGd, data, layoutImage, configImage)\n .then(redrawFunc)\n .then(wait)\n .then(convert)\n .then(function(url) { resolve(urlToImageData(url)); })\n .catch(function(err) { reject(err); });\n });\n}\n\nmodule.exports = toImage;\n","'use strict';\n\nvar Lib = require('../lib');\nvar Plots = require('../plots/plots');\nvar PlotSchema = require('./plot_schema');\nvar dfltConfig = require('./plot_config').dfltConfig;\n\nvar isPlainObject = Lib.isPlainObject;\nvar isArray = Array.isArray;\nvar isArrayOrTypedArray = Lib.isArrayOrTypedArray;\n\n/**\n * Validate a data array and layout object.\n *\n * @param {array} data\n * @param {object} layout\n *\n * @return {array} array of error objects each containing:\n * - {string} code\n * error code ('object', 'array', 'schema', 'unused', 'invisible' or 'value')\n * - {string} container\n * container where the error occurs ('data' or 'layout')\n * - {number} trace\n * trace index of the 'data' container where the error occurs\n * - {array} path\n * nested path to the key that causes the error\n * - {string} astr\n * attribute string variant of 'path' compatible with Plotly.restyle and\n * Plotly.relayout.\n * - {string} msg\n * error message (shown in console in logger config argument is enable)\n */\nmodule.exports = function validate(data, layout) {\n if(data === undefined) data = [];\n if(layout === undefined) layout = {};\n\n var schema = PlotSchema.get();\n var errorList = [];\n var gd = {_context: Lib.extendFlat({}, dfltConfig)};\n\n var dataIn, layoutIn;\n\n if(isArray(data)) {\n gd.data = Lib.extendDeep([], data);\n dataIn = data;\n } else {\n gd.data = [];\n dataIn = [];\n errorList.push(format('array', 'data'));\n }\n\n if(isPlainObject(layout)) {\n gd.layout = Lib.extendDeep({}, layout);\n layoutIn = layout;\n } else {\n gd.layout = {};\n layoutIn = {};\n if(arguments.length > 1) {\n errorList.push(format('object', 'layout'));\n }\n }\n\n // N.B. dataIn and layoutIn are in general not the same as\n // gd.data and gd.layout after supplyDefaults as some attributes\n // in gd.data and gd.layout (still) get mutated during this step.\n\n Plots.supplyDefaults(gd);\n\n var dataOut = gd._fullData;\n var len = dataIn.length;\n\n for(var i = 0; i < len; i++) {\n var traceIn = dataIn[i];\n var base = ['data', i];\n\n if(!isPlainObject(traceIn)) {\n errorList.push(format('object', base));\n continue;\n }\n\n var traceOut = dataOut[i];\n var traceType = traceOut.type;\n var traceSchema = schema.traces[traceType].attributes;\n\n // PlotSchema does something fancy with trace 'type', reset it here\n // to make the trace schema compatible with Lib.validate.\n traceSchema.type = {\n valType: 'enumerated',\n values: [traceType]\n };\n\n if(traceOut.visible === false && traceIn.visible !== false) {\n errorList.push(format('invisible', base));\n }\n\n crawl(traceIn, traceOut, traceSchema, errorList, base);\n\n var transformsIn = traceIn.transforms;\n var transformsOut = traceOut.transforms;\n\n if(transformsIn) {\n if(!isArray(transformsIn)) {\n errorList.push(format('array', base, ['transforms']));\n }\n\n base.push('transforms');\n\n for(var j = 0; j < transformsIn.length; j++) {\n var path = ['transforms', j];\n var transformType = transformsIn[j].type;\n\n if(!isPlainObject(transformsIn[j])) {\n errorList.push(format('object', base, path));\n continue;\n }\n\n var transformSchema = schema.transforms[transformType] ?\n schema.transforms[transformType].attributes :\n {};\n\n // add 'type' to transform schema to validate the transform type\n transformSchema.type = {\n valType: 'enumerated',\n values: Object.keys(schema.transforms)\n };\n\n crawl(transformsIn[j], transformsOut[j], transformSchema, errorList, base, path);\n }\n }\n }\n\n var layoutOut = gd._fullLayout;\n var layoutSchema = fillLayoutSchema(schema, dataOut);\n\n crawl(layoutIn, layoutOut, layoutSchema, errorList, 'layout');\n\n // return undefined if no validation errors were found\n return (errorList.length === 0) ? void(0) : errorList;\n};\n\nfunction crawl(objIn, objOut, schema, list, base, path) {\n path = path || [];\n\n var keys = Object.keys(objIn);\n\n for(var i = 0; i < keys.length; i++) {\n var k = keys[i];\n\n // transforms are handled separately\n if(k === 'transforms') continue;\n\n var p = path.slice();\n p.push(k);\n\n var valIn = objIn[k];\n var valOut = objOut[k];\n\n var nestedSchema = getNestedSchema(schema, k);\n var nestedValType = (nestedSchema || {}).valType;\n var isInfoArray = nestedValType === 'info_array';\n var isColorscale = nestedValType === 'colorscale';\n var items = (nestedSchema || {}).items;\n\n if(!isInSchema(schema, k)) {\n list.push(format('schema', base, p));\n } else if(isPlainObject(valIn) && isPlainObject(valOut) && nestedValType !== 'any') {\n crawl(valIn, valOut, nestedSchema, list, base, p);\n } else if(isInfoArray && isArray(valIn)) {\n if(valIn.length > valOut.length) {\n list.push(format('unused', base, p.concat(valOut.length)));\n }\n var len = valOut.length;\n var arrayItems = Array.isArray(items);\n if(arrayItems) len = Math.min(len, items.length);\n var m, n, item, valInPart, valOutPart;\n if(nestedSchema.dimensions === 2) {\n for(n = 0; n < len; n++) {\n if(isArray(valIn[n])) {\n if(valIn[n].length > valOut[n].length) {\n list.push(format('unused', base, p.concat(n, valOut[n].length)));\n }\n var len2 = valOut[n].length;\n for(m = 0; m < (arrayItems ? Math.min(len2, items[n].length) : len2); m++) {\n item = arrayItems ? items[n][m] : items;\n valInPart = valIn[n][m];\n valOutPart = valOut[n][m];\n if(!Lib.validate(valInPart, item)) {\n list.push(format('value', base, p.concat(n, m), valInPart));\n } else if(valOutPart !== valInPart && valOutPart !== +valInPart) {\n list.push(format('dynamic', base, p.concat(n, m), valInPart, valOutPart));\n }\n }\n } else {\n list.push(format('array', base, p.concat(n), valIn[n]));\n }\n }\n } else {\n for(n = 0; n < len; n++) {\n item = arrayItems ? items[n] : items;\n valInPart = valIn[n];\n valOutPart = valOut[n];\n if(!Lib.validate(valInPart, item)) {\n list.push(format('value', base, p.concat(n), valInPart));\n } else if(valOutPart !== valInPart && valOutPart !== +valInPart) {\n list.push(format('dynamic', base, p.concat(n), valInPart, valOutPart));\n }\n }\n }\n } else if(nestedSchema.items && !isInfoArray && isArray(valIn)) {\n var _nestedSchema = items[Object.keys(items)[0]];\n var indexList = [];\n\n var j, _p;\n\n // loop over valOut items while keeping track of their\n // corresponding input container index (given by _index)\n for(j = 0; j < valOut.length; j++) {\n var _index = valOut[j]._index || j;\n\n _p = p.slice();\n _p.push(_index);\n\n if(isPlainObject(valIn[_index]) && isPlainObject(valOut[j])) {\n indexList.push(_index);\n var valInj = valIn[_index];\n var valOutj = valOut[j];\n if(isPlainObject(valInj) && valInj.visible !== false && valOutj.visible === false) {\n list.push(format('invisible', base, _p));\n } else crawl(valInj, valOutj, _nestedSchema, list, base, _p);\n }\n }\n\n // loop over valIn to determine where it went wrong for some items\n for(j = 0; j < valIn.length; j++) {\n _p = p.slice();\n _p.push(j);\n\n if(!isPlainObject(valIn[j])) {\n list.push(format('object', base, _p, valIn[j]));\n } else if(indexList.indexOf(j) === -1) {\n list.push(format('unused', base, _p));\n }\n }\n } else if(!isPlainObject(valIn) && isPlainObject(valOut)) {\n list.push(format('object', base, p, valIn));\n } else if(!isArrayOrTypedArray(valIn) && isArrayOrTypedArray(valOut) && !isInfoArray && !isColorscale) {\n list.push(format('array', base, p, valIn));\n } else if(!(k in objOut)) {\n list.push(format('unused', base, p, valIn));\n } else if(!Lib.validate(valIn, nestedSchema)) {\n list.push(format('value', base, p, valIn));\n } else if(nestedSchema.valType === 'enumerated' &&\n ((nestedSchema.coerceNumber && valIn !== +valOut) || valIn !== valOut)\n ) {\n list.push(format('dynamic', base, p, valIn, valOut));\n }\n }\n\n return list;\n}\n\n// the 'full' layout schema depends on the traces types presents\nfunction fillLayoutSchema(schema, dataOut) {\n var layoutSchema = schema.layout.layoutAttributes;\n\n for(var i = 0; i < dataOut.length; i++) {\n var traceOut = dataOut[i];\n var traceSchema = schema.traces[traceOut.type];\n var traceLayoutAttr = traceSchema.layoutAttributes;\n\n if(traceLayoutAttr) {\n if(traceOut.subplot) {\n Lib.extendFlat(layoutSchema[traceSchema.attributes.subplot.dflt], traceLayoutAttr);\n } else {\n Lib.extendFlat(layoutSchema, traceLayoutAttr);\n }\n }\n }\n\n return layoutSchema;\n}\n\n// validation error codes\nvar code2msgFunc = {\n object: function(base, astr) {\n var prefix;\n\n if(base === 'layout' && astr === '') prefix = 'The layout argument';\n else if(base[0] === 'data' && astr === '') {\n prefix = 'Trace ' + base[1] + ' in the data argument';\n } else prefix = inBase(base) + 'key ' + astr;\n\n return prefix + ' must be linked to an object container';\n },\n array: function(base, astr) {\n var prefix;\n\n if(base === 'data') prefix = 'The data argument';\n else prefix = inBase(base) + 'key ' + astr;\n\n return prefix + ' must be linked to an array container';\n },\n schema: function(base, astr) {\n return inBase(base) + 'key ' + astr + ' is not part of the schema';\n },\n unused: function(base, astr, valIn) {\n var target = isPlainObject(valIn) ? 'container' : 'key';\n\n return inBase(base) + target + ' ' + astr + ' did not get coerced';\n },\n dynamic: function(base, astr, valIn, valOut) {\n return [\n inBase(base) + 'key',\n astr,\n '(set to \\'' + valIn + '\\')',\n 'got reset to',\n '\\'' + valOut + '\\'',\n 'during defaults.'\n ].join(' ');\n },\n invisible: function(base, astr) {\n return (\n astr ? (inBase(base) + 'item ' + astr) : ('Trace ' + base[1])\n ) + ' got defaulted to be not visible';\n },\n value: function(base, astr, valIn) {\n return [\n inBase(base) + 'key ' + astr,\n 'is set to an invalid value (' + valIn + ')'\n ].join(' ');\n }\n};\n\nfunction inBase(base) {\n if(isArray(base)) return 'In data trace ' + base[1] + ', ';\n\n return 'In ' + base + ', ';\n}\n\nfunction format(code, base, path, valIn, valOut) {\n path = path || '';\n\n var container, trace;\n\n // container is either 'data' or 'layout\n // trace is the trace index if 'data', null otherwise\n\n if(isArray(base)) {\n container = base[0];\n trace = base[1];\n } else {\n container = base;\n trace = null;\n }\n\n var astr = convertPathToAttributeString(path);\n var msg = code2msgFunc[code](base, astr, valIn, valOut);\n\n // log to console if logger config option is enabled\n Lib.log(msg);\n\n return {\n code: code,\n container: container,\n trace: trace,\n path: path,\n astr: astr,\n msg: msg\n };\n}\n\nfunction isInSchema(schema, key) {\n var parts = splitKey(key);\n var keyMinusId = parts.keyMinusId;\n var id = parts.id;\n\n if((keyMinusId in schema) && schema[keyMinusId]._isSubplotObj && id) {\n return true;\n }\n\n return (key in schema);\n}\n\nfunction getNestedSchema(schema, key) {\n if(key in schema) return schema[key];\n\n var parts = splitKey(key);\n\n return schema[parts.keyMinusId];\n}\n\nvar idRegex = Lib.counterRegex('([a-z]+)');\n\nfunction splitKey(key) {\n var idMatch = key.match(idRegex);\n\n return {\n keyMinusId: idMatch && idMatch[1],\n id: idMatch && idMatch[2]\n };\n}\n\nfunction convertPathToAttributeString(path) {\n if(!isArray(path)) return String(path);\n\n var astr = '';\n\n for(var i = 0; i < path.length; i++) {\n var p = path[i];\n\n if(typeof p === 'number') {\n astr = astr.substr(0, astr.length - 1) + '[' + p + ']';\n } else {\n astr += p;\n }\n\n if(i < path.length - 1) astr += '.';\n }\n\n return astr;\n}\n","'use strict';\n\nmodule.exports = {\n mode: {\n valType: 'enumerated',\n dflt: 'afterall',\n values: ['immediate', 'next', 'afterall'],\n description: [\n 'Describes how a new animate call interacts with currently-running',\n 'animations. If `immediate`, current animations are interrupted and',\n 'the new animation is started. If `next`, the current frame is allowed',\n 'to complete, after which the new animation is started. If `afterall`',\n 'all existing frames are animated to completion before the new animation',\n 'is started.'\n ].join(' ')\n },\n direction: {\n valType: 'enumerated',\n values: ['forward', 'reverse'],\n dflt: 'forward',\n description: [\n 'The direction in which to play the frames triggered by the animation call'\n ].join(' ')\n },\n fromcurrent: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Play frames starting at the current frame instead of the beginning.'\n ].join(' ')\n },\n frame: {\n duration: {\n valType: 'number',\n min: 0,\n dflt: 500,\n description: [\n 'The duration in milliseconds of each frame. If greater than the frame',\n 'duration, it will be limited to the frame duration.'\n ].join(' ')\n },\n redraw: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Redraw the plot at completion of the transition. This is desirable',\n 'for transitions that include properties that cannot be transitioned,',\n 'but may significantly slow down updates that do not require a full',\n 'redraw of the plot'\n ].join(' ')\n },\n },\n transition: {\n duration: {\n valType: 'number',\n min: 0,\n dflt: 500,\n editType: 'none',\n description: [\n 'The duration of the transition, in milliseconds. If equal to zero,',\n 'updates are synchronous.'\n ].join(' ')\n },\n easing: {\n valType: 'enumerated',\n dflt: 'cubic-in-out',\n values: [\n 'linear',\n 'quad',\n 'cubic',\n 'sin',\n 'exp',\n 'circle',\n 'elastic',\n 'back',\n 'bounce',\n 'linear-in',\n 'quad-in',\n 'cubic-in',\n 'sin-in',\n 'exp-in',\n 'circle-in',\n 'elastic-in',\n 'back-in',\n 'bounce-in',\n 'linear-out',\n 'quad-out',\n 'cubic-out',\n 'sin-out',\n 'exp-out',\n 'circle-out',\n 'elastic-out',\n 'back-out',\n 'bounce-out',\n 'linear-in-out',\n 'quad-in-out',\n 'cubic-in-out',\n 'sin-in-out',\n 'exp-in-out',\n 'circle-in-out',\n 'elastic-in-out',\n 'back-in-out',\n 'bounce-in-out'\n ],\n editType: 'none',\n description: 'The easing function used for the transition'\n },\n ordering: {\n valType: 'enumerated',\n values: ['layout first', 'traces first'],\n dflt: 'layout first',\n editType: 'none',\n description: [\n 'Determines whether the figure\\'s layout or traces smoothly transitions',\n 'during updates that make both traces and layout change.'\n ].join(' ')\n }\n }\n};\n","'use strict';\n\nvar Lib = require('../lib');\nvar Template = require('../plot_api/plot_template');\n\n/** Convenience wrapper for making array container logic DRY and consistent\n *\n * @param {object} parentObjIn\n * user input object where the container in question is linked\n * (i.e. either a user trace object or the user layout object)\n *\n * @param {object} parentObjOut\n * full object where the coerced container will be linked\n * (i.e. either a full trace object or the full layout object)\n *\n * @param {object} opts\n * options object:\n * - name {string}\n * name of the key linking the container in question\n * - inclusionAttr {string}\n * name of the item attribute for inclusion/exclusion. Default is 'visible'.\n * Since inclusion is true, use eg 'enabled' instead of 'disabled'.\n * - handleItemDefaults {function}\n * defaults method to be called on each item in the array container in question\n *\n * Its arguments are:\n * - itemIn {object} item in user layout\n * - itemOut {object} item in full layout\n * - parentObj {object} (as in closure)\n * - opts {object} (as in closure)\n * N.B.\n *\n * - opts is passed to handleItemDefaults so it can also store\n * links to supplementary data (e.g. fullData for layout components)\n *\n */\nmodule.exports = function handleArrayContainerDefaults(parentObjIn, parentObjOut, opts) {\n var name = opts.name;\n var inclusionAttr = opts.inclusionAttr || 'visible';\n\n var previousContOut = parentObjOut[name];\n\n var contIn = Lib.isArrayOrTypedArray(parentObjIn[name]) ? parentObjIn[name] : [];\n var contOut = parentObjOut[name] = [];\n var templater = Template.arrayTemplater(parentObjOut, name, inclusionAttr);\n var i, itemOut;\n\n for(i = 0; i < contIn.length; i++) {\n var itemIn = contIn[i];\n\n if(!Lib.isPlainObject(itemIn)) {\n itemOut = templater.newItem({});\n itemOut[inclusionAttr] = false;\n } else {\n itemOut = templater.newItem(itemIn);\n }\n\n itemOut._index = i;\n\n if(itemOut[inclusionAttr] !== false) {\n opts.handleItemDefaults(itemIn, itemOut, parentObjOut, opts);\n }\n\n contOut.push(itemOut);\n }\n\n var defaultItems = templater.defaultItems();\n for(i = 0; i < defaultItems.length; i++) {\n itemOut = defaultItems[i];\n itemOut._index = contOut.length;\n opts.handleItemDefaults({}, itemOut, parentObjOut, opts, {});\n contOut.push(itemOut);\n }\n\n // in case this array gets its defaults rebuilt independent of the whole layout,\n // relink the private keys just for this array.\n if(Lib.isArrayOrTypedArray(previousContOut)) {\n var len = Math.min(previousContOut.length, contOut.length);\n for(i = 0; i < len; i++) {\n Lib.relinkPrivateKeys(contOut[i], previousContOut[i]);\n }\n }\n\n return contOut;\n};\n","'use strict';\n\nvar fontAttrs = require('./font_attributes');\nvar fxAttrs = require('../components/fx/attributes');\n\nmodule.exports = {\n type: {\n valType: 'enumerated',\n values: [], // listed dynamically\n dflt: 'scatter',\n editType: 'calc+clearAxisTypes',\n _noTemplating: true // we handle this at a higher level\n },\n visible: {\n valType: 'enumerated',\n values: [true, false, 'legendonly'],\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether or not this trace is visible.',\n 'If *legendonly*, the trace is not drawn,',\n 'but can appear as a legend item',\n '(provided that the legend itself is visible).'\n ].join(' ')\n },\n showlegend: {\n valType: 'boolean',\n dflt: true,\n editType: 'style',\n description: [\n 'Determines whether or not an item corresponding to this',\n 'trace is shown in the legend.'\n ].join(' ')\n },\n legend: {\n valType: 'subplotid',\n dflt: 'legend',\n editType: 'style',\n\n description: [\n 'Sets the reference to a legend to show this trace in.',\n 'References to these legends are *legend*, *legend2*, *legend3*, etc.',\n 'Settings for these legends are set in the layout, under',\n '`layout.legend`, `layout.legend2`, etc.'\n ].join(' ')\n },\n legendgroup: {\n valType: 'string',\n dflt: '',\n editType: 'style',\n description: [\n 'Sets the legend group for this trace.',\n 'Traces and shapes part of the same legend group hide/show at the same time',\n 'when toggling legend items.'\n ].join(' ')\n },\n legendgrouptitle: {\n text: {\n valType: 'string',\n dflt: '',\n editType: 'style',\n description: [\n 'Sets the title of the legend group.'\n ].join(' ')\n },\n font: fontAttrs({\n editType: 'style',\n description: [\n 'Sets this legend group\\'s title font.'\n ].join(' '),\n }),\n editType: 'style',\n },\n legendrank: {\n valType: 'number',\n dflt: 1000,\n editType: 'style',\n description: [\n 'Sets the legend rank for this trace.',\n 'Items and groups with smaller ranks are presented on top/left side while',\n 'with *reversed* `legend.traceorder` they are on bottom/right side.',\n 'The default legendrank is 1000,',\n 'so that you can use ranks less than 1000 to place certain items before all unranked items,',\n 'and ranks greater than 1000 to go after all unranked items.',\n 'When having unranked or equal rank items shapes would be displayed after traces',\n 'i.e. according to their order in data and layout.'\n ].join(' ')\n },\n legendwidth: {\n valType: 'number',\n min: 0,\n editType: 'style',\n description: 'Sets the width (in px or fraction) of the legend for this trace.',\n },\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n editType: 'style',\n description: 'Sets the opacity of the trace.'\n },\n name: {\n valType: 'string',\n editType: 'style',\n description: [\n 'Sets the trace name.',\n 'The trace name appears as the legend item and on hover.'\n ].join(' ')\n },\n uid: {\n valType: 'string',\n editType: 'plot',\n anim: true,\n description: [\n 'Assign an id to this trace,',\n 'Use this to provide object constancy between traces during animations',\n 'and transitions.'\n ].join(' ')\n },\n ids: {\n valType: 'data_array',\n editType: 'calc',\n anim: true,\n description: [\n 'Assigns id labels to each datum.',\n 'These ids for object constancy of data points during animation.',\n 'Should be an array of strings, not numbers or any other type.'\n ].join(' ')\n },\n customdata: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Assigns extra data each datum.',\n 'This may be useful when listening to hover, click and selection events.',\n 'Note that, *scatter* traces also appends customdata items in the markers',\n 'DOM elements'\n ].join(' ')\n },\n meta: {\n valType: 'any',\n arrayOk: true,\n editType: 'plot',\n description: [\n 'Assigns extra meta information associated with this trace',\n 'that can be used in various text attributes.',\n 'Attributes such as trace `name`, graph, axis and colorbar `title.text`, annotation `text`',\n '`rangeselector`, `updatemenues` and `sliders` `label` text',\n 'all support `meta`.',\n 'To access the trace `meta` values in an attribute in the same trace, simply use',\n '`%{meta[i]}` where `i` is the index or key of the `meta`',\n 'item in question.',\n 'To access trace `meta` in layout attributes, use',\n '`%{data[n[.meta[i]}` where `i` is the index or key of the `meta`',\n 'and `n` is the trace index.'\n ].join(' ')\n },\n\n // N.B. these cannot be 'data_array' as they do not have the same length as\n // other data arrays and arrayOk attributes in general\n //\n // Maybe add another valType:\n // https://github.com/plotly/plotly.js/issues/1894\n selectedpoints: {\n valType: 'any',\n editType: 'calc',\n description: [\n 'Array containing integer indices of selected points.',\n 'Has an effect only for traces that support selections.',\n 'Note that an empty array means an empty selection where the `unselected`',\n 'are turned on for all points, whereas, any other non-array values means no',\n 'selection all where the `selected` and `unselected` styles have no effect.'\n ].join(' ')\n },\n\n hoverinfo: {\n valType: 'flaglist',\n flags: ['x', 'y', 'z', 'text', 'name'],\n extras: ['all', 'none', 'skip'],\n arrayOk: true,\n dflt: 'all',\n editType: 'none',\n description: [\n 'Determines which trace information appear on hover.',\n 'If `none` or `skip` are set, no information is displayed upon hovering.',\n 'But, if `none` is set, click and hover events are still fired.'\n ].join(' ')\n },\n hoverlabel: fxAttrs.hoverlabel,\n stream: {\n token: {\n valType: 'string',\n noBlank: true,\n strict: true,\n editType: 'calc',\n description: [\n 'The stream id number links a data trace on a plot with a stream.',\n 'See https://chart-studio.plotly.com/settings for more details.'\n ].join(' ')\n },\n maxpoints: {\n valType: 'number',\n min: 0,\n max: 10000,\n dflt: 500,\n editType: 'calc',\n description: [\n 'Sets the maximum number of points to keep on the plots from an',\n 'incoming stream.',\n 'If `maxpoints` is set to *50*, only the newest 50 points will',\n 'be displayed on the plot.'\n ].join(' ')\n },\n editType: 'calc'\n },\n transforms: {\n _isLinkedToArray: 'transform',\n editType: 'calc',\n description: [\n 'WARNING: All transforms are deprecated and may be removed from the API in next major version.',\n 'An array of operations that manipulate the trace data,',\n 'for example filtering or sorting the data arrays.'\n ].join(' ')\n },\n uirevision: {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of some user-driven changes to the trace:',\n '`constraintrange` in `parcoords` traces, as well as some',\n '`editable: true` modifications such as `name` and `colorbar.title`.',\n 'Defaults to `layout.uirevision`.',\n 'Note that other user-driven trace attribute changes are controlled',\n 'by `layout` attributes:',\n '`trace.visible` is controlled by `layout.legend.uirevision`,',\n '`selectedpoints` is controlled by `layout.selectionrevision`,',\n 'and `colorbar.(x|y)` (accessible with `config: {editable: true}`)',\n 'is controlled by `layout.editrevision`.',\n 'Trace changes are tracked by `uid`, which only falls back on trace',\n 'index if no `uid` is provided. So if your app can add/remove traces',\n 'before the end of the `data` array, such that the same trace has a',\n 'different index, you can still preserve user-driven changes if you',\n 'give each trace a `uid` that stays with it as it moves.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar Lib = require('../../lib');\nvar dateTime2ms = Lib.dateTime2ms;\nvar incrementMonth = Lib.incrementMonth;\nvar constants = require('../../constants/numerical');\nvar ONEAVGMONTH = constants.ONEAVGMONTH;\n\nmodule.exports = function alignPeriod(trace, ax, axLetter, vals) {\n if(ax.type !== 'date') return {vals: vals};\n\n var alignment = trace[axLetter + 'periodalignment'];\n if(!alignment) return {vals: vals};\n\n var period = trace[axLetter + 'period'];\n var mPeriod;\n if(isNumeric(period)) {\n period = +period;\n if(period <= 0) return {vals: vals};\n } else if(typeof period === 'string' && period.charAt(0) === 'M') {\n var n = +(period.substring(1));\n if(n > 0 && Math.round(n) === n) {\n mPeriod = n;\n } else return {vals: vals};\n }\n\n var calendar = ax.calendar;\n\n var isStart = 'start' === alignment;\n // var isMiddle = 'middle' === alignment;\n var isEnd = 'end' === alignment;\n\n var period0 = trace[axLetter + 'period0'];\n var base = dateTime2ms(period0, calendar) || 0;\n\n var newVals = [];\n var starts = [];\n var ends = [];\n\n var len = vals.length;\n for(var i = 0; i < len; i++) {\n var v = vals[i];\n\n var nEstimated, startTime, endTime;\n if(mPeriod) {\n // guess at how many periods away from base we are\n nEstimated = Math.round((v - base) / (mPeriod * ONEAVGMONTH));\n endTime = incrementMonth(base, mPeriod * nEstimated, calendar);\n\n // iterate to get the exact bounds before and after v\n // there may be ways to make this faster, but most of the time\n // we'll only execute each loop zero or one time.\n while(endTime > v) {\n endTime = incrementMonth(endTime, -mPeriod, calendar);\n }\n while(endTime <= v) {\n endTime = incrementMonth(endTime, mPeriod, calendar);\n }\n\n // now we know endTime is the boundary immediately after v\n // so startTime is obtained by incrementing backward one period.\n startTime = incrementMonth(endTime, -mPeriod, calendar);\n } else { // case of ms\n nEstimated = Math.round((v - base) / period);\n endTime = base + nEstimated * period;\n\n while(endTime > v) {\n endTime -= period;\n }\n while(endTime <= v) {\n endTime += period;\n }\n\n startTime = endTime - period;\n }\n\n newVals[i] = (\n isStart ? startTime :\n isEnd ? endTime :\n (startTime + endTime) / 2\n );\n\n starts[i] = startTime;\n ends[i] = endTime;\n }\n\n return {\n vals: newVals,\n starts: starts,\n ends: ends\n };\n};\n","'use strict';\n\n\nmodule.exports = {\n xaxis: {\n valType: 'subplotid',\n dflt: 'x',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets a reference between this trace\\'s x coordinates and',\n 'a 2D cartesian x axis.',\n 'If *x* (the default value), the x coordinates refer to',\n '`layout.xaxis`.',\n 'If *x2*, the x coordinates refer to `layout.xaxis2`, and so on.'\n ].join(' ')\n },\n yaxis: {\n valType: 'subplotid',\n dflt: 'y',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets a reference between this trace\\'s y coordinates and',\n 'a 2D cartesian y axis.',\n 'If *y* (the default value), the y coordinates refer to',\n '`layout.yaxis`.',\n 'If *y2*, the y coordinates refer to `layout.yaxis2`, and so on.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar FP_SAFE = require('../../constants/numerical').FP_SAFE;\nvar Registry = require('../../registry');\nvar Drawing = require('../../components/drawing');\n\nvar axIds = require('./axis_ids');\nvar getFromId = axIds.getFromId;\nvar isLinked = axIds.isLinked;\n\nmodule.exports = {\n applyAutorangeOptions: applyAutorangeOptions,\n getAutoRange: getAutoRange,\n makePadFn: makePadFn,\n doAutoRange: doAutoRange,\n findExtremes: findExtremes,\n concatExtremes: concatExtremes\n};\n\n/**\n * getAutoRange\n *\n * Collects all _extremes values corresponding to a given axis\n * and computes its auto range.\n *\n * Note that getAutoRange uses return values from findExtremes.\n *\n * @param {object} gd:\n * graph div object with filled-in fullData and fullLayout, in particular\n * with filled-in '_extremes' containers:\n * {\n * val: calcdata value,\n * pad: extra pixels beyond this value,\n * extrapad: bool, does this point want 5% extra padding\n * }\n * @param {object} ax:\n * full axis object, in particular with filled-in '_traceIndices'\n * and '_annIndices' / '_shapeIndices' if applicable\n * @return {array}\n * an array of [min, max]. These are calcdata for log and category axes\n * and data for linear and date axes.\n *\n * TODO: we want to change log to data as well, but it's hard to do this\n * maintaining backward compatibility. category will always have to use calcdata\n * though, because otherwise values between categories (or outside all categories)\n * would be impossible.\n */\nfunction getAutoRange(gd, ax) {\n var i, j;\n var newRange = [];\n\n var fullLayout = gd._fullLayout;\n var getPadMin = makePadFn(fullLayout, ax, 0);\n var getPadMax = makePadFn(fullLayout, ax, 1);\n var extremes = concatExtremes(gd, ax);\n var minArray = extremes.min;\n var maxArray = extremes.max;\n\n if(minArray.length === 0 || maxArray.length === 0) {\n return Lib.simpleMap(ax.range, ax.r2l);\n }\n\n var minmin = minArray[0].val;\n var maxmax = maxArray[0].val;\n\n for(i = 1; i < minArray.length; i++) {\n if(minmin !== maxmax) break;\n minmin = Math.min(minmin, minArray[i].val);\n }\n for(i = 1; i < maxArray.length; i++) {\n if(minmin !== maxmax) break;\n maxmax = Math.max(maxmax, maxArray[i].val);\n }\n\n var autorange = ax.autorange;\n var axReverse =\n autorange === 'reversed' ||\n autorange === 'min reversed' ||\n autorange === 'max reversed';\n\n if(!axReverse && ax.range) {\n var rng = Lib.simpleMap(ax.range, ax.r2l);\n axReverse = rng[1] < rng[0];\n }\n\n // one-time setting to easily reverse the axis\n // when plotting from code\n if(ax.autorange === 'reversed') {\n ax.autorange = true;\n }\n\n var rangeMode = ax.rangemode;\n var toZero = rangeMode === 'tozero';\n var nonNegative = rangeMode === 'nonnegative';\n var axLen = ax._length;\n // don't allow padding to reduce the data to < 10% of the length\n var minSpan = axLen / 10;\n\n var mbest = 0;\n var minpt, maxpt, minbest, maxbest, dp, dv;\n\n for(i = 0; i < minArray.length; i++) {\n minpt = minArray[i];\n for(j = 0; j < maxArray.length; j++) {\n maxpt = maxArray[j];\n dv = maxpt.val - minpt.val - calcBreaksLength(ax, minpt.val, maxpt.val);\n if(dv > 0) {\n dp = axLen - getPadMin(minpt) - getPadMax(maxpt);\n if(dp > minSpan) {\n if(dv / dp > mbest) {\n minbest = minpt;\n maxbest = maxpt;\n mbest = dv / dp;\n }\n } else if(dv / axLen > mbest) {\n // in case of padding longer than the axis\n // at least include the unpadded data values.\n minbest = {val: minpt.val, nopad: 1};\n maxbest = {val: maxpt.val, nopad: 1};\n mbest = dv / axLen;\n }\n }\n }\n }\n\n function maximumPad(prev, pt) {\n return Math.max(prev, getPadMax(pt));\n }\n\n if(minmin === maxmax) {\n var lower = minmin - 1;\n var upper = minmin + 1;\n if(toZero) {\n if(minmin === 0) {\n // The only value we have on this axis is 0, and we want to\n // autorange so zero is one end.\n // In principle this could be [0, 1] or [-1, 0] but usually\n // 'tozero' pins 0 to the low end, so follow that.\n newRange = [0, 1];\n } else {\n var maxPad = (minmin > 0 ? maxArray : minArray).reduce(maximumPad, 0);\n // we're pushing a single value away from the edge due to its\n // padding, with the other end clamped at zero\n // 0.5 means don't push it farther than the center.\n var rangeEnd = minmin / (1 - Math.min(0.5, maxPad / axLen));\n newRange = minmin > 0 ? [0, rangeEnd] : [rangeEnd, 0];\n }\n } else if(nonNegative) {\n newRange = [Math.max(0, lower), Math.max(1, upper)];\n } else {\n newRange = [lower, upper];\n }\n } else {\n if(toZero) {\n if(minbest.val >= 0) {\n minbest = {val: 0, nopad: 1};\n }\n if(maxbest.val <= 0) {\n maxbest = {val: 0, nopad: 1};\n }\n } else if(nonNegative) {\n if(minbest.val - mbest * getPadMin(minbest) < 0) {\n minbest = {val: 0, nopad: 1};\n }\n if(maxbest.val <= 0) {\n maxbest = {val: 1, nopad: 1};\n }\n }\n\n // in case it changed again...\n mbest = (maxbest.val - minbest.val - calcBreaksLength(ax, minpt.val, maxpt.val)) /\n (axLen - getPadMin(minbest) - getPadMax(maxbest));\n\n newRange = [\n minbest.val - mbest * getPadMin(minbest),\n maxbest.val + mbest * getPadMax(maxbest)\n ];\n }\n\n newRange = applyAutorangeOptions(newRange, ax);\n\n if(ax.limitRange) ax.limitRange();\n\n // maintain reversal\n if(axReverse) newRange.reverse();\n\n return Lib.simpleMap(newRange, ax.l2r || Number);\n}\n\n// find axis rangebreaks in [v0,v1] and compute its length in value space\nfunction calcBreaksLength(ax, v0, v1) {\n var lBreaks = 0;\n if(ax.rangebreaks) {\n var rangebreaksOut = ax.locateBreaks(v0, v1);\n for(var i = 0; i < rangebreaksOut.length; i++) {\n var brk = rangebreaksOut[i];\n lBreaks += brk.max - brk.min;\n }\n }\n return lBreaks;\n}\n\n/*\n * calculate the pixel padding for ax._min and ax._max entries with\n * optional extrapad as 5% of the total axis length\n */\nfunction makePadFn(fullLayout, ax, max) {\n // 5% padding for points that specify extrapad: true\n var extrappad = 0.05 * ax._length;\n\n var anchorAxis = ax._anchorAxis || {};\n\n if(\n (ax.ticklabelposition || '').indexOf('inside') !== -1 ||\n (anchorAxis.ticklabelposition || '').indexOf('inside') !== -1\n ) {\n var axReverse = ax.isReversed();\n if(!axReverse) {\n var rng = Lib.simpleMap(ax.range, ax.r2l);\n axReverse = rng[1] < rng[0];\n }\n if(axReverse) max = !max;\n }\n\n var zero = 0;\n if(!isLinked(fullLayout, ax._id)) {\n zero = padInsideLabelsOnAnchorAxis(fullLayout, ax, max);\n }\n extrappad = Math.max(zero, extrappad);\n\n // domain-constrained axes: base extrappad on the unconstrained\n // domain so it's consistent as the domain changes\n if((ax.constrain === 'domain') && ax._inputDomain) {\n extrappad *= (ax._inputDomain[1] - ax._inputDomain[0]) /\n (ax.domain[1] - ax.domain[0]);\n }\n\n return function getPad(pt) {\n if(pt.nopad) return 0;\n return pt.pad + (pt.extrapad ? extrappad : zero);\n };\n}\n\nvar TEXTPAD = 3;\n\nfunction padInsideLabelsOnAnchorAxis(fullLayout, ax, max) {\n var pad = 0;\n\n var isX = ax._id.charAt(0) === 'x';\n\n for(var subplot in fullLayout._plots) {\n var plotinfo = fullLayout._plots[subplot];\n\n if(ax._id !== plotinfo.xaxis._id && ax._id !== plotinfo.yaxis._id) continue;\n\n var anchorAxis = (isX ? plotinfo.yaxis : plotinfo.xaxis) || {};\n\n if((anchorAxis.ticklabelposition || '').indexOf('inside') !== -1) {\n // increase padding to make more room for inside tick labels of the counter axis\n if((\n !max && (\n anchorAxis.side === 'left' ||\n anchorAxis.side === 'bottom'\n )\n ) || (\n max && (\n anchorAxis.side === 'top' ||\n anchorAxis.side === 'right'\n )\n )) {\n if(anchorAxis._vals) {\n var rad = Lib.deg2rad(anchorAxis._tickAngles[anchorAxis._id + 'tick'] || 0);\n var cosA = Math.abs(Math.cos(rad));\n var sinA = Math.abs(Math.sin(rad));\n\n // no stashed bounding boxes - stash bounding boxes\n if(!anchorAxis._vals[0].bb) {\n var cls = anchorAxis._id + 'tick';\n var tickLabels = anchorAxis._selections[cls];\n tickLabels.each(function(d) {\n var thisLabel = d3.select(this);\n var mathjaxGroup = thisLabel.select('.text-math-group');\n if(mathjaxGroup.empty()) {\n d.bb = Drawing.bBox(thisLabel.node());\n }\n });\n }\n\n // use bounding boxes\n for(var i = 0; i < anchorAxis._vals.length; i++) {\n var t = anchorAxis._vals[i];\n var bb = t.bb;\n\n if(bb) {\n var w = 2 * TEXTPAD + bb.width;\n var h = 2 * TEXTPAD + bb.height;\n\n pad = Math.max(pad, isX ?\n Math.max(w * cosA, h * sinA) :\n Math.max(h * cosA, w * sinA)\n );\n }\n }\n }\n\n if(anchorAxis.ticks === 'inside' && anchorAxis.ticklabelposition === 'inside') {\n pad += anchorAxis.ticklen || 0;\n }\n }\n }\n }\n\n return pad;\n}\n\nfunction concatExtremes(gd, ax, noMatch) {\n var axId = ax._id;\n var fullData = gd._fullData;\n var fullLayout = gd._fullLayout;\n var minArray = [];\n var maxArray = [];\n var i, j, d;\n\n function _concat(cont, indices) {\n for(i = 0; i < indices.length; i++) {\n var item = cont[indices[i]];\n var extremes = (item._extremes || {})[axId];\n if(item.visible === true && extremes) {\n for(j = 0; j < extremes.min.length; j++) {\n d = extremes.min[j];\n collapseMinArray(minArray, d.val, d.pad, {extrapad: d.extrapad});\n }\n for(j = 0; j < extremes.max.length; j++) {\n d = extremes.max[j];\n collapseMaxArray(maxArray, d.val, d.pad, {extrapad: d.extrapad});\n }\n }\n }\n }\n\n _concat(fullData, ax._traceIndices);\n _concat(fullLayout.annotations || [], ax._annIndices || []);\n _concat(fullLayout.shapes || [], ax._shapeIndices || []);\n\n // Include the extremes from other matched axes with this one\n if(ax._matchGroup && !noMatch) {\n for(var axId2 in ax._matchGroup) {\n if(axId2 !== ax._id) {\n var ax2 = getFromId(gd, axId2);\n var extremes2 = concatExtremes(gd, ax2, true);\n // convert padding on the second axis to the first with lenRatio\n var lenRatio = ax._length / ax2._length;\n for(j = 0; j < extremes2.min.length; j++) {\n d = extremes2.min[j];\n collapseMinArray(minArray, d.val, d.pad * lenRatio, {extrapad: d.extrapad});\n }\n for(j = 0; j < extremes2.max.length; j++) {\n d = extremes2.max[j];\n collapseMaxArray(maxArray, d.val, d.pad * lenRatio, {extrapad: d.extrapad});\n }\n }\n }\n }\n\n return {min: minArray, max: maxArray};\n}\n\nfunction doAutoRange(gd, ax, presetRange) {\n ax.setScale();\n\n if(ax.autorange) {\n ax.range = presetRange ? presetRange.slice() : getAutoRange(gd, ax);\n\n ax._r = ax.range.slice();\n ax._rl = Lib.simpleMap(ax._r, ax.r2l);\n\n // doAutoRange will get called on fullLayout,\n // but we want to report its results back to layout\n\n var axIn = ax._input;\n\n // before we edit _input, store preGUI values\n var edits = {};\n edits[ax._attr + '.range'] = ax.range;\n edits[ax._attr + '.autorange'] = ax.autorange;\n Registry.call('_storeDirectGUIEdit', gd.layout, gd._fullLayout._preGUI, edits);\n\n axIn.range = ax.range.slice();\n axIn.autorange = ax.autorange;\n }\n\n var anchorAx = ax._anchorAxis;\n\n if(anchorAx && anchorAx.rangeslider) {\n var axeRangeOpts = anchorAx.rangeslider[ax._name];\n if(axeRangeOpts) {\n if(axeRangeOpts.rangemode === 'auto') {\n axeRangeOpts.range = getAutoRange(gd, ax);\n }\n }\n anchorAx._input.rangeslider[ax._name] = Lib.extendFlat({}, axeRangeOpts);\n }\n}\n\n/**\n * findExtremes\n *\n * Find min/max extremes of an array of coordinates on a given axis.\n *\n * Note that findExtremes is called during `calc`, when we don't yet know the axis\n * length; all the inputs should be based solely on the trace data, nothing\n * about the axis layout.\n *\n * Note that `ppad` and `vpad` as well as their asymmetric variants refer to\n * the before and after padding of the passed `data` array, not to the whole axis.\n *\n * @param {object} ax: full axis object\n * relies on\n * - ax.type\n * - ax._m (just its sign)\n * - ax.d2l\n * @param {array} data:\n * array of numbers (i.e. already run though ax.d2c)\n * @param {object} opts:\n * available keys are:\n * vpad: (number or number array) pad values (data value +-vpad)\n * ppad: (number or number array) pad pixels (pixel location +-ppad)\n * ppadplus, ppadminus, vpadplus, vpadminus:\n * separate padding for each side, overrides symmetric\n * padded: (boolean) add 5% padding to both ends\n * (unless one end is overridden by tozero)\n * tozero: (boolean) make sure to include zero if axis is linear,\n * and make it a tight bound if possible\n * vpadLinearized: (boolean) whether or not vpad (or vpadplus/vpadminus)\n * is linearized (for log scale axes)\n *\n * @return {object}\n * - min {array of objects}\n * - max {array of objects}\n * each object item has fields:\n * - val {number}\n * - pad {number}\n * - extrappad {number}\n * - opts {object}: a ref to the passed \"options\" object\n */\nfunction findExtremes(ax, data, opts) {\n if(!opts) opts = {};\n if(!ax._m) ax.setScale();\n\n var minArray = [];\n var maxArray = [];\n\n var len = data.length;\n var extrapad = opts.padded || false;\n var tozero = opts.tozero && (ax.type === 'linear' || ax.type === '-');\n var isLog = ax.type === 'log';\n var hasArrayOption = false;\n var vpadLinearized = opts.vpadLinearized || false;\n var i, v, di, dmin, dmax, ppadiplus, ppadiminus, vmin, vmax;\n\n function makePadAccessor(item) {\n if(Array.isArray(item)) {\n hasArrayOption = true;\n return function(i) { return Math.max(Number(item[i]||0), 0); };\n } else {\n var v = Math.max(Number(item||0), 0);\n return function() { return v; };\n }\n }\n\n var ppadplus = makePadAccessor((ax._m > 0 ?\n opts.ppadplus : opts.ppadminus) || opts.ppad || 0);\n var ppadminus = makePadAccessor((ax._m > 0 ?\n opts.ppadminus : opts.ppadplus) || opts.ppad || 0);\n var vpadplus = makePadAccessor(opts.vpadplus || opts.vpad);\n var vpadminus = makePadAccessor(opts.vpadminus || opts.vpad);\n\n if(!hasArrayOption) {\n // with no arrays other than `data` we don't need to consider\n // every point, only the extreme data points\n vmin = Infinity;\n vmax = -Infinity;\n\n if(isLog) {\n for(i = 0; i < len; i++) {\n v = data[i];\n // data is not linearized yet so we still have to filter out negative logs\n if(v < vmin && v > 0) vmin = v;\n if(v > vmax && v < FP_SAFE) vmax = v;\n }\n } else {\n for(i = 0; i < len; i++) {\n v = data[i];\n if(v < vmin && v > -FP_SAFE) vmin = v;\n if(v > vmax && v < FP_SAFE) vmax = v;\n }\n }\n\n data = [vmin, vmax];\n len = 2;\n }\n\n var collapseOpts = {tozero: tozero, extrapad: extrapad};\n\n function addItem(i) {\n di = data[i];\n if(!isNumeric(di)) return;\n ppadiplus = ppadplus(i);\n ppadiminus = ppadminus(i);\n\n if(vpadLinearized) {\n dmin = ax.c2l(di) - vpadminus(i);\n dmax = ax.c2l(di) + vpadplus(i);\n } else {\n vmin = di - vpadminus(i);\n vmax = di + vpadplus(i);\n // special case for log axes: if vpad makes this object span\n // more than an order of mag, clip it to one order. This is so\n // we don't have non-positive errors or absurdly large lower\n // range due to rounding errors\n if(isLog && vmin < vmax / 10) vmin = vmax / 10;\n\n dmin = ax.c2l(vmin);\n dmax = ax.c2l(vmax);\n }\n\n if(tozero) {\n dmin = Math.min(0, dmin);\n dmax = Math.max(0, dmax);\n }\n if(goodNumber(dmin)) {\n collapseMinArray(minArray, dmin, ppadiminus, collapseOpts);\n }\n if(goodNumber(dmax)) {\n collapseMaxArray(maxArray, dmax, ppadiplus, collapseOpts);\n }\n }\n\n // For efficiency covering monotonic or near-monotonic data,\n // check a few points at both ends first and then sweep\n // through the middle\n var iMax = Math.min(6, len);\n for(i = 0; i < iMax; i++) addItem(i);\n for(i = len - 1; i >= iMax; i--) addItem(i);\n\n return {\n min: minArray,\n max: maxArray,\n opts: opts\n };\n}\n\nfunction collapseMinArray(array, newVal, newPad, opts) {\n collapseArray(array, newVal, newPad, opts, lessOrEqual);\n}\n\nfunction collapseMaxArray(array, newVal, newPad, opts) {\n collapseArray(array, newVal, newPad, opts, greaterOrEqual);\n}\n\n/**\n * collapseArray\n *\n * Takes items from 'array' and compares them to 'newVal', 'newPad'.\n *\n * @param {array} array:\n * current set of min or max extremes\n * @param {number} newVal:\n * new value to compare against\n * @param {number} newPad:\n * pad value associated with 'newVal'\n * @param {object} opts:\n * - tozero {boolean}\n * - extrapad {number}\n * @param {function} atLeastAsExtreme:\n * comparison function, use\n * - lessOrEqual for min 'array' and\n * - greaterOrEqual for max 'array'\n *\n * In practice, 'array' is either\n * - 'extremes[ax._id].min' or\n * - 'extremes[ax._id].max\n * found in traces and layout items that affect autorange.\n *\n * Since we don't yet know the relationship between pixels and values\n * (that's what we're trying to figure out!) AND we don't yet know how\n * many pixels `extrapad` represents (it's going to be 5% of the length,\n * but we don't want to have to redo calc just because length changed)\n * two point must satisfy three criteria simultaneously for one to supersede the other:\n * - at least as extreme a `val`\n * - at least as big a `pad`\n * - an unpadded point cannot supersede a padded point, but any other combination can\n *\n * Then:\n * - If the item supersedes the new point, set includeThis false\n * - If the new pt supersedes the item, delete it from 'array'\n */\nfunction collapseArray(array, newVal, newPad, opts, atLeastAsExtreme) {\n var tozero = opts.tozero;\n var extrapad = opts.extrapad;\n var includeThis = true;\n\n for(var j = 0; j < array.length && includeThis; j++) {\n var v = array[j];\n if(atLeastAsExtreme(v.val, newVal) && v.pad >= newPad && (v.extrapad || !extrapad)) {\n includeThis = false;\n break;\n } else if(atLeastAsExtreme(newVal, v.val) && v.pad <= newPad && (extrapad || !v.extrapad)) {\n array.splice(j, 1);\n j--;\n }\n }\n if(includeThis) {\n var clipAtZero = (tozero && newVal === 0);\n array.push({\n val: newVal,\n pad: clipAtZero ? 0 : newPad,\n extrapad: clipAtZero ? false : extrapad\n });\n }\n}\n\n// In order to stop overflow errors, don't consider points\n// too close to the limits of js floating point\nfunction goodNumber(v) {\n return isNumeric(v) && Math.abs(v) < FP_SAFE;\n}\n\nfunction lessOrEqual(v0, v1) { return v0 <= v1; }\nfunction greaterOrEqual(v0, v1) { return v0 >= v1; }\n\nfunction applyAutorangeMinOptions(v, ax) {\n var autorangeoptions = ax.autorangeoptions;\n if(\n autorangeoptions &&\n autorangeoptions.minallowed !== undefined &&\n hasValidMinAndMax(ax, autorangeoptions.minallowed, autorangeoptions.maxallowed)\n ) {\n return autorangeoptions.minallowed;\n }\n\n if(\n autorangeoptions &&\n autorangeoptions.clipmin !== undefined &&\n hasValidMinAndMax(ax, autorangeoptions.clipmin, autorangeoptions.clipmax)\n ) {\n return Math.max(v, ax.d2l(autorangeoptions.clipmin));\n }\n return v;\n}\n\nfunction applyAutorangeMaxOptions(v, ax) {\n var autorangeoptions = ax.autorangeoptions;\n\n if(\n autorangeoptions &&\n autorangeoptions.maxallowed !== undefined &&\n hasValidMinAndMax(ax, autorangeoptions.minallowed, autorangeoptions.maxallowed)\n ) {\n return autorangeoptions.maxallowed;\n }\n\n if(\n autorangeoptions &&\n autorangeoptions.clipmax !== undefined &&\n hasValidMinAndMax(ax, autorangeoptions.clipmin, autorangeoptions.clipmax)\n ) {\n return Math.min(v, ax.d2l(autorangeoptions.clipmax));\n }\n\n return v;\n}\n\nfunction hasValidMinAndMax(ax, min, max) {\n // in case both min and max are defined, ensure min < max\n if(\n min !== undefined &&\n max !== undefined\n ) {\n min = ax.d2l(min);\n max = ax.d2l(max);\n return min < max;\n }\n return true;\n}\n\n// this function should be (and is) called before reversing the range\n// so range[0] is the minimum and range[1] is the maximum\nfunction applyAutorangeOptions(range, ax) {\n if(!ax || !ax.autorangeoptions) return range;\n\n var min = range[0];\n var max = range[1];\n\n var include = ax.autorangeoptions.include;\n if(include !== undefined) {\n var lMin = ax.d2l(min);\n var lMax = ax.d2l(max);\n\n if(!Lib.isArrayOrTypedArray(include)) include = [include];\n for(var i = 0; i < include.length; i++) {\n var v = ax.d2l(include[i]);\n if(lMin >= v) {\n lMin = v;\n min = v;\n }\n if(lMax <= v) {\n lMax = v;\n max = v;\n }\n }\n }\n\n min = applyAutorangeMinOptions(min, ax);\n max = applyAutorangeMaxOptions(max, ax);\n\n return [min, max];\n}\n","'use strict';\n\nmodule.exports = function handleAutorangeOptionsDefaults(coerce, autorange, range) {\n var minRange, maxRange;\n if(range) {\n var isReversed = (\n autorange === 'reversed' ||\n autorange === 'min reversed' ||\n autorange === 'max reversed'\n );\n\n minRange = range[isReversed ? 1 : 0];\n maxRange = range[isReversed ? 0 : 1];\n }\n\n var minallowed = coerce('autorangeoptions.minallowed', maxRange === null ? minRange : undefined);\n var maxallowed = coerce('autorangeoptions.maxallowed', minRange === null ? maxRange : undefined);\n\n if(minallowed === undefined) coerce('autorangeoptions.clipmin');\n if(maxallowed === undefined) coerce('autorangeoptions.clipmax');\n\n coerce('autorangeoptions.include');\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar isNumeric = require('fast-isnumeric');\nvar Plots = require('../../plots/plots');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar Titles = require('../../components/titles');\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\n\nvar axAttrs = require('./layout_attributes');\nvar cleanTicks = require('./clean_ticks');\n\nvar constants = require('../../constants/numerical');\nvar ONEMAXYEAR = constants.ONEMAXYEAR;\nvar ONEAVGYEAR = constants.ONEAVGYEAR;\nvar ONEMINYEAR = constants.ONEMINYEAR;\nvar ONEMAXQUARTER = constants.ONEMAXQUARTER;\nvar ONEAVGQUARTER = constants.ONEAVGQUARTER;\nvar ONEMINQUARTER = constants.ONEMINQUARTER;\nvar ONEMAXMONTH = constants.ONEMAXMONTH;\nvar ONEAVGMONTH = constants.ONEAVGMONTH;\nvar ONEMINMONTH = constants.ONEMINMONTH;\nvar ONEWEEK = constants.ONEWEEK;\nvar ONEDAY = constants.ONEDAY;\nvar HALFDAY = ONEDAY / 2;\nvar ONEHOUR = constants.ONEHOUR;\nvar ONEMIN = constants.ONEMIN;\nvar ONESEC = constants.ONESEC;\nvar ONEMILLI = constants.ONEMILLI;\nvar ONEMICROSEC = constants.ONEMICROSEC;\nvar MINUS_SIGN = constants.MINUS_SIGN;\nvar BADNUM = constants.BADNUM;\n\nvar ZERO_PATH = { K: 'zeroline' };\nvar GRID_PATH = { K: 'gridline', L: 'path' };\nvar MINORGRID_PATH = { K: 'minor-gridline', L: 'path' };\nvar TICK_PATH = { K: 'tick', L: 'path' };\nvar TICK_TEXT = { K: 'tick', L: 'text' };\nvar MARGIN_MAPPING = {\n width: ['x', 'r', 'l', 'xl', 'xr'],\n height: ['y', 't', 'b', 'yt', 'yb'],\n right: ['r', 'xr'],\n left: ['l', 'xl'],\n top: ['t', 'yt'],\n bottom: ['b', 'yb']\n};\n\nvar alignmentConstants = require('../../constants/alignment');\nvar MID_SHIFT = alignmentConstants.MID_SHIFT;\nvar CAP_SHIFT = alignmentConstants.CAP_SHIFT;\nvar LINE_SPACING = alignmentConstants.LINE_SPACING;\nvar OPPOSITE_SIDE = alignmentConstants.OPPOSITE_SIDE;\n\nvar TEXTPAD = 3;\n\nvar axes = module.exports = {};\n\naxes.setConvert = require('./set_convert');\nvar autoType = require('./axis_autotype');\n\nvar axisIds = require('./axis_ids');\nvar idSort = axisIds.idSort;\nvar isLinked = axisIds.isLinked;\n\n// tight coupling to chart studio\naxes.id2name = axisIds.id2name;\naxes.name2id = axisIds.name2id;\naxes.cleanId = axisIds.cleanId;\naxes.list = axisIds.list;\naxes.listIds = axisIds.listIds;\naxes.getFromId = axisIds.getFromId;\naxes.getFromTrace = axisIds.getFromTrace;\n\nvar autorange = require('./autorange');\naxes.getAutoRange = autorange.getAutoRange;\naxes.findExtremes = autorange.findExtremes;\n\nvar epsilon = 0.0001;\nfunction expandRange(range) {\n var delta = (range[1] - range[0]) * epsilon;\n return [\n range[0] - delta,\n range[1] + delta\n ];\n}\n\n/*\n * find the list of possible axes to reference with an xref or yref attribute\n * and coerce it to that list\n *\n * attr: the attribute we're generating a reference for. Should end in 'x' or 'y'\n * but can be prefixed, like 'ax' for annotation's arrow x\n * dflt: the default to coerce to, or blank to use the first axis (falling back on\n * extraOption if there is no axis)\n * extraOption: aside from existing axes with this letter, what non-axis value is allowed?\n * Only required if it's different from `dflt`\n */\naxes.coerceRef = function(containerIn, containerOut, gd, attr, dflt, extraOption) {\n var axLetter = attr.charAt(attr.length - 1);\n var axlist = gd._fullLayout._subplots[axLetter + 'axis'];\n var refAttr = attr + 'ref';\n var attrDef = {};\n\n if(!dflt) dflt = axlist[0] || (typeof extraOption === 'string' ? extraOption : extraOption[0]);\n if(!extraOption) extraOption = dflt;\n axlist = axlist.concat(axlist.map(function(x) { return x + ' domain'; }));\n\n // data-ref annotations are not supported in gl2d yet\n\n attrDef[refAttr] = {\n valType: 'enumerated',\n values: axlist.concat(extraOption ?\n (typeof extraOption === 'string' ? [extraOption] : extraOption) :\n []),\n dflt: dflt\n };\n\n // xref, yref\n return Lib.coerce(containerIn, containerOut, attrDef, refAttr);\n};\n\n/*\n * Get the type of an axis reference. This can be 'range', 'domain', or 'paper'.\n * This assumes ar is a valid axis reference and returns 'range' if it doesn't\n * match the patterns for 'paper' or 'domain'.\n *\n * ar: the axis reference string\n *\n */\naxes.getRefType = function(ar) {\n if(ar === undefined) { return ar; }\n if(ar === 'paper') { return 'paper'; }\n if(ar === 'pixel') { return 'pixel'; }\n if(/( domain)$/.test(ar)) { return 'domain'; } else { return 'range'; }\n};\n\n/*\n * coerce position attributes (range-type) that can be either on axes or absolute\n * (paper or pixel) referenced. The biggest complication here is that we don't know\n * before looking at the axis whether the value must be a number or not (it may be\n * a date string), so we can't use the regular valType='number' machinery\n *\n * axRef (string): the axis this position is referenced to, or:\n * paper: fraction of the plot area\n * pixel: pixels relative to some starting position\n * attr (string): the attribute in containerOut we are coercing\n * dflt (number): the default position, as a fraction or pixels. If the attribute\n * is to be axis-referenced, this will be converted to an axis data value\n *\n * Also cleans the values, since the attribute definition itself has to say\n * valType: 'any' to handle date axes. This allows us to accept:\n * - for category axes: category names, and convert them here into serial numbers.\n * Note that this will NOT work for axis range endpoints, because we don't know\n * the category list yet (it's set by ax.makeCalcdata during calc)\n * but it works for component (note, shape, images) positions.\n * - for date axes: JS Dates or milliseconds, and convert to date strings\n * - for other types: coerce them to numbers\n */\naxes.coercePosition = function(containerOut, gd, coerce, axRef, attr, dflt) {\n var cleanPos, pos;\n var axRefType = axes.getRefType(axRef);\n if(axRefType !== 'range') {\n cleanPos = Lib.ensureNumber;\n pos = coerce(attr, dflt);\n } else {\n var ax = axes.getFromId(gd, axRef);\n dflt = ax.fraction2r(dflt);\n pos = coerce(attr, dflt);\n cleanPos = ax.cleanPos;\n }\n containerOut[attr] = cleanPos(pos);\n};\n\naxes.cleanPosition = function(pos, gd, axRef) {\n var cleanPos = (axRef === 'paper' || axRef === 'pixel') ?\n Lib.ensureNumber :\n axes.getFromId(gd, axRef).cleanPos;\n\n return cleanPos(pos);\n};\n\naxes.redrawComponents = function(gd, axIds) {\n axIds = axIds ? axIds : axes.listIds(gd);\n\n var fullLayout = gd._fullLayout;\n\n function _redrawOneComp(moduleName, methodName, stashName, shortCircuit) {\n var method = Registry.getComponentMethod(moduleName, methodName);\n var stash = {};\n\n for(var i = 0; i < axIds.length; i++) {\n var ax = fullLayout[axes.id2name(axIds[i])];\n var indices = ax[stashName];\n\n for(var j = 0; j < indices.length; j++) {\n var ind = indices[j];\n\n if(!stash[ind]) {\n method(gd, ind);\n stash[ind] = 1;\n // once is enough for images (which doesn't use the `i` arg anyway)\n if(shortCircuit) return;\n }\n }\n }\n }\n\n // annotations and shapes 'draw' method is slow,\n // use the finer-grained 'drawOne' method instead\n _redrawOneComp('annotations', 'drawOne', '_annIndices');\n _redrawOneComp('shapes', 'drawOne', '_shapeIndices');\n _redrawOneComp('images', 'draw', '_imgIndices', true);\n _redrawOneComp('selections', 'drawOne', '_selectionIndices');\n};\n\nvar getDataConversions = axes.getDataConversions = function(gd, trace, target, targetArray) {\n var ax;\n\n // If target points to an axis, use the type we already have for that\n // axis to find the data type. Otherwise use the values to autotype.\n var d2cTarget = (target === 'x' || target === 'y' || target === 'z') ?\n target :\n targetArray;\n\n // In the case of an array target, make a mock data array\n // and call supplyDefaults to the data type and\n // setup the data-to-calc method.\n if(Lib.isArrayOrTypedArray(d2cTarget)) {\n ax = {\n type: autoType(targetArray, undefined, {\n autotypenumbers: gd._fullLayout.autotypenumbers\n }),\n _categories: []\n };\n axes.setConvert(ax);\n\n // build up ax._categories (usually done during ax.makeCalcdata()\n if(ax.type === 'category') {\n for(var i = 0; i < targetArray.length; i++) {\n ax.d2c(targetArray[i]);\n }\n }\n // TODO what to do for transforms?\n } else {\n ax = axes.getFromTrace(gd, trace, d2cTarget);\n }\n\n // if 'target' has corresponding axis\n // -> use setConvert method\n if(ax) return {d2c: ax.d2c, c2d: ax.c2d};\n\n // special case for 'ids'\n // -> cast to String\n if(d2cTarget === 'ids') return {d2c: toString, c2d: toString};\n\n // otherwise (e.g. numeric-array of 'marker.color' or 'marker.size')\n // -> cast to Number\n\n return {d2c: toNum, c2d: toNum};\n};\n\nfunction toNum(v) { return +v; }\nfunction toString(v) { return String(v); }\n\naxes.getDataToCoordFunc = function(gd, trace, target, targetArray) {\n return getDataConversions(gd, trace, target, targetArray).d2c;\n};\n\n// get counteraxis letter for this axis (name or id)\n// this can also be used as the id for default counter axis\naxes.counterLetter = function(id) {\n var axLetter = id.charAt(0);\n if(axLetter === 'x') return 'y';\n if(axLetter === 'y') return 'x';\n};\n\n// incorporate a new minimum difference and first tick into\n// forced\n// note that _forceTick0 is linearized, so needs to be turned into\n// a range value for setting tick0\naxes.minDtick = function(ax, newDiff, newFirst, allow) {\n // doesn't make sense to do forced min dTick on log or category axes,\n // and the plot itself may decide to cancel (ie non-grouped bars)\n if(['log', 'category', 'multicategory'].indexOf(ax.type) !== -1 || !allow) {\n ax._minDtick = 0;\n } else if(ax._minDtick === undefined) {\n // undefined means there's nothing there yet\n\n ax._minDtick = newDiff;\n ax._forceTick0 = newFirst;\n } else if(ax._minDtick) {\n if((ax._minDtick / newDiff + 1e-6) % 1 < 2e-6 &&\n // existing minDtick is an integer multiple of newDiff\n // (within rounding err)\n // and forceTick0 can be shifted to newFirst\n\n (((newFirst - ax._forceTick0) / newDiff % 1) +\n 1.000001) % 1 < 2e-6) {\n ax._minDtick = newDiff;\n ax._forceTick0 = newFirst;\n } else if((newDiff / ax._minDtick + 1e-6) % 1 > 2e-6 ||\n // if the converse is true (newDiff is a multiple of minDtick and\n // newFirst can be shifted to forceTick0) then do nothing - same\n // forcing stands. Otherwise, cancel forced minimum\n\n (((newFirst - ax._forceTick0) / ax._minDtick % 1) +\n 1.000001) % 1 > 2e-6) {\n ax._minDtick = 0;\n }\n }\n};\n\n// save a copy of the initial axis ranges in fullLayout\n// use them in mode bar and dblclick events\naxes.saveRangeInitial = function(gd, overwrite) {\n var axList = axes.list(gd, '', true);\n var hasOneAxisChanged = false;\n\n for(var i = 0; i < axList.length; i++) {\n var ax = axList[i];\n var isNew =\n ax._rangeInitial0 === undefined &&\n ax._rangeInitial1 === undefined;\n\n var hasChanged = isNew || (\n ax.range[0] !== ax._rangeInitial0 ||\n ax.range[1] !== ax._rangeInitial1\n );\n\n var autorange = ax.autorange;\n if((isNew && autorange !== true) || (overwrite && hasChanged)) {\n ax._rangeInitial0 = (autorange === 'min' || autorange === 'max reversed') ? undefined : ax.range[0];\n ax._rangeInitial1 = (autorange === 'max' || autorange === 'min reversed') ? undefined : ax.range[1];\n ax._autorangeInitial = autorange;\n hasOneAxisChanged = true;\n }\n }\n\n return hasOneAxisChanged;\n};\n\n// save a copy of the initial spike visibility\naxes.saveShowSpikeInitial = function(gd, overwrite) {\n var axList = axes.list(gd, '', true);\n var hasOneAxisChanged = false;\n var allSpikesEnabled = 'on';\n\n for(var i = 0; i < axList.length; i++) {\n var ax = axList[i];\n var isNew = (ax._showSpikeInitial === undefined);\n var hasChanged = isNew || !(ax.showspikes === ax._showspikes);\n\n if(isNew || (overwrite && hasChanged)) {\n ax._showSpikeInitial = ax.showspikes;\n hasOneAxisChanged = true;\n }\n\n if(allSpikesEnabled === 'on' && !ax.showspikes) {\n allSpikesEnabled = 'off';\n }\n }\n gd._fullLayout._cartesianSpikesEnabled = allSpikesEnabled;\n return hasOneAxisChanged;\n};\n\naxes.autoBin = function(data, ax, nbins, is2d, calendar, size) {\n var dataMin = Lib.aggNums(Math.min, null, data);\n var dataMax = Lib.aggNums(Math.max, null, data);\n\n if(ax.type === 'category' || ax.type === 'multicategory') {\n return {\n start: dataMin - 0.5,\n end: dataMax + 0.5,\n size: Math.max(1, Math.round(size) || 1),\n _dataSpan: dataMax - dataMin,\n };\n }\n\n if(!calendar) calendar = ax.calendar;\n\n // piggyback off tick code to make \"nice\" bin sizes and edges\n var dummyAx;\n if(ax.type === 'log') {\n dummyAx = {\n type: 'linear',\n range: [dataMin, dataMax]\n };\n } else {\n dummyAx = {\n type: ax.type,\n range: Lib.simpleMap([dataMin, dataMax], ax.c2r, 0, calendar),\n calendar: calendar\n };\n }\n axes.setConvert(dummyAx);\n\n size = size && cleanTicks.dtick(size, dummyAx.type);\n\n if(size) {\n dummyAx.dtick = size;\n dummyAx.tick0 = cleanTicks.tick0(undefined, dummyAx.type, calendar);\n } else {\n var size0;\n if(nbins) size0 = ((dataMax - dataMin) / nbins);\n else {\n // totally auto: scale off std deviation so the highest bin is\n // somewhat taller than the total number of bins, but don't let\n // the size get smaller than the 'nice' rounded down minimum\n // difference between values\n var distinctData = Lib.distinctVals(data);\n var msexp = Math.pow(10, Math.floor(\n Math.log(distinctData.minDiff) / Math.LN10));\n var minSize = msexp * Lib.roundUp(\n distinctData.minDiff / msexp, [0.9, 1.9, 4.9, 9.9], true);\n size0 = Math.max(minSize, 2 * Lib.stdev(data) /\n Math.pow(data.length, is2d ? 0.25 : 0.4));\n\n // fallback if ax.d2c output BADNUMs\n // e.g. when user try to plot categorical bins\n // on a layout.xaxis.type: 'linear'\n if(!isNumeric(size0)) size0 = 1;\n }\n\n axes.autoTicks(dummyAx, size0);\n }\n\n var finalSize = dummyAx.dtick;\n var binStart = axes.tickIncrement(\n axes.tickFirst(dummyAx), finalSize, 'reverse', calendar);\n var binEnd, bincount;\n\n // check for too many data points right at the edges of bins\n // (>50% within 1% of bin edges) or all data points integral\n // and offset the bins accordingly\n if(typeof finalSize === 'number') {\n binStart = autoShiftNumericBins(binStart, data, dummyAx, dataMin, dataMax);\n\n bincount = 1 + Math.floor((dataMax - binStart) / finalSize);\n binEnd = binStart + bincount * finalSize;\n } else {\n // month ticks - should be the only nonlinear kind we have at this point.\n // dtick (as supplied by axes.autoTick) only has nonlinear values on\n // date and log axes, but even if you display a histogram on a log axis\n // we bin it on a linear axis (which one could argue against, but that's\n // a separate issue)\n if(dummyAx.dtick.charAt(0) === 'M') {\n binStart = autoShiftMonthBins(binStart, data, finalSize, dataMin, calendar);\n }\n\n // calculate the endpoint for nonlinear ticks - you have to\n // just increment until you're done\n binEnd = binStart;\n bincount = 0;\n while(binEnd <= dataMax) {\n binEnd = axes.tickIncrement(binEnd, finalSize, false, calendar);\n bincount++;\n }\n }\n\n return {\n start: ax.c2r(binStart, 0, calendar),\n end: ax.c2r(binEnd, 0, calendar),\n size: finalSize,\n _dataSpan: dataMax - dataMin\n };\n};\n\n\nfunction autoShiftNumericBins(binStart, data, ax, dataMin, dataMax) {\n var edgecount = 0;\n var midcount = 0;\n var intcount = 0;\n var blankCount = 0;\n\n function nearEdge(v) {\n // is a value within 1% of a bin edge?\n return (1 + (v - binStart) * 100 / ax.dtick) % 100 < 2;\n }\n\n for(var i = 0; i < data.length; i++) {\n if(data[i] % 1 === 0) intcount++;\n else if(!isNumeric(data[i])) blankCount++;\n\n if(nearEdge(data[i])) edgecount++;\n if(nearEdge(data[i] + ax.dtick / 2)) midcount++;\n }\n var dataCount = data.length - blankCount;\n\n if(intcount === dataCount && ax.type !== 'date') {\n if(ax.dtick < 1) {\n // all integers: if bin size is <1, it's because\n // that was specifically requested (large nbins)\n // so respect that... but center the bins containing\n // integers on those integers\n\n binStart = dataMin - 0.5 * ax.dtick;\n } else {\n // otherwise start half an integer down regardless of\n // the bin size, just enough to clear up endpoint\n // ambiguity about which integers are in which bins.\n\n binStart -= 0.5;\n if(binStart + ax.dtick < dataMin) binStart += ax.dtick;\n }\n } else if(midcount < dataCount * 0.1) {\n if(edgecount > dataCount * 0.3 ||\n nearEdge(dataMin) || nearEdge(dataMax)) {\n // lots of points at the edge, not many in the middle\n // shift half a bin\n var binshift = ax.dtick / 2;\n binStart += (binStart + binshift < dataMin) ? binshift : -binshift;\n }\n }\n return binStart;\n}\n\n\nfunction autoShiftMonthBins(binStart, data, dtick, dataMin, calendar) {\n var stats = Lib.findExactDates(data, calendar);\n // number of data points that needs to be an exact value\n // to shift that increment to (near) the bin center\n var threshold = 0.8;\n\n if(stats.exactDays > threshold) {\n var numMonths = Number(dtick.substr(1));\n\n if((stats.exactYears > threshold) && (numMonths % 12 === 0)) {\n // The exact middle of a non-leap-year is 1.5 days into July\n // so if we start the bins here, all but leap years will\n // get hover-labeled as exact years.\n binStart = axes.tickIncrement(binStart, 'M6', 'reverse') + ONEDAY * 1.5;\n } else if(stats.exactMonths > threshold) {\n // Months are not as clean, but if we shift half the *longest*\n // month (31/2 days) then 31-day months will get labeled exactly\n // and shorter months will get labeled with the correct month\n // but shifted 12-36 hours into it.\n binStart = axes.tickIncrement(binStart, 'M1', 'reverse') + ONEDAY * 15.5;\n } else {\n // Shifting half a day is exact, but since these are month bins it\n // will always give a somewhat odd-looking label, until we do something\n // smarter like showing the bin boundaries (or the bounds of the actual\n // data in each bin)\n binStart -= HALFDAY;\n }\n var nextBinStart = axes.tickIncrement(binStart, dtick);\n\n if(nextBinStart <= dataMin) return nextBinStart;\n }\n return binStart;\n}\n\n// ----------------------------------------------------\n// Ticks and grids\n// ----------------------------------------------------\n\n// ensure we have minor tick0 and dtick calculated\naxes.prepMinorTicks = function(mockAx, ax, opts) {\n if(!ax.minor.dtick) {\n delete mockAx.dtick;\n var hasMajor = ax.dtick && isNumeric(ax._tmin);\n var mockMinorRange;\n if(hasMajor) {\n var tick2 = axes.tickIncrement(ax._tmin, ax.dtick, true);\n // mock range a tiny bit smaller than one major tick interval\n mockMinorRange = [ax._tmin, tick2 * 0.99 + ax._tmin * 0.01];\n } else {\n var rl = Lib.simpleMap(ax.range, ax.r2l);\n // If we don't have a major dtick, the concept of minor ticks is a little\n // ambiguous - just take a stab and say minor.nticks should span 1/5 the axis\n mockMinorRange = [rl[0], 0.8 * rl[0] + 0.2 * rl[1]];\n }\n mockAx.range = Lib.simpleMap(mockMinorRange, ax.l2r);\n mockAx._isMinor = true;\n\n axes.prepTicks(mockAx, opts);\n\n if(hasMajor) {\n var numericMajor = isNumeric(ax.dtick);\n var numericMinor = isNumeric(mockAx.dtick);\n var majorNum = numericMajor ? ax.dtick : +ax.dtick.substring(1);\n var minorNum = numericMinor ? mockAx.dtick : +mockAx.dtick.substring(1);\n if(numericMajor && numericMinor) {\n if(!isMultiple(majorNum, minorNum)) {\n // give up on minor ticks - outside the below exceptions,\n // this can only happen if minor.nticks is smaller than two jumps\n // in the auto-tick scale and the first jump is not an even multiple\n // (5 -> 2 or for dates 3 ->2, 15 -> 10 etc) or if you provided\n // an explicit dtick, in which case it's fine to give up,\n // you can provide an explicit minor.dtick.\n if((majorNum === 2 * ONEWEEK) && (minorNum === 3 * ONEDAY)) {\n mockAx.dtick = ONEWEEK;\n } else if(majorNum === ONEWEEK && !(ax._input.minor || {}).nticks) {\n // minor.nticks defaults to 5, but in this one case we want 7,\n // so the minor ticks show on all days of the week\n mockAx.dtick = ONEDAY;\n } else if(isClose(majorNum / minorNum, 2.5)) {\n // 5*10^n -> 2*10^n and you've set nticks < 5\n // quarters are pretty common, we don't do this by default as it\n // would add an extra digit to display, but minor has no labels\n mockAx.dtick = majorNum / 2;\n } else {\n mockAx.dtick = majorNum;\n }\n } else if(majorNum === 2 * ONEWEEK && minorNum === 2 * ONEDAY) {\n // this is a weird one: we don't want to automatically choose\n // 2-day minor ticks for 2-week major, even though it IS an even multiple,\n // because people would expect to see the weeks clearly\n mockAx.dtick = ONEWEEK;\n }\n } else if(String(ax.dtick).charAt(0) === 'M') {\n if(numericMinor) {\n mockAx.dtick = 'M1';\n } else {\n if(!isMultiple(majorNum, minorNum)) {\n // unless you provided an explicit ax.dtick (in which case\n // it's OK for us to give up, you can provide an explicit\n // minor.dtick too), this can only happen with:\n // minor.nticks < 3 and dtick === M3, or\n // minor.nticks < 5 and dtick === 5 * 10^n years\n // so in all cases we just give up.\n mockAx.dtick = ax.dtick;\n } else if((majorNum >= 12) && (minorNum === 2)) {\n // another special carve-out: for year major ticks, don't show\n // 2-month minor ticks, bump to quarters\n mockAx.dtick = 'M3';\n }\n }\n } else if(String(mockAx.dtick).charAt(0) === 'L') {\n if(String(ax.dtick).charAt(0) === 'L') {\n if(!isMultiple(majorNum, minorNum)) {\n mockAx.dtick = isClose(majorNum / minorNum, 2.5) ? (ax.dtick / 2) : ax.dtick;\n }\n } else {\n mockAx.dtick = 'D1';\n }\n } else if(mockAx.dtick === 'D2' && +ax.dtick > 1) {\n // the D2 log axis tick spacing is confusing for unlabeled minor ticks if\n // the major dtick is more than one order of magnitude.\n mockAx.dtick = 1;\n }\n }\n // put back the original range, to use to find the full set of minor ticks\n mockAx.range = ax.range;\n }\n if(ax.minor._tick0Init === undefined) {\n // ensure identical tick0\n mockAx.tick0 = ax.tick0;\n }\n};\n\nfunction isMultiple(bigger, smaller) {\n return Math.abs((bigger / smaller + 0.5) % 1 - 0.5) < 0.001;\n}\n\nfunction isClose(a, b) {\n return Math.abs((a / b) - 1) < 0.001;\n}\n\n// ensure we have tick0, dtick, and tick rounding calculated\naxes.prepTicks = function(ax, opts) {\n var rng = Lib.simpleMap(ax.range, ax.r2l, undefined, undefined, opts);\n\n // calculate max number of (auto) ticks to display based on plot size\n if(ax.tickmode === 'auto' || !ax.dtick) {\n var nt = ax.nticks;\n var minPx;\n\n if(!nt) {\n if(ax.type === 'category' || ax.type === 'multicategory') {\n minPx = ax.tickfont ? Lib.bigFont(ax.tickfont.size || 12) : 15;\n nt = ax._length / minPx;\n } else {\n minPx = ax._id.charAt(0) === 'y' ? 40 : 80;\n nt = Lib.constrain(ax._length / minPx, 4, 9) + 1;\n }\n\n // radial axes span half their domain,\n // multiply nticks value by two to get correct number of auto ticks.\n if(ax._name === 'radialaxis') nt *= 2;\n }\n\n if(!(ax.minor && ax.minor.tickmode !== 'array')) {\n // add a couple of extra digits for filling in ticks when we\n // have explicit tickvals without tick text\n if(ax.tickmode === 'array') nt *= 100;\n }\n\n ax._roughDTick = Math.abs(rng[1] - rng[0]) / nt;\n axes.autoTicks(ax, ax._roughDTick);\n\n // check for a forced minimum dtick\n if(ax._minDtick > 0 && ax.dtick < ax._minDtick * 2) {\n ax.dtick = ax._minDtick;\n ax.tick0 = ax.l2r(ax._forceTick0);\n }\n }\n\n if(ax.ticklabelmode === 'period') {\n adjustPeriodDelta(ax);\n }\n\n // check for missing tick0\n if(!ax.tick0) {\n ax.tick0 = (ax.type === 'date') ? '2000-01-01' : 0;\n }\n\n // ensure we don't try to make ticks below our minimum precision\n // see https://github.com/plotly/plotly.js/issues/2892\n if(ax.type === 'date' && ax.dtick < 0.1) ax.dtick = 0.1;\n\n // now figure out rounding of tick values\n autoTickRound(ax);\n};\n\nfunction nMonths(dtick) {\n return +(dtick.substring(1));\n}\n\nfunction adjustPeriodDelta(ax) { // adjusts ax.dtick and sets ax._definedDelta\n var definedDelta;\n\n function mDate() {\n return !(\n isNumeric(ax.dtick) ||\n ax.dtick.charAt(0) !== 'M'\n );\n }\n var isMDate = mDate();\n var tickformat = axes.getTickFormat(ax);\n if(tickformat) {\n var noDtick = ax._dtickInit !== ax.dtick;\n if(\n !(/%[fLQsSMX]/.test(tickformat))\n // %f: microseconds as a decimal number [000000, 999999]\n // %L: milliseconds as a decimal number [000, 999]\n // %Q: milliseconds since UNIX epoch\n // %s: seconds since UNIX epoch\n // %S: second as a decimal number [00,61]\n // %M: minute as a decimal number [00,59]\n // %X: the locale’s time, such as %-I:%M:%S %p\n ) {\n if(\n /%[HI]/.test(tickformat)\n // %H: hour (24-hour clock) as a decimal number [00,23]\n // %I: hour (12-hour clock) as a decimal number [01,12]\n ) {\n definedDelta = ONEHOUR;\n if(noDtick && !isMDate && ax.dtick < ONEHOUR) ax.dtick = ONEHOUR;\n } else if(\n /%p/.test(tickformat) // %p: either AM or PM\n ) {\n definedDelta = HALFDAY;\n if(noDtick && !isMDate && ax.dtick < HALFDAY) ax.dtick = HALFDAY;\n } else if(\n /%[Aadejuwx]/.test(tickformat)\n // %A: full weekday name\n // %a: abbreviated weekday name\n // %d: zero-padded day of the month as a decimal number [01,31]\n // %e: space-padded day of the month as a decimal number [ 1,31]\n // %j: day of the year as a decimal number [001,366]\n // %u: Monday-based (ISO 8601) weekday as a decimal number [1,7]\n // %w: Sunday-based weekday as a decimal number [0,6]\n // %x: the locale’s date, such as %-m/%-d/%Y\n ) {\n definedDelta = ONEDAY;\n if(noDtick && !isMDate && ax.dtick < ONEDAY) ax.dtick = ONEDAY;\n } else if(\n /%[UVW]/.test(tickformat)\n // %U: Sunday-based week of the year as a decimal number [00,53]\n // %V: ISO 8601 week of the year as a decimal number [01, 53]\n // %W: Monday-based week of the year as a decimal number [00,53]\n ) {\n definedDelta = ONEWEEK;\n if(noDtick && !isMDate && ax.dtick < ONEWEEK) ax.dtick = ONEWEEK;\n } else if(\n /%[Bbm]/.test(tickformat)\n // %B: full month name\n // %b: abbreviated month name\n // %m: month as a decimal number [01,12]\n ) {\n definedDelta = ONEAVGMONTH;\n if(noDtick && (\n isMDate ? nMonths(ax.dtick) < 1 : ax.dtick < ONEMINMONTH)\n ) ax.dtick = 'M1';\n } else if(\n /%[q]/.test(tickformat)\n // %q: quarter of the year as a decimal number [1,4]\n ) {\n definedDelta = ONEAVGQUARTER;\n if(noDtick && (\n isMDate ? nMonths(ax.dtick) < 3 : ax.dtick < ONEMINQUARTER)\n ) ax.dtick = 'M3';\n } else if(\n /%[Yy]/.test(tickformat)\n // %Y: year with century as a decimal number, such as 1999\n // %y: year without century as a decimal number [00,99]\n ) {\n definedDelta = ONEAVGYEAR;\n if(noDtick && (\n isMDate ? nMonths(ax.dtick) < 12 : ax.dtick < ONEMINYEAR)\n ) ax.dtick = 'M12';\n }\n }\n }\n\n isMDate = mDate();\n if(isMDate && ax.tick0 === ax._dowTick0) {\n // discard Sunday/Monday tweaks\n ax.tick0 = ax._rawTick0;\n }\n\n ax._definedDelta = definedDelta;\n}\n\nfunction positionPeriodTicks(tickVals, ax, definedDelta) {\n for(var i = 0; i < tickVals.length; i++) {\n var v = tickVals[i].value;\n\n var a = i;\n var b = i + 1;\n if(i < tickVals.length - 1) {\n a = i;\n b = i + 1;\n } else if(i > 0) {\n a = i - 1;\n b = i;\n } else {\n a = i;\n b = i;\n }\n\n var A = tickVals[a].value;\n var B = tickVals[b].value;\n var actualDelta = Math.abs(B - A);\n var delta = definedDelta || actualDelta;\n var periodLength = 0;\n\n if(delta >= ONEMINYEAR) {\n if(actualDelta >= ONEMINYEAR && actualDelta <= ONEMAXYEAR) {\n periodLength = actualDelta;\n } else {\n periodLength = ONEAVGYEAR;\n }\n } else if(definedDelta === ONEAVGQUARTER && delta >= ONEMINQUARTER) {\n if(actualDelta >= ONEMINQUARTER && actualDelta <= ONEMAXQUARTER) {\n periodLength = actualDelta;\n } else {\n periodLength = ONEAVGQUARTER;\n }\n } else if(delta >= ONEMINMONTH) {\n if(actualDelta >= ONEMINMONTH && actualDelta <= ONEMAXMONTH) {\n periodLength = actualDelta;\n } else {\n periodLength = ONEAVGMONTH;\n }\n } else if(definedDelta === ONEWEEK && delta >= ONEWEEK) {\n periodLength = ONEWEEK;\n } else if(delta >= ONEDAY) {\n periodLength = ONEDAY;\n } else if(definedDelta === HALFDAY && delta >= HALFDAY) {\n periodLength = HALFDAY;\n } else if(definedDelta === ONEHOUR && delta >= ONEHOUR) {\n periodLength = ONEHOUR;\n }\n\n var inBetween;\n if(periodLength >= actualDelta) {\n // ensure new label positions remain between ticks\n periodLength = actualDelta;\n inBetween = true;\n }\n\n var endPeriod = v + periodLength;\n if(ax.rangebreaks && periodLength > 0) {\n var nAll = 84; // highly divisible 7 * 12\n var n = 0;\n for(var c = 0; c < nAll; c++) {\n var r = (c + 0.5) / nAll;\n if(ax.maskBreaks(v * (1 - r) + r * endPeriod) !== BADNUM) n++;\n }\n periodLength *= n / nAll;\n\n if(!periodLength) {\n tickVals[i].drop = true;\n }\n\n if(inBetween && actualDelta > ONEWEEK) periodLength = actualDelta; // center monthly & longer periods\n }\n\n if(\n periodLength > 0 || // not instant\n i === 0 // taking care first tick added\n ) {\n tickVals[i].periodX = v + periodLength / 2;\n }\n }\n}\n\n// calculate the ticks: text, values, positioning\n// if ticks are set to automatic, determine the right values (tick0,dtick)\n// in any case, set tickround to # of digits to round tick labels to,\n// or codes to this effect for log and date scales\naxes.calcTicks = function calcTicks(ax, opts) {\n var type = ax.type;\n var calendar = ax.calendar;\n var ticklabelstep = ax.ticklabelstep;\n var isPeriod = ax.ticklabelmode === 'period';\n var isReversed = ax.range[0] > ax.range[1];\n var ticklabelIndex = (!ax.ticklabelindex || Lib.isArrayOrTypedArray(ax.ticklabelindex)) ?\n ax.ticklabelindex : [ax.ticklabelindex];\n var rng = Lib.simpleMap(ax.range, ax.r2l, undefined, undefined, opts);\n var axrev = (rng[1] < rng[0]);\n var minRange = Math.min(rng[0], rng[1]);\n var maxRange = Math.max(rng[0], rng[1]);\n\n var maxTicks = Math.max(1000, ax._length || 0);\n\n var ticksOut = [];\n var minorTicks = [];\n\n var tickVals = [];\n var minorTickVals = [];\n // all ticks for which labels are drawn which is not necessarily the major ticks when\n // `ticklabelindex` is set.\n var allTicklabelVals = [];\n\n var hasMinor = ax.minor && (ax.minor.ticks || ax.minor.showgrid);\n\n // calc major first\n for(var major = 1; major >= (hasMinor ? 0 : 1); major--) {\n var isMinor = !major;\n\n if(major) {\n ax._dtickInit = ax.dtick;\n ax._tick0Init = ax.tick0;\n } else {\n ax.minor._dtickInit = ax.minor.dtick;\n ax.minor._tick0Init = ax.minor.tick0;\n }\n\n var mockAx = major ? ax : Lib.extendFlat({}, ax, ax.minor);\n\n if(isMinor) {\n axes.prepMinorTicks(mockAx, ax, opts);\n } else {\n axes.prepTicks(mockAx, opts);\n }\n\n // now that we've figured out the auto values for formatting\n // in case we're missing some ticktext, we can break out for array ticks\n if(mockAx.tickmode === 'array') {\n if(major) {\n tickVals = [];\n ticksOut = arrayTicks(ax, !isMinor);\n } else {\n minorTickVals = [];\n minorTicks = arrayTicks(ax, !isMinor);\n }\n continue;\n }\n\n // fill tickVals based on overlaying axis\n if(mockAx.tickmode === 'sync') {\n tickVals = [];\n ticksOut = syncTicks(ax);\n continue;\n }\n\n // add a tiny bit so we get ticks which may have rounded out\n var exRng = expandRange(rng);\n var startTick = exRng[0];\n var endTick = exRng[1];\n\n var numDtick = isNumeric(mockAx.dtick);\n var isDLog = (type === 'log') && !(numDtick || mockAx.dtick.charAt(0) === 'L');\n\n // find the first tick\n var x0 = axes.tickFirst(mockAx, opts);\n\n if(major) {\n ax._tmin = x0;\n\n // No visible ticks? Quit.\n // I've only seen this on category axes with all categories off the edge.\n if((x0 < startTick) !== axrev) break;\n\n // return the full set of tick vals\n if(type === 'category' || type === 'multicategory') {\n endTick = (axrev) ? Math.max(-0.5, endTick) :\n Math.min(ax._categories.length - 0.5, endTick);\n }\n }\n\n var prevX = null;\n var x = x0;\n var majorId;\n\n if(major) {\n // ids for ticklabelstep\n var _dTick;\n if(numDtick) {\n _dTick = ax.dtick;\n } else {\n if(type === 'date') {\n if(typeof ax.dtick === 'string' && ax.dtick.charAt(0) === 'M') {\n _dTick = ONEAVGMONTH * ax.dtick.substring(1);\n }\n } else {\n _dTick = ax._roughDTick;\n }\n }\n\n majorId = Math.round((\n ax.r2l(x) -\n ax.r2l(ax.tick0)\n ) / _dTick) - 1;\n }\n\n var dtick = mockAx.dtick;\n\n if(mockAx.rangebreaks && mockAx._tick0Init !== mockAx.tick0) {\n // adjust tick0\n x = moveOutsideBreak(x, ax);\n if(!axrev) {\n x = axes.tickIncrement(x, dtick, !axrev, calendar);\n }\n }\n\n if(major && isPeriod) {\n // add one item to label period before tick0\n x = axes.tickIncrement(x, dtick, !axrev, calendar);\n majorId--;\n }\n\n for(;\n axrev ?\n (x >= endTick) :\n (x <= endTick);\n x = axes.tickIncrement(\n x,\n dtick,\n axrev,\n calendar\n )\n ) {\n if(major) majorId++;\n\n if(mockAx.rangebreaks) {\n if(!axrev) {\n if(x < startTick) continue;\n if(mockAx.maskBreaks(x) === BADNUM && moveOutsideBreak(x, mockAx) >= maxRange) break;\n }\n }\n\n // prevent infinite loops - no more than one tick per pixel,\n // and make sure each value is different from the previous\n if(tickVals.length > maxTicks || x === prevX) break;\n prevX = x;\n\n var obj = { value: x };\n\n if(major) {\n if(isDLog && (x !== (x | 0))) {\n obj.simpleLabel = true;\n }\n\n if(ticklabelstep > 1 && majorId % ticklabelstep) {\n obj.skipLabel = true;\n }\n\n tickVals.push(obj);\n } else {\n obj.minor = true;\n\n minorTickVals.push(obj);\n }\n }\n }\n\n // check if ticklabelIndex makes sense, otherwise ignore it\n if(!minorTickVals || minorTickVals.length < 2) {\n ticklabelIndex = false;\n } else {\n var diff = (minorTickVals[1].value - minorTickVals[0].value) * (isReversed ? -1 : 1);\n if(!periodCompatibleWithTickformat(diff, ax.tickformat)) {\n ticklabelIndex = false;\n }\n }\n // Determine for which ticks to draw labels\n if(!ticklabelIndex) {\n allTicklabelVals = tickVals;\n } else {\n // Collect and sort all major and minor ticks, to find the minor ticks `ticklabelIndex`\n // steps away from each major tick. For those minor ticks we want to draw the label.\n\n var allTickVals = tickVals.concat(minorTickVals);\n if(isPeriod && tickVals.length) {\n // first major tick was just added for period handling\n allTickVals = allTickVals.slice(1);\n }\n\n allTickVals =\n allTickVals\n .sort(function(a, b) { return a.value - b.value; })\n .filter(function(tick, index, self) {\n return index === 0 || tick.value !== self[index - 1].value;\n });\n\n var majorTickIndices =\n allTickVals\n .map(function(item, index) {\n return item.minor === undefined && !item.skipLabel ? index : null;\n })\n .filter(function(index) { return index !== null; });\n\n majorTickIndices.forEach(function(majorIdx) {\n ticklabelIndex.map(function(nextLabelIdx) {\n var minorIdx = majorIdx + nextLabelIdx;\n if(minorIdx >= 0 && minorIdx < allTickVals.length) {\n Lib.pushUnique(allTicklabelVals, allTickVals[minorIdx]);\n }\n });\n });\n }\n\n if(hasMinor) {\n var canOverlap =\n (ax.minor.ticks === 'inside' && ax.ticks === 'outside') ||\n (ax.minor.ticks === 'outside' && ax.ticks === 'inside');\n\n if(!canOverlap) {\n // remove duplicate minors\n\n var majorValues = tickVals.map(function(d) { return d.value; });\n\n var list = [];\n for(var k = 0; k < minorTickVals.length; k++) {\n var T = minorTickVals[k];\n var v = T.value;\n if(majorValues.indexOf(v) !== -1) {\n continue;\n }\n var found = false;\n for(var q = 0; !found && (q < tickVals.length); q++) {\n if(\n // add 10e6 to eliminate problematic digits\n 10e6 + tickVals[q].value ===\n 10e6 + v\n ) {\n found = true;\n }\n }\n if(!found) list.push(T);\n }\n minorTickVals = list;\n }\n }\n\n if(isPeriod) positionPeriodTicks(allTicklabelVals, ax, ax._definedDelta);\n\n var i;\n if(ax.rangebreaks) {\n var flip = ax._id.charAt(0) === 'y';\n\n var fontSize = 1; // one pixel minimum\n if(ax.tickmode === 'auto') {\n fontSize = ax.tickfont ? ax.tickfont.size : 12;\n }\n\n var prevL = NaN;\n for(i = tickVals.length - 1; i > -1; i--) {\n if(tickVals[i].drop) {\n tickVals.splice(i, 1);\n continue;\n }\n\n tickVals[i].value = moveOutsideBreak(tickVals[i].value, ax);\n\n // avoid overlaps\n var l = ax.c2p(tickVals[i].value);\n if(flip ?\n (prevL > l - fontSize) :\n (prevL < l + fontSize)\n ) { // ensure one pixel minimum\n tickVals.splice(axrev ? i + 1 : i, 1);\n } else {\n prevL = l;\n }\n }\n }\n\n // If same angle over a full circle, the last tick vals is a duplicate.\n // TODO must do something similar for angular date axes.\n if(isAngular(ax) && Math.abs(rng[1] - rng[0]) === 360) {\n tickVals.pop();\n }\n\n // save the last tick as well as first, so we can\n // show the exponent only on the last one\n ax._tmax = (tickVals[tickVals.length - 1] || {}).value;\n\n // for showing the rest of a date when the main tick label is only the\n // latter part: ax._prevDateHead holds what we showed most recently.\n // Start with it cleared and mark that we're in calcTicks (ie calculating a\n // whole string of these so we should care what the previous date head was!)\n ax._prevDateHead = '';\n ax._inCalcTicks = true;\n\n var lastVisibleHead;\n var hideLabel = function(tick) {\n tick.text = '';\n ax._prevDateHead = lastVisibleHead;\n };\n\n tickVals = tickVals.concat(minorTickVals);\n\n function setTickLabel(ax, tickVal) {\n var text = axes.tickText(\n ax,\n tickVal.value,\n false, // hover\n tickVal.simpleLabel // noSuffixPrefix\n );\n var p = tickVal.periodX;\n if(p !== undefined) {\n text.periodX = p;\n if(p > maxRange || p < minRange) { // hide label if outside the range\n if(p > maxRange) text.periodX = maxRange;\n if(p < minRange) text.periodX = minRange;\n\n hideLabel(text);\n }\n }\n return text;\n }\n\n var t;\n for(i = 0; i < tickVals.length; i++) {\n var _minor = tickVals[i].minor;\n var _value = tickVals[i].value;\n\n if(_minor) {\n if(ticklabelIndex && allTicklabelVals.indexOf(tickVals[i]) !== -1) {\n t = setTickLabel(ax, tickVals[i]);\n } else {\n t = { x: _value };\n }\n t.minor = true;\n minorTicks.push(t);\n } else {\n lastVisibleHead = ax._prevDateHead;\n t = setTickLabel(ax, tickVals[i]);\n if(tickVals[i].skipLabel ||\n ticklabelIndex && allTicklabelVals.indexOf(tickVals[i]) === -1) {\n hideLabel(t);\n }\n\n ticksOut.push(t);\n }\n }\n ticksOut = ticksOut.concat(minorTicks);\n\n ax._inCalcTicks = false;\n\n if(isPeriod && ticksOut.length) {\n // drop very first tick that we added to handle period\n ticksOut[0].noTick = true;\n }\n\n return ticksOut;\n};\n\nfunction filterRangeBreaks(ax, ticksOut) {\n if(ax.rangebreaks) {\n // remove ticks falling inside rangebreaks\n ticksOut = ticksOut.filter(function(d) {\n return ax.maskBreaks(d.x) !== BADNUM;\n });\n }\n\n return ticksOut;\n}\n\nfunction syncTicks(ax) {\n // get the overlaying axis\n var baseAxis = ax._mainAxis;\n\n var ticksOut = [];\n if(baseAxis._vals) {\n for(var i = 0; i < baseAxis._vals.length; i++) {\n // filter vals with noTick flag\n if(baseAxis._vals[i].noTick) {\n continue;\n }\n\n // get the position of the every tick\n var pos = baseAxis.l2p(baseAxis._vals[i].x);\n\n // get the tick for the current axis based on position\n var vali = ax.p2l(pos);\n var obj = axes.tickText(ax, vali);\n\n // assign minor ticks\n if(baseAxis._vals[i].minor) {\n obj.minor = true;\n obj.text = '';\n }\n\n ticksOut.push(obj);\n }\n }\n\n ticksOut = filterRangeBreaks(ax, ticksOut);\n\n return ticksOut;\n}\n\nfunction arrayTicks(ax, majorOnly) {\n var rng = Lib.simpleMap(ax.range, ax.r2l);\n var exRng = expandRange(rng);\n var tickMin = Math.min(exRng[0], exRng[1]);\n var tickMax = Math.max(exRng[0], exRng[1]);\n\n // make sure showing ticks doesn't accidentally add new categories\n // TODO multicategory, if we allow ticktext / tickvals\n var tickVal2l = ax.type === 'category' ? ax.d2l_noadd : ax.d2l;\n\n // array ticks on log axes always show the full number\n // (if no explicit ticktext overrides it)\n if(ax.type === 'log' && String(ax.dtick).charAt(0) !== 'L') {\n ax.dtick = 'L' + Math.pow(10, Math.floor(Math.min(ax.range[0], ax.range[1])) - 1);\n }\n\n var ticksOut = [];\n for(var isMinor = 0; isMinor <= 1; isMinor++) {\n if((majorOnly !== undefined) && ((majorOnly && isMinor) || (majorOnly === false && !isMinor))) continue;\n if(isMinor && !ax.minor) continue;\n var vals = !isMinor ? ax.tickvals : ax.minor.tickvals;\n var text = !isMinor ? ax.ticktext : [];\n if(!vals) continue;\n\n\n // without a text array, just format the given values as any other ticks\n // except with more precision to the numbers\n if(!Lib.isArrayOrTypedArray(text)) text = [];\n\n for(var i = 0; i < vals.length; i++) {\n var vali = tickVal2l(vals[i]);\n if(vali > tickMin && vali < tickMax) {\n var obj = axes.tickText(ax, vali, false, String(text[i]));\n if(isMinor) {\n obj.minor = true;\n obj.text = '';\n }\n\n ticksOut.push(obj);\n }\n }\n }\n\n ticksOut = filterRangeBreaks(ax, ticksOut);\n\n return ticksOut;\n}\n\nvar roundBase10 = [2, 5, 10];\nvar roundBase24 = [1, 2, 3, 6, 12];\nvar roundBase60 = [1, 2, 5, 10, 15, 30];\n// 2&3 day ticks are weird, but need something btwn 1&7\nvar roundDays = [1, 2, 3, 7, 14];\n// approx. tick positions for log axes, showing all (1) and just 1, 2, 5 (2)\n// these don't have to be exact, just close enough to round to the right value\nvar roundLog1 = [-0.046, 0, 0.301, 0.477, 0.602, 0.699, 0.778, 0.845, 0.903, 0.954, 1];\nvar roundLog2 = [-0.301, 0, 0.301, 0.699, 1];\n// N.B. `thetaunit; 'radians' angular axes must be converted to degrees\nvar roundAngles = [15, 30, 45, 90, 180];\n\nfunction roundDTick(roughDTick, base, roundingSet) {\n return base * Lib.roundUp(roughDTick / base, roundingSet);\n}\n\n// autoTicks: calculate best guess at pleasant ticks for this axis\n// inputs:\n// ax - an axis object\n// roughDTick - rough tick spacing (to be turned into a nice round number)\n// outputs (into ax):\n// tick0: starting point for ticks (not necessarily on the graph)\n// usually 0 for numeric (=10^0=1 for log) or jan 1, 2000 for dates\n// dtick: the actual, nice round tick spacing, usually a little larger than roughDTick\n// if the ticks are spaced linearly (linear scale, categories,\n// log with only full powers, date ticks < month),\n// this will just be a number\n// months: M#\n// years: M# where # is 12*number of years\n// log with linear ticks: L# where # is the linear tick spacing\n// log showing powers plus some intermediates:\n// D1 shows all digits, D2 shows 2 and 5\naxes.autoTicks = function(ax, roughDTick, isMinor) {\n var base;\n\n function getBase(v) {\n return Math.pow(v, Math.floor(Math.log(roughDTick) / Math.LN10));\n }\n\n if(ax.type === 'date') {\n ax.tick0 = Lib.dateTick0(ax.calendar, 0);\n\n // the criteria below are all based on the rough spacing we calculate\n // being > half of the final unit - so precalculate twice the rough val\n var roughX2 = 2 * roughDTick;\n\n if(roughX2 > ONEAVGYEAR) {\n roughDTick /= ONEAVGYEAR;\n base = getBase(10);\n ax.dtick = 'M' + (12 * roundDTick(roughDTick, base, roundBase10));\n } else if(roughX2 > ONEAVGMONTH) {\n roughDTick /= ONEAVGMONTH;\n ax.dtick = 'M' + roundDTick(roughDTick, 1, roundBase24);\n } else if(roughX2 > ONEDAY) {\n ax.dtick = roundDTick(roughDTick, ONEDAY, ax._hasDayOfWeekBreaks ? [1, 2, 7, 14] : roundDays);\n if(!isMinor) {\n // get week ticks on sunday\n // this will also move the base tick off 2000-01-01 if dtick is\n // 2 or 3 days... but that's a weird enough case that we'll ignore it.\n var tickformat = axes.getTickFormat(ax);\n var isPeriod = ax.ticklabelmode === 'period';\n if(isPeriod) ax._rawTick0 = ax.tick0;\n\n if(/%[uVW]/.test(tickformat)) {\n ax.tick0 = Lib.dateTick0(ax.calendar, 2); // Monday\n } else {\n ax.tick0 = Lib.dateTick0(ax.calendar, 1); // Sunday\n }\n\n if(isPeriod) ax._dowTick0 = ax.tick0;\n }\n } else if(roughX2 > ONEHOUR) {\n ax.dtick = roundDTick(roughDTick, ONEHOUR, roundBase24);\n } else if(roughX2 > ONEMIN) {\n ax.dtick = roundDTick(roughDTick, ONEMIN, roundBase60);\n } else if(roughX2 > ONESEC) {\n ax.dtick = roundDTick(roughDTick, ONESEC, roundBase60);\n } else {\n // milliseconds\n base = getBase(10);\n ax.dtick = roundDTick(roughDTick, base, roundBase10);\n }\n } else if(ax.type === 'log') {\n ax.tick0 = 0;\n var rng = Lib.simpleMap(ax.range, ax.r2l);\n if(ax._isMinor) {\n // Log axes by default get MORE than nTicks based on the metrics below\n // But for minor ticks we don't want this increase, we already have\n // the major ticks.\n roughDTick *= 1.5;\n }\n if(roughDTick > 0.7) {\n // only show powers of 10\n ax.dtick = Math.ceil(roughDTick);\n } else if(Math.abs(rng[1] - rng[0]) < 1) {\n // span is less than one power of 10\n var nt = 1.5 * Math.abs((rng[1] - rng[0]) / roughDTick);\n\n // ticks on a linear scale, labeled fully\n roughDTick = Math.abs(Math.pow(10, rng[1]) -\n Math.pow(10, rng[0])) / nt;\n base = getBase(10);\n ax.dtick = 'L' + roundDTick(roughDTick, base, roundBase10);\n } else {\n // include intermediates between powers of 10,\n // labeled with small digits\n // ax.dtick = \"D2\" (show 2 and 5) or \"D1\" (show all digits)\n ax.dtick = (roughDTick > 0.3) ? 'D2' : 'D1';\n }\n } else if(ax.type === 'category' || ax.type === 'multicategory') {\n ax.tick0 = 0;\n ax.dtick = Math.ceil(Math.max(roughDTick, 1));\n } else if(isAngular(ax)) {\n ax.tick0 = 0;\n base = 1;\n ax.dtick = roundDTick(roughDTick, base, roundAngles);\n } else {\n // auto ticks always start at 0\n ax.tick0 = 0;\n base = getBase(10);\n ax.dtick = roundDTick(roughDTick, base, roundBase10);\n }\n\n // prevent infinite loops\n if(ax.dtick === 0) ax.dtick = 1;\n\n // TODO: this is from log axis histograms with autorange off\n if(!isNumeric(ax.dtick) && typeof ax.dtick !== 'string') {\n var olddtick = ax.dtick;\n ax.dtick = 1;\n throw 'ax.dtick error: ' + String(olddtick);\n }\n};\n\n// after dtick is already known, find tickround = precision\n// to display in tick labels\n// for numeric ticks, integer # digits after . to round to\n// for date ticks, the last date part to show (y,m,d,H,M,S)\n// or an integer # digits past seconds\nfunction autoTickRound(ax) {\n var dtick = ax.dtick;\n\n ax._tickexponent = 0;\n if(!isNumeric(dtick) && typeof dtick !== 'string') {\n dtick = 1;\n }\n\n if(ax.type === 'category' || ax.type === 'multicategory') {\n ax._tickround = null;\n }\n if(ax.type === 'date') {\n // If tick0 is unusual, give tickround a bit more information\n // not necessarily *all* the information in tick0 though, if it's really odd\n // minimal string length for tick0: 'd' is 10, 'M' is 16, 'S' is 19\n // take off a leading minus (year < 0) and i (intercalary month) so length is consistent\n var tick0ms = ax.r2l(ax.tick0);\n var tick0str = ax.l2r(tick0ms).replace(/(^-|i)/g, '');\n var tick0len = tick0str.length;\n\n if(String(dtick).charAt(0) === 'M') {\n // any tick0 more specific than a year: alway show the full date\n if(tick0len > 10 || tick0str.substr(5) !== '01-01') ax._tickround = 'd';\n // show the month unless ticks are full multiples of a year\n else ax._tickround = (+(dtick.substr(1)) % 12 === 0) ? 'y' : 'm';\n } else if((dtick >= ONEDAY && tick0len <= 10) || (dtick >= ONEDAY * 15)) ax._tickround = 'd';\n else if((dtick >= ONEMIN && tick0len <= 16) || (dtick >= ONEHOUR)) ax._tickround = 'M';\n else if((dtick >= ONESEC && tick0len <= 19) || (dtick >= ONEMIN)) ax._tickround = 'S';\n else {\n // tickround is a number of digits of fractional seconds\n // of any two adjacent ticks, at least one will have the maximum fractional digits\n // of all possible ticks - so take the max. length of tick0 and the next one\n var tick1len = ax.l2r(tick0ms + dtick).replace(/^-/, '').length;\n ax._tickround = Math.max(tick0len, tick1len) - 20;\n\n // We shouldn't get here... but in case there's a situation I'm\n // not thinking of where tick0str and tick1str are identical or\n // something, fall back on maximum precision\n if(ax._tickround < 0) ax._tickround = 4;\n }\n } else if(isNumeric(dtick) || dtick.charAt(0) === 'L') {\n // linear or log (except D1, D2)\n var rng = ax.range.map(ax.r2d || Number);\n if(!isNumeric(dtick)) dtick = Number(dtick.substr(1));\n // 2 digits past largest digit of dtick\n ax._tickround = 2 - Math.floor(Math.log(dtick) / Math.LN10 + 0.01);\n\n var maxend = Math.max(Math.abs(rng[0]), Math.abs(rng[1]));\n var rangeexp = Math.floor(Math.log(maxend) / Math.LN10 + 0.01);\n var minexponent = ax.minexponent === undefined ? 3 : ax.minexponent;\n if(Math.abs(rangeexp) > minexponent) {\n if(isSIFormat(ax.exponentformat) && !beyondSI(rangeexp)) {\n ax._tickexponent = 3 * Math.round((rangeexp - 1) / 3);\n } else ax._tickexponent = rangeexp;\n }\n } else {\n // D1 or D2 (log)\n ax._tickround = null;\n }\n}\n\n// months and years don't have constant millisecond values\n// (but a year is always 12 months so we only need months)\n// log-scale ticks are also not consistently spaced, except\n// for pure powers of 10\n// numeric ticks always have constant differences, other datetime ticks\n// can all be calculated as constant number of milliseconds\naxes.tickIncrement = function(x, dtick, axrev, calendar) {\n var axSign = axrev ? -1 : 1;\n\n // includes linear, all dates smaller than month, and pure 10^n in log\n if(isNumeric(dtick)) return Lib.increment(x, axSign * dtick);\n\n // everything else is a string, one character plus a number\n var tType = dtick.charAt(0);\n var dtSigned = axSign * Number(dtick.substr(1));\n\n // Dates: months (or years - see Lib.incrementMonth)\n if(tType === 'M') return Lib.incrementMonth(x, dtSigned, calendar);\n\n // Log scales: Linear, Digits\n if(tType === 'L') return Math.log(Math.pow(10, x) + dtSigned) / Math.LN10;\n\n // log10 of 2,5,10, or all digits (logs just have to be\n // close enough to round)\n if(tType === 'D') {\n var tickset = (dtick === 'D2') ? roundLog2 : roundLog1;\n var x2 = x + axSign * 0.01;\n var frac = Lib.roundUp(Lib.mod(x2, 1), tickset, axrev);\n\n return Math.floor(x2) +\n Math.log(d3.round(Math.pow(10, frac), 1)) / Math.LN10;\n }\n\n throw 'unrecognized dtick ' + String(dtick);\n};\n\n// calculate the first tick on an axis\naxes.tickFirst = function(ax, opts) {\n var r2l = ax.r2l || Number;\n var rng = Lib.simpleMap(ax.range, r2l, undefined, undefined, opts);\n var axrev = rng[1] < rng[0];\n var sRound = axrev ? Math.floor : Math.ceil;\n // add a tiny extra bit to make sure we get ticks\n // that may have been rounded out\n var r0 = expandRange(rng)[0];\n var dtick = ax.dtick;\n var tick0 = r2l(ax.tick0);\n\n if(isNumeric(dtick)) {\n var tmin = sRound((r0 - tick0) / dtick) * dtick + tick0;\n\n // make sure no ticks outside the category list\n if(ax.type === 'category' || ax.type === 'multicategory') {\n tmin = Lib.constrain(tmin, 0, ax._categories.length - 1);\n }\n return tmin;\n }\n\n var tType = dtick.charAt(0);\n var dtNum = Number(dtick.substr(1));\n\n // Dates: months (or years)\n if(tType === 'M') {\n var cnt = 0;\n var t0 = tick0;\n var t1, mult, newDTick;\n\n // This algorithm should work for *any* nonlinear (but close to linear!)\n // tick spacing. Limit to 10 iterations, for gregorian months it's normally <=3.\n while(cnt < 10) {\n t1 = axes.tickIncrement(t0, dtick, axrev, ax.calendar);\n if((t1 - r0) * (t0 - r0) <= 0) {\n // t1 and t0 are on opposite sides of r0! we've succeeded!\n if(axrev) return Math.min(t0, t1);\n return Math.max(t0, t1);\n }\n mult = (r0 - ((t0 + t1) / 2)) / (t1 - t0);\n newDTick = tType + ((Math.abs(Math.round(mult)) || 1) * dtNum);\n t0 = axes.tickIncrement(t0, newDTick, mult < 0 ? !axrev : axrev, ax.calendar);\n cnt++;\n }\n Lib.error('tickFirst did not converge', ax);\n return t0;\n } else if(tType === 'L') {\n // Log scales: Linear, Digits\n\n return Math.log(sRound(\n (Math.pow(10, r0) - tick0) / dtNum) * dtNum + tick0) / Math.LN10;\n } else if(tType === 'D') {\n var tickset = (dtick === 'D2') ? roundLog2 : roundLog1;\n var frac = Lib.roundUp(Lib.mod(r0, 1), tickset, axrev);\n\n return Math.floor(r0) +\n Math.log(d3.round(Math.pow(10, frac), 1)) / Math.LN10;\n } else throw 'unrecognized dtick ' + String(dtick);\n};\n\n// draw the text for one tick.\n// px,py are the location on gd.paper\n// prefix is there so the x axis ticks can be dropped a line\n// ax is the axis layout, x is the tick value\n// hover is a (truthy) flag for whether to show numbers with a bit\n// more precision for hovertext\naxes.tickText = function(ax, x, hover, noSuffixPrefix) {\n var out = tickTextObj(ax, x);\n var arrayMode = ax.tickmode === 'array';\n var extraPrecision = hover || arrayMode;\n var axType = ax.type;\n // TODO multicategory, if we allow ticktext / tickvals\n var tickVal2l = axType === 'category' ? ax.d2l_noadd : ax.d2l;\n var i;\n\n var inbounds = function(v) {\n var p = ax.l2p(v);\n return p >= 0 && p <= ax._length ? v : null;\n };\n if(arrayMode && Lib.isArrayOrTypedArray(ax.ticktext)) {\n var rng = Lib.simpleMap(ax.range, ax.r2l);\n var minDiff = (Math.abs(rng[1] - rng[0]) - (ax._lBreaks || 0)) / 10000;\n\n for(i = 0; i < ax.ticktext.length; i++) {\n if(Math.abs(x - tickVal2l(ax.tickvals[i])) < minDiff) break;\n }\n if(i < ax.ticktext.length) {\n out.text = String(ax.ticktext[i]);\n\n out.xbnd = [\n inbounds(out.x - 0.5),\n inbounds(out.x + ax.dtick - 0.5)\n ];\n return out;\n }\n }\n\n function isHidden(showAttr) {\n if(showAttr === undefined) return true;\n if(hover) return showAttr === 'none';\n\n var firstOrLast = {\n first: ax._tmin,\n last: ax._tmax\n }[showAttr];\n\n return showAttr !== 'all' && x !== firstOrLast;\n }\n\n var hideexp = hover ?\n 'never' :\n ax.exponentformat !== 'none' && isHidden(ax.showexponent) ? 'hide' : '';\n\n if(axType === 'date') formatDate(ax, out, hover, extraPrecision);\n else if(axType === 'log') formatLog(ax, out, hover, extraPrecision, hideexp);\n else if(axType === 'category') formatCategory(ax, out);\n else if(axType === 'multicategory') formatMultiCategory(ax, out, hover);\n else if(isAngular(ax)) formatAngle(ax, out, hover, extraPrecision, hideexp);\n else formatLinear(ax, out, hover, extraPrecision, hideexp);\n\n // add prefix and suffix\n if(!noSuffixPrefix) {\n if(ax.tickprefix && !isHidden(ax.showtickprefix)) out.text = ax.tickprefix + out.text;\n if(ax.ticksuffix && !isHidden(ax.showticksuffix)) out.text += ax.ticksuffix;\n }\n\n if(ax.labelalias && ax.labelalias.hasOwnProperty(out.text)) {\n var t = ax.labelalias[out.text];\n if(typeof t === 'string') out.text = t;\n }\n\n // Setup ticks and grid lines boundaries\n // at 1/2 a 'category' to the left/bottom\n if(ax.tickson === 'boundaries' || ax.showdividers) {\n out.xbnd = [\n inbounds(out.x - 0.5),\n inbounds(out.x + ax.dtick - 0.5)\n ];\n }\n\n return out;\n};\n\n/**\n * create text for a hover label on this axis, with special handling of\n * log axes (where negative values can't be displayed but can appear in hover text)\n *\n * @param {object} ax: the axis to format text for\n * @param {number or array of numbers} values: calcdata value(s) to format\n * @param {Optional(string)} hoverformat: trace (x|y)hoverformat to override axis.hoverformat\n *\n * @returns {string} `val` formatted as a string appropriate to this axis, or\n * first value and second value as a range (ie ' - ') if the second value is provided and\n * it's different from the first value.\n */\naxes.hoverLabelText = function(ax, values, hoverformat) {\n if(hoverformat) ax = Lib.extendFlat({}, ax, {hoverformat: hoverformat});\n\n var val = Lib.isArrayOrTypedArray(values) ? values[0] : values;\n var val2 = Lib.isArrayOrTypedArray(values) ? values[1] : undefined;\n if(val2 !== undefined && val2 !== val) {\n return (\n axes.hoverLabelText(ax, val, hoverformat) + ' - ' +\n axes.hoverLabelText(ax, val2, hoverformat)\n );\n }\n\n var logOffScale = (ax.type === 'log' && val <= 0);\n var tx = axes.tickText(ax, ax.c2l(logOffScale ? -val : val), 'hover').text;\n\n if(logOffScale) {\n return val === 0 ? '0' : MINUS_SIGN + tx;\n }\n\n // TODO: should we do something special if the axis calendar and\n // the data calendar are different? Somehow display both dates with\n // their system names? Right now it will just display in the axis calendar\n // but users could add the other one as text.\n return tx;\n};\n\nfunction tickTextObj(ax, x, text) {\n var tf = ax.tickfont || {};\n\n return {\n x: x,\n dx: 0,\n dy: 0,\n text: text || '',\n fontSize: tf.size,\n font: tf.family,\n fontWeight: tf.weight,\n fontStyle: tf.style,\n fontVariant: tf.variant,\n fontTextcase: tf.textcase,\n fontLineposition: tf.lineposition,\n fontShadow: tf.shadow,\n fontColor: tf.color\n };\n}\n\nfunction formatDate(ax, out, hover, extraPrecision) {\n var tr = ax._tickround;\n var fmt = (hover && ax.hoverformat) || axes.getTickFormat(ax);\n\n // Only apply extra precision if no explicit format was provided.\n extraPrecision = !fmt && extraPrecision;\n\n if(extraPrecision) {\n // second or sub-second precision: extra always shows max digits.\n // for other fields, extra precision just adds one field.\n if(isNumeric(tr)) tr = 4;\n else tr = {y: 'm', m: 'd', d: 'M', M: 'S', S: 4}[tr];\n }\n\n var dateStr = Lib.formatDate(out.x, fmt, tr, ax._dateFormat, ax.calendar, ax._extraFormat);\n var headStr;\n\n var splitIndex = dateStr.indexOf('\\n');\n if(splitIndex !== -1) {\n headStr = dateStr.substr(splitIndex + 1);\n dateStr = dateStr.substr(0, splitIndex);\n }\n\n if(extraPrecision) {\n // if extraPrecision led to trailing zeros, strip them off\n // actually, this can lead to removing even more zeros than\n // in the original rounding, but that's fine because in these\n // contexts uniformity is not so important (if there's even\n // anything to be uniform with!)\n\n // can we remove the whole time part?\n if(headStr !== undefined && (dateStr === '00:00:00' || dateStr === '00:00')) {\n dateStr = headStr;\n headStr = '';\n } else if(dateStr.length === 8) {\n // strip off seconds if they're zero (zero fractional seconds\n // are already omitted)\n // but we never remove minutes and leave just hours\n dateStr = dateStr.replace(/:00$/, '');\n }\n }\n\n if(headStr) {\n if(hover) {\n // hover puts it all on one line, so headPart works best up front\n // except for year headPart: turn this into \"Jan 1, 2000\" etc.\n if(tr === 'd') dateStr += ', ' + headStr;\n else dateStr = headStr + (dateStr ? ', ' + dateStr : '');\n } else {\n if(\n !ax._inCalcTicks ||\n ax._prevDateHead !== headStr\n ) {\n ax._prevDateHead = headStr;\n dateStr += '
' + headStr;\n } else {\n var isInside = insideTicklabelposition(ax);\n var side = ax._trueSide || ax.side; // polar mocks the side of the radial axis\n if(\n (!isInside && side === 'top') ||\n (isInside && side === 'bottom')\n ) {\n dateStr += '
';\n }\n }\n }\n }\n\n out.text = dateStr;\n}\n\nfunction formatLog(ax, out, hover, extraPrecision, hideexp) {\n var dtick = ax.dtick;\n var x = out.x;\n var tickformat = ax.tickformat;\n var dtChar0 = typeof dtick === 'string' && dtick.charAt(0);\n\n if(hideexp === 'never') {\n // If this is a hover label, then we must *never* hide the exponent\n // for the sake of display, which could give the wrong value by\n // potentially many orders of magnitude. If hideexp was 'never', then\n // it's now succeeded by preventing the other condition from automating\n // this choice. Thus we can unset it so that the axis formatting takes\n // precedence.\n hideexp = '';\n }\n\n if(extraPrecision && (dtChar0 !== 'L')) {\n dtick = 'L3';\n dtChar0 = 'L';\n }\n\n if(tickformat || (dtChar0 === 'L')) {\n out.text = numFormat(Math.pow(10, x), ax, hideexp, extraPrecision);\n } else if(isNumeric(dtick) || ((dtChar0 === 'D') && (Lib.mod(x + 0.01, 1) < 0.1))) {\n var p = Math.round(x);\n var absP = Math.abs(p);\n var exponentFormat = ax.exponentformat;\n if(exponentFormat === 'power' || (isSIFormat(exponentFormat) && beyondSI(p))) {\n if(p === 0) out.text = 1;\n else if(p === 1) out.text = '10';\n else out.text = '10' + (p > 1 ? '' : MINUS_SIGN) + absP + '';\n\n out.fontSize *= 1.25;\n } else if((exponentFormat === 'e' || exponentFormat === 'E') && absP > 2) {\n out.text = '1' + exponentFormat + (p > 0 ? '+' : MINUS_SIGN) + absP;\n } else {\n out.text = numFormat(Math.pow(10, x), ax, '', 'fakehover');\n if(dtick === 'D1' && ax._id.charAt(0) === 'y') {\n out.dy -= out.fontSize / 6;\n }\n }\n } else if(dtChar0 === 'D') {\n out.text = String(Math.round(Math.pow(10, Lib.mod(x, 1))));\n out.fontSize *= 0.75;\n } else throw 'unrecognized dtick ' + String(dtick);\n\n // if 9's are printed on log scale, move the 10's away a bit\n if(ax.dtick === 'D1') {\n var firstChar = String(out.text).charAt(0);\n if(firstChar === '0' || firstChar === '1') {\n if(ax._id.charAt(0) === 'y') {\n out.dx -= out.fontSize / 4;\n } else {\n out.dy += out.fontSize / 2;\n out.dx += (ax.range[1] > ax.range[0] ? 1 : -1) *\n out.fontSize * (x < 0 ? 0.5 : 0.25);\n }\n }\n }\n}\n\nfunction formatCategory(ax, out) {\n var tt = ax._categories[Math.round(out.x)];\n if(tt === undefined) tt = '';\n out.text = String(tt);\n}\n\nfunction formatMultiCategory(ax, out, hover) {\n var v = Math.round(out.x);\n var cats = ax._categories[v] || [];\n var tt = cats[1] === undefined ? '' : String(cats[1]);\n var tt2 = cats[0] === undefined ? '' : String(cats[0]);\n\n if(hover) {\n // TODO is this what we want?\n out.text = tt2 + ' - ' + tt;\n } else {\n // setup for secondary labels\n out.text = tt;\n out.text2 = tt2;\n }\n}\n\nfunction formatLinear(ax, out, hover, extraPrecision, hideexp) {\n if(hideexp === 'never') {\n // If this is a hover label, then we must *never* hide the exponent\n // for the sake of display, which could give the wrong value by\n // potentially many orders of magnitude. If hideexp was 'never', then\n // it's now succeeded by preventing the other condition from automating\n // this choice. Thus we can unset it so that the axis formatting takes\n // precedence.\n hideexp = '';\n } else if(ax.showexponent === 'all' && Math.abs(out.x / ax.dtick) < 1e-6) {\n // don't add an exponent to zero if we're showing all exponents\n // so the only reason you'd show an exponent on zero is if it's the\n // ONLY tick to get an exponent (first or last)\n hideexp = 'hide';\n }\n out.text = numFormat(out.x, ax, hideexp, extraPrecision);\n}\n\nfunction formatAngle(ax, out, hover, extraPrecision, hideexp) {\n if(ax.thetaunit === 'radians' && !hover) {\n var num = out.x / 180;\n\n if(num === 0) {\n out.text = '0';\n } else {\n var frac = num2frac(num);\n\n if(frac[1] >= 100) {\n out.text = numFormat(Lib.deg2rad(out.x), ax, hideexp, extraPrecision);\n } else {\n var isNeg = out.x < 0;\n\n if(frac[1] === 1) {\n if(frac[0] === 1) out.text = 'π';\n else out.text = frac[0] + 'π';\n } else {\n out.text = [\n '', frac[0], '',\n '⁄',\n '', frac[1], '',\n 'π'\n ].join('');\n }\n\n if(isNeg) out.text = MINUS_SIGN + out.text;\n }\n }\n } else {\n out.text = numFormat(out.x, ax, hideexp, extraPrecision);\n }\n}\n\n// inspired by\n// https://github.com/yisibl/num2fraction/blob/master/index.js\nfunction num2frac(num) {\n function almostEq(a, b) {\n return Math.abs(a - b) <= 1e-6;\n }\n\n function findGCD(a, b) {\n return almostEq(b, 0) ? a : findGCD(b, a % b);\n }\n\n function findPrecision(n) {\n var e = 1;\n while(!almostEq(Math.round(n * e) / e, n)) {\n e *= 10;\n }\n return e;\n }\n\n var precision = findPrecision(num);\n var number = num * precision;\n var gcd = Math.abs(findGCD(number, precision));\n\n return [\n // numerator\n Math.round(number / gcd),\n // denominator\n Math.round(precision / gcd)\n ];\n}\n\n// format a number (tick value) according to the axis settings\n// new, more reliable procedure than d3.round or similar:\n// add half the rounding increment, then stringify and truncate\n// also automatically switch to sci. notation\nvar SIPREFIXES = ['f', 'p', 'n', 'μ', 'm', '', 'k', 'M', 'G', 'T'];\n\nfunction isSIFormat(exponentFormat) {\n return exponentFormat === 'SI' || exponentFormat === 'B';\n}\n\n// are we beyond the range of common SI prefixes?\n// 10^-16 -> 1x10^-16\n// 10^-15 -> 1f\n// ...\n// 10^14 -> 100T\n// 10^15 -> 1x10^15\n// 10^16 -> 1x10^16\nfunction beyondSI(exponent) {\n return exponent > 14 || exponent < -15;\n}\n\nfunction numFormat(v, ax, fmtoverride, hover) {\n var isNeg = v < 0;\n // max number of digits past decimal point to show\n var tickRound = ax._tickround;\n var exponentFormat = fmtoverride || ax.exponentformat || 'B';\n var exponent = ax._tickexponent;\n var tickformat = axes.getTickFormat(ax);\n var separatethousands = ax.separatethousands;\n\n // special case for hover: set exponent just for this value, and\n // add a couple more digits of precision over tick labels\n if(hover) {\n // make a dummy axis obj to get the auto rounding and exponent\n var ah = {\n exponentformat: exponentFormat,\n minexponent: ax.minexponent,\n dtick: ax.showexponent === 'none' ? ax.dtick :\n (isNumeric(v) ? Math.abs(v) || 1 : 1),\n // if not showing any exponents, don't change the exponent\n // from what we calculate\n range: ax.showexponent === 'none' ? ax.range.map(ax.r2d) : [0, v || 1]\n };\n autoTickRound(ah);\n tickRound = (Number(ah._tickround) || 0) + 4;\n exponent = ah._tickexponent;\n if(ax.hoverformat) tickformat = ax.hoverformat;\n }\n\n if(tickformat) return ax._numFormat(tickformat)(v).replace(/-/g, MINUS_SIGN);\n\n // 'epsilon' - rounding increment\n var e = Math.pow(10, -tickRound) / 2;\n\n // exponentFormat codes:\n // 'e' (1.2e+6, default)\n // 'E' (1.2E+6)\n // 'SI' (1.2M)\n // 'B' (same as SI except 10^9=B not G)\n // 'none' (1200000)\n // 'power' (1.2x10^6)\n // 'hide' (1.2, use 3rd argument=='hide' to eg\n // only show exponent on last tick)\n if(exponentFormat === 'none') exponent = 0;\n\n // take the sign out, put it back manually at the end\n // - makes cases easier\n v = Math.abs(v);\n if(v < e) {\n // 0 is just 0, but may get exponent if it's the last tick\n v = '0';\n isNeg = false;\n } else {\n v += e;\n // take out a common exponent, if any\n if(exponent) {\n v *= Math.pow(10, -exponent);\n tickRound += exponent;\n }\n // round the mantissa\n if(tickRound === 0) v = String(Math.floor(v));\n else if(tickRound < 0) {\n v = String(Math.round(v));\n v = v.substr(0, v.length + tickRound);\n for(var i = tickRound; i < 0; i++) v += '0';\n } else {\n v = String(v);\n var dp = v.indexOf('.') + 1;\n if(dp) v = v.substr(0, dp + tickRound).replace(/\\.?0+$/, '');\n }\n // insert appropriate decimal point and thousands separator\n v = Lib.numSeparate(v, ax._separators, separatethousands);\n }\n\n // add exponent\n if(exponent && exponentFormat !== 'hide') {\n if(isSIFormat(exponentFormat) && beyondSI(exponent)) exponentFormat = 'power';\n\n var signedExponent;\n if(exponent < 0) signedExponent = MINUS_SIGN + -exponent;\n else if(exponentFormat !== 'power') signedExponent = '+' + exponent;\n else signedExponent = String(exponent);\n\n if(exponentFormat === 'e' || exponentFormat === 'E') {\n v += exponentFormat + signedExponent;\n } else if(exponentFormat === 'power') {\n v += '×10' + signedExponent + '';\n } else if(exponentFormat === 'B' && exponent === 9) {\n v += 'B';\n } else if(isSIFormat(exponentFormat)) {\n v += SIPREFIXES[exponent / 3 + 5];\n }\n }\n\n // put sign back in and return\n // replace standard minus character (which is technically a hyphen)\n // with a true minus sign\n if(isNeg) return MINUS_SIGN + v;\n return v;\n}\n\naxes.getTickFormat = function(ax) {\n var i;\n\n function convertToMs(dtick) {\n return typeof dtick !== 'string' ? dtick : Number(dtick.replace('M', '')) * ONEAVGMONTH;\n }\n\n function compareLogTicks(left, right) {\n var priority = ['L', 'D'];\n if(typeof left === typeof right) {\n if(typeof left === 'number') {\n return left - right;\n } else {\n var leftPriority = priority.indexOf(left.charAt(0));\n var rightPriority = priority.indexOf(right.charAt(0));\n if(leftPriority === rightPriority) {\n return Number(left.replace(/(L|D)/g, '')) - Number(right.replace(/(L|D)/g, ''));\n } else {\n return leftPriority - rightPriority;\n }\n }\n } else {\n return typeof left === 'number' ? 1 : -1;\n }\n }\n\n function isProperStop(dtick, range, convert) {\n var convertFn = convert || function(x) { return x;};\n var leftDtick = range[0];\n var rightDtick = range[1];\n return ((!leftDtick && typeof leftDtick !== 'number') || convertFn(leftDtick) <= convertFn(dtick)) &&\n ((!rightDtick && typeof rightDtick !== 'number') || convertFn(rightDtick) >= convertFn(dtick));\n }\n\n function isProperLogStop(dtick, range) {\n var isLeftDtickNull = range[0] === null;\n var isRightDtickNull = range[1] === null;\n var isDtickInRangeLeft = compareLogTicks(dtick, range[0]) >= 0;\n var isDtickInRangeRight = compareLogTicks(dtick, range[1]) <= 0;\n return (isLeftDtickNull || isDtickInRangeLeft) && (isRightDtickNull || isDtickInRangeRight);\n }\n\n var tickstop, stopi;\n if(ax.tickformatstops && ax.tickformatstops.length > 0) {\n switch(ax.type) {\n case 'date':\n case 'linear': {\n for(i = 0; i < ax.tickformatstops.length; i++) {\n stopi = ax.tickformatstops[i];\n if(stopi.enabled && isProperStop(ax.dtick, stopi.dtickrange, convertToMs)) {\n tickstop = stopi;\n break;\n }\n }\n break;\n }\n case 'log': {\n for(i = 0; i < ax.tickformatstops.length; i++) {\n stopi = ax.tickformatstops[i];\n if(stopi.enabled && isProperLogStop(ax.dtick, stopi.dtickrange)) {\n tickstop = stopi;\n break;\n }\n }\n break;\n }\n default:\n }\n }\n return tickstop ? tickstop.value : ax.tickformat;\n};\n\n// getSubplots - extract all subplot IDs we need\n// as an array of items like 'xy', 'x2y', 'x2y2'...\n// sorted by x (x,x2,x3...) then y\n// optionally restrict to only subplots containing axis object ax\n//\n// NOTE: this is currently only used OUTSIDE plotly.js (toolpanel, webapp)\n// ideally we get rid of it there (or just copy this there) and remove it here\naxes.getSubplots = function(gd, ax) {\n var subplotObj = gd._fullLayout._subplots;\n var allSubplots = subplotObj.cartesian.concat(subplotObj.gl2d || []);\n\n var out = ax ? axes.findSubplotsWithAxis(allSubplots, ax) : allSubplots;\n\n out.sort(function(a, b) {\n var aParts = a.substr(1).split('y');\n var bParts = b.substr(1).split('y');\n\n if(aParts[0] === bParts[0]) return +aParts[1] - +bParts[1];\n return +aParts[0] - +bParts[0];\n });\n\n return out;\n};\n\n// find all subplots with axis 'ax'\n// NOTE: this is only used in axes.getSubplots (only used outside plotly.js) and\n// gl2d/convert (where it restricts axis subplots to only those with gl2d)\naxes.findSubplotsWithAxis = function(subplots, ax) {\n var axMatch = new RegExp(\n (ax._id.charAt(0) === 'x') ? ('^' + ax._id + 'y') : (ax._id + '$')\n );\n var subplotsWithAx = [];\n\n for(var i = 0; i < subplots.length; i++) {\n var sp = subplots[i];\n if(axMatch.test(sp)) subplotsWithAx.push(sp);\n }\n\n return subplotsWithAx;\n};\n\n// makeClipPaths: prepare clipPaths for all single axes and all possible xy pairings\naxes.makeClipPaths = function(gd) {\n var fullLayout = gd._fullLayout;\n\n // for more info: https://github.com/plotly/plotly.js/issues/2595\n if(fullLayout._hasOnlyLargeSploms) return;\n\n var fullWidth = {_offset: 0, _length: fullLayout.width, _id: ''};\n var fullHeight = {_offset: 0, _length: fullLayout.height, _id: ''};\n var xaList = axes.list(gd, 'x', true);\n var yaList = axes.list(gd, 'y', true);\n var clipList = [];\n var i, j;\n\n for(i = 0; i < xaList.length; i++) {\n clipList.push({x: xaList[i], y: fullHeight});\n for(j = 0; j < yaList.length; j++) {\n if(i === 0) clipList.push({x: fullWidth, y: yaList[j]});\n clipList.push({x: xaList[i], y: yaList[j]});\n }\n }\n\n // selectors don't work right with camelCase tags,\n // have to use class instead\n // https://groups.google.com/forum/#!topic/d3-js/6EpAzQ2gU9I\n var axClips = fullLayout._clips.selectAll('.axesclip')\n .data(clipList, function(d) { return d.x._id + d.y._id; });\n\n axClips.enter().append('clipPath')\n .classed('axesclip', true)\n .attr('id', function(d) { return 'clip' + fullLayout._uid + d.x._id + d.y._id; })\n .append('rect');\n\n axClips.exit().remove();\n\n axClips.each(function(d) {\n d3.select(this).select('rect').attr({\n x: d.x._offset || 0,\n y: d.y._offset || 0,\n width: d.x._length || 1,\n height: d.y._length || 1\n });\n });\n};\n\n/**\n * Main multi-axis drawing routine!\n *\n * @param {DOM element} gd : graph div\n * @param {string or array of strings} arg : polymorphic argument\n * @param {object} opts:\n * - @param {boolean} skipTitle : optional flag to skip axis title draw/update\n *\n * Signature 1: Axes.draw(gd, 'redraw')\n * use this to clear and redraw all axes on graph\n *\n * Signature 2: Axes.draw(gd, '')\n * use this to draw all axes on graph w/o the selectAll().remove()\n * of the 'redraw' signature\n *\n * Signature 3: Axes.draw(gd, [axId, axId2, ...])\n * where the items are axis id string,\n * use this to update multiple axes in one call\n *\n * N.B draw updates:\n * - ax._r (stored range for use by zoom/pan)\n * - ax._rl (stored linearized range for use by zoom/pan)\n */\naxes.draw = function(gd, arg, opts) {\n var fullLayout = gd._fullLayout;\n\n if(arg === 'redraw') {\n fullLayout._paper.selectAll('g.subplot').each(function(d) {\n var id = d[0];\n var plotinfo = fullLayout._plots[id];\n if(plotinfo) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n plotinfo.xaxislayer.selectAll('.' + xa._id + 'tick').remove();\n plotinfo.yaxislayer.selectAll('.' + ya._id + 'tick').remove();\n plotinfo.xaxislayer.selectAll('.' + xa._id + 'tick2').remove();\n plotinfo.yaxislayer.selectAll('.' + ya._id + 'tick2').remove();\n plotinfo.xaxislayer.selectAll('.' + xa._id + 'divider').remove();\n plotinfo.yaxislayer.selectAll('.' + ya._id + 'divider').remove();\n\n if(plotinfo.minorGridlayer) plotinfo.minorGridlayer.selectAll('path').remove();\n if(plotinfo.gridlayer) plotinfo.gridlayer.selectAll('path').remove();\n if(plotinfo.zerolinelayer) plotinfo.zerolinelayer.selectAll('path').remove();\n\n fullLayout._infolayer.select('.g-' + xa._id + 'title').remove();\n fullLayout._infolayer.select('.g-' + ya._id + 'title').remove();\n }\n });\n }\n\n var axList = (!arg || arg === 'redraw') ? axes.listIds(gd) : arg;\n\n var fullAxList = axes.list(gd);\n // Get the list of the overlaying axis for all 'shift' axes\n var overlayingShiftedAx = fullAxList.filter(function(ax) {\n return ax.autoshift;\n }).map(function(ax) {\n return ax.overlaying;\n });\n\n // order axes that have dependency to other axes\n axList.map(function(axId) {\n var ax = axes.getFromId(gd, axId);\n\n if(ax.tickmode === 'sync' && ax.overlaying) {\n var overlayingIndex = axList.findIndex(function(axis) {return axis === ax.overlaying;});\n\n if(overlayingIndex >= 0) {\n axList.unshift(axList.splice(overlayingIndex, 1).shift());\n }\n }\n });\n\n var axShifts = {false: {left: 0, right: 0}};\n\n return Lib.syncOrAsync(axList.map(function(axId) {\n return function() {\n if(!axId) return;\n\n var ax = axes.getFromId(gd, axId);\n\n if(!opts) opts = {};\n opts.axShifts = axShifts;\n opts.overlayingShiftedAx = overlayingShiftedAx;\n\n var axDone = axes.drawOne(gd, ax, opts);\n\n if(ax._shiftPusher) {\n incrementShift(ax, ax._fullDepth || 0, axShifts, true);\n }\n ax._r = ax.range.slice();\n ax._rl = Lib.simpleMap(ax._r, ax.r2l);\n\n return axDone;\n };\n }));\n};\n\n/**\n * Draw one cartesian axis\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * @param {object} opts\n * - @param {boolean} skipTitle (set to true to skip axis title draw call)\n *\n * Depends on:\n * - ax._mainSubplot (from linkSubplots)\n * - ax._mainAxis\n * - ax._anchorAxis\n * - ax._subplotsWith\n * - ax._counterDomainMin, ax._counterDomainMax (optionally, from linkSubplots)\n * - ax._tickAngles (on redraw only, old value relinked during supplyDefaults)\n * - ax._mainLinePosition (from lsInner)\n * - ax._mainMirrorPosition\n * - ax._linepositions\n *\n * Fills in:\n * - ax._vals:\n * - ax._gridVals:\n * - ax._selections:\n * - ax._tickAngles:\n * - ax._depth (when required only):\n * - and calls ax.setScale\n */\naxes.drawOne = function(gd, ax, opts) {\n opts = opts || {};\n\n var axShifts = opts.axShifts || {};\n var overlayingShiftedAx = opts.overlayingShiftedAx || [];\n\n var i, sp, plotinfo;\n\n ax.setScale();\n\n var fullLayout = gd._fullLayout;\n var axId = ax._id;\n var axLetter = axId.charAt(0);\n var counterLetter = axes.counterLetter(axId);\n var mainPlotinfo = fullLayout._plots[ax._mainSubplot];\n\n // this happens when updating matched group with 'missing' axes\n if(!mainPlotinfo) return;\n\n ax._shiftPusher = ax.autoshift ||\n overlayingShiftedAx.indexOf(ax._id) !== -1 ||\n overlayingShiftedAx.indexOf(ax.overlaying) !== -1;\n // An axis is also shifted by 1/2 of its own linewidth and inside tick length if applicable\n // as well as its manually specified `shift` val if we're in the context of `autoshift`\n if(ax._shiftPusher & ax.anchor === 'free') {\n var selfPush = (ax.linewidth / 2 || 0);\n if(ax.ticks === 'inside') {\n selfPush += ax.ticklen;\n }\n incrementShift(ax, selfPush, axShifts, true);\n incrementShift(ax, (ax.shift || 0), axShifts, false);\n }\n\n // Somewhat inelegant way of making sure that the shift value is only updated when the\n // Axes.DrawOne() function is called from the right context. An issue when redrawing the\n // axis as result of using the dragbox, for example.\n if(opts.skipTitle !== true || ax._shift === undefined) ax._shift = setShiftVal(ax, axShifts);\n\n var mainAxLayer = mainPlotinfo[axLetter + 'axislayer'];\n var mainLinePosition = ax._mainLinePosition;\n var mainLinePositionShift = mainLinePosition += ax._shift;\n var mainMirrorPosition = ax._mainMirrorPosition;\n\n var vals = ax._vals = axes.calcTicks(ax);\n\n // Add a couple of axis properties that should cause us to recreate\n // elements. Used in d3 data function.\n var axInfo = [ax.mirror, mainLinePositionShift, mainMirrorPosition].join('_');\n for(i = 0; i < vals.length; i++) {\n vals[i].axInfo = axInfo;\n }\n\n // stash selections to avoid DOM queries e.g.\n // - stash tickLabels selection, so that drawTitle can use it to scoot title\n ax._selections = {};\n // stash tick angle (including the computed 'auto' values) per tick-label class\n // linkup 'previous' tick angles on redraws\n if(ax._tickAngles) ax._prevTickAngles = ax._tickAngles;\n ax._tickAngles = {};\n // measure [in px] between axis position and outward-most part of bounding box\n // (touching either the tick label or ticks)\n // depth can be expansive to compute, so we only do so when required\n ax._depth = null;\n\n // calcLabelLevelBbox can be expensive,\n // so make sure to not call it twice during the same Axes.drawOne call\n // by stashing label-level bounding boxes per tick-label class\n var llbboxes = {};\n function getLabelLevelBbox(suffix) {\n var cls = axId + (suffix || 'tick');\n if(!llbboxes[cls]) llbboxes[cls] = calcLabelLevelBbox(ax, cls, mainLinePositionShift);\n return llbboxes[cls];\n }\n\n if(!ax.visible) return;\n\n var transTickFn = axes.makeTransTickFn(ax);\n var transTickLabelFn = axes.makeTransTickLabelFn(ax);\n\n var tickVals;\n // We remove zero lines, grid lines, and inside ticks if they're within 1px of the end\n // The key case here is removing zero lines when the axis bound is zero\n var valsClipped;\n\n var insideTicks = ax.ticks === 'inside';\n var outsideTicks = ax.ticks === 'outside';\n\n if(ax.tickson === 'boundaries') {\n var boundaryVals = getBoundaryVals(ax, vals);\n valsClipped = axes.clipEnds(ax, boundaryVals);\n tickVals = insideTicks ? valsClipped : boundaryVals;\n } else {\n valsClipped = axes.clipEnds(ax, vals);\n tickVals = (insideTicks && ax.ticklabelmode !== 'period') ? valsClipped : vals;\n }\n\n var gridVals = ax._gridVals = valsClipped;\n var dividerVals = getDividerVals(ax, vals);\n\n if(!fullLayout._hasOnlyLargeSploms) {\n var subplotsWithAx = ax._subplotsWith;\n\n // keep track of which subplots (by main counter axis) we've already\n // drawn grids for, so we don't overdraw overlaying subplots\n var finishedGrids = {};\n\n for(i = 0; i < subplotsWithAx.length; i++) {\n sp = subplotsWithAx[i];\n plotinfo = fullLayout._plots[sp];\n\n var counterAxis = plotinfo[counterLetter + 'axis'];\n var mainCounterID = counterAxis._mainAxis._id;\n if(finishedGrids[mainCounterID]) continue;\n finishedGrids[mainCounterID] = 1;\n\n var gridPath = axLetter === 'x' ?\n 'M0,' + counterAxis._offset + 'v' + counterAxis._length :\n 'M' + counterAxis._offset + ',0h' + counterAxis._length;\n\n axes.drawGrid(gd, ax, {\n vals: gridVals,\n counterAxis: counterAxis,\n layer: plotinfo.gridlayer.select('.' + axId),\n minorLayer: plotinfo.minorGridlayer.select('.' + axId),\n path: gridPath,\n transFn: transTickFn\n });\n axes.drawZeroLine(gd, ax, {\n counterAxis: counterAxis,\n layer: plotinfo.zerolinelayer,\n path: gridPath,\n transFn: transTickFn\n });\n }\n }\n\n var tickPath;\n\n var majorTickSigns = axes.getTickSigns(ax);\n var minorTickSigns = axes.getTickSigns(ax, 'minor');\n\n if(ax.ticks || (ax.minor && ax.minor.ticks)) {\n var majorTickPath = axes.makeTickPath(ax, mainLinePositionShift, majorTickSigns[2]);\n var minorTickPath = axes.makeTickPath(ax, mainLinePositionShift, minorTickSigns[2], { minor: true });\n\n var mirrorMajorTickPath;\n var mirrorMinorTickPath;\n\n var fullMajorTickPath;\n var fullMinorTickPath;\n\n if(ax._anchorAxis && ax.mirror && ax.mirror !== true) {\n mirrorMajorTickPath = axes.makeTickPath(ax, mainMirrorPosition, majorTickSigns[3]);\n mirrorMinorTickPath = axes.makeTickPath(ax, mainMirrorPosition, minorTickSigns[3], { minor: true });\n\n fullMajorTickPath = majorTickPath + mirrorMajorTickPath;\n fullMinorTickPath = minorTickPath + mirrorMinorTickPath;\n } else {\n mirrorMajorTickPath = '';\n mirrorMinorTickPath = '';\n fullMajorTickPath = majorTickPath;\n fullMinorTickPath = minorTickPath;\n }\n\n if(ax.showdividers && outsideTicks && ax.tickson === 'boundaries') {\n var dividerLookup = {};\n for(i = 0; i < dividerVals.length; i++) {\n dividerLookup[dividerVals[i].x] = 1;\n }\n tickPath = function(d) {\n return dividerLookup[d.x] ? mirrorMajorTickPath : fullMajorTickPath;\n };\n } else {\n tickPath = function(d) {\n return d.minor ? fullMinorTickPath : fullMajorTickPath;\n };\n }\n }\n\n axes.drawTicks(gd, ax, {\n vals: tickVals,\n layer: mainAxLayer,\n path: tickPath,\n transFn: transTickFn\n });\n\n if(ax.mirror === 'allticks') {\n var tickSubplots = Object.keys(ax._linepositions || {});\n\n for(i = 0; i < tickSubplots.length; i++) {\n sp = tickSubplots[i];\n plotinfo = fullLayout._plots[sp];\n // [bottom or left, top or right], free and main are handled above\n var linepositions = ax._linepositions[sp] || [];\n\n var p0 = linepositions[0];\n var p1 = linepositions[1];\n var isMinor = linepositions[2];\n\n var spTickPath =\n axes.makeTickPath(ax, p0,\n isMinor ? majorTickSigns[0] : minorTickSigns[0],\n { minor: isMinor }\n ) +\n axes.makeTickPath(ax, p1,\n isMinor ? majorTickSigns[1] : minorTickSigns[1],\n { minor: isMinor }\n );\n\n axes.drawTicks(gd, ax, {\n vals: tickVals,\n layer: plotinfo[axLetter + 'axislayer'],\n path: spTickPath,\n transFn: transTickFn\n });\n }\n }\n\n var seq = [];\n\n // tick labels - for now just the main labels.\n // TODO: mirror labels, esp for subplots\n\n seq.push(function() {\n return axes.drawLabels(gd, ax, {\n vals: vals,\n layer: mainAxLayer,\n plotinfo: plotinfo,\n transFn: transTickLabelFn,\n labelFns: axes.makeLabelFns(ax, mainLinePositionShift)\n });\n });\n\n if(ax.type === 'multicategory') {\n var pad = {x: 2, y: 10}[axLetter];\n\n seq.push(function() {\n var bboxKey = {x: 'height', y: 'width'}[axLetter];\n var standoff = getLabelLevelBbox()[bboxKey] + pad +\n (ax._tickAngles[axId + 'tick'] ? ax.tickfont.size * LINE_SPACING : 0);\n\n return axes.drawLabels(gd, ax, {\n vals: getSecondaryLabelVals(ax, vals),\n layer: mainAxLayer,\n cls: axId + 'tick2',\n repositionOnUpdate: true,\n secondary: true,\n transFn: transTickFn,\n labelFns: axes.makeLabelFns(ax, mainLinePositionShift + standoff * majorTickSigns[4])\n });\n });\n\n seq.push(function() {\n ax._depth = majorTickSigns[4] * (getLabelLevelBbox('tick2')[ax.side] - mainLinePositionShift);\n\n return drawDividers(gd, ax, {\n vals: dividerVals,\n layer: mainAxLayer,\n path: axes.makeTickPath(ax, mainLinePositionShift, majorTickSigns[4], { len: ax._depth }),\n transFn: transTickFn\n });\n });\n } else if(ax.title.hasOwnProperty('standoff')) {\n seq.push(function() {\n ax._depth = majorTickSigns[4] * (getLabelLevelBbox()[ax.side] - mainLinePositionShift);\n });\n }\n\n var hasRangeSlider = Registry.getComponentMethod('rangeslider', 'isVisible')(ax);\n\n if(!opts.skipTitle &&\n !(hasRangeSlider && ax.side === 'bottom')\n ) {\n seq.push(function() { return drawTitle(gd, ax); });\n }\n\n seq.push(function() {\n var s = ax.side.charAt(0);\n var sMirror = OPPOSITE_SIDE[ax.side].charAt(0);\n var pos = axes.getPxPosition(gd, ax);\n var outsideTickLen = outsideTicks ? ax.ticklen : 0;\n var llbbox;\n\n var push;\n var mirrorPush;\n var rangeSliderPush;\n\n if(ax.automargin || hasRangeSlider || ax._shiftPusher) {\n if(ax.type === 'multicategory') {\n llbbox = getLabelLevelBbox('tick2');\n } else {\n llbbox = getLabelLevelBbox();\n if(axLetter === 'x' && s === 'b') {\n ax._depth = Math.max(llbbox.width > 0 ? llbbox.bottom - pos : 0, outsideTickLen);\n }\n }\n }\n\n var axDepth = 0;\n var titleDepth = 0;\n if(ax._shiftPusher) {\n axDepth = Math.max(\n outsideTickLen,\n llbbox.height > 0 ? (s === 'l' ? pos - llbbox.left : llbbox.right - pos) : 0\n );\n if(ax.title.text !== fullLayout._dfltTitle[axLetter]) {\n titleDepth = (ax._titleStandoff || 0) + (ax._titleScoot || 0);\n if(s === 'l') {\n titleDepth += approxTitleDepth(ax);\n }\n }\n\n ax._fullDepth = Math.max(axDepth, titleDepth);\n }\n\n if(ax.automargin) {\n push = {x: 0, y: 0, r: 0, l: 0, t: 0, b: 0};\n var domainIndices = [0, 1];\n var shift = typeof ax._shift === 'number' ? ax._shift : 0;\n if(axLetter === 'x') {\n if(s === 'b') {\n push[s] = ax._depth;\n } else {\n push[s] = ax._depth = Math.max(llbbox.width > 0 ? pos - llbbox.top : 0, outsideTickLen);\n domainIndices.reverse();\n }\n\n if(llbbox.width > 0) {\n var rExtra = llbbox.right - (ax._offset + ax._length);\n if(rExtra > 0) {\n push.xr = 1;\n push.r = rExtra;\n }\n var lExtra = ax._offset - llbbox.left;\n if(lExtra > 0) {\n push.xl = 0;\n push.l = lExtra;\n }\n }\n } else {\n if(s === 'l') {\n ax._depth = Math.max(llbbox.height > 0 ? pos - llbbox.left : 0, outsideTickLen);\n push[s] = ax._depth - shift;\n } else {\n ax._depth = Math.max(llbbox.height > 0 ? llbbox.right - pos : 0, outsideTickLen);\n push[s] = ax._depth + shift;\n domainIndices.reverse();\n }\n\n if(llbbox.height > 0) {\n var bExtra = llbbox.bottom - (ax._offset + ax._length);\n if(bExtra > 0) {\n push.yb = 0;\n push.b = bExtra;\n }\n var tExtra = ax._offset - llbbox.top;\n if(tExtra > 0) {\n push.yt = 1;\n push.t = tExtra;\n }\n }\n }\n\n push[counterLetter] = ax.anchor === 'free' ?\n ax.position :\n ax._anchorAxis.domain[domainIndices[0]];\n\n if(ax.title.text !== fullLayout._dfltTitle[axLetter]) {\n push[s] += approxTitleDepth(ax) + (ax.title.standoff || 0);\n }\n\n if(ax.mirror && ax.anchor !== 'free') {\n mirrorPush = {x: 0, y: 0, r: 0, l: 0, t: 0, b: 0};\n\n mirrorPush[sMirror] = ax.linewidth;\n if(ax.mirror && ax.mirror !== true) mirrorPush[sMirror] += outsideTickLen;\n\n if(ax.mirror === true || ax.mirror === 'ticks') {\n mirrorPush[counterLetter] = ax._anchorAxis.domain[domainIndices[1]];\n } else if(ax.mirror === 'all' || ax.mirror === 'allticks') {\n mirrorPush[counterLetter] = [ax._counterDomainMin, ax._counterDomainMax][domainIndices[1]];\n }\n }\n }\n if(hasRangeSlider) {\n rangeSliderPush = Registry.getComponentMethod('rangeslider', 'autoMarginOpts')(gd, ax);\n }\n\n if(typeof ax.automargin === 'string') {\n filterPush(push, ax.automargin);\n filterPush(mirrorPush, ax.automargin);\n }\n\n Plots.autoMargin(gd, axAutoMarginID(ax), push);\n Plots.autoMargin(gd, axMirrorAutoMarginID(ax), mirrorPush);\n Plots.autoMargin(gd, rangeSliderAutoMarginID(ax), rangeSliderPush);\n });\n\n return Lib.syncOrAsync(seq);\n};\n\nfunction filterPush(push, automargin) {\n if(!push) return;\n\n var keepMargin = Object.keys(MARGIN_MAPPING).reduce(function(data, nextKey) {\n if(automargin.indexOf(nextKey) !== -1) {\n MARGIN_MAPPING[nextKey].forEach(function(key) { data[key] = 1;});\n }\n return data;\n }, {});\n Object.keys(push).forEach(function(key) {\n if(!keepMargin[key]) {\n if(key.length === 1) push[key] = 0;\n else delete push[key];\n }\n });\n}\n\nfunction getBoundaryVals(ax, vals) {\n var out = [];\n var i;\n\n // boundaryVals are never used for labels;\n // no need to worry about the other tickTextObj keys\n var _push = function(d, bndIndex) {\n var xb = d.xbnd[bndIndex];\n if(xb !== null) {\n out.push(Lib.extendFlat({}, d, {x: xb}));\n }\n };\n\n if(vals.length) {\n for(i = 0; i < vals.length; i++) {\n _push(vals[i], 0);\n }\n _push(vals[i - 1], 1);\n }\n\n return out;\n}\n\nfunction getSecondaryLabelVals(ax, vals) {\n var out = [];\n var lookup = {};\n\n for(var i = 0; i < vals.length; i++) {\n var d = vals[i];\n if(lookup[d.text2]) {\n lookup[d.text2].push(d.x);\n } else {\n lookup[d.text2] = [d.x];\n }\n }\n\n for(var k in lookup) {\n out.push(tickTextObj(ax, Lib.interp(lookup[k], 0.5), k));\n }\n\n return out;\n}\n\nfunction getDividerVals(ax, vals) {\n var out = [];\n var i, current;\n\n var reversed = (vals.length && vals[vals.length - 1].x < vals[0].x);\n\n // never used for labels;\n // no need to worry about the other tickTextObj keys\n var _push = function(d, bndIndex) {\n var xb = d.xbnd[bndIndex];\n if(xb !== null) {\n out.push(Lib.extendFlat({}, d, {x: xb}));\n }\n };\n\n if(ax.showdividers && vals.length) {\n for(i = 0; i < vals.length; i++) {\n var d = vals[i];\n if(d.text2 !== current) {\n _push(d, reversed ? 1 : 0);\n }\n current = d.text2;\n }\n _push(vals[i - 1], reversed ? 0 : 1);\n }\n\n return out;\n}\n\nfunction calcLabelLevelBbox(ax, cls, mainLinePositionShift) {\n var top, bottom;\n var left, right;\n\n if(ax._selections[cls].size()) {\n top = Infinity;\n bottom = -Infinity;\n left = Infinity;\n right = -Infinity;\n ax._selections[cls].each(function() {\n var thisLabel = selectTickLabel(this);\n // Use parent node , to make Drawing.bBox\n // retrieve a bbox computed with transform info\n //\n // To improve perf, it would be nice to use `thisLabel.node()`\n // (like in fixLabelOverlaps) instead and use Axes.getPxPosition\n // together with the makeLabelFns outputs and `tickangle`\n // to compute one bbox per (tick value x tick style)\n var bb = Drawing.bBox(thisLabel.node().parentNode);\n top = Math.min(top, bb.top);\n bottom = Math.max(bottom, bb.bottom);\n left = Math.min(left, bb.left);\n right = Math.max(right, bb.right);\n });\n } else {\n var dummyCalc = axes.makeLabelFns(ax, mainLinePositionShift);\n top = bottom = dummyCalc.yFn({dx: 0, dy: 0, fontSize: 0});\n left = right = dummyCalc.xFn({dx: 0, dy: 0, fontSize: 0});\n }\n\n return {\n top: top,\n bottom: bottom,\n left: left,\n right: right,\n height: bottom - top,\n width: right - left\n };\n}\n\n/**\n * Which direction do the 'ax.side' values, and free ticks go?\n *\n * @param {object} ax (full) axis object\n * - {string} _id (starting with 'x' or 'y')\n * - {string} side\n * - {string} ticks\n * @return {array} all entries are either -1 or 1\n * - [0]: sign for top/right ticks (i.e. negative SVG direction)\n * - [1]: sign for bottom/left ticks (i.e. positive SVG direction)\n * - [2]: sign for ticks corresponding to 'ax.side'\n * - [3]: sign for ticks mirroring 'ax.side'\n * - [4]: sign of arrow starting at axis pointing towards margin\n */\naxes.getTickSigns = function(ax, minor) {\n var axLetter = ax._id.charAt(0);\n var sideOpposite = {x: 'top', y: 'right'}[axLetter];\n var main = ax.side === sideOpposite ? 1 : -1;\n var out = [-1, 1, main, -main];\n // then we flip if outside XOR y axis\n\n var ticks = minor ? (ax.minor || {}).ticks : ax.ticks;\n if((ticks !== 'inside') === (axLetter === 'x')) {\n out = out.map(function(v) { return -v; });\n }\n // independent of `ticks`; do not flip this one\n if(ax.side) {\n out.push({l: -1, t: -1, r: 1, b: 1}[ax.side.charAt(0)]);\n }\n return out;\n};\n\n/**\n * Make axis translate transform function\n *\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {number} _offset\n * - {fn} l2p\n * @return {fn} function of calcTicks items\n */\naxes.makeTransTickFn = function(ax) {\n return ax._id.charAt(0) === 'x' ?\n function(d) { return strTranslate(ax._offset + ax.l2p(d.x), 0); } :\n function(d) { return strTranslate(0, ax._offset + ax.l2p(d.x)); };\n};\n\naxes.makeTransTickLabelFn = function(ax) {\n var uv = getTickLabelUV(ax);\n var shift = ax.ticklabelshift || 0;\n var standoff = ax.ticklabelstandoff || 0;\n\n var u = uv[0];\n var v = uv[1];\n\n var isReversed = ax.range[0] > ax.range[1];\n var labelsInside = ax.ticklabelposition && ax.ticklabelposition.indexOf('inside') !== -1;\n var labelsOutside = !labelsInside;\n\n if(shift) {\n var shiftSign = isReversed ? -1 : 1;\n shift = shift * shiftSign;\n }\n if(standoff) {\n var side = ax.side;\n var standoffSign = (\n (labelsInside && (side === 'top' || side === 'left')) ||\n (labelsOutside && (side === 'bottom' || side === 'right'))\n ) ? 1 : -1;\n standoff = standoff * standoffSign;\n }\n return ax._id.charAt(0) === 'x' ?\n function(d) {\n return strTranslate(\n u + ax._offset + ax.l2p(getPosX(d)) + shift,\n v + standoff\n );\n } :\n function(d) {\n return strTranslate(\n v + standoff,\n u + ax._offset + ax.l2p(getPosX(d)) + shift\n );\n };\n};\n\nfunction getPosX(d) {\n return d.periodX !== undefined ? d.periodX : d.x;\n}\n\n// u is a shift along the axis,\n// v is a shift perpendicular to the axis\nfunction getTickLabelUV(ax) {\n var ticklabelposition = ax.ticklabelposition || '';\n var has = function(str) {\n return ticklabelposition.indexOf(str) !== -1;\n };\n\n var isTop = has('top');\n var isLeft = has('left');\n var isRight = has('right');\n var isBottom = has('bottom');\n var isInside = has('inside');\n\n var isAligned = isBottom || isLeft || isTop || isRight;\n\n // early return\n if(!isAligned && !isInside) return [0, 0];\n\n var side = ax.side;\n\n var u = isAligned ? (ax.tickwidth || 0) / 2 : 0;\n var v = TEXTPAD;\n\n var fontSize = ax.tickfont ? ax.tickfont.size : 12;\n if(isBottom || isTop) {\n u += fontSize * CAP_SHIFT;\n v += (ax.linewidth || 0) / 2;\n }\n if(isLeft || isRight) {\n u += (ax.linewidth || 0) / 2;\n v += TEXTPAD;\n }\n if(isInside && side === 'top') {\n v -= fontSize * (1 - CAP_SHIFT);\n }\n\n if(isLeft || isTop) u = -u;\n if(side === 'bottom' || side === 'right') v = -v;\n\n return [\n isAligned ? u : 0,\n isInside ? v : 0\n ];\n}\n\n/**\n * Make axis tick path string\n *\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {number} ticklen\n * - {number} linewidth\n * @param {number} shift along direction of ticklen\n * @param {1 or -1} sgn tick sign\n * @param {object} opts\n * - {number (optional)} len tick length\n * @return {string}\n */\naxes.makeTickPath = function(ax, shift, sgn, opts) {\n if(!opts) opts = {};\n var minor = opts.minor;\n if(minor && !ax.minor) return '';\n\n var len = opts.len !== undefined ? opts.len :\n minor ? ax.minor.ticklen : ax.ticklen;\n\n var axLetter = ax._id.charAt(0);\n var pad = (ax.linewidth || 1) / 2;\n\n return axLetter === 'x' ?\n 'M0,' + (shift + pad * sgn) + 'v' + (len * sgn) :\n 'M' + (shift + pad * sgn) + ',0h' + (len * sgn);\n};\n\n/**\n * Make axis tick label x, y and anchor functions\n *\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {string} ticks\n * - {number} ticklen\n * - {string} side\n * - {number} linewidth\n * - {number} tickfont.size\n * - {boolean} showline\n * @param {number} shift\n * @param {number} angle [in degrees] ...\n * @return {object}\n * - {fn} xFn\n * - {fn} yFn\n * - {fn} anchorFn\n * - {fn} heightFn\n * - {number} labelStandoff (gap parallel to ticks)\n * - {number} labelShift (gap perpendicular to ticks)\n */\naxes.makeLabelFns = function(ax, shift, angle) {\n var ticklabelposition = ax.ticklabelposition || '';\n var has = function(str) {\n return ticklabelposition.indexOf(str) !== -1;\n };\n\n var isTop = has('top');\n var isLeft = has('left');\n var isRight = has('right');\n var isBottom = has('bottom');\n var isAligned = isBottom || isLeft || isTop || isRight;\n\n var insideTickLabels = has('inside');\n var labelsOverTicks =\n (ticklabelposition === 'inside' && ax.ticks === 'inside') ||\n (!insideTickLabels && ax.ticks === 'outside' && ax.tickson !== 'boundaries');\n\n var labelStandoff = 0;\n var labelShift = 0;\n\n var tickLen = labelsOverTicks ? ax.ticklen : 0;\n if(insideTickLabels) {\n tickLen *= -1;\n } else if(isAligned) {\n tickLen = 0;\n }\n\n if(labelsOverTicks) {\n labelStandoff += tickLen;\n if(angle) {\n var rad = Lib.deg2rad(angle);\n labelStandoff = tickLen * Math.cos(rad) + 1;\n labelShift = tickLen * Math.sin(rad);\n }\n }\n\n if(ax.showticklabels && (labelsOverTicks || ax.showline)) {\n labelStandoff += 0.2 * ax.tickfont.size;\n }\n labelStandoff += (ax.linewidth || 1) / 2 * (insideTickLabels ? -1 : 1);\n\n var out = {\n labelStandoff: labelStandoff,\n labelShift: labelShift\n };\n\n var x0, y0, ff, flipIt;\n var xQ = 0;\n\n var side = ax.side;\n var axLetter = ax._id.charAt(0);\n var tickangle = ax.tickangle;\n var endSide;\n if(axLetter === 'x') {\n endSide =\n (!insideTickLabels && side === 'bottom') ||\n (insideTickLabels && side === 'top');\n\n flipIt = endSide ? 1 : -1;\n if(insideTickLabels) flipIt *= -1;\n\n x0 = labelShift * flipIt;\n y0 = shift + labelStandoff * flipIt;\n ff = endSide ? 1 : -0.2;\n if(Math.abs(tickangle) === 90) {\n if(insideTickLabels) {\n ff += MID_SHIFT;\n } else {\n if(tickangle === -90 && side === 'bottom') {\n ff = CAP_SHIFT;\n } else if(tickangle === 90 && side === 'top') {\n ff = MID_SHIFT;\n } else {\n ff = 0.5;\n }\n }\n\n xQ = (MID_SHIFT / 2) * (tickangle / 90);\n }\n\n out.xFn = function(d) { return d.dx + x0 + xQ * d.fontSize; };\n out.yFn = function(d) { return d.dy + y0 + d.fontSize * ff; };\n out.anchorFn = function(d, a) {\n if(isAligned) {\n if(isLeft) return 'end';\n if(isRight) return 'start';\n }\n\n if(!isNumeric(a) || a === 0 || a === 180) {\n return 'middle';\n }\n\n return ((a * flipIt < 0) !== insideTickLabels) ? 'end' : 'start';\n };\n out.heightFn = function(d, a, h) {\n return (a < -60 || a > 60) ? -0.5 * h :\n ((ax.side === 'top') !== insideTickLabels) ? -h :\n 0;\n };\n } else if(axLetter === 'y') {\n endSide =\n (!insideTickLabels && side === 'left') ||\n (insideTickLabels && side === 'right');\n\n flipIt = endSide ? 1 : -1;\n if(insideTickLabels) flipIt *= -1;\n\n x0 = labelStandoff;\n y0 = labelShift * flipIt;\n ff = 0;\n if(!insideTickLabels && Math.abs(tickangle) === 90) {\n if(\n (tickangle === -90 && side === 'left') ||\n (tickangle === 90 && side === 'right')\n ) {\n ff = CAP_SHIFT;\n } else {\n ff = 0.5;\n }\n }\n\n if(insideTickLabels) {\n var ang = isNumeric(tickangle) ? +tickangle : 0;\n if(ang !== 0) {\n var rA = Lib.deg2rad(ang);\n xQ = Math.abs(Math.sin(rA)) * CAP_SHIFT * flipIt;\n ff = 0;\n }\n }\n\n out.xFn = function(d) { return d.dx + shift - (x0 + d.fontSize * ff) * flipIt + xQ * d.fontSize; };\n out.yFn = function(d) { return d.dy + y0 + d.fontSize * MID_SHIFT; };\n out.anchorFn = function(d, a) {\n if(isNumeric(a) && Math.abs(a) === 90) {\n return 'middle';\n }\n\n return endSide ? 'end' : 'start';\n };\n out.heightFn = function(d, a, h) {\n if(ax.side === 'right') a *= -1;\n\n return a < -30 ? -h :\n a < 30 ? -0.5 * h :\n 0;\n };\n }\n\n return out;\n};\n\nfunction tickDataFn(d) {\n return [d.text, d.x, d.axInfo, d.font, d.fontSize, d.fontColor].join('_');\n}\n\n/**\n * Draw axis ticks\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {string} ticks\n * - {number} linewidth\n * - {string} tickcolor\n * @param {object} opts\n * - {array of object} vals (calcTicks output-like)\n * - {d3 selection} layer\n * - {string or fn} path\n * - {fn} transFn\n * - {boolean} crisp (set to false to unset crisp-edge SVG rendering)\n */\naxes.drawTicks = function(gd, ax, opts) {\n opts = opts || {};\n\n var cls = ax._id + 'tick';\n\n var vals = []\n .concat(ax.minor && ax.minor.ticks ?\n // minor vals\n opts.vals.filter(function(d) { return d.minor && !d.noTick; }) :\n []\n )\n .concat(ax.ticks ?\n // major vals\n opts.vals.filter(function(d) { return !d.minor && !d.noTick; }) :\n []\n );\n\n var ticks = opts.layer.selectAll('path.' + cls)\n .data(vals, tickDataFn);\n\n ticks.exit().remove();\n\n ticks.enter().append('path')\n .classed(cls, 1)\n .classed('ticks', 1)\n .classed('crisp', opts.crisp !== false)\n .each(function(d) {\n return Color.stroke(d3.select(this), d.minor ? ax.minor.tickcolor : ax.tickcolor);\n })\n .style('stroke-width', function(d) {\n return Drawing.crispRound(\n gd,\n d.minor ? ax.minor.tickwidth : ax.tickwidth,\n 1\n ) + 'px';\n })\n .attr('d', opts.path)\n .style('display', null); // visible\n\n hideCounterAxisInsideTickLabels(ax, [TICK_PATH]);\n\n ticks.attr('transform', opts.transFn);\n};\n\n/**\n * Draw axis grid\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {boolean} showgrid\n * - {string} gridcolor\n * - {string} gridwidth\n * - {string} griddash\n * - {boolean} zeroline\n * - {string} type\n * - {string} dtick\n * @param {object} opts\n * - {array of object} vals (calcTicks output-like)\n * - {d3 selection} layer\n * - {object} counterAxis (full axis object corresponding to counter axis)\n * optional - only required if this axis supports zero lines\n * - {string or fn} path\n * - {fn} transFn\n * - {boolean} crisp (set to false to unset crisp-edge SVG rendering)\n */\naxes.drawGrid = function(gd, ax, opts) {\n opts = opts || {};\n\n if(ax.tickmode === 'sync') {\n // for tickmode sync we use the overlaying axis grid\n return;\n }\n\n var cls = ax._id + 'grid';\n\n var hasMinor = ax.minor && ax.minor.showgrid;\n var minorVals = hasMinor ? opts.vals.filter(function(d) { return d.minor; }) : [];\n var majorVals = ax.showgrid ? opts.vals.filter(function(d) { return !d.minor; }) : [];\n\n var counterAx = opts.counterAxis;\n if(counterAx && axes.shouldShowZeroLine(gd, ax, counterAx)) {\n var isArrayMode = ax.tickmode === 'array';\n for(var i = 0; i < majorVals.length; i++) {\n var xi = majorVals[i].x;\n if(isArrayMode ? !xi : (Math.abs(xi) < ax.dtick / 100)) {\n majorVals = majorVals.slice(0, i).concat(majorVals.slice(i + 1));\n // In array mode you can in principle have multiple\n // ticks at 0, so test them all. Otherwise once we found\n // one we can stop.\n if(isArrayMode) i--;\n else break;\n }\n }\n }\n\n ax._gw =\n Drawing.crispRound(gd, ax.gridwidth, 1);\n\n var wMinor = !hasMinor ? 0 :\n Drawing.crispRound(gd, ax.minor.gridwidth, 1);\n\n var majorLayer = opts.layer;\n var minorLayer = opts.minorLayer;\n for(var major = 1; major >= 0; major--) {\n var layer = major ? majorLayer : minorLayer;\n if(!layer) continue;\n\n var grid = layer.selectAll('path.' + cls)\n .data(major ? majorVals : minorVals, tickDataFn);\n\n grid.exit().remove();\n\n grid.enter().append('path')\n .classed(cls, 1)\n .classed('crisp', opts.crisp !== false);\n\n grid.attr('transform', opts.transFn)\n .attr('d', opts.path)\n .each(function(d) {\n return Color.stroke(d3.select(this), d.minor ?\n ax.minor.gridcolor :\n (ax.gridcolor || '#ddd')\n );\n })\n .style('stroke-dasharray', function(d) {\n return Drawing.dashStyle(\n d.minor ? ax.minor.griddash : ax.griddash,\n d.minor ? ax.minor.gridwidth : ax.gridwidth\n );\n })\n .style('stroke-width', function(d) {\n return (d.minor ? wMinor : ax._gw) + 'px';\n })\n .style('display', null); // visible\n\n if(typeof opts.path === 'function') grid.attr('d', opts.path);\n }\n\n hideCounterAxisInsideTickLabels(ax, [GRID_PATH, MINORGRID_PATH]);\n};\n\n/**\n * Draw axis zero-line\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {boolean} zeroline\n * - {number} zerolinewidth\n * - {string} zerolinecolor\n * - {number (optional)} _gridWidthCrispRound\n * @param {object} opts\n * - {d3 selection} layer\n * - {object} counterAxis (full axis object corresponding to counter axis)\n * - {string or fn} path\n * - {fn} transFn\n * - {boolean} crisp (set to false to unset crisp-edge SVG rendering)\n */\naxes.drawZeroLine = function(gd, ax, opts) {\n opts = opts || opts;\n\n var cls = ax._id + 'zl';\n var show = axes.shouldShowZeroLine(gd, ax, opts.counterAxis);\n\n var zl = opts.layer.selectAll('path.' + cls)\n .data(show ? [{x: 0, id: ax._id}] : []);\n\n zl.exit().remove();\n\n zl.enter().append('path')\n .classed(cls, 1)\n .classed('zl', 1)\n .classed('crisp', opts.crisp !== false)\n .each(function() {\n // use the fact that only one element can enter to trigger a sort.\n // If several zerolines enter at the same time we will sort once per,\n // but generally this should be a minimal overhead.\n opts.layer.selectAll('path').sort(function(da, db) {\n return idSort(da.id, db.id);\n });\n });\n\n zl.attr('transform', opts.transFn)\n .attr('d', opts.path)\n .call(Color.stroke, ax.zerolinecolor || Color.defaultLine)\n .style('stroke-width', Drawing.crispRound(gd, ax.zerolinewidth, ax._gw || 1) + 'px')\n .style('display', null); // visible\n\n hideCounterAxisInsideTickLabels(ax, [ZERO_PATH]);\n};\n\n/**\n * Draw axis tick labels\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {boolean} showticklabels\n * - {number} tickangle\n * - {object (optional)} _selections\n * - {object} (optional)} _tickAngles\n * - {object} (optional)} _prevTickAngles\n * @param {object} opts\n * - {array of object} vals (calcTicks output-like)\n * - {d3 selection} layer\n * - {string (optional)} cls (node className)\n * - {boolean} repositionOnUpdate (set to true to reposition update selection)\n * - {boolean} secondary\n * - {fn} transFn\n * - {object} labelFns\n * + {fn} xFn\n * + {fn} yFn\n * + {fn} anchorFn\n * + {fn} heightFn\n */\naxes.drawLabels = function(gd, ax, opts) {\n opts = opts || {};\n\n var fullLayout = gd._fullLayout;\n var axId = ax._id;\n var cls = opts.cls || axId + 'tick';\n\n var vals = opts.vals.filter(function(d) { return d.text; });\n\n var labelFns = opts.labelFns;\n var tickAngle = opts.secondary ? 0 : ax.tickangle;\n\n var prevAngle = (ax._prevTickAngles || {})[cls];\n\n var tickLabels = opts.layer.selectAll('g.' + cls)\n .data(ax.showticklabels ? vals : [], tickDataFn);\n\n var labelsReady = [];\n\n tickLabels.enter().append('g')\n .classed(cls, 1)\n .append('text')\n // only so tex has predictable alignment that we can\n // alter later\n .attr('text-anchor', 'middle')\n .each(function(d) {\n var thisLabel = d3.select(this);\n var newPromise = gd._promises.length;\n\n thisLabel\n .call(svgTextUtils.positionText, labelFns.xFn(d), labelFns.yFn(d))\n .call(Drawing.font, {\n family: d.font,\n size: d.fontSize,\n color: d.fontColor,\n weight: d.fontWeight,\n style: d.fontStyle,\n variant: d.fontVariant,\n textcase: d.fontTextcase,\n lineposition: d.fontLineposition,\n shadow: d.fontShadow,\n })\n .text(d.text)\n .call(svgTextUtils.convertToTspans, gd);\n\n if(gd._promises[newPromise]) {\n // if we have an async label, we'll deal with that\n // all here so take it out of gd._promises and\n // instead position the label and promise this in\n // labelsReady\n labelsReady.push(gd._promises.pop().then(function() {\n positionLabels(thisLabel, tickAngle);\n }));\n } else {\n // sync label: just position it now.\n positionLabels(thisLabel, tickAngle);\n }\n });\n\n hideCounterAxisInsideTickLabels(ax, [TICK_TEXT]);\n\n tickLabels.exit().remove();\n\n if(opts.repositionOnUpdate) {\n tickLabels.each(function(d) {\n d3.select(this).select('text')\n .call(svgTextUtils.positionText, labelFns.xFn(d), labelFns.yFn(d));\n });\n }\n\n function positionLabels(s, angle) {\n s.each(function(d) {\n var thisLabel = d3.select(this);\n var mathjaxGroup = thisLabel.select('.text-math-group');\n var anchor = labelFns.anchorFn(d, angle);\n\n var transform = opts.transFn.call(thisLabel.node(), d) +\n ((isNumeric(angle) && +angle !== 0) ?\n (' rotate(' + angle + ',' + labelFns.xFn(d) + ',' +\n (labelFns.yFn(d) - d.fontSize / 2) + ')') :\n '');\n\n // how much to shift a multi-line label to center it vertically.\n var nLines = svgTextUtils.lineCount(thisLabel);\n var lineHeight = LINE_SPACING * d.fontSize;\n var anchorHeight = labelFns.heightFn(d, isNumeric(angle) ? +angle : 0, (nLines - 1) * lineHeight);\n\n if(anchorHeight) {\n transform += strTranslate(0, anchorHeight);\n }\n\n if(mathjaxGroup.empty()) {\n var thisText = thisLabel.select('text');\n thisText.attr({\n transform: transform,\n 'text-anchor': anchor\n });\n\n thisText.style('opacity', 1); // visible\n\n if(ax._adjustTickLabelsOverflow) {\n ax._adjustTickLabelsOverflow();\n }\n } else {\n var mjWidth = Drawing.bBox(mathjaxGroup.node()).width;\n var mjShift = mjWidth * {end: -0.5, start: 0.5}[anchor];\n mathjaxGroup.attr('transform', transform + strTranslate(mjShift, 0));\n }\n });\n }\n\n ax._adjustTickLabelsOverflow = function() {\n var ticklabeloverflow = ax.ticklabeloverflow;\n if(!ticklabeloverflow || ticklabeloverflow === 'allow') return;\n\n var hideOverflow = ticklabeloverflow.indexOf('hide') !== -1;\n\n var isX = ax._id.charAt(0) === 'x';\n // div positions\n var p0 = 0;\n var p1 = isX ?\n gd._fullLayout.width :\n gd._fullLayout.height;\n\n if(ticklabeloverflow.indexOf('domain') !== -1) {\n // domain positions\n var rl = Lib.simpleMap(ax.range, ax.r2l);\n p0 = ax.l2p(rl[0]) + ax._offset;\n p1 = ax.l2p(rl[1]) + ax._offset;\n }\n\n var min = Math.min(p0, p1);\n var max = Math.max(p0, p1);\n\n var side = ax.side;\n\n var visibleLabelMin = Infinity;\n var visibleLabelMax = -Infinity;\n\n tickLabels.each(function(d) {\n var thisLabel = d3.select(this);\n var mathjaxGroup = thisLabel.select('.text-math-group');\n\n if(mathjaxGroup.empty()) {\n var bb = Drawing.bBox(thisLabel.node());\n var adjust = 0;\n if(isX) {\n if(bb.right > max) adjust = 1;\n else if(bb.left < min) adjust = 1;\n } else {\n if(bb.bottom > max) adjust = 1;\n else if(bb.top + (ax.tickangle ? 0 : d.fontSize / 4) < min) adjust = 1;\n }\n\n var t = thisLabel.select('text');\n if(adjust) {\n if(hideOverflow) t.style('opacity', 0); // hidden\n } else {\n t.style('opacity', 1); // visible\n\n if(side === 'bottom' || side === 'right') {\n visibleLabelMin = Math.min(visibleLabelMin, isX ? bb.top : bb.left);\n } else {\n visibleLabelMin = -Infinity;\n }\n\n if(side === 'top' || side === 'left') {\n visibleLabelMax = Math.max(visibleLabelMax, isX ? bb.bottom : bb.right);\n } else {\n visibleLabelMax = Infinity;\n }\n }\n } // TODO: hide mathjax?\n });\n\n for(var subplot in fullLayout._plots) {\n var plotinfo = fullLayout._plots[subplot];\n if(ax._id !== plotinfo.xaxis._id && ax._id !== plotinfo.yaxis._id) continue;\n var anchorAx = isX ? plotinfo.yaxis : plotinfo.xaxis;\n if(anchorAx) {\n anchorAx['_visibleLabelMin_' + ax._id] = visibleLabelMin;\n anchorAx['_visibleLabelMax_' + ax._id] = visibleLabelMax;\n }\n }\n };\n\n ax._hideCounterAxisInsideTickLabels = function(partialOpts) {\n var isX = ax._id.charAt(0) === 'x';\n\n var anchoredAxes = [];\n for(var subplot in fullLayout._plots) {\n var plotinfo = fullLayout._plots[subplot];\n if(ax._id !== plotinfo.xaxis._id && ax._id !== plotinfo.yaxis._id) continue;\n anchoredAxes.push(isX ? plotinfo.yaxis : plotinfo.xaxis);\n }\n\n anchoredAxes.forEach(function(anchorAx, idx) {\n if(anchorAx && insideTicklabelposition(anchorAx)) {\n (partialOpts || [\n ZERO_PATH,\n MINORGRID_PATH,\n GRID_PATH,\n TICK_PATH,\n TICK_TEXT\n ]).forEach(function(e) {\n var isPeriodLabel =\n e.K === 'tick' &&\n e.L === 'text' &&\n ax.ticklabelmode === 'period';\n\n var mainPlotinfo = fullLayout._plots[ax._mainSubplot];\n\n var sel;\n if(e.K === ZERO_PATH.K) sel = mainPlotinfo.zerolinelayer.selectAll('.' + ax._id + 'zl');\n else if(e.K === MINORGRID_PATH.K) sel = mainPlotinfo.minorGridlayer.selectAll('.' + ax._id);\n else if(e.K === GRID_PATH.K) sel = mainPlotinfo.gridlayer.selectAll('.' + ax._id);\n else sel = mainPlotinfo[ax._id.charAt(0) + 'axislayer'];\n\n sel.each(function() {\n var w = d3.select(this);\n if(e.L) w = w.selectAll(e.L);\n\n w.each(function(d) {\n var q = ax.l2p(\n isPeriodLabel ? getPosX(d) : d.x\n ) + ax._offset;\n\n var t = d3.select(this);\n if(\n q < ax['_visibleLabelMax_' + anchorAx._id] &&\n q > ax['_visibleLabelMin_' + anchorAx._id]\n ) {\n t.style('display', 'none'); // hidden\n } else if(e.K === 'tick' && !idx) {\n t.style('display', null); // visible\n }\n });\n });\n });\n }\n });\n };\n\n // make sure all labels are correctly positioned at their base angle\n // the positionLabels call above is only for newly drawn labels.\n // do this without waiting, using the last calculated angle to\n // minimize flicker, then do it again when we know all labels are\n // there, putting back the prescribed angle to check for overlaps.\n positionLabels(tickLabels, (prevAngle + 1) ? prevAngle : tickAngle);\n\n function allLabelsReady() {\n return labelsReady.length && Promise.all(labelsReady);\n }\n\n var autoangle = null;\n\n function fixLabelOverlaps() {\n positionLabels(tickLabels, tickAngle);\n\n // check for auto-angling if x labels overlap\n // don't auto-angle at all for log axes with\n // base and digit format\n if(vals.length && ax.autotickangles &&\n (ax.type !== 'log' || String(ax.dtick).charAt(0) !== 'D')\n ) {\n autoangle = ax.autotickangles[0];\n\n var maxFontSize = 0;\n var lbbArray = [];\n var i;\n var maxLines = 1;\n tickLabels.each(function(d) {\n maxFontSize = Math.max(maxFontSize, d.fontSize);\n\n var x = ax.l2p(d.x);\n var thisLabel = selectTickLabel(this);\n var bb = Drawing.bBox(thisLabel.node());\n maxLines = Math.max(maxLines, svgTextUtils.lineCount(thisLabel));\n\n lbbArray.push({\n // ignore about y, just deal with x overlaps\n top: 0,\n bottom: 10,\n height: 10,\n left: x - bb.width / 2,\n // impose a 2px gap\n right: x + bb.width / 2 + 2,\n width: bb.width + 2\n });\n });\n\n // autotickangles\n // if there are dividers or ticks on boundaries, the labels will be in between and\n // we need to prevent overlap with the next divider/tick. Else the labels will be on\n // the ticks and we need to prevent overlap with the next label.\n\n // TODO should secondary labels also fall into this fix-overlap regime?\n var preventOverlapWithTick = (ax.tickson === 'boundaries' || ax.showdividers) && !opts.secondary;\n\n var vLen = vals.length;\n var tickSpacing = Math.abs((vals[vLen - 1].x - vals[0].x) * ax._m) / (vLen - 1);\n\n var adjacent = preventOverlapWithTick ? tickSpacing / 2 : tickSpacing;\n var opposite = preventOverlapWithTick ? ax.ticklen : maxFontSize * 1.25 * maxLines;\n var hypotenuse = Math.sqrt(Math.pow(adjacent, 2) + Math.pow(opposite, 2));\n var maxCos = adjacent / hypotenuse;\n var autoTickAnglesRadians = ax.autotickangles.map(\n function(degrees) { return degrees * Math.PI / 180; }\n );\n var angleRadians = autoTickAnglesRadians.find(\n function(angle) { return Math.abs(Math.cos(angle)) <= maxCos; }\n );\n if(angleRadians === undefined) {\n // no angle with smaller cosine than maxCos, just pick the angle with smallest cosine\n angleRadians = autoTickAnglesRadians.reduce(\n function(currentMax, nextAngle) {\n return Math.abs(Math.cos(currentMax)) < Math.abs(Math.cos(nextAngle)) ? currentMax : nextAngle;\n }\n , autoTickAnglesRadians[0]\n );\n }\n var newAngle = angleRadians * (180 / Math.PI /* to degrees */);\n\n if(preventOverlapWithTick) {\n var gap = 2;\n if(ax.ticks) gap += ax.tickwidth / 2;\n\n for(i = 0; i < lbbArray.length; i++) {\n var xbnd = vals[i].xbnd;\n var lbb = lbbArray[i];\n if(\n (xbnd[0] !== null && (lbb.left - ax.l2p(xbnd[0])) < gap) ||\n (xbnd[1] !== null && (ax.l2p(xbnd[1]) - lbb.right) < gap)\n ) {\n autoangle = newAngle;\n break;\n }\n }\n } else {\n var ticklabelposition = ax.ticklabelposition || '';\n var has = function(str) {\n return ticklabelposition.indexOf(str) !== -1;\n };\n var isTop = has('top');\n var isLeft = has('left');\n var isRight = has('right');\n var isBottom = has('bottom');\n var isAligned = isBottom || isLeft || isTop || isRight;\n var pad = !isAligned ? 0 :\n (ax.tickwidth || 0) + 2 * TEXTPAD;\n\n for(i = 0; i < lbbArray.length - 1; i++) {\n if(Lib.bBoxIntersect(lbbArray[i], lbbArray[i + 1], pad)) {\n autoangle = newAngle;\n break;\n }\n }\n }\n\n if(autoangle) {\n positionLabels(tickLabels, autoangle);\n }\n }\n }\n\n if(ax._selections) {\n ax._selections[cls] = tickLabels;\n }\n\n var seq = [allLabelsReady];\n\n // N.B. during auto-margin redraws, if the axis fixed its label overlaps\n // by rotating 90 degrees, do not attempt to re-fix its label overlaps\n // as this can lead to infinite redraw loops!\n if(ax.automargin && fullLayout._redrawFromAutoMarginCount && prevAngle === 90) {\n autoangle = prevAngle;\n seq.push(function() {\n positionLabels(tickLabels, prevAngle);\n });\n } else {\n seq.push(fixLabelOverlaps);\n }\n\n // save current tick angle for future redraws\n if(ax._tickAngles) {\n seq.push(function() {\n ax._tickAngles[cls] = autoangle === null ?\n (isNumeric(tickAngle) ? tickAngle : 0) :\n autoangle;\n });\n }\n\n var computeTickLabelBoundingBoxes = function() {\n var labelsMaxW = 0;\n var labelsMaxH = 0;\n tickLabels.each(function(d, i) {\n var thisLabel = selectTickLabel(this);\n var mathjaxGroup = thisLabel.select('.text-math-group');\n\n if(mathjaxGroup.empty()) {\n var bb;\n\n if(ax._vals[i]) {\n bb = ax._vals[i].bb || Drawing.bBox(thisLabel.node());\n ax._vals[i].bb = bb;\n }\n\n labelsMaxW = Math.max(labelsMaxW, bb.width);\n labelsMaxH = Math.max(labelsMaxH, bb.height);\n }\n });\n\n return {\n labelsMaxW: labelsMaxW,\n labelsMaxH: labelsMaxH\n };\n };\n\n var anchorAx = ax._anchorAxis;\n if(\n anchorAx && (anchorAx.autorange || anchorAx.insiderange) &&\n insideTicklabelposition(ax) &&\n !isLinked(fullLayout, ax._id)\n ) {\n if(!fullLayout._insideTickLabelsUpdaterange) {\n fullLayout._insideTickLabelsUpdaterange = {};\n }\n\n if(anchorAx.autorange) {\n fullLayout._insideTickLabelsUpdaterange[anchorAx._name + '.autorange'] = anchorAx.autorange;\n\n seq.push(computeTickLabelBoundingBoxes);\n }\n\n if(anchorAx.insiderange) {\n var BBs = computeTickLabelBoundingBoxes();\n var move = ax._id.charAt(0) === 'y' ?\n BBs.labelsMaxW :\n BBs.labelsMaxH;\n\n move += 2 * TEXTPAD;\n\n if(ax.ticklabelposition === 'inside') {\n move += ax.ticklen || 0;\n }\n\n var sgn = (ax.side === 'right' || ax.side === 'top') ? 1 : -1;\n var index = sgn === 1 ? 1 : 0;\n var otherIndex = sgn === 1 ? 0 : 1;\n\n var newRange = [];\n newRange[otherIndex] = anchorAx.range[otherIndex];\n\n var anchorAxRange = anchorAx.range;\n\n var p0 = anchorAx.r2p(anchorAxRange[index]);\n var p1 = anchorAx.r2p(anchorAxRange[otherIndex]);\n\n var _tempNewRange = fullLayout._insideTickLabelsUpdaterange[anchorAx._name + '.range'];\n if(_tempNewRange) { // case of having multiple anchored axes having insideticklabel\n var q0 = anchorAx.r2p(_tempNewRange[index]);\n var q1 = anchorAx.r2p(_tempNewRange[otherIndex]);\n\n var dir = sgn * (ax._id.charAt(0) === 'y' ? 1 : -1);\n\n if(dir * p0 < dir * q0) {\n p0 = q0;\n newRange[index] = anchorAxRange[index] = _tempNewRange[index];\n }\n\n if(dir * p1 > dir * q1) {\n p1 = q1;\n newRange[otherIndex] = anchorAxRange[otherIndex] = _tempNewRange[otherIndex];\n }\n }\n\n var dist = Math.abs(p1 - p0);\n if(dist - move > 0) {\n dist -= move;\n move *= 1 + move / dist;\n } else {\n move = 0;\n }\n\n if(ax._id.charAt(0) !== 'y') move = -move;\n\n newRange[index] = anchorAx.p2r(\n anchorAx.r2p(anchorAxRange[index]) +\n sgn * move\n );\n\n // handle partial ranges in insiderange\n if(\n anchorAx.autorange === 'min' ||\n anchorAx.autorange === 'max reversed'\n ) {\n newRange[0] = null;\n\n anchorAx._rangeInitial0 = undefined;\n anchorAx._rangeInitial1 = undefined;\n } else if(\n anchorAx.autorange === 'max' ||\n anchorAx.autorange === 'min reversed'\n ) {\n newRange[1] = null;\n\n anchorAx._rangeInitial0 = undefined;\n anchorAx._rangeInitial1 = undefined;\n }\n\n fullLayout._insideTickLabelsUpdaterange[anchorAx._name + '.range'] = newRange;\n }\n }\n\n var done = Lib.syncOrAsync(seq);\n if(done && done.then) gd._promises.push(done);\n return done;\n};\n\n/**\n * Draw axis dividers\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {string} showdividers\n * - {number} dividerwidth\n * - {string} dividercolor\n * @param {object} opts\n * - {array of object} vals (calcTicks output-like)\n * - {d3 selection} layer\n * - {fn} path\n * - {fn} transFn\n */\nfunction drawDividers(gd, ax, opts) {\n var cls = ax._id + 'divider';\n var vals = opts.vals;\n\n var dividers = opts.layer.selectAll('path.' + cls)\n .data(vals, tickDataFn);\n\n dividers.exit().remove();\n\n dividers.enter().insert('path', ':first-child')\n .classed(cls, 1)\n .classed('crisp', 1)\n .call(Color.stroke, ax.dividercolor)\n .style('stroke-width', Drawing.crispRound(gd, ax.dividerwidth, 1) + 'px');\n\n dividers\n .attr('transform', opts.transFn)\n .attr('d', opts.path);\n}\n\n/**\n * Get axis position in px, that is the distance for the graph's\n * top (left) edge for x (y) axes.\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {string} side\n * if anchored:\n * - {object} _anchorAxis\n * Otherwise:\n * - {number} position\n * @return {number}\n */\naxes.getPxPosition = function(gd, ax) {\n var gs = gd._fullLayout._size;\n var axLetter = ax._id.charAt(0);\n var side = ax.side;\n var anchorAxis;\n\n if(ax.anchor !== 'free') {\n anchorAxis = ax._anchorAxis;\n } else if(axLetter === 'x') {\n anchorAxis = {\n _offset: gs.t + (1 - (ax.position || 0)) * gs.h,\n _length: 0\n };\n } else if(axLetter === 'y') {\n anchorAxis = {\n _offset: gs.l + (ax.position || 0) * gs.w + ax._shift,\n _length: 0\n };\n }\n\n if(side === 'top' || side === 'left') {\n return anchorAxis._offset;\n } else if(side === 'bottom' || side === 'right') {\n return anchorAxis._offset + anchorAxis._length;\n }\n};\n\n/**\n * Approximate axis title depth (w/o computing its bounding box)\n *\n * @param {object} ax (full) axis object\n * - {string} title.text\n * - {number} title.font.size\n * - {number} title.standoff\n * @return {number} (in px)\n */\nfunction approxTitleDepth(ax) {\n var fontSize = ax.title.font.size;\n var extraLines = (ax.title.text.match(svgTextUtils.BR_TAG_ALL) || []).length;\n if(ax.title.hasOwnProperty('standoff')) {\n return fontSize * (CAP_SHIFT + (extraLines * LINE_SPACING));\n } else {\n return extraLines ?\n fontSize * (extraLines + 1) * LINE_SPACING :\n fontSize;\n }\n}\n\n/**\n * Draw axis title, compute default standoff if necessary\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {string} _name\n * - {string} side\n * - {number} title.font.size\n * - {object} _selections\n *\n * - {number} _depth\n * - {number} title.standoff\n * OR\n * - {number} linewidth\n * - {boolean} showticklabels\n */\nfunction drawTitle(gd, ax) {\n var fullLayout = gd._fullLayout;\n var axId = ax._id;\n var axLetter = axId.charAt(0);\n var fontSize = ax.title.font.size;\n var titleStandoff;\n var extraLines = (ax.title.text.match(svgTextUtils.BR_TAG_ALL) || []).length;\n\n if(ax.title.hasOwnProperty('standoff')) {\n // With ax._depth the initial drawing baseline is at the outer axis border (where the\n // ticklabels are drawn). Since the title text will be drawn above the baseline,\n // bottom/right axes must be shifted by 1 text line to draw below ticklabels instead of on\n // top of them, whereas for top/left axes, the first line would be drawn\n // before the ticklabels, but we need an offset for the descender portion of the first line\n // and all subsequent lines.\n if(ax.side === 'bottom' || ax.side === 'right') {\n titleStandoff = ax._depth + ax.title.standoff + fontSize * CAP_SHIFT;\n } else if(ax.side === 'top' || ax.side === 'left') {\n titleStandoff = ax._depth + ax.title.standoff + fontSize * (MID_SHIFT + (extraLines * LINE_SPACING));\n }\n } else {\n var isInside = insideTicklabelposition(ax);\n\n if(ax.type === 'multicategory') {\n titleStandoff = ax._depth;\n } else {\n var offsetBase = 1.5 * fontSize;\n if(isInside) {\n offsetBase = 0.5 * fontSize;\n if(ax.ticks === 'outside') {\n offsetBase += ax.ticklen;\n }\n }\n titleStandoff = 10 + offsetBase + (ax.linewidth ? ax.linewidth - 1 : 0);\n }\n\n if(!isInside) {\n if(axLetter === 'x') {\n titleStandoff += ax.side === 'top' ?\n fontSize * (ax.showticklabels ? 1 : 0) :\n fontSize * (ax.showticklabels ? 1.5 : 0.5);\n } else {\n titleStandoff += ax.side === 'right' ?\n fontSize * (ax.showticklabels ? 1 : 0.5) :\n fontSize * (ax.showticklabels ? 0.5 : 0);\n }\n }\n }\n\n var pos = axes.getPxPosition(gd, ax);\n var transform, x, y;\n\n if(axLetter === 'x') {\n x = ax._offset + ax._length / 2;\n y = (ax.side === 'top') ? pos - titleStandoff : pos + titleStandoff;\n } else {\n y = ax._offset + ax._length / 2;\n x = (ax.side === 'right') ? pos + titleStandoff : pos - titleStandoff;\n transform = {rotate: '-90', offset: 0};\n }\n\n var avoid;\n\n if(ax.type !== 'multicategory') {\n var tickLabels = ax._selections[ax._id + 'tick'];\n\n avoid = {\n selection: tickLabels,\n side: ax.side\n };\n\n if(tickLabels && tickLabels.node() && tickLabels.node().parentNode) {\n var translation = Drawing.getTranslate(tickLabels.node().parentNode);\n avoid.offsetLeft = translation.x;\n avoid.offsetTop = translation.y;\n }\n\n if(ax.title.hasOwnProperty('standoff')) {\n avoid.pad = 0;\n }\n }\n\n ax._titleStandoff = titleStandoff;\n\n return Titles.draw(gd, axId + 'title', {\n propContainer: ax,\n propName: ax._name + '.title.text',\n placeholder: fullLayout._dfltTitle[axLetter],\n avoid: avoid,\n transform: transform,\n attributes: {x: x, y: y, 'text-anchor': 'middle'}\n });\n}\n\naxes.shouldShowZeroLine = function(gd, ax, counterAxis) {\n var rng = Lib.simpleMap(ax.range, ax.r2l);\n return (\n (rng[0] * rng[1] <= 0) &&\n ax.zeroline &&\n (ax.type === 'linear' || ax.type === '-') &&\n !(ax.rangebreaks && ax.maskBreaks(0) === BADNUM) &&\n (\n clipEnds(ax, 0) ||\n !anyCounterAxLineAtZero(gd, ax, counterAxis, rng) ||\n hasBarsOrFill(gd, ax)\n )\n );\n};\n\naxes.clipEnds = function(ax, vals) {\n return vals.filter(function(d) { return clipEnds(ax, d.x); });\n};\n\nfunction clipEnds(ax, l) {\n var p = ax.l2p(l);\n return (p > 1 && p < ax._length - 1);\n}\n\nfunction anyCounterAxLineAtZero(gd, ax, counterAxis, rng) {\n var mainCounterAxis = counterAxis._mainAxis;\n if(!mainCounterAxis) return;\n\n var fullLayout = gd._fullLayout;\n var axLetter = ax._id.charAt(0);\n var counterLetter = axes.counterLetter(ax._id);\n\n var zeroPosition = ax._offset + (\n ((Math.abs(rng[0]) < Math.abs(rng[1])) === (axLetter === 'x')) ?\n 0 : ax._length\n );\n\n function lineNearZero(ax2) {\n if(!ax2.showline || !ax2.linewidth) return false;\n var tolerance = Math.max((ax2.linewidth + ax.zerolinewidth) / 2, 1);\n\n function closeEnough(pos2) {\n return typeof pos2 === 'number' && Math.abs(pos2 - zeroPosition) < tolerance;\n }\n\n if(closeEnough(ax2._mainLinePosition) || closeEnough(ax2._mainMirrorPosition)) {\n return true;\n }\n var linePositions = ax2._linepositions || {};\n for(var k in linePositions) {\n if(closeEnough(linePositions[k][0]) || closeEnough(linePositions[k][1])) {\n return true;\n }\n }\n }\n\n var plotinfo = fullLayout._plots[counterAxis._mainSubplot];\n if(!(plotinfo.mainplotinfo || plotinfo).overlays.length) {\n return lineNearZero(counterAxis, zeroPosition);\n }\n\n var counterLetterAxes = axes.list(gd, counterLetter);\n for(var i = 0; i < counterLetterAxes.length; i++) {\n var counterAxis2 = counterLetterAxes[i];\n if(\n counterAxis2._mainAxis === mainCounterAxis &&\n lineNearZero(counterAxis2, zeroPosition)\n ) {\n return true;\n }\n }\n}\n\nfunction hasBarsOrFill(gd, ax) {\n var fullData = gd._fullData;\n var subplot = ax._mainSubplot;\n var axLetter = ax._id.charAt(0);\n\n for(var i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n\n if(trace.visible === true && (trace.xaxis + trace.yaxis) === subplot) {\n if(\n Registry.traceIs(trace, 'bar-like') &&\n trace.orientation === {x: 'h', y: 'v'}[axLetter]\n ) return true;\n\n if(\n trace.fill &&\n trace.fill.charAt(trace.fill.length - 1) === axLetter\n ) return true;\n }\n }\n return false;\n}\n\nfunction selectTickLabel(gTick) {\n var s = d3.select(gTick);\n var mj = s.select('.text-math-group');\n return mj.empty() ? s.select('text') : mj;\n}\n\n/**\n * Find all margin pushers for 2D axes and reserve them for later use\n * Both label and rangeslider automargin calculations happen later so\n * we need to explicitly allow their ids in order to not delete them.\n *\n * TODO: can we pull the actual automargin calls forward to avoid this hack?\n * We're probably also doing multiple redraws in this case, would be faster\n * if we can just do the whole calculation ahead of time and draw once.\n */\naxes.allowAutoMargin = function(gd) {\n var axList = axes.list(gd, '', true);\n for(var i = 0; i < axList.length; i++) {\n var ax = axList[i];\n if(ax.automargin) {\n Plots.allowAutoMargin(gd, axAutoMarginID(ax));\n if(ax.mirror) {\n Plots.allowAutoMargin(gd, axMirrorAutoMarginID(ax));\n }\n }\n if(Registry.getComponentMethod('rangeslider', 'isVisible')(ax)) {\n Plots.allowAutoMargin(gd, rangeSliderAutoMarginID(ax));\n }\n }\n};\n\nfunction axAutoMarginID(ax) { return ax._id + '.automargin'; }\nfunction axMirrorAutoMarginID(ax) { return axAutoMarginID(ax) + '.mirror'; }\nfunction rangeSliderAutoMarginID(ax) { return ax._id + '.rangeslider'; }\n\n// swap all the presentation attributes of the axes showing these traces\naxes.swap = function(gd, traces) {\n var axGroups = makeAxisGroups(gd, traces);\n\n for(var i = 0; i < axGroups.length; i++) {\n swapAxisGroup(gd, axGroups[i].x, axGroups[i].y);\n }\n};\n\nfunction makeAxisGroups(gd, traces) {\n var groups = [];\n var i, j;\n\n for(i = 0; i < traces.length; i++) {\n var groupsi = [];\n var xi = gd._fullData[traces[i]].xaxis;\n var yi = gd._fullData[traces[i]].yaxis;\n if(!xi || !yi) continue; // not a 2D cartesian trace?\n\n for(j = 0; j < groups.length; j++) {\n if(groups[j].x.indexOf(xi) !== -1 || groups[j].y.indexOf(yi) !== -1) {\n groupsi.push(j);\n }\n }\n\n if(!groupsi.length) {\n groups.push({x: [xi], y: [yi]});\n continue;\n }\n\n var group0 = groups[groupsi[0]];\n var groupj;\n\n if(groupsi.length > 1) {\n for(j = 1; j < groupsi.length; j++) {\n groupj = groups[groupsi[j]];\n mergeAxisGroups(group0.x, groupj.x);\n mergeAxisGroups(group0.y, groupj.y);\n }\n }\n mergeAxisGroups(group0.x, [xi]);\n mergeAxisGroups(group0.y, [yi]);\n }\n\n return groups;\n}\n\nfunction mergeAxisGroups(intoSet, fromSet) {\n for(var i = 0; i < fromSet.length; i++) {\n if(intoSet.indexOf(fromSet[i]) === -1) intoSet.push(fromSet[i]);\n }\n}\n\nfunction swapAxisGroup(gd, xIds, yIds) {\n var xFullAxes = [];\n var yFullAxes = [];\n var layout = gd.layout;\n var i, j;\n\n for(i = 0; i < xIds.length; i++) xFullAxes.push(axes.getFromId(gd, xIds[i]));\n for(i = 0; i < yIds.length; i++) yFullAxes.push(axes.getFromId(gd, yIds[i]));\n\n var allAxKeys = Object.keys(axAttrs);\n\n var noSwapAttrs = [\n 'anchor', 'domain', 'overlaying', 'position', 'side', 'tickangle', 'editType'\n ];\n var numericTypes = ['linear', 'log'];\n\n for(i = 0; i < allAxKeys.length; i++) {\n var keyi = allAxKeys[i];\n var xVal = xFullAxes[0][keyi];\n var yVal = yFullAxes[0][keyi];\n var allEqual = true;\n var coerceLinearX = false;\n var coerceLinearY = false;\n if(keyi.charAt(0) === '_' || typeof xVal === 'function' ||\n noSwapAttrs.indexOf(keyi) !== -1) {\n continue;\n }\n for(j = 1; j < xFullAxes.length && allEqual; j++) {\n var xVali = xFullAxes[j][keyi];\n if(keyi === 'type' && numericTypes.indexOf(xVal) !== -1 &&\n numericTypes.indexOf(xVali) !== -1 && xVal !== xVali) {\n // type is special - if we find a mixture of linear and log,\n // coerce them all to linear on flipping\n coerceLinearX = true;\n } else if(xVali !== xVal) allEqual = false;\n }\n for(j = 1; j < yFullAxes.length && allEqual; j++) {\n var yVali = yFullAxes[j][keyi];\n if(keyi === 'type' && numericTypes.indexOf(yVal) !== -1 &&\n numericTypes.indexOf(yVali) !== -1 && yVal !== yVali) {\n // type is special - if we find a mixture of linear and log,\n // coerce them all to linear on flipping\n coerceLinearY = true;\n } else if(yFullAxes[j][keyi] !== yVal) allEqual = false;\n }\n if(allEqual) {\n if(coerceLinearX) layout[xFullAxes[0]._name].type = 'linear';\n if(coerceLinearY) layout[yFullAxes[0]._name].type = 'linear';\n swapAxisAttrs(layout, keyi, xFullAxes, yFullAxes, gd._fullLayout._dfltTitle);\n }\n }\n\n // now swap x&y for any annotations anchored to these x & y\n for(i = 0; i < gd._fullLayout.annotations.length; i++) {\n var ann = gd._fullLayout.annotations[i];\n if(xIds.indexOf(ann.xref) !== -1 &&\n yIds.indexOf(ann.yref) !== -1) {\n Lib.swapAttrs(layout.annotations[i], ['?']);\n }\n }\n}\n\nfunction swapAxisAttrs(layout, key, xFullAxes, yFullAxes, dfltTitle) {\n // in case the value is the default for either axis,\n // look at the first axis in each list and see if\n // this key's value is undefined\n var np = Lib.nestedProperty;\n var xVal = np(layout[xFullAxes[0]._name], key).get();\n var yVal = np(layout[yFullAxes[0]._name], key).get();\n var i;\n\n if(key === 'title') {\n // special handling of placeholder titles\n if(xVal && xVal.text === dfltTitle.x) {\n xVal.text = dfltTitle.y;\n }\n if(yVal && yVal.text === dfltTitle.y) {\n yVal.text = dfltTitle.x;\n }\n }\n\n for(i = 0; i < xFullAxes.length; i++) {\n np(layout, xFullAxes[i]._name + '.' + key).set(yVal);\n }\n for(i = 0; i < yFullAxes.length; i++) {\n np(layout, yFullAxes[i]._name + '.' + key).set(xVal);\n }\n}\n\nfunction isAngular(ax) {\n return ax._id === 'angularaxis';\n}\n\nfunction moveOutsideBreak(v, ax) {\n var len = ax._rangebreaks.length;\n for(var k = 0; k < len; k++) {\n var brk = ax._rangebreaks[k];\n if(v >= brk.min && v < brk.max) {\n return brk.max;\n }\n }\n return v;\n}\n\nfunction insideTicklabelposition(ax) {\n return ((ax.ticklabelposition || '').indexOf('inside') !== -1);\n}\n\nfunction hideCounterAxisInsideTickLabels(ax, opts) {\n if(insideTicklabelposition(ax._anchorAxis || {})) {\n if(ax._hideCounterAxisInsideTickLabels) {\n ax._hideCounterAxisInsideTickLabels(opts);\n }\n }\n}\n\nfunction incrementShift(ax, shiftVal, axShifts, normalize) {\n // Need to set 'overlay' for anchored axis\n var overlay = ((ax.anchor !== 'free') && ((ax.overlaying === undefined) || (ax.overlaying === false))) ? ax._id : ax.overlaying;\n var shiftValAdj;\n if(normalize) {\n shiftValAdj = ax.side === 'right' ? shiftVal : -shiftVal;\n } else {\n shiftValAdj = shiftVal;\n }\n if(!(overlay in axShifts)) {\n axShifts[overlay] = {};\n }\n if(!(ax.side in axShifts[overlay])) {\n axShifts[overlay][ax.side] = 0;\n }\n axShifts[overlay][ax.side] += shiftValAdj;\n}\n\nfunction setShiftVal(ax, axShifts) {\n return ax.autoshift ?\n axShifts[ax.overlaying][ax.side] :\n (ax.shift || 0);\n}\n\n/**\n * Checks if the given period is at least the period described by the tickformat or larger. If that\n * is the case, they are compatible, because then the tickformat can be used to describe the period.\n * E.g. it doesn't make sense to put a year label on a period spanning only a month.\n * @param {number} period in ms\n * @param {string} tickformat\n * @returns {boolean}\n */\nfunction periodCompatibleWithTickformat(period, tickformat) {\n return (\n /%f/.test(tickformat) ? period >= ONEMICROSEC :\n /%L/.test(tickformat) ? period >= ONEMILLI :\n /%[SX]/.test(tickformat) ? period >= ONESEC :\n /%M/.test(tickformat) ? period >= ONEMIN :\n /%[HI]/.test(tickformat) ? period >= ONEHOUR :\n /%p/.test(tickformat) ? period >= HALFDAY :\n /%[Aadejuwx]/.test(tickformat) ? period >= ONEDAY :\n /%[UVW]/.test(tickformat) ? period >= ONEWEEK :\n /%[Bbm]/.test(tickformat) ? period >= ONEMINMONTH :\n /%[q]/.test(tickformat) ? period >= ONEMINQUARTER :\n /%[Yy]/.test(tickformat) ? period >= ONEMINYEAR :\n true\n );\n}\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nvar isArrayOrTypedArray = Lib.isArrayOrTypedArray;\nvar isDateTime = Lib.isDateTime;\nvar cleanNumber = Lib.cleanNumber;\nvar round = Math.round;\n\nmodule.exports = function autoType(array, calendar, opts) {\n var a = array;\n\n var noMultiCategory = opts.noMultiCategory;\n if(isArrayOrTypedArray(a) && !a.length) return '-';\n if(!noMultiCategory && multiCategory(a)) return 'multicategory';\n if(noMultiCategory && Array.isArray(a[0])) { // no need to flat typed arrays here\n var b = [];\n for(var i = 0; i < a.length; i++) {\n if(isArrayOrTypedArray(a[i])) {\n for(var j = 0; j < a[i].length; j++) {\n b.push(a[i][j]);\n }\n }\n }\n a = b;\n }\n\n if(moreDates(a, calendar)) return 'date';\n\n var convertNumeric = opts.autotypenumbers !== 'strict'; // compare against strict, just in case autotypenumbers was not provided in opts\n if(category(a, convertNumeric)) return 'category';\n if(linearOK(a, convertNumeric)) return 'linear';\n\n return '-';\n};\n\nfunction hasTypeNumber(v, convertNumeric) {\n return convertNumeric ? isNumeric(v) : typeof v === 'number';\n}\n\n// is there at least one number in array? If not, we should leave\n// ax.type empty so it can be autoset later\nfunction linearOK(a, convertNumeric) {\n var len = a.length;\n\n for(var i = 0; i < len; i++) {\n if(hasTypeNumber(a[i], convertNumeric)) return true;\n }\n\n return false;\n}\n\n// does the array a have mostly dates rather than numbers?\n// note: some values can be neither (such as blanks, text)\n// 2- or 4-digit integers can be both, so require twice as many\n// dates as non-dates, to exclude cases with mostly 2 & 4 digit\n// numbers and a few dates\n// as with categories, consider DISTINCT values only.\nfunction moreDates(a, calendar) {\n var len = a.length;\n\n var inc = getIncrement(len);\n var dats = 0;\n var nums = 0;\n var seen = {};\n\n for(var f = 0; f < len; f += inc) {\n var i = round(f);\n var ai = a[i];\n var stri = String(ai);\n if(seen[stri]) continue;\n seen[stri] = 1;\n\n if(isDateTime(ai, calendar)) dats++;\n if(isNumeric(ai)) nums++;\n }\n\n return dats > nums * 2;\n}\n\n// return increment to test at most 1000 points, evenly spaced\nfunction getIncrement(len) {\n return Math.max(1, (len - 1) / 1000);\n}\n\n// are the (x,y)-values in gd.data mostly text?\n// require twice as many DISTINCT categories as distinct numbers\nfunction category(a, convertNumeric) {\n var len = a.length;\n\n var inc = getIncrement(len);\n var nums = 0;\n var cats = 0;\n var seen = {};\n\n for(var f = 0; f < len; f += inc) {\n var i = round(f);\n var ai = a[i];\n var stri = String(ai);\n if(seen[stri]) continue;\n seen[stri] = 1;\n\n var t = typeof ai;\n if(t === 'boolean') cats++;\n else if(convertNumeric ? cleanNumber(ai) !== BADNUM : t === 'number') nums++;\n else if(t === 'string') cats++;\n }\n\n return cats > nums * 2;\n}\n\n// very-loose requirements for multicategory,\n// trace modules that should never auto-type to multicategory\n// should be declared with 'noMultiCategory'\nfunction multiCategory(a) {\n return isArrayOrTypedArray(a[0]) && isArrayOrTypedArray(a[1]);\n}\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Template = require('../../plot_api/plot_template');\n\nvar handleArrayContainerDefaults = require('../array_container_defaults');\n\nvar layoutAttributes = require('./layout_attributes');\nvar handleTickValueDefaults = require('./tick_value_defaults');\nvar handleTickMarkDefaults = require('./tick_mark_defaults');\nvar handleTickLabelDefaults = require('./tick_label_defaults');\nvar handlePrefixSuffixDefaults = require('./prefix_suffix_defaults');\nvar handleCategoryOrderDefaults = require('./category_order_defaults');\nvar handleLineGridDefaults = require('./line_grid_defaults');\nvar handleRangeDefaults = require('./range_defaults');\nvar setConvert = require('./set_convert');\n\nvar DAY_OF_WEEK = require('./constants').WEEKDAY_PATTERN;\nvar HOUR = require('./constants').HOUR_PATTERN;\n\n/**\n * options: object containing:\n *\n * letter: 'x' or 'y'\n * title: name of the axis (ie 'Colorbar') to go in default title\n * font: the default font to inherit\n * outerTicks: boolean, should ticks default to outside?\n * showGrid: boolean, should gridlines be shown by default?\n * noHover: boolean, this axis doesn't support hover effects?\n * noTickson: boolean, this axis doesn't support 'tickson'\n * data: the plot data, used to manage categories\n * bgColor: the plot background color, to calculate default gridline colors\n * calendar:\n * splomStash:\n * visibleDflt: boolean\n * reverseDflt: boolean\n * automargin: boolean\n */\nmodule.exports = function handleAxisDefaults(containerIn, containerOut, coerce, options, layoutOut) {\n var letter = options.letter;\n var font = options.font || {};\n var splomStash = options.splomStash || {};\n\n var visible = coerce('visible', !options.visibleDflt);\n\n var axTemplate = containerOut._template || {};\n var axType = containerOut.type || axTemplate.type || '-';\n\n var ticklabelmode;\n if(axType === 'date') {\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleDefaults');\n handleCalendarDefaults(containerIn, containerOut, 'calendar', options.calendar);\n\n if(!options.noTicklabelmode) {\n ticklabelmode = coerce('ticklabelmode');\n }\n }\n\n if(!options.noTicklabelindex && (axType === 'date' || axType === 'linear')) {\n coerce('ticklabelindex');\n }\n\n var ticklabelposition = '';\n if(!options.noTicklabelposition || axType === 'multicategory') {\n ticklabelposition = Lib.coerce(containerIn, containerOut, {\n ticklabelposition: {\n valType: 'enumerated',\n dflt: 'outside',\n values: ticklabelmode === 'period' ? ['outside', 'inside'] :\n letter === 'x' ? [\n 'outside', 'inside',\n 'outside left', 'inside left',\n 'outside right', 'inside right'\n ] : [\n 'outside', 'inside',\n 'outside top', 'inside top',\n 'outside bottom', 'inside bottom'\n ]\n }\n }, 'ticklabelposition');\n }\n\n if(!options.noTicklabeloverflow) {\n coerce('ticklabeloverflow',\n ticklabelposition.indexOf('inside') !== -1 ?\n 'hide past domain' :\n axType === 'category' ||\n axType === 'multicategory' ?\n 'allow' :\n 'hide past div'\n );\n }\n\n setConvert(containerOut, layoutOut);\n\n handleRangeDefaults(containerIn, containerOut, coerce, options);\n\n handleCategoryOrderDefaults(containerIn, containerOut, coerce, options);\n\n if(axType !== 'category' && !options.noHover) coerce('hoverformat');\n\n var dfltColor = coerce('color');\n // if axis.color was provided, use it for fonts too; otherwise,\n // inherit from global font color in case that was provided.\n // Compare to dflt rather than to containerIn, so we can provide color via\n // template too.\n var dfltFontColor = (dfltColor !== layoutAttributes.color.dflt) ? dfltColor : font.color;\n // try to get default title from splom trace, fallback to graph-wide value\n var dfltTitle = splomStash.label || layoutOut._dfltTitle[letter];\n\n handlePrefixSuffixDefaults(containerIn, containerOut, coerce, axType, options);\n if(!visible) return containerOut;\n\n coerce('title.text', dfltTitle);\n Lib.coerceFont(coerce, 'title.font', font, { overrideDflt: {\n size: Lib.bigFont(font.size),\n color: dfltFontColor\n }});\n\n // major ticks\n handleTickValueDefaults(containerIn, containerOut, coerce, axType);\n\n var hasMinor = options.hasMinor;\n if(hasMinor) {\n // minor ticks\n Template.newContainer(containerOut, 'minor');\n handleTickValueDefaults(containerIn, containerOut, coerce, axType, { isMinor: true });\n }\n\n handleTickLabelDefaults(containerIn, containerOut, coerce, axType, options);\n\n // major and minor ticks\n handleTickMarkDefaults(containerIn, containerOut, coerce, options);\n if(hasMinor) {\n var keepIsMinor = options.isMinor;\n options.isMinor = true;\n handleTickMarkDefaults(containerIn, containerOut, coerce, options);\n options.isMinor = keepIsMinor;\n }\n\n handleLineGridDefaults(containerIn, containerOut, coerce, {\n dfltColor: dfltColor,\n bgColor: options.bgColor,\n showGrid: options.showGrid,\n hasMinor: hasMinor,\n attributes: layoutAttributes\n });\n\n // delete minor when no minor ticks or gridlines\n if(\n hasMinor &&\n !containerOut.minor.ticks &&\n !containerOut.minor.showgrid\n ) {\n delete containerOut.minor;\n }\n\n // mirror\n if(containerOut.showline || containerOut.ticks) coerce('mirror');\n\n var isMultiCategory = axType === 'multicategory';\n\n if(!options.noTickson &&\n (axType === 'category' || isMultiCategory) &&\n (containerOut.ticks || containerOut.showgrid)\n ) {\n var ticksonDflt;\n if(isMultiCategory) ticksonDflt = 'boundaries';\n var tickson = coerce('tickson', ticksonDflt);\n if(tickson === 'boundaries') {\n delete containerOut.ticklabelposition;\n }\n }\n\n if(isMultiCategory) {\n var showDividers = coerce('showdividers');\n if(showDividers) {\n coerce('dividercolor');\n coerce('dividerwidth');\n }\n }\n\n if(axType === 'date') {\n handleArrayContainerDefaults(containerIn, containerOut, {\n name: 'rangebreaks',\n inclusionAttr: 'enabled',\n handleItemDefaults: rangebreaksDefaults\n });\n\n if(!containerOut.rangebreaks.length) {\n delete containerOut.rangebreaks;\n } else {\n for(var k = 0; k < containerOut.rangebreaks.length; k++) {\n if(containerOut.rangebreaks[k].pattern === DAY_OF_WEEK) {\n containerOut._hasDayOfWeekBreaks = true;\n break;\n }\n }\n\n setConvert(containerOut, layoutOut);\n\n if(layoutOut._has('scattergl') || layoutOut._has('splom')) {\n for(var i = 0; i < options.data.length; i++) {\n var trace = options.data[i];\n if(trace.type === 'scattergl' || trace.type === 'splom') {\n trace.visible = false;\n Lib.warn(trace.type +\n ' traces do not work on axes with rangebreaks.' +\n ' Setting trace ' + trace.index + ' to `visible: false`.');\n }\n }\n }\n }\n }\n\n return containerOut;\n};\n\nfunction rangebreaksDefaults(itemIn, itemOut, containerOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(itemIn, itemOut, layoutAttributes.rangebreaks, attr, dflt);\n }\n\n var enabled = coerce('enabled');\n\n if(enabled) {\n var bnds = coerce('bounds');\n if(bnds && bnds.length >= 2) {\n var dfltPattern = '';\n var i, q;\n if(bnds.length === 2) {\n for(i = 0; i < 2; i++) {\n q = indexOfDay(bnds[i]);\n if(q) {\n dfltPattern = DAY_OF_WEEK;\n break;\n }\n }\n }\n var pattern = coerce('pattern', dfltPattern);\n if(pattern === DAY_OF_WEEK) {\n for(i = 0; i < 2; i++) {\n q = indexOfDay(bnds[i]);\n if(q) {\n // convert to integers i.e 'Sunday' --> 0\n itemOut.bounds[i] = bnds[i] = q - 1;\n }\n }\n }\n if(pattern) {\n // ensure types and ranges\n for(i = 0; i < 2; i++) {\n q = bnds[i];\n switch(pattern) {\n case DAY_OF_WEEK :\n if(!isNumeric(q)) {\n itemOut.enabled = false;\n return;\n }\n q = +q;\n\n if(\n q !== Math.floor(q) || // don't accept fractional days for mow\n q < 0 || q >= 7\n ) {\n itemOut.enabled = false;\n return;\n }\n // use number\n itemOut.bounds[i] = bnds[i] = q;\n break;\n\n case HOUR :\n if(!isNumeric(q)) {\n itemOut.enabled = false;\n return;\n }\n q = +q;\n\n if(q < 0 || q > 24) { // accept 24\n itemOut.enabled = false;\n return;\n }\n // use number\n itemOut.bounds[i] = bnds[i] = q;\n break;\n }\n }\n }\n\n if(containerOut.autorange === false) {\n var rng = containerOut.range;\n\n // if bounds are bigger than the (set) range, disable break\n if(rng[0] < rng[1]) {\n if(bnds[0] < rng[0] && bnds[1] > rng[1]) {\n itemOut.enabled = false;\n return;\n }\n } else if(bnds[0] > rng[0] && bnds[1] < rng[1]) {\n itemOut.enabled = false;\n return;\n }\n }\n } else {\n var values = coerce('values');\n\n if(values && values.length) {\n coerce('dvalue');\n } else {\n itemOut.enabled = false;\n return;\n }\n }\n }\n}\n\n// these numbers are one more than what bounds would be mapped to\nvar dayStrToNum = {\n sun: 1,\n mon: 2,\n tue: 3,\n wed: 4,\n thu: 5,\n fri: 6,\n sat: 7\n};\n\nfunction indexOfDay(v) {\n if(typeof v !== 'string') return;\n return dayStrToNum[\n v.substr(0, 3).toLowerCase()\n ];\n}\n","'use strict';\n\nvar docs = require('../../constants/docs');\nvar FORMAT_LINK = docs.FORMAT_LINK;\nvar DATE_FORMAT_LINK = docs.DATE_FORMAT_LINK;\n\nfunction axisHoverFormat(x, noDates) {\n return {\n valType: 'string',\n dflt: '',\n editType: 'none',\n description: (\n noDates ? descriptionOnlyNumbers : descriptionWithDates\n )('hover text', x) + [\n 'By default the values are formatted using ' + (\n noDates ?\n 'generic number format' :\n ('`' + x + 'axis.hoverformat`')\n ) + '.',\n ].join(' ')\n };\n}\n\nfunction descriptionOnlyNumbers(label, x) {\n return [\n 'Sets the ' + label + ' formatting rule' + (x ? 'for `' + x + '` ' : ''),\n 'using d3 formatting mini-languages',\n 'which are very similar to those in Python. For numbers, see: ' + FORMAT_LINK + '.'\n ].join(' ');\n}\n\nfunction descriptionWithDates(label, x) {\n return descriptionOnlyNumbers(label, x) + [\n ' And for dates see: ' + DATE_FORMAT_LINK + '.',\n 'We add two items to d3\\'s date formatter:',\n '*%h* for half of the year as a decimal number as well as',\n '*%{n}f* for fractional seconds',\n 'with n digits. For example, *2016-10-13 09:15:23.456* with tickformat',\n '*%H~%M~%S.%2f* would display *09~15~23.46*'\n ].join(' ');\n}\n\nmodule.exports = {\n axisHoverFormat: axisHoverFormat,\n descriptionOnlyNumbers: descriptionOnlyNumbers,\n descriptionWithDates: descriptionWithDates\n};\n","'use strict';\n\nvar Registry = require('../../registry');\n\nvar constants = require('./constants');\n\n\n// convert between axis names (xaxis, xaxis2, etc, elements of gd.layout)\n// and axis id's (x, x2, etc). Would probably have ditched 'xaxis'\n// completely in favor of just 'x' if it weren't ingrained in the API etc.\nexports.id2name = function id2name(id) {\n if(typeof id !== 'string' || !id.match(constants.AX_ID_PATTERN)) return;\n var axNum = id.split(' ')[0].substr(1);\n if(axNum === '1') axNum = '';\n return id.charAt(0) + 'axis' + axNum;\n};\n\nexports.name2id = function name2id(name) {\n if(!name.match(constants.AX_NAME_PATTERN)) return;\n var axNum = name.substr(5);\n if(axNum === '1') axNum = '';\n return name.charAt(0) + axNum;\n};\n\n/*\n * Cleans up the number of an axis, e.g., 'x002'->'x2', 'x0'->'x', 'x1' -> 'x',\n * etc.\n * If domainId is true, then id could be a domain reference and if it is, the\n * ' domain' part is kept at the end of the axis ID string.\n */\nexports.cleanId = function cleanId(id, axLetter, domainId) {\n var domainTest = /( domain)$/.test(id);\n if(typeof id !== 'string' || !id.match(constants.AX_ID_PATTERN)) return;\n if(axLetter && id.charAt(0) !== axLetter) return;\n if(domainTest && (!domainId)) return;\n var axNum = id.split(' ')[0].substr(1).replace(/^0+/, '');\n if(axNum === '1') axNum = '';\n return id.charAt(0) + axNum + (domainTest && domainId ? ' domain' : '');\n};\n\n// get all axis objects, as restricted in listNames\nexports.list = function(gd, axLetter, only2d) {\n var fullLayout = gd._fullLayout;\n if(!fullLayout) return [];\n\n var idList = exports.listIds(gd, axLetter);\n var out = new Array(idList.length);\n var i;\n\n for(i = 0; i < idList.length; i++) {\n var idi = idList[i];\n out[i] = fullLayout[idi.charAt(0) + 'axis' + idi.substr(1)];\n }\n\n if(!only2d) {\n var sceneIds3D = fullLayout._subplots.gl3d || [];\n\n for(i = 0; i < sceneIds3D.length; i++) {\n var scene = fullLayout[sceneIds3D[i]];\n\n if(axLetter) out.push(scene[axLetter + 'axis']);\n else out.push(scene.xaxis, scene.yaxis, scene.zaxis);\n }\n }\n\n return out;\n};\n\n// get all axis ids, optionally restricted by letter\n// this only makes sense for 2d axes\nexports.listIds = function(gd, axLetter) {\n var fullLayout = gd._fullLayout;\n if(!fullLayout) return [];\n\n var subplotLists = fullLayout._subplots;\n if(axLetter) return subplotLists[axLetter + 'axis'];\n return subplotLists.xaxis.concat(subplotLists.yaxis);\n};\n\n// get an axis object from its id 'x','x2' etc\n// optionally, id can be a subplot (ie 'x2y3') and type gets x or y from it\nexports.getFromId = function(gd, id, type) {\n var fullLayout = gd._fullLayout;\n // remove \"domain\" suffix\n id = ((id === undefined) || (typeof(id) !== 'string')) ? id : id.replace(' domain', '');\n\n if(type === 'x') id = id.replace(/y[0-9]*/, '');\n else if(type === 'y') id = id.replace(/x[0-9]*/, '');\n\n return fullLayout[exports.id2name(id)];\n};\n\n// get an axis object of specified type from the containing trace\nexports.getFromTrace = function(gd, fullTrace, type) {\n var fullLayout = gd._fullLayout;\n var ax = null;\n\n if(Registry.traceIs(fullTrace, 'gl3d')) {\n var scene = fullTrace.scene;\n if(scene.substr(0, 5) === 'scene') {\n ax = fullLayout[scene][type + 'axis'];\n }\n } else {\n ax = exports.getFromId(gd, fullTrace[type + 'axis'] || type);\n }\n\n return ax;\n};\n\n// sort x, x2, x10, y, y2, y10...\nexports.idSort = function(id1, id2) {\n var letter1 = id1.charAt(0);\n var letter2 = id2.charAt(0);\n if(letter1 !== letter2) return letter1 > letter2 ? 1 : -1;\n return +(id1.substr(1) || 1) - +(id2.substr(1) || 1);\n};\n\n/*\n * An axis reference (e.g., the contents at the 'xref' key of an object) might\n * have extra information appended. Extract the axis ID only.\n *\n * ar: the axis reference string\n *\n */\nexports.ref2id = function(ar) {\n // This assumes ar has been coerced via coerceRef, and uses the shortcut of\n // checking if the first letter matches [xyz] to determine if it should\n // return the axis ID. Otherwise it returns false.\n return (/^[xyz]/.test(ar)) ? ar.split(' ')[0] : false;\n};\n\nfunction isFound(axId, list) {\n if(list && list.length) {\n for(var i = 0; i < list.length; i++) {\n if(list[i][axId]) return true;\n }\n }\n return false;\n}\n\nexports.isLinked = function(fullLayout, axId) {\n return (\n isFound(axId, fullLayout._axisMatchGroups) ||\n isFound(axId, fullLayout._axisConstraintGroups)\n );\n};\n","'use strict';\n\nvar isTypedArraySpec = require('../../lib/array').isTypedArraySpec;\n\nfunction findCategories(ax, opts) {\n var dataAttr = opts.dataAttr || ax._id.charAt(0);\n var lookup = {};\n var axData;\n var i, j;\n\n if(opts.axData) {\n // non-x/y case\n axData = opts.axData;\n } else {\n // x/y case\n axData = [];\n for(i = 0; i < opts.data.length; i++) {\n var trace = opts.data[i];\n if(trace[dataAttr + 'axis'] === ax._id) {\n axData.push(trace);\n }\n }\n }\n\n for(i = 0; i < axData.length; i++) {\n var vals = axData[i][dataAttr];\n for(j = 0; j < vals.length; j++) {\n var v = vals[j];\n if(v !== null && v !== undefined) {\n lookup[v] = 1;\n }\n }\n }\n\n return Object.keys(lookup);\n}\n\n/**\n * Fills in category* default and initial categories.\n *\n * @param {object} containerIn : input axis object\n * @param {object} containerOut : full axis object\n * @param {function} coerce : Lib.coerce fn wrapper\n * @param {object} opts :\n * - data {array} : (full) data trace\n * OR\n * - axData {array} : (full) data associated with axis being coerced here\n * - dataAttr {string} : attribute name corresponding to coordinate array\n */\nmodule.exports = function handleCategoryOrderDefaults(containerIn, containerOut, coerce, opts) {\n if(containerOut.type !== 'category') return;\n\n var arrayIn = containerIn.categoryarray;\n var isValidArray = (Array.isArray(arrayIn) && arrayIn.length > 0) ||\n isTypedArraySpec(arrayIn);\n\n // override default 'categoryorder' value when non-empty array is supplied\n var orderDefault;\n if(isValidArray) orderDefault = 'array';\n\n var order = coerce('categoryorder', orderDefault);\n var array;\n\n // coerce 'categoryarray' only in array order case\n if(order === 'array') {\n array = coerce('categoryarray');\n }\n\n // cannot set 'categoryorder' to 'array' with an invalid 'categoryarray'\n if(!isValidArray && order === 'array') {\n order = containerOut.categoryorder = 'trace';\n }\n\n // set up things for makeCalcdata\n if(order === 'trace') {\n containerOut._initialCategories = [];\n } else if(order === 'array') {\n containerOut._initialCategories = array.slice();\n } else {\n array = findCategories(containerOut, opts).sort();\n if(order === 'category ascending') {\n containerOut._initialCategories = array;\n } else if(order === 'category descending') {\n containerOut._initialCategories = array.reverse();\n }\n }\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar Lib = require('../../lib');\nvar constants = require('../../constants/numerical');\nvar ONEDAY = constants.ONEDAY;\nvar ONEWEEK = constants.ONEWEEK;\n\n/**\n * Return a validated dtick value for this axis\n *\n * @param {any} dtick: the candidate dtick. valid values are numbers and strings,\n * and further constrained depending on the axis type.\n * @param {string} axType: the axis type\n */\nexports.dtick = function(dtick, axType) {\n var isLog = axType === 'log';\n var isDate = axType === 'date';\n var isCat = axType === 'category';\n var dtickDflt = isDate ? ONEDAY : 1;\n\n if(!dtick) return dtickDflt;\n\n if(isNumeric(dtick)) {\n dtick = Number(dtick);\n if(dtick <= 0) return dtickDflt;\n if(isCat) {\n // category dtick must be positive integers\n return Math.max(1, Math.round(dtick));\n }\n if(isDate) {\n // date dtick must be at least 0.1ms (our current precision)\n return Math.max(0.1, dtick);\n }\n return dtick;\n }\n\n if(typeof dtick !== 'string' || !(isDate || isLog)) {\n return dtickDflt;\n }\n\n var prefix = dtick.charAt(0);\n var dtickNum = dtick.substr(1);\n dtickNum = isNumeric(dtickNum) ? Number(dtickNum) : 0;\n\n if((dtickNum <= 0) || !(\n // \"M\" gives ticks every (integer) n months\n (isDate && prefix === 'M' && dtickNum === Math.round(dtickNum)) ||\n // \"L\" gives ticks linearly spaced in data (not in position) every (float) f\n (isLog && prefix === 'L') ||\n // \"D1\" gives powers of 10 with all small digits between, \"D2\" gives only 2 and 5\n (isLog && prefix === 'D' && (dtickNum === 1 || dtickNum === 2))\n )) {\n return dtickDflt;\n }\n\n return dtick;\n};\n\n/**\n * Return a validated tick0 for this axis\n *\n * @param {any} tick0: the candidate tick0. Valid values are numbers and strings,\n * further constrained depending on the axis type\n * @param {string} axType: the axis type\n * @param {string} calendar: for date axes, the calendar to validate/convert with\n * @param {any} dtick: an already valid dtick. Only used for D1 and D2 log dticks,\n * which do not support tick0 at all.\n */\nexports.tick0 = function(tick0, axType, calendar, dtick) {\n if(axType === 'date') {\n return Lib.cleanDate(tick0,\n Lib.dateTick0(calendar, (dtick % ONEWEEK === 0) ? 1 : 0)\n );\n }\n if(dtick === 'D1' || dtick === 'D2') {\n // D1 and D2 modes ignore tick0 entirely\n return undefined;\n }\n // Aside from date axes, tick0 must be numeric\n return isNumeric(tick0) ? Number(tick0) : 0;\n};\n","'use strict';\n\nvar counterRegex = require('../../lib/regex').counter;\n\nmodule.exports = {\n idRegex: {\n x: counterRegex('x', '( domain)?'),\n y: counterRegex('y', '( domain)?')\n },\n\n attrRegex: counterRegex('[xy]axis'),\n\n // axis match regular expression\n xAxisMatch: counterRegex('xaxis'),\n yAxisMatch: counterRegex('yaxis'),\n\n // pattern matching axis ids and names\n // note that this is more permissive than counterRegex, as\n // id2name, name2id, and cleanId accept \"x1\" etc\n AX_ID_PATTERN: /^[xyz][0-9]*( domain)?$/,\n AX_NAME_PATTERN: /^[xyz]axis[0-9]*$/,\n\n // and for 2D subplots\n SUBPLOT_PATTERN: /^x([0-9]*)y([0-9]*)$/,\n\n HOUR_PATTERN: 'hour',\n WEEKDAY_PATTERN: 'day of week',\n\n // pixels to move mouse before you stop clamping to starting point\n MINDRAG: 8,\n\n // smallest dimension allowed for a zoombox\n MINZOOM: 20,\n\n // width of axis drag regions\n DRAGGERSIZE: 20,\n\n // delay before a redraw (relayout) after smooth panning and zooming\n REDRAWDELAY: 50,\n\n // last resort axis ranges for x and y axes if we have no data\n DFLTRANGEX: [-1, 6],\n DFLTRANGEY: [-1, 4],\n\n // Layers to keep trace types in the right order\n // N.B. each 'unique' plot method must have its own layer\n traceLayerClasses: [\n 'imagelayer',\n 'heatmaplayer',\n 'contourcarpetlayer', 'contourlayer',\n 'funnellayer', 'waterfalllayer', 'barlayer',\n 'carpetlayer',\n 'violinlayer',\n 'boxlayer',\n 'ohlclayer',\n 'scattercarpetlayer', 'scatterlayer'\n ],\n\n clipOnAxisFalseQuery: [\n '.scatterlayer',\n '.barlayer',\n '.funnellayer',\n '.waterfalllayer'\n ],\n\n layerValue2layerClass: {\n 'above traces': 'above',\n 'below traces': 'below'\n },\n\n zindexSeparator: 'z', // used for zindex of cartesian subplots e.g. xy, xyz2, xyz3, etc.\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar autorange = require('./autorange');\nvar id2name = require('./axis_ids').id2name;\nvar layoutAttributes = require('./layout_attributes');\nvar scaleZoom = require('./scale_zoom');\nvar setConvert = require('./set_convert');\n\nvar ALMOST_EQUAL = require('../../constants/numerical').ALMOST_EQUAL;\nvar FROM_BL = require('../../constants/alignment').FROM_BL;\n\nexports.handleDefaults = function(layoutIn, layoutOut, opts) {\n var axIds = opts.axIds;\n var axHasImage = opts.axHasImage;\n\n // sets of axes linked by `scaleanchor` OR `matches` along with the\n // scaleratios compounded together, populated in handleConstraintDefaults\n var constraintGroups = layoutOut._axisConstraintGroups = [];\n // similar to _axisConstraintGroups, but only matching axes\n var matchGroups = layoutOut._axisMatchGroups = [];\n\n var i, group, axId, axName, axIn, axOut, attr, val;\n\n for(i = 0; i < axIds.length; i++) {\n axName = id2name(axIds[i]);\n axIn = layoutIn[axName];\n axOut = layoutOut[axName];\n\n handleOneAxDefaults(axIn, axOut, {\n axIds: axIds,\n layoutOut: layoutOut,\n hasImage: axHasImage[axName]\n });\n }\n\n // save matchGroup on each matching axis\n function stash(groups, stashAttr) {\n for(i = 0; i < groups.length; i++) {\n group = groups[i];\n for(axId in group) {\n layoutOut[id2name(axId)][stashAttr] = group;\n }\n }\n }\n stash(matchGroups, '_matchGroup');\n\n // If any axis in a constraint group is fixedrange, they all get fixed\n // This covers matches axes, as they're now in the constraintgroup too\n // and have not yet been removed (if the group is *only* matching)\n for(i = 0; i < constraintGroups.length; i++) {\n group = constraintGroups[i];\n for(axId in group) {\n axOut = layoutOut[id2name(axId)];\n if(axOut.fixedrange) {\n for(var axId2 in group) {\n var axName2 = id2name(axId2);\n if((layoutIn[axName2] || {}).fixedrange === false) {\n Lib.warn(\n 'fixedrange was specified as false for axis ' +\n axName2 + ' but was overridden because another ' +\n 'axis in its constraint group has fixedrange true'\n );\n }\n layoutOut[axName2].fixedrange = true;\n }\n break;\n }\n }\n }\n\n // remove constraint groups that simply duplicate match groups\n i = 0;\n while(i < constraintGroups.length) {\n group = constraintGroups[i];\n for(axId in group) {\n axOut = layoutOut[id2name(axId)];\n if(axOut._matchGroup && Object.keys(axOut._matchGroup).length === Object.keys(group).length) {\n constraintGroups.splice(i, 1);\n i--;\n }\n break;\n }\n i++;\n }\n\n // save constraintGroup on each constrained axis\n stash(constraintGroups, '_constraintGroup');\n\n // make sure `matching` axes share values of necessary attributes\n // Precedence (base axis is the one that doesn't list a `matches`, ie others\n // all point to it):\n // (1) explicitly defined value in the base axis\n // (2) explicitly defined in another axis (arbitrary order)\n // (3) default in the base axis\n var matchAttrs = [\n 'constrain',\n 'range',\n 'autorange',\n 'rangemode',\n 'rangebreaks',\n 'categoryorder',\n 'categoryarray'\n ];\n var hasRange = false;\n var hasDayOfWeekBreaks = false;\n\n function setAttrVal() {\n val = axOut[attr];\n if(attr === 'rangebreaks') {\n hasDayOfWeekBreaks = axOut._hasDayOfWeekBreaks;\n }\n }\n\n for(i = 0; i < matchGroups.length; i++) {\n group = matchGroups[i];\n\n // find 'matching' range attrs\n for(var j = 0; j < matchAttrs.length; j++) {\n attr = matchAttrs[j];\n val = null;\n var baseAx;\n for(axId in group) {\n axName = id2name(axId);\n axIn = layoutIn[axName];\n axOut = layoutOut[axName];\n if(!(attr in axOut)) {\n continue;\n }\n if(!axOut.matches) {\n baseAx = axOut;\n // top priority: explicit value in base axis\n if(attr in axIn) {\n setAttrVal();\n break;\n }\n }\n if(val === null && attr in axIn) {\n // second priority: first explicit value in another axis\n setAttrVal();\n }\n }\n\n // special logic for coupling of range and autorange\n // if nobody explicitly specifies autorange, but someone does\n // explicitly specify range, autorange must be disabled.\n if(attr === 'range' && val &&\n axIn.range &&\n axIn.range.length === 2 &&\n axIn.range[0] !== null &&\n axIn.range[1] !== null\n ) {\n hasRange = true;\n }\n if(attr === 'autorange' && val === null && hasRange) {\n val = false;\n }\n\n if(val === null && attr in baseAx) {\n // fallback: default value in base axis\n val = baseAx[attr];\n }\n // but we still might not have a value, which is fine.\n if(val !== null) {\n for(axId in group) {\n axOut = layoutOut[id2name(axId)];\n axOut[attr] = attr === 'range' ? val.slice() : val;\n\n if(attr === 'rangebreaks') {\n axOut._hasDayOfWeekBreaks = hasDayOfWeekBreaks;\n setConvert(axOut, layoutOut);\n }\n }\n }\n }\n }\n};\n\nfunction handleOneAxDefaults(axIn, axOut, opts) {\n var axIds = opts.axIds;\n var layoutOut = opts.layoutOut;\n var hasImage = opts.hasImage;\n var constraintGroups = layoutOut._axisConstraintGroups;\n var matchGroups = layoutOut._axisMatchGroups;\n var axId = axOut._id;\n var axLetter = axId.charAt(0);\n var splomStash = ((layoutOut._splomAxes || {})[axLetter] || {})[axId] || {};\n var thisID = axOut._id;\n var isX = thisID.charAt(0) === 'x';\n\n // Clear _matchGroup & _constraintGroup so relinkPrivateKeys doesn't keep\n // an old one around. If this axis is in a group we'll set this again later\n axOut._matchGroup = null;\n axOut._constraintGroup = null;\n\n function coerce(attr, dflt) {\n return Lib.coerce(axIn, axOut, layoutAttributes, attr, dflt);\n }\n\n // coerce the constraint mechanics even if this axis has no scaleanchor\n // because it may be the anchor of another axis.\n coerce('constrain', hasImage ? 'domain' : 'range');\n Lib.coerce(axIn, axOut, {\n constraintoward: {\n valType: 'enumerated',\n values: isX ? ['left', 'center', 'right'] : ['bottom', 'middle', 'top'],\n dflt: isX ? 'center' : 'middle'\n }\n }, 'constraintoward');\n\n // If this axis is already part of a constraint group, we can't\n // scaleanchor any other axis in that group, or we'd make a loop.\n // Filter axIds to enforce this, also matching axis types.\n var thisType = axOut.type;\n var i, idi;\n\n var linkableAxes = [];\n for(i = 0; i < axIds.length; i++) {\n idi = axIds[i];\n if(idi === thisID) continue;\n\n var axi = layoutOut[id2name(idi)];\n if(axi.type === thisType) {\n linkableAxes.push(idi);\n }\n }\n\n var thisGroup = getConstraintGroup(constraintGroups, thisID);\n if(thisGroup) {\n var linkableAxesNoLoops = [];\n for(i = 0; i < linkableAxes.length; i++) {\n idi = linkableAxes[i];\n if(!thisGroup[idi]) linkableAxesNoLoops.push(idi);\n }\n linkableAxes = linkableAxesNoLoops;\n }\n\n var canLink = linkableAxes.length;\n\n var matches, scaleanchor;\n\n if(canLink && (axIn.matches || splomStash.matches)) {\n matches = Lib.coerce(axIn, axOut, {\n matches: {\n valType: 'enumerated',\n values: linkableAxes,\n dflt: linkableAxes.indexOf(splomStash.matches) !== -1 ? splomStash.matches : undefined\n }\n }, 'matches');\n }\n\n // 'matches' wins over 'scaleanchor' - each axis can only specify one\n // constraint, but you can chain matches and scaleanchor constraints by\n // specifying them in separate axes.\n var scaleanchorDflt = hasImage && !isX ? axOut.anchor : undefined;\n if(canLink && !matches && (axIn.scaleanchor || scaleanchorDflt)) {\n scaleanchor = Lib.coerce(axIn, axOut, {\n scaleanchor: {\n valType: 'enumerated',\n values: linkableAxes.concat([false])\n }\n }, 'scaleanchor', scaleanchorDflt);\n }\n\n if(matches) {\n axOut._matchGroup = updateConstraintGroups(matchGroups, thisID, matches, 1);\n\n // Also include match constraints in the scale groups\n var matchedAx = layoutOut[id2name(matches)];\n var matchRatio = extent(layoutOut, axOut) / extent(layoutOut, matchedAx);\n if(isX !== (matches.charAt(0) === 'x')) {\n // We don't yet know the actual scale ratio of x/y matches constraints,\n // due to possible automargins, so just leave a placeholder for this:\n // 'x' means \"x size over y size\", 'y' means the inverse.\n // in principle in the constraint group you could get multiple of these.\n matchRatio = (isX ? 'x' : 'y') + matchRatio;\n }\n updateConstraintGroups(constraintGroups, thisID, matches, matchRatio);\n } else if(axIn.matches && axIds.indexOf(axIn.matches) !== -1) {\n Lib.warn('ignored ' + axOut._name + '.matches: \"' +\n axIn.matches + '\" to avoid an infinite loop');\n }\n\n if(scaleanchor) {\n var scaleratio = coerce('scaleratio');\n\n // TODO: I suppose I could do attribute.min: Number.MIN_VALUE to avoid zero,\n // but that seems hacky. Better way to say \"must be a positive number\"?\n // Of course if you use several super-tiny values you could eventually\n // force a product of these to zero and all hell would break loose...\n // Likewise with super-huge values.\n if(!scaleratio) scaleratio = axOut.scaleratio = 1;\n\n updateConstraintGroups(constraintGroups, thisID, scaleanchor, scaleratio);\n } else if(axIn.scaleanchor && axIds.indexOf(axIn.scaleanchor) !== -1) {\n Lib.warn('ignored ' + axOut._name + '.scaleanchor: \"' +\n axIn.scaleanchor + '\" to avoid either an infinite loop ' +\n 'and possibly inconsistent scaleratios, or because this axis ' +\n 'declares a *matches* constraint.');\n }\n}\n\nfunction extent(layoutOut, ax) {\n var domain = ax.domain;\n if(!domain) {\n // at this point overlaying axes haven't yet inherited their main domains\n // TODO: constrain: domain with overlaying axes is likely a bug.\n domain = layoutOut[id2name(ax.overlaying)].domain;\n }\n return domain[1] - domain[0];\n}\n\nfunction getConstraintGroup(groups, thisID) {\n for(var i = 0; i < groups.length; i++) {\n if(groups[i][thisID]) {\n return groups[i];\n }\n }\n return null;\n}\n\n/*\n * Add this axis to the axis constraint groups, which is the collection\n * of axes that are all constrained together on scale (or matching).\n *\n * constraintGroups: a list of objects. each object is\n * {axis_id: scale_within_group}, where scale_within_group is\n * only important relative to the rest of the group, and defines\n * the relative scales between all axes in the group\n *\n * thisGroup: the group the current axis is already in\n * thisID: the id if the current axis\n * thatID: the id of the axis to scale it with\n * scaleratio: the ratio of this axis to the thatID axis\n */\nfunction updateConstraintGroups(constraintGroups, thisID, thatID, scaleratio) {\n var i, j, groupi, keyj, thisGroupIndex;\n\n var thisGroup = getConstraintGroup(constraintGroups, thisID);\n\n if(thisGroup === null) {\n thisGroup = {};\n thisGroup[thisID] = 1;\n thisGroupIndex = constraintGroups.length;\n constraintGroups.push(thisGroup);\n } else {\n thisGroupIndex = constraintGroups.indexOf(thisGroup);\n }\n\n var thisGroupKeys = Object.keys(thisGroup);\n\n // we know that this axis isn't in any other groups, but we don't know\n // about the thatID axis. If it is, we need to merge the groups.\n for(i = 0; i < constraintGroups.length; i++) {\n groupi = constraintGroups[i];\n if(i !== thisGroupIndex && groupi[thatID]) {\n var baseScale = groupi[thatID];\n for(j = 0; j < thisGroupKeys.length; j++) {\n keyj = thisGroupKeys[j];\n groupi[keyj] = multiplyScales(baseScale, multiplyScales(scaleratio, thisGroup[keyj]));\n }\n constraintGroups.splice(thisGroupIndex, 1);\n return;\n }\n }\n\n // otherwise, we insert the new thatID axis as the base scale (1)\n // in its group, and scale the rest of the group to it\n if(scaleratio !== 1) {\n for(j = 0; j < thisGroupKeys.length; j++) {\n var key = thisGroupKeys[j];\n thisGroup[key] = multiplyScales(scaleratio, thisGroup[key]);\n }\n }\n thisGroup[thatID] = 1;\n}\n\n// scales may be numbers or 'x1.3', 'yy4.5' etc to multiply by as-yet-unknown\n// ratios between x and y plot sizes n times\nfunction multiplyScales(a, b) {\n var aPrefix = '';\n var bPrefix = '';\n var aLen, bLen;\n\n if(typeof a === 'string') {\n aPrefix = a.match(/^[xy]*/)[0];\n aLen = aPrefix.length;\n a = +a.substr(aLen);\n }\n\n if(typeof b === 'string') {\n bPrefix = b.match(/^[xy]*/)[0];\n bLen = bPrefix.length;\n b = +b.substr(bLen);\n }\n\n var c = a * b;\n\n // just two numbers\n if(!aLen && !bLen) {\n return c;\n }\n\n // one or more prefixes of the same type\n if(!aLen || !bLen || aPrefix.charAt(0) === bPrefix.charAt(0)) {\n return aPrefix + bPrefix + (a * b);\n }\n\n // x and y cancel each other out exactly - back to a number\n if(aLen === bLen) {\n return c;\n }\n\n // partial cancelation of prefixes\n return (aLen > bLen ? aPrefix.substr(bLen) : bPrefix.substr(aLen)) + c;\n}\n\nfunction finalRatios(group, fullLayout) {\n var size = fullLayout._size;\n var yRatio = size.h / size.w;\n var out = {};\n var keys = Object.keys(group);\n for(var i = 0; i < keys.length; i++) {\n var key = keys[i];\n var val = group[key];\n\n if(typeof val === 'string') {\n var prefix = val.match(/^[xy]*/)[0];\n var pLen = prefix.length;\n val = +val.substr(pLen);\n var mult = prefix.charAt(0) === 'y' ? yRatio : (1 / yRatio);\n for(var j = 0; j < pLen; j++) {\n val *= mult;\n }\n }\n\n out[key] = val;\n }\n return out;\n}\n\nexports.enforce = function enforce(gd) {\n var fullLayout = gd._fullLayout;\n var constraintGroups = fullLayout._axisConstraintGroups || [];\n\n var i, j, group, axisID, ax, normScale, mode, factor;\n\n // matching constraints are handled in the autorange code when autoranged,\n // or in the supplyDefaults code when explicitly ranged.\n // now we just need to handle scaleanchor constraints\n // matches constraints that chain with scaleanchor constraints are included\n // here too, but because matches has already been satisfied,\n // any changes here should preserve that.\n for(i = 0; i < constraintGroups.length; i++) {\n group = finalRatios(constraintGroups[i], fullLayout);\n var axisIDs = Object.keys(group);\n\n var minScale = Infinity;\n var maxScale = 0;\n // mostly matchScale will be the same as minScale\n // ie we expand axis ranges to encompass *everything*\n // that's currently in any of their ranges, but during\n // autorange of a subset of axes we will ignore other\n // axes for this purpose.\n var matchScale = Infinity;\n var normScales = {};\n var axes = {};\n var hasAnyDomainConstraint = false;\n\n // find the (normalized) scale of each axis in the group\n for(j = 0; j < axisIDs.length; j++) {\n axisID = axisIDs[j];\n axes[axisID] = ax = fullLayout[id2name(axisID)];\n\n if(ax._inputDomain) ax.domain = ax._inputDomain.slice();\n else ax._inputDomain = ax.domain.slice();\n\n if(!ax._inputRange) ax._inputRange = ax.range.slice();\n\n // set axis scale here so we can use _m rather than\n // having to calculate it from length and range\n ax.setScale();\n\n // abs: inverted scales still satisfy the constraint\n normScales[axisID] = normScale = Math.abs(ax._m) / group[axisID];\n minScale = Math.min(minScale, normScale);\n if(ax.constrain === 'domain' || !ax._constraintShrinkable) {\n matchScale = Math.min(matchScale, normScale);\n }\n\n // this has served its purpose, so remove it\n delete ax._constraintShrinkable;\n maxScale = Math.max(maxScale, normScale);\n\n if(ax.constrain === 'domain') hasAnyDomainConstraint = true;\n }\n\n // Do we have a constraint mismatch? Give a small buffer for rounding errors\n if(minScale > ALMOST_EQUAL * maxScale && !hasAnyDomainConstraint) continue;\n\n // now increase any ranges we need to until all normalized scales are equal\n for(j = 0; j < axisIDs.length; j++) {\n axisID = axisIDs[j];\n normScale = normScales[axisID];\n ax = axes[axisID];\n mode = ax.constrain;\n\n // even if the scale didn't change, if we're shrinking domain\n // we need to recalculate in case `constraintoward` changed\n if(normScale !== matchScale || mode === 'domain') {\n factor = normScale / matchScale;\n\n if(mode === 'range') {\n scaleZoom(ax, factor);\n } else {\n // mode === 'domain'\n\n var inputDomain = ax._inputDomain;\n var domainShrunk = (ax.domain[1] - ax.domain[0]) /\n (inputDomain[1] - inputDomain[0]);\n var rangeShrunk = (ax.r2l(ax.range[1]) - ax.r2l(ax.range[0])) /\n (ax.r2l(ax._inputRange[1]) - ax.r2l(ax._inputRange[0]));\n\n factor /= domainShrunk;\n\n if(factor * rangeShrunk < 1) {\n // we've asked to magnify the axis more than we can just by\n // enlarging the domain - so we need to constrict range\n ax.domain = ax._input.domain = inputDomain.slice();\n scaleZoom(ax, factor);\n continue;\n }\n\n if(rangeShrunk < 1) {\n // the range has previously been constricted by ^^, but we've\n // switched to the domain-constricted regime, so reset range\n ax.range = ax._input.range = ax._inputRange.slice();\n factor *= rangeShrunk;\n }\n\n if(ax.autorange) {\n /*\n * range & factor may need to change because range was\n * calculated for the larger scaling, so some pixel\n * paddings may get cut off when we reduce the domain.\n *\n * This is easier than the regular autorange calculation\n * because we already know the scaling `m`, but we still\n * need to cut out impossible constraints (like\n * annotations with super-long arrows). That's what\n * outerMin/Max are for - if the expansion was going to\n * go beyond the original domain, it must be impossible\n */\n var rl0 = ax.r2l(ax.range[0]);\n var rl1 = ax.r2l(ax.range[1]);\n var rangeCenter = (rl0 + rl1) / 2;\n var rangeMin = rangeCenter;\n var rangeMax = rangeCenter;\n var halfRange = Math.abs(rl1 - rangeCenter);\n // extra tiny bit for rounding errors, in case we actually\n // *are* expanding to the full domain\n var outerMin = rangeCenter - halfRange * factor * 1.0001;\n var outerMax = rangeCenter + halfRange * factor * 1.0001;\n var getPadMin = autorange.makePadFn(fullLayout, ax, 0);\n var getPadMax = autorange.makePadFn(fullLayout, ax, 1);\n\n updateDomain(ax, factor);\n var m = Math.abs(ax._m);\n var extremes = autorange.concatExtremes(gd, ax);\n var minArray = extremes.min;\n var maxArray = extremes.max;\n var newVal;\n var k;\n\n for(k = 0; k < minArray.length; k++) {\n newVal = minArray[k].val - getPadMin(minArray[k]) / m;\n if(newVal > outerMin && newVal < rangeMin) {\n rangeMin = newVal;\n }\n }\n\n for(k = 0; k < maxArray.length; k++) {\n newVal = maxArray[k].val + getPadMax(maxArray[k]) / m;\n if(newVal < outerMax && newVal > rangeMax) {\n rangeMax = newVal;\n }\n }\n\n var domainExpand = (rangeMax - rangeMin) / (2 * halfRange);\n factor /= domainExpand;\n\n rangeMin = ax.l2r(rangeMin);\n rangeMax = ax.l2r(rangeMax);\n ax.range = ax._input.range = (rl0 < rl1) ?\n [rangeMin, rangeMax] : [rangeMax, rangeMin];\n }\n\n updateDomain(ax, factor);\n }\n }\n }\n }\n};\n\nexports.getAxisGroup = function getAxisGroup(fullLayout, axId) {\n var matchGroups = fullLayout._axisMatchGroups;\n\n for(var i = 0; i < matchGroups.length; i++) {\n var group = matchGroups[i];\n if(group[axId]) return 'g' + i;\n }\n return axId;\n};\n\n// For use before autoranging, check if this axis was previously constrained\n// by domain but no longer is\nexports.clean = function clean(gd, ax) {\n if(ax._inputDomain) {\n var isConstrained = false;\n var axId = ax._id;\n var constraintGroups = gd._fullLayout._axisConstraintGroups;\n for(var j = 0; j < constraintGroups.length; j++) {\n if(constraintGroups[j][axId]) {\n isConstrained = true;\n break;\n }\n }\n if(!isConstrained || ax.constrain !== 'domain') {\n ax._input.domain = ax.domain = ax._inputDomain;\n delete ax._inputDomain;\n }\n }\n};\n\nfunction updateDomain(ax, factor) {\n var inputDomain = ax._inputDomain;\n var centerFraction = FROM_BL[ax.constraintoward];\n var center = inputDomain[0] + (inputDomain[1] - inputDomain[0]) * centerFraction;\n\n ax.domain = ax._input.domain = [\n center + (inputDomain[0] - center) / factor,\n center + (inputDomain[1] - center) / factor\n ];\n ax.setScale();\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\nvar numberFormat = Lib.numberFormat;\nvar tinycolor = require('tinycolor2');\nvar supportsPassive = require('has-passive-events');\n\nvar Registry = require('../../registry');\nvar strTranslate = Lib.strTranslate;\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\nvar Fx = require('../../components/fx');\nvar Axes = require('./axes');\nvar setCursor = require('../../lib/setcursor');\nvar dragElement = require('../../components/dragelement');\nvar helpers = require('../../components/dragelement/helpers');\nvar selectingOrDrawing = helpers.selectingOrDrawing;\nvar freeMode = helpers.freeMode;\n\nvar FROM_TL = require('../../constants/alignment').FROM_TL;\nvar clearGlCanvases = require('../../lib/clear_gl_canvases');\nvar redrawReglTraces = require('../../plot_api/subroutines').redrawReglTraces;\n\nvar Plots = require('../plots');\n\nvar getFromId = require('./axis_ids').getFromId;\nvar prepSelect = require('../../components/selections').prepSelect;\nvar clearOutline = require('../../components/selections').clearOutline;\nvar selectOnClick = require('../../components/selections').selectOnClick;\nvar scaleZoom = require('./scale_zoom');\n\nvar constants = require('./constants');\nvar MINDRAG = constants.MINDRAG;\nvar MINZOOM = constants.MINZOOM;\n\n// flag for showing \"doubleclick to zoom out\" only at the beginning\nvar SHOWZOOMOUTTIP = true;\n\n// dragBox: create an element to drag one or more axis ends\n// inputs:\n// plotinfo - which subplot are we making dragboxes on?\n// x,y,w,h - left, top, width, height of the box\n// ns - how does this drag the vertical axis?\n// 'n' - top only\n// 's' - bottom only\n// 'ns' - top and bottom together, difference unchanged\n// ew - same for horizontal axis\nfunction makeDragBox(gd, plotinfo, x, y, w, h, ns, ew) {\n // mouseDown stores ms of first mousedown event in the last\n // `gd._context.doubleClickDelay` ms on the drag bars\n // numClicks stores how many mousedowns have been seen\n // within `gd._context.doubleClickDelay` so we can check for click or doubleclick events\n // dragged stores whether a drag has occurred, so we don't have to\n // redraw unnecessarily, ie if no move bigger than MINDRAG or MINZOOM px\n var zoomlayer = gd._fullLayout._zoomlayer;\n var isMainDrag = (ns + ew === 'nsew');\n var singleEnd = (ns + ew).length === 1;\n\n // main subplot x and y (i.e. found in plotinfo - the main ones)\n var xa0, ya0;\n // {ax._id: ax} hash objects\n var xaHash, yaHash;\n // xaHash/yaHash values (arrays)\n var xaxes, yaxes;\n // main axis offsets\n var xs, ys;\n // main axis lengths\n var pw, ph;\n // contains keys 'xaHash', 'yaHash', 'xaxes', and 'yaxes'\n // which are the x/y {ax._id: ax} hash objects and their values\n // for linked axis relative to this subplot\n var links;\n // similar to `links` but for matching axes\n var matches;\n // set to ew/ns val when active, set to '' when inactive\n var xActive, yActive;\n // are all axes in this subplot are fixed?\n var allFixedRanges;\n // do we need to edit x/y ranges?\n var editX, editY;\n // graph-wide optimization flags\n var hasScatterGl, hasSplom, hasSVG;\n // collected changes to be made to the plot by relayout at the end\n var updates;\n // scaling factors from css transform\n var scaleX;\n var scaleY;\n\n // offset the x location of the box if needed\n x += plotinfo.yaxis._shift;\n\n function recomputeAxisLists() {\n xa0 = plotinfo.xaxis;\n ya0 = plotinfo.yaxis;\n pw = xa0._length;\n ph = ya0._length;\n xs = xa0._offset;\n ys = ya0._offset;\n\n xaHash = {};\n xaHash[xa0._id] = xa0;\n yaHash = {};\n yaHash[ya0._id] = ya0;\n\n // if we're dragging two axes at once, also drag overlays\n if(ns && ew) {\n var overlays = plotinfo.overlays;\n for(var i = 0; i < overlays.length; i++) {\n var xa = overlays[i].xaxis;\n xaHash[xa._id] = xa;\n var ya = overlays[i].yaxis;\n yaHash[ya._id] = ya;\n }\n }\n\n xaxes = hashValues(xaHash);\n yaxes = hashValues(yaHash);\n xActive = isDirectionActive(xaxes, ew);\n yActive = isDirectionActive(yaxes, ns);\n allFixedRanges = !yActive && !xActive;\n\n matches = calcLinks(gd, gd._fullLayout._axisMatchGroups, xaHash, yaHash);\n links = calcLinks(gd, gd._fullLayout._axisConstraintGroups, xaHash, yaHash, matches);\n var spConstrained = links.isSubplotConstrained || matches.isSubplotConstrained;\n editX = ew || spConstrained;\n editY = ns || spConstrained;\n\n var fullLayout = gd._fullLayout;\n hasScatterGl = fullLayout._has('scattergl');\n hasSplom = fullLayout._has('splom');\n hasSVG = fullLayout._has('svg');\n }\n\n recomputeAxisLists();\n\n var cursor = getDragCursor(yActive + xActive, gd._fullLayout.dragmode, isMainDrag);\n var dragger = makeRectDragger(plotinfo, ns + ew + 'drag', cursor, x, y, w, h);\n\n // still need to make the element if the axes are disabled\n // but nuke its events (except for maindrag which needs them for hover)\n // and stop there\n if(allFixedRanges && !isMainDrag) {\n dragger.onmousedown = null;\n dragger.style.pointerEvents = 'none';\n return dragger;\n }\n\n var dragOptions = {\n element: dragger,\n gd: gd,\n plotinfo: plotinfo\n };\n\n dragOptions.prepFn = function(e, startX, startY) {\n var dragModePrev = dragOptions.dragmode;\n var dragModeNow = gd._fullLayout.dragmode;\n if(dragModeNow !== dragModePrev) {\n dragOptions.dragmode = dragModeNow;\n }\n\n recomputeAxisLists();\n\n scaleX = gd._fullLayout._invScaleX;\n scaleY = gd._fullLayout._invScaleY;\n\n if(!allFixedRanges) {\n if(isMainDrag) {\n // main dragger handles all drag modes, and changes\n // to pan (or to zoom if it already is pan) on shift\n if(e.shiftKey) {\n if(dragModeNow === 'pan') dragModeNow = 'zoom';\n else if(!selectingOrDrawing(dragModeNow)) dragModeNow = 'pan';\n } else if(e.ctrlKey) {\n dragModeNow = 'pan';\n }\n } else {\n // all other draggers just pan\n dragModeNow = 'pan';\n }\n }\n\n if(freeMode(dragModeNow)) dragOptions.minDrag = 1;\n else dragOptions.minDrag = undefined;\n\n if(selectingOrDrawing(dragModeNow)) {\n dragOptions.xaxes = xaxes;\n dragOptions.yaxes = yaxes;\n // this attaches moveFn, clickFn, doneFn on dragOptions\n prepSelect(e, startX, startY, dragOptions, dragModeNow);\n } else {\n dragOptions.clickFn = clickFn;\n if(selectingOrDrawing(dragModePrev)) {\n // TODO Fix potential bug\n // Note: clearing / resetting selection state only happens, when user\n // triggers at least one interaction in pan/zoom mode. Otherwise, the\n // select/lasso outlines are deleted (in plots.js.cleanPlot) but the selection\n // cache isn't cleared. So when the user switches back to select/lasso and\n // 'adds to a selection' with Shift, the \"old\", seemingly removed outlines\n // are redrawn again because the selection cache still holds their coordinates.\n // However, this isn't easily solved, since plots.js would need\n // to have a reference to the dragOptions object (which holds the\n // selection cache).\n clearAndResetSelect();\n }\n\n if(!allFixedRanges) {\n if(dragModeNow === 'zoom') {\n dragOptions.moveFn = zoomMove;\n dragOptions.doneFn = zoomDone;\n\n // zoomMove takes care of the threshold, but we need to\n // minimize this so that constrained zoom boxes will flip\n // orientation at the right place\n dragOptions.minDrag = 1;\n\n zoomPrep(e, startX, startY);\n } else if(dragModeNow === 'pan') {\n dragOptions.moveFn = plotDrag;\n dragOptions.doneFn = dragTail;\n }\n }\n }\n\n gd._fullLayout._redrag = function() {\n var dragDataNow = gd._dragdata;\n\n if(dragDataNow && dragDataNow.element === dragger) {\n var dragModeNow = gd._fullLayout.dragmode;\n\n if(!selectingOrDrawing(dragModeNow)) {\n recomputeAxisLists();\n updateSubplots([0, 0, pw, ph]);\n dragOptions.moveFn(dragDataNow.dx, dragDataNow.dy);\n }\n }\n };\n };\n\n function clearAndResetSelect() {\n // clear selection polygon cache (if any)\n dragOptions.plotinfo.selection = false;\n // clear selection outlines\n clearOutline(gd);\n }\n\n function clickFn(numClicks, evt) {\n var gd = dragOptions.gd;\n if(gd._fullLayout._activeShapeIndex >= 0) {\n gd._fullLayout._deactivateShape(gd);\n return;\n }\n\n var clickmode = gd._fullLayout.clickmode;\n\n removeZoombox(gd);\n\n if(numClicks === 2 && !singleEnd) doubleClick();\n\n if(isMainDrag) {\n if(clickmode.indexOf('select') > -1) {\n selectOnClick(evt, gd, xaxes, yaxes, plotinfo.id, dragOptions);\n }\n\n if(clickmode.indexOf('event') > -1) {\n Fx.click(gd, evt, plotinfo.id);\n }\n } else if(numClicks === 1 && singleEnd) {\n var ax = ns ? ya0 : xa0;\n var end = (ns === 's' || ew === 'w') ? 0 : 1;\n var attrStr = ax._name + '.range[' + end + ']';\n var initialText = getEndText(ax, end);\n var hAlign = 'left';\n var vAlign = 'middle';\n\n if(ax.fixedrange) return;\n\n if(ns) {\n vAlign = (ns === 'n') ? 'top' : 'bottom';\n if(ax.side === 'right') hAlign = 'right';\n } else if(ew === 'e') hAlign = 'right';\n\n if(gd._context.showAxisRangeEntryBoxes) {\n d3.select(dragger)\n .call(svgTextUtils.makeEditable, {\n gd: gd,\n immediate: true,\n background: gd._fullLayout.paper_bgcolor,\n text: String(initialText),\n fill: ax.tickfont ? ax.tickfont.color : '#444',\n horizontalAlign: hAlign,\n verticalAlign: vAlign\n })\n .on('edit', function(text) {\n var v = ax.d2r(text);\n if(v !== undefined) {\n Registry.call('_guiRelayout', gd, attrStr, v);\n }\n });\n }\n }\n }\n\n dragElement.init(dragOptions);\n\n // x/y px position at start of drag\n var x0, y0;\n // bbox object of the zoombox\n var box;\n // luminance of bg behind zoombox\n var lum;\n // zoombox path outline\n var path0;\n // is zoombox dimmed (during drag)\n var dimmed;\n // 'x'-only, 'y' or 'xy' zooming\n var zoomMode;\n // zoombox d3 selection\n var zb;\n // zoombox corner d3 selection\n var corners;\n // zoom takes over minDrag, so it also has to take over gd._dragged\n var zoomDragged;\n\n function zoomPrep(e, startX, startY) {\n var dragBBox = dragger.getBoundingClientRect();\n x0 = startX - dragBBox.left;\n y0 = startY - dragBBox.top;\n\n gd._fullLayout._calcInverseTransform(gd);\n var transformedCoords = Lib.apply3DTransform(gd._fullLayout._invTransform)(x0, y0);\n x0 = transformedCoords[0];\n y0 = transformedCoords[1];\n\n box = {l: x0, r: x0, w: 0, t: y0, b: y0, h: 0};\n lum = gd._hmpixcount ?\n (gd._hmlumcount / gd._hmpixcount) :\n tinycolor(gd._fullLayout.plot_bgcolor).getLuminance();\n path0 = 'M0,0H' + pw + 'V' + ph + 'H0V0';\n dimmed = false;\n zoomMode = 'xy';\n zoomDragged = false;\n zb = makeZoombox(zoomlayer, lum, xs, ys, path0);\n corners = makeCorners(zoomlayer, xs, ys);\n }\n\n function zoomMove(dx0, dy0) {\n if(gd._transitioningWithDuration) {\n return false;\n }\n\n var x1 = Math.max(0, Math.min(pw, scaleX * dx0 + x0));\n var y1 = Math.max(0, Math.min(ph, scaleY * dy0 + y0));\n var dx = Math.abs(x1 - x0);\n var dy = Math.abs(y1 - y0);\n\n box.l = Math.min(x0, x1);\n box.r = Math.max(x0, x1);\n box.t = Math.min(y0, y1);\n box.b = Math.max(y0, y1);\n\n function noZoom() {\n zoomMode = '';\n box.r = box.l;\n box.t = box.b;\n corners.attr('d', 'M0,0Z');\n }\n\n if(links.isSubplotConstrained) {\n if(dx > MINZOOM || dy > MINZOOM) {\n zoomMode = 'xy';\n if(dx / pw > dy / ph) {\n dy = dx * ph / pw;\n if(y0 > y1) box.t = y0 - dy;\n else box.b = y0 + dy;\n } else {\n dx = dy * pw / ph;\n if(x0 > x1) box.l = x0 - dx;\n else box.r = x0 + dx;\n }\n corners.attr('d', xyCorners(box));\n } else {\n noZoom();\n }\n } else if(matches.isSubplotConstrained) {\n if(dx > MINZOOM || dy > MINZOOM) {\n zoomMode = 'xy';\n\n var r0 = Math.min(box.l / pw, (ph - box.b) / ph);\n var r1 = Math.max(box.r / pw, (ph - box.t) / ph);\n\n box.l = r0 * pw;\n box.r = r1 * pw;\n box.b = (1 - r0) * ph;\n box.t = (1 - r1) * ph;\n corners.attr('d', xyCorners(box));\n } else {\n noZoom();\n }\n } else if(!yActive || dy < Math.min(Math.max(dx * 0.6, MINDRAG), MINZOOM)) {\n // look for small drags in one direction or the other,\n // and only drag the other axis\n\n if(dx < MINDRAG || !xActive) {\n noZoom();\n } else {\n box.t = 0;\n box.b = ph;\n zoomMode = 'x';\n corners.attr('d', xCorners(box, y0));\n }\n } else if(!xActive || dx < Math.min(dy * 0.6, MINZOOM)) {\n box.l = 0;\n box.r = pw;\n zoomMode = 'y';\n corners.attr('d', yCorners(box, x0));\n } else {\n zoomMode = 'xy';\n corners.attr('d', xyCorners(box));\n }\n box.w = box.r - box.l;\n box.h = box.b - box.t;\n\n if(zoomMode) zoomDragged = true;\n gd._dragged = zoomDragged;\n\n updateZoombox(zb, corners, box, path0, dimmed, lum);\n computeZoomUpdates();\n gd.emit('plotly_relayouting', updates);\n dimmed = true;\n }\n\n function computeZoomUpdates() {\n updates = {};\n\n // TODO: edit linked axes in zoomAxRanges and in dragTail\n if(zoomMode === 'xy' || zoomMode === 'x') {\n zoomAxRanges(xaxes, box.l / pw, box.r / pw, updates, links.xaxes);\n updateMatchedAxRange('x', updates);\n }\n if(zoomMode === 'xy' || zoomMode === 'y') {\n zoomAxRanges(yaxes, (ph - box.b) / ph, (ph - box.t) / ph, updates, links.yaxes);\n updateMatchedAxRange('y', updates);\n }\n }\n\n function zoomDone() {\n computeZoomUpdates();\n removeZoombox(gd);\n dragTail();\n showDoubleClickNotifier(gd);\n }\n\n // scroll zoom, on all draggers except corners\n var scrollViewBox = [0, 0, pw, ph];\n // wait a little after scrolling before redrawing\n var redrawTimer = null;\n var REDRAWDELAY = constants.REDRAWDELAY;\n var mainplot = plotinfo.mainplot ? gd._fullLayout._plots[plotinfo.mainplot] : plotinfo;\n\n function zoomWheel(e) {\n // deactivate mousewheel scrolling on embedded graphs\n // devs can override this with layout._enablescrollzoom,\n // but _ ensures this setting won't leave their page\n if(!gd._context._scrollZoom.cartesian && !gd._fullLayout._enablescrollzoom) {\n return;\n }\n\n clearAndResetSelect();\n\n // If a transition is in progress, then disable any behavior:\n if(gd._transitioningWithDuration) {\n e.preventDefault();\n e.stopPropagation();\n return;\n }\n\n recomputeAxisLists();\n\n clearTimeout(redrawTimer);\n\n var wheelDelta = -e.deltaY;\n if(!isFinite(wheelDelta)) wheelDelta = e.wheelDelta / 10;\n if(!isFinite(wheelDelta)) {\n Lib.log('Did not find wheel motion attributes: ', e);\n return;\n }\n\n var zoom = Math.exp(-Math.min(Math.max(wheelDelta, -20), 20) / 200);\n var gbb = mainplot.draglayer.select('.nsewdrag').node().getBoundingClientRect();\n var xfrac = (e.clientX - gbb.left) / gbb.width;\n var yfrac = (gbb.bottom - e.clientY) / gbb.height;\n var i;\n\n function zoomWheelOneAxis(ax, centerFraction, zoom) {\n if(ax.fixedrange) return;\n\n var axRange = Lib.simpleMap(ax.range, ax.r2l);\n var v0 = axRange[0] + (axRange[1] - axRange[0]) * centerFraction;\n function doZoom(v) { return ax.l2r(v0 + (v - v0) * zoom); }\n ax.range = axRange.map(doZoom);\n }\n\n if(editX) {\n // if we're only zooming this axis because of constraints,\n // zoom it about the center\n if(!ew) xfrac = 0.5;\n\n for(i = 0; i < xaxes.length; i++) {\n zoomWheelOneAxis(xaxes[i], xfrac, zoom);\n }\n updateMatchedAxRange('x');\n\n scrollViewBox[2] *= zoom;\n scrollViewBox[0] += scrollViewBox[2] * xfrac * (1 / zoom - 1);\n }\n if(editY) {\n if(!ns) yfrac = 0.5;\n\n for(i = 0; i < yaxes.length; i++) {\n zoomWheelOneAxis(yaxes[i], yfrac, zoom);\n }\n updateMatchedAxRange('y');\n\n scrollViewBox[3] *= zoom;\n scrollViewBox[1] += scrollViewBox[3] * (1 - yfrac) * (1 / zoom - 1);\n }\n\n // viewbox redraw at first\n updateSubplots(scrollViewBox);\n ticksAndAnnotations();\n\n gd.emit('plotly_relayouting', updates);\n\n // then replot after a delay to make sure\n // no more scrolling is coming\n redrawTimer = setTimeout(function() {\n if(!gd._fullLayout) return;\n scrollViewBox = [0, 0, pw, ph];\n dragTail();\n }, REDRAWDELAY);\n\n e.preventDefault();\n return;\n }\n\n // everything but the corners gets wheel zoom\n if(ns.length * ew.length !== 1) {\n attachWheelEventHandler(dragger, zoomWheel);\n }\n\n // plotDrag: move the plot in response to a drag\n function plotDrag(dx, dy) {\n dx = dx * scaleX;\n dy = dy * scaleY;\n // If a transition is in progress, then disable any behavior:\n if(gd._transitioningWithDuration) {\n return;\n }\n\n // prevent axis drawing from monkeying with margins until we're done\n gd._fullLayout._replotting = true;\n\n if(xActive === 'ew' || yActive === 'ns') {\n var spDx = xActive ? -dx : 0;\n var spDy = yActive ? -dy : 0;\n\n if(matches.isSubplotConstrained) {\n if(xActive && yActive) {\n var frac = (dx / pw - dy / ph) / 2;\n dx = frac * pw;\n dy = -frac * ph;\n spDx = -dx;\n spDy = -dy;\n }\n if(yActive) {\n spDx = -spDy * pw / ph;\n } else {\n spDy = -spDx * ph / pw;\n }\n }\n if(xActive) {\n dragAxList(xaxes, dx);\n updateMatchedAxRange('x');\n }\n if(yActive) {\n dragAxList(yaxes, dy);\n updateMatchedAxRange('y');\n }\n updateSubplots([spDx, spDy, pw, ph]);\n ticksAndAnnotations();\n gd.emit('plotly_relayouting', updates);\n return;\n }\n\n // dz: set a new value for one end (0 or 1) of an axis array axArray,\n // and return a pixel shift for that end for the viewbox\n // based on pixel drag distance d\n // TODO: this makes (generally non-fatal) errors when you get\n // near floating point limits\n function dz(axArray, end, d) {\n var otherEnd = 1 - end;\n var movedAx;\n var newLinearizedEnd;\n for(var i = 0; i < axArray.length; i++) {\n var axi = axArray[i];\n if(axi.fixedrange) continue;\n movedAx = axi;\n newLinearizedEnd = axi._rl[otherEnd] +\n (axi._rl[end] - axi._rl[otherEnd]) / dZoom(d / axi._length);\n var newEnd = axi.l2r(newLinearizedEnd);\n\n // if l2r comes back false or undefined, it means we've dragged off\n // the end of valid ranges - so stop.\n if(newEnd !== false && newEnd !== undefined) axi.range[end] = newEnd;\n }\n return movedAx._length * (movedAx._rl[end] - newLinearizedEnd) /\n (movedAx._rl[end] - movedAx._rl[otherEnd]);\n }\n\n var dxySign = ((xActive === 'w') === (yActive === 'n')) ? 1 : -1;\n if(xActive && yActive && (links.isSubplotConstrained || matches.isSubplotConstrained)) {\n // dragging a corner of a constrained subplot:\n // respect the fixed corner, but harmonize dx and dy\n var dxyFraction = (dx / pw + dxySign * dy / ph) / 2;\n dx = dxyFraction * pw;\n dy = dxySign * dxyFraction * ph;\n }\n\n var xStart, yStart;\n\n if(xActive === 'w') dx = dz(xaxes, 0, dx);\n else if(xActive === 'e') dx = dz(xaxes, 1, -dx);\n else if(!xActive) dx = 0;\n\n if(yActive === 'n') dy = dz(yaxes, 1, dy);\n else if(yActive === 's') dy = dz(yaxes, 0, -dy);\n else if(!yActive) dy = 0;\n\n xStart = (xActive === 'w') ? dx : 0;\n yStart = (yActive === 'n') ? dy : 0;\n\n if(\n (links.isSubplotConstrained && !matches.isSubplotConstrained) ||\n // NW or SE on matching axes - create a symmetric zoom\n (matches.isSubplotConstrained && xActive && yActive && dxySign > 0)\n ) {\n var i;\n if(matches.isSubplotConstrained || (!xActive && yActive.length === 1)) {\n // dragging one end of the y axis of a constrained subplot\n // scale the other axis the same about its middle\n for(i = 0; i < xaxes.length; i++) {\n xaxes[i].range = xaxes[i]._r.slice();\n scaleZoom(xaxes[i], 1 - dy / ph);\n }\n dx = dy * pw / ph;\n xStart = dx / 2;\n }\n if(matches.isSubplotConstrained || (!yActive && xActive.length === 1)) {\n for(i = 0; i < yaxes.length; i++) {\n yaxes[i].range = yaxes[i]._r.slice();\n scaleZoom(yaxes[i], 1 - dx / pw);\n }\n dy = dx * ph / pw;\n yStart = dy / 2;\n }\n }\n\n if(!matches.isSubplotConstrained || !yActive) {\n updateMatchedAxRange('x');\n }\n if(!matches.isSubplotConstrained || !xActive) {\n updateMatchedAxRange('y');\n }\n var xSize = pw - dx;\n var ySize = ph - dy;\n if(matches.isSubplotConstrained && !(xActive && yActive)) {\n if(xActive) {\n yStart = xStart ? 0 : (dx * ph / pw);\n ySize = xSize * ph / pw;\n } else {\n xStart = yStart ? 0 : (dy * pw / ph);\n xSize = ySize * pw / ph;\n }\n }\n updateSubplots([xStart, yStart, xSize, ySize]);\n ticksAndAnnotations();\n gd.emit('plotly_relayouting', updates);\n }\n\n function updateMatchedAxRange(axLetter, out) {\n var matchedAxes = matches.isSubplotConstrained ?\n {x: yaxes, y: xaxes}[axLetter] :\n matches[axLetter + 'axes'];\n\n var constrainedAxes = matches.isSubplotConstrained ?\n {x: xaxes, y: yaxes}[axLetter] :\n [];\n\n for(var i = 0; i < matchedAxes.length; i++) {\n var ax = matchedAxes[i];\n var axId = ax._id;\n var axId2 = matches.xLinks[axId] || matches.yLinks[axId];\n var ax2 = constrainedAxes[0] || xaHash[axId2] || yaHash[axId2];\n\n if(ax2) {\n if(out) {\n // zoombox case - don't mutate 'range', just add keys in 'updates'\n out[ax._name + '.range[0]'] = out[ax2._name + '.range[0]'];\n out[ax._name + '.range[1]'] = out[ax2._name + '.range[1]'];\n } else {\n ax.range = ax2.range.slice();\n }\n }\n }\n }\n\n // Draw ticks and annotations (and other components) when ranges change.\n // Also records the ranges that have changed for use by update at the end.\n function ticksAndAnnotations() {\n var activeAxIds = [];\n var i;\n\n function pushActiveAxIds(axList) {\n for(i = 0; i < axList.length; i++) {\n if(!axList[i].fixedrange) activeAxIds.push(axList[i]._id);\n }\n }\n\n function pushActiveAxIdsSynced(axList, axisType) {\n for(i = 0; i < axList.length; i++) {\n var axListI = axList[i];\n var axListIType = axListI[axisType];\n if(!axListI.fixedrange && axListIType.tickmode === 'sync') activeAxIds.push(axListIType._id);\n }\n }\n\n if(editX) {\n pushActiveAxIds(xaxes);\n pushActiveAxIds(links.xaxes);\n pushActiveAxIds(matches.xaxes);\n pushActiveAxIdsSynced(plotinfo.overlays, 'xaxis');\n }\n if(editY) {\n pushActiveAxIds(yaxes);\n pushActiveAxIds(links.yaxes);\n pushActiveAxIds(matches.yaxes);\n pushActiveAxIdsSynced(plotinfo.overlays, 'yaxis');\n }\n\n updates = {};\n for(i = 0; i < activeAxIds.length; i++) {\n var axId = activeAxIds[i];\n var ax = getFromId(gd, axId);\n Axes.drawOne(gd, ax, {skipTitle: true});\n updates[ax._name + '.range[0]'] = ax.range[0];\n updates[ax._name + '.range[1]'] = ax.range[1];\n }\n\n Axes.redrawComponents(gd, activeAxIds);\n }\n\n function doubleClick() {\n if(gd._transitioningWithDuration) return;\n\n var doubleClickConfig = gd._context.doubleClick;\n\n var axList = [];\n if(xActive) axList = axList.concat(xaxes);\n if(yActive) axList = axList.concat(yaxes);\n if(matches.xaxes) axList = axList.concat(matches.xaxes);\n if(matches.yaxes) axList = axList.concat(matches.yaxes);\n\n var attrs = {};\n var ax, i;\n\n // For reset+autosize mode:\n // If *any* of the main axes is not at its initial range\n // (or autoranged, if we have no initial range, to match the logic in\n // doubleClickConfig === 'reset' below), we reset.\n // If they are *all* at their initial ranges, then we autosize.\n if(doubleClickConfig === 'reset+autosize') {\n doubleClickConfig = 'autosize';\n\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n var r0 = ax._rangeInitial0;\n var r1 = ax._rangeInitial1;\n var hasRangeInitial =\n r0 !== undefined ||\n r1 !== undefined;\n\n if((hasRangeInitial && (\n (r0 !== undefined && r0 !== ax.range[0]) ||\n (r1 !== undefined && r1 !== ax.range[1])\n )) ||\n (!hasRangeInitial && ax.autorange !== true)\n ) {\n doubleClickConfig = 'reset';\n break;\n }\n }\n }\n\n if(doubleClickConfig === 'autosize') {\n // don't set the linked axes here, so relayout marks them as shrinkable\n // and we autosize just to the requested axis/axes\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n if(!ax.fixedrange) attrs[ax._name + '.autorange'] = true;\n }\n } else if(doubleClickConfig === 'reset') {\n // when we're resetting, reset all linked axes too, so we get back\n // to the fully-auto-with-constraints situation\n if(xActive || links.isSubplotConstrained) axList = axList.concat(links.xaxes);\n if(yActive && !links.isSubplotConstrained) axList = axList.concat(links.yaxes);\n\n if(links.isSubplotConstrained) {\n if(!xActive) axList = axList.concat(xaxes);\n else if(!yActive) axList = axList.concat(yaxes);\n }\n\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n\n if(!ax.fixedrange) {\n var axName = ax._name;\n\n var autorangeInitial = ax._autorangeInitial;\n if(ax._rangeInitial0 === undefined && ax._rangeInitial1 === undefined) {\n attrs[axName + '.autorange'] = true;\n } else if(ax._rangeInitial0 === undefined) {\n attrs[axName + '.autorange'] = autorangeInitial;\n attrs[axName + '.range'] = [null, ax._rangeInitial1];\n } else if(ax._rangeInitial1 === undefined) {\n attrs[axName + '.range'] = [ax._rangeInitial0, null];\n attrs[axName + '.autorange'] = autorangeInitial;\n } else {\n attrs[axName + '.range'] = [ax._rangeInitial0, ax._rangeInitial1];\n }\n }\n }\n }\n\n gd.emit('plotly_doubleclick', null);\n Registry.call('_guiRelayout', gd, attrs);\n }\n\n // dragTail - finish a drag event with a redraw\n function dragTail() {\n // put the subplot viewboxes back to default (Because we're going to)\n // be repositioning the data in the relayout. But DON'T call\n // ticksAndAnnotations again - it's unnecessary and would overwrite `updates`\n updateSubplots([0, 0, pw, ph]);\n\n // since we may have been redrawing some things during the drag, we may have\n // accumulated MathJax promises - wait for them before we relayout.\n Lib.syncOrAsync([\n Plots.previousPromises,\n function() {\n gd._fullLayout._replotting = false;\n Registry.call('_guiRelayout', gd, updates);\n }\n ], gd);\n }\n\n // updateSubplots - find all plot viewboxes that should be\n // affected by this drag, and update them. look for all plots\n // sharing an affected axis (including the one being dragged),\n // includes also scattergl and splom logic.\n function updateSubplots(viewBox) {\n var fullLayout = gd._fullLayout;\n var plotinfos = fullLayout._plots;\n var subplots = fullLayout._subplots.cartesian;\n var i, sp, xa, ya;\n\n if(hasSplom) {\n Registry.subplotsRegistry.splom.drag(gd);\n }\n\n if(hasScatterGl) {\n for(i = 0; i < subplots.length; i++) {\n sp = plotinfos[subplots[i]];\n xa = sp.xaxis;\n ya = sp.yaxis;\n\n if(sp._scene) {\n if(xa.limitRange) xa.limitRange();\n if(ya.limitRange) ya.limitRange();\n\n var xrng = Lib.simpleMap(xa.range, xa.r2l);\n var yrng = Lib.simpleMap(ya.range, ya.r2l);\n\n sp._scene.update({range: [xrng[0], yrng[0], xrng[1], yrng[1]]});\n }\n }\n }\n\n if(hasSplom || hasScatterGl) {\n clearGlCanvases(gd);\n redrawReglTraces(gd);\n }\n\n if(hasSVG) {\n var xScaleFactor = viewBox[2] / xa0._length;\n var yScaleFactor = viewBox[3] / ya0._length;\n\n for(i = 0; i < subplots.length; i++) {\n sp = plotinfos[subplots[i]];\n xa = sp.xaxis;\n ya = sp.yaxis;\n\n var editX2 = (editX || matches.isSubplotConstrained) && !xa.fixedrange && xaHash[xa._id];\n var editY2 = (editY || matches.isSubplotConstrained) && !ya.fixedrange && yaHash[ya._id];\n\n var xScaleFactor2, yScaleFactor2;\n var clipDx, clipDy;\n\n if(editX2) {\n xScaleFactor2 = xScaleFactor;\n clipDx = ew || matches.isSubplotConstrained ? viewBox[0] : getShift(xa, xScaleFactor2);\n } else if(matches.xaHash[xa._id]) {\n xScaleFactor2 = xScaleFactor;\n clipDx = viewBox[0] * xa._length / xa0._length;\n } else if(matches.yaHash[xa._id]) {\n xScaleFactor2 = yScaleFactor;\n clipDx = yActive === 'ns' ?\n -viewBox[1] * xa._length / ya0._length :\n getShift(xa, xScaleFactor2, {n: 'top', s: 'bottom'}[yActive]);\n } else {\n xScaleFactor2 = getLinkedScaleFactor(xa, xScaleFactor, yScaleFactor);\n clipDx = scaleAndGetShift(xa, xScaleFactor2);\n }\n\n if(xScaleFactor2 > 1 && (\n (xa.maxallowed !== undefined && editX === (xa.range[0] < xa.range[1] ? 'e' : 'w')) ||\n (xa.minallowed !== undefined && editX === (xa.range[0] < xa.range[1] ? 'w' : 'e'))\n )) {\n xScaleFactor2 = 1;\n clipDx = 0;\n }\n\n if(editY2) {\n yScaleFactor2 = yScaleFactor;\n clipDy = ns || matches.isSubplotConstrained ? viewBox[1] : getShift(ya, yScaleFactor2);\n } else if(matches.yaHash[ya._id]) {\n yScaleFactor2 = yScaleFactor;\n clipDy = viewBox[1] * ya._length / ya0._length;\n } else if(matches.xaHash[ya._id]) {\n yScaleFactor2 = xScaleFactor;\n clipDy = xActive === 'ew' ?\n -viewBox[0] * ya._length / xa0._length :\n getShift(ya, yScaleFactor2, {e: 'right', w: 'left'}[xActive]);\n } else {\n yScaleFactor2 = getLinkedScaleFactor(ya, xScaleFactor, yScaleFactor);\n clipDy = scaleAndGetShift(ya, yScaleFactor2);\n }\n\n if(yScaleFactor2 > 1 && (\n (ya.maxallowed !== undefined && editY === (ya.range[0] < ya.range[1] ? 'n' : 's')) ||\n (ya.minallowed !== undefined && editY === (ya.range[0] < ya.range[1] ? 's' : 'n'))\n )) {\n yScaleFactor2 = 1;\n clipDy = 0;\n }\n\n // don't scale at all if neither axis is scalable here\n if(!xScaleFactor2 && !yScaleFactor2) {\n continue;\n }\n\n // but if only one is, reset the other axis scaling\n if(!xScaleFactor2) xScaleFactor2 = 1;\n if(!yScaleFactor2) yScaleFactor2 = 1;\n\n var plotDx = xa._offset - clipDx / xScaleFactor2;\n var plotDy = ya._offset - clipDy / yScaleFactor2;\n\n // TODO could be more efficient here:\n // setTranslate and setScale do a lot of extra work\n // when working independently, should perhaps combine\n // them into a single routine.\n sp.clipRect\n .call(Drawing.setTranslate, clipDx, clipDy)\n .call(Drawing.setScale, xScaleFactor2, yScaleFactor2);\n\n sp.plot\n .call(Drawing.setTranslate, plotDx, plotDy)\n .call(Drawing.setScale, 1 / xScaleFactor2, 1 / yScaleFactor2);\n\n // apply an inverse scale to individual points to counteract\n // the scale of the trace group.\n // apply only when scale changes, as adjusting the scale of\n // all the points can be expansive.\n if(xScaleFactor2 !== sp.xScaleFactor || yScaleFactor2 !== sp.yScaleFactor) {\n Drawing.setPointGroupScale(sp.zoomScalePts, xScaleFactor2, yScaleFactor2);\n Drawing.setTextPointsScale(sp.zoomScaleTxt, xScaleFactor2, yScaleFactor2);\n }\n\n Drawing.hideOutsideRangePoints(sp.clipOnAxisFalseTraces, sp);\n\n // update x/y scaleFactor stash\n sp.xScaleFactor = xScaleFactor2;\n sp.yScaleFactor = yScaleFactor2;\n }\n }\n }\n\n // Find the appropriate scaling for this axis, if it's linked to the\n // dragged axes by constraints. 0 is special, it means this axis shouldn't\n // ever be scaled (will be converted to 1 if the other axis is scaled)\n function getLinkedScaleFactor(ax, xScaleFactor, yScaleFactor) {\n if(ax.fixedrange) return 0;\n\n if(editX && links.xaHash[ax._id]) {\n return xScaleFactor;\n }\n if(editY && (links.isSubplotConstrained ? links.xaHash : links.yaHash)[ax._id]) {\n return yScaleFactor;\n }\n return 0;\n }\n\n function scaleAndGetShift(ax, scaleFactor) {\n if(scaleFactor) {\n ax.range = ax._r.slice();\n scaleZoom(ax, scaleFactor);\n return getShift(ax, scaleFactor);\n }\n return 0;\n }\n\n function getShift(ax, scaleFactor, from) {\n return ax._length * (1 - scaleFactor) * FROM_TL[from || ax.constraintoward || 'middle'];\n }\n\n return dragger;\n}\n\nfunction makeDragger(plotinfo, nodeName, dragClass, cursor) {\n var dragger3 = Lib.ensureSingle(plotinfo.draglayer, nodeName, dragClass, function(s) {\n s.classed('drag', true)\n .style({fill: 'transparent', 'stroke-width': 0})\n .attr('data-subplot', plotinfo.id);\n });\n\n dragger3.call(setCursor, cursor);\n\n return dragger3.node();\n}\n\nfunction makeRectDragger(plotinfo, dragClass, cursor, x, y, w, h) {\n var dragger = makeDragger(plotinfo, 'rect', dragClass, cursor);\n d3.select(dragger).call(Drawing.setRect, x, y, w, h);\n return dragger;\n}\n\nfunction isDirectionActive(axList, activeVal) {\n for(var i = 0; i < axList.length; i++) {\n if(!axList[i].fixedrange) return activeVal;\n }\n return '';\n}\n\nfunction getEndText(ax, end) {\n var initialVal = ax.range[end];\n var diff = Math.abs(initialVal - ax.range[1 - end]);\n var dig;\n\n // TODO: this should basically be ax.r2d but we're doing extra\n // rounding here... can we clean up at all?\n if(ax.type === 'date') {\n return initialVal;\n } else if(ax.type === 'log') {\n dig = Math.ceil(Math.max(0, -Math.log(diff) / Math.LN10)) + 3;\n return numberFormat('.' + dig + 'g')(Math.pow(10, initialVal));\n } else { // linear numeric (or category... but just show numbers here)\n dig = Math.floor(Math.log(Math.abs(initialVal)) / Math.LN10) -\n Math.floor(Math.log(diff) / Math.LN10) + 4;\n return numberFormat('.' + String(dig) + 'g')(initialVal);\n }\n}\n\nfunction zoomAxRanges(axList, r0Fraction, r1Fraction, updates, linkedAxes) {\n for(var i = 0; i < axList.length; i++) {\n var axi = axList[i];\n if(axi.fixedrange) continue;\n\n if(axi.rangebreaks) {\n var isY = axi._id.charAt(0) === 'y';\n var r0F = isY ? (1 - r0Fraction) : r0Fraction;\n var r1F = isY ? (1 - r1Fraction) : r1Fraction;\n\n updates[axi._name + '.range[0]'] = axi.l2r(axi.p2l(r0F * axi._length));\n updates[axi._name + '.range[1]'] = axi.l2r(axi.p2l(r1F * axi._length));\n } else {\n var axRangeLinear0 = axi._rl[0];\n var axRangeLinearSpan = axi._rl[1] - axRangeLinear0;\n updates[axi._name + '.range[0]'] = axi.l2r(axRangeLinear0 + axRangeLinearSpan * r0Fraction);\n updates[axi._name + '.range[1]'] = axi.l2r(axRangeLinear0 + axRangeLinearSpan * r1Fraction);\n }\n }\n\n // zoom linked axes about their centers\n if(linkedAxes && linkedAxes.length) {\n var linkedR0Fraction = (r0Fraction + (1 - r1Fraction)) / 2;\n zoomAxRanges(linkedAxes, linkedR0Fraction, 1 - linkedR0Fraction, updates, []);\n }\n}\n\nfunction dragAxList(axList, pix) {\n for(var i = 0; i < axList.length; i++) {\n var axi = axList[i];\n if(!axi.fixedrange) {\n if(axi.rangebreaks) {\n var p0 = 0;\n var p1 = axi._length;\n var d0 = axi.p2l(p0 + pix) - axi.p2l(p0);\n var d1 = axi.p2l(p1 + pix) - axi.p2l(p1);\n var delta = (d0 + d1) / 2;\n\n axi.range = [\n axi.l2r(axi._rl[0] - delta),\n axi.l2r(axi._rl[1] - delta)\n ];\n } else {\n axi.range = [\n axi.l2r(axi._rl[0] - pix / axi._m),\n axi.l2r(axi._rl[1] - pix / axi._m)\n ];\n }\n\n if(axi.limitRange) axi.limitRange();\n }\n }\n}\n\n// common transform for dragging one end of an axis\n// d>0 is compressing scale (cursor is over the plot,\n// the axis end should move with the cursor)\n// d<0 is expanding (cursor is off the plot, axis end moves\n// nonlinearly so you can expand far)\nfunction dZoom(d) {\n return 1 - ((d >= 0) ? Math.min(d, 0.9) :\n 1 / (1 / Math.max(d, -0.3) + 3.222));\n}\n\nfunction getDragCursor(nsew, dragmode, isMainDrag) {\n if(!nsew) return 'pointer';\n if(nsew === 'nsew') {\n // in this case here, clear cursor and\n // use the cursor style set on \n if(isMainDrag) return '';\n if(dragmode === 'pan') return 'move';\n return 'crosshair';\n }\n return nsew.toLowerCase() + '-resize';\n}\n\nfunction makeZoombox(zoomlayer, lum, xs, ys, path0) {\n return zoomlayer.append('path')\n .attr('class', 'zoombox')\n .style({\n fill: lum > 0.2 ? 'rgba(0,0,0,0)' : 'rgba(255,255,255,0)',\n 'stroke-width': 0\n })\n .attr('transform', strTranslate(xs, ys))\n .attr('d', path0 + 'Z');\n}\n\nfunction makeCorners(zoomlayer, xs, ys) {\n return zoomlayer.append('path')\n .attr('class', 'zoombox-corners')\n .style({\n fill: Color.background,\n stroke: Color.defaultLine,\n 'stroke-width': 1,\n opacity: 0\n })\n .attr('transform', strTranslate(xs, ys))\n .attr('d', 'M0,0Z');\n}\n\nfunction updateZoombox(zb, corners, box, path0, dimmed, lum) {\n zb.attr('d',\n path0 + 'M' + (box.l) + ',' + (box.t) + 'v' + (box.h) +\n 'h' + (box.w) + 'v-' + (box.h) + 'h-' + (box.w) + 'Z');\n transitionZoombox(zb, corners, dimmed, lum);\n}\n\nfunction transitionZoombox(zb, corners, dimmed, lum) {\n if(!dimmed) {\n zb.transition()\n .style('fill', lum > 0.2 ? 'rgba(0,0,0,0.4)' :\n 'rgba(255,255,255,0.3)')\n .duration(200);\n corners.transition()\n .style('opacity', 1)\n .duration(200);\n }\n}\n\nfunction removeZoombox(gd) {\n d3.select(gd)\n .selectAll('.zoombox,.js-zoombox-backdrop,.js-zoombox-menu,.zoombox-corners')\n .remove();\n}\n\nfunction showDoubleClickNotifier(gd) {\n if(SHOWZOOMOUTTIP && gd.data && gd._context.showTips) {\n Lib.notifier(Lib._(gd, 'Double-click to zoom back out'), 'long');\n SHOWZOOMOUTTIP = false;\n }\n}\n\nfunction xCorners(box, y0) {\n return 'M' +\n (box.l - 0.5) + ',' + (y0 - MINZOOM - 0.5) +\n 'h-3v' + (2 * MINZOOM + 1) + 'h3ZM' +\n (box.r + 0.5) + ',' + (y0 - MINZOOM - 0.5) +\n 'h3v' + (2 * MINZOOM + 1) + 'h-3Z';\n}\n\nfunction yCorners(box, x0) {\n return 'M' +\n (x0 - MINZOOM - 0.5) + ',' + (box.t - 0.5) +\n 'v-3h' + (2 * MINZOOM + 1) + 'v3ZM' +\n (x0 - MINZOOM - 0.5) + ',' + (box.b + 0.5) +\n 'v3h' + (2 * MINZOOM + 1) + 'v-3Z';\n}\n\nfunction xyCorners(box) {\n var clen = Math.floor(Math.min(box.b - box.t, box.r - box.l, MINZOOM) / 2);\n return 'M' +\n (box.l - 3.5) + ',' + (box.t - 0.5 + clen) + 'h3v' + (-clen) +\n 'h' + clen + 'v-3h-' + (clen + 3) + 'ZM' +\n (box.r + 3.5) + ',' + (box.t - 0.5 + clen) + 'h-3v' + (-clen) +\n 'h' + (-clen) + 'v-3h' + (clen + 3) + 'ZM' +\n (box.r + 3.5) + ',' + (box.b + 0.5 - clen) + 'h-3v' + clen +\n 'h' + (-clen) + 'v3h' + (clen + 3) + 'ZM' +\n (box.l - 3.5) + ',' + (box.b + 0.5 - clen) + 'h3v' + clen +\n 'h' + clen + 'v3h-' + (clen + 3) + 'Z';\n}\n\nfunction calcLinks(gd, groups, xaHash, yaHash, exclude) {\n var isSubplotConstrained = false;\n var xLinks = {};\n var yLinks = {};\n var xID, yID, xLinkID, yLinkID;\n var xExclude = (exclude || {}).xaHash;\n var yExclude = (exclude || {}).yaHash;\n\n for(var i = 0; i < groups.length; i++) {\n var group = groups[i];\n // check if any of the x axes we're dragging is in this constraint group\n for(xID in xaHash) {\n if(group[xID]) {\n // put the rest of these axes into xLinks, if we're not already\n // dragging them, so we know to scale these axes automatically too\n // to match the changes in the dragged x axes\n for(xLinkID in group) {\n if(\n !(exclude && (xExclude[xLinkID] || yExclude[xLinkID])) &&\n !(xLinkID.charAt(0) === 'x' ? xaHash : yaHash)[xLinkID]\n ) {\n xLinks[xLinkID] = xID;\n }\n }\n\n // check if the x and y axes of THIS drag are linked\n for(yID in yaHash) {\n if(\n !(exclude && (xExclude[yID] || yExclude[yID])) &&\n group[yID]\n ) {\n isSubplotConstrained = true;\n }\n }\n }\n }\n\n // now check if any of the y axes we're dragging is in this constraint group\n // only look for outside links, as we've already checked for links within the dragger\n for(yID in yaHash) {\n if(group[yID]) {\n for(yLinkID in group) {\n if(\n !(exclude && (xExclude[yLinkID] || yExclude[yLinkID])) &&\n !(yLinkID.charAt(0) === 'x' ? xaHash : yaHash)[yLinkID]\n ) {\n yLinks[yLinkID] = yID;\n }\n }\n }\n }\n }\n\n if(isSubplotConstrained) {\n // merge xLinks and yLinks if the subplot is constrained,\n // since we'll always apply both anyway and the two will contain\n // duplicates\n Lib.extendFlat(xLinks, yLinks);\n yLinks = {};\n }\n\n var xaHashLinked = {};\n var xaxesLinked = [];\n for(xLinkID in xLinks) {\n var xa = getFromId(gd, xLinkID);\n xaxesLinked.push(xa);\n xaHashLinked[xa._id] = xa;\n }\n\n var yaHashLinked = {};\n var yaxesLinked = [];\n for(yLinkID in yLinks) {\n var ya = getFromId(gd, yLinkID);\n yaxesLinked.push(ya);\n yaHashLinked[ya._id] = ya;\n }\n\n return {\n xaHash: xaHashLinked,\n yaHash: yaHashLinked,\n xaxes: xaxesLinked,\n yaxes: yaxesLinked,\n xLinks: xLinks,\n yLinks: yLinks,\n isSubplotConstrained: isSubplotConstrained\n };\n}\n\n// still seems to be some confusion about onwheel vs onmousewheel...\nfunction attachWheelEventHandler(element, handler) {\n if(!supportsPassive) {\n if(element.onwheel !== undefined) element.onwheel = handler;\n else if(element.onmousewheel !== undefined) element.onmousewheel = handler;\n else if(!element.isAddedWheelEvent) {\n element.isAddedWheelEvent = true;\n element.addEventListener('wheel', handler, {passive: false});\n }\n } else {\n var wheelEventName = element.onwheel !== undefined ? 'wheel' : 'mousewheel';\n\n if(element._onwheel) {\n element.removeEventListener(wheelEventName, element._onwheel);\n }\n element._onwheel = handler;\n\n element.addEventListener(wheelEventName, handler, {passive: false});\n }\n}\n\nfunction hashValues(hash) {\n var out = [];\n for(var k in hash) out.push(hash[k]);\n return out;\n}\n\nmodule.exports = {\n makeDragBox: makeDragBox,\n\n makeDragger: makeDragger,\n makeRectDragger: makeRectDragger,\n makeZoombox: makeZoombox,\n makeCorners: makeCorners,\n\n updateZoombox: updateZoombox,\n xyCorners: xyCorners,\n transitionZoombox: transitionZoombox,\n removeZoombox: removeZoombox,\n showDoubleClickNotifier: showDoubleClickNotifier,\n\n attachWheelEventHandler: attachWheelEventHandler\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Fx = require('../../components/fx');\nvar dragElement = require('../../components/dragelement');\nvar setCursor = require('../../lib/setcursor');\n\nvar makeDragBox = require('./dragbox').makeDragBox;\nvar DRAGGERSIZE = require('./constants').DRAGGERSIZE;\n\nexports.initInteractions = function initInteractions(gd) {\n var fullLayout = gd._fullLayout;\n\n if(gd._context.staticPlot) {\n // this sweeps up more than just cartesian drag elements...\n d3.select(gd).selectAll('.drag').remove();\n return;\n }\n\n if(!fullLayout._has('cartesian') && !fullLayout._has('splom')) return;\n\n var subplots = Object.keys(fullLayout._plots || {}).sort(function(a, b) {\n // sort overlays last, then by x axis number, then y axis number\n if((fullLayout._plots[a].mainplot && true) ===\n (fullLayout._plots[b].mainplot && true)) {\n var aParts = a.split('y');\n var bParts = b.split('y');\n return (aParts[0] === bParts[0]) ?\n (Number(aParts[1] || 1) - Number(bParts[1] || 1)) :\n (Number(aParts[0] || 1) - Number(bParts[0] || 1));\n }\n return fullLayout._plots[a].mainplot ? 1 : -1;\n });\n\n subplots.forEach(function(subplot) {\n var plotinfo = fullLayout._plots[subplot];\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n // main and corner draggers need not be repeated for\n // overlaid subplots - these draggers drag them all\n if(!plotinfo.mainplot) {\n // main dragger goes over the grids and data, so we use its\n // mousemove events for all data hover effects\n var maindrag = makeDragBox(gd, plotinfo, xa._offset, ya._offset,\n xa._length, ya._length, 'ns', 'ew');\n\n maindrag.onmousemove = function(evt) {\n // This is on `gd._fullLayout`, *not* fullLayout because the reference\n // changes by the time this is called again.\n gd._fullLayout._rehover = function() {\n if((gd._fullLayout._hoversubplot === subplot) && gd._fullLayout._plots[subplot]) {\n Fx.hover(gd, evt, subplot);\n }\n };\n\n Fx.hover(gd, evt, subplot);\n\n // Note that we have *not* used the cached fullLayout variable here\n // since that may be outdated when this is called as a callback later on\n gd._fullLayout._lasthover = maindrag;\n gd._fullLayout._hoversubplot = subplot;\n };\n\n /*\n * IMPORTANT:\n * We must check for the presence of the drag cover here.\n * If we don't, a 'mouseout' event is triggered on the\n * maindrag before each 'click' event, which has the effect\n * of clearing the hoverdata; thus, cancelling the click event.\n */\n maindrag.onmouseout = function(evt) {\n if(gd._dragging) return;\n\n // When the mouse leaves this maindrag, unset the hovered subplot.\n // This may cause problems if it leaves the subplot directly *onto*\n // another subplot, but that's a tiny corner case at the moment.\n gd._fullLayout._hoversubplot = null;\n\n dragElement.unhover(gd, evt);\n };\n\n // corner draggers\n if(gd._context.showAxisDragHandles) {\n makeDragBox(gd, plotinfo, xa._offset - DRAGGERSIZE, ya._offset - DRAGGERSIZE,\n DRAGGERSIZE, DRAGGERSIZE, 'n', 'w');\n makeDragBox(gd, plotinfo, xa._offset + xa._length, ya._offset - DRAGGERSIZE,\n DRAGGERSIZE, DRAGGERSIZE, 'n', 'e');\n makeDragBox(gd, plotinfo, xa._offset - DRAGGERSIZE, ya._offset + ya._length,\n DRAGGERSIZE, DRAGGERSIZE, 's', 'w');\n makeDragBox(gd, plotinfo, xa._offset + xa._length, ya._offset + ya._length,\n DRAGGERSIZE, DRAGGERSIZE, 's', 'e');\n }\n }\n if(gd._context.showAxisDragHandles) {\n // x axis draggers - if you have overlaid plots,\n // these drag each axis separately\n if(subplot === xa._mainSubplot) {\n // the y position of the main x axis line\n var y0 = xa._mainLinePosition;\n if(xa.side === 'top') y0 -= DRAGGERSIZE;\n makeDragBox(gd, plotinfo, xa._offset + xa._length * 0.1, y0,\n xa._length * 0.8, DRAGGERSIZE, '', 'ew');\n makeDragBox(gd, plotinfo, xa._offset, y0,\n xa._length * 0.1, DRAGGERSIZE, '', 'w');\n makeDragBox(gd, plotinfo, xa._offset + xa._length * 0.9, y0,\n xa._length * 0.1, DRAGGERSIZE, '', 'e');\n }\n // y axis draggers\n if(subplot === ya._mainSubplot) {\n // the x position of the main y axis line\n var x0 = ya._mainLinePosition;\n if(ya.side !== 'right') x0 -= DRAGGERSIZE;\n makeDragBox(gd, plotinfo, x0, ya._offset + ya._length * 0.1,\n DRAGGERSIZE, ya._length * 0.8, 'ns', '');\n makeDragBox(gd, plotinfo, x0, ya._offset + ya._length * 0.9,\n DRAGGERSIZE, ya._length * 0.1, 's', '');\n makeDragBox(gd, plotinfo, x0, ya._offset,\n DRAGGERSIZE, ya._length * 0.1, 'n', '');\n }\n }\n });\n\n // In case you mousemove over some hovertext, send it to Fx.hover too\n // we do this so that we can put the hover text in front of everything,\n // but still be able to interact with everything as if it isn't there\n var hoverLayer = fullLayout._hoverlayer.node();\n\n hoverLayer.onmousemove = function(evt) {\n evt.target = gd._fullLayout._lasthover;\n Fx.hover(gd, evt, fullLayout._hoversubplot);\n };\n\n hoverLayer.onclick = function(evt) {\n evt.target = gd._fullLayout._lasthover;\n Fx.click(gd, evt);\n };\n\n // also delegate mousedowns... TODO: does this actually work?\n hoverLayer.onmousedown = function(evt) {\n gd._fullLayout._lasthover.onmousedown(evt);\n };\n\n exports.updateFx(gd);\n};\n\n// Minimal set of update needed on 'modebar' edits.\n// We only need to update the cursor style.\n//\n// Note that changing the axis configuration and/or the fixedrange attribute\n// should trigger a full initInteractions.\nexports.updateFx = function(gd) {\n var fullLayout = gd._fullLayout;\n var cursor = fullLayout.dragmode === 'pan' ? 'move' : 'crosshair';\n setCursor(fullLayout._draggers, cursor);\n};\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar axisIds = require('./axis_ids');\n\n/**\n * Factory function for checking component arrays for subplot references.\n *\n * @param {string} containerArrayName: the top-level array in gd.layout to check\n * If an item in this container is found that references a cartesian x and/or y axis,\n * ensure cartesian is marked as a base plot module and record the axes (and subplot\n * if both refs are axes) in gd._fullLayout\n *\n * @return {function}: with args layoutIn (gd.layout) and layoutOut (gd._fullLayout)\n * as expected of a component includeBasePlot method\n */\nmodule.exports = function makeIncludeComponents(containerArrayName) {\n return function includeComponents(layoutIn, layoutOut) {\n var array = layoutIn[containerArrayName];\n if(!Array.isArray(array)) return;\n\n var Cartesian = Registry.subplotsRegistry.cartesian;\n var idRegex = Cartesian.idRegex;\n var subplots = layoutOut._subplots;\n var xaList = subplots.xaxis;\n var yaList = subplots.yaxis;\n var cartesianList = subplots.cartesian;\n var hasCartesianOrGL2D = layoutOut._has('cartesian') || layoutOut._has('gl2d');\n\n for(var i = 0; i < array.length; i++) {\n var itemi = array[i];\n if(!Lib.isPlainObject(itemi)) continue;\n\n // call cleanId because if xref, or yref has something appended\n // (e.g., ' domain') this will get removed.\n var xref = axisIds.cleanId(itemi.xref, 'x', false);\n var yref = axisIds.cleanId(itemi.yref, 'y', false);\n\n var hasXref = idRegex.x.test(xref);\n var hasYref = idRegex.y.test(yref);\n if(hasXref || hasYref) {\n if(!hasCartesianOrGL2D) Lib.pushUnique(layoutOut._basePlotModules, Cartesian);\n\n var newAxis = false;\n if(hasXref && xaList.indexOf(xref) === -1) {\n xaList.push(xref);\n newAxis = true;\n }\n if(hasYref && yaList.indexOf(yref) === -1) {\n yaList.push(yref);\n newAxis = true;\n }\n\n /*\n * Notice the logic here: only add a subplot for a component if\n * it's referencing both x and y axes AND it's creating a new axis\n * so for example if your plot already has xy and x2y2, an annotation\n * on x2y or xy2 will not create a new subplot.\n */\n if(newAxis && hasXref && hasYref) {\n cartesianList.push(xref + yref);\n }\n }\n }\n };\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Plots = require('../plots');\nvar Drawing = require('../../components/drawing');\n\nvar getModuleCalcData = require('../get_data').getModuleCalcData;\nvar axisIds = require('./axis_ids');\nvar constants = require('./constants');\nvar xmlnsNamespaces = require('../../constants/xmlns_namespaces');\n\nvar ensureSingle = Lib.ensureSingle;\n\nfunction ensureSingleAndAddDatum(parent, nodeType, className) {\n return Lib.ensureSingle(parent, nodeType, className, function(s) {\n s.datum(className);\n });\n}\n\nvar zindexSeparator = constants.zindexSeparator;\n\nexports.name = 'cartesian';\n\nexports.attr = ['xaxis', 'yaxis'];\n\nexports.idRoot = ['x', 'y'];\n\nexports.idRegex = constants.idRegex;\n\nexports.attrRegex = constants.attrRegex;\n\nexports.attributes = require('./attributes');\n\nexports.layoutAttributes = require('./layout_attributes');\n\nexports.supplyLayoutDefaults = require('./layout_defaults');\n\nexports.transitionAxes = require('./transition_axes');\n\nexports.finalizeSubplots = function(layoutIn, layoutOut) {\n var subplots = layoutOut._subplots;\n var xList = subplots.xaxis;\n var yList = subplots.yaxis;\n var spSVG = subplots.cartesian;\n var spAll = spSVG.concat(subplots.gl2d || []);\n var allX = {};\n var allY = {};\n var i, xi, yi;\n\n for(i = 0; i < spAll.length; i++) {\n var parts = spAll[i].split('y');\n allX[parts[0]] = 1;\n allY['y' + parts[1]] = 1;\n }\n\n // check for x axes with no subplot, and make one from the anchor of that x axis\n for(i = 0; i < xList.length; i++) {\n xi = xList[i];\n if(!allX[xi]) {\n yi = (layoutIn[axisIds.id2name(xi)] || {}).anchor;\n if(!constants.idRegex.y.test(yi)) yi = 'y';\n spSVG.push(xi + yi);\n spAll.push(xi + yi);\n\n if(!allY[yi]) {\n allY[yi] = 1;\n Lib.pushUnique(yList, yi);\n }\n }\n }\n\n // same for y axes with no subplot\n for(i = 0; i < yList.length; i++) {\n yi = yList[i];\n if(!allY[yi]) {\n xi = (layoutIn[axisIds.id2name(yi)] || {}).anchor;\n if(!constants.idRegex.x.test(xi)) xi = 'x';\n spSVG.push(xi + yi);\n spAll.push(xi + yi);\n\n if(!allX[xi]) {\n allX[xi] = 1;\n Lib.pushUnique(xList, xi);\n }\n }\n }\n\n // finally, if we've gotten here we're supposed to show cartesian...\n // so if there are NO subplots at all, make one from the first\n // x & y axes in the input layout\n if(!spAll.length) {\n xi = '';\n yi = '';\n for(var ki in layoutIn) {\n if(constants.attrRegex.test(ki)) {\n var axLetter = ki.charAt(0);\n if(axLetter === 'x') {\n if(!xi || (+ki.substr(5) < +xi.substr(5))) {\n xi = ki;\n }\n } else if(!yi || (+ki.substr(5) < +yi.substr(5))) {\n yi = ki;\n }\n }\n }\n xi = xi ? axisIds.name2id(xi) : 'x';\n yi = yi ? axisIds.name2id(yi) : 'y';\n xList.push(xi);\n yList.push(yi);\n spSVG.push(xi + yi);\n }\n};\n\n/**\n * Cartesian.plot\n *\n * @param {DOM div | object} gd\n * @param {array (optional)} traces\n * array of traces indices to plot\n * if undefined, plots all cartesian traces,\n * @param {object} (optional) transitionOpts\n * transition option object\n * @param {function} (optional) makeOnCompleteCallback\n * transition make callback function from Plots.transition\n */\nexports.plot = function(gd, traces, transitionOpts, makeOnCompleteCallback) {\n var fullLayout = gd._fullLayout;\n var subplots = fullLayout._subplots.cartesian;\n var calcdata = gd.calcdata;\n var i;\n\n // Traces is a list of trace indices to (re)plot. If it's not provided,\n // then it's a complete replot so we create a new list and add all trace indices\n // which are in calcdata.\n\n if(!Array.isArray(traces)) {\n // If traces is not provided, then it's a complete replot and missing\n // traces are removed\n traces = [];\n for(i = 0; i < calcdata.length; i++) traces.push(i);\n }\n\n var zindices = fullLayout._zindices;\n // Plot each zorder group in ascending order\n for(var z = 0; z < zindices.length; z++) {\n var zorder = zindices[z];\n\n // For each subplot\n for(i = 0; i < subplots.length; i++) {\n var subplot = subplots[i];\n var subplotInfo = fullLayout._plots[subplot];\n\n if(z > 0) {\n var idWithZ = subplotInfo.id;\n if(idWithZ.indexOf(zindexSeparator) !== -1) continue;\n idWithZ += zindexSeparator + (z + 1);\n subplotInfo = Lib.extendFlat({}, subplotInfo, {\n id: idWithZ,\n plot: fullLayout._cartesianlayer.selectAll('.subplot').select('.' + idWithZ)\n });\n }\n\n // Get all calcdata (traces) for this subplot:\n var cdSubplot = [];\n var pcd;\n\n // For each trace\n for(var j = 0; j < calcdata.length; j++) {\n var cd = calcdata[j];\n var trace = cd[0].trace;\n\n if(zorder !== (trace.zorder || 0)) continue;\n\n // Skip trace if whitelist provided and it's not whitelisted:\n // if (Array.isArray(traces) && traces.indexOf(i) === -1) continue;\n if(trace.xaxis + trace.yaxis === subplot) {\n // XXX: Should trace carpet dependencies. Only replot all carpet plots if the carpet\n // axis has actually changed:\n //\n // If this trace is specifically requested, add it to the list:\n if(traces.indexOf(trace.index) !== -1 || trace.carpet) {\n // Okay, so example: traces 0, 1, and 2 have fill = tonext. You animate\n // traces 0 and 2. Trace 1 also needs to be updated, otherwise its fill\n // is outdated. So this retroactively adds the previous trace if the\n // traces are interdependent.\n if(\n pcd &&\n pcd[0].trace.xaxis + pcd[0].trace.yaxis === subplot &&\n ['tonextx', 'tonexty', 'tonext'].indexOf(trace.fill) !== -1 &&\n cdSubplot.indexOf(pcd) === -1\n ) {\n cdSubplot.push(pcd);\n }\n\n cdSubplot.push(cd);\n }\n\n // Track the previous trace on this subplot for the retroactive-add step\n // above:\n pcd = cd;\n }\n }\n // Plot the traces for this subplot\n plotOne(gd, subplotInfo, cdSubplot, transitionOpts, makeOnCompleteCallback);\n }\n }\n};\n\nfunction plotOne(gd, plotinfo, cdSubplot, transitionOpts, makeOnCompleteCallback) {\n var traceLayerClasses = constants.traceLayerClasses;\n var fullLayout = gd._fullLayout;\n var zindices = fullLayout._zindices;\n\n var modules = fullLayout._modules;\n var _module, cdModuleAndOthers, cdModule;\n\n var layerData = [];\n var zoomScaleQueryParts = [];\n\n // Plot each zorder group in ascending order\n for(var z = 0; z < zindices.length; z++) {\n var zorder = zindices[z];\n // For each \"module\" (trace type)\n for(var i = 0; i < modules.length; i++) {\n _module = modules[i];\n var name = _module.name;\n var categories = Registry.modules[name].categories;\n\n if(categories.svg) {\n var classBaseName = (_module.layerName || name + 'layer');\n var className = classBaseName + (z ? Number(z) + 1 : '');\n var plotMethod = _module.plot;\n\n // plot all visible traces of this type on this subplot at once\n cdModuleAndOthers = getModuleCalcData(cdSubplot, plotMethod, zorder);\n cdModule = cdModuleAndOthers[0];\n // don't need to search the found traces again - in fact we need to NOT\n // so that if two modules share the same plotter we don't double-plot\n cdSubplot = cdModuleAndOthers[1];\n\n if(cdModule.length) {\n layerData.push({\n i: traceLayerClasses.indexOf(classBaseName),\n zindex: z,\n className: className,\n plotMethod: plotMethod,\n cdModule: cdModule\n });\n }\n\n if(categories.zoomScale) {\n zoomScaleQueryParts.push('.' + className);\n }\n }\n }\n }\n // Sort the layers primarily by zindex, then by i\n layerData.sort(function(a, b) {\n return (\n (a.zindex || 0) - (b.zindex || 0) ||\n (a.i - b.i)\n );\n });\n\n var layers = plotinfo.plot.selectAll('g.mlayer')\n .data(layerData, function(d) { return d.className; });\n\n layers.enter().append('g')\n .attr('class', function(d) { return d.className; })\n .classed('mlayer', true)\n .classed('rangeplot', plotinfo.isRangePlot);\n\n layers.exit().remove();\n\n layers.order();\n\n layers.each(function(d) {\n var sel = d3.select(this);\n var className = d.className;\n\n d.plotMethod(\n gd, plotinfo, d.cdModule, sel,\n transitionOpts, makeOnCompleteCallback\n );\n\n // layers that allow `cliponaxis: false`\n if(constants.clipOnAxisFalseQuery.indexOf('.' + className) === -1) {\n Drawing.setClipUrl(sel, plotinfo.layerClipId, gd);\n }\n });\n\n // call Scattergl.plot separately\n if(fullLayout._has('scattergl')) {\n _module = Registry.getModule('scattergl');\n cdModule = getModuleCalcData(cdSubplot, _module)[0];\n _module.plot(gd, plotinfo, cdModule);\n }\n\n // stash \"hot\" selections for faster interaction on drag and scroll\n if(!gd._context.staticPlot) {\n if(plotinfo._hasClipOnAxisFalse) {\n plotinfo.clipOnAxisFalseTraces = plotinfo.plot\n .selectAll(constants.clipOnAxisFalseQuery.join(','))\n .selectAll('.trace');\n }\n\n if(zoomScaleQueryParts.length) {\n var traces = plotinfo.plot\n .selectAll(zoomScaleQueryParts.join(','))\n .selectAll('.trace');\n\n plotinfo.zoomScalePts = traces.selectAll('path.point');\n plotinfo.zoomScaleTxt = traces.selectAll('.textpoint');\n }\n }\n}\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var oldPlots = oldFullLayout._plots || {};\n var newPlots = newFullLayout._plots || {};\n var oldSubplotList = oldFullLayout._subplots || {};\n var plotinfo;\n var i, k;\n\n // when going from a large splom graph to something else,\n // we need to clear so that the new cartesian subplot\n // can have the correct layer ordering\n if(oldFullLayout._hasOnlyLargeSploms && !newFullLayout._hasOnlyLargeSploms) {\n for(k in oldPlots) {\n plotinfo = oldPlots[k];\n if(plotinfo.plotgroup) plotinfo.plotgroup.remove();\n }\n }\n\n var hadGl = (oldFullLayout._has && oldFullLayout._has('gl'));\n var hasGl = (newFullLayout._has && newFullLayout._has('gl'));\n\n if(hadGl && !hasGl) {\n for(k in oldPlots) {\n plotinfo = oldPlots[k];\n if(plotinfo._scene) plotinfo._scene.destroy();\n }\n }\n\n // delete any titles we don't need anymore\n // check if axis list has changed, and if so clear old titles\n if(oldSubplotList.xaxis && oldSubplotList.yaxis) {\n var oldAxIDs = axisIds.listIds({_fullLayout: oldFullLayout});\n for(i = 0; i < oldAxIDs.length; i++) {\n var oldAxId = oldAxIDs[i];\n if(!newFullLayout[axisIds.id2name(oldAxId)]) {\n oldFullLayout._infolayer.selectAll('.g-' + oldAxId + 'title').remove();\n }\n }\n }\n\n var hadCartesian = (oldFullLayout._has && oldFullLayout._has('cartesian'));\n var hasCartesian = (newFullLayout._has && newFullLayout._has('cartesian'));\n\n if(hadCartesian && !hasCartesian) {\n // if we've gotten rid of all cartesian traces, remove all the subplot svg items\n\n purgeSubplotLayers(oldFullLayout._cartesianlayer.selectAll('.subplot'), oldFullLayout);\n oldFullLayout._defs.selectAll('.axesclip').remove();\n delete oldFullLayout._axisConstraintGroups;\n delete oldFullLayout._axisMatchGroups;\n } else if(oldSubplotList.cartesian) {\n // otherwise look for subplots we need to remove\n\n for(i = 0; i < oldSubplotList.cartesian.length; i++) {\n var oldSubplotId = oldSubplotList.cartesian[i];\n\n // skip zindex layes in this process\n if(oldSubplotId.indexOf(zindexSeparator) !== -1) continue;\n\n if(!newPlots[oldSubplotId]) {\n var selector = '.' + oldSubplotId + ',.' + oldSubplotId + '-x,.' + oldSubplotId + '-y';\n oldFullLayout._cartesianlayer.selectAll(selector).remove();\n removeSubplotExtras(oldSubplotId, oldFullLayout);\n }\n }\n }\n};\n\nexports.drawFramework = function(gd) {\n var fullLayout = gd._fullLayout;\n var calcdata = gd.calcdata;\n var i;\n\n // Separate traces by zorder and plot each zorder group separately\n var traceZorderGroups = {};\n for(i = 0; i < calcdata.length; i++) {\n var cdi = calcdata[i][0];\n var trace = cdi.trace;\n\n var zi = trace.zorder || 0;\n if(!traceZorderGroups[zi]) traceZorderGroups[zi] = [];\n traceZorderGroups[zi].push(cdi);\n }\n\n // Group by zorder group in ascending order\n var zindices = Object.keys(traceZorderGroups)\n .map(Number)\n .sort(Lib.sorterAsc);\n\n if(!zindices.length) zindices = [0];\n\n fullLayout._zindices = zindices;\n\n var initialSubplotData = makeSubplotData(gd);\n\n var len = initialSubplotData.length;\n var subplotData = [];\n for(i = 0; i < len; i++) {\n subplotData[i] = initialSubplotData[i].slice();\n }\n\n for(var z = 1; z < zindices.length; z++) {\n var newSubplotData = [];\n for(i = 0; i < len; i++) {\n newSubplotData[i] = initialSubplotData[i].slice();\n newSubplotData[i][0] += zindexSeparator + (z + 1);\n }\n subplotData = subplotData.concat(newSubplotData);\n }\n\n var subplotLayers = fullLayout._cartesianlayer.selectAll('.subplot')\n .data(subplotData, String);\n\n\n subplotLayers.enter().append('g')\n .attr('class', function(d) { return 'subplot ' + d[0]; });\n\n subplotLayers.order();\n\n subplotLayers.exit()\n .call(purgeSubplotLayers, fullLayout);\n\n subplotLayers.each(function(d) {\n var id = d[0];\n var posZ = id.indexOf(zindexSeparator);\n var hasZ = posZ !== -1;\n var idWithoutZ = hasZ ?\n id.slice(0, posZ) :\n id;\n\n var plotinfo = fullLayout._plots[id];\n if(!plotinfo) {\n plotinfo = Lib.extendFlat({}, fullLayout._plots[idWithoutZ]);\n\n if(plotinfo) {\n plotinfo.id = id;\n fullLayout._plots[id] = plotinfo;\n fullLayout._subplots.cartesian.push(id);\n }\n }\n\n if(plotinfo) {\n plotinfo.plotgroup = d3.select(this);\n makeSubplotLayer(gd, plotinfo);\n\n if(!hasZ) {\n // make separate drag layers for each subplot,\n // but append them to paper rather than the plot groups,\n // so they end up on top of the rest\n plotinfo.draglayer = ensureSingle(fullLayout._draggers, 'g', id);\n }\n }\n });\n};\n\nexports.rangePlot = function(gd, plotinfo, cdSubplot) {\n makeSubplotLayer(gd, plotinfo);\n plotOne(gd, plotinfo, cdSubplot);\n Plots.style(gd);\n};\n\nfunction makeSubplotData(gd) {\n var fullLayout = gd._fullLayout;\n var numZ = fullLayout._zindices.length;\n\n var ids = fullLayout._subplots.cartesian;\n var len = ids.length;\n var i, j, id, plotinfo, xa, ya;\n\n // split 'regular' and 'overlaying' subplots\n var regulars = [];\n var overlays = [];\n\n for(i = 0; i < len; i++) {\n id = ids[i];\n plotinfo = fullLayout._plots[id];\n xa = plotinfo.xaxis;\n ya = plotinfo.yaxis;\n\n var xa2 = xa._mainAxis;\n var ya2 = ya._mainAxis;\n var mainplot = xa2._id + ya2._id;\n var mainplotinfo = fullLayout._plots[mainplot];\n plotinfo.overlays = [];\n\n if(mainplot !== id && mainplotinfo) {\n plotinfo.mainplot = mainplot;\n plotinfo.mainplotinfo = mainplotinfo;\n overlays.push(id);\n } else {\n plotinfo.mainplot = undefined;\n plotinfo.mainplotinfo = undefined;\n regulars.push(id);\n }\n }\n\n // fill in list of overlaying subplots in 'main plot'\n for(i = 0; i < overlays.length; i++) {\n id = overlays[i];\n plotinfo = fullLayout._plots[id];\n plotinfo.mainplotinfo.overlays.push(plotinfo);\n }\n\n // put 'regular' subplot data before 'overlaying'\n var subplotIds = regulars.concat(overlays);\n var subplotData = [];\n\n for(i = 0; i < len; i++) {\n id = subplotIds[i];\n plotinfo = fullLayout._plots[id];\n xa = plotinfo.xaxis;\n ya = plotinfo.yaxis;\n\n var d = [];\n\n for(var z = 1; z <= numZ; z++) {\n var zStr = '';\n if(z > 1) zStr += zindexSeparator + z;\n\n // use info about axis layer and overlaying pattern\n // to clean what need to be cleaned up in exit selection\n d.push(id + zStr);\n for(j = 0; j < plotinfo.overlays.length; j++) {\n d.push(plotinfo.overlays[j].id + zStr);\n }\n }\n\n d = d.concat([\n xa.layer,\n ya.layer,\n xa.overlaying || '',\n ya.overlaying || ''\n ]);\n\n subplotData.push(d);\n }\n return subplotData;\n}\n\nfunction makeSubplotLayer(gd, plotinfo) {\n var fullLayout = gd._fullLayout;\n var plotgroup = plotinfo.plotgroup;\n var id = plotinfo.id;\n\n var posZ = id.indexOf(zindexSeparator);\n var hasZ = posZ !== -1;\n\n var xLayer = constants.layerValue2layerClass[plotinfo.xaxis.layer];\n var yLayer = constants.layerValue2layerClass[plotinfo.yaxis.layer];\n var hasOnlyLargeSploms = fullLayout._hasOnlyLargeSploms;\n\n if(!plotinfo.mainplot || fullLayout._zindices.length > 1) {\n if(hasOnlyLargeSploms) {\n // TODO could do even better\n // - we don't need plot (but we would have to mock it in lsInner\n // and other places\n // - we don't (x|y)lines and (x|y)axislayer for most subplots\n // usually just the bottom x and left y axes.\n plotinfo.xlines = ensureSingle(plotgroup, 'path', 'xlines-above');\n plotinfo.ylines = ensureSingle(plotgroup, 'path', 'ylines-above');\n plotinfo.xaxislayer = ensureSingle(plotgroup, 'g', 'xaxislayer-above');\n plotinfo.yaxislayer = ensureSingle(plotgroup, 'g', 'yaxislayer-above');\n } else {\n if(!hasZ) {\n var backLayer = ensureSingle(plotgroup, 'g', 'layer-subplot');\n plotinfo.shapelayer = ensureSingle(backLayer, 'g', 'shapelayer');\n plotinfo.imagelayer = ensureSingle(backLayer, 'g', 'imagelayer');\n\n plotinfo.minorGridlayer = ensureSingle(plotgroup, 'g', 'minor-gridlayer');\n plotinfo.gridlayer = ensureSingle(plotgroup, 'g', 'gridlayer');\n plotinfo.zerolinelayer = ensureSingle(plotgroup, 'g', 'zerolinelayer');\n\n var betweenLayer = ensureSingle(plotgroup, 'g', 'layer-between');\n plotinfo.shapelayerBetween = ensureSingle(betweenLayer, 'g', 'shapelayer');\n plotinfo.imagelayerBetween = ensureSingle(betweenLayer, 'g', 'imagelayer');\n\n ensureSingle(plotgroup, 'path', 'xlines-below');\n ensureSingle(plotgroup, 'path', 'ylines-below');\n plotinfo.overlinesBelow = ensureSingle(plotgroup, 'g', 'overlines-below');\n\n ensureSingle(plotgroup, 'g', 'xaxislayer-below');\n ensureSingle(plotgroup, 'g', 'yaxislayer-below');\n plotinfo.overaxesBelow = ensureSingle(plotgroup, 'g', 'overaxes-below');\n }\n\n plotinfo.overplot = ensureSingle(plotgroup, 'g', 'overplot');\n plotinfo.plot = ensureSingle(plotinfo.overplot, 'g', id);\n\n if(!hasZ) {\n plotinfo.xlines = ensureSingle(plotgroup, 'path', 'xlines-above');\n plotinfo.ylines = ensureSingle(plotgroup, 'path', 'ylines-above');\n plotinfo.overlinesAbove = ensureSingle(plotgroup, 'g', 'overlines-above');\n\n ensureSingle(plotgroup, 'g', 'xaxislayer-above');\n ensureSingle(plotgroup, 'g', 'yaxislayer-above');\n plotinfo.overaxesAbove = ensureSingle(plotgroup, 'g', 'overaxes-above');\n\n // set refs to correct layers as determined by 'axis.layer'\n plotinfo.xlines = plotgroup.select('.xlines-' + xLayer);\n plotinfo.ylines = plotgroup.select('.ylines-' + yLayer);\n plotinfo.xaxislayer = plotgroup.select('.xaxislayer-' + xLayer);\n plotinfo.yaxislayer = plotgroup.select('.yaxislayer-' + yLayer);\n }\n }\n } else {\n var mainplotinfo = plotinfo.mainplotinfo;\n var mainplotgroup = mainplotinfo.plotgroup;\n var xId = id + '-x';\n var yId = id + '-y';\n\n // now make the components of overlaid subplots\n // overlays don't have backgrounds, and append all\n // their other components to the corresponding\n // extra groups of their main plots.\n\n plotinfo.minorGridlayer = mainplotinfo.minorGridlayer;\n plotinfo.gridlayer = mainplotinfo.gridlayer;\n plotinfo.zerolinelayer = mainplotinfo.zerolinelayer;\n\n ensureSingle(mainplotinfo.overlinesBelow, 'path', xId);\n ensureSingle(mainplotinfo.overlinesBelow, 'path', yId);\n ensureSingle(mainplotinfo.overaxesBelow, 'g', xId);\n ensureSingle(mainplotinfo.overaxesBelow, 'g', yId);\n\n plotinfo.plot = ensureSingle(mainplotinfo.overplot, 'g', id);\n\n ensureSingle(mainplotinfo.overlinesAbove, 'path', xId);\n ensureSingle(mainplotinfo.overlinesAbove, 'path', yId);\n ensureSingle(mainplotinfo.overaxesAbove, 'g', xId);\n ensureSingle(mainplotinfo.overaxesAbove, 'g', yId);\n\n // set refs to correct layers as determined by 'abovetraces'\n plotinfo.xlines = mainplotgroup.select('.overlines-' + xLayer).select('.' + xId);\n plotinfo.ylines = mainplotgroup.select('.overlines-' + yLayer).select('.' + yId);\n plotinfo.xaxislayer = mainplotgroup.select('.overaxes-' + xLayer).select('.' + xId);\n plotinfo.yaxislayer = mainplotgroup.select('.overaxes-' + yLayer).select('.' + yId);\n }\n\n if(!hasZ) {\n // common attributes for all subplots, overlays or not\n\n if(!hasOnlyLargeSploms) {\n ensureSingleAndAddDatum(plotinfo.minorGridlayer, 'g', plotinfo.xaxis._id);\n ensureSingleAndAddDatum(plotinfo.minorGridlayer, 'g', plotinfo.yaxis._id);\n plotinfo.minorGridlayer.selectAll('g')\n .map(function(d) { return d[0]; })\n .sort(axisIds.idSort);\n\n ensureSingleAndAddDatum(plotinfo.gridlayer, 'g', plotinfo.xaxis._id);\n ensureSingleAndAddDatum(plotinfo.gridlayer, 'g', plotinfo.yaxis._id);\n plotinfo.gridlayer.selectAll('g')\n .map(function(d) { return d[0]; })\n .sort(axisIds.idSort);\n }\n\n plotinfo.xlines\n .style('fill', 'none')\n .classed('crisp', true);\n\n plotinfo.ylines\n .style('fill', 'none')\n .classed('crisp', true);\n }\n}\n\nfunction purgeSubplotLayers(layers, fullLayout) {\n if(!layers) return;\n\n var overlayIdsToRemove = {};\n\n layers.each(function(d) {\n var id = d[0];\n var plotgroup = d3.select(this);\n\n plotgroup.remove();\n removeSubplotExtras(id, fullLayout);\n overlayIdsToRemove[id] = true;\n\n // do not remove individual axis s here\n // as other subplots may need them\n });\n\n // must remove overlaid subplot trace layers 'manually'\n\n for(var k in fullLayout._plots) {\n var subplotInfo = fullLayout._plots[k];\n var overlays = subplotInfo.overlays || [];\n\n for(var j = 0; j < overlays.length; j++) {\n var overlayInfo = overlays[j];\n\n if(overlayIdsToRemove[overlayInfo.id]) {\n overlayInfo.plot.selectAll('.trace').remove();\n }\n }\n }\n}\n\nfunction removeSubplotExtras(subplotId, fullLayout) {\n fullLayout._draggers.selectAll('g.' + subplotId).remove();\n fullLayout._defs.select('#clip' + fullLayout._uid + subplotId + 'plot').remove();\n}\n\nexports.toSVG = function(gd) {\n var imageRoot = gd._fullLayout._glimages;\n var root = d3.select(gd).selectAll('.svg-container');\n var canvases = root.filter(function(d, i) {return i === root.size() - 1;})\n .selectAll('.gl-canvas-context, .gl-canvas-focus');\n\n function canvasToImage() {\n var canvas = this;\n var imageData = canvas.toDataURL('image/png');\n var image = imageRoot.append('svg:image');\n\n image.attr({\n xmlns: xmlnsNamespaces.svg,\n 'xlink:href': imageData,\n preserveAspectRatio: 'none',\n x: 0,\n y: 0,\n width: canvas.style.width,\n height: canvas.style.height\n });\n }\n\n canvases.each(canvasToImage);\n};\n\nexports.updateFx = require('./graph_interact').updateFx;\n","'use strict';\n\nvar fontAttrs = require('../font_attributes');\nvar colorAttrs = require('../../components/color/attributes');\nvar dash = require('../../components/drawing/attributes').dash;\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\nvar descriptionWithDates = require('../../plots/cartesian/axis_format_attributes').descriptionWithDates;\n\nvar ONEDAY = require('../../constants/numerical').ONEDAY;\nvar constants = require('./constants');\nvar HOUR = constants.HOUR_PATTERN;\nvar DAY_OF_WEEK = constants.WEEKDAY_PATTERN;\n\nvar minorTickmode = {\n valType: 'enumerated',\n values: ['auto', 'linear', 'array'],\n editType: 'ticks',\n impliedEdits: {tick0: undefined, dtick: undefined},\n description: [\n 'Sets the tick mode for this axis.',\n 'If *auto*, the number of ticks is set via `nticks`.',\n 'If *linear*, the placement of the ticks is determined by',\n 'a starting position `tick0` and a tick step `dtick`',\n '(*linear* is the default value if `tick0` and `dtick` are provided).',\n 'If *array*, the placement of the ticks is set via `tickvals`',\n 'and the tick text is `ticktext`.',\n '(*array* is the default value if `tickvals` is provided).'\n ].join(' ')\n};\n\nvar tickmode = extendFlat({}, minorTickmode, {\n values: minorTickmode.values.slice().concat(['sync']),\n description: [\n minorTickmode.description,\n 'If *sync*, the number of ticks will sync with the overlayed axis',\n 'set by `overlaying` property.'\n ].join(' ')\n});\n\nfunction makeNticks(minor) {\n return {\n valType: 'integer',\n min: 0,\n dflt: minor ? 5 : 0,\n editType: 'ticks',\n description: [\n 'Specifies the maximum number of ticks for the particular axis.',\n 'The actual number of ticks will be chosen automatically to be',\n 'less than or equal to `nticks`.',\n 'Has an effect only if `tickmode` is set to *auto*.'\n ].join(' ')\n };\n}\n\nvar tick0 = {\n valType: 'any',\n editType: 'ticks',\n impliedEdits: {tickmode: 'linear'},\n description: [\n 'Sets the placement of the first tick on this axis.',\n 'Use with `dtick`.',\n 'If the axis `type` is *log*, then you must take the log of your starting tick',\n '(e.g. to set the starting tick to 100, set the `tick0` to 2)',\n 'except when `dtick`=*L* (see `dtick` for more info).',\n 'If the axis `type` is *date*, it should be a date string, like date data.',\n 'If the axis `type` is *category*, it should be a number, using the scale where',\n 'each category is assigned a serial number from zero in the order it appears.'\n ].join(' ')\n};\n\nvar dtick = {\n valType: 'any',\n editType: 'ticks',\n impliedEdits: {tickmode: 'linear'},\n description: [\n 'Sets the step in-between ticks on this axis. Use with `tick0`.',\n 'Must be a positive number, or special strings available to *log* and *date* axes.',\n 'If the axis `type` is *log*, then ticks are set every 10^(n*dtick) where n',\n 'is the tick number. For example,',\n 'to set a tick mark at 1, 10, 100, 1000, ... set dtick to 1.',\n 'To set tick marks at 1, 100, 10000, ... set dtick to 2.',\n 'To set tick marks at 1, 5, 25, 125, 625, 3125, ... set dtick to log_10(5), or 0.69897000433.',\n '*log* has several special values; *L*, where `f` is a positive number,',\n 'gives ticks linearly spaced in value (but not position).',\n 'For example `tick0` = 0.1, `dtick` = *L0.5* will put ticks at 0.1, 0.6, 1.1, 1.6 etc.',\n 'To show powers of 10 plus small digits between, use *D1* (all digits) or *D2* (only 2 and 5).',\n '`tick0` is ignored for *D1* and *D2*.',\n 'If the axis `type` is *date*, then you must convert the time to milliseconds.',\n 'For example, to set the interval between ticks to one day,',\n 'set `dtick` to 86400000.0.',\n '*date* also has special values *M* gives ticks spaced by a number of months.',\n '`n` must be a positive integer.',\n 'To set ticks on the 15th of every third month, set `tick0` to *2000-01-15* and `dtick` to *M3*.',\n 'To set ticks every 4 years, set `dtick` to *M48*'\n ].join(' ')\n};\n\nvar tickvals = {\n valType: 'data_array',\n editType: 'ticks',\n description: [\n 'Sets the values at which ticks on this axis appear.',\n 'Only has an effect if `tickmode` is set to *array*.',\n 'Used with `ticktext`.'\n ].join(' ')\n};\n\nvar ticks = {\n valType: 'enumerated',\n values: ['outside', 'inside', ''],\n editType: 'ticks',\n description: [\n 'Determines whether ticks are drawn or not.',\n 'If **, this axis\\' ticks are not drawn.',\n 'If *outside* (*inside*), this axis\\' are drawn outside (inside)',\n 'the axis lines.'\n ].join(' ')\n};\n\nfunction makeTicklen(minor) {\n var obj = {\n valType: 'number',\n min: 0,\n editType: 'ticks',\n description: 'Sets the tick length (in px).'\n };\n\n if(!minor) obj.dflt = 5;\n\n return obj;\n}\n\nfunction makeTickwidth(minor) {\n var obj = {\n valType: 'number',\n min: 0,\n editType: 'ticks',\n description: 'Sets the tick width (in px).'\n };\n\n if(!minor) obj.dflt = 1;\n\n return obj;\n}\n\nvar tickcolor = {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n editType: 'ticks',\n description: 'Sets the tick color.'\n};\n\nvar gridcolor = {\n valType: 'color',\n dflt: colorAttrs.lightLine,\n editType: 'ticks',\n description: 'Sets the color of the grid lines.'\n};\n\nfunction makeGridwidth(minor) {\n var obj = {\n valType: 'number',\n min: 0,\n editType: 'ticks',\n description: 'Sets the width (in px) of the grid lines.'\n };\n\n if(!minor) obj.dflt = 1;\n\n return obj;\n}\n\nvar griddash = extendFlat({}, dash, {editType: 'ticks'});\n\nvar showgrid = {\n valType: 'boolean',\n editType: 'ticks',\n description: [\n 'Determines whether or not grid lines are drawn.',\n 'If *true*, the grid lines are drawn at every tick mark.'\n ].join(' ')\n};\n\nmodule.exports = {\n visible: {\n valType: 'boolean',\n editType: 'plot',\n description: [\n 'A single toggle to hide the axis while preserving interaction like dragging.',\n 'Default is true when a cheater plot is present on the axis, otherwise',\n 'false'\n ].join(' ')\n },\n color: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n editType: 'ticks',\n description: [\n 'Sets default for all colors associated with this axis',\n 'all at once: line, font, tick, and grid colors.',\n 'Grid color is lightened by blending this with the plot background',\n 'Individual pieces can override this.'\n ].join(' ')\n },\n title: {\n text: {\n valType: 'string',\n editType: 'ticks',\n description: [\n 'Sets the title of this axis.',\n 'Note that before the existence of `title.text`, the title\\'s',\n 'contents used to be defined as the `title` attribute itself.',\n 'This behavior has been deprecated.'\n ].join(' ')\n },\n font: fontAttrs({\n editType: 'ticks',\n description: [\n 'Sets this axis\\' title font.',\n 'Note that the title\\'s font used to be customized',\n 'by the now deprecated `titlefont` attribute.'\n ].join(' ')\n }),\n standoff: {\n valType: 'number',\n min: 0,\n editType: 'ticks',\n description: [\n 'Sets the standoff distance (in px) between the axis labels and the title text',\n 'The default value is a function of the axis tick labels, the title `font.size`',\n 'and the axis `linewidth`.',\n 'Note that the axis title position is always constrained within the margins,',\n 'so the actual standoff distance is always less than the set or default value.',\n 'By setting `standoff` and turning on `automargin`, plotly.js will push the',\n 'margins to fit the axis title at given standoff distance.'\n ].join(' ')\n },\n editType: 'ticks'\n },\n type: {\n valType: 'enumerated',\n // '-' means we haven't yet run autotype or couldn't find any data\n // it gets turned into linear in gd._fullLayout but not copied back\n // to gd.data like the others are.\n values: ['-', 'linear', 'log', 'date', 'category', 'multicategory'],\n dflt: '-',\n editType: 'calc',\n // we forget when an axis has been autotyped, just writing the auto\n // value back to the input - so it doesn't make sense to template this.\n // Note: we do NOT prohibit this in `coerce`, so if someone enters a\n // type in the template explicitly it will be honored as the default.\n _noTemplating: true,\n description: [\n 'Sets the axis type.',\n 'By default, plotly attempts to determined the axis type',\n 'by looking into the data of the traces that referenced',\n 'the axis in question.'\n ].join(' ')\n },\n autotypenumbers: {\n valType: 'enumerated',\n values: ['convert types', 'strict'],\n dflt: 'convert types',\n editType: 'calc',\n description: [\n 'Using *strict* a numeric string in trace data is not converted to a number.',\n 'Using *convert types* a numeric string in trace data may be',\n 'treated as a number during automatic axis `type` detection.',\n 'Defaults to layout.autotypenumbers.'\n ].join(' ')\n },\n autorange: {\n valType: 'enumerated',\n values: [true, false, 'reversed', 'min reversed', 'max reversed', 'min', 'max'],\n dflt: true,\n editType: 'axrange',\n impliedEdits: {'range[0]': undefined, 'range[1]': undefined},\n description: [\n 'Determines whether or not the range of this axis is',\n 'computed in relation to the input data.',\n 'See `rangemode` for more info.',\n 'If `range` is provided and it has a value for both the',\n 'lower and upper bound, `autorange` is set to *false*.',\n 'Using *min* applies autorange only to set the minimum.',\n 'Using *max* applies autorange only to set the maximum.',\n 'Using *min reversed* applies autorange only to set the minimum on a reversed axis.',\n 'Using *max reversed* applies autorange only to set the maximum on a reversed axis.',\n 'Using *reversed* applies autorange on both ends and reverses the axis direction.',\n ].join(' ')\n },\n autorangeoptions: {\n minallowed: {\n valType: 'any',\n editType: 'plot',\n impliedEdits: {'range[0]': undefined, 'range[1]': undefined},\n description: [\n 'Use this value exactly as autorange minimum.'\n ].join(' ')\n },\n maxallowed: {\n valType: 'any',\n editType: 'plot',\n impliedEdits: {'range[0]': undefined, 'range[1]': undefined},\n description: [\n 'Use this value exactly as autorange maximum.'\n ].join(' ')\n },\n clipmin: {\n valType: 'any',\n editType: 'plot',\n impliedEdits: {'range[0]': undefined, 'range[1]': undefined},\n description: [\n 'Clip autorange minimum if it goes beyond this value.',\n 'Has no effect when `autorangeoptions.minallowed` is provided.'\n ].join(' ')\n },\n clipmax: {\n valType: 'any',\n editType: 'plot',\n impliedEdits: {'range[0]': undefined, 'range[1]': undefined},\n description: [\n 'Clip autorange maximum if it goes beyond this value.',\n 'Has no effect when `autorangeoptions.maxallowed` is provided.'\n ].join(' ')\n },\n include: {\n valType: 'any',\n arrayOk: true,\n editType: 'plot',\n impliedEdits: {'range[0]': undefined, 'range[1]': undefined},\n description: [\n 'Ensure this value is included in autorange.'\n ].join(' ')\n },\n editType: 'plot'\n },\n rangemode: {\n valType: 'enumerated',\n values: ['normal', 'tozero', 'nonnegative'],\n dflt: 'normal',\n editType: 'plot',\n description: [\n 'If *normal*, the range is computed in relation to the extrema',\n 'of the input data.',\n 'If *tozero*`, the range extends to 0,',\n 'regardless of the input data',\n 'If *nonnegative*, the range is non-negative,',\n 'regardless of the input data.',\n 'Applies only to linear axes.'\n ].join(' ')\n },\n range: {\n valType: 'info_array',\n items: [\n {valType: 'any', editType: 'axrange', impliedEdits: {'^autorange': false}, anim: true},\n {valType: 'any', editType: 'axrange', impliedEdits: {'^autorange': false}, anim: true}\n ],\n editType: 'axrange',\n impliedEdits: {autorange: false},\n anim: true,\n description: [\n 'Sets the range of this axis.',\n 'If the axis `type` is *log*, then you must take the log of your',\n 'desired range (e.g. to set the range from 1 to 100,',\n 'set the range from 0 to 2).',\n 'If the axis `type` is *date*, it should be date strings,',\n 'like date data, though Date objects and unix milliseconds',\n 'will be accepted and converted to strings.',\n 'If the axis `type` is *category*, it should be numbers,',\n 'using the scale where each category is assigned a serial',\n 'number from zero in the order it appears.',\n 'Leaving either or both elements `null` impacts the default `autorange`.',\n ].join(' ')\n },\n minallowed: {\n valType: 'any',\n editType: 'plot',\n impliedEdits: {'^autorange': false},\n description: [\n 'Determines the minimum range of this axis.'\n ].join(' ')\n },\n maxallowed: {\n valType: 'any',\n editType: 'plot',\n impliedEdits: {'^autorange': false},\n description: [\n 'Determines the maximum range of this axis.'\n ].join(' ')\n },\n fixedrange: {\n valType: 'boolean',\n dflt: false,\n editType: 'calc',\n description: [\n 'Determines whether or not this axis is zoom-able.',\n 'If true, then zoom is disabled.'\n ].join(' ')\n },\n insiderange: {\n valType: 'info_array',\n items: [\n {valType: 'any', editType: 'plot'},\n {valType: 'any', editType: 'plot'}\n ],\n editType: 'plot',\n description: [\n 'Could be used to set the desired inside range of this axis',\n '(excluding the labels) when `ticklabelposition` of',\n 'the anchored axis has *inside*.',\n 'Not implemented for axes with `type` *log*.',\n 'This would be ignored when `range` is provided.'\n ].join(' ')\n },\n // scaleanchor: not used directly, just put here for reference\n // values are any opposite-letter axis id, or `false`.\n scaleanchor: {\n valType: 'enumerated',\n values: [\n constants.idRegex.x.toString(),\n constants.idRegex.y.toString(),\n false\n ],\n editType: 'plot',\n description: [\n 'If set to another axis id (e.g. `x2`, `y`), the range of this axis',\n 'changes together with the range of the corresponding axis',\n 'such that the scale of pixels per unit is in a constant ratio.',\n 'Both axes are still zoomable, but when you zoom one, the other will',\n 'zoom the same amount, keeping a fixed midpoint.',\n '`constrain` and `constraintoward` determine how we enforce the constraint.',\n 'You can chain these, ie `yaxis: {scaleanchor: *x*}, xaxis2: {scaleanchor: *y*}`',\n 'but you can only link axes of the same `type`.',\n 'The linked axis can have the opposite letter (to constrain the aspect ratio)',\n 'or the same letter (to match scales across subplots).',\n 'Loops (`yaxis: {scaleanchor: *x*}, xaxis: {scaleanchor: *y*}` or longer) are redundant',\n 'and the last constraint encountered will be ignored to avoid possible',\n 'inconsistent constraints via `scaleratio`.',\n 'Note that setting axes simultaneously in both a `scaleanchor` and a `matches` constraint',\n 'is currently forbidden.',\n 'Setting `false` allows to remove a default constraint (occasionally,',\n 'you may need to prevent a default `scaleanchor` constraint from',\n 'being applied, eg. when having an image trace `yaxis: {scaleanchor: \"x\"}`',\n 'is set automatically in order for pixels to be rendered as squares,',\n 'setting `yaxis: {scaleanchor: false}` allows to remove the constraint).'\n ].join(' ')\n },\n scaleratio: {\n valType: 'number',\n min: 0,\n dflt: 1,\n editType: 'plot',\n description: [\n 'If this axis is linked to another by `scaleanchor`, this determines the pixel',\n 'to unit scale ratio. For example, if this value is 10, then every unit on',\n 'this axis spans 10 times the number of pixels as a unit on the linked axis.',\n 'Use this for example to create an elevation profile where the vertical scale',\n 'is exaggerated a fixed amount with respect to the horizontal.'\n ].join(' ')\n },\n constrain: {\n valType: 'enumerated',\n values: ['range', 'domain'],\n editType: 'plot',\n description: [\n 'If this axis needs to be compressed (either due to its own `scaleanchor` and',\n '`scaleratio` or those of the other axis), determines how that happens:',\n 'by increasing the *range*, or by decreasing the *domain*.',\n 'Default is *domain* for axes containing image traces, *range* otherwise.'\n ].join(' ')\n },\n // constraintoward: not used directly, just put here for reference\n constraintoward: {\n valType: 'enumerated',\n values: ['left', 'center', 'right', 'top', 'middle', 'bottom'],\n editType: 'plot',\n description: [\n 'If this axis needs to be compressed (either due to its own `scaleanchor` and',\n '`scaleratio` or those of the other axis), determines which direction we push',\n 'the originally specified plot area. Options are *left*, *center* (default),',\n 'and *right* for x axes, and *top*, *middle* (default), and *bottom* for y axes.'\n ].join(' ')\n },\n matches: {\n valType: 'enumerated',\n values: [\n constants.idRegex.x.toString(),\n constants.idRegex.y.toString()\n ],\n editType: 'calc',\n description: [\n 'If set to another axis id (e.g. `x2`, `y`), the range of this axis',\n 'will match the range of the corresponding axis in data-coordinates space.',\n 'Moreover, matching axes share auto-range values, category lists and',\n 'histogram auto-bins.',\n 'Note that setting axes simultaneously in both a `scaleanchor` and a `matches` constraint',\n 'is currently forbidden.',\n 'Moreover, note that matching axes must have the same `type`.'\n ].join(' ')\n },\n\n rangebreaks: templatedArray('rangebreak', {\n enabled: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether this axis rangebreak is enabled or disabled.',\n 'Please note that `rangebreaks` only work for *date* axis type.'\n ].join(' ')\n },\n\n bounds: {\n valType: 'info_array',\n items: [\n {valType: 'any', editType: 'calc'},\n {valType: 'any', editType: 'calc'}\n ],\n editType: 'calc',\n description: [\n 'Sets the lower and upper bounds of this axis rangebreak.',\n 'Can be used with `pattern`.'\n ].join(' ')\n },\n\n pattern: {\n valType: 'enumerated',\n values: [DAY_OF_WEEK, HOUR, ''],\n editType: 'calc',\n description: [\n 'Determines a pattern on the time line that generates breaks.',\n 'If *' + DAY_OF_WEEK + '* - days of the week in English e.g. \\'Sunday\\' or `\\sun\\`',\n '(matching is case-insensitive and considers only the first three characters),',\n 'as well as Sunday-based integers between 0 and 6.',\n 'If *' + HOUR + '* - hour (24-hour clock) as decimal numbers between 0 and 24.',\n 'for more info.',\n 'Examples:',\n '- { pattern: \\'' + DAY_OF_WEEK + '\\', bounds: [6, 1] }',\n ' or simply { bounds: [\\'sat\\', \\'mon\\'] }',\n ' breaks from Saturday to Monday (i.e. skips the weekends).',\n '- { pattern: \\'' + HOUR + '\\', bounds: [17, 8] }',\n ' breaks from 5pm to 8am (i.e. skips non-work hours).'\n ].join(' ')\n },\n\n values: {\n valType: 'info_array',\n freeLength: true,\n editType: 'calc',\n items: {\n valType: 'any',\n editType: 'calc'\n },\n description: [\n 'Sets the coordinate values corresponding to the rangebreaks.',\n 'An alternative to `bounds`.',\n 'Use `dvalue` to set the size of the values along the axis.'\n ].join(' ')\n },\n dvalue: {\n // TODO could become 'any' to add support for 'months', 'years'\n valType: 'number',\n editType: 'calc',\n min: 0,\n dflt: ONEDAY,\n description: [\n 'Sets the size of each `values` item.',\n 'The default is one day in milliseconds.'\n ].join(' ')\n },\n\n /*\n gap: {\n valType: 'number',\n min: 0,\n dflt: 0, // for *date* axes, maybe something else for *linear*\n editType: 'calc',\n description: [\n 'Sets the gap distance between the start and the end of this rangebreak.',\n 'Use with `gapmode` to set the unit of measurement.'\n ].join(' ')\n },\n gapmode: {\n valType: 'enumerated',\n values: ['pixels', 'fraction'],\n dflt: 'pixels',\n editType: 'calc',\n description: [\n 'Determines if the `gap` value corresponds to a pixel length',\n 'or a fraction of the plot area.'\n ].join(' ')\n },\n */\n\n // To complete https://github.com/plotly/plotly.js/issues/4210\n // we additionally need `gap` and make this work on *linear*, and\n // possibly all other cartesian axis types. We possibly would also need\n // some style attributes controlling the zig-zag on the corresponding\n // axis.\n\n editType: 'calc'\n }),\n\n // ticks\n tickmode: tickmode,\n nticks: makeNticks(),\n tick0: tick0,\n dtick: dtick,\n ticklabelstep: {\n valType: 'integer',\n min: 1,\n dflt: 1,\n editType: 'ticks',\n description: [\n 'Sets the spacing between tick labels as compared to the spacing between ticks.',\n 'A value of 1 (default) means each tick gets a label.',\n 'A value of 2 means shows every 2nd label.',\n 'A larger value n means only every nth tick is labeled.',\n '`tick0` determines which labels are shown.',\n 'Not implemented for axes with `type` *log* or *multicategory*, or when `tickmode` is *array*.'\n ].join(' ')\n },\n tickvals: tickvals,\n ticktext: {\n valType: 'data_array',\n editType: 'ticks',\n description: [\n 'Sets the text displayed at the ticks position via `tickvals`.',\n 'Only has an effect if `tickmode` is set to *array*.',\n 'Used with `tickvals`.'\n ].join(' ')\n },\n ticks: ticks,\n tickson: {\n valType: 'enumerated',\n values: ['labels', 'boundaries'],\n dflt: 'labels',\n editType: 'ticks',\n description: [\n 'Determines where ticks and grid lines are drawn with respect to their',\n 'corresponding tick labels.',\n 'Only has an effect for axes of `type` *category* or *multicategory*.',\n 'When set to *boundaries*, ticks and grid lines are drawn half a category',\n 'to the left/bottom of labels.'\n ].join(' ')\n },\n ticklabelmode: {\n valType: 'enumerated',\n values: ['instant', 'period'],\n dflt: 'instant',\n editType: 'ticks',\n description: [\n 'Determines where tick labels are drawn with respect to their',\n 'corresponding ticks and grid lines.',\n 'Only has an effect for axes of `type` *date*',\n 'When set to *period*, tick labels are drawn in the middle of the period',\n 'between ticks.'\n ].join(' ')\n },\n // ticklabelposition: not used directly, as values depend on direction (similar to side)\n // left/right options are for x axes, and top/bottom options are for y axes\n ticklabelposition: {\n valType: 'enumerated',\n values: [\n 'outside', 'inside',\n 'outside top', 'inside top',\n 'outside left', 'inside left',\n 'outside right', 'inside right',\n 'outside bottom', 'inside bottom'\n ],\n dflt: 'outside',\n editType: 'calc',\n description: [\n 'Determines where tick labels are drawn with respect to the axis',\n 'Please note that',\n 'top or bottom has no effect on x axes or when `ticklabelmode` is set to *period*.',\n 'Similarly',\n 'left or right has no effect on y axes or when `ticklabelmode` is set to *period*.',\n 'Has no effect on *multicategory* axes or when `tickson` is set to *boundaries*.',\n 'When used on axes linked by `matches` or `scaleanchor`,',\n 'no extra padding for inside labels would be added by autorange,',\n 'so that the scales could match.'\n ].join(' ')\n },\n ticklabeloverflow: {\n valType: 'enumerated',\n values: [\n 'allow',\n 'hide past div',\n 'hide past domain'\n ],\n editType: 'calc',\n description: [\n 'Determines how we handle tick labels that would overflow either the graph div or the domain of the axis.',\n 'The default value for inside tick labels is *hide past domain*.',\n 'Otherwise on *category* and *multicategory* axes the default is *allow*.',\n 'In other cases the default is *hide past div*.'\n ].join(' ')\n },\n ticklabelshift: {\n valType: 'integer',\n dflt: 0,\n editType: 'ticks',\n description: [\n 'Shifts the tick labels by the specified number of pixels in parallel to the axis.',\n 'Positive values move the labels in the positive direction of the axis.'\n ].join(' ')\n },\n ticklabelstandoff: {\n valType: 'integer',\n dflt: 0,\n editType: 'ticks',\n description: [\n 'Sets the standoff distance (in px) between the axis tick labels and their default position.',\n 'A positive `ticklabelstandoff` moves the labels farther away from the plot area',\n 'if `ticklabelposition` is *outside*, and deeper into the plot area if',\n '`ticklabelposition` is *inside*. A negative `ticklabelstandoff` works in the opposite',\n 'direction, moving outside ticks towards the plot area and inside ticks towards',\n 'the outside. If the negative value is large enough, inside ticks can even end up',\n 'outside and vice versa.'\n ].join(' ')\n },\n ticklabelindex: {\n // in the future maybe add `extras: ['all', 'minor']` to allow showing labels for all ticks\n // or for all minor ticks.\n valType: 'integer',\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Only for axes with `type` *date* or *linear*.',\n 'Instead of drawing the major tick label, draw the label for the minor tick',\n 'that is n positions away from the major tick. E.g. to always draw the label for the',\n 'minor tick before each major tick, choose `ticklabelindex` -1. This is useful for date',\n 'axes with `ticklabelmode` *period* if you want to label the period that ends with each',\n 'major tick instead of the period that begins there.'\n ].join(' ')\n },\n mirror: {\n valType: 'enumerated',\n values: [true, 'ticks', false, 'all', 'allticks'],\n dflt: false,\n editType: 'ticks+layoutstyle',\n description: [\n 'Determines if the axis lines or/and ticks are mirrored to',\n 'the opposite side of the plotting area.',\n 'If *true*, the axis lines are mirrored.',\n 'If *ticks*, the axis lines and ticks are mirrored.',\n 'If *false*, mirroring is disable.',\n 'If *all*, axis lines are mirrored on all shared-axes subplots.',\n 'If *allticks*, axis lines and ticks are mirrored',\n 'on all shared-axes subplots.'\n ].join(' ')\n },\n ticklen: makeTicklen(),\n tickwidth: makeTickwidth(),\n tickcolor: tickcolor,\n showticklabels: {\n valType: 'boolean',\n dflt: true,\n editType: 'ticks',\n description: 'Determines whether or not the tick labels are drawn.'\n },\n labelalias: {\n valType: 'any',\n dflt: false,\n editType: 'ticks',\n description: [\n 'Replacement text for specific tick or hover labels.',\n 'For example using {US: \\'USA\\', CA: \\'Canada\\'} changes US to USA',\n 'and CA to Canada. The labels we would have shown must match',\n 'the keys exactly, after adding any tickprefix or ticksuffix.',\n 'For negative numbers the minus sign symbol used (U+2212) is wider than the regular ascii dash.',\n 'That means you need to use −1 instead of -1.',\n 'labelalias can be used with any axis type, and both keys (if needed)',\n 'and values (if desired) can include html-like tags or MathJax.'\n ].join(' ')\n },\n automargin: {\n valType: 'flaglist',\n flags: ['height', 'width', 'left', 'right', 'top', 'bottom'],\n extras: [true, false],\n dflt: false,\n editType: 'ticks',\n description: [\n 'Determines whether long tick labels automatically grow the figure',\n 'margins.'\n ].join(' ')\n },\n showspikes: {\n valType: 'boolean',\n dflt: false,\n editType: 'modebar',\n description: [\n 'Determines whether or not spikes (aka droplines) are drawn for this axis.',\n 'Note: This only takes affect when hovermode = closest'\n ].join(' ')\n },\n spikecolor: {\n valType: 'color',\n dflt: null,\n editType: 'none',\n description: 'Sets the spike color. If undefined, will use the series color'\n },\n spikethickness: {\n valType: 'number',\n dflt: 3,\n editType: 'none',\n description: 'Sets the width (in px) of the zero line.'\n },\n spikedash: extendFlat({}, dash, {dflt: 'dash', editType: 'none'}),\n spikemode: {\n valType: 'flaglist',\n flags: ['toaxis', 'across', 'marker'],\n dflt: 'toaxis',\n editType: 'none',\n description: [\n 'Determines the drawing mode for the spike line',\n 'If *toaxis*, the line is drawn from the data point to the axis the ',\n 'series is plotted on.',\n\n 'If *across*, the line is drawn across the entire plot area, and',\n 'supercedes *toaxis*.',\n\n 'If *marker*, then a marker dot is drawn on the axis the series is',\n 'plotted on'\n ].join(' ')\n },\n spikesnap: {\n valType: 'enumerated',\n values: ['data', 'cursor', 'hovered data'],\n dflt: 'hovered data',\n editType: 'none',\n description: 'Determines whether spikelines are stuck to the cursor or to the closest datapoints.'\n },\n tickfont: fontAttrs({\n editType: 'ticks',\n description: 'Sets the tick font.'\n }),\n tickangle: {\n valType: 'angle',\n dflt: 'auto',\n editType: 'ticks',\n description: [\n 'Sets the angle of the tick labels with respect to the horizontal.',\n 'For example, a `tickangle` of -90 draws the tick labels',\n 'vertically.'\n ].join(' ')\n },\n autotickangles: {\n valType: 'info_array',\n freeLength: true,\n items: {\n valType: 'angle'\n },\n dflt: [0, 30, 90],\n editType: 'ticks',\n description: [\n 'When `tickangle` is set to *auto*, it will be set to the first',\n 'angle in this array that is large enough to prevent label',\n 'overlap.'\n ].join(' ')\n },\n tickprefix: {\n valType: 'string',\n dflt: '',\n editType: 'ticks',\n description: 'Sets a tick label prefix.'\n },\n showtickprefix: {\n valType: 'enumerated',\n values: ['all', 'first', 'last', 'none'],\n dflt: 'all',\n editType: 'ticks',\n description: [\n 'If *all*, all tick labels are displayed with a prefix.',\n 'If *first*, only the first tick is displayed with a prefix.',\n 'If *last*, only the last tick is displayed with a suffix.',\n 'If *none*, tick prefixes are hidden.'\n ].join(' ')\n },\n ticksuffix: {\n valType: 'string',\n dflt: '',\n editType: 'ticks',\n description: 'Sets a tick label suffix.'\n },\n showticksuffix: {\n valType: 'enumerated',\n values: ['all', 'first', 'last', 'none'],\n dflt: 'all',\n editType: 'ticks',\n description: 'Same as `showtickprefix` but for tick suffixes.'\n },\n showexponent: {\n valType: 'enumerated',\n values: ['all', 'first', 'last', 'none'],\n dflt: 'all',\n editType: 'ticks',\n description: [\n 'If *all*, all exponents are shown besides their significands.',\n 'If *first*, only the exponent of the first tick is shown.',\n 'If *last*, only the exponent of the last tick is shown.',\n 'If *none*, no exponents appear.'\n ].join(' ')\n },\n exponentformat: {\n valType: 'enumerated',\n values: ['none', 'e', 'E', 'power', 'SI', 'B'],\n dflt: 'B',\n editType: 'ticks',\n description: [\n 'Determines a formatting rule for the tick exponents.',\n 'For example, consider the number 1,000,000,000.',\n 'If *none*, it appears as 1,000,000,000.',\n 'If *e*, 1e+9.',\n 'If *E*, 1E+9.',\n 'If *power*, 1x10^9 (with 9 in a super script).',\n 'If *SI*, 1G.',\n 'If *B*, 1B.'\n ].join(' ')\n },\n minexponent: {\n valType: 'number',\n dflt: 3,\n min: 0,\n editType: 'ticks',\n description: [\n 'Hide SI prefix for 10^n if |n| is below this number.',\n 'This only has an effect when `tickformat` is *SI* or *B*.'\n ].join(' ')\n },\n separatethousands: {\n valType: 'boolean',\n dflt: false,\n editType: 'ticks',\n description: [\n 'If \"true\", even 4-digit integers are separated'\n ].join(' ')\n },\n tickformat: {\n valType: 'string',\n dflt: '',\n editType: 'ticks',\n description: descriptionWithDates('tick label')\n },\n tickformatstops: templatedArray('tickformatstop', {\n enabled: {\n valType: 'boolean',\n dflt: true,\n editType: 'ticks',\n description: [\n 'Determines whether or not this stop is used.',\n 'If `false`, this stop is ignored even within its `dtickrange`.'\n ].join(' ')\n },\n dtickrange: {\n valType: 'info_array',\n items: [\n {valType: 'any', editType: 'ticks'},\n {valType: 'any', editType: 'ticks'}\n ],\n editType: 'ticks',\n description: [\n 'range [*min*, *max*], where *min*, *max* - dtick values',\n 'which describe some zoom level, it is possible to omit *min*',\n 'or *max* value by passing *null*'\n ].join(' ')\n },\n value: {\n valType: 'string',\n dflt: '',\n editType: 'ticks',\n description: [\n 'string - dtickformat for described zoom level, the same as *tickformat*'\n ].join(' ')\n },\n editType: 'ticks'\n }),\n hoverformat: {\n valType: 'string',\n dflt: '',\n editType: 'none',\n description: descriptionWithDates('hover text')\n },\n // lines and grids\n showline: {\n valType: 'boolean',\n dflt: false,\n editType: 'ticks+layoutstyle',\n description: [\n 'Determines whether or not a line bounding this axis is drawn.'\n ].join(' ')\n },\n linecolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n editType: 'layoutstyle',\n description: 'Sets the axis line color.'\n },\n linewidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n editType: 'ticks+layoutstyle',\n description: 'Sets the width (in px) of the axis line.'\n },\n showgrid: showgrid,\n gridcolor: gridcolor,\n gridwidth: makeGridwidth(),\n griddash: griddash,\n\n zeroline: {\n valType: 'boolean',\n editType: 'ticks',\n description: [\n 'Determines whether or not a line is drawn at along the 0 value',\n 'of this axis.',\n 'If *true*, the zero line is drawn on top of the grid lines.'\n ].join(' ')\n },\n zerolinecolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n editType: 'ticks',\n description: 'Sets the line color of the zero line.'\n },\n zerolinewidth: {\n valType: 'number',\n dflt: 1,\n editType: 'ticks',\n description: 'Sets the width (in px) of the zero line.'\n },\n\n showdividers: {\n valType: 'boolean',\n dflt: true,\n editType: 'ticks',\n description: [\n 'Determines whether or not a dividers are drawn',\n 'between the category levels of this axis.',\n 'Only has an effect on *multicategory* axes.'\n ].join(' ')\n },\n dividercolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n editType: 'ticks',\n description: [\n 'Sets the color of the dividers',\n 'Only has an effect on *multicategory* axes.'\n ].join(' ')\n },\n dividerwidth: {\n valType: 'number',\n dflt: 1,\n editType: 'ticks',\n description: [\n 'Sets the width (in px) of the dividers',\n 'Only has an effect on *multicategory* axes.'\n ].join(' ')\n },\n // TODO dividerlen: that would override \"to label base\" length?\n\n // positioning attributes\n // anchor: not used directly, just put here for reference\n // values are any opposite-letter axis id\n anchor: {\n valType: 'enumerated',\n values: [\n 'free',\n constants.idRegex.x.toString(),\n constants.idRegex.y.toString()\n ],\n editType: 'plot',\n description: [\n 'If set to an opposite-letter axis id (e.g. `x2`, `y`), this axis is bound to',\n 'the corresponding opposite-letter axis.',\n 'If set to *free*, this axis\\' position is determined by `position`.'\n ].join(' ')\n },\n // side: not used directly, as values depend on direction\n // values are top, bottom for x axes, and left, right for y\n side: {\n valType: 'enumerated',\n values: ['top', 'bottom', 'left', 'right'],\n editType: 'plot',\n description: [\n 'Determines whether a x (y) axis is positioned',\n 'at the *bottom* (*left*) or *top* (*right*)',\n 'of the plotting area.'\n ].join(' ')\n },\n // overlaying: not used directly, just put here for reference\n // values are false and any other same-letter axis id that's not\n // itself overlaying anything\n overlaying: {\n valType: 'enumerated',\n values: [\n 'free',\n constants.idRegex.x.toString(),\n constants.idRegex.y.toString()\n ],\n editType: 'plot',\n description: [\n 'If set a same-letter axis id, this axis is overlaid on top of',\n 'the corresponding same-letter axis, with traces and axes visible for both',\n 'axes.',\n 'If *false*, this axis does not overlay any same-letter axes.',\n 'In this case, for axes with overlapping domains only the highest-numbered',\n 'axis will be visible.'\n ].join(' ')\n },\n\n minor: {\n tickmode: minorTickmode,\n nticks: makeNticks('minor'),\n tick0: tick0,\n dtick: dtick,\n tickvals: tickvals,\n ticks: ticks,\n ticklen: makeTicklen('minor'),\n tickwidth: makeTickwidth('minor'),\n tickcolor: tickcolor,\n\n gridcolor: gridcolor,\n gridwidth: makeGridwidth('minor'),\n griddash: griddash,\n showgrid: showgrid,\n\n editType: 'ticks'\n },\n\n layer: {\n valType: 'enumerated',\n values: ['above traces', 'below traces'],\n dflt: 'above traces',\n editType: 'plot',\n description: [\n 'Sets the layer on which this axis is displayed.',\n 'If *above traces*, this axis is displayed above all the subplot\\'s traces',\n 'If *below traces*, this axis is displayed below all the subplot\\'s traces,',\n 'but above the grid lines.',\n 'Useful when used together with scatter-like traces with `cliponaxis`',\n 'set to *false* to show markers and/or text nodes above this axis.'\n ].join(' ')\n },\n domain: {\n valType: 'info_array',\n items: [\n {valType: 'number', min: 0, max: 1, editType: 'plot'},\n {valType: 'number', min: 0, max: 1, editType: 'plot'}\n ],\n dflt: [0, 1],\n editType: 'plot',\n description: [\n 'Sets the domain of this axis (in plot fraction).'\n ].join(' ')\n },\n position: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0,\n editType: 'plot',\n description: [\n 'Sets the position of this axis in the plotting space',\n '(in normalized coordinates).',\n 'Only has an effect if `anchor` is set to *free*.'\n ].join(' ')\n },\n autoshift: {\n valType: 'boolean',\n dflt: false,\n editType: 'plot',\n description: [\n 'Automatically reposition the axis to avoid',\n 'overlap with other axes with the same `overlaying` value.',\n 'This repositioning will account for any `shift` amount applied to other',\n 'axes on the same side with `autoshift` is set to true.',\n 'Only has an effect if `anchor` is set to *free*.',\n ].join(' ')\n },\n shift: {\n valType: 'number',\n editType: 'plot',\n description: [\n 'Moves the axis a given number of pixels from where it would have been otherwise.',\n 'Accepts both positive and negative values, which will shift the axis either right',\n 'or left, respectively.',\n 'If `autoshift` is set to true, then this defaults to a padding of -3 if `side` is set to *left*.',\n 'and defaults to +3 if `side` is set to *right*. Defaults to 0 if `autoshift` is set to false.',\n 'Only has an effect if `anchor` is set to *free*.'\n ].join(' ')\n },\n categoryorder: {\n valType: 'enumerated',\n values: [\n 'trace', 'category ascending', 'category descending', 'array',\n 'total ascending', 'total descending',\n 'min ascending', 'min descending',\n 'max ascending', 'max descending',\n 'sum ascending', 'sum descending',\n 'mean ascending', 'mean descending',\n 'geometric mean ascending', 'geometric mean descending',\n 'median ascending', 'median descending'\n ],\n dflt: 'trace',\n editType: 'calc',\n description: [\n 'Specifies the ordering logic for the case of categorical variables.',\n 'By default, plotly uses *trace*, which specifies the order that is present in the data supplied.',\n 'Set `categoryorder` to *category ascending* or *category descending* if order should be determined by',\n 'the alphanumerical order of the category names.',\n 'Set `categoryorder` to *array* to derive the ordering from the attribute `categoryarray`. If a category',\n 'is not found in the `categoryarray` array, the sorting behavior for that attribute will be identical to',\n 'the *trace* mode. The unspecified categories will follow the categories in `categoryarray`.',\n 'Set `categoryorder` to *total ascending* or *total descending* if order should be determined by the',\n 'numerical order of the values.',\n 'Similarly, the order can be determined by the min, max, sum, mean, geometric mean or median of all the values.'\n ].join(' ')\n },\n categoryarray: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the order in which categories on this axis appear.',\n 'Only has an effect if `categoryorder` is set to *array*.',\n 'Used with `categoryorder`.'\n ].join(' ')\n },\n uirevision: {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in axis `range`,',\n '`autorange`, and `title` if in `editable: true` configuration.',\n 'Defaults to `layout.uirevision`.'\n ].join(' ')\n },\n editType: 'calc',\n\n _deprecated: {\n autotick: {\n valType: 'boolean',\n editType: 'ticks',\n description: [\n 'Obsolete.',\n 'Set `tickmode` to *auto* for old `autotick` *true* behavior.',\n 'Set `tickmode` to *linear* for `autotick` *false*.'\n ].join(' ')\n },\n title: {\n valType: 'string',\n editType: 'ticks',\n description: [\n 'Value of `title` is no longer a simple *string* but a set of sub-attributes.',\n 'To set the axis\\' title, please use `title.text` now.'\n ].join(' ')\n },\n titlefont: fontAttrs({\n editType: 'ticks',\n description: [\n 'Former `titlefont` is now the sub-attribute `font` of `title`.',\n 'To customize title font properties, please use `title.font` now.'\n ].join(' ')\n })\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../../components/color');\nvar isUnifiedHover = require('../../components/fx/helpers').isUnifiedHover;\nvar handleHoverModeDefaults = require('../../components/fx/hovermode_defaults');\nvar Template = require('../../plot_api/plot_template');\nvar basePlotLayoutAttributes = require('../layout_attributes');\n\nvar layoutAttributes = require('./layout_attributes');\nvar handleTypeDefaults = require('./type_defaults');\nvar handleAxisDefaults = require('./axis_defaults');\nvar constraints = require('./constraints');\nvar handlePositionDefaults = require('./position_defaults');\n\nvar axisIds = require('./axis_ids');\nvar id2name = axisIds.id2name;\nvar name2id = axisIds.name2id;\n\nvar AX_ID_PATTERN = require('./constants').AX_ID_PATTERN;\n\nvar Registry = require('../../registry');\nvar traceIs = Registry.traceIs;\nvar getComponentMethod = Registry.getComponentMethod;\n\nfunction appendList(cont, k, item) {\n if(Array.isArray(cont[k])) cont[k].push(item);\n else cont[k] = [item];\n}\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut, fullData) {\n var autotypenumbersDflt = layoutOut.autotypenumbers;\n\n var ax2traces = {};\n var xaMayHide = {};\n var yaMayHide = {};\n var xaMustDisplay = {};\n var yaMustDisplay = {};\n var yaMustNotReverse = {};\n var yaMayReverse = {};\n var axHasImage = {};\n var outerTicks = {};\n var noGrids = {};\n var i, j;\n\n // look for axes in the data\n for(i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n if(!traceIs(trace, 'cartesian') && !traceIs(trace, 'gl2d')) continue;\n\n var xaName;\n if(trace.xaxis) {\n xaName = id2name(trace.xaxis);\n appendList(ax2traces, xaName, trace);\n } else if(trace.xaxes) {\n for(j = 0; j < trace.xaxes.length; j++) {\n appendList(ax2traces, id2name(trace.xaxes[j]), trace);\n }\n }\n\n var yaName;\n if(trace.yaxis) {\n yaName = id2name(trace.yaxis);\n appendList(ax2traces, yaName, trace);\n } else if(trace.yaxes) {\n for(j = 0; j < trace.yaxes.length; j++) {\n appendList(ax2traces, id2name(trace.yaxes[j]), trace);\n }\n }\n\n // logic for funnels\n if(trace.type === 'funnel') {\n if(trace.orientation === 'h') {\n if(xaName) xaMayHide[xaName] = true;\n if(yaName) yaMayReverse[yaName] = true;\n } else {\n if(yaName) yaMayHide[yaName] = true;\n }\n } else if(trace.type === 'image') {\n if(yaName) axHasImage[yaName] = true;\n if(xaName) axHasImage[xaName] = true;\n } else {\n if(yaName) {\n yaMustDisplay[yaName] = true;\n yaMustNotReverse[yaName] = true;\n }\n\n if(!traceIs(trace, 'carpet') || (trace.type === 'carpet' && !trace._cheater)) {\n if(xaName) xaMustDisplay[xaName] = true;\n }\n }\n\n // Two things trigger axis visibility:\n // 1. is not carpet\n // 2. carpet that's not cheater\n\n // The above check for definitely-not-cheater is not adequate. This\n // second list tracks which axes *could* be a cheater so that the\n // full condition triggering hiding is:\n // *could* be a cheater and *is not definitely visible*\n if(trace.type === 'carpet' && trace._cheater) {\n if(xaName) xaMayHide[xaName] = true;\n }\n\n // check for default formatting tweaks\n if(traceIs(trace, '2dMap')) {\n outerTicks[xaName] = true;\n outerTicks[yaName] = true;\n }\n\n if(traceIs(trace, 'oriented')) {\n var positionAxis = trace.orientation === 'h' ? yaName : xaName;\n noGrids[positionAxis] = true;\n }\n }\n\n var subplots = layoutOut._subplots;\n var xIds = subplots.xaxis;\n var yIds = subplots.yaxis;\n var xNames = Lib.simpleMap(xIds, id2name);\n var yNames = Lib.simpleMap(yIds, id2name);\n var axNames = xNames.concat(yNames);\n\n // plot_bgcolor only makes sense if there's a (2D) plot!\n // TODO: bgcolor for each subplot, to inherit from the main one\n var plotBgColor = Color.background;\n if(xIds.length && yIds.length) {\n plotBgColor = Lib.coerce(layoutIn, layoutOut, basePlotLayoutAttributes, 'plot_bgcolor');\n }\n\n var bgColor = Color.combine(plotBgColor, layoutOut.paper_bgcolor);\n\n // name of single axis (e.g. 'xaxis', 'yaxis2')\n var axName;\n // id of single axis (e.g. 'y', 'x5')\n var axId;\n // 'x' or 'y'\n var axLetter;\n // input layout axis container\n var axLayoutIn;\n // full layout axis container\n var axLayoutOut;\n\n function newAxLayoutOut() {\n var traces = ax2traces[axName] || [];\n axLayoutOut._traceIndices = traces.map(function(t) { return t._expandedIndex; });\n axLayoutOut._annIndices = [];\n axLayoutOut._shapeIndices = [];\n axLayoutOut._selectionIndices = [];\n axLayoutOut._imgIndices = [];\n axLayoutOut._subplotsWith = [];\n axLayoutOut._counterAxes = [];\n axLayoutOut._name = axLayoutOut._attr = axName;\n axLayoutOut._id = axId;\n }\n\n function coerce(attr, dflt) {\n return Lib.coerce(axLayoutIn, axLayoutOut, layoutAttributes, attr, dflt);\n }\n\n function coerce2(attr, dflt) {\n return Lib.coerce2(axLayoutIn, axLayoutOut, layoutAttributes, attr, dflt);\n }\n\n function getCounterAxes(axLetter) {\n return (axLetter === 'x') ? yIds : xIds;\n }\n\n function getOverlayableAxes(axLetter, axName) {\n var list = (axLetter === 'x') ? xNames : yNames;\n var out = [];\n\n for(var j = 0; j < list.length; j++) {\n var axName2 = list[j];\n\n if(axName2 !== axName && !(layoutIn[axName2] || {}).overlaying) {\n out.push(name2id(axName2));\n }\n }\n\n return out;\n }\n\n // list of available counter axis names\n var counterAxes = {x: getCounterAxes('x'), y: getCounterAxes('y')};\n // list of all x AND y axis ids\n var allAxisIds = counterAxes.x.concat(counterAxes.y);\n // lookup and list of axis ids that axes in axNames have a reference to,\n // even though they are missing from allAxisIds\n var missingMatchedAxisIdsLookup = {};\n var missingMatchedAxisIds = [];\n\n // fill in 'missing' axis lookup when an axis is set to match an axis\n // not part of the allAxisIds list, save axis type so that we can propagate\n // it to the missing axes\n function addMissingMatchedAxis() {\n var matchesIn = axLayoutIn.matches;\n if(AX_ID_PATTERN.test(matchesIn) && allAxisIds.indexOf(matchesIn) === -1) {\n missingMatchedAxisIdsLookup[matchesIn] = axLayoutIn.type;\n missingMatchedAxisIds = Object.keys(missingMatchedAxisIdsLookup);\n }\n }\n\n var hovermode = handleHoverModeDefaults(layoutIn, layoutOut);\n var unifiedHover = isUnifiedHover(hovermode);\n\n // first pass creates the containers, determines types, and handles most of the settings\n for(i = 0; i < axNames.length; i++) {\n axName = axNames[i];\n axId = name2id(axName);\n axLetter = axName.charAt(0);\n\n if(!Lib.isPlainObject(layoutIn[axName])) {\n layoutIn[axName] = {};\n }\n\n axLayoutIn = layoutIn[axName];\n axLayoutOut = Template.newContainer(layoutOut, axName, axLetter + 'axis');\n newAxLayoutOut();\n\n var visibleDflt =\n (axLetter === 'x' && !xaMustDisplay[axName] && xaMayHide[axName]) ||\n (axLetter === 'y' && !yaMustDisplay[axName] && yaMayHide[axName]);\n\n var reverseDflt =\n (axLetter === 'y' &&\n (\n (!yaMustNotReverse[axName] && yaMayReverse[axName]) ||\n axHasImage[axName]\n ));\n\n var defaultOptions = {\n hasMinor: true,\n letter: axLetter,\n font: layoutOut.font,\n outerTicks: outerTicks[axName],\n showGrid: !noGrids[axName],\n data: ax2traces[axName] || [],\n bgColor: bgColor,\n calendar: layoutOut.calendar,\n automargin: true,\n visibleDflt: visibleDflt,\n reverseDflt: reverseDflt,\n autotypenumbersDflt: autotypenumbersDflt,\n splomStash: ((layoutOut._splomAxes || {})[axLetter] || {})[axId],\n noAutotickangles: axLetter === 'y'\n };\n\n coerce('uirevision', layoutOut.uirevision);\n\n handleTypeDefaults(axLayoutIn, axLayoutOut, coerce, defaultOptions);\n handleAxisDefaults(axLayoutIn, axLayoutOut, coerce, defaultOptions, layoutOut);\n\n var unifiedSpike = unifiedHover && axLetter === hovermode.charAt(0);\n var spikecolor = coerce2('spikecolor', unifiedHover ? axLayoutOut.color : undefined);\n var spikethickness = coerce2('spikethickness', unifiedHover ? 1.5 : undefined);\n var spikedash = coerce2('spikedash', unifiedHover ? 'dot' : undefined);\n var spikemode = coerce2('spikemode', unifiedHover ? 'across' : undefined);\n var spikesnap = coerce2('spikesnap');\n var showSpikes = coerce('showspikes', !!unifiedSpike || !!spikecolor || !!spikethickness || !!spikedash || !!spikemode || !!spikesnap);\n\n if(!showSpikes) {\n delete axLayoutOut.spikecolor;\n delete axLayoutOut.spikethickness;\n delete axLayoutOut.spikedash;\n delete axLayoutOut.spikemode;\n delete axLayoutOut.spikesnap;\n }\n\n // If it exists, the the domain of the axis for the anchor of the overlaying axis\n var overlayingAxis = id2name(axLayoutIn.overlaying);\n var overlayingAnchorDomain = [0, 1];\n\n if(layoutOut[overlayingAxis] !== undefined) {\n var overlayingAnchor = id2name(layoutOut[overlayingAxis].anchor);\n if(layoutOut[overlayingAnchor] !== undefined) {\n overlayingAnchorDomain = layoutOut[overlayingAnchor].domain;\n }\n }\n\n handlePositionDefaults(axLayoutIn, axLayoutOut, coerce, {\n letter: axLetter,\n counterAxes: counterAxes[axLetter],\n overlayableAxes: getOverlayableAxes(axLetter, axName),\n grid: layoutOut.grid,\n overlayingDomain: overlayingAnchorDomain\n\n });\n\n coerce('title.standoff');\n\n addMissingMatchedAxis();\n\n axLayoutOut._input = axLayoutIn;\n }\n\n // coerce the 'missing' axes\n i = 0;\n while(i < missingMatchedAxisIds.length) {\n axId = missingMatchedAxisIds[i++];\n axName = id2name(axId);\n axLetter = axName.charAt(0);\n\n if(!Lib.isPlainObject(layoutIn[axName])) {\n layoutIn[axName] = {};\n }\n\n axLayoutIn = layoutIn[axName];\n axLayoutOut = Template.newContainer(layoutOut, axName, axLetter + 'axis');\n newAxLayoutOut();\n\n var defaultOptions2 = {\n letter: axLetter,\n font: layoutOut.font,\n outerTicks: outerTicks[axName],\n showGrid: !noGrids[axName],\n data: [],\n bgColor: bgColor,\n calendar: layoutOut.calendar,\n automargin: true,\n visibleDflt: false,\n reverseDflt: false,\n autotypenumbersDflt: autotypenumbersDflt,\n splomStash: ((layoutOut._splomAxes || {})[axLetter] || {})[axId]\n };\n\n coerce('uirevision', layoutOut.uirevision);\n\n axLayoutOut.type = missingMatchedAxisIdsLookup[axId] || 'linear';\n\n handleAxisDefaults(axLayoutIn, axLayoutOut, coerce, defaultOptions2, layoutOut);\n\n handlePositionDefaults(axLayoutIn, axLayoutOut, coerce, {\n letter: axLetter,\n counterAxes: counterAxes[axLetter],\n overlayableAxes: getOverlayableAxes(axLetter, axName),\n grid: layoutOut.grid\n });\n\n coerce('fixedrange');\n\n addMissingMatchedAxis();\n\n axLayoutOut._input = axLayoutIn;\n }\n\n // quick second pass for range slider and selector defaults\n var rangeSliderDefaults = getComponentMethod('rangeslider', 'handleDefaults');\n var rangeSelectorDefaults = getComponentMethod('rangeselector', 'handleDefaults');\n\n for(i = 0; i < xNames.length; i++) {\n axName = xNames[i];\n axLayoutIn = layoutIn[axName];\n axLayoutOut = layoutOut[axName];\n\n rangeSliderDefaults(layoutIn, layoutOut, axName);\n\n if(axLayoutOut.type === 'date') {\n rangeSelectorDefaults(\n axLayoutIn,\n axLayoutOut,\n layoutOut,\n yNames,\n axLayoutOut.calendar\n );\n }\n\n coerce('fixedrange');\n }\n\n for(i = 0; i < yNames.length; i++) {\n axName = yNames[i];\n axLayoutIn = layoutIn[axName];\n axLayoutOut = layoutOut[axName];\n\n var anchoredAxis = layoutOut[id2name(axLayoutOut.anchor)];\n\n var fixedRangeDflt = getComponentMethod('rangeslider', 'isVisible')(anchoredAxis);\n\n coerce('fixedrange', fixedRangeDflt);\n }\n\n // Finally, handle scale constraints and matching axes.\n //\n // We need to do this after all axes have coerced both `type`\n // (so we link only axes of the same type) and\n // `fixedrange` (so we can avoid linking from OR TO a fixed axis).\n constraints.handleDefaults(layoutIn, layoutOut, {\n axIds: allAxisIds.concat(missingMatchedAxisIds).sort(axisIds.idSort),\n axHasImage: axHasImage\n });\n};\n","'use strict';\n\nvar colorMix = require('tinycolor2').mix;\nvar colorAttrs = require('../../components/color/attributes');\nvar Lib = require('../../lib');\n\n/**\n * @param {object} opts :\n * - dfltColor {string} : default axis color\n * - bgColor {string} : combined subplot bg color\n * - blend {number, optional} : blend percentage (to compute dflt grid color)\n * - showLine {boolean} : show line by default\n * - showGrid {boolean} : show grid by default\n * - noZeroLine {boolean} : don't coerce zeroline* attributes\n * - attributes {object} : attribute object associated with input containers\n */\nmodule.exports = function handleLineGridDefaults(containerIn, containerOut, coerce, opts) {\n opts = opts || {};\n\n var dfltColor = opts.dfltColor;\n\n function coerce2(attr, dflt) {\n return Lib.coerce2(containerIn, containerOut, opts.attributes, attr, dflt);\n }\n\n var lineColor = coerce2('linecolor', dfltColor);\n var lineWidth = coerce2('linewidth');\n var showLine = coerce('showline', opts.showLine || !!lineColor || !!lineWidth);\n\n if(!showLine) {\n delete containerOut.linecolor;\n delete containerOut.linewidth;\n }\n\n var gridColorDflt = colorMix(dfltColor, opts.bgColor, opts.blend || colorAttrs.lightFraction).toRgbString();\n var gridColor = coerce2('gridcolor', gridColorDflt);\n var gridWidth = coerce2('gridwidth');\n var gridDash = coerce2('griddash');\n var showGridLines = coerce('showgrid', opts.showGrid ||\n !!gridColor ||\n !!gridWidth ||\n !!gridDash\n );\n\n if(!showGridLines) {\n delete containerOut.gridcolor;\n delete containerOut.gridwidth;\n delete containerOut.griddash;\n }\n\n if(opts.hasMinor) {\n var minorGridColorDflt = colorMix(containerOut.gridcolor, opts.bgColor, 67).toRgbString();\n var minorGridColor = coerce2('minor.gridcolor', minorGridColorDflt);\n var minorGridWidth = coerce2('minor.gridwidth', containerOut.gridwidth || 1);\n var minorGridDash = coerce2('minor.griddash', containerOut.griddash || 'solid');\n var minorShowGridLines = coerce('minor.showgrid',\n !!minorGridColor ||\n !!minorGridWidth ||\n !!minorGridDash\n );\n\n if(!minorShowGridLines) {\n delete containerOut.minor.gridcolor;\n delete containerOut.minor.gridwidth;\n delete containerOut.minor.griddash;\n }\n }\n\n if(!opts.noZeroLine) {\n var zeroLineColor = coerce2('zerolinecolor', dfltColor);\n var zeroLineWidth = coerce2('zerolinewidth');\n var showZeroLine = coerce('zeroline', opts.showGrid || !!zeroLineColor || !!zeroLineWidth);\n\n if(!showZeroLine) {\n delete containerOut.zerolinecolor;\n delete containerOut.zerolinewidth;\n }\n }\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\n\n\nmodule.exports = function handlePositionDefaults(containerIn, containerOut, coerce, options) {\n var counterAxes = options.counterAxes || [];\n var overlayableAxes = options.overlayableAxes || [];\n var letter = options.letter;\n var grid = options.grid;\n var overlayingDomain = options.overlayingDomain;\n var dfltAnchor, dfltDomain, dfltSide, dfltPosition, dfltShift, dfltAutomargin;\n\n if(grid) {\n dfltDomain = grid._domains[letter][grid._axisMap[containerOut._id]];\n dfltAnchor = grid._anchors[containerOut._id];\n if(dfltDomain) {\n dfltSide = grid[letter + 'side'].split(' ')[0];\n dfltPosition = grid.domain[letter][dfltSide === 'right' || dfltSide === 'top' ? 1 : 0];\n }\n }\n\n // Even if there's a grid, this axis may not be in it - fall back on non-grid defaults\n dfltDomain = dfltDomain || [0, 1];\n dfltAnchor = dfltAnchor || (isNumeric(containerIn.position) ? 'free' : (counterAxes[0] || 'free'));\n dfltSide = dfltSide || (letter === 'x' ? 'bottom' : 'left');\n dfltPosition = dfltPosition || 0;\n dfltShift = 0;\n dfltAutomargin = false;\n\n var anchor = Lib.coerce(containerIn, containerOut, {\n anchor: {\n valType: 'enumerated',\n values: ['free'].concat(counterAxes),\n dflt: dfltAnchor\n }\n }, 'anchor');\n\n var side = Lib.coerce(containerIn, containerOut, {\n side: {\n valType: 'enumerated',\n values: letter === 'x' ? ['bottom', 'top'] : ['left', 'right'],\n dflt: dfltSide\n }\n }, 'side');\n\n if(anchor === 'free') {\n if(letter === 'y') {\n var autoshift = coerce('autoshift');\n if(autoshift) {\n dfltPosition = side === 'left' ? overlayingDomain[0] : overlayingDomain[1];\n dfltAutomargin = containerOut.automargin ? containerOut.automargin : true;\n dfltShift = side === 'left' ? -3 : 3;\n }\n coerce('shift', dfltShift);\n }\n coerce('position', dfltPosition);\n }\n coerce('automargin', dfltAutomargin);\n\n var overlaying = false;\n if(overlayableAxes.length) {\n overlaying = Lib.coerce(containerIn, containerOut, {\n overlaying: {\n valType: 'enumerated',\n values: [false].concat(overlayableAxes),\n dflt: false\n }\n }, 'overlaying');\n }\n\n if(!overlaying) {\n // TODO: right now I'm copying this domain over to overlaying axes\n // in ax.setscale()... but this means we still need (imperfect) logic\n // in the axes popover to hide domain for the overlaying axis.\n // perhaps I should make a private version _domain that all axes get???\n var domain = coerce('domain', dfltDomain);\n\n // according to https://www.npmjs.com/package/canvas-size\n // the minimum value of max canvas width across browsers and devices is 4096\n // which applied in the calculation below:\n if(domain[0] > domain[1] - 1 / 4096) containerOut.domain = dfltDomain;\n Lib.noneOrAll(containerIn.domain, containerOut.domain, dfltDomain);\n\n // tickmode sync needs an overlaying axis, otherwise\n // we should default it to 'auto'\n if(containerOut.tickmode === 'sync') {\n containerOut.tickmode = 'auto';\n }\n }\n\n coerce('layer');\n\n return containerOut;\n};\n","'use strict';\n\nvar getShowAttrDflt = require('./show_dflt');\n\nmodule.exports = function handlePrefixSuffixDefaults(containerIn, containerOut, coerce, axType, options) {\n if(!options) options = {};\n var tickSuffixDflt = options.tickSuffixDflt;\n\n var showAttrDflt = getShowAttrDflt(containerIn);\n\n var tickPrefix = coerce('tickprefix');\n if(tickPrefix) coerce('showtickprefix', showAttrDflt);\n\n var tickSuffix = coerce('ticksuffix', tickSuffixDflt);\n if(tickSuffix) coerce('showticksuffix', showAttrDflt);\n};\n","'use strict';\n\nvar handleAutorangeOptionsDefaults = require('./autorange_options_defaults');\n\nmodule.exports = function handleRangeDefaults(containerIn, containerOut, coerce, options) {\n var axTemplate = containerOut._template || {};\n var axType = containerOut.type || axTemplate.type || '-';\n\n coerce('minallowed');\n coerce('maxallowed');\n\n var range = coerce('range');\n if(!range) {\n var insiderange;\n if(!options.noInsiderange && axType !== 'log') {\n insiderange = coerce('insiderange');\n\n // We may support partial insideranges in future\n // For now it is out of scope\n if(insiderange && (\n insiderange[0] === null ||\n insiderange[1] === null\n )) {\n containerOut.insiderange = false;\n insiderange = undefined;\n }\n\n if(insiderange) range = coerce('range', insiderange);\n }\n }\n\n var autorangeDflt = containerOut.getAutorangeDflt(range, options);\n var autorange = coerce('autorange', autorangeDflt);\n\n var shouldAutorange;\n\n // validate range and set autorange true for invalid partial ranges\n if(range && (\n (range[0] === null && range[1] === null) ||\n ((range[0] === null || range[1] === null) && (autorange === 'reversed' || autorange === true)) ||\n (range[0] !== null && (autorange === 'min' || autorange === 'max reversed')) ||\n (range[1] !== null && (autorange === 'max' || autorange === 'min reversed'))\n )) {\n range = undefined;\n delete containerOut.range;\n containerOut.autorange = true;\n shouldAutorange = true;\n }\n\n if(!shouldAutorange) {\n autorangeDflt = containerOut.getAutorangeDflt(range, options);\n autorange = coerce('autorange', autorangeDflt);\n }\n\n if(autorange) {\n handleAutorangeOptionsDefaults(coerce, autorange, range);\n if(axType === 'linear' || axType === '-') coerce('rangemode');\n }\n\n containerOut.cleanRange();\n};\n","'use strict';\n\nvar FROM_BL = require('../../constants/alignment').FROM_BL;\n\nmodule.exports = function scaleZoom(ax, factor, centerFraction) {\n if(centerFraction === undefined) {\n centerFraction = FROM_BL[ax.constraintoward || 'center'];\n }\n\n var rangeLinear = [ax.r2l(ax.range[0]), ax.r2l(ax.range[1])];\n var center = rangeLinear[0] + (rangeLinear[1] - rangeLinear[0]) * centerFraction;\n\n ax.range = ax._input.range = [\n ax.l2r(center + (rangeLinear[0] - center) * factor),\n ax.l2r(center + (rangeLinear[1] - center) * factor)\n ];\n ax.setScale();\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar utcFormat = require('d3-time-format').utcFormat;\nvar Lib = require('../../lib');\nvar numberFormat = Lib.numberFormat;\nvar isNumeric = require('fast-isnumeric');\n\nvar cleanNumber = Lib.cleanNumber;\nvar ms2DateTime = Lib.ms2DateTime;\nvar dateTime2ms = Lib.dateTime2ms;\nvar ensureNumber = Lib.ensureNumber;\nvar isArrayOrTypedArray = Lib.isArrayOrTypedArray;\n\nvar numConstants = require('../../constants/numerical');\nvar FP_SAFE = numConstants.FP_SAFE;\nvar BADNUM = numConstants.BADNUM;\nvar LOG_CLIP = numConstants.LOG_CLIP;\nvar ONEWEEK = numConstants.ONEWEEK;\nvar ONEDAY = numConstants.ONEDAY;\nvar ONEHOUR = numConstants.ONEHOUR;\nvar ONEMIN = numConstants.ONEMIN;\nvar ONESEC = numConstants.ONESEC;\n\nvar axisIds = require('./axis_ids');\nvar constants = require('./constants');\nvar HOUR_PATTERN = constants.HOUR_PATTERN;\nvar WEEKDAY_PATTERN = constants.WEEKDAY_PATTERN;\n\nfunction fromLog(v) {\n return Math.pow(10, v);\n}\n\nfunction isValidCategory(v) {\n return v !== null && v !== undefined;\n}\n\n/**\n * Define the conversion functions for an axis data is used in 5 ways:\n *\n * d: data, in whatever form it's provided\n * c: calcdata: turned into numbers, but not linearized\n * l: linearized - same as c except for log axes (and other nonlinear\n * mappings later?) this is used when we need to know if it's\n * *possible* to show some data on this axis, without caring about\n * the current range\n * p: pixel value - mapped to the screen with current size and zoom\n * r: ranges, tick0, and annotation positions match one of the above\n * but are handled differently for different types:\n * - linear and date: data format (d)\n * - category: calcdata format (c), and will stay that way because\n * the data format has no continuous mapping\n * - log: linearized (l) format\n * TODO: in v3.0 we plan to change it to data format. At that point\n * shapes will work the same way as ranges, tick0, and annotations\n * so they can use this conversion too.\n *\n * Creates/updates these conversion functions, and a few more utilities\n * like cleanRange, and makeCalcdata\n *\n * also clears the autotick constraints ._minDtick, ._forceTick0\n */\nmodule.exports = function setConvert(ax, fullLayout) {\n fullLayout = fullLayout || {};\n\n var axId = (ax._id || 'x');\n var axLetter = axId.charAt(0);\n\n function toLog(v, clip) {\n if(v > 0) return Math.log(v) / Math.LN10;\n\n else if(v <= 0 && clip && ax.range && ax.range.length === 2) {\n // clip NaN (ie past negative infinity) to LOG_CLIP axis\n // length past the negative edge\n var r0 = ax.range[0];\n var r1 = ax.range[1];\n return 0.5 * (r0 + r1 - 2 * LOG_CLIP * Math.abs(r0 - r1));\n } else return BADNUM;\n }\n\n /*\n * wrapped dateTime2ms that:\n * - accepts ms numbers for backward compatibility\n * - inserts a dummy arg so calendar is the 3rd arg (see notes below).\n * - defaults to ax.calendar\n */\n function dt2ms(v, _, calendar, opts) {\n if((opts || {}).msUTC && isNumeric(v)) {\n // For now it is only used\n // to fix bar length in milliseconds & gl3d ticks\n // It could be applied in other places in v3\n return +v;\n }\n\n // NOTE: Changed this behavior: previously we took any numeric value\n // to be a ms, even if it was a string that could be a bare year.\n // Now we convert it as a date if at all possible, and only try\n // as (local) ms if that fails.\n var ms = dateTime2ms(v, calendar || ax.calendar);\n if(ms === BADNUM) {\n if(isNumeric(v)) {\n v = +v;\n // keep track of tenths of ms, that `new Date` will drop\n // same logic as in Lib.ms2DateTime\n var msecTenths = Math.floor(Lib.mod(v + 0.05, 1) * 10);\n var msRounded = Math.round(v - msecTenths / 10);\n ms = dateTime2ms(new Date(msRounded)) + msecTenths / 10;\n } else return BADNUM;\n }\n return ms;\n }\n\n // wrapped ms2DateTime to insert default ax.calendar\n function ms2dt(v, r, calendar) {\n return ms2DateTime(v, r, calendar || ax.calendar);\n }\n\n function getCategoryName(v) {\n return ax._categories[Math.round(v)];\n }\n\n /*\n * setCategoryIndex: return the index of category v,\n * inserting it in the list if it's not already there\n *\n * this will enter the categories in the order it\n * encounters them, ie all the categories from the\n * first data set, then all the ones from the second\n * that aren't in the first etc.\n *\n * it is assumed that this function is being invoked in the\n * already sorted category order; otherwise there would be\n * a disconnect between the array and the index returned\n */\n function setCategoryIndex(v) {\n if(isValidCategory(v)) {\n if(ax._categoriesMap === undefined) {\n ax._categoriesMap = {};\n }\n\n if(ax._categoriesMap[v] !== undefined) {\n return ax._categoriesMap[v];\n } else {\n ax._categories.push(typeof v === 'number' ? String(v) : v);\n\n var curLength = ax._categories.length - 1;\n ax._categoriesMap[v] = curLength;\n\n return curLength;\n }\n }\n return BADNUM;\n }\n\n function setMultiCategoryIndex(arrayIn, len) {\n var arrayOut = new Array(len);\n\n for(var i = 0; i < len; i++) {\n var v0 = (arrayIn[0] || [])[i];\n var v1 = (arrayIn[1] || [])[i];\n arrayOut[i] = getCategoryIndex([v0, v1]);\n }\n\n return arrayOut;\n }\n\n function getCategoryIndex(v) {\n if(ax._categoriesMap) {\n return ax._categoriesMap[v];\n }\n }\n\n function getCategoryPosition(v) {\n // d2l/d2c variant that that won't add categories but will also\n // allow numbers to be mapped to the linearized axis positions\n var index = getCategoryIndex(v);\n if(index !== undefined) return index;\n if(isNumeric(v)) return +v;\n }\n\n function getRangePosition(v) {\n return isNumeric(v) ? +v : getCategoryIndex(v);\n }\n\n // include 2 fractional digits on pixel, for PDF zooming etc\n function _l2p(v, m, b) { return d3.round(b + m * v, 2); }\n\n function _p2l(px, m, b) { return (px - b) / m; }\n\n var l2p = function l2p(v) {\n if(!isNumeric(v)) return BADNUM;\n return _l2p(v, ax._m, ax._b);\n };\n\n var p2l = function(px) {\n return _p2l(px, ax._m, ax._b);\n };\n\n if(ax.rangebreaks) {\n var isY = axLetter === 'y';\n\n l2p = function(v) {\n if(!isNumeric(v)) return BADNUM;\n var len = ax._rangebreaks.length;\n if(!len) return _l2p(v, ax._m, ax._b);\n\n var flip = isY;\n if(ax.range[0] > ax.range[1]) flip = !flip;\n var signAx = flip ? -1 : 1;\n var pos = signAx * v;\n\n var q = 0;\n for(var i = 0; i < len; i++) {\n var min = signAx * ax._rangebreaks[i].min;\n var max = signAx * ax._rangebreaks[i].max;\n\n if(pos < min) break;\n if(pos > max) q = i + 1;\n else {\n // when falls into break, pick 'closest' offset\n q = pos < (min + max) / 2 ? i : i + 1;\n break;\n }\n }\n var b2 = ax._B[q] || 0;\n if(!isFinite(b2)) return 0; // avoid NaN translate e.g. in positionLabels if one keep zooming exactly into a break\n return _l2p(v, ax._m2, b2);\n };\n\n p2l = function(px) {\n var len = ax._rangebreaks.length;\n if(!len) return _p2l(px, ax._m, ax._b);\n\n var q = 0;\n for(var i = 0; i < len; i++) {\n if(px < ax._rangebreaks[i].pmin) break;\n if(px > ax._rangebreaks[i].pmax) q = i + 1;\n }\n return _p2l(px, ax._m2, ax._B[q]);\n };\n }\n\n // conversions among c/l/p are fairly simple - do them together for all axis types\n ax.c2l = (ax.type === 'log') ? toLog : ensureNumber;\n ax.l2c = (ax.type === 'log') ? fromLog : ensureNumber;\n\n ax.l2p = l2p;\n ax.p2l = p2l;\n\n ax.c2p = (ax.type === 'log') ? function(v, clip) { return l2p(toLog(v, clip)); } : l2p;\n ax.p2c = (ax.type === 'log') ? function(px) { return fromLog(p2l(px)); } : p2l;\n\n /*\n * now type-specific conversions for **ALL** other combinations\n * they're all written out, instead of being combinations of each other, for\n * both clarity and speed.\n */\n if(['linear', '-'].indexOf(ax.type) !== -1) {\n // all are data vals, but d and r need cleaning\n ax.d2r = ax.r2d = ax.d2c = ax.r2c = ax.d2l = ax.r2l = cleanNumber;\n ax.c2d = ax.c2r = ax.l2d = ax.l2r = ensureNumber;\n\n ax.d2p = ax.r2p = function(v) { return ax.l2p(cleanNumber(v)); };\n ax.p2d = ax.p2r = p2l;\n\n ax.cleanPos = ensureNumber;\n } else if(ax.type === 'log') {\n // d and c are data vals, r and l are logged (but d and r need cleaning)\n ax.d2r = ax.d2l = function(v, clip) { return toLog(cleanNumber(v), clip); };\n ax.r2d = ax.r2c = function(v) { return fromLog(cleanNumber(v)); };\n\n ax.d2c = ax.r2l = cleanNumber;\n ax.c2d = ax.l2r = ensureNumber;\n\n ax.c2r = toLog;\n ax.l2d = fromLog;\n\n ax.d2p = function(v, clip) { return ax.l2p(ax.d2r(v, clip)); };\n ax.p2d = function(px) { return fromLog(p2l(px)); };\n\n ax.r2p = function(v) { return ax.l2p(cleanNumber(v)); };\n ax.p2r = p2l;\n\n ax.cleanPos = ensureNumber;\n } else if(ax.type === 'date') {\n // r and d are date strings, l and c are ms\n\n /*\n * Any of these functions with r and d on either side, calendar is the\n * **3rd** argument. log has reserved the second argument.\n *\n * Unless you need the special behavior of the second arg (ms2DateTime\n * uses this to limit precision, toLog uses true to clip negatives\n * to offscreen low rather than undefined), it's safe to pass 0.\n */\n ax.d2r = ax.r2d = Lib.identity;\n\n ax.d2c = ax.r2c = ax.d2l = ax.r2l = dt2ms;\n ax.c2d = ax.c2r = ax.l2d = ax.l2r = ms2dt;\n\n ax.d2p = ax.r2p = function(v, _, calendar) { return ax.l2p(dt2ms(v, 0, calendar)); };\n ax.p2d = ax.p2r = function(px, r, calendar) { return ms2dt(p2l(px), r, calendar); };\n\n ax.cleanPos = function(v) { return Lib.cleanDate(v, BADNUM, ax.calendar); };\n } else if(ax.type === 'category') {\n // d is categories (string)\n // c and l are indices (numbers)\n // r is categories or numbers\n\n ax.d2c = ax.d2l = setCategoryIndex;\n ax.r2d = ax.c2d = ax.l2d = getCategoryName;\n\n ax.d2r = ax.d2l_noadd = getCategoryPosition;\n\n ax.r2c = function(v) {\n var index = getRangePosition(v);\n return index !== undefined ? index : ax.fraction2r(0.5);\n };\n\n ax.l2r = ax.c2r = ensureNumber;\n ax.r2l = getRangePosition;\n\n ax.d2p = function(v) { return ax.l2p(ax.r2c(v)); };\n ax.p2d = function(px) { return getCategoryName(p2l(px)); };\n ax.r2p = ax.d2p;\n ax.p2r = p2l;\n\n ax.cleanPos = function(v) {\n if(typeof v === 'string' && v !== '') return v;\n return ensureNumber(v);\n };\n } else if(ax.type === 'multicategory') {\n // N.B. multicategory axes don't define d2c and d2l,\n // as 'data-to-calcdata' conversion needs to take into\n // account all data array items as in ax.makeCalcdata.\n\n ax.r2d = ax.c2d = ax.l2d = getCategoryName;\n ax.d2r = ax.d2l_noadd = getCategoryPosition;\n\n ax.r2c = function(v) {\n var index = getCategoryPosition(v);\n return index !== undefined ? index : ax.fraction2r(0.5);\n };\n\n ax.r2c_just_indices = getCategoryIndex;\n\n ax.l2r = ax.c2r = ensureNumber;\n ax.r2l = getCategoryPosition;\n\n ax.d2p = function(v) { return ax.l2p(ax.r2c(v)); };\n ax.p2d = function(px) { return getCategoryName(p2l(px)); };\n ax.r2p = ax.d2p;\n ax.p2r = p2l;\n\n ax.cleanPos = function(v) {\n if(Array.isArray(v) || (typeof v === 'string' && v !== '')) return v;\n return ensureNumber(v);\n };\n\n ax.setupMultiCategory = function(fullData) {\n var traceIndices = ax._traceIndices;\n var i, j;\n\n var group = ax._matchGroup;\n if(group && ax._categories.length === 0) {\n for(var axId2 in group) {\n if(axId2 !== axId) {\n var ax2 = fullLayout[axisIds.id2name(axId2)];\n traceIndices = traceIndices.concat(ax2._traceIndices);\n }\n }\n }\n\n // [ [cnt, {$cat: index}], for 1,2 ]\n var seen = [[0, {}], [0, {}]];\n // [ [arrayIn[0][i], arrayIn[1][i]], for i .. N ]\n var list = [];\n\n for(i = 0; i < traceIndices.length; i++) {\n var trace = fullData[traceIndices[i]];\n\n if(axLetter in trace) {\n var arrayIn = trace[axLetter];\n var len = trace._length || Lib.minRowLength(arrayIn);\n\n if(isArrayOrTypedArray(arrayIn[0]) && isArrayOrTypedArray(arrayIn[1])) {\n for(j = 0; j < len; j++) {\n var v0 = arrayIn[0][j];\n var v1 = arrayIn[1][j];\n\n if(isValidCategory(v0) && isValidCategory(v1)) {\n list.push([v0, v1]);\n\n if(!(v0 in seen[0][1])) {\n seen[0][1][v0] = seen[0][0]++;\n }\n if(!(v1 in seen[1][1])) {\n seen[1][1][v1] = seen[1][0]++;\n }\n }\n }\n }\n }\n }\n\n list.sort(function(a, b) {\n var ind0 = seen[0][1];\n var d = ind0[a[0]] - ind0[b[0]];\n if(d) return d;\n\n var ind1 = seen[1][1];\n return ind1[a[1]] - ind1[b[1]];\n });\n\n for(i = 0; i < list.length; i++) {\n setCategoryIndex(list[i]);\n }\n };\n }\n\n // find the range value at the specified (linear) fraction of the axis\n ax.fraction2r = function(v) {\n var rl0 = ax.r2l(ax.range[0]);\n var rl1 = ax.r2l(ax.range[1]);\n return ax.l2r(rl0 + v * (rl1 - rl0));\n };\n\n // find the fraction of the range at the specified range value\n ax.r2fraction = function(v) {\n var rl0 = ax.r2l(ax.range[0]);\n var rl1 = ax.r2l(ax.range[1]);\n return (ax.r2l(v) - rl0) / (rl1 - rl0);\n };\n\n ax.limitRange = function(rangeAttr) {\n var minallowed = ax.minallowed;\n var maxallowed = ax.maxallowed;\n if(minallowed === undefined && maxallowed === undefined) return;\n\n if(!rangeAttr) rangeAttr = 'range';\n var range = Lib.nestedProperty(ax, rangeAttr).get();\n var rng = Lib.simpleMap(range, ax.r2l);\n var axrev = rng[1] < rng[0];\n if(axrev) rng.reverse();\n\n var bounds = Lib.simpleMap([minallowed, maxallowed], ax.r2l);\n\n if(minallowed !== undefined && rng[0] < bounds[0]) range[axrev ? 1 : 0] = minallowed;\n if(maxallowed !== undefined && rng[1] > bounds[1]) range[axrev ? 0 : 1] = maxallowed;\n\n if(range[0] === range[1]) {\n var minL = ax.l2r(minallowed);\n var maxL = ax.l2r(maxallowed);\n\n if(minallowed !== undefined) {\n var _max = minL + 1;\n if(maxallowed !== undefined) _max = Math.min(_max, maxL);\n range[axrev ? 1 : 0] = _max;\n }\n\n if(maxallowed !== undefined) {\n var _min = maxL + 1;\n if(minallowed !== undefined) _min = Math.max(_min, minL);\n range[axrev ? 0 : 1] = _min;\n }\n }\n };\n\n /*\n * cleanRange: make sure range is a couplet of valid & distinct values\n * keep numbers away from the limits of floating point numbers,\n * and dates away from the ends of our date system (+/- 9999 years)\n *\n * optional param rangeAttr: operate on a different attribute, like\n * ax._r, rather than ax.range\n */\n ax.cleanRange = function(rangeAttr, opts) {\n ax._cleanRange(rangeAttr, opts);\n ax.limitRange(rangeAttr);\n };\n\n ax._cleanRange = function(rangeAttr, opts) {\n if(!opts) opts = {};\n if(!rangeAttr) rangeAttr = 'range';\n\n var range = Lib.nestedProperty(ax, rangeAttr).get();\n var i, dflt;\n\n if(ax.type === 'date') dflt = Lib.dfltRange(ax.calendar);\n else if(axLetter === 'y') dflt = constants.DFLTRANGEY;\n else if(ax._name === 'realaxis') dflt = [0, 1];\n else dflt = opts.dfltRange || constants.DFLTRANGEX;\n\n // make sure we don't later mutate the defaults\n dflt = dflt.slice();\n\n if(ax.rangemode === 'tozero' || ax.rangemode === 'nonnegative') {\n dflt[0] = 0;\n }\n\n if(!range || range.length !== 2) {\n Lib.nestedProperty(ax, rangeAttr).set(dflt);\n return;\n }\n\n var nullRange0 = range[0] === null;\n var nullRange1 = range[1] === null;\n\n if(ax.type === 'date' && !ax.autorange) {\n // check if milliseconds or js date objects are provided for range\n // and convert to date strings\n range[0] = Lib.cleanDate(range[0], BADNUM, ax.calendar);\n range[1] = Lib.cleanDate(range[1], BADNUM, ax.calendar);\n }\n\n for(i = 0; i < 2; i++) {\n if(ax.type === 'date') {\n if(!Lib.isDateTime(range[i], ax.calendar)) {\n ax[rangeAttr] = dflt;\n break;\n }\n\n if(ax.r2l(range[0]) === ax.r2l(range[1])) {\n // split by +/- 1 second\n var linCenter = Lib.constrain(ax.r2l(range[0]),\n Lib.MIN_MS + 1000, Lib.MAX_MS - 1000);\n range[0] = ax.l2r(linCenter - 1000);\n range[1] = ax.l2r(linCenter + 1000);\n break;\n }\n } else {\n if(!isNumeric(range[i])) {\n if(!(nullRange0 || nullRange1) && isNumeric(range[1 - i])) {\n range[i] = range[1 - i] * (i ? 10 : 0.1);\n } else {\n ax[rangeAttr] = dflt;\n break;\n }\n }\n\n if(range[i] < -FP_SAFE) range[i] = -FP_SAFE;\n else if(range[i] > FP_SAFE) range[i] = FP_SAFE;\n\n if(range[0] === range[1]) {\n // somewhat arbitrary: split by 1 or 1ppm, whichever is bigger\n var inc = Math.max(1, Math.abs(range[0] * 1e-6));\n range[0] -= inc;\n range[1] += inc;\n }\n }\n }\n };\n\n // set scaling to pixels\n ax.setScale = function(usePrivateRange) {\n var gs = fullLayout._size;\n\n // make sure we have a domain (pull it in from the axis\n // this one is overlaying if necessary)\n if(ax.overlaying) {\n var ax2 = axisIds.getFromId({ _fullLayout: fullLayout }, ax.overlaying);\n ax.domain = ax2.domain;\n }\n\n // While transitions are occurring, we get a double-transform\n // issue if we transform the drawn layer *and* use the new axis range to\n // draw the data. This allows us to construct setConvert using the pre-\n // interaction values of the range:\n var rangeAttr = (usePrivateRange && ax._r) ? '_r' : 'range';\n var calendar = ax.calendar;\n ax.cleanRange(rangeAttr);\n\n var rl0 = ax.r2l(ax[rangeAttr][0], calendar);\n var rl1 = ax.r2l(ax[rangeAttr][1], calendar);\n\n var isY = axLetter === 'y';\n if(isY) {\n ax._offset = gs.t + (1 - ax.domain[1]) * gs.h;\n ax._length = gs.h * (ax.domain[1] - ax.domain[0]);\n ax._m = ax._length / (rl0 - rl1);\n ax._b = -ax._m * rl1;\n } else {\n ax._offset = gs.l + ax.domain[0] * gs.w;\n ax._length = gs.w * (ax.domain[1] - ax.domain[0]);\n ax._m = ax._length / (rl1 - rl0);\n ax._b = -ax._m * rl0;\n }\n\n // set of \"N\" disjoint rangebreaks inside the range\n ax._rangebreaks = [];\n // length of these rangebreaks in value space - negative on reversed axes\n ax._lBreaks = 0;\n // l2p slope (same for all intervals)\n ax._m2 = 0;\n // set of l2p offsets (one for each of the (N+1) piecewise intervals)\n ax._B = [];\n\n if(ax.rangebreaks) {\n var i, brk;\n\n ax._rangebreaks = ax.locateBreaks(\n Math.min(rl0, rl1),\n Math.max(rl0, rl1)\n );\n\n if(ax._rangebreaks.length) {\n for(i = 0; i < ax._rangebreaks.length; i++) {\n brk = ax._rangebreaks[i];\n ax._lBreaks += Math.abs(brk.max - brk.min);\n }\n\n var flip = isY;\n if(rl0 > rl1) flip = !flip;\n if(flip) ax._rangebreaks.reverse();\n var sign = flip ? -1 : 1;\n\n ax._m2 = sign * ax._length / (Math.abs(rl1 - rl0) - ax._lBreaks);\n ax._B.push(-ax._m2 * (isY ? rl1 : rl0));\n for(i = 0; i < ax._rangebreaks.length; i++) {\n brk = ax._rangebreaks[i];\n ax._B.push(\n ax._B[ax._B.length - 1] -\n sign * ax._m2 * (brk.max - brk.min)\n );\n }\n\n // fill pixel (i.e. 'p') min/max here,\n // to not have to loop through the _rangebreaks twice during `p2l`\n for(i = 0; i < ax._rangebreaks.length; i++) {\n brk = ax._rangebreaks[i];\n brk.pmin = l2p(brk.min);\n brk.pmax = l2p(brk.max);\n }\n }\n }\n\n if(!isFinite(ax._m) || !isFinite(ax._b) || ax._length < 0) {\n fullLayout._replotting = false;\n throw new Error('Something went wrong with axis scaling');\n }\n };\n\n ax.maskBreaks = function(v) {\n var rangebreaksIn = ax.rangebreaks || [];\n var bnds, b0, b1, vb, vDate;\n\n\n if(!rangebreaksIn._cachedPatterns) {\n rangebreaksIn._cachedPatterns = rangebreaksIn.map(function(brk) {\n return brk.enabled && brk.bounds ? Lib.simpleMap(brk.bounds, brk.pattern ?\n cleanNumber :\n ax.d2c // case of pattern: ''\n ) : null;\n });\n }\n if(!rangebreaksIn._cachedValues) {\n rangebreaksIn._cachedValues = rangebreaksIn.map(function(brk) {\n return brk.enabled && brk.values ? Lib.simpleMap(brk.values, ax.d2c).sort(Lib.sorterAsc) : null;\n });\n }\n\n\n for(var i = 0; i < rangebreaksIn.length; i++) {\n var brk = rangebreaksIn[i];\n\n if(brk.enabled) {\n if(brk.bounds) {\n var pattern = brk.pattern;\n bnds = rangebreaksIn._cachedPatterns[i];\n b0 = bnds[0];\n b1 = bnds[1];\n\n switch(pattern) {\n case WEEKDAY_PATTERN:\n vDate = new Date(v);\n vb = vDate.getUTCDay();\n\n if(b0 > b1) {\n b1 += 7;\n if(vb < b0) vb += 7;\n }\n\n break;\n case HOUR_PATTERN:\n vDate = new Date(v);\n var hours = vDate.getUTCHours();\n var minutes = vDate.getUTCMinutes();\n var seconds = vDate.getUTCSeconds();\n var milliseconds = vDate.getUTCMilliseconds();\n\n vb = hours + (\n minutes / 60 +\n seconds / 3600 +\n milliseconds / 3600000\n );\n\n if(b0 > b1) {\n b1 += 24;\n if(vb < b0) vb += 24;\n }\n\n break;\n case '':\n // N.B. should work on date axes as well!\n // e.g. { bounds: ['2020-01-04', '2020-01-05 23:59'] }\n // TODO should work with reversed-range axes\n vb = v;\n break;\n }\n\n if(vb >= b0 && vb < b1) return BADNUM;\n } else {\n var vals = rangebreaksIn._cachedValues[i];\n for(var j = 0; j < vals.length; j++) {\n b0 = vals[j];\n b1 = b0 + brk.dvalue;\n if(v >= b0 && v < b1) return BADNUM;\n }\n }\n }\n }\n return v;\n };\n\n ax.locateBreaks = function(r0, r1) {\n var i, bnds, b0, b1;\n\n var rangebreaksOut = [];\n if(!ax.rangebreaks) return rangebreaksOut;\n\n var rangebreaksIn = ax.rangebreaks.slice().sort(function(a, b) {\n if(a.pattern === WEEKDAY_PATTERN && b.pattern === HOUR_PATTERN) return -1;\n if(b.pattern === WEEKDAY_PATTERN && a.pattern === HOUR_PATTERN) return 1;\n return 0;\n });\n\n var addBreak = function(min, max) {\n min = Lib.constrain(min, r0, r1);\n max = Lib.constrain(max, r0, r1);\n if(min === max) return;\n\n var isNewBreak = true;\n for(var j = 0; j < rangebreaksOut.length; j++) {\n var brkj = rangebreaksOut[j];\n if(min < brkj.max && max >= brkj.min) {\n if(min < brkj.min) {\n brkj.min = min;\n }\n if(max > brkj.max) {\n brkj.max = max;\n }\n isNewBreak = false;\n }\n }\n if(isNewBreak) {\n rangebreaksOut.push({min: min, max: max});\n }\n };\n\n for(i = 0; i < rangebreaksIn.length; i++) {\n var brk = rangebreaksIn[i];\n\n if(brk.enabled) {\n if(brk.bounds) {\n var t0 = r0;\n var t1 = r1;\n if(brk.pattern) {\n // to remove decimal (most often found in auto ranges)\n t0 = Math.floor(t0);\n }\n\n bnds = Lib.simpleMap(brk.bounds, brk.pattern ? cleanNumber : ax.r2l);\n b0 = bnds[0];\n b1 = bnds[1];\n\n // r0 value as date\n var t0Date = new Date(t0);\n // r0 value for break pattern\n var bndDelta;\n // step in ms between rangebreaks\n var step;\n\n switch(brk.pattern) {\n case WEEKDAY_PATTERN:\n step = ONEWEEK;\n\n bndDelta = (\n (b1 < b0 ? 7 : 0) +\n (b1 - b0)\n ) * ONEDAY;\n\n t0 += b0 * ONEDAY - (\n t0Date.getUTCDay() * ONEDAY +\n t0Date.getUTCHours() * ONEHOUR +\n t0Date.getUTCMinutes() * ONEMIN +\n t0Date.getUTCSeconds() * ONESEC +\n t0Date.getUTCMilliseconds()\n );\n break;\n case HOUR_PATTERN:\n step = ONEDAY;\n\n bndDelta = (\n (b1 < b0 ? 24 : 0) +\n (b1 - b0)\n ) * ONEHOUR;\n\n t0 += b0 * ONEHOUR - (\n t0Date.getUTCHours() * ONEHOUR +\n t0Date.getUTCMinutes() * ONEMIN +\n t0Date.getUTCSeconds() * ONESEC +\n t0Date.getUTCMilliseconds()\n );\n break;\n default:\n t0 = Math.min(bnds[0], bnds[1]);\n t1 = Math.max(bnds[0], bnds[1]);\n step = t1 - t0;\n bndDelta = step;\n }\n\n for(var t = t0; t < t1; t += step) {\n addBreak(t, t + bndDelta);\n }\n } else {\n var vals = Lib.simpleMap(brk.values, ax.d2c);\n for(var j = 0; j < vals.length; j++) {\n b0 = vals[j];\n b1 = b0 + brk.dvalue;\n addBreak(b0, b1);\n }\n }\n }\n }\n\n rangebreaksOut.sort(function(a, b) { return a.min - b.min; });\n\n return rangebreaksOut;\n };\n\n // makeCalcdata: takes an x or y array and converts it\n // to a position on the axis object \"ax\"\n // inputs:\n // trace - a data object from gd.data\n // axLetter - a string, either 'x' or 'y', for which item\n // to convert (TODO: is this now always the same as\n // the first letter of ax._id?)\n // in case the expected data isn't there, make a list of\n // integers based on the opposite data\n ax.makeCalcdata = function(trace, axLetter, opts) {\n var arrayIn, arrayOut, i, len;\n\n var axType = ax.type;\n var cal = axType === 'date' && trace[axLetter + 'calendar'];\n\n if(axLetter in trace) {\n arrayIn = trace[axLetter];\n len = trace._length || Lib.minRowLength(arrayIn);\n\n if(Lib.isTypedArray(arrayIn) && (axType === 'linear' || axType === 'log')) {\n if(len === arrayIn.length) {\n return arrayIn;\n } else if(arrayIn.subarray) {\n return arrayIn.subarray(0, len);\n }\n }\n\n if(axType === 'multicategory') {\n return setMultiCategoryIndex(arrayIn, len);\n }\n\n arrayOut = new Array(len);\n for(i = 0; i < len; i++) {\n arrayOut[i] = ax.d2c(arrayIn[i], 0, cal, opts);\n }\n } else {\n var v0 = ((axLetter + '0') in trace) ? ax.d2c(trace[axLetter + '0'], 0, cal) : 0;\n var dv = (trace['d' + axLetter]) ? Number(trace['d' + axLetter]) : 1;\n\n // the opposing data, for size if we have x and dx etc\n arrayIn = trace[{x: 'y', y: 'x'}[axLetter]];\n len = trace._length || arrayIn.length;\n arrayOut = new Array(len);\n\n for(i = 0; i < len; i++) {\n arrayOut[i] = v0 + i * dv;\n }\n }\n\n // mask (i.e. set to BADNUM) coords that fall inside rangebreaks\n if(ax.rangebreaks) {\n for(i = 0; i < len; i++) {\n arrayOut[i] = ax.maskBreaks(arrayOut[i]);\n }\n }\n\n return arrayOut;\n };\n\n ax.isValidRange = function(range, nullOk) {\n return (\n Array.isArray(range) &&\n range.length === 2 &&\n ((nullOk && range[0] === null) || isNumeric(ax.r2l(range[0]))) &&\n ((nullOk && range[1] === null) || isNumeric(ax.r2l(range[1])))\n );\n };\n\n ax.getAutorangeDflt = function(range, options) {\n var autorangeDflt = !ax.isValidRange(range, 'nullOk');\n if(autorangeDflt && options && options.reverseDflt) autorangeDflt = 'reversed';\n else if(range) {\n if(range[0] === null && range[1] === null) {\n autorangeDflt = true;\n } else if(range[0] === null && range[1] !== null) {\n autorangeDflt = 'min';\n } else if(range[0] !== null && range[1] === null) {\n autorangeDflt = 'max';\n }\n }\n return autorangeDflt;\n };\n\n ax.isReversed = function() {\n var autorange = ax.autorange;\n return (\n autorange === 'reversed' ||\n autorange === 'min reversed' ||\n autorange === 'max reversed'\n );\n };\n\n ax.isPtWithinRange = function(d, calendar) {\n var coord = ax.c2l(d[axLetter], null, calendar);\n var r0 = ax.r2l(ax.range[0]);\n var r1 = ax.r2l(ax.range[1]);\n\n if(r0 < r1) {\n return r0 <= coord && coord <= r1;\n } else {\n // Reversed axis case.\n return r1 <= coord && coord <= r0;\n }\n };\n\n ax._emptyCategories = function() {\n ax._categories = [];\n ax._categoriesMap = {};\n };\n\n // should skip if not category nor multicategory\n ax.clearCalc = function() {\n var group = ax._matchGroup;\n if(group) {\n var categories = null;\n var categoriesMap = null;\n\n for(var axId2 in group) {\n var ax2 = fullLayout[axisIds.id2name(axId2)];\n if(ax2._categories) {\n categories = ax2._categories;\n categoriesMap = ax2._categoriesMap;\n break;\n }\n }\n\n if(categories && categoriesMap) {\n ax._categories = categories;\n ax._categoriesMap = categoriesMap;\n } else {\n ax._emptyCategories();\n }\n } else {\n ax._emptyCategories();\n }\n\n if(ax._initialCategories) {\n for(var j = 0; j < ax._initialCategories.length; j++) {\n setCategoryIndex(ax._initialCategories[j]);\n }\n }\n };\n\n // sort the axis (and all the matching ones) by _initialCategories\n // returns the indices of the traces affected by the reordering\n ax.sortByInitialCategories = function() {\n var affectedTraces = [];\n\n ax._emptyCategories();\n\n if(ax._initialCategories) {\n for(var j = 0; j < ax._initialCategories.length; j++) {\n setCategoryIndex(ax._initialCategories[j]);\n }\n }\n\n affectedTraces = affectedTraces.concat(ax._traceIndices);\n\n // Propagate to matching axes\n var group = ax._matchGroup;\n for(var axId2 in group) {\n if(axId === axId2) continue;\n var ax2 = fullLayout[axisIds.id2name(axId2)];\n ax2._categories = ax._categories;\n ax2._categoriesMap = ax._categoriesMap;\n affectedTraces = affectedTraces.concat(ax2._traceIndices);\n }\n return affectedTraces;\n };\n\n // Propagate localization into the axis so that\n // methods in Axes can use it w/o having to pass fullLayout\n // Default (non-d3) number formatting uses separators directly\n // dates and d3-formatted numbers use the d3 locale\n // Fall back on default format for dummy axes that don't care about formatting\n var locale = fullLayout._d3locale;\n if(ax.type === 'date') {\n ax._dateFormat = locale ? locale.timeFormat : utcFormat;\n ax._extraFormat = fullLayout._extraFormat;\n }\n // occasionally we need _numFormat to pass through\n // even though it won't be needed by this axis\n ax._separators = fullLayout.separators;\n ax._numFormat = locale ? locale.numberFormat : numberFormat;\n\n // and for bar charts and box plots: reset forced minimum tick spacing\n delete ax._minDtick;\n delete ax._forceTick0;\n};\n","'use strict';\n\n/*\n * Attributes 'showexponent', 'showtickprefix' and 'showticksuffix'\n * share values.\n *\n * If only 1 attribute is set,\n * the remaining attributes inherit that value.\n *\n * If 2 attributes are set to the same value,\n * the remaining attribute inherits that value.\n *\n * If 2 attributes are set to different values,\n * the remaining is set to its dflt value.\n *\n */\nmodule.exports = function getShowAttrDflt(containerIn) {\n var showAttrsAll = ['showexponent', 'showtickprefix', 'showticksuffix'];\n var showAttrs = showAttrsAll.filter(function(a) {\n return containerIn[a] !== undefined;\n });\n var sameVal = function(a) {\n return containerIn[a] === containerIn[showAttrs[0]];\n };\n\n if(showAttrs.every(sameVal) || showAttrs.length === 1) {\n return containerIn[showAttrs[0]];\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar contrast = require('../../components/color').contrast;\nvar layoutAttributes = require('./layout_attributes');\nvar getShowAttrDflt = require('./show_dflt');\nvar handleArrayContainerDefaults = require('../array_container_defaults');\n\nmodule.exports = function handleTickLabelDefaults(containerIn, containerOut, coerce, axType, options) {\n if(!options) options = {};\n\n var labelalias = coerce('labelalias');\n if(!Lib.isPlainObject(labelalias)) delete containerOut.labelalias;\n\n var showAttrDflt = getShowAttrDflt(containerIn);\n\n var showTickLabels = coerce('showticklabels');\n if(showTickLabels) {\n if(!options.noTicklabelshift) {\n coerce('ticklabelshift');\n }\n if(!options.noTicklabelstandoff) {\n coerce('ticklabelstandoff');\n }\n var font = options.font || {};\n var contColor = containerOut.color;\n var position = containerOut.ticklabelposition || '';\n var dfltFontColor = position.indexOf('inside') !== -1 ?\n contrast(options.bgColor) :\n // as with titlefont.color, inherit axis.color only if one was\n // explicitly provided\n (contColor && contColor !== layoutAttributes.color.dflt) ?\n contColor : font.color;\n\n Lib.coerceFont(coerce, 'tickfont', font, { overrideDflt: {\n color: dfltFontColor\n }});\n\n if(\n !options.noTicklabelstep &&\n axType !== 'multicategory' &&\n axType !== 'log'\n ) {\n coerce('ticklabelstep');\n }\n\n if(!options.noAng) {\n var tickAngle = coerce('tickangle');\n if(!options.noAutotickangles && tickAngle === 'auto') {\n coerce('autotickangles');\n }\n }\n\n if(axType !== 'category') {\n var tickFormat = coerce('tickformat');\n\n handleArrayContainerDefaults(containerIn, containerOut, {\n name: 'tickformatstops',\n inclusionAttr: 'enabled',\n handleItemDefaults: tickformatstopDefaults\n });\n if(!containerOut.tickformatstops.length) {\n delete containerOut.tickformatstops;\n }\n\n if(!options.noExp && !tickFormat && axType !== 'date') {\n coerce('showexponent', showAttrDflt);\n coerce('exponentformat');\n coerce('minexponent');\n coerce('separatethousands');\n }\n }\n }\n};\n\nfunction tickformatstopDefaults(valueIn, valueOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(valueIn, valueOut, layoutAttributes.tickformatstops, attr, dflt);\n }\n\n var enabled = coerce('enabled');\n if(enabled) {\n coerce('dtickrange');\n coerce('value');\n }\n}\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar layoutAttributes = require('./layout_attributes');\n\n\n/**\n * options: inherits outerTicks from axes.handleAxisDefaults\n */\nmodule.exports = function handleTickMarkDefaults(containerIn, containerOut, coerce, options) {\n var isMinor = options.isMinor;\n var cIn = isMinor ? containerIn.minor || {} : containerIn;\n var cOut = isMinor ? containerOut.minor : containerOut;\n var lAttr = isMinor ? layoutAttributes.minor : layoutAttributes;\n var prefix = isMinor ? 'minor.' : '';\n\n var tickLen = Lib.coerce2(cIn, cOut, lAttr, 'ticklen', isMinor ? ((containerOut.ticklen || 5) * 0.6) : undefined);\n var tickWidth = Lib.coerce2(cIn, cOut, lAttr, 'tickwidth', isMinor ? (containerOut.tickwidth || 1) : undefined);\n var tickColor = Lib.coerce2(cIn, cOut, lAttr, 'tickcolor', (isMinor ? containerOut.tickcolor : undefined) || cOut.color);\n var showTicks = coerce(prefix + 'ticks', (\n (!isMinor && options.outerTicks) || tickLen || tickWidth || tickColor\n ) ? 'outside' : '');\n\n if(!showTicks) {\n delete cOut.ticklen;\n delete cOut.tickwidth;\n delete cOut.tickcolor;\n }\n};\n","'use strict';\n\nvar cleanTicks = require('./clean_ticks');\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar isTypedArraySpec = require('../../lib/array').isTypedArraySpec;\nvar decodeTypedArraySpec = require('../../lib/array').decodeTypedArraySpec;\n\nmodule.exports = function handleTickValueDefaults(containerIn, containerOut, coerce, axType, opts) {\n if(!opts) opts = {};\n var isMinor = opts.isMinor;\n var cIn = isMinor ? containerIn.minor || {} : containerIn;\n var cOut = isMinor ? containerOut.minor : containerOut;\n var prefix = isMinor ? 'minor.' : '';\n\n function readInput(attr) {\n var v = cIn[attr];\n if(isTypedArraySpec(v)) v = decodeTypedArraySpec(v);\n\n return (\n v !== undefined\n ) ? v : (cOut._template || {})[attr];\n }\n\n var _tick0 = readInput('tick0');\n var _dtick = readInput('dtick');\n var _tickvals = readInput('tickvals');\n\n var tickmodeDefault = isArrayOrTypedArray(_tickvals) ? 'array' :\n _dtick ? 'linear' :\n 'auto';\n var tickmode = coerce(prefix + 'tickmode', tickmodeDefault);\n\n if(tickmode === 'auto' || tickmode === 'sync') {\n coerce(prefix + 'nticks');\n } else if(tickmode === 'linear') {\n // dtick is usually a positive number, but there are some\n // special strings available for log or date axes\n // tick0 also has special logic\n var dtick = cOut.dtick = cleanTicks.dtick(\n _dtick, axType);\n cOut.tick0 = cleanTicks.tick0(\n _tick0, axType, containerOut.calendar, dtick);\n } else if(axType !== 'multicategory') {\n var tickvals = coerce(prefix + 'tickvals');\n if(tickvals === undefined) cOut.tickmode = 'auto';\n else if(!isMinor) coerce('ticktext');\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Drawing = require('../../components/drawing');\nvar Axes = require('./axes');\n\n/**\n * transitionAxes\n *\n * transition axes from one set of ranges to another, using a svg\n * transformations, similar to during panning.\n *\n * @param {DOM element | object} gd\n * @param {array} edits : array of 'edits', each item with\n * - plotinfo {object} subplot object\n * - xr0 {array} initial x-range\n * - xr1 {array} end x-range\n * - yr0 {array} initial y-range\n * - yr1 {array} end y-range\n * @param {object} transitionOpts\n * @param {function} makeOnCompleteCallback\n */\nmodule.exports = function transitionAxes(gd, edits, transitionOpts, makeOnCompleteCallback) {\n var fullLayout = gd._fullLayout;\n\n // special case for redraw:false Plotly.animate that relies on this\n // to update axis-referenced layout components\n if(edits.length === 0) {\n Axes.redrawComponents(gd);\n return;\n }\n\n function unsetSubplotTransform(subplot) {\n var xa = subplot.xaxis;\n var ya = subplot.yaxis;\n\n fullLayout._defs.select('#' + subplot.clipId + '> rect')\n .call(Drawing.setTranslate, 0, 0)\n .call(Drawing.setScale, 1, 1);\n\n subplot.plot\n .call(Drawing.setTranslate, xa._offset, ya._offset)\n .call(Drawing.setScale, 1, 1);\n\n var traceGroups = subplot.plot.selectAll('.scatterlayer .trace');\n\n // This is specifically directed at scatter traces, applying an inverse\n // scale to individual points to counteract the scale of the trace\n // as a whole:\n traceGroups.selectAll('.point')\n .call(Drawing.setPointGroupScale, 1, 1);\n traceGroups.selectAll('.textpoint')\n .call(Drawing.setTextPointsScale, 1, 1);\n traceGroups\n .call(Drawing.hideOutsideRangePoints, subplot);\n }\n\n function updateSubplot(edit, progress) {\n var plotinfo = edit.plotinfo;\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var xlen = xa._length;\n var ylen = ya._length;\n var editX = !!edit.xr1;\n var editY = !!edit.yr1;\n var viewBox = [];\n\n if(editX) {\n var xr0 = Lib.simpleMap(edit.xr0, xa.r2l);\n var xr1 = Lib.simpleMap(edit.xr1, xa.r2l);\n var dx0 = xr0[1] - xr0[0];\n var dx1 = xr1[1] - xr1[0];\n viewBox[0] = (xr0[0] * (1 - progress) + progress * xr1[0] - xr0[0]) / (xr0[1] - xr0[0]) * xlen;\n viewBox[2] = xlen * ((1 - progress) + progress * dx1 / dx0);\n xa.range[0] = xa.l2r(xr0[0] * (1 - progress) + progress * xr1[0]);\n xa.range[1] = xa.l2r(xr0[1] * (1 - progress) + progress * xr1[1]);\n } else {\n viewBox[0] = 0;\n viewBox[2] = xlen;\n }\n\n if(editY) {\n var yr0 = Lib.simpleMap(edit.yr0, ya.r2l);\n var yr1 = Lib.simpleMap(edit.yr1, ya.r2l);\n var dy0 = yr0[1] - yr0[0];\n var dy1 = yr1[1] - yr1[0];\n viewBox[1] = (yr0[1] * (1 - progress) + progress * yr1[1] - yr0[1]) / (yr0[0] - yr0[1]) * ylen;\n viewBox[3] = ylen * ((1 - progress) + progress * dy1 / dy0);\n ya.range[0] = xa.l2r(yr0[0] * (1 - progress) + progress * yr1[0]);\n ya.range[1] = ya.l2r(yr0[1] * (1 - progress) + progress * yr1[1]);\n } else {\n viewBox[1] = 0;\n viewBox[3] = ylen;\n }\n\n Axes.drawOne(gd, xa, {skipTitle: true});\n Axes.drawOne(gd, ya, {skipTitle: true});\n Axes.redrawComponents(gd, [xa._id, ya._id]);\n\n var xScaleFactor = editX ? xlen / viewBox[2] : 1;\n var yScaleFactor = editY ? ylen / viewBox[3] : 1;\n var clipDx = editX ? viewBox[0] : 0;\n var clipDy = editY ? viewBox[1] : 0;\n var fracDx = editX ? (viewBox[0] / viewBox[2] * xlen) : 0;\n var fracDy = editY ? (viewBox[1] / viewBox[3] * ylen) : 0;\n var plotDx = xa._offset - fracDx;\n var plotDy = ya._offset - fracDy;\n\n plotinfo.clipRect\n .call(Drawing.setTranslate, clipDx, clipDy)\n .call(Drawing.setScale, 1 / xScaleFactor, 1 / yScaleFactor);\n\n plotinfo.plot\n .call(Drawing.setTranslate, plotDx, plotDy)\n .call(Drawing.setScale, xScaleFactor, yScaleFactor);\n\n // apply an inverse scale to individual points to counteract\n // the scale of the trace group.\n Drawing.setPointGroupScale(plotinfo.zoomScalePts, 1 / xScaleFactor, 1 / yScaleFactor);\n Drawing.setTextPointsScale(plotinfo.zoomScaleTxt, 1 / xScaleFactor, 1 / yScaleFactor);\n }\n\n var onComplete;\n if(makeOnCompleteCallback) {\n // This module makes the choice whether or not it notifies Plotly.transition\n // about completion:\n onComplete = makeOnCompleteCallback();\n }\n\n function transitionComplete() {\n var aobj = {};\n\n for(var i = 0; i < edits.length; i++) {\n var edit = edits[i];\n var xa = edit.plotinfo.xaxis;\n var ya = edit.plotinfo.yaxis;\n if(edit.xr1) aobj[xa._name + '.range'] = edit.xr1.slice();\n if(edit.yr1) aobj[ya._name + '.range'] = edit.yr1.slice();\n }\n\n // Signal that this transition has completed:\n onComplete && onComplete();\n\n return Registry.call('relayout', gd, aobj).then(function() {\n for(var i = 0; i < edits.length; i++) {\n unsetSubplotTransform(edits[i].plotinfo);\n }\n });\n }\n\n function transitionInterrupt() {\n var aobj = {};\n\n for(var i = 0; i < edits.length; i++) {\n var edit = edits[i];\n var xa = edit.plotinfo.xaxis;\n var ya = edit.plotinfo.yaxis;\n if(edit.xr0) aobj[xa._name + '.range'] = edit.xr0.slice();\n if(edit.yr0) aobj[ya._name + '.range'] = edit.yr0.slice();\n }\n\n return Registry.call('relayout', gd, aobj).then(function() {\n for(var i = 0; i < edits.length; i++) {\n unsetSubplotTransform(edits[i].plotinfo);\n }\n });\n }\n\n var t1, t2, raf;\n var easeFn = d3.ease(transitionOpts.easing);\n\n gd._transitionData._interruptCallbacks.push(function() {\n window.cancelAnimationFrame(raf);\n raf = null;\n return transitionInterrupt();\n });\n\n function doFrame() {\n t2 = Date.now();\n\n var tInterp = Math.min(1, (t2 - t1) / transitionOpts.duration);\n var progress = easeFn(tInterp);\n\n for(var i = 0; i < edits.length; i++) {\n updateSubplot(edits[i], progress);\n }\n\n if(t2 - t1 > transitionOpts.duration) {\n transitionComplete();\n raf = window.cancelAnimationFrame(doFrame);\n } else {\n raf = window.requestAnimationFrame(doFrame);\n }\n }\n\n t1 = Date.now();\n raf = window.requestAnimationFrame(doFrame);\n\n return Promise.resolve();\n};\n","'use strict';\n\nvar traceIs = require('../../registry').traceIs;\nvar autoType = require('./axis_autotype');\n\n/*\n * data: the plot data to use in choosing auto type\n * name: axis object name (ie 'xaxis') if one should be stored\n */\nmodule.exports = function handleTypeDefaults(containerIn, containerOut, coerce, options) {\n coerce('autotypenumbers', options.autotypenumbersDflt);\n var axType = coerce('type', (options.splomStash || {}).type);\n\n if(axType === '-') {\n setAutoType(containerOut, options.data);\n\n if(containerOut.type === '-') {\n containerOut.type = 'linear';\n } else {\n // copy autoType back to input axis\n // note that if this object didn't exist\n // in the input layout, we have to put it in\n // this happens in the main supplyDefaults function\n containerIn.type = containerOut.type;\n }\n }\n};\n\nfunction setAutoType(ax, data) {\n // new logic: let people specify any type they want,\n // only autotype if type is '-'\n if(ax.type !== '-') return;\n\n var id = ax._id;\n var axLetter = id.charAt(0);\n var i;\n\n // support 3d\n if(id.indexOf('scene') !== -1) id = axLetter;\n\n var d0 = getFirstNonEmptyTrace(data, id, axLetter);\n if(!d0) return;\n\n // first check for histograms, as the count direction\n // should always default to a linear axis\n if(d0.type === 'histogram' &&\n axLetter === {v: 'y', h: 'x'}[d0.orientation || 'v']\n ) {\n ax.type = 'linear';\n return;\n }\n\n var calAttr = axLetter + 'calendar';\n var calendar = d0[calAttr];\n var opts = {noMultiCategory: !traceIs(d0, 'cartesian') || traceIs(d0, 'noMultiCategory')};\n\n // To not confuse 2D x/y used for per-box sample points for multicategory coordinates\n if(d0.type === 'box' && d0._hasPreCompStats &&\n axLetter === {h: 'x', v: 'y'}[d0.orientation || 'v']\n ) {\n opts.noMultiCategory = true;\n }\n\n opts.autotypenumbers = ax.autotypenumbers;\n\n // check all boxes on this x axis to see\n // if they're dates, numbers, or categories\n if(isBoxWithoutPositionCoords(d0, axLetter)) {\n var posLetter = getBoxPosLetter(d0);\n var boxPositions = [];\n\n for(i = 0; i < data.length; i++) {\n var trace = data[i];\n if(!traceIs(trace, 'box-violin') || (trace[axLetter + 'axis'] || axLetter) !== id) continue;\n\n if(trace[posLetter] !== undefined) boxPositions.push(trace[posLetter][0]);\n else if(trace.name !== undefined) boxPositions.push(trace.name);\n else boxPositions.push('text');\n\n if(trace[calAttr] !== calendar) calendar = undefined;\n }\n\n ax.type = autoType(boxPositions, calendar, opts);\n } else if(d0.type === 'splom') {\n var dimensions = d0.dimensions;\n var dim = dimensions[d0._axesDim[id]];\n if(dim.visible) ax.type = autoType(dim.values, calendar, opts);\n } else {\n ax.type = autoType(d0[axLetter] || [d0[axLetter + '0']], calendar, opts);\n }\n}\n\nfunction getFirstNonEmptyTrace(data, id, axLetter) {\n for(var i = 0; i < data.length; i++) {\n var trace = data[i];\n\n if(trace.type === 'splom' &&\n trace._length > 0 &&\n (trace['_' + axLetter + 'axes'] || {})[id]\n ) {\n return trace;\n }\n\n if((trace[axLetter + 'axis'] || axLetter) === id) {\n if(isBoxWithoutPositionCoords(trace, axLetter)) {\n return trace;\n } else if((trace[axLetter] || []).length || trace[axLetter + '0']) {\n return trace;\n }\n }\n }\n}\n\nfunction getBoxPosLetter(trace) {\n return {v: 'x', h: 'y'}[trace.orientation || 'v'];\n}\n\nfunction isBoxWithoutPositionCoords(trace, axLetter) {\n var posLetter = getBoxPosLetter(trace);\n var isBox = traceIs(trace, 'box-violin');\n var isCandlestick = traceIs(trace._fullInput || {}, 'candlestick');\n\n return (\n isBox &&\n !isCandlestick &&\n axLetter === posLetter &&\n trace[posLetter] === undefined &&\n trace[posLetter + '0'] === undefined\n );\n}\n","'use strict';\n\nvar Registry = require('../registry');\nvar Lib = require('../lib');\n\n/*\n * Create or update an observer. This function is designed to be\n * idempotent so that it can be called over and over as the component\n * updates, and will attach and detach listeners as needed.\n *\n * @param {optional object} container\n * An object on which the observer is stored. This is the mechanism\n * by which it is idempotent. If it already exists, another won't be\n * added. Each time it's called, the value lookup table is updated.\n * @param {array} commandList\n * An array of commands, following either `buttons` of `updatemenus`\n * or `steps` of `sliders`.\n * @param {function} onchange\n * A listener called when the value is changed. Receives data object\n * with information about the new state.\n */\nexports.manageCommandObserver = function(gd, container, commandList, onchange) {\n var ret = {};\n var enabled = true;\n\n if(container && container._commandObserver) {\n ret = container._commandObserver;\n }\n\n if(!ret.cache) {\n ret.cache = {};\n }\n\n // Either create or just recompute this:\n ret.lookupTable = {};\n\n var binding = exports.hasSimpleAPICommandBindings(gd, commandList, ret.lookupTable);\n\n if(container && container._commandObserver) {\n if(!binding) {\n // If container exists and there are no longer any bindings,\n // remove existing:\n if(container._commandObserver.remove) {\n container._commandObserver.remove();\n container._commandObserver = null;\n return ret;\n }\n } else {\n // If container exists and there *are* bindings, then the lookup\n // table should have been updated and check is already attached,\n // so there's nothing to be done:\n return ret;\n }\n }\n\n // Determine whether there's anything to do for this binding:\n\n if(binding) {\n // Build the cache:\n bindingValueHasChanged(gd, binding, ret.cache);\n\n ret.check = function check() {\n if(!enabled) return;\n\n var update = bindingValueHasChanged(gd, binding, ret.cache);\n\n if(update.changed && onchange) {\n // Disable checks for the duration of this command in order to avoid\n // infinite loops:\n if(ret.lookupTable[update.value] !== undefined) {\n ret.disable();\n Promise.resolve(onchange({\n value: update.value,\n type: binding.type,\n prop: binding.prop,\n traces: binding.traces,\n index: ret.lookupTable[update.value]\n })).then(ret.enable, ret.enable);\n }\n }\n\n return update.changed;\n };\n\n var checkEvents = [\n 'plotly_relayout',\n 'plotly_redraw',\n 'plotly_restyle',\n 'plotly_update',\n 'plotly_animatingframe',\n 'plotly_afterplot'\n ];\n\n for(var i = 0; i < checkEvents.length; i++) {\n gd._internalOn(checkEvents[i], ret.check);\n }\n\n ret.remove = function() {\n for(var i = 0; i < checkEvents.length; i++) {\n gd._removeInternalListener(checkEvents[i], ret.check);\n }\n };\n } else {\n // TODO: It'd be really neat to actually give a *reason* for this, but at least a warning\n // is a start\n Lib.log('Unable to automatically bind plot updates to API command');\n\n ret.lookupTable = {};\n ret.remove = function() {};\n }\n\n ret.disable = function disable() {\n enabled = false;\n };\n\n ret.enable = function enable() {\n enabled = true;\n };\n\n if(container) {\n container._commandObserver = ret;\n }\n\n return ret;\n};\n\n/*\n * This function checks to see if an array of objects containing\n * method and args properties is compatible with automatic two-way\n * binding. The criteria right now are that\n *\n * 1. multiple traces may be affected\n * 2. only one property may be affected\n * 3. the same property must be affected by all commands\n */\nexports.hasSimpleAPICommandBindings = function(gd, commandList, bindingsByValue) {\n var i;\n var n = commandList.length;\n\n var refBinding;\n\n for(i = 0; i < n; i++) {\n var binding;\n var command = commandList[i];\n var method = command.method;\n var args = command.args;\n\n if(!Array.isArray(args)) args = [];\n\n // If any command has no method, refuse to bind:\n if(!method) {\n return false;\n }\n var bindings = exports.computeAPICommandBindings(gd, method, args);\n\n // Right now, handle one and *only* one property being set:\n if(bindings.length !== 1) {\n return false;\n }\n\n if(!refBinding) {\n refBinding = bindings[0];\n if(Array.isArray(refBinding.traces)) {\n refBinding.traces.sort();\n }\n } else {\n binding = bindings[0];\n if(binding.type !== refBinding.type) {\n return false;\n }\n if(binding.prop !== refBinding.prop) {\n return false;\n }\n if(Array.isArray(refBinding.traces)) {\n if(Array.isArray(binding.traces)) {\n binding.traces.sort();\n for(var j = 0; j < refBinding.traces.length; j++) {\n if(refBinding.traces[j] !== binding.traces[j]) {\n return false;\n }\n }\n } else {\n return false;\n }\n } else {\n if(binding.prop !== refBinding.prop) {\n return false;\n }\n }\n }\n\n binding = bindings[0];\n var value = binding.value;\n if(Array.isArray(value)) {\n if(value.length === 1) {\n value = value[0];\n } else {\n return false;\n }\n }\n if(bindingsByValue) {\n bindingsByValue[value] = i;\n }\n }\n\n return refBinding;\n};\n\nfunction bindingValueHasChanged(gd, binding, cache) {\n var container, value, obj;\n var changed = false;\n\n if(binding.type === 'data') {\n // If it's data, we need to get a trace. Based on the limited scope\n // of what we cover, we can just take the first trace from the list,\n // or otherwise just the first trace:\n container = gd._fullData[binding.traces !== null ? binding.traces[0] : 0];\n } else if(binding.type === 'layout') {\n container = gd._fullLayout;\n } else {\n return false;\n }\n\n value = Lib.nestedProperty(container, binding.prop).get();\n\n obj = cache[binding.type] = cache[binding.type] || {};\n\n if(obj.hasOwnProperty(binding.prop)) {\n if(obj[binding.prop] !== value) {\n changed = true;\n }\n }\n\n obj[binding.prop] = value;\n\n return {\n changed: changed,\n value: value\n };\n}\n\n/*\n * Execute an API command. There's really not much to this; it just provides\n * a common hook so that implementations don't need to be synchronized across\n * multiple components with the ability to invoke API commands.\n *\n * @param {string} method\n * The name of the plotly command to execute. Must be one of 'animate',\n * 'restyle', 'relayout', 'update'.\n * @param {array} args\n * A list of arguments passed to the API command\n */\nexports.executeAPICommand = function(gd, method, args) {\n if(method === 'skip') return Promise.resolve();\n\n var _method = Registry.apiMethodRegistry[method];\n var allArgs = [gd];\n if(!Array.isArray(args)) args = [];\n\n for(var i = 0; i < args.length; i++) {\n allArgs.push(args[i]);\n }\n\n return _method.apply(null, allArgs).catch(function(err) {\n Lib.warn('API call to Plotly.' + method + ' rejected.', err);\n return Promise.reject(err);\n });\n};\n\nexports.computeAPICommandBindings = function(gd, method, args) {\n var bindings;\n\n if(!Array.isArray(args)) args = [];\n\n switch(method) {\n case 'restyle':\n bindings = computeDataBindings(gd, args);\n break;\n case 'relayout':\n bindings = computeLayoutBindings(gd, args);\n break;\n case 'update':\n bindings = computeDataBindings(gd, [args[0], args[2]])\n .concat(computeLayoutBindings(gd, [args[1]]));\n break;\n case 'animate':\n bindings = computeAnimateBindings(gd, args);\n break;\n default:\n // This is the case where intelligent logic about what affects\n // this command is not implemented. It causes no ill effects.\n // For example, addFrames simply won't bind to a control component.\n bindings = [];\n }\n return bindings;\n};\n\nfunction computeAnimateBindings(gd, args) {\n // We'll assume that the only relevant modification an animation\n // makes that's meaningfully tracked is the frame:\n if(Array.isArray(args[0]) && args[0].length === 1 && ['string', 'number'].indexOf(typeof args[0][0]) !== -1) {\n return [{type: 'layout', prop: '_currentFrame', value: args[0][0].toString()}];\n } else {\n return [];\n }\n}\n\nfunction computeLayoutBindings(gd, args) {\n var bindings = [];\n\n var astr = args[0];\n var aobj = {};\n if(typeof astr === 'string') {\n aobj[astr] = args[1];\n } else if(Lib.isPlainObject(astr)) {\n aobj = astr;\n } else {\n return bindings;\n }\n\n crawl(aobj, function(path, attrName, attr) {\n bindings.push({type: 'layout', prop: path, value: attr});\n }, '', 0);\n\n return bindings;\n}\n\nfunction computeDataBindings(gd, args) {\n var traces, astr, val, aobj;\n var bindings = [];\n\n // Logic copied from Plotly.restyle:\n astr = args[0];\n val = args[1];\n traces = args[2];\n aobj = {};\n if(typeof astr === 'string') {\n aobj[astr] = val;\n } else if(Lib.isPlainObject(astr)) {\n // the 3-arg form\n aobj = astr;\n\n if(traces === undefined) {\n traces = val;\n }\n } else {\n return bindings;\n }\n\n if(traces === undefined) {\n // Explicitly assign this to null instead of undefined:\n traces = null;\n }\n\n crawl(aobj, function(path, attrName, _attr) {\n var thisTraces;\n var attr;\n\n if(Array.isArray(_attr)) {\n attr = _attr.slice();\n\n var nAttr = Math.min(attr.length, gd.data.length);\n if(traces) {\n nAttr = Math.min(nAttr, traces.length);\n }\n thisTraces = [];\n for(var j = 0; j < nAttr; j++) {\n thisTraces[j] = traces ? traces[j] : j;\n }\n } else {\n attr = _attr;\n thisTraces = traces ? traces.slice() : null;\n }\n\n // Convert [7] to just 7 when traces is null:\n if(thisTraces === null) {\n if(Array.isArray(attr)) {\n attr = attr[0];\n }\n } else if(Array.isArray(thisTraces)) {\n if(!Array.isArray(attr)) {\n var tmp = attr;\n attr = [];\n for(var i = 0; i < thisTraces.length; i++) {\n attr[i] = tmp;\n }\n }\n attr.length = Math.min(thisTraces.length, attr.length);\n }\n\n bindings.push({\n type: 'data',\n prop: path,\n traces: thisTraces,\n value: attr\n });\n }, '', 0);\n\n return bindings;\n}\n\nfunction crawl(attrs, callback, path, depth) {\n Object.keys(attrs).forEach(function(attrName) {\n var attr = attrs[attrName];\n\n if(attrName[0] === '_') return;\n\n var thisPath = path + (depth > 0 ? '.' : '') + attrName;\n\n if(Lib.isPlainObject(attr)) {\n crawl(attr, callback, thisPath, depth + 1);\n } else {\n // Only execute the callback on leaf nodes:\n callback(thisPath, attrName, attr);\n }\n });\n}\n","'use strict';\n\nvar extendFlat = require('../lib/extend').extendFlat;\n\n/**\n * Make a xy domain attribute group\n *\n * @param {object} opts\n * @param {string}\n * opts.name: name to be inserted in the default description\n * @param {boolean}\n * opts.trace: set to true for trace containers\n * @param {string}\n * opts.editType: editType for all pieces\n * @param {boolean}\n * opts.noGridCell: set to true to omit `row` and `column`\n *\n * @param {object} extra\n * @param {string}\n * extra.description: extra description. N.B we use\n * a separate extra container to make it compatible with\n * the compress_attributes transform.\n *\n * @return {object} attributes object containing {x,y} as specified\n */\nexports.attributes = function(opts, extra) {\n opts = opts || {};\n extra = extra || {};\n\n var base = {\n valType: 'info_array',\n editType: opts.editType,\n items: [\n {valType: 'number', min: 0, max: 1, editType: opts.editType},\n {valType: 'number', min: 0, max: 1, editType: opts.editType}\n ],\n dflt: [0, 1]\n };\n\n var namePart = opts.name ? opts.name + ' ' : '';\n var contPart = opts.trace ? 'trace ' : 'subplot ';\n var descPart = extra.description ? ' ' + extra.description : '';\n\n var out = {\n x: extendFlat({}, base, {\n description: [\n 'Sets the horizontal domain of this ',\n namePart,\n contPart,\n '(in plot fraction).',\n descPart\n ].join('')\n }),\n y: extendFlat({}, base, {\n description: [\n 'Sets the vertical domain of this ',\n namePart,\n contPart,\n '(in plot fraction).',\n descPart\n ].join('')\n }),\n editType: opts.editType\n };\n\n if(!opts.noGridCell) {\n out.row = {\n valType: 'integer',\n min: 0,\n dflt: 0,\n editType: opts.editType,\n description: [\n 'If there is a layout grid, use the domain ',\n 'for this row in the grid for this ',\n namePart,\n contPart,\n '.',\n descPart\n ].join('')\n };\n out.column = {\n valType: 'integer',\n min: 0,\n dflt: 0,\n editType: opts.editType,\n description: [\n 'If there is a layout grid, use the domain ',\n 'for this column in the grid for this ',\n namePart,\n contPart,\n '.',\n descPart\n ].join('')\n };\n }\n\n return out;\n};\n\nexports.defaults = function(containerOut, layout, coerce, dfltDomains) {\n var dfltX = (dfltDomains && dfltDomains.x) || [0, 1];\n var dfltY = (dfltDomains && dfltDomains.y) || [0, 1];\n\n var grid = layout.grid;\n if(grid) {\n var column = coerce('domain.column');\n if(column !== undefined) {\n if(column < grid.columns) dfltX = grid._domains.x[column];\n else delete containerOut.domain.column;\n }\n\n var row = coerce('domain.row');\n if(row !== undefined) {\n if(row < grid.rows) dfltY = grid._domains.y[row];\n else delete containerOut.domain.row;\n }\n }\n\n var x = coerce('domain.x', dfltX);\n var y = coerce('domain.y', dfltY);\n\n // don't accept bad input data\n if(!(x[0] < x[1])) containerOut.domain.x = dfltX.slice();\n if(!(y[0] < y[1])) containerOut.domain.y = dfltY.slice();\n};\n","'use strict';\n\n/*\n * make a font attribute group\n *\n * @param {object} opts\n * @param {string}\n * opts.description: where & how this font is used\n * @param {optional bool} arrayOk:\n * should each part (family, size, color) be arrayOk? default false.\n * @param {string} editType:\n * the editType for all pieces of this font\n * @param {optional string} colorEditType:\n * a separate editType just for color\n *\n * @return {object} attributes object containing {family, size, color} as specified\n */\nmodule.exports = function(opts) {\n var variantValues = opts.variantValues;\n var editType = opts.editType;\n var colorEditType = opts.colorEditType;\n if(colorEditType === undefined) colorEditType = editType;\n\n var weight = {\n editType: editType,\n valType: 'integer',\n min: 1,\n max: 1000,\n extras: ['normal', 'bold'],\n dflt: 'normal',\n description: [\n 'Sets the weight (or boldness) of the font.'\n ].join(' ')\n };\n\n if(opts.noNumericWeightValues) {\n weight.valType = 'enumerated';\n weight.values = weight.extras;\n weight.extras = undefined;\n weight.min = undefined;\n weight.max = undefined;\n }\n\n var attrs = {\n family: {\n valType: 'string',\n noBlank: true,\n strict: true,\n editType: editType,\n description: [\n 'HTML font family - the typeface that will be applied by the web browser.',\n 'The web browser will only be able to apply a font if it is available on the system',\n 'which it operates. Provide multiple font families, separated by commas, to indicate',\n 'the preference in which to apply fonts if they aren\\'t available on the system.',\n 'The Chart Studio Cloud (at https://chart-studio.plotly.com or on-premise) generates images on a server,',\n 'where only a select number of',\n 'fonts are installed and supported.',\n 'These include *Arial*, *Balto*, *Courier New*, *Droid Sans*, *Droid Serif*,',\n '*Droid Sans Mono*, *Gravitas One*, *Old Standard TT*, *Open Sans*, *Overpass*,',\n '*PT Sans Narrow*, *Raleway*, *Times New Roman*.'\n ].join(' ')\n },\n size: {\n valType: 'number',\n min: 1,\n editType: editType\n },\n color: {\n valType: 'color',\n editType: colorEditType\n },\n\n weight: weight,\n\n style: {\n editType: editType,\n valType: 'enumerated',\n values: ['normal', 'italic'],\n dflt: 'normal',\n description: [\n 'Sets whether a font should be styled with a normal or italic face from its family.'\n ].join(' ')\n },\n\n variant: opts.noFontVariant ? undefined : {\n editType: editType,\n valType: 'enumerated',\n values: variantValues || [\n 'normal',\n 'small-caps',\n 'all-small-caps',\n 'all-petite-caps',\n 'petite-caps',\n 'unicase'\n ],\n dflt: 'normal',\n description: [\n 'Sets the variant of the font.'\n ].join(' ')\n },\n\n textcase: opts.noFontTextcase ? undefined : {\n editType: editType,\n valType: 'enumerated',\n values: ['normal', 'word caps', 'upper', 'lower'],\n dflt: 'normal',\n description: [\n 'Sets capitalization of text.',\n 'It can be used to make text appear in all-uppercase or all-lowercase,',\n 'or with each word capitalized.'\n ].join(' ')\n },\n\n lineposition: opts.noFontLineposition ? undefined : {\n editType: editType,\n valType: 'flaglist',\n flags: ['under', 'over', 'through'],\n extras: ['none'],\n dflt: 'none',\n description: [\n 'Sets the kind of decoration line(s) with text,',\n 'such as an *under*, *over* or *through*',\n 'as well as combinations e.g. *under+over*, etc.'\n ].join(' ')\n },\n\n shadow: opts.noFontShadow ? undefined : {\n editType: editType,\n valType: 'string',\n dflt: opts.autoShadowDflt ? 'auto' : 'none',\n description: [\n 'Sets the shape and color of the shadow behind text.',\n '*auto* places minimal shadow and applies contrast text font color.',\n 'See https://developer.mozilla.org/en-US/docs/Web/CSS/text-shadow for additional options.'\n ].join(' ')\n },\n\n editType: editType,\n // blank strings so compress_attributes can remove\n // TODO - that's uber hacky... better solution?\n description: '' + (opts.description || '') + ''\n };\n\n if(opts.autoSize) attrs.size.dflt = 'auto';\n if(opts.autoColor) attrs.color.dflt = 'auto';\n\n if(opts.arrayOk) {\n attrs.family.arrayOk = true;\n attrs.weight.arrayOk = true;\n attrs.style.arrayOk = true;\n if(!opts.noFontVariant) {\n attrs.variant.arrayOk = true;\n }\n if(!opts.noFontTextcase) {\n attrs.textcase.arrayOk = true;\n }\n if(!opts.noFontLineposition) {\n attrs.lineposition.arrayOk = true;\n }\n if(!opts.noFontShadow) {\n attrs.shadow.arrayOk = true;\n }\n attrs.size.arrayOk = true;\n attrs.color.arrayOk = true;\n }\n\n return attrs;\n};\n","'use strict';\n\nmodule.exports = {\n _isLinkedToArray: 'frames_entry',\n\n group: {\n valType: 'string',\n description: [\n 'An identifier that specifies the group to which the frame belongs,',\n 'used by animate to select a subset of frames.'\n ].join(' ')\n },\n name: {\n valType: 'string',\n description: 'A label by which to identify the frame'\n },\n traces: {\n valType: 'any',\n description: [\n 'A list of trace indices that identify the respective traces in the',\n 'data attribute'\n ].join(' ')\n },\n baseframe: {\n valType: 'string',\n description: [\n 'The name of the frame into which this frame\\'s properties are merged',\n 'before applying. This is used to unify properties and avoid needing',\n 'to specify the same values for the same properties in multiple frames.'\n ].join(' ')\n },\n data: {\n valType: 'any',\n description: [\n 'A list of traces this frame modifies. The format is identical to the',\n 'normal trace definition.'\n ].join(' ')\n },\n layout: {\n valType: 'any',\n description: [\n 'Layout properties which this frame modifies. The format is identical',\n 'to the normal layout definition.'\n ].join(' ')\n }\n};\n","'use strict';\n\n// projection names to d3 function name\nexports.projNames = {\n airy: 'airy',\n aitoff: 'aitoff',\n 'albers usa': 'albersUsa',\n albers: 'albers',\n // 'armadillo': 'armadillo',\n august: 'august',\n 'azimuthal equal area': 'azimuthalEqualArea',\n 'azimuthal equidistant': 'azimuthalEquidistant',\n baker: 'baker',\n // 'berghaus': 'berghaus',\n bertin1953: 'bertin1953',\n boggs: 'boggs',\n bonne: 'bonne',\n bottomley: 'bottomley',\n bromley: 'bromley',\n // 'chamberlin africa': 'chamberlinAfrica',\n // 'chamberlin': 'chamberlin',\n collignon: 'collignon',\n 'conic conformal': 'conicConformal',\n 'conic equal area': 'conicEqualArea',\n 'conic equidistant': 'conicEquidistant',\n craig: 'craig',\n craster: 'craster',\n 'cylindrical equal area': 'cylindricalEqualArea',\n 'cylindrical stereographic': 'cylindricalStereographic',\n eckert1: 'eckert1',\n eckert2: 'eckert2',\n eckert3: 'eckert3',\n eckert4: 'eckert4',\n eckert5: 'eckert5',\n eckert6: 'eckert6',\n eisenlohr: 'eisenlohr',\n 'equal earth': 'equalEarth',\n equirectangular: 'equirectangular',\n fahey: 'fahey',\n 'foucaut sinusoidal': 'foucautSinusoidal',\n foucaut: 'foucaut',\n // 'gilbert': 'gilbert',\n // 'gingery': 'gingery',\n ginzburg4: 'ginzburg4',\n ginzburg5: 'ginzburg5',\n ginzburg6: 'ginzburg6',\n ginzburg8: 'ginzburg8',\n ginzburg9: 'ginzburg9',\n gnomonic: 'gnomonic',\n 'gringorten quincuncial': 'gringortenQuincuncial',\n gringorten: 'gringorten',\n guyou: 'guyou',\n // 'hammer retroazimuthal': 'hammerRetroazimuthal',\n hammer: 'hammer',\n // 'healpix': 'healpix',\n hill: 'hill',\n homolosine: 'homolosine',\n hufnagel: 'hufnagel',\n hyperelliptical: 'hyperelliptical',\n // 'interrupted boggs': 'interruptedBoggs',\n // 'interrupted homolosine': 'interruptedHomolosine',\n // 'interrupted mollweide hemispheres': 'interruptedMollweideHemispheres',\n // 'interrupted mollweide': 'interruptedMollweide',\n // 'interrupted quartic authalic': 'interruptedQuarticAuthalic',\n // 'interrupted sinu mollweide': 'interruptedSinuMollweide',\n // 'interrupted sinusoidal': 'interruptedSinusoidal',\n kavrayskiy7: 'kavrayskiy7',\n lagrange: 'lagrange',\n larrivee: 'larrivee',\n laskowski: 'laskowski',\n // 'littrow': 'littrow',\n loximuthal: 'loximuthal',\n mercator: 'mercator',\n miller: 'miller',\n // 'modified stereographic alaska': 'modifiedStereographicAlaska',\n // 'modified stereographic gs48': 'modifiedStereographicGs48',\n // 'modified stereographic gs50': 'modifiedStereographicGs50',\n // 'modified stereographic lee': 'modifiedStereographicLee',\n // 'modified stereographic miller': 'modifiedStereographicMiller',\n // 'modified stereographic': 'modifiedStereographic',\n mollweide: 'mollweide',\n 'mt flat polar parabolic': 'mtFlatPolarParabolic',\n 'mt flat polar quartic': 'mtFlatPolarQuartic',\n 'mt flat polar sinusoidal': 'mtFlatPolarSinusoidal',\n 'natural earth': 'naturalEarth',\n 'natural earth1': 'naturalEarth1',\n 'natural earth2': 'naturalEarth2',\n 'nell hammer': 'nellHammer',\n nicolosi: 'nicolosi',\n orthographic: 'orthographic',\n patterson: 'patterson',\n 'peirce quincuncial': 'peirceQuincuncial',\n polyconic: 'polyconic',\n // 'polyhedral butterfly': 'polyhedralButterfly',\n // 'polyhedral collignon': 'polyhedralCollignon',\n // 'polyhedral waterman': 'polyhedralWaterman',\n 'rectangular polyconic': 'rectangularPolyconic',\n robinson: 'robinson',\n satellite: 'satellite',\n 'sinu mollweide': 'sinuMollweide',\n sinusoidal: 'sinusoidal',\n stereographic: 'stereographic',\n times: 'times',\n 'transverse mercator': 'transverseMercator',\n // 'two point azimuthalUsa': 'twoPointAzimuthalUsa',\n // 'two point azimuthal': 'twoPointAzimuthal',\n // 'two point equidistantUsa': 'twoPointEquidistantUsa',\n // 'two point equidistant': 'twoPointEquidistant',\n 'van der grinten': 'vanDerGrinten',\n 'van der grinten2': 'vanDerGrinten2',\n 'van der grinten3': 'vanDerGrinten3',\n 'van der grinten4': 'vanDerGrinten4',\n wagner4: 'wagner4',\n wagner6: 'wagner6',\n // 'wagner7': 'wagner7',\n // 'wagner': 'wagner',\n wiechel: 'wiechel',\n 'winkel tripel': 'winkel3',\n winkel3: 'winkel3',\n};\n\n// name of the axes\nexports.axesNames = ['lonaxis', 'lataxis'];\n\n// max longitudinal angular span (EXPERIMENTAL)\nexports.lonaxisSpan = {\n orthographic: 180,\n 'azimuthal equal area': 360,\n 'azimuthal equidistant': 360,\n 'conic conformal': 180,\n gnomonic: 160,\n stereographic: 180,\n 'transverse mercator': 180,\n '*': 360\n};\n\n// max latitudinal angular span (EXPERIMENTAL)\nexports.lataxisSpan = {\n 'conic conformal': 150,\n stereographic: 179.5,\n '*': 180\n};\n\n// defaults for each scope\nexports.scopeDefaults = {\n world: {\n lonaxisRange: [-180, 180],\n lataxisRange: [-90, 90],\n projType: 'equirectangular',\n projRotate: [0, 0, 0]\n },\n usa: {\n lonaxisRange: [-180, -50],\n lataxisRange: [15, 80],\n projType: 'albers usa'\n },\n europe: {\n lonaxisRange: [-30, 60],\n lataxisRange: [30, 85],\n projType: 'conic conformal',\n projRotate: [15, 0, 0],\n projParallels: [0, 60]\n },\n asia: {\n lonaxisRange: [22, 160],\n lataxisRange: [-15, 55],\n projType: 'mercator',\n projRotate: [0, 0, 0]\n },\n africa: {\n lonaxisRange: [-30, 60],\n lataxisRange: [-40, 40],\n projType: 'mercator',\n projRotate: [0, 0, 0]\n },\n 'north america': {\n lonaxisRange: [-180, -45],\n lataxisRange: [5, 85],\n projType: 'conic conformal',\n projRotate: [-100, 0, 0],\n projParallels: [29.5, 45.5]\n },\n 'south america': {\n lonaxisRange: [-100, -30],\n lataxisRange: [-60, 15],\n projType: 'mercator',\n projRotate: [0, 0, 0]\n }\n};\n\n// angular pad to avoid rounding error around clip angles\nexports.clipPad = 1e-3;\n\n// map projection precision\nexports.precision = 0.1;\n\n// default land and water fill colors\nexports.landColor = '#F0DC82';\nexports.waterColor = '#3399FF';\n\n// locationmode to layer name\nexports.locationmodeToLayer = {\n 'ISO-3': 'countries',\n 'USA-states': 'subunits',\n 'country names': 'countries'\n};\n\n// SVG element for a sphere (use to frame maps)\nexports.sphereSVG = {type: 'Sphere'};\n\n// N.B. base layer names must be the same as in the topojson files\n\n// base layer with a fill color\nexports.fillLayers = {\n ocean: 1,\n land: 1,\n lakes: 1\n};\n\n// base layer with a only a line color\nexports.lineLayers = {\n subunits: 1,\n countries: 1,\n coastlines: 1,\n rivers: 1,\n frame: 1\n};\n\nexports.layers = [\n 'bg',\n 'ocean', 'land', 'lakes',\n 'subunits', 'countries', 'coastlines', 'rivers',\n 'lataxis', 'lonaxis', 'frame',\n 'backplot',\n 'frontplot'\n];\n\nexports.layersForChoropleth = [\n 'bg',\n 'ocean', 'land',\n 'subunits', 'countries', 'coastlines',\n 'lataxis', 'lonaxis', 'frame',\n 'backplot',\n 'rivers', 'lakes',\n 'frontplot'\n];\n\nexports.layerNameToAdjective = {\n ocean: 'ocean',\n land: 'land',\n lakes: 'lake',\n subunits: 'subunit',\n countries: 'country',\n coastlines: 'coastline',\n rivers: 'river',\n frame: 'frame'\n};\n","'use strict';\n\n/* global PlotlyGeoAssets:false */\n\nvar d3 = require('@plotly/d3');\nvar geo = require('d3-geo');\nvar geoPath = geo.geoPath;\nvar geoDistance = geo.geoDistance;\nvar geoProjection = require('d3-geo-projection');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\nvar Fx = require('../../components/fx');\nvar Plots = require('../plots');\nvar Axes = require('../cartesian/axes');\nvar getAutoRange = require('../cartesian/autorange').getAutoRange;\nvar dragElement = require('../../components/dragelement');\nvar prepSelect = require('../../components/selections').prepSelect;\nvar clearOutline = require('../../components/selections').clearOutline;\nvar selectOnClick = require('../../components/selections').selectOnClick;\n\nvar createGeoZoom = require('./zoom');\nvar constants = require('./constants');\n\nvar geoUtils = require('../../lib/geo_location_utils');\nvar topojsonUtils = require('../../lib/topojson_utils');\nvar topojsonFeature = require('topojson-client').feature;\n\nfunction Geo(opts) {\n this.id = opts.id;\n this.graphDiv = opts.graphDiv;\n this.container = opts.container;\n this.topojsonURL = opts.topojsonURL;\n this.isStatic = opts.staticPlot;\n\n this.topojsonName = null;\n this.topojson = null;\n\n this.projection = null;\n this.scope = null;\n this.viewInitial = null;\n this.fitScale = null;\n this.bounds = null;\n this.midPt = null;\n\n this.hasChoropleth = false;\n this.traceHash = {};\n\n this.layers = {};\n this.basePaths = {};\n this.dataPaths = {};\n this.dataPoints = {};\n\n this.clipDef = null;\n this.clipRect = null;\n this.bgRect = null;\n\n this.makeFramework();\n}\n\nvar proto = Geo.prototype;\n\nmodule.exports = function createGeo(opts) {\n return new Geo(opts);\n};\n\nproto.plot = function(geoCalcData, fullLayout, promises, replot) {\n var _this = this;\n if(replot) return _this.update(geoCalcData, fullLayout, true);\n\n _this._geoCalcData = geoCalcData;\n _this._fullLayout = fullLayout;\n\n var geoLayout = fullLayout[this.id];\n var geoPromises = [];\n\n var needsTopojson = false;\n for(var k in constants.layerNameToAdjective) {\n if(k !== 'frame' && geoLayout['show' + k]) {\n needsTopojson = true;\n break;\n }\n }\n\n var hasMarkerAngles = false;\n for(var i = 0; i < geoCalcData.length; i++) {\n var trace = geoCalcData[0][0].trace;\n trace._geo = _this;\n\n if(trace.locationmode) {\n needsTopojson = true;\n }\n\n var marker = trace.marker;\n if(marker) {\n var angle = marker.angle;\n var angleref = marker.angleref;\n if(angle || angleref === 'north' || angleref === 'previous') hasMarkerAngles = true;\n }\n }\n this._hasMarkerAngles = hasMarkerAngles;\n\n if(needsTopojson) {\n var topojsonNameNew = topojsonUtils.getTopojsonName(geoLayout);\n if(_this.topojson === null || topojsonNameNew !== _this.topojsonName) {\n _this.topojsonName = topojsonNameNew;\n\n if(PlotlyGeoAssets.topojson[_this.topojsonName] === undefined) {\n geoPromises.push(_this.fetchTopojson());\n }\n }\n }\n\n geoPromises = geoPromises.concat(geoUtils.fetchTraceGeoData(geoCalcData));\n\n promises.push(new Promise(function(resolve, reject) {\n Promise.all(geoPromises).then(function() {\n _this.topojson = PlotlyGeoAssets.topojson[_this.topojsonName];\n _this.update(geoCalcData, fullLayout);\n resolve();\n })\n .catch(reject);\n }));\n};\n\nproto.fetchTopojson = function() {\n var _this = this;\n var topojsonPath = topojsonUtils.getTopojsonPath(_this.topojsonURL, _this.topojsonName);\n\n return new Promise(function(resolve, reject) {\n d3.json(topojsonPath, function(err, topojson) {\n if(err) {\n if(err.status === 404) {\n return reject(new Error([\n 'plotly.js could not find topojson file at',\n topojsonPath + '.',\n 'Make sure the *topojsonURL* plot config option',\n 'is set properly.'\n ].join(' ')));\n } else {\n return reject(new Error([\n 'unexpected error while fetching topojson file at',\n topojsonPath\n ].join(' ')));\n }\n }\n\n PlotlyGeoAssets.topojson[_this.topojsonName] = topojson;\n resolve();\n });\n });\n};\n\nproto.update = function(geoCalcData, fullLayout, replot) {\n var geoLayout = fullLayout[this.id];\n\n // important: maps with choropleth traces have a different layer order\n this.hasChoropleth = false;\n\n for(var i = 0; i < geoCalcData.length; i++) {\n var calcTrace = geoCalcData[i];\n var trace = calcTrace[0].trace;\n\n if(trace.type === 'choropleth') {\n this.hasChoropleth = true;\n }\n if(trace.visible === true && trace._length > 0) {\n trace._module.calcGeoJSON(calcTrace, fullLayout);\n }\n }\n\n if(!replot) {\n var hasInvalidBounds = this.updateProjection(geoCalcData, fullLayout);\n if(hasInvalidBounds) return;\n\n if(!this.viewInitial || this.scope !== geoLayout.scope) {\n this.saveViewInitial(geoLayout);\n }\n }\n this.scope = geoLayout.scope;\n\n this.updateBaseLayers(fullLayout, geoLayout);\n this.updateDims(fullLayout, geoLayout);\n this.updateFx(fullLayout, geoLayout);\n\n Plots.generalUpdatePerTraceModule(this.graphDiv, this, geoCalcData, geoLayout);\n\n var scatterLayer = this.layers.frontplot.select('.scatterlayer');\n this.dataPoints.point = scatterLayer.selectAll('.point');\n this.dataPoints.text = scatterLayer.selectAll('text');\n this.dataPaths.line = scatterLayer.selectAll('.js-line');\n\n var choroplethLayer = this.layers.backplot.select('.choroplethlayer');\n this.dataPaths.choropleth = choroplethLayer.selectAll('path');\n\n this._render();\n};\n\nproto.updateProjection = function(geoCalcData, fullLayout) {\n var gd = this.graphDiv;\n var geoLayout = fullLayout[this.id];\n var gs = fullLayout._size;\n var domain = geoLayout.domain;\n var projLayout = geoLayout.projection;\n\n var lonaxis = geoLayout.lonaxis;\n var lataxis = geoLayout.lataxis;\n var axLon = lonaxis._ax;\n var axLat = lataxis._ax;\n\n var projection = this.projection = getProjection(geoLayout);\n\n // setup subplot extent [[x0,y0], [x1,y1]]\n var extent = [[\n gs.l + gs.w * domain.x[0],\n gs.t + gs.h * (1 - domain.y[1])\n ], [\n gs.l + gs.w * domain.x[1],\n gs.t + gs.h * (1 - domain.y[0])\n ]];\n\n var center = geoLayout.center || {};\n var rotation = projLayout.rotation || {};\n var lonaxisRange = lonaxis.range || [];\n var lataxisRange = lataxis.range || [];\n\n if(geoLayout.fitbounds) {\n axLon._length = extent[1][0] - extent[0][0];\n axLat._length = extent[1][1] - extent[0][1];\n axLon.range = getAutoRange(gd, axLon);\n axLat.range = getAutoRange(gd, axLat);\n\n var midLon = (axLon.range[0] + axLon.range[1]) / 2;\n var midLat = (axLat.range[0] + axLat.range[1]) / 2;\n\n if(geoLayout._isScoped) {\n center = {lon: midLon, lat: midLat};\n } else if(geoLayout._isClipped) {\n center = {lon: midLon, lat: midLat};\n rotation = {lon: midLon, lat: midLat, roll: rotation.roll};\n\n var projType = projLayout.type;\n var lonHalfSpan = (constants.lonaxisSpan[projType] / 2) || 180;\n var latHalfSpan = (constants.lataxisSpan[projType] / 2) || 90;\n\n lonaxisRange = [midLon - lonHalfSpan, midLon + lonHalfSpan];\n lataxisRange = [midLat - latHalfSpan, midLat + latHalfSpan];\n } else {\n center = {lon: midLon, lat: midLat};\n rotation = {lon: midLon, lat: rotation.lat, roll: rotation.roll};\n }\n }\n\n // set 'pre-fit' projection\n projection\n .center([center.lon - rotation.lon, center.lat - rotation.lat])\n .rotate([-rotation.lon, -rotation.lat, rotation.roll])\n .parallels(projLayout.parallels);\n\n // fit projection 'scale' and 'translate' to set lon/lat ranges\n var rangeBox = makeRangeBox(lonaxisRange, lataxisRange);\n projection.fitExtent(extent, rangeBox);\n\n var b = this.bounds = projection.getBounds(rangeBox);\n var s = this.fitScale = projection.scale();\n var t = projection.translate();\n\n if(geoLayout.fitbounds) {\n var b2 = projection.getBounds(makeRangeBox(axLon.range, axLat.range));\n var k2 = Math.min(\n (b[1][0] - b[0][0]) / (b2[1][0] - b2[0][0]),\n (b[1][1] - b[0][1]) / (b2[1][1] - b2[0][1])\n );\n\n if(isFinite(k2)) {\n projection.scale(k2 * s);\n } else {\n Lib.warn('Something went wrong during' + this.id + 'fitbounds computations.');\n }\n } else {\n // adjust projection to user setting\n projection.scale(projLayout.scale * s);\n }\n\n // px coordinates of view mid-point,\n // useful to update `geo.center` after interactions\n var midPt = this.midPt = [\n (b[0][0] + b[1][0]) / 2,\n (b[0][1] + b[1][1]) / 2\n ];\n\n projection\n .translate([t[0] + (midPt[0] - t[0]), t[1] + (midPt[1] - t[1])])\n .clipExtent(b);\n\n // the 'albers usa' projection does not expose a 'center' method\n // so here's this hack to make it respond to 'geoLayout.center'\n if(geoLayout._isAlbersUsa) {\n var centerPx = projection([center.lon, center.lat]);\n var tt = projection.translate();\n\n projection.translate([\n tt[0] - (centerPx[0] - tt[0]),\n tt[1] - (centerPx[1] - tt[1])\n ]);\n }\n};\n\nproto.updateBaseLayers = function(fullLayout, geoLayout) {\n var _this = this;\n var topojson = _this.topojson;\n var layers = _this.layers;\n var basePaths = _this.basePaths;\n\n function isAxisLayer(d) {\n return (d === 'lonaxis' || d === 'lataxis');\n }\n\n function isLineLayer(d) {\n return Boolean(constants.lineLayers[d]);\n }\n\n function isFillLayer(d) {\n return Boolean(constants.fillLayers[d]);\n }\n\n var allLayers = this.hasChoropleth ?\n constants.layersForChoropleth :\n constants.layers;\n\n var layerData = allLayers.filter(function(d) {\n return (isLineLayer(d) || isFillLayer(d)) ? geoLayout['show' + d] :\n isAxisLayer(d) ? geoLayout[d].showgrid :\n true;\n });\n\n var join = _this.framework.selectAll('.layer')\n .data(layerData, String);\n\n join.exit().each(function(d) {\n delete layers[d];\n delete basePaths[d];\n d3.select(this).remove();\n });\n\n join.enter().append('g')\n .attr('class', function(d) { return 'layer ' + d; })\n .each(function(d) {\n var layer = layers[d] = d3.select(this);\n\n if(d === 'bg') {\n _this.bgRect = layer.append('rect')\n .style('pointer-events', 'all');\n } else if(isAxisLayer(d)) {\n basePaths[d] = layer.append('path')\n .style('fill', 'none');\n } else if(d === 'backplot') {\n layer.append('g')\n .classed('choroplethlayer', true);\n } else if(d === 'frontplot') {\n layer.append('g')\n .classed('scatterlayer', true);\n } else if(isLineLayer(d)) {\n basePaths[d] = layer.append('path')\n .style('fill', 'none')\n .style('stroke-miterlimit', 2);\n } else if(isFillLayer(d)) {\n basePaths[d] = layer.append('path')\n .style('stroke', 'none');\n }\n });\n\n join.order();\n\n join.each(function(d) {\n var path = basePaths[d];\n var adj = constants.layerNameToAdjective[d];\n\n if(d === 'frame') {\n path.datum(constants.sphereSVG);\n } else if(isLineLayer(d) || isFillLayer(d)) {\n path.datum(topojsonFeature(topojson, topojson.objects[d]));\n } else if(isAxisLayer(d)) {\n path.datum(makeGraticule(d, geoLayout, fullLayout))\n .call(Color.stroke, geoLayout[d].gridcolor)\n .call(Drawing.dashLine, geoLayout[d].griddash, geoLayout[d].gridwidth);\n }\n\n if(isLineLayer(d)) {\n path.call(Color.stroke, geoLayout[adj + 'color'])\n .call(Drawing.dashLine, '', geoLayout[adj + 'width']);\n } else if(isFillLayer(d)) {\n path.call(Color.fill, geoLayout[adj + 'color']);\n }\n });\n};\n\nproto.updateDims = function(fullLayout, geoLayout) {\n var b = this.bounds;\n var hFrameWidth = (geoLayout.framewidth || 0) / 2;\n\n var l = b[0][0] - hFrameWidth;\n var t = b[0][1] - hFrameWidth;\n var w = b[1][0] - l + hFrameWidth;\n var h = b[1][1] - t + hFrameWidth;\n\n Drawing.setRect(this.clipRect, l, t, w, h);\n\n this.bgRect\n .call(Drawing.setRect, l, t, w, h)\n .call(Color.fill, geoLayout.bgcolor);\n\n this.xaxis._offset = l;\n this.xaxis._length = w;\n\n this.yaxis._offset = t;\n this.yaxis._length = h;\n};\n\nproto.updateFx = function(fullLayout, geoLayout) {\n var _this = this;\n var gd = _this.graphDiv;\n var bgRect = _this.bgRect;\n var dragMode = fullLayout.dragmode;\n var clickMode = fullLayout.clickmode;\n\n if(_this.isStatic) return;\n\n function zoomReset() {\n var viewInitial = _this.viewInitial;\n var updateObj = {};\n\n for(var k in viewInitial) {\n updateObj[_this.id + '.' + k] = viewInitial[k];\n }\n\n Registry.call('_guiRelayout', gd, updateObj);\n gd.emit('plotly_doubleclick', null);\n }\n\n function invert(lonlat) {\n return _this.projection.invert([\n lonlat[0] + _this.xaxis._offset,\n lonlat[1] + _this.yaxis._offset\n ]);\n }\n\n var fillRangeItems = function(eventData, poly) {\n if(poly.isRect) {\n var ranges = eventData.range = {};\n ranges[_this.id] = [\n invert([poly.xmin, poly.ymin]),\n invert([poly.xmax, poly.ymax])\n ];\n } else {\n var dataPts = eventData.lassoPoints = {};\n dataPts[_this.id] = poly.map(invert);\n }\n };\n\n // Note: dragOptions is needed to be declared for all dragmodes because\n // it's the object that holds persistent selection state.\n var dragOptions = {\n element: _this.bgRect.node(),\n gd: gd,\n plotinfo: {\n id: _this.id,\n xaxis: _this.xaxis,\n yaxis: _this.yaxis,\n fillRangeItems: fillRangeItems\n },\n xaxes: [_this.xaxis],\n yaxes: [_this.yaxis],\n subplot: _this.id,\n clickFn: function(numClicks) {\n if(numClicks === 2) {\n clearOutline(gd);\n }\n }\n };\n\n if(dragMode === 'pan') {\n bgRect.node().onmousedown = null;\n bgRect.call(createGeoZoom(_this, geoLayout));\n bgRect.on('dblclick.zoom', zoomReset);\n if(!gd._context._scrollZoom.geo) {\n bgRect.on('wheel.zoom', null);\n }\n } else if(dragMode === 'select' || dragMode === 'lasso') {\n bgRect.on('.zoom', null);\n\n dragOptions.prepFn = function(e, startX, startY) {\n prepSelect(e, startX, startY, dragOptions, dragMode);\n };\n\n dragElement.init(dragOptions);\n }\n\n bgRect.on('mousemove', function() {\n var lonlat = _this.projection.invert(Lib.getPositionFromD3Event());\n\n if(!lonlat) {\n return dragElement.unhover(gd, d3.event);\n }\n\n _this.xaxis.p2c = function() { return lonlat[0]; };\n _this.yaxis.p2c = function() { return lonlat[1]; };\n\n Fx.hover(gd, d3.event, _this.id);\n });\n\n bgRect.on('mouseout', function() {\n if(gd._dragging) return;\n dragElement.unhover(gd, d3.event);\n });\n\n bgRect.on('click', function() {\n // For select and lasso the dragElement is handling clicks\n if(dragMode !== 'select' && dragMode !== 'lasso') {\n if(clickMode.indexOf('select') > -1) {\n selectOnClick(d3.event, gd, [_this.xaxis], [_this.yaxis],\n _this.id, dragOptions);\n }\n\n if(clickMode.indexOf('event') > -1) {\n // TODO: like pie and maps, this doesn't support right-click\n // actually this one is worse, as right-click starts a pan, or leaves\n // select in a weird state.\n // Also, only tangentially related, we should cancel hover during pan\n Fx.click(gd, d3.event);\n }\n }\n });\n};\n\nproto.makeFramework = function() {\n var _this = this;\n var gd = _this.graphDiv;\n var fullLayout = gd._fullLayout;\n var clipId = 'clip' + fullLayout._uid + _this.id;\n\n _this.clipDef = fullLayout._clips.append('clipPath')\n .attr('id', clipId);\n\n _this.clipRect = _this.clipDef.append('rect');\n\n _this.framework = d3.select(_this.container).append('g')\n .attr('class', 'geo ' + _this.id)\n .call(Drawing.setClipUrl, clipId, gd);\n\n // sane lonlat to px\n _this.project = function(v) {\n var px = _this.projection(v);\n return px ?\n [px[0] - _this.xaxis._offset, px[1] - _this.yaxis._offset] :\n [null, null];\n };\n\n _this.xaxis = {\n _id: 'x',\n c2p: function(v) { return _this.project(v)[0]; }\n };\n\n _this.yaxis = {\n _id: 'y',\n c2p: function(v) { return _this.project(v)[1]; }\n };\n\n // mock axis for hover formatting\n _this.mockAxis = {\n type: 'linear',\n showexponent: 'all',\n exponentformat: 'B'\n };\n Axes.setConvert(_this.mockAxis, fullLayout);\n};\n\nproto.saveViewInitial = function(geoLayout) {\n var center = geoLayout.center || {};\n var projLayout = geoLayout.projection;\n var rotation = projLayout.rotation || {};\n\n this.viewInitial = {\n fitbounds: geoLayout.fitbounds,\n 'projection.scale': projLayout.scale\n };\n\n var extra;\n if(geoLayout._isScoped) {\n extra = {\n 'center.lon': center.lon,\n 'center.lat': center.lat,\n };\n } else if(geoLayout._isClipped) {\n extra = {\n 'projection.rotation.lon': rotation.lon,\n 'projection.rotation.lat': rotation.lat\n };\n } else {\n extra = {\n 'center.lon': center.lon,\n 'center.lat': center.lat,\n 'projection.rotation.lon': rotation.lon\n };\n }\n\n Lib.extendFlat(this.viewInitial, extra);\n};\n\nproto.render = function(mayRedrawOnUpdates) {\n if(this._hasMarkerAngles && mayRedrawOnUpdates) {\n this.plot(this._geoCalcData, this._fullLayout, [], true);\n } else {\n this._render();\n }\n};\n\n// [hot code path] (re)draw all paths which depend on the projection\nproto._render = function() {\n var projection = this.projection;\n var pathFn = projection.getPath();\n var k;\n\n function translatePoints(d) {\n var lonlatPx = projection(d.lonlat);\n return lonlatPx ?\n strTranslate(lonlatPx[0], lonlatPx[1]) :\n null;\n }\n\n function hideShowPoints(d) {\n return projection.isLonLatOverEdges(d.lonlat) ? 'none' : null;\n }\n\n for(k in this.basePaths) {\n this.basePaths[k].attr('d', pathFn);\n }\n\n for(k in this.dataPaths) {\n this.dataPaths[k].attr('d', function(d) { return pathFn(d.geojson); });\n }\n\n for(k in this.dataPoints) {\n this.dataPoints[k]\n .attr('display', hideShowPoints)\n .attr('transform', translatePoints); // TODO: need to redraw points with marker angle instead of calling translatePoints\n }\n};\n\n// Helper that wraps d3[geo + /* Projection name /*]() which:\n//\n// - adds 'getPath', 'getBounds' convenience methods\n// - scopes logic related to 'clipAngle'\n// - adds 'isLonLatOverEdges' method\n// - sets projection precision\n// - sets methods that aren't always defined depending\n// on the projection type to a dummy 'd3-esque' function,\n//\n// This wrapper alleviates subsequent code of (many) annoying if-statements.\nfunction getProjection(geoLayout) {\n var projLayout = geoLayout.projection;\n var projType = projLayout.type;\n\n var projName = constants.projNames[projType];\n // uppercase the first letter and add geo to the start of method name\n projName = 'geo' + Lib.titleCase(projName);\n var projFn = geo[projName] || geoProjection[projName];\n var projection = projFn();\n\n var clipAngle =\n geoLayout._isSatellite ? Math.acos(1 / projLayout.distance) * 180 / Math.PI :\n geoLayout._isClipped ? constants.lonaxisSpan[projType] / 2 : null;\n\n var methods = ['center', 'rotate', 'parallels', 'clipExtent'];\n var dummyFn = function(_) { return _ ? projection : []; };\n\n for(var i = 0; i < methods.length; i++) {\n var m = methods[i];\n if(typeof projection[m] !== 'function') {\n projection[m] = dummyFn;\n }\n }\n\n projection.isLonLatOverEdges = function(lonlat) {\n if(projection(lonlat) === null) {\n return true;\n }\n\n if(clipAngle) {\n var r = projection.rotate();\n var angle = geoDistance(lonlat, [-r[0], -r[1]]);\n var maxAngle = clipAngle * Math.PI / 180;\n return angle > maxAngle;\n } else {\n return false;\n }\n };\n\n projection.getPath = function() {\n return geoPath().projection(projection);\n };\n\n projection.getBounds = function(object) {\n return projection.getPath().bounds(object);\n };\n\n projection.precision(constants.precision);\n\n if(geoLayout._isSatellite) {\n projection.tilt(projLayout.tilt).distance(projLayout.distance);\n }\n\n if(clipAngle) {\n projection.clipAngle(clipAngle - constants.clipPad);\n }\n\n return projection;\n}\n\nfunction makeGraticule(axisName, geoLayout, fullLayout) {\n // equivalent to the d3 \"ε\"\n var epsilon = 1e-6;\n // same as the geoGraticule default\n var precision = 2.5;\n\n var axLayout = geoLayout[axisName];\n var scopeDefaults = constants.scopeDefaults[geoLayout.scope];\n var rng;\n var oppRng;\n var coordFn;\n\n if(axisName === 'lonaxis') {\n rng = scopeDefaults.lonaxisRange;\n oppRng = scopeDefaults.lataxisRange;\n coordFn = function(v, l) { return [v, l]; };\n } else if(axisName === 'lataxis') {\n rng = scopeDefaults.lataxisRange;\n oppRng = scopeDefaults.lonaxisRange;\n coordFn = function(v, l) { return [l, v]; };\n }\n\n var dummyAx = {\n type: 'linear',\n range: [rng[0], rng[1] - epsilon],\n tick0: axLayout.tick0,\n dtick: axLayout.dtick\n };\n\n Axes.setConvert(dummyAx, fullLayout);\n var vals = Axes.calcTicks(dummyAx);\n\n // remove duplicate on antimeridian\n if(!geoLayout.isScoped && axisName === 'lonaxis') {\n vals.pop();\n }\n\n var len = vals.length;\n var coords = new Array(len);\n\n for(var i = 0; i < len; i++) {\n var v = vals[i].x;\n var line = coords[i] = [];\n for(var l = oppRng[0]; l < oppRng[1] + precision; l += precision) {\n line.push(coordFn(v, l));\n }\n }\n\n return {\n type: 'MultiLineString',\n coordinates: coords\n };\n}\n\n// Returns polygon GeoJSON corresponding to lon/lat range box\n// with well-defined direction\n//\n// Note that clipPad padding is added around range to avoid aliasing.\nfunction makeRangeBox(lon, lat) {\n var clipPad = constants.clipPad;\n var lon0 = lon[0] + clipPad;\n var lon1 = lon[1] - clipPad;\n var lat0 = lat[0] + clipPad;\n var lat1 = lat[1] - clipPad;\n\n // to cross antimeridian w/o ambiguity\n if(lon0 > 0 && lon1 < 0) lon1 += 360;\n\n var dlon4 = (lon1 - lon0) / 4;\n\n return {\n type: 'Polygon',\n coordinates: [[\n [lon0, lat0],\n [lon0, lat1],\n [lon0 + dlon4, lat1],\n [lon0 + 2 * dlon4, lat1],\n [lon0 + 3 * dlon4, lat1],\n [lon1, lat1],\n [lon1, lat0],\n [lon1 - dlon4, lat0],\n [lon1 - 2 * dlon4, lat0],\n [lon1 - 3 * dlon4, lat0],\n [lon0, lat0]\n ]]\n };\n}\n","'use strict';\n\nvar getSubplotCalcData = require('../../plots/get_data').getSubplotCalcData;\nvar counterRegex = require('../../lib').counterRegex;\n\nvar createGeo = require('./geo');\n\nvar GEO = 'geo';\nvar counter = counterRegex(GEO);\n\nvar attributes = {};\nattributes[GEO] = {\n valType: 'subplotid',\n dflt: GEO,\n editType: 'calc',\n description: [\n 'Sets a reference between this trace\\'s geospatial coordinates and',\n 'a geographic map.',\n 'If *geo* (the default value), the geospatial coordinates refer to',\n '`layout.geo`.',\n 'If *geo2*, the geospatial coordinates refer to `layout.geo2`,',\n 'and so on.'\n ].join(' ')\n};\n\nfunction plotGeo(gd) {\n var fullLayout = gd._fullLayout;\n var calcData = gd.calcdata;\n var geoIds = fullLayout._subplots[GEO];\n\n for(var i = 0; i < geoIds.length; i++) {\n var geoId = geoIds[i];\n var geoCalcData = getSubplotCalcData(calcData, GEO, geoId);\n var geoLayout = fullLayout[geoId];\n var geo = geoLayout._subplot;\n\n if(!geo) {\n geo = createGeo({\n id: geoId,\n graphDiv: gd,\n container: fullLayout._geolayer.node(),\n topojsonURL: gd._context.topojsonURL,\n staticPlot: gd._context.staticPlot\n });\n\n fullLayout[geoId]._subplot = geo;\n }\n\n geo.plot(geoCalcData, fullLayout, gd._promises);\n }\n}\n\nfunction clean(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var oldGeoKeys = oldFullLayout._subplots[GEO] || [];\n\n for(var i = 0; i < oldGeoKeys.length; i++) {\n var oldGeoKey = oldGeoKeys[i];\n var oldGeo = oldFullLayout[oldGeoKey]._subplot;\n\n if(!newFullLayout[oldGeoKey] && !!oldGeo) {\n oldGeo.framework.remove();\n oldGeo.clipDef.remove();\n }\n }\n}\n\nfunction updateFx(gd) {\n var fullLayout = gd._fullLayout;\n var subplotIds = fullLayout._subplots[GEO];\n\n for(var i = 0; i < subplotIds.length; i++) {\n var subplotLayout = fullLayout[subplotIds[i]];\n var subplotObj = subplotLayout._subplot;\n subplotObj.updateFx(fullLayout, subplotLayout);\n }\n}\n\nmodule.exports = {\n attr: GEO,\n name: GEO,\n idRoot: GEO,\n idRegex: counter,\n attrRegex: counter,\n attributes: attributes,\n layoutAttributes: require('./layout_attributes'),\n supplyLayoutDefaults: require('./layout_defaults'),\n plot: plotGeo,\n updateFx: updateFx,\n clean: clean\n};\n","'use strict';\n\nvar colorAttrs = require('../../components/color/attributes');\nvar domainAttrs = require('../domain').attributes;\nvar dash = require('../../components/drawing/attributes').dash;\nvar constants = require('./constants');\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar sortObjectKeys = require('../../lib/sort_object_keys');\n\nvar geoAxesAttrs = {\n range: {\n valType: 'info_array',\n items: [\n {valType: 'number'},\n {valType: 'number'}\n ],\n description: [\n 'Sets the range of this axis (in degrees),',\n 'sets the map\\'s clipped coordinates.'\n ].join(' ')\n },\n showgrid: {\n valType: 'boolean',\n dflt: false,\n description: 'Sets whether or not graticule are shown on the map.'\n },\n tick0: {\n valType: 'number',\n dflt: 0,\n description: [\n 'Sets the graticule\\'s starting tick longitude/latitude.'\n ].join(' ')\n },\n dtick: {\n valType: 'number',\n description: [\n 'Sets the graticule\\'s longitude/latitude tick step.'\n ].join(' ')\n },\n gridcolor: {\n valType: 'color',\n dflt: colorAttrs.lightLine,\n description: [\n 'Sets the graticule\\'s stroke color.'\n ].join(' ')\n },\n gridwidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n description: [\n 'Sets the graticule\\'s stroke width (in px).'\n ].join(' ')\n },\n griddash: dash\n};\n\nvar attrs = module.exports = overrideAll({\n domain: domainAttrs({name: 'geo'}, {\n description: [\n 'Note that geo subplots are constrained by domain.',\n 'In general, when `projection.scale` is set to 1.',\n 'a map will fit either its x or y domain, but not both.'\n ].join(' ')\n }),\n\n fitbounds: {\n valType: 'enumerated',\n values: [false, 'locations', 'geojson'],\n dflt: false,\n editType: 'plot',\n description: [\n 'Determines if this subplot\\'s view settings are auto-computed to fit trace data.',\n\n 'On scoped maps, setting `fitbounds` leads to `center.lon` and `center.lat` getting auto-filled.',\n\n 'On maps with a non-clipped projection, setting `fitbounds` leads to `center.lon`, `center.lat`,',\n 'and `projection.rotation.lon` getting auto-filled.',\n\n 'On maps with a clipped projection, setting `fitbounds` leads to `center.lon`, `center.lat`,',\n '`projection.rotation.lon`, `projection.rotation.lat`, `lonaxis.range` and `lonaxis.range`',\n 'getting auto-filled.',\n\n // TODO we should auto-fill `projection.parallels` for maps\n // with conic projection, but how?\n\n 'If *locations*, only the trace\\'s visible locations are considered in the `fitbounds` computations.',\n 'If *geojson*, the entire trace input `geojson` (if provided) is considered in the `fitbounds` computations,',\n 'Defaults to *false*.'\n ].join(' ')\n },\n\n resolution: {\n valType: 'enumerated',\n values: [110, 50],\n dflt: 110,\n coerceNumber: true,\n description: [\n 'Sets the resolution of the base layers.',\n 'The values have units of km/mm',\n 'e.g. 110 corresponds to a scale ratio of 1:110,000,000.'\n ].join(' ')\n },\n scope: {\n valType: 'enumerated',\n values: sortObjectKeys(constants.scopeDefaults),\n dflt: 'world',\n description: 'Set the scope of the map.'\n },\n projection: {\n type: {\n valType: 'enumerated',\n values: sortObjectKeys(constants.projNames),\n description: 'Sets the projection type.'\n },\n rotation: {\n lon: {\n valType: 'number',\n description: [\n 'Rotates the map along parallels',\n '(in degrees East).',\n 'Defaults to the center of the `lonaxis.range` values.'\n ].join(' ')\n },\n lat: {\n valType: 'number',\n description: [\n 'Rotates the map along meridians',\n '(in degrees North).'\n ].join(' ')\n },\n roll: {\n valType: 'number',\n description: [\n 'Roll the map (in degrees)',\n 'For example, a roll of *180* makes the map appear upside down.'\n ].join(' ')\n }\n },\n tilt: {\n valType: 'number',\n dflt: 0,\n description: [\n 'For satellite projection type only.',\n 'Sets the tilt angle of perspective projection.'\n ].join(' ')\n },\n distance: {\n valType: 'number',\n min: 1.001,\n dflt: 2,\n description: [\n 'For satellite projection type only.',\n 'Sets the distance from the center of the sphere to the point of view',\n 'as a proportion of the sphere’s radius.'\n ].join(' ')\n },\n parallels: {\n valType: 'info_array',\n items: [\n {valType: 'number'},\n {valType: 'number'}\n ],\n description: [\n 'For conic projection types only.',\n 'Sets the parallels (tangent, secant)',\n 'where the cone intersects the sphere.'\n ].join(' ')\n },\n scale: {\n valType: 'number',\n min: 0,\n dflt: 1,\n description: [\n 'Zooms in or out on the map view.',\n 'A scale of *1* corresponds to the largest zoom level',\n 'that fits the map\\'s lon and lat ranges. '\n ].join(' ')\n },\n },\n center: {\n lon: {\n valType: 'number',\n description: [\n 'Sets the longitude of the map\\'s center.',\n 'By default, the map\\'s longitude center lies at the middle of the longitude range',\n 'for scoped projection and above `projection.rotation.lon` otherwise.'\n ].join(' ')\n },\n lat: {\n valType: 'number',\n description: [\n 'Sets the latitude of the map\\'s center.',\n 'For all projection types, the map\\'s latitude center lies',\n 'at the middle of the latitude range by default.'\n ].join(' ')\n }\n },\n visible: {\n valType: 'boolean',\n dflt: true,\n description: 'Sets the default visibility of the base layers.'\n },\n showcoastlines: {\n valType: 'boolean',\n description: 'Sets whether or not the coastlines are drawn.'\n },\n coastlinecolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n description: 'Sets the coastline color.'\n },\n coastlinewidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n description: 'Sets the coastline stroke width (in px).'\n },\n showland: {\n valType: 'boolean',\n dflt: false,\n description: 'Sets whether or not land masses are filled in color.'\n },\n landcolor: {\n valType: 'color',\n dflt: constants.landColor,\n description: 'Sets the land mass color.'\n },\n showocean: {\n valType: 'boolean',\n dflt: false,\n description: 'Sets whether or not oceans are filled in color.'\n },\n oceancolor: {\n valType: 'color',\n dflt: constants.waterColor,\n description: 'Sets the ocean color'\n },\n showlakes: {\n valType: 'boolean',\n dflt: false,\n description: 'Sets whether or not lakes are drawn.'\n },\n lakecolor: {\n valType: 'color',\n dflt: constants.waterColor,\n description: 'Sets the color of the lakes.'\n },\n showrivers: {\n valType: 'boolean',\n dflt: false,\n description: 'Sets whether or not rivers are drawn.'\n },\n rivercolor: {\n valType: 'color',\n dflt: constants.waterColor,\n description: 'Sets color of the rivers.'\n },\n riverwidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n description: 'Sets the stroke width (in px) of the rivers.'\n },\n showcountries: {\n valType: 'boolean',\n description: 'Sets whether or not country boundaries are drawn.'\n },\n countrycolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n description: 'Sets line color of the country boundaries.'\n },\n countrywidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n description: 'Sets line width (in px) of the country boundaries.'\n },\n showsubunits: {\n valType: 'boolean',\n description: [\n 'Sets whether or not boundaries of subunits within countries',\n '(e.g. states, provinces) are drawn.'\n ].join(' ')\n },\n subunitcolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n description: 'Sets the color of the subunits boundaries.'\n },\n subunitwidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n description: 'Sets the stroke width (in px) of the subunits boundaries.'\n },\n showframe: {\n valType: 'boolean',\n description: 'Sets whether or not a frame is drawn around the map.'\n },\n framecolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n description: 'Sets the color the frame.'\n },\n framewidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n description: 'Sets the stroke width (in px) of the frame.'\n },\n bgcolor: {\n valType: 'color',\n dflt: colorAttrs.background,\n description: 'Set the background color of the map'\n },\n lonaxis: geoAxesAttrs,\n lataxis: geoAxesAttrs\n}, 'plot', 'from-root');\n\n// set uirevision outside of overrideAll so it can be `editType: 'none'`\nattrs.uirevision = {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in the view',\n '(projection and center). Defaults to `layout.uirevision`.'\n ].join(' ')\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar handleSubplotDefaults = require('../subplot_defaults');\nvar getSubplotData = require('../get_data').getSubplotData;\n\nvar constants = require('./constants');\nvar layoutAttributes = require('./layout_attributes');\n\nvar axesNames = constants.axesNames;\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut, fullData) {\n handleSubplotDefaults(layoutIn, layoutOut, fullData, {\n type: 'geo',\n attributes: layoutAttributes,\n handleDefaults: handleGeoDefaults,\n fullData: fullData,\n partition: 'y'\n });\n};\n\nfunction handleGeoDefaults(geoLayoutIn, geoLayoutOut, coerce, opts) {\n var subplotData = getSubplotData(opts.fullData, 'geo', opts.id);\n var traceIndices = subplotData.map(function(t) { return t._expandedIndex; });\n\n var resolution = coerce('resolution');\n var scope = coerce('scope');\n var scopeParams = constants.scopeDefaults[scope];\n\n var projType = coerce('projection.type', scopeParams.projType);\n var isAlbersUsa = geoLayoutOut._isAlbersUsa = projType === 'albers usa';\n\n // no other scopes are allowed for 'albers usa' projection\n if(isAlbersUsa) scope = geoLayoutOut.scope = 'usa';\n\n var isScoped = geoLayoutOut._isScoped = (scope !== 'world');\n var isSatellite = geoLayoutOut._isSatellite = projType === 'satellite';\n var isConic = geoLayoutOut._isConic = projType.indexOf('conic') !== -1 || projType === 'albers';\n var isClipped = geoLayoutOut._isClipped = !!constants.lonaxisSpan[projType];\n\n if(geoLayoutIn.visible === false) {\n // should override template.layout.geo.show* - see issue 4482\n\n // make a copy\n var newTemplate = Lib.extendDeep({}, geoLayoutOut._template);\n\n // override show*\n newTemplate.showcoastlines = false;\n newTemplate.showcountries = false;\n newTemplate.showframe = false;\n newTemplate.showlakes = false;\n newTemplate.showland = false;\n newTemplate.showocean = false;\n newTemplate.showrivers = false;\n newTemplate.showsubunits = false;\n if(newTemplate.lonaxis) newTemplate.lonaxis.showgrid = false;\n if(newTemplate.lataxis) newTemplate.lataxis.showgrid = false;\n\n // set ref to copy\n geoLayoutOut._template = newTemplate;\n }\n var visible = coerce('visible');\n\n var show;\n for(var i = 0; i < axesNames.length; i++) {\n var axisName = axesNames[i];\n var dtickDflt = [30, 10][i];\n var rangeDflt;\n\n if(isScoped) {\n rangeDflt = scopeParams[axisName + 'Range'];\n } else {\n var dfltSpans = constants[axisName + 'Span'];\n var hSpan = (dfltSpans[projType] || dfltSpans['*']) / 2;\n var rot = coerce(\n 'projection.rotation.' + axisName.substr(0, 3),\n scopeParams.projRotate[i]\n );\n rangeDflt = [rot - hSpan, rot + hSpan];\n }\n\n var range = coerce(axisName + '.range', rangeDflt);\n coerce(axisName + '.tick0');\n coerce(axisName + '.dtick', dtickDflt);\n\n show = coerce(axisName + '.showgrid', !visible ? false : undefined);\n if(show) {\n coerce(axisName + '.gridcolor');\n coerce(axisName + '.gridwidth');\n coerce(axisName + '.griddash');\n }\n\n // mock axis for autorange computations\n geoLayoutOut[axisName]._ax = {\n type: 'linear',\n _id: axisName.slice(0, 3),\n _traceIndices: traceIndices,\n setScale: Lib.identity,\n c2l: Lib.identity,\n r2l: Lib.identity,\n autorange: true,\n range: range.slice(),\n _m: 1,\n _input: {}\n };\n }\n\n var lonRange = geoLayoutOut.lonaxis.range;\n var latRange = geoLayoutOut.lataxis.range;\n\n // to cross antimeridian w/o ambiguity\n var lon0 = lonRange[0];\n var lon1 = lonRange[1];\n if(lon0 > 0 && lon1 < 0) lon1 += 360;\n\n var centerLon = (lon0 + lon1) / 2;\n var projLon;\n\n if(!isAlbersUsa) {\n var dfltProjRotate = isScoped ? scopeParams.projRotate : [centerLon, 0, 0];\n\n projLon = coerce('projection.rotation.lon', dfltProjRotate[0]);\n coerce('projection.rotation.lat', dfltProjRotate[1]);\n coerce('projection.rotation.roll', dfltProjRotate[2]);\n\n show = coerce('showcoastlines', !isScoped && visible);\n if(show) {\n coerce('coastlinecolor');\n coerce('coastlinewidth');\n }\n\n show = coerce('showocean', !visible ? false : undefined);\n if(show) coerce('oceancolor');\n }\n\n var centerLonDflt;\n var centerLatDflt;\n\n if(isAlbersUsa) {\n // 'albers usa' does not have a 'center',\n // these values were found using via:\n // projection.invert([geoLayout.center.lon, geoLayoutIn.center.lat])\n centerLonDflt = -96.6;\n centerLatDflt = 38.7;\n } else {\n centerLonDflt = isScoped ? centerLon : projLon;\n centerLatDflt = (latRange[0] + latRange[1]) / 2;\n }\n\n coerce('center.lon', centerLonDflt);\n coerce('center.lat', centerLatDflt);\n\n if(isSatellite) {\n coerce('projection.tilt');\n coerce('projection.distance');\n }\n\n if(isConic) {\n var dfltProjParallels = scopeParams.projParallels || [0, 60];\n coerce('projection.parallels', dfltProjParallels);\n }\n\n coerce('projection.scale');\n\n show = coerce('showland', !visible ? false : undefined);\n if(show) coerce('landcolor');\n\n show = coerce('showlakes', !visible ? false : undefined);\n if(show) coerce('lakecolor');\n\n show = coerce('showrivers', !visible ? false : undefined);\n if(show) {\n coerce('rivercolor');\n coerce('riverwidth');\n }\n\n show = coerce('showcountries', isScoped && scope !== 'usa' && visible);\n if(show) {\n coerce('countrycolor');\n coerce('countrywidth');\n }\n\n if(scope === 'usa' || (scope === 'north america' && resolution === 50)) {\n // Only works for:\n // USA states at 110m\n // USA states + Canada provinces at 50m\n coerce('showsubunits', visible);\n coerce('subunitcolor');\n coerce('subunitwidth');\n }\n\n if(!isScoped) {\n // Does not work in non-world scopes\n show = coerce('showframe', visible);\n if(show) {\n coerce('framecolor');\n coerce('framewidth');\n }\n }\n\n coerce('bgcolor');\n\n var fitBounds = coerce('fitbounds');\n\n // clear attributes that will get auto-filled later\n if(fitBounds) {\n delete geoLayoutOut.projection.scale;\n\n if(isScoped) {\n delete geoLayoutOut.center.lon;\n delete geoLayoutOut.center.lat;\n } else if(isClipped) {\n delete geoLayoutOut.center.lon;\n delete geoLayoutOut.center.lat;\n delete geoLayoutOut.projection.rotation.lon;\n delete geoLayoutOut.projection.rotation.lat;\n delete geoLayoutOut.lonaxis.range;\n delete geoLayoutOut.lataxis.range;\n } else {\n delete geoLayoutOut.center.lon;\n delete geoLayoutOut.center.lat;\n delete geoLayoutOut.projection.rotation.lon;\n }\n }\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\n\nvar radians = Math.PI / 180;\nvar degrees = 180 / Math.PI;\nvar zoomstartStyle = {cursor: 'pointer'};\nvar zoomendStyle = {cursor: 'auto'};\n\nfunction createGeoZoom(geo, geoLayout) {\n var projection = geo.projection;\n var zoomConstructor;\n\n if(geoLayout._isScoped) {\n zoomConstructor = zoomScoped;\n } else if(geoLayout._isClipped) {\n zoomConstructor = zoomClipped;\n } else {\n zoomConstructor = zoomNonClipped;\n }\n\n // TODO add a conic-specific zoom\n\n return zoomConstructor(geo, projection);\n}\n\nmodule.exports = createGeoZoom;\n\n// common to all zoom types\nfunction initZoom(geo, projection) {\n return d3.behavior.zoom()\n .translate(projection.translate())\n .scale(projection.scale());\n}\n\n// sync zoom updates with user & full layout\nfunction sync(geo, projection, cb) {\n var id = geo.id;\n var gd = geo.graphDiv;\n var layout = gd.layout;\n var userOpts = layout[id];\n var fullLayout = gd._fullLayout;\n var fullOpts = fullLayout[id];\n\n var preGUI = {};\n var eventData = {};\n\n function set(propStr, val) {\n preGUI[id + '.' + propStr] = Lib.nestedProperty(userOpts, propStr).get();\n Registry.call('_storeDirectGUIEdit', layout, fullLayout._preGUI, preGUI);\n\n var fullNp = Lib.nestedProperty(fullOpts, propStr);\n if(fullNp.get() !== val) {\n fullNp.set(val);\n Lib.nestedProperty(userOpts, propStr).set(val);\n eventData[id + '.' + propStr] = val;\n }\n }\n\n cb(set);\n set('projection.scale', projection.scale() / geo.fitScale);\n set('fitbounds', false);\n gd.emit('plotly_relayout', eventData);\n}\n\n// zoom for scoped projections\nfunction zoomScoped(geo, projection) {\n var zoom = initZoom(geo, projection);\n\n function handleZoomstart() {\n d3.select(this).style(zoomstartStyle);\n }\n\n function handleZoom() {\n projection\n .scale(d3.event.scale)\n .translate(d3.event.translate);\n geo.render(true);\n\n var center = projection.invert(geo.midPt);\n geo.graphDiv.emit('plotly_relayouting', {\n 'geo.projection.scale': projection.scale() / geo.fitScale,\n 'geo.center.lon': center[0],\n 'geo.center.lat': center[1]\n });\n }\n\n function syncCb(set) {\n var center = projection.invert(geo.midPt);\n\n set('center.lon', center[0]);\n set('center.lat', center[1]);\n }\n\n function handleZoomend() {\n d3.select(this).style(zoomendStyle);\n sync(geo, projection, syncCb);\n }\n\n zoom\n .on('zoomstart', handleZoomstart)\n .on('zoom', handleZoom)\n .on('zoomend', handleZoomend);\n\n return zoom;\n}\n\n// zoom for non-clipped projections\nfunction zoomNonClipped(geo, projection) {\n var zoom = initZoom(geo, projection);\n\n var INSIDETOLORANCEPXS = 2;\n\n var mouse0, rotate0, translate0, lastRotate, zoomPoint,\n mouse1, rotate1, point1, didZoom;\n\n function position(x) { return projection.invert(x); }\n\n function outside(x) {\n var pos = position(x);\n if(!pos) return true;\n\n var pt = projection(pos);\n return (\n Math.abs(pt[0] - x[0]) > INSIDETOLORANCEPXS ||\n Math.abs(pt[1] - x[1]) > INSIDETOLORANCEPXS\n );\n }\n\n function handleZoomstart() {\n d3.select(this).style(zoomstartStyle);\n\n mouse0 = d3.mouse(this);\n rotate0 = projection.rotate();\n translate0 = projection.translate();\n lastRotate = rotate0;\n zoomPoint = position(mouse0);\n }\n\n function handleZoom() {\n mouse1 = d3.mouse(this);\n\n if(outside(mouse0)) {\n zoom.scale(projection.scale());\n zoom.translate(projection.translate());\n return;\n }\n\n projection.scale(d3.event.scale);\n projection.translate([translate0[0], d3.event.translate[1]]);\n\n if(!zoomPoint) {\n mouse0 = mouse1;\n zoomPoint = position(mouse0);\n } else if(position(mouse1)) {\n point1 = position(mouse1);\n rotate1 = [lastRotate[0] + (point1[0] - zoomPoint[0]), rotate0[1], rotate0[2]];\n projection.rotate(rotate1);\n lastRotate = rotate1;\n }\n\n didZoom = true;\n geo.render(true);\n\n var rotate = projection.rotate();\n var center = projection.invert(geo.midPt);\n geo.graphDiv.emit('plotly_relayouting', {\n 'geo.projection.scale': projection.scale() / geo.fitScale,\n 'geo.center.lon': center[0],\n 'geo.center.lat': center[1],\n 'geo.projection.rotation.lon': -rotate[0]\n });\n }\n\n function handleZoomend() {\n d3.select(this).style(zoomendStyle);\n if(didZoom) sync(geo, projection, syncCb);\n }\n\n function syncCb(set) {\n var rotate = projection.rotate();\n var center = projection.invert(geo.midPt);\n\n set('projection.rotation.lon', -rotate[0]);\n set('center.lon', center[0]);\n set('center.lat', center[1]);\n }\n\n zoom\n .on('zoomstart', handleZoomstart)\n .on('zoom', handleZoom)\n .on('zoomend', handleZoomend);\n\n return zoom;\n}\n\n// zoom for clipped projections\n// inspired by https://www.jasondavies.com/maps/d3.geo.zoom.js\nfunction zoomClipped(geo, projection) {\n var view = {r: projection.rotate(), k: projection.scale()};\n var zoom = initZoom(geo, projection);\n var event = d3eventDispatch(zoom, 'zoomstart', 'zoom', 'zoomend');\n var zooming = 0;\n var zoomOn = zoom.on;\n\n var zoomPoint;\n\n zoom.on('zoomstart', function() {\n d3.select(this).style(zoomstartStyle);\n\n var mouse0 = d3.mouse(this);\n var rotate0 = projection.rotate();\n var lastRotate = rotate0;\n var translate0 = projection.translate();\n var q = quaternionFromEuler(rotate0);\n\n zoomPoint = position(projection, mouse0);\n\n zoomOn.call(zoom, 'zoom', function() {\n var mouse1 = d3.mouse(this);\n\n projection.scale(view.k = d3.event.scale);\n\n if(!zoomPoint) {\n // if no zoomPoint, the mouse wasn't over the actual geography yet\n // maybe this point is the start... we'll find out next time!\n mouse0 = mouse1;\n zoomPoint = position(projection, mouse0);\n } else if(position(projection, mouse1)) {\n // check if the point is on the map\n // if not, don't do anything new but scale\n // if it is, then we can assume between will exist below\n // so we don't need the 'bank' function, whatever that is.\n\n // go back to original projection temporarily\n // except for scale... that's kind of independent?\n projection\n .rotate(rotate0)\n .translate(translate0);\n\n // calculate the new params\n var point1 = position(projection, mouse1);\n var between = rotateBetween(zoomPoint, point1);\n var newEuler = eulerFromQuaternion(multiply(q, between));\n var rotateAngles = view.r = unRoll(newEuler, zoomPoint, lastRotate);\n\n if(!isFinite(rotateAngles[0]) || !isFinite(rotateAngles[1]) ||\n !isFinite(rotateAngles[2])) {\n rotateAngles = lastRotate;\n }\n\n // update the projection\n projection.rotate(rotateAngles);\n lastRotate = rotateAngles;\n }\n\n zoomed(event.of(this, arguments));\n });\n\n zoomstarted(event.of(this, arguments));\n })\n .on('zoomend', function() {\n d3.select(this).style(zoomendStyle);\n zoomOn.call(zoom, 'zoom', null);\n zoomended(event.of(this, arguments));\n sync(geo, projection, syncCb);\n })\n .on('zoom.redraw', function() {\n geo.render(true);\n\n var _rotate = projection.rotate();\n geo.graphDiv.emit('plotly_relayouting', {\n 'geo.projection.scale': projection.scale() / geo.fitScale,\n 'geo.projection.rotation.lon': -_rotate[0],\n 'geo.projection.rotation.lat': -_rotate[1]\n });\n });\n\n function zoomstarted(dispatch) {\n if(!zooming++) dispatch({type: 'zoomstart'});\n }\n\n function zoomed(dispatch) {\n dispatch({type: 'zoom'});\n }\n\n function zoomended(dispatch) {\n if(!--zooming) dispatch({type: 'zoomend'});\n }\n\n function syncCb(set) {\n var _rotate = projection.rotate();\n set('projection.rotation.lon', -_rotate[0]);\n set('projection.rotation.lat', -_rotate[1]);\n }\n\n return d3.rebind(zoom, event, 'on');\n}\n\n// -- helper functions for zoomClipped\n\nfunction position(projection, point) {\n var spherical = projection.invert(point);\n return spherical && isFinite(spherical[0]) && isFinite(spherical[1]) && cartesian(spherical);\n}\n\nfunction quaternionFromEuler(euler) {\n var lambda = 0.5 * euler[0] * radians;\n var phi = 0.5 * euler[1] * radians;\n var gamma = 0.5 * euler[2] * radians;\n var sinLambda = Math.sin(lambda);\n var cosLambda = Math.cos(lambda);\n var sinPhi = Math.sin(phi);\n var cosPhi = Math.cos(phi);\n var sinGamma = Math.sin(gamma);\n var cosGamma = Math.cos(gamma);\n return [\n cosLambda * cosPhi * cosGamma + sinLambda * sinPhi * sinGamma,\n sinLambda * cosPhi * cosGamma - cosLambda * sinPhi * sinGamma,\n cosLambda * sinPhi * cosGamma + sinLambda * cosPhi * sinGamma,\n cosLambda * cosPhi * sinGamma - sinLambda * sinPhi * cosGamma\n ];\n}\n\nfunction multiply(a, b) {\n var a0 = a[0];\n var a1 = a[1];\n var a2 = a[2];\n var a3 = a[3];\n var b0 = b[0];\n var b1 = b[1];\n var b2 = b[2];\n var b3 = b[3];\n return [\n a0 * b0 - a1 * b1 - a2 * b2 - a3 * b3,\n a0 * b1 + a1 * b0 + a2 * b3 - a3 * b2,\n a0 * b2 - a1 * b3 + a2 * b0 + a3 * b1,\n a0 * b3 + a1 * b2 - a2 * b1 + a3 * b0\n ];\n}\n\nfunction rotateBetween(a, b) {\n if(!a || !b) return;\n var axis = cross(a, b);\n var norm = Math.sqrt(dot(axis, axis));\n var halfgamma = 0.5 * Math.acos(Math.max(-1, Math.min(1, dot(a, b))));\n var k = Math.sin(halfgamma) / norm;\n return norm && [Math.cos(halfgamma), axis[2] * k, -axis[1] * k, axis[0] * k];\n}\n\n// input:\n// rotateAngles: a calculated set of Euler angles\n// pt: a point (cartesian in 3-space) to keep fixed\n// roll0: an initial roll, to be preserved\n// output:\n// a set of Euler angles that preserve the projection of pt\n// but set roll (output[2]) equal to roll0\n// note that this doesn't depend on the particular projection,\n// just on the rotation angles\nfunction unRoll(rotateAngles, pt, lastRotate) {\n // calculate the fixed point transformed by these Euler angles\n // but with the desired roll undone\n var ptRotated = rotateCartesian(pt, 2, rotateAngles[0]);\n ptRotated = rotateCartesian(ptRotated, 1, rotateAngles[1]);\n ptRotated = rotateCartesian(ptRotated, 0, rotateAngles[2] - lastRotate[2]);\n\n var x = pt[0];\n var y = pt[1];\n var z = pt[2];\n var f = ptRotated[0];\n var g = ptRotated[1];\n var h = ptRotated[2];\n\n // the following essentially solves:\n // ptRotated = rotateCartesian(rotateCartesian(pt, 2, newYaw), 1, newPitch)\n // for newYaw and newPitch, as best it can\n var theta = Math.atan2(y, x) * degrees;\n var a = Math.sqrt(x * x + y * y);\n var b;\n var newYaw1;\n\n if(Math.abs(g) > a) {\n newYaw1 = (g > 0 ? 90 : -90) - theta;\n b = 0;\n } else {\n newYaw1 = Math.asin(g / a) * degrees - theta;\n b = Math.sqrt(a * a - g * g);\n }\n\n var newYaw2 = 180 - newYaw1 - 2 * theta;\n var newPitch1 = (Math.atan2(h, f) - Math.atan2(z, b)) * degrees;\n var newPitch2 = (Math.atan2(h, f) - Math.atan2(z, -b)) * degrees;\n\n // which is closest to lastRotate[0,1]: newYaw/Pitch or newYaw2/Pitch2?\n var dist1 = angleDistance(lastRotate[0], lastRotate[1], newYaw1, newPitch1);\n var dist2 = angleDistance(lastRotate[0], lastRotate[1], newYaw2, newPitch2);\n\n if(dist1 <= dist2) return [newYaw1, newPitch1, lastRotate[2]];\n else return [newYaw2, newPitch2, lastRotate[2]];\n}\n\nfunction angleDistance(yaw0, pitch0, yaw1, pitch1) {\n var dYaw = angleMod(yaw1 - yaw0);\n var dPitch = angleMod(pitch1 - pitch0);\n return Math.sqrt(dYaw * dYaw + dPitch * dPitch);\n}\n\n// reduce an angle in degrees to [-180,180]\nfunction angleMod(angle) {\n return (angle % 360 + 540) % 360 - 180;\n}\n\n// rotate a cartesian vector\n// axis is 0 (x), 1 (y), or 2 (z)\n// angle is in degrees\nfunction rotateCartesian(vector, axis, angle) {\n var angleRads = angle * radians;\n var vectorOut = vector.slice();\n var ax1 = (axis === 0) ? 1 : 0;\n var ax2 = (axis === 2) ? 1 : 2;\n var cosa = Math.cos(angleRads);\n var sina = Math.sin(angleRads);\n\n vectorOut[ax1] = vector[ax1] * cosa - vector[ax2] * sina;\n vectorOut[ax2] = vector[ax2] * cosa + vector[ax1] * sina;\n\n return vectorOut;\n}\nfunction eulerFromQuaternion(q) {\n return [\n Math.atan2(2 * (q[0] * q[1] + q[2] * q[3]), 1 - 2 * (q[1] * q[1] + q[2] * q[2])) * degrees,\n Math.asin(Math.max(-1, Math.min(1, 2 * (q[0] * q[2] - q[3] * q[1])))) * degrees,\n Math.atan2(2 * (q[0] * q[3] + q[1] * q[2]), 1 - 2 * (q[2] * q[2] + q[3] * q[3])) * degrees\n ];\n}\n\nfunction cartesian(spherical) {\n var lambda = spherical[0] * radians;\n var phi = spherical[1] * radians;\n var cosPhi = Math.cos(phi);\n return [\n cosPhi * Math.cos(lambda),\n cosPhi * Math.sin(lambda),\n Math.sin(phi)\n ];\n}\n\nfunction dot(a, b) {\n var s = 0;\n for(var i = 0, n = a.length; i < n; ++i) s += a[i] * b[i];\n return s;\n}\n\nfunction cross(a, b) {\n return [\n a[1] * b[2] - a[2] * b[1],\n a[2] * b[0] - a[0] * b[2],\n a[0] * b[1] - a[1] * b[0]\n ];\n}\n\n// Like d3.dispatch, but for custom events abstracting native UI events. These\n// events have a target component (such as a brush), a target element (such as\n// the svg:g element containing the brush) and the standard arguments `d` (the\n// target element's data) and `i` (the selection index of the target element).\nfunction d3eventDispatch(target) {\n var i = 0;\n var n = arguments.length;\n var argumentz = [];\n\n while(++i < n) argumentz.push(arguments[i]);\n\n var dispatch = d3.dispatch.apply(null, argumentz);\n\n // Creates a dispatch context for the specified `thiz` (typically, the target\n // DOM element that received the source event) and `argumentz` (typically, the\n // data `d` and index `i` of the target element). The returned function can be\n // used to dispatch an event to any registered listeners; the function takes a\n // single argument as input, being the event to dispatch. The event must have\n // a \"type\" attribute which corresponds to a type registered in the\n // constructor. This context will automatically populate the \"sourceEvent\" and\n // \"target\" attributes of the event, as well as setting the `d3.event` global\n // for the duration of the notification.\n dispatch.of = function(thiz, argumentz) {\n return function(e1) {\n var e0;\n try {\n e0 = e1.sourceEvent = d3.event;\n e1.target = target;\n d3.event = e1;\n dispatch[e1.type].apply(thiz, argumentz);\n } finally {\n d3.event = e0;\n }\n };\n };\n\n return dispatch;\n}\n","'use strict';\n\nvar Registry = require('../registry');\nvar SUBPLOT_PATTERN = require('./cartesian/constants').SUBPLOT_PATTERN;\n\n/**\n * Get calcdata trace(s) associated with a given subplot\n *\n * @param {array} calcData: as in gd.calcdata\n * @param {string} type: subplot type\n * @param {string} subplotId: subplot id to look for\n *\n * @return {array} array of calcdata traces\n */\nexports.getSubplotCalcData = function(calcData, type, subplotId) {\n var basePlotModule = Registry.subplotsRegistry[type];\n if(!basePlotModule) return [];\n\n var attr = basePlotModule.attr;\n var subplotCalcData = [];\n\n for(var i = 0; i < calcData.length; i++) {\n var calcTrace = calcData[i];\n var trace = calcTrace[0].trace;\n\n if(trace[attr] === subplotId) subplotCalcData.push(calcTrace);\n }\n\n return subplotCalcData;\n};\n/**\n * Get calcdata trace(s) that can be plotted with a given module\n * NOTE: this isn't necessarily just exactly matching trace type,\n * if multiple trace types use the same plotting routine, they will be\n * collected here.\n * In order to not plot the same thing multiple times, we return two arrays,\n * the calcdata we *will* plot with this module, and the ones we *won't*\n *\n * @param {array} calcdata: as in gd.calcdata\n * @param {object|string|fn} arg1:\n * the plotting module, or its name, or its plot method\n * @param {int} arg2: (optional) zorder to filter on\n * @return {array[array]} [foundCalcdata, remainingCalcdata]\n */\nexports.getModuleCalcData = function(calcdata, arg1, arg2) {\n var moduleCalcData = [];\n var remainingCalcData = [];\n\n var plotMethod;\n if(typeof arg1 === 'string') {\n plotMethod = Registry.getModule(arg1).plot;\n } else if(typeof arg1 === 'function') {\n plotMethod = arg1;\n } else {\n plotMethod = arg1.plot;\n }\n if(!plotMethod) {\n return [moduleCalcData, calcdata];\n }\n var zorder = arg2;\n\n for(var i = 0; i < calcdata.length; i++) {\n var cd = calcdata[i];\n var trace = cd[0].trace;\n var filterByZ = (trace.zorder !== undefined);\n // N.B.\n // - 'legendonly' traces do not make it past here\n // - skip over 'visible' traces that got trimmed completely during calc transforms\n if(trace.visible !== true || trace._length === 0) continue;\n\n // group calcdata trace not by 'module' (as the name of this function\n // would suggest), but by 'module plot method' so that if some traces\n // share the same module plot method (e.g. bar and histogram), we\n // only call it one!\n if(trace._module && trace._module.plot === plotMethod && (!filterByZ || trace.zorder === zorder)) {\n moduleCalcData.push(cd);\n } else {\n remainingCalcData.push(cd);\n }\n }\n\n return [moduleCalcData, remainingCalcData];\n};\n\n/**\n * Get the data trace(s) associated with a given subplot.\n *\n * @param {array} data plotly full data array.\n * @param {string} type subplot type to look for.\n * @param {string} subplotId subplot id to look for.\n *\n * @return {array} list of trace objects.\n *\n */\nexports.getSubplotData = function getSubplotData(data, type, subplotId) {\n if(!Registry.subplotsRegistry[type]) return [];\n\n var attr = Registry.subplotsRegistry[type].attr;\n var subplotData = [];\n var trace, subplotX, subplotY;\n\n if(type === 'gl2d') {\n var spmatch = subplotId.match(SUBPLOT_PATTERN);\n subplotX = 'x' + spmatch[1];\n subplotY = 'y' + spmatch[2];\n }\n\n for(var i = 0; i < data.length; i++) {\n trace = data[i];\n\n if(type === 'gl2d' && Registry.traceIs(trace, 'gl2d')) {\n if(trace[attr[0]] === subplotX && trace[attr[1]] === subplotY) {\n subplotData.push(trace);\n }\n } else {\n if(trace[attr] === subplotId) subplotData.push(trace);\n }\n }\n\n return subplotData;\n};\n","'use strict';\n\nvar mouseChange = require('mouse-change');\nvar mouseWheel = require('mouse-wheel');\nvar mouseOffset = require('mouse-event-offset');\nvar cartesianConstants = require('../cartesian/constants');\nvar hasPassive = require('has-passive-events');\n\nmodule.exports = createCamera;\n\nfunction Camera2D(element, plot) {\n this.element = element;\n this.plot = plot;\n this.mouseListener = null;\n this.wheelListener = null;\n this.lastInputTime = Date.now();\n this.lastPos = [0, 0];\n this.boxEnabled = false;\n this.boxInited = false;\n this.boxStart = [0, 0];\n this.boxEnd = [0, 0];\n this.dragStart = [0, 0];\n}\n\n\nfunction createCamera(scene) {\n var element = scene.mouseContainer;\n var plot = scene.glplot;\n var result = new Camera2D(element, plot);\n\n function unSetAutoRange() {\n scene.xaxis.autorange = false;\n scene.yaxis.autorange = false;\n }\n\n function getSubplotConstraint() {\n // note: this assumes we only have one x and one y axis on this subplot\n // when this constraint is lifted this block won't make sense\n var constraints = scene.graphDiv._fullLayout._axisConstraintGroups;\n var xaId = scene.xaxis._id;\n var yaId = scene.yaxis._id;\n for(var i = 0; i < constraints.length; i++) {\n if(constraints[i][xaId] !== -1) {\n if(constraints[i][yaId] !== -1) return true;\n break;\n }\n }\n return false;\n }\n\n result.mouseListener = mouseChange(element, handleInteraction);\n\n // enable simple touch interactions\n element.addEventListener('touchstart', function(ev) {\n var xy = mouseOffset(ev.changedTouches[0], element);\n handleInteraction(0, xy[0], xy[1]);\n handleInteraction(1, xy[0], xy[1]);\n\n ev.preventDefault();\n }, hasPassive ? {passive: false} : false);\n element.addEventListener('touchmove', function(ev) {\n ev.preventDefault();\n var xy = mouseOffset(ev.changedTouches[0], element);\n handleInteraction(1, xy[0], xy[1]);\n\n ev.preventDefault();\n }, hasPassive ? {passive: false} : false);\n element.addEventListener('touchend', function(ev) {\n handleInteraction(0, result.lastPos[0], result.lastPos[1]);\n\n ev.preventDefault();\n }, hasPassive ? {passive: false} : false);\n\n function handleInteraction(buttons, x, y) {\n var dataBox = scene.calcDataBox();\n var viewBox = plot.viewBox;\n\n var lastX = result.lastPos[0];\n var lastY = result.lastPos[1];\n\n var MINDRAG = cartesianConstants.MINDRAG * plot.pixelRatio;\n var MINZOOM = cartesianConstants.MINZOOM * plot.pixelRatio;\n\n var dx, dy;\n\n x *= plot.pixelRatio;\n y *= plot.pixelRatio;\n\n // mouseChange gives y about top; convert to about bottom\n y = (viewBox[3] - viewBox[1]) - y;\n\n function updateRange(i0, start, end) {\n var range0 = Math.min(start, end);\n var range1 = Math.max(start, end);\n\n if(range0 !== range1) {\n dataBox[i0] = range0;\n dataBox[i0 + 2] = range1;\n result.dataBox = dataBox;\n scene.setRanges(dataBox);\n } else {\n scene.selectBox.selectBox = [0, 0, 1, 1];\n scene.glplot.setDirty();\n }\n }\n\n switch(scene.fullLayout.dragmode) {\n case 'zoom':\n if(buttons) {\n var dataX = x /\n (viewBox[2] - viewBox[0]) * (dataBox[2] - dataBox[0]) +\n dataBox[0];\n var dataY = y /\n (viewBox[3] - viewBox[1]) * (dataBox[3] - dataBox[1]) +\n dataBox[1];\n\n if(!result.boxInited) {\n result.boxStart[0] = dataX;\n result.boxStart[1] = dataY;\n result.dragStart[0] = x;\n result.dragStart[1] = y;\n }\n\n result.boxEnd[0] = dataX;\n result.boxEnd[1] = dataY;\n\n // we need to mark the box as initialized right away\n // so that we can tell the start and end points apart\n result.boxInited = true;\n\n // but don't actually enable the box until the cursor moves\n if(!result.boxEnabled && (\n result.boxStart[0] !== result.boxEnd[0] ||\n result.boxStart[1] !== result.boxEnd[1])\n ) {\n result.boxEnabled = true;\n }\n\n // constrain aspect ratio if the axes require it\n var smallDx = Math.abs(result.dragStart[0] - x) < MINZOOM;\n var smallDy = Math.abs(result.dragStart[1] - y) < MINZOOM;\n if(getSubplotConstraint() && !(smallDx && smallDy)) {\n dx = result.boxEnd[0] - result.boxStart[0];\n dy = result.boxEnd[1] - result.boxStart[1];\n var dydx = (dataBox[3] - dataBox[1]) / (dataBox[2] - dataBox[0]);\n\n if(Math.abs(dx * dydx) > Math.abs(dy)) {\n result.boxEnd[1] = result.boxStart[1] +\n Math.abs(dx) * dydx * (dy >= 0 ? 1 : -1);\n\n // gl-select-box clips to the plot area bounds,\n // which breaks the axis constraint, so don't allow\n // this box to go out of bounds\n if(result.boxEnd[1] < dataBox[1]) {\n result.boxEnd[1] = dataBox[1];\n result.boxEnd[0] = result.boxStart[0] +\n (dataBox[1] - result.boxStart[1]) / Math.abs(dydx);\n } else if(result.boxEnd[1] > dataBox[3]) {\n result.boxEnd[1] = dataBox[3];\n result.boxEnd[0] = result.boxStart[0] +\n (dataBox[3] - result.boxStart[1]) / Math.abs(dydx);\n }\n } else {\n result.boxEnd[0] = result.boxStart[0] +\n Math.abs(dy) / dydx * (dx >= 0 ? 1 : -1);\n\n if(result.boxEnd[0] < dataBox[0]) {\n result.boxEnd[0] = dataBox[0];\n result.boxEnd[1] = result.boxStart[1] +\n (dataBox[0] - result.boxStart[0]) * Math.abs(dydx);\n } else if(result.boxEnd[0] > dataBox[2]) {\n result.boxEnd[0] = dataBox[2];\n result.boxEnd[1] = result.boxStart[1] +\n (dataBox[2] - result.boxStart[0]) * Math.abs(dydx);\n }\n }\n } else {\n // otherwise clamp small changes to the origin so we get 1D zoom\n\n if(smallDx) result.boxEnd[0] = result.boxStart[0];\n if(smallDy) result.boxEnd[1] = result.boxStart[1];\n }\n } else if(result.boxEnabled) {\n dx = result.boxStart[0] !== result.boxEnd[0];\n dy = result.boxStart[1] !== result.boxEnd[1];\n if(dx || dy) {\n if(dx) {\n updateRange(0, result.boxStart[0], result.boxEnd[0]);\n scene.xaxis.autorange = false;\n }\n if(dy) {\n updateRange(1, result.boxStart[1], result.boxEnd[1]);\n scene.yaxis.autorange = false;\n }\n scene.relayoutCallback();\n } else {\n scene.glplot.setDirty();\n }\n result.boxEnabled = false;\n result.boxInited = false;\n } else if(result.boxInited) {\n // if box was inited but button released then - reset the box\n\n result.boxInited = false;\n }\n break;\n\n case 'pan':\n result.boxEnabled = false;\n result.boxInited = false;\n\n if(buttons) {\n if(!result.panning) {\n result.dragStart[0] = x;\n result.dragStart[1] = y;\n }\n\n if(Math.abs(result.dragStart[0] - x) < MINDRAG) x = result.dragStart[0];\n if(Math.abs(result.dragStart[1] - y) < MINDRAG) y = result.dragStart[1];\n\n dx = (lastX - x) * (dataBox[2] - dataBox[0]) /\n (plot.viewBox[2] - plot.viewBox[0]);\n dy = (lastY - y) * (dataBox[3] - dataBox[1]) /\n (plot.viewBox[3] - plot.viewBox[1]);\n\n dataBox[0] += dx;\n dataBox[2] += dx;\n dataBox[1] += dy;\n dataBox[3] += dy;\n\n scene.setRanges(dataBox);\n\n result.panning = true;\n result.lastInputTime = Date.now();\n unSetAutoRange();\n scene.cameraChanged();\n scene.handleAnnotations();\n } else if(result.panning) {\n result.panning = false;\n scene.relayoutCallback();\n }\n break;\n }\n\n result.lastPos[0] = x;\n result.lastPos[1] = y;\n }\n\n result.wheelListener = mouseWheel(element, function(dx, dy) {\n if(!scene.scrollZoom) return false;\n\n var dataBox = scene.calcDataBox();\n var viewBox = plot.viewBox;\n\n var lastX = result.lastPos[0];\n var lastY = result.lastPos[1];\n\n var scale = Math.exp(5.0 * dy / (viewBox[3] - viewBox[1]));\n\n var cx = lastX /\n (viewBox[2] - viewBox[0]) * (dataBox[2] - dataBox[0]) +\n dataBox[0];\n var cy = lastY /\n (viewBox[3] - viewBox[1]) * (dataBox[3] - dataBox[1]) +\n dataBox[1];\n\n dataBox[0] = (dataBox[0] - cx) * scale + cx;\n dataBox[2] = (dataBox[2] - cx) * scale + cx;\n dataBox[1] = (dataBox[1] - cy) * scale + cy;\n dataBox[3] = (dataBox[3] - cy) * scale + cy;\n\n scene.setRanges(dataBox);\n\n result.lastInputTime = Date.now();\n unSetAutoRange();\n scene.cameraChanged();\n scene.handleAnnotations();\n scene.relayoutCallback();\n\n return true;\n }, true);\n\n return result;\n}\n","'use strict';\n\nvar Axes = require('../cartesian/axes');\n\nvar str2RGBArray = require('../../lib/str2rgbarray');\n\nfunction Axes2DOptions(scene) {\n this.scene = scene;\n this.gl = scene.gl;\n this.pixelRatio = scene.pixelRatio;\n\n this.screenBox = [0, 0, 1, 1];\n this.viewBox = [0, 0, 1, 1];\n this.dataBox = [-1, -1, 1, 1];\n\n this.borderLineEnable = [false, false, false, false];\n this.borderLineWidth = [1, 1, 1, 1];\n this.borderLineColor = [\n [0, 0, 0, 1],\n [0, 0, 0, 1],\n [0, 0, 0, 1],\n [0, 0, 0, 1]\n ];\n\n this.ticks = [[], []];\n this.tickEnable = [true, true, false, false];\n this.tickPad = [15, 15, 15, 15];\n this.tickAngle = [0, 0, 0, 0];\n this.tickColor = [\n [0, 0, 0, 1],\n [0, 0, 0, 1],\n [0, 0, 0, 1],\n [0, 0, 0, 1]\n ];\n this.tickMarkLength = [0, 0, 0, 0];\n this.tickMarkWidth = [0, 0, 0, 0];\n this.tickMarkColor = [\n [0, 0, 0, 1],\n [0, 0, 0, 1],\n [0, 0, 0, 1],\n [0, 0, 0, 1]\n ];\n\n this.labels = ['x', 'y'];\n this.labelEnable = [true, true, false, false];\n this.labelAngle = [0, Math.PI / 2, 0, 3.0 * Math.PI / 2];\n this.labelPad = [15, 15, 15, 15];\n this.labelSize = [12, 12];\n this.labelFont = ['sans-serif', 'sans-serif'];\n this.labelColor = [\n [0, 0, 0, 1],\n [0, 0, 0, 1],\n [0, 0, 0, 1],\n [0, 0, 0, 1]\n ];\n\n this.title = '';\n this.titleEnable = true;\n this.titleCenter = [0, 0, 0, 0];\n this.titleAngle = 0;\n this.titleColor = [0, 0, 0, 1];\n this.titleFont = 'sans-serif';\n this.titleSize = 18;\n\n this.gridLineEnable = [true, true];\n this.gridLineColor = [\n [0, 0, 0, 0.5],\n [0, 0, 0, 0.5]\n ];\n this.gridLineWidth = [1, 1];\n\n this.zeroLineEnable = [true, true];\n this.zeroLineWidth = [1, 1];\n this.zeroLineColor = [\n [0, 0, 0, 1],\n [0, 0, 0, 1]\n ];\n\n this.borderColor = [0, 0, 0, 0];\n this.backgroundColor = [0, 0, 0, 0];\n\n this.static = this.scene.staticPlot;\n}\n\nvar proto = Axes2DOptions.prototype;\n\nvar AXES = ['xaxis', 'yaxis'];\n\nproto.merge = function(options) {\n // titles are rendered in SVG\n this.titleEnable = false;\n this.backgroundColor = str2RGBArray(options.plot_bgcolor);\n\n var axisName, ax, axTitle, axMirror;\n var hasAxisInDfltPos, hasAxisInAltrPos, hasSharedAxis, mirrorLines, mirrorTicks;\n var i, j;\n\n for(i = 0; i < 2; ++i) {\n axisName = AXES[i];\n var axisLetter = axisName.charAt(0);\n\n // get options relevant to this subplot,\n // '_name' is e.g. xaxis, xaxis2, yaxis, yaxis4 ...\n ax = options[this.scene[axisName]._name];\n\n axTitle = ax.title.text === this.scene.fullLayout._dfltTitle[axisLetter] ? '' : ax.title.text;\n\n for(j = 0; j <= 2; j += 2) {\n this.labelEnable[i + j] = false;\n this.labels[i + j] = axTitle;\n this.labelColor[i + j] = str2RGBArray(ax.title.font.color);\n this.labelFont[i + j] = ax.title.font.family;\n this.labelSize[i + j] = ax.title.font.size;\n this.labelPad[i + j] = this.getLabelPad(axisName, ax);\n\n this.tickEnable[i + j] = false;\n this.tickColor[i + j] = str2RGBArray((ax.tickfont || {}).color);\n this.tickAngle[i + j] = (ax.tickangle === 'auto') ?\n 0 :\n Math.PI * -ax.tickangle / 180;\n this.tickPad[i + j] = this.getTickPad(ax);\n\n this.tickMarkLength[i + j] = 0;\n this.tickMarkWidth[i + j] = ax.tickwidth || 0;\n this.tickMarkColor[i + j] = str2RGBArray(ax.tickcolor);\n\n this.borderLineEnable[i + j] = false;\n this.borderLineColor[i + j] = str2RGBArray(ax.linecolor);\n this.borderLineWidth[i + j] = ax.linewidth || 0;\n }\n\n hasSharedAxis = this.hasSharedAxis(ax);\n hasAxisInDfltPos = this.hasAxisInDfltPos(axisName, ax) && !hasSharedAxis;\n hasAxisInAltrPos = this.hasAxisInAltrPos(axisName, ax) && !hasSharedAxis;\n\n axMirror = ax.mirror || false;\n mirrorLines = hasSharedAxis ?\n (String(axMirror).indexOf('all') !== -1) : // 'all' or 'allticks'\n !!axMirror; // all but false\n mirrorTicks = hasSharedAxis ?\n (axMirror === 'allticks') :\n (String(axMirror).indexOf('ticks') !== -1); // 'ticks' or 'allticks'\n\n // Axis titles and tick labels can only appear of one side of the scene\n // and are never show on subplots that share existing axes.\n\n if(hasAxisInDfltPos) this.labelEnable[i] = true;\n else if(hasAxisInAltrPos) this.labelEnable[i + 2] = true;\n\n if(hasAxisInDfltPos) this.tickEnable[i] = ax.showticklabels;\n else if(hasAxisInAltrPos) this.tickEnable[i + 2] = ax.showticklabels;\n\n // Grid lines and ticks can appear on both sides of the scene\n // and can appear on subplot that share existing axes via `ax.mirror`.\n\n if(hasAxisInDfltPos || mirrorLines) this.borderLineEnable[i] = ax.showline;\n if(hasAxisInAltrPos || mirrorLines) this.borderLineEnable[i + 2] = ax.showline;\n\n if(hasAxisInDfltPos || mirrorTicks) this.tickMarkLength[i] = this.getTickMarkLength(ax);\n if(hasAxisInAltrPos || mirrorTicks) this.tickMarkLength[i + 2] = this.getTickMarkLength(ax);\n\n this.gridLineEnable[i] = ax.showgrid;\n this.gridLineColor[i] = str2RGBArray(ax.gridcolor);\n this.gridLineWidth[i] = ax.gridwidth;\n\n this.zeroLineEnable[i] = ax.zeroline;\n this.zeroLineColor[i] = str2RGBArray(ax.zerolinecolor);\n this.zeroLineWidth[i] = ax.zerolinewidth;\n }\n};\n\n// is an axis shared with an already-drawn subplot ?\nproto.hasSharedAxis = function(ax) {\n var scene = this.scene;\n var subplotIds = scene.fullLayout._subplots.gl2d;\n var list = Axes.findSubplotsWithAxis(subplotIds, ax);\n\n // if index === 0, then the subplot is already drawn as subplots\n // are drawn in order.\n return (list.indexOf(scene.id) !== 0);\n};\n\n// has an axis in default position (i.e. bottom/left) ?\nproto.hasAxisInDfltPos = function(axisName, ax) {\n var axSide = ax.side;\n\n if(axisName === 'xaxis') return (axSide === 'bottom');\n else if(axisName === 'yaxis') return (axSide === 'left');\n};\n\n// has an axis in alternate position (i.e. top/right) ?\nproto.hasAxisInAltrPos = function(axisName, ax) {\n var axSide = ax.side;\n\n if(axisName === 'xaxis') return (axSide === 'top');\n else if(axisName === 'yaxis') return (axSide === 'right');\n};\n\nproto.getLabelPad = function(axisName, ax) {\n var offsetBase = 1.5;\n var fontSize = ax.title.font.size;\n var showticklabels = ax.showticklabels;\n\n if(axisName === 'xaxis') {\n return (ax.side === 'top') ?\n -10 + fontSize * (offsetBase + (showticklabels ? 1 : 0)) :\n -10 + fontSize * (offsetBase + (showticklabels ? 0.5 : 0));\n } else if(axisName === 'yaxis') {\n return (ax.side === 'right') ?\n 10 + fontSize * (offsetBase + (showticklabels ? 1 : 0.5)) :\n 10 + fontSize * (offsetBase + (showticklabels ? 0.5 : 0));\n }\n};\n\nproto.getTickPad = function(ax) {\n return (ax.ticks === 'outside') ? 10 + ax.ticklen : 15;\n};\n\nproto.getTickMarkLength = function(ax) {\n if(!ax.ticks) return 0;\n\n var ticklen = ax.ticklen;\n\n return (ax.ticks === 'inside') ? -ticklen : ticklen;\n};\n\n\nfunction createAxes2D(scene) {\n return new Axes2DOptions(scene);\n}\n\nmodule.exports = createAxes2D;\n","'use strict';\n\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\n\nvar Scene2D = require('./scene2d');\nvar layoutGlobalAttrs = require('../layout_attributes');\nvar xmlnsNamespaces = require('../../constants/xmlns_namespaces');\nvar constants = require('../cartesian/constants');\nvar Cartesian = require('../cartesian');\nvar fxAttrs = require('../../components/fx/layout_attributes');\nvar getSubplotData = require('../get_data').getSubplotData;\n\nexports.name = 'gl2d';\n\nexports.attr = ['xaxis', 'yaxis'];\n\nexports.idRoot = ['x', 'y'];\n\nexports.idRegex = constants.idRegex;\n\nexports.attrRegex = constants.attrRegex;\n\nexports.attributes = require('../cartesian/attributes');\n\nexports.supplyLayoutDefaults = function(layoutIn, layoutOut, fullData) {\n if(!layoutOut._has('cartesian')) {\n Cartesian.supplyLayoutDefaults(layoutIn, layoutOut, fullData);\n }\n};\n\n// gl2d uses svg axis attributes verbatim, but overrides editType\n// this could potentially be just `layoutAttributes` but it would\n// still need special handling somewhere to give it precedence over\n// the svg version when both are in use on one plot\nexports.layoutAttrOverrides = overrideAll(Cartesian.layoutAttributes, 'plot', 'from-root');\n\n// similar overrides for base plot attributes (and those added by components)\nexports.baseLayoutAttrOverrides = overrideAll({\n plot_bgcolor: layoutGlobalAttrs.plot_bgcolor,\n hoverlabel: fxAttrs.hoverlabel\n // dragmode needs calc but only when transitioning TO lasso or select\n // so for now it's left inside _relayout\n // dragmode: fxAttrs.dragmode\n}, 'plot', 'nested');\n\nexports.plot = function plot(gd) {\n var fullLayout = gd._fullLayout;\n var fullData = gd._fullData;\n var subplotIds = fullLayout._subplots.gl2d;\n\n for(var i = 0; i < subplotIds.length; i++) {\n var subplotId = subplotIds[i];\n var subplotObj = fullLayout._plots[subplotId];\n var fullSubplotData = getSubplotData(fullData, 'gl2d', subplotId);\n\n // ref. to corresp. Scene instance\n var scene = subplotObj._scene2d;\n\n // If Scene is not instantiated, create one!\n if(scene === undefined) {\n scene = new Scene2D({\n id: subplotId,\n graphDiv: gd,\n container: gd.querySelector('.gl-container'),\n staticPlot: gd._context.staticPlot,\n plotGlPixelRatio: gd._context.plotGlPixelRatio\n },\n fullLayout\n );\n\n // set ref to Scene instance\n subplotObj._scene2d = scene;\n }\n\n scene.plot(fullSubplotData, gd.calcdata, fullLayout, gd.layout);\n }\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var oldSceneKeys = oldFullLayout._subplots.gl2d || [];\n\n for(var i = 0; i < oldSceneKeys.length; i++) {\n var id = oldSceneKeys[i];\n var oldSubplot = oldFullLayout._plots[id];\n\n // old subplot wasn't gl2d; nothing to do\n if(!oldSubplot._scene2d) continue;\n\n // if no traces are present, delete gl2d subplot\n var subplotData = getSubplotData(newFullData, 'gl2d', id);\n if(subplotData.length === 0) {\n oldSubplot._scene2d.destroy();\n delete oldFullLayout._plots[id];\n }\n }\n\n // since we use cartesian interactions, do cartesian clean\n Cartesian.clean.apply(this, arguments);\n};\n\nexports.drawFramework = function(gd) {\n if(!gd._context.staticPlot) {\n Cartesian.drawFramework(gd);\n }\n};\n\nexports.toSVG = function(gd) {\n var fullLayout = gd._fullLayout;\n var subplotIds = fullLayout._subplots.gl2d;\n\n for(var i = 0; i < subplotIds.length; i++) {\n var subplot = fullLayout._plots[subplotIds[i]];\n var scene = subplot._scene2d;\n\n var imageData = scene.toImage('png');\n var image = fullLayout._glimages.append('svg:image');\n\n image.attr({\n xmlns: xmlnsNamespaces.svg,\n 'xlink:href': imageData,\n x: 0,\n y: 0,\n width: '100%',\n height: '100%',\n preserveAspectRatio: 'none'\n });\n\n scene.destroy();\n }\n};\n\nexports.updateFx = function(gd) {\n var fullLayout = gd._fullLayout;\n var subplotIds = fullLayout._subplots.gl2d;\n\n for(var i = 0; i < subplotIds.length; i++) {\n var subplotObj = fullLayout._plots[subplotIds[i]]._scene2d;\n subplotObj.updateFx(fullLayout.dragmode);\n }\n};\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Axes = require('../../plots/cartesian/axes');\nvar Fx = require('../../components/fx');\n\nvar createPlot2D = require('../../../stackgl_modules').gl_plot2d;\nvar createSpikes = require('../../../stackgl_modules').gl_spikes2d;\nvar createSelectBox = require('../../../stackgl_modules').gl_select_box;\nvar getContext = require('webgl-context');\n\nvar createOptions = require('./convert');\nvar createCamera = require('./camera');\nvar showNoWebGlMsg = require('../../lib/show_no_webgl_msg');\nvar axisConstraints = require('../cartesian/constraints');\nvar enforceAxisConstraints = axisConstraints.enforce;\nvar cleanAxisConstraints = axisConstraints.clean;\nvar doAutoRange = require('../cartesian/autorange').doAutoRange;\n\nvar dragHelpers = require('../../components/dragelement/helpers');\nvar drawMode = dragHelpers.drawMode;\nvar selectMode = dragHelpers.selectMode;\n\nvar AXES = ['xaxis', 'yaxis'];\nvar STATIC_CANVAS, STATIC_CONTEXT;\n\nvar SUBPLOT_PATTERN = require('../cartesian/constants').SUBPLOT_PATTERN;\n\n\nfunction Scene2D(options, fullLayout) {\n this.container = options.container;\n this.graphDiv = options.graphDiv;\n this.pixelRatio = options.plotGlPixelRatio || window.devicePixelRatio;\n this.id = options.id;\n this.staticPlot = !!options.staticPlot;\n this.scrollZoom = this.graphDiv._context._scrollZoom.cartesian;\n\n this.fullData = null;\n this.updateRefs(fullLayout);\n\n this.makeFramework();\n if(this.stopped) return;\n\n // update options\n this.glplotOptions = createOptions(this);\n this.glplotOptions.merge(fullLayout);\n\n // create the plot\n this.glplot = createPlot2D(this.glplotOptions);\n\n // create camera\n this.camera = createCamera(this);\n\n // trace set\n this.traces = {};\n\n // create axes spikes\n this.spikes = createSpikes(this.glplot);\n\n this.selectBox = createSelectBox(this.glplot, {\n innerFill: false,\n outerFill: true\n });\n\n // last button state\n this.lastButtonState = 0;\n\n // last pick result\n this.pickResult = null;\n\n // is the mouse over the plot?\n // it's OK if this says true when it's not, so long as\n // when we get a mouseout we set it to false before handling\n this.isMouseOver = true;\n\n // flag to stop render loop\n this.stopped = false;\n\n // redraw the plot\n this.redraw = this.draw.bind(this);\n this.redraw();\n}\n\nmodule.exports = Scene2D;\n\nvar proto = Scene2D.prototype;\n\nproto.makeFramework = function() {\n // create canvas and gl context\n if(this.staticPlot) {\n if(!STATIC_CONTEXT) {\n STATIC_CANVAS = document.createElement('canvas');\n\n STATIC_CONTEXT = getContext({\n canvas: STATIC_CANVAS,\n preserveDrawingBuffer: false,\n premultipliedAlpha: true,\n antialias: true\n });\n\n if(!STATIC_CONTEXT) {\n throw new Error('Error creating static canvas/context for image server');\n }\n }\n\n this.canvas = STATIC_CANVAS;\n this.gl = STATIC_CONTEXT;\n } else {\n var liveCanvas = this.container.querySelector('.gl-canvas-focus');\n\n var gl = getContext({\n canvas: liveCanvas,\n preserveDrawingBuffer: true,\n premultipliedAlpha: true\n });\n\n if(!gl) {\n showNoWebGlMsg(this);\n this.stopped = true;\n return;\n }\n\n this.canvas = liveCanvas;\n this.gl = gl;\n }\n\n // position the canvas\n var canvas = this.canvas;\n\n canvas.style.width = '100%';\n canvas.style.height = '100%';\n canvas.style.position = 'absolute';\n canvas.style.top = '0px';\n canvas.style.left = '0px';\n canvas.style['pointer-events'] = 'none';\n\n this.updateSize(canvas);\n\n // create SVG container for hover text\n var svgContainer = this.svgContainer = document.createElementNS(\n 'http://www.w3.org/2000/svg',\n 'svg');\n svgContainer.style.position = 'absolute';\n svgContainer.style.top = svgContainer.style.left = '0px';\n svgContainer.style.width = svgContainer.style.height = '100%';\n svgContainer.style['z-index'] = 20;\n svgContainer.style['pointer-events'] = 'none';\n\n // create div to catch the mouse event\n var mouseContainer = this.mouseContainer = document.createElement('div');\n mouseContainer.style.position = 'absolute';\n mouseContainer.style['pointer-events'] = 'auto';\n\n this.pickCanvas = this.container.querySelector('.gl-canvas-pick');\n\n\n // append canvas, hover svg and mouse div to container\n var container = this.container;\n container.appendChild(svgContainer);\n container.appendChild(mouseContainer);\n\n var self = this;\n mouseContainer.addEventListener('mouseout', function() {\n self.isMouseOver = false;\n self.unhover();\n });\n mouseContainer.addEventListener('mouseover', function() {\n self.isMouseOver = true;\n });\n};\n\nproto.toImage = function(format) {\n if(!format) format = 'png';\n\n this.stopped = true;\n\n if(this.staticPlot) this.container.appendChild(STATIC_CANVAS);\n\n // update canvas size\n this.updateSize(this.canvas);\n\n\n // grab context and yank out pixels\n var gl = this.glplot.gl;\n var w = gl.drawingBufferWidth;\n var h = gl.drawingBufferHeight;\n\n // force redraw\n gl.clearColor(1, 1, 1, 0);\n gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);\n this.glplot.setDirty();\n this.glplot.draw();\n\n gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n\n var pixels = new Uint8Array(w * h * 4);\n gl.readPixels(0, 0, w, h, gl.RGBA, gl.UNSIGNED_BYTE, pixels);\n\n // flip pixels\n for(var j = 0, k = h - 1; j < k; ++j, --k) {\n for(var i = 0; i < w; ++i) {\n for(var l = 0; l < 4; ++l) {\n var tmp = pixels[4 * (w * j + i) + l];\n pixels[4 * (w * j + i) + l] = pixels[4 * (w * k + i) + l];\n pixels[4 * (w * k + i) + l] = tmp;\n }\n }\n }\n\n var canvas = document.createElement('canvas');\n canvas.width = w;\n canvas.height = h;\n\n var context = canvas.getContext('2d', {willReadFrequently: true});\n var imageData = context.createImageData(w, h);\n imageData.data.set(pixels);\n context.putImageData(imageData, 0, 0);\n\n var dataURL;\n\n switch(format) {\n case 'jpeg':\n dataURL = canvas.toDataURL('image/jpeg');\n break;\n case 'webp':\n dataURL = canvas.toDataURL('image/webp');\n break;\n default:\n dataURL = canvas.toDataURL('image/png');\n }\n\n if(this.staticPlot) this.container.removeChild(STATIC_CANVAS);\n\n return dataURL;\n};\n\nproto.updateSize = function(canvas) {\n if(!canvas) canvas = this.canvas;\n\n var pixelRatio = this.pixelRatio;\n var fullLayout = this.fullLayout;\n\n var width = fullLayout.width;\n var height = fullLayout.height;\n var pixelWidth = Math.ceil(pixelRatio * width) |0;\n var pixelHeight = Math.ceil(pixelRatio * height) |0;\n\n // check for resize\n if(canvas.width !== pixelWidth || canvas.height !== pixelHeight) {\n canvas.width = pixelWidth;\n canvas.height = pixelHeight;\n }\n\n return canvas;\n};\n\nproto.computeTickMarks = function() {\n this.xaxis.setScale();\n this.yaxis.setScale();\n\n var nextTicks = [\n Axes.calcTicks(this.xaxis),\n Axes.calcTicks(this.yaxis)\n ];\n\n for(var j = 0; j < 2; ++j) {\n for(var i = 0; i < nextTicks[j].length; ++i) {\n // coercing tick value (may not be a string) to a string\n nextTicks[j][i].text = nextTicks[j][i].text + '';\n }\n }\n\n return nextTicks;\n};\n\nfunction compareTicks(a, b) {\n for(var i = 0; i < 2; ++i) {\n var aticks = a[i];\n var bticks = b[i];\n\n if(aticks.length !== bticks.length) return true;\n\n for(var j = 0; j < aticks.length; ++j) {\n if(aticks[j].x !== bticks[j].x) return true;\n }\n }\n\n return false;\n}\n\nproto.updateRefs = function(newFullLayout) {\n this.fullLayout = newFullLayout;\n\n var spmatch = this.id.match(SUBPLOT_PATTERN);\n var xaxisName = 'xaxis' + spmatch[1];\n var yaxisName = 'yaxis' + spmatch[2];\n\n this.xaxis = this.fullLayout[xaxisName];\n this.yaxis = this.fullLayout[yaxisName];\n};\n\nproto.relayoutCallback = function() {\n var graphDiv = this.graphDiv;\n var xaxis = this.xaxis;\n var yaxis = this.yaxis;\n var layout = graphDiv.layout;\n\n // make a meaningful value to be passed on to possible 'plotly_relayout' subscriber(s)\n var update = {};\n var xrange = update[xaxis._name + '.range'] = xaxis.range.slice();\n var yrange = update[yaxis._name + '.range'] = yaxis.range.slice();\n update[xaxis._name + '.autorange'] = xaxis.autorange;\n update[yaxis._name + '.autorange'] = yaxis.autorange;\n\n Registry.call('_storeDirectGUIEdit', graphDiv.layout, graphDiv._fullLayout._preGUI, update);\n\n // update the input layout\n var xaIn = layout[xaxis._name];\n xaIn.range = xrange;\n xaIn.autorange = xaxis.autorange;\n\n var yaIn = layout[yaxis._name];\n yaIn.range = yrange;\n yaIn.autorange = yaxis.autorange;\n\n // lastInputTime helps determine which one is the latest input (if async)\n update.lastInputTime = this.camera.lastInputTime;\n graphDiv.emit('plotly_relayout', update);\n};\n\nproto.cameraChanged = function() {\n var camera = this.camera;\n\n this.glplot.setDataBox(this.calcDataBox());\n\n var nextTicks = this.computeTickMarks();\n var curTicks = this.glplotOptions.ticks;\n\n if(compareTicks(nextTicks, curTicks)) {\n this.glplotOptions.ticks = nextTicks;\n this.glplotOptions.dataBox = camera.dataBox;\n this.glplot.update(this.glplotOptions);\n this.handleAnnotations();\n }\n};\n\nproto.handleAnnotations = function() {\n var gd = this.graphDiv;\n var annotations = this.fullLayout.annotations;\n\n for(var i = 0; i < annotations.length; i++) {\n var ann = annotations[i];\n\n if(ann.xref === this.xaxis._id && ann.yref === this.yaxis._id) {\n Registry.getComponentMethod('annotations', 'drawOne')(gd, i);\n }\n }\n};\n\nproto.destroy = function() {\n if(!this.glplot) return;\n\n var traces = this.traces;\n\n if(traces) {\n Object.keys(traces).map(function(key) {\n traces[key].dispose();\n delete traces[key];\n });\n }\n\n this.glplot.dispose();\n\n this.container.removeChild(this.svgContainer);\n this.container.removeChild(this.mouseContainer);\n\n this.fullData = null;\n this.glplot = null;\n this.stopped = true;\n this.camera.mouseListener.enabled = false;\n this.mouseContainer.removeEventListener('wheel', this.camera.wheelListener);\n this.camera = null;\n};\n\nproto.plot = function(fullData, calcData, fullLayout) {\n var glplot = this.glplot;\n\n this.updateRefs(fullLayout);\n this.xaxis.clearCalc();\n this.yaxis.clearCalc();\n this.updateTraces(fullData, calcData);\n this.updateFx(fullLayout.dragmode);\n\n var width = fullLayout.width;\n var height = fullLayout.height;\n\n this.updateSize(this.canvas);\n\n var options = this.glplotOptions;\n options.merge(fullLayout);\n options.screenBox = [0, 0, width, height];\n\n var mockGraphDiv = {_fullLayout: {\n _axisConstraintGroups: fullLayout._axisConstraintGroups,\n xaxis: this.xaxis,\n yaxis: this.yaxis,\n _size: fullLayout._size\n }};\n\n cleanAxisConstraints(mockGraphDiv, this.xaxis);\n cleanAxisConstraints(mockGraphDiv, this.yaxis);\n\n var size = fullLayout._size;\n var domainX = this.xaxis.domain;\n var domainY = this.yaxis.domain;\n\n options.viewBox = [\n size.l + domainX[0] * size.w,\n size.b + domainY[0] * size.h,\n (width - size.r) - (1 - domainX[1]) * size.w,\n (height - size.t) - (1 - domainY[1]) * size.h\n ];\n\n this.mouseContainer.style.width = size.w * (domainX[1] - domainX[0]) + 'px';\n this.mouseContainer.style.height = size.h * (domainY[1] - domainY[0]) + 'px';\n this.mouseContainer.height = size.h * (domainY[1] - domainY[0]);\n this.mouseContainer.style.left = size.l + domainX[0] * size.w + 'px';\n this.mouseContainer.style.top = size.t + (1 - domainY[1]) * size.h + 'px';\n\n var ax, i;\n\n for(i = 0; i < 2; ++i) {\n ax = this[AXES[i]];\n ax._length = options.viewBox[i + 2] - options.viewBox[i];\n\n doAutoRange(this.graphDiv, ax);\n ax.setScale();\n }\n\n enforceAxisConstraints(mockGraphDiv);\n\n options.ticks = this.computeTickMarks();\n\n options.dataBox = this.calcDataBox();\n\n options.merge(fullLayout);\n glplot.update(options);\n\n // force redraw so that promise is returned when rendering is completed\n this.glplot.draw();\n};\n\nproto.calcDataBox = function() {\n var xaxis = this.xaxis;\n var yaxis = this.yaxis;\n var xrange = xaxis.range;\n var yrange = yaxis.range;\n var xr2l = xaxis.r2l;\n var yr2l = yaxis.r2l;\n\n return [xr2l(xrange[0]), yr2l(yrange[0]), xr2l(xrange[1]), yr2l(yrange[1])];\n};\n\nproto.setRanges = function(dataBox) {\n var xaxis = this.xaxis;\n var yaxis = this.yaxis;\n var xl2r = xaxis.l2r;\n var yl2r = yaxis.l2r;\n\n xaxis.range = [xl2r(dataBox[0]), xl2r(dataBox[2])];\n yaxis.range = [yl2r(dataBox[1]), yl2r(dataBox[3])];\n};\n\nproto.updateTraces = function(fullData, calcData) {\n var traceIds = Object.keys(this.traces);\n var i, j, fullTrace;\n\n this.fullData = fullData;\n\n // remove empty traces\n traceIdLoop:\n for(i = 0; i < traceIds.length; i++) {\n var oldUid = traceIds[i];\n var oldTrace = this.traces[oldUid];\n\n for(j = 0; j < fullData.length; j++) {\n fullTrace = fullData[j];\n\n if(fullTrace.uid === oldUid && fullTrace.type === oldTrace.type) {\n continue traceIdLoop;\n }\n }\n\n oldTrace.dispose();\n delete this.traces[oldUid];\n }\n\n // update / create trace objects\n for(i = 0; i < fullData.length; i++) {\n fullTrace = fullData[i];\n var calcTrace = calcData[i];\n var traceObj = this.traces[fullTrace.uid];\n\n if(traceObj) traceObj.update(fullTrace, calcTrace);\n else {\n traceObj = fullTrace._module.plot(this, fullTrace, calcTrace);\n this.traces[fullTrace.uid] = traceObj;\n }\n }\n\n // order object per traces\n this.glplot.objects.sort(function(a, b) {\n return a._trace.index - b._trace.index;\n });\n};\n\nproto.updateFx = function(dragmode) {\n // switch to svg interactions in lasso/select mode & shape drawing\n if(selectMode(dragmode) || drawMode(dragmode)) {\n this.pickCanvas.style['pointer-events'] = 'none';\n this.mouseContainer.style['pointer-events'] = 'none';\n } else {\n this.pickCanvas.style['pointer-events'] = 'auto';\n this.mouseContainer.style['pointer-events'] = 'auto';\n }\n\n // set proper cursor\n if(dragmode === 'pan') {\n this.mouseContainer.style.cursor = 'move';\n } else if(dragmode === 'zoom') {\n this.mouseContainer.style.cursor = 'crosshair';\n } else {\n this.mouseContainer.style.cursor = null;\n }\n};\n\nproto.emitPointAction = function(nextSelection, eventType) {\n var uid = nextSelection.trace.uid;\n var ptNumber = nextSelection.pointIndex;\n var trace;\n\n for(var i = 0; i < this.fullData.length; i++) {\n if(this.fullData[i].uid === uid) {\n trace = this.fullData[i];\n }\n }\n\n var pointData = {\n x: nextSelection.traceCoord[0],\n y: nextSelection.traceCoord[1],\n curveNumber: trace.index,\n pointNumber: ptNumber,\n data: trace._input,\n fullData: this.fullData,\n xaxis: this.xaxis,\n yaxis: this.yaxis\n };\n\n Fx.appendArrayPointValue(pointData, trace, ptNumber);\n\n this.graphDiv.emit(eventType, {points: [pointData]});\n};\n\nproto.draw = function() {\n if(this.stopped) return;\n\n requestAnimationFrame(this.redraw);\n\n var glplot = this.glplot;\n var camera = this.camera;\n var mouseListener = camera.mouseListener;\n var mouseUp = this.lastButtonState === 1 && mouseListener.buttons === 0;\n var fullLayout = this.fullLayout;\n\n this.lastButtonState = mouseListener.buttons;\n\n this.cameraChanged();\n\n var x = mouseListener.x * glplot.pixelRatio;\n var y = this.canvas.height - glplot.pixelRatio * mouseListener.y;\n\n var result;\n\n if(camera.boxEnabled && fullLayout.dragmode === 'zoom') {\n this.selectBox.enabled = true;\n\n var selectBox = this.selectBox.selectBox = [\n Math.min(camera.boxStart[0], camera.boxEnd[0]),\n Math.min(camera.boxStart[1], camera.boxEnd[1]),\n Math.max(camera.boxStart[0], camera.boxEnd[0]),\n Math.max(camera.boxStart[1], camera.boxEnd[1])\n ];\n\n // 1D zoom\n for(var i = 0; i < 2; i++) {\n if(camera.boxStart[i] === camera.boxEnd[i]) {\n selectBox[i] = glplot.dataBox[i];\n selectBox[i + 2] = glplot.dataBox[i + 2];\n }\n }\n\n glplot.setDirty();\n } else if(!camera.panning && this.isMouseOver) {\n this.selectBox.enabled = false;\n\n var size = fullLayout._size;\n var domainX = this.xaxis.domain;\n var domainY = this.yaxis.domain;\n\n result = glplot.pick(\n (x / glplot.pixelRatio) + size.l + domainX[0] * size.w,\n (y / glplot.pixelRatio) - (size.t + (1 - domainY[1]) * size.h)\n );\n\n var nextSelection = result && result.object._trace.handlePick(result);\n\n if(nextSelection && mouseUp) {\n this.emitPointAction(nextSelection, 'plotly_click');\n }\n\n if(result && result.object._trace.hoverinfo !== 'skip' && fullLayout.hovermode) {\n if(nextSelection && (\n !this.lastPickResult ||\n this.lastPickResult.traceUid !== nextSelection.trace.uid ||\n this.lastPickResult.dataCoord[0] !== nextSelection.dataCoord[0] ||\n this.lastPickResult.dataCoord[1] !== nextSelection.dataCoord[1])\n ) {\n var selection = nextSelection;\n\n this.lastPickResult = {\n traceUid: nextSelection.trace ? nextSelection.trace.uid : null,\n dataCoord: nextSelection.dataCoord.slice()\n };\n this.spikes.update({ center: result.dataCoord });\n\n selection.screenCoord = [\n ((glplot.viewBox[2] - glplot.viewBox[0]) *\n (result.dataCoord[0] - glplot.dataBox[0]) /\n (glplot.dataBox[2] - glplot.dataBox[0]) + glplot.viewBox[0]) /\n glplot.pixelRatio,\n (this.canvas.height - (glplot.viewBox[3] - glplot.viewBox[1]) *\n (result.dataCoord[1] - glplot.dataBox[1]) /\n (glplot.dataBox[3] - glplot.dataBox[1]) - glplot.viewBox[1]) /\n glplot.pixelRatio\n ];\n\n // this needs to happen before the next block that deletes traceCoord data\n // also it's important to copy, otherwise data is lost by the time event data is read\n this.emitPointAction(nextSelection, 'plotly_hover');\n\n var trace = this.fullData[selection.trace.index] || {};\n var ptNumber = selection.pointIndex;\n var hoverinfo = Fx.castHoverinfo(trace, fullLayout, ptNumber);\n\n if(hoverinfo && hoverinfo !== 'all') {\n var parts = hoverinfo.split('+');\n if(parts.indexOf('x') === -1) selection.traceCoord[0] = undefined;\n if(parts.indexOf('y') === -1) selection.traceCoord[1] = undefined;\n if(parts.indexOf('z') === -1) selection.traceCoord[2] = undefined;\n if(parts.indexOf('text') === -1) selection.textLabel = undefined;\n if(parts.indexOf('name') === -1) selection.name = undefined;\n }\n\n Fx.loneHover({\n x: selection.screenCoord[0],\n y: selection.screenCoord[1],\n xLabel: this.hoverFormatter('xaxis', selection.traceCoord[0]),\n yLabel: this.hoverFormatter('yaxis', selection.traceCoord[1]),\n zLabel: selection.traceCoord[2],\n text: selection.textLabel,\n name: selection.name,\n color: Fx.castHoverOption(trace, ptNumber, 'bgcolor') || selection.color,\n borderColor: Fx.castHoverOption(trace, ptNumber, 'bordercolor'),\n fontFamily: Fx.castHoverOption(trace, ptNumber, 'font.family'),\n fontSize: Fx.castHoverOption(trace, ptNumber, 'font.size'),\n fontColor: Fx.castHoverOption(trace, ptNumber, 'font.color'),\n nameLength: Fx.castHoverOption(trace, ptNumber, 'namelength'),\n textAlign: Fx.castHoverOption(trace, ptNumber, 'align')\n }, {\n container: this.svgContainer,\n gd: this.graphDiv\n });\n }\n }\n }\n\n // Remove hover effects if we're not over a point OR\n // if we're zooming or panning (in which case result is not set)\n if(!result) {\n this.unhover();\n }\n\n glplot.draw();\n};\n\nproto.unhover = function() {\n if(this.lastPickResult) {\n this.spikes.update({});\n this.lastPickResult = null;\n this.graphDiv.emit('plotly_unhover');\n Fx.loneUnhover(this.svgContainer);\n }\n};\n\nproto.hoverFormatter = function(axisName, val) {\n if(val === undefined) return undefined;\n\n var axis = this[axisName];\n return Axes.tickText(axis, axis.c2l(val), 'hover').text;\n};\n","'use strict';\n\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar fxAttrs = require('../../components/fx/layout_attributes');\n\nvar Scene = require('./scene');\nvar getSubplotData = require('../get_data').getSubplotData;\nvar Lib = require('../../lib');\nvar xmlnsNamespaces = require('../../constants/xmlns_namespaces');\n\nvar GL3D = 'gl3d';\nvar SCENE = 'scene';\n\n\nexports.name = GL3D;\n\nexports.attr = SCENE;\n\nexports.idRoot = SCENE;\n\nexports.idRegex = exports.attrRegex = Lib.counterRegex('scene');\n\nexports.attributes = require('./layout/attributes');\n\nexports.layoutAttributes = require('./layout/layout_attributes');\n\nexports.baseLayoutAttrOverrides = overrideAll({\n hoverlabel: fxAttrs.hoverlabel\n}, 'plot', 'nested');\n\nexports.supplyLayoutDefaults = require('./layout/defaults');\n\nexports.plot = function plot(gd) {\n var fullLayout = gd._fullLayout;\n var fullData = gd._fullData;\n var sceneIds = fullLayout._subplots[GL3D];\n\n for(var i = 0; i < sceneIds.length; i++) {\n var sceneId = sceneIds[i];\n var fullSceneData = getSubplotData(fullData, GL3D, sceneId);\n var sceneLayout = fullLayout[sceneId];\n var camera = sceneLayout.camera;\n var scene = sceneLayout._scene;\n\n if(!scene) {\n scene = new Scene({\n id: sceneId,\n graphDiv: gd,\n container: gd.querySelector('.gl-container'),\n staticPlot: gd._context.staticPlot,\n plotGlPixelRatio: gd._context.plotGlPixelRatio,\n camera: camera\n },\n fullLayout\n );\n\n // set ref to Scene instance\n sceneLayout._scene = scene;\n }\n\n // save 'initial' camera view settings for modebar button\n if(!scene.viewInitial) {\n scene.viewInitial = {\n up: {\n x: camera.up.x,\n y: camera.up.y,\n z: camera.up.z\n },\n eye: {\n x: camera.eye.x,\n y: camera.eye.y,\n z: camera.eye.z\n },\n center: {\n x: camera.center.x,\n y: camera.center.y,\n z: camera.center.z\n }\n };\n }\n\n scene.plot(fullSceneData, fullLayout, gd.layout);\n }\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var oldSceneKeys = oldFullLayout._subplots[GL3D] || [];\n\n for(var i = 0; i < oldSceneKeys.length; i++) {\n var oldSceneKey = oldSceneKeys[i];\n\n if(!newFullLayout[oldSceneKey] && !!oldFullLayout[oldSceneKey]._scene) {\n oldFullLayout[oldSceneKey]._scene.destroy();\n\n if(oldFullLayout._infolayer) {\n oldFullLayout._infolayer\n .selectAll('.annotation-' + oldSceneKey)\n .remove();\n }\n }\n }\n};\n\nexports.toSVG = function(gd) {\n var fullLayout = gd._fullLayout;\n var sceneIds = fullLayout._subplots[GL3D];\n var size = fullLayout._size;\n\n for(var i = 0; i < sceneIds.length; i++) {\n var sceneLayout = fullLayout[sceneIds[i]];\n var domain = sceneLayout.domain;\n var scene = sceneLayout._scene;\n\n var imageData = scene.toImage('png');\n var image = fullLayout._glimages.append('svg:image');\n\n image.attr({\n xmlns: xmlnsNamespaces.svg,\n 'xlink:href': imageData,\n x: size.l + size.w * domain.x[0],\n y: size.t + size.h * (1 - domain.y[1]),\n width: size.w * (domain.x[1] - domain.x[0]),\n height: size.h * (domain.y[1] - domain.y[0]),\n preserveAspectRatio: 'none'\n });\n\n scene.destroy();\n }\n};\n\n// clean scene ids, 'scene1' -> 'scene'\nexports.cleanId = function cleanId(id) {\n if(!id.match(/^scene[0-9]*$/)) return;\n\n var sceneNum = id.substr(5);\n if(sceneNum === '1') sceneNum = '';\n\n return SCENE + sceneNum;\n};\n\nexports.updateFx = function(gd) {\n var fullLayout = gd._fullLayout;\n var subplotIds = fullLayout._subplots[GL3D];\n\n for(var i = 0; i < subplotIds.length; i++) {\n var subplotObj = fullLayout[subplotIds[i]]._scene;\n subplotObj.updateFx(fullLayout.dragmode, fullLayout.hovermode);\n }\n};\n","'use strict';\n\n\nmodule.exports = {\n scene: {\n valType: 'subplotid',\n dflt: 'scene',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets a reference between this trace\\'s 3D coordinate system and',\n 'a 3D scene.',\n 'If *scene* (the default value), the (x,y,z) coordinates refer to',\n '`layout.scene`.',\n 'If *scene2*, the (x,y,z) coordinates refer to `layout.scene2`,',\n 'and so on.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Color = require('../../../components/color');\nvar axesAttrs = require('../../cartesian/layout_attributes');\nvar extendFlat = require('../../../lib/extend').extendFlat;\nvar overrideAll = require('../../../plot_api/edit_types').overrideAll;\n\nmodule.exports = overrideAll({\n visible: axesAttrs.visible,\n showspikes: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Sets whether or not spikes starting from',\n 'data points to this axis\\' wall are shown on hover.'\n ].join(' ')\n },\n spikesides: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Sets whether or not spikes extending from the',\n 'projection data points to this axis\\' wall boundaries',\n 'are shown on hover.'\n ].join(' ')\n },\n spikethickness: {\n valType: 'number',\n min: 0,\n dflt: 2,\n description: 'Sets the thickness (in px) of the spikes.'\n },\n spikecolor: {\n valType: 'color',\n dflt: Color.defaultLine,\n description: 'Sets the color of the spikes.'\n },\n showbackground: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Sets whether or not this axis\\' wall',\n 'has a background color.'\n ].join(' ')\n },\n backgroundcolor: {\n valType: 'color',\n dflt: 'rgba(204, 204, 204, 0.5)',\n description: 'Sets the background color of this axis\\' wall.'\n },\n showaxeslabels: {\n valType: 'boolean',\n dflt: true,\n description: 'Sets whether or not this axis is labeled'\n },\n color: axesAttrs.color,\n categoryorder: axesAttrs.categoryorder,\n categoryarray: axesAttrs.categoryarray,\n title: {\n text: axesAttrs.title.text,\n font: axesAttrs.title.font\n },\n type: extendFlat({}, axesAttrs.type, {\n values: ['-', 'linear', 'log', 'date', 'category']\n }),\n autotypenumbers: axesAttrs.autotypenumbers,\n autorange: axesAttrs.autorange,\n autorangeoptions: {\n minallowed: axesAttrs.autorangeoptions.minallowed,\n maxallowed: axesAttrs.autorangeoptions.maxallowed,\n clipmin: axesAttrs.autorangeoptions.clipmin,\n clipmax: axesAttrs.autorangeoptions.clipmax,\n include: axesAttrs.autorangeoptions.include,\n editType: 'plot'\n },\n rangemode: axesAttrs.rangemode,\n minallowed: axesAttrs.minallowed,\n maxallowed: axesAttrs.maxallowed,\n range: extendFlat({}, axesAttrs.range, {\n items: [\n {valType: 'any', editType: 'plot', impliedEdits: {'^autorange': false}},\n {valType: 'any', editType: 'plot', impliedEdits: {'^autorange': false}}\n ],\n anim: false\n }),\n // ticks\n tickmode: axesAttrs.minor.tickmode,\n nticks: axesAttrs.nticks,\n tick0: axesAttrs.tick0,\n dtick: axesAttrs.dtick,\n tickvals: axesAttrs.tickvals,\n ticktext: axesAttrs.ticktext,\n ticks: axesAttrs.ticks,\n mirror: axesAttrs.mirror,\n ticklen: axesAttrs.ticklen,\n tickwidth: axesAttrs.tickwidth,\n tickcolor: axesAttrs.tickcolor,\n showticklabels: axesAttrs.showticklabels,\n labelalias: axesAttrs.labelalias,\n tickfont: axesAttrs.tickfont,\n tickangle: axesAttrs.tickangle,\n tickprefix: axesAttrs.tickprefix,\n showtickprefix: axesAttrs.showtickprefix,\n ticksuffix: axesAttrs.ticksuffix,\n showticksuffix: axesAttrs.showticksuffix,\n showexponent: axesAttrs.showexponent,\n exponentformat: axesAttrs.exponentformat,\n minexponent: axesAttrs.minexponent,\n separatethousands: axesAttrs.separatethousands,\n tickformat: axesAttrs.tickformat,\n tickformatstops: axesAttrs.tickformatstops,\n hoverformat: axesAttrs.hoverformat,\n // lines and grids\n showline: axesAttrs.showline,\n linecolor: axesAttrs.linecolor,\n linewidth: axesAttrs.linewidth,\n showgrid: axesAttrs.showgrid,\n gridcolor: extendFlat({}, axesAttrs.gridcolor, // shouldn't this be on-par with 2D?\n {dflt: 'rgb(204, 204, 204)'}),\n gridwidth: axesAttrs.gridwidth,\n zeroline: axesAttrs.zeroline,\n zerolinecolor: axesAttrs.zerolinecolor,\n zerolinewidth: axesAttrs.zerolinewidth,\n _deprecated: {\n title: axesAttrs._deprecated.title,\n titlefont: axesAttrs._deprecated.titlefont\n }\n}, 'plot', 'from-root');\n","'use strict';\n\nvar colorMix = require('tinycolor2').mix;\n\nvar Lib = require('../../../lib');\nvar Template = require('../../../plot_api/plot_template');\n\nvar layoutAttributes = require('./axis_attributes');\nvar handleTypeDefaults = require('../../cartesian/type_defaults');\nvar handleAxisDefaults = require('../../cartesian/axis_defaults');\n\nvar axesNames = ['xaxis', 'yaxis', 'zaxis'];\n\n// TODO: hard-coded lightness fraction based on gridline default colors\n// that differ from other subplot types.\nvar gridLightness = 100 * (204 - 0x44) / (255 - 0x44);\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut, options) {\n var containerIn, containerOut;\n\n function coerce(attr, dflt) {\n return Lib.coerce(containerIn, containerOut, layoutAttributes, attr, dflt);\n }\n\n for(var j = 0; j < axesNames.length; j++) {\n var axName = axesNames[j];\n containerIn = layoutIn[axName] || {};\n\n containerOut = Template.newContainer(layoutOut, axName);\n containerOut._id = axName[0] + options.scene;\n containerOut._name = axName;\n\n handleTypeDefaults(containerIn, containerOut, coerce, options);\n\n handleAxisDefaults(\n containerIn,\n containerOut,\n coerce,\n {\n font: options.font,\n letter: axName[0],\n data: options.data,\n showGrid: true,\n noAutotickangles: true,\n noTicklabelindex: true,\n noTickson: true,\n noTicklabelmode: true,\n noTicklabelshift: true,\n noTicklabelstandoff: true,\n noTicklabelstep: true,\n noTicklabelposition: true,\n noTicklabeloverflow: true,\n noInsiderange: true,\n bgColor: options.bgColor,\n calendar: options.calendar\n },\n options.fullLayout);\n\n coerce('gridcolor', colorMix(containerOut.color, options.bgColor, gridLightness).toRgbString());\n coerce('title.text', axName[0]); // shouldn't this be on-par with 2D?\n\n containerOut.setScale = Lib.noop;\n\n if(coerce('showspikes')) {\n coerce('spikesides');\n coerce('spikethickness');\n coerce('spikecolor', containerOut.color);\n }\n\n coerce('showaxeslabels');\n if(coerce('showbackground')) coerce('backgroundcolor');\n }\n};\n","'use strict';\n\nvar str2RgbaArray = require('../../../lib/str2rgbarray');\nvar Lib = require('../../../lib');\n\nvar AXES_NAMES = ['xaxis', 'yaxis', 'zaxis'];\n\nfunction AxesOptions() {\n this.bounds = [\n [-10, -10, -10],\n [10, 10, 10]\n ];\n\n this.ticks = [ [], [], [] ];\n this.tickEnable = [ true, true, true ];\n this.tickFont = [ 'sans-serif', 'sans-serif', 'sans-serif' ];\n this.tickSize = [ 12, 12, 12 ];\n this.tickFontWeight = [ 'normal', 'normal', 'normal', 'normal' ];\n this.tickFontStyle = [ 'normal', 'normal', 'normal', 'normal' ];\n this.tickFontVariant = [ 'normal', 'normal', 'normal', 'normal' ];\n this.tickAngle = [ 0, 0, 0 ];\n this.tickColor = [ [0, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 1] ];\n this.tickPad = [ 18, 18, 18 ];\n\n this.labels = [ 'x', 'y', 'z' ];\n this.labelEnable = [ true, true, true ];\n this.labelFont = ['Open Sans', 'Open Sans', 'Open Sans'];\n this.labelSize = [ 20, 20, 20 ];\n this.labelFontWeight = [ 'normal', 'normal', 'normal', 'normal' ];\n this.labelFontStyle = [ 'normal', 'normal', 'normal', 'normal' ];\n this.labelFontVariant = [ 'normal', 'normal', 'normal', 'normal' ];\n this.labelColor = [ [0, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 1] ];\n this.labelPad = [ 30, 30, 30 ];\n\n this.lineEnable = [ true, true, true ];\n this.lineMirror = [ false, false, false ];\n this.lineWidth = [ 1, 1, 1 ];\n this.lineColor = [ [0, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 1] ];\n\n this.lineTickEnable = [ true, true, true ];\n this.lineTickMirror = [ false, false, false ];\n this.lineTickLength = [ 10, 10, 10 ];\n this.lineTickWidth = [ 1, 1, 1 ];\n this.lineTickColor = [ [0, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 1] ];\n\n this.gridEnable = [ true, true, true ];\n this.gridWidth = [ 1, 1, 1 ];\n this.gridColor = [ [0, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 1] ];\n\n this.zeroEnable = [ true, true, true ];\n this.zeroLineColor = [ [0, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 1] ];\n this.zeroLineWidth = [ 2, 2, 2 ];\n\n this.backgroundEnable = [ true, true, true ];\n this.backgroundColor = [ [0.8, 0.8, 0.8, 0.5],\n [0.8, 0.8, 0.8, 0.5],\n [0.8, 0.8, 0.8, 0.5] ];\n\n // some default values are stored for applying model transforms\n this._defaultTickPad = this.tickPad.slice();\n this._defaultLabelPad = this.labelPad.slice();\n this._defaultLineTickLength = this.lineTickLength.slice();\n}\n\nvar proto = AxesOptions.prototype;\n\nproto.merge = function(fullLayout, sceneLayout) {\n var opts = this;\n for(var i = 0; i < 3; ++i) {\n var axes = sceneLayout[AXES_NAMES[i]];\n\n if(!axes.visible) {\n opts.tickEnable[i] = false;\n opts.labelEnable[i] = false;\n opts.lineEnable[i] = false;\n opts.lineTickEnable[i] = false;\n opts.gridEnable[i] = false;\n opts.zeroEnable[i] = false;\n opts.backgroundEnable[i] = false;\n continue;\n }\n\n // Axes labels\n opts.labels[i] = fullLayout._meta ?\n Lib.templateString(axes.title.text, fullLayout._meta) :\n axes.title.text;\n\n if('font' in axes.title) {\n if(axes.title.font.color) opts.labelColor[i] = str2RgbaArray(axes.title.font.color);\n if(axes.title.font.family) opts.labelFont[i] = axes.title.font.family;\n if(axes.title.font.size) opts.labelSize[i] = axes.title.font.size;\n if(axes.title.font.weight) opts.labelFontWeight[i] = axes.title.font.weight;\n if(axes.title.font.style) opts.labelFontStyle[i] = axes.title.font.style;\n if(axes.title.font.variant) opts.labelFontVariant[i] = axes.title.font.variant;\n }\n\n // Lines\n if('showline' in axes) opts.lineEnable[i] = axes.showline;\n if('linecolor' in axes) opts.lineColor[i] = str2RgbaArray(axes.linecolor);\n if('linewidth' in axes) opts.lineWidth[i] = axes.linewidth;\n\n if('showgrid' in axes) opts.gridEnable[i] = axes.showgrid;\n if('gridcolor' in axes) opts.gridColor[i] = str2RgbaArray(axes.gridcolor);\n if('gridwidth' in axes) opts.gridWidth[i] = axes.gridwidth;\n\n // Remove zeroline if axis type is log\n // otherwise the zeroline is incorrectly drawn at 1 on log axes\n if(axes.type === 'log') opts.zeroEnable[i] = false;\n else if('zeroline' in axes) opts.zeroEnable[i] = axes.zeroline;\n if('zerolinecolor' in axes) opts.zeroLineColor[i] = str2RgbaArray(axes.zerolinecolor);\n if('zerolinewidth' in axes) opts.zeroLineWidth[i] = axes.zerolinewidth;\n\n // tick lines\n if('ticks' in axes && !!axes.ticks) opts.lineTickEnable[i] = true;\n else opts.lineTickEnable[i] = false;\n\n if('ticklen' in axes) {\n opts.lineTickLength[i] = opts._defaultLineTickLength[i] = axes.ticklen;\n }\n if('tickcolor' in axes) opts.lineTickColor[i] = str2RgbaArray(axes.tickcolor);\n if('tickwidth' in axes) opts.lineTickWidth[i] = axes.tickwidth;\n if('tickangle' in axes) {\n opts.tickAngle[i] = (axes.tickangle === 'auto') ?\n -3600 : // i.e. special number to set auto option\n Math.PI * -axes.tickangle / 180;\n }\n\n // tick labels\n if('showticklabels' in axes) opts.tickEnable[i] = axes.showticklabels;\n if('tickfont' in axes) {\n if(axes.tickfont.color) opts.tickColor[i] = str2RgbaArray(axes.tickfont.color);\n if(axes.tickfont.family) opts.tickFont[i] = axes.tickfont.family;\n if(axes.tickfont.size) opts.tickSize[i] = axes.tickfont.size;\n if(axes.tickfont.weight) opts.tickFontWeight[i] = axes.tickfont.weight;\n if(axes.tickfont.style) opts.tickFontStyle[i] = axes.tickfont.style;\n if(axes.tickfont.variant) opts.tickFontVariant[i] = axes.tickfont.variant;\n }\n\n if('mirror' in axes) {\n if(['ticks', 'all', 'allticks'].indexOf(axes.mirror) !== -1) {\n opts.lineTickMirror[i] = true;\n opts.lineMirror[i] = true;\n } else if(axes.mirror === true) {\n opts.lineTickMirror[i] = false;\n opts.lineMirror[i] = true;\n } else {\n opts.lineTickMirror[i] = false;\n opts.lineMirror[i] = false;\n }\n } else opts.lineMirror[i] = false;\n\n // grid background\n if('showbackground' in axes && axes.showbackground !== false) {\n opts.backgroundEnable[i] = true;\n opts.backgroundColor[i] = str2RgbaArray(axes.backgroundcolor);\n } else opts.backgroundEnable[i] = false;\n }\n};\n\n\nfunction createAxesOptions(fullLayout, sceneLayout) {\n var result = new AxesOptions();\n result.merge(fullLayout, sceneLayout);\n return result;\n}\n\nmodule.exports = createAxesOptions;\n","'use strict';\n\nvar Lib = require('../../../lib');\nvar Color = require('../../../components/color');\nvar Registry = require('../../../registry');\n\nvar handleSubplotDefaults = require('../../subplot_defaults');\nvar supplyGl3dAxisLayoutDefaults = require('./axis_defaults');\nvar layoutAttributes = require('./layout_attributes');\nvar getSubplotData = require('../../get_data').getSubplotData;\n\nvar GL3D = 'gl3d';\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut, fullData) {\n var hasNon3D = layoutOut._basePlotModules.length > 1;\n\n // some layout-wide attribute are used in all scenes\n // if 3D is the only visible plot type\n function getDfltFromLayout(attr) {\n if(hasNon3D) return;\n\n var isValid = Lib.validate(layoutIn[attr], layoutAttributes[attr]);\n if(isValid) return layoutIn[attr];\n }\n\n handleSubplotDefaults(layoutIn, layoutOut, fullData, {\n type: GL3D,\n attributes: layoutAttributes,\n handleDefaults: handleGl3dDefaults,\n fullLayout: layoutOut,\n font: layoutOut.font,\n fullData: fullData,\n getDfltFromLayout: getDfltFromLayout,\n autotypenumbersDflt: layoutOut.autotypenumbers,\n paper_bgcolor: layoutOut.paper_bgcolor,\n calendar: layoutOut.calendar\n });\n};\n\nfunction handleGl3dDefaults(sceneLayoutIn, sceneLayoutOut, coerce, opts) {\n /*\n * Scene numbering proceeds as follows\n * scene\n * scene2\n * scene3\n *\n * and d.scene will be undefined or some number or number string\n *\n * Also write back a blank scene object to user layout so that some\n * attributes like aspectratio can be written back dynamically.\n */\n\n var bgcolor = coerce('bgcolor');\n var bgColorCombined = Color.combine(bgcolor, opts.paper_bgcolor);\n\n var cameraKeys = ['up', 'center', 'eye'];\n\n for(var j = 0; j < cameraKeys.length; j++) {\n coerce('camera.' + cameraKeys[j] + '.x');\n coerce('camera.' + cameraKeys[j] + '.y');\n coerce('camera.' + cameraKeys[j] + '.z');\n }\n\n coerce('camera.projection.type');\n\n /*\n * coerce to positive number (min 0) but also do not accept 0 (>0 not >=0)\n * note that 0's go false with the !! call\n */\n var hasAspect = !!coerce('aspectratio.x') &&\n !!coerce('aspectratio.y') &&\n !!coerce('aspectratio.z');\n\n var defaultAspectMode = hasAspect ? 'manual' : 'auto';\n var aspectMode = coerce('aspectmode', defaultAspectMode);\n\n /*\n * We need aspectratio object in all the Layouts as it is dynamically set\n * in the calculation steps, ie, we cant set the correct data now, it happens later.\n * We must also account for the case the user sends bad ratio data with 'manual' set\n * for the mode. In this case we must force change it here as the default coerce\n * misses it above.\n */\n if(!hasAspect) {\n sceneLayoutIn.aspectratio = sceneLayoutOut.aspectratio = {x: 1, y: 1, z: 1};\n\n if(aspectMode === 'manual') sceneLayoutOut.aspectmode = 'auto';\n\n /*\n * kind of like autorange - we need the calculated aspectmode back in\n * the input layout or relayout can cause problems later\n */\n sceneLayoutIn.aspectmode = sceneLayoutOut.aspectmode;\n }\n\n var fullGl3dData = getSubplotData(opts.fullData, GL3D, opts.id);\n\n supplyGl3dAxisLayoutDefaults(sceneLayoutIn, sceneLayoutOut, {\n font: opts.font,\n scene: opts.id,\n data: fullGl3dData,\n bgColor: bgColorCombined,\n calendar: opts.calendar,\n autotypenumbersDflt: opts.autotypenumbersDflt,\n fullLayout: opts.fullLayout\n });\n\n Registry.getComponentMethod('annotations3d', 'handleDefaults')(\n sceneLayoutIn, sceneLayoutOut, opts\n );\n\n var dragmode = opts.getDfltFromLayout('dragmode');\n\n if(dragmode !== false) {\n if(!dragmode) {\n dragmode = 'orbit';\n\n if(sceneLayoutIn.camera &&\n sceneLayoutIn.camera.up) {\n var x = sceneLayoutIn.camera.up.x;\n var y = sceneLayoutIn.camera.up.y;\n var z = sceneLayoutIn.camera.up.z;\n\n if(z !== 0) {\n if(!x || !y || !z) {\n dragmode = 'turntable';\n } else if(z / Math.sqrt(x * x + y * y + z * z) > 0.999) {\n dragmode = 'turntable';\n }\n }\n } else {\n dragmode = 'turntable';\n }\n }\n }\n\n coerce('dragmode', dragmode);\n coerce('hovermode', opts.getDfltFromLayout('hovermode'));\n}\n","'use strict';\n\nvar gl3dAxisAttrs = require('./axis_attributes');\nvar domainAttrs = require('../../domain').attributes;\nvar extendFlat = require('../../../lib/extend').extendFlat;\nvar counterRegex = require('../../../lib').counterRegex;\n\nfunction makeCameraVector(x, y, z) {\n return {\n x: {\n valType: 'number',\n dflt: x,\n editType: 'camera'\n },\n y: {\n valType: 'number',\n dflt: y,\n editType: 'camera'\n },\n z: {\n valType: 'number',\n dflt: z,\n editType: 'camera'\n },\n editType: 'camera'\n };\n}\n\nmodule.exports = {\n _arrayAttrRegexps: [counterRegex('scene', '.annotations', true)],\n\n bgcolor: {\n valType: 'color',\n dflt: 'rgba(0,0,0,0)',\n editType: 'plot'\n },\n camera: {\n up: extendFlat(makeCameraVector(0, 0, 1), {\n description: [\n 'Sets the (x,y,z) components of the \\'up\\' camera vector.',\n 'This vector determines the up direction of this scene',\n 'with respect to the page.',\n 'The default is *{x: 0, y: 0, z: 1}* which means that',\n 'the z axis points up.'\n ].join(' ')\n }),\n center: extendFlat(makeCameraVector(0, 0, 0), {\n description: [\n 'Sets the (x,y,z) components of the \\'center\\' camera vector',\n 'This vector determines the translation (x,y,z) space',\n 'about the center of this scene.',\n 'By default, there is no such translation.'\n ].join(' ')\n }),\n eye: extendFlat(makeCameraVector(1.25, 1.25, 1.25), {\n description: [\n 'Sets the (x,y,z) components of the \\'eye\\' camera vector.',\n 'This vector determines the view point about the origin',\n 'of this scene.'\n ].join(' ')\n }),\n projection: {\n type: {\n valType: 'enumerated',\n values: ['perspective', 'orthographic'],\n dflt: 'perspective',\n editType: 'calc',\n description: [\n 'Sets the projection type. The projection type could be',\n 'either *perspective* or *orthographic*. The default is',\n '*perspective*.'\n ].join(' ')\n },\n editType: 'calc'\n },\n editType: 'camera'\n },\n domain: domainAttrs({name: 'scene', editType: 'plot'}),\n aspectmode: {\n valType: 'enumerated',\n values: ['auto', 'cube', 'data', 'manual'],\n dflt: 'auto',\n editType: 'plot',\n impliedEdits: {\n 'aspectratio.x': undefined,\n 'aspectratio.y': undefined,\n 'aspectratio.z': undefined\n },\n description: [\n 'If *cube*, this scene\\'s axes are drawn as a cube,',\n 'regardless of the axes\\' ranges.',\n\n 'If *data*, this scene\\'s axes are drawn',\n 'in proportion with the axes\\' ranges.',\n\n 'If *manual*, this scene\\'s axes are drawn',\n 'in proportion with the input of *aspectratio*',\n '(the default behavior if *aspectratio* is provided).',\n\n 'If *auto*, this scene\\'s axes are drawn',\n 'using the results of *data* except when one axis',\n 'is more than four times the size of the two others,',\n 'where in that case the results of *cube* are used.'\n ].join(' ')\n },\n aspectratio: { // must be positive (0's are coerced to 1)\n x: {\n valType: 'number',\n min: 0,\n editType: 'plot',\n impliedEdits: {'^aspectmode': 'manual'}\n },\n y: {\n valType: 'number',\n min: 0,\n editType: 'plot',\n impliedEdits: {'^aspectmode': 'manual'}\n },\n z: {\n valType: 'number',\n min: 0,\n editType: 'plot',\n impliedEdits: {'^aspectmode': 'manual'}\n },\n editType: 'plot',\n impliedEdits: {aspectmode: 'manual'},\n description: [\n 'Sets this scene\\'s axis aspectratio.'\n ].join(' ')\n },\n\n xaxis: gl3dAxisAttrs,\n yaxis: gl3dAxisAttrs,\n zaxis: gl3dAxisAttrs,\n\n dragmode: {\n valType: 'enumerated',\n values: ['orbit', 'turntable', 'zoom', 'pan', false],\n editType: 'plot',\n description: [\n 'Determines the mode of drag interactions for this scene.'\n ].join(' ')\n },\n hovermode: {\n valType: 'enumerated',\n values: ['closest', false],\n dflt: 'closest',\n editType: 'modebar',\n description: [\n 'Determines the mode of hover interactions for this scene.'\n ].join(' ')\n },\n uirevision: {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in camera attributes.',\n 'Defaults to `layout.uirevision`.'\n ].join(' ')\n },\n editType: 'plot',\n\n _deprecated: {\n cameraposition: {\n valType: 'info_array',\n editType: 'camera',\n description: 'Obsolete. Use `camera` instead.'\n }\n }\n};\n","'use strict';\n\nvar str2RGBArray = require('../../../lib/str2rgbarray');\n\nvar AXES_NAMES = ['xaxis', 'yaxis', 'zaxis'];\n\nfunction SpikeOptions() {\n this.enabled = [true, true, true];\n this.colors = [[0, 0, 0, 1],\n [0, 0, 0, 1],\n [0, 0, 0, 1]];\n this.drawSides = [true, true, true];\n this.lineWidth = [1, 1, 1];\n}\n\nvar proto = SpikeOptions.prototype;\n\nproto.merge = function(sceneLayout) {\n for(var i = 0; i < 3; ++i) {\n var axes = sceneLayout[AXES_NAMES[i]];\n\n if(!axes.visible) {\n this.enabled[i] = false;\n this.drawSides[i] = false;\n continue;\n }\n\n this.enabled[i] = axes.showspikes;\n this.colors[i] = str2RGBArray(axes.spikecolor);\n this.drawSides[i] = axes.spikesides;\n this.lineWidth[i] = axes.spikethickness;\n }\n};\n\nfunction createSpikeOptions(layout) {\n var result = new SpikeOptions();\n result.merge(layout);\n return result;\n}\n\nmodule.exports = createSpikeOptions;\n","/* eslint block-scoped-var: 0*/\n/* eslint no-redeclare: 0*/\n\n'use strict';\n\nmodule.exports = computeTickMarks;\n\nvar Axes = require('../../cartesian/axes');\nvar Lib = require('../../../lib');\n\nvar AXES_NAMES = ['xaxis', 'yaxis', 'zaxis'];\n\nvar centerPoint = [0, 0, 0];\n\nfunction contourLevelsFromTicks(ticks) {\n var result = new Array(3);\n for(var i = 0; i < 3; ++i) {\n var tlevel = ticks[i];\n var clevel = new Array(tlevel.length);\n for(var j = 0; j < tlevel.length; ++j) {\n clevel[j] = tlevel[j].x;\n }\n result[i] = clevel;\n }\n return result;\n}\n\nfunction computeTickMarks(scene) {\n var axesOptions = scene.axesOptions;\n var glRange = scene.glplot.axesPixels;\n var sceneLayout = scene.fullSceneLayout;\n\n var ticks = [[], [], []];\n\n for(var i = 0; i < 3; ++i) {\n var axes = sceneLayout[AXES_NAMES[i]];\n\n axes._length = (glRange[i].hi - glRange[i].lo) *\n glRange[i].pixelsPerDataUnit / scene.dataScale[i];\n\n if(Math.abs(axes._length) === Infinity ||\n isNaN(axes._length)) {\n ticks[i] = [];\n } else {\n axes._input_range = axes.range.slice();\n axes.range[0] = (glRange[i].lo) / scene.dataScale[i];\n axes.range[1] = (glRange[i].hi) / scene.dataScale[i];\n axes._m = 1.0 / (scene.dataScale[i] * glRange[i].pixelsPerDataUnit);\n\n if(axes.range[0] === axes.range[1]) {\n axes.range[0] -= 1;\n axes.range[1] += 1;\n }\n // this is necessary to short-circuit the 'y' handling\n // in autotick part of calcTicks... Treating all axes as 'y' in this case\n // running the autoticks here, then setting\n // autoticks to false to get around the 2D handling in calcTicks.\n var tickModeCached = axes.tickmode;\n if(axes.tickmode === 'auto') {\n axes.tickmode = 'linear';\n var nticks = axes.nticks || Lib.constrain((axes._length / 40), 4, 9);\n Axes.autoTicks(axes, Math.abs(axes.range[1] - axes.range[0]) / nticks);\n }\n var dataTicks = Axes.calcTicks(axes, { msUTC: true });\n for(var j = 0; j < dataTicks.length; ++j) {\n dataTicks[j].x = dataTicks[j].x * scene.dataScale[i];\n\n if(axes.type === 'date') {\n dataTicks[j].text =\n dataTicks[j].text.replace(/\\/g, ' ');\n }\n }\n ticks[i] = dataTicks;\n\n\n axes.tickmode = tickModeCached;\n }\n }\n\n axesOptions.ticks = ticks;\n\n // Calculate tick lengths dynamically\n for(var i = 0; i < 3; ++i) {\n centerPoint[i] = 0.5 * (scene.glplot.bounds[0][i] + scene.glplot.bounds[1][i]);\n for(var j = 0; j < 2; ++j) {\n axesOptions.bounds[j][i] = scene.glplot.bounds[j][i];\n }\n }\n\n scene.contourLevels = contourLevelsFromTicks(ticks);\n}\n","'use strict';\n\nfunction xformMatrix(m, v) {\n var out = [0, 0, 0, 0];\n var i, j;\n\n for(i = 0; i < 4; ++i) {\n for(j = 0; j < 4; ++j) {\n out[j] += m[4 * i + j] * v[i];\n }\n }\n\n return out;\n}\n\nfunction project(camera, v) {\n var p = xformMatrix(camera.projection,\n xformMatrix(camera.view,\n xformMatrix(camera.model, [v[0], v[1], v[2], 1])));\n return p;\n}\n\nmodule.exports = project;\n","'use strict';\n\nvar glPlot3d = require('../../../stackgl_modules').gl_plot3d;\nvar createCamera = glPlot3d.createCamera;\nvar createPlot = glPlot3d.createScene;\n\nvar getContext = require('webgl-context');\nvar passiveSupported = require('has-passive-events');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar preserveDrawingBuffer = Lib.preserveDrawingBuffer();\n\nvar Axes = require('../../plots/cartesian/axes');\nvar Fx = require('../../components/fx');\n\nvar str2RGBAarray = require('../../lib/str2rgbarray');\nvar showNoWebGlMsg = require('../../lib/show_no_webgl_msg');\n\nvar project = require('./project');\nvar createAxesOptions = require('./layout/convert');\nvar createSpikeOptions = require('./layout/spikes');\nvar computeTickMarks = require('./layout/tick_marks');\n\nvar applyAutorangeOptions = require('../cartesian/autorange').applyAutorangeOptions;\n\nvar STATIC_CANVAS, STATIC_CONTEXT;\n\nvar tabletmode = false;\n\nfunction Scene(options, fullLayout) {\n // create sub container for plot\n var sceneContainer = document.createElement('div');\n var plotContainer = options.container;\n\n // keep a ref to the graph div to fire hover+click events\n this.graphDiv = options.graphDiv;\n\n // create SVG container for hover text\n var svgContainer = document.createElementNS(\n 'http://www.w3.org/2000/svg',\n 'svg');\n svgContainer.style.position = 'absolute';\n svgContainer.style.top = svgContainer.style.left = '0px';\n svgContainer.style.width = svgContainer.style.height = '100%';\n svgContainer.style['z-index'] = 20;\n svgContainer.style['pointer-events'] = 'none';\n sceneContainer.appendChild(svgContainer);\n this.svgContainer = svgContainer;\n\n // Tag the container with the sceneID\n sceneContainer.id = options.id;\n sceneContainer.style.position = 'absolute';\n sceneContainer.style.top = sceneContainer.style.left = '0px';\n sceneContainer.style.width = sceneContainer.style.height = '100%';\n plotContainer.appendChild(sceneContainer);\n\n this.fullLayout = fullLayout;\n this.id = options.id || 'scene';\n this.fullSceneLayout = fullLayout[this.id];\n\n // Saved from last call to plot()\n this.plotArgs = [ [], {}, {} ];\n\n /*\n * Move this to calc step? Why does it work here?\n */\n this.axesOptions = createAxesOptions(fullLayout, fullLayout[this.id]);\n this.spikeOptions = createSpikeOptions(fullLayout[this.id]);\n this.container = sceneContainer;\n this.staticMode = !!options.staticPlot;\n this.pixelRatio = this.pixelRatio || options.plotGlPixelRatio || 2;\n\n // Coordinate rescaling\n this.dataScale = [1, 1, 1];\n\n this.contourLevels = [ [], [], [] ];\n\n this.convertAnnotations = Registry.getComponentMethod('annotations3d', 'convert');\n this.drawAnnotations = Registry.getComponentMethod('annotations3d', 'draw');\n\n this.initializeGLPlot();\n}\n\nvar proto = Scene.prototype;\n\nproto.prepareOptions = function() {\n var scene = this;\n\n var opts = {\n canvas: scene.canvas,\n gl: scene.gl,\n glOptions: {\n preserveDrawingBuffer: preserveDrawingBuffer,\n premultipliedAlpha: true,\n antialias: true\n },\n container: scene.container,\n axes: scene.axesOptions,\n spikes: scene.spikeOptions,\n pickRadius: 10,\n snapToData: true,\n autoScale: true,\n autoBounds: false,\n cameraObject: scene.camera,\n pixelRatio: scene.pixelRatio\n };\n\n // for static plots, we reuse the WebGL context\n // as WebKit doesn't collect them reliably\n if(scene.staticMode) {\n if(!STATIC_CONTEXT) {\n STATIC_CANVAS = document.createElement('canvas');\n STATIC_CONTEXT = getContext({\n canvas: STATIC_CANVAS,\n preserveDrawingBuffer: true,\n premultipliedAlpha: true,\n antialias: true\n });\n if(!STATIC_CONTEXT) {\n throw new Error('error creating static canvas/context for image server');\n }\n }\n\n opts.gl = STATIC_CONTEXT;\n opts.canvas = STATIC_CANVAS;\n }\n\n return opts;\n};\n\nvar firstInit = true;\n\nproto.tryCreatePlot = function() {\n var scene = this;\n\n var opts = scene.prepareOptions();\n\n var success = true;\n\n try {\n scene.glplot = createPlot(opts);\n } catch(e) {\n if(scene.staticMode || !firstInit || preserveDrawingBuffer) {\n success = false;\n } else { // try second time\n // enable preserveDrawingBuffer setup\n // in case is-mobile not detecting the right device\n Lib.warn([\n 'webgl setup failed possibly due to',\n 'false preserveDrawingBuffer config.',\n 'The mobile/tablet device may not be detected by is-mobile module.',\n 'Enabling preserveDrawingBuffer in second attempt to create webgl scene...'\n ].join(' '));\n\n try {\n // invert preserveDrawingBuffer\n preserveDrawingBuffer = opts.glOptions.preserveDrawingBuffer = true;\n\n scene.glplot = createPlot(opts);\n } catch(e) {\n // revert changes to preserveDrawingBuffer\n preserveDrawingBuffer = opts.glOptions.preserveDrawingBuffer = false;\n\n success = false;\n }\n }\n }\n\n firstInit = false;\n\n return success;\n};\n\nproto.initializeGLCamera = function() {\n var scene = this;\n var cameraData = scene.fullSceneLayout.camera;\n var isOrtho = (cameraData.projection.type === 'orthographic');\n\n scene.camera = createCamera(scene.container, {\n center: [cameraData.center.x, cameraData.center.y, cameraData.center.z],\n eye: [cameraData.eye.x, cameraData.eye.y, cameraData.eye.z],\n up: [cameraData.up.x, cameraData.up.y, cameraData.up.z],\n _ortho: isOrtho,\n zoomMin: 0.01,\n zoomMax: 100,\n mode: 'orbit'\n });\n};\n\nproto.initializeGLPlot = function() {\n var scene = this;\n\n scene.initializeGLCamera();\n\n var success = scene.tryCreatePlot();\n /*\n * createPlot will throw when webgl is not enabled in the client.\n * Lets return an instance of the module with all functions noop'd.\n * The destroy method - which will remove the container from the DOM\n * is overridden with a function that removes the container only.\n */\n if(!success) return showNoWebGlMsg(scene);\n\n // List of scene objects\n scene.traces = {};\n\n scene.make4thDimension();\n\n var gd = scene.graphDiv;\n var layout = gd.layout;\n\n var makeUpdate = function() {\n var update = {};\n\n if(scene.isCameraChanged(layout)) {\n // camera updates\n update[scene.id + '.camera'] = scene.getCamera();\n }\n\n if(scene.isAspectChanged(layout)) {\n // scene updates\n update[scene.id + '.aspectratio'] = scene.glplot.getAspectratio();\n\n if(layout[scene.id].aspectmode !== 'manual') {\n scene.fullSceneLayout.aspectmode =\n layout[scene.id].aspectmode =\n update[scene.id + '.aspectmode'] = 'manual';\n }\n }\n\n return update;\n };\n\n var relayoutCallback = function(scene) {\n if(scene.fullSceneLayout.dragmode === false) return;\n\n var update = makeUpdate();\n scene.saveLayout(layout);\n scene.graphDiv.emit('plotly_relayout', update);\n };\n\n if(scene.glplot.canvas) {\n scene.glplot.canvas.addEventListener('mouseup', function() {\n relayoutCallback(scene);\n });\n\n scene.glplot.canvas.addEventListener('touchstart', function() {\n tabletmode = true;\n });\n\n scene.glplot.canvas.addEventListener('wheel', function(e) {\n if(gd._context._scrollZoom.gl3d) {\n if(scene.camera._ortho) {\n var s = (e.deltaX > e.deltaY) ? 1.1 : 1.0 / 1.1;\n var o = scene.glplot.getAspectratio();\n scene.glplot.setAspectratio({\n x: s * o.x,\n y: s * o.y,\n z: s * o.z\n });\n }\n\n relayoutCallback(scene);\n }\n }, passiveSupported ? {passive: false} : false);\n\n scene.glplot.canvas.addEventListener('mousemove', function() {\n if(scene.fullSceneLayout.dragmode === false) return;\n if(scene.camera.mouseListener.buttons === 0) return;\n\n var update = makeUpdate();\n scene.graphDiv.emit('plotly_relayouting', update);\n });\n\n if(!scene.staticMode) {\n scene.glplot.canvas.addEventListener('webglcontextlost', function(event) {\n if(gd && gd.emit) {\n gd.emit('plotly_webglcontextlost', {\n event: event,\n layer: scene.id\n });\n }\n }, false);\n }\n }\n\n scene.glplot.oncontextloss = function() {\n scene.recoverContext();\n };\n\n scene.glplot.onrender = function() {\n scene.render();\n };\n\n return true;\n};\n\nproto.render = function() {\n var scene = this;\n var gd = scene.graphDiv;\n var trace;\n\n // update size of svg container\n var svgContainer = scene.svgContainer;\n var clientRect = scene.container.getBoundingClientRect();\n\n gd._fullLayout._calcInverseTransform(gd);\n var scaleX = gd._fullLayout._invScaleX;\n var scaleY = gd._fullLayout._invScaleY;\n var width = clientRect.width * scaleX;\n var height = clientRect.height * scaleY;\n svgContainer.setAttributeNS(null, 'viewBox', '0 0 ' + width + ' ' + height);\n svgContainer.setAttributeNS(null, 'width', width);\n svgContainer.setAttributeNS(null, 'height', height);\n\n computeTickMarks(scene);\n scene.glplot.axes.update(scene.axesOptions);\n\n // check if pick has changed\n var keys = Object.keys(scene.traces);\n var lastPicked = null;\n var selection = scene.glplot.selection;\n for(var i = 0; i < keys.length; ++i) {\n trace = scene.traces[keys[i]];\n if(trace.data.hoverinfo !== 'skip' && trace.handlePick(selection)) {\n lastPicked = trace;\n }\n\n if(trace.setContourLevels) trace.setContourLevels();\n }\n\n function formatter(axLetter, val, hoverformat) {\n var ax = scene.fullSceneLayout[axLetter + 'axis'];\n\n if(ax.type !== 'log') {\n val = ax.d2l(val);\n }\n\n return Axes.hoverLabelText(ax, val, hoverformat);\n }\n\n if(lastPicked !== null) {\n var pdata = project(scene.glplot.cameraParams, selection.dataCoordinate);\n trace = lastPicked.data;\n var traceNow = gd._fullData[trace.index];\n var ptNumber = selection.index;\n\n var labels = {\n xLabel: formatter('x', selection.traceCoordinate[0], trace.xhoverformat),\n yLabel: formatter('y', selection.traceCoordinate[1], trace.yhoverformat),\n zLabel: formatter('z', selection.traceCoordinate[2], trace.zhoverformat)\n };\n\n var hoverinfo = Fx.castHoverinfo(traceNow, scene.fullLayout, ptNumber);\n var hoverinfoParts = (hoverinfo || '').split('+');\n var isHoverinfoAll = hoverinfo && hoverinfo === 'all';\n\n if(!traceNow.hovertemplate && !isHoverinfoAll) {\n if(hoverinfoParts.indexOf('x') === -1) labels.xLabel = undefined;\n if(hoverinfoParts.indexOf('y') === -1) labels.yLabel = undefined;\n if(hoverinfoParts.indexOf('z') === -1) labels.zLabel = undefined;\n if(hoverinfoParts.indexOf('text') === -1) selection.textLabel = undefined;\n if(hoverinfoParts.indexOf('name') === -1) lastPicked.name = undefined;\n }\n\n var tx;\n var vectorTx = [];\n\n if(trace.type === 'cone' || trace.type === 'streamtube') {\n labels.uLabel = formatter('x', selection.traceCoordinate[3], trace.uhoverformat);\n if(isHoverinfoAll || hoverinfoParts.indexOf('u') !== -1) {\n vectorTx.push('u: ' + labels.uLabel);\n }\n\n labels.vLabel = formatter('y', selection.traceCoordinate[4], trace.vhoverformat);\n if(isHoverinfoAll || hoverinfoParts.indexOf('v') !== -1) {\n vectorTx.push('v: ' + labels.vLabel);\n }\n\n labels.wLabel = formatter('z', selection.traceCoordinate[5], trace.whoverformat);\n if(isHoverinfoAll || hoverinfoParts.indexOf('w') !== -1) {\n vectorTx.push('w: ' + labels.wLabel);\n }\n\n labels.normLabel = selection.traceCoordinate[6].toPrecision(3);\n if(isHoverinfoAll || hoverinfoParts.indexOf('norm') !== -1) {\n vectorTx.push('norm: ' + labels.normLabel);\n }\n if(trace.type === 'streamtube') {\n labels.divergenceLabel = selection.traceCoordinate[7].toPrecision(3);\n if(isHoverinfoAll || hoverinfoParts.indexOf('divergence') !== -1) {\n vectorTx.push('divergence: ' + labels.divergenceLabel);\n }\n }\n if(selection.textLabel) {\n vectorTx.push(selection.textLabel);\n }\n tx = vectorTx.join('
');\n } else if(trace.type === 'isosurface' || trace.type === 'volume') {\n labels.valueLabel = Axes.hoverLabelText(scene._mockAxis, scene._mockAxis.d2l(selection.traceCoordinate[3]), trace.valuehoverformat);\n vectorTx.push('value: ' + labels.valueLabel);\n if(selection.textLabel) {\n vectorTx.push(selection.textLabel);\n }\n tx = vectorTx.join('
');\n } else {\n tx = selection.textLabel;\n }\n\n var pointData = {\n x: selection.traceCoordinate[0],\n y: selection.traceCoordinate[1],\n z: selection.traceCoordinate[2],\n data: traceNow._input,\n fullData: traceNow,\n curveNumber: traceNow.index,\n pointNumber: ptNumber\n };\n\n Fx.appendArrayPointValue(pointData, traceNow, ptNumber);\n\n if(trace._module.eventData) {\n pointData = traceNow._module.eventData(pointData, selection, traceNow, {}, ptNumber);\n }\n\n var eventData = {points: [pointData]};\n\n if(scene.fullSceneLayout.hovermode) {\n var bbox = [];\n Fx.loneHover({\n trace: traceNow,\n x: (0.5 + 0.5 * pdata[0] / pdata[3]) * width,\n y: (0.5 - 0.5 * pdata[1] / pdata[3]) * height,\n xLabel: labels.xLabel,\n yLabel: labels.yLabel,\n zLabel: labels.zLabel,\n text: tx,\n name: lastPicked.name,\n color: Fx.castHoverOption(traceNow, ptNumber, 'bgcolor') || lastPicked.color,\n borderColor: Fx.castHoverOption(traceNow, ptNumber, 'bordercolor'),\n fontFamily: Fx.castHoverOption(traceNow, ptNumber, 'font.family'),\n fontSize: Fx.castHoverOption(traceNow, ptNumber, 'font.size'),\n fontColor: Fx.castHoverOption(traceNow, ptNumber, 'font.color'),\n nameLength: Fx.castHoverOption(traceNow, ptNumber, 'namelength'),\n textAlign: Fx.castHoverOption(traceNow, ptNumber, 'align'),\n hovertemplate: Lib.castOption(traceNow, ptNumber, 'hovertemplate'),\n hovertemplateLabels: Lib.extendFlat({}, pointData, labels),\n eventData: [pointData]\n }, {\n container: svgContainer,\n gd: gd,\n inOut_bbox: bbox\n });\n\n pointData.bbox = bbox[0];\n }\n\n if(selection.distance < 5 && (selection.buttons || tabletmode)) {\n gd.emit('plotly_click', eventData);\n } else {\n gd.emit('plotly_hover', eventData);\n }\n\n this.oldEventData = eventData;\n } else {\n Fx.loneUnhover(svgContainer);\n if(this.oldEventData) gd.emit('plotly_unhover', this.oldEventData);\n this.oldEventData = undefined;\n }\n\n scene.drawAnnotations(scene);\n};\n\nproto.recoverContext = function() {\n var scene = this;\n\n scene.glplot.dispose();\n\n var tryRecover = function() {\n if(scene.glplot.gl.isContextLost()) {\n requestAnimationFrame(tryRecover);\n return;\n }\n if(!scene.initializeGLPlot()) {\n Lib.error('Catastrophic and unrecoverable WebGL error. Context lost.');\n return;\n }\n scene.plot.apply(scene, scene.plotArgs);\n };\n\n requestAnimationFrame(tryRecover);\n};\n\nvar axisProperties = [ 'xaxis', 'yaxis', 'zaxis' ];\n\nfunction computeTraceBounds(scene, trace, bounds) {\n var fullSceneLayout = scene.fullSceneLayout;\n\n for(var d = 0; d < 3; d++) {\n var axisName = axisProperties[d];\n var axLetter = axisName.charAt(0);\n var ax = fullSceneLayout[axisName];\n var coords = trace[axLetter];\n var calendar = trace[axLetter + 'calendar'];\n var len = trace['_' + axLetter + 'length'];\n\n if(!Lib.isArrayOrTypedArray(coords)) {\n bounds[0][d] = Math.min(bounds[0][d], 0);\n bounds[1][d] = Math.max(bounds[1][d], len - 1);\n } else {\n var v;\n\n for(var i = 0; i < (len || coords.length); i++) {\n if(Lib.isArrayOrTypedArray(coords[i])) {\n for(var j = 0; j < coords[i].length; ++j) {\n v = ax.d2l(coords[i][j], 0, calendar);\n if(!isNaN(v) && isFinite(v)) {\n bounds[0][d] = Math.min(bounds[0][d], v);\n bounds[1][d] = Math.max(bounds[1][d], v);\n }\n }\n } else {\n v = ax.d2l(coords[i], 0, calendar);\n if(!isNaN(v) && isFinite(v)) {\n bounds[0][d] = Math.min(bounds[0][d], v);\n bounds[1][d] = Math.max(bounds[1][d], v);\n }\n }\n }\n }\n }\n}\n\nfunction computeAnnotationBounds(scene, bounds) {\n var fullSceneLayout = scene.fullSceneLayout;\n var annotations = fullSceneLayout.annotations || [];\n\n for(var d = 0; d < 3; d++) {\n var axisName = axisProperties[d];\n var axLetter = axisName.charAt(0);\n var ax = fullSceneLayout[axisName];\n\n for(var j = 0; j < annotations.length; j++) {\n var ann = annotations[j];\n\n if(ann.visible) {\n var pos = ax.r2l(ann[axLetter]);\n if(!isNaN(pos) && isFinite(pos)) {\n bounds[0][d] = Math.min(bounds[0][d], pos);\n bounds[1][d] = Math.max(bounds[1][d], pos);\n }\n }\n }\n }\n}\n\nproto.plot = function(sceneData, fullLayout, layout) {\n var scene = this;\n\n // Save parameters\n scene.plotArgs = [sceneData, fullLayout, layout];\n\n if(scene.glplot.contextLost) return;\n\n var data, trace;\n var i, j, axis, axisType;\n var fullSceneLayout = fullLayout[scene.id];\n var sceneLayout = layout[scene.id];\n\n // Update layout\n scene.fullLayout = fullLayout;\n scene.fullSceneLayout = fullSceneLayout;\n\n scene.axesOptions.merge(fullLayout, fullSceneLayout);\n scene.spikeOptions.merge(fullSceneLayout);\n\n // Update camera and camera mode\n scene.setViewport(fullSceneLayout);\n scene.updateFx(fullSceneLayout.dragmode, fullSceneLayout.hovermode);\n scene.camera.enableWheel = scene.graphDiv._context._scrollZoom.gl3d;\n\n // Update scene background\n scene.glplot.setClearColor(str2RGBAarray(fullSceneLayout.bgcolor));\n\n // Update axes functions BEFORE updating traces\n scene.setConvert(axis);\n\n // Convert scene data\n if(!sceneData) sceneData = [];\n else if(!Array.isArray(sceneData)) sceneData = [sceneData];\n\n // Compute trace bounding box\n var dataBounds = [\n [Infinity, Infinity, Infinity],\n [-Infinity, -Infinity, -Infinity]\n ];\n\n for(i = 0; i < sceneData.length; ++i) {\n data = sceneData[i];\n if(data.visible !== true || data._length === 0) continue;\n\n computeTraceBounds(this, data, dataBounds);\n }\n computeAnnotationBounds(this, dataBounds);\n\n var dataScale = [1, 1, 1];\n for(j = 0; j < 3; ++j) {\n if(dataBounds[1][j] === dataBounds[0][j]) {\n dataScale[j] = 1.0;\n } else {\n dataScale[j] = 1.0 / (dataBounds[1][j] - dataBounds[0][j]);\n }\n }\n\n // Save scale\n scene.dataScale = dataScale;\n\n // after computeTraceBounds where ax._categories are filled in\n scene.convertAnnotations(this);\n\n // Update traces\n for(i = 0; i < sceneData.length; ++i) {\n data = sceneData[i];\n if(data.visible !== true || data._length === 0) {\n continue;\n }\n trace = scene.traces[data.uid];\n if(trace) {\n if(trace.data.type === data.type) {\n trace.update(data);\n } else {\n trace.dispose();\n trace = data._module.plot(this, data);\n scene.traces[data.uid] = trace;\n }\n } else {\n trace = data._module.plot(this, data);\n scene.traces[data.uid] = trace;\n }\n trace.name = data.name;\n }\n\n // Remove empty traces\n var traceIds = Object.keys(scene.traces);\n\n traceIdLoop:\n for(i = 0; i < traceIds.length; ++i) {\n for(j = 0; j < sceneData.length; ++j) {\n if(sceneData[j].uid === traceIds[i] &&\n (sceneData[j].visible === true && sceneData[j]._length !== 0)) {\n continue traceIdLoop;\n }\n }\n trace = scene.traces[traceIds[i]];\n trace.dispose();\n delete scene.traces[traceIds[i]];\n }\n\n // order object per trace index\n scene.glplot.objects.sort(function(a, b) {\n return a._trace.data.index - b._trace.data.index;\n });\n\n // Update ranges (needs to be called *after* objects are added due to updates)\n var sceneBounds = [[0, 0, 0], [0, 0, 0]];\n var axisDataRange = [];\n var axisTypeRatios = {};\n\n for(i = 0; i < 3; ++i) {\n axis = fullSceneLayout[axisProperties[i]];\n axisType = axis.type;\n\n if(axisType in axisTypeRatios) {\n axisTypeRatios[axisType].acc *= dataScale[i];\n axisTypeRatios[axisType].count += 1;\n } else {\n axisTypeRatios[axisType] = {\n acc: dataScale[i],\n count: 1\n };\n }\n\n var range;\n\n if(axis.autorange) {\n sceneBounds[0][i] = Infinity;\n sceneBounds[1][i] = -Infinity;\n\n var objects = scene.glplot.objects;\n var annotations = scene.fullSceneLayout.annotations || [];\n var axLetter = axis._name.charAt(0);\n\n for(j = 0; j < objects.length; j++) {\n var obj = objects[j];\n var objBounds = obj.bounds;\n var pad = obj._trace.data._pad || 0;\n\n if(obj.constructor.name === 'ErrorBars' && axis._lowerLogErrorBound) {\n sceneBounds[0][i] = Math.min(sceneBounds[0][i], axis._lowerLogErrorBound);\n } else {\n sceneBounds[0][i] = Math.min(sceneBounds[0][i], objBounds[0][i] / dataScale[i] - pad);\n }\n sceneBounds[1][i] = Math.max(sceneBounds[1][i], objBounds[1][i] / dataScale[i] + pad);\n }\n\n for(j = 0; j < annotations.length; j++) {\n var ann = annotations[j];\n\n // N.B. not taking into consideration the arrowhead\n if(ann.visible) {\n var pos = axis.r2l(ann[axLetter]);\n sceneBounds[0][i] = Math.min(sceneBounds[0][i], pos);\n sceneBounds[1][i] = Math.max(sceneBounds[1][i], pos);\n }\n }\n\n if('rangemode' in axis && axis.rangemode === 'tozero') {\n sceneBounds[0][i] = Math.min(sceneBounds[0][i], 0);\n sceneBounds[1][i] = Math.max(sceneBounds[1][i], 0);\n }\n if(sceneBounds[0][i] > sceneBounds[1][i]) {\n sceneBounds[0][i] = -1;\n sceneBounds[1][i] = 1;\n } else {\n var d = sceneBounds[1][i] - sceneBounds[0][i];\n sceneBounds[0][i] -= d / 32.0;\n sceneBounds[1][i] += d / 32.0;\n }\n\n range = [\n sceneBounds[0][i],\n sceneBounds[1][i]\n ];\n\n range = applyAutorangeOptions(range, axis);\n\n sceneBounds[0][i] = range[0];\n sceneBounds[1][i] = range[1];\n\n if(axis.isReversed()) {\n // swap bounds:\n var tmp = sceneBounds[0][i];\n sceneBounds[0][i] = sceneBounds[1][i];\n sceneBounds[1][i] = tmp;\n }\n } else {\n range = axis.range;\n sceneBounds[0][i] = axis.r2l(range[0]);\n sceneBounds[1][i] = axis.r2l(range[1]);\n }\n if(sceneBounds[0][i] === sceneBounds[1][i]) {\n sceneBounds[0][i] -= 1;\n sceneBounds[1][i] += 1;\n }\n axisDataRange[i] = sceneBounds[1][i] - sceneBounds[0][i];\n\n axis.range = [\n sceneBounds[0][i],\n sceneBounds[1][i]\n ];\n\n axis.limitRange();\n\n // Update plot bounds\n scene.glplot.setBounds(i, {\n min: axis.range[0] * dataScale[i],\n max: axis.range[1] * dataScale[i]\n });\n }\n\n /*\n * Dynamically set the aspect ratio depending on the users aspect settings\n */\n var aspectRatio;\n var aspectmode = fullSceneLayout.aspectmode;\n if(aspectmode === 'cube') {\n aspectRatio = [1, 1, 1];\n } else if(aspectmode === 'manual') {\n var userRatio = fullSceneLayout.aspectratio;\n aspectRatio = [userRatio.x, userRatio.y, userRatio.z];\n } else if(aspectmode === 'auto' || aspectmode === 'data') {\n var axesScaleRatio = [1, 1, 1];\n // Compute axis scale per category\n for(i = 0; i < 3; ++i) {\n axis = fullSceneLayout[axisProperties[i]];\n axisType = axis.type;\n var axisRatio = axisTypeRatios[axisType];\n axesScaleRatio[i] = Math.pow(axisRatio.acc, 1.0 / axisRatio.count) / dataScale[i];\n }\n\n if(aspectmode === 'data') {\n aspectRatio = axesScaleRatio;\n } else { // i.e. 'auto' option\n if(\n Math.max.apply(null, axesScaleRatio) /\n Math.min.apply(null, axesScaleRatio) <= 4\n ) {\n // USE DATA MODE WHEN AXIS RANGE DIMENSIONS ARE RELATIVELY EQUAL\n aspectRatio = axesScaleRatio;\n } else {\n // USE EQUAL MODE WHEN AXIS RANGE DIMENSIONS ARE HIGHLY UNEQUAL\n aspectRatio = [1, 1, 1];\n }\n }\n } else {\n throw new Error('scene.js aspectRatio was not one of the enumerated types');\n }\n\n /*\n * Write aspect Ratio back to user data and fullLayout so that it is modifies as user\n * manipulates the aspectmode settings and the fullLayout is up-to-date.\n */\n fullSceneLayout.aspectratio.x = sceneLayout.aspectratio.x = aspectRatio[0];\n fullSceneLayout.aspectratio.y = sceneLayout.aspectratio.y = aspectRatio[1];\n fullSceneLayout.aspectratio.z = sceneLayout.aspectratio.z = aspectRatio[2];\n\n /*\n * Finally assign the computed aspecratio to the glplot module. This will have an effect\n * on the next render cycle.\n */\n scene.glplot.setAspectratio(fullSceneLayout.aspectratio);\n\n // save 'initial' aspectratio & aspectmode view settings for modebar buttons\n if(!scene.viewInitial.aspectratio) {\n scene.viewInitial.aspectratio = {\n x: fullSceneLayout.aspectratio.x,\n y: fullSceneLayout.aspectratio.y,\n z: fullSceneLayout.aspectratio.z\n };\n }\n if(!scene.viewInitial.aspectmode) {\n scene.viewInitial.aspectmode = fullSceneLayout.aspectmode;\n }\n\n // Update frame position for multi plots\n var domain = fullSceneLayout.domain || null;\n var size = fullLayout._size || null;\n\n if(domain && size) {\n var containerStyle = scene.container.style;\n containerStyle.position = 'absolute';\n containerStyle.left = (size.l + domain.x[0] * size.w) + 'px';\n containerStyle.top = (size.t + (1 - domain.y[1]) * size.h) + 'px';\n containerStyle.width = (size.w * (domain.x[1] - domain.x[0])) + 'px';\n containerStyle.height = (size.h * (domain.y[1] - domain.y[0])) + 'px';\n }\n\n // force redraw so that promise is returned when rendering is completed\n scene.glplot.redraw();\n};\n\nproto.destroy = function() {\n var scene = this;\n\n if(!scene.glplot) return;\n scene.camera.mouseListener.enabled = false;\n scene.container.removeEventListener('wheel', scene.camera.wheelListener);\n scene.camera = null;\n scene.glplot.dispose();\n scene.container.parentNode.removeChild(scene.container);\n scene.glplot = null;\n};\n\n// getCameraArrays :: plotly_coords -> gl-plot3d_coords\n// inverse of getLayoutCamera\nfunction getCameraArrays(camera) {\n return [\n [camera.eye.x, camera.eye.y, camera.eye.z],\n [camera.center.x, camera.center.y, camera.center.z],\n [camera.up.x, camera.up.y, camera.up.z]\n ];\n}\n\n// getLayoutCamera :: gl-plot3d_coords -> plotly_coords\n// inverse of getCameraArrays\nfunction getLayoutCamera(camera) {\n return {\n up: {x: camera.up[0], y: camera.up[1], z: camera.up[2]},\n center: {x: camera.center[0], y: camera.center[1], z: camera.center[2]},\n eye: {x: camera.eye[0], y: camera.eye[1], z: camera.eye[2]},\n projection: {type: (camera._ortho === true) ? 'orthographic' : 'perspective'}\n };\n}\n\n// get camera position in plotly coords from 'gl-plot3d' coords\nproto.getCamera = function() {\n var scene = this;\n scene.camera.view.recalcMatrix(scene.camera.view.lastT());\n return getLayoutCamera(scene.camera);\n};\n\n// set gl-plot3d camera position and scene aspects with a set of plotly coords\nproto.setViewport = function(sceneLayout) {\n var scene = this;\n var cameraData = sceneLayout.camera;\n\n scene.camera.lookAt.apply(this, getCameraArrays(cameraData));\n scene.glplot.setAspectratio(sceneLayout.aspectratio);\n\n var newOrtho = (cameraData.projection.type === 'orthographic');\n var oldOrtho = scene.camera._ortho;\n\n if(newOrtho !== oldOrtho) {\n scene.glplot.redraw(); // TODO: figure out why we need to redraw here?\n scene.glplot.clearRGBA();\n scene.glplot.dispose();\n scene.initializeGLPlot();\n }\n};\n\nproto.isCameraChanged = function(layout) {\n var scene = this;\n var cameraData = scene.getCamera();\n var cameraNestedProp = Lib.nestedProperty(layout, scene.id + '.camera');\n var cameraDataLastSave = cameraNestedProp.get();\n\n function same(x, y, i, j) {\n var vectors = ['up', 'center', 'eye'];\n var components = ['x', 'y', 'z'];\n return y[vectors[i]] && (x[vectors[i]][components[j]] === y[vectors[i]][components[j]]);\n }\n\n var changed = false;\n if(cameraDataLastSave === undefined) {\n changed = true;\n } else {\n for(var i = 0; i < 3; i++) {\n for(var j = 0; j < 3; j++) {\n if(!same(cameraData, cameraDataLastSave, i, j)) {\n changed = true;\n break;\n }\n }\n }\n\n if(!cameraDataLastSave.projection || (\n cameraData.projection &&\n cameraData.projection.type !== cameraDataLastSave.projection.type)) {\n changed = true;\n }\n }\n\n return changed;\n};\n\nproto.isAspectChanged = function(layout) {\n var scene = this;\n var aspectData = scene.glplot.getAspectratio();\n var aspectNestedProp = Lib.nestedProperty(layout, scene.id + '.aspectratio');\n var aspectDataLastSave = aspectNestedProp.get();\n\n return (\n aspectDataLastSave === undefined || (\n aspectDataLastSave.x !== aspectData.x ||\n aspectDataLastSave.y !== aspectData.y ||\n aspectDataLastSave.z !== aspectData.z\n ));\n};\n\n// save camera to user layout (i.e. gd.layout)\nproto.saveLayout = function(layout) {\n var scene = this;\n var fullLayout = scene.fullLayout;\n\n var cameraData;\n var cameraNestedProp;\n var cameraDataLastSave;\n\n var aspectData;\n var aspectNestedProp;\n var aspectDataLastSave;\n\n var cameraChanged = scene.isCameraChanged(layout);\n var aspectChanged = scene.isAspectChanged(layout);\n\n var hasChanged = cameraChanged || aspectChanged;\n if(hasChanged) {\n var preGUI = {};\n if(cameraChanged) {\n cameraData = scene.getCamera();\n cameraNestedProp = Lib.nestedProperty(layout, scene.id + '.camera');\n cameraDataLastSave = cameraNestedProp.get();\n\n preGUI[scene.id + '.camera'] = cameraDataLastSave;\n }\n if(aspectChanged) {\n aspectData = scene.glplot.getAspectratio();\n aspectNestedProp = Lib.nestedProperty(layout, scene.id + '.aspectratio');\n aspectDataLastSave = aspectNestedProp.get();\n\n preGUI[scene.id + '.aspectratio'] = aspectDataLastSave;\n }\n Registry.call('_storeDirectGUIEdit', layout, fullLayout._preGUI, preGUI);\n\n if(cameraChanged) {\n cameraNestedProp.set(cameraData);\n\n var cameraFullNP = Lib.nestedProperty(fullLayout, scene.id + '.camera');\n cameraFullNP.set(cameraData);\n }\n\n if(aspectChanged) {\n aspectNestedProp.set(aspectData);\n\n var aspectFullNP = Lib.nestedProperty(fullLayout, scene.id + '.aspectratio');\n aspectFullNP.set(aspectData);\n\n scene.glplot.redraw();\n }\n }\n\n return hasChanged;\n};\n\nproto.updateFx = function(dragmode, hovermode) {\n var scene = this;\n var camera = scene.camera;\n if(camera) {\n // rotate and orbital are synonymous\n if(dragmode === 'orbit') {\n camera.mode = 'orbit';\n camera.keyBindingMode = 'rotate';\n } else if(dragmode === 'turntable') {\n camera.up = [0, 0, 1];\n camera.mode = 'turntable';\n camera.keyBindingMode = 'rotate';\n\n // The setter for camera.mode animates the transition to z-up,\n // but only if we *don't* explicitly set z-up earlier via the\n // relayout. So push `up` back to layout & fullLayout manually now.\n var gd = scene.graphDiv;\n var fullLayout = gd._fullLayout;\n var fullCamera = scene.fullSceneLayout.camera;\n var x = fullCamera.up.x;\n var y = fullCamera.up.y;\n var z = fullCamera.up.z;\n // only push `up` back to (full)layout if it's going to change\n if(z / Math.sqrt(x * x + y * y + z * z) < 0.999) {\n var attr = scene.id + '.camera.up';\n var zUp = {x: 0, y: 0, z: 1};\n var edits = {};\n edits[attr] = zUp;\n var layout = gd.layout;\n Registry.call('_storeDirectGUIEdit', layout, fullLayout._preGUI, edits);\n fullCamera.up = zUp;\n Lib.nestedProperty(layout, attr).set(zUp);\n }\n } else {\n // none rotation modes [pan or zoom]\n camera.keyBindingMode = dragmode;\n }\n }\n\n // to put dragmode and hovermode on the same grounds from relayout\n scene.fullSceneLayout.hovermode = hovermode;\n};\n\nfunction flipPixels(pixels, w, h) {\n for(var i = 0, q = h - 1; i < q; ++i, --q) {\n for(var j = 0; j < w; ++j) {\n for(var k = 0; k < 4; ++k) {\n var a = 4 * (w * i + j) + k;\n var b = 4 * (w * q + j) + k;\n var tmp = pixels[a];\n pixels[a] = pixels[b];\n pixels[b] = tmp;\n }\n }\n }\n}\n\nfunction correctRGB(pixels, w, h) {\n for(var i = 0; i < h; ++i) {\n for(var j = 0; j < w; ++j) {\n var k = 4 * (w * i + j);\n\n var a = pixels[k + 3]; // alpha\n if(a > 0) {\n var q = 255 / a;\n\n for(var l = 0; l < 3; ++l) { // RGB\n pixels[k + l] = Math.min(q * pixels[k + l], 255);\n }\n }\n }\n }\n}\n\nproto.toImage = function(format) {\n var scene = this;\n\n if(!format) format = 'png';\n if(scene.staticMode) scene.container.appendChild(STATIC_CANVAS);\n\n // Force redraw\n scene.glplot.redraw();\n\n // Grab context and yank out pixels\n var gl = scene.glplot.gl;\n var w = gl.drawingBufferWidth;\n var h = gl.drawingBufferHeight;\n\n gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n\n var pixels = new Uint8Array(w * h * 4);\n gl.readPixels(0, 0, w, h, gl.RGBA, gl.UNSIGNED_BYTE, pixels);\n flipPixels(pixels, w, h);\n correctRGB(pixels, w, h);\n\n var canvas = document.createElement('canvas');\n canvas.width = w;\n canvas.height = h;\n var context = canvas.getContext('2d', {willReadFrequently: true});\n var imageData = context.createImageData(w, h);\n imageData.data.set(pixels);\n context.putImageData(imageData, 0, 0);\n\n var dataURL;\n\n switch(format) {\n case 'jpeg':\n dataURL = canvas.toDataURL('image/jpeg');\n break;\n case 'webp':\n dataURL = canvas.toDataURL('image/webp');\n break;\n default:\n dataURL = canvas.toDataURL('image/png');\n }\n\n if(scene.staticMode) scene.container.removeChild(STATIC_CANVAS);\n\n return dataURL;\n};\n\nproto.setConvert = function() {\n var scene = this;\n for(var i = 0; i < 3; i++) {\n var ax = scene.fullSceneLayout[axisProperties[i]];\n Axes.setConvert(ax, scene.fullLayout);\n ax.setScale = Lib.noop;\n }\n};\n\nproto.make4thDimension = function() {\n var scene = this;\n var gd = scene.graphDiv;\n var fullLayout = gd._fullLayout;\n\n // mock axis for hover formatting\n scene._mockAxis = {\n type: 'linear',\n showexponent: 'all',\n exponentformat: 'B'\n };\n Axes.setConvert(scene._mockAxis, fullLayout);\n};\n\nmodule.exports = Scene;\n","'use strict';\n\nmodule.exports = function zip3(x, y, z, len) {\n len = len || x.length;\n\n var result = new Array(len);\n for(var i = 0; i < len; i++) {\n result[i] = [x[i], y[i], z[i]];\n }\n return result;\n};\n","'use strict';\n\nvar fontAttrs = require('./font_attributes');\nvar animationAttrs = require('./animation_attributes');\nvar colorAttrs = require('../components/color/attributes');\nvar drawNewShapeAttrs = require('../components/shapes/draw_newshape/attributes');\nvar drawNewSelectionAttrs = require('../components/selections/draw_newselection/attributes');\nvar padAttrs = require('./pad_attributes');\nvar extendFlat = require('../lib/extend').extendFlat;\n\nvar globalFont = fontAttrs({\n editType: 'calc',\n description: [\n 'Sets the global font.',\n 'Note that fonts used in traces and other',\n 'layout components inherit from the global font.'\n ].join(' ')\n});\nglobalFont.family.dflt = '\"Open Sans\", verdana, arial, sans-serif';\nglobalFont.size.dflt = 12;\nglobalFont.color.dflt = colorAttrs.defaultLine;\n\nmodule.exports = {\n font: globalFont,\n title: {\n text: {\n valType: 'string',\n editType: 'layoutstyle',\n description: [\n 'Sets the plot\\'s title.',\n 'Note that before the existence of `title.text`, the title\\'s',\n 'contents used to be defined as the `title` attribute itself.',\n 'This behavior has been deprecated.'\n ].join(' ')\n },\n font: fontAttrs({\n editType: 'layoutstyle',\n description: [\n 'Sets the title font.',\n 'Note that the title\\'s font used to be customized',\n 'by the now deprecated `titlefont` attribute.'\n ].join(' ')\n }),\n subtitle: {\n text: {\n valType: 'string',\n editType: 'layoutstyle',\n description: 'Sets the plot\\'s subtitle.'\n },\n font: fontAttrs({\n editType: 'layoutstyle',\n description: 'Sets the subtitle font.'\n }),\n editType: 'layoutstyle',\n },\n xref: {\n valType: 'enumerated',\n dflt: 'container',\n values: ['container', 'paper'],\n editType: 'layoutstyle',\n description: [\n 'Sets the container `x` refers to.',\n '*container* spans the entire `width` of the plot.',\n '*paper* refers to the width of the plotting area only.'\n ].join(' ')\n },\n yref: {\n valType: 'enumerated',\n dflt: 'container',\n values: ['container', 'paper'],\n editType: 'layoutstyle',\n description: [\n 'Sets the container `y` refers to.',\n '*container* spans the entire `height` of the plot.',\n '*paper* refers to the height of the plotting area only.'\n ].join(' ')\n },\n x: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0.5,\n editType: 'layoutstyle',\n description: [\n 'Sets the x position with respect to `xref` in normalized',\n 'coordinates from *0* (left) to *1* (right).'\n ].join(' ')\n },\n y: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 'auto',\n editType: 'layoutstyle',\n description: [\n 'Sets the y position with respect to `yref` in normalized',\n 'coordinates from *0* (bottom) to *1* (top).',\n '*auto* places the baseline of the title onto the',\n 'vertical center of the top margin.'\n ].join(' ')\n },\n xanchor: {\n valType: 'enumerated',\n dflt: 'auto',\n values: ['auto', 'left', 'center', 'right'],\n editType: 'layoutstyle',\n description: [\n 'Sets the title\\'s horizontal alignment with respect to its x position.',\n '*left* means that the title starts at x,',\n '*right* means that the title ends at x',\n 'and *center* means that the title\\'s center is at x.',\n '*auto* divides `xref` by three and calculates the `xanchor`',\n 'value automatically based on the value of `x`.'\n ].join(' ')\n },\n yanchor: {\n valType: 'enumerated',\n dflt: 'auto',\n values: ['auto', 'top', 'middle', 'bottom'],\n editType: 'layoutstyle',\n description: [\n 'Sets the title\\'s vertical alignment with respect to its y position.',\n '*top* means that the title\\'s cap line is at y,',\n '*bottom* means that the title\\'s baseline is at y',\n 'and *middle* means that the title\\'s midline is at y.',\n '*auto* divides `yref` by three and calculates the `yanchor`',\n 'value automatically based on the value of `y`.'\n ].join(' ')\n },\n pad: extendFlat(padAttrs({editType: 'layoutstyle'}), {\n description: [\n 'Sets the padding of the title.',\n 'Each padding value only applies when the corresponding',\n '`xanchor`/`yanchor` value is set accordingly. E.g. for left',\n 'padding to take effect, `xanchor` must be set to *left*.',\n 'The same rule applies if `xanchor`/`yanchor` is determined automatically.',\n 'Padding is muted if the respective anchor value is *middle*/*center*.'\n ].join(' ')\n }),\n automargin: {\n valType: 'boolean',\n dflt: false,\n editType: 'plot',\n description: [\n 'Determines whether the title can automatically push the figure margins.',\n 'If `yref=\\'paper\\'` then the margin will expand to ensure that the title doesn\\’t',\n 'overlap with the edges of the container. If `yref=\\'container\\'` then the margins',\n 'will ensure that the title doesn\\’t overlap with the plot area, tick labels,',\n 'and axis titles. If `automargin=true` and the margins need to be expanded,',\n 'then y will be set to a default 1 and yanchor will be set to an appropriate',\n 'default to ensure that minimal margin space is needed. Note that when `yref=\\'paper\\'`,',\n 'only 1 or 0 are allowed y values. Invalid values will be reset to the default 1.'\n ].join(' ')\n },\n editType: 'layoutstyle'\n },\n uniformtext: {\n mode: {\n valType: 'enumerated',\n values: [false, 'hide', 'show'],\n dflt: false,\n editType: 'plot',\n description: [\n 'Determines how the font size for various text',\n 'elements are uniformed between each trace type.',\n 'If the computed text sizes were smaller than',\n 'the minimum size defined by `uniformtext.minsize`',\n 'using *hide* option hides the text; and',\n 'using *show* option shows the text without further downscaling.',\n 'Please note that if the size defined by `minsize` is greater than',\n 'the font size defined by trace, then the `minsize` is used.'\n ].join(' ')\n },\n minsize: {\n valType: 'number',\n min: 0,\n dflt: 0,\n editType: 'plot',\n description: [\n 'Sets the minimum text size between traces of the same type.'\n ].join(' ')\n },\n editType: 'plot'\n },\n autosize: {\n valType: 'boolean',\n dflt: false,\n // autosize, width, and height get special editType treatment in _relayout\n // so we can handle noop resizes more efficiently\n editType: 'none',\n description: [\n 'Determines whether or not a layout width or height',\n 'that has been left undefined by the user',\n 'is initialized on each relayout.',\n\n 'Note that, regardless of this attribute,',\n 'an undefined layout width or height',\n 'is always initialized on the first call to plot.'\n ].join(' ')\n },\n width: {\n valType: 'number',\n min: 10,\n dflt: 700,\n editType: 'plot',\n description: [\n 'Sets the plot\\'s width (in px).'\n ].join(' ')\n },\n height: {\n valType: 'number',\n min: 10,\n dflt: 450,\n editType: 'plot',\n description: [\n 'Sets the plot\\'s height (in px).'\n ].join(' ')\n },\n minreducedwidth: {\n valType: 'number',\n min: 2,\n dflt: 64,\n editType: 'plot',\n description: 'Minimum width of the plot with margin.automargin applied (in px)'\n },\n minreducedheight: {\n valType: 'number',\n min: 2,\n dflt: 64,\n editType: 'plot',\n description: 'Minimum height of the plot with margin.automargin applied (in px)'\n },\n margin: {\n l: {\n valType: 'number',\n min: 0,\n dflt: 80,\n editType: 'plot',\n description: 'Sets the left margin (in px).'\n },\n r: {\n valType: 'number',\n min: 0,\n dflt: 80,\n editType: 'plot',\n description: 'Sets the right margin (in px).'\n },\n t: {\n valType: 'number',\n min: 0,\n dflt: 100,\n editType: 'plot',\n description: 'Sets the top margin (in px).'\n },\n b: {\n valType: 'number',\n min: 0,\n dflt: 80,\n editType: 'plot',\n description: 'Sets the bottom margin (in px).'\n },\n pad: {\n valType: 'number',\n min: 0,\n dflt: 0,\n editType: 'plot',\n description: [\n 'Sets the amount of padding (in px)',\n 'between the plotting area and the axis lines'\n ].join(' ')\n },\n autoexpand: {\n valType: 'boolean',\n dflt: true,\n editType: 'plot',\n description: [\n 'Turns on/off margin expansion computations.',\n 'Legends, colorbars, updatemenus, sliders, axis rangeselector and rangeslider',\n 'are allowed to push the margins by defaults.'\n ].join(' ')\n },\n editType: 'plot'\n },\n computed: {\n valType: 'any',\n editType: 'none',\n description: [\n 'Placeholder for exporting automargin-impacting values namely',\n '`margin.t`, `margin.b`, `margin.l` and `margin.r` in *full-json* mode.',\n ].join(' ')\n },\n paper_bgcolor: {\n valType: 'color',\n dflt: colorAttrs.background,\n editType: 'plot',\n description: 'Sets the background color of the paper where the graph is drawn.'\n },\n plot_bgcolor: {\n // defined here, but set in cartesian.supplyLayoutDefaults\n // because it needs to know if there are (2D) axes or not\n valType: 'color',\n dflt: colorAttrs.background,\n editType: 'layoutstyle',\n description: [\n 'Sets the background color of the plotting area in-between x and y axes.'\n ].join(' ')\n },\n autotypenumbers: {\n valType: 'enumerated',\n values: ['convert types', 'strict'],\n dflt: 'convert types',\n editType: 'calc',\n description: [\n 'Using *strict* a numeric string in trace data is not converted to a number.',\n 'Using *convert types* a numeric string in trace data may be',\n 'treated as a number during automatic axis `type` detection.',\n 'This is the default value; however it could be overridden for individual axes.'\n ].join(' ')\n },\n separators: {\n valType: 'string',\n editType: 'plot',\n description: [\n 'Sets the decimal and thousand separators.',\n 'For example, *. * puts a \\'.\\' before decimals and a space',\n 'between thousands. In English locales, dflt is *.,* but',\n 'other locales may alter this default.'\n ].join(' ')\n },\n hidesources: {\n valType: 'boolean',\n dflt: false,\n editType: 'plot',\n description: [\n 'Determines whether or not a text link citing the data source is',\n 'placed at the bottom-right cored of the figure.',\n 'Has only an effect only on graphs that have been generated via',\n 'forked graphs from the Chart Studio Cloud (at https://chart-studio.plotly.com or on-premise).'\n ].join(' ')\n },\n showlegend: {\n // handled in legend.supplyLayoutDefaults\n // but included here because it's not in the legend object\n valType: 'boolean',\n editType: 'legend',\n description: [\n 'Determines whether or not a legend is drawn.',\n 'Default is `true` if there is a trace to show and any of these:',\n 'a) Two or more traces would by default be shown in the legend.',\n 'b) One pie trace is shown in the legend.',\n 'c) One trace is explicitly given with `showlegend: true`.'\n ].join(' ')\n },\n\n colorway: {\n valType: 'colorlist',\n dflt: colorAttrs.defaults,\n editType: 'calc',\n description: 'Sets the default trace colors.'\n },\n datarevision: {\n valType: 'any',\n editType: 'calc',\n description: [\n 'If provided, a changed value tells `Plotly.react` that',\n 'one or more data arrays has changed. This way you can modify',\n 'arrays in-place rather than making a complete new copy for an',\n 'incremental change.',\n 'If NOT provided, `Plotly.react` assumes that data arrays are',\n 'being treated as immutable, thus any data array with a',\n 'different identity from its predecessor contains new data.'\n ].join(' ')\n },\n uirevision: {\n valType: 'any',\n editType: 'none',\n description: [\n 'Used to allow user interactions with the plot to persist after',\n '`Plotly.react` calls that are unaware of these interactions.',\n 'If `uirevision` is omitted, or if it is given and it changed from',\n 'the previous `Plotly.react` call, the exact new figure is used.',\n 'If `uirevision` is truthy and did NOT change, any attribute',\n 'that has been affected by user interactions and did not receive a',\n 'different value in the new figure will keep the interaction value.',\n '`layout.uirevision` attribute serves as the default for',\n '`uirevision` attributes in various sub-containers. For finer',\n 'control you can set these sub-attributes directly. For example,',\n 'if your app separately controls the data on the x and y axes you',\n 'might set `xaxis.uirevision=*time*` and `yaxis.uirevision=*cost*`.',\n 'Then if only the y data is changed, you can update',\n '`yaxis.uirevision=*quantity*` and the y axis range will reset but',\n 'the x axis range will retain any user-driven zoom.'\n ].join(' ')\n },\n editrevision: {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in `editable: true`',\n 'configuration, other than trace names and axis titles.',\n 'Defaults to `layout.uirevision`.'\n ].join(' ')\n },\n selectionrevision: {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in selected points',\n 'from all traces.'\n ].join(' ')\n },\n template: {\n valType: 'any',\n editType: 'calc',\n description: [\n 'Default attributes to be applied to the plot. Templates can be',\n 'created from existing plots using `Plotly.makeTemplate`, or',\n 'created manually. They should be objects with format:',\n '`{layout: layoutTemplate, data: {[type]: [traceTemplate, ...]}, ...}`',\n '`layoutTemplate` and `traceTemplate` are objects matching the',\n 'attribute structure of `layout` and a data trace. ',\n 'Trace templates are applied cyclically to traces of each type.',\n 'Container arrays (eg `annotations`) have special handling:',\n 'An object ending in `defaults` (eg `annotationdefaults`) is applied',\n 'to each array item. But if an item has a `templateitemname` key',\n 'we look in the template array for an item with matching `name` and',\n 'apply that instead. If no matching `name` is found we mark the item',\n 'invisible. Any named template item not referenced is appended to',\n 'the end of the array, so you can use this for a watermark annotation',\n 'or a logo image, for example. To omit one of these items on the plot,',\n 'make an item with matching `templateitemname` and `visible: false`.'\n ].join(' ')\n },\n\n newshape: drawNewShapeAttrs.newshape,\n activeshape: drawNewShapeAttrs.activeshape,\n\n newselection: drawNewSelectionAttrs.newselection,\n activeselection: drawNewSelectionAttrs.activeselection,\n\n meta: {\n valType: 'any',\n arrayOk: true,\n editType: 'plot',\n description: [\n 'Assigns extra meta information that can be used in various `text` attributes.',\n 'Attributes such as the graph, axis and colorbar `title.text`, annotation `text`',\n '`trace.name` in legend items, `rangeselector`, `updatemenus` and `sliders` `label` text',\n 'all support `meta`. One can access `meta` fields using template strings:',\n '`%{meta[i]}` where `i` is the index of the `meta`',\n 'item in question.',\n '`meta` can also be an object for example `{key: value}` which can be accessed',\n '%{meta[key]}.'\n ].join(' ')\n },\n\n transition: extendFlat({}, animationAttrs.transition, {\n description: [\n 'Sets transition options used during Plotly.react updates.'\n ].join(' '),\n editType: 'none'\n }),\n _deprecated: {\n title: {\n valType: 'string',\n editType: 'layoutstyle',\n description: [\n 'Value of `title` is no longer a simple *string* but a set of sub-attributes.',\n 'To set the contents of the title, please use `title.text` now.'\n ].join(' ')\n },\n titlefont: fontAttrs({\n editType: 'layoutstyle',\n description: [\n 'Former `titlefont` is now the sub-attribute `font` of `title`.',\n 'To customize title font properties, please use `title.font` now.'\n ].join(' ')\n })\n }\n};\n","'use strict';\n\nvar sortObjectKeys = require('../../lib/sort_object_keys');\nvar arcgisSatHybrid = require('./styles/arcgis-sat-hybrid.json'); // https://raw.githubusercontent.com/go2garret/maps/v1.0.0/LICENSE\nvar arcgisSat = require('./styles/arcgis-sat.json');\n\n\nvar OSM = '© OpenStreetMap contributors';\n\nvar cartoPositron = 'https://basemaps.cartocdn.com/gl/positron-gl-style/style.json';\nvar cartoDarkmatter = 'https://basemaps.cartocdn.com/gl/dark-matter-gl-style/style.json';\nvar cartoVoyager = 'https://basemaps.cartocdn.com/gl/voyager-gl-style/style.json';\nvar cartoPositronNoLabels = 'https://basemaps.cartocdn.com/gl/positron-nolabels-gl-style/style.json';\nvar cartoDarkmatterNoLabels = 'https://basemaps.cartocdn.com/gl/dark-matter-nolabels-gl-style/style.json';\nvar cartoVoyagerNoLabels = 'https://basemaps.cartocdn.com/gl/voyager-nolabels-gl-style/style.json';\n\n\nvar stylesMap = {\n basic: cartoVoyager,\n streets: cartoVoyager,\n outdoors: cartoVoyager,\n light: cartoPositron,\n dark: cartoDarkmatter,\n satellite: arcgisSat,\n 'satellite-streets': arcgisSatHybrid,\n 'open-street-map': {\n id: 'osm',\n version: 8,\n sources: {\n 'plotly-osm-tiles': {\n type: 'raster',\n attribution: OSM,\n tiles: [\n 'https://tile.openstreetmap.org/{z}/{x}/{y}.png'\n ],\n tileSize: 256\n }\n },\n layers: [{\n id: 'plotly-osm-tiles',\n type: 'raster',\n source: 'plotly-osm-tiles',\n minzoom: 0,\n maxzoom: 22\n }],\n glyphs: 'https://fonts.openmaptiles.org/{fontstack}/{range}.pbf'\n },\n 'white-bg': {\n id: 'white-bg',\n version: 8,\n sources: {},\n layers: [{\n id: 'white-bg',\n type: 'background',\n paint: {'background-color': '#FFFFFF'},\n minzoom: 0,\n maxzoom: 22\n }],\n glyphs: 'https://fonts.openmaptiles.org/{fontstack}/{range}.pbf'\n },\n 'carto-positron': cartoPositron,\n 'carto-darkmatter': cartoDarkmatter,\n 'carto-voyager': cartoVoyager,\n 'carto-positron-nolabels': cartoPositronNoLabels,\n 'carto-darkmatter-nolabels': cartoDarkmatterNoLabels,\n 'carto-voyager-nolabels': cartoVoyagerNoLabels,\n};\n\nvar styleValuesMap = sortObjectKeys(stylesMap);\n\nmodule.exports = {\n styleValueDflt: 'basic',\n stylesMap: stylesMap,\n styleValuesMap: styleValuesMap,\n\n traceLayerPrefix: 'plotly-trace-layer-',\n layoutLayerPrefix: 'plotly-layout-layer-',\n\n\n missingStyleErrorMsg: [\n 'No valid maplibre style found, please set `map.style` to one of:',\n styleValuesMap.join(', '),\n 'or use a tile service.'\n ].join('\\n'),\n\n\n mapOnErrorMsg: 'Map error.',\n\n\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\n/**\n * Convert plotly.js 'textposition' to map-gl 'anchor' and 'offset'\n * (with the help of the icon size).\n *\n * @param {string} textpostion : plotly.js textposition value\n * @param {number} iconSize : plotly.js icon size (e.g. marker.size for traces)\n *\n * @return {object}\n * - anchor\n * - offset\n */\nmodule.exports = function convertTextOpts(textposition, iconSize) {\n var parts = textposition.split(' ');\n var vPos = parts[0];\n var hPos = parts[1];\n\n // ballpack values\n var factor = Lib.isArrayOrTypedArray(iconSize) ? Lib.mean(iconSize) : iconSize;\n var xInc = 0.5 + (factor / 100);\n var yInc = 1.5 + (factor / 100);\n\n var anchorVals = ['', ''];\n var offset = [0, 0];\n\n switch(vPos) {\n case 'top':\n anchorVals[0] = 'top';\n offset[1] = -yInc;\n break;\n case 'bottom':\n anchorVals[0] = 'bottom';\n offset[1] = yInc;\n break;\n }\n\n switch(hPos) {\n case 'left':\n anchorVals[1] = 'right';\n offset[0] = -xInc;\n break;\n case 'right':\n anchorVals[1] = 'left';\n offset[0] = xInc;\n break;\n }\n\n // Map text-anchor must be one of:\n // center, left, right, top, bottom,\n // top-left, top-right, bottom-left, bottom-right\n\n var anchor;\n if(anchorVals[0] && anchorVals[1]) anchor = anchorVals.join('-');\n else if(anchorVals[0]) anchor = anchorVals[0];\n else if(anchorVals[1]) anchor = anchorVals[1];\n else anchor = 'center';\n\n return { anchor: anchor, offset: offset };\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar strScale = Lib.strScale;\nvar getSubplotCalcData = require('../get_data').getSubplotCalcData;\nvar xmlnsNamespaces = require('../../constants/xmlns_namespaces');\nvar d3 = require('@plotly/d3');\nvar Drawing = require('../../components/drawing');\nvar svgTextUtils = require('../../lib/svg_text_utils');\n\nvar Map = require('./map');\n\nvar MAP = 'map';\n\nexports.name = MAP;\n\nexports.attr = 'subplot';\n\nexports.idRoot = MAP;\n\nexports.idRegex = exports.attrRegex = Lib.counterRegex(MAP);\n\nexports.attributes = {\n subplot: {\n valType: 'subplotid',\n dflt: 'map',\n editType: 'calc',\n description: [\n 'Sets a reference between this trace\\'s data coordinates and',\n 'a map subplot.',\n 'If *map* (the default value), the data refer to `layout.map`.',\n 'If *map2*, the data refer to `layout.map2`, and so on.'\n ].join(' ')\n }\n};\n\nexports.layoutAttributes = require('./layout_attributes');\n\nexports.supplyLayoutDefaults = require('./layout_defaults');\n\nexports.plot = function plot(gd) {\n var fullLayout = gd._fullLayout;\n var calcData = gd.calcdata;\n var mapIds = fullLayout._subplots[MAP];\n\n for(var i = 0; i < mapIds.length; i++) {\n var id = mapIds[i];\n var subplotCalcData = getSubplotCalcData(calcData, MAP, id);\n var opts = fullLayout[id];\n var map = opts._subplot;\n\n if(!map) {\n map = new Map(gd, id);\n fullLayout[id]._subplot = map;\n }\n\n if(!map.viewInitial) {\n map.viewInitial = {\n center: Lib.extendFlat({}, opts.center),\n zoom: opts.zoom,\n bearing: opts.bearing,\n pitch: opts.pitch\n };\n }\n\n map.plot(subplotCalcData, fullLayout, gd._promises);\n }\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var oldMapKeys = oldFullLayout._subplots[MAP] || [];\n\n for(var i = 0; i < oldMapKeys.length; i++) {\n var oldMapKey = oldMapKeys[i];\n\n if(!newFullLayout[oldMapKey] && !!oldFullLayout[oldMapKey]._subplot) {\n oldFullLayout[oldMapKey]._subplot.destroy();\n }\n }\n};\n\nexports.toSVG = function(gd) {\n var fullLayout = gd._fullLayout;\n var subplotIds = fullLayout._subplots[MAP];\n var size = fullLayout._size;\n\n for(var i = 0; i < subplotIds.length; i++) {\n var opts = fullLayout[subplotIds[i]];\n var domain = opts.domain;\n var map = opts._subplot;\n\n var imageData = map.toImage('png');\n var image = fullLayout._glimages.append('svg:image');\n\n image.attr({\n xmlns: xmlnsNamespaces.svg,\n 'xlink:href': imageData,\n x: size.l + size.w * domain.x[0],\n y: size.t + size.h * (1 - domain.y[1]),\n width: size.w * (domain.x[1] - domain.x[0]),\n height: size.h * (domain.y[1] - domain.y[0]),\n preserveAspectRatio: 'none'\n });\n\n var subplotDiv = d3.select(opts._subplot.div);\n\n // Add attributions\n var attributions = subplotDiv\n .select('.maplibregl-ctrl-attrib').text()\n .replace('Improve this map', '');\n\n var attributionGroup = fullLayout._glimages.append('g');\n\n var attributionText = attributionGroup.append('text');\n attributionText\n .text(attributions)\n .classed('static-attribution', true)\n .attr({\n 'font-size': 12,\n 'font-family': 'Arial',\n color: 'rgba(0, 0, 0, 0.75)',\n 'text-anchor': 'end',\n 'data-unformatted': attributions\n });\n\n var bBox = Drawing.bBox(attributionText.node());\n\n // Break into multiple lines twice larger than domain\n var maxWidth = size.w * (domain.x[1] - domain.x[0]);\n if((bBox.width > maxWidth / 2)) {\n var multilineAttributions = attributions.split('|').join('
');\n attributionText\n .text(multilineAttributions)\n .attr('data-unformatted', multilineAttributions)\n .call(svgTextUtils.convertToTspans, gd);\n\n bBox = Drawing.bBox(attributionText.node());\n }\n attributionText.attr('transform', strTranslate(-3, -bBox.height + 8));\n\n // Draw white rectangle behind text\n attributionGroup\n .insert('rect', '.static-attribution')\n .attr({\n x: -bBox.width - 6,\n y: -bBox.height - 3,\n width: bBox.width + 6,\n height: bBox.height + 3,\n fill: 'rgba(255, 255, 255, 0.75)'\n });\n\n // Scale down if larger than domain\n var scaleRatio = 1;\n if((bBox.width + 6) > maxWidth) scaleRatio = maxWidth / (bBox.width + 6);\n\n var offset = [(size.l + size.w * domain.x[1]), (size.t + size.h * (1 - domain.y[0]))];\n attributionGroup.attr('transform', strTranslate(offset[0], offset[1]) + strScale(scaleRatio));\n }\n};\n\nexports.updateFx = function(gd) {\n var fullLayout = gd._fullLayout;\n var subplotIds = fullLayout._subplots[MAP];\n\n for(var i = 0; i < subplotIds.length; i++) {\n var subplotObj = fullLayout[subplotIds[i]]._subplot;\n subplotObj.updateFx(fullLayout);\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar sanitizeHTML = require('../../lib/svg_text_utils').sanitizeHTML;\nvar convertTextOpts = require('./convert_text_opts');\nvar constants = require('./constants');\n\nfunction MapLayer(subplot, index) {\n this.subplot = subplot;\n\n this.uid = subplot.uid + '-' + index;\n this.index = index;\n\n this.idSource = 'source-' + this.uid;\n this.idLayer = constants.layoutLayerPrefix + this.uid;\n\n // some state variable to check if a remove/add step is needed\n this.sourceType = null;\n this.source = null;\n this.layerType = null;\n this.below = null;\n\n // is layer currently visible\n this.visible = false;\n}\n\nvar proto = MapLayer.prototype;\n\nproto.update = function update(opts) {\n if(!this.visible) {\n // IMPORTANT: must create source before layer to not cause errors\n this.updateSource(opts);\n this.updateLayer(opts);\n } else if(this.needsNewImage(opts)) {\n this.updateImage(opts);\n } else if(this.needsNewSource(opts)) {\n // IMPORTANT: must delete layer before source to not cause errors\n this.removeLayer();\n this.updateSource(opts);\n this.updateLayer(opts);\n } else if(this.needsNewLayer(opts)) {\n this.updateLayer(opts);\n } else {\n this.updateStyle(opts);\n }\n\n this.visible = isVisible(opts);\n};\n\nproto.needsNewImage = function(opts) {\n var map = this.subplot.map;\n return (\n map.getSource(this.idSource) &&\n this.sourceType === 'image' &&\n opts.sourcetype === 'image' &&\n (this.source !== opts.source ||\n JSON.stringify(this.coordinates) !==\n JSON.stringify(opts.coordinates))\n );\n};\n\nproto.needsNewSource = function(opts) {\n // for some reason changing layer to 'fill' or 'symbol'\n // w/o changing the source throws an exception in map-gl 0.18 ;\n // stay safe and make new source on type changes\n return (\n this.sourceType !== opts.sourcetype ||\n JSON.stringify(this.source) !== JSON.stringify(opts.source) ||\n this.layerType !== opts.type\n );\n};\n\nproto.needsNewLayer = function(opts) {\n return (\n this.layerType !== opts.type ||\n this.below !== this.subplot.belowLookup['layout-' + this.index]\n );\n};\n\nproto.lookupBelow = function() {\n return this.subplot.belowLookup['layout-' + this.index];\n};\n\nproto.updateImage = function(opts) {\n var map = this.subplot.map;\n map.getSource(this.idSource).updateImage({\n url: opts.source, coordinates: opts.coordinates\n });\n\n // Since the `updateImage` control flow doesn't call updateLayer,\n // We need to take care of moving the image layer to match the location\n // where updateLayer would have placed it.\n var _below = this.findFollowingMapLayerId(this.lookupBelow());\n if(_below !== null) {\n this.subplot.map.moveLayer(this.idLayer, _below);\n }\n};\n\nproto.updateSource = function(opts) {\n var map = this.subplot.map;\n\n if(map.getSource(this.idSource)) map.removeSource(this.idSource);\n\n this.sourceType = opts.sourcetype;\n this.source = opts.source;\n\n if(!isVisible(opts)) return;\n\n var sourceOpts = convertSourceOpts(opts);\n\n map.addSource(this.idSource, sourceOpts);\n};\n\nproto.findFollowingMapLayerId = function(below) {\n if(below === 'traces') {\n var mapLayers = this.subplot.getMapLayers();\n\n // find id of first plotly trace layer\n for(var i = 0; i < mapLayers.length; i++) {\n var layerId = mapLayers[i].id;\n if(typeof layerId === 'string' &&\n layerId.indexOf(constants.traceLayerPrefix) === 0\n ) {\n below = layerId;\n break;\n }\n }\n }\n return below;\n};\n\nproto.updateLayer = function(opts) {\n var subplot = this.subplot;\n var convertedOpts = convertOpts(opts);\n var below = this.lookupBelow();\n var _below = this.findFollowingMapLayerId(below);\n\n this.removeLayer();\n\n if(isVisible(opts)) {\n subplot.addLayer({\n id: this.idLayer,\n source: this.idSource,\n 'source-layer': opts.sourcelayer || '',\n type: opts.type,\n minzoom: opts.minzoom,\n maxzoom: opts.maxzoom,\n layout: convertedOpts.layout,\n paint: convertedOpts.paint\n }, _below);\n }\n\n this.layerType = opts.type;\n this.below = below;\n};\n\nproto.updateStyle = function(opts) {\n if(isVisible(opts)) {\n var convertedOpts = convertOpts(opts);\n this.subplot.setOptions(this.idLayer, 'setLayoutProperty', convertedOpts.layout);\n this.subplot.setOptions(this.idLayer, 'setPaintProperty', convertedOpts.paint);\n }\n};\n\nproto.removeLayer = function() {\n var map = this.subplot.map;\n if(map.getLayer(this.idLayer)) {\n map.removeLayer(this.idLayer);\n }\n};\n\nproto.dispose = function() {\n var map = this.subplot.map;\n if(map.getLayer(this.idLayer)) map.removeLayer(this.idLayer);\n if(map.getSource(this.idSource)) map.removeSource(this.idSource);\n};\n\nfunction isVisible(opts) {\n if(!opts.visible) return false;\n\n var source = opts.source;\n\n if(Array.isArray(source) && source.length > 0) {\n for(var i = 0; i < source.length; i++) {\n if(typeof source[i] !== 'string' || source[i].length === 0) {\n return false;\n }\n }\n return true;\n }\n\n return Lib.isPlainObject(source) ||\n (typeof source === 'string' && source.length > 0);\n}\n\nfunction convertOpts(opts) {\n var layout = {};\n var paint = {};\n\n switch(opts.type) {\n case 'circle':\n Lib.extendFlat(paint, {\n 'circle-radius': opts.circle.radius,\n 'circle-color': opts.color,\n 'circle-opacity': opts.opacity\n });\n break;\n\n case 'line':\n Lib.extendFlat(paint, {\n 'line-width': opts.line.width,\n 'line-color': opts.color,\n 'line-opacity': opts.opacity,\n 'line-dasharray': opts.line.dash\n });\n break;\n\n case 'fill':\n Lib.extendFlat(paint, {\n 'fill-color': opts.color,\n 'fill-outline-color': opts.fill.outlinecolor,\n 'fill-opacity': opts.opacity\n\n // no way to pass specify outline width at the moment\n });\n break;\n\n case 'symbol':\n var symbol = opts.symbol;\n var textOpts = convertTextOpts(symbol.textposition, symbol.iconsize);\n\n Lib.extendFlat(layout, {\n 'icon-image': symbol.icon + '-15',\n 'icon-size': symbol.iconsize / 10,\n\n 'text-field': symbol.text,\n 'text-size': symbol.textfont.size,\n 'text-anchor': textOpts.anchor,\n 'text-offset': textOpts.offset,\n 'symbol-placement': symbol.placement,\n\n // TODO font family\n // 'text-font': symbol.textfont.family.split(', '),\n });\n\n Lib.extendFlat(paint, {\n 'icon-color': opts.color,\n 'text-color': symbol.textfont.color,\n 'text-opacity': opts.opacity\n });\n break;\n case 'raster':\n Lib.extendFlat(paint, {\n 'raster-fade-duration': 0,\n 'raster-opacity': opts.opacity\n });\n break;\n }\n\n return {\n layout: layout,\n paint: paint\n };\n}\n\nfunction convertSourceOpts(opts) {\n var sourceType = opts.sourcetype;\n var source = opts.source;\n var sourceOpts = {type: sourceType};\n var field;\n\n if(sourceType === 'geojson') {\n field = 'data';\n } else if(sourceType === 'vector') {\n field = typeof source === 'string' ? 'url' : 'tiles';\n } else if(sourceType === 'raster') {\n field = 'tiles';\n sourceOpts.tileSize = 256;\n } else if(sourceType === 'image') {\n field = 'url';\n sourceOpts.coordinates = opts.coordinates;\n }\n\n sourceOpts[field] = source;\n\n if(opts.sourceattribution) {\n sourceOpts.attribution = sanitizeHTML(opts.sourceattribution);\n }\n\n return sourceOpts;\n}\n\nmodule.exports = function createMapLayer(subplot, index, opts) {\n var mapLayer = new MapLayer(subplot, index);\n\n mapLayer.update(opts);\n\n return mapLayer;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar defaultLine = require('../../components/color').defaultLine;\nvar domainAttrs = require('../domain').attributes;\nvar fontAttrs = require('../font_attributes');\nvar textposition = require('../../traces/scatter/attributes').textposition;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\n\nvar constants = require('./constants');\n\nvar fontAttr = fontAttrs({\n noFontVariant: true,\n noFontShadow: true,\n noFontLineposition: true,\n noFontTextcase: true,\n description: [\n 'Sets the icon text font (color=map.layer.paint.text-color, size=map.layer.layout.text-size).',\n 'Has an effect only when `type` is set to *symbol*.'\n ].join(' ')\n});\nfontAttr.family.dflt = 'Open Sans Regular, Arial Unicode MS Regular';\n\nvar attrs = module.exports = overrideAll({\n _arrayAttrRegexps: [Lib.counterRegex('map', '.layers', true)],\n\n domain: domainAttrs({name: 'map'}),\n\n style: {\n valType: 'any',\n values: constants.styleValuesMap,\n dflt: constants.styleValueDflt,\n description: [\n 'Defines the map layers that are rendered by default below the trace layers defined in `data`,',\n 'which are themselves by default rendered below the layers defined in `layout.map.layers`.',\n '',\n 'These layers can be defined either explicitly as a Map Style object which can contain multiple',\n 'layer definitions that load data from any public or private Tile Map Service (TMS or XYZ) or Web Map Service (WMS)',\n 'or implicitly by using one of the built-in style objects which use WMSes',\n 'or by using a custom style URL',\n '',\n 'Map Style objects are of the form described in the MapLibre GL JS documentation available at',\n 'https://maplibre.org/maplibre-style-spec/',\n '',\n 'The built-in plotly.js styles objects are:', constants.styleValuesMap.join(', ') + '.'\n ].join(' ')\n },\n\n center: {\n lon: {\n valType: 'number',\n dflt: 0,\n description: 'Sets the longitude of the center of the map (in degrees East).'\n },\n lat: {\n valType: 'number',\n dflt: 0,\n description: 'Sets the latitude of the center of the map (in degrees North).'\n }\n },\n zoom: {\n valType: 'number',\n dflt: 1,\n description: 'Sets the zoom level of the map (map.zoom).'\n },\n bearing: {\n valType: 'number',\n dflt: 0,\n description: 'Sets the bearing angle of the map in degrees counter-clockwise from North (map.bearing).'\n },\n pitch: {\n valType: 'number',\n dflt: 0,\n description: [\n 'Sets the pitch angle of the map',\n '(in degrees, where *0* means perpendicular to the surface of the map) (map.pitch).'\n ].join(' ')\n },\n\n bounds: {\n west: {\n valType: 'number',\n description: [\n 'Sets the minimum longitude of the map (in degrees East)',\n 'if `east`, `south` and `north` are declared.'\n ].join(' ')\n },\n east: {\n valType: 'number',\n description: [\n 'Sets the maximum longitude of the map (in degrees East)',\n 'if `west`, `south` and `north` are declared.'\n ].join(' ')\n },\n south: {\n valType: 'number',\n description: [\n 'Sets the minimum latitude of the map (in degrees North)',\n 'if `east`, `west` and `north` are declared.'\n ].join(' ')\n },\n north: {\n valType: 'number',\n description: [\n 'Sets the maximum latitude of the map (in degrees North)',\n 'if `east`, `west` and `south` are declared.'\n ].join(' ')\n }\n },\n\n layers: templatedArray('layer', {\n visible: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Determines whether this layer is displayed'\n ].join(' ')\n },\n sourcetype: {\n valType: 'enumerated',\n values: ['geojson', 'vector', 'raster', 'image'],\n dflt: 'geojson',\n description: [\n 'Sets the source type for this layer,',\n 'that is the type of the layer data.'\n ].join(' ')\n },\n\n source: {\n valType: 'any',\n description: [\n 'Sets the source data for this layer (map.layer.source).',\n 'When `sourcetype` is set to *geojson*, `source` can be a URL to a GeoJSON',\n 'or a GeoJSON object.',\n 'When `sourcetype` is set to *vector* or *raster*, `source` can be a URL or',\n 'an array of tile URLs.',\n 'When `sourcetype` is set to *image*, `source` can be a URL to an image.'\n ].join(' ')\n },\n\n sourcelayer: {\n valType: 'string',\n dflt: '',\n description: [\n 'Specifies the layer to use from a vector tile source (map.layer.source-layer).',\n 'Required for *vector* source type that supports multiple layers.'\n ].join(' ')\n },\n\n sourceattribution: {\n valType: 'string',\n description: [\n 'Sets the attribution for this source.'\n ].join(' ')\n },\n\n type: {\n valType: 'enumerated',\n values: ['circle', 'line', 'fill', 'symbol', 'raster'],\n dflt: 'circle',\n description: [\n 'Sets the layer type,',\n 'that is the how the layer data set in `source` will be rendered',\n 'With `sourcetype` set to *geojson*, the following values are allowed:',\n '*circle*, *line*, *fill* and *symbol*.',\n 'but note that *line* and *fill* are not compatible with Point',\n 'GeoJSON geometries.',\n 'With `sourcetype` set to *vector*, the following values are allowed:',\n ' *circle*, *line*, *fill* and *symbol*.',\n 'With `sourcetype` set to *raster* or `*image*`, only the *raster* value is allowed.'\n ].join(' ')\n },\n\n coordinates: {\n valType: 'any',\n description: [\n 'Sets the coordinates array contains [longitude, latitude] pairs',\n 'for the image corners listed in clockwise order:',\n 'top left, top right, bottom right, bottom left.',\n 'Only has an effect for *image* `sourcetype`.'\n ].join(' ')\n },\n\n // attributes shared between all types\n below: {\n valType: 'string',\n description: [\n 'Determines if the layer will be inserted',\n 'before the layer with the specified ID.',\n 'If omitted or set to \\'\\',',\n 'the layer will be inserted above every existing layer.'\n ].join(' ')\n },\n color: {\n valType: 'color',\n dflt: defaultLine,\n description: [\n 'Sets the primary layer color.',\n 'If `type` is *circle*, color corresponds to the circle color (map.layer.paint.circle-color)',\n 'If `type` is *line*, color corresponds to the line color (map.layer.paint.line-color)',\n 'If `type` is *fill*, color corresponds to the fill color (map.layer.paint.fill-color)',\n 'If `type` is *symbol*, color corresponds to the icon color (map.layer.paint.icon-color)'\n ].join(' ')\n },\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n description: [\n 'Sets the opacity of the layer.',\n 'If `type` is *circle*, opacity corresponds to the circle opacity (map.layer.paint.circle-opacity)',\n 'If `type` is *line*, opacity corresponds to the line opacity (map.layer.paint.line-opacity)',\n 'If `type` is *fill*, opacity corresponds to the fill opacity (map.layer.paint.fill-opacity)',\n 'If `type` is *symbol*, opacity corresponds to the icon/text opacity (map.layer.paint.text-opacity)'\n ].join(' ')\n },\n minzoom: {\n valType: 'number',\n min: 0,\n max: 24,\n dflt: 0,\n description: [\n 'Sets the minimum zoom level (map.layer.minzoom).',\n 'At zoom levels less than the minzoom, the layer will be hidden.',\n ].join(' ')\n },\n maxzoom: {\n valType: 'number',\n min: 0,\n max: 24,\n dflt: 24,\n description: [\n 'Sets the maximum zoom level (map.layer.maxzoom).',\n 'At zoom levels equal to or greater than the maxzoom, the layer will be hidden.'\n ].join(' ')\n },\n\n // type-specific style attributes\n circle: {\n radius: {\n valType: 'number',\n dflt: 15,\n description: [\n 'Sets the circle radius (map.layer.paint.circle-radius).',\n 'Has an effect only when `type` is set to *circle*.'\n ].join(' ')\n }\n },\n\n line: {\n width: {\n valType: 'number',\n dflt: 2,\n description: [\n 'Sets the line width (map.layer.paint.line-width).',\n 'Has an effect only when `type` is set to *line*.'\n ].join(' ')\n },\n dash: {\n valType: 'data_array',\n description: [\n 'Sets the length of dashes and gaps (map.layer.paint.line-dasharray).',\n 'Has an effect only when `type` is set to *line*.'\n ].join(' ')\n }\n },\n\n fill: {\n outlinecolor: {\n valType: 'color',\n dflt: defaultLine,\n description: [\n 'Sets the fill outline color (map.layer.paint.fill-outline-color).',\n 'Has an effect only when `type` is set to *fill*.'\n ].join(' ')\n }\n },\n\n symbol: {\n icon: {\n valType: 'string',\n dflt: 'marker',\n description: [\n 'Sets the symbol icon image (map.layer.layout.icon-image).',\n 'Full list: https://www.map.com/maki-icons/'\n ].join(' ')\n },\n iconsize: {\n valType: 'number',\n dflt: 10,\n description: [\n 'Sets the symbol icon size (map.layer.layout.icon-size).',\n 'Has an effect only when `type` is set to *symbol*.'\n ].join(' ')\n },\n text: {\n valType: 'string',\n dflt: '',\n description: [\n 'Sets the symbol text (map.layer.layout.text-field).'\n ].join(' ')\n },\n placement: {\n valType: 'enumerated',\n values: ['point', 'line', 'line-center'],\n dflt: 'point',\n description: [\n 'Sets the symbol and/or text placement (map.layer.layout.symbol-placement).',\n 'If `placement` is *point*, the label is placed where the geometry is located',\n 'If `placement` is *line*, the label is placed along the line of the geometry',\n 'If `placement` is *line-center*, the label is placed on the center of the geometry',\n ].join(' ')\n },\n textfont: fontAttr,\n textposition: Lib.extendFlat({}, textposition, { arrayOk: false })\n }\n })\n}, 'plot', 'from-root');\n\n// set uirevision outside of overrideAll so it can be `editType: 'none'`\nattrs.uirevision = {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in the view:',\n '`center`, `zoom`, `bearing`, `pitch`. Defaults to `layout.uirevision`.'\n ].join(' ')\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar handleSubplotDefaults = require('../subplot_defaults');\nvar handleArrayContainerDefaults = require('../array_container_defaults');\nvar layoutAttributes = require('./layout_attributes');\n\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut, fullData) {\n handleSubplotDefaults(layoutIn, layoutOut, fullData, {\n type: 'map',\n attributes: layoutAttributes,\n handleDefaults: handleDefaults,\n partition: 'y'\n });\n};\n\nfunction handleDefaults(containerIn, containerOut, coerce) {\n coerce('style');\n coerce('center.lon');\n coerce('center.lat');\n coerce('zoom');\n coerce('bearing');\n coerce('pitch');\n\n var west = coerce('bounds.west');\n var east = coerce('bounds.east');\n var south = coerce('bounds.south');\n var north = coerce('bounds.north');\n if(\n west === undefined ||\n east === undefined ||\n south === undefined ||\n north === undefined\n ) {\n delete containerOut.bounds;\n }\n\n handleArrayContainerDefaults(containerIn, containerOut, {\n name: 'layers',\n handleItemDefaults: handleLayerDefaults\n });\n\n // copy ref to input container to update 'center' and 'zoom' on map move\n containerOut._input = containerIn;\n}\n\nfunction handleLayerDefaults(layerIn, layerOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(layerIn, layerOut, layoutAttributes.layers, attr, dflt);\n }\n\n var visible = coerce('visible');\n if(visible) {\n var sourceType = coerce('sourcetype');\n var mustBeRasterLayer = sourceType === 'raster' || sourceType === 'image';\n\n coerce('source');\n coerce('sourceattribution');\n\n if(sourceType === 'vector') {\n coerce('sourcelayer');\n }\n\n if(sourceType === 'image') {\n coerce('coordinates');\n }\n\n var typeDflt;\n if(mustBeRasterLayer) typeDflt = 'raster';\n\n var type = coerce('type', typeDflt);\n\n if(mustBeRasterLayer && type !== 'raster') {\n type = layerOut.type = 'raster';\n Lib.log('Source types *raster* and *image* must drawn *raster* layer type.');\n }\n\n coerce('below');\n coerce('color');\n coerce('opacity');\n coerce('minzoom');\n coerce('maxzoom');\n\n if(type === 'circle') {\n coerce('circle.radius');\n }\n\n if(type === 'line') {\n coerce('line.width');\n coerce('line.dash');\n }\n\n if(type === 'fill') {\n coerce('fill.outlinecolor');\n }\n\n if(type === 'symbol') {\n coerce('symbol.icon');\n coerce('symbol.iconsize');\n\n coerce('symbol.text');\n Lib.coerceFont(coerce, 'symbol.textfont', undefined, {\n noFontVariant: true,\n noFontShadow: true,\n noFontLineposition: true,\n noFontTextcase: true,\n });\n coerce('symbol.textposition');\n coerce('symbol.placement');\n }\n }\n}\n","'use strict';\n\nvar maplibregl = require('maplibre-gl/dist/maplibre-gl-unminified');\n\nvar Lib = require('../../lib');\nvar geoUtils = require('../../lib/geo_location_utils');\nvar Registry = require('../../registry');\nvar Axes = require('../cartesian/axes');\nvar dragElement = require('../../components/dragelement');\n\nvar Fx = require('../../components/fx');\nvar dragHelpers = require('../../components/dragelement/helpers');\nvar drawMode = dragHelpers.drawMode;\nvar selectMode = dragHelpers.selectMode;\n\nvar prepSelect = require('../../components/selections').prepSelect;\nvar clearOutline = require('../../components/selections').clearOutline;\nvar clearSelectionsCache = require('../../components/selections').clearSelectionsCache;\nvar selectOnClick = require('../../components/selections').selectOnClick;\n\nvar constants = require('./constants');\nvar createMapLayer = require('./layers');\n\nfunction Map(gd, id) {\n this.id = id;\n this.gd = gd;\n\n var fullLayout = gd._fullLayout;\n var context = gd._context;\n\n this.container = fullLayout._glcontainer.node();\n this.isStatic = context.staticPlot;\n\n // unique id for this Map instance\n this.uid = fullLayout._uid + '-' + this.id;\n\n // create framework on instantiation for a smoother first plot call\n this.div = null;\n this.xaxis = null;\n this.yaxis = null;\n this.createFramework(fullLayout);\n\n // state variables used to infer how and what to update\n this.map = null;\n this.styleObj = null;\n this.traceHash = {};\n this.layerList = [];\n this.belowLookup = {};\n this.dragging = false;\n this.wheeling = false;\n}\n\nvar proto = Map.prototype;\n\nproto.plot = function(calcData, fullLayout, promises) {\n var self = this;\n\n var promise;\n\n if(!self.map) {\n promise = new Promise(function(resolve, reject) {\n self.createMap(calcData, fullLayout, resolve, reject);\n });\n } else {\n promise = new Promise(function(resolve, reject) {\n self.updateMap(calcData, fullLayout, resolve, reject);\n });\n }\n\n promises.push(promise);\n};\n\nproto.createMap = function(calcData, fullLayout, resolve, reject) {\n var self = this;\n var opts = fullLayout[self.id];\n\n // store style id and URL or object\n var styleObj = self.styleObj = getStyleObj(opts.style);\n\n\n var bounds = opts.bounds;\n var maxBounds = bounds ? [[bounds.west, bounds.south], [bounds.east, bounds.north]] : null;\n\n // create the map!\n var map = self.map = new maplibregl.Map({\n container: self.div,\n\n style: styleObj.style,\n center: convertCenter(opts.center),\n zoom: opts.zoom,\n bearing: opts.bearing,\n pitch: opts.pitch,\n maxBounds: maxBounds,\n\n interactive: !self.isStatic,\n preserveDrawingBuffer: self.isStatic,\n\n doubleClickZoom: false,\n boxZoom: false,\n\n attributionControl: false\n })\n .addControl(new maplibregl.AttributionControl({\n compact: true\n }));\n\n var requestedIcons = {};\n map.on('styleimagemissing', function(e) {\n var id = e.id;\n if(!requestedIcons[id] && id.includes('-15')) {\n requestedIcons[id] = true;\n var img = new Image(15, 15);\n img.onload = function() {\n map.addImage(id, img);\n };\n img.crossOrigin = 'Anonymous';\n img.src = 'https://unpkg.com/maki@2.1.0/icons/' + id + '.svg';\n }\n });\n\n map.setTransformRequest(function(url) {\n url = url.replace('https://fonts.openmaptiles.org/Open Sans Extrabold', 'https://fonts.openmaptiles.org/Open Sans Extra Bold');\n url = url.replace('https://tiles.basemaps.cartocdn.com/fonts/Open Sans Extrabold', 'https://fonts.openmaptiles.org/Open Sans Extra Bold');\n url = url.replace('https://fonts.openmaptiles.org/Open Sans Regular,Arial Unicode MS Regular', 'https://fonts.openmaptiles.org/Klokantech Noto Sans Regular');\n return {\n url: url\n };\n });\n\n\n // make sure canvas does not inherit left and top css\n map._canvas.style.left = '0px';\n map._canvas.style.top = '0px';\n\n self.rejectOnError(reject);\n\n if(!self.isStatic) {\n self.initFx(calcData, fullLayout);\n }\n\n var promises = [];\n\n promises.push(new Promise(function(resolve) {\n map.once('load', resolve);\n }));\n\n promises = promises.concat(geoUtils.fetchTraceGeoData(calcData));\n\n Promise.all(promises).then(function() {\n self.fillBelowLookup(calcData, fullLayout);\n self.updateData(calcData);\n self.updateLayout(fullLayout);\n self.resolveOnRender(resolve);\n }).catch(reject);\n};\n\nproto.updateMap = function(calcData, fullLayout, resolve, reject) {\n var self = this;\n var map = self.map;\n var opts = fullLayout[this.id];\n\n self.rejectOnError(reject);\n\n var promises = [];\n var styleObj = getStyleObj(opts.style);\n\n if(JSON.stringify(self.styleObj) !== JSON.stringify(styleObj)) {\n self.styleObj = styleObj;\n map.setStyle(styleObj.style);\n\n // need to rebuild trace layers on reload\n // to avoid 'lost event' errors\n self.traceHash = {};\n\n promises.push(new Promise(function(resolve) {\n map.once('styledata', resolve);\n }));\n }\n\n promises = promises.concat(geoUtils.fetchTraceGeoData(calcData));\n\n Promise.all(promises).then(function() {\n self.fillBelowLookup(calcData, fullLayout);\n self.updateData(calcData);\n self.updateLayout(fullLayout);\n self.resolveOnRender(resolve);\n }).catch(reject);\n};\n\nproto.fillBelowLookup = function(calcData, fullLayout) {\n var opts = fullLayout[this.id];\n var layers = opts.layers;\n var i, val;\n\n var belowLookup = this.belowLookup = {};\n var hasTraceAtTop = false;\n\n for(i = 0; i < calcData.length; i++) {\n var trace = calcData[i][0].trace;\n var _module = trace._module;\n\n if(typeof trace.below === 'string') {\n val = trace.below;\n } else if(_module.getBelow) {\n // 'smart' default that depend the map's base layers\n val = _module.getBelow(trace, this);\n }\n\n if(val === '') {\n hasTraceAtTop = true;\n }\n\n belowLookup['trace-' + trace.uid] = val || '';\n }\n\n for(i = 0; i < layers.length; i++) {\n var item = layers[i];\n\n if(typeof item.below === 'string') {\n val = item.below;\n } else if(hasTraceAtTop) {\n // if one or more trace(s) set `below:''` and\n // layers[i].below is unset,\n // place layer below traces\n val = 'traces';\n } else {\n val = '';\n }\n\n belowLookup['layout-' + i] = val;\n }\n\n // N.B. If multiple layers have the 'below' value,\n // we must clear the stashed 'below' field in order\n // to make `traceHash[k].update()` and `layerList[i].update()`\n // remove/add the all those layers to have preserve\n // the correct layer ordering\n var val2list = {};\n var k, id;\n\n for(k in belowLookup) {\n val = belowLookup[k];\n if(val2list[val]) {\n val2list[val].push(k);\n } else {\n val2list[val] = [k];\n }\n }\n\n for(val in val2list) {\n var list = val2list[val];\n if(list.length > 1) {\n for(i = 0; i < list.length; i++) {\n k = list[i];\n if(k.indexOf('trace-') === 0) {\n id = k.split('trace-')[1];\n if(this.traceHash[id]) {\n this.traceHash[id].below = null;\n }\n } else if(k.indexOf('layout-') === 0) {\n id = k.split('layout-')[1];\n if(this.layerList[id]) {\n this.layerList[id].below = null;\n }\n }\n }\n }\n }\n};\n\nvar traceType2orderIndex = {\n choroplethmap: 0,\n densitymap: 1,\n scattermap: 2\n};\n\nproto.updateData = function(calcData) {\n var traceHash = this.traceHash;\n var traceObj, trace, i, j;\n\n // Need to sort here by trace type here,\n // in case traces with different `type` have the same\n // below value, but sorting we ensure that\n // e.g. choroplethmap traces will be below scattermap traces\n var calcDataSorted = calcData.slice().sort(function(a, b) {\n return (\n traceType2orderIndex[a[0].trace.type] -\n traceType2orderIndex[b[0].trace.type]\n );\n });\n\n // update or create trace objects\n for(i = 0; i < calcDataSorted.length; i++) {\n var calcTrace = calcDataSorted[i];\n\n trace = calcTrace[0].trace;\n traceObj = traceHash[trace.uid];\n\n var didUpdate = false;\n if(traceObj) {\n if(traceObj.type === trace.type) {\n traceObj.update(calcTrace);\n didUpdate = true;\n } else {\n traceObj.dispose();\n }\n }\n if(!didUpdate && trace._module) {\n traceHash[trace.uid] = trace._module.plot(this, calcTrace);\n }\n }\n\n // remove empty trace objects\n var ids = Object.keys(traceHash);\n idLoop:\n for(i = 0; i < ids.length; i++) {\n var id = ids[i];\n\n for(j = 0; j < calcData.length; j++) {\n trace = calcData[j][0].trace;\n if(id === trace.uid) continue idLoop;\n }\n\n traceObj = traceHash[id];\n traceObj.dispose();\n delete traceHash[id];\n }\n};\n\nproto.updateLayout = function(fullLayout) {\n var map = this.map;\n var opts = fullLayout[this.id];\n\n if(!this.dragging && !this.wheeling) {\n map.setCenter(convertCenter(opts.center));\n map.setZoom(opts.zoom);\n map.setBearing(opts.bearing);\n map.setPitch(opts.pitch);\n }\n\n this.updateLayers(fullLayout);\n this.updateFramework(fullLayout);\n this.updateFx(fullLayout);\n this.map.resize();\n\n if(this.gd._context._scrollZoom.map) {\n map.scrollZoom.enable();\n } else {\n map.scrollZoom.disable();\n }\n};\n\nproto.resolveOnRender = function(resolve) {\n var map = this.map;\n\n map.on('render', function onRender() {\n if(map.loaded()) {\n map.off('render', onRender);\n // resolve at end of render loop\n //\n // Need a 10ms delay (0ms should suffice to skip a thread in the\n // render loop) to workaround map-gl bug introduced in v1.3.0\n setTimeout(resolve, 10);\n }\n });\n};\n\nproto.rejectOnError = function(reject) {\n var map = this.map;\n\n function handler() {\n reject(new Error(constants.mapOnErrorMsg));\n }\n\n map.once('error', handler);\n map.once('style.error', handler);\n map.once('source.error', handler);\n map.once('tile.error', handler);\n map.once('layer.error', handler);\n};\n\nproto.createFramework = function(fullLayout) {\n var self = this;\n\n var div = self.div = document.createElement('div');\n div.id = self.uid;\n div.style.position = 'absolute';\n self.container.appendChild(div);\n\n // create mock x/y axes for hover routine\n self.xaxis = {\n _id: 'x',\n c2p: function(v) { return self.project(v).x; }\n };\n self.yaxis = {\n _id: 'y',\n c2p: function(v) { return self.project(v).y; }\n };\n\n self.updateFramework(fullLayout);\n\n // mock axis for hover formatting\n self.mockAxis = {\n type: 'linear',\n showexponent: 'all',\n exponentformat: 'B'\n };\n Axes.setConvert(self.mockAxis, fullLayout);\n};\n\nproto.initFx = function(calcData, fullLayout) {\n var self = this;\n var gd = self.gd;\n var map = self.map;\n\n // keep track of pan / zoom in user layout and emit relayout event\n map.on('moveend', function(evt) {\n if(!self.map) return;\n\n var fullLayoutNow = gd._fullLayout;\n\n // 'moveend' gets triggered by map.setCenter, map.setZoom,\n // map.setBearing and map.setPitch.\n //\n // Here, we make sure that state updates amd 'plotly_relayout'\n // are triggered only when the 'moveend' originates from a\n // mouse target (filtering out API calls) to not\n // duplicate 'plotly_relayout' events.\n\n if(evt.originalEvent || self.wheeling) {\n var optsNow = fullLayoutNow[self.id];\n Registry.call('_storeDirectGUIEdit', gd.layout, fullLayoutNow._preGUI, self.getViewEdits(optsNow));\n\n var viewNow = self.getView();\n optsNow._input.center = optsNow.center = viewNow.center;\n optsNow._input.zoom = optsNow.zoom = viewNow.zoom;\n optsNow._input.bearing = optsNow.bearing = viewNow.bearing;\n optsNow._input.pitch = optsNow.pitch = viewNow.pitch;\n gd.emit('plotly_relayout', self.getViewEditsWithDerived(viewNow));\n }\n if(evt.originalEvent && evt.originalEvent.type === 'mouseup') {\n self.dragging = false;\n } else if(self.wheeling) {\n self.wheeling = false;\n }\n\n if(fullLayoutNow && fullLayoutNow._rehover) {\n fullLayoutNow._rehover();\n }\n });\n\n map.on('wheel', function() {\n self.wheeling = true;\n });\n\n map.on('mousemove', function(evt) {\n var bb = self.div.getBoundingClientRect();\n var xy = [\n evt.originalEvent.offsetX,\n evt.originalEvent.offsetY\n ];\n\n evt.target.getBoundingClientRect = function() { return bb; };\n\n self.xaxis.p2c = function() { return map.unproject(xy).lng; };\n self.yaxis.p2c = function() { return map.unproject(xy).lat; };\n\n gd._fullLayout._rehover = function() {\n if(gd._fullLayout._hoversubplot === self.id && gd._fullLayout[self.id]) {\n Fx.hover(gd, evt, self.id);\n }\n };\n\n Fx.hover(gd, evt, self.id);\n gd._fullLayout._hoversubplot = self.id;\n });\n\n function unhover() {\n Fx.loneUnhover(fullLayout._hoverlayer);\n }\n\n map.on('dragstart', function() {\n self.dragging = true;\n unhover();\n });\n map.on('zoomstart', unhover);\n\n map.on('mouseout', function() {\n gd._fullLayout._hoversubplot = null;\n });\n\n function emitUpdate() {\n var viewNow = self.getView();\n gd.emit('plotly_relayouting', self.getViewEditsWithDerived(viewNow));\n }\n\n map.on('drag', emitUpdate);\n map.on('zoom', emitUpdate);\n\n map.on('dblclick', function() {\n var optsNow = gd._fullLayout[self.id];\n Registry.call('_storeDirectGUIEdit', gd.layout, gd._fullLayout._preGUI, self.getViewEdits(optsNow));\n\n var viewInitial = self.viewInitial;\n map.setCenter(convertCenter(viewInitial.center));\n map.setZoom(viewInitial.zoom);\n map.setBearing(viewInitial.bearing);\n map.setPitch(viewInitial.pitch);\n\n var viewNow = self.getView();\n optsNow._input.center = optsNow.center = viewNow.center;\n optsNow._input.zoom = optsNow.zoom = viewNow.zoom;\n optsNow._input.bearing = optsNow.bearing = viewNow.bearing;\n optsNow._input.pitch = optsNow.pitch = viewNow.pitch;\n\n gd.emit('plotly_doubleclick', null);\n gd.emit('plotly_relayout', self.getViewEditsWithDerived(viewNow));\n });\n\n // define event handlers on map creation, to keep one ref per map,\n // so that map.on / map.off in updateFx works as expected\n self.clearOutline = function() {\n clearSelectionsCache(self.dragOptions);\n clearOutline(self.dragOptions.gd);\n };\n\n /**\n * Returns a click handler function that is supposed\n * to handle clicks in pan mode.\n */\n self.onClickInPanFn = function(dragOptions) {\n return function(evt) {\n var clickMode = gd._fullLayout.clickmode;\n\n if(clickMode.indexOf('select') > -1) {\n selectOnClick(evt.originalEvent, gd, [self.xaxis], [self.yaxis], self.id, dragOptions);\n }\n\n if(clickMode.indexOf('event') > -1) {\n // TODO: this does not support right-click. If we want to support it, we\n // would likely need to change map to use dragElement instead of straight\n // map event binding. Or perhaps better, make a simple wrapper with the\n // right mousedown, mousemove, and mouseup handlers just for a left/right click\n // pie would use this too.\n Fx.click(gd, evt.originalEvent);\n }\n };\n };\n};\n\nproto.updateFx = function(fullLayout) {\n var self = this;\n var map = self.map;\n var gd = self.gd;\n\n if(self.isStatic) return;\n\n function invert(pxpy) {\n var obj = self.map.unproject(pxpy);\n return [obj.lng, obj.lat];\n }\n\n var dragMode = fullLayout.dragmode;\n var fillRangeItems;\n\n fillRangeItems = function(eventData, poly) {\n if(poly.isRect) {\n var ranges = eventData.range = {};\n ranges[self.id] = [\n invert([poly.xmin, poly.ymin]),\n invert([poly.xmax, poly.ymax])\n ];\n } else {\n var dataPts = eventData.lassoPoints = {};\n dataPts[self.id] = poly.map(invert);\n }\n };\n\n // Note: dragOptions is needed to be declared for all dragmodes because\n // it's the object that holds persistent selection state.\n // Merge old dragOptions with new to keep possibly initialized\n // persistent selection state.\n var oldDragOptions = self.dragOptions;\n self.dragOptions = Lib.extendDeep(oldDragOptions || {}, {\n dragmode: fullLayout.dragmode,\n element: self.div,\n gd: gd,\n plotinfo: {\n id: self.id,\n domain: fullLayout[self.id].domain,\n xaxis: self.xaxis,\n yaxis: self.yaxis,\n fillRangeItems: fillRangeItems\n },\n xaxes: [self.xaxis],\n yaxes: [self.yaxis],\n subplot: self.id\n });\n\n // Unregister the old handler before potentially registering\n // a new one. Otherwise multiple click handlers might\n // be registered resulting in unwanted behavior.\n map.off('click', self.onClickInPanHandler);\n if(selectMode(dragMode) || drawMode(dragMode)) {\n map.dragPan.disable();\n map.on('zoomstart', self.clearOutline);\n\n self.dragOptions.prepFn = function(e, startX, startY) {\n prepSelect(e, startX, startY, self.dragOptions, dragMode);\n };\n\n dragElement.init(self.dragOptions);\n } else {\n map.dragPan.enable();\n map.off('zoomstart', self.clearOutline);\n self.div.onmousedown = null;\n self.div.ontouchstart = null;\n self.div.removeEventListener('touchstart', self.div._ontouchstart);\n // TODO: this does not support right-click. If we want to support it, we\n // would likely need to change map to use dragElement instead of straight\n // map event binding. Or perhaps better, make a simple wrapper with the\n // right mousedown, mousemove, and mouseup handlers just for a left/right click\n // pie would use this too.\n self.onClickInPanHandler = self.onClickInPanFn(self.dragOptions);\n map.on('click', self.onClickInPanHandler);\n }\n};\n\nproto.updateFramework = function(fullLayout) {\n var domain = fullLayout[this.id].domain;\n var size = fullLayout._size;\n\n var style = this.div.style;\n style.width = size.w * (domain.x[1] - domain.x[0]) + 'px';\n style.height = size.h * (domain.y[1] - domain.y[0]) + 'px';\n style.left = size.l + domain.x[0] * size.w + 'px';\n style.top = size.t + (1 - domain.y[1]) * size.h + 'px';\n\n this.xaxis._offset = size.l + domain.x[0] * size.w;\n this.xaxis._length = size.w * (domain.x[1] - domain.x[0]);\n\n this.yaxis._offset = size.t + (1 - domain.y[1]) * size.h;\n this.yaxis._length = size.h * (domain.y[1] - domain.y[0]);\n};\n\nproto.updateLayers = function(fullLayout) {\n var opts = fullLayout[this.id];\n var layers = opts.layers;\n var layerList = this.layerList;\n var i;\n\n // if the layer arrays don't match,\n // don't try to be smart,\n // delete them all, and start all over.\n\n if(layers.length !== layerList.length) {\n for(i = 0; i < layerList.length; i++) {\n layerList[i].dispose();\n }\n\n layerList = this.layerList = [];\n\n for(i = 0; i < layers.length; i++) {\n layerList.push(createMapLayer(this, i, layers[i]));\n }\n } else {\n for(i = 0; i < layers.length; i++) {\n layerList[i].update(layers[i]);\n }\n }\n};\n\nproto.destroy = function() {\n if(this.map) {\n this.map.remove();\n this.map = null;\n this.container.removeChild(this.div);\n }\n};\n\nproto.toImage = function() {\n this.map.stop();\n return this.map.getCanvas().toDataURL();\n};\n\n// convenience wrapper to create set multiple layer\n// 'layout' or 'paint options at once.\nproto.setOptions = function(id, methodName, opts) {\n for(var k in opts) {\n this.map[methodName](id, k, opts[k]);\n }\n};\n\nproto.getMapLayers = function() {\n return this.map.getStyle().layers;\n};\n\n// convenience wrapper that first check in 'below' references\n// a layer that exist and then add the layer to the map,\nproto.addLayer = function(opts, below) {\n var map = this.map;\n\n if(typeof below === 'string') {\n if(below === '') {\n map.addLayer(opts, below);\n return;\n }\n\n var mapLayers = this.getMapLayers();\n for(var i = 0; i < mapLayers.length; i++) {\n if(below === mapLayers[i].id) {\n map.addLayer(opts, below);\n return;\n }\n }\n\n Lib.warn([\n 'Trying to add layer with *below* value',\n below,\n 'referencing a layer that does not exist',\n 'or that does not yet exist.'\n ].join(' '));\n }\n\n map.addLayer(opts);\n};\n\n// convenience method to project a [lon, lat] array to pixel coords\nproto.project = function(v) {\n return this.map.project(new maplibregl.LngLat(v[0], v[1]));\n};\n\n// get map's current view values in plotly.js notation\nproto.getView = function() {\n var map = this.map;\n var mapCenter = map.getCenter();\n var lon = mapCenter.lng;\n var lat = mapCenter.lat;\n var center = { lon: lon, lat: lat };\n\n var canvas = map.getCanvas();\n var w = parseInt(canvas.style.width);\n var h = parseInt(canvas.style.height);\n\n return {\n center: center,\n zoom: map.getZoom(),\n bearing: map.getBearing(),\n pitch: map.getPitch(),\n _derived: {\n coordinates: [\n map.unproject([0, 0]).toArray(),\n map.unproject([w, 0]).toArray(),\n map.unproject([w, h]).toArray(),\n map.unproject([0, h]).toArray()\n ]\n }\n };\n};\n\nproto.getViewEdits = function(cont) {\n var id = this.id;\n var keys = ['center', 'zoom', 'bearing', 'pitch'];\n var obj = {};\n\n for(var i = 0; i < keys.length; i++) {\n var k = keys[i];\n obj[id + '.' + k] = cont[k];\n }\n\n return obj;\n};\n\nproto.getViewEditsWithDerived = function(cont) {\n var id = this.id;\n var obj = this.getViewEdits(cont);\n obj[id + '._derived'] = cont._derived;\n return obj;\n};\n\nfunction getStyleObj(val) {\n var styleObj = {};\n\n if(Lib.isPlainObject(val)) {\n styleObj.id = val.id;\n styleObj.style = val;\n } else if(typeof val === 'string') {\n styleObj.id = val;\n\n if(constants.stylesMap[val]) {\n styleObj.style = constants.stylesMap[val];\n } else {\n styleObj.style = val;\n }\n } else {\n styleObj.id = constants.styleValueDflt;\n styleObj.style = convertStyleVal(constants.styleValueDflt);\n }\n\n styleObj.transition = {duration: 0, delay: 0};\n\n return styleObj;\n}\n\n// if style is part of the 'official' map values, add URL prefix and suffix\nfunction convertStyleVal(val) {\n return constants.styleUrlPrefix + val + '-' + constants.styleUrlSuffix;\n}\n\nfunction convertCenter(center) {\n return [center.lon, center.lat];\n}\n\nmodule.exports = Map;\n","'use strict';\n\nvar sortObjectKeys = require('../../lib/sort_object_keys');\n\nvar requiredVersion = '1.13.4';\n\nvar OSM = '© OpenStreetMap contributors';\nvar carto = [\n '© Carto',\n OSM\n].join(' ');\n\nvar stamenTerrainOrToner = [\n 'Map tiles by Stamen Design',\n 'under CC BY 3.0',\n '|',\n 'Data by OpenStreetMap contributors',\n 'under ODbL'\n].join(' ');\n\nvar stamenWaterColor = [\n 'Map tiles by Stamen Design',\n 'under CC BY 3.0',\n '|',\n 'Data by OpenStreetMap contributors',\n 'under CC BY SA'\n].join(' ');\n\nvar stylesNonMapbox = {\n 'open-street-map': {\n id: 'osm',\n version: 8,\n sources: {\n 'plotly-osm-tiles': {\n type: 'raster',\n attribution: OSM,\n tiles: [\n 'https://a.tile.openstreetmap.org/{z}/{x}/{y}.png',\n 'https://b.tile.openstreetmap.org/{z}/{x}/{y}.png'\n ],\n tileSize: 256\n }\n },\n layers: [{\n id: 'plotly-osm-tiles',\n type: 'raster',\n source: 'plotly-osm-tiles',\n minzoom: 0,\n maxzoom: 22\n }],\n glyphs: 'https://fonts.openmaptiles.org/{fontstack}/{range}.pbf'\n },\n 'white-bg': {\n id: 'white-bg',\n version: 8,\n sources: {},\n layers: [{\n id: 'white-bg',\n type: 'background',\n paint: {'background-color': '#FFFFFF'},\n minzoom: 0,\n maxzoom: 22\n }],\n glyphs: 'https://fonts.openmaptiles.org/{fontstack}/{range}.pbf'\n },\n 'carto-positron': {\n id: 'carto-positron',\n version: 8,\n sources: {\n 'plotly-carto-positron': {\n type: 'raster',\n attribution: carto,\n tiles: ['https://cartodb-basemaps-c.global.ssl.fastly.net/light_all/{z}/{x}/{y}.png'],\n tileSize: 256\n }\n },\n layers: [{\n id: 'plotly-carto-positron',\n type: 'raster',\n source: 'plotly-carto-positron',\n minzoom: 0,\n maxzoom: 22\n }],\n glyphs: 'https://fonts.openmaptiles.org/{fontstack}/{range}.pbf'\n },\n 'carto-darkmatter': {\n id: 'carto-darkmatter',\n version: 8,\n sources: {\n 'plotly-carto-darkmatter': {\n type: 'raster',\n attribution: carto,\n tiles: ['https://cartodb-basemaps-c.global.ssl.fastly.net/dark_all/{z}/{x}/{y}.png'],\n tileSize: 256\n }\n },\n layers: [{\n id: 'plotly-carto-darkmatter',\n type: 'raster',\n source: 'plotly-carto-darkmatter',\n minzoom: 0,\n maxzoom: 22\n }],\n glyphs: 'https://fonts.openmaptiles.org/{fontstack}/{range}.pbf'\n },\n 'stamen-terrain': {\n id: 'stamen-terrain',\n version: 8,\n sources: {\n 'plotly-stamen-terrain': {\n type: 'raster',\n attribution: stamenTerrainOrToner,\n tiles: ['https://tiles.stadiamaps.com/tiles/stamen_terrain/{z}/{x}/{y}.png?api_key='],\n tileSize: 256\n }\n },\n layers: [{\n id: 'plotly-stamen-terrain',\n type: 'raster',\n source: 'plotly-stamen-terrain',\n minzoom: 0,\n maxzoom: 22\n }],\n glyphs: 'https://fonts.openmaptiles.org/{fontstack}/{range}.pbf'\n },\n 'stamen-toner': {\n id: 'stamen-toner',\n version: 8,\n sources: {\n 'plotly-stamen-toner': {\n type: 'raster',\n attribution: stamenTerrainOrToner,\n tiles: ['https://tiles.stadiamaps.com/tiles/stamen_toner/{z}/{x}/{y}.png?api_key='],\n tileSize: 256\n }\n },\n layers: [{\n id: 'plotly-stamen-toner',\n type: 'raster',\n source: 'plotly-stamen-toner',\n minzoom: 0,\n maxzoom: 22\n }],\n glyphs: 'https://fonts.openmaptiles.org/{fontstack}/{range}.pbf'\n },\n 'stamen-watercolor': {\n id: 'stamen-watercolor',\n version: 8,\n sources: {\n 'plotly-stamen-watercolor': {\n type: 'raster',\n attribution: stamenWaterColor,\n tiles: ['https://tiles.stadiamaps.com/tiles/stamen_watercolor/{z}/{x}/{y}.jpg?api_key='],\n tileSize: 256\n }\n },\n layers: [{\n id: 'plotly-stamen-watercolor',\n type: 'raster',\n source: 'plotly-stamen-watercolor',\n minzoom: 0,\n maxzoom: 22\n }],\n glyphs: 'https://fonts.openmaptiles.org/{fontstack}/{range}.pbf'\n }\n};\n\nvar styleValuesNonMapbox = sortObjectKeys(stylesNonMapbox);\n\nmodule.exports = {\n requiredVersion: requiredVersion,\n\n styleUrlPrefix: 'mapbox://styles/mapbox/',\n styleUrlSuffix: 'v9',\n\n styleValuesMapbox: ['basic', 'streets', 'outdoors', 'light', 'dark', 'satellite', 'satellite-streets'],\n styleValueDflt: 'basic',\n stylesNonMapbox: stylesNonMapbox,\n styleValuesNonMapbox: styleValuesNonMapbox,\n\n traceLayerPrefix: 'plotly-trace-layer-',\n layoutLayerPrefix: 'plotly-layout-layer-',\n\n wrongVersionErrorMsg: [\n 'Your custom plotly.js bundle is not using the correct mapbox-gl version',\n 'Please install @plotly/mapbox-gl@' + requiredVersion + '.'\n ].join('\\n'),\n\n noAccessTokenErrorMsg: [\n 'Missing Mapbox access token.',\n 'Mapbox trace type require a Mapbox access token to be registered.',\n 'For example:',\n ' Plotly.newPlot(gd, data, layout, { mapboxAccessToken: \\'my-access-token\\' });',\n 'More info here: https://www.mapbox.com/help/define-access-token/'\n ].join('\\n'),\n\n missingStyleErrorMsg: [\n 'No valid mapbox style found, please set `mapbox.style` to one of:',\n styleValuesNonMapbox.join(', '),\n 'or register a Mapbox access token to use a Mapbox-served style.'\n ].join('\\n'),\n\n multipleTokensErrorMsg: [\n 'Set multiple mapbox access token across different mapbox subplot,',\n 'using first token found as mapbox-gl does not allow multiple' +\n 'access tokens on the same page.'\n ].join('\\n'),\n\n mapOnErrorMsg: 'Mapbox error.',\n\n // Mapbox logo for static export\n mapboxLogo: {\n path0: 'm 10.5,1.24 c -5.11,0 -9.25,4.15 -9.25,9.25 0,5.1 4.15,9.25 9.25,9.25 5.1,0 9.25,-4.15 9.25,-9.25 0,-5.11 -4.14,-9.25 -9.25,-9.25 z m 4.39,11.53 c -1.93,1.93 -4.78,2.31 -6.7,2.31 -0.7,0 -1.41,-0.05 -2.1,-0.16 0,0 -1.02,-5.64 2.14,-8.81 0.83,-0.83 1.95,-1.28 3.13,-1.28 1.27,0 2.49,0.51 3.39,1.42 1.84,1.84 1.89,4.75 0.14,6.52 z',\n path1: 'M 10.5,-0.01 C 4.7,-0.01 0,4.7 0,10.49 c 0,5.79 4.7,10.5 10.5,10.5 5.8,0 10.5,-4.7 10.5,-10.5 C 20.99,4.7 16.3,-0.01 10.5,-0.01 Z m 0,19.75 c -5.11,0 -9.25,-4.15 -9.25,-9.25 0,-5.1 4.14,-9.26 9.25,-9.26 5.11,0 9.25,4.15 9.25,9.25 0,5.13 -4.14,9.26 -9.25,9.26 z',\n path2: 'M 14.74,6.25 C 12.9,4.41 9.98,4.35 8.23,6.1 5.07,9.27 6.09,14.91 6.09,14.91 c 0,0 5.64,1.02 8.81,-2.14 C 16.64,11 16.59,8.09 14.74,6.25 Z m -2.27,4.09 -0.91,1.87 -0.9,-1.87 -1.86,-0.91 1.86,-0.9 0.9,-1.87 0.91,1.87 1.86,0.9 z',\n polygon: '11.56,12.21 10.66,10.34 8.8,9.43 10.66,8.53 11.56,6.66 12.47,8.53 14.33,9.43 12.47,10.34'\n },\n\n // a subset of node_modules/mapbox-gl/dist/mapbox-gl.css\n styleRules: {\n map: 'overflow:hidden;position:relative;',\n 'missing-css': 'display:none;',\n canary: 'background-color:salmon;',\n\n // Reusing CSS directives from: https://api.tiles.mapbox.com/mapbox-gl-js/v1.1.1/mapbox-gl.css\n 'ctrl-bottom-left': 'position: absolute; pointer-events: none; z-index: 2; bottom: 0; left: 0;',\n 'ctrl-bottom-right': 'position: absolute; pointer-events: none; z-index: 2; right: 0; bottom: 0;',\n ctrl: 'clear: both; pointer-events: auto; transform: translate(0, 0);',\n\n // Compact ctrl\n 'ctrl-attrib.mapboxgl-compact .mapboxgl-ctrl-attrib-inner': 'display: none;',\n 'ctrl-attrib.mapboxgl-compact:hover .mapboxgl-ctrl-attrib-inner': 'display: block; margin-top:2px',\n 'ctrl-attrib.mapboxgl-compact:hover': 'padding: 2px 24px 2px 4px; visibility: visible; margin-top: 6px;',\n 'ctrl-attrib.mapboxgl-compact::after': 'content: \"\"; cursor: pointer; position: absolute; background-image: url(\\'data:image/svg+xml;charset=utf-8,%3Csvg viewBox=\"0 0 20 20\" xmlns=\"http://www.w3.org/2000/svg\"%3E %3Cpath fill=\"%23333333\" fill-rule=\"evenodd\" d=\"M4,10a6,6 0 1,0 12,0a6,6 0 1,0 -12,0 M9,7a1,1 0 1,0 2,0a1,1 0 1,0 -2,0 M9,10a1,1 0 1,1 2,0l0,3a1,1 0 1,1 -2,0\"/%3E %3C/svg%3E\\'); background-color: rgba(255, 255, 255, 0.5); width: 24px; height: 24px; box-sizing: border-box; border-radius: 12px;',\n 'ctrl-attrib.mapboxgl-compact': 'min-height: 20px; padding: 0; margin: 10px; position: relative; background-color: #fff; border-radius: 3px 12px 12px 3px;',\n 'ctrl-bottom-right > .mapboxgl-ctrl-attrib.mapboxgl-compact::after': 'bottom: 0; right: 0',\n 'ctrl-bottom-left > .mapboxgl-ctrl-attrib.mapboxgl-compact::after': 'bottom: 0; left: 0',\n\n 'ctrl-bottom-left .mapboxgl-ctrl': 'margin: 0 0 10px 10px; float: left;',\n 'ctrl-bottom-right .mapboxgl-ctrl': 'margin: 0 10px 10px 0; float: right;',\n\n 'ctrl-attrib': 'color: rgba(0, 0, 0, 0.75); text-decoration: none; font-size: 12px',\n 'ctrl-attrib a': 'color: rgba(0, 0, 0, 0.75); text-decoration: none; font-size: 12px',\n 'ctrl-attrib a:hover': 'color: inherit; text-decoration: underline;',\n\n 'ctrl-attrib .mapbox-improve-map': 'font-weight: bold; margin-left: 2px;',\n 'attrib-empty': 'display: none;',\n\n // Compact Mapbox logo without text\n 'ctrl-logo': 'display:block; width: 21px; height: 21px; background-image: url(\\'data:image/svg+xml;charset=utf-8,%3C?xml version=\"1.0\" encoding=\"utf-8\"?%3E %3Csvg version=\"1.1\" id=\"Layer_1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\" viewBox=\"0 0 21 21\" style=\"enable-background:new 0 0 21 21;\" xml:space=\"preserve\"%3E%3Cg transform=\"translate(0,0.01)\"%3E%3Cpath d=\"m 10.5,1.24 c -5.11,0 -9.25,4.15 -9.25,9.25 0,5.1 4.15,9.25 9.25,9.25 5.1,0 9.25,-4.15 9.25,-9.25 0,-5.11 -4.14,-9.25 -9.25,-9.25 z m 4.39,11.53 c -1.93,1.93 -4.78,2.31 -6.7,2.31 -0.7,0 -1.41,-0.05 -2.1,-0.16 0,0 -1.02,-5.64 2.14,-8.81 0.83,-0.83 1.95,-1.28 3.13,-1.28 1.27,0 2.49,0.51 3.39,1.42 1.84,1.84 1.89,4.75 0.14,6.52 z\" style=\"opacity:0.9;fill:%23ffffff;enable-background:new\" class=\"st0\"/%3E%3Cpath d=\"M 10.5,-0.01 C 4.7,-0.01 0,4.7 0,10.49 c 0,5.79 4.7,10.5 10.5,10.5 5.8,0 10.5,-4.7 10.5,-10.5 C 20.99,4.7 16.3,-0.01 10.5,-0.01 Z m 0,19.75 c -5.11,0 -9.25,-4.15 -9.25,-9.25 0,-5.1 4.14,-9.26 9.25,-9.26 5.11,0 9.25,4.15 9.25,9.25 0,5.13 -4.14,9.26 -9.25,9.26 z\" style=\"opacity:0.35;enable-background:new\" class=\"st1\"/%3E%3Cpath d=\"M 14.74,6.25 C 12.9,4.41 9.98,4.35 8.23,6.1 5.07,9.27 6.09,14.91 6.09,14.91 c 0,0 5.64,1.02 8.81,-2.14 C 16.64,11 16.59,8.09 14.74,6.25 Z m -2.27,4.09 -0.91,1.87 -0.9,-1.87 -1.86,-0.91 1.86,-0.9 0.9,-1.87 0.91,1.87 1.86,0.9 z\" style=\"opacity:0.35;enable-background:new\" class=\"st1\"/%3E%3Cpolygon points=\"11.56,12.21 10.66,10.34 8.8,9.43 10.66,8.53 11.56,6.66 12.47,8.53 14.33,9.43 12.47,10.34 \" style=\"opacity:0.9;fill:%23ffffff;enable-background:new\" class=\"st0\"/%3E%3C/g%3E%3C/svg%3E\\')'\n\n // Mapbox logo WITH text below (commented out for now)\n // 'ctrl-logo': 'width: 85px; height: 21px; margin: 0 0 -3px -3px; display: block; background-repeat: no-repeat; cursor: pointer; background-image: url(\\'data:image/svg+xml;charset=utf-8,%3C?xml version=\"1.0\" encoding=\"utf-8\"?%3E%3Csvg version=\"1.1\" id=\"Layer_1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\" viewBox=\"0 0 84.49 21\" style=\"enable-background:new 0 0 84.49 21;\" xml:space=\"preserve\"%3E%3Cg%3E %3Cpath class=\"st0\" style=\"opacity:0.9; fill: %23FFFFFF; enable-background: new;\" d=\"M83.25,14.26c0,0.12-0.09,0.21-0.21,0.21h-1.61c-0.13,0-0.24-0.06-0.3-0.17l-1.44-2.39l-1.44,2.39 c-0.06,0.11-0.18,0.17-0.3,0.17h-1.61c-0.04,0-0.08-0.01-0.12-0.03c-0.09-0.06-0.13-0.19-0.06-0.28l0,0l2.43-3.68L76.2,6.84 c-0.02-0.03-0.03-0.07-0.03-0.12c0-0.12,0.09-0.21,0.21-0.21h1.61c0.13,0,0.24,0.06,0.3,0.17l1.41,2.36l1.4-2.35 c0.06-0.11,0.18-0.17,0.3-0.17H83c0.04,0,0.08,0.01,0.12,0.03c0.09,0.06,0.13,0.19,0.06,0.28l0,0l-2.37,3.63l2.43,3.67 C83.24,14.18,83.25,14.22,83.25,14.26z\"/%3E %3Cpath class=\"st0\" style=\"opacity:0.9; fill: %23FFFFFF; enable-background: new;\" d=\"M66.24,9.59c-0.39-1.88-1.96-3.28-3.84-3.28c-1.03,0-2.03,0.42-2.73,1.18V3.51c0-0.13-0.1-0.23-0.23-0.23h-1.4 c-0.13,0-0.23,0.11-0.23,0.23v10.72c0,0.13,0.1,0.23,0.23,0.23h1.4c0.13,0,0.23-0.11,0.23-0.23V13.5c0.71,0.75,1.7,1.18,2.73,1.18 c1.88,0,3.45-1.41,3.84-3.29C66.37,10.79,66.37,10.18,66.24,9.59L66.24,9.59z M62.08,13c-1.32,0-2.39-1.11-2.41-2.48v-0.06 c0.02-1.38,1.09-2.48,2.41-2.48s2.42,1.12,2.42,2.51S63.41,13,62.08,13z\"/%3E %3Cpath class=\"st0\" style=\"opacity:0.9; fill: %23FFFFFF; enable-background: new;\" d=\"M71.67,6.32c-1.98-0.01-3.72,1.35-4.16,3.29c-0.13,0.59-0.13,1.19,0,1.77c0.44,1.94,2.17,3.32,4.17,3.3 c2.35,0,4.26-1.87,4.26-4.19S74.04,6.32,71.67,6.32z M71.65,13.01c-1.33,0-2.42-1.12-2.42-2.51s1.08-2.52,2.42-2.52 c1.33,0,2.42,1.12,2.42,2.51S72.99,13,71.65,13.01L71.65,13.01z\"/%3E %3Cpath class=\"st1\" style=\"opacity:0.35; enable-background:new;\" d=\"M62.08,7.98c-1.32,0-2.39,1.11-2.41,2.48v0.06C59.68,11.9,60.75,13,62.08,13s2.42-1.12,2.42-2.51 S63.41,7.98,62.08,7.98z M62.08,11.76c-0.63,0-1.14-0.56-1.17-1.25v-0.04c0.01-0.69,0.54-1.25,1.17-1.25 c0.63,0,1.17,0.57,1.17,1.27C63.24,11.2,62.73,11.76,62.08,11.76z\"/%3E %3Cpath class=\"st1\" style=\"opacity:0.35; enable-background:new;\" d=\"M71.65,7.98c-1.33,0-2.42,1.12-2.42,2.51S70.32,13,71.65,13s2.42-1.12,2.42-2.51S72.99,7.98,71.65,7.98z M71.65,11.76c-0.64,0-1.17-0.57-1.17-1.27c0-0.7,0.53-1.26,1.17-1.26s1.17,0.57,1.17,1.27C72.82,11.21,72.29,11.76,71.65,11.76z\"/%3E %3Cpath class=\"st0\" style=\"opacity:0.9; fill: %23FFFFFF; enable-background: new;\" d=\"M45.74,6.53h-1.4c-0.13,0-0.23,0.11-0.23,0.23v0.73c-0.71-0.75-1.7-1.18-2.73-1.18 c-2.17,0-3.94,1.87-3.94,4.19s1.77,4.19,3.94,4.19c1.04,0,2.03-0.43,2.73-1.19v0.73c0,0.13,0.1,0.23,0.23,0.23h1.4 c0.13,0,0.23-0.11,0.23-0.23V6.74c0-0.12-0.09-0.22-0.22-0.22C45.75,6.53,45.75,6.53,45.74,6.53z M44.12,10.53 C44.11,11.9,43.03,13,41.71,13s-2.42-1.12-2.42-2.51s1.08-2.52,2.4-2.52c1.33,0,2.39,1.11,2.41,2.48L44.12,10.53z\"/%3E %3Cpath class=\"st1\" style=\"opacity:0.35; enable-background:new;\" d=\"M41.71,7.98c-1.33,0-2.42,1.12-2.42,2.51S40.37,13,41.71,13s2.39-1.11,2.41-2.48v-0.06 C44.1,9.09,43.03,7.98,41.71,7.98z M40.55,10.49c0-0.7,0.52-1.27,1.17-1.27c0.64,0,1.14,0.56,1.17,1.25v0.04 c-0.01,0.68-0.53,1.24-1.17,1.24C41.08,11.75,40.55,11.19,40.55,10.49z\"/%3E %3Cpath class=\"st0\" style=\"opacity:0.9; fill: %23FFFFFF; enable-background: new;\" d=\"M52.41,6.32c-1.03,0-2.03,0.42-2.73,1.18V6.75c0-0.13-0.1-0.23-0.23-0.23h-1.4c-0.13,0-0.23,0.11-0.23,0.23 v10.72c0,0.13,0.1,0.23,0.23,0.23h1.4c0.13,0,0.23-0.1,0.23-0.23V13.5c0.71,0.75,1.7,1.18,2.74,1.18c2.17,0,3.94-1.87,3.94-4.19 S54.58,6.32,52.41,6.32z M52.08,13.01c-1.32,0-2.39-1.11-2.42-2.48v-0.07c0.02-1.38,1.09-2.49,2.4-2.49c1.32,0,2.41,1.12,2.41,2.51 S53.4,13,52.08,13.01L52.08,13.01z\"/%3E %3Cpath class=\"st1\" style=\"opacity:0.35; enable-background:new;\" d=\"M52.08,7.98c-1.32,0-2.39,1.11-2.42,2.48v0.06c0.03,1.38,1.1,2.48,2.42,2.48s2.41-1.12,2.41-2.51 S53.4,7.98,52.08,7.98z M52.08,11.76c-0.63,0-1.14-0.56-1.17-1.25v-0.04c0.01-0.69,0.54-1.25,1.17-1.25c0.63,0,1.17,0.58,1.17,1.27 S52.72,11.76,52.08,11.76z\"/%3E %3Cpath class=\"st0\" style=\"opacity:0.9; fill: %23FFFFFF; enable-background: new;\" d=\"M36.08,14.24c0,0.13-0.1,0.23-0.23,0.23h-1.41c-0.13,0-0.23-0.11-0.23-0.23V9.68c0-0.98-0.74-1.71-1.62-1.71 c-0.8,0-1.46,0.7-1.59,1.62l0.01,4.66c0,0.13-0.11,0.23-0.23,0.23h-1.41c-0.13,0-0.23-0.11-0.23-0.23V9.68 c0-0.98-0.74-1.71-1.62-1.71c-0.85,0-1.54,0.79-1.6,1.8v4.48c0,0.13-0.1,0.23-0.23,0.23h-1.4c-0.13,0-0.23-0.11-0.23-0.23V6.74 c0.01-0.13,0.1-0.22,0.23-0.22h1.4c0.13,0,0.22,0.11,0.23,0.22V7.4c0.5-0.68,1.3-1.09,2.16-1.1h0.03c1.09,0,2.09,0.6,2.6,1.55 c0.45-0.95,1.4-1.55,2.44-1.56c1.62,0,2.93,1.25,2.9,2.78L36.08,14.24z\"/%3E %3Cpath class=\"st1\" style=\"opacity:0.35; enable-background:new;\" d=\"M84.34,13.59l-0.07-0.13l-1.96-2.99l1.94-2.95c0.44-0.67,0.26-1.56-0.41-2.02c-0.02,0-0.03,0-0.04-0.01 c-0.23-0.15-0.5-0.22-0.78-0.22h-1.61c-0.56,0-1.08,0.29-1.37,0.78L79.72,6.6l-0.34-0.56C79.09,5.56,78.57,5.27,78,5.27h-1.6 c-0.6,0-1.13,0.37-1.35,0.92c-2.19-1.66-5.28-1.47-7.26,0.45c-0.35,0.34-0.65,0.72-0.89,1.14c-0.9-1.62-2.58-2.72-4.5-2.72 c-0.5,0-1.01,0.07-1.48,0.23V3.51c0-0.82-0.66-1.48-1.47-1.48h-1.4c-0.81,0-1.47,0.66-1.47,1.47v3.75 c-0.95-1.36-2.5-2.18-4.17-2.19c-0.74,0-1.46,0.16-2.12,0.47c-0.24-0.17-0.54-0.26-0.84-0.26h-1.4c-0.45,0-0.87,0.21-1.15,0.56 c-0.02-0.03-0.04-0.05-0.07-0.08c-0.28-0.3-0.68-0.47-1.09-0.47h-1.39c-0.3,0-0.6,0.09-0.84,0.26c-0.67-0.3-1.39-0.46-2.12-0.46 c-1.83,0-3.43,1-4.37,2.5c-0.2-0.46-0.48-0.89-0.83-1.25c-0.8-0.81-1.89-1.25-3.02-1.25h-0.01c-0.89,0.01-1.75,0.33-2.46,0.88 c-0.74-0.57-1.64-0.88-2.57-0.88H28.1c-0.29,0-0.58,0.03-0.86,0.11c-0.28,0.06-0.56,0.16-0.82,0.28c-0.21-0.12-0.45-0.18-0.7-0.18 h-1.4c-0.82,0-1.47,0.66-1.47,1.47v7.5c0,0.82,0.66,1.47,1.47,1.47h1.4c0.82,0,1.48-0.66,1.48-1.48l0,0V9.79 c0.03-0.36,0.23-0.59,0.36-0.59c0.18,0,0.38,0.18,0.38,0.47v4.57c0,0.82,0.66,1.47,1.47,1.47h1.41c0.82,0,1.47-0.66,1.47-1.47 l-0.01-4.57c0.06-0.32,0.25-0.47,0.35-0.47c0.18,0,0.38,0.18,0.38,0.47v4.57c0,0.82,0.66,1.47,1.47,1.47h1.41 c0.82,0,1.47-0.66,1.47-1.47v-0.38c0.96,1.29,2.46,2.06,4.06,2.06c0.74,0,1.46-0.16,2.12-0.47c0.24,0.17,0.54,0.26,0.84,0.26h1.39 c0.3,0,0.6-0.09,0.84-0.26v2.01c0,0.82,0.66,1.47,1.47,1.47h1.4c0.82,0,1.47-0.66,1.47-1.47v-1.77c0.48,0.15,0.99,0.23,1.49,0.22 c1.7,0,3.22-0.87,4.17-2.2v0.52c0,0.82,0.66,1.47,1.47,1.47h1.4c0.3,0,0.6-0.09,0.84-0.26c0.66,0.31,1.39,0.47,2.12,0.47 c1.92,0,3.6-1.1,4.49-2.73c1.54,2.65,4.95,3.53,7.58,1.98c0.18-0.11,0.36-0.22,0.53-0.36c0.22,0.55,0.76,0.91,1.35,0.9H78 c0.56,0,1.08-0.29,1.37-0.78l0.37-0.61l0.37,0.61c0.29,0.48,0.81,0.78,1.38,0.78h1.6c0.81,0,1.46-0.66,1.45-1.46 C84.49,14.02,84.44,13.8,84.34,13.59L84.34,13.59z M35.86,14.47h-1.41c-0.13,0-0.23-0.11-0.23-0.23V9.68 c0-0.98-0.74-1.71-1.62-1.71c-0.8,0-1.46,0.7-1.59,1.62l0.01,4.66c0,0.13-0.1,0.23-0.23,0.23h-1.41c-0.13,0-0.23-0.11-0.23-0.23 V9.68c0-0.98-0.74-1.71-1.62-1.71c-0.85,0-1.54,0.79-1.6,1.8v4.48c0,0.13-0.1,0.23-0.23,0.23h-1.4c-0.13,0-0.23-0.11-0.23-0.23 V6.74c0.01-0.13,0.11-0.22,0.23-0.22h1.4c0.13,0,0.22,0.11,0.23,0.22V7.4c0.5-0.68,1.3-1.09,2.16-1.1h0.03 c1.09,0,2.09,0.6,2.6,1.55c0.45-0.95,1.4-1.55,2.44-1.56c1.62,0,2.93,1.25,2.9,2.78l0.01,5.16C36.09,14.36,35.98,14.46,35.86,14.47 L35.86,14.47z M45.97,14.24c0,0.13-0.1,0.23-0.23,0.23h-1.4c-0.13,0-0.23-0.11-0.23-0.23V13.5c-0.7,0.76-1.69,1.18-2.72,1.18 c-2.17,0-3.94-1.87-3.94-4.19s1.77-4.19,3.94-4.19c1.03,0,2.02,0.43,2.73,1.18V6.74c0-0.13,0.1-0.23,0.23-0.23h1.4 c0.12-0.01,0.22,0.08,0.23,0.21c0,0.01,0,0.01,0,0.02v7.51h-0.01V14.24z M52.41,14.67c-1.03,0-2.02-0.43-2.73-1.18v3.97 c0,0.13-0.1,0.23-0.23,0.23h-1.4c-0.13,0-0.23-0.1-0.23-0.23V6.75c0-0.13,0.1-0.22,0.23-0.22h1.4c0.13,0,0.23,0.11,0.23,0.23v0.73 c0.71-0.76,1.7-1.18,2.73-1.18c2.17,0,3.94,1.86,3.94,4.18S54.58,14.67,52.41,14.67z M66.24,11.39c-0.39,1.87-1.96,3.29-3.84,3.29 c-1.03,0-2.02-0.43-2.73-1.18v0.73c0,0.13-0.1,0.23-0.23,0.23h-1.4c-0.13,0-0.23-0.11-0.23-0.23V3.51c0-0.13,0.1-0.23,0.23-0.23 h1.4c0.13,0,0.23,0.11,0.23,0.23v3.97c0.71-0.75,1.7-1.18,2.73-1.17c1.88,0,3.45,1.4,3.84,3.28C66.37,10.19,66.37,10.8,66.24,11.39 L66.24,11.39L66.24,11.39z M71.67,14.68c-2,0.01-3.73-1.35-4.17-3.3c-0.13-0.59-0.13-1.19,0-1.77c0.44-1.94,2.17-3.31,4.17-3.3 c2.36,0,4.26,1.87,4.26,4.19S74.03,14.68,71.67,14.68L71.67,14.68z M83.04,14.47h-1.61c-0.13,0-0.24-0.06-0.3-0.17l-1.44-2.39 l-1.44,2.39c-0.06,0.11-0.18,0.17-0.3,0.17h-1.61c-0.04,0-0.08-0.01-0.12-0.03c-0.09-0.06-0.13-0.19-0.06-0.28l0,0l2.43-3.68 L76.2,6.84c-0.02-0.03-0.03-0.07-0.03-0.12c0-0.12,0.09-0.21,0.21-0.21h1.61c0.13,0,0.24,0.06,0.3,0.17l1.41,2.36l1.41-2.36 c0.06-0.11,0.18-0.17,0.3-0.17h1.61c0.04,0,0.08,0.01,0.12,0.03c0.09,0.06,0.13,0.19,0.06,0.28l0,0l-2.38,3.64l2.43,3.67 c0.02,0.03,0.03,0.07,0.03,0.12C83.25,14.38,83.16,14.47,83.04,14.47L83.04,14.47L83.04,14.47z\"/%3E %3Cpath class=\"st0\" style=\"opacity:0.9; fill: %23FFFFFF; enable-background: new;\" d=\"M10.5,1.24c-5.11,0-9.25,4.15-9.25,9.25s4.15,9.25,9.25,9.25s9.25-4.15,9.25-9.25 C19.75,5.38,15.61,1.24,10.5,1.24z M14.89,12.77c-1.93,1.93-4.78,2.31-6.7,2.31c-0.7,0-1.41-0.05-2.1-0.16c0,0-1.02-5.64,2.14-8.81 c0.83-0.83,1.95-1.28,3.13-1.28c1.27,0,2.49,0.51,3.39,1.42C16.59,8.09,16.64,11,14.89,12.77z\"/%3E %3Cpath class=\"st1\" style=\"opacity:0.35; enable-background:new;\" d=\"M10.5-0.01C4.7-0.01,0,4.7,0,10.49s4.7,10.5,10.5,10.5S21,16.29,21,10.49C20.99,4.7,16.3-0.01,10.5-0.01z M10.5,19.74c-5.11,0-9.25-4.15-9.25-9.25s4.14-9.26,9.25-9.26s9.25,4.15,9.25,9.25C19.75,15.61,15.61,19.74,10.5,19.74z\"/%3E %3Cpath class=\"st1\" style=\"opacity:0.35; enable-background:new;\" d=\"M14.74,6.25C12.9,4.41,9.98,4.35,8.23,6.1c-3.16,3.17-2.14,8.81-2.14,8.81s5.64,1.02,8.81-2.14 C16.64,11,16.59,8.09,14.74,6.25z M12.47,10.34l-0.91,1.87l-0.9-1.87L8.8,9.43l1.86-0.9l0.9-1.87l0.91,1.87l1.86,0.9L12.47,10.34z\"/%3E %3Cpolygon class=\"st0\" style=\"opacity:0.9; fill: %23FFFFFF; enable-background: new;\" points=\"14.33,9.43 12.47,10.34 11.56,12.21 10.66,10.34 8.8,9.43 10.66,8.53 11.56,6.66 12.47,8.53 \"/%3E%3C/g%3E%3C/svg%3E\\');'\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\n/**\n * Convert plotly.js 'textposition' to mapbox-gl 'anchor' and 'offset'\n * (with the help of the icon size).\n *\n * @param {string} textpostion : plotly.js textposition value\n * @param {number} iconSize : plotly.js icon size (e.g. marker.size for traces)\n *\n * @return {object}\n * - anchor\n * - offset\n */\nmodule.exports = function convertTextOpts(textposition, iconSize) {\n var parts = textposition.split(' ');\n var vPos = parts[0];\n var hPos = parts[1];\n\n // ballpack values\n var factor = Lib.isArrayOrTypedArray(iconSize) ? Lib.mean(iconSize) : iconSize;\n var xInc = 0.5 + (factor / 100);\n var yInc = 1.5 + (factor / 100);\n\n var anchorVals = ['', ''];\n var offset = [0, 0];\n\n switch(vPos) {\n case 'top':\n anchorVals[0] = 'top';\n offset[1] = -yInc;\n break;\n case 'bottom':\n anchorVals[0] = 'bottom';\n offset[1] = yInc;\n break;\n }\n\n switch(hPos) {\n case 'left':\n anchorVals[1] = 'right';\n offset[0] = -xInc;\n break;\n case 'right':\n anchorVals[1] = 'left';\n offset[0] = xInc;\n break;\n }\n\n // Mapbox text-anchor must be one of:\n // center, left, right, top, bottom,\n // top-left, top-right, bottom-left, bottom-right\n\n var anchor;\n if(anchorVals[0] && anchorVals[1]) anchor = anchorVals.join('-');\n else if(anchorVals[0]) anchor = anchorVals[0];\n else if(anchorVals[1]) anchor = anchorVals[1];\n else anchor = 'center';\n\n return { anchor: anchor, offset: offset };\n};\n","'use strict';\n\nvar mapboxgl = require('@plotly/mapbox-gl/dist/mapbox-gl-unminified');\n\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar strScale = Lib.strScale;\nvar getSubplotCalcData = require('../../plots/get_data').getSubplotCalcData;\nvar xmlnsNamespaces = require('../../constants/xmlns_namespaces');\nvar d3 = require('@plotly/d3');\nvar Drawing = require('../../components/drawing');\nvar svgTextUtils = require('../../lib/svg_text_utils');\n\nvar Mapbox = require('./mapbox');\n\nvar MAPBOX = 'mapbox';\n\nvar constants = exports.constants = require('./constants');\n\nexports.name = MAPBOX;\n\nexports.attr = 'subplot';\n\nexports.idRoot = MAPBOX;\n\nexports.idRegex = exports.attrRegex = Lib.counterRegex(MAPBOX);\n\nvar deprecationWarning = [\n 'mapbox subplots and traces are deprecated!',\n 'Please consider switching to `map` subplots and traces.',\n 'Learn more at: https://plotly.com/javascript/maplibre-migration/'\n].join(' ');\n\nexports.attributes = {\n subplot: {\n valType: 'subplotid',\n dflt: 'mapbox',\n editType: 'calc',\n description: [\n deprecationWarning,\n 'Sets a reference between this trace\\'s data coordinates and',\n 'a mapbox subplot.',\n 'If *mapbox* (the default value), the data refer to `layout.mapbox`.',\n 'If *mapbox2*, the data refer to `layout.mapbox2`, and so on.'\n ].join(' ')\n }\n};\n\nexports.layoutAttributes = require('./layout_attributes');\n\nexports.supplyLayoutDefaults = require('./layout_defaults');\n\nvar firstPlot = true;\n\nexports.plot = function plot(gd) {\n if(firstPlot) {\n firstPlot = false;\n Lib.warn(deprecationWarning);\n }\n\n var fullLayout = gd._fullLayout;\n var calcData = gd.calcdata;\n var mapboxIds = fullLayout._subplots[MAPBOX];\n\n if(mapboxgl.version !== constants.requiredVersion) {\n throw new Error(constants.wrongVersionErrorMsg);\n }\n\n var accessToken = findAccessToken(gd, mapboxIds);\n mapboxgl.accessToken = accessToken;\n\n for(var i = 0; i < mapboxIds.length; i++) {\n var id = mapboxIds[i];\n var subplotCalcData = getSubplotCalcData(calcData, MAPBOX, id);\n var opts = fullLayout[id];\n var mapbox = opts._subplot;\n\n if(!mapbox) {\n mapbox = new Mapbox(gd, id);\n fullLayout[id]._subplot = mapbox;\n }\n\n if(!mapbox.viewInitial) {\n mapbox.viewInitial = {\n center: Lib.extendFlat({}, opts.center),\n zoom: opts.zoom,\n bearing: opts.bearing,\n pitch: opts.pitch\n };\n }\n\n mapbox.plot(subplotCalcData, fullLayout, gd._promises);\n }\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var oldMapboxKeys = oldFullLayout._subplots[MAPBOX] || [];\n\n for(var i = 0; i < oldMapboxKeys.length; i++) {\n var oldMapboxKey = oldMapboxKeys[i];\n\n if(!newFullLayout[oldMapboxKey] && !!oldFullLayout[oldMapboxKey]._subplot) {\n oldFullLayout[oldMapboxKey]._subplot.destroy();\n }\n }\n};\n\nexports.toSVG = function(gd) {\n var fullLayout = gd._fullLayout;\n var subplotIds = fullLayout._subplots[MAPBOX];\n var size = fullLayout._size;\n\n for(var i = 0; i < subplotIds.length; i++) {\n var opts = fullLayout[subplotIds[i]];\n var domain = opts.domain;\n var mapbox = opts._subplot;\n\n var imageData = mapbox.toImage('png');\n var image = fullLayout._glimages.append('svg:image');\n\n image.attr({\n xmlns: xmlnsNamespaces.svg,\n 'xlink:href': imageData,\n x: size.l + size.w * domain.x[0],\n y: size.t + size.h * (1 - domain.y[1]),\n width: size.w * (domain.x[1] - domain.x[0]),\n height: size.h * (domain.y[1] - domain.y[0]),\n preserveAspectRatio: 'none'\n });\n\n var subplotDiv = d3.select(opts._subplot.div);\n\n // Append logo if visible\n var hidden = subplotDiv.select('.mapboxgl-ctrl-logo').node().offsetParent === null;\n if(!hidden) {\n var logo = fullLayout._glimages.append('g');\n logo.attr('transform', strTranslate(size.l + size.w * domain.x[0] + 10, size.t + size.h * (1 - domain.y[0]) - 31));\n logo.append('path')\n .attr('d', constants.mapboxLogo.path0)\n .style({\n opacity: 0.9,\n fill: '#ffffff',\n 'enable-background': 'new'\n });\n\n logo.append('path')\n .attr('d', constants.mapboxLogo.path1)\n .style('opacity', 0.35)\n .style('enable-background', 'new');\n\n logo.append('path')\n .attr('d', constants.mapboxLogo.path2)\n .style('opacity', 0.35)\n .style('enable-background', 'new');\n\n logo.append('polygon')\n .attr('points', constants.mapboxLogo.polygon)\n .style({\n opacity: 0.9,\n fill: '#ffffff',\n 'enable-background': 'new'\n });\n }\n\n // Add attributions\n var attributions = subplotDiv\n .select('.mapboxgl-ctrl-attrib').text()\n .replace('Improve this map', '');\n\n var attributionGroup = fullLayout._glimages.append('g');\n\n var attributionText = attributionGroup.append('text');\n attributionText\n .text(attributions)\n .classed('static-attribution', true)\n .attr({\n 'font-size': 12,\n 'font-family': 'Arial',\n color: 'rgba(0, 0, 0, 0.75)',\n 'text-anchor': 'end',\n 'data-unformatted': attributions\n });\n\n var bBox = Drawing.bBox(attributionText.node());\n\n // Break into multiple lines twice larger than domain\n var maxWidth = size.w * (domain.x[1] - domain.x[0]);\n if((bBox.width > maxWidth / 2)) {\n var multilineAttributions = attributions.split('|').join('
');\n attributionText\n .text(multilineAttributions)\n .attr('data-unformatted', multilineAttributions)\n .call(svgTextUtils.convertToTspans, gd);\n\n bBox = Drawing.bBox(attributionText.node());\n }\n attributionText.attr('transform', strTranslate(-3, -bBox.height + 8));\n\n // Draw white rectangle behind text\n attributionGroup\n .insert('rect', '.static-attribution')\n .attr({\n x: -bBox.width - 6,\n y: -bBox.height - 3,\n width: bBox.width + 6,\n height: bBox.height + 3,\n fill: 'rgba(255, 255, 255, 0.75)'\n });\n\n // Scale down if larger than domain\n var scaleRatio = 1;\n if((bBox.width + 6) > maxWidth) scaleRatio = maxWidth / (bBox.width + 6);\n\n var offset = [(size.l + size.w * domain.x[1]), (size.t + size.h * (1 - domain.y[0]))];\n attributionGroup.attr('transform', strTranslate(offset[0], offset[1]) + strScale(scaleRatio));\n }\n};\n\n// N.B. mapbox-gl only allows one accessToken to be set per page:\n// https://github.com/mapbox/mapbox-gl-js/issues/6331\nfunction findAccessToken(gd, mapboxIds) {\n var fullLayout = gd._fullLayout;\n var context = gd._context;\n\n // special case for Mapbox Atlas users\n if(context.mapboxAccessToken === '') return '';\n\n var tokensUseful = [];\n var tokensListed = [];\n var hasOneSetMapboxStyle = false;\n var wontWork = false;\n\n // Take the first token we find in a mapbox subplot.\n // These default to the context value but may be overridden.\n for(var i = 0; i < mapboxIds.length; i++) {\n var opts = fullLayout[mapboxIds[i]];\n var token = opts.accesstoken;\n\n if(isStyleRequireAccessToken(opts.style)) {\n if(token) {\n Lib.pushUnique(tokensUseful, token);\n } else {\n if(isStyleRequireAccessToken(opts._input.style)) {\n Lib.error('Uses Mapbox map style, but did not set an access token.');\n hasOneSetMapboxStyle = true;\n }\n wontWork = true;\n }\n }\n\n if(token) {\n Lib.pushUnique(tokensListed, token);\n }\n }\n\n if(wontWork) {\n var msg = hasOneSetMapboxStyle ?\n constants.noAccessTokenErrorMsg :\n constants.missingStyleErrorMsg;\n Lib.error(msg);\n throw new Error(msg);\n }\n\n if(tokensUseful.length) {\n if(tokensUseful.length > 1) {\n Lib.warn(constants.multipleTokensErrorMsg);\n }\n return tokensUseful[0];\n } else {\n if(tokensListed.length) {\n Lib.log([\n 'Listed mapbox access token(s)', tokensListed.join(','),\n 'but did not use a Mapbox map style, ignoring token(s).'\n ].join(' '));\n }\n return '';\n }\n}\n\nfunction isStyleRequireAccessToken(s) {\n return typeof s === 'string' && (\n constants.styleValuesMapbox.indexOf(s) !== -1 ||\n s.indexOf('mapbox://') === 0 ||\n s.indexOf('stamen') === 0\n );\n}\n\nexports.updateFx = function(gd) {\n var fullLayout = gd._fullLayout;\n var subplotIds = fullLayout._subplots[MAPBOX];\n\n for(var i = 0; i < subplotIds.length; i++) {\n var subplotObj = fullLayout[subplotIds[i]]._subplot;\n subplotObj.updateFx(fullLayout);\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar sanitizeHTML = require('../../lib/svg_text_utils').sanitizeHTML;\nvar convertTextOpts = require('./convert_text_opts');\nvar constants = require('./constants');\n\nfunction MapboxLayer(subplot, index) {\n this.subplot = subplot;\n\n this.uid = subplot.uid + '-' + index;\n this.index = index;\n\n this.idSource = 'source-' + this.uid;\n this.idLayer = constants.layoutLayerPrefix + this.uid;\n\n // some state variable to check if a remove/add step is needed\n this.sourceType = null;\n this.source = null;\n this.layerType = null;\n this.below = null;\n\n // is layer currently visible\n this.visible = false;\n}\n\nvar proto = MapboxLayer.prototype;\n\nproto.update = function update(opts) {\n if(!this.visible) {\n // IMPORTANT: must create source before layer to not cause errors\n this.updateSource(opts);\n this.updateLayer(opts);\n } else if(this.needsNewImage(opts)) {\n this.updateImage(opts);\n } else if(this.needsNewSource(opts)) {\n // IMPORTANT: must delete layer before source to not cause errors\n this.removeLayer();\n this.updateSource(opts);\n this.updateLayer(opts);\n } else if(this.needsNewLayer(opts)) {\n this.updateLayer(opts);\n } else {\n this.updateStyle(opts);\n }\n\n this.visible = isVisible(opts);\n};\n\nproto.needsNewImage = function(opts) {\n var map = this.subplot.map;\n return (\n map.getSource(this.idSource) &&\n this.sourceType === 'image' &&\n opts.sourcetype === 'image' &&\n (this.source !== opts.source ||\n JSON.stringify(this.coordinates) !==\n JSON.stringify(opts.coordinates))\n );\n};\n\nproto.needsNewSource = function(opts) {\n // for some reason changing layer to 'fill' or 'symbol'\n // w/o changing the source throws an exception in mapbox-gl 0.18 ;\n // stay safe and make new source on type changes\n return (\n this.sourceType !== opts.sourcetype ||\n JSON.stringify(this.source) !== JSON.stringify(opts.source) ||\n this.layerType !== opts.type\n );\n};\n\nproto.needsNewLayer = function(opts) {\n return (\n this.layerType !== opts.type ||\n this.below !== this.subplot.belowLookup['layout-' + this.index]\n );\n};\n\nproto.lookupBelow = function() {\n return this.subplot.belowLookup['layout-' + this.index];\n};\n\nproto.updateImage = function(opts) {\n var map = this.subplot.map;\n map.getSource(this.idSource).updateImage({\n url: opts.source, coordinates: opts.coordinates\n });\n\n // Since the `updateImage` control flow doesn't call updateLayer,\n // We need to take care of moving the image layer to match the location\n // where updateLayer would have placed it.\n var _below = this.findFollowingMapboxLayerId(this.lookupBelow());\n if(_below !== null) {\n this.subplot.map.moveLayer(this.idLayer, _below);\n }\n};\n\nproto.updateSource = function(opts) {\n var map = this.subplot.map;\n\n if(map.getSource(this.idSource)) map.removeSource(this.idSource);\n\n this.sourceType = opts.sourcetype;\n this.source = opts.source;\n\n if(!isVisible(opts)) return;\n\n var sourceOpts = convertSourceOpts(opts);\n\n map.addSource(this.idSource, sourceOpts);\n};\n\nproto.findFollowingMapboxLayerId = function(below) {\n if(below === 'traces') {\n var mapLayers = this.subplot.getMapLayers();\n\n // find id of first plotly trace layer\n for(var i = 0; i < mapLayers.length; i++) {\n var layerId = mapLayers[i].id;\n if(typeof layerId === 'string' &&\n layerId.indexOf(constants.traceLayerPrefix) === 0\n ) {\n below = layerId;\n break;\n }\n }\n }\n return below;\n};\n\nproto.updateLayer = function(opts) {\n var subplot = this.subplot;\n var convertedOpts = convertOpts(opts);\n var below = this.lookupBelow();\n var _below = this.findFollowingMapboxLayerId(below);\n\n this.removeLayer();\n\n if(isVisible(opts)) {\n subplot.addLayer({\n id: this.idLayer,\n source: this.idSource,\n 'source-layer': opts.sourcelayer || '',\n type: opts.type,\n minzoom: opts.minzoom,\n maxzoom: opts.maxzoom,\n layout: convertedOpts.layout,\n paint: convertedOpts.paint\n }, _below);\n }\n\n this.layerType = opts.type;\n this.below = below;\n};\n\nproto.updateStyle = function(opts) {\n if(isVisible(opts)) {\n var convertedOpts = convertOpts(opts);\n this.subplot.setOptions(this.idLayer, 'setLayoutProperty', convertedOpts.layout);\n this.subplot.setOptions(this.idLayer, 'setPaintProperty', convertedOpts.paint);\n }\n};\n\nproto.removeLayer = function() {\n var map = this.subplot.map;\n if(map.getLayer(this.idLayer)) {\n map.removeLayer(this.idLayer);\n }\n};\n\nproto.dispose = function() {\n var map = this.subplot.map;\n if(map.getLayer(this.idLayer)) map.removeLayer(this.idLayer);\n if(map.getSource(this.idSource)) map.removeSource(this.idSource);\n};\n\nfunction isVisible(opts) {\n if(!opts.visible) return false;\n\n var source = opts.source;\n\n if(Array.isArray(source) && source.length > 0) {\n for(var i = 0; i < source.length; i++) {\n if(typeof source[i] !== 'string' || source[i].length === 0) {\n return false;\n }\n }\n return true;\n }\n\n return Lib.isPlainObject(source) ||\n (typeof source === 'string' && source.length > 0);\n}\n\nfunction convertOpts(opts) {\n var layout = {};\n var paint = {};\n\n switch(opts.type) {\n case 'circle':\n Lib.extendFlat(paint, {\n 'circle-radius': opts.circle.radius,\n 'circle-color': opts.color,\n 'circle-opacity': opts.opacity\n });\n break;\n\n case 'line':\n Lib.extendFlat(paint, {\n 'line-width': opts.line.width,\n 'line-color': opts.color,\n 'line-opacity': opts.opacity,\n 'line-dasharray': opts.line.dash\n });\n break;\n\n case 'fill':\n Lib.extendFlat(paint, {\n 'fill-color': opts.color,\n 'fill-outline-color': opts.fill.outlinecolor,\n 'fill-opacity': opts.opacity\n\n // no way to pass specify outline width at the moment\n });\n break;\n\n case 'symbol':\n var symbol = opts.symbol;\n var textOpts = convertTextOpts(symbol.textposition, symbol.iconsize);\n\n Lib.extendFlat(layout, {\n 'icon-image': symbol.icon + '-15',\n 'icon-size': symbol.iconsize / 10,\n\n 'text-field': symbol.text,\n 'text-size': symbol.textfont.size,\n 'text-anchor': textOpts.anchor,\n 'text-offset': textOpts.offset,\n 'symbol-placement': symbol.placement,\n\n // TODO font family\n // 'text-font': symbol.textfont.family.split(', '),\n });\n\n Lib.extendFlat(paint, {\n 'icon-color': opts.color,\n 'text-color': symbol.textfont.color,\n 'text-opacity': opts.opacity\n });\n break;\n case 'raster':\n Lib.extendFlat(paint, {\n 'raster-fade-duration': 0,\n 'raster-opacity': opts.opacity\n });\n break;\n }\n\n return {\n layout: layout,\n paint: paint\n };\n}\n\nfunction convertSourceOpts(opts) {\n var sourceType = opts.sourcetype;\n var source = opts.source;\n var sourceOpts = {type: sourceType};\n var field;\n\n if(sourceType === 'geojson') {\n field = 'data';\n } else if(sourceType === 'vector') {\n field = typeof source === 'string' ? 'url' : 'tiles';\n } else if(sourceType === 'raster') {\n field = 'tiles';\n sourceOpts.tileSize = 256;\n } else if(sourceType === 'image') {\n field = 'url';\n sourceOpts.coordinates = opts.coordinates;\n }\n\n sourceOpts[field] = source;\n\n if(opts.sourceattribution) {\n sourceOpts.attribution = sanitizeHTML(opts.sourceattribution);\n }\n\n return sourceOpts;\n}\n\nmodule.exports = function createMapboxLayer(subplot, index, opts) {\n var mapboxLayer = new MapboxLayer(subplot, index);\n\n mapboxLayer.update(opts);\n\n return mapboxLayer;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar defaultLine = require('../../components/color').defaultLine;\nvar domainAttrs = require('../domain').attributes;\nvar fontAttrs = require('../font_attributes');\nvar textposition = require('../../traces/scatter/attributes').textposition;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\n\nvar constants = require('./constants');\n\nvar fontAttr = fontAttrs({\n noFontVariant: true,\n noFontShadow: true,\n noFontLineposition: true,\n noFontTextcase: true,\n description: [\n 'Sets the icon text font (color=mapbox.layer.paint.text-color, size=mapbox.layer.layout.text-size).',\n 'Has an effect only when `type` is set to *symbol*.'\n ].join(' ')\n});\nfontAttr.family.dflt = 'Open Sans Regular, Arial Unicode MS Regular';\n\nvar attrs = module.exports = overrideAll({\n _arrayAttrRegexps: [Lib.counterRegex('mapbox', '.layers', true)],\n\n domain: domainAttrs({name: 'mapbox'}),\n\n accesstoken: {\n valType: 'string',\n noBlank: true,\n strict: true,\n description: [\n 'Sets the mapbox access token to be used for this mapbox map.',\n 'Alternatively, the mapbox access token can be set in the',\n 'configuration options under `mapboxAccessToken`.',\n 'Note that accessToken are only required when `style`',\n '(e.g with values :', constants.styleValuesMapbox.join(', '), ')',\n 'and/or a layout layer references the Mapbox server.'\n ].join(' ')\n },\n style: {\n valType: 'any',\n values: constants.styleValuesMapbox.concat(constants.styleValuesNonMapbox),\n dflt: constants.styleValueDflt,\n description: [\n 'Defines the map layers that are rendered by default below the trace layers defined in `data`,',\n 'which are themselves by default rendered below the layers defined in `layout.mapbox.layers`.',\n '',\n 'These layers can be defined either explicitly as a Mapbox Style object which can contain multiple',\n 'layer definitions that load data from any public or private Tile Map Service (TMS or XYZ) or Web Map Service (WMS)',\n 'or implicitly by using one of the built-in style objects which use WMSes which do not require any',\n 'access tokens, or by using a default Mapbox style or custom Mapbox style URL, both of',\n 'which require a Mapbox access token',\n '',\n 'Note that Mapbox access token can be set in the `accesstoken` attribute',\n 'or in the `mapboxAccessToken` config option.',\n '',\n 'Mapbox Style objects are of the form described in the Mapbox GL JS documentation available at',\n 'https://docs.mapbox.com/mapbox-gl-js/style-spec',\n '',\n 'The built-in plotly.js styles objects are:', constants.styleValuesNonMapbox.join(', '),\n '',\n 'The built-in Mapbox styles are:', constants.styleValuesMapbox.join(', '),\n '',\n 'Mapbox style URLs are of the form: mapbox://mapbox.mapbox--'\n ].join(' ')\n },\n\n center: {\n lon: {\n valType: 'number',\n dflt: 0,\n description: 'Sets the longitude of the center of the map (in degrees East).'\n },\n lat: {\n valType: 'number',\n dflt: 0,\n description: 'Sets the latitude of the center of the map (in degrees North).'\n }\n },\n zoom: {\n valType: 'number',\n dflt: 1,\n description: 'Sets the zoom level of the map (mapbox.zoom).'\n },\n bearing: {\n valType: 'number',\n dflt: 0,\n description: 'Sets the bearing angle of the map in degrees counter-clockwise from North (mapbox.bearing).'\n },\n pitch: {\n valType: 'number',\n dflt: 0,\n description: [\n 'Sets the pitch angle of the map',\n '(in degrees, where *0* means perpendicular to the surface of the map) (mapbox.pitch).'\n ].join(' ')\n },\n\n bounds: {\n west: {\n valType: 'number',\n description: [\n 'Sets the minimum longitude of the map (in degrees East)',\n 'if `east`, `south` and `north` are declared.'\n ].join(' ')\n },\n east: {\n valType: 'number',\n description: [\n 'Sets the maximum longitude of the map (in degrees East)',\n 'if `west`, `south` and `north` are declared.'\n ].join(' ')\n },\n south: {\n valType: 'number',\n description: [\n 'Sets the minimum latitude of the map (in degrees North)',\n 'if `east`, `west` and `north` are declared.'\n ].join(' ')\n },\n north: {\n valType: 'number',\n description: [\n 'Sets the maximum latitude of the map (in degrees North)',\n 'if `east`, `west` and `south` are declared.'\n ].join(' ')\n }\n },\n\n layers: templatedArray('layer', {\n visible: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Determines whether this layer is displayed'\n ].join(' ')\n },\n sourcetype: {\n valType: 'enumerated',\n values: ['geojson', 'vector', 'raster', 'image'],\n dflt: 'geojson',\n description: [\n 'Sets the source type for this layer,',\n 'that is the type of the layer data.'\n ].join(' ')\n },\n\n source: {\n valType: 'any',\n description: [\n 'Sets the source data for this layer (mapbox.layer.source).',\n 'When `sourcetype` is set to *geojson*, `source` can be a URL to a GeoJSON',\n 'or a GeoJSON object.',\n 'When `sourcetype` is set to *vector* or *raster*, `source` can be a URL or',\n 'an array of tile URLs.',\n 'When `sourcetype` is set to *image*, `source` can be a URL to an image.'\n ].join(' ')\n },\n\n sourcelayer: {\n valType: 'string',\n dflt: '',\n description: [\n 'Specifies the layer to use from a vector tile source (mapbox.layer.source-layer).',\n 'Required for *vector* source type that supports multiple layers.'\n ].join(' ')\n },\n\n sourceattribution: {\n valType: 'string',\n description: [\n 'Sets the attribution for this source.'\n ].join(' ')\n },\n\n type: {\n valType: 'enumerated',\n values: ['circle', 'line', 'fill', 'symbol', 'raster'],\n dflt: 'circle',\n description: [\n 'Sets the layer type,',\n 'that is the how the layer data set in `source` will be rendered',\n 'With `sourcetype` set to *geojson*, the following values are allowed:',\n '*circle*, *line*, *fill* and *symbol*.',\n 'but note that *line* and *fill* are not compatible with Point',\n 'GeoJSON geometries.',\n 'With `sourcetype` set to *vector*, the following values are allowed:',\n ' *circle*, *line*, *fill* and *symbol*.',\n 'With `sourcetype` set to *raster* or `*image*`, only the *raster* value is allowed.'\n ].join(' ')\n },\n\n coordinates: {\n valType: 'any',\n description: [\n 'Sets the coordinates array contains [longitude, latitude] pairs',\n 'for the image corners listed in clockwise order:',\n 'top left, top right, bottom right, bottom left.',\n 'Only has an effect for *image* `sourcetype`.'\n ].join(' ')\n },\n\n // attributes shared between all types\n below: {\n valType: 'string',\n description: [\n 'Determines if the layer will be inserted',\n 'before the layer with the specified ID.',\n 'If omitted or set to \\'\\',',\n 'the layer will be inserted above every existing layer.'\n ].join(' ')\n },\n color: {\n valType: 'color',\n dflt: defaultLine,\n description: [\n 'Sets the primary layer color.',\n 'If `type` is *circle*, color corresponds to the circle color (mapbox.layer.paint.circle-color)',\n 'If `type` is *line*, color corresponds to the line color (mapbox.layer.paint.line-color)',\n 'If `type` is *fill*, color corresponds to the fill color (mapbox.layer.paint.fill-color)',\n 'If `type` is *symbol*, color corresponds to the icon color (mapbox.layer.paint.icon-color)'\n ].join(' ')\n },\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n description: [\n 'Sets the opacity of the layer.',\n 'If `type` is *circle*, opacity corresponds to the circle opacity (mapbox.layer.paint.circle-opacity)',\n 'If `type` is *line*, opacity corresponds to the line opacity (mapbox.layer.paint.line-opacity)',\n 'If `type` is *fill*, opacity corresponds to the fill opacity (mapbox.layer.paint.fill-opacity)',\n 'If `type` is *symbol*, opacity corresponds to the icon/text opacity (mapbox.layer.paint.text-opacity)'\n ].join(' ')\n },\n minzoom: {\n valType: 'number',\n min: 0,\n max: 24,\n dflt: 0,\n description: [\n 'Sets the minimum zoom level (mapbox.layer.minzoom).',\n 'At zoom levels less than the minzoom, the layer will be hidden.',\n ].join(' ')\n },\n maxzoom: {\n valType: 'number',\n min: 0,\n max: 24,\n dflt: 24,\n description: [\n 'Sets the maximum zoom level (mapbox.layer.maxzoom).',\n 'At zoom levels equal to or greater than the maxzoom, the layer will be hidden.'\n ].join(' ')\n },\n\n // type-specific style attributes\n circle: {\n radius: {\n valType: 'number',\n dflt: 15,\n description: [\n 'Sets the circle radius (mapbox.layer.paint.circle-radius).',\n 'Has an effect only when `type` is set to *circle*.'\n ].join(' ')\n }\n },\n\n line: {\n width: {\n valType: 'number',\n dflt: 2,\n description: [\n 'Sets the line width (mapbox.layer.paint.line-width).',\n 'Has an effect only when `type` is set to *line*.'\n ].join(' ')\n },\n dash: {\n valType: 'data_array',\n description: [\n 'Sets the length of dashes and gaps (mapbox.layer.paint.line-dasharray).',\n 'Has an effect only when `type` is set to *line*.'\n ].join(' ')\n }\n },\n\n fill: {\n outlinecolor: {\n valType: 'color',\n dflt: defaultLine,\n description: [\n 'Sets the fill outline color (mapbox.layer.paint.fill-outline-color).',\n 'Has an effect only when `type` is set to *fill*.'\n ].join(' ')\n }\n },\n\n symbol: {\n icon: {\n valType: 'string',\n dflt: 'marker',\n description: [\n 'Sets the symbol icon image (mapbox.layer.layout.icon-image).',\n 'Full list: https://www.mapbox.com/maki-icons/'\n ].join(' ')\n },\n iconsize: {\n valType: 'number',\n dflt: 10,\n description: [\n 'Sets the symbol icon size (mapbox.layer.layout.icon-size).',\n 'Has an effect only when `type` is set to *symbol*.'\n ].join(' ')\n },\n text: {\n valType: 'string',\n dflt: '',\n description: [\n 'Sets the symbol text (mapbox.layer.layout.text-field).'\n ].join(' ')\n },\n placement: {\n valType: 'enumerated',\n values: ['point', 'line', 'line-center'],\n dflt: 'point',\n description: [\n 'Sets the symbol and/or text placement (mapbox.layer.layout.symbol-placement).',\n 'If `placement` is *point*, the label is placed where the geometry is located',\n 'If `placement` is *line*, the label is placed along the line of the geometry',\n 'If `placement` is *line-center*, the label is placed on the center of the geometry',\n ].join(' ')\n },\n textfont: fontAttr,\n textposition: Lib.extendFlat({}, textposition, { arrayOk: false })\n }\n })\n}, 'plot', 'from-root');\n\n// set uirevision outside of overrideAll so it can be `editType: 'none'`\nattrs.uirevision = {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in the view:',\n '`center`, `zoom`, `bearing`, `pitch`. Defaults to `layout.uirevision`.'\n ].join(' ')\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar handleSubplotDefaults = require('../subplot_defaults');\nvar handleArrayContainerDefaults = require('../array_container_defaults');\nvar layoutAttributes = require('./layout_attributes');\n\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut, fullData) {\n handleSubplotDefaults(layoutIn, layoutOut, fullData, {\n type: 'mapbox',\n attributes: layoutAttributes,\n handleDefaults: handleDefaults,\n partition: 'y',\n accessToken: layoutOut._mapboxAccessToken\n });\n};\n\nfunction handleDefaults(containerIn, containerOut, coerce, opts) {\n coerce('accesstoken', opts.accessToken);\n coerce('style');\n coerce('center.lon');\n coerce('center.lat');\n coerce('zoom');\n coerce('bearing');\n coerce('pitch');\n\n var west = coerce('bounds.west');\n var east = coerce('bounds.east');\n var south = coerce('bounds.south');\n var north = coerce('bounds.north');\n if(\n west === undefined ||\n east === undefined ||\n south === undefined ||\n north === undefined\n ) {\n delete containerOut.bounds;\n }\n\n handleArrayContainerDefaults(containerIn, containerOut, {\n name: 'layers',\n handleItemDefaults: handleLayerDefaults\n });\n\n // copy ref to input container to update 'center' and 'zoom' on map move\n containerOut._input = containerIn;\n}\n\nfunction handleLayerDefaults(layerIn, layerOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(layerIn, layerOut, layoutAttributes.layers, attr, dflt);\n }\n\n var visible = coerce('visible');\n if(visible) {\n var sourceType = coerce('sourcetype');\n var mustBeRasterLayer = sourceType === 'raster' || sourceType === 'image';\n\n coerce('source');\n coerce('sourceattribution');\n\n if(sourceType === 'vector') {\n coerce('sourcelayer');\n }\n\n if(sourceType === 'image') {\n coerce('coordinates');\n }\n\n var typeDflt;\n if(mustBeRasterLayer) typeDflt = 'raster';\n\n var type = coerce('type', typeDflt);\n\n if(mustBeRasterLayer && type !== 'raster') {\n type = layerOut.type = 'raster';\n Lib.log('Source types *raster* and *image* must drawn *raster* layer type.');\n }\n\n coerce('below');\n coerce('color');\n coerce('opacity');\n coerce('minzoom');\n coerce('maxzoom');\n\n if(type === 'circle') {\n coerce('circle.radius');\n }\n\n if(type === 'line') {\n coerce('line.width');\n coerce('line.dash');\n }\n\n if(type === 'fill') {\n coerce('fill.outlinecolor');\n }\n\n if(type === 'symbol') {\n coerce('symbol.icon');\n coerce('symbol.iconsize');\n\n coerce('symbol.text');\n Lib.coerceFont(coerce, 'symbol.textfont', undefined, {\n noFontVariant: true,\n noFontShadow: true,\n noFontLineposition: true,\n noFontTextcase: true,\n });\n coerce('symbol.textposition');\n coerce('symbol.placement');\n }\n }\n}\n","'use strict';\n\nvar mapboxgl = require('@plotly/mapbox-gl/dist/mapbox-gl-unminified');\n\nvar Lib = require('../../lib');\nvar geoUtils = require('../../lib/geo_location_utils');\nvar Registry = require('../../registry');\nvar Axes = require('../cartesian/axes');\nvar dragElement = require('../../components/dragelement');\n\nvar Fx = require('../../components/fx');\nvar dragHelpers = require('../../components/dragelement/helpers');\nvar drawMode = dragHelpers.drawMode;\nvar selectMode = dragHelpers.selectMode;\n\nvar prepSelect = require('../../components/selections').prepSelect;\nvar clearOutline = require('../../components/selections').clearOutline;\nvar clearSelectionsCache = require('../../components/selections').clearSelectionsCache;\nvar selectOnClick = require('../../components/selections').selectOnClick;\n\nvar constants = require('./constants');\nvar createMapboxLayer = require('./layers');\n\nfunction Mapbox(gd, id) {\n this.id = id;\n this.gd = gd;\n\n var fullLayout = gd._fullLayout;\n var context = gd._context;\n\n this.container = fullLayout._glcontainer.node();\n this.isStatic = context.staticPlot;\n\n // unique id for this Mapbox instance\n this.uid = fullLayout._uid + '-' + this.id;\n\n // create framework on instantiation for a smoother first plot call\n this.div = null;\n this.xaxis = null;\n this.yaxis = null;\n this.createFramework(fullLayout);\n\n // state variables used to infer how and what to update\n this.map = null;\n this.accessToken = null;\n this.styleObj = null;\n this.traceHash = {};\n this.layerList = [];\n this.belowLookup = {};\n this.dragging = false;\n this.wheeling = false;\n}\n\nvar proto = Mapbox.prototype;\n\nproto.plot = function(calcData, fullLayout, promises) {\n var self = this;\n var opts = fullLayout[self.id];\n\n // remove map and create a new map if access token has change\n if(self.map && (opts.accesstoken !== self.accessToken)) {\n self.map.remove();\n self.map = null;\n self.styleObj = null;\n self.traceHash = {};\n self.layerList = [];\n }\n\n var promise;\n\n if(!self.map) {\n promise = new Promise(function(resolve, reject) {\n self.createMap(calcData, fullLayout, resolve, reject);\n });\n } else {\n promise = new Promise(function(resolve, reject) {\n self.updateMap(calcData, fullLayout, resolve, reject);\n });\n }\n\n promises.push(promise);\n};\n\nproto.createMap = function(calcData, fullLayout, resolve, reject) {\n var self = this;\n var opts = fullLayout[self.id];\n\n // store style id and URL or object\n var styleObj = self.styleObj = getStyleObj(opts.style, fullLayout);\n\n // store access token associated with this map\n self.accessToken = opts.accesstoken;\n\n var bounds = opts.bounds;\n var maxBounds = bounds ? [[bounds.west, bounds.south], [bounds.east, bounds.north]] : null;\n\n // create the map!\n var map = self.map = new mapboxgl.Map({\n container: self.div,\n\n style: styleObj.style,\n center: convertCenter(opts.center),\n zoom: opts.zoom,\n bearing: opts.bearing,\n pitch: opts.pitch,\n maxBounds: maxBounds,\n\n interactive: !self.isStatic,\n preserveDrawingBuffer: self.isStatic,\n\n doubleClickZoom: false,\n boxZoom: false,\n\n attributionControl: false\n })\n .addControl(new mapboxgl.AttributionControl({\n compact: true\n }));\n\n\n // make sure canvas does not inherit left and top css\n map._canvas.style.left = '0px';\n map._canvas.style.top = '0px';\n\n self.rejectOnError(reject);\n\n if(!self.isStatic) {\n self.initFx(calcData, fullLayout);\n }\n\n var promises = [];\n\n promises.push(new Promise(function(resolve) {\n map.once('load', resolve);\n }));\n\n promises = promises.concat(geoUtils.fetchTraceGeoData(calcData));\n\n Promise.all(promises).then(function() {\n self.fillBelowLookup(calcData, fullLayout);\n self.updateData(calcData);\n self.updateLayout(fullLayout);\n self.resolveOnRender(resolve);\n }).catch(reject);\n};\n\nproto.updateMap = function(calcData, fullLayout, resolve, reject) {\n var self = this;\n var map = self.map;\n var opts = fullLayout[this.id];\n\n self.rejectOnError(reject);\n\n var promises = [];\n var styleObj = getStyleObj(opts.style, fullLayout);\n\n if(JSON.stringify(self.styleObj) !== JSON.stringify(styleObj)) {\n self.styleObj = styleObj;\n map.setStyle(styleObj.style);\n\n // need to rebuild trace layers on reload\n // to avoid 'lost event' errors\n self.traceHash = {};\n\n promises.push(new Promise(function(resolve) {\n map.once('styledata', resolve);\n }));\n }\n\n promises = promises.concat(geoUtils.fetchTraceGeoData(calcData));\n\n Promise.all(promises).then(function() {\n self.fillBelowLookup(calcData, fullLayout);\n self.updateData(calcData);\n self.updateLayout(fullLayout);\n self.resolveOnRender(resolve);\n }).catch(reject);\n};\n\nproto.fillBelowLookup = function(calcData, fullLayout) {\n var opts = fullLayout[this.id];\n var layers = opts.layers;\n var i, val;\n\n var belowLookup = this.belowLookup = {};\n var hasTraceAtTop = false;\n\n for(i = 0; i < calcData.length; i++) {\n var trace = calcData[i][0].trace;\n var _module = trace._module;\n\n if(typeof trace.below === 'string') {\n val = trace.below;\n } else if(_module.getBelow) {\n // 'smart' default that depend the map's base layers\n val = _module.getBelow(trace, this);\n }\n\n if(val === '') {\n hasTraceAtTop = true;\n }\n\n belowLookup['trace-' + trace.uid] = val || '';\n }\n\n for(i = 0; i < layers.length; i++) {\n var item = layers[i];\n\n if(typeof item.below === 'string') {\n val = item.below;\n } else if(hasTraceAtTop) {\n // if one or more trace(s) set `below:''` and\n // layers[i].below is unset,\n // place layer below traces\n val = 'traces';\n } else {\n val = '';\n }\n\n belowLookup['layout-' + i] = val;\n }\n\n // N.B. If multiple layers have the 'below' value,\n // we must clear the stashed 'below' field in order\n // to make `traceHash[k].update()` and `layerList[i].update()`\n // remove/add the all those layers to have preserve\n // the correct layer ordering\n var val2list = {};\n var k, id;\n\n for(k in belowLookup) {\n val = belowLookup[k];\n if(val2list[val]) {\n val2list[val].push(k);\n } else {\n val2list[val] = [k];\n }\n }\n\n for(val in val2list) {\n var list = val2list[val];\n if(list.length > 1) {\n for(i = 0; i < list.length; i++) {\n k = list[i];\n if(k.indexOf('trace-') === 0) {\n id = k.split('trace-')[1];\n if(this.traceHash[id]) {\n this.traceHash[id].below = null;\n }\n } else if(k.indexOf('layout-') === 0) {\n id = k.split('layout-')[1];\n if(this.layerList[id]) {\n this.layerList[id].below = null;\n }\n }\n }\n }\n }\n};\n\nvar traceType2orderIndex = {\n choroplethmapbox: 0,\n densitymapbox: 1,\n scattermapbox: 2\n};\n\nproto.updateData = function(calcData) {\n var traceHash = this.traceHash;\n var traceObj, trace, i, j;\n\n // Need to sort here by trace type here,\n // in case traces with different `type` have the same\n // below value, but sorting we ensure that\n // e.g. choroplethmapbox traces will be below scattermapbox traces\n var calcDataSorted = calcData.slice().sort(function(a, b) {\n return (\n traceType2orderIndex[a[0].trace.type] -\n traceType2orderIndex[b[0].trace.type]\n );\n });\n\n // update or create trace objects\n for(i = 0; i < calcDataSorted.length; i++) {\n var calcTrace = calcDataSorted[i];\n\n trace = calcTrace[0].trace;\n traceObj = traceHash[trace.uid];\n\n var didUpdate = false;\n if(traceObj) {\n if(traceObj.type === trace.type) {\n traceObj.update(calcTrace);\n didUpdate = true;\n } else {\n traceObj.dispose();\n }\n }\n if(!didUpdate && trace._module) {\n traceHash[trace.uid] = trace._module.plot(this, calcTrace);\n }\n }\n\n // remove empty trace objects\n var ids = Object.keys(traceHash);\n idLoop:\n for(i = 0; i < ids.length; i++) {\n var id = ids[i];\n\n for(j = 0; j < calcData.length; j++) {\n trace = calcData[j][0].trace;\n if(id === trace.uid) continue idLoop;\n }\n\n traceObj = traceHash[id];\n traceObj.dispose();\n delete traceHash[id];\n }\n};\n\nproto.updateLayout = function(fullLayout) {\n var map = this.map;\n var opts = fullLayout[this.id];\n\n if(!this.dragging && !this.wheeling) {\n map.setCenter(convertCenter(opts.center));\n map.setZoom(opts.zoom);\n map.setBearing(opts.bearing);\n map.setPitch(opts.pitch);\n }\n\n this.updateLayers(fullLayout);\n this.updateFramework(fullLayout);\n this.updateFx(fullLayout);\n this.map.resize();\n\n if(this.gd._context._scrollZoom.mapbox) {\n map.scrollZoom.enable();\n } else {\n map.scrollZoom.disable();\n }\n};\n\nproto.resolveOnRender = function(resolve) {\n var map = this.map;\n\n map.on('render', function onRender() {\n if(map.loaded()) {\n map.off('render', onRender);\n // resolve at end of render loop\n //\n // Need a 10ms delay (0ms should suffice to skip a thread in the\n // render loop) to workaround mapbox-gl bug introduced in v1.3.0\n setTimeout(resolve, 10);\n }\n });\n};\n\nproto.rejectOnError = function(reject) {\n var map = this.map;\n\n function handler() {\n reject(new Error(constants.mapOnErrorMsg));\n }\n\n map.once('error', handler);\n map.once('style.error', handler);\n map.once('source.error', handler);\n map.once('tile.error', handler);\n map.once('layer.error', handler);\n};\n\nproto.createFramework = function(fullLayout) {\n var self = this;\n\n var div = self.div = document.createElement('div');\n div.id = self.uid;\n div.style.position = 'absolute';\n self.container.appendChild(div);\n\n // create mock x/y axes for hover routine\n self.xaxis = {\n _id: 'x',\n c2p: function(v) { return self.project(v).x; }\n };\n self.yaxis = {\n _id: 'y',\n c2p: function(v) { return self.project(v).y; }\n };\n\n self.updateFramework(fullLayout);\n\n // mock axis for hover formatting\n self.mockAxis = {\n type: 'linear',\n showexponent: 'all',\n exponentformat: 'B'\n };\n Axes.setConvert(self.mockAxis, fullLayout);\n};\n\nproto.initFx = function(calcData, fullLayout) {\n var self = this;\n var gd = self.gd;\n var map = self.map;\n\n // keep track of pan / zoom in user layout and emit relayout event\n map.on('moveend', function(evt) {\n if(!self.map) return;\n\n var fullLayoutNow = gd._fullLayout;\n\n // 'moveend' gets triggered by map.setCenter, map.setZoom,\n // map.setBearing and map.setPitch.\n //\n // Here, we make sure that state updates amd 'plotly_relayout'\n // are triggered only when the 'moveend' originates from a\n // mouse target (filtering out API calls) to not\n // duplicate 'plotly_relayout' events.\n\n if(evt.originalEvent || self.wheeling) {\n var optsNow = fullLayoutNow[self.id];\n Registry.call('_storeDirectGUIEdit', gd.layout, fullLayoutNow._preGUI, self.getViewEdits(optsNow));\n\n var viewNow = self.getView();\n optsNow._input.center = optsNow.center = viewNow.center;\n optsNow._input.zoom = optsNow.zoom = viewNow.zoom;\n optsNow._input.bearing = optsNow.bearing = viewNow.bearing;\n optsNow._input.pitch = optsNow.pitch = viewNow.pitch;\n gd.emit('plotly_relayout', self.getViewEditsWithDerived(viewNow));\n }\n if(evt.originalEvent && evt.originalEvent.type === 'mouseup') {\n self.dragging = false;\n } else if(self.wheeling) {\n self.wheeling = false;\n }\n\n if(fullLayoutNow._rehover) {\n fullLayoutNow._rehover();\n }\n });\n\n map.on('wheel', function() {\n self.wheeling = true;\n });\n\n map.on('mousemove', function(evt) {\n var bb = self.div.getBoundingClientRect();\n var xy = [\n evt.originalEvent.offsetX,\n evt.originalEvent.offsetY\n ];\n\n evt.target.getBoundingClientRect = function() { return bb; };\n\n self.xaxis.p2c = function() { return map.unproject(xy).lng; };\n self.yaxis.p2c = function() { return map.unproject(xy).lat; };\n\n gd._fullLayout._rehover = function() {\n if(gd._fullLayout._hoversubplot === self.id && gd._fullLayout[self.id]) {\n Fx.hover(gd, evt, self.id);\n }\n };\n\n Fx.hover(gd, evt, self.id);\n gd._fullLayout._hoversubplot = self.id;\n });\n\n function unhover() {\n Fx.loneUnhover(fullLayout._hoverlayer);\n }\n\n map.on('dragstart', function() {\n self.dragging = true;\n unhover();\n });\n map.on('zoomstart', unhover);\n\n map.on('mouseout', function() {\n gd._fullLayout._hoversubplot = null;\n });\n\n function emitUpdate() {\n var viewNow = self.getView();\n gd.emit('plotly_relayouting', self.getViewEditsWithDerived(viewNow));\n }\n\n map.on('drag', emitUpdate);\n map.on('zoom', emitUpdate);\n\n map.on('dblclick', function() {\n var optsNow = gd._fullLayout[self.id];\n Registry.call('_storeDirectGUIEdit', gd.layout, gd._fullLayout._preGUI, self.getViewEdits(optsNow));\n\n var viewInitial = self.viewInitial;\n map.setCenter(convertCenter(viewInitial.center));\n map.setZoom(viewInitial.zoom);\n map.setBearing(viewInitial.bearing);\n map.setPitch(viewInitial.pitch);\n\n var viewNow = self.getView();\n optsNow._input.center = optsNow.center = viewNow.center;\n optsNow._input.zoom = optsNow.zoom = viewNow.zoom;\n optsNow._input.bearing = optsNow.bearing = viewNow.bearing;\n optsNow._input.pitch = optsNow.pitch = viewNow.pitch;\n\n gd.emit('plotly_doubleclick', null);\n gd.emit('plotly_relayout', self.getViewEditsWithDerived(viewNow));\n });\n\n // define event handlers on map creation, to keep one ref per map,\n // so that map.on / map.off in updateFx works as expected\n self.clearOutline = function() {\n clearSelectionsCache(self.dragOptions);\n clearOutline(self.dragOptions.gd);\n };\n\n /**\n * Returns a click handler function that is supposed\n * to handle clicks in pan mode.\n */\n self.onClickInPanFn = function(dragOptions) {\n return function(evt) {\n var clickMode = gd._fullLayout.clickmode;\n\n if(clickMode.indexOf('select') > -1) {\n selectOnClick(evt.originalEvent, gd, [self.xaxis], [self.yaxis], self.id, dragOptions);\n }\n\n if(clickMode.indexOf('event') > -1) {\n // TODO: this does not support right-click. If we want to support it, we\n // would likely need to change mapbox to use dragElement instead of straight\n // mapbox event binding. Or perhaps better, make a simple wrapper with the\n // right mousedown, mousemove, and mouseup handlers just for a left/right click\n // pie would use this too.\n Fx.click(gd, evt.originalEvent);\n }\n };\n };\n};\n\nproto.updateFx = function(fullLayout) {\n var self = this;\n var map = self.map;\n var gd = self.gd;\n\n if(self.isStatic) return;\n\n function invert(pxpy) {\n var obj = self.map.unproject(pxpy);\n return [obj.lng, obj.lat];\n }\n\n var dragMode = fullLayout.dragmode;\n var fillRangeItems;\n\n fillRangeItems = function(eventData, poly) {\n if(poly.isRect) {\n var ranges = eventData.range = {};\n ranges[self.id] = [\n invert([poly.xmin, poly.ymin]),\n invert([poly.xmax, poly.ymax])\n ];\n } else {\n var dataPts = eventData.lassoPoints = {};\n dataPts[self.id] = poly.map(invert);\n }\n };\n\n // Note: dragOptions is needed to be declared for all dragmodes because\n // it's the object that holds persistent selection state.\n // Merge old dragOptions with new to keep possibly initialized\n // persistent selection state.\n var oldDragOptions = self.dragOptions;\n self.dragOptions = Lib.extendDeep(oldDragOptions || {}, {\n dragmode: fullLayout.dragmode,\n element: self.div,\n gd: gd,\n plotinfo: {\n id: self.id,\n domain: fullLayout[self.id].domain,\n xaxis: self.xaxis,\n yaxis: self.yaxis,\n fillRangeItems: fillRangeItems\n },\n xaxes: [self.xaxis],\n yaxes: [self.yaxis],\n subplot: self.id\n });\n\n // Unregister the old handler before potentially registering\n // a new one. Otherwise multiple click handlers might\n // be registered resulting in unwanted behavior.\n map.off('click', self.onClickInPanHandler);\n if(selectMode(dragMode) || drawMode(dragMode)) {\n map.dragPan.disable();\n map.on('zoomstart', self.clearOutline);\n\n self.dragOptions.prepFn = function(e, startX, startY) {\n prepSelect(e, startX, startY, self.dragOptions, dragMode);\n };\n\n dragElement.init(self.dragOptions);\n } else {\n map.dragPan.enable();\n map.off('zoomstart', self.clearOutline);\n self.div.onmousedown = null;\n self.div.ontouchstart = null;\n self.div.removeEventListener('touchstart', self.div._ontouchstart);\n // TODO: this does not support right-click. If we want to support it, we\n // would likely need to change mapbox to use dragElement instead of straight\n // mapbox event binding. Or perhaps better, make a simple wrapper with the\n // right mousedown, mousemove, and mouseup handlers just for a left/right click\n // pie would use this too.\n self.onClickInPanHandler = self.onClickInPanFn(self.dragOptions);\n map.on('click', self.onClickInPanHandler);\n }\n};\n\nproto.updateFramework = function(fullLayout) {\n var domain = fullLayout[this.id].domain;\n var size = fullLayout._size;\n\n var style = this.div.style;\n style.width = size.w * (domain.x[1] - domain.x[0]) + 'px';\n style.height = size.h * (domain.y[1] - domain.y[0]) + 'px';\n style.left = size.l + domain.x[0] * size.w + 'px';\n style.top = size.t + (1 - domain.y[1]) * size.h + 'px';\n\n this.xaxis._offset = size.l + domain.x[0] * size.w;\n this.xaxis._length = size.w * (domain.x[1] - domain.x[0]);\n\n this.yaxis._offset = size.t + (1 - domain.y[1]) * size.h;\n this.yaxis._length = size.h * (domain.y[1] - domain.y[0]);\n};\n\nproto.updateLayers = function(fullLayout) {\n var opts = fullLayout[this.id];\n var layers = opts.layers;\n var layerList = this.layerList;\n var i;\n\n // if the layer arrays don't match,\n // don't try to be smart,\n // delete them all, and start all over.\n\n if(layers.length !== layerList.length) {\n for(i = 0; i < layerList.length; i++) {\n layerList[i].dispose();\n }\n\n layerList = this.layerList = [];\n\n for(i = 0; i < layers.length; i++) {\n layerList.push(createMapboxLayer(this, i, layers[i]));\n }\n } else {\n for(i = 0; i < layers.length; i++) {\n layerList[i].update(layers[i]);\n }\n }\n};\n\nproto.destroy = function() {\n if(this.map) {\n this.map.remove();\n this.map = null;\n this.container.removeChild(this.div);\n }\n};\n\nproto.toImage = function() {\n this.map.stop();\n return this.map.getCanvas().toDataURL();\n};\n\n// convenience wrapper to create set multiple layer\n// 'layout' or 'paint options at once.\nproto.setOptions = function(id, methodName, opts) {\n for(var k in opts) {\n this.map[methodName](id, k, opts[k]);\n }\n};\n\nproto.getMapLayers = function() {\n return this.map.getStyle().layers;\n};\n\n// convenience wrapper that first check in 'below' references\n// a layer that exist and then add the layer to the map,\nproto.addLayer = function(opts, below) {\n var map = this.map;\n\n if(typeof below === 'string') {\n if(below === '') {\n map.addLayer(opts, below);\n return;\n }\n\n var mapLayers = this.getMapLayers();\n for(var i = 0; i < mapLayers.length; i++) {\n if(below === mapLayers[i].id) {\n map.addLayer(opts, below);\n return;\n }\n }\n\n Lib.warn([\n 'Trying to add layer with *below* value',\n below,\n 'referencing a layer that does not exist',\n 'or that does not yet exist.'\n ].join(' '));\n }\n\n map.addLayer(opts);\n};\n\n// convenience method to project a [lon, lat] array to pixel coords\nproto.project = function(v) {\n return this.map.project(new mapboxgl.LngLat(v[0], v[1]));\n};\n\n// get map's current view values in plotly.js notation\nproto.getView = function() {\n var map = this.map;\n var mapCenter = map.getCenter();\n var lon = mapCenter.lng;\n var lat = mapCenter.lat;\n var center = { lon: lon, lat: lat };\n\n var canvas = map.getCanvas();\n var w = parseInt(canvas.style.width);\n var h = parseInt(canvas.style.height);\n\n return {\n center: center,\n zoom: map.getZoom(),\n bearing: map.getBearing(),\n pitch: map.getPitch(),\n _derived: {\n coordinates: [\n map.unproject([0, 0]).toArray(),\n map.unproject([w, 0]).toArray(),\n map.unproject([w, h]).toArray(),\n map.unproject([0, h]).toArray()\n ]\n }\n };\n};\n\nproto.getViewEdits = function(cont) {\n var id = this.id;\n var keys = ['center', 'zoom', 'bearing', 'pitch'];\n var obj = {};\n\n for(var i = 0; i < keys.length; i++) {\n var k = keys[i];\n obj[id + '.' + k] = cont[k];\n }\n\n return obj;\n};\n\nproto.getViewEditsWithDerived = function(cont) {\n var id = this.id;\n var obj = this.getViewEdits(cont);\n obj[id + '._derived'] = cont._derived;\n return obj;\n};\n\nfunction getStyleObj(val, fullLayout) {\n var styleObj = {};\n\n if(Lib.isPlainObject(val)) {\n styleObj.id = val.id;\n styleObj.style = val;\n } else if(typeof val === 'string') {\n styleObj.id = val;\n\n if(constants.styleValuesMapbox.indexOf(val) !== -1) {\n styleObj.style = convertStyleVal(val);\n } else if(constants.stylesNonMapbox[val]) {\n styleObj.style = constants.stylesNonMapbox[val];\n var spec = styleObj.style.sources['plotly-' + val];\n var tiles = spec ? spec.tiles : undefined;\n if(\n tiles &&\n tiles[0] &&\n tiles[0].slice(-9) === '?api_key='\n ) {\n // provide api_key for stamen styles\n tiles[0] += fullLayout._mapboxAccessToken;\n }\n } else {\n styleObj.style = val;\n }\n } else {\n styleObj.id = constants.styleValueDflt;\n styleObj.style = convertStyleVal(constants.styleValueDflt);\n }\n\n styleObj.transition = {duration: 0, delay: 0};\n\n return styleObj;\n}\n\n// if style is part of the 'official' mapbox values, add URL prefix and suffix\nfunction convertStyleVal(val) {\n return constants.styleUrlPrefix + val + '-' + constants.styleUrlSuffix;\n}\n\nfunction convertCenter(center) {\n return [center.lon, center.lat];\n}\n\nmodule.exports = Mapbox;\n","'use strict';\n\n/**\n * Creates a set of padding attributes.\n *\n * @param {object} opts\n * @param {string} editType:\n * the editType for all pieces of this padding definition\n *\n * @return {object} attributes object containing {t, r, b, l} as specified\n */\nmodule.exports = function(opts) {\n var editType = opts.editType;\n return {\n t: {\n valType: 'number',\n dflt: 0,\n editType: editType,\n description: 'The amount of padding (in px) along the top of the component.'\n },\n r: {\n valType: 'number',\n dflt: 0,\n editType: editType,\n description: 'The amount of padding (in px) on the right side of the component.'\n },\n b: {\n valType: 'number',\n dflt: 0,\n editType: editType,\n description: 'The amount of padding (in px) along the bottom of the component.'\n },\n l: {\n valType: 'number',\n dflt: 0,\n editType: editType,\n description: 'The amount of padding (in px) on the left side of the component.'\n },\n editType: editType\n };\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar timeFormatLocale = require('d3-time-format').timeFormatLocale;\nvar formatLocale = require('d3-format').formatLocale;\nvar isNumeric = require('fast-isnumeric');\nvar b64encode = require('base64-arraybuffer');\n\nvar Registry = require('../registry');\nvar PlotSchema = require('../plot_api/plot_schema');\nvar Template = require('../plot_api/plot_template');\nvar Lib = require('../lib');\nvar Color = require('../components/color');\nvar BADNUM = require('../constants/numerical').BADNUM;\n\nvar axisIDs = require('./cartesian/axis_ids');\nvar clearOutline = require('../components/shapes/handle_outline').clearOutline;\nvar scatterAttrs = require('../traces/scatter/layout_attributes');\n\nvar animationAttrs = require('./animation_attributes');\nvar frameAttrs = require('./frame_attributes');\n\nvar getModuleCalcData = require('../plots/get_data').getModuleCalcData;\n\nvar relinkPrivateKeys = Lib.relinkPrivateKeys;\nvar _ = Lib._;\n\nvar plots = module.exports = {};\n\n// Expose registry methods on Plots for backward-compatibility\nLib.extendFlat(plots, Registry);\n\nplots.attributes = require('./attributes');\nplots.attributes.type.values = plots.allTypes;\nplots.fontAttrs = require('./font_attributes');\nplots.layoutAttributes = require('./layout_attributes');\n\nvar transformsRegistry = plots.transformsRegistry;\n\nvar commandModule = require('./command');\nplots.executeAPICommand = commandModule.executeAPICommand;\nplots.computeAPICommandBindings = commandModule.computeAPICommandBindings;\nplots.manageCommandObserver = commandModule.manageCommandObserver;\nplots.hasSimpleAPICommandBindings = commandModule.hasSimpleAPICommandBindings;\n\n// in some cases the browser doesn't seem to know how big\n// the text is at first, so it needs to draw it,\n// then wait a little, then draw it again\nplots.redrawText = function(gd) {\n gd = Lib.getGraphDiv(gd);\n\n return new Promise(function(resolve) {\n setTimeout(function() {\n if(!gd._fullLayout) return;\n Registry.getComponentMethod('annotations', 'draw')(gd);\n Registry.getComponentMethod('legend', 'draw')(gd);\n Registry.getComponentMethod('colorbar', 'draw')(gd);\n resolve(plots.previousPromises(gd));\n }, 300);\n });\n};\n\n// resize plot about the container size\nplots.resize = function(gd) {\n gd = Lib.getGraphDiv(gd);\n\n var resolveLastResize;\n var p = new Promise(function(resolve, reject) {\n if(!gd || Lib.isHidden(gd)) {\n reject(new Error('Resize must be passed a displayed plot div element.'));\n }\n\n if(gd._redrawTimer) clearTimeout(gd._redrawTimer);\n if(gd._resolveResize) resolveLastResize = gd._resolveResize;\n gd._resolveResize = resolve;\n\n gd._redrawTimer = setTimeout(function() {\n // return if there is nothing to resize or is hidden\n if(!gd.layout || (gd.layout.width && gd.layout.height) || Lib.isHidden(gd)) {\n resolve(gd);\n return;\n }\n\n delete gd.layout.width;\n delete gd.layout.height;\n\n // autosizing doesn't count as a change that needs saving\n var oldchanged = gd.changed;\n\n // nor should it be included in the undo queue\n gd.autoplay = true;\n\n Registry.call('relayout', gd, {autosize: true}).then(function() {\n gd.changed = oldchanged;\n // Only resolve if a new call hasn't been made!\n if(gd._resolveResize === resolve) {\n delete gd._resolveResize;\n resolve(gd);\n }\n });\n }, 100);\n });\n\n if(resolveLastResize) resolveLastResize(p);\n return p;\n};\n\n\n// for use in Lib.syncOrAsync, check if there are any\n// pending promises in this plot and wait for them\nplots.previousPromises = function(gd) {\n if((gd._promises || []).length) {\n return Promise.all(gd._promises)\n .then(function() { gd._promises = []; });\n }\n};\n\n/**\n * Adds the 'Edit chart' link.\n * Note that now _doPlot calls this so it can regenerate whenever it replots\n *\n * Add source links to your graph inside the 'showSources' config argument.\n */\nplots.addLinks = function(gd) {\n // Do not do anything if showLink and showSources are not set to true in config\n if(!gd._context.showLink && !gd._context.showSources) return;\n\n var fullLayout = gd._fullLayout;\n\n var linkContainer = Lib.ensureSingle(fullLayout._paper, 'text', 'js-plot-link-container', function(s) {\n s.style({\n 'font-family': '\"Open Sans\", Arial, sans-serif',\n 'font-size': '12px',\n fill: Color.defaultLine,\n 'pointer-events': 'all'\n })\n .each(function() {\n var links = d3.select(this);\n links.append('tspan').classed('js-link-to-tool', true);\n links.append('tspan').classed('js-link-spacer', true);\n links.append('tspan').classed('js-sourcelinks', true);\n });\n });\n\n // The text node inside svg\n var text = linkContainer.node();\n var attrs = {y: fullLayout._paper.attr('height') - 9};\n\n // If text's width is bigger than the layout\n // Check that text is a child node or document.body\n // because otherwise IE/Edge might throw an exception\n // when calling getComputedTextLength().\n // Apparently offsetParent is null for invisibles.\n if(document.body.contains(text) && text.getComputedTextLength() >= (fullLayout.width - 20)) {\n // Align the text at the left\n attrs['text-anchor'] = 'start';\n attrs.x = 5;\n } else {\n // Align the text at the right\n attrs['text-anchor'] = 'end';\n attrs.x = fullLayout._paper.attr('width') - 7;\n }\n\n linkContainer.attr(attrs);\n\n var toolspan = linkContainer.select('.js-link-to-tool');\n var spacespan = linkContainer.select('.js-link-spacer');\n var sourcespan = linkContainer.select('.js-sourcelinks');\n\n if(gd._context.showSources) gd._context.showSources(gd);\n\n // 'view in plotly' link for embedded plots\n if(gd._context.showLink) positionPlayWithData(gd, toolspan);\n\n // separator if we have both sources and tool link\n spacespan.text((toolspan.text() && sourcespan.text()) ? ' - ' : '');\n};\n\n// note that now this function is only adding the brand in\n// iframes and 3rd-party apps\nfunction positionPlayWithData(gd, container) {\n container.text('');\n var link = container.append('a')\n .attr({\n 'xlink:xlink:href': '#',\n class: 'link--impt link--embedview',\n 'font-weight': 'bold'\n })\n .text(gd._context.linkText + ' ' + String.fromCharCode(187));\n\n if(gd._context.sendData) {\n link.on('click', function() {\n plots.sendDataToCloud(gd);\n });\n } else {\n var path = window.location.pathname.split('/');\n var query = window.location.search;\n link.attr({\n 'xlink:xlink:show': 'new',\n 'xlink:xlink:href': '/' + path[2].split('.')[0] + '/' + path[1] + query\n });\n }\n}\n\nplots.sendDataToCloud = function(gd) {\n var baseUrl = (window.PLOTLYENV || {}).BASE_URL || gd._context.plotlyServerURL;\n if(!baseUrl) return;\n\n gd.emit('plotly_beforeexport');\n\n var hiddenformDiv = d3.select(gd)\n .append('div')\n .attr('id', 'hiddenform')\n .style('display', 'none');\n\n var hiddenform = hiddenformDiv\n .append('form')\n .attr({\n action: baseUrl + '/external',\n method: 'post',\n target: '_blank'\n });\n\n var hiddenformInput = hiddenform\n .append('input')\n .attr({\n type: 'text',\n name: 'data'\n });\n\n hiddenformInput.node().value = plots.graphJson(gd, false, 'keepdata');\n hiddenform.node().submit();\n hiddenformDiv.remove();\n\n gd.emit('plotly_afterexport');\n return false;\n};\n\nvar d3FormatKeys = [\n 'days', 'shortDays', 'months', 'shortMonths', 'periods',\n 'dateTime', 'date', 'time',\n 'decimal', 'thousands', 'grouping', 'currency'\n];\n\nvar extraFormatKeys = [\n 'year', 'month', 'dayMonth', 'dayMonthYear'\n];\n\n/*\n * Fill in default values\n * @param {DOM element} gd\n * @param {object} opts\n * @param {boolean} opts.skipUpdateCalc: normally if the existing gd.calcdata looks\n * compatible with the new gd._fullData we finish by linking the new _fullData traces\n * to the old gd.calcdata, so it's correctly set if we're not going to recalc. But also,\n * if there are calcTransforms on the trace, we first remap data arrays from the old full\n * trace into the new one. Use skipUpdateCalc to defer this (needed by Plotly.react)\n *\n * gd.data, gd.layout:\n * are precisely what the user specified (except as modified by cleanData/cleanLayout),\n * these fields shouldn't be modified (except for filling in some auto values)\n * nor used directly after the supply defaults step.\n *\n * gd._fullData, gd._fullLayout:\n * are complete descriptions of how to draw the plot,\n * use these fields in all required computations.\n *\n * gd._fullLayout._modules\n * is a list of all the trace modules required to draw the plot.\n *\n * gd._fullLayout._visibleModules\n * subset of _modules, a list of modules corresponding to visible:true traces.\n *\n * gd._fullLayout._basePlotModules\n * is a list of all the plot modules required to draw the plot.\n *\n * gd._fullLayout._transformModules\n * is a list of all the transform modules invoked.\n *\n */\nplots.supplyDefaults = function(gd, opts) {\n var skipUpdateCalc = opts && opts.skipUpdateCalc;\n var oldFullLayout = gd._fullLayout || {};\n\n if(oldFullLayout._skipDefaults) {\n delete oldFullLayout._skipDefaults;\n return;\n }\n\n var newFullLayout = gd._fullLayout = {};\n var newLayout = gd.layout || {};\n\n var oldFullData = gd._fullData || [];\n var newFullData = gd._fullData = [];\n var newData = gd.data || [];\n\n var oldCalcdata = gd.calcdata || [];\n\n var context = gd._context || {};\n\n var i;\n\n // Create all the storage space for frames, but only if doesn't already exist\n if(!gd._transitionData) plots.createTransitionData(gd);\n\n // So we only need to do this once (and since we have gd here)\n // get the translated placeholder titles.\n // These ones get used as default values so need to be known at supplyDefaults\n // others keep their blank defaults but render the placeholder as desired later\n // TODO: make these work the same way, only inserting the placeholder text at draw time?\n // The challenge is that this has slightly different behavior right now in editable mode:\n // using the placeholder as default makes this text permanently (but lightly) visible,\n // but explicit '' for these titles gives you a placeholder that's hidden until you mouse\n // over it - so you're not distracted by it if you really don't want a title, but if you do\n // and you're new to plotly you may not be able to find it.\n // When editable=false the two behave the same, no title is drawn.\n newFullLayout._dfltTitle = {\n plot: _(gd, 'Click to enter Plot title'),\n subtitle: _(gd, 'Click to enter Plot subtitle'),\n x: _(gd, 'Click to enter X axis title'),\n y: _(gd, 'Click to enter Y axis title'),\n colorbar: _(gd, 'Click to enter Colorscale title'),\n annotation: _(gd, 'new text')\n };\n newFullLayout._traceWord = _(gd, 'trace');\n\n var formatObj = getFormatObj(gd, d3FormatKeys);\n\n // stash the token from context so mapbox subplots can use it as default\n newFullLayout._mapboxAccessToken = context.mapboxAccessToken;\n\n // first fill in what we can of layout without looking at data\n // because fullData needs a few things from layout\n if(oldFullLayout._initialAutoSizeIsDone) {\n // coerce the updated layout while preserving width and height\n var oldWidth = oldFullLayout.width;\n var oldHeight = oldFullLayout.height;\n\n plots.supplyLayoutGlobalDefaults(newLayout, newFullLayout, formatObj);\n\n if(!newLayout.width) newFullLayout.width = oldWidth;\n if(!newLayout.height) newFullLayout.height = oldHeight;\n plots.sanitizeMargins(newFullLayout);\n } else {\n // coerce the updated layout and autosize if needed\n plots.supplyLayoutGlobalDefaults(newLayout, newFullLayout, formatObj);\n\n var missingWidthOrHeight = (!newLayout.width || !newLayout.height);\n var autosize = newFullLayout.autosize;\n var autosizable = context.autosizable;\n var initialAutoSize = missingWidthOrHeight && (autosize || autosizable);\n\n if(initialAutoSize) plots.plotAutoSize(gd, newLayout, newFullLayout);\n else if(missingWidthOrHeight) plots.sanitizeMargins(newFullLayout);\n\n // for backwards-compatibility with Plotly v1.x.x\n if(!autosize && missingWidthOrHeight) {\n newLayout.width = newFullLayout.width;\n newLayout.height = newFullLayout.height;\n }\n }\n\n newFullLayout._d3locale = getFormatter(formatObj, newFullLayout.separators);\n newFullLayout._extraFormat = getFormatObj(gd, extraFormatKeys);\n\n newFullLayout._initialAutoSizeIsDone = true;\n\n // keep track of how many traces are inputted\n newFullLayout._dataLength = newData.length;\n\n // clear the lists of trace and baseplot modules, and subplots\n newFullLayout._modules = [];\n newFullLayout._visibleModules = [];\n newFullLayout._basePlotModules = [];\n var subplots = newFullLayout._subplots = emptySubplotLists();\n\n // initialize axis and subplot hash objects for splom-generated grids\n var splomAxes = newFullLayout._splomAxes = {x: {}, y: {}};\n var splomSubplots = newFullLayout._splomSubplots = {};\n // initialize splom grid defaults\n newFullLayout._splomGridDflt = {};\n\n // for stacked area traces to share config across traces\n newFullLayout._scatterStackOpts = {};\n // for the first scatter trace on each subplot (so it knows tonext->tozero)\n newFullLayout._firstScatter = {};\n // for grouped bar/box/violin trace to share config across traces\n newFullLayout._alignmentOpts = {};\n // track color axes referenced in the data\n newFullLayout._colorAxes = {};\n\n // for traces to request a default rangeslider on their x axes\n // eg set `_requestRangeslider.x2 = true` for xaxis2\n newFullLayout._requestRangeslider = {};\n\n // pull uids from old data to use as new defaults\n newFullLayout._traceUids = getTraceUids(oldFullData, newData);\n\n // then do the data\n newFullLayout._globalTransforms = (gd._context || {}).globalTransforms;\n plots.supplyDataDefaults(newData, newFullData, newLayout, newFullLayout);\n\n // redo grid size defaults with info about splom x/y axes,\n // and fill in generated cartesian axes and subplots\n var splomXa = Object.keys(splomAxes.x);\n var splomYa = Object.keys(splomAxes.y);\n if(splomXa.length > 1 && splomYa.length > 1) {\n Registry.getComponentMethod('grid', 'sizeDefaults')(newLayout, newFullLayout);\n\n for(i = 0; i < splomXa.length; i++) {\n Lib.pushUnique(subplots.xaxis, splomXa[i]);\n }\n for(i = 0; i < splomYa.length; i++) {\n Lib.pushUnique(subplots.yaxis, splomYa[i]);\n }\n for(var k in splomSubplots) {\n Lib.pushUnique(subplots.cartesian, k);\n }\n }\n\n // attach helper method to check whether a plot type is present on graph\n newFullLayout._has = plots._hasPlotType.bind(newFullLayout);\n\n if(oldFullData.length === newFullData.length) {\n for(i = 0; i < newFullData.length; i++) {\n relinkPrivateKeys(newFullData[i], oldFullData[i]);\n }\n }\n\n // finally, fill in the pieces of layout that may need to look at data\n plots.supplyLayoutModuleDefaults(newLayout, newFullLayout, newFullData, gd._transitionData);\n\n // Special cases that introduce interactions between traces.\n // This is after relinkPrivateKeys so we can use those in crossTraceDefaults\n // and after layout module defaults, so we can use eg barmode\n var _modules = newFullLayout._visibleModules;\n var crossTraceDefaultsFuncs = [];\n for(i = 0; i < _modules.length; i++) {\n var funci = _modules[i].crossTraceDefaults;\n // some trace types share crossTraceDefaults (ie histogram2d, histogram2dcontour)\n if(funci) Lib.pushUnique(crossTraceDefaultsFuncs, funci);\n }\n for(i = 0; i < crossTraceDefaultsFuncs.length; i++) {\n crossTraceDefaultsFuncs[i](newFullData, newFullLayout);\n }\n\n // turn on flag to optimize large splom-only graphs\n // mostly by omitting SVG layers during Cartesian.drawFramework\n newFullLayout._hasOnlyLargeSploms = (\n newFullLayout._basePlotModules.length === 1 &&\n newFullLayout._basePlotModules[0].name === 'splom' &&\n splomXa.length > 15 &&\n splomYa.length > 15 &&\n newFullLayout.shapes.length === 0 &&\n newFullLayout.images.length === 0\n );\n\n // relink / initialize subplot axis objects\n plots.linkSubplots(newFullData, newFullLayout, oldFullData, oldFullLayout);\n\n // clean subplots and other artifacts from previous plot calls\n plots.cleanPlot(newFullData, newFullLayout, oldFullData, oldFullLayout);\n\n var hadGL2D = !!(oldFullLayout._has && oldFullLayout._has('gl2d'));\n var hasGL2D = !!(newFullLayout._has && newFullLayout._has('gl2d'));\n var hadCartesian = !!(oldFullLayout._has && oldFullLayout._has('cartesian'));\n var hasCartesian = !!(newFullLayout._has && newFullLayout._has('cartesian'));\n var hadBgLayer = hadCartesian || hadGL2D;\n var hasBgLayer = hasCartesian || hasGL2D;\n if(hadBgLayer && !hasBgLayer) {\n // remove bgLayer\n oldFullLayout._bgLayer.remove();\n } else if(hasBgLayer && !hadBgLayer) {\n // create bgLayer\n newFullLayout._shouldCreateBgLayer = true;\n }\n\n // clear selection outline until we implement persistent selection,\n // don't clear them though when drag handlers (e.g. listening to\n // `plotly_selecting`) update the graph.\n // we should try to come up with a better solution when implementing\n // https://github.com/plotly/plotly.js/issues/1851\n if(oldFullLayout._zoomlayer && !gd._dragging) {\n clearOutline({ // mock old gd\n _fullLayout: oldFullLayout\n });\n }\n\n\n // fill in meta helpers\n fillMetaTextHelpers(newFullData, newFullLayout);\n\n // relink functions and _ attributes to promote consistency between plots\n relinkPrivateKeys(newFullLayout, oldFullLayout);\n\n // colorscale crossTraceDefaults needs newFullLayout with relinked keys\n Registry.getComponentMethod('colorscale', 'crossTraceDefaults')(newFullData, newFullLayout);\n\n // For persisting GUI-driven changes in layout\n // _preGUI and _tracePreGUI were already copied over in relinkPrivateKeys\n if(!newFullLayout._preGUI) newFullLayout._preGUI = {};\n // track trace GUI changes by uid rather than by trace index\n if(!newFullLayout._tracePreGUI) newFullLayout._tracePreGUI = {};\n var tracePreGUI = newFullLayout._tracePreGUI;\n var uids = {};\n var uid;\n for(uid in tracePreGUI) uids[uid] = 'old';\n for(i = 0; i < newFullData.length; i++) {\n uid = newFullData[i]._fullInput.uid;\n if(!uids[uid]) tracePreGUI[uid] = {};\n uids[uid] = 'new';\n }\n for(uid in uids) {\n if(uids[uid] === 'old') delete tracePreGUI[uid];\n }\n\n // set up containers for margin calculations\n initMargins(newFullLayout);\n\n // collect and do some initial calculations for rangesliders\n Registry.getComponentMethod('rangeslider', 'makeData')(newFullLayout);\n\n // update object references in calcdata\n if(!skipUpdateCalc && oldCalcdata.length === newFullData.length) {\n plots.supplyDefaultsUpdateCalc(oldCalcdata, newFullData);\n }\n};\n\nplots.supplyDefaultsUpdateCalc = function(oldCalcdata, newFullData) {\n for(var i = 0; i < newFullData.length; i++) {\n var newTrace = newFullData[i];\n var cd0 = (oldCalcdata[i] || [])[0];\n if(cd0 && cd0.trace) {\n var oldTrace = cd0.trace;\n if(oldTrace._hasCalcTransform) {\n var arrayAttrs = oldTrace._arrayAttrs;\n var j, astr, oldArrayVal;\n\n for(j = 0; j < arrayAttrs.length; j++) {\n astr = arrayAttrs[j];\n oldArrayVal = Lib.nestedProperty(oldTrace, astr).get().slice();\n Lib.nestedProperty(newTrace, astr).set(oldArrayVal);\n }\n }\n cd0.trace = newTrace;\n }\n }\n};\n\n/**\n * Create a list of uid strings satisfying (in this order of importance):\n * 1. all unique, all strings\n * 2. matches input uids if provided\n * 3. matches previous data uids\n */\nfunction getTraceUids(oldFullData, newData) {\n var len = newData.length;\n var oldFullInput = [];\n var i, prevFullInput;\n for(i = 0; i < oldFullData.length; i++) {\n var thisFullInput = oldFullData[i]._fullInput;\n if(thisFullInput !== prevFullInput) oldFullInput.push(thisFullInput);\n prevFullInput = thisFullInput;\n }\n var oldLen = oldFullInput.length;\n var out = new Array(len);\n var seenUids = {};\n\n function setUid(uid, i) {\n out[i] = uid;\n seenUids[uid] = 1;\n }\n\n function tryUid(uid, i) {\n if(uid && typeof uid === 'string' && !seenUids[uid]) {\n setUid(uid, i);\n return true;\n }\n }\n\n for(i = 0; i < len; i++) {\n var newUid = newData[i].uid;\n if(typeof newUid === 'number') newUid = String(newUid);\n\n if(tryUid(newUid, i)) continue;\n if(i < oldLen && tryUid(oldFullInput[i].uid, i)) continue;\n setUid(Lib.randstr(seenUids), i);\n }\n\n return out;\n}\n\n/**\n * Make a container for collecting subplots we need to display.\n *\n * Finds all subplot types we need to enumerate once and caches it,\n * but makes a new output object each time.\n * Single-trace subplots (which have no `id`) such as pie, table, etc\n * do not need to be collected because we just draw all visible traces.\n */\nfunction emptySubplotLists() {\n var collectableSubplotTypes = Registry.collectableSubplotTypes;\n var out = {};\n var i, j;\n\n if(!collectableSubplotTypes) {\n collectableSubplotTypes = [];\n\n var subplotsRegistry = Registry.subplotsRegistry;\n\n for(var subplotType in subplotsRegistry) {\n var subplotModule = subplotsRegistry[subplotType];\n var subplotAttr = subplotModule.attr;\n\n if(subplotAttr) {\n collectableSubplotTypes.push(subplotType);\n\n // special case, currently just for cartesian:\n // we need to enumerate axes, not just subplots\n if(Array.isArray(subplotAttr)) {\n for(j = 0; j < subplotAttr.length; j++) {\n Lib.pushUnique(collectableSubplotTypes, subplotAttr[j]);\n }\n }\n }\n }\n }\n\n for(i = 0; i < collectableSubplotTypes.length; i++) {\n out[collectableSubplotTypes[i]] = [];\n }\n return out;\n}\n\n/**\n * getFormatObj: use _context to get the format object from locale.\n * Used to get d3.locale argument object and extraFormat argument object\n *\n * Regarding d3.locale argument :\n * decimal and thousands can be overridden later by layout.separators\n * grouping and currency are not presently used by our automatic number\n * formatting system but can be used by custom formats.\n *\n * @returns {object} d3.locale format object\n */\nfunction getFormatObj(gd, formatKeys) {\n var locale = gd._context.locale;\n if(!locale) locale = 'en-US';\n\n var formatDone = false;\n var formatObj = {};\n\n function includeFormat(newFormat) {\n var formatFinished = true;\n for(var i = 0; i < formatKeys.length; i++) {\n var formatKey = formatKeys[i];\n if(!formatObj[formatKey]) {\n if(newFormat[formatKey]) {\n formatObj[formatKey] = newFormat[formatKey];\n } else formatFinished = false;\n }\n }\n if(formatFinished) formatDone = true;\n }\n\n // same as localize, look for format parts in each format spec in the chain\n for(var i = 0; i < 2; i++) {\n var locales = gd._context.locales;\n for(var j = 0; j < 2; j++) {\n var formatj = (locales[locale] || {}).format;\n if(formatj) {\n includeFormat(formatj);\n if(formatDone) break;\n }\n locales = Registry.localeRegistry;\n }\n\n var baseLocale = locale.split('-')[0];\n if(formatDone || baseLocale === locale) break;\n locale = baseLocale;\n }\n\n // lastly pick out defaults from english (non-US, as DMY is so much more common)\n if(!formatDone) includeFormat(Registry.localeRegistry.en.format);\n\n return formatObj;\n}\n\n/**\n * getFormatter: combine the final separators with the locale formatting object\n * we pulled earlier to generate number and time formatters\n * TODO: remove separators in v3, only use locale, so we don't need this step?\n *\n * @param {object} formatObj: d3.locale format object\n * @param {string} separators: length-2 string to override decimal and thousands\n * separators in number formatting\n *\n * @returns {object} {numberFormat, timeFormat} d3 formatter factory functions\n * for numbers and time\n */\nfunction getFormatter(formatObj, separators) {\n formatObj.decimal = separators.charAt(0);\n formatObj.thousands = separators.charAt(1);\n\n return {\n numberFormat: function(formatStr) {\n try {\n formatStr = formatLocale(formatObj).format(\n Lib.adjustFormat(formatStr)\n );\n } catch(e) {\n Lib.warnBadFormat(formatStr);\n return Lib.noFormat;\n }\n\n return formatStr;\n },\n timeFormat: timeFormatLocale(formatObj).utcFormat\n };\n}\n\nfunction fillMetaTextHelpers(newFullData, newFullLayout) {\n var _meta;\n var meta4data = [];\n\n if(newFullLayout.meta) {\n _meta = newFullLayout._meta = {\n meta: newFullLayout.meta,\n layout: {meta: newFullLayout.meta}\n };\n }\n\n for(var i = 0; i < newFullData.length; i++) {\n var trace = newFullData[i];\n\n if(trace.meta) {\n meta4data[trace.index] = trace._meta = {meta: trace.meta};\n } else if(newFullLayout.meta) {\n trace._meta = {meta: newFullLayout.meta};\n }\n if(newFullLayout.meta) {\n trace._meta.layout = {meta: newFullLayout.meta};\n }\n }\n\n if(meta4data.length) {\n if(!_meta) {\n _meta = newFullLayout._meta = {};\n }\n _meta.data = meta4data;\n }\n}\n\n// Create storage for all of the data related to frames and transitions:\nplots.createTransitionData = function(gd) {\n // Set up the default keyframe if it doesn't exist:\n if(!gd._transitionData) {\n gd._transitionData = {};\n }\n\n if(!gd._transitionData._frames) {\n gd._transitionData._frames = [];\n }\n\n if(!gd._transitionData._frameHash) {\n gd._transitionData._frameHash = {};\n }\n\n if(!gd._transitionData._counter) {\n gd._transitionData._counter = 0;\n }\n\n if(!gd._transitionData._interruptCallbacks) {\n gd._transitionData._interruptCallbacks = [];\n }\n};\n\n// helper function to be bound to fullLayout to check\n// whether a certain plot type is present on plot\n// or trace has a category\nplots._hasPlotType = function(category) {\n var i;\n\n // check base plot modules\n var basePlotModules = this._basePlotModules || [];\n for(i = 0; i < basePlotModules.length; i++) {\n if(basePlotModules[i].name === category) return true;\n }\n\n // check trace modules (including non-visible:true)\n var modules = this._modules || [];\n for(i = 0; i < modules.length; i++) {\n var name = modules[i].name;\n if(name === category) return true;\n // N.B. this is modules[i] along with 'categories' as a hash object\n var _module = Registry.modules[name];\n if(_module && _module.categories[category]) return true;\n }\n\n return false;\n};\n\nplots.cleanPlot = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var i, j;\n\n var basePlotModules = oldFullLayout._basePlotModules || [];\n for(i = 0; i < basePlotModules.length; i++) {\n var _module = basePlotModules[i];\n\n if(_module.clean) {\n _module.clean(newFullData, newFullLayout, oldFullData, oldFullLayout);\n }\n }\n\n var hadGl = oldFullLayout._has && oldFullLayout._has('gl');\n var hasGl = newFullLayout._has && newFullLayout._has('gl');\n\n if(hadGl && !hasGl) {\n if(oldFullLayout._glcontainer !== undefined) {\n oldFullLayout._glcontainer.selectAll('.gl-canvas').remove();\n oldFullLayout._glcontainer.selectAll('.no-webgl').remove();\n oldFullLayout._glcanvas = null;\n }\n }\n\n var hasInfoLayer = !!oldFullLayout._infolayer;\n\n oldLoop:\n for(i = 0; i < oldFullData.length; i++) {\n var oldTrace = oldFullData[i];\n var oldUid = oldTrace.uid;\n\n for(j = 0; j < newFullData.length; j++) {\n var newTrace = newFullData[j];\n\n if(oldUid === newTrace.uid) continue oldLoop;\n }\n\n // clean old colorbars\n if(hasInfoLayer) {\n oldFullLayout._infolayer.select('.cb' + oldUid).remove();\n }\n }\n};\n\nplots.linkSubplots = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var i, j;\n\n var oldSubplots = oldFullLayout._plots || {};\n var newSubplots = newFullLayout._plots = {};\n var newSubplotList = newFullLayout._subplots;\n\n var mockGd = {\n _fullData: newFullData,\n _fullLayout: newFullLayout\n };\n\n var ids = newSubplotList.cartesian.concat(newSubplotList.gl2d || []);\n\n for(i = 0; i < ids.length; i++) {\n var id = ids[i];\n var oldSubplot = oldSubplots[id];\n var xaxis = axisIDs.getFromId(mockGd, id, 'x');\n var yaxis = axisIDs.getFromId(mockGd, id, 'y');\n var plotinfo;\n\n // link or create subplot object\n if(oldSubplot) {\n plotinfo = newSubplots[id] = oldSubplot;\n } else {\n plotinfo = newSubplots[id] = {};\n plotinfo.id = id;\n }\n\n // add these axis ids to each others' subplot lists\n xaxis._counterAxes.push(yaxis._id);\n yaxis._counterAxes.push(xaxis._id);\n xaxis._subplotsWith.push(id);\n yaxis._subplotsWith.push(id);\n\n // update x and y axis layout object refs\n plotinfo.xaxis = xaxis;\n plotinfo.yaxis = yaxis;\n\n // By default, we clip at the subplot level,\n // but if one trace on a given subplot has *cliponaxis* set to false,\n // we need to clip at the trace module layer level;\n // find this out here, once of for all.\n plotinfo._hasClipOnAxisFalse = false;\n\n for(j = 0; j < newFullData.length; j++) {\n var trace = newFullData[j];\n\n if(\n trace.xaxis === plotinfo.xaxis._id &&\n trace.yaxis === plotinfo.yaxis._id &&\n trace.cliponaxis === false\n ) {\n plotinfo._hasClipOnAxisFalse = true;\n break;\n }\n }\n }\n\n // while we're at it, link overlaying axes to their main axes and\n // anchored axes to the axes they're anchored to\n var axList = axisIDs.list(mockGd, null, true);\n var ax;\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n var mainAx = null;\n\n if(ax.overlaying) {\n mainAx = axisIDs.getFromId(mockGd, ax.overlaying);\n\n // you cannot overlay an axis that's already overlaying another\n if(mainAx && mainAx.overlaying) {\n ax.overlaying = false;\n mainAx = null;\n }\n }\n ax._mainAxis = mainAx || ax;\n\n /*\n * For now force overlays to overlay completely... so they\n * can drag together correctly and share backgrounds.\n * Later perhaps we make separate axis domain and\n * tick/line domain or something, so they can still share\n * the (possibly larger) dragger and background but don't\n * have to both be drawn over that whole domain\n */\n if(mainAx) ax.domain = mainAx.domain.slice();\n\n ax._anchorAxis = ax.anchor === 'free' ?\n null :\n axisIDs.getFromId(mockGd, ax.anchor);\n }\n\n // finally, we can find the main subplot for each axis\n // (on which the ticks & labels are drawn)\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n ax._counterAxes.sort(axisIDs.idSort);\n ax._subplotsWith.sort(Lib.subplotSort);\n ax._mainSubplot = findMainSubplot(ax, newFullLayout);\n\n // find \"full\" domain span of counter axes,\n // this loop can be costly, so only compute it when required\n if(ax._counterAxes.length && (\n (ax.spikemode && ax.spikemode.indexOf('across') !== -1) ||\n (ax.automargin && ax.mirror && ax.anchor !== 'free') ||\n Registry.getComponentMethod('rangeslider', 'isVisible')(ax)\n )) {\n var min = 1;\n var max = 0;\n for(j = 0; j < ax._counterAxes.length; j++) {\n var ax2 = axisIDs.getFromId(mockGd, ax._counterAxes[j]);\n min = Math.min(min, ax2.domain[0]);\n max = Math.max(max, ax2.domain[1]);\n }\n if(min < max) {\n ax._counterDomainMin = min;\n ax._counterDomainMax = max;\n }\n }\n }\n};\n\nfunction findMainSubplot(ax, fullLayout) {\n var mockGd = {_fullLayout: fullLayout};\n\n var isX = ax._id.charAt(0) === 'x';\n var anchorAx = ax._mainAxis._anchorAxis;\n var mainSubplotID = '';\n var nextBestMainSubplotID = '';\n var anchorID = '';\n\n // First try the main ID with the anchor\n if(anchorAx) {\n anchorID = anchorAx._mainAxis._id;\n mainSubplotID = isX ? (ax._id + anchorID) : (anchorID + ax._id);\n }\n\n // Then look for a subplot with the counteraxis overlaying the anchor\n // If that fails just use the first subplot including this axis\n if(!mainSubplotID || !fullLayout._plots[mainSubplotID]) {\n mainSubplotID = '';\n\n var counterIDs = ax._counterAxes;\n for(var j = 0; j < counterIDs.length; j++) {\n var counterPart = counterIDs[j];\n var id = isX ? (ax._id + counterPart) : (counterPart + ax._id);\n if(!nextBestMainSubplotID) nextBestMainSubplotID = id;\n var counterAx = axisIDs.getFromId(mockGd, counterPart);\n if(anchorID && counterAx.overlaying === anchorID) {\n mainSubplotID = id;\n break;\n }\n }\n }\n\n return mainSubplotID || nextBestMainSubplotID;\n}\n\n// This function clears any trace attributes with valType: color and\n// no set dflt filed in the plot schema. This is needed because groupby (which\n// is the only transform for which this currently applies) supplies parent\n// trace defaults, then expanded trace defaults. The result is that `null`\n// colors are default-supplied and inherited as a color instead of a null.\n// The result is that expanded trace default colors have no effect, with\n// the final result that groups are indistinguishable. This function clears\n// those colors so that individual groupby groups get unique colors.\nplots.clearExpandedTraceDefaultColors = function(trace) {\n var colorAttrs, path, i;\n\n // This uses weird closure state in order to satisfy the linter rule\n // that we can't create functions in a loop.\n function locateColorAttrs(attr, attrName, attrs, level) {\n path[level] = attrName;\n path.length = level + 1;\n if(attr.valType === 'color' && attr.dflt === undefined) {\n colorAttrs.push(path.join('.'));\n }\n }\n\n path = [];\n\n // Get the cached colorAttrs:\n colorAttrs = trace._module._colorAttrs;\n\n // Or else compute and cache the colorAttrs on the module:\n if(!colorAttrs) {\n trace._module._colorAttrs = colorAttrs = [];\n PlotSchema.crawl(\n trace._module.attributes,\n locateColorAttrs\n );\n }\n\n for(i = 0; i < colorAttrs.length; i++) {\n var origprop = Lib.nestedProperty(trace, '_input.' + colorAttrs[i]);\n\n if(!origprop.get()) {\n Lib.nestedProperty(trace, colorAttrs[i]).set(null);\n }\n }\n};\n\n\nplots.supplyDataDefaults = function(dataIn, dataOut, layout, fullLayout) {\n var modules = fullLayout._modules;\n var visibleModules = fullLayout._visibleModules;\n var basePlotModules = fullLayout._basePlotModules;\n var cnt = 0;\n var colorCnt = 0;\n\n var i, fullTrace, trace;\n\n fullLayout._transformModules = [];\n\n function pushModule(fullTrace) {\n dataOut.push(fullTrace);\n\n var _module = fullTrace._module;\n if(!_module) return;\n\n Lib.pushUnique(modules, _module);\n if(fullTrace.visible === true) Lib.pushUnique(visibleModules, _module);\n Lib.pushUnique(basePlotModules, fullTrace._module.basePlotModule);\n cnt++;\n\n // TODO: do we really want color not to increment for explicitly invisible traces?\n // This logic is weird, but matches previous behavior: traces that you explicitly\n // set to visible:false do not increment the color, but traces WE determine to be\n // empty or invalid (and thus set to visible:false) DO increment color.\n // I kind of think we should just let all traces increment color, visible or not.\n // see mock: axes-autotype-empty vs. a test of restyling visible: false that\n // I can't find right now...\n if(fullTrace._input.visible !== false) colorCnt++;\n }\n\n var carpetIndex = {};\n var carpetDependents = [];\n var dataTemplate = (layout.template || {}).data || {};\n var templater = Template.traceTemplater(dataTemplate);\n\n for(i = 0; i < dataIn.length; i++) {\n trace = dataIn[i];\n\n // reuse uid we may have pulled out of oldFullData\n // Note: templater supplies trace type\n fullTrace = templater.newTrace(trace);\n fullTrace.uid = fullLayout._traceUids[i];\n plots.supplyTraceDefaults(trace, fullTrace, colorCnt, fullLayout, i);\n\n fullTrace.index = i;\n fullTrace._input = trace;\n fullTrace._expandedIndex = cnt;\n\n if(fullTrace.transforms && fullTrace.transforms.length) {\n var sdInvisible = trace.visible !== false && fullTrace.visible === false;\n\n var expandedTraces = applyTransforms(fullTrace, dataOut, layout, fullLayout);\n\n for(var j = 0; j < expandedTraces.length; j++) {\n var expandedTrace = expandedTraces[j];\n\n // No further templating during transforms.\n var fullExpandedTrace = {\n _template: fullTrace._template,\n type: fullTrace.type,\n // set uid using parent uid and expanded index\n // to promote consistency between update calls\n uid: fullTrace.uid + j\n };\n\n // If the first supplyDefaults created `visible: false`,\n // clear it before running supplyDefaults a second time,\n // because sometimes there are items we still want to coerce\n // inside trace modules before determining that the trace is\n // again `visible: false`, for example partial visibilities\n // in `splom` traces.\n if(sdInvisible && expandedTrace.visible === false) {\n delete expandedTrace.visible;\n }\n\n plots.supplyTraceDefaults(expandedTrace, fullExpandedTrace, cnt, fullLayout, i);\n\n // relink private (i.e. underscore) keys expanded trace to full expanded trace so\n // that transform supply-default methods can set _ keys for future use.\n relinkPrivateKeys(fullExpandedTrace, expandedTrace);\n\n // add info about parent data trace\n fullExpandedTrace.index = i;\n fullExpandedTrace._input = trace;\n fullExpandedTrace._fullInput = fullTrace;\n\n // add info about the expanded data\n fullExpandedTrace._expandedIndex = cnt;\n fullExpandedTrace._expandedInput = expandedTrace;\n\n pushModule(fullExpandedTrace);\n }\n } else {\n // add identify refs for consistency with transformed traces\n fullTrace._fullInput = fullTrace;\n fullTrace._expandedInput = fullTrace;\n\n pushModule(fullTrace);\n }\n\n if(Registry.traceIs(fullTrace, 'carpetAxis')) {\n carpetIndex[fullTrace.carpet] = fullTrace;\n }\n\n if(Registry.traceIs(fullTrace, 'carpetDependent')) {\n carpetDependents.push(i);\n }\n }\n\n for(i = 0; i < carpetDependents.length; i++) {\n fullTrace = dataOut[carpetDependents[i]];\n\n if(!fullTrace.visible) continue;\n\n var carpetAxis = carpetIndex[fullTrace.carpet];\n fullTrace._carpet = carpetAxis;\n\n if(!carpetAxis || !carpetAxis.visible) {\n fullTrace.visible = false;\n continue;\n }\n\n fullTrace.xaxis = carpetAxis.xaxis;\n fullTrace.yaxis = carpetAxis.yaxis;\n }\n};\n\nplots.supplyAnimationDefaults = function(opts) {\n opts = opts || {};\n var i;\n var optsOut = {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(opts || {}, optsOut, animationAttrs, attr, dflt);\n }\n\n coerce('mode');\n coerce('direction');\n coerce('fromcurrent');\n\n if(Array.isArray(opts.frame)) {\n optsOut.frame = [];\n for(i = 0; i < opts.frame.length; i++) {\n optsOut.frame[i] = plots.supplyAnimationFrameDefaults(opts.frame[i] || {});\n }\n } else {\n optsOut.frame = plots.supplyAnimationFrameDefaults(opts.frame || {});\n }\n\n if(Array.isArray(opts.transition)) {\n optsOut.transition = [];\n for(i = 0; i < opts.transition.length; i++) {\n optsOut.transition[i] = plots.supplyAnimationTransitionDefaults(opts.transition[i] || {});\n }\n } else {\n optsOut.transition = plots.supplyAnimationTransitionDefaults(opts.transition || {});\n }\n\n return optsOut;\n};\n\nplots.supplyAnimationFrameDefaults = function(opts) {\n var optsOut = {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(opts || {}, optsOut, animationAttrs.frame, attr, dflt);\n }\n\n coerce('duration');\n coerce('redraw');\n\n return optsOut;\n};\n\nplots.supplyAnimationTransitionDefaults = function(opts) {\n var optsOut = {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(opts || {}, optsOut, animationAttrs.transition, attr, dflt);\n }\n\n coerce('duration');\n coerce('easing');\n\n return optsOut;\n};\n\nplots.supplyFrameDefaults = function(frameIn) {\n var frameOut = {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(frameIn, frameOut, frameAttrs, attr, dflt);\n }\n\n coerce('group');\n coerce('name');\n coerce('traces');\n coerce('baseframe');\n coerce('data');\n coerce('layout');\n\n return frameOut;\n};\n\nplots.supplyTraceDefaults = function(traceIn, traceOut, colorIndex, layout, traceInIndex) {\n var colorway = layout.colorway || Color.defaults;\n var defaultColor = colorway[colorIndex % colorway.length];\n\n var i;\n\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, plots.attributes, attr, dflt);\n }\n\n var visible = coerce('visible');\n\n coerce('type');\n coerce('name', layout._traceWord + ' ' + traceInIndex);\n\n coerce('uirevision', layout.uirevision);\n\n // we want even invisible traces to make their would-be subplots visible\n // so coerce the subplot id(s) now no matter what\n var _module = plots.getModule(traceOut);\n\n traceOut._module = _module;\n if(_module) {\n var basePlotModule = _module.basePlotModule;\n var subplotAttr = basePlotModule.attr;\n var subplotAttrs = basePlotModule.attributes;\n if(subplotAttr && subplotAttrs) {\n var subplots = layout._subplots;\n var subplotId = '';\n\n if(\n visible ||\n basePlotModule.name !== 'gl2d' // for now just drop empty gl2d subplots\n // TODO - currently if we draw an empty gl2d subplot, it draws\n // nothing then gets stuck and you can't get it back without newPlot\n // sort this out in the regl refactor?\n ) {\n if(Array.isArray(subplotAttr)) {\n for(i = 0; i < subplotAttr.length; i++) {\n var attri = subplotAttr[i];\n var vali = Lib.coerce(traceIn, traceOut, subplotAttrs, attri);\n\n if(subplots[attri]) Lib.pushUnique(subplots[attri], vali);\n subplotId += vali;\n }\n } else {\n subplotId = Lib.coerce(traceIn, traceOut, subplotAttrs, subplotAttr);\n }\n\n if(subplots[basePlotModule.name]) {\n Lib.pushUnique(subplots[basePlotModule.name], subplotId);\n }\n }\n }\n }\n\n if(visible) {\n coerce('customdata');\n coerce('ids');\n coerce('meta');\n\n if(Registry.traceIs(traceOut, 'showLegend')) {\n Lib.coerce(traceIn, traceOut,\n _module.attributes.showlegend ? _module.attributes : plots.attributes,\n 'showlegend'\n );\n\n coerce('legend');\n coerce('legendwidth');\n coerce('legendgroup');\n coerce('legendgrouptitle.text');\n coerce('legendrank');\n\n traceOut._dfltShowLegend = true;\n } else {\n traceOut._dfltShowLegend = false;\n }\n\n if(_module) {\n _module.supplyDefaults(traceIn, traceOut, defaultColor, layout);\n }\n\n if(!Registry.traceIs(traceOut, 'noOpacity')) {\n coerce('opacity');\n }\n\n if(Registry.traceIs(traceOut, 'notLegendIsolatable')) {\n // This clears out the legendonly state for traces like carpet that\n // cannot be isolated in the legend\n traceOut.visible = !!traceOut.visible;\n }\n\n if(!Registry.traceIs(traceOut, 'noHover')) {\n if(!traceOut.hovertemplate) Lib.coerceHoverinfo(traceIn, traceOut, layout);\n\n // parcats support hover, but not hoverlabel stylings (yet)\n if(traceOut.type !== 'parcats') {\n Registry.getComponentMethod('fx', 'supplyDefaults')(traceIn, traceOut, defaultColor, layout);\n }\n }\n\n if(_module && _module.selectPoints) {\n var selectedpoints = coerce('selectedpoints');\n if(Lib.isTypedArray(selectedpoints)) {\n traceOut.selectedpoints = Array.from(selectedpoints);\n }\n }\n\n plots.supplyTransformDefaults(traceIn, traceOut, layout);\n }\n\n return traceOut;\n};\n\n/**\n * hasMakesDataTransform: does this trace have a transform that makes its own\n * data, either by grabbing it from somewhere else or by creating it from input\n * parameters? If so, we should still keep going with supplyDefaults\n * even if the trace is invisible, which may just be because it has no data yet.\n */\nfunction hasMakesDataTransform(trace) {\n var transforms = trace.transforms;\n if(Array.isArray(transforms) && transforms.length) {\n for(var i = 0; i < transforms.length; i++) {\n var ti = transforms[i];\n var _module = ti._module || transformsRegistry[ti.type];\n if(_module && _module.makesData) return true;\n }\n }\n return false;\n}\n\nplots.hasMakesDataTransform = hasMakesDataTransform;\n\nplots.supplyTransformDefaults = function(traceIn, traceOut, layout) {\n // For now we only allow transforms on 1D traces, ie those that specify a _length.\n // If we were to implement 2D transforms, we'd need to have each transform\n // describe its own applicability and disable itself when it doesn't apply.\n // Also allow transforms that make their own data, but not in globalTransforms\n if(!(traceOut._length || hasMakesDataTransform(traceIn))) return;\n\n var globalTransforms = layout._globalTransforms || [];\n var transformModules = layout._transformModules || [];\n\n if(!Array.isArray(traceIn.transforms) && globalTransforms.length === 0) return;\n\n var containerIn = traceIn.transforms || [];\n var transformList = globalTransforms.concat(containerIn);\n var containerOut = traceOut.transforms = [];\n\n for(var i = 0; i < transformList.length; i++) {\n var transformIn = transformList[i];\n var type = transformIn.type;\n var _module = transformsRegistry[type];\n var transformOut;\n\n /*\n * Supply defaults may run twice. First pass runs all supply defaults steps\n * and adds the _module to any output transforms.\n * If transforms exist another pass is run so that any generated traces also\n * go through supply defaults. This has the effect of rerunning\n * supplyTransformDefaults. If the transform does not have a `transform`\n * function it could not have generated any new traces and the second stage\n * is unnecessary. We detect this case with the following variables.\n */\n var isFirstStage = !(transformIn._module && transformIn._module === _module);\n var doLaterStages = _module && typeof _module.transform === 'function';\n\n if(!_module) Lib.warn('Unrecognized transform type ' + type + '.');\n\n if(_module && _module.supplyDefaults && (isFirstStage || doLaterStages)) {\n transformOut = _module.supplyDefaults(transformIn, traceOut, layout, traceIn);\n transformOut.type = type;\n transformOut._module = _module;\n\n Lib.pushUnique(transformModules, _module);\n } else {\n transformOut = Lib.extendFlat({}, transformIn);\n }\n\n containerOut.push(transformOut);\n }\n};\n\nfunction applyTransforms(fullTrace, fullData, layout, fullLayout) {\n var container = fullTrace.transforms;\n var dataOut = [fullTrace];\n\n for(var i = 0; i < container.length; i++) {\n var transform = container[i];\n var _module = transformsRegistry[transform.type];\n\n if(_module && _module.transform) {\n dataOut = _module.transform(dataOut, {\n transform: transform,\n fullTrace: fullTrace,\n fullData: fullData,\n layout: layout,\n fullLayout: fullLayout,\n transformIndex: i\n });\n }\n }\n\n return dataOut;\n}\n\nplots.supplyLayoutGlobalDefaults = function(layoutIn, layoutOut, formatObj) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, plots.layoutAttributes, attr, dflt);\n }\n\n var template = layoutIn.template;\n if(Lib.isPlainObject(template)) {\n layoutOut.template = template;\n layoutOut._template = template.layout;\n layoutOut._dataTemplate = template.data;\n }\n\n coerce('autotypenumbers');\n\n var font = Lib.coerceFont(coerce, 'font');\n var fontSize = font.size;\n\n Lib.coerceFont(coerce, 'title.font', font, { overrideDflt: {\n size: Math.round(fontSize * 1.4)\n }});\n\n coerce('title.text', layoutOut._dfltTitle.plot);\n coerce('title.xref');\n var titleYref = coerce('title.yref');\n coerce('title.pad.t');\n coerce('title.pad.r');\n coerce('title.pad.b');\n coerce('title.pad.l');\n var titleAutomargin = coerce('title.automargin');\n\n coerce('title.x');\n coerce('title.xanchor');\n coerce('title.y');\n coerce('title.yanchor');\n\n coerce('title.subtitle.text', layoutOut._dfltTitle.subtitle);\n Lib.coerceFont(coerce, 'title.subtitle.font', font, {\n overrideDflt: {\n size: Math.round(layoutOut.title.font.size * 0.7)\n }\n });\n\n if(titleAutomargin) {\n // when automargin=true\n // title.y is 1 or 0 if paper ref\n // 'auto' is not supported for either title.y or title.yanchor\n\n // TODO: mention this smart default in the title.y and title.yanchor descriptions\n\n if(titleYref === 'paper') {\n if(layoutOut.title.y !== 0) layoutOut.title.y = 1;\n\n if(layoutOut.title.yanchor === 'auto') {\n layoutOut.title.yanchor = layoutOut.title.y === 0 ? 'top' : 'bottom';\n }\n }\n\n if(titleYref === 'container') {\n if(layoutOut.title.y === 'auto') layoutOut.title.y = 1;\n\n if(layoutOut.title.yanchor === 'auto') {\n layoutOut.title.yanchor = layoutOut.title.y < 0.5 ? 'bottom' : 'top';\n }\n }\n }\n\n var uniformtextMode = coerce('uniformtext.mode');\n if(uniformtextMode) {\n coerce('uniformtext.minsize');\n }\n\n // Make sure that autosize is defaulted to *true*\n // on layouts with no set width and height for backward compatibly,\n // in particular https://plotly.com/javascript/responsive-fluid-layout/\n //\n // Before https://github.com/plotly/plotly.js/pull/635 ,\n // layouts with no set width and height were set temporary set to 'initial'\n // to pass through the autosize routine\n //\n // This behavior is subject to change in v3.\n coerce('autosize', !(layoutIn.width && layoutIn.height));\n\n coerce('width');\n coerce('height');\n coerce('minreducedwidth');\n coerce('minreducedheight');\n\n coerce('margin.l');\n coerce('margin.r');\n coerce('margin.t');\n coerce('margin.b');\n coerce('margin.pad');\n coerce('margin.autoexpand');\n\n if(layoutIn.width && layoutIn.height) plots.sanitizeMargins(layoutOut);\n\n Registry.getComponentMethod('grid', 'sizeDefaults')(layoutIn, layoutOut);\n\n coerce('paper_bgcolor');\n\n coerce('separators', formatObj.decimal + formatObj.thousands);\n coerce('hidesources');\n\n coerce('colorway');\n\n coerce('datarevision');\n var uirevision = coerce('uirevision');\n coerce('editrevision', uirevision);\n coerce('selectionrevision', uirevision);\n\n Registry.getComponentMethod(\n 'modebar',\n 'supplyLayoutDefaults'\n )(layoutIn, layoutOut);\n\n Registry.getComponentMethod(\n 'shapes',\n 'supplyDrawNewShapeDefaults'\n )(layoutIn, layoutOut, coerce);\n\n Registry.getComponentMethod(\n 'selections',\n 'supplyDrawNewSelectionDefaults'\n )(layoutIn, layoutOut, coerce);\n\n coerce('meta');\n\n // do not include defaults in fullLayout when users do not set transition\n if(Lib.isPlainObject(layoutIn.transition)) {\n coerce('transition.duration');\n coerce('transition.easing');\n coerce('transition.ordering');\n }\n\n Registry.getComponentMethod(\n 'calendars',\n 'handleDefaults'\n )(layoutIn, layoutOut, 'calendar');\n\n Registry.getComponentMethod(\n 'fx',\n 'supplyLayoutGlobalDefaults'\n )(layoutIn, layoutOut, coerce);\n\n Lib.coerce(layoutIn, layoutOut, scatterAttrs, 'scattermode');\n};\n\nfunction getComputedSize(attr) {\n return (\n (typeof attr === 'string') &&\n (attr.substr(attr.length - 2) === 'px') &&\n parseFloat(attr)\n );\n}\n\n\nplots.plotAutoSize = function plotAutoSize(gd, layout, fullLayout) {\n var context = gd._context || {};\n var frameMargins = context.frameMargins;\n var newWidth;\n var newHeight;\n\n var isPlotDiv = Lib.isPlotDiv(gd);\n\n if(isPlotDiv) gd.emit('plotly_autosize');\n\n // embedded in an iframe - just take the full iframe size\n // if we get to this point, with no aspect ratio restrictions\n if(context.fillFrame) {\n newWidth = window.innerWidth;\n newHeight = window.innerHeight;\n\n // somehow we get a few extra px height sometimes...\n // just hide it\n document.body.style.overflow = 'hidden';\n } else {\n // plotly.js - let the developers do what they want, either\n // provide height and width for the container div,\n // specify size in layout, or take the defaults,\n // but don't enforce any ratio restrictions\n var computedStyle = isPlotDiv ? window.getComputedStyle(gd) : {};\n\n newWidth = getComputedSize(computedStyle.width) || getComputedSize(computedStyle.maxWidth) || fullLayout.width;\n newHeight = getComputedSize(computedStyle.height) || getComputedSize(computedStyle.maxHeight) || fullLayout.height;\n\n if(isNumeric(frameMargins) && frameMargins > 0) {\n var factor = 1 - 2 * frameMargins;\n newWidth = Math.round(factor * newWidth);\n newHeight = Math.round(factor * newHeight);\n }\n }\n\n var minWidth = plots.layoutAttributes.width.min;\n var minHeight = plots.layoutAttributes.height.min;\n if(newWidth < minWidth) newWidth = minWidth;\n if(newHeight < minHeight) newHeight = minHeight;\n\n var widthHasChanged = !layout.width &&\n (Math.abs(fullLayout.width - newWidth) > 1);\n var heightHasChanged = !layout.height &&\n (Math.abs(fullLayout.height - newHeight) > 1);\n\n if(heightHasChanged || widthHasChanged) {\n if(widthHasChanged) fullLayout.width = newWidth;\n if(heightHasChanged) fullLayout.height = newHeight;\n }\n\n // cache initial autosize value, used in relayout when\n // width or height values are set to null\n if(!gd._initialAutoSize) {\n gd._initialAutoSize = { width: newWidth, height: newHeight };\n }\n\n plots.sanitizeMargins(fullLayout);\n};\n\nplots.supplyLayoutModuleDefaults = function(layoutIn, layoutOut, fullData, transitionData) {\n var componentsRegistry = Registry.componentsRegistry;\n var basePlotModules = layoutOut._basePlotModules;\n var component, i, _module;\n\n var Cartesian = Registry.subplotsRegistry.cartesian;\n\n // check if any components need to add more base plot modules\n // that weren't captured by traces\n for(component in componentsRegistry) {\n _module = componentsRegistry[component];\n\n if(_module.includeBasePlot) {\n _module.includeBasePlot(layoutIn, layoutOut);\n }\n }\n\n // make sure we *at least* have some cartesian axes\n if(!basePlotModules.length) {\n basePlotModules.push(Cartesian);\n }\n\n // ensure all cartesian axes have at least one subplot\n if(layoutOut._has('cartesian')) {\n Registry.getComponentMethod('grid', 'contentDefaults')(layoutIn, layoutOut);\n Cartesian.finalizeSubplots(layoutIn, layoutOut);\n }\n\n // sort subplot lists\n for(var subplotType in layoutOut._subplots) {\n layoutOut._subplots[subplotType].sort(Lib.subplotSort);\n }\n\n // base plot module layout defaults\n for(i = 0; i < basePlotModules.length; i++) {\n _module = basePlotModules[i];\n\n // e.g. pie does not have a layout-defaults step\n if(_module.supplyLayoutDefaults) {\n _module.supplyLayoutDefaults(layoutIn, layoutOut, fullData);\n }\n }\n\n // trace module layout defaults\n // use _modules rather than _visibleModules so that even\n // legendonly traces can include settings - eg barmode, which affects\n // legend.traceorder default value.\n var modules = layoutOut._modules;\n for(i = 0; i < modules.length; i++) {\n _module = modules[i];\n\n if(_module.supplyLayoutDefaults) {\n _module.supplyLayoutDefaults(layoutIn, layoutOut, fullData);\n }\n }\n\n // transform module layout defaults\n var transformModules = layoutOut._transformModules;\n for(i = 0; i < transformModules.length; i++) {\n _module = transformModules[i];\n\n if(_module.supplyLayoutDefaults) {\n _module.supplyLayoutDefaults(layoutIn, layoutOut, fullData, transitionData);\n }\n }\n\n for(component in componentsRegistry) {\n _module = componentsRegistry[component];\n\n if(_module.supplyLayoutDefaults) {\n _module.supplyLayoutDefaults(layoutIn, layoutOut, fullData);\n }\n }\n};\n\n// Remove all plotly attributes from a div so it can be replotted fresh\n// TODO: these really need to be encapsulated into a much smaller set...\nplots.purge = function(gd) {\n // note: we DO NOT remove _context because it doesn't change when we insert\n // a new plot, and may have been set outside of our scope.\n\n var fullLayout = gd._fullLayout || {};\n if(fullLayout._glcontainer !== undefined) {\n fullLayout._glcontainer.selectAll('.gl-canvas').remove();\n fullLayout._glcontainer.remove();\n fullLayout._glcanvas = null;\n }\n\n // remove modebar\n if(fullLayout._modeBar) fullLayout._modeBar.destroy();\n\n if(gd._transitionData) {\n // Ensure any dangling callbacks are simply dropped if the plot is purged.\n // This is more or less only actually important for testing.\n if(gd._transitionData._interruptCallbacks) {\n gd._transitionData._interruptCallbacks.length = 0;\n }\n\n if(gd._transitionData._animationRaf) {\n window.cancelAnimationFrame(gd._transitionData._animationRaf);\n }\n }\n\n // remove any planned throttles\n Lib.clearThrottle();\n\n // remove responsive handler\n Lib.clearResponsive(gd);\n\n // data and layout\n delete gd.data;\n delete gd.layout;\n delete gd._fullData;\n delete gd._fullLayout;\n delete gd.calcdata;\n delete gd.empty;\n\n delete gd.fid;\n\n delete gd.undoqueue; // action queue\n delete gd.undonum;\n delete gd.autoplay; // are we doing an action that doesn't go in undo queue?\n delete gd.changed;\n\n // these get recreated on _doPlot anyway, but just to be safe\n // (and to have a record of them...)\n delete gd._promises;\n delete gd._redrawTimer;\n delete gd._hmlumcount;\n delete gd._hmpixcount;\n delete gd._transitionData;\n delete gd._transitioning;\n delete gd._initialAutoSize;\n delete gd._transitioningWithDuration;\n\n // created during certain events, that *should* clean them up\n // themselves, but may not if there was an error\n delete gd._dragging;\n delete gd._dragged;\n delete gd._dragdata;\n delete gd._hoverdata;\n delete gd._snapshotInProgress;\n delete gd._editing;\n delete gd._mouseDownTime;\n delete gd._legendMouseDownTime;\n\n // remove all event listeners\n if(gd.removeAllListeners) gd.removeAllListeners();\n};\n\nplots.style = function(gd) {\n var _modules = gd._fullLayout._visibleModules;\n var styleModules = [];\n var i;\n\n // some trace modules reuse the same style method,\n // make sure to not unnecessary call them multiple times.\n\n for(i = 0; i < _modules.length; i++) {\n var _module = _modules[i];\n if(_module.style) {\n Lib.pushUnique(styleModules, _module.style);\n }\n }\n\n for(i = 0; i < styleModules.length; i++) {\n styleModules[i](gd);\n }\n};\n\nplots.sanitizeMargins = function(fullLayout) {\n // polar doesn't do margins...\n if(!fullLayout || !fullLayout.margin) return;\n\n var width = fullLayout.width;\n var height = fullLayout.height;\n var margin = fullLayout.margin;\n var plotWidth = width - (margin.l + margin.r);\n var plotHeight = height - (margin.t + margin.b);\n var correction;\n\n // if margin.l + margin.r = 0 then plotWidth > 0\n // as width >= 10 by supplyDefaults\n // similarly for margin.t + margin.b\n\n if(plotWidth < 0) {\n correction = (width - 1) / (margin.l + margin.r);\n margin.l = Math.floor(correction * margin.l);\n margin.r = Math.floor(correction * margin.r);\n }\n\n if(plotHeight < 0) {\n correction = (height - 1) / (margin.t + margin.b);\n margin.t = Math.floor(correction * margin.t);\n margin.b = Math.floor(correction * margin.b);\n }\n};\n\nplots.clearAutoMarginIds = function(gd) {\n gd._fullLayout._pushmarginIds = {};\n};\n\nplots.allowAutoMargin = function(gd, id) {\n gd._fullLayout._pushmarginIds[id] = 1;\n};\n\nfunction initMargins(fullLayout) {\n var margin = fullLayout.margin;\n\n if(!fullLayout._size) {\n var gs = fullLayout._size = {\n l: Math.round(margin.l),\n r: Math.round(margin.r),\n t: Math.round(margin.t),\n b: Math.round(margin.b),\n p: Math.round(margin.pad)\n };\n gs.w = Math.round(fullLayout.width) - gs.l - gs.r;\n gs.h = Math.round(fullLayout.height) - gs.t - gs.b;\n }\n if(!fullLayout._pushmargin) fullLayout._pushmargin = {};\n if(!fullLayout._pushmarginIds) fullLayout._pushmarginIds = {};\n if(!fullLayout._reservedMargin) fullLayout._reservedMargin = {};\n}\n\n// non-negotiable - this is the smallest height we will allow users to specify via explicit margins\nvar MIN_SPECIFIED_WIDTH = 2;\nvar MIN_SPECIFIED_HEIGHT = 2;\n\n/**\n * autoMargin: called by components that may need to expand the margins to\n * be rendered on-plot.\n *\n * @param {DOM element} gd\n * @param {string} id - an identifier unique (within this plot) to this object,\n * so we can remove a previous margin expansion from the same object.\n * @param {object} o - the margin requirements of this object, or omit to delete\n * this entry (like if it's hidden). Keys are:\n * x, y: plot fraction of the anchor point.\n * xl, xr, yt, yb: if the object has an extent defined in plot fraction,\n * you can specify both edges as plot fractions in each dimension\n * l, r, t, b: the pixels to pad past the plot fraction x[l|r] and y[t|b]\n * pad: extra pixels to add in all directions, default 12 (why?)\n */\nplots.autoMargin = function(gd, id, o) {\n var fullLayout = gd._fullLayout;\n var width = fullLayout.width;\n var height = fullLayout.height;\n var margin = fullLayout.margin;\n var minreducedwidth = fullLayout.minreducedwidth;\n var minreducedheight = fullLayout.minreducedheight;\n\n var minFinalWidth = Lib.constrain(\n width - margin.l - margin.r,\n MIN_SPECIFIED_WIDTH,\n minreducedwidth\n );\n\n var minFinalHeight = Lib.constrain(\n height - margin.t - margin.b,\n MIN_SPECIFIED_HEIGHT,\n minreducedheight\n );\n\n var maxSpaceW = Math.max(0, width - minFinalWidth);\n var maxSpaceH = Math.max(0, height - minFinalHeight);\n\n var pushMargin = fullLayout._pushmargin;\n var pushMarginIds = fullLayout._pushmarginIds;\n\n if(margin.autoexpand !== false) {\n if(!o) {\n delete pushMargin[id];\n delete pushMarginIds[id];\n } else {\n var pad = o.pad;\n if(pad === undefined) {\n // if no explicit pad is given, use 12px unless there's a\n // specified margin that's smaller than that\n pad = Math.min(12, margin.l, margin.r, margin.t, margin.b);\n }\n\n // if the item is too big, just give it enough automargin to\n // make sure you can still grab it and bring it back\n if(maxSpaceW) {\n var rW = (o.l + o.r) / maxSpaceW;\n if(rW > 1) {\n o.l /= rW;\n o.r /= rW;\n }\n }\n if(maxSpaceH) {\n var rH = (o.t + o.b) / maxSpaceH;\n if(rH > 1) {\n o.t /= rH;\n o.b /= rH;\n }\n }\n\n var xl = o.xl !== undefined ? o.xl : o.x;\n var xr = o.xr !== undefined ? o.xr : o.x;\n var yt = o.yt !== undefined ? o.yt : o.y;\n var yb = o.yb !== undefined ? o.yb : o.y;\n\n pushMargin[id] = {\n l: {val: xl, size: o.l + pad},\n r: {val: xr, size: o.r + pad},\n b: {val: yb, size: o.b + pad},\n t: {val: yt, size: o.t + pad}\n };\n pushMarginIds[id] = 1;\n }\n\n if(!fullLayout._replotting) {\n return plots.doAutoMargin(gd);\n }\n }\n};\n\nfunction needsRedrawForShift(gd) {\n if('_redrawFromAutoMarginCount' in gd._fullLayout) {\n return false;\n }\n var axList = axisIDs.list(gd, '', true);\n for(var ax in axList) {\n if(axList[ax].autoshift || axList[ax].shift) return true;\n }\n return false;\n}\n\nplots.doAutoMargin = function(gd) {\n var fullLayout = gd._fullLayout;\n var width = fullLayout.width;\n var height = fullLayout.height;\n\n if(!fullLayout._size) fullLayout._size = {};\n initMargins(fullLayout);\n\n var gs = fullLayout._size;\n var margin = fullLayout.margin;\n var reservedMargins = {t: 0, b: 0, l: 0, r: 0};\n var oldMargins = Lib.extendFlat({}, gs);\n\n // adjust margins for outside components\n // fullLayout.margin is the requested margin,\n // fullLayout._size has margins and plotsize after adjustment\n var ml = margin.l;\n var mr = margin.r;\n var mt = margin.t;\n var mb = margin.b;\n var pushMargin = fullLayout._pushmargin;\n var pushMarginIds = fullLayout._pushmarginIds;\n var minreducedwidth = fullLayout.minreducedwidth;\n var minreducedheight = fullLayout.minreducedheight;\n\n if(margin.autoexpand !== false) {\n for(var k in pushMargin) {\n if(!pushMarginIds[k]) delete pushMargin[k];\n }\n\n var margins = gd._fullLayout._reservedMargin;\n for(var key in margins) {\n for(var side in margins[key]) {\n var val = margins[key][side];\n reservedMargins[side] = Math.max(reservedMargins[side], val);\n }\n }\n // fill in the requested margins\n pushMargin.base = {\n l: {val: 0, size: ml},\n r: {val: 1, size: mr},\n t: {val: 1, size: mt},\n b: {val: 0, size: mb}\n };\n\n\n // make sure that the reservedMargin is the minimum needed\n for(var s in reservedMargins) {\n var autoMarginPush = 0;\n for(var m in pushMargin) {\n if(m !== 'base') {\n if(isNumeric(pushMargin[m][s].size)) {\n autoMarginPush = pushMargin[m][s].size > autoMarginPush ? pushMargin[m][s].size : autoMarginPush;\n }\n }\n }\n var extraMargin = Math.max(0, (margin[s] - autoMarginPush));\n reservedMargins[s] = Math.max(0, reservedMargins[s] - extraMargin);\n }\n\n // now cycle through all the combinations of l and r\n // (and t and b) to find the required margins\n for(var k1 in pushMargin) {\n var pushleft = pushMargin[k1].l || {};\n var pushbottom = pushMargin[k1].b || {};\n var fl = pushleft.val;\n var pl = pushleft.size;\n var fb = pushbottom.val;\n var pb = pushbottom.size;\n var availableWidth = width - reservedMargins.r - reservedMargins.l;\n var availableHeight = height - reservedMargins.t - reservedMargins.b;\n\n for(var k2 in pushMargin) {\n if(isNumeric(pl) && pushMargin[k2].r) {\n var fr = pushMargin[k2].r.val;\n var pr = pushMargin[k2].r.size;\n if(fr > fl) {\n var newL = (pl * fr + (pr - availableWidth) * fl) / (fr - fl);\n var newR = (pr * (1 - fl) + (pl - availableWidth) * (1 - fr)) / (fr - fl);\n if(newL + newR > ml + mr) {\n ml = newL;\n mr = newR;\n }\n }\n }\n\n if(isNumeric(pb) && pushMargin[k2].t) {\n var ft = pushMargin[k2].t.val;\n var pt = pushMargin[k2].t.size;\n if(ft > fb) {\n var newB = (pb * ft + (pt - availableHeight) * fb) / (ft - fb);\n var newT = (pt * (1 - fb) + (pb - availableHeight) * (1 - ft)) / (ft - fb);\n if(newB + newT > mb + mt) {\n mb = newB;\n mt = newT;\n }\n }\n }\n }\n }\n }\n\n var minFinalWidth = Lib.constrain(\n width - margin.l - margin.r,\n MIN_SPECIFIED_WIDTH,\n minreducedwidth\n );\n\n var minFinalHeight = Lib.constrain(\n height - margin.t - margin.b,\n MIN_SPECIFIED_HEIGHT,\n minreducedheight\n );\n\n var maxSpaceW = Math.max(0, width - minFinalWidth);\n var maxSpaceH = Math.max(0, height - minFinalHeight);\n\n if(maxSpaceW) {\n var rW = (ml + mr) / maxSpaceW;\n if(rW > 1) {\n ml /= rW;\n mr /= rW;\n }\n }\n\n if(maxSpaceH) {\n var rH = (mb + mt) / maxSpaceH;\n if(rH > 1) {\n mb /= rH;\n mt /= rH;\n }\n }\n\n\n gs.l = Math.round(ml) + reservedMargins.l;\n gs.r = Math.round(mr) + reservedMargins.r;\n gs.t = Math.round(mt) + reservedMargins.t;\n gs.b = Math.round(mb) + reservedMargins.b;\n gs.p = Math.round(margin.pad);\n gs.w = Math.round(width) - gs.l - gs.r;\n gs.h = Math.round(height) - gs.t - gs.b;\n\n // if things changed and we're not already redrawing, trigger a redraw\n if(!fullLayout._replotting && (plots.didMarginChange(oldMargins, gs) || needsRedrawForShift(gd))) {\n if('_redrawFromAutoMarginCount' in fullLayout) {\n fullLayout._redrawFromAutoMarginCount++;\n } else {\n fullLayout._redrawFromAutoMarginCount = 1;\n }\n\n // Always allow at least one redraw and give each margin-push\n // call 3 loops to converge. Of course, for most cases this way too many,\n // but let's keep things on the safe side until we fix our\n // auto-margin pipeline problems:\n // https://github.com/plotly/plotly.js/issues/2704\n var maxNumberOfRedraws = 3 * (1 + Object.keys(pushMarginIds).length);\n\n if(fullLayout._redrawFromAutoMarginCount < maxNumberOfRedraws) {\n return Registry.call('_doPlot', gd);\n } else {\n fullLayout._size = oldMargins;\n Lib.warn('Too many auto-margin redraws.');\n }\n }\n\n refineTicks(gd);\n};\n\nfunction refineTicks(gd) {\n var axList = axisIDs.list(gd, '', true);\n\n [\n '_adjustTickLabelsOverflow',\n '_hideCounterAxisInsideTickLabels'\n ].forEach(function(k) {\n for(var i = 0; i < axList.length; i++) {\n var hideFn = axList[i][k];\n if(hideFn) hideFn();\n }\n });\n}\n\nvar marginKeys = ['l', 'r', 't', 'b', 'p', 'w', 'h'];\n\nplots.didMarginChange = function(margin0, margin1) {\n for(var i = 0; i < marginKeys.length; i++) {\n var k = marginKeys[i];\n var m0 = margin0[k];\n var m1 = margin1[k];\n // use 1px tolerance in case we old/new differ only\n // by rounding errors, which can lead to infinite loops\n if(!isNumeric(m0) || Math.abs(m1 - m0) > 1) {\n return true;\n }\n }\n return false;\n};\n\n/**\n * JSONify the graph data and layout\n *\n * This function needs to recurse because some src can be inside\n * sub-objects.\n *\n * It also strips out functions and private (starts with _) elements.\n * Therefore, we can add temporary things to data and layout that don't\n * get saved.\n *\n * @param gd The graphDiv\n * @param {Boolean} dataonly If true, don't return layout.\n * @param {'keepref'|'keepdata'|'keepall'} [mode='keepref'] Filter what's kept\n * keepref: remove data for which there's a src present\n * eg if there's xsrc present (and xsrc is well-formed,\n * ie has : and some chars before it), strip out x\n * keepdata: remove all src tags, don't remove the data itself\n * keepall: keep data and src\n * @param {String} output If you specify 'object', the result will not be stringified\n * @param {Boolean} useDefaults If truthy, use _fullLayout and _fullData\n * @param {Boolean} includeConfig If truthy, include _context\n * @returns {Object|String}\n */\nplots.graphJson = function(gd, dataonly, mode, output, useDefaults, includeConfig) {\n // if the defaults aren't supplied yet, we need to do that...\n if((useDefaults && dataonly && !gd._fullData) ||\n (useDefaults && !dataonly && !gd._fullLayout)) {\n plots.supplyDefaults(gd);\n }\n\n var data = (useDefaults) ? gd._fullData : gd.data;\n var layout = (useDefaults) ? gd._fullLayout : gd.layout;\n var frames = (gd._transitionData || {})._frames;\n\n function stripObj(d, keepFunction) {\n if(typeof d === 'function') {\n return keepFunction ? '_function_' : null;\n }\n if(Lib.isPlainObject(d)) {\n var o = {};\n var src;\n Object.keys(d).sort().forEach(function(v) {\n // remove private elements and functions\n // _ is for private, [ is a mistake ie [object Object]\n if(['_', '['].indexOf(v.charAt(0)) !== -1) return;\n\n // if a function, add if necessary then move on\n if(typeof d[v] === 'function') {\n if(keepFunction) o[v] = '_function';\n return;\n }\n\n // look for src/data matches and remove the appropriate one\n if(mode === 'keepdata') {\n // keepdata: remove all ...src tags\n if(v.substr(v.length - 3) === 'src') {\n return;\n }\n } else if(mode === 'keepstream') {\n // keep sourced data if it's being streamed.\n // similar to keepref, but if the 'stream' object exists\n // in a trace, we will keep the data array.\n src = d[v + 'src'];\n if(typeof src === 'string' && src.indexOf(':') > 0) {\n if(!Lib.isPlainObject(d.stream)) {\n return;\n }\n }\n } else if(mode !== 'keepall') {\n // keepref: remove sourced data but only\n // if the source tag is well-formed\n src = d[v + 'src'];\n if(typeof src === 'string' && src.indexOf(':') > 0) {\n return;\n }\n }\n\n // OK, we're including this... recurse into it\n o[v] = stripObj(d[v], keepFunction);\n });\n return o;\n }\n\n var dIsArray = Array.isArray(d);\n var dIsTypedArray = Lib.isTypedArray(d);\n\n if((dIsArray || dIsTypedArray) && d.dtype && d.shape) {\n var bdata = d.bdata;\n return stripObj({\n dtype: d.dtype,\n shape: d.shape,\n\n bdata:\n // case of ArrayBuffer\n Lib.isArrayBuffer(bdata) ? b64encode.encode(bdata) :\n // case of b64 string\n bdata\n\n }, keepFunction);\n }\n\n if(dIsArray) {\n return d.map(function(x) {return stripObj(x, keepFunction);});\n }\n\n if(dIsTypedArray) {\n return Lib.simpleMap(d, Lib.identity);\n }\n\n // convert native dates to date strings...\n // mostly for external users exporting to plotly\n if(Lib.isJSDate(d)) return Lib.ms2DateTimeLocal(+d);\n\n return d;\n }\n\n var obj = {\n data: (data || []).map(function(v) {\n var d = stripObj(v);\n // fit has some little arrays in it that don't contain data,\n // just fit params and meta\n if(dataonly) { delete d.fit; }\n return d;\n })\n };\n if(!dataonly) {\n obj.layout = stripObj(layout);\n if(useDefaults) {\n var gs = layout._size;\n obj.layout.computed = {\n margin: {\n b: gs.b,\n l: gs.l,\n r: gs.r,\n t: gs.t\n }\n };\n }\n }\n\n if(frames) obj.frames = stripObj(frames);\n\n if(includeConfig) obj.config = stripObj(gd._context, true);\n\n return (output === 'object') ? obj : JSON.stringify(obj);\n};\n\n/**\n * Modify a keyframe using a list of operations:\n *\n * @param {array of objects} operations\n * Sequence of operations to be performed on the keyframes\n */\nplots.modifyFrames = function(gd, operations) {\n var i, op, frame;\n var _frames = gd._transitionData._frames;\n var _frameHash = gd._transitionData._frameHash;\n\n for(i = 0; i < operations.length; i++) {\n op = operations[i];\n\n switch(op.type) {\n // No reason this couldn't exist, but is currently unused/untested:\n /* case 'rename':\n frame = _frames[op.index];\n delete _frameHash[frame.name];\n _frameHash[op.name] = frame;\n frame.name = op.name;\n break;*/\n case 'replace':\n frame = op.value;\n var oldName = (_frames[op.index] || {}).name;\n var newName = frame.name;\n _frames[op.index] = _frameHash[newName] = frame;\n\n if(newName !== oldName) {\n // If name has changed in addition to replacement, then update\n // the lookup table:\n delete _frameHash[oldName];\n _frameHash[newName] = frame;\n }\n\n break;\n case 'insert':\n frame = op.value;\n _frameHash[frame.name] = frame;\n _frames.splice(op.index, 0, frame);\n break;\n case 'delete':\n frame = _frames[op.index];\n delete _frameHash[frame.name];\n _frames.splice(op.index, 1);\n break;\n }\n }\n\n return Promise.resolve();\n};\n\n/*\n * Compute a keyframe. Merge a keyframe into its base frame(s) and\n * expand properties.\n *\n * @param {object} frameLookup\n * An object containing frames keyed by name (i.e. gd._transitionData._frameHash)\n * @param {string} frame\n * The name of the keyframe to be computed\n *\n * Returns: a new object with the merged content\n */\nplots.computeFrame = function(gd, frameName) {\n var frameLookup = gd._transitionData._frameHash;\n var i, traceIndices, traceIndex, destIndex;\n\n // Null or undefined will fail on .toString(). We'll allow numbers since we\n // make it clear frames must be given string names, but we'll allow numbers\n // here since they're otherwise fine for looking up frames as long as they're\n // properly cast to strings. We really just want to ensure here that this\n // 1) doesn't fail, and\n // 2) doens't give an incorrect answer (which String(frameName) would)\n if(!frameName) {\n throw new Error('computeFrame must be given a string frame name');\n }\n\n var framePtr = frameLookup[frameName.toString()];\n\n // Return false if the name is invalid:\n if(!framePtr) {\n return false;\n }\n\n var frameStack = [framePtr];\n var frameNameStack = [framePtr.name];\n\n // Follow frame pointers:\n while(framePtr.baseframe && (framePtr = frameLookup[framePtr.baseframe.toString()])) {\n // Avoid infinite loops:\n if(frameNameStack.indexOf(framePtr.name) !== -1) break;\n\n frameStack.push(framePtr);\n frameNameStack.push(framePtr.name);\n }\n\n // A new object for the merged result:\n var result = {};\n\n // Merge, starting with the last and ending with the desired frame:\n while((framePtr = frameStack.pop())) {\n if(framePtr.layout) {\n result.layout = plots.extendLayout(result.layout, framePtr.layout);\n }\n\n if(framePtr.data) {\n if(!result.data) {\n result.data = [];\n }\n traceIndices = framePtr.traces;\n\n if(!traceIndices) {\n // If not defined, assume serial order starting at zero\n traceIndices = [];\n for(i = 0; i < framePtr.data.length; i++) {\n traceIndices[i] = i;\n }\n }\n\n if(!result.traces) {\n result.traces = [];\n }\n\n for(i = 0; i < framePtr.data.length; i++) {\n // Loop through this frames data, find out where it should go,\n // and merge it!\n traceIndex = traceIndices[i];\n if(traceIndex === undefined || traceIndex === null) {\n continue;\n }\n\n destIndex = result.traces.indexOf(traceIndex);\n if(destIndex === -1) {\n destIndex = result.data.length;\n result.traces[destIndex] = traceIndex;\n }\n\n result.data[destIndex] = plots.extendTrace(result.data[destIndex], framePtr.data[i]);\n }\n }\n }\n\n return result;\n};\n\n/*\n * Recompute the lookup table that maps frame name -> frame object. addFrames/\n * deleteFrames already manages this data one at a time, so the only time this\n * is necessary is if you poke around manually in `gd._transitionData._frames`\n * and create and haven't updated the lookup table.\n */\nplots.recomputeFrameHash = function(gd) {\n var hash = gd._transitionData._frameHash = {};\n var frames = gd._transitionData._frames;\n for(var i = 0; i < frames.length; i++) {\n var frame = frames[i];\n if(frame && frame.name) {\n hash[frame.name] = frame;\n }\n }\n};\n\n/**\n * Extend an object, treating container arrays very differently by extracting\n * their contents and merging them separately.\n *\n * This exists so that we can extendDeepNoArrays and avoid stepping into data\n * arrays without knowledge of the plot schema, but so that we may also manually\n * recurse into known container arrays, such as transforms.\n *\n * See extendTrace and extendLayout below for usage.\n */\nplots.extendObjectWithContainers = function(dest, src, containerPaths) {\n var containerProp, containerVal, i, j, srcProp, destProp, srcContainer, destContainer;\n var copy = Lib.extendDeepNoArrays({}, src || {});\n var expandedObj = Lib.expandObjectPaths(copy);\n var containerObj = {};\n\n // Step through and extract any container properties. Otherwise extendDeepNoArrays\n // will clobber any existing properties with an empty array and then supplyDefaults\n // will reset everything to defaults.\n if(containerPaths && containerPaths.length) {\n for(i = 0; i < containerPaths.length; i++) {\n containerProp = Lib.nestedProperty(expandedObj, containerPaths[i]);\n containerVal = containerProp.get();\n\n if(containerVal === undefined) {\n Lib.nestedProperty(containerObj, containerPaths[i]).set(null);\n } else {\n containerProp.set(null);\n Lib.nestedProperty(containerObj, containerPaths[i]).set(containerVal);\n }\n }\n }\n\n dest = Lib.extendDeepNoArrays(dest || {}, expandedObj);\n\n if(containerPaths && containerPaths.length) {\n for(i = 0; i < containerPaths.length; i++) {\n srcProp = Lib.nestedProperty(containerObj, containerPaths[i]);\n srcContainer = srcProp.get();\n\n if(!srcContainer) continue;\n\n destProp = Lib.nestedProperty(dest, containerPaths[i]);\n destContainer = destProp.get();\n\n if(!Array.isArray(destContainer)) {\n destContainer = [];\n destProp.set(destContainer);\n }\n\n for(j = 0; j < srcContainer.length; j++) {\n var srcObj = srcContainer[j];\n\n if(srcObj === null) destContainer[j] = null;\n else {\n destContainer[j] = plots.extendObjectWithContainers(destContainer[j], srcObj);\n }\n }\n\n destProp.set(destContainer);\n }\n }\n\n return dest;\n};\n\nplots.dataArrayContainers = ['transforms', 'dimensions'];\nplots.layoutArrayContainers = Registry.layoutArrayContainers;\n\n/*\n * Extend a trace definition. This method:\n *\n * 1. directly transfers any array references\n * 2. manually recurses into container arrays like transforms\n *\n * The result is the original object reference with the new contents merged in.\n */\nplots.extendTrace = function(destTrace, srcTrace) {\n return plots.extendObjectWithContainers(destTrace, srcTrace, plots.dataArrayContainers);\n};\n\n/*\n * Extend a layout definition. This method:\n *\n * 1. directly transfers any array references (not critically important for\n * layout since there aren't really data arrays)\n * 2. manually recurses into container arrays like annotations\n *\n * The result is the original object reference with the new contents merged in.\n */\nplots.extendLayout = function(destLayout, srcLayout) {\n return plots.extendObjectWithContainers(destLayout, srcLayout, plots.layoutArrayContainers);\n};\n\n/**\n * Transition to a set of new data and layout properties from Plotly.animate\n *\n * @param {DOM element} gd\n * @param {Object[]} data\n * an array of data objects following the normal Plotly data definition format\n * @param {Object} layout\n * a layout object, following normal Plotly layout format\n * @param {Number[]} traces\n * indices of the corresponding traces specified in `data`\n * @param {Object} frameOpts\n * options for the frame (i.e. whether to redraw post-transition)\n * @param {Object} transitionOpts\n * options for the transition\n */\nplots.transition = function(gd, data, layout, traces, frameOpts, transitionOpts) {\n var opts = {redraw: frameOpts.redraw};\n var transitionedTraces = {};\n var axEdits = [];\n\n opts.prepareFn = function() {\n var dataLength = Array.isArray(data) ? data.length : 0;\n var traceIndices = traces.slice(0, dataLength);\n\n for(var i = 0; i < traceIndices.length; i++) {\n var traceIdx = traceIndices[i];\n var trace = gd._fullData[traceIdx];\n var _module = trace._module;\n\n // There's nothing to do if this module is not defined:\n if(!_module) continue;\n\n // Don't register the trace as transitioned if it doesn't know what to do.\n // If it *is* registered, it will receive a callback that it's responsible\n // for calling in order to register the transition as having completed.\n if(_module.animatable) {\n var n = _module.basePlotModule.name;\n if(!transitionedTraces[n]) transitionedTraces[n] = [];\n transitionedTraces[n].push(traceIdx);\n }\n\n gd.data[traceIndices[i]] = plots.extendTrace(gd.data[traceIndices[i]], data[i]);\n }\n\n // Follow the same procedure. Clone it so we don't mangle the input, then\n // expand any object paths so we can merge deep into gd.layout:\n var layoutUpdate = Lib.expandObjectPaths(Lib.extendDeepNoArrays({}, layout));\n\n // Before merging though, we need to modify the incoming layout. We only\n // know how to *transition* layout ranges, so it's imperative that a new\n // range not be sent to the layout before the transition has started. So\n // we must remove the things we can transition:\n var axisAttrRe = /^[xy]axis[0-9]*$/;\n for(var attr in layoutUpdate) {\n if(!axisAttrRe.test(attr)) continue;\n delete layoutUpdate[attr].range;\n }\n\n plots.extendLayout(gd.layout, layoutUpdate);\n\n // Supply defaults after applying the incoming properties. Note that any attempt\n // to simplify this step and reduce the amount of work resulted in the reconstruction\n // of essentially the whole supplyDefaults step, so that it seems sensible to just use\n // supplyDefaults even though it's heavier than would otherwise be desired for\n // transitions:\n\n // first delete calcdata so supplyDefaults knows a calc step is coming\n delete gd.calcdata;\n\n plots.supplyDefaults(gd);\n plots.doCalcdata(gd);\n\n var newLayout = Lib.expandObjectPaths(layout);\n\n if(newLayout) {\n var subplots = gd._fullLayout._plots;\n\n for(var k in subplots) {\n var plotinfo = subplots[k];\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var xr0 = xa.range.slice();\n var yr0 = ya.range.slice();\n\n var xr1 = null;\n var yr1 = null;\n var editX = null;\n var editY = null;\n\n if(Array.isArray(newLayout[xa._name + '.range'])) {\n xr1 = newLayout[xa._name + '.range'].slice();\n } else if(Array.isArray((newLayout[xa._name] || {}).range)) {\n xr1 = newLayout[xa._name].range.slice();\n }\n if(Array.isArray(newLayout[ya._name + '.range'])) {\n yr1 = newLayout[ya._name + '.range'].slice();\n } else if(Array.isArray((newLayout[ya._name] || {}).range)) {\n yr1 = newLayout[ya._name].range.slice();\n }\n\n if(xr0 && xr1 &&\n (xa.r2l(xr0[0]) !== xa.r2l(xr1[0]) || xa.r2l(xr0[1]) !== xa.r2l(xr1[1]))\n ) {\n editX = {xr0: xr0, xr1: xr1};\n }\n if(yr0 && yr1 &&\n (ya.r2l(yr0[0]) !== ya.r2l(yr1[0]) || ya.r2l(yr0[1]) !== ya.r2l(yr1[1]))\n ) {\n editY = {yr0: yr0, yr1: yr1};\n }\n\n if(editX || editY) {\n axEdits.push(Lib.extendFlat({plotinfo: plotinfo}, editX, editY));\n }\n }\n }\n\n return Promise.resolve();\n };\n\n opts.runFn = function(makeCallback) {\n var traceTransitionOpts;\n var basePlotModules = gd._fullLayout._basePlotModules;\n var hasAxisTransition = axEdits.length;\n var i;\n\n if(layout) {\n for(i = 0; i < basePlotModules.length; i++) {\n if(basePlotModules[i].transitionAxes) {\n basePlotModules[i].transitionAxes(gd, axEdits, transitionOpts, makeCallback);\n }\n }\n }\n\n // Here handle the exception that we refuse to animate scales and axes at the same\n // time. In other words, if there's an axis transition, then set the data transition\n // to instantaneous.\n if(hasAxisTransition) {\n traceTransitionOpts = Lib.extendFlat({}, transitionOpts);\n traceTransitionOpts.duration = 0;\n // This means do not transition cartesian traces,\n // this happens on layout-only (e.g. axis range) animations\n delete transitionedTraces.cartesian;\n } else {\n traceTransitionOpts = transitionOpts;\n }\n\n // Note that we pass a callback to *create* the callback that must be invoked on completion.\n // This is since not all traces know about transitions, so it greatly simplifies matters if\n // the trace is responsible for creating a callback, if needed, and then executing it when\n // the time is right.\n for(var n in transitionedTraces) {\n var traceIndices = transitionedTraces[n];\n var _module = gd._fullData[traceIndices[0]]._module;\n _module.basePlotModule.plot(gd, traceIndices, traceTransitionOpts, makeCallback);\n }\n };\n\n return _transition(gd, transitionOpts, opts);\n};\n\n/**\n * Transition to a set of new data and layout properties from Plotly.react\n *\n * @param {DOM element} gd\n * @param {object} restyleFlags\n * - anim {'all'|'some'}\n * @param {object} relayoutFlags\n * - anim {'all'|'some'}\n * @param {object} oldFullLayout : old (pre Plotly.react) fullLayout\n */\nplots.transitionFromReact = function(gd, restyleFlags, relayoutFlags, oldFullLayout) {\n var fullLayout = gd._fullLayout;\n var transitionOpts = fullLayout.transition;\n var opts = {};\n var axEdits = [];\n\n opts.prepareFn = function() {\n var subplots = fullLayout._plots;\n\n // no need to redraw at end of transition,\n // if all changes are animatable\n opts.redraw = false;\n if(restyleFlags.anim === 'some') opts.redraw = true;\n if(relayoutFlags.anim === 'some') opts.redraw = true;\n\n for(var k in subplots) {\n var plotinfo = subplots[k];\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var xr0 = oldFullLayout[xa._name].range.slice();\n var yr0 = oldFullLayout[ya._name].range.slice();\n var xr1 = xa.range.slice();\n var yr1 = ya.range.slice();\n\n xa.setScale();\n ya.setScale();\n\n var editX = null;\n var editY = null;\n\n if(xa.r2l(xr0[0]) !== xa.r2l(xr1[0]) || xa.r2l(xr0[1]) !== xa.r2l(xr1[1])) {\n editX = {xr0: xr0, xr1: xr1};\n }\n if(ya.r2l(yr0[0]) !== ya.r2l(yr1[0]) || ya.r2l(yr0[1]) !== ya.r2l(yr1[1])) {\n editY = {yr0: yr0, yr1: yr1};\n }\n\n if(editX || editY) {\n axEdits.push(Lib.extendFlat({plotinfo: plotinfo}, editX, editY));\n }\n }\n\n return Promise.resolve();\n };\n\n opts.runFn = function(makeCallback) {\n var fullData = gd._fullData;\n var fullLayout = gd._fullLayout;\n var basePlotModules = fullLayout._basePlotModules;\n\n var axisTransitionOpts;\n var traceTransitionOpts;\n var transitionedTraces;\n\n var allTraceIndices = [];\n for(var i = 0; i < fullData.length; i++) {\n allTraceIndices.push(i);\n }\n\n function transitionAxes() {\n if(!gd._fullLayout) return;\n for(var j = 0; j < basePlotModules.length; j++) {\n if(basePlotModules[j].transitionAxes) {\n basePlotModules[j].transitionAxes(gd, axEdits, axisTransitionOpts, makeCallback);\n }\n }\n }\n\n function transitionTraces() {\n if(!gd._fullLayout) return;\n for(var j = 0; j < basePlotModules.length; j++) {\n basePlotModules[j].plot(gd, transitionedTraces, traceTransitionOpts, makeCallback);\n }\n }\n\n if(axEdits.length && restyleFlags.anim) {\n if(transitionOpts.ordering === 'traces first') {\n axisTransitionOpts = Lib.extendFlat({}, transitionOpts, {duration: 0});\n transitionedTraces = allTraceIndices;\n traceTransitionOpts = transitionOpts;\n setTimeout(transitionAxes, transitionOpts.duration);\n transitionTraces();\n } else {\n axisTransitionOpts = transitionOpts;\n transitionedTraces = null;\n traceTransitionOpts = Lib.extendFlat({}, transitionOpts, {duration: 0});\n setTimeout(transitionTraces, axisTransitionOpts.duration);\n transitionAxes();\n }\n } else if(axEdits.length) {\n axisTransitionOpts = transitionOpts;\n transitionAxes();\n } else if(restyleFlags.anim) {\n transitionedTraces = allTraceIndices;\n traceTransitionOpts = transitionOpts;\n transitionTraces();\n }\n };\n\n return _transition(gd, transitionOpts, opts);\n};\n\n/**\n * trace/layout transition wrapper that works\n * for transitions initiated by Plotly.animate and Plotly.react.\n *\n * @param {DOM element} gd\n * @param {object} transitionOpts\n * @param {object} opts\n * - redraw {boolean}\n * - prepareFn {function} *should return a Promise*\n * - runFn {function} ran inside executeTransitions\n */\nfunction _transition(gd, transitionOpts, opts) {\n var aborted = false;\n\n function executeCallbacks(list) {\n var p = Promise.resolve();\n if(!list) return p;\n while(list.length) {\n p = p.then((list.shift()));\n }\n return p;\n }\n\n function flushCallbacks(list) {\n if(!list) return;\n while(list.length) {\n list.shift();\n }\n }\n\n function executeTransitions() {\n gd.emit('plotly_transitioning', []);\n\n return new Promise(function(resolve) {\n // This flag is used to disabled things like autorange:\n gd._transitioning = true;\n\n // When instantaneous updates are coming through quickly, it's too much to simply disable\n // all interaction, so store this flag so we can disambiguate whether mouse interactions\n // should be fully disabled or not:\n if(transitionOpts.duration > 0) {\n gd._transitioningWithDuration = true;\n }\n\n // If another transition is triggered, this callback will be executed simply because it's\n // in the interruptCallbacks queue. If this transition completes, it will instead flush\n // that queue and forget about this callback.\n gd._transitionData._interruptCallbacks.push(function() {\n aborted = true;\n });\n\n if(opts.redraw) {\n gd._transitionData._interruptCallbacks.push(function() {\n return Registry.call('redraw', gd);\n });\n }\n\n // Emit this and make sure it happens last:\n gd._transitionData._interruptCallbacks.push(function() {\n gd.emit('plotly_transitioninterrupted', []);\n });\n\n // Construct callbacks that are executed on transition end. This ensures the d3 transitions\n // are *complete* before anything else is done.\n var numCallbacks = 0;\n var numCompleted = 0;\n function makeCallback() {\n numCallbacks++;\n return function() {\n numCompleted++;\n // When all are complete, perform a redraw:\n if(!aborted && numCompleted === numCallbacks) {\n completeTransition(resolve);\n }\n };\n }\n\n opts.runFn(makeCallback);\n\n // If nothing else creates a callback, then this will trigger the completion in the next tick:\n setTimeout(makeCallback());\n });\n }\n\n function completeTransition(callback) {\n // This a simple workaround for tests which purge the graph before animations\n // have completed. That's not a very common case, so this is the simplest\n // fix.\n if(!gd._transitionData) return;\n\n flushCallbacks(gd._transitionData._interruptCallbacks);\n\n return Promise.resolve().then(function() {\n if(opts.redraw) {\n return Registry.call('redraw', gd);\n }\n }).then(function() {\n // Set transitioning false again once the redraw has occurred. This is used, for example,\n // to prevent the trailing redraw from autoranging:\n gd._transitioning = false;\n gd._transitioningWithDuration = false;\n\n gd.emit('plotly_transitioned', []);\n }).then(callback);\n }\n\n function interruptPreviousTransitions() {\n // Fail-safe against purged plot:\n if(!gd._transitionData) return;\n\n // If a transition is interrupted, set this to false. At the moment, the only thing that would\n // interrupt a transition is another transition, so that it will momentarily be set to true\n // again, but this determines whether autorange or dragbox work, so it's for the sake of\n // cleanliness:\n gd._transitioning = false;\n\n return executeCallbacks(gd._transitionData._interruptCallbacks);\n }\n\n var seq = [\n plots.previousPromises,\n interruptPreviousTransitions,\n opts.prepareFn,\n plots.rehover,\n plots.reselect,\n executeTransitions\n ];\n\n var transitionStarting = Lib.syncOrAsync(seq, gd);\n\n if(!transitionStarting || !transitionStarting.then) {\n transitionStarting = Promise.resolve();\n }\n\n return transitionStarting.then(function() { return gd; });\n}\n\nplots.doCalcdata = function(gd, traces) {\n var axList = axisIDs.list(gd);\n var fullData = gd._fullData;\n var fullLayout = gd._fullLayout;\n\n var trace, _module, i, j;\n\n // XXX: Is this correct? Needs a closer look so that *some* traces can be recomputed without\n // *all* needing doCalcdata:\n var calcdata = new Array(fullData.length);\n var oldCalcdata = (gd.calcdata || []).slice();\n gd.calcdata = calcdata;\n\n // extra helper variables\n\n // how many box/violins plots do we have (in case they're grouped)\n fullLayout._numBoxes = 0;\n fullLayout._numViolins = 0;\n\n // initialize violin per-scale-group stats container\n fullLayout._violinScaleGroupStats = {};\n\n // for calculating avg luminosity of heatmaps\n gd._hmpixcount = 0;\n gd._hmlumcount = 0;\n\n // for sharing colors across pies / sunbursts / treemap / icicle / funnelarea (and for legend)\n fullLayout._piecolormap = {};\n fullLayout._sunburstcolormap = {};\n fullLayout._treemapcolormap = {};\n fullLayout._iciclecolormap = {};\n fullLayout._funnelareacolormap = {};\n\n // If traces were specified and this trace was not included,\n // then transfer it over from the old calcdata:\n for(i = 0; i < fullData.length; i++) {\n if(Array.isArray(traces) && traces.indexOf(i) === -1) {\n calcdata[i] = oldCalcdata[i];\n continue;\n }\n }\n\n for(i = 0; i < fullData.length; i++) {\n trace = fullData[i];\n\n trace._arrayAttrs = PlotSchema.findArrayAttributes(trace);\n\n // keep track of trace extremes (for autorange) in here\n trace._extremes = {};\n }\n\n // add polar axes to axis list\n var polarIds = fullLayout._subplots.polar || [];\n for(i = 0; i < polarIds.length; i++) {\n axList.push(\n fullLayout[polarIds[i]].radialaxis,\n fullLayout[polarIds[i]].angularaxis\n );\n }\n\n // clear relinked cmin/cmax values in shared axes to start aggregation from scratch\n for(var k in fullLayout._colorAxes) {\n var cOpts = fullLayout[k];\n if(cOpts.cauto !== false) {\n delete cOpts.cmin;\n delete cOpts.cmax;\n }\n }\n\n var hasCalcTransform = false;\n\n function transformCalci(i) {\n trace = fullData[i];\n _module = trace._module;\n\n if(trace.visible === true && trace.transforms) {\n // we need one round of trace module calc before\n // the calc transform to 'fill in' the categories list\n // used for example in the data-to-coordinate method\n if(_module && _module.calc) {\n var cdi = _module.calc(gd, trace);\n\n // must clear scene 'batches', so that 2nd\n // _module.calc call starts from scratch\n if(cdi[0] && cdi[0].t && cdi[0].t._scene) {\n delete cdi[0].t._scene.dirty;\n }\n }\n\n for(j = 0; j < trace.transforms.length; j++) {\n var transform = trace.transforms[j];\n\n _module = transformsRegistry[transform.type];\n if(_module && _module.calcTransform) {\n trace._hasCalcTransform = true;\n hasCalcTransform = true;\n _module.calcTransform(gd, trace, transform);\n }\n }\n }\n }\n\n function calci(i, isContainer) {\n trace = fullData[i];\n _module = trace._module;\n\n if(!!_module.isContainer !== isContainer) return;\n\n var cd = [];\n\n if(trace.visible === true && trace._length !== 0) {\n // clear existing ref in case it got relinked\n delete trace._indexToPoints;\n // keep ref of index-to-points map object of the *last* enabled transform,\n // this index-to-points map object is required to determine the calcdata indices\n // that correspond to input indices (e.g. from 'selectedpoints')\n var transforms = trace.transforms || [];\n for(j = transforms.length - 1; j >= 0; j--) {\n if(transforms[j].enabled) {\n trace._indexToPoints = transforms[j]._indexToPoints;\n break;\n }\n }\n\n if(_module && _module.calc) {\n cd = _module.calc(gd, trace);\n }\n }\n\n // Make sure there is a first point.\n //\n // This ensures there is a calcdata item for every trace,\n // even if cartesian logic doesn't handle it (for things like legends).\n if(!Array.isArray(cd) || !cd[0]) {\n cd = [{x: BADNUM, y: BADNUM}];\n }\n\n // add the trace-wide properties to the first point,\n // per point properties to every point\n // t is the holder for trace-wide properties\n if(!cd[0].t) cd[0].t = {};\n cd[0].trace = trace;\n\n calcdata[i] = cd;\n }\n\n setupAxisCategories(axList, fullData, fullLayout);\n\n // 'transform' loop - must calc container traces first\n // so that if their dependent traces can get transform properly\n for(i = 0; i < fullData.length; i++) calci(i, true);\n for(i = 0; i < fullData.length; i++) transformCalci(i);\n\n // clear stuff that should recomputed in 'regular' loop\n if(hasCalcTransform) setupAxisCategories(axList, fullData, fullLayout);\n\n // 'regular' loop - make sure container traces (eg carpet) calc before\n // contained traces (eg contourcarpet)\n for(i = 0; i < fullData.length; i++) calci(i, true);\n for(i = 0; i < fullData.length; i++) calci(i, false);\n\n doCrossTraceCalc(gd);\n\n // Sort axis categories per value if specified\n var sorted = sortAxisCategoriesByValue(axList, gd);\n if(sorted.length) {\n // how many box/violins plots do we have (in case they're grouped)\n fullLayout._numBoxes = 0;\n fullLayout._numViolins = 0;\n // If a sort operation was performed, run calc() again\n for(i = 0; i < sorted.length; i++) calci(sorted[i], true);\n for(i = 0; i < sorted.length; i++) calci(sorted[i], false);\n doCrossTraceCalc(gd);\n }\n\n Registry.getComponentMethod('fx', 'calc')(gd);\n Registry.getComponentMethod('errorbars', 'calc')(gd);\n};\n\nvar sortAxisCategoriesByValueRegex = /(total|sum|min|max|mean|geometric mean|median) (ascending|descending)/;\n\nfunction sortAxisCategoriesByValue(axList, gd) {\n var affectedTraces = [];\n var i, j, k, l, o;\n\n function zMapCategory(type, ax, value) {\n var axLetter = ax._id.charAt(0);\n if(type === 'histogram2dcontour') {\n var counterAxLetter = ax._counterAxes[0];\n var counterAx = axisIDs.getFromId(gd, counterAxLetter);\n\n var xCategorical = axLetter === 'x' || (counterAxLetter === 'x' && counterAx.type === 'category');\n var yCategorical = axLetter === 'y' || (counterAxLetter === 'y' && counterAx.type === 'category');\n\n return function(o, l) {\n if(o === 0 || l === 0) return -1; // Skip first row and column\n if(xCategorical && o === value[l].length - 1) return -1;\n if(yCategorical && l === value.length - 1) return -1;\n\n return (axLetter === 'y' ? l : o) - 1;\n };\n } else {\n return function(o, l) {\n return axLetter === 'y' ? l : o;\n };\n }\n }\n\n var aggFn = {\n min: function(values) {return Lib.aggNums(Math.min, null, values);},\n max: function(values) {return Lib.aggNums(Math.max, null, values);},\n sum: function(values) {return Lib.aggNums(function(a, b) { return a + b;}, null, values);},\n total: function(values) {return Lib.aggNums(function(a, b) { return a + b;}, null, values);},\n mean: function(values) {return Lib.mean(values);},\n 'geometric mean': function(values) {return Lib.geometricMean(values);},\n median: function(values) {return Lib.median(values);}\n };\n\n function sortAscending(a, b) {\n return a[1] - b[1];\n }\n\n function sortDescending(a, b) {\n return b[1] - a[1];\n }\n\n for(i = 0; i < axList.length; i++) {\n var ax = axList[i];\n if(ax.type !== 'category') continue;\n\n // Order by value\n var match = ax.categoryorder.match(sortAxisCategoriesByValueRegex);\n if(match) {\n var aggregator = match[1];\n var order = match[2];\n\n var axLetter = ax._id.charAt(0);\n var isX = axLetter === 'x';\n\n // Store values associated with each category\n var categoriesValue = [];\n for(j = 0; j < ax._categories.length; j++) {\n categoriesValue.push([ax._categories[j], []]);\n }\n\n // Collect values across traces\n for(j = 0; j < ax._traceIndices.length; j++) {\n var traceIndex = ax._traceIndices[j];\n var fullTrace = gd._fullData[traceIndex];\n\n // Skip over invisible traces\n if(fullTrace.visible !== true) continue;\n\n var type = fullTrace.type;\n if(Registry.traceIs(fullTrace, 'histogram')) {\n delete fullTrace._xautoBinFinished;\n delete fullTrace._yautoBinFinished;\n }\n var isSplom = type === 'splom';\n var isScattergl = type === 'scattergl';\n\n var cd = gd.calcdata[traceIndex];\n for(k = 0; k < cd.length; k++) {\n var cdi = cd[k];\n var catIndex, value;\n\n if(isSplom) {\n // If `splom`, collect values across dimensions\n // Find which dimension the current axis is representing\n var currentDimensionIndex = fullTrace._axesDim[ax._id];\n\n // Apply logic to associated x axis if it's defined\n if(!isX) {\n var associatedXAxisID = fullTrace._diag[currentDimensionIndex][0];\n if(associatedXAxisID) ax = gd._fullLayout[axisIDs.id2name(associatedXAxisID)];\n }\n\n var categories = cdi.trace.dimensions[currentDimensionIndex].values;\n for(l = 0; l < categories.length; l++) {\n catIndex = ax._categoriesMap[categories[l]];\n\n // Collect associated values at index `l` over all other dimensions\n for(o = 0; o < cdi.trace.dimensions.length; o++) {\n if(o === currentDimensionIndex) continue;\n var dimension = cdi.trace.dimensions[o];\n categoriesValue[catIndex][1].push(dimension.values[l]);\n }\n }\n } else if(isScattergl) {\n // If `scattergl`, collect all values stashed under cdi.t\n for(l = 0; l < cdi.t.x.length; l++) {\n if(isX) {\n catIndex = cdi.t.x[l];\n value = cdi.t.y[l];\n } else {\n catIndex = cdi.t.y[l];\n value = cdi.t.x[l];\n }\n categoriesValue[catIndex][1].push(value);\n }\n // must clear scene 'batches', so that 2nd\n // _module.calc call starts from scratch\n if(cdi.t && cdi.t._scene) {\n delete cdi.t._scene.dirty;\n }\n } else if(cdi.hasOwnProperty('z')) {\n // If 2dMap, collect values in `z`\n value = cdi.z;\n var mapping = zMapCategory(fullTrace.type, ax, value);\n\n for(l = 0; l < value.length; l++) {\n for(o = 0; o < value[l].length; o++) {\n catIndex = mapping(o, l);\n if(catIndex + 1) categoriesValue[catIndex][1].push(value[l][o]);\n }\n }\n } else {\n // For all other 2d cartesian traces\n catIndex = cdi.p;\n if(catIndex === undefined) catIndex = cdi[axLetter];\n\n value = cdi.s;\n if(value === undefined) value = cdi.v;\n if(value === undefined) value = isX ? cdi.y : cdi.x;\n\n if(!Array.isArray(value)) {\n if(value === undefined) value = [];\n else value = [value];\n }\n for(l = 0; l < value.length; l++) {\n categoriesValue[catIndex][1].push(value[l]);\n }\n }\n }\n }\n\n ax._categoriesValue = categoriesValue;\n\n var categoriesAggregatedValue = [];\n for(j = 0; j < categoriesValue.length; j++) {\n categoriesAggregatedValue.push([\n categoriesValue[j][0],\n aggFn[aggregator](categoriesValue[j][1])\n ]);\n }\n\n // Sort by aggregated value\n categoriesAggregatedValue.sort(order === 'descending' ? sortDescending : sortAscending);\n\n ax._categoriesAggregatedValue = categoriesAggregatedValue;\n\n // Set new category order\n ax._initialCategories = categoriesAggregatedValue.map(function(c) {\n return c[0];\n });\n\n // Sort all matching axes\n affectedTraces = affectedTraces.concat(ax.sortByInitialCategories());\n }\n }\n return affectedTraces;\n}\n\nfunction setupAxisCategories(axList, fullData, fullLayout) {\n var axLookup = {};\n\n function setupOne(ax) {\n ax.clearCalc();\n if(ax.type === 'multicategory') {\n ax.setupMultiCategory(fullData);\n }\n\n axLookup[ax._id] = 1;\n }\n\n Lib.simpleMap(axList, setupOne);\n\n // look into match groups for 'missing' axes\n var matchGroups = fullLayout._axisMatchGroups || [];\n for(var i = 0; i < matchGroups.length; i++) {\n for(var axId in matchGroups[i]) {\n if(!axLookup[axId]) {\n setupOne(fullLayout[axisIDs.id2name(axId)]);\n }\n }\n }\n}\n\nfunction doCrossTraceCalc(gd) {\n var fullLayout = gd._fullLayout;\n var modules = fullLayout._visibleModules;\n var hash = {};\n var i, j, k;\n\n // position and range calculations for traces that\n // depend on each other ie bars (stacked or grouped)\n // and boxes (grouped) push each other out of the way\n\n for(j = 0; j < modules.length; j++) {\n var _module = modules[j];\n var fn = _module.crossTraceCalc;\n if(fn) {\n var spType = _module.basePlotModule.name;\n if(hash[spType]) {\n Lib.pushUnique(hash[spType], fn);\n } else {\n hash[spType] = [fn];\n }\n }\n }\n\n for(k in hash) {\n var methods = hash[k];\n var subplots = fullLayout._subplots[k];\n\n if(Array.isArray(subplots)) {\n for(i = 0; i < subplots.length; i++) {\n var sp = subplots[i];\n var spInfo = k === 'cartesian' ?\n fullLayout._plots[sp] :\n fullLayout[sp];\n\n for(j = 0; j < methods.length; j++) {\n methods[j](gd, spInfo, sp);\n }\n }\n } else {\n for(j = 0; j < methods.length; j++) {\n methods[j](gd);\n }\n }\n }\n}\n\nplots.rehover = function(gd) {\n if(gd._fullLayout._rehover) {\n gd._fullLayout._rehover();\n }\n};\n\nplots.redrag = function(gd) {\n if(gd._fullLayout._redrag) {\n gd._fullLayout._redrag();\n }\n};\n\nplots.reselect = function(gd) {\n var fullLayout = gd._fullLayout;\n\n var A = (gd.layout || {}).selections;\n var B = fullLayout._previousSelections;\n fullLayout._previousSelections = A;\n\n var mayEmitSelected = fullLayout._reselect ||\n JSON.stringify(A) !== JSON.stringify(B);\n\n Registry.getComponentMethod('selections', 'reselect')(gd, mayEmitSelected);\n};\n\nplots.generalUpdatePerTraceModule = function(gd, subplot, subplotCalcData, subplotLayout) {\n var traceHashOld = subplot.traceHash;\n var traceHash = {};\n var i;\n\n // build up moduleName -> calcData hash\n for(i = 0; i < subplotCalcData.length; i++) {\n var calcTraces = subplotCalcData[i];\n var trace = calcTraces[0].trace;\n\n // skip over visible === false traces\n // as they don't have `_module` ref\n if(trace.visible) {\n traceHash[trace.type] = traceHash[trace.type] || [];\n traceHash[trace.type].push(calcTraces);\n }\n }\n\n // when a trace gets deleted, make sure that its module's\n // plot method is called so that it is properly\n // removed from the DOM.\n for(var moduleNameOld in traceHashOld) {\n if(!traceHash[moduleNameOld]) {\n var fakeCalcTrace = traceHashOld[moduleNameOld][0];\n var fakeTrace = fakeCalcTrace[0].trace;\n\n fakeTrace.visible = false;\n traceHash[moduleNameOld] = [fakeCalcTrace];\n }\n }\n\n // call module plot method\n for(var moduleName in traceHash) {\n var moduleCalcData = traceHash[moduleName];\n var _module = moduleCalcData[0][0].trace._module;\n\n _module.plot(gd, subplot, Lib.filterVisible(moduleCalcData), subplotLayout);\n }\n\n // update moduleName -> calcData hash\n subplot.traceHash = traceHash;\n};\n\nplots.plotBasePlot = function(desiredType, gd, traces, transitionOpts, makeOnCompleteCallback) {\n var _module = Registry.getModule(desiredType);\n var cdmodule = getModuleCalcData(gd.calcdata, _module)[0];\n _module.plot(gd, cdmodule, transitionOpts, makeOnCompleteCallback);\n};\n\nplots.cleanBasePlot = function(desiredType, newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var had = (oldFullLayout._has && oldFullLayout._has(desiredType));\n var has = (newFullLayout._has && newFullLayout._has(desiredType));\n\n if(had && !has) {\n oldFullLayout['_' + desiredType + 'layer'].selectAll('g.trace').remove();\n }\n};\n","'use strict';\n\nmodule.exports = {\n attr: 'subplot',\n name: 'polar',\n\n axisNames: ['angularaxis', 'radialaxis'],\n axisName2dataArray: {angularaxis: 'theta', radialaxis: 'r'},\n\n layerNames: [\n 'draglayer',\n 'plotbg',\n 'backplot',\n 'angular-grid',\n 'radial-grid',\n 'frontplot',\n 'angular-line',\n 'radial-line',\n 'angular-axis',\n 'radial-axis'\n ],\n\n radialDragBoxSize: 50,\n angularDragBoxSize: 30,\n cornerLen: 25,\n cornerHalfWidth: 2,\n\n // pixels to move mouse before you stop clamping to starting point\n MINDRAG: 8,\n // smallest radial distance [px] allowed for a zoombox\n MINZOOM: 20,\n // distance [px] off (r=0) or (r=radius) where we transition\n // from single-sided to two-sided radial zoom\n OFFEDGE: 20\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar polygonTester = require('../../lib/polygon').tester;\n\nvar findIndexOfMin = Lib.findIndexOfMin;\nvar isAngleInsideSector = Lib.isAngleInsideSector;\nvar angleDelta = Lib.angleDelta;\nvar angleDist = Lib.angleDist;\n\n/**\n * is pt (r,a) inside polygon made up vertices at angles 'vangles'\n * inside a given polar sector\n *\n * @param {number} r : pt's radial coordinate\n * @param {number} a : pt's angular coordinate in *radians*\n * @param {2-item array} rBnds : sector's radial bounds\n * @param {2-item array} aBnds : sector's angular bounds *radians*\n * @param {array} vangles : angles of polygon vertices in *radians*\n * @return {boolean}\n */\nfunction isPtInsidePolygon(r, a, rBnds, aBnds, vangles) {\n if(!isAngleInsideSector(a, aBnds)) return false;\n\n var r0, r1;\n\n if(rBnds[0] < rBnds[1]) {\n r0 = rBnds[0];\n r1 = rBnds[1];\n } else {\n r0 = rBnds[1];\n r1 = rBnds[0];\n }\n\n var polygonIn = polygonTester(makePolygon(r0, aBnds[0], aBnds[1], vangles));\n var polygonOut = polygonTester(makePolygon(r1, aBnds[0], aBnds[1], vangles));\n var xy = [r * Math.cos(a), r * Math.sin(a)];\n return polygonOut.contains(xy) && !polygonIn.contains(xy);\n}\n\n// find intersection of 'v0' <-> 'v1' edge with a ray at angle 'a'\n// (i.e. a line that starts from the origin at angle 'a')\n// given an (xp,yp) pair on the 'v0' <-> 'v1' line\n// (N.B. 'v0' and 'v1' are angles in radians)\nfunction findIntersectionXY(v0, v1, a, xpyp) {\n var xstar, ystar;\n\n var xp = xpyp[0];\n var yp = xpyp[1];\n var dsin = clampTiny(Math.sin(v1) - Math.sin(v0));\n var dcos = clampTiny(Math.cos(v1) - Math.cos(v0));\n var tanA = Math.tan(a);\n var cotanA = clampTiny(1 / tanA);\n var m = dsin / dcos;\n var b = yp - m * xp;\n\n if(cotanA) {\n if(dsin && dcos) {\n // given\n // g(x) := v0 -> v1 line = m*x + b\n // h(x) := ray at angle 'a' = m*x = tanA*x\n // solve g(xstar) = h(xstar)\n xstar = b / (tanA - m);\n ystar = tanA * xstar;\n } else if(dcos) {\n // horizontal v0 -> v1\n xstar = yp * cotanA;\n ystar = yp;\n } else {\n // vertical v0 -> v1\n xstar = xp;\n ystar = xp * tanA;\n }\n } else {\n // vertical ray\n if(dsin && dcos) {\n xstar = 0;\n ystar = b;\n } else if(dcos) {\n xstar = 0;\n ystar = yp;\n } else {\n // does this case exists?\n xstar = ystar = NaN;\n }\n }\n\n return [xstar, ystar];\n}\n\n// solves l^2 = (f(x)^2 - yp)^2 + (x - xp)^2\n// rearranged into 0 = a*x^2 + b * x + c\n//\n// where f(x) = m*x + t + yp\n// and (x0, x1) = (-b +/- del) / (2*a)\nfunction findXYatLength(l, m, xp, yp) {\n var t = -m * xp;\n var a = m * m + 1;\n var b = 2 * (m * t - xp);\n var c = t * t + xp * xp - l * l;\n var del = Math.sqrt(b * b - 4 * a * c);\n var x0 = (-b + del) / (2 * a);\n var x1 = (-b - del) / (2 * a);\n return [\n [x0, m * x0 + t + yp],\n [x1, m * x1 + t + yp]\n ];\n}\n\nfunction makeRegularPolygon(r, vangles) {\n var len = vangles.length;\n var vertices = new Array(len + 1);\n var i;\n for(i = 0; i < len; i++) {\n var va = vangles[i];\n vertices[i] = [r * Math.cos(va), r * Math.sin(va)];\n }\n vertices[i] = vertices[0].slice();\n return vertices;\n}\n\nfunction makeClippedPolygon(r, a0, a1, vangles) {\n var len = vangles.length;\n var vertices = [];\n var i, j;\n\n function a2xy(a) {\n return [r * Math.cos(a), r * Math.sin(a)];\n }\n\n function findXY(va0, va1, s) {\n return findIntersectionXY(va0, va1, s, a2xy(va0));\n }\n\n function cycleIndex(ind) {\n return Lib.mod(ind, len);\n }\n\n function isInside(v) {\n return isAngleInsideSector(v, [a0, a1]);\n }\n\n // find index in sector closest to a0\n // use it to find intersection of v[i0] <-> v[i0-1] edge with sector radius\n var i0 = findIndexOfMin(vangles, function(v) {\n return isInside(v) ? angleDist(v, a0) : Infinity;\n });\n var xy0 = findXY(vangles[i0], vangles[cycleIndex(i0 - 1)], a0);\n vertices.push(xy0);\n\n // fill in in-sector vertices\n for(i = i0, j = 0; j < len; i++, j++) {\n var va = vangles[cycleIndex(i)];\n if(!isInside(va)) break;\n vertices.push(a2xy(va));\n }\n\n // find index in sector closest to a1,\n // use it to find intersection of v[iN] <-> v[iN+1] edge with sector radius\n var iN = findIndexOfMin(vangles, function(v) {\n return isInside(v) ? angleDist(v, a1) : Infinity;\n });\n var xyN = findXY(vangles[iN], vangles[cycleIndex(iN + 1)], a1);\n vertices.push(xyN);\n\n vertices.push([0, 0]);\n vertices.push(vertices[0].slice());\n\n return vertices;\n}\n\nfunction makePolygon(r, a0, a1, vangles) {\n return Lib.isFullCircle([a0, a1]) ?\n makeRegularPolygon(r, vangles) :\n makeClippedPolygon(r, a0, a1, vangles);\n}\n\nfunction findPolygonOffset(r, a0, a1, vangles) {\n var minX = Infinity;\n var minY = Infinity;\n var vertices = makePolygon(r, a0, a1, vangles);\n\n for(var i = 0; i < vertices.length; i++) {\n var v = vertices[i];\n minX = Math.min(minX, v[0]);\n minY = Math.min(minY, -v[1]);\n }\n return [minX, minY];\n}\n\n/**\n * find vertex angles (in 'vangles') the enclose angle 'a'\n *\n * @param {number} a : angle in *radians*\n * @param {array} vangles : angles of polygon vertices in *radians*\n * @return {2-item array}\n */\nfunction findEnclosingVertexAngles(a, vangles) {\n var minFn = function(v) {\n var adelta = angleDelta(v, a);\n return adelta > 0 ? adelta : Infinity;\n };\n var i0 = findIndexOfMin(vangles, minFn);\n var i1 = Lib.mod(i0 + 1, vangles.length);\n return [vangles[i0], vangles[i1]];\n}\n\n// to more easily catch 'almost zero' numbers in if-else blocks\nfunction clampTiny(v) {\n return Math.abs(v) > 1e-10 ? v : 0;\n}\n\nfunction transformForSVG(pts0, cx, cy) {\n cx = cx || 0;\n cy = cy || 0;\n\n var len = pts0.length;\n var pts1 = new Array(len);\n\n for(var i = 0; i < len; i++) {\n var pt = pts0[i];\n pts1[i] = [cx + pt[0], cy - pt[1]];\n }\n return pts1;\n}\n\n/**\n * path polygon\n *\n * @param {number} r : polygon 'radius'\n * @param {number} a0 : first angular coordinate in *radians*\n * @param {number} a1 : second angular coordinate in *radians*\n * @param {array} vangles : angles of polygon vertices in *radians*\n * @param {number (optional)} cx : x coordinate of center\n * @param {number (optional)} cy : y coordinate of center\n * @return {string} svg path\n *\n */\nfunction pathPolygon(r, a0, a1, vangles, cx, cy) {\n var poly = makePolygon(r, a0, a1, vangles);\n return 'M' + transformForSVG(poly, cx, cy).join('L');\n}\n\n/**\n * path a polygon 'annulus'\n * i.e. a polygon with a concentric hole\n *\n * N.B. this routine uses the evenodd SVG rule\n *\n * @param {number} r0 : first radial coordinate\n * @param {number} r1 : second radial coordinate\n * @param {number} a0 : first angular coordinate in *radians*\n * @param {number} a1 : second angular coordinate in *radians*\n * @param {array} vangles : angles of polygon vertices in *radians*\n * @param {number (optional)} cx : x coordinate of center\n * @param {number (optional)} cy : y coordinate of center\n * @return {string} svg path\n *\n */\nfunction pathPolygonAnnulus(r0, r1, a0, a1, vangles, cx, cy) {\n var rStart, rEnd;\n\n if(r0 < r1) {\n rStart = r0;\n rEnd = r1;\n } else {\n rStart = r1;\n rEnd = r0;\n }\n\n var inner = transformForSVG(makePolygon(rStart, a0, a1, vangles), cx, cy);\n var outer = transformForSVG(makePolygon(rEnd, a0, a1, vangles), cx, cy);\n return 'M' + outer.reverse().join('L') + 'M' + inner.join('L');\n}\n\nmodule.exports = {\n isPtInsidePolygon: isPtInsidePolygon,\n findPolygonOffset: findPolygonOffset,\n findEnclosingVertexAngles: findEnclosingVertexAngles,\n findIntersectionXY: findIntersectionXY,\n findXYatLength: findXYatLength,\n clampTiny: clampTiny,\n pathPolygon: pathPolygon,\n pathPolygonAnnulus: pathPolygonAnnulus\n};\n","'use strict';\n\nvar getSubplotCalcData = require('../get_data').getSubplotCalcData;\nvar counterRegex = require('../../lib').counterRegex;\n\nvar createPolar = require('./polar');\nvar constants = require('./constants');\n\nvar attr = constants.attr;\nvar name = constants.name;\nvar counter = counterRegex(name);\n\nvar attributes = {};\nattributes[attr] = {\n valType: 'subplotid',\n dflt: name,\n editType: 'calc',\n description: [\n 'Sets a reference between this trace\\'s data coordinates and',\n 'a polar subplot.',\n 'If *polar* (the default value), the data refer to `layout.polar`.',\n 'If *polar2*, the data refer to `layout.polar2`, and so on.'\n ].join(' ')\n};\n\nfunction plot(gd) {\n var fullLayout = gd._fullLayout;\n var calcData = gd.calcdata;\n var subplotIds = fullLayout._subplots[name];\n\n for(var i = 0; i < subplotIds.length; i++) {\n var id = subplotIds[i];\n var subplotCalcData = getSubplotCalcData(calcData, name, id);\n var subplot = fullLayout[id]._subplot;\n\n if(!subplot) {\n subplot = createPolar(gd, id);\n fullLayout[id]._subplot = subplot;\n }\n\n subplot.plot(subplotCalcData, fullLayout, gd._promises);\n }\n}\n\nfunction clean(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var oldIds = oldFullLayout._subplots[name] || [];\n var hadGl = (oldFullLayout._has && oldFullLayout._has('gl'));\n var hasGl = (newFullLayout._has && newFullLayout._has('gl'));\n var mustCleanScene = hadGl && !hasGl;\n\n for(var i = 0; i < oldIds.length; i++) {\n var id = oldIds[i];\n var oldSubplot = oldFullLayout[id]._subplot;\n\n if(!newFullLayout[id] && !!oldSubplot) {\n oldSubplot.framework.remove();\n oldSubplot.layers['radial-axis-title'].remove();\n\n for(var k in oldSubplot.clipPaths) {\n oldSubplot.clipPaths[k].remove();\n }\n }\n\n if(mustCleanScene && oldSubplot._scene) {\n oldSubplot._scene.destroy();\n oldSubplot._scene = null;\n }\n }\n}\n\nmodule.exports = {\n attr: attr,\n name: name,\n idRoot: name,\n idRegex: counter,\n attrRegex: counter,\n attributes: attributes,\n layoutAttributes: require('./layout_attributes'),\n supplyLayoutDefaults: require('./layout_defaults'),\n plot: plot,\n clean: clean,\n toSVG: require('../cartesian').toSVG\n};\n","'use strict';\n\nvar colorAttrs = require('../../components/color/attributes');\nvar axesAttrs = require('../cartesian/layout_attributes');\nvar domainAttrs = require('../domain').attributes;\nvar extendFlat = require('../../lib').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\n\nvar axisLineGridAttr = overrideAll({\n color: axesAttrs.color,\n showline: extendFlat({}, axesAttrs.showline, {dflt: true}),\n linecolor: axesAttrs.linecolor,\n linewidth: axesAttrs.linewidth,\n showgrid: extendFlat({}, axesAttrs.showgrid, {dflt: true}),\n gridcolor: axesAttrs.gridcolor,\n gridwidth: axesAttrs.gridwidth,\n griddash: axesAttrs.griddash\n\n // TODO add spike* attributes down the road\n\n // should we add zeroline* attributes?\n\n}, 'plot', 'from-root');\n\nvar axisTickAttrs = overrideAll({\n tickmode: axesAttrs.minor.tickmode,\n nticks: axesAttrs.nticks,\n tick0: axesAttrs.tick0,\n dtick: axesAttrs.dtick,\n tickvals: axesAttrs.tickvals,\n ticktext: axesAttrs.ticktext,\n ticks: axesAttrs.ticks,\n ticklen: axesAttrs.ticklen,\n tickwidth: axesAttrs.tickwidth,\n tickcolor: axesAttrs.tickcolor,\n ticklabelstep: axesAttrs.ticklabelstep,\n showticklabels: axesAttrs.showticklabels,\n labelalias: axesAttrs.labelalias,\n showtickprefix: axesAttrs.showtickprefix,\n tickprefix: axesAttrs.tickprefix,\n showticksuffix: axesAttrs.showticksuffix,\n ticksuffix: axesAttrs.ticksuffix,\n showexponent: axesAttrs.showexponent,\n exponentformat: axesAttrs.exponentformat,\n minexponent: axesAttrs.minexponent,\n separatethousands: axesAttrs.separatethousands,\n tickfont: axesAttrs.tickfont,\n tickangle: axesAttrs.tickangle,\n tickformat: axesAttrs.tickformat,\n tickformatstops: axesAttrs.tickformatstops,\n layer: axesAttrs.layer\n}, 'plot', 'from-root');\n\nvar radialAxisAttrs = {\n visible: extendFlat({}, axesAttrs.visible, {dflt: true}),\n type: extendFlat({}, axesAttrs.type, {\n values: ['-', 'linear', 'log', 'date', 'category']\n }),\n autotypenumbers: axesAttrs.autotypenumbers,\n\n autorangeoptions: {\n minallowed: axesAttrs.autorangeoptions.minallowed,\n maxallowed: axesAttrs.autorangeoptions.maxallowed,\n clipmin: axesAttrs.autorangeoptions.clipmin,\n clipmax: axesAttrs.autorangeoptions.clipmax,\n include: axesAttrs.autorangeoptions.include,\n editType: 'plot'\n },\n autorange: extendFlat({}, axesAttrs.autorange, {editType: 'plot'}),\n rangemode: {\n valType: 'enumerated',\n values: ['tozero', 'nonnegative', 'normal'],\n dflt: 'tozero',\n editType: 'calc',\n description: [\n 'If *tozero*`, the range extends to 0,',\n 'regardless of the input data',\n 'If *nonnegative*, the range is non-negative,',\n 'regardless of the input data.',\n 'If *normal*, the range is computed in relation to the extrema',\n 'of the input data (same behavior as for cartesian axes).'\n ].join(' ')\n },\n minallowed: extendFlat({}, axesAttrs.minallowed, {editType: 'plot'}),\n maxallowed: extendFlat({}, axesAttrs.maxallowed, {editType: 'plot'}),\n range: extendFlat({}, axesAttrs.range, {\n items: [\n {valType: 'any', editType: 'plot', impliedEdits: {'^autorange': false}},\n {valType: 'any', editType: 'plot', impliedEdits: {'^autorange': false}}\n ],\n editType: 'plot'\n }),\n\n categoryorder: axesAttrs.categoryorder,\n categoryarray: axesAttrs.categoryarray,\n\n angle: {\n valType: 'angle',\n editType: 'plot',\n description: [\n 'Sets the angle (in degrees) from which the radial axis is drawn.',\n 'Note that by default, radial axis line on the theta=0 line',\n 'corresponds to a line pointing right (like what mathematicians prefer).',\n 'Defaults to the first `polar.sector` angle.'\n ].join(' ')\n },\n\n autotickangles: axesAttrs.autotickangles,\n\n side: {\n valType: 'enumerated',\n // TODO add 'center' for `showline: false` radial axes\n values: ['clockwise', 'counterclockwise'],\n dflt: 'clockwise',\n editType: 'plot',\n description: [\n 'Determines on which side of radial axis line',\n 'the tick and tick labels appear.'\n ].join(' ')\n },\n\n\n title: {\n // radial title is not gui-editable at the moment,\n // so it needs dflt: '', similar to carpet axes.\n text: extendFlat({}, axesAttrs.title.text, {editType: 'plot', dflt: ''}),\n font: extendFlat({}, axesAttrs.title.font, {editType: 'plot'}),\n\n // TODO\n // - might need a 'titleside' and even 'titledirection' down the road\n // - what about standoff ??\n\n editType: 'plot'\n },\n\n hoverformat: axesAttrs.hoverformat,\n\n uirevision: {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in axis `range`,',\n '`autorange`, `angle`, and `title` if in `editable: true` configuration.',\n 'Defaults to `polar.uirevision`.'\n ].join(' ')\n },\n\n editType: 'calc',\n\n _deprecated: {\n title: axesAttrs._deprecated.title,\n titlefont: axesAttrs._deprecated.titlefont\n }\n};\n\nextendFlat(\n radialAxisAttrs,\n\n // N.B. radialaxis grid lines are circular,\n // but radialaxis lines are straight from circle center to outer bound\n axisLineGridAttr,\n axisTickAttrs\n);\n\nvar angularAxisAttrs = {\n visible: extendFlat({}, axesAttrs.visible, {dflt: true}),\n type: {\n valType: 'enumerated',\n // 'linear' should maybe be called 'angle' or 'angular' here\n // to make clear that axis here is periodic and more tightly match\n // `thetaunit`?\n //\n // skip 'date' for first push\n // no 'log' for now\n values: ['-', 'linear', 'category'],\n dflt: '-',\n editType: 'calc',\n _noTemplating: true,\n description: [\n 'Sets the angular axis type.',\n 'If *linear*, set `thetaunit` to determine the unit in which axis value are shown.',\n 'If *category, use `period` to set the number of integer coordinates around polar axis.'\n ].join(' ')\n },\n autotypenumbers: axesAttrs.autotypenumbers,\n\n categoryorder: axesAttrs.categoryorder,\n categoryarray: axesAttrs.categoryarray,\n\n thetaunit: {\n valType: 'enumerated',\n values: ['radians', 'degrees'],\n dflt: 'degrees',\n editType: 'calc',\n description: [\n 'Sets the format unit of the formatted *theta* values.',\n 'Has an effect only when `angularaxis.type` is *linear*.'\n ].join(' ')\n },\n\n period: {\n valType: 'number',\n editType: 'calc',\n min: 0,\n description: [\n 'Set the angular period.',\n 'Has an effect only when `angularaxis.type` is *category*.',\n ].join(' ')\n // Examples for date axes:\n //\n // - period that equals the timeseries length\n // http://flowingdata.com/2017/01/24/one-dataset-visualized-25-ways/18-polar-coordinates/\n // - and 1-year periods (focusing on seasonal change0\n // http://otexts.org/fpp2/seasonal-plots.html\n // https://blogs.scientificamerican.com/sa-visual/why-are-so-many-babies-born-around-8-00-a-m/\n // http://www.seasonaladjustment.com/2012/09/05/clock-plot-visualising-seasonality-using-r-and-ggplot2-part-3/\n // https://i.pinimg.com/736x/49/b9/72/49b972ccb3206a1a6d6f870dac543280.jpg\n // https://www.climate-lab-book.ac.uk/spirals/\n },\n\n direction: {\n valType: 'enumerated',\n values: ['counterclockwise', 'clockwise'],\n dflt: 'counterclockwise',\n editType: 'calc',\n description: [\n 'Sets the direction corresponding to positive angles.'\n ].join(' ')\n },\n\n rotation: {\n valType: 'angle',\n editType: 'calc',\n description: [\n 'Sets that start position (in degrees) of the angular axis',\n 'By default, polar subplots with `direction` set to *counterclockwise*',\n 'get a `rotation` of *0*',\n 'which corresponds to due East (like what mathematicians prefer).',\n 'In turn, polar with `direction` set to *clockwise* get a rotation of *90*',\n 'which corresponds to due North (like on a compass),'\n ].join(' ')\n },\n\n hoverformat: axesAttrs.hoverformat,\n\n uirevision: {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in axis `rotation`.',\n 'Defaults to `polar.uirevision`.'\n ].join(' ')\n },\n\n editType: 'calc'\n};\n\nextendFlat(\n angularAxisAttrs,\n\n // N.B. angular grid lines are straight lines from circle center to outer bound\n // the angular line is circular bounding the polar plot area.\n axisLineGridAttr,\n\n // N.B. ticksuffix defaults to '°' for angular axes with `thetaunit: 'degrees'`\n axisTickAttrs\n);\n\nmodule.exports = {\n // TODO for x/y/zoom system for paper-based zooming:\n // x: {},\n // y: {},\n // zoom: {},\n\n domain: domainAttrs({name: 'polar', editType: 'plot'}),\n\n sector: {\n valType: 'info_array',\n items: [\n {valType: 'number', editType: 'plot'},\n {valType: 'number', editType: 'plot'}\n ],\n dflt: [0, 360],\n editType: 'plot',\n description: [\n 'Sets angular span of this polar subplot with two angles (in degrees).',\n 'Sector are assumed to be spanned in the counterclockwise direction',\n 'with *0* corresponding to rightmost limit of the polar subplot.'\n ].join(' ')\n },\n hole: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0,\n editType: 'plot',\n description: [\n 'Sets the fraction of the radius to cut out of the polar subplot.'\n ].join(' ')\n },\n\n bgcolor: {\n valType: 'color',\n editType: 'plot',\n dflt: colorAttrs.background,\n description: 'Set the background color of the subplot'\n },\n\n radialaxis: radialAxisAttrs,\n angularaxis: angularAxisAttrs,\n\n gridshape: {\n valType: 'enumerated',\n values: ['circular', 'linear'],\n dflt: 'circular',\n editType: 'plot',\n description: [\n 'Determines if the radial axis grid lines and angular axis line are drawn',\n 'as *circular* sectors or as *linear* (polygon) sectors.',\n 'Has an effect only when the angular axis has `type` *category*.',\n 'Note that `radialaxis.angle` is snapped to the angle of the closest',\n 'vertex when `gridshape` is *circular*',\n '(so that radial axis scale is the same as the data scale).'\n ].join(' ')\n },\n\n // TODO maybe?\n // annotations:\n\n uirevision: {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in axis attributes,',\n 'if not overridden in the individual axes.',\n 'Defaults to `layout.uirevision`.'\n ].join(' ')\n },\n\n editType: 'calc'\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../../components/color');\nvar Template = require('../../plot_api/plot_template');\n\nvar handleSubplotDefaults = require('../subplot_defaults');\nvar getSubplotData = require('../get_data').getSubplotData;\n\nvar handleTickValueDefaults = require('../cartesian/tick_value_defaults');\nvar handleTickMarkDefaults = require('../cartesian/tick_mark_defaults');\nvar handleTickLabelDefaults = require('../cartesian/tick_label_defaults');\nvar handlePrefixSuffixDefaults = require('../cartesian/prefix_suffix_defaults');\nvar handleCategoryOrderDefaults = require('../cartesian/category_order_defaults');\nvar handleLineGridDefaults = require('../cartesian/line_grid_defaults');\nvar handleAutorangeOptionsDefaults = require('../cartesian/autorange_options_defaults');\nvar autoType = require('../cartesian/axis_autotype');\n\nvar layoutAttributes = require('./layout_attributes');\nvar setConvert = require('./set_convert');\nvar constants = require('./constants');\nvar axisNames = constants.axisNames;\n\nfunction handleDefaults(contIn, contOut, coerce, opts) {\n var bgColor = coerce('bgcolor');\n opts.bgColor = Color.combine(bgColor, opts.paper_bgcolor);\n\n var sector = coerce('sector');\n coerce('hole');\n\n // could optimize, subplotData is not always needed!\n var subplotData = getSubplotData(opts.fullData, constants.name, opts.id);\n var layoutOut = opts.layoutOut;\n var axName;\n\n function coerceAxis(attr, dflt) {\n return coerce(axName + '.' + attr, dflt);\n }\n\n for(var i = 0; i < axisNames.length; i++) {\n axName = axisNames[i];\n\n if(!Lib.isPlainObject(contIn[axName])) {\n contIn[axName] = {};\n }\n\n var axIn = contIn[axName];\n var axOut = Template.newContainer(contOut, axName);\n axOut._id = axOut._name = axName;\n axOut._attr = opts.id + '.' + axName;\n axOut._traceIndices = subplotData.map(function(t) { return t._expandedIndex; });\n\n var dataAttr = constants.axisName2dataArray[axName];\n var axType = handleAxisTypeDefaults(axIn, axOut, coerceAxis, subplotData, dataAttr, opts);\n\n handleCategoryOrderDefaults(axIn, axOut, coerceAxis, {\n axData: subplotData,\n dataAttr: dataAttr\n });\n\n var visible = coerceAxis('visible');\n setConvert(axOut, contOut, layoutOut);\n\n coerceAxis('uirevision', contOut.uirevision);\n\n // We don't want to make downstream code call ax.setScale,\n // as both radial and angular axes don't have a set domain.\n // Furthermore, angular axes don't have a set range.\n //\n // Mocked domains and ranges are set by the polar subplot instances,\n // but Axes.findExtremes uses the sign of _m to determine which padding value\n // to use.\n //\n // By setting, _m to 1 here, we make Axes.findExtremes think that\n // range[1] > range[0], and vice-versa for `autorange: 'reversed'` below.\n axOut._m = 1;\n\n switch(axName) {\n case 'radialaxis':\n coerceAxis('minallowed');\n coerceAxis('maxallowed');\n var range = coerceAxis('range');\n var autorangeDflt = axOut.getAutorangeDflt(range);\n var autorange = coerceAxis('autorange', autorangeDflt);\n var shouldAutorange;\n\n // validate range and set autorange true for invalid partial ranges\n if(range && (\n (range[0] === null && range[1] === null) ||\n ((range[0] === null || range[1] === null) && (autorange === 'reversed' || autorange === true)) ||\n (range[0] !== null && (autorange === 'min' || autorange === 'max reversed')) ||\n (range[1] !== null && (autorange === 'max' || autorange === 'min reversed'))\n )) {\n range = undefined;\n delete axOut.range;\n axOut.autorange = true;\n shouldAutorange = true;\n }\n\n if(!shouldAutorange) {\n autorangeDflt = axOut.getAutorangeDflt(range);\n autorange = coerceAxis('autorange', autorangeDflt);\n }\n\n axIn.autorange = autorange;\n if(autorange) {\n handleAutorangeOptionsDefaults(coerceAxis, autorange, range);\n\n if(axType === 'linear' || axType === '-') coerceAxis('rangemode');\n if(axOut.isReversed()) axOut._m = -1;\n }\n\n axOut.cleanRange('range', {dfltRange: [0, 1]});\n break;\n\n case 'angularaxis':\n // We do not support 'true' date angular axes yet,\n // users can still plot dates on angular axes by setting\n // `angularaxis.type: 'category'`.\n //\n // Here, if a date angular axes is detected, we make\n // all its corresponding traces invisible, so that\n // when we do add support for data angular axes, the new\n // behavior won't conflict with existing behavior\n if(axType === 'date') {\n Lib.log('Polar plots do not support date angular axes yet.');\n\n for(var j = 0; j < subplotData.length; j++) {\n subplotData[j].visible = false;\n }\n\n // turn this into a 'dummy' linear axis so that\n // the subplot still renders ok\n axType = axIn.type = axOut.type = 'linear';\n }\n\n if(axType === 'linear') {\n coerceAxis('thetaunit');\n } else {\n coerceAxis('period');\n }\n\n var direction = coerceAxis('direction');\n coerceAxis('rotation', {counterclockwise: 0, clockwise: 90}[direction]);\n break;\n }\n\n handlePrefixSuffixDefaults(axIn, axOut, coerceAxis, axOut.type, {\n tickSuffixDflt: axOut.thetaunit === 'degrees' ? '°' : undefined\n });\n\n if(visible) {\n var dfltColor;\n var dfltFontColor;\n var dfltFontSize;\n var dfltFontFamily;\n var dfltFontWeight;\n var dfltFontStyle;\n var dfltFontVariant;\n var dfltFontTextcase;\n var dfltFontLineposition;\n var dfltFontShadow;\n var font = opts.font || {};\n\n dfltColor = coerceAxis('color');\n dfltFontColor = (dfltColor === axIn.color) ? dfltColor : font.color;\n dfltFontSize = font.size;\n dfltFontFamily = font.family;\n dfltFontWeight = font.weight;\n dfltFontStyle = font.style;\n dfltFontVariant = font.variant;\n dfltFontTextcase = font.textcase;\n dfltFontLineposition = font.lineposition;\n dfltFontShadow = font.shadow;\n\n handleTickValueDefaults(axIn, axOut, coerceAxis, axOut.type);\n handleTickLabelDefaults(axIn, axOut, coerceAxis, axOut.type, {\n font: {\n weight: dfltFontWeight,\n style: dfltFontStyle,\n variant: dfltFontVariant,\n textcase: dfltFontTextcase,\n lineposition: dfltFontLineposition,\n shadow: dfltFontShadow,\n color: dfltFontColor,\n size: dfltFontSize,\n family: dfltFontFamily\n },\n noAutotickangles: axName === 'angularaxis',\n noTicklabelshift: true,\n noTicklabelstandoff: true\n });\n\n handleTickMarkDefaults(axIn, axOut, coerceAxis, {outerTicks: true});\n\n handleLineGridDefaults(axIn, axOut, coerceAxis, {\n dfltColor: dfltColor,\n bgColor: opts.bgColor,\n // default grid color is darker here (60%, vs cartesian default ~91%)\n // because the grid is not square so the eye needs heavier cues to follow\n blend: 60,\n showLine: true,\n showGrid: true,\n noZeroLine: true,\n attributes: layoutAttributes[axName]\n });\n\n coerceAxis('layer');\n\n if(axName === 'radialaxis') {\n coerceAxis('side');\n coerceAxis('angle', sector[0]);\n\n coerceAxis('title.text');\n Lib.coerceFont(coerceAxis, 'title.font', {\n weight: dfltFontWeight,\n style: dfltFontStyle,\n variant: dfltFontVariant,\n textcase: dfltFontTextcase,\n lineposition: dfltFontLineposition,\n shadow: dfltFontShadow,\n color: dfltFontColor,\n size: Lib.bigFont(dfltFontSize),\n family: dfltFontFamily\n });\n }\n }\n\n if(axType !== 'category') coerceAxis('hoverformat');\n\n axOut._input = axIn;\n }\n\n if(contOut.angularaxis.type === 'category') {\n coerce('gridshape');\n }\n}\n\nfunction handleAxisTypeDefaults(axIn, axOut, coerce, subplotData, dataAttr, options) {\n var autotypenumbers = coerce('autotypenumbers', options.autotypenumbersDflt);\n var axType = coerce('type');\n\n if(axType === '-') {\n var trace;\n\n for(var i = 0; i < subplotData.length; i++) {\n if(subplotData[i].visible) {\n trace = subplotData[i];\n break;\n }\n }\n\n if(trace && trace[dataAttr]) {\n axOut.type = autoType(trace[dataAttr], 'gregorian', {\n noMultiCategory: true,\n autotypenumbers: autotypenumbers\n });\n }\n\n if(axOut.type === '-') {\n axOut.type = 'linear';\n } else {\n // copy autoType back to input axis\n // note that if this object didn't exist\n // in the input layout, we have to put it in\n // this happens in the main supplyDefaults function\n axIn.type = axOut.type;\n }\n }\n\n return axOut.type;\n}\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut, fullData) {\n handleSubplotDefaults(layoutIn, layoutOut, fullData, {\n type: constants.name,\n attributes: layoutAttributes,\n handleDefaults: handleDefaults,\n font: layoutOut.font,\n autotypenumbersDflt: layoutOut.autotypenumbers,\n paper_bgcolor: layoutOut.paper_bgcolor,\n fullData: fullData,\n layoutOut: layoutOut\n });\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar tinycolor = require('tinycolor2');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar strRotate = Lib.strRotate;\nvar strTranslate = Lib.strTranslate;\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\nvar Plots = require('../plots');\nvar Axes = require('../../plots/cartesian/axes');\nvar setConvertCartesian = require('../cartesian/set_convert');\nvar setConvertPolar = require('./set_convert');\nvar doAutoRange = require('../cartesian/autorange').doAutoRange;\nvar dragBox = require('../cartesian/dragbox');\nvar dragElement = require('../../components/dragelement');\nvar Fx = require('../../components/fx');\nvar Titles = require('../../components/titles');\nvar prepSelect = require('../../components/selections').prepSelect;\nvar selectOnClick = require('../../components/selections').selectOnClick;\nvar clearOutline = require('../../components/selections').clearOutline;\nvar setCursor = require('../../lib/setcursor');\nvar clearGlCanvases = require('../../lib/clear_gl_canvases');\nvar redrawReglTraces = require('../../plot_api/subroutines').redrawReglTraces;\n\nvar MID_SHIFT = require('../../constants/alignment').MID_SHIFT;\nvar constants = require('./constants');\nvar helpers = require('./helpers');\n\nvar smithHelpers = require('../smith/helpers');\nvar smith = smithHelpers.smith;\nvar reactanceArc = smithHelpers.reactanceArc;\nvar resistanceArc = smithHelpers.resistanceArc;\nvar smithTransform = smithHelpers.smithTransform;\n\nvar _ = Lib._;\nvar mod = Lib.mod;\nvar deg2rad = Lib.deg2rad;\nvar rad2deg = Lib.rad2deg;\n\nfunction Polar(gd, id, isSmith) {\n this.isSmith = isSmith || false;\n this.id = id;\n this.gd = gd;\n\n this._hasClipOnAxisFalse = null;\n this.vangles = null;\n this.radialAxisAngle = null;\n this.traceHash = {};\n this.layers = {};\n this.clipPaths = {};\n this.clipIds = {};\n this.viewInitial = {};\n\n var fullLayout = gd._fullLayout;\n var clipIdBase = 'clip' + fullLayout._uid + id;\n\n this.clipIds.forTraces = clipIdBase + '-for-traces';\n this.clipPaths.forTraces = fullLayout._clips.append('clipPath')\n .attr('id', this.clipIds.forTraces);\n this.clipPaths.forTraces.append('path');\n\n this.framework = fullLayout['_' + (isSmith ? 'smith' : 'polar') + 'layer'].append('g')\n .attr('class', id);\n\n this.getHole = function(s) {\n return this.isSmith ? 0 : s.hole;\n };\n\n this.getSector = function(s) {\n return this.isSmith ? [0, 360] : s.sector;\n };\n\n this.getRadial = function(s) {\n return this.isSmith ? s.realaxis : s.radialaxis;\n };\n\n this.getAngular = function(s) {\n return this.isSmith ? s.imaginaryaxis : s.angularaxis;\n };\n\n if(!isSmith) {\n // unfortunately, we have to keep track of some axis tick settings\n // as polar subplots do not implement the 'ticks' editType\n this.radialTickLayout = null;\n this.angularTickLayout = null;\n }\n}\n\nvar proto = Polar.prototype;\n\nmodule.exports = function createPolar(gd, id, isSmith) {\n return new Polar(gd, id, isSmith);\n};\n\nproto.plot = function(polarCalcData, fullLayout) {\n var _this = this;\n var polarLayout = fullLayout[_this.id];\n\n var found = false;\n for(var i = 0; i < polarCalcData.length; i++) {\n var trace = polarCalcData[i][0].trace;\n if(trace.cliponaxis === false) {\n found = true;\n break;\n }\n }\n _this._hasClipOnAxisFalse = found;\n\n _this.updateLayers(fullLayout, polarLayout);\n _this.updateLayout(fullLayout, polarLayout);\n Plots.generalUpdatePerTraceModule(_this.gd, _this, polarCalcData, polarLayout);\n _this.updateFx(fullLayout, polarLayout);\n\n if(_this.isSmith) {\n delete polarLayout.realaxis.range;\n delete polarLayout.imaginaryaxis.range;\n }\n};\n\nproto.updateLayers = function(fullLayout, polarLayout) {\n var _this = this;\n var isSmith = _this.isSmith;\n var layers = _this.layers;\n var radialLayout = _this.getRadial(polarLayout);\n var angularLayout = _this.getAngular(polarLayout);\n var layerNames = constants.layerNames;\n\n var frontPlotIndex = layerNames.indexOf('frontplot');\n var layerData = layerNames.slice(0, frontPlotIndex);\n var isAngularAxisBelowTraces = angularLayout.layer === 'below traces';\n var isRadialAxisBelowTraces = radialLayout.layer === 'below traces';\n\n if(isAngularAxisBelowTraces) layerData.push('angular-line');\n if(isRadialAxisBelowTraces) layerData.push('radial-line');\n if(isAngularAxisBelowTraces) layerData.push('angular-axis');\n if(isRadialAxisBelowTraces) layerData.push('radial-axis');\n\n layerData.push('frontplot');\n\n if(!isAngularAxisBelowTraces) layerData.push('angular-line');\n if(!isRadialAxisBelowTraces) layerData.push('radial-line');\n if(!isAngularAxisBelowTraces) layerData.push('angular-axis');\n if(!isRadialAxisBelowTraces) layerData.push('radial-axis');\n\n var subLayer = (isSmith ? 'smith' : 'polar') + 'sublayer';\n\n var join = _this.framework.selectAll('.' + subLayer)\n .data(layerData, String);\n\n join.enter().append('g')\n .attr('class', function(d) { return subLayer + ' ' + d;})\n .each(function(d) {\n var sel = layers[d] = d3.select(this);\n\n switch(d) {\n case 'frontplot':\n // TODO add option to place in 'backplot' layer??\n if(!isSmith) {\n sel.append('g').classed('barlayer', true);\n }\n sel.append('g').classed('scatterlayer', true);\n break;\n case 'backplot':\n sel.append('g').classed('maplayer', true);\n break;\n case 'plotbg':\n layers.bg = sel.append('path');\n break;\n case 'radial-grid':\n sel.style('fill', 'none');\n break;\n case 'angular-grid':\n sel.style('fill', 'none');\n break;\n case 'radial-line':\n sel.append('line').style('fill', 'none');\n break;\n case 'angular-line':\n sel.append('path').style('fill', 'none');\n break;\n }\n });\n\n join.order();\n};\n\n/* Polar subplots juggle with 6 'axis objects' (!), these are:\n *\n * - getRadial(polarLayout) (aka radialLayout in this file):\n * - getAngular(polarLayout) (aka angularLayout in this file):\n * used for data -> calcdata conversions (aka d2c) during the calc step\n *\n * - this.radialAxis\n * extends getRadial(polarLayout), adds mocked 'domain' and\n * few other keys in order to reuse Cartesian doAutoRange and the Axes\n * drawing routines.\n * used for calcdata -> geometric conversions (aka c2g) during the plot step\n * + setGeometry setups ax.c2g for given ax.range\n * + setScale setups ax._m,ax._b for given ax.range\n *\n * - this.angularAxis\n * extends getAngular(polarLayout), adds mocked 'range' and 'domain' and\n * a few other keys in order to reuse the Axes drawing routines.\n * used for calcdata -> geometric conversions (aka c2g) during the plot step\n * + setGeometry setups ax.c2g given ax.rotation, ax.direction & ax._categories,\n * and mocks ax.range\n * + setScale setups ax._m,ax._b with that mocked ax.range\n *\n * - this.xaxis\n * - this.yaxis\n * setup so that polar traces can reuse plot methods of Cartesian traces\n * which mostly rely on 2pixel methods (e.g ax.c2p)\n */\nproto.updateLayout = function(fullLayout, polarLayout) {\n var _this = this;\n var layers = _this.layers;\n var gs = fullLayout._size;\n\n // axis attributes\n var radialLayout = _this.getRadial(polarLayout);\n var angularLayout = _this.getAngular(polarLayout);\n // layout domains\n var xDomain = polarLayout.domain.x;\n var yDomain = polarLayout.domain.y;\n // offsets from paper edge to layout domain box\n _this.xOffset = gs.l + gs.w * xDomain[0];\n _this.yOffset = gs.t + gs.h * (1 - yDomain[1]);\n // lengths of the layout domain box\n var xLength = _this.xLength = gs.w * (xDomain[1] - xDomain[0]);\n var yLength = _this.yLength = gs.h * (yDomain[1] - yDomain[0]);\n // sector to plot\n var sector = _this.getSector(polarLayout);\n _this.sectorInRad = sector.map(deg2rad);\n var sectorBBox = _this.sectorBBox = computeSectorBBox(sector);\n var dxSectorBBox = sectorBBox[2] - sectorBBox[0];\n var dySectorBBox = sectorBBox[3] - sectorBBox[1];\n // aspect ratios\n var arDomain = yLength / xLength;\n var arSector = Math.abs(dySectorBBox / dxSectorBBox);\n // actual lengths and domains of subplot box\n var xLength2, yLength2;\n var xDomain2, yDomain2;\n var gap;\n if(arDomain > arSector) {\n xLength2 = xLength;\n yLength2 = xLength * arSector;\n gap = (yLength - yLength2) / gs.h / 2;\n xDomain2 = [xDomain[0], xDomain[1]];\n yDomain2 = [yDomain[0] + gap, yDomain[1] - gap];\n } else {\n xLength2 = yLength / arSector;\n yLength2 = yLength;\n gap = (xLength - xLength2) / gs.w / 2;\n xDomain2 = [xDomain[0] + gap, xDomain[1] - gap];\n yDomain2 = [yDomain[0], yDomain[1]];\n }\n _this.xLength2 = xLength2;\n _this.yLength2 = yLength2;\n _this.xDomain2 = xDomain2;\n _this.yDomain2 = yDomain2;\n // actual offsets from paper edge to the subplot box top-left corner\n var xOffset2 = _this.xOffset2 = gs.l + gs.w * xDomain2[0];\n var yOffset2 = _this.yOffset2 = gs.t + gs.h * (1 - yDomain2[1]);\n // circle radius in px\n var radius = _this.radius = xLength2 / dxSectorBBox;\n // 'inner' radius in px (when polar.hole is set)\n var innerRadius = _this.innerRadius = _this.getHole(polarLayout) * radius;\n // circle center position in px\n var cx = _this.cx = xOffset2 - radius * sectorBBox[0];\n var cy = _this.cy = yOffset2 + radius * sectorBBox[3];\n // circle center in the coordinate system of plot area\n var cxx = _this.cxx = cx - xOffset2;\n var cyy = _this.cyy = cy - yOffset2;\n\n var side = radialLayout.side;\n var trueSide;\n if(side === 'counterclockwise') {\n trueSide = side;\n side = 'top';\n } else if(side === 'clockwise') {\n trueSide = side;\n side = 'bottom';\n }\n\n _this.radialAxis = _this.mockAxis(fullLayout, polarLayout, radialLayout, {\n // make this an 'x' axis to make positioning (especially rotation) easier\n _id: 'x',\n // convert to 'x' axis equivalent\n side: side,\n // keep track of real side\n _trueSide: trueSide,\n // spans length 1 radius\n domain: [innerRadius / gs.w, radius / gs.w]\n });\n\n _this.angularAxis = _this.mockAxis(fullLayout, polarLayout, angularLayout, {\n side: 'right',\n // to get auto nticks right\n domain: [0, Math.PI],\n // don't pass through autorange logic\n autorange: false\n });\n\n _this.doAutoRange(fullLayout, polarLayout);\n // N.B. this sets _this.vangles\n _this.updateAngularAxis(fullLayout, polarLayout);\n // N.B. this sets _this.radialAxisAngle\n _this.updateRadialAxis(fullLayout, polarLayout);\n _this.updateRadialAxisTitle(fullLayout, polarLayout);\n\n _this.xaxis = _this.mockCartesianAxis(fullLayout, polarLayout, {\n _id: 'x',\n domain: xDomain2\n });\n\n _this.yaxis = _this.mockCartesianAxis(fullLayout, polarLayout, {\n _id: 'y',\n domain: yDomain2\n });\n\n var dPath = _this.pathSubplot();\n\n _this.clipPaths.forTraces.select('path')\n .attr('d', dPath)\n .attr('transform', strTranslate(cxx, cyy));\n\n layers.frontplot\n .attr('transform', strTranslate(xOffset2, yOffset2))\n .call(Drawing.setClipUrl, _this._hasClipOnAxisFalse ? null : _this.clipIds.forTraces, _this.gd);\n\n layers.bg\n .attr('d', dPath)\n .attr('transform', strTranslate(cx, cy))\n .call(Color.fill, polarLayout.bgcolor);\n};\n\nproto.mockAxis = function(fullLayout, polarLayout, axLayout, opts) {\n var ax = Lib.extendFlat({}, axLayout, opts);\n setConvertPolar(ax, polarLayout, fullLayout);\n return ax;\n};\n\nproto.mockCartesianAxis = function(fullLayout, polarLayout, opts) {\n var _this = this;\n var isSmith = _this.isSmith;\n var axId = opts._id;\n\n var ax = Lib.extendFlat({type: 'linear'}, opts);\n setConvertCartesian(ax, fullLayout);\n\n var bboxIndices = {\n x: [0, 2],\n y: [1, 3]\n };\n\n ax.setRange = function() {\n var sectorBBox = _this.sectorBBox;\n var ind = bboxIndices[axId];\n var rl = _this.radialAxis._rl;\n var drl = (rl[1] - rl[0]) / (1 - _this.getHole(polarLayout));\n ax.range = [sectorBBox[ind[0]] * drl, sectorBBox[ind[1]] * drl];\n };\n\n ax.isPtWithinRange = axId === 'x' && !isSmith ?\n function(d) { return _this.isPtInside(d); } :\n function() { return true; };\n\n ax.setRange();\n ax.setScale();\n\n return ax;\n};\n\nproto.doAutoRange = function(fullLayout, polarLayout) {\n var _this = this;\n var gd = _this.gd;\n var radialAxis = _this.radialAxis;\n var radialLayout = _this.getRadial(polarLayout);\n\n doAutoRange(gd, radialAxis);\n\n var rng = radialAxis.range;\n radialLayout.range = rng.slice();\n radialLayout._input.range = rng.slice();\n\n radialAxis._rl = [\n radialAxis.r2l(rng[0], null, 'gregorian'),\n radialAxis.r2l(rng[1], null, 'gregorian')\n ];\n\n if(radialAxis.minallowed !== undefined) {\n var minallowed = radialAxis.r2l(radialAxis.minallowed);\n if(radialAxis._rl[0] > radialAxis._rl[1]) {\n radialAxis._rl[1] = Math.max(radialAxis._rl[1], minallowed);\n } else {\n radialAxis._rl[0] = Math.max(radialAxis._rl[0], minallowed);\n }\n }\n\n if(radialAxis.maxallowed !== undefined) {\n var maxallowed = radialAxis.r2l(radialAxis.maxallowed);\n if(radialAxis._rl[0] < radialAxis._rl[1]) {\n radialAxis._rl[1] = Math.min(radialAxis._rl[1], maxallowed);\n } else {\n radialAxis._rl[0] = Math.min(radialAxis._rl[0], maxallowed);\n }\n }\n};\n\nproto.updateRadialAxis = function(fullLayout, polarLayout) {\n var _this = this;\n var gd = _this.gd;\n var layers = _this.layers;\n var radius = _this.radius;\n var innerRadius = _this.innerRadius;\n var cx = _this.cx;\n var cy = _this.cy;\n var radialLayout = _this.getRadial(polarLayout);\n var a0 = mod(_this.getSector(polarLayout)[0], 360);\n var ax = _this.radialAxis;\n var hasRoomForIt = innerRadius < radius;\n\n var isSmith = _this.isSmith;\n if(!isSmith) {\n _this.fillViewInitialKey('radialaxis.angle', radialLayout.angle);\n _this.fillViewInitialKey('radialaxis.range', ax.range.slice());\n\n ax.setGeometry();\n }\n\n // rotate auto tick labels by 180 if in quadrant II and III to make them\n // readable from left-to-right\n //\n // TODO try moving deeper in Axes.drawLabels for better results?\n if(ax.tickangle === 'auto' && (a0 > 90 && a0 <= 270)) {\n ax.tickangle = 180;\n }\n\n // easier to set rotate angle with custom translate function\n var transFn = isSmith ?\n function(d) {\n var t = smithTransform(_this, smith([d.x, 0]));\n return strTranslate(t[0] - cx, t[1] - cy);\n } :\n function(d) {\n return strTranslate(ax.l2p(d.x) + innerRadius, 0);\n };\n\n // set special grid path function\n var gridPathFn = isSmith ?\n function(d) {\n return resistanceArc(_this, d.x, -Infinity, Infinity);\n } :\n function(d) {\n return _this.pathArc(ax.r2p(d.x) + innerRadius);\n };\n\n var newTickLayout = strTickLayout(radialLayout);\n if(_this.radialTickLayout !== newTickLayout) {\n layers['radial-axis'].selectAll('.xtick').remove();\n _this.radialTickLayout = newTickLayout;\n }\n\n if(hasRoomForIt) {\n ax.setScale();\n\n var labelShift = 0;\n\n var vals = isSmith ?\n (ax.tickvals || []).filter(function(x) {\n // filter negative\n return x >= 0;\n }).map(function(x) {\n return Axes.tickText(ax, x, true, false);\n }) : Axes.calcTicks(ax);\n\n var valsClipped = isSmith ? vals : Axes.clipEnds(ax, vals);\n var tickSign = Axes.getTickSigns(ax)[2];\n if(isSmith) {\n if(\n (ax.ticks === 'top' && ax.side === 'bottom') ||\n (ax.ticks === 'bottom' && ax.side === 'top')\n ) {\n // invert sign\n tickSign = -tickSign;\n }\n\n if(ax.ticks === 'top' && ax.side === 'top') labelShift = -ax.ticklen;\n if(ax.ticks === 'bottom' && ax.side === 'bottom') labelShift = ax.ticklen;\n }\n\n Axes.drawTicks(gd, ax, {\n vals: vals,\n layer: layers['radial-axis'],\n path: Axes.makeTickPath(ax, 0, tickSign),\n transFn: transFn,\n crisp: false\n });\n\n Axes.drawGrid(gd, ax, {\n vals: valsClipped,\n layer: layers['radial-grid'],\n path: gridPathFn,\n transFn: Lib.noop,\n crisp: false\n });\n\n Axes.drawLabels(gd, ax, {\n vals: vals,\n layer: layers['radial-axis'],\n transFn: transFn,\n labelFns: Axes.makeLabelFns(ax, labelShift)\n });\n }\n\n // stash 'actual' radial axis angle for drag handlers (in degrees)\n var angle = _this.radialAxisAngle = _this.vangles ?\n rad2deg(snapToVertexAngle(deg2rad(radialLayout.angle), _this.vangles)) :\n radialLayout.angle;\n\n var tLayer = strTranslate(cx, cy);\n var tLayer2 = tLayer + strRotate(-angle);\n\n updateElement(\n layers['radial-axis'],\n hasRoomForIt && (radialLayout.showticklabels || radialLayout.ticks),\n {transform: tLayer2}\n );\n\n updateElement(\n layers['radial-grid'],\n hasRoomForIt && radialLayout.showgrid,\n {transform: isSmith ? '' : tLayer}\n );\n\n updateElement(\n layers['radial-line'].select('line'),\n hasRoomForIt && radialLayout.showline,\n {\n x1: isSmith ? -radius : innerRadius,\n y1: 0,\n x2: radius,\n y2: 0,\n transform: tLayer2\n }\n )\n .attr('stroke-width', radialLayout.linewidth)\n .call(Color.stroke, radialLayout.linecolor);\n};\n\nproto.updateRadialAxisTitle = function(fullLayout, polarLayout, _angle) {\n if(this.isSmith) return;\n\n var _this = this;\n var gd = _this.gd;\n var radius = _this.radius;\n var cx = _this.cx;\n var cy = _this.cy;\n var radialLayout = _this.getRadial(polarLayout);\n var titleClass = _this.id + 'title';\n\n var pad = 0;\n\n // Hint: no need to check if there is in fact a title.text set\n // because if plot is editable, pad needs to be calculated anyways\n // to properly show placeholder text when title is empty.\n if(radialLayout.title) {\n var h = Drawing.bBox(_this.layers['radial-axis'].node()).height;\n var ts = radialLayout.title.font.size;\n var side = radialLayout.side;\n pad =\n side === 'top' ? ts :\n side === 'counterclockwise' ?\n -(h + ts * 0.4) :\n h + ts * 0.8;\n }\n\n var angle = _angle !== undefined ? _angle : _this.radialAxisAngle;\n\n var angleRad = deg2rad(angle);\n var cosa = Math.cos(angleRad);\n var sina = Math.sin(angleRad);\n\n var x = cx + (radius / 2) * cosa + pad * sina;\n var y = cy - (radius / 2) * sina + pad * cosa;\n\n _this.layers['radial-axis-title'] = Titles.draw(gd, titleClass, {\n propContainer: radialLayout,\n propName: _this.id + '.radialaxis.title',\n placeholder: _(gd, 'Click to enter radial axis title'),\n attributes: {\n x: x,\n y: y,\n 'text-anchor': 'middle'\n },\n transform: {rotate: -angle}\n });\n};\n\nproto.updateAngularAxis = function(fullLayout, polarLayout) {\n var _this = this;\n var gd = _this.gd;\n var layers = _this.layers;\n var radius = _this.radius;\n var innerRadius = _this.innerRadius;\n var cx = _this.cx;\n var cy = _this.cy;\n var angularLayout = _this.getAngular(polarLayout);\n var ax = _this.angularAxis;\n\n var isSmith = _this.isSmith;\n if(!isSmith) {\n _this.fillViewInitialKey('angularaxis.rotation', angularLayout.rotation);\n\n ax.setGeometry();\n ax.setScale();\n }\n\n // 't'ick to 'g'eometric radians is used all over the place here\n var t2g = isSmith ?\n function(d) {\n var t = smithTransform(_this, smith([0, d.x]));\n return Math.atan2(t[0] - cx, t[1] - cy) - Math.PI / 2;\n } :\n function(d) { return ax.t2g(d.x); };\n\n // run rad2deg on tick0 and ditck for thetaunit: 'radians' axes\n if(ax.type === 'linear' && ax.thetaunit === 'radians') {\n ax.tick0 = rad2deg(ax.tick0);\n ax.dtick = rad2deg(ax.dtick);\n }\n\n var _transFn = function(rad) {\n return strTranslate(cx + radius * Math.cos(rad), cy - radius * Math.sin(rad));\n };\n\n var transFn = isSmith ?\n function(d) {\n var t = smithTransform(_this, smith([0, d.x]));\n return strTranslate(t[0], t[1]);\n } :\n function(d) {\n return _transFn(t2g(d));\n };\n\n var transFn2 = isSmith ?\n function(d) {\n var t = smithTransform(_this, smith([0, d.x]));\n var rad = Math.atan2(t[0] - cx, t[1] - cy) - Math.PI / 2;\n return strTranslate(t[0], t[1]) + strRotate(-rad2deg(rad));\n } :\n function(d) {\n var rad = t2g(d);\n return _transFn(rad) + strRotate(-rad2deg(rad));\n };\n\n var gridPathFn = isSmith ?\n function(d) {\n return reactanceArc(_this, d.x, 0, Infinity);\n } :\n function(d) {\n var rad = t2g(d);\n var cosRad = Math.cos(rad);\n var sinRad = Math.sin(rad);\n return 'M' + [cx + innerRadius * cosRad, cy - innerRadius * sinRad] +\n 'L' + [cx + radius * cosRad, cy - radius * sinRad];\n };\n\n var out = Axes.makeLabelFns(ax, 0);\n var labelStandoff = out.labelStandoff;\n var labelFns = {};\n\n labelFns.xFn = function(d) {\n var rad = t2g(d);\n return Math.cos(rad) * labelStandoff;\n };\n\n labelFns.yFn = function(d) {\n var rad = t2g(d);\n var ff = Math.sin(rad) > 0 ? 0.2 : 1;\n return -Math.sin(rad) * (labelStandoff + d.fontSize * ff) +\n Math.abs(Math.cos(rad)) * (d.fontSize * MID_SHIFT);\n };\n\n labelFns.anchorFn = function(d) {\n var rad = t2g(d);\n var cos = Math.cos(rad);\n return Math.abs(cos) < 0.1 ?\n 'middle' :\n (cos > 0 ? 'start' : 'end');\n };\n\n labelFns.heightFn = function(d, a, h) {\n var rad = t2g(d);\n return -0.5 * (1 + Math.sin(rad)) * h;\n };\n\n var newTickLayout = strTickLayout(angularLayout);\n if(_this.angularTickLayout !== newTickLayout) {\n layers['angular-axis'].selectAll('.' + ax._id + 'tick').remove();\n _this.angularTickLayout = newTickLayout;\n }\n\n var vals = isSmith ?\n [Infinity].concat(ax.tickvals || []).map(function(x) {\n return Axes.tickText(ax, x, true, false);\n }) : Axes.calcTicks(ax);\n\n if(isSmith) {\n vals[0].text = '∞';\n vals[0].fontSize *= 1.75;\n }\n\n // angle of polygon vertices in geometric radians (null means circles)\n // TODO what to do when ax.period > ax._categories ??\n var vangles;\n if(polarLayout.gridshape === 'linear') {\n vangles = vals.map(t2g);\n\n // ax._vals should be always ordered, make them\n // always turn counterclockwise for convenience here\n if(Lib.angleDelta(vangles[0], vangles[1]) < 0) {\n vangles = vangles.slice().reverse();\n }\n } else {\n vangles = null;\n }\n _this.vangles = vangles;\n\n // Use tickval filter for category axes instead of tweaking\n // the range w.r.t sector, so that sectors that cross 360 can\n // show all their ticks.\n if(ax.type === 'category') {\n vals = vals.filter(function(d) {\n return Lib.isAngleInsideSector(t2g(d), _this.sectorInRad);\n });\n }\n\n if(ax.visible) {\n var tickSign = ax.ticks === 'inside' ? -1 : 1;\n\n var pad = (ax.linewidth || 1) / 2;\n\n Axes.drawTicks(gd, ax, {\n vals: vals,\n layer: layers['angular-axis'],\n path: 'M' + (tickSign * pad) + ',0h' + (tickSign * ax.ticklen),\n transFn: transFn2,\n crisp: false\n });\n\n Axes.drawGrid(gd, ax, {\n vals: vals,\n layer: layers['angular-grid'],\n path: gridPathFn,\n transFn: Lib.noop,\n crisp: false\n });\n\n Axes.drawLabels(gd, ax, {\n vals: vals,\n layer: layers['angular-axis'],\n repositionOnUpdate: true,\n transFn: transFn,\n labelFns: labelFns\n });\n }\n\n // TODO maybe two arcs is better here?\n // maybe split style attributes between inner and outer angular axes?\n\n updateElement(layers['angular-line'].select('path'), angularLayout.showline, {\n d: _this.pathSubplot(),\n transform: strTranslate(cx, cy)\n })\n .attr('stroke-width', angularLayout.linewidth)\n .call(Color.stroke, angularLayout.linecolor);\n};\n\nproto.updateFx = function(fullLayout, polarLayout) {\n if(!this.gd._context.staticPlot) {\n var hasDrag = !this.isSmith;\n if(hasDrag) {\n this.updateAngularDrag(fullLayout);\n this.updateRadialDrag(fullLayout, polarLayout, 0);\n this.updateRadialDrag(fullLayout, polarLayout, 1);\n }\n this.updateHoverAndMainDrag(fullLayout);\n }\n};\n\nproto.updateHoverAndMainDrag = function(fullLayout) {\n var _this = this;\n var isSmith = _this.isSmith;\n var gd = _this.gd;\n var layers = _this.layers;\n var zoomlayer = fullLayout._zoomlayer;\n var MINZOOM = constants.MINZOOM;\n var OFFEDGE = constants.OFFEDGE;\n var radius = _this.radius;\n var innerRadius = _this.innerRadius;\n var cx = _this.cx;\n var cy = _this.cy;\n var cxx = _this.cxx;\n var cyy = _this.cyy;\n var sectorInRad = _this.sectorInRad;\n var vangles = _this.vangles;\n var radialAxis = _this.radialAxis;\n var clampTiny = helpers.clampTiny;\n var findXYatLength = helpers.findXYatLength;\n var findEnclosingVertexAngles = helpers.findEnclosingVertexAngles;\n var chw = constants.cornerHalfWidth;\n var chl = constants.cornerLen / 2;\n\n var scaleX;\n var scaleY;\n\n var mainDrag = dragBox.makeDragger(layers, 'path', 'maindrag', fullLayout.dragmode === false ? 'none' : 'crosshair');\n\n d3.select(mainDrag)\n .attr('d', _this.pathSubplot())\n .attr('transform', strTranslate(cx, cy));\n\n mainDrag.onmousemove = function(evt) {\n Fx.hover(gd, evt, _this.id);\n gd._fullLayout._lasthover = mainDrag;\n gd._fullLayout._hoversubplot = _this.id;\n };\n\n mainDrag.onmouseout = function(evt) {\n if(gd._dragging) return;\n dragElement.unhover(gd, evt);\n };\n\n var dragOpts = {\n element: mainDrag,\n gd: gd,\n subplot: _this.id,\n plotinfo: {\n id: _this.id,\n xaxis: _this.xaxis,\n yaxis: _this.yaxis\n },\n xaxes: [_this.xaxis],\n yaxes: [_this.yaxis]\n };\n\n // mouse px position at drag start (0), move (1)\n var x0, y0;\n // radial distance from circle center at drag start (0), move (1)\n var r0, r1;\n // zoombox persistent quantities\n var path0, dimmed, lum;\n // zoombox, corners elements\n var zb, corners;\n\n function norm(x, y) {\n return Math.sqrt(x * x + y * y);\n }\n\n function xy2r(x, y) {\n return norm(x - cxx, y - cyy);\n }\n\n function xy2a(x, y) {\n return Math.atan2(cyy - y, x - cxx);\n }\n\n function ra2xy(r, a) {\n return [r * Math.cos(a), r * Math.sin(-a)];\n }\n\n function pathCorner(r, a) {\n if(r === 0) return _this.pathSector(2 * chw);\n\n var da = chl / r;\n var am = a - da;\n var ap = a + da;\n var rb = Math.max(0, Math.min(r, radius));\n var rm = rb - chw;\n var rp = rb + chw;\n\n return 'M' + ra2xy(rm, am) +\n 'A' + [rm, rm] + ' 0,0,0 ' + ra2xy(rm, ap) +\n 'L' + ra2xy(rp, ap) +\n 'A' + [rp, rp] + ' 0,0,1 ' + ra2xy(rp, am) +\n 'Z';\n }\n\n // (x,y) is the pt at middle of the va0 <-> va1 edge\n //\n // ... we could eventually add another mode for cursor\n // angles 'close to' enough to a particular vertex.\n function pathCornerForPolygons(r, va0, va1) {\n if(r === 0) return _this.pathSector(2 * chw);\n\n var xy0 = ra2xy(r, va0);\n var xy1 = ra2xy(r, va1);\n var x = clampTiny((xy0[0] + xy1[0]) / 2);\n var y = clampTiny((xy0[1] + xy1[1]) / 2);\n var innerPts, outerPts;\n\n if(x && y) {\n var m = y / x;\n var mperp = -1 / m;\n var midPts = findXYatLength(chw, m, x, y);\n innerPts = findXYatLength(chl, mperp, midPts[0][0], midPts[0][1]);\n outerPts = findXYatLength(chl, mperp, midPts[1][0], midPts[1][1]);\n } else {\n var dx, dy;\n if(y) {\n // horizontal handles\n dx = chl;\n dy = chw;\n } else {\n // vertical handles\n dx = chw;\n dy = chl;\n }\n innerPts = [[x - dx, y - dy], [x + dx, y - dy]];\n outerPts = [[x - dx, y + dy], [x + dx, y + dy]];\n }\n\n return 'M' + innerPts.join('L') +\n 'L' + outerPts.reverse().join('L') + 'Z';\n }\n\n function zoomPrep() {\n r0 = null;\n r1 = null;\n path0 = _this.pathSubplot();\n dimmed = false;\n\n var polarLayoutNow = gd._fullLayout[_this.id];\n lum = tinycolor(polarLayoutNow.bgcolor).getLuminance();\n\n zb = dragBox.makeZoombox(zoomlayer, lum, cx, cy, path0);\n zb.attr('fill-rule', 'evenodd');\n corners = dragBox.makeCorners(zoomlayer, cx, cy);\n clearOutline(gd);\n }\n\n // N.B. this sets scoped 'r0' and 'r1'\n // return true if 'valid' zoom distance, false otherwise\n function clampAndSetR0R1(rr0, rr1) {\n rr1 = Math.max(Math.min(rr1, radius), innerRadius);\n\n // starting or ending drag near center (outer edge),\n // clamps radial distance at origin (at r=radius)\n if(rr0 < OFFEDGE) rr0 = 0;\n else if((radius - rr0) < OFFEDGE) rr0 = radius;\n else if(rr1 < OFFEDGE) rr1 = 0;\n else if((radius - rr1) < OFFEDGE) rr1 = radius;\n\n // make sure r0 < r1,\n // to get correct fill pattern in path1 below\n if(Math.abs(rr1 - rr0) > MINZOOM) {\n if(rr0 < rr1) {\n r0 = rr0;\n r1 = rr1;\n } else {\n r0 = rr1;\n r1 = rr0;\n }\n return true;\n } else {\n r0 = null;\n r1 = null;\n return false;\n }\n }\n\n function applyZoomMove(path1, cpath) {\n path1 = path1 || path0;\n cpath = cpath || 'M0,0Z';\n\n zb.attr('d', path1);\n corners.attr('d', cpath);\n dragBox.transitionZoombox(zb, corners, dimmed, lum);\n dimmed = true;\n\n var updateObj = {};\n computeZoomUpdates(updateObj);\n gd.emit('plotly_relayouting', updateObj);\n }\n\n function zoomMove(dx, dy) {\n dx = dx * scaleX;\n dy = dy * scaleY;\n\n var x1 = x0 + dx;\n var y1 = y0 + dy;\n\n var rr0 = xy2r(x0, y0);\n var rr1 = Math.min(xy2r(x1, y1), radius);\n var a0 = xy2a(x0, y0);\n var path1;\n var cpath;\n\n if(clampAndSetR0R1(rr0, rr1)) {\n path1 = path0 + _this.pathSector(r1);\n if(r0) path1 += _this.pathSector(r0);\n // keep 'starting' angle\n cpath = pathCorner(r0, a0) + pathCorner(r1, a0);\n }\n applyZoomMove(path1, cpath);\n }\n\n function findPolygonRadius(x, y, va0, va1) {\n var xy = helpers.findIntersectionXY(va0, va1, va0, [x - cxx, cyy - y]);\n return norm(xy[0], xy[1]);\n }\n\n function zoomMoveForPolygons(dx, dy) {\n var x1 = x0 + dx;\n var y1 = y0 + dy;\n var a0 = xy2a(x0, y0);\n var a1 = xy2a(x1, y1);\n var vangles0 = findEnclosingVertexAngles(a0, vangles);\n var vangles1 = findEnclosingVertexAngles(a1, vangles);\n var rr0 = findPolygonRadius(x0, y0, vangles0[0], vangles0[1]);\n var rr1 = Math.min(findPolygonRadius(x1, y1, vangles1[0], vangles1[1]), radius);\n var path1;\n var cpath;\n\n if(clampAndSetR0R1(rr0, rr1)) {\n path1 = path0 + _this.pathSector(r1);\n if(r0) path1 += _this.pathSector(r0);\n // keep 'starting' angle here too\n cpath = [\n pathCornerForPolygons(r0, vangles0[0], vangles0[1]),\n pathCornerForPolygons(r1, vangles0[0], vangles0[1])\n ].join(' ');\n }\n applyZoomMove(path1, cpath);\n }\n\n function zoomDone() {\n dragBox.removeZoombox(gd);\n\n if(r0 === null || r1 === null) return;\n var updateObj = {};\n computeZoomUpdates(updateObj);\n\n dragBox.showDoubleClickNotifier(gd);\n\n Registry.call('_guiRelayout', gd, updateObj);\n }\n\n function computeZoomUpdates(update) {\n var rl = radialAxis._rl;\n var m = (rl[1] - rl[0]) / (1 - innerRadius / radius) / radius;\n var newRng = [\n rl[0] + (r0 - innerRadius) * m,\n rl[0] + (r1 - innerRadius) * m\n ];\n update[_this.id + '.radialaxis.range'] = newRng;\n }\n\n function zoomClick(numClicks, evt) {\n var clickMode = gd._fullLayout.clickmode;\n\n dragBox.removeZoombox(gd);\n\n // TODO double once vs twice logic (autorange vs fixed range)\n if(numClicks === 2) {\n var updateObj = {};\n for(var k in _this.viewInitial) {\n updateObj[_this.id + '.' + k] = _this.viewInitial[k];\n }\n\n gd.emit('plotly_doubleclick', null);\n Registry.call('_guiRelayout', gd, updateObj);\n }\n\n if(clickMode.indexOf('select') > -1 && numClicks === 1) {\n selectOnClick(evt, gd, [_this.xaxis], [_this.yaxis], _this.id, dragOpts);\n }\n\n if(clickMode.indexOf('event') > -1) {\n Fx.click(gd, evt, _this.id);\n }\n }\n\n dragOpts.prepFn = function(evt, startX, startY) {\n var dragModeNow = gd._fullLayout.dragmode;\n\n var bbox = mainDrag.getBoundingClientRect();\n gd._fullLayout._calcInverseTransform(gd);\n var inverse = gd._fullLayout._invTransform;\n scaleX = gd._fullLayout._invScaleX;\n scaleY = gd._fullLayout._invScaleY;\n var transformedCoords = Lib.apply3DTransform(inverse)(startX - bbox.left, startY - bbox.top);\n x0 = transformedCoords[0];\n y0 = transformedCoords[1];\n\n // need to offset x/y as bbox center does not\n // match origin for asymmetric polygons\n if(vangles) {\n var offset = helpers.findPolygonOffset(radius, sectorInRad[0], sectorInRad[1], vangles);\n x0 += cxx + offset[0];\n y0 += cyy + offset[1];\n }\n\n switch(dragModeNow) {\n case 'zoom':\n dragOpts.clickFn = zoomClick;\n\n if(!isSmith) {\n if(vangles) {\n dragOpts.moveFn = zoomMoveForPolygons;\n } else {\n dragOpts.moveFn = zoomMove;\n }\n\n dragOpts.doneFn = zoomDone;\n zoomPrep(evt, startX, startY);\n }\n break;\n case 'select':\n case 'lasso':\n prepSelect(evt, startX, startY, dragOpts, dragModeNow);\n break;\n }\n };\n\n dragElement.init(dragOpts);\n};\n\nproto.updateRadialDrag = function(fullLayout, polarLayout, rngIndex) {\n var _this = this;\n var gd = _this.gd;\n var layers = _this.layers;\n var radius = _this.radius;\n var innerRadius = _this.innerRadius;\n var cx = _this.cx;\n var cy = _this.cy;\n var radialAxis = _this.radialAxis;\n var bl = constants.radialDragBoxSize;\n var bl2 = bl / 2;\n\n if(!radialAxis.visible) return;\n\n var angle0 = deg2rad(_this.radialAxisAngle);\n var rl = radialAxis._rl;\n var rl0 = rl[0];\n var rl1 = rl[1];\n var rbase = rl[rngIndex];\n var m = 0.75 * (rl[1] - rl[0]) / (1 - _this.getHole(polarLayout)) / radius;\n\n var tx, ty, className;\n if(rngIndex) {\n tx = cx + (radius + bl2) * Math.cos(angle0);\n ty = cy - (radius + bl2) * Math.sin(angle0);\n className = 'radialdrag';\n } else {\n // the 'inner' box can get called:\n // - when polar.hole>0\n // - when polar.sector isn't a full circle\n // otherwise it is hidden behind the main drag.\n tx = cx + (innerRadius - bl2) * Math.cos(angle0);\n ty = cy - (innerRadius - bl2) * Math.sin(angle0);\n className = 'radialdrag-inner';\n }\n\n var radialDrag = dragBox.makeRectDragger(layers, className, 'crosshair', -bl2, -bl2, bl, bl);\n var dragOpts = {element: radialDrag, gd: gd};\n if(fullLayout.dragmode === false) {\n dragOpts.dragmode = false;\n }\n\n updateElement(d3.select(radialDrag), radialAxis.visible && innerRadius < radius, {\n transform: strTranslate(tx, ty)\n });\n\n // move function (either rotate or re-range flavor)\n var moveFn2;\n // rotate angle on done\n var angle1;\n // re-range range[1] (or range[0]) on done\n var rprime;\n\n function moveFn(dx, dy) {\n if(moveFn2) {\n moveFn2(dx, dy);\n } else {\n var dvec = [dx, -dy];\n var rvec = [Math.cos(angle0), Math.sin(angle0)];\n var comp = Math.abs(Lib.dot(dvec, rvec) / Math.sqrt(Lib.dot(dvec, dvec)));\n\n // mostly perpendicular motions rotate,\n // mostly parallel motions re-range\n if(!isNaN(comp)) {\n moveFn2 = comp < 0.5 ? rotateMove : rerangeMove;\n }\n }\n\n var update = {};\n computeRadialAxisUpdates(update);\n gd.emit('plotly_relayouting', update);\n }\n\n function computeRadialAxisUpdates(update) {\n if(angle1 !== null) {\n update[_this.id + '.radialaxis.angle'] = angle1;\n } else if(rprime !== null) {\n update[_this.id + '.radialaxis.range[' + rngIndex + ']'] = rprime;\n }\n }\n\n function doneFn() {\n if(angle1 !== null) {\n Registry.call('_guiRelayout', gd, _this.id + '.radialaxis.angle', angle1);\n } else if(rprime !== null) {\n Registry.call('_guiRelayout', gd, _this.id + '.radialaxis.range[' + rngIndex + ']', rprime);\n }\n }\n\n function rotateMove(dx, dy) {\n // disable for inner drag boxes\n if(rngIndex === 0) return;\n\n var x1 = tx + dx;\n var y1 = ty + dy;\n\n angle1 = Math.atan2(cy - y1, x1 - cx);\n if(_this.vangles) angle1 = snapToVertexAngle(angle1, _this.vangles);\n angle1 = rad2deg(angle1);\n\n var transform = strTranslate(cx, cy) + strRotate(-angle1);\n layers['radial-axis'].attr('transform', transform);\n layers['radial-line'].select('line').attr('transform', transform);\n\n var fullLayoutNow = _this.gd._fullLayout;\n var polarLayoutNow = fullLayoutNow[_this.id];\n _this.updateRadialAxisTitle(fullLayoutNow, polarLayoutNow, angle1);\n }\n\n function rerangeMove(dx, dy) {\n // project (dx, dy) unto unit radial axis vector\n var dr = Lib.dot([dx, -dy], [Math.cos(angle0), Math.sin(angle0)]);\n rprime = rbase - m * dr;\n\n // make sure rprime does not change the range[0] -> range[1] sign\n if((m > 0) !== (rngIndex ? rprime > rl0 : rprime < rl1)) {\n rprime = null;\n return;\n }\n\n var fullLayoutNow = gd._fullLayout;\n var polarLayoutNow = fullLayoutNow[_this.id];\n\n // update radial range -> update c2g -> update _m,_b\n radialAxis.range[rngIndex] = rprime;\n radialAxis._rl[rngIndex] = rprime;\n _this.updateRadialAxis(fullLayoutNow, polarLayoutNow);\n\n _this.xaxis.setRange();\n _this.xaxis.setScale();\n _this.yaxis.setRange();\n _this.yaxis.setScale();\n\n var hasRegl = false;\n\n for(var traceType in _this.traceHash) {\n var moduleCalcData = _this.traceHash[traceType];\n var moduleCalcDataVisible = Lib.filterVisible(moduleCalcData);\n var _module = moduleCalcData[0][0].trace._module;\n _module.plot(gd, _this, moduleCalcDataVisible, polarLayoutNow);\n if(Registry.traceIs(traceType, 'gl') && moduleCalcDataVisible.length) hasRegl = true;\n }\n\n if(hasRegl) {\n clearGlCanvases(gd);\n redrawReglTraces(gd);\n }\n }\n\n dragOpts.prepFn = function() {\n moveFn2 = null;\n angle1 = null;\n rprime = null;\n\n dragOpts.moveFn = moveFn;\n dragOpts.doneFn = doneFn;\n\n clearOutline(gd);\n };\n\n dragOpts.clampFn = function(dx, dy) {\n if(Math.sqrt(dx * dx + dy * dy) < constants.MINDRAG) {\n dx = 0;\n dy = 0;\n }\n return [dx, dy];\n };\n\n dragElement.init(dragOpts);\n};\n\nproto.updateAngularDrag = function(fullLayout) {\n var _this = this;\n var gd = _this.gd;\n var layers = _this.layers;\n var radius = _this.radius;\n var angularAxis = _this.angularAxis;\n var cx = _this.cx;\n var cy = _this.cy;\n var cxx = _this.cxx;\n var cyy = _this.cyy;\n var dbs = constants.angularDragBoxSize;\n\n var angularDrag = dragBox.makeDragger(layers, 'path', 'angulardrag', fullLayout.dragmode === false ? 'none' : 'move');\n var dragOpts = {element: angularDrag, gd: gd};\n\n if(fullLayout.dragmode === false) {\n dragOpts.dragmode = false;\n } else {\n d3.select(angularDrag)\n .attr('d', _this.pathAnnulus(radius, radius + dbs))\n .attr('transform', strTranslate(cx, cy))\n .call(setCursor, 'move');\n }\n\n function xy2a(x, y) {\n return Math.atan2(cyy + dbs - y, x - cxx - dbs);\n }\n\n // scatter trace, points and textpoints selections\n var scatterTraces = layers.frontplot.select('.scatterlayer').selectAll('.trace');\n var scatterPoints = scatterTraces.selectAll('.point');\n var scatterTextPoints = scatterTraces.selectAll('.textpoint');\n\n // mouse px position at drag start (0), move (1)\n var x0, y0;\n // angular axis angle rotation at drag start (0), move (1)\n var rot0, rot1;\n // induced radial axis rotation (only used on polygon grids)\n var rrot1;\n // angle about circle center at drag start\n var a0;\n\n function moveFn(dx, dy) {\n var fullLayoutNow = _this.gd._fullLayout;\n var polarLayoutNow = fullLayoutNow[_this.id];\n\n var x1 = x0 + dx * fullLayout._invScaleX;\n var y1 = y0 + dy * fullLayout._invScaleY;\n var a1 = xy2a(x1, y1);\n var da = rad2deg(a1 - a0);\n rot1 = rot0 + da;\n\n layers.frontplot.attr('transform',\n strTranslate(_this.xOffset2, _this.yOffset2) + strRotate([-da, cxx, cyy])\n );\n\n if(_this.vangles) {\n rrot1 = _this.radialAxisAngle + da;\n\n var trans = strTranslate(cx, cy) + strRotate(-da);\n var trans2 = strTranslate(cx, cy) + strRotate(-rrot1);\n\n layers.bg.attr('transform', trans);\n layers['radial-grid'].attr('transform', trans);\n layers['radial-axis'].attr('transform', trans2);\n layers['radial-line'].select('line').attr('transform', trans2);\n _this.updateRadialAxisTitle(fullLayoutNow, polarLayoutNow, rrot1);\n } else {\n _this.clipPaths.forTraces.select('path').attr('transform',\n strTranslate(cxx, cyy) + strRotate(da)\n );\n }\n\n // 'un-rotate' marker and text points\n scatterPoints.each(function() {\n var sel = d3.select(this);\n var xy = Drawing.getTranslate(sel);\n sel.attr('transform', strTranslate(xy.x, xy.y) + strRotate([da]));\n });\n scatterTextPoints.each(function() {\n var sel = d3.select(this);\n var tx = sel.select('text');\n var xy = Drawing.getTranslate(sel);\n // N.B rotate -> translate ordering matters\n sel.attr('transform', strRotate([da, tx.attr('x'), tx.attr('y')]) + strTranslate(xy.x, xy.y));\n });\n\n // update rotation -> range -> _m,_b\n angularAxis.rotation = Lib.modHalf(rot1, 360);\n _this.updateAngularAxis(fullLayoutNow, polarLayoutNow);\n\n if(_this._hasClipOnAxisFalse && !Lib.isFullCircle(_this.sectorInRad)) {\n scatterTraces.call(Drawing.hideOutsideRangePoints, _this);\n }\n\n var hasRegl = false;\n\n for(var traceType in _this.traceHash) {\n if(Registry.traceIs(traceType, 'gl')) {\n var moduleCalcData = _this.traceHash[traceType];\n var moduleCalcDataVisible = Lib.filterVisible(moduleCalcData);\n var _module = moduleCalcData[0][0].trace._module;\n _module.plot(gd, _this, moduleCalcDataVisible, polarLayoutNow);\n if(moduleCalcDataVisible.length) hasRegl = true;\n }\n }\n\n if(hasRegl) {\n clearGlCanvases(gd);\n redrawReglTraces(gd);\n }\n\n var update = {};\n computeRotationUpdates(update);\n gd.emit('plotly_relayouting', update);\n }\n\n function computeRotationUpdates(updateObj) {\n updateObj[_this.id + '.angularaxis.rotation'] = rot1;\n\n if(_this.vangles) {\n updateObj[_this.id + '.radialaxis.angle'] = rrot1;\n }\n }\n\n function doneFn() {\n scatterTextPoints.select('text').attr('transform', null);\n\n var updateObj = {};\n computeRotationUpdates(updateObj);\n Registry.call('_guiRelayout', gd, updateObj);\n }\n\n dragOpts.prepFn = function(evt, startX, startY) {\n var polarLayoutNow = fullLayout[_this.id];\n rot0 = polarLayoutNow.angularaxis.rotation;\n\n var bbox = angularDrag.getBoundingClientRect();\n x0 = startX - bbox.left;\n y0 = startY - bbox.top;\n\n gd._fullLayout._calcInverseTransform(gd);\n var transformedCoords = Lib.apply3DTransform(fullLayout._invTransform)(x0, y0);\n x0 = transformedCoords[0];\n y0 = transformedCoords[1];\n\n a0 = xy2a(x0, y0);\n\n dragOpts.moveFn = moveFn;\n dragOpts.doneFn = doneFn;\n\n clearOutline(gd);\n };\n\n // I don't what we should do in this case, skip we now\n if(_this.vangles && !Lib.isFullCircle(_this.sectorInRad)) {\n dragOpts.prepFn = Lib.noop;\n setCursor(d3.select(angularDrag), null);\n }\n\n dragElement.init(dragOpts);\n};\n\nproto.isPtInside = function(d) {\n if(this.isSmith) return true;\n\n var sectorInRad = this.sectorInRad;\n var vangles = this.vangles;\n var thetag = this.angularAxis.c2g(d.theta);\n var radialAxis = this.radialAxis;\n var r = radialAxis.c2l(d.r);\n var rl = radialAxis._rl;\n\n var fn = vangles ? helpers.isPtInsidePolygon : Lib.isPtInsideSector;\n return fn(r, thetag, rl, sectorInRad, vangles);\n};\n\nproto.pathArc = function(r) {\n var sectorInRad = this.sectorInRad;\n var vangles = this.vangles;\n var fn = vangles ? helpers.pathPolygon : Lib.pathArc;\n return fn(r, sectorInRad[0], sectorInRad[1], vangles);\n};\n\nproto.pathSector = function(r) {\n var sectorInRad = this.sectorInRad;\n var vangles = this.vangles;\n var fn = vangles ? helpers.pathPolygon : Lib.pathSector;\n return fn(r, sectorInRad[0], sectorInRad[1], vangles);\n};\n\nproto.pathAnnulus = function(r0, r1) {\n var sectorInRad = this.sectorInRad;\n var vangles = this.vangles;\n var fn = vangles ? helpers.pathPolygonAnnulus : Lib.pathAnnulus;\n return fn(r0, r1, sectorInRad[0], sectorInRad[1], vangles);\n};\n\nproto.pathSubplot = function() {\n var r0 = this.innerRadius;\n var r1 = this.radius;\n return r0 ? this.pathAnnulus(r0, r1) : this.pathSector(r1);\n};\n\nproto.fillViewInitialKey = function(key, val) {\n if(!(key in this.viewInitial)) {\n this.viewInitial[key] = val;\n }\n};\n\nfunction strTickLayout(axLayout) {\n var out = axLayout.ticks + String(axLayout.ticklen) + String(axLayout.showticklabels);\n if('side' in axLayout) out += axLayout.side;\n return out;\n}\n\n// Finds the bounding box of a given circle sector,\n// inspired by https://math.stackexchange.com/q/1852703\n//\n// assumes:\n// - sector[0] < sector[1]\n// - counterclockwise rotation\nfunction computeSectorBBox(sector) {\n var s0 = sector[0];\n var s1 = sector[1];\n var arc = s1 - s0;\n var a0 = mod(s0, 360);\n var a1 = a0 + arc;\n\n var ax0 = Math.cos(deg2rad(a0));\n var ay0 = Math.sin(deg2rad(a0));\n var ax1 = Math.cos(deg2rad(a1));\n var ay1 = Math.sin(deg2rad(a1));\n\n var x0, y0, x1, y1;\n\n if((a0 <= 90 && a1 >= 90) || (a0 > 90 && a1 >= 450)) {\n y1 = 1;\n } else if(ay0 <= 0 && ay1 <= 0) {\n y1 = 0;\n } else {\n y1 = Math.max(ay0, ay1);\n }\n\n if((a0 <= 180 && a1 >= 180) || (a0 > 180 && a1 >= 540)) {\n x0 = -1;\n } else if(ax0 >= 0 && ax1 >= 0) {\n x0 = 0;\n } else {\n x0 = Math.min(ax0, ax1);\n }\n\n if((a0 <= 270 && a1 >= 270) || (a0 > 270 && a1 >= 630)) {\n y0 = -1;\n } else if(ay0 >= 0 && ay1 >= 0) {\n y0 = 0;\n } else {\n y0 = Math.min(ay0, ay1);\n }\n\n if(a1 >= 360) {\n x1 = 1;\n } else if(ax0 <= 0 && ax1 <= 0) {\n x1 = 0;\n } else {\n x1 = Math.max(ax0, ax1);\n }\n\n return [x0, y0, x1, y1];\n}\n\nfunction snapToVertexAngle(a, vangles) {\n var fn = function(v) { return Lib.angleDist(a, v); };\n var ind = Lib.findIndexOfMin(vangles, fn);\n return vangles[ind];\n}\n\nfunction updateElement(sel, showAttr, attrs) {\n if(showAttr) {\n sel.attr('display', null);\n sel.attr(attrs);\n } else if(sel) {\n sel.attr('display', 'none');\n }\n return sel;\n}\n","'use strict';\n\nvar Lib = require('../../lib');\nvar setConvertCartesian = require('../cartesian/set_convert');\n\nvar deg2rad = Lib.deg2rad;\nvar rad2deg = Lib.rad2deg;\n\n/**\n * setConvert for polar axes!\n *\n * @param {object} ax\n * axis in question (works for both radial and angular axes)\n * @param {object} polarLayout\n * full polar layout of the subplot associated with 'ax'\n * @param {object} fullLayout\n * full layout\n *\n * Here, reuse some of the Cartesian setConvert logic,\n * but we must extend some of it, as both radial and angular axes\n * don't have domains and angular axes don't have _true_ ranges.\n *\n * Moreover, we introduce two new coordinate systems:\n * - 'g' for geometric coordinates and\n * - 't' for angular ticks\n *\n * Radial axis coordinate systems:\n * - d, c and l: same as for cartesian axes\n * - g: like calcdata but translated about `radialaxis.range[0]` & `polar.hole`\n *\n * Angular axis coordinate systems:\n * - d: data, in whatever form it's provided\n * - c: calcdata, turned into radians (for linear axes)\n * or category indices (category axes)\n * - t: tick calcdata, just like 'c' but in degrees for linear axes\n * - g: geometric calcdata, radians coordinates that take into account\n * axis rotation and direction\n *\n * Then, 'g'eometric data is ready to be converted to (x,y).\n */\nmodule.exports = function setConvert(ax, polarLayout, fullLayout) {\n setConvertCartesian(ax, fullLayout);\n\n switch(ax._id) {\n case 'x':\n case 'radialaxis':\n setConvertRadial(ax, polarLayout);\n break;\n case 'angularaxis':\n setConvertAngular(ax, polarLayout);\n break;\n }\n};\n\nfunction setConvertRadial(ax, polarLayout) {\n var subplot = polarLayout._subplot;\n\n ax.setGeometry = function() {\n var rl0 = ax._rl[0];\n var rl1 = ax._rl[1];\n\n var b = subplot.innerRadius;\n var m = (subplot.radius - b) / (rl1 - rl0);\n var b2 = b / m;\n\n var rFilter = rl0 > rl1 ?\n function(v) { return v <= 0; } :\n function(v) { return v >= 0; };\n\n ax.c2g = function(v) {\n var r = ax.c2l(v) - rl0;\n return (rFilter(r) ? r : 0) + b2;\n };\n\n ax.g2c = function(v) {\n return ax.l2c(v + rl0 - b2);\n };\n\n ax.g2p = function(v) { return v * m; };\n ax.c2p = function(v) { return ax.g2p(ax.c2g(v)); };\n };\n}\n\nfunction toRadians(v, unit) {\n return unit === 'degrees' ? deg2rad(v) : v;\n}\n\nfunction fromRadians(v, unit) {\n return unit === 'degrees' ? rad2deg(v) : v;\n}\n\nfunction setConvertAngular(ax, polarLayout) {\n var axType = ax.type;\n\n if(axType === 'linear') {\n var _d2c = ax.d2c;\n var _c2d = ax.c2d;\n\n ax.d2c = function(v, unit) { return toRadians(_d2c(v), unit); };\n ax.c2d = function(v, unit) { return _c2d(fromRadians(v, unit)); };\n }\n\n // override makeCalcdata to handle thetaunit and special theta0/dtheta logic\n ax.makeCalcdata = function(trace, coord) {\n var arrayIn = trace[coord];\n var len = trace._length;\n var arrayOut, i;\n\n var _d2c = function(v) { return ax.d2c(v, trace.thetaunit); };\n\n if(arrayIn) {\n arrayOut = new Array(len);\n for(i = 0; i < len; i++) {\n arrayOut[i] = _d2c(arrayIn[i]);\n }\n } else {\n var coord0 = coord + '0';\n var dcoord = 'd' + coord;\n var v0 = (coord0 in trace) ? _d2c(trace[coord0]) : 0;\n var dv = (trace[dcoord]) ? _d2c(trace[dcoord]) : (ax.period || 2 * Math.PI) / len;\n\n arrayOut = new Array(len);\n for(i = 0; i < len; i++) {\n arrayOut[i] = v0 + i * dv;\n }\n }\n\n return arrayOut;\n };\n\n // N.B. we mock the axis 'range' here\n ax.setGeometry = function() {\n var sector = polarLayout.sector;\n var sectorInRad = sector.map(deg2rad);\n var dir = {clockwise: -1, counterclockwise: 1}[ax.direction];\n var rot = deg2rad(ax.rotation);\n\n var rad2g = function(v) { return dir * v + rot; };\n var g2rad = function(v) { return (v - rot) / dir; };\n\n var rad2c, c2rad;\n var rad2t, t2rad;\n\n switch(axType) {\n case 'linear':\n c2rad = rad2c = Lib.identity;\n t2rad = deg2rad;\n rad2t = rad2deg;\n\n // Set the angular range in degrees to make auto-tick computation cleaner,\n // changing rotation/direction should not affect the angular tick value.\n ax.range = Lib.isFullCircle(sectorInRad) ?\n [sector[0], sector[0] + 360] :\n sectorInRad.map(g2rad).map(rad2deg);\n break;\n\n case 'category':\n var catLen = ax._categories.length;\n var _period = ax.period ? Math.max(ax.period, catLen) : catLen;\n\n // fallback in case all categories have been filtered out\n if(_period === 0) _period = 1;\n\n c2rad = t2rad = function(v) { return v * 2 * Math.PI / _period; };\n rad2c = rad2t = function(v) { return v * _period / Math.PI / 2; };\n\n ax.range = [0, _period];\n break;\n }\n\n ax.c2g = function(v) { return rad2g(c2rad(v)); };\n ax.g2c = function(v) { return rad2c(g2rad(v)); };\n\n ax.t2g = function(v) { return rad2g(t2rad(v)); };\n ax.g2t = function(v) { return rad2t(g2rad(v)); };\n };\n}\n","'use strict';\n\nmodule.exports = {\n attr: 'subplot',\n name: 'smith',\n\n axisNames: [\n 'realaxis',\n 'imaginaryaxis' // imaginary axis should be second here so that the `tickvals` defaults could be inherited from realaxis\n ],\n axisName2dataArray: {imaginaryaxis: 'imag', realaxis: 'real'},\n};\n","'use strict';\n\nfunction sign(x) {\n return (\n x < 0 ? -1 :\n x > 0 ? 1 : 0\n );\n}\n\n// adapted from Mike Bostock's https://observablehq.com/@mbostock/smith-chart\nfunction smith(a) {\n var R = a[0];\n var X = a[1];\n\n if(!isFinite(R) || !isFinite(X)) return [1, 0];\n\n var D = (R + 1) * (R + 1) + X * X;\n return [(R * R + X * X - 1) / D, 2 * X / D];\n}\n\nfunction transform(subplot, a) {\n var x = a[0];\n var y = a[1];\n\n return [\n x * subplot.radius + subplot.cx,\n -y * subplot.radius + subplot.cy\n ];\n}\n\nfunction scale(subplot, r) {\n return r * subplot.radius;\n}\n\nfunction reactanceArc(subplot, X, R1, R2) {\n var t1 = transform(subplot, smith([R1, X]));\n var x1 = t1[0];\n var y1 = t1[1];\n\n var t2 = transform(subplot, smith([R2, X]));\n var x2 = t2[0];\n var y2 = t2[1];\n\n if(X === 0) {\n return [\n 'M' + x1 + ',' + y1,\n 'L' + x2 + ',' + y2\n ].join(' ');\n }\n\n var r = scale(subplot, 1 / Math.abs(X));\n\n return [\n 'M' + x1 + ',' + y1,\n 'A' + r + ',' + r + ' 0 0,' + (X < 0 ? 1 : 0) + ' ' + x2 + ',' + y2\n ].join(' ');\n}\n\nfunction resistanceArc(subplot, R, X1, X2) {\n var r = scale(subplot, 1 / (R + 1));\n\n var t1 = transform(subplot, smith([R, X1]));\n var x1 = t1[0];\n var y1 = t1[1];\n\n var t2 = transform(subplot, smith([R, X2]));\n var x2 = t2[0];\n var y2 = t2[1];\n\n if(sign(X1) !== sign(X2)) {\n var t0 = transform(subplot, smith([R, 0]));\n var x0 = t0[0];\n var y0 = t0[1];\n\n return [\n 'M' + x1 + ',' + y1,\n 'A' + r + ',' + r + ' 0 0,' + (0 < X1 ? 0 : 1) + ' ' + x0 + ',' + y0,\n 'A' + r + ',' + r + ' 0 0,' + (X2 < 0 ? 0 : 1) + x2 + ',' + y2,\n ].join(' ');\n }\n\n return [\n 'M' + x1 + ',' + y1,\n 'A' + r + ',' + r + ' 0 0,' + (X2 < X1 ? 0 : 1) + ' ' + x2 + ',' + y2\n ].join(' ');\n}\n\nmodule.exports = {\n smith: smith,\n reactanceArc: reactanceArc,\n resistanceArc: resistanceArc,\n smithTransform: transform\n};\n","'use strict';\n\nvar getSubplotCalcData = require('../get_data').getSubplotCalcData;\nvar counterRegex = require('../../lib').counterRegex;\n\nvar createPolar = require('../polar/polar');\nvar constants = require('./constants');\n\nvar attr = constants.attr;\nvar name = constants.name;\nvar counter = counterRegex(name);\n\nvar attributes = {};\nattributes[attr] = {\n valType: 'subplotid',\n dflt: name,\n editType: 'calc',\n description: [\n 'Sets a reference between this trace\\'s data coordinates and',\n 'a smith subplot.',\n 'If *smith* (the default value), the data refer to `layout.smith`.',\n 'If *smith2*, the data refer to `layout.smith2`, and so on.'\n ].join(' ')\n};\n\nfunction plot(gd) {\n var fullLayout = gd._fullLayout;\n var calcData = gd.calcdata;\n var subplotIds = fullLayout._subplots[name];\n\n for(var i = 0; i < subplotIds.length; i++) {\n var id = subplotIds[i];\n var subplotCalcData = getSubplotCalcData(calcData, name, id);\n var subplot = fullLayout[id]._subplot;\n\n if(!subplot) {\n subplot = createPolar(gd, id, true);\n fullLayout[id]._subplot = subplot;\n }\n\n subplot.plot(subplotCalcData, fullLayout, gd._promises);\n }\n}\n\nfunction clean(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var oldIds = oldFullLayout._subplots[name] || [];\n for(var i = 0; i < oldIds.length; i++) {\n var id = oldIds[i];\n var oldSubplot = oldFullLayout[id]._subplot;\n\n if(!newFullLayout[id] && !!oldSubplot) {\n oldSubplot.framework.remove();\n\n for(var k in oldSubplot.clipPaths) {\n oldSubplot.clipPaths[k].remove();\n }\n }\n }\n}\n\nmodule.exports = {\n attr: attr,\n name: name,\n idRoot: name,\n idRegex: counter,\n attrRegex: counter,\n attributes: attributes,\n layoutAttributes: require('./layout_attributes'),\n supplyLayoutDefaults: require('./layout_defaults'),\n plot: plot,\n clean: clean,\n toSVG: require('../cartesian').toSVG\n};\n","'use strict';\n\nvar colorAttrs = require('../../components/color/attributes');\nvar axesAttrs = require('../cartesian/layout_attributes');\nvar domainAttrs = require('../domain').attributes;\nvar extendFlat = require('../../lib').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\n\nvar axisLineGridAttr = overrideAll({\n color: axesAttrs.color,\n showline: extendFlat({}, axesAttrs.showline, {dflt: true}),\n linecolor: axesAttrs.linecolor,\n linewidth: axesAttrs.linewidth,\n showgrid: extendFlat({}, axesAttrs.showgrid, {dflt: true}),\n gridcolor: axesAttrs.gridcolor,\n gridwidth: axesAttrs.gridwidth,\n griddash: axesAttrs.griddash\n}, 'plot', 'from-root');\n\nvar axisTickAttrs = overrideAll({\n ticklen: axesAttrs.ticklen,\n tickwidth: extendFlat({}, axesAttrs.tickwidth, {dflt: 2}),\n tickcolor: axesAttrs.tickcolor,\n showticklabels: axesAttrs.showticklabels,\n labelalias: axesAttrs.labelalias,\n showtickprefix: axesAttrs.showtickprefix,\n tickprefix: axesAttrs.tickprefix,\n showticksuffix: axesAttrs.showticksuffix,\n ticksuffix: axesAttrs.ticksuffix,\n tickfont: axesAttrs.tickfont,\n tickformat: axesAttrs.tickformat,\n hoverformat: axesAttrs.hoverformat,\n layer: axesAttrs.layer\n}, 'plot', 'from-root');\n\nvar realAxisAttrs = extendFlat({\n visible: extendFlat({}, axesAttrs.visible, {dflt: true}),\n\n tickvals: {\n dflt: [0.2, 0.5, 1, 2, 5],\n valType: 'data_array',\n editType: 'plot',\n description: 'Sets the values at which ticks on this axis appear.'\n },\n\n tickangle: extendFlat({}, axesAttrs.tickangle, {dflt: 90}),\n\n ticks: {\n valType: 'enumerated',\n values: ['top', 'bottom', ''],\n editType: 'ticks',\n description: [\n 'Determines whether ticks are drawn or not.',\n 'If **, this axis\\' ticks are not drawn.',\n 'If *top* (*bottom*), this axis\\' are drawn above (below)',\n 'the axis line.'\n ].join(' ')\n },\n\n side: {\n valType: 'enumerated',\n values: ['top', 'bottom'],\n dflt: 'top',\n editType: 'plot',\n description: [\n 'Determines on which side of real axis line',\n 'the tick and tick labels appear.'\n ].join(' ')\n },\n\n editType: 'calc',\n}, axisLineGridAttr, axisTickAttrs);\n\nvar imaginaryAxisAttrs = extendFlat({\n visible: extendFlat({}, axesAttrs.visible, {dflt: true}),\n\n tickvals: {\n valType: 'data_array',\n editType: 'plot',\n description: [\n 'Sets the values at which ticks on this axis appear.',\n 'Defaults to `realaxis.tickvals` plus the same as negatives and zero.'\n ].join(' ')\n },\n\n ticks: axesAttrs.ticks,\n\n editType: 'calc'\n}, axisLineGridAttr, axisTickAttrs);\n\nmodule.exports = {\n domain: domainAttrs({name: 'smith', editType: 'plot'}),\n\n bgcolor: {\n valType: 'color',\n editType: 'plot',\n dflt: colorAttrs.background,\n description: 'Set the background color of the subplot'\n },\n\n realaxis: realAxisAttrs,\n imaginaryaxis: imaginaryAxisAttrs,\n\n editType: 'calc'\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../../components/color');\nvar Template = require('../../plot_api/plot_template');\n\nvar handleSubplotDefaults = require('../subplot_defaults');\nvar getSubplotData = require('../get_data').getSubplotData;\n\nvar handlePrefixSuffixDefaults = require('../cartesian/prefix_suffix_defaults');\nvar handleTickLabelDefaults = require('../cartesian/tick_label_defaults');\nvar handleLineGridDefaults = require('../cartesian/line_grid_defaults');\nvar setConvertCartesian = require('../cartesian/set_convert');\n\nvar layoutAttributes = require('./layout_attributes');\nvar constants = require('./constants');\nvar axisNames = constants.axisNames;\n\nvar makeImagDflt = memoize(function(realTickvals) {\n // TODO: handle this case outside supply defaults step\n if(Lib.isTypedArray(realTickvals)) realTickvals = Array.from(realTickvals);\n\n return realTickvals.slice().reverse().map(function(x) { return -x; })\n .concat([0])\n .concat(realTickvals);\n}, String);\n\nfunction handleDefaults(contIn, contOut, coerce, opts) {\n var bgColor = coerce('bgcolor');\n opts.bgColor = Color.combine(bgColor, opts.paper_bgcolor);\n\n var subplotData = getSubplotData(opts.fullData, constants.name, opts.id);\n var layoutOut = opts.layoutOut;\n var axName;\n\n function coerceAxis(attr, dflt) {\n return coerce(axName + '.' + attr, dflt);\n }\n\n for(var i = 0; i < axisNames.length; i++) {\n axName = axisNames[i];\n\n if(!Lib.isPlainObject(contIn[axName])) {\n contIn[axName] = {};\n }\n\n var axIn = contIn[axName];\n var axOut = Template.newContainer(contOut, axName);\n axOut._id = axOut._name = axName;\n axOut._attr = opts.id + '.' + axName;\n axOut._traceIndices = subplotData.map(function(t) { return t._expandedIndex; });\n\n var visible = coerceAxis('visible');\n\n axOut.type = 'linear';\n setConvertCartesian(axOut, layoutOut);\n\n handlePrefixSuffixDefaults(axIn, axOut, coerceAxis, axOut.type);\n\n if(visible) {\n var isRealAxis = axName === 'realaxis';\n if(isRealAxis) coerceAxis('side');\n\n if(isRealAxis) {\n coerceAxis('tickvals');\n } else {\n var imagTickvalsDflt = makeImagDflt(\n contOut.realaxis.tickvals ||\n layoutAttributes.realaxis.tickvals.dflt\n );\n\n coerceAxis('tickvals', imagTickvalsDflt);\n }\n\n // TODO: handle this case outside supply defaults step\n if(Lib.isTypedArray(axOut.tickvals)) axOut.tickvals = Array.from(axOut.tickvals);\n\n var dfltColor;\n var dfltFontColor;\n var dfltFontSize;\n var dfltFontFamily;\n var font = opts.font || {};\n\n if(visible) {\n dfltColor = coerceAxis('color');\n dfltFontColor = (dfltColor === axIn.color) ? dfltColor : font.color;\n dfltFontSize = font.size;\n dfltFontFamily = font.family;\n }\n\n handleTickLabelDefaults(axIn, axOut, coerceAxis, axOut.type, {\n noAutotickangles: true,\n noTicklabelshift: true,\n noTicklabelstandoff: true,\n noTicklabelstep: true,\n noAng: !isRealAxis,\n noExp: true,\n font: {\n color: dfltFontColor,\n size: dfltFontSize,\n family: dfltFontFamily\n }\n });\n\n Lib.coerce2(contIn, contOut, layoutAttributes, axName + '.ticklen');\n Lib.coerce2(contIn, contOut, layoutAttributes, axName + '.tickwidth');\n Lib.coerce2(contIn, contOut, layoutAttributes, axName + '.tickcolor', contOut.color);\n var showTicks = coerceAxis('ticks');\n if(!showTicks) {\n delete contOut[axName].ticklen;\n delete contOut[axName].tickwidth;\n delete contOut[axName].tickcolor;\n }\n\n handleLineGridDefaults(axIn, axOut, coerceAxis, {\n dfltColor: dfltColor,\n bgColor: opts.bgColor,\n // default grid color is darker here (60%, vs cartesian default ~91%)\n // because the grid is not square so the eye needs heavier cues to follow\n blend: 60,\n showLine: true,\n showGrid: true,\n noZeroLine: true,\n attributes: layoutAttributes[axName]\n });\n\n coerceAxis('layer');\n }\n\n coerceAxis('hoverformat');\n\n delete axOut.type;\n\n axOut._input = axIn;\n }\n}\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut, fullData) {\n handleSubplotDefaults(layoutIn, layoutOut, fullData, {\n noUirevision: true,\n type: constants.name,\n attributes: layoutAttributes,\n handleDefaults: handleDefaults,\n font: layoutOut.font,\n paper_bgcolor: layoutOut.paper_bgcolor,\n fullData: fullData,\n layoutOut: layoutOut\n });\n};\n\nfunction memoize(fn, keyFn) {\n var cache = {};\n return function(val) {\n var newKey = keyFn ? keyFn(val) : val;\n if(newKey in cache) { return cache[newKey]; }\n\n var out = fn(val);\n cache[newKey] = out;\n return out;\n };\n}\n","'use strict';\n\nvar Lib = require('../lib');\nvar Template = require('../plot_api/plot_template');\nvar handleDomainDefaults = require('./domain').defaults;\n\n\n/**\n * Find and supply defaults to all subplots of a given type\n * This handles subplots that are contained within one container - so\n * gl3d, geo, ternary... but not 2d axes which have separate x and y axes\n * finds subplots, coerces their `domain` attributes, then calls the\n * given handleDefaults function to fill in everything else.\n *\n * layoutIn: the complete user-supplied input layout\n * layoutOut: the complete finished layout\n * fullData: the finished data array, used only to find subplots\n * opts: {\n * type: subplot type string\n * attributes: subplot attributes object\n * partition: 'x' or 'y', which direction to divide domain space by default\n * (default 'x', ie side-by-side subplots)\n * TODO: this option is only here because 3D and geo made opposite\n * choices in this regard previously and I didn't want to change it.\n * Instead we should do:\n * - something consistent\n * - something more square (4 cuts 2x2, 5/6 cuts 2x3, etc.)\n * - something that includes all subplot types in one arrangement,\n * now that we can have them together!\n * handleDefaults: function of (subplotLayoutIn, subplotLayoutOut, coerce, opts)\n * this opts object is passed through to handleDefaults, so attach any\n * additional items needed by this function here as well\n * }\n */\nmodule.exports = function handleSubplotDefaults(layoutIn, layoutOut, fullData, opts) {\n var subplotType = opts.type;\n var subplotAttributes = opts.attributes;\n var handleDefaults = opts.handleDefaults;\n var partition = opts.partition || 'x';\n\n var ids = layoutOut._subplots[subplotType];\n var idsLength = ids.length;\n\n var baseId = idsLength && ids[0].replace(/\\d+$/, '');\n\n var subplotLayoutIn, subplotLayoutOut;\n\n function coerce(attr, dflt) {\n return Lib.coerce(subplotLayoutIn, subplotLayoutOut, subplotAttributes, attr, dflt);\n }\n\n for(var i = 0; i < idsLength; i++) {\n var id = ids[i];\n\n // ternary traces get a layout ternary for free!\n if(layoutIn[id]) subplotLayoutIn = layoutIn[id];\n else subplotLayoutIn = layoutIn[id] = {};\n\n subplotLayoutOut = Template.newContainer(layoutOut, id, baseId);\n\n if(!opts.noUirevision) coerce('uirevision', layoutOut.uirevision);\n\n var dfltDomains = {};\n dfltDomains[partition] = [i / idsLength, (i + 1) / idsLength];\n handleDomainDefaults(subplotLayoutOut, layoutOut, coerce, dfltDomains);\n\n opts.id = id;\n handleDefaults(subplotLayoutIn, subplotLayoutOut, coerce, opts);\n }\n};\n","'use strict';\n\nvar docs = require('../constants/docs');\nvar FORMAT_LINK = docs.FORMAT_LINK;\nvar DATE_FORMAT_LINK = docs.DATE_FORMAT_LINK;\n\nfunction templateFormatStringDescription(opts) {\n var supportOther = opts && opts.supportOther;\n\n return [\n 'Variables are inserted using %{variable},',\n 'for example \"y: %{y}\"' + (\n supportOther ?\n ' as well as %{xother}, {%_xother}, {%_xother_}, {%xother_}. When showing info for several points, *xother* will be added to those with different x positions from the first point. An underscore before or after *(x|y)other* will add a space on that side, only when this field is shown.' :\n '.'\n ),\n 'Numbers are formatted using d3-format\\'s syntax %{variable:d3-format}, for example \"Price: %{y:$.2f}\".',\n FORMAT_LINK,\n 'for details on the formatting syntax.',\n 'Dates are formatted using d3-time-format\\'s syntax %{variable|d3-time-format}, for example \"Day: %{2019-01-01|%A}\".',\n DATE_FORMAT_LINK,\n 'for details on the date formatting syntax.'\n ].join(' ');\n}\n\nfunction shapeTemplateFormatStringDescription() {\n return [\n 'Variables are inserted using %{variable},',\n 'for example \"x0: %{x0}\".',\n 'Numbers are formatted using d3-format\\'s syntax %{variable:d3-format}, for example \"Price: %{x0:$.2f}\". See',\n FORMAT_LINK,\n 'for details on the formatting syntax.',\n 'Dates are formatted using d3-time-format\\'s syntax %{variable|d3-time-format}, for example \"Day: %{x0|%m %b %Y}\". See',\n DATE_FORMAT_LINK,\n 'for details on the date formatting syntax.',\n 'A single multiplication or division operation may be applied to numeric variables, and combined with',\n 'd3 number formatting, for example \"Length in cm: %{x0*2.54}\", \"%{slope*60:.1f} meters per second.\"',\n 'For log axes, variable values are given in log units.',\n 'For date axes, x/y coordinate variables and center variables use datetimes, while all other variable values use values in ms.',\n ].join(' ');\n}\n\nfunction describeVariables(extra) {\n var descPart = extra.description ? ' ' + extra.description : '';\n var keys = extra.keys || [];\n if(keys.length > 0) {\n var quotedKeys = [];\n for(var i = 0; i < keys.length; i++) {\n quotedKeys[i] = '`' + keys[i] + '`';\n }\n descPart = descPart + 'Finally, the template string has access to ';\n if(keys.length === 1) {\n descPart = descPart + 'variable ' + quotedKeys[0];\n } else {\n descPart = descPart + 'variables ' + quotedKeys.slice(0, -1).join(', ') + ' and ' + quotedKeys.slice(-1) + '.';\n }\n }\n return descPart;\n}\n\nexports.hovertemplateAttrs = function(opts, extra) {\n opts = opts || {};\n extra = extra || {};\n\n var descPart = describeVariables(extra);\n\n var hovertemplate = {\n valType: 'string',\n dflt: '',\n editType: opts.editType || 'none',\n description: [\n 'Template string used for rendering the information that appear on hover box.',\n 'Note that this will override `hoverinfo`.',\n templateFormatStringDescription({supportOther: true}),\n 'The variables available in `hovertemplate` are the ones emitted as event data described at this link https://plotly.com/javascript/plotlyjs-events/#event-data.',\n 'Additionally, every attributes that can be specified per-point (the ones that are `arrayOk: true`) are available.',\n descPart,\n 'Anything contained in tag `` is displayed in the secondary box, for example \"{fullData.name}\".',\n 'To hide the secondary box completely, use an empty tag ``.'\n ].join(' ')\n };\n\n if(opts.arrayOk !== false) {\n hovertemplate.arrayOk = true;\n }\n\n return hovertemplate;\n};\n\nexports.texttemplateAttrs = function(opts, extra) {\n opts = opts || {};\n extra = extra || {};\n\n var descPart = describeVariables(extra);\n\n var texttemplate = {\n valType: 'string',\n dflt: '',\n editType: opts.editType || 'calc',\n description: [\n 'Template string used for rendering the information text that appear on points.',\n 'Note that this will override `textinfo`.',\n templateFormatStringDescription(),\n 'Every attributes that can be specified per-point (the ones that are `arrayOk: true`) are available.',\n descPart\n ].join(' ')\n };\n\n if(opts.arrayOk !== false) {\n texttemplate.arrayOk = true;\n }\n return texttemplate;\n};\n\n\nexports.shapeTexttemplateAttrs = function(opts, extra) {\n opts = opts || {};\n extra = extra || {};\n\n var newStr = opts.newshape ? 'new ' : '';\n\n var descPart = describeVariables(extra);\n\n var texttemplate = {\n valType: 'string',\n dflt: '',\n editType: opts.editType || 'arraydraw',\n description: [\n 'Template string used for rendering the ' + newStr + 'shape\\'s label.',\n 'Note that this will override `text`.',\n shapeTemplateFormatStringDescription(),\n descPart,\n ].join(' ')\n };\n return texttemplate;\n};\n","'use strict';\n\nvar Ternary = require('./ternary');\n\nvar getSubplotCalcData = require('../../plots/get_data').getSubplotCalcData;\nvar counterRegex = require('../../lib').counterRegex;\nvar TERNARY = 'ternary';\n\nexports.name = TERNARY;\n\nvar attr = exports.attr = 'subplot';\n\nexports.idRoot = TERNARY;\n\nexports.idRegex = exports.attrRegex = counterRegex(TERNARY);\n\nvar attributes = exports.attributes = {};\nattributes[attr] = {\n valType: 'subplotid',\n dflt: 'ternary',\n editType: 'calc',\n description: [\n 'Sets a reference between this trace\\'s data coordinates and',\n 'a ternary subplot.',\n 'If *ternary* (the default value), the data refer to `layout.ternary`.',\n 'If *ternary2*, the data refer to `layout.ternary2`, and so on.'\n ].join(' ')\n};\n\nexports.layoutAttributes = require('./layout_attributes');\n\nexports.supplyLayoutDefaults = require('./layout_defaults');\n\nexports.plot = function plot(gd) {\n var fullLayout = gd._fullLayout;\n var calcData = gd.calcdata;\n var ternaryIds = fullLayout._subplots[TERNARY];\n\n for(var i = 0; i < ternaryIds.length; i++) {\n var ternaryId = ternaryIds[i];\n var ternaryCalcData = getSubplotCalcData(calcData, TERNARY, ternaryId);\n var ternary = fullLayout[ternaryId]._subplot;\n\n // If ternary is not instantiated, create one!\n if(!ternary) {\n ternary = new Ternary({\n id: ternaryId,\n graphDiv: gd,\n container: fullLayout._ternarylayer.node()\n },\n fullLayout\n );\n\n fullLayout[ternaryId]._subplot = ternary;\n }\n\n ternary.plot(ternaryCalcData, fullLayout, gd._promises);\n }\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var oldTernaryKeys = oldFullLayout._subplots[TERNARY] || [];\n\n for(var i = 0; i < oldTernaryKeys.length; i++) {\n var oldTernaryKey = oldTernaryKeys[i];\n var oldTernary = oldFullLayout[oldTernaryKey]._subplot;\n\n if(!newFullLayout[oldTernaryKey] && !!oldTernary) {\n oldTernary.plotContainer.remove();\n oldTernary.clipDef.remove();\n oldTernary.clipDefRelative.remove();\n oldTernary.layers['a-title'].remove();\n oldTernary.layers['b-title'].remove();\n oldTernary.layers['c-title'].remove();\n }\n }\n};\n\nexports.updateFx = function(gd) {\n var fullLayout = gd._fullLayout;\n fullLayout._ternarylayer\n .selectAll('g.toplevel')\n .style('cursor', fullLayout.dragmode === 'pan' ? 'move' : 'crosshair');\n};\n","'use strict';\n\nvar colorAttrs = require('../../components/color/attributes');\nvar domainAttrs = require('../domain').attributes;\nvar axesAttrs = require('../cartesian/layout_attributes');\n\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar ternaryAxesAttrs = {\n title: {\n text: axesAttrs.title.text,\n font: axesAttrs.title.font\n // TODO does standoff here make sense?\n },\n color: axesAttrs.color,\n // ticks\n tickmode: axesAttrs.minor.tickmode,\n nticks: extendFlat({}, axesAttrs.nticks, {dflt: 6, min: 1}),\n tick0: axesAttrs.tick0,\n dtick: axesAttrs.dtick,\n tickvals: axesAttrs.tickvals,\n ticktext: axesAttrs.ticktext,\n ticks: axesAttrs.ticks,\n ticklen: axesAttrs.ticklen,\n tickwidth: axesAttrs.tickwidth,\n tickcolor: axesAttrs.tickcolor,\n ticklabelstep: axesAttrs.ticklabelstep,\n showticklabels: axesAttrs.showticklabels,\n labelalias: axesAttrs.labelalias,\n showtickprefix: axesAttrs.showtickprefix,\n tickprefix: axesAttrs.tickprefix,\n showticksuffix: axesAttrs.showticksuffix,\n ticksuffix: axesAttrs.ticksuffix,\n showexponent: axesAttrs.showexponent,\n exponentformat: axesAttrs.exponentformat,\n minexponent: axesAttrs.minexponent,\n separatethousands: axesAttrs.separatethousands,\n tickfont: axesAttrs.tickfont,\n tickangle: axesAttrs.tickangle,\n tickformat: axesAttrs.tickformat,\n tickformatstops: axesAttrs.tickformatstops,\n hoverformat: axesAttrs.hoverformat,\n // lines and grids\n showline: extendFlat({}, axesAttrs.showline, {dflt: true}),\n linecolor: axesAttrs.linecolor,\n linewidth: axesAttrs.linewidth,\n showgrid: extendFlat({}, axesAttrs.showgrid, {dflt: true}),\n gridcolor: axesAttrs.gridcolor,\n gridwidth: axesAttrs.gridwidth,\n griddash: axesAttrs.griddash,\n layer: axesAttrs.layer,\n // range\n min: {\n valType: 'number',\n dflt: 0,\n min: 0,\n description: [\n 'The minimum value visible on this axis.',\n 'The maximum is determined by the sum minus the minimum',\n 'values of the other two axes. The full view corresponds to',\n 'all the minima set to zero.'\n ].join(' ')\n },\n _deprecated: {\n title: axesAttrs._deprecated.title,\n titlefont: axesAttrs._deprecated.titlefont\n }\n};\n\nvar attrs = module.exports = overrideAll({\n domain: domainAttrs({name: 'ternary'}),\n\n bgcolor: {\n valType: 'color',\n dflt: colorAttrs.background,\n description: 'Set the background color of the subplot'\n },\n sum: {\n valType: 'number',\n dflt: 1,\n min: 0,\n description: [\n 'The number each triplet should sum to,',\n 'and the maximum range of each axis'\n ].join(' ')\n },\n aaxis: ternaryAxesAttrs,\n baxis: ternaryAxesAttrs,\n caxis: ternaryAxesAttrs\n}, 'plot', 'from-root');\n\n// set uirevisions outside of `overrideAll` so we can get `editType: none`\nattrs.uirevision = {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in axis `min` and `title`,',\n 'if not overridden in the individual axes.',\n 'Defaults to `layout.uirevision`.'\n ].join(' ')\n};\n\nattrs.aaxis.uirevision = attrs.baxis.uirevision = attrs.caxis.uirevision = {\n valType: 'any',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in axis `min`,',\n 'and `title` if in `editable: true` configuration.',\n 'Defaults to `ternary.uirevision`.'\n ].join(' ')\n};\n","'use strict';\n\nvar Color = require('../../components/color');\nvar Template = require('../../plot_api/plot_template');\nvar Lib = require('../../lib');\n\nvar handleSubplotDefaults = require('../subplot_defaults');\nvar handleTickLabelDefaults = require('../cartesian/tick_label_defaults');\nvar handlePrefixSuffixDefaults = require('../cartesian/prefix_suffix_defaults');\nvar handleTickMarkDefaults = require('../cartesian/tick_mark_defaults');\nvar handleTickValueDefaults = require('../cartesian/tick_value_defaults');\nvar handleLineGridDefaults = require('../cartesian/line_grid_defaults');\nvar layoutAttributes = require('./layout_attributes');\n\nvar axesNames = ['aaxis', 'baxis', 'caxis'];\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut, fullData) {\n handleSubplotDefaults(layoutIn, layoutOut, fullData, {\n type: 'ternary',\n attributes: layoutAttributes,\n handleDefaults: handleTernaryDefaults,\n font: layoutOut.font,\n paper_bgcolor: layoutOut.paper_bgcolor\n });\n};\n\nfunction handleTernaryDefaults(ternaryLayoutIn, ternaryLayoutOut, coerce, options) {\n var bgColor = coerce('bgcolor');\n var sum = coerce('sum');\n options.bgColor = Color.combine(bgColor, options.paper_bgcolor);\n var axName, containerIn, containerOut;\n\n // TODO: allow most (if not all) axis attributes to be set\n // in the outer container and used as defaults in the individual axes?\n\n for(var j = 0; j < axesNames.length; j++) {\n axName = axesNames[j];\n containerIn = ternaryLayoutIn[axName] || {};\n containerOut = Template.newContainer(ternaryLayoutOut, axName);\n containerOut._name = axName;\n\n handleAxisDefaults(containerIn, containerOut, options, ternaryLayoutOut);\n }\n\n // if the min values contradict each other, set them all to default (0)\n // and delete *all* the inputs so the user doesn't get confused later by\n // changing one and having them all change.\n var aaxis = ternaryLayoutOut.aaxis;\n var baxis = ternaryLayoutOut.baxis;\n var caxis = ternaryLayoutOut.caxis;\n if(aaxis.min + baxis.min + caxis.min >= sum) {\n aaxis.min = 0;\n baxis.min = 0;\n caxis.min = 0;\n if(ternaryLayoutIn.aaxis) delete ternaryLayoutIn.aaxis.min;\n if(ternaryLayoutIn.baxis) delete ternaryLayoutIn.baxis.min;\n if(ternaryLayoutIn.caxis) delete ternaryLayoutIn.caxis.min;\n }\n}\n\nfunction handleAxisDefaults(containerIn, containerOut, options, ternaryLayoutOut) {\n var axAttrs = layoutAttributes[containerOut._name];\n\n function coerce(attr, dflt) {\n return Lib.coerce(containerIn, containerOut, axAttrs, attr, dflt);\n }\n\n coerce('uirevision', ternaryLayoutOut.uirevision);\n\n containerOut.type = 'linear'; // no other types allowed for ternary\n\n var dfltColor = coerce('color');\n // if axis.color was provided, use it for fonts too; otherwise,\n // inherit from global font color in case that was provided.\n var dfltFontColor = (dfltColor !== axAttrs.color.dflt) ? dfltColor : options.font.color;\n\n var axName = containerOut._name;\n var letterUpper = axName.charAt(0).toUpperCase();\n var dfltTitle = 'Component ' + letterUpper;\n\n var title = coerce('title.text', dfltTitle);\n containerOut._hovertitle = title === dfltTitle ? title : letterUpper;\n\n Lib.coerceFont(coerce, 'title.font', options.font, { overrideDflt: {\n size: Lib.bigFont(options.font.size),\n color: dfltFontColor\n }});\n\n // range is just set by 'min' - max is determined by the other axes mins\n coerce('min');\n\n handleTickValueDefaults(containerIn, containerOut, coerce, 'linear');\n handlePrefixSuffixDefaults(containerIn, containerOut, coerce, 'linear');\n handleTickLabelDefaults(containerIn, containerOut, coerce, 'linear', {\n noAutotickangles: true,\n noTicklabelshift: true,\n noTicklabelstandoff: true\n });\n handleTickMarkDefaults(containerIn, containerOut, coerce,\n { outerTicks: true });\n\n var showTickLabels = coerce('showticklabels');\n if(showTickLabels) {\n Lib.coerceFont(coerce, 'tickfont', options.font, { overrideDflt: {\n color: dfltFontColor\n }});\n coerce('tickangle');\n coerce('tickformat');\n }\n\n handleLineGridDefaults(containerIn, containerOut, coerce, {\n dfltColor: dfltColor,\n bgColor: options.bgColor,\n // default grid color is darker here (60%, vs cartesian default ~91%)\n // because the grid is not square so the eye needs heavier cues to follow\n blend: 60,\n showLine: true,\n showGrid: true,\n noZeroLine: true,\n attributes: axAttrs\n });\n\n coerce('hoverformat');\n coerce('layer');\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar tinycolor = require('tinycolor2');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar _ = Lib._;\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\nvar setConvert = require('../cartesian/set_convert');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar Plots = require('../plots');\nvar Axes = require('../cartesian/axes');\nvar dragElement = require('../../components/dragelement');\nvar Fx = require('../../components/fx');\nvar dragHelpers = require('../../components/dragelement/helpers');\nvar freeMode = dragHelpers.freeMode;\nvar rectMode = dragHelpers.rectMode;\nvar Titles = require('../../components/titles');\nvar prepSelect = require('../../components/selections').prepSelect;\nvar selectOnClick = require('../../components/selections').selectOnClick;\nvar clearOutline = require('../../components/selections').clearOutline;\nvar clearSelectionsCache = require('../../components/selections').clearSelectionsCache;\nvar constants = require('../cartesian/constants');\n\nfunction Ternary(options, fullLayout) {\n this.id = options.id;\n this.graphDiv = options.graphDiv;\n this.init(fullLayout);\n this.makeFramework(fullLayout);\n this.updateFx(fullLayout);\n\n // unfortunately, we have to keep track of some axis tick settings\n // as ternary subplots do not implement the 'ticks' editType\n this.aTickLayout = null;\n this.bTickLayout = null;\n this.cTickLayout = null;\n}\n\nmodule.exports = Ternary;\n\nvar proto = Ternary.prototype;\n\nproto.init = function(fullLayout) {\n this.container = fullLayout._ternarylayer;\n this.defs = fullLayout._defs;\n this.layoutId = fullLayout._uid;\n this.traceHash = {};\n this.layers = {};\n};\n\nproto.plot = function(ternaryCalcData, fullLayout) {\n var _this = this;\n var ternaryLayout = fullLayout[_this.id];\n var graphSize = fullLayout._size;\n\n _this._hasClipOnAxisFalse = false;\n for(var i = 0; i < ternaryCalcData.length; i++) {\n var trace = ternaryCalcData[i][0].trace;\n\n if(trace.cliponaxis === false) {\n _this._hasClipOnAxisFalse = true;\n break;\n }\n }\n\n _this.updateLayers(ternaryLayout);\n _this.adjustLayout(ternaryLayout, graphSize);\n Plots.generalUpdatePerTraceModule(_this.graphDiv, _this, ternaryCalcData, ternaryLayout);\n _this.layers.plotbg.select('path').call(Color.fill, ternaryLayout.bgcolor);\n};\n\nproto.makeFramework = function(fullLayout) {\n var _this = this;\n var gd = _this.graphDiv;\n var ternaryLayout = fullLayout[_this.id];\n\n var clipId = _this.clipId = 'clip' + _this.layoutId + _this.id;\n var clipIdRelative = _this.clipIdRelative = 'clip-relative' + _this.layoutId + _this.id;\n\n // clippath for this ternary subplot\n _this.clipDef = Lib.ensureSingleById(fullLayout._clips, 'clipPath', clipId, function(s) {\n s.append('path').attr('d', 'M0,0Z');\n });\n\n // 'relative' clippath (i.e. no translation) for this ternary subplot\n _this.clipDefRelative = Lib.ensureSingleById(fullLayout._clips, 'clipPath', clipIdRelative, function(s) {\n s.append('path').attr('d', 'M0,0Z');\n });\n\n // container for everything in this ternary subplot\n _this.plotContainer = Lib.ensureSingle(_this.container, 'g', _this.id);\n _this.updateLayers(ternaryLayout);\n\n Drawing.setClipUrl(_this.layers.backplot, clipId, gd);\n Drawing.setClipUrl(_this.layers.grids, clipId, gd);\n};\n\nproto.updateFx = function(fullLayout) {\n fullLayout._ternarylayer\n .selectAll('g.toplevel')\n .style('cursor', fullLayout.dragmode === 'pan' ? 'move' : 'crosshair');\n};\n\nproto.updateLayers = function(ternaryLayout) {\n var _this = this;\n var layers = _this.layers;\n\n // inside that container, we have one container for the data, and\n // one each for the three axes around it.\n\n var plotLayers = ['draglayer', 'plotbg', 'backplot', 'grids'];\n\n if(ternaryLayout.aaxis.layer === 'below traces') {\n plotLayers.push('aaxis', 'aline');\n }\n if(ternaryLayout.baxis.layer === 'below traces') {\n plotLayers.push('baxis', 'bline');\n }\n if(ternaryLayout.caxis.layer === 'below traces') {\n plotLayers.push('caxis', 'cline');\n }\n\n plotLayers.push('frontplot');\n\n if(ternaryLayout.aaxis.layer === 'above traces') {\n plotLayers.push('aaxis', 'aline');\n }\n if(ternaryLayout.baxis.layer === 'above traces') {\n plotLayers.push('baxis', 'bline');\n }\n if(ternaryLayout.caxis.layer === 'above traces') {\n plotLayers.push('caxis', 'cline');\n }\n\n var toplevel = _this.plotContainer.selectAll('g.toplevel')\n .data(plotLayers, String);\n\n var grids = ['agrid', 'bgrid', 'cgrid'];\n\n toplevel.enter().append('g')\n .attr('class', function(d) { return 'toplevel ' + d; })\n .each(function(d) {\n var s = d3.select(this);\n layers[d] = s;\n\n // containers for different trace types.\n // NOTE - this is different from cartesian, where all traces\n // are in front of grids. Here I'm putting maps behind the grids\n // so the grids will always be visible if they're requested.\n // Perhaps we want that for cartesian too?\n if(d === 'frontplot') {\n s.append('g').classed('scatterlayer', true);\n } else if(d === 'backplot') {\n s.append('g').classed('maplayer', true);\n } else if(d === 'plotbg') {\n s.append('path').attr('d', 'M0,0Z');\n } else if(d === 'aline' || d === 'bline' || d === 'cline') {\n s.append('path');\n } else if(d === 'grids') {\n grids.forEach(function(d) {\n layers[d] = s.append('g').classed('grid ' + d, true);\n });\n }\n });\n\n toplevel.order();\n};\n\nvar whRatio = Math.sqrt(4 / 3);\n\nproto.adjustLayout = function(ternaryLayout, graphSize) {\n var _this = this;\n var domain = ternaryLayout.domain;\n var xDomainCenter = (domain.x[0] + domain.x[1]) / 2;\n var yDomainCenter = (domain.y[0] + domain.y[1]) / 2;\n var xDomain = domain.x[1] - domain.x[0];\n var yDomain = domain.y[1] - domain.y[0];\n var wmax = xDomain * graphSize.w;\n var hmax = yDomain * graphSize.h;\n var sum = ternaryLayout.sum;\n var amin = ternaryLayout.aaxis.min;\n var bmin = ternaryLayout.baxis.min;\n var cmin = ternaryLayout.caxis.min;\n\n var x0, y0, w, h, xDomainFinal, yDomainFinal;\n\n if(wmax > whRatio * hmax) {\n h = hmax;\n w = h * whRatio;\n } else {\n w = wmax;\n h = w / whRatio;\n }\n\n xDomainFinal = xDomain * w / wmax;\n yDomainFinal = yDomain * h / hmax;\n\n x0 = graphSize.l + graphSize.w * xDomainCenter - w / 2;\n y0 = graphSize.t + graphSize.h * (1 - yDomainCenter) - h / 2;\n\n _this.x0 = x0;\n _this.y0 = y0;\n _this.w = w;\n _this.h = h;\n _this.sum = sum;\n\n // set up the x and y axis objects we'll use to lay out the points\n _this.xaxis = {\n type: 'linear',\n range: [amin + 2 * cmin - sum, sum - amin - 2 * bmin],\n domain: [\n xDomainCenter - xDomainFinal / 2,\n xDomainCenter + xDomainFinal / 2\n ],\n _id: 'x'\n };\n setConvert(_this.xaxis, _this.graphDiv._fullLayout);\n _this.xaxis.setScale();\n _this.xaxis.isPtWithinRange = function(d) {\n return (\n d.a >= _this.aaxis.range[0] &&\n d.a <= _this.aaxis.range[1] &&\n d.b >= _this.baxis.range[1] &&\n d.b <= _this.baxis.range[0] &&\n d.c >= _this.caxis.range[1] &&\n d.c <= _this.caxis.range[0]\n );\n };\n\n _this.yaxis = {\n type: 'linear',\n range: [amin, sum - bmin - cmin],\n domain: [\n yDomainCenter - yDomainFinal / 2,\n yDomainCenter + yDomainFinal / 2\n ],\n _id: 'y'\n };\n setConvert(_this.yaxis, _this.graphDiv._fullLayout);\n _this.yaxis.setScale();\n _this.yaxis.isPtWithinRange = function() { return true; };\n\n // set up the modified axes for tick drawing\n var yDomain0 = _this.yaxis.domain[0];\n\n // aaxis goes up the left side. Set it up as a y axis, but with\n // fictitious angles and domain, but then rotate and translate\n // it into place at the end\n var aaxis = _this.aaxis = extendFlat({}, ternaryLayout.aaxis, {\n range: [amin, sum - bmin - cmin],\n side: 'left',\n // tickangle = 'auto' means 0 anyway for a y axis, need to coerce to 0 here\n // so we can shift by 30.\n tickangle: (+ternaryLayout.aaxis.tickangle || 0) - 30,\n domain: [yDomain0, yDomain0 + yDomainFinal * whRatio],\n anchor: 'free',\n position: 0,\n _id: 'y',\n _length: w\n });\n setConvert(aaxis, _this.graphDiv._fullLayout);\n aaxis.setScale();\n\n // baxis goes across the bottom (backward). We can set it up as an x axis\n // without any enclosing transformation.\n var baxis = _this.baxis = extendFlat({}, ternaryLayout.baxis, {\n range: [sum - amin - cmin, bmin],\n side: 'bottom',\n domain: _this.xaxis.domain,\n anchor: 'free',\n position: 0,\n _id: 'x',\n _length: w\n });\n setConvert(baxis, _this.graphDiv._fullLayout);\n baxis.setScale();\n\n // caxis goes down the right side. Set it up as a y axis, with\n // post-transformation similar to aaxis\n var caxis = _this.caxis = extendFlat({}, ternaryLayout.caxis, {\n range: [sum - amin - bmin, cmin],\n side: 'right',\n tickangle: (+ternaryLayout.caxis.tickangle || 0) + 30,\n domain: [yDomain0, yDomain0 + yDomainFinal * whRatio],\n anchor: 'free',\n position: 0,\n _id: 'y',\n _length: w\n });\n setConvert(caxis, _this.graphDiv._fullLayout);\n caxis.setScale();\n\n var triangleClip = 'M' + x0 + ',' + (y0 + h) + 'h' + w + 'l-' + (w / 2) + ',-' + h + 'Z';\n _this.clipDef.select('path').attr('d', triangleClip);\n _this.layers.plotbg.select('path').attr('d', triangleClip);\n\n var triangleClipRelative = 'M0,' + h + 'h' + w + 'l-' + (w / 2) + ',-' + h + 'Z';\n _this.clipDefRelative.select('path').attr('d', triangleClipRelative);\n\n var plotTransform = strTranslate(x0, y0);\n _this.plotContainer.selectAll('.scatterlayer,.maplayer')\n .attr('transform', plotTransform);\n\n _this.clipDefRelative.select('path').attr('transform', null);\n\n // TODO: shift axes to accommodate linewidth*sin(30) tick mark angle\n\n // TODO: there's probably an easier way to handle these translations/offsets now...\n var bTransform = strTranslate(x0 - baxis._offset, y0 + h);\n\n _this.layers.baxis.attr('transform', bTransform);\n _this.layers.bgrid.attr('transform', bTransform);\n\n var aTransform = strTranslate(x0 + w / 2, y0) +\n 'rotate(30)' + strTranslate(0, -aaxis._offset);\n _this.layers.aaxis.attr('transform', aTransform);\n _this.layers.agrid.attr('transform', aTransform);\n\n var cTransform = strTranslate(x0 + w / 2, y0) +\n 'rotate(-30)' + strTranslate(0, -caxis._offset);\n _this.layers.caxis.attr('transform', cTransform);\n _this.layers.cgrid.attr('transform', cTransform);\n\n _this.drawAxes(true);\n\n _this.layers.aline.select('path')\n .attr('d', aaxis.showline ?\n 'M' + x0 + ',' + (y0 + h) + 'l' + (w / 2) + ',-' + h : 'M0,0')\n .call(Color.stroke, aaxis.linecolor || '#000')\n .style('stroke-width', (aaxis.linewidth || 0) + 'px');\n _this.layers.bline.select('path')\n .attr('d', baxis.showline ?\n 'M' + x0 + ',' + (y0 + h) + 'h' + w : 'M0,0')\n .call(Color.stroke, baxis.linecolor || '#000')\n .style('stroke-width', (baxis.linewidth || 0) + 'px');\n _this.layers.cline.select('path')\n .attr('d', caxis.showline ?\n 'M' + (x0 + w / 2) + ',' + y0 + 'l' + (w / 2) + ',' + h : 'M0,0')\n .call(Color.stroke, caxis.linecolor || '#000')\n .style('stroke-width', (caxis.linewidth || 0) + 'px');\n\n if(!_this.graphDiv._context.staticPlot) {\n _this.initInteractions();\n }\n\n Drawing.setClipUrl(\n _this.layers.frontplot,\n _this._hasClipOnAxisFalse ? null : _this.clipId,\n _this.graphDiv\n );\n};\n\nproto.drawAxes = function(doTitles) {\n var _this = this;\n var gd = _this.graphDiv;\n var titlesuffix = _this.id.substr(7) + 'title';\n var layers = _this.layers;\n var aaxis = _this.aaxis;\n var baxis = _this.baxis;\n var caxis = _this.caxis;\n\n _this.drawAx(aaxis);\n _this.drawAx(baxis);\n _this.drawAx(caxis);\n\n if(doTitles) {\n var apad = Math.max(aaxis.showticklabels ? aaxis.tickfont.size / 2 : 0,\n (caxis.showticklabels ? caxis.tickfont.size * 0.75 : 0) +\n (caxis.ticks === 'outside' ? caxis.ticklen * 0.87 : 0));\n var bpad = (baxis.showticklabels ? baxis.tickfont.size : 0) +\n (baxis.ticks === 'outside' ? baxis.ticklen : 0) + 3;\n\n layers['a-title'] = Titles.draw(gd, 'a' + titlesuffix, {\n propContainer: aaxis,\n propName: _this.id + '.aaxis.title',\n placeholder: _(gd, 'Click to enter Component A title'),\n attributes: {\n x: _this.x0 + _this.w / 2,\n y: _this.y0 - aaxis.title.font.size / 3 - apad,\n 'text-anchor': 'middle'\n }\n });\n layers['b-title'] = Titles.draw(gd, 'b' + titlesuffix, {\n propContainer: baxis,\n propName: _this.id + '.baxis.title',\n placeholder: _(gd, 'Click to enter Component B title'),\n attributes: {\n x: _this.x0 - bpad,\n y: _this.y0 + _this.h + baxis.title.font.size * 0.83 + bpad,\n 'text-anchor': 'middle'\n }\n });\n layers['c-title'] = Titles.draw(gd, 'c' + titlesuffix, {\n propContainer: caxis,\n propName: _this.id + '.caxis.title',\n placeholder: _(gd, 'Click to enter Component C title'),\n attributes: {\n x: _this.x0 + _this.w + bpad,\n y: _this.y0 + _this.h + caxis.title.font.size * 0.83 + bpad,\n 'text-anchor': 'middle'\n }\n });\n }\n};\n\nproto.drawAx = function(ax) {\n var _this = this;\n var gd = _this.graphDiv;\n var axName = ax._name;\n var axLetter = axName.charAt(0);\n var axId = ax._id;\n var axLayer = _this.layers[axName];\n var counterAngle = 30;\n\n var stashKey = axLetter + 'tickLayout';\n var newTickLayout = strTickLayout(ax);\n if(_this[stashKey] !== newTickLayout) {\n axLayer.selectAll('.' + axId + 'tick').remove();\n _this[stashKey] = newTickLayout;\n }\n\n ax.setScale();\n\n var vals = Axes.calcTicks(ax);\n var valsClipped = Axes.clipEnds(ax, vals);\n var transFn = Axes.makeTransTickFn(ax);\n var tickSign = Axes.getTickSigns(ax)[2];\n\n var caRad = Lib.deg2rad(counterAngle);\n var pad = tickSign * (ax.linewidth || 1) / 2;\n var len = tickSign * ax.ticklen;\n var w = _this.w;\n var h = _this.h;\n\n var tickPath = axLetter === 'b' ?\n 'M0,' + pad + 'l' + (Math.sin(caRad) * len) + ',' + (Math.cos(caRad) * len) :\n 'M' + pad + ',0l' + (Math.cos(caRad) * len) + ',' + (-Math.sin(caRad) * len);\n\n var gridPath = {\n a: 'M0,0l' + h + ',-' + (w / 2),\n b: 'M0,0l-' + (w / 2) + ',-' + h,\n c: 'M0,0l-' + h + ',' + (w / 2)\n }[axLetter];\n\n Axes.drawTicks(gd, ax, {\n vals: ax.ticks === 'inside' ? valsClipped : vals,\n layer: axLayer,\n path: tickPath,\n transFn: transFn,\n crisp: false\n });\n\n Axes.drawGrid(gd, ax, {\n vals: valsClipped,\n layer: _this.layers[axLetter + 'grid'],\n path: gridPath,\n transFn: transFn,\n crisp: false\n });\n\n Axes.drawLabels(gd, ax, {\n vals: vals,\n layer: axLayer,\n transFn: transFn,\n labelFns: Axes.makeLabelFns(ax, 0, counterAngle)\n });\n};\n\nfunction strTickLayout(axLayout) {\n return axLayout.ticks + String(axLayout.ticklen) + String(axLayout.showticklabels);\n}\n\n// hard coded paths for zoom corners\n// uses the same sizing as cartesian, length is MINZOOM/2, width is 3px\nvar CLEN = constants.MINZOOM / 2 + 0.87;\nvar BLPATH = 'm-0.87,.5h' + CLEN + 'v3h-' + (CLEN + 5.2) +\n 'l' + (CLEN / 2 + 2.6) + ',-' + (CLEN * 0.87 + 4.5) +\n 'l2.6,1.5l-' + (CLEN / 2) + ',' + (CLEN * 0.87) + 'Z';\nvar BRPATH = 'm0.87,.5h-' + CLEN + 'v3h' + (CLEN + 5.2) +\n 'l-' + (CLEN / 2 + 2.6) + ',-' + (CLEN * 0.87 + 4.5) +\n 'l-2.6,1.5l' + (CLEN / 2) + ',' + (CLEN * 0.87) + 'Z';\nvar TOPPATH = 'm0,1l' + (CLEN / 2) + ',' + (CLEN * 0.87) +\n 'l2.6,-1.5l-' + (CLEN / 2 + 2.6) + ',-' + (CLEN * 0.87 + 4.5) +\n 'l-' + (CLEN / 2 + 2.6) + ',' + (CLEN * 0.87 + 4.5) +\n 'l2.6,1.5l' + (CLEN / 2) + ',-' + (CLEN * 0.87) + 'Z';\nvar STARTMARKER = 'm0.5,0.5h5v-2h-5v-5h-2v5h-5v2h5v5h2Z';\n\n// I guess this could be shared with cartesian... but for now it's separate.\nvar SHOWZOOMOUTTIP = true;\n\nproto.clearOutline = function() {\n clearSelectionsCache(this.dragOptions);\n clearOutline(this.dragOptions.gd);\n};\n\nproto.initInteractions = function() {\n var _this = this;\n var dragger = _this.layers.plotbg.select('path').node();\n var gd = _this.graphDiv;\n var zoomLayer = gd._fullLayout._zoomlayer;\n var scaleX;\n var scaleY;\n\n // use plotbg for the main interactions\n this.dragOptions = {\n element: dragger,\n gd: gd,\n plotinfo: {\n id: _this.id,\n domain: gd._fullLayout[_this.id].domain,\n xaxis: _this.xaxis,\n yaxis: _this.yaxis\n },\n subplot: _this.id,\n prepFn: function(e, startX, startY) {\n // these aren't available yet when initInteractions\n // is called\n _this.dragOptions.xaxes = [_this.xaxis];\n _this.dragOptions.yaxes = [_this.yaxis];\n\n scaleX = gd._fullLayout._invScaleX;\n scaleY = gd._fullLayout._invScaleY;\n\n var dragModeNow = _this.dragOptions.dragmode = gd._fullLayout.dragmode;\n\n if(freeMode(dragModeNow)) _this.dragOptions.minDrag = 1;\n else _this.dragOptions.minDrag = undefined;\n\n if(dragModeNow === 'zoom') {\n _this.dragOptions.moveFn = zoomMove;\n _this.dragOptions.clickFn = clickZoomPan;\n _this.dragOptions.doneFn = zoomDone;\n zoomPrep(e, startX, startY);\n } else if(dragModeNow === 'pan') {\n _this.dragOptions.moveFn = plotDrag;\n _this.dragOptions.clickFn = clickZoomPan;\n _this.dragOptions.doneFn = dragDone;\n panPrep();\n _this.clearOutline(gd);\n } else if(rectMode(dragModeNow) || freeMode(dragModeNow)) {\n prepSelect(e, startX, startY, _this.dragOptions, dragModeNow);\n }\n }\n };\n\n var x0, y0, mins0, span0, mins, lum, path0, dimmed, zb, corners;\n\n function makeUpdate(_mins) {\n var attrs = {};\n attrs[_this.id + '.aaxis.min'] = _mins.a;\n attrs[_this.id + '.baxis.min'] = _mins.b;\n attrs[_this.id + '.caxis.min'] = _mins.c;\n return attrs;\n }\n\n function clickZoomPan(numClicks, evt) {\n var clickMode = gd._fullLayout.clickmode;\n\n removeZoombox(gd);\n\n if(numClicks === 2) {\n gd.emit('plotly_doubleclick', null);\n Registry.call('_guiRelayout', gd, makeUpdate({a: 0, b: 0, c: 0}));\n }\n\n if(clickMode.indexOf('select') > -1 && numClicks === 1) {\n selectOnClick(evt, gd, [_this.xaxis], [_this.yaxis], _this.id, _this.dragOptions);\n }\n\n if(clickMode.indexOf('event') > -1) {\n Fx.click(gd, evt, _this.id);\n }\n }\n\n function zoomPrep(e, startX, startY) {\n var dragBBox = dragger.getBoundingClientRect();\n x0 = startX - dragBBox.left;\n y0 = startY - dragBBox.top;\n\n gd._fullLayout._calcInverseTransform(gd);\n var inverse = gd._fullLayout._invTransform;\n var transformedCoords = Lib.apply3DTransform(inverse)(x0, y0);\n x0 = transformedCoords[0];\n y0 = transformedCoords[1];\n\n mins0 = {\n a: _this.aaxis.range[0],\n b: _this.baxis.range[1],\n c: _this.caxis.range[1]\n };\n mins = mins0;\n span0 = _this.aaxis.range[1] - mins0.a;\n lum = tinycolor(_this.graphDiv._fullLayout[_this.id].bgcolor).getLuminance();\n path0 = 'M0,' + _this.h + 'L' + (_this.w / 2) + ', 0L' + _this.w + ',' + _this.h + 'Z';\n dimmed = false;\n\n zb = zoomLayer.append('path')\n .attr('class', 'zoombox')\n .attr('transform', strTranslate(_this.x0, _this.y0))\n .style({\n fill: lum > 0.2 ? 'rgba(0,0,0,0)' : 'rgba(255,255,255,0)',\n 'stroke-width': 0\n })\n .attr('d', path0);\n\n corners = zoomLayer.append('path')\n .attr('class', 'zoombox-corners')\n .attr('transform', strTranslate(_this.x0, _this.y0))\n .style({\n fill: Color.background,\n stroke: Color.defaultLine,\n 'stroke-width': 1,\n opacity: 0\n })\n .attr('d', 'M0,0Z');\n\n _this.clearOutline(gd);\n }\n\n function getAFrac(x, y) { return 1 - (y / _this.h); }\n function getBFrac(x, y) { return 1 - ((x + (_this.h - y) / Math.sqrt(3)) / _this.w); }\n function getCFrac(x, y) { return ((x - (_this.h - y) / Math.sqrt(3)) / _this.w); }\n\n function zoomMove(dx0, dy0) {\n var x1 = x0 + dx0 * scaleX;\n var y1 = y0 + dy0 * scaleY;\n var afrac = Math.max(0, Math.min(1, getAFrac(x0, y0), getAFrac(x1, y1)));\n var bfrac = Math.max(0, Math.min(1, getBFrac(x0, y0), getBFrac(x1, y1)));\n var cfrac = Math.max(0, Math.min(1, getCFrac(x0, y0), getCFrac(x1, y1)));\n var xLeft = ((afrac / 2) + cfrac) * _this.w;\n var xRight = (1 - (afrac / 2) - bfrac) * _this.w;\n var xCenter = (xLeft + xRight) / 2;\n var xSpan = xRight - xLeft;\n var yBottom = (1 - afrac) * _this.h;\n var yTop = yBottom - xSpan / whRatio;\n\n if(xSpan < constants.MINZOOM) {\n mins = mins0;\n zb.attr('d', path0);\n corners.attr('d', 'M0,0Z');\n } else {\n mins = {\n a: mins0.a + afrac * span0,\n b: mins0.b + bfrac * span0,\n c: mins0.c + cfrac * span0\n };\n zb.attr('d', path0 + 'M' + xLeft + ',' + yBottom +\n 'H' + xRight + 'L' + xCenter + ',' + yTop +\n 'L' + xLeft + ',' + yBottom + 'Z');\n corners.attr('d', 'M' + x0 + ',' + y0 + STARTMARKER +\n 'M' + xLeft + ',' + yBottom + BLPATH +\n 'M' + xRight + ',' + yBottom + BRPATH +\n 'M' + xCenter + ',' + yTop + TOPPATH);\n }\n\n if(!dimmed) {\n zb.transition()\n .style('fill', lum > 0.2 ? 'rgba(0,0,0,0.4)' :\n 'rgba(255,255,255,0.3)')\n .duration(200);\n corners.transition()\n .style('opacity', 1)\n .duration(200);\n dimmed = true;\n }\n\n gd.emit('plotly_relayouting', makeUpdate(mins));\n }\n\n function zoomDone() {\n removeZoombox(gd);\n\n if(mins === mins0) return;\n\n Registry.call('_guiRelayout', gd, makeUpdate(mins));\n\n if(SHOWZOOMOUTTIP && gd.data && gd._context.showTips) {\n Lib.notifier(_(gd, 'Double-click to zoom back out'), 'long');\n SHOWZOOMOUTTIP = false;\n }\n }\n\n function panPrep() {\n mins0 = {\n a: _this.aaxis.range[0],\n b: _this.baxis.range[1],\n c: _this.caxis.range[1]\n };\n mins = mins0;\n }\n\n function plotDrag(dx, dy) {\n var dxScaled = dx / _this.xaxis._m;\n var dyScaled = dy / _this.yaxis._m;\n mins = {\n a: mins0.a - dyScaled,\n b: mins0.b + (dxScaled + dyScaled) / 2,\n c: mins0.c - (dxScaled - dyScaled) / 2\n };\n var minsorted = [mins.a, mins.b, mins.c].sort(Lib.sorterAsc);\n var minindices = {\n a: minsorted.indexOf(mins.a),\n b: minsorted.indexOf(mins.b),\n c: minsorted.indexOf(mins.c)\n };\n if(minsorted[0] < 0) {\n if(minsorted[1] + minsorted[0] / 2 < 0) {\n minsorted[2] += minsorted[0] + minsorted[1];\n minsorted[0] = minsorted[1] = 0;\n } else {\n minsorted[2] += minsorted[0] / 2;\n minsorted[1] += minsorted[0] / 2;\n minsorted[0] = 0;\n }\n mins = {\n a: minsorted[minindices.a],\n b: minsorted[minindices.b],\n c: minsorted[minindices.c]\n };\n dy = (mins0.a - mins.a) * _this.yaxis._m;\n dx = (mins0.c - mins.c - mins0.b + mins.b) * _this.xaxis._m;\n }\n\n // move the data (translate, don't redraw)\n var plotTransform = strTranslate(_this.x0 + dx, _this.y0 + dy);\n _this.plotContainer.selectAll('.scatterlayer,.maplayer')\n .attr('transform', plotTransform);\n\n var plotTransform2 = strTranslate(-dx, -dy);\n _this.clipDefRelative.select('path').attr('transform', plotTransform2);\n\n // move the ticks\n _this.aaxis.range = [mins.a, _this.sum - mins.b - mins.c];\n _this.baxis.range = [_this.sum - mins.a - mins.c, mins.b];\n _this.caxis.range = [_this.sum - mins.a - mins.b, mins.c];\n\n _this.drawAxes(false);\n\n if(_this._hasClipOnAxisFalse) {\n _this.plotContainer\n .select('.scatterlayer').selectAll('.trace')\n .call(Drawing.hideOutsideRangePoints, _this);\n }\n\n gd.emit('plotly_relayouting', makeUpdate(mins));\n }\n\n function dragDone() {\n Registry.call('_guiRelayout', gd, makeUpdate(mins));\n }\n\n // finally, set up hover and click\n // these event handlers must already be set before dragElement.init\n // so it can stash them and override them.\n dragger.onmousemove = function(evt) {\n Fx.hover(gd, evt, _this.id);\n gd._fullLayout._lasthover = dragger;\n gd._fullLayout._hoversubplot = _this.id;\n };\n\n dragger.onmouseout = function(evt) {\n if(gd._dragging) return;\n\n dragElement.unhover(gd, evt);\n };\n\n dragElement.init(this.dragOptions);\n};\n\nfunction removeZoombox(gd) {\n d3.select(gd)\n .selectAll('.zoombox,.js-zoombox-backdrop,.js-zoombox-menu,.zoombox-corners')\n .remove();\n}\n","'use strict';\n\nvar Loggers = require('./lib/loggers');\nvar noop = require('./lib/noop');\nvar pushUnique = require('./lib/push_unique');\nvar isPlainObject = require('./lib/is_plain_object');\nvar addStyleRule = require('./lib/dom').addStyleRule;\nvar ExtendModule = require('./lib/extend');\n\nvar basePlotAttributes = require('./plots/attributes');\nvar baseLayoutAttributes = require('./plots/layout_attributes');\n\nvar extendFlat = ExtendModule.extendFlat;\nvar extendDeepAll = ExtendModule.extendDeepAll;\n\nexports.modules = {};\nexports.allCategories = {};\nexports.allTypes = [];\nexports.subplotsRegistry = {};\nexports.transformsRegistry = {};\nexports.componentsRegistry = {};\nexports.layoutArrayContainers = [];\nexports.layoutArrayRegexes = [];\nexports.traceLayoutAttributes = {};\nexports.localeRegistry = {};\nexports.apiMethodRegistry = {};\nexports.collectableSubplotTypes = null;\n\n/**\n * Top-level register routine, exported as Plotly.register\n *\n * @param {object array or array of objects} _modules :\n * module object or list of module object to register.\n *\n * A valid `moduleType: 'trace'` module has fields:\n * - name {string} : the trace type\n * - categories {array} : categories associated with this trace type,\n * tested with Register.traceIs()\n * - meta {object} : meta info (mostly for plot-schema)\n *\n * A valid `moduleType: 'locale'` module has fields:\n * - name {string} : the locale name. Should be a 2-digit language string ('en', 'de')\n * optionally with a country/region code ('en-GB', 'de-CH'). If a country\n * code is used but the base language locale has not yet been supplied,\n * we will use this locale for the base as well.\n * - dictionary {object} : the dictionary mapping input strings to localized strings\n * generally the keys should be the literal input strings, but\n * if default translations are provided you can use any string as a key.\n * - format {object} : a `d3.locale` format specifier for this locale\n * any omitted keys we'll fall back on en-US.\n *\n * A valid `moduleType: 'transform'` module has fields:\n * - name {string} : transform name\n * - transform {function} : default-level transform function\n * - calcTransform {function} : calc-level transform function\n * - attributes {object} : transform attributes declarations\n * - supplyDefaults {function} : attributes default-supply function\n *\n * A valid `moduleType: 'component'` module has fields:\n * - name {string} : the component name, used it with Register.getComponentMethod()\n * to employ component method.\n *\n * A valid `moduleType: 'apiMethod'` module has fields:\n * - name {string} : the api method name.\n * - fn {function} : the api method called with Register.call();\n *\n */\nexports.register = function register(_modules) {\n exports.collectableSubplotTypes = null;\n\n if(!_modules) {\n throw new Error('No argument passed to Plotly.register.');\n } else if(_modules && !Array.isArray(_modules)) {\n _modules = [_modules];\n }\n\n for(var i = 0; i < _modules.length; i++) {\n var newModule = _modules[i];\n\n if(!newModule) {\n throw new Error('Invalid module was attempted to be registered!');\n }\n\n switch(newModule.moduleType) {\n case 'trace':\n registerTraceModule(newModule);\n break;\n case 'transform':\n registerTransformModule(newModule);\n break;\n case 'component':\n registerComponentModule(newModule);\n break;\n case 'locale':\n registerLocale(newModule);\n break;\n case 'apiMethod':\n var name = newModule.name;\n exports.apiMethodRegistry[name] = newModule.fn;\n break;\n default:\n throw new Error('Invalid module was attempted to be registered!');\n }\n }\n};\n\n/**\n * Get registered module using trace object or trace type\n *\n * @param {object||string} trace\n * trace object with prop 'type' or trace type as a string\n * @return {object}\n * module object corresponding to trace type\n */\nexports.getModule = function(trace) {\n var _module = exports.modules[getTraceType(trace)];\n if(!_module) return false;\n return _module._module;\n};\n\n/**\n * Determine if this trace type is in a given category\n *\n * @param {object||string} traceType\n * a trace (object) or trace type (string)\n * @param {string} category\n * category in question\n * @return {boolean}\n */\nexports.traceIs = function(traceType, category) {\n traceType = getTraceType(traceType);\n\n // old Chart Studio Cloud workspace hack, nothing to see here\n if(traceType === 'various') return false;\n\n var _module = exports.modules[traceType];\n\n if(!_module) {\n if(traceType) {\n Loggers.log('Unrecognized trace type ' + traceType + '.');\n }\n\n _module = exports.modules[basePlotAttributes.type.dflt];\n }\n\n return !!_module.categories[category];\n};\n\n/**\n * Determine if this trace has a transform of the given type and return\n * array of matching indices.\n *\n * @param {object} data\n * a trace object (member of data or fullData)\n * @param {string} type\n * type of trace to test\n * @return {array}\n * array of matching indices. If none found, returns []\n */\nexports.getTransformIndices = function(data, type) {\n var indices = [];\n var transforms = data.transforms || [];\n for(var i = 0; i < transforms.length; i++) {\n if(transforms[i].type === type) {\n indices.push(i);\n }\n }\n return indices;\n};\n\n/**\n * Determine if this trace has a transform of the given type\n *\n * @param {object} data\n * a trace object (member of data or fullData)\n * @param {string} type\n * type of trace to test\n * @return {boolean}\n */\nexports.hasTransform = function(data, type) {\n var transforms = data.transforms || [];\n for(var i = 0; i < transforms.length; i++) {\n if(transforms[i].type === type) {\n return true;\n }\n }\n return false;\n};\n\n/**\n * Retrieve component module method. Falls back on noop if either the\n * module or the method is missing, so the result can always be safely called\n *\n * @param {string} name\n * name of component (as declared in component module)\n * @param {string} method\n * name of component module method\n * @return {function}\n */\nexports.getComponentMethod = function(name, method) {\n var _module = exports.componentsRegistry[name];\n\n if(!_module) return noop;\n return _module[method] || noop;\n};\n\n/**\n * Call registered api method.\n *\n * @param {string} name : api method name\n * @param {...array} args : arguments passed to api method\n * @return {any} : returns api method output\n */\nexports.call = function() {\n var name = arguments[0];\n var args = [].slice.call(arguments, 1);\n return exports.apiMethodRegistry[name].apply(null, args);\n};\n\nfunction registerTraceModule(_module) {\n var thisType = _module.name;\n var categoriesIn = _module.categories;\n var meta = _module.meta;\n\n if(exports.modules[thisType]) {\n Loggers.log('Type ' + thisType + ' already registered');\n return;\n }\n\n if(!exports.subplotsRegistry[_module.basePlotModule.name]) {\n registerSubplot(_module.basePlotModule);\n }\n\n var categoryObj = {};\n for(var i = 0; i < categoriesIn.length; i++) {\n categoryObj[categoriesIn[i]] = true;\n exports.allCategories[categoriesIn[i]] = true;\n }\n\n exports.modules[thisType] = {\n _module: _module,\n categories: categoryObj\n };\n\n if(meta && Object.keys(meta).length) {\n exports.modules[thisType].meta = meta;\n }\n\n exports.allTypes.push(thisType);\n\n for(var componentName in exports.componentsRegistry) {\n mergeComponentAttrsToTrace(componentName, thisType);\n }\n\n /*\n * Collect all trace layout attributes in one place for easier lookup later\n * but don't merge them into the base schema as it would confuse the docs\n * (at least after https://github.com/plotly/documentation/issues/202 gets done!)\n */\n if(_module.layoutAttributes) {\n extendFlat(exports.traceLayoutAttributes, _module.layoutAttributes);\n }\n\n var basePlotModule = _module.basePlotModule;\n var bpmName = basePlotModule.name;\n\n // add mapbox-gl CSS here to avoid console warning on instantiation\n if(bpmName === 'mapbox') {\n var styleRules = basePlotModule.constants.styleRules;\n for(var k in styleRules) {\n addStyleRule('.js-plotly-plot .plotly .mapboxgl-' + k, styleRules[k]);\n }\n }\n\n // add maplibre-gl CSS here to avoid console warning on instantiation\n if(bpmName === 'map') {\n require('maplibre-gl/dist/maplibre-gl.css');\n }\n\n // if `plotly-geo-assets.js` is not included,\n // add `PlotlyGeoAssets` global to stash references to all fetched\n // topojson / geojson data\n if((bpmName === 'geo' || bpmName === 'mapbox' || bpmName === 'map') &&\n (window.PlotlyGeoAssets === undefined)\n ) {\n window.PlotlyGeoAssets = {topojson: {}};\n }\n}\n\nfunction registerSubplot(_module) {\n var plotType = _module.name;\n\n if(exports.subplotsRegistry[plotType]) {\n Loggers.log('Plot type ' + plotType + ' already registered.');\n return;\n }\n\n // relayout array handling will look for component module methods with this\n // name and won't find them because this is a subplot module... but that\n // should be fine, it will just fall back on redrawing the plot.\n findArrayRegexps(_module);\n\n // not sure what's best for the 'cartesian' type at this point\n exports.subplotsRegistry[plotType] = _module;\n\n for(var componentName in exports.componentsRegistry) {\n mergeComponentAttrsToSubplot(componentName, _module.name);\n }\n}\n\nfunction registerComponentModule(_module) {\n if(typeof _module.name !== 'string') {\n throw new Error('Component module *name* must be a string.');\n }\n\n var name = _module.name;\n exports.componentsRegistry[name] = _module;\n\n if(_module.layoutAttributes) {\n if(_module.layoutAttributes._isLinkedToArray) {\n pushUnique(exports.layoutArrayContainers, name);\n }\n findArrayRegexps(_module);\n }\n\n for(var traceType in exports.modules) {\n mergeComponentAttrsToTrace(name, traceType);\n }\n\n for(var subplotName in exports.subplotsRegistry) {\n mergeComponentAttrsToSubplot(name, subplotName);\n }\n\n for(var transformType in exports.transformsRegistry) {\n mergeComponentAttrsToTransform(name, transformType);\n }\n\n if(_module.schema && _module.schema.layout) {\n extendDeepAll(baseLayoutAttributes, _module.schema.layout);\n }\n}\n\nfunction registerTransformModule(_module) {\n if(typeof _module.name !== 'string') {\n throw new Error('Transform module *name* must be a string.');\n }\n\n var prefix = 'Transform module ' + _module.name;\n var hasTransform = typeof _module.transform === 'function';\n var hasCalcTransform = typeof _module.calcTransform === 'function';\n\n if(!hasTransform && !hasCalcTransform) {\n throw new Error(prefix + ' is missing a *transform* or *calcTransform* method.');\n }\n if(hasTransform && hasCalcTransform) {\n Loggers.log([\n prefix + ' has both a *transform* and *calcTransform* methods.',\n 'Please note that all *transform* methods are executed',\n 'before all *calcTransform* methods.'\n ].join(' '));\n }\n if(!isPlainObject(_module.attributes)) {\n Loggers.log(prefix + ' registered without an *attributes* object.');\n }\n if(typeof _module.supplyDefaults !== 'function') {\n Loggers.log(prefix + ' registered without a *supplyDefaults* method.');\n }\n\n exports.transformsRegistry[_module.name] = _module;\n\n for(var componentName in exports.componentsRegistry) {\n mergeComponentAttrsToTransform(componentName, _module.name);\n }\n}\n\nfunction registerLocale(_module) {\n var locale = _module.name;\n var baseLocale = locale.split('-')[0];\n\n var newDict = _module.dictionary;\n var newFormat = _module.format;\n var hasDict = newDict && Object.keys(newDict).length;\n var hasFormat = newFormat && Object.keys(newFormat).length;\n\n var locales = exports.localeRegistry;\n\n var localeObj = locales[locale];\n if(!localeObj) locales[locale] = localeObj = {};\n\n // Should we use this dict for the base locale?\n // In case we're overwriting a previous dict for this locale, check\n // whether the base matches the full locale dict now. If we're not\n // overwriting, locales[locale] is undefined so this just checks if\n // baseLocale already had a dict or not.\n // Same logic for dateFormats\n if(baseLocale !== locale) {\n var baseLocaleObj = locales[baseLocale];\n if(!baseLocaleObj) locales[baseLocale] = baseLocaleObj = {};\n\n if(hasDict && baseLocaleObj.dictionary === localeObj.dictionary) {\n baseLocaleObj.dictionary = newDict;\n }\n if(hasFormat && baseLocaleObj.format === localeObj.format) {\n baseLocaleObj.format = newFormat;\n }\n }\n\n if(hasDict) localeObj.dictionary = newDict;\n if(hasFormat) localeObj.format = newFormat;\n}\n\nfunction findArrayRegexps(_module) {\n if(_module.layoutAttributes) {\n var arrayAttrRegexps = _module.layoutAttributes._arrayAttrRegexps;\n if(arrayAttrRegexps) {\n for(var i = 0; i < arrayAttrRegexps.length; i++) {\n pushUnique(exports.layoutArrayRegexes, arrayAttrRegexps[i]);\n }\n }\n }\n}\n\nfunction mergeComponentAttrsToTrace(componentName, traceType) {\n var componentSchema = exports.componentsRegistry[componentName].schema;\n if(!componentSchema || !componentSchema.traces) return;\n\n var traceAttrs = componentSchema.traces[traceType];\n if(traceAttrs) {\n extendDeepAll(exports.modules[traceType]._module.attributes, traceAttrs);\n }\n}\n\nfunction mergeComponentAttrsToTransform(componentName, transformType) {\n var componentSchema = exports.componentsRegistry[componentName].schema;\n if(!componentSchema || !componentSchema.transforms) return;\n\n var transformAttrs = componentSchema.transforms[transformType];\n if(transformAttrs) {\n extendDeepAll(exports.transformsRegistry[transformType].attributes, transformAttrs);\n }\n}\n\nfunction mergeComponentAttrsToSubplot(componentName, subplotName) {\n var componentSchema = exports.componentsRegistry[componentName].schema;\n if(!componentSchema || !componentSchema.subplots) return;\n\n var subplotModule = exports.subplotsRegistry[subplotName];\n var subplotAttrs = subplotModule.layoutAttributes;\n var subplotAttr = subplotModule.attr === 'subplot' ? subplotModule.name : subplotModule.attr;\n if(Array.isArray(subplotAttr)) subplotAttr = subplotAttr[0];\n\n var componentLayoutAttrs = componentSchema.subplots[subplotAttr];\n if(subplotAttrs && componentLayoutAttrs) {\n extendDeepAll(subplotAttrs, componentLayoutAttrs);\n }\n}\n\nfunction getTraceType(traceType) {\n if(typeof traceType === 'object') traceType = traceType.type;\n return traceType;\n}\n","'use strict';\n\nvar Registry = require('../registry');\nvar Lib = require('../lib');\n\nvar extendFlat = Lib.extendFlat;\nvar extendDeep = Lib.extendDeep;\n\n// Put default plotTile layouts here\nfunction cloneLayoutOverride(tileClass) {\n var override;\n\n switch(tileClass) {\n case 'themes__thumb':\n override = {\n autosize: true,\n width: 150,\n height: 150,\n title: {text: ''},\n showlegend: false,\n margin: {l: 5, r: 5, t: 5, b: 5, pad: 0},\n annotations: []\n };\n break;\n\n case 'thumbnail':\n override = {\n title: {text: ''},\n hidesources: true,\n showlegend: false,\n borderwidth: 0,\n bordercolor: '',\n margin: {l: 1, r: 1, t: 1, b: 1, pad: 0},\n annotations: []\n };\n break;\n\n default:\n override = {};\n }\n\n\n return override;\n}\n\nfunction keyIsAxis(keyName) {\n var types = ['xaxis', 'yaxis', 'zaxis'];\n return (types.indexOf(keyName.slice(0, 5)) > -1);\n}\n\n\nmodule.exports = function clonePlot(graphObj, options) {\n var i;\n var oldData = graphObj.data;\n var oldLayout = graphObj.layout;\n var newData = extendDeep([], oldData);\n var newLayout = extendDeep({}, oldLayout, cloneLayoutOverride(options.tileClass));\n var context = graphObj._context || {};\n\n if(options.width) newLayout.width = options.width;\n if(options.height) newLayout.height = options.height;\n\n if(options.tileClass === 'thumbnail' || options.tileClass === 'themes__thumb') {\n // kill annotations\n newLayout.annotations = [];\n var keys = Object.keys(newLayout);\n\n for(i = 0; i < keys.length; i++) {\n if(keyIsAxis(keys[i])) {\n newLayout[keys[i]].title = {text: ''};\n }\n }\n\n // kill colorbar and pie labels\n for(i = 0; i < newData.length; i++) {\n var trace = newData[i];\n trace.showscale = false;\n if(trace.marker) trace.marker.showscale = false;\n if(Registry.traceIs(trace, 'pie-like')) trace.textposition = 'none';\n }\n }\n\n if(Array.isArray(options.annotations)) {\n for(i = 0; i < options.annotations.length; i++) {\n newLayout.annotations.push(options.annotations[i]);\n }\n }\n\n // TODO: does this scene modification really belong here?\n // If we still need it, can it move into the gl3d module?\n var sceneIds = Object.keys(newLayout).filter(function(key) {\n return key.match(/^scene\\d*$/);\n });\n if(sceneIds.length) {\n var axesImageOverride = {};\n if(options.tileClass === 'thumbnail') {\n axesImageOverride = {\n title: {text: ''},\n showaxeslabels: false,\n showticklabels: false,\n linetickenable: false\n };\n }\n for(i = 0; i < sceneIds.length; i++) {\n var scene = newLayout[sceneIds[i]];\n\n if(!scene.xaxis) {\n scene.xaxis = {};\n }\n\n if(!scene.yaxis) {\n scene.yaxis = {};\n }\n\n if(!scene.zaxis) {\n scene.zaxis = {};\n }\n\n extendFlat(scene.xaxis, axesImageOverride);\n extendFlat(scene.yaxis, axesImageOverride);\n extendFlat(scene.zaxis, axesImageOverride);\n\n // TODO what does this do?\n scene._scene = null;\n }\n }\n\n var gd = document.createElement('div');\n if(options.tileClass) gd.className = options.tileClass;\n\n var plotTile = {\n gd: gd,\n td: gd, // for external (image server) compatibility\n layout: newLayout,\n data: newData,\n config: {\n staticPlot: (options.staticPlot === undefined) ?\n true :\n options.staticPlot,\n plotGlPixelRatio: (options.plotGlPixelRatio === undefined) ?\n 2 :\n options.plotGlPixelRatio,\n displaylogo: options.displaylogo || false,\n showLink: options.showLink || false,\n showTips: options.showTips || false,\n mapboxAccessToken: context.mapboxAccessToken\n }\n };\n\n if(options.setBackground !== 'transparent') {\n plotTile.config.setBackground = options.setBackground || 'opaque';\n }\n\n // attaching the default Layout the gd, so you can grab it later\n plotTile.gd.defaultLayout = cloneLayoutOverride(options.tileClass);\n\n return plotTile;\n};\n","'use strict';\n\nvar Lib = require('../lib');\n\nvar toImage = require('../plot_api/to_image');\n\nvar fileSaver = require('./filesaver');\nvar helpers = require('./helpers');\n\n/**\n * Plotly.downloadImage\n *\n * @param {object | string | HTML div} gd\n * can either be a data/layout/config object\n * or an existing graph
\n * or an id to an existing graph
\n * @param {object} opts (see Plotly.toImage in ../plot_api/to_image)\n * @return {promise}\n */\nfunction downloadImage(gd, opts) {\n var _gd;\n if(!Lib.isPlainObject(gd)) _gd = Lib.getGraphDiv(gd);\n\n opts = opts || {};\n opts.format = opts.format || 'png';\n opts.width = opts.width || null;\n opts.height = opts.height || null;\n opts.imageDataOnly = true;\n\n return new Promise(function(resolve, reject) {\n if(_gd && _gd._snapshotInProgress) {\n reject(new Error('Snapshotting already in progress.'));\n }\n\n // see comments within svgtoimg for additional\n // discussion of problems with IE\n // can now draw to canvas, but CORS tainted canvas\n // does not allow toDataURL\n // svg format will work though\n if(Lib.isIE() && opts.format !== 'svg') {\n reject(new Error(helpers.MSG_IE_BAD_FORMAT));\n }\n\n if(_gd) _gd._snapshotInProgress = true;\n var promise = toImage(gd, opts);\n\n var filename = opts.filename || gd.fn || 'newplot';\n filename += '.' + opts.format.replace('-', '.');\n\n promise.then(function(result) {\n if(_gd) _gd._snapshotInProgress = false;\n return fileSaver(result, filename, opts.format);\n }).then(function(name) {\n resolve(name);\n }).catch(function(err) {\n if(_gd) _gd._snapshotInProgress = false;\n reject(err);\n });\n });\n}\n\nmodule.exports = downloadImage;\n","'use strict';\n\nvar Lib = require('../lib');\nvar helpers = require('./helpers');\n\n/*\n* substantial portions of this code from FileSaver.js\n* https://github.com/eligrey/FileSaver.js\n* License: https://github.com/eligrey/FileSaver.js/blob/master/LICENSE.md\n* FileSaver.js\n* A saveAs() FileSaver implementation.\n* 1.1.20160328\n*\n* By Eli Grey, http://eligrey.com\n* License: MIT\n* See https://github.com/eligrey/FileSaver.js/blob/master/LICENSE.md\n*/\nfunction fileSaver(url, name, format) {\n var saveLink = document.createElement('a');\n var canUseSaveLink = 'download' in saveLink;\n\n var promise = new Promise(function(resolve, reject) {\n var blob;\n var objectUrl;\n\n // IE 10+ (native saveAs)\n if(Lib.isIE()) {\n // At this point we are only dealing with a decoded SVG as\n // a data URL (since IE only supports SVG)\n blob = helpers.createBlob(url, 'svg');\n window.navigator.msSaveBlob(blob, name);\n blob = null;\n return resolve(name);\n }\n\n if(canUseSaveLink) {\n blob = helpers.createBlob(url, format);\n objectUrl = helpers.createObjectURL(blob);\n\n saveLink.href = objectUrl;\n saveLink.download = name;\n document.body.appendChild(saveLink);\n saveLink.click();\n\n document.body.removeChild(saveLink);\n helpers.revokeObjectURL(objectUrl);\n blob = null;\n\n return resolve(name);\n }\n\n // Older versions of Safari did not allow downloading of blob urls\n if(Lib.isSafari()) {\n var prefix = format === 'svg' ? ',' : ';base64,';\n helpers.octetStream(prefix + encodeURIComponent(url));\n return resolve(name);\n }\n\n reject(new Error('download error'));\n });\n\n return promise;\n}\n\n\nmodule.exports = fileSaver;\n","'use strict';\n\nvar Registry = require('../registry');\n\nexports.getDelay = function(fullLayout) {\n if(!fullLayout._has) return 0;\n\n return (\n fullLayout._has('gl3d') ||\n fullLayout._has('gl2d') ||\n fullLayout._has('mapbox') ||\n fullLayout._has('map')\n ) ? 500 : 0;\n};\n\nexports.getRedrawFunc = function(gd) {\n return function() {\n Registry.getComponentMethod('colorbar', 'draw')(gd);\n };\n};\n\nexports.encodeSVG = function(svg) {\n return 'data:image/svg+xml,' + encodeURIComponent(svg);\n};\n\nexports.encodeJSON = function(json) {\n return 'data:application/json,' + encodeURIComponent(json);\n};\n\nvar DOM_URL = window.URL || window.webkitURL;\n\nexports.createObjectURL = function(blob) {\n return DOM_URL.createObjectURL(blob);\n};\n\nexports.revokeObjectURL = function(url) {\n return DOM_URL.revokeObjectURL(url);\n};\n\nexports.createBlob = function(url, format) {\n if(format === 'svg') {\n return new window.Blob([url], {type: 'image/svg+xml;charset=utf-8'});\n } else if(format === 'full-json') {\n return new window.Blob([url], {type: 'application/json;charset=utf-8'});\n } else {\n var binary = fixBinary(window.atob(url));\n return new window.Blob([binary], {type: 'image/' + format});\n }\n};\n\nexports.octetStream = function(s) {\n document.location.href = 'data:application/octet-stream' + s;\n};\n\n// Taken from https://bl.ocks.org/nolanlawson/0eac306e4dac2114c752\nfunction fixBinary(b) {\n var len = b.length;\n var buf = new ArrayBuffer(len);\n var arr = new Uint8Array(buf);\n for(var i = 0; i < len; i++) {\n arr[i] = b.charCodeAt(i);\n }\n return buf;\n}\n\nexports.IMAGE_URL_PREFIX = /^data:image\\/\\w+;base64,/;\n\nexports.MSG_IE_BAD_FORMAT = 'Sorry IE does not support downloading from canvas. Try {format:\\'svg\\'} instead.';\n","'use strict';\n\nvar helpers = require('./helpers');\n\nvar Snapshot = {\n getDelay: helpers.getDelay,\n getRedrawFunc: helpers.getRedrawFunc,\n clone: require('./cloneplot'),\n toSVG: require('./tosvg'),\n svgToImg: require('./svgtoimg'),\n toImage: require('./toimage'),\n downloadImage: require('./download')\n};\n\nmodule.exports = Snapshot;\n","'use strict';\n\nvar Lib = require('../lib');\nvar EventEmitter = require('events').EventEmitter;\n\nvar helpers = require('./helpers');\n\nfunction svgToImg(opts) {\n var ev = opts.emitter || new EventEmitter();\n\n var promise = new Promise(function(resolve, reject) {\n var Image = window.Image;\n var svg = opts.svg;\n var format = opts.format || 'png';\n\n // IE only support svg\n if(Lib.isIE() && format !== 'svg') {\n var ieSvgError = new Error(helpers.MSG_IE_BAD_FORMAT);\n reject(ieSvgError);\n // eventually remove the ev\n // in favor of promises\n if(!opts.promise) {\n return ev.emit('error', ieSvgError);\n } else {\n return promise;\n }\n }\n\n var canvas = opts.canvas;\n var scale = opts.scale || 1;\n var w0 = opts.width || 300;\n var h0 = opts.height || 150;\n var w1 = scale * w0;\n var h1 = scale * h0;\n\n var ctx = canvas.getContext('2d', {willReadFrequently: true});\n var img = new Image();\n var svgBlob, url;\n\n if(format === 'svg' || Lib.isSafari()) {\n url = helpers.encodeSVG(svg);\n } else {\n svgBlob = helpers.createBlob(svg, 'svg');\n url = helpers.createObjectURL(svgBlob);\n }\n\n canvas.width = w1;\n canvas.height = h1;\n\n img.onload = function() {\n var imgData;\n\n svgBlob = null;\n helpers.revokeObjectURL(url);\n\n // don't need to draw to canvas if svg\n // save some time and also avoid failure on IE\n if(format !== 'svg') {\n ctx.drawImage(img, 0, 0, w1, h1);\n }\n\n switch(format) {\n case 'jpeg':\n imgData = canvas.toDataURL('image/jpeg');\n break;\n case 'png':\n imgData = canvas.toDataURL('image/png');\n break;\n case 'webp':\n imgData = canvas.toDataURL('image/webp');\n break;\n case 'svg':\n imgData = url;\n break;\n default:\n var errorMsg = 'Image format is not jpeg, png, svg or webp.';\n reject(new Error(errorMsg));\n // eventually remove the ev\n // in favor of promises\n if(!opts.promise) {\n return ev.emit('error', errorMsg);\n }\n }\n resolve(imgData);\n // eventually remove the ev\n // in favor of promises\n if(!opts.promise) {\n ev.emit('success', imgData);\n }\n };\n\n img.onerror = function(err) {\n svgBlob = null;\n helpers.revokeObjectURL(url);\n\n reject(err);\n // eventually remove the ev\n // in favor of promises\n if(!opts.promise) {\n return ev.emit('error', err);\n }\n };\n\n img.src = url;\n });\n\n // temporary for backward compatibility\n // move to only Promise in 2.0.0\n // and eliminate the EventEmitter\n if(opts.promise) {\n return promise;\n }\n\n return ev;\n}\n\nmodule.exports = svgToImg;\n","'use strict';\n\nvar EventEmitter = require('events').EventEmitter;\n\nvar Registry = require('../registry');\nvar Lib = require('../lib');\n\nvar helpers = require('./helpers');\nvar clonePlot = require('./cloneplot');\nvar toSVG = require('./tosvg');\nvar svgToImg = require('./svgtoimg');\n\n/**\n * @param {object} gd figure Object\n * @param {object} opts option object\n * @param opts.format 'jpeg' | 'png' | 'webp' | 'svg'\n */\nfunction toImage(gd, opts) {\n // first clone the GD so we can operate in a clean environment\n var ev = new EventEmitter();\n\n var clone = clonePlot(gd, {format: 'png'});\n var clonedGd = clone.gd;\n\n // put the cloned div somewhere off screen before attaching to DOM\n clonedGd.style.position = 'absolute';\n clonedGd.style.left = '-5000px';\n document.body.appendChild(clonedGd);\n\n function wait() {\n var delay = helpers.getDelay(clonedGd._fullLayout);\n\n setTimeout(function() {\n var svg = toSVG(clonedGd);\n\n var canvas = document.createElement('canvas');\n canvas.id = Lib.randstr();\n\n ev = svgToImg({\n format: opts.format,\n width: clonedGd._fullLayout.width,\n height: clonedGd._fullLayout.height,\n canvas: canvas,\n emitter: ev,\n svg: svg\n });\n\n ev.clean = function() {\n if(clonedGd) document.body.removeChild(clonedGd);\n };\n }, delay);\n }\n\n var redrawFunc = helpers.getRedrawFunc(clonedGd);\n\n Registry.call('_doPlot', clonedGd, clone.data, clone.layout, clone.config)\n .then(redrawFunc)\n .then(wait)\n .catch(function(err) {\n ev.emit('error', err);\n });\n\n\n return ev;\n}\n\nmodule.exports = toImage;\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Lib = require('../lib');\nvar Drawing = require('../components/drawing');\nvar Color = require('../components/color');\n\nvar xmlnsNamespaces = require('../constants/xmlns_namespaces');\nvar DOUBLEQUOTE_REGEX = /\"/g;\nvar DUMMY_SUB = 'TOBESTRIPPED';\nvar DUMMY_REGEX = new RegExp('(\"' + DUMMY_SUB + ')|(' + DUMMY_SUB + '\")', 'g');\n\nfunction htmlEntityDecode(s) {\n var hiddenDiv = d3.select('body').append('div').style({display: 'none'}).html('');\n var replaced = s.replace(/(&[^;]*;)/gi, function(d) {\n if(d === '<') { return '<'; } // special handling for brackets\n if(d === '&rt;') { return '>'; }\n if(d.indexOf('<') !== -1 || d.indexOf('>') !== -1) { return ''; }\n return hiddenDiv.html(d).text(); // everything else, let the browser decode it to unicode\n });\n hiddenDiv.remove();\n return replaced;\n}\n\nfunction xmlEntityEncode(str) {\n return str.replace(/&(?!\\w+;|\\#[0-9]+;| \\#x[0-9A-F]+;)/g, '&');\n}\n\nmodule.exports = function toSVG(gd, format, scale) {\n var fullLayout = gd._fullLayout;\n var svg = fullLayout._paper;\n var toppaper = fullLayout._toppaper;\n var width = fullLayout.width;\n var height = fullLayout.height;\n var i;\n\n // make background color a rect in the svg, then revert after scraping\n // all other alterations have been dealt with by properly preparing the svg\n // in the first place... like setting cursors with css classes so we don't\n // have to remove them, and providing the right namespaces in the svg to\n // begin with\n svg.insert('rect', ':first-child')\n .call(Drawing.setRect, 0, 0, width, height)\n .call(Color.fill, fullLayout.paper_bgcolor);\n\n // subplot-specific to-SVG methods\n // which notably add the contents of the gl-container\n // into the main svg node\n var basePlotModules = fullLayout._basePlotModules || [];\n for(i = 0; i < basePlotModules.length; i++) {\n var _module = basePlotModules[i];\n\n if(_module.toSVG) _module.toSVG(gd);\n }\n\n // add top items above them assumes everything in toppaper is either\n // a group or a defs, and if it's empty (like hoverlayer) we can ignore it.\n if(toppaper) {\n var nodes = toppaper.node().childNodes;\n\n // make copy of nodes as childNodes prop gets mutated in loop below\n var topGroups = Array.prototype.slice.call(nodes);\n\n for(i = 0; i < topGroups.length; i++) {\n var topGroup = topGroups[i];\n\n if(topGroup.childNodes.length) svg.node().appendChild(topGroup);\n }\n }\n\n // remove draglayer for Adobe Illustrator compatibility\n if(fullLayout._draggers) {\n fullLayout._draggers.remove();\n }\n\n // in case the svg element had an explicit background color, remove this\n // we want the rect to get the color so it's the right size; svg bg will\n // fill whatever container it's displayed in regardless of plot size.\n svg.node().style.background = '';\n\n svg.selectAll('text')\n .attr({'data-unformatted': null, 'data-math': null})\n .each(function() {\n var txt = d3.select(this);\n\n // hidden text is pre-formatting mathjax, the browser ignores it\n // but in a static plot it's useless and it can confuse batik\n // we've tried to standardize on display:none but make sure we still\n // catch visibility:hidden if it ever arises\n if(this.style.visibility === 'hidden' || this.style.display === 'none') {\n txt.remove();\n return;\n } else {\n // clear other visibility/display values to default\n // to not potentially confuse non-browser SVG implementations\n txt.style({visibility: null, display: null});\n }\n\n // Font family styles break things because of quotation marks,\n // so we must remove them *after* the SVG DOM has been serialized\n // to a string (browsers convert singles back)\n var ff = this.style.fontFamily;\n if(ff && ff.indexOf('\"') !== -1) {\n txt.style('font-family', ff.replace(DOUBLEQUOTE_REGEX, DUMMY_SUB));\n }\n\n // Drop normal font-weight, font-style and font-variant to reduce the size\n var fw = this.style.fontWeight;\n if(fw && (fw === 'normal' || fw === '400')) { // font-weight 400 is similar to normal\n txt.style('font-weight', undefined);\n }\n var fs = this.style.fontStyle;\n if(fs && fs === 'normal') {\n txt.style('font-style', undefined);\n }\n var fv = this.style.fontVariant;\n if(fv && fv === 'normal') {\n txt.style('font-variant', undefined);\n }\n });\n\n svg.selectAll('.gradient_filled,.pattern_filled').each(function() {\n var pt = d3.select(this);\n\n // similar to font family styles above,\n // we must remove \" after the SVG DOM has been serialized\n var fill = this.style.fill;\n if(fill && fill.indexOf('url(') !== -1) {\n pt.style('fill', fill.replace(DOUBLEQUOTE_REGEX, DUMMY_SUB));\n }\n\n var stroke = this.style.stroke;\n if(stroke && stroke.indexOf('url(') !== -1) {\n pt.style('stroke', stroke.replace(DOUBLEQUOTE_REGEX, DUMMY_SUB));\n }\n });\n\n if(format === 'pdf' || format === 'eps') {\n // these formats make the extra line MathJax adds around symbols look super thick in some cases\n // it looks better if this is removed entirely.\n svg.selectAll('#MathJax_SVG_glyphs path')\n .attr('stroke-width', 0);\n }\n\n // fix for IE namespacing quirk?\n // http://stackoverflow.com/questions/19610089/unwanted-namespaces-on-svg-markup-when-using-xmlserializer-in-javascript-with-ie\n svg.node().setAttributeNS(xmlnsNamespaces.xmlns, 'xmlns', xmlnsNamespaces.svg);\n svg.node().setAttributeNS(xmlnsNamespaces.xmlns, 'xmlns:xlink', xmlnsNamespaces.xlink);\n\n if(format === 'svg' && scale) {\n svg.attr('width', scale * width);\n svg.attr('height', scale * height);\n svg.attr('viewBox', '0 0 ' + width + ' ' + height);\n }\n\n var s = new window.XMLSerializer().serializeToString(svg.node());\n s = htmlEntityDecode(s);\n s = xmlEntityEncode(s);\n\n // Fix quotations around font strings and gradient URLs\n s = s.replace(DUMMY_REGEX, '\\'');\n\n // Do we need this process now that IE9 and IE10 are not supported?\n\n // IE is very strict, so we will need to clean\n // svg with the following regex\n // yes this is messy, but do not know a better way\n // Even with this IE will not work due to tainted canvas\n // see https://github.com/kangax/fabric.js/issues/1957\n // http://stackoverflow.com/questions/18112047/canvas-todataurl-working-in-all-browsers-except-ie10\n // Leave here just in case the CORS/tainted IE issue gets resolved\n if(Lib.isIE()) {\n // replace double quote with single quote\n s = s.replace(/\"/gi, '\\'');\n // url in svg are single quoted\n // since we changed double to single\n // we'll need to change these to double-quoted\n s = s.replace(/(\\('#)([^']*)('\\))/gi, '(\\\"#$2\\\")');\n // font names with spaces will be escaped single-quoted\n // we'll need to change these to double-quoted\n s = s.replace(/(\\\\')/gi, '\\\"');\n }\n\n return s;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\n// arrayOk attributes, merge them into calcdata array\nmodule.exports = function arraysToCalcdata(cd, trace) {\n for(var i = 0; i < cd.length; i++) cd[i].i = i;\n\n Lib.mergeArray(trace.text, cd, 'tx');\n Lib.mergeArray(trace.hovertext, cd, 'htx');\n\n var marker = trace.marker;\n if(marker) {\n Lib.mergeArray(marker.opacity, cd, 'mo', true);\n Lib.mergeArray(marker.color, cd, 'mc');\n\n var markerLine = marker.line;\n if(markerLine) {\n Lib.mergeArray(markerLine.color, cd, 'mlc');\n Lib.mergeArrayCastPositive(markerLine.width, cd, 'mlw');\n }\n }\n};\n","'use strict';\n\nvar scatterAttrs = require('../scatter/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar fontAttrs = require('../../plots/font_attributes');\nvar constants = require('./constants');\nvar pattern = require('../../components/drawing/attributes').pattern;\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar textFontAttrs = fontAttrs({\n editType: 'calc',\n arrayOk: true,\n colorEditType: 'style',\n description: ''\n});\n\nvar scatterMarkerAttrs = scatterAttrs.marker;\nvar scatterMarkerLineAttrs = scatterMarkerAttrs.line;\n\nvar markerLineWidth = extendFlat({},\n scatterMarkerLineAttrs.width, { dflt: 0 });\n\nvar markerLine = extendFlat({\n width: markerLineWidth,\n editType: 'calc'\n}, colorScaleAttrs('marker.line'));\n\nvar marker = extendFlat({\n line: markerLine,\n editType: 'calc'\n}, colorScaleAttrs('marker'), {\n opacity: {\n valType: 'number',\n arrayOk: true,\n dflt: 1,\n min: 0,\n max: 1,\n editType: 'style',\n description: 'Sets the opacity of the bars.'\n },\n pattern: pattern,\n cornerradius: {\n valType: 'any',\n editType: 'calc',\n description: [\n 'Sets the rounding of corners. May be an integer number of pixels,',\n 'or a percentage of bar width (as a string ending in %). Defaults to `layout.barcornerradius`.',\n 'In stack or relative barmode, the first trace to set cornerradius is used for the whole stack.'\n ].join(' ')\n },\n});\n\nmodule.exports = {\n x: scatterAttrs.x,\n x0: scatterAttrs.x0,\n dx: scatterAttrs.dx,\n y: scatterAttrs.y,\n y0: scatterAttrs.y0,\n dy: scatterAttrs.dy,\n\n xperiod: scatterAttrs.xperiod,\n yperiod: scatterAttrs.yperiod,\n xperiod0: scatterAttrs.xperiod0,\n yperiod0: scatterAttrs.yperiod0,\n xperiodalignment: scatterAttrs.xperiodalignment,\n yperiodalignment: scatterAttrs.yperiodalignment,\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n\n text: scatterAttrs.text,\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: constants.eventDataKeys\n }),\n hovertext: scatterAttrs.hovertext,\n hovertemplate: hovertemplateAttrs({}, {\n keys: constants.eventDataKeys\n }),\n\n textposition: {\n valType: 'enumerated',\n values: ['inside', 'outside', 'auto', 'none'],\n dflt: 'auto',\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Specifies the location of the `text`.',\n '*inside* positions `text` inside, next to the bar end',\n '(rotated and scaled if needed).',\n '*outside* positions `text` outside, next to the bar end',\n '(scaled if needed), unless there is another bar stacked on',\n 'this one, then the text gets pushed inside.',\n '*auto* tries to position `text` inside the bar, but if',\n 'the bar is too small and no bar is stacked on this one',\n 'the text is moved outside.',\n 'If *none*, no text appears.'\n ].join(' ')\n },\n\n insidetextanchor: {\n valType: 'enumerated',\n values: ['end', 'middle', 'start'],\n dflt: 'end',\n editType: 'plot',\n description: [\n 'Determines if texts are kept at center or start/end points in `textposition` *inside* mode.'\n ].join(' ')\n },\n\n textangle: {\n valType: 'angle',\n dflt: 'auto',\n editType: 'plot',\n description: [\n 'Sets the angle of the tick labels with respect to the bar.',\n 'For example, a `tickangle` of -90 draws the tick labels',\n 'vertically. With *auto* the texts may automatically be',\n 'rotated to fit with the maximum size in bars.'\n ].join(' ')\n },\n\n textfont: extendFlat({}, textFontAttrs, {\n description: 'Sets the font used for `text`.'\n }),\n\n insidetextfont: extendFlat({}, textFontAttrs, {\n description: 'Sets the font used for `text` lying inside the bar.'\n }),\n\n outsidetextfont: extendFlat({}, textFontAttrs, {\n description: 'Sets the font used for `text` lying outside the bar.'\n }),\n\n constraintext: {\n valType: 'enumerated',\n values: ['inside', 'outside', 'both', 'none'],\n dflt: 'both',\n editType: 'calc',\n description: [\n 'Constrain the size of text inside or outside a bar to be no',\n 'larger than the bar itself.'\n ].join(' ')\n },\n\n cliponaxis: extendFlat({}, scatterAttrs.cliponaxis, {\n description: [\n 'Determines whether the text nodes',\n 'are clipped about the subplot axes.',\n 'To show the text nodes above axis lines and tick labels,',\n 'make sure to set `xaxis.layer` and `yaxis.layer` to *below traces*.'\n ].join(' ')\n }),\n\n orientation: {\n valType: 'enumerated',\n values: ['v', 'h'],\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the orientation of the bars.',\n 'With *v* (*h*), the value of the each bar spans',\n 'along the vertical (horizontal).'\n ].join(' ')\n },\n\n base: {\n valType: 'any',\n dflt: null,\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Sets where the bar base is drawn (in position axis units).',\n 'In *stack* or *relative* barmode,',\n 'traces that set *base* will be excluded',\n 'and drawn in *overlay* mode instead.'\n ].join(' ')\n },\n\n offset: {\n valType: 'number',\n dflt: null,\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Shifts the position where the bar is drawn',\n '(in position axis units).',\n 'In *group* barmode,',\n 'traces that set *offset* will be excluded',\n 'and drawn in *overlay* mode instead.'\n ].join(' ')\n },\n\n width: {\n valType: 'number',\n dflt: null,\n min: 0,\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Sets the bar width (in position axis units).'\n ].join(' ')\n },\n\n marker: marker,\n\n offsetgroup: scatterAttrs.offsetgroup,\n alignmentgroup: scatterAttrs.alignmentgroup,\n\n selected: {\n marker: {\n opacity: scatterAttrs.selected.marker.opacity,\n color: scatterAttrs.selected.marker.color,\n editType: 'style'\n },\n textfont: scatterAttrs.selected.textfont,\n editType: 'style'\n },\n unselected: {\n marker: {\n opacity: scatterAttrs.unselected.marker.opacity,\n color: scatterAttrs.unselected.marker.color,\n editType: 'style'\n },\n textfont: scatterAttrs.unselected.textfont,\n editType: 'style'\n },\n zorder: scatterAttrs.zorder,\n\n _deprecated: {\n bardir: {\n valType: 'enumerated',\n editType: 'calc',\n values: ['v', 'h'],\n description: 'Renamed to `orientation`.'\n }\n }\n};\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\nvar alignPeriod = require('../../plots/cartesian/align_period');\nvar hasColorscale = require('../../components/colorscale/helpers').hasColorscale;\nvar colorscaleCalc = require('../../components/colorscale/calc');\nvar arraysToCalcdata = require('./arrays_to_calcdata');\nvar calcSelection = require('../scatter/calc_selection');\n\nmodule.exports = function calc(gd, trace) {\n var xa = Axes.getFromId(gd, trace.xaxis || 'x');\n var ya = Axes.getFromId(gd, trace.yaxis || 'y');\n var size, pos, origPos, pObj, hasPeriod, pLetter;\n\n var sizeOpts = {\n msUTC: !!(trace.base || trace.base === 0)\n };\n\n if(trace.orientation === 'h') {\n size = xa.makeCalcdata(trace, 'x', sizeOpts);\n origPos = ya.makeCalcdata(trace, 'y');\n pObj = alignPeriod(trace, ya, 'y', origPos);\n hasPeriod = !!trace.yperiodalignment;\n pLetter = 'y';\n } else {\n size = ya.makeCalcdata(trace, 'y', sizeOpts);\n origPos = xa.makeCalcdata(trace, 'x');\n pObj = alignPeriod(trace, xa, 'x', origPos);\n hasPeriod = !!trace.xperiodalignment;\n pLetter = 'x';\n }\n pos = pObj.vals;\n\n // create the \"calculated data\" to plot\n var serieslen = Math.min(pos.length, size.length);\n var cd = new Array(serieslen);\n\n // set position and size\n for(var i = 0; i < serieslen; i++) {\n cd[i] = { p: pos[i], s: size[i] };\n\n if(hasPeriod) {\n cd[i].orig_p = origPos[i]; // used by hover\n cd[i][pLetter + 'End'] = pObj.ends[i];\n cd[i][pLetter + 'Start'] = pObj.starts[i];\n }\n\n if(trace.ids) {\n cd[i].id = String(trace.ids[i]);\n }\n }\n\n // auto-z and autocolorscale if applicable\n if(hasColorscale(trace, 'marker')) {\n colorscaleCalc(gd, trace, {\n vals: trace.marker.color,\n containerStr: 'marker',\n cLetter: 'c'\n });\n }\n if(hasColorscale(trace, 'marker.line')) {\n colorscaleCalc(gd, trace, {\n vals: trace.marker.line.color,\n containerStr: 'marker.line',\n cLetter: 'c'\n });\n }\n\n arraysToCalcdata(cd, trace);\n calcSelection(cd, trace);\n\n return cd;\n};\n","'use strict';\n\nmodule.exports = {\n // padding in pixels around text\n TEXTPAD: 3,\n // 'value' and 'label' are not really necessary for bar traces,\n // but they were made available to `texttemplate` (maybe by accident)\n // via tokens `%{value}` and `%{label}` starting in 1.50.0,\n // so let's include them in the event data also.\n eventDataKeys: ['value', 'label']\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nvar Registry = require('../../registry');\nvar Axes = require('../../plots/cartesian/axes');\nvar getAxisGroup = require('../../plots/cartesian/constraints').getAxisGroup;\nvar Sieve = require('./sieve.js');\n\n/*\n * Bar chart stacking/grouping positioning and autoscaling calculations\n * for each direction separately calculate the ranges and positions\n * note that this handles histograms too\n * now doing this one subplot at a time\n */\n\nfunction crossTraceCalc(gd, plotinfo) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n var fullLayout = gd._fullLayout;\n var fullTraces = gd._fullData;\n var calcTraces = gd.calcdata;\n var calcTracesHorz = [];\n var calcTracesVert = [];\n\n for(var i = 0; i < fullTraces.length; i++) {\n var fullTrace = fullTraces[i];\n if(\n fullTrace.visible === true &&\n Registry.traceIs(fullTrace, 'bar') &&\n fullTrace.xaxis === xa._id &&\n fullTrace.yaxis === ya._id\n ) {\n if(fullTrace.orientation === 'h') {\n calcTracesHorz.push(calcTraces[i]);\n } else {\n calcTracesVert.push(calcTraces[i]);\n }\n\n if(fullTrace._computePh) {\n var cd = gd.calcdata[i];\n for(var j = 0; j < cd.length; j++) {\n if(typeof cd[j].ph0 === 'function') cd[j].ph0 = cd[j].ph0();\n if(typeof cd[j].ph1 === 'function') cd[j].ph1 = cd[j].ph1();\n }\n }\n }\n }\n\n var opts = {\n xCat: xa.type === 'category' || xa.type === 'multicategory',\n yCat: ya.type === 'category' || ya.type === 'multicategory',\n\n mode: fullLayout.barmode,\n norm: fullLayout.barnorm,\n gap: fullLayout.bargap,\n groupgap: fullLayout.bargroupgap\n };\n\n setGroupPositions(gd, xa, ya, calcTracesVert, opts);\n setGroupPositions(gd, ya, xa, calcTracesHorz, opts);\n}\n\nfunction setGroupPositions(gd, pa, sa, calcTraces, opts) {\n if(!calcTraces.length) return;\n\n var excluded;\n var included;\n var i, calcTrace, fullTrace;\n\n initBase(sa, calcTraces);\n\n switch(opts.mode) {\n case 'overlay':\n setGroupPositionsInOverlayMode(pa, sa, calcTraces, opts);\n break;\n\n case 'group':\n // exclude from the group those traces for which the user set an offset\n excluded = [];\n included = [];\n for(i = 0; i < calcTraces.length; i++) {\n calcTrace = calcTraces[i];\n fullTrace = calcTrace[0].trace;\n\n if(fullTrace.offset === undefined) included.push(calcTrace);\n else excluded.push(calcTrace);\n }\n\n if(included.length) {\n setGroupPositionsInGroupMode(gd, pa, sa, included, opts);\n }\n if(excluded.length) {\n setGroupPositionsInOverlayMode(pa, sa, excluded, opts);\n }\n break;\n\n case 'stack':\n case 'relative':\n // exclude from the stack those traces for which the user set a base\n excluded = [];\n included = [];\n for(i = 0; i < calcTraces.length; i++) {\n calcTrace = calcTraces[i];\n fullTrace = calcTrace[0].trace;\n\n if(fullTrace.base === undefined) included.push(calcTrace);\n else excluded.push(calcTrace);\n }\n\n // If any trace in `included` has a cornerradius, set cornerradius of all bars\n // in `included` to match the first trace which has a cornerradius\n standardizeCornerradius(included);\n\n if(included.length) {\n setGroupPositionsInStackOrRelativeMode(gd, pa, sa, included, opts);\n }\n if(excluded.length) {\n setGroupPositionsInOverlayMode(pa, sa, excluded, opts);\n }\n break;\n }\n setCornerradius(calcTraces);\n collectExtents(calcTraces, pa);\n}\n\n// Set cornerradiusvalue and cornerradiusform in calcTraces[0].t\nfunction setCornerradius(calcTraces) {\n var i, calcTrace, fullTrace, t, cr, crValue, crForm;\n\n for(i = 0; i < calcTraces.length; i++) {\n calcTrace = calcTraces[i];\n fullTrace = calcTrace[0].trace;\n t = calcTrace[0].t;\n\n if(t.cornerradiusvalue === undefined) {\n cr = fullTrace.marker ? fullTrace.marker.cornerradius : undefined;\n if(cr !== undefined) {\n crValue = isNumeric(cr) ? +cr : +cr.slice(0, -1);\n crForm = isNumeric(cr) ? 'px' : '%';\n t.cornerradiusvalue = crValue;\n t.cornerradiusform = crForm;\n }\n }\n }\n}\n\n// Make sure all traces in a stack use the same cornerradius\nfunction standardizeCornerradius(calcTraces) {\n if(calcTraces.length < 2) return;\n var i, calcTrace, fullTrace, t;\n var cr, crValue, crForm;\n for(i = 0; i < calcTraces.length; i++) {\n calcTrace = calcTraces[i];\n fullTrace = calcTrace[0].trace;\n cr = fullTrace.marker ? fullTrace.marker.cornerradius : undefined;\n if(cr !== undefined) break;\n }\n // If any trace has cornerradius, store first cornerradius\n // in calcTrace[0].t so that all traces in stack use same cornerradius\n if(cr !== undefined) {\n crValue = isNumeric(cr) ? +cr : +cr.slice(0, -1);\n crForm = isNumeric(cr) ? 'px' : '%';\n for(i = 0; i < calcTraces.length; i++) {\n calcTrace = calcTraces[i];\n t = calcTrace[0].t;\n\n t.cornerradiusvalue = crValue;\n t.cornerradiusform = crForm;\n }\n }\n}\n\nfunction initBase(sa, calcTraces) {\n var i, j;\n\n for(i = 0; i < calcTraces.length; i++) {\n var cd = calcTraces[i];\n var trace = cd[0].trace;\n var base = (trace.type === 'funnel') ? trace._base : trace.base;\n var b;\n\n // not sure if it really makes sense to have dates for bar size data...\n // ideally if we want to make gantt charts or something we'd treat\n // the actual size (trace.x or y) as time delta but base as absolute\n // time. But included here for completeness.\n var scalendar = trace.orientation === 'h' ? trace.xcalendar : trace.ycalendar;\n\n // 'base' on categorical axes makes no sense\n var d2c = sa.type === 'category' || sa.type === 'multicategory' ?\n function() { return null; } :\n sa.d2c;\n\n if(isArrayOrTypedArray(base)) {\n for(j = 0; j < Math.min(base.length, cd.length); j++) {\n b = d2c(base[j], 0, scalendar);\n if(isNumeric(b)) {\n cd[j].b = +b;\n cd[j].hasB = 1;\n } else cd[j].b = 0;\n }\n for(; j < cd.length; j++) {\n cd[j].b = 0;\n }\n } else {\n b = d2c(base, 0, scalendar);\n var hasBase = isNumeric(b);\n b = hasBase ? b : 0;\n for(j = 0; j < cd.length; j++) {\n cd[j].b = b;\n if(hasBase) cd[j].hasB = 1;\n }\n }\n }\n}\n\nfunction setGroupPositionsInOverlayMode(pa, sa, calcTraces, opts) {\n // update position axis and set bar offsets and widths\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n\n var sieve = new Sieve([calcTrace], {\n posAxis: pa,\n sepNegVal: false,\n overlapNoMerge: !opts.norm\n });\n\n // set bar offsets and widths, and update position axis\n setOffsetAndWidth(pa, sieve, opts);\n\n // set bar bases and sizes, and update size axis\n //\n // (note that `setGroupPositionsInOverlayMode` handles the case barnorm\n // is defined, because this function is also invoked for traces that\n // can't be grouped or stacked)\n if(opts.norm) {\n sieveBars(sieve);\n normalizeBars(sa, sieve, opts);\n } else {\n setBaseAndTop(sa, sieve);\n }\n }\n}\n\nfunction setGroupPositionsInGroupMode(gd, pa, sa, calcTraces, opts) {\n var sieve = new Sieve(calcTraces, {\n posAxis: pa,\n sepNegVal: false,\n overlapNoMerge: !opts.norm\n });\n\n // set bar offsets and widths, and update position axis\n setOffsetAndWidthInGroupMode(gd, pa, sieve, opts);\n\n // relative-stack bars within the same trace that would otherwise\n // be hidden\n unhideBarsWithinTrace(sieve, pa);\n\n // set bar bases and sizes, and update size axis\n if(opts.norm) {\n sieveBars(sieve);\n normalizeBars(sa, sieve, opts);\n } else {\n setBaseAndTop(sa, sieve);\n }\n}\n\nfunction setGroupPositionsInStackOrRelativeMode(gd, pa, sa, calcTraces, opts) {\n var sieve = new Sieve(calcTraces, {\n posAxis: pa,\n sepNegVal: opts.mode === 'relative',\n overlapNoMerge: !(opts.norm || opts.mode === 'stack' || opts.mode === 'relative')\n });\n\n // set bar offsets and widths, and update position axis\n setOffsetAndWidth(pa, sieve, opts);\n\n // set bar bases and sizes, and update size axis\n stackBars(sa, sieve, opts);\n\n // flag the outmost bar (for text display purposes)\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n\n for(var j = 0; j < calcTrace.length; j++) {\n var bar = calcTrace[j];\n\n if(bar.s !== BADNUM) {\n var isOutmostBar = ((bar.b + bar.s) === sieve.get(bar.p, bar.s));\n if(isOutmostBar) bar._outmost = true;\n }\n }\n }\n\n // Note that marking the outmost bars has to be done\n // before `normalizeBars` changes `bar.b` and `bar.s`.\n if(opts.norm) normalizeBars(sa, sieve, opts);\n}\n\nfunction setOffsetAndWidth(pa, sieve, opts) {\n var minDiff = sieve.minDiff;\n var calcTraces = sieve.traces;\n\n // set bar offsets and widths\n var barGroupWidth = minDiff * (1 - opts.gap);\n var barWidthPlusGap = barGroupWidth;\n var barWidth = barWidthPlusGap * (1 - (opts.groupgap || 0));\n\n // computer bar group center and bar offset\n var offsetFromCenter = -barWidth / 2;\n\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n var t = calcTrace[0].t;\n\n // store bar width and offset for this trace\n t.barwidth = barWidth;\n t.poffset = offsetFromCenter;\n t.bargroupwidth = barGroupWidth;\n t.bardelta = minDiff;\n }\n\n // stack bars that only differ by rounding\n sieve.binWidth = calcTraces[0][0].t.barwidth / 100;\n\n // if defined, apply trace offset and width\n applyAttributes(sieve);\n\n // store the bar center in each calcdata item\n setBarCenterAndWidth(pa, sieve);\n\n // update position axes\n updatePositionAxis(pa, sieve);\n}\n\nfunction setOffsetAndWidthInGroupMode(gd, pa, sieve, opts) {\n var fullLayout = gd._fullLayout;\n var positions = sieve.positions;\n var distinctPositions = sieve.distinctPositions;\n var minDiff = sieve.minDiff;\n var calcTraces = sieve.traces;\n var nTraces = calcTraces.length;\n\n // if there aren't any overlapping positions,\n // let them have full width even if mode is group\n var overlap = (positions.length !== distinctPositions.length);\n var barGroupWidth = minDiff * (1 - opts.gap);\n\n var groupId = getAxisGroup(fullLayout, pa._id) + calcTraces[0][0].trace.orientation;\n var alignmentGroups = fullLayout._alignmentOpts[groupId] || {};\n\n for(var i = 0; i < nTraces; i++) {\n var calcTrace = calcTraces[i];\n var trace = calcTrace[0].trace;\n\n var alignmentGroupOpts = alignmentGroups[trace.alignmentgroup] || {};\n var nOffsetGroups = Object.keys(alignmentGroupOpts.offsetGroups || {}).length;\n\n var barWidthPlusGap;\n if(nOffsetGroups) {\n barWidthPlusGap = barGroupWidth / nOffsetGroups;\n } else {\n barWidthPlusGap = overlap ? barGroupWidth / nTraces : barGroupWidth;\n }\n\n var barWidth = barWidthPlusGap * (1 - (opts.groupgap || 0));\n\n var offsetFromCenter;\n if(nOffsetGroups) {\n offsetFromCenter = ((2 * trace._offsetIndex + 1 - nOffsetGroups) * barWidthPlusGap - barWidth) / 2;\n } else {\n offsetFromCenter = overlap ?\n ((2 * i + 1 - nTraces) * barWidthPlusGap - barWidth) / 2 :\n -barWidth / 2;\n }\n\n var t = calcTrace[0].t;\n t.barwidth = barWidth;\n t.poffset = offsetFromCenter;\n t.bargroupwidth = barGroupWidth;\n t.bardelta = minDiff;\n }\n\n // stack bars that only differ by rounding\n sieve.binWidth = calcTraces[0][0].t.barwidth / 100;\n\n // if defined, apply trace width\n applyAttributes(sieve);\n\n // store the bar center in each calcdata item\n setBarCenterAndWidth(pa, sieve);\n\n // update position axes\n updatePositionAxis(pa, sieve, overlap);\n}\n\nfunction applyAttributes(sieve) {\n var calcTraces = sieve.traces;\n var i, j;\n\n for(i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n var calcTrace0 = calcTrace[0];\n var fullTrace = calcTrace0.trace;\n var t = calcTrace0.t;\n var offset = fullTrace._offset || fullTrace.offset;\n var initialPoffset = t.poffset;\n var newPoffset;\n\n if(isArrayOrTypedArray(offset)) {\n // if offset is an array, then clone it into t.poffset.\n newPoffset = Array.prototype.slice.call(offset, 0, calcTrace.length);\n\n // guard against non-numeric items\n for(j = 0; j < newPoffset.length; j++) {\n if(!isNumeric(newPoffset[j])) {\n newPoffset[j] = initialPoffset;\n }\n }\n\n // if the length of the array is too short,\n // then extend it with the initial value of t.poffset\n for(j = newPoffset.length; j < calcTrace.length; j++) {\n newPoffset.push(initialPoffset);\n }\n\n t.poffset = newPoffset;\n } else if(offset !== undefined) {\n t.poffset = offset;\n }\n\n var width = fullTrace._width || fullTrace.width;\n var initialBarwidth = t.barwidth;\n\n if(isArrayOrTypedArray(width)) {\n // if width is an array, then clone it into t.barwidth.\n var newBarwidth = Array.prototype.slice.call(width, 0, calcTrace.length);\n\n // guard against non-numeric items\n for(j = 0; j < newBarwidth.length; j++) {\n if(!isNumeric(newBarwidth[j])) newBarwidth[j] = initialBarwidth;\n }\n\n // if the length of the array is too short,\n // then extend it with the initial value of t.barwidth\n for(j = newBarwidth.length; j < calcTrace.length; j++) {\n newBarwidth.push(initialBarwidth);\n }\n\n t.barwidth = newBarwidth;\n\n // if user didn't set offset,\n // then correct t.poffset to ensure bars remain centered\n if(offset === undefined) {\n newPoffset = [];\n for(j = 0; j < calcTrace.length; j++) {\n newPoffset.push(\n initialPoffset + (initialBarwidth - newBarwidth[j]) / 2\n );\n }\n t.poffset = newPoffset;\n }\n } else if(width !== undefined) {\n t.barwidth = width;\n\n // if user didn't set offset,\n // then correct t.poffset to ensure bars remain centered\n if(offset === undefined) {\n t.poffset = initialPoffset + (initialBarwidth - width) / 2;\n }\n }\n }\n}\n\nfunction setBarCenterAndWidth(pa, sieve) {\n var calcTraces = sieve.traces;\n var pLetter = getAxisLetter(pa);\n\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n var t = calcTrace[0].t;\n var poffset = t.poffset;\n var poffsetIsArray = isArrayOrTypedArray(poffset);\n var barwidth = t.barwidth;\n var barwidthIsArray = isArrayOrTypedArray(barwidth);\n\n for(var j = 0; j < calcTrace.length; j++) {\n var calcBar = calcTrace[j];\n\n // store the actual bar width and position, for use by hover\n var width = calcBar.w = barwidthIsArray ? barwidth[j] : barwidth;\n\n if(calcBar.p === undefined) {\n calcBar.p = calcBar[pLetter];\n calcBar['orig_' + pLetter] = calcBar[pLetter];\n }\n\n var delta = (poffsetIsArray ? poffset[j] : poffset) + width / 2;\n calcBar[pLetter] = calcBar.p + delta;\n }\n }\n}\n\nfunction updatePositionAxis(pa, sieve, allowMinDtick) {\n var calcTraces = sieve.traces;\n var minDiff = sieve.minDiff;\n var vpad = minDiff / 2;\n\n Axes.minDtick(pa, sieve.minDiff, sieve.distinctPositions[0], allowMinDtick);\n\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n var calcTrace0 = calcTrace[0];\n var fullTrace = calcTrace0.trace;\n var pts = [];\n var bar, l, r, j;\n\n for(j = 0; j < calcTrace.length; j++) {\n bar = calcTrace[j];\n l = bar.p - vpad;\n r = bar.p + vpad;\n pts.push(l, r);\n }\n\n if(fullTrace.width || fullTrace.offset) {\n var t = calcTrace0.t;\n var poffset = t.poffset;\n var barwidth = t.barwidth;\n var poffsetIsArray = isArrayOrTypedArray(poffset);\n var barwidthIsArray = isArrayOrTypedArray(barwidth);\n\n for(j = 0; j < calcTrace.length; j++) {\n bar = calcTrace[j];\n var calcBarOffset = poffsetIsArray ? poffset[j] : poffset;\n var calcBarWidth = barwidthIsArray ? barwidth[j] : barwidth;\n l = bar.p + calcBarOffset;\n r = l + calcBarWidth;\n pts.push(l, r);\n }\n }\n\n fullTrace._extremes[pa._id] = Axes.findExtremes(pa, pts, {padded: false});\n }\n}\n\n// store these bar bases and tops in calcdata\n// and make sure the size axis includes zero,\n// along with the bases and tops of each bar.\nfunction setBaseAndTop(sa, sieve) {\n var calcTraces = sieve.traces;\n var sLetter = getAxisLetter(sa);\n\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n var fullTrace = calcTrace[0].trace;\n var isScatter = fullTrace.type === 'scatter';\n var isVertical = fullTrace.orientation === 'v';\n var pts = [];\n var tozero = false;\n\n for(var j = 0; j < calcTrace.length; j++) {\n var bar = calcTrace[j];\n var base = isScatter ? 0 : bar.b;\n var top = isScatter ? (\n isVertical ? bar.y : bar.x\n ) : base + bar.s;\n\n bar[sLetter] = top;\n pts.push(top);\n if(bar.hasB) pts.push(base);\n\n if(!bar.hasB || !bar.b) {\n tozero = true;\n }\n }\n\n fullTrace._extremes[sa._id] = Axes.findExtremes(sa, pts, {\n tozero: tozero,\n padded: true\n });\n }\n}\n\nfunction stackBars(sa, sieve, opts) {\n var sLetter = getAxisLetter(sa);\n var calcTraces = sieve.traces;\n var calcTrace;\n var fullTrace;\n var isFunnel;\n var i, j;\n var bar;\n\n for(i = 0; i < calcTraces.length; i++) {\n calcTrace = calcTraces[i];\n fullTrace = calcTrace[0].trace;\n\n if(fullTrace.type === 'funnel') {\n for(j = 0; j < calcTrace.length; j++) {\n bar = calcTrace[j];\n\n if(bar.s !== BADNUM) {\n // create base of funnels\n sieve.put(bar.p, -0.5 * bar.s);\n }\n }\n }\n }\n\n for(i = 0; i < calcTraces.length; i++) {\n calcTrace = calcTraces[i];\n fullTrace = calcTrace[0].trace;\n\n isFunnel = (fullTrace.type === 'funnel');\n\n var pts = [];\n\n for(j = 0; j < calcTrace.length; j++) {\n bar = calcTrace[j];\n\n if(bar.s !== BADNUM) {\n // stack current bar and get previous sum\n var value;\n if(isFunnel) {\n value = bar.s;\n } else {\n value = bar.s + bar.b;\n }\n\n var base = sieve.put(bar.p, value);\n\n var top = base + value;\n\n // store the bar base and top in each calcdata item\n bar.b = base;\n bar[sLetter] = top;\n\n if(!opts.norm) {\n pts.push(top);\n if(bar.hasB) {\n pts.push(base);\n }\n }\n }\n }\n\n // if barnorm is set, let normalizeBars update the axis range\n if(!opts.norm) {\n fullTrace._extremes[sa._id] = Axes.findExtremes(sa, pts, {\n // N.B. we don't stack base with 'base',\n // so set tozero:true always!\n tozero: true,\n padded: true\n });\n }\n }\n}\n\nfunction sieveBars(sieve) {\n var calcTraces = sieve.traces;\n\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n\n for(var j = 0; j < calcTrace.length; j++) {\n var bar = calcTrace[j];\n\n if(bar.s !== BADNUM) {\n sieve.put(bar.p, bar.b + bar.s);\n }\n }\n }\n}\n\nfunction unhideBarsWithinTrace(sieve, pa) {\n var calcTraces = sieve.traces;\n\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n var fullTrace = calcTrace[0].trace;\n\n if(fullTrace.base === undefined) {\n var inTraceSieve = new Sieve([calcTrace], {\n posAxis: pa,\n sepNegVal: true,\n overlapNoMerge: true\n });\n\n for(var j = 0; j < calcTrace.length; j++) {\n var bar = calcTrace[j];\n\n if(bar.p !== BADNUM) {\n // stack current bar and get previous sum\n var base = inTraceSieve.put(bar.p, bar.b + bar.s);\n\n // if previous sum if non-zero, this means:\n // multiple bars have same starting point are potentially hidden,\n // shift them vertically so that all bars are visible by default\n if(base) bar.b = base;\n }\n }\n }\n }\n}\n\n// Note:\n//\n// normalizeBars requires that either sieveBars or stackBars has been\n// previously invoked.\nfunction normalizeBars(sa, sieve, opts) {\n var calcTraces = sieve.traces;\n var sLetter = getAxisLetter(sa);\n var sTop = opts.norm === 'fraction' ? 1 : 100;\n var sTiny = sTop / 1e9; // in case of rounding error in sum\n var sMin = sa.l2c(sa.c2l(0));\n var sMax = opts.mode === 'stack' ? sTop : sMin;\n\n function needsPadding(v) {\n return (\n isNumeric(sa.c2l(v)) &&\n ((v < sMin - sTiny) || (v > sMax + sTiny) || !isNumeric(sMin))\n );\n }\n\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n var fullTrace = calcTrace[0].trace;\n var pts = [];\n var tozero = false;\n var padded = false;\n\n for(var j = 0; j < calcTrace.length; j++) {\n var bar = calcTrace[j];\n\n if(bar.s !== BADNUM) {\n var scale = Math.abs(sTop / sieve.get(bar.p, bar.s));\n bar.b *= scale;\n bar.s *= scale;\n\n var base = bar.b;\n var top = base + bar.s;\n\n bar[sLetter] = top;\n pts.push(top);\n padded = padded || needsPadding(top);\n\n if(bar.hasB) {\n pts.push(base);\n padded = padded || needsPadding(base);\n }\n\n if(!bar.hasB || !bar.b) {\n tozero = true;\n }\n }\n }\n\n fullTrace._extremes[sa._id] = Axes.findExtremes(sa, pts, {\n tozero: tozero,\n padded: padded\n });\n }\n}\n\n// Add an `_sMin` and `_sMax` value for each bar representing the min and max size value\n// across all bars sharing the same position as that bar. These values are used for rounded\n// bar corners, to carry rounding down to lower bars in the stack as needed.\nfunction setHelperValuesForRoundedCorners(calcTraces, sMinByPos, sMaxByPos, pa) {\n var pLetter = getAxisLetter(pa);\n // Set `_sMin` and `_sMax` value for each bar\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n for(var j = 0; j < calcTrace.length; j++) {\n var bar = calcTrace[j];\n var pos = bar[pLetter];\n bar._sMin = sMinByPos[pos];\n bar._sMax = sMaxByPos[pos];\n }\n }\n}\n\n// find the full position span of bars at each position\n// for use by hover, to ensure labels move in if bars are\n// narrower than the space they're in.\n// run once per trace group (subplot & direction) and\n// the same mapping is attached to all calcdata traces\nfunction collectExtents(calcTraces, pa) {\n var pLetter = getAxisLetter(pa);\n var extents = {};\n var i, j, cd;\n\n var pMin = Infinity;\n var pMax = -Infinity;\n\n for(i = 0; i < calcTraces.length; i++) {\n cd = calcTraces[i];\n for(j = 0; j < cd.length; j++) {\n var p = cd[j].p;\n if(isNumeric(p)) {\n pMin = Math.min(pMin, p);\n pMax = Math.max(pMax, p);\n }\n }\n }\n\n // this is just for positioning of hover labels, and nobody will care if\n // the label is 1px too far out; so round positions to 1/10K in case\n // position values don't exactly match from trace to trace\n var roundFactor = 10000 / (pMax - pMin);\n var round = extents.round = function(p) {\n return String(Math.round(roundFactor * (p - pMin)));\n };\n\n // Find min and max size axis extent for each position\n // This is used for rounded bar corners, to carry rounding\n // down to lower bars in the case of stacked bars\n var sMinByPos = {};\n var sMaxByPos = {};\n\n // Check whether any trace has rounded corners\n var anyTraceHasCornerradius = calcTraces.some(function(x) {\n var trace = x[0].trace;\n return 'marker' in trace && trace.marker.cornerradius;\n });\n\n for(i = 0; i < calcTraces.length; i++) {\n cd = calcTraces[i];\n cd[0].t.extents = extents;\n\n var poffset = cd[0].t.poffset;\n var poffsetIsArray = isArrayOrTypedArray(poffset);\n\n for(j = 0; j < cd.length; j++) {\n var di = cd[j];\n var p0 = di[pLetter] - di.w / 2;\n\n if(isNumeric(p0)) {\n var p1 = di[pLetter] + di.w / 2;\n var pVal = round(di.p);\n if(extents[pVal]) {\n extents[pVal] = [Math.min(p0, extents[pVal][0]), Math.max(p1, extents[pVal][1])];\n } else {\n extents[pVal] = [p0, p1];\n }\n }\n\n di.p0 = di.p + (poffsetIsArray ? poffset[j] : poffset);\n di.p1 = di.p0 + di.w;\n di.s0 = di.b;\n di.s1 = di.s0 + di.s;\n\n if(anyTraceHasCornerradius) {\n var sMin = Math.min(di.s0, di.s1) || 0;\n var sMax = Math.max(di.s0, di.s1) || 0;\n var pos = di[pLetter];\n sMinByPos[pos] = (pos in sMinByPos) ? Math.min(sMinByPos[pos], sMin) : sMin;\n sMaxByPos[pos] = (pos in sMaxByPos) ? Math.max(sMaxByPos[pos], sMax) : sMax;\n }\n }\n }\n if(anyTraceHasCornerradius) {\n setHelperValuesForRoundedCorners(calcTraces, sMinByPos, sMaxByPos, pa);\n }\n}\n\nfunction getAxisLetter(ax) {\n return ax._id.charAt(0);\n}\n\nmodule.exports = {\n crossTraceCalc: crossTraceCalc,\n setGroupPositions: setGroupPositions\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar Color = require('../../components/color');\nvar Registry = require('../../registry');\n\nvar handleXYDefaults = require('../scatter/xy_defaults');\nvar handlePeriodDefaults = require('../scatter/period_defaults');\nvar handleStyleDefaults = require('./style_defaults');\nvar handleGroupingDefaults = require('../scatter/grouping_defaults');\nvar attributes = require('./attributes');\n\nvar coerceFont = Lib.coerceFont;\n\nfunction supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleXYDefaults(traceIn, traceOut, layout, coerce);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n handlePeriodDefaults(traceIn, traceOut, layout, coerce);\n coerce('xhoverformat');\n coerce('yhoverformat');\n\n coerce('zorder');\n\n coerce('orientation', (traceOut.x && !traceOut.y) ? 'h' : 'v');\n coerce('base');\n coerce('offset');\n coerce('width');\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n\n var textposition = coerce('textposition');\n handleText(traceIn, traceOut, layout, coerce, textposition, {\n moduleHasSelected: true,\n moduleHasUnselected: true,\n moduleHasConstrain: true,\n moduleHasCliponaxis: true,\n moduleHasTextangle: true,\n moduleHasInsideanchor: true\n });\n\n handleStyleDefaults(traceIn, traceOut, coerce, defaultColor, layout);\n var lineColor = (traceOut.marker.line || {}).color;\n\n // override defaultColor for error bars with defaultLine\n var errorBarsSupplyDefaults = Registry.getComponentMethod('errorbars', 'supplyDefaults');\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || Color.defaultLine, {axis: 'y'});\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || Color.defaultLine, {axis: 'x', inherit: 'y'});\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n}\n\nfunction crossTraceDefaults(fullData, fullLayout) {\n var traceIn, traceOut;\n\n function coerce(attr, dflt) {\n return Lib.coerce(traceOut._input, traceOut, attributes, attr, dflt);\n }\n\n for(var i = 0; i < fullData.length; i++) {\n traceOut = fullData[i];\n\n if(traceOut.type === 'bar') {\n traceIn = traceOut._input;\n // `marker.cornerradius` needs to be coerced here rather than in handleStyleDefaults()\n // because it needs to happen after `layout.barcornerradius` has been coerced\n var r = coerce('marker.cornerradius', fullLayout.barcornerradius);\n if(traceOut.marker) {\n traceOut.marker.cornerradius = validateCornerradius(r);\n }\n\n if(fullLayout.barmode === 'group') {\n handleGroupingDefaults(traceIn, traceOut, fullLayout, coerce);\n }\n }\n }\n}\n\n// Returns a value equivalent to the given cornerradius value, if valid;\n// otherwise returns`undefined`.\n// Valid cornerradius values must be either:\n// - a numeric value (string or number) >= 0, or\n// - a string consisting of a number >= 0 followed by a % sign\n// If the given cornerradius value is a numeric string, it will be converted\n// to a number.\nfunction validateCornerradius(r) {\n if(isNumeric(r)) {\n r = +r;\n if(r >= 0) return r;\n } else if(typeof r === 'string') {\n r = r.trim();\n if(r.slice(-1) === '%' && isNumeric(r.slice(0, -1))) {\n r = +r.slice(0, -1);\n if(r >= 0) return r + '%';\n }\n }\n return undefined;\n}\n\nfunction handleText(traceIn, traceOut, layout, coerce, textposition, opts) {\n opts = opts || {};\n var moduleHasSelected = !(opts.moduleHasSelected === false);\n var moduleHasUnselected = !(opts.moduleHasUnselected === false);\n var moduleHasConstrain = !(opts.moduleHasConstrain === false);\n var moduleHasCliponaxis = !(opts.moduleHasCliponaxis === false);\n var moduleHasTextangle = !(opts.moduleHasTextangle === false);\n var moduleHasInsideanchor = !(opts.moduleHasInsideanchor === false);\n var hasPathbar = !!opts.hasPathbar;\n\n var hasBoth = Array.isArray(textposition) || textposition === 'auto';\n var hasInside = hasBoth || textposition === 'inside';\n var hasOutside = hasBoth || textposition === 'outside';\n\n if(hasInside || hasOutside) {\n var dfltFont = coerceFont(coerce, 'textfont', layout.font);\n\n // Note that coercing `insidetextfont` is always needed –\n // even if `textposition` is `outside` for each trace – since\n // an outside label can become an inside one, for example because\n // of a bar being stacked on top of it.\n var insideTextFontDefault = Lib.extendFlat({}, dfltFont);\n var isTraceTextfontColorSet = traceIn.textfont && traceIn.textfont.color;\n var isColorInheritedFromLayoutFont = !isTraceTextfontColorSet;\n if(isColorInheritedFromLayoutFont) {\n delete insideTextFontDefault.color;\n }\n coerceFont(coerce, 'insidetextfont', insideTextFontDefault);\n\n if(hasPathbar) {\n var pathbarTextFontDefault = Lib.extendFlat({}, dfltFont);\n if(isColorInheritedFromLayoutFont) {\n delete pathbarTextFontDefault.color;\n }\n coerceFont(coerce, 'pathbar.textfont', pathbarTextFontDefault);\n }\n\n if(hasOutside) coerceFont(coerce, 'outsidetextfont', dfltFont);\n\n if(moduleHasSelected) coerce('selected.textfont.color');\n if(moduleHasUnselected) coerce('unselected.textfont.color');\n if(moduleHasConstrain) coerce('constraintext');\n if(moduleHasCliponaxis) coerce('cliponaxis');\n if(moduleHasTextangle) coerce('textangle');\n\n coerce('texttemplate');\n }\n\n if(hasInside) {\n if(moduleHasInsideanchor) coerce('insidetextanchor');\n }\n}\n\nmodule.exports = {\n supplyDefaults: supplyDefaults,\n crossTraceDefaults: crossTraceDefaults,\n handleText: handleText,\n validateCornerradius: validateCornerradius,\n};\n","'use strict';\n\nmodule.exports = function eventData(out, pt, trace) {\n // standard cartesian event data\n out.x = 'xVal' in pt ? pt.xVal : pt.x;\n out.y = 'yVal' in pt ? pt.yVal : pt.y;\n if(pt.xa) out.xaxis = pt.xa;\n if(pt.ya) out.yaxis = pt.ya;\n\n if(trace.orientation === 'h') {\n out.label = out.y;\n out.value = out.x;\n } else {\n out.label = out.x;\n out.value = out.y;\n }\n\n return out;\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar tinycolor = require('tinycolor2');\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\n\nexports.coerceString = function(attributeDefinition, value, defaultValue) {\n if(typeof value === 'string') {\n if(value || !attributeDefinition.noBlank) return value;\n } else if(typeof value === 'number' || value === true) {\n if(!attributeDefinition.strict) return String(value);\n }\n\n return (defaultValue !== undefined) ?\n defaultValue :\n attributeDefinition.dflt;\n};\n\nexports.coerceNumber = function(attributeDefinition, value, defaultValue) {\n if(isNumeric(value)) {\n value = +value;\n\n var min = attributeDefinition.min;\n var max = attributeDefinition.max;\n var isOutOfBounds = (min !== undefined && value < min) ||\n (max !== undefined && value > max);\n\n if(!isOutOfBounds) return value;\n }\n\n return (defaultValue !== undefined) ?\n defaultValue :\n attributeDefinition.dflt;\n};\n\nexports.coerceColor = function(attributeDefinition, value, defaultValue) {\n if(tinycolor(value).isValid()) return value;\n\n return (defaultValue !== undefined) ?\n defaultValue :\n attributeDefinition.dflt;\n};\n\nexports.coerceEnumerated = function(attributeDefinition, value, defaultValue) {\n if(attributeDefinition.coerceNumber) value = +value;\n\n if(attributeDefinition.values.indexOf(value) !== -1) return value;\n\n return (defaultValue !== undefined) ?\n defaultValue :\n attributeDefinition.dflt;\n};\n\nexports.getValue = function(arrayOrScalar, index) {\n var value;\n if(!isArrayOrTypedArray(arrayOrScalar)) value = arrayOrScalar;\n else if(index < arrayOrScalar.length) value = arrayOrScalar[index];\n return value;\n};\n\nexports.getLineWidth = function(trace, di) {\n var w =\n (0 < di.mlw) ? di.mlw :\n !isArrayOrTypedArray(trace.marker.line.width) ? trace.marker.line.width :\n 0;\n\n return w;\n};\n","'use strict';\n\nvar Fx = require('../../components/fx');\nvar Registry = require('../../registry');\nvar Color = require('../../components/color');\n\nvar fillText = require('../../lib').fillText;\nvar getLineWidth = require('./helpers').getLineWidth;\nvar hoverLabelText = require('../../plots/cartesian/axes').hoverLabelText;\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nfunction hoverPoints(pointData, xval, yval, hovermode, opts) {\n var barPointData = hoverOnBars(pointData, xval, yval, hovermode, opts);\n\n if(barPointData) {\n var cd = barPointData.cd;\n var trace = cd[0].trace;\n var di = cd[barPointData.index];\n\n barPointData.color = getTraceColor(trace, di);\n Registry.getComponentMethod('errorbars', 'hoverInfo')(di, trace, barPointData);\n\n return [barPointData];\n }\n}\n\nfunction hoverOnBars(pointData, xval, yval, hovermode, opts) {\n var cd = pointData.cd;\n var trace = cd[0].trace;\n var t = cd[0].t;\n var isClosest = (hovermode === 'closest');\n var isWaterfall = (trace.type === 'waterfall');\n var maxHoverDistance = pointData.maxHoverDistance;\n var maxSpikeDistance = pointData.maxSpikeDistance;\n\n var posVal, sizeVal, posLetter, sizeLetter, dx, dy, pRangeCalc;\n\n if(trace.orientation === 'h') {\n posVal = yval;\n sizeVal = xval;\n posLetter = 'y';\n sizeLetter = 'x';\n dx = sizeFn;\n dy = positionFn;\n } else {\n posVal = xval;\n sizeVal = yval;\n posLetter = 'x';\n sizeLetter = 'y';\n dy = sizeFn;\n dx = positionFn;\n }\n\n var period = trace[posLetter + 'period'];\n var isClosestOrPeriod = isClosest || period;\n\n function thisBarMinPos(di) { return thisBarExtPos(di, -1); }\n function thisBarMaxPos(di) { return thisBarExtPos(di, 1); }\n\n function thisBarExtPos(di, sgn) {\n var w = di.w;\n\n return di[posLetter] + sgn * w / 2;\n }\n\n function periodLength(di) {\n return di[posLetter + 'End'] - di[posLetter + 'Start'];\n }\n\n var minPos = isClosest ?\n thisBarMinPos : period ?\n function(di) {\n return di.p - periodLength(di) / 2;\n } :\n function(di) {\n /*\n * In compare mode, accept a bar if you're on it *or* its group.\n * Nearly always it's the group that matters, but in case the bar\n * was explicitly set wider than its group we'd better accept the\n * whole bar.\n *\n * use `bardelta` instead of `bargroupwidth` so we accept hover\n * in the gap. That way hover doesn't flash on and off as you\n * mouse over the plot in compare modes.\n * In 'closest' mode though the flashing seems inevitable,\n * without far more complex logic\n */\n return Math.min(thisBarMinPos(di), di.p - t.bardelta / 2);\n };\n\n var maxPos = isClosest ?\n thisBarMaxPos : period ?\n function(di) {\n return di.p + periodLength(di) / 2;\n } :\n function(di) {\n return Math.max(thisBarMaxPos(di), di.p + t.bardelta / 2);\n };\n\n function inbox(_minPos, _maxPos, maxDistance) {\n if(opts.finiteRange) maxDistance = 0;\n\n // add a little to the pseudo-distance for wider bars, so that like scatter,\n // if you are over two overlapping bars, the narrower one wins.\n return Fx.inbox(_minPos - posVal, _maxPos - posVal,\n maxDistance + Math.min(1, Math.abs(_maxPos - _minPos) / pRangeCalc) - 1);\n }\n\n function positionFn(di) {\n return inbox(minPos(di), maxPos(di), maxHoverDistance);\n }\n\n function thisBarPositionFn(di) {\n return inbox(thisBarMinPos(di), thisBarMaxPos(di), maxSpikeDistance);\n }\n\n function getSize(di) {\n var s = di[sizeLetter];\n\n if(isWaterfall) {\n var rawS = Math.abs(di.rawS) || 0;\n if(sizeVal > 0) {\n s += rawS;\n } else if(sizeVal < 0) {\n s -= rawS;\n }\n }\n\n return s;\n }\n\n function sizeFn(di) {\n var v = sizeVal;\n var b = di.b;\n var s = getSize(di);\n\n // add a gradient so hovering near the end of a\n // bar makes it a little closer match\n return Fx.inbox(b - v, s - v, maxHoverDistance + (s - v) / (s - b) - 1);\n }\n\n function thisBarSizeFn(di) {\n var v = sizeVal;\n var b = di.b;\n var s = getSize(di);\n\n // add a gradient so hovering near the end of a\n // bar makes it a little closer match\n return Fx.inbox(b - v, s - v, maxSpikeDistance + (s - v) / (s - b) - 1);\n }\n\n var pa = pointData[posLetter + 'a'];\n var sa = pointData[sizeLetter + 'a'];\n\n pRangeCalc = Math.abs(pa.r2c(pa.range[1]) - pa.r2c(pa.range[0]));\n\n function dxy(di) { return (dx(di) + dy(di)) / 2; }\n var distfn = Fx.getDistanceFunction(hovermode, dx, dy, dxy);\n Fx.getClosest(cd, distfn, pointData);\n\n // skip the rest (for this trace) if we didn't find a close point\n if(pointData.index === false) return;\n\n // skip points inside axis rangebreaks\n if(cd[pointData.index].p === BADNUM) return;\n\n // if we get here and we're not in 'closest' mode, push min/max pos back\n // onto the group - even though that means occasionally the mouse will be\n // over the hover label.\n if(!isClosestOrPeriod) {\n minPos = function(di) {\n return Math.min(thisBarMinPos(di), di.p - t.bargroupwidth / 2);\n };\n maxPos = function(di) {\n return Math.max(thisBarMaxPos(di), di.p + t.bargroupwidth / 2);\n };\n }\n\n // the closest data point\n var index = pointData.index;\n var di = cd[index];\n\n var size = (trace.base) ? di.b + di.s : di.s;\n pointData[sizeLetter + '0'] = pointData[sizeLetter + '1'] = sa.c2p(di[sizeLetter], true);\n pointData[sizeLetter + 'LabelVal'] = size;\n\n var extent = t.extents[t.extents.round(di.p)];\n pointData[posLetter + '0'] = pa.c2p(isClosest ? minPos(di) : extent[0], true);\n pointData[posLetter + '1'] = pa.c2p(isClosest ? maxPos(di) : extent[1], true);\n\n var hasPeriod = di.orig_p !== undefined;\n pointData[posLetter + 'LabelVal'] = hasPeriod ? di.orig_p : di.p;\n\n pointData.labelLabel = hoverLabelText(pa, pointData[posLetter + 'LabelVal'], trace[posLetter + 'hoverformat']);\n pointData.valueLabel = hoverLabelText(sa, pointData[sizeLetter + 'LabelVal'], trace[sizeLetter + 'hoverformat']);\n pointData.baseLabel = hoverLabelText(sa, di.b, trace[sizeLetter + 'hoverformat']);\n\n // spikelines always want \"closest\" distance regardless of hovermode\n pointData.spikeDistance = (thisBarSizeFn(di) + thisBarPositionFn(di)) / 2;\n // they also want to point to the data value, regardless of where the label goes\n // in case of bars shifted within groups\n pointData[posLetter + 'Spike'] = pa.c2p(di.p, true);\n\n fillText(di, trace, pointData);\n pointData.hovertemplate = trace.hovertemplate;\n\n return pointData;\n}\n\nfunction getTraceColor(trace, di) {\n var mc = di.mcc || trace.marker.color;\n var mlc = di.mlcc || trace.marker.line.color;\n var mlw = getLineWidth(trace, di);\n\n if(Color.opacity(mc)) return mc;\n else if(Color.opacity(mlc) && mlw) return mlc;\n}\n\nmodule.exports = {\n hoverPoints: hoverPoints,\n hoverOnBars: hoverOnBars,\n getTraceColor: getTraceColor\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n layoutAttributes: require('./layout_attributes'),\n supplyDefaults: require('./defaults').supplyDefaults,\n crossTraceDefaults: require('./defaults').crossTraceDefaults,\n supplyLayoutDefaults: require('./layout_defaults'),\n calc: require('./calc'),\n crossTraceCalc: require('./cross_trace_calc').crossTraceCalc,\n colorbar: require('../scatter/marker_colorbar'),\n arraysToCalcdata: require('./arrays_to_calcdata'),\n plot: require('./plot').plot,\n style: require('./style').style,\n styleOnSelect: require('./style').styleOnSelect,\n hoverPoints: require('./hover').hoverPoints,\n eventData: require('./event_data'),\n selectPoints: require('./select'),\n\n moduleType: 'trace',\n name: 'bar',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['bar-like', 'cartesian', 'svg', 'bar', 'oriented', 'errorBarsOK', 'showLegend', 'zoomScale'],\n animatable: true,\n meta: {\n description: [\n 'The data visualized by the span of the bars is set in `y`',\n 'if `orientation` is set to *v* (the default)',\n 'and the labels are set in `x`.',\n 'By setting `orientation` to *h*, the roles are interchanged.'\n ].join(' ')\n }\n};\n","'use strict';\n\n\nmodule.exports = {\n barmode: {\n valType: 'enumerated',\n values: ['stack', 'group', 'overlay', 'relative'],\n dflt: 'group',\n editType: 'calc',\n description: [\n 'Determines how bars at the same location coordinate',\n 'are displayed on the graph.',\n 'With *stack*, the bars are stacked on top of one another',\n 'With *relative*, the bars are stacked on top of one another,',\n 'with negative values below the axis, positive values above',\n 'With *group*, the bars are plotted next to one another',\n 'centered around the shared location.',\n 'With *overlay*, the bars are plotted over one another,',\n 'you might need to reduce *opacity* to see multiple bars.'\n ].join(' ')\n },\n barnorm: {\n valType: 'enumerated',\n values: ['', 'fraction', 'percent'],\n dflt: '',\n editType: 'calc',\n description: [\n 'Sets the normalization for bar traces on the graph.',\n 'With *fraction*, the value of each bar is divided by the sum of all',\n 'values at that location coordinate.',\n '*percent* is the same but multiplied by 100 to show percentages.'\n ].join(' ')\n },\n bargap: {\n valType: 'number',\n min: 0,\n max: 1,\n editType: 'calc',\n description: [\n 'Sets the gap (in plot fraction) between bars of',\n 'adjacent location coordinates.'\n ].join(' ')\n },\n bargroupgap: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0,\n editType: 'calc',\n description: [\n 'Sets the gap (in plot fraction) between bars of',\n 'the same location coordinate.'\n ].join(' ')\n },\n barcornerradius: {\n valType: 'any',\n editType: 'calc',\n description: [\n 'Sets the rounding of bar corners. May be an integer number of pixels,',\n 'or a percentage of bar width (as a string ending in %).'\n ].join(' ')\n },\n};\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Axes = require('../../plots/cartesian/axes');\nvar Lib = require('../../lib');\n\nvar layoutAttributes = require('./layout_attributes');\nvar validateCornerradius = require('./defaults').validateCornerradius;\n\n\nmodule.exports = function(layoutIn, layoutOut, fullData) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n\n var hasBars = false;\n var shouldBeGapless = false;\n var gappedAnyway = false;\n var usedSubplots = {};\n\n var mode = coerce('barmode');\n\n for(var i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n if(Registry.traceIs(trace, 'bar') && trace.visible) hasBars = true;\n else continue;\n\n // if we have at least 2 grouped bar traces on the same subplot,\n // we should default to a gap anyway, even if the data is histograms\n if(mode === 'group') {\n var subploti = trace.xaxis + trace.yaxis;\n if(usedSubplots[subploti]) gappedAnyway = true;\n usedSubplots[subploti] = true;\n }\n\n if(trace.visible && trace.type === 'histogram') {\n var pa = Axes.getFromId({_fullLayout: layoutOut},\n trace[trace.orientation === 'v' ? 'xaxis' : 'yaxis']);\n if(pa.type !== 'category') shouldBeGapless = true;\n }\n }\n\n if(!hasBars) {\n delete layoutOut.barmode;\n return;\n }\n\n if(mode !== 'overlay') coerce('barnorm');\n\n coerce('bargap', (shouldBeGapless && !gappedAnyway) ? 0 : 0.2);\n coerce('bargroupgap');\n var r = coerce('barcornerradius');\n layoutOut.barcornerradius = validateCornerradius(r);\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar svgTextUtils = require('../../lib/svg_text_utils');\n\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\nvar Registry = require('../../registry');\nvar tickText = require('../../plots/cartesian/axes').tickText;\n\nvar uniformText = require('./uniform_text');\nvar recordMinTextSize = uniformText.recordMinTextSize;\nvar clearMinTextSize = uniformText.clearMinTextSize;\n\nvar style = require('./style');\nvar helpers = require('./helpers');\nvar constants = require('./constants');\nvar attributes = require('./attributes');\n\nvar attributeText = attributes.text;\nvar attributeTextPosition = attributes.textposition;\n\nvar appendArrayPointValue = require('../../components/fx/helpers').appendArrayPointValue;\n\nvar TEXTPAD = constants.TEXTPAD;\n\nfunction keyFunc(d) {return d.id;}\nfunction getKeyFunc(trace) {\n if(trace.ids) {\n return keyFunc;\n }\n}\n\n// Returns -1 if v < 0, 1 if v > 0, and 0 if v == 0\nfunction sign(v) {\n return (v > 0) - (v < 0);\n}\n\n// Returns 1 if a < b and -1 otherwise\n// (For the purposes of this module we don't care about the case where a == b)\nfunction dirSign(a, b) {\n return (a < b) ? 1 : -1;\n}\n\nfunction getXY(di, xa, ya, isHorizontal) {\n var s = [];\n var p = [];\n\n var sAxis = isHorizontal ? xa : ya;\n var pAxis = isHorizontal ? ya : xa;\n\n s[0] = sAxis.c2p(di.s0, true);\n p[0] = pAxis.c2p(di.p0, true);\n\n s[1] = sAxis.c2p(di.s1, true);\n p[1] = pAxis.c2p(di.p1, true);\n\n return isHorizontal ? [s, p] : [p, s];\n}\n\nfunction transition(selection, fullLayout, opts, makeOnCompleteCallback) {\n if(!fullLayout.uniformtext.mode && hasTransition(opts)) {\n var onComplete;\n if(makeOnCompleteCallback) {\n onComplete = makeOnCompleteCallback();\n }\n return selection\n .transition()\n .duration(opts.duration)\n .ease(opts.easing)\n .each('end', function() { onComplete && onComplete(); })\n .each('interrupt', function() { onComplete && onComplete(); });\n } else {\n return selection;\n }\n}\n\nfunction hasTransition(transitionOpts) {\n return transitionOpts && transitionOpts.duration > 0;\n}\n\nfunction plot(gd, plotinfo, cdModule, traceLayer, opts, makeOnCompleteCallback) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var fullLayout = gd._fullLayout;\n var isStatic = gd._context.staticPlot;\n\n if(!opts) {\n opts = {\n mode: fullLayout.barmode,\n norm: fullLayout.barmode,\n gap: fullLayout.bargap,\n groupgap: fullLayout.bargroupgap\n };\n\n // don't clear bar when this is called from waterfall or funnel\n clearMinTextSize('bar', fullLayout);\n }\n\n var bartraces = Lib.makeTraceGroups(traceLayer, cdModule, 'trace bars').each(function(cd) {\n var plotGroup = d3.select(this);\n var trace = cd[0].trace;\n var t = cd[0].t;\n var isWaterfall = (trace.type === 'waterfall');\n var isFunnel = (trace.type === 'funnel');\n var isHistogram = (trace.type === 'histogram');\n var isBar = (trace.type === 'bar');\n var shouldDisplayZeros = (isBar || isFunnel);\n var adjustPixel = 0;\n if(isWaterfall && trace.connector.visible && trace.connector.mode === 'between') {\n adjustPixel = trace.connector.line.width / 2;\n }\n\n var isHorizontal = (trace.orientation === 'h');\n var withTransition = hasTransition(opts);\n\n var pointGroup = Lib.ensureSingle(plotGroup, 'g', 'points');\n\n var keyFunc = getKeyFunc(trace);\n var bars = pointGroup.selectAll('g.point').data(Lib.identity, keyFunc);\n\n bars.enter().append('g')\n .classed('point', true);\n\n bars.exit().remove();\n\n bars.each(function(di, i) {\n var bar = d3.select(this);\n\n // now display the bar\n // clipped xf/yf (2nd arg true): non-positive\n // log values go off-screen by plotwidth\n // so you see them continue if you drag the plot\n var xy = getXY(di, xa, ya, isHorizontal);\n\n var x0 = xy[0][0];\n var x1 = xy[0][1];\n var y0 = xy[1][0];\n var y1 = xy[1][1];\n\n // empty bars\n var isBlank = (isHorizontal ? x1 - x0 : y1 - y0) === 0;\n\n // display zeros if line.width > 0\n if(isBlank && shouldDisplayZeros && helpers.getLineWidth(trace, di)) {\n isBlank = false;\n }\n\n // skip nulls\n if(!isBlank) {\n isBlank = (\n !isNumeric(x0) ||\n !isNumeric(x1) ||\n !isNumeric(y0) ||\n !isNumeric(y1)\n );\n }\n\n // record isBlank\n di.isBlank = isBlank;\n\n // for blank bars, ensure start and end positions are equal - important for smooth transitions\n if(isBlank) {\n if(isHorizontal) {\n x1 = x0;\n } else {\n y1 = y0;\n }\n }\n\n // in waterfall mode `between` we need to adjust bar end points to match the connector width\n if(adjustPixel && !isBlank) {\n if(isHorizontal) {\n x0 -= dirSign(x0, x1) * adjustPixel;\n x1 += dirSign(x0, x1) * adjustPixel;\n } else {\n y0 -= dirSign(y0, y1) * adjustPixel;\n y1 += dirSign(y0, y1) * adjustPixel;\n }\n }\n\n var lw;\n var mc;\n\n if(trace.type === 'waterfall') {\n if(!isBlank) {\n var cont = trace[di.dir].marker;\n lw = cont.line.width;\n mc = cont.color;\n }\n } else {\n lw = helpers.getLineWidth(trace, di);\n mc = di.mc || trace.marker.color;\n }\n\n function roundWithLine(v) {\n var offset = d3.round((lw / 2) % 1, 2);\n\n // if there are explicit gaps, don't round,\n // it can make the gaps look crappy\n return (opts.gap === 0 && opts.groupgap === 0) ?\n d3.round(Math.round(v) - offset, 2) : v;\n }\n\n function expandToVisible(v, vc, hideZeroSpan) {\n if(hideZeroSpan && v === vc) {\n // should not expand zero span bars\n // when start and end positions are identical\n // i.e. for vertical when y0 === y1\n // and for horizontal when x0 === x1\n return v;\n }\n\n // if it's not in danger of disappearing entirely,\n // round more precisely\n return Math.abs(v - vc) >= 2 ? roundWithLine(v) :\n // but if it's very thin, expand it so it's\n // necessarily visible, even if it might overlap\n // its neighbor\n (v > vc ? Math.ceil(v) : Math.floor(v));\n }\n\n var op = Color.opacity(mc);\n var fixpx = (op < 1 || lw > 0.01) ? roundWithLine : expandToVisible;\n if(!gd._context.staticPlot) {\n // if bars are not fully opaque or they have a line\n // around them, round to integer pixels, mainly for\n // safari so we prevent overlaps from its expansive\n // pixelation. if the bars ARE fully opaque and have\n // no line, expand to a full pixel to make sure we\n // can see them\n x0 = fixpx(x0, x1, isHorizontal);\n x1 = fixpx(x1, x0, isHorizontal);\n y0 = fixpx(y0, y1, !isHorizontal);\n y1 = fixpx(y1, y0, !isHorizontal);\n }\n\n // Function to convert from size axis values to pixels\n var c2p = isHorizontal ? xa.c2p : ya.c2p;\n\n // Decide whether to use upper or lower bound of current bar stack\n // as reference point for rounding\n var outerBound;\n if(di.s0 > 0) {\n outerBound = di._sMax;\n } else if(di.s0 < 0) {\n outerBound = di._sMin;\n } else {\n outerBound = di.s1 > 0 ? di._sMax : di._sMin;\n }\n\n // Calculate corner radius of bar in pixels\n function calcCornerRadius(crValue, crForm) {\n if(!crValue) return 0;\n\n var barWidth = isHorizontal ? Math.abs(y1 - y0) : Math.abs(x1 - x0);\n var barLength = isHorizontal ? Math.abs(x1 - x0) : Math.abs(y1 - y0);\n var stackedBarTotalLength = fixpx(Math.abs(c2p(outerBound, true) - c2p(0, true)));\n var maxRadius = di.hasB ? Math.min(barWidth / 2, barLength / 2) : Math.min(barWidth / 2, stackedBarTotalLength);\n var crPx;\n\n if(crForm === '%') {\n // If radius is given as a % string, convert to number of pixels\n var crPercent = Math.min(50, crValue);\n crPx = barWidth * (crPercent / 100);\n } else {\n // Otherwise, it's already a number of pixels, use the given value\n crPx = crValue;\n }\n return fixpx(Math.max(Math.min(crPx, maxRadius), 0));\n }\n // Exclude anything which is not explicitly a bar or histogram chart from rounding\n var r = (isBar || isHistogram) ? calcCornerRadius(t.cornerradiusvalue, t.cornerradiusform) : 0;\n // Construct path string for bar\n var path, h;\n // Default rectangular path (used if no rounding)\n var rectanglePath = 'M' + x0 + ',' + y0 + 'V' + y1 + 'H' + x1 + 'V' + y0 + 'Z';\n var overhead = 0;\n if(r && di.s) {\n // Bar has cornerradius, and nonzero size\n // Check amount of 'overhead' (bars stacked above this one)\n // to see whether we need to round or not\n var refPoint = sign(di.s0) === 0 || sign(di.s) === sign(di.s0) ? di.s1 : di.s0;\n overhead = fixpx(!di.hasB ? Math.abs(c2p(outerBound, true) - c2p(refPoint, true)) : 0);\n if(overhead < r) {\n // Calculate parameters for rounded corners\n var xdir = dirSign(x0, x1);\n var ydir = dirSign(y0, y1);\n // Sweep direction for rounded corner arcs\n var cornersweep = (xdir === -ydir) ? 1 : 0;\n if(isHorizontal) {\n // Horizontal bars\n if(di.hasB) {\n // Floating base: Round 1st & 2nd, and 3rd & 4th corners\n path = 'M' + (x0 + r * xdir) + ',' + y0 +\n 'A ' + r + ',' + r + ' 0 0 ' + cornersweep + ' ' + x0 + ',' + (y0 + r * ydir) +\n 'V' + (y1 - r * ydir) +\n 'A ' + r + ',' + r + ' 0 0 ' + cornersweep + ' ' + (x0 + r * xdir) + ',' + y1 +\n 'H' + (x1 - r * xdir) +\n 'A ' + r + ',' + r + ' 0 0 ' + cornersweep + ' ' + x1 + ',' + (y1 - r * ydir) +\n 'V' + (y0 + r * ydir) +\n 'A ' + r + ',' + r + ' 0 0 ' + cornersweep + ' ' + (x1 - r * xdir) + ',' + y0 +\n 'Z';\n } else {\n // Base on axis: Round 3rd and 4th corners\n\n // Helper variables to help with extending rounding down to lower bars\n h = Math.abs(x1 - x0) + overhead;\n var dy1 = (h < r) ? r - Math.sqrt(h * (2 * r - h)) : 0;\n var dy2 = (overhead > 0) ? Math.sqrt(overhead * (2 * r - overhead)) : 0;\n var xminfunc = xdir > 0 ? Math.max : Math.min;\n\n path = 'M' + x0 + ',' + y0 +\n 'V' + (y1 - dy1 * ydir) +\n 'H' + xminfunc(x1 - (r - overhead) * xdir, x0) +\n 'A ' + r + ',' + r + ' 0 0 ' + cornersweep + ' ' + x1 + ',' + (y1 - r * ydir - dy2) +\n 'V' + (y0 + r * ydir + dy2) +\n 'A ' + r + ',' + r + ' 0 0 ' + cornersweep + ' ' + xminfunc(x1 - (r - overhead) * xdir, x0) + ',' + (y0 + dy1 * ydir) +\n 'Z';\n }\n } else {\n // Vertical bars\n if(di.hasB) {\n // Floating base: Round 1st & 4th, and 2nd & 3rd corners\n path = 'M' + (x0 + r * xdir) + ',' + y0 +\n 'A ' + r + ',' + r + ' 0 0 ' + cornersweep + ' ' + x0 + ',' + (y0 + r * ydir) +\n 'V' + (y1 - r * ydir) +\n 'A ' + r + ',' + r + ' 0 0 ' + cornersweep + ' ' + (x0 + r * xdir) + ',' + y1 +\n 'H' + (x1 - r * xdir) +\n 'A ' + r + ',' + r + ' 0 0 ' + cornersweep + ' ' + x1 + ',' + (y1 - r * ydir) +\n 'V' + (y0 + r * ydir) +\n 'A ' + r + ',' + r + ' 0 0 ' + cornersweep + ' ' + (x1 - r * xdir) + ',' + y0 +\n 'Z';\n } else {\n // Base on axis: Round 2nd and 3rd corners\n\n // Helper variables to help with extending rounding down to lower bars\n h = Math.abs(y1 - y0) + overhead;\n var dx1 = (h < r) ? r - Math.sqrt(h * (2 * r - h)) : 0;\n var dx2 = (overhead > 0) ? Math.sqrt(overhead * (2 * r - overhead)) : 0;\n var yminfunc = ydir > 0 ? Math.max : Math.min;\n\n path = 'M' + (x0 + dx1 * xdir) + ',' + y0 +\n 'V' + yminfunc(y1 - (r - overhead) * ydir, y0) +\n 'A ' + r + ',' + r + ' 0 0 ' + cornersweep + ' ' + (x0 + r * xdir - dx2) + ',' + y1 +\n 'H' + (x1 - r * xdir + dx2) +\n 'A ' + r + ',' + r + ' 0 0 ' + cornersweep + ' ' + (x1 - dx1 * xdir) + ',' + yminfunc(y1 - (r - overhead) * ydir, y0) +\n 'V' + y0 + 'Z';\n }\n }\n } else {\n // There is a cornerradius, but bar is too far down the stack to be rounded; just draw a rectangle\n path = rectanglePath;\n }\n } else {\n // No cornerradius, just draw a rectangle\n path = rectanglePath;\n }\n\n var sel = transition(Lib.ensureSingle(bar, 'path'), fullLayout, opts, makeOnCompleteCallback);\n sel\n .style('vector-effect', isStatic ? 'none' : 'non-scaling-stroke')\n .attr('d', (isNaN((x1 - x0) * (y1 - y0)) || (isBlank && gd._context.staticPlot)) ? 'M0,0Z' : path)\n .call(Drawing.setClipUrl, plotinfo.layerClipId, gd);\n\n if(!fullLayout.uniformtext.mode && withTransition) {\n var styleFns = Drawing.makePointStyleFns(trace);\n Drawing.singlePointStyle(di, sel, trace, styleFns, gd);\n }\n\n appendBarText(gd, plotinfo, bar, cd, i, x0, x1, y0, y1, r, overhead, opts, makeOnCompleteCallback);\n\n if(plotinfo.layerClipId) {\n Drawing.hideOutsideRangePoint(di, bar.select('text'), xa, ya, trace.xcalendar, trace.ycalendar);\n }\n });\n\n // lastly, clip points groups of `cliponaxis !== false` traces\n // on `plotinfo._hasClipOnAxisFalse === true` subplots\n var hasClipOnAxisFalse = trace.cliponaxis === false;\n Drawing.setClipUrl(plotGroup, hasClipOnAxisFalse ? null : plotinfo.layerClipId, gd);\n });\n\n // error bars are on the top\n Registry.getComponentMethod('errorbars', 'plot')(gd, bartraces, plotinfo, opts);\n}\n\nfunction appendBarText(gd, plotinfo, bar, cd, i, x0, x1, y0, y1, r, overhead, opts, makeOnCompleteCallback) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n var fullLayout = gd._fullLayout;\n var textPosition;\n\n function appendTextNode(bar, text, font) {\n var textSelection = Lib.ensureSingle(bar, 'text')\n .text(text)\n .attr({\n class: 'bartext bartext-' + textPosition,\n 'text-anchor': 'middle',\n // prohibit tex interpretation until we can handle\n // tex and regular text together\n 'data-notex': 1\n })\n .call(Drawing.font, font)\n .call(svgTextUtils.convertToTspans, gd);\n\n return textSelection;\n }\n\n // get trace attributes\n var trace = cd[0].trace;\n var isHorizontal = (trace.orientation === 'h');\n\n var text = getText(fullLayout, cd, i, xa, ya);\n\n textPosition = getTextPosition(trace, i);\n\n // compute text position\n var inStackOrRelativeMode =\n opts.mode === 'stack' ||\n opts.mode === 'relative';\n\n var calcBar = cd[i];\n var isOutmostBar = !inStackOrRelativeMode || calcBar._outmost;\n var hasB = calcBar.hasB;\n var barIsRounded = r && (r - overhead) > TEXTPAD;\n\n if(!text ||\n textPosition === 'none' ||\n ((calcBar.isBlank || x0 === x1 || y0 === y1) && (\n textPosition === 'auto' ||\n textPosition === 'inside'))) {\n bar.select('text').remove();\n return;\n }\n\n var layoutFont = fullLayout.font;\n var barColor = style.getBarColor(cd[i], trace);\n var insideTextFont = style.getInsideTextFont(trace, i, layoutFont, barColor);\n var outsideTextFont = style.getOutsideTextFont(trace, i, layoutFont);\n var insidetextanchor = trace.insidetextanchor || 'end';\n\n // Special case: don't use the c2p(v, true) value on log size axes,\n // so that we can get correctly inside text scaling\n var di = bar.datum();\n if(isHorizontal) {\n if(xa.type === 'log' && di.s0 <= 0) {\n if(xa.range[0] < xa.range[1]) {\n x0 = 0;\n } else {\n x0 = xa._length;\n }\n }\n } else {\n if(ya.type === 'log' && di.s0 <= 0) {\n if(ya.range[0] < ya.range[1]) {\n y0 = ya._length;\n } else {\n y0 = 0;\n }\n }\n }\n\n // Compute width and height of bar\n var lx = Math.abs(x1 - x0);\n var ly = Math.abs(y1 - y0);\n\n // padding excluded\n var barWidth = lx - 2 * TEXTPAD;\n var barHeight = ly - 2 * TEXTPAD;\n\n var textSelection;\n\n var textBB;\n var textWidth;\n var textHeight;\n var font;\n\n if(textPosition === 'outside') {\n if(!isOutmostBar && !calcBar.hasB) textPosition = 'inside';\n }\n\n if(textPosition === 'auto') {\n if(isOutmostBar) {\n // draw text using insideTextFont and check if it fits inside bar\n textPosition = 'inside';\n\n font = Lib.ensureUniformFontSize(gd, insideTextFont);\n\n textSelection = appendTextNode(bar, text, font);\n\n textBB = Drawing.bBox(textSelection.node());\n textWidth = textBB.width;\n textHeight = textBB.height;\n\n var textHasSize = (textWidth > 0 && textHeight > 0);\n\n var fitsInside;\n if(barIsRounded) {\n // If bar is rounded, check if text fits between rounded corners\n if(hasB) {\n fitsInside = (\n textfitsInsideBar(barWidth - 2 * r, barHeight, textWidth, textHeight, isHorizontal) ||\n textfitsInsideBar(barWidth, barHeight - 2 * r, textWidth, textHeight, isHorizontal)\n );\n } else if(isHorizontal) {\n fitsInside = (\n textfitsInsideBar(barWidth - (r - overhead), barHeight, textWidth, textHeight, isHorizontal) ||\n textfitsInsideBar(barWidth, barHeight - 2 * (r - overhead), textWidth, textHeight, isHorizontal)\n );\n } else {\n fitsInside = (\n textfitsInsideBar(barWidth, barHeight - (r - overhead), textWidth, textHeight, isHorizontal) ||\n textfitsInsideBar(barWidth - 2 * (r - overhead), barHeight, textWidth, textHeight, isHorizontal)\n );\n }\n } else {\n fitsInside = textfitsInsideBar(barWidth, barHeight, textWidth, textHeight, isHorizontal);\n }\n\n if(textHasSize && fitsInside) {\n textPosition = 'inside';\n } else {\n textPosition = 'outside';\n textSelection.remove();\n textSelection = null;\n }\n } else {\n textPosition = 'inside';\n }\n }\n\n if(!textSelection) {\n font = Lib.ensureUniformFontSize(gd, (textPosition === 'outside') ? outsideTextFont : insideTextFont);\n\n textSelection = appendTextNode(bar, text, font);\n\n var currentTransform = textSelection.attr('transform');\n textSelection.attr('transform', '');\n textBB = Drawing.bBox(textSelection.node()),\n textWidth = textBB.width,\n textHeight = textBB.height;\n textSelection.attr('transform', currentTransform);\n\n if(textWidth <= 0 || textHeight <= 0) {\n textSelection.remove();\n return;\n }\n }\n\n var angle = trace.textangle;\n\n // compute text transform\n var transform, constrained;\n if(textPosition === 'outside') {\n constrained =\n trace.constraintext === 'both' ||\n trace.constraintext === 'outside';\n\n transform = toMoveOutsideBar(x0, x1, y0, y1, textBB, {\n isHorizontal: isHorizontal,\n constrained: constrained,\n angle: angle\n });\n } else {\n constrained =\n trace.constraintext === 'both' ||\n trace.constraintext === 'inside';\n\n transform = toMoveInsideBar(x0, x1, y0, y1, textBB, {\n isHorizontal: isHorizontal,\n constrained: constrained,\n angle: angle,\n anchor: insidetextanchor,\n hasB: hasB,\n r: r,\n overhead: overhead,\n });\n }\n\n transform.fontSize = font.size;\n recordMinTextSize(trace.type === 'histogram' ? 'bar' : trace.type, transform, fullLayout);\n calcBar.transform = transform;\n\n var s = transition(textSelection, fullLayout, opts, makeOnCompleteCallback);\n Lib.setTransormAndDisplay(s, transform);\n}\n\nfunction textfitsInsideBar(barWidth, barHeight, textWidth, textHeight, isHorizontal) {\n if(barWidth < 0 || barHeight < 0) return false;\n var fitsInside = (textWidth <= barWidth && textHeight <= barHeight);\n var fitsInsideIfRotated = (textWidth <= barHeight && textHeight <= barWidth);\n var fitsInsideIfShrunk = (isHorizontal) ?\n (barWidth >= textWidth * (barHeight / textHeight)) :\n (barHeight >= textHeight * (barWidth / textWidth));\n return fitsInside || fitsInsideIfRotated || fitsInsideIfShrunk;\n}\n\nfunction getRotateFromAngle(angle) {\n return (angle === 'auto') ? 0 : angle;\n}\n\nfunction getRotatedTextSize(textBB, rotate) {\n var a = Math.PI / 180 * rotate;\n var absSin = Math.abs(Math.sin(a));\n var absCos = Math.abs(Math.cos(a));\n\n return {\n x: textBB.width * absCos + textBB.height * absSin,\n y: textBB.width * absSin + textBB.height * absCos\n };\n}\n\nfunction toMoveInsideBar(x0, x1, y0, y1, textBB, opts) {\n var isHorizontal = !!opts.isHorizontal;\n var constrained = !!opts.constrained;\n var angle = opts.angle || 0;\n var anchor = opts.anchor;\n var isEnd = anchor === 'end';\n var isStart = anchor === 'start';\n var leftToRight = opts.leftToRight || 0; // left: -1, center: 0, right: 1\n var toRight = (leftToRight + 1) / 2;\n var toLeft = 1 - toRight;\n var hasB = opts.hasB;\n var r = opts.r;\n var overhead = opts.overhead;\n\n var textWidth = textBB.width;\n var textHeight = textBB.height;\n\n var lx = Math.abs(x1 - x0);\n var ly = Math.abs(y1 - y0);\n\n // compute remaining space\n var textpad = (\n lx > (2 * TEXTPAD) &&\n ly > (2 * TEXTPAD)\n ) ? TEXTPAD : 0;\n\n lx -= 2 * textpad;\n ly -= 2 * textpad;\n\n var rotate = getRotateFromAngle(angle);\n if((angle === 'auto') &&\n !(textWidth <= lx && textHeight <= ly) &&\n (textWidth > lx || textHeight > ly) && (\n !(textWidth > ly || textHeight > lx) ||\n ((textWidth < textHeight) !== (lx < ly))\n )) {\n rotate += 90;\n }\n\n var t = getRotatedTextSize(textBB, rotate);\n\n var scale, padForRounding;\n // Scale text for rounded bars\n if(r && (r - overhead) > TEXTPAD) {\n var scaleAndPad = scaleTextForRoundedBar(x0, x1, y0, y1, t, r, overhead, isHorizontal, hasB);\n scale = scaleAndPad.scale;\n padForRounding = scaleAndPad.pad;\n // Scale text for non-rounded bars\n } else {\n scale = 1;\n if(constrained) {\n scale = Math.min(\n 1,\n lx / t.x,\n ly / t.y\n );\n }\n padForRounding = 0;\n }\n\n // compute text and target positions\n var textX = (\n textBB.left * toLeft +\n textBB.right * toRight\n );\n var textY = (textBB.top + textBB.bottom) / 2;\n var targetX = (\n (x0 + TEXTPAD) * toLeft +\n (x1 - TEXTPAD) * toRight\n );\n var targetY = (y0 + y1) / 2;\n var anchorX = 0;\n var anchorY = 0;\n if(isStart || isEnd) {\n var extrapad = (isHorizontal ? t.x : t.y) / 2;\n\n if(r && (isEnd || hasB)) {\n textpad += padForRounding;\n }\n\n var dir = isHorizontal ? dirSign(x0, x1) : dirSign(y0, y1);\n\n if(isHorizontal) {\n if(isStart) {\n targetX = x0 + dir * textpad;\n anchorX = -dir * extrapad;\n } else {\n targetX = x1 - dir * textpad;\n anchorX = dir * extrapad;\n }\n } else {\n if(isStart) {\n targetY = y0 + dir * textpad;\n anchorY = -dir * extrapad;\n } else {\n targetY = y1 - dir * textpad;\n anchorY = dir * extrapad;\n }\n }\n }\n\n return {\n textX: textX,\n textY: textY,\n targetX: targetX,\n targetY: targetY,\n anchorX: anchorX,\n anchorY: anchorY,\n scale: scale,\n rotate: rotate\n };\n}\n\nfunction scaleTextForRoundedBar(x0, x1, y0, y1, t, r, overhead, isHorizontal, hasB) {\n var barWidth = Math.max(0, Math.abs(x1 - x0) - 2 * TEXTPAD);\n var barHeight = Math.max(0, Math.abs(y1 - y0) - 2 * TEXTPAD);\n var R = r - TEXTPAD;\n var clippedR = overhead ? R - Math.sqrt(R * R - (R - overhead) * (R - overhead)) : R;\n var rX = hasB ? R * 2 : (isHorizontal ? R - overhead : 2 * clippedR);\n var rY = hasB ? R * 2 : (isHorizontal ? 2 * clippedR : R - overhead);\n var a, b, c;\n var scale, pad;\n\n\n if(t.y / t.x >= barHeight / (barWidth - rX)) {\n // Case 1 (Tall text)\n scale = barHeight / t.y;\n } else if(t.y / t.x <= (barHeight - rY) / barWidth) {\n // Case 2 (Wide text)\n scale = barWidth / t.x;\n } else if(!hasB && isHorizontal) {\n // Case 3a (Quadratic case, two side corners are rounded)\n a = t.x * t.x + t.y * t.y / 4;\n b = -2 * t.x * (barWidth - R) - t.y * (barHeight / 2 - R);\n c = (barWidth - R) * (barWidth - R) + (barHeight / 2 - R) * (barHeight / 2 - R) - R * R;\n\n scale = (-b + Math.sqrt(b * b - 4 * a * c)) / (2 * a);\n } else if(!hasB) {\n // Case 3b (Quadratic case, two top/bottom corners are rounded)\n a = t.x * t.x / 4 + t.y * t.y;\n b = -t.x * (barWidth / 2 - R) - 2 * t.y * (barHeight - R);\n c = (barWidth / 2 - R) * (barWidth / 2 - R) + (barHeight - R) * (barHeight - R) - R * R;\n\n scale = (-b + Math.sqrt(b * b - 4 * a * c)) / (2 * a);\n } else {\n // Case 4 (Quadratic case, all four corners are rounded)\n a = (t.x * t.x + t.y * t.y) / 4;\n b = -t.x * (barWidth / 2 - R) - t.y * (barHeight / 2 - R);\n c = (barWidth / 2 - R) * (barWidth / 2 - R) + (barHeight / 2 - R) * (barHeight / 2 - R) - R * R;\n scale = (-b + Math.sqrt(b * b - 4 * a * c)) / (2 * a);\n }\n\n // Scale should not be larger than 1\n scale = Math.min(1, scale);\n\n if(isHorizontal) {\n pad = Math.max(0, R - Math.sqrt(Math.max(0, R * R - (R - (barHeight - t.y * scale) / 2) * (R - (barHeight - t.y * scale) / 2))) - overhead);\n } else {\n pad = Math.max(0, R - Math.sqrt(Math.max(0, R * R - (R - (barWidth - t.x * scale) / 2) * (R - (barWidth - t.x * scale) / 2))) - overhead);\n }\n\n return { scale: scale, pad: pad };\n}\n\nfunction toMoveOutsideBar(x0, x1, y0, y1, textBB, opts) {\n var isHorizontal = !!opts.isHorizontal;\n var constrained = !!opts.constrained;\n var angle = opts.angle || 0;\n\n var textWidth = textBB.width;\n var textHeight = textBB.height;\n var lx = Math.abs(x1 - x0);\n var ly = Math.abs(y1 - y0);\n\n var textpad;\n // Keep the padding so the text doesn't sit right against\n // the bars, but don't factor it into barWidth\n if(isHorizontal) {\n textpad = (ly > 2 * TEXTPAD) ? TEXTPAD : 0;\n } else {\n textpad = (lx > 2 * TEXTPAD) ? TEXTPAD : 0;\n }\n\n // compute rotate and scale\n var scale = 1;\n if(constrained) {\n scale = (isHorizontal) ?\n Math.min(1, ly / textHeight) :\n Math.min(1, lx / textWidth);\n }\n\n var rotate = getRotateFromAngle(angle);\n var t = getRotatedTextSize(textBB, rotate);\n\n // compute text and target positions\n var extrapad = (isHorizontal ? t.x : t.y) / 2;\n var textX = (textBB.left + textBB.right) / 2;\n var textY = (textBB.top + textBB.bottom) / 2;\n var targetX = (x0 + x1) / 2;\n var targetY = (y0 + y1) / 2;\n var anchorX = 0;\n var anchorY = 0;\n\n var dir = isHorizontal ? dirSign(x1, x0) : dirSign(y0, y1);\n if(isHorizontal) {\n targetX = x1 - dir * textpad;\n anchorX = dir * extrapad;\n } else {\n targetY = y1 + dir * textpad;\n anchorY = -dir * extrapad;\n }\n\n return {\n textX: textX,\n textY: textY,\n targetX: targetX,\n targetY: targetY,\n anchorX: anchorX,\n anchorY: anchorY,\n scale: scale,\n rotate: rotate\n };\n}\n\nfunction getText(fullLayout, cd, index, xa, ya) {\n var trace = cd[0].trace;\n var texttemplate = trace.texttemplate;\n\n var value;\n if(texttemplate) {\n value = calcTexttemplate(fullLayout, cd, index, xa, ya);\n } else if(trace.textinfo) {\n value = calcTextinfo(cd, index, xa, ya);\n } else {\n value = helpers.getValue(trace.text, index);\n }\n\n return helpers.coerceString(attributeText, value);\n}\n\nfunction getTextPosition(trace, index) {\n var value = helpers.getValue(trace.textposition, index);\n return helpers.coerceEnumerated(attributeTextPosition, value);\n}\n\nfunction calcTexttemplate(fullLayout, cd, index, xa, ya) {\n var trace = cd[0].trace;\n var texttemplate = Lib.castOption(trace, index, 'texttemplate');\n if(!texttemplate) return '';\n var isHistogram = (trace.type === 'histogram');\n var isWaterfall = (trace.type === 'waterfall');\n var isFunnel = (trace.type === 'funnel');\n var isHorizontal = trace.orientation === 'h';\n\n var pLetter, pAxis;\n var vLetter, vAxis;\n if(isHorizontal) {\n pLetter = 'y';\n pAxis = ya;\n vLetter = 'x';\n vAxis = xa;\n } else {\n pLetter = 'x';\n pAxis = xa;\n vLetter = 'y';\n vAxis = ya;\n }\n\n function formatLabel(u) {\n return tickText(pAxis, pAxis.c2l(u), true).text;\n }\n\n function formatNumber(v) {\n return tickText(vAxis, vAxis.c2l(v), true).text;\n }\n\n var cdi = cd[index];\n var obj = {};\n\n obj.label = cdi.p;\n obj.labelLabel = obj[pLetter + 'Label'] = formatLabel(cdi.p);\n\n var tx = Lib.castOption(trace, cdi.i, 'text');\n if(tx === 0 || tx) obj.text = tx;\n\n obj.value = cdi.s;\n obj.valueLabel = obj[vLetter + 'Label'] = formatNumber(cdi.s);\n\n var pt = {};\n appendArrayPointValue(pt, trace, cdi.i);\n\n if(isHistogram || pt.x === undefined) pt.x = isHorizontal ? obj.value : obj.label;\n if(isHistogram || pt.y === undefined) pt.y = isHorizontal ? obj.label : obj.value;\n if(isHistogram || pt.xLabel === undefined) pt.xLabel = isHorizontal ? obj.valueLabel : obj.labelLabel;\n if(isHistogram || pt.yLabel === undefined) pt.yLabel = isHorizontal ? obj.labelLabel : obj.valueLabel;\n\n if(isWaterfall) {\n obj.delta = +cdi.rawS || cdi.s;\n obj.deltaLabel = formatNumber(obj.delta);\n obj.final = cdi.v;\n obj.finalLabel = formatNumber(obj.final);\n obj.initial = obj.final - obj.delta;\n obj.initialLabel = formatNumber(obj.initial);\n }\n\n if(isFunnel) {\n obj.value = cdi.s;\n obj.valueLabel = formatNumber(obj.value);\n\n obj.percentInitial = cdi.begR;\n obj.percentInitialLabel = Lib.formatPercent(cdi.begR);\n obj.percentPrevious = cdi.difR;\n obj.percentPreviousLabel = Lib.formatPercent(cdi.difR);\n obj.percentTotal = cdi.sumR;\n obj.percenTotalLabel = Lib.formatPercent(cdi.sumR);\n }\n\n var customdata = Lib.castOption(trace, cdi.i, 'customdata');\n if(customdata) obj.customdata = customdata;\n return Lib.texttemplateString(texttemplate, obj, fullLayout._d3locale, pt, obj, trace._meta || {});\n}\n\nfunction calcTextinfo(cd, index, xa, ya) {\n var trace = cd[0].trace;\n var isHorizontal = (trace.orientation === 'h');\n var isWaterfall = (trace.type === 'waterfall');\n var isFunnel = (trace.type === 'funnel');\n\n function formatLabel(u) {\n var pAxis = isHorizontal ? ya : xa;\n return tickText(pAxis, u, true).text;\n }\n\n function formatNumber(v) {\n var sAxis = isHorizontal ? xa : ya;\n return tickText(sAxis, +v, true).text;\n }\n\n var textinfo = trace.textinfo;\n var cdi = cd[index];\n\n var parts = textinfo.split('+');\n var text = [];\n var tx;\n\n var hasFlag = function(flag) { return parts.indexOf(flag) !== -1; };\n\n if(hasFlag('label')) {\n text.push(formatLabel(cd[index].p));\n }\n\n if(hasFlag('text')) {\n tx = Lib.castOption(trace, cdi.i, 'text');\n if(tx === 0 || tx) text.push(tx);\n }\n\n if(isWaterfall) {\n var delta = +cdi.rawS || cdi.s;\n var final = cdi.v;\n var initial = final - delta;\n\n if(hasFlag('initial')) text.push(formatNumber(initial));\n if(hasFlag('delta')) text.push(formatNumber(delta));\n if(hasFlag('final')) text.push(formatNumber(final));\n }\n\n if(isFunnel) {\n if(hasFlag('value')) text.push(formatNumber(cdi.s));\n\n var nPercent = 0;\n if(hasFlag('percent initial')) nPercent++;\n if(hasFlag('percent previous')) nPercent++;\n if(hasFlag('percent total')) nPercent++;\n\n var hasMultiplePercents = nPercent > 1;\n\n if(hasFlag('percent initial')) {\n tx = Lib.formatPercent(cdi.begR);\n if(hasMultiplePercents) tx += ' of initial';\n text.push(tx);\n }\n if(hasFlag('percent previous')) {\n tx = Lib.formatPercent(cdi.difR);\n if(hasMultiplePercents) tx += ' of previous';\n text.push(tx);\n }\n if(hasFlag('percent total')) {\n tx = Lib.formatPercent(cdi.sumR);\n if(hasMultiplePercents) tx += ' of total';\n text.push(tx);\n }\n }\n\n return text.join('
');\n}\n\nmodule.exports = {\n plot: plot,\n toMoveInsideBar: toMoveInsideBar\n};\n","'use strict';\n\nmodule.exports = function selectPoints(searchInfo, selectionTester) {\n var cd = searchInfo.cd;\n var xa = searchInfo.xaxis;\n var ya = searchInfo.yaxis;\n var trace = cd[0].trace;\n var isFunnel = (trace.type === 'funnel');\n var isHorizontal = (trace.orientation === 'h');\n var selection = [];\n var i;\n\n if(selectionTester === false) {\n // clear selection\n for(i = 0; i < cd.length; i++) {\n cd[i].selected = 0;\n }\n } else {\n for(i = 0; i < cd.length; i++) {\n var di = cd[i];\n var ct = 'ct' in di ? di.ct : getCentroid(di, xa, ya, isHorizontal, isFunnel);\n\n if(selectionTester.contains(ct, false, i, searchInfo)) {\n selection.push({\n pointNumber: i,\n x: xa.c2d(di.x),\n y: ya.c2d(di.y)\n });\n di.selected = 1;\n } else {\n di.selected = 0;\n }\n }\n }\n\n return selection;\n};\n\nfunction getCentroid(d, xa, ya, isHorizontal, isFunnel) {\n var x0 = xa.c2p(isHorizontal ? d.s0 : d.p0, true);\n var x1 = xa.c2p(isHorizontal ? d.s1 : d.p1, true);\n var y0 = ya.c2p(isHorizontal ? d.p0 : d.s0, true);\n var y1 = ya.c2p(isHorizontal ? d.p1 : d.s1, true);\n\n if(isFunnel) {\n return [(x0 + x1) / 2, (y0 + y1) / 2];\n } else {\n if(isHorizontal) {\n return [x1, (y0 + y1) / 2];\n } else {\n return [(x0 + x1) / 2, y1];\n }\n }\n}\n","'use strict';\n\nmodule.exports = Sieve;\n\nvar distinctVals = require('../../lib').distinctVals;\n\n/**\n * Helper class to sieve data from traces into bins\n *\n * @class\n *\n * @param {Array} traces\n* Array of calculated traces\n * @param {object} opts\n * - @param {boolean} [sepNegVal]\n * If true, then split data at the same position into a bar\n * for positive values and another for negative values\n * - @param {boolean} [overlapNoMerge]\n * If true, then don't merge overlapping bars into a single bar\n */\nfunction Sieve(traces, opts) {\n this.traces = traces;\n this.sepNegVal = opts.sepNegVal;\n this.overlapNoMerge = opts.overlapNoMerge;\n\n // for single-bin histograms - see histogram/calc\n var width1 = Infinity;\n\n var axLetter = opts.posAxis._id.charAt(0);\n\n var positions = [];\n for(var i = 0; i < traces.length; i++) {\n var trace = traces[i];\n for(var j = 0; j < trace.length; j++) {\n var bar = trace[j];\n var pos = bar.p;\n if(pos === undefined) {\n pos = bar[axLetter];\n }\n if(pos !== undefined) positions.push(pos);\n }\n if(trace[0] && trace[0].width1) {\n width1 = Math.min(trace[0].width1, width1);\n }\n }\n this.positions = positions;\n\n var dv = distinctVals(positions);\n\n this.distinctPositions = dv.vals;\n if(dv.vals.length === 1 && width1 !== Infinity) this.minDiff = width1;\n else this.minDiff = Math.min(dv.minDiff, width1);\n\n var type = (opts.posAxis || {}).type;\n if(type === 'category' || type === 'multicategory') {\n this.minDiff = 1;\n }\n\n this.binWidth = this.minDiff;\n\n this.bins = {};\n}\n\n/**\n * Sieve datum\n *\n * @method\n * @param {number} position\n * @param {number} value\n * @returns {number} Previous bin value\n */\nSieve.prototype.put = function put(position, value) {\n var label = this.getLabel(position, value);\n var oldValue = this.bins[label] || 0;\n\n this.bins[label] = oldValue + value;\n\n return oldValue;\n};\n\n/**\n * Get current bin value for a given datum\n *\n * @method\n * @param {number} position Position of datum\n * @param {number} [value] Value of datum\n * (required if this.sepNegVal is true)\n * @returns {number} Current bin value\n */\nSieve.prototype.get = function get(position, value) {\n var label = this.getLabel(position, value);\n return this.bins[label] || 0;\n};\n\n/**\n * Get bin label for a given datum\n *\n * @method\n * @param {number} position Position of datum\n * @param {number} [value] Value of datum\n * (required if this.sepNegVal is true)\n * @returns {string} Bin label\n * (prefixed with a 'v' if value is negative and this.sepNegVal is\n * true; otherwise prefixed with '^')\n */\nSieve.prototype.getLabel = function getLabel(position, value) {\n var prefix = (value < 0 && this.sepNegVal) ? 'v' : '^';\n var label = (this.overlapNoMerge) ?\n position :\n Math.round(position / this.binWidth);\n return prefix + label;\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\n\nvar resizeText = require('./uniform_text').resizeText;\nvar attributes = require('./attributes');\nvar attributeTextFont = attributes.textfont;\nvar attributeInsideTextFont = attributes.insidetextfont;\nvar attributeOutsideTextFont = attributes.outsidetextfont;\nvar helpers = require('./helpers');\n\nfunction style(gd) {\n var s = d3.select(gd).selectAll('g[class^=\"barlayer\"]').selectAll('g.trace');\n resizeText(gd, s, 'bar');\n\n var barcount = s.size();\n var fullLayout = gd._fullLayout;\n\n // trace styling\n s.style('opacity', function(d) { return d[0].trace.opacity; })\n\n // for gapless (either stacked or neighboring grouped) bars use\n // crispEdges to turn off antialiasing so an artificial gap\n // isn't introduced.\n .each(function(d) {\n if((fullLayout.barmode === 'stack' && barcount > 1) ||\n (fullLayout.bargap === 0 &&\n fullLayout.bargroupgap === 0 &&\n !d[0].trace.marker.line.width)) {\n d3.select(this).attr('shape-rendering', 'crispEdges');\n }\n });\n\n s.selectAll('g.points').each(function(d) {\n var sel = d3.select(this);\n var trace = d[0].trace;\n stylePoints(sel, trace, gd);\n });\n\n Registry.getComponentMethod('errorbars', 'style')(s);\n}\n\nfunction stylePoints(sel, trace, gd) {\n Drawing.pointStyle(sel.selectAll('path'), trace, gd);\n styleTextPoints(sel, trace, gd);\n}\n\nfunction styleTextPoints(sel, trace, gd) {\n sel.selectAll('text').each(function(d) {\n var tx = d3.select(this);\n var font = Lib.ensureUniformFontSize(gd, determineFont(tx, d, trace, gd));\n\n Drawing.font(tx, font);\n });\n}\n\nfunction styleOnSelect(gd, cd, sel) {\n var trace = cd[0].trace;\n\n if(trace.selectedpoints) {\n stylePointsInSelectionMode(sel, trace, gd);\n } else {\n stylePoints(sel, trace, gd);\n Registry.getComponentMethod('errorbars', 'style')(sel);\n }\n}\n\nfunction stylePointsInSelectionMode(s, trace, gd) {\n Drawing.selectedPointStyle(s.selectAll('path'), trace);\n styleTextInSelectionMode(s.selectAll('text'), trace, gd);\n}\n\nfunction styleTextInSelectionMode(txs, trace, gd) {\n txs.each(function(d) {\n var tx = d3.select(this);\n var font;\n\n if(d.selected) {\n font = Lib.ensureUniformFontSize(gd, determineFont(tx, d, trace, gd));\n\n var selectedFontColor = trace.selected.textfont && trace.selected.textfont.color;\n if(selectedFontColor) {\n font.color = selectedFontColor;\n }\n\n Drawing.font(tx, font);\n } else {\n Drawing.selectedTextStyle(tx, trace);\n }\n });\n}\n\nfunction determineFont(tx, d, trace, gd) {\n var layoutFont = gd._fullLayout.font;\n var textFont = trace.textfont;\n\n if(tx.classed('bartext-inside')) {\n var barColor = getBarColor(d, trace);\n textFont = getInsideTextFont(trace, d.i, layoutFont, barColor);\n } else if(tx.classed('bartext-outside')) {\n textFont = getOutsideTextFont(trace, d.i, layoutFont);\n }\n\n return textFont;\n}\n\nfunction getTextFont(trace, index, defaultValue) {\n return getFontValue(\n attributeTextFont, trace.textfont, index, defaultValue);\n}\n\nfunction getInsideTextFont(trace, index, layoutFont, barColor) {\n var defaultFont = getTextFont(trace, index, layoutFont);\n\n var wouldFallBackToLayoutFont =\n (trace._input.textfont === undefined || trace._input.textfont.color === undefined) ||\n (Array.isArray(trace.textfont.color) && trace.textfont.color[index] === undefined);\n if(wouldFallBackToLayoutFont) {\n defaultFont = {\n color: Color.contrast(barColor),\n family: defaultFont.family,\n size: defaultFont.size,\n weight: defaultFont.weight,\n style: defaultFont.style,\n variant: defaultFont.variant,\n textcase: defaultFont.textcase,\n lineposition: defaultFont.lineposition,\n shadow: defaultFont.shadow,\n };\n }\n\n return getFontValue(\n attributeInsideTextFont, trace.insidetextfont, index, defaultFont);\n}\n\nfunction getOutsideTextFont(trace, index, layoutFont) {\n var defaultFont = getTextFont(trace, index, layoutFont);\n return getFontValue(\n attributeOutsideTextFont, trace.outsidetextfont, index, defaultFont);\n}\n\nfunction getFontValue(attributeDefinition, attributeValue, index, defaultValue) {\n attributeValue = attributeValue || {};\n\n var familyValue = helpers.getValue(attributeValue.family, index);\n var sizeValue = helpers.getValue(attributeValue.size, index);\n var colorValue = helpers.getValue(attributeValue.color, index);\n var weightValue = helpers.getValue(attributeValue.weight, index);\n var styleValue = helpers.getValue(attributeValue.style, index);\n var variantValue = helpers.getValue(attributeValue.variant, index);\n var textcaseValue = helpers.getValue(attributeValue.textcase, index);\n var linepositionValue = helpers.getValue(attributeValue.lineposition, index);\n var shadowValue = helpers.getValue(attributeValue.shadow, index);\n\n return {\n family: helpers.coerceString(\n attributeDefinition.family, familyValue, defaultValue.family),\n size: helpers.coerceNumber(\n attributeDefinition.size, sizeValue, defaultValue.size),\n color: helpers.coerceColor(\n attributeDefinition.color, colorValue, defaultValue.color),\n weight: helpers.coerceString(\n attributeDefinition.weight, weightValue, defaultValue.weight),\n style: helpers.coerceString(\n attributeDefinition.style, styleValue, defaultValue.style),\n variant: helpers.coerceString(\n attributeDefinition.variant, variantValue, defaultValue.variant),\n textcase: helpers.coerceString(\n attributeDefinition.variant, textcaseValue, defaultValue.textcase),\n lineposition: helpers.coerceString(\n attributeDefinition.variant, linepositionValue, defaultValue.lineposition),\n shadow: helpers.coerceString(\n attributeDefinition.variant, shadowValue, defaultValue.shadow),\n };\n}\n\nfunction getBarColor(cd, trace) {\n if(trace.type === 'waterfall') {\n return trace[cd.dir].marker.color;\n }\n return cd.mcc || cd.mc || trace.marker.color;\n}\n\nmodule.exports = {\n style: style,\n styleTextPoints: styleTextPoints,\n styleOnSelect: styleOnSelect,\n getInsideTextFont: getInsideTextFont,\n getOutsideTextFont: getOutsideTextFont,\n getBarColor: getBarColor,\n resizeText: resizeText\n};\n","'use strict';\n\nvar Color = require('../../components/color');\nvar hasColorscale = require('../../components/colorscale/helpers').hasColorscale;\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar coercePattern = require('../../lib').coercePattern;\n\nmodule.exports = function handleStyleDefaults(traceIn, traceOut, coerce, defaultColor, layout) {\n var markerColor = coerce('marker.color', defaultColor);\n var hasMarkerColorscale = hasColorscale(traceIn, 'marker');\n if(hasMarkerColorscale) {\n colorscaleDefaults(\n traceIn, traceOut, layout, coerce, {prefix: 'marker.', cLetter: 'c'}\n );\n }\n\n coerce('marker.line.color', Color.defaultLine);\n\n if(hasColorscale(traceIn, 'marker.line')) {\n colorscaleDefaults(\n traceIn, traceOut, layout, coerce, {prefix: 'marker.line.', cLetter: 'c'}\n );\n }\n\n coerce('marker.line.width');\n coerce('marker.opacity');\n coercePattern(coerce, 'marker.pattern', markerColor, hasMarkerColorscale);\n coerce('selected.marker.color');\n coerce('unselected.marker.color');\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\n\nfunction resizeText(gd, gTrace, traceType) {\n var fullLayout = gd._fullLayout;\n var minSize = fullLayout['_' + traceType + 'Text_minsize'];\n if(minSize) {\n var shouldHide = fullLayout.uniformtext.mode === 'hide';\n\n var selector;\n switch(traceType) {\n case 'funnelarea' :\n case 'pie' :\n case 'sunburst' :\n selector = 'g.slice';\n break;\n case 'treemap' :\n case 'icicle' :\n selector = 'g.slice, g.pathbar';\n break;\n default :\n selector = 'g.points > g.point';\n }\n\n gTrace.selectAll(selector).each(function(d) {\n var transform = d.transform;\n if(transform) {\n transform.scale = (shouldHide && transform.hide) ? 0 : minSize / transform.fontSize;\n\n var el = d3.select(this).select('text');\n Lib.setTransormAndDisplay(el, transform);\n }\n });\n }\n}\n\nfunction recordMinTextSize(\n traceType, // in\n transform, // inout\n fullLayout // inout\n) {\n if(fullLayout.uniformtext.mode) {\n var minKey = getMinKey(traceType);\n var minSize = fullLayout.uniformtext.minsize;\n var size = transform.scale * transform.fontSize;\n\n transform.hide = size < minSize;\n\n fullLayout[minKey] = fullLayout[minKey] || Infinity;\n if(!transform.hide) {\n fullLayout[minKey] = Math.min(\n fullLayout[minKey],\n Math.max(size, minSize)\n );\n }\n }\n}\n\nfunction clearMinTextSize(\n traceType, // in\n fullLayout // inout\n) {\n var minKey = getMinKey(traceType);\n fullLayout[minKey] = undefined;\n}\n\nfunction getMinKey(traceType) {\n return '_' + traceType + 'Text_minsize';\n}\n\nmodule.exports = {\n recordMinTextSize: recordMinTextSize,\n clearMinTextSize: clearMinTextSize,\n resizeText: resizeText\n};\n","'use strict';\n\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar scatterPolarAttrs = require('../scatterpolar/attributes');\nvar barAttrs = require('../bar/attributes');\n\n\nmodule.exports = {\n r: scatterPolarAttrs.r,\n theta: scatterPolarAttrs.theta,\n r0: scatterPolarAttrs.r0,\n dr: scatterPolarAttrs.dr,\n theta0: scatterPolarAttrs.theta0,\n dtheta: scatterPolarAttrs.dtheta,\n thetaunit: scatterPolarAttrs.thetaunit,\n\n // orientation: {\n // valType: 'enumerated',\n // values: ['radial', 'angular'],\n // editType: 'calc+clearAxisTypes',\n // description: 'Sets the orientation of the bars.'\n // },\n\n base: extendFlat({}, barAttrs.base, {\n description: [\n 'Sets where the bar base is drawn (in radial axis units).',\n 'In *stack* barmode,',\n 'traces that set *base* will be excluded',\n 'and drawn in *overlay* mode instead.'\n ].join(' ')\n }),\n offset: extendFlat({}, barAttrs.offset, {\n description: [\n 'Shifts the angular position where the bar is drawn',\n '(in *thetatunit* units).'\n ].join(' ')\n }),\n width: extendFlat({}, barAttrs.width, {\n description: [\n 'Sets the bar angular width (in *thetaunit* units).'\n ].join(' ')\n }),\n\n text: extendFlat({}, barAttrs.text, {\n description: [\n 'Sets hover text elements associated with each bar.',\n 'If a single string, the same string appears over all bars.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s coordinates.'\n ].join(' ')\n }),\n hovertext: extendFlat({}, barAttrs.hovertext, {\n description: 'Same as `text`.'\n }),\n\n // textposition: {},\n // textfont: {},\n // insidetextfont: {},\n // outsidetextfont: {},\n // constraintext: {},\n // cliponaxis: extendFlat({}, barAttrs.cliponaxis, {dflt: false}),\n\n marker: barPolarMarker(),\n\n hoverinfo: scatterPolarAttrs.hoverinfo,\n hovertemplate: hovertemplateAttrs(),\n\n selected: barAttrs.selected,\n unselected: barAttrs.unselected\n\n // error_x (error_r, error_theta)\n // error_y\n};\n\nfunction barPolarMarker() {\n var marker = extendFlat({}, barAttrs.marker);\n delete marker.cornerradius;\n return marker;\n}\n","'use strict';\n\nvar hasColorscale = require('../../components/colorscale/helpers').hasColorscale;\nvar colorscaleCalc = require('../../components/colorscale/calc');\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar arraysToCalcdata = require('../bar/arrays_to_calcdata');\nvar setGroupPositions = require('../bar/cross_trace_calc').setGroupPositions;\nvar calcSelection = require('../scatter/calc_selection');\nvar traceIs = require('../../registry').traceIs;\nvar extendFlat = require('../../lib').extendFlat;\n\nfunction calc(gd, trace) {\n var fullLayout = gd._fullLayout;\n var subplotId = trace.subplot;\n var radialAxis = fullLayout[subplotId].radialaxis;\n var angularAxis = fullLayout[subplotId].angularaxis;\n var rArray = radialAxis.makeCalcdata(trace, 'r');\n var thetaArray = angularAxis.makeCalcdata(trace, 'theta');\n var len = trace._length;\n var cd = new Array(len);\n\n // 'size' axis variables\n var sArray = rArray;\n // 'pos' axis variables\n var pArray = thetaArray;\n\n for(var i = 0; i < len; i++) {\n cd[i] = {p: pArray[i], s: sArray[i]};\n }\n\n // convert width and offset in 'c' coordinate,\n // set 'c' value(s) in trace._width and trace._offset,\n // to make Bar.crossTraceCalc \"just work\"\n function d2c(attr) {\n var val = trace[attr];\n if(val !== undefined) {\n trace['_' + attr] = isArrayOrTypedArray(val) ?\n angularAxis.makeCalcdata(trace, attr) :\n angularAxis.d2c(val, trace.thetaunit);\n }\n }\n\n if(angularAxis.type === 'linear') {\n d2c('width');\n d2c('offset');\n }\n\n if(hasColorscale(trace, 'marker')) {\n colorscaleCalc(gd, trace, {\n vals: trace.marker.color,\n containerStr: 'marker',\n cLetter: 'c'\n });\n }\n if(hasColorscale(trace, 'marker.line')) {\n colorscaleCalc(gd, trace, {\n vals: trace.marker.line.color,\n containerStr: 'marker.line',\n cLetter: 'c'\n });\n }\n\n arraysToCalcdata(cd, trace);\n calcSelection(cd, trace);\n\n return cd;\n}\n\nfunction crossTraceCalc(gd, polarLayout, subplotId) {\n var calcdata = gd.calcdata;\n var barPolarCd = [];\n\n for(var i = 0; i < calcdata.length; i++) {\n var cdi = calcdata[i];\n var trace = cdi[0].trace;\n\n if(trace.visible === true && traceIs(trace, 'bar') &&\n trace.subplot === subplotId\n ) {\n barPolarCd.push(cdi);\n }\n }\n\n // to make _extremes is filled in correctly so that\n // polar._subplot.radialAxis can get auotrange'd\n // TODO clean up!\n // I think we want to call getAutorange on polar.radialaxis\n // NOT on polar._subplot.radialAxis\n var rAxis = extendFlat({}, polarLayout.radialaxis, {_id: 'x'});\n var aAxis = polarLayout.angularaxis;\n\n setGroupPositions(gd, aAxis, rAxis, barPolarCd, {\n mode: polarLayout.barmode,\n norm: polarLayout.barnorm,\n gap: polarLayout.bargap,\n groupgap: polarLayout.bargroupgap\n });\n}\n\nmodule.exports = {\n calc: calc,\n crossTraceCalc: crossTraceCalc\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar handleRThetaDefaults = require('../scatterpolar/defaults').handleRThetaDefaults;\nvar handleStyleDefaults = require('../bar/style_defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleRThetaDefaults(traceIn, traceOut, layout, coerce);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n // coerce('orientation', (traceOut.theta && !traceOut.r) ? 'angular' : 'radial');\n\n coerce('thetaunit');\n coerce('base');\n coerce('offset');\n coerce('width');\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n\n // var textPosition = coerce('textposition');\n // var hasBoth = Array.isArray(textPosition) || textPosition === 'auto';\n // var hasInside = hasBoth || textPosition === 'inside';\n // var hasOutside = hasBoth || textPosition === 'outside';\n\n // if(hasInside || hasOutside) {\n // var textFont = coerceFont(coerce, 'textfont', layout.font);\n // if(hasInside) coerceFont(coerce, 'insidetextfont', textFont);\n // if(hasOutside) coerceFont(coerce, 'outsidetextfont', textFont);\n // coerce('constraintext');\n // coerce('selected.textfont.color');\n // coerce('unselected.textfont.color');\n // coerce('cliponaxis');\n // }\n\n handleStyleDefaults(traceIn, traceOut, coerce, defaultColor, layout);\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n","'use strict';\n\nvar Fx = require('../../components/fx');\nvar Lib = require('../../lib');\nvar getTraceColor = require('../bar/hover').getTraceColor;\nvar fillText = Lib.fillText;\nvar makeHoverPointText = require('../scatterpolar/hover').makeHoverPointText;\nvar isPtInsidePolygon = require('../../plots/polar/helpers').isPtInsidePolygon;\n\nmodule.exports = function hoverPoints(pointData, xval, yval) {\n var cd = pointData.cd;\n var trace = cd[0].trace;\n\n var subplot = pointData.subplot;\n var radialAxis = subplot.radialAxis;\n var angularAxis = subplot.angularAxis;\n var vangles = subplot.vangles;\n var inboxFn = vangles ? isPtInsidePolygon : Lib.isPtInsideSector;\n var maxHoverDistance = pointData.maxHoverDistance;\n var period = angularAxis._period || 2 * Math.PI;\n\n var rVal = Math.abs(radialAxis.g2p(Math.sqrt(xval * xval + yval * yval)));\n var thetaVal = Math.atan2(yval, xval);\n\n // polar.(x|y)axis.p2c doesn't get the reversed radial axis range case right\n if(radialAxis.range[0] > radialAxis.range[1]) {\n thetaVal += Math.PI;\n }\n\n var distFn = function(di) {\n if(inboxFn(rVal, thetaVal, [di.rp0, di.rp1], [di.thetag0, di.thetag1], vangles)) {\n return maxHoverDistance +\n // add a little to the pseudo-distance for wider bars, so that like scatter,\n // if you are over two overlapping bars, the narrower one wins.\n Math.min(1, Math.abs(di.thetag1 - di.thetag0) / period) - 1 +\n // add a gradient so hovering near the end of a\n // bar makes it a little closer match\n (di.rp1 - rVal) / (di.rp1 - di.rp0) - 1;\n } else {\n return Infinity;\n }\n };\n\n Fx.getClosest(cd, distFn, pointData);\n if(pointData.index === false) return;\n\n var index = pointData.index;\n var cdi = cd[index];\n\n pointData.x0 = pointData.x1 = cdi.ct[0];\n pointData.y0 = pointData.y1 = cdi.ct[1];\n\n var _cdi = Lib.extendFlat({}, cdi, {r: cdi.s, theta: cdi.p});\n fillText(cdi, trace, pointData);\n makeHoverPointText(_cdi, trace, subplot, pointData);\n pointData.hovertemplate = trace.hovertemplate;\n pointData.color = getTraceColor(trace, cdi);\n pointData.xLabelVal = pointData.yLabelVal = undefined;\n\n if(cdi.s < 0) {\n pointData.idealAlign = 'left';\n }\n\n return [pointData];\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'barpolar',\n basePlotModule: require('../../plots/polar'),\n categories: ['polar', 'bar', 'showLegend'],\n\n attributes: require('./attributes'),\n layoutAttributes: require('./layout_attributes'),\n supplyDefaults: require('./defaults'),\n supplyLayoutDefaults: require('./layout_defaults'),\n\n calc: require('./calc').calc,\n crossTraceCalc: require('./calc').crossTraceCalc,\n\n plot: require('./plot'),\n colorbar: require('../scatter/marker_colorbar'),\n formatLabels: require('../scatterpolar/format_labels'),\n\n style: require('../bar/style').style,\n styleOnSelect: require('../bar/style').styleOnSelect,\n\n hoverPoints: require('./hover'),\n selectPoints: require('../bar/select'),\n\n meta: {\n hrName: 'bar_polar',\n description: [\n 'The data visualized by the radial span of the bars is set in `r`'\n // 'if `orientation` is set to *radial* (the default)',\n // 'and the labels are set in `theta`.',\n // 'By setting `orientation` to *angular*, the roles are interchanged.'\n ].join(' ')\n }\n};\n","'use strict';\n\nmodule.exports = {\n barmode: {\n valType: 'enumerated',\n values: ['stack', 'overlay'],\n dflt: 'stack',\n editType: 'calc',\n description: [\n 'Determines how bars at the same location coordinate',\n 'are displayed on the graph.',\n 'With *stack*, the bars are stacked on top of one another',\n 'With *overlay*, the bars are plotted over one another,',\n 'you might need to reduce *opacity* to see multiple bars.'\n ].join(' ')\n },\n bargap: {\n valType: 'number',\n dflt: 0.1,\n min: 0,\n max: 1,\n editType: 'calc',\n description: [\n 'Sets the gap between bars of',\n 'adjacent location coordinates.',\n 'Values are unitless, they represent fractions of the minimum difference',\n 'in bar positions in the data.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar attrs = require('./layout_attributes');\n\nmodule.exports = function(layoutIn, layoutOut, fullData) {\n var subplotsDone = {};\n var sp;\n\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn[sp] || {}, layoutOut[sp], attrs, attr, dflt);\n }\n\n for(var i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n if(trace.type === 'barpolar' && trace.visible === true) {\n sp = trace.subplot;\n if(!subplotsDone[sp]) {\n coerce('barmode');\n coerce('bargap');\n subplotsDone[sp] = 1;\n }\n }\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar Drawing = require('../../components/drawing');\nvar helpers = require('../../plots/polar/helpers');\n\nmodule.exports = function plot(gd, subplot, cdbar) {\n var isStatic = gd._context.staticPlot;\n var xa = subplot.xaxis;\n var ya = subplot.yaxis;\n var radialAxis = subplot.radialAxis;\n var angularAxis = subplot.angularAxis;\n var pathFn = makePathFn(subplot);\n var barLayer = subplot.layers.frontplot.select('g.barlayer');\n\n Lib.makeTraceGroups(barLayer, cdbar, 'trace bars').each(function() {\n var plotGroup = d3.select(this);\n var pointGroup = Lib.ensureSingle(plotGroup, 'g', 'points');\n var bars = pointGroup.selectAll('g.point').data(Lib.identity);\n\n bars.enter().append('g')\n .style('vector-effect', isStatic ? 'none' : 'non-scaling-stroke')\n .style('stroke-miterlimit', 2)\n .classed('point', true);\n\n bars.exit().remove();\n\n bars.each(function(di) {\n var bar = d3.select(this);\n\n var rp0 = di.rp0 = radialAxis.c2p(di.s0);\n var rp1 = di.rp1 = radialAxis.c2p(di.s1);\n var thetag0 = di.thetag0 = angularAxis.c2g(di.p0);\n var thetag1 = di.thetag1 = angularAxis.c2g(di.p1);\n\n var dPath;\n\n if(!isNumeric(rp0) || !isNumeric(rp1) ||\n !isNumeric(thetag0) || !isNumeric(thetag1) ||\n rp0 === rp1 || thetag0 === thetag1\n ) {\n // do not remove blank bars, to keep data-to-node\n // mapping intact during radial drag, that we\n // can skip calling _module.style during interactions\n dPath = 'M0,0Z';\n } else {\n // this 'center' pt is used for selections and hover labels\n var rg1 = radialAxis.c2g(di.s1);\n var thetagMid = (thetag0 + thetag1) / 2;\n di.ct = [\n xa.c2p(rg1 * Math.cos(thetagMid)),\n ya.c2p(rg1 * Math.sin(thetagMid))\n ];\n\n dPath = pathFn(rp0, rp1, thetag0, thetag1);\n }\n\n Lib.ensureSingle(bar, 'path').attr('d', dPath);\n });\n\n // clip plotGroup, when trace layer isn't clipped\n Drawing.setClipUrl(\n plotGroup,\n subplot._hasClipOnAxisFalse ? subplot.clipIds.forTraces : null,\n gd\n );\n });\n};\n\nfunction makePathFn(subplot) {\n var cxx = subplot.cxx;\n var cyy = subplot.cyy;\n\n if(subplot.vangles) {\n return function(r0, r1, _a0, _a1) {\n var a0, a1;\n\n if(Lib.angleDelta(_a0, _a1) > 0) {\n a0 = _a0;\n a1 = _a1;\n } else {\n a0 = _a1;\n a1 = _a0;\n }\n\n var va0 = helpers.findEnclosingVertexAngles(a0, subplot.vangles)[0];\n var va1 = helpers.findEnclosingVertexAngles(a1, subplot.vangles)[1];\n var vaBar = [va0, (a0 + a1) / 2, va1];\n return helpers.pathPolygonAnnulus(r0, r1, a0, a1, vaBar, cxx, cyy);\n };\n }\n\n return function(r0, r1, a0, a1) {\n return Lib.pathAnnulus(r0, r1, a0, a1, cxx, cyy);\n };\n}\n","'use strict';\n\nvar makeFillcolorAttr = require('../scatter/fillcolor_attribute');\nvar scatterAttrs = require('../scatter/attributes');\nvar barAttrs = require('../bar/attributes');\nvar colorAttrs = require('../../components/color/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar scatterMarkerAttrs = scatterAttrs.marker;\nvar scatterMarkerLineAttrs = scatterMarkerAttrs.line;\n\nmodule.exports = {\n y: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the y sample data or coordinates.',\n 'See overview for more info.'\n ].join(' ')\n },\n x: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the x sample data or coordinates.',\n 'See overview for more info.'\n ].join(' ')\n },\n x0: {\n valType: 'any',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the x coordinate for single-box traces',\n 'or the starting coordinate for multi-box traces',\n 'set using q1/median/q3.',\n 'See overview for more info.'\n ].join(' ')\n },\n y0: {\n valType: 'any',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the y coordinate for single-box traces',\n 'or the starting coordinate for multi-box traces',\n 'set using q1/median/q3.',\n 'See overview for more info.'\n ].join(' ')\n },\n\n dx: {\n valType: 'number',\n editType: 'calc',\n description: [\n 'Sets the x coordinate step for multi-box traces',\n 'set using q1/median/q3.'\n ].join(' ')\n },\n dy: {\n valType: 'number',\n editType: 'calc',\n description: [\n 'Sets the y coordinate step for multi-box traces',\n 'set using q1/median/q3.'\n ].join(' ')\n },\n\n xperiod: scatterAttrs.xperiod,\n yperiod: scatterAttrs.yperiod,\n xperiod0: scatterAttrs.xperiod0,\n yperiod0: scatterAttrs.yperiod0,\n xperiodalignment: scatterAttrs.xperiodalignment,\n yperiodalignment: scatterAttrs.yperiodalignment,\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n\n name: {\n valType: 'string',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the trace name.',\n 'The trace name appears as the legend item and on hover.',\n 'For box traces, the name will also be used for the position',\n 'coordinate, if `x` and `x0` (`y` and `y0` if horizontal) are',\n 'missing and the position axis is categorical'\n ].join(' ')\n },\n\n q1: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the Quartile 1 values.',\n 'There should be as many items as the number of boxes desired.',\n ].join(' ')\n },\n median: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the median values.',\n 'There should be as many items as the number of boxes desired.',\n ].join(' ')\n },\n q3: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the Quartile 3 values.',\n 'There should be as many items as the number of boxes desired.',\n ].join(' ')\n },\n lowerfence: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the lower fence values.',\n 'There should be as many items as the number of boxes desired.',\n 'This attribute has effect only under the q1/median/q3 signature.',\n 'If `lowerfence` is not provided but a sample (in `y` or `x`) is set,',\n 'we compute the lower as the last sample point below 1.5 times the IQR.'\n ].join(' ')\n },\n upperfence: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the upper fence values.',\n 'There should be as many items as the number of boxes desired.',\n 'This attribute has effect only under the q1/median/q3 signature.',\n 'If `upperfence` is not provided but a sample (in `y` or `x`) is set,',\n 'we compute the upper as the last sample point above 1.5 times the IQR.'\n ].join(' ')\n },\n\n notched: {\n valType: 'boolean',\n editType: 'calc',\n description: [\n 'Determines whether or not notches are drawn.',\n 'Notches displays a confidence interval around the median.',\n 'We compute the confidence interval as median +/- 1.57 * IQR / sqrt(N),',\n 'where IQR is the interquartile range and N is the sample size.',\n 'If two boxes\\' notches do not overlap there is 95% confidence their medians differ.',\n 'See https://sites.google.com/site/davidsstatistics/home/notched-box-plots for more info.',\n 'Defaults to *false* unless `notchwidth` or `notchspan` is set.'\n ].join(' ')\n },\n notchwidth: {\n valType: 'number',\n min: 0,\n max: 0.5,\n dflt: 0.25,\n editType: 'calc',\n description: [\n 'Sets the width of the notches relative to',\n 'the box\\' width.',\n 'For example, with 0, the notches are as wide as the box(es).'\n ].join(' ')\n },\n notchspan: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the notch span from the boxes\\' `median` values.',\n 'There should be as many items as the number of boxes desired.',\n 'This attribute has effect only under the q1/median/q3 signature.',\n 'If `notchspan` is not provided but a sample (in `y` or `x`) is set,',\n 'we compute it as 1.57 * IQR / sqrt(N),',\n 'where N is the sample size.'\n ].join(' ')\n },\n\n // TODO\n // maybe add\n // - loweroutlierbound / upperoutlierbound\n // - lowersuspectedoutlierbound / uppersuspectedoutlierbound\n\n boxpoints: {\n valType: 'enumerated',\n values: ['all', 'outliers', 'suspectedoutliers', false],\n editType: 'calc',\n description: [\n 'If *outliers*, only the sample points lying outside the whiskers',\n 'are shown',\n 'If *suspectedoutliers*, the outlier points are shown and',\n 'points either less than 4*Q1-3*Q3 or greater than 4*Q3-3*Q1',\n 'are highlighted (see `outliercolor`)',\n 'If *all*, all sample points are shown',\n 'If *false*, only the box(es) are shown with no sample points',\n 'Defaults to *suspectedoutliers* when `marker.outliercolor` or',\n '`marker.line.outliercolor` is set.',\n 'Defaults to *all* under the q1/median/q3 signature.',\n 'Otherwise defaults to *outliers*.',\n ].join(' ')\n },\n jitter: {\n valType: 'number',\n min: 0,\n max: 1,\n editType: 'calc',\n description: [\n 'Sets the amount of jitter in the sample points drawn.',\n 'If *0*, the sample points align along the distribution axis.',\n 'If *1*, the sample points are drawn in a random jitter of width',\n 'equal to the width of the box(es).'\n ].join(' ')\n },\n pointpos: {\n valType: 'number',\n min: -2,\n max: 2,\n editType: 'calc',\n description: [\n 'Sets the position of the sample points in relation to the box(es).',\n 'If *0*, the sample points are places over the center of the box(es).',\n 'Positive (negative) values correspond to positions to the',\n 'right (left) for vertical boxes and above (below) for horizontal boxes'\n ].join(' ')\n },\n sdmultiple: {\n valType: 'number',\n min: 0,\n editType: 'calc',\n dflt: 1,\n description: [\n 'Scales the box size when sizemode=sd',\n 'Allowing boxes to be drawn across any stddev range',\n 'For example 1-stddev, 3-stddev, 5-stddev',\n ].join(' ')\n },\n sizemode: {\n valType: 'enumerated',\n values: ['quartiles', 'sd'],\n editType: 'calc',\n dflt: 'quartiles',\n description: [\n 'Sets the upper and lower bound for the boxes',\n 'quartiles means box is drawn between Q1 and Q3',\n 'SD means the box is drawn between Mean +- Standard Deviation',\n 'Argument sdmultiple (default 1) to scale the box size',\n 'So it could be drawn 1-stddev, 3-stddev etc',\n ].join(' ')\n },\n boxmean: {\n valType: 'enumerated',\n values: [true, 'sd', false],\n editType: 'calc',\n description: [\n 'If *true*, the mean of the box(es)\\' underlying distribution is',\n 'drawn as a dashed line inside the box(es).',\n 'If *sd* the standard deviation is also drawn.',\n 'Defaults to *true* when `mean` is set.',\n 'Defaults to *sd* when `sd` is set',\n 'Otherwise defaults to *false*.'\n ].join(' ')\n },\n mean: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the mean values.',\n 'There should be as many items as the number of boxes desired.',\n 'This attribute has effect only under the q1/median/q3 signature.',\n 'If `mean` is not provided but a sample (in `y` or `x`) is set,',\n 'we compute the mean for each box using the sample values.'\n ].join(' ')\n },\n sd: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the standard deviation values.',\n 'There should be as many items as the number of boxes desired.',\n 'This attribute has effect only under the q1/median/q3 signature.',\n 'If `sd` is not provided but a sample (in `y` or `x`) is set,',\n 'we compute the standard deviation for each box using the sample values.'\n ].join(' ')\n },\n\n orientation: {\n valType: 'enumerated',\n values: ['v', 'h'],\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the orientation of the box(es).',\n 'If *v* (*h*), the distribution is visualized along',\n 'the vertical (horizontal).'\n ].join(' ')\n },\n\n quartilemethod: {\n valType: 'enumerated',\n values: ['linear', 'exclusive', 'inclusive'],\n dflt: 'linear',\n editType: 'calc',\n description: [\n 'Sets the method used to compute the sample\\'s Q1 and Q3 quartiles.',\n\n 'The *linear* method uses the 25th percentile for Q1 and 75th percentile for Q3',\n 'as computed using method #10 (listed on http://jse.amstat.org/v14n3/langford.html).',\n\n 'The *exclusive* method uses the median to divide the ordered dataset into two halves',\n 'if the sample is odd, it does not include the median in either half -',\n 'Q1 is then the median of the lower half and',\n 'Q3 the median of the upper half.',\n\n 'The *inclusive* method also uses the median to divide the ordered dataset into two halves',\n 'but if the sample is odd, it includes the median in both halves -',\n 'Q1 is then the median of the lower half and',\n 'Q3 the median of the upper half.'\n ].join(' ')\n },\n\n width: {\n valType: 'number',\n min: 0,\n dflt: 0,\n editType: 'calc',\n description: [\n 'Sets the width of the box in data coordinate',\n 'If *0* (default value) the width is automatically selected based on the positions',\n 'of other box traces in the same subplot.'\n ].join(' ')\n },\n\n marker: {\n outliercolor: {\n valType: 'color',\n dflt: 'rgba(0, 0, 0, 0)',\n editType: 'style',\n description: 'Sets the color of the outlier sample points.'\n },\n symbol: extendFlat({}, scatterMarkerAttrs.symbol,\n {arrayOk: false, editType: 'plot'}),\n opacity: extendFlat({}, scatterMarkerAttrs.opacity,\n {arrayOk: false, dflt: 1, editType: 'style'}),\n angle: extendFlat({}, scatterMarkerAttrs.angle,\n {arrayOk: false, editType: 'calc'}),\n size: extendFlat({}, scatterMarkerAttrs.size,\n {arrayOk: false, editType: 'calc'}),\n color: extendFlat({}, scatterMarkerAttrs.color,\n {arrayOk: false, editType: 'style'}),\n line: {\n color: extendFlat({}, scatterMarkerLineAttrs.color,\n {arrayOk: false, dflt: colorAttrs.defaultLine, editType: 'style'}\n ),\n width: extendFlat({}, scatterMarkerLineAttrs.width,\n {arrayOk: false, dflt: 0, editType: 'style'}\n ),\n outliercolor: {\n valType: 'color',\n editType: 'style',\n description: [\n 'Sets the border line color of the outlier sample points.',\n 'Defaults to marker.color'\n ].join(' ')\n },\n outlierwidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n editType: 'style',\n description: [\n 'Sets the border line width (in px) of the outlier sample points.'\n ].join(' ')\n },\n editType: 'style'\n },\n editType: 'plot'\n },\n\n line: {\n color: {\n valType: 'color',\n editType: 'style',\n description: 'Sets the color of line bounding the box(es).'\n },\n width: {\n valType: 'number',\n min: 0,\n dflt: 2,\n editType: 'style',\n description: 'Sets the width (in px) of line bounding the box(es).'\n },\n editType: 'plot'\n },\n\n fillcolor: makeFillcolorAttr(),\n\n whiskerwidth: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0.5,\n editType: 'calc',\n description: [\n 'Sets the width of the whiskers relative to',\n 'the box\\' width.',\n 'For example, with 1, the whiskers are as wide as the box(es).'\n ].join(' ')\n },\n\n showwhiskers: {\n valType: 'boolean',\n editType: 'calc',\n description: [\n 'Determines whether or not whiskers are visible.',\n 'Defaults to true for `sizemode` *quartiles*, false for *sd*.'\n ].join(' ')\n },\n\n offsetgroup: barAttrs.offsetgroup,\n alignmentgroup: barAttrs.alignmentgroup,\n\n selected: {\n marker: scatterAttrs.selected.marker,\n editType: 'style'\n },\n unselected: {\n marker: scatterAttrs.unselected.marker,\n editType: 'style'\n },\n\n text: extendFlat({}, scatterAttrs.text, {\n description: [\n 'Sets the text elements associated with each sample value.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s (x,y) coordinates.',\n 'To be seen, trace `hoverinfo` must contain a *text* flag.'\n ].join(' ')\n }),\n hovertext: extendFlat({}, scatterAttrs.hovertext, {\n description: 'Same as `text`.'\n }),\n hovertemplate: hovertemplateAttrs({\n description: [\n 'N.B. This only has an effect when hovering on points.'\n ].join(' ')\n }),\n\n hoveron: {\n valType: 'flaglist',\n flags: ['boxes', 'points'],\n dflt: 'boxes+points',\n editType: 'style',\n description: [\n 'Do the hover effects highlight individual boxes ',\n 'or sample points or both?'\n ].join(' ')\n },\n zorder: scatterAttrs.zorder\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Axes = require('../../plots/cartesian/axes');\nvar alignPeriod = require('../../plots/cartesian/align_period');\nvar Lib = require('../../lib');\n\nvar BADNUM = require('../../constants/numerical').BADNUM;\nvar _ = Lib._;\n\nmodule.exports = function calc(gd, trace) {\n var fullLayout = gd._fullLayout;\n var xa = Axes.getFromId(gd, trace.xaxis || 'x');\n var ya = Axes.getFromId(gd, trace.yaxis || 'y');\n var cd = [];\n\n // N.B. violin reuses same Box.calc\n var numKey = trace.type === 'violin' ? '_numViolins' : '_numBoxes';\n\n var i, j;\n var valAxis, valLetter;\n var posAxis, posLetter;\n\n var hasPeriod;\n if(trace.orientation === 'h') {\n valAxis = xa;\n valLetter = 'x';\n posAxis = ya;\n posLetter = 'y';\n hasPeriod = !!trace.yperiodalignment;\n } else {\n valAxis = ya;\n valLetter = 'y';\n posAxis = xa;\n posLetter = 'x';\n hasPeriod = !!trace.xperiodalignment;\n }\n\n var allPosArrays = getPosArrays(trace, posLetter, posAxis, fullLayout[numKey]);\n var posArray = allPosArrays[0];\n var origPos = allPosArrays[1];\n var dv = Lib.distinctVals(posArray, posAxis);\n var posDistinct = dv.vals;\n var dPos = dv.minDiff / 2;\n\n // item in trace calcdata\n var cdi;\n // array of {v: v, i, i} sample pts\n var pts;\n // values of the `pts` array of objects\n var boxVals;\n // length of sample\n var N;\n // single sample point\n var pt;\n // single sample value\n var v;\n\n // filter function for outlier pts\n // outlier definition based on http://www.physics.csbsju.edu/stats/box2.html\n var ptFilterFn = (trace.boxpoints || trace.points) === 'all' ?\n Lib.identity :\n function(pt) { return (pt.v < cdi.lf || pt.v > cdi.uf); };\n\n if(trace._hasPreCompStats) {\n var valArrayRaw = trace[valLetter];\n var d2c = function(k) { return valAxis.d2c((trace[k] || [])[i]); };\n var minVal = Infinity;\n var maxVal = -Infinity;\n\n for(i = 0; i < trace._length; i++) {\n var posi = posArray[i];\n if(!isNumeric(posi)) continue;\n\n cdi = {};\n cdi.pos = cdi[posLetter] = posi;\n if(hasPeriod && origPos) {\n cdi.orig_p = origPos[i]; // used by hover\n }\n\n cdi.q1 = d2c('q1');\n cdi.med = d2c('median');\n cdi.q3 = d2c('q3');\n\n pts = [];\n if(valArrayRaw && Lib.isArrayOrTypedArray(valArrayRaw[i])) {\n for(j = 0; j < valArrayRaw[i].length; j++) {\n v = valAxis.d2c(valArrayRaw[i][j]);\n if(v !== BADNUM) {\n pt = {v: v, i: [i, j]};\n arraysToCalcdata(pt, trace, [i, j]);\n pts.push(pt);\n }\n }\n }\n cdi.pts = pts.sort(sortByVal);\n boxVals = cdi[valLetter] = pts.map(extractVal);\n N = boxVals.length;\n\n if(cdi.med !== BADNUM && cdi.q1 !== BADNUM && cdi.q3 !== BADNUM &&\n cdi.med >= cdi.q1 && cdi.q3 >= cdi.med\n ) {\n var lf = d2c('lowerfence');\n cdi.lf = (lf !== BADNUM && lf <= cdi.q1) ?\n lf :\n computeLowerFence(cdi, boxVals, N);\n\n var uf = d2c('upperfence');\n cdi.uf = (uf !== BADNUM && uf >= cdi.q3) ?\n uf :\n computeUpperFence(cdi, boxVals, N);\n\n var mean = d2c('mean');\n cdi.mean = (mean !== BADNUM) ?\n mean :\n (N ? Lib.mean(boxVals, N) : (cdi.q1 + cdi.q3) / 2);\n\n var sd = d2c('sd');\n cdi.sd = (mean !== BADNUM && sd >= 0) ?\n sd :\n (N ? Lib.stdev(boxVals, N, cdi.mean) : (cdi.q3 - cdi.q1));\n\n cdi.lo = computeLowerOutlierBound(cdi);\n cdi.uo = computeUpperOutlierBound(cdi);\n\n var ns = d2c('notchspan');\n ns = (ns !== BADNUM && ns > 0) ? ns : computeNotchSpan(cdi, N);\n cdi.ln = cdi.med - ns;\n cdi.un = cdi.med + ns;\n\n var imin = cdi.lf;\n var imax = cdi.uf;\n if(trace.boxpoints && boxVals.length) {\n imin = Math.min(imin, boxVals[0]);\n imax = Math.max(imax, boxVals[N - 1]);\n }\n if(trace.notched) {\n imin = Math.min(imin, cdi.ln);\n imax = Math.max(imax, cdi.un);\n }\n cdi.min = imin;\n cdi.max = imax;\n } else {\n Lib.warn([\n 'Invalid input - make sure that q1 <= median <= q3',\n 'q1 = ' + cdi.q1,\n 'median = ' + cdi.med,\n 'q3 = ' + cdi.q3\n ].join('\\n'));\n\n var v0;\n if(cdi.med !== BADNUM) {\n v0 = cdi.med;\n } else if(cdi.q1 !== BADNUM) {\n if(cdi.q3 !== BADNUM) v0 = (cdi.q1 + cdi.q3) / 2;\n else v0 = cdi.q1;\n } else if(cdi.q3 !== BADNUM) {\n v0 = cdi.q3;\n } else {\n v0 = 0;\n }\n\n // draw box as line segment\n cdi.med = v0;\n cdi.q1 = cdi.q3 = v0;\n cdi.lf = cdi.uf = v0;\n cdi.mean = cdi.sd = v0;\n cdi.ln = cdi.un = v0;\n cdi.min = cdi.max = v0;\n }\n\n minVal = Math.min(minVal, cdi.min);\n maxVal = Math.max(maxVal, cdi.max);\n\n cdi.pts2 = pts.filter(ptFilterFn);\n\n cd.push(cdi);\n }\n\n trace._extremes[valAxis._id] = Axes.findExtremes(valAxis,\n [minVal, maxVal],\n {padded: true}\n );\n } else {\n var valArray = valAxis.makeCalcdata(trace, valLetter);\n var posBins = makeBins(posDistinct, dPos);\n var pLen = posDistinct.length;\n var ptsPerBin = initNestedArray(pLen);\n\n // bin pts info per position bins\n for(i = 0; i < trace._length; i++) {\n v = valArray[i];\n if(!isNumeric(v)) continue;\n\n var n = Lib.findBin(posArray[i], posBins);\n if(n >= 0 && n < pLen) {\n pt = {v: v, i: i};\n arraysToCalcdata(pt, trace, i);\n ptsPerBin[n].push(pt);\n }\n }\n\n var minLowerNotch = Infinity;\n var maxUpperNotch = -Infinity;\n\n var quartilemethod = trace.quartilemethod;\n var usesExclusive = quartilemethod === 'exclusive';\n var usesInclusive = quartilemethod === 'inclusive';\n\n // build calcdata trace items, one item per distinct position\n for(i = 0; i < pLen; i++) {\n if(ptsPerBin[i].length > 0) {\n cdi = {};\n cdi.pos = cdi[posLetter] = posDistinct[i];\n\n pts = cdi.pts = ptsPerBin[i].sort(sortByVal);\n boxVals = cdi[valLetter] = pts.map(extractVal);\n N = boxVals.length;\n\n cdi.min = boxVals[0];\n cdi.max = boxVals[N - 1];\n cdi.mean = Lib.mean(boxVals, N);\n cdi.sd = Lib.stdev(boxVals, N, cdi.mean) * trace.sdmultiple;\n cdi.med = Lib.interp(boxVals, 0.5);\n\n if((N % 2) && (usesExclusive || usesInclusive)) {\n var lower;\n var upper;\n\n if(usesExclusive) {\n // do NOT include the median in either half\n lower = boxVals.slice(0, N / 2);\n upper = boxVals.slice(N / 2 + 1);\n } else if(usesInclusive) {\n // include the median in either half\n lower = boxVals.slice(0, N / 2 + 1);\n upper = boxVals.slice(N / 2);\n }\n\n cdi.q1 = Lib.interp(lower, 0.5);\n cdi.q3 = Lib.interp(upper, 0.5);\n } else {\n cdi.q1 = Lib.interp(boxVals, 0.25);\n cdi.q3 = Lib.interp(boxVals, 0.75);\n }\n\n // lower and upper fences\n cdi.lf = computeLowerFence(cdi, boxVals, N);\n cdi.uf = computeUpperFence(cdi, boxVals, N);\n\n // lower and upper outliers bounds\n cdi.lo = computeLowerOutlierBound(cdi);\n cdi.uo = computeUpperOutlierBound(cdi);\n\n // lower and upper notches\n var mci = computeNotchSpan(cdi, N);\n cdi.ln = cdi.med - mci;\n cdi.un = cdi.med + mci;\n minLowerNotch = Math.min(minLowerNotch, cdi.ln);\n maxUpperNotch = Math.max(maxUpperNotch, cdi.un);\n\n cdi.pts2 = pts.filter(ptFilterFn);\n\n cd.push(cdi);\n }\n }\n\n if(trace.notched && Lib.isTypedArray(valArray)) valArray = Array.from(valArray);\n trace._extremes[valAxis._id] = Axes.findExtremes(valAxis,\n trace.notched ? valArray.concat([minLowerNotch, maxUpperNotch]) : valArray,\n {padded: true}\n );\n }\n\n calcSelection(cd, trace);\n\n if(cd.length > 0) {\n cd[0].t = {\n num: fullLayout[numKey],\n dPos: dPos,\n posLetter: posLetter,\n valLetter: valLetter,\n labels: {\n med: _(gd, 'median:'),\n min: _(gd, 'min:'),\n q1: _(gd, 'q1:'),\n q3: _(gd, 'q3:'),\n max: _(gd, 'max:'),\n mean: (trace.boxmean === 'sd') || (trace.sizemode === 'sd') ?\n _(gd, 'mean ± σ:').replace('σ', trace.sdmultiple === 1 ? 'σ' : (trace.sdmultiple + 'σ')) : // displaying mean +- Nσ whilst supporting translations\n _(gd, 'mean:'),\n lf: _(gd, 'lower fence:'),\n uf: _(gd, 'upper fence:')\n }\n };\n\n fullLayout[numKey]++;\n return cd;\n } else {\n return [{t: {empty: true}}];\n }\n};\n\n// In vertical (horizontal) box plots:\n// if no x (y) data, use x0 (y0), or name\n// so if you want one box\n// per trace, set x0 (y0) to the x (y) value or category for this trace\n// (or set x (y) to a constant array matching y (x))\nfunction getPosArrays(trace, posLetter, posAxis, num) {\n var hasPosArray = posLetter in trace;\n var hasPos0 = posLetter + '0' in trace;\n var hasPosStep = 'd' + posLetter in trace;\n\n if(hasPosArray || (hasPos0 && hasPosStep)) {\n var origPos = posAxis.makeCalcdata(trace, posLetter);\n var pos = alignPeriod(trace, posAxis, posLetter, origPos).vals;\n return [pos, origPos];\n }\n\n var pos0;\n if(hasPos0) {\n pos0 = trace[posLetter + '0'];\n } else if('name' in trace && (\n posAxis.type === 'category' || (\n isNumeric(trace.name) &&\n ['linear', 'log'].indexOf(posAxis.type) !== -1\n ) || (\n Lib.isDateTime(trace.name) &&\n posAxis.type === 'date'\n )\n )) {\n pos0 = trace.name;\n } else {\n pos0 = num;\n }\n\n var pos0c = posAxis.type === 'multicategory' ?\n posAxis.r2c_just_indices(pos0) :\n posAxis.d2c(pos0, 0, trace[posLetter + 'calendar']);\n\n var len = trace._length;\n var out = new Array(len);\n for(var i = 0; i < len; i++) out[i] = pos0c;\n\n return [out];\n}\n\nfunction makeBins(x, dx) {\n var len = x.length;\n var bins = new Array(len + 1);\n\n for(var i = 0; i < len; i++) {\n bins[i] = x[i] - dx;\n }\n bins[len] = x[len - 1] + dx;\n\n return bins;\n}\n\nfunction initNestedArray(len) {\n var arr = new Array(len);\n for(var i = 0; i < len; i++) {\n arr[i] = [];\n }\n return arr;\n}\n\nvar TRACE_TO_CALC = {\n text: 'tx',\n hovertext: 'htx'\n};\n\nfunction arraysToCalcdata(pt, trace, ptNumber) {\n for(var k in TRACE_TO_CALC) {\n if(Lib.isArrayOrTypedArray(trace[k])) {\n if(Array.isArray(ptNumber)) {\n if(Lib.isArrayOrTypedArray(trace[k][ptNumber[0]])) {\n pt[TRACE_TO_CALC[k]] = trace[k][ptNumber[0]][ptNumber[1]];\n }\n } else {\n pt[TRACE_TO_CALC[k]] = trace[k][ptNumber];\n }\n }\n }\n}\n\nfunction calcSelection(cd, trace) {\n if(Lib.isArrayOrTypedArray(trace.selectedpoints)) {\n for(var i = 0; i < cd.length; i++) {\n var pts = cd[i].pts || [];\n var ptNumber2cdIndex = {};\n\n for(var j = 0; j < pts.length; j++) {\n ptNumber2cdIndex[pts[j].i] = j;\n }\n\n Lib.tagSelected(pts, trace, ptNumber2cdIndex);\n }\n }\n}\n\nfunction sortByVal(a, b) { return a.v - b.v; }\n\nfunction extractVal(o) { return o.v; }\n\n// last point below 1.5 * IQR\nfunction computeLowerFence(cdi, boxVals, N) {\n if(N === 0) return cdi.q1;\n return Math.min(\n cdi.q1,\n boxVals[Math.min(\n Lib.findBin(2.5 * cdi.q1 - 1.5 * cdi.q3, boxVals, true) + 1,\n N - 1\n )]\n );\n}\n\n// last point above 1.5 * IQR\nfunction computeUpperFence(cdi, boxVals, N) {\n if(N === 0) return cdi.q3;\n return Math.max(\n cdi.q3,\n boxVals[Math.max(\n Lib.findBin(2.5 * cdi.q3 - 1.5 * cdi.q1, boxVals),\n 0\n )]\n );\n}\n\n// 3 IQR below (don't clip to max/min,\n// this is only for discriminating suspected & far outliers)\nfunction computeLowerOutlierBound(cdi) {\n return 4 * cdi.q1 - 3 * cdi.q3;\n}\n\n// 3 IQR above (don't clip to max/min,\n// this is only for discriminating suspected & far outliers)\nfunction computeUpperOutlierBound(cdi) {\n return 4 * cdi.q3 - 3 * cdi.q1;\n}\n\n// 95% confidence intervals for median\nfunction computeNotchSpan(cdi, N) {\n if(N === 0) return 0;\n return 1.57 * (cdi.q3 - cdi.q1) / Math.sqrt(N);\n}\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\nvar Lib = require('../../lib');\nvar getAxisGroup = require('../../plots/cartesian/constraints').getAxisGroup;\n\nvar orientations = ['v', 'h'];\n\nfunction crossTraceCalc(gd, plotinfo) {\n var calcdata = gd.calcdata;\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n for(var i = 0; i < orientations.length; i++) {\n var orientation = orientations[i];\n var posAxis = orientation === 'h' ? ya : xa;\n var boxList = [];\n\n // make list of boxes / candlesticks\n // For backward compatibility, candlesticks are treated as if they *are* box traces here\n for(var j = 0; j < calcdata.length; j++) {\n var cd = calcdata[j];\n var t = cd[0].t;\n var trace = cd[0].trace;\n\n if(trace.visible === true &&\n (trace.type === 'box' || trace.type === 'candlestick') &&\n !t.empty &&\n (trace.orientation || 'v') === orientation &&\n trace.xaxis === xa._id &&\n trace.yaxis === ya._id\n ) {\n boxList.push(j);\n }\n }\n\n setPositionOffset('box', gd, boxList, posAxis);\n }\n}\n\nfunction setPositionOffset(traceType, gd, boxList, posAxis) {\n var calcdata = gd.calcdata;\n var fullLayout = gd._fullLayout;\n var axId = posAxis._id;\n var axLetter = axId.charAt(0);\n\n var i, j, calcTrace;\n var pointList = [];\n var shownPts = 0;\n\n // make list of box points\n for(i = 0; i < boxList.length; i++) {\n calcTrace = calcdata[boxList[i]];\n for(j = 0; j < calcTrace.length; j++) {\n pointList.push(posAxis.c2l(calcTrace[j].pos, true));\n shownPts += (calcTrace[j].pts2 || []).length;\n }\n }\n\n if(!pointList.length) return;\n\n // box plots - update dPos based on multiple traces\n var boxdv = Lib.distinctVals(pointList);\n if(posAxis.type === 'category' || posAxis.type === 'multicategory') {\n boxdv.minDiff = 1;\n }\n\n var dPos0 = boxdv.minDiff / 2;\n\n // check for forced minimum dtick\n Axes.minDtick(posAxis, boxdv.minDiff, boxdv.vals[0], true);\n\n var numKey = traceType === 'violin' ? '_numViolins' : '_numBoxes';\n var numTotal = fullLayout[numKey];\n var group = fullLayout[traceType + 'mode'] === 'group' && numTotal > 1;\n var groupFraction = 1 - fullLayout[traceType + 'gap'];\n var groupGapFraction = 1 - fullLayout[traceType + 'groupgap'];\n\n for(i = 0; i < boxList.length; i++) {\n calcTrace = calcdata[boxList[i]];\n\n var trace = calcTrace[0].trace;\n var t = calcTrace[0].t;\n var width = trace.width;\n var side = trace.side;\n\n // position coordinate delta\n var dPos;\n // box half width;\n var bdPos;\n // box center offset\n var bPos;\n // half-width within which to accept hover for this box/violin\n // always split the distance to the closest box/violin\n var wHover;\n\n if(width) {\n dPos = bdPos = wHover = width / 2;\n bPos = 0;\n } else {\n dPos = dPos0;\n\n if(group) {\n var groupId = getAxisGroup(fullLayout, posAxis._id) + trace.orientation;\n var alignmentGroups = fullLayout._alignmentOpts[groupId] || {};\n var alignmentGroupOpts = alignmentGroups[trace.alignmentgroup] || {};\n var nOffsetGroups = Object.keys(alignmentGroupOpts.offsetGroups || {}).length;\n var num = nOffsetGroups || numTotal;\n var shift = nOffsetGroups ? trace._offsetIndex : t.num;\n\n bdPos = dPos * groupFraction * groupGapFraction / num;\n bPos = 2 * dPos * (-0.5 + (shift + 0.5) / num) * groupFraction;\n wHover = dPos * groupFraction / num;\n } else {\n bdPos = dPos * groupFraction * groupGapFraction;\n bPos = 0;\n wHover = dPos;\n }\n }\n t.dPos = dPos;\n t.bPos = bPos;\n t.bdPos = bdPos;\n t.wHover = wHover;\n\n // box/violin-only value-space push value\n var pushplus;\n var pushminus;\n // edge of box/violin\n var edge = bPos + bdPos;\n var edgeplus;\n var edgeminus;\n // value-space padding\n var vpadplus;\n var vpadminus;\n // pixel-space padding\n var ppadplus;\n var ppadminus;\n // do we add 5% of both sides (more logic for points beyond box/violin below)\n var padded = Boolean(width);\n // does this trace show points?\n var hasPts = (trace.boxpoints || trace.points) && (shownPts > 0);\n\n if(side === 'positive') {\n pushplus = dPos * (width ? 1 : 0.5);\n edgeplus = edge;\n pushminus = edgeplus = bPos;\n } else if(side === 'negative') {\n pushplus = edgeplus = bPos;\n pushminus = dPos * (width ? 1 : 0.5);\n edgeminus = edge;\n } else {\n pushplus = pushminus = dPos;\n edgeplus = edgeminus = edge;\n }\n\n if(hasPts) {\n var pointpos = trace.pointpos;\n var jitter = trace.jitter;\n var ms = trace.marker.size / 2;\n\n var pp = 0;\n if((pointpos + jitter) >= 0) {\n pp = edge * (pointpos + jitter);\n if(pp > pushplus) {\n // (++) beyond plus-value, use pp\n padded = true;\n ppadplus = ms;\n vpadplus = pp;\n } else if(pp > edgeplus) {\n // (+), use push-value (it's bigger), but add px-pad\n ppadplus = ms;\n vpadplus = pushplus;\n }\n }\n if(pp <= pushplus) {\n // (->) fallback to push value\n vpadplus = pushplus;\n }\n\n var pm = 0;\n if((pointpos - jitter) <= 0) {\n pm = -edge * (pointpos - jitter);\n if(pm > pushminus) {\n // (--) beyond plus-value, use pp\n padded = true;\n ppadminus = ms;\n vpadminus = pm;\n } else if(pm > edgeminus) {\n // (-), use push-value (it's bigger), but add px-pad\n ppadminus = ms;\n vpadminus = pushminus;\n }\n }\n if(pm <= pushminus) {\n // (<-) fallback to push value\n vpadminus = pushminus;\n }\n } else {\n vpadplus = pushplus;\n vpadminus = pushminus;\n }\n\n var pos = new Array(calcTrace.length);\n for(j = 0; j < calcTrace.length; j++) {\n pos[j] = calcTrace[j].pos;\n }\n\n trace._extremes[axId] = Axes.findExtremes(posAxis, pos, {\n padded: padded,\n vpadminus: vpadminus,\n vpadplus: vpadplus,\n vpadLinearized: true,\n // N.B. SVG px-space positive/negative\n ppadminus: {x: ppadminus, y: ppadplus}[axLetter],\n ppadplus: {x: ppadplus, y: ppadminus}[axLetter],\n });\n }\n}\n\nmodule.exports = {\n crossTraceCalc: crossTraceCalc,\n setPositionOffset: setPositionOffset\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\nvar Color = require('../../components/color');\nvar handlePeriodDefaults = require('../scatter/period_defaults');\nvar handleGroupingDefaults = require('../scatter/grouping_defaults');\nvar autoType = require('../../plots/cartesian/axis_autotype');\nvar attributes = require('./attributes');\n\nfunction supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n handleSampleDefaults(traceIn, traceOut, coerce, layout);\n if(traceOut.visible === false) return;\n\n handlePeriodDefaults(traceIn, traceOut, layout, coerce);\n coerce('xhoverformat');\n coerce('yhoverformat');\n\n var hasPreCompStats = traceOut._hasPreCompStats;\n\n if(hasPreCompStats) {\n coerce('lowerfence');\n coerce('upperfence');\n }\n\n coerce('line.color', (traceIn.marker || {}).color || defaultColor);\n coerce('line.width');\n coerce('fillcolor', Color.addOpacity(traceOut.line.color, 0.5));\n\n var boxmeanDflt = false;\n if(hasPreCompStats) {\n var mean = coerce('mean');\n var sd = coerce('sd');\n if(mean && mean.length) {\n boxmeanDflt = true;\n if(sd && sd.length) boxmeanDflt = 'sd';\n }\n }\n\n coerce('whiskerwidth');\n var sizemode = coerce('sizemode');\n var boxmean;\n if(sizemode === 'quartiles') {\n boxmean = coerce('boxmean', boxmeanDflt);\n }\n coerce('showwhiskers', sizemode === 'quartiles');\n if((sizemode === 'sd') || (boxmean === 'sd')) {\n coerce('sdmultiple');\n }\n coerce('width');\n coerce('quartilemethod');\n\n var notchedDflt = false;\n if(hasPreCompStats) {\n var notchspan = coerce('notchspan');\n if(notchspan && notchspan.length) {\n notchedDflt = true;\n }\n } else if(Lib.validate(traceIn.notchwidth, attributes.notchwidth)) {\n notchedDflt = true;\n }\n var notched = coerce('notched', notchedDflt);\n if(notched) coerce('notchwidth');\n\n handlePointsDefaults(traceIn, traceOut, coerce, {prefix: 'box'});\n coerce('zorder');\n}\n\nfunction handleSampleDefaults(traceIn, traceOut, coerce, layout) {\n function getDims(arr) {\n var dims = 0;\n if(arr && arr.length) {\n dims += 1;\n if(Lib.isArrayOrTypedArray(arr[0]) && arr[0].length) {\n dims += 1;\n }\n }\n return dims;\n }\n\n function valid(astr) {\n return Lib.validate(traceIn[astr], attributes[astr]);\n }\n\n var y = coerce('y');\n var x = coerce('x');\n\n var sLen;\n if(traceOut.type === 'box') {\n var q1 = coerce('q1');\n var median = coerce('median');\n var q3 = coerce('q3');\n\n traceOut._hasPreCompStats = (\n q1 && q1.length &&\n median && median.length &&\n q3 && q3.length\n );\n sLen = Math.min(\n Lib.minRowLength(q1),\n Lib.minRowLength(median),\n Lib.minRowLength(q3)\n );\n }\n\n var yDims = getDims(y);\n var xDims = getDims(x);\n var yLen = yDims && Lib.minRowLength(y);\n var xLen = xDims && Lib.minRowLength(x);\n\n var calendar = layout.calendar;\n var opts = {\n autotypenumbers: layout.autotypenumbers\n };\n\n var defaultOrientation, len;\n if(traceOut._hasPreCompStats) {\n switch(String(xDims) + String(yDims)) {\n // no x / no y\n case '00':\n var setInX = valid('x0') || valid('dx');\n var setInY = valid('y0') || valid('dy');\n\n if(setInY && !setInX) {\n defaultOrientation = 'h';\n } else {\n defaultOrientation = 'v';\n }\n\n len = sLen;\n break;\n // just x\n case '10':\n defaultOrientation = 'v';\n len = Math.min(sLen, xLen);\n break;\n case '20':\n defaultOrientation = 'h';\n len = Math.min(sLen, x.length);\n break;\n // just y\n case '01':\n defaultOrientation = 'h';\n len = Math.min(sLen, yLen);\n break;\n case '02':\n defaultOrientation = 'v';\n len = Math.min(sLen, y.length);\n break;\n // both\n case '12':\n defaultOrientation = 'v';\n len = Math.min(sLen, xLen, y.length);\n break;\n case '21':\n defaultOrientation = 'h';\n len = Math.min(sLen, x.length, yLen);\n break;\n case '11':\n // this one is ill-defined\n len = 0;\n break;\n case '22':\n var hasCategories = false;\n var i;\n for(i = 0; i < x.length; i++) {\n if(autoType(x[i], calendar, opts) === 'category') {\n hasCategories = true;\n break;\n }\n }\n\n if(hasCategories) {\n defaultOrientation = 'v';\n len = Math.min(sLen, xLen, y.length);\n } else {\n for(i = 0; i < y.length; i++) {\n if(autoType(y[i], calendar, opts) === 'category') {\n hasCategories = true;\n break;\n }\n }\n\n if(hasCategories) {\n defaultOrientation = 'h';\n len = Math.min(sLen, x.length, yLen);\n } else {\n defaultOrientation = 'v';\n len = Math.min(sLen, xLen, y.length);\n }\n }\n break;\n }\n } else if(yDims > 0) {\n defaultOrientation = 'v';\n if(xDims > 0) {\n len = Math.min(xLen, yLen);\n } else {\n len = Math.min(yLen);\n }\n } else if(xDims > 0) {\n defaultOrientation = 'h';\n len = Math.min(xLen);\n } else {\n len = 0;\n }\n\n if(!len) {\n traceOut.visible = false;\n return;\n }\n traceOut._length = len;\n\n var orientation = coerce('orientation', defaultOrientation);\n\n // these are just used for positioning, they never define the sample\n if(traceOut._hasPreCompStats) {\n if(orientation === 'v' && xDims === 0) {\n coerce('x0', 0);\n coerce('dx', 1);\n } else if(orientation === 'h' && yDims === 0) {\n coerce('y0', 0);\n coerce('dy', 1);\n }\n } else {\n if(orientation === 'v' && xDims === 0) {\n coerce('x0');\n } else if(orientation === 'h' && yDims === 0) {\n coerce('y0');\n }\n }\n\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleTraceDefaults');\n handleCalendarDefaults(traceIn, traceOut, ['x', 'y'], layout);\n}\n\nfunction handlePointsDefaults(traceIn, traceOut, coerce, opts) {\n var prefix = opts.prefix;\n\n var outlierColorDflt = Lib.coerce2(traceIn, traceOut, attributes, 'marker.outliercolor');\n var lineoutliercolor = coerce('marker.line.outliercolor');\n\n var modeDflt = 'outliers';\n if(traceOut._hasPreCompStats) {\n modeDflt = 'all';\n } else if(outlierColorDflt || lineoutliercolor) {\n modeDflt = 'suspectedoutliers';\n }\n\n var mode = coerce(prefix + 'points', modeDflt);\n\n if(mode) {\n coerce('jitter', mode === 'all' ? 0.3 : 0);\n coerce('pointpos', mode === 'all' ? -1.5 : 0);\n\n coerce('marker.symbol');\n coerce('marker.opacity');\n coerce('marker.size');\n coerce('marker.angle');\n\n coerce('marker.color', traceOut.line.color);\n coerce('marker.line.color');\n coerce('marker.line.width');\n\n if(mode === 'suspectedoutliers') {\n coerce('marker.line.outliercolor', traceOut.marker.color);\n coerce('marker.line.outlierwidth');\n }\n\n coerce('selected.marker.color');\n coerce('unselected.marker.color');\n coerce('selected.marker.size');\n coerce('unselected.marker.size');\n\n coerce('text');\n coerce('hovertext');\n } else {\n delete traceOut.marker;\n }\n\n var hoveron = coerce('hoveron');\n if(hoveron === 'all' || hoveron.indexOf('points') !== -1) {\n coerce('hovertemplate');\n }\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n}\n\nfunction crossTraceDefaults(fullData, fullLayout) {\n var traceIn, traceOut;\n\n function coerce(attr) {\n return Lib.coerce(traceOut._input, traceOut, attributes, attr);\n }\n\n for(var i = 0; i < fullData.length; i++) {\n traceOut = fullData[i];\n var traceType = traceOut.type;\n\n if(traceType === 'box' || traceType === 'violin') {\n traceIn = traceOut._input;\n if(fullLayout[traceType + 'mode'] === 'group') {\n handleGroupingDefaults(traceIn, traceOut, fullLayout, coerce);\n }\n }\n }\n}\n\nmodule.exports = {\n supplyDefaults: supplyDefaults,\n crossTraceDefaults: crossTraceDefaults,\n\n handleSampleDefaults: handleSampleDefaults,\n handlePointsDefaults: handlePointsDefaults\n};\n","'use strict';\n\nmodule.exports = function eventData(out, pt) {\n // Note: hoverOnBox property is needed for click-to-select\n // to ignore when a box was clicked. This is the reason box\n // implements this custom eventData function.\n if(pt.hoverOnBox) out.hoverOnBox = pt.hoverOnBox;\n\n if('xVal' in pt) out.x = pt.xVal;\n if('yVal' in pt) out.y = pt.yVal;\n if(pt.xa) out.xaxis = pt.xa;\n if(pt.ya) out.yaxis = pt.ya;\n\n return out;\n};\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\nvar Lib = require('../../lib');\nvar Fx = require('../../components/fx');\nvar Color = require('../../components/color');\nvar fillText = Lib.fillText;\n\nfunction hoverPoints(pointData, xval, yval, hovermode) {\n var cd = pointData.cd;\n var trace = cd[0].trace;\n var hoveron = trace.hoveron;\n var closeBoxData = [];\n var closePtData;\n\n if(hoveron.indexOf('boxes') !== -1) {\n closeBoxData = closeBoxData.concat(hoverOnBoxes(pointData, xval, yval, hovermode));\n }\n\n if(hoveron.indexOf('points') !== -1) {\n closePtData = hoverOnPoints(pointData, xval, yval);\n }\n\n // If there's a point in range and hoveron has points, show the best single point only.\n // If hoveron has boxes and there's no point in range (or hoveron doesn't have points), show the box stats.\n if(hovermode === 'closest') {\n if(closePtData) return [closePtData];\n return closeBoxData;\n }\n\n // Otherwise in compare mode, allow a point AND the box stats to be labeled\n // If there are multiple boxes in range (ie boxmode = 'overlay') we'll see stats for all of them.\n if(closePtData) {\n closeBoxData.push(closePtData);\n return closeBoxData;\n }\n return closeBoxData;\n}\n\nfunction hoverOnBoxes(pointData, xval, yval, hovermode) {\n var cd = pointData.cd;\n var xa = pointData.xa;\n var ya = pointData.ya;\n var trace = cd[0].trace;\n var t = cd[0].t;\n var isViolin = trace.type === 'violin';\n\n var pLetter, vLetter, pAxis, vAxis, vVal, pVal, dx, dy, dPos,\n hoverPseudoDistance, spikePseudoDistance;\n\n var boxDelta = t.bdPos;\n var boxDeltaPos, boxDeltaNeg;\n var posAcceptance = t.wHover;\n var shiftPos = function(di) { return pAxis.c2l(di.pos) + t.bPos - pAxis.c2l(pVal); };\n\n if(isViolin && trace.side !== 'both') {\n if(trace.side === 'positive') {\n dPos = function(di) {\n var pos = shiftPos(di);\n return Fx.inbox(pos, pos + posAcceptance, hoverPseudoDistance);\n };\n boxDeltaPos = boxDelta;\n boxDeltaNeg = 0;\n }\n if(trace.side === 'negative') {\n dPos = function(di) {\n var pos = shiftPos(di);\n return Fx.inbox(pos - posAcceptance, pos, hoverPseudoDistance);\n };\n boxDeltaPos = 0;\n boxDeltaNeg = boxDelta;\n }\n } else {\n dPos = function(di) {\n var pos = shiftPos(di);\n return Fx.inbox(pos - posAcceptance, pos + posAcceptance, hoverPseudoDistance);\n };\n boxDeltaPos = boxDeltaNeg = boxDelta;\n }\n\n var dVal;\n\n if(isViolin) {\n dVal = function(di) {\n return Fx.inbox(di.span[0] - vVal, di.span[1] - vVal, hoverPseudoDistance);\n };\n } else {\n dVal = function(di) {\n return Fx.inbox(di.min - vVal, di.max - vVal, hoverPseudoDistance);\n };\n }\n\n if(trace.orientation === 'h') {\n vVal = xval;\n pVal = yval;\n dx = dVal;\n dy = dPos;\n pLetter = 'y';\n pAxis = ya;\n vLetter = 'x';\n vAxis = xa;\n } else {\n vVal = yval;\n pVal = xval;\n dx = dPos;\n dy = dVal;\n pLetter = 'x';\n pAxis = xa;\n vLetter = 'y';\n vAxis = ya;\n }\n\n // if two boxes are overlaying, let the narrowest one win\n var pseudoDistance = Math.min(1, boxDelta / Math.abs(pAxis.r2c(pAxis.range[1]) - pAxis.r2c(pAxis.range[0])));\n hoverPseudoDistance = pointData.maxHoverDistance - pseudoDistance;\n spikePseudoDistance = pointData.maxSpikeDistance - pseudoDistance;\n\n function dxy(di) { return (dx(di) + dy(di)) / 2; }\n var distfn = Fx.getDistanceFunction(hovermode, dx, dy, dxy);\n Fx.getClosest(cd, distfn, pointData);\n\n // skip the rest (for this trace) if we didn't find a close point\n // and create the item(s) in closedata for this point\n if(pointData.index === false) return [];\n\n var di = cd[pointData.index];\n var lc = trace.line.color;\n var mc = (trace.marker || {}).color;\n\n if(Color.opacity(lc) && trace.line.width) pointData.color = lc;\n else if(Color.opacity(mc) && trace.boxpoints) pointData.color = mc;\n else pointData.color = trace.fillcolor;\n\n pointData[pLetter + '0'] = pAxis.c2p(di.pos + t.bPos - boxDeltaNeg, true);\n pointData[pLetter + '1'] = pAxis.c2p(di.pos + t.bPos + boxDeltaPos, true);\n\n pointData[pLetter + 'LabelVal'] = di.orig_p !== undefined ? di.orig_p : di.pos;\n\n var spikePosAttr = pLetter + 'Spike';\n pointData.spikeDistance = dxy(di) * spikePseudoDistance / hoverPseudoDistance;\n pointData[spikePosAttr] = pAxis.c2p(di.pos, true);\n\n var hasMean = trace.boxmean || (trace.sizemode === 'sd') || (trace.meanline || {}).visible;\n var hasFences = trace.boxpoints || trace.points;\n\n // labels with equal values (e.g. when min === q1) should still be presented in the order they have when they're unequal\n var attrs =\n (hasFences && hasMean) ? ['max', 'uf', 'q3', 'med', 'mean', 'q1', 'lf', 'min'] :\n (hasFences && !hasMean) ? ['max', 'uf', 'q3', 'med', 'q1', 'lf', 'min'] :\n (!hasFences && hasMean) ? ['max', 'q3', 'med', 'mean', 'q1', 'min'] :\n ['max', 'q3', 'med', 'q1', 'min'];\n\n var rev = vAxis.range[1] < vAxis.range[0];\n\n if(trace.orientation === (rev ? 'v' : 'h')) {\n attrs.reverse();\n }\n\n var spikeDistance = pointData.spikeDistance;\n var spikePosition = pointData[spikePosAttr];\n\n var closeBoxData = [];\n for(var i = 0; i < attrs.length; i++) {\n var attr = attrs[i];\n\n if(!(attr in di)) continue;\n\n // copy out to a new object for each value to label\n var val = di[attr];\n var valPx = vAxis.c2p(val, true);\n var pointData2 = Lib.extendFlat({}, pointData);\n\n pointData2.attr = attr;\n pointData2[vLetter + '0'] = pointData2[vLetter + '1'] = valPx;\n pointData2[vLetter + 'LabelVal'] = val;\n pointData2[vLetter + 'Label'] = (t.labels ? t.labels[attr] + ' ' : '') + Axes.hoverLabelText(vAxis, val, trace[vLetter + 'hoverformat']);\n\n // Note: introduced to be able to distinguish a\n // clicked point from a box during click-to-select\n pointData2.hoverOnBox = true;\n\n if(attr === 'mean' && ('sd' in di) && ((trace.boxmean === 'sd') || (trace.sizemode === 'sd'))) {\n pointData2[vLetter + 'err'] = di.sd;\n }\n\n // no hovertemplate support yet\n pointData2.hovertemplate = false;\n\n closeBoxData.push(pointData2);\n }\n\n // only keep name and spikes on the median\n pointData.name = '';\n pointData.spikeDistance = undefined;\n pointData[spikePosAttr] = undefined;\n for(var k = 0; k < closeBoxData.length; k++) {\n if(closeBoxData[k].attr !== 'med') {\n closeBoxData[k].name = '';\n closeBoxData[k].spikeDistance = undefined;\n closeBoxData[k][spikePosAttr] = undefined;\n } else {\n closeBoxData[k].spikeDistance = spikeDistance;\n closeBoxData[k][spikePosAttr] = spikePosition;\n }\n }\n\n return closeBoxData;\n}\n\nfunction hoverOnPoints(pointData, xval, yval) {\n var cd = pointData.cd;\n var xa = pointData.xa;\n var ya = pointData.ya;\n var trace = cd[0].trace;\n var xPx = xa.c2p(xval);\n var yPx = ya.c2p(yval);\n var closePtData;\n\n var dx = function(di) {\n var rad = Math.max(3, di.mrc || 0);\n return Math.max(Math.abs(xa.c2p(di.x) - xPx) - rad, 1 - 3 / rad);\n };\n var dy = function(di) {\n var rad = Math.max(3, di.mrc || 0);\n return Math.max(Math.abs(ya.c2p(di.y) - yPx) - rad, 1 - 3 / rad);\n };\n var distfn = Fx.quadrature(dx, dy);\n\n // show one point per trace\n var ijClosest = false;\n var di, pt;\n\n for(var i = 0; i < cd.length; i++) {\n di = cd[i];\n\n for(var j = 0; j < (di.pts || []).length; j++) {\n pt = di.pts[j];\n\n var newDistance = distfn(pt);\n if(newDistance <= pointData.distance) {\n pointData.distance = newDistance;\n ijClosest = [i, j];\n }\n }\n }\n\n if(!ijClosest) return false;\n\n di = cd[ijClosest[0]];\n pt = di.pts[ijClosest[1]];\n\n var xc = xa.c2p(pt.x, true);\n var yc = ya.c2p(pt.y, true);\n var rad = pt.mrc || 1;\n\n closePtData = Lib.extendFlat({}, pointData, {\n // corresponds to index in x/y input data array\n index: pt.i,\n color: (trace.marker || {}).color,\n name: trace.name,\n x0: xc - rad,\n x1: xc + rad,\n y0: yc - rad,\n y1: yc + rad,\n spikeDistance: pointData.distance,\n hovertemplate: trace.hovertemplate\n });\n\n var origPos = di.orig_p;\n var pos = origPos !== undefined ? origPos : di.pos;\n var pa;\n if(trace.orientation === 'h') {\n pa = ya;\n closePtData.xLabelVal = pt.x;\n closePtData.yLabelVal = pos;\n } else {\n pa = xa;\n closePtData.xLabelVal = pos;\n closePtData.yLabelVal = pt.y;\n }\n\n var pLetter = pa._id.charAt(0);\n closePtData[pLetter + 'Spike'] = pa.c2p(di.pos, true);\n\n fillText(pt, trace, closePtData);\n\n return closePtData;\n}\n\nmodule.exports = {\n hoverPoints: hoverPoints,\n hoverOnBoxes: hoverOnBoxes,\n hoverOnPoints: hoverOnPoints\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n layoutAttributes: require('./layout_attributes'),\n supplyDefaults: require('./defaults').supplyDefaults,\n crossTraceDefaults: require('./defaults').crossTraceDefaults,\n supplyLayoutDefaults: require('./layout_defaults').supplyLayoutDefaults,\n calc: require('./calc'),\n crossTraceCalc: require('./cross_trace_calc').crossTraceCalc,\n plot: require('./plot').plot,\n style: require('./style').style,\n styleOnSelect: require('./style').styleOnSelect,\n hoverPoints: require('./hover').hoverPoints,\n eventData: require('./event_data'),\n selectPoints: require('./select'),\n\n moduleType: 'trace',\n name: 'box',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['cartesian', 'svg', 'symbols', 'oriented', 'box-violin', 'showLegend', 'boxLayout', 'zoomScale'],\n meta: {\n description: [\n 'Each box spans from quartile 1 (Q1) to quartile 3 (Q3).',\n 'The second quartile (Q2, i.e. the median) is marked by a line inside the box.',\n 'The fences grow outward from the boxes\\' edges,',\n 'by default they span +/- 1.5 times the interquartile range (IQR: Q3-Q1),',\n 'The sample mean and standard deviation as well as notches and',\n 'the sample, outlier and suspected outliers points can be optionally',\n 'added to the box plot.',\n\n 'The values and positions corresponding to each boxes can be input',\n 'using two signatures.',\n\n 'The first signature expects users to supply the sample values in the `y`',\n 'data array for vertical boxes (`x` for horizontal boxes).',\n 'By supplying an `x` (`y`) array, one box per distinct `x` (`y`) value is drawn',\n 'If no `x` (`y`) {array} is provided, a single box is drawn.',\n 'In this case, the box is positioned with the trace `name` or with `x0` (`y0`) if provided.',\n\n 'The second signature expects users to supply the boxes corresponding Q1, median and Q3',\n 'statistics in the `q1`, `median` and `q3` data arrays respectively.',\n 'Other box features relying on statistics namely `lowerfence`, `upperfence`, `notchspan`',\n 'can be set directly by the users.',\n 'To have plotly compute them or to show sample points besides the boxes,',\n 'users can set the `y` data array for vertical boxes (`x` for horizontal boxes)',\n 'to a 2D array with the outer length corresponding',\n 'to the number of boxes in the traces and the inner length corresponding the sample size.'\n ].join(' ')\n }\n};\n","'use strict';\n\n\nmodule.exports = {\n boxmode: {\n valType: 'enumerated',\n values: ['group', 'overlay'],\n dflt: 'overlay',\n editType: 'calc',\n description: [\n 'Determines how boxes at the same location coordinate',\n 'are displayed on the graph.',\n 'If *group*, the boxes are plotted next to one another',\n 'centered around the shared location.',\n 'If *overlay*, the boxes are plotted over one another,',\n 'you might need to set *opacity* to see them multiple boxes.',\n 'Has no effect on traces that have *width* set.'\n ].join(' ')\n },\n boxgap: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0.3,\n editType: 'calc',\n description: [\n 'Sets the gap (in plot fraction) between boxes of',\n 'adjacent location coordinates.',\n 'Has no effect on traces that have *width* set.'\n ].join(' ')\n },\n boxgroupgap: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0.3,\n editType: 'calc',\n description: [\n 'Sets the gap (in plot fraction) between boxes of',\n 'the same location coordinate.',\n 'Has no effect on traces that have *width* set.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar layoutAttributes = require('./layout_attributes');\n\nfunction _supply(layoutIn, layoutOut, fullData, coerce, traceType) {\n var category = traceType + 'Layout';\n var hasTraceType = false;\n\n for(var i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n\n if(Registry.traceIs(trace, category)) {\n hasTraceType = true;\n break;\n }\n }\n if(!hasTraceType) return;\n\n coerce(traceType + 'mode');\n coerce(traceType + 'gap');\n coerce(traceType + 'groupgap');\n}\n\nfunction supplyLayoutDefaults(layoutIn, layoutOut, fullData) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n _supply(layoutIn, layoutOut, fullData, coerce, 'box');\n}\n\nmodule.exports = {\n supplyLayoutDefaults: supplyLayoutDefaults,\n _supply: _supply\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Lib = require('../../lib');\nvar Drawing = require('../../components/drawing');\n\n// constants for dynamic jitter (ie less jitter for sparser points)\nvar JITTERCOUNT = 5; // points either side of this to include\nvar JITTERSPREAD = 0.01; // fraction of IQR to count as \"dense\"\n\nfunction plot(gd, plotinfo, cdbox, boxLayer) {\n var isStatic = gd._context.staticPlot;\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n Lib.makeTraceGroups(boxLayer, cdbox, 'trace boxes').each(function(cd) {\n var plotGroup = d3.select(this);\n var cd0 = cd[0];\n var t = cd0.t;\n var trace = cd0.trace;\n\n // whisker width\n t.wdPos = t.bdPos * trace.whiskerwidth;\n\n if(trace.visible !== true || t.empty) {\n plotGroup.remove();\n return;\n }\n\n var posAxis, valAxis;\n\n if(trace.orientation === 'h') {\n posAxis = ya;\n valAxis = xa;\n } else {\n posAxis = xa;\n valAxis = ya;\n }\n\n plotBoxAndWhiskers(plotGroup, {pos: posAxis, val: valAxis}, trace, t, isStatic);\n plotPoints(plotGroup, {x: xa, y: ya}, trace, t);\n plotBoxMean(plotGroup, {pos: posAxis, val: valAxis}, trace, t);\n });\n}\n\nfunction plotBoxAndWhiskers(sel, axes, trace, t, isStatic) {\n var isHorizontal = trace.orientation === 'h';\n var valAxis = axes.val;\n var posAxis = axes.pos;\n var posHasRangeBreaks = !!posAxis.rangebreaks;\n\n var bPos = t.bPos;\n var wdPos = t.wdPos || 0;\n var bPosPxOffset = t.bPosPxOffset || 0;\n var whiskerWidth = trace.whiskerwidth || 0;\n var showWhiskers = (trace.showwhiskers !== false);\n var notched = trace.notched || false;\n var nw = notched ? 1 - 2 * trace.notchwidth : 1;\n\n // to support for one-sided box\n var bdPos0;\n var bdPos1;\n if(Array.isArray(t.bdPos)) {\n bdPos0 = t.bdPos[0];\n bdPos1 = t.bdPos[1];\n } else {\n bdPos0 = t.bdPos;\n bdPos1 = t.bdPos;\n }\n\n var paths = sel.selectAll('path.box').data((\n trace.type !== 'violin' ||\n trace.box.visible\n ) ? Lib.identity : []);\n\n paths.enter().append('path')\n .style('vector-effect', isStatic ? 'none' : 'non-scaling-stroke')\n .attr('class', 'box');\n\n paths.exit().remove();\n\n paths.each(function(d) {\n if(d.empty) return d3.select(this).attr('d', 'M0,0Z');\n\n var lcenter = posAxis.c2l(d.pos + bPos, true);\n\n var pos0 = posAxis.l2p(lcenter - bdPos0) + bPosPxOffset;\n var pos1 = posAxis.l2p(lcenter + bdPos1) + bPosPxOffset;\n var posc = posHasRangeBreaks ? (pos0 + pos1) / 2 : posAxis.l2p(lcenter) + bPosPxOffset;\n\n var r = trace.whiskerwidth;\n var posw0 = posHasRangeBreaks ? pos0 * r + (1 - r) * posc : posAxis.l2p(lcenter - wdPos) + bPosPxOffset;\n var posw1 = posHasRangeBreaks ? pos1 * r + (1 - r) * posc : posAxis.l2p(lcenter + wdPos) + bPosPxOffset;\n\n var posm0 = posAxis.l2p(lcenter - bdPos0 * nw) + bPosPxOffset;\n var posm1 = posAxis.l2p(lcenter + bdPos1 * nw) + bPosPxOffset;\n var sdmode = trace.sizemode === 'sd';\n var q1 = valAxis.c2p(sdmode ? d.mean - d.sd : d.q1, true);\n var q3 = sdmode ? valAxis.c2p(d.mean + d.sd, true) :\n valAxis.c2p(d.q3, true);\n // make sure median isn't identical to either of the\n // quartiles, so we can see it\n var m = Lib.constrain(\n sdmode ? valAxis.c2p(d.mean, true) :\n valAxis.c2p(d.med, true),\n Math.min(q1, q3) + 1, Math.max(q1, q3) - 1\n );\n\n // for compatibility with box, violin, and candlestick\n // perhaps we should put this into cd0.t instead so it's more explicit,\n // but what we have now is:\n // - box always has d.lf, but boxpoints can be anything\n // - violin has d.lf and should always use it (boxpoints is undefined)\n // - candlestick has only min/max\n var useExtremes = (d.lf === undefined) || (trace.boxpoints === false) || sdmode;\n var lf = valAxis.c2p(useExtremes ? d.min : d.lf, true);\n var uf = valAxis.c2p(useExtremes ? d.max : d.uf, true);\n var ln = valAxis.c2p(d.ln, true);\n var un = valAxis.c2p(d.un, true);\n\n if(isHorizontal) {\n d3.select(this).attr('d',\n 'M' + m + ',' + posm0 + 'V' + posm1 + // median line\n 'M' + q1 + ',' + pos0 + 'V' + pos1 + // left edge\n (notched ?\n 'H' + ln + 'L' + m + ',' + posm1 + 'L' + un + ',' + pos1 :\n ''\n ) + // top notched edge\n 'H' + q3 + // end of the top edge\n 'V' + pos0 + // right edge\n (notched ? 'H' + un + 'L' + m + ',' + posm0 + 'L' + ln + ',' + pos0 : '') + // bottom notched edge\n 'Z' + // end of the box\n (showWhiskers ?\n 'M' + q1 + ',' + posc + 'H' + lf + 'M' + q3 + ',' + posc + 'H' + uf + // whiskers\n (whiskerWidth === 0 ?\n '' : // whisker caps\n 'M' + lf + ',' + posw0 + 'V' + posw1 + 'M' + uf + ',' + posw0 + 'V' + posw1\n ) :\n ''\n )\n );\n } else {\n d3.select(this).attr('d',\n 'M' + posm0 + ',' + m + 'H' + posm1 + // median line\n 'M' + pos0 + ',' + q1 + 'H' + pos1 + // top of the box\n (notched ?\n 'V' + ln + 'L' + posm1 + ',' + m + 'L' + pos1 + ',' + un :\n ''\n ) + // notched right edge\n 'V' + q3 + // end of the right edge\n 'H' + pos0 + // bottom of the box\n (notched ?\n 'V' + un + 'L' + posm0 + ',' + m + 'L' + pos0 + ',' + ln :\n ''\n ) + // notched left edge\n 'Z' + // end of the box\n (showWhiskers ?\n 'M' + posc + ',' + q1 + 'V' + lf + 'M' + posc + ',' + q3 + 'V' + uf + // whiskers\n (whiskerWidth === 0 ?\n '' : // whisker caps\n 'M' + posw0 + ',' + lf + 'H' + posw1 + 'M' + posw0 + ',' + uf + 'H' + posw1\n ) :\n ''\n )\n );\n }\n });\n}\n\nfunction plotPoints(sel, axes, trace, t) {\n var xa = axes.x;\n var ya = axes.y;\n var bdPos = t.bdPos;\n var bPos = t.bPos;\n\n // to support violin points\n var mode = trace.boxpoints || trace.points;\n\n // repeatable pseudo-random number generator\n Lib.seedPseudoRandom();\n\n // since box plot points get an extra level of nesting, each\n // box needs the trace styling info\n var fn = function(d) {\n d.forEach(function(v) {\n v.t = t;\n v.trace = trace;\n });\n return d;\n };\n\n var gPoints = sel.selectAll('g.points')\n .data(mode ? fn : []);\n\n gPoints.enter().append('g')\n .attr('class', 'points');\n\n gPoints.exit().remove();\n\n var paths = gPoints.selectAll('path')\n .data(function(d) {\n var i;\n var pts = d.pts2;\n\n // normally use IQR, but if this is 0 or too small, use max-min\n var typicalSpread = Math.max((d.max - d.min) / 10, d.q3 - d.q1);\n var minSpread = typicalSpread * 1e-9;\n var spreadLimit = typicalSpread * JITTERSPREAD;\n var jitterFactors = [];\n var maxJitterFactor = 0;\n var newJitter;\n\n // dynamic jitter\n if(trace.jitter) {\n if(typicalSpread === 0) {\n // edge case of no spread at all: fall back to max jitter\n maxJitterFactor = 1;\n jitterFactors = new Array(pts.length);\n for(i = 0; i < pts.length; i++) {\n jitterFactors[i] = 1;\n }\n } else {\n for(i = 0; i < pts.length; i++) {\n var i0 = Math.max(0, i - JITTERCOUNT);\n var pmin = pts[i0].v;\n var i1 = Math.min(pts.length - 1, i + JITTERCOUNT);\n var pmax = pts[i1].v;\n\n if(mode !== 'all') {\n if(pts[i].v < d.lf) pmax = Math.min(pmax, d.lf);\n else pmin = Math.max(pmin, d.uf);\n }\n\n var jitterFactor = Math.sqrt(spreadLimit * (i1 - i0) / (pmax - pmin + minSpread)) || 0;\n jitterFactor = Lib.constrain(Math.abs(jitterFactor), 0, 1);\n\n jitterFactors.push(jitterFactor);\n maxJitterFactor = Math.max(jitterFactor, maxJitterFactor);\n }\n }\n newJitter = trace.jitter * 2 / (maxJitterFactor || 1);\n }\n\n // fills in 'x' and 'y' in calcdata 'pts' item\n for(i = 0; i < pts.length; i++) {\n var pt = pts[i];\n var v = pt.v;\n\n var jitterOffset = trace.jitter ?\n (newJitter * jitterFactors[i] * (Lib.pseudoRandom() - 0.5)) :\n 0;\n\n var posPx = d.pos + bPos + bdPos * (trace.pointpos + jitterOffset);\n\n if(trace.orientation === 'h') {\n pt.y = posPx;\n pt.x = v;\n } else {\n pt.x = posPx;\n pt.y = v;\n }\n\n // tag suspected outliers\n if(mode === 'suspectedoutliers' && v < d.uo && v > d.lo) {\n pt.so = true;\n }\n }\n\n return pts;\n });\n\n paths.enter().append('path')\n .classed('point', true);\n\n paths.exit().remove();\n\n paths.call(Drawing.translatePoints, xa, ya);\n}\n\nfunction plotBoxMean(sel, axes, trace, t) {\n var valAxis = axes.val;\n var posAxis = axes.pos;\n var posHasRangeBreaks = !!posAxis.rangebreaks;\n\n var bPos = t.bPos;\n var bPosPxOffset = t.bPosPxOffset || 0;\n\n // to support violin mean lines\n var mode = trace.boxmean || (trace.meanline || {}).visible;\n\n // to support for one-sided box\n var bdPos0;\n var bdPos1;\n if(Array.isArray(t.bdPos)) {\n bdPos0 = t.bdPos[0];\n bdPos1 = t.bdPos[1];\n } else {\n bdPos0 = t.bdPos;\n bdPos1 = t.bdPos;\n }\n\n var paths = sel.selectAll('path.mean').data((\n (trace.type === 'box' && trace.boxmean) ||\n (trace.type === 'violin' && trace.box.visible && trace.meanline.visible)\n ) ? Lib.identity : []);\n\n paths.enter().append('path')\n .attr('class', 'mean')\n .style({\n fill: 'none',\n 'vector-effect': 'non-scaling-stroke'\n });\n\n paths.exit().remove();\n\n paths.each(function(d) {\n var lcenter = posAxis.c2l(d.pos + bPos, true);\n\n var pos0 = posAxis.l2p(lcenter - bdPos0) + bPosPxOffset;\n var pos1 = posAxis.l2p(lcenter + bdPos1) + bPosPxOffset;\n var posc = posHasRangeBreaks ? (pos0 + pos1) / 2 : posAxis.l2p(lcenter) + bPosPxOffset;\n\n var m = valAxis.c2p(d.mean, true);\n var sl = valAxis.c2p(d.mean - d.sd, true);\n var sh = valAxis.c2p(d.mean + d.sd, true);\n\n if(trace.orientation === 'h') {\n d3.select(this).attr('d',\n 'M' + m + ',' + pos0 + 'V' + pos1 +\n (mode === 'sd' ?\n 'm0,0L' + sl + ',' + posc + 'L' + m + ',' + pos0 + 'L' + sh + ',' + posc + 'Z' :\n '')\n );\n } else {\n d3.select(this).attr('d',\n 'M' + pos0 + ',' + m + 'H' + pos1 +\n (mode === 'sd' ?\n 'm0,0L' + posc + ',' + sl + 'L' + pos0 + ',' + m + 'L' + posc + ',' + sh + 'Z' :\n '')\n );\n }\n });\n}\n\nmodule.exports = {\n plot: plot,\n plotBoxAndWhiskers: plotBoxAndWhiskers,\n plotPoints: plotPoints,\n plotBoxMean: plotBoxMean\n};\n","'use strict';\n\nmodule.exports = function selectPoints(searchInfo, selectionTester) {\n var cd = searchInfo.cd;\n var xa = searchInfo.xaxis;\n var ya = searchInfo.yaxis;\n var selection = [];\n var i, j;\n\n if(selectionTester === false) {\n for(i = 0; i < cd.length; i++) {\n for(j = 0; j < (cd[i].pts || []).length; j++) {\n // clear selection\n cd[i].pts[j].selected = 0;\n }\n }\n } else {\n for(i = 0; i < cd.length; i++) {\n for(j = 0; j < (cd[i].pts || []).length; j++) {\n var pt = cd[i].pts[j];\n var x = xa.c2p(pt.x);\n var y = ya.c2p(pt.y);\n\n if(selectionTester.contains([x, y], null, pt.i, searchInfo)) {\n selection.push({\n pointNumber: pt.i,\n x: xa.c2d(pt.x),\n y: ya.c2d(pt.y)\n });\n pt.selected = 1;\n } else {\n pt.selected = 0;\n }\n }\n }\n }\n\n return selection;\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\n\nfunction style(gd, cd, sel) {\n var s = sel ? sel : d3.select(gd).selectAll('g.trace.boxes');\n\n s.style('opacity', function(d) { return d[0].trace.opacity; });\n\n s.each(function(d) {\n var el = d3.select(this);\n var trace = d[0].trace;\n var lineWidth = trace.line.width;\n\n function styleBox(boxSel, lineWidth, lineColor, fillColor) {\n boxSel.style('stroke-width', lineWidth + 'px')\n .call(Color.stroke, lineColor)\n .call(Color.fill, fillColor);\n }\n\n var allBoxes = el.selectAll('path.box');\n\n if(trace.type === 'candlestick') {\n allBoxes.each(function(boxData) {\n if(boxData.empty) return;\n\n var thisBox = d3.select(this);\n var container = trace[boxData.dir]; // dir = 'increasing' or 'decreasing'\n styleBox(thisBox, container.line.width, container.line.color, container.fillcolor);\n // TODO: custom selection style for candlesticks\n thisBox.style('opacity', trace.selectedpoints && !boxData.selected ? 0.3 : 1);\n });\n } else {\n styleBox(allBoxes, lineWidth, trace.line.color, trace.fillcolor);\n el.selectAll('path.mean')\n .style({\n 'stroke-width': lineWidth,\n 'stroke-dasharray': (2 * lineWidth) + 'px,' + lineWidth + 'px'\n })\n .call(Color.stroke, trace.line.color);\n\n var pts = el.selectAll('path.point');\n Drawing.pointStyle(pts, trace, gd);\n }\n });\n}\n\nfunction styleOnSelect(gd, cd, sel) {\n var trace = cd[0].trace;\n var pts = sel.selectAll('path.point');\n\n if(trace.selectedpoints) {\n Drawing.selectedPointStyle(pts, trace);\n } else {\n Drawing.pointStyle(pts, trace, gd);\n }\n}\n\nmodule.exports = {\n style: style,\n styleOnSelect: styleOnSelect\n};\n","'use strict';\n\nvar extendFlat = require('../../lib').extendFlat;\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar OHLCattrs = require('../ohlc/attributes');\nvar boxAttrs = require('../box/attributes');\n\nfunction directionAttrs(lineColorDefault) {\n return {\n line: {\n color: extendFlat({}, boxAttrs.line.color, {dflt: lineColorDefault}),\n width: boxAttrs.line.width,\n editType: 'style'\n },\n\n fillcolor: boxAttrs.fillcolor,\n editType: 'style'\n };\n}\n\nmodule.exports = {\n xperiod: OHLCattrs.xperiod,\n xperiod0: OHLCattrs.xperiod0,\n xperiodalignment: OHLCattrs.xperiodalignment,\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n\n x: OHLCattrs.x,\n open: OHLCattrs.open,\n high: OHLCattrs.high,\n low: OHLCattrs.low,\n close: OHLCattrs.close,\n\n line: {\n width: extendFlat({}, boxAttrs.line.width, {\n description: [\n boxAttrs.line.width.description,\n 'Note that this style setting can also be set per',\n 'direction via `increasing.line.width` and',\n '`decreasing.line.width`.'\n ].join(' ')\n }),\n editType: 'style'\n },\n\n increasing: directionAttrs(OHLCattrs.increasing.line.color.dflt),\n\n decreasing: directionAttrs(OHLCattrs.decreasing.line.color.dflt),\n\n text: OHLCattrs.text,\n hovertext: OHLCattrs.hovertext,\n\n whiskerwidth: extendFlat({}, boxAttrs.whiskerwidth, { dflt: 0 }),\n\n hoverlabel: OHLCattrs.hoverlabel,\n zorder: boxAttrs.zorder\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar alignPeriod = require('../../plots/cartesian/align_period');\n\nvar calcCommon = require('../ohlc/calc').calcCommon;\n\nmodule.exports = function(gd, trace) {\n var fullLayout = gd._fullLayout;\n var xa = Axes.getFromId(gd, trace.xaxis);\n var ya = Axes.getFromId(gd, trace.yaxis);\n\n var origX = xa.makeCalcdata(trace, 'x');\n var x = alignPeriod(trace, xa, 'x', origX).vals;\n\n var cd = calcCommon(gd, trace, origX, x, ya, ptFunc);\n\n if(cd.length) {\n Lib.extendFlat(cd[0].t, {\n num: fullLayout._numBoxes,\n dPos: Lib.distinctVals(x).minDiff / 2,\n posLetter: 'x',\n valLetter: 'y',\n });\n\n fullLayout._numBoxes++;\n return cd;\n } else {\n return [{t: {empty: true}}];\n }\n};\n\nfunction ptFunc(o, h, l, c) {\n return {\n min: l,\n q1: Math.min(o, c),\n med: c,\n q3: Math.max(o, c),\n max: h,\n };\n}\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../../components/color');\nvar handleOHLC = require('../ohlc/ohlc_defaults');\nvar handlePeriodDefaults = require('../scatter/period_defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleOHLC(traceIn, traceOut, coerce, layout);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n handlePeriodDefaults(traceIn, traceOut, layout, coerce, {x: true});\n coerce('xhoverformat');\n coerce('yhoverformat');\n\n coerce('line.width');\n\n handleDirection(traceIn, traceOut, coerce, 'increasing');\n handleDirection(traceIn, traceOut, coerce, 'decreasing');\n\n coerce('text');\n coerce('hovertext');\n coerce('whiskerwidth');\n\n layout._requestRangeslider[traceOut.xaxis] = true;\n coerce('zorder');\n};\n\nfunction handleDirection(traceIn, traceOut, coerce, direction) {\n var lineColor = coerce(direction + '.line.color');\n coerce(direction + '.line.width', traceOut.line.width);\n coerce(direction + '.fillcolor', Color.addOpacity(lineColor, 0.5));\n}\n","'use strict';\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'candlestick',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['cartesian', 'svg', 'showLegend', 'candlestick', 'boxLayout'],\n meta: {\n description: [\n 'The candlestick is a style of financial chart describing',\n 'open, high, low and close for a given `x` coordinate (most likely time).',\n\n 'The boxes represent the spread between the `open` and `close` values and',\n 'the lines represent the spread between the `low` and `high` values',\n\n 'Sample points where the close value is higher (lower) then the open',\n 'value are called increasing (decreasing).',\n\n 'By default, increasing candles are drawn in green whereas',\n 'decreasing are drawn in red.'\n ].join(' ')\n },\n\n attributes: require('./attributes'),\n layoutAttributes: require('../box/layout_attributes'),\n supplyLayoutDefaults: require('../box/layout_defaults').supplyLayoutDefaults,\n crossTraceCalc: require('../box/cross_trace_calc').crossTraceCalc,\n supplyDefaults: require('./defaults'),\n calc: require('./calc'),\n plot: require('../box/plot').plot,\n layerName: 'boxlayer',\n style: require('../box/style').style,\n hoverPoints: require('../ohlc/hover').hoverPoints,\n selectPoints: require('../ohlc/select')\n};\n","'use strict';\n\nvar handleAxisDefaults = require('./axis_defaults');\nvar Template = require('../../plot_api/plot_template');\n\nmodule.exports = function handleABDefaults(traceIn, traceOut, fullLayout, coerce, dfltColor) {\n var a = coerce('a');\n\n if(!a) {\n coerce('da');\n coerce('a0');\n }\n\n var b = coerce('b');\n\n if(!b) {\n coerce('db');\n coerce('b0');\n }\n\n mimickAxisDefaults(traceIn, traceOut, fullLayout, dfltColor);\n};\n\nfunction mimickAxisDefaults(traceIn, traceOut, fullLayout, dfltColor) {\n var axesList = ['aaxis', 'baxis'];\n\n axesList.forEach(function(axName) {\n var axLetter = axName.charAt(0);\n var axIn = traceIn[axName] || {};\n var axOut = Template.newContainer(traceOut, axName);\n\n var defaultOptions = {\n noAutotickangles: true,\n noTicklabelshift: true,\n noTicklabelstandoff: true,\n noTicklabelstep: true,\n tickfont: 'x',\n id: axLetter + 'axis',\n letter: axLetter,\n font: traceOut.font,\n name: axName,\n data: traceIn[axLetter],\n calendar: traceOut.calendar,\n dfltColor: dfltColor,\n bgColor: fullLayout.paper_bgcolor,\n autotypenumbersDflt: fullLayout.autotypenumbers,\n fullLayout: fullLayout\n };\n\n handleAxisDefaults(axIn, axOut, defaultOptions);\n axOut._categories = axOut._categories || [];\n\n // so we don't have to repeat autotype unnecessarily,\n // copy an autotype back to traceIn\n if(!traceIn[axName] && axIn.type !== '-') {\n traceIn[axName] = {type: axIn.type};\n }\n });\n}\n","'use strict';\n\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\n\nmodule.exports = function(a) {\n return minMax(a, 0);\n};\n\nfunction minMax(a, depth) {\n // Limit to ten dimensional datasets. This seems *exceedingly* unlikely to\n // ever cause problems or even be a concern. It's include strictly so that\n // circular arrays could never cause this to loop.\n if(!isArrayOrTypedArray(a) || depth >= 10) {\n return null;\n }\n\n var min = Infinity;\n var max = -Infinity;\n var n = a.length;\n for(var i = 0; i < n; i++) {\n var datum = a[i];\n\n if(isArrayOrTypedArray(datum)) {\n var result = minMax(datum, depth + 1);\n\n if(result) {\n min = Math.min(result[0], min);\n max = Math.max(result[1], max);\n }\n } else {\n min = Math.min(datum, min);\n max = Math.max(datum, max);\n }\n }\n\n return [min, max];\n}\n","'use strict';\n\nvar fontAttrs = require('../../plots/font_attributes');\nvar axisAttrs = require('./axis_attributes');\nvar colorAttrs = require('../../components/color/attributes');\n\nvar carpetFont = fontAttrs({\n editType: 'calc',\n description: 'The default font used for axis & tick labels on this carpet'\n});\n\nvar zorder = require('../scatter/attributes').zorder;\n\n// TODO: inherit from global font\ncarpetFont.family.dflt = '\"Open Sans\", verdana, arial, sans-serif';\ncarpetFont.size.dflt = 12;\ncarpetFont.color.dflt = colorAttrs.defaultLine;\n\nmodule.exports = {\n carpet: {\n valType: 'string',\n editType: 'calc',\n description: [\n 'An identifier for this carpet, so that `scattercarpet` and',\n '`contourcarpet` traces can specify a carpet plot on which',\n 'they lie'\n ].join(' ')\n },\n x: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'A two dimensional array of x coordinates at each carpet point.',\n 'If omitted, the plot is a cheater plot and the xaxis is hidden',\n 'by default.'\n ].join(' ')\n },\n y: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: 'A two dimensional array of y coordinates at each carpet point.'\n },\n a: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'An array containing values of the first parameter value'\n ].join(' ')\n },\n a0: {\n valType: 'number',\n dflt: 0,\n editType: 'calc',\n description: [\n 'Alternate to `a`.',\n 'Builds a linear space of a coordinates.',\n 'Use with `da`',\n 'where `a0` is the starting coordinate and `da` the step.'\n ].join(' ')\n },\n da: {\n valType: 'number',\n dflt: 1,\n editType: 'calc',\n description: [\n 'Sets the a coordinate step.',\n 'See `a0` for more info.'\n ].join(' ')\n },\n b: {\n valType: 'data_array',\n editType: 'calc',\n description: 'A two dimensional array of y coordinates at each carpet point.'\n },\n b0: {\n valType: 'number',\n dflt: 0,\n editType: 'calc',\n description: [\n 'Alternate to `b`.',\n 'Builds a linear space of a coordinates.',\n 'Use with `db`',\n 'where `b0` is the starting coordinate and `db` the step.'\n ].join(' ')\n },\n db: {\n valType: 'number',\n dflt: 1,\n editType: 'calc',\n description: [\n 'Sets the b coordinate step.',\n 'See `b0` for more info.'\n ].join(' ')\n },\n cheaterslope: {\n valType: 'number',\n dflt: 1,\n editType: 'calc',\n description: [\n 'The shift applied to each successive row of data in creating a cheater plot.',\n 'Only used if `x` is been omitted.'\n ].join(' ')\n },\n aaxis: axisAttrs,\n baxis: axisAttrs,\n font: carpetFont,\n color: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n editType: 'plot',\n description: [\n 'Sets default for all colors associated with this axis',\n 'all at once: line, font, tick, and grid colors.',\n 'Grid color is lightened by blending this with the plot background',\n 'Individual pieces can override this.'\n ].join(' ')\n },\n transforms: undefined,\n zorder: zorder\n};\n","'use strict';\n\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\n\n/* This function retrns a set of control points that define a curve aligned along\n * either the a or b axis. Exactly one of a or b must be an array defining the range\n * spanned.\n *\n * Honestly this is the most complicated function I've implemente here so far because\n * of the way it handles knot insertion and direction/axis-agnostic slices.\n */\nmodule.exports = function(carpet, carpetcd, a, b) {\n var idx, tangent, tanIsoIdx, tanIsoPar, segment, refidx;\n var p0, p1, v0, v1, start, end, range;\n\n var axis = isArrayOrTypedArray(a) ? 'a' : 'b';\n var ax = axis === 'a' ? carpet.aaxis : carpet.baxis;\n var smoothing = ax.smoothing;\n var toIdx = axis === 'a' ? carpet.a2i : carpet.b2j;\n var pt = axis === 'a' ? a : b;\n var iso = axis === 'a' ? b : a;\n var n = axis === 'a' ? carpetcd.a.length : carpetcd.b.length;\n var m = axis === 'a' ? carpetcd.b.length : carpetcd.a.length;\n var isoIdx = Math.floor(axis === 'a' ? carpet.b2j(iso) : carpet.a2i(iso));\n\n var xy = axis === 'a' ? function(value) {\n return carpet.evalxy([], value, isoIdx);\n } : function(value) {\n return carpet.evalxy([], isoIdx, value);\n };\n\n if(smoothing) {\n tanIsoIdx = Math.max(0, Math.min(m - 2, isoIdx));\n tanIsoPar = isoIdx - tanIsoIdx;\n tangent = axis === 'a' ? function(i, ti) {\n return carpet.dxydi([], i, tanIsoIdx, ti, tanIsoPar);\n } : function(j, tj) {\n return carpet.dxydj([], tanIsoIdx, j, tanIsoPar, tj);\n };\n }\n\n var vstart = toIdx(pt[0]);\n var vend = toIdx(pt[1]);\n\n // So that we can make this work in two directions, flip all of the\n // math functions if the direction is from higher to lower indices:\n //\n // Note that the tolerance is directional!\n var dir = vstart < vend ? 1 : -1;\n var tol = (vend - vstart) * 1e-8;\n var dirfloor = dir > 0 ? Math.floor : Math.ceil;\n var dirceil = dir > 0 ? Math.ceil : Math.floor;\n var dirmin = dir > 0 ? Math.min : Math.max;\n var dirmax = dir > 0 ? Math.max : Math.min;\n\n var idx0 = dirfloor(vstart + tol);\n var idx1 = dirceil(vend - tol);\n\n p0 = xy(vstart);\n var segments = [[p0]];\n\n for(idx = idx0; idx * dir < idx1 * dir; idx += dir) {\n segment = [];\n start = dirmax(vstart, idx);\n end = dirmin(vend, idx + dir);\n range = end - start;\n\n // In order to figure out which cell we're in for the derivative (remember,\n // the derivatives are *not* constant across grid lines), let's just average\n // the start and end points. This cuts out just a tiny bit of logic and\n // there's really no computational difference:\n refidx = Math.max(0, Math.min(n - 2, Math.floor(0.5 * (start + end))));\n\n p1 = xy(end);\n if(smoothing) {\n v0 = tangent(refidx, start - refidx);\n v1 = tangent(refidx, end - refidx);\n\n segment.push([\n p0[0] + v0[0] / 3 * range,\n p0[1] + v0[1] / 3 * range\n ]);\n\n segment.push([\n p1[0] - v1[0] / 3 * range,\n p1[1] - v1[1] / 3 * range\n ]);\n }\n\n segment.push(p1);\n\n segments.push(segment);\n p0 = p1;\n }\n\n return segments;\n};\n","'use strict';\n\nvar fontAttrs = require('../../plots/font_attributes');\nvar colorAttrs = require('../../components/color/attributes');\nvar axesAttrs = require('../../plots/cartesian/layout_attributes');\nvar descriptionWithDates = require('../../plots/cartesian/axis_format_attributes').descriptionWithDates;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar dash = require('../../components/drawing/attributes').dash;\nvar extendFlat = require('../../lib/extend').extendFlat;\n\n\nmodule.exports = {\n color: {\n valType: 'color',\n editType: 'calc',\n description: [\n 'Sets default for all colors associated with this axis',\n 'all at once: line, font, tick, and grid colors.',\n 'Grid color is lightened by blending this with the plot background',\n 'Individual pieces can override this.'\n ].join(' ')\n },\n smoothing: {\n valType: 'number',\n dflt: 1,\n min: 0,\n max: 1.3,\n editType: 'calc'\n },\n title: {\n text: {\n valType: 'string',\n dflt: '',\n editType: 'calc',\n description: [\n 'Sets the title of this axis.',\n 'Note that before the existence of `title.text`, the title\\'s',\n 'contents used to be defined as the `title` attribute itself.',\n 'This behavior has been deprecated.'\n ].join(' ')\n },\n font: fontAttrs({\n editType: 'calc',\n description: [\n 'Sets this axis\\' title font.',\n 'Note that the title\\'s font used to be set',\n 'by the now deprecated `titlefont` attribute.'\n ].join(' ')\n }),\n // TODO how is this different than `title.standoff`\n offset: {\n valType: 'number',\n dflt: 10,\n editType: 'calc',\n description: [\n 'An additional amount by which to offset the title from the tick',\n 'labels, given in pixels.',\n 'Note that this used to be set',\n 'by the now deprecated `titleoffset` attribute.'\n ].join(' '),\n },\n editType: 'calc',\n },\n type: {\n valType: 'enumerated',\n // '-' means we haven't yet run autotype or couldn't find any data\n // it gets turned into linear in gd._fullLayout but not copied back\n // to gd.data like the others are.\n values: ['-', 'linear', 'date', 'category'],\n dflt: '-',\n editType: 'calc',\n description: [\n 'Sets the axis type.',\n 'By default, plotly attempts to determined the axis type',\n 'by looking into the data of the traces that referenced',\n 'the axis in question.'\n ].join(' ')\n },\n autotypenumbers: axesAttrs.autotypenumbers,\n autorange: {\n valType: 'enumerated',\n values: [true, false, 'reversed'],\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether or not the range of this axis is',\n 'computed in relation to the input data.',\n 'See `rangemode` for more info.',\n 'If `range` is provided, then `autorange` is set to *false*.'\n ].join(' ')\n },\n rangemode: {\n valType: 'enumerated',\n values: ['normal', 'tozero', 'nonnegative'],\n dflt: 'normal',\n editType: 'calc',\n description: [\n 'If *normal*, the range is computed in relation to the extrema',\n 'of the input data.',\n 'If *tozero*`, the range extends to 0,',\n 'regardless of the input data',\n 'If *nonnegative*, the range is non-negative,',\n 'regardless of the input data.'\n ].join(' ')\n },\n range: {\n valType: 'info_array',\n editType: 'calc',\n items: [\n {valType: 'any', editType: 'calc'},\n {valType: 'any', editType: 'calc'}\n ],\n description: [\n 'Sets the range of this axis.',\n 'If the axis `type` is *log*, then you must take the log of your',\n 'desired range (e.g. to set the range from 1 to 100,',\n 'set the range from 0 to 2).',\n 'If the axis `type` is *date*, it should be date strings,',\n 'like date data, though Date objects and unix milliseconds',\n 'will be accepted and converted to strings.',\n 'If the axis `type` is *category*, it should be numbers,',\n 'using the scale where each category is assigned a serial',\n 'number from zero in the order it appears.'\n ].join(' ')\n },\n\n fixedrange: {\n valType: 'boolean',\n dflt: false,\n editType: 'calc',\n description: [\n 'Determines whether or not this axis is zoom-able.',\n 'If true, then zoom is disabled.'\n ].join(' ')\n },\n cheatertype: {\n valType: 'enumerated',\n values: ['index', 'value'],\n dflt: 'value',\n editType: 'calc'\n },\n tickmode: {\n valType: 'enumerated',\n values: ['linear', 'array'],\n dflt: 'array',\n editType: 'calc'\n },\n nticks: {\n valType: 'integer',\n min: 0,\n dflt: 0,\n editType: 'calc',\n description: [\n 'Specifies the maximum number of ticks for the particular axis.',\n 'The actual number of ticks will be chosen automatically to be',\n 'less than or equal to `nticks`.',\n 'Has an effect only if `tickmode` is set to *auto*.'\n ].join(' ')\n },\n tickvals: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the values at which ticks on this axis appear.',\n 'Only has an effect if `tickmode` is set to *array*.',\n 'Used with `ticktext`.'\n ].join(' ')\n },\n ticktext: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the text displayed at the ticks position via `tickvals`.',\n 'Only has an effect if `tickmode` is set to *array*.',\n 'Used with `tickvals`.'\n ].join(' ')\n },\n showticklabels: {\n valType: 'enumerated',\n values: ['start', 'end', 'both', 'none'],\n dflt: 'start',\n editType: 'calc',\n description: [\n 'Determines whether axis labels are drawn on the low side,',\n 'the high side, both, or neither side of the axis.'\n ].join(' ')\n },\n labelalias: extendFlat({}, axesAttrs.labelalias, {editType: 'calc'}),\n tickfont: fontAttrs({\n editType: 'calc',\n description: 'Sets the tick font.'\n }),\n tickangle: {\n valType: 'angle',\n dflt: 'auto',\n editType: 'calc',\n description: [\n 'Sets the angle of the tick labels with respect to the horizontal.',\n 'For example, a `tickangle` of -90 draws the tick labels',\n 'vertically.'\n ].join(' ')\n },\n tickprefix: {\n valType: 'string',\n dflt: '',\n editType: 'calc',\n description: 'Sets a tick label prefix.'\n },\n showtickprefix: {\n valType: 'enumerated',\n values: ['all', 'first', 'last', 'none'],\n dflt: 'all',\n editType: 'calc',\n description: [\n 'If *all*, all tick labels are displayed with a prefix.',\n 'If *first*, only the first tick is displayed with a prefix.',\n 'If *last*, only the last tick is displayed with a suffix.',\n 'If *none*, tick prefixes are hidden.'\n ].join(' ')\n },\n ticksuffix: {\n valType: 'string',\n dflt: '',\n editType: 'calc',\n description: 'Sets a tick label suffix.'\n },\n showticksuffix: {\n valType: 'enumerated',\n values: ['all', 'first', 'last', 'none'],\n dflt: 'all',\n editType: 'calc',\n description: 'Same as `showtickprefix` but for tick suffixes.'\n },\n showexponent: {\n valType: 'enumerated',\n values: ['all', 'first', 'last', 'none'],\n dflt: 'all',\n editType: 'calc',\n description: [\n 'If *all*, all exponents are shown besides their significands.',\n 'If *first*, only the exponent of the first tick is shown.',\n 'If *last*, only the exponent of the last tick is shown.',\n 'If *none*, no exponents appear.'\n ].join(' ')\n },\n exponentformat: {\n valType: 'enumerated',\n values: ['none', 'e', 'E', 'power', 'SI', 'B'],\n dflt: 'B',\n editType: 'calc',\n description: [\n 'Determines a formatting rule for the tick exponents.',\n 'For example, consider the number 1,000,000,000.',\n 'If *none*, it appears as 1,000,000,000.',\n 'If *e*, 1e+9.',\n 'If *E*, 1E+9.',\n 'If *power*, 1x10^9 (with 9 in a super script).',\n 'If *SI*, 1G.',\n 'If *B*, 1B.'\n ].join(' ')\n },\n minexponent: {\n valType: 'number',\n dflt: 3,\n min: 0,\n editType: 'calc',\n description: [\n 'Hide SI prefix for 10^n if |n| is below this number'\n ].join(' ')\n },\n separatethousands: {\n valType: 'boolean',\n dflt: false,\n editType: 'calc',\n description: [\n 'If \"true\", even 4-digit integers are separated'\n ].join(' ')\n },\n tickformat: {\n valType: 'string',\n dflt: '',\n editType: 'calc',\n description: descriptionWithDates('tick label')\n },\n tickformatstops: overrideAll(axesAttrs.tickformatstops, 'calc', 'from-root'),\n categoryorder: {\n valType: 'enumerated',\n values: [\n 'trace', 'category ascending', 'category descending', 'array'\n /* , 'value ascending', 'value descending'*/ // value ascending / descending to be implemented later\n ],\n dflt: 'trace',\n editType: 'calc',\n description: [\n 'Specifies the ordering logic for the case of categorical variables.',\n 'By default, plotly uses *trace*, which specifies the order that is present in the data supplied.',\n 'Set `categoryorder` to *category ascending* or *category descending* if order should be determined by',\n 'the alphanumerical order of the category names.',\n /* 'Set `categoryorder` to *value ascending* or *value descending* if order should be determined by the',\n 'numerical order of the values.',*/ // // value ascending / descending to be implemented later\n 'Set `categoryorder` to *array* to derive the ordering from the attribute `categoryarray`. If a category',\n 'is not found in the `categoryarray` array, the sorting behavior for that attribute will be identical to',\n 'the *trace* mode. The unspecified categories will follow the categories in `categoryarray`.'\n ].join(' ')\n },\n categoryarray: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the order in which categories on this axis appear.',\n 'Only has an effect if `categoryorder` is set to *array*.',\n 'Used with `categoryorder`.'\n ].join(' ')\n },\n labelpadding: {\n valType: 'integer',\n dflt: 10,\n editType: 'calc',\n description: 'Extra padding between label and the axis'\n },\n labelprefix: {\n valType: 'string',\n editType: 'calc',\n description: 'Sets a axis label prefix.'\n },\n labelsuffix: {\n valType: 'string',\n dflt: '',\n editType: 'calc',\n description: 'Sets a axis label suffix.'\n },\n // lines and grids\n showline: {\n valType: 'boolean',\n dflt: false,\n editType: 'calc',\n description: [\n 'Determines whether or not a line bounding this axis is drawn.'\n ].join(' ')\n },\n linecolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n editType: 'calc',\n description: 'Sets the axis line color.'\n },\n linewidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n editType: 'calc',\n description: 'Sets the width (in px) of the axis line.'\n },\n gridcolor: {\n valType: 'color',\n editType: 'calc',\n description: 'Sets the axis line color.'\n },\n gridwidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n editType: 'calc',\n description: 'Sets the width (in px) of the axis line.'\n },\n griddash: extendFlat({}, dash, {editType: 'calc'}),\n showgrid: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether or not grid lines are drawn.',\n 'If *true*, the grid lines are drawn at every tick mark.'\n ].join(' ')\n },\n minorgridcount: {\n valType: 'integer',\n min: 0,\n dflt: 0,\n editType: 'calc',\n description: 'Sets the number of minor grid ticks per major grid tick'\n },\n minorgridwidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n editType: 'calc',\n description: 'Sets the width (in px) of the grid lines.'\n },\n minorgriddash: extendFlat({}, dash, {editType: 'calc'}),\n minorgridcolor: {\n valType: 'color',\n dflt: colorAttrs.lightLine,\n editType: 'calc',\n description: 'Sets the color of the grid lines.'\n },\n startline: {\n valType: 'boolean',\n editType: 'calc',\n description: [\n 'Determines whether or not a line is drawn at along the starting value',\n 'of this axis.',\n 'If *true*, the start line is drawn on top of the grid lines.'\n ].join(' ')\n },\n startlinecolor: {\n valType: 'color',\n editType: 'calc',\n description: 'Sets the line color of the start line.'\n },\n startlinewidth: {\n valType: 'number',\n dflt: 1,\n editType: 'calc',\n description: 'Sets the width (in px) of the start line.'\n },\n endline: {\n valType: 'boolean',\n editType: 'calc',\n description: [\n 'Determines whether or not a line is drawn at along the final value',\n 'of this axis.',\n 'If *true*, the end line is drawn on top of the grid lines.'\n ].join(' ')\n },\n endlinewidth: {\n valType: 'number',\n dflt: 1,\n editType: 'calc',\n description: 'Sets the width (in px) of the end line.'\n },\n endlinecolor: {\n valType: 'color',\n editType: 'calc',\n description: 'Sets the line color of the end line.'\n },\n tick0: {\n valType: 'number',\n min: 0,\n dflt: 0,\n editType: 'calc',\n description: 'The starting index of grid lines along the axis'\n },\n dtick: {\n valType: 'number',\n min: 0,\n dflt: 1,\n editType: 'calc',\n description: 'The stride between grid lines along the axis'\n },\n arraytick0: {\n valType: 'integer',\n min: 0,\n dflt: 0,\n editType: 'calc',\n description: 'The starting index of grid lines along the axis'\n },\n arraydtick: {\n valType: 'integer',\n min: 1,\n dflt: 1,\n editType: 'calc',\n description: 'The stride between grid lines along the axis'\n },\n\n _deprecated: {\n title: {\n valType: 'string',\n editType: 'calc',\n description: [\n 'Deprecated in favor of `title.text`.',\n 'Note that value of `title` is no longer a simple',\n '*string* but a set of sub-attributes.'\n ].join(' ')\n },\n titlefont: fontAttrs({\n editType: 'calc',\n description: 'Deprecated in favor of `title.font`.'\n }),\n titleoffset: {\n valType: 'number',\n dflt: 10,\n editType: 'calc',\n description: 'Deprecated in favor of `title.offset`.'\n }\n },\n\n editType: 'calc'\n};\n","'use strict';\n\nvar carpetAttrs = require('./attributes');\n\nvar addOpacity = require('../../components/color').addOpacity;\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar handleTickValueDefaults = require('../../plots/cartesian/tick_value_defaults');\nvar handleTickLabelDefaults = require('../../plots/cartesian/tick_label_defaults');\nvar handlePrefixSuffixDefaults = require('../../plots/cartesian/prefix_suffix_defaults');\nvar handleCategoryOrderDefaults = require('../../plots/cartesian/category_order_defaults');\nvar setConvert = require('../../plots/cartesian/set_convert');\nvar autoType = require('../../plots/cartesian/axis_autotype');\n\n/**\n * options: object containing:\n *\n * letter: 'a' or 'b'\n * title: name of the axis (ie 'Colorbar') to go in default title\n * name: axis object name (ie 'xaxis') if one should be stored\n * font: the default font to inherit\n * outerTicks: boolean, should ticks default to outside?\n * showGrid: boolean, should gridlines be shown by default?\n * data: the plot data to use in choosing auto type\n * bgColor: the plot background color, to calculate default gridline colors\n */\nmodule.exports = function handleAxisDefaults(containerIn, containerOut, options) {\n var letter = options.letter;\n var font = options.font || {};\n var attributes = carpetAttrs[letter + 'axis'];\n\n function coerce(attr, dflt) {\n return Lib.coerce(containerIn, containerOut, attributes, attr, dflt);\n }\n\n function coerce2(attr, dflt) {\n return Lib.coerce2(containerIn, containerOut, attributes, attr, dflt);\n }\n\n // set up some private properties\n if(options.name) {\n containerOut._name = options.name;\n containerOut._id = options.name;\n }\n\n // now figure out type and do some more initialization\n coerce('autotypenumbers', options.autotypenumbersDflt);\n var axType = coerce('type');\n if(axType === '-') {\n if(options.data) setAutoType(containerOut, options.data);\n\n if(containerOut.type === '-') {\n containerOut.type = 'linear';\n } else {\n // copy autoType back to input axis\n // note that if this object didn't exist\n // in the input layout, we have to put it in\n // this happens in the main supplyDefaults function\n axType = containerIn.type = containerOut.type;\n }\n }\n\n coerce('smoothing');\n coerce('cheatertype');\n\n coerce('showticklabels');\n coerce('labelprefix', letter + ' = ');\n coerce('labelsuffix');\n coerce('showtickprefix');\n coerce('showticksuffix');\n\n coerce('separatethousands');\n coerce('tickformat');\n coerce('exponentformat');\n coerce('minexponent');\n coerce('showexponent');\n coerce('categoryorder');\n\n coerce('tickmode');\n coerce('tickvals');\n coerce('ticktext');\n coerce('tick0');\n coerce('dtick');\n\n if(containerOut.tickmode === 'array') {\n coerce('arraytick0');\n coerce('arraydtick');\n }\n\n coerce('labelpadding');\n\n containerOut._hovertitle = letter;\n\n\n if(axType === 'date') {\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleDefaults');\n handleCalendarDefaults(containerIn, containerOut, 'calendar', options.calendar);\n }\n\n // we need some of the other functions setConvert attaches, but for\n // path finding, override pixel scaling to simple passthrough (identity)\n setConvert(containerOut, options.fullLayout);\n containerOut.c2p = Lib.identity;\n\n var dfltColor = coerce('color', options.dfltColor);\n // if axis.color was provided, use it for fonts too; otherwise,\n // inherit from global font color in case that was provided.\n var dfltFontColor = (dfltColor === containerIn.color) ? dfltColor : font.color;\n\n var title = coerce('title.text');\n if(title) {\n Lib.coerceFont(coerce, 'title.font', font, { overrideDflt: {\n size: Lib.bigFont(font.size),\n color: dfltFontColor\n }});\n coerce('title.offset');\n }\n\n coerce('tickangle');\n\n var autoRange = coerce('autorange', !containerOut.isValidRange(containerIn.range));\n\n if(autoRange) coerce('rangemode');\n\n coerce('range');\n containerOut.cleanRange();\n\n coerce('fixedrange');\n\n handleTickValueDefaults(containerIn, containerOut, coerce, axType);\n handlePrefixSuffixDefaults(containerIn, containerOut, coerce, axType, options);\n handleTickLabelDefaults(containerIn, containerOut, coerce, axType, options);\n handleCategoryOrderDefaults(containerIn, containerOut, coerce, {\n data: options.data,\n dataAttr: letter\n });\n\n var gridColor = coerce2('gridcolor', addOpacity(dfltColor, 0.3));\n var gridWidth = coerce2('gridwidth');\n var gridDash = coerce2('griddash');\n var showGrid = coerce('showgrid');\n\n if(!showGrid) {\n delete containerOut.gridcolor;\n delete containerOut.gridwidth;\n delete containerOut.griddash;\n }\n\n var startLineColor = coerce2('startlinecolor', dfltColor);\n var startLineWidth = coerce2('startlinewidth', gridWidth);\n var showStartLine = coerce('startline', containerOut.showgrid || !!startLineColor || !!startLineWidth);\n\n if(!showStartLine) {\n delete containerOut.startlinecolor;\n delete containerOut.startlinewidth;\n }\n\n var endLineColor = coerce2('endlinecolor', dfltColor);\n var endLineWidth = coerce2('endlinewidth', gridWidth);\n var showEndLine = coerce('endline', containerOut.showgrid || !!endLineColor || !!endLineWidth);\n\n if(!showEndLine) {\n delete containerOut.endlinecolor;\n delete containerOut.endlinewidth;\n }\n\n if(!showGrid) {\n delete containerOut.gridcolor;\n delete containerOut.gridwidth;\n delete containerOut.griddash;\n } else {\n coerce('minorgridcount');\n coerce('minorgridwidth', gridWidth);\n coerce('minorgriddash', gridDash);\n coerce('minorgridcolor', addOpacity(gridColor, 0.06));\n\n if(!containerOut.minorgridcount) {\n delete containerOut.minorgridwidth;\n delete containerOut.minorgriddash;\n delete containerOut.minorgridcolor;\n }\n }\n\n if(containerOut.showticklabels === 'none') {\n delete containerOut.tickfont;\n delete containerOut.tickangle;\n delete containerOut.showexponent;\n delete containerOut.exponentformat;\n delete containerOut.minexponent;\n delete containerOut.tickformat;\n delete containerOut.showticksuffix;\n delete containerOut.showtickprefix;\n }\n\n if(!containerOut.showticksuffix) {\n delete containerOut.ticksuffix;\n }\n\n if(!containerOut.showtickprefix) {\n delete containerOut.tickprefix;\n }\n\n // It needs to be coerced, then something above overrides this deep in the axis code,\n // but no, we *actually* want to coerce this.\n coerce('tickmode');\n\n return containerOut;\n};\n\nfunction setAutoType(ax, data) {\n // new logic: let people specify any type they want,\n // only autotype if type is '-'\n if(ax.type !== '-') return;\n\n var id = ax._id;\n var axLetter = id.charAt(0);\n\n var calAttr = axLetter + 'calendar';\n var calendar = ax[calAttr];\n\n ax.type = autoType(data, calendar, {\n autotypenumbers: ax.autotypenumbers\n });\n}\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\nvar isArray1D = require('../../lib').isArray1D;\nvar cheaterBasis = require('./cheater_basis');\nvar arrayMinmax = require('./array_minmax');\nvar calcGridlines = require('./calc_gridlines');\nvar calcLabels = require('./calc_labels');\nvar calcClipPath = require('./calc_clippath');\nvar clean2dArray = require('../heatmap/clean_2d_array');\nvar smoothFill2dArray = require('./smooth_fill_2d_array');\nvar convertColumnData = require('../heatmap/convert_column_xyz');\nvar setConvert = require('./set_convert');\n\nmodule.exports = function calc(gd, trace) {\n var xa = Axes.getFromId(gd, trace.xaxis);\n var ya = Axes.getFromId(gd, trace.yaxis);\n var aax = trace.aaxis;\n var bax = trace.baxis;\n\n var x = trace.x;\n var y = trace.y;\n var cols = [];\n if(x && isArray1D(x)) cols.push('x');\n if(y && isArray1D(y)) cols.push('y');\n\n if(cols.length) {\n convertColumnData(trace, aax, bax, 'a', 'b', cols);\n }\n\n var a = trace._a = trace._a || trace.a;\n var b = trace._b = trace._b || trace.b;\n x = trace._x || trace.x;\n y = trace._y || trace.y;\n\n var t = {};\n\n if(trace._cheater) {\n var avals = aax.cheatertype === 'index' ? a.length : a;\n var bvals = bax.cheatertype === 'index' ? b.length : b;\n x = cheaterBasis(avals, bvals, trace.cheaterslope);\n }\n\n trace._x = x = clean2dArray(x);\n trace._y = y = clean2dArray(y);\n\n // Fill in any undefined values with elliptic smoothing. This doesn't take\n // into account the spacing of the values. That is, the derivatives should\n // be modified to use a and b values. It's not that hard, but this is already\n // moderate overkill for just filling in missing values.\n smoothFill2dArray(x, a, b);\n smoothFill2dArray(y, a, b);\n\n setConvert(trace);\n\n // create conversion functions that depend on the data\n trace.setScale();\n\n // This is a rather expensive scan. Nothing guarantees monotonicity,\n // so we need to scan through all data to get proper ranges:\n var xrange = arrayMinmax(x);\n var yrange = arrayMinmax(y);\n\n var dx = 0.5 * (xrange[1] - xrange[0]);\n var xc = 0.5 * (xrange[1] + xrange[0]);\n\n var dy = 0.5 * (yrange[1] - yrange[0]);\n var yc = 0.5 * (yrange[1] + yrange[0]);\n\n // Expand the axes to fit the plot, except just grow it by a factor of 1.3\n // because the labels should be taken into account except that's difficult\n // hence 1.3.\n var grow = 1.3;\n xrange = [xc - dx * grow, xc + dx * grow];\n yrange = [yc - dy * grow, yc + dy * grow];\n\n trace._extremes[xa._id] = Axes.findExtremes(xa, xrange, {padded: true});\n trace._extremes[ya._id] = Axes.findExtremes(ya, yrange, {padded: true});\n\n // Enumerate the gridlines, both major and minor, and store them on the trace\n // object:\n calcGridlines(trace, 'a', 'b');\n calcGridlines(trace, 'b', 'a');\n\n // Calculate the text labels for each major gridline and store them on the\n // trace object:\n calcLabels(trace, aax);\n calcLabels(trace, bax);\n\n // Tabulate points for the four segments that bound the axes so that we can\n // map to pixel coordinates in the plot function and create a clip rect:\n t.clipsegments = calcClipPath(trace._xctrl, trace._yctrl, aax, bax);\n\n t.x = x;\n t.y = y;\n t.a = a;\n t.b = b;\n\n return [t];\n};\n","'use strict';\n\nmodule.exports = function makeClipPath(xctrl, yctrl, aax, bax) {\n var i, x, y;\n var segments = [];\n\n var asmoothing = !!aax.smoothing;\n var bsmoothing = !!bax.smoothing;\n var nea1 = xctrl[0].length - 1;\n var neb1 = xctrl.length - 1;\n\n // Along the lower a axis:\n for(i = 0, x = [], y = []; i <= nea1; i++) {\n x[i] = xctrl[0][i];\n y[i] = yctrl[0][i];\n }\n segments.push({x: x, y: y, bicubic: asmoothing});\n\n // Along the upper b axis:\n for(i = 0, x = [], y = []; i <= neb1; i++) {\n x[i] = xctrl[i][nea1];\n y[i] = yctrl[i][nea1];\n }\n segments.push({x: x, y: y, bicubic: bsmoothing});\n\n // Backwards along the upper a axis:\n for(i = nea1, x = [], y = []; i >= 0; i--) {\n x[nea1 - i] = xctrl[neb1][i];\n y[nea1 - i] = yctrl[neb1][i];\n }\n segments.push({x: x, y: y, bicubic: asmoothing});\n\n // Backwards along the lower b axis:\n for(i = neb1, x = [], y = []; i >= 0; i--) {\n x[neb1 - i] = xctrl[i][0];\n y[neb1 - i] = yctrl[i][0];\n }\n segments.push({x: x, y: y, bicubic: bsmoothing});\n\n return segments;\n};\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nmodule.exports = function calcGridlines(trace, axisLetter, crossAxisLetter) {\n var i, j, j0;\n var eps, bounds, n1, n2, n, value, v;\n var j1, v0, v1, d;\n\n var data = trace['_' + axisLetter];\n var axis = trace[axisLetter + 'axis'];\n\n var gridlines = axis._gridlines = [];\n var minorgridlines = axis._minorgridlines = [];\n var boundarylines = axis._boundarylines = [];\n\n var crossData = trace['_' + crossAxisLetter];\n var crossAxis = trace[crossAxisLetter + 'axis'];\n\n if(axis.tickmode === 'array') {\n axis.tickvals = data.slice();\n }\n\n var xcp = trace._xctrl;\n var ycp = trace._yctrl;\n var nea = xcp[0].length;\n var neb = xcp.length;\n var na = trace._a.length;\n var nb = trace._b.length;\n\n Axes.prepTicks(axis);\n\n // don't leave tickvals in axis looking like an attribute\n if(axis.tickmode === 'array') delete axis.tickvals;\n\n // The default is an empty array that will cause the join to remove the gridline if\n // it's just disappeared:\n // axis._startline = axis._endline = [];\n\n // If the cross axis uses bicubic interpolation, then the grid\n // lines fall once every three expanded grid row/cols:\n var stride = axis.smoothing ? 3 : 1;\n\n function constructValueGridline(value) {\n var i, j, j0, tj, pxy, i0, ti, xy, dxydi0, dxydi1, dxydj0, dxydj1;\n var xpoints = [];\n var ypoints = [];\n var ret = {};\n // Search for the fractional grid index giving this line:\n if(axisLetter === 'b') {\n // For the position we use just the i-j coordinates:\n j = trace.b2j(value);\n\n // The derivatives for catmull-rom splines are discontinuous across cell\n // boundaries though, so we need to provide both the cell and the position\n // within the cell separately:\n j0 = Math.floor(Math.max(0, Math.min(nb - 2, j)));\n tj = j - j0;\n\n ret.length = nb;\n ret.crossLength = na;\n\n ret.xy = function(i) {\n return trace.evalxy([], i, j);\n };\n\n ret.dxy = function(i0, ti) {\n return trace.dxydi([], i0, j0, ti, tj);\n };\n\n for(i = 0; i < na; i++) {\n i0 = Math.min(na - 2, i);\n ti = i - i0;\n xy = trace.evalxy([], i, j);\n\n if(crossAxis.smoothing && i > 0) {\n // First control point:\n dxydi0 = trace.dxydi([], i - 1, j0, 0, tj);\n xpoints.push(pxy[0] + dxydi0[0] / 3);\n ypoints.push(pxy[1] + dxydi0[1] / 3);\n\n // Second control point:\n dxydi1 = trace.dxydi([], i - 1, j0, 1, tj);\n xpoints.push(xy[0] - dxydi1[0] / 3);\n ypoints.push(xy[1] - dxydi1[1] / 3);\n }\n\n xpoints.push(xy[0]);\n ypoints.push(xy[1]);\n\n pxy = xy;\n }\n } else {\n i = trace.a2i(value);\n i0 = Math.floor(Math.max(0, Math.min(na - 2, i)));\n ti = i - i0;\n\n ret.length = na;\n ret.crossLength = nb;\n\n ret.xy = function(j) {\n return trace.evalxy([], i, j);\n };\n\n ret.dxy = function(j0, tj) {\n return trace.dxydj([], i0, j0, ti, tj);\n };\n\n for(j = 0; j < nb; j++) {\n j0 = Math.min(nb - 2, j);\n tj = j - j0;\n xy = trace.evalxy([], i, j);\n\n if(crossAxis.smoothing && j > 0) {\n // First control point:\n dxydj0 = trace.dxydj([], i0, j - 1, ti, 0);\n xpoints.push(pxy[0] + dxydj0[0] / 3);\n ypoints.push(pxy[1] + dxydj0[1] / 3);\n\n // Second control point:\n dxydj1 = trace.dxydj([], i0, j - 1, ti, 1);\n xpoints.push(xy[0] - dxydj1[0] / 3);\n ypoints.push(xy[1] - dxydj1[1] / 3);\n }\n\n xpoints.push(xy[0]);\n ypoints.push(xy[1]);\n\n pxy = xy;\n }\n }\n\n ret.axisLetter = axisLetter;\n ret.axis = axis;\n ret.crossAxis = crossAxis;\n ret.value = value;\n ret.constvar = crossAxisLetter;\n ret.index = n;\n ret.x = xpoints;\n ret.y = ypoints;\n ret.smoothing = crossAxis.smoothing;\n\n return ret;\n }\n\n function constructArrayGridline(idx) {\n var j, i0, j0, ti, tj;\n var xpoints = [];\n var ypoints = [];\n var ret = {};\n ret.length = data.length;\n ret.crossLength = crossData.length;\n\n if(axisLetter === 'b') {\n j0 = Math.max(0, Math.min(nb - 2, idx));\n tj = Math.min(1, Math.max(0, idx - j0));\n\n ret.xy = function(i) {\n return trace.evalxy([], i, idx);\n };\n\n ret.dxy = function(i0, ti) {\n return trace.dxydi([], i0, j0, ti, tj);\n };\n\n // In the tickmode: array case, this operation is a simple\n // transfer of data:\n for(j = 0; j < nea; j++) {\n xpoints[j] = xcp[idx * stride][j];\n ypoints[j] = ycp[idx * stride][j];\n }\n } else {\n i0 = Math.max(0, Math.min(na - 2, idx));\n ti = Math.min(1, Math.max(0, idx - i0));\n\n ret.xy = function(j) {\n return trace.evalxy([], idx, j);\n };\n\n ret.dxy = function(j0, tj) {\n return trace.dxydj([], i0, j0, ti, tj);\n };\n\n // In the tickmode: array case, this operation is a simple\n // transfer of data:\n for(j = 0; j < neb; j++) {\n xpoints[j] = xcp[j][idx * stride];\n ypoints[j] = ycp[j][idx * stride];\n }\n }\n\n ret.axisLetter = axisLetter;\n ret.axis = axis;\n ret.crossAxis = crossAxis;\n ret.value = data[idx];\n ret.constvar = crossAxisLetter;\n ret.index = idx;\n ret.x = xpoints;\n ret.y = ypoints;\n ret.smoothing = crossAxis.smoothing;\n\n return ret;\n }\n\n if(axis.tickmode === 'array') {\n // var j0 = axis.startline ? 1 : 0;\n // var j1 = data.length - (axis.endline ? 1 : 0);\n\n eps = 5e-15;\n bounds = [\n Math.floor(((data.length - 1) - axis.arraytick0) / axis.arraydtick * (1 + eps)),\n Math.ceil((- axis.arraytick0) / axis.arraydtick / (1 + eps))\n ].sort(function(a, b) {return a - b;});\n\n // Unpack sorted values so we can be sure to avoid infinite loops if something\n // is backwards:\n n1 = bounds[0] - 1;\n n2 = bounds[1] + 1;\n\n // If the axes fall along array lines, then this is a much simpler process since\n // we already have all the control points we need\n for(n = n1; n < n2; n++) {\n j = axis.arraytick0 + axis.arraydtick * n;\n if(j < 0 || j > data.length - 1) continue;\n gridlines.push(extendFlat(constructArrayGridline(j), {\n color: axis.gridcolor,\n width: axis.gridwidth,\n dash: axis.griddash\n }));\n }\n\n for(n = n1; n < n2; n++) {\n j0 = axis.arraytick0 + axis.arraydtick * n;\n j1 = Math.min(j0 + axis.arraydtick, data.length - 1);\n\n // TODO: fix the bounds computation so we don't have to do a large range and then throw\n // out unneeded numbers\n if(j0 < 0 || j0 > data.length - 1) continue;\n if(j1 < 0 || j1 > data.length - 1) continue;\n\n v0 = data[j0];\n v1 = data[j1];\n\n for(i = 0; i < axis.minorgridcount; i++) {\n d = j1 - j0;\n\n // TODO: fix the bounds computation so we don't have to do a large range and then throw\n // out unneeded numbers\n if(d <= 0) continue;\n\n // XXX: This calculation isn't quite right. Off by one somewhere?\n v = v0 + (v1 - v0) * (i + 1) / (axis.minorgridcount + 1) * (axis.arraydtick / d);\n\n // TODO: fix the bounds computation so we don't have to do a large range and then throw\n // out unneeded numbers\n if(v < data[0] || v > data[data.length - 1]) continue;\n minorgridlines.push(extendFlat(constructValueGridline(v), {\n color: axis.minorgridcolor,\n width: axis.minorgridwidth,\n dash: axis.minorgriddash\n }));\n }\n }\n\n if(axis.startline) {\n boundarylines.push(extendFlat(constructArrayGridline(0), {\n color: axis.startlinecolor,\n width: axis.startlinewidth\n }));\n }\n\n if(axis.endline) {\n boundarylines.push(extendFlat(constructArrayGridline(data.length - 1), {\n color: axis.endlinecolor,\n width: axis.endlinewidth\n }));\n }\n } else {\n // If the lines do not fall along the axes, then we have to interpolate\n // the contro points and so some math to figure out where the lines are\n // in the first place.\n\n // Compute the integer boudns of tick0 + n * dtick that fall within the range\n // (roughly speaking):\n // Give this a nice generous epsilon. We use at as * (1 + eps) in order to make\n // inequalities a little tolerant in a more or less correct manner:\n eps = 5e-15;\n bounds = [\n Math.floor((data[data.length - 1] - axis.tick0) / axis.dtick * (1 + eps)),\n Math.ceil((data[0] - axis.tick0) / axis.dtick / (1 + eps))\n ].sort(function(a, b) {return a - b;});\n\n // Unpack sorted values so we can be sure to avoid infinite loops if something\n // is backwards:\n n1 = bounds[0];\n n2 = bounds[1];\n\n for(n = n1; n <= n2; n++) {\n value = axis.tick0 + axis.dtick * n;\n\n gridlines.push(extendFlat(constructValueGridline(value), {\n color: axis.gridcolor,\n width: axis.gridwidth,\n dash: axis.griddash\n }));\n }\n\n for(n = n1 - 1; n < n2 + 1; n++) {\n value = axis.tick0 + axis.dtick * n;\n\n for(i = 0; i < axis.minorgridcount; i++) {\n v = value + axis.dtick * (i + 1) / (axis.minorgridcount + 1);\n if(v < data[0] || v > data[data.length - 1]) continue;\n minorgridlines.push(extendFlat(constructValueGridline(v), {\n color: axis.minorgridcolor,\n width: axis.minorgridwidth,\n dash: axis.minorgriddash\n }));\n }\n }\n\n if(axis.startline) {\n boundarylines.push(extendFlat(constructValueGridline(data[0]), {\n color: axis.startlinecolor,\n width: axis.startlinewidth\n }));\n }\n\n if(axis.endline) {\n boundarylines.push(extendFlat(constructValueGridline(data[data.length - 1]), {\n color: axis.endlinecolor,\n width: axis.endlinewidth\n }));\n }\n }\n};\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nmodule.exports = function calcLabels(trace, axis) {\n var i, tobj, prefix, suffix, gridline;\n\n var labels = axis._labels = [];\n var gridlines = axis._gridlines;\n\n for(i = 0; i < gridlines.length; i++) {\n gridline = gridlines[i];\n\n if(['start', 'both'].indexOf(axis.showticklabels) !== -1) {\n tobj = Axes.tickText(axis, gridline.value);\n\n extendFlat(tobj, {\n prefix: prefix,\n suffix: suffix,\n endAnchor: true,\n xy: gridline.xy(0),\n dxy: gridline.dxy(0, 0),\n axis: gridline.axis,\n length: gridline.crossAxis.length,\n font: gridline.axis.tickfont,\n isFirst: i === 0,\n isLast: i === gridlines.length - 1\n });\n\n labels.push(tobj);\n }\n\n if(['end', 'both'].indexOf(axis.showticklabels) !== -1) {\n tobj = Axes.tickText(axis, gridline.value);\n\n extendFlat(tobj, {\n endAnchor: false,\n xy: gridline.xy(gridline.crossLength - 1),\n dxy: gridline.dxy(gridline.crossLength - 2, 1),\n axis: gridline.axis,\n length: gridline.crossAxis.length,\n font: gridline.axis.tickfont,\n isFirst: i === 0,\n isLast: i === gridlines.length - 1\n });\n\n labels.push(tobj);\n }\n }\n};\n","'use strict';\n\n/*\n * Compute the tangent vector according to catmull-rom cubic splines (centripetal,\n * I think). That differs from the control point in two ways:\n * 1. It is a vector, not a position relative to the point\n * 2. the vector is longer than the position relative to p1 by a factor of 3\n *\n * Close to the boundaries, we'll use these as *quadratic control points, so that\n * to make a nice grid, we'll need to divide the tangent by 2 instead of 3. (The\n * math works out this way if you work through the bezier derivatives)\n */\nvar CatmullRomExp = 0.5;\nmodule.exports = function makeControlPoints(p0, p1, p2, smoothness) {\n var d1x = p0[0] - p1[0];\n var d1y = p0[1] - p1[1];\n var d2x = p2[0] - p1[0];\n var d2y = p2[1] - p1[1];\n var d1a = Math.pow(d1x * d1x + d1y * d1y, CatmullRomExp / 2);\n var d2a = Math.pow(d2x * d2x + d2y * d2y, CatmullRomExp / 2);\n var numx = (d2a * d2a * d1x - d1a * d1a * d2x) * smoothness;\n var numy = (d2a * d2a * d1y - d1a * d1a * d2y) * smoothness;\n var denom1 = d2a * (d1a + d2a) * 3;\n var denom2 = d1a * (d1a + d2a) * 3;\n\n return [[\n p1[0] + (denom1 && numx / denom1),\n p1[1] + (denom1 && numy / denom1)\n ], [\n p1[0] - (denom2 && numx / denom2),\n p1[1] - (denom2 && numy / denom2)\n ]];\n};\n","'use strict';\n\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\n\n/*\n * Construct a 2D array of cheater values given a, b, and a slope.\n * If\n */\nmodule.exports = function(a, b, cheaterslope) {\n var i, j, ascal, bscal, aval, bval;\n var data = [];\n\n var na = isArrayOrTypedArray(a) ? a.length : a;\n var nb = isArrayOrTypedArray(b) ? b.length : b;\n var adata = isArrayOrTypedArray(a) ? a : null;\n var bdata = isArrayOrTypedArray(b) ? b : null;\n\n // If we're using data, scale it so that for data that's just barely\n // not evenly spaced, the switch to value-based indexing is continuous.\n // This means evenly spaced data should look the same whether value\n // or index cheatertype.\n if(adata) {\n ascal = (adata.length - 1) / (adata[adata.length - 1] - adata[0]) / (na - 1);\n }\n\n if(bdata) {\n bscal = (bdata.length - 1) / (bdata[bdata.length - 1] - bdata[0]) / (nb - 1);\n }\n\n var xval;\n var xmin = Infinity;\n var xmax = -Infinity;\n for(j = 0; j < nb; j++) {\n data[j] = [];\n bval = bdata ? (bdata[j] - bdata[0]) * bscal : j / (nb - 1);\n for(i = 0; i < na; i++) {\n aval = adata ? (adata[i] - adata[0]) * ascal : i / (na - 1);\n xval = aval - bval * cheaterslope;\n xmin = Math.min(xval, xmin);\n xmax = Math.max(xval, xmax);\n data[j][i] = xval;\n }\n }\n\n // Normalize cheater values to the 0-1 range. This comes into play when you have\n // multiple cheater plots. After careful consideration, it seems better if cheater\n // values are normalized to a consistent range. Otherwise one cheater affects the\n // layout of other cheaters on the same axis.\n var slope = 1.0 / (xmax - xmin);\n var offset = -xmin * slope;\n for(j = 0; j < nb; j++) {\n for(i = 0; i < na; i++) {\n data[j][i] = slope * data[j][i] + offset;\n }\n }\n\n return data;\n};\n","'use strict';\n\nvar makeControlPoints = require('./catmull_rom');\nvar ensureArray = require('../../lib').ensureArray;\n\n/*\n * Turns a coarse grid into a fine grid with control points.\n *\n * Here's an ASCII representation:\n *\n * o ----- o ----- o ----- o\n * | | | |\n * | | | |\n * | | | |\n * o ----- o ----- o ----- o\n * | | | |\n * | | | |\n * ^ | | | |\n * | o ----- o ----- o ----- o\n * b | | | | |\n * | | | | |\n * | | | | |\n * o ----- o ----- o ----- o\n * ------>\n * a\n *\n * First of all, note that we want to do this in *cartesian* space. This means\n * we might run into problems when there are extreme differences in x/y scaling,\n * but the alternative is that the topology of the contours might actually be\n * view-dependent, which seems worse. As a fallback, the only parameter that\n * actually affects the result is the *aspect ratio*, so that we can at least\n * improve the situation a bit without going all the way to screen coordinates.\n *\n * This function flattens the points + tangents into a slightly denser grid of\n * *control points*. The resulting grid looks like this:\n *\n * 9 +--o-o--+ -o-o--+--o-o--+\n * 8 o o o o o o o o o o\n * | | | |\n * 7 o o o o o o o o o o\n * 6 +--o-o--+ -o-o--+--o-o--+\n * 5 o o o o o o o o o o\n * | | | |\n * ^ 4 o o o o o o o o o o\n * | 3 +--o-o--+ -o-o--+--o-o--+\n * b | 2 o o o o o o o o o o\n * | | | | |\n * | 1 o o o o o o o o o o\n * 0 +--o-o--+ -o-o--+--o-o--+\n * 0 1 2 3 4 5 6 7 8 9\n * ------>\n * a\n *\n * where `o`s represent newly-computed control points. the resulting dimension is\n *\n * (m - 1) * 3 + 1\n * = 3 * m - 2\n *\n * We could simply store the tangents separately, but that's a nightmare to organize\n * in two dimensions since we'll be slicing grid lines in both directions and since\n * that basically requires very nearly just as much storage as just storing the dense\n * grid.\n *\n * Wow!\n */\n\n\n/*\n * Catmull-rom is biased at the boundaries toward the interior and we actually\n * can't use catmull-rom to compute the control point closest to (but inside)\n * the boundary.\n *\n * A note on plotly's spline interpolation. It uses the catmull rom control point\n * closest to the boundary *as* a quadratic control point. This seems incorrect,\n * so I've elected not to follow that. Given control points 0 and 1, regular plotly\n * splines give *equivalent* cubic control points:\n *\n * Input:\n *\n * boundary\n * | |\n * p0 p2 p3 --> interior\n * 0.0 0.667 1.0\n * | |\n *\n * Cubic-equivalent of what plotly splines draw::\n *\n * boundary\n * | |\n * p0 p1 p2 p3 --> interior\n * 0.0 0.4444 0.8888 1.0\n * | |\n *\n * What this function fills in:\n *\n * boundary\n * | |\n * p0 p1 p2 p3 --> interior\n * 0.0 0.333 0.667 1.0\n * | |\n *\n * Parameters:\n * p0: boundary point\n * p2: catmull rom point based on computation at p3\n * p3: first grid point\n *\n * Of course it works whichever way it's oriented; you just need to interpret the\n * input/output accordingly.\n */\nfunction inferCubicControlPoint(p0, p2, p3) {\n // Extend p1 away from p0 by 50%. This is the equivalent quadratic point that\n // would give the same slope as catmull rom at p0.\n var p2e0 = -0.5 * p3[0] + 1.5 * p2[0];\n var p2e1 = -0.5 * p3[1] + 1.5 * p2[1];\n\n return [\n (2 * p2e0 + p0[0]) / 3,\n (2 * p2e1 + p0[1]) / 3,\n ];\n}\n\nmodule.exports = function computeControlPoints(xe, ye, x, y, asmoothing, bsmoothing) {\n var i, j, ie, je, xej, yej, xj, yj, cp, p1;\n // At this point, we know these dimensions are correct and representative of\n // the whole 2D arrays:\n var na = x[0].length;\n var nb = x.length;\n\n // (n)umber of (e)xpanded points:\n var nea = asmoothing ? 3 * na - 2 : na;\n var neb = bsmoothing ? 3 * nb - 2 : nb;\n\n xe = ensureArray(xe, neb);\n ye = ensureArray(ye, neb);\n\n for(ie = 0; ie < neb; ie++) {\n xe[ie] = ensureArray(xe[ie], nea);\n ye[ie] = ensureArray(ye[ie], nea);\n }\n\n // This loop fills in the X'd points:\n //\n // . . . .\n // . . . .\n // | | | |\n // | | | |\n // X ----- X ----- X ----- X\n // | | | |\n // | | | |\n // | | | |\n // X ----- X ----- X ----- X\n //\n //\n // ie = (i) (e)xpanded:\n for(j = 0, je = 0; j < nb; j++, je += bsmoothing ? 3 : 1) {\n xej = xe[je];\n yej = ye[je];\n xj = x[j];\n yj = y[j];\n\n // je = (j) (e)xpanded:\n for(i = 0, ie = 0; i < na; i++, ie += asmoothing ? 3 : 1) {\n xej[ie] = xj[i];\n yej[ie] = yj[i];\n }\n }\n\n if(asmoothing) {\n // If there's a-smoothing, this loop fills in the X'd points with catmull-rom\n // control points computed along the a-axis:\n // . . . .\n // . . . .\n // | | | |\n // | | | |\n // o -Y-X- o -X-X- o -X-Y- o\n // | | | |\n // | | | |\n // | | | |\n // o -Y-X- o -X-X- o -X-Y- o\n //\n // i: 0 1 2 3\n // ie: 0 1 3 3 4 5 6 7 8 9\n //\n // ------>\n // a\n //\n for(j = 0, je = 0; j < nb; j++, je += bsmoothing ? 3 : 1) {\n // Fill in the points marked X for this a-row:\n for(i = 1, ie = 3; i < na - 1; i++, ie += 3) {\n cp = makeControlPoints(\n [x[j][i - 1], y[j][i - 1]],\n [x[j][i ], y[j][i]],\n [x[j][i + 1], y[j][i + 1]],\n asmoothing\n );\n\n xe[je][ie - 1] = cp[0][0];\n ye[je][ie - 1] = cp[0][1];\n xe[je][ie + 1] = cp[1][0];\n ye[je][ie + 1] = cp[1][1];\n }\n\n // The very first cubic interpolation point (to the left for i = 1 above) is\n // used as a *quadratic* interpolation point by the spline drawing function\n // which isn't really correct. But for the sake of consistency, we'll use it\n // as such. Since we're using cubic splines, that means we need to shorten the\n // tangent by 1/3 and also construct a new cubic spline control point 1/3 from\n // the original to the i = 0 point.\n p1 = inferCubicControlPoint(\n [xe[je][0], ye[je][0]],\n [xe[je][2], ye[je][2]],\n [xe[je][3], ye[je][3]]\n );\n xe[je][1] = p1[0];\n ye[je][1] = p1[1];\n\n // Ditto last points, sans explanation:\n p1 = inferCubicControlPoint(\n [xe[je][nea - 1], ye[je][nea - 1]],\n [xe[je][nea - 3], ye[je][nea - 3]],\n [xe[je][nea - 4], ye[je][nea - 4]]\n );\n xe[je][nea - 2] = p1[0];\n ye[je][nea - 2] = p1[1];\n }\n }\n\n if(bsmoothing) {\n // If there's a-smoothing, this loop fills in the X'd points with catmull-rom\n // control points computed along the b-axis:\n // . . . .\n // X X X X X X X X X X\n // | | | |\n // X X X X X X X X X X\n // o -o-o- o -o-o- o -o-o- o\n // X X X X X X X X X X\n // | | | |\n // Y Y Y Y Y Y Y Y Y Y\n // o -o-o- o -o-o- o -o-o- o\n //\n // i: 0 1 2 3\n // ie: 0 1 3 3 4 5 6 7 8 9\n //\n // ------>\n // a\n //\n for(ie = 0; ie < nea; ie++) {\n for(je = 3; je < neb - 3; je += 3) {\n cp = makeControlPoints(\n [xe[je - 3][ie], ye[je - 3][ie]],\n [xe[je][ie], ye[je][ie]],\n [xe[je + 3][ie], ye[je + 3][ie]],\n bsmoothing\n );\n\n xe[je - 1][ie] = cp[0][0];\n ye[je - 1][ie] = cp[0][1];\n xe[je + 1][ie] = cp[1][0];\n ye[je + 1][ie] = cp[1][1];\n }\n // Do the same boundary condition magic for these control points marked Y above:\n p1 = inferCubicControlPoint(\n [xe[0][ie], ye[0][ie]],\n [xe[2][ie], ye[2][ie]],\n [xe[3][ie], ye[3][ie]]\n );\n xe[1][ie] = p1[0];\n ye[1][ie] = p1[1];\n\n p1 = inferCubicControlPoint(\n [xe[neb - 1][ie], ye[neb - 1][ie]],\n [xe[neb - 3][ie], ye[neb - 3][ie]],\n [xe[neb - 4][ie], ye[neb - 4][ie]]\n );\n xe[neb - 2][ie] = p1[0];\n ye[neb - 2][ie] = p1[1];\n }\n }\n\n if(asmoothing && bsmoothing) {\n // Do one more pass, this time recomputing exactly what we just computed.\n // It's overdetermined since we're peforming catmull-rom in two directions,\n // so we'll just average the overdetermined. These points don't lie along the\n // grid lines, so note that only grid lines will follow normal plotly spline\n // interpolation.\n //\n // Unless of course there was no b smoothing. Then these intermediate points\n // don't actually exist and this section is bypassed.\n // . . . .\n // o X X o X X o X X o\n // | | | |\n // o X X o X X o X X o\n // o -o-o- o -o-o- o -o-o- o\n // o X X o X X o X X o\n // | | | |\n // o Y Y o Y Y o Y Y o\n // o -o-o- o -o-o- o -o-o- o\n //\n // i: 0 1 2 3\n // ie: 0 1 3 3 4 5 6 7 8 9\n //\n // ------>\n // a\n //\n for(je = 1; je < neb; je += (je + 1) % 3 === 0 ? 2 : 1) {\n // Fill in the points marked X for this a-row:\n for(ie = 3; ie < nea - 3; ie += 3) {\n cp = makeControlPoints(\n [xe[je][ie - 3], ye[je][ie - 3]],\n [xe[je][ie], ye[je][ie]],\n [xe[je][ie + 3], ye[je][ie + 3]],\n asmoothing\n );\n\n xe[je][ie - 1] = 0.5 * (xe[je][ie - 1] + cp[0][0]);\n ye[je][ie - 1] = 0.5 * (ye[je][ie - 1] + cp[0][1]);\n xe[je][ie + 1] = 0.5 * (xe[je][ie + 1] + cp[1][0]);\n ye[je][ie + 1] = 0.5 * (ye[je][ie + 1] + cp[1][1]);\n }\n\n // This case is just slightly different. The computation is the same,\n // but having computed this, we'll average with the existing result.\n p1 = inferCubicControlPoint(\n [xe[je][0], ye[je][0]],\n [xe[je][2], ye[je][2]],\n [xe[je][3], ye[je][3]]\n );\n xe[je][1] = 0.5 * (xe[je][1] + p1[0]);\n ye[je][1] = 0.5 * (ye[je][1] + p1[1]);\n\n p1 = inferCubicControlPoint(\n [xe[je][nea - 1], ye[je][nea - 1]],\n [xe[je][nea - 3], ye[je][nea - 3]],\n [xe[je][nea - 4], ye[je][nea - 4]]\n );\n xe[je][nea - 2] = 0.5 * (xe[je][nea - 2] + p1[0]);\n ye[je][nea - 2] = 0.5 * (ye[je][nea - 2] + p1[1]);\n }\n }\n\n return [xe, ye];\n};\n","'use strict';\n\nmodule.exports = {\n RELATIVE_CULL_TOLERANCE: 1e-6\n};\n","'use strict';\n\n/*\n * Evaluates the derivative of a list of control point arrays. That is, it expects an array or arrays\n * that are expanded relative to the raw data to include the bicubic control points, if applicable. If\n * only linear interpolation is desired, then the data points correspond 1-1 along that axis to the\n * data itself. Since it's catmull-rom splines in either direction note in particular that the\n * derivatives are discontinuous across cell boundaries. That's the reason you need both the *cell*\n * and the *point within the cell*.\n *\n * Also note that the discontinuity of the derivative is in magnitude only. The direction *is*\n * continuous across cell boundaries.\n *\n * For example, to compute the derivative of the xcoordinate halfway between the 7 and 8th i-gridpoints\n * and the 10th and 11th j-gridpoints given bicubic smoothing in both dimensions, you'd write:\n *\n * var deriv = createIDerivativeEvaluator([x], 1, 1);\n *\n * var dxdi = deriv([], 7, 10, 0.5, 0.5);\n * // => [0.12345]\n *\n * Since there'd be a bunch of duplicate computation to compute multiple derivatives, you can double\n * this up by providing more arrays:\n *\n * var deriv = createIDerivativeEvaluator([x, y], 1, 1);\n *\n * var dxdi = deriv([], 7, 10, 0.5, 0.5);\n * // => [0.12345, 0.78910]\n *\n * NB: It's presumed that at this point all data has been sanitized and is valid numerical data arrays\n * of the correct dimension.\n */\nmodule.exports = function(arrays, asmoothing, bsmoothing) {\n if(asmoothing && bsmoothing) {\n return function(out, i0, j0, u, v) {\n if(!out) out = [];\n var f0, f1, f2, f3, ak, k;\n\n // Since it's a grid of control points, the actual indices are * 3:\n i0 *= 3;\n j0 *= 3;\n\n // Precompute some numbers:\n var u2 = u * u;\n var ou = 1 - u;\n var ou2 = ou * ou;\n var ouu2 = ou * u * 2;\n var a = -3 * ou2;\n var b = 3 * (ou2 - ouu2);\n var c = 3 * (ouu2 - u2);\n var d = 3 * u2;\n\n var v2 = v * v;\n var v3 = v2 * v;\n var ov = 1 - v;\n var ov2 = ov * ov;\n var ov3 = ov2 * ov;\n\n for(k = 0; k < arrays.length; k++) {\n ak = arrays[k];\n // Compute the derivatives in the u-direction:\n f0 = a * ak[j0 ][i0] + b * ak[j0 ][i0 + 1] + c * ak[j0 ][i0 + 2] + d * ak[j0 ][i0 + 3];\n f1 = a * ak[j0 + 1][i0] + b * ak[j0 + 1][i0 + 1] + c * ak[j0 + 1][i0 + 2] + d * ak[j0 + 1][i0 + 3];\n f2 = a * ak[j0 + 2][i0] + b * ak[j0 + 2][i0 + 1] + c * ak[j0 + 2][i0 + 2] + d * ak[j0 + 2][i0 + 3];\n f3 = a * ak[j0 + 3][i0] + b * ak[j0 + 3][i0 + 1] + c * ak[j0 + 3][i0 + 2] + d * ak[j0 + 3][i0 + 3];\n\n // Now just interpolate in the v-direction since it's all separable:\n out[k] = ov3 * f0 + 3 * (ov2 * v * f1 + ov * v2 * f2) + v3 * f3;\n }\n\n return out;\n };\n } else if(asmoothing) {\n // Handle smooth in the a-direction but linear in the b-direction by performing four\n // linear interpolations followed by one cubic interpolation of the result\n return function(out, i0, j0, u, v) {\n if(!out) out = [];\n var f0, f1, k, ak;\n i0 *= 3;\n var u2 = u * u;\n var ou = 1 - u;\n var ou2 = ou * ou;\n var ouu2 = ou * u * 2;\n var a = -3 * ou2;\n var b = 3 * (ou2 - ouu2);\n var c = 3 * (ouu2 - u2);\n var d = 3 * u2;\n var ov = 1 - v;\n for(k = 0; k < arrays.length; k++) {\n ak = arrays[k];\n f0 = a * ak[j0 ][i0] + b * ak[j0 ][i0 + 1] + c * ak[j0 ][i0 + 2] + d * ak[j0 ][i0 + 3];\n f1 = a * ak[j0 + 1][i0] + b * ak[j0 + 1][i0 + 1] + c * ak[j0 + 1][i0 + 2] + d * ak[j0 + 1][i0 + 3];\n\n out[k] = ov * f0 + v * f1;\n }\n return out;\n };\n } else if(bsmoothing) {\n // Same as the above case, except reversed. I've disabled the no-unused vars rule\n // so that this function is fully interpolation-agnostic. Otherwise it would need\n // to be called differently in different cases. Which wouldn't be the worst, but\n /* eslint-disable no-unused-vars */\n return function(out, i0, j0, u, v) {\n /* eslint-enable no-unused-vars */\n if(!out) out = [];\n var f0, f1, f2, f3, k, ak;\n j0 *= 3;\n var v2 = v * v;\n var v3 = v2 * v;\n var ov = 1 - v;\n var ov2 = ov * ov;\n var ov3 = ov2 * ov;\n for(k = 0; k < arrays.length; k++) {\n ak = arrays[k];\n f0 = ak[j0][i0 + 1] - ak[j0][i0];\n f1 = ak[j0 + 1][i0 + 1] - ak[j0 + 1][i0];\n f2 = ak[j0 + 2][i0 + 1] - ak[j0 + 2][i0];\n f3 = ak[j0 + 3][i0 + 1] - ak[j0 + 3][i0];\n\n out[k] = ov3 * f0 + 3 * (ov2 * v * f1 + ov * v2 * f2) + v3 * f3;\n }\n return out;\n };\n } else {\n // Finally, both directions are linear:\n /* eslint-disable no-unused-vars */\n return function(out, i0, j0, u, v) {\n /* eslint-enable no-unused-vars */\n if(!out) out = [];\n var f0, f1, k, ak;\n var ov = 1 - v;\n for(k = 0; k < arrays.length; k++) {\n ak = arrays[k];\n f0 = ak[j0][i0 + 1] - ak[j0][i0];\n f1 = ak[j0 + 1][i0 + 1] - ak[j0 + 1][i0];\n\n out[k] = ov * f0 + v * f1;\n }\n return out;\n };\n }\n};\n","'use strict';\n\nmodule.exports = function(arrays, asmoothing, bsmoothing) {\n if(asmoothing && bsmoothing) {\n return function(out, i0, j0, u, v) {\n if(!out) out = [];\n var f0, f1, f2, f3, ak, k;\n\n // Since it's a grid of control points, the actual indices are * 3:\n i0 *= 3;\n j0 *= 3;\n\n // Precompute some numbers:\n var u2 = u * u;\n var u3 = u2 * u;\n var ou = 1 - u;\n var ou2 = ou * ou;\n var ou3 = ou2 * ou;\n\n var v2 = v * v;\n var ov = 1 - v;\n var ov2 = ov * ov;\n var ovv2 = ov * v * 2;\n var a = -3 * ov2;\n var b = 3 * (ov2 - ovv2);\n var c = 3 * (ovv2 - v2);\n var d = 3 * v2;\n\n for(k = 0; k < arrays.length; k++) {\n ak = arrays[k];\n\n // Compute the derivatives in the v-direction:\n f0 = a * ak[j0][i0] + b * ak[j0 + 1][i0] + c * ak[j0 + 2][i0] + d * ak[j0 + 3][i0];\n f1 = a * ak[j0][i0 + 1] + b * ak[j0 + 1][i0 + 1] + c * ak[j0 + 2][i0 + 1] + d * ak[j0 + 3][i0 + 1];\n f2 = a * ak[j0][i0 + 2] + b * ak[j0 + 1][i0 + 2] + c * ak[j0 + 2][i0 + 2] + d * ak[j0 + 3][i0 + 2];\n f3 = a * ak[j0][i0 + 3] + b * ak[j0 + 1][i0 + 3] + c * ak[j0 + 2][i0 + 3] + d * ak[j0 + 3][i0 + 3];\n\n // Now just interpolate in the v-direction since it's all separable:\n out[k] = ou3 * f0 + 3 * (ou2 * u * f1 + ou * u2 * f2) + u3 * f3;\n }\n\n return out;\n };\n } else if(asmoothing) {\n // Handle smooth in the a-direction but linear in the b-direction by performing four\n // linear interpolations followed by one cubic interpolation of the result\n return function(out, i0, j0, v, u) {\n if(!out) out = [];\n var f0, f1, f2, f3, k, ak;\n i0 *= 3;\n var u2 = u * u;\n var u3 = u2 * u;\n var ou = 1 - u;\n var ou2 = ou * ou;\n var ou3 = ou2 * ou;\n for(k = 0; k < arrays.length; k++) {\n ak = arrays[k];\n\n f0 = ak[j0 + 1][i0] - ak[j0][i0];\n f1 = ak[j0 + 1][i0 + 1] - ak[j0][i0 + 1];\n f2 = ak[j0 + 1][i0 + 2] - ak[j0][i0 + 2];\n f3 = ak[j0 + 1][i0 + 3] - ak[j0][i0 + 3];\n\n out[k] = ou3 * f0 + 3 * (ou2 * u * f1 + ou * u2 * f2) + u3 * f3;\n\n // mathematically equivalent:\n // f0 = ou3 * ak[j0 ][i0] + 3 * (ou2 * u * ak[j0 ][i0 + 1] + ou * u2 * ak[j0 ][i0 + 2]) + u3 * ak[j0 ][i0 + 3];\n // f1 = ou3 * ak[j0 + 1][i0] + 3 * (ou2 * u * ak[j0 + 1][i0 + 1] + ou * u2 * ak[j0 + 1][i0 + 2]) + u3 * ak[j0 + 1][i0 + 3];\n // out[k] = f1 - f0;\n }\n return out;\n };\n } else if(bsmoothing) {\n // Same as the above case, except reversed:\n /* eslint-disable no-unused-vars */\n return function(out, i0, j0, u, v) {\n /* eslint-enable no-unused-vars */\n if(!out) out = [];\n var f0, f1, k, ak;\n j0 *= 3;\n var ou = 1 - u;\n var v2 = v * v;\n var ov = 1 - v;\n var ov2 = ov * ov;\n var ovv2 = ov * v * 2;\n var a = -3 * ov2;\n var b = 3 * (ov2 - ovv2);\n var c = 3 * (ovv2 - v2);\n var d = 3 * v2;\n for(k = 0; k < arrays.length; k++) {\n ak = arrays[k];\n f0 = a * ak[j0][i0] + b * ak[j0 + 1][i0] + c * ak[j0 + 2][i0] + d * ak[j0 + 3][i0];\n f1 = a * ak[j0][i0 + 1] + b * ak[j0 + 1][i0 + 1] + c * ak[j0 + 2][i0 + 1] + d * ak[j0 + 3][i0 + 1];\n\n out[k] = ou * f0 + u * f1;\n }\n return out;\n };\n } else {\n // Finally, both directions are linear:\n /* eslint-disable no-unused-vars */\n return function(out, i0, j0, v, u) {\n /* eslint-enable no-unused-vars */\n if(!out) out = [];\n var f0, f1, k, ak;\n var ov = 1 - v;\n for(k = 0; k < arrays.length; k++) {\n ak = arrays[k];\n f0 = ak[j0 + 1][i0] - ak[j0][i0];\n f1 = ak[j0 + 1][i0 + 1] - ak[j0][i0 + 1];\n\n out[k] = ov * f0 + v * f1;\n }\n return out;\n };\n }\n};\n","'use strict';\n\n/*\n * Return a function that evaluates a set of linear or bicubic control points.\n * This will get evaluated a lot, so we'll at least do a bit of extra work to\n * flatten some of the choices. In particular, we'll unroll the linear/bicubic\n * combinations and we'll allow computing results in parallel to cut down\n * on repeated arithmetic.\n *\n * Take note that we don't search for the correct range in this function. The\n * reason is for consistency due to the corrresponding derivative function. In\n * particular, the derivatives aren't continuous across cells, so it's important\n * to be able control whether the derivative at a cell boundary is approached\n * from one side or the other.\n */\nmodule.exports = function(arrays, na, nb, asmoothing, bsmoothing) {\n var imax = na - 2;\n var jmax = nb - 2;\n\n if(asmoothing && bsmoothing) {\n return function(out, i, j) {\n if(!out) out = [];\n var f0, f1, f2, f3, ak, k;\n\n var i0 = Math.max(0, Math.min(Math.floor(i), imax));\n var j0 = Math.max(0, Math.min(Math.floor(j), jmax));\n var u = Math.max(0, Math.min(1, i - i0));\n var v = Math.max(0, Math.min(1, j - j0));\n\n // Since it's a grid of control points, the actual indices are * 3:\n i0 *= 3;\n j0 *= 3;\n\n // Precompute some numbers:\n var u2 = u * u;\n var u3 = u2 * u;\n var ou = 1 - u;\n var ou2 = ou * ou;\n var ou3 = ou2 * ou;\n\n var v2 = v * v;\n var v3 = v2 * v;\n var ov = 1 - v;\n var ov2 = ov * ov;\n var ov3 = ov2 * ov;\n\n for(k = 0; k < arrays.length; k++) {\n ak = arrays[k];\n f0 = ou3 * ak[j0][i0] + 3 * (ou2 * u * ak[j0][i0 + 1] + ou * u2 * ak[j0][i0 + 2]) + u3 * ak[j0][i0 + 3];\n f1 = ou3 * ak[j0 + 1][i0] + 3 * (ou2 * u * ak[j0 + 1][i0 + 1] + ou * u2 * ak[j0 + 1][i0 + 2]) + u3 * ak[j0 + 1][i0 + 3];\n f2 = ou3 * ak[j0 + 2][i0] + 3 * (ou2 * u * ak[j0 + 2][i0 + 1] + ou * u2 * ak[j0 + 2][i0 + 2]) + u3 * ak[j0 + 2][i0 + 3];\n f3 = ou3 * ak[j0 + 3][i0] + 3 * (ou2 * u * ak[j0 + 3][i0 + 1] + ou * u2 * ak[j0 + 3][i0 + 2]) + u3 * ak[j0 + 3][i0 + 3];\n out[k] = ov3 * f0 + 3 * (ov2 * v * f1 + ov * v2 * f2) + v3 * f3;\n }\n\n return out;\n };\n } else if(asmoothing) {\n // Handle smooth in the a-direction but linear in the b-direction by performing four\n // linear interpolations followed by one cubic interpolation of the result\n return function(out, i, j) {\n if(!out) out = [];\n\n var i0 = Math.max(0, Math.min(Math.floor(i), imax));\n var j0 = Math.max(0, Math.min(Math.floor(j), jmax));\n var u = Math.max(0, Math.min(1, i - i0));\n var v = Math.max(0, Math.min(1, j - j0));\n\n var f0, f1, f2, f3, k, ak;\n i0 *= 3;\n var u2 = u * u;\n var u3 = u2 * u;\n var ou = 1 - u;\n var ou2 = ou * ou;\n var ou3 = ou2 * ou;\n var ov = 1 - v;\n for(k = 0; k < arrays.length; k++) {\n ak = arrays[k];\n f0 = ov * ak[j0][i0] + v * ak[j0 + 1][i0];\n f1 = ov * ak[j0][i0 + 1] + v * ak[j0 + 1][i0 + 1];\n f2 = ov * ak[j0][i0 + 2] + v * ak[j0 + 1][i0 + 1];\n f3 = ov * ak[j0][i0 + 3] + v * ak[j0 + 1][i0 + 1];\n\n out[k] = ou3 * f0 + 3 * (ou2 * u * f1 + ou * u2 * f2) + u3 * f3;\n }\n return out;\n };\n } else if(bsmoothing) {\n // Same as the above case, except reversed:\n return function(out, i, j) {\n if(!out) out = [];\n\n var i0 = Math.max(0, Math.min(Math.floor(i), imax));\n var j0 = Math.max(0, Math.min(Math.floor(j), jmax));\n var u = Math.max(0, Math.min(1, i - i0));\n var v = Math.max(0, Math.min(1, j - j0));\n\n var f0, f1, f2, f3, k, ak;\n j0 *= 3;\n var v2 = v * v;\n var v3 = v2 * v;\n var ov = 1 - v;\n var ov2 = ov * ov;\n var ov3 = ov2 * ov;\n var ou = 1 - u;\n for(k = 0; k < arrays.length; k++) {\n ak = arrays[k];\n f0 = ou * ak[j0][i0] + u * ak[j0][i0 + 1];\n f1 = ou * ak[j0 + 1][i0] + u * ak[j0 + 1][i0 + 1];\n f2 = ou * ak[j0 + 2][i0] + u * ak[j0 + 2][i0 + 1];\n f3 = ou * ak[j0 + 3][i0] + u * ak[j0 + 3][i0 + 1];\n\n out[k] = ov3 * f0 + 3 * (ov2 * v * f1 + ov * v2 * f2) + v3 * f3;\n }\n return out;\n };\n } else {\n // Finally, both directions are linear:\n return function(out, i, j) {\n if(!out) out = [];\n\n var i0 = Math.max(0, Math.min(Math.floor(i), imax));\n var j0 = Math.max(0, Math.min(Math.floor(j), jmax));\n var u = Math.max(0, Math.min(1, i - i0));\n var v = Math.max(0, Math.min(1, j - j0));\n\n var f0, f1, k, ak;\n var ov = 1 - v;\n var ou = 1 - u;\n for(k = 0; k < arrays.length; k++) {\n ak = arrays[k];\n f0 = ou * ak[j0][i0] + u * ak[j0][i0 + 1];\n f1 = ou * ak[j0 + 1][i0] + u * ak[j0 + 1][i0 + 1];\n\n out[k] = ov * f0 + v * f1;\n }\n return out;\n };\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar handleXYDefaults = require('./xy_defaults');\nvar handleABDefaults = require('./ab_defaults');\nvar attributes = require('./attributes');\nvar colorAttrs = require('../../components/color/attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, dfltColor, fullLayout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n traceOut._clipPathId = 'clip' + traceOut.uid + 'carpet';\n\n var defaultColor = coerce('color', colorAttrs.defaultLine);\n Lib.coerceFont(coerce, 'font', fullLayout.font);\n\n coerce('carpet');\n\n handleABDefaults(traceIn, traceOut, fullLayout, coerce, defaultColor);\n\n if(!traceOut.a || !traceOut.b) {\n traceOut.visible = false;\n return;\n }\n\n if(traceOut.a.length < 3) {\n traceOut.aaxis.smoothing = 0;\n }\n\n if(traceOut.b.length < 3) {\n traceOut.baxis.smoothing = 0;\n }\n\n // NB: the input is x/y arrays. You should know that the *first* dimension of x and y\n // corresponds to b and the second to a. This sounds backwards but ends up making sense\n // the important part to know is that when you write y[j][i], j goes from 0 to b.length - 1\n // and i goes from 0 to a.length - 1.\n var validData = handleXYDefaults(traceIn, traceOut, coerce);\n if(!validData) {\n traceOut.visible = false;\n }\n\n if(traceOut._cheater) {\n coerce('cheaterslope');\n }\n coerce('zorder');\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n plot: require('./plot'),\n calc: require('./calc'),\n animatable: true,\n isContainer: true, // so carpet traces get `calc` before other traces\n\n moduleType: 'trace',\n name: 'carpet',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['cartesian', 'svg', 'carpet', 'carpetAxis', 'notLegendIsolatable', 'noMultiCategory', 'noHover', 'noSortingByValue'],\n meta: {\n description: [\n 'The data describing carpet axis layout is set in `y` and (optionally)',\n 'also `x`. If only `y` is present, `x` the plot is interpreted as a',\n 'cheater plot and is filled in using the `y` values.',\n\n '`x` and `y` may either be 2D arrays matching with each dimension matching',\n 'that of `a` and `b`, or they may be 1D arrays with total length equal to',\n 'that of `a` and `b`.'\n ].join(' ')\n }\n};\n","'use strict';\n\n/*\n * Given a trace, look up the carpet axis by carpet.\n */\nmodule.exports = function(gd, trace) {\n var n = gd._fullData.length;\n var firstAxis;\n for(var i = 0; i < n; i++) {\n var maybeCarpet = gd._fullData[i];\n\n if(maybeCarpet.index === trace.index) continue;\n\n if(maybeCarpet.type === 'carpet') {\n if(!firstAxis) {\n firstAxis = maybeCarpet;\n }\n\n if(maybeCarpet.carpet === trace.carpet) {\n return maybeCarpet;\n }\n }\n }\n\n return firstAxis;\n};\n","'use strict';\n\nmodule.exports = function makePath(xp, yp, isBicubic) {\n // Prevent d3 errors that would result otherwise:\n if(xp.length === 0) return '';\n\n var i;\n var path = [];\n var stride = isBicubic ? 3 : 1;\n for(i = 0; i < xp.length; i += stride) {\n path.push(xp[i] + ',' + yp[i]);\n\n if(isBicubic && i < xp.length - stride) {\n path.push('C');\n path.push([\n xp[i + 1] + ',' + yp[i + 1],\n xp[i + 2] + ',' + yp[i + 2] + ' ',\n ].join(' '));\n }\n }\n return path.join(isBicubic ? '' : 'L');\n};\n","'use strict';\n\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\n\n/*\n * Map an array of x or y coordinates (c) to screen-space pixel coordinates (p).\n * The output array is optional, but if provided, it will be reused without\n * reallocation to the extent possible.\n */\nmodule.exports = function mapArray(out, data, func) {\n var i;\n\n if(!isArrayOrTypedArray(out)) {\n // If not an array, make it an array:\n out = [];\n } else if(out.length > data.length) {\n // If too long, truncate. (If too short, it will grow\n // automatically so we don't care about that case)\n out = out.slice(0, data.length);\n }\n\n for(i = 0; i < data.length; i++) {\n out[i] = func(data[i]);\n }\n\n return out;\n};\n","'use strict';\n\nmodule.exports = function orientText(trace, xaxis, yaxis, xy, dxy, refDxy) {\n var dx = dxy[0] * trace.dpdx(xaxis);\n var dy = dxy[1] * trace.dpdy(yaxis);\n var flip = 1;\n\n var offsetMultiplier = 1.0;\n if(refDxy) {\n var l1 = Math.sqrt(dxy[0] * dxy[0] + dxy[1] * dxy[1]);\n var l2 = Math.sqrt(refDxy[0] * refDxy[0] + refDxy[1] * refDxy[1]);\n var dot = (dxy[0] * refDxy[0] + dxy[1] * refDxy[1]) / l1 / l2;\n offsetMultiplier = Math.max(0.0, dot);\n }\n\n var angle = Math.atan2(dy, dx) * 180 / Math.PI;\n if(angle < -90) {\n angle += 180;\n flip = -flip;\n } else if(angle > 90) {\n angle -= 180;\n flip = -flip;\n }\n\n return {\n angle: angle,\n flip: flip,\n p: trace.c2p(xy, xaxis, yaxis),\n offsetMultplier: offsetMultiplier\n };\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Drawing = require('../../components/drawing');\nvar map1dArray = require('./map_1d_array');\nvar makepath = require('./makepath');\nvar orientText = require('./orient_text');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar Lib = require('../../lib');\nvar strRotate = Lib.strRotate;\nvar strTranslate = Lib.strTranslate;\nvar alignmentConstants = require('../../constants/alignment');\n\nmodule.exports = function plot(gd, plotinfo, cdcarpet, carpetLayer) {\n var isStatic = gd._context.staticPlot;\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var fullLayout = gd._fullLayout;\n var clipLayer = fullLayout._clips;\n\n Lib.makeTraceGroups(carpetLayer, cdcarpet, 'trace').each(function(cd) {\n var axisLayer = d3.select(this);\n var cd0 = cd[0];\n var trace = cd0.trace;\n var aax = trace.aaxis;\n var bax = trace.baxis;\n\n var minorLayer = Lib.ensureSingle(axisLayer, 'g', 'minorlayer');\n var majorLayer = Lib.ensureSingle(axisLayer, 'g', 'majorlayer');\n var boundaryLayer = Lib.ensureSingle(axisLayer, 'g', 'boundarylayer');\n var labelLayer = Lib.ensureSingle(axisLayer, 'g', 'labellayer');\n\n axisLayer.style('opacity', trace.opacity);\n\n drawGridLines(xa, ya, majorLayer, aax, 'a', aax._gridlines, true, isStatic);\n drawGridLines(xa, ya, majorLayer, bax, 'b', bax._gridlines, true, isStatic);\n drawGridLines(xa, ya, minorLayer, aax, 'a', aax._minorgridlines, true, isStatic);\n drawGridLines(xa, ya, minorLayer, bax, 'b', bax._minorgridlines, true, isStatic);\n\n // NB: These are not omitted if the lines are not active. The joins must be executed\n // in order for them to get cleaned up without a full redraw\n drawGridLines(xa, ya, boundaryLayer, aax, 'a-boundary', aax._boundarylines, isStatic);\n drawGridLines(xa, ya, boundaryLayer, bax, 'b-boundary', bax._boundarylines, isStatic);\n\n var labelOrientationA = drawAxisLabels(gd, xa, ya, trace, cd0, labelLayer, aax._labels, 'a-label');\n var labelOrientationB = drawAxisLabels(gd, xa, ya, trace, cd0, labelLayer, bax._labels, 'b-label');\n\n drawAxisTitles(gd, labelLayer, trace, cd0, xa, ya, labelOrientationA, labelOrientationB);\n\n drawClipPath(trace, cd0, clipLayer, xa, ya);\n });\n};\n\nfunction drawClipPath(trace, t, layer, xaxis, yaxis) {\n var seg, xp, yp, i;\n\n var clip = layer.select('#' + trace._clipPathId);\n\n if(!clip.size()) {\n clip = layer.append('clipPath')\n .classed('carpetclip', true);\n }\n\n var path = Lib.ensureSingle(clip, 'path', 'carpetboundary');\n var segments = t.clipsegments;\n var segs = [];\n\n for(i = 0; i < segments.length; i++) {\n seg = segments[i];\n xp = map1dArray([], seg.x, xaxis.c2p);\n yp = map1dArray([], seg.y, yaxis.c2p);\n segs.push(makepath(xp, yp, seg.bicubic));\n }\n\n // This could be optimized ever so slightly to avoid no-op L segments\n // at the corners, but it's so negligible that I don't think it's worth\n // the extra complexity\n var clipPathData = 'M' + segs.join('L') + 'Z';\n clip.attr('id', trace._clipPathId);\n path.attr('d', clipPathData);\n}\n\nfunction drawGridLines(xaxis, yaxis, layer, axis, axisLetter, gridlines, isStatic) {\n var lineClass = 'const-' + axisLetter + '-lines';\n var gridJoin = layer.selectAll('.' + lineClass).data(gridlines);\n\n gridJoin.enter().append('path')\n .classed(lineClass, true)\n .style('vector-effect', isStatic ? 'none' : 'non-scaling-stroke');\n\n gridJoin.each(function(d) {\n var gridline = d;\n var x = gridline.x;\n var y = gridline.y;\n\n var xp = map1dArray([], x, xaxis.c2p);\n var yp = map1dArray([], y, yaxis.c2p);\n\n var path = 'M' + makepath(xp, yp, gridline.smoothing);\n\n var el = d3.select(this);\n\n el.attr('d', path)\n .style('stroke-width', gridline.width)\n .style('stroke', gridline.color)\n .style('stroke-dasharray', Drawing.dashStyle(gridline.dash, gridline.width))\n .style('fill', 'none');\n });\n\n gridJoin.exit().remove();\n}\n\nfunction drawAxisLabels(gd, xaxis, yaxis, trace, t, layer, labels, labelClass) {\n var labelJoin = layer.selectAll('text.' + labelClass).data(labels);\n\n labelJoin.enter().append('text')\n .classed(labelClass, true);\n\n var maxExtent = 0;\n var labelOrientation = {};\n\n labelJoin.each(function(label, i) {\n // Most of the positioning is done in calc_labels. Only the parts that depend upon\n // the screen space representation of the x and y axes are here:\n var orientation;\n if(label.axis.tickangle === 'auto') {\n orientation = orientText(trace, xaxis, yaxis, label.xy, label.dxy);\n } else {\n var angle = (label.axis.tickangle + 180.0) * Math.PI / 180.0;\n orientation = orientText(trace, xaxis, yaxis, label.xy, [Math.cos(angle), Math.sin(angle)]);\n }\n\n if(!i) {\n // TODO: offsetMultiplier? Not currently used anywhere...\n labelOrientation = {angle: orientation.angle, flip: orientation.flip};\n }\n var direction = (label.endAnchor ? -1 : 1) * orientation.flip;\n\n var labelEl = d3.select(this)\n .attr({\n 'text-anchor': direction > 0 ? 'start' : 'end',\n 'data-notex': 1\n })\n .call(Drawing.font, label.font)\n .text(label.text)\n .call(svgTextUtils.convertToTspans, gd);\n\n var bbox = Drawing.bBox(this);\n\n labelEl.attr('transform',\n // Translate to the correct point:\n strTranslate(orientation.p[0], orientation.p[1]) +\n // Rotate to line up with grid line tangent:\n strRotate(orientation.angle) +\n // Adjust the baseline and indentation:\n strTranslate(label.axis.labelpadding * direction, bbox.height * 0.3)\n );\n\n maxExtent = Math.max(maxExtent, bbox.width + label.axis.labelpadding);\n });\n\n labelJoin.exit().remove();\n\n labelOrientation.maxExtent = maxExtent;\n return labelOrientation;\n}\n\nfunction drawAxisTitles(gd, layer, trace, t, xa, ya, labelOrientationA, labelOrientationB) {\n var a, b, xy, dxy;\n\n var aMin = Lib.aggNums(Math.min, null, trace.a);\n var aMax = Lib.aggNums(Math.max, null, trace.a);\n var bMin = Lib.aggNums(Math.min, null, trace.b);\n var bMax = Lib.aggNums(Math.max, null, trace.b);\n\n a = 0.5 * (aMin + aMax);\n b = bMin;\n xy = trace.ab2xy(a, b, true);\n dxy = trace.dxyda_rough(a, b);\n if(labelOrientationA.angle === undefined) {\n Lib.extendFlat(labelOrientationA, orientText(trace, xa, ya, xy, trace.dxydb_rough(a, b)));\n }\n drawAxisTitle(gd, layer, trace, t, xy, dxy, trace.aaxis, xa, ya, labelOrientationA, 'a-title');\n\n a = aMin;\n b = 0.5 * (bMin + bMax);\n xy = trace.ab2xy(a, b, true);\n dxy = trace.dxydb_rough(a, b);\n if(labelOrientationB.angle === undefined) {\n Lib.extendFlat(labelOrientationB, orientText(trace, xa, ya, xy, trace.dxyda_rough(a, b)));\n }\n drawAxisTitle(gd, layer, trace, t, xy, dxy, trace.baxis, xa, ya, labelOrientationB, 'b-title');\n}\n\nvar lineSpacing = alignmentConstants.LINE_SPACING;\nvar midShift = ((1 - alignmentConstants.MID_SHIFT) / lineSpacing) + 1;\n\nfunction drawAxisTitle(gd, layer, trace, t, xy, dxy, axis, xa, ya, labelOrientation, labelClass) {\n var data = [];\n if(axis.title.text) data.push(axis.title.text);\n var titleJoin = layer.selectAll('text.' + labelClass).data(data);\n var offset = labelOrientation.maxExtent;\n\n titleJoin.enter().append('text')\n .classed(labelClass, true);\n\n // There's only one, but we'll do it as a join so it's updated nicely:\n titleJoin.each(function() {\n var orientation = orientText(trace, xa, ya, xy, dxy);\n\n if(['start', 'both'].indexOf(axis.showticklabels) === -1) {\n offset = 0;\n }\n\n // In addition to the size of the labels, add on some extra padding:\n var titleSize = axis.title.font.size;\n offset += titleSize + axis.title.offset;\n\n var labelNorm = labelOrientation.angle + (labelOrientation.flip < 0 ? 180 : 0);\n var angleDiff = (labelNorm - orientation.angle + 450) % 360;\n var reverseTitle = angleDiff > 90 && angleDiff < 270;\n\n var el = d3.select(this);\n\n el.text(axis.title.text)\n .call(svgTextUtils.convertToTspans, gd);\n\n if(reverseTitle) {\n offset = (-svgTextUtils.lineCount(el) + midShift) * lineSpacing * titleSize - offset;\n }\n\n el.attr('transform',\n strTranslate(orientation.p[0], orientation.p[1]) +\n strRotate(orientation.angle) +\n strTranslate(0, offset)\n )\n .attr('text-anchor', 'middle')\n .call(Drawing.font, axis.title.font);\n });\n\n titleJoin.exit().remove();\n}\n","'use strict';\n\nvar constants = require('./constants');\nvar search = require('../../lib/search').findBin;\nvar computeControlPoints = require('./compute_control_points');\nvar createSplineEvaluator = require('./create_spline_evaluator');\nvar createIDerivativeEvaluator = require('./create_i_derivative_evaluator');\nvar createJDerivativeEvaluator = require('./create_j_derivative_evaluator');\n\n/*\n * Create conversion functions to go from one basis to another. In particular the letter\n * abbreviations are:\n *\n * i: i/j coordinates along the grid. Integer values correspond to data points\n * a: real-valued coordinates along the a/b axes\n * c: cartesian x-y coordinates\n * p: screen-space pixel coordinates\n */\nmodule.exports = function setConvert(trace) {\n var a = trace._a;\n var b = trace._b;\n var na = a.length;\n var nb = b.length;\n var aax = trace.aaxis;\n var bax = trace.baxis;\n\n // Grab the limits once rather than recomputing the bounds for every point\n // independently:\n var amin = a[0];\n var amax = a[na - 1];\n var bmin = b[0];\n var bmax = b[nb - 1];\n var arange = a[a.length - 1] - a[0];\n var brange = b[b.length - 1] - b[0];\n\n // Compute the tolerance so that points are visible slightly outside the\n // defined carpet axis:\n var atol = arange * constants.RELATIVE_CULL_TOLERANCE;\n var btol = brange * constants.RELATIVE_CULL_TOLERANCE;\n\n // Expand the limits to include the relative tolerance:\n amin -= atol;\n amax += atol;\n bmin -= btol;\n bmax += btol;\n\n trace.isVisible = function(a, b) {\n return a > amin && a < amax && b > bmin && b < bmax;\n };\n\n trace.isOccluded = function(a, b) {\n return a < amin || a > amax || b < bmin || b > bmax;\n };\n\n trace.setScale = function() {\n var x = trace._x;\n var y = trace._y;\n\n // This is potentially a very expensive step! It does the bulk of the work of constructing\n // an expanded basis of control points. Note in particular that it overwrites the existing\n // basis without creating a new array since that would potentially thrash the garbage\n // collector.\n var result = computeControlPoints(trace._xctrl, trace._yctrl, x, y, aax.smoothing, bax.smoothing);\n trace._xctrl = result[0];\n trace._yctrl = result[1];\n\n // This step is the second step in the process, but it's somewhat simpler. It just unrolls\n // some logic since it would be unnecessarily expensive to compute both interpolations\n // nearly identically but separately and to include a bunch of linear vs. bicubic logic in\n // every single call.\n trace.evalxy = createSplineEvaluator([trace._xctrl, trace._yctrl], na, nb, aax.smoothing, bax.smoothing);\n\n trace.dxydi = createIDerivativeEvaluator([trace._xctrl, trace._yctrl], aax.smoothing, bax.smoothing);\n trace.dxydj = createJDerivativeEvaluator([trace._xctrl, trace._yctrl], aax.smoothing, bax.smoothing);\n };\n\n /*\n * Convert from i/j data grid coordinates to a/b values. Note in particular that this\n * is *linear* interpolation, even if the data is interpolated bicubically.\n */\n trace.i2a = function(i) {\n var i0 = Math.max(0, Math.floor(i[0]), na - 2);\n var ti = i[0] - i0;\n return (1 - ti) * a[i0] + ti * a[i0 + 1];\n };\n\n trace.j2b = function(j) {\n var j0 = Math.max(0, Math.floor(j[1]), na - 2);\n var tj = j[1] - j0;\n return (1 - tj) * b[j0] + tj * b[j0 + 1];\n };\n\n trace.ij2ab = function(ij) {\n return [trace.i2a(ij[0]), trace.j2b(ij[1])];\n };\n\n /*\n * Convert from a/b coordinates to i/j grid-numbered coordinates. This requires searching\n * through the a/b data arrays and assumes they are monotonic, which is presumed to have\n * been enforced already.\n */\n trace.a2i = function(aval) {\n var i0 = Math.max(0, Math.min(search(aval, a), na - 2));\n var a0 = a[i0];\n var a1 = a[i0 + 1];\n return Math.max(0, Math.min(na - 1, i0 + (aval - a0) / (a1 - a0)));\n };\n\n trace.b2j = function(bval) {\n var j0 = Math.max(0, Math.min(search(bval, b), nb - 2));\n var b0 = b[j0];\n var b1 = b[j0 + 1];\n return Math.max(0, Math.min(nb - 1, j0 + (bval - b0) / (b1 - b0)));\n };\n\n trace.ab2ij = function(ab) {\n return [trace.a2i(ab[0]), trace.b2j(ab[1])];\n };\n\n /*\n * Convert from i/j coordinates to x/y caretesian coordinates. This means either bilinear\n * or bicubic spline evaluation, but the hard part is already done at this point.\n */\n trace.i2c = function(i, j) {\n return trace.evalxy([], i, j);\n };\n\n trace.ab2xy = function(aval, bval, extrapolate) {\n if(!extrapolate && (aval < a[0] || aval > a[na - 1] | bval < b[0] || bval > b[nb - 1])) {\n return [false, false];\n }\n var i = trace.a2i(aval);\n var j = trace.b2j(bval);\n\n var pt = trace.evalxy([], i, j);\n\n if(extrapolate) {\n // This section uses the boundary derivatives to extrapolate linearly outside\n // the defined range. Consider a scatter line with one point inside the carpet\n // axis and one point outside. If we don't extrapolate, we can't draw the line\n // at all.\n var iex = 0;\n var jex = 0;\n var der = [];\n\n var i0, ti, j0, tj;\n if(aval < a[0]) {\n i0 = 0;\n ti = 0;\n iex = (aval - a[0]) / (a[1] - a[0]);\n } else if(aval > a[na - 1]) {\n i0 = na - 2;\n ti = 1;\n iex = (aval - a[na - 1]) / (a[na - 1] - a[na - 2]);\n } else {\n i0 = Math.max(0, Math.min(na - 2, Math.floor(i)));\n ti = i - i0;\n }\n\n if(bval < b[0]) {\n j0 = 0;\n tj = 0;\n jex = (bval - b[0]) / (b[1] - b[0]);\n } else if(bval > b[nb - 1]) {\n j0 = nb - 2;\n tj = 1;\n jex = (bval - b[nb - 1]) / (b[nb - 1] - b[nb - 2]);\n } else {\n j0 = Math.max(0, Math.min(nb - 2, Math.floor(j)));\n tj = j - j0;\n }\n\n if(iex) {\n trace.dxydi(der, i0, j0, ti, tj);\n pt[0] += der[0] * iex;\n pt[1] += der[1] * iex;\n }\n\n if(jex) {\n trace.dxydj(der, i0, j0, ti, tj);\n pt[0] += der[0] * jex;\n pt[1] += der[1] * jex;\n }\n }\n\n return pt;\n };\n\n\n trace.c2p = function(xy, xa, ya) {\n return [xa.c2p(xy[0]), ya.c2p(xy[1])];\n };\n\n trace.p2x = function(p, xa, ya) {\n return [xa.p2c(p[0]), ya.p2c(p[1])];\n };\n\n trace.dadi = function(i /* , u*/) {\n // Right now only a piecewise linear a or b basis is permitted since smoother interpolation\n // would cause monotonicity problems. As a retult, u is entirely disregarded in this\n // computation, though we'll specify it as a parameter for the sake of completeness and\n // future-proofing. It would be possible to use monotonic cubic interpolation, for example.\n //\n // See: https://en.wikipedia.org/wiki/Monotone_cubic_interpolation\n\n // u = u || 0;\n\n var i0 = Math.max(0, Math.min(a.length - 2, i));\n\n // The step (denominator) is implicitly 1 since that's the grid spacing.\n return a[i0 + 1] - a[i0];\n };\n\n trace.dbdj = function(j /* , v*/) {\n // See above caveats for dadi which also apply here\n var j0 = Math.max(0, Math.min(b.length - 2, j));\n\n // The step (denominator) is implicitly 1 since that's the grid spacing.\n return b[j0 + 1] - b[j0];\n };\n\n // Takes: grid cell coordinate (i, j) and fractional grid cell coordinates (u, v)\n // Returns: (dx/da, dy/db)\n //\n // NB: separate grid cell + fractional grid cell coordinate format is due to the discontinuous\n // derivative, as described better in create_i_derivative_evaluator.js\n trace.dxyda = function(i0, j0, u, v) {\n var dxydi = trace.dxydi(null, i0, j0, u, v);\n var dadi = trace.dadi(i0, u);\n\n return [dxydi[0] / dadi, dxydi[1] / dadi];\n };\n\n trace.dxydb = function(i0, j0, u, v) {\n var dxydj = trace.dxydj(null, i0, j0, u, v);\n var dbdj = trace.dbdj(j0, v);\n\n return [dxydj[0] / dbdj, dxydj[1] / dbdj];\n };\n\n // Sometimes we don't care about precision and all we really want is decent rough\n // directions (as is the case with labels). In that case, we can do a very rough finite\n // difference and spare having to worry about precise grid coordinates:\n trace.dxyda_rough = function(a, b, reldiff) {\n var h = arange * (reldiff || 0.1);\n var plus = trace.ab2xy(a + h, b, true);\n var minus = trace.ab2xy(a - h, b, true);\n\n return [\n (plus[0] - minus[0]) * 0.5 / h,\n (plus[1] - minus[1]) * 0.5 / h\n ];\n };\n\n trace.dxydb_rough = function(a, b, reldiff) {\n var h = brange * (reldiff || 0.1);\n var plus = trace.ab2xy(a, b + h, true);\n var minus = trace.ab2xy(a, b - h, true);\n\n return [\n (plus[0] - minus[0]) * 0.5 / h,\n (plus[1] - minus[1]) * 0.5 / h\n ];\n };\n\n trace.dpdx = function(xa) {\n return xa._m;\n };\n\n trace.dpdy = function(ya) {\n return ya._m;\n };\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\n/*\n * Given a 2D array as well as a basis in either direction, this function fills in the\n * 2D array using a combination of smoothing and extrapolation. This is rather important\n * for carpet plots since it's used for layout so that we can't simply omit or blank out\n * points. We need a reasonable guess so that the interpolation puts points somewhere\n * even if we were to somehow represent that the data was missing later on.\n *\n * input:\n * - data: 2D array of arrays\n * - a: array such that a.length === data[0].length\n * - b: array such that b.length === data.length\n */\nmodule.exports = function smoothFill2dArray(data, a, b) {\n var i, j, k;\n var ip = [];\n var jp = [];\n // var neighborCnts = [];\n\n var ni = data[0].length;\n var nj = data.length;\n\n function avgSurrounding(i, j) {\n // As a low-quality start, we can simply average surrounding points (in a not\n // non-uniform grid aware manner):\n var sum = 0.0;\n var val;\n var cnt = 0;\n if(i > 0 && (val = data[j][i - 1]) !== undefined) {\n cnt++;\n sum += val;\n }\n if(i < ni - 1 && (val = data[j][i + 1]) !== undefined) {\n cnt++;\n sum += val;\n }\n if(j > 0 && (val = data[j - 1][i]) !== undefined) {\n cnt++;\n sum += val;\n }\n if(j < nj - 1 && (val = data[j + 1][i]) !== undefined) {\n cnt++;\n sum += val;\n }\n return sum / Math.max(1, cnt);\n }\n\n // This loop iterates over all cells. Any cells that are null will be noted and those\n // are the only points we will loop over and update via laplace's equation. Points with\n // any neighbors will receive the average. If there are no neighboring points, then they\n // will be set to zero. Also as we go, track the maximum magnitude so that we can scale\n // our tolerance accordingly.\n var dmax = 0.0;\n for(i = 0; i < ni; i++) {\n for(j = 0; j < nj; j++) {\n if(data[j][i] === undefined) {\n ip.push(i);\n jp.push(j);\n\n data[j][i] = avgSurrounding(i, j);\n // neighborCnts.push(result.neighbors);\n }\n dmax = Math.max(dmax, Math.abs(data[j][i]));\n }\n }\n\n if(!ip.length) return data;\n\n // The tolerance doesn't need to be excessive. It's just for display positioning\n var dxp, dxm, dap, dam, dbp, dbm, c, d, diff, reldiff, overrelaxation;\n var tol = 1e-5;\n var resid = 0;\n var itermax = 100;\n var iter = 0;\n var n = ip.length;\n do {\n resid = 0;\n // Normally we'd loop in two dimensions, but not all points are blank and need\n // an update, so we instead loop only over the points that were tabulated above\n for(k = 0; k < n; k++) {\n i = ip[k];\n j = jp[k];\n // neighborCnt = neighborCnts[k];\n\n // Track a counter for how many contributions there are. We'll use this counter\n // to average at the end, which reduces to laplace's equation with neumann boundary\n // conditions on the first derivative (second derivative is zero so that we get\n // a nice linear extrapolation at the boundaries).\n var boundaryCnt = 0;\n var newVal = 0;\n\n var d0, d1, x0, x1, i0, j0;\n if(i === 0) {\n // If this lies along the i = 0 boundary, extrapolate from the two points\n // to the right of this point. Note that the finite differences take into\n // account non-uniform grid spacing:\n i0 = Math.min(ni - 1, 2);\n x0 = a[i0];\n x1 = a[1];\n d0 = data[j][i0];\n d1 = data[j][1];\n newVal += d1 + (d1 - d0) * (a[0] - x1) / (x1 - x0);\n boundaryCnt++;\n } else if(i === ni - 1) {\n // If along the high i boundary, extrapolate from the two points to the\n // left of this point\n i0 = Math.max(0, ni - 3);\n x0 = a[i0];\n x1 = a[ni - 2];\n d0 = data[j][i0];\n d1 = data[j][ni - 2];\n newVal += d1 + (d1 - d0) * (a[ni - 1] - x1) / (x1 - x0);\n boundaryCnt++;\n }\n\n if((i === 0 || i === ni - 1) && (j > 0 && j < nj - 1)) {\n // If along the min(i) or max(i) boundaries, also smooth vertically as long\n // as we're not in a corner. Note that the finite differences used here\n // are also aware of nonuniform grid spacing:\n dxp = b[j + 1] - b[j];\n dxm = b[j] - b[j - 1];\n newVal += (dxm * data[j + 1][i] + dxp * data[j - 1][i]) / (dxm + dxp);\n boundaryCnt++;\n }\n\n if(j === 0) {\n // If along the j = 0 boundary, extrpolate this point from the two points\n // above it\n j0 = Math.min(nj - 1, 2);\n x0 = b[j0];\n x1 = b[1];\n d0 = data[j0][i];\n d1 = data[1][i];\n newVal += d1 + (d1 - d0) * (b[0] - x1) / (x1 - x0);\n boundaryCnt++;\n } else if(j === nj - 1) {\n // Same for the max j boundary from the cells below it:\n j0 = Math.max(0, nj - 3);\n x0 = b[j0];\n x1 = b[nj - 2];\n d0 = data[j0][i];\n d1 = data[nj - 2][i];\n newVal += d1 + (d1 - d0) * (b[nj - 1] - x1) / (x1 - x0);\n boundaryCnt++;\n }\n\n if((j === 0 || j === nj - 1) && (i > 0 && i < ni - 1)) {\n // Now average points to the left/right as long as not in a corner:\n dxp = a[i + 1] - a[i];\n dxm = a[i] - a[i - 1];\n newVal += (dxm * data[j][i + 1] + dxp * data[j][i - 1]) / (dxm + dxp);\n boundaryCnt++;\n }\n\n if(!boundaryCnt) {\n // If none of the above conditions were triggered, then this is an interior\n // point and we can just do a laplace equation update. As above, these differences\n // are aware of nonuniform grid spacing:\n dap = a[i + 1] - a[i];\n dam = a[i] - a[i - 1];\n dbp = b[j + 1] - b[j];\n dbm = b[j] - b[j - 1];\n\n // These are just some useful constants for the iteration, which is perfectly\n // straightforward but a little long to derive from f_xx + f_yy = 0.\n c = dap * dam * (dap + dam);\n d = dbp * dbm * (dbp + dbm);\n\n newVal = (c * (dbm * data[j + 1][i] + dbp * data[j - 1][i]) +\n d * (dam * data[j][i + 1] + dap * data[j][i - 1])) /\n (d * (dam + dap) + c * (dbm + dbp));\n } else {\n // If we did have contributions from the boundary conditions, then average\n // the result from the various contributions:\n newVal /= boundaryCnt;\n }\n\n // Jacobi updates are ridiculously slow to converge, so this approach uses a\n // Gauss-seidel iteration which is dramatically faster.\n diff = newVal - data[j][i];\n reldiff = diff / dmax;\n resid += reldiff * reldiff;\n\n // Gauss-Seidel-ish iteration, omega chosen based on heuristics and some\n // quick tests.\n //\n // NB: Don't overrelax the boundarie. Otherwise set an overrelaxation factor\n // which is a little low but safely optimal-ish:\n overrelaxation = boundaryCnt ? 0 : 0.85;\n\n // If there are four non-null neighbors, then we want a simple average without\n // overrelaxation. If all the surrounding points are null, then we want the full\n // overrelaxation\n //\n // Based on experiments, this actually seems to slow down convergence just a bit.\n // I'll leave it here for reference in case this needs to be revisited, but\n // it seems to work just fine without this.\n // if (overrelaxation) overrelaxation *= (4 - neighborCnt) / 4;\n\n data[j][i] += diff * (1 + overrelaxation);\n }\n\n resid = Math.sqrt(resid);\n } while(iter++ < itermax && resid > tol);\n\n Lib.log('Smoother converged to', resid, 'after', iter, 'iterations');\n\n return data;\n};\n","'use strict';\n\nvar isArray1D = require('../../lib').isArray1D;\n\nmodule.exports = function handleXYDefaults(traceIn, traceOut, coerce) {\n var x = coerce('x');\n var hasX = x && x.length;\n var y = coerce('y');\n var hasY = y && y.length;\n if(!hasX && !hasY) return false;\n\n traceOut._cheater = !x;\n\n if((!hasX || isArray1D(x)) && (!hasY || isArray1D(y))) {\n var len = hasX ? x.length : Infinity;\n if(hasY) len = Math.min(len, y.length);\n if(traceOut.a && traceOut.a.length) len = Math.min(len, traceOut.a.length);\n if(traceOut.b && traceOut.b.length) len = Math.min(len, traceOut.b.length);\n traceOut._length = len;\n } else traceOut._length = null;\n\n return true;\n};\n","'use strict';\n\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar scatterGeoAttrs = require('../scattergeo/attributes');\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar baseAttrs = require('../../plots/attributes');\nvar defaultLine = require('../../components/color/attributes').defaultLine;\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar scatterGeoMarkerLineAttrs = scatterGeoAttrs.marker.line;\n\nmodule.exports = extendFlat({\n locations: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the coordinates via location IDs or names.',\n 'See `locationmode` for more info.'\n ].join(' ')\n },\n locationmode: scatterGeoAttrs.locationmode,\n z: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the color values.'\n },\n geojson: extendFlat({}, scatterGeoAttrs.geojson, {\n description: [\n 'Sets optional GeoJSON data associated with this trace.',\n 'If not given, the features on the base map are used.',\n\n 'It can be set as a valid GeoJSON object or as a URL string.',\n 'Note that we only accept GeoJSONs of type *FeatureCollection* or *Feature*',\n 'with geometries of type *Polygon* or *MultiPolygon*.'\n\n // TODO add topojson support with additional 'topojsonobject' attr?\n // https://github.com/topojson/topojson-specification/blob/master/README.md\n ].join(' ')\n }),\n featureidkey: scatterGeoAttrs.featureidkey,\n\n text: extendFlat({}, scatterGeoAttrs.text, {\n description: 'Sets the text elements associated with each location.'\n }),\n hovertext: extendFlat({}, scatterGeoAttrs.hovertext, {\n description: 'Same as `text`.'\n }),\n marker: {\n line: {\n color: extendFlat({}, scatterGeoMarkerLineAttrs.color, {dflt: defaultLine}),\n width: extendFlat({}, scatterGeoMarkerLineAttrs.width, {dflt: 1}),\n editType: 'calc'\n },\n opacity: {\n valType: 'number',\n arrayOk: true,\n min: 0,\n max: 1,\n dflt: 1,\n editType: 'style',\n description: 'Sets the opacity of the locations.'\n },\n editType: 'calc'\n },\n\n selected: {\n marker: {\n opacity: scatterGeoAttrs.selected.marker.opacity,\n editType: 'plot'\n },\n editType: 'plot'\n },\n unselected: {\n marker: {\n opacity: scatterGeoAttrs.unselected.marker.opacity,\n editType: 'plot'\n },\n editType: 'plot'\n },\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n editType: 'calc',\n flags: ['location', 'z', 'text', 'name']\n }),\n hovertemplate: hovertemplateAttrs(),\n showlegend: extendFlat({}, baseAttrs.showlegend, {dflt: false})\n},\n\n colorScaleAttrs('', {\n cLetter: 'z',\n editTypeOverride: 'calc'\n })\n);\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nvar colorscaleCalc = require('../../components/colorscale/calc');\nvar arraysToCalcdata = require('../scatter/arrays_to_calcdata');\nvar calcSelection = require('../scatter/calc_selection');\n\nfunction isNonBlankString(v) {\n return v && typeof v === 'string';\n}\n\nmodule.exports = function calc(gd, trace) {\n var len = trace._length;\n var calcTrace = new Array(len);\n\n var isValidLoc;\n\n if(trace.geojson) {\n isValidLoc = function(v) { return isNonBlankString(v) || isNumeric(v); };\n } else {\n isValidLoc = isNonBlankString;\n }\n\n for(var i = 0; i < len; i++) {\n var calcPt = calcTrace[i] = {};\n var loc = trace.locations[i];\n var z = trace.z[i];\n\n if(isValidLoc(loc) && isNumeric(z)) {\n calcPt.loc = loc;\n calcPt.z = z;\n } else {\n calcPt.loc = null;\n calcPt.z = BADNUM;\n }\n\n calcPt.index = i;\n }\n\n arraysToCalcdata(calcTrace, trace);\n colorscaleCalc(gd, trace, {\n vals: trace.z,\n containerStr: '',\n cLetter: 'z'\n });\n calcSelection(calcTrace, trace);\n\n return calcTrace;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var locations = coerce('locations');\n var z = coerce('z');\n\n if(!(locations && locations.length && Lib.isArrayOrTypedArray(z) && z.length)) {\n traceOut.visible = false;\n return;\n }\n\n traceOut._length = Math.min(locations.length, z.length);\n\n var geojson = coerce('geojson');\n\n var locationmodeDflt;\n if((typeof geojson === 'string' && geojson !== '') || Lib.isPlainObject(geojson)) {\n locationmodeDflt = 'geojson-id';\n }\n\n var locationMode = coerce('locationmode', locationmodeDflt);\n\n if(locationMode === 'geojson-id') {\n coerce('featureidkey');\n }\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n\n var mlw = coerce('marker.line.width');\n if(mlw) coerce('marker.line.color');\n coerce('marker.opacity');\n\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'z'});\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n","'use strict';\n\nmodule.exports = function eventData(out, pt, trace, cd, pointNumber) {\n out.location = pt.location;\n out.z = pt.z;\n\n // include feature properties from input geojson\n var cdi = cd[pointNumber];\n if(cdi.fIn && cdi.fIn.properties) {\n out.properties = cdi.fIn.properties;\n }\n out.ct = cdi.ct;\n\n return out;\n};\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\nvar attributes = require('./attributes');\nvar fillText = require('../../lib').fillText;\n\nmodule.exports = function hoverPoints(pointData, xval, yval) {\n var cd = pointData.cd;\n var trace = cd[0].trace;\n var geo = pointData.subplot;\n\n var pt, i, j, isInside;\n\n var xy = [xval, yval];\n var altXy = [xval + 360, yval];\n\n for(i = 0; i < cd.length; i++) {\n pt = cd[i];\n isInside = false;\n\n if(pt._polygons) {\n for(j = 0; j < pt._polygons.length; j++) {\n if(pt._polygons[j].contains(xy)) {\n isInside = !isInside;\n }\n // for polygons that cross antimeridian as xval is in [-180, 180]\n if(pt._polygons[j].contains(altXy)) {\n isInside = !isInside;\n }\n }\n\n if(isInside) break;\n }\n }\n\n if(!isInside || !pt) return;\n\n pointData.x0 = pointData.x1 = pointData.xa.c2p(pt.ct);\n pointData.y0 = pointData.y1 = pointData.ya.c2p(pt.ct);\n\n pointData.index = pt.index;\n pointData.location = pt.loc;\n pointData.z = pt.z;\n pointData.zLabel = Axes.tickText(geo.mockAxis, geo.mockAxis.c2l(pt.z), 'hover').text;\n pointData.hovertemplate = pt.hovertemplate;\n\n makeHoverInfo(pointData, trace, pt);\n\n return [pointData];\n};\n\nfunction makeHoverInfo(pointData, trace, pt) {\n if(trace.hovertemplate) return;\n\n var hoverinfo = pt.hi || trace.hoverinfo;\n var loc = String(pt.loc);\n\n var parts = (hoverinfo === 'all') ?\n attributes.hoverinfo.flags :\n hoverinfo.split('+');\n\n var hasName = (parts.indexOf('name') !== -1);\n var hasLocation = (parts.indexOf('location') !== -1);\n var hasZ = (parts.indexOf('z') !== -1);\n var hasText = (parts.indexOf('text') !== -1);\n var hasIdAsNameLabel = !hasName && hasLocation;\n\n var text = [];\n\n if(hasIdAsNameLabel) {\n pointData.nameOverride = loc;\n } else {\n if(hasName) pointData.nameOverride = trace.name;\n if(hasLocation) text.push(loc);\n }\n\n if(hasZ) {\n text.push(pointData.zLabel);\n }\n if(hasText) {\n fillText(pt, trace, text);\n }\n\n pointData.extraText = text.join('
');\n}\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../heatmap/colorbar'),\n calc: require('./calc'),\n calcGeoJSON: require('./plot').calcGeoJSON,\n plot: require('./plot').plot,\n style: require('./style').style,\n styleOnSelect: require('./style').styleOnSelect,\n hoverPoints: require('./hover'),\n eventData: require('./event_data'),\n selectPoints: require('./select'),\n\n moduleType: 'trace',\n name: 'choropleth',\n basePlotModule: require('../../plots/geo'),\n categories: ['geo', 'noOpacity', 'showLegend'],\n meta: {\n description: [\n 'The data that describes the choropleth value-to-color mapping',\n 'is set in `z`.',\n 'The geographic locations corresponding to each value in `z`',\n 'are set in `locations`.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Lib = require('../../lib');\nvar geoUtils = require('../../lib/geo_location_utils');\nvar getTopojsonFeatures = require('../../lib/topojson_utils').getTopojsonFeatures;\nvar findExtremes = require('../../plots/cartesian/autorange').findExtremes;\n\nvar style = require('./style').style;\n\nfunction plot(gd, geo, calcData) {\n var choroplethLayer = geo.layers.backplot.select('.choroplethlayer');\n\n Lib.makeTraceGroups(choroplethLayer, calcData, 'trace choropleth').each(function(calcTrace) {\n var sel = d3.select(this);\n\n var paths = sel.selectAll('path.choroplethlocation')\n .data(Lib.identity);\n\n paths.enter().append('path')\n .classed('choroplethlocation', true);\n\n paths.exit().remove();\n\n // call style here within topojson request callback\n style(gd, calcTrace);\n });\n}\n\nfunction calcGeoJSON(calcTrace, fullLayout) {\n var trace = calcTrace[0].trace;\n var geoLayout = fullLayout[trace.geo];\n var geo = geoLayout._subplot;\n var locationmode = trace.locationmode;\n var len = trace._length;\n\n var features = locationmode === 'geojson-id' ?\n geoUtils.extractTraceFeature(calcTrace) :\n getTopojsonFeatures(trace, geo.topojson);\n\n var lonArray = [];\n var latArray = [];\n\n for(var i = 0; i < len; i++) {\n var calcPt = calcTrace[i];\n var feature = locationmode === 'geojson-id' ?\n calcPt.fOut :\n geoUtils.locationToFeature(locationmode, calcPt.loc, features);\n\n if(feature) {\n calcPt.geojson = feature;\n calcPt.ct = feature.properties.ct;\n calcPt._polygons = geoUtils.feature2polygons(feature);\n\n var bboxFeature = geoUtils.computeBbox(feature);\n lonArray.push(bboxFeature[0], bboxFeature[2]);\n latArray.push(bboxFeature[1], bboxFeature[3]);\n } else {\n calcPt.geojson = null;\n }\n }\n\n if(geoLayout.fitbounds === 'geojson' && locationmode === 'geojson-id') {\n var bboxGeojson = geoUtils.computeBbox(geoUtils.getTraceGeojson(trace));\n lonArray = [bboxGeojson[0], bboxGeojson[2]];\n latArray = [bboxGeojson[1], bboxGeojson[3]];\n }\n\n var opts = {padded: true};\n trace._extremes.lon = findExtremes(geoLayout.lonaxis._ax, lonArray, opts);\n trace._extremes.lat = findExtremes(geoLayout.lataxis._ax, latArray, opts);\n}\n\nmodule.exports = {\n calcGeoJSON: calcGeoJSON,\n plot: plot\n};\n","'use strict';\n\nmodule.exports = function selectPoints(searchInfo, selectionTester) {\n var cd = searchInfo.cd;\n var xa = searchInfo.xaxis;\n var ya = searchInfo.yaxis;\n var selection = [];\n\n var i, di, ct, x, y;\n\n if(selectionTester === false) {\n for(i = 0; i < cd.length; i++) {\n cd[i].selected = 0;\n }\n } else {\n for(i = 0; i < cd.length; i++) {\n di = cd[i];\n ct = di.ct;\n\n if(!ct) continue;\n\n x = xa.c2p(ct);\n y = ya.c2p(ct);\n\n if(selectionTester.contains([x, y], null, i, searchInfo)) {\n selection.push({\n pointNumber: i,\n lon: ct[0],\n lat: ct[1]\n });\n di.selected = 1;\n } else {\n di.selected = 0;\n }\n }\n }\n\n return selection;\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\nvar Colorscale = require('../../components/colorscale');\n\nfunction style(gd, calcTrace) {\n if(calcTrace) styleTrace(gd, calcTrace);\n}\n\nfunction styleTrace(gd, calcTrace) {\n var trace = calcTrace[0].trace;\n var s = calcTrace[0].node3;\n var locs = s.selectAll('.choroplethlocation');\n var marker = trace.marker || {};\n var markerLine = marker.line || {};\n\n var sclFunc = Colorscale.makeColorScaleFuncFromTrace(trace);\n\n locs.each(function(d) {\n d3.select(this)\n .attr('fill', sclFunc(d.z))\n .call(Color.stroke, d.mlc || markerLine.color)\n .call(Drawing.dashLine, '', d.mlw || markerLine.width || 0)\n .style('opacity', marker.opacity);\n });\n\n Drawing.selectedPointStyle(locs, trace);\n}\n\nfunction styleOnSelect(gd, calcTrace) {\n var s = calcTrace[0].node3;\n var trace = calcTrace[0].trace;\n\n if(trace.selectedpoints) {\n Drawing.selectedPointStyle(s.selectAll('.choroplethlocation'), trace);\n } else {\n styleTrace(gd, calcTrace);\n }\n}\n\nmodule.exports = {\n style: style,\n styleOnSelect: styleOnSelect\n};\n","'use strict';\n\nvar choroplethAttrs = require('../choropleth/attributes');\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar baseAttrs = require('../../plots/attributes');\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nmodule.exports = extendFlat({\n locations: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets which features found in *geojson* to plot using',\n 'their feature `id` field.'\n ].join(' ')\n },\n\n // TODO\n // Maybe start with only one value (that we could name e.g. 'geojson-id'),\n // but eventually:\n // - we could also support for our own dist/topojson/*\n // .. and locationmode: choroplethAttrs.locationmode,\n\n z: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the color values.'\n },\n\n // TODO maybe we could also set a \"key\" to dig out values out of the\n // GeoJSON feature `properties` fields?\n\n geojson: {\n valType: 'any',\n editType: 'calc',\n description: [\n 'Sets the GeoJSON data associated with this trace.',\n\n 'It can be set as a valid GeoJSON object or as a URL string.',\n 'Note that we only accept GeoJSONs of type *FeatureCollection* or *Feature*',\n 'with geometries of type *Polygon* or *MultiPolygon*.'\n ].join(' ')\n },\n featureidkey: extendFlat({}, choroplethAttrs.featureidkey, {\n description: [\n 'Sets the key in GeoJSON features which is used as id to match the items',\n 'included in the `locations` array.',\n 'Support nested property, for example *properties.name*.'\n ].join(' ')\n }),\n\n // TODO agree on name / behaviour\n //\n // 'below' is used currently for layout.map.layers,\n // even though it's not very plotly-esque.\n //\n // Note also, that the map-gl style don't all have the same layers,\n // see https://codepen.io/etpinard/pen/ydVMwM for full list\n below: {\n valType: 'string',\n editType: 'plot',\n description: [\n 'Determines if the choropleth polygons will be inserted',\n 'before the layer with the specified ID.',\n 'By default, choroplethmap traces are placed above the water layers.',\n 'If set to \\'\\',',\n 'the layer will be inserted above every existing layer.'\n ].join(' ')\n },\n\n text: choroplethAttrs.text,\n hovertext: choroplethAttrs.hovertext,\n\n marker: {\n line: {\n color: extendFlat({}, choroplethAttrs.marker.line.color, {editType: 'plot'}),\n width: extendFlat({}, choroplethAttrs.marker.line.width, {editType: 'plot'}),\n editType: 'calc'\n },\n // TODO maybe having a dflt less than 1, together with `below:''` would be better?\n opacity: extendFlat({}, choroplethAttrs.marker.opacity, {editType: 'plot'}),\n editType: 'calc'\n },\n\n selected: {\n marker: {\n opacity: extendFlat({}, choroplethAttrs.selected.marker.opacity, {editType: 'plot'}),\n editType: 'plot'\n },\n editType: 'plot'\n },\n unselected: {\n marker: {\n opacity: extendFlat({}, choroplethAttrs.unselected.marker.opacity, {editType: 'plot'}),\n editType: 'plot'\n },\n editType: 'plot'\n },\n\n hoverinfo: choroplethAttrs.hoverinfo,\n hovertemplate: hovertemplateAttrs({}, {keys: ['properties']}),\n showlegend: extendFlat({}, baseAttrs.showlegend, {dflt: false})\n},\n\n colorScaleAttrs('', {\n cLetter: 'z',\n editTypeOverride: 'calc'\n })\n);\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar Colorscale = require('../../components/colorscale');\nvar Drawing = require('../../components/drawing');\n\nvar makeBlank = require('../../lib/geojson_utils').makeBlank;\nvar geoUtils = require('../../lib/geo_location_utils');\n\n/* N.B.\n *\n * We fetch the GeoJSON files \"ourselves\" (during\n * map.prototype.fetchMapData) where they are stored in a global object\n * named `PlotlyGeoAssets` (same as for topojson files in `geo` subplots).\n *\n * Map does allow using URLs as geojson sources, but does NOT allow filtering\n * features by feature `id` that are not numbers (more info in:\n * https://github.com/mapbox/mapbox-gl-js/issues/8088).\n */\n\nfunction convert(calcTrace) {\n var trace = calcTrace[0].trace;\n var isVisible = trace.visible === true && trace._length !== 0;\n\n var fill = {\n layout: {visibility: 'none'},\n paint: {}\n };\n\n var line = {\n layout: {visibility: 'none'},\n paint: {}\n };\n\n var opts = trace._opts = {\n fill: fill,\n line: line,\n geojson: makeBlank()\n };\n\n if(!isVisible) return opts;\n\n var features = geoUtils.extractTraceFeature(calcTrace);\n\n if(!features) return opts;\n\n var sclFunc = Colorscale.makeColorScaleFuncFromTrace(trace);\n var marker = trace.marker;\n var markerLine = marker.line || {};\n\n var opacityFn;\n if(Lib.isArrayOrTypedArray(marker.opacity)) {\n opacityFn = function(d) {\n var mo = d.mo;\n return isNumeric(mo) ? +Lib.constrain(mo, 0, 1) : 0;\n };\n }\n\n var lineColorFn;\n if(Lib.isArrayOrTypedArray(markerLine.color)) {\n lineColorFn = function(d) { return d.mlc; };\n }\n\n var lineWidthFn;\n if(Lib.isArrayOrTypedArray(markerLine.width)) {\n lineWidthFn = function(d) { return d.mlw; };\n }\n\n for(var i = 0; i < calcTrace.length; i++) {\n var cdi = calcTrace[i];\n var fOut = cdi.fOut;\n\n if(fOut) {\n var props = fOut.properties;\n props.fc = sclFunc(cdi.z);\n if(opacityFn) props.mo = opacityFn(cdi);\n if(lineColorFn) props.mlc = lineColorFn(cdi);\n if(lineWidthFn) props.mlw = lineWidthFn(cdi);\n cdi.ct = props.ct;\n cdi._polygons = geoUtils.feature2polygons(fOut);\n }\n }\n\n var opacitySetting = opacityFn ?\n {type: 'identity', property: 'mo'} :\n marker.opacity;\n\n Lib.extendFlat(fill.paint, {\n 'fill-color': {type: 'identity', property: 'fc'},\n 'fill-opacity': opacitySetting\n });\n\n Lib.extendFlat(line.paint, {\n 'line-color': lineColorFn ?\n {type: 'identity', property: 'mlc'} :\n markerLine.color,\n 'line-width': lineWidthFn ?\n {type: 'identity', property: 'mlw'} :\n markerLine.width,\n 'line-opacity': opacitySetting\n });\n\n fill.layout.visibility = 'visible';\n line.layout.visibility = 'visible';\n\n opts.geojson = {type: 'FeatureCollection', features: features};\n\n convertOnSelect(calcTrace);\n\n return opts;\n}\n\nfunction convertOnSelect(calcTrace) {\n var trace = calcTrace[0].trace;\n var opts = trace._opts;\n var opacitySetting;\n\n if(trace.selectedpoints) {\n var fns = Drawing.makeSelectedPointStyleFns(trace);\n\n for(var i = 0; i < calcTrace.length; i++) {\n var cdi = calcTrace[i];\n if(cdi.fOut) {\n cdi.fOut.properties.mo2 = fns.selectedOpacityFn(cdi);\n }\n }\n\n opacitySetting = {type: 'identity', property: 'mo2'};\n } else {\n opacitySetting = Lib.isArrayOrTypedArray(trace.marker.opacity) ?\n {type: 'identity', property: 'mo'} :\n trace.marker.opacity;\n }\n\n Lib.extendFlat(opts.fill.paint, {'fill-opacity': opacitySetting});\n Lib.extendFlat(opts.line.paint, {'line-opacity': opacitySetting});\n\n return opts;\n}\n\nmodule.exports = {\n convert: convert,\n convertOnSelect: convertOnSelect\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var locations = coerce('locations');\n var z = coerce('z');\n var geojson = coerce('geojson');\n\n if(!Lib.isArrayOrTypedArray(locations) || !locations.length ||\n !Lib.isArrayOrTypedArray(z) || !z.length ||\n !((typeof geojson === 'string' && geojson !== '') || Lib.isPlainObject(geojson))\n ) {\n traceOut.visible = false;\n return;\n }\n\n coerce('featureidkey');\n\n traceOut._length = Math.min(locations.length, z.length);\n\n coerce('below');\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n\n var mlw = coerce('marker.line.width');\n if(mlw) coerce('marker.line.color');\n coerce('marker.opacity');\n\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'z'});\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../heatmap/colorbar'),\n calc: require('../choropleth/calc'),\n plot: require('./plot'),\n hoverPoints: require('../choropleth/hover'),\n eventData: require('../choropleth/event_data'),\n selectPoints: require('../choropleth/select'),\n\n styleOnSelect: function(_, cd) {\n if(cd) {\n var trace = cd[0].trace;\n trace._glTrace.updateOnSelect(cd);\n }\n },\n\n getBelow: function(trace, subplot) {\n var mapLayers = subplot.getMapLayers();\n\n // find layer just above top-most \"water\" layer\n // that is not a plotly layer\n for(var i = mapLayers.length - 2; i >= 0; i--) {\n var layerId = mapLayers[i].id;\n\n if(typeof layerId === 'string' &&\n layerId.indexOf('water') === 0\n ) {\n for(var j = i + 1; j < mapLayers.length; j++) {\n layerId = mapLayers[j].id;\n\n if(typeof layerId === 'string' &&\n layerId.indexOf('plotly-') === -1\n ) {\n return layerId;\n }\n }\n }\n }\n },\n\n moduleType: 'trace',\n name: 'choroplethmap',\n basePlotModule: require('../../plots/map'),\n categories: ['map', 'gl', 'noOpacity', 'showLegend'],\n meta: {\n hr_name: 'choropleth_map',\n description: [\n 'GeoJSON features to be filled are set in `geojson`',\n 'The data that describes the choropleth value-to-color mapping',\n 'is set in `locations` and `z`.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar convert = require('./convert').convert;\nvar convertOnSelect = require('./convert').convertOnSelect;\nvar LAYER_PREFIX = require('../../plots/map/constants').traceLayerPrefix;\n\nfunction ChoroplethMap(subplot, uid) {\n this.type = 'choroplethmap';\n this.subplot = subplot;\n this.uid = uid;\n\n // N.B. fill and line layers share same source\n this.sourceId = 'source-' + uid;\n\n this.layerList = [\n ['fill', LAYER_PREFIX + uid + '-fill'],\n ['line', LAYER_PREFIX + uid + '-line']\n ];\n\n // previous 'below' value,\n // need this to update it properly\n this.below = null;\n}\n\nvar proto = ChoroplethMap.prototype;\n\nproto.update = function(calcTrace) {\n this._update(convert(calcTrace));\n\n // link ref for quick update during selections\n calcTrace[0].trace._glTrace = this;\n};\n\nproto.updateOnSelect = function(calcTrace) {\n this._update(convertOnSelect(calcTrace));\n};\n\nproto._update = function(optsAll) {\n var subplot = this.subplot;\n var layerList = this.layerList;\n var below = subplot.belowLookup['trace-' + this.uid];\n\n subplot.map\n .getSource(this.sourceId)\n .setData(optsAll.geojson);\n\n if(below !== this.below) {\n this._removeLayers();\n this._addLayers(optsAll, below);\n this.below = below;\n }\n\n for(var i = 0; i < layerList.length; i++) {\n var item = layerList[i];\n var k = item[0];\n var id = item[1];\n var opts = optsAll[k];\n\n subplot.setOptions(id, 'setLayoutProperty', opts.layout);\n\n if(opts.layout.visibility === 'visible') {\n subplot.setOptions(id, 'setPaintProperty', opts.paint);\n }\n }\n};\n\nproto._addLayers = function(optsAll, below) {\n var subplot = this.subplot;\n var layerList = this.layerList;\n var sourceId = this.sourceId;\n\n for(var i = 0; i < layerList.length; i++) {\n var item = layerList[i];\n var k = item[0];\n var opts = optsAll[k];\n\n subplot.addLayer({\n type: k,\n id: item[1],\n source: sourceId,\n layout: opts.layout,\n paint: opts.paint\n }, below);\n }\n};\n\nproto._removeLayers = function() {\n var map = this.subplot.map;\n var layerList = this.layerList;\n\n for(var i = layerList.length - 1; i >= 0; i--) {\n map.removeLayer(layerList[i][1]);\n }\n};\n\nproto.dispose = function() {\n var map = this.subplot.map;\n this._removeLayers();\n map.removeSource(this.sourceId);\n};\n\nmodule.exports = function createChoroplethMap(subplot, calcTrace) {\n var trace = calcTrace[0].trace;\n var choroplethMap = new ChoroplethMap(subplot, trace.uid);\n var sourceId = choroplethMap.sourceId;\n var optsAll = convert(calcTrace);\n var below = choroplethMap.below = subplot.belowLookup['trace-' + trace.uid];\n\n subplot.map.addSource(sourceId, {\n type: 'geojson',\n data: optsAll.geojson\n });\n\n choroplethMap._addLayers(optsAll, below);\n\n // link ref for quick update during selections\n calcTrace[0].trace._glTrace = choroplethMap;\n\n return choroplethMap;\n};\n","'use strict';\n\nvar choroplethAttrs = require('../choropleth/attributes');\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar baseAttrs = require('../../plots/attributes');\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nmodule.exports = extendFlat({\n locations: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets which features found in *geojson* to plot using',\n 'their feature `id` field.'\n ].join(' ')\n },\n\n // TODO\n // Maybe start with only one value (that we could name e.g. 'geojson-id'),\n // but eventually:\n // - we could also support for our own dist/topojson/*\n // .. and locationmode: choroplethAttrs.locationmode,\n\n z: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the color values.'\n },\n\n // TODO maybe we could also set a \"key\" to dig out values out of the\n // GeoJSON feature `properties` fields?\n\n geojson: {\n valType: 'any',\n editType: 'calc',\n description: [\n 'Sets the GeoJSON data associated with this trace.',\n\n 'It can be set as a valid GeoJSON object or as a URL string.',\n 'Note that we only accept GeoJSONs of type *FeatureCollection* or *Feature*',\n 'with geometries of type *Polygon* or *MultiPolygon*.'\n ].join(' ')\n },\n featureidkey: extendFlat({}, choroplethAttrs.featureidkey, {\n description: [\n 'Sets the key in GeoJSON features which is used as id to match the items',\n 'included in the `locations` array.',\n 'Support nested property, for example *properties.name*.'\n ].join(' ')\n }),\n\n // TODO agree on name / behaviour\n //\n // 'below' is used currently for layout.mapbox.layers,\n // even though it's not very plotly-esque.\n //\n // Note also, that the mapbox-gl style don't all have the same layers,\n // see https://codepen.io/etpinard/pen/ydVMwM for full list\n below: {\n valType: 'string',\n editType: 'plot',\n description: [\n 'Determines if the choropleth polygons will be inserted',\n 'before the layer with the specified ID.',\n 'By default, choroplethmapbox traces are placed above the water layers.',\n 'If set to \\'\\',',\n 'the layer will be inserted above every existing layer.'\n ].join(' ')\n },\n\n text: choroplethAttrs.text,\n hovertext: choroplethAttrs.hovertext,\n\n marker: {\n line: {\n color: extendFlat({}, choroplethAttrs.marker.line.color, {editType: 'plot'}),\n width: extendFlat({}, choroplethAttrs.marker.line.width, {editType: 'plot'}),\n editType: 'calc'\n },\n // TODO maybe having a dflt less than 1, together with `below:''` would be better?\n opacity: extendFlat({}, choroplethAttrs.marker.opacity, {editType: 'plot'}),\n editType: 'calc'\n },\n\n selected: {\n marker: {\n opacity: extendFlat({}, choroplethAttrs.selected.marker.opacity, {editType: 'plot'}),\n editType: 'plot'\n },\n editType: 'plot'\n },\n unselected: {\n marker: {\n opacity: extendFlat({}, choroplethAttrs.unselected.marker.opacity, {editType: 'plot'}),\n editType: 'plot'\n },\n editType: 'plot'\n },\n\n hoverinfo: choroplethAttrs.hoverinfo,\n hovertemplate: hovertemplateAttrs({}, {keys: ['properties']}),\n showlegend: extendFlat({}, baseAttrs.showlegend, {dflt: false})\n},\n\n colorScaleAttrs('', {\n cLetter: 'z',\n editTypeOverride: 'calc'\n })\n);\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar Colorscale = require('../../components/colorscale');\nvar Drawing = require('../../components/drawing');\n\nvar makeBlank = require('../../lib/geojson_utils').makeBlank;\nvar geoUtils = require('../../lib/geo_location_utils');\n\n/* N.B.\n *\n * We fetch the GeoJSON files \"ourselves\" (during\n * mapbox.prototype.fetchMapData) where they are stored in a global object\n * named `PlotlyGeoAssets` (same as for topojson files in `geo` subplots).\n *\n * Mapbox does allow using URLs as geojson sources, but does NOT allow filtering\n * features by feature `id` that are not numbers (more info in:\n * https://github.com/mapbox/mapbox-gl-js/issues/8088).\n */\n\nfunction convert(calcTrace) {\n var trace = calcTrace[0].trace;\n var isVisible = trace.visible === true && trace._length !== 0;\n\n var fill = {\n layout: {visibility: 'none'},\n paint: {}\n };\n\n var line = {\n layout: {visibility: 'none'},\n paint: {}\n };\n\n var opts = trace._opts = {\n fill: fill,\n line: line,\n geojson: makeBlank()\n };\n\n if(!isVisible) return opts;\n\n var features = geoUtils.extractTraceFeature(calcTrace);\n\n if(!features) return opts;\n\n var sclFunc = Colorscale.makeColorScaleFuncFromTrace(trace);\n var marker = trace.marker;\n var markerLine = marker.line || {};\n\n var opacityFn;\n if(Lib.isArrayOrTypedArray(marker.opacity)) {\n opacityFn = function(d) {\n var mo = d.mo;\n return isNumeric(mo) ? +Lib.constrain(mo, 0, 1) : 0;\n };\n }\n\n var lineColorFn;\n if(Lib.isArrayOrTypedArray(markerLine.color)) {\n lineColorFn = function(d) { return d.mlc; };\n }\n\n var lineWidthFn;\n if(Lib.isArrayOrTypedArray(markerLine.width)) {\n lineWidthFn = function(d) { return d.mlw; };\n }\n\n for(var i = 0; i < calcTrace.length; i++) {\n var cdi = calcTrace[i];\n var fOut = cdi.fOut;\n\n if(fOut) {\n var props = fOut.properties;\n props.fc = sclFunc(cdi.z);\n if(opacityFn) props.mo = opacityFn(cdi);\n if(lineColorFn) props.mlc = lineColorFn(cdi);\n if(lineWidthFn) props.mlw = lineWidthFn(cdi);\n cdi.ct = props.ct;\n cdi._polygons = geoUtils.feature2polygons(fOut);\n }\n }\n\n var opacitySetting = opacityFn ?\n {type: 'identity', property: 'mo'} :\n marker.opacity;\n\n Lib.extendFlat(fill.paint, {\n 'fill-color': {type: 'identity', property: 'fc'},\n 'fill-opacity': opacitySetting\n });\n\n Lib.extendFlat(line.paint, {\n 'line-color': lineColorFn ?\n {type: 'identity', property: 'mlc'} :\n markerLine.color,\n 'line-width': lineWidthFn ?\n {type: 'identity', property: 'mlw'} :\n markerLine.width,\n 'line-opacity': opacitySetting\n });\n\n fill.layout.visibility = 'visible';\n line.layout.visibility = 'visible';\n\n opts.geojson = {type: 'FeatureCollection', features: features};\n\n convertOnSelect(calcTrace);\n\n return opts;\n}\n\nfunction convertOnSelect(calcTrace) {\n var trace = calcTrace[0].trace;\n var opts = trace._opts;\n var opacitySetting;\n\n if(trace.selectedpoints) {\n var fns = Drawing.makeSelectedPointStyleFns(trace);\n\n for(var i = 0; i < calcTrace.length; i++) {\n var cdi = calcTrace[i];\n if(cdi.fOut) {\n cdi.fOut.properties.mo2 = fns.selectedOpacityFn(cdi);\n }\n }\n\n opacitySetting = {type: 'identity', property: 'mo2'};\n } else {\n opacitySetting = Lib.isArrayOrTypedArray(trace.marker.opacity) ?\n {type: 'identity', property: 'mo'} :\n trace.marker.opacity;\n }\n\n Lib.extendFlat(opts.fill.paint, {'fill-opacity': opacitySetting});\n Lib.extendFlat(opts.line.paint, {'line-opacity': opacitySetting});\n\n return opts;\n}\n\nmodule.exports = {\n convert: convert,\n convertOnSelect: convertOnSelect\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var locations = coerce('locations');\n var z = coerce('z');\n var geojson = coerce('geojson');\n\n if(!Lib.isArrayOrTypedArray(locations) || !locations.length ||\n !Lib.isArrayOrTypedArray(z) || !z.length ||\n !((typeof geojson === 'string' && geojson !== '') || Lib.isPlainObject(geojson))\n ) {\n traceOut.visible = false;\n return;\n }\n\n coerce('featureidkey');\n\n traceOut._length = Math.min(locations.length, z.length);\n\n coerce('below');\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n\n var mlw = coerce('marker.line.width');\n if(mlw) coerce('marker.line.color');\n coerce('marker.opacity');\n\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'z'});\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n","'use strict';\n\nvar deprecationWarning = [\n '*choroplethmapbox* trace is deprecated!',\n 'Please consider switching to the *choroplethmap* trace type and `map` subplots.',\n 'Learn more at: https://plotly.com/javascript/maplibre-migration/'\n].join(' ');\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../heatmap/colorbar'),\n calc: require('../choropleth/calc'),\n plot: require('./plot'),\n hoverPoints: require('../choropleth/hover'),\n eventData: require('../choropleth/event_data'),\n selectPoints: require('../choropleth/select'),\n\n styleOnSelect: function(_, cd) {\n if(cd) {\n var trace = cd[0].trace;\n trace._glTrace.updateOnSelect(cd);\n }\n },\n\n getBelow: function(trace, subplot) {\n var mapLayers = subplot.getMapLayers();\n\n // find layer just above top-most \"water\" layer\n // that is not a plotly layer\n for(var i = mapLayers.length - 2; i >= 0; i--) {\n var layerId = mapLayers[i].id;\n\n if(typeof layerId === 'string' &&\n layerId.indexOf('water') === 0\n ) {\n for(var j = i + 1; j < mapLayers.length; j++) {\n layerId = mapLayers[j].id;\n\n if(typeof layerId === 'string' &&\n layerId.indexOf('plotly-') === -1\n ) {\n return layerId;\n }\n }\n }\n }\n },\n\n moduleType: 'trace',\n name: 'choroplethmapbox',\n basePlotModule: require('../../plots/mapbox'),\n categories: ['mapbox', 'gl', 'noOpacity', 'showLegend'],\n meta: {\n hr_name: 'choropleth_mapbox',\n description: [\n deprecationWarning,\n 'GeoJSON features to be filled are set in `geojson`',\n 'The data that describes the choropleth value-to-color mapping',\n 'is set in `locations` and `z`.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar convert = require('./convert').convert;\nvar convertOnSelect = require('./convert').convertOnSelect;\nvar LAYER_PREFIX = require('../../plots/mapbox/constants').traceLayerPrefix;\n\nfunction ChoroplethMapbox(subplot, uid) {\n this.type = 'choroplethmapbox';\n this.subplot = subplot;\n this.uid = uid;\n\n // N.B. fill and line layers share same source\n this.sourceId = 'source-' + uid;\n\n this.layerList = [\n ['fill', LAYER_PREFIX + uid + '-fill'],\n ['line', LAYER_PREFIX + uid + '-line']\n ];\n\n // previous 'below' value,\n // need this to update it properly\n this.below = null;\n}\n\nvar proto = ChoroplethMapbox.prototype;\n\nproto.update = function(calcTrace) {\n this._update(convert(calcTrace));\n\n // link ref for quick update during selections\n calcTrace[0].trace._glTrace = this;\n};\n\nproto.updateOnSelect = function(calcTrace) {\n this._update(convertOnSelect(calcTrace));\n};\n\nproto._update = function(optsAll) {\n var subplot = this.subplot;\n var layerList = this.layerList;\n var below = subplot.belowLookup['trace-' + this.uid];\n\n subplot.map\n .getSource(this.sourceId)\n .setData(optsAll.geojson);\n\n if(below !== this.below) {\n this._removeLayers();\n this._addLayers(optsAll, below);\n this.below = below;\n }\n\n for(var i = 0; i < layerList.length; i++) {\n var item = layerList[i];\n var k = item[0];\n var id = item[1];\n var opts = optsAll[k];\n\n subplot.setOptions(id, 'setLayoutProperty', opts.layout);\n\n if(opts.layout.visibility === 'visible') {\n subplot.setOptions(id, 'setPaintProperty', opts.paint);\n }\n }\n};\n\nproto._addLayers = function(optsAll, below) {\n var subplot = this.subplot;\n var layerList = this.layerList;\n var sourceId = this.sourceId;\n\n for(var i = 0; i < layerList.length; i++) {\n var item = layerList[i];\n var k = item[0];\n var opts = optsAll[k];\n\n subplot.addLayer({\n type: k,\n id: item[1],\n source: sourceId,\n layout: opts.layout,\n paint: opts.paint\n }, below);\n }\n};\n\nproto._removeLayers = function() {\n var map = this.subplot.map;\n var layerList = this.layerList;\n\n for(var i = layerList.length - 1; i >= 0; i--) {\n map.removeLayer(layerList[i][1]);\n }\n};\n\nproto.dispose = function() {\n var map = this.subplot.map;\n this._removeLayers();\n map.removeSource(this.sourceId);\n};\n\nmodule.exports = function createChoroplethMapbox(subplot, calcTrace) {\n var trace = calcTrace[0].trace;\n var choroplethMapbox = new ChoroplethMapbox(subplot, trace.uid);\n var sourceId = choroplethMapbox.sourceId;\n var optsAll = convert(calcTrace);\n var below = choroplethMapbox.below = subplot.belowLookup['trace-' + trace.uid];\n\n subplot.map.addSource(sourceId, {\n type: 'geojson',\n data: optsAll.geojson\n });\n\n choroplethMapbox._addLayers(optsAll, below);\n\n // link ref for quick update during selections\n calcTrace[0].trace._glTrace = choroplethMapbox;\n\n return choroplethMapbox;\n};\n","'use strict';\n\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar mesh3dAttrs = require('../mesh3d/attributes');\nvar baseAttrs = require('../../plots/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar attrs = {\n x: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the x coordinates of the vector field',\n 'and of the displayed cones.'\n ].join(' ')\n },\n y: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the y coordinates of the vector field',\n 'and of the displayed cones.'\n ].join(' ')\n },\n z: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the z coordinates of the vector field',\n 'and of the displayed cones.'\n ].join(' ')\n },\n\n u: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the x components of the vector field.'\n },\n v: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the y components of the vector field.'\n },\n w: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the z components of the vector field.'\n },\n\n // TODO add way to specify cone positions independently of the vector field\n // provided, similar to MATLAB's coneplot Cx/Cy/Cz meshgrids,\n // see https://www.mathworks.com/help/matlab/ref/coneplot.html\n //\n // Alternatively, if our goal is only to 'fill in gaps' in the vector data,\n // we could try to extend the heatmap 'connectgaps' algorithm to 3D.\n // From AJ: this particular algorithm which amounts to a Poisson equation,\n // both for interpolation and extrapolation - is the right one to use for\n // cones too. It makes a field with zero divergence, which is a good\n // baseline assumption for vector fields.\n //\n // cones: {\n // // potential attributes to add:\n // //\n // // - meshmode: 'cartesian-product', 'pts', 'grid'\n // //\n // // under `meshmode: 'grid'`\n // // - (x|y|z)grid.start\n // // - (x|y|z)grid.end\n // // - (x|y|z)grid.size\n //\n // x: {\n // valType: 'data_array',\n // editType: 'calc',\n // description: 'Sets the x coordinates of the cones to be displayed.'\n // },\n // y: {\n // valType: 'data_array',\n // editType: 'calc',\n // description: 'Sets the y coordinates of the cones to be displayed.'\n // },\n // z: {\n // valType: 'data_array',\n // editType: 'calc',\n // description: 'Sets the z coordinates of the cones to be displayed.'\n // },\n //\n // editType: 'calc',\n // description: [\n // 'By setting `cones.x`, `cones.y` and `cones.z` to 1D arrays,',\n // 'plotly creates a mesh using the cartesian product of those 3 arrays.'\n // ].join(' ')\n // },\n\n sizemode: {\n valType: 'enumerated',\n values: ['scaled', 'absolute', 'raw'],\n editType: 'calc',\n dflt: 'scaled',\n description: [\n 'Determines whether `sizeref` is set as a *scaled* (i.e unitless) scalar',\n '(normalized by the max u/v/w norm in the vector field) or as',\n '*absolute* value (in the same units as the vector field).',\n 'To display sizes in actual vector length use *raw*.'\n ].join(' ')\n },\n sizeref: {\n valType: 'number',\n editType: 'calc',\n min: 0,\n description: [\n 'Adjusts the cone size scaling.',\n 'The size of the cones is determined by their u/v/w norm multiplied a factor and `sizeref`.',\n 'This factor (computed internally) corresponds to the minimum \"time\" to travel across',\n 'two successive x/y/z positions at the average velocity of those two successive positions.',\n 'All cones in a given trace use the same factor.',\n 'With `sizemode` set to *raw*, its default value is *1*.',\n 'With `sizemode` set to *scaled*, `sizeref` is unitless, its default value is *0.5*.',\n 'With `sizemode` set to *absolute*, `sizeref` has the same units as the u/v/w vector field,',\n 'its the default value is half the sample\\'s maximum vector norm.'\n ].join(' ')\n },\n\n anchor: {\n valType: 'enumerated',\n editType: 'calc',\n values: ['tip', 'tail', 'cm', 'center'],\n dflt: 'cm',\n description: [\n 'Sets the cones\\' anchor with respect to their x/y/z positions.',\n 'Note that *cm* denote the cone\\'s center of mass which corresponds to',\n '1/4 from the tail to tip.'\n ].join(' ')\n },\n\n text: {\n valType: 'string',\n dflt: '',\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Sets the text elements associated with the cones.',\n 'If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,',\n 'these elements will be seen in the hover labels.'\n ].join(' ')\n },\n hovertext: {\n valType: 'string',\n dflt: '',\n arrayOk: true,\n editType: 'calc',\n description: 'Same as `text`.'\n },\n\n hovertemplate: hovertemplateAttrs({editType: 'calc'}, {keys: ['norm']}),\n uhoverformat: axisHoverFormat('u', 1),\n vhoverformat: axisHoverFormat('v', 1),\n whoverformat: axisHoverFormat('w', 1),\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n zhoverformat: axisHoverFormat('z'),\n\n showlegend: extendFlat({}, baseAttrs.showlegend, {dflt: false})\n};\n\nextendFlat(attrs, colorScaleAttrs('', {\n colorAttr: 'u/v/w norm',\n showScaleDflt: true,\n editTypeOverride: 'calc'\n}));\n\nvar fromMesh3d = ['opacity', 'lightposition', 'lighting'];\n\nfromMesh3d.forEach(function(k) {\n attrs[k] = mesh3dAttrs[k];\n});\n\nattrs.hoverinfo = extendFlat({}, baseAttrs.hoverinfo, {\n editType: 'calc',\n flags: ['x', 'y', 'z', 'u', 'v', 'w', 'norm', 'text', 'name'],\n dflt: 'x+y+z+norm+text+name'\n});\n\nattrs.transforms = undefined;\n\nmodule.exports = attrs;\n","'use strict';\n\nvar colorscaleCalc = require('../../components/colorscale/calc');\n\nmodule.exports = function calc(gd, trace) {\n var u = trace.u;\n var v = trace.v;\n var w = trace.w;\n var len = Math.min(\n trace.x.length, trace.y.length, trace.z.length,\n u.length, v.length, w.length\n );\n var normMax = -Infinity;\n var normMin = Infinity;\n\n for(var i = 0; i < len; i++) {\n var uu = u[i];\n var vv = v[i];\n var ww = w[i];\n var norm = Math.sqrt(uu * uu + vv * vv + ww * ww);\n\n normMax = Math.max(normMax, norm);\n normMin = Math.min(normMin, norm);\n }\n\n trace._len = len;\n trace._normMax = normMax;\n\n colorscaleCalc(gd, trace, {\n vals: [normMin, normMax],\n containerStr: '',\n cLetter: 'c'\n });\n};\n","'use strict';\n\nvar conePlot = require('../../../stackgl_modules').gl_cone3d;\nvar createConeMesh = require('../../../stackgl_modules').gl_cone3d.createConeMesh;\n\nvar simpleMap = require('../../lib').simpleMap;\nvar parseColorScale = require('../../lib/gl_format_color').parseColorScale;\nvar extractOpts = require('../../components/colorscale').extractOpts;\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar zip3 = require('../../plots/gl3d/zip3');\n\nfunction Cone(scene, uid) {\n this.scene = scene;\n this.uid = uid;\n this.mesh = null;\n this.data = null;\n}\n\nvar proto = Cone.prototype;\n\nproto.handlePick = function(selection) {\n if(selection.object === this.mesh) {\n var selectIndex = selection.index = selection.data.index;\n var xx = this.data.x[selectIndex];\n var yy = this.data.y[selectIndex];\n var zz = this.data.z[selectIndex];\n var uu = this.data.u[selectIndex];\n var vv = this.data.v[selectIndex];\n var ww = this.data.w[selectIndex];\n\n selection.traceCoordinate = [\n xx, yy, zz,\n uu, vv, ww,\n Math.sqrt(uu * uu + vv * vv + ww * ww)\n ];\n\n var text = this.data.hovertext || this.data.text;\n if(isArrayOrTypedArray(text) && text[selectIndex] !== undefined) {\n selection.textLabel = text[selectIndex];\n } else if(text) {\n selection.textLabel = text;\n }\n\n return true;\n }\n};\n\nvar axisName2scaleIndex = {xaxis: 0, yaxis: 1, zaxis: 2};\nvar anchor2coneOffset = {tip: 1, tail: 0, cm: 0.25, center: 0.5};\nvar anchor2coneSpan = {tip: 1, tail: 1, cm: 0.75, center: 0.5};\n\nfunction convert(scene, trace) {\n var sceneLayout = scene.fullSceneLayout;\n var dataScale = scene.dataScale;\n var coneOpts = {};\n\n function toDataCoords(arr, axisName) {\n var ax = sceneLayout[axisName];\n var scale = dataScale[axisName2scaleIndex[axisName]];\n return simpleMap(arr, function(v) { return ax.d2l(v) * scale; });\n }\n\n coneOpts.vectors = zip3(\n toDataCoords(trace.u, 'xaxis'),\n toDataCoords(trace.v, 'yaxis'),\n toDataCoords(trace.w, 'zaxis'),\n trace._len\n );\n\n coneOpts.positions = zip3(\n toDataCoords(trace.x, 'xaxis'),\n toDataCoords(trace.y, 'yaxis'),\n toDataCoords(trace.z, 'zaxis'),\n trace._len\n );\n\n var cOpts = extractOpts(trace);\n coneOpts.colormap = parseColorScale(trace);\n coneOpts.vertexIntensityBounds = [cOpts.min / trace._normMax, cOpts.max / trace._normMax];\n coneOpts.coneOffset = anchor2coneOffset[trace.anchor];\n\n\n var sizemode = trace.sizemode;\n if(sizemode === 'scaled') {\n // unitless sizeref\n coneOpts.coneSize = trace.sizeref || 0.5;\n } else if(sizemode === 'absolute') {\n // sizeref here has unit of velocity\n coneOpts.coneSize = trace.sizeref && trace._normMax ?\n trace.sizeref / trace._normMax :\n 0.5;\n } else if(sizemode === 'raw') {\n coneOpts.coneSize = trace.sizeref;\n }\n coneOpts.coneSizemode = sizemode;\n\n var meshData = conePlot(coneOpts);\n\n // pass gl-mesh3d lighting attributes\n var lp = trace.lightposition;\n meshData.lightPosition = [lp.x, lp.y, lp.z];\n meshData.ambient = trace.lighting.ambient;\n meshData.diffuse = trace.lighting.diffuse;\n meshData.specular = trace.lighting.specular;\n meshData.roughness = trace.lighting.roughness;\n meshData.fresnel = trace.lighting.fresnel;\n meshData.opacity = trace.opacity;\n\n // stash autorange pad value\n trace._pad = anchor2coneSpan[trace.anchor] * meshData.vectorScale * meshData.coneScale * trace._normMax;\n\n return meshData;\n}\n\nproto.update = function(data) {\n this.data = data;\n\n var meshData = convert(this.scene, data);\n this.mesh.update(meshData);\n};\n\nproto.dispose = function() {\n this.scene.glplot.remove(this.mesh);\n this.mesh.dispose();\n};\n\nfunction createConeTrace(scene, data) {\n var gl = scene.glplot.gl;\n\n var meshData = convert(scene, data);\n var mesh = createConeMesh(gl, meshData);\n\n var cone = new Cone(scene, data.uid);\n cone.mesh = mesh;\n cone.data = data;\n mesh._trace = cone;\n\n scene.glplot.add(mesh);\n\n return cone;\n}\n\nmodule.exports = createConeTrace;\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var u = coerce('u');\n var v = coerce('v');\n var w = coerce('w');\n\n var x = coerce('x');\n var y = coerce('y');\n var z = coerce('z');\n\n if(\n !u || !u.length || !v || !v.length || !w || !w.length ||\n !x || !x.length || !y || !y.length || !z || !z.length\n ) {\n traceOut.visible = false;\n return;\n }\n\n var sizemode = coerce('sizemode');\n coerce('sizeref', sizemode === 'raw' ? 1 : 0.5);\n\n coerce('anchor');\n\n coerce('lighting.ambient');\n coerce('lighting.diffuse');\n coerce('lighting.specular');\n coerce('lighting.roughness');\n coerce('lighting.fresnel');\n coerce('lightposition.x');\n coerce('lightposition.y');\n coerce('lightposition.z');\n\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'c'});\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n coerce('uhoverformat');\n coerce('vhoverformat');\n coerce('whoverformat');\n coerce('xhoverformat');\n coerce('yhoverformat');\n coerce('zhoverformat');\n\n // disable 1D transforms (for now)\n traceOut._length = null;\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'cone',\n basePlotModule: require('../../plots/gl3d'),\n categories: ['gl3d', 'showLegend'],\n\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: {\n min: 'cmin',\n max: 'cmax'\n },\n calc: require('./calc'),\n plot: require('./convert'),\n eventData: function(out, pt) {\n out.norm = pt.traceCoordinate[6];\n return out;\n },\n\n meta: {\n description: [\n 'Use cone traces to visualize vector fields.',\n '',\n 'Specify a vector field using 6 1D arrays,',\n '3 position arrays `x`, `y` and `z`',\n 'and 3 vector component arrays `u`, `v`, `w`.',\n 'The cones are drawn exactly at the positions given',\n 'by `x`, `y` and `z`.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar heatmapAttrs = require('../heatmap/attributes');\nvar scatterAttrs = require('../scatter/attributes');\nvar axisFormat = require('../../plots/cartesian/axis_format_attributes');\nvar axisHoverFormat = axisFormat.axisHoverFormat;\nvar descriptionOnlyNumbers = axisFormat.descriptionOnlyNumbers;\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar dash = require('../../components/drawing/attributes').dash;\nvar fontAttrs = require('../../plots/font_attributes');\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar filterOps = require('../../constants/filter_ops');\nvar COMPARISON_OPS2 = filterOps.COMPARISON_OPS2;\nvar INTERVAL_OPS = filterOps.INTERVAL_OPS;\n\n\nvar scatterLineAttrs = scatterAttrs.line;\n\nmodule.exports = extendFlat({\n z: heatmapAttrs.z,\n x: heatmapAttrs.x,\n x0: heatmapAttrs.x0,\n dx: heatmapAttrs.dx,\n y: heatmapAttrs.y,\n y0: heatmapAttrs.y0,\n dy: heatmapAttrs.dy,\n\n xperiod: heatmapAttrs.xperiod,\n yperiod: heatmapAttrs.yperiod,\n xperiod0: scatterAttrs.xperiod0,\n yperiod0: scatterAttrs.yperiod0,\n xperiodalignment: heatmapAttrs.xperiodalignment,\n yperiodalignment: heatmapAttrs.yperiodalignment,\n\n text: heatmapAttrs.text,\n hovertext: heatmapAttrs.hovertext,\n transpose: heatmapAttrs.transpose,\n xtype: heatmapAttrs.xtype,\n ytype: heatmapAttrs.ytype,\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n zhoverformat: axisHoverFormat('z', 1),\n hovertemplate: heatmapAttrs.hovertemplate,\n texttemplate: extendFlat({}, heatmapAttrs.texttemplate, {\n description: [\n 'For this trace it only has an effect if `coloring` is set to *heatmap*.',\n heatmapAttrs.texttemplate.description\n ].join(' ')\n }),\n textfont: extendFlat({}, heatmapAttrs.textfont, {\n description: [\n 'For this trace it only has an effect if `coloring` is set to *heatmap*.',\n heatmapAttrs.textfont.description\n ].join(' ')\n }),\n hoverongaps: heatmapAttrs.hoverongaps,\n connectgaps: extendFlat({}, heatmapAttrs.connectgaps, {\n description: [\n 'Determines whether or not gaps',\n '(i.e. {nan} or missing values)',\n 'in the `z` data are filled in.',\n 'It is defaulted to true if `z` is a',\n 'one dimensional array',\n 'otherwise it is defaulted to false.'\n ].join(' ')\n }),\n\n fillcolor: {\n valType: 'color',\n editType: 'calc',\n description: [\n 'Sets the fill color if `contours.type` is *constraint*.',\n 'Defaults to a half-transparent variant of the line color,',\n 'marker color, or marker line color, whichever is available.'\n ].join(' ')\n },\n\n autocontour: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n impliedEdits: {\n 'contours.start': undefined,\n 'contours.end': undefined,\n 'contours.size': undefined\n },\n description: [\n 'Determines whether or not the contour level attributes are',\n 'picked by an algorithm.',\n 'If *true*, the number of contour levels can be set in `ncontours`.',\n 'If *false*, set the contour level attributes in `contours`.'\n ].join(' ')\n },\n ncontours: {\n valType: 'integer',\n dflt: 15,\n min: 1,\n editType: 'calc',\n description: [\n 'Sets the maximum number of contour levels. The actual number',\n 'of contours will be chosen automatically to be less than or',\n 'equal to the value of `ncontours`.',\n 'Has an effect only if `autocontour` is *true* or if',\n '`contours.size` is missing.'\n ].join(' ')\n },\n\n contours: {\n type: {\n valType: 'enumerated',\n values: ['levels', 'constraint'],\n dflt: 'levels',\n editType: 'calc',\n description: [\n 'If `levels`, the data is represented as a contour plot with multiple',\n 'levels displayed. If `constraint`, the data is represented as constraints',\n 'with the invalid region shaded as specified by the `operation` and',\n '`value` parameters.'\n ].join(' ')\n },\n start: {\n valType: 'number',\n dflt: null,\n editType: 'plot',\n impliedEdits: {'^autocontour': false},\n description: [\n 'Sets the starting contour level value.',\n 'Must be less than `contours.end`'\n ].join(' ')\n },\n end: {\n valType: 'number',\n dflt: null,\n editType: 'plot',\n impliedEdits: {'^autocontour': false},\n description: [\n 'Sets the end contour level value.',\n 'Must be more than `contours.start`'\n ].join(' ')\n },\n size: {\n valType: 'number',\n dflt: null,\n min: 0,\n editType: 'plot',\n impliedEdits: {'^autocontour': false},\n description: [\n 'Sets the step between each contour level.',\n 'Must be positive.'\n ].join(' ')\n },\n coloring: {\n valType: 'enumerated',\n values: ['fill', 'heatmap', 'lines', 'none'],\n dflt: 'fill',\n editType: 'calc',\n description: [\n 'Determines the coloring method showing the contour values.',\n 'If *fill*, coloring is done evenly between each contour level',\n 'If *heatmap*, a heatmap gradient coloring is applied',\n 'between each contour level.',\n 'If *lines*, coloring is done on the contour lines.',\n 'If *none*, no coloring is applied on this trace.'\n ].join(' ')\n },\n showlines: {\n valType: 'boolean',\n dflt: true,\n editType: 'plot',\n description: [\n 'Determines whether or not the contour lines are drawn.',\n 'Has an effect only if `contours.coloring` is set to *fill*.'\n ].join(' ')\n },\n showlabels: {\n valType: 'boolean',\n dflt: false,\n editType: 'plot',\n description: [\n 'Determines whether to label the contour lines with their values.'\n ].join(' ')\n },\n labelfont: fontAttrs({\n editType: 'plot',\n colorEditType: 'style',\n description: [\n 'Sets the font used for labeling the contour levels.',\n 'The default color comes from the lines, if shown.',\n 'The default family and size come from `layout.font`.'\n ].join(' '),\n }),\n labelformat: {\n valType: 'string',\n dflt: '',\n editType: 'plot',\n description: descriptionOnlyNumbers('contour label')\n },\n operation: {\n valType: 'enumerated',\n values: [].concat(COMPARISON_OPS2).concat(INTERVAL_OPS),\n dflt: '=',\n editType: 'calc',\n description: [\n 'Sets the constraint operation.',\n\n '*=* keeps regions equal to `value`',\n\n '*<* and *<=* keep regions less than `value`',\n\n '*>* and *>=* keep regions greater than `value`',\n\n '*[]*, *()*, *[)*, and *(]* keep regions inside `value[0]` to `value[1]`',\n\n '*][*, *)(*, *](*, *)[* keep regions outside `value[0]` to value[1]`',\n\n 'Open vs. closed intervals make no difference to constraint display, but',\n 'all versions are allowed for consistency with filter transforms.'\n ].join(' ')\n },\n value: {\n valType: 'any',\n dflt: 0,\n editType: 'calc',\n description: [\n 'Sets the value or values of the constraint boundary.',\n\n 'When `operation` is set to one of the comparison values',\n '(' + COMPARISON_OPS2 + ')',\n '*value* is expected to be a number.',\n\n 'When `operation` is set to one of the interval values',\n '(' + INTERVAL_OPS + ')',\n '*value* is expected to be an array of two numbers where the first',\n 'is the lower bound and the second is the upper bound.',\n ].join(' ')\n },\n editType: 'calc',\n impliedEdits: {autocontour: false}\n },\n\n line: {\n color: extendFlat({}, scatterLineAttrs.color, {\n editType: 'style+colorbars',\n description: [\n 'Sets the color of the contour level.',\n 'Has no effect if `contours.coloring` is set to *lines*.'\n ].join(' ')\n }),\n width: {\n valType: 'number',\n min: 0,\n editType: 'style+colorbars',\n description: [\n 'Sets the contour line width in (in px)',\n 'Defaults to *0.5* when `contours.type` is *levels*.',\n 'Defaults to *2* when `contour.type` is *constraint*.'\n ].join(' ')\n },\n dash: dash,\n smoothing: extendFlat({}, scatterLineAttrs.smoothing, {\n description: [\n 'Sets the amount of smoothing for the contour lines,',\n 'where *0* corresponds to no smoothing.'\n ].join(' ')\n }),\n editType: 'plot'\n },\n zorder: scatterAttrs.zorder\n},\n colorScaleAttrs('', {\n cLetter: 'z',\n autoColorDflt: false,\n editTypeOverride: 'calc'\n })\n);\n","'use strict';\n\nvar Colorscale = require('../../components/colorscale');\n\nvar heatmapCalc = require('../heatmap/calc');\nvar setContours = require('./set_contours');\nvar endPlus = require('./end_plus');\n\n// most is the same as heatmap calc, then adjust it\n// though a few things inside heatmap calc still look for\n// contour maps, because the makeBoundArray calls are too entangled\nmodule.exports = function calc(gd, trace) {\n var cd = heatmapCalc(gd, trace);\n\n var zOut = cd[0].z;\n setContours(trace, zOut);\n\n var contours = trace.contours;\n var cOpts = Colorscale.extractOpts(trace);\n var cVals;\n\n if(contours.coloring === 'heatmap' && cOpts.auto && trace.autocontour === false) {\n var start = contours.start;\n var end = endPlus(contours);\n var cs = contours.size || 1;\n var nc = Math.floor((end - start) / cs) + 1;\n\n if(!isFinite(cs)) {\n cs = 1;\n nc = 1;\n }\n\n var min0 = start - cs / 2;\n var max0 = min0 + nc * cs;\n cVals = [min0, max0];\n } else {\n cVals = zOut;\n }\n\n Colorscale.calc(gd, trace, {vals: cVals, cLetter: 'z'});\n\n return cd;\n};\n","'use strict';\n\nmodule.exports = function(pathinfo, contours) {\n var pi0 = pathinfo[0];\n var z = pi0.z;\n var i;\n\n switch(contours.type) {\n case 'levels':\n // Why (just) use z[0][0] and z[0][1]?\n //\n // N.B. using boundaryMin instead of edgeVal2 here makes the\n // `contour_scatter` mock fail\n var edgeVal2 = Math.min(z[0][0], z[0][1]);\n\n for(i = 0; i < pathinfo.length; i++) {\n var pi = pathinfo[i];\n pi.prefixBoundary = !pi.edgepaths.length &&\n (edgeVal2 > pi.level || pi.starts.length && edgeVal2 === pi.level);\n }\n break;\n case 'constraint':\n // after convertToConstraints, pathinfo has length=0\n pi0.prefixBoundary = false;\n\n // joinAllPaths does enough already when edgepaths are present\n if(pi0.edgepaths.length) return;\n\n var na = pi0.x.length;\n var nb = pi0.y.length;\n var boundaryMax = -Infinity;\n var boundaryMin = Infinity;\n\n for(i = 0; i < nb; i++) {\n boundaryMin = Math.min(boundaryMin, z[i][0]);\n boundaryMin = Math.min(boundaryMin, z[i][na - 1]);\n boundaryMax = Math.max(boundaryMax, z[i][0]);\n boundaryMax = Math.max(boundaryMax, z[i][na - 1]);\n }\n for(i = 1; i < na - 1; i++) {\n boundaryMin = Math.min(boundaryMin, z[0][i]);\n boundaryMin = Math.min(boundaryMin, z[nb - 1][i]);\n boundaryMax = Math.max(boundaryMax, z[0][i]);\n boundaryMax = Math.max(boundaryMax, z[nb - 1][i]);\n }\n\n var contoursValue = contours.value;\n var v1, v2;\n\n switch(contours._operation) {\n case '>':\n if(contoursValue > boundaryMax) {\n pi0.prefixBoundary = true;\n }\n break;\n case '<':\n if(contoursValue < boundaryMin ||\n (pi0.starts.length && contoursValue === boundaryMin)) {\n pi0.prefixBoundary = true;\n }\n break;\n case '[]':\n v1 = Math.min(contoursValue[0], contoursValue[1]);\n v2 = Math.max(contoursValue[0], contoursValue[1]);\n if(v2 < boundaryMin || v1 > boundaryMax ||\n (pi0.starts.length && v2 === boundaryMin)) {\n pi0.prefixBoundary = true;\n }\n break;\n case '][':\n v1 = Math.min(contoursValue[0], contoursValue[1]);\n v2 = Math.max(contoursValue[0], contoursValue[1]);\n if(v1 < boundaryMin && v2 > boundaryMax) {\n pi0.prefixBoundary = true;\n }\n break;\n }\n break;\n }\n};\n","'use strict';\n\nvar Colorscale = require('../../components/colorscale');\nvar makeColorMap = require('./make_color_map');\nvar endPlus = require('./end_plus');\n\nfunction calc(gd, trace, opts) {\n var contours = trace.contours;\n var line = trace.line;\n var cs = contours.size || 1;\n var coloring = contours.coloring;\n var colorMap = makeColorMap(trace, {isColorbar: true});\n\n if(coloring === 'heatmap') {\n var cOpts = Colorscale.extractOpts(trace);\n opts._fillgradient = cOpts.reversescale ?\n Colorscale.flipScale(cOpts.colorscale) :\n cOpts.colorscale;\n opts._zrange = [cOpts.min, cOpts.max];\n } else if(coloring === 'fill') {\n opts._fillcolor = colorMap;\n }\n\n opts._line = {\n color: coloring === 'lines' ? colorMap : line.color,\n width: contours.showlines !== false ? line.width : 0,\n dash: line.dash\n };\n\n opts._levels = {\n start: contours.start,\n end: endPlus(contours),\n size: cs\n };\n}\n\nmodule.exports = {\n min: 'zmin',\n max: 'zmax',\n calc: calc\n};\n","'use strict';\nmodule.exports = {\n // some constants to help with marching squares algorithm\n // where does the path start for each index?\n BOTTOMSTART: [1, 9, 13, 104, 713],\n TOPSTART: [4, 6, 7, 104, 713],\n LEFTSTART: [8, 12, 14, 208, 1114],\n RIGHTSTART: [2, 3, 11, 208, 1114],\n\n // which way [dx,dy] do we leave a given index?\n // saddles are already disambiguated\n NEWDELTA: [\n null, [-1, 0], [0, -1], [-1, 0],\n [1, 0], null, [0, -1], [-1, 0],\n [0, 1], [0, 1], null, [0, 1],\n [1, 0], [1, 0], [0, -1]\n ],\n\n // for each saddle, the first index here is used\n // for dx||dy<0, the second for dx||dy>0\n CHOOSESADDLE: {\n 104: [4, 1],\n 208: [2, 8],\n 713: [7, 13],\n 1114: [11, 14]\n },\n\n // after one index has been used for a saddle, which do we\n // substitute to be used up later?\n SADDLEREMAINDER: {1: 4, 2: 8, 4: 1, 7: 13, 8: 2, 11: 14, 13: 7, 14: 11},\n\n // length of a contour, as a multiple of the plot area diagonal, per label\n LABELDISTANCE: 2,\n\n // number of contour levels after which we start increasing the number of\n // labels we draw. Many contours means they will generally be close\n // together, so it will be harder to follow a long way to find a label\n LABELINCREASE: 10,\n\n // minimum length of a contour line, as a multiple of the label length,\n // at which we draw *any* labels\n LABELMIN: 3,\n\n // max number of labels to draw on a single contour path, no matter how long\n LABELMAX: 10,\n\n // constants for the label position cost function\n LABELOPTIMIZER: {\n // weight given to edge proximity\n EDGECOST: 1,\n // weight given to the angle off horizontal\n ANGLECOST: 1,\n // weight given to distance from already-placed labels\n NEIGHBORCOST: 5,\n // cost multiplier for labels on the same level\n SAMELEVELFACTOR: 10,\n // minimum distance (as a multiple of the label length)\n // for labels on the same level\n SAMELEVELDISTANCE: 5,\n // maximum cost before we won't even place the label\n MAXCOST: 100,\n // number of evenly spaced points to look at in the first\n // iteration of the search\n INITIALSEARCHPOINTS: 10,\n // number of binary search iterations after the initial wide search\n ITERATIONS: 5\n }\n};\n","'use strict';\nvar isNumeric = require('fast-isnumeric');\n\nvar handleLabelDefaults = require('./label_defaults');\n\nvar Color = require('../../components/color');\nvar addOpacity = Color.addOpacity;\nvar opacity = Color.opacity;\n\nvar filterOps = require('../../constants/filter_ops');\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar CONSTRAINT_REDUCTION = filterOps.CONSTRAINT_REDUCTION;\nvar COMPARISON_OPS2 = filterOps.COMPARISON_OPS2;\n\nmodule.exports = function handleConstraintDefaults(traceIn, traceOut, coerce, layout, defaultColor, opts) {\n var contours = traceOut.contours;\n var showLines, lineColor, fillColor;\n\n var operation = coerce('contours.operation');\n contours._operation = CONSTRAINT_REDUCTION[operation];\n\n handleConstraintValueDefaults(coerce, contours);\n\n if(operation === '=') {\n showLines = contours.showlines = true;\n } else {\n showLines = coerce('contours.showlines');\n fillColor = coerce('fillcolor', addOpacity(\n (traceIn.line || {}).color || defaultColor, 0.5\n ));\n }\n\n if(showLines) {\n var lineDfltColor = fillColor && opacity(fillColor) ?\n addOpacity(traceOut.fillcolor, 1) :\n defaultColor;\n lineColor = coerce('line.color', lineDfltColor);\n coerce('line.width', 2);\n coerce('line.dash');\n }\n\n coerce('line.smoothing');\n\n handleLabelDefaults(coerce, layout, lineColor, opts);\n};\n\nfunction handleConstraintValueDefaults(coerce, contours) {\n var zvalue;\n\n if(COMPARISON_OPS2.indexOf(contours.operation) === -1) {\n // Requires an array of two numbers:\n coerce('contours.value', [0, 1]);\n\n if(!isArrayOrTypedArray(contours.value)) {\n if(isNumeric(contours.value)) {\n zvalue = parseFloat(contours.value);\n contours.value = [zvalue, zvalue + 1];\n }\n } else if(contours.value.length > 2) {\n contours.value = contours.value.slice(2);\n } else if(contours.length === 0) {\n contours.value = [0, 1];\n } else if(contours.length < 2) {\n zvalue = parseFloat(contours.value[0]);\n contours.value = [zvalue, zvalue + 1];\n } else {\n contours.value = [\n parseFloat(contours.value[0]),\n parseFloat(contours.value[1])\n ];\n }\n } else {\n // Requires a single scalar:\n coerce('contours.value', 0);\n\n if(!isNumeric(contours.value)) {\n if(isArrayOrTypedArray(contours.value)) {\n contours.value = parseFloat(contours.value[0]);\n } else {\n contours.value = 0;\n }\n }\n }\n}\n","'use strict';\n\nvar filterOps = require('../../constants/filter_ops');\nvar isNumeric = require('fast-isnumeric');\n\n// This syntax conforms to the existing filter transform syntax, but we don't care\n// about open vs. closed intervals for simply drawing contours constraints:\nmodule.exports = {\n '[]': makeRangeSettings('[]'),\n '][': makeRangeSettings(']['),\n '>': makeInequalitySettings('>'),\n '<': makeInequalitySettings('<'),\n '=': makeInequalitySettings('=')\n};\n\n// This does not in any way shape or form support calendars. It's adapted from\n// transforms/filter.js.\nfunction coerceValue(operation, value) {\n var hasArrayValue = Array.isArray(value);\n\n var coercedValue;\n\n function coerce(value) {\n return isNumeric(value) ? (+value) : null;\n }\n\n if(filterOps.COMPARISON_OPS2.indexOf(operation) !== -1) {\n coercedValue = hasArrayValue ? coerce(value[0]) : coerce(value);\n } else if(filterOps.INTERVAL_OPS.indexOf(operation) !== -1) {\n coercedValue = hasArrayValue ?\n [coerce(value[0]), coerce(value[1])] :\n [coerce(value), coerce(value)];\n } else if(filterOps.SET_OPS.indexOf(operation) !== -1) {\n coercedValue = hasArrayValue ? value.map(coerce) : [coerce(value)];\n }\n\n return coercedValue;\n}\n\n// Returns a parabola scaled so that the min/max is either +/- 1 and zero at the two values\n// provided. The data is mapped by this function when constructing intervals so that it's\n// very easy to construct contours as normal.\nfunction makeRangeSettings(operation) {\n return function(value) {\n value = coerceValue(operation, value);\n\n // Ensure proper ordering:\n var min = Math.min(value[0], value[1]);\n var max = Math.max(value[0], value[1]);\n\n return {\n start: min,\n end: max,\n size: max - min\n };\n };\n}\n\nfunction makeInequalitySettings(operation) {\n return function(value) {\n value = coerceValue(operation, value);\n\n return {\n start: value,\n end: Infinity,\n size: Infinity\n };\n };\n}\n","'use strict';\n\nmodule.exports = function handleContourDefaults(traceIn, traceOut, coerce, coerce2) {\n var contourStart = coerce2('contours.start');\n var contourEnd = coerce2('contours.end');\n var missingEnd = (contourStart === false) || (contourEnd === false);\n\n // normally we only need size if autocontour is off. But contour.calc\n // pushes its calculated contour size back to the input trace, so for\n // things like restyle that can call supplyDefaults without calc\n // after the initial draw, we can just reuse the previous calculation\n var contourSize = coerce('contours.size');\n var autoContour;\n\n if(missingEnd) autoContour = traceOut.autocontour = true;\n else autoContour = coerce('autocontour', false);\n\n if(autoContour || !contourSize) coerce('ncontours');\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\n// The contour extraction is great, except it totally fails for constraints because we\n// need weird range loops and flipped contours instead of the usual format. This function\n// does some weird manipulation of the extracted pathinfo data such that it magically\n// draws contours correctly *as* constraints.\n//\n// ** I do not know which \"weird range loops\" the comment above is referring to.\nmodule.exports = function(pathinfo, operation) {\n var i, pi0, pi1;\n\n var op0 = function(arr) { return arr.reverse(); };\n var op1 = function(arr) { return arr; };\n\n switch(operation) {\n case '=':\n case '<':\n return pathinfo;\n case '>':\n if(pathinfo.length !== 1) {\n Lib.warn('Contour data invalid for the specified inequality operation.');\n }\n\n // In this case there should be exactly one contour levels in pathinfo.\n // We flip all of the data. This will draw the contour as closed.\n pi0 = pathinfo[0];\n\n for(i = 0; i < pi0.edgepaths.length; i++) {\n pi0.edgepaths[i] = op0(pi0.edgepaths[i]);\n }\n for(i = 0; i < pi0.paths.length; i++) {\n pi0.paths[i] = op0(pi0.paths[i]);\n }\n for(i = 0; i < pi0.starts.length; i++) {\n pi0.starts[i] = op0(pi0.starts[i]);\n }\n\n return pathinfo;\n case '][':\n var tmp = op0;\n op0 = op1;\n op1 = tmp;\n // It's a nice rule, except this definitely *is* what's intended here.\n /* eslint-disable: no-fallthrough */\n case '[]':\n /* eslint-enable: no-fallthrough */\n if(pathinfo.length !== 2) {\n Lib.warn('Contour data invalid for the specified inequality range operation.');\n }\n\n // In this case there should be exactly two contour levels in pathinfo.\n // - We concatenate the info into one pathinfo.\n // - We must also flip all of the data in the `[]` case.\n // This will draw the contours as closed.\n pi0 = copyPathinfo(pathinfo[0]);\n pi1 = copyPathinfo(pathinfo[1]);\n\n for(i = 0; i < pi0.edgepaths.length; i++) {\n pi0.edgepaths[i] = op0(pi0.edgepaths[i]);\n }\n for(i = 0; i < pi0.paths.length; i++) {\n pi0.paths[i] = op0(pi0.paths[i]);\n }\n for(i = 0; i < pi0.starts.length; i++) {\n pi0.starts[i] = op0(pi0.starts[i]);\n }\n\n while(pi1.edgepaths.length) {\n pi0.edgepaths.push(op1(pi1.edgepaths.shift()));\n }\n while(pi1.paths.length) {\n pi0.paths.push(op1(pi1.paths.shift()));\n }\n while(pi1.starts.length) {\n pi0.starts.push(op1(pi1.starts.shift()));\n }\n\n return [pi0];\n }\n};\n\nfunction copyPathinfo(pi) {\n return Lib.extendFlat({}, pi, {\n edgepaths: Lib.extendDeep([], pi.edgepaths),\n paths: Lib.extendDeep([], pi.paths),\n starts: Lib.extendDeep([], pi.starts)\n });\n}\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar handleXYZDefaults = require('../heatmap/xyz_defaults');\nvar handlePeriodDefaults = require('../scatter/period_defaults');\nvar handleConstraintDefaults = require('./constraint_defaults');\nvar handleContoursDefaults = require('./contours_defaults');\nvar handleStyleDefaults = require('./style_defaults');\nvar handleHeatmapLabelDefaults = require('../heatmap/label_defaults');\nvar attributes = require('./attributes');\n\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n function coerce2(attr) {\n return Lib.coerce2(traceIn, traceOut, attributes, attr);\n }\n\n var len = handleXYZDefaults(traceIn, traceOut, coerce, layout);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n handlePeriodDefaults(traceIn, traceOut, layout, coerce);\n coerce('xhoverformat');\n coerce('yhoverformat');\n\n coerce('text');\n coerce('hovertext');\n coerce('hoverongaps');\n coerce('hovertemplate');\n\n var isConstraint = (coerce('contours.type') === 'constraint');\n coerce('connectgaps', Lib.isArray1D(traceOut.z));\n\n if(isConstraint) {\n handleConstraintDefaults(traceIn, traceOut, coerce, layout, defaultColor);\n } else {\n handleContoursDefaults(traceIn, traceOut, coerce, coerce2);\n handleStyleDefaults(traceIn, traceOut, coerce, layout);\n }\n\n if(\n traceOut.contours &&\n traceOut.contours.coloring === 'heatmap'\n ) {\n handleHeatmapLabelDefaults(coerce, layout);\n }\n coerce('zorder');\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar constraintMapping = require('./constraint_mapping');\nvar endPlus = require('./end_plus');\n\nmodule.exports = function emptyPathinfo(contours, plotinfo, cd0) {\n var contoursFinal = (contours.type === 'constraint') ?\n constraintMapping[contours._operation](contours.value) :\n contours;\n\n var cs = contoursFinal.size;\n var pathinfo = [];\n var end = endPlus(contoursFinal);\n\n var carpet = cd0.trace._carpetTrace;\n\n var basePathinfo = carpet ? {\n // store axes so we can convert to px\n xaxis: carpet.aaxis,\n yaxis: carpet.baxis,\n // full data arrays to use for interpolation\n x: cd0.a,\n y: cd0.b\n } : {\n xaxis: plotinfo.xaxis,\n yaxis: plotinfo.yaxis,\n x: cd0.x,\n y: cd0.y\n };\n\n for(var ci = contoursFinal.start; ci < end; ci += cs) {\n pathinfo.push(Lib.extendFlat({\n level: ci,\n // all the cells with nontrivial marching index\n crossings: {},\n // starting points on the edges of the lattice for each contour\n starts: [],\n // all unclosed paths (may have less items than starts,\n // if a path is closed by rounding)\n edgepaths: [],\n // all closed paths\n paths: [],\n z: cd0.z,\n smoothing: cd0.trace.line.smoothing\n }, basePathinfo));\n\n if(pathinfo.length > 1000) {\n Lib.warn('Too many contours, clipping at 1000', contours);\n break;\n }\n }\n return pathinfo;\n};\n","'use strict';\n\n/*\n * tiny helper to move the end of the contours a little to prevent\n * losing the last contour to rounding errors\n */\nmodule.exports = function endPlus(contours) {\n return contours.end + contours.size / 1e6;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar constants = require('./constants');\n\nmodule.exports = function findAllPaths(pathinfo, xtol, ytol) {\n var cnt,\n startLoc,\n i,\n pi,\n j;\n\n // Default just passes these values through as they were before:\n xtol = xtol || 0.01;\n ytol = ytol || 0.01;\n\n for(i = 0; i < pathinfo.length; i++) {\n pi = pathinfo[i];\n\n for(j = 0; j < pi.starts.length; j++) {\n startLoc = pi.starts[j];\n makePath(pi, startLoc, 'edge', xtol, ytol);\n }\n\n cnt = 0;\n while(Object.keys(pi.crossings).length && cnt < 10000) {\n cnt++;\n startLoc = Object.keys(pi.crossings)[0].split(',').map(Number);\n makePath(pi, startLoc, undefined, xtol, ytol);\n }\n if(cnt === 10000) Lib.log('Infinite loop in contour?');\n }\n};\n\nfunction equalPts(pt1, pt2, xtol, ytol) {\n return Math.abs(pt1[0] - pt2[0]) < xtol &&\n Math.abs(pt1[1] - pt2[1]) < ytol;\n}\n\n// distance in index units - uses the 3rd and 4th items in points\nfunction ptDist(pt1, pt2) {\n var dx = pt1[2] - pt2[2];\n var dy = pt1[3] - pt2[3];\n return Math.sqrt(dx * dx + dy * dy);\n}\n\nfunction makePath(pi, loc, edgeflag, xtol, ytol) {\n var locStr = loc.join(',');\n var mi = pi.crossings[locStr];\n var marchStep = getStartStep(mi, edgeflag, loc);\n // start by going backward a half step and finding the crossing point\n var pts = [getInterpPx(pi, loc, [-marchStep[0], -marchStep[1]])];\n var m = pi.z.length;\n var n = pi.z[0].length;\n var startLoc = loc.slice();\n var startStep = marchStep.slice();\n var cnt;\n\n // now follow the path\n for(cnt = 0; cnt < 10000; cnt++) { // just to avoid infinite loops\n if(mi > 20) {\n mi = constants.CHOOSESADDLE[mi][(marchStep[0] || marchStep[1]) < 0 ? 0 : 1];\n pi.crossings[locStr] = constants.SADDLEREMAINDER[mi];\n } else {\n delete pi.crossings[locStr];\n }\n\n marchStep = constants.NEWDELTA[mi];\n if(!marchStep) {\n Lib.log('Found bad marching index:', mi, loc, pi.level);\n break;\n }\n\n // find the crossing a half step forward, and then take the full step\n pts.push(getInterpPx(pi, loc, marchStep));\n loc[0] += marchStep[0];\n loc[1] += marchStep[1];\n locStr = loc.join(',');\n\n // don't include the same point multiple times\n if(equalPts(pts[pts.length - 1], pts[pts.length - 2], xtol, ytol)) pts.pop();\n\n var atEdge = (marchStep[0] && (loc[0] < 0 || loc[0] > n - 2)) ||\n (marchStep[1] && (loc[1] < 0 || loc[1] > m - 2));\n\n var closedLoop = loc[0] === startLoc[0] && loc[1] === startLoc[1] &&\n marchStep[0] === startStep[0] && marchStep[1] === startStep[1];\n\n // have we completed a loop, or reached an edge?\n if((closedLoop) || (edgeflag && atEdge)) break;\n\n mi = pi.crossings[locStr];\n }\n\n if(cnt === 10000) {\n Lib.log('Infinite loop in contour?');\n }\n var closedpath = equalPts(pts[0], pts[pts.length - 1], xtol, ytol);\n var totaldist = 0;\n var distThresholdFactor = 0.2 * pi.smoothing;\n var alldists = [];\n var cropstart = 0;\n var distgroup, cnt2, cnt3, newpt, ptcnt, ptavg, thisdist,\n i, j, edgepathi, edgepathj;\n\n /*\n * Check for points that are too close together (<1/5 the average dist\n * *in grid index units* (important for log axes and nonuniform grids),\n * less if less smoothed) and just take the center (or avg of center 2).\n * This cuts down on funny behavior when a point is very close to a\n * contour level.\n */\n for(cnt = 1; cnt < pts.length; cnt++) {\n thisdist = ptDist(pts[cnt], pts[cnt - 1]);\n totaldist += thisdist;\n alldists.push(thisdist);\n }\n\n var distThreshold = totaldist / alldists.length * distThresholdFactor;\n\n function getpt(i) { return pts[i % pts.length]; }\n\n for(cnt = pts.length - 2; cnt >= cropstart; cnt--) {\n distgroup = alldists[cnt];\n if(distgroup < distThreshold) {\n cnt3 = 0;\n for(cnt2 = cnt - 1; cnt2 >= cropstart; cnt2--) {\n if(distgroup + alldists[cnt2] < distThreshold) {\n distgroup += alldists[cnt2];\n } else break;\n }\n\n // closed path with close points wrapping around the boundary?\n if(closedpath && cnt === pts.length - 2) {\n for(cnt3 = 0; cnt3 < cnt2; cnt3++) {\n if(distgroup + alldists[cnt3] < distThreshold) {\n distgroup += alldists[cnt3];\n } else break;\n }\n }\n ptcnt = cnt - cnt2 + cnt3 + 1;\n ptavg = Math.floor((cnt + cnt2 + cnt3 + 2) / 2);\n\n // either endpoint included: keep the endpoint\n if(!closedpath && cnt === pts.length - 2) newpt = pts[pts.length - 1];\n else if(!closedpath && cnt2 === -1) newpt = pts[0];\n\n // odd # of points - just take the central one\n else if(ptcnt % 2) newpt = getpt(ptavg);\n\n // even # of pts - average central two\n else {\n newpt = [(getpt(ptavg)[0] + getpt(ptavg + 1)[0]) / 2,\n (getpt(ptavg)[1] + getpt(ptavg + 1)[1]) / 2];\n }\n\n pts.splice(cnt2 + 1, cnt - cnt2 + 1, newpt);\n cnt = cnt2 + 1;\n if(cnt3) cropstart = cnt3;\n if(closedpath) {\n if(cnt === pts.length - 2) pts[cnt3] = pts[pts.length - 1];\n else if(cnt === 0) pts[pts.length - 1] = pts[0];\n }\n }\n }\n pts.splice(0, cropstart);\n\n // done with the index parts - remove them so path generation works right\n // because it depends on only having [xpx, ypx]\n for(cnt = 0; cnt < pts.length; cnt++) pts[cnt].length = 2;\n\n // don't return single-point paths (ie all points were the same\n // so they got deleted?)\n if(pts.length < 2) return;\n else if(closedpath) {\n pts.pop();\n pi.paths.push(pts);\n } else {\n if(!edgeflag) {\n Lib.log('Unclosed interior contour?',\n pi.level, startLoc.join(','), pts.join('L'));\n }\n\n // edge path - does it start where an existing edge path ends, or vice versa?\n var merged = false;\n for(i = 0; i < pi.edgepaths.length; i++) {\n edgepathi = pi.edgepaths[i];\n if(!merged && equalPts(edgepathi[0], pts[pts.length - 1], xtol, ytol)) {\n pts.pop();\n merged = true;\n\n // now does it ALSO meet the end of another (or the same) path?\n var doublemerged = false;\n for(j = 0; j < pi.edgepaths.length; j++) {\n edgepathj = pi.edgepaths[j];\n if(equalPts(edgepathj[edgepathj.length - 1], pts[0], xtol, ytol)) {\n doublemerged = true;\n pts.shift();\n pi.edgepaths.splice(i, 1);\n if(j === i) {\n // the path is now closed\n pi.paths.push(pts.concat(edgepathj));\n } else {\n if(j > i) j--;\n pi.edgepaths[j] = edgepathj.concat(pts, edgepathi);\n }\n break;\n }\n }\n if(!doublemerged) {\n pi.edgepaths[i] = pts.concat(edgepathi);\n }\n }\n }\n for(i = 0; i < pi.edgepaths.length; i++) {\n if(merged) break;\n edgepathi = pi.edgepaths[i];\n if(equalPts(edgepathi[edgepathi.length - 1], pts[0], xtol, ytol)) {\n pts.shift();\n pi.edgepaths[i] = edgepathi.concat(pts);\n merged = true;\n }\n }\n\n if(!merged) pi.edgepaths.push(pts);\n }\n}\n\n// special function to get the marching step of the\n// first point in the path (leading to loc)\nfunction getStartStep(mi, edgeflag, loc) {\n var dx = 0;\n var dy = 0;\n if(mi > 20 && edgeflag) {\n // these saddles start at +/- x\n if(mi === 208 || mi === 1114) {\n // if we're starting at the left side, we must be going right\n dx = loc[0] === 0 ? 1 : -1;\n } else {\n // if we're starting at the bottom, we must be going up\n dy = loc[1] === 0 ? 1 : -1;\n }\n } else if(constants.BOTTOMSTART.indexOf(mi) !== -1) dy = 1;\n else if(constants.LEFTSTART.indexOf(mi) !== -1) dx = 1;\n else if(constants.TOPSTART.indexOf(mi) !== -1) dy = -1;\n else dx = -1;\n return [dx, dy];\n}\n\n/*\n * Find the pixel coordinates of a particular crossing\n *\n * @param {object} pi: the pathinfo object at this level\n * @param {array} loc: the grid index [x, y] of the crossing\n * @param {array} step: the direction [dx, dy] we're moving on the grid\n *\n * @return {array} [xpx, ypx, xi, yi]: the first two are the pixel location,\n * the next two are the interpolated grid indices, which we use for\n * distance calculations to delete points that are too close together.\n * This is important when the grid is nonuniform (and most dramatically when\n * we're on log axes and include invalid (0 or negative) values.\n * It's crucial to delete these extra two before turning an array of these\n * points into a path, because those routines require length-2 points.\n */\nfunction getInterpPx(pi, loc, step) {\n var locx = loc[0] + Math.max(step[0], 0);\n var locy = loc[1] + Math.max(step[1], 0);\n var zxy = pi.z[locy][locx];\n var xa = pi.xaxis;\n var ya = pi.yaxis;\n\n // Interpolate in linear space, then convert to pixel\n if(step[1]) {\n var dx = (pi.level - zxy) / (pi.z[locy][locx + 1] - zxy);\n // Interpolate, but protect against NaN linear values for log axis (dx will equal 1 or 0)\n var dxl =\n (dx !== 1 ? (1 - dx) * xa.c2l(pi.x[locx]) : 0) +\n (dx !== 0 ? dx * xa.c2l(pi.x[locx + 1]) : 0);\n\n return [xa.c2p(xa.l2c(dxl), true),\n ya.c2p(pi.y[locy], true),\n locx + dx, locy];\n } else {\n var dy = (pi.level - zxy) / (pi.z[locy + 1][locx] - zxy);\n var dyl =\n (dy !== 1 ? (1 - dy) * ya.c2l(pi.y[locy]) : 0) +\n (dy !== 0 ? dy * ya.c2l(pi.y[locy + 1]) : 0);\n\n return [xa.c2p(pi.x[locx], true),\n ya.c2p(ya.l2c(dyl), true),\n locx, locy + dy];\n }\n}\n","'use strict';\n\nvar Color = require('../../components/color');\n\nvar heatmapHoverPoints = require('../heatmap/hover');\n\nmodule.exports = function hoverPoints(pointData, xval, yval, hovermode, opts) {\n if(!opts) opts = {};\n opts.isContour = true;\n\n var hoverData = heatmapHoverPoints(pointData, xval, yval, hovermode, opts);\n\n if(hoverData) {\n hoverData.forEach(function(hoverPt) {\n var trace = hoverPt.trace;\n if(trace.contours.type === 'constraint') {\n if(trace.fillcolor && Color.opacity(trace.fillcolor)) {\n hoverPt.color = Color.addOpacity(trace.fillcolor, 1);\n } else if(trace.contours.showlines && Color.opacity(trace.line.color)) {\n hoverPt.color = Color.addOpacity(trace.line.color, 1);\n }\n }\n });\n }\n\n return hoverData;\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n calc: require('./calc'),\n plot: require('./plot').plot,\n style: require('./style'),\n colorbar: require('./colorbar'),\n hoverPoints: require('./hover'),\n\n moduleType: 'trace',\n name: 'contour',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['cartesian', 'svg', '2dMap', 'contour', 'showLegend'],\n meta: {\n description: [\n 'The data from which contour lines are computed is set in `z`.',\n 'Data in `z` must be a {2D array} of numbers.',\n\n 'Say that `z` has N rows and M columns, then by default,',\n 'these N rows correspond to N y coordinates',\n '(set in `y` or auto-generated) and the M columns',\n 'correspond to M x coordinates (set in `x` or auto-generated).',\n 'By setting `transpose` to *true*, the above behavior is flipped.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nmodule.exports = function handleLabelDefaults(coerce, layout, lineColor, opts) {\n if(!opts) opts = {};\n var showLabels = coerce('contours.showlabels');\n if(showLabels) {\n var globalFont = layout.font;\n Lib.coerceFont(coerce, 'contours.labelfont', globalFont, { overrideDflt: {\n color: lineColor\n }});\n coerce('contours.labelformat');\n }\n\n if(opts.hasHover !== false) coerce('zhoverformat');\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Colorscale = require('../../components/colorscale');\nvar endPlus = require('./end_plus');\n\nmodule.exports = function makeColorMap(trace) {\n var contours = trace.contours;\n var start = contours.start;\n var end = endPlus(contours);\n var cs = contours.size || 1;\n var nc = Math.floor((end - start) / cs) + 1;\n var extra = contours.coloring === 'lines' ? 0 : 1;\n var cOpts = Colorscale.extractOpts(trace);\n\n if(!isFinite(cs)) {\n cs = 1;\n nc = 1;\n }\n\n var scl = cOpts.reversescale ?\n Colorscale.flipScale(cOpts.colorscale) :\n cOpts.colorscale;\n\n var len = scl.length;\n var domain = new Array(len);\n var range = new Array(len);\n\n var si, i;\n\n var zmin0 = cOpts.min;\n var zmax0 = cOpts.max;\n\n if(contours.coloring === 'heatmap') {\n for(i = 0; i < len; i++) {\n si = scl[i];\n domain[i] = si[0] * (zmax0 - zmin0) + zmin0;\n range[i] = si[1];\n }\n\n // do the contours extend beyond the colorscale?\n // if so, extend the colorscale with constants\n var zRange = d3.extent([\n zmin0,\n zmax0,\n contours.start,\n contours.start + cs * (nc - 1)\n ]);\n var zmin = zRange[zmin0 < zmax0 ? 0 : 1];\n var zmax = zRange[zmin0 < zmax0 ? 1 : 0];\n\n if(zmin !== zmin0) {\n domain.splice(0, 0, zmin);\n range.splice(0, 0, range[0]);\n }\n\n if(zmax !== zmax0) {\n domain.push(zmax);\n range.push(range[range.length - 1]);\n }\n } else {\n var zRangeInput = trace._input && (\n typeof trace._input.zmin === 'number' && typeof trace._input.zmax === 'number'\n );\n\n // If zmin/zmax are explicitly set, consider case where user specifies a\n // narrower z range than that of the contours start/end.\n if(zRangeInput && (start <= zmin0 || end >= zmax0)) {\n if(start <= zmin0) start = zmin0;\n if(end >= zmax0) end = zmax0;\n nc = Math.floor((end - start) / cs) + 1;\n extra = 0;\n }\n\n for(i = 0; i < len; i++) {\n si = scl[i];\n domain[i] = (si[0] * (nc + extra - 1) - (extra / 2)) * cs + start;\n range[i] = si[1];\n }\n\n // Make the colorscale fit the z range except if contours are explicitly\n // set BUT NOT zmin/zmax.\n if(zRangeInput || trace.autocontour) {\n if(domain[0] > zmin0) {\n domain.unshift(zmin0);\n range.unshift(range[0]);\n }\n if(domain[domain.length - 1] < zmax0) {\n domain.push(zmax0);\n range.push(range[range.length - 1]);\n }\n }\n }\n\n return Colorscale.makeColorScaleFunc(\n {domain: domain, range: range},\n {noNumericCheck: true}\n );\n};\n","'use strict';\n\nvar constants = require('./constants');\n\n// Calculate all the marching indices, for ALL levels at once.\n// since we want to be exhaustive we'll check for contour crossings\n// at every intersection, rather than just following a path\n// TODO: shorten the inner loop to only the relevant levels\nmodule.exports = function makeCrossings(pathinfo) {\n var z = pathinfo[0].z;\n var m = z.length;\n var n = z[0].length; // we already made sure z isn't ragged in interp2d\n var twoWide = m === 2 || n === 2;\n var xi;\n var yi;\n var startIndices;\n var ystartIndices;\n var label;\n var corners;\n var mi;\n var pi;\n var i;\n\n for(yi = 0; yi < m - 1; yi++) {\n ystartIndices = [];\n if(yi === 0) ystartIndices = ystartIndices.concat(constants.BOTTOMSTART);\n if(yi === m - 2) ystartIndices = ystartIndices.concat(constants.TOPSTART);\n\n for(xi = 0; xi < n - 1; xi++) {\n startIndices = ystartIndices.slice();\n if(xi === 0) startIndices = startIndices.concat(constants.LEFTSTART);\n if(xi === n - 2) startIndices = startIndices.concat(constants.RIGHTSTART);\n\n label = xi + ',' + yi;\n corners = [[z[yi][xi], z[yi][xi + 1]],\n [z[yi + 1][xi], z[yi + 1][xi + 1]]];\n for(i = 0; i < pathinfo.length; i++) {\n pi = pathinfo[i];\n mi = getMarchingIndex(pi.level, corners);\n if(!mi) continue;\n\n pi.crossings[label] = mi;\n if(startIndices.indexOf(mi) !== -1) {\n pi.starts.push([xi, yi]);\n if(twoWide && startIndices.indexOf(mi,\n startIndices.indexOf(mi) + 1) !== -1) {\n // the same square has starts from opposite sides\n // it's not possible to have starts on opposite edges\n // of a corner, only a start and an end...\n // but if the array is only two points wide (either way)\n // you can have starts on opposite sides.\n pi.starts.push([xi, yi]);\n }\n }\n }\n }\n }\n};\n\n// modified marching squares algorithm,\n// so we disambiguate the saddle points from the start\n// and we ignore the cases with no crossings\n// the index I'm using is based on:\n// http://en.wikipedia.org/wiki/Marching_squares\n// except that the saddles bifurcate and I represent them\n// as the decimal combination of the two appropriate\n// non-saddle indices\nfunction getMarchingIndex(val, corners) {\n var mi = (corners[0][0] > val ? 0 : 1) +\n (corners[0][1] > val ? 0 : 2) +\n (corners[1][1] > val ? 0 : 4) +\n (corners[1][0] > val ? 0 : 8);\n if(mi === 5 || mi === 10) {\n var avg = (corners[0][0] + corners[0][1] +\n corners[1][0] + corners[1][1]) / 4;\n // two peaks with a big valley\n if(val > avg) return (mi === 5) ? 713 : 1114;\n // two valleys with a big ridge\n return (mi === 5) ? 104 : 208;\n }\n return (mi === 15) ? 0 : mi;\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Lib = require('../../lib');\nvar Drawing = require('../../components/drawing');\nvar Colorscale = require('../../components/colorscale');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar Axes = require('../../plots/cartesian/axes');\nvar setConvert = require('../../plots/cartesian/set_convert');\n\nvar heatmapPlot = require('../heatmap/plot');\nvar makeCrossings = require('./make_crossings');\nvar findAllPaths = require('./find_all_paths');\nvar emptyPathinfo = require('./empty_pathinfo');\nvar convertToConstraints = require('./convert_to_constraints');\nvar closeBoundaries = require('./close_boundaries');\nvar constants = require('./constants');\nvar costConstants = constants.LABELOPTIMIZER;\n\nexports.plot = function plot(gd, plotinfo, cdcontours, contourLayer) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n Lib.makeTraceGroups(contourLayer, cdcontours, 'contour').each(function(cd) {\n var plotGroup = d3.select(this);\n var cd0 = cd[0];\n var trace = cd0.trace;\n var x = cd0.x;\n var y = cd0.y;\n var contours = trace.contours;\n var pathinfo = emptyPathinfo(contours, plotinfo, cd0);\n\n // use a heatmap to fill - draw it behind the lines\n var heatmapColoringLayer = Lib.ensureSingle(plotGroup, 'g', 'heatmapcoloring');\n var cdheatmaps = [];\n if(contours.coloring === 'heatmap') {\n cdheatmaps = [cd];\n }\n heatmapPlot(gd, plotinfo, cdheatmaps, heatmapColoringLayer);\n\n makeCrossings(pathinfo);\n findAllPaths(pathinfo);\n\n var leftedge = xa.c2p(x[0], true);\n var rightedge = xa.c2p(x[x.length - 1], true);\n var bottomedge = ya.c2p(y[0], true);\n var topedge = ya.c2p(y[y.length - 1], true);\n var perimeter = [\n [leftedge, topedge],\n [rightedge, topedge],\n [rightedge, bottomedge],\n [leftedge, bottomedge]\n ];\n\n var fillPathinfo = pathinfo;\n if(contours.type === 'constraint') {\n // N.B. this also mutates pathinfo\n fillPathinfo = convertToConstraints(pathinfo, contours._operation);\n }\n\n // draw everything\n makeBackground(plotGroup, perimeter, contours);\n makeFills(plotGroup, fillPathinfo, perimeter, contours);\n makeLinesAndLabels(plotGroup, pathinfo, gd, cd0, contours);\n clipGaps(plotGroup, plotinfo, gd, cd0, perimeter);\n });\n};\n\nfunction makeBackground(plotgroup, perimeter, contours) {\n var bggroup = Lib.ensureSingle(plotgroup, 'g', 'contourbg');\n\n var bgfill = bggroup.selectAll('path')\n .data(contours.coloring === 'fill' ? [0] : []);\n bgfill.enter().append('path');\n bgfill.exit().remove();\n bgfill\n .attr('d', 'M' + perimeter.join('L') + 'Z')\n .style('stroke', 'none');\n}\n\nfunction makeFills(plotgroup, pathinfo, perimeter, contours) {\n var hasFills = contours.coloring === 'fill' || (contours.type === 'constraint' && contours._operation !== '=');\n var boundaryPath = 'M' + perimeter.join('L') + 'Z';\n\n // fills prefixBoundary in pathinfo items\n if(hasFills) {\n closeBoundaries(pathinfo, contours);\n }\n\n var fillgroup = Lib.ensureSingle(plotgroup, 'g', 'contourfill');\n\n var fillitems = fillgroup.selectAll('path').data(hasFills ? pathinfo : []);\n fillitems.enter().append('path');\n fillitems.exit().remove();\n fillitems.each(function(pi) {\n // join all paths for this level together into a single path\n // first follow clockwise around the perimeter to close any open paths\n // if the whole perimeter is above this level, start with a path\n // enclosing the whole thing. With all that, the parity should mean\n // that we always fill everything above the contour, nothing below\n var fullpath = (pi.prefixBoundary ? boundaryPath : '') +\n joinAllPaths(pi, perimeter);\n\n if(!fullpath) {\n d3.select(this).remove();\n } else {\n d3.select(this)\n .attr('d', fullpath)\n .style('stroke', 'none');\n }\n });\n}\n\nfunction joinAllPaths(pi, perimeter) {\n var fullpath = '';\n var i = 0;\n var startsleft = pi.edgepaths.map(function(v, i) { return i; });\n var newloop = true;\n var endpt;\n var newendpt;\n var cnt;\n var nexti;\n var possiblei;\n var addpath;\n\n function istop(pt) { return Math.abs(pt[1] - perimeter[0][1]) < 0.01; }\n function isbottom(pt) { return Math.abs(pt[1] - perimeter[2][1]) < 0.01; }\n function isleft(pt) { return Math.abs(pt[0] - perimeter[0][0]) < 0.01; }\n function isright(pt) { return Math.abs(pt[0] - perimeter[2][0]) < 0.01; }\n\n while(startsleft.length) {\n addpath = Drawing.smoothopen(pi.edgepaths[i], pi.smoothing);\n fullpath += newloop ? addpath : addpath.replace(/^M/, 'L');\n startsleft.splice(startsleft.indexOf(i), 1);\n endpt = pi.edgepaths[i][pi.edgepaths[i].length - 1];\n nexti = -1;\n\n // now loop through sides, moving our endpoint until we find a new start\n for(cnt = 0; cnt < 4; cnt++) { // just to prevent infinite loops\n if(!endpt) {\n Lib.log('Missing end?', i, pi);\n break;\n }\n\n if(istop(endpt) && !isright(endpt)) newendpt = perimeter[1]; // right top\n else if(isleft(endpt)) newendpt = perimeter[0]; // left top\n else if(isbottom(endpt)) newendpt = perimeter[3]; // right bottom\n else if(isright(endpt)) newendpt = perimeter[2]; // left bottom\n\n for(possiblei = 0; possiblei < pi.edgepaths.length; possiblei++) {\n var ptNew = pi.edgepaths[possiblei][0];\n // is ptNew on the (horz. or vert.) segment from endpt to newendpt?\n if(Math.abs(endpt[0] - newendpt[0]) < 0.01) {\n if(Math.abs(endpt[0] - ptNew[0]) < 0.01 &&\n (ptNew[1] - endpt[1]) * (newendpt[1] - ptNew[1]) >= 0) {\n newendpt = ptNew;\n nexti = possiblei;\n }\n } else if(Math.abs(endpt[1] - newendpt[1]) < 0.01) {\n if(Math.abs(endpt[1] - ptNew[1]) < 0.01 &&\n (ptNew[0] - endpt[0]) * (newendpt[0] - ptNew[0]) >= 0) {\n newendpt = ptNew;\n nexti = possiblei;\n }\n } else {\n Lib.log('endpt to newendpt is not vert. or horz.',\n endpt, newendpt, ptNew);\n }\n }\n\n endpt = newendpt;\n\n if(nexti >= 0) break;\n fullpath += 'L' + newendpt;\n }\n\n if(nexti === pi.edgepaths.length) {\n Lib.log('unclosed perimeter path');\n break;\n }\n\n i = nexti;\n\n // if we closed back on a loop we already included,\n // close it and start a new loop\n newloop = (startsleft.indexOf(i) === -1);\n if(newloop) {\n i = startsleft[0];\n fullpath += 'Z';\n }\n }\n\n // finally add the interior paths\n for(i = 0; i < pi.paths.length; i++) {\n fullpath += Drawing.smoothclosed(pi.paths[i], pi.smoothing);\n }\n\n return fullpath;\n}\n\nfunction makeLinesAndLabels(plotgroup, pathinfo, gd, cd0, contours) {\n var isStatic = gd._context.staticPlot;\n var lineContainer = Lib.ensureSingle(plotgroup, 'g', 'contourlines');\n var showLines = contours.showlines !== false;\n var showLabels = contours.showlabels;\n var clipLinesForLabels = showLines && showLabels;\n\n // Even if we're not going to show lines, we need to create them\n // if we're showing labels, because the fill paths include the perimeter\n // so can't be used to position the labels correctly.\n // In this case we'll remove the lines after making the labels.\n var linegroup = exports.createLines(lineContainer, showLines || showLabels, pathinfo, isStatic);\n\n var lineClip = exports.createLineClip(lineContainer, clipLinesForLabels, gd, cd0.trace.uid);\n\n var labelGroup = plotgroup.selectAll('g.contourlabels')\n .data(showLabels ? [0] : []);\n\n labelGroup.exit().remove();\n\n labelGroup.enter().append('g')\n .classed('contourlabels', true);\n\n if(showLabels) {\n var labelClipPathData = [];\n var labelData = [];\n\n // invalidate the getTextLocation cache in case paths changed\n Lib.clearLocationCache();\n\n var contourFormat = exports.labelFormatter(gd, cd0);\n\n var dummyText = Drawing.tester.append('text')\n .attr('data-notex', 1)\n .call(Drawing.font, contours.labelfont);\n\n var xa = pathinfo[0].xaxis;\n var ya = pathinfo[0].yaxis;\n var xLen = xa._length;\n var yLen = ya._length;\n var xRng = xa.range;\n var yRng = ya.range;\n var xMin = Lib.aggNums(Math.min, null, cd0.x);\n var xMax = Lib.aggNums(Math.max, null, cd0.x);\n var yMin = Lib.aggNums(Math.min, null, cd0.y);\n var yMax = Lib.aggNums(Math.max, null, cd0.y);\n var x0 = Math.max(xa.c2p(xMin, true), 0);\n var x1 = Math.min(xa.c2p(xMax, true), xLen);\n var y0 = Math.max(ya.c2p(yMax, true), 0);\n var y1 = Math.min(ya.c2p(yMin, true), yLen);\n\n // visible bounds of the contour trace (and the midpoints, to\n // help with cost calculations)\n var bounds = {};\n\n if(xRng[0] < xRng[1]) {\n bounds.left = x0;\n bounds.right = x1;\n } else {\n bounds.left = x1;\n bounds.right = x0;\n }\n\n if(yRng[0] < yRng[1]) {\n bounds.top = y0;\n bounds.bottom = y1;\n } else {\n bounds.top = y1;\n bounds.bottom = y0;\n }\n\n bounds.middle = (bounds.top + bounds.bottom) / 2;\n bounds.center = (bounds.left + bounds.right) / 2;\n\n labelClipPathData.push([\n [bounds.left, bounds.top],\n [bounds.right, bounds.top],\n [bounds.right, bounds.bottom],\n [bounds.left, bounds.bottom]\n ]);\n\n var plotDiagonal = Math.sqrt(xLen * xLen + yLen * yLen);\n\n // the path length to use to scale the number of labels to draw:\n var normLength = constants.LABELDISTANCE * plotDiagonal /\n Math.max(1, pathinfo.length / constants.LABELINCREASE);\n\n linegroup.each(function(d) {\n var textOpts = exports.calcTextOpts(d.level, contourFormat, dummyText, gd);\n\n d3.select(this).selectAll('path').each(function() {\n var path = this;\n var pathBounds = Lib.getVisibleSegment(path, bounds, textOpts.height / 2);\n if(!pathBounds) return;\n\n if(pathBounds.len < (textOpts.width + textOpts.height) * constants.LABELMIN) return;\n\n var maxLabels = Math.min(Math.ceil(pathBounds.len / normLength),\n constants.LABELMAX);\n\n for(var i = 0; i < maxLabels; i++) {\n var loc = exports.findBestTextLocation(path, pathBounds, textOpts,\n labelData, bounds);\n\n if(!loc) break;\n\n exports.addLabelData(loc, textOpts, labelData, labelClipPathData);\n }\n });\n });\n\n dummyText.remove();\n\n exports.drawLabels(labelGroup, labelData, gd, lineClip,\n clipLinesForLabels ? labelClipPathData : null);\n }\n\n if(showLabels && !showLines) linegroup.remove();\n}\n\nexports.createLines = function(lineContainer, makeLines, pathinfo, isStatic) {\n var smoothing = pathinfo[0].smoothing;\n\n var linegroup = lineContainer.selectAll('g.contourlevel')\n .data(makeLines ? pathinfo : []);\n\n linegroup.exit().remove();\n linegroup.enter().append('g')\n .classed('contourlevel', true);\n\n if(makeLines) {\n // pedgepaths / ppaths are used by contourcarpet, for the paths transformed from a/b to x/y\n // edgepaths / paths are used by contour since it's in x/y from the start\n var opencontourlines = linegroup.selectAll('path.openline')\n .data(function(d) { return d.pedgepaths || d.edgepaths; });\n\n opencontourlines.exit().remove();\n opencontourlines.enter().append('path')\n .classed('openline', true);\n\n opencontourlines\n .attr('d', function(d) {\n return Drawing.smoothopen(d, smoothing);\n })\n .style('stroke-miterlimit', 1)\n .style('vector-effect', isStatic ? 'none' : 'non-scaling-stroke');\n\n var closedcontourlines = linegroup.selectAll('path.closedline')\n .data(function(d) { return d.ppaths || d.paths; });\n\n closedcontourlines.exit().remove();\n closedcontourlines.enter().append('path')\n .classed('closedline', true);\n\n closedcontourlines\n .attr('d', function(d) {\n return Drawing.smoothclosed(d, smoothing);\n })\n .style('stroke-miterlimit', 1)\n .style('vector-effect', isStatic ? 'none' : 'non-scaling-stroke');\n }\n\n return linegroup;\n};\n\nexports.createLineClip = function(lineContainer, clipLinesForLabels, gd, uid) {\n var clips = gd._fullLayout._clips;\n var clipId = clipLinesForLabels ? ('clipline' + uid) : null;\n\n var lineClip = clips.selectAll('#' + clipId)\n .data(clipLinesForLabels ? [0] : []);\n lineClip.exit().remove();\n\n lineClip.enter().append('clipPath')\n .classed('contourlineclip', true)\n .attr('id', clipId);\n\n Drawing.setClipUrl(lineContainer, clipId, gd);\n\n return lineClip;\n};\n\nexports.labelFormatter = function(gd, cd0) {\n var fullLayout = gd._fullLayout;\n var trace = cd0.trace;\n var contours = trace.contours;\n\n var formatAxis = {\n type: 'linear',\n _id: 'ycontour',\n showexponent: 'all',\n exponentformat: 'B'\n };\n\n if(contours.labelformat) {\n formatAxis.tickformat = contours.labelformat;\n setConvert(formatAxis, fullLayout);\n } else {\n var cOpts = Colorscale.extractOpts(trace);\n if(cOpts && cOpts.colorbar && cOpts.colorbar._axis) {\n formatAxis = cOpts.colorbar._axis;\n } else {\n if(contours.type === 'constraint') {\n var value = contours.value;\n if(Lib.isArrayOrTypedArray(value)) {\n formatAxis.range = [value[0], value[value.length - 1]];\n } else formatAxis.range = [value, value];\n } else {\n formatAxis.range = [contours.start, contours.end];\n formatAxis.nticks = (contours.end - contours.start) / contours.size;\n }\n\n if(formatAxis.range[0] === formatAxis.range[1]) {\n formatAxis.range[1] += formatAxis.range[0] || 1;\n }\n if(!formatAxis.nticks) formatAxis.nticks = 1000;\n\n setConvert(formatAxis, fullLayout);\n Axes.prepTicks(formatAxis);\n formatAxis._tmin = null;\n formatAxis._tmax = null;\n }\n }\n\n return function(v) { return Axes.tickText(formatAxis, v).text; };\n};\n\nexports.calcTextOpts = function(level, contourFormat, dummyText, gd) {\n var text = contourFormat(level);\n dummyText.text(text)\n .call(svgTextUtils.convertToTspans, gd);\n\n var el = dummyText.node();\n var bBox = Drawing.bBox(el, true);\n\n return {\n text: text,\n width: bBox.width,\n height: bBox.height,\n fontSize: +(el.style['font-size'].replace('px', '')),\n level: level,\n dy: (bBox.top + bBox.bottom) / 2\n };\n};\n\nexports.findBestTextLocation = function(path, pathBounds, textOpts, labelData, plotBounds) {\n var textWidth = textOpts.width;\n\n var p0, dp, pMax, pMin, loc;\n if(pathBounds.isClosed) {\n dp = pathBounds.len / costConstants.INITIALSEARCHPOINTS;\n p0 = pathBounds.min + dp / 2;\n pMax = pathBounds.max;\n } else {\n dp = (pathBounds.len - textWidth) / (costConstants.INITIALSEARCHPOINTS + 1);\n p0 = pathBounds.min + dp + textWidth / 2;\n pMax = pathBounds.max - (dp + textWidth) / 2;\n }\n\n var cost = Infinity;\n for(var j = 0; j < costConstants.ITERATIONS; j++) {\n for(var p = p0; p < pMax; p += dp) {\n var newLocation = Lib.getTextLocation(path, pathBounds.total, p, textWidth);\n var newCost = locationCost(newLocation, textOpts, labelData, plotBounds);\n if(newCost < cost) {\n cost = newCost;\n loc = newLocation;\n pMin = p;\n }\n }\n if(cost > costConstants.MAXCOST * 2) break;\n\n // subsequent iterations just look half steps away from the\n // best we found in the previous iteration\n if(j) dp /= 2;\n p0 = pMin - dp / 2;\n pMax = p0 + dp * 1.5;\n }\n if(cost <= costConstants.MAXCOST) return loc;\n};\n\n/*\n * locationCost: a cost function for label locations\n * composed of three kinds of penalty:\n * - for open paths, being close to the end of the path\n * - the angle away from horizontal\n * - being too close to already placed neighbors\n */\nfunction locationCost(loc, textOpts, labelData, bounds) {\n var halfWidth = textOpts.width / 2;\n var halfHeight = textOpts.height / 2;\n var x = loc.x;\n var y = loc.y;\n var theta = loc.theta;\n var dx = Math.cos(theta) * halfWidth;\n var dy = Math.sin(theta) * halfWidth;\n\n // cost for being near an edge\n var normX = ((x > bounds.center) ? (bounds.right - x) : (x - bounds.left)) /\n (dx + Math.abs(Math.sin(theta) * halfHeight));\n var normY = ((y > bounds.middle) ? (bounds.bottom - y) : (y - bounds.top)) /\n (Math.abs(dy) + Math.cos(theta) * halfHeight);\n if(normX < 1 || normY < 1) return Infinity;\n var cost = costConstants.EDGECOST * (1 / (normX - 1) + 1 / (normY - 1));\n\n // cost for not being horizontal\n cost += costConstants.ANGLECOST * theta * theta;\n\n // cost for being close to other labels\n var x1 = x - dx;\n var y1 = y - dy;\n var x2 = x + dx;\n var y2 = y + dy;\n for(var i = 0; i < labelData.length; i++) {\n var labeli = labelData[i];\n var dxd = Math.cos(labeli.theta) * labeli.width / 2;\n var dyd = Math.sin(labeli.theta) * labeli.width / 2;\n var dist = Lib.segmentDistance(\n x1, y1,\n x2, y2,\n labeli.x - dxd, labeli.y - dyd,\n labeli.x + dxd, labeli.y + dyd\n ) * 2 / (textOpts.height + labeli.height);\n\n var sameLevel = labeli.level === textOpts.level;\n var distOffset = sameLevel ? costConstants.SAMELEVELDISTANCE : 1;\n\n if(dist <= distOffset) return Infinity;\n\n var distFactor = costConstants.NEIGHBORCOST *\n (sameLevel ? costConstants.SAMELEVELFACTOR : 1);\n\n cost += distFactor / (dist - distOffset);\n }\n\n return cost;\n}\n\nexports.addLabelData = function(loc, textOpts, labelData, labelClipPathData) {\n var fontSize = textOpts.fontSize;\n var w = textOpts.width + fontSize / 3;\n var h = Math.max(0, textOpts.height - fontSize / 3);\n\n var x = loc.x;\n var y = loc.y;\n var theta = loc.theta;\n\n var sin = Math.sin(theta);\n var cos = Math.cos(theta);\n\n var rotateXY = function(dx, dy) {\n return [\n x + dx * cos - dy * sin,\n y + dx * sin + dy * cos\n ];\n };\n\n var bBoxPts = [\n rotateXY(-w / 2, -h / 2),\n rotateXY(-w / 2, h / 2),\n rotateXY(w / 2, h / 2),\n rotateXY(w / 2, -h / 2)\n ];\n\n labelData.push({\n text: textOpts.text,\n x: x,\n y: y,\n dy: textOpts.dy,\n theta: theta,\n level: textOpts.level,\n width: w,\n height: h\n });\n\n labelClipPathData.push(bBoxPts);\n};\n\nexports.drawLabels = function(labelGroup, labelData, gd, lineClip, labelClipPathData) {\n var labels = labelGroup.selectAll('text')\n .data(labelData, function(d) {\n return d.text + ',' + d.x + ',' + d.y + ',' + d.theta;\n });\n\n labels.exit().remove();\n\n labels.enter().append('text')\n .attr({\n 'data-notex': 1,\n 'text-anchor': 'middle'\n })\n .each(function(d) {\n var x = d.x + Math.sin(d.theta) * d.dy;\n var y = d.y - Math.cos(d.theta) * d.dy;\n d3.select(this)\n .text(d.text)\n .attr({\n x: x,\n y: y,\n transform: 'rotate(' + (180 * d.theta / Math.PI) + ' ' + x + ' ' + y + ')'\n })\n .call(svgTextUtils.convertToTspans, gd);\n });\n\n if(labelClipPathData) {\n var clipPath = '';\n for(var i = 0; i < labelClipPathData.length; i++) {\n clipPath += 'M' + labelClipPathData[i].join('L') + 'Z';\n }\n\n var lineClipPath = Lib.ensureSingle(lineClip, 'path', '');\n lineClipPath.attr('d', clipPath);\n }\n};\n\nfunction clipGaps(plotGroup, plotinfo, gd, cd0, perimeter) {\n var trace = cd0.trace;\n var clips = gd._fullLayout._clips;\n var clipId = 'clip' + trace.uid;\n\n var clipPath = clips.selectAll('#' + clipId)\n .data(trace.connectgaps ? [] : [0]);\n clipPath.enter().append('clipPath')\n .classed('contourclip', true)\n .attr('id', clipId);\n clipPath.exit().remove();\n\n if(trace.connectgaps === false) {\n var clipPathInfo = {\n // fraction of the way from missing to present point\n // to draw the boundary.\n // if you make this 1 (or 1-epsilon) then a point in\n // a sea of missing data will disappear entirely.\n level: 0.9,\n crossings: {},\n starts: [],\n edgepaths: [],\n paths: [],\n xaxis: plotinfo.xaxis,\n yaxis: plotinfo.yaxis,\n x: cd0.x,\n y: cd0.y,\n // 0 = no data, 1 = data\n z: makeClipMask(cd0),\n smoothing: 0\n };\n\n makeCrossings([clipPathInfo]);\n findAllPaths([clipPathInfo]);\n closeBoundaries([clipPathInfo], {type: 'levels'});\n\n var path = Lib.ensureSingle(clipPath, 'path', '');\n path.attr('d',\n (clipPathInfo.prefixBoundary ? 'M' + perimeter.join('L') + 'Z' : '') +\n joinAllPaths(clipPathInfo, perimeter)\n );\n } else clipId = null;\n\n Drawing.setClipUrl(plotGroup, clipId, gd);\n}\n\nfunction makeClipMask(cd0) {\n var empties = cd0.trace._emptypoints;\n var z = [];\n var m = cd0.z.length;\n var n = cd0.z[0].length;\n var i;\n var row = [];\n var emptyPoint;\n\n for(i = 0; i < n; i++) row.push(1);\n for(i = 0; i < m; i++) z.push(row.slice());\n for(i = 0; i < empties.length; i++) {\n emptyPoint = empties[i];\n z[emptyPoint[0]][emptyPoint[1]] = 0;\n }\n // save this mask to determine whether to show this data in hover\n cd0.zmask = z;\n return z;\n}\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\nvar Lib = require('../../lib');\n\nmodule.exports = function setContours(trace, vals) {\n var contours = trace.contours;\n\n // check if we need to auto-choose contour levels\n if(trace.autocontour) {\n // N.B. do not try to use coloraxis cmin/cmax,\n // these values here are meant to remain \"per-trace\" for now\n var zmin = trace.zmin;\n var zmax = trace.zmax;\n if(trace.zauto || zmin === undefined) {\n zmin = Lib.aggNums(Math.min, null, vals);\n }\n if(trace.zauto || zmax === undefined) {\n zmax = Lib.aggNums(Math.max, null, vals);\n }\n\n var dummyAx = autoContours(zmin, zmax, trace.ncontours);\n contours.size = dummyAx.dtick;\n contours.start = Axes.tickFirst(dummyAx);\n dummyAx.range.reverse();\n contours.end = Axes.tickFirst(dummyAx);\n\n if(contours.start === zmin) contours.start += contours.size;\n if(contours.end === zmax) contours.end -= contours.size;\n\n // if you set a small ncontours, *and* the ends are exactly on zmin/zmax\n // there's an edge case where start > end now. Make sure there's at least\n // one meaningful contour, put it midway between the crossed values\n if(contours.start > contours.end) {\n contours.start = contours.end = (contours.start + contours.end) / 2;\n }\n\n // copy auto-contour info back to the source data.\n // previously we copied the whole contours object back, but that had\n // other info (coloring, showlines) that should be left to supplyDefaults\n if(!trace._input.contours) trace._input.contours = {};\n Lib.extendFlat(trace._input.contours, {\n start: contours.start,\n end: contours.end,\n size: contours.size\n });\n trace._input.autocontour = true;\n } else if(contours.type !== 'constraint') {\n // sanity checks on manually-supplied start/end/size\n var start = contours.start;\n var end = contours.end;\n var inputContours = trace._input.contours;\n\n if(start > end) {\n contours.start = inputContours.start = end;\n end = contours.end = inputContours.end = start;\n start = contours.start;\n }\n\n if(!(contours.size > 0)) {\n var sizeOut;\n if(start === end) sizeOut = 1;\n else sizeOut = autoContours(start, end, trace.ncontours).dtick;\n\n inputContours.size = contours.size = sizeOut;\n }\n }\n};\n\n\n/*\n * autoContours: make a dummy axis object with dtick we can use\n * as contours.size, and if needed we can use Axes.tickFirst\n * with this axis object to calculate the start and end too\n *\n * start: the value to start the contours at\n * end: the value to end at (must be > start)\n * ncontours: max number of contours to make, like roughDTick\n *\n * returns: an axis object\n */\nfunction autoContours(start, end, ncontours) {\n var dummyAx = {\n type: 'linear',\n range: [start, end]\n };\n\n Axes.autoTicks(\n dummyAx,\n (end - start) / (ncontours || 15)\n );\n\n return dummyAx;\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Drawing = require('../../components/drawing');\nvar heatmapStyle = require('../heatmap/style');\n\nvar makeColorMap = require('./make_color_map');\n\n\nmodule.exports = function style(gd) {\n var contours = d3.select(gd).selectAll('g.contour');\n\n contours.style('opacity', function(d) {\n return d[0].trace.opacity;\n });\n\n contours.each(function(d) {\n var c = d3.select(this);\n var trace = d[0].trace;\n var contours = trace.contours;\n var line = trace.line;\n var cs = contours.size || 1;\n var start = contours.start;\n\n // for contourcarpet only - is this a constraint-type contour trace?\n var isConstraintType = contours.type === 'constraint';\n var colorLines = !isConstraintType && contours.coloring === 'lines';\n var colorFills = !isConstraintType && contours.coloring === 'fill';\n\n var colorMap = (colorLines || colorFills) ? makeColorMap(trace) : null;\n\n c.selectAll('g.contourlevel').each(function(d) {\n d3.select(this).selectAll('path')\n .call(Drawing.lineGroupStyle,\n line.width,\n colorLines ? colorMap(d.level) : line.color,\n line.dash);\n });\n\n var labelFont = contours.labelfont;\n c.selectAll('g.contourlabels text').each(function(d) {\n Drawing.font(d3.select(this), {\n weight: labelFont.weight,\n style: labelFont.style,\n variant: labelFont.variant,\n textcase: labelFont.textcase,\n lineposition: labelFont.lineposition,\n shadow: labelFont.shadow,\n family: labelFont.family,\n size: labelFont.size,\n color: labelFont.color || (colorLines ? colorMap(d.level) : line.color)\n });\n });\n\n if(isConstraintType) {\n c.selectAll('g.contourfill path')\n .style('fill', trace.fillcolor);\n } else if(colorFills) {\n var firstFill;\n\n c.selectAll('g.contourfill path')\n .style('fill', function(d) {\n if(firstFill === undefined) firstFill = d.level;\n return colorMap(d.level + 0.5 * cs);\n });\n\n if(firstFill === undefined) firstFill = start;\n\n c.selectAll('g.contourbg path')\n .style('fill', colorMap(firstFill - 0.5 * cs));\n }\n });\n\n heatmapStyle(gd);\n};\n","'use strict';\n\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar handleLabelDefaults = require('./label_defaults');\n\n\nmodule.exports = function handleStyleDefaults(traceIn, traceOut, coerce, layout, opts) {\n var coloring = coerce('contours.coloring');\n\n var showLines;\n var lineColor = '';\n if(coloring === 'fill') showLines = coerce('contours.showlines');\n\n if(showLines !== false) {\n if(coloring !== 'lines') lineColor = coerce('line.color', '#000');\n coerce('line.width', 0.5);\n coerce('line.dash');\n }\n\n if(coloring !== 'none') {\n // plots/plots always coerces showlegend to true, but in this case\n // we default to false and (by default) show a colorbar instead\n if(traceIn.showlegend !== true) traceOut.showlegend = false;\n traceOut._dfltShowLegend = false;\n\n colorscaleDefaults(\n traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'z'}\n );\n }\n\n coerce('line.smoothing');\n\n handleLabelDefaults(coerce, layout, lineColor, opts);\n};\n","'use strict';\n\nvar heatmapAttrs = require('../heatmap/attributes');\nvar contourAttrs = require('../contour/attributes');\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar contourContourAttrs = contourAttrs.contours;\n\nmodule.exports = extendFlat({\n carpet: {\n valType: 'string',\n editType: 'calc',\n description: [\n 'The `carpet` of the carpet axes on which this contour trace lies'\n ].join(' ')\n },\n z: heatmapAttrs.z,\n a: heatmapAttrs.x,\n a0: heatmapAttrs.x0,\n da: heatmapAttrs.dx,\n b: heatmapAttrs.y,\n b0: heatmapAttrs.y0,\n db: heatmapAttrs.dy,\n text: heatmapAttrs.text,\n hovertext: heatmapAttrs.hovertext,\n transpose: heatmapAttrs.transpose,\n atype: heatmapAttrs.xtype,\n btype: heatmapAttrs.ytype,\n\n fillcolor: contourAttrs.fillcolor,\n\n autocontour: contourAttrs.autocontour,\n ncontours: contourAttrs.ncontours,\n\n contours: {\n type: contourContourAttrs.type,\n start: contourContourAttrs.start,\n end: contourContourAttrs.end,\n size: contourContourAttrs.size,\n coloring: {\n // from contourAttrs.contours.coloring but no 'heatmap' option\n valType: 'enumerated',\n values: ['fill', 'lines', 'none'],\n dflt: 'fill',\n editType: 'calc',\n description: [\n 'Determines the coloring method showing the contour values.',\n 'If *fill*, coloring is done evenly between each contour level',\n 'If *lines*, coloring is done on the contour lines.',\n 'If *none*, no coloring is applied on this trace.'\n ].join(' ')\n },\n showlines: contourContourAttrs.showlines,\n showlabels: contourContourAttrs.showlabels,\n labelfont: contourContourAttrs.labelfont,\n labelformat: contourContourAttrs.labelformat,\n operation: contourContourAttrs.operation,\n value: contourContourAttrs.value,\n editType: 'calc',\n impliedEdits: {autocontour: false}\n },\n\n line: {\n color: contourAttrs.line.color,\n width: contourAttrs.line.width,\n dash: contourAttrs.line.dash,\n smoothing: contourAttrs.line.smoothing,\n editType: 'plot'\n },\n\n zorder: contourAttrs.zorder,\n transforms: undefined\n},\n\n colorScaleAttrs('', {\n cLetter: 'z',\n autoColorDflt: false\n })\n);\n","'use strict';\n\nvar colorscaleCalc = require('../../components/colorscale/calc');\nvar Lib = require('../../lib');\n\nvar convertColumnData = require('../heatmap/convert_column_xyz');\nvar clean2dArray = require('../heatmap/clean_2d_array');\nvar interp2d = require('../heatmap/interp2d');\nvar findEmpties = require('../heatmap/find_empties');\nvar makeBoundArray = require('../heatmap/make_bound_array');\nvar supplyDefaults = require('./defaults');\nvar lookupCarpet = require('../carpet/lookup_carpetid');\nvar setContours = require('../contour/set_contours');\n\n// most is the same as heatmap calc, then adjust it\n// though a few things inside heatmap calc still look for\n// contour maps, because the makeBoundArray calls are too entangled\nmodule.exports = function calc(gd, trace) {\n var carpet = trace._carpetTrace = lookupCarpet(gd, trace);\n if(!carpet || !carpet.visible || carpet.visible === 'legendonly') return;\n\n if(!trace.a || !trace.b) {\n // Look up the original incoming carpet data:\n var carpetdata = gd.data[carpet.index];\n\n // Look up the incoming trace data, *except* perform a shallow\n // copy so that we're not actually modifying it when we use it\n // to supply defaults:\n var tracedata = gd.data[trace.index];\n // var tracedata = extendFlat({}, gd.data[trace.index]);\n\n // If the data is not specified\n if(!tracedata.a) tracedata.a = carpetdata.a;\n if(!tracedata.b) tracedata.b = carpetdata.b;\n\n supplyDefaults(tracedata, trace, trace._defaultColor, gd._fullLayout);\n }\n\n var cd = heatmappishCalc(gd, trace);\n setContours(trace, trace._z);\n\n return cd;\n};\n\nfunction heatmappishCalc(gd, trace) {\n // prepare the raw data\n // run makeCalcdata on x and y even for heatmaps, in case of category mappings\n var carpet = trace._carpetTrace;\n var aax = carpet.aaxis;\n var bax = carpet.baxis;\n var a,\n a0,\n da,\n b,\n b0,\n db,\n z;\n\n // cancel minimum tick spacings (only applies to bars and boxes)\n aax._minDtick = 0;\n bax._minDtick = 0;\n\n if(Lib.isArray1D(trace.z)) convertColumnData(trace, aax, bax, 'a', 'b', ['z']);\n a = trace._a = trace._a || trace.a;\n b = trace._b = trace._b || trace.b;\n\n a = a ? aax.makeCalcdata(trace, '_a') : [];\n b = b ? bax.makeCalcdata(trace, '_b') : [];\n a0 = trace.a0 || 0;\n da = trace.da || 1;\n b0 = trace.b0 || 0;\n db = trace.db || 1;\n\n z = trace._z = clean2dArray(trace._z || trace.z, trace.transpose);\n\n trace._emptypoints = findEmpties(z);\n interp2d(z, trace._emptypoints);\n\n // create arrays of brick boundaries, to be used by autorange and heatmap.plot\n var xlen = Lib.maxRowLength(z);\n var xIn = trace.xtype === 'scaled' ? '' : a;\n var xArray = makeBoundArray(trace, xIn, a0, da, xlen, aax);\n var yIn = trace.ytype === 'scaled' ? '' : b;\n var yArray = makeBoundArray(trace, yIn, b0, db, z.length, bax);\n\n var cd0 = {\n a: xArray,\n b: yArray,\n z: z,\n };\n\n if(trace.contours.type === 'levels' && trace.contours.coloring !== 'none') {\n // auto-z and autocolorscale if applicable\n colorscaleCalc(gd, trace, {\n vals: z,\n containerStr: '',\n cLetter: 'z'\n });\n }\n\n return [cd0];\n}\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar handleXYZDefaults = require('../heatmap/xyz_defaults');\nvar attributes = require('./attributes');\nvar handleConstraintDefaults = require('../contour/constraint_defaults');\nvar handleContoursDefaults = require('../contour/contours_defaults');\nvar handleStyleDefaults = require('../contour/style_defaults');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n function coerce2(attr) {\n return Lib.coerce2(traceIn, traceOut, attributes, attr);\n }\n\n coerce('carpet');\n\n // If either a or b is not present, then it's not a valid trace *unless* the carpet\n // axis has the a or b values we're looking for. So if these are not found, just defer\n // that decision until the calc step.\n //\n // NB: the calc step will modify the original data input by assigning whichever of\n // a or b are missing. This is necessary because panning goes right from supplyDefaults\n // to plot (skipping calc). That means on subsequent updates, this *will* need to be\n // able to find a and b.\n //\n // The long-term proper fix is that this should perhaps use underscored attributes to\n // at least modify the user input to a slightly lesser extent. Fully removing the\n // input mutation is challenging. The underscore approach is not currently taken since\n // it requires modification to all of the functions below that expect the coerced\n // attribute name to match the property name -- except '_a' !== 'a' so that is not\n // straightforward.\n if(traceIn.a && traceIn.b) {\n var len = handleXYZDefaults(traceIn, traceOut, coerce, layout, 'a', 'b');\n\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n coerce('text');\n var isConstraint = (coerce('contours.type') === 'constraint');\n\n if(isConstraint) {\n handleConstraintDefaults(traceIn, traceOut, coerce, layout, defaultColor, {hasHover: false});\n } else {\n handleContoursDefaults(traceIn, traceOut, coerce, coerce2);\n handleStyleDefaults(traceIn, traceOut, coerce, layout, {hasHover: false});\n }\n } else {\n traceOut._defaultColor = defaultColor;\n traceOut._length = null;\n }\n coerce('zorder');\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../contour/colorbar'),\n calc: require('./calc'),\n plot: require('./plot'),\n style: require('../contour/style'),\n\n moduleType: 'trace',\n name: 'contourcarpet',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['cartesian', 'svg', 'carpet', 'contour', 'symbols', 'showLegend', 'hasLines', 'carpetDependent', 'noHover', 'noSortingByValue'],\n meta: {\n hrName: 'contour_carpet',\n description: [\n 'Plots contours on either the first carpet axis or the',\n 'carpet axis with a matching `carpet` attribute. Data `z`',\n 'is interpreted as matching that of the corresponding carpet',\n 'axis.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar map1dArray = require('../carpet/map_1d_array');\nvar makepath = require('../carpet/makepath');\nvar Drawing = require('../../components/drawing');\nvar Lib = require('../../lib');\n\nvar makeCrossings = require('../contour/make_crossings');\nvar findAllPaths = require('../contour/find_all_paths');\nvar contourPlot = require('../contour/plot');\nvar constants = require('../contour/constants');\nvar convertToConstraints = require('../contour/convert_to_constraints');\nvar emptyPathinfo = require('../contour/empty_pathinfo');\nvar closeBoundaries = require('../contour/close_boundaries');\nvar lookupCarpet = require('../carpet/lookup_carpetid');\nvar axisAlignedLine = require('../carpet/axis_aligned_line');\n\nmodule.exports = function plot(gd, plotinfo, cdcontours, contourcarpetLayer) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n Lib.makeTraceGroups(contourcarpetLayer, cdcontours, 'contour').each(function(cd) {\n var plotGroup = d3.select(this);\n var cd0 = cd[0];\n var trace = cd0.trace;\n\n var carpet = trace._carpetTrace = lookupCarpet(gd, trace);\n var carpetcd = gd.calcdata[carpet.index][0];\n\n if(!carpet.visible || carpet.visible === 'legendonly') return;\n\n var a = cd0.a;\n var b = cd0.b;\n var contours = trace.contours;\n var pathinfo = emptyPathinfo(contours, plotinfo, cd0);\n var isConstraint = contours.type === 'constraint';\n var operation = contours._operation;\n var coloring = isConstraint ? (operation === '=' ? 'lines' : 'fill') : contours.coloring;\n\n // Map [a, b] (data) --> [i, j] (pixels)\n function ab2p(ab) {\n var pt = carpet.ab2xy(ab[0], ab[1], true);\n return [xa.c2p(pt[0]), ya.c2p(pt[1])];\n }\n\n // Define the perimeter in a/b coordinates:\n var perimeter = [\n [a[0], b[b.length - 1]],\n [a[a.length - 1], b[b.length - 1]],\n [a[a.length - 1], b[0]],\n [a[0], b[0]]\n ];\n\n // Extract the contour levels:\n makeCrossings(pathinfo);\n var atol = (a[a.length - 1] - a[0]) * 1e-8;\n var btol = (b[b.length - 1] - b[0]) * 1e-8;\n findAllPaths(pathinfo, atol, btol);\n\n // Constraints might need to be draw inverted, which is not something contours\n // handle by default since they're assumed fully opaque so that they can be\n // drawn overlapping. This function flips the paths as necessary so that they're\n // drawn correctly.\n //\n // TODO: Perhaps this should be generalized and *all* paths should be drawn as\n // closed regions so that translucent contour levels would be valid.\n // See: https://github.com/plotly/plotly.js/issues/1356\n var fillPathinfo = pathinfo;\n if(contours.type === 'constraint') {\n fillPathinfo = convertToConstraints(pathinfo, operation);\n }\n\n // Map the paths in a/b coordinates to pixel coordinates:\n mapPathinfo(pathinfo, ab2p);\n\n // draw everything\n\n // Compute the boundary path\n var seg, xp, yp, i;\n var segs = [];\n for(i = carpetcd.clipsegments.length - 1; i >= 0; i--) {\n seg = carpetcd.clipsegments[i];\n xp = map1dArray([], seg.x, xa.c2p);\n yp = map1dArray([], seg.y, ya.c2p);\n xp.reverse();\n yp.reverse();\n segs.push(makepath(xp, yp, seg.bicubic));\n }\n\n var boundaryPath = 'M' + segs.join('L') + 'Z';\n\n // Draw the baseline background fill that fills in the space behind any other\n // contour levels:\n makeBackground(plotGroup, carpetcd.clipsegments, xa, ya, isConstraint, coloring);\n\n // Draw the specific contour fills. As a simplification, they're assumed to be\n // fully opaque so that it's easy to draw them simply overlapping. The alternative\n // would be to flip adjacent paths and draw closed paths for each level instead.\n makeFills(trace, plotGroup, xa, ya, fillPathinfo, perimeter, ab2p, carpet, carpetcd, coloring, boundaryPath);\n\n // Draw contour lines:\n makeLinesAndLabels(plotGroup, pathinfo, gd, cd0, contours, plotinfo, carpet);\n\n // Clip the boundary of the plot\n Drawing.setClipUrl(plotGroup, carpet._clipPathId, gd);\n });\n};\n\nfunction mapPathinfo(pathinfo, map) {\n var i, j, k, pi, pedgepaths, ppaths, pedgepath, ppath, path;\n\n for(i = 0; i < pathinfo.length; i++) {\n pi = pathinfo[i];\n pedgepaths = pi.pedgepaths = [];\n ppaths = pi.ppaths = [];\n for(j = 0; j < pi.edgepaths.length; j++) {\n path = pi.edgepaths[j];\n pedgepath = [];\n for(k = 0; k < path.length; k++) {\n pedgepath[k] = map(path[k]);\n }\n pedgepaths.push(pedgepath);\n }\n for(j = 0; j < pi.paths.length; j++) {\n path = pi.paths[j];\n ppath = [];\n for(k = 0; k < path.length; k++) {\n ppath[k] = map(path[k]);\n }\n ppaths.push(ppath);\n }\n }\n}\n\nfunction makeLinesAndLabels(plotgroup, pathinfo, gd, cd0, contours, plotinfo, carpet) {\n var isStatic = gd._context.staticPlot;\n var lineContainer = Lib.ensureSingle(plotgroup, 'g', 'contourlines');\n var showLines = contours.showlines !== false;\n var showLabels = contours.showlabels;\n var clipLinesForLabels = showLines && showLabels;\n\n // Even if we're not going to show lines, we need to create them\n // if we're showing labels, because the fill paths include the perimeter\n // so can't be used to position the labels correctly.\n // In this case we'll remove the lines after making the labels.\n var linegroup = contourPlot.createLines(lineContainer, showLines || showLabels, pathinfo, isStatic);\n\n var lineClip = contourPlot.createLineClip(lineContainer, clipLinesForLabels, gd, cd0.trace.uid);\n\n var labelGroup = plotgroup.selectAll('g.contourlabels')\n .data(showLabels ? [0] : []);\n\n labelGroup.exit().remove();\n\n labelGroup.enter().append('g')\n .classed('contourlabels', true);\n\n if(showLabels) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var xLen = xa._length;\n var yLen = ya._length;\n // for simplicity use the xy box for label clipping outline.\n var labelClipPathData = [[\n [0, 0],\n [xLen, 0],\n [xLen, yLen],\n [0, yLen]\n ]];\n\n\n var labelData = [];\n\n // invalidate the getTextLocation cache in case paths changed\n Lib.clearLocationCache();\n\n var contourFormat = contourPlot.labelFormatter(gd, cd0);\n\n var dummyText = Drawing.tester.append('text')\n .attr('data-notex', 1)\n .call(Drawing.font, contours.labelfont);\n\n // use `bounds` only to keep labels away from the x/y boundaries\n // `constrainToCarpet` below ensures labels don't go off the\n // carpet edges\n var bounds = {\n left: 0,\n right: xLen,\n center: xLen / 2,\n top: 0,\n bottom: yLen,\n middle: yLen / 2\n };\n\n var plotDiagonal = Math.sqrt(xLen * xLen + yLen * yLen);\n\n // the path length to use to scale the number of labels to draw:\n var normLength = constants.LABELDISTANCE * plotDiagonal /\n Math.max(1, pathinfo.length / constants.LABELINCREASE);\n\n linegroup.each(function(d) {\n var textOpts = contourPlot.calcTextOpts(d.level, contourFormat, dummyText, gd);\n\n d3.select(this).selectAll('path').each(function(pathData) {\n var path = this;\n var pathBounds = Lib.getVisibleSegment(path, bounds, textOpts.height / 2);\n if(!pathBounds) return;\n\n constrainToCarpet(path, pathData, d, pathBounds, carpet, textOpts.height);\n\n if(pathBounds.len < (textOpts.width + textOpts.height) * constants.LABELMIN) return;\n\n var maxLabels = Math.min(Math.ceil(pathBounds.len / normLength),\n constants.LABELMAX);\n\n for(var i = 0; i < maxLabels; i++) {\n var loc = contourPlot.findBestTextLocation(path, pathBounds, textOpts,\n labelData, bounds);\n\n if(!loc) break;\n\n contourPlot.addLabelData(loc, textOpts, labelData, labelClipPathData);\n }\n });\n });\n\n dummyText.remove();\n\n contourPlot.drawLabels(labelGroup, labelData, gd, lineClip,\n clipLinesForLabels ? labelClipPathData : null);\n }\n\n if(showLabels && !showLines) linegroup.remove();\n}\n\n// figure out if this path goes off the edge of the carpet\n// and shorten the part we call visible to keep labels away from the edge\nfunction constrainToCarpet(path, pathData, levelData, pathBounds, carpet, textHeight) {\n var pathABData;\n for(var i = 0; i < levelData.pedgepaths.length; i++) {\n if(pathData === levelData.pedgepaths[i]) {\n pathABData = levelData.edgepaths[i];\n }\n }\n if(!pathABData) return;\n\n var aMin = carpet.a[0];\n var aMax = carpet.a[carpet.a.length - 1];\n var bMin = carpet.b[0];\n var bMax = carpet.b[carpet.b.length - 1];\n\n function getOffset(abPt, pathVector) {\n var offset = 0;\n var edgeVector;\n var dAB = 0.1;\n if(Math.abs(abPt[0] - aMin) < dAB || Math.abs(abPt[0] - aMax) < dAB) {\n edgeVector = normalizeVector(carpet.dxydb_rough(abPt[0], abPt[1], dAB));\n offset = Math.max(offset, textHeight * vectorTan(pathVector, edgeVector) / 2);\n }\n\n if(Math.abs(abPt[1] - bMin) < dAB || Math.abs(abPt[1] - bMax) < dAB) {\n edgeVector = normalizeVector(carpet.dxyda_rough(abPt[0], abPt[1], dAB));\n offset = Math.max(offset, textHeight * vectorTan(pathVector, edgeVector) / 2);\n }\n return offset;\n }\n\n var startVector = getUnitVector(path, 0, 1);\n var endVector = getUnitVector(path, pathBounds.total, pathBounds.total - 1);\n var minStart = getOffset(pathABData[0], startVector);\n var maxEnd = pathBounds.total - getOffset(pathABData[pathABData.length - 1], endVector);\n\n if(pathBounds.min < minStart) pathBounds.min = minStart;\n if(pathBounds.max > maxEnd) pathBounds.max = maxEnd;\n\n pathBounds.len = pathBounds.max - pathBounds.min;\n}\n\nfunction getUnitVector(path, p0, p1) {\n var pt0 = path.getPointAtLength(p0);\n var pt1 = path.getPointAtLength(p1);\n var dx = pt1.x - pt0.x;\n var dy = pt1.y - pt0.y;\n var len = Math.sqrt(dx * dx + dy * dy);\n return [dx / len, dy / len];\n}\n\nfunction normalizeVector(v) {\n var len = Math.sqrt(v[0] * v[0] + v[1] * v[1]);\n return [v[0] / len, v[1] / len];\n}\n\nfunction vectorTan(v0, v1) {\n var cos = Math.abs(v0[0] * v1[0] + v0[1] * v1[1]);\n var sin = Math.sqrt(1 - cos * cos);\n return sin / cos;\n}\n\nfunction makeBackground(plotgroup, clipsegments, xaxis, yaxis, isConstraint, coloring) {\n var seg, xp, yp, i;\n var bggroup = Lib.ensureSingle(plotgroup, 'g', 'contourbg');\n\n var bgfill = bggroup.selectAll('path')\n .data((coloring === 'fill' && !isConstraint) ? [0] : []);\n bgfill.enter().append('path');\n bgfill.exit().remove();\n\n var segs = [];\n for(i = 0; i < clipsegments.length; i++) {\n seg = clipsegments[i];\n xp = map1dArray([], seg.x, xaxis.c2p);\n yp = map1dArray([], seg.y, yaxis.c2p);\n segs.push(makepath(xp, yp, seg.bicubic));\n }\n\n bgfill\n .attr('d', 'M' + segs.join('L') + 'Z')\n .style('stroke', 'none');\n}\n\nfunction makeFills(trace, plotgroup, xa, ya, pathinfo, perimeter, ab2p, carpet, carpetcd, coloring, boundaryPath) {\n var hasFills = coloring === 'fill';\n\n // fills prefixBoundary in pathinfo items\n if(hasFills) {\n closeBoundaries(pathinfo, trace.contours);\n }\n\n var fillgroup = Lib.ensureSingle(plotgroup, 'g', 'contourfill');\n var fillitems = fillgroup.selectAll('path').data(hasFills ? pathinfo : []);\n fillitems.enter().append('path');\n fillitems.exit().remove();\n fillitems.each(function(pi) {\n // join all paths for this level together into a single path\n // first follow clockwise around the perimeter to close any open paths\n // if the whole perimeter is above this level, start with a path\n // enclosing the whole thing. With all that, the parity should mean\n // that we always fill everything above the contour, nothing below\n var fullpath = (pi.prefixBoundary ? boundaryPath : '') +\n joinAllPaths(trace, pi, perimeter, ab2p, carpet, carpetcd, xa, ya);\n\n if(!fullpath) {\n d3.select(this).remove();\n } else {\n d3.select(this)\n .attr('d', fullpath)\n .style('stroke', 'none');\n }\n });\n}\n\nfunction joinAllPaths(trace, pi, perimeter, ab2p, carpet, carpetcd, xa, ya) {\n var i;\n var fullpath = '';\n\n var startsleft = pi.edgepaths.map(function(v, i) { return i; });\n var newloop = true;\n var endpt, newendpt, cnt, nexti, possiblei, addpath;\n\n var atol = Math.abs(perimeter[0][0] - perimeter[2][0]) * 1e-4;\n var btol = Math.abs(perimeter[0][1] - perimeter[2][1]) * 1e-4;\n\n function istop(pt) { return Math.abs(pt[1] - perimeter[0][1]) < btol; }\n function isbottom(pt) { return Math.abs(pt[1] - perimeter[2][1]) < btol; }\n function isleft(pt) { return Math.abs(pt[0] - perimeter[0][0]) < atol; }\n function isright(pt) { return Math.abs(pt[0] - perimeter[2][0]) < atol; }\n\n function pathto(pt0, pt1) {\n var i, j, segments, axis;\n var path = '';\n\n if((istop(pt0) && !isright(pt0)) || (isbottom(pt0) && !isleft(pt0))) {\n axis = carpet.aaxis;\n segments = axisAlignedLine(carpet, carpetcd, [pt0[0], pt1[0]], 0.5 * (pt0[1] + pt1[1]));\n } else {\n axis = carpet.baxis;\n segments = axisAlignedLine(carpet, carpetcd, 0.5 * (pt0[0] + pt1[0]), [pt0[1], pt1[1]]);\n }\n\n for(i = 1; i < segments.length; i++) {\n path += axis.smoothing ? 'C' : 'L';\n for(j = 0; j < segments[i].length; j++) {\n var pt = segments[i][j];\n path += [xa.c2p(pt[0]), ya.c2p(pt[1])] + ' ';\n }\n }\n\n return path;\n }\n\n i = 0;\n endpt = null;\n while(startsleft.length) {\n var startpt = pi.edgepaths[i][0];\n\n if(endpt) {\n fullpath += pathto(endpt, startpt);\n }\n\n addpath = Drawing.smoothopen(pi.edgepaths[i].map(ab2p), pi.smoothing);\n fullpath += newloop ? addpath : addpath.replace(/^M/, 'L');\n startsleft.splice(startsleft.indexOf(i), 1);\n endpt = pi.edgepaths[i][pi.edgepaths[i].length - 1];\n nexti = -1;\n\n // now loop through sides, moving our endpoint until we find a new start\n for(cnt = 0; cnt < 4; cnt++) { // just to prevent infinite loops\n if(!endpt) {\n Lib.log('Missing end?', i, pi);\n break;\n }\n\n if(istop(endpt) && !isright(endpt)) {\n newendpt = perimeter[1]; // left top ---> right top\n } else if(isleft(endpt)) {\n newendpt = perimeter[0]; // left bottom ---> left top\n } else if(isbottom(endpt)) {\n newendpt = perimeter[3]; // right bottom\n } else if(isright(endpt)) {\n newendpt = perimeter[2]; // left bottom\n }\n\n for(possiblei = 0; possiblei < pi.edgepaths.length; possiblei++) {\n var ptNew = pi.edgepaths[possiblei][0];\n // is ptNew on the (horz. or vert.) segment from endpt to newendpt?\n if(Math.abs(endpt[0] - newendpt[0]) < atol) {\n if(Math.abs(endpt[0] - ptNew[0]) < atol &&\n (ptNew[1] - endpt[1]) * (newendpt[1] - ptNew[1]) >= 0) {\n newendpt = ptNew;\n nexti = possiblei;\n }\n } else if(Math.abs(endpt[1] - newendpt[1]) < btol) {\n if(Math.abs(endpt[1] - ptNew[1]) < btol &&\n (ptNew[0] - endpt[0]) * (newendpt[0] - ptNew[0]) >= 0) {\n newendpt = ptNew;\n nexti = possiblei;\n }\n } else {\n Lib.log('endpt to newendpt is not vert. or horz.', endpt, newendpt, ptNew);\n }\n }\n\n if(nexti >= 0) break;\n fullpath += pathto(endpt, newendpt);\n endpt = newendpt;\n }\n\n if(nexti === pi.edgepaths.length) {\n Lib.log('unclosed perimeter path');\n break;\n }\n\n i = nexti;\n\n // if we closed back on a loop we already included,\n // close it and start a new loop\n newloop = (startsleft.indexOf(i) === -1);\n if(newloop) {\n i = startsleft[0];\n fullpath += pathto(endpt, newendpt) + 'Z';\n endpt = null;\n }\n }\n\n // finally add the interior paths\n for(i = 0; i < pi.paths.length; i++) {\n fullpath += Drawing.smoothclosed(pi.paths[i].map(ab2p), pi.smoothing);\n }\n\n return fullpath;\n}\n","'use strict';\n\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar baseAttrs = require('../../plots/attributes');\nvar scatterMapAttrs = require('../scattermap/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\n/*\n * - https://docs.map.com/help/tutorials/make-a-heatmap-with-mapbox-gl-js/\n * - https://docs.mapbox.com/mapbox-gl-js/example/heatmap-layer/\n * - https://docs.mapbox.com/mapbox-gl-js/style-spec/#layers-heatmap\n * - https://blog.map.com/introducing-heatmaps-in-mapbox-gl-js-71355ada9e6c\n *\n * Gotchas:\n * - https://github.com/mapbox/mapbox-gl-js/issues/6463\n * - https://github.com/mapbox/mapbox-gl-js/issues/6112\n */\n\n/*\n *\n * In mathematical terms, Map GL heatmaps are a bivariate (2D) kernel density\n * estimation with a Gaussian kernel. It means that each data point has an area\n * of “influence” around it (called a kernel) where the numerical value of\n * influence (which we call density) decreases as you go further from the point.\n * If we sum density values of all points in every pixel of the screen, we get a\n * combined density value which we then map to a heatmap color.\n *\n */\n\nmodule.exports = extendFlat({\n lon: scatterMapAttrs.lon,\n lat: scatterMapAttrs.lat,\n\n z: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the points\\' weight.',\n 'For example, a value of 10 would be equivalent to having 10 points of weight 1',\n 'in the same spot'\n ].join(' ')\n },\n\n radius: {\n valType: 'number',\n editType: 'plot',\n arrayOk: true,\n min: 1,\n dflt: 30,\n description: [\n 'Sets the radius of influence of one `lon` / `lat` point in pixels.',\n 'Increasing the value makes the densitymap trace smoother, but less detailed.'\n ].join(' ')\n },\n\n below: {\n valType: 'string',\n editType: 'plot',\n description: [\n 'Determines if the densitymap trace will be inserted',\n 'before the layer with the specified ID.',\n 'By default, densitymap traces are placed below the first',\n 'layer of type symbol',\n 'If set to \\'\\',',\n 'the layer will be inserted above every existing layer.'\n ].join(' ')\n },\n\n text: scatterMapAttrs.text,\n hovertext: scatterMapAttrs.hovertext,\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['lon', 'lat', 'z', 'text', 'name']\n }),\n hovertemplate: hovertemplateAttrs(),\n showlegend: extendFlat({}, baseAttrs.showlegend, {dflt: false})\n},\n colorScaleAttrs('', {\n cLetter: 'z',\n editTypeOverride: 'calc'\n })\n);\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nvar colorscaleCalc = require('../../components/colorscale/calc');\nvar _ = require('../../lib')._;\n\nmodule.exports = function calc(gd, trace) {\n var len = trace._length;\n var calcTrace = new Array(len);\n var z = trace.z;\n var hasZ = isArrayOrTypedArray(z) && z.length;\n\n for(var i = 0; i < len; i++) {\n var cdi = calcTrace[i] = {};\n\n var lon = trace.lon[i];\n var lat = trace.lat[i];\n\n cdi.lonlat = isNumeric(lon) && isNumeric(lat) ?\n [+lon, +lat] :\n [BADNUM, BADNUM];\n\n if(hasZ) {\n var zi = z[i];\n cdi.z = isNumeric(zi) ? zi : BADNUM;\n }\n }\n\n colorscaleCalc(gd, trace, {\n vals: hasZ ? z : [0, 1],\n containerStr: '',\n cLetter: 'z'\n });\n\n if(len) {\n calcTrace[0].t = {\n labels: {\n lat: _(gd, 'lat:') + ' ',\n lon: _(gd, 'lon:') + ' '\n }\n };\n }\n\n return calcTrace;\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar Color = require('../../components/color');\nvar Colorscale = require('../../components/colorscale');\n\nvar BADNUM = require('../../constants/numerical').BADNUM;\nvar makeBlank = require('../../lib/geojson_utils').makeBlank;\n\nmodule.exports = function convert(calcTrace) {\n var trace = calcTrace[0].trace;\n var isVisible = (trace.visible === true && trace._length !== 0);\n\n var heatmap = {\n layout: {visibility: 'none'},\n paint: {}\n };\n\n var opts = trace._opts = {\n heatmap: heatmap,\n geojson: makeBlank()\n };\n\n // early return if not visible or placeholder\n if(!isVisible) return opts;\n\n var features = [];\n var i;\n\n var z = trace.z;\n var radius = trace.radius;\n var hasZ = Lib.isArrayOrTypedArray(z) && z.length;\n var hasArrayRadius = Lib.isArrayOrTypedArray(radius);\n\n for(i = 0; i < calcTrace.length; i++) {\n var cdi = calcTrace[i];\n var lonlat = cdi.lonlat;\n\n if(lonlat[0] !== BADNUM) {\n var props = {};\n\n if(hasZ) {\n var zi = cdi.z;\n props.z = zi !== BADNUM ? zi : 0;\n }\n if(hasArrayRadius) {\n props.r = (isNumeric(radius[i]) && radius[i] > 0) ? +radius[i] : 0;\n }\n\n features.push({\n type: 'Feature',\n geometry: {type: 'Point', coordinates: lonlat},\n properties: props\n });\n }\n }\n\n var cOpts = Colorscale.extractOpts(trace);\n var scl = cOpts.reversescale ?\n Colorscale.flipScale(cOpts.colorscale) :\n cOpts.colorscale;\n\n // Add alpha channel to first colorscale step.\n // If not, we would essentially color the entire map.\n // See https://maplibre.org/maplibre-gl-js/docs/examples/heatmap-layer/\n var scl01 = scl[0][1];\n var color0 = Color.opacity(scl01) < 1 ? scl01 : Color.addOpacity(scl01, 0);\n\n var heatmapColor = [\n 'interpolate', ['linear'],\n ['heatmap-density'],\n 0, color0\n ];\n for(i = 1; i < scl.length; i++) {\n heatmapColor.push(scl[i][0], scl[i][1]);\n }\n\n // Those \"weights\" have to be in [0, 1], we can do this either:\n // - as here using a map-gl expression\n // - or, scale the 'z' property in the feature loop\n var zExp = [\n 'interpolate', ['linear'],\n ['get', 'z'],\n cOpts.min, 0,\n cOpts.max, 1\n ];\n\n Lib.extendFlat(opts.heatmap.paint, {\n 'heatmap-weight': hasZ ? zExp : 1 / (cOpts.max - cOpts.min),\n\n 'heatmap-color': heatmapColor,\n\n 'heatmap-radius': hasArrayRadius ?\n {type: 'identity', property: 'r'} :\n trace.radius,\n\n 'heatmap-opacity': trace.opacity\n });\n\n opts.geojson = {type: 'FeatureCollection', features: features};\n opts.heatmap.layout.visibility = 'visible';\n\n return opts;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var lon = coerce('lon') || [];\n var lat = coerce('lat') || [];\n\n var len = Math.min(lon.length, lat.length);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n traceOut._length = len;\n\n coerce('z');\n coerce('radius');\n coerce('below');\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'z'});\n};\n","'use strict';\n\nmodule.exports = function eventData(out, pt) {\n out.lon = pt.lon;\n out.lat = pt.lat;\n out.z = pt.z;\n return out;\n};\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\nvar scatterMapHoverPoints = require('../scattermap/hover').hoverPoints;\nvar getExtraText = require('../scattermap/hover').getExtraText;\n\nmodule.exports = function hoverPoints(pointData, xval, yval) {\n var pts = scatterMapHoverPoints(pointData, xval, yval);\n if(!pts) return;\n\n var newPointData = pts[0];\n var cd = newPointData.cd;\n var trace = cd[0].trace;\n var di = cd[newPointData.index];\n\n // let Fx.hover pick the color\n delete newPointData.color;\n\n if('z' in di) {\n var ax = newPointData.subplot.mockAxis;\n newPointData.z = di.z;\n newPointData.zLabel = Axes.tickText(ax, ax.c2l(di.z), 'hover').text;\n }\n\n newPointData.extraText = getExtraText(trace, di, cd[0].t.labels);\n\n return [newPointData];\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../heatmap/colorbar'),\n formatLabels: require('../scattermap/format_labels'),\n calc: require('./calc'),\n plot: require('./plot'),\n hoverPoints: require('./hover'),\n eventData: require('./event_data'),\n\n getBelow: function(trace, subplot) {\n var mapLayers = subplot.getMapLayers();\n\n // find first layer with `type: 'symbol'`,\n // that is not a plotly layer\n for(var i = 0; i < mapLayers.length; i++) {\n var layer = mapLayers[i];\n var layerId = layer.id;\n if(layer.type === 'symbol' &&\n typeof layerId === 'string' && layerId.indexOf('plotly-') === -1\n ) {\n return layerId;\n }\n }\n },\n\n moduleType: 'trace',\n name: 'densitymap',\n basePlotModule: require('../../plots/map'),\n categories: ['map', 'gl', 'showLegend'],\n meta: {\n hr_name: 'density_map',\n description: [\n 'Draws a bivariate kernel density estimation with a Gaussian kernel',\n 'from `lon` and `lat` coordinates and optional `z` values using a colorscale.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar convert = require('./convert');\nvar LAYER_PREFIX = require('../../plots/map/constants').traceLayerPrefix;\n\nfunction DensityMap(subplot, uid) {\n this.type = 'densitymap';\n this.subplot = subplot;\n this.uid = uid;\n\n this.sourceId = 'source-' + uid;\n\n this.layerList = [\n ['heatmap', LAYER_PREFIX + uid + '-heatmap']\n ];\n\n // previous 'below' value,\n // need this to update it properly\n this.below = null;\n}\n\nvar proto = DensityMap.prototype;\n\nproto.update = function(calcTrace) {\n var subplot = this.subplot;\n var layerList = this.layerList;\n var optsAll = convert(calcTrace);\n var below = subplot.belowLookup['trace-' + this.uid];\n\n subplot.map\n .getSource(this.sourceId)\n .setData(optsAll.geojson);\n\n if(below !== this.below) {\n this._removeLayers();\n this._addLayers(optsAll, below);\n this.below = below;\n }\n\n for(var i = 0; i < layerList.length; i++) {\n var item = layerList[i];\n var k = item[0];\n var id = item[1];\n var opts = optsAll[k];\n\n subplot.setOptions(id, 'setLayoutProperty', opts.layout);\n\n if(opts.layout.visibility === 'visible') {\n subplot.setOptions(id, 'setPaintProperty', opts.paint);\n }\n }\n};\n\nproto._addLayers = function(optsAll, below) {\n var subplot = this.subplot;\n var layerList = this.layerList;\n var sourceId = this.sourceId;\n\n for(var i = 0; i < layerList.length; i++) {\n var item = layerList[i];\n var k = item[0];\n var opts = optsAll[k];\n\n subplot.addLayer({\n type: k,\n id: item[1],\n source: sourceId,\n layout: opts.layout,\n paint: opts.paint\n }, below);\n }\n};\n\nproto._removeLayers = function() {\n var map = this.subplot.map;\n var layerList = this.layerList;\n\n for(var i = layerList.length - 1; i >= 0; i--) {\n map.removeLayer(layerList[i][1]);\n }\n};\n\nproto.dispose = function() {\n var map = this.subplot.map;\n this._removeLayers();\n map.removeSource(this.sourceId);\n};\n\nmodule.exports = function createDensityMap(subplot, calcTrace) {\n var trace = calcTrace[0].trace;\n var densityMap = new DensityMap(subplot, trace.uid);\n var sourceId = densityMap.sourceId;\n var optsAll = convert(calcTrace);\n var below = densityMap.below = subplot.belowLookup['trace-' + trace.uid];\n\n subplot.map.addSource(sourceId, {\n type: 'geojson',\n data: optsAll.geojson\n });\n\n densityMap._addLayers(optsAll, below);\n\n return densityMap;\n};\n","'use strict';\n\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar baseAttrs = require('../../plots/attributes');\nvar scatterMapboxAttrs = require('../scattermapbox/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\n/*\n * - https://docs.mapbox.com/help/tutorials/make-a-heatmap-with-mapbox-gl-js/\n * - https://docs.mapbox.com/mapbox-gl-js/example/heatmap-layer/\n * - https://docs.mapbox.com/mapbox-gl-js/style-spec/#layers-heatmap\n * - https://blog.mapbox.com/introducing-heatmaps-in-mapbox-gl-js-71355ada9e6c\n *\n * Gotchas:\n * - https://github.com/mapbox/mapbox-gl-js/issues/6463\n * - https://github.com/mapbox/mapbox-gl-js/issues/6112\n */\n\n/*\n *\n * In mathematical terms, Mapbox GL heatmaps are a bivariate (2D) kernel density\n * estimation with a Gaussian kernel. It means that each data point has an area\n * of “influence” around it (called a kernel) where the numerical value of\n * influence (which we call density) decreases as you go further from the point.\n * If we sum density values of all points in every pixel of the screen, we get a\n * combined density value which we then map to a heatmap color.\n *\n */\n\nmodule.exports = extendFlat({\n lon: scatterMapboxAttrs.lon,\n lat: scatterMapboxAttrs.lat,\n\n z: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the points\\' weight.',\n 'For example, a value of 10 would be equivalent to having 10 points of weight 1',\n 'in the same spot'\n ].join(' ')\n },\n\n radius: {\n valType: 'number',\n editType: 'plot',\n arrayOk: true,\n min: 1,\n dflt: 30,\n description: [\n 'Sets the radius of influence of one `lon` / `lat` point in pixels.',\n 'Increasing the value makes the densitymapbox trace smoother, but less detailed.'\n ].join(' ')\n },\n\n below: {\n valType: 'string',\n editType: 'plot',\n description: [\n 'Determines if the densitymapbox trace will be inserted',\n 'before the layer with the specified ID.',\n 'By default, densitymapbox traces are placed below the first',\n 'layer of type symbol',\n 'If set to \\'\\',',\n 'the layer will be inserted above every existing layer.'\n ].join(' ')\n },\n\n text: scatterMapboxAttrs.text,\n hovertext: scatterMapboxAttrs.hovertext,\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['lon', 'lat', 'z', 'text', 'name']\n }),\n hovertemplate: hovertemplateAttrs(),\n showlegend: extendFlat({}, baseAttrs.showlegend, {dflt: false})\n},\n colorScaleAttrs('', {\n cLetter: 'z',\n editTypeOverride: 'calc'\n })\n);\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nvar colorscaleCalc = require('../../components/colorscale/calc');\nvar _ = require('../../lib')._;\n\nmodule.exports = function calc(gd, trace) {\n var len = trace._length;\n var calcTrace = new Array(len);\n var z = trace.z;\n var hasZ = isArrayOrTypedArray(z) && z.length;\n\n for(var i = 0; i < len; i++) {\n var cdi = calcTrace[i] = {};\n\n var lon = trace.lon[i];\n var lat = trace.lat[i];\n\n cdi.lonlat = isNumeric(lon) && isNumeric(lat) ?\n [+lon, +lat] :\n [BADNUM, BADNUM];\n\n if(hasZ) {\n var zi = z[i];\n cdi.z = isNumeric(zi) ? zi : BADNUM;\n }\n }\n\n colorscaleCalc(gd, trace, {\n vals: hasZ ? z : [0, 1],\n containerStr: '',\n cLetter: 'z'\n });\n\n if(len) {\n calcTrace[0].t = {\n labels: {\n lat: _(gd, 'lat:') + ' ',\n lon: _(gd, 'lon:') + ' '\n }\n };\n }\n\n return calcTrace;\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar Color = require('../../components/color');\nvar Colorscale = require('../../components/colorscale');\n\nvar BADNUM = require('../../constants/numerical').BADNUM;\nvar makeBlank = require('../../lib/geojson_utils').makeBlank;\n\nmodule.exports = function convert(calcTrace) {\n var trace = calcTrace[0].trace;\n var isVisible = (trace.visible === true && trace._length !== 0);\n\n var heatmap = {\n layout: {visibility: 'none'},\n paint: {}\n };\n\n var opts = trace._opts = {\n heatmap: heatmap,\n geojson: makeBlank()\n };\n\n // early return if not visible or placeholder\n if(!isVisible) return opts;\n\n var features = [];\n var i;\n\n var z = trace.z;\n var radius = trace.radius;\n var hasZ = Lib.isArrayOrTypedArray(z) && z.length;\n var hasArrayRadius = Lib.isArrayOrTypedArray(radius);\n\n for(i = 0; i < calcTrace.length; i++) {\n var cdi = calcTrace[i];\n var lonlat = cdi.lonlat;\n\n if(lonlat[0] !== BADNUM) {\n var props = {};\n\n if(hasZ) {\n var zi = cdi.z;\n props.z = zi !== BADNUM ? zi : 0;\n }\n if(hasArrayRadius) {\n props.r = (isNumeric(radius[i]) && radius[i] > 0) ? +radius[i] : 0;\n }\n\n features.push({\n type: 'Feature',\n geometry: {type: 'Point', coordinates: lonlat},\n properties: props\n });\n }\n }\n\n var cOpts = Colorscale.extractOpts(trace);\n var scl = cOpts.reversescale ?\n Colorscale.flipScale(cOpts.colorscale) :\n cOpts.colorscale;\n\n // Add alpha channel to first colorscale step.\n // If not, we would essentially color the entire map.\n // See https://docs.mapbox.com/mapbox-gl-js/example/heatmap-layer/\n var scl01 = scl[0][1];\n var color0 = Color.opacity(scl01) < 1 ? scl01 : Color.addOpacity(scl01, 0);\n\n var heatmapColor = [\n 'interpolate', ['linear'],\n ['heatmap-density'],\n 0, color0\n ];\n for(i = 1; i < scl.length; i++) {\n heatmapColor.push(scl[i][0], scl[i][1]);\n }\n\n // Those \"weights\" have to be in [0, 1], we can do this either:\n // - as here using a mapbox-gl expression\n // - or, scale the 'z' property in the feature loop\n var zExp = [\n 'interpolate', ['linear'],\n ['get', 'z'],\n cOpts.min, 0,\n cOpts.max, 1\n ];\n\n Lib.extendFlat(opts.heatmap.paint, {\n 'heatmap-weight': hasZ ? zExp : 1 / (cOpts.max - cOpts.min),\n\n 'heatmap-color': heatmapColor,\n\n 'heatmap-radius': hasArrayRadius ?\n {type: 'identity', property: 'r'} :\n trace.radius,\n\n 'heatmap-opacity': trace.opacity\n });\n\n opts.geojson = {type: 'FeatureCollection', features: features};\n opts.heatmap.layout.visibility = 'visible';\n\n return opts;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var lon = coerce('lon') || [];\n var lat = coerce('lat') || [];\n\n var len = Math.min(lon.length, lat.length);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n traceOut._length = len;\n\n coerce('z');\n coerce('radius');\n coerce('below');\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'z'});\n};\n","'use strict';\n\nmodule.exports = function eventData(out, pt) {\n out.lon = pt.lon;\n out.lat = pt.lat;\n out.z = pt.z;\n return out;\n};\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\nvar scatterMapboxHoverPoints = require('../scattermapbox/hover').hoverPoints;\nvar getExtraText = require('../scattermapbox/hover').getExtraText;\n\nmodule.exports = function hoverPoints(pointData, xval, yval) {\n var pts = scatterMapboxHoverPoints(pointData, xval, yval);\n if(!pts) return;\n\n var newPointData = pts[0];\n var cd = newPointData.cd;\n var trace = cd[0].trace;\n var di = cd[newPointData.index];\n\n // let Fx.hover pick the color\n delete newPointData.color;\n\n if('z' in di) {\n var ax = newPointData.subplot.mockAxis;\n newPointData.z = di.z;\n newPointData.zLabel = Axes.tickText(ax, ax.c2l(di.z), 'hover').text;\n }\n\n newPointData.extraText = getExtraText(trace, di, cd[0].t.labels);\n\n return [newPointData];\n};\n","'use strict';\n\nvar deprecationWarning = [\n '*densitymapbox* trace is deprecated!',\n 'Please consider switching to the *densitymap* trace type and `map` subplots.',\n 'Learn more at: https://plotly.com/javascript/maplibre-migration/'\n].join(' ');\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../heatmap/colorbar'),\n formatLabels: require('../scattermapbox/format_labels'),\n calc: require('./calc'),\n plot: require('./plot'),\n hoverPoints: require('./hover'),\n eventData: require('./event_data'),\n\n getBelow: function(trace, subplot) {\n var mapLayers = subplot.getMapLayers();\n\n // find first layer with `type: 'symbol'`,\n // that is not a plotly layer\n for(var i = 0; i < mapLayers.length; i++) {\n var layer = mapLayers[i];\n var layerId = layer.id;\n if(layer.type === 'symbol' &&\n typeof layerId === 'string' && layerId.indexOf('plotly-') === -1\n ) {\n return layerId;\n }\n }\n },\n\n moduleType: 'trace',\n name: 'densitymapbox',\n basePlotModule: require('../../plots/mapbox'),\n categories: ['mapbox', 'gl', 'showLegend'],\n meta: {\n hr_name: 'density_mapbox',\n description: [\n deprecationWarning,\n 'Draws a bivariate kernel density estimation with a Gaussian kernel',\n 'from `lon` and `lat` coordinates and optional `z` values using a colorscale.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar convert = require('./convert');\nvar LAYER_PREFIX = require('../../plots/mapbox/constants').traceLayerPrefix;\n\nfunction DensityMapbox(subplot, uid) {\n this.type = 'densitymapbox';\n this.subplot = subplot;\n this.uid = uid;\n\n this.sourceId = 'source-' + uid;\n\n this.layerList = [\n ['heatmap', LAYER_PREFIX + uid + '-heatmap']\n ];\n\n // previous 'below' value,\n // need this to update it properly\n this.below = null;\n}\n\nvar proto = DensityMapbox.prototype;\n\nproto.update = function(calcTrace) {\n var subplot = this.subplot;\n var layerList = this.layerList;\n var optsAll = convert(calcTrace);\n var below = subplot.belowLookup['trace-' + this.uid];\n\n subplot.map\n .getSource(this.sourceId)\n .setData(optsAll.geojson);\n\n if(below !== this.below) {\n this._removeLayers();\n this._addLayers(optsAll, below);\n this.below = below;\n }\n\n for(var i = 0; i < layerList.length; i++) {\n var item = layerList[i];\n var k = item[0];\n var id = item[1];\n var opts = optsAll[k];\n\n subplot.setOptions(id, 'setLayoutProperty', opts.layout);\n\n if(opts.layout.visibility === 'visible') {\n subplot.setOptions(id, 'setPaintProperty', opts.paint);\n }\n }\n};\n\nproto._addLayers = function(optsAll, below) {\n var subplot = this.subplot;\n var layerList = this.layerList;\n var sourceId = this.sourceId;\n\n for(var i = 0; i < layerList.length; i++) {\n var item = layerList[i];\n var k = item[0];\n var opts = optsAll[k];\n\n subplot.addLayer({\n type: k,\n id: item[1],\n source: sourceId,\n layout: opts.layout,\n paint: opts.paint\n }, below);\n }\n};\n\nproto._removeLayers = function() {\n var map = this.subplot.map;\n var layerList = this.layerList;\n\n for(var i = layerList.length - 1; i >= 0; i--) {\n map.removeLayer(layerList[i][1]);\n }\n};\n\nproto.dispose = function() {\n var map = this.subplot.map;\n this._removeLayers();\n map.removeSource(this.sourceId);\n};\n\nmodule.exports = function createDensityMapbox(subplot, calcTrace) {\n var trace = calcTrace[0].trace;\n var densityMapbox = new DensityMapbox(subplot, trace.uid);\n var sourceId = densityMapbox.sourceId;\n var optsAll = convert(calcTrace);\n var below = densityMapbox.below = subplot.belowLookup['trace-' + trace.uid];\n\n subplot.map.addSource(sourceId, {\n type: 'geojson',\n data: optsAll.geojson\n });\n\n densityMapbox._addLayers(optsAll, below);\n\n return densityMapbox;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\n// arrayOk attributes, merge them into calcdata array\nmodule.exports = function arraysToCalcdata(cd, trace) {\n for(var i = 0; i < cd.length; i++) cd[i].i = i;\n\n Lib.mergeArray(trace.text, cd, 'tx');\n Lib.mergeArray(trace.hovertext, cd, 'htx');\n\n var marker = trace.marker;\n if(marker) {\n Lib.mergeArray(marker.opacity, cd, 'mo');\n Lib.mergeArray(marker.color, cd, 'mc');\n\n var markerLine = marker.line;\n if(markerLine) {\n Lib.mergeArray(markerLine.color, cd, 'mlc');\n Lib.mergeArrayCastPositive(markerLine.width, cd, 'mlw');\n }\n }\n};\n","'use strict';\n\nvar barAttrs = require('../bar/attributes');\nvar lineAttrs = require('../scatter/attributes').line;\nvar baseAttrs = require('../../plots/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar constants = require('./constants');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar Color = require('../../components/color');\n\nmodule.exports = {\n x: barAttrs.x,\n x0: barAttrs.x0,\n dx: barAttrs.dx,\n y: barAttrs.y,\n y0: barAttrs.y0,\n dy: barAttrs.dy,\n\n xperiod: barAttrs.xperiod,\n yperiod: barAttrs.yperiod,\n xperiod0: barAttrs.xperiod0,\n yperiod0: barAttrs.yperiod0,\n xperiodalignment: barAttrs.xperiodalignment,\n yperiodalignment: barAttrs.yperiodalignment,\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n\n hovertext: barAttrs.hovertext,\n hovertemplate: hovertemplateAttrs({}, {\n keys: constants.eventDataKeys\n }),\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['name', 'x', 'y', 'text', 'percent initial', 'percent previous', 'percent total']\n }),\n\n textinfo: {\n valType: 'flaglist',\n flags: ['label', 'text', 'percent initial', 'percent previous', 'percent total', 'value'],\n extras: ['none'],\n editType: 'plot',\n arrayOk: false,\n description: [\n 'Determines which trace information appear on the graph.',\n 'In the case of having multiple funnels, percentages & totals',\n 'are computed separately (per trace).'\n ].join(' ')\n },\n // TODO: incorporate `label` and `value` in the eventData\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: constants.eventDataKeys.concat(['label', 'value'])\n }),\n\n text: barAttrs.text,\n textposition: barAttrs.textposition,\n insidetextanchor: extendFlat({}, barAttrs.insidetextanchor, {dflt: 'middle'}),\n textangle: extendFlat({}, barAttrs.textangle, {dflt: 0}),\n textfont: barAttrs.textfont,\n insidetextfont: barAttrs.insidetextfont,\n outsidetextfont: barAttrs.outsidetextfont,\n constraintext: barAttrs.constraintext,\n cliponaxis: barAttrs.cliponaxis,\n\n orientation: extendFlat({}, barAttrs.orientation, {\n description: [\n 'Sets the orientation of the funnels.',\n 'With *v* (*h*), the value of the each bar spans',\n 'along the vertical (horizontal).',\n 'By default funnels are tend to be oriented horizontally;',\n 'unless only *y* array is presented or orientation is set to *v*.',\n 'Also regarding graphs including only \\'horizontal\\' funnels,',\n '*autorange* on the *y-axis* are set to *reversed*.'\n ].join(' ')\n }),\n\n offset: extendFlat({}, barAttrs.offset, {arrayOk: false}),\n width: extendFlat({}, barAttrs.width, {arrayOk: false}),\n\n marker: funnelMarker(),\n\n connector: {\n fillcolor: {\n valType: 'color',\n editType: 'style',\n description: [\n 'Sets the fill color.'\n ].join(' ')\n },\n line: {\n color: extendFlat({}, lineAttrs.color, {dflt: Color.defaultLine}),\n width: extendFlat({}, lineAttrs.width, {\n dflt: 0,\n editType: 'plot',\n }),\n dash: lineAttrs.dash,\n editType: 'style'\n },\n visible: {\n valType: 'boolean',\n dflt: true,\n editType: 'plot',\n description: [\n 'Determines if connector regions and lines are drawn.'\n ].join(' ')\n },\n editType: 'plot'\n },\n\n offsetgroup: barAttrs.offsetgroup,\n alignmentgroup: barAttrs.alignmentgroup,\n zorder: barAttrs.zorder\n};\n\nfunction funnelMarker() {\n var marker = extendFlat({}, barAttrs.marker);\n delete marker.pattern;\n delete marker.cornerradius;\n return marker;\n}\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\nvar alignPeriod = require('../../plots/cartesian/align_period');\nvar arraysToCalcdata = require('./arrays_to_calcdata');\nvar calcSelection = require('../scatter/calc_selection');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nmodule.exports = function calc(gd, trace) {\n var xa = Axes.getFromId(gd, trace.xaxis || 'x');\n var ya = Axes.getFromId(gd, trace.yaxis || 'y');\n var size, pos, origPos, pObj, hasPeriod, pLetter, i, cdi;\n\n if(trace.orientation === 'h') {\n size = xa.makeCalcdata(trace, 'x');\n origPos = ya.makeCalcdata(trace, 'y');\n pObj = alignPeriod(trace, ya, 'y', origPos);\n hasPeriod = !!trace.yperiodalignment;\n pLetter = 'y';\n } else {\n size = ya.makeCalcdata(trace, 'y');\n origPos = xa.makeCalcdata(trace, 'x');\n pObj = alignPeriod(trace, xa, 'x', origPos);\n hasPeriod = !!trace.xperiodalignment;\n pLetter = 'x';\n }\n pos = pObj.vals;\n\n // create the \"calculated data\" to plot\n var serieslen = Math.min(pos.length, size.length);\n var cd = new Array(serieslen);\n\n // Unlike other bar-like traces funnels do not support base attribute.\n // bases for funnels are computed internally in a way that\n // the mid-point of each bar are located on the axis line.\n trace._base = [];\n\n // set position and size\n for(i = 0; i < serieslen; i++) {\n // treat negative values as bad numbers\n if(size[i] < 0) size[i] = BADNUM;\n\n var connectToNext = false;\n if(size[i] !== BADNUM) {\n if(i + 1 < serieslen && size[i + 1] !== BADNUM) {\n connectToNext = true;\n }\n }\n\n cdi = cd[i] = {\n p: pos[i],\n s: size[i],\n cNext: connectToNext\n };\n\n trace._base[i] = -0.5 * cdi.s;\n\n if(hasPeriod) {\n cd[i].orig_p = origPos[i]; // used by hover\n cd[i][pLetter + 'End'] = pObj.ends[i];\n cd[i][pLetter + 'Start'] = pObj.starts[i];\n }\n\n if(trace.ids) {\n cdi.id = String(trace.ids[i]);\n }\n\n // calculate total values\n if(i === 0) cd[0].vTotal = 0;\n cd[0].vTotal += fixNum(cdi.s);\n\n // ratio from initial value\n cdi.begR = fixNum(cdi.s) / fixNum(cd[0].s);\n }\n\n var prevGoodNum;\n for(i = 0; i < serieslen; i++) {\n cdi = cd[i];\n if(cdi.s === BADNUM) continue;\n\n // ratio of total value\n cdi.sumR = cdi.s / cd[0].vTotal;\n\n // ratio of previous (good) value\n cdi.difR = (prevGoodNum !== undefined) ? cdi.s / prevGoodNum : 1;\n\n prevGoodNum = cdi.s;\n }\n\n arraysToCalcdata(cd, trace);\n calcSelection(cd, trace);\n\n return cd;\n};\n\nfunction fixNum(a) {\n return (a === BADNUM) ? 0 : a;\n}\n","'use strict';\n\nmodule.exports = {\n eventDataKeys: [\n 'percentInitial',\n 'percentPrevious',\n 'percentTotal'\n ]\n};\n","'use strict';\n\nvar setGroupPositions = require('../bar/cross_trace_calc').setGroupPositions;\n\nmodule.exports = function crossTraceCalc(gd, plotinfo) {\n var fullLayout = gd._fullLayout;\n var fullData = gd._fullData;\n var calcdata = gd.calcdata;\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var funnels = [];\n var funnelsVert = [];\n var funnelsHorz = [];\n var cd, i;\n\n for(i = 0; i < fullData.length; i++) {\n var fullTrace = fullData[i];\n var isHorizontal = (fullTrace.orientation === 'h');\n\n if(\n fullTrace.visible === true &&\n fullTrace.xaxis === xa._id &&\n fullTrace.yaxis === ya._id &&\n fullTrace.type === 'funnel'\n ) {\n cd = calcdata[i];\n\n if(isHorizontal) {\n funnelsHorz.push(cd);\n } else {\n funnelsVert.push(cd);\n }\n\n funnels.push(cd);\n }\n }\n\n var opts = {\n mode: fullLayout.funnelmode,\n norm: fullLayout.funnelnorm,\n gap: fullLayout.funnelgap,\n groupgap: fullLayout.funnelgroupgap\n };\n\n setGroupPositions(gd, xa, ya, funnelsVert, opts);\n setGroupPositions(gd, ya, xa, funnelsHorz, opts);\n\n for(i = 0; i < funnels.length; i++) {\n cd = funnels[i];\n\n for(var j = 0; j < cd.length; j++) {\n if(j + 1 < cd.length) {\n cd[j].nextP0 = cd[j + 1].p0;\n cd[j].nextS0 = cd[j + 1].s0;\n\n cd[j].nextP1 = cd[j + 1].p1;\n cd[j].nextS1 = cd[j + 1].s1;\n }\n }\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar handleGroupingDefaults = require('../scatter/grouping_defaults');\nvar handleText = require('../bar/defaults').handleText;\nvar handleXYDefaults = require('../scatter/xy_defaults');\nvar handlePeriodDefaults = require('../scatter/period_defaults');\nvar attributes = require('./attributes');\nvar Color = require('../../components/color');\n\nfunction supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleXYDefaults(traceIn, traceOut, layout, coerce);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n handlePeriodDefaults(traceIn, traceOut, layout, coerce);\n coerce('xhoverformat');\n coerce('yhoverformat');\n\n coerce('orientation', (traceOut.y && !traceOut.x) ? 'v' : 'h');\n coerce('offset');\n coerce('width');\n\n var text = coerce('text');\n\n coerce('hovertext');\n coerce('hovertemplate');\n\n var textposition = coerce('textposition');\n handleText(traceIn, traceOut, layout, coerce, textposition, {\n moduleHasSelected: false,\n moduleHasUnselected: false,\n moduleHasConstrain: true,\n moduleHasCliponaxis: true,\n moduleHasTextangle: true,\n moduleHasInsideanchor: true\n });\n\n if(traceOut.textposition !== 'none' && !traceOut.texttemplate) {\n coerce('textinfo', Lib.isArrayOrTypedArray(text) ? 'text+value' : 'value');\n }\n\n var markerColor = coerce('marker.color', defaultColor);\n coerce('marker.line.color', Color.defaultLine);\n coerce('marker.line.width');\n\n var connectorVisible = coerce('connector.visible');\n if(connectorVisible) {\n coerce('connector.fillcolor', defaultFillColor(markerColor));\n\n var connectorLineWidth = coerce('connector.line.width');\n if(connectorLineWidth) {\n coerce('connector.line.color');\n coerce('connector.line.dash');\n }\n }\n coerce('zorder');\n}\n\nfunction defaultFillColor(markerColor) {\n var cBase = Lib.isArrayOrTypedArray(markerColor) ? '#000' : markerColor;\n\n return Color.addOpacity(cBase, 0.5 * Color.opacity(cBase));\n}\n\nfunction crossTraceDefaults(fullData, fullLayout) {\n var traceIn, traceOut;\n\n function coerce(attr) {\n return Lib.coerce(traceOut._input, traceOut, attributes, attr);\n }\n\n if(fullLayout.funnelmode === 'group') {\n for(var i = 0; i < fullData.length; i++) {\n traceOut = fullData[i];\n traceIn = traceOut._input;\n\n handleGroupingDefaults(traceIn, traceOut, fullLayout, coerce);\n }\n }\n}\n\nmodule.exports = {\n supplyDefaults: supplyDefaults,\n crossTraceDefaults: crossTraceDefaults\n};\n","'use strict';\n\nmodule.exports = function eventData(out, pt /* , trace, cd, pointNumber */) {\n // standard cartesian event data\n out.x = 'xVal' in pt ? pt.xVal : pt.x;\n out.y = 'yVal' in pt ? pt.yVal : pt.y;\n\n // for funnel\n if('percentInitial' in pt) out.percentInitial = pt.percentInitial;\n if('percentPrevious' in pt) out.percentPrevious = pt.percentPrevious;\n if('percentTotal' in pt) out.percentTotal = pt.percentTotal;\n\n if(pt.xa) out.xaxis = pt.xa;\n if(pt.ya) out.yaxis = pt.ya;\n\n return out;\n};\n","'use strict';\n\nvar opacity = require('../../components/color').opacity;\nvar hoverOnBars = require('../bar/hover').hoverOnBars;\nvar formatPercent = require('../../lib').formatPercent;\n\nmodule.exports = function hoverPoints(pointData, xval, yval, hovermode, opts) {\n var point = hoverOnBars(pointData, xval, yval, hovermode, opts);\n if(!point) return;\n\n var cd = point.cd;\n var trace = cd[0].trace;\n var isHorizontal = (trace.orientation === 'h');\n\n // the closest data point\n var index = point.index;\n var di = cd[index];\n\n var sizeLetter = isHorizontal ? 'x' : 'y';\n point[sizeLetter + 'LabelVal'] = di.s;\n\n point.percentInitial = di.begR;\n point.percentInitialLabel = formatPercent(di.begR, 1);\n\n point.percentPrevious = di.difR;\n point.percentPreviousLabel = formatPercent(di.difR, 1);\n\n point.percentTotal = di.sumR;\n point.percentTotalLabel = formatPercent(di.sumR, 1);\n\n var hoverinfo = di.hi || trace.hoverinfo;\n var text = [];\n if(hoverinfo && hoverinfo !== 'none' && hoverinfo !== 'skip') {\n var isAll = (hoverinfo === 'all');\n var parts = hoverinfo.split('+');\n\n var hasFlag = function(flag) { return isAll || parts.indexOf(flag) !== -1; };\n\n if(hasFlag('percent initial')) {\n text.push(point.percentInitialLabel + ' of initial');\n }\n if(hasFlag('percent previous')) {\n text.push(point.percentPreviousLabel + ' of previous');\n }\n if(hasFlag('percent total')) {\n text.push(point.percentTotalLabel + ' of total');\n }\n }\n point.extraText = text.join('
');\n\n point.color = getTraceColor(trace, di);\n\n return [point];\n};\n\nfunction getTraceColor(trace, di) {\n var cont = trace.marker;\n var mc = di.mc || cont.color;\n var mlc = di.mlc || cont.line.color;\n var mlw = di.mlw || cont.line.width;\n if(opacity(mc)) return mc;\n else if(opacity(mlc) && mlw) return mlc;\n}\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n layoutAttributes: require('./layout_attributes'),\n supplyDefaults: require('./defaults').supplyDefaults,\n crossTraceDefaults: require('./defaults').crossTraceDefaults,\n supplyLayoutDefaults: require('./layout_defaults'),\n calc: require('./calc'),\n crossTraceCalc: require('./cross_trace_calc'),\n plot: require('./plot'),\n style: require('./style').style,\n hoverPoints: require('./hover'),\n eventData: require('./event_data'),\n\n selectPoints: require('../bar/select'),\n\n moduleType: 'trace',\n name: 'funnel',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['bar-like', 'cartesian', 'svg', 'oriented', 'showLegend', 'zoomScale'],\n meta: {\n description: [\n 'Visualize stages in a process using length-encoded bars. This trace can be used',\n 'to show data in either a part-to-whole representation wherein each item appears',\n 'in a single stage, or in a \"drop-off\" representation wherein each item appears in',\n 'each stage it traversed. See also the \"funnelarea\" trace type for a different',\n 'approach to visualizing funnel data.'\n ].join(' ')\n }\n};\n","'use strict';\n\nmodule.exports = {\n funnelmode: {\n valType: 'enumerated',\n values: ['stack', 'group', 'overlay'],\n dflt: 'stack',\n editType: 'calc',\n description: [\n 'Determines how bars at the same location coordinate',\n 'are displayed on the graph.',\n 'With *stack*, the bars are stacked on top of one another',\n 'With *group*, the bars are plotted next to one another',\n 'centered around the shared location.',\n 'With *overlay*, the bars are plotted over one another,',\n 'you might need to reduce *opacity* to see multiple bars.'\n ].join(' ')\n },\n funnelgap: {\n valType: 'number',\n min: 0,\n max: 1,\n editType: 'calc',\n description: [\n 'Sets the gap (in plot fraction) between bars of',\n 'adjacent location coordinates.'\n ].join(' ')\n },\n funnelgroupgap: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0,\n editType: 'calc',\n description: [\n 'Sets the gap (in plot fraction) between bars of',\n 'the same location coordinate.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar layoutAttributes = require('./layout_attributes');\n\nmodule.exports = function(layoutIn, layoutOut, fullData) {\n var hasTraceType = false;\n\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n\n for(var i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n\n if(trace.visible && trace.type === 'funnel') {\n hasTraceType = true;\n break;\n }\n }\n\n if(hasTraceType) {\n coerce('funnelmode');\n coerce('funnelgap', 0.2);\n coerce('funnelgroupgap');\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\nvar Drawing = require('../../components/drawing');\nvar BADNUM = require('../../constants/numerical').BADNUM;\nvar barPlot = require('../bar/plot');\nvar clearMinTextSize = require('../bar/uniform_text').clearMinTextSize;\n\nmodule.exports = function plot(gd, plotinfo, cdModule, traceLayer) {\n var fullLayout = gd._fullLayout;\n\n clearMinTextSize('funnel', fullLayout);\n\n plotConnectorRegions(gd, plotinfo, cdModule, traceLayer);\n plotConnectorLines(gd, plotinfo, cdModule, traceLayer);\n\n barPlot.plot(gd, plotinfo, cdModule, traceLayer, {\n mode: fullLayout.funnelmode,\n norm: fullLayout.funnelmode,\n gap: fullLayout.funnelgap,\n groupgap: fullLayout.funnelgroupgap\n });\n};\n\nfunction plotConnectorRegions(gd, plotinfo, cdModule, traceLayer) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n Lib.makeTraceGroups(traceLayer, cdModule, 'trace bars').each(function(cd) {\n var plotGroup = d3.select(this);\n var trace = cd[0].trace;\n\n var group = Lib.ensureSingle(plotGroup, 'g', 'regions');\n\n if(!trace.connector || !trace.connector.visible) {\n group.remove();\n return;\n }\n\n var isHorizontal = (trace.orientation === 'h');\n\n var connectors = group.selectAll('g.region').data(Lib.identity);\n\n connectors.enter().append('g')\n .classed('region', true);\n\n connectors.exit().remove();\n\n var len = connectors.size();\n\n connectors.each(function(di, i) {\n // don't draw lines between nulls\n if(i !== len - 1 && !di.cNext) return;\n\n var xy = getXY(di, xa, ya, isHorizontal);\n var x = xy[0];\n var y = xy[1];\n\n var shape = '';\n\n if(\n x[0] !== BADNUM && y[0] !== BADNUM &&\n x[1] !== BADNUM && y[1] !== BADNUM &&\n x[2] !== BADNUM && y[2] !== BADNUM &&\n x[3] !== BADNUM && y[3] !== BADNUM\n ) {\n if(isHorizontal) {\n shape += 'M' + x[0] + ',' + y[1] + 'L' + x[2] + ',' + y[2] + 'H' + x[3] + 'L' + x[1] + ',' + y[1] + 'Z';\n } else {\n shape += 'M' + x[1] + ',' + y[1] + 'L' + x[2] + ',' + y[3] + 'V' + y[2] + 'L' + x[1] + ',' + y[0] + 'Z';\n }\n }\n\n if(shape === '') shape = 'M0,0Z';\n\n Lib.ensureSingle(d3.select(this), 'path')\n .attr('d', shape)\n .call(Drawing.setClipUrl, plotinfo.layerClipId, gd);\n });\n });\n}\n\nfunction plotConnectorLines(gd, plotinfo, cdModule, traceLayer) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n Lib.makeTraceGroups(traceLayer, cdModule, 'trace bars').each(function(cd) {\n var plotGroup = d3.select(this);\n var trace = cd[0].trace;\n\n var group = Lib.ensureSingle(plotGroup, 'g', 'lines');\n\n if(!trace.connector || !trace.connector.visible || !trace.connector.line.width) {\n group.remove();\n return;\n }\n\n var isHorizontal = (trace.orientation === 'h');\n\n var connectors = group.selectAll('g.line').data(Lib.identity);\n\n connectors.enter().append('g')\n .classed('line', true);\n\n connectors.exit().remove();\n\n var len = connectors.size();\n\n connectors.each(function(di, i) {\n // don't draw lines between nulls\n if(i !== len - 1 && !di.cNext) return;\n\n var xy = getXY(di, xa, ya, isHorizontal);\n var x = xy[0];\n var y = xy[1];\n\n var shape = '';\n\n if(x[3] !== undefined && y[3] !== undefined) {\n if(isHorizontal) {\n shape += 'M' + x[0] + ',' + y[1] + 'L' + x[2] + ',' + y[2];\n shape += 'M' + x[1] + ',' + y[1] + 'L' + x[3] + ',' + y[2];\n } else {\n shape += 'M' + x[1] + ',' + y[1] + 'L' + x[2] + ',' + y[3];\n shape += 'M' + x[1] + ',' + y[0] + 'L' + x[2] + ',' + y[2];\n }\n }\n\n if(shape === '') shape = 'M0,0Z';\n\n Lib.ensureSingle(d3.select(this), 'path')\n .attr('d', shape)\n .call(Drawing.setClipUrl, plotinfo.layerClipId, gd);\n });\n });\n}\n\nfunction getXY(di, xa, ya, isHorizontal) {\n var s = [];\n var p = [];\n\n var sAxis = isHorizontal ? xa : ya;\n var pAxis = isHorizontal ? ya : xa;\n\n s[0] = sAxis.c2p(di.s0, true);\n p[0] = pAxis.c2p(di.p0, true);\n\n s[1] = sAxis.c2p(di.s1, true);\n p[1] = pAxis.c2p(di.p1, true);\n\n s[2] = sAxis.c2p(di.nextS0, true);\n p[2] = pAxis.c2p(di.nextP0, true);\n\n s[3] = sAxis.c2p(di.nextS1, true);\n p[3] = pAxis.c2p(di.nextP1, true);\n\n return isHorizontal ? [s, p] : [p, s];\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Drawing = require('../../components/drawing');\nvar Color = require('../../components/color');\nvar DESELECTDIM = require('../../constants/interactions').DESELECTDIM;\nvar barStyle = require('../bar/style');\nvar resizeText = require('../bar/uniform_text').resizeText;\nvar styleTextPoints = barStyle.styleTextPoints;\n\nfunction style(gd, cd, sel) {\n var s = sel ? sel : d3.select(gd).selectAll('g[class^=\"funnellayer\"]').selectAll('g.trace');\n resizeText(gd, s, 'funnel');\n\n s.style('opacity', function(d) { return d[0].trace.opacity; });\n\n s.each(function(d) {\n var gTrace = d3.select(this);\n var trace = d[0].trace;\n\n gTrace.selectAll('.point > path').each(function(di) {\n if(!di.isBlank) {\n var cont = trace.marker;\n\n d3.select(this)\n .call(Color.fill, di.mc || cont.color)\n .call(Color.stroke, di.mlc || cont.line.color)\n .call(Drawing.dashLine, cont.line.dash, di.mlw || cont.line.width)\n .style('opacity', trace.selectedpoints && !di.selected ? DESELECTDIM : 1);\n }\n });\n\n styleTextPoints(gTrace, trace, gd);\n\n gTrace.selectAll('.regions').each(function() {\n d3.select(this).selectAll('path').style('stroke-width', 0).call(Color.fill, trace.connector.fillcolor);\n });\n\n gTrace.selectAll('.lines').each(function() {\n var cont = trace.connector.line;\n\n Drawing.lineGroupStyle(\n d3.select(this).selectAll('path'),\n cont.width,\n cont.color,\n cont.dash\n );\n });\n });\n}\n\nmodule.exports = {\n style: style\n};\n","'use strict';\n\nvar pieAttrs = require('../pie/attributes');\nvar baseAttrs = require('../../plots/attributes');\nvar domainAttrs = require('../../plots/domain').attributes;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nmodule.exports = {\n labels: pieAttrs.labels,\n // equivalent of x0 and dx, if label is missing\n label0: pieAttrs.label0,\n dlabel: pieAttrs.dlabel,\n values: pieAttrs.values,\n\n marker: {\n colors: pieAttrs.marker.colors,\n line: {\n color: extendFlat({}, pieAttrs.marker.line.color, {\n dflt: null,\n description: [\n 'Sets the color of the line enclosing each sector.',\n 'Defaults to the `paper_bgcolor` value.'\n ].join(' ')\n }),\n width: extendFlat({}, pieAttrs.marker.line.width, {dflt: 1}),\n editType: 'calc'\n },\n pattern: pieAttrs.marker.pattern,\n editType: 'calc'\n },\n\n text: pieAttrs.text,\n hovertext: pieAttrs.hovertext,\n\n scalegroup: extendFlat({}, pieAttrs.scalegroup, {\n description: [\n 'If there are multiple funnelareas that should be sized according to',\n 'their totals, link them by providing a non-empty group id here',\n 'shared by every trace in the same group.'\n ].join(' ')\n }),\n\n textinfo: extendFlat({}, pieAttrs.textinfo, {\n flags: ['label', 'text', 'value', 'percent']\n }),\n\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: ['label', 'color', 'value', 'text', 'percent']\n }),\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['label', 'text', 'value', 'percent', 'name']\n }),\n\n hovertemplate: hovertemplateAttrs({}, {\n keys: ['label', 'color', 'value', 'text', 'percent']\n }),\n\n textposition: extendFlat({}, pieAttrs.textposition, {\n values: ['inside', 'none'],\n dflt: 'inside'\n }),\n\n textfont: pieAttrs.textfont,\n insidetextfont: pieAttrs.insidetextfont,\n\n title: {\n text: pieAttrs.title.text,\n font: pieAttrs.title.font,\n position: extendFlat({}, pieAttrs.title.position, {\n values: ['top left', 'top center', 'top right'],\n dflt: 'top center'\n }),\n editType: 'plot'\n },\n\n domain: domainAttrs({name: 'funnelarea', trace: true, editType: 'calc'}),\n\n aspectratio: {\n valType: 'number',\n min: 0,\n dflt: 1,\n editType: 'plot',\n description: [\n 'Sets the ratio between height and width'\n ].join(' ')\n },\n\n baseratio: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0.333,\n editType: 'plot',\n description: [\n 'Sets the ratio between bottom length and maximum top length.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar plots = require('../../plots/plots');\n\nexports.name = 'funnelarea';\n\nexports.plot = function(gd, traces, transitionOpts, makeOnCompleteCallback) {\n plots.plotBasePlot(exports.name, gd, traces, transitionOpts, makeOnCompleteCallback);\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n plots.cleanBasePlot(exports.name, newFullData, newFullLayout, oldFullData, oldFullLayout);\n};\n","'use strict';\n\nvar pieCalc = require('../pie/calc');\n\nfunction calc(gd, trace) {\n return pieCalc.calc(gd, trace);\n}\n\nfunction crossTraceCalc(gd) {\n pieCalc.crossTraceCalc(gd, { type: 'funnelarea' });\n}\n\nmodule.exports = {\n calc: calc,\n crossTraceCalc: crossTraceCalc\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar attributes = require('./attributes');\nvar handleDomainDefaults = require('../../plots/domain').defaults;\nvar handleText = require('../bar/defaults').handleText;\nvar handleLabelsAndValues = require('../pie/defaults').handleLabelsAndValues;\nvar handleMarkerDefaults = require('../pie/defaults').handleMarkerDefaults;\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var labels = coerce('labels');\n var values = coerce('values');\n\n var res = handleLabelsAndValues(labels, values);\n var len = res.len;\n traceOut._hasLabels = res.hasLabels;\n traceOut._hasValues = res.hasValues;\n\n if(!traceOut._hasLabels &&\n traceOut._hasValues\n ) {\n coerce('label0');\n coerce('dlabel');\n }\n\n if(!len) {\n traceOut.visible = false;\n return;\n }\n traceOut._length = len;\n\n handleMarkerDefaults(traceIn, traceOut, layout, coerce);\n\n coerce('scalegroup');\n\n var textData = coerce('text');\n var textTemplate = coerce('texttemplate');\n var textInfo;\n if(!textTemplate) textInfo = coerce('textinfo', Array.isArray(textData) ? 'text+percent' : 'percent');\n\n coerce('hovertext');\n coerce('hovertemplate');\n\n if(textTemplate || (textInfo && textInfo !== 'none')) {\n var textposition = coerce('textposition');\n handleText(traceIn, traceOut, layout, coerce, textposition, {\n moduleHasSelected: false,\n moduleHasUnselected: false,\n moduleHasConstrain: false,\n moduleHasCliponaxis: false,\n moduleHasTextangle: false,\n moduleHasInsideanchor: false\n });\n } else if(textInfo === 'none') {\n coerce('textposition', 'none');\n }\n\n handleDomainDefaults(traceOut, layout, coerce);\n\n var title = coerce('title.text');\n if(title) {\n coerce('title.position');\n Lib.coerceFont(coerce, 'title.font', layout.font);\n }\n\n coerce('aspectratio');\n coerce('baseratio');\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'funnelarea',\n basePlotModule: require('./base_plot'),\n categories: ['pie-like', 'funnelarea', 'showLegend'],\n\n attributes: require('./attributes'),\n layoutAttributes: require('./layout_attributes'),\n supplyDefaults: require('./defaults'),\n supplyLayoutDefaults: require('./layout_defaults'),\n\n calc: require('./calc').calc,\n crossTraceCalc: require('./calc').crossTraceCalc,\n\n plot: require('./plot'),\n style: require('./style'),\n styleOne: require('../pie/style_one'),\n\n meta: {\n description: [\n 'Visualize stages in a process using area-encoded trapezoids. This trace can be used',\n 'to show data in a part-to-whole representation similar to a \"pie\" trace, wherein',\n 'each item appears in a single stage. See also the \"funnel\" trace type for a different',\n 'approach to visualizing funnel data.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar hiddenlabels = require('../pie/layout_attributes').hiddenlabels;\n\nmodule.exports = {\n hiddenlabels: hiddenlabels,\n\n funnelareacolorway: {\n valType: 'colorlist',\n editType: 'calc',\n description: [\n 'Sets the default funnelarea slice colors. Defaults to the main',\n '`colorway` used for trace colors. If you specify a new',\n 'list here it can still be extended with lighter and darker',\n 'colors, see `extendfunnelareacolors`.'\n ].join(' ')\n },\n extendfunnelareacolors: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'If `true`, the funnelarea slice colors (whether given by `funnelareacolorway` or',\n 'inherited from `colorway`) will be extended to three times its',\n 'original length by first repeating every color 20% lighter then',\n 'each color 20% darker. This is intended to reduce the likelihood',\n 'of reusing the same color when you have many slices, but you can',\n 'set `false` to disable.',\n 'Colors provided in the trace, using `marker.colors`, are never',\n 'extended.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar layoutAttributes = require('./layout_attributes');\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n\n coerce('hiddenlabels');\n coerce('funnelareacolorway', layoutOut.colorway);\n coerce('extendfunnelareacolors');\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Drawing = require('../../components/drawing');\nvar Lib = require('../../lib');\nvar strScale = Lib.strScale;\nvar strTranslate = Lib.strTranslate;\nvar svgTextUtils = require('../../lib/svg_text_utils');\n\nvar barPlot = require('../bar/plot');\nvar toMoveInsideBar = barPlot.toMoveInsideBar;\nvar uniformText = require('../bar/uniform_text');\nvar recordMinTextSize = uniformText.recordMinTextSize;\nvar clearMinTextSize = uniformText.clearMinTextSize;\nvar pieHelpers = require('../pie/helpers');\nvar piePlot = require('../pie/plot');\n\nvar attachFxHandlers = piePlot.attachFxHandlers;\nvar determineInsideTextFont = piePlot.determineInsideTextFont;\n\nvar layoutAreas = piePlot.layoutAreas;\nvar prerenderTitles = piePlot.prerenderTitles;\nvar positionTitleOutside = piePlot.positionTitleOutside;\nvar formatSliceLabel = piePlot.formatSliceLabel;\n\nmodule.exports = function plot(gd, cdModule) {\n var isStatic = gd._context.staticPlot;\n\n var fullLayout = gd._fullLayout;\n\n clearMinTextSize('funnelarea', fullLayout);\n\n prerenderTitles(cdModule, gd);\n layoutAreas(cdModule, fullLayout._size);\n\n Lib.makeTraceGroups(fullLayout._funnelarealayer, cdModule, 'trace').each(function(cd) {\n var plotGroup = d3.select(this);\n var cd0 = cd[0];\n var trace = cd0.trace;\n\n setCoords(cd);\n\n plotGroup.each(function() {\n var slices = d3.select(this).selectAll('g.slice').data(cd);\n\n slices.enter().append('g')\n .classed('slice', true);\n slices.exit().remove();\n\n slices.each(function(pt, i) {\n if(pt.hidden) {\n d3.select(this).selectAll('path,g').remove();\n return;\n }\n\n // to have consistent event data compared to other traces\n pt.pointNumber = pt.i;\n pt.curveNumber = trace.index;\n\n var cx = cd0.cx;\n var cy = cd0.cy;\n var sliceTop = d3.select(this);\n var slicePath = sliceTop.selectAll('path.surface').data([pt]);\n\n slicePath.enter().append('path')\n .classed('surface', true)\n .style({'pointer-events': isStatic ? 'none' : 'all'});\n\n sliceTop.call(attachFxHandlers, gd, cd);\n\n var shape =\n 'M' + (cx + pt.TR[0]) + ',' + (cy + pt.TR[1]) +\n line(pt.TR, pt.BR) +\n line(pt.BR, pt.BL) +\n line(pt.BL, pt.TL) +\n 'Z';\n\n slicePath.attr('d', shape);\n\n // add text\n formatSliceLabel(gd, pt, cd0);\n var textPosition = pieHelpers.castOption(trace.textposition, pt.pts);\n var sliceTextGroup = sliceTop.selectAll('g.slicetext')\n .data(pt.text && (textPosition !== 'none') ? [0] : []);\n\n sliceTextGroup.enter().append('g')\n .classed('slicetext', true);\n sliceTextGroup.exit().remove();\n\n sliceTextGroup.each(function() {\n var sliceText = Lib.ensureSingle(d3.select(this), 'text', '', function(s) {\n // prohibit tex interpretation until we can handle\n // tex and regular text together\n s.attr('data-notex', 1);\n });\n\n var font = Lib.ensureUniformFontSize(gd, determineInsideTextFont(trace, pt, fullLayout.font));\n\n sliceText.text(pt.text)\n .attr({\n class: 'slicetext',\n transform: '',\n 'text-anchor': 'middle'\n })\n .call(Drawing.font, font)\n .call(svgTextUtils.convertToTspans, gd);\n\n // position the text relative to the slice\n var textBB = Drawing.bBox(sliceText.node());\n var transform;\n\n var x0, x1;\n var y0 = Math.min(pt.BL[1], pt.BR[1]) + cy;\n var y1 = Math.max(pt.TL[1], pt.TR[1]) + cy;\n\n x0 = Math.max(pt.TL[0], pt.BL[0]) + cx;\n x1 = Math.min(pt.TR[0], pt.BR[0]) + cx;\n\n transform = toMoveInsideBar(x0, x1, y0, y1, textBB, {\n isHorizontal: true,\n constrained: true,\n angle: 0,\n anchor: 'middle'\n });\n\n transform.fontSize = font.size;\n recordMinTextSize(trace.type, transform, fullLayout);\n cd[i].transform = transform;\n\n Lib.setTransormAndDisplay(sliceText, transform);\n });\n });\n\n // add the title\n var titleTextGroup = d3.select(this).selectAll('g.titletext')\n .data(trace.title.text ? [0] : []);\n\n titleTextGroup.enter().append('g')\n .classed('titletext', true);\n titleTextGroup.exit().remove();\n\n titleTextGroup.each(function() {\n var titleText = Lib.ensureSingle(d3.select(this), 'text', '', function(s) {\n // prohibit tex interpretation as above\n s.attr('data-notex', 1);\n });\n\n var txt = trace.title.text;\n if(trace._meta) {\n txt = Lib.templateString(txt, trace._meta);\n }\n\n titleText.text(txt)\n .attr({\n class: 'titletext',\n transform: '',\n 'text-anchor': 'middle',\n })\n .call(Drawing.font, trace.title.font)\n .call(svgTextUtils.convertToTspans, gd);\n\n var transform = positionTitleOutside(cd0, fullLayout._size);\n\n titleText.attr('transform',\n strTranslate(transform.x, transform.y) +\n strScale(Math.min(1, transform.scale)) +\n strTranslate(transform.tx, transform.ty));\n });\n });\n });\n};\n\nfunction line(a, b) {\n var dx = b[0] - a[0];\n var dy = b[1] - a[1];\n\n return 'l' + dx + ',' + dy;\n}\n\nfunction getBetween(a, b) {\n return [\n 0.5 * (a[0] + b[0]),\n 0.5 * (a[1] + b[1])\n ];\n}\n\nfunction setCoords(cd) {\n if(!cd.length) return;\n\n var cd0 = cd[0];\n var trace = cd0.trace;\n\n var aspectratio = trace.aspectratio;\n\n var h = trace.baseratio;\n if(h > 0.999) h = 0.999; // TODO: may handle this case separately\n var h2 = Math.pow(h, 2);\n\n var v1 = cd0.vTotal;\n var v0 = v1 * h2 / (1 - h2);\n\n var totalValues = v1;\n var sumSteps = v0 / v1;\n\n function calcPos() {\n var q = Math.sqrt(sumSteps);\n return {\n x: q,\n y: -q\n };\n }\n\n function getPoint() {\n var pos = calcPos();\n return [pos.x, pos.y];\n }\n\n var p;\n var allPoints = [];\n allPoints.push(getPoint());\n\n var i, cdi;\n for(i = cd.length - 1; i > -1; i--) {\n cdi = cd[i];\n if(cdi.hidden) continue;\n\n var step = cdi.v / totalValues;\n sumSteps += step;\n\n allPoints.push(getPoint());\n }\n\n var minY = Infinity;\n var maxY = -Infinity;\n for(i = 0; i < allPoints.length; i++) {\n p = allPoints[i];\n minY = Math.min(minY, p[1]);\n maxY = Math.max(maxY, p[1]);\n }\n\n // center the shape\n for(i = 0; i < allPoints.length; i++) {\n allPoints[i][1] -= (maxY + minY) / 2;\n }\n\n var lastX = allPoints[allPoints.length - 1][0];\n\n // get pie r\n var r = cd0.r;\n\n var rY = (maxY - minY) / 2;\n var scaleX = r / lastX;\n var scaleY = r / rY * aspectratio;\n\n // set funnelarea r\n cd0.r = scaleY * rY;\n\n // scale the shape\n for(i = 0; i < allPoints.length; i++) {\n allPoints[i][0] *= scaleX;\n allPoints[i][1] *= scaleY;\n }\n\n // record first position\n p = allPoints[0];\n var prevLeft = [-p[0], p[1]];\n var prevRight = [p[0], p[1]];\n\n var n = 0; // note we skip the very first point.\n for(i = cd.length - 1; i > -1; i--) {\n cdi = cd[i];\n if(cdi.hidden) continue;\n\n n += 1;\n var x = allPoints[n][0];\n var y = allPoints[n][1];\n\n cdi.TL = [-x, y];\n cdi.TR = [x, y];\n\n cdi.BL = prevLeft;\n cdi.BR = prevRight;\n\n cdi.pxmid = getBetween(cdi.TR, cdi.BR);\n\n prevLeft = cdi.TL;\n prevRight = cdi.TR;\n }\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar styleOne = require('../pie/style_one');\nvar resizeText = require('../bar/uniform_text').resizeText;\n\nmodule.exports = function style(gd) {\n var s = gd._fullLayout._funnelarealayer.selectAll('.trace');\n resizeText(gd, s, 'funnelarea');\n\n s.each(function(cd) {\n var cd0 = cd[0];\n var trace = cd0.trace;\n var traceSelection = d3.select(this);\n\n traceSelection.style({opacity: trace.opacity});\n\n traceSelection.selectAll('path.surface').each(function(pt) {\n d3.select(this).call(styleOne, pt, trace, gd);\n });\n });\n};\n","'use strict';\n\nvar scatterAttrs = require('../scatter/attributes');\nvar baseAttrs = require('../../plots/attributes');\nvar fontAttrs = require('../../plots/font_attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nmodule.exports = extendFlat({\n z: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the z data.'\n },\n x: extendFlat({}, scatterAttrs.x, {impliedEdits: {xtype: 'array'}}),\n x0: extendFlat({}, scatterAttrs.x0, {impliedEdits: {xtype: 'scaled'}}),\n dx: extendFlat({}, scatterAttrs.dx, {impliedEdits: {xtype: 'scaled'}}),\n y: extendFlat({}, scatterAttrs.y, {impliedEdits: {ytype: 'array'}}),\n y0: extendFlat({}, scatterAttrs.y0, {impliedEdits: {ytype: 'scaled'}}),\n dy: extendFlat({}, scatterAttrs.dy, {impliedEdits: {ytype: 'scaled'}}),\n\n xperiod: extendFlat({}, scatterAttrs.xperiod, {impliedEdits: {xtype: 'scaled'}}),\n yperiod: extendFlat({}, scatterAttrs.yperiod, {impliedEdits: {ytype: 'scaled'}}),\n xperiod0: extendFlat({}, scatterAttrs.xperiod0, {impliedEdits: {xtype: 'scaled'}}),\n yperiod0: extendFlat({}, scatterAttrs.yperiod0, {impliedEdits: {ytype: 'scaled'}}),\n xperiodalignment: extendFlat({}, scatterAttrs.xperiodalignment, {impliedEdits: {xtype: 'scaled'}}),\n yperiodalignment: extendFlat({}, scatterAttrs.yperiodalignment, {impliedEdits: {ytype: 'scaled'}}),\n\n text: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the text elements associated with each z value.'\n },\n hovertext: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Same as `text`.'\n },\n transpose: {\n valType: 'boolean',\n dflt: false,\n editType: 'calc',\n description: 'Transposes the z data.'\n },\n xtype: {\n valType: 'enumerated',\n values: ['array', 'scaled'],\n editType: 'calc+clearAxisTypes',\n description: [\n 'If *array*, the heatmap\\'s x coordinates are given by *x*',\n '(the default behavior when `x` is provided).',\n 'If *scaled*, the heatmap\\'s x coordinates are given by *x0* and *dx*',\n '(the default behavior when `x` is not provided).'\n ].join(' ')\n },\n ytype: {\n valType: 'enumerated',\n values: ['array', 'scaled'],\n editType: 'calc+clearAxisTypes',\n description: [\n 'If *array*, the heatmap\\'s y coordinates are given by *y*',\n '(the default behavior when `y` is provided)',\n 'If *scaled*, the heatmap\\'s y coordinates are given by *y0* and *dy*',\n '(the default behavior when `y` is not provided)'\n ].join(' ')\n },\n zsmooth: {\n valType: 'enumerated',\n values: ['fast', 'best', false],\n dflt: false,\n editType: 'calc',\n description: [\n 'Picks a smoothing algorithm use to smooth `z` data.'\n ].join(' ')\n },\n hoverongaps: {\n valType: 'boolean',\n dflt: true,\n editType: 'none',\n description: [\n 'Determines whether or not gaps',\n '(i.e. {nan} or missing values)',\n 'in the `z` data have hover labels associated with them.'\n ].join(' ')\n },\n connectgaps: {\n valType: 'boolean',\n editType: 'calc',\n description: [\n 'Determines whether or not gaps',\n '(i.e. {nan} or missing values)',\n 'in the `z` data are filled in.',\n 'It is defaulted to true if `z` is a',\n 'one dimensional array and `zsmooth` is not false;',\n 'otherwise it is defaulted to false.'\n ].join(' ')\n },\n xgap: {\n valType: 'number',\n dflt: 0,\n min: 0,\n editType: 'plot',\n description: 'Sets the horizontal gap (in pixels) between bricks.'\n },\n ygap: {\n valType: 'number',\n dflt: 0,\n min: 0,\n editType: 'plot',\n description: 'Sets the vertical gap (in pixels) between bricks.'\n },\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n zhoverformat: axisHoverFormat('z', 1),\n\n hovertemplate: hovertemplateAttrs(),\n texttemplate: texttemplateAttrs({\n arrayOk: false,\n editType: 'plot'\n }, {\n keys: ['x', 'y', 'z', 'text']\n }),\n textfont: fontAttrs({\n editType: 'plot',\n autoSize: true,\n autoColor: true,\n colorEditType: 'style',\n description: 'Sets the text font.'\n }),\n\n showlegend: extendFlat({}, baseAttrs.showlegend, {dflt: false}),\n zorder: scatterAttrs.zorder\n}, {\n transforms: undefined\n},\n colorScaleAttrs('', {cLetter: 'z', autoColorDflt: false})\n);\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar alignPeriod = require('../../plots/cartesian/align_period');\n\nvar histogram2dCalc = require('../histogram2d/calc');\nvar colorscaleCalc = require('../../components/colorscale/calc');\nvar convertColumnData = require('./convert_column_xyz');\nvar clean2dArray = require('./clean_2d_array');\nvar interp2d = require('./interp2d');\nvar findEmpties = require('./find_empties');\nvar makeBoundArray = require('./make_bound_array');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nmodule.exports = function calc(gd, trace) {\n // prepare the raw data\n // run makeCalcdata on x and y even for heatmaps, in case of category mappings\n var xa = Axes.getFromId(gd, trace.xaxis || 'x');\n var ya = Axes.getFromId(gd, trace.yaxis || 'y');\n var isContour = Registry.traceIs(trace, 'contour');\n var isHist = Registry.traceIs(trace, 'histogram');\n var isGL2D = Registry.traceIs(trace, 'gl2d');\n var zsmooth = isContour ? 'best' : trace.zsmooth;\n var x, x0, dx, origX;\n var y, y0, dy, origY;\n var z, i, binned;\n\n // cancel minimum tick spacings (only applies to bars and boxes)\n xa._minDtick = 0;\n ya._minDtick = 0;\n\n if(isHist) {\n binned = histogram2dCalc(gd, trace);\n origX = binned.orig_x;\n x = binned.x;\n x0 = binned.x0;\n dx = binned.dx;\n\n origY = binned.orig_y;\n y = binned.y;\n y0 = binned.y0;\n dy = binned.dy;\n\n z = binned.z;\n } else {\n var zIn = trace.z;\n if(Lib.isArray1D(zIn)) {\n convertColumnData(trace, xa, ya, 'x', 'y', ['z']);\n x = trace._x;\n y = trace._y;\n zIn = trace._z;\n } else {\n origX = trace.x ? xa.makeCalcdata(trace, 'x') : [];\n origY = trace.y ? ya.makeCalcdata(trace, 'y') : [];\n x = alignPeriod(trace, xa, 'x', origX).vals;\n y = alignPeriod(trace, ya, 'y', origY).vals;\n trace._x = x;\n trace._y = y;\n }\n\n x0 = trace.x0;\n dx = trace.dx;\n y0 = trace.y0;\n dy = trace.dy;\n\n z = clean2dArray(zIn, trace, xa, ya);\n }\n\n if(xa.rangebreaks || ya.rangebreaks) {\n z = dropZonBreaks(x, y, z);\n\n if(!isHist) {\n x = skipBreaks(x);\n y = skipBreaks(y);\n\n trace._x = x;\n trace._y = y;\n }\n }\n\n if(!isHist && (isContour || trace.connectgaps)) {\n trace._emptypoints = findEmpties(z);\n interp2d(z, trace._emptypoints);\n }\n\n function noZsmooth(msg) {\n zsmooth = trace._input.zsmooth = trace.zsmooth = false;\n Lib.warn('cannot use zsmooth: \"fast\": ' + msg);\n }\n\n function scaleIsLinear(s) {\n if(s.length > 1) {\n var avgdx = (s[s.length - 1] - s[0]) / (s.length - 1);\n var maxErrX = Math.abs(avgdx / 100);\n for(i = 0; i < s.length - 1; i++) {\n if(Math.abs(s[i + 1] - s[i] - avgdx) > maxErrX) {\n return false;\n }\n }\n }\n return true;\n }\n\n // Check whether all brick are uniform\n trace._islinear = false;\n if(xa.type === 'log' || ya.type === 'log') {\n if(zsmooth === 'fast') {\n noZsmooth('log axis found');\n }\n } else if(!scaleIsLinear(x)) {\n if(zsmooth === 'fast') noZsmooth('x scale is not linear');\n } else if(!scaleIsLinear(y)) {\n if(zsmooth === 'fast') noZsmooth('y scale is not linear');\n } else {\n trace._islinear = true;\n }\n\n // create arrays of brick boundaries, to be used by autorange and heatmap.plot\n var xlen = Lib.maxRowLength(z);\n var xIn = trace.xtype === 'scaled' ? '' : x;\n var xArray = makeBoundArray(trace, xIn, x0, dx, xlen, xa);\n var yIn = trace.ytype === 'scaled' ? '' : y;\n var yArray = makeBoundArray(trace, yIn, y0, dy, z.length, ya);\n\n // handled in gl2d convert step\n if(!isGL2D) {\n trace._extremes[xa._id] = Axes.findExtremes(xa, xArray);\n trace._extremes[ya._id] = Axes.findExtremes(ya, yArray);\n }\n\n var cd0 = {\n x: xArray,\n y: yArray,\n z: z,\n text: trace._text || trace.text,\n hovertext: trace._hovertext || trace.hovertext\n };\n\n if(trace.xperiodalignment && origX) {\n cd0.orig_x = origX;\n }\n if(trace.yperiodalignment && origY) {\n cd0.orig_y = origY;\n }\n\n if(xIn && xIn.length === xArray.length - 1) cd0.xCenter = xIn;\n if(yIn && yIn.length === yArray.length - 1) cd0.yCenter = yIn;\n\n if(isHist) {\n cd0.xRanges = binned.xRanges;\n cd0.yRanges = binned.yRanges;\n cd0.pts = binned.pts;\n }\n\n if(!isContour) {\n colorscaleCalc(gd, trace, {vals: z, cLetter: 'z'});\n }\n\n if(isContour && trace.contours && trace.contours.coloring === 'heatmap') {\n var dummyTrace = {\n type: trace.type === 'contour' ? 'heatmap' : 'histogram2d',\n xcalendar: trace.xcalendar,\n ycalendar: trace.ycalendar\n };\n cd0.xfill = makeBoundArray(dummyTrace, xIn, x0, dx, xlen, xa);\n cd0.yfill = makeBoundArray(dummyTrace, yIn, y0, dy, z.length, ya);\n }\n\n return [cd0];\n};\n\nfunction skipBreaks(a) {\n var b = [];\n var len = a.length;\n for(var i = 0; i < len; i++) {\n var v = a[i];\n if(v !== BADNUM) b.push(v);\n }\n return b;\n}\n\nfunction dropZonBreaks(x, y, z) {\n var newZ = [];\n var k = -1;\n for(var i = 0; i < z.length; i++) {\n if(y[i] === BADNUM) continue;\n k++;\n newZ[k] = [];\n for(var j = 0; j < z[i].length; j++) {\n if(x[j] === BADNUM) continue;\n\n newZ[k].push(z[i][j]);\n }\n }\n return newZ;\n}\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar Lib = require('../../lib');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nmodule.exports = function clean2dArray(zOld, trace, xa, ya) {\n var rowlen, collen, getCollen, old2new, i, j;\n\n function cleanZvalue(v) {\n if(!isNumeric(v)) return undefined;\n return +v;\n }\n\n if(trace && trace.transpose) {\n rowlen = 0;\n for(i = 0; i < zOld.length; i++) rowlen = Math.max(rowlen, zOld[i].length);\n if(rowlen === 0) return false;\n getCollen = function(zOld) { return zOld.length; };\n old2new = function(zOld, i, j) { return (zOld[j] || [])[i]; };\n } else {\n rowlen = zOld.length;\n getCollen = function(zOld, i) { return zOld[i].length; };\n old2new = function(zOld, i, j) { return (zOld[i] || [])[j]; };\n }\n\n var padOld2new = function(zOld, i, j) {\n if(i === BADNUM || j === BADNUM) return BADNUM;\n return old2new(zOld, i, j);\n };\n\n function axisMapping(ax) {\n if(trace && trace.type !== 'carpet' && trace.type !== 'contourcarpet' &&\n ax && ax.type === 'category' && trace['_' + ax._id.charAt(0)].length) {\n var axLetter = ax._id.charAt(0);\n var axMapping = {};\n var traceCategories = trace['_' + axLetter + 'CategoryMap'] || trace[axLetter];\n for(i = 0; i < traceCategories.length; i++) {\n axMapping[traceCategories[i]] = i;\n }\n return function(i) {\n var ind = axMapping[ax._categories[i]];\n return ind + 1 ? ind : BADNUM;\n };\n } else {\n return Lib.identity;\n }\n }\n\n var xMap = axisMapping(xa);\n var yMap = axisMapping(ya);\n\n if(ya && ya.type === 'category') rowlen = ya._categories.length;\n var zNew = new Array(rowlen);\n\n for(i = 0; i < rowlen; i++) {\n if(xa && xa.type === 'category') {\n collen = xa._categories.length;\n } else {\n collen = getCollen(zOld, i);\n }\n zNew[i] = new Array(collen);\n for(j = 0; j < collen; j++) zNew[i][j] = cleanZvalue(padOld2new(zOld, yMap(i), xMap(j)));\n }\n\n return zNew;\n};\n","'use strict';\n\nmodule.exports = {\n min: 'zmin',\n max: 'zmax'\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar BADNUM = require('../../constants/numerical').BADNUM;\nvar alignPeriod = require('../../plots/cartesian/align_period');\n\nmodule.exports = function convertColumnData(trace, ax1, ax2, var1Name, var2Name, arrayVarNames) {\n var colLen = trace._length;\n var col1 = ax1.makeCalcdata(trace, var1Name);\n var col2 = ax2.makeCalcdata(trace, var2Name);\n col1 = alignPeriod(trace, ax1, var1Name, col1).vals;\n col2 = alignPeriod(trace, ax2, var2Name, col2).vals;\n\n var textCol = trace.text;\n var hasColumnText = (textCol !== undefined && Lib.isArray1D(textCol));\n var hoverTextCol = trace.hovertext;\n var hasColumnHoverText = (hoverTextCol !== undefined && Lib.isArray1D(hoverTextCol));\n var i, j;\n\n var col1dv = Lib.distinctVals(col1);\n var col1vals = col1dv.vals;\n var col2dv = Lib.distinctVals(col2);\n var col2vals = col2dv.vals;\n var newArrays = [];\n var text;\n var hovertext;\n\n var nI = col2vals.length;\n var nJ = col1vals.length;\n\n for(i = 0; i < arrayVarNames.length; i++) {\n newArrays[i] = Lib.init2dArray(nI, nJ);\n }\n\n if(hasColumnText) {\n text = Lib.init2dArray(nI, nJ);\n }\n if(hasColumnHoverText) {\n hovertext = Lib.init2dArray(nI, nJ);\n }\n\n var after2before = Lib.init2dArray(nI, nJ);\n\n for(i = 0; i < colLen; i++) {\n if(col1[i] !== BADNUM && col2[i] !== BADNUM) {\n var i1 = Lib.findBin(col1[i] + col1dv.minDiff / 2, col1vals);\n var i2 = Lib.findBin(col2[i] + col2dv.minDiff / 2, col2vals);\n\n for(j = 0; j < arrayVarNames.length; j++) {\n var arrayVarName = arrayVarNames[j];\n var arrayVar = trace[arrayVarName];\n var newArray = newArrays[j];\n newArray[i2][i1] = arrayVar[i];\n after2before[i2][i1] = i;\n }\n\n if(hasColumnText) text[i2][i1] = textCol[i];\n if(hasColumnHoverText) hovertext[i2][i1] = hoverTextCol[i];\n }\n }\n\n trace['_' + var1Name] = col1vals;\n trace['_' + var2Name] = col2vals;\n for(j = 0; j < arrayVarNames.length; j++) {\n trace['_' + arrayVarNames[j]] = newArrays[j];\n }\n if(hasColumnText) trace._text = text;\n if(hasColumnHoverText) trace._hovertext = hovertext;\n\n if(ax1 && ax1.type === 'category') {\n trace['_' + var1Name + 'CategoryMap'] = col1vals.map(function(v) { return ax1._categories[v];});\n }\n\n if(ax2 && ax2.type === 'category') {\n trace['_' + var2Name + 'CategoryMap'] = col2vals.map(function(v) { return ax2._categories[v];});\n }\n\n trace._after2before = after2before;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar handleXYZDefaults = require('./xyz_defaults');\nvar handleHeatmapLabelDefaults = require('./label_defaults');\nvar handlePeriodDefaults = require('../scatter/period_defaults');\nvar handleStyleDefaults = require('./style_defaults');\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar attributes = require('./attributes');\n\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var validData = handleXYZDefaults(traceIn, traceOut, coerce, layout);\n if(!validData) {\n traceOut.visible = false;\n return;\n }\n\n handlePeriodDefaults(traceIn, traceOut, layout, coerce);\n coerce('xhoverformat');\n coerce('yhoverformat');\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n\n handleHeatmapLabelDefaults(coerce, layout);\n handleStyleDefaults(traceIn, traceOut, coerce, layout);\n\n coerce('hoverongaps');\n coerce('connectgaps', Lib.isArray1D(traceOut.z) && (traceOut.zsmooth !== false));\n\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'z'});\n coerce('zorder');\n};\n","'use strict';\n\nvar maxRowLength = require('../../lib').maxRowLength;\n\n/* Return a list of empty points in 2D array z\n * each empty point z[i][j] gives an array [i, j, neighborCount]\n * neighborCount is the count of 4 nearest neighbors that DO exist\n * this is to give us an order of points to evaluate for interpolation.\n * if no neighbors exist, we iteratively look for neighbors that HAVE\n * neighbors, and add a fractional neighborCount\n */\nmodule.exports = function findEmpties(z) {\n var empties = [];\n var neighborHash = {};\n var noNeighborList = [];\n var nextRow = z[0];\n var row = [];\n var blank = [0, 0, 0];\n var rowLength = maxRowLength(z);\n var prevRow;\n var i;\n var j;\n var thisPt;\n var p;\n var neighborCount;\n var newNeighborHash;\n var foundNewNeighbors;\n\n for(i = 0; i < z.length; i++) {\n prevRow = row;\n row = nextRow;\n nextRow = z[i + 1] || [];\n for(j = 0; j < rowLength; j++) {\n if(row[j] === undefined) {\n neighborCount = (row[j - 1] !== undefined ? 1 : 0) +\n (row[j + 1] !== undefined ? 1 : 0) +\n (prevRow[j] !== undefined ? 1 : 0) +\n (nextRow[j] !== undefined ? 1 : 0);\n\n if(neighborCount) {\n // for this purpose, don't count off-the-edge points\n // as undefined neighbors\n if(i === 0) neighborCount++;\n if(j === 0) neighborCount++;\n if(i === z.length - 1) neighborCount++;\n if(j === row.length - 1) neighborCount++;\n\n // if all neighbors that could exist do, we don't\n // need this for finding farther neighbors\n if(neighborCount < 4) {\n neighborHash[[i, j]] = [i, j, neighborCount];\n }\n\n empties.push([i, j, neighborCount]);\n } else noNeighborList.push([i, j]);\n }\n }\n }\n\n while(noNeighborList.length) {\n newNeighborHash = {};\n foundNewNeighbors = false;\n\n // look for cells that now have neighbors but didn't before\n for(p = noNeighborList.length - 1; p >= 0; p--) {\n thisPt = noNeighborList[p];\n i = thisPt[0];\n j = thisPt[1];\n\n neighborCount = ((neighborHash[[i - 1, j]] || blank)[2] +\n (neighborHash[[i + 1, j]] || blank)[2] +\n (neighborHash[[i, j - 1]] || blank)[2] +\n (neighborHash[[i, j + 1]] || blank)[2]) / 20;\n\n if(neighborCount) {\n newNeighborHash[thisPt] = [i, j, neighborCount];\n noNeighborList.splice(p, 1);\n foundNewNeighbors = true;\n }\n }\n\n if(!foundNewNeighbors) {\n throw 'findEmpties iterated with no new neighbors';\n }\n\n // put these new cells into the main neighbor list\n for(thisPt in newNeighborHash) {\n neighborHash[thisPt] = newNeighborHash[thisPt];\n empties.push(newNeighborHash[thisPt]);\n }\n }\n\n // sort the full list in descending order of neighbor count\n return empties.sort(function(a, b) { return b[2] - a[2]; });\n};\n","'use strict';\n\nvar Fx = require('../../components/fx');\nvar Lib = require('../../lib');\nvar isArrayOrTypedArray = Lib.isArrayOrTypedArray;\nvar Axes = require('../../plots/cartesian/axes');\nvar extractOpts = require('../../components/colorscale').extractOpts;\n\nmodule.exports = function hoverPoints(pointData, xval, yval, hovermode, opts) {\n if(!opts) opts = {};\n var isContour = opts.isContour;\n\n var cd0 = pointData.cd[0];\n var trace = cd0.trace;\n var xa = pointData.xa;\n var ya = pointData.ya;\n var x = cd0.x;\n var y = cd0.y;\n var z = cd0.z;\n var xc = cd0.xCenter;\n var yc = cd0.yCenter;\n var zmask = cd0.zmask;\n var zhoverformat = trace.zhoverformat;\n var x2 = x;\n var y2 = y;\n\n var xl, yl, nx, ny;\n\n if(pointData.index !== false) {\n try {\n nx = Math.round(pointData.index[1]);\n ny = Math.round(pointData.index[0]);\n } catch(e) {\n Lib.error('Error hovering on heatmap, ' +\n 'pointNumber must be [row,col], found:', pointData.index);\n return;\n }\n if(nx < 0 || nx >= z[0].length || ny < 0 || ny > z.length) {\n return;\n }\n } else if(Fx.inbox(xval - x[0], xval - x[x.length - 1], 0) > 0 ||\n Fx.inbox(yval - y[0], yval - y[y.length - 1], 0) > 0) {\n return;\n } else {\n if(isContour) {\n var i2;\n x2 = [2 * x[0] - x[1]];\n\n for(i2 = 1; i2 < x.length; i2++) {\n x2.push((x[i2] + x[i2 - 1]) / 2);\n }\n x2.push([2 * x[x.length - 1] - x[x.length - 2]]);\n\n y2 = [2 * y[0] - y[1]];\n for(i2 = 1; i2 < y.length; i2++) {\n y2.push((y[i2] + y[i2 - 1]) / 2);\n }\n y2.push([2 * y[y.length - 1] - y[y.length - 2]]);\n }\n nx = Math.max(0, Math.min(x2.length - 2, Lib.findBin(xval, x2)));\n ny = Math.max(0, Math.min(y2.length - 2, Lib.findBin(yval, y2)));\n }\n\n var x0 = xa.c2p(x[nx]);\n var x1 = xa.c2p(x[nx + 1]);\n var y0 = ya.c2p(y[ny]);\n var y1 = ya.c2p(y[ny + 1]);\n\n var _x, _y;\n if(isContour) {\n _x = cd0.orig_x || x;\n _y = cd0.orig_y || y;\n\n x1 = x0;\n xl = _x[nx];\n y1 = y0;\n yl = _y[ny];\n } else {\n _x = cd0.orig_x || xc || x;\n _y = cd0.orig_y || yc || y;\n\n xl = xc ? _x[nx] : ((_x[nx] + _x[nx + 1]) / 2);\n yl = yc ? _y[ny] : ((_y[ny] + _y[ny + 1]) / 2);\n\n if(xa && xa.type === 'category') xl = x[nx];\n if(ya && ya.type === 'category') yl = y[ny];\n\n if(trace.zsmooth) {\n x0 = x1 = xa.c2p(xl);\n y0 = y1 = ya.c2p(yl);\n }\n }\n\n var zVal = z[ny][nx];\n if(zmask && !zmask[ny][nx]) zVal = undefined;\n\n if(zVal === undefined && !trace.hoverongaps) return;\n\n var text;\n if(isArrayOrTypedArray(cd0.hovertext) && isArrayOrTypedArray(cd0.hovertext[ny])) {\n text = cd0.hovertext[ny][nx];\n } else if(isArrayOrTypedArray(cd0.text) && isArrayOrTypedArray(cd0.text[ny])) {\n text = cd0.text[ny][nx];\n }\n\n // dummy axis for formatting the z value\n var cOpts = extractOpts(trace);\n var dummyAx = {\n type: 'linear',\n range: [cOpts.min, cOpts.max],\n hoverformat: zhoverformat,\n _separators: xa._separators,\n _numFormat: xa._numFormat\n };\n var zLabel = Axes.tickText(dummyAx, zVal, 'hover').text;\n\n return [Lib.extendFlat(pointData, {\n index: trace._after2before ? trace._after2before[ny][nx] : [ny, nx],\n // never let a 2D override 1D type as closest point\n distance: pointData.maxHoverDistance,\n spikeDistance: pointData.maxSpikeDistance,\n x0: x0,\n x1: x1,\n y0: y0,\n y1: y1,\n xLabelVal: xl,\n yLabelVal: yl,\n zLabelVal: zVal,\n zLabel: zLabel,\n text: text\n })];\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n calc: require('./calc'),\n plot: require('./plot'),\n colorbar: require('./colorbar'),\n style: require('./style'),\n hoverPoints: require('./hover'),\n\n moduleType: 'trace',\n name: 'heatmap',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['cartesian', 'svg', '2dMap', 'showLegend'],\n meta: {\n description: [\n 'The data that describes the heatmap value-to-color mapping',\n 'is set in `z`.',\n 'Data in `z` can either be a {2D array} of values (ragged or not)',\n 'or a 1D array of values.',\n\n 'In the case where `z` is a {2D array},',\n 'say that `z` has N rows and M columns.',\n 'Then, by default, the resulting heatmap will have N partitions along',\n 'the y axis and M partitions along the x axis.',\n 'In other words, the i-th row/ j-th column cell in `z`',\n 'is mapped to the i-th partition of the y axis',\n '(starting from the bottom of the plot) and the j-th partition',\n 'of the x-axis (starting from the left of the plot).',\n 'This behavior can be flipped by using `transpose`.',\n 'Moreover, `x` (`y`) can be provided with M or M+1 (N or N+1) elements.',\n 'If M (N), then the coordinates correspond to the center of the',\n 'heatmap cells and the cells have equal width.',\n 'If M+1 (N+1), then the coordinates correspond to the edges of the',\n 'heatmap cells.',\n\n 'In the case where `z` is a 1D {array}, the x and y coordinates must be',\n 'provided in `x` and `y` respectively to form data triplets.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar INTERPTHRESHOLD = 1e-2;\nvar NEIGHBORSHIFTS = [[-1, 0], [1, 0], [0, -1], [0, 1]];\n\nfunction correctionOvershoot(maxFractionalChange) {\n // start with less overshoot, until we know it's converging,\n // then ramp up the overshoot for faster convergence\n return 0.5 - 0.25 * Math.min(1, maxFractionalChange * 0.5);\n}\n\n/*\n * interp2d: Fill in missing data from a 2D array using an iterative\n * poisson equation solver with zero-derivative BC at edges.\n * Amazingly, this just amounts to repeatedly averaging all the existing\n * nearest neighbors, at least if we don't take x/y scaling into account,\n * which is the right approach here where x and y may not even have the\n * same units.\n *\n * @param {array of arrays} z\n * The 2D array to fill in. Will be mutated here. Assumed to already be\n * cleaned, so all entries are numbers except gaps, which are `undefined`.\n * @param {array of arrays} emptyPoints\n * Each entry [i, j, neighborCount] for empty points z[i][j] and the number\n * of neighbors that are *not* missing. Assumed to be sorted from most to\n * least neighbors, as produced by heatmap/find_empties.\n */\nmodule.exports = function interp2d(z, emptyPoints) {\n var maxFractionalChange = 1;\n var i;\n\n // one pass to fill in a starting value for all the empties\n iterateInterp2d(z, emptyPoints);\n\n // we're don't need to iterate lone empties - remove them\n for(i = 0; i < emptyPoints.length; i++) {\n if(emptyPoints[i][2] < 4) break;\n }\n // but don't remove these points from the original array,\n // we'll use them for masking, so make a copy.\n emptyPoints = emptyPoints.slice(i);\n\n for(i = 0; i < 100 && maxFractionalChange > INTERPTHRESHOLD; i++) {\n maxFractionalChange = iterateInterp2d(z, emptyPoints,\n correctionOvershoot(maxFractionalChange));\n }\n if(maxFractionalChange > INTERPTHRESHOLD) {\n Lib.log('interp2d didn\\'t converge quickly', maxFractionalChange);\n }\n\n return z;\n};\n\nfunction iterateInterp2d(z, emptyPoints, overshoot) {\n var maxFractionalChange = 0;\n var thisPt;\n var i;\n var j;\n var p;\n var q;\n var neighborShift;\n var neighborRow;\n var neighborVal;\n var neighborCount;\n var neighborSum;\n var initialVal;\n var minNeighbor;\n var maxNeighbor;\n\n for(p = 0; p < emptyPoints.length; p++) {\n thisPt = emptyPoints[p];\n i = thisPt[0];\n j = thisPt[1];\n initialVal = z[i][j];\n neighborSum = 0;\n neighborCount = 0;\n\n for(q = 0; q < 4; q++) {\n neighborShift = NEIGHBORSHIFTS[q];\n neighborRow = z[i + neighborShift[0]];\n if(!neighborRow) continue;\n neighborVal = neighborRow[j + neighborShift[1]];\n if(neighborVal !== undefined) {\n if(neighborSum === 0) {\n minNeighbor = maxNeighbor = neighborVal;\n } else {\n minNeighbor = Math.min(minNeighbor, neighborVal);\n maxNeighbor = Math.max(maxNeighbor, neighborVal);\n }\n neighborCount++;\n neighborSum += neighborVal;\n }\n }\n\n if(neighborCount === 0) {\n throw 'iterateInterp2d order is wrong: no defined neighbors';\n }\n\n // this is the laplace equation interpolation:\n // each point is just the average of its neighbors\n // note that this ignores differential x/y scaling\n // which I think is the right approach, since we\n // don't know what that scaling means\n z[i][j] = neighborSum / neighborCount;\n\n if(initialVal === undefined) {\n if(neighborCount < 4) maxFractionalChange = 1;\n } else {\n // we can make large empty regions converge faster\n // if we overshoot the change vs the previous value\n z[i][j] = (1 + overshoot) * z[i][j] - overshoot * initialVal;\n\n if(maxNeighbor > minNeighbor) {\n maxFractionalChange = Math.max(maxFractionalChange,\n Math.abs(z[i][j] - initialVal) / (maxNeighbor - minNeighbor));\n }\n }\n }\n\n return maxFractionalChange;\n}\n","'use strict';\n\nvar Lib = require('../../lib');\n\nmodule.exports = function handleHeatmapLabelDefaults(coerce, layout) {\n coerce('texttemplate');\n\n var fontDflt = Lib.extendFlat({}, layout.font, {\n color: 'auto',\n size: 'auto'\n });\n Lib.coerceFont(coerce, 'textfont', fontDflt);\n};\n","'use strict';\n\nvar Registry = require('../../registry');\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\n\nmodule.exports = function makeBoundArray(trace, arrayIn, v0In, dvIn, numbricks, ax) {\n var arrayOut = [];\n var isContour = Registry.traceIs(trace, 'contour');\n var isHist = Registry.traceIs(trace, 'histogram');\n var isGL2D = Registry.traceIs(trace, 'gl2d');\n var v0;\n var dv;\n var i;\n\n var isArrayOfTwoItemsOrMore = isArrayOrTypedArray(arrayIn) && arrayIn.length > 1;\n\n if(isArrayOfTwoItemsOrMore && !isHist && (ax.type !== 'category')) {\n var len = arrayIn.length;\n\n // given vals are brick centers\n // hopefully length === numbricks, but use this method even if too few are supplied\n // and extend it linearly based on the last two points\n if(len <= numbricks) {\n // contour plots only want the centers\n if(isContour || isGL2D) arrayOut = Array.from(arrayIn).slice(0, numbricks);\n else if(numbricks === 1) {\n if(ax.type === 'log') {\n arrayOut = [0.5 * arrayIn[0], 2 * arrayIn[0]];\n } else {\n arrayOut = [arrayIn[0] - 0.5, arrayIn[0] + 0.5];\n }\n } else if(ax.type === 'log') {\n arrayOut = [Math.pow(arrayIn[0], 1.5) / Math.pow(arrayIn[1], 0.5)];\n\n for(i = 1; i < len; i++) {\n // Geomean\n arrayOut.push(Math.sqrt(arrayIn[i - 1] * arrayIn[i]));\n }\n\n arrayOut.push(Math.pow(arrayIn[len - 1], 1.5) / Math.pow(arrayIn[len - 2], 0.5));\n } else {\n arrayOut = [1.5 * arrayIn[0] - 0.5 * arrayIn[1]];\n\n for(i = 1; i < len; i++) {\n // Arithmetic mean\n arrayOut.push((arrayIn[i - 1] + arrayIn[i]) * 0.5);\n }\n\n arrayOut.push(1.5 * arrayIn[len - 1] - 0.5 * arrayIn[len - 2]);\n }\n\n if(len < numbricks) {\n var lastPt = arrayOut[arrayOut.length - 1];\n var delta; // either multiplicative delta (log axis type) or arithmetic delta (all other axis types)\n if(ax.type === 'log') {\n delta = lastPt / arrayOut[arrayOut.length - 2];\n\n for(i = len; i < numbricks; i++) {\n lastPt *= delta;\n arrayOut.push(lastPt);\n }\n } else {\n delta = lastPt - arrayOut[arrayOut.length - 2];\n\n for(i = len; i < numbricks; i++) {\n lastPt += delta;\n arrayOut.push(lastPt);\n }\n }\n }\n } else {\n // hopefully length === numbricks+1, but do something regardless:\n // given vals are brick boundaries\n return isContour ?\n arrayIn.slice(0, numbricks) : // we must be strict for contours\n arrayIn.slice(0, numbricks + 1);\n }\n } else {\n var calendar = trace[ax._id.charAt(0) + 'calendar'];\n\n if(isHist) {\n v0 = ax.r2c(v0In, 0, calendar);\n } else {\n if(isArrayOrTypedArray(arrayIn) && arrayIn.length === 1) {\n v0 = arrayIn[0];\n } else if(v0In === undefined) {\n v0 = 0;\n } else {\n var fn = ax.type === 'log' ? ax.d2c : ax.r2c;\n v0 = fn(v0In, 0, calendar);\n }\n }\n\n dv = dvIn || 1;\n\n for(i = (isContour || isGL2D) ? 0 : -0.5; i < numbricks; i++) {\n arrayOut.push(v0 + dv * i);\n }\n }\n\n return arrayOut;\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar tinycolor = require('tinycolor2');\n\nvar Registry = require('../../registry');\nvar Drawing = require('../../components/drawing');\nvar Axes = require('../../plots/cartesian/axes');\nvar Lib = require('../../lib');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar formatLabels = require('../scatter/format_labels');\nvar Color = require('../../components/color');\nvar extractOpts = require('../../components/colorscale').extractOpts;\nvar makeColorScaleFuncFromTrace = require('../../components/colorscale').makeColorScaleFuncFromTrace;\nvar xmlnsNamespaces = require('../../constants/xmlns_namespaces');\nvar alignmentConstants = require('../../constants/alignment');\nvar LINE_SPACING = alignmentConstants.LINE_SPACING;\nvar supportsPixelatedImage = require('../../lib/supports_pixelated_image');\nvar PIXELATED_IMAGE_STYLE = require('../../constants/pixelated_image').STYLE;\n\nvar labelClass = 'heatmap-label';\n\nfunction selectLabels(plotGroup) {\n return plotGroup.selectAll('g.' + labelClass);\n}\n\nfunction removeLabels(plotGroup) {\n selectLabels(plotGroup).remove();\n}\n\nmodule.exports = function(gd, plotinfo, cdheatmaps, heatmapLayer) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n Lib.makeTraceGroups(heatmapLayer, cdheatmaps, 'hm').each(function(cd) {\n var plotGroup = d3.select(this);\n var cd0 = cd[0];\n var trace = cd0.trace;\n var xGap = trace.xgap || 0;\n var yGap = trace.ygap || 0;\n\n var z = cd0.z;\n var x = cd0.x;\n var y = cd0.y;\n var xc = cd0.xCenter;\n var yc = cd0.yCenter;\n var isContour = Registry.traceIs(trace, 'contour');\n var zsmooth = isContour ? 'best' : trace.zsmooth;\n\n // get z dims\n var m = z.length;\n var n = Lib.maxRowLength(z);\n var xrev = false;\n var yrev = false;\n\n var left, right, temp, top, bottom, i, j, k;\n\n // TODO: if there are multiple overlapping categorical heatmaps,\n // or if we allow category sorting, then the categories may not be\n // sequential... may need to reorder and/or expand z\n\n // Get edges of png in pixels (xa.c2p() maps axes coordinates to pixel coordinates)\n // figure out if either axis is reversed (y is usually reversed, in pixel coords)\n // also clip the image to maximum 50% outside the visible plot area\n // bigger image lets you pan more naturally, but slows performance.\n // TODO: use low-resolution images outside the visible plot for panning\n // these while loops find the first and last brick bounds that are defined\n // (in case of log of a negative)\n i = 0;\n while(left === undefined && i < x.length - 1) {\n left = xa.c2p(x[i]);\n i++;\n }\n i = x.length - 1;\n while(right === undefined && i > 0) {\n right = xa.c2p(x[i]);\n i--;\n }\n\n if(right < left) {\n temp = right;\n right = left;\n left = temp;\n xrev = true;\n }\n\n i = 0;\n while(top === undefined && i < y.length - 1) {\n top = ya.c2p(y[i]);\n i++;\n }\n i = y.length - 1;\n while(bottom === undefined && i > 0) {\n bottom = ya.c2p(y[i]);\n i--;\n }\n\n if(bottom < top) {\n temp = top;\n top = bottom;\n bottom = temp;\n yrev = true;\n }\n\n // for contours with heatmap fill, we generate the boundaries based on\n // brick centers but then use the brick edges for drawing the bricks\n if(isContour) {\n xc = x;\n yc = y;\n x = cd0.xfill;\n y = cd0.yfill;\n }\n\n var drawingMethod = 'default';\n if(zsmooth) {\n drawingMethod = zsmooth === 'best' ? 'smooth' : 'fast';\n } else if(trace._islinear && xGap === 0 && yGap === 0 && supportsPixelatedImage()) {\n drawingMethod = 'fast';\n }\n\n // make an image that goes at most half a screen off either side, to keep\n // time reasonable when you zoom in. if drawingMethod is fast, don't worry\n // about this, because zooming doesn't increase number of pixels\n // if zsmooth is best, don't include anything off screen because it takes too long\n if(drawingMethod !== 'fast') {\n var extra = zsmooth === 'best' ? 0 : 0.5;\n left = Math.max(-extra * xa._length, left);\n right = Math.min((1 + extra) * xa._length, right);\n top = Math.max(-extra * ya._length, top);\n bottom = Math.min((1 + extra) * ya._length, bottom);\n }\n\n var imageWidth = Math.round(right - left);\n var imageHeight = Math.round(bottom - top);\n\n // setup image nodes\n\n // if image is entirely off-screen, don't even draw it\n var isOffScreen = (\n left >= xa._length || right <= 0 || top >= ya._length || bottom <= 0\n );\n\n if(isOffScreen) {\n var noImage = plotGroup.selectAll('image').data([]);\n noImage.exit().remove();\n\n removeLabels(plotGroup);\n return;\n }\n\n // generate image data\n\n var canvasW, canvasH;\n if(drawingMethod === 'fast') {\n canvasW = n;\n canvasH = m;\n } else {\n canvasW = imageWidth;\n canvasH = imageHeight;\n }\n\n var canvas = document.createElement('canvas');\n canvas.width = canvasW;\n canvas.height = canvasH;\n var context = canvas.getContext('2d', {willReadFrequently: true});\n\n var sclFunc = makeColorScaleFuncFromTrace(trace, {noNumericCheck: true, returnArray: true});\n\n // map brick boundaries to image pixels\n var xpx,\n ypx;\n if(drawingMethod === 'fast') {\n xpx = xrev ?\n function(index) { return n - 1 - index; } :\n Lib.identity;\n ypx = yrev ?\n function(index) { return m - 1 - index; } :\n Lib.identity;\n } else {\n xpx = function(index) {\n return Lib.constrain(Math.round(xa.c2p(x[index]) - left),\n 0, imageWidth);\n };\n ypx = function(index) {\n return Lib.constrain(Math.round(ya.c2p(y[index]) - top),\n 0, imageHeight);\n };\n }\n\n // build the pixel map brick-by-brick\n // cruise through z-matrix row-by-row\n // build a brick at each z-matrix value\n var yi = ypx(0);\n var yb = [yi, yi];\n var xbi = xrev ? 0 : 1;\n var ybi = yrev ? 0 : 1;\n // for collecting an average luminosity of the heatmap\n var pixcount = 0;\n var rcount = 0;\n var gcount = 0;\n var bcount = 0;\n\n var xb, xi, v, row, c;\n\n function setColor(v, pixsize) {\n if(v !== undefined) {\n var c = sclFunc(v);\n c[0] = Math.round(c[0]);\n c[1] = Math.round(c[1]);\n c[2] = Math.round(c[2]);\n\n pixcount += pixsize;\n rcount += c[0] * pixsize;\n gcount += c[1] * pixsize;\n bcount += c[2] * pixsize;\n return c;\n }\n return [0, 0, 0, 0];\n }\n\n function interpColor(r0, r1, xinterp, yinterp) {\n var z00 = r0[xinterp.bin0];\n if(z00 === undefined) return setColor(undefined, 1);\n\n var z01 = r0[xinterp.bin1];\n var z10 = r1[xinterp.bin0];\n var z11 = r1[xinterp.bin1];\n var dx = (z01 - z00) || 0;\n var dy = (z10 - z00) || 0;\n var dxy;\n\n // the bilinear interpolation term needs different calculations\n // for all the different permutations of missing data\n // among the neighbors of the main point, to ensure\n // continuity across brick boundaries.\n if(z01 === undefined) {\n if(z11 === undefined) dxy = 0;\n else if(z10 === undefined) dxy = 2 * (z11 - z00);\n else dxy = (2 * z11 - z10 - z00) * 2 / 3;\n } else if(z11 === undefined) {\n if(z10 === undefined) dxy = 0;\n else dxy = (2 * z00 - z01 - z10) * 2 / 3;\n } else if(z10 === undefined) dxy = (2 * z11 - z01 - z00) * 2 / 3;\n else dxy = (z11 + z00 - z01 - z10);\n\n return setColor(z00 + xinterp.frac * dx + yinterp.frac * (dy + xinterp.frac * dxy));\n }\n\n if(drawingMethod !== 'default') { // works fastest with imageData\n var pxIndex = 0;\n var pixels;\n\n try {\n pixels = new Uint8Array(canvasW * canvasH * 4);\n } catch(e) {\n pixels = new Array(canvasW * canvasH * 4);\n }\n\n if(drawingMethod === 'smooth') { // zsmooth=\"best\"\n var xForPx = xc || x;\n var yForPx = yc || y;\n var xPixArray = new Array(xForPx.length);\n var yPixArray = new Array(yForPx.length);\n var xinterpArray = new Array(imageWidth);\n var findInterpX = xc ? findInterpFromCenters : findInterp;\n var findInterpY = yc ? findInterpFromCenters : findInterp;\n var yinterp, r0, r1;\n\n // first make arrays of x and y pixel locations of brick boundaries\n for(i = 0; i < xForPx.length; i++) xPixArray[i] = Math.round(xa.c2p(xForPx[i]) - left);\n for(i = 0; i < yForPx.length; i++) yPixArray[i] = Math.round(ya.c2p(yForPx[i]) - top);\n\n // then make arrays of interpolations\n // (bin0=closest, bin1=next, frac=fractional dist.)\n for(i = 0; i < imageWidth; i++) xinterpArray[i] = findInterpX(i, xPixArray);\n\n // now do the interpolations and fill the png\n for(j = 0; j < imageHeight; j++) {\n yinterp = findInterpY(j, yPixArray);\n r0 = z[yinterp.bin0];\n r1 = z[yinterp.bin1];\n for(i = 0; i < imageWidth; i++, pxIndex += 4) {\n c = interpColor(r0, r1, xinterpArray[i], yinterp);\n putColor(pixels, pxIndex, c);\n }\n }\n } else { // drawingMethod = \"fast\" (zsmooth = \"fast\"|false)\n for(j = 0; j < m; j++) {\n row = z[j];\n yb = ypx(j);\n for(i = 0; i < n; i++) {\n c = setColor(row[i], 1);\n pxIndex = (yb * n + xpx(i)) * 4;\n putColor(pixels, pxIndex, c);\n }\n }\n }\n\n var imageData = context.createImageData(canvasW, canvasH);\n try {\n imageData.data.set(pixels);\n } catch(e) {\n var pxArray = imageData.data;\n var dlen = pxArray.length;\n for(j = 0; j < dlen; j ++) {\n pxArray[j] = pixels[j];\n }\n }\n\n context.putImageData(imageData, 0, 0);\n } else { // rawingMethod = \"default\" (zsmooth = false)\n // filling potentially large bricks works fastest with fillRect\n // gaps do not need to be exact integers, but if they *are* we will get\n // cleaner edges by rounding at least one edge\n var xGapLeft = Math.floor(xGap / 2);\n var yGapTop = Math.floor(yGap / 2);\n\n for(j = 0; j < m; j++) {\n row = z[j];\n yb.reverse();\n yb[ybi] = ypx(j + 1);\n if(yb[0] === yb[1] || yb[0] === undefined || yb[1] === undefined) {\n continue;\n }\n xi = xpx(0);\n xb = [xi, xi];\n for(i = 0; i < n; i++) {\n // build one color brick!\n xb.reverse();\n xb[xbi] = xpx(i + 1);\n if(xb[0] === xb[1] || xb[0] === undefined || xb[1] === undefined) {\n continue;\n }\n v = row[i];\n c = setColor(v, (xb[1] - xb[0]) * (yb[1] - yb[0]));\n context.fillStyle = 'rgba(' + c.join(',') + ')';\n\n context.fillRect(xb[0] + xGapLeft, yb[0] + yGapTop,\n xb[1] - xb[0] - xGap, yb[1] - yb[0] - yGap);\n }\n }\n }\n\n rcount = Math.round(rcount / pixcount);\n gcount = Math.round(gcount / pixcount);\n bcount = Math.round(bcount / pixcount);\n var avgColor = tinycolor('rgb(' + rcount + ',' + gcount + ',' + bcount + ')');\n\n gd._hmpixcount = (gd._hmpixcount||0) + pixcount;\n gd._hmlumcount = (gd._hmlumcount||0) + pixcount * avgColor.getLuminance();\n\n var image3 = plotGroup.selectAll('image')\n .data(cd);\n\n image3.enter().append('svg:image').attr({\n xmlns: xmlnsNamespaces.svg,\n preserveAspectRatio: 'none'\n });\n\n image3.attr({\n height: imageHeight,\n width: imageWidth,\n x: left,\n y: top,\n 'xlink:href': canvas.toDataURL('image/png')\n });\n\n if(drawingMethod === 'fast' && !zsmooth) {\n image3.attr('style', PIXELATED_IMAGE_STYLE);\n }\n\n removeLabels(plotGroup);\n\n var texttemplate = trace.texttemplate;\n if(texttemplate) {\n // dummy axis for formatting the z value\n var cOpts = extractOpts(trace);\n var dummyAx = {\n type: 'linear',\n range: [cOpts.min, cOpts.max],\n _separators: xa._separators,\n _numFormat: xa._numFormat\n };\n\n var aHistogram2dContour = trace.type === 'histogram2dcontour';\n var aContour = trace.type === 'contour';\n var iStart = aContour ? 1 : 0;\n var iStop = aContour ? m - 1 : m;\n var jStart = aContour ? 1 : 0;\n var jStop = aContour ? n - 1 : n;\n\n var textData = [];\n for(i = iStart; i < iStop; i++) {\n var yVal;\n if(aContour) {\n yVal = cd0.y[i];\n } else if(aHistogram2dContour) {\n if(i === 0 || i === m - 1) continue;\n yVal = cd0.y[i];\n } else if(cd0.yCenter) {\n yVal = cd0.yCenter[i];\n } else {\n if(i + 1 === m && cd0.y[i + 1] === undefined) continue;\n yVal = (cd0.y[i] + cd0.y[i + 1]) / 2;\n }\n\n var _y = Math.round(ya.c2p(yVal));\n if(0 > _y || _y > ya._length) continue;\n\n for(j = jStart; j < jStop; j++) {\n var xVal;\n if(aContour) {\n xVal = cd0.x[j];\n } else if(aHistogram2dContour) {\n if(j === 0 || j === n - 1) continue;\n xVal = cd0.x[j];\n } else if(cd0.xCenter) {\n xVal = cd0.xCenter[j];\n } else {\n if(j + 1 === n && cd0.x[j + 1] === undefined) continue;\n xVal = (cd0.x[j] + cd0.x[j + 1]) / 2;\n }\n\n var _x = Math.round(xa.c2p(xVal));\n if(0 > _x || _x > xa._length) continue;\n\n var obj = formatLabels({\n x: xVal,\n y: yVal\n }, trace, gd._fullLayout);\n\n obj.x = xVal;\n obj.y = yVal;\n\n var zVal = cd0.z[i][j];\n if(zVal === undefined) {\n obj.z = '';\n obj.zLabel = '';\n } else {\n obj.z = zVal;\n obj.zLabel = Axes.tickText(dummyAx, zVal, 'hover').text;\n }\n\n var theText = cd0.text && cd0.text[i] && cd0.text[i][j];\n if(theText === undefined || theText === false) theText = '';\n obj.text = theText;\n\n var _t = Lib.texttemplateString(texttemplate, obj, gd._fullLayout._d3locale, obj, trace._meta || {});\n if(!_t) continue;\n\n var lines = _t.split('
');\n var nL = lines.length;\n var nC = 0;\n for(k = 0; k < nL; k++) {\n nC = Math.max(nC, lines[k].length);\n }\n\n textData.push({\n l: nL, // number of lines\n c: nC, // maximum number of chars in a line\n t: _t, // text\n x: _x,\n y: _y,\n z: zVal\n });\n }\n }\n\n var font = trace.textfont;\n var fontSize = font.size;\n var globalFontSize = gd._fullLayout.font.size;\n\n if(!fontSize || fontSize === 'auto') {\n var minW = Infinity;\n var minH = Infinity;\n var maxL = 0;\n var maxC = 0;\n\n for(k = 0; k < textData.length; k++) {\n var d = textData[k];\n maxL = Math.max(maxL, d.l);\n maxC = Math.max(maxC, d.c);\n\n if(k < textData.length - 1) {\n var nextD = textData[k + 1];\n var dx = Math.abs(nextD.x - d.x);\n var dy = Math.abs(nextD.y - d.y);\n\n if(dx) minW = Math.min(minW, dx);\n if(dy) minH = Math.min(minH, dy);\n }\n }\n\n if(\n !isFinite(minW) ||\n !isFinite(minH)\n ) {\n fontSize = globalFontSize;\n } else {\n minW -= xGap;\n minH -= yGap;\n\n minW /= maxC;\n minH /= maxL;\n\n minW /= LINE_SPACING / 2;\n minH /= LINE_SPACING;\n\n fontSize = Math.min(\n Math.floor(minW),\n Math.floor(minH),\n globalFontSize\n );\n }\n }\n if(fontSize <= 0 || !isFinite(fontSize)) return;\n\n var xFn = function(d) { return d.x; };\n var yFn = function(d) {\n return d.y - fontSize * ((d.l * LINE_SPACING) / 2 - 1);\n };\n\n var labels = selectLabels(plotGroup).data(textData);\n\n labels\n .enter()\n .append('g')\n .classed(labelClass, 1)\n .append('text')\n .attr('text-anchor', 'middle')\n .each(function(d) {\n var thisLabel = d3.select(this);\n\n var fontColor = font.color;\n if(!fontColor || fontColor === 'auto') {\n fontColor = Color.contrast(\n d.z === undefined ? gd._fullLayout.plot_bgcolor :\n 'rgba(' +\n sclFunc(d.z).join() +\n ')'\n );\n }\n\n thisLabel\n .attr('data-notex', 1)\n .call(svgTextUtils.positionText, xFn(d), yFn(d))\n .call(Drawing.font, {\n family: font.family,\n size: fontSize,\n color: fontColor,\n weight: font.weight,\n style: font.style,\n variant: font.variant,\n textcase: font.textcase,\n lineposition: font.lineposition,\n shadow: font.shadow,\n })\n .text(d.t)\n .call(svgTextUtils.convertToTspans, gd);\n });\n }\n });\n};\n\n// get interpolated bin value. Returns {bin0:closest bin, frac:fractional dist to next, bin1:next bin}\nfunction findInterp(pixel, pixArray) {\n var maxBin = pixArray.length - 2;\n var bin = Lib.constrain(Lib.findBin(pixel, pixArray), 0, maxBin);\n var pix0 = pixArray[bin];\n var pix1 = pixArray[bin + 1];\n var interp = Lib.constrain(bin + (pixel - pix0) / (pix1 - pix0) - 0.5, 0, maxBin);\n var bin0 = Math.round(interp);\n var frac = Math.abs(interp - bin0);\n\n if(!interp || interp === maxBin || !frac) {\n return {\n bin0: bin0,\n bin1: bin0,\n frac: 0\n };\n }\n return {\n bin0: bin0,\n frac: frac,\n bin1: Math.round(bin0 + frac / (interp - bin0))\n };\n}\n\nfunction findInterpFromCenters(pixel, centerPixArray) {\n var maxBin = centerPixArray.length - 1;\n var bin = Lib.constrain(Lib.findBin(pixel, centerPixArray), 0, maxBin);\n var pix0 = centerPixArray[bin];\n var pix1 = centerPixArray[bin + 1];\n var frac = ((pixel - pix0) / (pix1 - pix0)) || 0;\n if(frac <= 0) {\n return {\n bin0: bin,\n bin1: bin,\n frac: 0\n };\n }\n if(frac < 0.5) {\n return {\n bin0: bin,\n bin1: bin + 1,\n frac: frac\n };\n }\n return {\n bin0: bin + 1,\n bin1: bin,\n frac: 1 - frac\n };\n}\n\nfunction putColor(pixels, pxIndex, c) {\n pixels[pxIndex] = c[0];\n pixels[pxIndex + 1] = c[1];\n pixels[pxIndex + 2] = c[2];\n pixels[pxIndex + 3] = Math.round(c[3] * 255);\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nmodule.exports = function style(gd) {\n d3.select(gd).selectAll('.hm image')\n .style('opacity', function(d) {\n return d.trace.opacity;\n });\n};\n","'use strict';\n\nmodule.exports = function handleStyleDefaults(traceIn, traceOut, coerce) {\n var zsmooth = coerce('zsmooth');\n if(zsmooth === false) {\n // ensure that xgap and ygap are coerced only when zsmooth allows them to have an effect.\n coerce('xgap');\n coerce('ygap');\n }\n\n coerce('zhoverformat');\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar Lib = require('../../lib');\n\nvar Registry = require('../../registry');\n\nmodule.exports = function handleXYZDefaults(traceIn, traceOut, coerce, layout, xName, yName) {\n var z = coerce('z');\n xName = xName || 'x';\n yName = yName || 'y';\n var x, y;\n\n if(z === undefined || !z.length) return 0;\n\n if(Lib.isArray1D(z)) {\n x = coerce(xName);\n y = coerce(yName);\n\n var xlen = Lib.minRowLength(x);\n var ylen = Lib.minRowLength(y);\n\n // column z must be accompanied by xName and yName arrays\n if(xlen === 0 || ylen === 0) return 0;\n\n traceOut._length = Math.min(xlen, ylen, z.length);\n } else {\n x = coordDefaults(xName, coerce);\n y = coordDefaults(yName, coerce);\n\n // TODO put z validation elsewhere\n if(!isValidZ(z)) return 0;\n\n coerce('transpose');\n\n traceOut._length = null;\n }\n\n if(traceIn.type === 'heatmapgl') return true; // skip calendars until we handle them in those traces\n\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleTraceDefaults');\n handleCalendarDefaults(traceIn, traceOut, [xName, yName], layout);\n\n return true;\n};\n\nfunction coordDefaults(coordStr, coerce) {\n var coord = coerce(coordStr);\n var coordType = coord ? coerce(coordStr + 'type', 'array') : 'scaled';\n\n if(coordType === 'scaled') {\n coerce(coordStr + '0');\n coerce('d' + coordStr);\n }\n\n return coord;\n}\n\nfunction isValidZ(z) {\n var allRowsAreArrays = true;\n var oneRowIsFilled = false;\n var hasOneNumber = false;\n var zi;\n\n /*\n * Without this step:\n *\n * hasOneNumber = false breaks contour but not heatmap\n * allRowsAreArrays = false breaks contour but not heatmap\n * oneRowIsFilled = false breaks both\n */\n\n for(var i = 0; i < z.length; i++) {\n zi = z[i];\n if(!Lib.isArrayOrTypedArray(zi)) {\n allRowsAreArrays = false;\n break;\n }\n if(zi.length > 0) oneRowIsFilled = true;\n for(var j = 0; j < zi.length; j++) {\n if(isNumeric(zi[j])) {\n hasOneNumber = true;\n break;\n }\n }\n }\n\n return (allRowsAreArrays && oneRowIsFilled && hasOneNumber);\n}\n","'use strict';\n\nvar heatmapAttrs = require('../heatmap/attributes');\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\n\nvar commonList = [\n 'z',\n 'x', 'x0', 'dx',\n 'y', 'y0', 'dy',\n 'text', 'transpose',\n 'xtype', 'ytype'\n];\n\nvar attrs = {};\n\nfor(var i = 0; i < commonList.length; i++) {\n var k = commonList[i];\n attrs[k] = heatmapAttrs[k];\n}\n\nattrs.zsmooth = {\n valType: 'enumerated',\n values: ['fast', false],\n dflt: 'fast',\n editType: 'calc',\n description: 'Picks a smoothing algorithm use to smooth `z` data.'\n};\n\nextendFlat(\n attrs,\n colorScaleAttrs('', {cLetter: 'z', autoColorDflt: false})\n);\n\nmodule.exports = overrideAll(attrs, 'calc', 'nested');\n","'use strict';\n\nvar createHeatmap2D = require('../../../stackgl_modules').gl_heatmap2d;\nvar Axes = require('../../plots/cartesian/axes');\nvar str2RGBArray = require('../../lib/str2rgbarray');\n\n\nfunction Heatmap(scene, uid) {\n this.scene = scene;\n this.uid = uid;\n this.type = 'heatmapgl';\n\n this.name = '';\n this.hoverinfo = 'all';\n\n this.xData = [];\n this.yData = [];\n this.zData = [];\n this.textLabels = [];\n\n this.idToIndex = [];\n this.bounds = [0, 0, 0, 0];\n\n this.options = {\n zsmooth: 'fast',\n z: [],\n x: [],\n y: [],\n shape: [0, 0],\n colorLevels: [0],\n colorValues: [0, 0, 0, 1]\n };\n\n this.heatmap = createHeatmap2D(scene.glplot, this.options);\n this.heatmap._trace = this;\n}\n\nvar proto = Heatmap.prototype;\n\nproto.handlePick = function(pickResult) {\n var options = this.options;\n var shape = options.shape;\n var index = pickResult.pointId;\n var xIndex = index % shape[0];\n var yIndex = Math.floor(index / shape[0]);\n var zIndex = index;\n\n return {\n trace: this,\n dataCoord: pickResult.dataCoord,\n traceCoord: [\n options.x[xIndex],\n options.y[yIndex],\n options.z[zIndex]\n ],\n textLabel: this.textLabels[index],\n name: this.name,\n pointIndex: [yIndex, xIndex],\n hoverinfo: this.hoverinfo\n };\n};\n\nproto.update = function(fullTrace, calcTrace) {\n var calcPt = calcTrace[0];\n\n this.index = fullTrace.index;\n this.name = fullTrace.name;\n this.hoverinfo = fullTrace.hoverinfo;\n\n // convert z from 2D -> 1D\n var z = calcPt.z;\n this.options.z = [].concat.apply([], z);\n\n var rowLen = z[0].length;\n var colLen = z.length;\n this.options.shape = [rowLen, colLen];\n\n this.options.x = calcPt.x;\n this.options.y = calcPt.y;\n this.options.zsmooth = fullTrace.zsmooth;\n\n var colorOptions = convertColorscale(fullTrace);\n this.options.colorLevels = colorOptions.colorLevels;\n this.options.colorValues = colorOptions.colorValues;\n\n // convert text from 2D -> 1D\n this.textLabels = [].concat.apply([], fullTrace.text);\n\n this.heatmap.update(this.options);\n\n var xa = this.scene.xaxis;\n var ya = this.scene.yaxis;\n\n var xOpts, yOpts;\n if(fullTrace.zsmooth === false) {\n // increase padding for discretised heatmap as suggested by Louise Ord\n xOpts = { ppad: calcPt.x[1] - calcPt.x[0] };\n yOpts = { ppad: calcPt.y[1] - calcPt.y[0] };\n }\n\n fullTrace._extremes[xa._id] = Axes.findExtremes(xa, calcPt.x, xOpts);\n fullTrace._extremes[ya._id] = Axes.findExtremes(ya, calcPt.y, yOpts);\n};\n\nproto.dispose = function() {\n this.heatmap.dispose();\n};\n\nfunction convertColorscale(fullTrace) {\n var scl = fullTrace.colorscale;\n var zmin = fullTrace.zmin;\n var zmax = fullTrace.zmax;\n\n var N = scl.length;\n var domain = new Array(N);\n var range = new Array(4 * N);\n\n for(var i = 0; i < N; i++) {\n var si = scl[i];\n var color = str2RGBArray(si[1]);\n\n domain[i] = zmin + si[0] * (zmax - zmin);\n\n for(var j = 0; j < 4; j++) {\n range[(4 * i) + j] = color[j];\n }\n }\n\n return {\n colorLevels: domain,\n colorValues: range\n };\n}\n\nfunction createHeatmap(scene, fullTrace, calcTrace) {\n var plot = new Heatmap(scene, fullTrace.uid);\n plot.update(fullTrace, calcTrace);\n return plot;\n}\n\nmodule.exports = createHeatmap;\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar handleXYZDefaults = require('../heatmap/xyz_defaults');\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar attributes = require('./attributes');\n\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var validData = handleXYZDefaults(traceIn, traceOut, coerce, layout);\n if(!validData) {\n traceOut.visible = false;\n return;\n }\n\n coerce('text');\n coerce('zsmooth');\n\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'z'});\n};\n","'use strict';\n\nvar deprecationWarning = [\n '*heatmapgl* trace is deprecated!',\n 'Please consider switching to the *heatmap* or *image* trace types.',\n 'Alternatively you could contribute/sponsor rewriting this trace type',\n 'based on cartesian features and using regl framework.'\n].join(' ');\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../heatmap/colorbar'),\n\n calc: require('../heatmap/calc'),\n plot: require('./convert'),\n\n moduleType: 'trace',\n name: 'heatmapgl',\n basePlotModule: require('../../plots/gl2d'),\n categories: ['gl', 'gl2d', '2dMap'],\n meta: {\n description: [\n deprecationWarning,\n 'WebGL version of the heatmap trace type.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar barAttrs = require('../bar/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar fontAttrs = require('../../plots/font_attributes');\nvar makeBinAttrs = require('./bin_attributes');\nvar constants = require('./constants');\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nmodule.exports = {\n x: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the sample data to be binned on the x axis.'\n ].join(' ')\n },\n y: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the sample data to be binned on the y axis.'\n ].join(' ')\n },\n\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n\n text: extendFlat({}, barAttrs.text, {\n description: [\n 'Sets hover text elements associated with each bar.',\n 'If a single string, the same string appears over all bars.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s coordinates.'\n ].join(' ')\n }),\n hovertext: extendFlat({}, barAttrs.hovertext, {\n description: 'Same as `text`.'\n }),\n orientation: barAttrs.orientation,\n\n histfunc: {\n valType: 'enumerated',\n values: ['count', 'sum', 'avg', 'min', 'max'],\n dflt: 'count',\n editType: 'calc',\n description: [\n 'Specifies the binning function used for this histogram trace.',\n\n 'If *count*, the histogram values are computed by counting the',\n 'number of values lying inside each bin.',\n\n 'If *sum*, *avg*, *min*, *max*,',\n 'the histogram values are computed using',\n 'the sum, the average, the minimum or the maximum',\n 'of the values lying inside each bin respectively.'\n ].join(' ')\n },\n histnorm: {\n valType: 'enumerated',\n values: ['', 'percent', 'probability', 'density', 'probability density'],\n dflt: '',\n editType: 'calc',\n description: [\n 'Specifies the type of normalization used for this histogram trace.',\n\n 'If **, the span of each bar corresponds to the number of',\n 'occurrences (i.e. the number of data points lying inside the bins).',\n\n 'If *percent* / *probability*, the span of each bar corresponds to',\n 'the percentage / fraction of occurrences with respect to the total',\n 'number of sample points',\n '(here, the sum of all bin HEIGHTS equals 100% / 1).',\n\n 'If *density*, the span of each bar corresponds to the number of',\n 'occurrences in a bin divided by the size of the bin interval',\n '(here, the sum of all bin AREAS equals the',\n 'total number of sample points).',\n\n 'If *probability density*, the area of each bar corresponds to the',\n 'probability that an event will fall into the corresponding bin',\n '(here, the sum of all bin AREAS equals 1).'\n ].join(' ')\n },\n\n cumulative: {\n enabled: {\n valType: 'boolean',\n dflt: false,\n editType: 'calc',\n description: [\n 'If true, display the cumulative distribution by summing the',\n 'binned values. Use the `direction` and `centralbin` attributes',\n 'to tune the accumulation method.',\n 'Note: in this mode, the *density* `histnorm` settings behave',\n 'the same as their equivalents without *density*:',\n '** and *density* both rise to the number of data points, and',\n '*probability* and *probability density* both rise to the',\n 'number of sample points.'\n ].join(' ')\n },\n\n direction: {\n valType: 'enumerated',\n values: ['increasing', 'decreasing'],\n dflt: 'increasing',\n editType: 'calc',\n description: [\n 'Only applies if cumulative is enabled.',\n 'If *increasing* (default) we sum all prior bins, so the result',\n 'increases from left to right. If *decreasing* we sum later bins',\n 'so the result decreases from left to right.'\n ].join(' ')\n },\n\n currentbin: {\n valType: 'enumerated',\n values: ['include', 'exclude', 'half'],\n dflt: 'include',\n editType: 'calc',\n description: [\n 'Only applies if cumulative is enabled.',\n 'Sets whether the current bin is included, excluded, or has half',\n 'of its value included in the current cumulative value.',\n '*include* is the default for compatibility with various other',\n 'tools, however it introduces a half-bin bias to the results.',\n '*exclude* makes the opposite half-bin bias, and *half* removes',\n 'it.'\n ].join(' ')\n },\n editType: 'calc'\n },\n nbinsx: {\n valType: 'integer',\n min: 0,\n dflt: 0,\n editType: 'calc',\n description: [\n 'Specifies the maximum number of desired bins. This value will be used',\n 'in an algorithm that will decide the optimal bin size such that the',\n 'histogram best visualizes the distribution of the data.',\n 'Ignored if `xbins.size` is provided.'\n ].join(' ')\n },\n xbins: makeBinAttrs('x', true),\n\n nbinsy: {\n valType: 'integer',\n min: 0,\n dflt: 0,\n editType: 'calc',\n description: [\n 'Specifies the maximum number of desired bins. This value will be used',\n 'in an algorithm that will decide the optimal bin size such that the',\n 'histogram best visualizes the distribution of the data.',\n 'Ignored if `ybins.size` is provided.'\n ].join(' ')\n },\n ybins: makeBinAttrs('y', true),\n autobinx: {\n valType: 'boolean',\n dflt: null,\n editType: 'calc',\n description: [\n 'Obsolete: since v1.42 each bin attribute is auto-determined',\n 'separately and `autobinx` is not needed. However, we accept',\n '`autobinx: true` or `false` and will update `xbins` accordingly',\n 'before deleting `autobinx` from the trace.'\n ].join(' ')\n },\n autobiny: {\n valType: 'boolean',\n dflt: null,\n editType: 'calc',\n description: [\n 'Obsolete: since v1.42 each bin attribute is auto-determined',\n 'separately and `autobiny` is not needed. However, we accept',\n '`autobiny: true` or `false` and will update `ybins` accordingly',\n 'before deleting `autobiny` from the trace.'\n ].join(' ')\n },\n\n bingroup: {\n valType: 'string',\n dflt: '',\n editType: 'calc',\n description: [\n 'Set a group of histogram traces which will have compatible bin settings.',\n 'Note that traces on the same subplot and with the same *orientation*',\n 'under `barmode` *stack*, *relative* and *group* are forced into the same bingroup,',\n 'Using `bingroup`, traces under `barmode` *overlay* and on different axes',\n '(of the same axis type) can have compatible bin settings.',\n 'Note that histogram and histogram2d* trace can share the same `bingroup`'\n ].join(' ')\n },\n\n hovertemplate: hovertemplateAttrs({}, {\n keys: constants.eventDataKeys\n }),\n\n texttemplate: texttemplateAttrs({\n arrayOk: false,\n editType: 'plot'\n }, {\n keys: ['label', 'value']\n }),\n\n textposition: extendFlat({}, barAttrs.textposition, {\n arrayOk: false\n }),\n\n textfont: fontAttrs({\n arrayOk: false,\n editType: 'plot',\n colorEditType: 'style',\n description: 'Sets the text font.'\n }),\n\n outsidetextfont: fontAttrs({\n arrayOk: false,\n editType: 'plot',\n colorEditType: 'style',\n description: 'Sets the font used for `text` lying outside the bar.'\n }),\n\n insidetextfont: fontAttrs({\n arrayOk: false,\n editType: 'plot',\n colorEditType: 'style',\n description: 'Sets the font used for `text` lying inside the bar.'\n }),\n\n insidetextanchor: barAttrs.insidetextanchor,\n\n textangle: barAttrs.textangle,\n cliponaxis: barAttrs.cliponaxis,\n constraintext: barAttrs.constraintext,\n\n marker: barAttrs.marker,\n\n offsetgroup: barAttrs.offsetgroup,\n alignmentgroup: barAttrs.alignmentgroup,\n\n selected: barAttrs.selected,\n unselected: barAttrs.unselected,\n\n _deprecated: {\n bardir: barAttrs._deprecated.bardir\n },\n\n zorder: barAttrs.zorder\n};\n","'use strict';\n\n\nmodule.exports = function doAvg(size, counts) {\n var nMax = size.length;\n var total = 0;\n for(var i = 0; i < nMax; i++) {\n if(counts[i]) {\n size[i] /= counts[i];\n total += size[i];\n } else size[i] = null;\n }\n return total;\n};\n","'use strict';\n\nmodule.exports = function makeBinAttrs(axLetter, match) {\n return {\n start: {\n valType: 'any', // for date axes\n editType: 'calc',\n description: [\n 'Sets the starting value for the', axLetter,\n 'axis bins. Defaults to the minimum data value,',\n 'shifted down if necessary to make nice round values',\n 'and to remove ambiguous bin edges. For example, if most of the',\n 'data is integers we shift the bin edges 0.5 down, so a `size`',\n 'of 5 would have a default `start` of -0.5, so it is clear',\n 'that 0-4 are in the first bin, 5-9 in the second, but',\n 'continuous data gets a start of 0 and bins [0,5), [5,10) etc.',\n 'Dates behave similarly, and `start` should be a date string.',\n 'For category data, `start` is based on the category serial',\n 'numbers, and defaults to -0.5.',\n (match ? (\n 'If multiple non-overlaying histograms share a subplot, ' +\n 'the first explicit `start` is used exactly and all others ' +\n 'are shifted down (if necessary) to differ from that one ' +\n 'by an integer number of bins.'\n ) : '')\n ].join(' ')\n },\n end: {\n valType: 'any', // for date axes\n editType: 'calc',\n description: [\n 'Sets the end value for the', axLetter,\n 'axis bins. The last bin may not end exactly at this value,',\n 'we increment the bin edge by `size` from `start` until we',\n 'reach or exceed `end`. Defaults to the maximum data value.',\n 'Like `start`, for dates use a date string, and for category',\n 'data `end` is based on the category serial numbers.'\n ].join(' ')\n },\n size: {\n valType: 'any', // for date axes\n editType: 'calc',\n description: [\n 'Sets the size of each', axLetter, 'axis bin.',\n 'Default behavior: If `nbins' + axLetter + '` is 0 or omitted,',\n 'we choose a nice round bin size such that the number of bins',\n 'is about the same as the typical number of samples in each bin.',\n 'If `nbins' + axLetter + '` is provided, we choose a nice round',\n 'bin size giving no more than that many bins.',\n 'For date data, use milliseconds or *M* for months, as in',\n '`axis.dtick`. For category data, the number of categories to',\n 'bin together (always defaults to 1).',\n (match ? (\n 'If multiple non-overlaying histograms share a subplot, ' +\n 'the first explicit `size` is used and all others discarded. ' +\n 'If no `size` is provided,the sample data from all traces ' +\n 'is combined to determine `size` as described above.'\n ) : '')\n ].join(' ')\n },\n editType: 'calc'\n };\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\n\nmodule.exports = {\n count: function(n, i, size) {\n size[n]++;\n return 1;\n },\n\n sum: function(n, i, size, counterData) {\n var v = counterData[i];\n if(isNumeric(v)) {\n v = Number(v);\n size[n] += v;\n return v;\n }\n return 0;\n },\n\n avg: function(n, i, size, counterData, counts) {\n var v = counterData[i];\n if(isNumeric(v)) {\n v = Number(v);\n size[n] += v;\n counts[n]++;\n }\n return 0;\n },\n\n min: function(n, i, size, counterData) {\n var v = counterData[i];\n if(isNumeric(v)) {\n v = Number(v);\n if(!isNumeric(size[n])) {\n size[n] = v;\n return v;\n } else if(size[n] > v) {\n var delta = v - size[n];\n size[n] = v;\n return delta;\n }\n }\n return 0;\n },\n\n max: function(n, i, size, counterData) {\n var v = counterData[i];\n if(isNumeric(v)) {\n v = Number(v);\n if(!isNumeric(size[n])) {\n size[n] = v;\n return v;\n } else if(size[n] < v) {\n var delta = v - size[n];\n size[n] = v;\n return delta;\n }\n }\n return 0;\n }\n};\n","'use strict';\n\nvar numConstants = require('../../constants/numerical');\nvar oneYear = numConstants.ONEAVGYEAR;\nvar oneMonth = numConstants.ONEAVGMONTH;\nvar oneDay = numConstants.ONEDAY;\nvar oneHour = numConstants.ONEHOUR;\nvar oneMin = numConstants.ONEMIN;\nvar oneSec = numConstants.ONESEC;\nvar tickIncrement = require('../../plots/cartesian/axes').tickIncrement;\n\n\n/*\n * make a function that will find rounded bin edges\n * @param {number} leftGap: how far from the left edge of any bin is the closest data value?\n * @param {number} rightGap: how far from the right edge of any bin is the closest data value?\n * @param {Array[number]} binEdges: the actual edge values used in binning\n * @param {object} pa: the position axis\n * @param {string} calendar: the data calendar\n *\n * @return {function(v, isRightEdge)}:\n * find the start (isRightEdge is falsy) or end (truthy) label value for a bin edge `v`\n */\nmodule.exports = function getBinSpanLabelRound(leftGap, rightGap, binEdges, pa, calendar) {\n // the rounding digit is the largest digit that changes in *all* of 4 regions:\n // - inside the rightGap before binEdges[0] (shifted 10% to the left)\n // - inside the leftGap after binEdges[0] (expanded by 10% of rightGap on each end)\n // - same for binEdges[1]\n var dv0 = -1.1 * rightGap;\n var dv1 = -0.1 * rightGap;\n var dv2 = leftGap - dv1;\n var edge0 = binEdges[0];\n var edge1 = binEdges[1];\n var leftDigit = Math.min(\n biggestDigitChanged(edge0 + dv1, edge0 + dv2, pa, calendar),\n biggestDigitChanged(edge1 + dv1, edge1 + dv2, pa, calendar)\n );\n var rightDigit = Math.min(\n biggestDigitChanged(edge0 + dv0, edge0 + dv1, pa, calendar),\n biggestDigitChanged(edge1 + dv0, edge1 + dv1, pa, calendar)\n );\n\n // normally we try to make the label for the right edge different from\n // the left edge label, so it's unambiguous which bin gets data on the edge.\n // but if this results in more than 3 extra digits (or for dates, more than\n // 2 fields ie hr&min or min&sec, which is 3600x), it'll be more clutter than\n // useful so keep the label cleaner instead\n var digit, disambiguateEdges;\n if(leftDigit > rightDigit && rightDigit < Math.abs(edge1 - edge0) / 4000) {\n digit = leftDigit;\n disambiguateEdges = false;\n } else {\n digit = Math.min(leftDigit, rightDigit);\n disambiguateEdges = true;\n }\n\n if(pa.type === 'date' && digit > oneDay) {\n var dashExclude = (digit === oneYear) ? 1 : 6;\n var increment = (digit === oneYear) ? 'M12' : 'M1';\n\n return function(v, isRightEdge) {\n var dateStr = pa.c2d(v, oneYear, calendar);\n var dashPos = dateStr.indexOf('-', dashExclude);\n if(dashPos > 0) dateStr = dateStr.substr(0, dashPos);\n var roundedV = pa.d2c(dateStr, 0, calendar);\n\n if(roundedV < v) {\n var nextV = tickIncrement(roundedV, increment, false, calendar);\n if((roundedV + nextV) / 2 < v + leftGap) roundedV = nextV;\n }\n\n if(isRightEdge && disambiguateEdges) {\n return tickIncrement(roundedV, increment, true, calendar);\n }\n\n return roundedV;\n };\n }\n\n return function(v, isRightEdge) {\n var roundedV = digit * Math.round(v / digit);\n // if we rounded down and we could round up and still be < leftGap\n // (or what leftGap values round to), do that\n if(roundedV + (digit / 10) < v && roundedV + (digit * 0.9) < v + leftGap) {\n roundedV += digit;\n }\n // finally for the right edge back off one digit - but only if we can do that\n // and not clip off any data that's potentially in the bin\n if(isRightEdge && disambiguateEdges) {\n roundedV -= digit;\n }\n return roundedV;\n };\n};\n\n/*\n * Find the largest digit that changes within a (calcdata) region [v1, v2]\n * if dates, \"digit\" means date/time part when it's bigger than a second\n * returns the unit value to round to this digit, eg 0.01 to round to hundredths, or\n * 100 to round to hundreds. returns oneMonth or oneYear for month or year rounding,\n * so that Math.min will work, rather than 'M1' and 'M12'\n */\nfunction biggestDigitChanged(v1, v2, pa, calendar) {\n // are we crossing zero? can't say anything.\n // in principle this doesn't apply to dates but turns out this doesn't matter.\n if(v1 * v2 <= 0) return Infinity;\n\n var dv = Math.abs(v2 - v1);\n var isDate = pa.type === 'date';\n var digit = biggestGuaranteedDigitChanged(dv, isDate);\n // see if a larger digit also changed\n for(var i = 0; i < 10; i++) {\n // numbers: next digit needs to be >10x but <100x then gets rounded down.\n // dates: next digit can be as much as 60x (then rounded down)\n var nextDigit = biggestGuaranteedDigitChanged(digit * 80, isDate);\n // if we get to years, the chain stops\n if(digit === nextDigit) break;\n if(didDigitChange(nextDigit, v1, v2, isDate, pa, calendar)) digit = nextDigit;\n else break;\n }\n return digit;\n}\n\n/*\n * Find the largest digit that *definitely* changes in a region [v, v + dv] for any v\n * for nonuniform date regions (months/years) pick the largest\n */\nfunction biggestGuaranteedDigitChanged(dv, isDate) {\n if(isDate && dv > oneSec) {\n // this is supposed to be the biggest *guaranteed* change\n // so compare to the longest month and year across any calendar,\n // and we'll iterate back up later\n // note: does not support rounding larger than one year. We could add\n // that if anyone wants it, but seems unusual and not strictly necessary.\n if(dv > oneDay) {\n if(dv > oneYear * 1.1) return oneYear;\n if(dv > oneMonth * 1.1) return oneMonth;\n return oneDay;\n }\n\n if(dv > oneHour) return oneHour;\n if(dv > oneMin) return oneMin;\n return oneSec;\n }\n return Math.pow(10, Math.floor(Math.log(dv) / Math.LN10));\n}\n\nfunction didDigitChange(digit, v1, v2, isDate, pa, calendar) {\n if(isDate && digit > oneDay) {\n var dateParts1 = dateParts(v1, pa, calendar);\n var dateParts2 = dateParts(v2, pa, calendar);\n var parti = (digit === oneYear) ? 0 : 1;\n return dateParts1[parti] !== dateParts2[parti];\n }\n return Math.floor(v2 / digit) - Math.floor(v1 / digit) > 0.1;\n}\n\nfunction dateParts(v, pa, calendar) {\n var parts = pa.c2d(v, oneYear, calendar).split('-');\n if(parts[0] === '') {\n parts.unshift();\n parts[0] = '-' + parts[0];\n }\n return parts;\n}\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\nvar Axes = require('../../plots/cartesian/axes');\n\nvar arraysToCalcdata = require('../bar/arrays_to_calcdata');\nvar binFunctions = require('./bin_functions');\nvar normFunctions = require('./norm_functions');\nvar doAvg = require('./average');\nvar getBinSpanLabelRound = require('./bin_label_vals');\n\nfunction calc(gd, trace) {\n var pos = [];\n var size = [];\n var isHorizontal = trace.orientation === 'h';\n var pa = Axes.getFromId(gd, isHorizontal ? trace.yaxis : trace.xaxis);\n var mainData = isHorizontal ? 'y' : 'x';\n var counterData = {x: 'y', y: 'x'}[mainData];\n var calendar = trace[mainData + 'calendar'];\n var cumulativeSpec = trace.cumulative;\n var i;\n\n var binsAndPos = calcAllAutoBins(gd, trace, pa, mainData);\n var binSpec = binsAndPos[0];\n var pos0 = binsAndPos[1];\n\n var nonuniformBins = typeof binSpec.size === 'string';\n var binEdges = [];\n var bins = nonuniformBins ? binEdges : binSpec;\n // make the empty bin array\n var inc = [];\n var counts = [];\n var inputPoints = [];\n var total = 0;\n var norm = trace.histnorm;\n var func = trace.histfunc;\n var densityNorm = norm.indexOf('density') !== -1;\n var i2, binEnd, n;\n\n if(cumulativeSpec.enabled && densityNorm) {\n // we treat \"cumulative\" like it means \"integral\" if you use a density norm,\n // which in the end means it's the same as without \"density\"\n norm = norm.replace(/ ?density$/, '');\n densityNorm = false;\n }\n\n var extremeFunc = func === 'max' || func === 'min';\n var sizeInit = extremeFunc ? null : 0;\n var binFunc = binFunctions.count;\n var normFunc = normFunctions[norm];\n var isAvg = false;\n var pr2c = function(v) { return pa.r2c(v, 0, calendar); };\n var rawCounterData;\n\n if(Lib.isArrayOrTypedArray(trace[counterData]) && func !== 'count') {\n rawCounterData = trace[counterData];\n isAvg = func === 'avg';\n binFunc = binFunctions[func];\n }\n\n // create the bins (and any extra arrays needed)\n // assume more than 1e6 bins is an error, so we don't crash the browser\n i = pr2c(binSpec.start);\n\n // decrease end a little in case of rounding errors\n binEnd = pr2c(binSpec.end) + (i - Axes.tickIncrement(i, binSpec.size, false, calendar)) / 1e6;\n\n while(i < binEnd && pos.length < 1e6) {\n i2 = Axes.tickIncrement(i, binSpec.size, false, calendar);\n pos.push((i + i2) / 2);\n size.push(sizeInit);\n inputPoints.push([]);\n // nonuniform bins (like months) we need to search,\n // rather than straight calculate the bin we're in\n binEdges.push(i);\n // nonuniform bins also need nonuniform normalization factors\n if(densityNorm) inc.push(1 / (i2 - i));\n if(isAvg) counts.push(0);\n // break to avoid infinite loops\n if(i2 <= i) break;\n i = i2;\n }\n binEdges.push(i);\n\n // for date axes we need bin bounds to be calcdata. For nonuniform bins\n // we already have this, but uniform with start/end/size they're still strings.\n if(!nonuniformBins && pa.type === 'date') {\n bins = {\n start: pr2c(bins.start),\n end: pr2c(bins.end),\n size: bins.size\n };\n }\n\n // stash left and right gaps by group\n if(!gd._fullLayout._roundFnOpts) gd._fullLayout._roundFnOpts = {};\n var groupName = trace['_' + mainData + 'bingroup'];\n var roundFnOpts = {leftGap: Infinity, rightGap: Infinity};\n if(groupName) {\n if(!gd._fullLayout._roundFnOpts[groupName]) gd._fullLayout._roundFnOpts[groupName] = roundFnOpts;\n roundFnOpts = gd._fullLayout._roundFnOpts[groupName];\n }\n\n // bin the data\n // and make histogram-specific pt-number-to-cd-index map object\n var nMax = size.length;\n var uniqueValsPerBin = true;\n var leftGap = roundFnOpts.leftGap;\n var rightGap = roundFnOpts.rightGap;\n var ptNumber2cdIndex = {};\n for(i = 0; i < pos0.length; i++) {\n var posi = pos0[i];\n n = Lib.findBin(posi, bins);\n if(n >= 0 && n < nMax) {\n total += binFunc(n, i, size, rawCounterData, counts);\n if(uniqueValsPerBin && inputPoints[n].length && posi !== pos0[inputPoints[n][0]]) {\n uniqueValsPerBin = false;\n }\n inputPoints[n].push(i);\n ptNumber2cdIndex[i] = n;\n\n leftGap = Math.min(leftGap, posi - binEdges[n]);\n rightGap = Math.min(rightGap, binEdges[n + 1] - posi);\n }\n }\n roundFnOpts.leftGap = leftGap;\n roundFnOpts.rightGap = rightGap;\n\n var roundFn;\n if(!uniqueValsPerBin) {\n roundFn = function(v, isRightEdge) {\n return function() {\n var roundFnOpts = gd._fullLayout._roundFnOpts[groupName];\n return getBinSpanLabelRound(\n roundFnOpts.leftGap,\n roundFnOpts.rightGap,\n binEdges, pa, calendar\n )(v, isRightEdge);\n };\n };\n }\n\n // average and/or normalize the data, if needed\n if(isAvg) total = doAvg(size, counts);\n if(normFunc) normFunc(size, total, inc);\n\n // after all normalization etc, now we can accumulate if desired\n if(cumulativeSpec.enabled) cdf(size, cumulativeSpec.direction, cumulativeSpec.currentbin);\n\n var seriesLen = Math.min(pos.length, size.length);\n var cd = [];\n var firstNonzero = 0;\n var lastNonzero = seriesLen - 1;\n\n // look for empty bins at the ends to remove, so autoscale omits them\n for(i = 0; i < seriesLen; i++) {\n if(size[i]) {\n firstNonzero = i;\n break;\n }\n }\n for(i = seriesLen - 1; i >= firstNonzero; i--) {\n if(size[i]) {\n lastNonzero = i;\n break;\n }\n }\n\n // create the \"calculated data\" to plot\n for(i = firstNonzero; i <= lastNonzero; i++) {\n if((isNumeric(pos[i]) && isNumeric(size[i]))) {\n var cdi = {\n p: pos[i],\n s: size[i],\n b: 0\n };\n\n // setup hover and event data fields,\n // N.B. pts and \"hover\" positions ph0/ph1 don't seem to make much sense\n // for cumulative distributions\n if(!cumulativeSpec.enabled) {\n cdi.pts = inputPoints[i];\n if(uniqueValsPerBin) {\n cdi.ph0 = cdi.ph1 = (inputPoints[i].length) ? pos0[inputPoints[i][0]] : pos[i];\n } else {\n // Defer evaluation of ph(0|1) in crossTraceCalc\n trace._computePh = true;\n cdi.ph0 = roundFn(binEdges[i]);\n cdi.ph1 = roundFn(binEdges[i + 1], true);\n }\n }\n cd.push(cdi);\n }\n }\n\n if(cd.length === 1) {\n // when we collapse to a single bin, calcdata no longer describes bin size\n // so we need to explicitly specify it\n cd[0].width1 = Axes.tickIncrement(cd[0].p, binSpec.size, false, calendar) - cd[0].p;\n }\n\n arraysToCalcdata(cd, trace);\n\n if(Lib.isArrayOrTypedArray(trace.selectedpoints)) {\n Lib.tagSelected(cd, trace, ptNumber2cdIndex);\n }\n\n return cd;\n}\n\n/*\n * calcAllAutoBins: we want all histograms inside the same bingroup\n * (see logic in Histogram.crossTraceDefaults) to share bin specs\n *\n * If the user has explicitly specified differing\n * bin specs, there's nothing we can do, but if possible we will try to use the\n * smallest bins of any of the auto values for all histograms inside the same\n * bingroup.\n */\nfunction calcAllAutoBins(gd, trace, pa, mainData, _overlayEdgeCase) {\n var binAttr = mainData + 'bins';\n var fullLayout = gd._fullLayout;\n var groupName = trace['_' + mainData + 'bingroup'];\n var binOpts = fullLayout._histogramBinOpts[groupName];\n var isOverlay = fullLayout.barmode === 'overlay';\n var i, traces, tracei, calendar, pos0, autoVals, cumulativeSpec;\n\n var r2c = function(v) { return pa.r2c(v, 0, calendar); };\n var c2r = function(v) { return pa.c2r(v, 0, calendar); };\n\n var cleanBound = pa.type === 'date' ?\n function(v) { return (v || v === 0) ? Lib.cleanDate(v, null, calendar) : null; } :\n function(v) { return isNumeric(v) ? Number(v) : null; };\n\n function setBound(attr, bins, newBins) {\n if(bins[attr + 'Found']) {\n bins[attr] = cleanBound(bins[attr]);\n if(bins[attr] === null) bins[attr] = newBins[attr];\n } else {\n autoVals[attr] = bins[attr] = newBins[attr];\n Lib.nestedProperty(traces[0], binAttr + '.' + attr).set(newBins[attr]);\n }\n }\n\n // all but the first trace in this group has already been marked finished\n // clear this flag, so next time we run calc we will run autobin again\n if(trace['_' + mainData + 'autoBinFinished']) {\n delete trace['_' + mainData + 'autoBinFinished'];\n } else {\n traces = binOpts.traces;\n var allPos = [];\n\n // Note: we're including `legendonly` traces here for autobin purposes,\n // so that showing & hiding from the legend won't affect bins.\n // But this complicates things a bit since those traces don't `calc`,\n // hence `isFirstVisible`.\n var isFirstVisible = true;\n var has2dMap = false;\n var hasHist2dContour = false;\n for(i = 0; i < traces.length; i++) {\n tracei = traces[i];\n\n if(tracei.visible) {\n var mainDatai = binOpts.dirs[i];\n pos0 = tracei['_' + mainDatai + 'pos0'] = pa.makeCalcdata(tracei, mainDatai);\n\n allPos = Lib.concat(allPos, pos0);\n delete tracei['_' + mainData + 'autoBinFinished'];\n\n if(trace.visible === true) {\n if(isFirstVisible) {\n isFirstVisible = false;\n } else {\n delete tracei._autoBin;\n tracei['_' + mainData + 'autoBinFinished'] = 1;\n }\n if(Registry.traceIs(tracei, '2dMap')) {\n has2dMap = true;\n }\n if(tracei.type === 'histogram2dcontour') {\n hasHist2dContour = true;\n }\n }\n }\n }\n\n calendar = traces[0][mainData + 'calendar'];\n var newBinSpec = Axes.autoBin(allPos, pa, binOpts.nbins, has2dMap, calendar, binOpts.sizeFound && binOpts.size);\n\n var autoBin = traces[0]._autoBin = {};\n autoVals = autoBin[binOpts.dirs[0]] = {};\n\n if(hasHist2dContour) {\n // the \"true\" 2nd argument reverses the tick direction (which we can't\n // just do with a minus sign because of month bins)\n if(!binOpts.size) {\n newBinSpec.start = c2r(Axes.tickIncrement(\n r2c(newBinSpec.start), newBinSpec.size, true, calendar));\n }\n if(binOpts.end === undefined) {\n newBinSpec.end = c2r(Axes.tickIncrement(\n r2c(newBinSpec.end), newBinSpec.size, false, calendar));\n }\n }\n\n // Edge case: single-valued histogram overlaying others\n // Use them all together to calculate the bin size for the single-valued one\n // Don't re-calculate bin width if user manually specified it (checing in bingroup=='' or xbins is defined)\n if(isOverlay && !Registry.traceIs(trace, '2dMap') && newBinSpec._dataSpan === 0 &&\n pa.type !== 'category' && pa.type !== 'multicategory' &&\n trace.bingroup === '' && (typeof trace.xbins === 'undefined')) {\n // Several single-valued histograms! Stop infinite recursion,\n // just return an extra flag that tells handleSingleValueOverlays\n // to sort out this trace too\n if(_overlayEdgeCase) return [newBinSpec, pos0, true];\n\n newBinSpec = handleSingleValueOverlays(gd, trace, pa, mainData, binAttr);\n }\n\n // adjust for CDF edge cases\n cumulativeSpec = tracei.cumulative || {};\n if(cumulativeSpec.enabled && (cumulativeSpec.currentbin !== 'include')) {\n if(cumulativeSpec.direction === 'decreasing') {\n newBinSpec.start = c2r(Axes.tickIncrement(\n r2c(newBinSpec.start), newBinSpec.size, true, calendar));\n } else {\n newBinSpec.end = c2r(Axes.tickIncrement(\n r2c(newBinSpec.end), newBinSpec.size, false, calendar));\n }\n }\n\n binOpts.size = newBinSpec.size;\n if(!binOpts.sizeFound) {\n autoVals.size = newBinSpec.size;\n Lib.nestedProperty(traces[0], binAttr + '.size').set(newBinSpec.size);\n }\n\n setBound('start', binOpts, newBinSpec);\n setBound('end', binOpts, newBinSpec);\n }\n\n pos0 = trace['_' + mainData + 'pos0'];\n delete trace['_' + mainData + 'pos0'];\n\n // Each trace can specify its own start/end, or if omitted\n // we ensure they're beyond the bounds of this trace's data,\n // and we need to make sure start is aligned with the main start\n var traceInputBins = trace._input[binAttr] || {};\n var traceBinOptsCalc = Lib.extendFlat({}, binOpts);\n var mainStart = binOpts.start;\n var startIn = pa.r2l(traceInputBins.start);\n var hasStart = startIn !== undefined;\n if((binOpts.startFound || hasStart) && startIn !== pa.r2l(mainStart)) {\n // We have an explicit start to reconcile across traces\n // if this trace has an explicit start, shift it down to a bin edge\n // if another trace had an explicit start, shift it down to a\n // bin edge past our data\n var traceStart = hasStart ?\n startIn :\n Lib.aggNums(Math.min, null, pos0);\n\n var dummyAx = {\n type: (pa.type === 'category' || pa.type === 'multicategory') ? 'linear' : pa.type,\n r2l: pa.r2l,\n dtick: binOpts.size,\n tick0: mainStart,\n calendar: calendar,\n range: ([traceStart, Axes.tickIncrement(traceStart, binOpts.size, false, calendar)]).map(pa.l2r)\n };\n var newStart = Axes.tickFirst(dummyAx);\n if(newStart > pa.r2l(traceStart)) {\n newStart = Axes.tickIncrement(newStart, binOpts.size, true, calendar);\n }\n traceBinOptsCalc.start = pa.l2r(newStart);\n if(!hasStart) Lib.nestedProperty(trace, binAttr + '.start').set(traceBinOptsCalc.start);\n }\n\n var mainEnd = binOpts.end;\n var endIn = pa.r2l(traceInputBins.end);\n var hasEnd = endIn !== undefined;\n if((binOpts.endFound || hasEnd) && endIn !== pa.r2l(mainEnd)) {\n // Reconciling an explicit end is easier, as it doesn't need to\n // match bin edges\n var traceEnd = hasEnd ?\n endIn :\n Lib.aggNums(Math.max, null, pos0);\n\n traceBinOptsCalc.end = pa.l2r(traceEnd);\n if(!hasEnd) Lib.nestedProperty(trace, binAttr + '.start').set(traceBinOptsCalc.end);\n }\n\n // Backward compatibility for one-time autobinning.\n // autobin: true is handled in cleanData, but autobin: false\n // needs to be here where we have determined the values.\n var autoBinAttr = 'autobin' + mainData;\n if(trace._input[autoBinAttr] === false) {\n trace._input[binAttr] = Lib.extendFlat({}, trace[binAttr] || {});\n delete trace._input[autoBinAttr];\n delete trace[autoBinAttr];\n }\n\n return [traceBinOptsCalc, pos0];\n}\n\n/*\n * Adjust single-value histograms in overlay mode to make as good a\n * guess as we can at autobin values the user would like.\n *\n * Returns the binSpec for the trace that sparked all this\n */\nfunction handleSingleValueOverlays(gd, trace, pa, mainData, binAttr) {\n var fullLayout = gd._fullLayout;\n var overlaidTraceGroup = getConnectedHistograms(gd, trace);\n var pastThisTrace = false;\n var minSize = Infinity;\n var singleValuedTraces = [trace];\n var i, tracei, binOpts;\n\n // first collect all the:\n // - min bin size from all multi-valued traces\n // - single-valued traces\n for(i = 0; i < overlaidTraceGroup.length; i++) {\n tracei = overlaidTraceGroup[i];\n\n if(tracei === trace) {\n pastThisTrace = true;\n } else if(!pastThisTrace) {\n // This trace has already had its autobins calculated, so either:\n // - it is part of a bingroup\n // - it is NOT a single-valued trace\n binOpts = fullLayout._histogramBinOpts[tracei['_' + mainData + 'bingroup']];\n minSize = Math.min(minSize, binOpts.size || tracei[binAttr].size);\n } else {\n var resulti = calcAllAutoBins(gd, tracei, pa, mainData, true);\n var binSpeci = resulti[0];\n var isSingleValued = resulti[2];\n\n // so we can use this result when we get to tracei in the normal\n // course of events, mark it as done and put _pos0 back\n tracei['_' + mainData + 'autoBinFinished'] = 1;\n tracei['_' + mainData + 'pos0'] = resulti[1];\n\n if(isSingleValued) {\n singleValuedTraces.push(tracei);\n } else {\n minSize = Math.min(minSize, binSpeci.size);\n }\n }\n }\n\n // find the real data values for each single-valued trace\n // hunt through pos0 for the first valid value\n var dataVals = new Array(singleValuedTraces.length);\n for(i = 0; i < singleValuedTraces.length; i++) {\n var pos0 = singleValuedTraces[i]['_' + mainData + 'pos0'];\n for(var j = 0; j < pos0.length; j++) {\n if(pos0[j] !== undefined) {\n dataVals[i] = pos0[j];\n break;\n }\n }\n }\n\n // are ALL traces are single-valued? use the min difference between\n // all of their values (which defaults to 1 if there's still only one)\n if(!isFinite(minSize)) {\n minSize = Lib.distinctVals(dataVals).minDiff;\n }\n\n // now apply the min size we found to all single-valued traces\n for(i = 0; i < singleValuedTraces.length; i++) {\n tracei = singleValuedTraces[i];\n var calendar = tracei[mainData + 'calendar'];\n\n var newBins = {\n start: pa.c2r(dataVals[i] - minSize / 2, 0, calendar),\n end: pa.c2r(dataVals[i] + minSize / 2, 0, calendar),\n size: minSize\n };\n\n tracei._input[binAttr] = tracei[binAttr] = newBins;\n\n binOpts = fullLayout._histogramBinOpts[tracei['_' + mainData + 'bingroup']];\n if(binOpts) Lib.extendFlat(binOpts, newBins);\n }\n\n return trace[binAttr];\n}\n\n/*\n * Return an array of histograms that share axes and orientation.\n *\n * Only considers histograms. In principle we could include bars in a\n * similar way to how we do manually binned histograms, though this\n * would have tons of edge cases and value judgments to make.\n */\nfunction getConnectedHistograms(gd, trace) {\n var xid = trace.xaxis;\n var yid = trace.yaxis;\n var orientation = trace.orientation;\n\n var out = [];\n var fullData = gd._fullData;\n for(var i = 0; i < fullData.length; i++) {\n var tracei = fullData[i];\n if(tracei.type === 'histogram' &&\n tracei.visible === true &&\n tracei.orientation === orientation &&\n tracei.xaxis === xid && tracei.yaxis === yid\n ) {\n out.push(tracei);\n }\n }\n\n return out;\n}\n\nfunction cdf(size, direction, currentBin) {\n var i, vi, prevSum;\n\n function firstHalfPoint(i) {\n prevSum = size[i];\n size[i] /= 2;\n }\n\n function nextHalfPoint(i) {\n vi = size[i];\n size[i] = prevSum + vi / 2;\n prevSum += vi;\n }\n\n if(currentBin === 'half') {\n if(direction === 'increasing') {\n firstHalfPoint(0);\n for(i = 1; i < size.length; i++) {\n nextHalfPoint(i);\n }\n } else {\n firstHalfPoint(size.length - 1);\n for(i = size.length - 2; i >= 0; i--) {\n nextHalfPoint(i);\n }\n }\n } else if(direction === 'increasing') {\n for(i = 1; i < size.length; i++) {\n size[i] += size[i - 1];\n }\n\n // 'exclude' is identical to 'include' just shifted one bin over\n if(currentBin === 'exclude') {\n size.unshift(0);\n size.pop();\n }\n } else {\n for(i = size.length - 2; i >= 0; i--) {\n size[i] += size[i + 1];\n }\n\n if(currentBin === 'exclude') {\n size.push(0);\n size.shift();\n }\n }\n}\n\nmodule.exports = {\n calc: calc,\n calcAllAutoBins: calcAllAutoBins\n};\n","'use strict';\n\nmodule.exports = {\n eventDataKeys: ['binNumber']\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar axisIds = require('../../plots/cartesian/axis_ids');\n\nvar traceIs = require('../../registry').traceIs;\nvar handleGroupingDefaults = require('../scatter/grouping_defaults');\nvar validateCornerradius = require('../bar/defaults').validateCornerradius;\n\nvar nestedProperty = Lib.nestedProperty;\nvar getAxisGroup = require('../../plots/cartesian/constraints').getAxisGroup;\n\nvar BINATTRS = [\n {aStr: {x: 'xbins.start', y: 'ybins.start'}, name: 'start'},\n {aStr: {x: 'xbins.end', y: 'ybins.end'}, name: 'end'},\n {aStr: {x: 'xbins.size', y: 'ybins.size'}, name: 'size'},\n {aStr: {x: 'nbinsx', y: 'nbinsy'}, name: 'nbins'}\n];\n\nvar BINDIRECTIONS = ['x', 'y'];\n\n// handle bin attrs and relink auto-determined values so fullData is complete\nmodule.exports = function crossTraceDefaults(fullData, fullLayout) {\n var allBinOpts = fullLayout._histogramBinOpts = {};\n var histTraces = [];\n var mustMatchTracesLookup = {};\n var otherTracesList = [];\n\n var traceOut, traces, groupName, binDir;\n var i, j, k;\n\n function coerce(attr, dflt) {\n return Lib.coerce(traceOut._input, traceOut, traceOut._module.attributes, attr, dflt);\n }\n\n function orientation2binDir(traceOut) {\n return traceOut.orientation === 'v' ? 'x' : 'y';\n }\n\n function getAxisType(traceOut, binDir) {\n var ax = axisIds.getFromTrace({_fullLayout: fullLayout}, traceOut, binDir);\n return ax.type;\n }\n\n function fillBinOpts(traceOut, groupName, binDir) {\n // N.B. group traces that don't have a bingroup with themselves\n var fallbackGroupName = traceOut.uid + '__' + binDir;\n if(!groupName) groupName = fallbackGroupName;\n\n var axType = getAxisType(traceOut, binDir);\n var calendar = traceOut[binDir + 'calendar'] || '';\n var binOpts = allBinOpts[groupName];\n var needsNewItem = true;\n\n if(binOpts) {\n if(axType === binOpts.axType && calendar === binOpts.calendar) {\n needsNewItem = false;\n binOpts.traces.push(traceOut);\n binOpts.dirs.push(binDir);\n } else {\n groupName = fallbackGroupName;\n\n if(axType !== binOpts.axType) {\n Lib.warn([\n 'Attempted to group the bins of trace', traceOut.index,\n 'set on a', 'type:' + axType, 'axis',\n 'with bins on', 'type:' + binOpts.axType, 'axis.'\n ].join(' '));\n }\n if(calendar !== binOpts.calendar) {\n // prohibit bingroup for traces using different calendar,\n // there's probably a way to make this work, but skip for now\n Lib.warn([\n 'Attempted to group the bins of trace', traceOut.index,\n 'set with a', calendar, 'calendar',\n 'with bins',\n (binOpts.calendar ? 'on a ' + binOpts.calendar + ' calendar' : 'w/o a set calendar')\n ].join(' '));\n }\n }\n }\n\n if(needsNewItem) {\n allBinOpts[groupName] = {\n traces: [traceOut],\n dirs: [binDir],\n axType: axType,\n calendar: traceOut[binDir + 'calendar'] || ''\n };\n }\n traceOut['_' + binDir + 'bingroup'] = groupName;\n }\n\n for(i = 0; i < fullData.length; i++) {\n traceOut = fullData[i];\n\n if(traceIs(traceOut, 'histogram')) {\n histTraces.push(traceOut);\n\n // TODO: this shouldn't be relinked as it's only used within calc\n // https://github.com/plotly/plotly.js/issues/749\n delete traceOut._xautoBinFinished;\n delete traceOut._yautoBinFinished;\n\n if(traceOut.type === 'histogram') {\n var r = coerce('marker.cornerradius', fullLayout.barcornerradius);\n if(traceOut.marker) {\n traceOut.marker.cornerradius = validateCornerradius(r);\n }\n }\n\n // N.B. need to coerce *alignmentgroup* before *bingroup*, as traces\n // in same alignmentgroup \"have to match\"\n if(!traceIs(traceOut, '2dMap')) {\n handleGroupingDefaults(traceOut._input, traceOut, fullLayout, coerce);\n }\n }\n }\n\n var alignmentOpts = fullLayout._alignmentOpts || {};\n\n // Look for traces that \"have to match\", that is:\n // - 1d histogram traces on the same subplot with same orientation under barmode:stack,\n // - 1d histogram traces on the same subplot with same orientation under barmode:group\n // - 1d histogram traces on the same position axis with the same orientation\n // and the same *alignmentgroup* (coerced under barmode:group)\n // - Once `stackgroup` gets implemented (see https://github.com/plotly/plotly.js/issues/3614),\n // traces within the same stackgroup will also \"have to match\"\n for(i = 0; i < histTraces.length; i++) {\n traceOut = histTraces[i];\n groupName = '';\n\n if(!traceIs(traceOut, '2dMap')) {\n binDir = orientation2binDir(traceOut);\n\n if(fullLayout.barmode === 'group' && traceOut.alignmentgroup) {\n var pa = traceOut[binDir + 'axis'];\n var aGroupId = getAxisGroup(fullLayout, pa) + traceOut.orientation;\n if((alignmentOpts[aGroupId] || {})[traceOut.alignmentgroup]) {\n groupName = aGroupId;\n }\n }\n\n if(!groupName && fullLayout.barmode !== 'overlay') {\n groupName = (\n getAxisGroup(fullLayout, traceOut.xaxis) +\n getAxisGroup(fullLayout, traceOut.yaxis) +\n orientation2binDir(traceOut)\n );\n }\n }\n\n if(groupName) {\n if(!mustMatchTracesLookup[groupName]) {\n mustMatchTracesLookup[groupName] = [];\n }\n mustMatchTracesLookup[groupName].push(traceOut);\n } else {\n otherTracesList.push(traceOut);\n }\n }\n\n // Setup binOpts for traces that have to match,\n // if the traces have a valid bingroup, use that\n // if not use axis+binDir groupName\n for(groupName in mustMatchTracesLookup) {\n traces = mustMatchTracesLookup[groupName];\n\n // no need to 'force' anything when a single\n // trace is detected as \"must match\"\n if(traces.length === 1) {\n otherTracesList.push(traces[0]);\n continue;\n }\n\n var binGroupFound = false;\n if(traces.length) {\n traceOut = traces[0];\n binGroupFound = coerce('bingroup');\n }\n\n groupName = binGroupFound || groupName;\n\n for(i = 0; i < traces.length; i++) {\n traceOut = traces[i];\n var bingroupIn = traceOut._input.bingroup;\n if(bingroupIn && bingroupIn !== groupName) {\n Lib.warn([\n 'Trace', traceOut.index, 'must match',\n 'within bingroup', groupName + '.',\n 'Ignoring its bingroup:', bingroupIn, 'setting.'\n ].join(' '));\n }\n traceOut.bingroup = groupName;\n\n // N.B. no need to worry about 2dMap case\n // (where both bin direction are set in each trace)\n // as 2dMap trace never \"have to match\"\n fillBinOpts(traceOut, groupName, orientation2binDir(traceOut));\n }\n }\n\n // setup binOpts for traces that can but don't have to match,\n // notice that these traces can be matched with traces that have to match\n for(i = 0; i < otherTracesList.length; i++) {\n traceOut = otherTracesList[i];\n\n var binGroup = coerce('bingroup');\n\n if(traceIs(traceOut, '2dMap')) {\n for(k = 0; k < 2; k++) {\n binDir = BINDIRECTIONS[k];\n var binGroupInDir = coerce(binDir + 'bingroup',\n binGroup ? binGroup + '__' + binDir : null\n );\n fillBinOpts(traceOut, binGroupInDir, binDir);\n }\n } else {\n fillBinOpts(traceOut, binGroup, orientation2binDir(traceOut));\n }\n }\n\n // coerce bin attrs!\n for(groupName in allBinOpts) {\n var binOpts = allBinOpts[groupName];\n traces = binOpts.traces;\n\n for(j = 0; j < BINATTRS.length; j++) {\n var attrSpec = BINATTRS[j];\n var attr = attrSpec.name;\n var aStr;\n var autoVals;\n\n // nbins(x|y) is moot if we have a size. This depends on\n // nbins coming after size in binAttrs.\n if(attr === 'nbins' && binOpts.sizeFound) continue;\n\n for(i = 0; i < traces.length; i++) {\n traceOut = traces[i];\n binDir = binOpts.dirs[i];\n aStr = attrSpec.aStr[binDir];\n\n if(nestedProperty(traceOut._input, aStr).get() !== undefined) {\n binOpts[attr] = coerce(aStr);\n binOpts[attr + 'Found'] = true;\n break;\n }\n\n autoVals = (traceOut._autoBin || {})[binDir] || {};\n if(autoVals[attr]) {\n // if this is the *first* autoval\n nestedProperty(traceOut, aStr).set(autoVals[attr]);\n }\n }\n\n // start and end we need to coerce anyway, after having collected the\n // first of each into binOpts, in case a trace wants to restrict its\n // data to a certain range\n if(attr === 'start' || attr === 'end') {\n for(; i < traces.length; i++) {\n traceOut = traces[i];\n if(traceOut['_' + binDir + 'bingroup']) {\n autoVals = (traceOut._autoBin || {})[binDir] || {};\n coerce(aStr, autoVals[attr]);\n }\n }\n }\n\n if(attr === 'nbins' && !binOpts.sizeFound && !binOpts.nbinsFound) {\n traceOut = traces[0];\n binOpts[attr] = coerce(aStr);\n }\n }\n }\n};\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Color = require('../../components/color');\n\nvar handleText = require('../bar/defaults').handleText;\nvar handleStyleDefaults = require('../bar/style_defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var x = coerce('x');\n var y = coerce('y');\n\n var cumulative = coerce('cumulative.enabled');\n if(cumulative) {\n coerce('cumulative.direction');\n coerce('cumulative.currentbin');\n }\n\n coerce('text');\n var textposition = coerce('textposition');\n handleText(traceIn, traceOut, layout, coerce, textposition, {\n moduleHasSelected: true,\n moduleHasUnselected: true,\n moduleHasConstrain: true,\n moduleHasCliponaxis: true,\n moduleHasTextangle: true,\n moduleHasInsideanchor: true\n });\n\n coerce('hovertext');\n coerce('hovertemplate');\n coerce('xhoverformat');\n coerce('yhoverformat');\n\n var orientation = coerce('orientation', (y && !x) ? 'h' : 'v');\n var sampleLetter = orientation === 'v' ? 'x' : 'y';\n var aggLetter = orientation === 'v' ? 'y' : 'x';\n\n var len = (x && y) ?\n Math.min(Lib.minRowLength(x) && Lib.minRowLength(y)) :\n Lib.minRowLength(traceOut[sampleLetter] || []);\n\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n traceOut._length = len;\n\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleTraceDefaults');\n handleCalendarDefaults(traceIn, traceOut, ['x', 'y'], layout);\n\n var hasAggregationData = traceOut[aggLetter];\n if(hasAggregationData) coerce('histfunc');\n coerce('histnorm');\n\n // Note: bin defaults are now handled in Histogram.crossTraceDefaults\n // autobin(x|y) are only included here to appease Plotly.validate\n coerce('autobin' + sampleLetter);\n\n handleStyleDefaults(traceIn, traceOut, coerce, defaultColor, layout);\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n\n var lineColor = (traceOut.marker.line || {}).color;\n\n // override defaultColor for error bars with defaultLine\n var errorBarsSupplyDefaults = Registry.getComponentMethod('errorbars', 'supplyDefaults');\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || Color.defaultLine, {axis: 'y'});\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || Color.defaultLine, {axis: 'x', inherit: 'y'});\n\n coerce('zorder');\n};\n","'use strict';\n\nmodule.exports = function eventData(out, pt, trace, cd, pointNumber) {\n // standard cartesian event data\n out.x = 'xVal' in pt ? pt.xVal : pt.x;\n out.y = 'yVal' in pt ? pt.yVal : pt.y;\n\n // for 2d histograms\n if('zLabelVal' in pt) out.z = pt.zLabelVal;\n\n if(pt.xa) out.xaxis = pt.xa;\n if(pt.ya) out.yaxis = pt.ya;\n\n // specific to histogram - CDFs do not have pts (yet?)\n if(!(trace.cumulative || {}).enabled) {\n var pts = Array.isArray(pointNumber) ?\n cd[0].pts[pointNumber[0]][pointNumber[1]] :\n cd[pointNumber].pts;\n\n out.pointNumbers = pts;\n out.binNumber = out.pointNumber;\n delete out.pointNumber;\n delete out.pointIndex;\n\n var pointIndices;\n if(trace._indexToPoints) {\n pointIndices = [];\n for(var i = 0; i < pts.length; i++) {\n pointIndices = pointIndices.concat(trace._indexToPoints[pts[i]]);\n }\n } else {\n pointIndices = pts;\n }\n\n out.pointIndices = pointIndices;\n }\n\n return out;\n};\n","'use strict';\n\nvar barHover = require('../bar/hover').hoverPoints;\nvar hoverLabelText = require('../../plots/cartesian/axes').hoverLabelText;\n\nmodule.exports = function hoverPoints(pointData, xval, yval, hovermode, opts) {\n var pts = barHover(pointData, xval, yval, hovermode, opts);\n\n if(!pts) return;\n\n pointData = pts[0];\n var di = pointData.cd[pointData.index];\n var trace = pointData.cd[0].trace;\n\n if(!trace.cumulative.enabled) {\n var posLetter = trace.orientation === 'h' ? 'y' : 'x';\n\n pointData[posLetter + 'Label'] = hoverLabelText(pointData[posLetter + 'a'], [di.ph0, di.ph1], trace[posLetter + 'hoverformat']);\n }\n\n return pts;\n};\n","'use strict';\n\n/**\n * Histogram has its own attribute, defaults and calc steps,\n * but uses bar's plot to display\n * and bar's crossTraceCalc (formerly known as setPositions) for stacking and grouping\n */\n\n/**\n * histogram errorBarsOK is debatable, but it's put in for backward compat.\n * there are use cases for it - sqrt for a simple histogram works right now,\n * constant and % work but they're not so meaningful. I guess it could be cool\n * to allow quadrature combination of errors in summed histograms...\n */\n\nmodule.exports = {\n attributes: require('./attributes'),\n layoutAttributes: require('../bar/layout_attributes'),\n supplyDefaults: require('./defaults'),\n crossTraceDefaults: require('./cross_trace_defaults'),\n supplyLayoutDefaults: require('../bar/layout_defaults'),\n calc: require('./calc').calc,\n crossTraceCalc: require('../bar/cross_trace_calc').crossTraceCalc,\n plot: require('../bar/plot').plot,\n layerName: 'barlayer',\n style: require('../bar/style').style,\n styleOnSelect: require('../bar/style').styleOnSelect,\n colorbar: require('../scatter/marker_colorbar'),\n hoverPoints: require('./hover'),\n selectPoints: require('../bar/select'),\n eventData: require('./event_data'),\n\n moduleType: 'trace',\n name: 'histogram',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['bar-like', 'cartesian', 'svg', 'bar', 'histogram', 'oriented', 'errorBarsOK', 'showLegend'],\n meta: {\n description: [\n 'The sample data from which statistics are computed is set in `x`',\n 'for vertically spanning histograms and',\n 'in `y` for horizontally spanning histograms.',\n 'Binning options are set `xbins` and `ybins` respectively',\n 'if no aggregation data is provided.'\n ].join(' ')\n }\n};\n","'use strict';\n\n\nmodule.exports = {\n percent: function(size, total) {\n var nMax = size.length;\n var norm = 100 / total;\n for(var n = 0; n < nMax; n++) size[n] *= norm;\n },\n probability: function(size, total) {\n var nMax = size.length;\n for(var n = 0; n < nMax; n++) size[n] /= total;\n },\n density: function(size, total, inc, yinc) {\n var nMax = size.length;\n yinc = yinc || 1;\n for(var n = 0; n < nMax; n++) size[n] *= inc[n] * yinc;\n },\n 'probability density': function(size, total, inc, yinc) {\n var nMax = size.length;\n if(yinc) total /= yinc;\n for(var n = 0; n < nMax; n++) size[n] *= inc[n] / total;\n }\n};\n","'use strict';\n\nvar histogramAttrs = require('../histogram/attributes');\nvar makeBinAttrs = require('../histogram/bin_attributes');\nvar heatmapAttrs = require('../heatmap/attributes');\nvar baseAttrs = require('../../plots/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nmodule.exports = extendFlat(\n {\n x: histogramAttrs.x,\n y: histogramAttrs.y,\n\n z: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the aggregation data.'\n },\n marker: {\n color: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the aggregation data.'\n },\n editType: 'calc'\n },\n\n histnorm: histogramAttrs.histnorm,\n histfunc: histogramAttrs.histfunc,\n nbinsx: histogramAttrs.nbinsx,\n xbins: makeBinAttrs('x'),\n nbinsy: histogramAttrs.nbinsy,\n ybins: makeBinAttrs('y'),\n autobinx: histogramAttrs.autobinx,\n autobiny: histogramAttrs.autobiny,\n\n bingroup: extendFlat({}, histogramAttrs.bingroup, {\n description: [\n 'Set the `xbingroup` and `ybingroup` default prefix',\n 'For example, setting a `bingroup` of *1* on two histogram2d traces',\n 'will make them their x-bins and y-bins match separately.'\n ].join(' ')\n }),\n xbingroup: extendFlat({}, histogramAttrs.bingroup, {\n description: [\n 'Set a group of histogram traces which will have compatible x-bin settings.',\n 'Using `xbingroup`, histogram2d and histogram2dcontour traces ',\n '(on axes of the same axis type) can have compatible x-bin settings.',\n 'Note that the same `xbingroup` value can be used to set (1D) histogram `bingroup`'\n ].join(' ')\n }),\n ybingroup: extendFlat({}, histogramAttrs.bingroup, {\n description: [\n 'Set a group of histogram traces which will have compatible y-bin settings.',\n 'Using `ybingroup`, histogram2d and histogram2dcontour traces ',\n '(on axes of the same axis type) can have compatible y-bin settings.',\n 'Note that the same `ybingroup` value can be used to set (1D) histogram `bingroup`'\n ].join(' ')\n }),\n\n xgap: heatmapAttrs.xgap,\n ygap: heatmapAttrs.ygap,\n zsmooth: heatmapAttrs.zsmooth,\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n zhoverformat: axisHoverFormat('z', 1),\n hovertemplate: hovertemplateAttrs({}, {keys: 'z'}),\n texttemplate: texttemplateAttrs({\n arrayOk: false,\n editType: 'plot'\n }, {\n keys: 'z'\n }),\n textfont: heatmapAttrs.textfont,\n showlegend: extendFlat({}, baseAttrs.showlegend, {dflt: false})\n },\n colorScaleAttrs('', {cLetter: 'z', autoColorDflt: false})\n);\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\n\nvar binFunctions = require('../histogram/bin_functions');\nvar normFunctions = require('../histogram/norm_functions');\nvar doAvg = require('../histogram/average');\nvar getBinSpanLabelRound = require('../histogram/bin_label_vals');\nvar calcAllAutoBins = require('../histogram/calc').calcAllAutoBins;\n\nmodule.exports = function calc(gd, trace) {\n var xa = Axes.getFromId(gd, trace.xaxis);\n var ya = Axes.getFromId(gd, trace.yaxis);\n\n var xcalendar = trace.xcalendar;\n var ycalendar = trace.ycalendar;\n var xr2c = function(v) { return xa.r2c(v, 0, xcalendar); };\n var yr2c = function(v) { return ya.r2c(v, 0, ycalendar); };\n var xc2r = function(v) { return xa.c2r(v, 0, xcalendar); };\n var yc2r = function(v) { return ya.c2r(v, 0, ycalendar); };\n\n var i, j, n, m;\n\n // calculate the bins\n var xBinsAndPos = calcAllAutoBins(gd, trace, xa, 'x');\n var xBinSpec = xBinsAndPos[0];\n var xPos0 = xBinsAndPos[1];\n var yBinsAndPos = calcAllAutoBins(gd, trace, ya, 'y');\n var yBinSpec = yBinsAndPos[0];\n var yPos0 = yBinsAndPos[1];\n\n var serieslen = trace._length;\n if(xPos0.length > serieslen) xPos0.splice(serieslen, xPos0.length - serieslen);\n if(yPos0.length > serieslen) yPos0.splice(serieslen, yPos0.length - serieslen);\n\n // make the empty bin array & scale the map\n var z = [];\n var onecol = [];\n var zerocol = [];\n var nonuniformBinsX = typeof xBinSpec.size === 'string';\n var nonuniformBinsY = typeof yBinSpec.size === 'string';\n var xEdges = [];\n var yEdges = [];\n var xbins = nonuniformBinsX ? xEdges : xBinSpec;\n var ybins = nonuniformBinsY ? yEdges : yBinSpec;\n var total = 0;\n var counts = [];\n var inputPoints = [];\n var norm = trace.histnorm;\n var func = trace.histfunc;\n var densitynorm = norm.indexOf('density') !== -1;\n var extremefunc = func === 'max' || func === 'min';\n var sizeinit = extremefunc ? null : 0;\n var binfunc = binFunctions.count;\n var normfunc = normFunctions[norm];\n var doavg = false;\n var xinc = [];\n var yinc = [];\n\n // set a binning function other than count?\n // for binning functions: check first for 'z',\n // then 'mc' in case we had a colored scatter plot\n // and want to transfer these colors to the 2D histo\n // TODO: axe this, make it the responsibility of the app changing type? or an impliedEdit?\n var rawCounterData = ('z' in trace) ?\n trace.z :\n (('marker' in trace && Array.isArray(trace.marker.color)) ?\n trace.marker.color : '');\n if(rawCounterData && func !== 'count') {\n doavg = func === 'avg';\n binfunc = binFunctions[func];\n }\n\n // decrease end a little in case of rounding errors\n var xBinSize = xBinSpec.size;\n var xBinStart = xr2c(xBinSpec.start);\n var xBinEnd = xr2c(xBinSpec.end) +\n (xBinStart - Axes.tickIncrement(xBinStart, xBinSize, false, xcalendar)) / 1e6;\n\n for(i = xBinStart; i < xBinEnd; i = Axes.tickIncrement(i, xBinSize, false, xcalendar)) {\n onecol.push(sizeinit);\n xEdges.push(i);\n if(doavg) zerocol.push(0);\n }\n xEdges.push(i);\n\n var nx = onecol.length;\n var dx = (i - xBinStart) / nx;\n var x0 = xc2r(xBinStart + dx / 2);\n\n var yBinSize = yBinSpec.size;\n var yBinStart = yr2c(yBinSpec.start);\n var yBinEnd = yr2c(yBinSpec.end) +\n (yBinStart - Axes.tickIncrement(yBinStart, yBinSize, false, ycalendar)) / 1e6;\n\n for(i = yBinStart; i < yBinEnd; i = Axes.tickIncrement(i, yBinSize, false, ycalendar)) {\n z.push(onecol.slice());\n yEdges.push(i);\n var ipCol = new Array(nx);\n for(j = 0; j < nx; j++) ipCol[j] = [];\n inputPoints.push(ipCol);\n if(doavg) counts.push(zerocol.slice());\n }\n yEdges.push(i);\n\n var ny = z.length;\n var dy = (i - yBinStart) / ny;\n var y0 = yc2r(yBinStart + dy / 2);\n\n if(densitynorm) {\n xinc = makeIncrements(onecol.length, xbins, dx, nonuniformBinsX);\n yinc = makeIncrements(z.length, ybins, dy, nonuniformBinsY);\n }\n\n // for date axes we need bin bounds to be calcdata. For nonuniform bins\n // we already have this, but uniform with start/end/size they're still strings.\n if(!nonuniformBinsX && xa.type === 'date') xbins = binsToCalc(xr2c, xbins);\n if(!nonuniformBinsY && ya.type === 'date') ybins = binsToCalc(yr2c, ybins);\n\n // put data into bins\n var uniqueValsPerX = true;\n var uniqueValsPerY = true;\n var xVals = new Array(nx);\n var yVals = new Array(ny);\n var xGapLow = Infinity;\n var xGapHigh = Infinity;\n var yGapLow = Infinity;\n var yGapHigh = Infinity;\n for(i = 0; i < serieslen; i++) {\n var xi = xPos0[i];\n var yi = yPos0[i];\n n = Lib.findBin(xi, xbins);\n m = Lib.findBin(yi, ybins);\n if(n >= 0 && n < nx && m >= 0 && m < ny) {\n total += binfunc(n, i, z[m], rawCounterData, counts[m]);\n inputPoints[m][n].push(i);\n\n if(uniqueValsPerX) {\n if(xVals[n] === undefined) xVals[n] = xi;\n else if(xVals[n] !== xi) uniqueValsPerX = false;\n }\n if(uniqueValsPerY) {\n if(yVals[m] === undefined) yVals[m] = yi;\n else if(yVals[m] !== yi) uniqueValsPerY = false;\n }\n\n xGapLow = Math.min(xGapLow, xi - xEdges[n]);\n xGapHigh = Math.min(xGapHigh, xEdges[n + 1] - xi);\n yGapLow = Math.min(yGapLow, yi - yEdges[m]);\n yGapHigh = Math.min(yGapHigh, yEdges[m + 1] - yi);\n }\n }\n // normalize, if needed\n if(doavg) {\n for(m = 0; m < ny; m++) total += doAvg(z[m], counts[m]);\n }\n if(normfunc) {\n for(m = 0; m < ny; m++) normfunc(z[m], total, xinc, yinc[m]);\n }\n\n return {\n x: xPos0,\n xRanges: getRanges(xEdges, uniqueValsPerX && xVals, xGapLow, xGapHigh, xa, xcalendar),\n x0: x0,\n dx: dx,\n y: yPos0,\n yRanges: getRanges(yEdges, uniqueValsPerY && yVals, yGapLow, yGapHigh, ya, ycalendar),\n y0: y0,\n dy: dy,\n z: z,\n pts: inputPoints\n };\n};\n\nfunction makeIncrements(len, bins, dv, nonuniform) {\n var out = new Array(len);\n var i;\n if(nonuniform) {\n for(i = 0; i < len; i++) out[i] = 1 / (bins[i + 1] - bins[i]);\n } else {\n var inc = 1 / dv;\n for(i = 0; i < len; i++) out[i] = inc;\n }\n return out;\n}\n\nfunction binsToCalc(r2c, bins) {\n return {\n start: r2c(bins.start),\n end: r2c(bins.end),\n size: bins.size\n };\n}\n\nfunction getRanges(edges, uniqueVals, gapLow, gapHigh, ax, calendar) {\n var i;\n var len = edges.length - 1;\n var out = new Array(len);\n var roundFn = getBinSpanLabelRound(gapLow, gapHigh, edges, ax, calendar);\n\n for(i = 0; i < len; i++) {\n var v = (uniqueVals || [])[i];\n out[i] = v === undefined ?\n [roundFn(edges[i]), roundFn(edges[i + 1], true)] :\n [v, v];\n }\n return out;\n}\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar handleSampleDefaults = require('./sample_defaults');\nvar handleStyleDefaults = require('../heatmap/style_defaults');\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar handleHeatmapLabelDefaults = require('../heatmap/label_defaults');\nvar attributes = require('./attributes');\n\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n handleSampleDefaults(traceIn, traceOut, coerce, layout);\n if(traceOut.visible === false) return;\n\n handleStyleDefaults(traceIn, traceOut, coerce, layout);\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'z'});\n coerce('hovertemplate');\n\n handleHeatmapLabelDefaults(coerce, layout);\n\n coerce('xhoverformat');\n coerce('yhoverformat');\n};\n","'use strict';\n\nvar heatmapHover = require('../heatmap/hover');\nvar hoverLabelText = require('../../plots/cartesian/axes').hoverLabelText;\n\nmodule.exports = function hoverPoints(pointData, xval, yval, hovermode, opts) {\n var pts = heatmapHover(pointData, xval, yval, hovermode, opts);\n\n if(!pts) return;\n\n pointData = pts[0];\n var indices = pointData.index;\n var ny = indices[0];\n var nx = indices[1];\n var cd0 = pointData.cd[0];\n var trace = cd0.trace;\n var xRange = cd0.xRanges[nx];\n var yRange = cd0.yRanges[ny];\n\n pointData.xLabel = hoverLabelText(pointData.xa, [xRange[0], xRange[1]], trace.xhoverformat);\n pointData.yLabel = hoverLabelText(pointData.ya, [yRange[0], yRange[1]], trace.yhoverformat);\n\n return pts;\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n crossTraceDefaults: require('../histogram/cross_trace_defaults'),\n calc: require('../heatmap/calc'),\n plot: require('../heatmap/plot'),\n layerName: 'heatmaplayer',\n colorbar: require('../heatmap/colorbar'),\n style: require('../heatmap/style'),\n hoverPoints: require('./hover'),\n eventData: require('../histogram/event_data'),\n\n moduleType: 'trace',\n name: 'histogram2d',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['cartesian', 'svg', '2dMap', 'histogram', 'showLegend'],\n meta: {\n hrName: 'histogram_2d',\n description: [\n 'The sample data from which statistics are computed is set in `x`',\n 'and `y` (where `x` and `y` represent marginal distributions,',\n 'binning is set in `xbins` and `ybins` in this case)',\n 'or `z` (where `z` represent the 2D distribution and binning set,',\n 'binning is set by `x` and `y` in this case).',\n 'The resulting distribution is visualized as a heatmap.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\n\nmodule.exports = function handleSampleDefaults(traceIn, traceOut, coerce, layout) {\n var x = coerce('x');\n var y = coerce('y');\n var xlen = Lib.minRowLength(x);\n var ylen = Lib.minRowLength(y);\n\n // we could try to accept x0 and dx, etc...\n // but that's a pretty weird use case.\n // for now require both x and y explicitly specified.\n if(!xlen || !ylen) {\n traceOut.visible = false;\n return;\n }\n\n traceOut._length = Math.min(xlen, ylen);\n\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleTraceDefaults');\n handleCalendarDefaults(traceIn, traceOut, ['x', 'y'], layout);\n\n // if marker.color is an array, we can use it in aggregation instead of z\n var hasAggregationData = coerce('z') || coerce('marker.color');\n\n if(hasAggregationData) coerce('histfunc');\n coerce('histnorm');\n\n // Note: bin defaults are now handled in Histogram2D.crossTraceDefaults\n // autobin(x|y) are only included here to appease Plotly.validate\n coerce('autobinx');\n coerce('autobiny');\n};\n","'use strict';\n\nvar histogram2dAttrs = require('../histogram2d/attributes');\nvar contourAttrs = require('../contour/attributes');\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nmodule.exports = extendFlat({\n x: histogram2dAttrs.x,\n y: histogram2dAttrs.y,\n z: histogram2dAttrs.z,\n marker: histogram2dAttrs.marker,\n\n histnorm: histogram2dAttrs.histnorm,\n histfunc: histogram2dAttrs.histfunc,\n nbinsx: histogram2dAttrs.nbinsx,\n xbins: histogram2dAttrs.xbins,\n nbinsy: histogram2dAttrs.nbinsy,\n ybins: histogram2dAttrs.ybins,\n autobinx: histogram2dAttrs.autobinx,\n autobiny: histogram2dAttrs.autobiny,\n\n bingroup: histogram2dAttrs.bingroup,\n xbingroup: histogram2dAttrs.xbingroup,\n ybingroup: histogram2dAttrs.ybingroup,\n\n autocontour: contourAttrs.autocontour,\n ncontours: contourAttrs.ncontours,\n contours: contourAttrs.contours,\n line: {\n color: contourAttrs.line.color,\n width: extendFlat({}, contourAttrs.line.width, {\n dflt: 0.5,\n description: 'Sets the contour line width in (in px)'\n }),\n dash: contourAttrs.line.dash,\n smoothing: contourAttrs.line.smoothing,\n editType: 'plot'\n },\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n zhoverformat: axisHoverFormat('z', 1),\n hovertemplate: histogram2dAttrs.hovertemplate,\n texttemplate: contourAttrs.texttemplate,\n textfont: contourAttrs.textfont\n},\n colorScaleAttrs('', {\n cLetter: 'z',\n editTypeOverride: 'calc'\n })\n);\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar handleSampleDefaults = require('../histogram2d/sample_defaults');\nvar handleContoursDefaults = require('../contour/contours_defaults');\nvar handleStyleDefaults = require('../contour/style_defaults');\nvar handleHeatmapLabelDefaults = require('../heatmap/label_defaults');\nvar attributes = require('./attributes');\n\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n function coerce2(attr) {\n return Lib.coerce2(traceIn, traceOut, attributes, attr);\n }\n\n handleSampleDefaults(traceIn, traceOut, coerce, layout);\n if(traceOut.visible === false) return;\n\n handleContoursDefaults(traceIn, traceOut, coerce, coerce2);\n handleStyleDefaults(traceIn, traceOut, coerce, layout);\n coerce('xhoverformat');\n coerce('yhoverformat');\n coerce('hovertemplate');\n if(\n traceOut.contours &&\n traceOut.contours.coloring === 'heatmap'\n ) {\n handleHeatmapLabelDefaults(coerce, layout);\n }\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n crossTraceDefaults: require('../histogram/cross_trace_defaults'),\n calc: require('../contour/calc'),\n plot: require('../contour/plot').plot,\n layerName: 'contourlayer',\n style: require('../contour/style'),\n colorbar: require('../contour/colorbar'),\n hoverPoints: require('../contour/hover'),\n\n moduleType: 'trace',\n name: 'histogram2dcontour',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['cartesian', 'svg', '2dMap', 'contour', 'histogram', 'showLegend'],\n meta: {\n hrName: 'histogram_2d_contour',\n description: [\n 'The sample data from which statistics are computed is set in `x`',\n 'and `y` (where `x` and `y` represent marginal distributions,',\n 'binning is set in `xbins` and `ybins` in this case)',\n 'or `z` (where `z` represent the 2D distribution and binning set,',\n 'binning is set by `x` and `y` in this case).',\n 'The resulting distribution is visualized as a contour plot.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\n\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar domainAttrs = require('../../plots/domain').attributes;\nvar pieAttrs = require('../pie/attributes');\nvar sunburstAttrs = require('../sunburst/attributes');\nvar treemapAttrs = require('../treemap/attributes');\nvar constants = require('../treemap/constants');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar pattern = require('../../components/drawing/attributes').pattern;\n\nmodule.exports = {\n labels: sunburstAttrs.labels,\n parents: sunburstAttrs.parents,\n\n values: sunburstAttrs.values,\n branchvalues: sunburstAttrs.branchvalues,\n count: sunburstAttrs.count,\n\n level: sunburstAttrs.level,\n maxdepth: sunburstAttrs.maxdepth,\n\n tiling: {\n orientation: {\n valType: 'enumerated',\n values: ['v', 'h'],\n dflt: 'h',\n editType: 'plot',\n description: [\n 'When set in conjunction with `tiling.flip`, determines on',\n 'which side the root nodes are drawn in the chart. If',\n '`tiling.orientation` is *v* and `tiling.flip` is **, the root',\n 'nodes appear at the top. If `tiling.orientation` is *v* and',\n '`tiling.flip` is *y*, the root nodes appear at the bottom. If',\n '`tiling.orientation` is *h* and `tiling.flip` is **, the',\n 'root nodes appear at the left. If `tiling.orientation` is *h*',\n 'and `tiling.flip` is *x*, the root nodes appear at the right.',\n ].join(' ')\n },\n\n flip: treemapAttrs.tiling.flip,\n\n pad: {\n valType: 'number',\n min: 0,\n dflt: 0,\n editType: 'plot',\n description: [\n 'Sets the inner padding (in px).'\n ].join(' ')\n },\n\n\n editType: 'calc',\n },\n\n marker: extendFlat({\n colors: sunburstAttrs.marker.colors,\n\n line: sunburstAttrs.marker.line,\n\n pattern: pattern,\n\n editType: 'calc'\n },\n colorScaleAttrs('marker', {\n colorAttr: 'colors',\n anim: false // TODO: set to anim: true?\n })\n ),\n\n leaf: sunburstAttrs.leaf,\n\n pathbar: treemapAttrs.pathbar,\n\n text: pieAttrs.text,\n textinfo: sunburstAttrs.textinfo,\n // TODO: incorporate `label` and `value` in the eventData\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: constants.eventDataKeys.concat(['label', 'value'])\n }),\n\n hovertext: pieAttrs.hovertext,\n hoverinfo: sunburstAttrs.hoverinfo,\n hovertemplate: hovertemplateAttrs({}, {\n keys: constants.eventDataKeys\n }),\n\n textfont: pieAttrs.textfont,\n insidetextfont: pieAttrs.insidetextfont,\n outsidetextfont: treemapAttrs.outsidetextfont,\n\n textposition: treemapAttrs.textposition,\n sort: pieAttrs.sort,\n root: sunburstAttrs.root,\n\n domain: domainAttrs({name: 'icicle', trace: true, editType: 'calc'}),\n};\n","'use strict';\n\nvar plots = require('../../plots/plots');\n\nexports.name = 'icicle';\n\nexports.plot = function(gd, traces, transitionOpts, makeOnCompleteCallback) {\n plots.plotBasePlot(exports.name, gd, traces, transitionOpts, makeOnCompleteCallback);\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n plots.cleanBasePlot(exports.name, newFullData, newFullLayout, oldFullData, oldFullLayout);\n};\n","'use strict';\n\nvar calc = require('../sunburst/calc');\n\nexports.calc = function(gd, trace) {\n return calc.calc(gd, trace);\n};\n\nexports.crossTraceCalc = function(gd) {\n return calc._runCrossTraceCalc('icicle', gd);\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar attributes = require('./attributes');\nvar Color = require('../../components/color');\nvar handleDomainDefaults = require('../../plots/domain').defaults;\nvar handleText = require('../bar/defaults').handleText;\nvar TEXTPAD = require('../bar/constants').TEXTPAD;\nvar handleMarkerDefaults = require('../pie/defaults').handleMarkerDefaults;\n\nvar Colorscale = require('../../components/colorscale');\nvar hasColorscale = Colorscale.hasColorscale;\nvar colorscaleDefaults = Colorscale.handleDefaults;\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var labels = coerce('labels');\n var parents = coerce('parents');\n\n if(!labels || !labels.length || !parents || !parents.length) {\n traceOut.visible = false;\n return;\n }\n\n var vals = coerce('values');\n if(vals && vals.length) {\n coerce('branchvalues');\n } else {\n coerce('count');\n }\n\n coerce('level');\n coerce('maxdepth');\n\n coerce('tiling.orientation');\n coerce('tiling.flip');\n coerce('tiling.pad');\n\n var text = coerce('text');\n coerce('texttemplate');\n if(!traceOut.texttemplate) coerce('textinfo', Lib.isArrayOrTypedArray(text) ? 'text+label' : 'label');\n\n coerce('hovertext');\n coerce('hovertemplate');\n\n var hasPathbar = coerce('pathbar.visible');\n\n var textposition = 'auto';\n handleText(traceIn, traceOut, layout, coerce, textposition, {\n hasPathbar: hasPathbar,\n moduleHasSelected: false,\n moduleHasUnselected: false,\n moduleHasConstrain: false,\n moduleHasCliponaxis: false,\n moduleHasTextangle: false,\n moduleHasInsideanchor: false\n });\n coerce('textposition');\n\n handleMarkerDefaults(traceIn, traceOut, layout, coerce);\n\n var withColorscale = traceOut._hasColorscale = (\n hasColorscale(traceIn, 'marker', 'colors') ||\n (traceIn.marker || {}).coloraxis // N.B. special logic to consider \"values\" colorscales\n );\n if(withColorscale) {\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: 'marker.', cLetter: 'c'});\n }\n\n coerce('leaf.opacity', withColorscale ? 1 : 0.7);\n\n traceOut._hovered = {\n marker: {\n line: {\n width: 2,\n color: Color.contrast(layout.paper_bgcolor)\n }\n }\n };\n\n if(hasPathbar) {\n // This works even for multi-line labels as icicle pathbar trim out line breaks\n coerce('pathbar.thickness', traceOut.pathbar.textfont.size + 2 * TEXTPAD);\n\n coerce('pathbar.side');\n coerce('pathbar.edgeshape');\n }\n\n coerce('sort');\n\n coerce('root.color');\n\n handleDomainDefaults(traceOut, layout, coerce);\n\n // do not support transforms for now\n traceOut._length = null;\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\nvar Drawing = require('../../components/drawing');\nvar svgTextUtils = require('../../lib/svg_text_utils');\n\nvar partition = require('./partition');\nvar styleOne = require('./style').styleOne;\nvar constants = require('../treemap/constants');\nvar helpers = require('../sunburst/helpers');\nvar attachFxHandlers = require('../sunburst/fx');\nvar formatSliceLabel = require('../sunburst/plot').formatSliceLabel;\n\nvar onPathbar = false; // for Descendants\n\nmodule.exports = function drawDescendants(gd, cd, entry, slices, opts) {\n var width = opts.width;\n var height = opts.height;\n var viewX = opts.viewX;\n var viewY = opts.viewY;\n var pathSlice = opts.pathSlice;\n var toMoveInsideSlice = opts.toMoveInsideSlice;\n var strTransform = opts.strTransform;\n var hasTransition = opts.hasTransition;\n var handleSlicesExit = opts.handleSlicesExit;\n var makeUpdateSliceInterpolator = opts.makeUpdateSliceInterpolator;\n var makeUpdateTextInterpolator = opts.makeUpdateTextInterpolator;\n var prevEntry = opts.prevEntry;\n var refRect = {};\n\n var isStatic = gd._context.staticPlot;\n\n var fullLayout = gd._fullLayout;\n var cd0 = cd[0];\n var trace = cd0.trace;\n\n var hasLeft = trace.textposition.indexOf('left') !== -1;\n var hasRight = trace.textposition.indexOf('right') !== -1;\n var hasBottom = trace.textposition.indexOf('bottom') !== -1;\n\n // N.B. slice data isn't the calcdata,\n // grab corresponding calcdata item in sliceData[i].data.data\n var allData = partition(entry, [width, height], {\n flipX: trace.tiling.flip.indexOf('x') > -1,\n flipY: trace.tiling.flip.indexOf('y') > -1,\n orientation: trace.tiling.orientation,\n pad: {\n inner: trace.tiling.pad\n },\n maxDepth: trace._maxDepth\n });\n\n var sliceData = allData.descendants();\n\n var minVisibleDepth = Infinity;\n var maxVisibleDepth = -Infinity;\n sliceData.forEach(function(pt) {\n var depth = pt.depth;\n if(depth >= trace._maxDepth) {\n // hide slices that won't show up on graph\n pt.x0 = pt.x1 = (pt.x0 + pt.x1) / 2;\n pt.y0 = pt.y1 = (pt.y0 + pt.y1) / 2;\n } else {\n minVisibleDepth = Math.min(minVisibleDepth, depth);\n maxVisibleDepth = Math.max(maxVisibleDepth, depth);\n }\n });\n\n slices = slices.data(sliceData, helpers.getPtId);\n\n trace._maxVisibleLayers = isFinite(maxVisibleDepth) ? maxVisibleDepth - minVisibleDepth + 1 : 0;\n\n slices.enter().append('g')\n .classed('slice', true);\n\n handleSlicesExit(slices, onPathbar, refRect, [width, height], pathSlice);\n\n slices.order();\n\n // next coords of previous entry\n var nextOfPrevEntry = null;\n if(hasTransition && prevEntry) {\n var prevEntryId = helpers.getPtId(prevEntry);\n slices.each(function(pt) {\n if(nextOfPrevEntry === null && (helpers.getPtId(pt) === prevEntryId)) {\n nextOfPrevEntry = {\n x0: pt.x0,\n x1: pt.x1,\n y0: pt.y0,\n y1: pt.y1\n };\n }\n });\n }\n\n var getRefRect = function() {\n return nextOfPrevEntry || {\n x0: 0,\n x1: width,\n y0: 0,\n y1: height\n };\n };\n\n var updateSlices = slices;\n if(hasTransition) {\n updateSlices = updateSlices.transition().each('end', function() {\n // N.B. gd._transitioning is (still) *true* by the time\n // transition updates get here\n var sliceTop = d3.select(this);\n helpers.setSliceCursor(sliceTop, gd, {\n hideOnRoot: true,\n hideOnLeaves: false,\n isTransitioning: false\n });\n });\n }\n\n updateSlices.each(function(pt) {\n // for bbox\n pt._x0 = viewX(pt.x0);\n pt._x1 = viewX(pt.x1);\n pt._y0 = viewY(pt.y0);\n pt._y1 = viewY(pt.y1);\n\n pt._hoverX = viewX(pt.x1 - trace.tiling.pad),\n pt._hoverY = hasBottom ?\n viewY(pt.y1 - trace.tiling.pad / 2) :\n viewY(pt.y0 + trace.tiling.pad / 2);\n\n var sliceTop = d3.select(this);\n\n var slicePath = Lib.ensureSingle(sliceTop, 'path', 'surface', function(s) {\n s.style('pointer-events', isStatic ? 'none' : 'all');\n });\n\n if(hasTransition) {\n slicePath.transition().attrTween('d', function(pt2) {\n var interp = makeUpdateSliceInterpolator(\n pt2,\n onPathbar,\n getRefRect(),\n [width, height],\n {\n orientation: trace.tiling.orientation,\n flipX: trace.tiling.flip.indexOf('x') > -1,\n flipY: trace.tiling.flip.indexOf('y') > -1,\n }\n );\n return function(t) { return pathSlice(interp(t)); };\n });\n } else {\n slicePath.attr('d', pathSlice);\n }\n\n sliceTop\n .call(attachFxHandlers, entry, gd, cd, {\n styleOne: styleOne,\n eventDataKeys: constants.eventDataKeys,\n transitionTime: constants.CLICK_TRANSITION_TIME,\n transitionEasing: constants.CLICK_TRANSITION_EASING\n })\n .call(helpers.setSliceCursor, gd, { isTransitioning: gd._transitioning });\n\n slicePath.call(styleOne, pt, trace, gd, {\n hovered: false\n });\n\n if(pt.x0 === pt.x1 || pt.y0 === pt.y1) {\n pt._text = '';\n } else {\n pt._text = formatSliceLabel(pt, entry, trace, cd, fullLayout) || '';\n }\n\n var sliceTextGroup = Lib.ensureSingle(sliceTop, 'g', 'slicetext');\n var sliceText = Lib.ensureSingle(sliceTextGroup, 'text', '', function(s) {\n // prohibit tex interpretation until we can handle\n // tex and regular text together\n s.attr('data-notex', 1);\n });\n\n var font = Lib.ensureUniformFontSize(gd, helpers.determineTextFont(trace, pt, fullLayout.font));\n\n sliceText.text(pt._text || ' ') // use one space character instead of a blank string to avoid jumps during transition\n .classed('slicetext', true)\n .attr('text-anchor', hasRight ? 'end' : hasLeft ? 'start' : 'middle')\n .call(Drawing.font, font)\n .call(svgTextUtils.convertToTspans, gd);\n\n pt.textBB = Drawing.bBox(sliceText.node());\n pt.transform = toMoveInsideSlice(pt, {\n fontSize: font.size\n });\n pt.transform.fontSize = font.size;\n\n if(hasTransition) {\n sliceText.transition().attrTween('transform', function(pt2) {\n var interp = makeUpdateTextInterpolator(pt2, onPathbar, getRefRect(), [width, height]);\n return function(t) { return strTransform(interp(t)); };\n });\n } else {\n sliceText.attr('transform', strTransform(pt));\n }\n });\n\n return nextOfPrevEntry;\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'icicle',\n basePlotModule: require('./base_plot'),\n categories: [],\n animatable: true,\n\n attributes: require('./attributes'),\n layoutAttributes: require('./layout_attributes'),\n supplyDefaults: require('./defaults'),\n supplyLayoutDefaults: require('./layout_defaults'),\n\n calc: require('./calc').calc,\n crossTraceCalc: require('./calc').crossTraceCalc,\n\n plot: require('./plot'),\n style: require('./style').style,\n\n colorbar: require('../scatter/marker_colorbar'),\n\n meta: {\n description: [\n 'Visualize hierarchal data from leaves (and/or outer branches) towards root',\n 'with rectangles. The icicle sectors are determined by the entries in',\n '*labels* or *ids* and in *parents*.'\n ].join(' ')\n }\n};\n","'use strict';\n\nmodule.exports = {\n iciclecolorway: {\n valType: 'colorlist',\n editType: 'calc',\n description: [\n 'Sets the default icicle slice colors. Defaults to the main',\n '`colorway` used for trace colors. If you specify a new',\n 'list here it can still be extended with lighter and darker',\n 'colors, see `extendiciclecolors`.'\n ].join(' ')\n },\n extendiciclecolors: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'If `true`, the icicle slice colors (whether given by `iciclecolorway` or',\n 'inherited from `colorway`) will be extended to three times its',\n 'original length by first repeating every color 20% lighter then',\n 'each color 20% darker. This is intended to reduce the likelihood',\n 'of reusing the same color when you have many slices, but you can',\n 'set `false` to disable.',\n 'Colors provided in the trace, using `marker.colors`, are never',\n 'extended.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar layoutAttributes = require('./layout_attributes');\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n coerce('iciclecolorway', layoutOut.colorway);\n coerce('extendiciclecolors');\n};\n","'use strict';\n\nvar d3Hierarchy = require('d3-hierarchy');\nvar flipTree = require('../treemap/flip_tree');\n\nmodule.exports = function partition(entry, size, opts) {\n var flipX = opts.flipX;\n var flipY = opts.flipY;\n var swapXY = opts.orientation === 'h';\n var maxDepth = opts.maxDepth;\n\n var newWidth = size[0];\n var newHeight = size[1];\n if(maxDepth) {\n newWidth = (entry.height + 1) * size[0] / Math.min(entry.height + 1, maxDepth);\n newHeight = (entry.height + 1) * size[1] / Math.min(entry.height + 1, maxDepth);\n }\n\n var result = d3Hierarchy\n .partition()\n .padding(opts.pad.inner)\n .size(\n swapXY ? [size[1], newWidth] : [size[0], newHeight]\n )(entry);\n\n if(swapXY || flipX || flipY) {\n flipTree(result, size, {\n swapXY: swapXY,\n flipX: flipX,\n flipY: flipY\n });\n }\n return result;\n};\n","'use strict';\n\nvar draw = require('../treemap/draw');\nvar drawDescendants = require('./draw_descendants');\n\nmodule.exports = function _plot(gd, cdmodule, transitionOpts, makeOnCompleteCallback) {\n return draw(gd, cdmodule, transitionOpts, makeOnCompleteCallback, {\n type: 'icicle',\n drawDescendants: drawDescendants\n });\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Color = require('../../components/color');\nvar Lib = require('../../lib');\nvar resizeText = require('../bar/uniform_text').resizeText;\nvar fillOne = require('../sunburst/fill_one');\n\nfunction style(gd) {\n var s = gd._fullLayout._iciclelayer.selectAll('.trace');\n resizeText(gd, s, 'icicle');\n\n s.each(function(cd) {\n var gTrace = d3.select(this);\n var cd0 = cd[0];\n var trace = cd0.trace;\n\n gTrace.style('opacity', trace.opacity);\n\n gTrace.selectAll('path.surface').each(function(pt) {\n d3.select(this).call(styleOne, pt, trace, gd);\n });\n });\n}\n\nfunction styleOne(s, pt, trace, gd) {\n var cdi = pt.data.data;\n var isLeaf = !pt.children;\n var ptNumber = cdi.i;\n var lineColor = Lib.castOption(trace, ptNumber, 'marker.line.color') || Color.defaultLine;\n var lineWidth = Lib.castOption(trace, ptNumber, 'marker.line.width') || 0;\n\n s.call(fillOne, pt, trace, gd)\n .style('stroke-width', lineWidth)\n .call(Color.stroke, lineColor)\n .style('opacity', isLeaf ? trace.leaf.opacity : null);\n}\n\nmodule.exports = {\n style: style,\n styleOne: styleOne\n};\n","'use strict';\n\nvar baseAttrs = require('../../plots/attributes');\nvar zorder = require('../scatter/attributes').zorder;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar colormodel = require('./constants').colormodel;\n\nvar cm = ['rgb', 'rgba', 'rgba256', 'hsl', 'hsla'];\nvar zminDesc = [];\nvar zmaxDesc = [];\nfor(var i = 0; i < cm.length; i++) {\n var cr = colormodel[cm[i]];\n zminDesc.push('For the `' + cm[i] + '` colormodel, it is [' + (cr.zminDflt || cr.min).join(', ') + '].');\n zmaxDesc.push('For the `' + cm[i] + '` colormodel, it is [' + (cr.zmaxDflt || cr.max).join(', ') + '].');\n}\n\nmodule.exports = extendFlat({\n source: {\n valType: 'string',\n editType: 'calc',\n description: [\n 'Specifies the data URI of the image to be visualized.',\n 'The URI consists of \"data:image/[][;base64],\"'\n ].join(' ')\n },\n z: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'A 2-dimensional array in which each element is an array of 3 or 4 numbers representing a color.',\n ].join(' ')\n },\n colormodel: {\n valType: 'enumerated',\n values: cm,\n editType: 'calc',\n description: [\n 'Color model used to map the numerical color components described in `z` into colors.',\n 'If `source` is specified, this attribute will be set to `rgba256`',\n 'otherwise it defaults to `rgb`.'\n ].join(' ')\n },\n zsmooth: {\n valType: 'enumerated',\n values: ['fast', false],\n dflt: false,\n editType: 'plot',\n description: [\n 'Picks a smoothing algorithm used to smooth `z` data.',\n 'This only applies for image traces that use the `source` attribute.'\n ].join(' ')\n },\n zmin: {\n valType: 'info_array',\n items: [\n {valType: 'number', editType: 'calc'},\n {valType: 'number', editType: 'calc'},\n {valType: 'number', editType: 'calc'},\n {valType: 'number', editType: 'calc'}\n ],\n editType: 'calc',\n description: [\n 'Array defining the lower bound for each color component.',\n 'Note that the default value will depend on the colormodel.',\n zminDesc.join(' ')\n ].join(' ')\n },\n zmax: {\n valType: 'info_array',\n items: [\n {valType: 'number', editType: 'calc'},\n {valType: 'number', editType: 'calc'},\n {valType: 'number', editType: 'calc'},\n {valType: 'number', editType: 'calc'}\n ],\n editType: 'calc',\n description: [\n 'Array defining the higher bound for each color component.',\n 'Note that the default value will depend on the colormodel.',\n zmaxDesc.join(' ')\n ].join(' ')\n },\n x0: {\n valType: 'any',\n dflt: 0,\n editType: 'calc+clearAxisTypes',\n description: [\n 'Set the image\\'s x position. The left edge of the image',\n '(or the right edge if the x axis is reversed or dx is negative)',\n 'will be found at xmin=x0-dx/2'\n ].join(' ')\n },\n y0: {\n valType: 'any',\n dflt: 0,\n editType: 'calc+clearAxisTypes',\n description: [\n 'Set the image\\'s y position. The top edge of the image',\n '(or the bottom edge if the y axis is NOT reversed or if dy is negative)',\n 'will be found at ymin=y0-dy/2. By default when an image trace is',\n 'included, the y axis will be reversed so that the image is right-side-up,',\n 'but you can disable this by setting yaxis.autorange=true or by providing',\n 'an explicit y axis range.'\n ].join(' ')\n },\n dx: {\n valType: 'number',\n dflt: 1,\n editType: 'calc',\n description: 'Set the pixel\\'s horizontal size.'\n },\n dy: {\n valType: 'number',\n dflt: 1,\n editType: 'calc',\n description: 'Set the pixel\\'s vertical size'\n },\n text: {\n valType: 'data_array',\n editType: 'plot',\n description: 'Sets the text elements associated with each z value.'\n },\n hovertext: {\n valType: 'data_array',\n editType: 'plot',\n description: 'Same as `text`.'\n },\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['x', 'y', 'z', 'color', 'name', 'text'],\n dflt: 'x+y+z+text+name'\n }),\n hovertemplate: hovertemplateAttrs({}, {\n keys: ['z', 'color', 'colormodel']\n }),\n\n zorder: zorder,\n transforms: undefined\n});\n","'use strict';\n\nvar Lib = require('../../lib');\nvar constants = require('./constants');\nvar isNumeric = require('fast-isnumeric');\nvar Axes = require('../../plots/cartesian/axes');\nvar maxRowLength = require('../../lib').maxRowLength;\nvar getImageSize = require('./helpers').getImageSize;\n\nmodule.exports = function calc(gd, trace) {\n var h;\n var w;\n if(trace._hasZ) {\n h = trace.z.length;\n w = maxRowLength(trace.z);\n } else if(trace._hasSource) {\n var size = getImageSize(trace.source);\n h = size.height;\n w = size.width;\n }\n\n var xa = Axes.getFromId(gd, trace.xaxis || 'x');\n var ya = Axes.getFromId(gd, trace.yaxis || 'y');\n\n var x0 = xa.d2c(trace.x0) - trace.dx / 2;\n var y0 = ya.d2c(trace.y0) - trace.dy / 2;\n\n // Set axis range\n var i;\n var xrange = [x0, x0 + w * trace.dx];\n var yrange = [y0, y0 + h * trace.dy];\n if(xa && xa.type === 'log') for(i = 0; i < w; i++) xrange.push(x0 + i * trace.dx);\n if(ya && ya.type === 'log') for(i = 0; i < h; i++) yrange.push(y0 + i * trace.dy);\n trace._extremes[xa._id] = Axes.findExtremes(xa, xrange);\n trace._extremes[ya._id] = Axes.findExtremes(ya, yrange);\n trace._scaler = makeScaler(trace);\n\n var cd0 = {\n x0: x0,\n y0: y0,\n z: trace.z,\n w: w,\n h: h\n };\n return [cd0];\n};\n\nfunction scale(zero, ratio, min, max) {\n return function(c) {\n return Lib.constrain((c - zero) * ratio, min, max);\n };\n}\n\nfunction constrain(min, max) {\n return function(c) { return Lib.constrain(c, min, max);};\n}\n\n// Generate a function to scale color components according to zmin/zmax and the colormodel\nfunction makeScaler(trace) {\n var cr = constants.colormodel[trace.colormodel];\n var colormodel = (cr.colormodel || trace.colormodel);\n var n = colormodel.length;\n\n trace._sArray = [];\n // Loop over all color components\n for(var k = 0; k < n; k++) {\n if(cr.min[k] !== trace.zmin[k] || cr.max[k] !== trace.zmax[k]) {\n trace._sArray.push(scale(\n trace.zmin[k],\n (cr.max[k] - cr.min[k]) / (trace.zmax[k] - trace.zmin[k]),\n cr.min[k],\n cr.max[k]\n ));\n } else {\n trace._sArray.push(constrain(cr.min[k], cr.max[k]));\n }\n }\n\n return function(pixel) {\n var c = pixel.slice(0, n);\n for(var k = 0; k < n; k++) {\n var ck = c[k];\n if(!isNumeric(ck)) return false;\n c[k] = trace._sArray[k](ck);\n }\n return c;\n };\n}\n","'use strict';\n\nmodule.exports = {\n colormodel: {\n // min and max define the numerical range accepted in CSS\n // If z(min|max)Dflt are not defined, z(min|max) will default to min/max\n rgb: {\n min: [0, 0, 0],\n max: [255, 255, 255],\n fmt: function(c) {return c.slice(0, 3);},\n suffix: ['', '', '']\n },\n rgba: {\n min: [0, 0, 0, 0],\n max: [255, 255, 255, 1],\n fmt: function(c) {return c.slice(0, 4);},\n suffix: ['', '', '', '']\n },\n rgba256: {\n colormodel: 'rgba', // because rgba256 is not an accept colormodel in CSS\n zminDflt: [0, 0, 0, 0],\n zmaxDflt: [255, 255, 255, 255],\n min: [0, 0, 0, 0],\n max: [255, 255, 255, 1],\n fmt: function(c) {return c.slice(0, 4);},\n suffix: ['', '', '', '']\n },\n hsl: {\n min: [0, 0, 0],\n max: [360, 100, 100],\n fmt: function(c) {\n var p = c.slice(0, 3);\n p[1] = p[1] + '%';\n p[2] = p[2] + '%';\n return p;\n },\n suffix: ['°', '%', '%']\n },\n hsla: {\n min: [0, 0, 0, 0],\n max: [360, 100, 100, 1],\n fmt: function(c) {\n var p = c.slice(0, 4);\n p[1] = p[1] + '%';\n p[2] = p[2] + '%';\n return p;\n },\n suffix: ['°', '%', '%', '']\n }\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar attributes = require('./attributes');\nvar constants = require('./constants');\nvar dataUri = require('../../snapshot/helpers').IMAGE_URL_PREFIX;\n\nmodule.exports = function supplyDefaults(traceIn, traceOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n coerce('source');\n // sanitize source to only allow for data URI representing images\n if(traceOut.source && !traceOut.source.match(dataUri)) delete traceOut.source;\n traceOut._hasSource = !!traceOut.source;\n\n var z = coerce('z');\n traceOut._hasZ = !(z === undefined || !z.length || !z[0] || !z[0].length);\n if(!traceOut._hasZ && !traceOut._hasSource) {\n traceOut.visible = false;\n return;\n }\n\n coerce('x0');\n coerce('y0');\n coerce('dx');\n coerce('dy');\n\n var cm;\n if(traceOut._hasZ) {\n coerce('colormodel', 'rgb');\n cm = constants.colormodel[traceOut.colormodel];\n coerce('zmin', (cm.zminDflt || cm.min));\n coerce('zmax', (cm.zmaxDflt || cm.max));\n } else if(traceOut._hasSource) {\n traceOut.colormodel = 'rgba256';\n cm = constants.colormodel[traceOut.colormodel];\n traceOut.zmin = cm.zminDflt;\n traceOut.zmax = cm.zmaxDflt;\n }\n\n coerce('zsmooth');\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n\n traceOut._length = null;\n\n coerce('zorder');\n};\n","'use strict';\n\nmodule.exports = function eventData(out, pt) {\n if('xVal' in pt) out.x = pt.xVal;\n if('yVal' in pt) out.y = pt.yVal;\n if(pt.xa) out.xaxis = pt.xa;\n if(pt.ya) out.yaxis = pt.ya;\n out.color = pt.color;\n out.colormodel = pt.trace.colormodel;\n if(!out.z) out.z = pt.color;\n return out;\n};\n","'use strict';\n\nvar probeSync = require('probe-image-size/sync');\nvar dataUri = require('../../snapshot/helpers').IMAGE_URL_PREFIX;\nvar Buffer = require('buffer/').Buffer; // note: the trailing slash is important!\n\nexports.getImageSize = function(src) {\n var data = src.replace(dataUri, '');\n var buff = new Buffer(data, 'base64');\n return probeSync(buff);\n};\n","'use strict';\n\nvar Fx = require('../../components/fx');\nvar Lib = require('../../lib');\nvar isArrayOrTypedArray = Lib.isArrayOrTypedArray;\nvar constants = require('./constants');\n\nmodule.exports = function hoverPoints(pointData, xval, yval) {\n var cd0 = pointData.cd[0];\n var trace = cd0.trace;\n var xa = pointData.xa;\n var ya = pointData.ya;\n\n // Return early if not on image\n if(Fx.inbox(xval - cd0.x0, xval - (cd0.x0 + cd0.w * trace.dx), 0) > 0 ||\n Fx.inbox(yval - cd0.y0, yval - (cd0.y0 + cd0.h * trace.dy), 0) > 0) {\n return;\n }\n\n // Find nearest pixel's index\n var nx = Math.floor((xval - cd0.x0) / trace.dx);\n var ny = Math.floor(Math.abs(yval - cd0.y0) / trace.dy);\n\n var pixel;\n if(trace._hasZ) {\n pixel = cd0.z[ny][nx];\n } else if(trace._hasSource) {\n pixel = trace._canvas.el.getContext('2d', {willReadFrequently: true}).getImageData(nx, ny, 1, 1).data;\n }\n\n // return early if pixel is undefined\n if(!pixel) return;\n\n var hoverinfo = cd0.hi || trace.hoverinfo;\n var fmtColor;\n if(hoverinfo) {\n var parts = hoverinfo.split('+');\n if(parts.indexOf('all') !== -1) parts = ['color'];\n if(parts.indexOf('color') !== -1) fmtColor = true;\n }\n\n var cr = constants.colormodel[trace.colormodel];\n var colormodel = cr.colormodel || trace.colormodel;\n var dims = colormodel.length;\n var c = trace._scaler(pixel);\n var s = cr.suffix;\n\n var colorstring = [];\n if(trace.hovertemplate || fmtColor) {\n colorstring.push('[' + [c[0] + s[0], c[1] + s[1], c[2] + s[2]].join(', '));\n if(dims === 4) colorstring.push(', ' + c[3] + s[3]);\n colorstring.push(']');\n colorstring = colorstring.join('');\n pointData.extraText = colormodel.toUpperCase() + ': ' + colorstring;\n }\n\n var text;\n if(isArrayOrTypedArray(trace.hovertext) && isArrayOrTypedArray(trace.hovertext[ny])) {\n text = trace.hovertext[ny][nx];\n } else if(isArrayOrTypedArray(trace.text) && isArrayOrTypedArray(trace.text[ny])) {\n text = trace.text[ny][nx];\n }\n\n // TODO: for color model with 3 dims, display something useful for hovertemplate `%{color[3]}`\n var py = ya.c2p(cd0.y0 + (ny + 0.5) * trace.dy);\n var xVal = cd0.x0 + (nx + 0.5) * trace.dx;\n var yVal = cd0.y0 + (ny + 0.5) * trace.dy;\n var zLabel = '[' + pixel.slice(0, trace.colormodel.length).join(', ') + ']';\n return [Lib.extendFlat(pointData, {\n index: [ny, nx],\n x0: xa.c2p(cd0.x0 + nx * trace.dx),\n x1: xa.c2p(cd0.x0 + (nx + 1) * trace.dx),\n y0: py,\n y1: py,\n color: c,\n xVal: xVal,\n xLabelVal: xVal,\n yVal: yVal,\n yLabelVal: yVal,\n zLabelVal: zLabel,\n text: text,\n hovertemplateLabels: {\n zLabel: zLabel,\n colorLabel: colorstring,\n 'color[0]Label': c[0] + s[0],\n 'color[1]Label': c[1] + s[1],\n 'color[2]Label': c[2] + s[2],\n 'color[3]Label': c[3] + s[3]\n }\n })];\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n calc: require('./calc'),\n plot: require('./plot'),\n style: require('./style'),\n hoverPoints: require('./hover'),\n eventData: require('./event_data'),\n\n moduleType: 'trace',\n name: 'image',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['cartesian', 'svg', '2dMap', 'noSortingByValue'],\n animatable: false,\n meta: {\n description: [\n 'Display an image, i.e. data on a 2D regular raster.',\n 'By default, when an image is displayed in a subplot,',\n 'its y axis will be reversed (ie. `autorange: \\'reversed\\'`),',\n 'constrained to the domain (ie. `constrain: \\'domain\\'`)',\n 'and it will have the same scale as its x axis (ie. `scaleanchor: \\'x\\,`)',\n 'in order for pixels to be rendered as squares.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar xmlnsNamespaces = require('../../constants/xmlns_namespaces');\nvar constants = require('./constants');\nvar supportsPixelatedImage = require('../../lib/supports_pixelated_image');\nvar PIXELATED_IMAGE_STYLE = require('../../constants/pixelated_image').STYLE;\n\nmodule.exports = function plot(gd, plotinfo, cdimage, imageLayer) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n var supportsPixelated = !gd._context._exportedPlot && supportsPixelatedImage();\n\n Lib.makeTraceGroups(imageLayer, cdimage, 'im').each(function(cd) {\n var plotGroup = d3.select(this);\n var cd0 = cd[0];\n var trace = cd0.trace;\n var realImage = (\n ((trace.zsmooth === 'fast') || (trace.zsmooth === false && supportsPixelated)) &&\n !trace._hasZ && trace._hasSource && xa.type === 'linear' && ya.type === 'linear'\n );\n trace._realImage = realImage;\n\n var z = cd0.z;\n var x0 = cd0.x0;\n var y0 = cd0.y0;\n var w = cd0.w;\n var h = cd0.h;\n var dx = trace.dx;\n var dy = trace.dy;\n\n var left, right, temp, top, bottom, i;\n // in case of log of a negative\n i = 0;\n while(left === undefined && i < w) {\n left = xa.c2p(x0 + i * dx);\n i++;\n }\n i = w;\n while(right === undefined && i > 0) {\n right = xa.c2p(x0 + i * dx);\n i--;\n }\n i = 0;\n while(top === undefined && i < h) {\n top = ya.c2p(y0 + i * dy);\n i++;\n }\n i = h;\n while(bottom === undefined && i > 0) {\n bottom = ya.c2p(y0 + i * dy);\n i--;\n }\n\n if(right < left) {\n temp = right;\n right = left;\n left = temp;\n }\n\n if(bottom < top) {\n temp = top;\n top = bottom;\n bottom = temp;\n }\n\n // Reduce image size when zoomed in to save memory\n if(!realImage) {\n var extra = 0.5; // half the axis size\n left = Math.max(-extra * xa._length, left);\n right = Math.min((1 + extra) * xa._length, right);\n top = Math.max(-extra * ya._length, top);\n bottom = Math.min((1 + extra) * ya._length, bottom);\n }\n\n var imageWidth = Math.round(right - left);\n var imageHeight = Math.round(bottom - top);\n\n // if image is entirely off-screen, don't even draw it\n var isOffScreen = (imageWidth <= 0 || imageHeight <= 0);\n if(isOffScreen) {\n var noImage = plotGroup.selectAll('image').data([]);\n noImage.exit().remove();\n return;\n }\n\n // Create a new canvas and draw magnified pixels on it\n function drawMagnifiedPixelsOnCanvas(readPixel) {\n var canvas = document.createElement('canvas');\n canvas.width = imageWidth;\n canvas.height = imageHeight;\n var context = canvas.getContext('2d', {willReadFrequently: true});\n\n var ipx = function(i) {return Lib.constrain(Math.round(xa.c2p(x0 + i * dx) - left), 0, imageWidth);};\n var jpx = function(j) {return Lib.constrain(Math.round(ya.c2p(y0 + j * dy) - top), 0, imageHeight);};\n\n var cr = constants.colormodel[trace.colormodel];\n var colormodel = (cr.colormodel || trace.colormodel);\n var fmt = cr.fmt;\n var c;\n for(i = 0; i < cd0.w; i++) {\n var ipx0 = ipx(i); var ipx1 = ipx(i + 1);\n if(ipx1 === ipx0 || isNaN(ipx1) || isNaN(ipx0)) continue;\n for(var j = 0; j < cd0.h; j++) {\n var jpx0 = jpx(j); var jpx1 = jpx(j + 1);\n if(jpx1 === jpx0 || isNaN(jpx1) || isNaN(jpx0) || !readPixel(i, j)) continue;\n c = trace._scaler(readPixel(i, j));\n if(c) {\n context.fillStyle = colormodel + '(' + fmt(c).join(',') + ')';\n } else {\n // Return a transparent pixel\n context.fillStyle = 'rgba(0,0,0,0)';\n }\n context.fillRect(ipx0, jpx0, ipx1 - ipx0, jpx1 - jpx0);\n }\n }\n\n return canvas;\n }\n\n var image3 = plotGroup.selectAll('image')\n .data([cd]);\n\n image3.enter().append('svg:image').attr({\n xmlns: xmlnsNamespaces.svg,\n preserveAspectRatio: 'none'\n });\n\n image3.exit().remove();\n\n var style = (trace.zsmooth === false) ? PIXELATED_IMAGE_STYLE : '';\n\n if(realImage) {\n var xRange = Lib.simpleMap(xa.range, xa.r2l);\n var yRange = Lib.simpleMap(ya.range, ya.r2l);\n\n var flipX = xRange[1] < xRange[0];\n var flipY = yRange[1] > yRange[0];\n if(flipX || flipY) {\n var tx = left + imageWidth / 2;\n var ty = top + imageHeight / 2;\n style += 'transform:' +\n strTranslate(tx + 'px', ty + 'px') +\n 'scale(' + (flipX ? -1 : 1) + ',' + (flipY ? -1 : 1) + ')' +\n strTranslate(-tx + 'px', -ty + 'px') + ';';\n }\n }\n image3.attr('style', style);\n\n var p = new Promise(function(resolve) {\n if(trace._hasZ) {\n resolve();\n } else if(trace._hasSource) {\n // Check if canvas already exists and has the right data\n if(\n trace._canvas &&\n trace._canvas.el.width === w &&\n trace._canvas.el.height === h &&\n trace._canvas.source === trace.source\n ) {\n resolve();\n } else {\n // Create a canvas and transfer image onto it to access pixel information\n var canvas = document.createElement('canvas');\n canvas.width = w;\n canvas.height = h;\n var context = canvas.getContext('2d', {willReadFrequently: true});\n\n trace._image = trace._image || new Image();\n var image = trace._image;\n image.onload = function() {\n context.drawImage(image, 0, 0);\n trace._canvas = {\n el: canvas,\n source: trace.source\n };\n resolve();\n };\n image.setAttribute('src', trace.source);\n }\n }\n })\n .then(function() {\n var href, canvas;\n if(trace._hasZ) {\n canvas = drawMagnifiedPixelsOnCanvas(function(i, j) {\n var _z = z[j][i];\n if(Lib.isTypedArray(_z)) _z = Array.from(_z);\n return _z;\n });\n href = canvas.toDataURL('image/png');\n } else if(trace._hasSource) {\n if(realImage) {\n href = trace.source;\n } else {\n var context = trace._canvas.el.getContext('2d', {willReadFrequently: true});\n var data = context.getImageData(0, 0, w, h).data;\n canvas = drawMagnifiedPixelsOnCanvas(function(i, j) {\n var index = 4 * (j * w + i);\n return [\n data[index],\n data[index + 1],\n data[index + 2],\n data[index + 3]\n ];\n });\n href = canvas.toDataURL('image/png');\n }\n }\n\n image3.attr({\n 'xlink:href': href,\n height: imageHeight,\n width: imageWidth,\n x: left,\n y: top\n });\n });\n\n gd._promises.push(p);\n });\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nmodule.exports = function style(gd) {\n d3.select(gd).selectAll('.im image')\n .style('opacity', function(d) {\n return d[0].trace.opacity;\n });\n};\n","'use strict';\n\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar extendDeep = require('../../lib/extend').extendDeep;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar fontAttrs = require('../../plots/font_attributes');\nvar colorAttrs = require('../../components/color/attributes');\nvar domainAttrs = require('../../plots/domain').attributes;\nvar axesAttrs = require('../../plots/cartesian/layout_attributes');\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\nvar delta = require('../../constants/delta.js');\nvar descriptionOnlyNumbers = require('../../plots/cartesian/axis_format_attributes').descriptionOnlyNumbers;\n\nvar textFontAttrs = fontAttrs({\n editType: 'plot',\n colorEditType: 'plot'\n});\n\nvar gaugeBarAttrs = {\n color: {\n valType: 'color',\n editType: 'plot',\n description: [\n 'Sets the background color of the arc.'\n ].join(' ')\n },\n line: {\n color: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n editType: 'plot',\n description: [\n 'Sets the color of the line enclosing each sector.'\n ].join(' ')\n },\n width: {\n valType: 'number',\n min: 0,\n dflt: 0,\n editType: 'plot',\n description: [\n 'Sets the width (in px) of the line enclosing each sector.'\n ].join(' ')\n },\n editType: 'calc'\n },\n thickness: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n editType: 'plot',\n description: [\n 'Sets the thickness of the bar as a fraction of the total thickness of the gauge.'\n ].join(' ')\n },\n editType: 'calc'\n};\n\nvar rangeAttr = {\n valType: 'info_array',\n items: [\n {valType: 'number', editType: 'plot'},\n {valType: 'number', editType: 'plot'}\n ],\n editType: 'plot',\n description: [\n 'Sets the range of this axis.'\n // TODO: add support for other axis type\n // 'If the axis `type` is *log*, then you must take the log of your',\n // 'desired range (e.g. to set the range from 1 to 100,',\n // 'set the range from 0 to 2).',\n // 'If the axis `type` is *date*, it should be date strings,',\n // 'like date data, though Date objects and unix milliseconds',\n // 'will be accepted and converted to strings.',\n // 'If the axis `type` is *category*, it should be numbers,',\n // 'using the scale where each category is assigned a serial',\n // 'number from zero in the order it appears.'\n ].join(' ')\n};\n\nvar stepsAttrs = templatedArray('step', extendDeep({}, gaugeBarAttrs, {\n range: rangeAttr\n}));\n\nmodule.exports = {\n mode: {\n valType: 'flaglist',\n editType: 'calc',\n flags: ['number', 'delta', 'gauge'],\n dflt: 'number',\n description: [\n 'Determines how the value is displayed on the graph.',\n '`number` displays the value numerically in text.',\n '`delta` displays the difference to a reference value in text.',\n 'Finally, `gauge` displays the value graphically on an axis.',\n ].join(' ')\n },\n value: {\n valType: 'number',\n editType: 'calc',\n anim: true,\n description: [\n 'Sets the number to be displayed.'\n ].join(' ')\n },\n align: {\n valType: 'enumerated',\n values: ['left', 'center', 'right'],\n editType: 'plot',\n description: [\n 'Sets the horizontal alignment of the `text` within the box.',\n 'Note that this attribute has no effect if an angular gauge is displayed:',\n 'in this case, it is always centered'\n ].join(' ')\n },\n // position\n domain: domainAttrs({name: 'indicator', trace: true, editType: 'calc'}),\n\n title: {\n text: {\n valType: 'string',\n editType: 'plot',\n description: [\n 'Sets the title of this indicator.'\n ].join(' ')\n },\n align: {\n valType: 'enumerated',\n values: ['left', 'center', 'right'],\n editType: 'plot',\n description: [\n 'Sets the horizontal alignment of the title.',\n 'It defaults to `center` except for bullet charts',\n 'for which it defaults to right.'\n ].join(' ')\n },\n font: extendFlat({}, textFontAttrs, {\n description: [\n 'Set the font used to display the title'\n ].join(' ')\n }),\n editType: 'plot'\n },\n number: {\n valueformat: {\n valType: 'string',\n dflt: '',\n editType: 'plot',\n description: descriptionOnlyNumbers('value')\n },\n font: extendFlat({}, textFontAttrs, {\n description: [\n 'Set the font used to display main number'\n ].join(' ')\n }),\n prefix: {\n valType: 'string',\n dflt: '',\n editType: 'plot',\n description: [\n 'Sets a prefix appearing before the number.'\n ].join(' ')\n },\n suffix: {\n valType: 'string',\n dflt: '',\n editType: 'plot',\n description: [\n 'Sets a suffix appearing next to the number.'\n ].join(' ')\n },\n editType: 'plot'\n },\n delta: {\n reference: {\n valType: 'number',\n editType: 'calc',\n description: [\n 'Sets the reference value to compute the delta.',\n 'By default, it is set to the current value.'\n ].join(' ')\n },\n position: {\n valType: 'enumerated',\n values: ['top', 'bottom', 'left', 'right'],\n dflt: 'bottom',\n editType: 'plot',\n description: [\n 'Sets the position of delta with respect to the number.'\n ].join(' ')\n },\n relative: {\n valType: 'boolean',\n editType: 'plot',\n dflt: false,\n description: [\n 'Show relative change'\n ].join(' ')\n },\n valueformat: {\n valType: 'string',\n editType: 'plot',\n description: descriptionOnlyNumbers('value')\n },\n increasing: {\n symbol: {\n valType: 'string',\n dflt: delta.INCREASING.SYMBOL,\n editType: 'plot',\n description: [\n 'Sets the symbol to display for increasing value'\n ].join(' ')\n },\n color: {\n valType: 'color',\n dflt: delta.INCREASING.COLOR,\n editType: 'plot',\n description: [\n 'Sets the color for increasing value.'\n ].join(' ')\n },\n // TODO: add attribute to show sign\n editType: 'plot'\n },\n decreasing: {\n symbol: {\n valType: 'string',\n dflt: delta.DECREASING.SYMBOL,\n editType: 'plot',\n description: [\n 'Sets the symbol to display for increasing value'\n ].join(' ')\n },\n color: {\n valType: 'color',\n dflt: delta.DECREASING.COLOR,\n editType: 'plot',\n description: [\n 'Sets the color for increasing value.'\n ].join(' ')\n },\n // TODO: add attribute to hide sign\n editType: 'plot'\n },\n font: extendFlat({}, textFontAttrs, {\n description: [\n 'Set the font used to display the delta'\n ].join(' ')\n }),\n prefix: {\n valType: 'string',\n dflt: '',\n editType: 'plot',\n description: [\n 'Sets a prefix appearing before the delta.'\n ].join(' ')\n },\n suffix: {\n valType: 'string',\n dflt: '',\n editType: 'plot',\n description: [\n 'Sets a suffix appearing next to the delta.'\n ].join(' ')\n },\n editType: 'calc'\n },\n gauge: {\n shape: {\n valType: 'enumerated',\n editType: 'plot',\n dflt: 'angular',\n values: ['angular', 'bullet'],\n description: [\n 'Set the shape of the gauge'\n ].join(' ')\n },\n bar: extendDeep({}, gaugeBarAttrs, {\n color: {dflt: 'green'},\n description: [\n 'Set the appearance of the gauge\\'s value'\n ].join(' ')\n }),\n // Background of the gauge\n bgcolor: {\n valType: 'color',\n editType: 'plot',\n description: 'Sets the gauge background color.'\n },\n bordercolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n editType: 'plot',\n description: 'Sets the color of the border enclosing the gauge.'\n },\n borderwidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n editType: 'plot',\n description: 'Sets the width (in px) of the border enclosing the gauge.'\n },\n axis: overrideAll({\n range: rangeAttr,\n visible: extendFlat({}, axesAttrs.visible, {\n dflt: true\n }),\n // tick and title properties named and function exactly as in axes\n tickmode: axesAttrs.minor.tickmode,\n nticks: axesAttrs.nticks,\n tick0: axesAttrs.tick0,\n dtick: axesAttrs.dtick,\n tickvals: axesAttrs.tickvals,\n ticktext: axesAttrs.ticktext,\n ticks: extendFlat({}, axesAttrs.ticks, {dflt: 'outside'}),\n ticklen: axesAttrs.ticklen,\n tickwidth: axesAttrs.tickwidth,\n tickcolor: axesAttrs.tickcolor,\n ticklabelstep: axesAttrs.ticklabelstep,\n showticklabels: axesAttrs.showticklabels,\n labelalias: axesAttrs.labelalias,\n tickfont: fontAttrs({\n description: 'Sets the color bar\\'s tick label font'\n }),\n tickangle: axesAttrs.tickangle,\n tickformat: axesAttrs.tickformat,\n tickformatstops: axesAttrs.tickformatstops,\n tickprefix: axesAttrs.tickprefix,\n showtickprefix: axesAttrs.showtickprefix,\n ticksuffix: axesAttrs.ticksuffix,\n showticksuffix: axesAttrs.showticksuffix,\n separatethousands: axesAttrs.separatethousands,\n exponentformat: axesAttrs.exponentformat,\n minexponent: axesAttrs.minexponent,\n showexponent: axesAttrs.showexponent,\n editType: 'plot'\n }, 'plot'),\n // Steps (or ranges) and thresholds\n steps: stepsAttrs,\n threshold: {\n line: {\n color: extendFlat({}, gaugeBarAttrs.line.color, {\n description: [\n 'Sets the color of the threshold line.'\n ].join(' ')\n }),\n width: extendFlat({}, gaugeBarAttrs.line.width, {\n dflt: 1,\n description: [\n 'Sets the width (in px) of the threshold line.'\n ].join(' ')\n }),\n editType: 'plot'\n },\n thickness: extendFlat({}, gaugeBarAttrs.thickness, {\n dflt: 0.85,\n description: [\n 'Sets the thickness of the threshold line as a fraction of the thickness of the gauge.'\n ].join(' ')\n }),\n value: {\n valType: 'number',\n editType: 'calc',\n dflt: false,\n description: [\n 'Sets a treshold value drawn as a line.'\n ].join(' ')\n },\n editType: 'plot'\n },\n description: 'The gauge of the Indicator plot.',\n editType: 'plot'\n // TODO: in future version, add marker: (bar|needle)\n }\n};\n","'use strict';\n\nvar plots = require('../../plots/plots');\n\nexports.name = 'indicator';\n\nexports.plot = function(gd, traces, transitionOpts, makeOnCompleteCallback) {\n plots.plotBasePlot(exports.name, gd, traces, transitionOpts, makeOnCompleteCallback);\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n plots.cleanBasePlot(exports.name, newFullData, newFullLayout, oldFullData, oldFullLayout);\n};\n","'use strict';\n\n// var Lib = require('../../lib');\n\nfunction calc(gd, trace) {\n var cd = [];\n\n var lastReading = trace.value;\n if(!(typeof trace._lastValue === 'number')) trace._lastValue = trace.value;\n var secondLastReading = trace._lastValue;\n var deltaRef = secondLastReading;\n if(trace._hasDelta && typeof trace.delta.reference === 'number') {\n deltaRef = trace.delta.reference;\n }\n cd[0] = {\n y: lastReading,\n lastY: secondLastReading,\n\n delta: lastReading - deltaRef,\n relativeDelta: (lastReading - deltaRef) / deltaRef,\n };\n return cd;\n}\n\nmodule.exports = {\n calc: calc\n};\n","'use strict';\n\nmodule.exports = {\n // Defaults for delta\n defaultNumberFontSize: 80,\n bulletNumberDomainSize: 0.25,\n bulletPadding: 0.025,\n innerRadius: 0.75,\n valueThickness: 0.5, // thickness of value bars relative to full thickness,\n titlePadding: 5,\n horizontalPadding: 10\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar attributes = require('./attributes');\nvar handleDomainDefaults = require('../../plots/domain').defaults;\nvar Template = require('../../plot_api/plot_template');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\nvar cn = require('./constants.js');\n\nvar handleTickValueDefaults = require('../../plots/cartesian/tick_value_defaults');\nvar handleTickMarkDefaults = require('../../plots/cartesian/tick_mark_defaults');\nvar handleTickLabelDefaults = require('../../plots/cartesian/tick_label_defaults');\nvar handlePrefixSuffixDefaults = require('../../plots/cartesian/prefix_suffix_defaults');\n\nfunction supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n handleDomainDefaults(traceOut, layout, coerce);\n\n // Mode\n coerce('mode');\n traceOut._hasNumber = traceOut.mode.indexOf('number') !== -1;\n traceOut._hasDelta = traceOut.mode.indexOf('delta') !== -1;\n traceOut._hasGauge = traceOut.mode.indexOf('gauge') !== -1;\n\n var value = coerce('value');\n traceOut._range = [0, (typeof value === 'number' ? 1.5 * value : 1)];\n\n // Number attributes\n var auto = new Array(2);\n var bignumberFontSize;\n if(traceOut._hasNumber) {\n coerce('number.valueformat');\n var numberFontDflt = Lib.extendFlat({}, layout.font);\n numberFontDflt.size = undefined;\n Lib.coerceFont(coerce, 'number.font', numberFontDflt);\n if(traceOut.number.font.size === undefined) {\n traceOut.number.font.size = cn.defaultNumberFontSize;\n auto[0] = true;\n }\n coerce('number.prefix');\n coerce('number.suffix');\n bignumberFontSize = traceOut.number.font.size;\n }\n\n // delta attributes\n var deltaFontSize;\n if(traceOut._hasDelta) {\n var deltaFontDflt = Lib.extendFlat({}, layout.font);\n deltaFontDflt.size = undefined;\n Lib.coerceFont(coerce, 'delta.font', deltaFontDflt);\n if(traceOut.delta.font.size === undefined) {\n traceOut.delta.font.size = (traceOut._hasNumber ? 0.5 : 1) * (bignumberFontSize || cn.defaultNumberFontSize);\n auto[1] = true;\n }\n coerce('delta.reference', traceOut.value);\n coerce('delta.relative');\n coerce('delta.valueformat', traceOut.delta.relative ? '2%' : '');\n coerce('delta.increasing.symbol');\n coerce('delta.increasing.color');\n coerce('delta.decreasing.symbol');\n coerce('delta.decreasing.color');\n coerce('delta.position');\n coerce('delta.prefix');\n coerce('delta.suffix');\n deltaFontSize = traceOut.delta.font.size;\n }\n traceOut._scaleNumbers = (!traceOut._hasNumber || auto[0]) && (!traceOut._hasDelta || auto[1]) || false;\n\n // Title attributes\n var titleFontDflt = Lib.extendFlat({}, layout.font);\n titleFontDflt.size = 0.25 * (bignumberFontSize || deltaFontSize || cn.defaultNumberFontSize);\n Lib.coerceFont(coerce, 'title.font', titleFontDflt);\n coerce('title.text');\n\n // Gauge attributes\n var gaugeIn, gaugeOut, axisIn, axisOut;\n function coerceGauge(attr, dflt) {\n return Lib.coerce(gaugeIn, gaugeOut, attributes.gauge, attr, dflt);\n }\n function coerceGaugeAxis(attr, dflt) {\n return Lib.coerce(axisIn, axisOut, attributes.gauge.axis, attr, dflt);\n }\n\n if(traceOut._hasGauge) {\n gaugeIn = traceIn.gauge;\n if(!gaugeIn) gaugeIn = {};\n gaugeOut = Template.newContainer(traceOut, 'gauge');\n coerceGauge('shape');\n var isBullet = traceOut._isBullet = traceOut.gauge.shape === 'bullet';\n if(!isBullet) {\n coerce('title.align', 'center');\n }\n var isAngular = traceOut._isAngular = traceOut.gauge.shape === 'angular';\n if(!isAngular) {\n coerce('align', 'center');\n }\n\n // gauge background\n coerceGauge('bgcolor', layout.paper_bgcolor);\n coerceGauge('borderwidth');\n coerceGauge('bordercolor');\n\n // gauge bar indicator\n coerceGauge('bar.color');\n coerceGauge('bar.line.color');\n coerceGauge('bar.line.width');\n var defaultBarThickness = cn.valueThickness * (traceOut.gauge.shape === 'bullet' ? 0.5 : 1);\n coerceGauge('bar.thickness', defaultBarThickness);\n\n // Gauge steps\n handleArrayContainerDefaults(gaugeIn, gaugeOut, {\n name: 'steps',\n handleItemDefaults: stepDefaults\n });\n\n // Gauge threshold\n coerceGauge('threshold.value');\n coerceGauge('threshold.thickness');\n coerceGauge('threshold.line.width');\n coerceGauge('threshold.line.color');\n\n // Gauge axis\n axisIn = {};\n if(gaugeIn) axisIn = gaugeIn.axis || {};\n axisOut = Template.newContainer(gaugeOut, 'axis');\n coerceGaugeAxis('visible');\n traceOut._range = coerceGaugeAxis('range', traceOut._range);\n\n var opts = {\n font: layout.font,\n noAutotickangles: true,\n outerTicks: true,\n noTicklabelshift: true,\n noTicklabelstandoff: true\n };\n handleTickValueDefaults(axisIn, axisOut, coerceGaugeAxis, 'linear');\n handlePrefixSuffixDefaults(axisIn, axisOut, coerceGaugeAxis, 'linear', opts);\n handleTickLabelDefaults(axisIn, axisOut, coerceGaugeAxis, 'linear', opts);\n handleTickMarkDefaults(axisIn, axisOut, coerceGaugeAxis, opts);\n } else {\n coerce('title.align', 'center');\n coerce('align', 'center');\n traceOut._isAngular = traceOut._isBullet = false;\n }\n\n // disable 1D transforms\n traceOut._length = null;\n}\n\nfunction stepDefaults(stepIn, stepOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(stepIn, stepOut, attributes.gauge.steps, attr, dflt);\n }\n\n coerce('color');\n coerce('line.color');\n coerce('line.width');\n coerce('range');\n coerce('thickness');\n}\n\nmodule.exports = {\n supplyDefaults: supplyDefaults\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'indicator',\n basePlotModule: require('./base_plot'),\n categories: ['svg', 'noOpacity', 'noHover'],\n animatable: true,\n\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults').supplyDefaults,\n\n calc: require('./calc').calc,\n\n plot: require('./plot'),\n\n meta: {\n description: [\n 'An indicator is used to visualize a single `value` along with some',\n 'contextual information such as `steps` or a `threshold`, using a',\n 'combination of three visual elements: a number, a delta, and/or a gauge.',\n 'Deltas are taken with respect to a `reference`.',\n 'Gauges can be either angular or bullet (aka linear) gauges.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar interpolate = require('d3-interpolate').interpolate;\nvar interpolateNumber = require('d3-interpolate').interpolateNumber;\n\nvar Lib = require('../../lib');\nvar strScale = Lib.strScale;\nvar strTranslate = Lib.strTranslate;\nvar rad2deg = Lib.rad2deg;\nvar MID_SHIFT = require('../../constants/alignment').MID_SHIFT;\nvar Drawing = require('../../components/drawing');\nvar cn = require('./constants');\nvar svgTextUtils = require('../../lib/svg_text_utils');\n\nvar Axes = require('../../plots/cartesian/axes');\nvar handleAxisDefaults = require('../../plots/cartesian/axis_defaults');\nvar handleAxisPositionDefaults = require('../../plots/cartesian/position_defaults');\nvar axisLayoutAttrs = require('../../plots/cartesian/layout_attributes');\n\nvar Color = require('../../components/color');\nvar anchor = {\n left: 'start',\n center: 'middle',\n right: 'end'\n};\nvar position = {\n left: 0,\n center: 0.5,\n right: 1\n};\n\nvar SI_PREFIX = /[yzafpnµmkMGTPEZY]/;\n\nfunction hasTransition(transitionOpts) {\n // If transition config is provided, then it is only a partial replot and traces not\n // updated are removed.\n return transitionOpts && transitionOpts.duration > 0;\n}\n\nmodule.exports = function plot(gd, cdModule, transitionOpts, makeOnCompleteCallback) {\n var fullLayout = gd._fullLayout;\n var onComplete;\n\n if(hasTransition(transitionOpts)) {\n if(makeOnCompleteCallback) {\n // If it was passed a callback to register completion, make a callback. If\n // this is created, then it must be executed on completion, otherwise the\n // pos-transition redraw will not execute:\n onComplete = makeOnCompleteCallback();\n }\n }\n\n Lib.makeTraceGroups(fullLayout._indicatorlayer, cdModule, 'trace').each(function(cd) {\n var cd0 = cd[0];\n var trace = cd0.trace;\n\n var plotGroup = d3.select(this);\n\n // Elements in trace\n var hasGauge = trace._hasGauge;\n var isAngular = trace._isAngular;\n var isBullet = trace._isBullet;\n\n // Domain size\n var domain = trace.domain;\n var size = {\n w: fullLayout._size.w * (domain.x[1] - domain.x[0]),\n h: fullLayout._size.h * (domain.y[1] - domain.y[0]),\n l: fullLayout._size.l + fullLayout._size.w * domain.x[0],\n r: fullLayout._size.r + fullLayout._size.w * (1 - domain.x[1]),\n t: fullLayout._size.t + fullLayout._size.h * (1 - domain.y[1]),\n b: fullLayout._size.b + fullLayout._size.h * (domain.y[0])\n };\n var centerX = size.l + size.w / 2;\n var centerY = size.t + size.h / 2;\n\n // Angular gauge size\n var radius = Math.min(size.w / 2, size.h); // fill domain\n var innerRadius = cn.innerRadius * radius;\n\n // Position numbers based on mode and set the scaling logic\n var numbersX, numbersY, numbersScaler;\n var numbersAlign = trace.align || 'center';\n\n numbersY = centerY;\n if(!hasGauge) {\n numbersX = size.l + position[numbersAlign] * size.w;\n numbersScaler = function(el) {\n return fitTextInsideBox(el, size.w, size.h);\n };\n } else {\n if(isAngular) {\n numbersX = centerX;\n numbersY = centerY + radius / 2;\n numbersScaler = function(el) {\n return fitTextInsideCircle(el, 0.9 * innerRadius);\n };\n }\n if(isBullet) {\n var padding = cn.bulletPadding;\n var p = (1 - cn.bulletNumberDomainSize) + padding;\n numbersX = size.l + (p + (1 - p) * position[numbersAlign]) * size.w;\n numbersScaler = function(el) {\n return fitTextInsideBox(el, (cn.bulletNumberDomainSize - padding) * size.w, size.h);\n };\n }\n }\n\n // Draw numbers\n drawNumbers(gd, plotGroup, cd, {\n numbersX: numbersX,\n numbersY: numbersY,\n numbersScaler: numbersScaler,\n transitionOpts: transitionOpts,\n onComplete: onComplete\n });\n\n // Reexpress our gauge background attributes for drawing\n var gaugeBg, gaugeOutline;\n if(hasGauge) {\n gaugeBg = {\n range: trace.gauge.axis.range,\n color: trace.gauge.bgcolor,\n line: {\n color: trace.gauge.bordercolor,\n width: 0\n },\n thickness: 1\n };\n\n gaugeOutline = {\n range: trace.gauge.axis.range,\n color: 'rgba(0, 0, 0, 0)',\n line: {\n color: trace.gauge.bordercolor,\n width: trace.gauge.borderwidth\n },\n thickness: 1\n };\n }\n\n // Prepare angular gauge layers\n var angularGauge = plotGroup.selectAll('g.angular').data(isAngular ? cd : []);\n angularGauge.exit().remove();\n var angularaxisLayer = plotGroup.selectAll('g.angularaxis').data(isAngular ? cd : []);\n angularaxisLayer.exit().remove();\n\n if(isAngular) {\n drawAngularGauge(gd, plotGroup, cd, {\n radius: radius,\n innerRadius: innerRadius,\n\n gauge: angularGauge,\n layer: angularaxisLayer,\n size: size,\n gaugeBg: gaugeBg,\n gaugeOutline: gaugeOutline,\n transitionOpts: transitionOpts,\n onComplete: onComplete\n });\n }\n\n // Prepare bullet layers\n var bulletGauge = plotGroup.selectAll('g.bullet').data(isBullet ? cd : []);\n bulletGauge.exit().remove();\n var bulletaxisLayer = plotGroup.selectAll('g.bulletaxis').data(isBullet ? cd : []);\n bulletaxisLayer.exit().remove();\n\n if(isBullet) {\n drawBulletGauge(gd, plotGroup, cd, {\n gauge: bulletGauge,\n layer: bulletaxisLayer,\n size: size,\n gaugeBg: gaugeBg,\n gaugeOutline: gaugeOutline,\n transitionOpts: transitionOpts,\n onComplete: onComplete\n });\n }\n\n // title\n var title = plotGroup.selectAll('text.title').data(cd);\n title.exit().remove();\n title.enter().append('text').classed('title', true);\n title\n .attr('text-anchor', function() {\n return isBullet ? anchor.right : anchor[trace.title.align];\n })\n .text(trace.title.text)\n .call(Drawing.font, trace.title.font)\n .call(svgTextUtils.convertToTspans, gd);\n\n // Position title\n title.attr('transform', function() {\n var titleX = size.l + size.w * position[trace.title.align];\n var titleY;\n var titlePadding = cn.titlePadding;\n var titlebBox = Drawing.bBox(title.node());\n if(hasGauge) {\n if(isAngular) {\n // position above axis ticks/labels\n if(trace.gauge.axis.visible) {\n var bBox = Drawing.bBox(angularaxisLayer.node());\n titleY = (bBox.top - titlePadding) - titlebBox.bottom;\n } else {\n titleY = size.t + size.h / 2 - radius / 2 - titlebBox.bottom - titlePadding;\n }\n }\n if(isBullet) {\n // position outside domain\n titleY = numbersY - (titlebBox.top + titlebBox.bottom) / 2;\n titleX = size.l - cn.bulletPadding * size.w; // Outside domain, on the left\n }\n } else {\n // position above numbers\n titleY = (trace._numbersTop - titlePadding) - titlebBox.bottom;\n }\n return strTranslate(titleX, titleY);\n });\n });\n};\n\nfunction drawBulletGauge(gd, plotGroup, cd, opts) {\n var trace = cd[0].trace;\n\n var bullet = opts.gauge;\n var axisLayer = opts.layer;\n var gaugeBg = opts.gaugeBg;\n var gaugeOutline = opts.gaugeOutline;\n var size = opts.size;\n var domain = trace.domain;\n\n var transitionOpts = opts.transitionOpts;\n var onComplete = opts.onComplete;\n\n // preparing axis\n var ax, vals, transFn, tickSign, shift;\n\n // Enter bullet, axis\n bullet.enter().append('g').classed('bullet', true);\n bullet.attr('transform', strTranslate(size.l, size.t));\n\n axisLayer.enter().append('g')\n .classed('bulletaxis', true)\n .classed('crisp', true);\n axisLayer.selectAll('g.' + 'xbulletaxis' + 'tick,path,text').remove();\n\n // Draw bullet\n var bulletHeight = size.h; // use all vertical domain\n var innerBulletHeight = trace.gauge.bar.thickness * bulletHeight;\n var bulletLeft = domain.x[0];\n var bulletRight = domain.x[0] + (domain.x[1] - domain.x[0]) * ((trace._hasNumber || trace._hasDelta) ? (1 - cn.bulletNumberDomainSize) : 1);\n\n ax = mockAxis(gd, trace.gauge.axis);\n ax._id = 'xbulletaxis';\n ax.domain = [bulletLeft, bulletRight];\n ax.setScale();\n\n vals = Axes.calcTicks(ax);\n transFn = Axes.makeTransTickFn(ax);\n tickSign = Axes.getTickSigns(ax)[2];\n\n shift = size.t + size.h;\n if(ax.visible) {\n Axes.drawTicks(gd, ax, {\n vals: ax.ticks === 'inside' ? Axes.clipEnds(ax, vals) : vals,\n layer: axisLayer,\n path: Axes.makeTickPath(ax, shift, tickSign),\n transFn: transFn\n });\n\n Axes.drawLabels(gd, ax, {\n vals: vals,\n layer: axisLayer,\n transFn: transFn,\n labelFns: Axes.makeLabelFns(ax, shift)\n });\n }\n\n function drawRect(s) {\n s\n .attr('width', function(d) { return Math.max(0, ax.c2p(d.range[1]) - ax.c2p(d.range[0]));})\n .attr('x', function(d) { return ax.c2p(d.range[0]);})\n .attr('y', function(d) { return 0.5 * (1 - d.thickness) * bulletHeight;})\n .attr('height', function(d) { return d.thickness * bulletHeight; });\n }\n\n // Draw bullet background, steps\n var boxes = [gaugeBg].concat(trace.gauge.steps);\n var bgBullet = bullet.selectAll('g.bg-bullet').data(boxes);\n bgBullet.enter().append('g').classed('bg-bullet', true).append('rect');\n bgBullet.select('rect')\n .call(drawRect)\n .call(styleShape);\n bgBullet.exit().remove();\n\n // Draw value bar with transitions\n var fgBullet = bullet.selectAll('g.value-bullet').data([trace.gauge.bar]);\n fgBullet.enter().append('g').classed('value-bullet', true).append('rect');\n fgBullet.select('rect')\n .attr('height', innerBulletHeight)\n .attr('y', (bulletHeight - innerBulletHeight) / 2)\n .call(styleShape);\n if(hasTransition(transitionOpts)) {\n fgBullet.select('rect')\n .transition()\n .duration(transitionOpts.duration)\n .ease(transitionOpts.easing)\n .each('end', function() { onComplete && onComplete(); })\n .each('interrupt', function() { onComplete && onComplete(); })\n .attr('width', Math.max(0, ax.c2p(Math.min(trace.gauge.axis.range[1], cd[0].y))));\n } else {\n fgBullet.select('rect')\n .attr('width', typeof cd[0].y === 'number' ?\n Math.max(0, ax.c2p(Math.min(trace.gauge.axis.range[1], cd[0].y))) :\n 0);\n }\n fgBullet.exit().remove();\n\n var data = cd.filter(function() {return trace.gauge.threshold.value || trace.gauge.threshold.value === 0;});\n var threshold = bullet.selectAll('g.threshold-bullet').data(data);\n threshold.enter().append('g').classed('threshold-bullet', true).append('line');\n threshold.select('line')\n .attr('x1', ax.c2p(trace.gauge.threshold.value))\n .attr('x2', ax.c2p(trace.gauge.threshold.value))\n .attr('y1', (1 - trace.gauge.threshold.thickness) / 2 * bulletHeight)\n .attr('y2', (1 - (1 - trace.gauge.threshold.thickness) / 2) * bulletHeight)\n .call(Color.stroke, trace.gauge.threshold.line.color)\n .style('stroke-width', trace.gauge.threshold.line.width);\n threshold.exit().remove();\n\n var bulletOutline = bullet.selectAll('g.gauge-outline').data([gaugeOutline]);\n bulletOutline.enter().append('g').classed('gauge-outline', true).append('rect');\n bulletOutline.select('rect')\n .call(drawRect)\n .call(styleShape);\n bulletOutline.exit().remove();\n}\n\nfunction drawAngularGauge(gd, plotGroup, cd, opts) {\n var trace = cd[0].trace;\n\n var size = opts.size;\n var radius = opts.radius;\n var innerRadius = opts.innerRadius;\n var gaugeBg = opts.gaugeBg;\n var gaugeOutline = opts.gaugeOutline;\n var gaugePosition = [size.l + size.w / 2, size.t + size.h / 2 + radius / 2];\n var gauge = opts.gauge;\n var axisLayer = opts.layer;\n\n var transitionOpts = opts.transitionOpts;\n var onComplete = opts.onComplete;\n\n // circular gauge\n var theta = Math.PI / 2;\n function valueToAngle(v) {\n var min = trace.gauge.axis.range[0];\n var max = trace.gauge.axis.range[1];\n var angle = (v - min) / (max - min) * Math.PI - theta;\n if(angle < -theta) return -theta;\n if(angle > theta) return theta;\n return angle;\n }\n\n function arcPathGenerator(size) {\n return d3.svg.arc()\n .innerRadius((innerRadius + radius) / 2 - size / 2 * (radius - innerRadius))\n .outerRadius((innerRadius + radius) / 2 + size / 2 * (radius - innerRadius))\n .startAngle(-theta);\n }\n\n function drawArc(p) {\n p\n .attr('d', function(d) {\n return arcPathGenerator(d.thickness)\n .startAngle(valueToAngle(d.range[0]))\n .endAngle(valueToAngle(d.range[1]))();\n });\n }\n\n // preparing axis\n var ax, vals, transFn, tickSign;\n\n // Enter gauge and axis\n gauge.enter().append('g').classed('angular', true);\n gauge.attr('transform', strTranslate(gaugePosition[0], gaugePosition[1]));\n\n axisLayer.enter().append('g')\n .classed('angularaxis', true)\n .classed('crisp', true);\n axisLayer.selectAll('g.' + 'xangularaxis' + 'tick,path,text').remove();\n\n ax = mockAxis(gd, trace.gauge.axis);\n ax.type = 'linear';\n ax.range = trace.gauge.axis.range;\n ax._id = 'xangularaxis'; // or 'y', but I don't think this makes a difference here\n ax.ticklabeloverflow = 'allow';\n ax.setScale();\n\n // 't'ick to 'g'eometric radians is used all over the place here\n var t2g = function(d) {\n return (ax.range[0] - d.x) / (ax.range[1] - ax.range[0]) * Math.PI + Math.PI;\n };\n\n var labelFns = {};\n var out = Axes.makeLabelFns(ax, 0);\n var labelStandoff = out.labelStandoff;\n labelFns.xFn = function(d) {\n var rad = t2g(d);\n return Math.cos(rad) * labelStandoff;\n };\n labelFns.yFn = function(d) {\n var rad = t2g(d);\n var ff = Math.sin(rad) > 0 ? 0.2 : 1;\n return -Math.sin(rad) * (labelStandoff + d.fontSize * ff) +\n Math.abs(Math.cos(rad)) * (d.fontSize * MID_SHIFT);\n };\n labelFns.anchorFn = function(d) {\n var rad = t2g(d);\n var cos = Math.cos(rad);\n return Math.abs(cos) < 0.1 ?\n 'middle' :\n (cos > 0 ? 'start' : 'end');\n };\n labelFns.heightFn = function(d, a, h) {\n var rad = t2g(d);\n return -0.5 * (1 + Math.sin(rad)) * h;\n };\n var _transFn = function(rad) {\n return strTranslate(\n gaugePosition[0] + radius * Math.cos(rad),\n gaugePosition[1] - radius * Math.sin(rad)\n );\n };\n transFn = function(d) {\n return _transFn(t2g(d));\n };\n var transFn2 = function(d) {\n var rad = t2g(d);\n return _transFn(rad) + 'rotate(' + -rad2deg(rad) + ')';\n };\n vals = Axes.calcTicks(ax);\n tickSign = Axes.getTickSigns(ax)[2];\n if(ax.visible) {\n tickSign = ax.ticks === 'inside' ? -1 : 1;\n var pad = (ax.linewidth || 1) / 2;\n Axes.drawTicks(gd, ax, {\n vals: vals,\n layer: axisLayer,\n path: 'M' + (tickSign * pad) + ',0h' + (tickSign * ax.ticklen),\n transFn: transFn2\n });\n Axes.drawLabels(gd, ax, {\n vals: vals,\n layer: axisLayer,\n transFn: transFn,\n labelFns: labelFns\n });\n }\n\n // Draw background + steps\n var arcs = [gaugeBg].concat(trace.gauge.steps);\n var bgArc = gauge.selectAll('g.bg-arc').data(arcs);\n bgArc.enter().append('g').classed('bg-arc', true).append('path');\n bgArc.select('path').call(drawArc).call(styleShape);\n bgArc.exit().remove();\n\n // Draw foreground with transition\n var valueArcPathGenerator = arcPathGenerator(trace.gauge.bar.thickness);\n var valueArc = gauge.selectAll('g.value-arc').data([trace.gauge.bar]);\n valueArc.enter().append('g').classed('value-arc', true).append('path');\n var valueArcPath = valueArc.select('path');\n if(hasTransition(transitionOpts)) {\n valueArcPath\n .transition()\n .duration(transitionOpts.duration)\n .ease(transitionOpts.easing)\n .each('end', function() { onComplete && onComplete(); })\n .each('interrupt', function() { onComplete && onComplete(); })\n .attrTween('d', arcTween(valueArcPathGenerator, valueToAngle(cd[0].lastY), valueToAngle(cd[0].y)));\n trace._lastValue = cd[0].y;\n } else {\n valueArcPath.attr('d', typeof cd[0].y === 'number' ?\n valueArcPathGenerator.endAngle(valueToAngle(cd[0].y)) :\n 'M0,0Z');\n }\n valueArcPath.call(styleShape);\n valueArc.exit().remove();\n\n // Draw threshold\n arcs = [];\n var v = trace.gauge.threshold.value;\n if(v || v === 0) {\n arcs.push({\n range: [v, v],\n color: trace.gauge.threshold.color,\n line: {\n color: trace.gauge.threshold.line.color,\n width: trace.gauge.threshold.line.width\n },\n thickness: trace.gauge.threshold.thickness\n });\n }\n var thresholdArc = gauge.selectAll('g.threshold-arc').data(arcs);\n thresholdArc.enter().append('g').classed('threshold-arc', true).append('path');\n thresholdArc.select('path').call(drawArc).call(styleShape);\n thresholdArc.exit().remove();\n\n // Draw border last\n var gaugeBorder = gauge.selectAll('g.gauge-outline').data([gaugeOutline]);\n gaugeBorder.enter().append('g').classed('gauge-outline', true).append('path');\n gaugeBorder.select('path').call(drawArc).call(styleShape);\n gaugeBorder.exit().remove();\n}\n\nfunction drawNumbers(gd, plotGroup, cd, opts) {\n var trace = cd[0].trace;\n\n var numbersX = opts.numbersX;\n var numbersY = opts.numbersY;\n var numbersAlign = trace.align || 'center';\n var numbersAnchor = anchor[numbersAlign];\n\n var transitionOpts = opts.transitionOpts;\n var onComplete = opts.onComplete;\n\n var numbers = Lib.ensureSingle(plotGroup, 'g', 'numbers');\n var bignumberbBox, deltabBox;\n var numbersbBox;\n\n var data = [];\n if(trace._hasNumber) data.push('number');\n if(trace._hasDelta) {\n data.push('delta');\n if(trace.delta.position === 'left') data.reverse();\n }\n var sel = numbers.selectAll('text').data(data);\n sel.enter().append('text');\n sel\n .attr('text-anchor', function() {return numbersAnchor;})\n .attr('class', function(d) { return d;})\n .attr('x', null)\n .attr('y', null)\n .attr('dx', null)\n .attr('dy', null);\n sel.exit().remove();\n\n // Function to override the number formatting used during transitions\n function transitionFormat(valueformat, fmt, from, to) {\n // For now, do not display SI prefix if start and end value do not have any\n if(valueformat.match('s') && // If using SI prefix\n (from >= 0 !== to >= 0) && // If sign change\n (!fmt(from).slice(-1).match(SI_PREFIX) && !fmt(to).slice(-1).match(SI_PREFIX)) // Has no SI prefix\n ) {\n var transitionValueFormat = valueformat.slice().replace('s', 'f').replace(/\\d+/, function(m) { return parseInt(m) - 1;});\n var transitionAx = mockAxis(gd, {tickformat: transitionValueFormat});\n return function(v) {\n // Switch to fixed precision if number is smaller than one\n if(Math.abs(v) < 1) return Axes.tickText(transitionAx, v).text;\n return fmt(v);\n };\n } else {\n return fmt;\n }\n }\n\n function drawBignumber() {\n var bignumberAx = mockAxis(gd, {tickformat: trace.number.valueformat}, trace._range);\n bignumberAx.setScale();\n Axes.prepTicks(bignumberAx);\n\n var bignumberFmt = function(v) { return Axes.tickText(bignumberAx, v).text;};\n var bignumberSuffix = trace.number.suffix;\n var bignumberPrefix = trace.number.prefix;\n\n var number = numbers.select('text.number');\n\n function writeNumber() {\n var txt = typeof cd[0].y === 'number' ?\n bignumberPrefix + bignumberFmt(cd[0].y) + bignumberSuffix :\n '-';\n number.text(txt)\n .call(Drawing.font, trace.number.font)\n .call(svgTextUtils.convertToTspans, gd);\n }\n\n if(hasTransition(transitionOpts)) {\n number\n .transition()\n .duration(transitionOpts.duration)\n .ease(transitionOpts.easing)\n .each('end', function() { writeNumber(); onComplete && onComplete(); })\n .each('interrupt', function() { writeNumber(); onComplete && onComplete(); })\n .attrTween('text', function() {\n var that = d3.select(this);\n var interpolator = interpolateNumber(cd[0].lastY, cd[0].y);\n trace._lastValue = cd[0].y;\n\n var transitionFmt = transitionFormat(trace.number.valueformat, bignumberFmt, cd[0].lastY, cd[0].y);\n return function(t) {\n that.text(bignumberPrefix + transitionFmt(interpolator(t)) + bignumberSuffix);\n };\n });\n } else {\n writeNumber();\n }\n\n bignumberbBox = measureText(bignumberPrefix + bignumberFmt(cd[0].y) + bignumberSuffix, trace.number.font, numbersAnchor, gd);\n return number;\n }\n\n function drawDelta() {\n var deltaAx = mockAxis(gd, {tickformat: trace.delta.valueformat}, trace._range);\n deltaAx.setScale();\n Axes.prepTicks(deltaAx);\n\n var deltaFmt = function(v) { return Axes.tickText(deltaAx, v).text;};\n var deltaSuffix = trace.delta.suffix;\n var deltaPrefix = trace.delta.prefix;\n\n var deltaValue = function(d) {\n var value = trace.delta.relative ? d.relativeDelta : d.delta;\n return value;\n };\n var deltaFormatText = function(value, numberFmt) {\n if(value === 0 || typeof value !== 'number' || isNaN(value)) return '-';\n return (value > 0 ? trace.delta.increasing.symbol : trace.delta.decreasing.symbol) + deltaPrefix + numberFmt(value) + deltaSuffix;\n };\n var deltaFill = function(d) {\n return d.delta >= 0 ? trace.delta.increasing.color : trace.delta.decreasing.color;\n };\n if(trace._deltaLastValue === undefined) {\n trace._deltaLastValue = deltaValue(cd[0]);\n }\n var delta = numbers.select('text.delta');\n delta\n .call(Drawing.font, trace.delta.font)\n .call(Color.fill, deltaFill({delta: trace._deltaLastValue}));\n\n function writeDelta() {\n delta.text(deltaFormatText(deltaValue(cd[0]), deltaFmt))\n .call(Color.fill, deltaFill(cd[0]))\n .call(svgTextUtils.convertToTspans, gd);\n }\n\n if(hasTransition(transitionOpts)) {\n delta\n .transition()\n .duration(transitionOpts.duration)\n .ease(transitionOpts.easing)\n .tween('text', function() {\n var that = d3.select(this);\n var to = deltaValue(cd[0]);\n var from = trace._deltaLastValue;\n var transitionFmt = transitionFormat(trace.delta.valueformat, deltaFmt, from, to);\n var interpolator = interpolateNumber(from, to);\n trace._deltaLastValue = to;\n return function(t) {\n that.text(deltaFormatText(interpolator(t), transitionFmt));\n that.call(Color.fill, deltaFill({delta: interpolator(t)}));\n };\n })\n .each('end', function() { writeDelta(); onComplete && onComplete(); })\n .each('interrupt', function() { writeDelta(); onComplete && onComplete(); });\n } else {\n writeDelta();\n }\n\n deltabBox = measureText(deltaFormatText(deltaValue(cd[0]), deltaFmt), trace.delta.font, numbersAnchor, gd);\n return delta;\n }\n\n var key = trace.mode + trace.align;\n var delta;\n if(trace._hasDelta) {\n delta = drawDelta();\n key += trace.delta.position + trace.delta.font.size + trace.delta.font.family + trace.delta.valueformat;\n key += trace.delta.increasing.symbol + trace.delta.decreasing.symbol;\n numbersbBox = deltabBox;\n }\n if(trace._hasNumber) {\n drawBignumber();\n key += trace.number.font.size + trace.number.font.family + trace.number.valueformat + trace.number.suffix + trace.number.prefix;\n numbersbBox = bignumberbBox;\n }\n\n // Position delta relative to bignumber\n if(trace._hasDelta && trace._hasNumber) {\n var bignumberCenter = [\n (bignumberbBox.left + bignumberbBox.right) / 2,\n (bignumberbBox.top + bignumberbBox.bottom) / 2\n ];\n var deltaCenter = [\n (deltabBox.left + deltabBox.right) / 2,\n (deltabBox.top + deltabBox.bottom) / 2\n ];\n\n var dx, dy;\n var padding = 0.75 * trace.delta.font.size;\n if(trace.delta.position === 'left') {\n dx = cache(trace, 'deltaPos', 0, -1 * (bignumberbBox.width * (position[trace.align]) + deltabBox.width * (1 - position[trace.align]) + padding), key, Math.min);\n dy = bignumberCenter[1] - deltaCenter[1];\n\n numbersbBox = {\n width: bignumberbBox.width + deltabBox.width + padding,\n height: Math.max(bignumberbBox.height, deltabBox.height),\n left: deltabBox.left + dx,\n right: bignumberbBox.right,\n top: Math.min(bignumberbBox.top, deltabBox.top + dy),\n bottom: Math.max(bignumberbBox.bottom, deltabBox.bottom + dy)\n };\n }\n if(trace.delta.position === 'right') {\n dx = cache(trace, 'deltaPos', 0, bignumberbBox.width * (1 - position[trace.align]) + deltabBox.width * position[trace.align] + padding, key, Math.max);\n dy = bignumberCenter[1] - deltaCenter[1];\n\n numbersbBox = {\n width: bignumberbBox.width + deltabBox.width + padding,\n height: Math.max(bignumberbBox.height, deltabBox.height),\n left: bignumberbBox.left,\n right: deltabBox.right + dx,\n top: Math.min(bignumberbBox.top, deltabBox.top + dy),\n bottom: Math.max(bignumberbBox.bottom, deltabBox.bottom + dy)\n };\n }\n if(trace.delta.position === 'bottom') {\n dx = null;\n dy = deltabBox.height;\n\n numbersbBox = {\n width: Math.max(bignumberbBox.width, deltabBox.width),\n height: bignumberbBox.height + deltabBox.height,\n left: Math.min(bignumberbBox.left, deltabBox.left),\n right: Math.max(bignumberbBox.right, deltabBox.right),\n top: bignumberbBox.bottom - bignumberbBox.height,\n bottom: bignumberbBox.bottom + deltabBox.height\n };\n }\n if(trace.delta.position === 'top') {\n dx = null;\n dy = bignumberbBox.top;\n\n numbersbBox = {\n width: Math.max(bignumberbBox.width, deltabBox.width),\n height: bignumberbBox.height + deltabBox.height,\n left: Math.min(bignumberbBox.left, deltabBox.left),\n right: Math.max(bignumberbBox.right, deltabBox.right),\n top: bignumberbBox.bottom - bignumberbBox.height - deltabBox.height,\n bottom: bignumberbBox.bottom\n };\n }\n\n delta.attr({dx: dx, dy: dy});\n }\n\n // Resize numbers to fit within space and position\n if(trace._hasNumber || trace._hasDelta) {\n numbers.attr('transform', function() {\n var m = opts.numbersScaler(numbersbBox);\n key += m[2];\n var scaleRatio = cache(trace, 'numbersScale', 1, m[0], key, Math.min);\n var translateY;\n if(!trace._scaleNumbers) scaleRatio = 1;\n if(trace._isAngular) {\n // align vertically to bottom\n translateY = numbersY - scaleRatio * numbersbBox.bottom;\n } else {\n // align vertically to center\n translateY = numbersY - scaleRatio * (numbersbBox.top + numbersbBox.bottom) / 2;\n }\n\n // Stash the top position of numbersbBox for title positioning\n trace._numbersTop = scaleRatio * (numbersbBox.top) + translateY;\n\n var ref = numbersbBox[numbersAlign];\n if(numbersAlign === 'center') ref = (numbersbBox.left + numbersbBox.right) / 2;\n var translateX = numbersX - scaleRatio * ref;\n\n // Stash translateX\n translateX = cache(trace, 'numbersTranslate', 0, translateX, key, Math.max);\n return strTranslate(translateX, translateY) + strScale(scaleRatio);\n });\n }\n}\n\n// Apply fill, stroke, stroke-width to SVG shape\nfunction styleShape(p) {\n p\n .each(function(d) { Color.stroke(d3.select(this), d.line.color);})\n .each(function(d) { Color.fill(d3.select(this), d.color);})\n .style('stroke-width', function(d) { return d.line.width;});\n}\n\n// Returns a tween for a transition’s \"d\" attribute, transitioning any selected\n// arcs from their current angle to the specified new angle.\nfunction arcTween(arc, endAngle, newAngle) {\n return function() {\n var interp = interpolate(endAngle, newAngle);\n return function(t) {\n return arc.endAngle(interp(t))();\n };\n };\n}\n\n// mocks our axis\nfunction mockAxis(gd, opts, zrange) {\n var fullLayout = gd._fullLayout;\n\n var axisIn = Lib.extendFlat({\n type: 'linear',\n ticks: 'outside',\n range: zrange,\n showline: true\n }, opts);\n\n var axisOut = {\n type: 'linear',\n _id: 'x' + opts._id\n };\n\n var axisOptions = {\n letter: 'x',\n font: fullLayout.font,\n noAutotickangles: true,\n noHover: true,\n noTickson: true\n };\n\n function coerce(attr, dflt) {\n return Lib.coerce(axisIn, axisOut, axisLayoutAttrs, attr, dflt);\n }\n\n handleAxisDefaults(axisIn, axisOut, coerce, axisOptions, fullLayout);\n handleAxisPositionDefaults(axisIn, axisOut, coerce, axisOptions);\n\n return axisOut;\n}\n\nfunction fitTextInsideBox(textBB, width, height) {\n // compute scaling ratio to have text fit within specified width and height\n var ratio = Math.min(width / textBB.width, height / textBB.height);\n return [ratio, textBB, width + 'x' + height];\n}\n\nfunction fitTextInsideCircle(textBB, radius) {\n // compute scaling ratio to have text fit within specified radius\n var elRadius = Math.sqrt((textBB.width / 2) * (textBB.width / 2) + textBB.height * textBB.height);\n var ratio = radius / elRadius;\n return [ratio, textBB, radius];\n}\n\nfunction measureText(txt, font, textAnchor, gd) {\n var element = document.createElementNS('http://www.w3.org/2000/svg', 'text');\n var sel = d3.select(element);\n sel.text(txt)\n .attr('x', 0)\n .attr('y', 0)\n .attr('text-anchor', textAnchor)\n .attr('data-unformatted', txt)\n .call(svgTextUtils.convertToTspans, gd)\n .call(Drawing.font, font);\n return Drawing.bBox(sel.node());\n}\n\nfunction cache(trace, name, initialValue, value, key, fn) {\n var objName = '_cache' + name;\n if(!(trace[objName] && trace[objName].key === key)) {\n trace[objName] = {key: key, value: initialValue};\n }\n var v = Lib.aggNums(fn, null, [trace[objName].value, value], 2);\n trace[objName].value = v;\n\n return v;\n}\n","'use strict';\n\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar meshAttrs = require('../mesh3d/attributes');\nvar baseAttrs = require('../../plots/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\n\nfunction makeSliceAttr(axLetter) {\n return {\n show: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether or not slice planes about the', axLetter,\n 'dimension are drawn.'\n ].join(' ')\n },\n locations: {\n valType: 'data_array',\n dflt: [],\n description: [\n 'Specifies the location(s) of slices on the axis.',\n 'When not specified slices would be created for',\n 'all points of the axis', axLetter, 'except start and end.'\n ].join(' ')\n },\n fill: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n description: [\n 'Sets the fill ratio of the `slices`. The default fill value of the',\n '`slices` is 1 meaning that they are entirely shaded. On the other hand',\n 'Applying a `fill` ratio less than one would allow the creation of',\n 'openings parallel to the edges.'\n ].join(' ')\n }\n };\n}\n\nfunction makeCapAttr(axLetter) {\n return {\n show: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Sets the fill ratio of the `slices`. The default fill value of the', axLetter,\n '`slices` is 1 meaning that they are entirely shaded. On the other hand',\n 'Applying a `fill` ratio less than one would allow the creation of',\n 'openings parallel to the edges.'\n ].join(' ')\n },\n fill: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n description: [\n 'Sets the fill ratio of the `caps`. The default fill value of the',\n '`caps` is 1 meaning that they are entirely shaded. On the other hand',\n 'Applying a `fill` ratio less than one would allow the creation of',\n 'openings parallel to the edges.'\n ].join(' ')\n }\n };\n}\n\nvar attrs = module.exports = overrideAll(extendFlat({\n x: {\n valType: 'data_array',\n description: [\n 'Sets the X coordinates of the vertices on X axis.'\n ].join(' ')\n },\n y: {\n valType: 'data_array',\n description: [\n 'Sets the Y coordinates of the vertices on Y axis.'\n ].join(' ')\n },\n z: {\n valType: 'data_array',\n description: [\n 'Sets the Z coordinates of the vertices on Z axis.'\n ].join(' ')\n },\n value: {\n valType: 'data_array',\n description: [\n 'Sets the 4th dimension (value) of the vertices.'\n ].join(' ')\n },\n isomin: {\n valType: 'number',\n description: [\n 'Sets the minimum boundary for iso-surface plot.'\n ].join(' ')\n },\n isomax: {\n valType: 'number',\n description: [\n 'Sets the maximum boundary for iso-surface plot.'\n ].join(' ')\n },\n\n surface: {\n show: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Hides/displays surfaces between minimum and maximum iso-values.'\n ].join(' ')\n },\n count: {\n valType: 'integer',\n dflt: 2,\n min: 1,\n description: [\n 'Sets the number of iso-surfaces between minimum and maximum iso-values.',\n 'By default this value is 2 meaning that only minimum and maximum surfaces',\n 'would be drawn.'\n ].join(' ')\n },\n fill: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n description: [\n 'Sets the fill ratio of the iso-surface. The default fill value of the',\n 'surface is 1 meaning that they are entirely shaded. On the other hand',\n 'Applying a `fill` ratio less than one would allow the creation of',\n 'openings parallel to the edges.'\n ].join(' ')\n },\n pattern: {\n valType: 'flaglist',\n flags: ['A', 'B', 'C', 'D', 'E'],\n extras: ['all', 'odd', 'even'],\n dflt: 'all',\n description: [\n 'Sets the surface pattern of the iso-surface 3-D sections. The default pattern of',\n 'the surface is `all` meaning that the rest of surface elements would be shaded.',\n 'The check options (either 1 or 2) could be used to draw half of the squares',\n 'on the surface. Using various combinations of capital `A`, `B`, `C`, `D` and `E`',\n 'may also be used to reduce the number of triangles on the iso-surfaces and',\n 'creating other patterns of interest.'\n ].join(' ')\n }\n },\n\n spaceframe: {\n show: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Displays/hides tetrahedron shapes between minimum and',\n 'maximum iso-values. Often useful when either caps or',\n 'surfaces are disabled or filled with values less than 1.'\n ].join(' ')\n },\n fill: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0.15,\n description: [\n 'Sets the fill ratio of the `spaceframe` elements. The default fill value',\n 'is 0.15 meaning that only 15% of the area of every faces of tetras would be',\n 'shaded. Applying a greater `fill` ratio would allow the creation of stronger',\n 'elements or could be sued to have entirely closed areas (in case of using 1).'\n ].join(' ')\n }\n },\n\n slices: {\n x: makeSliceAttr('x'),\n y: makeSliceAttr('y'),\n z: makeSliceAttr('z')\n },\n\n caps: {\n x: makeCapAttr('x'),\n y: makeCapAttr('y'),\n z: makeCapAttr('z')\n },\n\n text: {\n valType: 'string',\n dflt: '',\n arrayOk: true,\n description: [\n 'Sets the text elements associated with the vertices.',\n 'If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,',\n 'these elements will be seen in the hover labels.'\n ].join(' ')\n },\n hovertext: {\n valType: 'string',\n dflt: '',\n arrayOk: true,\n description: 'Same as `text`.'\n },\n hovertemplate: hovertemplateAttrs(),\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n zhoverformat: axisHoverFormat('z'),\n valuehoverformat: axisHoverFormat('value', 1),\n\n showlegend: extendFlat({}, baseAttrs.showlegend, {dflt: false})\n},\n\ncolorScaleAttrs('', {\n colorAttr: '`value`',\n showScaleDflt: true,\n editTypeOverride: 'calc'\n}), {\n opacity: meshAttrs.opacity,\n lightposition: meshAttrs.lightposition,\n lighting: meshAttrs.lighting,\n flatshading: meshAttrs.flatshading,\n contour: meshAttrs.contour,\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo)\n}), 'calc', 'nested');\n\n// required defaults to speed up surface normal calculations\nattrs.flatshading.dflt = true; attrs.lighting.facenormalsepsilon.dflt = 0;\n\nattrs.x.editType = attrs.y.editType = attrs.z.editType = attrs.value.editType = 'calc+clearAxisTypes';\nattrs.transforms = undefined;\n","'use strict';\n\nvar colorscaleCalc = require('../../components/colorscale/calc');\nvar processGrid = require('../streamtube/calc').processGrid;\nvar filter = require('../streamtube/calc').filter;\n\nmodule.exports = function calc(gd, trace) {\n trace._len = Math.min(\n trace.x.length,\n trace.y.length,\n trace.z.length,\n trace.value.length\n );\n\n trace._x = filter(trace.x, trace._len);\n trace._y = filter(trace.y, trace._len);\n trace._z = filter(trace.z, trace._len);\n trace._value = filter(trace.value, trace._len);\n\n var grid = processGrid(trace);\n trace._gridFill = grid.fill;\n trace._Xs = grid.Xs;\n trace._Ys = grid.Ys;\n trace._Zs = grid.Zs;\n trace._len = grid.len;\n\n var min = Infinity;\n var max = -Infinity;\n for(var i = 0; i < trace._len; i++) {\n var v = trace._value[i];\n min = Math.min(min, v);\n max = Math.max(max, v);\n }\n\n trace._minValues = min;\n trace._maxValues = max;\n trace._vMin = (trace.isomin === undefined || trace.isomin === null) ? min : trace.isomin;\n trace._vMax = (trace.isomax === undefined || trace.isomax === null) ? max : trace.isomax;\n\n colorscaleCalc(gd, trace, {\n vals: [trace._vMin, trace._vMax],\n containerStr: '',\n cLetter: 'c'\n });\n};\n","'use strict';\n\nvar createMesh = require('../../../stackgl_modules').gl_mesh3d;\nvar parseColorScale = require('../../lib/gl_format_color').parseColorScale;\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar str2RgbaArray = require('../../lib/str2rgbarray');\nvar extractOpts = require('../../components/colorscale').extractOpts;\nvar zip3 = require('../../plots/gl3d/zip3');\n\nvar findNearestOnAxis = function(w, arr) {\n for(var q = arr.length - 1; q > 0; q--) {\n var min = Math.min(arr[q], arr[q - 1]);\n var max = Math.max(arr[q], arr[q - 1]);\n if(max > min && min < w && w <= max) {\n return {\n id: q,\n distRatio: (max - w) / (max - min)\n };\n }\n }\n return {\n id: 0,\n distRatio: 0\n };\n};\n\nfunction IsosurfaceTrace(scene, mesh, uid) {\n this.scene = scene;\n this.uid = uid;\n this.mesh = mesh;\n this.name = '';\n this.data = null;\n this.showContour = false;\n}\n\nvar proto = IsosurfaceTrace.prototype;\n\nproto.handlePick = function(selection) {\n if(selection.object === this.mesh) {\n var rawId = selection.data.index;\n\n var x = this.data._meshX[rawId];\n var y = this.data._meshY[rawId];\n var z = this.data._meshZ[rawId];\n\n var height = this.data._Ys.length;\n var depth = this.data._Zs.length;\n\n var i = findNearestOnAxis(x, this.data._Xs).id;\n var j = findNearestOnAxis(y, this.data._Ys).id;\n var k = findNearestOnAxis(z, this.data._Zs).id;\n\n var selectIndex = selection.index = k + depth * j + depth * height * i;\n\n selection.traceCoordinate = [\n this.data._meshX[selectIndex],\n this.data._meshY[selectIndex],\n this.data._meshZ[selectIndex],\n this.data._value[selectIndex]\n ];\n\n var text = this.data.hovertext || this.data.text;\n if(isArrayOrTypedArray(text) && text[selectIndex] !== undefined) {\n selection.textLabel = text[selectIndex];\n } else if(text) {\n selection.textLabel = text;\n }\n\n return true;\n }\n};\n\nproto.update = function(data) {\n var scene = this.scene;\n var layout = scene.fullSceneLayout;\n\n this.data = generateIsoMeshes(data);\n\n // Unpack position data\n function toDataCoords(axis, coord, scale, calendar) {\n return coord.map(function(x) {\n return axis.d2l(x, 0, calendar) * scale;\n });\n }\n\n var positions = zip3(\n toDataCoords(layout.xaxis, data._meshX, scene.dataScale[0], data.xcalendar),\n toDataCoords(layout.yaxis, data._meshY, scene.dataScale[1], data.ycalendar),\n toDataCoords(layout.zaxis, data._meshZ, scene.dataScale[2], data.zcalendar));\n\n var cells = zip3(data._meshI, data._meshJ, data._meshK);\n\n var config = {\n positions: positions,\n cells: cells,\n lightPosition: [data.lightposition.x, data.lightposition.y, data.lightposition.z],\n ambient: data.lighting.ambient,\n diffuse: data.lighting.diffuse,\n specular: data.lighting.specular,\n roughness: data.lighting.roughness,\n fresnel: data.lighting.fresnel,\n vertexNormalsEpsilon: data.lighting.vertexnormalsepsilon,\n faceNormalsEpsilon: data.lighting.facenormalsepsilon,\n opacity: data.opacity,\n contourEnable: data.contour.show,\n contourColor: str2RgbaArray(data.contour.color).slice(0, 3),\n contourWidth: data.contour.width,\n useFacetNormals: data.flatshading\n };\n\n var cOpts = extractOpts(data);\n config.vertexIntensity = data._meshIntensity;\n config.vertexIntensityBounds = [cOpts.min, cOpts.max];\n config.colormap = parseColorScale(data);\n\n // Update mesh\n this.mesh.update(config);\n};\n\nproto.dispose = function() {\n this.scene.glplot.remove(this.mesh);\n this.mesh.dispose();\n};\n\nvar GRID_TYPES = ['xyz', 'xzy', 'yxz', 'yzx', 'zxy', 'zyx'];\n\nfunction generateIsoMeshes(data) {\n data._meshI = [];\n data._meshJ = [];\n data._meshK = [];\n\n var showSurface = data.surface.show;\n var showSpaceframe = data.spaceframe.show;\n\n var surfaceFill = data.surface.fill;\n var spaceframeFill = data.spaceframe.fill;\n\n var drawingSurface = false;\n var drawingSpaceframe = false;\n\n var numFaces = 0;\n var numVertices;\n var beginVertextLength;\n\n var Xs = data._Xs;\n var Ys = data._Ys;\n var Zs = data._Zs;\n\n var width = Xs.length;\n var height = Ys.length;\n var depth = Zs.length;\n\n var filled = GRID_TYPES.indexOf(data._gridFill.replace(/-/g, '').replace(/\\+/g, ''));\n\n var getIndex = function(i, j, k) {\n switch(filled) {\n case 5: // 'zyx'\n return k + depth * j + depth * height * i;\n case 4: // 'zxy'\n return k + depth * i + depth * width * j;\n case 3: // 'yzx'\n return j + height * k + height * depth * i;\n case 2: // 'yxz'\n return j + height * i + height * width * k;\n case 1: // 'xzy'\n return i + width * k + width * depth * j;\n default: // case 0: // 'xyz'\n return i + width * j + width * height * k;\n }\n };\n\n var minValues = data._minValues;\n var maxValues = data._maxValues;\n\n var vMin = data._vMin;\n var vMax = data._vMax;\n\n var allXs;\n var allYs;\n var allZs;\n var allVs;\n\n function findVertexId(x, y, z) {\n // could be used to find the vertex id of previously generated vertex within the group\n\n var len = allVs.length;\n for(var f = beginVertextLength; f < len; f++) {\n if(\n x === allXs[f] &&\n y === allYs[f] &&\n z === allZs[f]\n ) {\n return f;\n }\n }\n return -1;\n }\n\n function beginGroup() {\n beginVertextLength = numVertices;\n }\n\n function emptyVertices() {\n allXs = [];\n allYs = [];\n allZs = [];\n allVs = [];\n numVertices = 0;\n\n beginGroup();\n }\n\n function addVertex(x, y, z, v) {\n allXs.push(x);\n allYs.push(y);\n allZs.push(z);\n allVs.push(v);\n numVertices++;\n\n return numVertices - 1;\n }\n\n function addFace(a, b, c) {\n data._meshI.push(a);\n data._meshJ.push(b);\n data._meshK.push(c);\n numFaces++;\n\n return numFaces - 1;\n }\n\n function getCenter(A, B, C) {\n var M = [];\n for(var i = 0; i < A.length; i++) {\n M[i] = (A[i] + B[i] + C[i]) / 3.0;\n }\n return M;\n }\n\n function getBetween(A, B, r) {\n var M = [];\n for(var i = 0; i < A.length; i++) {\n M[i] = A[i] * (1 - r) + r * B[i];\n }\n return M;\n }\n\n var activeFill;\n function setFill(fill) {\n activeFill = fill;\n }\n\n function createOpenTri(xyzv, abc) {\n var A = xyzv[0];\n var B = xyzv[1];\n var C = xyzv[2];\n var G = getCenter(A, B, C);\n\n var r = Math.sqrt(1 - activeFill);\n var p1 = getBetween(G, A, r);\n var p2 = getBetween(G, B, r);\n var p3 = getBetween(G, C, r);\n\n var a = abc[0];\n var b = abc[1];\n var c = abc[2];\n\n return {\n xyzv: [\n [A, B, p2], [p2, p1, A],\n [B, C, p3], [p3, p2, B],\n [C, A, p1], [p1, p3, C]\n ],\n abc: [\n [a, b, -1], [-1, -1, a],\n [b, c, -1], [-1, -1, b],\n [c, a, -1], [-1, -1, c]\n ]\n };\n }\n\n function styleIncludes(style, char) {\n if(style === 'all' || style === null) return true;\n return (style.indexOf(char) > -1);\n }\n\n function mapValue(style, value) {\n if(style === null) return value;\n return style;\n }\n\n function drawTri(style, xyzv, abc) {\n beginGroup();\n\n var allXYZVs = [xyzv];\n var allABCs = [abc];\n if(activeFill >= 1) {\n allXYZVs = [xyzv];\n allABCs = [abc];\n } else if(activeFill > 0) {\n var openTri = createOpenTri(xyzv, abc);\n allXYZVs = openTri.xyzv;\n allABCs = openTri.abc;\n }\n\n for(var f = 0; f < allXYZVs.length; f++) {\n xyzv = allXYZVs[f];\n abc = allABCs[f];\n\n var pnts = [];\n for(var i = 0; i < 3; i++) {\n var x = xyzv[i][0];\n var y = xyzv[i][1];\n var z = xyzv[i][2];\n var v = xyzv[i][3];\n\n var id = (abc[i] > -1) ? abc[i] : findVertexId(x, y, z);\n if(id > -1) {\n pnts[i] = id;\n } else {\n pnts[i] = addVertex(x, y, z, mapValue(style, v));\n }\n }\n\n addFace(pnts[0], pnts[1], pnts[2]);\n }\n }\n\n function drawQuad(style, xyzv, abcd) {\n var makeTri = function(i, j, k) {\n drawTri(style, [xyzv[i], xyzv[j], xyzv[k]], [abcd[i], abcd[j], abcd[k]]);\n };\n\n makeTri(0, 1, 2);\n makeTri(2, 3, 0);\n }\n\n function drawTetra(style, xyzv, abcd) {\n var makeTri = function(i, j, k) {\n drawTri(style, [xyzv[i], xyzv[j], xyzv[k]], [abcd[i], abcd[j], abcd[k]]);\n };\n\n makeTri(0, 1, 2);\n makeTri(3, 0, 1);\n makeTri(2, 3, 0);\n makeTri(1, 2, 3);\n }\n\n function calcIntersection(pointOut, pointIn, min, max) {\n var value = pointOut[3];\n\n if(value < min) value = min;\n if(value > max) value = max;\n\n var ratio = (pointOut[3] - value) / (pointOut[3] - pointIn[3] + 0.000000001); // we had to add this error to force solve the tiny caps\n\n var result = [];\n for(var s = 0; s < 4; s++) {\n result[s] = (1 - ratio) * pointOut[s] + ratio * pointIn[s];\n }\n return result;\n }\n\n function inRange(value, min, max) {\n return (\n value >= min &&\n value <= max\n );\n }\n\n function almostInFinalRange(value) {\n var vErr = 0.001 * (vMax - vMin);\n return (\n value >= vMin - vErr &&\n value <= vMax + vErr\n );\n }\n\n function getXYZV(indecies) {\n var xyzv = [];\n for(var q = 0; q < 4; q++) {\n var index = indecies[q];\n xyzv.push(\n [\n data._x[index],\n data._y[index],\n data._z[index],\n data._value[index]\n ]\n );\n }\n\n return xyzv;\n }\n\n var MAX_PASS = 3;\n\n function tryCreateTri(style, xyzv, abc, min, max, nPass) {\n if(!nPass) nPass = 1;\n\n abc = [-1, -1, -1]; // Note: for the moment we override indices\n // to run faster! But it is possible to comment this line\n // to reduce the number of vertices.\n\n var result = false;\n\n var ok = [\n inRange(xyzv[0][3], min, max),\n inRange(xyzv[1][3], min, max),\n inRange(xyzv[2][3], min, max)\n ];\n\n if(!ok[0] && !ok[1] && !ok[2]) {\n return false;\n }\n\n var tryDrawTri = function(style, xyzv, abc) {\n if( // we check here if the points are in `real` iso-min/max range\n almostInFinalRange(xyzv[0][3]) &&\n almostInFinalRange(xyzv[1][3]) &&\n almostInFinalRange(xyzv[2][3])\n ) {\n drawTri(style, xyzv, abc);\n return true;\n } else if(nPass < MAX_PASS) {\n return tryCreateTri(style, xyzv, abc, vMin, vMax, ++nPass); // i.e. second pass using actual vMin vMax bounds\n }\n return false;\n };\n\n if(ok[0] && ok[1] && ok[2]) {\n return tryDrawTri(style, xyzv, abc) || result;\n }\n\n var interpolated = false;\n\n [\n [0, 1, 2],\n [2, 0, 1],\n [1, 2, 0]\n ].forEach(function(e) {\n if(ok[e[0]] && ok[e[1]] && !ok[e[2]]) {\n var A = xyzv[e[0]];\n var B = xyzv[e[1]];\n var C = xyzv[e[2]];\n\n var p1 = calcIntersection(C, A, min, max);\n var p2 = calcIntersection(C, B, min, max);\n\n result = tryDrawTri(style, [p2, p1, A], [-1, -1, abc[e[0]]]) || result;\n result = tryDrawTri(style, [A, B, p2], [abc[e[0]], abc[e[1]], -1]) || result;\n\n interpolated = true;\n }\n });\n if(interpolated) return result;\n\n [\n [0, 1, 2],\n [1, 2, 0],\n [2, 0, 1]\n ].forEach(function(e) {\n if(ok[e[0]] && !ok[e[1]] && !ok[e[2]]) {\n var A = xyzv[e[0]];\n var B = xyzv[e[1]];\n var C = xyzv[e[2]];\n\n var p1 = calcIntersection(B, A, min, max);\n var p2 = calcIntersection(C, A, min, max);\n\n result = tryDrawTri(style, [p2, p1, A], [-1, -1, abc[e[0]]]) || result;\n\n interpolated = true;\n }\n });\n return result;\n }\n\n function tryCreateTetra(style, abcd, min, max) {\n var result = false;\n\n var xyzv = getXYZV(abcd);\n\n var ok = [\n inRange(xyzv[0][3], min, max),\n inRange(xyzv[1][3], min, max),\n inRange(xyzv[2][3], min, max),\n inRange(xyzv[3][3], min, max)\n ];\n\n if(!ok[0] && !ok[1] && !ok[2] && !ok[3]) {\n return result;\n }\n\n if(ok[0] && ok[1] && ok[2] && ok[3]) {\n if(drawingSpaceframe) {\n result = drawTetra(style, xyzv, abcd) || result;\n }\n return result;\n }\n\n var interpolated = false;\n\n [\n [0, 1, 2, 3],\n [3, 0, 1, 2],\n [2, 3, 0, 1],\n [1, 2, 3, 0]\n ].forEach(function(e) {\n if(ok[e[0]] && ok[e[1]] && ok[e[2]] && !ok[e[3]]) {\n var A = xyzv[e[0]];\n var B = xyzv[e[1]];\n var C = xyzv[e[2]];\n var D = xyzv[e[3]];\n\n if(drawingSpaceframe) {\n result = drawTri(style, [A, B, C], [abcd[e[0]], abcd[e[1]], abcd[e[2]]]) || result;\n } else {\n var p1 = calcIntersection(D, A, min, max);\n var p2 = calcIntersection(D, B, min, max);\n var p3 = calcIntersection(D, C, min, max);\n\n result = drawTri(null, [p1, p2, p3], [-1, -1, -1]) || result;\n }\n\n interpolated = true;\n }\n });\n if(interpolated) return result;\n\n [\n [0, 1, 2, 3],\n [1, 2, 3, 0],\n [2, 3, 0, 1],\n [3, 0, 1, 2],\n [0, 2, 3, 1],\n [1, 3, 2, 0]\n ].forEach(function(e) {\n if(ok[e[0]] && ok[e[1]] && !ok[e[2]] && !ok[e[3]]) {\n var A = xyzv[e[0]];\n var B = xyzv[e[1]];\n var C = xyzv[e[2]];\n var D = xyzv[e[3]];\n\n var p1 = calcIntersection(C, A, min, max);\n var p2 = calcIntersection(C, B, min, max);\n var p3 = calcIntersection(D, B, min, max);\n var p4 = calcIntersection(D, A, min, max);\n\n if(drawingSpaceframe) {\n result = drawTri(style, [A, p4, p1], [abcd[e[0]], -1, -1]) || result;\n result = drawTri(style, [B, p2, p3], [abcd[e[1]], -1, -1]) || result;\n } else {\n result = drawQuad(null, [p1, p2, p3, p4], [-1, -1, -1, -1]) || result;\n }\n\n interpolated = true;\n }\n });\n if(interpolated) return result;\n\n [\n [0, 1, 2, 3],\n [1, 2, 3, 0],\n [2, 3, 0, 1],\n [3, 0, 1, 2]\n ].forEach(function(e) {\n if(ok[e[0]] && !ok[e[1]] && !ok[e[2]] && !ok[e[3]]) {\n var A = xyzv[e[0]];\n var B = xyzv[e[1]];\n var C = xyzv[e[2]];\n var D = xyzv[e[3]];\n\n var p1 = calcIntersection(B, A, min, max);\n var p2 = calcIntersection(C, A, min, max);\n var p3 = calcIntersection(D, A, min, max);\n\n if(drawingSpaceframe) {\n result = drawTri(style, [A, p1, p2], [abcd[e[0]], -1, -1]) || result;\n result = drawTri(style, [A, p2, p3], [abcd[e[0]], -1, -1]) || result;\n result = drawTri(style, [A, p3, p1], [abcd[e[0]], -1, -1]) || result;\n } else {\n result = drawTri(null, [p1, p2, p3], [-1, -1, -1]) || result;\n }\n\n interpolated = true;\n }\n });\n return result;\n }\n\n function addCube(style, p000, p001, p010, p011, p100, p101, p110, p111, min, max) {\n var result = false;\n\n if(drawingSurface) {\n if(styleIncludes(style, 'A')) {\n result = tryCreateTetra(null, [p000, p001, p010, p100], min, max) || result;\n }\n if(styleIncludes(style, 'B')) {\n result = tryCreateTetra(null, [p001, p010, p011, p111], min, max) || result;\n }\n if(styleIncludes(style, 'C')) {\n result = tryCreateTetra(null, [p001, p100, p101, p111], min, max) || result;\n }\n if(styleIncludes(style, 'D')) {\n result = tryCreateTetra(null, [p010, p100, p110, p111], min, max) || result;\n }\n if(styleIncludes(style, 'E')) {\n result = tryCreateTetra(null, [p001, p010, p100, p111], min, max) || result;\n }\n }\n\n if(drawingSpaceframe) {\n result = tryCreateTetra(style, [p001, p010, p100, p111], min, max) || result;\n }\n\n return result;\n }\n\n function addRect(style, a, b, c, d, min, max, previousResult) {\n return [\n (previousResult[0] === true) ? true :\n tryCreateTri(style, getXYZV([a, b, c]), [a, b, c], min, max),\n (previousResult[1] === true) ? true :\n tryCreateTri(style, getXYZV([c, d, a]), [c, d, a], min, max)\n ];\n }\n\n function begin2dCell(style, p00, p01, p10, p11, min, max, isEven, previousResult) {\n // used to create caps and/or slices on exact axis points\n if(isEven) {\n return addRect(style, p00, p01, p11, p10, min, max, previousResult);\n } else {\n return addRect(style, p01, p11, p10, p00, min, max, previousResult);\n }\n }\n\n function beginSection(style, i, j, k, min, max, distRatios) {\n // used to create slices between axis points\n\n var result = false;\n var A, B, C, D;\n\n var makeSection = function() {\n result = tryCreateTri(style, [A, B, C], [-1, -1, -1], min, max) || result;\n result = tryCreateTri(style, [C, D, A], [-1, -1, -1], min, max) || result;\n };\n\n var rX = distRatios[0];\n var rY = distRatios[1];\n var rZ = distRatios[2];\n\n if(rX) {\n A = getBetween(getXYZV([getIndex(i, j - 0, k - 0)])[0], getXYZV([getIndex(i - 1, j - 0, k - 0)])[0], rX);\n B = getBetween(getXYZV([getIndex(i, j - 0, k - 1)])[0], getXYZV([getIndex(i - 1, j - 0, k - 1)])[0], rX);\n C = getBetween(getXYZV([getIndex(i, j - 1, k - 1)])[0], getXYZV([getIndex(i - 1, j - 1, k - 1)])[0], rX);\n D = getBetween(getXYZV([getIndex(i, j - 1, k - 0)])[0], getXYZV([getIndex(i - 1, j - 1, k - 0)])[0], rX);\n makeSection();\n }\n\n if(rY) {\n A = getBetween(getXYZV([getIndex(i - 0, j, k - 0)])[0], getXYZV([getIndex(i - 0, j - 1, k - 0)])[0], rY);\n B = getBetween(getXYZV([getIndex(i - 0, j, k - 1)])[0], getXYZV([getIndex(i - 0, j - 1, k - 1)])[0], rY);\n C = getBetween(getXYZV([getIndex(i - 1, j, k - 1)])[0], getXYZV([getIndex(i - 1, j - 1, k - 1)])[0], rY);\n D = getBetween(getXYZV([getIndex(i - 1, j, k - 0)])[0], getXYZV([getIndex(i - 1, j - 1, k - 0)])[0], rY);\n makeSection();\n }\n\n if(rZ) {\n A = getBetween(getXYZV([getIndex(i - 0, j - 0, k)])[0], getXYZV([getIndex(i - 0, j - 0, k - 1)])[0], rZ);\n B = getBetween(getXYZV([getIndex(i - 0, j - 1, k)])[0], getXYZV([getIndex(i - 0, j - 1, k - 1)])[0], rZ);\n C = getBetween(getXYZV([getIndex(i - 1, j - 1, k)])[0], getXYZV([getIndex(i - 1, j - 1, k - 1)])[0], rZ);\n D = getBetween(getXYZV([getIndex(i - 1, j - 0, k)])[0], getXYZV([getIndex(i - 1, j - 0, k - 1)])[0], rZ);\n makeSection();\n }\n\n return result;\n }\n\n function begin3dCell(style, p000, p001, p010, p011, p100, p101, p110, p111, min, max, isEven) {\n // used to create spaceframe and/or iso-surfaces\n\n var cellStyle = style;\n if(isEven) {\n if(drawingSurface && style === 'even') cellStyle = null;\n return addCube(cellStyle, p000, p001, p010, p011, p100, p101, p110, p111, min, max);\n } else {\n if(drawingSurface && style === 'odd') cellStyle = null;\n return addCube(cellStyle, p111, p110, p101, p100, p011, p010, p001, p000, min, max);\n }\n }\n\n function draw2dX(style, items, min, max, previousResult) {\n var result = [];\n var n = 0;\n for(var q = 0; q < items.length; q++) {\n var i = items[q];\n for(var k = 1; k < depth; k++) {\n for(var j = 1; j < height; j++) {\n result.push(\n begin2dCell(style,\n getIndex(i, j - 1, k - 1),\n getIndex(i, j - 1, k),\n getIndex(i, j, k - 1),\n getIndex(i, j, k),\n min,\n max,\n (i + j + k) % 2,\n (previousResult && previousResult[n]) ? previousResult[n] : []\n )\n );\n n++;\n }\n }\n }\n return result;\n }\n\n function draw2dY(style, items, min, max, previousResult) {\n var result = [];\n var n = 0;\n for(var q = 0; q < items.length; q++) {\n var j = items[q];\n for(var i = 1; i < width; i++) {\n for(var k = 1; k < depth; k++) {\n result.push(\n begin2dCell(style,\n getIndex(i - 1, j, k - 1),\n getIndex(i, j, k - 1),\n getIndex(i - 1, j, k),\n getIndex(i, j, k),\n min,\n max,\n (i + j + k) % 2,\n (previousResult && previousResult[n]) ? previousResult[n] : []\n )\n );\n n++;\n }\n }\n }\n return result;\n }\n\n function draw2dZ(style, items, min, max, previousResult) {\n var result = [];\n var n = 0;\n for(var q = 0; q < items.length; q++) {\n var k = items[q];\n for(var j = 1; j < height; j++) {\n for(var i = 1; i < width; i++) {\n result.push(\n begin2dCell(style,\n getIndex(i - 1, j - 1, k),\n getIndex(i - 1, j, k),\n getIndex(i, j - 1, k),\n getIndex(i, j, k),\n min,\n max,\n (i + j + k) % 2,\n (previousResult && previousResult[n]) ? previousResult[n] : []\n )\n );\n n++;\n }\n }\n }\n return result;\n }\n\n function draw3d(style, min, max) {\n for(var k = 1; k < depth; k++) {\n for(var j = 1; j < height; j++) {\n for(var i = 1; i < width; i++) {\n begin3dCell(style,\n getIndex(i - 1, j - 1, k - 1),\n getIndex(i - 1, j - 1, k),\n getIndex(i - 1, j, k - 1),\n getIndex(i - 1, j, k),\n getIndex(i, j - 1, k - 1),\n getIndex(i, j - 1, k),\n getIndex(i, j, k - 1),\n getIndex(i, j, k),\n min,\n max,\n (i + j + k) % 2\n );\n }\n }\n }\n }\n\n function drawSpaceframe(style, min, max) {\n drawingSpaceframe = true;\n draw3d(style, min, max);\n drawingSpaceframe = false;\n }\n\n function drawSurface(style, min, max) {\n drawingSurface = true;\n draw3d(style, min, max);\n drawingSurface = false;\n }\n\n function drawSectionX(style, items, min, max, distRatios, previousResult) {\n var result = [];\n var n = 0;\n for(var q = 0; q < items.length; q++) {\n var i = items[q];\n for(var k = 1; k < depth; k++) {\n for(var j = 1; j < height; j++) {\n result.push(\n beginSection(style, i, j, k, min, max, distRatios[q],\n (previousResult && previousResult[n]) ? previousResult[n] : []\n )\n );\n n++;\n }\n }\n }\n return result;\n }\n\n function drawSectionY(style, items, min, max, distRatios, previousResult) {\n var result = [];\n var n = 0;\n for(var q = 0; q < items.length; q++) {\n var j = items[q];\n for(var i = 1; i < width; i++) {\n for(var k = 1; k < depth; k++) {\n result.push(\n beginSection(style, i, j, k, min, max, distRatios[q],\n (previousResult && previousResult[n]) ? previousResult[n] : []\n )\n );\n n++;\n }\n }\n }\n return result;\n }\n\n function drawSectionZ(style, items, min, max, distRatios, previousResult) {\n var result = [];\n var n = 0;\n for(var q = 0; q < items.length; q++) {\n var k = items[q];\n for(var j = 1; j < height; j++) {\n for(var i = 1; i < width; i++) {\n result.push(\n beginSection(style, i, j, k, min, max, distRatios[q],\n (previousResult && previousResult[n]) ? previousResult[n] : []\n )\n );\n n++;\n }\n }\n }\n return result;\n }\n\n function createRange(a, b) {\n var range = [];\n for(var q = a; q < b; q++) {\n range.push(q);\n }\n return range;\n }\n\n function insertGridPoints() {\n for(var i = 0; i < width; i++) {\n for(var j = 0; j < height; j++) {\n for(var k = 0; k < depth; k++) {\n var index = getIndex(i, j, k);\n addVertex(\n data._x[index],\n data._y[index],\n data._z[index],\n data._value[index]\n );\n }\n }\n }\n }\n\n function drawAll() {\n emptyVertices();\n\n // insert grid points\n insertGridPoints();\n\n var activeStyle = null;\n\n // draw spaceframes\n if(showSpaceframe && spaceframeFill) {\n setFill(spaceframeFill);\n\n drawSpaceframe(activeStyle, vMin, vMax);\n }\n\n // draw iso-surfaces\n if(showSurface && surfaceFill) {\n setFill(surfaceFill);\n\n var surfacePattern = data.surface.pattern;\n var surfaceCount = data.surface.count;\n for(var q = 0; q < surfaceCount; q++) {\n var ratio = (surfaceCount === 1) ? 0.5 : q / (surfaceCount - 1);\n var level = (1 - ratio) * vMin + ratio * vMax;\n\n var d1 = Math.abs(level - minValues);\n var d2 = Math.abs(level - maxValues);\n var ranges = (d1 > d2) ?\n [minValues, level] :\n [level, maxValues];\n\n drawSurface(surfacePattern, ranges[0], ranges[1]);\n }\n }\n\n var setupMinMax = [\n [ Math.min(vMin, maxValues), Math.max(vMin, maxValues) ],\n [ Math.min(minValues, vMax), Math.max(minValues, vMax) ]\n ];\n\n ['x', 'y', 'z'].forEach(function(e) {\n var preRes = [];\n for(var s = 0; s < setupMinMax.length; s++) {\n var count = 0;\n\n var activeMin = setupMinMax[s][0];\n var activeMax = setupMinMax[s][1];\n\n // draw slices\n var slice = data.slices[e];\n if(slice.show && slice.fill) {\n setFill(slice.fill);\n\n var exactIndices = [];\n var ceilIndices = [];\n var distRatios = [];\n if(slice.locations.length) {\n for(var q = 0; q < slice.locations.length; q++) {\n var near = findNearestOnAxis(\n slice.locations[q],\n (e === 'x') ? Xs :\n (e === 'y') ? Ys : Zs\n );\n\n if(near.distRatio === 0) {\n exactIndices.push(near.id);\n } else if(near.id > 0) {\n ceilIndices.push(near.id);\n if(e === 'x') {\n distRatios.push([near.distRatio, 0, 0]);\n } else if(e === 'y') {\n distRatios.push([0, near.distRatio, 0]);\n } else {\n distRatios.push([0, 0, near.distRatio]);\n }\n }\n }\n } else {\n if(e === 'x') {\n exactIndices = createRange(1, width - 1);\n } else if(e === 'y') {\n exactIndices = createRange(1, height - 1);\n } else {\n exactIndices = createRange(1, depth - 1);\n }\n }\n\n if(ceilIndices.length > 0) {\n if(e === 'x') {\n preRes[count] = drawSectionX(activeStyle, ceilIndices, activeMin, activeMax, distRatios, preRes[count]);\n } else if(e === 'y') {\n preRes[count] = drawSectionY(activeStyle, ceilIndices, activeMin, activeMax, distRatios, preRes[count]);\n } else {\n preRes[count] = drawSectionZ(activeStyle, ceilIndices, activeMin, activeMax, distRatios, preRes[count]);\n }\n count++;\n }\n\n if(exactIndices.length > 0) {\n if(e === 'x') {\n preRes[count] = draw2dX(activeStyle, exactIndices, activeMin, activeMax, preRes[count]);\n } else if(e === 'y') {\n preRes[count] = draw2dY(activeStyle, exactIndices, activeMin, activeMax, preRes[count]);\n } else {\n preRes[count] = draw2dZ(activeStyle, exactIndices, activeMin, activeMax, preRes[count]);\n }\n count++;\n }\n }\n\n // draw caps\n var cap = data.caps[e];\n if(cap.show && cap.fill) {\n setFill(cap.fill);\n if(e === 'x') {\n preRes[count] = draw2dX(activeStyle, [0, width - 1], activeMin, activeMax, preRes[count]);\n } else if(e === 'y') {\n preRes[count] = draw2dY(activeStyle, [0, height - 1], activeMin, activeMax, preRes[count]);\n } else {\n preRes[count] = draw2dZ(activeStyle, [0, depth - 1], activeMin, activeMax, preRes[count]);\n }\n count++;\n }\n }\n });\n\n // remove vertices arrays (i.e. grid points) in case no face was created.\n if(numFaces === 0) {\n emptyVertices();\n }\n\n data._meshX = allXs;\n data._meshY = allYs;\n data._meshZ = allZs;\n data._meshIntensity = allVs;\n\n data._Xs = Xs;\n data._Ys = Ys;\n data._Zs = Zs;\n }\n\n drawAll();\n\n return data;\n}\n\nfunction createIsosurfaceTrace(scene, data) {\n var gl = scene.glplot.gl;\n var mesh = createMesh({gl: gl});\n var result = new IsosurfaceTrace(scene, mesh, data.uid);\n\n mesh._trace = result;\n result.update(data);\n scene.glplot.add(mesh);\n return result;\n}\n\nmodule.exports = {\n findNearestOnAxis: findNearestOnAxis,\n generateIsoMeshes: generateIsoMeshes,\n createIsosurfaceTrace: createIsosurfaceTrace,\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\nvar attributes = require('./attributes');\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\n\nfunction supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n supplyIsoDefaults(traceIn, traceOut, defaultColor, layout, coerce);\n}\n\nfunction supplyIsoDefaults(traceIn, traceOut, defaultColor, layout, coerce) {\n var isomin = coerce('isomin');\n var isomax = coerce('isomax');\n\n if(isomax !== undefined && isomax !== null &&\n isomin !== undefined && isomin !== null &&\n isomin > isomax) {\n // applying default values in this case:\n traceOut.isomin = null;\n traceOut.isomax = null;\n }\n\n var x = coerce('x');\n var y = coerce('y');\n var z = coerce('z');\n var value = coerce('value');\n\n if(\n !x || !x.length ||\n !y || !y.length ||\n !z || !z.length ||\n !value || !value.length\n ) {\n traceOut.visible = false;\n return;\n }\n\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleTraceDefaults');\n handleCalendarDefaults(traceIn, traceOut, ['x', 'y', 'z'], layout);\n\n coerce('valuehoverformat');\n ['x', 'y', 'z'].forEach(function(dim) {\n coerce(dim + 'hoverformat');\n\n var capDim = 'caps.' + dim;\n var showCap = coerce(capDim + '.show');\n if(showCap) {\n coerce(capDim + '.fill');\n }\n\n var sliceDim = 'slices.' + dim;\n var showSlice = coerce(sliceDim + '.show');\n if(showSlice) {\n coerce(sliceDim + '.fill');\n coerce(sliceDim + '.locations');\n }\n });\n\n var showSpaceframe = coerce('spaceframe.show');\n if(showSpaceframe) {\n coerce('spaceframe.fill');\n }\n\n var showSurface = coerce('surface.show');\n if(showSurface) {\n coerce('surface.count');\n coerce('surface.fill');\n coerce('surface.pattern');\n }\n\n var showContour = coerce('contour.show');\n if(showContour) {\n coerce('contour.color');\n coerce('contour.width');\n }\n\n // Coerce remaining properties\n [\n 'text',\n 'hovertext',\n 'hovertemplate',\n 'lighting.ambient',\n 'lighting.diffuse',\n 'lighting.specular',\n 'lighting.roughness',\n 'lighting.fresnel',\n 'lighting.vertexnormalsepsilon',\n 'lighting.facenormalsepsilon',\n 'lightposition.x',\n 'lightposition.y',\n 'lightposition.z',\n 'flatshading',\n 'opacity'\n ].forEach(function(x) { coerce(x); });\n\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'c'});\n\n // disable 1D transforms (for now)\n traceOut._length = null;\n}\n\nmodule.exports = {\n supplyDefaults: supplyDefaults,\n supplyIsoDefaults: supplyIsoDefaults\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults').supplyDefaults,\n calc: require('./calc'),\n colorbar: {\n min: 'cmin',\n max: 'cmax'\n },\n plot: require('./convert').createIsosurfaceTrace,\n\n moduleType: 'trace',\n name: 'isosurface',\n basePlotModule: require('../../plots/gl3d'),\n categories: ['gl3d', 'showLegend'],\n meta: {\n description: [\n 'Draws isosurfaces between iso-min and iso-max values with coordinates given by',\n 'four 1-dimensional arrays containing the `value`, `x`, `y` and `z` of every vertex',\n 'of a uniform or non-uniform 3-D grid. Horizontal or vertical slices, caps as well as',\n 'spaceframe between iso-min and iso-max values could also be drawn using this trace.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar surfaceAttrs = require('../surface/attributes');\nvar baseAttrs = require('../../plots/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nmodule.exports = extendFlat({\n x: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the X coordinates of the vertices. The nth element of vectors `x`, `y` and `z`',\n 'jointly represent the X, Y and Z coordinates of the nth vertex.'\n ].join(' ')\n },\n y: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the Y coordinates of the vertices. The nth element of vectors `x`, `y` and `z`',\n 'jointly represent the X, Y and Z coordinates of the nth vertex.'\n ].join(' ')\n },\n z: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the Z coordinates of the vertices. The nth element of vectors `x`, `y` and `z`',\n 'jointly represent the X, Y and Z coordinates of the nth vertex.'\n ].join(' ')\n },\n\n i: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'A vector of vertex indices, i.e. integer values between 0 and the length of the vertex',\n 'vectors, representing the *first* vertex of a triangle. For example, `{i[m], j[m], k[m]}`',\n 'together represent face m (triangle m) in the mesh, where `i[m] = n` points to the triplet',\n '`{x[n], y[n], z[n]}` in the vertex arrays. Therefore, each element in `i` represents a',\n 'point in space, which is the first vertex of a triangle.'\n ].join(' ')\n },\n j: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'A vector of vertex indices, i.e. integer values between 0 and the length of the vertex',\n 'vectors, representing the *second* vertex of a triangle. For example, `{i[m], j[m], k[m]}` ',\n 'together represent face m (triangle m) in the mesh, where `j[m] = n` points to the triplet',\n '`{x[n], y[n], z[n]}` in the vertex arrays. Therefore, each element in `j` represents a',\n 'point in space, which is the second vertex of a triangle.'\n ].join(' ')\n\n },\n k: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'A vector of vertex indices, i.e. integer values between 0 and the length of the vertex',\n 'vectors, representing the *third* vertex of a triangle. For example, `{i[m], j[m], k[m]}`',\n 'together represent face m (triangle m) in the mesh, where `k[m] = n` points to the triplet ',\n '`{x[n], y[n], z[n]}` in the vertex arrays. Therefore, each element in `k` represents a',\n 'point in space, which is the third vertex of a triangle.'\n ].join(' ')\n\n },\n\n text: {\n valType: 'string',\n dflt: '',\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Sets the text elements associated with the vertices.',\n 'If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,',\n 'these elements will be seen in the hover labels.'\n ].join(' ')\n },\n hovertext: {\n valType: 'string',\n dflt: '',\n arrayOk: true,\n editType: 'calc',\n description: 'Same as `text`.'\n },\n hovertemplate: hovertemplateAttrs({editType: 'calc'}),\n\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n zhoverformat: axisHoverFormat('z'),\n\n delaunayaxis: {\n valType: 'enumerated',\n values: [ 'x', 'y', 'z' ],\n dflt: 'z',\n editType: 'calc',\n description: [\n 'Sets the Delaunay axis, which is the axis that is perpendicular to the surface of the',\n 'Delaunay triangulation.',\n 'It has an effect if `i`, `j`, `k` are not provided and `alphahull` is set to indicate',\n 'Delaunay triangulation.'\n ].join(' ')\n },\n\n alphahull: {\n valType: 'number',\n dflt: -1,\n editType: 'calc',\n description: [\n 'Determines how the mesh surface triangles are derived from the set of',\n 'vertices (points) represented by the `x`, `y` and `z` arrays, if',\n 'the `i`, `j`, `k` arrays are not supplied.',\n 'For general use of `mesh3d` it is preferred that `i`, `j`, `k` are',\n 'supplied.',\n\n 'If *-1*, Delaunay triangulation is used, which is mainly suitable if the',\n 'mesh is a single, more or less layer surface that is perpendicular to `delaunayaxis`.',\n 'In case the `delaunayaxis` intersects the mesh surface at more than one point',\n 'it will result triangles that are very long in the dimension of `delaunayaxis`.',\n\n 'If *>0*, the alpha-shape algorithm is used. In this case, the positive `alphahull` value',\n 'signals the use of the alpha-shape algorithm, _and_ its value',\n 'acts as the parameter for the mesh fitting.',\n\n 'If *0*, the convex-hull algorithm is used. It is suitable for convex bodies',\n 'or if the intention is to enclose the `x`, `y` and `z` point set into a convex',\n 'hull.'\n ].join(' ')\n },\n\n intensity: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the intensity values for vertices or cells',\n 'as defined by `intensitymode`.',\n 'It can be used for plotting fields on meshes.'\n ].join(' ')\n },\n intensitymode: {\n valType: 'enumerated',\n values: ['vertex', 'cell'],\n dflt: 'vertex',\n editType: 'calc',\n description: [\n 'Determines the source of `intensity` values.'\n ].join(' ')\n },\n\n // Color field\n color: {\n valType: 'color',\n editType: 'calc',\n description: 'Sets the color of the whole mesh'\n },\n vertexcolor: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the color of each vertex',\n 'Overrides *color*. While Red, green and blue colors',\n 'are in the range of 0 and 255; in the case of having',\n 'vertex color data in RGBA format, the alpha color',\n 'should be normalized to be between 0 and 1.'\n ].join(' ')\n },\n facecolor: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the color of each face',\n 'Overrides *color* and *vertexcolor*.'\n ].join(' ')\n },\n transforms: undefined\n},\n\ncolorScaleAttrs('', {\n colorAttr: '`intensity`',\n showScaleDflt: true,\n editTypeOverride: 'calc'\n}), {\n opacity: surfaceAttrs.opacity,\n\n // Flat shaded mode\n flatshading: {\n valType: 'boolean',\n dflt: false,\n editType: 'calc',\n description: [\n 'Determines whether or not normal smoothing is applied to the meshes,',\n 'creating meshes with an angular, low-poly look via flat reflections.'\n ].join(' ')\n },\n\n contour: {\n show: extendFlat({}, surfaceAttrs.contours.x.show, {\n description: [\n 'Sets whether or not dynamic contours are shown on hover'\n ].join(' ')\n }),\n color: surfaceAttrs.contours.x.color,\n width: surfaceAttrs.contours.x.width,\n editType: 'calc'\n },\n\n lightposition: {\n x: extendFlat({}, surfaceAttrs.lightposition.x, {dflt: 1e5}),\n y: extendFlat({}, surfaceAttrs.lightposition.y, {dflt: 1e5}),\n z: extendFlat({}, surfaceAttrs.lightposition.z, {dflt: 0}),\n editType: 'calc'\n },\n lighting: extendFlat({\n vertexnormalsepsilon: {\n valType: 'number',\n min: 0.00,\n max: 1,\n dflt: 1e-12, // otherwise finely tessellated things eg. the brain will have no specular light reflection\n editType: 'calc',\n description: 'Epsilon for vertex normals calculation avoids math issues arising from degenerate geometry.'\n },\n facenormalsepsilon: {\n valType: 'number',\n min: 0.00,\n max: 1,\n dflt: 1e-6, // even the brain model doesn't appear to need finer than this\n editType: 'calc',\n description: 'Epsilon for face normals calculation avoids math issues arising from degenerate geometry.'\n },\n editType: 'calc'\n }, surfaceAttrs.lighting),\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {editType: 'calc'}),\n showlegend: extendFlat({}, baseAttrs.showlegend, {dflt: false})\n});\n","'use strict';\n\nvar colorscaleCalc = require('../../components/colorscale/calc');\n\nmodule.exports = function calc(gd, trace) {\n if(trace.intensity) {\n colorscaleCalc(gd, trace, {\n vals: trace.intensity,\n containerStr: '',\n cLetter: 'c'\n });\n }\n};\n","'use strict';\n\nvar createMesh = require('../../../stackgl_modules').gl_mesh3d;\nvar triangulate = require('../../../stackgl_modules').delaunay_triangulate;\nvar alphaShape = require('../../../stackgl_modules').alpha_shape;\nvar convexHull = require('../../../stackgl_modules').convex_hull;\n\nvar parseColorScale = require('../../lib/gl_format_color').parseColorScale;\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar str2RgbaArray = require('../../lib/str2rgbarray');\nvar extractOpts = require('../../components/colorscale').extractOpts;\nvar zip3 = require('../../plots/gl3d/zip3');\n\nfunction Mesh3DTrace(scene, mesh, uid) {\n this.scene = scene;\n this.uid = uid;\n this.mesh = mesh;\n this.name = '';\n this.color = '#fff';\n this.data = null;\n this.showContour = false;\n}\n\nvar proto = Mesh3DTrace.prototype;\n\nproto.handlePick = function(selection) {\n if(selection.object === this.mesh) {\n var selectIndex = selection.index = selection.data.index;\n\n if(selection.data._cellCenter) {\n selection.traceCoordinate = selection.data.dataCoordinate;\n } else {\n selection.traceCoordinate = [\n this.data.x[selectIndex],\n this.data.y[selectIndex],\n this.data.z[selectIndex]\n ];\n }\n\n var text = this.data.hovertext || this.data.text;\n if(isArrayOrTypedArray(text) && text[selectIndex] !== undefined) {\n selection.textLabel = text[selectIndex];\n } else if(text) {\n selection.textLabel = text;\n }\n\n return true;\n }\n};\n\nfunction parseColorArray(colors) {\n var b = [];\n var len = colors.length;\n for(var i = 0; i < len; i++) {\n b[i] = str2RgbaArray(colors[i]);\n }\n return b;\n}\n\n// Unpack position data\nfunction toDataCoords(axis, coord, scale, calendar) {\n var b = [];\n var len = coord.length;\n for(var i = 0; i < len; i++) {\n b[i] = axis.d2l(coord[i], 0, calendar) * scale;\n }\n return b;\n}\n\n// Round indices if passed as floats\nfunction toRoundIndex(a) {\n var b = [];\n var len = a.length;\n for(var i = 0; i < len; i++) {\n b[i] = Math.round(a[i]);\n }\n return b;\n}\n\nfunction delaunayCells(delaunayaxis, positions) {\n var d = ['x', 'y', 'z'].indexOf(delaunayaxis);\n var b = [];\n var len = positions.length;\n for(var i = 0; i < len; i++) {\n b[i] = [positions[i][(d + 1) % 3], positions[i][(d + 2) % 3]];\n }\n return triangulate(b);\n}\n\n// Validate indices\nfunction hasValidIndices(list, numVertices) {\n var len = list.length;\n for(var i = 0; i < len; i++) {\n if(list[i] <= -0.5 || list[i] >= numVertices - 0.5) { // Note: the indices would be rounded -0.49 is valid.\n return false;\n }\n }\n return true;\n}\n\nproto.update = function(data) {\n var scene = this.scene;\n var layout = scene.fullSceneLayout;\n\n this.data = data;\n\n var numVertices = data.x.length;\n\n var positions = zip3(\n toDataCoords(layout.xaxis, data.x, scene.dataScale[0], data.xcalendar),\n toDataCoords(layout.yaxis, data.y, scene.dataScale[1], data.ycalendar),\n toDataCoords(layout.zaxis, data.z, scene.dataScale[2], data.zcalendar)\n );\n\n var cells;\n if(data.i && data.j && data.k) {\n if(\n data.i.length !== data.j.length ||\n data.j.length !== data.k.length ||\n !hasValidIndices(data.i, numVertices) ||\n !hasValidIndices(data.j, numVertices) ||\n !hasValidIndices(data.k, numVertices)\n ) {\n return;\n }\n cells = zip3(\n toRoundIndex(data.i),\n toRoundIndex(data.j),\n toRoundIndex(data.k)\n );\n } else if(data.alphahull === 0) {\n cells = convexHull(positions);\n } else if(data.alphahull > 0) {\n cells = alphaShape(data.alphahull, positions);\n } else {\n cells = delaunayCells(data.delaunayaxis, positions);\n }\n\n var config = {\n positions: positions,\n cells: cells,\n lightPosition: [data.lightposition.x, data.lightposition.y, data.lightposition.z],\n ambient: data.lighting.ambient,\n diffuse: data.lighting.diffuse,\n specular: data.lighting.specular,\n roughness: data.lighting.roughness,\n fresnel: data.lighting.fresnel,\n vertexNormalsEpsilon: data.lighting.vertexnormalsepsilon,\n faceNormalsEpsilon: data.lighting.facenormalsepsilon,\n opacity: data.opacity,\n contourEnable: data.contour.show,\n contourColor: str2RgbaArray(data.contour.color).slice(0, 3),\n contourWidth: data.contour.width,\n useFacetNormals: data.flatshading\n };\n\n if(data.intensity) {\n var cOpts = extractOpts(data);\n this.color = '#fff';\n var mode = data.intensitymode;\n config[mode + 'Intensity'] = data.intensity;\n config[mode + 'IntensityBounds'] = [cOpts.min, cOpts.max];\n config.colormap = parseColorScale(data);\n } else if(data.vertexcolor) {\n this.color = data.vertexcolor[0];\n config.vertexColors = parseColorArray(data.vertexcolor);\n } else if(data.facecolor) {\n this.color = data.facecolor[0];\n config.cellColors = parseColorArray(data.facecolor);\n } else {\n this.color = data.color;\n config.meshColor = str2RgbaArray(data.color);\n }\n\n // Update mesh\n this.mesh.update(config);\n};\n\nproto.dispose = function() {\n this.scene.glplot.remove(this.mesh);\n this.mesh.dispose();\n};\n\nfunction createMesh3DTrace(scene, data) {\n var gl = scene.glplot.gl;\n var mesh = createMesh({gl: gl});\n var result = new Mesh3DTrace(scene, mesh, data.uid);\n mesh._trace = result;\n result.update(data);\n scene.glplot.add(mesh);\n return result;\n}\n\nmodule.exports = createMesh3DTrace;\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n // read in face/vertex properties\n function readComponents(array) {\n var ret = array.map(function(attr) {\n var result = coerce(attr);\n\n if(result && Lib.isArrayOrTypedArray(result)) return result;\n return null;\n });\n\n return ret.every(function(x) {\n return x && x.length === ret[0].length;\n }) && ret;\n }\n\n var coords = readComponents(['x', 'y', 'z']);\n if(!coords) {\n traceOut.visible = false;\n return;\n }\n\n readComponents(['i', 'j', 'k']);\n // three indices should be all provided or not\n if(\n (traceOut.i && (!traceOut.j || !traceOut.k)) ||\n (traceOut.j && (!traceOut.k || !traceOut.i)) ||\n (traceOut.k && (!traceOut.i || !traceOut.j))\n ) {\n traceOut.visible = false;\n return;\n }\n\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleTraceDefaults');\n handleCalendarDefaults(traceIn, traceOut, ['x', 'y', 'z'], layout);\n\n // Coerce remaining properties\n [\n 'lighting.ambient',\n 'lighting.diffuse',\n 'lighting.specular',\n 'lighting.roughness',\n 'lighting.fresnel',\n 'lighting.vertexnormalsepsilon',\n 'lighting.facenormalsepsilon',\n 'lightposition.x',\n 'lightposition.y',\n 'lightposition.z',\n 'flatshading',\n 'alphahull',\n 'delaunayaxis',\n 'opacity'\n ].forEach(function(x) { coerce(x); });\n\n var showContour = coerce('contour.show');\n if(showContour) {\n coerce('contour.color');\n coerce('contour.width');\n }\n\n if('intensity' in traceIn) {\n coerce('intensity');\n coerce('intensitymode');\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'c'});\n } else {\n traceOut.showscale = false;\n\n if('facecolor' in traceIn) coerce('facecolor');\n else if('vertexcolor' in traceIn) coerce('vertexcolor');\n else coerce('color', defaultColor);\n }\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n coerce('xhoverformat');\n coerce('yhoverformat');\n coerce('zhoverformat');\n\n // disable 1D transforms\n // x/y/z should match lengths, and i/j/k should match as well, but\n // the two sets have different lengths so transforms wouldn't work.\n traceOut._length = null;\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n calc: require('./calc'),\n colorbar: {\n min: 'cmin',\n max: 'cmax'\n },\n plot: require('./convert'),\n\n moduleType: 'trace',\n name: 'mesh3d',\n basePlotModule: require('../../plots/gl3d'),\n categories: ['gl3d', 'showLegend'],\n meta: {\n description: [\n 'Draws sets of triangles with coordinates given by',\n 'three 1-dimensional arrays in `x`, `y`, `z` and',\n '(1) a sets of `i`, `j`, `k` indices',\n '(2) Delaunay triangulation or',\n '(3) the Alpha-shape algorithm or',\n '(4) the Convex-hull algorithm'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar extendFlat = require('../../lib').extendFlat;\nvar scatterAttrs = require('../scatter/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar dash = require('../../components/drawing/attributes').dash;\nvar fxAttrs = require('../../components/fx/attributes');\nvar delta = require('../../constants/delta.js');\n\nvar INCREASING_COLOR = delta.INCREASING.COLOR;\nvar DECREASING_COLOR = delta.DECREASING.COLOR;\n\nvar lineAttrs = scatterAttrs.line;\n\nfunction directionAttrs(lineColorDefault) {\n return {\n line: {\n color: extendFlat({}, lineAttrs.color, {dflt: lineColorDefault}),\n width: lineAttrs.width,\n dash: dash,\n editType: 'style'\n },\n editType: 'style'\n };\n}\n\nmodule.exports = {\n\n xperiod: scatterAttrs.xperiod,\n xperiod0: scatterAttrs.xperiod0,\n xperiodalignment: scatterAttrs.xperiodalignment,\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n\n x: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the x coordinates.',\n 'If absent, linear coordinate will be generated.'\n ].join(' ')\n },\n\n open: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the open values.'\n },\n\n high: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the high values.'\n },\n\n low: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the low values.'\n },\n\n close: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the close values.'\n },\n\n line: {\n width: extendFlat({}, lineAttrs.width, {\n description: [\n lineAttrs.width,\n 'Note that this style setting can also be set per',\n 'direction via `increasing.line.width` and',\n '`decreasing.line.width`.'\n ].join(' ')\n }),\n dash: extendFlat({}, dash, {\n description: [\n dash.description,\n 'Note that this style setting can also be set per',\n 'direction via `increasing.line.dash` and',\n '`decreasing.line.dash`.'\n ].join(' ')\n }),\n editType: 'style'\n },\n\n increasing: directionAttrs(INCREASING_COLOR),\n\n decreasing: directionAttrs(DECREASING_COLOR),\n\n text: {\n valType: 'string',\n dflt: '',\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Sets hover text elements associated with each sample point.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to',\n 'this trace\\'s sample points.'\n ].join(' ')\n },\n hovertext: {\n valType: 'string',\n dflt: '',\n arrayOk: true,\n editType: 'calc',\n description: 'Same as `text`.'\n },\n\n tickwidth: {\n valType: 'number',\n min: 0,\n max: 0.5,\n dflt: 0.3,\n editType: 'calc',\n description: [\n 'Sets the width of the open/close tick marks',\n 'relative to the *x* minimal interval.'\n ].join(' ')\n },\n\n hoverlabel: extendFlat({}, fxAttrs.hoverlabel, {\n split: {\n valType: 'boolean',\n dflt: false,\n editType: 'style',\n description: [\n 'Show hover information (open, close, high, low) in',\n 'separate labels.'\n ].join(' ')\n }\n }),\n\n zorder: scatterAttrs.zorder\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar _ = Lib._;\nvar Axes = require('../../plots/cartesian/axes');\nvar alignPeriod = require('../../plots/cartesian/align_period');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nfunction calc(gd, trace) {\n var xa = Axes.getFromId(gd, trace.xaxis);\n var ya = Axes.getFromId(gd, trace.yaxis);\n\n var tickLen = convertTickWidth(gd, xa, trace);\n var minDiff = trace._minDiff;\n trace._minDiff = null;\n var origX = trace._origX;\n trace._origX = null;\n var x = trace._xcalc;\n trace._xcalc = null;\n\n var cd = calcCommon(gd, trace, origX, x, ya, ptFunc);\n\n trace._extremes[xa._id] = Axes.findExtremes(xa, x, {vpad: minDiff / 2});\n if(cd.length) {\n Lib.extendFlat(cd[0].t, {\n wHover: minDiff / 2,\n tickLen: tickLen\n });\n return cd;\n } else {\n return [{t: {empty: true}}];\n }\n}\n\nfunction ptFunc(o, h, l, c) {\n return {\n o: o,\n h: h,\n l: l,\n c: c\n };\n}\n\n\n// shared between OHLC and candlestick\n// ptFunc makes a calcdata point specific to each trace type, from oi, hi, li, ci\nfunction calcCommon(gd, trace, origX, x, ya, ptFunc) {\n var o = ya.makeCalcdata(trace, 'open');\n var h = ya.makeCalcdata(trace, 'high');\n var l = ya.makeCalcdata(trace, 'low');\n var c = ya.makeCalcdata(trace, 'close');\n\n var hasTextArray = Lib.isArrayOrTypedArray(trace.text);\n var hasHovertextArray = Lib.isArrayOrTypedArray(trace.hovertext);\n\n // we're optimists - before we have any changing data, assume increasing\n var increasing = true;\n var cPrev = null;\n\n var hasPeriod = !!trace.xperiodalignment;\n\n var cd = [];\n for(var i = 0; i < x.length; i++) {\n var xi = x[i];\n var oi = o[i];\n var hi = h[i];\n var li = l[i];\n var ci = c[i];\n\n if(xi !== BADNUM && oi !== BADNUM && hi !== BADNUM && li !== BADNUM && ci !== BADNUM) {\n if(ci === oi) {\n // if open == close, look for a change from the previous close\n if(cPrev !== null && ci !== cPrev) increasing = ci > cPrev;\n // else (c === cPrev or cPrev is null) no change\n } else increasing = ci > oi;\n\n cPrev = ci;\n\n var pt = ptFunc(oi, hi, li, ci);\n\n pt.pos = xi;\n pt.yc = (oi + ci) / 2;\n pt.i = i;\n pt.dir = increasing ? 'increasing' : 'decreasing';\n\n // For categoryorder, store low and high\n pt.x = pt.pos;\n pt.y = [li, hi];\n\n if(hasPeriod) pt.orig_p = origX[i]; // used by hover\n if(hasTextArray) pt.tx = trace.text[i];\n if(hasHovertextArray) pt.htx = trace.hovertext[i];\n\n cd.push(pt);\n } else {\n cd.push({pos: xi, empty: true});\n }\n }\n\n trace._extremes[ya._id] = Axes.findExtremes(ya, Lib.concat(l, h), {padded: true});\n\n if(cd.length) {\n cd[0].t = {\n labels: {\n open: _(gd, 'open:') + ' ',\n high: _(gd, 'high:') + ' ',\n low: _(gd, 'low:') + ' ',\n close: _(gd, 'close:') + ' '\n }\n };\n }\n\n return cd;\n}\n\n/*\n * find min x-coordinates difference of all traces\n * attached to this x-axis and stash the result in _minDiff\n * in all traces; when a trace uses this in its\n * calc step it deletes _minDiff, so that next calc this is\n * done again in case the data changed.\n * also since we need it here, stash _xcalc (and _origX) on the trace\n */\nfunction convertTickWidth(gd, xa, trace) {\n var minDiff = trace._minDiff;\n\n if(!minDiff) {\n var fullData = gd._fullData;\n var ohlcTracesOnThisXaxis = [];\n\n minDiff = Infinity;\n\n var i;\n\n for(i = 0; i < fullData.length; i++) {\n var tracei = fullData[i];\n\n if(tracei.type === 'ohlc' &&\n tracei.visible === true &&\n tracei.xaxis === xa._id\n ) {\n ohlcTracesOnThisXaxis.push(tracei);\n\n var origX = xa.makeCalcdata(tracei, 'x');\n tracei._origX = origX;\n\n var xcalc = alignPeriod(trace, xa, 'x', origX).vals;\n tracei._xcalc = xcalc;\n\n var _minDiff = Lib.distinctVals(xcalc).minDiff;\n if(_minDiff && isFinite(_minDiff)) {\n minDiff = Math.min(minDiff, _minDiff);\n }\n }\n }\n\n // if minDiff is still Infinity here, set it to 1\n if(minDiff === Infinity) minDiff = 1;\n\n for(i = 0; i < ohlcTracesOnThisXaxis.length; i++) {\n ohlcTracesOnThisXaxis[i]._minDiff = minDiff;\n }\n }\n\n return minDiff * trace.tickwidth;\n}\n\nmodule.exports = {\n calc: calc,\n calcCommon: calcCommon\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar handleOHLC = require('./ohlc_defaults');\nvar handlePeriodDefaults = require('../scatter/period_defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleOHLC(traceIn, traceOut, coerce, layout);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n handlePeriodDefaults(traceIn, traceOut, layout, coerce, {x: true});\n coerce('xhoverformat');\n coerce('yhoverformat');\n\n coerce('line.width');\n coerce('line.dash');\n\n handleDirection(traceIn, traceOut, coerce, 'increasing');\n handleDirection(traceIn, traceOut, coerce, 'decreasing');\n\n coerce('text');\n coerce('hovertext');\n coerce('tickwidth');\n\n layout._requestRangeslider[traceOut.xaxis] = true;\n\n coerce('zorder');\n};\n\nfunction handleDirection(traceIn, traceOut, coerce, direction) {\n coerce(direction + '.line.color');\n coerce(direction + '.line.width', traceOut.line.width);\n coerce(direction + '.line.dash', traceOut.line.dash);\n}\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\nvar Lib = require('../../lib');\nvar Fx = require('../../components/fx');\nvar Color = require('../../components/color');\nvar fillText = require('../../lib').fillText;\nvar delta = require('../../constants/delta.js');\n\nvar DIRSYMBOL = {\n increasing: delta.INCREASING.SYMBOL,\n decreasing: delta.DECREASING.SYMBOL\n};\n\nfunction hoverPoints(pointData, xval, yval, hovermode) {\n var cd = pointData.cd;\n var trace = cd[0].trace;\n\n if(trace.hoverlabel.split) {\n return hoverSplit(pointData, xval, yval, hovermode);\n }\n\n return hoverOnPoints(pointData, xval, yval, hovermode);\n}\n\nfunction _getClosestPoint(pointData, xval, yval, hovermode) {\n var cd = pointData.cd;\n var xa = pointData.xa;\n var trace = cd[0].trace;\n var t = cd[0].t;\n\n var type = trace.type;\n var minAttr = type === 'ohlc' ? 'l' : 'min';\n var maxAttr = type === 'ohlc' ? 'h' : 'max';\n\n var hoverPseudoDistance, spikePseudoDistance;\n\n // potentially shift xval for grouped candlesticks\n var centerShift = t.bPos || 0;\n var shiftPos = function(di) { return di.pos + centerShift - xval; };\n\n // ohlc and candlestick call displayHalfWidth different things...\n var displayHalfWidth = t.bdPos || t.tickLen;\n var hoverHalfWidth = t.wHover;\n\n // if two figures are overlaying, let the narrowest one win\n var pseudoDistance = Math.min(1, displayHalfWidth / Math.abs(xa.r2c(xa.range[1]) - xa.r2c(xa.range[0])));\n hoverPseudoDistance = pointData.maxHoverDistance - pseudoDistance;\n spikePseudoDistance = pointData.maxSpikeDistance - pseudoDistance;\n\n function dx(di) {\n var pos = shiftPos(di);\n return Fx.inbox(pos - hoverHalfWidth, pos + hoverHalfWidth, hoverPseudoDistance);\n }\n\n function dy(di) {\n var min = di[minAttr];\n var max = di[maxAttr];\n return min === max || Fx.inbox(min - yval, max - yval, hoverPseudoDistance);\n }\n\n function dxy(di) { return (dx(di) + dy(di)) / 2; }\n\n var distfn = Fx.getDistanceFunction(hovermode, dx, dy, dxy);\n Fx.getClosest(cd, distfn, pointData);\n\n if(pointData.index === false) return null;\n\n var di = cd[pointData.index];\n\n if(di.empty) return null;\n\n var dir = di.dir;\n var container = trace[dir];\n var lc = container.line.color;\n\n if(Color.opacity(lc) && container.line.width) pointData.color = lc;\n else pointData.color = container.fillcolor;\n\n pointData.x0 = xa.c2p(di.pos + centerShift - displayHalfWidth, true);\n pointData.x1 = xa.c2p(di.pos + centerShift + displayHalfWidth, true);\n\n pointData.xLabelVal = di.orig_p !== undefined ? di.orig_p : di.pos;\n\n pointData.spikeDistance = dxy(di) * spikePseudoDistance / hoverPseudoDistance;\n pointData.xSpike = xa.c2p(di.pos, true);\n\n return pointData;\n}\n\nfunction hoverSplit(pointData, xval, yval, hovermode) {\n var cd = pointData.cd;\n var ya = pointData.ya;\n var trace = cd[0].trace;\n var t = cd[0].t;\n var closeBoxData = [];\n\n var closestPoint = _getClosestPoint(pointData, xval, yval, hovermode);\n // skip the rest (for this trace) if we didn't find a close point\n if(!closestPoint) return [];\n\n var cdIndex = closestPoint.index;\n var di = cd[cdIndex];\n var hoverinfo = di.hi || trace.hoverinfo;\n var hoverParts = hoverinfo.split('+');\n var isAll = hoverinfo === 'all';\n var hasY = isAll || hoverParts.indexOf('y') !== -1;\n\n // similar to hoverOnPoints, we return nothing\n // if all or y is not present.\n if(!hasY) return [];\n\n var attrs = ['high', 'open', 'close', 'low'];\n\n // several attributes can have the same y-coordinate. We will\n // bunch them together in a single text block. For this, we keep\n // a dictionary mapping y-coord -> point data.\n var usedVals = {};\n\n for(var i = 0; i < attrs.length; i++) {\n var attr = attrs[i];\n\n var val = trace[attr][closestPoint.index];\n var valPx = ya.c2p(val, true);\n var pointData2;\n if(val in usedVals) {\n pointData2 = usedVals[val];\n pointData2.yLabel += '
' + t.labels[attr] + Axes.hoverLabelText(ya, val, trace.yhoverformat);\n } else {\n // copy out to a new object for each new y-value to label\n pointData2 = Lib.extendFlat({}, closestPoint);\n\n pointData2.y0 = pointData2.y1 = valPx;\n pointData2.yLabelVal = val;\n pointData2.yLabel = t.labels[attr] + Axes.hoverLabelText(ya, val, trace.yhoverformat);\n\n pointData2.name = '';\n\n closeBoxData.push(pointData2);\n usedVals[val] = pointData2;\n }\n }\n\n return closeBoxData;\n}\n\nfunction hoverOnPoints(pointData, xval, yval, hovermode) {\n var cd = pointData.cd;\n var ya = pointData.ya;\n var trace = cd[0].trace;\n var t = cd[0].t;\n\n var closestPoint = _getClosestPoint(pointData, xval, yval, hovermode);\n // skip the rest (for this trace) if we didn't find a close point\n if(!closestPoint) return [];\n\n // we don't make a calcdata point if we're missing any piece (x/o/h/l/c)\n // so we need to fix the index here to point to the data arrays\n var cdIndex = closestPoint.index;\n var di = cd[cdIndex];\n var i = closestPoint.index = di.i;\n var dir = di.dir;\n\n function getLabelLine(attr) {\n return t.labels[attr] + Axes.hoverLabelText(ya, trace[attr][i], trace.yhoverformat);\n }\n\n var hoverinfo = di.hi || trace.hoverinfo;\n var hoverParts = hoverinfo.split('+');\n var isAll = hoverinfo === 'all';\n var hasY = isAll || hoverParts.indexOf('y') !== -1;\n var hasText = isAll || hoverParts.indexOf('text') !== -1;\n\n var textParts = hasY ? [\n getLabelLine('open'),\n getLabelLine('high'),\n getLabelLine('low'),\n getLabelLine('close') + ' ' + DIRSYMBOL[dir]\n ] : [];\n if(hasText) fillText(di, trace, textParts);\n\n // don't make .yLabelVal or .text, since we're managing hoverinfo\n // put it all in .extraText\n closestPoint.extraText = textParts.join('
');\n\n // this puts the label *and the spike* at the midpoint of the box, ie\n // halfway between open and close, not between high and low.\n closestPoint.y0 = closestPoint.y1 = ya.c2p(di.yc, true);\n\n return [closestPoint];\n}\n\nmodule.exports = {\n hoverPoints: hoverPoints,\n hoverSplit: hoverSplit,\n hoverOnPoints: hoverOnPoints\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'ohlc',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['cartesian', 'svg', 'showLegend'],\n meta: {\n description: [\n 'The ohlc (short for Open-High-Low-Close) is a style of financial chart describing',\n 'open, high, low and close for a given `x` coordinate (most likely time).',\n\n 'The tip of the lines represent the `low` and `high` values and',\n 'the horizontal segments represent the `open` and `close` values.',\n\n 'Sample points where the close value is higher (lower) then the open',\n 'value are called increasing (decreasing).',\n\n 'By default, increasing items are drawn in green whereas',\n 'decreasing are drawn in red.'\n ].join(' ')\n },\n\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n calc: require('./calc').calc,\n plot: require('./plot'),\n style: require('./style'),\n hoverPoints: require('./hover').hoverPoints,\n selectPoints: require('./select')\n};\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\n\nmodule.exports = function handleOHLC(traceIn, traceOut, coerce, layout) {\n var x = coerce('x');\n var open = coerce('open');\n var high = coerce('high');\n var low = coerce('low');\n var close = coerce('close');\n\n coerce('hoverlabel.split');\n\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleTraceDefaults');\n handleCalendarDefaults(traceIn, traceOut, ['x'], layout);\n\n if(!(open && high && low && close)) return;\n\n var len = Math.min(open.length, high.length, low.length, close.length);\n if(x) len = Math.min(len, Lib.minRowLength(x));\n traceOut._length = len;\n\n return len;\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Lib = require('../../lib');\n\nmodule.exports = function plot(gd, plotinfo, cdOHLC, ohlcLayer) {\n var ya = plotinfo.yaxis;\n var xa = plotinfo.xaxis;\n var posHasRangeBreaks = !!xa.rangebreaks;\n\n Lib.makeTraceGroups(ohlcLayer, cdOHLC, 'trace ohlc').each(function(cd) {\n var plotGroup = d3.select(this);\n var cd0 = cd[0];\n var t = cd0.t;\n var trace = cd0.trace;\n\n if(trace.visible !== true || t.empty) {\n plotGroup.remove();\n return;\n }\n\n var tickLen = t.tickLen;\n\n var paths = plotGroup.selectAll('path').data(Lib.identity);\n\n paths.enter().append('path');\n\n paths.exit().remove();\n\n paths.attr('d', function(d) {\n if(d.empty) return 'M0,0Z';\n\n var xo = xa.c2p(d.pos - tickLen, true);\n var xc = xa.c2p(d.pos + tickLen, true);\n var x = posHasRangeBreaks ? (xo + xc) / 2 : xa.c2p(d.pos, true);\n\n var yo = ya.c2p(d.o, true);\n var yh = ya.c2p(d.h, true);\n var yl = ya.c2p(d.l, true);\n var yc = ya.c2p(d.c, true);\n\n return 'M' + xo + ',' + yo + 'H' + x +\n 'M' + x + ',' + yh + 'V' + yl +\n 'M' + xc + ',' + yc + 'H' + x;\n });\n });\n};\n","'use strict';\n\nmodule.exports = function selectPoints(searchInfo, selectionTester) {\n var cd = searchInfo.cd;\n var xa = searchInfo.xaxis;\n var ya = searchInfo.yaxis;\n var selection = [];\n var i;\n // for (potentially grouped) candlesticks\n var posOffset = cd[0].t.bPos || 0;\n\n if(selectionTester === false) {\n // clear selection\n for(i = 0; i < cd.length; i++) {\n cd[i].selected = 0;\n }\n } else {\n for(i = 0; i < cd.length; i++) {\n var di = cd[i];\n\n if(selectionTester.contains([xa.c2p(di.pos + posOffset), ya.c2p(di.yc)], null, di.i, searchInfo)) {\n selection.push({\n pointNumber: di.i,\n x: xa.c2d(di.pos),\n y: ya.c2d(di.yc)\n });\n di.selected = 1;\n } else {\n di.selected = 0;\n }\n }\n }\n\n return selection;\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Drawing = require('../../components/drawing');\nvar Color = require('../../components/color');\n\nmodule.exports = function style(gd, cd, sel) {\n var s = sel ? sel : d3.select(gd).selectAll('g.ohlclayer').selectAll('g.trace');\n\n s.style('opacity', function(d) {\n return d[0].trace.opacity;\n });\n\n s.each(function(d) {\n var trace = d[0].trace;\n\n d3.select(this).selectAll('path').each(function(di) {\n if(di.empty) return;\n\n var dirLine = trace[di.dir].line;\n d3.select(this)\n .style('fill', 'none')\n .call(Color.stroke, dirLine.color)\n .call(Drawing.dashLine, dirLine.dash, dirLine.width)\n // TODO: custom selection style for OHLC\n .style('opacity', trace.selectedpoints && !di.selected ? 0.3 : 1);\n });\n });\n};\n","'use strict';\n\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar baseAttrs = require('../../plots/attributes');\nvar fontAttrs = require('../../plots/font_attributes');\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar domainAttrs = require('../../plots/domain').attributes;\n\nvar line = extendFlat(\n {editType: 'calc'},\n colorScaleAttrs('line', {editTypeOverride: 'calc'}),\n {\n shape: {\n valType: 'enumerated',\n values: ['linear', 'hspline'],\n dflt: 'linear',\n editType: 'plot',\n description: [\n 'Sets the shape of the paths.',\n 'If `linear`, paths are composed of straight lines.',\n 'If `hspline`, paths are composed of horizontal curved splines'\n ].join(' ')\n },\n\n hovertemplate: hovertemplateAttrs({\n editType: 'plot',\n arrayOk: false\n }, {\n keys: ['count', 'probability'],\n description: [\n 'This value here applies when hovering over lines.'\n ].join(' ')\n })\n }\n);\n\nmodule.exports = {\n domain: domainAttrs({name: 'parcats', trace: true, editType: 'calc'}),\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['count', 'probability'],\n editType: 'plot',\n arrayOk: false\n }),\n hoveron: {\n valType: 'enumerated',\n values: ['category', 'color', 'dimension'],\n dflt: 'category',\n editType: 'plot',\n description: [\n 'Sets the hover interaction mode for the parcats diagram.',\n 'If `category`, hover interaction take place per category.',\n 'If `color`, hover interactions take place per color per category.',\n 'If `dimension`, hover interactions take place across all categories per dimension.'\n ].join(' ')\n },\n hovertemplate: hovertemplateAttrs({\n editType: 'plot',\n arrayOk: false\n }, {\n keys: [\n 'count', 'probability', 'category',\n 'categorycount', 'colorcount', 'bandcolorcount'\n ],\n description: [\n 'This value here applies when hovering over dimensions.',\n 'Note that `*categorycount`, *colorcount* and *bandcolorcount*',\n 'are only available when `hoveron` contains the *color* flag'\n ].join(' ')\n }),\n\n arrangement: {\n valType: 'enumerated',\n values: ['perpendicular', 'freeform', 'fixed'],\n dflt: 'perpendicular',\n editType: 'plot',\n description: [\n 'Sets the drag interaction mode for categories and dimensions.',\n 'If `perpendicular`, the categories can only move along a line perpendicular to the paths.',\n 'If `freeform`, the categories can freely move on the plane.',\n 'If `fixed`, the categories and dimensions are stationary.'\n ].join(' ')\n },\n bundlecolors: {\n valType: 'boolean',\n dflt: true,\n editType: 'plot',\n description: 'Sort paths so that like colors are bundled together within each category.'\n },\n sortpaths: {\n valType: 'enumerated',\n values: ['forward', 'backward'],\n dflt: 'forward',\n editType: 'plot',\n description: [\n 'Sets the path sorting algorithm.',\n 'If `forward`, sort paths based on dimension categories from left to right.',\n 'If `backward`, sort paths based on dimensions categories from right to left.'\n ].join(' ')\n },\n labelfont: fontAttrs({\n editType: 'calc',\n description: 'Sets the font for the `dimension` labels.'\n }),\n\n tickfont: fontAttrs({\n autoShadowDflt: true,\n editType: 'calc',\n description: 'Sets the font for the `category` labels.'\n }),\n\n dimensions: {\n _isLinkedToArray: 'dimension',\n label: {\n valType: 'string',\n editType: 'calc',\n description: 'The shown name of the dimension.'\n },\n categoryorder: {\n valType: 'enumerated',\n values: [\n 'trace', 'category ascending', 'category descending', 'array'\n ],\n dflt: 'trace',\n editType: 'calc',\n description: [\n 'Specifies the ordering logic for the categories in the dimension.',\n 'By default, plotly uses *trace*, which specifies the order that is present in the data supplied.',\n 'Set `categoryorder` to *category ascending* or *category descending* if order should be determined by',\n 'the alphanumerical order of the category names.',\n 'Set `categoryorder` to *array* to derive the ordering from the attribute `categoryarray`. If a category',\n 'is not found in the `categoryarray` array, the sorting behavior for that attribute will be identical to',\n 'the *trace* mode. The unspecified categories will follow the categories in `categoryarray`.'\n ].join(' ')\n },\n categoryarray: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the order in which categories in this dimension appear.',\n 'Only has an effect if `categoryorder` is set to *array*.',\n 'Used with `categoryorder`.'\n ].join(' ')\n },\n ticktext: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets alternative tick labels for the categories in this dimension.',\n 'Only has an effect if `categoryorder` is set to *array*.',\n 'Should be an array the same length as `categoryarray`',\n 'Used with `categoryorder`.'\n ].join(' ')\n },\n values: {\n valType: 'data_array',\n dflt: [],\n editType: 'calc',\n description: [\n 'Dimension values. `values[n]` represents the category value of the `n`th point in the dataset,',\n 'therefore the `values` vector for all dimensions must be the same (longer vectors',\n 'will be truncated).'\n ].join(' ')\n },\n displayindex: {\n valType: 'integer',\n editType: 'calc',\n description: [\n 'The display index of dimension, from left to right, zero indexed, defaults to dimension',\n 'index.'\n ].join(' ')\n },\n editType: 'calc',\n description: 'The dimensions (variables) of the parallel categories diagram.',\n visible: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: 'Shows the dimension when set to `true` (the default). Hides the dimension for `false`.'\n }\n },\n\n line: line,\n counts: {\n valType: 'number',\n min: 0,\n dflt: 1,\n arrayOk: true,\n editType: 'calc',\n description: [\n 'The number of observations represented by each state. Defaults to 1 so that each state represents',\n 'one observation'\n ].join(' ')\n },\n\n // Hide unsupported top-level properties from plot-schema\n customdata: undefined,\n hoverlabel: undefined,\n ids: undefined,\n legend: undefined,\n legendgroup: undefined,\n legendrank: undefined,\n opacity: undefined,\n selectedpoints: undefined,\n showlegend: undefined\n};\n","'use strict';\n\nvar getModuleCalcData = require('../../plots/get_data').getModuleCalcData;\nvar parcatsPlot = require('./plot');\n\nvar PARCATS = 'parcats';\nexports.name = PARCATS;\n\nexports.plot = function(gd, traces, transitionOpts, makeOnCompleteCallback) {\n var cdModuleAndOthers = getModuleCalcData(gd.calcdata, PARCATS);\n\n if(cdModuleAndOthers.length) {\n var calcData = cdModuleAndOthers[0];\n parcatsPlot(gd, calcData, transitionOpts, makeOnCompleteCallback);\n }\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var hadTable = (oldFullLayout._has && oldFullLayout._has('parcats'));\n var hasTable = (newFullLayout._has && newFullLayout._has('parcats'));\n\n if(hadTable && !hasTable) {\n oldFullLayout._paperdiv.selectAll('.parcats').remove();\n }\n};\n","'use strict';\n\n// Requirements\n// ============\nvar wrap = require('../../lib/gup').wrap;\nvar hasColorscale = require('../../components/colorscale/helpers').hasColorscale;\nvar colorscaleCalc = require('../../components/colorscale/calc');\nvar filterUnique = require('../../lib/filter_unique.js');\nvar Drawing = require('../../components/drawing');\nvar Lib = require('../../lib');\nvar isNumeric = require('fast-isnumeric');\n\n/**\n * Create a wrapped ParcatsModel object from trace\n *\n * Note: trace defaults have already been applied\n * @param {Object} gd\n * @param {Object} trace\n * @return {Array.}\n */\nmodule.exports = function calc(gd, trace) {\n var visibleDims = Lib.filterVisible(trace.dimensions);\n\n if(visibleDims.length === 0) return [];\n\n var uniqueInfoDims = visibleDims.map(function(dim) {\n var categoryValues;\n if(dim.categoryorder === 'trace') {\n // Use order of first occurrence in trace\n categoryValues = null;\n } else if(dim.categoryorder === 'array') {\n // Use categories specified in `categoryarray` first,\n // then add extra to the end in trace order\n categoryValues = dim.categoryarray;\n } else {\n // Get all categories up front\n categoryValues = filterUnique(dim.values);\n\n // order them\n var allNumeric = true;\n for(var i = 0; i < categoryValues.length; i++) {\n if(!isNumeric(categoryValues[i])) {\n allNumeric = false;\n break;\n }\n }\n categoryValues.sort(allNumeric ? Lib.sorterAsc : undefined);\n\n if(dim.categoryorder === 'category descending') {\n categoryValues = categoryValues.reverse();\n }\n }\n return getUniqueInfo(dim.values, categoryValues);\n });\n\n var counts,\n count,\n totalCount;\n if(Lib.isArrayOrTypedArray(trace.counts)) {\n counts = trace.counts;\n } else {\n counts = [trace.counts];\n }\n\n validateDimensionDisplayInds(visibleDims);\n\n visibleDims.forEach(function(dim, dimInd) {\n validateCategoryProperties(dim, uniqueInfoDims[dimInd]);\n });\n\n // Handle path colors\n // ------------------\n var line = trace.line;\n var markerColorscale;\n\n // Process colorscale\n if(line) {\n if(hasColorscale(trace, 'line')) {\n colorscaleCalc(gd, trace, {\n vals: trace.line.color,\n containerStr: 'line',\n cLetter: 'c'\n });\n }\n markerColorscale = Drawing.tryColorscale(line);\n } else {\n markerColorscale = Lib.identity;\n }\n\n // Build color generation function\n function getMarkerColorInfo(index) {\n var value, rawColor;\n if(Lib.isArrayOrTypedArray(line.color)) {\n value = line.color[index % line.color.length];\n rawColor = value;\n } else {\n value = line.color;\n }\n\n return {color: markerColorscale(value), rawColor: rawColor};\n }\n\n // Number of values and counts\n // ---------------------------\n var numValues = visibleDims[0].values.length;\n\n // Build path info\n // ---------------\n // Mapping from category inds to PathModel objects\n var pathModels = {};\n\n // Category inds array for each dimension\n var categoryIndsDims = uniqueInfoDims.map(function(di) {return di.inds;});\n\n // Initialize total count\n totalCount = 0;\n var valueInd;\n var d;\n\n for(valueInd = 0; valueInd < numValues; valueInd++) {\n // Category inds for this input value across dimensions\n var categoryIndsPath = [];\n for(d = 0; d < categoryIndsDims.length; d++) {\n categoryIndsPath.push(categoryIndsDims[d][valueInd]);\n }\n\n // Count\n count = counts[valueInd % counts.length];\n\n // Update total count\n totalCount += count;\n\n // Path color\n var pathColorInfo = getMarkerColorInfo(valueInd);\n\n // path key\n var pathKey = categoryIndsPath + '-' + pathColorInfo.rawColor;\n\n // Create / Update PathModel\n if(pathModels[pathKey] === undefined) {\n pathModels[pathKey] = createPathModel(categoryIndsPath,\n pathColorInfo.color,\n pathColorInfo.rawColor);\n }\n updatePathModel(pathModels[pathKey], valueInd, count);\n }\n\n var dimensionModels = visibleDims.map(function(di, i) {\n return createDimensionModel(i, di._index, di._displayindex, di.label, totalCount);\n });\n\n\n for(valueInd = 0; valueInd < numValues; valueInd++) {\n count = counts[valueInd % counts.length];\n\n for(d = 0; d < dimensionModels.length; d++) {\n var containerInd = dimensionModels[d].containerInd;\n var catInd = uniqueInfoDims[d].inds[valueInd];\n var cats = dimensionModels[d].categories;\n\n if(cats[catInd] === undefined) {\n var catValue = trace.dimensions[containerInd]._categoryarray[catInd];\n var catLabel = trace.dimensions[containerInd]._ticktext[catInd];\n cats[catInd] = createCategoryModel(d, catInd, catValue, catLabel);\n }\n\n updateCategoryModel(cats[catInd], valueInd, count);\n }\n }\n\n // Compute unique\n return wrap(createParcatsModel(dimensionModels, pathModels, totalCount));\n};\n\n// Models\n// ======\n\n// Parcats Model\n// -------------\n/**\n * @typedef {Object} ParcatsModel\n * Object containing calculated information about a parcats trace\n *\n * @property {Array.} dimensions\n * Array of dimension models\n * @property {Object.} paths\n * Dictionary from category inds string (e.g. \"1,2,1,1\") to path model\n * @property {Number} maxCats\n * The maximum number of categories of any dimension in the diagram\n * @property {Number} count\n * Total number of input values\n * @property {Object} trace\n */\n\n/**\n * Create and new ParcatsModel object\n * @param {Array.} dimensions\n * @param {Object.} paths\n * @param {Number} count\n * @return {ParcatsModel}\n */\nfunction createParcatsModel(dimensions, paths, count) {\n var maxCats = dimensions\n .map(function(d) {return d.categories.length;})\n .reduce(function(v1, v2) {return Math.max(v1, v2);});\n return {dimensions: dimensions, paths: paths, trace: undefined, maxCats: maxCats, count: count};\n}\n\n// Dimension Model\n// ---------------\n/**\n * @typedef {Object} DimensionModel\n * Object containing calculated information about a single dimension\n *\n * @property {Number} dimensionInd\n * The index of this dimension among the *visible* dimensions\n * @property {Number} containerInd\n * The index of this dimension in the original dimensions container,\n * irrespective of dimension visibility\n * @property {Number} displayInd\n * The display index of this dimension (where 0 is the left most dimension)\n * @property {String} dimensionLabel\n * The label of this dimension\n * @property {Number} count\n * Total number of input values\n * @property {Array.} categories\n * @property {Number|null} dragX\n * The x position of dimension that is currently being dragged. null if not being dragged\n */\n\n/**\n * Create and new DimensionModel object with an empty categories array\n * @param {Number} dimensionInd\n * @param {Number} containerInd\n * @param {Number} displayInd\n * @param {String} dimensionLabel\n * @param {Number} count\n * Total number of input values\n * @return {DimensionModel}\n */\nfunction createDimensionModel(dimensionInd, containerInd, displayInd, dimensionLabel, count) {\n return {\n dimensionInd: dimensionInd,\n containerInd: containerInd,\n displayInd: displayInd,\n dimensionLabel: dimensionLabel,\n count: count,\n categories: [],\n dragX: null\n };\n}\n\n// Category Model\n// --------------\n/**\n * @typedef {Object} CategoryModel\n * Object containing calculated information about a single category.\n *\n * @property {Number} dimensionInd\n * The index of this categories dimension\n * @property {Number} categoryInd\n * The index of this category\n * @property {Number} displayInd\n * The display index of this category (where 0 is the topmost category)\n * @property {String} categoryLabel\n * The name of this category\n * @property categoryValue: Raw value of the category\n * @property {Array} valueInds\n * Array of indices (into the original value array) of all samples in this category\n * @property {Number} count\n * The number of elements from the original array in this path\n * @property {Number|null} dragY\n * The y position of category that is currently being dragged. null if not being dragged\n */\n\n/**\n * Create and return a new CategoryModel object\n * @param {Number} dimensionInd\n * @param {Number} categoryInd\n * The display index of this category (where 0 is the topmost category)\n * @param {String} categoryValue\n * @param {String} categoryLabel\n * @return {CategoryModel}\n */\nfunction createCategoryModel(dimensionInd, categoryInd, categoryValue, categoryLabel) {\n return {\n dimensionInd: dimensionInd,\n categoryInd: categoryInd,\n categoryValue: categoryValue,\n displayInd: categoryInd,\n categoryLabel: categoryLabel,\n valueInds: [],\n count: 0,\n dragY: null\n };\n}\n\n/**\n * Update a CategoryModel object with a new value index\n * Note: The calling parameter is modified in place.\n *\n * @param {CategoryModel} categoryModel\n * @param {Number} valueInd\n * @param {Number} count\n */\nfunction updateCategoryModel(categoryModel, valueInd, count) {\n categoryModel.valueInds.push(valueInd);\n categoryModel.count += count;\n}\n\n\n// Path Model\n// ----------\n/**\n * @typedef {Object} PathModel\n * Object containing calculated information about the samples in a path.\n *\n * @property {Array} categoryInds\n * Array of category indices for each dimension (length `numDimensions`)\n * @param {String} pathColor\n * Color of this path. (Note: Any colorscaling has already taken place)\n * @property {Array} valueInds\n * Array of indices (into the original value array) of all samples in this path\n * @property {Number} count\n * The number of elements from the original array in this path\n * @property {String} color\n * The path's color (ass CSS color string)\n * @property rawColor\n * The raw color value specified by the user. May be a CSS color string or a Number\n */\n\n/**\n * Create and return a new PathModel object\n * @param {Array} categoryInds\n * @param color\n * @param rawColor\n * @return {PathModel}\n */\nfunction createPathModel(categoryInds, color, rawColor) {\n return {\n categoryInds: categoryInds,\n color: color,\n rawColor: rawColor,\n valueInds: [],\n count: 0\n };\n}\n\n/**\n * Update a PathModel object with a new value index\n * Note: The calling parameter is modified in place.\n *\n * @param {PathModel} pathModel\n * @param {Number} valueInd\n * @param {Number} count\n */\nfunction updatePathModel(pathModel, valueInd, count) {\n pathModel.valueInds.push(valueInd);\n pathModel.count += count;\n}\n\n// Unique calculations\n// ===================\n/**\n * @typedef {Object} UniqueInfo\n * Object containing information about the unique values of an input array\n *\n * @property {Array} uniqueValues\n * The unique values in the input array\n * @property {Array} uniqueCounts\n * The number of times each entry in uniqueValues occurs in input array.\n * This has the same length as `uniqueValues`\n * @property {Array} inds\n * Indices into uniqueValues that would reproduce original input array\n */\n\n/**\n * Compute unique value information for an array\n *\n * IMPORTANT: Note that values are considered unique\n * if their string representations are unique.\n *\n * @param {Array} values\n * @param {Array|undefined} uniqueValues\n * Array of expected unique values. The uniqueValues property of the resulting UniqueInfo object will begin with\n * these entries. Entries are included even if there are zero occurrences in the values array. Entries found in\n * the values array that are not present in uniqueValues will be included at the end of the array in the\n * UniqueInfo object.\n * @return {UniqueInfo}\n */\nfunction getUniqueInfo(values, uniqueValues) {\n // Initialize uniqueValues if not specified\n if(uniqueValues === undefined || uniqueValues === null) {\n uniqueValues = [];\n } else {\n // Shallow copy so append below doesn't alter input array\n uniqueValues = uniqueValues.map(function(e) {return e;});\n }\n\n // Initialize Variables\n var uniqueValueCounts = {};\n var uniqueValueInds = {};\n var inds = [];\n\n // Initialize uniqueValueCounts and\n uniqueValues.forEach(function(uniqueVal, valInd) {\n uniqueValueCounts[uniqueVal] = 0;\n uniqueValueInds[uniqueVal] = valInd;\n });\n\n // Compute the necessary unique info in a single pass\n for(var i = 0; i < values.length; i++) {\n var item = values[i];\n var itemInd;\n\n if(uniqueValueCounts[item] === undefined) {\n // This item has a previously unseen value\n uniqueValueCounts[item] = 1;\n itemInd = uniqueValues.push(item) - 1;\n uniqueValueInds[item] = itemInd;\n } else {\n // Increment count for this item\n uniqueValueCounts[item]++;\n itemInd = uniqueValueInds[item];\n }\n inds.push(itemInd);\n }\n\n // Build UniqueInfo\n var uniqueCounts = uniqueValues.map(function(v) { return uniqueValueCounts[v]; });\n\n return {\n uniqueValues: uniqueValues,\n uniqueCounts: uniqueCounts,\n inds: inds\n };\n}\n\n\n/**\n * Validate the requested display order for the dimensions.\n * If the display order is a permutation of 0 through dimensions.length - 1, link to _displayindex\n * Otherwise, replace the display order with the dimension order\n * @param {Object} trace\n */\nfunction validateDimensionDisplayInds(visibleDims) {\n var displayInds = visibleDims.map(function(d) { return d.displayindex; });\n var i;\n\n if(isRangePermutation(displayInds)) {\n for(i = 0; i < visibleDims.length; i++) {\n visibleDims[i]._displayindex = visibleDims[i].displayindex;\n }\n } else {\n for(i = 0; i < visibleDims.length; i++) {\n visibleDims[i]._displayindex = i;\n }\n }\n}\n\n\n/**\n * Update category properties based on the unique values found for this dimension\n * @param {Object} dim\n * @param {UniqueInfo} uniqueInfoDim\n */\nfunction validateCategoryProperties(dim, uniqueInfoDim) {\n // Update categoryarray\n dim._categoryarray = uniqueInfoDim.uniqueValues;\n\n // Handle ticktext\n if(dim.ticktext === null || dim.ticktext === undefined) {\n dim._ticktext = [];\n } else {\n // Shallow copy to avoid modifying input array\n dim._ticktext = dim.ticktext.slice();\n }\n\n // Extend ticktext with elements from uniqueInfoDim.uniqueValues\n for(var i = dim._ticktext.length; i < uniqueInfoDim.uniqueValues.length; i++) {\n dim._ticktext.push(uniqueInfoDim.uniqueValues[i]);\n }\n}\n\n/**\n * Determine whether an array contains a permutation of the integers from 0 to the array's length - 1\n * @param {Array} inds\n * @return {boolean}\n */\nfunction isRangePermutation(inds) {\n var indsSpecified = new Array(inds.length);\n\n for(var i = 0; i < inds.length; i++) {\n // Check for out of bounds\n if(inds[i] < 0 || inds[i] >= inds.length) {\n return false;\n }\n\n // Check for collisions with already specified index\n if(indsSpecified[inds[i]] !== undefined) {\n return false;\n }\n\n indsSpecified[inds[i]] = true;\n }\n\n // Nothing out of bounds and no collisions. We have a permutation\n return true;\n}\n","'use strict';\n\nvar Lib = require('../../lib');\nvar hasColorscale = require('../../components/colorscale/helpers').hasColorscale;\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar handleDomainDefaults = require('../../plots/domain').defaults;\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar attributes = require('./attributes');\nvar mergeLength = require('../parcoords/merge_length');\nvar isTypedArraySpec = require('../../lib/array').isTypedArraySpec;\n\nfunction handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce) {\n coerce('line.shape');\n coerce('line.hovertemplate');\n\n var lineColor = coerce('line.color', layout.colorway[0]);\n if(hasColorscale(traceIn, 'line') && Lib.isArrayOrTypedArray(lineColor)) {\n if(lineColor.length) {\n coerce('line.colorscale');\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: 'line.', cLetter: 'c'});\n return lineColor.length;\n } else {\n traceOut.line.color = defaultColor;\n }\n }\n return Infinity;\n}\n\nfunction dimensionDefaults(dimensionIn, dimensionOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(dimensionIn, dimensionOut, attributes.dimensions, attr, dflt);\n }\n\n var values = coerce('values');\n var visible = coerce('visible');\n if(!(values && values.length)) {\n visible = dimensionOut.visible = false;\n }\n\n if(visible) {\n // Dimension level\n coerce('label');\n coerce('displayindex', dimensionOut._index);\n\n // Category level\n var arrayIn = dimensionIn.categoryarray;\n var isValidArray = (Lib.isArrayOrTypedArray(arrayIn) && arrayIn.length > 0) ||\n isTypedArraySpec(arrayIn);\n\n var orderDefault;\n if(isValidArray) orderDefault = 'array';\n var order = coerce('categoryorder', orderDefault);\n\n // coerce 'categoryarray' only in array order case\n if(order === 'array') {\n coerce('categoryarray');\n coerce('ticktext');\n } else {\n delete dimensionIn.categoryarray;\n delete dimensionIn.ticktext;\n }\n\n // cannot set 'categoryorder' to 'array' with an invalid 'categoryarray'\n if(!isValidArray && order === 'array') {\n dimensionOut.categoryorder = 'trace';\n }\n }\n}\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var dimensions = handleArrayContainerDefaults(traceIn, traceOut, {\n name: 'dimensions',\n handleItemDefaults: dimensionDefaults\n });\n\n var len = handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce);\n\n handleDomainDefaults(traceOut, layout, coerce);\n\n if(!Array.isArray(dimensions) || !dimensions.length) {\n traceOut.visible = false;\n }\n\n mergeLength(traceOut, dimensions, 'values', len);\n\n coerce('hoveron');\n coerce('hovertemplate');\n coerce('arrangement');\n coerce('bundlecolors');\n coerce('sortpaths');\n coerce('counts');\n\n var layoutFont = layout.font;\n\n Lib.coerceFont(coerce, 'labelfont', layoutFont, {\n overrideDflt: {\n size: Math.round(layoutFont.size)\n }\n });\n\n Lib.coerceFont(coerce, 'tickfont', layoutFont, {\n autoShadowDflt: true,\n overrideDflt: {\n size: Math.round(layoutFont.size / 1.2)\n }\n });\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n calc: require('./calc'),\n plot: require('./plot'),\n colorbar: {\n container: 'line',\n min: 'cmin',\n max: 'cmax'\n },\n\n moduleType: 'trace',\n name: 'parcats',\n basePlotModule: require('./base_plot'),\n categories: ['noOpacity'],\n meta: {\n description: [\n 'Parallel categories diagram for multidimensional categorical data.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar interpolateNumber = require('d3-interpolate').interpolateNumber;\nvar Plotly = require('../../plot_api/plot_api');\nvar Fx = require('../../components/fx');\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar Drawing = require('../../components/drawing');\nvar tinycolor = require('tinycolor2');\nvar svgTextUtils = require('../../lib/svg_text_utils');\n\nfunction performPlot(parcatsModels, graphDiv, layout, svg) {\n var isStatic = graphDiv._context.staticPlot;\n\n var viewModels = parcatsModels.map(createParcatsViewModel.bind(0, graphDiv, layout));\n\n // Get (potentially empty) parcatslayer selection with bound data to single element array\n var layerSelection = svg.selectAll('g.parcatslayer').data([null]);\n\n // Initialize single parcatslayer group if it doesn't exist\n layerSelection.enter()\n .append('g')\n .attr('class', 'parcatslayer')\n .style('pointer-events', isStatic ? 'none' : 'all');\n\n // Bind data to children of layerSelection and get reference to traceSelection\n var traceSelection = layerSelection\n .selectAll('g.trace.parcats')\n .data(viewModels, key);\n\n // Initialize group for each trace/dimensions\n var traceEnter = traceSelection.enter()\n .append('g')\n .attr('class', 'trace parcats');\n\n // Update properties for each trace\n traceSelection\n .attr('transform', function(d) {\n return strTranslate(d.x, d.y);\n });\n\n // Initialize paths group\n traceEnter\n .append('g')\n .attr('class', 'paths');\n\n // Update paths transform\n var pathsSelection = traceSelection\n .select('g.paths');\n\n // Get paths selection\n var pathSelection = pathsSelection\n .selectAll('path.path')\n .data(function(d) {\n return d.paths;\n }, key);\n\n // Update existing path colors\n pathSelection\n .attr('fill', function(d) {\n return d.model.color;\n });\n\n // Create paths\n var pathSelectionEnter = pathSelection\n .enter()\n .append('path')\n .attr('class', 'path')\n .attr('stroke-opacity', 0)\n .attr('fill', function(d) {\n return d.model.color;\n })\n .attr('fill-opacity', 0);\n\n stylePathsNoHover(pathSelectionEnter);\n\n // Set path geometry\n pathSelection\n .attr('d', function(d) {\n return d.svgD;\n });\n\n // sort paths\n if(!pathSelectionEnter.empty()) {\n // Only sort paths if there has been a change.\n // Otherwise paths are already sorted or a hover operation may be in progress\n pathSelection.sort(compareRawColor);\n }\n\n // Remove any old paths\n pathSelection.exit().remove();\n\n // Path hover\n pathSelection\n .on('mouseover', mouseoverPath)\n .on('mouseout', mouseoutPath)\n .on('click', clickPath);\n\n // Initialize dimensions group\n traceEnter.append('g').attr('class', 'dimensions');\n\n // Update dimensions transform\n var dimensionsSelection = traceSelection\n .select('g.dimensions');\n\n // Get dimension selection\n var dimensionSelection = dimensionsSelection\n .selectAll('g.dimension')\n .data(function(d) {\n return d.dimensions;\n }, key);\n\n // Create dimension groups\n dimensionSelection.enter()\n .append('g')\n .attr('class', 'dimension');\n\n // Update dimension group transforms\n dimensionSelection.attr('transform', function(d) {\n return strTranslate(d.x, 0);\n });\n\n // Remove any old dimensions\n dimensionSelection.exit().remove();\n\n // Get category selection\n var categorySelection = dimensionSelection\n .selectAll('g.category')\n .data(function(d) {\n return d.categories;\n }, key);\n\n // Initialize category groups\n var categoryGroupEnterSelection = categorySelection\n .enter()\n .append('g')\n .attr('class', 'category');\n\n // Update category transforms\n categorySelection\n .attr('transform', function(d) {\n return strTranslate(0, d.y);\n });\n\n\n // Initialize rectangle\n categoryGroupEnterSelection\n .append('rect')\n .attr('class', 'catrect')\n .attr('pointer-events', 'none');\n\n\n // Update rectangle\n categorySelection.select('rect.catrect')\n .attr('fill', 'none')\n .attr('width', function(d) {\n return d.width;\n })\n .attr('height', function(d) {\n return d.height;\n });\n\n styleCategoriesNoHover(categoryGroupEnterSelection);\n\n // Initialize color band rects\n var bandSelection = categorySelection\n .selectAll('rect.bandrect')\n .data(\n /** @param {CategoryViewModel} catViewModel*/\n function(catViewModel) {\n return catViewModel.bands;\n }, key);\n\n // Raise all update bands to the top so that fading enter/exit bands will be behind\n bandSelection.each(function() {Lib.raiseToTop(this);});\n\n // Update band color\n bandSelection\n .attr('fill', function(d) {\n return d.color;\n });\n\n var bandsSelectionEnter = bandSelection.enter()\n .append('rect')\n .attr('class', 'bandrect')\n .attr('stroke-opacity', 0)\n .attr('fill', function(d) {\n return d.color;\n })\n .attr('fill-opacity', 0);\n\n bandSelection\n .attr('fill', function(d) {\n return d.color;\n })\n .attr('width', function(d) {\n return d.width;\n })\n .attr('height', function(d) {\n return d.height;\n })\n .attr('y', function(d) {\n return d.y;\n })\n .attr('cursor',\n /** @param {CategoryBandViewModel} bandModel*/\n function(bandModel) {\n if(bandModel.parcatsViewModel.arrangement === 'fixed') {\n return 'default';\n } else if(bandModel.parcatsViewModel.arrangement === 'perpendicular') {\n return 'ns-resize';\n } else {\n return 'move';\n }\n });\n\n styleBandsNoHover(bandsSelectionEnter);\n\n bandSelection.exit().remove();\n\n // Initialize category label\n categoryGroupEnterSelection\n .append('text')\n .attr('class', 'catlabel')\n .attr('pointer-events', 'none');\n\n // Update category label\n categorySelection.select('text.catlabel')\n .attr('text-anchor',\n function(d) {\n if(catInRightDim(d)) {\n // Place label to the right of category\n return 'start';\n } else {\n // Place label to the left of category\n return 'end';\n }\n })\n .attr('alignment-baseline', 'middle')\n .style('fill', 'rgb(0, 0, 0)')\n .attr('x',\n function(d) {\n if(catInRightDim(d)) {\n // Place label to the right of category\n return d.width + 5;\n } else {\n // Place label to the left of category\n return -5;\n }\n })\n .attr('y', function(d) {\n return d.height / 2;\n })\n .text(function(d) {\n return d.model.categoryLabel;\n })\n .each(\n /** @param {CategoryViewModel} catModel*/\n function(catModel) {\n Drawing.font(d3.select(this), catModel.parcatsViewModel.categorylabelfont);\n svgTextUtils.convertToTspans(d3.select(this), graphDiv);\n });\n\n // Initialize dimension label\n categoryGroupEnterSelection\n .append('text')\n .attr('class', 'dimlabel');\n\n // Update dimension label\n categorySelection.select('text.dimlabel')\n .attr('text-anchor', 'middle')\n .attr('alignment-baseline', 'baseline')\n .attr('cursor',\n /** @param {CategoryViewModel} catModel*/\n function(catModel) {\n if(catModel.parcatsViewModel.arrangement === 'fixed') {\n return 'default';\n } else {\n return 'ew-resize';\n }\n })\n .attr('x', function(d) {\n return d.width / 2;\n })\n .attr('y', -5)\n .text(function(d, i) {\n if(i === 0) {\n // Add dimension label above topmost category\n return d.parcatsViewModel.model.dimensions[d.model.dimensionInd].dimensionLabel;\n } else {\n return null;\n }\n })\n .each(\n /** @param {CategoryViewModel} catModel*/\n function(catModel) {\n Drawing.font(d3.select(this), catModel.parcatsViewModel.labelfont);\n });\n\n // Category hover\n // categorySelection.select('rect.catrect')\n categorySelection.selectAll('rect.bandrect')\n .on('mouseover', mouseoverCategoryBand)\n .on('mouseout', mouseoutCategory);\n\n // Remove unused categories\n categorySelection.exit().remove();\n\n // Setup drag\n dimensionSelection.call(d3.behavior.drag()\n .origin(function(d) {\n return {x: d.x, y: 0};\n })\n .on('dragstart', dragDimensionStart)\n .on('drag', dragDimension)\n .on('dragend', dragDimensionEnd));\n\n\n // Save off selections to view models\n traceSelection.each(function(d) {\n d.traceSelection = d3.select(this);\n d.pathSelection = d3.select(this).selectAll('g.paths').selectAll('path.path');\n d.dimensionSelection = d3.select(this).selectAll('g.dimensions').selectAll('g.dimension');\n });\n\n // Remove any orphan traces\n traceSelection.exit().remove();\n}\n\n/**\n * Create / update parcat traces\n *\n * @param {Object} graphDiv\n * @param {Object} svg\n * @param {Array.} parcatsModels\n * @param {Layout} layout\n */\nmodule.exports = function(graphDiv, svg, parcatsModels, layout) {\n performPlot(parcatsModels, graphDiv, layout, svg);\n};\n\n/**\n * Function the returns the key property of an object for use with as D3 join function\n * @param d\n */\nfunction key(d) {\n return d.key;\n}\n\n /** True if a category view model is in the right-most display dimension\n * @param {CategoryViewModel} d */\nfunction catInRightDim(d) {\n var numDims = d.parcatsViewModel.dimensions.length;\n var leftDimInd = d.parcatsViewModel.dimensions[numDims - 1].model.dimensionInd;\n return d.model.dimensionInd === leftDimInd;\n}\n\n/**\n * @param {PathViewModel} a\n * @param {PathViewModel} b\n */\nfunction compareRawColor(a, b) {\n if(a.model.rawColor > b.model.rawColor) {\n return 1;\n } else if(a.model.rawColor < b.model.rawColor) {\n return -1;\n } else {\n return 0;\n }\n}\n\n/**\n * Handle path mouseover\n * @param {PathViewModel} d\n */\nfunction mouseoverPath(d) {\n if(!d.parcatsViewModel.dragDimension) {\n // We're not currently dragging\n\n if(d.parcatsViewModel.hoverinfoItems.indexOf('skip') === -1) {\n // hoverinfo is not skip, so we at least style the paths and emit interaction events\n\n // Raise path to top\n Lib.raiseToTop(this);\n\n stylePathsHover(d3.select(this));\n\n // Emit hover event\n var points = buildPointsArrayForPath(d);\n var constraints = buildConstraintsForPath(d);\n d.parcatsViewModel.graphDiv.emit('plotly_hover', {\n points: points, event: d3.event, constraints: constraints\n });\n\n // Handle hover label\n if(d.parcatsViewModel.hoverinfoItems.indexOf('none') === -1) {\n // hoverinfo is a combination of 'count' and 'probability'\n\n // Mouse\n var hoverX = d3.mouse(this)[0];\n\n // Label\n var gd = d.parcatsViewModel.graphDiv;\n var trace = d.parcatsViewModel.trace;\n var fullLayout = gd._fullLayout;\n var rootBBox = fullLayout._paperdiv.node().getBoundingClientRect();\n var graphDivBBox = d.parcatsViewModel.graphDiv.getBoundingClientRect();\n\n // Find path center in path coordinates\n var pathCenterX,\n pathCenterY,\n dimInd;\n\n for(dimInd = 0; dimInd < (d.leftXs.length - 1); dimInd++) {\n if(d.leftXs[dimInd] + d.dimWidths[dimInd] - 2 <= hoverX && hoverX <= d.leftXs[dimInd + 1] + 2) {\n var leftDim = d.parcatsViewModel.dimensions[dimInd];\n var rightDim = d.parcatsViewModel.dimensions[dimInd + 1];\n pathCenterX = (leftDim.x + leftDim.width + rightDim.x) / 2;\n pathCenterY = (d.topYs[dimInd] + d.topYs[dimInd + 1] + d.height) / 2;\n break;\n }\n }\n\n // Find path center in root coordinates\n var hoverCenterX = d.parcatsViewModel.x + pathCenterX;\n var hoverCenterY = d.parcatsViewModel.y + pathCenterY;\n\n var textColor = tinycolor.mostReadable(d.model.color, ['black', 'white']);\n\n var count = d.model.count;\n var prob = count / d.parcatsViewModel.model.count;\n var labels = {\n countLabel: count,\n probabilityLabel: prob.toFixed(3)\n };\n\n // Build hover text\n var hovertextParts = [];\n if(d.parcatsViewModel.hoverinfoItems.indexOf('count') !== -1) {\n hovertextParts.push(['Count:', labels.countLabel].join(' '));\n }\n if(d.parcatsViewModel.hoverinfoItems.indexOf('probability') !== -1) {\n hovertextParts.push(['P:', labels.probabilityLabel].join(' '));\n }\n\n var hovertext = hovertextParts.join('
');\n var mouseX = d3.mouse(gd)[0];\n\n Fx.loneHover({\n trace: trace,\n x: hoverCenterX - rootBBox.left + graphDivBBox.left,\n y: hoverCenterY - rootBBox.top + graphDivBBox.top,\n text: hovertext,\n color: d.model.color,\n borderColor: 'black',\n fontFamily: 'Monaco, \"Courier New\", monospace',\n fontSize: 10,\n fontColor: textColor,\n idealAlign: mouseX < hoverCenterX ? 'right' : 'left',\n hovertemplate: (trace.line || {}).hovertemplate,\n hovertemplateLabels: labels,\n eventData: [{\n data: trace._input,\n fullData: trace,\n count: count,\n probability: prob\n }]\n }, {\n container: fullLayout._hoverlayer.node(),\n outerContainer: fullLayout._paper.node(),\n gd: gd\n });\n }\n }\n }\n}\n\n/**\n * Handle path mouseout\n * @param {PathViewModel} d\n */\nfunction mouseoutPath(d) {\n if(!d.parcatsViewModel.dragDimension) {\n // We're not currently dragging\n stylePathsNoHover(d3.select(this));\n\n // Remove and hover label\n Fx.loneUnhover(d.parcatsViewModel.graphDiv._fullLayout._hoverlayer.node());\n\n // Restore path order\n d.parcatsViewModel.pathSelection.sort(compareRawColor);\n\n // Emit unhover event\n if(d.parcatsViewModel.hoverinfoItems.indexOf('skip') === -1) {\n var points = buildPointsArrayForPath(d);\n var constraints = buildConstraintsForPath(d);\n d.parcatsViewModel.graphDiv.emit('plotly_unhover', {\n points: points, event: d3.event, constraints: constraints\n });\n }\n }\n}\n\n/**\n * Build array of point objects for a path\n *\n * For use in click/hover events\n * @param {PathViewModel} d\n */\nfunction buildPointsArrayForPath(d) {\n var points = [];\n var curveNumber = getTraceIndex(d.parcatsViewModel);\n\n for(var i = 0; i < d.model.valueInds.length; i++) {\n var pointNumber = d.model.valueInds[i];\n points.push({\n curveNumber: curveNumber,\n pointNumber: pointNumber\n });\n }\n return points;\n}\n\n/**\n * Build constraints object for a path\n *\n * For use in click/hover events\n * @param {PathViewModel} d\n */\nfunction buildConstraintsForPath(d) {\n var constraints = {};\n var dimensions = d.parcatsViewModel.model.dimensions;\n\n // dimensions\n for(var i = 0; i < dimensions.length; i++) {\n var dimension = dimensions[i];\n var category = dimension.categories[d.model.categoryInds[i]];\n constraints[dimension.containerInd] = category.categoryValue;\n }\n\n // color\n if(d.model.rawColor !== undefined) {\n constraints.color = d.model.rawColor;\n }\n return constraints;\n}\n\n/**\n * Handle path click\n * @param {PathViewModel} d\n */\nfunction clickPath(d) {\n if(d.parcatsViewModel.hoverinfoItems.indexOf('skip') === -1) {\n // hoverinfo it's skip, so interaction events aren't disabled\n var points = buildPointsArrayForPath(d);\n var constraints = buildConstraintsForPath(d);\n d.parcatsViewModel.graphDiv.emit('plotly_click', {\n points: points, event: d3.event, constraints: constraints\n });\n }\n}\n\nfunction stylePathsNoHover(pathSelection) {\n pathSelection\n .attr('fill', function(d) {\n return d.model.color;\n })\n .attr('fill-opacity', 0.6)\n .attr('stroke', 'lightgray')\n .attr('stroke-width', 0.2)\n .attr('stroke-opacity', 1.0);\n}\n\nfunction stylePathsHover(pathSelection) {\n pathSelection\n .attr('fill-opacity', 0.8)\n .attr('stroke', function(d) {\n return tinycolor.mostReadable(d.model.color, ['black', 'white']);\n })\n .attr('stroke-width', 0.3);\n}\n\nfunction styleCategoryHover(categorySelection) {\n categorySelection\n .select('rect.catrect')\n .attr('stroke', 'black')\n .attr('stroke-width', 2.5);\n}\n\nfunction styleCategoriesNoHover(categorySelection) {\n categorySelection\n .select('rect.catrect')\n .attr('stroke', 'black')\n .attr('stroke-width', 1)\n .attr('stroke-opacity', 1);\n}\n\nfunction styleBandsHover(bandsSelection) {\n bandsSelection\n .attr('stroke', 'black')\n .attr('stroke-width', 1.5);\n}\n\nfunction styleBandsNoHover(bandsSelection) {\n bandsSelection\n .attr('stroke', 'black')\n .attr('stroke-width', 0.2)\n .attr('stroke-opacity', 1.0)\n .attr('fill-opacity', 1.0);\n}\n\n/**\n * Return selection of all paths that pass through the specified category\n * @param {CategoryBandViewModel} catBandViewModel\n */\nfunction selectPathsThroughCategoryBandColor(catBandViewModel) {\n var allPaths = catBandViewModel.parcatsViewModel.pathSelection;\n var dimInd = catBandViewModel.categoryViewModel.model.dimensionInd;\n var catInd = catBandViewModel.categoryViewModel.model.categoryInd;\n\n return allPaths\n .filter(\n /** @param {PathViewModel} pathViewModel */\n function(pathViewModel) {\n return pathViewModel.model.categoryInds[dimInd] === catInd &&\n pathViewModel.model.color === catBandViewModel.color;\n });\n}\n\n\n/**\n * Perform hover styling for all paths that pass though the specified band element's category\n *\n * @param {HTMLElement} bandElement\n * HTML element for band\n *\n */\nfunction styleForCategoryHovermode(bandElement) {\n // Get all bands in the current category\n var bandSel = d3.select(bandElement.parentNode).selectAll('rect.bandrect');\n\n // Raise and style paths\n bandSel.each(function(bvm) {\n var paths = selectPathsThroughCategoryBandColor(bvm);\n stylePathsHover(paths);\n paths.each(function() {\n // Raise path to top\n Lib.raiseToTop(this);\n });\n });\n\n // Style category\n styleCategoryHover(d3.select(bandElement.parentNode));\n}\n\n/**\n * Perform hover styling for all paths that pass though the category of the specified band element and share the\n * same color\n *\n * @param {HTMLElement} bandElement\n * HTML element for band\n *\n */\nfunction styleForColorHovermode(bandElement) {\n var bandViewModel = d3.select(bandElement).datum();\n var catPaths = selectPathsThroughCategoryBandColor(bandViewModel);\n stylePathsHover(catPaths);\n catPaths.each(function() {\n // Raise path to top\n Lib.raiseToTop(this);\n });\n\n // Style category for drag\n d3.select(bandElement.parentNode)\n .selectAll('rect.bandrect')\n .filter(function(b) {return b.color === bandViewModel.color;})\n .each(function() {\n Lib.raiseToTop(this);\n styleBandsHover(d3.select(this));\n });\n}\n\n\n/**\n * @param {HTMLElement} bandElement\n * HTML element for band\n * @param eventName\n * Event name (plotly_hover or plotly_click)\n * @param event\n * Mouse Event\n */\nfunction emitPointsEventCategoryHovermode(bandElement, eventName, event) {\n // Get all bands in the current category\n var bandViewModel = d3.select(bandElement).datum();\n var categoryModel = bandViewModel.categoryViewModel.model;\n var gd = bandViewModel.parcatsViewModel.graphDiv;\n var bandSel = d3.select(bandElement.parentNode).selectAll('rect.bandrect');\n\n var points = [];\n bandSel.each(function(bvm) {\n var paths = selectPathsThroughCategoryBandColor(bvm);\n paths.each(function(pathViewModel) {\n // Extend points array\n Array.prototype.push.apply(points, buildPointsArrayForPath(pathViewModel));\n });\n });\n\n var constraints = {};\n constraints[categoryModel.dimensionInd] = categoryModel.categoryValue;\n gd.emit(eventName, {\n points: points, event: event, constraints: constraints\n });\n}\n\n/**\n * @param {HTMLElement} bandElement\n * HTML element for band\n * @param eventName\n * Event name (plotly_hover or plotly_click)\n * @param event\n * Mouse Event\n */\nfunction emitPointsEventColorHovermode(bandElement, eventName, event) {\n var bandViewModel = d3.select(bandElement).datum();\n var categoryModel = bandViewModel.categoryViewModel.model;\n var gd = bandViewModel.parcatsViewModel.graphDiv;\n var paths = selectPathsThroughCategoryBandColor(bandViewModel);\n\n var points = [];\n paths.each(function(pathViewModel) {\n // Extend points array\n Array.prototype.push.apply(points, buildPointsArrayForPath(pathViewModel));\n });\n\n var constraints = {};\n constraints[categoryModel.dimensionInd] = categoryModel.categoryValue;\n // color\n if(bandViewModel.rawColor !== undefined) {\n constraints.color = bandViewModel.rawColor;\n }\n gd.emit(eventName, {\n points: points, event: event, constraints: constraints\n });\n}\n\n/**\n * Create hover label for a band element's category (for use when hoveron === 'category')\n *\n * @param {ClientRect} rootBBox\n * Client bounding box for root of figure\n * @param {HTMLElement} bandElement\n * HTML element for band\n *\n */\nfunction createHoverLabelForCategoryHovermode(gd, rootBBox, bandElement) {\n gd._fullLayout._calcInverseTransform(gd);\n var scaleX = gd._fullLayout._invScaleX;\n var scaleY = gd._fullLayout._invScaleY;\n\n // Selections\n var rectSelection = d3.select(bandElement.parentNode).select('rect.catrect');\n var rectBoundingBox = rectSelection.node().getBoundingClientRect();\n\n // Models\n /** @type {CategoryViewModel} */\n var catViewModel = rectSelection.datum();\n var parcatsViewModel = catViewModel.parcatsViewModel;\n var dimensionModel = parcatsViewModel.model.dimensions[catViewModel.model.dimensionInd];\n var trace = parcatsViewModel.trace;\n\n // Positions\n var hoverCenterY = rectBoundingBox.top + rectBoundingBox.height / 2;\n var hoverCenterX,\n hoverLabelIdealAlign;\n\n if(parcatsViewModel.dimensions.length > 1 &&\n dimensionModel.displayInd === parcatsViewModel.dimensions.length - 1) {\n // right most dimension\n hoverCenterX = rectBoundingBox.left;\n hoverLabelIdealAlign = 'left';\n } else {\n hoverCenterX = rectBoundingBox.left + rectBoundingBox.width;\n hoverLabelIdealAlign = 'right';\n }\n\n var count = catViewModel.model.count;\n var catLabel = catViewModel.model.categoryLabel;\n var prob = count / catViewModel.parcatsViewModel.model.count;\n var labels = {\n countLabel: count,\n categoryLabel: catLabel,\n probabilityLabel: prob.toFixed(3)\n };\n\n // Hover label text\n var hoverinfoParts = [];\n if(catViewModel.parcatsViewModel.hoverinfoItems.indexOf('count') !== -1) {\n hoverinfoParts.push(['Count:', labels.countLabel].join(' '));\n }\n if(catViewModel.parcatsViewModel.hoverinfoItems.indexOf('probability') !== -1) {\n hoverinfoParts.push(['P(' + labels.categoryLabel + '):', labels.probabilityLabel].join(' '));\n }\n\n var hovertext = hoverinfoParts.join('
');\n return {\n trace: trace,\n x: scaleX * (hoverCenterX - rootBBox.left),\n y: scaleY * (hoverCenterY - rootBBox.top),\n text: hovertext,\n color: 'lightgray',\n borderColor: 'black',\n fontFamily: 'Monaco, \"Courier New\", monospace',\n fontSize: 12,\n fontColor: 'black',\n idealAlign: hoverLabelIdealAlign,\n hovertemplate: trace.hovertemplate,\n hovertemplateLabels: labels,\n eventData: [{\n data: trace._input,\n fullData: trace,\n count: count,\n category: catLabel,\n probability: prob\n }]\n };\n}\n\n/**\n * Create hover label for a band element's category (for use when hoveron === 'category')\n *\n * @param {ClientRect} rootBBox\n * Client bounding box for root of figure\n * @param {HTMLElement} bandElement\n * HTML element for band\n *\n */\nfunction createHoverLabelForDimensionHovermode(gd, rootBBox, bandElement) {\n var allHoverlabels = [];\n\n d3.select(bandElement.parentNode.parentNode)\n .selectAll('g.category')\n .select('rect.catrect')\n .each(function() {\n var bandNode = this;\n allHoverlabels.push(createHoverLabelForCategoryHovermode(gd, rootBBox, bandNode));\n });\n\n return allHoverlabels;\n}\n\n/**\n * Create hover labels for a band element's category (for use when hoveron === 'dimension')\n *\n * @param {ClientRect} rootBBox\n * Client bounding box for root of figure\n * @param {HTMLElement} bandElement\n * HTML element for band\n *\n */\nfunction createHoverLabelForColorHovermode(gd, rootBBox, bandElement) {\n gd._fullLayout._calcInverseTransform(gd);\n var scaleX = gd._fullLayout._invScaleX;\n var scaleY = gd._fullLayout._invScaleY;\n\n var bandBoundingBox = bandElement.getBoundingClientRect();\n\n // Models\n /** @type {CategoryBandViewModel} */\n var bandViewModel = d3.select(bandElement).datum();\n var catViewModel = bandViewModel.categoryViewModel;\n var parcatsViewModel = catViewModel.parcatsViewModel;\n var dimensionModel = parcatsViewModel.model.dimensions[catViewModel.model.dimensionInd];\n var trace = parcatsViewModel.trace;\n\n // positions\n var hoverCenterY = bandBoundingBox.y + bandBoundingBox.height / 2;\n\n var hoverCenterX,\n hoverLabelIdealAlign;\n if(parcatsViewModel.dimensions.length > 1 &&\n dimensionModel.displayInd === parcatsViewModel.dimensions.length - 1) {\n // right most dimension\n hoverCenterX = bandBoundingBox.left;\n hoverLabelIdealAlign = 'left';\n } else {\n hoverCenterX = bandBoundingBox.left + bandBoundingBox.width;\n hoverLabelIdealAlign = 'right';\n }\n\n // Labels\n var catLabel = catViewModel.model.categoryLabel;\n\n // Counts\n var totalCount = bandViewModel.parcatsViewModel.model.count;\n\n var bandColorCount = 0;\n bandViewModel.categoryViewModel.bands.forEach(function(b) {\n if(b.color === bandViewModel.color) {\n bandColorCount += b.count;\n }\n });\n\n var catCount = catViewModel.model.count;\n\n var colorCount = 0;\n parcatsViewModel.pathSelection.each(\n /** @param {PathViewModel} pathViewModel */\n function(pathViewModel) {\n if(pathViewModel.model.color === bandViewModel.color) {\n colorCount += pathViewModel.model.count;\n }\n });\n\n var pColorAndCat = bandColorCount / totalCount;\n var pCatGivenColor = bandColorCount / colorCount;\n var pColorGivenCat = bandColorCount / catCount;\n\n var labels = {\n countLabel: bandColorCount,\n categoryLabel: catLabel,\n probabilityLabel: pColorAndCat.toFixed(3)\n };\n\n // Hover label text\n var hoverinfoParts = [];\n if(catViewModel.parcatsViewModel.hoverinfoItems.indexOf('count') !== -1) {\n hoverinfoParts.push(['Count:', labels.countLabel].join(' '));\n }\n if(catViewModel.parcatsViewModel.hoverinfoItems.indexOf('probability') !== -1) {\n hoverinfoParts.push('P(color ∩ ' + catLabel + '): ' + labels.probabilityLabel);\n hoverinfoParts.push('P(' + catLabel + ' | color): ' + pCatGivenColor.toFixed(3));\n hoverinfoParts.push('P(color | ' + catLabel + '): ' + pColorGivenCat.toFixed(3));\n }\n\n var hovertext = hoverinfoParts.join('
');\n\n // Compute text color\n var textColor = tinycolor.mostReadable(bandViewModel.color, ['black', 'white']);\n\n return {\n trace: trace,\n x: scaleX * (hoverCenterX - rootBBox.left),\n y: scaleY * (hoverCenterY - rootBBox.top),\n // name: 'NAME',\n text: hovertext,\n color: bandViewModel.color,\n borderColor: 'black',\n fontFamily: 'Monaco, \"Courier New\", monospace',\n fontColor: textColor,\n fontSize: 10,\n idealAlign: hoverLabelIdealAlign,\n hovertemplate: trace.hovertemplate,\n hovertemplateLabels: labels,\n eventData: [{\n data: trace._input,\n fullData: trace,\n category: catLabel,\n count: totalCount,\n probability: pColorAndCat,\n categorycount: catCount,\n colorcount: colorCount,\n bandcolorcount: bandColorCount\n }]\n };\n}\n\n/**\n * Handle dimension mouseover\n * @param {CategoryBandViewModel} bandViewModel\n */\nfunction mouseoverCategoryBand(bandViewModel) {\n if(!bandViewModel.parcatsViewModel.dragDimension) {\n // We're not currently dragging\n\n if(bandViewModel.parcatsViewModel.hoverinfoItems.indexOf('skip') === -1) {\n // hoverinfo is not skip, so we at least style the bands and emit interaction events\n\n // Mouse\n var mouseY = d3.mouse(this)[1];\n if(mouseY < -1) {\n // Hover is above above the category rectangle (probably the dimension title text)\n return;\n }\n\n var gd = bandViewModel.parcatsViewModel.graphDiv;\n var fullLayout = gd._fullLayout;\n var rootBBox = fullLayout._paperdiv.node().getBoundingClientRect();\n var hoveron = bandViewModel.parcatsViewModel.hoveron;\n\n /** @type {HTMLElement} */\n var bandElement = this;\n\n // Handle style and events\n if(hoveron === 'color') {\n styleForColorHovermode(bandElement);\n emitPointsEventColorHovermode(bandElement, 'plotly_hover', d3.event);\n } else {\n styleForCategoryHovermode(bandElement);\n emitPointsEventCategoryHovermode(bandElement, 'plotly_hover', d3.event);\n }\n\n // Handle hover label\n if(bandViewModel.parcatsViewModel.hoverinfoItems.indexOf('none') === -1) {\n var hoverItems;\n if(hoveron === 'category') {\n hoverItems = createHoverLabelForCategoryHovermode(gd, rootBBox, bandElement);\n } else if(hoveron === 'color') {\n hoverItems = createHoverLabelForColorHovermode(gd, rootBBox, bandElement);\n } else if(hoveron === 'dimension') {\n hoverItems = createHoverLabelForDimensionHovermode(gd, rootBBox, bandElement);\n }\n\n if(hoverItems) {\n Fx.loneHover(hoverItems, {\n container: fullLayout._hoverlayer.node(),\n outerContainer: fullLayout._paper.node(),\n gd: gd\n });\n }\n }\n }\n }\n}\n\n\n/**\n * Handle dimension mouseover\n * @param {CategoryBandViewModel} bandViewModel\n */\nfunction mouseoutCategory(bandViewModel) {\n var parcatsViewModel = bandViewModel.parcatsViewModel;\n\n if(!parcatsViewModel.dragDimension) {\n // We're not dragging anything\n\n // Reset unhovered styles\n stylePathsNoHover(parcatsViewModel.pathSelection);\n styleCategoriesNoHover(parcatsViewModel.dimensionSelection.selectAll('g.category'));\n styleBandsNoHover(parcatsViewModel.dimensionSelection.selectAll('g.category').selectAll('rect.bandrect'));\n\n // Remove hover label\n Fx.loneUnhover(parcatsViewModel.graphDiv._fullLayout._hoverlayer.node());\n\n // Restore path order\n parcatsViewModel.pathSelection.sort(compareRawColor);\n\n // Emit unhover event\n if(parcatsViewModel.hoverinfoItems.indexOf('skip') === -1) {\n var hoveron = bandViewModel.parcatsViewModel.hoveron;\n var bandElement = this;\n\n // Handle style and events\n if(hoveron === 'color') {\n emitPointsEventColorHovermode(bandElement, 'plotly_unhover', d3.event);\n } else {\n emitPointsEventCategoryHovermode(bandElement, 'plotly_unhover', d3.event);\n }\n }\n }\n}\n\n\n/**\n * Handle dimension drag start\n * @param {DimensionViewModel} d\n */\nfunction dragDimensionStart(d) {\n // Check if dragging is supported\n if(d.parcatsViewModel.arrangement === 'fixed') {\n return;\n }\n\n // Save off initial drag indexes for dimension\n d.dragDimensionDisplayInd = d.model.displayInd;\n d.initialDragDimensionDisplayInds = d.parcatsViewModel.model.dimensions.map(function(d) {return d.displayInd;});\n d.dragHasMoved = false;\n\n // Check for category hit\n d.dragCategoryDisplayInd = null;\n d3.select(this)\n .selectAll('g.category')\n .select('rect.catrect')\n .each(\n /** @param {CategoryViewModel} catViewModel */\n function(catViewModel) {\n var catMouseX = d3.mouse(this)[0];\n var catMouseY = d3.mouse(this)[1];\n\n\n if(-2 <= catMouseX && catMouseX <= catViewModel.width + 2 &&\n -2 <= catMouseY && catMouseY <= catViewModel.height + 2) {\n // Save off initial drag indexes for categories\n d.dragCategoryDisplayInd = catViewModel.model.displayInd;\n d.initialDragCategoryDisplayInds = d.model.categories.map(function(c) {\n return c.displayInd;\n });\n\n // Initialize categories dragY to be the current y position\n catViewModel.model.dragY = catViewModel.y;\n\n // Raise category\n Lib.raiseToTop(this.parentNode);\n\n // Get band element\n d3.select(this.parentNode)\n .selectAll('rect.bandrect')\n /** @param {CategoryBandViewModel} bandViewModel */\n .each(function(bandViewModel) {\n if(bandViewModel.y < catMouseY && catMouseY <= bandViewModel.y + bandViewModel.height) {\n d.potentialClickBand = this;\n }\n });\n }\n });\n\n // Update toplevel drag dimension\n d.parcatsViewModel.dragDimension = d;\n\n // Remove hover label if any\n Fx.loneUnhover(d.parcatsViewModel.graphDiv._fullLayout._hoverlayer.node());\n}\n\n/**\n * Handle dimension drag\n * @param {DimensionViewModel} d\n */\nfunction dragDimension(d) {\n // Check if dragging is supported\n if(d.parcatsViewModel.arrangement === 'fixed') {\n return;\n }\n\n d.dragHasMoved = true;\n\n if(d.dragDimensionDisplayInd === null) {\n return;\n }\n\n var dragDimInd = d.dragDimensionDisplayInd;\n var prevDimInd = dragDimInd - 1;\n var nextDimInd = dragDimInd + 1;\n\n var dragDimension = d.parcatsViewModel\n .dimensions[dragDimInd];\n\n // Update category\n if(d.dragCategoryDisplayInd !== null) {\n var dragCategory = dragDimension.categories[d.dragCategoryDisplayInd];\n\n // Update dragY by dy\n dragCategory.model.dragY += d3.event.dy;\n var categoryY = dragCategory.model.dragY;\n\n // Check for category drag swaps\n var catDisplayInd = dragCategory.model.displayInd;\n var dimCategoryViews = dragDimension.categories;\n\n var catAbove = dimCategoryViews[catDisplayInd - 1];\n var catBelow = dimCategoryViews[catDisplayInd + 1];\n\n // Check for overlap above\n if(catAbove !== undefined) {\n if(categoryY < (catAbove.y + catAbove.height / 2.0)) {\n // Swap display inds\n dragCategory.model.displayInd = catAbove.model.displayInd;\n catAbove.model.displayInd = catDisplayInd;\n }\n }\n\n if(catBelow !== undefined) {\n if((categoryY + dragCategory.height) > (catBelow.y + catBelow.height / 2.0)) {\n // Swap display inds\n dragCategory.model.displayInd = catBelow.model.displayInd;\n catBelow.model.displayInd = catDisplayInd;\n }\n }\n\n // Update category drag display index\n d.dragCategoryDisplayInd = dragCategory.model.displayInd;\n }\n\n // Update dimension position\n if(d.dragCategoryDisplayInd === null || d.parcatsViewModel.arrangement === 'freeform') {\n dragDimension.model.dragX = d3.event.x;\n\n // Check for dimension swaps\n var prevDimension = d.parcatsViewModel.dimensions[prevDimInd];\n var nextDimension = d.parcatsViewModel.dimensions[nextDimInd];\n\n if(prevDimension !== undefined) {\n if(dragDimension.model.dragX < (prevDimension.x + prevDimension.width)) {\n // Swap display inds\n dragDimension.model.displayInd = prevDimension.model.displayInd;\n prevDimension.model.displayInd = dragDimInd;\n }\n }\n\n if(nextDimension !== undefined) {\n if((dragDimension.model.dragX + dragDimension.width) > nextDimension.x) {\n // Swap display inds\n dragDimension.model.displayInd = nextDimension.model.displayInd;\n nextDimension.model.displayInd = d.dragDimensionDisplayInd;\n }\n }\n\n // Update drag display index\n d.dragDimensionDisplayInd = dragDimension.model.displayInd;\n }\n\n // Update view models\n updateDimensionViewModels(d.parcatsViewModel);\n updatePathViewModels(d.parcatsViewModel);\n\n // Update svg geometry\n updateSvgCategories(d.parcatsViewModel);\n updateSvgPaths(d.parcatsViewModel);\n}\n\n\n/**\n * Handle dimension drag end\n * @param {DimensionViewModel} d\n */\nfunction dragDimensionEnd(d) {\n // Check if dragging is supported\n if(d.parcatsViewModel.arrangement === 'fixed') {\n return;\n }\n\n if(d.dragDimensionDisplayInd === null) {\n return;\n }\n\n d3.select(this).selectAll('text').attr('font-weight', 'normal');\n\n // Compute restyle command\n // -----------------------\n var restyleData = {};\n var traceInd = getTraceIndex(d.parcatsViewModel);\n\n // ### Handle dimension reordering ###\n var finalDragDimensionDisplayInds = d.parcatsViewModel.model.dimensions.map(function(d) {return d.displayInd;});\n var anyDimsReordered = d.initialDragDimensionDisplayInds.some(function(initDimDisplay, dimInd) {\n return initDimDisplay !== finalDragDimensionDisplayInds[dimInd];\n });\n\n if(anyDimsReordered) {\n finalDragDimensionDisplayInds.forEach(function(finalDimDisplay, dimInd) {\n var containerInd = d.parcatsViewModel.model.dimensions[dimInd].containerInd;\n restyleData['dimensions[' + containerInd + '].displayindex'] = finalDimDisplay;\n });\n }\n\n // ### Handle category reordering ###\n var anyCatsReordered = false;\n if(d.dragCategoryDisplayInd !== null) {\n var finalDragCategoryDisplayInds = d.model.categories.map(function(c) {\n return c.displayInd;\n });\n\n anyCatsReordered = d.initialDragCategoryDisplayInds.some(function(initCatDisplay, catInd) {\n return initCatDisplay !== finalDragCategoryDisplayInds[catInd];\n });\n\n if(anyCatsReordered) {\n // Sort a shallow copy of the category models by display index\n var sortedCategoryModels = d.model.categories.slice().sort(\n function(a, b) { return a.displayInd - b.displayInd; });\n\n // Get new categoryarray and ticktext values\n var newCategoryArray = sortedCategoryModels.map(function(v) { return v.categoryValue; });\n var newCategoryLabels = sortedCategoryModels.map(function(v) { return v.categoryLabel; });\n\n restyleData['dimensions[' + d.model.containerInd + '].categoryarray'] = [newCategoryArray];\n restyleData['dimensions[' + d.model.containerInd + '].ticktext'] = [newCategoryLabels];\n restyleData['dimensions[' + d.model.containerInd + '].categoryorder'] = 'array';\n }\n }\n\n // Handle potential click event\n // ----------------------------\n if(d.parcatsViewModel.hoverinfoItems.indexOf('skip') === -1) {\n if(!d.dragHasMoved && d.potentialClickBand) {\n if(d.parcatsViewModel.hoveron === 'color') {\n emitPointsEventColorHovermode(d.potentialClickBand, 'plotly_click', d3.event.sourceEvent);\n } else {\n emitPointsEventCategoryHovermode(d.potentialClickBand, 'plotly_click', d3.event.sourceEvent);\n }\n }\n }\n\n // Nullify drag states\n // -------------------\n d.model.dragX = null;\n if(d.dragCategoryDisplayInd !== null) {\n var dragCategory = d.parcatsViewModel\n .dimensions[d.dragDimensionDisplayInd]\n .categories[d.dragCategoryDisplayInd];\n\n dragCategory.model.dragY = null;\n d.dragCategoryDisplayInd = null;\n }\n\n d.dragDimensionDisplayInd = null;\n d.parcatsViewModel.dragDimension = null;\n d.dragHasMoved = null;\n d.potentialClickBand = null;\n\n // Update view models\n // ------------------\n updateDimensionViewModels(d.parcatsViewModel);\n updatePathViewModels(d.parcatsViewModel);\n\n // Perform transition\n // ------------------\n var transition = d3.transition()\n .duration(300)\n .ease('cubic-in-out');\n\n transition\n .each(function() {\n updateSvgCategories(d.parcatsViewModel, true);\n updateSvgPaths(d.parcatsViewModel, true);\n })\n .each('end', function() {\n if(anyDimsReordered || anyCatsReordered) {\n // Perform restyle if the order of categories or dimensions changed\n Plotly.restyle(d.parcatsViewModel.graphDiv, restyleData, [traceInd]);\n }\n });\n}\n\n/**\n *\n * @param {ParcatsViewModel} parcatsViewModel\n */\nfunction getTraceIndex(parcatsViewModel) {\n var traceInd;\n var allTraces = parcatsViewModel.graphDiv._fullData;\n for(var i = 0; i < allTraces.length; i++) {\n if(parcatsViewModel.key === allTraces[i].uid) {\n traceInd = i;\n break;\n }\n }\n return traceInd;\n}\n\n/** Update the svg paths for view model\n * @param {ParcatsViewModel} parcatsViewModel\n * @param {boolean} hasTransition Whether to update element with transition\n */\nfunction updateSvgPaths(parcatsViewModel, hasTransition) {\n if(hasTransition === undefined) {\n hasTransition = false;\n }\n\n function transition(selection) {\n return hasTransition ? selection.transition() : selection;\n }\n\n // Update binding\n parcatsViewModel.pathSelection.data(function(d) {\n return d.paths;\n }, key);\n\n // Update paths\n transition(parcatsViewModel.pathSelection).attr('d', function(d) {\n return d.svgD;\n });\n}\n\n/** Update the svg paths for view model\n * @param {ParcatsViewModel} parcatsViewModel\n * @param {boolean} hasTransition Whether to update element with transition\n */\nfunction updateSvgCategories(parcatsViewModel, hasTransition) {\n if(hasTransition === undefined) {\n hasTransition = false;\n }\n\n function transition(selection) {\n return hasTransition ? selection.transition() : selection;\n }\n\n // Update binding\n parcatsViewModel.dimensionSelection\n .data(function(d) {\n return d.dimensions;\n }, key);\n\n var categorySelection = parcatsViewModel.dimensionSelection\n .selectAll('g.category')\n .data(function(d) {return d.categories;}, key);\n\n // Update dimension position\n transition(parcatsViewModel.dimensionSelection)\n .attr('transform', function(d) {\n return strTranslate(d.x, 0);\n });\n\n // Update category position\n transition(categorySelection)\n .attr('transform', function(d) {\n return strTranslate(0, d.y);\n });\n\n var dimLabelSelection = categorySelection.select('.dimlabel');\n\n // ### Update dimension label\n // Only the top-most display category should have the dimension label\n dimLabelSelection\n .text(function(d, i) {\n if(i === 0) {\n // Add dimension label above topmost category\n return d.parcatsViewModel.model.dimensions[d.model.dimensionInd].dimensionLabel;\n } else {\n return null;\n }\n });\n\n // Update category label\n // Categories in the right-most display dimension have their labels on\n // the right, all others on the left\n var catLabelSelection = categorySelection.select('.catlabel');\n catLabelSelection\n .attr('text-anchor',\n function(d) {\n if(catInRightDim(d)) {\n // Place label to the right of category\n return 'start';\n } else {\n // Place label to the left of category\n return 'end';\n }\n })\n .attr('x',\n function(d) {\n if(catInRightDim(d)) {\n // Place label to the right of category\n return d.width + 5;\n } else {\n // Place label to the left of category\n return -5;\n }\n })\n .each(function(d) {\n // Update attriubutes of elements\n var newX;\n var newAnchor;\n if(catInRightDim(d)) {\n // Place label to the right of category\n newX = d.width + 5;\n newAnchor = 'start';\n } else {\n // Place label to the left of category\n newX = -5;\n newAnchor = 'end';\n }\n d3.select(this)\n .selectAll('tspan')\n .attr('x', newX)\n .attr('text-anchor', newAnchor);\n });\n\n // Update bands\n // Initialize color band rects\n var bandSelection = categorySelection\n .selectAll('rect.bandrect')\n .data(\n /** @param {CategoryViewModel} catViewModel*/\n function(catViewModel) {\n return catViewModel.bands;\n }, key);\n\n var bandsSelectionEnter = bandSelection.enter()\n .append('rect')\n .attr('class', 'bandrect')\n .attr('cursor', 'move')\n .attr('stroke-opacity', 0)\n .attr('fill', function(d) {\n return d.color;\n })\n .attr('fill-opacity', 0);\n\n bandSelection\n .attr('fill', function(d) {\n return d.color;\n })\n .attr('width', function(d) {\n return d.width;\n })\n .attr('height', function(d) {\n return d.height;\n })\n .attr('y', function(d) {\n return d.y;\n });\n\n styleBandsNoHover(bandsSelectionEnter);\n\n // Raise bands to the top\n bandSelection.each(function() {Lib.raiseToTop(this);});\n\n // Remove unused bands\n bandSelection.exit().remove();\n}\n\n/**\n * Create a ParcatsViewModel traces\n * @param {Object} graphDiv\n * Top-level graph div element\n * @param {Layout} layout\n * SVG layout object\n * @param {Array.} wrappedParcatsModel\n * Wrapped ParcatsModel for this trace\n * @return {ParcatsViewModel}\n */\nfunction createParcatsViewModel(graphDiv, layout, wrappedParcatsModel) {\n // Unwrap model\n var parcatsModel = wrappedParcatsModel[0];\n\n // Compute margin\n var margin = layout.margin || {l: 80, r: 80, t: 100, b: 80};\n\n // Compute pixel position/extents\n var trace = parcatsModel.trace;\n var domain = trace.domain;\n var figureWidth = layout.width;\n var figureHeight = layout.height;\n var traceWidth = Math.floor(figureWidth * (domain.x[1] - domain.x[0]));\n var traceHeight = Math.floor(figureHeight * (domain.y[1] - domain.y[0]));\n var traceX = domain.x[0] * figureWidth + margin.l;\n var traceY = layout.height - domain.y[1] * layout.height + margin.t;\n\n // Handle path shape\n // -----------------\n var pathShape = trace.line.shape;\n\n // Handle hover info\n // -----------------\n var hoverinfoItems;\n if(trace.hoverinfo === 'all') {\n hoverinfoItems = ['count', 'probability'];\n } else {\n hoverinfoItems = (trace.hoverinfo || '').split('+');\n }\n\n // Construct parcatsViewModel\n // --------------------------\n var parcatsViewModel = {\n trace: trace,\n key: trace.uid,\n model: parcatsModel,\n x: traceX,\n y: traceY,\n width: traceWidth,\n height: traceHeight,\n hoveron: trace.hoveron,\n hoverinfoItems: hoverinfoItems,\n arrangement: trace.arrangement,\n bundlecolors: trace.bundlecolors,\n sortpaths: trace.sortpaths,\n labelfont: trace.labelfont,\n categorylabelfont: trace.tickfont,\n pathShape: pathShape,\n dragDimension: null,\n margin: margin,\n paths: [],\n dimensions: [],\n graphDiv: graphDiv,\n traceSelection: null,\n pathSelection: null,\n dimensionSelection: null\n };\n\n // Update dimension view models if we have at least 1 dimension\n if(parcatsModel.dimensions) {\n updateDimensionViewModels(parcatsViewModel);\n\n // Update path view models if we have at least 2 dimensions\n updatePathViewModels(parcatsViewModel);\n }\n // Inside a categories view model\n return parcatsViewModel;\n}\n\n/**\n * Build the SVG string to represents a parallel categories path\n * @param {Array.} leftXPositions\n * Array of the x positions of the left edge of each dimension (in display order)\n * @param {Array.} pathYs\n * Array of the y positions of the top of the path at each dimension (in display order)\n * @param {Array.} dimWidths\n * Array of the widths of each dimension in display order\n * @param {Number} pathHeight\n * The height of the path in pixels\n * @param {Number} curvature\n * The curvature factor for the path. 0 results in a straight line and values greater than zero result in curved paths\n * @return {string}\n */\nfunction buildSvgPath(leftXPositions, pathYs, dimWidths, pathHeight, curvature) {\n // Compute the x midpoint of each path segment\n var xRefPoints1 = [];\n var xRefPoints2 = [];\n var refInterpolator;\n var d;\n\n for(d = 0; d < dimWidths.length - 1; d++) {\n refInterpolator = interpolateNumber(dimWidths[d] + leftXPositions[d], leftXPositions[d + 1]);\n xRefPoints1.push(refInterpolator(curvature));\n xRefPoints2.push(refInterpolator(1 - curvature));\n }\n\n // Move to top of path on left edge of left-most category\n var svgD = 'M ' + leftXPositions[0] + ',' + pathYs[0];\n\n // Horizontal line to right edge\n svgD += 'l' + dimWidths[0] + ',0 ';\n\n // Horizontal line to right edge\n for(d = 1; d < dimWidths.length; d++) {\n // Curve to left edge of category\n svgD += 'C' + xRefPoints1[d - 1] + ',' + pathYs[d - 1] +\n ' ' + xRefPoints2[d - 1] + ',' + pathYs[d] +\n ' ' + leftXPositions[d] + ',' + pathYs[d];\n\n // svgD += 'L' + leftXPositions[d] + ',' + pathYs[d];\n\n // Horizontal line to right edge\n svgD += 'l' + dimWidths[d] + ',0 ';\n }\n\n // Line down\n svgD += 'l' + '0,' + pathHeight + ' ';\n\n // Line to left edge of right-most category\n svgD += 'l -' + dimWidths[dimWidths.length - 1] + ',0 ';\n\n for(d = dimWidths.length - 2; d >= 0; d--) {\n // Curve to right edge of category\n svgD += 'C' + xRefPoints2[d] + ',' + (pathYs[d + 1] + pathHeight) +\n ' ' + xRefPoints1[d] + ',' + (pathYs[d] + pathHeight) +\n ' ' + (leftXPositions[d] + dimWidths[d]) + ',' + (pathYs[d] + pathHeight);\n\n // svgD += 'L' + (leftXPositions[d] + dimWidths[d]) + ',' + (pathYs[d] + pathHeight);\n\n // Horizontal line to right edge\n svgD += 'l-' + dimWidths[d] + ',0 ';\n }\n\n // Close path\n svgD += 'Z';\n return svgD;\n}\n\n/**\n * Update the path view models based on the dimension view models in a ParcatsViewModel\n *\n * @param {ParcatsViewModel} parcatsViewModel\n * View model for trace\n */\nfunction updatePathViewModels(parcatsViewModel) {\n // Initialize an array of the y position of the top of the next path to be added to each category.\n //\n // nextYPositions[d][c] is the y position of the next path through category with index c of dimension with index d\n var dimensionViewModels = parcatsViewModel.dimensions;\n var parcatsModel = parcatsViewModel.model;\n var nextYPositions = dimensionViewModels.map(\n function(d) {\n return d.categories.map(\n function(c) {\n return c.y;\n });\n });\n\n // Array from category index to category display index for each true dimension index\n var catToDisplayIndPerDim = parcatsViewModel.model.dimensions.map(\n function(d) {\n return d.categories.map(function(c) {return c.displayInd;});\n });\n\n // Array from true dimension index to dimension display index\n var dimToDisplayInd = parcatsViewModel.model.dimensions.map(function(d) {return d.displayInd;});\n var displayToDimInd = parcatsViewModel.dimensions.map(function(d) {return d.model.dimensionInd;});\n\n // Array of the x position of the left edge of the rectangles for each dimension\n var leftXPositions = dimensionViewModels.map(\n function(d) {\n return d.x;\n });\n\n // Compute dimension widths\n var dimWidths = dimensionViewModels.map(function(d) {return d.width;});\n\n // Build sorted Array of PathModel objects\n var pathModels = [];\n for(var p in parcatsModel.paths) {\n if(parcatsModel.paths.hasOwnProperty(p)) {\n pathModels.push(parcatsModel.paths[p]);\n }\n }\n\n // Compute category display inds to use for sorting paths\n function pathDisplayCategoryInds(pathModel) {\n var dimensionInds = pathModel.categoryInds.map(function(catInd, dimInd) {return catToDisplayIndPerDim[dimInd][catInd];});\n var displayInds = displayToDimInd.map(function(dimInd) {\n return dimensionInds[dimInd];\n });\n return displayInds;\n }\n\n // Sort in ascending order by display index array\n pathModels.sort(function(v1, v2) {\n // Build display inds for each path\n var sortArray1 = pathDisplayCategoryInds(v1);\n var sortArray2 = pathDisplayCategoryInds(v2);\n\n // Handle path sort order\n if(parcatsViewModel.sortpaths === 'backward') {\n sortArray1.reverse();\n sortArray2.reverse();\n }\n\n // Append the first value index of the path to break ties\n sortArray1.push(v1.valueInds[0]);\n sortArray2.push(v2.valueInds[0]);\n\n // Handle color bundling\n if(parcatsViewModel.bundlecolors) {\n // Prepend sort array with the raw color value\n sortArray1.unshift(v1.rawColor);\n sortArray2.unshift(v2.rawColor);\n }\n\n // colors equal, sort by display categories\n if(sortArray1 < sortArray2) {\n return -1;\n }\n if(sortArray1 > sortArray2) {\n return 1;\n }\n\n return 0;\n });\n\n // Create path models\n var pathViewModels = new Array(pathModels.length);\n var totalCount = dimensionViewModels[0].model.count;\n var totalHeight = dimensionViewModels[0].categories\n .map(function(c) { return c.height; })\n .reduce(function(v1, v2) { return v1 + v2; });\n\n\n for(var pathNumber = 0; pathNumber < pathModels.length; pathNumber++) {\n var pathModel = pathModels[pathNumber];\n\n var pathHeight;\n if(totalCount > 0) {\n pathHeight = totalHeight * (pathModel.count / totalCount);\n } else {\n pathHeight = 0;\n }\n\n // Build path y coords\n var pathYs = new Array(nextYPositions.length);\n for(var d = 0; d < pathModel.categoryInds.length; d++) {\n var catInd = pathModel.categoryInds[d];\n var catDisplayInd = catToDisplayIndPerDim[d][catInd];\n var dimDisplayInd = dimToDisplayInd[d];\n\n // Update next y position\n pathYs[dimDisplayInd] = nextYPositions[dimDisplayInd][catDisplayInd];\n nextYPositions[dimDisplayInd][catDisplayInd] += pathHeight;\n\n // Update category color information\n var catViewModle = parcatsViewModel.dimensions[dimDisplayInd].categories[catDisplayInd];\n var numBands = catViewModle.bands.length;\n var lastCatBand = catViewModle.bands[numBands - 1];\n\n if(lastCatBand === undefined || pathModel.rawColor !== lastCatBand.rawColor) {\n // Create a new band\n var bandY = lastCatBand === undefined ? 0 : lastCatBand.y + lastCatBand.height;\n catViewModle.bands.push({\n key: bandY,\n color: pathModel.color,\n rawColor: pathModel.rawColor,\n height: pathHeight,\n width: catViewModle.width,\n count: pathModel.count,\n y: bandY,\n categoryViewModel: catViewModle,\n parcatsViewModel: parcatsViewModel\n });\n } else {\n // Extend current band\n var currentBand = catViewModle.bands[numBands - 1];\n currentBand.height += pathHeight;\n currentBand.count += pathModel.count;\n }\n }\n\n // build svg path\n var svgD;\n if(parcatsViewModel.pathShape === 'hspline') {\n svgD = buildSvgPath(leftXPositions, pathYs, dimWidths, pathHeight, 0.5);\n } else {\n svgD = buildSvgPath(leftXPositions, pathYs, dimWidths, pathHeight, 0);\n }\n\n pathViewModels[pathNumber] = {\n key: pathModel.valueInds[0],\n model: pathModel,\n height: pathHeight,\n leftXs: leftXPositions,\n topYs: pathYs,\n dimWidths: dimWidths,\n svgD: svgD,\n parcatsViewModel: parcatsViewModel\n };\n }\n\n parcatsViewModel.paths = pathViewModels;\n\n // * @property key\n // * Unique key for this model\n // * @property {PathModel} model\n // * Source path model\n // * @property {Number} height\n // * Height of this path (pixels)\n // * @property {String} svgD\n // * SVG path \"d\" attribute string\n}\n\n/**\n * Update the dimension view models based on the dimension models in a ParcatsViewModel\n *\n * @param {ParcatsViewModel} parcatsViewModel\n * View model for trace\n */\nfunction updateDimensionViewModels(parcatsViewModel) {\n // Compute dimension ordering\n var dimensionsIndInfo = parcatsViewModel.model.dimensions.map(function(d) {\n return {displayInd: d.displayInd, dimensionInd: d.dimensionInd};\n });\n\n dimensionsIndInfo.sort(function(a, b) {\n return a.displayInd - b.displayInd;\n });\n\n var dimensions = [];\n for(var displayInd in dimensionsIndInfo) {\n var dimensionInd = dimensionsIndInfo[displayInd].dimensionInd;\n var dimModel = parcatsViewModel.model.dimensions[dimensionInd];\n dimensions.push(createDimensionViewModel(parcatsViewModel, dimModel));\n }\n\n parcatsViewModel.dimensions = dimensions;\n}\n\n/**\n * Create a parcats DimensionViewModel\n *\n * @param {ParcatsViewModel} parcatsViewModel\n * View model for trace\n * @param {DimensionModel} dimensionModel\n * @return {DimensionViewModel}\n */\nfunction createDimensionViewModel(parcatsViewModel, dimensionModel) {\n // Compute dimension x position\n var categoryLabelPad = 40;\n var dimWidth = 16;\n var numDimensions = parcatsViewModel.model.dimensions.length;\n var displayInd = dimensionModel.displayInd;\n\n // Compute x coordinate values\n var dimDx;\n var dimX0;\n var dimX;\n\n if(numDimensions > 1) {\n dimDx = (parcatsViewModel.width - 2 * categoryLabelPad - dimWidth) / (numDimensions - 1);\n } else {\n dimDx = 0;\n }\n dimX0 = categoryLabelPad;\n dimX = dimX0 + dimDx * displayInd;\n\n // Compute categories\n var categories = [];\n var maxCats = parcatsViewModel.model.maxCats;\n var numCats = dimensionModel.categories.length;\n var catSpacing = 8;\n var totalCount = dimensionModel.count;\n var totalHeight = parcatsViewModel.height - catSpacing * (maxCats - 1);\n var nextCatHeight;\n var nextCatModel;\n var nextCat;\n var catInd;\n var catDisplayInd;\n\n // Compute starting Y offset\n var nextCatY = (maxCats - numCats) * catSpacing / 2.0;\n\n // Compute category ordering\n var categoryIndInfo = dimensionModel.categories.map(function(c) {\n return {displayInd: c.displayInd, categoryInd: c.categoryInd};\n });\n\n categoryIndInfo.sort(function(a, b) {\n return a.displayInd - b.displayInd;\n });\n\n for(catDisplayInd = 0; catDisplayInd < numCats; catDisplayInd++) {\n catInd = categoryIndInfo[catDisplayInd].categoryInd;\n nextCatModel = dimensionModel.categories[catInd];\n\n if(totalCount > 0) {\n nextCatHeight = (nextCatModel.count / totalCount) * totalHeight;\n } else {\n nextCatHeight = 0;\n }\n\n nextCat = {\n key: nextCatModel.valueInds[0],\n model: nextCatModel,\n width: dimWidth,\n height: nextCatHeight,\n y: nextCatModel.dragY !== null ? nextCatModel.dragY : nextCatY,\n bands: [],\n parcatsViewModel: parcatsViewModel\n };\n\n nextCatY = nextCatY + nextCatHeight + catSpacing;\n categories.push(nextCat);\n }\n\n return {\n key: dimensionModel.dimensionInd,\n x: dimensionModel.dragX !== null ? dimensionModel.dragX : dimX,\n y: 0,\n width: dimWidth,\n model: dimensionModel,\n categories: categories,\n parcatsViewModel: parcatsViewModel,\n dragCategoryDisplayInd: null,\n dragDimensionDisplayInd: null,\n initialDragDimensionDisplayInds: null,\n initialDragCategoryDisplayInds: null,\n dragHasMoved: null,\n potentialClickBand: null\n };\n}\n\n// JSDoc typedefs\n// ==============\n/**\n * @typedef {Object} Layout\n * Object containing svg layout information\n *\n * @property {Number} width (pixels)\n * Usable width for Figure (after margins are removed)\n * @property {Number} height (pixels)\n * Usable height for Figure (after margins are removed)\n * @property {Margin} margin\n * Margin around the Figure (pixels)\n */\n\n/**\n * @typedef {Object} Margin\n * Object containing padding information in pixels\n *\n * @property {Number} t\n * Top margin\n * @property {Number} r\n * Right margin\n * @property {Number} b\n * Bottom margin\n * @property {Number} l\n * Left margin\n */\n\n/**\n * @typedef {Object} Font\n * Object containing font information\n *\n * @property {Number} size: Font size\n * @property {String} color: Font color\n * @property {String} family: Font family\n */\n\n/**\n * @typedef {Object} ParcatsViewModel\n * Object containing calculated parcats view information\n *\n * These are quantities that require Layout information to calculate\n * @property key\n * Unique key for this model\n * @property {ParcatsModel} model\n * Source parcats model\n * @property {Array.} dimensions\n * Array of dimension view models\n * @property {Number} width\n * Width for this trace (pixels)\n * @property {Number} height\n * Height for this trace (pixels)\n * @property {Number} x\n * X position of this trace with respect to the Figure (pixels)\n * @property {Number} y\n * Y position of this trace with respect to the Figure (pixels)\n * @property {String} hoveron\n * Hover interaction mode. One of: 'category', 'color', or 'dimension'\n * @property {Array.} hoverinfoItems\n * Info to display on hover. Array with a combination of 'counts' and/or 'probabilities', or 'none', or 'skip'\n * @property {String} arrangement\n * Category arrangement. One of: 'perpendicular', 'freeform', or 'fixed'\n * @property {Boolean} bundlecolors\n * Whether paths should be sorted so that like colors are bundled together as they pass through categories\n * @property {String} sortpaths\n * If 'forward' then sort paths based on dimensions from left to right. If 'backward' sort based on dimensions\n * from right to left\n * @property {Font} labelfont\n * Font for the dimension labels\n * @property {Font} categorylabelfont\n * Font for the category labels\n * @property {String} pathShape\n * The shape of the paths. Either 'linear' or 'hspline'.\n * @property {DimensionViewModel|null} dragDimension\n * Dimension currently being dragged. Null if no drag in progress\n * @property {Margin} margin\n * Margin around the Figure\n * @property {Object} graphDiv\n * Top-level graph div element\n * @property {Object} traceSelection\n * D3 selection of this view models trace group element\n * @property {Object} pathSelection\n * D3 selection of this view models path elements\n * @property {Object} dimensionSelection\n * D3 selection of this view models dimension group element\n */\n\n/**\n * @typedef {Object} DimensionViewModel\n * Object containing calculated parcats dimension view information\n *\n * These are quantities that require Layout information to calculate\n * @property key\n * Unique key for this model\n * @property {DimensionModel} model\n * Source dimension model\n * @property {Number} x\n * X position of the center of this dimension with respect to the Figure (pixels)\n * @property {Number} y\n * Y position of the top of this dimension with respect to the Figure (pixels)\n * @property {Number} width\n * Width of categories in this dimension (pixels)\n * @property {ParcatsViewModel} parcatsViewModel\n * The parent trace's view model\n * @property {Array.} categories\n * Dimensions category view models\n * @property {Number|null} dragCategoryDisplayInd\n * Display index of category currently being dragged. null if no category is being dragged\n * @property {Number|null} dragDimensionDisplayInd\n * Display index of the dimension being dragged. null if no dimension is being dragged\n * @property {Array.|null} initialDragDimensionDisplayInds\n * Dimensions display indexes at the beginning of the current drag. null if no dimension is being dragged\n * @property {Array.|null} initialDragCategoryDisplayInds\n * Category display indexes for the at the beginning of the current drag. null if no category is being dragged\n * @property {HTMLElement} potentialClickBand\n * Band under mouse when current drag began. If no drag movement takes place then a click will be emitted for this\n * band. Null if not drag in progress.\n * @property {Boolean} dragHasMoved\n * True if there is an active drag and the drag has moved. If drag doesn't move before being ended then\n * this may be interpreted as a click. Null if no drag in progress\n */\n\n/**\n * @typedef {Object} CategoryViewModel\n * Object containing calculated parcats category view information\n *\n * These are quantities that require Layout information to calculate\n * @property key\n * Unique key for this model\n * @property {CategoryModel} model\n * Source category model\n * @property {Number} width\n * Width for this category (pixels)\n * @property {Number} height\n * Height for this category (pixels)\n * @property {Number} y\n * Y position of this cateogry with respect to the Figure (pixels)\n * @property {Array.} bands\n * Array of color bands inside the category\n * @property {ParcatsViewModel} parcatsViewModel\n * The parent trace's view model\n */\n\n/**\n * @typedef {Object} CategoryBandViewModel\n * Object containing calculated category band information. A category band is a region inside a category covering\n * paths of a single color\n *\n * @property key\n * Unique key for this model\n * @property color\n * Band color\n * @property rawColor\n * Raw color value for band\n * @property {Number} width\n * Band width\n * @property {Number} height\n * Band height\n * @property {Number} y\n * Y position of top of the band with respect to the category\n * @property {Number} count\n * The number of samples represented by the band\n * @property {CategoryViewModel} categoryViewModel\n * The parent categorie's view model\n * @property {ParcatsViewModel} parcatsViewModel\n * The parent trace's view model\n */\n\n/**\n * @typedef {Object} PathViewModel\n * Object containing calculated parcats path view information\n *\n * These are quantities that require Layout information to calculate\n * @property key\n * Unique key for this model\n * @property {PathModel} model\n * Source path model\n * @property {Number} height\n * Height of this path (pixels)\n * @property {Array.} leftXs\n * The x position of the left edge of each display dimension\n * @property {Array.} topYs\n * The y position of the top of the path for each display dimension\n * @property {Array.} dimWidths\n * The width of each display dimension\n * @property {String} svgD\n * SVG path \"d\" attribute string\n * @property {ParcatsViewModel} parcatsViewModel\n * The parent trace's view model\n */\n","'use strict';\n\n\nvar parcats = require('./parcats');\n\n/**\n * Create / update parcat traces\n *\n * @param {Object} graphDiv\n * @param {Array.} parcatsModels\n */\nmodule.exports = function plot(graphDiv, parcatsModels, transitionOpts, makeOnCompleteCallback) {\n var fullLayout = graphDiv._fullLayout;\n var svg = fullLayout._paper;\n var size = fullLayout._size;\n\n parcats(\n graphDiv,\n svg,\n parcatsModels,\n {\n width: size.w,\n height: size.h,\n margin: {\n t: size.t,\n r: size.r,\n b: size.b,\n l: size.l\n }\n },\n transitionOpts,\n makeOnCompleteCallback\n );\n};\n","'use strict';\n\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar axesAttrs = require('../../plots/cartesian/layout_attributes');\nvar fontAttrs = require('../../plots/font_attributes');\nvar domainAttrs = require('../../plots/domain').attributes;\n\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\n\nmodule.exports = {\n domain: domainAttrs({name: 'parcoords', trace: true, editType: 'plot'}),\n\n labelangle: {\n valType: 'angle',\n dflt: 0,\n editType: 'plot',\n description: [\n 'Sets the angle of the labels with respect to the horizontal.',\n 'For example, a `tickangle` of -90 draws the labels vertically.',\n 'Tilted labels with *labelangle* may be positioned better',\n 'inside margins when `labelposition` is set to *bottom*.'\n ].join(' ')\n },\n\n labelside: {\n valType: 'enumerated',\n values: ['top', 'bottom'],\n dflt: 'top',\n editType: 'plot',\n description: [\n 'Specifies the location of the `label`.',\n '*top* positions labels above, next to the title',\n '*bottom* positions labels below the graph',\n 'Tilted labels with *labelangle* may be positioned better',\n 'inside margins when `labelposition` is set to *bottom*.'\n ].join(' ')\n },\n\n labelfont: fontAttrs({\n editType: 'plot',\n description: 'Sets the font for the `dimension` labels.'\n }),\n tickfont: fontAttrs({\n autoShadowDflt: true,\n editType: 'plot',\n description: 'Sets the font for the `dimension` tick values.'\n }),\n rangefont: fontAttrs({\n editType: 'plot',\n description: 'Sets the font for the `dimension` range values.'\n }),\n\n dimensions: templatedArray('dimension', {\n label: {\n valType: 'string',\n editType: 'plot',\n description: 'The shown name of the dimension.'\n },\n // TODO: better way to determine ordinal vs continuous axes,\n // so users can use tickvals/ticktext with a continuous axis.\n tickvals: extendFlat({}, axesAttrs.tickvals, {\n editType: 'plot',\n description: [\n 'Sets the values at which ticks on this axis appear.'\n ].join(' ')\n }),\n ticktext: extendFlat({}, axesAttrs.ticktext, {\n editType: 'plot',\n description: [\n 'Sets the text displayed at the ticks position via `tickvals`.'\n ].join(' ')\n }),\n tickformat: extendFlat({}, axesAttrs.tickformat, {\n editType: 'plot'\n }),\n visible: {\n valType: 'boolean',\n dflt: true,\n editType: 'plot',\n description: 'Shows the dimension when set to `true` (the default). Hides the dimension for `false`.'\n },\n range: {\n valType: 'info_array',\n items: [\n {valType: 'number', editType: 'plot'},\n {valType: 'number', editType: 'plot'}\n ],\n editType: 'plot',\n description: [\n 'The domain range that represents the full, shown axis extent. Defaults to the `values` extent.',\n 'Must be an array of `[fromValue, toValue]` with finite numbers as elements.'\n ].join(' ')\n },\n constraintrange: {\n valType: 'info_array',\n freeLength: true,\n dimensions: '1-2',\n items: [\n {valType: 'any', editType: 'plot'},\n {valType: 'any', editType: 'plot'}\n ],\n editType: 'plot',\n description: [\n 'The domain range to which the filter on the dimension is constrained. Must be an array',\n 'of `[fromValue, toValue]` with `fromValue <= toValue`, or if `multiselect` is not',\n 'disabled, you may give an array of arrays, where each inner array is `[fromValue, toValue]`.'\n ].join(' ')\n },\n multiselect: {\n valType: 'boolean',\n dflt: true,\n editType: 'plot',\n description: 'Do we allow multiple selection ranges or just a single range?'\n },\n values: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Dimension values. `values[n]` represents the value of the `n`th point in the dataset,',\n 'therefore the `values` vector for all dimensions must be the same (longer vectors',\n 'will be truncated). Each value must be a finite number.'\n ].join(' ')\n },\n editType: 'calc',\n description: 'The dimensions (variables) of the parallel coordinates chart. 2..60 dimensions are supported.'\n }),\n\n line: extendFlat({editType: 'calc'},\n colorScaleAttrs('line', {\n // the default autocolorscale isn't quite usable for parcoords due to context ambiguity around 0 (grey, off-white)\n // autocolorscale therefore defaults to false too, to avoid being overridden by the blue-white-red autocolor palette\n colorscaleDflt: 'Viridis',\n autoColorDflt: false,\n editTypeOverride: 'calc'\n })\n ),\n\n unselected: {\n line: {\n color: {\n valType: 'color',\n dflt: '#7f7f7f',\n editType: 'plot',\n description: [\n 'Sets the base color of unselected lines.',\n 'in connection with `unselected.line.opacity`.'\n ].join(' ')\n },\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 'auto',\n editType: 'plot',\n description: [\n 'Sets the opacity of unselected lines.',\n 'The default *auto* decreases the opacity smoothly as the number of lines increases.',\n 'Use *1* to achieve exact `unselected.line.color`.'\n ].join(' ')\n },\n editType: 'plot'\n },\n editType: 'plot'\n }\n};\n","'use strict';\n\nvar c = require('./constants');\nvar d3 = require('@plotly/d3');\nvar keyFun = require('../../lib/gup').keyFun;\nvar repeat = require('../../lib/gup').repeat;\nvar sortAsc = require('../../lib').sorterAsc;\nvar strTranslate = require('../../lib').strTranslate;\n\nvar snapRatio = c.bar.snapRatio;\nfunction snapOvershoot(v, vAdjacent) { return v * (1 - snapRatio) + vAdjacent * snapRatio; }\n\nvar snapClose = c.bar.snapClose;\nfunction closeToCovering(v, vAdjacent) { return v * (1 - snapClose) + vAdjacent * snapClose; }\n\n// snap for the low end of a range on an ordinal scale\n// on an ordinal scale, always show some overshoot from the exact value,\n// so it's clear we're covering it\n// find the interval we're in, and snap to 1/4 the distance to the next\n// these two could be unified at a slight loss of readability / perf\nfunction ordinalScaleSnap(isHigh, a, v, existingRanges) {\n if(overlappingExisting(v, existingRanges)) return v;\n\n var dir = isHigh ? -1 : 1;\n\n var first = 0;\n var last = a.length - 1;\n if(dir < 0) {\n var tmp = first;\n first = last;\n last = tmp;\n }\n\n var aHere = a[first];\n var aPrev = aHere;\n for(var i = first; dir * i < dir * last; i += dir) {\n var nextI = i + dir;\n var aNext = a[nextI];\n\n // very close to the previous - snap down to it\n if(dir * v < dir * closeToCovering(aHere, aNext)) return snapOvershoot(aHere, aPrev);\n if(dir * v < dir * aNext || nextI === last) return snapOvershoot(aNext, aHere);\n\n aPrev = aHere;\n aHere = aNext;\n }\n}\n\nfunction overlappingExisting(v, existingRanges) {\n for(var i = 0; i < existingRanges.length; i++) {\n if(v >= existingRanges[i][0] && v <= existingRanges[i][1]) return true;\n }\n return false;\n}\n\nfunction barHorizontalSetup(selection) {\n selection\n .attr('x', -c.bar.captureWidth / 2)\n .attr('width', c.bar.captureWidth);\n}\n\nfunction backgroundBarHorizontalSetup(selection) {\n selection\n .attr('visibility', 'visible')\n .style('visibility', 'visible')\n .attr('fill', 'yellow')\n .attr('opacity', 0);\n}\n\nfunction setHighlight(d) {\n if(!d.brush.filterSpecified) {\n return '0,' + d.height;\n }\n\n var pixelRanges = unitToPx(d.brush.filter.getConsolidated(), d.height);\n var dashArray = [0]; // we start with a 0 length selection as filter ranges are inclusive, not exclusive\n var p, sectionHeight, iNext;\n var currentGap = pixelRanges.length ? pixelRanges[0][0] : null;\n for(var i = 0; i < pixelRanges.length; i++) {\n p = pixelRanges[i];\n sectionHeight = p[1] - p[0];\n dashArray.push(currentGap);\n dashArray.push(sectionHeight);\n iNext = i + 1;\n if(iNext < pixelRanges.length) {\n currentGap = pixelRanges[iNext][0] - p[1];\n }\n }\n dashArray.push(d.height);\n // d.height is added at the end to ensure that (1) we have an even number of dasharray points, MDN page says\n // \"If an odd number of values is provided, then the list of values is repeated to yield an even number of values.\"\n // and (2) it's _at least_ as long as the full height (even if range is minuscule and at the bottom) though this\n // may not be necessary, maybe duplicating the last point would do too. But no harm in a longer dasharray than line.\n return dashArray;\n}\n\nfunction unitToPx(unitRanges, height) {\n return unitRanges.map(function(pr) {\n return pr.map(function(v) { return Math.max(0, v * height); }).sort(sortAsc);\n });\n}\n\n// is the cursor over the north, middle, or south of a bar?\n// the end handles extend over the last 10% of the bar\nfunction getRegion(fPix, y) {\n var pad = c.bar.handleHeight;\n if(y > fPix[1] + pad || y < fPix[0] - pad) return;\n if(y >= 0.9 * fPix[1] + 0.1 * fPix[0]) return 'n';\n if(y <= 0.9 * fPix[0] + 0.1 * fPix[1]) return 's';\n return 'ns';\n}\n\nfunction clearCursor() {\n d3.select(document.body)\n .style('cursor', null);\n}\n\nfunction styleHighlight(selection) {\n // stroke-dasharray is used to minimize the number of created DOM nodes, because the requirement calls for up to\n // 1000 individual selections on an axis, and there can be 60 axes per parcoords, and multiple parcoords per\n // dashboard. The technique is similar to https://codepen.io/monfera/pen/rLYqWR and using a `polyline` with\n // multiple sections, or a `path` element via its `d` attribute would also be DOM-sparing alternatives.\n selection.attr('stroke-dasharray', setHighlight);\n}\n\nfunction renderHighlight(root, tweenCallback) {\n var bar = d3.select(root).selectAll('.highlight, .highlight-shadow');\n var barToStyle = tweenCallback ? bar.transition().duration(c.bar.snapDuration).each('end', tweenCallback) : bar;\n styleHighlight(barToStyle);\n}\n\nfunction getInterval(d, y) {\n var b = d.brush;\n var active = b.filterSpecified;\n var closestInterval = NaN;\n var out = {};\n var i;\n\n if(active) {\n var height = d.height;\n var intervals = b.filter.getConsolidated();\n var pixIntervals = unitToPx(intervals, height);\n var hoveredInterval = NaN;\n var previousInterval = NaN;\n var nextInterval = NaN;\n for(i = 0; i <= pixIntervals.length; i++) {\n var p = pixIntervals[i];\n if(p && p[0] <= y && y <= p[1]) {\n // over a bar\n hoveredInterval = i;\n break;\n } else {\n // between bars, or before/after the first/last bar\n previousInterval = i ? i - 1 : NaN;\n if(p && p[0] > y) {\n nextInterval = i;\n break; // no point continuing as intervals are non-overlapping and sorted; could use log search\n }\n }\n }\n\n closestInterval = hoveredInterval;\n if(isNaN(closestInterval)) {\n if(isNaN(previousInterval) || isNaN(nextInterval)) {\n closestInterval = isNaN(previousInterval) ? nextInterval : previousInterval;\n } else {\n closestInterval = (y - pixIntervals[previousInterval][1] < pixIntervals[nextInterval][0] - y) ?\n previousInterval : nextInterval;\n }\n }\n\n if(!isNaN(closestInterval)) {\n var fPix = pixIntervals[closestInterval];\n var region = getRegion(fPix, y);\n\n if(region) {\n out.interval = intervals[closestInterval];\n out.intervalPix = fPix;\n out.region = region;\n }\n }\n }\n\n if(d.ordinal && !out.region) {\n var a = d.unitTickvals;\n var unitLocation = d.unitToPaddedPx.invert(y);\n for(i = 0; i < a.length; i++) {\n var rangei = [\n a[Math.max(i - 1, 0)] * 0.25 + a[i] * 0.75,\n a[Math.min(i + 1, a.length - 1)] * 0.25 + a[i] * 0.75\n ];\n if(unitLocation >= rangei[0] && unitLocation <= rangei[1]) {\n out.clickableOrdinalRange = rangei;\n break;\n }\n }\n }\n\n return out;\n}\n\nfunction dragstart(lThis, d) {\n d3.event.sourceEvent.stopPropagation();\n var y = d.height - d3.mouse(lThis)[1] - 2 * c.verticalPadding;\n var unitLocation = d.unitToPaddedPx.invert(y);\n var b = d.brush;\n var interval = getInterval(d, y);\n var unitRange = interval.interval;\n var s = b.svgBrush;\n s.wasDragged = false; // we start assuming there won't be a drag - useful for reset\n s.grabbingBar = interval.region === 'ns';\n if(s.grabbingBar) {\n var pixelRange = unitRange.map(d.unitToPaddedPx);\n s.grabPoint = y - pixelRange[0] - c.verticalPadding;\n s.barLength = pixelRange[1] - pixelRange[0];\n }\n s.clickableOrdinalRange = interval.clickableOrdinalRange;\n s.stayingIntervals = (d.multiselect && b.filterSpecified) ? b.filter.getConsolidated() : [];\n if(unitRange) {\n s.stayingIntervals = s.stayingIntervals.filter(function(int2) {\n return int2[0] !== unitRange[0] && int2[1] !== unitRange[1];\n });\n }\n s.startExtent = interval.region ? unitRange[interval.region === 's' ? 1 : 0] : unitLocation;\n d.parent.inBrushDrag = true;\n s.brushStartCallback();\n}\n\nfunction drag(lThis, d) {\n d3.event.sourceEvent.stopPropagation();\n var y = d.height - d3.mouse(lThis)[1] - 2 * c.verticalPadding;\n var s = d.brush.svgBrush;\n s.wasDragged = true;\n s._dragging = true;\n\n if(s.grabbingBar) { // moving the bar\n s.newExtent = [y - s.grabPoint, y + s.barLength - s.grabPoint].map(d.unitToPaddedPx.invert);\n } else { // south/north drag or new bar creation\n s.newExtent = [s.startExtent, d.unitToPaddedPx.invert(y)].sort(sortAsc);\n }\n\n d.brush.filterSpecified = true;\n s.extent = s.stayingIntervals.concat([s.newExtent]);\n s.brushCallback(d);\n renderHighlight(lThis.parentNode);\n}\n\nfunction dragend(lThis, d) {\n var brush = d.brush;\n var filter = brush.filter;\n var s = brush.svgBrush;\n\n if(!s._dragging) { // i.e. click\n // mock zero drag\n mousemove(lThis, d);\n drag(lThis, d);\n // remember it is a click not a drag\n d.brush.svgBrush.wasDragged = false;\n }\n s._dragging = false;\n\n var e = d3.event;\n e.sourceEvent.stopPropagation();\n var grabbingBar = s.grabbingBar;\n s.grabbingBar = false;\n s.grabLocation = undefined;\n d.parent.inBrushDrag = false;\n clearCursor(); // instead of clearing, a nicer thing would be to set it according to current location\n if(!s.wasDragged) { // a click+release on the same spot (ie. w/o dragging) means a bar or full reset\n s.wasDragged = undefined; // logic-wise unneeded, just shows `wasDragged` has no longer a meaning\n if(s.clickableOrdinalRange) {\n if(brush.filterSpecified && d.multiselect) {\n s.extent.push(s.clickableOrdinalRange);\n } else {\n s.extent = [s.clickableOrdinalRange];\n brush.filterSpecified = true;\n }\n } else if(grabbingBar) {\n s.extent = s.stayingIntervals;\n if(s.extent.length === 0) {\n brushClear(brush);\n }\n } else {\n brushClear(brush);\n }\n s.brushCallback(d);\n renderHighlight(lThis.parentNode);\n s.brushEndCallback(brush.filterSpecified ? filter.getConsolidated() : []);\n return; // no need to fuse intervals or snap to ordinals, so we can bail early\n }\n\n var mergeIntervals = function() {\n // Key piece of logic: once the button is released, possibly overlapping intervals will be fused:\n // Here it's done immediately on click release while on ordinal snap transition it's done at the end\n filter.set(filter.getConsolidated());\n };\n\n if(d.ordinal) {\n var a = d.unitTickvals;\n if(a[a.length - 1] < a[0]) a.reverse();\n s.newExtent = [\n ordinalScaleSnap(0, a, s.newExtent[0], s.stayingIntervals),\n ordinalScaleSnap(1, a, s.newExtent[1], s.stayingIntervals)\n ];\n var hasNewExtent = s.newExtent[1] > s.newExtent[0];\n s.extent = s.stayingIntervals.concat(hasNewExtent ? [s.newExtent] : []);\n if(!s.extent.length) {\n brushClear(brush);\n }\n s.brushCallback(d);\n if(hasNewExtent) {\n // merging intervals post the snap tween\n renderHighlight(lThis.parentNode, mergeIntervals);\n } else {\n // if no new interval, don't animate, just redraw the highlight immediately\n mergeIntervals();\n renderHighlight(lThis.parentNode);\n }\n } else {\n mergeIntervals(); // merging intervals immediately\n }\n s.brushEndCallback(brush.filterSpecified ? filter.getConsolidated() : []);\n}\n\nfunction mousemove(lThis, d) {\n var y = d.height - d3.mouse(lThis)[1] - 2 * c.verticalPadding;\n var interval = getInterval(d, y);\n\n var cursor = 'crosshair';\n if(interval.clickableOrdinalRange) cursor = 'pointer';\n else if(interval.region) cursor = interval.region + '-resize';\n d3.select(document.body)\n .style('cursor', cursor);\n}\n\nfunction attachDragBehavior(selection) {\n // There's some fiddling with pointer cursor styling so that the cursor preserves its shape while dragging a brush\n // even if the cursor strays from the interacting bar, which is bound to happen as bars are thin and the user\n // will inevitably leave the hotspot strip. In this regard, it does something similar to what the D3 brush would do.\n selection\n .on('mousemove', function(d) {\n d3.event.preventDefault();\n if(!d.parent.inBrushDrag) mousemove(this, d);\n })\n .on('mouseleave', function(d) {\n if(!d.parent.inBrushDrag) clearCursor();\n })\n .call(d3.behavior.drag()\n .on('dragstart', function(d) { dragstart(this, d); })\n .on('drag', function(d) { drag(this, d); })\n .on('dragend', function(d) { dragend(this, d); })\n );\n}\n\nfunction startAsc(a, b) { return a[0] - b[0]; }\n\nfunction renderAxisBrush(axisBrush, paperColor, gd) {\n var isStatic = gd._context.staticPlot;\n\n var background = axisBrush.selectAll('.background').data(repeat);\n\n background.enter()\n .append('rect')\n .classed('background', true)\n .call(barHorizontalSetup)\n .call(backgroundBarHorizontalSetup)\n .style('pointer-events', isStatic ? 'none' : 'auto') // parent pointer events are disabled; we must have it to register events\n .attr('transform', strTranslate(0, c.verticalPadding));\n\n background\n .call(attachDragBehavior)\n .attr('height', function(d) {\n return d.height - c.verticalPadding;\n });\n\n var highlightShadow = axisBrush.selectAll('.highlight-shadow').data(repeat); // we have a set here, can't call it `extent`\n\n highlightShadow.enter()\n .append('line')\n .classed('highlight-shadow', true)\n .attr('x', -c.bar.width / 2)\n .attr('stroke-width', c.bar.width + c.bar.strokeWidth)\n .attr('stroke', paperColor)\n .attr('opacity', c.bar.strokeOpacity)\n .attr('stroke-linecap', 'butt');\n\n highlightShadow\n .attr('y1', function(d) { return d.height; })\n .call(styleHighlight);\n\n var highlight = axisBrush.selectAll('.highlight').data(repeat); // we have a set here, can't call it `extent`\n\n highlight.enter()\n .append('line')\n .classed('highlight', true)\n .attr('x', -c.bar.width / 2)\n .attr('stroke-width', c.bar.width - c.bar.strokeWidth)\n .attr('stroke', c.bar.fillColor)\n .attr('opacity', c.bar.fillOpacity)\n .attr('stroke-linecap', 'butt');\n\n highlight\n .attr('y1', function(d) { return d.height; })\n .call(styleHighlight);\n}\n\nfunction ensureAxisBrush(axisOverlays, paperColor, gd) {\n var axisBrush = axisOverlays.selectAll('.' + c.cn.axisBrush)\n .data(repeat, keyFun);\n\n axisBrush.enter()\n .append('g')\n .classed(c.cn.axisBrush, true);\n\n renderAxisBrush(axisBrush, paperColor, gd);\n}\n\nfunction getBrushExtent(brush) {\n return brush.svgBrush.extent.map(function(e) {return e.slice();});\n}\n\nfunction brushClear(brush) {\n brush.filterSpecified = false;\n brush.svgBrush.extent = [[-Infinity, Infinity]];\n}\n\nfunction axisBrushMoved(callback) {\n return function axisBrushMoved(dimension) {\n var brush = dimension.brush;\n var extent = getBrushExtent(brush);\n var newExtent = extent.slice();\n brush.filter.set(newExtent);\n callback();\n };\n}\n\nfunction dedupeRealRanges(intervals) {\n // Fuses elements of intervals if they overlap, yielding discontiguous intervals, results.length <= intervals.length\n // Currently uses closed intervals, ie. dedupeRealRanges([[400, 800], [300, 400]]) -> [300, 800]\n var queue = intervals.slice();\n var result = [];\n var currentInterval;\n var current = queue.shift();\n while(current) { // [].shift === undefined, so we don't descend into an empty array\n currentInterval = current.slice();\n while((current = queue.shift()) && current[0] <= /* right-open interval would need `<` */ currentInterval[1]) {\n currentInterval[1] = Math.max(currentInterval[1], current[1]);\n }\n result.push(currentInterval);\n }\n\n if(\n result.length === 1 &&\n result[0][0] > result[0][1]\n ) {\n // discard result\n result = [];\n }\n\n return result;\n}\n\nfunction makeFilter() {\n var filter = [];\n var consolidated;\n var bounds;\n return {\n set: function(a) {\n filter = a\n .map(function(d) { return d.slice().sort(sortAsc); })\n .sort(startAsc);\n\n // handle unselected case\n if(filter.length === 1 &&\n filter[0][0] === -Infinity &&\n filter[0][1] === Infinity) {\n filter = [[0, -1]];\n }\n\n consolidated = dedupeRealRanges(filter);\n bounds = filter.reduce(function(p, n) {\n return [Math.min(p[0], n[0]), Math.max(p[1], n[1])];\n }, [Infinity, -Infinity]);\n },\n get: function() { return filter.slice(); },\n getConsolidated: function() { return consolidated; },\n getBounds: function() { return bounds; }\n };\n}\n\nfunction makeBrush(state, rangeSpecified, initialRange, brushStartCallback, brushCallback, brushEndCallback) {\n var filter = makeFilter();\n filter.set(initialRange);\n return {\n filter: filter,\n filterSpecified: rangeSpecified, // there's a difference between not filtering and filtering a non-proper subset\n svgBrush: {\n extent: [], // this is where the svgBrush writes contents into\n brushStartCallback: brushStartCallback,\n brushCallback: axisBrushMoved(brushCallback),\n brushEndCallback: brushEndCallback\n }\n };\n}\n\n// for use by supplyDefaults, but it needed tons of pieces from here so\n// seemed to make more sense just to put the whole routine here\nfunction cleanRanges(ranges, dimension) {\n if(Array.isArray(ranges[0])) {\n ranges = ranges.map(function(ri) { return ri.sort(sortAsc); });\n\n if(!dimension.multiselect) ranges = [ranges[0]];\n else ranges = dedupeRealRanges(ranges.sort(startAsc));\n } else ranges = [ranges.sort(sortAsc)];\n\n // ordinal snapping\n if(dimension.tickvals) {\n var sortedTickVals = dimension.tickvals.slice().sort(sortAsc);\n ranges = ranges.map(function(ri) {\n var rSnapped = [\n ordinalScaleSnap(0, sortedTickVals, ri[0], []),\n ordinalScaleSnap(1, sortedTickVals, ri[1], [])\n ];\n if(rSnapped[1] > rSnapped[0]) return rSnapped;\n })\n .filter(function(ri) { return ri; });\n\n if(!ranges.length) return;\n }\n return ranges.length > 1 ? ranges : ranges[0];\n}\n\nmodule.exports = {\n makeBrush: makeBrush,\n ensureAxisBrush: ensureAxisBrush,\n cleanRanges: cleanRanges\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n calc: require('./calc'),\n colorbar: {\n container: 'line',\n min: 'cmin',\n max: 'cmax'\n },\n\n moduleType: 'trace',\n name: 'parcoords',\n basePlotModule: require('./base_plot'),\n categories: ['gl', 'regl', 'noOpacity', 'noHover'],\n meta: {\n description: [\n 'Parallel coordinates for multidimensional exploratory data analysis.',\n 'The samples are specified in `dimensions`.',\n 'The colors are set in `line.color`.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar getModuleCalcData = require('../../plots/get_data').getModuleCalcData;\nvar parcoordsPlot = require('./plot');\nvar xmlnsNamespaces = require('../../constants/xmlns_namespaces');\n\nexports.name = 'parcoords';\n\nexports.plot = function(gd) {\n var calcData = getModuleCalcData(gd.calcdata, 'parcoords')[0];\n if(calcData.length) parcoordsPlot(gd, calcData);\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var hadParcoords = (oldFullLayout._has && oldFullLayout._has('parcoords'));\n var hasParcoords = (newFullLayout._has && newFullLayout._has('parcoords'));\n\n if(hadParcoords && !hasParcoords) {\n oldFullLayout._paperdiv.selectAll('.parcoords').remove();\n oldFullLayout._glimages.selectAll('*').remove();\n }\n};\n\nexports.toSVG = function(gd) {\n var imageRoot = gd._fullLayout._glimages;\n var root = d3.select(gd).selectAll('.svg-container');\n var canvases = root.filter(function(d, i) {return i === root.size() - 1;})\n .selectAll('.gl-canvas-context, .gl-canvas-focus');\n\n function canvasToImage() {\n var canvas = this;\n var imageData = canvas.toDataURL('image/png');\n var image = imageRoot.append('svg:image');\n\n image.attr({\n xmlns: xmlnsNamespaces.svg,\n 'xlink:href': imageData,\n preserveAspectRatio: 'none',\n x: 0,\n y: 0,\n width: canvas.style.width,\n height: canvas.style.height\n });\n }\n\n canvases.each(canvasToImage);\n\n // Chrome / Safari bug workaround - browser apparently loses connection to the defined pattern\n // Without the workaround, these browsers 'lose' the filter brush styling (color etc.) after a snapshot\n // on a subsequent interaction.\n // Firefox works fine without this workaround\n window.setTimeout(function() {\n d3.selectAll('#filterBarPattern')\n .attr('id', 'filterBarPattern');\n }, 60);\n};\n","'use strict';\n\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar Colorscale = require('../../components/colorscale');\nvar wrap = require('../../lib/gup').wrap;\n\nmodule.exports = function calc(gd, trace) {\n var lineColor;\n var cscale;\n\n if(Colorscale.hasColorscale(trace, 'line') && isArrayOrTypedArray(trace.line.color)) {\n lineColor = trace.line.color;\n cscale = Colorscale.extractOpts(trace.line).colorscale;\n\n Colorscale.calc(gd, trace, {\n vals: lineColor,\n containerStr: 'line',\n cLetter: 'c'\n });\n } else {\n lineColor = constHalf(trace._length);\n cscale = [[0, trace.line.color], [1, trace.line.color]];\n }\n\n return wrap({lineColor: lineColor, cscale: cscale});\n};\n\nfunction constHalf(len) {\n var out = new Array(len);\n for(var i = 0; i < len; i++) {\n out[i] = 0.5;\n }\n return out;\n}\n","'use strict';\n\n\nmodule.exports = {\n maxDimensionCount: 60, // this cannot be increased without WebGL code refactoring\n overdrag: 45,\n verticalPadding: 2, // otherwise, horizontal lines on top or bottom are of lower width\n tickDistance: 50,\n canvasPixelRatio: 1,\n blockLineCount: 5000,\n layers: ['contextLineLayer', 'focusLineLayer', 'pickLineLayer'],\n axisTitleOffset: 28,\n axisExtentOffset: 10,\n bar: {\n width: 4, // Visible width of the filter bar\n captureWidth: 10, // Mouse-sensitive width for interaction (Fitts law)\n fillColor: 'magenta', // Color of the filter bar fill\n fillOpacity: 1, // Filter bar fill opacity\n snapDuration: 150, // tween duration in ms for brush snap for ordinal axes\n snapRatio: 0.25, // ratio of bar extension relative to the distance between two adjacent ordinal values\n snapClose: 0.01, // fraction of inter-value distance to snap to the closer one, even if you're not over it\n strokeOpacity: 1, // Filter bar side stroke opacity\n strokeWidth: 1, // Filter bar side stroke width in pixels\n handleHeight: 8, // Height of the filter bar vertical resize areas on top and bottom\n handleOpacity: 1, // Opacity of the filter bar vertical resize areas on top and bottom\n handleOverlap: 0 // A larger than 0 value causes overlaps with the filter bar, represented as pixels\n },\n cn: {\n axisExtentText: 'axis-extent-text',\n parcoordsLineLayers: 'parcoords-line-layers',\n parcoordsLineLayer: 'parcoords-lines',\n parcoords: 'parcoords',\n parcoordsControlView: 'parcoords-control-view',\n yAxis: 'y-axis',\n axisOverlays: 'axis-overlays',\n axis: 'axis',\n axisHeading: 'axis-heading',\n axisTitle: 'axis-title',\n axisExtent: 'axis-extent',\n axisExtentTop: 'axis-extent-top',\n axisExtentTopText: 'axis-extent-top-text',\n axisExtentBottom: 'axis-extent-bottom',\n axisExtentBottomText: 'axis-extent-bottom-text',\n axisBrush: 'axis-brush'\n },\n id: {\n filterBarPattern: 'filter-bar-pattern'\n\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar hasColorscale = require('../../components/colorscale/helpers').hasColorscale;\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar handleDomainDefaults = require('../../plots/domain').defaults;\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\nvar Axes = require('../../plots/cartesian/axes');\n\nvar attributes = require('./attributes');\nvar axisBrush = require('./axisbrush');\nvar maxDimensionCount = require('./constants').maxDimensionCount;\nvar mergeLength = require('./merge_length');\n\nfunction handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce) {\n var lineColor = coerce('line.color', defaultColor);\n\n if(hasColorscale(traceIn, 'line') && Lib.isArrayOrTypedArray(lineColor)) {\n if(lineColor.length) {\n coerce('line.colorscale');\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: 'line.', cLetter: 'c'});\n // TODO: I think it would be better to keep showing lines beyond the last line color\n // but I'm not sure what color to give these lines - probably black or white\n // depending on the background color?\n return lineColor.length;\n } else {\n traceOut.line.color = defaultColor;\n }\n }\n return Infinity;\n}\n\nfunction dimensionDefaults(dimensionIn, dimensionOut, parentOut, opts) {\n function coerce(attr, dflt) {\n return Lib.coerce(dimensionIn, dimensionOut, attributes.dimensions, attr, dflt);\n }\n\n var values = coerce('values');\n var visible = coerce('visible');\n if(!(values && values.length)) {\n visible = dimensionOut.visible = false;\n }\n\n if(visible) {\n coerce('label');\n coerce('tickvals');\n coerce('ticktext');\n coerce('tickformat');\n var range = coerce('range');\n\n dimensionOut._ax = {\n _id: 'y',\n type: 'linear',\n showexponent: 'all',\n exponentformat: 'B',\n range: range\n };\n\n Axes.setConvert(dimensionOut._ax, opts.layout);\n\n coerce('multiselect');\n var constraintRange = coerce('constraintrange');\n if(constraintRange) {\n dimensionOut.constraintrange = axisBrush.cleanRanges(constraintRange, dimensionOut);\n }\n }\n}\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var dimensionsIn = traceIn.dimensions;\n if(Array.isArray(dimensionsIn) && dimensionsIn.length > maxDimensionCount) {\n Lib.log('parcoords traces support up to ' + maxDimensionCount + ' dimensions at the moment');\n dimensionsIn.splice(maxDimensionCount);\n }\n\n var dimensions = handleArrayContainerDefaults(traceIn, traceOut, {\n name: 'dimensions',\n layout: layout,\n handleItemDefaults: dimensionDefaults\n });\n\n var len = handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce);\n\n handleDomainDefaults(traceOut, layout, coerce);\n\n if(!Array.isArray(dimensions) || !dimensions.length) {\n traceOut.visible = false;\n }\n\n mergeLength(traceOut, dimensions, 'values', len);\n\n // make default font size 10px (default is 12),\n // scale linearly with global font size\n var fontDflt = Lib.extendFlat({}, layout.font, {\n size: Math.round(layout.font.size / 1.2)\n });\n\n Lib.coerceFont(coerce, 'labelfont', fontDflt);\n Lib.coerceFont(coerce, 'tickfont', fontDflt, { autoShadowDflt: true });\n Lib.coerceFont(coerce, 'rangefont', fontDflt);\n\n coerce('labelangle');\n coerce('labelside');\n\n coerce('unselected.line.color');\n coerce('unselected.line.opacity');\n};\n","'use strict';\n\nvar isTypedArray = require('../../lib').isTypedArray;\n\nexports.convertTypedArray = function(a) {\n return isTypedArray(a) ? Array.prototype.slice.call(a) : a;\n};\n\nexports.isOrdinal = function(dimension) {\n return !!dimension.tickvals;\n};\n\nexports.isVisible = function(dimension) {\n return dimension.visible || !('visible' in dimension);\n};\n","'use strict';\n\nvar index = require('./base_index');\n\nindex.plot = require('./plot');\n\nmodule.exports = index;\n","'use strict';\n\nvar vertexShaderSource = [\n 'precision highp float;',\n '',\n 'varying vec4 fragColor;',\n '',\n 'attribute vec4 p01_04, p05_08, p09_12, p13_16,',\n ' p17_20, p21_24, p25_28, p29_32,',\n ' p33_36, p37_40, p41_44, p45_48,',\n ' p49_52, p53_56, p57_60, colors;',\n '',\n 'uniform mat4 dim0A, dim1A, dim0B, dim1B, dim0C, dim1C, dim0D, dim1D,',\n ' loA, hiA, loB, hiB, loC, hiC, loD, hiD;',\n '',\n 'uniform vec2 resolution, viewBoxPos, viewBoxSize;',\n 'uniform float maskHeight;',\n 'uniform float drwLayer; // 0: context, 1: focus, 2: pick',\n 'uniform vec4 contextColor;',\n 'uniform sampler2D maskTexture, palette;',\n '',\n 'bool isPick = (drwLayer > 1.5);',\n 'bool isContext = (drwLayer < 0.5);',\n '',\n 'const vec4 ZEROS = vec4(0.0, 0.0, 0.0, 0.0);',\n 'const vec4 UNITS = vec4(1.0, 1.0, 1.0, 1.0);',\n '',\n 'float val(mat4 p, mat4 v) {',\n ' return dot(matrixCompMult(p, v) * UNITS, UNITS);',\n '}',\n '',\n 'float axisY(float ratio, mat4 A, mat4 B, mat4 C, mat4 D) {',\n ' float y1 = val(A, dim0A) + val(B, dim0B) + val(C, dim0C) + val(D, dim0D);',\n ' float y2 = val(A, dim1A) + val(B, dim1B) + val(C, dim1C) + val(D, dim1D);',\n ' return y1 * (1.0 - ratio) + y2 * ratio;',\n '}',\n '',\n 'int iMod(int a, int b) {',\n ' return a - b * (a / b);',\n '}',\n '',\n 'bool fOutside(float p, float lo, float hi) {',\n ' return (lo < hi) && (lo > p || p > hi);',\n '}',\n '',\n 'bool vOutside(vec4 p, vec4 lo, vec4 hi) {',\n ' return (',\n ' fOutside(p[0], lo[0], hi[0]) ||',\n ' fOutside(p[1], lo[1], hi[1]) ||',\n ' fOutside(p[2], lo[2], hi[2]) ||',\n ' fOutside(p[3], lo[3], hi[3])',\n ' );',\n '}',\n '',\n 'bool mOutside(mat4 p, mat4 lo, mat4 hi) {',\n ' return (',\n ' vOutside(p[0], lo[0], hi[0]) ||',\n ' vOutside(p[1], lo[1], hi[1]) ||',\n ' vOutside(p[2], lo[2], hi[2]) ||',\n ' vOutside(p[3], lo[3], hi[3])',\n ' );',\n '}',\n '',\n 'bool outsideBoundingBox(mat4 A, mat4 B, mat4 C, mat4 D) {',\n ' return mOutside(A, loA, hiA) ||',\n ' mOutside(B, loB, hiB) ||',\n ' mOutside(C, loC, hiC) ||',\n ' mOutside(D, loD, hiD);',\n '}',\n '',\n 'bool outsideRasterMask(mat4 A, mat4 B, mat4 C, mat4 D) {',\n ' mat4 pnts[4];',\n ' pnts[0] = A;',\n ' pnts[1] = B;',\n ' pnts[2] = C;',\n ' pnts[3] = D;',\n '',\n ' for(int i = 0; i < 4; ++i) {',\n ' for(int j = 0; j < 4; ++j) {',\n ' for(int k = 0; k < 4; ++k) {',\n ' if(0 == iMod(',\n ' int(255.0 * texture2D(maskTexture,',\n ' vec2(',\n ' (float(i * 2 + j / 2) + 0.5) / 8.0,',\n ' (pnts[i][j][k] * (maskHeight - 1.0) + 1.0) / maskHeight',\n ' ))[3]',\n ' ) / int(pow(2.0, float(iMod(j * 4 + k, 8)))),',\n ' 2',\n ' )) return true;',\n ' }',\n ' }',\n ' }',\n ' return false;',\n '}',\n '',\n 'vec4 position(bool isContext, float v, mat4 A, mat4 B, mat4 C, mat4 D) {',\n ' float x = 0.5 * sign(v) + 0.5;',\n ' float y = axisY(x, A, B, C, D);',\n ' float z = 1.0 - abs(v);',\n '',\n ' z += isContext ? 0.0 : 2.0 * float(',\n ' outsideBoundingBox(A, B, C, D) ||',\n ' outsideRasterMask(A, B, C, D)',\n ' );',\n '',\n ' return vec4(',\n ' 2.0 * (vec2(x, y) * viewBoxSize + viewBoxPos) / resolution - 1.0,',\n ' z,',\n ' 1.0',\n ' );',\n '}',\n '',\n 'void main() {',\n ' mat4 A = mat4(p01_04, p05_08, p09_12, p13_16);',\n ' mat4 B = mat4(p17_20, p21_24, p25_28, p29_32);',\n ' mat4 C = mat4(p33_36, p37_40, p41_44, p45_48);',\n ' mat4 D = mat4(p49_52, p53_56, p57_60, ZEROS);',\n '',\n ' float v = colors[3];',\n '',\n ' gl_Position = position(isContext, v, A, B, C, D);',\n '',\n ' fragColor =',\n ' isContext ? vec4(contextColor) :',\n ' isPick ? vec4(colors.rgb, 1.0) : texture2D(palette, vec2(abs(v), 0.5));',\n '}'\n].join('\\n');\n\nvar fragmentShaderSource = [\n 'precision highp float;',\n '',\n 'varying vec4 fragColor;',\n '',\n 'void main() {',\n ' gl_FragColor = fragColor;',\n '}'\n].join('\\n');\n\nvar maxDim = require('./constants').maxDimensionCount;\n\nvar Lib = require('../../lib');\n\n// don't change; otherwise near/far plane lines are lost\nvar depthLimitEpsilon = 1e-6;\n\n// precision of multiselect is the full range divided into this many parts\nvar maskHeight = 2048;\n\nvar dummyPixel = new Uint8Array(4);\nvar dataPixel = new Uint8Array(4);\n\nvar paletteTextureConfig = {\n shape: [256, 1],\n format: 'rgba',\n type: 'uint8',\n mag: 'nearest',\n min: 'nearest'\n};\n\nfunction ensureDraw(regl) {\n regl.read({\n x: 0,\n y: 0,\n width: 1,\n height: 1,\n data: dummyPixel\n });\n}\n\nfunction clear(regl, x, y, width, height) {\n var gl = regl._gl;\n gl.enable(gl.SCISSOR_TEST);\n gl.scissor(x, y, width, height);\n regl.clear({color: [0, 0, 0, 0], depth: 1}); // clearing is done in scissored panel only\n}\n\nfunction renderBlock(regl, glAes, renderState, blockLineCount, sampleCount, item) {\n var rafKey = item.key;\n\n function render(blockNumber) {\n var count = Math.min(blockLineCount, sampleCount - blockNumber * blockLineCount);\n\n if(blockNumber === 0) {\n // stop drawing possibly stale glyphs before clearing\n window.cancelAnimationFrame(renderState.currentRafs[rafKey]);\n delete renderState.currentRafs[rafKey];\n clear(regl, item.scissorX, item.scissorY, item.scissorWidth, item.viewBoxSize[1]);\n }\n\n if(renderState.clearOnly) {\n return;\n }\n\n item.count = 2 * count;\n item.offset = 2 * blockNumber * blockLineCount;\n glAes(item);\n\n if(blockNumber * blockLineCount + count < sampleCount) {\n renderState.currentRafs[rafKey] = window.requestAnimationFrame(function() {\n render(blockNumber + 1);\n });\n }\n\n renderState.drawCompleted = false;\n }\n\n if(!renderState.drawCompleted) {\n ensureDraw(regl);\n renderState.drawCompleted = true;\n }\n\n // start with rendering item 0; recursion handles the rest\n render(0);\n}\n\nfunction adjustDepth(d) {\n // WebGL matrix operations use floats with limited precision, potentially causing a number near a border of [0, 1]\n // to end up slightly outside the border. With an epsilon, we reduce the chance that a line gets clipped by the\n // near or the far plane.\n return Math.max(depthLimitEpsilon, Math.min(1 - depthLimitEpsilon, d));\n}\n\nfunction palette(unitToColor, opacity) {\n var result = new Array(256);\n for(var i = 0; i < 256; i++) {\n result[i] = unitToColor(i / 255).concat(opacity);\n }\n return result;\n}\n\n// Maps the sample index [0...sampleCount - 1] to a range of [0, 1] as the shader expects colors in the [0, 1] range.\n// but first it shifts the sample index by 0, 8 or 16 bits depending on rgbIndex [0..2]\n// with the end result that each line will be of a unique color, making it possible for the pick handler\n// to uniquely identify which line is hovered over (bijective mapping).\n// The inverse, i.e. readPixel is invoked from 'parcoords.js'\nfunction calcPickColor(i, rgbIndex) {\n return (i >>> 8 * rgbIndex) % 256 / 255;\n}\n\nfunction makePoints(sampleCount, dims, color) {\n var points = new Array(sampleCount * (maxDim + 4));\n var n = 0;\n for(var i = 0; i < sampleCount; i++) {\n for(var k = 0; k < maxDim; k++) {\n points[n++] = (k < dims.length) ? dims[k].paddedUnitValues[i] : 0.5;\n }\n points[n++] = calcPickColor(i, 2);\n points[n++] = calcPickColor(i, 1);\n points[n++] = calcPickColor(i, 0);\n points[n++] = adjustDepth(color[i]);\n }\n return points;\n}\n\nfunction makeVecAttr(vecIndex, sampleCount, points) {\n var pointPairs = new Array(sampleCount * 8);\n var n = 0;\n for(var i = 0; i < sampleCount; i++) {\n for(var j = 0; j < 2; j++) {\n for(var k = 0; k < 4; k++) {\n var q = vecIndex * 4 + k;\n var v = points[i * 64 + q];\n if(q === 63 && j === 0) {\n v *= -1;\n }\n pointPairs[n++] = v;\n }\n }\n }\n return pointPairs;\n}\n\nfunction pad2(num) {\n var s = '0' + num;\n return s.substr(s.length - 2);\n}\n\nfunction getAttrName(i) {\n return (i < maxDim) ? 'p' + pad2(i + 1) + '_' + pad2(i + 4) : 'colors';\n}\n\nfunction setAttributes(attributes, sampleCount, points) {\n for(var i = 0; i <= maxDim; i += 4) {\n attributes[getAttrName(i)](makeVecAttr(i / 4, sampleCount, points));\n }\n}\n\nfunction emptyAttributes(regl) {\n var attributes = {};\n for(var i = 0; i <= maxDim; i += 4) {\n attributes[getAttrName(i)] = regl.buffer({usage: 'dynamic', type: 'float', data: new Uint8Array(0)});\n }\n return attributes;\n}\n\nfunction makeItem(\n model, leftmost, rightmost, itemNumber, i0, i1, x, y, panelSizeX, panelSizeY,\n crossfilterDimensionIndex, drwLayer, constraints, plotGlPixelRatio\n) {\n var dims = [[], []];\n for(var k = 0; k < 64; k++) {\n dims[0][k] = (k === i0) ? 1 : 0;\n dims[1][k] = (k === i1) ? 1 : 0;\n }\n x *= plotGlPixelRatio;\n y *= plotGlPixelRatio;\n panelSizeX *= plotGlPixelRatio;\n panelSizeY *= plotGlPixelRatio;\n var overdrag = model.lines.canvasOverdrag * plotGlPixelRatio;\n var domain = model.domain;\n var canvasWidth = model.canvasWidth * plotGlPixelRatio;\n var canvasHeight = model.canvasHeight * plotGlPixelRatio;\n var padL = model.pad.l * plotGlPixelRatio;\n var padB = model.pad.b * plotGlPixelRatio;\n var layoutHeight = model.layoutHeight * plotGlPixelRatio;\n var layoutWidth = model.layoutWidth * plotGlPixelRatio;\n\n var deselectedLinesColor = model.deselectedLines.color;\n var deselectedLinesOpacity = model.deselectedLines.opacity;\n\n var itemModel = Lib.extendFlat({\n key: crossfilterDimensionIndex,\n resolution: [canvasWidth, canvasHeight],\n viewBoxPos: [x + overdrag, y],\n viewBoxSize: [panelSizeX, panelSizeY],\n i0: i0,\n i1: i1,\n\n dim0A: dims[0].slice(0, 16),\n dim0B: dims[0].slice(16, 32),\n dim0C: dims[0].slice(32, 48),\n dim0D: dims[0].slice(48, 64),\n dim1A: dims[1].slice(0, 16),\n dim1B: dims[1].slice(16, 32),\n dim1C: dims[1].slice(32, 48),\n dim1D: dims[1].slice(48, 64),\n\n drwLayer: drwLayer,\n contextColor: [\n deselectedLinesColor[0] / 255,\n deselectedLinesColor[1] / 255,\n deselectedLinesColor[2] / 255,\n deselectedLinesOpacity !== 'auto' ?\n deselectedLinesColor[3] * deselectedLinesOpacity :\n Math.max(1 / 255, Math.pow(1 / model.lines.color.length, 1 / 3))\n ],\n\n scissorX: (itemNumber === leftmost ? 0 : x + overdrag) + (padL - overdrag) + layoutWidth * domain.x[0],\n scissorWidth: (itemNumber === rightmost ? canvasWidth - x + overdrag : panelSizeX + 0.5) + (itemNumber === leftmost ? x + overdrag : 0),\n scissorY: y + padB + layoutHeight * domain.y[0],\n scissorHeight: panelSizeY,\n\n viewportX: padL - overdrag + layoutWidth * domain.x[0],\n viewportY: padB + layoutHeight * domain.y[0],\n viewportWidth: canvasWidth,\n viewportHeight: canvasHeight\n }, constraints);\n\n return itemModel;\n}\n\nfunction expandedPixelRange(bounds) {\n var dh = maskHeight - 1;\n var a = Math.max(0, Math.floor(bounds[0] * dh), 0);\n var b = Math.min(dh, Math.ceil(bounds[1] * dh), dh);\n return [\n Math.min(a, b),\n Math.max(a, b)\n ];\n}\n\nmodule.exports = function(canvasGL, d) {\n // context & pick describe which canvas we're talking about - won't change with new data\n var isContext = d.context;\n var isPick = d.pick;\n\n var regl = d.regl;\n var gl = regl._gl;\n var supportedLineWidth = gl.getParameter(gl.ALIASED_LINE_WIDTH_RANGE);\n // ensure here that plotGlPixelRatio is within supported range; otherwise regl throws error\n var plotGlPixelRatio = Math.max(\n supportedLineWidth[0],\n Math.min(\n supportedLineWidth[1],\n d.viewModel.plotGlPixelRatio\n )\n );\n\n var renderState = {\n currentRafs: {},\n drawCompleted: true,\n clearOnly: false\n };\n\n // state to be set by update and used later\n var model;\n var vm;\n var initialDims;\n var sampleCount;\n var attributes = emptyAttributes(regl);\n var maskTexture;\n var paletteTexture = regl.texture(paletteTextureConfig);\n\n var prevAxisOrder = [];\n\n update(d);\n\n var glAes = regl({\n\n profile: false,\n\n blend: {\n enable: isContext,\n func: {\n srcRGB: 'src alpha',\n dstRGB: 'one minus src alpha',\n srcAlpha: 1,\n dstAlpha: 1 // 'one minus src alpha'\n },\n equation: {\n rgb: 'add',\n alpha: 'add'\n },\n color: [0, 0, 0, 0]\n },\n\n depth: {\n enable: !isContext,\n mask: true,\n func: 'less',\n range: [0, 1]\n },\n\n // for polygons\n cull: {\n enable: true,\n face: 'back'\n },\n\n scissor: {\n enable: true,\n box: {\n x: regl.prop('scissorX'),\n y: regl.prop('scissorY'),\n width: regl.prop('scissorWidth'),\n height: regl.prop('scissorHeight')\n }\n },\n\n viewport: {\n x: regl.prop('viewportX'),\n y: regl.prop('viewportY'),\n width: regl.prop('viewportWidth'),\n height: regl.prop('viewportHeight')\n },\n\n dither: false,\n\n vert: vertexShaderSource,\n\n frag: fragmentShaderSource,\n\n primitive: 'lines',\n lineWidth: plotGlPixelRatio,\n attributes: attributes,\n uniforms: {\n resolution: regl.prop('resolution'),\n viewBoxPos: regl.prop('viewBoxPos'),\n viewBoxSize: regl.prop('viewBoxSize'),\n dim0A: regl.prop('dim0A'),\n dim1A: regl.prop('dim1A'),\n dim0B: regl.prop('dim0B'),\n dim1B: regl.prop('dim1B'),\n dim0C: regl.prop('dim0C'),\n dim1C: regl.prop('dim1C'),\n dim0D: regl.prop('dim0D'),\n dim1D: regl.prop('dim1D'),\n loA: regl.prop('loA'),\n hiA: regl.prop('hiA'),\n loB: regl.prop('loB'),\n hiB: regl.prop('hiB'),\n loC: regl.prop('loC'),\n hiC: regl.prop('hiC'),\n loD: regl.prop('loD'),\n hiD: regl.prop('hiD'),\n palette: paletteTexture,\n contextColor: regl.prop('contextColor'),\n maskTexture: regl.prop('maskTexture'),\n drwLayer: regl.prop('drwLayer'),\n maskHeight: regl.prop('maskHeight')\n },\n offset: regl.prop('offset'),\n count: regl.prop('count')\n });\n\n function update(dNew) {\n model = dNew.model;\n vm = dNew.viewModel;\n initialDims = vm.dimensions.slice();\n sampleCount = initialDims[0] ? initialDims[0].values.length : 0;\n\n var lines = model.lines;\n var color = isPick ? lines.color.map(function(_, i) {return i / lines.color.length;}) : lines.color;\n\n var points = makePoints(sampleCount, initialDims, color);\n setAttributes(attributes, sampleCount, points);\n\n if(!isContext && !isPick) {\n paletteTexture = regl.texture(Lib.extendFlat({\n data: palette(model.unitToColor, 255)\n }, paletteTextureConfig));\n }\n }\n\n function makeConstraints(isContext) {\n var i, j, k;\n\n var limits = [[], []];\n for(k = 0; k < 64; k++) {\n var p = (!isContext && k < initialDims.length) ?\n initialDims[k].brush.filter.getBounds() : [-Infinity, Infinity];\n\n limits[0][k] = p[0];\n limits[1][k] = p[1];\n }\n\n var len = maskHeight * 8;\n var mask = new Array(len);\n for(i = 0; i < len; i++) {\n mask[i] = 255;\n }\n if(!isContext) {\n for(i = 0; i < initialDims.length; i++) {\n var u = i % 8;\n var v = (i - u) / 8;\n var bitMask = Math.pow(2, u);\n var dim = initialDims[i];\n var ranges = dim.brush.filter.get();\n if(ranges.length < 2) continue; // bail if the bounding box based filter is sufficient\n\n var prevEnd = expandedPixelRange(ranges[0])[1];\n for(j = 1; j < ranges.length; j++) {\n var nextRange = expandedPixelRange(ranges[j]);\n for(k = prevEnd + 1; k < nextRange[0]; k++) {\n mask[k * 8 + v] &= ~bitMask;\n }\n prevEnd = Math.max(prevEnd, nextRange[1]);\n }\n }\n }\n\n var textureData = {\n // 8 units x 8 bits = 64 bits, just sufficient for the almost 64 dimensions we support\n shape: [8, maskHeight],\n format: 'alpha',\n type: 'uint8',\n mag: 'nearest',\n min: 'nearest',\n data: mask\n };\n if(maskTexture) maskTexture(textureData);\n else maskTexture = regl.texture(textureData);\n\n return {\n maskTexture: maskTexture,\n maskHeight: maskHeight,\n loA: limits[0].slice(0, 16),\n loB: limits[0].slice(16, 32),\n loC: limits[0].slice(32, 48),\n loD: limits[0].slice(48, 64),\n hiA: limits[1].slice(0, 16),\n hiB: limits[1].slice(16, 32),\n hiC: limits[1].slice(32, 48),\n hiD: limits[1].slice(48, 64),\n };\n }\n\n function renderGLParcoords(panels, setChanged, clearOnly) {\n var panelCount = panels.length;\n var i;\n\n var leftmost;\n var rightmost;\n var lowestX = Infinity;\n var highestX = -Infinity;\n\n for(i = 0; i < panelCount; i++) {\n if(panels[i].dim0.canvasX < lowestX) {\n lowestX = panels[i].dim0.canvasX;\n leftmost = i;\n }\n if(panels[i].dim1.canvasX > highestX) {\n highestX = panels[i].dim1.canvasX;\n rightmost = i;\n }\n }\n\n if(panelCount === 0) {\n // clear canvas here, as the panel iteration below will not enter the loop body\n clear(regl, 0, 0, model.canvasWidth, model.canvasHeight);\n }\n var constraints = makeConstraints(isContext);\n\n for(i = 0; i < panelCount; i++) {\n var p = panels[i];\n var i0 = p.dim0.crossfilterDimensionIndex;\n var i1 = p.dim1.crossfilterDimensionIndex;\n var x = p.canvasX;\n var y = p.canvasY;\n var nextX = x + p.panelSizeX;\n var plotGlPixelRatio = p.plotGlPixelRatio;\n if(setChanged ||\n !prevAxisOrder[i0] ||\n prevAxisOrder[i0][0] !== x ||\n prevAxisOrder[i0][1] !== nextX\n ) {\n prevAxisOrder[i0] = [x, nextX];\n\n var item = makeItem(\n model,\n leftmost, rightmost, i, i0, i1, x, y,\n p.panelSizeX, p.panelSizeY,\n p.dim0.crossfilterDimensionIndex,\n isContext ? 0 : isPick ? 2 : 1,\n constraints,\n plotGlPixelRatio\n );\n\n renderState.clearOnly = clearOnly;\n\n var blockLineCount = setChanged ? model.lines.blockLineCount : sampleCount;\n renderBlock(\n regl, glAes, renderState, blockLineCount, sampleCount, item\n );\n }\n }\n }\n\n function readPixel(canvasX, canvasY) {\n regl.read({\n x: canvasX,\n y: canvasY,\n width: 1,\n height: 1,\n data: dataPixel\n });\n return dataPixel;\n }\n\n function readPixels(canvasX, canvasY, width, height) {\n var pixelArray = new Uint8Array(4 * width * height);\n regl.read({\n x: canvasX,\n y: canvasY,\n width: width,\n height: height,\n data: pixelArray\n });\n return pixelArray;\n }\n\n function destroy() {\n canvasGL.style['pointer-events'] = 'none';\n paletteTexture.destroy();\n if(maskTexture) maskTexture.destroy();\n for(var k in attributes) attributes[k].destroy();\n }\n\n return {\n render: renderGLParcoords,\n readPixel: readPixel,\n readPixels: readPixels,\n destroy: destroy,\n update: update\n };\n};\n","'use strict';\n\n/**\n * mergeLength: set trace length as the minimum of all dimension data lengths\n * and propagates this length into each dimension\n *\n * @param {object} traceOut: the fullData trace\n * @param {Array(object)} dimensions: array of dimension objects\n * @param {string} dataAttr: the attribute of each dimension containing the data\n * @param {integer} len: an already-existing length from other attributes\n */\nmodule.exports = function(traceOut, dimensions, dataAttr, len) {\n if(!len) len = Infinity;\n var i, dimi;\n for(i = 0; i < dimensions.length; i++) {\n dimi = dimensions[i];\n if(dimi.visible) len = Math.min(len, dimi[dataAttr].length);\n }\n if(len === Infinity) len = 0;\n\n traceOut._length = len;\n for(i = 0; i < dimensions.length; i++) {\n dimi = dimensions[i];\n if(dimi.visible) dimi._length = len;\n }\n\n return len;\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\nvar isArrayOrTypedArray = Lib.isArrayOrTypedArray;\nvar numberFormat = Lib.numberFormat;\nvar rgba = require('color-rgba');\n\nvar Axes = require('../../plots/cartesian/axes');\nvar strRotate = Lib.strRotate;\nvar strTranslate = Lib.strTranslate;\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar Drawing = require('../../components/drawing');\nvar Colorscale = require('../../components/colorscale');\n\nvar gup = require('../../lib/gup');\nvar keyFun = gup.keyFun;\nvar repeat = gup.repeat;\nvar unwrap = gup.unwrap;\n\nvar helpers = require('./helpers');\nvar c = require('./constants');\nvar brush = require('./axisbrush');\nvar lineLayerMaker = require('./lines');\n\nfunction findExtreme(fn, values, len) {\n return Lib.aggNums(fn, null, values, len);\n}\n\nfunction findExtremes(values, len) {\n return fixExtremes(\n findExtreme(Math.min, values, len),\n findExtreme(Math.max, values, len)\n );\n}\n\nfunction dimensionExtent(dimension) {\n var range = dimension.range;\n return range ?\n fixExtremes(range[0], range[1]) :\n findExtremes(dimension.values, dimension._length);\n}\n\nfunction fixExtremes(lo, hi) {\n if(isNaN(lo) || !isFinite(lo)) {\n lo = 0;\n }\n\n if(isNaN(hi) || !isFinite(hi)) {\n hi = 0;\n }\n\n // avoid a degenerate (zero-width) domain\n if(lo === hi) {\n if(lo === 0) {\n // no use to multiplying zero, so add/subtract in this case\n lo -= 1;\n hi += 1;\n } else {\n // this keeps the range in the order of magnitude of the data\n lo *= 0.9;\n hi *= 1.1;\n }\n }\n\n return [lo, hi];\n}\n\nfunction toText(formatter, texts) {\n if(texts) {\n return function(v, i) {\n var text = texts[i];\n if(text === null || text === undefined) return formatter(v);\n return text;\n };\n }\n return formatter;\n}\n\nfunction domainScale(height, padding, dimension, tickvals, ticktext) {\n var extent = dimensionExtent(dimension);\n if(tickvals) {\n return d3.scale.ordinal()\n .domain(tickvals.map(toText(numberFormat(dimension.tickformat), ticktext)))\n .range(tickvals\n .map(function(d) {\n var unitVal = (d - extent[0]) / (extent[1] - extent[0]);\n return (height - padding + unitVal * (2 * padding - height));\n })\n );\n }\n return d3.scale.linear()\n .domain(extent)\n .range([height - padding, padding]);\n}\n\nfunction unitToPaddedPx(height, padding) {\n return d3.scale.linear().range([padding, height - padding]);\n}\n\nfunction domainToPaddedUnitScale(dimension, padFraction) {\n return d3.scale.linear()\n .domain(dimensionExtent(dimension))\n .range([padFraction, 1 - padFraction]);\n}\n\nfunction ordinalScale(dimension) {\n if(!dimension.tickvals) return;\n\n var extent = dimensionExtent(dimension);\n return d3.scale.ordinal()\n .domain(dimension.tickvals)\n .range(dimension.tickvals.map(function(d) {\n return (d - extent[0]) / (extent[1] - extent[0]);\n }));\n}\n\nfunction unitToColorScale(cscale) {\n var colorStops = cscale.map(function(d) { return d[0]; });\n var colorTuples = cscale.map(function(d) {\n var RGBA = rgba(d[1]);\n return d3.rgb('rgb(' + RGBA[0] + ',' + RGBA[1] + ',' + RGBA[2] + ')');\n });\n var prop = function(n) { return function(o) { return o[n]; }; };\n\n // We can't use d3 color interpolation as we may have non-uniform color palette raster\n // (various color stop distances).\n var polylinearUnitScales = 'rgb'.split('').map(function(key) {\n return d3.scale.linear()\n .clamp(true)\n .domain(colorStops)\n .range(colorTuples.map(prop(key)));\n });\n\n return function(d) {\n return polylinearUnitScales.map(function(s) {\n return s(d);\n });\n };\n}\n\nfunction someFiltersActive(view) {\n return view.dimensions.some(function(p) {\n return p.brush.filterSpecified;\n });\n}\n\nfunction model(layout, d, i) {\n var cd0 = unwrap(d);\n var trace = cd0.trace;\n var lineColor = helpers.convertTypedArray(cd0.lineColor);\n var line = trace.line;\n var deselectedLines = {\n color: rgba(trace.unselected.line.color),\n opacity: trace.unselected.line.opacity\n };\n var cOpts = Colorscale.extractOpts(line);\n var cscale = cOpts.reversescale ? Colorscale.flipScale(cd0.cscale) : cd0.cscale;\n var domain = trace.domain;\n var dimensions = trace.dimensions;\n var width = layout.width;\n var labelAngle = trace.labelangle;\n var labelSide = trace.labelside;\n var labelFont = trace.labelfont;\n var tickFont = trace.tickfont;\n var rangeFont = trace.rangefont;\n\n var lines = Lib.extendDeepNoArrays({}, line, {\n color: lineColor.map(d3.scale.linear().domain(\n dimensionExtent({\n values: lineColor,\n range: [cOpts.min, cOpts.max],\n _length: trace._length\n })\n )),\n blockLineCount: c.blockLineCount,\n canvasOverdrag: c.overdrag * c.canvasPixelRatio\n });\n\n var groupWidth = Math.floor(width * (domain.x[1] - domain.x[0]));\n var groupHeight = Math.floor(layout.height * (domain.y[1] - domain.y[0]));\n\n var pad = layout.margin || {l: 80, r: 80, t: 100, b: 80};\n var rowContentWidth = groupWidth;\n var rowHeight = groupHeight;\n\n return {\n key: i,\n colCount: dimensions.filter(helpers.isVisible).length,\n dimensions: dimensions,\n tickDistance: c.tickDistance,\n unitToColor: unitToColorScale(cscale),\n lines: lines,\n deselectedLines: deselectedLines,\n labelAngle: labelAngle,\n labelSide: labelSide,\n labelFont: labelFont,\n tickFont: tickFont,\n rangeFont: rangeFont,\n layoutWidth: width,\n layoutHeight: layout.height,\n domain: domain,\n translateX: domain.x[0] * width,\n translateY: layout.height - domain.y[1] * layout.height,\n pad: pad,\n canvasWidth: rowContentWidth * c.canvasPixelRatio + 2 * lines.canvasOverdrag,\n canvasHeight: rowHeight * c.canvasPixelRatio,\n width: rowContentWidth,\n height: rowHeight,\n canvasPixelRatio: c.canvasPixelRatio\n };\n}\n\nfunction viewModel(state, callbacks, model) {\n var width = model.width;\n var height = model.height;\n var dimensions = model.dimensions;\n var canvasPixelRatio = model.canvasPixelRatio;\n\n var xScale = function(d) {return width * d / Math.max(1, model.colCount - 1);};\n\n var unitPad = c.verticalPadding / height;\n var _unitToPaddedPx = unitToPaddedPx(height, c.verticalPadding);\n\n var vm = {\n key: model.key,\n xScale: xScale,\n model: model,\n inBrushDrag: false // consider factoring it out and putting it in a centralized global-ish gesture state object\n };\n\n var uniqueKeys = {};\n\n vm.dimensions = dimensions.filter(helpers.isVisible).map(function(dimension, i) {\n var domainToPaddedUnit = domainToPaddedUnitScale(dimension, unitPad);\n var foundKey = uniqueKeys[dimension.label];\n uniqueKeys[dimension.label] = (foundKey || 0) + 1;\n var key = dimension.label + (foundKey ? '__' + foundKey : '');\n var specifiedConstraint = dimension.constraintrange;\n var filterRangeSpecified = specifiedConstraint && specifiedConstraint.length;\n if(filterRangeSpecified && !isArrayOrTypedArray(specifiedConstraint[0])) {\n specifiedConstraint = [specifiedConstraint];\n }\n var filterRange = filterRangeSpecified ?\n specifiedConstraint.map(function(d) { return d.map(domainToPaddedUnit); }) :\n [[-Infinity, Infinity]];\n var brushMove = function() {\n var p = vm;\n p.focusLayer && p.focusLayer.render(p.panels, true);\n var filtersActive = someFiltersActive(p);\n if(!state.contextShown() && filtersActive) {\n p.contextLayer && p.contextLayer.render(p.panels, true);\n state.contextShown(true);\n } else if(state.contextShown() && !filtersActive) {\n p.contextLayer && p.contextLayer.render(p.panels, true, true);\n state.contextShown(false);\n }\n };\n\n var truncatedValues = dimension.values;\n if(truncatedValues.length > dimension._length) {\n truncatedValues = truncatedValues.slice(0, dimension._length);\n }\n\n var tickvals = dimension.tickvals;\n var ticktext;\n function makeTickItem(v, i) { return {val: v, text: ticktext[i]}; }\n function sortTickItem(a, b) { return a.val - b.val; }\n if(isArrayOrTypedArray(tickvals) && tickvals.length) {\n if(Lib.isTypedArray(tickvals)) tickvals = Array.from(tickvals);\n\n ticktext = dimension.ticktext;\n\n // ensure ticktext and tickvals have same length\n if(!isArrayOrTypedArray(ticktext) || !ticktext.length) {\n ticktext = tickvals.map(numberFormat(dimension.tickformat));\n } else if(ticktext.length > tickvals.length) {\n ticktext = ticktext.slice(0, tickvals.length);\n } else if(tickvals.length > ticktext.length) {\n tickvals = tickvals.slice(0, ticktext.length);\n }\n\n // check if we need to sort tickvals/ticktext\n for(var j = 1; j < tickvals.length; j++) {\n if(tickvals[j] < tickvals[j - 1]) {\n var tickItems = tickvals.map(makeTickItem).sort(sortTickItem);\n for(var k = 0; k < tickvals.length; k++) {\n tickvals[k] = tickItems[k].val;\n ticktext[k] = tickItems[k].text;\n }\n break;\n }\n }\n } else tickvals = undefined;\n\n truncatedValues = helpers.convertTypedArray(truncatedValues);\n\n return {\n key: key,\n label: dimension.label,\n tickFormat: dimension.tickformat,\n tickvals: tickvals,\n ticktext: ticktext,\n ordinal: helpers.isOrdinal(dimension),\n multiselect: dimension.multiselect,\n xIndex: i,\n crossfilterDimensionIndex: i,\n visibleIndex: dimension._index,\n height: height,\n values: truncatedValues,\n paddedUnitValues: truncatedValues.map(domainToPaddedUnit),\n unitTickvals: tickvals && tickvals.map(domainToPaddedUnit),\n xScale: xScale,\n x: xScale(i),\n canvasX: xScale(i) * canvasPixelRatio,\n unitToPaddedPx: _unitToPaddedPx,\n domainScale: domainScale(height, c.verticalPadding, dimension, tickvals, ticktext),\n ordinalScale: ordinalScale(dimension),\n parent: vm,\n model: model,\n brush: brush.makeBrush(\n state,\n filterRangeSpecified,\n filterRange,\n function() {\n state.linePickActive(false);\n },\n brushMove,\n function(f) {\n vm.focusLayer.render(vm.panels, true);\n vm.pickLayer && vm.pickLayer.render(vm.panels, true);\n state.linePickActive(true);\n if(callbacks && callbacks.filterChanged) {\n var invScale = domainToPaddedUnit.invert;\n\n // update gd.data as if a Plotly.restyle were fired\n var newRanges = f.map(function(r) {\n return r.map(invScale).sort(Lib.sorterAsc);\n }).sort(function(a, b) { return a[0] - b[0]; });\n callbacks.filterChanged(vm.key, dimension._index, newRanges);\n }\n }\n )\n };\n });\n\n return vm;\n}\n\nfunction styleExtentTexts(selection) {\n selection\n .classed(c.cn.axisExtentText, true)\n .attr('text-anchor', 'middle')\n .style('cursor', 'default');\n}\n\nfunction parcoordsInteractionState() {\n var linePickActive = true;\n var contextShown = false;\n return {\n linePickActive: function(val) {return arguments.length ? linePickActive = !!val : linePickActive;},\n contextShown: function(val) {return arguments.length ? contextShown = !!val : contextShown;}\n };\n}\n\nfunction calcTilt(angle, position) {\n var dir = (position === 'top') ? 1 : -1;\n var radians = angle * Math.PI / 180;\n var dx = Math.sin(radians);\n var dy = Math.cos(radians);\n return {\n dir: dir,\n dx: dx,\n dy: dy,\n degrees: angle\n };\n}\n\nfunction updatePanelLayout(yAxis, vm, plotGlPixelRatio) {\n var panels = vm.panels || (vm.panels = []);\n var data = yAxis.data();\n for(var i = 0; i < data.length - 1; i++) {\n var p = panels[i] || (panels[i] = {});\n var dim0 = data[i];\n var dim1 = data[i + 1];\n p.dim0 = dim0;\n p.dim1 = dim1;\n p.canvasX = dim0.canvasX;\n p.panelSizeX = dim1.canvasX - dim0.canvasX;\n p.panelSizeY = vm.model.canvasHeight;\n p.y = 0;\n p.canvasY = 0;\n p.plotGlPixelRatio = plotGlPixelRatio;\n }\n}\n\nfunction calcAllTicks(cd) {\n for(var i = 0; i < cd.length; i++) {\n for(var j = 0; j < cd[i].length; j++) {\n var trace = cd[i][j].trace;\n var dimensions = trace.dimensions;\n\n for(var k = 0; k < dimensions.length; k++) {\n var values = dimensions[k].values;\n var dim = dimensions[k]._ax;\n\n if(dim) {\n if(!dim.range) {\n dim.range = findExtremes(values, trace._length);\n } else {\n dim.range = fixExtremes(dim.range[0], dim.range[1]);\n }\n\n if(!dim.dtick) {\n dim.dtick = 0.01 * (Math.abs(dim.range[1] - dim.range[0]) || 1);\n }\n\n dim.tickformat = dimensions[k].tickformat;\n Axes.calcTicks(dim);\n dim.cleanRange();\n }\n }\n }\n }\n}\n\nfunction linearFormat(dim, v) {\n return Axes.tickText(dim._ax, v, false).text;\n}\n\nfunction extremeText(d, isTop) {\n if(d.ordinal) return '';\n var domain = d.domainScale.domain();\n var v = (domain[isTop ? domain.length - 1 : 0]);\n\n return linearFormat(d.model.dimensions[d.visibleIndex], v);\n}\n\n\nmodule.exports = function parcoords(gd, cdModule, layout, callbacks) {\n var isStatic = gd._context.staticPlot;\n\n var fullLayout = gd._fullLayout;\n var svg = fullLayout._toppaper;\n var glContainer = fullLayout._glcontainer;\n var plotGlPixelRatio = gd._context.plotGlPixelRatio;\n var paperColor = gd._fullLayout.paper_bgcolor;\n\n calcAllTicks(cdModule);\n\n var state = parcoordsInteractionState();\n\n var vm = cdModule\n .filter(function(d) { return unwrap(d).trace.visible; })\n .map(model.bind(0, layout))\n .map(viewModel.bind(0, state, callbacks));\n\n glContainer.each(function(d, i) {\n return Lib.extendFlat(d, vm[i]);\n });\n\n var glLayers = glContainer.selectAll('.gl-canvas')\n .each(function(d) {\n // FIXME: figure out how to handle multiple instances\n d.viewModel = vm[0];\n d.viewModel.plotGlPixelRatio = plotGlPixelRatio;\n d.viewModel.paperColor = paperColor;\n d.model = d.viewModel ? d.viewModel.model : null;\n });\n\n var lastHovered = null;\n\n var pickLayer = glLayers.filter(function(d) {return d.pick;});\n\n // emit hover / unhover event\n pickLayer\n .style('pointer-events', isStatic ? 'none' : 'auto')\n .on('mousemove', function(d) {\n if(state.linePickActive() && d.lineLayer && callbacks && callbacks.hover) {\n var event = d3.event;\n var cw = this.width;\n var ch = this.height;\n var pointer = d3.mouse(this);\n var x = pointer[0];\n var y = pointer[1];\n\n if(x < 0 || y < 0 || x >= cw || y >= ch) {\n return;\n }\n var pixel = d.lineLayer.readPixel(x, ch - 1 - y);\n var found = pixel[3] !== 0;\n // inverse of the calcPickColor in `lines.js`; detailed comment there\n var curveNumber = found ? pixel[2] + 256 * (pixel[1] + 256 * pixel[0]) : null;\n var eventData = {\n x: x,\n y: y,\n clientX: event.clientX,\n clientY: event.clientY,\n dataIndex: d.model.key,\n curveNumber: curveNumber\n };\n if(curveNumber !== lastHovered) { // don't unnecessarily repeat the same hit (or miss)\n if(found) {\n callbacks.hover(eventData);\n } else if(callbacks.unhover) {\n callbacks.unhover(eventData);\n }\n lastHovered = curveNumber;\n }\n }\n });\n\n glLayers\n .style('opacity', function(d) {return d.pick ? 0 : 1;});\n\n svg.style('background', 'rgba(255, 255, 255, 0)');\n var controlOverlay = svg.selectAll('.' + c.cn.parcoords)\n .data(vm, keyFun);\n\n controlOverlay.exit().remove();\n\n controlOverlay.enter()\n .append('g')\n .classed(c.cn.parcoords, true)\n .style('shape-rendering', 'crispEdges')\n .style('pointer-events', 'none');\n\n controlOverlay.attr('transform', function(d) {\n return strTranslate(d.model.translateX, d.model.translateY);\n });\n\n var parcoordsControlView = controlOverlay.selectAll('.' + c.cn.parcoordsControlView)\n .data(repeat, keyFun);\n\n parcoordsControlView.enter()\n .append('g')\n .classed(c.cn.parcoordsControlView, true);\n\n parcoordsControlView.attr('transform', function(d) {\n return strTranslate(d.model.pad.l, d.model.pad.t);\n });\n\n var yAxis = parcoordsControlView.selectAll('.' + c.cn.yAxis)\n .data(function(p) { return p.dimensions; }, keyFun);\n\n yAxis.enter()\n .append('g')\n .classed(c.cn.yAxis, true);\n\n parcoordsControlView.each(function(p) {\n updatePanelLayout(yAxis, p, plotGlPixelRatio);\n });\n\n glLayers\n .each(function(d) {\n if(d.viewModel) {\n if(!d.lineLayer || callbacks) { // recreate in case of having callbacks e.g. restyle. Should we test for callback to be a restyle?\n d.lineLayer = lineLayerMaker(this, d);\n } else d.lineLayer.update(d);\n\n if(d.key || d.key === 0) d.viewModel[d.key] = d.lineLayer;\n\n var setChanged = (!d.context || // don't update background\n callbacks); // unless there is a callback on the context layer. Should we test the callback?\n\n d.lineLayer.render(d.viewModel.panels, setChanged);\n }\n });\n\n yAxis.attr('transform', function(d) {\n return strTranslate(d.xScale(d.xIndex), 0);\n });\n\n // drag column for reordering columns\n yAxis.call(d3.behavior.drag()\n .origin(function(d) { return d; })\n .on('drag', function(d) {\n var p = d.parent;\n state.linePickActive(false);\n d.x = Math.max(-c.overdrag, Math.min(d.model.width + c.overdrag, d3.event.x));\n d.canvasX = d.x * d.model.canvasPixelRatio;\n yAxis\n .sort(function(a, b) { return a.x - b.x; })\n .each(function(e, i) {\n e.xIndex = i;\n e.x = d === e ? e.x : e.xScale(e.xIndex);\n e.canvasX = e.x * e.model.canvasPixelRatio;\n });\n\n updatePanelLayout(yAxis, p, plotGlPixelRatio);\n\n yAxis.filter(function(e) { return Math.abs(d.xIndex - e.xIndex) !== 0; })\n .attr('transform', function(d) { return strTranslate(d.xScale(d.xIndex), 0); });\n d3.select(this).attr('transform', strTranslate(d.x, 0));\n yAxis.each(function(e, i0, i1) { if(i1 === d.parent.key) p.dimensions[i0] = e; });\n p.contextLayer && p.contextLayer.render(p.panels, false, !someFiltersActive(p));\n p.focusLayer.render && p.focusLayer.render(p.panels);\n })\n .on('dragend', function(d) {\n var p = d.parent;\n d.x = d.xScale(d.xIndex);\n d.canvasX = d.x * d.model.canvasPixelRatio;\n updatePanelLayout(yAxis, p, plotGlPixelRatio);\n d3.select(this)\n .attr('transform', function(d) { return strTranslate(d.x, 0); });\n p.contextLayer && p.contextLayer.render(p.panels, false, !someFiltersActive(p));\n p.focusLayer && p.focusLayer.render(p.panels);\n p.pickLayer && p.pickLayer.render(p.panels, true);\n state.linePickActive(true);\n\n if(callbacks && callbacks.axesMoved) {\n callbacks.axesMoved(p.key, p.dimensions.map(function(e) {return e.crossfilterDimensionIndex;}));\n }\n })\n );\n\n yAxis.exit()\n .remove();\n\n var axisOverlays = yAxis.selectAll('.' + c.cn.axisOverlays)\n .data(repeat, keyFun);\n\n axisOverlays.enter()\n .append('g')\n .classed(c.cn.axisOverlays, true);\n\n axisOverlays.selectAll('.' + c.cn.axis).remove();\n\n var axis = axisOverlays.selectAll('.' + c.cn.axis)\n .data(repeat, keyFun);\n\n axis.enter()\n .append('g')\n .classed(c.cn.axis, true);\n\n axis\n .each(function(d) {\n var wantedTickCount = d.model.height / d.model.tickDistance;\n var scale = d.domainScale;\n var sdom = scale.domain();\n d3.select(this)\n .call(d3.svg.axis()\n .orient('left')\n .tickSize(4)\n .outerTickSize(2)\n .ticks(wantedTickCount, d.tickFormat) // works for continuous scales only...\n .tickValues(d.ordinal ? // and this works for ordinal scales\n sdom :\n null)\n .tickFormat(function(v) {\n return helpers.isOrdinal(d) ? v : linearFormat(d.model.dimensions[d.visibleIndex], v);\n })\n .scale(scale));\n Drawing.font(axis.selectAll('text'), d.model.tickFont);\n });\n\n axis.selectAll('.domain, .tick>line')\n .attr('fill', 'none')\n .attr('stroke', 'black')\n .attr('stroke-opacity', 0.25)\n .attr('stroke-width', '1px');\n\n axis.selectAll('text')\n .style('cursor', 'default');\n\n var axisHeading = axisOverlays.selectAll('.' + c.cn.axisHeading)\n .data(repeat, keyFun);\n\n axisHeading.enter()\n .append('g')\n .classed(c.cn.axisHeading, true);\n\n var axisTitle = axisHeading.selectAll('.' + c.cn.axisTitle)\n .data(repeat, keyFun);\n\n axisTitle.enter()\n .append('text')\n .classed(c.cn.axisTitle, true)\n .attr('text-anchor', 'middle')\n .style('cursor', 'ew-resize')\n .style('pointer-events', isStatic ? 'none' : 'auto');\n\n axisTitle\n .text(function(d) { return d.label; })\n .each(function(d) {\n var e = d3.select(this);\n Drawing.font(e, d.model.labelFont);\n svgTextUtils.convertToTspans(e, gd);\n })\n .attr('transform', function(d) {\n var tilt = calcTilt(d.model.labelAngle, d.model.labelSide);\n var r = c.axisTitleOffset;\n return (\n (tilt.dir > 0 ? '' : strTranslate(0, 2 * r + d.model.height)) +\n strRotate(tilt.degrees) +\n strTranslate(-r * tilt.dx, -r * tilt.dy)\n );\n })\n .attr('text-anchor', function(d) {\n var tilt = calcTilt(d.model.labelAngle, d.model.labelSide);\n var adx = Math.abs(tilt.dx);\n var ady = Math.abs(tilt.dy);\n\n if(2 * adx > ady) {\n return (tilt.dir * tilt.dx < 0) ? 'start' : 'end';\n } else {\n return 'middle';\n }\n });\n\n var axisExtent = axisOverlays.selectAll('.' + c.cn.axisExtent)\n .data(repeat, keyFun);\n\n axisExtent.enter()\n .append('g')\n .classed(c.cn.axisExtent, true);\n\n var axisExtentTop = axisExtent.selectAll('.' + c.cn.axisExtentTop)\n .data(repeat, keyFun);\n\n axisExtentTop.enter()\n .append('g')\n .classed(c.cn.axisExtentTop, true);\n\n axisExtentTop\n .attr('transform', strTranslate(0, -c.axisExtentOffset));\n\n var axisExtentTopText = axisExtentTop.selectAll('.' + c.cn.axisExtentTopText)\n .data(repeat, keyFun);\n\n axisExtentTopText.enter()\n .append('text')\n .classed(c.cn.axisExtentTopText, true)\n .call(styleExtentTexts);\n\n axisExtentTopText\n .text(function(d) { return extremeText(d, true); })\n .each(function(d) { Drawing.font(d3.select(this), d.model.rangeFont); });\n\n var axisExtentBottom = axisExtent.selectAll('.' + c.cn.axisExtentBottom)\n .data(repeat, keyFun);\n\n axisExtentBottom.enter()\n .append('g')\n .classed(c.cn.axisExtentBottom, true);\n\n axisExtentBottom\n .attr('transform', function(d) {\n return strTranslate(0, d.model.height + c.axisExtentOffset);\n });\n\n var axisExtentBottomText = axisExtentBottom.selectAll('.' + c.cn.axisExtentBottomText)\n .data(repeat, keyFun);\n\n axisExtentBottomText.enter()\n .append('text')\n .classed(c.cn.axisExtentBottomText, true)\n .attr('dy', '0.75em')\n .call(styleExtentTexts);\n\n axisExtentBottomText\n .text(function(d) { return extremeText(d, false); })\n .each(function(d) { Drawing.font(d3.select(this), d.model.rangeFont); });\n\n brush.ensureAxisBrush(axisOverlays, paperColor, gd);\n};\n","'use strict';\n\nvar parcoords = require('./parcoords');\nvar prepareRegl = require('../../lib/prepare_regl');\nvar isVisible = require('./helpers').isVisible;\nvar reglPrecompiled = {};\n\nfunction newIndex(visibleIndices, orig, dim) {\n var origIndex = orig.indexOf(dim);\n var currentIndex = visibleIndices.indexOf(origIndex);\n if(currentIndex === -1) {\n // invisible dimensions initially go to the end\n currentIndex += orig.length;\n }\n return currentIndex;\n}\n\nfunction sorter(visibleIndices, orig) {\n return function sorter(d1, d2) {\n return (\n newIndex(visibleIndices, orig, d1) -\n newIndex(visibleIndices, orig, d2)\n );\n };\n}\n\nvar exports = module.exports = function plot(gd, cdModule) {\n var fullLayout = gd._fullLayout;\n\n var success = prepareRegl(gd, [], reglPrecompiled);\n if(!success) return;\n\n var currentDims = {};\n var initialDims = {};\n var fullIndices = {};\n var inputIndices = {};\n\n var size = fullLayout._size;\n\n cdModule.forEach(function(d, i) {\n var trace = d[0].trace;\n fullIndices[i] = trace.index;\n var iIn = inputIndices[i] = trace._fullInput.index;\n currentDims[i] = gd.data[iIn].dimensions;\n initialDims[i] = gd.data[iIn].dimensions.slice();\n });\n\n var filterChanged = function(i, initialDimIndex, newRanges) {\n // Have updated `constraintrange` data on `gd.data` and raise `Plotly.restyle` event\n // without having to incur heavy UI blocking due to an actual `Plotly.restyle` call\n\n var dim = initialDims[i][initialDimIndex];\n var newConstraints = newRanges.map(function(r) { return r.slice(); });\n\n // Store constraint range in preGUI\n // This one doesn't work if it's stored in pieces in _storeDirectGUIEdit\n // because it's an array of variable dimensionality. So store the whole\n // thing at once manually.\n var aStr = 'dimensions[' + initialDimIndex + '].constraintrange';\n var preGUI = fullLayout._tracePreGUI[gd._fullData[fullIndices[i]]._fullInput.uid];\n if(preGUI[aStr] === undefined) {\n var initialVal = dim.constraintrange;\n preGUI[aStr] = initialVal || null;\n }\n\n var fullDimension = gd._fullData[fullIndices[i]].dimensions[initialDimIndex];\n\n if(!newConstraints.length) {\n delete dim.constraintrange;\n delete fullDimension.constraintrange;\n newConstraints = null;\n } else {\n if(newConstraints.length === 1) newConstraints = newConstraints[0];\n dim.constraintrange = newConstraints;\n fullDimension.constraintrange = newConstraints.slice();\n // wrap in another array for restyle event data\n newConstraints = [newConstraints];\n }\n\n var restyleData = {};\n restyleData[aStr] = newConstraints;\n gd.emit('plotly_restyle', [restyleData, [inputIndices[i]]]);\n };\n\n var hover = function(eventData) {\n gd.emit('plotly_hover', eventData);\n };\n\n var unhover = function(eventData) {\n gd.emit('plotly_unhover', eventData);\n };\n\n var axesMoved = function(i, visibleIndices) {\n // Have updated order data on `gd.data` and raise `Plotly.restyle` event\n // without having to incur heavy UI blocking due to an actual `Plotly.restyle` call\n\n // drag&drop sorting of the visible dimensions\n var orig = sorter(visibleIndices, initialDims[i].filter(isVisible));\n currentDims[i].sort(orig);\n\n // invisible dimensions are not interpreted in the context of drag&drop sorting as an invisible dimension\n // cannot be dragged; they're interspersed into their original positions by this subsequent merging step\n initialDims[i].filter(function(d) {return !isVisible(d);})\n .sort(function(d) {\n // subsequent splicing to be done left to right, otherwise indices may be incorrect\n return initialDims[i].indexOf(d);\n })\n .forEach(function(d) {\n currentDims[i].splice(currentDims[i].indexOf(d), 1); // remove from the end\n currentDims[i].splice(initialDims[i].indexOf(d), 0, d); // insert at original index\n });\n\n // TODO: we can't really store this part of the interaction state\n // directly as below, since it incudes data arrays. If we want to\n // persist column order we may have to do something special for this\n // case to just store the order itself.\n // Registry.call('_storeDirectGUIEdit',\n // gd.data[inputIndices[i]],\n // fullLayout._tracePreGUI[gd._fullData[fullIndices[i]]._fullInput.uid],\n // {dimensions: currentDims[i]}\n // );\n\n gd.emit('plotly_restyle', [{dimensions: [currentDims[i]]}, [inputIndices[i]]]);\n };\n\n parcoords(\n gd,\n cdModule,\n { // layout\n width: size.w,\n height: size.h,\n margin: {\n t: size.t,\n r: size.r,\n b: size.b,\n l: size.l\n }\n },\n { // callbacks\n filterChanged: filterChanged,\n hover: hover,\n unhover: unhover,\n axesMoved: axesMoved\n }\n );\n};\n\nexports.reglPrecompiled = reglPrecompiled;\n","'use strict';\n\nvar baseAttrs = require('../../plots/attributes');\nvar domainAttrs = require('../../plots/domain').attributes;\nvar fontAttrs = require('../../plots/font_attributes');\nvar colorAttrs = require('../../components/color/attributes');\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\n\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar pattern = require('../../components/drawing/attributes').pattern;\n\nvar textFontAttrs = fontAttrs({\n editType: 'plot',\n arrayOk: true,\n colorEditType: 'plot',\n description: 'Sets the font used for `textinfo`.'\n});\n\nmodule.exports = {\n labels: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the sector labels.',\n 'If `labels` entries are duplicated, we sum associated `values`',\n 'or simply count occurrences if `values` is not provided.',\n 'For other array attributes (including color) we use the first',\n 'non-empty entry among all occurrences of the label.'\n ].join(' ')\n },\n // equivalent of x0 and dx, if label is missing\n label0: {\n valType: 'number',\n dflt: 0,\n editType: 'calc',\n description: [\n 'Alternate to `labels`.',\n 'Builds a numeric set of labels.',\n 'Use with `dlabel`',\n 'where `label0` is the starting label and `dlabel` the step.'\n ].join(' ')\n },\n dlabel: {\n valType: 'number',\n dflt: 1,\n editType: 'calc',\n description: 'Sets the label step. See `label0` for more info.'\n },\n\n values: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the values of the sectors.',\n 'If omitted, we count occurrences of each label.'\n ].join(' ')\n },\n\n marker: {\n colors: {\n valType: 'data_array', // TODO 'color_array' ?\n editType: 'calc',\n description: [\n 'Sets the color of each sector.',\n 'If not specified, the default trace color set is used',\n 'to pick the sector colors.'\n ].join(' ')\n },\n\n line: {\n color: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n arrayOk: true,\n editType: 'style',\n description: [\n 'Sets the color of the line enclosing each sector.'\n ].join(' ')\n },\n width: {\n valType: 'number',\n min: 0,\n dflt: 0,\n arrayOk: true,\n editType: 'style',\n description: [\n 'Sets the width (in px) of the line enclosing each sector.'\n ].join(' ')\n },\n editType: 'calc'\n },\n pattern: pattern,\n editType: 'calc'\n },\n\n text: {\n valType: 'data_array',\n editType: 'plot',\n description: [\n 'Sets text elements associated with each sector.',\n 'If trace `textinfo` contains a *text* flag, these elements will be seen',\n 'on the chart.',\n 'If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,',\n 'these elements will be seen in the hover labels.'\n ].join(' ')\n },\n hovertext: {\n valType: 'string',\n dflt: '',\n arrayOk: true,\n editType: 'style',\n description: [\n 'Sets hover text elements associated with each sector.',\n 'If a single string, the same string appears for',\n 'all data points.',\n 'If an array of string, the items are mapped in order of',\n 'this trace\\'s sectors.',\n 'To be seen, trace `hoverinfo` must contain a *text* flag.'\n ].join(' ')\n },\n\n// 'see eg:'\n// 'https://www.e-education.psu.edu/natureofgeoinfo/sites/www.e-education.psu.edu.natureofgeoinfo/files/image/hisp_pies.gif',\n// '(this example involves a map too - may someday be a whole trace type',\n// 'of its own. but the point is the size of the whole pie is important.)'\n scalegroup: {\n valType: 'string',\n dflt: '',\n editType: 'calc',\n description: [\n 'If there are multiple pie charts that should be sized according to',\n 'their totals, link them by providing a non-empty group id here',\n 'shared by every trace in the same group.'\n ].join(' ')\n },\n\n // labels (legend is handled by plots.attributes.showlegend and layout.hiddenlabels)\n textinfo: {\n valType: 'flaglist',\n flags: ['label', 'text', 'value', 'percent'],\n extras: ['none'],\n editType: 'calc',\n description: [\n 'Determines which trace information appear on the graph.'\n ].join(' ')\n },\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['label', 'text', 'value', 'percent', 'name']\n }),\n hovertemplate: hovertemplateAttrs({}, {\n keys: ['label', 'color', 'value', 'percent', 'text']\n }),\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: ['label', 'color', 'value', 'percent', 'text']\n }),\n textposition: {\n valType: 'enumerated',\n values: ['inside', 'outside', 'auto', 'none'],\n dflt: 'auto',\n arrayOk: true,\n editType: 'plot',\n description: [\n 'Specifies the location of the `textinfo`.'\n ].join(' ')\n },\n textfont: extendFlat({}, textFontAttrs, {\n description: 'Sets the font used for `textinfo`.'\n }),\n insidetextorientation: {\n valType: 'enumerated',\n values: ['horizontal', 'radial', 'tangential', 'auto'],\n dflt: 'auto',\n editType: 'plot',\n description: [\n 'Controls the orientation of the text inside chart sectors.',\n 'When set to *auto*, text may be oriented in any direction in order',\n 'to be as big as possible in the middle of a sector.',\n 'The *horizontal* option orients text to be parallel with the bottom',\n 'of the chart, and may make text smaller in order to achieve that goal.',\n 'The *radial* option orients text along the radius of the sector.',\n 'The *tangential* option orients text perpendicular to the radius of the sector.'\n ].join(' ')\n },\n insidetextfont: extendFlat({}, textFontAttrs, {\n description: 'Sets the font used for `textinfo` lying inside the sector.'\n }),\n outsidetextfont: extendFlat({}, textFontAttrs, {\n description: 'Sets the font used for `textinfo` lying outside the sector.'\n }),\n automargin: {\n valType: 'boolean',\n dflt: false,\n editType: 'plot',\n description: [\n 'Determines whether outside text labels can push the margins.'\n ].join(' ')\n },\n\n title: {\n text: {\n valType: 'string',\n dflt: '',\n editType: 'plot',\n description: [\n 'Sets the title of the chart.',\n 'If it is empty, no title is displayed.',\n 'Note that before the existence of `title.text`, the title\\'s',\n 'contents used to be defined as the `title` attribute itself.',\n 'This behavior has been deprecated.'\n ].join(' ')\n },\n font: extendFlat({}, textFontAttrs, {\n description: [\n 'Sets the font used for `title`.',\n 'Note that the title\\'s font used to be set',\n 'by the now deprecated `titlefont` attribute.'\n ].join(' ')\n }),\n position: {\n valType: 'enumerated',\n values: [\n 'top left', 'top center', 'top right',\n 'middle center',\n 'bottom left', 'bottom center', 'bottom right'\n ],\n editType: 'plot',\n description: [\n 'Specifies the location of the `title`.',\n 'Note that the title\\'s position used to be set',\n 'by the now deprecated `titleposition` attribute.'\n ].join(' ')\n },\n\n editType: 'plot'\n },\n\n // position and shape\n domain: domainAttrs({name: 'pie', trace: true, editType: 'calc'}),\n\n hole: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0,\n editType: 'calc',\n description: [\n 'Sets the fraction of the radius to cut out of the pie.',\n 'Use this to make a donut chart.'\n ].join(' ')\n },\n\n // ordering and direction\n sort: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether or not the sectors are reordered',\n 'from largest to smallest.'\n ].join(' ')\n },\n direction: {\n /**\n * there are two common conventions, both of which place the first\n * (largest, if sorted) slice with its left edge at 12 o'clock but\n * succeeding slices follow either cw or ccw from there.\n *\n * see http://visage.co/data-visualization-101-pie-charts/\n */\n valType: 'enumerated',\n values: ['clockwise', 'counterclockwise'],\n dflt: 'counterclockwise',\n editType: 'calc',\n description: [\n 'Specifies the direction at which succeeding sectors follow',\n 'one another.'\n ].join(' ')\n },\n rotation: {\n valType: 'angle',\n dflt: 0,\n editType: 'calc',\n description: [\n 'Instead of the first slice starting at 12 o\\'clock,',\n 'rotate to some other angle.'\n ].join(' ')\n },\n\n pull: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0,\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Sets the fraction of larger radius to pull the sectors',\n 'out from the center. This can be a constant',\n 'to pull all slices apart from each other equally',\n 'or an array to highlight one or more slices.'\n ].join(' ')\n },\n\n _deprecated: {\n title: {\n valType: 'string',\n dflt: '',\n editType: 'calc',\n description: [\n 'Deprecated in favor of `title.text`.',\n 'Note that value of `title` is no longer a simple',\n '*string* but a set of sub-attributes.'\n ].join(' ')\n },\n titlefont: extendFlat({}, textFontAttrs, {\n description: 'Deprecated in favor of `title.font`.'\n }),\n titleposition: {\n valType: 'enumerated',\n values: [\n 'top left', 'top center', 'top right',\n 'middle center',\n 'bottom left', 'bottom center', 'bottom right'\n ],\n editType: 'calc',\n description: 'Deprecated in favor of `title.position`.'\n }\n }\n};\n","'use strict';\n\nvar plots = require('../../plots/plots');\n\nexports.name = 'pie';\n\nexports.plot = function(gd, traces, transitionOpts, makeOnCompleteCallback) {\n plots.plotBasePlot(exports.name, gd, traces, transitionOpts, makeOnCompleteCallback);\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n plots.cleanBasePlot(exports.name, newFullData, newFullLayout, oldFullData, oldFullLayout);\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar tinycolor = require('tinycolor2');\n\nvar Color = require('../../components/color');\n\nvar extendedColorWayList = {};\n\nfunction calc(gd, trace) {\n var cd = [];\n\n var fullLayout = gd._fullLayout;\n var hiddenLabels = fullLayout.hiddenlabels || [];\n\n var labels = trace.labels;\n var colors = trace.marker.colors || [];\n var vals = trace.values;\n var len = trace._length;\n var hasValues = trace._hasValues && len;\n\n var i, pt;\n\n if(trace.dlabel) {\n labels = new Array(len);\n for(i = 0; i < len; i++) {\n labels[i] = String(trace.label0 + i * trace.dlabel);\n }\n }\n\n var allThisTraceLabels = {};\n var pullColor = makePullColorFn(fullLayout['_' + trace.type + 'colormap']);\n var vTotal = 0;\n var isAggregated = false;\n\n for(i = 0; i < len; i++) {\n var v, label, hidden;\n if(hasValues) {\n v = vals[i];\n if(!isNumeric(v)) continue;\n v = +v;\n } else v = 1;\n\n label = labels[i];\n if(label === undefined || label === '') label = i;\n label = String(label);\n\n var thisLabelIndex = allThisTraceLabels[label];\n if(thisLabelIndex === undefined) {\n allThisTraceLabels[label] = cd.length;\n\n hidden = hiddenLabels.indexOf(label) !== -1;\n\n if(!hidden) vTotal += v;\n\n cd.push({\n v: v,\n label: label,\n color: pullColor(colors[i], label),\n i: i,\n pts: [i],\n hidden: hidden\n });\n } else {\n isAggregated = true;\n\n pt = cd[thisLabelIndex];\n pt.v += v;\n pt.pts.push(i);\n if(!pt.hidden) vTotal += v;\n\n if(pt.color === false && colors[i]) {\n pt.color = pullColor(colors[i], label);\n }\n }\n }\n\n // Drop aggregate sums of value 0 or less\n cd = cd.filter(function(elem) { return elem.v >= 0; });\n\n var shouldSort = (trace.type === 'funnelarea') ? isAggregated : trace.sort;\n if(shouldSort) cd.sort(function(a, b) { return b.v - a.v; });\n\n // include the sum of all values in the first point\n if(cd[0]) cd[0].vTotal = vTotal;\n\n return cd;\n}\n\nfunction makePullColorFn(colorMap) {\n return function pullColor(color, id) {\n if(!color) return false;\n\n color = tinycolor(color);\n if(!color.isValid()) return false;\n\n color = Color.addOpacity(color, color.getAlpha());\n if(!colorMap[id]) colorMap[id] = color;\n\n return color;\n };\n}\n\n/*\n * `calc` filled in (and collated) explicit colors.\n * Now we need to propagate these explicit colors to other traces,\n * and fill in default colors.\n * This is done after sorting, so we pick defaults\n * in the order slices will be displayed\n */\nfunction crossTraceCalc(gd, plotinfo) { // TODO: should we name the second argument opts?\n var desiredType = (plotinfo || {}).type;\n if(!desiredType) desiredType = 'pie';\n\n var fullLayout = gd._fullLayout;\n var calcdata = gd.calcdata;\n var colorWay = fullLayout[desiredType + 'colorway'];\n var colorMap = fullLayout['_' + desiredType + 'colormap'];\n\n if(fullLayout['extend' + desiredType + 'colors']) {\n colorWay = generateExtendedColors(colorWay, extendedColorWayList);\n }\n var dfltColorCount = 0;\n\n for(var i = 0; i < calcdata.length; i++) {\n var cd = calcdata[i];\n var traceType = cd[0].trace.type;\n if(traceType !== desiredType) continue;\n\n for(var j = 0; j < cd.length; j++) {\n var pt = cd[j];\n if(pt.color === false) {\n // have we seen this label and assigned a color to it in a previous trace?\n if(colorMap[pt.label]) {\n pt.color = colorMap[pt.label];\n } else {\n colorMap[pt.label] = pt.color = colorWay[dfltColorCount % colorWay.length];\n dfltColorCount++;\n }\n }\n }\n }\n}\n\n/**\n * pick a default color from the main default set, augmented by\n * itself lighter then darker before repeating\n */\nfunction generateExtendedColors(colorList, extendedColorWays) {\n var i;\n var colorString = JSON.stringify(colorList);\n var colors = extendedColorWays[colorString];\n if(!colors) {\n colors = colorList.slice();\n\n for(i = 0; i < colorList.length; i++) {\n colors.push(tinycolor(colorList[i]).lighten(20).toHexString());\n }\n\n for(i = 0; i < colorList.length; i++) {\n colors.push(tinycolor(colorList[i]).darken(20).toHexString());\n }\n extendedColorWays[colorString] = colors;\n }\n\n return colors;\n}\n\nmodule.exports = {\n calc: calc,\n crossTraceCalc: crossTraceCalc,\n\n makePullColorFn: makePullColorFn,\n generateExtendedColors: generateExtendedColors\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar Lib = require('../../lib');\nvar attributes = require('./attributes');\nvar handleDomainDefaults = require('../../plots/domain').defaults;\nvar handleText = require('../bar/defaults').handleText;\nvar coercePattern = require('../../lib').coercePattern;\n\nfunction handleLabelsAndValues(labels, values) {\n var hasLabels = Lib.isArrayOrTypedArray(labels);\n var hasValues = Lib.isArrayOrTypedArray(values);\n var len = Math.min(\n hasLabels ? labels.length : Infinity,\n hasValues ? values.length : Infinity\n );\n\n if(!isFinite(len)) len = 0;\n\n if(len && hasValues) {\n var hasPositive;\n for(var i = 0; i < len; i++) {\n var v = values[i];\n if(isNumeric(v) && v > 0) {\n hasPositive = true;\n break;\n }\n }\n if(!hasPositive) len = 0;\n }\n\n return {\n hasLabels: hasLabels,\n hasValues: hasValues,\n len: len\n };\n}\n\nfunction handleMarkerDefaults(traceIn, traceOut, layout, coerce, isPie) {\n var lineWidth = coerce('marker.line.width');\n if(lineWidth) {\n coerce('marker.line.color',\n isPie ? undefined :\n layout.paper_bgcolor // case of funnelarea, sunburst, icicle, treemap\n );\n }\n\n var markerColors = coerce('marker.colors');\n coercePattern(coerce, 'marker.pattern', markerColors);\n // push the marker colors (with s) to the foreground colors, to work around logic in the drawing pattern code on marker.color (without s, which is okay for a bar trace)\n if(traceIn.marker && !traceOut.marker.pattern.fgcolor) traceOut.marker.pattern.fgcolor = traceIn.marker.colors;\n if(!traceOut.marker.pattern.bgcolor) traceOut.marker.pattern.bgcolor = layout.paper_bgcolor;\n}\n\nfunction supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var labels = coerce('labels');\n var values = coerce('values');\n\n var res = handleLabelsAndValues(labels, values);\n var len = res.len;\n traceOut._hasLabels = res.hasLabels;\n traceOut._hasValues = res.hasValues;\n\n if(!traceOut._hasLabels &&\n traceOut._hasValues\n ) {\n coerce('label0');\n coerce('dlabel');\n }\n\n if(!len) {\n traceOut.visible = false;\n return;\n }\n traceOut._length = len;\n\n handleMarkerDefaults(traceIn, traceOut, layout, coerce, true);\n\n coerce('scalegroup');\n // TODO: hole needs to be coerced to the same value within a scaleegroup\n\n var textData = coerce('text');\n var textTemplate = coerce('texttemplate');\n var textInfo;\n if(!textTemplate) textInfo = coerce('textinfo', Lib.isArrayOrTypedArray(textData) ? 'text+percent' : 'percent');\n\n coerce('hovertext');\n coerce('hovertemplate');\n\n if(textTemplate || (textInfo && textInfo !== 'none')) {\n var textposition = coerce('textposition');\n handleText(traceIn, traceOut, layout, coerce, textposition, {\n moduleHasSelected: false,\n moduleHasUnselected: false,\n moduleHasConstrain: false,\n moduleHasCliponaxis: false,\n moduleHasTextangle: false,\n moduleHasInsideanchor: false\n });\n\n var hasBoth = Array.isArray(textposition) || textposition === 'auto';\n var hasOutside = hasBoth || textposition === 'outside';\n if(hasOutside) {\n coerce('automargin');\n }\n\n if(textposition === 'inside' || textposition === 'auto' || Array.isArray(textposition)) {\n coerce('insidetextorientation');\n }\n } else if(textInfo === 'none') {\n coerce('textposition', 'none');\n }\n\n handleDomainDefaults(traceOut, layout, coerce);\n\n var hole = coerce('hole');\n var title = coerce('title.text');\n if(title) {\n var titlePosition = coerce('title.position', hole ? 'middle center' : 'top center');\n if(!hole && titlePosition === 'middle center') traceOut.title.position = 'top center';\n Lib.coerceFont(coerce, 'title.font', layout.font);\n }\n\n coerce('sort');\n coerce('direction');\n coerce('rotation');\n coerce('pull');\n}\n\nmodule.exports = {\n handleLabelsAndValues: handleLabelsAndValues,\n handleMarkerDefaults: handleMarkerDefaults,\n supplyDefaults: supplyDefaults\n};\n","'use strict';\n\nvar appendArrayMultiPointValues = require('../../components/fx/helpers').appendArrayMultiPointValues;\n\n// Note: like other eventData routines, this creates the data for hover/unhover/click events\n// but it has a different API and goes through a totally different pathway.\n// So to ensure it doesn't get misused, it's not attached to the Pie module.\nmodule.exports = function eventData(pt, trace) {\n var out = {\n curveNumber: trace.index,\n pointNumbers: pt.pts,\n data: trace._input,\n fullData: trace,\n label: pt.label,\n color: pt.color,\n value: pt.v,\n percent: pt.percent,\n text: pt.text,\n bbox: pt.bbox,\n\n // pt.v (and pt.i below) for backward compatibility\n v: pt.v\n };\n\n // Only include pointNumber if it's unambiguous\n if(pt.pts.length === 1) out.pointNumber = out.i = pt.pts[0];\n\n // Add extra data arrays to the output\n // notice that this is the multi-point version ('s' on the end!)\n // so added data will be arrays matching the pointNumbers array.\n appendArrayMultiPointValues(out, trace, pt.pts);\n\n // don't include obsolete fields in new funnelarea traces\n if(trace.type === 'funnelarea') {\n delete out.v;\n delete out.i;\n }\n\n return out;\n};\n","'use strict';\n\nvar Drawing = require('../../components/drawing');\nvar Color = require('../../components/color');\n\nmodule.exports = function fillOne(s, pt, trace, gd) {\n var pattern = trace.marker.pattern;\n if(pattern && pattern.shape) {\n Drawing.pointStyle(s, trace, gd, pt);\n } else {\n Color.fill(s, pt.color);\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nfunction format(vRounded) {\n return (\n vRounded.indexOf('e') !== -1 ? vRounded.replace(/[.]?0+e/, 'e') :\n vRounded.indexOf('.') !== -1 ? vRounded.replace(/[.]?0+$/, '') :\n vRounded\n );\n}\n\nexports.formatPiePercent = function formatPiePercent(v, separators) {\n var vRounded = format((v * 100).toPrecision(3));\n return Lib.numSeparate(vRounded, separators) + '%';\n};\n\nexports.formatPieValue = function formatPieValue(v, separators) {\n var vRounded = format(v.toPrecision(10));\n return Lib.numSeparate(vRounded, separators);\n};\n\nexports.getFirstFilled = function getFirstFilled(array, indices) {\n if(!Lib.isArrayOrTypedArray(array)) return;\n for(var i = 0; i < indices.length; i++) {\n var v = array[indices[i]];\n if(v || v === 0 || v === '') return v;\n }\n};\n\nexports.castOption = function castOption(item, indices) {\n if(Lib.isArrayOrTypedArray(item)) return exports.getFirstFilled(item, indices);\n else if(item) return item;\n};\n\nexports.getRotationAngle = function(rotation) {\n return (rotation === 'auto' ? 0 : rotation) * Math.PI / 180;\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults').supplyDefaults,\n supplyLayoutDefaults: require('./layout_defaults'),\n layoutAttributes: require('./layout_attributes'),\n\n calc: require('./calc').calc,\n crossTraceCalc: require('./calc').crossTraceCalc,\n\n plot: require('./plot').plot,\n style: require('./style'),\n styleOne: require('./style_one'),\n\n moduleType: 'trace',\n name: 'pie',\n basePlotModule: require('./base_plot'),\n categories: ['pie-like', 'pie', 'showLegend'],\n meta: {\n description: [\n 'A data visualized by the sectors of the pie is set in `values`.',\n 'The sector labels are set in `labels`.',\n 'The sector colors are set in `marker.colors`'\n ].join(' ')\n }\n};\n","'use strict';\n\nmodule.exports = {\n hiddenlabels: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'hiddenlabels is the funnelarea & pie chart analog of',\n 'visible:\\'legendonly\\'',\n 'but it can contain many labels, and can simultaneously',\n 'hide slices from several pies/funnelarea charts'\n ].join(' ')\n },\n piecolorway: {\n valType: 'colorlist',\n editType: 'calc',\n description: [\n 'Sets the default pie slice colors. Defaults to the main',\n '`colorway` used for trace colors. If you specify a new',\n 'list here it can still be extended with lighter and darker',\n 'colors, see `extendpiecolors`.'\n ].join(' ')\n },\n extendpiecolors: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'If `true`, the pie slice colors (whether given by `piecolorway` or',\n 'inherited from `colorway`) will be extended to three times its',\n 'original length by first repeating every color 20% lighter then',\n 'each color 20% darker. This is intended to reduce the likelihood',\n 'of reusing the same color when you have many slices, but you can',\n 'set `false` to disable.',\n 'Colors provided in the trace, using `marker.colors`, are never',\n 'extended.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar layoutAttributes = require('./layout_attributes');\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n\n coerce('hiddenlabels');\n coerce('piecolorway', layoutOut.colorway);\n coerce('extendpiecolors');\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Plots = require('../../plots/plots');\nvar Fx = require('../../components/fx');\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\nvar Lib = require('../../lib');\nvar strScale = Lib.strScale;\nvar strTranslate = Lib.strTranslate;\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar uniformText = require('../bar/uniform_text');\nvar recordMinTextSize = uniformText.recordMinTextSize;\nvar clearMinTextSize = uniformText.clearMinTextSize;\nvar TEXTPAD = require('../bar/constants').TEXTPAD;\n\nvar helpers = require('./helpers');\nvar eventData = require('./event_data');\nvar isValidTextValue = require('../../lib').isValidTextValue;\n\nfunction plot(gd, cdModule) {\n var isStatic = gd._context.staticPlot;\n\n var fullLayout = gd._fullLayout;\n var gs = fullLayout._size;\n\n clearMinTextSize('pie', fullLayout);\n\n prerenderTitles(cdModule, gd);\n layoutAreas(cdModule, gs);\n\n var plotGroups = Lib.makeTraceGroups(fullLayout._pielayer, cdModule, 'trace').each(function(cd) {\n var plotGroup = d3.select(this);\n var cd0 = cd[0];\n var trace = cd0.trace;\n\n setCoords(cd);\n\n // TODO: miter might look better but can sometimes cause problems\n // maybe miter with a small-ish stroke-miterlimit?\n plotGroup.attr('stroke-linejoin', 'round');\n\n plotGroup.each(function() {\n var slices = d3.select(this).selectAll('g.slice').data(cd);\n\n slices.enter().append('g')\n .classed('slice', true);\n slices.exit().remove();\n\n var quadrants = [\n [[], []], // y<0: x<0, x>=0\n [[], []] // y>=0: x<0, x>=0\n ];\n var hasOutsideText = false;\n\n slices.each(function(pt, i) {\n if(pt.hidden) {\n d3.select(this).selectAll('path,g').remove();\n return;\n }\n\n // to have consistent event data compared to other traces\n pt.pointNumber = pt.i;\n pt.curveNumber = trace.index;\n\n quadrants[pt.pxmid[1] < 0 ? 0 : 1][pt.pxmid[0] < 0 ? 0 : 1].push(pt);\n\n var cx = cd0.cx;\n var cy = cd0.cy;\n var sliceTop = d3.select(this);\n var slicePath = sliceTop.selectAll('path.surface').data([pt]);\n\n slicePath.enter().append('path')\n .classed('surface', true)\n .style({'pointer-events': isStatic ? 'none' : 'all'});\n\n sliceTop.call(attachFxHandlers, gd, cd);\n\n if(trace.pull) {\n var pull = +helpers.castOption(trace.pull, pt.pts) || 0;\n if(pull > 0) {\n cx += pull * pt.pxmid[0];\n cy += pull * pt.pxmid[1];\n }\n }\n\n pt.cxFinal = cx;\n pt.cyFinal = cy;\n\n function arc(start, finish, cw, scale) {\n var dx = scale * (finish[0] - start[0]);\n var dy = scale * (finish[1] - start[1]);\n\n return 'a' +\n (scale * cd0.r) + ',' + (scale * cd0.r) + ' 0 ' +\n pt.largeArc + (cw ? ' 1 ' : ' 0 ') + dx + ',' + dy;\n }\n\n var hole = trace.hole;\n if(pt.v === cd0.vTotal) { // 100% fails bcs arc start and end are identical\n var outerCircle = 'M' + (cx + pt.px0[0]) + ',' + (cy + pt.px0[1]) +\n arc(pt.px0, pt.pxmid, true, 1) +\n arc(pt.pxmid, pt.px0, true, 1) + 'Z';\n if(hole) {\n slicePath.attr('d',\n 'M' + (cx + hole * pt.px0[0]) + ',' + (cy + hole * pt.px0[1]) +\n arc(pt.px0, pt.pxmid, false, hole) +\n arc(pt.pxmid, pt.px0, false, hole) +\n 'Z' + outerCircle);\n } else slicePath.attr('d', outerCircle);\n } else {\n var outerArc = arc(pt.px0, pt.px1, true, 1);\n\n if(hole) {\n var rim = 1 - hole;\n slicePath.attr('d',\n 'M' + (cx + hole * pt.px1[0]) + ',' + (cy + hole * pt.px1[1]) +\n arc(pt.px1, pt.px0, false, hole) +\n 'l' + (rim * pt.px0[0]) + ',' + (rim * pt.px0[1]) +\n outerArc +\n 'Z');\n } else {\n slicePath.attr('d',\n 'M' + cx + ',' + cy +\n 'l' + pt.px0[0] + ',' + pt.px0[1] +\n outerArc +\n 'Z');\n }\n }\n\n // add text\n formatSliceLabel(gd, pt, cd0);\n var textPosition = helpers.castOption(trace.textposition, pt.pts);\n var sliceTextGroup = sliceTop.selectAll('g.slicetext')\n .data(pt.text && (textPosition !== 'none') ? [0] : []);\n\n sliceTextGroup.enter().append('g')\n .classed('slicetext', true);\n sliceTextGroup.exit().remove();\n\n sliceTextGroup.each(function() {\n var sliceText = Lib.ensureSingle(d3.select(this), 'text', '', function(s) {\n // prohibit tex interpretation until we can handle\n // tex and regular text together\n s.attr('data-notex', 1);\n });\n\n var font = Lib.ensureUniformFontSize(gd, textPosition === 'outside' ?\n determineOutsideTextFont(trace, pt, fullLayout.font) :\n determineInsideTextFont(trace, pt, fullLayout.font)\n );\n\n sliceText.text(pt.text)\n .attr({\n class: 'slicetext',\n transform: '',\n 'text-anchor': 'middle'\n })\n .call(Drawing.font, font)\n .call(svgTextUtils.convertToTspans, gd);\n\n // position the text relative to the slice\n var textBB = Drawing.bBox(sliceText.node());\n var transform;\n\n if(textPosition === 'outside') {\n transform = transformOutsideText(textBB, pt);\n } else {\n transform = transformInsideText(textBB, pt, cd0);\n if(textPosition === 'auto' && transform.scale < 1) {\n var newFont = Lib.ensureUniformFontSize(gd, trace.outsidetextfont);\n\n sliceText.call(Drawing.font, newFont);\n textBB = Drawing.bBox(sliceText.node());\n\n transform = transformOutsideText(textBB, pt);\n }\n }\n\n var textPosAngle = transform.textPosAngle;\n var textXY = textPosAngle === undefined ? pt.pxmid : getCoords(cd0.r, textPosAngle);\n transform.targetX = cx + textXY[0] * transform.rCenter + (transform.x || 0);\n transform.targetY = cy + textXY[1] * transform.rCenter + (transform.y || 0);\n computeTransform(transform, textBB);\n\n // save some stuff to use later ensure no labels overlap\n if(transform.outside) {\n var targetY = transform.targetY;\n pt.yLabelMin = targetY - textBB.height / 2;\n pt.yLabelMid = targetY;\n pt.yLabelMax = targetY + textBB.height / 2;\n pt.labelExtraX = 0;\n pt.labelExtraY = 0;\n hasOutsideText = true;\n }\n\n transform.fontSize = font.size;\n recordMinTextSize(trace.type, transform, fullLayout);\n cd[i].transform = transform;\n\n Lib.setTransormAndDisplay(sliceText, transform);\n });\n });\n\n // add the title\n var titleTextGroup = d3.select(this).selectAll('g.titletext')\n .data(trace.title.text ? [0] : []);\n\n titleTextGroup.enter().append('g')\n .classed('titletext', true);\n titleTextGroup.exit().remove();\n\n titleTextGroup.each(function() {\n var titleText = Lib.ensureSingle(d3.select(this), 'text', '', function(s) {\n // prohibit tex interpretation as above\n s.attr('data-notex', 1);\n });\n\n var txt = trace.title.text;\n if(trace._meta) {\n txt = Lib.templateString(txt, trace._meta);\n }\n\n titleText.text(txt)\n .attr({\n class: 'titletext',\n transform: '',\n 'text-anchor': 'middle',\n })\n .call(Drawing.font, trace.title.font)\n .call(svgTextUtils.convertToTspans, gd);\n\n var transform;\n\n if(trace.title.position === 'middle center') {\n transform = positionTitleInside(cd0);\n } else {\n transform = positionTitleOutside(cd0, gs);\n }\n\n titleText.attr('transform',\n strTranslate(transform.x, transform.y) +\n strScale(Math.min(1, transform.scale)) +\n strTranslate(transform.tx, transform.ty));\n });\n\n // now make sure no labels overlap (at least within one pie)\n if(hasOutsideText) scootLabels(quadrants, trace);\n\n plotTextLines(slices, trace);\n\n if(hasOutsideText && trace.automargin) {\n // TODO if we ever want to improve perf,\n // we could reuse the textBB computed above together\n // with the sliceText transform info\n var traceBbox = Drawing.bBox(plotGroup.node());\n\n var domain = trace.domain;\n var vpw = gs.w * (domain.x[1] - domain.x[0]);\n var vph = gs.h * (domain.y[1] - domain.y[0]);\n var xgap = (0.5 * vpw - cd0.r) / gs.w;\n var ygap = (0.5 * vph - cd0.r) / gs.h;\n\n Plots.autoMargin(gd, 'pie.' + trace.uid + '.automargin', {\n xl: domain.x[0] - xgap,\n xr: domain.x[1] + xgap,\n yb: domain.y[0] - ygap,\n yt: domain.y[1] + ygap,\n l: Math.max(cd0.cx - cd0.r - traceBbox.left, 0),\n r: Math.max(traceBbox.right - (cd0.cx + cd0.r), 0),\n b: Math.max(traceBbox.bottom - (cd0.cy + cd0.r), 0),\n t: Math.max(cd0.cy - cd0.r - traceBbox.top, 0),\n pad: 5\n });\n }\n });\n });\n\n // This is for a bug in Chrome (as of 2015-07-22, and does not affect FF)\n // if insidetextfont and outsidetextfont are different sizes, sometimes the size\n // of an \"em\" gets taken from the wrong element at first so lines are\n // spaced wrong. You just have to tell it to try again later and it gets fixed.\n // I have no idea why we haven't seen this in other contexts. Also, sometimes\n // it gets the initial draw correct but on redraw it gets confused.\n setTimeout(function() {\n plotGroups.selectAll('tspan').each(function() {\n var s = d3.select(this);\n if(s.attr('dy')) s.attr('dy', s.attr('dy'));\n });\n }, 0);\n}\n\n// TODO add support for transition\nfunction plotTextLines(slices, trace) {\n slices.each(function(pt) {\n var sliceTop = d3.select(this);\n\n if(!pt.labelExtraX && !pt.labelExtraY) {\n sliceTop.select('path.textline').remove();\n return;\n }\n\n // first move the text to its new location\n var sliceText = sliceTop.select('g.slicetext text');\n\n pt.transform.targetX += pt.labelExtraX;\n pt.transform.targetY += pt.labelExtraY;\n\n Lib.setTransormAndDisplay(sliceText, pt.transform);\n\n // then add a line to the new location\n var lineStartX = pt.cxFinal + pt.pxmid[0];\n var lineStartY = pt.cyFinal + pt.pxmid[1];\n var textLinePath = 'M' + lineStartX + ',' + lineStartY;\n var finalX = (pt.yLabelMax - pt.yLabelMin) * (pt.pxmid[0] < 0 ? -1 : 1) / 4;\n\n if(pt.labelExtraX) {\n var yFromX = pt.labelExtraX * pt.pxmid[1] / pt.pxmid[0];\n var yNet = pt.yLabelMid + pt.labelExtraY - (pt.cyFinal + pt.pxmid[1]);\n\n if(Math.abs(yFromX) > Math.abs(yNet)) {\n textLinePath +=\n 'l' + (yNet * pt.pxmid[0] / pt.pxmid[1]) + ',' + yNet +\n 'H' + (lineStartX + pt.labelExtraX + finalX);\n } else {\n textLinePath += 'l' + pt.labelExtraX + ',' + yFromX +\n 'v' + (yNet - yFromX) +\n 'h' + finalX;\n }\n } else {\n textLinePath +=\n 'V' + (pt.yLabelMid + pt.labelExtraY) +\n 'h' + finalX;\n }\n\n Lib.ensureSingle(sliceTop, 'path', 'textline')\n .call(Color.stroke, trace.outsidetextfont.color)\n .attr({\n 'stroke-width': Math.min(2, trace.outsidetextfont.size / 8),\n d: textLinePath,\n fill: 'none'\n });\n });\n}\n\nfunction attachFxHandlers(sliceTop, gd, cd) {\n var cd0 = cd[0];\n var cx = cd0.cx;\n var cy = cd0.cy;\n var trace = cd0.trace;\n var isFunnelArea = trace.type === 'funnelarea';\n\n // hover state vars\n // have we drawn a hover label, so it should be cleared later\n if(!('_hasHoverLabel' in trace)) trace._hasHoverLabel = false;\n // have we emitted a hover event, so later an unhover event should be emitted\n // note that click events do not depend on this - you can still get them\n // with hovermode: false or if you were earlier dragging, then clicked\n // in the same slice that you moused up in\n if(!('_hasHoverEvent' in trace)) trace._hasHoverEvent = false;\n\n sliceTop.on('mouseover', function(pt) {\n // in case fullLayout or fullData has changed without a replot\n var fullLayout2 = gd._fullLayout;\n var trace2 = gd._fullData[trace.index];\n\n if(gd._dragging || fullLayout2.hovermode === false) return;\n\n var hoverinfo = trace2.hoverinfo;\n if(Array.isArray(hoverinfo)) {\n // super hacky: we need to pull out the *first* hoverinfo from\n // pt.pts, then put it back into an array in a dummy trace\n // and call castHoverinfo on that.\n // TODO: do we want to have Fx.castHoverinfo somehow handle this?\n // it already takes an array for index, for 2D, so this seems tricky.\n hoverinfo = Fx.castHoverinfo({\n hoverinfo: [helpers.castOption(hoverinfo, pt.pts)],\n _module: trace._module\n }, fullLayout2, 0);\n }\n\n if(hoverinfo === 'all') hoverinfo = 'label+text+value+percent+name';\n\n // in case we dragged over the pie from another subplot,\n // or if hover is turned off\n if(trace2.hovertemplate || (hoverinfo !== 'none' && hoverinfo !== 'skip' && hoverinfo)) {\n var rInscribed = pt.rInscribed || 0;\n var hoverCenterX = cx + pt.pxmid[0] * (1 - rInscribed);\n var hoverCenterY = cy + pt.pxmid[1] * (1 - rInscribed);\n var separators = fullLayout2.separators;\n var text = [];\n\n if(hoverinfo && hoverinfo.indexOf('label') !== -1) text.push(pt.label);\n pt.text = helpers.castOption(trace2.hovertext || trace2.text, pt.pts);\n if(hoverinfo && hoverinfo.indexOf('text') !== -1) {\n var tx = pt.text;\n if(Lib.isValidTextValue(tx)) text.push(tx);\n }\n pt.value = pt.v;\n pt.valueLabel = helpers.formatPieValue(pt.v, separators);\n if(hoverinfo && hoverinfo.indexOf('value') !== -1) text.push(pt.valueLabel);\n pt.percent = pt.v / cd0.vTotal;\n pt.percentLabel = helpers.formatPiePercent(pt.percent, separators);\n if(hoverinfo && hoverinfo.indexOf('percent') !== -1) text.push(pt.percentLabel);\n\n var hoverLabel = trace2.hoverlabel;\n var hoverFont = hoverLabel.font;\n\n var bbox = [];\n Fx.loneHover({\n trace: trace,\n x0: hoverCenterX - rInscribed * cd0.r,\n x1: hoverCenterX + rInscribed * cd0.r,\n y: hoverCenterY,\n _x0: isFunnelArea ? cx + pt.TL[0] : hoverCenterX - rInscribed * cd0.r,\n _x1: isFunnelArea ? cx + pt.TR[0] : hoverCenterX + rInscribed * cd0.r,\n _y0: isFunnelArea ? cy + pt.TL[1] : hoverCenterY - rInscribed * cd0.r,\n _y1: isFunnelArea ? cy + pt.BL[1] : hoverCenterY + rInscribed * cd0.r,\n text: text.join('
'),\n name: (trace2.hovertemplate || hoverinfo.indexOf('name') !== -1) ? trace2.name : undefined,\n idealAlign: pt.pxmid[0] < 0 ? 'left' : 'right',\n color: helpers.castOption(hoverLabel.bgcolor, pt.pts) || pt.color,\n borderColor: helpers.castOption(hoverLabel.bordercolor, pt.pts),\n fontFamily: helpers.castOption(hoverFont.family, pt.pts),\n fontSize: helpers.castOption(hoverFont.size, pt.pts),\n fontColor: helpers.castOption(hoverFont.color, pt.pts),\n nameLength: helpers.castOption(hoverLabel.namelength, pt.pts),\n textAlign: helpers.castOption(hoverLabel.align, pt.pts),\n hovertemplate: helpers.castOption(trace2.hovertemplate, pt.pts),\n hovertemplateLabels: pt,\n eventData: [eventData(pt, trace2)]\n }, {\n container: fullLayout2._hoverlayer.node(),\n outerContainer: fullLayout2._paper.node(),\n gd: gd,\n inOut_bbox: bbox\n });\n pt.bbox = bbox[0];\n\n trace._hasHoverLabel = true;\n }\n\n trace._hasHoverEvent = true;\n gd.emit('plotly_hover', {\n points: [eventData(pt, trace2)],\n event: d3.event\n });\n });\n\n sliceTop.on('mouseout', function(evt) {\n var fullLayout2 = gd._fullLayout;\n var trace2 = gd._fullData[trace.index];\n var pt = d3.select(this).datum();\n\n if(trace._hasHoverEvent) {\n evt.originalEvent = d3.event;\n gd.emit('plotly_unhover', {\n points: [eventData(pt, trace2)],\n event: d3.event\n });\n trace._hasHoverEvent = false;\n }\n\n if(trace._hasHoverLabel) {\n Fx.loneUnhover(fullLayout2._hoverlayer.node());\n trace._hasHoverLabel = false;\n }\n });\n\n sliceTop.on('click', function(pt) {\n // TODO: this does not support right-click. If we want to support it, we\n // would likely need to change pie to use dragElement instead of straight\n // map subplot event binding. Or perhaps better, make a simple wrapper with the\n // right mousedown, mousemove, and mouseup handlers just for a left/right click\n // map subplots would use this too.\n var fullLayout2 = gd._fullLayout;\n var trace2 = gd._fullData[trace.index];\n\n if(gd._dragging || fullLayout2.hovermode === false) return;\n\n gd._hoverdata = [eventData(pt, trace2)];\n Fx.click(gd, d3.event);\n });\n}\n\nfunction determineOutsideTextFont(trace, pt, layoutFont) {\n var color =\n helpers.castOption(trace.outsidetextfont.color, pt.pts) ||\n helpers.castOption(trace.textfont.color, pt.pts) ||\n layoutFont.color;\n\n var family =\n helpers.castOption(trace.outsidetextfont.family, pt.pts) ||\n helpers.castOption(trace.textfont.family, pt.pts) ||\n layoutFont.family;\n\n var size =\n helpers.castOption(trace.outsidetextfont.size, pt.pts) ||\n helpers.castOption(trace.textfont.size, pt.pts) ||\n layoutFont.size;\n\n var weight =\n helpers.castOption(trace.outsidetextfont.weight, pt.pts) ||\n helpers.castOption(trace.textfont.weight, pt.pts) ||\n layoutFont.weight;\n\n var style =\n helpers.castOption(trace.outsidetextfont.style, pt.pts) ||\n helpers.castOption(trace.textfont.style, pt.pts) ||\n layoutFont.style;\n\n var variant =\n helpers.castOption(trace.outsidetextfont.variant, pt.pts) ||\n helpers.castOption(trace.textfont.variant, pt.pts) ||\n layoutFont.variant;\n\n var textcase =\n helpers.castOption(trace.outsidetextfont.textcase, pt.pts) ||\n helpers.castOption(trace.textfont.textcase, pt.pts) ||\n layoutFont.textcase;\n\n var lineposition =\n helpers.castOption(trace.outsidetextfont.lineposition, pt.pts) ||\n helpers.castOption(trace.textfont.lineposition, pt.pts) ||\n layoutFont.lineposition;\n\n var shadow =\n helpers.castOption(trace.outsidetextfont.shadow, pt.pts) ||\n helpers.castOption(trace.textfont.shadow, pt.pts) ||\n layoutFont.shadow;\n\n return {\n color: color,\n family: family,\n size: size,\n weight: weight,\n style: style,\n variant: variant,\n textcase: textcase,\n lineposition: lineposition,\n shadow: shadow,\n };\n}\n\nfunction determineInsideTextFont(trace, pt, layoutFont) {\n var customColor = helpers.castOption(trace.insidetextfont.color, pt.pts);\n if(!customColor && trace._input.textfont) {\n // Why not simply using trace.textfont? Because if not set, it\n // defaults to layout.font which has a default color. But if\n // textfont.color and insidetextfont.color don't supply a value,\n // a contrasting color shall be used.\n customColor = helpers.castOption(trace._input.textfont.color, pt.pts);\n }\n\n var family =\n helpers.castOption(trace.insidetextfont.family, pt.pts) ||\n helpers.castOption(trace.textfont.family, pt.pts) ||\n layoutFont.family;\n\n var size =\n helpers.castOption(trace.insidetextfont.size, pt.pts) ||\n helpers.castOption(trace.textfont.size, pt.pts) ||\n layoutFont.size;\n\n var weight =\n helpers.castOption(trace.insidetextfont.weight, pt.pts) ||\n helpers.castOption(trace.textfont.weight, pt.pts) ||\n layoutFont.weight;\n\n var style =\n helpers.castOption(trace.insidetextfont.style, pt.pts) ||\n helpers.castOption(trace.textfont.style, pt.pts) ||\n layoutFont.style;\n\n var variant =\n helpers.castOption(trace.insidetextfont.variant, pt.pts) ||\n helpers.castOption(trace.textfont.variant, pt.pts) ||\n layoutFont.variant;\n\n var textcase =\n helpers.castOption(trace.insidetextfont.textcase, pt.pts) ||\n helpers.castOption(trace.textfont.textcase, pt.pts) ||\n layoutFont.textcase;\n\n var lineposition =\n helpers.castOption(trace.insidetextfont.lineposition, pt.pts) ||\n helpers.castOption(trace.textfont.lineposition, pt.pts) ||\n layoutFont.lineposition;\n\n var shadow =\n helpers.castOption(trace.insidetextfont.shadow, pt.pts) ||\n helpers.castOption(trace.textfont.shadow, pt.pts) ||\n layoutFont.shadow;\n\n return {\n color: customColor || Color.contrast(pt.color),\n family: family,\n size: size,\n weight: weight,\n style: style,\n variant: variant,\n textcase: textcase,\n lineposition: lineposition,\n shadow: shadow,\n };\n}\n\nfunction prerenderTitles(cdModule, gd) {\n var cd0, trace;\n\n // Determine the width and height of the title for each pie.\n for(var i = 0; i < cdModule.length; i++) {\n cd0 = cdModule[i][0];\n trace = cd0.trace;\n\n if(trace.title.text) {\n var txt = trace.title.text;\n if(trace._meta) {\n txt = Lib.templateString(txt, trace._meta);\n }\n\n var dummyTitle = Drawing.tester.append('text')\n .attr('data-notex', 1)\n .text(txt)\n .call(Drawing.font, trace.title.font)\n .call(svgTextUtils.convertToTspans, gd);\n var bBox = Drawing.bBox(dummyTitle.node(), true);\n cd0.titleBox = {\n width: bBox.width,\n height: bBox.height,\n };\n dummyTitle.remove();\n }\n }\n}\n\nfunction transformInsideText(textBB, pt, cd0) {\n var r = cd0.r || pt.rpx1;\n var rInscribed = pt.rInscribed;\n\n var isEmpty = pt.startangle === pt.stopangle;\n if(isEmpty) {\n return {\n rCenter: 1 - rInscribed,\n scale: 0,\n rotate: 0,\n textPosAngle: 0\n };\n }\n\n var ring = pt.ring;\n var isCircle = (ring === 1) && (Math.abs(pt.startangle - pt.stopangle) === Math.PI * 2);\n\n var halfAngle = pt.halfangle;\n var midAngle = pt.midangle;\n\n var orientation = cd0.trace.insidetextorientation;\n var isHorizontal = orientation === 'horizontal';\n var isTangential = orientation === 'tangential';\n var isRadial = orientation === 'radial';\n var isAuto = orientation === 'auto';\n\n var allTransforms = [];\n var newT;\n\n if(!isAuto) {\n // max size if text is placed (horizontally) at the top or bottom of the arc\n\n var considerCrossing = function(angle, key) {\n if(isCrossing(pt, angle)) {\n var dStart = Math.abs(angle - pt.startangle);\n var dStop = Math.abs(angle - pt.stopangle);\n\n var closestEdge = dStart < dStop ? dStart : dStop;\n\n if(key === 'tan') {\n newT = calcTanTransform(textBB, r, ring, closestEdge, 0);\n } else { // case of 'rad'\n newT = calcRadTransform(textBB, r, ring, closestEdge, Math.PI / 2);\n }\n newT.textPosAngle = angle;\n\n allTransforms.push(newT);\n }\n };\n\n // to cover all cases with trace.rotation added\n var i;\n if(isHorizontal || isTangential) {\n // top\n for(i = 4; i >= -4; i -= 2) considerCrossing(Math.PI * i, 'tan');\n // bottom\n for(i = 4; i >= -4; i -= 2) considerCrossing(Math.PI * (i + 1), 'tan');\n }\n if(isHorizontal || isRadial) {\n // left\n for(i = 4; i >= -4; i -= 2) considerCrossing(Math.PI * (i + 1.5), 'rad');\n // right\n for(i = 4; i >= -4; i -= 2) considerCrossing(Math.PI * (i + 0.5), 'rad');\n }\n }\n\n if(isCircle || isAuto || isHorizontal) {\n // max size text can be inserted inside without rotating it\n // this inscribes the text rectangle in a circle, which is then inscribed\n // in the slice, so it will be an underestimate, which some day we may want\n // to improve so this case can get more use\n var textDiameter = Math.sqrt(textBB.width * textBB.width + textBB.height * textBB.height);\n\n newT = {\n scale: rInscribed * r * 2 / textDiameter,\n\n // and the center position and rotation in this case\n rCenter: 1 - rInscribed,\n rotate: 0\n };\n\n newT.textPosAngle = (pt.startangle + pt.stopangle) / 2;\n if(newT.scale >= 1) return newT;\n\n allTransforms.push(newT);\n }\n\n if(isAuto || isRadial) {\n newT = calcRadTransform(textBB, r, ring, halfAngle, midAngle);\n newT.textPosAngle = (pt.startangle + pt.stopangle) / 2;\n allTransforms.push(newT);\n }\n\n if(isAuto || isTangential) {\n newT = calcTanTransform(textBB, r, ring, halfAngle, midAngle);\n newT.textPosAngle = (pt.startangle + pt.stopangle) / 2;\n allTransforms.push(newT);\n }\n\n var id = 0;\n var maxScale = 0;\n for(var k = 0; k < allTransforms.length; k++) {\n var s = allTransforms[k].scale;\n if(maxScale < s) {\n maxScale = s;\n id = k;\n }\n\n if(!isAuto && maxScale >= 1) {\n // respect test order for non-auto options\n break;\n }\n }\n return allTransforms[id];\n}\n\nfunction isCrossing(pt, angle) {\n var start = pt.startangle;\n var stop = pt.stopangle;\n return (\n (start > angle && angle > stop) ||\n (start < angle && angle < stop)\n );\n}\n\nfunction calcRadTransform(textBB, r, ring, halfAngle, midAngle) {\n r = Math.max(0, r - 2 * TEXTPAD);\n\n // max size if text is rotated radially\n var a = textBB.width / textBB.height;\n var s = calcMaxHalfSize(a, halfAngle, r, ring);\n return {\n scale: s * 2 / textBB.height,\n rCenter: calcRCenter(a, s / r),\n rotate: calcRotate(midAngle)\n };\n}\n\nfunction calcTanTransform(textBB, r, ring, halfAngle, midAngle) {\n r = Math.max(0, r - 2 * TEXTPAD);\n\n // max size if text is rotated tangentially\n var a = textBB.height / textBB.width;\n var s = calcMaxHalfSize(a, halfAngle, r, ring);\n return {\n scale: s * 2 / textBB.width,\n rCenter: calcRCenter(a, s / r),\n rotate: calcRotate(midAngle + Math.PI / 2)\n };\n}\n\nfunction calcRCenter(a, b) {\n return Math.cos(b) - a * b;\n}\n\nfunction calcRotate(t) {\n return (180 / Math.PI * t + 720) % 180 - 90;\n}\n\nfunction calcMaxHalfSize(a, halfAngle, r, ring) {\n var q = a + 1 / (2 * Math.tan(halfAngle));\n return r * Math.min(\n 1 / (Math.sqrt(q * q + 0.5) + q),\n ring / (Math.sqrt(a * a + ring / 2) + a)\n );\n}\n\nfunction getInscribedRadiusFraction(pt, cd0) {\n if(pt.v === cd0.vTotal && !cd0.trace.hole) return 1;// special case of 100% with no hole\n\n return Math.min(1 / (1 + 1 / Math.sin(pt.halfangle)), pt.ring / 2);\n}\n\nfunction transformOutsideText(textBB, pt) {\n var x = pt.pxmid[0];\n var y = pt.pxmid[1];\n var dx = textBB.width / 2;\n var dy = textBB.height / 2;\n\n if(x < 0) dx *= -1;\n if(y < 0) dy *= -1;\n\n return {\n scale: 1,\n rCenter: 1,\n rotate: 0,\n x: dx + Math.abs(dy) * (dx > 0 ? 1 : -1) / 2,\n y: dy / (1 + x * x / (y * y)),\n outside: true\n };\n}\n\nfunction positionTitleInside(cd0) {\n var textDiameter =\n Math.sqrt(cd0.titleBox.width * cd0.titleBox.width + cd0.titleBox.height * cd0.titleBox.height);\n return {\n x: cd0.cx,\n y: cd0.cy,\n scale: cd0.trace.hole * cd0.r * 2 / textDiameter,\n tx: 0,\n ty: - cd0.titleBox.height / 2 + cd0.trace.title.font.size\n };\n}\n\nfunction positionTitleOutside(cd0, plotSize) {\n var scaleX = 1;\n var scaleY = 1;\n var maxPull;\n\n var trace = cd0.trace;\n // position of the baseline point of the text box in the plot, before scaling.\n // we anchored the text in the middle, so the baseline is on the bottom middle\n // of the first line of text.\n var topMiddle = {\n x: cd0.cx,\n y: cd0.cy\n };\n // relative translation of the text box after scaling\n var translate = {\n tx: 0,\n ty: 0\n };\n\n // we reason below as if the baseline is the top middle point of the text box.\n // so we must add the font size to approximate the y-coord. of the top.\n // note that this correction must happen after scaling.\n translate.ty += trace.title.font.size;\n maxPull = getMaxPull(trace);\n\n if(trace.title.position.indexOf('top') !== -1) {\n topMiddle.y -= (1 + maxPull) * cd0.r;\n translate.ty -= cd0.titleBox.height;\n } else if(trace.title.position.indexOf('bottom') !== -1) {\n topMiddle.y += (1 + maxPull) * cd0.r;\n }\n\n var rx = applyAspectRatio(cd0.r, cd0.trace.aspectratio);\n\n var maxWidth = plotSize.w * (trace.domain.x[1] - trace.domain.x[0]) / 2;\n if(trace.title.position.indexOf('left') !== -1) {\n // we start the text at the left edge of the pie\n maxWidth = maxWidth + rx;\n topMiddle.x -= (1 + maxPull) * rx;\n translate.tx += cd0.titleBox.width / 2;\n } else if(trace.title.position.indexOf('center') !== -1) {\n maxWidth *= 2;\n } else if(trace.title.position.indexOf('right') !== -1) {\n maxWidth = maxWidth + rx;\n topMiddle.x += (1 + maxPull) * rx;\n translate.tx -= cd0.titleBox.width / 2;\n }\n scaleX = maxWidth / cd0.titleBox.width;\n scaleY = getTitleSpace(cd0, plotSize) / cd0.titleBox.height;\n return {\n x: topMiddle.x,\n y: topMiddle.y,\n scale: Math.min(scaleX, scaleY),\n tx: translate.tx,\n ty: translate.ty\n };\n}\n\nfunction applyAspectRatio(x, aspectratio) {\n return x / ((aspectratio === undefined) ? 1 : aspectratio);\n}\n\nfunction getTitleSpace(cd0, plotSize) {\n var trace = cd0.trace;\n var pieBoxHeight = plotSize.h * (trace.domain.y[1] - trace.domain.y[0]);\n // use at most half of the plot for the title\n return Math.min(cd0.titleBox.height, pieBoxHeight / 2);\n}\n\nfunction getMaxPull(trace) {\n var maxPull = trace.pull;\n if(!maxPull) return 0;\n\n var j;\n if(Lib.isArrayOrTypedArray(maxPull)) {\n maxPull = 0;\n for(j = 0; j < trace.pull.length; j++) {\n if(trace.pull[j] > maxPull) maxPull = trace.pull[j];\n }\n }\n return maxPull;\n}\n\nfunction scootLabels(quadrants, trace) {\n var xHalf, yHalf, equatorFirst, farthestX, farthestY,\n xDiffSign, yDiffSign, thisQuad, oppositeQuad,\n wholeSide, i, thisQuadOutside, firstOppositeOutsidePt;\n\n function topFirst(a, b) { return a.pxmid[1] - b.pxmid[1]; }\n function bottomFirst(a, b) { return b.pxmid[1] - a.pxmid[1]; }\n\n function scootOneLabel(thisPt, prevPt) {\n if(!prevPt) prevPt = {};\n\n var prevOuterY = prevPt.labelExtraY + (yHalf ? prevPt.yLabelMax : prevPt.yLabelMin);\n var thisInnerY = yHalf ? thisPt.yLabelMin : thisPt.yLabelMax;\n var thisOuterY = yHalf ? thisPt.yLabelMax : thisPt.yLabelMin;\n var thisSliceOuterY = thisPt.cyFinal + farthestY(thisPt.px0[1], thisPt.px1[1]);\n var newExtraY = prevOuterY - thisInnerY;\n\n var xBuffer, i, otherPt, otherOuterY, otherOuterX, newExtraX;\n\n // make sure this label doesn't overlap other labels\n // this *only* has us move these labels vertically\n if(newExtraY * yDiffSign > 0) thisPt.labelExtraY = newExtraY;\n\n // make sure this label doesn't overlap any slices\n if(!Lib.isArrayOrTypedArray(trace.pull)) return; // this can only happen with array pulls\n\n for(i = 0; i < wholeSide.length; i++) {\n otherPt = wholeSide[i];\n\n // overlap can only happen if the other point is pulled more than this one\n if(otherPt === thisPt || (\n (helpers.castOption(trace.pull, thisPt.pts) || 0) >=\n (helpers.castOption(trace.pull, otherPt.pts) || 0))\n ) {\n continue;\n }\n\n if((thisPt.pxmid[1] - otherPt.pxmid[1]) * yDiffSign > 0) {\n // closer to the equator - by construction all of these happen first\n // move the text vertically to get away from these slices\n otherOuterY = otherPt.cyFinal + farthestY(otherPt.px0[1], otherPt.px1[1]);\n newExtraY = otherOuterY - thisInnerY - thisPt.labelExtraY;\n\n if(newExtraY * yDiffSign > 0) thisPt.labelExtraY += newExtraY;\n } else if((thisOuterY + thisPt.labelExtraY - thisSliceOuterY) * yDiffSign > 0) {\n // farther from the equator - happens after we've done all the\n // vertical moving we're going to do\n // move horizontally to get away from these more polar slices\n\n // if we're moving horz. based on a slice that's several slices away from this one\n // then we need some extra space for the lines to labels between them\n xBuffer = 3 * xDiffSign * Math.abs(i - wholeSide.indexOf(thisPt));\n\n otherOuterX = otherPt.cxFinal + farthestX(otherPt.px0[0], otherPt.px1[0]);\n newExtraX = otherOuterX + xBuffer - (thisPt.cxFinal + thisPt.pxmid[0]) - thisPt.labelExtraX;\n\n if(newExtraX * xDiffSign > 0) thisPt.labelExtraX += newExtraX;\n }\n }\n }\n\n for(yHalf = 0; yHalf < 2; yHalf++) {\n equatorFirst = yHalf ? topFirst : bottomFirst;\n farthestY = yHalf ? Math.max : Math.min;\n yDiffSign = yHalf ? 1 : -1;\n\n for(xHalf = 0; xHalf < 2; xHalf++) {\n farthestX = xHalf ? Math.max : Math.min;\n xDiffSign = xHalf ? 1 : -1;\n\n // first sort the array\n // note this is a copy of cd, so cd itself doesn't get sorted\n // but we can still modify points in place.\n thisQuad = quadrants[yHalf][xHalf];\n thisQuad.sort(equatorFirst);\n\n oppositeQuad = quadrants[1 - yHalf][xHalf];\n wholeSide = oppositeQuad.concat(thisQuad);\n\n thisQuadOutside = [];\n for(i = 0; i < thisQuad.length; i++) {\n if(thisQuad[i].yLabelMid !== undefined) thisQuadOutside.push(thisQuad[i]);\n }\n\n firstOppositeOutsidePt = false;\n for(i = 0; yHalf && i < oppositeQuad.length; i++) {\n if(oppositeQuad[i].yLabelMid !== undefined) {\n firstOppositeOutsidePt = oppositeQuad[i];\n break;\n }\n }\n\n // each needs to avoid the previous\n for(i = 0; i < thisQuadOutside.length; i++) {\n var prevPt = i && thisQuadOutside[i - 1];\n // bottom half needs to avoid the first label of the top half\n // top half we still need to call scootOneLabel on the first slice\n // so we can avoid other slices, but we don't pass a prevPt\n if(firstOppositeOutsidePt && !i) prevPt = firstOppositeOutsidePt;\n scootOneLabel(thisQuadOutside[i], prevPt);\n }\n }\n }\n}\n\nfunction layoutAreas(cdModule, plotSize) {\n var scaleGroups = [];\n\n // figure out the center and maximum radius\n for(var i = 0; i < cdModule.length; i++) {\n var cd0 = cdModule[i][0];\n var trace = cd0.trace;\n\n var domain = trace.domain;\n var width = plotSize.w * (domain.x[1] - domain.x[0]);\n var height = plotSize.h * (domain.y[1] - domain.y[0]);\n // leave some space for the title, if it will be displayed outside\n if(trace.title.text && trace.title.position !== 'middle center') {\n height -= getTitleSpace(cd0, plotSize);\n }\n\n var rx = width / 2;\n var ry = height / 2;\n if(trace.type === 'funnelarea' && !trace.scalegroup) {\n ry /= trace.aspectratio;\n }\n\n cd0.r = Math.min(rx, ry) / (1 + getMaxPull(trace));\n\n cd0.cx = plotSize.l + plotSize.w * (trace.domain.x[1] + trace.domain.x[0]) / 2;\n cd0.cy = plotSize.t + plotSize.h * (1 - trace.domain.y[0]) - height / 2;\n if(trace.title.text && trace.title.position.indexOf('bottom') !== -1) {\n cd0.cy -= getTitleSpace(cd0, plotSize);\n }\n\n if(trace.scalegroup && scaleGroups.indexOf(trace.scalegroup) === -1) {\n scaleGroups.push(trace.scalegroup);\n }\n }\n\n groupScale(cdModule, scaleGroups);\n}\n\nfunction groupScale(cdModule, scaleGroups) {\n var cd0, i, trace;\n\n // scale those that are grouped\n for(var k = 0; k < scaleGroups.length; k++) {\n var min = Infinity;\n var g = scaleGroups[k];\n\n for(i = 0; i < cdModule.length; i++) {\n cd0 = cdModule[i][0];\n trace = cd0.trace;\n\n if(trace.scalegroup === g) {\n var area;\n if(trace.type === 'pie') {\n area = cd0.r * cd0.r;\n } else if(trace.type === 'funnelarea') {\n var rx, ry;\n\n if(trace.aspectratio > 1) {\n rx = cd0.r;\n ry = rx / trace.aspectratio;\n } else {\n ry = cd0.r;\n rx = ry * trace.aspectratio;\n }\n\n rx *= (1 + trace.baseratio) / 2;\n\n area = rx * ry;\n }\n\n min = Math.min(min, area / cd0.vTotal);\n }\n }\n\n for(i = 0; i < cdModule.length; i++) {\n cd0 = cdModule[i][0];\n trace = cd0.trace;\n if(trace.scalegroup === g) {\n var v = min * cd0.vTotal;\n if(trace.type === 'funnelarea') {\n v /= (1 + trace.baseratio) / 2;\n v /= trace.aspectratio;\n }\n\n cd0.r = Math.sqrt(v);\n }\n }\n }\n}\n\nfunction setCoords(cd) {\n var cd0 = cd[0];\n var r = cd0.r;\n var trace = cd0.trace;\n var currentAngle = helpers.getRotationAngle(trace.rotation);\n var angleFactor = 2 * Math.PI / cd0.vTotal;\n var firstPt = 'px0';\n var lastPt = 'px1';\n\n var i, cdi, currentCoords;\n\n if(trace.direction === 'counterclockwise') {\n for(i = 0; i < cd.length; i++) {\n if(!cd[i].hidden) break; // find the first non-hidden slice\n }\n if(i === cd.length) return; // all slices hidden\n\n currentAngle += angleFactor * cd[i].v;\n angleFactor *= -1;\n firstPt = 'px1';\n lastPt = 'px0';\n }\n\n currentCoords = getCoords(r, currentAngle);\n\n for(i = 0; i < cd.length; i++) {\n cdi = cd[i];\n if(cdi.hidden) continue;\n\n cdi[firstPt] = currentCoords;\n\n cdi.startangle = currentAngle;\n currentAngle += angleFactor * cdi.v / 2;\n cdi.pxmid = getCoords(r, currentAngle);\n cdi.midangle = currentAngle;\n currentAngle += angleFactor * cdi.v / 2;\n currentCoords = getCoords(r, currentAngle);\n cdi.stopangle = currentAngle;\n\n cdi[lastPt] = currentCoords;\n\n cdi.largeArc = (cdi.v > cd0.vTotal / 2) ? 1 : 0;\n\n cdi.halfangle = Math.PI * Math.min(cdi.v / cd0.vTotal, 0.5);\n cdi.ring = 1 - trace.hole;\n cdi.rInscribed = getInscribedRadiusFraction(cdi, cd0);\n }\n}\n\nfunction getCoords(r, angle) {\n return [r * Math.sin(angle), -r * Math.cos(angle)];\n}\n\nfunction formatSliceLabel(gd, pt, cd0) {\n var fullLayout = gd._fullLayout;\n var trace = cd0.trace;\n // look for textemplate\n var texttemplate = trace.texttemplate;\n\n // now insert text\n var textinfo = trace.textinfo;\n if(!texttemplate && textinfo && textinfo !== 'none') {\n var parts = textinfo.split('+');\n var hasFlag = function(flag) { return parts.indexOf(flag) !== -1; };\n var hasLabel = hasFlag('label');\n var hasText = hasFlag('text');\n var hasValue = hasFlag('value');\n var hasPercent = hasFlag('percent');\n\n var separators = fullLayout.separators;\n var text;\n\n text = hasLabel ? [pt.label] : [];\n if(hasText) {\n var tx = helpers.getFirstFilled(trace.text, pt.pts);\n if(isValidTextValue(tx)) text.push(tx);\n }\n if(hasValue) text.push(helpers.formatPieValue(pt.v, separators));\n if(hasPercent) text.push(helpers.formatPiePercent(pt.v / cd0.vTotal, separators));\n pt.text = text.join('
');\n }\n\n function makeTemplateVariables(pt) {\n return {\n label: pt.label,\n value: pt.v,\n valueLabel: helpers.formatPieValue(pt.v, fullLayout.separators),\n percent: pt.v / cd0.vTotal,\n percentLabel: helpers.formatPiePercent(pt.v / cd0.vTotal, fullLayout.separators),\n color: pt.color,\n text: pt.text,\n customdata: Lib.castOption(trace, pt.i, 'customdata')\n };\n }\n\n if(texttemplate) {\n var txt = Lib.castOption(trace, pt.i, 'texttemplate');\n if(!txt) {\n pt.text = '';\n } else {\n var obj = makeTemplateVariables(pt);\n var ptTx = helpers.getFirstFilled(trace.text, pt.pts);\n if(isValidTextValue(ptTx) || ptTx === '') obj.text = ptTx;\n pt.text = Lib.texttemplateString(txt, obj, gd._fullLayout._d3locale, obj, trace._meta || {});\n }\n }\n}\n\nfunction computeTransform(\n transform, // inout\n textBB // in\n) {\n var a = transform.rotate * Math.PI / 180;\n var cosA = Math.cos(a);\n var sinA = Math.sin(a);\n var midX = (textBB.left + textBB.right) / 2;\n var midY = (textBB.top + textBB.bottom) / 2;\n transform.textX = midX * cosA - midY * sinA;\n transform.textY = midX * sinA + midY * cosA;\n transform.noCenter = true;\n}\n\nmodule.exports = {\n plot: plot,\n formatSliceLabel: formatSliceLabel,\n transformInsideText: transformInsideText,\n determineInsideTextFont: determineInsideTextFont,\n positionTitleOutside: positionTitleOutside,\n prerenderTitles: prerenderTitles,\n layoutAreas: layoutAreas,\n attachFxHandlers: attachFxHandlers,\n computeTransform: computeTransform\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar styleOne = require('./style_one');\nvar resizeText = require('../bar/uniform_text').resizeText;\n\nmodule.exports = function style(gd) {\n var s = gd._fullLayout._pielayer.selectAll('.trace');\n resizeText(gd, s, 'pie');\n\n s.each(function(cd) {\n var cd0 = cd[0];\n var trace = cd0.trace;\n var traceSelection = d3.select(this);\n\n traceSelection.style({opacity: trace.opacity});\n\n traceSelection.selectAll('path.surface').each(function(pt) {\n d3.select(this).call(styleOne, pt, trace, gd);\n });\n });\n};\n","'use strict';\n\nvar Color = require('../../components/color');\nvar castOption = require('./helpers').castOption;\nvar fillOne = require('./fill_one');\n\nmodule.exports = function styleOne(s, pt, trace, gd) {\n var line = trace.marker.line;\n var lineColor = castOption(line.color, pt.pts) || Color.defaultLine;\n var lineWidth = castOption(line.width, pt.pts) || 0;\n\n s.call(fillOne, pt, trace, gd)\n .style('stroke-width', lineWidth)\n .call(Color.stroke, lineColor);\n};\n","'use strict';\n\nvar scatterglAttrs = require('../scatter/attributes');\n\nmodule.exports = {\n x: scatterglAttrs.x,\n y: scatterglAttrs.y,\n xy: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Faster alternative to specifying `x` and `y` separately.',\n 'If supplied, it must be a typed `Float32Array` array that',\n 'represents points such that `xy[i * 2] = x[i]` and `xy[i * 2 + 1] = y[i]`'\n ].join(' ')\n },\n indices: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'A sequential value, 0..n, supply it to avoid creating this array inside plotting.',\n 'If specified, it must be a typed `Int32Array` array.',\n 'Its length must be equal to or greater than the number of points.',\n 'For the best performance and memory use, create one large `indices` typed array',\n 'that is guaranteed to be at least as long as the largest number of points during',\n 'use, and reuse it on each `Plotly.restyle()` call.'\n ].join(' ')\n },\n xbounds: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Specify `xbounds` in the shape of `[xMin, xMax] to avoid looping through',\n 'the `xy` typed array. Use it in conjunction with `xy` and `ybounds` for the performance benefits.'\n ].join(' ')\n },\n ybounds: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Specify `ybounds` in the shape of `[yMin, yMax] to avoid looping through',\n 'the `xy` typed array. Use it in conjunction with `xy` and `xbounds` for the performance benefits.'\n ].join(' ')\n },\n text: scatterglAttrs.text,\n marker: {\n color: {\n valType: 'color',\n arrayOk: false,\n\n editType: 'calc',\n description: [\n 'Sets the marker fill color. It accepts a specific color.',\n 'If the color is not fully opaque and there are hundreds of thousands',\n 'of points, it may cause slower zooming and panning.'\n ].join(' ')\n },\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n arrayOk: false,\n\n editType: 'calc',\n description: [\n 'Sets the marker opacity. The default value is `1` (fully opaque).',\n 'If the markers are not fully opaque and there are hundreds of thousands',\n 'of points, it may cause slower zooming and panning.',\n 'Opacity fades the color even if `blend` is left on `false` even if there',\n 'is no translucency effect in that case.'\n ].join(' ')\n },\n blend: {\n valType: 'boolean',\n dflt: null,\n\n editType: 'calc',\n description: [\n 'Determines if colors are blended together for a translucency effect',\n 'in case `opacity` is specified as a value less then `1`.',\n 'Setting `blend` to `true` reduces zoom/pan',\n 'speed if used with large numbers of points.'\n ].join(' ')\n },\n sizemin: {\n valType: 'number',\n min: 0.1,\n max: 2,\n dflt: 0.5,\n\n editType: 'calc',\n description: [\n 'Sets the minimum size (in px) of the rendered marker points, effective when',\n 'the `pointcloud` shows a million or more points.'\n ].join(' ')\n },\n sizemax: {\n valType: 'number',\n min: 0.1,\n dflt: 20,\n\n editType: 'calc',\n description: [\n 'Sets the maximum size (in px) of the rendered marker points.',\n 'Effective when the `pointcloud` shows only few points.'\n ].join(' ')\n },\n border: {\n color: {\n valType: 'color',\n arrayOk: false,\n\n editType: 'calc',\n description: [\n 'Sets the stroke color. It accepts a specific color.',\n 'If the color is not fully opaque and there are hundreds of thousands',\n 'of points, it may cause slower zooming and panning.'\n ].join(' ')\n },\n arearatio: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0,\n\n editType: 'calc',\n description: [\n 'Specifies what fraction of the marker area is covered with the',\n 'border.'\n ].join(' ')\n },\n editType: 'calc'\n },\n editType: 'calc'\n },\n transforms: undefined\n};\n","'use strict';\n\nvar createPointCloudRenderer = require('../../../stackgl_modules').gl_pointcloud2d;\n\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar str2RGBArray = require('../../lib/str2rgbarray');\nvar findExtremes = require('../../plots/cartesian/autorange').findExtremes;\nvar getTraceColor = require('../scatter/get_trace_color');\n\nfunction Pointcloud(scene, uid) {\n this.scene = scene;\n this.uid = uid;\n this.type = 'pointcloud';\n\n this.pickXData = [];\n this.pickYData = [];\n this.xData = [];\n this.yData = [];\n this.textLabels = [];\n this.color = 'rgb(0, 0, 0)';\n this.name = '';\n this.hoverinfo = 'all';\n\n this.idToIndex = new Int32Array(0);\n this.bounds = [0, 0, 0, 0];\n\n this.pointcloudOptions = {\n positions: new Float32Array(0),\n idToIndex: this.idToIndex,\n sizemin: 0.5,\n sizemax: 12,\n color: [0, 0, 0, 1],\n areaRatio: 1,\n borderColor: [0, 0, 0, 1]\n };\n this.pointcloud = createPointCloudRenderer(scene.glplot, this.pointcloudOptions);\n this.pointcloud._trace = this; // scene2d requires this prop\n}\n\nvar proto = Pointcloud.prototype;\n\nproto.handlePick = function(pickResult) {\n var index = this.idToIndex[pickResult.pointId];\n\n // prefer the readout from XY, if present\n return {\n trace: this,\n dataCoord: pickResult.dataCoord,\n traceCoord: this.pickXYData ?\n [this.pickXYData[index * 2], this.pickXYData[index * 2 + 1]] :\n [this.pickXData[index], this.pickYData[index]],\n textLabel: isArrayOrTypedArray(this.textLabels) ?\n this.textLabels[index] :\n this.textLabels,\n color: this.color,\n name: this.name,\n pointIndex: index,\n hoverinfo: this.hoverinfo\n };\n};\n\nproto.update = function(options) {\n this.index = options.index;\n this.textLabels = options.text;\n this.name = options.name;\n this.hoverinfo = options.hoverinfo;\n this.bounds = [Infinity, Infinity, -Infinity, -Infinity];\n\n this.updateFast(options);\n\n this.color = getTraceColor(options, {});\n};\n\nproto.updateFast = function(options) {\n var x = this.xData = this.pickXData = options.x;\n var y = this.yData = this.pickYData = options.y;\n var xy = this.pickXYData = options.xy;\n\n var userBounds = options.xbounds && options.ybounds;\n var index = options.indices;\n\n var len;\n var idToIndex;\n var positions;\n var bounds = this.bounds;\n\n var xx, yy, i;\n\n if(xy) {\n positions = xy;\n\n // dividing xy.length by 2 and truncating to integer if xy.length was not even\n len = xy.length >>> 1;\n\n if(userBounds) {\n bounds[0] = options.xbounds[0];\n bounds[2] = options.xbounds[1];\n bounds[1] = options.ybounds[0];\n bounds[3] = options.ybounds[1];\n } else {\n for(i = 0; i < len; i++) {\n xx = positions[i * 2];\n yy = positions[i * 2 + 1];\n\n if(xx < bounds[0]) bounds[0] = xx;\n if(xx > bounds[2]) bounds[2] = xx;\n if(yy < bounds[1]) bounds[1] = yy;\n if(yy > bounds[3]) bounds[3] = yy;\n }\n }\n\n if(index) {\n idToIndex = index;\n } else {\n idToIndex = new Int32Array(len);\n\n for(i = 0; i < len; i++) {\n idToIndex[i] = i;\n }\n }\n } else {\n len = x.length;\n\n positions = new Float32Array(2 * len);\n idToIndex = new Int32Array(len);\n\n for(i = 0; i < len; i++) {\n xx = x[i];\n yy = y[i];\n\n idToIndex[i] = i;\n\n positions[i * 2] = xx;\n positions[i * 2 + 1] = yy;\n\n if(xx < bounds[0]) bounds[0] = xx;\n if(xx > bounds[2]) bounds[2] = xx;\n if(yy < bounds[1]) bounds[1] = yy;\n if(yy > bounds[3]) bounds[3] = yy;\n }\n }\n\n this.idToIndex = idToIndex;\n this.pointcloudOptions.idToIndex = idToIndex;\n\n this.pointcloudOptions.positions = positions;\n\n var markerColor = str2RGBArray(options.marker.color);\n var borderColor = str2RGBArray(options.marker.border.color);\n var opacity = options.opacity * options.marker.opacity;\n\n markerColor[3] *= opacity;\n this.pointcloudOptions.color = markerColor;\n\n // detect blending from the number of points, if undefined\n // because large data with blending hits performance\n var blend = options.marker.blend;\n if(blend === null) {\n var maxPoints = 100;\n blend = x.length < maxPoints || y.length < maxPoints;\n }\n this.pointcloudOptions.blend = blend;\n\n borderColor[3] *= opacity;\n this.pointcloudOptions.borderColor = borderColor;\n\n var markerSizeMin = options.marker.sizemin;\n var markerSizeMax = Math.max(options.marker.sizemax, options.marker.sizemin);\n this.pointcloudOptions.sizeMin = markerSizeMin;\n this.pointcloudOptions.sizeMax = markerSizeMax;\n this.pointcloudOptions.areaRatio = options.marker.border.arearatio;\n\n this.pointcloud.update(this.pointcloudOptions);\n\n // add item for autorange routine\n var xa = this.scene.xaxis;\n var ya = this.scene.yaxis;\n var pad = markerSizeMax / 2 || 0.5;\n options._extremes[xa._id] = findExtremes(xa, [bounds[0], bounds[2]], {ppad: pad});\n options._extremes[ya._id] = findExtremes(ya, [bounds[1], bounds[3]], {ppad: pad});\n};\n\nproto.dispose = function() {\n this.pointcloud.dispose();\n};\n\nfunction createPointcloud(scene, data) {\n var plot = new Pointcloud(scene, data.uid);\n plot.update(data);\n return plot;\n}\n\nmodule.exports = createPointcloud;\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n coerce('x');\n coerce('y');\n\n coerce('xbounds');\n coerce('ybounds');\n\n if(traceIn.xy && traceIn.xy instanceof Float32Array) {\n traceOut.xy = traceIn.xy;\n }\n\n if(traceIn.indices && traceIn.indices instanceof Int32Array) {\n traceOut.indices = traceIn.indices;\n }\n\n coerce('text');\n coerce('marker.color', defaultColor);\n coerce('marker.opacity');\n coerce('marker.blend');\n coerce('marker.sizemin');\n coerce('marker.sizemax');\n coerce('marker.border.color', defaultColor);\n coerce('marker.border.arearatio');\n\n // disable 1D transforms - that would defeat the purpose of this trace type, performance!\n traceOut._length = null;\n};\n","'use strict';\n\nvar deprecationWarning = [\n '*pointcloud* trace is deprecated!',\n 'Please consider switching to the *scattergl* trace type.'\n].join(' ');\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n\n // reuse the Scatter3D 'dummy' calc step so that legends know what to do\n calc: require('../scatter3d/calc'),\n plot: require('./convert'),\n\n moduleType: 'trace',\n name: 'pointcloud',\n basePlotModule: require('../../plots/gl2d'),\n categories: ['gl', 'gl2d', 'showLegend'],\n meta: {\n description: [\n deprecationWarning,\n 'The data visualized as a point cloud set in `x` and `y`',\n 'using the WebGl plotting engine.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar fontAttrs = require('../../plots/font_attributes');\nvar baseAttrs = require('../../plots/attributes');\nvar colorAttrs = require('../../components/color/attributes');\nvar fxAttrs = require('../../components/fx/attributes');\nvar domainAttrs = require('../../plots/domain').attributes;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar colorAttributes = require('../../components/colorscale/attributes');\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\nvar descriptionOnlyNumbers = require('../../plots/cartesian/axis_format_attributes').descriptionOnlyNumbers;\n\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\n\nvar attrs = module.exports = overrideAll({\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: [],\n arrayOk: false,\n description: [\n 'Determines which trace information appear on hover.',\n 'If `none` or `skip` are set, no information is displayed upon hovering.',\n 'But, if `none` is set, click and hover events are still fired.',\n 'Note that this attribute is superseded by `node.hoverinfo` and `node.hoverinfo`',\n 'for nodes and links respectively.'\n ].join(' ')\n }),\n hoverlabel: fxAttrs.hoverlabel,\n domain: domainAttrs({name: 'sankey', trace: true}),\n\n orientation: {\n valType: 'enumerated',\n values: ['v', 'h'],\n dflt: 'h',\n description: 'Sets the orientation of the Sankey diagram.'\n },\n\n valueformat: {\n valType: 'string',\n dflt: '.3s',\n description: descriptionOnlyNumbers('value')\n },\n\n valuesuffix: {\n valType: 'string',\n dflt: '',\n description: [\n 'Adds a unit to follow the value in the hover tooltip. Add a space if a separation',\n 'is necessary from the value.'\n ].join(' ')\n },\n\n arrangement: {\n valType: 'enumerated',\n values: ['snap', 'perpendicular', 'freeform', 'fixed'],\n dflt: 'snap',\n description: [\n 'If value is `snap` (the default), the node arrangement is assisted by automatic snapping of elements to',\n 'preserve space between nodes specified via `nodepad`.',\n 'If value is `perpendicular`, the nodes can only move along a line perpendicular to the flow.',\n 'If value is `freeform`, the nodes can freely move on the plane.',\n 'If value is `fixed`, the nodes are stationary.'\n ].join(' ')\n },\n\n textfont: fontAttrs({\n autoShadowDflt: true,\n description: 'Sets the font for node labels'\n }),\n\n // Remove top-level customdata\n customdata: undefined,\n\n node: {\n label: {\n valType: 'data_array',\n dflt: [],\n description: 'The shown name of the node.'\n },\n groups: {\n valType: 'info_array',\n impliedEdits: {x: [], y: []},\n dimensions: 2,\n freeLength: true,\n dflt: [],\n items: {valType: 'number', editType: 'calc'},\n description: [\n 'Groups of nodes.',\n 'Each group is defined by an array with the indices of the nodes it contains.',\n 'Multiple groups can be specified.'\n ].join(' ')\n },\n x: {\n valType: 'data_array',\n dflt: [],\n description: 'The normalized horizontal position of the node.'\n },\n y: {\n valType: 'data_array',\n dflt: [],\n description: 'The normalized vertical position of the node.'\n },\n color: {\n valType: 'color',\n arrayOk: true,\n description: [\n 'Sets the `node` color. It can be a single value, or an array for specifying color for each `node`.',\n 'If `node.color` is omitted, then the default `Plotly` color palette will be cycled through',\n 'to have a variety of colors. These defaults are not fully opaque, to allow some visibility of',\n 'what is beneath the node.'\n ].join(' ')\n },\n customdata: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Assigns extra data to each node.'\n ].join(' ')\n },\n line: {\n color: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n arrayOk: true,\n description: [\n 'Sets the color of the `line` around each `node`.'\n ].join(' ')\n },\n width: {\n valType: 'number',\n min: 0,\n dflt: 0.5,\n arrayOk: true,\n description: [\n 'Sets the width (in px) of the `line` around each `node`.'\n ].join(' ')\n }\n },\n pad: {\n valType: 'number',\n arrayOk: false,\n min: 0,\n dflt: 20,\n description: 'Sets the padding (in px) between the `nodes`.'\n },\n thickness: {\n valType: 'number',\n arrayOk: false,\n min: 1,\n dflt: 20,\n description: 'Sets the thickness (in px) of the `nodes`.'\n },\n hoverinfo: {\n valType: 'enumerated',\n values: ['all', 'none', 'skip'],\n dflt: 'all',\n description: [\n 'Determines which trace information appear when hovering nodes.',\n 'If `none` or `skip` are set, no information is displayed upon hovering.',\n 'But, if `none` is set, click and hover events are still fired.'\n ].join(' ')\n },\n hoverlabel: fxAttrs.hoverlabel, // needs editType override,\n hovertemplate: hovertemplateAttrs({}, {\n description: 'Variables `sourceLinks` and `targetLinks` are arrays of link objects.',\n keys: ['value', 'label']\n }),\n align: {\n valType: 'enumerated',\n values: ['justify', 'left', 'right', 'center'],\n dflt: 'justify',\n description: 'Sets the alignment method used to position the nodes along the horizontal axis.'\n },\n description: 'The nodes of the Sankey plot.'\n },\n\n link: {\n arrowlen: {\n valType: 'number',\n min: 0,\n dflt: 0,\n description: [\n 'Sets the length (in px) of the links arrow, if 0 no arrow will be drawn.'\n ].join(' ')\n },\n label: {\n valType: 'data_array',\n dflt: [],\n description: 'The shown name of the link.'\n },\n color: {\n valType: 'color',\n arrayOk: true,\n description: [\n 'Sets the `link` color. It can be a single value, or an array for specifying color for each `link`.',\n 'If `link.color` is omitted, then by default, a translucent grey link will be used.'\n ].join(' ')\n },\n hovercolor: {\n valType: 'color',\n arrayOk: true,\n description: [\n 'Sets the `link` hover color. It can be a single value, or an array for specifying hover colors for',\n 'each `link`. If `link.hovercolor` is omitted, then by default, links will become slightly more',\n 'opaque when hovered over.'\n ].join(' ')\n },\n customdata: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Assigns extra data to each link.'\n ].join(' ')\n },\n line: {\n color: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n arrayOk: true,\n description: [\n 'Sets the color of the `line` around each `link`.'\n ].join(' ')\n },\n width: {\n valType: 'number',\n min: 0,\n dflt: 0,\n arrayOk: true,\n description: [\n 'Sets the width (in px) of the `line` around each `link`.'\n ].join(' ')\n }\n },\n source: {\n valType: 'data_array',\n dflt: [],\n description: 'An integer number `[0..nodes.length - 1]` that represents the source node.'\n },\n target: {\n valType: 'data_array',\n dflt: [],\n description: 'An integer number `[0..nodes.length - 1]` that represents the target node.'\n },\n value: {\n valType: 'data_array',\n dflt: [],\n description: 'A numeric value representing the flow volume value.'\n },\n hoverinfo: {\n valType: 'enumerated',\n values: ['all', 'none', 'skip'],\n dflt: 'all',\n description: [\n 'Determines which trace information appear when hovering links.',\n 'If `none` or `skip` are set, no information is displayed upon hovering.',\n 'But, if `none` is set, click and hover events are still fired.'\n ].join(' ')\n },\n hoverlabel: fxAttrs.hoverlabel, // needs editType override,\n hovertemplate: hovertemplateAttrs({}, {\n description: 'Variables `source` and `target` are node objects.',\n keys: ['value', 'label']\n }),\n colorscales: templatedArray('concentrationscales', {\n editType: 'calc',\n label: {\n valType: 'string',\n editType: 'calc',\n description: 'The label of the links to color based on their concentration within a flow.',\n dflt: ''\n },\n cmax: {\n valType: 'number',\n editType: 'calc',\n dflt: 1,\n description: 'Sets the upper bound of the color domain.'\n },\n cmin: {\n valType: 'number',\n editType: 'calc',\n dflt: 0,\n description: 'Sets the lower bound of the color domain.'\n },\n colorscale: extendFlat(colorAttributes().colorscale, {dflt: [[0, 'white'], [1, 'black']]})\n }),\n description: 'The links of the Sankey plot.',\n }\n}, 'calc', 'nested');\nattrs.transforms = undefined;\n","'use strict';\n\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar getModuleCalcData = require('../../plots/get_data').getModuleCalcData;\nvar plot = require('./plot');\nvar fxAttrs = require('../../components/fx/layout_attributes');\n\nvar setCursor = require('../../lib/setcursor');\nvar dragElement = require('../../components/dragelement');\nvar prepSelect = require('../../components/selections').prepSelect;\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\n\nvar SANKEY = 'sankey';\n\nexports.name = SANKEY;\n\nexports.baseLayoutAttrOverrides = overrideAll({\n hoverlabel: fxAttrs.hoverlabel\n}, 'plot', 'nested');\n\nexports.plot = function(gd) {\n var calcData = getModuleCalcData(gd.calcdata, SANKEY)[0];\n plot(gd, calcData);\n exports.updateFx(gd);\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var hadPlot = (oldFullLayout._has && oldFullLayout._has(SANKEY));\n var hasPlot = (newFullLayout._has && newFullLayout._has(SANKEY));\n\n if(hadPlot && !hasPlot) {\n oldFullLayout._paperdiv.selectAll('.sankey').remove();\n oldFullLayout._paperdiv.selectAll('.bgsankey').remove();\n }\n};\n\nexports.updateFx = function(gd) {\n for(var i = 0; i < gd._fullData.length; i++) {\n subplotUpdateFx(gd, i);\n }\n};\n\nfunction subplotUpdateFx(gd, index) {\n var trace = gd._fullData[index];\n var fullLayout = gd._fullLayout;\n\n var dragMode = fullLayout.dragmode;\n var cursor = fullLayout.dragmode === 'pan' ? 'move' : 'crosshair';\n var bgRect = trace._bgRect;\n if(!bgRect) return;\n\n if(dragMode === 'pan' || dragMode === 'zoom') return;\n\n setCursor(bgRect, cursor);\n\n var xaxis = {\n _id: 'x',\n c2p: Lib.identity,\n _offset: trace._sankey.translateX,\n _length: trace._sankey.width\n };\n var yaxis = {\n _id: 'y',\n c2p: Lib.identity,\n _offset: trace._sankey.translateY,\n _length: trace._sankey.height\n };\n\n // Note: dragOptions is needed to be declared for all dragmodes because\n // it's the object that holds persistent selection state.\n var dragOptions = {\n gd: gd,\n element: bgRect.node(),\n plotinfo: {\n id: index,\n xaxis: xaxis,\n yaxis: yaxis,\n fillRangeItems: Lib.noop\n },\n subplot: index,\n // create mock x/y axes for hover routine\n xaxes: [xaxis],\n yaxes: [yaxis],\n doneFnCompleted: function(selection) {\n var traceNow = gd._fullData[index];\n var newGroups;\n var oldGroups = traceNow.node.groups.slice();\n var newGroup = [];\n\n function findNode(pt) {\n var nodes = traceNow._sankey.graph.nodes;\n for(var i = 0; i < nodes.length; i++) {\n if(nodes[i].pointNumber === pt) return nodes[i];\n }\n }\n\n for(var j = 0; j < selection.length; j++) {\n var node = findNode(selection[j].pointNumber);\n if(!node) continue;\n\n // If the node represents a group\n if(node.group) {\n // Add all its children to the current selection\n for(var k = 0; k < node.childrenNodes.length; k++) {\n newGroup.push(node.childrenNodes[k].pointNumber);\n }\n // Flag group for removal from existing list of groups\n oldGroups[node.pointNumber - traceNow.node._count] = false;\n } else {\n newGroup.push(node.pointNumber);\n }\n }\n\n newGroups = oldGroups\n .filter(Boolean)\n .concat([newGroup]);\n\n Registry.call('_guiRestyle', gd, {\n 'node.groups': [ newGroups ]\n }, index);\n }\n };\n\n dragOptions.prepFn = function(e, startX, startY) {\n prepSelect(e, startX, startY, dragOptions, dragMode);\n };\n\n dragElement.init(dragOptions);\n}\n","'use strict';\n\nvar tarjan = require('strongly-connected-components');\nvar Lib = require('../../lib');\nvar wrap = require('../../lib/gup').wrap;\n\nvar isArrayOrTypedArray = Lib.isArrayOrTypedArray;\nvar isIndex = Lib.isIndex;\nvar Colorscale = require('../../components/colorscale');\n\nfunction convertToD3Sankey(trace) {\n var nodeSpec = trace.node;\n var linkSpec = trace.link;\n\n var links = [];\n var hasLinkColorArray = isArrayOrTypedArray(linkSpec.color);\n var hasLinkHoverColorArray = isArrayOrTypedArray(linkSpec.hovercolor);\n var hasLinkCustomdataArray = isArrayOrTypedArray(linkSpec.customdata);\n var linkedNodes = {};\n\n var components = {};\n var componentCount = linkSpec.colorscales.length;\n var i;\n for(i = 0; i < componentCount; i++) {\n var cscale = linkSpec.colorscales[i];\n var specs = Colorscale.extractScale(cscale, {cLetter: 'c'});\n var scale = Colorscale.makeColorScaleFunc(specs);\n components[cscale.label] = scale;\n }\n\n var maxNodeId = 0;\n for(i = 0; i < linkSpec.value.length; i++) {\n if(linkSpec.source[i] > maxNodeId) maxNodeId = linkSpec.source[i];\n if(linkSpec.target[i] > maxNodeId) maxNodeId = linkSpec.target[i];\n }\n var nodeCount = maxNodeId + 1;\n trace.node._count = nodeCount;\n\n // Group nodes\n var j;\n var groups = trace.node.groups;\n var groupLookup = {};\n for(i = 0; i < groups.length; i++) {\n var group = groups[i];\n // Build a lookup table to quickly find in which group a node is\n for(j = 0; j < group.length; j++) {\n var nodeIndex = group[j];\n var groupIndex = nodeCount + i;\n if(groupLookup.hasOwnProperty(nodeIndex)) {\n Lib.warn('Node ' + nodeIndex + ' is already part of a group.');\n } else {\n groupLookup[nodeIndex] = groupIndex;\n }\n }\n }\n\n // Process links\n var groupedLinks = {\n source: [],\n target: []\n };\n for(i = 0; i < linkSpec.value.length; i++) {\n var val = linkSpec.value[i];\n // remove negative values, but keep zeros with special treatment\n var source = linkSpec.source[i];\n var target = linkSpec.target[i];\n if(!(val > 0 && isIndex(source, nodeCount) && isIndex(target, nodeCount))) {\n continue;\n }\n\n // Remove links that are within the same group\n if(groupLookup.hasOwnProperty(source) && groupLookup.hasOwnProperty(target) && groupLookup[source] === groupLookup[target]) {\n continue;\n }\n\n // if link targets a node in the group, relink target to that group\n if(groupLookup.hasOwnProperty(target)) {\n target = groupLookup[target];\n }\n\n // if link originates from a node in a group, relink source to that group\n if(groupLookup.hasOwnProperty(source)) {\n source = groupLookup[source];\n }\n\n source = +source;\n target = +target;\n linkedNodes[source] = linkedNodes[target] = true;\n\n var label = '';\n if(linkSpec.label && linkSpec.label[i]) label = linkSpec.label[i];\n\n var concentrationscale = null;\n if(label && components.hasOwnProperty(label)) concentrationscale = components[label];\n\n links.push({\n pointNumber: i,\n label: label,\n color: hasLinkColorArray ? linkSpec.color[i] : linkSpec.color,\n hovercolor: hasLinkHoverColorArray ? linkSpec.hovercolor[i] : linkSpec.hovercolor,\n customdata: hasLinkCustomdataArray ? linkSpec.customdata[i] : linkSpec.customdata,\n concentrationscale: concentrationscale,\n source: source,\n target: target,\n value: +val\n });\n\n groupedLinks.source.push(source);\n groupedLinks.target.push(target);\n }\n\n // Process nodes\n var totalCount = nodeCount + groups.length;\n var hasNodeColorArray = isArrayOrTypedArray(nodeSpec.color);\n var hasNodeCustomdataArray = isArrayOrTypedArray(nodeSpec.customdata);\n var nodes = [];\n for(i = 0; i < totalCount; i++) {\n if(!linkedNodes[i]) continue;\n var l = nodeSpec.label[i];\n\n nodes.push({\n group: (i > nodeCount - 1),\n childrenNodes: [],\n pointNumber: i,\n label: l,\n color: hasNodeColorArray ? nodeSpec.color[i] : nodeSpec.color,\n customdata: hasNodeCustomdataArray ? nodeSpec.customdata[i] : nodeSpec.customdata\n });\n }\n\n // Check if we have circularity on the resulting graph\n var circular = false;\n if(circularityPresent(totalCount, groupedLinks.source, groupedLinks.target)) {\n circular = true;\n }\n\n return {\n circular: circular,\n links: links,\n nodes: nodes,\n\n // Data structure for groups\n groups: groups,\n groupLookup: groupLookup\n };\n}\n\nfunction circularityPresent(nodeLen, sources, targets) {\n var nodes = Lib.init2dArray(nodeLen, 0);\n\n for(var i = 0; i < Math.min(sources.length, targets.length); i++) {\n if(Lib.isIndex(sources[i], nodeLen) && Lib.isIndex(targets[i], nodeLen)) {\n if(sources[i] === targets[i]) {\n return true; // self-link which is also a scc of one\n }\n nodes[sources[i]].push(targets[i]);\n }\n }\n\n var scc = tarjan(nodes);\n\n // Tarján's strongly connected components algorithm coded by Mikola Lysenko\n // returns at least one non-singular component if there's circularity in the graph\n return scc.components.some(function(c) {\n return c.length > 1;\n });\n}\n\nmodule.exports = function calc(gd, trace) {\n var result = convertToD3Sankey(trace);\n\n return wrap({\n circular: result.circular,\n _nodes: result.nodes,\n _links: result.links,\n\n // Data structure for grouping\n _groups: result.groups,\n _groupLookup: result.groupLookup,\n });\n};\n","'use strict';\n\nmodule.exports = {\n nodeTextOffsetHorizontal: 4,\n nodeTextOffsetVertical: 3,\n nodePadAcross: 10,\n sankeyIterations: 50,\n forceIterations: 5,\n forceTicksPerFrame: 10,\n duration: 500,\n ease: 'linear',\n cn: {\n sankey: 'sankey',\n sankeyLinks: 'sankey-links',\n sankeyLink: 'sankey-link',\n sankeyNodeSet: 'sankey-node-set',\n sankeyNode: 'sankey-node',\n nodeRect: 'node-rect',\n nodeLabel: 'node-label'\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar attributes = require('./attributes');\nvar Color = require('../../components/color');\nvar tinycolor = require('tinycolor2');\nvar handleDomainDefaults = require('../../plots/domain').defaults;\nvar handleHoverLabelDefaults = require('../../components/fx/hoverlabel_defaults');\nvar Template = require('../../plot_api/plot_template');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var hoverlabelDefault = Lib.extendDeep(layout.hoverlabel, traceIn.hoverlabel);\n\n // node attributes\n var nodeIn = traceIn.node;\n var nodeOut = Template.newContainer(traceOut, 'node');\n\n function coerceNode(attr, dflt) {\n return Lib.coerce(nodeIn, nodeOut, attributes.node, attr, dflt);\n }\n coerceNode('label');\n coerceNode('groups');\n coerceNode('x');\n coerceNode('y');\n coerceNode('pad');\n coerceNode('thickness');\n coerceNode('line.color');\n coerceNode('line.width');\n coerceNode('hoverinfo', traceIn.hoverinfo);\n handleHoverLabelDefaults(nodeIn, nodeOut, coerceNode, hoverlabelDefault);\n coerceNode('hovertemplate');\n coerceNode('align');\n\n var colors = layout.colorway;\n\n var defaultNodePalette = function(i) {return colors[i % colors.length];};\n\n coerceNode('color', nodeOut.label.map(function(d, i) {\n return Color.addOpacity(defaultNodePalette(i), 0.8);\n }));\n coerceNode('customdata');\n\n // link attributes\n var linkIn = traceIn.link || {};\n var linkOut = Template.newContainer(traceOut, 'link');\n\n function coerceLink(attr, dflt) {\n return Lib.coerce(linkIn, linkOut, attributes.link, attr, dflt);\n }\n coerceLink('label');\n coerceLink('arrowlen');\n coerceLink('source');\n coerceLink('target');\n coerceLink('value');\n coerceLink('line.color');\n coerceLink('line.width');\n coerceLink('hoverinfo', traceIn.hoverinfo);\n handleHoverLabelDefaults(linkIn, linkOut, coerceLink, hoverlabelDefault);\n coerceLink('hovertemplate');\n\n var darkBG = tinycolor(layout.paper_bgcolor).getLuminance() < 0.333;\n var defaultLinkColor = darkBG ? 'rgba(255, 255, 255, 0.6)' : 'rgba(0, 0, 0, 0.2)';\n var linkColor = coerceLink('color', defaultLinkColor);\n\n function makeDefaultHoverColor(_linkColor) {\n var tc = tinycolor(_linkColor);\n if(!tc.isValid()) {\n // hopefully the user-specified color is valid, but if not that can be caught elsewhere\n return _linkColor;\n }\n var alpha = tc.getAlpha();\n if(alpha <= 0.8) {\n tc.setAlpha(alpha + 0.2);\n } else {\n tc = darkBG ? tc.brighten() : tc.darken();\n }\n return tc.toRgbString();\n }\n\n coerceLink('hovercolor', Array.isArray(linkColor) ?\n linkColor.map(makeDefaultHoverColor) :\n makeDefaultHoverColor(linkColor)\n );\n\n coerceLink('customdata');\n\n handleArrayContainerDefaults(linkIn, linkOut, {\n name: 'colorscales',\n handleItemDefaults: concentrationscalesDefaults\n });\n\n handleDomainDefaults(traceOut, layout, coerce);\n\n coerce('orientation');\n coerce('valueformat');\n coerce('valuesuffix');\n\n var dfltArrangement;\n if(nodeOut.x.length && nodeOut.y.length) {\n dfltArrangement = 'freeform';\n }\n coerce('arrangement', dfltArrangement);\n\n Lib.coerceFont(coerce, 'textfont', layout.font, { autoShadowDflt: true });\n\n // disable 1D transforms - arrays here are 1D but their lengths/meanings\n // don't match, between nodes and links\n traceOut._length = null;\n};\n\nfunction concentrationscalesDefaults(In, Out) {\n function coerce(attr, dflt) {\n return Lib.coerce(In, Out, attributes.link.colorscales, attr, dflt);\n }\n\n coerce('label');\n coerce('cmin');\n coerce('cmax');\n coerce('colorscale');\n}\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n calc: require('./calc'),\n plot: require('./plot'),\n\n moduleType: 'trace',\n name: 'sankey',\n basePlotModule: require('./base_plot'),\n selectPoints: require('./select.js'),\n categories: ['noOpacity'],\n meta: {\n description: [\n 'Sankey plots for network flow data analysis.',\n 'The nodes are specified in `nodes` and the links between sources and targets in `links`.',\n 'The colors are set in `nodes[i].color` and `links[i].color`, otherwise defaults are used.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\nvar numberFormat = Lib.numberFormat;\nvar render = require('./render');\nvar Fx = require('../../components/fx');\nvar Color = require('../../components/color');\nvar cn = require('./constants').cn;\n\nvar _ = Lib._;\n\nfunction renderableValuePresent(d) {return d !== '';}\n\nfunction ownTrace(selection, d) {\n return selection.filter(function(s) {return s.key === d.traceId;});\n}\n\nfunction makeTranslucent(element, alpha) {\n d3.select(element)\n .select('path')\n .style('fill-opacity', alpha);\n d3.select(element)\n .select('rect')\n .style('fill-opacity', alpha);\n}\n\nfunction makeTextContrasty(element) {\n d3.select(element)\n .select('text.name')\n .style('fill', 'black');\n}\n\nfunction relatedLinks(d) {\n return function(l) {\n return d.node.sourceLinks.indexOf(l.link) !== -1 || d.node.targetLinks.indexOf(l.link) !== -1;\n };\n}\n\nfunction relatedNodes(l) {\n return function(d) {\n return d.node.sourceLinks.indexOf(l.link) !== -1 || d.node.targetLinks.indexOf(l.link) !== -1;\n };\n}\n\nfunction nodeHoveredStyle(sankeyNode, d, sankey) {\n if(d && sankey) {\n ownTrace(sankey, d)\n .selectAll('.' + cn.sankeyLink)\n .filter(relatedLinks(d))\n .call(linkHoveredStyle.bind(0, d, sankey, false));\n }\n}\n\nfunction nodeNonHoveredStyle(sankeyNode, d, sankey) {\n if(d && sankey) {\n ownTrace(sankey, d)\n .selectAll('.' + cn.sankeyLink)\n .filter(relatedLinks(d))\n .call(linkNonHoveredStyle.bind(0, d, sankey, false));\n }\n}\n\nfunction linkHoveredStyle(d, sankey, visitNodes, sankeyLink) {\n sankeyLink.style('fill', function(l) {\n if(!l.link.concentrationscale) {\n return l.tinyColorHoverHue;\n }\n }).style('fill-opacity', function(l) {\n if(!l.link.concentrationscale) {\n return l.tinyColorHoverAlpha;\n }\n });\n\n sankeyLink.each(function(curLink) {\n var label = curLink.link.label;\n if(label !== '') {\n ownTrace(sankey, d)\n .selectAll('.' + cn.sankeyLink)\n .filter(function(l) {return l.link.label === label;})\n .style('fill', function(l) {\n if(!l.link.concentrationscale) {\n return l.tinyColorHoverHue;\n }\n }).style('fill-opacity', function(l) {\n if(!l.link.concentrationscale) {\n return l.tinyColorHoverAlpha;\n }\n });\n }\n });\n\n if(visitNodes) {\n ownTrace(sankey, d)\n .selectAll('.' + cn.sankeyNode)\n .filter(relatedNodes(d))\n .call(nodeHoveredStyle);\n }\n}\n\nfunction linkNonHoveredStyle(d, sankey, visitNodes, sankeyLink) {\n sankeyLink.style('fill', function(l) {\n return l.tinyColorHue;\n }).style('fill-opacity', function(l) {\n return l.tinyColorAlpha;\n });\n\n sankeyLink.each(function(curLink) {\n var label = curLink.link.label;\n if(label !== '') {\n ownTrace(sankey, d)\n .selectAll('.' + cn.sankeyLink)\n .filter(function(l) {return l.link.label === label;})\n .style('fill', function(l) {return l.tinyColorHue;})\n .style('fill-opacity', function(l) {return l.tinyColorAlpha;});\n }\n });\n\n if(visitNodes) {\n ownTrace(sankey, d)\n .selectAll(cn.sankeyNode)\n .filter(relatedNodes(d))\n .call(nodeNonHoveredStyle);\n }\n}\n\n// does not support array values for now\nfunction castHoverOption(trace, attr) {\n var labelOpts = trace.hoverlabel || {};\n var val = Lib.nestedProperty(labelOpts, attr).get();\n return Array.isArray(val) ? false : val;\n}\n\nmodule.exports = function plot(gd, calcData) {\n var fullLayout = gd._fullLayout;\n var svg = fullLayout._paper;\n var size = fullLayout._size;\n\n // stash initial view\n for(var i = 0; i < gd._fullData.length; i++) {\n if(!gd._fullData[i].visible) continue;\n if(gd._fullData[i].type !== cn.sankey) continue;\n if(!gd._fullData[i]._viewInitial) {\n var node = gd._fullData[i].node;\n gd._fullData[i]._viewInitial = {\n node: {\n groups: node.groups.slice(),\n x: node.x.slice(),\n y: node.y.slice()\n }\n };\n }\n }\n\n var linkSelect = function(element, d) {\n var evt = d.link;\n evt.originalEvent = d3.event;\n gd._hoverdata = [evt];\n Fx.click(gd, { target: true });\n };\n\n var linkHover = function(element, d, sankey) {\n if(gd._fullLayout.hovermode === false) return;\n d3.select(element).call(linkHoveredStyle.bind(0, d, sankey, true));\n if(d.link.trace.link.hoverinfo !== 'skip') {\n d.link.fullData = d.link.trace;\n gd.emit('plotly_hover', {\n event: d3.event,\n points: [d.link]\n });\n }\n };\n\n var sourceLabel = _(gd, 'source:') + ' ';\n var targetLabel = _(gd, 'target:') + ' ';\n var concentrationLabel = _(gd, 'concentration:') + ' ';\n var incomingLabel = _(gd, 'incoming flow count:') + ' ';\n var outgoingLabel = _(gd, 'outgoing flow count:') + ' ';\n\n var linkHoverFollow = function(element, d) {\n if(gd._fullLayout.hovermode === false) return;\n var obj = d.link.trace.link;\n if(obj.hoverinfo === 'none' || obj.hoverinfo === 'skip') return;\n\n var hoverItems = [];\n\n function hoverCenterPosition(link) {\n var hoverCenterX, hoverCenterY;\n if(link.circular) {\n hoverCenterX = (link.circularPathData.leftInnerExtent + link.circularPathData.rightInnerExtent) / 2;\n hoverCenterY = link.circularPathData.verticalFullExtent;\n } else {\n hoverCenterX = (link.source.x1 + link.target.x0) / 2;\n hoverCenterY = (link.y0 + link.y1) / 2;\n }\n var center = [hoverCenterX, hoverCenterY];\n if(link.trace.orientation === 'v') center.reverse();\n center[0] += d.parent.translateX;\n center[1] += d.parent.translateY;\n return center;\n }\n\n // For each related links, create a hoverItem\n var anchorIndex = 0;\n for(var i = 0; i < d.flow.links.length; i++) {\n var link = d.flow.links[i];\n if(gd._fullLayout.hovermode === 'closest' && d.link.pointNumber !== link.pointNumber) continue;\n if(d.link.pointNumber === link.pointNumber) anchorIndex = i;\n link.fullData = link.trace;\n obj = d.link.trace.link;\n var hoverCenter = hoverCenterPosition(link);\n var hovertemplateLabels = {valueLabel: numberFormat(d.valueFormat)(link.value) + d.valueSuffix};\n\n hoverItems.push({\n x: hoverCenter[0],\n y: hoverCenter[1],\n name: hovertemplateLabels.valueLabel,\n text: [\n link.label || '',\n sourceLabel + link.source.label,\n targetLabel + link.target.label,\n link.concentrationscale ? concentrationLabel + numberFormat('%0.2f')(link.flow.labelConcentration) : ''\n ].filter(renderableValuePresent).join('
'),\n color: castHoverOption(obj, 'bgcolor') || Color.addOpacity(link.color, 1),\n borderColor: castHoverOption(obj, 'bordercolor'),\n fontFamily: castHoverOption(obj, 'font.family'),\n fontSize: castHoverOption(obj, 'font.size'),\n fontColor: castHoverOption(obj, 'font.color'),\n fontWeight: castHoverOption(obj, 'font.weight'),\n fontStyle: castHoverOption(obj, 'font.style'),\n fontVariant: castHoverOption(obj, 'font.variant'),\n fontTextcase: castHoverOption(obj, 'font.textcase'),\n fontLineposition: castHoverOption(obj, 'font.lineposition'),\n fontShadow: castHoverOption(obj, 'font.shadow'),\n nameLength: castHoverOption(obj, 'namelength'),\n textAlign: castHoverOption(obj, 'align'),\n idealAlign: d3.event.x < hoverCenter[0] ? 'right' : 'left',\n\n hovertemplate: obj.hovertemplate,\n hovertemplateLabels: hovertemplateLabels,\n eventData: [link]\n });\n }\n\n var tooltips = Fx.loneHover(hoverItems, {\n container: fullLayout._hoverlayer.node(),\n outerContainer: fullLayout._paper.node(),\n gd: gd,\n anchorIndex: anchorIndex\n });\n\n tooltips.each(function() {\n var tooltip = this;\n if(!d.link.concentrationscale) {\n makeTranslucent(tooltip, 0.65);\n }\n makeTextContrasty(tooltip);\n });\n };\n\n var linkUnhover = function(element, d, sankey) {\n if(gd._fullLayout.hovermode === false) return;\n d3.select(element).call(linkNonHoveredStyle.bind(0, d, sankey, true));\n if(d.link.trace.link.hoverinfo !== 'skip') {\n d.link.fullData = d.link.trace;\n gd.emit('plotly_unhover', {\n event: d3.event,\n points: [d.link]\n });\n }\n\n Fx.loneUnhover(fullLayout._hoverlayer.node());\n };\n\n var nodeSelect = function(element, d, sankey) {\n var evt = d.node;\n evt.originalEvent = d3.event;\n gd._hoverdata = [evt];\n d3.select(element).call(nodeNonHoveredStyle, d, sankey);\n Fx.click(gd, { target: true });\n };\n\n var nodeHover = function(element, d, sankey) {\n if(gd._fullLayout.hovermode === false) return;\n d3.select(element).call(nodeHoveredStyle, d, sankey);\n if(d.node.trace.node.hoverinfo !== 'skip') {\n d.node.fullData = d.node.trace;\n gd.emit('plotly_hover', {\n event: d3.event,\n points: [d.node]\n });\n }\n };\n\n var nodeHoverFollow = function(element, d) {\n if(gd._fullLayout.hovermode === false) return;\n\n var obj = d.node.trace.node;\n if(obj.hoverinfo === 'none' || obj.hoverinfo === 'skip') return;\n var nodeRect = d3.select(element).select('.' + cn.nodeRect);\n var rootBBox = gd._fullLayout._paperdiv.node().getBoundingClientRect();\n var boundingBox = nodeRect.node().getBoundingClientRect();\n var hoverCenterX0 = boundingBox.left - 2 - rootBBox.left;\n var hoverCenterX1 = boundingBox.right + 2 - rootBBox.left;\n var hoverCenterY = boundingBox.top + boundingBox.height / 4 - rootBBox.top;\n\n var hovertemplateLabels = {valueLabel: numberFormat(d.valueFormat)(d.node.value) + d.valueSuffix};\n d.node.fullData = d.node.trace;\n\n gd._fullLayout._calcInverseTransform(gd);\n var scaleX = gd._fullLayout._invScaleX;\n var scaleY = gd._fullLayout._invScaleY;\n\n var tooltip = Fx.loneHover({\n x0: scaleX * hoverCenterX0,\n x1: scaleX * hoverCenterX1,\n y: scaleY * hoverCenterY,\n name: numberFormat(d.valueFormat)(d.node.value) + d.valueSuffix,\n text: [\n d.node.label,\n incomingLabel + d.node.targetLinks.length,\n outgoingLabel + d.node.sourceLinks.length\n ].filter(renderableValuePresent).join('
'),\n color: castHoverOption(obj, 'bgcolor') || d.tinyColorHue,\n borderColor: castHoverOption(obj, 'bordercolor'),\n fontFamily: castHoverOption(obj, 'font.family'),\n fontSize: castHoverOption(obj, 'font.size'),\n fontColor: castHoverOption(obj, 'font.color'),\n fontWeight: castHoverOption(obj, 'font.weight'),\n fontStyle: castHoverOption(obj, 'font.style'),\n fontVariant: castHoverOption(obj, 'font.variant'),\n fontTextcase: castHoverOption(obj, 'font.textcase'),\n fontLineposition: castHoverOption(obj, 'font.lineposition'),\n fontShadow: castHoverOption(obj, 'font.shadow'),\n nameLength: castHoverOption(obj, 'namelength'),\n textAlign: castHoverOption(obj, 'align'),\n idealAlign: 'left',\n\n hovertemplate: obj.hovertemplate,\n hovertemplateLabels: hovertemplateLabels,\n eventData: [d.node]\n }, {\n container: fullLayout._hoverlayer.node(),\n outerContainer: fullLayout._paper.node(),\n gd: gd\n });\n\n makeTranslucent(tooltip, 0.85);\n makeTextContrasty(tooltip);\n };\n\n var nodeUnhover = function(element, d, sankey) {\n if(gd._fullLayout.hovermode === false) return;\n d3.select(element).call(nodeNonHoveredStyle, d, sankey);\n if(d.node.trace.node.hoverinfo !== 'skip') {\n d.node.fullData = d.node.trace;\n gd.emit('plotly_unhover', {\n event: d3.event,\n points: [d.node]\n });\n }\n\n Fx.loneUnhover(fullLayout._hoverlayer.node());\n };\n\n render(\n gd,\n svg,\n calcData,\n {\n width: size.w,\n height: size.h,\n margin: {\n t: size.t,\n r: size.r,\n b: size.b,\n l: size.l\n }\n },\n {\n linkEvents: {\n hover: linkHover,\n follow: linkHoverFollow,\n unhover: linkUnhover,\n select: linkSelect\n },\n nodeEvents: {\n hover: nodeHover,\n follow: nodeHoverFollow,\n unhover: nodeUnhover,\n select: nodeSelect\n }\n }\n );\n};\n","'use strict';\n\nvar d3Force = require('d3-force');\nvar interpolateNumber = require('d3-interpolate').interpolateNumber;\nvar d3 = require('@plotly/d3');\nvar d3Sankey = require('@plotly/d3-sankey');\nvar d3SankeyCircular = require('@plotly/d3-sankey-circular');\n\nvar c = require('./constants');\nvar tinycolor = require('tinycolor2');\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\nvar Lib = require('../../lib');\nvar strTranslate = Lib.strTranslate;\nvar strRotate = Lib.strRotate;\nvar gup = require('../../lib/gup');\nvar keyFun = gup.keyFun;\nvar repeat = gup.repeat;\nvar unwrap = gup.unwrap;\nvar svgTextUtils = require('../../lib/svg_text_utils');\n\nvar Registry = require('../../registry');\n\nvar alignmentConstants = require('../../constants/alignment');\nvar CAP_SHIFT = alignmentConstants.CAP_SHIFT;\nvar LINE_SPACING = alignmentConstants.LINE_SPACING;\nvar TEXTPAD = 3;\n\n// view models\n\nfunction sankeyModel(layout, d, traceIndex) {\n var calcData = unwrap(d);\n var trace = calcData.trace;\n var domain = trace.domain;\n var horizontal = trace.orientation === 'h';\n var nodePad = trace.node.pad;\n var nodeThickness = trace.node.thickness;\n var nodeAlign = {\n justify: d3Sankey.sankeyJustify,\n left: d3Sankey.sankeyLeft,\n right: d3Sankey.sankeyRight,\n center: d3Sankey.sankeyCenter\n }[trace.node.align];\n\n var width = layout.width * (domain.x[1] - domain.x[0]);\n var height = layout.height * (domain.y[1] - domain.y[0]);\n\n var nodes = calcData._nodes;\n var links = calcData._links;\n var circular = calcData.circular;\n\n // Select Sankey generator\n var sankey;\n if(circular) {\n sankey = d3SankeyCircular\n .sankeyCircular()\n .circularLinkGap(0);\n } else {\n sankey = d3Sankey.sankey();\n }\n\n sankey\n .iterations(c.sankeyIterations)\n .size(horizontal ? [width, height] : [height, width])\n .nodeWidth(nodeThickness)\n .nodePadding(nodePad)\n .nodeId(function(d) {\n return d.pointNumber;\n })\n .nodeAlign(nodeAlign)\n .nodes(nodes)\n .links(links);\n\n var graph = sankey();\n\n if(sankey.nodePadding() < nodePad) {\n Lib.warn('node.pad was reduced to ', sankey.nodePadding(), ' to fit within the figure.');\n }\n\n // Counters for nested loops\n var i, j, k;\n\n // Create transient nodes for animations\n for(var nodePointNumber in calcData._groupLookup) {\n var groupIndex = parseInt(calcData._groupLookup[nodePointNumber]);\n\n // Find node representing groupIndex\n var groupingNode;\n\n for(i = 0; i < graph.nodes.length; i++) {\n if(graph.nodes[i].pointNumber === groupIndex) {\n groupingNode = graph.nodes[i];\n break;\n }\n }\n // If groupinNode is undefined, no links are targeting this group\n if(!groupingNode) continue;\n\n var child = {\n pointNumber: parseInt(nodePointNumber),\n x0: groupingNode.x0,\n x1: groupingNode.x1,\n y0: groupingNode.y0,\n y1: groupingNode.y1,\n partOfGroup: true,\n sourceLinks: [],\n targetLinks: []\n };\n\n graph.nodes.unshift(child);\n groupingNode.childrenNodes.unshift(child);\n }\n\n function computeLinkConcentrations() {\n for(i = 0; i < graph.nodes.length; i++) {\n var node = graph.nodes[i];\n // Links connecting the same two nodes are part of a flow\n var flows = {};\n var flowKey;\n var link;\n for(j = 0; j < node.targetLinks.length; j++) {\n link = node.targetLinks[j];\n flowKey = link.source.pointNumber + ':' + link.target.pointNumber;\n if(!flows.hasOwnProperty(flowKey)) flows[flowKey] = [];\n flows[flowKey].push(link);\n }\n\n // Compute statistics for each flow\n var keys = Object.keys(flows);\n for(j = 0; j < keys.length; j++) {\n flowKey = keys[j];\n var flowLinks = flows[flowKey];\n\n // Find the total size of the flow and total size per label\n var total = 0;\n var totalPerLabel = {};\n for(k = 0; k < flowLinks.length; k++) {\n link = flowLinks[k];\n if(!totalPerLabel[link.label]) totalPerLabel[link.label] = 0;\n totalPerLabel[link.label] += link.value;\n total += link.value;\n }\n\n // Find the ratio of the link's value and the size of the flow\n for(k = 0; k < flowLinks.length; k++) {\n link = flowLinks[k];\n link.flow = {\n value: total,\n labelConcentration: totalPerLabel[link.label] / total,\n concentration: link.value / total,\n links: flowLinks\n };\n if(link.concentrationscale) {\n link.color = tinycolor(link.concentrationscale(link.flow.labelConcentration));\n }\n }\n }\n\n // Gather statistics of all links at current node\n var totalOutflow = 0;\n for(j = 0; j < node.sourceLinks.length; j++) {\n totalOutflow += node.sourceLinks[j].value;\n }\n for(j = 0; j < node.sourceLinks.length; j++) {\n link = node.sourceLinks[j];\n link.concentrationOut = link.value / totalOutflow;\n }\n\n var totalInflow = 0;\n for(j = 0; j < node.targetLinks.length; j++) {\n totalInflow += node.targetLinks[j].value;\n }\n\n for(j = 0; j < node.targetLinks.length; j++) {\n link = node.targetLinks[j];\n link.concenrationIn = link.value / totalInflow;\n }\n }\n }\n computeLinkConcentrations();\n\n // Push any overlapping nodes down.\n function resolveCollisionsTopToBottom(columns) {\n columns.forEach(function(nodes) {\n var node;\n var dy;\n var y = 0;\n var n = nodes.length;\n var i;\n nodes.sort(function(a, b) {\n return a.y0 - b.y0;\n });\n for(i = 0; i < n; ++i) {\n node = nodes[i];\n if(node.y0 >= y) {\n // No overlap\n } else {\n dy = (y - node.y0);\n if(dy > 1e-6) node.y0 += dy, node.y1 += dy;\n }\n y = node.y1 + nodePad;\n }\n });\n }\n\n // Group nodes into columns based on their x position\n function snapToColumns(nodes) {\n // Sort nodes by x position\n var orderedNodes = nodes.map(function(n, i) {\n return {\n x0: n.x0,\n index: i\n };\n })\n .sort(function(a, b) {\n return a.x0 - b.x0;\n });\n\n var columns = [];\n var colNumber = -1;\n var colX; // Position of column\n var lastX = -Infinity; // Position of last node\n var dx;\n for(i = 0; i < orderedNodes.length; i++) {\n var node = nodes[orderedNodes[i].index];\n // If the node does not overlap with the last one\n if(node.x0 > lastX + nodeThickness) {\n // Start a new column\n colNumber += 1;\n colX = node.x0;\n }\n lastX = node.x0;\n\n // Add node to its associated column\n if(!columns[colNumber]) columns[colNumber] = [];\n columns[colNumber].push(node);\n\n // Change node's x position to align it with its column\n dx = colX - node.x0;\n node.x0 += dx, node.x1 += dx;\n }\n return columns;\n }\n\n // Force node position\n if(trace.node.x.length && trace.node.y.length) {\n for(i = 0; i < Math.min(trace.node.x.length, trace.node.y.length, graph.nodes.length); i++) {\n if(trace.node.x[i] && trace.node.y[i]) {\n var pos = [trace.node.x[i] * width, trace.node.y[i] * height];\n graph.nodes[i].x0 = pos[0] - nodeThickness / 2;\n graph.nodes[i].x1 = pos[0] + nodeThickness / 2;\n\n var nodeHeight = graph.nodes[i].y1 - graph.nodes[i].y0;\n graph.nodes[i].y0 = pos[1] - nodeHeight / 2;\n graph.nodes[i].y1 = pos[1] + nodeHeight / 2;\n }\n }\n if(trace.arrangement === 'snap') {\n nodes = graph.nodes;\n var columns = snapToColumns(nodes);\n resolveCollisionsTopToBottom(columns);\n }\n // Update links\n sankey.update(graph);\n }\n\n\n return {\n circular: circular,\n key: traceIndex,\n trace: trace,\n guid: Lib.randstr(),\n horizontal: horizontal,\n width: width,\n height: height,\n nodePad: trace.node.pad,\n nodeLineColor: trace.node.line.color,\n nodeLineWidth: trace.node.line.width,\n linkLineColor: trace.link.line.color,\n linkLineWidth: trace.link.line.width,\n linkArrowLength: trace.link.arrowlen,\n valueFormat: trace.valueformat,\n valueSuffix: trace.valuesuffix,\n textFont: trace.textfont,\n translateX: domain.x[0] * layout.width + layout.margin.l,\n translateY: layout.height - domain.y[1] * layout.height + layout.margin.t,\n dragParallel: horizontal ? height : width,\n dragPerpendicular: horizontal ? width : height,\n arrangement: trace.arrangement,\n sankey: sankey,\n graph: graph,\n forceLayouts: {},\n interactionState: {\n dragInProgress: false,\n hovered: false\n }\n };\n}\n\nfunction linkModel(d, l, i) {\n var tc = tinycolor(l.color);\n var htc = tinycolor(l.hovercolor);\n var basicKey = l.source.label + '|' + l.target.label;\n var key = basicKey + '__' + i;\n\n // for event data\n l.trace = d.trace;\n l.curveNumber = d.trace.index;\n\n return {\n circular: d.circular,\n key: key,\n traceId: d.key,\n pointNumber: l.pointNumber,\n link: l,\n tinyColorHue: Color.tinyRGB(tc),\n tinyColorAlpha: tc.getAlpha(),\n tinyColorHoverHue: Color.tinyRGB(htc),\n tinyColorHoverAlpha: htc.getAlpha(),\n linkPath: linkPath,\n linkLineColor: d.linkLineColor,\n linkLineWidth: d.linkLineWidth,\n linkArrowLength: d.linkArrowLength,\n valueFormat: d.valueFormat,\n valueSuffix: d.valueSuffix,\n sankey: d.sankey,\n parent: d,\n interactionState: d.interactionState,\n flow: l.flow\n };\n}\n\nfunction createCircularClosedPathString(link, arrowLen) {\n // Using coordinates computed by d3-sankey-circular\n var pathString = '';\n var offset = link.width / 2;\n var coords = link.circularPathData;\n if(link.circularLinkType === 'top') {\n // Top path\n pathString =\n // start at the left of the target node\n 'M ' +\n (coords.targetX - arrowLen) + ' ' + (coords.targetY + offset) + ' ' +\n 'L' +\n (coords.rightInnerExtent - arrowLen) + ' ' + (coords.targetY + offset) +\n 'A' +\n (coords.rightLargeArcRadius + offset) + ' ' + (coords.rightSmallArcRadius + offset) + ' 0 0 1 ' +\n (coords.rightFullExtent - offset - arrowLen) + ' ' + (coords.targetY - coords.rightSmallArcRadius) +\n 'L' +\n (coords.rightFullExtent - offset - arrowLen) + ' ' + coords.verticalRightInnerExtent +\n 'A' +\n (coords.rightLargeArcRadius + offset) + ' ' + (coords.rightLargeArcRadius + offset) + ' 0 0 1 ' +\n (coords.rightInnerExtent - arrowLen) + ' ' + (coords.verticalFullExtent - offset) +\n 'L' +\n coords.leftInnerExtent + ' ' + (coords.verticalFullExtent - offset) +\n 'A' +\n (coords.leftLargeArcRadius + offset) + ' ' + (coords.leftLargeArcRadius + offset) + ' 0 0 1 ' +\n (coords.leftFullExtent + offset) + ' ' + coords.verticalLeftInnerExtent +\n 'L' +\n (coords.leftFullExtent + offset) + ' ' + (coords.sourceY - coords.leftSmallArcRadius) +\n 'A' +\n (coords.leftLargeArcRadius + offset) + ' ' + (coords.leftSmallArcRadius + offset) + ' 0 0 1 ' +\n coords.leftInnerExtent + ' ' + (coords.sourceY + offset) +\n 'L' +\n coords.sourceX + ' ' + (coords.sourceY + offset) +\n\n // Walking back\n 'L' +\n coords.sourceX + ' ' + (coords.sourceY - offset) +\n 'L' +\n coords.leftInnerExtent + ' ' + (coords.sourceY - offset) +\n 'A' +\n (coords.leftLargeArcRadius - offset) + ' ' + (coords.leftSmallArcRadius - offset) + ' 0 0 0 ' +\n (coords.leftFullExtent - offset) + ' ' + (coords.sourceY - coords.leftSmallArcRadius) +\n 'L' +\n (coords.leftFullExtent - offset) + ' ' + coords.verticalLeftInnerExtent +\n 'A' +\n (coords.leftLargeArcRadius - offset) + ' ' + (coords.leftLargeArcRadius - offset) + ' 0 0 0 ' +\n coords.leftInnerExtent + ' ' + (coords.verticalFullExtent + offset) +\n 'L' +\n (coords.rightInnerExtent - arrowLen) + ' ' + (coords.verticalFullExtent + offset) +\n 'A' +\n (coords.rightLargeArcRadius - offset) + ' ' + (coords.rightLargeArcRadius - offset) + ' 0 0 0 ' +\n (coords.rightFullExtent + offset - arrowLen) + ' ' + coords.verticalRightInnerExtent +\n 'L' +\n (coords.rightFullExtent + offset - arrowLen) + ' ' + (coords.targetY - coords.rightSmallArcRadius) +\n 'A' +\n (coords.rightLargeArcRadius - offset) + ' ' + (coords.rightSmallArcRadius - offset) + ' 0 0 0 ' +\n (coords.rightInnerExtent - arrowLen) + ' ' + (coords.targetY - offset) +\n 'L' +\n (coords.targetX - arrowLen) + ' ' + (coords.targetY - offset) +\n (arrowLen > 0 ? 'L' + coords.targetX + ' ' + (coords.targetY) : '') +\n 'Z';\n } else {\n // Bottom path\n pathString =\n // start at the left of the target node\n 'M ' +\n (coords.targetX - arrowLen) + ' ' + (coords.targetY - offset) + ' ' +\n 'L' +\n (coords.rightInnerExtent - arrowLen) + ' ' + (coords.targetY - offset) +\n 'A' +\n (coords.rightLargeArcRadius + offset) + ' ' + (coords.rightSmallArcRadius + offset) + ' 0 0 0 ' +\n (coords.rightFullExtent - offset - arrowLen) + ' ' + (coords.targetY + coords.rightSmallArcRadius) +\n 'L' +\n (coords.rightFullExtent - offset - arrowLen) + ' ' + coords.verticalRightInnerExtent +\n 'A' +\n (coords.rightLargeArcRadius + offset) + ' ' + (coords.rightLargeArcRadius + offset) + ' 0 0 0 ' +\n (coords.rightInnerExtent - arrowLen) + ' ' + (coords.verticalFullExtent + offset) +\n 'L' +\n coords.leftInnerExtent + ' ' + (coords.verticalFullExtent + offset) +\n 'A' +\n (coords.leftLargeArcRadius + offset) + ' ' + (coords.leftLargeArcRadius + offset) + ' 0 0 0 ' +\n (coords.leftFullExtent + offset) + ' ' + coords.verticalLeftInnerExtent +\n 'L' +\n (coords.leftFullExtent + offset) + ' ' + (coords.sourceY + coords.leftSmallArcRadius) +\n 'A' +\n (coords.leftLargeArcRadius + offset) + ' ' + (coords.leftSmallArcRadius + offset) + ' 0 0 0 ' +\n coords.leftInnerExtent + ' ' + (coords.sourceY - offset) +\n 'L' +\n coords.sourceX + ' ' + (coords.sourceY - offset) +\n\n // Walking back\n 'L' +\n coords.sourceX + ' ' + (coords.sourceY + offset) +\n 'L' +\n coords.leftInnerExtent + ' ' + (coords.sourceY + offset) +\n 'A' +\n (coords.leftLargeArcRadius - offset) + ' ' + (coords.leftSmallArcRadius - offset) + ' 0 0 1 ' +\n (coords.leftFullExtent - offset) + ' ' + (coords.sourceY + coords.leftSmallArcRadius) +\n 'L' +\n (coords.leftFullExtent - offset) + ' ' + coords.verticalLeftInnerExtent +\n 'A' +\n (coords.leftLargeArcRadius - offset) + ' ' + (coords.leftLargeArcRadius - offset) + ' 0 0 1 ' +\n coords.leftInnerExtent + ' ' + (coords.verticalFullExtent - offset) +\n 'L' +\n (coords.rightInnerExtent - arrowLen) + ' ' + (coords.verticalFullExtent - offset) +\n 'A' +\n (coords.rightLargeArcRadius - offset) + ' ' + (coords.rightLargeArcRadius - offset) + ' 0 0 1 ' +\n (coords.rightFullExtent + offset - arrowLen) + ' ' + coords.verticalRightInnerExtent +\n 'L' +\n (coords.rightFullExtent + offset - arrowLen) + ' ' + (coords.targetY + coords.rightSmallArcRadius) +\n 'A' +\n (coords.rightLargeArcRadius - offset) + ' ' + (coords.rightSmallArcRadius - offset) + ' 0 0 1 ' +\n (coords.rightInnerExtent - arrowLen) + ' ' + (coords.targetY + offset) +\n 'L' +\n (coords.targetX - arrowLen) + ' ' + (coords.targetY + offset) +\n (arrowLen > 0 ? 'L' + coords.targetX + ' ' + (coords.targetY) : '') +\n 'Z';\n }\n return pathString;\n}\n\nfunction linkPath() {\n var curvature = 0.5;\n function path(d) {\n var arrowLen = d.linkArrowLength;\n if(d.link.circular) {\n return createCircularClosedPathString(d.link, arrowLen);\n } else {\n var maxArrowLength = Math.abs((d.link.target.x0 - d.link.source.x1) / 2);\n if(arrowLen > maxArrowLength) {\n arrowLen = maxArrowLength;\n }\n var x0 = d.link.source.x1;\n var x1 = d.link.target.x0 - arrowLen;\n var xi = interpolateNumber(x0, x1);\n var x2 = xi(curvature);\n var x3 = xi(1 - curvature);\n var y0a = d.link.y0 - d.link.width / 2;\n var y0b = d.link.y0 + d.link.width / 2;\n var y1a = d.link.y1 - d.link.width / 2;\n var y1b = d.link.y1 + d.link.width / 2;\n var start = 'M' + x0 + ',' + y0a;\n var upperCurve = 'C' + x2 + ',' + y0a +\n ' ' + x3 + ',' + y1a +\n ' ' + x1 + ',' + y1a;\n var lowerCurve = 'C' + x3 + ',' + y1b +\n ' ' + x2 + ',' + y0b +\n ' ' + x0 + ',' + y0b;\n\n var rightEnd = arrowLen > 0 ? 'L' + (x1 + arrowLen) + ',' + (y1a + d.link.width / 2) : '';\n rightEnd += 'L' + x1 + ',' + y1b;\n return start + upperCurve + rightEnd + lowerCurve + 'Z';\n }\n }\n return path;\n}\n\nfunction nodeModel(d, n) {\n var tc = tinycolor(n.color);\n var zoneThicknessPad = c.nodePadAcross;\n var zoneLengthPad = d.nodePad / 2;\n n.dx = n.x1 - n.x0;\n n.dy = n.y1 - n.y0;\n var visibleThickness = n.dx;\n var visibleLength = Math.max(0.5, n.dy);\n\n var key = 'node_' + n.pointNumber;\n // If it's a group, it's mutable and should be unique\n if(n.group) {\n key = Lib.randstr();\n }\n\n // for event data\n n.trace = d.trace;\n n.curveNumber = d.trace.index;\n\n return {\n index: n.pointNumber,\n key: key,\n partOfGroup: n.partOfGroup || false,\n group: n.group,\n traceId: d.key,\n trace: d.trace,\n node: n,\n nodePad: d.nodePad,\n nodeLineColor: d.nodeLineColor,\n nodeLineWidth: d.nodeLineWidth,\n textFont: d.textFont,\n size: d.horizontal ? d.height : d.width,\n visibleWidth: Math.ceil(visibleThickness),\n visibleHeight: visibleLength,\n zoneX: -zoneThicknessPad,\n zoneY: -zoneLengthPad,\n zoneWidth: visibleThickness + 2 * zoneThicknessPad,\n zoneHeight: visibleLength + 2 * zoneLengthPad,\n labelY: d.horizontal ? n.dy / 2 + 1 : n.dx / 2 + 1,\n left: n.originalLayer === 1,\n sizeAcross: d.width,\n forceLayouts: d.forceLayouts,\n horizontal: d.horizontal,\n darkBackground: tc.getBrightness() <= 128,\n tinyColorHue: Color.tinyRGB(tc),\n tinyColorAlpha: tc.getAlpha(),\n valueFormat: d.valueFormat,\n valueSuffix: d.valueSuffix,\n sankey: d.sankey,\n graph: d.graph,\n arrangement: d.arrangement,\n uniqueNodeLabelPathId: [d.guid, d.key, key].join('_'),\n interactionState: d.interactionState,\n figure: d\n };\n}\n\n// rendering snippets\n\nfunction updateNodePositions(sankeyNode) {\n sankeyNode\n .attr('transform', function(d) {\n return strTranslate(d.node.x0.toFixed(3), (d.node.y0).toFixed(3));\n });\n}\n\nfunction updateNodeShapes(sankeyNode) {\n sankeyNode.call(updateNodePositions);\n}\n\nfunction updateShapes(sankeyNode, sankeyLink) {\n sankeyNode.call(updateNodeShapes);\n sankeyLink.attr('d', linkPath());\n}\n\nfunction sizeNode(rect) {\n rect\n .attr('width', function(d) {return d.node.x1 - d.node.x0;})\n .attr('height', function(d) {return d.visibleHeight;});\n}\n\nfunction salientEnough(d) {return (d.link.width > 1 || d.linkLineWidth > 0);}\n\nfunction sankeyTransform(d) {\n var offset = strTranslate(d.translateX, d.translateY);\n return offset + (d.horizontal ? 'matrix(1 0 0 1 0 0)' : 'matrix(0 1 1 0 0 0)');\n}\n\n// event handling\n\nfunction attachPointerEvents(selection, sankey, eventSet) {\n selection\n .on('.basic', null) // remove any preexisting handlers\n .on('mouseover.basic', function(d) {\n if(!d.interactionState.dragInProgress && !d.partOfGroup) {\n eventSet.hover(this, d, sankey);\n d.interactionState.hovered = [this, d];\n }\n })\n .on('mousemove.basic', function(d) {\n if(!d.interactionState.dragInProgress && !d.partOfGroup) {\n eventSet.follow(this, d);\n d.interactionState.hovered = [this, d];\n }\n })\n .on('mouseout.basic', function(d) {\n if(!d.interactionState.dragInProgress && !d.partOfGroup) {\n eventSet.unhover(this, d, sankey);\n d.interactionState.hovered = false;\n }\n })\n .on('click.basic', function(d) {\n if(d.interactionState.hovered) {\n eventSet.unhover(this, d, sankey);\n d.interactionState.hovered = false;\n }\n if(!d.interactionState.dragInProgress && !d.partOfGroup) {\n eventSet.select(this, d, sankey);\n }\n });\n}\n\nfunction attachDragHandler(sankeyNode, sankeyLink, callbacks, gd) {\n var dragBehavior = d3.behavior.drag()\n .origin(function(d) {\n return {\n x: d.node.x0 + d.visibleWidth / 2,\n y: d.node.y0 + d.visibleHeight / 2\n };\n })\n\n .on('dragstart', function(d) {\n if(d.arrangement === 'fixed') return;\n Lib.ensureSingle(gd._fullLayout._infolayer, 'g', 'dragcover', function(s) {\n gd._fullLayout._dragCover = s;\n });\n Lib.raiseToTop(this);\n d.interactionState.dragInProgress = d.node;\n\n saveCurrentDragPosition(d.node);\n if(d.interactionState.hovered) {\n callbacks.nodeEvents.unhover.apply(0, d.interactionState.hovered);\n d.interactionState.hovered = false;\n }\n if(d.arrangement === 'snap') {\n var forceKey = d.traceId + '|' + d.key;\n if(d.forceLayouts[forceKey]) {\n d.forceLayouts[forceKey].alpha(1);\n } else { // make a forceLayout if needed\n attachForce(sankeyNode, forceKey, d, gd);\n }\n startForce(sankeyNode, sankeyLink, d, forceKey, gd);\n }\n })\n\n .on('drag', function(d) {\n if(d.arrangement === 'fixed') return;\n var x = d3.event.x;\n var y = d3.event.y;\n if(d.arrangement === 'snap') {\n d.node.x0 = x - d.visibleWidth / 2;\n d.node.x1 = x + d.visibleWidth / 2;\n d.node.y0 = y - d.visibleHeight / 2;\n d.node.y1 = y + d.visibleHeight / 2;\n } else {\n if(d.arrangement === 'freeform') {\n d.node.x0 = x - d.visibleWidth / 2;\n d.node.x1 = x + d.visibleWidth / 2;\n }\n y = Math.max(0, Math.min(d.size - d.visibleHeight / 2, y));\n d.node.y0 = y - d.visibleHeight / 2;\n d.node.y1 = y + d.visibleHeight / 2;\n }\n\n saveCurrentDragPosition(d.node);\n if(d.arrangement !== 'snap') {\n d.sankey.update(d.graph);\n updateShapes(sankeyNode.filter(sameLayer(d)), sankeyLink);\n }\n })\n\n .on('dragend', function(d) {\n if(d.arrangement === 'fixed') return;\n d.interactionState.dragInProgress = false;\n for(var i = 0; i < d.node.childrenNodes.length; i++) {\n d.node.childrenNodes[i].x = d.node.x;\n d.node.childrenNodes[i].y = d.node.y;\n }\n if(d.arrangement !== 'snap') persistFinalNodePositions(d, gd);\n });\n\n sankeyNode\n .on('.drag', null) // remove possible previous handlers\n .call(dragBehavior);\n}\n\nfunction attachForce(sankeyNode, forceKey, d, gd) {\n // Attach force to nodes in the same column (same x coordinate)\n switchToForceFormat(d.graph.nodes);\n var nodes = d.graph.nodes\n .filter(function(n) {return n.originalX === d.node.originalX;})\n // Filter out children\n .filter(function(n) {return !n.partOfGroup;});\n d.forceLayouts[forceKey] = d3Force.forceSimulation(nodes)\n .alphaDecay(0)\n .force('collide', d3Force.forceCollide()\n .radius(function(n) {return n.dy / 2 + d.nodePad / 2;})\n .strength(1)\n .iterations(c.forceIterations))\n .force('constrain', snappingForce(sankeyNode, forceKey, nodes, d, gd))\n .stop();\n}\n\nfunction startForce(sankeyNode, sankeyLink, d, forceKey, gd) {\n window.requestAnimationFrame(function faster() {\n var i;\n for(i = 0; i < c.forceTicksPerFrame; i++) {\n d.forceLayouts[forceKey].tick();\n }\n\n var nodes = d.graph.nodes;\n switchToSankeyFormat(nodes);\n\n d.sankey.update(d.graph);\n updateShapes(sankeyNode.filter(sameLayer(d)), sankeyLink);\n\n if(d.forceLayouts[forceKey].alpha() > 0) {\n window.requestAnimationFrame(faster);\n } else {\n // Make sure the final x position is equal to its original value\n // because the force simulation will have numerical error\n var x = d.node.originalX;\n d.node.x0 = x - d.visibleWidth / 2;\n d.node.x1 = x + d.visibleWidth / 2;\n\n persistFinalNodePositions(d, gd);\n }\n });\n}\n\nfunction snappingForce(sankeyNode, forceKey, nodes, d) {\n return function _snappingForce() {\n var maxVelocity = 0;\n for(var i = 0; i < nodes.length; i++) {\n var n = nodes[i];\n if(n === d.interactionState.dragInProgress) { // constrain node position to the dragging pointer\n n.x = n.lastDraggedX;\n n.y = n.lastDraggedY;\n } else {\n n.vx = (n.originalX - n.x) / c.forceTicksPerFrame; // snap to layer\n n.y = Math.min(d.size - n.dy / 2, Math.max(n.dy / 2, n.y)); // constrain to extent\n }\n maxVelocity = Math.max(maxVelocity, Math.abs(n.vx), Math.abs(n.vy));\n }\n if(!d.interactionState.dragInProgress && maxVelocity < 0.1 && d.forceLayouts[forceKey].alpha() > 0) {\n d.forceLayouts[forceKey].alpha(0); // This will stop the animation loop\n }\n };\n}\n\n// basic data utilities\n\nfunction persistFinalNodePositions(d, gd) {\n var x = [];\n var y = [];\n for(var i = 0; i < d.graph.nodes.length; i++) {\n var nodeX = (d.graph.nodes[i].x0 + d.graph.nodes[i].x1) / 2;\n var nodeY = (d.graph.nodes[i].y0 + d.graph.nodes[i].y1) / 2;\n x.push(nodeX / d.figure.width);\n y.push(nodeY / d.figure.height);\n }\n Registry.call('_guiRestyle', gd, {\n 'node.x': [x],\n 'node.y': [y]\n }, d.trace.index)\n .then(function() {\n if(gd._fullLayout._dragCover) gd._fullLayout._dragCover.remove();\n });\n}\n\nfunction persistOriginalPlace(nodes) {\n var distinctLayerPositions = [];\n var i;\n for(i = 0; i < nodes.length; i++) {\n nodes[i].originalX = (nodes[i].x0 + nodes[i].x1) / 2;\n nodes[i].originalY = (nodes[i].y0 + nodes[i].y1) / 2;\n if(distinctLayerPositions.indexOf(nodes[i].originalX) === -1) {\n distinctLayerPositions.push(nodes[i].originalX);\n }\n }\n distinctLayerPositions.sort(function(a, b) {return a - b;});\n for(i = 0; i < nodes.length; i++) {\n nodes[i].originalLayerIndex = distinctLayerPositions.indexOf(nodes[i].originalX);\n nodes[i].originalLayer = nodes[i].originalLayerIndex / (distinctLayerPositions.length - 1);\n }\n}\n\nfunction saveCurrentDragPosition(d) {\n d.lastDraggedX = d.x0 + d.dx / 2;\n d.lastDraggedY = d.y0 + d.dy / 2;\n}\n\nfunction sameLayer(d) {\n return function(n) {return n.node.originalX === d.node.originalX;};\n}\n\nfunction switchToForceFormat(nodes) {\n // force uses x, y as centers\n for(var i = 0; i < nodes.length; i++) {\n nodes[i].y = (nodes[i].y0 + nodes[i].y1) / 2;\n nodes[i].x = (nodes[i].x0 + nodes[i].x1) / 2;\n }\n}\n\nfunction switchToSankeyFormat(nodes) {\n // sankey uses x0, x1, y0, y1\n for(var i = 0; i < nodes.length; i++) {\n nodes[i].y0 = nodes[i].y - nodes[i].dy / 2;\n nodes[i].y1 = nodes[i].y0 + nodes[i].dy;\n\n nodes[i].x0 = nodes[i].x - nodes[i].dx / 2;\n nodes[i].x1 = nodes[i].x0 + nodes[i].dx;\n }\n}\n\n// scene graph\nmodule.exports = function(gd, svg, calcData, layout, callbacks) {\n var isStatic = gd._context.staticPlot;\n\n // To prevent animation on first render\n var firstRender = false;\n Lib.ensureSingle(gd._fullLayout._infolayer, 'g', 'first-render', function() {\n firstRender = true;\n });\n\n // To prevent animation on dragging\n var dragcover = gd._fullLayout._dragCover;\n\n var styledData = calcData\n .filter(function(d) {return unwrap(d).trace.visible;})\n .map(sankeyModel.bind(null, layout));\n\n var sankey = svg.selectAll('.' + c.cn.sankey)\n .data(styledData, keyFun);\n\n sankey.exit()\n .remove();\n\n sankey.enter()\n .append('g')\n .classed(c.cn.sankey, true)\n .style('box-sizing', 'content-box')\n .style('position', 'absolute')\n .style('left', 0)\n .style('shape-rendering', 'geometricPrecision')\n .style('pointer-events', isStatic ? 'none' : 'auto')\n .attr('transform', sankeyTransform);\n\n sankey.each(function(d, i) {\n gd._fullData[i]._sankey = d;\n // Create dragbox if missing\n var dragboxClassName = 'bgsankey-' + d.trace.uid + '-' + i;\n Lib.ensureSingle(gd._fullLayout._draggers, 'rect', dragboxClassName);\n\n gd._fullData[i]._bgRect = d3.select('.' + dragboxClassName);\n\n // Style dragbox\n gd._fullData[i]._bgRect\n .style('pointer-events', isStatic ? 'none' : 'all')\n .attr('width', d.width)\n .attr('height', d.height)\n .attr('x', d.translateX)\n .attr('y', d.translateY)\n .classed('bgsankey', true)\n .style({fill: 'transparent', 'stroke-width': 0});\n });\n\n sankey.transition()\n .ease(c.ease).duration(c.duration)\n .attr('transform', sankeyTransform);\n\n var sankeyLinks = sankey.selectAll('.' + c.cn.sankeyLinks)\n .data(repeat, keyFun);\n\n sankeyLinks.enter()\n .append('g')\n .classed(c.cn.sankeyLinks, true)\n .style('fill', 'none');\n\n var sankeyLink = sankeyLinks.selectAll('.' + c.cn.sankeyLink)\n .data(function(d) {\n var links = d.graph.links;\n return links\n .filter(function(l) {return l.value;})\n .map(linkModel.bind(null, d));\n }, keyFun);\n\n sankeyLink\n .enter().append('path')\n .classed(c.cn.sankeyLink, true)\n .call(attachPointerEvents, sankey, callbacks.linkEvents);\n\n sankeyLink\n .style('stroke', function(d) {\n return salientEnough(d) ? Color.tinyRGB(tinycolor(d.linkLineColor)) : d.tinyColorHue;\n })\n .style('stroke-opacity', function(d) {\n return salientEnough(d) ? Color.opacity(d.linkLineColor) : d.tinyColorAlpha;\n })\n .style('fill', function(d) {\n return d.tinyColorHue;\n })\n .style('fill-opacity', function(d) {\n return d.tinyColorAlpha;\n })\n .style('stroke-width', function(d) {\n return salientEnough(d) ? d.linkLineWidth : 1;\n })\n .attr('d', linkPath());\n\n sankeyLink\n .style('opacity', function() { return (gd._context.staticPlot || firstRender || dragcover) ? 1 : 0;})\n .transition()\n .ease(c.ease).duration(c.duration)\n .style('opacity', 1);\n\n sankeyLink.exit()\n .transition()\n .ease(c.ease).duration(c.duration)\n .style('opacity', 0)\n .remove();\n\n var sankeyNodeSet = sankey.selectAll('.' + c.cn.sankeyNodeSet)\n .data(repeat, keyFun);\n\n sankeyNodeSet.enter()\n .append('g')\n .classed(c.cn.sankeyNodeSet, true);\n\n sankeyNodeSet\n .style('cursor', function(d) {\n switch(d.arrangement) {\n case 'fixed': return 'default';\n case 'perpendicular': return 'ns-resize';\n default: return 'move';\n }\n });\n\n var sankeyNode = sankeyNodeSet.selectAll('.' + c.cn.sankeyNode)\n .data(function(d) {\n var nodes = d.graph.nodes;\n persistOriginalPlace(nodes);\n return nodes\n .map(nodeModel.bind(null, d));\n }, keyFun);\n\n sankeyNode.enter()\n .append('g')\n .classed(c.cn.sankeyNode, true)\n .call(updateNodePositions)\n .style('opacity', function(n) { return ((gd._context.staticPlot || firstRender) && !n.partOfGroup) ? 1 : 0;});\n\n sankeyNode\n .call(attachPointerEvents, sankey, callbacks.nodeEvents)\n .call(attachDragHandler, sankeyLink, callbacks, gd); // has to be here as it binds sankeyLink\n\n sankeyNode\n .transition()\n .ease(c.ease).duration(c.duration)\n .call(updateNodePositions)\n .style('opacity', function(n) { return n.partOfGroup ? 0 : 1;});\n\n sankeyNode.exit()\n .transition()\n .ease(c.ease).duration(c.duration)\n .style('opacity', 0)\n .remove();\n\n var nodeRect = sankeyNode.selectAll('.' + c.cn.nodeRect)\n .data(repeat);\n\n nodeRect.enter()\n .append('rect')\n .classed(c.cn.nodeRect, true)\n .call(sizeNode);\n\n nodeRect\n .style('stroke-width', function(d) {return d.nodeLineWidth;})\n .style('stroke', function(d) {return Color.tinyRGB(tinycolor(d.nodeLineColor));})\n .style('stroke-opacity', function(d) {return Color.opacity(d.nodeLineColor);})\n .style('fill', function(d) {return d.tinyColorHue;})\n .style('fill-opacity', function(d) {return d.tinyColorAlpha;});\n\n nodeRect.transition()\n .ease(c.ease).duration(c.duration)\n .call(sizeNode);\n\n var nodeLabel = sankeyNode.selectAll('.' + c.cn.nodeLabel)\n .data(repeat);\n\n nodeLabel.enter()\n .append('text')\n .classed(c.cn.nodeLabel, true)\n .style('cursor', 'default');\n\n nodeLabel\n .attr('data-notex', 1) // prohibit tex interpretation until we can handle tex and regular text together\n .text(function(d) { return d.node.label; })\n .each(function(d) {\n var e = d3.select(this);\n Drawing.font(e, d.textFont);\n svgTextUtils.convertToTspans(e, gd);\n })\n .attr('text-anchor', function(d) {\n return (d.horizontal && d.left) ? 'end' : 'start';\n })\n .attr('transform', function(d) {\n var e = d3.select(this);\n // how much to shift a multi-line label to center it vertically.\n var nLines = svgTextUtils.lineCount(e);\n var blockHeight = d.textFont.size * (\n (nLines - 1) * LINE_SPACING - CAP_SHIFT\n );\n\n var posX = d.nodeLineWidth / 2 + TEXTPAD;\n var posY = ((d.horizontal ? d.visibleHeight : d.visibleWidth) - blockHeight) / 2;\n if(d.horizontal) {\n if(d.left) {\n posX = -posX;\n } else {\n posX += d.visibleWidth;\n }\n }\n\n var flipText = d.horizontal ? '' : (\n 'scale(-1,1)' + strRotate(90)\n );\n\n return strTranslate(\n d.horizontal ? posX : posY,\n d.horizontal ? posY : posX\n ) + flipText;\n });\n\n nodeLabel\n .transition()\n .ease(c.ease).duration(c.duration);\n};\n","'use strict';\n\nmodule.exports = function selectPoints(searchInfo, selectionTester) {\n var cd = searchInfo.cd;\n var selection = [];\n var fullData = cd[0].trace;\n\n var nodes = fullData._sankey.graph.nodes;\n\n for(var i = 0; i < nodes.length; i++) {\n var node = nodes[i];\n if(node.partOfGroup) continue; // Those are invisible\n\n // Position of node's centroid\n var pos = [(node.x0 + node.x1) / 2, (node.y0 + node.y1) / 2];\n\n // Swap x and y if trace is vertical\n if(fullData.orientation === 'v') pos.reverse();\n\n if(selectionTester && selectionTester.contains(pos, false, i, searchInfo)) {\n selection.push({\n pointNumber: node.pointNumber\n // TODO: add eventData\n });\n }\n }\n return selection;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\n\n// arrayOk attributes, merge them into calcdata array\nmodule.exports = function arraysToCalcdata(cd, trace) {\n // so each point knows which index it originally came from\n for(var i = 0; i < cd.length; i++) cd[i].i = i;\n\n Lib.mergeArray(trace.text, cd, 'tx');\n Lib.mergeArray(trace.texttemplate, cd, 'txt');\n Lib.mergeArray(trace.hovertext, cd, 'htx');\n Lib.mergeArray(trace.customdata, cd, 'data');\n Lib.mergeArray(trace.textposition, cd, 'tp');\n if(trace.textfont) {\n Lib.mergeArrayCastPositive(trace.textfont.size, cd, 'ts');\n Lib.mergeArray(trace.textfont.color, cd, 'tc');\n Lib.mergeArray(trace.textfont.family, cd, 'tf');\n Lib.mergeArray(trace.textfont.weight, cd, 'tw');\n Lib.mergeArray(trace.textfont.style, cd, 'ty');\n Lib.mergeArray(trace.textfont.variant, cd, 'tv');\n Lib.mergeArray(trace.textfont.textcase, cd, 'tC');\n Lib.mergeArray(trace.textfont.lineposition, cd, 'tE');\n Lib.mergeArray(trace.textfont.shadow, cd, 'tS');\n }\n\n var marker = trace.marker;\n if(marker) {\n Lib.mergeArrayCastPositive(marker.size, cd, 'ms');\n Lib.mergeArrayCastPositive(marker.opacity, cd, 'mo');\n Lib.mergeArray(marker.symbol, cd, 'mx');\n Lib.mergeArray(marker.angle, cd, 'ma');\n Lib.mergeArray(marker.standoff, cd, 'mf');\n Lib.mergeArray(marker.color, cd, 'mc');\n\n var markerLine = marker.line;\n if(marker.line) {\n Lib.mergeArray(markerLine.color, cd, 'mlc');\n Lib.mergeArrayCastPositive(markerLine.width, cd, 'mlw');\n }\n\n var markerGradient = marker.gradient;\n if(markerGradient && markerGradient.type !== 'none') {\n Lib.mergeArray(markerGradient.type, cd, 'mgt');\n Lib.mergeArray(markerGradient.color, cd, 'mgc');\n }\n }\n};\n","'use strict';\n\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar fontAttrs = require('../../plots/font_attributes');\nvar dash = require('../../components/drawing/attributes').dash;\nvar pattern = require('../../components/drawing/attributes').pattern;\n\nvar Drawing = require('../../components/drawing');\nvar constants = require('./constants');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar makeFillcolorAttr = require('./fillcolor_attribute');\n\nfunction axisPeriod(axis) {\n return {\n valType: 'any',\n dflt: 0,\n editType: 'calc',\n description: [\n 'Only relevant when the axis `type` is *date*.',\n 'Sets the period positioning in milliseconds or *M* on the ' + axis + ' axis.',\n 'Special values in the form of *M* could be used to declare',\n 'the number of months. In this case `n` must be a positive integer.'\n ].join(' ')\n };\n}\n\nfunction axisPeriod0(axis) {\n return {\n valType: 'any',\n editType: 'calc',\n description: [\n 'Only relevant when the axis `type` is *date*.',\n 'Sets the base for period positioning in milliseconds or date string on the ' + axis + ' axis.',\n 'When `' + axis + 'period` is round number of weeks,',\n 'the `' + axis + 'period0` by default would be on a Sunday i.e. 2000-01-02,',\n 'otherwise it would be at 2000-01-01.'\n ].join(' ')\n };\n}\n\nfunction axisPeriodAlignment(axis) {\n return {\n valType: 'enumerated',\n values: [\n 'start', 'middle', 'end'\n ],\n dflt: 'middle',\n editType: 'calc',\n description: [\n 'Only relevant when the axis `type` is *date*.',\n 'Sets the alignment of data points on the ' + axis + ' axis.'\n ].join(' ')\n };\n}\n\nmodule.exports = {\n x: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n anim: true,\n description: 'Sets the x coordinates.'\n },\n x0: {\n valType: 'any',\n dflt: 0,\n editType: 'calc+clearAxisTypes',\n anim: true,\n description: [\n 'Alternate to `x`.',\n 'Builds a linear space of x coordinates.',\n 'Use with `dx`',\n 'where `x0` is the starting coordinate and `dx` the step.'\n ].join(' ')\n },\n dx: {\n valType: 'number',\n dflt: 1,\n editType: 'calc',\n anim: true,\n description: [\n 'Sets the x coordinate step.',\n 'See `x0` for more info.'\n ].join(' ')\n },\n y: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n anim: true,\n description: 'Sets the y coordinates.'\n },\n y0: {\n valType: 'any',\n dflt: 0,\n editType: 'calc+clearAxisTypes',\n anim: true,\n description: [\n 'Alternate to `y`.',\n 'Builds a linear space of y coordinates.',\n 'Use with `dy`',\n 'where `y0` is the starting coordinate and `dy` the step.'\n ].join(' ')\n },\n dy: {\n valType: 'number',\n dflt: 1,\n editType: 'calc',\n anim: true,\n description: [\n 'Sets the y coordinate step.',\n 'See `y0` for more info.'\n ].join(' ')\n },\n\n xperiod: axisPeriod('x'),\n yperiod: axisPeriod('y'),\n xperiod0: axisPeriod0('x0'),\n yperiod0: axisPeriod0('y0'),\n xperiodalignment: axisPeriodAlignment('x'),\n yperiodalignment: axisPeriodAlignment('y'),\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n\n offsetgroup: {\n valType: 'string',\n dflt: '',\n editType: 'calc',\n description: [\n 'Set several traces linked to the same position axis',\n 'or matching axes to the same',\n 'offsetgroup where bars of the same position coordinate will line up.'\n ].join(' ')\n },\n\n alignmentgroup: {\n valType: 'string',\n dflt: '',\n editType: 'calc',\n description: [\n 'Set several traces linked to the same position axis',\n 'or matching axes to the same',\n 'alignmentgroup. This controls whether bars compute their positional',\n 'range dependently or independently.'\n ].join(' ')\n },\n\n stackgroup: {\n valType: 'string',\n dflt: '',\n editType: 'calc',\n description: [\n 'Set several scatter traces (on the same subplot) to the same',\n 'stackgroup in order to add their y values (or their x values if',\n '`orientation` is *h*). If blank or omitted this trace will not be',\n 'stacked. Stacking also turns `fill` on by default, using *tonexty*',\n '(*tonextx*) if `orientation` is *h* (*v*) and sets the default',\n '`mode` to *lines* irrespective of point count.',\n 'You can only stack on a numeric (linear or log) axis.',\n 'Traces in a `stackgroup` will only fill to (or be filled to) other',\n 'traces in the same group. With multiple `stackgroup`s or some',\n 'traces stacked and some not, if fill-linked traces are not already',\n 'consecutive, the later ones will be pushed down in the drawing order.'\n ].join(' ')\n },\n orientation: {\n valType: 'enumerated',\n values: ['v', 'h'],\n editType: 'calc',\n description: [\n 'Only relevant in the following cases:',\n '1. when `scattermode` is set to *group*.',\n '2. when `stackgroup` is used, and only the first',\n '`orientation` found in the `stackgroup` will be used - including',\n 'if `visible` is *legendonly* but not if it is `false`. Sets the',\n 'stacking direction. With *v* (*h*), the y (x) values of subsequent',\n 'traces are added. Also affects the default value of `fill`.'\n ].join(' ')\n },\n groupnorm: {\n valType: 'enumerated',\n values: ['', 'fraction', 'percent'],\n dflt: '',\n editType: 'calc',\n description: [\n 'Only relevant when `stackgroup` is used, and only the first',\n '`groupnorm` found in the `stackgroup` will be used - including',\n 'if `visible` is *legendonly* but not if it is `false`.',\n 'Sets the normalization for the sum of this `stackgroup`.',\n 'With *fraction*, the value of each trace at each location is',\n 'divided by the sum of all trace values at that location.',\n '*percent* is the same but multiplied by 100 to show percentages.',\n 'If there are multiple subplots, or multiple `stackgroup`s on one',\n 'subplot, each will be normalized within its own set.'\n ].join(' ')\n },\n stackgaps: {\n valType: 'enumerated',\n values: ['infer zero', 'interpolate'],\n dflt: 'infer zero',\n editType: 'calc',\n description: [\n 'Only relevant when `stackgroup` is used, and only the first',\n '`stackgaps` found in the `stackgroup` will be used - including',\n 'if `visible` is *legendonly* but not if it is `false`.',\n 'Determines how we handle locations at which other traces in this',\n 'group have data but this one does not.',\n 'With *infer zero* we insert a zero at these locations.',\n 'With *interpolate* we linearly interpolate between existing',\n 'values, and extrapolate a constant beyond the existing values.'\n // TODO - implement interrupt mode\n // '*interrupt* omits this trace from the stack at this location by',\n // 'dropping abruptly, midway between the existing and missing locations.'\n ].join(' ')\n },\n\n text: {\n valType: 'string',\n dflt: '',\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Sets text elements associated with each (x,y) pair.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s (x,y) coordinates.',\n 'If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,',\n 'these elements will be seen in the hover labels.'\n ].join(' ')\n },\n\n texttemplate: texttemplateAttrs({}, {\n\n }),\n hovertext: {\n valType: 'string',\n dflt: '',\n arrayOk: true,\n editType: 'style',\n description: [\n 'Sets hover text elements associated with each (x,y) pair.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s (x,y) coordinates.',\n 'To be seen, trace `hoverinfo` must contain a *text* flag.'\n ].join(' ')\n },\n mode: {\n valType: 'flaglist',\n flags: ['lines', 'markers', 'text'],\n extras: ['none'],\n editType: 'calc',\n description: [\n 'Determines the drawing mode for this scatter trace.',\n 'If the provided `mode` includes *text* then the `text` elements',\n 'appear at the coordinates. Otherwise, the `text` elements',\n 'appear on hover.',\n 'If there are less than ' + constants.PTS_LINESONLY + ' points',\n 'and the trace is not stacked',\n 'then the default is *lines+markers*. Otherwise, *lines*.'\n ].join(' ')\n },\n hoveron: {\n valType: 'flaglist',\n flags: ['points', 'fills'],\n editType: 'style',\n description: [\n 'Do the hover effects highlight individual points (markers or',\n 'line points) or do they highlight filled regions?',\n 'If the fill is *toself* or *tonext* and there are no markers',\n 'or text, then the default is *fills*, otherwise it is *points*.'\n ].join(' ')\n },\n hovertemplate: hovertemplateAttrs({}, {\n keys: constants.eventDataKeys\n }),\n\n line: {\n color: {\n valType: 'color',\n editType: 'style',\n anim: true,\n description: 'Sets the line color.'\n },\n width: {\n valType: 'number',\n min: 0,\n dflt: 2,\n editType: 'style',\n anim: true,\n description: 'Sets the line width (in px).'\n },\n shape: {\n valType: 'enumerated',\n values: ['linear', 'spline', 'hv', 'vh', 'hvh', 'vhv'],\n dflt: 'linear',\n editType: 'plot',\n description: [\n 'Determines the line shape.',\n 'With *spline* the lines are drawn using spline interpolation.',\n 'The other available values correspond to step-wise line shapes.'\n ].join(' ')\n },\n smoothing: {\n valType: 'number',\n min: 0,\n max: 1.3,\n dflt: 1,\n editType: 'plot',\n description: [\n 'Has an effect only if `shape` is set to *spline*',\n 'Sets the amount of smoothing.',\n '*0* corresponds to no smoothing (equivalent to a *linear* shape).'\n ].join(' ')\n },\n dash: extendFlat({}, dash, {editType: 'style'}),\n backoff: { // we want to have a similar option for the start of the line\n valType: 'number',\n min: 0,\n dflt: 'auto',\n arrayOk: true,\n editType: 'plot',\n description: [\n 'Sets the line back off from the end point of the nth line segment (in px).',\n 'This option is useful e.g. to avoid overlap with arrowhead markers.',\n 'With *auto* the lines would trim before markers if `marker.angleref` is set to *previous*.'\n ].join(' ')\n },\n simplify: {\n valType: 'boolean',\n dflt: true,\n editType: 'plot',\n description: [\n 'Simplifies lines by removing nearly-collinear points. When transitioning',\n 'lines, it may be desirable to disable this so that the number of points',\n 'along the resulting SVG path is unaffected.'\n ].join(' ')\n },\n editType: 'plot'\n },\n\n connectgaps: {\n valType: 'boolean',\n dflt: false,\n editType: 'calc',\n description: [\n 'Determines whether or not gaps',\n '(i.e. {nan} or missing values)',\n 'in the provided data arrays are connected.'\n ].join(' ')\n },\n cliponaxis: {\n valType: 'boolean',\n dflt: true,\n editType: 'plot',\n description: [\n 'Determines whether or not markers and text nodes',\n 'are clipped about the subplot axes.',\n 'To show markers and text nodes above axis lines and tick labels,',\n 'make sure to set `xaxis.layer` and `yaxis.layer` to *below traces*.'\n ].join(' ')\n },\n\n fill: {\n valType: 'enumerated',\n values: ['none', 'tozeroy', 'tozerox', 'tonexty', 'tonextx', 'toself', 'tonext'],\n editType: 'calc',\n description: [\n 'Sets the area to fill with a solid color.',\n 'Defaults to *none* unless this trace is stacked, then it gets',\n '*tonexty* (*tonextx*) if `orientation` is *v* (*h*)',\n 'Use with `fillcolor` if not *none*.',\n '*tozerox* and *tozeroy* fill to x=0 and y=0 respectively.',\n '*tonextx* and *tonexty* fill between the endpoints of this',\n 'trace and the endpoints of the trace before it, connecting those',\n 'endpoints with straight lines (to make a stacked area graph);',\n 'if there is no trace before it, they behave like *tozerox* and',\n '*tozeroy*.',\n '*toself* connects the endpoints of the trace (or each segment',\n 'of the trace if it has gaps) into a closed shape.',\n '*tonext* fills the space between two traces if one completely',\n 'encloses the other (eg consecutive contour lines), and behaves like',\n '*toself* if there is no trace before it. *tonext* should not be',\n 'used if one trace does not enclose the other.',\n 'Traces in a `stackgroup` will only fill to (or be filled to) other',\n 'traces in the same group. With multiple `stackgroup`s or some',\n 'traces stacked and some not, if fill-linked traces are not already',\n 'consecutive, the later ones will be pushed down in the drawing order.'\n ].join(' ')\n },\n fillcolor: makeFillcolorAttr(true),\n fillgradient: extendFlat({\n type: {\n valType: 'enumerated',\n values: ['radial', 'horizontal', 'vertical', 'none'],\n dflt: 'none',\n editType: 'calc',\n description: [\n 'Sets the type/orientation of the color gradient for the fill.',\n 'Defaults to *none*.'\n ].join(' ')\n },\n start: {\n valType: 'number',\n editType: 'calc',\n description: [\n 'Sets the gradient start value.',\n 'It is given as the absolute position on the axis determined by',\n 'the orientiation. E.g., if orientation is *horizontal*, the',\n 'gradient will be horizontal and start from the x-position',\n 'given by start. If omitted, the gradient starts at the lowest',\n 'value of the trace along the respective axis.',\n 'Ignored if orientation is *radial*.'\n ].join(' ')\n },\n stop: {\n valType: 'number',\n editType: 'calc',\n description: [\n 'Sets the gradient end value.',\n 'It is given as the absolute position on the axis determined by',\n 'the orientiation. E.g., if orientation is *horizontal*, the',\n 'gradient will be horizontal and end at the x-position',\n 'given by end. If omitted, the gradient ends at the highest',\n 'value of the trace along the respective axis.',\n 'Ignored if orientation is *radial*.'\n ].join(' ')\n },\n colorscale: {\n valType: 'colorscale',\n editType: 'style',\n description: [\n 'Sets the fill gradient colors as a color scale.',\n 'The color scale is interpreted as a gradient',\n 'applied in the direction specified by *orientation*,',\n 'from the lowest to the highest value of the scatter',\n 'plot along that axis, or from the center to the most',\n 'distant point from it, if orientation is *radial*.'\n ].join(' ')\n },\n editType: 'calc',\n description: [\n 'Sets a fill gradient.',\n 'If not specified, the fillcolor is used instead.'\n ].join(' ')\n }),\n fillpattern: pattern,\n marker: extendFlat({\n symbol: {\n valType: 'enumerated',\n values: Drawing.symbolList,\n dflt: 'circle',\n arrayOk: true,\n editType: 'style',\n description: [\n 'Sets the marker symbol type.',\n 'Adding 100 is equivalent to appending *-open* to a symbol name.',\n 'Adding 200 is equivalent to appending *-dot* to a symbol name.',\n 'Adding 300 is equivalent to appending *-open-dot*',\n 'or *dot-open* to a symbol name.'\n ].join(' ')\n },\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n arrayOk: true,\n editType: 'style',\n anim: true,\n description: 'Sets the marker opacity.'\n },\n angle: {\n valType: 'angle',\n dflt: 0,\n arrayOk: true,\n editType: 'plot',\n anim: false, // TODO: possibly set to true in future\n description: [\n 'Sets the marker angle in respect to `angleref`.'\n ].join(' ')\n },\n angleref: {\n valType: 'enumerated',\n values: ['previous', 'up'],\n dflt: 'up',\n editType: 'plot',\n anim: false,\n description: [\n 'Sets the reference for marker angle.',\n 'With *previous*, angle 0 points along the line from the previous point to this one.',\n 'With *up*, angle 0 points toward the top of the screen.'\n ].join(' ')\n },\n standoff: {\n valType: 'number',\n min: 0,\n dflt: 0,\n arrayOk: true,\n editType: 'plot',\n anim: true,\n description: [\n 'Moves the marker away from the data point in the direction of `angle` (in px).',\n 'This can be useful for example if you have another marker at this',\n 'location and you want to point an arrowhead marker at it.'\n ].join(' ')\n },\n size: {\n valType: 'number',\n min: 0,\n dflt: 6,\n arrayOk: true,\n editType: 'calc',\n anim: true,\n description: 'Sets the marker size (in px).'\n },\n maxdisplayed: {\n valType: 'number',\n min: 0,\n dflt: 0,\n editType: 'plot',\n description: [\n 'Sets a maximum number of points to be drawn on the graph.',\n '*0* corresponds to no limit.'\n ].join(' ')\n },\n sizeref: {\n valType: 'number',\n dflt: 1,\n editType: 'calc',\n description: [\n 'Has an effect only if `marker.size` is set to a numerical array.',\n 'Sets the scale factor used to determine the rendered size of',\n 'marker points. Use with `sizemin` and `sizemode`.'\n ].join(' ')\n },\n sizemin: {\n valType: 'number',\n min: 0,\n dflt: 0,\n editType: 'calc',\n description: [\n 'Has an effect only if `marker.size` is set to a numerical array.',\n 'Sets the minimum size (in px) of the rendered marker points.'\n ].join(' ')\n },\n sizemode: {\n valType: 'enumerated',\n values: ['diameter', 'area'],\n dflt: 'diameter',\n editType: 'calc',\n description: [\n 'Has an effect only if `marker.size` is set to a numerical array.',\n 'Sets the rule for which the data in `size` is converted',\n 'to pixels.'\n ].join(' ')\n },\n\n line: extendFlat({\n width: {\n valType: 'number',\n min: 0,\n arrayOk: true,\n editType: 'style',\n anim: true,\n description: 'Sets the width (in px) of the lines bounding the marker points.'\n },\n editType: 'calc'\n },\n colorScaleAttrs('marker.line', {anim: true})\n ),\n gradient: {\n type: {\n valType: 'enumerated',\n values: ['radial', 'horizontal', 'vertical', 'none'],\n arrayOk: true,\n dflt: 'none',\n editType: 'calc',\n description: [\n 'Sets the type of gradient used to fill the markers'\n ].join(' ')\n },\n color: {\n valType: 'color',\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Sets the final color of the gradient fill:',\n 'the center color for radial, the right for horizontal,',\n 'or the bottom for vertical.',\n ].join(' ')\n },\n editType: 'calc'\n },\n editType: 'calc'\n },\n colorScaleAttrs('marker', {anim: true})\n ),\n selected: {\n marker: {\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n editType: 'style',\n description: 'Sets the marker opacity of selected points.'\n },\n color: {\n valType: 'color',\n editType: 'style',\n description: 'Sets the marker color of selected points.'\n },\n size: {\n valType: 'number',\n min: 0,\n editType: 'style',\n description: 'Sets the marker size of selected points.'\n },\n editType: 'style'\n },\n textfont: {\n color: {\n valType: 'color',\n editType: 'style',\n description: 'Sets the text font color of selected points.'\n },\n editType: 'style'\n },\n editType: 'style'\n },\n unselected: {\n marker: {\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n editType: 'style',\n description: 'Sets the marker opacity of unselected points, applied only when a selection exists.'\n },\n color: {\n valType: 'color',\n editType: 'style',\n description: 'Sets the marker color of unselected points, applied only when a selection exists.'\n },\n size: {\n valType: 'number',\n min: 0,\n editType: 'style',\n description: 'Sets the marker size of unselected points, applied only when a selection exists.'\n },\n editType: 'style'\n },\n textfont: {\n color: {\n valType: 'color',\n editType: 'style',\n description: 'Sets the text font color of unselected points, applied only when a selection exists.'\n },\n editType: 'style'\n },\n editType: 'style'\n },\n\n textposition: {\n valType: 'enumerated',\n values: [\n 'top left', 'top center', 'top right',\n 'middle left', 'middle center', 'middle right',\n 'bottom left', 'bottom center', 'bottom right'\n ],\n dflt: 'middle center',\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Sets the positions of the `text` elements',\n 'with respects to the (x,y) coordinates.'\n ].join(' ')\n },\n textfont: fontAttrs({\n editType: 'calc',\n colorEditType: 'style',\n arrayOk: true,\n description: 'Sets the text font.'\n }),\n zorder: {\n valType: 'integer',\n dflt: 0,\n editType: 'plot',\n description: [\n 'Sets the layer on which this trace is displayed, relative to',\n 'other SVG traces on the same subplot. SVG traces with higher `zorder`',\n 'appear in front of those with lower `zorder`.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar Lib = require('../../lib');\n\nvar Axes = require('../../plots/cartesian/axes');\nvar alignPeriod = require('../../plots/cartesian/align_period');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nvar subTypes = require('./subtypes');\nvar calcColorscale = require('./colorscale_calc');\nvar arraysToCalcdata = require('./arrays_to_calcdata');\nvar calcSelection = require('./calc_selection');\n\nfunction calc(gd, trace) {\n var fullLayout = gd._fullLayout;\n var xa = trace._xA = Axes.getFromId(gd, trace.xaxis || 'x', 'x');\n var ya = trace._yA = Axes.getFromId(gd, trace.yaxis || 'y', 'y');\n var origX = xa.makeCalcdata(trace, 'x');\n var origY = ya.makeCalcdata(trace, 'y');\n var xObj = alignPeriod(trace, xa, 'x', origX);\n var yObj = alignPeriod(trace, ya, 'y', origY);\n var x = xObj.vals;\n var y = yObj.vals;\n\n var serieslen = trace._length;\n var cd = new Array(serieslen);\n var ids = trace.ids;\n var stackGroupOpts = getStackOpts(trace, fullLayout, xa, ya);\n var interpolateGaps = false;\n var isV, i, j, k, interpolate, vali;\n\n setFirstScatter(fullLayout, trace);\n\n var xAttr = 'x';\n var yAttr = 'y';\n var posAttr;\n if(stackGroupOpts) {\n Lib.pushUnique(stackGroupOpts.traceIndices, trace._expandedIndex);\n isV = stackGroupOpts.orientation === 'v';\n\n // size, like we use for bar\n if(isV) {\n yAttr = 's';\n posAttr = 'x';\n } else {\n xAttr = 's';\n posAttr = 'y';\n }\n interpolate = stackGroupOpts.stackgaps === 'interpolate';\n } else {\n var ppad = calcMarkerSize(trace, serieslen);\n calcAxisExpansion(gd, trace, xa, ya, x, y, ppad);\n }\n\n var hasPeriodX = !!trace.xperiodalignment;\n var hasPeriodY = !!trace.yperiodalignment;\n\n for(i = 0; i < serieslen; i++) {\n var cdi = cd[i] = {};\n var xValid = isNumeric(x[i]);\n var yValid = isNumeric(y[i]);\n if(xValid && yValid) {\n cdi[xAttr] = x[i];\n cdi[yAttr] = y[i];\n\n if(hasPeriodX) {\n cdi.orig_x = origX[i]; // used by hover\n cdi.xEnd = xObj.ends[i];\n cdi.xStart = xObj.starts[i];\n }\n if(hasPeriodY) {\n cdi.orig_y = origY[i]; // used by hover\n cdi.yEnd = yObj.ends[i];\n cdi.yStart = yObj.starts[i];\n }\n } else if(stackGroupOpts && (isV ? xValid : yValid)) {\n // if we're stacking we need to hold on to all valid positions\n // even with invalid sizes\n\n cdi[posAttr] = isV ? x[i] : y[i];\n cdi.gap = true;\n if(interpolate) {\n cdi.s = BADNUM;\n interpolateGaps = true;\n } else {\n cdi.s = 0;\n }\n } else {\n cdi[xAttr] = cdi[yAttr] = BADNUM;\n }\n\n if(ids) {\n cdi.id = String(ids[i]);\n }\n }\n\n arraysToCalcdata(cd, trace);\n calcColorscale(gd, trace);\n calcSelection(cd, trace);\n\n if(stackGroupOpts) {\n // remove bad positions and sort\n // note that original indices get added to cd in arraysToCalcdata\n i = 0;\n while(i < cd.length) {\n if(cd[i][posAttr] === BADNUM) {\n cd.splice(i, 1);\n } else i++;\n }\n\n Lib.sort(cd, function(a, b) {\n return (a[posAttr] - b[posAttr]) || (a.i - b.i);\n });\n\n if(interpolateGaps) {\n // first fill the beginning with constant from the first point\n i = 0;\n while(i < cd.length - 1 && cd[i].gap) {\n i++;\n }\n vali = cd[i].s;\n if(!vali) vali = cd[i].s = 0; // in case of no data AT ALL in this trace - use 0\n for(j = 0; j < i; j++) {\n cd[j].s = vali;\n }\n // then fill the end with constant from the last point\n k = cd.length - 1;\n while(k > i && cd[k].gap) {\n k--;\n }\n vali = cd[k].s;\n for(j = cd.length - 1; j > k; j--) {\n cd[j].s = vali;\n }\n // now interpolate internal gaps linearly\n while(i < k) {\n i++;\n if(cd[i].gap) {\n j = i + 1;\n while(cd[j].gap) {\n j++;\n }\n var pos0 = cd[i - 1][posAttr];\n var size0 = cd[i - 1].s;\n var m = (cd[j].s - size0) / (cd[j][posAttr] - pos0);\n while(i < j) {\n cd[i].s = size0 + (cd[i][posAttr] - pos0) * m;\n i++;\n }\n }\n }\n }\n }\n\n return cd;\n}\n\nfunction calcAxisExpansion(gd, trace, xa, ya, x, y, ppad) {\n var serieslen = trace._length;\n var fullLayout = gd._fullLayout;\n var xId = xa._id;\n var yId = ya._id;\n var firstScatter = fullLayout._firstScatter[firstScatterGroup(trace)] === trace.uid;\n var stackOrientation = (getStackOpts(trace, fullLayout, xa, ya) || {}).orientation;\n var fill = trace.fill;\n\n // cancel minimum tick spacings (only applies to bars and boxes)\n xa._minDtick = 0;\n ya._minDtick = 0;\n\n // check whether bounds should be tight, padded, extended to zero...\n // most cases both should be padded on both ends, so start with that.\n var xOptions = {padded: true};\n var yOptions = {padded: true};\n\n if(ppad) {\n xOptions.ppad = yOptions.ppad = ppad;\n }\n\n // TODO: text size\n\n var openEnded = serieslen < 2 || (x[0] !== x[serieslen - 1]) || (y[0] !== y[serieslen - 1]);\n\n if(openEnded && (\n (fill === 'tozerox') ||\n ((fill === 'tonextx') && (firstScatter || stackOrientation === 'h'))\n )) {\n // include zero (tight) and extremes (padded) if fill to zero\n // (unless the shape is closed, then it's just filling the shape regardless)\n\n xOptions.tozero = true;\n } else if(!(trace.error_y || {}).visible && (\n // if no error bars, markers or text, or fill to y=0 remove x padding\n\n (fill === 'tonexty' || fill === 'tozeroy') ||\n (!subTypes.hasMarkers(trace) && !subTypes.hasText(trace))\n )) {\n xOptions.padded = false;\n xOptions.ppad = 0;\n }\n\n if(openEnded && (\n (fill === 'tozeroy') ||\n ((fill === 'tonexty') && (firstScatter || stackOrientation === 'v'))\n )) {\n // now check for y - rather different logic, though still mostly padded both ends\n // include zero (tight) and extremes (padded) if fill to zero\n // (unless the shape is closed, then it's just filling the shape regardless)\n\n yOptions.tozero = true;\n } else if(fill === 'tonextx' || fill === 'tozerox') {\n // tight y: any x fill\n\n yOptions.padded = false;\n }\n\n // N.B. asymmetric splom traces call this with blank {} xa or ya\n if(xId) trace._extremes[xId] = Axes.findExtremes(xa, x, xOptions);\n if(yId) trace._extremes[yId] = Axes.findExtremes(ya, y, yOptions);\n}\n\nfunction calcMarkerSize(trace, serieslen) {\n if(!subTypes.hasMarkers(trace)) return;\n\n // Treat size like x or y arrays --- Run d2c\n // this needs to go before ppad computation\n var marker = trace.marker;\n var sizeref = 1.6 * (trace.marker.sizeref || 1);\n var markerTrans;\n\n if(trace.marker.sizemode === 'area') {\n markerTrans = function(v) {\n return Math.max(Math.sqrt((v || 0) / sizeref), 3);\n };\n } else {\n markerTrans = function(v) {\n return Math.max((v || 0) / sizeref, 3);\n };\n }\n\n if(Lib.isArrayOrTypedArray(marker.size)) {\n // I tried auto-type but category and dates dont make much sense.\n var ax = {type: 'linear'};\n Axes.setConvert(ax);\n\n var s = ax.makeCalcdata(trace.marker, 'size');\n\n var sizeOut = new Array(serieslen);\n for(var i = 0; i < serieslen; i++) {\n sizeOut[i] = markerTrans(s[i]);\n }\n return sizeOut;\n } else {\n return markerTrans(marker.size);\n }\n}\n\n/**\n * mark the first scatter trace for each subplot\n * note that scatter and scattergl each get their own first trace\n * note also that I'm doing this during calc rather than supplyDefaults\n * so I don't need to worry about transforms, but if we ever do\n * per-trace calc this will get confused.\n */\nfunction setFirstScatter(fullLayout, trace) {\n var group = firstScatterGroup(trace);\n var firstScatter = fullLayout._firstScatter;\n if(!firstScatter[group]) firstScatter[group] = trace.uid;\n}\n\nfunction firstScatterGroup(trace) {\n var stackGroup = trace.stackgroup;\n return trace.xaxis + trace.yaxis + trace.type +\n (stackGroup ? '-' + stackGroup : '');\n}\n\nfunction getStackOpts(trace, fullLayout, xa, ya) {\n var stackGroup = trace.stackgroup;\n if(!stackGroup) return;\n var stackOpts = fullLayout._scatterStackOpts[xa._id + ya._id][stackGroup];\n var stackAx = stackOpts.orientation === 'v' ? ya : xa;\n // Allow stacking only on numeric axes\n // calc is a little late to be figuring this out, but during supplyDefaults\n // we don't know the axis type yet\n if(stackAx.type === 'linear' || stackAx.type === 'log') return stackOpts;\n}\n\nmodule.exports = {\n calc: calc,\n calcMarkerSize: calcMarkerSize,\n calcAxisExpansion: calcAxisExpansion,\n setFirstScatter: setFirstScatter,\n getStackOpts: getStackOpts\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nmodule.exports = function calcSelection(cd, trace) {\n if(Lib.isArrayOrTypedArray(trace.selectedpoints)) {\n Lib.tagSelected(cd, trace);\n }\n};\n","'use strict';\n\nvar hasColorscale = require('../../components/colorscale/helpers').hasColorscale;\nvar calcColorscale = require('../../components/colorscale/calc');\n\nvar subTypes = require('./subtypes');\n\nmodule.exports = function calcMarkerColorscale(gd, trace) {\n if(subTypes.hasLines(trace) && hasColorscale(trace, 'line')) {\n calcColorscale(gd, trace, {\n vals: trace.line.color,\n containerStr: 'line',\n cLetter: 'c'\n });\n }\n\n if(subTypes.hasMarkers(trace)) {\n if(hasColorscale(trace, 'marker')) {\n calcColorscale(gd, trace, {\n vals: trace.marker.color,\n containerStr: 'marker',\n cLetter: 'c'\n });\n }\n if(hasColorscale(trace, 'marker.line')) {\n calcColorscale(gd, trace, {\n vals: trace.marker.line.color,\n containerStr: 'marker.line',\n cLetter: 'c'\n });\n }\n }\n};\n","'use strict';\n\nmodule.exports = {\n PTS_LINESONLY: 20,\n\n // fixed parameters of clustering and clipping algorithms\n\n // fraction of clustering tolerance \"so close we don't even consider it a new point\"\n minTolerance: 0.2,\n // how fast does clustering tolerance increase as you get away from the visible region\n toleranceGrowth: 10,\n\n // number of viewport sizes away from the visible region\n // at which we clip all lines to the perimeter\n maxScreensAway: 20,\n\n eventDataKeys: []\n};\n","'use strict';\n\nvar calc = require('./calc');\nvar setGroupPositions = require('../bar/cross_trace_calc').setGroupPositions;\n\nfunction groupCrossTraceCalc(gd, plotinfo) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n var fullLayout = gd._fullLayout;\n var fullTraces = gd._fullData;\n var calcTraces = gd.calcdata;\n var calcTracesHorz = [];\n var calcTracesVert = [];\n\n for(var i = 0; i < fullTraces.length; i++) {\n var fullTrace = fullTraces[i];\n if(\n fullTrace.visible === true &&\n fullTrace.type === 'scatter' &&\n fullTrace.xaxis === xa._id &&\n fullTrace.yaxis === ya._id\n ) {\n if(fullTrace.orientation === 'h') {\n calcTracesHorz.push(calcTraces[i]);\n } else if(fullTrace.orientation === 'v') { // check for v since certain scatter traces may not have an orientation\n calcTracesVert.push(calcTraces[i]);\n }\n }\n }\n\n var opts = {\n mode: fullLayout.scattermode,\n gap: fullLayout.scattergap\n };\n\n setGroupPositions(gd, xa, ya, calcTracesVert, opts);\n setGroupPositions(gd, ya, xa, calcTracesHorz, opts);\n}\n\n/*\n * Scatter stacking & normalization calculations\n * runs per subplot, and can handle multiple stacking groups\n */\n\nmodule.exports = function crossTraceCalc(gd, plotinfo) {\n if(gd._fullLayout.scattermode === 'group') {\n groupCrossTraceCalc(gd, plotinfo);\n }\n\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var subplot = xa._id + ya._id;\n\n var subplotStackOpts = gd._fullLayout._scatterStackOpts[subplot];\n if(!subplotStackOpts) return;\n\n var calcTraces = gd.calcdata;\n\n var i, j, k, i2, cd, cd0, posj, sumj, norm;\n var groupOpts, interpolate, groupnorm, posAttr, valAttr;\n var hasAnyBlanks;\n\n for(var stackGroup in subplotStackOpts) {\n groupOpts = subplotStackOpts[stackGroup];\n var indices = groupOpts.traceIndices;\n\n // can get here with no indices if the stack axis is non-numeric\n if(!indices.length) continue;\n\n interpolate = groupOpts.stackgaps === 'interpolate';\n groupnorm = groupOpts.groupnorm;\n if(groupOpts.orientation === 'v') {\n posAttr = 'x';\n valAttr = 'y';\n } else {\n posAttr = 'y';\n valAttr = 'x';\n }\n hasAnyBlanks = new Array(indices.length);\n for(i = 0; i < hasAnyBlanks.length; i++) {\n hasAnyBlanks[i] = false;\n }\n\n // Collect the complete set of all positions across ALL traces.\n // Start with the first trace, then interleave items from later traces\n // as needed.\n // Fill in mising items as we go.\n cd0 = calcTraces[indices[0]];\n var allPositions = new Array(cd0.length);\n for(i = 0; i < cd0.length; i++) {\n allPositions[i] = cd0[i][posAttr];\n }\n\n for(i = 1; i < indices.length; i++) {\n cd = calcTraces[indices[i]];\n\n for(j = k = 0; j < cd.length; j++) {\n posj = cd[j][posAttr];\n for(; posj > allPositions[k] && k < allPositions.length; k++) {\n // the current trace is missing a position from some previous trace(s)\n insertBlank(cd, j, allPositions[k], i, hasAnyBlanks, interpolate, posAttr);\n j++;\n }\n if(posj !== allPositions[k]) {\n // previous trace(s) are missing a position from the current trace\n for(i2 = 0; i2 < i; i2++) {\n insertBlank(calcTraces[indices[i2]], k, posj, i2, hasAnyBlanks, interpolate, posAttr);\n }\n allPositions.splice(k, 0, posj);\n }\n k++;\n }\n for(; k < allPositions.length; k++) {\n insertBlank(cd, j, allPositions[k], i, hasAnyBlanks, interpolate, posAttr);\n j++;\n }\n }\n\n var serieslen = allPositions.length;\n\n // stack (and normalize)!\n for(j = 0; j < cd0.length; j++) {\n sumj = cd0[j][valAttr] = cd0[j].s;\n for(i = 1; i < indices.length; i++) {\n cd = calcTraces[indices[i]];\n cd[0].trace._rawLength = cd[0].trace._length;\n cd[0].trace._length = serieslen;\n sumj += cd[j].s;\n cd[j][valAttr] = sumj;\n }\n\n if(groupnorm) {\n norm = ((groupnorm === 'fraction') ? sumj : (sumj / 100)) || 1;\n for(i = 0; i < indices.length; i++) {\n var cdj = calcTraces[indices[i]][j];\n cdj[valAttr] /= norm;\n cdj.sNorm = cdj.s / norm;\n }\n }\n }\n\n // autorange\n for(i = 0; i < indices.length; i++) {\n cd = calcTraces[indices[i]];\n var trace = cd[0].trace;\n var ppad = calc.calcMarkerSize(trace, trace._rawLength);\n var arrayPad = Array.isArray(ppad);\n if((ppad && hasAnyBlanks[i]) || arrayPad) {\n var ppadRaw = ppad;\n ppad = new Array(serieslen);\n for(j = 0; j < serieslen; j++) {\n ppad[j] = cd[j].gap ? 0 : (arrayPad ? ppadRaw[cd[j].i] : ppadRaw);\n }\n }\n var x = new Array(serieslen);\n var y = new Array(serieslen);\n for(j = 0; j < serieslen; j++) {\n x[j] = cd[j].x;\n y[j] = cd[j].y;\n }\n calc.calcAxisExpansion(gd, trace, xa, ya, x, y, ppad);\n\n // while we're here (in a loop over all traces in the stack)\n // record the orientation, so hover can find it easily\n cd[0].t.orientation = groupOpts.orientation;\n }\n }\n};\n\nfunction insertBlank(calcTrace, index, position, traceIndex, hasAnyBlanks, interpolate, posAttr) {\n hasAnyBlanks[traceIndex] = true;\n var newEntry = {\n i: null,\n gap: true,\n s: 0\n };\n newEntry[posAttr] = position;\n calcTrace.splice(index, 0, newEntry);\n // Even if we're not interpolating, if one trace has multiple\n // values at the same position and this trace only has one value there,\n // we just duplicate that one value rather than insert a zero.\n // We also make it look like a real point - because it's ambiguous which\n // one really is the real one!\n if(index && position === calcTrace[index - 1][posAttr]) {\n var prevEntry = calcTrace[index - 1];\n newEntry.s = prevEntry.s;\n // TODO is it going to cause any problems to have multiple\n // calcdata points with the same index?\n newEntry.i = prevEntry.i;\n newEntry.gap = prevEntry.gap;\n } else if(interpolate) {\n newEntry.s = getInterp(calcTrace, index, position, posAttr);\n }\n if(!index) {\n // t and trace need to stay on the first cd entry\n calcTrace[0].t = calcTrace[1].t;\n calcTrace[0].trace = calcTrace[1].trace;\n delete calcTrace[1].t;\n delete calcTrace[1].trace;\n }\n}\n\nfunction getInterp(calcTrace, index, position, posAttr) {\n var pt0 = calcTrace[index - 1];\n var pt1 = calcTrace[index + 1];\n if(!pt1) return pt0.s;\n if(!pt0) return pt1.s;\n return pt0.s + (pt1.s - pt0.s) * (position - pt0[posAttr]) / (pt1[posAttr] - pt0[posAttr]);\n}\n","'use strict';\n\nvar Lib = require('../../lib');\nvar handleGroupingDefaults = require('./grouping_defaults');\nvar attributes = require('./attributes');\n\n// remove opacity for any trace that has a fill or is filled to\nmodule.exports = function crossTraceDefaults(fullData, fullLayout) {\n var traceIn, traceOut, i;\n\n function coerce(attr) {\n return Lib.coerce(traceOut._input, traceOut, attributes, attr);\n }\n\n if(fullLayout.scattermode === 'group') {\n for(i = 0; i < fullData.length; i++) {\n traceOut = fullData[i];\n\n if(traceOut.type === 'scatter') {\n traceIn = traceOut._input;\n handleGroupingDefaults(traceIn, traceOut, fullLayout, coerce);\n }\n }\n }\n\n for(i = 0; i < fullData.length; i++) {\n var tracei = fullData[i];\n if(tracei.type !== 'scatter') continue;\n\n var filli = tracei.fill;\n if(filli === 'none' || filli === 'toself') continue;\n\n tracei.opacity = undefined;\n\n if(filli === 'tonexty' || filli === 'tonextx') {\n for(var j = i - 1; j >= 0; j--) {\n var tracej = fullData[j];\n\n if((tracej.type === 'scatter') &&\n (tracej.xaxis === tracei.xaxis) &&\n (tracej.yaxis === tracei.yaxis)) {\n tracej.opacity = undefined;\n break;\n }\n }\n }\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\n\nvar attributes = require('./attributes');\nvar constants = require('./constants');\nvar subTypes = require('./subtypes');\nvar handleXYDefaults = require('./xy_defaults');\nvar handlePeriodDefaults = require('./period_defaults');\nvar handleStackDefaults = require('./stack_defaults');\nvar handleMarkerDefaults = require('./marker_defaults');\nvar handleLineDefaults = require('./line_defaults');\nvar handleLineShapeDefaults = require('./line_shape_defaults');\nvar handleTextDefaults = require('./text_defaults');\nvar handleFillColorDefaults = require('./fillcolor_defaults');\nvar coercePattern = require('../../lib').coercePattern;\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleXYDefaults(traceIn, traceOut, layout, coerce);\n if(!len) traceOut.visible = false;\n\n if(!traceOut.visible) return;\n\n handlePeriodDefaults(traceIn, traceOut, layout, coerce);\n coerce('xhoverformat');\n coerce('yhoverformat');\n\n coerce('zorder');\n\n var stackGroupOpts = handleStackDefaults(traceIn, traceOut, layout, coerce);\n if(\n layout.scattermode === 'group' &&\n traceOut.orientation === undefined\n ) {\n coerce('orientation', 'v');\n }\n\n var defaultMode = !stackGroupOpts && (len < constants.PTS_LINESONLY) ?\n 'lines+markers' : 'lines';\n coerce('text');\n coerce('hovertext');\n coerce('mode', defaultMode);\n\n if(subTypes.hasMarkers(traceOut)) {\n handleMarkerDefaults(traceIn, traceOut, defaultColor, layout, coerce, {gradient: true});\n }\n\n if(subTypes.hasLines(traceOut)) {\n handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce, {backoff: true});\n handleLineShapeDefaults(traceIn, traceOut, coerce);\n coerce('connectgaps');\n coerce('line.simplify');\n }\n\n if(subTypes.hasText(traceOut)) {\n coerce('texttemplate');\n handleTextDefaults(traceIn, traceOut, layout, coerce);\n }\n\n var dfltHoverOn = [];\n\n if(subTypes.hasMarkers(traceOut) || subTypes.hasText(traceOut)) {\n coerce('cliponaxis');\n coerce('marker.maxdisplayed');\n dfltHoverOn.push('points');\n }\n\n // It's possible for this default to be changed by a later trace.\n // We handle that case in some hacky code inside handleStackDefaults.\n coerce('fill', stackGroupOpts ? stackGroupOpts.fillDflt : 'none');\n if(traceOut.fill !== 'none') {\n handleFillColorDefaults(traceIn, traceOut, defaultColor, coerce, {\n moduleHasFillgradient: true\n });\n if(!subTypes.hasLines(traceOut)) handleLineShapeDefaults(traceIn, traceOut, coerce);\n coercePattern(coerce, 'fillpattern', traceOut.fillcolor, false);\n }\n\n var lineColor = (traceOut.line || {}).color;\n var markerColor = (traceOut.marker || {}).color;\n\n if(traceOut.fill === 'tonext' || traceOut.fill === 'toself') {\n dfltHoverOn.push('fills');\n }\n coerce('hoveron', dfltHoverOn.join('+') || 'points');\n if(traceOut.hoveron !== 'fills') coerce('hovertemplate');\n var errorBarsSupplyDefaults = Registry.getComponentMethod('errorbars', 'supplyDefaults');\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || markerColor || defaultColor, {axis: 'y'});\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || markerColor || defaultColor, {axis: 'x', inherit: 'y'});\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n","'use strict';\n\nmodule.exports = function makeFillcolorAttr(hasFillgradient) {\n return {\n valType: 'color',\n editType: 'style',\n anim: true,\n description: [\n 'Sets the fill color.',\n 'Defaults to a half-transparent variant of the line color,',\n 'marker color, or marker line color, whichever is available.' + (\n hasFillgradient ?\n ' If fillgradient is specified, fillcolor is ignored except for setting the background color of the hover label, if any.' :\n ''\n )\n ].join(' ')\n };\n};\n","'use strict';\n\nvar Color = require('../../components/color');\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\n\nfunction averageColors(colorscale) {\n var color = Color.interpolate(colorscale[0][1], colorscale[1][1], 0.5);\n for(var i = 2; i < colorscale.length; i++) {\n var averageColorI = Color.interpolate(colorscale[i - 1][1], colorscale[i][1], 0.5);\n color = Color.interpolate(color, averageColorI, colorscale[i - 1][0] / colorscale[i][0]);\n }\n return color;\n}\n\nmodule.exports = function fillColorDefaults(traceIn, traceOut, defaultColor, coerce, opts) {\n if(!opts) opts = {};\n\n var inheritColorFromMarker = false;\n\n if(traceOut.marker) {\n // don't try to inherit a color array\n var markerColor = traceOut.marker.color;\n var markerLineColor = (traceOut.marker.line || {}).color;\n\n if(markerColor && !isArrayOrTypedArray(markerColor)) {\n inheritColorFromMarker = markerColor;\n } else if(markerLineColor && !isArrayOrTypedArray(markerLineColor)) {\n inheritColorFromMarker = markerLineColor;\n }\n }\n\n var averageGradientColor;\n if(opts.moduleHasFillgradient) {\n var gradientOrientation = coerce('fillgradient.type');\n if(gradientOrientation !== 'none') {\n coerce('fillgradient.start');\n coerce('fillgradient.stop');\n var gradientColorscale = coerce('fillgradient.colorscale');\n\n // if a fillgradient is specified, we use the average gradient color\n // to specify fillcolor after all other more specific candidates\n // are considered, but before the global default color.\n // fillcolor affects the background color of the hoverlabel in this case.\n if(gradientColorscale) {\n averageGradientColor = averageColors(gradientColorscale);\n }\n }\n }\n\n coerce('fillcolor', Color.addOpacity(\n (traceOut.line || {}).color ||\n inheritColorFromMarker ||\n averageGradientColor ||\n defaultColor, 0.5\n ));\n};\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\n\nmodule.exports = function formatLabels(cdi, trace, fullLayout) {\n var labels = {};\n\n var mockGd = {_fullLayout: fullLayout};\n var xa = Axes.getFromTrace(mockGd, trace, 'x');\n var ya = Axes.getFromTrace(mockGd, trace, 'y');\n\n var x = cdi.orig_x;\n if(x === undefined) x = cdi.x;\n\n var y = cdi.orig_y;\n if(y === undefined) y = cdi.y;\n\n labels.xLabel = Axes.tickText(xa, xa.c2l(x), true).text;\n labels.yLabel = Axes.tickText(ya, ya.c2l(y), true).text;\n\n return labels;\n};\n","'use strict';\n\nvar Color = require('../../components/color');\nvar subtypes = require('./subtypes');\n\n\nmodule.exports = function getTraceColor(trace, di) {\n var lc, tc;\n\n // TODO: text modes\n\n if(trace.mode === 'lines') {\n lc = trace.line.color;\n return (lc && Color.opacity(lc)) ?\n lc : trace.fillcolor;\n } else if(trace.mode === 'none') {\n return trace.fill ? trace.fillcolor : '';\n } else {\n var mc = di.mcc || (trace.marker || {}).color;\n var mlc = di.mlcc || ((trace.marker || {}).line || {}).color;\n\n tc = (mc && Color.opacity(mc)) ? mc :\n (mlc && Color.opacity(mlc) &&\n (di.mlw || ((trace.marker || {}).line || {}).width)) ? mlc : '';\n\n if(tc) {\n // make sure the points aren't TOO transparent\n if(Color.opacity(tc) < 0.3) {\n return Color.addOpacity(tc, 0.3);\n } else return tc;\n } else {\n lc = (trace.line || {}).color;\n return (lc && Color.opacity(lc) &&\n subtypes.hasLines(trace) && trace.line.width) ?\n lc : trace.fillcolor;\n }\n }\n};\n","'use strict';\n\nvar getAxisGroup = require('../../plots/cartesian/constraints').getAxisGroup;\n\nmodule.exports = function handleGroupingDefaults(traceIn, traceOut, fullLayout, coerce) {\n var orientation = traceOut.orientation;\n // N.B. grouping is done across all trace types that support it\n var posAxId = traceOut[{v: 'x', h: 'y'}[orientation] + 'axis'];\n var groupId = getAxisGroup(fullLayout, posAxId) + orientation;\n\n var alignmentOpts = fullLayout._alignmentOpts || {};\n var alignmentgroup = coerce('alignmentgroup');\n\n var alignmentGroups = alignmentOpts[groupId];\n if(!alignmentGroups) alignmentGroups = alignmentOpts[groupId] = {};\n\n var alignmentGroupOpts = alignmentGroups[alignmentgroup];\n\n if(alignmentGroupOpts) {\n alignmentGroupOpts.traces.push(traceOut);\n } else {\n alignmentGroupOpts = alignmentGroups[alignmentgroup] = {\n traces: [traceOut],\n alignmentIndex: Object.keys(alignmentGroups).length,\n offsetGroups: {}\n };\n }\n\n var offsetgroup = coerce('offsetgroup');\n var offsetGroups = alignmentGroupOpts.offsetGroups;\n var offsetGroupOpts = offsetGroups[offsetgroup];\n\n if(offsetgroup) {\n if(!offsetGroupOpts) {\n offsetGroupOpts = offsetGroups[offsetgroup] = {\n offsetIndex: Object.keys(offsetGroups).length\n };\n }\n\n traceOut._offsetIndex = offsetGroupOpts.offsetIndex;\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Fx = require('../../components/fx');\nvar Registry = require('../../registry');\nvar getTraceColor = require('./get_trace_color');\nvar Color = require('../../components/color');\nvar fillText = Lib.fillText;\n\nmodule.exports = function hoverPoints(pointData, xval, yval, hovermode) {\n var cd = pointData.cd;\n var trace = cd[0].trace;\n var xa = pointData.xa;\n var ya = pointData.ya;\n var xpx = xa.c2p(xval);\n var ypx = ya.c2p(yval);\n var pt = [xpx, ypx];\n var hoveron = trace.hoveron || '';\n var minRad = (trace.mode.indexOf('markers') !== -1) ? 3 : 0.5;\n\n var xPeriod = !!trace.xperiodalignment;\n var yPeriod = !!trace.yperiodalignment;\n\n // look for points to hover on first, then take fills only if we\n // didn't find a point\n\n if(hoveron.indexOf('points') !== -1) {\n // dx and dy are used in compare modes - here we want to always\n // prioritize the closest data point, at least as long as markers are\n // the same size or nonexistent, but still try to prioritize small markers too.\n var dx = function(di) {\n if(xPeriod) {\n var x0 = xa.c2p(di.xStart);\n var x1 = xa.c2p(di.xEnd);\n\n return (\n xpx >= Math.min(x0, x1) &&\n xpx <= Math.max(x0, x1)\n ) ? 0 : Infinity;\n }\n\n var rad = Math.max(3, di.mrc || 0);\n var kink = 1 - 1 / rad;\n var dxRaw = Math.abs(xa.c2p(di.x) - xpx);\n return (dxRaw < rad) ? (kink * dxRaw / rad) : (dxRaw - rad + kink);\n };\n var dy = function(di) {\n if(yPeriod) {\n var y0 = ya.c2p(di.yStart);\n var y1 = ya.c2p(di.yEnd);\n\n return (\n ypx >= Math.min(y0, y1) &&\n ypx <= Math.max(y0, y1)\n ) ? 0 : Infinity;\n }\n\n var rad = Math.max(3, di.mrc || 0);\n var kink = 1 - 1 / rad;\n var dyRaw = Math.abs(ya.c2p(di.y) - ypx);\n return (dyRaw < rad) ? (kink * dyRaw / rad) : (dyRaw - rad + kink);\n };\n\n // scatter points: d.mrc is the calculated marker radius\n // adjust the distance so if you're inside the marker it\n // always will show up regardless of point size, but\n // prioritize smaller points\n var dxy = function(di) {\n var rad = Math.max(minRad, di.mrc || 0);\n var dx = xa.c2p(di.x) - xpx;\n var dy = ya.c2p(di.y) - ypx;\n return Math.max(Math.sqrt(dx * dx + dy * dy) - rad, 1 - minRad / rad);\n };\n var distfn = Fx.getDistanceFunction(hovermode, dx, dy, dxy);\n\n Fx.getClosest(cd, distfn, pointData);\n\n // skip the rest (for this trace) if we didn't find a close point\n if(pointData.index !== false) {\n // the closest data point\n var di = cd[pointData.index];\n var xc = xa.c2p(di.x, true);\n var yc = ya.c2p(di.y, true);\n var rad = di.mrc || 1;\n\n // now we're done using the whole `calcdata` array, replace the\n // index with the original index (in case of inserted point from\n // stacked area)\n pointData.index = di.i;\n\n var orientation = cd[0].t.orientation;\n // TODO: for scatter and bar, option to show (sub)totals and\n // raw data? Currently stacked and/or normalized bars just show\n // the normalized individual sizes, so that's what I'm doing here\n // for now.\n var sizeVal = orientation && (di.sNorm || di.s);\n var xLabelVal = (orientation === 'h') ? sizeVal : di.orig_x !== undefined ? di.orig_x : di.x;\n var yLabelVal = (orientation === 'v') ? sizeVal : di.orig_y !== undefined ? di.orig_y : di.y;\n\n Lib.extendFlat(pointData, {\n color: getTraceColor(trace, di),\n\n x0: xc - rad,\n x1: xc + rad,\n xLabelVal: xLabelVal,\n\n y0: yc - rad,\n y1: yc + rad,\n yLabelVal: yLabelVal,\n\n spikeDistance: dxy(di),\n hovertemplate: trace.hovertemplate\n });\n\n fillText(di, trace, pointData);\n Registry.getComponentMethod('errorbars', 'hoverInfo')(di, trace, pointData);\n\n return [pointData];\n }\n }\n\n function isHoverPointInFillElement(el) {\n // Uses SVGElement.isPointInFill to accurately determine wether\n // the hover point / cursor is contained in the fill, taking\n // curved or jagged edges into account, which the Polygon-based\n // approach does not.\n if(!el) {\n return false;\n }\n var svgElement = el.node();\n try {\n var domPoint = new DOMPoint(pt[0], pt[1]);\n return svgElement.isPointInFill(domPoint);\n } catch(TypeError) {\n var svgPoint = svgElement.ownerSVGElement.createSVGPoint();\n svgPoint.x = pt[0];\n svgPoint.y = pt[1];\n return svgElement.isPointInFill(svgPoint);\n }\n }\n\n function getHoverLabelPosition(polygons) {\n // Uses Polygon s to determine the left- and right-most x-coordinates\n // of the subshape of the fill that contains the hover point / cursor.\n // Doing this with the SVGElement directly is quite tricky, so this falls\n // back to the existing relatively simple code, accepting some small inaccuracies\n // of label positioning for curved/jagged edges.\n var i;\n var polygonsIn = [];\n var xmin = Infinity;\n var xmax = -Infinity;\n var ymin = Infinity;\n var ymax = -Infinity;\n var yPos;\n\n for(i = 0; i < polygons.length; i++) {\n var polygon = polygons[i];\n // This is not going to work right for curved or jagged edges, it will\n // act as though they're straight.\n if(polygon.contains(pt)) {\n polygonsIn.push(polygon);\n ymin = Math.min(ymin, polygon.ymin);\n ymax = Math.max(ymax, polygon.ymax);\n }\n }\n\n // The above found no polygon that contains the cursor, but we know that\n // the cursor must be inside the fill as determined by the SVGElement\n // (so we are probably close to a curved/jagged edge...).\n if(polygonsIn.length === 0) {\n return null;\n }\n\n // constrain ymin/max to the visible plot, so the label goes\n // at the middle of the piece you can see\n ymin = Math.max(ymin, 0);\n ymax = Math.min(ymax, ya._length);\n\n yPos = (ymin + ymax) / 2;\n\n // find the overall left-most and right-most points of the\n // polygon(s) we're inside at their combined vertical midpoint.\n // This is where we will draw the hover label.\n // Note that this might not be the vertical midpoint of the\n // whole trace, if it's disjoint.\n var j, pts, xAtYPos, x0, x1, y0, y1;\n for(i = 0; i < polygonsIn.length; i++) {\n pts = polygonsIn[i].pts;\n for(j = 1; j < pts.length; j++) {\n y0 = pts[j - 1][1];\n y1 = pts[j][1];\n if((y0 > yPos) !== (y1 >= yPos)) {\n x0 = pts[j - 1][0];\n x1 = pts[j][0];\n if(y1 - y0) {\n xAtYPos = x0 + (x1 - x0) * (yPos - y0) / (y1 - y0);\n xmin = Math.min(xmin, xAtYPos);\n xmax = Math.max(xmax, xAtYPos);\n }\n }\n }\n }\n\n // constrain xmin/max to the visible plot now too\n xmin = Math.max(xmin, 0);\n xmax = Math.min(xmax, xa._length);\n\n return {\n x0: xmin,\n x1: xmax,\n y0: yPos,\n y1: yPos,\n };\n }\n\n // even if hoveron is 'fills', only use it if we have a fill element too\n if(hoveron.indexOf('fills') !== -1 && trace._fillElement) {\n var inside = isHoverPointInFillElement(trace._fillElement) && !isHoverPointInFillElement(trace._fillExclusionElement);\n\n if(inside) {\n var hoverLabelCoords = getHoverLabelPosition(trace._polygons);\n\n // getHoverLabelPosition may return null if the cursor / hover point is not contained\n // in any of the trace's polygons, which can happen close to curved edges. in that\n // case we fall back to displaying the hover label at the cursor position.\n if(hoverLabelCoords === null) {\n hoverLabelCoords = {\n x0: pt[0],\n x1: pt[0],\n y0: pt[1],\n y1: pt[1]\n };\n }\n\n // get only fill or line color for the hover color\n var color = Color.defaultLine;\n if(Color.opacity(trace.fillcolor)) color = trace.fillcolor;\n else if(Color.opacity((trace.line || {}).color)) {\n color = trace.line.color;\n }\n\n Lib.extendFlat(pointData, {\n // never let a 2D override 1D type as closest point\n // also: no spikeDistance, it's not allowed for fills\n distance: pointData.maxHoverDistance,\n x0: hoverLabelCoords.x0,\n x1: hoverLabelCoords.x1,\n y0: hoverLabelCoords.y0,\n y1: hoverLabelCoords.y1,\n color: color,\n hovertemplate: false\n });\n\n delete pointData.index;\n\n if(trace.text && !Lib.isArrayOrTypedArray(trace.text)) {\n pointData.text = String(trace.text);\n } else pointData.text = trace.name;\n\n return [pointData];\n }\n }\n};\n","'use strict';\n\nvar subtypes = require('./subtypes');\n\nmodule.exports = {\n hasLines: subtypes.hasLines,\n hasMarkers: subtypes.hasMarkers,\n hasText: subtypes.hasText,\n isBubble: subtypes.isBubble,\n\n attributes: require('./attributes'),\n layoutAttributes: require('./layout_attributes'),\n supplyDefaults: require('./defaults'),\n crossTraceDefaults: require('./cross_trace_defaults'),\n supplyLayoutDefaults: require('./layout_defaults'),\n calc: require('./calc').calc,\n crossTraceCalc: require('./cross_trace_calc'),\n arraysToCalcdata: require('./arrays_to_calcdata'),\n plot: require('./plot'),\n colorbar: require('./marker_colorbar'),\n formatLabels: require('./format_labels'),\n style: require('./style').style,\n styleOnSelect: require('./style').styleOnSelect,\n hoverPoints: require('./hover'),\n selectPoints: require('./select'),\n animatable: true,\n\n moduleType: 'trace',\n name: 'scatter',\n basePlotModule: require('../../plots/cartesian'),\n categories: [\n 'cartesian', 'svg', 'symbols', 'errorBarsOK', 'showLegend', 'scatter-like',\n 'zoomScale'\n ],\n meta: {\n description: [\n 'The scatter trace type encompasses line charts, scatter charts, text charts, and bubble charts.',\n 'The data visualized as scatter point or lines is set in `x` and `y`.',\n 'Text (appearing either on the chart or on hover only) is via `text`.',\n 'Bubble charts are achieved by setting `marker.size` and/or `marker.color`',\n 'to numerical arrays.'\n ].join(' ')\n }\n};\n","'use strict';\n\n\nmodule.exports = {\n scattermode: {\n valType: 'enumerated',\n values: ['group', 'overlay'],\n dflt: 'overlay',\n editType: 'calc',\n description: [\n 'Determines how scatter points at the same location coordinate',\n 'are displayed on the graph.',\n 'With *group*, the scatter points are plotted next to one another',\n 'centered around the shared location.',\n 'With *overlay*, the scatter points are plotted over one another,',\n 'you might need to reduce *opacity* to see multiple scatter points.'\n ].join(' ')\n },\n scattergap: {\n valType: 'number',\n min: 0,\n max: 1,\n editType: 'calc',\n description: [\n 'Sets the gap (in plot fraction) between scatter points of',\n 'adjacent location coordinates.',\n 'Defaults to `bargap`.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar layoutAttributes = require('./layout_attributes');\n\nmodule.exports = function(layoutIn, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n\n var groupBarmode = layoutOut.barmode === 'group';\n\n if(layoutOut.scattermode === 'group') {\n coerce('scattergap', groupBarmode ? layoutOut.bargap : 0.2);\n }\n};\n","'use strict';\n\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar hasColorscale = require('../../components/colorscale/helpers').hasColorscale;\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\n\nmodule.exports = function lineDefaults(traceIn, traceOut, defaultColor, layout, coerce, opts) {\n if(!opts) opts = {};\n\n var markerColor = (traceIn.marker || {}).color;\n if(markerColor && markerColor._inputArray) markerColor = markerColor._inputArray;\n\n coerce('line.color', defaultColor);\n\n if(hasColorscale(traceIn, 'line')) {\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: 'line.', cLetter: 'c'});\n } else {\n var lineColorDflt = (isArrayOrTypedArray(markerColor) ? false : markerColor) || defaultColor;\n coerce('line.color', lineColorDflt);\n }\n\n coerce('line.width');\n\n if(!opts.noDash) coerce('line.dash');\n if(opts.backoff) coerce('line.backoff');\n};\n","'use strict';\n\nvar Drawing = require('../../components/drawing');\nvar numConstants = require('../../constants/numerical');\nvar BADNUM = numConstants.BADNUM;\nvar LOG_CLIP = numConstants.LOG_CLIP;\nvar LOG_CLIP_PLUS = LOG_CLIP + 0.5;\nvar LOG_CLIP_MINUS = LOG_CLIP - 0.5;\nvar Lib = require('../../lib');\nvar segmentsIntersect = Lib.segmentsIntersect;\nvar constrain = Lib.constrain;\nvar constants = require('./constants');\n\n\nmodule.exports = function linePoints(d, opts) {\n var trace = opts.trace || {};\n var xa = opts.xaxis;\n var ya = opts.yaxis;\n var xLog = xa.type === 'log';\n var yLog = ya.type === 'log';\n var xLen = xa._length;\n var yLen = ya._length;\n var backoff = opts.backoff;\n var marker = trace.marker;\n var connectGaps = opts.connectGaps;\n var baseTolerance = opts.baseTolerance;\n var shape = opts.shape;\n var linear = shape === 'linear';\n var fill = trace.fill && trace.fill !== 'none';\n var segments = [];\n var minTolerance = constants.minTolerance;\n var len = d.length;\n var pts = new Array(len);\n var pti = 0;\n\n var i;\n\n // pt variables are pixel coordinates [x,y] of one point\n // these four are the outputs of clustering on a line\n var clusterStartPt, clusterEndPt, clusterHighPt, clusterLowPt;\n\n // \"this\" is the next point we're considering adding to the cluster\n var thisPt;\n\n // did we encounter the high point first, then a low point, or vice versa?\n var clusterHighFirst;\n\n // the first two points in the cluster determine its unit vector\n // so the second is always in the \"High\" direction\n var clusterUnitVector;\n\n // the pixel delta from clusterStartPt\n var thisVector;\n\n // val variables are (signed) pixel distances along the cluster vector\n var clusterRefDist, clusterHighVal, clusterLowVal, thisVal;\n\n // deviation variables are (signed) pixel distances normal to the cluster vector\n var clusterMinDeviation, clusterMaxDeviation, thisDeviation;\n\n // turn one calcdata point into pixel coordinates\n function getPt(index) {\n var di = d[index];\n if(!di) return false;\n var x = opts.linearized ? xa.l2p(di.x) : xa.c2p(di.x);\n var y = opts.linearized ? ya.l2p(di.y) : ya.c2p(di.y);\n\n // if non-positive log values, set them VERY far off-screen\n // so the line looks essentially straight from the previous point.\n if(x === BADNUM) {\n if(xLog) x = xa.c2p(di.x, true);\n if(x === BADNUM) return false;\n // If BOTH were bad log values, make the line follow a constant\n // exponent rather than a constant slope\n if(yLog && y === BADNUM) {\n x *= Math.abs(xa._m * yLen * (xa._m > 0 ? LOG_CLIP_PLUS : LOG_CLIP_MINUS) /\n (ya._m * xLen * (ya._m > 0 ? LOG_CLIP_PLUS : LOG_CLIP_MINUS)));\n }\n x *= 1000;\n }\n if(y === BADNUM) {\n if(yLog) y = ya.c2p(di.y, true);\n if(y === BADNUM) return false;\n y *= 1000;\n }\n return [x, y];\n }\n\n function crossesViewport(xFrac0, yFrac0, xFrac1, yFrac1) {\n var dx = xFrac1 - xFrac0;\n var dy = yFrac1 - yFrac0;\n var dx0 = 0.5 - xFrac0;\n var dy0 = 0.5 - yFrac0;\n var norm2 = dx * dx + dy * dy;\n var dot = dx * dx0 + dy * dy0;\n if(dot > 0 && dot < norm2) {\n var cross = dx0 * dy - dy0 * dx;\n if(cross * cross < norm2) return true;\n }\n }\n\n var latestXFrac, latestYFrac;\n // if we're off-screen, increase tolerance over baseTolerance\n function getTolerance(pt, nextPt) {\n var xFrac = pt[0] / xLen;\n var yFrac = pt[1] / yLen;\n var offScreenFraction = Math.max(0, -xFrac, xFrac - 1, -yFrac, yFrac - 1);\n if(offScreenFraction && (latestXFrac !== undefined) &&\n crossesViewport(xFrac, yFrac, latestXFrac, latestYFrac)\n ) {\n offScreenFraction = 0;\n }\n if(offScreenFraction && nextPt &&\n crossesViewport(xFrac, yFrac, nextPt[0] / xLen, nextPt[1] / yLen)\n ) {\n offScreenFraction = 0;\n }\n\n return (1 + constants.toleranceGrowth * offScreenFraction) * baseTolerance;\n }\n\n function ptDist(pt1, pt2) {\n var dx = pt1[0] - pt2[0];\n var dy = pt1[1] - pt2[1];\n return Math.sqrt(dx * dx + dy * dy);\n }\n\n // last bit of filtering: clip paths that are VERY far off-screen\n // so we don't get near the browser's hard limit (+/- 2^29 px in Chrome and FF)\n\n var maxScreensAway = constants.maxScreensAway;\n\n // find the intersections between the segment from pt1 to pt2\n // and the large rectangle maxScreensAway around the viewport\n // if one of pt1 and pt2 is inside and the other outside, there\n // will be only one intersection.\n // if both are outside there will be 0 or 2 intersections\n // (or 1 if it's right at a corner - we'll treat that like 0)\n // returns an array of intersection pts\n var xEdge0 = -xLen * maxScreensAway;\n var xEdge1 = xLen * (1 + maxScreensAway);\n var yEdge0 = -yLen * maxScreensAway;\n var yEdge1 = yLen * (1 + maxScreensAway);\n var edges = [\n [xEdge0, yEdge0, xEdge1, yEdge0],\n [xEdge1, yEdge0, xEdge1, yEdge1],\n [xEdge1, yEdge1, xEdge0, yEdge1],\n [xEdge0, yEdge1, xEdge0, yEdge0]\n ];\n var xEdge, yEdge, lastXEdge, lastYEdge, lastFarPt, edgePt;\n\n // for linear line shape, edge intersections should be linearly interpolated\n // spline uses this too, which isn't precisely correct but is actually pretty\n // good, because Catmull-Rom weights far-away points less in creating the curvature\n function getLinearEdgeIntersections(pt1, pt2) {\n var out = [];\n var ptCount = 0;\n for(var i = 0; i < 4; i++) {\n var edge = edges[i];\n var ptInt = segmentsIntersect(\n pt1[0], pt1[1], pt2[0], pt2[1],\n edge[0], edge[1], edge[2], edge[3]\n );\n if(ptInt && (!ptCount ||\n Math.abs(ptInt.x - out[0][0]) > 1 ||\n Math.abs(ptInt.y - out[0][1]) > 1\n )) {\n ptInt = [ptInt.x, ptInt.y];\n // if we have 2 intersections, make sure the closest one to pt1 comes first\n if(ptCount && ptDist(ptInt, pt1) < ptDist(out[0], pt1)) out.unshift(ptInt);\n else out.push(ptInt);\n ptCount++;\n }\n }\n return out;\n }\n\n function onlyConstrainedPoint(pt) {\n if(pt[0] < xEdge0 || pt[0] > xEdge1 || pt[1] < yEdge0 || pt[1] > yEdge1) {\n return [constrain(pt[0], xEdge0, xEdge1), constrain(pt[1], yEdge0, yEdge1)];\n }\n }\n\n function sameEdge(pt1, pt2) {\n if(pt1[0] === pt2[0] && (pt1[0] === xEdge0 || pt1[0] === xEdge1)) return true;\n if(pt1[1] === pt2[1] && (pt1[1] === yEdge0 || pt1[1] === yEdge1)) return true;\n }\n\n // for line shapes hv and vh, movement in the two dimensions is decoupled,\n // so all we need to do is constrain each dimension independently\n function getHVEdgeIntersections(pt1, pt2) {\n var out = [];\n var ptInt1 = onlyConstrainedPoint(pt1);\n var ptInt2 = onlyConstrainedPoint(pt2);\n if(ptInt1 && ptInt2 && sameEdge(ptInt1, ptInt2)) return out;\n\n if(ptInt1) out.push(ptInt1);\n if(ptInt2) out.push(ptInt2);\n return out;\n }\n\n // hvh and vhv we sometimes have to move one of the intersection points\n // out BEYOND the clipping rect, by a maximum of a factor of 2, so that\n // the midpoint line is drawn in the right place\n function getABAEdgeIntersections(dim, limit0, limit1) {\n return function(pt1, pt2) {\n var ptInt1 = onlyConstrainedPoint(pt1);\n var ptInt2 = onlyConstrainedPoint(pt2);\n\n var out = [];\n if(ptInt1 && ptInt2 && sameEdge(ptInt1, ptInt2)) return out;\n\n if(ptInt1) out.push(ptInt1);\n if(ptInt2) out.push(ptInt2);\n\n var midShift = 2 * Lib.constrain((pt1[dim] + pt2[dim]) / 2, limit0, limit1) -\n ((ptInt1 || pt1)[dim] + (ptInt2 || pt2)[dim]);\n if(midShift) {\n var ptToAlter;\n if(ptInt1 && ptInt2) {\n ptToAlter = (midShift > 0 === ptInt1[dim] > ptInt2[dim]) ? ptInt1 : ptInt2;\n } else ptToAlter = ptInt1 || ptInt2;\n\n ptToAlter[dim] += midShift;\n }\n\n return out;\n };\n }\n\n var getEdgeIntersections;\n if(shape === 'linear' || shape === 'spline') {\n getEdgeIntersections = getLinearEdgeIntersections;\n } else if(shape === 'hv' || shape === 'vh') {\n getEdgeIntersections = getHVEdgeIntersections;\n } else if(shape === 'hvh') getEdgeIntersections = getABAEdgeIntersections(0, xEdge0, xEdge1);\n else if(shape === 'vhv') getEdgeIntersections = getABAEdgeIntersections(1, yEdge0, yEdge1);\n\n // a segment pt1->pt2 entirely outside the nearby region:\n // find the corner it gets closest to touching\n function getClosestCorner(pt1, pt2) {\n var dx = pt2[0] - pt1[0];\n var m = (pt2[1] - pt1[1]) / dx;\n var b = (pt1[1] * pt2[0] - pt2[1] * pt1[0]) / dx;\n\n if(b > 0) return [m > 0 ? xEdge0 : xEdge1, yEdge1];\n else return [m > 0 ? xEdge1 : xEdge0, yEdge0];\n }\n\n function updateEdge(pt) {\n var x = pt[0];\n var y = pt[1];\n var xSame = x === pts[pti - 1][0];\n var ySame = y === pts[pti - 1][1];\n // duplicate point?\n if(xSame && ySame) return;\n if(pti > 1) {\n // backtracking along an edge?\n var xSame2 = x === pts[pti - 2][0];\n var ySame2 = y === pts[pti - 2][1];\n if(xSame && (x === xEdge0 || x === xEdge1) && xSame2) {\n if(ySame2) pti--; // backtracking exactly - drop prev pt and don't add\n else pts[pti - 1] = pt; // not exact: replace the prev pt\n } else if(ySame && (y === yEdge0 || y === yEdge1) && ySame2) {\n if(xSame2) pti--;\n else pts[pti - 1] = pt;\n } else pts[pti++] = pt;\n } else pts[pti++] = pt;\n }\n\n function updateEdgesForReentry(pt) {\n // if we're outside the nearby region and going back in,\n // we may need to loop around a corner point\n if(pts[pti - 1][0] !== pt[0] && pts[pti - 1][1] !== pt[1]) {\n updateEdge([lastXEdge, lastYEdge]);\n }\n updateEdge(pt);\n lastFarPt = null;\n lastXEdge = lastYEdge = 0;\n }\n\n var arrayMarker = Lib.isArrayOrTypedArray(marker);\n\n function addPt(pt) {\n if(pt && backoff) {\n pt.i = i;\n pt.d = d;\n pt.trace = trace;\n pt.marker = arrayMarker ? marker[pt.i] : marker;\n pt.backoff = backoff;\n }\n\n latestXFrac = pt[0] / xLen;\n latestYFrac = pt[1] / yLen;\n // Are we more than maxScreensAway off-screen any direction?\n // if so, clip to this box, but in such a way that on-screen\n // drawing is unchanged\n xEdge = (pt[0] < xEdge0) ? xEdge0 : (pt[0] > xEdge1) ? xEdge1 : 0;\n yEdge = (pt[1] < yEdge0) ? yEdge0 : (pt[1] > yEdge1) ? yEdge1 : 0;\n if(xEdge || yEdge) {\n if(!pti) {\n // to get fills right - if first point is far, push it toward the\n // screen in whichever direction(s) are far\n\n pts[pti++] = [xEdge || pt[0], yEdge || pt[1]];\n } else if(lastFarPt) {\n // both this point and the last are outside the nearby region\n // check if we're crossing the nearby region\n var intersections = getEdgeIntersections(lastFarPt, pt);\n if(intersections.length > 1) {\n updateEdgesForReentry(intersections[0]);\n pts[pti++] = intersections[1];\n }\n } else {\n // we're leaving the nearby region - add the point where we left it\n\n edgePt = getEdgeIntersections(pts[pti - 1], pt)[0];\n pts[pti++] = edgePt;\n }\n\n var lastPt = pts[pti - 1];\n if(xEdge && yEdge && (lastPt[0] !== xEdge || lastPt[1] !== yEdge)) {\n // we've gone out beyond a new corner: add the corner too\n // so that the next point will take the right winding\n if(lastFarPt) {\n if(lastXEdge !== xEdge && lastYEdge !== yEdge) {\n if(lastXEdge && lastYEdge) {\n // we've gone around to an opposite corner - we\n // need to add the correct extra corner\n // in order to get the right winding\n updateEdge(getClosestCorner(lastFarPt, pt));\n } else {\n // we're coming from a far edge - the extra corner\n // we need is determined uniquely by the sectors\n updateEdge([lastXEdge || xEdge, lastYEdge || yEdge]);\n }\n } else if(lastXEdge && lastYEdge) {\n updateEdge([lastXEdge, lastYEdge]);\n }\n }\n updateEdge([xEdge, yEdge]);\n } else if((lastXEdge - xEdge) && (lastYEdge - yEdge)) {\n // we're coming from an edge or far corner to an edge - again the\n // extra corner we need is uniquely determined by the sectors\n updateEdge([xEdge || lastXEdge, yEdge || lastYEdge]);\n }\n lastFarPt = pt;\n lastXEdge = xEdge;\n lastYEdge = yEdge;\n } else {\n if(lastFarPt) {\n // this point is in range but the previous wasn't: add its entry pt first\n updateEdgesForReentry(getEdgeIntersections(lastFarPt, pt)[0]);\n }\n\n pts[pti++] = pt;\n }\n }\n\n // loop over ALL points in this trace\n for(i = 0; i < len; i++) {\n clusterStartPt = getPt(i);\n if(!clusterStartPt) continue;\n\n pti = 0;\n lastFarPt = null;\n addPt(clusterStartPt);\n\n // loop over one segment of the trace\n for(i++; i < len; i++) {\n clusterHighPt = getPt(i);\n if(!clusterHighPt) {\n if(connectGaps) continue;\n else break;\n }\n\n // can't decimate if nonlinear line shape\n // TODO: we *could* decimate [hv]{2,3} shapes if we restricted clusters to horz or vert again\n // but spline would be verrry awkward to decimate\n if(!linear || !opts.simplify) {\n addPt(clusterHighPt);\n continue;\n }\n\n var nextPt = getPt(i + 1);\n\n clusterRefDist = ptDist(clusterHighPt, clusterStartPt);\n\n // #3147 - always include the very first and last points for fills\n if(!(fill && (pti === 0 || pti === len - 1)) &&\n clusterRefDist < getTolerance(clusterHighPt, nextPt) * minTolerance) continue;\n\n clusterUnitVector = [\n (clusterHighPt[0] - clusterStartPt[0]) / clusterRefDist,\n (clusterHighPt[1] - clusterStartPt[1]) / clusterRefDist\n ];\n\n clusterLowPt = clusterStartPt;\n clusterHighVal = clusterRefDist;\n clusterLowVal = clusterMinDeviation = clusterMaxDeviation = 0;\n clusterHighFirst = false;\n clusterEndPt = clusterHighPt;\n\n // loop over one cluster of points that collapse onto one line\n for(i++; i < d.length; i++) {\n thisPt = nextPt;\n nextPt = getPt(i + 1);\n if(!thisPt) {\n if(connectGaps) continue;\n else break;\n }\n thisVector = [\n thisPt[0] - clusterStartPt[0],\n thisPt[1] - clusterStartPt[1]\n ];\n // cross product (or dot with normal to the cluster vector)\n thisDeviation = thisVector[0] * clusterUnitVector[1] - thisVector[1] * clusterUnitVector[0];\n clusterMinDeviation = Math.min(clusterMinDeviation, thisDeviation);\n clusterMaxDeviation = Math.max(clusterMaxDeviation, thisDeviation);\n\n if(clusterMaxDeviation - clusterMinDeviation > getTolerance(thisPt, nextPt)) break;\n\n clusterEndPt = thisPt;\n thisVal = thisVector[0] * clusterUnitVector[0] + thisVector[1] * clusterUnitVector[1];\n\n if(thisVal > clusterHighVal) {\n clusterHighVal = thisVal;\n clusterHighPt = thisPt;\n clusterHighFirst = false;\n } else if(thisVal < clusterLowVal) {\n clusterLowVal = thisVal;\n clusterLowPt = thisPt;\n clusterHighFirst = true;\n }\n }\n\n // insert this cluster into pts\n // we've already inserted the start pt, now check if we have high and low pts\n if(clusterHighFirst) {\n addPt(clusterHighPt);\n if(clusterEndPt !== clusterLowPt) addPt(clusterLowPt);\n } else {\n if(clusterLowPt !== clusterStartPt) addPt(clusterLowPt);\n if(clusterEndPt !== clusterHighPt) addPt(clusterHighPt);\n }\n // and finally insert the end pt\n addPt(clusterEndPt);\n\n // have we reached the end of this segment?\n if(i >= d.length || !thisPt) break;\n\n // otherwise we have an out-of-cluster point to insert as next clusterStartPt\n addPt(thisPt);\n clusterStartPt = thisPt;\n }\n\n // to get fills right - repeat what we did at the start\n if(lastFarPt) updateEdge([lastXEdge || lastFarPt[0], lastYEdge || lastFarPt[1]]);\n\n segments.push(pts.slice(0, pti));\n }\n\n\n var lastShapeChar = shape.slice(shape.length - 1);\n if(backoff && lastShapeChar !== 'h' && lastShapeChar !== 'v') {\n var trimmed = false;\n var n = -1;\n var newSegments = [];\n\n for(var j = 0; j < segments.length; j++) {\n for(var k = 0; k < segments[j].length - 1; k++) {\n var start = segments[j][k];\n var end = segments[j][k + 1];\n\n var xy = Drawing.applyBackoff(end, start);\n if(\n xy[0] !== end[0] ||\n xy[1] !== end[1]\n ) {\n trimmed = true;\n }\n if(!newSegments[n + 1]) {\n n++;\n newSegments[n] = [\n start, [xy[0], xy[1]]\n ];\n }\n }\n }\n\n return trimmed ? newSegments : segments;\n }\n\n return segments;\n};\n","'use strict';\n\n\n// common to 'scatter' and 'scatterternary'\nmodule.exports = function handleLineShapeDefaults(traceIn, traceOut, coerce) {\n var shape = coerce('line.shape');\n if(shape === 'spline') coerce('line.smoothing');\n};\n","'use strict';\n\nvar LINKEDFILLS = {tonextx: 1, tonexty: 1, tonext: 1};\n\nmodule.exports = function linkTraces(gd, plotinfo, cdscatter) {\n var trace, i, group, prevtrace, groupIndex;\n\n // first sort traces to keep stacks & filled-together groups together\n var groupIndices = {};\n var needsSort = false;\n var prevGroupIndex = -1;\n var nextGroupIndex = 0;\n var prevUnstackedGroupIndex = -1;\n for(i = 0; i < cdscatter.length; i++) {\n trace = cdscatter[i][0].trace;\n group = trace.stackgroup || '';\n if(group) {\n if(group in groupIndices) {\n groupIndex = groupIndices[group];\n } else {\n groupIndex = groupIndices[group] = nextGroupIndex;\n nextGroupIndex++;\n }\n } else if(trace.fill in LINKEDFILLS && prevUnstackedGroupIndex >= 0) {\n groupIndex = prevUnstackedGroupIndex;\n } else {\n groupIndex = prevUnstackedGroupIndex = nextGroupIndex;\n nextGroupIndex++;\n }\n\n if(groupIndex < prevGroupIndex) needsSort = true;\n trace._groupIndex = prevGroupIndex = groupIndex;\n }\n\n var cdscatterSorted = cdscatter.slice();\n if(needsSort) {\n cdscatterSorted.sort(function(a, b) {\n var traceA = a[0].trace;\n var traceB = b[0].trace;\n return (traceA._groupIndex - traceB._groupIndex) ||\n (traceA.index - traceB.index);\n });\n }\n\n // now link traces to each other\n var prevtraces = {};\n for(i = 0; i < cdscatterSorted.length; i++) {\n trace = cdscatterSorted[i][0].trace;\n group = trace.stackgroup || '';\n\n // Note: The check which ensures all cdscatter here are for the same axis and\n // are either cartesian or scatterternary has been removed. This code assumes\n // the passed scattertraces have been filtered to the proper plot types and\n // the proper subplots.\n if(trace.visible === true) {\n trace._nexttrace = null;\n\n if(trace.fill in LINKEDFILLS) {\n prevtrace = prevtraces[group];\n trace._prevtrace = prevtrace || null;\n\n if(prevtrace) {\n prevtrace._nexttrace = trace;\n }\n }\n\n trace._ownfill = (trace.fill && (\n trace.fill.substr(0, 6) === 'tozero' ||\n trace.fill === 'toself' ||\n (trace.fill.substr(0, 2) === 'to' && !trace._prevtrace)\n ));\n\n prevtraces[group] = trace;\n } else {\n trace._prevtrace = trace._nexttrace = trace._ownfill = null;\n }\n }\n\n return cdscatterSorted;\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\n\n// used in the drawing step for 'scatter' and 'scattegeo' and\n// in the convert step for 'scatter3d'\nmodule.exports = function makeBubbleSizeFn(trace, factor) {\n if(!factor) {\n factor = 2;\n }\n var marker = trace.marker;\n var sizeRef = marker.sizeref || 1;\n var sizeMin = marker.sizemin || 0;\n\n // for bubble charts, allow scaling the provided value linearly\n // and by area or diameter.\n // Note this only applies to the array-value sizes\n\n var baseFn = (marker.sizemode === 'area') ?\n function(v) { return Math.sqrt(v / sizeRef); } :\n function(v) { return v / sizeRef; };\n\n // TODO add support for position/negative bubbles?\n // TODO add 'sizeoffset' attribute?\n return function(v) {\n var baseSize = baseFn(v / factor);\n\n // don't show non-numeric and negative sizes\n return (isNumeric(baseSize) && (baseSize > 0)) ?\n Math.max(baseSize, sizeMin) :\n 0;\n };\n};\n","'use strict';\n\nmodule.exports = {\n container: 'marker',\n min: 'cmin',\n max: 'cmax'\n};\n","'use strict';\n\nvar Color = require('../../components/color');\nvar hasColorscale = require('../../components/colorscale/helpers').hasColorscale;\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\n\nvar subTypes = require('./subtypes');\n\n/*\n * opts: object of flags to control features not all marker users support\n * noLine: caller does not support marker lines\n * gradient: caller supports gradients\n * noSelect: caller does not support selected/unselected attribute containers\n */\nmodule.exports = function markerDefaults(traceIn, traceOut, defaultColor, layout, coerce, opts) {\n var isBubble = subTypes.isBubble(traceIn);\n var lineColor = (traceIn.line || {}).color;\n var defaultMLC;\n\n opts = opts || {};\n\n // marker.color inherit from line.color (even if line.color is an array)\n if(lineColor) defaultColor = lineColor;\n\n coerce('marker.symbol');\n coerce('marker.opacity', isBubble ? 0.7 : 1);\n coerce('marker.size');\n if(!opts.noAngle) {\n coerce('marker.angle');\n if(!opts.noAngleRef) {\n coerce('marker.angleref');\n }\n\n if(!opts.noStandOff) {\n coerce('marker.standoff');\n }\n }\n\n coerce('marker.color', defaultColor);\n if(hasColorscale(traceIn, 'marker')) {\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: 'marker.', cLetter: 'c'});\n }\n\n if(!opts.noSelect) {\n coerce('selected.marker.color');\n coerce('unselected.marker.color');\n coerce('selected.marker.size');\n coerce('unselected.marker.size');\n }\n\n if(!opts.noLine) {\n // if there's a line with a different color than the marker, use\n // that line color as the default marker line color\n // (except when it's an array)\n // mostly this is for transparent markers to behave nicely\n if(lineColor && !Array.isArray(lineColor) && (traceOut.marker.color !== lineColor)) {\n defaultMLC = lineColor;\n } else if(isBubble) defaultMLC = Color.background;\n else defaultMLC = Color.defaultLine;\n\n coerce('marker.line.color', defaultMLC);\n if(hasColorscale(traceIn, 'marker.line')) {\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: 'marker.line.', cLetter: 'c'});\n }\n\n coerce('marker.line.width', isBubble ? 1 : 0);\n }\n\n if(isBubble) {\n coerce('marker.sizeref');\n coerce('marker.sizemin');\n coerce('marker.sizemode');\n }\n\n if(opts.gradient) {\n var gradientType = coerce('marker.gradient.type');\n if(gradientType !== 'none') {\n coerce('marker.gradient.color');\n }\n }\n};\n","'use strict';\n\nvar dateTick0 = require('../../lib').dateTick0;\nvar numConstants = require('../../constants/numerical');\nvar ONEWEEK = numConstants.ONEWEEK;\n\nfunction getPeriod0Dflt(period, calendar) {\n if(period % ONEWEEK === 0) {\n return dateTick0(calendar, 1); // Sunday\n }\n return dateTick0(calendar, 0);\n}\n\nmodule.exports = function handlePeriodDefaults(traceIn, traceOut, layout, coerce, opts) {\n if(!opts) {\n opts = {\n x: true,\n y: true\n };\n }\n\n if(opts.x) {\n var xperiod = coerce('xperiod');\n if(xperiod) {\n coerce('xperiod0', getPeriod0Dflt(xperiod, traceOut.xcalendar));\n coerce('xperiodalignment');\n }\n }\n\n if(opts.y) {\n var yperiod = coerce('yperiod');\n if(yperiod) {\n coerce('yperiod0', getPeriod0Dflt(yperiod, traceOut.ycalendar));\n coerce('yperiodalignment');\n }\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar ensureSingle = Lib.ensureSingle;\nvar identity = Lib.identity;\nvar Drawing = require('../../components/drawing');\n\nvar subTypes = require('./subtypes');\nvar linePoints = require('./line_points');\nvar linkTraces = require('./link_traces');\nvar polygonTester = require('../../lib/polygon').tester;\n\nmodule.exports = function plot(gd, plotinfo, cdscatter, scatterLayer, transitionOpts, makeOnCompleteCallback) {\n var join, onComplete;\n\n // If transition config is provided, then it is only a partial replot and traces not\n // updated are removed.\n var isFullReplot = !transitionOpts;\n var hasTransition = !!transitionOpts && transitionOpts.duration > 0;\n\n // Link traces so the z-order of fill layers is correct\n var cdscatterSorted = linkTraces(gd, plotinfo, cdscatter);\n\n join = scatterLayer.selectAll('g.trace')\n .data(cdscatterSorted, function(d) { return d[0].trace.uid; });\n\n // Append new traces:\n join.enter().append('g')\n .attr('class', function(d) {\n return 'trace scatter trace' + d[0].trace.uid;\n })\n .style('stroke-miterlimit', 2);\n join.order();\n\n createFills(gd, join, plotinfo);\n\n if(hasTransition) {\n if(makeOnCompleteCallback) {\n // If it was passed a callback to register completion, make a callback. If\n // this is created, then it must be executed on completion, otherwise the\n // pos-transition redraw will not execute:\n onComplete = makeOnCompleteCallback();\n }\n\n var transition = d3.transition()\n .duration(transitionOpts.duration)\n .ease(transitionOpts.easing)\n .each('end', function() {\n onComplete && onComplete();\n })\n .each('interrupt', function() {\n onComplete && onComplete();\n });\n\n transition.each(function() {\n // Must run the selection again since otherwise enters/updates get grouped together\n // and these get executed out of order. Except we need them in order!\n scatterLayer.selectAll('g.trace').each(function(d, i) {\n plotOne(gd, i, plotinfo, d, cdscatterSorted, this, transitionOpts);\n });\n });\n } else {\n join.each(function(d, i) {\n plotOne(gd, i, plotinfo, d, cdscatterSorted, this, transitionOpts);\n });\n }\n\n if(isFullReplot) {\n join.exit().remove();\n }\n\n // remove paths that didn't get used\n scatterLayer.selectAll('path:not([d])').remove();\n};\n\nfunction createFills(gd, traceJoin, plotinfo) {\n traceJoin.each(function(d) {\n var fills = ensureSingle(d3.select(this), 'g', 'fills');\n Drawing.setClipUrl(fills, plotinfo.layerClipId, gd);\n\n var trace = d[0].trace;\n\n var fillData = [];\n if(trace._ownfill) fillData.push('_ownFill');\n if(trace._nexttrace) fillData.push('_nextFill');\n\n var fillJoin = fills.selectAll('g').data(fillData, identity);\n\n fillJoin.enter().append('g');\n\n fillJoin.exit()\n .each(function(d) { trace[d] = null; })\n .remove();\n\n fillJoin.order().each(function(d) {\n // make a path element inside the fill group, just so\n // we can give it its own data later on and the group can\n // keep its simple '_*Fill' data\n trace[d] = ensureSingle(d3.select(this), 'path', 'js-fill');\n });\n });\n}\n\nfunction plotOne(gd, idx, plotinfo, cdscatter, cdscatterAll, element, transitionOpts) {\n var isStatic = gd._context.staticPlot;\n var i;\n\n // Since this has been reorganized and we're executing this on individual traces,\n // we need to pass it the full list of cdscatter as well as this trace's index (idx)\n // since it does an internal n^2 loop over comparisons with other traces:\n selectMarkers(gd, idx, plotinfo, cdscatter, cdscatterAll);\n\n var hasTransition = !!transitionOpts && transitionOpts.duration > 0;\n\n function transition(selection) {\n return hasTransition ? selection.transition() : selection;\n }\n\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n var trace = cdscatter[0].trace;\n var line = trace.line;\n var tr = d3.select(element);\n\n var errorBarGroup = ensureSingle(tr, 'g', 'errorbars');\n var lines = ensureSingle(tr, 'g', 'lines');\n var points = ensureSingle(tr, 'g', 'points');\n var text = ensureSingle(tr, 'g', 'text');\n\n // error bars are at the bottom\n Registry.getComponentMethod('errorbars', 'plot')(gd, errorBarGroup, plotinfo, transitionOpts);\n\n if(trace.visible !== true) return;\n\n transition(tr).style('opacity', trace.opacity);\n\n // BUILD LINES AND FILLS\n var ownFillEl3, tonext;\n var ownFillDir = trace.fill.charAt(trace.fill.length - 1);\n if(ownFillDir !== 'x' && ownFillDir !== 'y') ownFillDir = '';\n\n var fillAxisIndex, fillAxisZero;\n if(ownFillDir === 'y') {\n fillAxisIndex = 1;\n fillAxisZero = ya.c2p(0, true);\n } else if(ownFillDir === 'x') {\n fillAxisIndex = 0;\n fillAxisZero = xa.c2p(0, true);\n }\n\n // store node for tweaking by selectPoints\n cdscatter[0][plotinfo.isRangePlot ? 'nodeRangePlot3' : 'node3'] = tr;\n\n var prevRevpath = '';\n var prevPolygons = [];\n var prevtrace = trace._prevtrace;\n var prevFillsegments = null;\n var prevFillElement = null;\n\n if(prevtrace) {\n prevRevpath = prevtrace._prevRevpath || '';\n tonext = prevtrace._nextFill;\n prevPolygons = prevtrace._ownPolygons;\n prevFillsegments = prevtrace._fillsegments;\n prevFillElement = prevtrace._fillElement;\n }\n\n var thispath;\n var thisrevpath;\n // fullpath is all paths for this curve, joined together straight\n // across gaps, for filling\n var fullpath = '';\n // revpath is fullpath reversed, for fill-to-next\n var revpath = '';\n // functions for converting a point array to a path\n var pathfn, revpathbase, revpathfn;\n // variables used before and after the data join\n var pt0, lastSegment, pt1;\n\n // thisPolygons always contains only the polygons of this trace only\n // whereas trace._polygons may be extended to include those of the previous\n // trace as well for exclusion during hover detection\n var thisPolygons = [];\n trace._polygons = [];\n\n var fillsegments = [];\n\n // initialize line join data / method\n var segments = [];\n var makeUpdate = Lib.noop;\n\n ownFillEl3 = trace._ownFill;\n\n if(subTypes.hasLines(trace) || trace.fill !== 'none') {\n if(tonext) {\n // This tells .style which trace to use for fill information:\n tonext.datum(cdscatter);\n }\n\n if(['hv', 'vh', 'hvh', 'vhv'].indexOf(line.shape) !== -1) {\n pathfn = Drawing.steps(line.shape);\n revpathbase = Drawing.steps(\n line.shape.split('').reverse().join('')\n );\n } else if(line.shape === 'spline') {\n pathfn = revpathbase = function(pts) {\n var pLast = pts[pts.length - 1];\n if(pts.length > 1 && pts[0][0] === pLast[0] && pts[0][1] === pLast[1]) {\n // identical start and end points: treat it as a\n // closed curve so we don't get a kink\n return Drawing.smoothclosed(pts.slice(1), line.smoothing);\n } else {\n return Drawing.smoothopen(pts, line.smoothing);\n }\n };\n } else {\n pathfn = revpathbase = function(pts) {\n return 'M' + pts.join('L');\n };\n }\n\n revpathfn = function(pts) {\n // note: this is destructive (reverses pts in place) so can't use pts after this\n return revpathbase(pts.reverse());\n };\n\n segments = linePoints(cdscatter, {\n xaxis: xa,\n yaxis: ya,\n trace: trace,\n connectGaps: trace.connectgaps,\n baseTolerance: Math.max(line.width || 1, 3) / 4,\n shape: line.shape,\n backoff: line.backoff,\n simplify: line.simplify,\n fill: trace.fill\n });\n\n // since we already have the pixel segments here, use them to make\n // polygons for hover on fill; we first merge segments where the fill\n // is connected into \"fillsegments\"; the actual polygon construction\n // is deferred to later to distinguish between self and tonext/tozero fills.\n // TODO: can we skip this if hoveron!=fills? That would mean we\n // need to redraw when you change hoveron...\n fillsegments = new Array(segments.length);\n var fillsegmentCount = 0;\n for(i = 0; i < segments.length; i++) {\n var curpoints;\n var pts = segments[i];\n if(!curpoints || !ownFillDir) {\n curpoints = pts.slice();\n fillsegments[fillsegmentCount] = curpoints;\n fillsegmentCount++;\n } else {\n curpoints.push.apply(curpoints, pts);\n }\n }\n\n trace._fillElement = null;\n trace._fillExclusionElement = prevFillElement;\n\n trace._fillsegments = fillsegments.slice(0, fillsegmentCount);\n fillsegments = trace._fillsegments;\n\n if(segments.length) {\n pt0 = segments[0][0].slice();\n lastSegment = segments[segments.length - 1];\n pt1 = lastSegment[lastSegment.length - 1].slice();\n }\n\n makeUpdate = function(isEnter) {\n return function(pts) {\n thispath = pathfn(pts);\n thisrevpath = revpathfn(pts); // side-effect: reverses input\n // calculate SVG path over all segments for fills\n if(!fullpath) {\n fullpath = thispath;\n revpath = thisrevpath;\n } else if(ownFillDir) {\n // for fills with fill direction: ignore gaps\n fullpath += 'L' + thispath.substr(1);\n revpath = thisrevpath + ('L' + revpath.substr(1));\n } else {\n fullpath += 'Z' + thispath;\n revpath = thisrevpath + 'Z' + revpath;\n }\n\n // actual lines get drawn here, with gaps between segments if requested\n if(subTypes.hasLines(trace)) {\n var el = d3.select(this);\n\n // This makes the coloring work correctly:\n el.datum(cdscatter);\n\n if(isEnter) {\n transition(el.style('opacity', 0)\n .attr('d', thispath)\n .call(Drawing.lineGroupStyle))\n .style('opacity', 1);\n } else {\n var sel = transition(el);\n sel.attr('d', thispath);\n Drawing.singleLineStyle(cdscatter, sel);\n }\n }\n };\n };\n }\n\n var lineJoin = lines.selectAll('.js-line').data(segments);\n\n transition(lineJoin.exit())\n .style('opacity', 0)\n .remove();\n\n lineJoin.each(makeUpdate(false));\n\n lineJoin.enter().append('path')\n .classed('js-line', true)\n .style('vector-effect', isStatic ? 'none' : 'non-scaling-stroke')\n .call(Drawing.lineGroupStyle)\n .each(makeUpdate(true));\n\n Drawing.setClipUrl(lineJoin, plotinfo.layerClipId, gd);\n\n function clearFill(selection) {\n transition(selection).attr('d', 'M0,0Z');\n }\n\n // helper functions to create polygons for hoveron fill detection\n var makeSelfPolygons = function() {\n var polygons = new Array(fillsegments.length);\n for(i = 0; i < fillsegments.length; i++) {\n polygons[i] = polygonTester(fillsegments[i]);\n }\n return polygons;\n };\n\n var makePolygonsToPrevious = function(prevFillsegments) {\n var polygons, i;\n if(!prevFillsegments || prevFillsegments.length === 0) {\n // if there are no fill segments of a previous trace, stretch the\n // polygon to the relevant axis\n polygons = new Array(fillsegments.length);\n for(i = 0; i < fillsegments.length; i++) {\n var pt0 = fillsegments[i][0].slice();\n var pt1 = fillsegments[i][fillsegments[i].length - 1].slice();\n\n pt0[fillAxisIndex] = pt1[fillAxisIndex] = fillAxisZero;\n\n var zeropoints = [pt1, pt0];\n var polypoints = zeropoints.concat(fillsegments[i]);\n polygons[i] = polygonTester(polypoints);\n }\n } else {\n // if there are more than one previous fill segment, the\n // way that fills work is to \"self\" fill all but the last segments\n // of the previous and then fill from the new trace to the last\n // segment of the previous.\n polygons = new Array(prevFillsegments.length - 1 + fillsegments.length);\n for(i = 0; i < prevFillsegments.length - 1; i++) {\n polygons[i] = polygonTester(prevFillsegments[i]);\n }\n\n var reversedPrevFillsegment = prevFillsegments[prevFillsegments.length - 1].slice();\n reversedPrevFillsegment.reverse();\n\n for(i = 0; i < fillsegments.length; i++) {\n polygons[prevFillsegments.length - 1 + i] = polygonTester(fillsegments[i].concat(reversedPrevFillsegment));\n }\n }\n return polygons;\n };\n\n // draw fills and create hover detection polygons\n if(segments.length) {\n if(ownFillEl3) {\n ownFillEl3.datum(cdscatter);\n if(pt0 && pt1) { // TODO(2023-12-10): this is always true if segments is not empty (?)\n if(ownFillDir) {\n pt0[fillAxisIndex] = pt1[fillAxisIndex] = fillAxisZero;\n\n // fill to zero: full trace path, plus extension of\n // the endpoints to the appropriate axis\n // For the sake of animations, wrap the points around so that\n // the points on the axes are the first two points. Otherwise\n // animations get a little crazy if the number of points changes.\n transition(ownFillEl3).attr('d', 'M' + pt1 + 'L' + pt0 + 'L' + fullpath.substr(1))\n .call(Drawing.singleFillStyle, gd);\n\n // create hover polygons that extend to the axis as well.\n thisPolygons = makePolygonsToPrevious(null); // polygon to axis\n } else {\n // fill to self: just join the path to itself\n transition(ownFillEl3).attr('d', fullpath + 'Z')\n .call(Drawing.singleFillStyle, gd);\n\n // and simply emit hover polygons for each segment\n thisPolygons = makeSelfPolygons();\n }\n }\n trace._polygons = thisPolygons;\n trace._fillElement = ownFillEl3;\n } else if(tonext) {\n if(trace.fill.substr(0, 6) === 'tonext' && fullpath && prevRevpath) {\n // fill to next: full trace path, plus the previous path reversed\n if(trace.fill === 'tonext') {\n // tonext: for use by concentric shapes, like manually constructed\n // contours, we just add the two paths closed on themselves.\n // This makes strange results if one path is *not* entirely\n // inside the other, but then that is a strange usage.\n transition(tonext).attr('d', fullpath + 'Z' + prevRevpath + 'Z')\n .call(Drawing.singleFillStyle, gd);\n\n // and simply emit hover polygons for each segment\n thisPolygons = makeSelfPolygons();\n\n // we add the polygons of the previous trace which causes hover\n // detection to ignore points contained in them.\n trace._polygons = thisPolygons.concat(prevPolygons); // this does not modify thisPolygons, on purpose\n } else {\n // tonextx/y: for now just connect endpoints with lines. This is\n // the correct behavior if the endpoints are at the same value of\n // y/x, but if they *aren't*, we should ideally do more complicated\n // things depending on whether the new endpoint projects onto the\n // existing curve or off the end of it\n transition(tonext).attr('d', fullpath + 'L' + prevRevpath.substr(1) + 'Z')\n .call(Drawing.singleFillStyle, gd);\n\n // create hover polygons that extend to the previous trace.\n thisPolygons = makePolygonsToPrevious(prevFillsegments);\n\n // in this case our polygons do not cover that of previous traces,\n // so must not include previous trace polygons for hover detection.\n trace._polygons = thisPolygons;\n }\n trace._fillElement = tonext;\n } else {\n clearFill(tonext);\n }\n }\n trace._prevRevpath = revpath;\n } else {\n if(ownFillEl3) clearFill(ownFillEl3);\n else if(tonext) clearFill(tonext);\n trace._prevRevpath = null;\n }\n trace._ownPolygons = thisPolygons;\n\n\n function visFilter(d) {\n return d.filter(function(v) { return !v.gap && v.vis; });\n }\n\n function visFilterWithGaps(d) {\n return d.filter(function(v) { return v.vis; });\n }\n\n function gapFilter(d) {\n return d.filter(function(v) { return !v.gap; });\n }\n\n function keyFunc(d) {\n return d.id;\n }\n\n // Returns a function if the trace is keyed, otherwise returns undefined\n function getKeyFunc(trace) {\n if(trace.ids) {\n return keyFunc;\n }\n }\n\n function hideFilter() {\n return false;\n }\n\n function makePoints(points, text, cdscatter) {\n var join, selection, hasNode;\n\n var trace = cdscatter[0].trace;\n var showMarkers = subTypes.hasMarkers(trace);\n var showText = subTypes.hasText(trace);\n\n var keyFunc = getKeyFunc(trace);\n var markerFilter = hideFilter;\n var textFilter = hideFilter;\n\n if(showMarkers || showText) {\n var showFilter = identity;\n // if we're stacking, \"infer zero\" gap mode gets markers in the\n // gap points - because we've inferred a zero there - but other\n // modes (currently \"interpolate\", later \"interrupt\" hopefully)\n // we don't draw generated markers\n var stackGroup = trace.stackgroup;\n var isInferZero = stackGroup && (\n gd._fullLayout._scatterStackOpts[xa._id + ya._id][stackGroup].stackgaps === 'infer zero');\n if(trace.marker.maxdisplayed || trace._needsCull) {\n showFilter = isInferZero ? visFilterWithGaps : visFilter;\n } else if(stackGroup && !isInferZero) {\n showFilter = gapFilter;\n }\n\n if(showMarkers) markerFilter = showFilter;\n if(showText) textFilter = showFilter;\n }\n\n // marker points\n\n selection = points.selectAll('path.point');\n\n join = selection.data(markerFilter, keyFunc);\n\n var enter = join.enter().append('path')\n .classed('point', true);\n\n if(hasTransition) {\n enter\n .call(Drawing.pointStyle, trace, gd)\n .call(Drawing.translatePoints, xa, ya)\n .style('opacity', 0)\n .transition()\n .style('opacity', 1);\n }\n\n join.order();\n\n var styleFns;\n if(showMarkers) {\n styleFns = Drawing.makePointStyleFns(trace);\n }\n\n join.each(function(d) {\n var el = d3.select(this);\n var sel = transition(el);\n hasNode = Drawing.translatePoint(d, sel, xa, ya);\n\n if(hasNode) {\n Drawing.singlePointStyle(d, sel, trace, styleFns, gd);\n\n if(plotinfo.layerClipId) {\n Drawing.hideOutsideRangePoint(d, sel, xa, ya, trace.xcalendar, trace.ycalendar);\n }\n\n if(trace.customdata) {\n el.classed('plotly-customdata', d.data !== null && d.data !== undefined);\n }\n } else {\n sel.remove();\n }\n });\n\n if(hasTransition) {\n join.exit().transition()\n .style('opacity', 0)\n .remove();\n } else {\n join.exit().remove();\n }\n\n // text points\n selection = text.selectAll('g');\n join = selection.data(textFilter, keyFunc);\n\n // each text needs to go in its own 'g' in case\n // it gets converted to mathjax\n join.enter().append('g').classed('textpoint', true).append('text');\n\n join.order();\n\n join.each(function(d) {\n var g = d3.select(this);\n var sel = transition(g.select('text'));\n hasNode = Drawing.translatePoint(d, sel, xa, ya);\n\n if(hasNode) {\n if(plotinfo.layerClipId) {\n Drawing.hideOutsideRangePoint(d, g, xa, ya, trace.xcalendar, trace.ycalendar);\n }\n } else {\n g.remove();\n }\n });\n\n join.selectAll('text')\n .call(Drawing.textPointStyle, trace, gd)\n .each(function(d) {\n // This just *has* to be totally custom because of SVG text positioning :(\n // It's obviously copied from translatePoint; we just can't use that\n var x = xa.c2p(d.x);\n var y = ya.c2p(d.y);\n\n d3.select(this).selectAll('tspan.line').each(function() {\n transition(d3.select(this)).attr({x: x, y: y});\n });\n });\n\n join.exit().remove();\n }\n\n points.datum(cdscatter);\n text.datum(cdscatter);\n makePoints(points, text, cdscatter);\n\n // lastly, clip points groups of `cliponaxis !== false` traces\n // on `plotinfo._hasClipOnAxisFalse === true` subplots\n var hasClipOnAxisFalse = trace.cliponaxis === false;\n var clipUrl = hasClipOnAxisFalse ? null : plotinfo.layerClipId;\n Drawing.setClipUrl(points, clipUrl, gd);\n Drawing.setClipUrl(text, clipUrl, gd);\n}\n\nfunction selectMarkers(gd, idx, plotinfo, cdscatter, cdscatterAll) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var xr = d3.extent(Lib.simpleMap(xa.range, xa.r2c));\n var yr = d3.extent(Lib.simpleMap(ya.range, ya.r2c));\n\n var trace = cdscatter[0].trace;\n if(!subTypes.hasMarkers(trace)) return;\n // if marker.maxdisplayed is used, select a maximum of\n // mnum markers to show, from the set that are in the viewport\n var mnum = trace.marker.maxdisplayed;\n\n // TODO: remove some as we get away from the viewport?\n if(mnum === 0) return;\n\n var cd = cdscatter.filter(function(v) {\n return v.x >= xr[0] && v.x <= xr[1] && v.y >= yr[0] && v.y <= yr[1];\n });\n var inc = Math.ceil(cd.length / mnum);\n var tnum = 0;\n cdscatterAll.forEach(function(cdj, j) {\n var tracei = cdj[0].trace;\n if(subTypes.hasMarkers(tracei) &&\n tracei.marker.maxdisplayed > 0 && j < idx) {\n tnum++;\n }\n });\n\n // if multiple traces use maxdisplayed, stagger which markers we\n // display this formula offsets successive traces by 1/3 of the\n // increment, adding an extra small amount after each triplet so\n // it's not quite periodic\n var i0 = Math.round(tnum * inc / 3 + Math.floor(tnum / 3) * inc / 7.1);\n\n // for error bars: save in cd which markers to show\n // so we don't have to repeat this\n cdscatter.forEach(function(v) { delete v.vis; });\n cd.forEach(function(v, i) {\n if(Math.round((i + i0) % inc) === 0) v.vis = true;\n });\n}\n","'use strict';\n\nvar subtypes = require('./subtypes');\n\nmodule.exports = function selectPoints(searchInfo, selectionTester) {\n var cd = searchInfo.cd;\n var xa = searchInfo.xaxis;\n var ya = searchInfo.yaxis;\n var selection = [];\n var trace = cd[0].trace;\n var i;\n var di;\n var x;\n var y;\n\n var hasOnlyLines = (!subtypes.hasMarkers(trace) && !subtypes.hasText(trace));\n if(hasOnlyLines) return [];\n\n if(selectionTester === false) { // clear selection\n for(i = 0; i < cd.length; i++) {\n cd[i].selected = 0;\n }\n } else {\n for(i = 0; i < cd.length; i++) {\n di = cd[i];\n x = xa.c2p(di.x);\n y = ya.c2p(di.y);\n\n if((di.i !== null) && selectionTester.contains([x, y], false, i, searchInfo)) {\n selection.push({\n pointNumber: di.i,\n x: xa.c2d(di.x),\n y: ya.c2d(di.y)\n });\n di.selected = 1;\n } else {\n di.selected = 0;\n }\n }\n }\n\n return selection;\n};\n","'use strict';\n\nvar perStackAttrs = ['orientation', 'groupnorm', 'stackgaps'];\n\nmodule.exports = function handleStackDefaults(traceIn, traceOut, layout, coerce) {\n var stackOpts = layout._scatterStackOpts;\n\n var stackGroup = coerce('stackgroup');\n if(stackGroup) {\n // use independent stacking options per subplot\n var subplot = traceOut.xaxis + traceOut.yaxis;\n var subplotStackOpts = stackOpts[subplot];\n if(!subplotStackOpts) subplotStackOpts = stackOpts[subplot] = {};\n\n var groupOpts = subplotStackOpts[stackGroup];\n var firstTrace = false;\n if(groupOpts) {\n groupOpts.traces.push(traceOut);\n } else {\n groupOpts = subplotStackOpts[stackGroup] = {\n // keep track of trace indices for use during stacking calculations\n // this will be filled in during `calc` and used during `crossTraceCalc`\n // so it's OK if we don't recreate it during a non-calc edit\n traceIndices: [],\n // Hold on to the whole set of prior traces\n // First one is most important, so we can clear defaults\n // there if we find explicit values only in later traces.\n // We're only going to *use* the values stored in groupOpts,\n // but for the editor and validate we want things self-consistent\n // The full set of traces is used only to fix `fill` default if\n // we find `orientation: 'h'` beyond the first trace\n traces: [traceOut]\n };\n firstTrace = true;\n }\n // TODO: how is this going to work with groupby transforms?\n // in principle it should be OK I guess, as long as explicit group styles\n // don't override explicit base-trace styles?\n\n var dflts = {\n orientation: (traceOut.x && !traceOut.y) ? 'h' : 'v'\n };\n\n for(var i = 0; i < perStackAttrs.length; i++) {\n var attr = perStackAttrs[i];\n var attrFound = attr + 'Found';\n if(!groupOpts[attrFound]) {\n var traceHasAttr = traceIn[attr] !== undefined;\n var isOrientation = attr === 'orientation';\n if(traceHasAttr || firstTrace) {\n groupOpts[attr] = coerce(attr, dflts[attr]);\n\n if(isOrientation) {\n groupOpts.fillDflt = groupOpts[attr] === 'h' ?\n 'tonextx' : 'tonexty';\n }\n\n if(traceHasAttr) {\n // Note: this will show a value here even if it's invalid\n // in which case it will revert to default.\n groupOpts[attrFound] = true;\n\n // Note: only one trace in the stack will get a _fullData\n // entry for a given stack-wide attribute. If no traces\n // (or the first trace) specify that attribute, the\n // first trace will get it. If the first trace does NOT\n // specify it but some later trace does, then it gets\n // removed from the first trace and only included in the\n // one that specified it. This is mostly important for\n // editors (that want to see the full values to know\n // what settings are available) and Plotly.react diffing.\n // Editors may want to use fullLayout._scatterStackOpts\n // directly and make these settings available from all\n // traces in the stack... then set the new value into\n // the first trace, and clear all later traces.\n if(!firstTrace) {\n delete groupOpts.traces[0][attr];\n\n // orientation can affect default fill of previous traces\n if(isOrientation) {\n for(var j = 0; j < groupOpts.traces.length - 1; j++) {\n var trace2 = groupOpts.traces[j];\n if(trace2._input.fill !== trace2.fill) {\n trace2.fill = groupOpts.fillDflt;\n }\n }\n }\n }\n }\n }\n }\n }\n return groupOpts;\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Drawing = require('../../components/drawing');\nvar Registry = require('../../registry');\n\nfunction style(gd) {\n var s = d3.select(gd).selectAll('g.trace.scatter');\n\n s.style('opacity', function(d) {\n return d[0].trace.opacity;\n });\n\n s.selectAll('g.points').each(function(d) {\n var sel = d3.select(this);\n var trace = d.trace || d[0].trace;\n stylePoints(sel, trace, gd);\n });\n\n s.selectAll('g.text').each(function(d) {\n var sel = d3.select(this);\n var trace = d.trace || d[0].trace;\n styleText(sel, trace, gd);\n });\n\n s.selectAll('g.trace path.js-line')\n .call(Drawing.lineGroupStyle);\n\n s.selectAll('g.trace path.js-fill')\n .call(Drawing.fillGroupStyle, gd, false);\n\n Registry.getComponentMethod('errorbars', 'style')(s);\n}\n\nfunction stylePoints(sel, trace, gd) {\n Drawing.pointStyle(sel.selectAll('path.point'), trace, gd);\n}\n\nfunction styleText(sel, trace, gd) {\n Drawing.textPointStyle(sel.selectAll('text'), trace, gd);\n}\n\nfunction styleOnSelect(gd, cd, sel) {\n var trace = cd[0].trace;\n\n if(trace.selectedpoints) {\n Drawing.selectedPointStyle(sel.selectAll('path.point'), trace);\n Drawing.selectedTextStyle(sel.selectAll('text'), trace);\n } else {\n stylePoints(sel, trace, gd);\n styleText(sel, trace, gd);\n }\n}\n\nmodule.exports = {\n style: style,\n stylePoints: stylePoints,\n styleText: styleText,\n styleOnSelect: styleOnSelect\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar isTypedArraySpec = require('../../lib/array').isTypedArraySpec;\n\nmodule.exports = {\n hasLines: function(trace) {\n return trace.visible && trace.mode &&\n trace.mode.indexOf('lines') !== -1;\n },\n\n hasMarkers: function(trace) {\n return trace.visible && (\n (trace.mode && trace.mode.indexOf('markers') !== -1) ||\n // until splom implements 'mode'\n trace.type === 'splom'\n );\n },\n\n hasText: function(trace) {\n return trace.visible && trace.mode &&\n trace.mode.indexOf('text') !== -1;\n },\n\n isBubble: function(trace) {\n var marker = trace.marker;\n return Lib.isPlainObject(marker) && (\n Lib.isArrayOrTypedArray(marker.size) ||\n isTypedArraySpec(marker.size)\n );\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\n/*\n * opts: object of flags to control features not all text users support\n * noSelect: caller does not support selected/unselected attribute containers\n */\nmodule.exports = function(traceIn, traceOut, layout, coerce, opts) {\n opts = opts || {};\n\n coerce('textposition');\n Lib.coerceFont(coerce, 'textfont', opts.font || layout.font, opts);\n\n if(!opts.noSelect) {\n coerce('selected.textfont.color');\n coerce('unselected.textfont.color');\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\n\nmodule.exports = function handleXYDefaults(traceIn, traceOut, layout, coerce) {\n var x = coerce('x');\n var y = coerce('y');\n var len;\n\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleTraceDefaults');\n handleCalendarDefaults(traceIn, traceOut, ['x', 'y'], layout);\n\n if(x) {\n var xlen = Lib.minRowLength(x);\n if(y) {\n len = Math.min(xlen, Lib.minRowLength(y));\n } else {\n len = xlen;\n coerce('y0');\n coerce('dy');\n }\n } else {\n if(!y) return 0;\n\n len = Lib.minRowLength(y);\n coerce('x0');\n coerce('dx');\n }\n\n traceOut._length = len;\n\n return len;\n};\n","'use strict';\n\nvar scatterAttrs = require('../scatter/attributes');\nvar fontAttrs = require('../../plots/font_attributes');\nvar colorAttributes = require('../../components/colorscale/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar baseAttrs = require('../../plots/attributes');\nvar DASHES = require('../../constants/gl3d_dashes');\n\nvar MARKER_SYMBOLS = require('../../constants/gl3d_markers');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar sortObjectKeys = require('../../lib/sort_object_keys');\n\nvar scatterLineAttrs = scatterAttrs.line;\nvar scatterMarkerAttrs = scatterAttrs.marker;\nvar scatterMarkerLineAttrs = scatterMarkerAttrs.line;\n\nvar lineAttrs = extendFlat({\n width: scatterLineAttrs.width,\n dash: {\n valType: 'enumerated',\n values: sortObjectKeys(DASHES),\n dflt: 'solid',\n description: 'Sets the dash style of the lines.'\n }\n}, colorAttributes('line'));\n\nfunction makeProjectionAttr(axLetter) {\n return {\n show: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Sets whether or not projections are shown along the',\n axLetter, 'axis.'\n ].join(' ')\n },\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n description: 'Sets the projection color.'\n },\n scale: {\n valType: 'number',\n min: 0,\n max: 10,\n dflt: 2 / 3,\n description: [\n 'Sets the scale factor determining the size of the',\n 'projection marker points.'\n ].join(' ')\n }\n };\n}\n\nvar attrs = module.exports = overrideAll({\n x: scatterAttrs.x,\n y: scatterAttrs.y,\n z: {\n valType: 'data_array',\n description: 'Sets the z coordinates.'\n },\n\n text: extendFlat({}, scatterAttrs.text, {\n description: [\n 'Sets text elements associated with each (x,y,z) triplet.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s (x,y,z) coordinates.',\n 'If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,',\n 'these elements will be seen in the hover labels.'\n ].join(' ')\n }),\n texttemplate: texttemplateAttrs({}, {\n\n }),\n hovertext: extendFlat({}, scatterAttrs.hovertext, {\n description: [\n 'Sets text elements associated with each (x,y,z) triplet.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s (x,y,z) coordinates.',\n 'To be seen, trace `hoverinfo` must contain a *text* flag.'\n ].join(' ')\n }),\n hovertemplate: hovertemplateAttrs(),\n\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n zhoverformat: axisHoverFormat('z'),\n\n mode: extendFlat({}, scatterAttrs.mode, // shouldn't this be on-par with 2D?\n {dflt: 'lines+markers'}),\n surfaceaxis: {\n valType: 'enumerated',\n values: [-1, 0, 1, 2],\n dflt: -1,\n description: [\n 'If *-1*, the scatter points are not fill with a surface',\n 'If *0*, *1*, *2*, the scatter points are filled with',\n 'a Delaunay surface about the x, y, z respectively.'\n ].join(' ')\n },\n surfacecolor: {\n valType: 'color',\n description: 'Sets the surface fill color.'\n },\n projection: {\n x: makeProjectionAttr('x'),\n y: makeProjectionAttr('y'),\n z: makeProjectionAttr('z')\n },\n\n connectgaps: scatterAttrs.connectgaps,\n line: lineAttrs,\n\n marker: extendFlat({ // Parity with scatter.js?\n symbol: {\n valType: 'enumerated',\n values: sortObjectKeys(MARKER_SYMBOLS),\n dflt: 'circle',\n arrayOk: true,\n description: 'Sets the marker symbol type.'\n },\n size: extendFlat({}, scatterMarkerAttrs.size, {dflt: 8}),\n sizeref: scatterMarkerAttrs.sizeref,\n sizemin: scatterMarkerAttrs.sizemin,\n sizemode: scatterMarkerAttrs.sizemode,\n opacity: extendFlat({}, scatterMarkerAttrs.opacity, {\n arrayOk: false,\n description: [\n 'Sets the marker opacity.',\n 'Note that the marker opacity for scatter3d traces',\n 'must be a scalar value for performance reasons.',\n 'To set a blending opacity value',\n '(i.e. which is not transparent), set *marker.color*',\n 'to an rgba color and use its alpha channel.'\n ].join(' ')\n }),\n colorbar: scatterMarkerAttrs.colorbar,\n\n line: extendFlat({\n width: extendFlat({}, scatterMarkerLineAttrs.width, {arrayOk: false})\n },\n colorAttributes('marker.line')\n )\n },\n colorAttributes('marker')\n ),\n\n textposition: extendFlat({}, scatterAttrs.textposition, {dflt: 'top center'}),\n textfont: fontAttrs({\n noFontShadow: true,\n noFontLineposition: true,\n noFontTextcase: true,\n editType: 'calc',\n colorEditType: 'style',\n arrayOk: true,\n variantValues: ['normal', 'small-caps'],\n description: 'Sets the text font.'\n }),\n\n opacity: baseAttrs.opacity,\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo)\n}, 'calc', 'nested');\n\nattrs.x.editType = attrs.y.editType = attrs.z.editType = 'calc+clearAxisTypes';\n","'use strict';\n\nvar arraysToCalcdata = require('../scatter/arrays_to_calcdata');\nvar calcColorscale = require('../scatter/colorscale_calc');\n\n/**\n * This is a kludge to put the array attributes into\n * calcdata the way Scatter.plot does, so that legends and\n * popovers know what to do with them.\n */\nmodule.exports = function calc(gd, trace) {\n var cd = [{x: false, y: false, trace: trace, t: {}}];\n\n arraysToCalcdata(cd, trace);\n calcColorscale(gd, trace);\n\n return cd;\n};\n","'use strict';\n\nvar Registry = require('../../registry');\n\nfunction calculateAxisErrors(data, params, scaleFactor, axis) {\n if(!params || !params.visible) return null;\n\n var computeError = Registry.getComponentMethod('errorbars', 'makeComputeError')(params);\n var result = new Array(data.length);\n\n for(var i = 0; i < data.length; i++) {\n var errors = computeError(+data[i], i);\n\n if(axis.type === 'log') {\n var point = axis.c2l(data[i]);\n var min = data[i] - errors[0];\n var max = data[i] + errors[1];\n\n result[i] = [\n (axis.c2l(min, true) - point) * scaleFactor,\n (axis.c2l(max, true) - point) * scaleFactor\n ];\n\n // Keep track of the lower error bound which isn't negative!\n if(min > 0) {\n var lower = axis.c2l(min);\n if(!axis._lowerLogErrorBound) axis._lowerLogErrorBound = lower;\n axis._lowerErrorBound = Math.min(axis._lowerLogErrorBound, lower);\n }\n } else {\n result[i] = [\n -errors[0] * scaleFactor,\n errors[1] * scaleFactor\n ];\n }\n }\n\n return result;\n}\n\nfunction dataLength(array) {\n for(var i = 0; i < array.length; i++) {\n if(array[i]) return array[i].length;\n }\n return 0;\n}\n\nfunction calculateErrors(data, scaleFactor, sceneLayout) {\n var errors = [\n calculateAxisErrors(data.x, data.error_x, scaleFactor[0], sceneLayout.xaxis),\n calculateAxisErrors(data.y, data.error_y, scaleFactor[1], sceneLayout.yaxis),\n calculateAxisErrors(data.z, data.error_z, scaleFactor[2], sceneLayout.zaxis)\n ];\n\n var n = dataLength(errors);\n if(n === 0) return null;\n\n var errorBounds = new Array(n);\n\n for(var i = 0; i < n; i++) {\n var bound = [[0, 0, 0], [0, 0, 0]];\n\n for(var j = 0; j < 3; j++) {\n if(errors[j]) {\n for(var k = 0; k < 2; k++) {\n bound[k][j] = errors[j][i][k];\n }\n }\n }\n\n errorBounds[i] = bound;\n }\n\n return errorBounds;\n}\n\nmodule.exports = calculateErrors;\n","'use strict';\n\nvar createLinePlot = require('../../../stackgl_modules').gl_line3d;\nvar createScatterPlot = require('../../../stackgl_modules').gl_scatter3d;\nvar createErrorBars = require('../../../stackgl_modules').gl_error3d;\nvar createMesh = require('../../../stackgl_modules').gl_mesh3d;\nvar triangulate = require('../../../stackgl_modules').delaunay_triangulate;\n\nvar Lib = require('../../lib');\nvar str2RgbaArray = require('../../lib/str2rgbarray');\nvar formatColor = require('../../lib/gl_format_color').formatColor;\nvar makeBubbleSizeFn = require('../scatter/make_bubble_size_func');\nvar DASH_PATTERNS = require('../../constants/gl3d_dashes');\nvar MARKER_SYMBOLS = require('../../constants/gl3d_markers');\n\nvar Axes = require('../../plots/cartesian/axes');\nvar appendArrayPointValue = require('../../components/fx/helpers').appendArrayPointValue;\n\nvar calculateError = require('./calc_errors');\n\nfunction LineWithMarkers(scene, uid) {\n this.scene = scene;\n this.uid = uid;\n this.linePlot = null;\n this.scatterPlot = null;\n this.errorBars = null;\n this.textMarkers = null;\n this.delaunayMesh = null;\n this.color = null;\n this.mode = '';\n this.dataPoints = [];\n this.axesBounds = [\n [-Infinity, -Infinity, -Infinity],\n [Infinity, Infinity, Infinity]\n ];\n this.textLabels = null;\n this.data = null;\n}\n\nvar proto = LineWithMarkers.prototype;\n\nproto.handlePick = function(selection) {\n if(selection.object &&\n (selection.object === this.linePlot ||\n selection.object === this.delaunayMesh ||\n selection.object === this.textMarkers ||\n selection.object === this.scatterPlot)\n ) {\n var ind = selection.index = selection.data.index;\n\n if(selection.object.highlight) {\n selection.object.highlight(null);\n }\n if(this.scatterPlot) {\n selection.object = this.scatterPlot;\n this.scatterPlot.highlight(selection.data);\n }\n\n selection.textLabel = '';\n if(this.textLabels) {\n if(Lib.isArrayOrTypedArray(this.textLabels)) {\n if(this.textLabels[ind] || this.textLabels[ind] === 0) {\n selection.textLabel = this.textLabels[ind];\n }\n } else {\n selection.textLabel = this.textLabels;\n }\n }\n\n selection.traceCoordinate = [\n this.data.x[ind],\n this.data.y[ind],\n this.data.z[ind]\n ];\n\n return true;\n }\n};\n\nfunction constructDelaunay(points, color, axis) {\n var u = (axis + 1) % 3;\n var v = (axis + 2) % 3;\n var filteredPoints = [];\n var filteredIds = [];\n var i;\n\n for(i = 0; i < points.length; ++i) {\n var p = points[i];\n if(isNaN(p[u]) || !isFinite(p[u]) ||\n isNaN(p[v]) || !isFinite(p[v])) {\n continue;\n }\n filteredPoints.push([p[u], p[v]]);\n filteredIds.push(i);\n }\n var cells = triangulate(filteredPoints);\n for(i = 0; i < cells.length; ++i) {\n var c = cells[i];\n for(var j = 0; j < c.length; ++j) {\n c[j] = filteredIds[c[j]];\n }\n }\n return {\n positions: points,\n cells: cells,\n meshColor: color\n };\n}\n\nfunction calculateErrorParams(errors) {\n var capSize = [0.0, 0.0, 0.0];\n var color = [[0, 0, 0], [0, 0, 0], [0, 0, 0]];\n var lineWidth = [1.0, 1.0, 1.0];\n\n for(var i = 0; i < 3; i++) {\n var e = errors[i];\n\n if(e && e.copy_zstyle !== false && errors[2].visible !== false) e = errors[2];\n if(!e || !e.visible) continue;\n\n capSize[i] = e.width / 2; // ballpark rescaling\n color[i] = str2RgbaArray(e.color);\n lineWidth[i] = e.thickness;\n }\n\n return {capSize: capSize, color: color, lineWidth: lineWidth};\n}\n\nfunction parseAlignmentX(a) {\n if(a === null || a === undefined) return 0;\n\n return (a.indexOf('left') > -1) ? -1 :\n (a.indexOf('right') > -1) ? 1 : 0;\n}\n\nfunction parseAlignmentY(a) {\n if(a === null || a === undefined) return 0;\n\n return (a.indexOf('top') > -1) ? -1 :\n (a.indexOf('bottom') > -1) ? 1 : 0;\n}\n\nfunction calculateTextOffset(tp) {\n // Read out text properties\n\n var defaultAlignmentX = 0;\n var defaultAlignmentY = 0;\n\n var textOffset = [\n defaultAlignmentX,\n defaultAlignmentY\n ];\n\n if(Array.isArray(tp)) {\n for(var i = 0; i < tp.length; i++) {\n textOffset[i] = [\n defaultAlignmentX,\n defaultAlignmentY\n ];\n if(tp[i]) {\n textOffset[i][0] = parseAlignmentX(tp[i]);\n textOffset[i][1] = parseAlignmentY(tp[i]);\n }\n }\n } else {\n textOffset[0] = parseAlignmentX(tp);\n textOffset[1] = parseAlignmentY(tp);\n }\n\n return textOffset;\n}\n\n\nfunction calculateSize(sizeIn, sizeFn) {\n // rough parity with Plotly 2D markers\n return sizeFn(sizeIn * 4);\n}\n\nfunction calculateSymbol(symbolIn) {\n return MARKER_SYMBOLS[symbolIn];\n}\n\nfunction formatParam(paramIn, len, calculate, dflt, extraFn) {\n var paramOut = null;\n\n if(Lib.isArrayOrTypedArray(paramIn)) {\n paramOut = [];\n\n for(var i = 0; i < len; i++) {\n if(paramIn[i] === undefined) paramOut[i] = dflt;\n else paramOut[i] = calculate(paramIn[i], extraFn);\n }\n } else paramOut = calculate(paramIn, Lib.identity);\n\n return paramOut;\n}\n\n\nfunction convertPlotlyOptions(scene, data) {\n var points = [];\n var sceneLayout = scene.fullSceneLayout;\n var scaleFactor = scene.dataScale;\n var xaxis = sceneLayout.xaxis;\n var yaxis = sceneLayout.yaxis;\n var zaxis = sceneLayout.zaxis;\n var marker = data.marker;\n var line = data.line;\n var x = data.x || [];\n var y = data.y || [];\n var z = data.z || [];\n var len = x.length;\n var xcalendar = data.xcalendar;\n var ycalendar = data.ycalendar;\n var zcalendar = data.zcalendar;\n var xc, yc, zc;\n var params, i;\n var text;\n\n // Convert points\n for(i = 0; i < len; i++) {\n // sanitize numbers and apply transforms based on axes.type\n xc = xaxis.d2l(x[i], 0, xcalendar) * scaleFactor[0];\n yc = yaxis.d2l(y[i], 0, ycalendar) * scaleFactor[1];\n zc = zaxis.d2l(z[i], 0, zcalendar) * scaleFactor[2];\n\n points[i] = [xc, yc, zc];\n }\n\n // convert text\n if(Array.isArray(data.text)) {\n text = data.text;\n } else if(Lib.isTypedArray(data.text)) {\n text = Array.from(data.text);\n } else if(data.text !== undefined) {\n text = new Array(len);\n for(i = 0; i < len; i++) text[i] = data.text;\n }\n\n function formatter(axName, val) {\n var ax = sceneLayout[axName];\n return Axes.tickText(ax, ax.d2l(val), true).text;\n }\n\n // check texttemplate\n var texttemplate = data.texttemplate;\n if(texttemplate) {\n var fullLayout = scene.fullLayout;\n var d3locale = fullLayout._d3locale;\n var isArray = Array.isArray(texttemplate);\n var N = isArray ? Math.min(texttemplate.length, len) : len;\n var txt = isArray ?\n function(i) { return texttemplate[i]; } :\n function() { return texttemplate; };\n\n text = new Array(N);\n\n for(i = 0; i < N; i++) {\n var d = {x: x[i], y: y[i], z: z[i]};\n var labels = {\n xLabel: formatter('xaxis', x[i]),\n yLabel: formatter('yaxis', y[i]),\n zLabel: formatter('zaxis', z[i])\n };\n var pointValues = {};\n appendArrayPointValue(pointValues, data, i);\n var meta = data._meta || {};\n text[i] = Lib.texttemplateString(txt(i), labels, d3locale, pointValues, d, meta);\n }\n }\n\n // Build object parameters\n params = {\n position: points,\n mode: data.mode,\n text: text\n };\n\n if('line' in data) {\n params.lineColor = formatColor(line, 1, len);\n params.lineWidth = line.width;\n params.lineDashes = line.dash;\n }\n\n if('marker' in data) {\n var sizeFn = makeBubbleSizeFn(data);\n\n params.scatterColor = formatColor(marker, 1, len);\n params.scatterSize = formatParam(marker.size, len, calculateSize, 20, sizeFn);\n params.scatterMarker = formatParam(marker.symbol, len, calculateSymbol, '●');\n params.scatterLineWidth = marker.line.width; // arrayOk === false\n params.scatterLineColor = formatColor(marker.line, 1, len);\n params.scatterAngle = 0;\n }\n\n if('textposition' in data) {\n params.textOffset = calculateTextOffset(data.textposition);\n params.textColor = formatColor(data.textfont, 1, len);\n params.textSize = formatParam(data.textfont.size, len, Lib.identity, 12);\n params.textFontFamily = data.textfont.family;\n params.textFontWeight = data.textfont.weight;\n params.textFontStyle = data.textfont.style;\n params.textFontVariant = data.textfont.variant;\n params.textAngle = 0;\n }\n\n var dims = ['x', 'y', 'z'];\n params.project = [false, false, false];\n params.projectScale = [1, 1, 1];\n params.projectOpacity = [1, 1, 1];\n for(i = 0; i < 3; ++i) {\n var projection = data.projection[dims[i]];\n if((params.project[i] = projection.show)) {\n params.projectOpacity[i] = projection.opacity;\n params.projectScale[i] = projection.scale;\n }\n }\n\n params.errorBounds = calculateError(data, scaleFactor, sceneLayout);\n\n var errorParams = calculateErrorParams([data.error_x, data.error_y, data.error_z]);\n params.errorColor = errorParams.color;\n params.errorLineWidth = errorParams.lineWidth;\n params.errorCapSize = errorParams.capSize;\n\n params.delaunayAxis = data.surfaceaxis;\n params.delaunayColor = str2RgbaArray(data.surfacecolor);\n\n return params;\n}\n\nfunction _arrayToColor(color) {\n if(Lib.isArrayOrTypedArray(color)) {\n var c = color[0];\n\n if(Lib.isArrayOrTypedArray(c)) color = c;\n\n return 'rgb(' + color.slice(0, 3).map(function(x) {\n return Math.round(x * 255);\n }) + ')';\n }\n\n return null;\n}\n\nfunction arrayToColor(colors) {\n if(!Lib.isArrayOrTypedArray(colors)) {\n return null;\n }\n\n if((colors.length === 4) && (typeof colors[0] === 'number')) {\n return _arrayToColor(colors);\n }\n\n return colors.map(_arrayToColor);\n}\n\nproto.update = function(data) {\n var gl = this.scene.glplot.gl;\n var lineOptions;\n var scatterOptions;\n var errorOptions;\n var textOptions;\n var dashPattern = DASH_PATTERNS.solid;\n\n // Save data\n this.data = data;\n\n // Run data conversion\n var options = convertPlotlyOptions(this.scene, data);\n\n if('mode' in options) {\n this.mode = options.mode;\n }\n if('lineDashes' in options) {\n if(options.lineDashes in DASH_PATTERNS) {\n dashPattern = DASH_PATTERNS[options.lineDashes];\n }\n }\n\n this.color = arrayToColor(options.scatterColor) ||\n arrayToColor(options.lineColor);\n\n // Save data points\n this.dataPoints = options.position;\n\n lineOptions = {\n gl: this.scene.glplot.gl,\n position: options.position,\n color: options.lineColor,\n lineWidth: options.lineWidth || 1,\n dashes: dashPattern[0],\n dashScale: dashPattern[1],\n opacity: data.opacity,\n connectGaps: data.connectgaps\n };\n\n if(this.mode.indexOf('lines') !== -1) {\n if(this.linePlot) this.linePlot.update(lineOptions);\n else {\n this.linePlot = createLinePlot(lineOptions);\n this.linePlot._trace = this;\n this.scene.glplot.add(this.linePlot);\n }\n } else if(this.linePlot) {\n this.scene.glplot.remove(this.linePlot);\n this.linePlot.dispose();\n this.linePlot = null;\n }\n\n // N.B. marker.opacity must be a scalar for performance\n var scatterOpacity = data.opacity;\n if(data.marker && data.marker.opacity !== undefined) scatterOpacity *= data.marker.opacity;\n\n scatterOptions = {\n gl: this.scene.glplot.gl,\n position: options.position,\n color: options.scatterColor,\n size: options.scatterSize,\n glyph: options.scatterMarker,\n opacity: scatterOpacity,\n orthographic: true,\n lineWidth: options.scatterLineWidth,\n lineColor: options.scatterLineColor,\n project: options.project,\n projectScale: options.projectScale,\n projectOpacity: options.projectOpacity\n };\n\n if(this.mode.indexOf('markers') !== -1) {\n if(this.scatterPlot) this.scatterPlot.update(scatterOptions);\n else {\n this.scatterPlot = createScatterPlot(scatterOptions);\n this.scatterPlot._trace = this;\n this.scatterPlot.highlightScale = 1;\n this.scene.glplot.add(this.scatterPlot);\n }\n } else if(this.scatterPlot) {\n this.scene.glplot.remove(this.scatterPlot);\n this.scatterPlot.dispose();\n this.scatterPlot = null;\n }\n\n textOptions = {\n gl: this.scene.glplot.gl,\n position: options.position,\n glyph: options.text,\n color: options.textColor,\n size: options.textSize,\n angle: options.textAngle,\n alignment: options.textOffset,\n font: options.textFontFamily,\n fontWeight: options.textFontWeight,\n fontStyle: options.textFontStyle,\n fontVariant: options.textFontVariant,\n orthographic: true,\n lineWidth: 0,\n project: false,\n opacity: data.opacity\n };\n\n this.textLabels = data.hovertext || data.text;\n\n if(this.mode.indexOf('text') !== -1) {\n if(this.textMarkers) this.textMarkers.update(textOptions);\n else {\n this.textMarkers = createScatterPlot(textOptions);\n this.textMarkers._trace = this;\n this.textMarkers.highlightScale = 1;\n this.scene.glplot.add(this.textMarkers);\n }\n } else if(this.textMarkers) {\n this.scene.glplot.remove(this.textMarkers);\n this.textMarkers.dispose();\n this.textMarkers = null;\n }\n\n errorOptions = {\n gl: this.scene.glplot.gl,\n position: options.position,\n color: options.errorColor,\n error: options.errorBounds,\n lineWidth: options.errorLineWidth,\n capSize: options.errorCapSize,\n opacity: data.opacity\n };\n if(this.errorBars) {\n if(options.errorBounds) {\n this.errorBars.update(errorOptions);\n } else {\n this.scene.glplot.remove(this.errorBars);\n this.errorBars.dispose();\n this.errorBars = null;\n }\n } else if(options.errorBounds) {\n this.errorBars = createErrorBars(errorOptions);\n this.errorBars._trace = this;\n this.scene.glplot.add(this.errorBars);\n }\n\n if(options.delaunayAxis >= 0) {\n var delaunayOptions = constructDelaunay(\n options.position,\n options.delaunayColor,\n options.delaunayAxis\n );\n delaunayOptions.opacity = data.opacity;\n\n if(this.delaunayMesh) {\n this.delaunayMesh.update(delaunayOptions);\n } else {\n delaunayOptions.gl = gl;\n this.delaunayMesh = createMesh(delaunayOptions);\n this.delaunayMesh._trace = this;\n this.scene.glplot.add(this.delaunayMesh);\n }\n } else if(this.delaunayMesh) {\n this.scene.glplot.remove(this.delaunayMesh);\n this.delaunayMesh.dispose();\n this.delaunayMesh = null;\n }\n};\n\nproto.dispose = function() {\n if(this.linePlot) {\n this.scene.glplot.remove(this.linePlot);\n this.linePlot.dispose();\n }\n if(this.scatterPlot) {\n this.scene.glplot.remove(this.scatterPlot);\n this.scatterPlot.dispose();\n }\n if(this.errorBars) {\n this.scene.glplot.remove(this.errorBars);\n this.errorBars.dispose();\n }\n if(this.textMarkers) {\n this.scene.glplot.remove(this.textMarkers);\n this.textMarkers.dispose();\n }\n if(this.delaunayMesh) {\n this.scene.glplot.remove(this.delaunayMesh);\n this.delaunayMesh.dispose();\n }\n};\n\nfunction createLineWithMarkers(scene, data) {\n var plot = new LineWithMarkers(scene, data.uid);\n plot.update(data);\n return plot;\n}\n\nmodule.exports = createLineWithMarkers;\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\n\nvar subTypes = require('../scatter/subtypes');\nvar handleMarkerDefaults = require('../scatter/marker_defaults');\nvar handleLineDefaults = require('../scatter/line_defaults');\nvar handleTextDefaults = require('../scatter/text_defaults');\n\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleXYZDefaults(traceIn, traceOut, coerce, layout);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n coerce('xhoverformat');\n coerce('yhoverformat');\n coerce('zhoverformat');\n\n coerce('mode');\n\n if(subTypes.hasMarkers(traceOut)) {\n handleMarkerDefaults(traceIn, traceOut, defaultColor, layout, coerce, {noSelect: true, noAngle: true});\n }\n\n if(subTypes.hasLines(traceOut)) {\n coerce('connectgaps');\n handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce);\n }\n\n if(subTypes.hasText(traceOut)) {\n coerce('texttemplate');\n handleTextDefaults(traceIn, traceOut, layout, coerce, {\n noSelect: true,\n noFontShadow: true,\n noFontLineposition: true,\n noFontTextcase: true,\n });\n }\n\n var lineColor = (traceOut.line || {}).color;\n var markerColor = (traceOut.marker || {}).color;\n if(coerce('surfaceaxis') >= 0) coerce('surfacecolor', lineColor || markerColor);\n\n var dims = ['x', 'y', 'z'];\n for(var i = 0; i < 3; ++i) {\n var projection = 'projection.' + dims[i];\n if(coerce(projection + '.show')) {\n coerce(projection + '.opacity');\n coerce(projection + '.scale');\n }\n }\n\n var errorBarsSupplyDefaults = Registry.getComponentMethod('errorbars', 'supplyDefaults');\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || markerColor || defaultColor, {axis: 'z'});\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || markerColor || defaultColor, {axis: 'y', inherit: 'z'});\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || markerColor || defaultColor, {axis: 'x', inherit: 'z'});\n};\n\nfunction handleXYZDefaults(traceIn, traceOut, coerce, layout) {\n var len = 0;\n var x = coerce('x');\n var y = coerce('y');\n var z = coerce('z');\n\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleTraceDefaults');\n handleCalendarDefaults(traceIn, traceOut, ['x', 'y', 'z'], layout);\n\n if(x && y && z) {\n // TODO: what happens if one is missing?\n len = Math.min(x.length, y.length, z.length);\n traceOut._length = traceOut._xlength = traceOut._ylength = traceOut._zlength = len;\n }\n\n return len;\n}\n","'use strict';\n\nmodule.exports = {\n plot: require('./convert'),\n attributes: require('./attributes'),\n markerSymbols: require('../../constants/gl3d_markers'),\n supplyDefaults: require('./defaults'),\n colorbar: [\n {\n container: 'marker',\n min: 'cmin',\n max: 'cmax'\n }, {\n container: 'line',\n min: 'cmin',\n max: 'cmax'\n }\n ],\n calc: require('./calc'),\n\n moduleType: 'trace',\n name: 'scatter3d',\n basePlotModule: require('../../plots/gl3d'),\n categories: ['gl3d', 'symbols', 'showLegend', 'scatter-like'],\n meta: {\n hrName: 'scatter_3d',\n description: [\n 'The data visualized as scatter point or lines in 3D dimension',\n 'is set in `x`, `y`, `z`.',\n 'Text (appearing either on the chart or on hover only) is via `text`.',\n 'Bubble charts are achieved by setting `marker.size` and/or `marker.color`',\n 'Projections are achieved via `projection`.',\n 'Surface fills are achieved via `surfaceaxis`.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar makeFillcolorAttr = require('../scatter/fillcolor_attribute');\nvar scatterAttrs = require('../scatter/attributes');\nvar baseAttrs = require('../../plots/attributes');\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar scatterMarkerAttrs = scatterAttrs.marker;\nvar scatterLineAttrs = scatterAttrs.line;\nvar scatterMarkerLineAttrs = scatterMarkerAttrs.line;\n\nmodule.exports = {\n carpet: {\n valType: 'string',\n editType: 'calc',\n description: [\n 'An identifier for this carpet, so that `scattercarpet` and',\n '`contourcarpet` traces can specify a carpet plot on which',\n 'they lie'\n ].join(' ')\n },\n a: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the a-axis coordinates.'\n },\n b: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the b-axis coordinates.'\n },\n mode: extendFlat({}, scatterAttrs.mode, {dflt: 'markers'}),\n text: extendFlat({}, scatterAttrs.text, {\n description: [\n 'Sets text elements associated with each (a,b) point.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of strings, the items are mapped in order to the',\n 'the data points in (a,b).',\n 'If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,',\n 'these elements will be seen in the hover labels.'\n ].join(' ')\n }),\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: ['a', 'b', 'text']\n }),\n hovertext: extendFlat({}, scatterAttrs.hovertext, {\n description: [\n 'Sets hover text elements associated with each (a,b) point.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of strings, the items are mapped in order to the',\n 'the data points in (a,b).',\n 'To be seen, trace `hoverinfo` must contain a *text* flag.'\n ].join(' ')\n }),\n line: {\n color: scatterLineAttrs.color,\n width: scatterLineAttrs.width,\n dash: scatterLineAttrs.dash,\n backoff: scatterLineAttrs.backoff,\n shape: extendFlat({}, scatterLineAttrs.shape,\n {values: ['linear', 'spline']}),\n smoothing: scatterLineAttrs.smoothing,\n editType: 'calc'\n },\n connectgaps: scatterAttrs.connectgaps,\n fill: extendFlat({}, scatterAttrs.fill, {\n values: ['none', 'toself', 'tonext'],\n dflt: 'none',\n description: [\n 'Sets the area to fill with a solid color.',\n 'Use with `fillcolor` if not *none*.',\n 'scatterternary has a subset of the options available to scatter.',\n '*toself* connects the endpoints of the trace (or each segment',\n 'of the trace if it has gaps) into a closed shape.',\n '*tonext* fills the space between two traces if one completely',\n 'encloses the other (eg consecutive contour lines), and behaves like',\n '*toself* if there is no trace before it. *tonext* should not be',\n 'used if one trace does not enclose the other.'\n ].join(' ')\n }),\n fillcolor: makeFillcolorAttr(),\n marker: extendFlat({\n symbol: scatterMarkerAttrs.symbol,\n opacity: scatterMarkerAttrs.opacity,\n maxdisplayed: scatterMarkerAttrs.maxdisplayed,\n angle: scatterMarkerAttrs.angle,\n angleref: scatterMarkerAttrs.angleref,\n standoff: scatterMarkerAttrs.standoff,\n size: scatterMarkerAttrs.size,\n sizeref: scatterMarkerAttrs.sizeref,\n sizemin: scatterMarkerAttrs.sizemin,\n sizemode: scatterMarkerAttrs.sizemode,\n line: extendFlat({\n width: scatterMarkerLineAttrs.width,\n editType: 'calc'\n },\n colorScaleAttrs('marker.line')\n ),\n gradient: scatterMarkerAttrs.gradient,\n editType: 'calc'\n },\n colorScaleAttrs('marker')\n ),\n\n textfont: scatterAttrs.textfont,\n textposition: scatterAttrs.textposition,\n\n selected: scatterAttrs.selected,\n unselected: scatterAttrs.unselected,\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['a', 'b', 'text', 'name']\n }),\n hoveron: scatterAttrs.hoveron,\n hovertemplate: hovertemplateAttrs(),\n zorder: scatterAttrs.zorder\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar calcColorscale = require('../scatter/colorscale_calc');\nvar arraysToCalcdata = require('../scatter/arrays_to_calcdata');\nvar calcSelection = require('../scatter/calc_selection');\nvar calcMarkerSize = require('../scatter/calc').calcMarkerSize;\nvar lookupCarpet = require('../carpet/lookup_carpetid');\n\nmodule.exports = function calc(gd, trace) {\n var carpet = trace._carpetTrace = lookupCarpet(gd, trace);\n if(!carpet || !carpet.visible || carpet.visible === 'legendonly') return;\n var i;\n\n // Transfer this over from carpet before plotting since this is a necessary\n // condition in order for cartesian to actually plot this trace:\n trace.xaxis = carpet.xaxis;\n trace.yaxis = carpet.yaxis;\n\n // make the calcdata array\n var serieslen = trace._length;\n var cd = new Array(serieslen);\n var a, b;\n var needsCull = false;\n for(i = 0; i < serieslen; i++) {\n a = trace.a[i];\n b = trace.b[i];\n if(isNumeric(a) && isNumeric(b)) {\n var xy = carpet.ab2xy(+a, +b, true);\n var visible = carpet.isVisible(+a, +b);\n if(!visible) needsCull = true;\n cd[i] = {x: xy[0], y: xy[1], a: a, b: b, vis: visible};\n } else cd[i] = {x: false, y: false};\n }\n\n trace._needsCull = needsCull;\n\n cd[0].carpet = carpet;\n cd[0].trace = trace;\n\n calcMarkerSize(trace, serieslen);\n calcColorscale(gd, trace);\n arraysToCalcdata(cd, trace);\n calcSelection(cd, trace);\n\n return cd;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar constants = require('../scatter/constants');\nvar subTypes = require('../scatter/subtypes');\nvar handleMarkerDefaults = require('../scatter/marker_defaults');\nvar handleLineDefaults = require('../scatter/line_defaults');\nvar handleLineShapeDefaults = require('../scatter/line_shape_defaults');\nvar handleTextDefaults = require('../scatter/text_defaults');\nvar handleFillColorDefaults = require('../scatter/fillcolor_defaults');\n\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n coerce('carpet');\n\n // XXX: Don't hard code this\n traceOut.xaxis = 'x';\n traceOut.yaxis = 'y';\n\n var a = coerce('a');\n var b = coerce('b');\n var len = Math.min(a.length, b.length);\n\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n traceOut._length = len;\n\n coerce('text');\n coerce('texttemplate');\n coerce('hovertext');\n\n var defaultMode = len < constants.PTS_LINESONLY ? 'lines+markers' : 'lines';\n coerce('mode', defaultMode);\n\n if(subTypes.hasMarkers(traceOut)) {\n handleMarkerDefaults(traceIn, traceOut, defaultColor, layout, coerce, {gradient: true});\n }\n\n if(subTypes.hasLines(traceOut)) {\n handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce, {backoff: true});\n handleLineShapeDefaults(traceIn, traceOut, coerce);\n coerce('connectgaps');\n }\n\n if(subTypes.hasText(traceOut)) {\n handleTextDefaults(traceIn, traceOut, layout, coerce);\n }\n\n var dfltHoverOn = [];\n\n if(subTypes.hasMarkers(traceOut) || subTypes.hasText(traceOut)) {\n coerce('marker.maxdisplayed');\n dfltHoverOn.push('points');\n }\n\n coerce('fill');\n if(traceOut.fill !== 'none') {\n handleFillColorDefaults(traceIn, traceOut, defaultColor, coerce);\n if(!subTypes.hasLines(traceOut)) handleLineShapeDefaults(traceIn, traceOut, coerce);\n }\n\n if(traceOut.fill === 'tonext' || traceOut.fill === 'toself') {\n dfltHoverOn.push('fills');\n }\n\n var hoverOn = coerce('hoveron', dfltHoverOn.join('+') || 'points');\n if(hoverOn !== 'fills') coerce('hovertemplate');\n\n coerce('zorder');\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n","'use strict';\n\nmodule.exports = function eventData(out, pt, trace, cd, pointNumber) {\n var cdi = cd[pointNumber];\n\n out.a = cdi.a;\n out.b = cdi.b;\n out.y = cdi.y;\n\n return out;\n};\n","'use strict';\n\nmodule.exports = function formatLabels(cdi, trace) {\n var labels = {};\n\n var carpet = trace._carpet;\n var ij = carpet.ab2ij([cdi.a, cdi.b]);\n var i0 = Math.floor(ij[0]);\n var ti = ij[0] - i0;\n var j0 = Math.floor(ij[1]);\n var tj = ij[1] - j0;\n var xy = carpet.evalxy([], i0, j0, ti, tj);\n\n labels.yLabel = xy[1].toFixed(3);\n\n return labels;\n};\n","'use strict';\n\nvar scatterHover = require('../scatter/hover');\nvar fillText = require('../../lib').fillText;\n\nmodule.exports = function hoverPoints(pointData, xval, yval, hovermode) {\n var scatterPointData = scatterHover(pointData, xval, yval, hovermode);\n if(!scatterPointData || scatterPointData[0].index === false) return;\n\n var newPointData = scatterPointData[0];\n\n // if hovering on a fill, we don't show any point data so the label is\n // unchanged from what scatter gives us - except that it needs to\n // be constrained to the trianglular plot area, not just the rectangular\n // area defined by the synthetic x and y axes\n // TODO: in some cases the vertical middle of the shape is not within\n // the triangular viewport at all, so the label can become disconnected\n // from the shape entirely. But calculating what portion of the shape\n // is actually visible, as constrained by the diagonal axis lines, is not\n // so easy and anyway we lost the information we would have needed to do\n // this inside scatterHover.\n if(newPointData.index === undefined) {\n var yFracUp = 1 - (newPointData.y0 / pointData.ya._length);\n var xLen = pointData.xa._length;\n var xMin = xLen * yFracUp / 2;\n var xMax = xLen - xMin;\n newPointData.x0 = Math.max(Math.min(newPointData.x0, xMax), xMin);\n newPointData.x1 = Math.max(Math.min(newPointData.x1, xMax), xMin);\n return scatterPointData;\n }\n\n var cdi = newPointData.cd[newPointData.index];\n\n newPointData.a = cdi.a;\n newPointData.b = cdi.b;\n\n newPointData.xLabelVal = undefined;\n newPointData.yLabelVal = undefined;\n // TODO: nice formatting, and label by axis title, for a, b, and c?\n\n var trace = newPointData.trace;\n var carpet = trace._carpet;\n\n var labels = trace._module.formatLabels(cdi, trace);\n newPointData.yLabel = labels.yLabel;\n\n delete newPointData.text;\n var text = [];\n\n function textPart(ax, val) {\n var prefix;\n\n if(ax.labelprefix && ax.labelprefix.length > 0) {\n prefix = ax.labelprefix.replace(/ = $/, '');\n } else {\n prefix = ax._hovertitle;\n }\n\n text.push(prefix + ': ' + val.toFixed(3) + ax.labelsuffix);\n }\n\n\n if(!trace.hovertemplate) {\n var hoverinfo = cdi.hi || trace.hoverinfo;\n var parts = hoverinfo.split('+');\n\n if(parts.indexOf('all') !== -1) parts = ['a', 'b', 'text'];\n if(parts.indexOf('a') !== -1) textPart(carpet.aaxis, cdi.a);\n if(parts.indexOf('b') !== -1) textPart(carpet.baxis, cdi.b);\n\n text.push('y: ' + newPointData.yLabel);\n\n if(parts.indexOf('text') !== -1) {\n fillText(cdi, trace, text);\n }\n\n newPointData.extraText = text.join('
');\n }\n\n return scatterPointData;\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../scatter/marker_colorbar'),\n formatLabels: require('./format_labels'),\n calc: require('./calc'),\n plot: require('./plot'),\n style: require('../scatter/style').style,\n styleOnSelect: require('../scatter/style').styleOnSelect,\n hoverPoints: require('./hover'),\n selectPoints: require('../scatter/select'),\n eventData: require('./event_data'),\n\n moduleType: 'trace',\n name: 'scattercarpet',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['svg', 'carpet', 'symbols', 'showLegend', 'carpetDependent', 'zoomScale'],\n meta: {\n hrName: 'scatter_carpet',\n description: [\n 'Plots a scatter trace on either the first carpet axis or the',\n 'carpet axis with a matching `carpet` attribute.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar scatterPlot = require('../scatter/plot');\nvar Axes = require('../../plots/cartesian/axes');\nvar Drawing = require('../../components/drawing');\n\nmodule.exports = function plot(gd, plotinfoproxy, data, layer) {\n var i, trace, node;\n\n var carpet = data[0][0].carpet;\n\n var xaxis = Axes.getFromId(gd, carpet.xaxis || 'x');\n var yaxis = Axes.getFromId(gd, carpet.yaxis || 'y');\n\n // mimic cartesian plotinfo\n var plotinfo = {\n xaxis: xaxis,\n yaxis: yaxis,\n plot: plotinfoproxy.plot,\n };\n\n for(i = 0; i < data.length; i++) {\n trace = data[i][0].trace;\n\n trace._xA = xaxis;\n trace._yA = yaxis;\n }\n\n scatterPlot(gd, plotinfo, data, layer);\n\n for(i = 0; i < data.length; i++) {\n trace = data[i][0].trace;\n\n // Note: .select is adequate but seems to mutate the node data,\n // which is at least a bit surprising and causes problems elsewhere\n node = layer.selectAll('g.trace' + trace.uid + ' .js-line');\n\n // Note: it would be more efficient if this didn't need to be applied\n // separately to all scattercarpet traces, but that would require\n // lots of reorganization of scatter traces that is otherwise not\n // necessary. That makes this a potential optimization.\n Drawing.setClipUrl(node, data[i][0].carpet._clipPathId, gd);\n }\n};\n","'use strict';\n\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar makeFillcolorAttr = require('../scatter/fillcolor_attribute');\nvar scatterAttrs = require('../scatter/attributes');\nvar baseAttrs = require('../../plots/attributes');\nvar colorAttributes = require('../../components/colorscale/attributes');\nvar dash = require('../../components/drawing/attributes').dash;\n\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\n\nvar scatterMarkerAttrs = scatterAttrs.marker;\nvar scatterLineAttrs = scatterAttrs.line;\nvar scatterMarkerLineAttrs = scatterMarkerAttrs.line;\n\nmodule.exports = overrideAll({\n lon: {\n valType: 'data_array',\n description: 'Sets the longitude coordinates (in degrees East).'\n },\n lat: {\n valType: 'data_array',\n description: 'Sets the latitude coordinates (in degrees North).'\n },\n\n locations: {\n valType: 'data_array',\n description: [\n 'Sets the coordinates via location IDs or names.',\n 'Coordinates correspond to the centroid of each location given.',\n 'See `locationmode` for more info.'\n ].join(' ')\n },\n locationmode: {\n valType: 'enumerated',\n values: ['ISO-3', 'USA-states', 'country names', 'geojson-id'],\n dflt: 'ISO-3',\n description: [\n 'Determines the set of locations used to match entries in `locations`',\n 'to regions on the map.',\n 'Values *ISO-3*, *USA-states*, *country names* correspond to features on',\n 'the base map and value *geojson-id* corresponds to features from a custom',\n 'GeoJSON linked to the `geojson` attribute.'\n ].join(' ')\n },\n\n geojson: {\n valType: 'any',\n editType: 'calc',\n description: [\n 'Sets optional GeoJSON data associated with this trace.',\n 'If not given, the features on the base map are used when `locations` is set.',\n\n 'It can be set as a valid GeoJSON object or as a URL string.',\n 'Note that we only accept GeoJSONs of type *FeatureCollection* or *Feature*',\n 'with geometries of type *Polygon* or *MultiPolygon*.'\n\n // TODO add topojson support with additional 'topojsonobject' attr?\n // https://github.com/topojson/topojson-specification/blob/master/README.md\n ].join(' ')\n },\n featureidkey: {\n valType: 'string',\n editType: 'calc',\n dflt: 'id',\n description: [\n 'Sets the key in GeoJSON features which is used as id to match the items',\n 'included in the `locations` array.',\n 'Only has an effect when `geojson` is set.',\n 'Support nested property, for example *properties.name*.'\n ].join(' ')\n },\n\n mode: extendFlat({}, scatterAttrs.mode, {dflt: 'markers'}),\n\n text: extendFlat({}, scatterAttrs.text, {\n description: [\n 'Sets text elements associated with each (lon,lat) pair',\n 'or item in `locations`.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s (lon,lat) or `locations` coordinates.',\n 'If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,',\n 'these elements will be seen in the hover labels.'\n ].join(' ')\n }),\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: ['lat', 'lon', 'location', 'text']\n }),\n hovertext: extendFlat({}, scatterAttrs.hovertext, {\n description: [\n 'Sets hover text elements associated with each (lon,lat) pair',\n 'or item in `locations`.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s (lon,lat) or `locations` coordinates.',\n 'To be seen, trace `hoverinfo` must contain a *text* flag.'\n ].join(' ')\n }),\n\n textfont: scatterAttrs.textfont,\n textposition: scatterAttrs.textposition,\n\n line: {\n color: scatterLineAttrs.color,\n width: scatterLineAttrs.width,\n dash: dash\n },\n connectgaps: scatterAttrs.connectgaps,\n\n marker: extendFlat({\n symbol: scatterMarkerAttrs.symbol,\n opacity: scatterMarkerAttrs.opacity,\n angle: scatterMarkerAttrs.angle,\n angleref: extendFlat({}, scatterMarkerAttrs.angleref, {\n values: ['previous', 'up', 'north'],\n description: [\n 'Sets the reference for marker angle.',\n 'With *previous*, angle 0 points along the line from the previous point to this one.',\n 'With *up*, angle 0 points toward the top of the screen.',\n 'With *north*, angle 0 points north based on the current map projection.',\n ].join(' ')\n }),\n standoff: scatterMarkerAttrs.standoff,\n size: scatterMarkerAttrs.size,\n sizeref: scatterMarkerAttrs.sizeref,\n sizemin: scatterMarkerAttrs.sizemin,\n sizemode: scatterMarkerAttrs.sizemode,\n colorbar: scatterMarkerAttrs.colorbar,\n line: extendFlat({\n width: scatterMarkerLineAttrs.width\n },\n colorAttributes('marker.line')\n ),\n gradient: scatterMarkerAttrs.gradient\n },\n colorAttributes('marker')\n ),\n\n fill: {\n valType: 'enumerated',\n values: ['none', 'toself'],\n dflt: 'none',\n description: [\n 'Sets the area to fill with a solid color.',\n 'Use with `fillcolor` if not *none*.',\n '*toself* connects the endpoints of the trace (or each segment',\n 'of the trace if it has gaps) into a closed shape.'\n ].join(' ')\n },\n fillcolor: makeFillcolorAttr(),\n\n selected: scatterAttrs.selected,\n unselected: scatterAttrs.unselected,\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['lon', 'lat', 'location', 'text', 'name']\n }),\n hovertemplate: hovertemplateAttrs(),\n}, 'calc', 'nested');\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nvar calcMarkerColorscale = require('../scatter/colorscale_calc');\nvar arraysToCalcdata = require('../scatter/arrays_to_calcdata');\nvar calcSelection = require('../scatter/calc_selection');\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\n\nvar _ = require('../../lib')._;\n\nfunction isNonBlankString(v) {\n return v && typeof v === 'string';\n}\n\nmodule.exports = function calc(gd, trace) {\n var hasLocationData = isArrayOrTypedArray(trace.locations);\n var len = hasLocationData ? trace.locations.length : trace._length;\n var calcTrace = new Array(len);\n\n var isValidLoc;\n if(trace.geojson) {\n isValidLoc = function(v) { return isNonBlankString(v) || isNumeric(v); };\n } else {\n isValidLoc = isNonBlankString;\n }\n\n for(var i = 0; i < len; i++) {\n var calcPt = calcTrace[i] = {};\n\n if(hasLocationData) {\n var loc = trace.locations[i];\n calcPt.loc = isValidLoc(loc) ? loc : null;\n } else {\n var lon = trace.lon[i];\n var lat = trace.lat[i];\n\n if(isNumeric(lon) && isNumeric(lat)) calcPt.lonlat = [+lon, +lat];\n else calcPt.lonlat = [BADNUM, BADNUM];\n }\n }\n\n arraysToCalcdata(calcTrace, trace);\n calcMarkerColorscale(gd, trace);\n calcSelection(calcTrace, trace);\n\n if(len) {\n calcTrace[0].t = {\n labels: {\n lat: _(gd, 'lat:') + ' ',\n lon: _(gd, 'lon:') + ' '\n }\n };\n }\n\n return calcTrace;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar subTypes = require('../scatter/subtypes');\nvar handleMarkerDefaults = require('../scatter/marker_defaults');\nvar handleLineDefaults = require('../scatter/line_defaults');\nvar handleTextDefaults = require('../scatter/text_defaults');\nvar handleFillColorDefaults = require('../scatter/fillcolor_defaults');\n\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var locations = coerce('locations');\n var len;\n\n if(locations && locations.length) {\n var geojson = coerce('geojson');\n var locationmodeDflt;\n if((typeof geojson === 'string' && geojson !== '') || Lib.isPlainObject(geojson)) {\n locationmodeDflt = 'geojson-id';\n }\n\n var locationMode = coerce('locationmode', locationmodeDflt);\n\n if(locationMode === 'geojson-id') {\n coerce('featureidkey');\n }\n\n len = locations.length;\n } else {\n var lon = coerce('lon') || [];\n var lat = coerce('lat') || [];\n len = Math.min(lon.length, lat.length);\n }\n\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n traceOut._length = len;\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n coerce('mode');\n\n if(subTypes.hasMarkers(traceOut)) {\n handleMarkerDefaults(traceIn, traceOut, defaultColor, layout, coerce, {gradient: true});\n }\n\n if(subTypes.hasLines(traceOut)) {\n handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce);\n coerce('connectgaps');\n }\n\n if(subTypes.hasText(traceOut)) {\n coerce('texttemplate');\n handleTextDefaults(traceIn, traceOut, layout, coerce);\n }\n\n coerce('fill');\n if(traceOut.fill !== 'none') {\n handleFillColorDefaults(traceIn, traceOut, defaultColor, coerce);\n }\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n","'use strict';\n\n\nmodule.exports = function eventData(out, pt, trace, cd, pointNumber) {\n out.lon = pt.lon;\n out.lat = pt.lat;\n out.location = pt.loc ? pt.loc : null;\n\n // include feature properties from input geojson\n var cdi = cd[pointNumber];\n if(cdi.fIn && cdi.fIn.properties) {\n out.properties = cdi.fIn.properties;\n }\n\n return out;\n};\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\n\nmodule.exports = function formatLabels(cdi, trace, fullLayout) {\n var labels = {};\n\n var geo = fullLayout[trace.geo]._subplot;\n var ax = geo.mockAxis;\n var lonlat = cdi.lonlat;\n labels.lonLabel = Axes.tickText(ax, ax.c2l(lonlat[0]), true).text;\n labels.latLabel = Axes.tickText(ax, ax.c2l(lonlat[1]), true).text;\n\n return labels;\n};\n","'use strict';\n\nvar Fx = require('../../components/fx');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nvar getTraceColor = require('../scatter/get_trace_color');\nvar fillText = require('../../lib').fillText;\nvar attributes = require('./attributes');\n\nmodule.exports = function hoverPoints(pointData, xval, yval) {\n var cd = pointData.cd;\n var trace = cd[0].trace;\n var xa = pointData.xa;\n var ya = pointData.ya;\n var geo = pointData.subplot;\n\n var isLonLatOverEdges = geo.projection.isLonLatOverEdges;\n var project = geo.project;\n\n function distFn(d) {\n var lonlat = d.lonlat;\n\n if(lonlat[0] === BADNUM) return Infinity;\n if(isLonLatOverEdges(lonlat)) return Infinity;\n\n var pt = project(lonlat);\n var px = project([xval, yval]);\n var dx = Math.abs(pt[0] - px[0]);\n var dy = Math.abs(pt[1] - px[1]);\n var rad = Math.max(3, d.mrc || 0);\n\n // N.B. d.mrc is the calculated marker radius\n // which is only set for trace with 'markers' mode.\n\n return Math.max(Math.sqrt(dx * dx + dy * dy) - rad, 1 - 3 / rad);\n }\n\n Fx.getClosest(cd, distFn, pointData);\n\n // skip the rest (for this trace) if we didn't find a close point\n if(pointData.index === false) return;\n\n var di = cd[pointData.index];\n var lonlat = di.lonlat;\n var pos = [xa.c2p(lonlat), ya.c2p(lonlat)];\n var rad = di.mrc || 1;\n\n pointData.x0 = pos[0] - rad;\n pointData.x1 = pos[0] + rad;\n pointData.y0 = pos[1] - rad;\n pointData.y1 = pos[1] + rad;\n\n pointData.loc = di.loc;\n pointData.lon = lonlat[0];\n pointData.lat = lonlat[1];\n\n var fullLayout = {};\n fullLayout[trace.geo] = {_subplot: geo};\n var labels = trace._module.formatLabels(di, trace, fullLayout);\n pointData.lonLabel = labels.lonLabel;\n pointData.latLabel = labels.latLabel;\n\n pointData.color = getTraceColor(trace, di);\n pointData.extraText = getExtraText(trace, di, pointData, cd[0].t.labels);\n pointData.hovertemplate = trace.hovertemplate;\n\n return [pointData];\n};\n\nfunction getExtraText(trace, pt, pointData, labels) {\n if(trace.hovertemplate) return;\n\n var hoverinfo = pt.hi || trace.hoverinfo;\n\n var parts = hoverinfo === 'all' ?\n attributes.hoverinfo.flags :\n hoverinfo.split('+');\n\n var hasLocation = parts.indexOf('location') !== -1 && Array.isArray(trace.locations);\n var hasLon = (parts.indexOf('lon') !== -1);\n var hasLat = (parts.indexOf('lat') !== -1);\n var hasText = (parts.indexOf('text') !== -1);\n var text = [];\n\n function format(val) { return val + '\\u00B0'; }\n\n if(hasLocation) {\n text.push(pt.loc);\n } else if(hasLon && hasLat) {\n text.push('(' + format(pointData.latLabel) + ', ' + format(pointData.lonLabel) + ')');\n } else if(hasLon) {\n text.push(labels.lon + format(pointData.lonLabel));\n } else if(hasLat) {\n text.push(labels.lat + format(pointData.latLabel));\n }\n\n if(hasText) {\n fillText(pt, trace, text);\n }\n\n return text.join('
');\n}\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../scatter/marker_colorbar'),\n formatLabels: require('./format_labels'),\n calc: require('./calc'),\n calcGeoJSON: require('./plot').calcGeoJSON,\n plot: require('./plot').plot,\n style: require('./style'),\n styleOnSelect: require('../scatter/style').styleOnSelect,\n hoverPoints: require('./hover'),\n eventData: require('./event_data'),\n selectPoints: require('./select'),\n\n moduleType: 'trace',\n name: 'scattergeo',\n basePlotModule: require('../../plots/geo'),\n categories: ['geo', 'symbols', 'showLegend', 'scatter-like'],\n meta: {\n hrName: 'scatter_geo',\n description: [\n 'The data visualized as scatter point or lines on a geographic map',\n 'is provided either by longitude/latitude pairs in `lon` and `lat`',\n 'respectively or by geographic location IDs or names in `locations`.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Lib = require('../../lib');\nvar getTopojsonFeatures = require('../../lib/topojson_utils').getTopojsonFeatures;\nvar geoJsonUtils = require('../../lib/geojson_utils');\nvar geoUtils = require('../../lib/geo_location_utils');\nvar findExtremes = require('../../plots/cartesian/autorange').findExtremes;\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nvar calcMarkerSize = require('../scatter/calc').calcMarkerSize;\nvar subTypes = require('../scatter/subtypes');\nvar style = require('./style');\n\nfunction plot(gd, geo, calcData) {\n var scatterLayer = geo.layers.frontplot.select('.scatterlayer');\n var gTraces = Lib.makeTraceGroups(scatterLayer, calcData, 'trace scattergeo');\n\n function removeBADNUM(d, node) {\n if(d.lonlat[0] === BADNUM) {\n d3.select(node).remove();\n }\n }\n\n // TODO find a way to order the inner nodes on update\n gTraces.selectAll('*').remove();\n\n gTraces.each(function(calcTrace) {\n var s = d3.select(this);\n var trace = calcTrace[0].trace;\n\n if(subTypes.hasLines(trace) || trace.fill !== 'none') {\n var lineCoords = geoJsonUtils.calcTraceToLineCoords(calcTrace);\n\n var lineData = (trace.fill !== 'none') ?\n geoJsonUtils.makePolygon(lineCoords) :\n geoJsonUtils.makeLine(lineCoords);\n\n s.selectAll('path.js-line')\n .data([{geojson: lineData, trace: trace}])\n .enter().append('path')\n .classed('js-line', true)\n .style('stroke-miterlimit', 2);\n }\n\n if(subTypes.hasMarkers(trace)) {\n s.selectAll('path.point')\n .data(Lib.identity)\n .enter().append('path')\n .classed('point', true)\n .each(function(calcPt) { removeBADNUM(calcPt, this); });\n }\n\n if(subTypes.hasText(trace)) {\n s.selectAll('g')\n .data(Lib.identity)\n .enter().append('g')\n .append('text')\n .each(function(calcPt) { removeBADNUM(calcPt, this); });\n }\n\n // call style here within topojson request callback\n style(gd, calcTrace);\n });\n}\n\nfunction calcGeoJSON(calcTrace, fullLayout) {\n var trace = calcTrace[0].trace;\n var geoLayout = fullLayout[trace.geo];\n var geo = geoLayout._subplot;\n var len = trace._length;\n var i, calcPt;\n\n if(Lib.isArrayOrTypedArray(trace.locations)) {\n var locationmode = trace.locationmode;\n var features = locationmode === 'geojson-id' ?\n geoUtils.extractTraceFeature(calcTrace) :\n getTopojsonFeatures(trace, geo.topojson);\n\n for(i = 0; i < len; i++) {\n calcPt = calcTrace[i];\n\n var feature = locationmode === 'geojson-id' ?\n calcPt.fOut :\n geoUtils.locationToFeature(locationmode, calcPt.loc, features);\n\n calcPt.lonlat = feature ? feature.properties.ct : [BADNUM, BADNUM];\n }\n }\n\n var opts = {padded: true};\n var lonArray;\n var latArray;\n\n if(geoLayout.fitbounds === 'geojson' && trace.locationmode === 'geojson-id') {\n var bboxGeojson = geoUtils.computeBbox(geoUtils.getTraceGeojson(trace));\n lonArray = [bboxGeojson[0], bboxGeojson[2]];\n latArray = [bboxGeojson[1], bboxGeojson[3]];\n } else {\n lonArray = new Array(len);\n latArray = new Array(len);\n for(i = 0; i < len; i++) {\n calcPt = calcTrace[i];\n lonArray[i] = calcPt.lonlat[0];\n latArray[i] = calcPt.lonlat[1];\n }\n\n opts.ppad = calcMarkerSize(trace, len);\n }\n\n trace._extremes.lon = findExtremes(geoLayout.lonaxis._ax, lonArray, opts);\n trace._extremes.lat = findExtremes(geoLayout.lataxis._ax, latArray, opts);\n}\n\nmodule.exports = {\n calcGeoJSON: calcGeoJSON,\n plot: plot\n};\n","'use strict';\n\nvar subtypes = require('../scatter/subtypes');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nmodule.exports = function selectPoints(searchInfo, selectionTester) {\n var cd = searchInfo.cd;\n var xa = searchInfo.xaxis;\n var ya = searchInfo.yaxis;\n var selection = [];\n var trace = cd[0].trace;\n\n var di, lonlat, x, y, i;\n\n var hasOnlyLines = (!subtypes.hasMarkers(trace) && !subtypes.hasText(trace));\n if(hasOnlyLines) return [];\n\n if(selectionTester === false) {\n for(i = 0; i < cd.length; i++) {\n cd[i].selected = 0;\n }\n } else {\n for(i = 0; i < cd.length; i++) {\n di = cd[i];\n lonlat = di.lonlat;\n\n // some projection types can't handle BADNUMs\n if(lonlat[0] === BADNUM) continue;\n\n x = xa.c2p(lonlat);\n y = ya.c2p(lonlat);\n\n if(selectionTester.contains([x, y], null, i, searchInfo)) {\n selection.push({\n pointNumber: i,\n lon: lonlat[0],\n lat: lonlat[1]\n });\n di.selected = 1;\n } else {\n di.selected = 0;\n }\n }\n }\n\n return selection;\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Drawing = require('../../components/drawing');\nvar Color = require('../../components/color');\n\nvar scatterStyle = require('../scatter/style');\nvar stylePoints = scatterStyle.stylePoints;\nvar styleText = scatterStyle.styleText;\n\nmodule.exports = function style(gd, calcTrace) {\n if(calcTrace) styleTrace(gd, calcTrace);\n};\n\nfunction styleTrace(gd, calcTrace) {\n var trace = calcTrace[0].trace;\n var s = calcTrace[0].node3;\n\n s.style('opacity', calcTrace[0].trace.opacity);\n\n stylePoints(s, trace, gd);\n styleText(s, trace, gd);\n\n // this part is incompatible with Drawing.lineGroupStyle\n s.selectAll('path.js-line')\n .style('fill', 'none')\n .each(function(d) {\n var path = d3.select(this);\n var trace = d.trace;\n var line = trace.line || {};\n\n path.call(Color.stroke, line.color)\n .call(Drawing.dashLine, line.dash || '', line.width || 0);\n\n if(trace.fill !== 'none') {\n path.call(Color.fill, trace.fillcolor);\n }\n });\n}\n","'use strict';\n\nvar baseAttrs = require('../../plots/attributes');\nvar fontAttrs = require('../../plots/font_attributes');\nvar makeFillcolorAttr = require('../scatter/fillcolor_attribute');\nvar scatterAttrs = require('../scatter/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\n\nvar sortObjectKeys = require('../../lib/sort_object_keys');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar DASHES = require('./constants').DASHES;\n\nvar scatterLineAttrs = scatterAttrs.line;\nvar scatterMarkerAttrs = scatterAttrs.marker;\nvar scatterMarkerLineAttrs = scatterMarkerAttrs.line;\n\nvar attrs = module.exports = overrideAll({\n x: scatterAttrs.x,\n x0: scatterAttrs.x0,\n dx: scatterAttrs.dx,\n y: scatterAttrs.y,\n y0: scatterAttrs.y0,\n dy: scatterAttrs.dy,\n\n xperiod: scatterAttrs.xperiod,\n yperiod: scatterAttrs.yperiod,\n xperiod0: scatterAttrs.xperiod0,\n yperiod0: scatterAttrs.yperiod0,\n xperiodalignment: scatterAttrs.xperiodalignment,\n yperiodalignment: scatterAttrs.yperiodalignment,\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n\n text: scatterAttrs.text,\n hovertext: scatterAttrs.hovertext,\n\n textposition: scatterAttrs.textposition,\n textfont: fontAttrs({\n noFontShadow: true,\n noFontLineposition: true,\n noFontTextcase: true,\n editType: 'calc',\n colorEditType: 'style',\n arrayOk: true,\n noNumericWeightValues: true,\n variantValues: ['normal', 'small-caps'],\n description: 'Sets the text font.'\n }),\n\n mode: {\n valType: 'flaglist',\n flags: ['lines', 'markers', 'text'],\n extras: ['none'],\n description: [\n 'Determines the drawing mode for this scatter trace.'\n ].join(' ')\n },\n line: {\n color: scatterLineAttrs.color,\n width: scatterLineAttrs.width,\n shape: {\n valType: 'enumerated',\n values: ['linear', 'hv', 'vh', 'hvh', 'vhv'],\n dflt: 'linear',\n editType: 'plot',\n description: [\n 'Determines the line shape.',\n 'The values correspond to step-wise line shapes.'\n ].join(' ')\n },\n dash: {\n valType: 'enumerated',\n values: sortObjectKeys(DASHES),\n dflt: 'solid',\n description: 'Sets the style of the lines.'\n }\n },\n marker: extendFlat({}, colorScaleAttrs('marker'), {\n symbol: scatterMarkerAttrs.symbol,\n angle: scatterMarkerAttrs.angle,\n size: scatterMarkerAttrs.size,\n sizeref: scatterMarkerAttrs.sizeref,\n sizemin: scatterMarkerAttrs.sizemin,\n sizemode: scatterMarkerAttrs.sizemode,\n opacity: scatterMarkerAttrs.opacity,\n colorbar: scatterMarkerAttrs.colorbar,\n line: extendFlat({}, colorScaleAttrs('marker.line'), {\n width: scatterMarkerLineAttrs.width\n })\n }),\n connectgaps: scatterAttrs.connectgaps,\n fill: extendFlat({}, scatterAttrs.fill, {dflt: 'none'}),\n fillcolor: makeFillcolorAttr(),\n\n // no hoveron\n\n selected: {\n marker: scatterAttrs.selected.marker,\n textfont: scatterAttrs.selected.textfont\n },\n unselected: {\n marker: scatterAttrs.unselected.marker,\n textfont: scatterAttrs.unselected.textfont\n },\n\n opacity: baseAttrs.opacity\n\n}, 'calc', 'nested');\n\nattrs.x.editType = attrs.y.editType = attrs.x0.editType = attrs.y0.editType = 'calc+clearAxisTypes';\nattrs.hovertemplate = scatterAttrs.hovertemplate;\nattrs.texttemplate = scatterAttrs.texttemplate;\n","'use strict';\n\nvar hover = require('./hover');\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'scattergl',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['gl', 'regl', 'cartesian', 'symbols', 'errorBarsOK', 'showLegend', 'scatter-like'],\n\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n crossTraceDefaults: require('../scatter/cross_trace_defaults'),\n colorbar: require('../scatter/marker_colorbar'),\n formatLabels: require('./format_labels'),\n calc: require('./calc'),\n hoverPoints: hover.hoverPoints,\n selectPoints: require('./select'),\n\n meta: {\n hrName: 'scatter_gl',\n description: [\n 'The data visualized as scatter point or lines is set in `x` and `y`',\n 'using the WebGL plotting engine.',\n 'Bubble charts are achieved by setting `marker.size` and/or `marker.color`',\n 'to a numerical arrays.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar cluster = require('@plotly/point-cluster');\n\nvar Lib = require('../../lib');\nvar AxisIDs = require('../../plots/cartesian/axis_ids');\nvar findExtremes = require('../../plots/cartesian/autorange').findExtremes;\nvar alignPeriod = require('../../plots/cartesian/align_period');\n\nvar scatterCalc = require('../scatter/calc');\nvar calcMarkerSize = scatterCalc.calcMarkerSize;\nvar calcAxisExpansion = scatterCalc.calcAxisExpansion;\nvar setFirstScatter = scatterCalc.setFirstScatter;\nvar calcColorscale = require('../scatter/colorscale_calc');\nvar convert = require('./convert');\nvar sceneUpdate = require('./scene_update');\n\nvar BADNUM = require('../../constants/numerical').BADNUM;\nvar TOO_MANY_POINTS = require('./constants').TOO_MANY_POINTS;\n\nmodule.exports = function calc(gd, trace) {\n var fullLayout = gd._fullLayout;\n var xa = trace._xA = AxisIDs.getFromId(gd, trace.xaxis, 'x');\n var ya = trace._yA = AxisIDs.getFromId(gd, trace.yaxis, 'y');\n\n var subplot = fullLayout._plots[trace.xaxis + trace.yaxis];\n var len = trace._length;\n var hasTooManyPoints = len >= TOO_MANY_POINTS;\n var len2 = len * 2;\n var stash = {};\n var i;\n\n var origX = xa.makeCalcdata(trace, 'x');\n var origY = ya.makeCalcdata(trace, 'y');\n var xObj = alignPeriod(trace, xa, 'x', origX);\n var yObj = alignPeriod(trace, ya, 'y', origY);\n var x = xObj.vals;\n var y = yObj.vals;\n trace._x = x;\n trace._y = y;\n\n if(trace.xperiodalignment) {\n trace._origX = origX;\n trace._xStarts = xObj.starts;\n trace._xEnds = xObj.ends;\n }\n if(trace.yperiodalignment) {\n trace._origY = origY;\n trace._yStarts = yObj.starts;\n trace._yEnds = yObj.ends;\n }\n\n // we need hi-precision for scatter2d,\n // regl-scatter2d uses NaNs for bad/missing values\n var positions = new Array(len2);\n var _ids = new Array(len);\n for(i = 0; i < len; i++) {\n positions[i * 2] = x[i] === BADNUM ? NaN : x[i];\n positions[i * 2 + 1] = y[i] === BADNUM ? NaN : y[i];\n // Pre-compute ids.\n _ids[i] = i;\n }\n\n if(xa.type === 'log') {\n for(i = 0; i < len2; i += 2) {\n positions[i] = xa.c2l(positions[i]);\n }\n }\n if(ya.type === 'log') {\n for(i = 1; i < len2; i += 2) {\n positions[i] = ya.c2l(positions[i]);\n }\n }\n\n // we don't build a tree for log axes since it takes long to convert log2px\n // and it is also\n if(hasTooManyPoints && (xa.type !== 'log' && ya.type !== 'log')) {\n // FIXME: delegate this to webworker\n stash.tree = cluster(positions);\n } else {\n stash.ids = _ids;\n }\n\n // create scene options and scene\n calcColorscale(gd, trace);\n var opts = sceneOptions(gd, subplot, trace, positions, x, y);\n var scene = sceneUpdate(gd, subplot);\n\n // Reuse SVG scatter axis expansion routine.\n // For graphs with very large number of points and array marker.size,\n // use average marker size instead to speed things up.\n setFirstScatter(fullLayout, trace);\n var ppad;\n if(!hasTooManyPoints) {\n ppad = calcMarkerSize(trace, len);\n } else if(opts.marker) {\n ppad = opts.marker.sizeAvg || Math.max(opts.marker.size, 3);\n }\n calcAxisExpansion(gd, trace, xa, ya, x, y, ppad);\n if(opts.errorX) expandForErrorBars(trace, xa, opts.errorX);\n if(opts.errorY) expandForErrorBars(trace, ya, opts.errorY);\n\n // set flags to create scene renderers\n if(opts.fill && !scene.fill2d) scene.fill2d = true;\n if(opts.marker && !scene.scatter2d) scene.scatter2d = true;\n if(opts.line && !scene.line2d) scene.line2d = true;\n if((opts.errorX || opts.errorY) && !scene.error2d) scene.error2d = true;\n if(opts.text && !scene.glText) scene.glText = true;\n if(opts.marker) opts.marker.snap = len;\n\n scene.lineOptions.push(opts.line);\n scene.errorXOptions.push(opts.errorX);\n scene.errorYOptions.push(opts.errorY);\n scene.fillOptions.push(opts.fill);\n scene.markerOptions.push(opts.marker);\n scene.markerSelectedOptions.push(opts.markerSel);\n scene.markerUnselectedOptions.push(opts.markerUnsel);\n scene.textOptions.push(opts.text);\n scene.textSelectedOptions.push(opts.textSel);\n scene.textUnselectedOptions.push(opts.textUnsel);\n scene.selectBatch.push([]);\n scene.unselectBatch.push([]);\n\n stash._scene = scene;\n stash.index = scene.count;\n stash.x = x;\n stash.y = y;\n stash.positions = positions;\n scene.count++;\n\n return [{x: false, y: false, t: stash, trace: trace}];\n};\n\nfunction expandForErrorBars(trace, ax, opts) {\n var extremes = trace._extremes[ax._id];\n var errExt = findExtremes(ax, opts._bnds, {padded: true});\n extremes.min = extremes.min.concat(errExt.min);\n extremes.max = extremes.max.concat(errExt.max);\n}\n\nfunction sceneOptions(gd, subplot, trace, positions, x, y) {\n var opts = convert.style(gd, trace);\n\n if(opts.marker) {\n opts.marker.positions = positions;\n }\n\n if(opts.line && positions.length > 1) {\n Lib.extendFlat(\n opts.line,\n convert.linePositions(gd, trace, positions)\n );\n }\n\n if(opts.errorX || opts.errorY) {\n var errors = convert.errorBarPositions(gd, trace, positions, x, y);\n\n if(opts.errorX) {\n Lib.extendFlat(opts.errorX, errors.x);\n }\n if(opts.errorY) {\n Lib.extendFlat(opts.errorY, errors.y);\n }\n }\n\n if(opts.text) {\n Lib.extendFlat(\n opts.text,\n {positions: positions},\n convert.textPosition(gd, trace, opts.text, opts.marker)\n );\n Lib.extendFlat(\n opts.textSel,\n {positions: positions},\n convert.textPosition(gd, trace, opts.text, opts.markerSel)\n );\n Lib.extendFlat(\n opts.textUnsel,\n {positions: positions},\n convert.textPosition(gd, trace, opts.text, opts.markerUnsel)\n );\n }\n\n return opts;\n}\n","'use strict';\n\nvar SYMBOL_SIZE = 20;\n\nmodule.exports = {\n TOO_MANY_POINTS: 1e5,\n\n SYMBOL_SDF_SIZE: 200,\n SYMBOL_SIZE: SYMBOL_SIZE,\n SYMBOL_STROKE: SYMBOL_SIZE / 20,\n\n DOT_RE: /-dot/,\n OPEN_RE: /-open/,\n\n DASHES: {\n solid: [1],\n dot: [1, 1],\n dash: [4, 1],\n longdash: [8, 1],\n dashdot: [4, 1, 1, 1],\n longdashdot: [8, 1, 1, 1]\n }\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar svgSdf = require('svg-path-sdf');\nvar rgba = require('color-normalize');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar isArrayOrTypedArray = Lib.isArrayOrTypedArray;\nvar Drawing = require('../../components/drawing');\nvar AxisIDs = require('../../plots/cartesian/axis_ids');\n\nvar formatColor = require('../../lib/gl_format_color').formatColor;\nvar subTypes = require('../scatter/subtypes');\nvar makeBubbleSizeFn = require('../scatter/make_bubble_size_func');\n\nvar helpers = require('./helpers');\nvar constants = require('./constants');\nvar DESELECTDIM = require('../../constants/interactions').DESELECTDIM;\n\nvar TEXTOFFSETSIGN = {\n start: 1, left: 1, end: -1, right: -1, middle: 0, center: 0, bottom: 1, top: -1\n};\n\nvar appendArrayPointValue = require('../../components/fx/helpers').appendArrayPointValue;\n\nfunction convertStyle(gd, trace) {\n var i;\n\n var opts = {\n marker: undefined,\n markerSel: undefined,\n markerUnsel: undefined,\n line: undefined,\n fill: undefined,\n errorX: undefined,\n errorY: undefined,\n text: undefined,\n textSel: undefined,\n textUnsel: undefined\n };\n\n var plotGlPixelRatio = gd._context.plotGlPixelRatio;\n\n if(trace.visible !== true) return opts;\n\n if(subTypes.hasText(trace)) {\n opts.text = convertTextStyle(gd, trace);\n opts.textSel = convertTextSelection(gd, trace, trace.selected);\n opts.textUnsel = convertTextSelection(gd, trace, trace.unselected);\n }\n\n if(subTypes.hasMarkers(trace)) {\n opts.marker = convertMarkerStyle(gd, trace);\n opts.markerSel = convertMarkerSelection(gd, trace, trace.selected);\n opts.markerUnsel = convertMarkerSelection(gd, trace, trace.unselected);\n\n if(!trace.unselected && isArrayOrTypedArray(trace.marker.opacity)) {\n var mo = trace.marker.opacity;\n opts.markerUnsel.opacity = new Array(mo.length);\n for(i = 0; i < mo.length; i++) {\n opts.markerUnsel.opacity[i] = DESELECTDIM * mo[i];\n }\n }\n }\n\n if(subTypes.hasLines(trace)) {\n opts.line = {\n overlay: true,\n thickness: trace.line.width * plotGlPixelRatio,\n color: trace.line.color,\n opacity: trace.opacity\n };\n\n var dashes = (constants.DASHES[trace.line.dash] || [1]).slice();\n for(i = 0; i < dashes.length; ++i) {\n dashes[i] *= trace.line.width * plotGlPixelRatio;\n }\n opts.line.dashes = dashes;\n }\n\n if(trace.error_x && trace.error_x.visible) {\n opts.errorX = convertErrorBarStyle(trace, trace.error_x, plotGlPixelRatio);\n }\n\n if(trace.error_y && trace.error_y.visible) {\n opts.errorY = convertErrorBarStyle(trace, trace.error_y, plotGlPixelRatio);\n }\n\n if(!!trace.fill && trace.fill !== 'none') {\n opts.fill = {\n closed: true,\n fill: trace.fillcolor,\n thickness: 0\n };\n }\n\n return opts;\n}\n\nfunction convertTextStyle(gd, trace) {\n var fullLayout = gd._fullLayout;\n var count = trace._length;\n var textfontIn = trace.textfont;\n var textpositionIn = trace.textposition;\n var textPos = isArrayOrTypedArray(textpositionIn) ? textpositionIn : [textpositionIn];\n var tfc = textfontIn.color;\n var tfs = textfontIn.size;\n var tff = textfontIn.family;\n var tfw = textfontIn.weight;\n var tfy = textfontIn.style;\n var tfv = textfontIn.variant;\n var optsOut = {};\n var i;\n var plotGlPixelRatio = gd._context.plotGlPixelRatio;\n\n var texttemplate = trace.texttemplate;\n if(texttemplate) {\n optsOut.text = [];\n\n var d3locale = fullLayout._d3locale;\n var isArray = Array.isArray(texttemplate);\n var N = isArray ? Math.min(texttemplate.length, count) : count;\n var txt = isArray ?\n function(i) { return texttemplate[i]; } :\n function() { return texttemplate; };\n\n for(i = 0; i < N; i++) {\n var d = {i: i};\n var labels = trace._module.formatLabels(d, trace, fullLayout);\n var pointValues = {};\n appendArrayPointValue(pointValues, trace, i);\n var meta = trace._meta || {};\n optsOut.text.push(Lib.texttemplateString(txt(i), labels, d3locale, pointValues, d, meta));\n }\n } else {\n if(isArrayOrTypedArray(trace.text) && trace.text.length < count) {\n // if text array is shorter, we'll need to append to it, so let's slice to prevent mutating\n optsOut.text = trace.text.slice();\n } else {\n optsOut.text = trace.text;\n }\n }\n // pad text array with empty strings\n if(isArrayOrTypedArray(optsOut.text)) {\n for(i = optsOut.text.length; i < count; i++) {\n optsOut.text[i] = '';\n }\n }\n\n optsOut.opacity = trace.opacity;\n optsOut.font = {};\n optsOut.align = [];\n optsOut.baseline = [];\n\n for(i = 0; i < textPos.length; i++) {\n var tp = textPos[i].split(/\\s+/);\n\n switch(tp[1]) {\n case 'left':\n optsOut.align.push('right');\n break;\n case 'right':\n optsOut.align.push('left');\n break;\n default:\n optsOut.align.push(tp[1]);\n }\n switch(tp[0]) {\n case 'top':\n optsOut.baseline.push('bottom');\n break;\n case 'bottom':\n optsOut.baseline.push('top');\n break;\n default:\n optsOut.baseline.push(tp[0]);\n }\n }\n\n if(isArrayOrTypedArray(tfc)) {\n optsOut.color = new Array(count);\n for(i = 0; i < count; i++) {\n optsOut.color[i] = tfc[i];\n }\n } else {\n optsOut.color = tfc;\n }\n\n if(\n isArrayOrTypedArray(tfs) ||\n Array.isArray(tff) ||\n isArrayOrTypedArray(tfw) ||\n Array.isArray(tfy) ||\n Array.isArray(tfv)\n ) {\n // if any textfont param is array - make render a batch\n optsOut.font = new Array(count);\n for(i = 0; i < count; i++) {\n var fonti = optsOut.font[i] = {};\n\n fonti.size = (\n Lib.isTypedArray(tfs) ? tfs[i] :\n isArrayOrTypedArray(tfs) ? (\n isNumeric(tfs[i]) ? tfs[i] : 0\n ) : tfs\n ) * plotGlPixelRatio;\n\n fonti.family = Array.isArray(tff) ? tff[i] : tff;\n fonti.weight = weightFallBack(isArrayOrTypedArray(tfw) ? tfw[i] : tfw);\n fonti.style = Array.isArray(tfy) ? tfy[i] : tfy;\n fonti.variant = Array.isArray(tfv) ? tfv[i] : tfv;\n }\n } else {\n // if both are single values, make render fast single-value\n optsOut.font = {\n size: tfs * plotGlPixelRatio,\n family: tff,\n weight: weightFallBack(tfw),\n style: tfy,\n variant: tfv\n };\n }\n\n return optsOut;\n}\n\n// scattergl rendering pipeline has limited support of numeric weight values\n// Here we map the numbers to be either bold or normal.\nfunction weightFallBack(w) {\n if(w <= 1000) {\n return w > 500 ? 'bold' : 'normal';\n }\n return w;\n}\n\nfunction convertMarkerStyle(gd, trace) {\n var count = trace._length;\n var optsIn = trace.marker;\n var optsOut = {};\n var i;\n\n var multiSymbol = isArrayOrTypedArray(optsIn.symbol);\n var multiAngle = isArrayOrTypedArray(optsIn.angle);\n var multiColor = isArrayOrTypedArray(optsIn.color);\n var multiLineColor = isArrayOrTypedArray(optsIn.line.color);\n var multiOpacity = isArrayOrTypedArray(optsIn.opacity);\n var multiSize = isArrayOrTypedArray(optsIn.size);\n var multiLineWidth = isArrayOrTypedArray(optsIn.line.width);\n\n var isOpen;\n if(!multiSymbol) isOpen = helpers.isOpenSymbol(optsIn.symbol);\n\n // prepare colors\n if(multiSymbol || multiColor || multiLineColor || multiOpacity || multiAngle) {\n optsOut.symbols = new Array(count);\n optsOut.angles = new Array(count);\n optsOut.colors = new Array(count);\n optsOut.borderColors = new Array(count);\n\n var symbols = optsIn.symbol;\n var angles = optsIn.angle;\n var colors = formatColor(optsIn, optsIn.opacity, count);\n var borderColors = formatColor(optsIn.line, optsIn.opacity, count);\n\n if(!isArrayOrTypedArray(borderColors[0])) {\n var borderColor = borderColors;\n borderColors = Array(count);\n for(i = 0; i < count; i++) {\n borderColors[i] = borderColor;\n }\n }\n if(!isArrayOrTypedArray(colors[0])) {\n var color = colors;\n colors = Array(count);\n for(i = 0; i < count; i++) {\n colors[i] = color;\n }\n }\n if(!isArrayOrTypedArray(symbols)) {\n var symbol = symbols;\n symbols = Array(count);\n for(i = 0; i < count; i++) {\n symbols[i] = symbol;\n }\n }\n if(!isArrayOrTypedArray(angles)) {\n var angle = angles;\n angles = Array(count);\n for(i = 0; i < count; i++) {\n angles[i] = angle;\n }\n }\n\n optsOut.symbols = symbols;\n optsOut.angles = angles;\n optsOut.colors = colors;\n optsOut.borderColors = borderColors;\n\n for(i = 0; i < count; i++) {\n if(multiSymbol) {\n isOpen = helpers.isOpenSymbol(optsIn.symbol[i]);\n }\n if(isOpen) {\n borderColors[i] = colors[i].slice();\n colors[i] = colors[i].slice();\n colors[i][3] = 0;\n }\n }\n\n optsOut.opacity = trace.opacity;\n\n optsOut.markers = new Array(count);\n for(i = 0; i < count; i++) {\n optsOut.markers[i] = getSymbolSdf({\n mx: optsOut.symbols[i],\n ma: optsOut.angles[i]\n }, trace);\n }\n } else {\n if(isOpen) {\n optsOut.color = rgba(optsIn.color, 'uint8');\n optsOut.color[3] = 0;\n optsOut.borderColor = rgba(optsIn.color, 'uint8');\n } else {\n optsOut.color = rgba(optsIn.color, 'uint8');\n optsOut.borderColor = rgba(optsIn.line.color, 'uint8');\n }\n\n optsOut.opacity = trace.opacity * optsIn.opacity;\n\n optsOut.marker = getSymbolSdf({\n mx: optsIn.symbol,\n ma: optsIn.angle\n }, trace);\n }\n\n // prepare sizes\n var sizeFactor = 1;\n var markerSizeFunc = makeBubbleSizeFn(trace, sizeFactor);\n var s;\n\n if(multiSize || multiLineWidth) {\n var sizes = optsOut.sizes = new Array(count);\n var borderSizes = optsOut.borderSizes = new Array(count);\n var sizeTotal = 0;\n var sizeAvg;\n\n if(multiSize) {\n for(i = 0; i < count; i++) {\n sizes[i] = markerSizeFunc(optsIn.size[i]);\n sizeTotal += sizes[i];\n }\n sizeAvg = sizeTotal / count;\n } else {\n s = markerSizeFunc(optsIn.size);\n for(i = 0; i < count; i++) {\n sizes[i] = s;\n }\n }\n\n // See https://github.com/plotly/plotly.js/pull/1781#discussion_r121820798\n if(multiLineWidth) {\n for(i = 0; i < count; i++) {\n borderSizes[i] = optsIn.line.width[i];\n }\n } else {\n s = optsIn.line.width;\n for(i = 0; i < count; i++) {\n borderSizes[i] = s;\n }\n }\n\n optsOut.sizeAvg = sizeAvg;\n } else {\n optsOut.size = markerSizeFunc(optsIn && optsIn.size || 10);\n optsOut.borderSizes = markerSizeFunc(optsIn.line.width);\n }\n\n return optsOut;\n}\n\nfunction convertMarkerSelection(gd, trace, target) {\n var optsIn = trace.marker;\n var optsOut = {};\n\n if(!target) return optsOut;\n\n if(target.marker && target.marker.symbol) {\n optsOut = convertMarkerStyle(gd, Lib.extendFlat({}, optsIn, target.marker));\n } else if(target.marker) {\n if(target.marker.size) optsOut.size = target.marker.size;\n if(target.marker.color) optsOut.colors = target.marker.color;\n if(target.marker.opacity !== undefined) optsOut.opacity = target.marker.opacity;\n }\n\n return optsOut;\n}\n\nfunction convertTextSelection(gd, trace, target) {\n var optsOut = {};\n\n if(!target) return optsOut;\n\n if(target.textfont) {\n var optsIn = {\n opacity: 1,\n text: trace.text,\n texttemplate: trace.texttemplate,\n textposition: trace.textposition,\n textfont: Lib.extendFlat({}, trace.textfont)\n };\n if(target.textfont) {\n Lib.extendFlat(optsIn.textfont, target.textfont);\n }\n optsOut = convertTextStyle(gd, optsIn);\n }\n\n return optsOut;\n}\n\nfunction convertErrorBarStyle(trace, target, plotGlPixelRatio) {\n var optsOut = {\n capSize: target.width * 2 * plotGlPixelRatio,\n lineWidth: target.thickness * plotGlPixelRatio,\n color: target.color\n };\n\n if(target.copy_ystyle) {\n optsOut = trace.error_y;\n }\n\n return optsOut;\n}\n\nvar SYMBOL_SDF_SIZE = constants.SYMBOL_SDF_SIZE;\nvar SYMBOL_SIZE = constants.SYMBOL_SIZE;\nvar SYMBOL_STROKE = constants.SYMBOL_STROKE;\nvar SYMBOL_SDF = {};\nvar SYMBOL_SVG_CIRCLE = Drawing.symbolFuncs[0](SYMBOL_SIZE * 0.05);\n\nfunction getSymbolSdf(d, trace) {\n var symbol = d.mx;\n if(symbol === 'circle') return null;\n\n var symbolPath, symbolSdf;\n var symbolNumber = Drawing.symbolNumber(symbol);\n var symbolFunc = Drawing.symbolFuncs[symbolNumber % 100];\n var symbolNoDot = !!Drawing.symbolNoDot[symbolNumber % 100];\n var symbolNoFill = !!Drawing.symbolNoFill[symbolNumber % 100];\n\n var isDot = helpers.isDotSymbol(symbol);\n\n // until we may handle angles in shader?\n if(d.ma) symbol += '_' + d.ma;\n\n // get symbol sdf from cache or generate it\n if(SYMBOL_SDF[symbol]) return SYMBOL_SDF[symbol];\n\n var angle = Drawing.getMarkerAngle(d, trace);\n if(isDot && !symbolNoDot) {\n symbolPath = symbolFunc(SYMBOL_SIZE * 1.1, angle) + SYMBOL_SVG_CIRCLE;\n } else {\n symbolPath = symbolFunc(SYMBOL_SIZE, angle);\n }\n\n symbolSdf = svgSdf(symbolPath, {\n w: SYMBOL_SDF_SIZE,\n h: SYMBOL_SDF_SIZE,\n viewBox: [-SYMBOL_SIZE, -SYMBOL_SIZE, SYMBOL_SIZE, SYMBOL_SIZE],\n stroke: symbolNoFill ? SYMBOL_STROKE : -SYMBOL_STROKE\n });\n\n SYMBOL_SDF[symbol] = symbolSdf;\n\n return symbolSdf || null;\n}\n\nfunction convertLinePositions(gd, trace, positions) {\n var len = positions.length;\n var count = len / 2;\n var linePositions;\n var i;\n\n if(subTypes.hasLines(trace) && count) {\n if(trace.line.shape === 'hv') {\n linePositions = [];\n for(i = 0; i < count - 1; i++) {\n if(isNaN(positions[i * 2]) || isNaN(positions[i * 2 + 1])) {\n linePositions.push(NaN, NaN, NaN, NaN);\n } else {\n linePositions.push(positions[i * 2], positions[i * 2 + 1]);\n if(!isNaN(positions[i * 2 + 2]) && !isNaN(positions[i * 2 + 3])) {\n linePositions.push(positions[i * 2 + 2], positions[i * 2 + 1]);\n } else {\n linePositions.push(NaN, NaN);\n }\n }\n }\n linePositions.push(positions[len - 2], positions[len - 1]);\n } else if(trace.line.shape === 'hvh') {\n linePositions = [];\n for(i = 0; i < count - 1; i++) {\n if(isNaN(positions[i * 2]) || isNaN(positions[i * 2 + 1]) || isNaN(positions[i * 2 + 2]) || isNaN(positions[i * 2 + 3])) {\n if(!isNaN(positions[i * 2]) && !isNaN(positions[i * 2 + 1])) {\n linePositions.push(positions[i * 2], positions[i * 2 + 1]);\n } else {\n linePositions.push(NaN, NaN);\n }\n linePositions.push(NaN, NaN);\n } else {\n var midPtX = (positions[i * 2] + positions[i * 2 + 2]) / 2;\n linePositions.push(\n positions[i * 2],\n positions[i * 2 + 1],\n midPtX,\n positions[i * 2 + 1],\n midPtX,\n positions[i * 2 + 3]\n );\n }\n }\n linePositions.push(positions[len - 2], positions[len - 1]);\n } else if(trace.line.shape === 'vhv') {\n linePositions = [];\n for(i = 0; i < count - 1; i++) {\n if(isNaN(positions[i * 2]) || isNaN(positions[i * 2 + 1]) || isNaN(positions[i * 2 + 2]) || isNaN(positions[i * 2 + 3])) {\n if(!isNaN(positions[i * 2]) && !isNaN(positions[i * 2 + 1])) {\n linePositions.push(positions[i * 2], positions[i * 2 + 1]);\n } else {\n linePositions.push(NaN, NaN);\n }\n linePositions.push(NaN, NaN);\n } else {\n var midPtY = (positions[i * 2 + 1] + positions[i * 2 + 3]) / 2;\n linePositions.push(\n positions[i * 2],\n positions[i * 2 + 1],\n positions[i * 2],\n midPtY,\n positions[i * 2 + 2],\n midPtY\n );\n }\n }\n linePositions.push(positions[len - 2], positions[len - 1]);\n } else if(trace.line.shape === 'vh') {\n linePositions = [];\n for(i = 0; i < count - 1; i++) {\n if(isNaN(positions[i * 2]) || isNaN(positions[i * 2 + 1])) {\n linePositions.push(NaN, NaN, NaN, NaN);\n } else {\n linePositions.push(positions[i * 2], positions[i * 2 + 1]);\n if(!isNaN(positions[i * 2 + 2]) && !isNaN(positions[i * 2 + 3])) {\n linePositions.push(positions[i * 2], positions[i * 2 + 3]);\n } else {\n linePositions.push(NaN, NaN);\n }\n }\n }\n linePositions.push(positions[len - 2], positions[len - 1]);\n } else {\n linePositions = positions;\n }\n }\n\n // If we have data with gaps, we ought to use rect joins\n // FIXME: get rid of this\n var hasNaN = false;\n for(i = 0; i < linePositions.length; i++) {\n if(isNaN(linePositions[i])) {\n hasNaN = true;\n break;\n }\n }\n\n var join = (hasNaN || linePositions.length > constants.TOO_MANY_POINTS) ? 'rect' :\n subTypes.hasMarkers(trace) ? 'rect' : 'round';\n\n // fill gaps\n if(hasNaN && trace.connectgaps) {\n var lastX = linePositions[0];\n var lastY = linePositions[1];\n\n for(i = 0; i < linePositions.length; i += 2) {\n if(isNaN(linePositions[i]) || isNaN(linePositions[i + 1])) {\n linePositions[i] = lastX;\n linePositions[i + 1] = lastY;\n } else {\n lastX = linePositions[i];\n lastY = linePositions[i + 1];\n }\n }\n }\n\n return {\n join: join,\n positions: linePositions\n };\n}\n\nfunction convertErrorBarPositions(gd, trace, positions, x, y) {\n var makeComputeError = Registry.getComponentMethod('errorbars', 'makeComputeError');\n var xa = AxisIDs.getFromId(gd, trace.xaxis, 'x');\n var ya = AxisIDs.getFromId(gd, trace.yaxis, 'y');\n var count = positions.length / 2;\n var out = {};\n\n function convertOneAxis(coords, ax) {\n var axLetter = ax._id.charAt(0);\n var opts = trace['error_' + axLetter];\n\n if(opts && opts.visible && (ax.type === 'linear' || ax.type === 'log')) {\n var computeError = makeComputeError(opts);\n var pOffset = {x: 0, y: 1}[axLetter];\n var eOffset = {x: [0, 1, 2, 3], y: [2, 3, 0, 1]}[axLetter];\n var errors = new Float64Array(4 * count);\n var minShoe = Infinity;\n var maxHat = -Infinity;\n\n for(var i = 0, j = 0; i < count; i++, j += 4) {\n var dc = coords[i];\n\n if(isNumeric(dc)) {\n var dl = positions[i * 2 + pOffset];\n var vals = computeError(dc, i);\n var lv = vals[0];\n var hv = vals[1];\n\n if(isNumeric(lv) && isNumeric(hv)) {\n var shoe = dc - lv;\n var hat = dc + hv;\n\n errors[j + eOffset[0]] = dl - ax.c2l(shoe);\n errors[j + eOffset[1]] = ax.c2l(hat) - dl;\n errors[j + eOffset[2]] = 0;\n errors[j + eOffset[3]] = 0;\n\n minShoe = Math.min(minShoe, dc - lv);\n maxHat = Math.max(maxHat, dc + hv);\n }\n }\n }\n\n out[axLetter] = {\n positions: positions,\n errors: errors,\n _bnds: [minShoe, maxHat]\n };\n }\n }\n\n convertOneAxis(x, xa);\n convertOneAxis(y, ya);\n return out;\n}\n\nfunction convertTextPosition(gd, trace, textOpts, markerOpts) {\n var count = trace._length;\n var out = {};\n var i;\n\n // corresponds to textPointPosition from component.drawing\n if(subTypes.hasMarkers(trace)) {\n var fontOpts = textOpts.font;\n var align = textOpts.align;\n var baseline = textOpts.baseline;\n out.offset = new Array(count);\n\n for(i = 0; i < count; i++) {\n var ms = markerOpts.sizes ? markerOpts.sizes[i] : markerOpts.size;\n var fs = isArrayOrTypedArray(fontOpts) ? fontOpts[i].size : fontOpts.size;\n\n var a = isArrayOrTypedArray(align) ?\n (align.length > 1 ? align[i] : align[0]) :\n align;\n var b = isArrayOrTypedArray(baseline) ?\n (baseline.length > 1 ? baseline[i] : baseline[0]) :\n baseline;\n\n var hSign = TEXTOFFSETSIGN[a];\n var vSign = TEXTOFFSETSIGN[b];\n var xPad = ms ? ms / 0.8 + 1 : 0;\n var yPad = -vSign * xPad - vSign * 0.5;\n out.offset[i] = [hSign * xPad / fs, yPad / fs];\n }\n }\n\n return out;\n}\n\nmodule.exports = {\n style: convertStyle,\n\n markerStyle: convertMarkerStyle,\n markerSelection: convertMarkerSelection,\n\n linePositions: convertLinePositions,\n errorBarPositions: convertErrorBarPositions,\n textPosition: convertTextPosition\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\n\nvar helpers = require('./helpers');\nvar attributes = require('./attributes');\nvar constants = require('../scatter/constants');\nvar subTypes = require('../scatter/subtypes');\nvar handleXYDefaults = require('../scatter/xy_defaults');\nvar handlePeriodDefaults = require('../scatter/period_defaults');\nvar handleMarkerDefaults = require('../scatter/marker_defaults');\nvar handleLineDefaults = require('../scatter/line_defaults');\nvar handleFillColorDefaults = require('../scatter/fillcolor_defaults');\nvar handleTextDefaults = require('../scatter/text_defaults');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var isOpen = traceIn.marker ? helpers.isOpenSymbol(traceIn.marker.symbol) : false;\n var isBubble = subTypes.isBubble(traceIn);\n\n var len = handleXYDefaults(traceIn, traceOut, layout, coerce);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n handlePeriodDefaults(traceIn, traceOut, layout, coerce);\n coerce('xhoverformat');\n coerce('yhoverformat');\n\n var defaultMode = len < constants.PTS_LINESONLY ? 'lines+markers' : 'lines';\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n coerce('mode', defaultMode);\n\n if(subTypes.hasMarkers(traceOut)) {\n handleMarkerDefaults(traceIn, traceOut, defaultColor, layout, coerce, {noAngleRef: true, noStandOff: true});\n coerce('marker.line.width', isOpen || isBubble ? 1 : 0);\n }\n\n if(subTypes.hasLines(traceOut)) {\n coerce('connectgaps');\n handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce);\n coerce('line.shape');\n }\n\n if(subTypes.hasText(traceOut)) {\n coerce('texttemplate');\n handleTextDefaults(traceIn, traceOut, layout, coerce, {\n noFontShadow: true,\n noFontLineposition: true,\n noFontTextcase: true,\n });\n }\n\n var lineColor = (traceOut.line || {}).color;\n var markerColor = (traceOut.marker || {}).color;\n\n coerce('fill');\n if(traceOut.fill !== 'none') {\n handleFillColorDefaults(traceIn, traceOut, defaultColor, coerce);\n }\n\n var errorBarsSupplyDefaults = Registry.getComponentMethod('errorbars', 'supplyDefaults');\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || markerColor || defaultColor, {axis: 'y'});\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || markerColor || defaultColor, {axis: 'x', inherit: 'y'});\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../../components/color');\n\nvar DESELECTDIM = require('../../constants/interactions').DESELECTDIM;\n\nfunction styleTextSelection(cd) {\n var cd0 = cd[0];\n var trace = cd0.trace;\n var stash = cd0.t;\n var scene = stash._scene;\n var index = stash.index;\n var els = scene.selectBatch[index];\n var unels = scene.unselectBatch[index];\n var baseOpts = scene.textOptions[index];\n var selOpts = scene.textSelectedOptions[index] || {};\n var unselOpts = scene.textUnselectedOptions[index] || {};\n var opts = Lib.extendFlat({}, baseOpts);\n var i, j;\n\n if(els.length || unels.length) {\n var stc = selOpts.color;\n var utc = unselOpts.color;\n var base = baseOpts.color;\n var hasArrayBase = Lib.isArrayOrTypedArray(base);\n opts.color = new Array(trace._length);\n\n for(i = 0; i < els.length; i++) {\n j = els[i];\n opts.color[j] = stc || (hasArrayBase ? base[j] : base);\n }\n for(i = 0; i < unels.length; i++) {\n j = unels[i];\n var basej = hasArrayBase ? base[j] : base;\n opts.color[j] = utc ? utc :\n stc ? basej : Color.addOpacity(basej, DESELECTDIM);\n }\n }\n\n scene.glText[index].update(opts);\n}\n\nmodule.exports = {\n styleTextSelection: styleTextSelection\n};\n","'use strict';\n\nvar scatterFormatLabels = require('../scatter/format_labels');\n\nmodule.exports = function formatLabels(cdi, trace, fullLayout) {\n var i = cdi.i;\n if(!('x' in cdi)) cdi.x = trace._x[i];\n if(!('y' in cdi)) cdi.y = trace._y[i];\n return scatterFormatLabels(cdi, trace, fullLayout);\n};\n","'use strict';\n\nvar constants = require('./constants');\n\nexports.isOpenSymbol = function(symbol) {\n return (typeof symbol === 'string') ?\n constants.OPEN_RE.test(symbol) :\n symbol % 200 > 100;\n};\n\nexports.isDotSymbol = function(symbol) {\n return (typeof symbol === 'string') ?\n constants.DOT_RE.test(symbol) :\n symbol > 200;\n};\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar getTraceColor = require('../scatter/get_trace_color');\n\nfunction hoverPoints(pointData, xval, yval, hovermode) {\n var cd = pointData.cd;\n var stash = cd[0].t;\n var trace = cd[0].trace;\n var xa = pointData.xa;\n var ya = pointData.ya;\n var x = stash.x;\n var y = stash.y;\n var xpx = xa.c2p(xval);\n var ypx = ya.c2p(yval);\n var maxDistance = pointData.distance;\n var ids;\n\n // FIXME: make sure this is a proper way to calc search radius\n if(stash.tree) {\n var xl = xa.p2c(xpx - maxDistance);\n var xr = xa.p2c(xpx + maxDistance);\n var yl = ya.p2c(ypx - maxDistance);\n var yr = ya.p2c(ypx + maxDistance);\n\n if(hovermode === 'x') {\n ids = stash.tree.range(\n Math.min(xl, xr), Math.min(ya._rl[0], ya._rl[1]),\n Math.max(xl, xr), Math.max(ya._rl[0], ya._rl[1])\n );\n } else {\n ids = stash.tree.range(\n Math.min(xl, xr), Math.min(yl, yr),\n Math.max(xl, xr), Math.max(yl, yr)\n );\n }\n } else {\n ids = stash.ids;\n }\n\n // pick the id closest to the point\n // note that point possibly may not be found\n var k, closestId, ptx, pty, i, dx, dy, dist, dxy;\n\n var minDist = maxDistance;\n if(hovermode === 'x') {\n var xPeriod = !!trace.xperiodalignment;\n var yPeriod = !!trace.yperiodalignment;\n\n for(i = 0; i < ids.length; i++) {\n k = ids[i];\n ptx = x[k];\n\n dx = Math.abs(xa.c2p(ptx) - xpx);\n if(xPeriod) {\n var x0 = xa.c2p(trace._xStarts[k]);\n var x1 = xa.c2p(trace._xEnds[k]);\n\n dx = (\n xpx >= Math.min(x0, x1) &&\n xpx <= Math.max(x0, x1)\n ) ? 0 : Infinity;\n }\n\n if(dx < minDist) {\n minDist = dx;\n pty = y[k];\n dy = ya.c2p(pty) - ypx;\n\n if(yPeriod) {\n var y0 = ya.c2p(trace._yStarts[k]);\n var y1 = ya.c2p(trace._yEnds[k]);\n\n dy = (\n ypx >= Math.min(y0, y1) &&\n ypx <= Math.max(y0, y1)\n ) ? 0 : Infinity;\n }\n\n dxy = Math.sqrt(dx * dx + dy * dy);\n closestId = ids[i];\n }\n }\n } else {\n for(i = ids.length - 1; i > -1; i--) {\n k = ids[i];\n ptx = x[k];\n pty = y[k];\n dx = xa.c2p(ptx) - xpx;\n dy = ya.c2p(pty) - ypx;\n\n dist = Math.sqrt(dx * dx + dy * dy);\n if(dist < minDist) {\n minDist = dxy = dist;\n closestId = k;\n }\n }\n }\n\n pointData.index = closestId;\n pointData.distance = minDist;\n pointData.dxy = dxy;\n\n if(closestId === undefined) return [pointData];\n\n return [calcHover(pointData, x, y, trace)];\n}\n\nfunction calcHover(pointData, x, y, trace) {\n var xa = pointData.xa;\n var ya = pointData.ya;\n var minDist = pointData.distance;\n var dxy = pointData.dxy;\n var id = pointData.index;\n\n // the closest data point\n var di = {\n pointNumber: id,\n x: x[id],\n y: y[id]\n };\n\n // that is single-item arrays_to_calcdata excerpt, since we are doing it for a single point and we don't have to do it beforehead for 1e6 points\n di.tx = Lib.isArrayOrTypedArray(trace.text) ? trace.text[id] : trace.text;\n di.htx = Array.isArray(trace.hovertext) ? trace.hovertext[id] : trace.hovertext;\n di.data = Array.isArray(trace.customdata) ? trace.customdata[id] : trace.customdata;\n di.tp = Array.isArray(trace.textposition) ? trace.textposition[id] : trace.textposition;\n\n var font = trace.textfont;\n if(font) {\n di.ts = Lib.isArrayOrTypedArray(font.size) ? font.size[id] : font.size;\n di.tc = Lib.isArrayOrTypedArray(font.color) ? font.color[id] : font.color;\n di.tf = Array.isArray(font.family) ? font.family[id] : font.family;\n di.tw = Array.isArray(font.weight) ? font.weight[id] : font.weight;\n di.ty = Array.isArray(font.style) ? font.style[id] : font.style;\n di.tv = Array.isArray(font.variant) ? font.variant[id] : font.variant;\n }\n\n var marker = trace.marker;\n if(marker) {\n di.ms = Lib.isArrayOrTypedArray(marker.size) ? marker.size[id] : marker.size;\n di.mo = Lib.isArrayOrTypedArray(marker.opacity) ? marker.opacity[id] : marker.opacity;\n di.mx = Lib.isArrayOrTypedArray(marker.symbol) ? marker.symbol[id] : marker.symbol;\n di.ma = Lib.isArrayOrTypedArray(marker.angle) ? marker.angle[id] : marker.angle;\n di.mc = Lib.isArrayOrTypedArray(marker.color) ? marker.color[id] : marker.color;\n }\n\n var line = marker && marker.line;\n if(line) {\n di.mlc = Array.isArray(line.color) ? line.color[id] : line.color;\n di.mlw = Lib.isArrayOrTypedArray(line.width) ? line.width[id] : line.width;\n }\n\n var grad = marker && marker.gradient;\n if(grad && grad.type !== 'none') {\n di.mgt = Array.isArray(grad.type) ? grad.type[id] : grad.type;\n di.mgc = Array.isArray(grad.color) ? grad.color[id] : grad.color;\n }\n\n var xp = xa.c2p(di.x, true);\n var yp = ya.c2p(di.y, true);\n var rad = di.mrc || 1;\n\n var hoverlabel = trace.hoverlabel;\n\n if(hoverlabel) {\n di.hbg = Array.isArray(hoverlabel.bgcolor) ? hoverlabel.bgcolor[id] : hoverlabel.bgcolor;\n di.hbc = Array.isArray(hoverlabel.bordercolor) ? hoverlabel.bordercolor[id] : hoverlabel.bordercolor;\n di.hts = Lib.isArrayOrTypedArray(hoverlabel.font.size) ? hoverlabel.font.size[id] : hoverlabel.font.size;\n di.htc = Array.isArray(hoverlabel.font.color) ? hoverlabel.font.color[id] : hoverlabel.font.color;\n di.htf = Array.isArray(hoverlabel.font.family) ? hoverlabel.font.family[id] : hoverlabel.font.family;\n di.hnl = Lib.isArrayOrTypedArray(hoverlabel.namelength) ? hoverlabel.namelength[id] : hoverlabel.namelength;\n }\n var hoverinfo = trace.hoverinfo;\n if(hoverinfo) {\n di.hi = Array.isArray(hoverinfo) ? hoverinfo[id] : hoverinfo;\n }\n\n var hovertemplate = trace.hovertemplate;\n if(hovertemplate) {\n di.ht = Array.isArray(hovertemplate) ? hovertemplate[id] : hovertemplate;\n }\n\n var fakeCd = {};\n fakeCd[pointData.index] = di;\n\n var origX = trace._origX;\n var origY = trace._origY;\n\n var pointData2 = Lib.extendFlat({}, pointData, {\n color: getTraceColor(trace, di),\n\n x0: xp - rad,\n x1: xp + rad,\n xLabelVal: origX ? origX[id] : di.x,\n\n y0: yp - rad,\n y1: yp + rad,\n yLabelVal: origY ? origY[id] : di.y,\n\n cd: fakeCd,\n distance: minDist,\n spikeDistance: dxy,\n\n hovertemplate: di.ht\n });\n\n if(di.htx) pointData2.text = di.htx;\n else if(di.tx) pointData2.text = di.tx;\n else if(trace.text) pointData2.text = trace.text;\n\n Lib.fillText(di, trace, pointData2);\n Registry.getComponentMethod('errorbars', 'hoverInfo')(di, trace, pointData2);\n\n return pointData2;\n}\n\nmodule.exports = {\n hoverPoints: hoverPoints,\n calcHover: calcHover\n};\n","'use strict';\n\nvar index = require('./base_index');\n\nindex.plot = require('./plot');\n\nmodule.exports = index;\n","'use strict';\n\nvar createScatter = require('regl-scatter2d');\nvar createLine = require('regl-line2d');\nvar createError = require('regl-error2d');\nvar Text = require('gl-text');\n\nvar Lib = require('../../lib');\nvar selectMode = require('../../components/dragelement/helpers').selectMode;\nvar prepareRegl = require('../../lib/prepare_regl');\n\nvar subTypes = require('../scatter/subtypes');\nvar linkTraces = require('../scatter/link_traces');\n\nvar styleTextSelection = require('./edit_style').styleTextSelection;\n\nvar reglPrecompiled = {};\n\nfunction getViewport(fullLayout, xaxis, yaxis, plotGlPixelRatio) {\n var gs = fullLayout._size;\n var width = fullLayout.width * plotGlPixelRatio;\n var height = fullLayout.height * plotGlPixelRatio;\n\n var l = gs.l * plotGlPixelRatio;\n var b = gs.b * plotGlPixelRatio;\n var r = gs.r * plotGlPixelRatio;\n var t = gs.t * plotGlPixelRatio;\n var w = gs.w * plotGlPixelRatio;\n var h = gs.h * plotGlPixelRatio;\n return [\n l + xaxis.domain[0] * w,\n b + yaxis.domain[0] * h,\n (width - r) - (1 - xaxis.domain[1]) * w,\n (height - t) - (1 - yaxis.domain[1]) * h\n ];\n}\n\nvar exports = module.exports = function plot(gd, subplot, cdata) {\n if(!cdata.length) return;\n\n var fullLayout = gd._fullLayout;\n var scene = subplot._scene;\n var xaxis = subplot.xaxis;\n var yaxis = subplot.yaxis;\n var i, j;\n\n // we may have more subplots than initialized data due to Axes.getSubplots method\n if(!scene) return;\n\n var success = prepareRegl(gd, ['ANGLE_instanced_arrays', 'OES_element_index_uint'], reglPrecompiled);\n if(!success) {\n scene.init();\n return;\n }\n\n var count = scene.count;\n var regl = fullLayout._glcanvas.data()[0].regl;\n\n // that is needed for fills\n linkTraces(gd, subplot, cdata);\n\n if(scene.dirty) {\n if(\n (scene.line2d || scene.error2d) &&\n !(scene.scatter2d || scene.fill2d || scene.glText)\n ) {\n // Fixes shared WebGL context drawing lines only case\n regl.clear({});\n }\n\n // make sure scenes are created\n if(scene.error2d === true) {\n scene.error2d = createError(regl);\n }\n if(scene.line2d === true) {\n scene.line2d = createLine(regl);\n }\n if(scene.scatter2d === true) {\n scene.scatter2d = createScatter(regl);\n }\n if(scene.fill2d === true) {\n scene.fill2d = createLine(regl);\n }\n if(scene.glText === true) {\n scene.glText = new Array(count);\n for(i = 0; i < count; i++) {\n scene.glText[i] = new Text(regl);\n }\n }\n\n // update main marker options\n if(scene.glText) {\n if(count > scene.glText.length) {\n // add gl text marker\n var textsToAdd = count - scene.glText.length;\n for(i = 0; i < textsToAdd; i++) {\n scene.glText.push(new Text(regl));\n }\n } else if(count < scene.glText.length) {\n // remove gl text marker\n var textsToRemove = scene.glText.length - count;\n var removedTexts = scene.glText.splice(count, textsToRemove);\n removedTexts.forEach(function(text) { text.destroy(); });\n }\n\n for(i = 0; i < count; i++) {\n scene.glText[i].update(scene.textOptions[i]);\n }\n }\n if(scene.line2d) {\n scene.line2d.update(scene.lineOptions);\n scene.lineOptions = scene.lineOptions.map(function(lineOptions) {\n if(lineOptions && lineOptions.positions) {\n var srcPos = lineOptions.positions;\n\n var firstptdef = 0;\n while(firstptdef < srcPos.length && (isNaN(srcPos[firstptdef]) || isNaN(srcPos[firstptdef + 1]))) {\n firstptdef += 2;\n }\n var lastptdef = srcPos.length - 2;\n while(lastptdef > firstptdef && (isNaN(srcPos[lastptdef]) || isNaN(srcPos[lastptdef + 1]))) {\n lastptdef -= 2;\n }\n lineOptions.positions = srcPos.slice(firstptdef, lastptdef + 2);\n }\n return lineOptions;\n });\n scene.line2d.update(scene.lineOptions);\n }\n if(scene.error2d) {\n var errorBatch = (scene.errorXOptions || []).concat(scene.errorYOptions || []);\n scene.error2d.update(errorBatch);\n }\n if(scene.scatter2d) {\n scene.scatter2d.update(scene.markerOptions);\n }\n\n // fill requires linked traces, so we generate it's positions here\n scene.fillOrder = Lib.repeat(null, count);\n if(scene.fill2d) {\n scene.fillOptions = scene.fillOptions.map(function(fillOptions, i) {\n var cdscatter = cdata[i];\n if(!fillOptions || !cdscatter || !cdscatter[0] || !cdscatter[0].trace) return;\n var cd = cdscatter[0];\n var trace = cd.trace;\n var stash = cd.t;\n var lineOptions = scene.lineOptions[i];\n var last, j;\n\n var fillData = [];\n if(trace._ownfill) fillData.push(i);\n if(trace._nexttrace) fillData.push(i + 1);\n if(fillData.length) scene.fillOrder[i] = fillData;\n\n var pos = [];\n var srcPos = (lineOptions && lineOptions.positions) || stash.positions;\n var firstptdef, lastptdef;\n\n if(trace.fill === 'tozeroy') {\n firstptdef = 0;\n while(firstptdef < srcPos.length && isNaN(srcPos[firstptdef + 1])) {\n firstptdef += 2;\n }\n lastptdef = srcPos.length - 2;\n while(lastptdef > firstptdef && isNaN(srcPos[lastptdef + 1])) {\n lastptdef -= 2;\n }\n if(srcPos[firstptdef + 1] !== 0) {\n pos = [srcPos[firstptdef], 0];\n }\n pos = pos.concat(srcPos.slice(firstptdef, lastptdef + 2));\n if(srcPos[lastptdef + 1] !== 0) {\n pos = pos.concat([srcPos[lastptdef], 0]);\n }\n } else if(trace.fill === 'tozerox') {\n firstptdef = 0;\n while(firstptdef < srcPos.length && isNaN(srcPos[firstptdef])) {\n firstptdef += 2;\n }\n lastptdef = srcPos.length - 2;\n while(lastptdef > firstptdef && isNaN(srcPos[lastptdef])) {\n lastptdef -= 2;\n }\n if(srcPos[firstptdef] !== 0) {\n pos = [0, srcPos[firstptdef + 1]];\n }\n pos = pos.concat(srcPos.slice(firstptdef, lastptdef + 2));\n if(srcPos[lastptdef] !== 0) {\n pos = pos.concat([ 0, srcPos[lastptdef + 1]]);\n }\n } else if(trace.fill === 'toself' || trace.fill === 'tonext') {\n pos = [];\n last = 0;\n\n fillOptions.splitNull = true;\n\n for(j = 0; j < srcPos.length; j += 2) {\n if(isNaN(srcPos[j]) || isNaN(srcPos[j + 1])) {\n pos = pos.concat(srcPos.slice(last, j));\n pos.push(srcPos[last], srcPos[last + 1]);\n pos.push(null, null); // keep null to mark end of polygon\n last = j + 2;\n }\n }\n pos = pos.concat(srcPos.slice(last));\n if(last) {\n pos.push(srcPos[last], srcPos[last + 1]);\n }\n } else {\n var nextTrace = trace._nexttrace;\n\n if(nextTrace) {\n var nextOptions = scene.lineOptions[i + 1];\n\n if(nextOptions) {\n var nextPos = nextOptions.positions;\n if(trace.fill === 'tonexty') {\n pos = srcPos.slice();\n\n for(i = Math.floor(nextPos.length / 2); i--;) {\n var xx = nextPos[i * 2];\n var yy = nextPos[i * 2 + 1];\n if(isNaN(xx) || isNaN(yy)) continue;\n pos.push(xx, yy);\n }\n fillOptions.fill = nextTrace.fillcolor;\n }\n }\n }\n }\n\n // detect prev trace positions to exclude from current fill\n if(trace._prevtrace && trace._prevtrace.fill === 'tonext') {\n var prevLinePos = scene.lineOptions[i - 1].positions;\n\n // FIXME: likely this logic should be tested better\n var offset = pos.length / 2;\n last = offset;\n var hole = [last];\n for(j = 0; j < prevLinePos.length; j += 2) {\n if(isNaN(prevLinePos[j]) || isNaN(prevLinePos[j + 1])) {\n hole.push(j / 2 + offset + 1);\n last = j + 2;\n }\n }\n\n pos = pos.concat(prevLinePos);\n fillOptions.hole = hole;\n }\n fillOptions.fillmode = trace.fill;\n fillOptions.opacity = trace.opacity;\n fillOptions.positions = pos;\n\n return fillOptions;\n });\n\n scene.fill2d.update(scene.fillOptions);\n }\n }\n\n // form batch arrays, and check for selected points\n var dragmode = fullLayout.dragmode;\n var isSelectMode = selectMode(dragmode);\n var clickSelectEnabled = fullLayout.clickmode.indexOf('select') > -1;\n\n for(i = 0; i < count; i++) {\n var cd0 = cdata[i][0];\n var trace = cd0.trace;\n var stash = cd0.t;\n var index = stash.index;\n var len = trace._length;\n var x = stash.x;\n var y = stash.y;\n\n if(trace.selectedpoints || isSelectMode || clickSelectEnabled) {\n if(!isSelectMode) isSelectMode = true;\n\n // regenerate scene batch, if traces number changed during selection\n if(trace.selectedpoints) {\n var selPts = scene.selectBatch[index] = Lib.selIndices2selPoints(trace);\n\n var selDict = {};\n for(j = 0; j < selPts.length; j++) {\n selDict[selPts[j]] = 1;\n }\n var unselPts = [];\n for(j = 0; j < len; j++) {\n if(!selDict[j]) unselPts.push(j);\n }\n scene.unselectBatch[index] = unselPts;\n }\n\n // precalculate px coords since we are not going to pan during select\n // TODO, could do better here e.g.\n // - spin that in a webworker\n // - compute selection from polygons in data coordinates\n // (maybe just for linear axes)\n var xpx = stash.xpx = new Array(len);\n var ypx = stash.ypx = new Array(len);\n for(j = 0; j < len; j++) {\n xpx[j] = xaxis.c2p(x[j]);\n ypx[j] = yaxis.c2p(y[j]);\n }\n } else {\n stash.xpx = stash.ypx = null;\n }\n }\n\n if(isSelectMode) {\n // create scatter instance by cloning scatter2d\n if(!scene.select2d) {\n scene.select2d = createScatter(fullLayout._glcanvas.data()[1].regl);\n }\n\n // use unselected styles on 'context' canvas\n if(scene.scatter2d) {\n var unselOpts = new Array(count);\n for(i = 0; i < count; i++) {\n unselOpts[i] = scene.selectBatch[i].length || scene.unselectBatch[i].length ?\n scene.markerUnselectedOptions[i] :\n {};\n }\n scene.scatter2d.update(unselOpts);\n }\n\n // use selected style on 'focus' canvas\n if(scene.select2d) {\n scene.select2d.update(scene.markerOptions);\n scene.select2d.update(scene.markerSelectedOptions);\n }\n\n if(scene.glText) {\n cdata.forEach(function(cdscatter) {\n var trace = ((cdscatter || [])[0] || {}).trace || {};\n if(subTypes.hasText(trace)) {\n styleTextSelection(cdscatter);\n }\n });\n }\n } else {\n // reset 'context' scatter2d opts to base opts,\n // thus unsetting markerUnselectedOptions from selection\n if(scene.scatter2d) {\n scene.scatter2d.update(scene.markerOptions);\n }\n }\n\n // provide viewport and range\n var vpRange0 = {\n viewport: getViewport(fullLayout, xaxis, yaxis, gd._context.plotGlPixelRatio),\n // TODO do we need those fallbacks?\n range: [\n (xaxis._rl || xaxis.range)[0],\n (yaxis._rl || yaxis.range)[0],\n (xaxis._rl || xaxis.range)[1],\n (yaxis._rl || yaxis.range)[1]\n ]\n };\n var vpRange = Lib.repeat(vpRange0, scene.count);\n\n // upload viewport/range data to GPU\n if(scene.fill2d) {\n scene.fill2d.update(vpRange);\n }\n if(scene.line2d) {\n scene.line2d.update(vpRange);\n }\n if(scene.error2d) {\n scene.error2d.update(vpRange.concat(vpRange));\n }\n if(scene.scatter2d) {\n scene.scatter2d.update(vpRange);\n }\n if(scene.select2d) {\n scene.select2d.update(vpRange);\n }\n if(scene.glText) {\n scene.glText.forEach(function(text) { text.update(vpRange0); });\n }\n};\n\nexports.reglPrecompiled = reglPrecompiled;\n","'use strict';\n\nvar Lib = require('../../lib');\n\n// make sure scene exists on subplot, return it\nmodule.exports = function sceneUpdate(gd, subplot) {\n var scene = subplot._scene;\n\n var resetOpts = {\n // number of traces in subplot, since scene:subplot -> 1:1\n count: 0,\n // whether scene requires init hook in plot call (dirty plot call)\n dirty: true,\n // last used options\n lineOptions: [],\n fillOptions: [],\n markerOptions: [],\n markerSelectedOptions: [],\n markerUnselectedOptions: [],\n errorXOptions: [],\n errorYOptions: [],\n textOptions: [],\n textSelectedOptions: [],\n textUnselectedOptions: [],\n // selection batches\n selectBatch: [],\n unselectBatch: []\n };\n\n // regl- component stubs, initialized in dirty plot call\n var initOpts = {\n fill2d: false,\n scatter2d: false,\n error2d: false,\n line2d: false,\n glText: false,\n select2d: false\n };\n\n if(!subplot._scene) {\n scene = subplot._scene = {};\n\n scene.init = function init() {\n Lib.extendFlat(scene, initOpts, resetOpts);\n };\n\n scene.init();\n\n // apply new option to all regl components (used on drag)\n scene.update = function update(opt) {\n var opts = Lib.repeat(opt, scene.count);\n\n if(scene.fill2d) scene.fill2d.update(opts);\n if(scene.scatter2d) scene.scatter2d.update(opts);\n if(scene.line2d) scene.line2d.update(opts);\n if(scene.error2d) scene.error2d.update(opts.concat(opts));\n if(scene.select2d) scene.select2d.update(opts);\n if(scene.glText) {\n for(var i = 0; i < scene.count; i++) {\n scene.glText[i].update(opt);\n }\n }\n };\n\n // draw traces in proper order\n scene.draw = function draw() {\n var count = scene.count;\n var fill2d = scene.fill2d;\n var error2d = scene.error2d;\n var line2d = scene.line2d;\n var scatter2d = scene.scatter2d;\n var glText = scene.glText;\n var select2d = scene.select2d;\n var selectBatch = scene.selectBatch;\n var unselectBatch = scene.unselectBatch;\n\n for(var i = 0; i < count; i++) {\n if(fill2d && scene.fillOrder[i]) {\n fill2d.draw(scene.fillOrder[i]);\n }\n if(line2d && scene.lineOptions[i]) {\n line2d.draw(i);\n }\n if(error2d) {\n if(scene.errorXOptions[i]) error2d.draw(i);\n if(scene.errorYOptions[i]) error2d.draw(i + count);\n }\n if(scatter2d && scene.markerOptions[i]) {\n if(unselectBatch[i].length) {\n var arg = Lib.repeat([], scene.count);\n arg[i] = unselectBatch[i];\n scatter2d.draw(arg);\n } else if(!selectBatch[i].length) {\n scatter2d.draw(i);\n }\n }\n if(glText[i] && scene.textOptions[i]) {\n glText[i].render();\n }\n }\n\n if(select2d) {\n select2d.draw(selectBatch);\n }\n\n scene.dirty = false;\n };\n\n // remove scene resources\n scene.destroy = function destroy() {\n if(scene.fill2d && scene.fill2d.destroy) scene.fill2d.destroy();\n if(scene.scatter2d && scene.scatter2d.destroy) scene.scatter2d.destroy();\n if(scene.error2d && scene.error2d.destroy) scene.error2d.destroy();\n if(scene.line2d && scene.line2d.destroy) scene.line2d.destroy();\n if(scene.select2d && scene.select2d.destroy) scene.select2d.destroy();\n if(scene.glText) {\n scene.glText.forEach(function(text) {\n if(text.destroy) text.destroy();\n });\n }\n\n scene.lineOptions = null;\n scene.fillOptions = null;\n scene.markerOptions = null;\n scene.markerSelectedOptions = null;\n scene.markerUnselectedOptions = null;\n scene.errorXOptions = null;\n scene.errorYOptions = null;\n scene.textOptions = null;\n scene.textSelectedOptions = null;\n scene.textUnselectedOptions = null;\n\n scene.selectBatch = null;\n scene.unselectBatch = null;\n\n // we can't just delete _scene, because `destroy` is called in the\n // middle of supplyDefaults, before relinkPrivateKeys which will put it back.\n subplot._scene = null;\n };\n }\n\n // in case if we have scene from the last calc - reset data\n if(!scene.dirty) {\n Lib.extendFlat(scene, resetOpts);\n }\n\n return scene;\n};\n","'use strict';\n\nvar subTypes = require('../scatter/subtypes');\nvar styleTextSelection = require('./edit_style').styleTextSelection;\n\nmodule.exports = function select(searchInfo, selectionTester) {\n var cd = searchInfo.cd;\n var xa = searchInfo.xaxis;\n var ya = searchInfo.yaxis;\n var selection = [];\n var trace = cd[0].trace;\n var stash = cd[0].t;\n var len = trace._length;\n var x = stash.x;\n var y = stash.y;\n var scene = stash._scene;\n var index = stash.index;\n\n if(!scene) return selection;\n\n var hasText = subTypes.hasText(trace);\n var hasMarkers = subTypes.hasMarkers(trace);\n var hasOnlyLines = !hasMarkers && !hasText;\n\n if(trace.visible !== true || hasOnlyLines) return selection;\n\n var els = [];\n var unels = [];\n\n // degenerate polygon does not enable selection\n // filter out points by visible scatter ones\n if(selectionTester !== false && !selectionTester.degenerate) {\n for(var i = 0; i < len; i++) {\n if(selectionTester.contains([stash.xpx[i], stash.ypx[i]], false, i, searchInfo)) {\n els.push(i);\n selection.push({\n pointNumber: i,\n x: xa.c2d(x[i]),\n y: ya.c2d(y[i])\n });\n } else {\n unels.push(i);\n }\n }\n }\n\n if(hasMarkers) {\n var scatter2d = scene.scatter2d;\n\n if(!els.length && !unels.length) {\n // reset to base styles when clearing\n var baseOpts = new Array(scene.count);\n baseOpts[index] = scene.markerOptions[index];\n scatter2d.update.apply(scatter2d, baseOpts);\n } else if(!scene.selectBatch[index].length && !scene.unselectBatch[index].length) {\n // set unselected styles on 'context' canvas (if not done already)\n var unselOpts = new Array(scene.count);\n unselOpts[index] = scene.markerUnselectedOptions[index];\n scatter2d.update.apply(scatter2d, unselOpts);\n }\n }\n\n scene.selectBatch[index] = els;\n scene.unselectBatch[index] = unels;\n\n if(hasText) {\n styleTextSelection(cd);\n }\n\n return selection;\n};\n","'use strict';\n\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar makeFillcolorAttr = require('../scatter/fillcolor_attribute');\nvar scatterGeoAttrs = require('../scattergeo/attributes');\nvar scatterAttrs = require('../scatter/attributes');\nvar mapAttrs = require('../../plots/map/layout_attributes');\nvar baseAttrs = require('../../plots/attributes');\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar mapLayoutAtributes = require('../../plots/map/layout_attributes');\n\nvar lineAttrs = scatterGeoAttrs.line;\nvar markerAttrs = scatterGeoAttrs.marker;\n\nmodule.exports = overrideAll({\n lon: scatterGeoAttrs.lon,\n lat: scatterGeoAttrs.lat,\n\n cluster: {\n enabled: {\n valType: 'boolean',\n description: 'Determines whether clustering is enabled or disabled.'\n },\n maxzoom: extendFlat({}, mapLayoutAtributes.layers.maxzoom, {\n description: [\n 'Sets the maximum zoom level.',\n 'At zoom levels equal to or greater than this, points will never be clustered.'\n ].join(' ')\n }),\n step: {\n valType: 'number',\n arrayOk: true,\n dflt: -1,\n min: -1,\n description: [\n 'Sets how many points it takes to create a cluster or advance to the next cluster step.',\n 'Use this in conjunction with arrays for `size` and / or `color`.',\n 'If an integer, steps start at multiples of this number.',\n 'If an array, each step extends from the given value until one less than the next value.'\n ].join(' ')\n },\n size: {\n valType: 'number',\n arrayOk: true,\n dflt: 20,\n min: 0,\n description: [\n 'Sets the size for each cluster step.'\n ].join(' ')\n },\n color: {\n valType: 'color',\n arrayOk: true,\n description: [\n 'Sets the color for each cluster step.'\n ].join(' ')\n },\n opacity: extendFlat({}, markerAttrs.opacity, {\n dflt: 1\n })\n },\n\n // locations\n // locationmode\n\n mode: extendFlat({}, scatterAttrs.mode, {\n dflt: 'markers',\n description: [\n 'Determines the drawing mode for this scatter trace.',\n 'If the provided `mode` includes *text* then the `text` elements',\n 'appear at the coordinates. Otherwise, the `text` elements',\n 'appear on hover.'\n ].join(' ')\n }),\n\n text: extendFlat({}, scatterAttrs.text, {\n description: [\n 'Sets text elements associated with each (lon,lat) pair',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s (lon,lat) coordinates.',\n 'If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,',\n 'these elements will be seen in the hover labels.'\n ].join(' ')\n }),\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: ['lat', 'lon', 'text']\n }),\n hovertext: extendFlat({}, scatterAttrs.hovertext, {\n description: [\n 'Sets hover text elements associated with each (lon,lat) pair',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s (lon,lat) coordinates.',\n 'To be seen, trace `hoverinfo` must contain a *text* flag.'\n ].join(' ')\n }),\n\n line: {\n color: lineAttrs.color,\n width: lineAttrs.width\n\n // TODO\n // dash: dash\n },\n\n connectgaps: scatterAttrs.connectgaps,\n\n marker: extendFlat({\n symbol: {\n valType: 'string',\n dflt: 'circle',\n arrayOk: true,\n description: [\n 'Sets the marker symbol.',\n 'Full list: https://www.map.com/maki-icons/',\n 'Note that the array `marker.color` and `marker.size`',\n 'are only available for *circle* symbols.'\n ].join(' ')\n },\n angle: {\n valType: 'number',\n dflt: 'auto',\n arrayOk: true,\n description: [\n 'Sets the marker orientation from true North, in degrees clockwise.',\n 'When using the *auto* default, no rotation would be applied',\n 'in perspective views which is different from using a zero angle.'\n ].join(' ')\n },\n allowoverlap: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Flag to draw all symbols, even if they overlap.'\n ].join(' ')\n },\n opacity: markerAttrs.opacity,\n size: markerAttrs.size,\n sizeref: markerAttrs.sizeref,\n sizemin: markerAttrs.sizemin,\n sizemode: markerAttrs.sizemode\n },\n colorScaleAttrs('marker')\n // line\n ),\n\n fill: scatterGeoAttrs.fill,\n fillcolor: makeFillcolorAttr(),\n\n textfont: mapAttrs.layers.symbol.textfont,\n textposition: mapAttrs.layers.symbol.textposition,\n\n below: {\n valType: 'string',\n description: [\n 'Determines if this scattermap trace\\'s layers are to be inserted',\n 'before the layer with the specified ID.',\n 'By default, scattermap layers are inserted',\n 'above all the base layers.',\n 'To place the scattermap layers above every other layer, set `below` to *\\'\\'*.'\n ].join(' ')\n },\n\n selected: {\n marker: scatterAttrs.selected.marker\n },\n unselected: {\n marker: scatterAttrs.unselected.marker\n },\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['lon', 'lat', 'text', 'name']\n }),\n hovertemplate: hovertemplateAttrs(),\n}, 'calc', 'nested');\n","'use strict';\n\n// Must use one of the following fonts as the family, else default to 'Open Sans Regular'\n// See https://github.com/openmaptiles/fonts/blob/gh-pages/fontstacks.json\nvar supportedFonts = [\n 'Metropolis Black Italic',\n 'Metropolis Black',\n 'Metropolis Bold Italic',\n 'Metropolis Bold',\n 'Metropolis Extra Bold Italic',\n 'Metropolis Extra Bold',\n 'Metropolis Extra Light Italic',\n 'Metropolis Extra Light',\n 'Metropolis Light Italic',\n 'Metropolis Light',\n 'Metropolis Medium Italic',\n 'Metropolis Medium',\n 'Metropolis Regular Italic',\n 'Metropolis Regular',\n 'Metropolis Semi Bold Italic',\n 'Metropolis Semi Bold',\n 'Metropolis Thin Italic',\n 'Metropolis Thin',\n 'Open Sans Bold Italic',\n 'Open Sans Bold',\n 'Open Sans Extrabold Italic',\n 'Open Sans Extrabold',\n 'Open Sans Italic',\n 'Open Sans Light Italic',\n 'Open Sans Light',\n 'Open Sans Regular',\n 'Open Sans Semibold Italic',\n 'Open Sans Semibold',\n 'Klokantech Noto Sans Bold',\n 'Klokantech Noto Sans CJK Bold',\n 'Klokantech Noto Sans CJK Regular',\n 'Klokantech Noto Sans Italic',\n 'Klokantech Noto Sans Regular'\n];\n\nmodule.exports = {\n isSupportedFont: function(a) {\n return supportedFonts.indexOf(a) !== -1;\n }\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar BADNUM = require('../../constants/numerical').BADNUM;\nvar geoJsonUtils = require('../../lib/geojson_utils');\n\nvar Colorscale = require('../../components/colorscale');\nvar Drawing = require('../../components/drawing');\nvar makeBubbleSizeFn = require('../scatter/make_bubble_size_func');\nvar subTypes = require('../scatter/subtypes');\nvar isSupportedFont = require('./constants').isSupportedFont;\nvar convertTextOpts = require('../../plots/map/convert_text_opts');\nvar appendArrayPointValue = require('../../components/fx/helpers').appendArrayPointValue;\n\nvar NEWLINES = require('../../lib/svg_text_utils').NEWLINES;\nvar BR_TAG_ALL = require('../../lib/svg_text_utils').BR_TAG_ALL;\n\nmodule.exports = function convert(gd, calcTrace) {\n var trace = calcTrace[0].trace;\n\n var isVisible = (trace.visible === true && trace._length !== 0);\n var hasFill = (trace.fill !== 'none');\n var hasLines = subTypes.hasLines(trace);\n var hasMarkers = subTypes.hasMarkers(trace);\n var hasText = subTypes.hasText(trace);\n var hasCircles = (hasMarkers && trace.marker.symbol === 'circle');\n var hasSymbols = (hasMarkers && trace.marker.symbol !== 'circle');\n var hasCluster = trace.cluster && trace.cluster.enabled;\n\n var fill = initContainer('fill');\n var line = initContainer('line');\n var circle = initContainer('circle');\n var symbol = initContainer('symbol');\n\n var opts = {\n fill: fill,\n line: line,\n circle: circle,\n symbol: symbol\n };\n\n // early return if not visible or placeholder\n if(!isVisible) return opts;\n\n // fill layer and line layer use the same coords\n var lineCoords;\n if(hasFill || hasLines) {\n lineCoords = geoJsonUtils.calcTraceToLineCoords(calcTrace);\n }\n\n if(hasFill) {\n fill.geojson = geoJsonUtils.makePolygon(lineCoords);\n fill.layout.visibility = 'visible';\n\n Lib.extendFlat(fill.paint, {\n 'fill-color': trace.fillcolor\n });\n }\n\n if(hasLines) {\n line.geojson = geoJsonUtils.makeLine(lineCoords);\n line.layout.visibility = 'visible';\n\n Lib.extendFlat(line.paint, {\n 'line-width': trace.line.width,\n 'line-color': trace.line.color,\n 'line-opacity': trace.opacity\n });\n\n // TODO convert line.dash into line-dasharray\n }\n\n if(hasCircles) {\n var circleOpts = makeCircleOpts(calcTrace);\n circle.geojson = circleOpts.geojson;\n circle.layout.visibility = 'visible';\n if(hasCluster) {\n circle.filter = ['!', ['has', 'point_count']];\n opts.cluster = {\n type: 'circle',\n filter: ['has', 'point_count'],\n layout: {visibility: 'visible'},\n paint: {\n 'circle-color': arrayifyAttribute(trace.cluster.color, trace.cluster.step),\n 'circle-radius': arrayifyAttribute(trace.cluster.size, trace.cluster.step),\n 'circle-opacity': arrayifyAttribute(trace.cluster.opacity, trace.cluster.step),\n },\n };\n opts.clusterCount = {\n type: 'symbol',\n filter: ['has', 'point_count'],\n paint: {},\n layout: {\n 'text-field': '{point_count_abbreviated}',\n 'text-font': getTextFont(trace),\n 'text-size': 12\n }\n };\n }\n\n Lib.extendFlat(circle.paint, {\n 'circle-color': circleOpts.mcc,\n 'circle-radius': circleOpts.mrc,\n 'circle-opacity': circleOpts.mo\n });\n }\n\n if(hasCircles && hasCluster) {\n circle.filter = ['!', ['has', 'point_count']];\n }\n\n if(hasSymbols || hasText) {\n symbol.geojson = makeSymbolGeoJSON(calcTrace, gd);\n\n Lib.extendFlat(symbol.layout, {\n visibility: 'visible',\n 'icon-image': '{symbol}-15',\n 'text-field': '{text}'\n });\n\n if(hasSymbols) {\n Lib.extendFlat(symbol.layout, {\n 'icon-size': trace.marker.size / 10\n });\n\n if('angle' in trace.marker && trace.marker.angle !== 'auto') {\n Lib.extendFlat(symbol.layout, {\n // unfortunately cant use {angle} do to this issue:\n // https://github.com/mapbox/mapbox-gl-js/issues/873\n 'icon-rotate': {\n type: 'identity', property: 'angle'\n },\n 'icon-rotation-alignment': 'map'\n });\n }\n\n symbol.layout['icon-allow-overlap'] = trace.marker.allowoverlap;\n\n Lib.extendFlat(symbol.paint, {\n 'icon-opacity': trace.opacity * trace.marker.opacity,\n\n // TODO does not work ??\n 'icon-color': trace.marker.color\n });\n }\n\n if(hasText) {\n var iconSize = (trace.marker || {}).size;\n var textOpts = convertTextOpts(trace.textposition, iconSize);\n\n // all data-driven below !!\n\n Lib.extendFlat(symbol.layout, {\n 'text-size': trace.textfont.size,\n 'text-anchor': textOpts.anchor,\n 'text-offset': textOpts.offset,\n 'text-font': getTextFont(trace)\n });\n\n Lib.extendFlat(symbol.paint, {\n 'text-color': trace.textfont.color,\n 'text-opacity': trace.opacity\n });\n }\n }\n\n return opts;\n};\n\nfunction initContainer(type) {\n return {\n type: type,\n geojson: geoJsonUtils.makeBlank(),\n layout: { visibility: 'none' },\n filter: null,\n paint: {}\n };\n}\n\nfunction makeCircleOpts(calcTrace) {\n var trace = calcTrace[0].trace;\n var marker = trace.marker;\n var selectedpoints = trace.selectedpoints;\n var arrayColor = Lib.isArrayOrTypedArray(marker.color);\n var arraySize = Lib.isArrayOrTypedArray(marker.size);\n var arrayOpacity = Lib.isArrayOrTypedArray(marker.opacity);\n var i;\n\n function addTraceOpacity(o) { return trace.opacity * o; }\n\n function size2radius(s) { return s / 2; }\n\n var colorFn;\n if(arrayColor) {\n if(Colorscale.hasColorscale(trace, 'marker')) {\n colorFn = Colorscale.makeColorScaleFuncFromTrace(marker);\n } else {\n colorFn = Lib.identity;\n }\n }\n\n var sizeFn;\n if(arraySize) {\n sizeFn = makeBubbleSizeFn(trace);\n }\n\n var opacityFn;\n if(arrayOpacity) {\n opacityFn = function(mo) {\n var mo2 = isNumeric(mo) ? +Lib.constrain(mo, 0, 1) : 0;\n return addTraceOpacity(mo2);\n };\n }\n\n var features = [];\n for(i = 0; i < calcTrace.length; i++) {\n var calcPt = calcTrace[i];\n var lonlat = calcPt.lonlat;\n\n if(isBADNUM(lonlat)) continue;\n\n var props = {};\n if(colorFn) props.mcc = calcPt.mcc = colorFn(calcPt.mc);\n if(sizeFn) props.mrc = calcPt.mrc = sizeFn(calcPt.ms);\n if(opacityFn) props.mo = opacityFn(calcPt.mo);\n if(selectedpoints) props.selected = calcPt.selected || 0;\n\n features.push({\n type: 'Feature',\n id: i + 1,\n geometry: { type: 'Point', coordinates: lonlat },\n properties: props\n });\n }\n\n var fns;\n if(selectedpoints) {\n fns = Drawing.makeSelectedPointStyleFns(trace);\n\n for(i = 0; i < features.length; i++) {\n var d = features[i].properties;\n\n if(fns.selectedOpacityFn) {\n d.mo = addTraceOpacity(fns.selectedOpacityFn(d));\n }\n if(fns.selectedColorFn) {\n d.mcc = fns.selectedColorFn(d);\n }\n if(fns.selectedSizeFn) {\n d.mrc = fns.selectedSizeFn(d);\n }\n }\n }\n\n return {\n geojson: {type: 'FeatureCollection', features: features},\n mcc: arrayColor || (fns && fns.selectedColorFn) ?\n {type: 'identity', property: 'mcc'} :\n marker.color,\n mrc: arraySize || (fns && fns.selectedSizeFn) ?\n {type: 'identity', property: 'mrc'} :\n size2radius(marker.size),\n mo: arrayOpacity || (fns && fns.selectedOpacityFn) ?\n {type: 'identity', property: 'mo'} :\n addTraceOpacity(marker.opacity)\n };\n}\n\nfunction makeSymbolGeoJSON(calcTrace, gd) {\n var fullLayout = gd._fullLayout;\n var trace = calcTrace[0].trace;\n\n var marker = trace.marker || {};\n var symbol = marker.symbol;\n var angle = marker.angle;\n\n var fillSymbol = (symbol !== 'circle') ?\n getFillFunc(symbol) :\n blankFillFunc;\n\n var fillAngle = (angle !== 'auto') ?\n getFillFunc(angle, true) :\n blankFillFunc;\n\n var fillText = subTypes.hasText(trace) ?\n getFillFunc(trace.text) :\n blankFillFunc;\n\n\n var features = [];\n\n for(var i = 0; i < calcTrace.length; i++) {\n var calcPt = calcTrace[i];\n\n if(isBADNUM(calcPt.lonlat)) continue;\n\n var texttemplate = trace.texttemplate;\n var text;\n\n if(texttemplate) {\n var tt = Array.isArray(texttemplate) ? (texttemplate[i] || '') : texttemplate;\n var labels = trace._module.formatLabels(calcPt, trace, fullLayout);\n var pointValues = {};\n appendArrayPointValue(pointValues, trace, calcPt.i);\n var meta = trace._meta || {};\n text = Lib.texttemplateString(tt, labels, fullLayout._d3locale, pointValues, calcPt, meta);\n } else {\n text = fillText(i);\n }\n\n if(text) {\n text = text.replace(NEWLINES, '').replace(BR_TAG_ALL, '\\n');\n }\n\n features.push({\n type: 'Feature',\n geometry: {\n type: 'Point',\n coordinates: calcPt.lonlat\n },\n properties: {\n symbol: fillSymbol(i),\n angle: fillAngle(i),\n text: text\n }\n });\n }\n\n return {\n type: 'FeatureCollection',\n features: features\n };\n}\n\nfunction getFillFunc(attr, numeric) {\n if(Lib.isArrayOrTypedArray(attr)) {\n if(numeric) {\n return function(i) { return isNumeric(attr[i]) ? +attr[i] : 0; };\n }\n return function(i) { return attr[i]; };\n } else if(attr) {\n return function() { return attr; };\n } else {\n return blankFillFunc;\n }\n}\n\nfunction blankFillFunc() { return ''; }\n\n// only need to check lon (OR lat)\nfunction isBADNUM(lonlat) {\n return lonlat[0] === BADNUM;\n}\n\nfunction arrayifyAttribute(values, step) {\n var newAttribute;\n if(Lib.isArrayOrTypedArray(values) && Lib.isArrayOrTypedArray(step)) {\n newAttribute = ['step', ['get', 'point_count'], values[0]];\n\n for(var idx = 1; idx < values.length; idx++) {\n newAttribute.push(step[idx - 1], values[idx]);\n }\n } else {\n newAttribute = values;\n }\n return newAttribute;\n}\n\nfunction getTextFont(trace) {\n var font = trace.textfont;\n var family = font.family;\n var style = font.style;\n var weight = font.weight;\n\n var parts = family.split(' ');\n var isItalic = parts[parts.length - 1] === 'Italic';\n if(isItalic) parts.pop();\n isItalic = isItalic || style === 'italic';\n\n var str = parts.join(' ');\n if(weight === 'bold' && parts.indexOf('Bold') === -1) {\n str += ' Bold';\n } else if(weight <= 1000) { // numeric font-weight\n // See supportedFonts\n\n if(parts[0] === 'Metropolis') {\n str = 'Metropolis';\n if(weight > 850) str += ' Black';\n else if(weight > 750) str += ' Extra Bold';\n else if(weight > 650) str += ' Bold';\n else if(weight > 550) str += ' Semi Bold';\n else if(weight > 450) str += ' Medium';\n else if(weight > 350) str += ' Regular';\n else if(weight > 250) str += ' Light';\n else if(weight > 150) str += ' Extra Light';\n else str += ' Thin';\n } else if(parts.slice(0, 2).join(' ') === 'Open Sans') {\n str = 'Open Sans';\n if(weight > 750) str += ' Extrabold';\n else if(weight > 650) str += ' Bold';\n else if(weight > 550) str += ' Semibold';\n else if(weight > 350) str += ' Regular';\n else str += ' Light';\n } else if(parts.slice(0, 3).join(' ') === 'Klokantech Noto Sans') {\n str = 'Klokantech Noto Sans';\n if(parts[3] === 'CJK') str += ' CJK';\n str += (weight > 500) ? ' Bold' : ' Regular';\n }\n }\n\n if(isItalic) str += ' Italic';\n\n if(str === 'Open Sans Regular Italic') str = 'Open Sans Italic';\n else if(str === 'Open Sans Regular Bold') str = 'Open Sans Bold';\n else if(str === 'Open Sans Regular Bold Italic') str = 'Open Sans Bold Italic';\n else if(str === 'Klokantech Noto Sans Regular Italic') str = 'Klokantech Noto Sans Italic';\n\n // Ensure the result is a supported font\n if(!isSupportedFont(str)) {\n str = family;\n }\n\n var textFont = str.split(', ');\n return textFont;\n}\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar subTypes = require('../scatter/subtypes');\nvar handleMarkerDefaults = require('../scatter/marker_defaults');\nvar handleLineDefaults = require('../scatter/line_defaults');\nvar handleTextDefaults = require('../scatter/text_defaults');\nvar handleFillColorDefaults = require('../scatter/fillcolor_defaults');\nvar attributes = require('./attributes');\nvar isSupportedFont = require('./constants').isSupportedFont;\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n function coerce2(attr, dflt) {\n return Lib.coerce2(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleLonLatDefaults(traceIn, traceOut, coerce);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n coerce('text');\n coerce('texttemplate');\n coerce('hovertext');\n coerce('hovertemplate');\n coerce('mode');\n coerce('below');\n\n if(subTypes.hasMarkers(traceOut)) {\n handleMarkerDefaults(traceIn, traceOut, defaultColor, layout, coerce, {noLine: true, noAngle: true});\n\n coerce('marker.allowoverlap');\n coerce('marker.angle');\n\n // array marker.size and marker.color are only supported with circles\n var marker = traceOut.marker;\n if(marker.symbol !== 'circle') {\n if(Lib.isArrayOrTypedArray(marker.size)) marker.size = marker.size[0];\n if(Lib.isArrayOrTypedArray(marker.color)) marker.color = marker.color[0];\n }\n }\n\n if(subTypes.hasLines(traceOut)) {\n handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce, {noDash: true});\n coerce('connectgaps');\n }\n\n var clusterMaxzoom = coerce2('cluster.maxzoom');\n var clusterStep = coerce2('cluster.step');\n var clusterColor = coerce2('cluster.color', (traceOut.marker && traceOut.marker.color) || defaultColor);\n var clusterSize = coerce2('cluster.size');\n var clusterOpacity = coerce2('cluster.opacity');\n\n var clusterEnabledDflt =\n clusterMaxzoom !== false ||\n clusterStep !== false ||\n clusterColor !== false ||\n clusterSize !== false ||\n clusterOpacity !== false;\n\n var clusterEnabled = coerce('cluster.enabled', clusterEnabledDflt);\n\n if(clusterEnabled || subTypes.hasText(traceOut)) {\n var layoutFontFamily = layout.font.family;\n\n handleTextDefaults(traceIn, traceOut, layout, coerce,\n {\n noSelect: true,\n noFontVariant: true,\n noFontShadow: true,\n noFontLineposition: true,\n noFontTextcase: true,\n font: {\n family: isSupportedFont(layoutFontFamily) ? layoutFontFamily : 'Open Sans Regular',\n weight: layout.font.weight,\n style: layout.font.style,\n size: layout.font.size,\n color: layout.font.color\n }\n });\n }\n\n coerce('fill');\n if(traceOut.fill !== 'none') {\n handleFillColorDefaults(traceIn, traceOut, defaultColor, coerce);\n }\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n\nfunction handleLonLatDefaults(traceIn, traceOut, coerce) {\n var lon = coerce('lon') || [];\n var lat = coerce('lat') || [];\n var len = Math.min(lon.length, lat.length);\n traceOut._length = len;\n\n return len;\n}\n","'use strict';\n\n\nmodule.exports = function eventData(out, pt) {\n out.lon = pt.lon;\n out.lat = pt.lat;\n\n return out;\n};\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\n\nmodule.exports = function formatLabels(cdi, trace, fullLayout) {\n var labels = {};\n\n var subplot = fullLayout[trace.subplot]._subplot;\n var ax = subplot.mockAxis;\n\n var lonlat = cdi.lonlat;\n labels.lonLabel = Axes.tickText(ax, ax.c2l(lonlat[0]), true).text;\n labels.latLabel = Axes.tickText(ax, ax.c2l(lonlat[1]), true).text;\n\n return labels;\n};\n","'use strict';\n\nvar Fx = require('../../components/fx');\nvar Lib = require('../../lib');\nvar getTraceColor = require('../scatter/get_trace_color');\nvar fillText = Lib.fillText;\nvar BADNUM = require('../../constants/numerical').BADNUM;\nvar LAYER_PREFIX = require('../../plots/map/constants').traceLayerPrefix;\n\nfunction hoverPoints(pointData, xval, yval) {\n var cd = pointData.cd;\n var trace = cd[0].trace;\n var xa = pointData.xa;\n var ya = pointData.ya;\n var subplot = pointData.subplot;\n var clusteredPointsIds = [];\n var layer = LAYER_PREFIX + trace.uid + '-circle';\n var hasCluster = trace.cluster && trace.cluster.enabled;\n\n if(hasCluster) {\n var elems = subplot.map.queryRenderedFeatures(null, {layers: [layer]});\n clusteredPointsIds = elems.map(function(elem) {return elem.id;});\n }\n\n // compute winding number about [-180, 180] globe\n var winding = (xval >= 0) ?\n Math.floor((xval + 180) / 360) :\n Math.ceil((xval - 180) / 360);\n\n // shift longitude to [-180, 180] to determine closest point\n var lonShift = winding * 360;\n var xval2 = xval - lonShift;\n\n function distFn(d) {\n var lonlat = d.lonlat;\n if(lonlat[0] === BADNUM) return Infinity;\n if(hasCluster && clusteredPointsIds.indexOf(d.i + 1) === -1) return Infinity;\n\n var lon = Lib.modHalf(lonlat[0], 360);\n var lat = lonlat[1];\n var pt = subplot.project([lon, lat]);\n var dx = pt.x - xa.c2p([xval2, lat]);\n var dy = pt.y - ya.c2p([lon, yval]);\n var rad = Math.max(3, d.mrc || 0);\n\n return Math.max(Math.sqrt(dx * dx + dy * dy) - rad, 1 - 3 / rad);\n }\n\n Fx.getClosest(cd, distFn, pointData);\n\n // skip the rest (for this trace) if we didn't find a close point\n if(pointData.index === false) return;\n\n var di = cd[pointData.index];\n var lonlat = di.lonlat;\n var lonlatShifted = [Lib.modHalf(lonlat[0], 360) + lonShift, lonlat[1]];\n\n // shift labels back to original winded globe\n var xc = xa.c2p(lonlatShifted);\n var yc = ya.c2p(lonlatShifted);\n var rad = di.mrc || 1;\n\n pointData.x0 = xc - rad;\n pointData.x1 = xc + rad;\n pointData.y0 = yc - rad;\n pointData.y1 = yc + rad;\n\n var fullLayout = {};\n fullLayout[trace.subplot] = {_subplot: subplot};\n var labels = trace._module.formatLabels(di, trace, fullLayout);\n pointData.lonLabel = labels.lonLabel;\n pointData.latLabel = labels.latLabel;\n\n pointData.color = getTraceColor(trace, di);\n pointData.extraText = getExtraText(trace, di, cd[0].t.labels);\n pointData.hovertemplate = trace.hovertemplate;\n\n return [pointData];\n}\n\nfunction getExtraText(trace, di, labels) {\n if(trace.hovertemplate) return;\n\n var hoverinfo = di.hi || trace.hoverinfo;\n var parts = hoverinfo.split('+');\n var isAll = parts.indexOf('all') !== -1;\n var hasLon = parts.indexOf('lon') !== -1;\n var hasLat = parts.indexOf('lat') !== -1;\n var lonlat = di.lonlat;\n var text = [];\n\n // TODO should we use a mock axis to format hover?\n // If so, we'll need to make precision be zoom-level dependent\n function format(v) {\n return v + '\\u00B0';\n }\n\n if(isAll || (hasLon && hasLat)) {\n text.push('(' + format(lonlat[1]) + ', ' + format(lonlat[0]) + ')');\n } else if(hasLon) {\n text.push(labels.lon + format(lonlat[0]));\n } else if(hasLat) {\n text.push(labels.lat + format(lonlat[1]));\n }\n\n if(isAll || parts.indexOf('text') !== -1) {\n fillText(di, trace, text);\n }\n\n return text.join('
');\n}\n\nmodule.exports = {\n hoverPoints: hoverPoints,\n getExtraText: getExtraText\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../scatter/marker_colorbar'),\n formatLabels: require('./format_labels'),\n calc: require('../scattergeo/calc'),\n plot: require('./plot'),\n hoverPoints: require('./hover').hoverPoints,\n eventData: require('./event_data'),\n selectPoints: require('./select'),\n\n styleOnSelect: function(_, cd) {\n if(cd) {\n var trace = cd[0].trace;\n trace._glTrace.update(cd);\n }\n },\n\n moduleType: 'trace',\n name: 'scattermap',\n basePlotModule: require('../../plots/map'),\n categories: ['map', 'gl', 'symbols', 'showLegend', 'scatter-like'],\n meta: {\n hrName: 'scatter_map',\n description: [\n 'The data visualized as scatter point, lines or marker symbols',\n 'on a MapLibre GL geographic map',\n 'is provided by longitude/latitude pairs in `lon` and `lat`.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar convert = require('./convert');\nvar LAYER_PREFIX = require('../../plots/map/constants').traceLayerPrefix;\nvar ORDER = {\n cluster: ['cluster', 'clusterCount', 'circle'],\n nonCluster: ['fill', 'line', 'circle', 'symbol'],\n};\n\nfunction ScatterMap(subplot, uid, clusterEnabled, isHidden) {\n this.type = 'scattermap';\n this.subplot = subplot;\n this.uid = uid;\n this.clusterEnabled = clusterEnabled;\n this.isHidden = isHidden;\n\n this.sourceIds = {\n fill: 'source-' + uid + '-fill',\n line: 'source-' + uid + '-line',\n circle: 'source-' + uid + '-circle',\n symbol: 'source-' + uid + '-symbol',\n cluster: 'source-' + uid + '-circle',\n clusterCount: 'source-' + uid + '-circle',\n };\n\n this.layerIds = {\n fill: LAYER_PREFIX + uid + '-fill',\n line: LAYER_PREFIX + uid + '-line',\n circle: LAYER_PREFIX + uid + '-circle',\n symbol: LAYER_PREFIX + uid + '-symbol',\n cluster: LAYER_PREFIX + uid + '-cluster',\n clusterCount: LAYER_PREFIX + uid + '-cluster-count',\n };\n\n // We could merge the 'fill' source with the 'line' source and\n // the 'circle' source with the 'symbol' source if ever having\n // for up-to 4 sources per 'scattermap' traces becomes a problem.\n\n // previous 'below' value,\n // need this to update it properly\n this.below = null;\n}\n\nvar proto = ScatterMap.prototype;\n\nproto.addSource = function(k, opts, cluster) {\n var sourceOpts = {\n type: 'geojson',\n data: opts.geojson,\n };\n\n if(cluster && cluster.enabled) {\n Lib.extendFlat(sourceOpts, {\n cluster: true,\n clusterMaxZoom: cluster.maxzoom,\n });\n }\n var isSourceExists = this.subplot.map.getSource(this.sourceIds[k]);\n if(isSourceExists) {\n isSourceExists.setData(opts.geojson);\n } else {\n this.subplot.map.addSource(this.sourceIds[k], sourceOpts);\n }\n};\n\nproto.setSourceData = function(k, opts) {\n this.subplot.map\n .getSource(this.sourceIds[k])\n .setData(opts.geojson);\n};\n\nproto.addLayer = function(k, opts, below) {\n var source = {\n type: opts.type,\n id: this.layerIds[k],\n source: this.sourceIds[k],\n layout: opts.layout,\n paint: opts.paint,\n };\n if(opts.filter) {\n source.filter = opts.filter;\n }\n var currentLayerId = this.layerIds[k];\n var layerExist;\n var layers = this.subplot.getMapLayers();\n for(var i = 0; i < layers.length; i++) {\n if(layers[i].id === currentLayerId) {\n layerExist = true;\n break;\n }\n }\n\n if(layerExist) {\n this.subplot.setOptions(currentLayerId, 'setLayoutProperty', source.layout);\n if(source.layout.visibility === 'visible') {\n this.subplot.setOptions(currentLayerId, 'setPaintProperty', source.paint);\n }\n } else {\n this.subplot.addLayer(source, below);\n }\n};\n\nproto.update = function update(calcTrace) {\n var trace = calcTrace[0].trace;\n var subplot = this.subplot;\n var map = subplot.map;\n var optsAll = convert(subplot.gd, calcTrace);\n var below = subplot.belowLookup['trace-' + this.uid];\n var hasCluster = !!(trace.cluster && trace.cluster.enabled);\n var hadCluster = !!this.clusterEnabled;\n var lThis = this;\n\n function addCluster(noSource) {\n if(!noSource) lThis.addSource('circle', optsAll.circle, trace.cluster);\n var order = ORDER.cluster;\n for(var i = 0; i < order.length; i++) {\n var k = order[i];\n var opts = optsAll[k];\n lThis.addLayer(k, opts, below);\n }\n }\n\n function removeCluster(noSource) {\n var order = ORDER.cluster;\n for(var i = order.length - 1; i >= 0; i--) {\n var k = order[i];\n map.removeLayer(lThis.layerIds[k]);\n }\n if(!noSource) map.removeSource(lThis.sourceIds.circle);\n }\n\n function addNonCluster(noSource) {\n var order = ORDER.nonCluster;\n for(var i = 0; i < order.length; i++) {\n var k = order[i];\n var opts = optsAll[k];\n if(!noSource) lThis.addSource(k, opts);\n lThis.addLayer(k, opts, below);\n }\n }\n\n function removeNonCluster(noSource) {\n var order = ORDER.nonCluster;\n for(var i = order.length - 1; i >= 0; i--) {\n var k = order[i];\n map.removeLayer(lThis.layerIds[k]);\n if(!noSource) map.removeSource(lThis.sourceIds[k]);\n }\n }\n\n function remove(noSource) {\n if(hadCluster) removeCluster(noSource); else removeNonCluster(noSource);\n }\n\n function add(noSource) {\n if(hasCluster) addCluster(noSource); else addNonCluster(noSource);\n }\n\n function repaint() {\n var order = hasCluster ? ORDER.cluster : ORDER.nonCluster;\n for(var i = 0; i < order.length; i++) {\n var k = order[i];\n var opts = optsAll[k];\n if(!opts) continue;\n\n subplot.setOptions(lThis.layerIds[k], 'setLayoutProperty', opts.layout);\n\n if(opts.layout.visibility === 'visible') {\n if(k !== 'cluster') {\n lThis.setSourceData(k, opts);\n }\n subplot.setOptions(lThis.layerIds[k], 'setPaintProperty', opts.paint);\n }\n }\n }\n\n var wasHidden = this.isHidden;\n var isHidden = trace.visible !== true;\n\n if(isHidden) {\n if(!wasHidden) remove();\n } else if(wasHidden) {\n if(!isHidden) add();\n } else if(hadCluster !== hasCluster) {\n remove();\n add();\n } else if(this.below !== below) {\n remove(true);\n add(true);\n repaint();\n } else {\n repaint();\n }\n\n this.clusterEnabled = hasCluster;\n this.isHidden = isHidden;\n this.below = below;\n\n // link ref for quick update during selections\n calcTrace[0].trace._glTrace = this;\n};\n\nproto.dispose = function dispose() {\n var map = this.subplot.map;\n var order = this.clusterEnabled ? ORDER.cluster : ORDER.nonCluster;\n for(var i = order.length - 1; i >= 0; i--) {\n var k = order[i];\n map.removeLayer(this.layerIds[k]);\n map.removeSource(this.sourceIds[k]);\n }\n};\n\nmodule.exports = function createScatterMap(subplot, calcTrace) {\n var trace = calcTrace[0].trace;\n var hasCluster = trace.cluster && trace.cluster.enabled;\n var isHidden = trace.visible !== true;\n\n var scatterMap = new ScatterMap(\n subplot,\n trace.uid,\n hasCluster,\n isHidden\n );\n\n var optsAll = convert(subplot.gd, calcTrace);\n var below = scatterMap.below = subplot.belowLookup['trace-' + trace.uid];\n var i, k, opts;\n\n if(hasCluster) {\n scatterMap.addSource('circle', optsAll.circle, trace.cluster);\n for(i = 0; i < ORDER.cluster.length; i++) {\n k = ORDER.cluster[i];\n opts = optsAll[k];\n scatterMap.addLayer(k, opts, below);\n }\n } else {\n for(i = 0; i < ORDER.nonCluster.length; i++) {\n k = ORDER.nonCluster[i];\n opts = optsAll[k];\n scatterMap.addSource(k, opts, trace.cluster);\n scatterMap.addLayer(k, opts, below);\n }\n }\n\n // link ref for quick update during selections\n calcTrace[0].trace._glTrace = scatterMap;\n\n return scatterMap;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar subtypes = require('../scatter/subtypes');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nmodule.exports = function selectPoints(searchInfo, selectionTester) {\n var cd = searchInfo.cd;\n var xa = searchInfo.xaxis;\n var ya = searchInfo.yaxis;\n var selection = [];\n var trace = cd[0].trace;\n var i;\n\n if(!subtypes.hasMarkers(trace)) return [];\n\n if(selectionTester === false) {\n for(i = 0; i < cd.length; i++) {\n cd[i].selected = 0;\n }\n } else {\n for(i = 0; i < cd.length; i++) {\n var di = cd[i];\n var lonlat = di.lonlat;\n\n if(lonlat[0] !== BADNUM) {\n var lonlat2 = [Lib.modHalf(lonlat[0], 360), lonlat[1]];\n var xy = [xa.c2p(lonlat2), ya.c2p(lonlat2)];\n\n if(selectionTester.contains(xy, null, i, searchInfo)) {\n selection.push({\n pointNumber: i,\n lon: lonlat[0],\n lat: lonlat[1]\n });\n di.selected = 1;\n } else {\n di.selected = 0;\n }\n }\n }\n }\n\n return selection;\n};\n","'use strict';\n\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar makeFillcolorAttr = require('../scatter/fillcolor_attribute');\nvar scatterGeoAttrs = require('../scattergeo/attributes');\nvar scatterAttrs = require('../scatter/attributes');\nvar mapboxAttrs = require('../../plots/mapbox/layout_attributes');\nvar baseAttrs = require('../../plots/attributes');\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar mapboxLayoutAtributes = require('../../plots/mapbox/layout_attributes');\n\nvar lineAttrs = scatterGeoAttrs.line;\nvar markerAttrs = scatterGeoAttrs.marker;\n\nmodule.exports = overrideAll({\n lon: scatterGeoAttrs.lon,\n lat: scatterGeoAttrs.lat,\n\n cluster: {\n enabled: {\n valType: 'boolean',\n description: 'Determines whether clustering is enabled or disabled.'\n },\n maxzoom: extendFlat({}, mapboxLayoutAtributes.layers.maxzoom, {\n description: [\n 'Sets the maximum zoom level.',\n 'At zoom levels equal to or greater than this, points will never be clustered.'\n ].join(' ')\n }),\n step: {\n valType: 'number',\n arrayOk: true,\n dflt: -1,\n min: -1,\n description: [\n 'Sets how many points it takes to create a cluster or advance to the next cluster step.',\n 'Use this in conjunction with arrays for `size` and / or `color`.',\n 'If an integer, steps start at multiples of this number.',\n 'If an array, each step extends from the given value until one less than the next value.'\n ].join(' ')\n },\n size: {\n valType: 'number',\n arrayOk: true,\n dflt: 20,\n min: 0,\n description: [\n 'Sets the size for each cluster step.'\n ].join(' ')\n },\n color: {\n valType: 'color',\n arrayOk: true,\n description: [\n 'Sets the color for each cluster step.'\n ].join(' ')\n },\n opacity: extendFlat({}, markerAttrs.opacity, {\n dflt: 1\n })\n },\n\n // locations\n // locationmode\n\n mode: extendFlat({}, scatterAttrs.mode, {\n dflt: 'markers',\n description: [\n 'Determines the drawing mode for this scatter trace.',\n 'If the provided `mode` includes *text* then the `text` elements',\n 'appear at the coordinates. Otherwise, the `text` elements',\n 'appear on hover.'\n ].join(' ')\n }),\n\n text: extendFlat({}, scatterAttrs.text, {\n description: [\n 'Sets text elements associated with each (lon,lat) pair',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s (lon,lat) coordinates.',\n 'If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,',\n 'these elements will be seen in the hover labels.'\n ].join(' ')\n }),\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: ['lat', 'lon', 'text']\n }),\n hovertext: extendFlat({}, scatterAttrs.hovertext, {\n description: [\n 'Sets hover text elements associated with each (lon,lat) pair',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s (lon,lat) coordinates.',\n 'To be seen, trace `hoverinfo` must contain a *text* flag.'\n ].join(' ')\n }),\n\n line: {\n color: lineAttrs.color,\n width: lineAttrs.width\n\n // TODO\n // dash: dash\n },\n\n connectgaps: scatterAttrs.connectgaps,\n\n marker: extendFlat({\n symbol: {\n valType: 'string',\n dflt: 'circle',\n arrayOk: true,\n description: [\n 'Sets the marker symbol.',\n 'Full list: https://www.mapbox.com/maki-icons/',\n 'Note that the array `marker.color` and `marker.size`',\n 'are only available for *circle* symbols.'\n ].join(' ')\n },\n angle: {\n valType: 'number',\n dflt: 'auto',\n arrayOk: true,\n description: [\n 'Sets the marker orientation from true North, in degrees clockwise.',\n 'When using the *auto* default, no rotation would be applied',\n 'in perspective views which is different from using a zero angle.'\n ].join(' ')\n },\n allowoverlap: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Flag to draw all symbols, even if they overlap.'\n ].join(' ')\n },\n opacity: markerAttrs.opacity,\n size: markerAttrs.size,\n sizeref: markerAttrs.sizeref,\n sizemin: markerAttrs.sizemin,\n sizemode: markerAttrs.sizemode\n },\n colorScaleAttrs('marker')\n // line\n ),\n\n fill: scatterGeoAttrs.fill,\n fillcolor: makeFillcolorAttr(),\n\n textfont: mapboxAttrs.layers.symbol.textfont,\n textposition: mapboxAttrs.layers.symbol.textposition,\n\n below: {\n valType: 'string',\n description: [\n 'Determines if this scattermapbox trace\\'s layers are to be inserted',\n 'before the layer with the specified ID.',\n 'By default, scattermapbox layers are inserted',\n 'above all the base layers.',\n 'To place the scattermapbox layers above every other layer, set `below` to *\\'\\'*.'\n ].join(' ')\n },\n\n selected: {\n marker: scatterAttrs.selected.marker\n },\n unselected: {\n marker: scatterAttrs.unselected.marker\n },\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['lon', 'lat', 'text', 'name']\n }),\n hovertemplate: hovertemplateAttrs(),\n}, 'calc', 'nested');\n","'use strict';\n\n// Must use one of the following fonts as the family, else default to 'Open Sans Regular'\n// See https://github.com/openmaptiles/fonts/blob/gh-pages/fontstacks.json\nvar supportedFonts = [\n 'Metropolis Black Italic',\n 'Metropolis Black',\n 'Metropolis Bold Italic',\n 'Metropolis Bold',\n 'Metropolis Extra Bold Italic',\n 'Metropolis Extra Bold',\n 'Metropolis Extra Light Italic',\n 'Metropolis Extra Light',\n 'Metropolis Light Italic',\n 'Metropolis Light',\n 'Metropolis Medium Italic',\n 'Metropolis Medium',\n 'Metropolis Regular Italic',\n 'Metropolis Regular',\n 'Metropolis Semi Bold Italic',\n 'Metropolis Semi Bold',\n 'Metropolis Thin Italic',\n 'Metropolis Thin',\n 'Open Sans Bold Italic',\n 'Open Sans Bold',\n 'Open Sans Extrabold Italic',\n 'Open Sans Extrabold',\n 'Open Sans Italic',\n 'Open Sans Light Italic',\n 'Open Sans Light',\n 'Open Sans Regular',\n 'Open Sans Semibold Italic',\n 'Open Sans Semibold',\n 'Klokantech Noto Sans Bold',\n 'Klokantech Noto Sans CJK Bold',\n 'Klokantech Noto Sans CJK Regular',\n 'Klokantech Noto Sans Italic',\n 'Klokantech Noto Sans Regular'\n];\n\nmodule.exports = {\n isSupportedFont: function(a) {\n return supportedFonts.indexOf(a) !== -1;\n }\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar BADNUM = require('../../constants/numerical').BADNUM;\nvar geoJsonUtils = require('../../lib/geojson_utils');\n\nvar Colorscale = require('../../components/colorscale');\nvar Drawing = require('../../components/drawing');\nvar makeBubbleSizeFn = require('../scatter/make_bubble_size_func');\nvar subTypes = require('../scatter/subtypes');\nvar isSupportedFont = require('./constants').isSupportedFont;\nvar convertTextOpts = require('../../plots/mapbox/convert_text_opts');\nvar appendArrayPointValue = require('../../components/fx/helpers').appendArrayPointValue;\n\nvar NEWLINES = require('../../lib/svg_text_utils').NEWLINES;\nvar BR_TAG_ALL = require('../../lib/svg_text_utils').BR_TAG_ALL;\n\nmodule.exports = function convert(gd, calcTrace) {\n var trace = calcTrace[0].trace;\n\n var isVisible = (trace.visible === true && trace._length !== 0);\n var hasFill = (trace.fill !== 'none');\n var hasLines = subTypes.hasLines(trace);\n var hasMarkers = subTypes.hasMarkers(trace);\n var hasText = subTypes.hasText(trace);\n var hasCircles = (hasMarkers && trace.marker.symbol === 'circle');\n var hasSymbols = (hasMarkers && trace.marker.symbol !== 'circle');\n var hasCluster = trace.cluster && trace.cluster.enabled;\n\n var fill = initContainer('fill');\n var line = initContainer('line');\n var circle = initContainer('circle');\n var symbol = initContainer('symbol');\n\n var opts = {\n fill: fill,\n line: line,\n circle: circle,\n symbol: symbol\n };\n\n // early return if not visible or placeholder\n if(!isVisible) return opts;\n\n // fill layer and line layer use the same coords\n var lineCoords;\n if(hasFill || hasLines) {\n lineCoords = geoJsonUtils.calcTraceToLineCoords(calcTrace);\n }\n\n if(hasFill) {\n fill.geojson = geoJsonUtils.makePolygon(lineCoords);\n fill.layout.visibility = 'visible';\n\n Lib.extendFlat(fill.paint, {\n 'fill-color': trace.fillcolor\n });\n }\n\n if(hasLines) {\n line.geojson = geoJsonUtils.makeLine(lineCoords);\n line.layout.visibility = 'visible';\n\n Lib.extendFlat(line.paint, {\n 'line-width': trace.line.width,\n 'line-color': trace.line.color,\n 'line-opacity': trace.opacity\n });\n\n // TODO convert line.dash into line-dasharray\n }\n\n if(hasCircles) {\n var circleOpts = makeCircleOpts(calcTrace);\n circle.geojson = circleOpts.geojson;\n circle.layout.visibility = 'visible';\n if(hasCluster) {\n circle.filter = ['!', ['has', 'point_count']];\n opts.cluster = {\n type: 'circle',\n filter: ['has', 'point_count'],\n layout: {visibility: 'visible'},\n paint: {\n 'circle-color': arrayifyAttribute(trace.cluster.color, trace.cluster.step),\n 'circle-radius': arrayifyAttribute(trace.cluster.size, trace.cluster.step),\n 'circle-opacity': arrayifyAttribute(trace.cluster.opacity, trace.cluster.step),\n },\n };\n opts.clusterCount = {\n type: 'symbol',\n filter: ['has', 'point_count'],\n paint: {},\n layout: {\n 'text-field': '{point_count_abbreviated}',\n 'text-font': getTextFont(trace),\n 'text-size': 12\n }\n };\n }\n\n Lib.extendFlat(circle.paint, {\n 'circle-color': circleOpts.mcc,\n 'circle-radius': circleOpts.mrc,\n 'circle-opacity': circleOpts.mo\n });\n }\n\n if(hasCircles && hasCluster) {\n circle.filter = ['!', ['has', 'point_count']];\n }\n\n if(hasSymbols || hasText) {\n symbol.geojson = makeSymbolGeoJSON(calcTrace, gd);\n\n Lib.extendFlat(symbol.layout, {\n visibility: 'visible',\n 'icon-image': '{symbol}-15',\n 'text-field': '{text}'\n });\n\n if(hasSymbols) {\n Lib.extendFlat(symbol.layout, {\n 'icon-size': trace.marker.size / 10\n });\n\n if('angle' in trace.marker && trace.marker.angle !== 'auto') {\n Lib.extendFlat(symbol.layout, {\n // unfortunately cant use {angle} do to this issue:\n // https://github.com/mapbox/mapbox-gl-js/issues/873\n 'icon-rotate': {\n type: 'identity', property: 'angle'\n },\n 'icon-rotation-alignment': 'map'\n });\n }\n\n symbol.layout['icon-allow-overlap'] = trace.marker.allowoverlap;\n\n Lib.extendFlat(symbol.paint, {\n 'icon-opacity': trace.opacity * trace.marker.opacity,\n\n // TODO does not work ??\n 'icon-color': trace.marker.color\n });\n }\n\n if(hasText) {\n var iconSize = (trace.marker || {}).size;\n var textOpts = convertTextOpts(trace.textposition, iconSize);\n\n // all data-driven below !!\n\n Lib.extendFlat(symbol.layout, {\n 'text-size': trace.textfont.size,\n 'text-anchor': textOpts.anchor,\n 'text-offset': textOpts.offset,\n 'text-font': getTextFont(trace)\n });\n\n Lib.extendFlat(symbol.paint, {\n 'text-color': trace.textfont.color,\n 'text-opacity': trace.opacity\n });\n }\n }\n\n return opts;\n};\n\nfunction initContainer(type) {\n return {\n type: type,\n geojson: geoJsonUtils.makeBlank(),\n layout: { visibility: 'none' },\n filter: null,\n paint: {}\n };\n}\n\nfunction makeCircleOpts(calcTrace) {\n var trace = calcTrace[0].trace;\n var marker = trace.marker;\n var selectedpoints = trace.selectedpoints;\n var arrayColor = Lib.isArrayOrTypedArray(marker.color);\n var arraySize = Lib.isArrayOrTypedArray(marker.size);\n var arrayOpacity = Lib.isArrayOrTypedArray(marker.opacity);\n var i;\n\n function addTraceOpacity(o) { return trace.opacity * o; }\n\n function size2radius(s) { return s / 2; }\n\n var colorFn;\n if(arrayColor) {\n if(Colorscale.hasColorscale(trace, 'marker')) {\n colorFn = Colorscale.makeColorScaleFuncFromTrace(marker);\n } else {\n colorFn = Lib.identity;\n }\n }\n\n var sizeFn;\n if(arraySize) {\n sizeFn = makeBubbleSizeFn(trace);\n }\n\n var opacityFn;\n if(arrayOpacity) {\n opacityFn = function(mo) {\n var mo2 = isNumeric(mo) ? +Lib.constrain(mo, 0, 1) : 0;\n return addTraceOpacity(mo2);\n };\n }\n\n var features = [];\n for(i = 0; i < calcTrace.length; i++) {\n var calcPt = calcTrace[i];\n var lonlat = calcPt.lonlat;\n\n if(isBADNUM(lonlat)) continue;\n\n var props = {};\n if(colorFn) props.mcc = calcPt.mcc = colorFn(calcPt.mc);\n if(sizeFn) props.mrc = calcPt.mrc = sizeFn(calcPt.ms);\n if(opacityFn) props.mo = opacityFn(calcPt.mo);\n if(selectedpoints) props.selected = calcPt.selected || 0;\n\n features.push({\n type: 'Feature',\n id: i + 1,\n geometry: { type: 'Point', coordinates: lonlat },\n properties: props\n });\n }\n\n var fns;\n if(selectedpoints) {\n fns = Drawing.makeSelectedPointStyleFns(trace);\n\n for(i = 0; i < features.length; i++) {\n var d = features[i].properties;\n\n if(fns.selectedOpacityFn) {\n d.mo = addTraceOpacity(fns.selectedOpacityFn(d));\n }\n if(fns.selectedColorFn) {\n d.mcc = fns.selectedColorFn(d);\n }\n if(fns.selectedSizeFn) {\n d.mrc = fns.selectedSizeFn(d);\n }\n }\n }\n\n return {\n geojson: {type: 'FeatureCollection', features: features},\n mcc: arrayColor || (fns && fns.selectedColorFn) ?\n {type: 'identity', property: 'mcc'} :\n marker.color,\n mrc: arraySize || (fns && fns.selectedSizeFn) ?\n {type: 'identity', property: 'mrc'} :\n size2radius(marker.size),\n mo: arrayOpacity || (fns && fns.selectedOpacityFn) ?\n {type: 'identity', property: 'mo'} :\n addTraceOpacity(marker.opacity)\n };\n}\n\nfunction makeSymbolGeoJSON(calcTrace, gd) {\n var fullLayout = gd._fullLayout;\n var trace = calcTrace[0].trace;\n\n var marker = trace.marker || {};\n var symbol = marker.symbol;\n var angle = marker.angle;\n\n var fillSymbol = (symbol !== 'circle') ?\n getFillFunc(symbol) :\n blankFillFunc;\n\n var fillAngle = (angle !== 'auto') ?\n getFillFunc(angle, true) :\n blankFillFunc;\n\n var fillText = subTypes.hasText(trace) ?\n getFillFunc(trace.text) :\n blankFillFunc;\n\n\n var features = [];\n\n for(var i = 0; i < calcTrace.length; i++) {\n var calcPt = calcTrace[i];\n\n if(isBADNUM(calcPt.lonlat)) continue;\n\n var texttemplate = trace.texttemplate;\n var text;\n\n if(texttemplate) {\n var tt = Array.isArray(texttemplate) ? (texttemplate[i] || '') : texttemplate;\n var labels = trace._module.formatLabels(calcPt, trace, fullLayout);\n var pointValues = {};\n appendArrayPointValue(pointValues, trace, calcPt.i);\n var meta = trace._meta || {};\n text = Lib.texttemplateString(tt, labels, fullLayout._d3locale, pointValues, calcPt, meta);\n } else {\n text = fillText(i);\n }\n\n if(text) {\n text = text.replace(NEWLINES, '').replace(BR_TAG_ALL, '\\n');\n }\n\n features.push({\n type: 'Feature',\n geometry: {\n type: 'Point',\n coordinates: calcPt.lonlat\n },\n properties: {\n symbol: fillSymbol(i),\n angle: fillAngle(i),\n text: text\n }\n });\n }\n\n return {\n type: 'FeatureCollection',\n features: features\n };\n}\n\nfunction getFillFunc(attr, numeric) {\n if(Lib.isArrayOrTypedArray(attr)) {\n if(numeric) {\n return function(i) { return isNumeric(attr[i]) ? +attr[i] : 0; };\n }\n return function(i) { return attr[i]; };\n } else if(attr) {\n return function() { return attr; };\n } else {\n return blankFillFunc;\n }\n}\n\nfunction blankFillFunc() { return ''; }\n\n// only need to check lon (OR lat)\nfunction isBADNUM(lonlat) {\n return lonlat[0] === BADNUM;\n}\n\nfunction arrayifyAttribute(values, step) {\n var newAttribute;\n if(Lib.isArrayOrTypedArray(values) && Lib.isArrayOrTypedArray(step)) {\n newAttribute = ['step', ['get', 'point_count'], values[0]];\n\n for(var idx = 1; idx < values.length; idx++) {\n newAttribute.push(step[idx - 1], values[idx]);\n }\n } else {\n newAttribute = values;\n }\n return newAttribute;\n}\n\nfunction getTextFont(trace) {\n var font = trace.textfont;\n var family = font.family;\n var style = font.style;\n var weight = font.weight;\n\n var parts = family.split(' ');\n var isItalic = parts[parts.length - 1] === 'Italic';\n if(isItalic) parts.pop();\n isItalic = isItalic || style === 'italic';\n\n var str = parts.join(' ');\n if(weight === 'bold' && parts.indexOf('Bold') === -1) {\n str += ' Bold';\n } else if(weight <= 1000) { // numeric font-weight\n // See supportedFonts\n\n if(parts[0] === 'Metropolis') {\n str = 'Metropolis';\n if(weight > 850) str += ' Black';\n else if(weight > 750) str += ' Extra Bold';\n else if(weight > 650) str += ' Bold';\n else if(weight > 550) str += ' Semi Bold';\n else if(weight > 450) str += ' Medium';\n else if(weight > 350) str += ' Regular';\n else if(weight > 250) str += ' Light';\n else if(weight > 150) str += ' Extra Light';\n else str += ' Thin';\n } else if(parts.slice(0, 2).join(' ') === 'Open Sans') {\n str = 'Open Sans';\n if(weight > 750) str += ' Extrabold';\n else if(weight > 650) str += ' Bold';\n else if(weight > 550) str += ' Semibold';\n else if(weight > 350) str += ' Regular';\n else str += ' Light';\n } else if(parts.slice(0, 3).join(' ') === 'Klokantech Noto Sans') {\n str = 'Klokantech Noto Sans';\n if(parts[3] === 'CJK') str += ' CJK';\n str += (weight > 500) ? ' Bold' : ' Regular';\n }\n }\n\n if(isItalic) str += ' Italic';\n\n if(str === 'Open Sans Regular Italic') str = 'Open Sans Italic';\n else if(str === 'Open Sans Regular Bold') str = 'Open Sans Bold';\n else if(str === 'Open Sans Regular Bold Italic') str = 'Open Sans Bold Italic';\n else if(str === 'Klokantech Noto Sans Regular Italic') str = 'Klokantech Noto Sans Italic';\n\n // Ensure the result is a supported font\n if(!isSupportedFont(str)) {\n str = family;\n }\n\n var textFont = str.split(', ');\n return textFont;\n}\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar subTypes = require('../scatter/subtypes');\nvar handleMarkerDefaults = require('../scatter/marker_defaults');\nvar handleLineDefaults = require('../scatter/line_defaults');\nvar handleTextDefaults = require('../scatter/text_defaults');\nvar handleFillColorDefaults = require('../scatter/fillcolor_defaults');\nvar attributes = require('./attributes');\nvar isSupportedFont = require('./constants').isSupportedFont;\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n function coerce2(attr, dflt) {\n return Lib.coerce2(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleLonLatDefaults(traceIn, traceOut, coerce);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n coerce('text');\n coerce('texttemplate');\n coerce('hovertext');\n coerce('hovertemplate');\n coerce('mode');\n coerce('below');\n\n if(subTypes.hasMarkers(traceOut)) {\n handleMarkerDefaults(traceIn, traceOut, defaultColor, layout, coerce, {noLine: true, noAngle: true});\n\n coerce('marker.allowoverlap');\n coerce('marker.angle');\n\n // array marker.size and marker.color are only supported with circles\n var marker = traceOut.marker;\n if(marker.symbol !== 'circle') {\n if(Lib.isArrayOrTypedArray(marker.size)) marker.size = marker.size[0];\n if(Lib.isArrayOrTypedArray(marker.color)) marker.color = marker.color[0];\n }\n }\n\n if(subTypes.hasLines(traceOut)) {\n handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce, {noDash: true});\n coerce('connectgaps');\n }\n\n var clusterMaxzoom = coerce2('cluster.maxzoom');\n var clusterStep = coerce2('cluster.step');\n var clusterColor = coerce2('cluster.color', (traceOut.marker && traceOut.marker.color) || defaultColor);\n var clusterSize = coerce2('cluster.size');\n var clusterOpacity = coerce2('cluster.opacity');\n\n var clusterEnabledDflt =\n clusterMaxzoom !== false ||\n clusterStep !== false ||\n clusterColor !== false ||\n clusterSize !== false ||\n clusterOpacity !== false;\n\n var clusterEnabled = coerce('cluster.enabled', clusterEnabledDflt);\n\n if(clusterEnabled || subTypes.hasText(traceOut)) {\n var layoutFontFamily = layout.font.family;\n\n handleTextDefaults(traceIn, traceOut, layout, coerce,\n {\n noSelect: true,\n noFontVariant: true,\n noFontShadow: true,\n noFontLineposition: true,\n noFontTextcase: true,\n font: {\n family: isSupportedFont(layoutFontFamily) ? layoutFontFamily : 'Open Sans Regular',\n weight: layout.font.weight,\n style: layout.font.style,\n size: layout.font.size,\n color: layout.font.color\n }\n });\n }\n\n coerce('fill');\n if(traceOut.fill !== 'none') {\n handleFillColorDefaults(traceIn, traceOut, defaultColor, coerce);\n }\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n\nfunction handleLonLatDefaults(traceIn, traceOut, coerce) {\n var lon = coerce('lon') || [];\n var lat = coerce('lat') || [];\n var len = Math.min(lon.length, lat.length);\n traceOut._length = len;\n\n return len;\n}\n","'use strict';\n\n\nmodule.exports = function eventData(out, pt) {\n out.lon = pt.lon;\n out.lat = pt.lat;\n\n return out;\n};\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\n\nmodule.exports = function formatLabels(cdi, trace, fullLayout) {\n var labels = {};\n\n var subplot = fullLayout[trace.subplot]._subplot;\n var ax = subplot.mockAxis;\n\n var lonlat = cdi.lonlat;\n labels.lonLabel = Axes.tickText(ax, ax.c2l(lonlat[0]), true).text;\n labels.latLabel = Axes.tickText(ax, ax.c2l(lonlat[1]), true).text;\n\n return labels;\n};\n","'use strict';\n\nvar Fx = require('../../components/fx');\nvar Lib = require('../../lib');\nvar getTraceColor = require('../scatter/get_trace_color');\nvar fillText = Lib.fillText;\nvar BADNUM = require('../../constants/numerical').BADNUM;\nvar LAYER_PREFIX = require('../../plots/mapbox/constants').traceLayerPrefix;\n\nfunction hoverPoints(pointData, xval, yval) {\n var cd = pointData.cd;\n var trace = cd[0].trace;\n var xa = pointData.xa;\n var ya = pointData.ya;\n var subplot = pointData.subplot;\n var clusteredPointsIds = [];\n var layer = LAYER_PREFIX + trace.uid + '-circle';\n var hasCluster = trace.cluster && trace.cluster.enabled;\n\n if(hasCluster) {\n var elems = subplot.map.queryRenderedFeatures(null, {layers: [layer]});\n clusteredPointsIds = elems.map(function(elem) {return elem.id;});\n }\n\n // compute winding number about [-180, 180] globe\n var winding = (xval >= 0) ?\n Math.floor((xval + 180) / 360) :\n Math.ceil((xval - 180) / 360);\n\n // shift longitude to [-180, 180] to determine closest point\n var lonShift = winding * 360;\n var xval2 = xval - lonShift;\n\n function distFn(d) {\n var lonlat = d.lonlat;\n if(lonlat[0] === BADNUM) return Infinity;\n if(hasCluster && clusteredPointsIds.indexOf(d.i + 1) === -1) return Infinity;\n\n var lon = Lib.modHalf(lonlat[0], 360);\n var lat = lonlat[1];\n var pt = subplot.project([lon, lat]);\n var dx = pt.x - xa.c2p([xval2, lat]);\n var dy = pt.y - ya.c2p([lon, yval]);\n var rad = Math.max(3, d.mrc || 0);\n\n return Math.max(Math.sqrt(dx * dx + dy * dy) - rad, 1 - 3 / rad);\n }\n\n Fx.getClosest(cd, distFn, pointData);\n\n // skip the rest (for this trace) if we didn't find a close point\n if(pointData.index === false) return;\n\n var di = cd[pointData.index];\n var lonlat = di.lonlat;\n var lonlatShifted = [Lib.modHalf(lonlat[0], 360) + lonShift, lonlat[1]];\n\n // shift labels back to original winded globe\n var xc = xa.c2p(lonlatShifted);\n var yc = ya.c2p(lonlatShifted);\n var rad = di.mrc || 1;\n\n pointData.x0 = xc - rad;\n pointData.x1 = xc + rad;\n pointData.y0 = yc - rad;\n pointData.y1 = yc + rad;\n\n var fullLayout = {};\n fullLayout[trace.subplot] = {_subplot: subplot};\n var labels = trace._module.formatLabels(di, trace, fullLayout);\n pointData.lonLabel = labels.lonLabel;\n pointData.latLabel = labels.latLabel;\n\n pointData.color = getTraceColor(trace, di);\n pointData.extraText = getExtraText(trace, di, cd[0].t.labels);\n pointData.hovertemplate = trace.hovertemplate;\n\n return [pointData];\n}\n\nfunction getExtraText(trace, di, labels) {\n if(trace.hovertemplate) return;\n\n var hoverinfo = di.hi || trace.hoverinfo;\n var parts = hoverinfo.split('+');\n var isAll = parts.indexOf('all') !== -1;\n var hasLon = parts.indexOf('lon') !== -1;\n var hasLat = parts.indexOf('lat') !== -1;\n var lonlat = di.lonlat;\n var text = [];\n\n // TODO should we use a mock axis to format hover?\n // If so, we'll need to make precision be zoom-level dependent\n function format(v) {\n return v + '\\u00B0';\n }\n\n if(isAll || (hasLon && hasLat)) {\n text.push('(' + format(lonlat[1]) + ', ' + format(lonlat[0]) + ')');\n } else if(hasLon) {\n text.push(labels.lon + format(lonlat[0]));\n } else if(hasLat) {\n text.push(labels.lat + format(lonlat[1]));\n }\n\n if(isAll || parts.indexOf('text') !== -1) {\n fillText(di, trace, text);\n }\n\n return text.join('
');\n}\n\nmodule.exports = {\n hoverPoints: hoverPoints,\n getExtraText: getExtraText\n};\n","'use strict';\n\nvar deprecationWarning = [\n '*scattermapbox* trace is deprecated!',\n 'Please consider switching to the *scattermap* trace type and `map` subplots.',\n 'Learn more at: https://plotly.com/javascript/maplibre-migration/'\n].join(' ');\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../scatter/marker_colorbar'),\n formatLabels: require('./format_labels'),\n calc: require('../scattergeo/calc'),\n plot: require('./plot'),\n hoverPoints: require('./hover').hoverPoints,\n eventData: require('./event_data'),\n selectPoints: require('./select'),\n\n styleOnSelect: function(_, cd) {\n if(cd) {\n var trace = cd[0].trace;\n trace._glTrace.update(cd);\n }\n },\n\n moduleType: 'trace',\n name: 'scattermapbox',\n basePlotModule: require('../../plots/mapbox'),\n categories: ['mapbox', 'gl', 'symbols', 'showLegend', 'scatter-like'],\n meta: {\n hrName: 'scatter_mapbox',\n description: [\n deprecationWarning,\n 'The data visualized as scatter point, lines or marker symbols',\n 'on a Mapbox GL geographic map',\n 'is provided by longitude/latitude pairs in `lon` and `lat`.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar convert = require('./convert');\nvar LAYER_PREFIX = require('../../plots/mapbox/constants').traceLayerPrefix;\nvar ORDER = {\n cluster: ['cluster', 'clusterCount', 'circle'],\n nonCluster: ['fill', 'line', 'circle', 'symbol'],\n};\n\nfunction ScatterMapbox(subplot, uid, clusterEnabled, isHidden) {\n this.type = 'scattermapbox';\n this.subplot = subplot;\n this.uid = uid;\n this.clusterEnabled = clusterEnabled;\n this.isHidden = isHidden;\n\n this.sourceIds = {\n fill: 'source-' + uid + '-fill',\n line: 'source-' + uid + '-line',\n circle: 'source-' + uid + '-circle',\n symbol: 'source-' + uid + '-symbol',\n cluster: 'source-' + uid + '-circle',\n clusterCount: 'source-' + uid + '-circle',\n };\n\n this.layerIds = {\n fill: LAYER_PREFIX + uid + '-fill',\n line: LAYER_PREFIX + uid + '-line',\n circle: LAYER_PREFIX + uid + '-circle',\n symbol: LAYER_PREFIX + uid + '-symbol',\n cluster: LAYER_PREFIX + uid + '-cluster',\n clusterCount: LAYER_PREFIX + uid + '-cluster-count',\n };\n\n // We could merge the 'fill' source with the 'line' source and\n // the 'circle' source with the 'symbol' source if ever having\n // for up-to 4 sources per 'scattermapbox' traces becomes a problem.\n\n // previous 'below' value,\n // need this to update it properly\n this.below = null;\n}\n\nvar proto = ScatterMapbox.prototype;\n\nproto.addSource = function(k, opts, cluster) {\n var sourceOpts = {\n type: 'geojson',\n data: opts.geojson,\n };\n\n if(cluster && cluster.enabled) {\n Lib.extendFlat(sourceOpts, {\n cluster: true,\n clusterMaxZoom: cluster.maxzoom,\n });\n }\n var isSourceExists = this.subplot.map.getSource(this.sourceIds[k]);\n if(isSourceExists) {\n isSourceExists.setData(opts.geojson);\n } else {\n this.subplot.map.addSource(this.sourceIds[k], sourceOpts);\n }\n};\n\nproto.setSourceData = function(k, opts) {\n this.subplot.map\n .getSource(this.sourceIds[k])\n .setData(opts.geojson);\n};\n\nproto.addLayer = function(k, opts, below) {\n var source = {\n type: opts.type,\n id: this.layerIds[k],\n source: this.sourceIds[k],\n layout: opts.layout,\n paint: opts.paint,\n };\n if(opts.filter) {\n source.filter = opts.filter;\n }\n var currentLayerId = this.layerIds[k];\n var layerExist;\n var layers = this.subplot.getMapLayers();\n for(var i = 0; i < layers.length; i++) {\n if(layers[i].id === currentLayerId) {\n layerExist = true;\n break;\n }\n }\n\n if(layerExist) {\n this.subplot.setOptions(currentLayerId, 'setLayoutProperty', source.layout);\n if(source.layout.visibility === 'visible') {\n this.subplot.setOptions(currentLayerId, 'setPaintProperty', source.paint);\n }\n } else {\n this.subplot.addLayer(source, below);\n }\n};\n\nproto.update = function update(calcTrace) {\n var trace = calcTrace[0].trace;\n var subplot = this.subplot;\n var map = subplot.map;\n var optsAll = convert(subplot.gd, calcTrace);\n var below = subplot.belowLookup['trace-' + this.uid];\n var hasCluster = !!(trace.cluster && trace.cluster.enabled);\n var hadCluster = !!this.clusterEnabled;\n var lThis = this;\n\n function addCluster(noSource) {\n if(!noSource) lThis.addSource('circle', optsAll.circle, trace.cluster);\n var order = ORDER.cluster;\n for(var i = 0; i < order.length; i++) {\n var k = order[i];\n var opts = optsAll[k];\n lThis.addLayer(k, opts, below);\n }\n }\n\n function removeCluster(noSource) {\n var order = ORDER.cluster;\n for(var i = order.length - 1; i >= 0; i--) {\n var k = order[i];\n map.removeLayer(lThis.layerIds[k]);\n }\n if(!noSource) map.removeSource(lThis.sourceIds.circle);\n }\n\n function addNonCluster(noSource) {\n var order = ORDER.nonCluster;\n for(var i = 0; i < order.length; i++) {\n var k = order[i];\n var opts = optsAll[k];\n if(!noSource) lThis.addSource(k, opts);\n lThis.addLayer(k, opts, below);\n }\n }\n\n function removeNonCluster(noSource) {\n var order = ORDER.nonCluster;\n for(var i = order.length - 1; i >= 0; i--) {\n var k = order[i];\n map.removeLayer(lThis.layerIds[k]);\n if(!noSource) map.removeSource(lThis.sourceIds[k]);\n }\n }\n\n function remove(noSource) {\n if(hadCluster) removeCluster(noSource); else removeNonCluster(noSource);\n }\n\n function add(noSource) {\n if(hasCluster) addCluster(noSource); else addNonCluster(noSource);\n }\n\n function repaint() {\n var order = hasCluster ? ORDER.cluster : ORDER.nonCluster;\n for(var i = 0; i < order.length; i++) {\n var k = order[i];\n var opts = optsAll[k];\n if(!opts) continue;\n\n subplot.setOptions(lThis.layerIds[k], 'setLayoutProperty', opts.layout);\n\n if(opts.layout.visibility === 'visible') {\n if(k !== 'cluster') {\n lThis.setSourceData(k, opts);\n }\n subplot.setOptions(lThis.layerIds[k], 'setPaintProperty', opts.paint);\n }\n }\n }\n\n var wasHidden = this.isHidden;\n var isHidden = trace.visible !== true;\n\n if(isHidden) {\n if(!wasHidden) remove();\n } else if(wasHidden) {\n if(!isHidden) add();\n } else if(hadCluster !== hasCluster) {\n remove();\n add();\n } else if(this.below !== below) {\n remove(true);\n add(true);\n repaint();\n } else {\n repaint();\n }\n\n this.clusterEnabled = hasCluster;\n this.isHidden = isHidden;\n this.below = below;\n\n // link ref for quick update during selections\n calcTrace[0].trace._glTrace = this;\n};\n\nproto.dispose = function dispose() {\n var map = this.subplot.map;\n var order = this.clusterEnabled ? ORDER.cluster : ORDER.nonCluster;\n for(var i = order.length - 1; i >= 0; i--) {\n var k = order[i];\n map.removeLayer(this.layerIds[k]);\n map.removeSource(this.sourceIds[k]);\n }\n};\n\nmodule.exports = function createScatterMapbox(subplot, calcTrace) {\n var trace = calcTrace[0].trace;\n var hasCluster = trace.cluster && trace.cluster.enabled;\n var isHidden = trace.visible !== true;\n\n var scatterMapbox = new ScatterMapbox(\n subplot,\n trace.uid,\n hasCluster,\n isHidden\n );\n\n var optsAll = convert(subplot.gd, calcTrace);\n var below = scatterMapbox.below = subplot.belowLookup['trace-' + trace.uid];\n var i, k, opts;\n\n if(hasCluster) {\n scatterMapbox.addSource('circle', optsAll.circle, trace.cluster);\n for(i = 0; i < ORDER.cluster.length; i++) {\n k = ORDER.cluster[i];\n opts = optsAll[k];\n scatterMapbox.addLayer(k, opts, below);\n }\n } else {\n for(i = 0; i < ORDER.nonCluster.length; i++) {\n k = ORDER.nonCluster[i];\n opts = optsAll[k];\n scatterMapbox.addSource(k, opts, trace.cluster);\n scatterMapbox.addLayer(k, opts, below);\n }\n }\n\n // link ref for quick update during selections\n calcTrace[0].trace._glTrace = scatterMapbox;\n\n return scatterMapbox;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar subtypes = require('../scatter/subtypes');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nmodule.exports = function selectPoints(searchInfo, selectionTester) {\n var cd = searchInfo.cd;\n var xa = searchInfo.xaxis;\n var ya = searchInfo.yaxis;\n var selection = [];\n var trace = cd[0].trace;\n var i;\n\n if(!subtypes.hasMarkers(trace)) return [];\n\n if(selectionTester === false) {\n for(i = 0; i < cd.length; i++) {\n cd[i].selected = 0;\n }\n } else {\n for(i = 0; i < cd.length; i++) {\n var di = cd[i];\n var lonlat = di.lonlat;\n\n if(lonlat[0] !== BADNUM) {\n var lonlat2 = [Lib.modHalf(lonlat[0], 360), lonlat[1]];\n var xy = [xa.c2p(lonlat2), ya.c2p(lonlat2)];\n\n if(selectionTester.contains(xy, null, i, searchInfo)) {\n selection.push({\n pointNumber: i,\n lon: lonlat[0],\n lat: lonlat[1]\n });\n di.selected = 1;\n } else {\n di.selected = 0;\n }\n }\n }\n }\n\n return selection;\n};\n","'use strict';\n\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar makeFillcolorAttr = require('../scatter/fillcolor_attribute');\nvar scatterAttrs = require('../scatter/attributes');\nvar baseAttrs = require('../../plots/attributes');\nvar lineAttrs = scatterAttrs.line;\n\nmodule.exports = {\n mode: scatterAttrs.mode,\n\n r: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: 'Sets the radial coordinates'\n },\n\n theta: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: 'Sets the angular coordinates'\n },\n\n r0: {\n valType: 'any',\n dflt: 0,\n editType: 'calc+clearAxisTypes',\n description: [\n 'Alternate to `r`.',\n 'Builds a linear space of r coordinates.',\n 'Use with `dr`',\n 'where `r0` is the starting coordinate and `dr` the step.'\n ].join(' ')\n },\n dr: {\n valType: 'number',\n dflt: 1,\n editType: 'calc',\n description: 'Sets the r coordinate step.'\n },\n\n theta0: {\n valType: 'any',\n dflt: 0,\n editType: 'calc+clearAxisTypes',\n description: [\n 'Alternate to `theta`.',\n 'Builds a linear space of theta coordinates.',\n 'Use with `dtheta`',\n 'where `theta0` is the starting coordinate and `dtheta` the step.'\n ].join(' ')\n },\n dtheta: {\n valType: 'number',\n editType: 'calc',\n description: [\n 'Sets the theta coordinate step.',\n 'By default, the `dtheta` step equals the subplot\\'s period divided',\n 'by the length of the `r` coordinates.'\n ].join(' ')\n },\n\n thetaunit: {\n valType: 'enumerated',\n values: ['radians', 'degrees', 'gradians'],\n dflt: 'degrees',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the unit of input *theta* values.',\n 'Has an effect only when on *linear* angular axes.'\n ].join(' ')\n },\n\n text: scatterAttrs.text,\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: ['r', 'theta', 'text']\n }),\n hovertext: scatterAttrs.hovertext,\n\n line: {\n color: lineAttrs.color,\n width: lineAttrs.width,\n dash: lineAttrs.dash,\n backoff: lineAttrs.backoff,\n shape: extendFlat({}, lineAttrs.shape, {\n values: ['linear', 'spline']\n }),\n smoothing: lineAttrs.smoothing,\n editType: 'calc'\n },\n connectgaps: scatterAttrs.connectgaps,\n\n marker: scatterAttrs.marker,\n cliponaxis: extendFlat({}, scatterAttrs.cliponaxis, {dflt: false}),\n\n textposition: scatterAttrs.textposition,\n textfont: scatterAttrs.textfont,\n\n fill: extendFlat({}, scatterAttrs.fill, {\n values: ['none', 'toself', 'tonext'],\n dflt: 'none',\n description: [\n 'Sets the area to fill with a solid color.',\n 'Use with `fillcolor` if not *none*.',\n 'scatterpolar has a subset of the options available to scatter.',\n '*toself* connects the endpoints of the trace (or each segment',\n 'of the trace if it has gaps) into a closed shape.',\n '*tonext* fills the space between two traces if one completely',\n 'encloses the other (eg consecutive contour lines), and behaves like',\n '*toself* if there is no trace before it. *tonext* should not be',\n 'used if one trace does not enclose the other.'\n ].join(' ')\n }),\n fillcolor: makeFillcolorAttr(),\n\n // TODO error bars\n // https://stackoverflow.com/a/26597487/4068492\n // error_x (error_r, error_theta)\n // error_y\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['r', 'theta', 'text', 'name']\n }),\n hoveron: scatterAttrs.hoveron,\n hovertemplate: hovertemplateAttrs(),\n\n selected: scatterAttrs.selected,\n unselected: scatterAttrs.unselected\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nvar Axes = require('../../plots/cartesian/axes');\n\nvar calcColorscale = require('../scatter/colorscale_calc');\nvar arraysToCalcdata = require('../scatter/arrays_to_calcdata');\nvar calcSelection = require('../scatter/calc_selection');\nvar calcMarkerSize = require('../scatter/calc').calcMarkerSize;\n\nmodule.exports = function calc(gd, trace) {\n var fullLayout = gd._fullLayout;\n var subplotId = trace.subplot;\n var radialAxis = fullLayout[subplotId].radialaxis;\n var angularAxis = fullLayout[subplotId].angularaxis;\n var rArray = radialAxis.makeCalcdata(trace, 'r');\n var thetaArray = angularAxis.makeCalcdata(trace, 'theta');\n var len = trace._length;\n var cd = new Array(len);\n\n for(var i = 0; i < len; i++) {\n var r = rArray[i];\n var theta = thetaArray[i];\n var cdi = cd[i] = {};\n\n if(isNumeric(r) && isNumeric(theta)) {\n cdi.r = r;\n cdi.theta = theta;\n } else {\n cdi.r = BADNUM;\n }\n }\n\n var ppad = calcMarkerSize(trace, len);\n trace._extremes.x = Axes.findExtremes(radialAxis, rArray, {ppad: ppad});\n\n calcColorscale(gd, trace);\n arraysToCalcdata(cd, trace);\n calcSelection(cd, trace);\n\n return cd;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar subTypes = require('../scatter/subtypes');\nvar handleMarkerDefaults = require('../scatter/marker_defaults');\nvar handleLineDefaults = require('../scatter/line_defaults');\nvar handleLineShapeDefaults = require('../scatter/line_shape_defaults');\nvar handleTextDefaults = require('../scatter/text_defaults');\nvar handleFillColorDefaults = require('../scatter/fillcolor_defaults');\nvar PTS_LINESONLY = require('../scatter/constants').PTS_LINESONLY;\n\nvar attributes = require('./attributes');\n\nfunction supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleRThetaDefaults(traceIn, traceOut, layout, coerce);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n coerce('thetaunit');\n coerce('mode', len < PTS_LINESONLY ? 'lines+markers' : 'lines');\n coerce('text');\n coerce('hovertext');\n if(traceOut.hoveron !== 'fills') coerce('hovertemplate');\n\n if(subTypes.hasMarkers(traceOut)) {\n handleMarkerDefaults(traceIn, traceOut, defaultColor, layout, coerce, {gradient: true});\n }\n\n if(subTypes.hasLines(traceOut)) {\n handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce, {backoff: true});\n handleLineShapeDefaults(traceIn, traceOut, coerce);\n coerce('connectgaps');\n }\n\n if(subTypes.hasText(traceOut)) {\n coerce('texttemplate');\n handleTextDefaults(traceIn, traceOut, layout, coerce);\n }\n\n var dfltHoverOn = [];\n\n if(subTypes.hasMarkers(traceOut) || subTypes.hasText(traceOut)) {\n coerce('cliponaxis');\n coerce('marker.maxdisplayed');\n dfltHoverOn.push('points');\n }\n\n coerce('fill');\n\n if(traceOut.fill !== 'none') {\n handleFillColorDefaults(traceIn, traceOut, defaultColor, coerce);\n if(!subTypes.hasLines(traceOut)) handleLineShapeDefaults(traceIn, traceOut, coerce);\n }\n\n if(traceOut.fill === 'tonext' || traceOut.fill === 'toself') {\n dfltHoverOn.push('fills');\n }\n coerce('hoveron', dfltHoverOn.join('+') || 'points');\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n}\n\nfunction handleRThetaDefaults(traceIn, traceOut, layout, coerce) {\n var r = coerce('r');\n var theta = coerce('theta');\n\n // TODO: handle this case outside supply defaults step\n if(Lib.isTypedArray(r)) {\n traceOut.r = r = Array.from(r);\n }\n if(Lib.isTypedArray(theta)) {\n traceOut.theta = theta = Array.from(theta);\n }\n\n var len;\n\n if(r) {\n if(theta) {\n len = Math.min(r.length, theta.length);\n } else {\n len = r.length;\n coerce('theta0');\n coerce('dtheta');\n }\n } else {\n if(!theta) return 0;\n len = traceOut.theta.length;\n coerce('r0');\n coerce('dr');\n }\n\n traceOut._length = len;\n return len;\n}\n\nmodule.exports = {\n handleRThetaDefaults: handleRThetaDefaults,\n supplyDefaults: supplyDefaults\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\n\nmodule.exports = function formatLabels(cdi, trace, fullLayout) {\n var labels = {};\n\n var subplot = fullLayout[trace.subplot]._subplot;\n var radialAxis;\n var angularAxis;\n\n // for scatterpolargl texttemplate, _subplot is NOT defined, this takes part during the convert step\n // TODO we should consider moving the texttemplate formatting logic to the plot step\n if(!subplot) {\n subplot = fullLayout[trace.subplot];\n radialAxis = subplot.radialaxis;\n angularAxis = subplot.angularaxis;\n } else {\n radialAxis = subplot.radialAxis;\n angularAxis = subplot.angularAxis;\n }\n\n var rVal = radialAxis.c2l(cdi.r);\n labels.rLabel = Axes.tickText(radialAxis, rVal, true).text;\n\n // N.B here the ° sign is part of the formatted value for thetaunit:'degrees'\n var thetaVal = angularAxis.thetaunit === 'degrees' ? Lib.rad2deg(cdi.theta) : cdi.theta;\n labels.thetaLabel = Axes.tickText(angularAxis, thetaVal, true).text;\n\n return labels;\n};\n","'use strict';\n\nvar scatterHover = require('../scatter/hover');\n\nfunction hoverPoints(pointData, xval, yval, hovermode) {\n var scatterPointData = scatterHover(pointData, xval, yval, hovermode);\n if(!scatterPointData || scatterPointData[0].index === false) return;\n\n var newPointData = scatterPointData[0];\n\n // hovering on fill case\n if(newPointData.index === undefined) {\n return scatterPointData;\n }\n\n var subplot = pointData.subplot;\n var cdi = newPointData.cd[newPointData.index];\n var trace = newPointData.trace;\n\n if(!subplot.isPtInside(cdi)) return;\n\n newPointData.xLabelVal = undefined;\n newPointData.yLabelVal = undefined;\n makeHoverPointText(cdi, trace, subplot, newPointData);\n newPointData.hovertemplate = trace.hovertemplate;\n return scatterPointData;\n}\n\nfunction makeHoverPointText(cdi, trace, subplot, pointData) {\n var radialAxis = subplot.radialAxis;\n var angularAxis = subplot.angularAxis;\n radialAxis._hovertitle = 'r';\n angularAxis._hovertitle = 'θ';\n\n var fullLayout = {};\n fullLayout[trace.subplot] = {_subplot: subplot};\n var labels = trace._module.formatLabels(cdi, trace, fullLayout);\n pointData.rLabel = labels.rLabel;\n pointData.thetaLabel = labels.thetaLabel;\n\n var hoverinfo = cdi.hi || trace.hoverinfo;\n var text = [];\n function textPart(ax, val) {\n text.push(ax._hovertitle + ': ' + val);\n }\n\n if(!trace.hovertemplate) {\n var parts = hoverinfo.split('+');\n\n if(parts.indexOf('all') !== -1) parts = ['r', 'theta', 'text'];\n if(parts.indexOf('r') !== -1) textPart(radialAxis, pointData.rLabel);\n if(parts.indexOf('theta') !== -1) textPart(angularAxis, pointData.thetaLabel);\n\n if(parts.indexOf('text') !== -1 && pointData.text) {\n text.push(pointData.text);\n delete pointData.text;\n }\n\n pointData.extraText = text.join('
');\n }\n}\n\nmodule.exports = {\n hoverPoints: hoverPoints,\n makeHoverPointText: makeHoverPointText\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'scatterpolar',\n basePlotModule: require('../../plots/polar'),\n categories: ['polar', 'symbols', 'showLegend', 'scatter-like'],\n\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults').supplyDefaults,\n colorbar: require('../scatter/marker_colorbar'),\n formatLabels: require('./format_labels'),\n calc: require('./calc'),\n plot: require('./plot'),\n style: require('../scatter/style').style,\n styleOnSelect: require('../scatter/style').styleOnSelect,\n hoverPoints: require('./hover').hoverPoints,\n selectPoints: require('../scatter/select'),\n\n meta: {\n hrName: 'scatter_polar',\n description: [\n 'The scatterpolar trace type encompasses line charts, scatter charts, text charts, and bubble charts',\n 'in polar coordinates.',\n 'The data visualized as scatter point or lines is set in',\n '`r` (radial) and `theta` (angular) coordinates',\n 'Text (appearing either on the chart or on hover only) is via `text`.',\n 'Bubble charts are achieved by setting `marker.size` and/or `marker.color`',\n 'to numerical arrays.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar scatterPlot = require('../scatter/plot');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nmodule.exports = function plot(gd, subplot, moduleCalcData) {\n var mlayer = subplot.layers.frontplot.select('g.scatterlayer');\n\n var xa = subplot.xaxis;\n var ya = subplot.yaxis;\n\n var plotinfo = {\n xaxis: xa,\n yaxis: ya,\n plot: subplot.framework,\n layerClipId: subplot._hasClipOnAxisFalse ? subplot.clipIds.forTraces : null\n };\n\n var radialAxis = subplot.radialAxis;\n var angularAxis = subplot.angularAxis;\n\n // convert:\n // 'c' (r,theta) -> 'geometric' (r,theta) -> (x,y)\n for(var i = 0; i < moduleCalcData.length; i++) {\n var cdi = moduleCalcData[i];\n\n for(var j = 0; j < cdi.length; j++) {\n if(j === 0) {\n cdi[0].trace._xA = xa;\n cdi[0].trace._yA = ya;\n }\n\n var cd = cdi[j];\n var r = cd.r;\n\n if(r === BADNUM) {\n cd.x = cd.y = BADNUM;\n } else {\n var rg = radialAxis.c2g(r);\n var thetag = angularAxis.c2g(cd.theta);\n cd.x = rg * Math.cos(thetag);\n cd.y = rg * Math.sin(thetag);\n }\n }\n }\n\n scatterPlot(gd, plotinfo, moduleCalcData, mlayer);\n};\n","'use strict';\n\nvar scatterPolarAttrs = require('../scatterpolar/attributes');\nvar scatterGlAttrs = require('../scattergl/attributes');\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\n\nmodule.exports = {\n mode: scatterPolarAttrs.mode,\n r: scatterPolarAttrs.r,\n theta: scatterPolarAttrs.theta,\n r0: scatterPolarAttrs.r0,\n dr: scatterPolarAttrs.dr,\n theta0: scatterPolarAttrs.theta0,\n dtheta: scatterPolarAttrs.dtheta,\n thetaunit: scatterPolarAttrs.thetaunit,\n\n text: scatterPolarAttrs.text,\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: ['r', 'theta', 'text']\n }),\n hovertext: scatterPolarAttrs.hovertext,\n hovertemplate: scatterPolarAttrs.hovertemplate,\n\n line: {\n color: scatterGlAttrs.line.color,\n width: scatterGlAttrs.line.width,\n dash: scatterGlAttrs.line.dash,\n editType: 'calc'\n },\n\n connectgaps: scatterGlAttrs.connectgaps,\n\n marker: scatterGlAttrs.marker,\n // no cliponaxis\n\n fill: scatterGlAttrs.fill,\n fillcolor: scatterGlAttrs.fillcolor,\n\n textposition: scatterGlAttrs.textposition,\n textfont: scatterGlAttrs.textfont,\n\n hoverinfo: scatterPolarAttrs.hoverinfo,\n // no hoveron\n\n selected: scatterPolarAttrs.selected,\n unselected: scatterPolarAttrs.unselected\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'scatterpolargl',\n basePlotModule: require('../../plots/polar'),\n categories: ['gl', 'regl', 'polar', 'symbols', 'showLegend', 'scatter-like'],\n\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../scatter/marker_colorbar'),\n formatLabels: require('./format_labels'),\n\n calc: require('./calc'),\n hoverPoints: require('./hover').hoverPoints,\n selectPoints: require('../scattergl/select'),\n\n meta: {\n hrName: 'scatter_polar_gl',\n description: [\n 'The scatterpolargl trace type encompasses line charts, scatter charts, and bubble charts',\n 'in polar coordinates using the WebGL plotting engine.',\n 'The data visualized as scatter point or lines is set in',\n '`r` (radial) and `theta` (angular) coordinates',\n 'Bubble charts are achieved by setting `marker.size` and/or `marker.color`',\n 'to numerical arrays.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar calcColorscale = require('../scatter/colorscale_calc');\nvar calcMarkerSize = require('../scatter/calc').calcMarkerSize;\nvar convert = require('../scattergl/convert');\nvar Axes = require('../../plots/cartesian/axes');\nvar TOO_MANY_POINTS = require('../scattergl/constants').TOO_MANY_POINTS;\n\nmodule.exports = function calc(gd, trace) {\n var fullLayout = gd._fullLayout;\n var subplotId = trace.subplot;\n var radialAxis = fullLayout[subplotId].radialaxis;\n var angularAxis = fullLayout[subplotId].angularaxis;\n var rArray = trace._r = radialAxis.makeCalcdata(trace, 'r');\n var thetaArray = trace._theta = angularAxis.makeCalcdata(trace, 'theta');\n var len = trace._length;\n var stash = {};\n\n if(len < rArray.length) rArray = rArray.slice(0, len);\n if(len < thetaArray.length) thetaArray = thetaArray.slice(0, len);\n\n stash.r = rArray;\n stash.theta = thetaArray;\n\n calcColorscale(gd, trace);\n\n // only compute 'style' options in calc, as position options\n // depend on the radial range and must be set in plot\n var opts = stash.opts = convert.style(gd, trace);\n\n // For graphs with very large number of points and array marker.size,\n // use average marker size instead to speed things up.\n var ppad;\n if(len < TOO_MANY_POINTS) {\n ppad = calcMarkerSize(trace, len);\n } else if(opts.marker) {\n ppad = 2 * (opts.marker.sizeAvg || Math.max(opts.marker.size, 3));\n }\n trace._extremes.x = Axes.findExtremes(radialAxis, rArray, {ppad: ppad});\n\n return [{x: false, y: false, t: stash, trace: trace}];\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar subTypes = require('../scatter/subtypes');\nvar handleRThetaDefaults = require('../scatterpolar/defaults').handleRThetaDefaults;\nvar handleMarkerDefaults = require('../scatter/marker_defaults');\nvar handleLineDefaults = require('../scatter/line_defaults');\nvar handleTextDefaults = require('../scatter/text_defaults');\nvar handleFillColorDefaults = require('../scatter/fillcolor_defaults');\nvar PTS_LINESONLY = require('../scatter/constants').PTS_LINESONLY;\n\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleRThetaDefaults(traceIn, traceOut, layout, coerce);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n coerce('thetaunit');\n coerce('mode', len < PTS_LINESONLY ? 'lines+markers' : 'lines');\n coerce('text');\n coerce('hovertext');\n if(traceOut.hoveron !== 'fills') coerce('hovertemplate');\n\n if(subTypes.hasMarkers(traceOut)) {\n handleMarkerDefaults(traceIn, traceOut, defaultColor, layout, coerce, {noAngleRef: true, noStandOff: true});\n }\n\n if(subTypes.hasLines(traceOut)) {\n handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce);\n coerce('connectgaps');\n }\n\n if(subTypes.hasText(traceOut)) {\n coerce('texttemplate');\n handleTextDefaults(traceIn, traceOut, layout, coerce, {\n noFontShadow: true,\n noFontLineposition: true,\n noFontTextcase: true,\n });\n }\n\n coerce('fill');\n if(traceOut.fill !== 'none') {\n handleFillColorDefaults(traceIn, traceOut, defaultColor, coerce);\n }\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n","'use strict';\n\nvar scatterPolarFormatLabels = require('../scatterpolar/format_labels');\n\nmodule.exports = function formatLabels(cdi, trace, fullLayout) {\n var i = cdi.i;\n if(!('r' in cdi)) cdi.r = trace._r[i];\n if(!('theta' in cdi)) cdi.theta = trace._theta[i];\n return scatterPolarFormatLabels(cdi, trace, fullLayout);\n};\n","'use strict';\n\nvar hover = require('../scattergl/hover');\nvar makeHoverPointText = require('../scatterpolar/hover').makeHoverPointText;\n\nfunction hoverPoints(pointData, xval, yval, hovermode) {\n var cd = pointData.cd;\n var stash = cd[0].t;\n var rArray = stash.r;\n var thetaArray = stash.theta;\n\n var scatterPointData = hover.hoverPoints(pointData, xval, yval, hovermode);\n if(!scatterPointData || scatterPointData[0].index === false) return;\n\n var newPointData = scatterPointData[0];\n\n if(newPointData.index === undefined) {\n return scatterPointData;\n }\n\n var subplot = pointData.subplot;\n var cdi = newPointData.cd[newPointData.index];\n var trace = newPointData.trace;\n\n // augment pointData with r/theta param\n cdi.r = rArray[newPointData.index];\n cdi.theta = thetaArray[newPointData.index];\n\n if(!subplot.isPtInside(cdi)) return;\n\n newPointData.xLabelVal = undefined;\n newPointData.yLabelVal = undefined;\n makeHoverPointText(cdi, trace, subplot, newPointData);\n\n return scatterPointData;\n}\n\nmodule.exports = {\n hoverPoints: hoverPoints\n};\n","'use strict';\n\nvar index = require('./base_index');\n\nindex.plot = require('./plot');\n\nmodule.exports = index;\n","'use strict';\n\nvar cluster = require('@plotly/point-cluster');\nvar isNumeric = require('fast-isnumeric');\n\nvar scatterglPlot = require('../scattergl/plot');\nvar sceneUpdate = require('../scattergl/scene_update');\nvar convert = require('../scattergl/convert');\n\nvar Lib = require('../../lib');\n\nvar TOO_MANY_POINTS = require('../scattergl/constants').TOO_MANY_POINTS;\n\nvar reglPrecompiled = {};\n\nmodule.exports = function plot(gd, subplot, cdata) {\n if(!cdata.length) return;\n\n var radialAxis = subplot.radialAxis;\n var angularAxis = subplot.angularAxis;\n var scene = sceneUpdate(gd, subplot);\n\n cdata.forEach(function(cdscatter) {\n if(!cdscatter || !cdscatter[0] || !cdscatter[0].trace) return;\n var cd = cdscatter[0];\n var trace = cd.trace;\n var stash = cd.t;\n var len = trace._length;\n var rArray = stash.r;\n var thetaArray = stash.theta;\n var opts = stash.opts;\n var i;\n\n var subRArray = rArray.slice();\n var subThetaArray = thetaArray.slice();\n\n // filter out by range\n for(i = 0; i < rArray.length; i++) {\n if(!subplot.isPtInside({r: rArray[i], theta: thetaArray[i]})) {\n subRArray[i] = NaN;\n subThetaArray[i] = NaN;\n }\n }\n\n var positions = new Array(len * 2);\n var x = Array(len);\n var y = Array(len);\n\n for(i = 0; i < len; i++) {\n var r = subRArray[i];\n var xx, yy;\n\n if(isNumeric(r)) {\n var rg = radialAxis.c2g(r);\n var thetag = angularAxis.c2g(subThetaArray[i], trace.thetaunit);\n xx = rg * Math.cos(thetag);\n yy = rg * Math.sin(thetag);\n } else {\n xx = yy = NaN;\n }\n x[i] = positions[i * 2] = xx;\n y[i] = positions[i * 2 + 1] = yy;\n }\n\n stash.tree = cluster(positions);\n\n // FIXME: see scattergl.js#109\n if(opts.marker && len >= TOO_MANY_POINTS) {\n opts.marker.cluster = stash.tree;\n }\n\n if(opts.marker) {\n opts.markerSel.positions = opts.markerUnsel.positions = opts.marker.positions = positions;\n }\n\n if(opts.line && positions.length > 1) {\n Lib.extendFlat(\n opts.line,\n convert.linePositions(gd, trace, positions)\n );\n }\n\n if(opts.text) {\n Lib.extendFlat(\n opts.text,\n {positions: positions},\n convert.textPosition(gd, trace, opts.text, opts.marker)\n );\n Lib.extendFlat(\n opts.textSel,\n {positions: positions},\n convert.textPosition(gd, trace, opts.text, opts.markerSel)\n );\n Lib.extendFlat(\n opts.textUnsel,\n {positions: positions},\n convert.textPosition(gd, trace, opts.text, opts.markerUnsel)\n );\n }\n\n if(opts.fill && !scene.fill2d) scene.fill2d = true;\n if(opts.marker && !scene.scatter2d) scene.scatter2d = true;\n if(opts.line && !scene.line2d) scene.line2d = true;\n if(opts.text && !scene.glText) scene.glText = true;\n\n scene.lineOptions.push(opts.line);\n scene.fillOptions.push(opts.fill);\n scene.markerOptions.push(opts.marker);\n scene.markerSelectedOptions.push(opts.markerSel);\n scene.markerUnselectedOptions.push(opts.markerUnsel);\n scene.textOptions.push(opts.text);\n scene.textSelectedOptions.push(opts.textSel);\n scene.textUnselectedOptions.push(opts.textUnsel);\n scene.selectBatch.push([]);\n scene.unselectBatch.push([]);\n\n stash.x = x;\n stash.y = y;\n stash.rawx = x;\n stash.rawy = y;\n stash.r = rArray;\n stash.theta = thetaArray;\n stash.positions = positions;\n stash._scene = scene;\n stash.index = scene.count;\n scene.count++;\n });\n\n return scatterglPlot(gd, subplot, cdata);\n};\n\nmodule.exports.reglPrecompiled = reglPrecompiled;\n","'use strict';\n\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar makeFillcolorAttr = require('../scatter/fillcolor_attribute');\nvar scatterAttrs = require('../scatter/attributes');\nvar baseAttrs = require('../../plots/attributes');\nvar lineAttrs = scatterAttrs.line;\n\nmodule.exports = {\n mode: scatterAttrs.mode,\n\n real: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the real component of the data, in units of normalized impedance',\n 'such that real=1, imag=0 is the center of the chart.'\n ].join(' ')\n },\n\n imag: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the imaginary component of the data, in units of normalized impedance',\n 'such that real=1, imag=0 is the center of the chart.'\n ].join(' ')\n },\n\n text: scatterAttrs.text,\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: ['real', 'imag', 'text']\n }),\n hovertext: scatterAttrs.hovertext,\n\n line: {\n color: lineAttrs.color,\n width: lineAttrs.width,\n dash: lineAttrs.dash,\n backoff: lineAttrs.backoff,\n shape: extendFlat({}, lineAttrs.shape, {\n values: ['linear', 'spline']\n }),\n smoothing: lineAttrs.smoothing,\n editType: 'calc'\n },\n connectgaps: scatterAttrs.connectgaps,\n\n marker: scatterAttrs.marker,\n cliponaxis: extendFlat({}, scatterAttrs.cliponaxis, {dflt: false}),\n\n textposition: scatterAttrs.textposition,\n textfont: scatterAttrs.textfont,\n\n fill: extendFlat({}, scatterAttrs.fill, {\n values: ['none', 'toself', 'tonext'],\n dflt: 'none',\n description: [\n 'Sets the area to fill with a solid color.',\n 'Use with `fillcolor` if not *none*.',\n 'scattersmith has a subset of the options available to scatter.',\n '*toself* connects the endpoints of the trace (or each segment',\n 'of the trace if it has gaps) into a closed shape.',\n '*tonext* fills the space between two traces if one completely',\n 'encloses the other (eg consecutive contour lines), and behaves like',\n '*toself* if there is no trace before it. *tonext* should not be',\n 'used if one trace does not enclose the other.'\n ].join(' ')\n }),\n fillcolor: makeFillcolorAttr(),\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['real', 'imag', 'text', 'name']\n }),\n hoveron: scatterAttrs.hoveron,\n hovertemplate: hovertemplateAttrs(),\n\n selected: scatterAttrs.selected,\n unselected: scatterAttrs.unselected\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nvar calcColorscale = require('../scatter/colorscale_calc');\nvar arraysToCalcdata = require('../scatter/arrays_to_calcdata');\nvar calcSelection = require('../scatter/calc_selection');\nvar calcMarkerSize = require('../scatter/calc').calcMarkerSize;\n\nmodule.exports = function calc(gd, trace) {\n var fullLayout = gd._fullLayout;\n var subplotId = trace.subplot;\n var realAxis = fullLayout[subplotId].realaxis;\n var imaginaryAxis = fullLayout[subplotId].imaginaryaxis;\n var realArray = realAxis.makeCalcdata(trace, 'real');\n var imagArray = imaginaryAxis.makeCalcdata(trace, 'imag');\n var len = trace._length;\n var cd = new Array(len);\n\n for(var i = 0; i < len; i++) {\n var real = realArray[i];\n var imag = imagArray[i];\n var cdi = cd[i] = {};\n\n if(isNumeric(real) && isNumeric(imag)) {\n cdi.real = real;\n cdi.imag = imag;\n } else {\n cdi.real = BADNUM;\n }\n }\n\n calcMarkerSize(trace, len);\n calcColorscale(gd, trace);\n arraysToCalcdata(cd, trace);\n calcSelection(cd, trace);\n\n return cd;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar subTypes = require('../scatter/subtypes');\nvar handleMarkerDefaults = require('../scatter/marker_defaults');\nvar handleLineDefaults = require('../scatter/line_defaults');\nvar handleLineShapeDefaults = require('../scatter/line_shape_defaults');\nvar handleTextDefaults = require('../scatter/text_defaults');\nvar handleFillColorDefaults = require('../scatter/fillcolor_defaults');\nvar PTS_LINESONLY = require('../scatter/constants').PTS_LINESONLY;\n\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleRealImagDefaults(traceIn, traceOut, layout, coerce);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n coerce('mode', len < PTS_LINESONLY ? 'lines+markers' : 'lines');\n coerce('text');\n coerce('hovertext');\n if(traceOut.hoveron !== 'fills') coerce('hovertemplate');\n\n if(subTypes.hasMarkers(traceOut)) {\n handleMarkerDefaults(traceIn, traceOut, defaultColor, layout, coerce, {gradient: true});\n }\n\n if(subTypes.hasLines(traceOut)) {\n handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce, {backoff: true});\n handleLineShapeDefaults(traceIn, traceOut, coerce);\n coerce('connectgaps');\n }\n\n if(subTypes.hasText(traceOut)) {\n coerce('texttemplate');\n handleTextDefaults(traceIn, traceOut, layout, coerce);\n }\n\n var dfltHoverOn = [];\n\n if(subTypes.hasMarkers(traceOut) || subTypes.hasText(traceOut)) {\n coerce('cliponaxis');\n coerce('marker.maxdisplayed');\n dfltHoverOn.push('points');\n }\n\n coerce('fill');\n\n if(traceOut.fill !== 'none') {\n handleFillColorDefaults(traceIn, traceOut, defaultColor, coerce);\n if(!subTypes.hasLines(traceOut)) handleLineShapeDefaults(traceIn, traceOut, coerce);\n }\n\n if(traceOut.fill === 'tonext' || traceOut.fill === 'toself') {\n dfltHoverOn.push('fills');\n }\n coerce('hoveron', dfltHoverOn.join('+') || 'points');\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n\nfunction handleRealImagDefaults(traceIn, traceOut, layout, coerce) {\n var real = coerce('real');\n var imag = coerce('imag');\n var len;\n\n if(real && imag) {\n len = Math.min(real.length, imag.length);\n }\n\n // TODO: handle this case outside supply defaults step\n if(Lib.isTypedArray(real)) {\n traceOut.real = real = Array.from(real);\n }\n if(Lib.isTypedArray(imag)) {\n traceOut.imag = imag = Array.from(imag);\n }\n\n traceOut._length = len;\n return len;\n}\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\n\nmodule.exports = function formatLabels(cdi, trace, fullLayout) {\n var labels = {};\n\n var subplot = fullLayout[trace.subplot]._subplot;\n\n labels.realLabel = Axes.tickText(subplot.radialAxis, cdi.real, true).text;\n labels.imagLabel = Axes.tickText(subplot.angularAxis, cdi.imag, true).text;\n\n return labels;\n};\n","'use strict';\n\nvar scatterHover = require('../scatter/hover');\n\nfunction hoverPoints(pointData, xval, yval, hovermode) {\n var scatterPointData = scatterHover(pointData, xval, yval, hovermode);\n if(!scatterPointData || scatterPointData[0].index === false) return;\n\n var newPointData = scatterPointData[0];\n\n // hovering on fill case\n if(newPointData.index === undefined) {\n return scatterPointData;\n }\n\n var subplot = pointData.subplot;\n var cdi = newPointData.cd[newPointData.index];\n var trace = newPointData.trace;\n\n if(!subplot.isPtInside(cdi)) return;\n\n newPointData.xLabelVal = undefined;\n newPointData.yLabelVal = undefined;\n makeHoverPointText(cdi, trace, subplot, newPointData);\n newPointData.hovertemplate = trace.hovertemplate;\n return scatterPointData;\n}\n\nfunction makeHoverPointText(cdi, trace, subplot, pointData) {\n var realAxis = subplot.radialAxis;\n var imaginaryAxis = subplot.angularAxis;\n realAxis._hovertitle = 'real';\n imaginaryAxis._hovertitle = 'imag';\n\n var fullLayout = {};\n fullLayout[trace.subplot] = {_subplot: subplot};\n var labels = trace._module.formatLabels(cdi, trace, fullLayout);\n pointData.realLabel = labels.realLabel;\n pointData.imagLabel = labels.imagLabel;\n\n var hoverinfo = cdi.hi || trace.hoverinfo;\n var text = [];\n function textPart(ax, val) {\n text.push(ax._hovertitle + ': ' + val);\n }\n\n if(!trace.hovertemplate) {\n var parts = hoverinfo.split('+');\n\n if(parts.indexOf('all') !== -1) parts = ['real', 'imag', 'text'];\n if(parts.indexOf('real') !== -1) textPart(realAxis, pointData.realLabel);\n if(parts.indexOf('imag') !== -1) textPart(imaginaryAxis, pointData.imagLabel);\n\n if(parts.indexOf('text') !== -1 && pointData.text) {\n text.push(pointData.text);\n delete pointData.text;\n }\n\n pointData.extraText = text.join('
');\n }\n}\n\nmodule.exports = {\n hoverPoints: hoverPoints,\n makeHoverPointText: makeHoverPointText\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'scattersmith',\n basePlotModule: require('../../plots/smith'),\n categories: ['smith', 'symbols', 'showLegend', 'scatter-like'],\n\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../scatter/marker_colorbar'),\n formatLabels: require('./format_labels'),\n calc: require('./calc'),\n plot: require('./plot'),\n style: require('../scatter/style').style,\n styleOnSelect: require('../scatter/style').styleOnSelect,\n hoverPoints: require('./hover').hoverPoints,\n selectPoints: require('../scatter/select'),\n\n meta: {\n hrName: 'scatter_smith',\n description: [\n // TODO: improve me!\n 'The scattersmith trace type encompasses line charts, scatter charts, text charts, and bubble charts',\n 'in smith coordinates.',\n 'The data visualized as scatter point or lines is set in',\n '`real` and `imag` (imaginary) coordinates',\n 'Text (appearing either on the chart or on hover only) is via `text`.',\n 'Bubble charts are achieved by setting `marker.size` and/or `marker.color`',\n 'to numerical arrays.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar scatterPlot = require('../scatter/plot');\nvar BADNUM = require('../../constants/numerical').BADNUM;\nvar helpers = require('../../plots/smith/helpers');\nvar smith = helpers.smith;\n\nmodule.exports = function plot(gd, subplot, moduleCalcData) {\n var mlayer = subplot.layers.frontplot.select('g.scatterlayer');\n\n var xa = subplot.xaxis;\n var ya = subplot.yaxis;\n\n var plotinfo = {\n xaxis: xa,\n yaxis: ya,\n plot: subplot.framework,\n layerClipId: subplot._hasClipOnAxisFalse ? subplot.clipIds.forTraces : null\n };\n\n // convert:\n // 'c' (real,imag) -> (x,y)\n for(var i = 0; i < moduleCalcData.length; i++) {\n var cdi = moduleCalcData[i];\n\n for(var j = 0; j < cdi.length; j++) {\n if(j === 0) {\n cdi[0].trace._xA = xa;\n cdi[0].trace._yA = ya;\n }\n\n var cd = cdi[j];\n var real = cd.real;\n\n if(real === BADNUM) {\n cd.x = cd.y = BADNUM;\n } else {\n var t = smith([real, cd.imag]);\n\n cd.x = t[0];\n cd.y = t[1];\n }\n }\n }\n\n scatterPlot(gd, plotinfo, moduleCalcData, mlayer);\n};\n","'use strict';\n\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar makeFillcolorAttr = require('../scatter/fillcolor_attribute');\nvar scatterAttrs = require('../scatter/attributes');\nvar baseAttrs = require('../../plots/attributes');\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar dash = require('../../components/drawing/attributes').dash;\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar scatterMarkerAttrs = scatterAttrs.marker;\nvar scatterLineAttrs = scatterAttrs.line;\nvar scatterMarkerLineAttrs = scatterMarkerAttrs.line;\n\nmodule.exports = {\n a: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the quantity of component `a` in each data point.',\n 'If `a`, `b`, and `c` are all provided, they need not be',\n 'normalized, only the relative values matter. If only two',\n 'arrays are provided they must be normalized to match',\n '`ternary.sum`.'\n ].join(' ')\n },\n b: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the quantity of component `a` in each data point.',\n 'If `a`, `b`, and `c` are all provided, they need not be',\n 'normalized, only the relative values matter. If only two',\n 'arrays are provided they must be normalized to match',\n '`ternary.sum`.'\n ].join(' ')\n },\n c: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the quantity of component `a` in each data point.',\n 'If `a`, `b`, and `c` are all provided, they need not be',\n 'normalized, only the relative values matter. If only two',\n 'arrays are provided they must be normalized to match',\n '`ternary.sum`.'\n ].join(' ')\n },\n sum: {\n valType: 'number',\n dflt: 0,\n min: 0,\n editType: 'calc',\n description: [\n 'The number each triplet should sum to,',\n 'if only two of `a`, `b`, and `c` are provided.',\n 'This overrides `ternary.sum` to normalize this specific',\n 'trace, but does not affect the values displayed on the axes.',\n '0 (or missing) means to use ternary.sum'\n ].join(' ')\n },\n mode: extendFlat({}, scatterAttrs.mode, {dflt: 'markers'}),\n text: extendFlat({}, scatterAttrs.text, {\n description: [\n 'Sets text elements associated with each (a,b,c) point.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of strings, the items are mapped in order to the',\n 'the data points in (a,b,c).',\n 'If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,',\n 'these elements will be seen in the hover labels.'\n ].join(' ')\n }),\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: ['a', 'b', 'c', 'text']\n }),\n hovertext: extendFlat({}, scatterAttrs.hovertext, {\n description: [\n 'Sets hover text elements associated with each (a,b,c) point.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of strings, the items are mapped in order to the',\n 'the data points in (a,b,c).',\n 'To be seen, trace `hoverinfo` must contain a *text* flag.'\n ].join(' ')\n }),\n line: {\n color: scatterLineAttrs.color,\n width: scatterLineAttrs.width,\n dash: dash,\n backoff: scatterLineAttrs.backoff,\n shape: extendFlat({}, scatterLineAttrs.shape,\n {values: ['linear', 'spline']}),\n smoothing: scatterLineAttrs.smoothing,\n editType: 'calc'\n },\n connectgaps: scatterAttrs.connectgaps,\n cliponaxis: scatterAttrs.cliponaxis,\n fill: extendFlat({}, scatterAttrs.fill, {\n values: ['none', 'toself', 'tonext'],\n dflt: 'none',\n description: [\n 'Sets the area to fill with a solid color.',\n 'Use with `fillcolor` if not *none*.',\n 'scatterternary has a subset of the options available to scatter.',\n '*toself* connects the endpoints of the trace (or each segment',\n 'of the trace if it has gaps) into a closed shape.',\n '*tonext* fills the space between two traces if one completely',\n 'encloses the other (eg consecutive contour lines), and behaves like',\n '*toself* if there is no trace before it. *tonext* should not be',\n 'used if one trace does not enclose the other.'\n ].join(' ')\n }),\n fillcolor: makeFillcolorAttr(),\n marker: extendFlat({\n symbol: scatterMarkerAttrs.symbol,\n opacity: scatterMarkerAttrs.opacity,\n angle: scatterMarkerAttrs.angle,\n angleref: scatterMarkerAttrs.angleref,\n standoff: scatterMarkerAttrs.standoff,\n maxdisplayed: scatterMarkerAttrs.maxdisplayed,\n size: scatterMarkerAttrs.size,\n sizeref: scatterMarkerAttrs.sizeref,\n sizemin: scatterMarkerAttrs.sizemin,\n sizemode: scatterMarkerAttrs.sizemode,\n line: extendFlat({\n width: scatterMarkerLineAttrs.width,\n editType: 'calc'\n },\n colorScaleAttrs('marker.line')\n ),\n gradient: scatterMarkerAttrs.gradient,\n editType: 'calc'\n },\n colorScaleAttrs('marker')\n ),\n\n textfont: scatterAttrs.textfont,\n textposition: scatterAttrs.textposition,\n\n selected: scatterAttrs.selected,\n unselected: scatterAttrs.unselected,\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['a', 'b', 'c', 'text', 'name']\n }),\n hoveron: scatterAttrs.hoveron,\n hovertemplate: hovertemplateAttrs(),\n};\n","'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar calcColorscale = require('../scatter/colorscale_calc');\nvar arraysToCalcdata = require('../scatter/arrays_to_calcdata');\nvar calcSelection = require('../scatter/calc_selection');\nvar calcMarkerSize = require('../scatter/calc').calcMarkerSize;\n\nvar dataArrays = ['a', 'b', 'c'];\nvar arraysToFill = {a: ['b', 'c'], b: ['a', 'c'], c: ['a', 'b']};\n\nmodule.exports = function calc(gd, trace) {\n var ternary = gd._fullLayout[trace.subplot];\n var displaySum = ternary.sum;\n var normSum = trace.sum || displaySum;\n var arrays = {a: trace.a, b: trace.b, c: trace.c};\n\n var i, j, dataArray, newArray, fillArray1, fillArray2;\n\n // fill in one missing component\n for(i = 0; i < dataArrays.length; i++) {\n dataArray = dataArrays[i];\n if(arrays[dataArray]) continue;\n\n fillArray1 = arrays[arraysToFill[dataArray][0]];\n fillArray2 = arrays[arraysToFill[dataArray][1]];\n newArray = new Array(fillArray1.length);\n for(j = 0; j < fillArray1.length; j++) {\n newArray[j] = normSum - fillArray1[j] - fillArray2[j];\n }\n arrays[dataArray] = newArray;\n }\n\n // make the calcdata array\n var serieslen = trace._length;\n var cd = new Array(serieslen);\n var a, b, c, norm, x, y;\n for(i = 0; i < serieslen; i++) {\n a = arrays.a[i];\n b = arrays.b[i];\n c = arrays.c[i];\n if(isNumeric(a) && isNumeric(b) && isNumeric(c)) {\n a = +a;\n b = +b;\n c = +c;\n norm = displaySum / (a + b + c);\n if(norm !== 1) {\n a *= norm;\n b *= norm;\n c *= norm;\n }\n // map a, b, c onto x and y where the full scale of y\n // is [0, sum], and x is [-sum, sum]\n // TODO: this makes `a` always the top, `b` the bottom left,\n // and `c` the bottom right. Do we want options to rearrange\n // these?\n y = a;\n x = c - b;\n cd[i] = {x: x, y: y, a: a, b: b, c: c};\n } else cd[i] = {x: false, y: false};\n }\n\n calcMarkerSize(trace, serieslen);\n calcColorscale(gd, trace);\n arraysToCalcdata(cd, trace);\n calcSelection(cd, trace);\n\n return cd;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar constants = require('../scatter/constants');\nvar subTypes = require('../scatter/subtypes');\nvar handleMarkerDefaults = require('../scatter/marker_defaults');\nvar handleLineDefaults = require('../scatter/line_defaults');\nvar handleLineShapeDefaults = require('../scatter/line_shape_defaults');\nvar handleTextDefaults = require('../scatter/text_defaults');\nvar handleFillColorDefaults = require('../scatter/fillcolor_defaults');\n\nvar attributes = require('./attributes');\n\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var a = coerce('a');\n var b = coerce('b');\n var c = coerce('c');\n var len;\n\n // allow any one array to be missing, len is the minimum length of those\n // present. Note that after coerce data_array's are either Arrays (which\n // are truthy even if empty) or undefined. As in scatter, an empty array\n // is different from undefined, because it can signify that this data is\n // not known yet but expected in the future\n if(a) {\n len = a.length;\n if(b) {\n len = Math.min(len, b.length);\n if(c) len = Math.min(len, c.length);\n } else if(c) len = Math.min(len, c.length);\n else len = 0;\n } else if(b && c) {\n len = Math.min(b.length, c.length);\n }\n\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n traceOut._length = len;\n\n coerce('sum');\n\n coerce('text');\n coerce('hovertext');\n if(traceOut.hoveron !== 'fills') coerce('hovertemplate');\n\n var defaultMode = len < constants.PTS_LINESONLY ? 'lines+markers' : 'lines';\n coerce('mode', defaultMode);\n\n if(subTypes.hasMarkers(traceOut)) {\n handleMarkerDefaults(traceIn, traceOut, defaultColor, layout, coerce, {gradient: true});\n }\n\n if(subTypes.hasLines(traceOut)) {\n handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce, {backoff: true});\n handleLineShapeDefaults(traceIn, traceOut, coerce);\n coerce('connectgaps');\n }\n\n if(subTypes.hasText(traceOut)) {\n coerce('texttemplate');\n handleTextDefaults(traceIn, traceOut, layout, coerce);\n }\n\n var dfltHoverOn = [];\n\n if(subTypes.hasMarkers(traceOut) || subTypes.hasText(traceOut)) {\n coerce('cliponaxis');\n coerce('marker.maxdisplayed');\n dfltHoverOn.push('points');\n }\n\n coerce('fill');\n if(traceOut.fill !== 'none') {\n handleFillColorDefaults(traceIn, traceOut, defaultColor, coerce);\n if(!subTypes.hasLines(traceOut)) handleLineShapeDefaults(traceIn, traceOut, coerce);\n }\n\n if(traceOut.fill === 'tonext' || traceOut.fill === 'toself') {\n dfltHoverOn.push('fills');\n }\n coerce('hoveron', dfltHoverOn.join('+') || 'points');\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n","'use strict';\n\nmodule.exports = function eventData(out, pt, trace, cd, pointNumber) {\n if(pt.xa) out.xaxis = pt.xa;\n if(pt.ya) out.yaxis = pt.ya;\n\n if(cd[pointNumber]) {\n var cdi = cd[pointNumber];\n\n // N.B. These are the normalized coordinates.\n out.a = cdi.a;\n out.b = cdi.b;\n out.c = cdi.c;\n } else {\n // for fill-hover only\n out.a = pt.a;\n out.b = pt.b;\n out.c = pt.c;\n }\n\n return out;\n};\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\n\nmodule.exports = function formatLabels(cdi, trace, fullLayout) {\n var labels = {};\n\n var subplot = fullLayout[trace.subplot]._subplot;\n labels.aLabel = Axes.tickText(subplot.aaxis, cdi.a, true).text;\n labels.bLabel = Axes.tickText(subplot.baxis, cdi.b, true).text;\n labels.cLabel = Axes.tickText(subplot.caxis, cdi.c, true).text;\n\n return labels;\n};\n","'use strict';\n\nvar scatterHover = require('../scatter/hover');\n\nmodule.exports = function hoverPoints(pointData, xval, yval, hovermode) {\n var scatterPointData = scatterHover(pointData, xval, yval, hovermode);\n if(!scatterPointData || scatterPointData[0].index === false) return;\n\n var newPointData = scatterPointData[0];\n\n // if hovering on a fill, we don't show any point data so the label is\n // unchanged from what scatter gives us - except that it needs to\n // be constrained to the trianglular plot area, not just the rectangular\n // area defined by the synthetic x and y axes\n // TODO: in some cases the vertical middle of the shape is not within\n // the triangular viewport at all, so the label can become disconnected\n // from the shape entirely. But calculating what portion of the shape\n // is actually visible, as constrained by the diagonal axis lines, is not\n // so easy and anyway we lost the information we would have needed to do\n // this inside scatterHover.\n if(newPointData.index === undefined) {\n var yFracUp = 1 - (newPointData.y0 / pointData.ya._length);\n var xLen = pointData.xa._length;\n var xMin = xLen * yFracUp / 2;\n var xMax = xLen - xMin;\n newPointData.x0 = Math.max(Math.min(newPointData.x0, xMax), xMin);\n newPointData.x1 = Math.max(Math.min(newPointData.x1, xMax), xMin);\n return scatterPointData;\n }\n\n var cdi = newPointData.cd[newPointData.index];\n var trace = newPointData.trace;\n var subplot = newPointData.subplot;\n\n newPointData.a = cdi.a;\n newPointData.b = cdi.b;\n newPointData.c = cdi.c;\n\n newPointData.xLabelVal = undefined;\n newPointData.yLabelVal = undefined;\n\n var fullLayout = {};\n fullLayout[trace.subplot] = {_subplot: subplot};\n var labels = trace._module.formatLabels(cdi, trace, fullLayout);\n newPointData.aLabel = labels.aLabel;\n newPointData.bLabel = labels.bLabel;\n newPointData.cLabel = labels.cLabel;\n\n var hoverinfo = cdi.hi || trace.hoverinfo;\n var text = [];\n function textPart(ax, val) {\n text.push(ax._hovertitle + ': ' + val);\n }\n if(!trace.hovertemplate) {\n var parts = hoverinfo.split('+');\n if(parts.indexOf('all') !== -1) parts = ['a', 'b', 'c'];\n if(parts.indexOf('a') !== -1) textPart(subplot.aaxis, newPointData.aLabel);\n if(parts.indexOf('b') !== -1) textPart(subplot.baxis, newPointData.bLabel);\n if(parts.indexOf('c') !== -1) textPart(subplot.caxis, newPointData.cLabel);\n }\n newPointData.extraText = text.join('
');\n newPointData.hovertemplate = trace.hovertemplate;\n return scatterPointData;\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../scatter/marker_colorbar'),\n formatLabels: require('./format_labels'),\n calc: require('./calc'),\n plot: require('./plot'),\n style: require('../scatter/style').style,\n styleOnSelect: require('../scatter/style').styleOnSelect,\n hoverPoints: require('./hover'),\n selectPoints: require('../scatter/select'),\n eventData: require('./event_data'),\n\n moduleType: 'trace',\n name: 'scatterternary',\n basePlotModule: require('../../plots/ternary'),\n categories: ['ternary', 'symbols', 'showLegend', 'scatter-like'],\n meta: {\n hrName: 'scatter_ternary',\n description: [\n 'Provides similar functionality to the *scatter* type but on a ternary phase diagram.',\n 'The data is provided by at least two arrays out of `a`, `b`, `c` triplets.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar scatterPlot = require('../scatter/plot');\n\nmodule.exports = function plot(gd, ternary, moduleCalcData) {\n var plotContainer = ternary.plotContainer;\n\n // remove all nodes inside the scatter layer\n plotContainer.select('.scatterlayer').selectAll('*').remove();\n\n // mimic cartesian plotinfo\n var xa = ternary.xaxis;\n var ya = ternary.yaxis;\n\n var plotinfo = {\n xaxis: xa,\n yaxis: ya,\n plot: plotContainer,\n layerClipId: ternary._hasClipOnAxisFalse ? ternary.clipIdRelative : null\n };\n\n var scatterLayer = ternary.layers.frontplot.select('g.scatterlayer');\n\n for(var i = 0; i < moduleCalcData.length; i++) {\n var cdi = moduleCalcData[i];\n if(cdi.length) {\n cdi[0].trace._xA = xa;\n cdi[0].trace._yA = ya;\n }\n }\n\n scatterPlot(gd, plotinfo, moduleCalcData, scatterLayer);\n};\n","'use strict';\n\nvar scatterAttrs = require('../scatter/attributes');\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar scatterGlAttrs = require('../scattergl/attributes');\nvar cartesianIdRegex = require('../../plots/cartesian/constants').idRegex;\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar scatterMarkerAttrs = scatterAttrs.marker;\nvar scatterMarkerLineAttrs = scatterMarkerAttrs.line;\n\nvar markerLineAttrs = extendFlat(colorScaleAttrs('marker.line', {editTypeOverride: 'calc'}), {\n width: extendFlat({}, scatterMarkerLineAttrs.width, {editType: 'calc'}),\n editType: 'calc'\n});\n\nvar markerAttrs = extendFlat(colorScaleAttrs('marker'), {\n symbol: scatterMarkerAttrs.symbol,\n angle: scatterMarkerAttrs.angle,\n size: extendFlat({}, scatterMarkerAttrs.size, {editType: 'markerSize'}),\n sizeref: scatterMarkerAttrs.sizeref,\n sizemin: scatterMarkerAttrs.sizemin,\n sizemode: scatterMarkerAttrs.sizemode,\n opacity: scatterMarkerAttrs.opacity,\n colorbar: scatterMarkerAttrs.colorbar,\n line: markerLineAttrs,\n editType: 'calc'\n});\n\nmarkerAttrs.color.editType = markerAttrs.cmin.editType = markerAttrs.cmax.editType = 'style';\n\nfunction makeAxesValObject(axLetter) {\n return {\n valType: 'info_array',\n freeLength: true,\n editType: 'calc',\n items: {\n valType: 'subplotid',\n regex: cartesianIdRegex[axLetter],\n editType: 'plot'\n },\n description: [\n 'Sets the list of ' + axLetter + ' axes',\n 'corresponding to dimensions of this splom trace.',\n 'By default, a splom will match the first N ' + axLetter + 'axes',\n 'where N is the number of input dimensions.',\n 'Note that, in case where `diagonal.visible` is false and `showupperhalf`',\n 'or `showlowerhalf` is false, this splom trace will generate',\n 'one less x-axis and one less y-axis.',\n ].join(' ')\n };\n}\n\nmodule.exports = {\n dimensions: templatedArray('dimension', {\n visible: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether or not this dimension is shown on the graph.',\n 'Note that even visible false dimension contribute to the',\n 'default grid generate by this splom trace.'\n ].join(' ')\n },\n label: {\n valType: 'string',\n editType: 'calc',\n description: 'Sets the label corresponding to this splom dimension.'\n },\n values: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: 'Sets the dimension values to be plotted.'\n },\n\n axis: {\n type: {\n valType: 'enumerated',\n values: ['linear', 'log', 'date', 'category'],\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the axis type for this dimension\\'s generated',\n 'x and y axes.',\n 'Note that the axis `type` values set in layout take',\n 'precedence over this attribute.'\n ].join(' ')\n },\n\n // TODO make 'true' the default in v3?\n matches: {\n valType: 'boolean',\n dflt: false,\n editType: 'calc',\n description: [\n 'Determines whether or not the x & y axes generated by this',\n 'dimension match.',\n 'Equivalent to setting the `matches` axis attribute in the layout',\n 'with the correct axis id.'\n ].join(' ')\n },\n\n editType: 'calc+clearAxisTypes'\n },\n\n // TODO should add an attribute to pin down x only vars and y only vars\n // like https://seaborn.pydata.org/generated/seaborn.pairplot.html\n // x_vars and y_vars\n\n // maybe more axis defaulting option e.g. `showgrid: false`\n\n editType: 'calc+clearAxisTypes'\n }),\n\n // mode: {}, (only 'markers' for now)\n\n text: extendFlat({}, scatterGlAttrs.text, {\n description: [\n 'Sets text elements associated with each (x,y) pair to appear on hover.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s (x,y) coordinates.'\n ].join(' ')\n }),\n hovertext: extendFlat({}, scatterGlAttrs.hovertext, {\n description: 'Same as `text`.'\n }),\n\n hovertemplate: hovertemplateAttrs(),\n\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n\n marker: markerAttrs,\n\n xaxes: makeAxesValObject('x'),\n yaxes: makeAxesValObject('y'),\n\n diagonal: {\n visible: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether or not subplots on the diagonal are displayed.'\n ].join(' ')\n },\n\n // type: 'scattergl' | 'histogram' | 'box' | 'violin'\n // ...\n // more options\n\n editType: 'calc'\n },\n\n showupperhalf: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether or not subplots on the upper half',\n 'from the diagonal are displayed.'\n ].join(' ')\n },\n showlowerhalf: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether or not subplots on the lower half',\n 'from the diagonal are displayed.'\n ].join(' ')\n },\n\n selected: {\n marker: scatterGlAttrs.selected.marker,\n editType: 'calc'\n },\n unselected: {\n marker: scatterGlAttrs.unselected.marker,\n editType: 'calc'\n },\n\n opacity: scatterGlAttrs.opacity\n};\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Grid = require('../../components/grid');\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'splom',\n\n categories: ['gl', 'regl', 'cartesian', 'symbols', 'showLegend', 'scatter-like'],\n\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: require('../scatter/marker_colorbar'),\n\n calc: require('./calc'),\n plot: require('./plot'),\n hoverPoints: require('./hover').hoverPoints,\n selectPoints: require('./select'),\n editStyle: require('./edit_style'),\n\n meta: {\n description: [\n 'Splom traces generate scatter plot matrix visualizations.',\n 'Each splom `dimensions` items correspond to a generated axis.',\n 'Values for each of those dimensions are set in `dimensions[i].values`.',\n 'Splom traces support all `scattergl` marker style attributes.',\n 'Specify `layout.grid` attributes and/or layout x-axis and y-axis attributes',\n 'for more control over the axis positioning and style. '\n ].join(' ')\n }\n};\n\n// splom traces use the 'grid' component to generate their axes,\n// register it here\nRegistry.register(Grid);\n","'use strict';\n\nvar createLine = require('regl-line2d');\n\nvar Registry = require('../../registry');\nvar prepareRegl = require('../../lib/prepare_regl');\nvar getModuleCalcData = require('../../plots/get_data').getModuleCalcData;\nvar Cartesian = require('../../plots/cartesian');\nvar getFromId = require('../../plots/cartesian/axis_ids').getFromId;\nvar shouldShowZeroLine = require('../../plots/cartesian/axes').shouldShowZeroLine;\n\nvar SPLOM = 'splom';\n\nvar reglPrecompiled = {};\n\nfunction plot(gd) {\n var fullLayout = gd._fullLayout;\n var _module = Registry.getModule(SPLOM);\n var splomCalcData = getModuleCalcData(gd.calcdata, _module)[0];\n\n var success = prepareRegl(gd, ['ANGLE_instanced_arrays', 'OES_element_index_uint'], reglPrecompiled);\n if(!success) return;\n\n if(fullLayout._hasOnlyLargeSploms) {\n updateGrid(gd);\n }\n\n _module.plot(gd, {}, splomCalcData);\n}\n\nfunction drag(gd) {\n var cd = gd.calcdata;\n var fullLayout = gd._fullLayout;\n\n if(fullLayout._hasOnlyLargeSploms) {\n updateGrid(gd);\n }\n\n for(var i = 0; i < cd.length; i++) {\n var cd0 = cd[i][0];\n var trace = cd0.trace;\n var scene = fullLayout._splomScenes[trace.uid];\n\n if(trace.type === 'splom' && scene && scene.matrix) {\n dragOne(gd, trace, scene);\n }\n }\n}\n\nfunction dragOne(gd, trace, scene) {\n var visibleLength = scene.matrixOptions.data.length;\n var visibleDims = trace._visibleDims;\n var ranges = scene.viewOpts.ranges = new Array(visibleLength);\n\n for(var k = 0; k < visibleDims.length; k++) {\n var i = visibleDims[k];\n var rng = ranges[k] = new Array(4);\n\n var xa = getFromId(gd, trace._diag[i][0]);\n if(xa) {\n rng[0] = xa.r2l(xa.range[0]);\n rng[2] = xa.r2l(xa.range[1]);\n }\n\n var ya = getFromId(gd, trace._diag[i][1]);\n if(ya) {\n rng[1] = ya.r2l(ya.range[0]);\n rng[3] = ya.r2l(ya.range[1]);\n }\n }\n\n if(scene.selectBatch.length || scene.unselectBatch.length) {\n scene.matrix.update({ranges: ranges}, {ranges: ranges});\n } else {\n scene.matrix.update({ranges: ranges});\n }\n}\n\nfunction updateGrid(gd) {\n var fullLayout = gd._fullLayout;\n var regl = fullLayout._glcanvas.data()[0].regl;\n var splomGrid = fullLayout._splomGrid;\n\n if(!splomGrid) {\n splomGrid = fullLayout._splomGrid = createLine(regl);\n }\n splomGrid.update(makeGridData(gd));\n}\n\nfunction makeGridData(gd) {\n var plotGlPixelRatio = gd._context.plotGlPixelRatio;\n var fullLayout = gd._fullLayout;\n var gs = fullLayout._size;\n var fullView = [\n 0, 0,\n fullLayout.width * plotGlPixelRatio,\n fullLayout.height * plotGlPixelRatio\n ];\n var lookup = {};\n var k;\n\n function push(prefix, ax, x0, x1, y0, y1) {\n x0 *= plotGlPixelRatio;\n x1 *= plotGlPixelRatio;\n y0 *= plotGlPixelRatio;\n y1 *= plotGlPixelRatio;\n\n var lcolor = ax[prefix + 'color'];\n var lwidth = ax[prefix + 'width'];\n var key = String(lcolor + lwidth);\n\n if(key in lookup) {\n lookup[key].data.push(NaN, NaN, x0, x1, y0, y1);\n } else {\n lookup[key] = {\n data: [x0, x1, y0, y1],\n join: 'rect',\n thickness: lwidth * plotGlPixelRatio,\n color: lcolor,\n viewport: fullView,\n range: fullView,\n overlay: false\n };\n }\n }\n\n for(k in fullLayout._splomSubplots) {\n var sp = fullLayout._plots[k];\n var xa = sp.xaxis;\n var ya = sp.yaxis;\n var xVals = xa._gridVals;\n var yVals = ya._gridVals;\n var xOffset = xa._offset;\n var xLength = xa._length;\n var yLength = ya._length;\n\n // ya.l2p assumes top-to-bottom coordinate system (a la SVG),\n // we need to compute bottom-to-top offsets and slopes:\n var yOffset = gs.b + ya.domain[0] * gs.h;\n var ym = -ya._m;\n var yb = -ym * ya.r2l(ya.range[0], ya.calendar);\n var x, y;\n\n if(xa.showgrid) {\n for(k = 0; k < xVals.length; k++) {\n x = xOffset + xa.l2p(xVals[k].x);\n push('grid', xa, x, yOffset, x, yOffset + yLength);\n }\n }\n if(ya.showgrid) {\n for(k = 0; k < yVals.length; k++) {\n y = yOffset + yb + ym * yVals[k].x;\n push('grid', ya, xOffset, y, xOffset + xLength, y);\n }\n }\n if(shouldShowZeroLine(gd, xa, ya)) {\n x = xOffset + xa.l2p(0);\n push('zeroline', xa, x, yOffset, x, yOffset + yLength);\n }\n if(shouldShowZeroLine(gd, ya, xa)) {\n y = yOffset + yb + 0;\n push('zeroline', ya, xOffset, y, xOffset + xLength, y);\n }\n }\n\n var gridBatches = [];\n for(k in lookup) {\n gridBatches.push(lookup[k]);\n }\n\n return gridBatches;\n}\n\nfunction clean(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var lookup = {};\n var i;\n\n if(oldFullLayout._splomScenes) {\n for(i = 0; i < newFullData.length; i++) {\n var newTrace = newFullData[i];\n if(newTrace.type === 'splom') {\n lookup[newTrace.uid] = 1;\n }\n }\n for(i = 0; i < oldFullData.length; i++) {\n var oldTrace = oldFullData[i];\n if(!lookup[oldTrace.uid]) {\n var scene = oldFullLayout._splomScenes[oldTrace.uid];\n if(scene && scene.destroy) scene.destroy();\n // must first set scene to null in order to get garbage collected\n oldFullLayout._splomScenes[oldTrace.uid] = null;\n delete oldFullLayout._splomScenes[oldTrace.uid];\n }\n }\n }\n\n if(Object.keys(oldFullLayout._splomScenes || {}).length === 0) {\n delete oldFullLayout._splomScenes;\n }\n\n if(oldFullLayout._splomGrid &&\n (!newFullLayout._hasOnlyLargeSploms && oldFullLayout._hasOnlyLargeSploms)) {\n // must first set scene to null in order to get garbage collected\n oldFullLayout._splomGrid.destroy();\n oldFullLayout._splomGrid = null;\n delete oldFullLayout._splomGrid;\n }\n\n Cartesian.clean(newFullData, newFullLayout, oldFullData, oldFullLayout);\n}\n\nmodule.exports = {\n name: SPLOM,\n attr: Cartesian.attr,\n attrRegex: Cartesian.attrRegex,\n layoutAttributes: Cartesian.layoutAttributes,\n supplyLayoutDefaults: Cartesian.supplyLayoutDefaults,\n drawFramework: Cartesian.drawFramework,\n plot: plot,\n drag: drag,\n updateGrid: updateGrid,\n clean: clean,\n updateFx: Cartesian.updateFx,\n toSVG: Cartesian.toSVG,\n reglPrecompiled: reglPrecompiled\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar AxisIDs = require('../../plots/cartesian/axis_ids');\n\nvar calcMarkerSize = require('../scatter/calc').calcMarkerSize;\nvar calcAxisExpansion = require('../scatter/calc').calcAxisExpansion;\nvar calcColorscale = require('../scatter/colorscale_calc');\nvar convertMarkerSelection = require('../scattergl/convert').markerSelection;\nvar convertMarkerStyle = require('../scattergl/convert').markerStyle;\nvar sceneUpdate = require('./scene_update');\n\nvar BADNUM = require('../../constants/numerical').BADNUM;\nvar TOO_MANY_POINTS = require('../scattergl/constants').TOO_MANY_POINTS;\n\nmodule.exports = function calc(gd, trace) {\n var dimensions = trace.dimensions;\n var commonLength = trace._length;\n var opts = {};\n // 'c' for calculated, 'l' for linear,\n // only differ here for log axes, pass ldata to createMatrix as 'data'\n var cdata = opts.cdata = [];\n var ldata = opts.data = [];\n // keep track of visible dimensions\n var visibleDims = trace._visibleDims = [];\n var i, k, dim, xa, ya;\n\n function makeCalcdata(ax, dim) {\n // call makeCalcdata with fake input\n var ccol = ax.makeCalcdata({\n v: dim.values,\n vcalendar: trace.calendar\n }, 'v');\n\n for(var j = 0; j < ccol.length; j++) {\n ccol[j] = ccol[j] === BADNUM ? NaN : ccol[j];\n }\n cdata.push(ccol);\n ldata.push(ax.type === 'log' ? Lib.simpleMap(ccol, ax.c2l) : ccol);\n }\n\n for(i = 0; i < dimensions.length; i++) {\n dim = dimensions[i];\n\n if(dim.visible) {\n xa = AxisIDs.getFromId(gd, trace._diag[i][0]);\n ya = AxisIDs.getFromId(gd, trace._diag[i][1]);\n\n // if corresponding x & y axes don't have matching types, skip dim\n if(xa && ya && xa.type !== ya.type) {\n Lib.log('Skipping splom dimension ' + i + ' with conflicting axis types');\n continue;\n }\n\n if(xa) {\n makeCalcdata(xa, dim);\n if(ya && ya.type === 'category') {\n ya._categories = xa._categories.slice();\n }\n } else {\n // should not make it here, if both xa and ya undefined\n makeCalcdata(ya, dim);\n }\n\n visibleDims.push(i);\n }\n }\n\n calcColorscale(gd, trace);\n Lib.extendFlat(opts, convertMarkerStyle(gd, trace));\n\n var visibleLength = cdata.length;\n var hasTooManyPoints = (visibleLength * commonLength) > TOO_MANY_POINTS;\n\n // Reuse SVG scatter axis expansion routine.\n // For graphs with very large number of points and array marker.size,\n // use average marker size instead to speed things up.\n var ppad;\n if(hasTooManyPoints) {\n ppad = opts.sizeAvg || Math.max(opts.size, 3);\n } else {\n ppad = calcMarkerSize(trace, commonLength);\n }\n\n for(k = 0; k < visibleDims.length; k++) {\n i = visibleDims[k];\n dim = dimensions[i];\n xa = AxisIDs.getFromId(gd, trace._diag[i][0]) || {};\n ya = AxisIDs.getFromId(gd, trace._diag[i][1]) || {};\n calcAxisExpansion(gd, trace, xa, ya, cdata[k], cdata[k], ppad);\n }\n\n var scene = sceneUpdate(gd, trace);\n if(!scene.matrix) scene.matrix = true;\n scene.matrixOptions = opts;\n\n scene.selectedOptions = convertMarkerSelection(gd, trace, trace.selected);\n scene.unselectedOptions = convertMarkerSelection(gd, trace, trace.unselected);\n\n return [{x: false, y: false, t: {}, trace: trace}];\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar attributes = require('./attributes');\nvar subTypes = require('../scatter/subtypes');\nvar handleMarkerDefaults = require('../scatter/marker_defaults');\nvar mergeLength = require('../parcoords/merge_length');\nvar isOpenSymbol = require('../scattergl/helpers').isOpenSymbol;\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var dimensions = handleArrayContainerDefaults(traceIn, traceOut, {\n name: 'dimensions',\n handleItemDefaults: dimensionDefaults\n });\n\n var showDiag = coerce('diagonal.visible');\n var showUpper = coerce('showupperhalf');\n var showLower = coerce('showlowerhalf');\n\n var dimLength = mergeLength(traceOut, dimensions, 'values');\n\n if(!dimLength || (!showDiag && !showUpper && !showLower)) {\n traceOut.visible = false;\n return;\n }\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n coerce('xhoverformat');\n coerce('yhoverformat');\n\n handleMarkerDefaults(traceIn, traceOut, defaultColor, layout, coerce, {noAngleRef: true, noStandOff: true});\n\n var isOpen = isOpenSymbol(traceOut.marker.symbol);\n var isBubble = subTypes.isBubble(traceOut);\n coerce('marker.line.width', isOpen || isBubble ? 1 : 0);\n\n handleAxisDefaults(traceIn, traceOut, layout, coerce);\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n\nfunction dimensionDefaults(dimIn, dimOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(dimIn, dimOut, attributes.dimensions, attr, dflt);\n }\n\n coerce('label');\n var values = coerce('values');\n\n if(!(values && values.length)) dimOut.visible = false;\n else coerce('visible');\n\n coerce('axis.type');\n coerce('axis.matches');\n}\n\nfunction handleAxisDefaults(traceIn, traceOut, layout, coerce) {\n var dimensions = traceOut.dimensions;\n var dimLength = dimensions.length;\n var showUpper = traceOut.showupperhalf;\n var showLower = traceOut.showlowerhalf;\n var showDiag = traceOut.diagonal.visible;\n var i, j;\n\n var xAxesDflt = new Array(dimLength);\n var yAxesDflt = new Array(dimLength);\n\n for(i = 0; i < dimLength; i++) {\n var suffix = i ? i + 1 : '';\n xAxesDflt[i] = 'x' + suffix;\n yAxesDflt[i] = 'y' + suffix;\n }\n\n var xaxes = coerce('xaxes', xAxesDflt);\n var yaxes = coerce('yaxes', yAxesDflt);\n\n // build list of [x,y] axis corresponding to each dimensions[i],\n // very useful for passing options to regl-splom\n var diag = traceOut._diag = new Array(dimLength);\n\n // lookup for 'drawn' x|y axes, to avoid costly indexOf downstream\n traceOut._xaxes = {};\n traceOut._yaxes = {};\n\n // list of 'drawn' x|y axes, use to generate list of subplots\n var xList = [];\n var yList = [];\n\n function fillAxisStashes(axId, counterAxId, dim, list) {\n if(!axId) return;\n\n var axLetter = axId.charAt(0);\n var stash = layout._splomAxes[axLetter];\n\n traceOut['_' + axLetter + 'axes'][axId] = 1;\n list.push(axId);\n\n if(!(axId in stash)) {\n var s = stash[axId] = {};\n if(dim) {\n s.label = dim.label || '';\n if(dim.visible && dim.axis) {\n if(dim.axis.type) s.type = dim.axis.type;\n if(dim.axis.matches) s.matches = counterAxId;\n }\n }\n }\n }\n\n // cases where showDiag and showLower or showUpper are false\n // no special treatment as the 'drawn' x-axes and y-axes no longer match\n // the dimensions items and xaxes|yaxes 1-to-1\n var mustShiftX = !showDiag && !showLower;\n var mustShiftY = !showDiag && !showUpper;\n\n traceOut._axesDim = {};\n for(i = 0; i < dimLength; i++) {\n var dim = dimensions[i];\n var i0 = i === 0;\n var iN = i === dimLength - 1;\n\n var xaId = (i0 && mustShiftX) || (iN && mustShiftY) ?\n undefined :\n xaxes[i];\n\n var yaId = (i0 && mustShiftY) || (iN && mustShiftX) ?\n undefined :\n yaxes[i];\n\n fillAxisStashes(xaId, yaId, dim, xList);\n fillAxisStashes(yaId, xaId, dim, yList);\n diag[i] = [xaId, yaId];\n traceOut._axesDim[xaId] = i;\n traceOut._axesDim[yaId] = i;\n }\n\n // fill in splom subplot keys\n for(i = 0; i < xList.length; i++) {\n for(j = 0; j < yList.length; j++) {\n var id = xList[i] + yList[j];\n\n if(i > j && showUpper) {\n layout._splomSubplots[id] = 1;\n } else if(i < j && showLower) {\n layout._splomSubplots[id] = 1;\n } else if(i === j && (showDiag || !showLower || !showUpper)) {\n // need to include diagonal subplots when\n // hiding one half and the diagonal\n layout._splomSubplots[id] = 1;\n }\n }\n }\n\n // when lower half is omitted, or when just the diagonal is gone,\n // override grid default to make sure axes remain on\n // the left/bottom of the plot area\n if(!showLower || (!showDiag && showUpper && showLower)) {\n layout._splomGridDflt.xside = 'bottom';\n layout._splomGridDflt.yside = 'left';\n }\n}\n","'use strict';\n\nvar Lib = require('../../lib');\nvar calcColorscale = require('../scatter/colorscale_calc');\nvar convertMarkerStyle = require('../scattergl/convert').markerStyle;\n\nmodule.exports = function editStyle(gd, cd0) {\n var trace = cd0.trace;\n var scene = gd._fullLayout._splomScenes[trace.uid];\n\n if(scene) {\n calcColorscale(gd, trace);\n\n Lib.extendFlat(scene.matrixOptions, convertMarkerStyle(gd, trace));\n // TODO [un]selected styles?\n\n var opts = Lib.extendFlat({}, scene.matrixOptions, scene.viewOpts);\n\n // TODO this is too long for arrayOk attributes!\n scene.matrix.update(opts, null);\n }\n};\n","'use strict';\n\nexports.getDimIndex = function getDimIndex(trace, ax) {\n var axId = ax._id;\n var axLetter = axId.charAt(0);\n var ind = {x: 0, y: 1}[axLetter];\n var visibleDims = trace._visibleDims;\n\n for(var k = 0; k < visibleDims.length; k++) {\n var i = visibleDims[k];\n if(trace._diag[i][ind] === axId) return k;\n }\n return false;\n};\n","'use strict';\n\nvar helpers = require('./helpers');\nvar calcHover = require('../scattergl/hover').calcHover;\nvar getFromId = require('../../plots/cartesian/axes').getFromId;\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nfunction hoverPoints(pointData, xval, yval, hovermode, opts) {\n if(!opts) opts = {};\n\n var hovermodeHasX = (hovermode || '').charAt(0) === 'x';\n var hovermodeHasY = (hovermode || '').charAt(0) === 'y';\n\n var points = _hoverPoints(pointData, xval, yval);\n\n if((hovermodeHasX || hovermodeHasY) && opts.hoversubplots === 'axis' && points[0]) {\n var subplotsWith = (\n hovermodeHasX ?\n pointData.xa :\n pointData.ya\n )._subplotsWith;\n\n var gd = opts.gd;\n\n var _pointData = extendFlat({}, pointData);\n\n for(var i = 0; i < subplotsWith.length; i++) {\n var spId = subplotsWith[i];\n\n // do not reselect on the initial subplot\n if(spId === (pointData.xa._id + pointData.ya._id)) continue;\n\n if(hovermodeHasY) {\n _pointData.xa = getFromId(gd, spId, 'x');\n } else { // hovermodeHasX\n _pointData.ya = getFromId(gd, spId, 'y');\n }\n\n var axisHoversubplots = hovermodeHasX || hovermodeHasY;\n var newPoints = _hoverPoints(_pointData, xval, yval, axisHoversubplots);\n\n points = points.concat(newPoints);\n }\n }\n\n return points;\n}\n\nfunction _hoverPoints(pointData, xval, yval, axisHoversubplots) {\n var cd = pointData.cd;\n var trace = cd[0].trace;\n var scene = pointData.scene;\n var cdata = scene.matrixOptions.cdata;\n var xa = pointData.xa;\n var ya = pointData.ya;\n var xpx = xa.c2p(xval);\n var ypx = ya.c2p(yval);\n var maxDistance = pointData.distance;\n\n var xi = helpers.getDimIndex(trace, xa);\n var yi = helpers.getDimIndex(trace, ya);\n if(xi === false || yi === false) return [pointData];\n\n var x = cdata[xi];\n var y = cdata[yi];\n\n var id, dxy;\n var minDist = maxDistance;\n\n for(var i = 0; i < x.length; i++) {\n if(axisHoversubplots && i !== pointData.index) continue;\n\n var ptx = x[i];\n var pty = y[i];\n var dx = xa.c2p(ptx) - xpx;\n var dy = ya.c2p(pty) - ypx;\n var dist = Math.sqrt(dx * dx + dy * dy);\n\n if(axisHoversubplots || dist < minDist) {\n minDist = dxy = dist;\n id = i;\n }\n }\n\n pointData.index = id;\n pointData.distance = minDist;\n pointData.dxy = dxy;\n\n if(id === undefined) return [pointData];\n\n return [calcHover(pointData, x, y, trace)];\n}\n\nmodule.exports = {\n hoverPoints: hoverPoints\n};\n","'use strict';\n\nvar index = require('./base_index');\n\nindex.basePlotModule = require('./base_plot'),\n\nmodule.exports = index;\n","'use strict';\n\nvar createMatrix = require('regl-splom');\n\nvar Lib = require('../../lib');\nvar AxisIDs = require('../../plots/cartesian/axis_ids');\nvar selectMode = require('../../components/dragelement/helpers').selectMode;\n\nmodule.exports = function plot(gd, _, splomCalcData) {\n if(!splomCalcData.length) return;\n\n for(var i = 0; i < splomCalcData.length; i++) {\n plotOne(gd, splomCalcData[i][0]);\n }\n};\n\nfunction plotOne(gd, cd0) {\n var fullLayout = gd._fullLayout;\n var gs = fullLayout._size;\n var trace = cd0.trace;\n var stash = cd0.t;\n var scene = fullLayout._splomScenes[trace.uid];\n var matrixOpts = scene.matrixOptions;\n var cdata = matrixOpts.cdata;\n var regl = fullLayout._glcanvas.data()[0].regl;\n var dragmode = fullLayout.dragmode;\n var xa, ya;\n var i, j, k;\n\n if(cdata.length === 0) return;\n\n // augment options with proper upper/lower halves\n // regl-splom's default grid starts from bottom-left\n matrixOpts.lower = trace.showupperhalf;\n matrixOpts.upper = trace.showlowerhalf;\n matrixOpts.diagonal = trace.diagonal.visible;\n\n var visibleDims = trace._visibleDims;\n var visibleLength = cdata.length;\n var viewOpts = scene.viewOpts = {};\n viewOpts.ranges = new Array(visibleLength);\n viewOpts.domains = new Array(visibleLength);\n\n for(k = 0; k < visibleDims.length; k++) {\n i = visibleDims[k];\n\n var rng = viewOpts.ranges[k] = new Array(4);\n var dmn = viewOpts.domains[k] = new Array(4);\n\n xa = AxisIDs.getFromId(gd, trace._diag[i][0]);\n if(xa) {\n rng[0] = xa._rl[0];\n rng[2] = xa._rl[1];\n dmn[0] = xa.domain[0];\n dmn[2] = xa.domain[1];\n }\n\n ya = AxisIDs.getFromId(gd, trace._diag[i][1]);\n if(ya) {\n rng[1] = ya._rl[0];\n rng[3] = ya._rl[1];\n dmn[1] = ya.domain[0];\n dmn[3] = ya.domain[1];\n }\n }\n\n var plotGlPixelRatio = gd._context.plotGlPixelRatio;\n var l = gs.l * plotGlPixelRatio;\n var b = gs.b * plotGlPixelRatio;\n var w = gs.w * plotGlPixelRatio;\n var h = gs.h * plotGlPixelRatio;\n\n viewOpts.viewport = [l, b, w + l, h + b];\n\n if(scene.matrix === true) {\n scene.matrix = createMatrix(regl);\n }\n\n var clickSelectEnabled = fullLayout.clickmode.indexOf('select') > -1;\n var isSelectMode = selectMode(dragmode) ||\n !!trace.selectedpoints || clickSelectEnabled;\n var needsBaseUpdate = true;\n\n if(isSelectMode) {\n var commonLength = trace._length;\n\n // regenerate scene batch, if traces number changed during selection\n if(trace.selectedpoints) {\n scene.selectBatch = trace.selectedpoints;\n\n var selPts = trace.selectedpoints;\n var selDict = {};\n for(i = 0; i < selPts.length; i++) {\n selDict[selPts[i]] = true;\n }\n var unselPts = [];\n for(i = 0; i < commonLength; i++) {\n if(!selDict[i]) unselPts.push(i);\n }\n scene.unselectBatch = unselPts;\n }\n\n // precalculate px coords since we are not going to pan during select\n var xpx = stash.xpx = new Array(visibleLength);\n var ypx = stash.ypx = new Array(visibleLength);\n\n for(k = 0; k < visibleDims.length; k++) {\n i = visibleDims[k];\n\n xa = AxisIDs.getFromId(gd, trace._diag[i][0]);\n if(xa) {\n xpx[k] = new Array(commonLength);\n for(j = 0; j < commonLength; j++) {\n xpx[k][j] = xa.c2p(cdata[k][j]);\n }\n }\n\n ya = AxisIDs.getFromId(gd, trace._diag[i][1]);\n if(ya) {\n ypx[k] = new Array(commonLength);\n for(j = 0; j < commonLength; j++) {\n ypx[k][j] = ya.c2p(cdata[k][j]);\n }\n }\n }\n\n if(scene.selectBatch.length || scene.unselectBatch.length) {\n var unselOpts = Lib.extendFlat({}, matrixOpts, scene.unselectedOptions, viewOpts);\n var selOpts = Lib.extendFlat({}, matrixOpts, scene.selectedOptions, viewOpts);\n scene.matrix.update(unselOpts, selOpts);\n needsBaseUpdate = false;\n }\n } else {\n stash.xpx = stash.ypx = null;\n }\n\n if(needsBaseUpdate) {\n var opts = Lib.extendFlat({}, matrixOpts, viewOpts);\n scene.matrix.update(opts, null);\n }\n}\n","'use strict';\n\nvar Lib = require('../../lib');\n\nmodule.exports = function sceneUpdate(gd, trace) {\n var fullLayout = gd._fullLayout;\n var uid = trace.uid;\n\n // must place ref to 'scene' in fullLayout, so that:\n // - it can be relinked properly on updates\n // - it can be destroyed properly when needed\n var splomScenes = fullLayout._splomScenes;\n if(!splomScenes) splomScenes = fullLayout._splomScenes = {};\n\n var reset = {\n dirty: true,\n selectBatch: [],\n unselectBatch: []\n };\n\n var first = {\n matrix: false,\n selectBatch: [],\n unselectBatch: []\n };\n\n var scene = splomScenes[trace.uid];\n\n if(!scene) {\n scene = splomScenes[uid] = Lib.extendFlat({}, reset, first);\n\n scene.draw = function draw() {\n if(scene.matrix && scene.matrix.draw) {\n if(scene.selectBatch.length || scene.unselectBatch.length) {\n scene.matrix.draw(scene.unselectBatch, scene.selectBatch);\n } else {\n scene.matrix.draw();\n }\n }\n\n scene.dirty = false;\n };\n\n // remove scene resources\n scene.destroy = function destroy() {\n if(scene.matrix && scene.matrix.destroy) {\n scene.matrix.destroy();\n }\n scene.matrixOptions = null;\n scene.selectBatch = null;\n scene.unselectBatch = null;\n scene = null;\n };\n }\n\n // In case if we have scene from the last calc - reset data\n if(!scene.dirty) {\n Lib.extendFlat(scene, reset);\n }\n\n return scene;\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar pushUnique = Lib.pushUnique;\nvar subTypes = require('../scatter/subtypes');\nvar helpers = require('./helpers');\n\nmodule.exports = function select(searchInfo, selectionTester) {\n var cd = searchInfo.cd;\n var trace = cd[0].trace;\n var stash = cd[0].t;\n var scene = searchInfo.scene;\n var cdata = scene.matrixOptions.cdata;\n var xa = searchInfo.xaxis;\n var ya = searchInfo.yaxis;\n var selection = [];\n\n if(!scene) return selection;\n\n var hasOnlyLines = (!subTypes.hasMarkers(trace) && !subTypes.hasText(trace));\n if(trace.visible !== true || hasOnlyLines) return selection;\n\n var xi = helpers.getDimIndex(trace, xa);\n var yi = helpers.getDimIndex(trace, ya);\n if(xi === false || yi === false) return selection;\n\n var xpx = stash.xpx[xi];\n var ypx = stash.ypx[yi];\n var x = cdata[xi];\n var y = cdata[yi];\n var els = (searchInfo.scene.selectBatch || []).slice();\n var unels = [];\n\n // degenerate polygon does not enable selection\n // filter out points by visible scatter ones\n if(selectionTester !== false && !selectionTester.degenerate) {\n for(var i = 0; i < x.length; i++) {\n if(selectionTester.contains([xpx[i], ypx[i]], null, i, searchInfo)) {\n selection.push({\n pointNumber: i,\n x: x[i],\n y: y[i]\n });\n\n pushUnique(els, i);\n } else if(els.indexOf(i) !== -1) {\n pushUnique(els, i);\n } else {\n unels.push(i);\n }\n }\n }\n\n var matrixOpts = scene.matrixOptions;\n\n if(!els.length && !unels.length) {\n scene.matrix.update(matrixOpts, null);\n } else if(!scene.selectBatch.length && !scene.unselectBatch.length) {\n scene.matrix.update(\n scene.unselectedOptions,\n Lib.extendFlat({}, matrixOpts, scene.selectedOptions, scene.viewOpts)\n );\n }\n\n scene.selectBatch = els;\n scene.unselectBatch = unels;\n\n return selection;\n};\n","'use strict';\n\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar mesh3dAttrs = require('../mesh3d/attributes');\nvar baseAttrs = require('../../plots/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar attrs = {\n x: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: 'Sets the x coordinates of the vector field.'\n },\n y: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: 'Sets the y coordinates of the vector field.'\n },\n z: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n description: 'Sets the z coordinates of the vector field.'\n },\n\n u: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the x components of the vector field.'\n },\n v: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the y components of the vector field.'\n },\n w: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the z components of the vector field.'\n },\n\n starts: {\n x: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the x components of the starting position of the streamtubes',\n ].join(' ')\n },\n y: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the y components of the starting position of the streamtubes',\n ].join(' ')\n },\n z: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the z components of the starting position of the streamtubes',\n ].join(' ')\n },\n editType: 'calc'\n },\n\n maxdisplayed: {\n valType: 'integer',\n min: 0,\n dflt: 1000,\n editType: 'calc',\n description: [\n 'The maximum number of displayed segments in a streamtube.'\n ].join(' ')\n },\n\n // TODO\n //\n // Should add 'absolute' (like cone traces have), but currently gl-streamtube3d's\n // `absoluteTubeSize` doesn't behave well enough for our needs.\n //\n // 'fixed' would be a nice addition to plot stream 'lines', see\n // https://github.com/plotly/plotly.js/commit/812be20750e21e0a1831975001c248d365850f73#r29129877\n //\n // sizemode: {\n // valType: 'enumerated',\n // values: ['scaled', 'absolute', 'fixed'],\n // dflt: 'scaled',\n // editType: 'calc',\n // description: [\n // 'Sets the mode by which the streamtubes are sized.'\n // ].join(' ')\n // },\n\n sizeref: {\n valType: 'number',\n editType: 'calc',\n min: 0,\n dflt: 1,\n description: [\n 'The scaling factor for the streamtubes.',\n 'The default is 1, which avoids two max divergence tubes from touching',\n 'at adjacent starting positions.'\n ].join(' ')\n },\n\n text: {\n valType: 'string',\n dflt: '',\n editType: 'calc',\n description: [\n 'Sets a text element associated with this trace.',\n 'If trace `hoverinfo` contains a *text* flag,',\n 'this text element will be seen in all hover labels.',\n 'Note that streamtube traces do not support array `text` values.'\n ].join(' ')\n },\n hovertext: {\n valType: 'string',\n dflt: '',\n editType: 'calc',\n description: 'Same as `text`.'\n },\n hovertemplate: hovertemplateAttrs({editType: 'calc'}, {\n keys: [\n 'tubex', 'tubey', 'tubez',\n 'tubeu', 'tubev', 'tubew',\n 'norm', 'divergence'\n ]\n }),\n uhoverformat: axisHoverFormat('u', 1),\n vhoverformat: axisHoverFormat('v', 1),\n whoverformat: axisHoverFormat('w', 1),\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n zhoverformat: axisHoverFormat('z'),\n\n showlegend: extendFlat({}, baseAttrs.showlegend, {dflt: false})\n};\n\nextendFlat(attrs, colorScaleAttrs('', {\n colorAttr: 'u/v/w norm',\n showScaleDflt: true,\n editTypeOverride: 'calc'\n}));\n\nvar fromMesh3d = ['opacity', 'lightposition', 'lighting'];\nfromMesh3d.forEach(function(k) {\n attrs[k] = mesh3dAttrs[k];\n});\n\nattrs.hoverinfo = extendFlat({}, baseAttrs.hoverinfo, {\n editType: 'calc',\n flags: ['x', 'y', 'z', 'u', 'v', 'w', 'norm', 'divergence', 'text', 'name'],\n dflt: 'x+y+z+norm+text+name'\n});\n\nattrs.transforms = undefined;\n\nmodule.exports = attrs;\n","'use strict';\n\nvar Lib = require('../../lib');\nvar colorscaleCalc = require('../../components/colorscale/calc');\n\nfunction calc(gd, trace) {\n trace._len = Math.min(\n trace.u.length,\n trace.v.length,\n trace.w.length,\n trace.x.length,\n trace.y.length,\n trace.z.length\n );\n\n trace._u = filter(trace.u, trace._len);\n trace._v = filter(trace.v, trace._len);\n trace._w = filter(trace.w, trace._len);\n trace._x = filter(trace.x, trace._len);\n trace._y = filter(trace.y, trace._len);\n trace._z = filter(trace.z, trace._len);\n\n var grid = processGrid(trace);\n trace._gridFill = grid.fill;\n trace._Xs = grid.Xs;\n trace._Ys = grid.Ys;\n trace._Zs = grid.Zs;\n trace._len = grid.len;\n\n var slen = 0;\n var startx, starty, startz;\n if(trace.starts) {\n startx = filter(trace.starts.x || []);\n starty = filter(trace.starts.y || []);\n startz = filter(trace.starts.z || []);\n slen = Math.min(startx.length, starty.length, startz.length);\n }\n trace._startsX = startx || [];\n trace._startsY = starty || [];\n trace._startsZ = startz || [];\n\n var normMax = 0;\n var normMin = Infinity;\n var i;\n for(i = 0; i < trace._len; i++) {\n var u = trace._u[i];\n var v = trace._v[i];\n var w = trace._w[i];\n var norm = Math.sqrt(u * u + v * v + w * w);\n\n normMax = Math.max(normMax, norm);\n normMin = Math.min(normMin, norm);\n }\n\n colorscaleCalc(gd, trace, {\n vals: [normMin, normMax],\n containerStr: '',\n cLetter: 'c'\n });\n\n for(i = 0; i < slen; i++) {\n var sx = startx[i];\n grid.xMax = Math.max(grid.xMax, sx);\n grid.xMin = Math.min(grid.xMin, sx);\n\n var sy = starty[i];\n grid.yMax = Math.max(grid.yMax, sy);\n grid.yMin = Math.min(grid.yMin, sy);\n\n var sz = startz[i];\n grid.zMax = Math.max(grid.zMax, sz);\n grid.zMin = Math.min(grid.zMin, sz);\n }\n\n trace._slen = slen;\n trace._normMax = normMax;\n trace._xbnds = [grid.xMin, grid.xMax];\n trace._ybnds = [grid.yMin, grid.yMax];\n trace._zbnds = [grid.zMin, grid.zMax];\n}\n\nfunction processGrid(trace) {\n var x = trace._x;\n var y = trace._y;\n var z = trace._z;\n var len = trace._len;\n\n var i, j, k;\n\n var xMax = -Infinity;\n var xMin = Infinity;\n var yMax = -Infinity;\n var yMin = Infinity;\n var zMax = -Infinity;\n var zMin = Infinity;\n\n var gridFill = '';\n var filledX;\n var filledY;\n var filledZ;\n var firstX, lastX;\n var firstY, lastY;\n var firstZ, lastZ;\n if(len) {\n firstX = x[0];\n firstY = y[0];\n firstZ = z[0];\n }\n if(len > 1) {\n lastX = x[len - 1];\n lastY = y[len - 1];\n lastZ = z[len - 1];\n }\n\n for(i = 0; i < len; i++) {\n xMax = Math.max(xMax, x[i]);\n xMin = Math.min(xMin, x[i]);\n\n yMax = Math.max(yMax, y[i]);\n yMin = Math.min(yMin, y[i]);\n\n zMax = Math.max(zMax, z[i]);\n zMin = Math.min(zMin, z[i]);\n\n if(!filledX && x[i] !== firstX) {\n filledX = true;\n gridFill += 'x';\n }\n if(!filledY && y[i] !== firstY) {\n filledY = true;\n gridFill += 'y';\n }\n if(!filledZ && z[i] !== firstZ) {\n filledZ = true;\n gridFill += 'z';\n }\n }\n // fill if not filled - case of having dimension(s) with one item\n if(!filledX) gridFill += 'x';\n if(!filledY) gridFill += 'y';\n if(!filledZ) gridFill += 'z';\n\n var Xs = distinctVals(trace._x);\n var Ys = distinctVals(trace._y);\n var Zs = distinctVals(trace._z);\n\n gridFill = gridFill.replace('x', (firstX > lastX ? '-' : '+') + 'x');\n gridFill = gridFill.replace('y', (firstY > lastY ? '-' : '+') + 'y');\n gridFill = gridFill.replace('z', (firstZ > lastZ ? '-' : '+') + 'z');\n\n var empty = function() {\n len = 0;\n Xs = [];\n Ys = [];\n Zs = [];\n };\n\n // Over-specified mesh case, this would error in tube2mesh\n if(!len || len < Xs.length * Ys.length * Zs.length) empty();\n\n var getArray = function(c) { return c === 'x' ? x : c === 'y' ? y : z; };\n var getVals = function(c) { return c === 'x' ? Xs : c === 'y' ? Ys : Zs; };\n var getDir = function(c) { return c[len - 1] < c[0] ? -1 : 1; };\n\n var arrK = getArray(gridFill[1]);\n var arrJ = getArray(gridFill[3]);\n var arrI = getArray(gridFill[5]);\n var nk = getVals(gridFill[1]).length;\n var nj = getVals(gridFill[3]).length;\n var ni = getVals(gridFill[5]).length;\n\n var arbitrary = false;\n\n var getIndex = function(_i, _j, _k) {\n return nk * (nj * _i + _j) + _k;\n };\n\n var dirK = getDir(getArray(gridFill[1]));\n var dirJ = getDir(getArray(gridFill[3]));\n var dirI = getDir(getArray(gridFill[5]));\n\n for(i = 0; i < ni - 1; i++) {\n for(j = 0; j < nj - 1; j++) {\n for(k = 0; k < nk - 1; k++) {\n var q000 = getIndex(i, j, k);\n var q001 = getIndex(i, j, k + 1);\n var q010 = getIndex(i, j + 1, k);\n var q100 = getIndex(i + 1, j, k);\n\n if(\n !(arrK[q000] * dirK < arrK[q001] * dirK) ||\n !(arrJ[q000] * dirJ < arrJ[q010] * dirJ) ||\n !(arrI[q000] * dirI < arrI[q100] * dirI)\n ) {\n arbitrary = true;\n }\n\n if(arbitrary) break;\n }\n if(arbitrary) break;\n }\n if(arbitrary) break;\n }\n\n if(arbitrary) {\n Lib.warn('Encountered arbitrary coordinates! Unable to input data grid.');\n empty();\n }\n\n return {\n xMin: xMin,\n yMin: yMin,\n zMin: zMin,\n xMax: xMax,\n yMax: yMax,\n zMax: zMax,\n Xs: Xs,\n Ys: Ys,\n Zs: Zs,\n len: len,\n fill: gridFill\n };\n}\n\nfunction distinctVals(col) {\n return Lib.distinctVals(col).vals;\n}\n\nfunction filter(arr, len) {\n if(len === undefined) len = arr.length;\n\n // no need for casting typed arrays to numbers\n if(Lib.isTypedArray(arr)) return arr.subarray(0, len);\n\n var values = [];\n for(var i = 0; i < len; i++) {\n values[i] = +arr[i];\n }\n return values;\n}\n\nmodule.exports = {\n calc: calc,\n filter: filter,\n processGrid: processGrid\n};\n","'use strict';\n\nvar tube2mesh = require('../../../stackgl_modules').gl_streamtube3d;\nvar createTubeMesh = tube2mesh.createTubeMesh;\n\nvar Lib = require('../../lib');\nvar parseColorScale = require('../../lib/gl_format_color').parseColorScale;\nvar extractOpts = require('../../components/colorscale').extractOpts;\nvar zip3 = require('../../plots/gl3d/zip3');\n\nvar axisName2scaleIndex = {xaxis: 0, yaxis: 1, zaxis: 2};\n\nfunction Streamtube(scene, uid) {\n this.scene = scene;\n this.uid = uid;\n this.mesh = null;\n this.data = null;\n}\n\nvar proto = Streamtube.prototype;\n\nproto.handlePick = function(selection) {\n var sceneLayout = this.scene.fullSceneLayout;\n var dataScale = this.scene.dataScale;\n\n function fromDataScale(v, axisName) {\n var ax = sceneLayout[axisName];\n var scale = dataScale[axisName2scaleIndex[axisName]];\n return ax.l2c(v) / scale;\n }\n\n if(selection.object === this.mesh) {\n var pos = selection.data.position;\n var uvx = selection.data.velocity;\n\n selection.traceCoordinate = [\n fromDataScale(pos[0], 'xaxis'),\n fromDataScale(pos[1], 'yaxis'),\n fromDataScale(pos[2], 'zaxis'),\n\n fromDataScale(uvx[0], 'xaxis'),\n fromDataScale(uvx[1], 'yaxis'),\n fromDataScale(uvx[2], 'zaxis'),\n\n // u/v/w norm\n selection.data.intensity * this.data._normMax,\n // divergence\n selection.data.divergence\n ];\n\n selection.textLabel = this.data.hovertext || this.data.text;\n\n return true;\n }\n};\n\nfunction getDfltStartingPositions(vec) {\n var len = vec.length;\n var s;\n\n if(len > 2) {\n s = vec.slice(1, len - 1);\n } else if(len === 2) {\n s = [(vec[0] + vec[1]) / 2];\n } else {\n s = vec;\n }\n return s;\n}\n\nfunction getBoundPads(vec) {\n var len = vec.length;\n if(len === 1) {\n return [0.5, 0.5];\n } else {\n return [vec[1] - vec[0], vec[len - 1] - vec[len - 2]];\n }\n}\n\nfunction convert(scene, trace) {\n var sceneLayout = scene.fullSceneLayout;\n var dataScale = scene.dataScale;\n var len = trace._len;\n var tubeOpts = {};\n\n function toDataCoords(arr, axisName) {\n var ax = sceneLayout[axisName];\n var scale = dataScale[axisName2scaleIndex[axisName]];\n return Lib.simpleMap(arr, function(v) { return ax.d2l(v) * scale; });\n }\n\n tubeOpts.vectors = zip3(\n toDataCoords(trace._u, 'xaxis'),\n toDataCoords(trace._v, 'yaxis'),\n toDataCoords(trace._w, 'zaxis'),\n len\n );\n\n // Over-specified mesh case, this would error in tube2mesh\n if(!len) {\n return {\n positions: [],\n cells: []\n };\n }\n\n var meshx = toDataCoords(trace._Xs, 'xaxis');\n var meshy = toDataCoords(trace._Ys, 'yaxis');\n var meshz = toDataCoords(trace._Zs, 'zaxis');\n\n tubeOpts.meshgrid = [meshx, meshy, meshz];\n tubeOpts.gridFill = trace._gridFill;\n\n var slen = trace._slen;\n if(slen) {\n tubeOpts.startingPositions = zip3(\n toDataCoords(trace._startsX, 'xaxis'),\n toDataCoords(trace._startsY, 'yaxis'),\n toDataCoords(trace._startsZ, 'zaxis')\n );\n } else {\n // Default starting positions:\n //\n // if len>2, cut xz plane at min-y,\n // takes all x/y/z pts on that plane except those on the edges\n // to generate \"well-defined\" tubes,\n //\n // if len=2, take position halfway between two the pts,\n //\n // if len=1, take that pt\n var sy0 = meshy[0];\n var sx = getDfltStartingPositions(meshx);\n var sz = getDfltStartingPositions(meshz);\n var startingPositions = new Array(sx.length * sz.length);\n var m = 0;\n\n for(var i = 0; i < sx.length; i++) {\n for(var k = 0; k < sz.length; k++) {\n startingPositions[m++] = [sx[i], sy0, sz[k]];\n }\n }\n tubeOpts.startingPositions = startingPositions;\n }\n\n tubeOpts.colormap = parseColorScale(trace);\n tubeOpts.tubeSize = trace.sizeref;\n tubeOpts.maxLength = trace.maxdisplayed;\n\n // add some padding around the bounds\n // to e.g. allow tubes starting from a slice of the x/y/z mesh\n // to go beyond bounds a little bit w/o getting clipped\n var xbnds = toDataCoords(trace._xbnds, 'xaxis');\n var ybnds = toDataCoords(trace._ybnds, 'yaxis');\n var zbnds = toDataCoords(trace._zbnds, 'zaxis');\n var xpads = getBoundPads(meshx);\n var ypads = getBoundPads(meshy);\n var zpads = getBoundPads(meshz);\n\n var bounds = [\n [xbnds[0] - xpads[0], ybnds[0] - ypads[0], zbnds[0] - zpads[0]],\n [xbnds[1] + xpads[1], ybnds[1] + ypads[1], zbnds[1] + zpads[1]]\n ];\n\n var meshData = tube2mesh(tubeOpts, bounds);\n\n // N.B. cmin/cmax correspond to the min/max vector norm\n // in the u/v/w arrays, which in general is NOT equal to max\n // intensity that colors the tubes.\n var cOpts = extractOpts(trace);\n meshData.vertexIntensityBounds = [cOpts.min / trace._normMax, cOpts.max / trace._normMax];\n\n // pass gl-mesh3d lighting attributes\n var lp = trace.lightposition;\n meshData.lightPosition = [lp.x, lp.y, lp.z];\n meshData.ambient = trace.lighting.ambient;\n meshData.diffuse = trace.lighting.diffuse;\n meshData.specular = trace.lighting.specular;\n meshData.roughness = trace.lighting.roughness;\n meshData.fresnel = trace.lighting.fresnel;\n meshData.opacity = trace.opacity;\n\n // stash autorange pad value\n trace._pad = meshData.tubeScale * trace.sizeref * 2;\n\n return meshData;\n}\n\nproto.update = function(data) {\n this.data = data;\n\n var meshData = convert(this.scene, data);\n this.mesh.update(meshData);\n};\n\nproto.dispose = function() {\n this.scene.glplot.remove(this.mesh);\n this.mesh.dispose();\n};\n\nfunction createStreamtubeTrace(scene, data) {\n var gl = scene.glplot.gl;\n\n var meshData = convert(scene, data);\n var mesh = createTubeMesh(gl, meshData);\n\n var streamtube = new Streamtube(scene, data.uid);\n streamtube.mesh = mesh;\n streamtube.data = data;\n mesh._trace = streamtube;\n\n scene.glplot.add(mesh);\n\n return streamtube;\n}\n\nmodule.exports = createStreamtubeTrace;\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var u = coerce('u');\n var v = coerce('v');\n var w = coerce('w');\n\n var x = coerce('x');\n var y = coerce('y');\n var z = coerce('z');\n\n if(\n !u || !u.length || !v || !v.length || !w || !w.length ||\n !x || !x.length || !y || !y.length || !z || !z.length\n ) {\n traceOut.visible = false;\n return;\n }\n\n coerce('starts.x');\n coerce('starts.y');\n coerce('starts.z');\n\n coerce('maxdisplayed');\n coerce('sizeref');\n\n coerce('lighting.ambient');\n coerce('lighting.diffuse');\n coerce('lighting.specular');\n coerce('lighting.roughness');\n coerce('lighting.fresnel');\n coerce('lightposition.x');\n coerce('lightposition.y');\n coerce('lightposition.z');\n\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'c'});\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n coerce('uhoverformat');\n coerce('vhoverformat');\n coerce('whoverformat');\n coerce('xhoverformat');\n coerce('yhoverformat');\n coerce('zhoverformat');\n\n // disable 1D transforms (for now)\n // x/y/z and u/v/w have matching lengths,\n // but they don't have to match with starts.(x|y|z)\n traceOut._length = null;\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'streamtube',\n basePlotModule: require('../../plots/gl3d'),\n categories: ['gl3d', 'showLegend'],\n\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n colorbar: {\n min: 'cmin',\n max: 'cmax'\n },\n calc: require('./calc').calc,\n plot: require('./convert'),\n eventData: function(out, pt) {\n out.tubex = out.x;\n out.tubey = out.y;\n out.tubez = out.z;\n\n out.tubeu = pt.traceCoordinate[3];\n out.tubev = pt.traceCoordinate[4];\n out.tubew = pt.traceCoordinate[5];\n\n out.norm = pt.traceCoordinate[6];\n out.divergence = pt.traceCoordinate[7];\n\n // Does not correspond to input x/y/z, so delete them\n delete out.x;\n delete out.y;\n delete out.z;\n\n return out;\n },\n\n meta: {\n description: [\n 'Use a streamtube trace to visualize flow in a vector field.',\n '',\n 'Specify a vector field using 6 1D arrays of equal length,',\n '3 position arrays `x`, `y` and `z`',\n 'and 3 vector component arrays `u`, `v`, and `w`.',\n '',\n 'By default, the tubes\\' starting positions will be cut from the vector field\\'s',\n 'x-z plane at its minimum y value.',\n 'To specify your own starting position, use attributes `starts.x`, `starts.y`',\n 'and `starts.z`.',\n 'The color is encoded by the norm of (u, v, w), and the local radius',\n 'by the divergence of (u, v, w).'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar baseAttrs = require('../../plots/attributes');\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\n\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar domainAttrs = require('../../plots/domain').attributes;\nvar pieAttrs = require('../pie/attributes');\nvar constants = require('./constants');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar pattern = require('../../components/drawing/attributes').pattern;\n\nmodule.exports = {\n labels: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the labels of each of the sectors.'\n ].join(' ')\n },\n parents: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the parent sectors for each of the sectors.',\n 'Empty string items \\'\\' are understood to reference',\n 'the root node in the hierarchy.',\n 'If `ids` is filled, `parents` items are understood to be \"ids\" themselves.',\n 'When `ids` is not set, plotly attempts to find matching items in `labels`,',\n 'but beware they must be unique.'\n ].join(' ')\n },\n\n values: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the values associated with each of the sectors.',\n 'Use with `branchvalues` to determine how the values are summed.'\n ].join(' ')\n },\n branchvalues: {\n valType: 'enumerated',\n values: ['remainder', 'total'],\n dflt: 'remainder',\n editType: 'calc',\n description: [\n 'Determines how the items in `values` are summed.',\n 'When set to *total*, items in `values` are taken to be value of all its descendants.',\n 'When set to *remainder*, items in `values` corresponding to the root and the branches sectors',\n 'are taken to be the extra part not part of the sum of the values at their leaves.'\n ].join(' ')\n },\n count: {\n valType: 'flaglist',\n flags: [\n 'branches',\n 'leaves'\n ],\n dflt: 'leaves',\n editType: 'calc',\n description: [\n 'Determines default for `values` when it is not provided,',\n 'by inferring a 1 for each of the *leaves* and/or *branches*, otherwise 0.'\n ].join(' ')\n },\n\n level: {\n valType: 'any',\n editType: 'plot',\n anim: true,\n description: [\n 'Sets the level from which this trace hierarchy is rendered.',\n 'Set `level` to `\\'\\'` to start from the root node in the hierarchy.',\n 'Must be an \"id\" if `ids` is filled in, otherwise plotly attempts to find a matching',\n 'item in `labels`.'\n ].join(' ')\n },\n maxdepth: {\n valType: 'integer',\n editType: 'plot',\n dflt: -1,\n description: [\n 'Sets the number of rendered sectors from any given `level`.',\n 'Set `maxdepth` to *-1* to render all the levels in the hierarchy.'\n ].join(' ')\n },\n\n marker: extendFlat({\n colors: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the color of each sector of this trace.',\n 'If not specified, the default trace color set is used',\n 'to pick the sector colors.'\n ].join(' ')\n },\n\n // colorinheritance: {\n // valType: 'enumerated',\n // values: ['per-branch', 'per-label', false]\n // },\n\n line: {\n color: extendFlat({}, pieAttrs.marker.line.color, {\n dflt: null,\n description: [\n 'Sets the color of the line enclosing each sector.',\n 'Defaults to the `paper_bgcolor` value.'\n ].join(' ')\n }),\n width: extendFlat({}, pieAttrs.marker.line.width, {dflt: 1}),\n editType: 'calc'\n },\n pattern: pattern,\n editType: 'calc'\n },\n colorScaleAttrs('marker', {\n colorAttr: 'colors',\n anim: false // TODO: set to anim: true?\n })\n ),\n\n leaf: {\n opacity: {\n valType: 'number',\n editType: 'style',\n min: 0,\n max: 1,\n description: [\n 'Sets the opacity of the leaves. With colorscale',\n 'it is defaulted to 1; otherwise it is defaulted to 0.7'\n ].join(' ')\n },\n editType: 'plot'\n },\n\n text: pieAttrs.text,\n textinfo: {\n valType: 'flaglist',\n flags: [\n 'label',\n 'text',\n 'value',\n 'current path',\n 'percent root',\n 'percent entry',\n 'percent parent'\n ],\n extras: ['none'],\n editType: 'plot',\n description: [\n 'Determines which trace information appear on the graph.'\n ].join(' ')\n },\n\n // TODO: incorporate `label` and `value` in the eventData\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: constants.eventDataKeys.concat(['label', 'value'])\n }),\n\n hovertext: pieAttrs.hovertext,\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: [\n 'label',\n 'text',\n 'value',\n 'name',\n 'current path',\n 'percent root',\n 'percent entry',\n 'percent parent'\n ],\n dflt: 'label+text+value+name'\n }),\n hovertemplate: hovertemplateAttrs({}, {\n keys: constants.eventDataKeys\n }),\n\n textfont: pieAttrs.textfont,\n insidetextorientation: pieAttrs.insidetextorientation,\n insidetextfont: pieAttrs.insidetextfont,\n outsidetextfont: extendFlat({}, pieAttrs.outsidetextfont, {\n description: [\n 'Sets the font used for `textinfo` lying outside the sector.',\n 'This option refers to the root of the hierarchy',\n 'presented at the center of a sunburst graph.',\n 'Please note that if a hierarchy has multiple root nodes,',\n 'this option won\\'t have any effect and `insidetextfont` would be used.'\n ].join(' ')\n }),\n rotation: {\n valType: 'angle',\n dflt: 0,\n editType: 'plot',\n description: [\n 'Rotates the whole diagram counterclockwise by some angle.',\n 'By default the first slice starts at 3 o\\'clock.'\n ].join(' ')\n },\n sort: pieAttrs.sort,\n\n root: {\n color: {\n valType: 'color',\n editType: 'calc',\n dflt: 'rgba(0,0,0,0)',\n description: [\n 'sets the color of the root node for a sunburst/treemap/icicle trace.',\n 'this has no effect when a colorscale is used to set the markers.'\n ].join(' ')\n },\n editType: 'calc'\n },\n\n domain: domainAttrs({name: 'sunburst', trace: true, editType: 'calc'})\n};\n","'use strict';\n\nvar plots = require('../../plots/plots');\n\nexports.name = 'sunburst';\n\nexports.plot = function(gd, traces, transitionOpts, makeOnCompleteCallback) {\n plots.plotBasePlot(exports.name, gd, traces, transitionOpts, makeOnCompleteCallback);\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n plots.cleanBasePlot(exports.name, newFullData, newFullLayout, oldFullData, oldFullLayout);\n};\n","'use strict';\n\nvar d3Hierarchy = require('d3-hierarchy');\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar makeColorScaleFn = require('../../components/colorscale').makeColorScaleFuncFromTrace;\nvar makePullColorFn = require('../pie/calc').makePullColorFn;\nvar generateExtendedColors = require('../pie/calc').generateExtendedColors;\nvar colorscaleCalc = require('../../components/colorscale').calc;\n\nvar ALMOST_EQUAL = require('../../constants/numerical').ALMOST_EQUAL;\n\nvar sunburstExtendedColorWays = {};\nvar treemapExtendedColorWays = {};\nvar icicleExtendedColorWays = {};\n\nexports.calc = function(gd, trace) {\n var fullLayout = gd._fullLayout;\n var ids = trace.ids;\n var hasIds = Lib.isArrayOrTypedArray(ids);\n var labels = trace.labels;\n var parents = trace.parents;\n var values = trace.values;\n var hasValues = Lib.isArrayOrTypedArray(values);\n var cd = [];\n\n var parent2children = {};\n var refs = {};\n var addToLookup = function(parent, v) {\n if(parent2children[parent]) parent2children[parent].push(v);\n else parent2children[parent] = [v];\n refs[v] = 1;\n };\n\n // treat number `0` as valid\n var isValidKey = function(k) {\n return k || typeof k === 'number';\n };\n\n var isValidVal = function(i) {\n return !hasValues || (isNumeric(values[i]) && values[i] >= 0);\n };\n\n var len;\n var isValid;\n var getId;\n\n if(hasIds) {\n len = Math.min(ids.length, parents.length);\n isValid = function(i) { return isValidKey(ids[i]) && isValidVal(i); };\n getId = function(i) { return String(ids[i]); };\n } else {\n len = Math.min(labels.length, parents.length);\n isValid = function(i) { return isValidKey(labels[i]) && isValidVal(i); };\n // TODO We could allow some label / parent duplication\n //\n // From AJ:\n // It would work OK for one level\n // (multiple rows with the same name and different parents -\n // or even the same parent) but if that name is then used as a parent\n // which one is it?\n getId = function(i) { return String(labels[i]); };\n }\n\n if(hasValues) len = Math.min(len, values.length);\n\n for(var i = 0; i < len; i++) {\n if(isValid(i)) {\n var id = getId(i);\n var pid = isValidKey(parents[i]) ? String(parents[i]) : '';\n\n var cdi = {\n i: i,\n id: id,\n pid: pid,\n label: isValidKey(labels[i]) ? String(labels[i]) : ''\n };\n\n if(hasValues) cdi.v = +values[i];\n cd.push(cdi);\n addToLookup(pid, id);\n }\n }\n\n if(!parent2children['']) {\n var impliedRoots = [];\n var k;\n for(k in parent2children) {\n if(!refs[k]) {\n impliedRoots.push(k);\n }\n }\n\n // if an `id` has no ref in the `parents` array,\n // take it as being the root node\n\n if(impliedRoots.length === 1) {\n k = impliedRoots[0];\n cd.unshift({\n hasImpliedRoot: true,\n id: k,\n pid: '',\n label: k\n });\n } else {\n return Lib.warn([\n 'Multiple implied roots, cannot build', trace.type, 'hierarchy of', trace.name + '.',\n 'These roots include:', impliedRoots.join(', ')\n ].join(' '));\n }\n } else if(parent2children[''].length > 1) {\n var dummyId = Lib.randstr();\n\n // if multiple rows linked to the root node,\n // add dummy \"root of roots\" node to make d3 build the hierarchy successfully\n\n for(var j = 0; j < cd.length; j++) {\n if(cd[j].pid === '') {\n cd[j].pid = dummyId;\n }\n }\n\n cd.unshift({\n hasMultipleRoots: true,\n id: dummyId,\n pid: '',\n label: ''\n });\n }\n\n // TODO might be better to replace stratify() with our own algorithm\n var root;\n try {\n root = d3Hierarchy.stratify()\n .id(function(d) { return d.id; })\n .parentId(function(d) { return d.pid; })(cd);\n } catch(e) {\n return Lib.warn([\n 'Failed to build', trace.type, 'hierarchy of', trace.name + '.',\n 'Error:', e.message\n ].join(' '));\n }\n\n var hierarchy = d3Hierarchy.hierarchy(root);\n var failed = false;\n\n if(hasValues) {\n switch(trace.branchvalues) {\n case 'remainder':\n hierarchy.sum(function(d) { return d.data.v; });\n break;\n case 'total':\n hierarchy.each(function(d) {\n var cdi = d.data.data;\n var v = cdi.v;\n\n if(d.children) {\n var partialSum = d.children.reduce(function(a, c) {\n return a + c.data.data.v;\n }, 0);\n\n // N.B. we must fill in `value` for generated sectors\n // with the partialSum to compute the correct partition\n if(cdi.hasImpliedRoot || cdi.hasMultipleRoots) {\n v = partialSum;\n }\n\n if(v < partialSum * ALMOST_EQUAL) {\n failed = true;\n return Lib.warn([\n 'Total value for node', d.data.data.id, 'of', trace.name,\n 'is smaller than the sum of its children.',\n '\\nparent value =', v,\n '\\nchildren sum =', partialSum\n ].join(' '));\n }\n }\n\n d.value = v;\n });\n break;\n }\n } else {\n countDescendants(hierarchy, trace, {\n branches: trace.count.indexOf('branches') !== -1,\n leaves: trace.count.indexOf('leaves') !== -1\n });\n }\n\n if(failed) return;\n\n // TODO add way to sort by height also?\n if(trace.sort) {\n hierarchy.sort(function(a, b) { return b.value - a.value; });\n }\n\n var pullColor;\n var scaleColor;\n var colors = trace.marker.colors || [];\n var hasColors = !!colors.length;\n\n if(trace._hasColorscale) {\n if(!hasColors) {\n colors = hasValues ? trace.values : trace._values;\n }\n\n colorscaleCalc(gd, trace, {\n vals: colors,\n containerStr: 'marker',\n cLetter: 'c'\n });\n\n scaleColor = makeColorScaleFn(trace.marker);\n } else {\n pullColor = makePullColorFn(fullLayout['_' + trace.type + 'colormap']);\n }\n\n // TODO keep track of 'root-children' (i.e. branch) for hover info etc.\n\n hierarchy.each(function(d) {\n var cdi = d.data.data;\n // N.B. this mutates items in `cd`\n cdi.color = trace._hasColorscale ?\n scaleColor(colors[cdi.i]) :\n pullColor(colors[cdi.i], cdi.id);\n });\n\n cd[0].hierarchy = hierarchy;\n\n return cd;\n};\n\n/*\n * `calc` filled in (and collated) explicit colors.\n * Now we need to propagate these explicit colors to other traces,\n * and fill in default colors.\n * This is done after sorting, so we pick defaults\n * in the order slices will be displayed\n */\nexports._runCrossTraceCalc = function(desiredType, gd) {\n var fullLayout = gd._fullLayout;\n var calcdata = gd.calcdata;\n var colorWay = fullLayout[desiredType + 'colorway'];\n var colorMap = fullLayout['_' + desiredType + 'colormap'];\n\n if(fullLayout['extend' + desiredType + 'colors']) {\n colorWay = generateExtendedColors(colorWay,\n desiredType === 'icicle' ? icicleExtendedColorWays :\n desiredType === 'treemap' ? treemapExtendedColorWays :\n sunburstExtendedColorWays\n );\n }\n var dfltColorCount = 0;\n\n var rootColor;\n function pickColor(d) {\n var cdi = d.data.data;\n var id = cdi.id;\n\n if(cdi.color === false) {\n if(colorMap[id]) {\n // have we seen this label and assigned a color to it in a previous trace?\n cdi.color = colorMap[id];\n } else if(d.parent) {\n if(d.parent.parent) {\n // from third-level on, inherit from parent\n cdi.color = d.parent.data.data.color;\n } else {\n // pick new color for second level\n colorMap[id] = cdi.color = colorWay[dfltColorCount % colorWay.length];\n dfltColorCount++;\n }\n } else {\n // set root color. no coloring by default.\n cdi.color = rootColor;\n }\n }\n }\n\n for(var i = 0; i < calcdata.length; i++) {\n var cd = calcdata[i];\n var cd0 = cd[0];\n if(cd0.trace.type === desiredType && cd0.hierarchy) {\n rootColor = cd0.trace.root.color;\n cd0.hierarchy.each(pickColor);\n }\n }\n};\n\nexports.crossTraceCalc = function(gd) {\n return exports._runCrossTraceCalc('sunburst', gd);\n};\n\nfunction countDescendants(node, trace, opts) {\n var nChild = 0;\n\n var children = node.children;\n if(children) {\n var len = children.length;\n\n for(var i = 0; i < len; i++) {\n nChild += countDescendants(children[i], trace, opts);\n }\n\n if(opts.branches) nChild++; // count this branch\n } else {\n if(opts.leaves) nChild++; // count this leaf\n }\n\n // save to the node\n node.value = node.data.data.value = nChild;\n\n // save to the trace\n if(!trace._values) trace._values = [];\n trace._values[node.data.data.i] = nChild;\n\n return nChild;\n}\n","'use strict';\n\nmodule.exports = {\n CLICK_TRANSITION_TIME: 750,\n CLICK_TRANSITION_EASING: 'linear',\n eventDataKeys: [\n // string\n 'currentPath',\n 'root',\n 'entry',\n // no need to add 'parent' here\n\n // percentages i.e. ratios\n 'percentRoot',\n 'percentEntry',\n 'percentParent'\n ]\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar attributes = require('./attributes');\nvar handleDomainDefaults = require('../../plots/domain').defaults;\nvar handleText = require('../bar/defaults').handleText;\nvar handleMarkerDefaults = require('../pie/defaults').handleMarkerDefaults;\n\nvar Colorscale = require('../../components/colorscale');\nvar hasColorscale = Colorscale.hasColorscale;\nvar colorscaleDefaults = Colorscale.handleDefaults;\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var labels = coerce('labels');\n var parents = coerce('parents');\n\n if(!labels || !labels.length || !parents || !parents.length) {\n traceOut.visible = false;\n return;\n }\n\n var vals = coerce('values');\n if(vals && vals.length) {\n coerce('branchvalues');\n } else {\n coerce('count');\n }\n\n coerce('level');\n coerce('maxdepth');\n\n handleMarkerDefaults(traceIn, traceOut, layout, coerce);\n\n var withColorscale = traceOut._hasColorscale = (\n hasColorscale(traceIn, 'marker', 'colors') ||\n (traceIn.marker || {}).coloraxis // N.B. special logic to consider \"values\" colorscales\n );\n if(withColorscale) {\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: 'marker.', cLetter: 'c'});\n }\n\n coerce('leaf.opacity', withColorscale ? 1 : 0.7);\n\n var text = coerce('text');\n coerce('texttemplate');\n if(!traceOut.texttemplate) coerce('textinfo', Lib.isArrayOrTypedArray(text) ? 'text+label' : 'label');\n\n coerce('hovertext');\n coerce('hovertemplate');\n\n var textposition = 'auto';\n handleText(traceIn, traceOut, layout, coerce, textposition, {\n moduleHasSelected: false,\n moduleHasUnselected: false,\n moduleHasConstrain: false,\n moduleHasCliponaxis: false,\n moduleHasTextangle: false,\n moduleHasInsideanchor: false\n });\n\n coerce('insidetextorientation');\n\n coerce('sort');\n\n coerce('rotation');\n\n coerce('root.color');\n\n handleDomainDefaults(traceOut, layout, coerce);\n\n // do not support transforms for now\n traceOut._length = null;\n};\n","'use strict';\n\nvar Drawing = require('../../components/drawing');\nvar Color = require('../../components/color');\n\nmodule.exports = function fillOne(s, pt, trace, gd, fadedColor) {\n var cdi = pt.data.data;\n var ptNumber = cdi.i;\n\n var color = fadedColor || cdi.color;\n\n if(ptNumber >= 0) {\n pt.i = cdi.i;\n\n var marker = trace.marker;\n if(marker.pattern) {\n if(!marker.colors || !marker.pattern.shape) {\n marker.color = color;\n pt.color = color;\n }\n } else {\n marker.color = color;\n pt.color = color;\n }\n\n Drawing.pointStyle(s, trace, gd, pt);\n } else {\n Color.fill(s, color);\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Registry = require('../../registry');\nvar appendArrayPointValue = require('../../components/fx/helpers').appendArrayPointValue;\nvar Fx = require('../../components/fx');\nvar Lib = require('../../lib');\nvar Events = require('../../lib/events');\n\nvar helpers = require('./helpers');\nvar pieHelpers = require('../pie/helpers');\n\nvar formatValue = pieHelpers.formatPieValue;\n\nmodule.exports = function attachFxHandlers(sliceTop, entry, gd, cd, opts) {\n var cd0 = cd[0];\n var trace = cd0.trace;\n var hierarchy = cd0.hierarchy;\n\n var isSunburst = trace.type === 'sunburst';\n var isTreemapOrIcicle =\n trace.type === 'treemap' ||\n trace.type === 'icicle';\n\n // hover state vars\n // have we drawn a hover label, so it should be cleared later\n if(!('_hasHoverLabel' in trace)) trace._hasHoverLabel = false;\n // have we emitted a hover event, so later an unhover event should be emitted\n // note that click events do not depend on this - you can still get them\n // with hovermode: false or if you were earlier dragging, then clicked\n // in the same slice that you moused up in\n if(!('_hasHoverEvent' in trace)) trace._hasHoverEvent = false;\n\n var onMouseOver = function(pt) {\n var fullLayoutNow = gd._fullLayout;\n\n if(gd._dragging || fullLayoutNow.hovermode === false) return;\n\n var traceNow = gd._fullData[trace.index];\n var cdi = pt.data.data;\n var ptNumber = cdi.i;\n var isRoot = helpers.isHierarchyRoot(pt);\n var parent = helpers.getParent(hierarchy, pt);\n\n var val = helpers.getValue(pt);\n\n var _cast = function(astr) {\n return Lib.castOption(traceNow, ptNumber, astr);\n };\n\n var hovertemplate = _cast('hovertemplate');\n var hoverinfo = Fx.castHoverinfo(traceNow, fullLayoutNow, ptNumber);\n var separators = fullLayoutNow.separators;\n\n var eventData;\n\n if(hovertemplate || (hoverinfo && hoverinfo !== 'none' && hoverinfo !== 'skip')) {\n var hoverCenterX;\n var hoverCenterY;\n if(isSunburst) {\n hoverCenterX = cd0.cx + pt.pxmid[0] * (1 - pt.rInscribed);\n hoverCenterY = cd0.cy + pt.pxmid[1] * (1 - pt.rInscribed);\n }\n if(isTreemapOrIcicle) {\n hoverCenterX = pt._hoverX;\n hoverCenterY = pt._hoverY;\n }\n\n var hoverPt = {};\n var parts = [];\n var thisText = [];\n var hasFlag = function(flag) { return parts.indexOf(flag) !== -1; };\n\n if(hoverinfo) {\n parts = hoverinfo === 'all' ?\n traceNow._module.attributes.hoverinfo.flags :\n hoverinfo.split('+');\n }\n\n hoverPt.label = cdi.label;\n if(hasFlag('label') && hoverPt.label) thisText.push(hoverPt.label);\n\n if(cdi.hasOwnProperty('v')) {\n hoverPt.value = cdi.v;\n hoverPt.valueLabel = formatValue(hoverPt.value, separators);\n if(hasFlag('value')) thisText.push(hoverPt.valueLabel);\n }\n\n hoverPt.currentPath = pt.currentPath = helpers.getPath(pt.data);\n if(hasFlag('current path') && !isRoot) {\n thisText.push(hoverPt.currentPath);\n }\n\n var tx;\n var allPercents = [];\n var insertPercent = function() {\n if(allPercents.indexOf(tx) === -1) { // no need to add redundant info\n thisText.push(tx);\n allPercents.push(tx);\n }\n };\n\n hoverPt.percentParent = pt.percentParent = val / helpers.getValue(parent);\n hoverPt.parent = pt.parentString = helpers.getPtLabel(parent);\n if(hasFlag('percent parent')) {\n tx = helpers.formatPercent(hoverPt.percentParent, separators) + ' of ' + hoverPt.parent;\n insertPercent();\n }\n\n hoverPt.percentEntry = pt.percentEntry = val / helpers.getValue(entry);\n hoverPt.entry = pt.entry = helpers.getPtLabel(entry);\n if(hasFlag('percent entry') && !isRoot && !pt.onPathbar) {\n tx = helpers.formatPercent(hoverPt.percentEntry, separators) + ' of ' + hoverPt.entry;\n insertPercent();\n }\n\n hoverPt.percentRoot = pt.percentRoot = val / helpers.getValue(hierarchy);\n hoverPt.root = pt.root = helpers.getPtLabel(hierarchy);\n if(hasFlag('percent root') && !isRoot) {\n tx = helpers.formatPercent(hoverPt.percentRoot, separators) + ' of ' + hoverPt.root;\n insertPercent();\n }\n\n hoverPt.text = _cast('hovertext') || _cast('text');\n if(hasFlag('text')) {\n tx = hoverPt.text;\n if(Lib.isValidTextValue(tx)) thisText.push(tx);\n }\n\n eventData = [makeEventData(pt, traceNow, opts.eventDataKeys)];\n\n var hoverItems = {\n trace: traceNow,\n y: hoverCenterY,\n _x0: pt._x0,\n _x1: pt._x1,\n _y0: pt._y0,\n _y1: pt._y1,\n text: thisText.join('
'),\n name: (hovertemplate || hasFlag('name')) ? traceNow.name : undefined,\n color: _cast('hoverlabel.bgcolor') || cdi.color,\n borderColor: _cast('hoverlabel.bordercolor'),\n fontFamily: _cast('hoverlabel.font.family'),\n fontSize: _cast('hoverlabel.font.size'),\n fontColor: _cast('hoverlabel.font.color'),\n fontWeight: _cast('hoverlabel.font.weight'),\n fontStyle: _cast('hoverlabel.font.style'),\n fontVariant: _cast('hoverlabel.font.variant'),\n nameLength: _cast('hoverlabel.namelength'),\n textAlign: _cast('hoverlabel.align'),\n hovertemplate: hovertemplate,\n hovertemplateLabels: hoverPt,\n eventData: eventData\n };\n\n if(isSunburst) {\n hoverItems.x0 = hoverCenterX - pt.rInscribed * pt.rpx1;\n hoverItems.x1 = hoverCenterX + pt.rInscribed * pt.rpx1;\n hoverItems.idealAlign = pt.pxmid[0] < 0 ? 'left' : 'right';\n }\n if(isTreemapOrIcicle) {\n hoverItems.x = hoverCenterX;\n hoverItems.idealAlign = hoverCenterX < 0 ? 'left' : 'right';\n }\n\n var bbox = [];\n Fx.loneHover(hoverItems, {\n container: fullLayoutNow._hoverlayer.node(),\n outerContainer: fullLayoutNow._paper.node(),\n gd: gd,\n inOut_bbox: bbox\n });\n eventData[0].bbox = bbox[0];\n\n trace._hasHoverLabel = true;\n }\n\n if(isTreemapOrIcicle) {\n var slice = sliceTop.select('path.surface');\n opts.styleOne(slice, pt, traceNow, gd, {\n hovered: true\n });\n }\n\n trace._hasHoverEvent = true;\n gd.emit('plotly_hover', {\n points: eventData || [makeEventData(pt, traceNow, opts.eventDataKeys)],\n event: d3.event\n });\n };\n\n var onMouseOut = function(evt) {\n var fullLayoutNow = gd._fullLayout;\n var traceNow = gd._fullData[trace.index];\n var pt = d3.select(this).datum();\n\n if(trace._hasHoverEvent) {\n evt.originalEvent = d3.event;\n gd.emit('plotly_unhover', {\n points: [makeEventData(pt, traceNow, opts.eventDataKeys)],\n event: d3.event\n });\n trace._hasHoverEvent = false;\n }\n\n if(trace._hasHoverLabel) {\n Fx.loneUnhover(fullLayoutNow._hoverlayer.node());\n trace._hasHoverLabel = false;\n }\n\n if(isTreemapOrIcicle) {\n var slice = sliceTop.select('path.surface');\n opts.styleOne(slice, pt, traceNow, gd, {\n hovered: false\n });\n }\n };\n\n var onClick = function(pt) {\n // TODO: this does not support right-click. If we want to support it, we\n // would likely need to change pie to use dragElement instead of straight\n // map subplots event binding. Or perhaps better, make a simple wrapper with the\n // right mousedown, mousemove, and mouseup handlers just for a left/right click\n // map subplots would use this too.\n var fullLayoutNow = gd._fullLayout;\n var traceNow = gd._fullData[trace.index];\n\n var noTransition = isSunburst && (helpers.isHierarchyRoot(pt) || helpers.isLeaf(pt));\n\n var id = helpers.getPtId(pt);\n var nextEntry = helpers.isEntry(pt) ?\n helpers.findEntryWithChild(hierarchy, id) :\n helpers.findEntryWithLevel(hierarchy, id);\n var nextLevel = helpers.getPtId(nextEntry);\n\n var typeClickEvtData = {\n points: [makeEventData(pt, traceNow, opts.eventDataKeys)],\n event: d3.event\n };\n if(!noTransition) typeClickEvtData.nextLevel = nextLevel;\n\n var clickVal = Events.triggerHandler(gd, 'plotly_' + trace.type + 'click', typeClickEvtData);\n\n if(clickVal !== false && fullLayoutNow.hovermode) {\n gd._hoverdata = [makeEventData(pt, traceNow, opts.eventDataKeys)];\n Fx.click(gd, d3.event);\n }\n\n // if click does not trigger a transition, we're done!\n if(noTransition) return;\n\n // if custom handler returns false, we're done!\n if(clickVal === false) return;\n\n // skip if triggered from dragging a nearby cartesian subplot\n if(gd._dragging) return;\n\n // skip during transitions, to avoid potential bugs\n // we could remove this check later\n if(gd._transitioning) return;\n\n // store 'old' level in guiEdit stash, so that subsequent Plotly.react\n // calls with the same uirevision can start from the same entry\n Registry.call('_storeDirectGUIEdit', traceNow, fullLayoutNow._tracePreGUI[traceNow.uid], {\n level: traceNow.level\n });\n\n var frame = {\n data: [{level: nextLevel}],\n traces: [trace.index]\n };\n\n var animOpts = {\n frame: {\n redraw: false,\n duration: opts.transitionTime\n },\n transition: {\n duration: opts.transitionTime,\n easing: opts.transitionEasing\n },\n mode: 'immediate',\n fromcurrent: true\n };\n\n Fx.loneUnhover(fullLayoutNow._hoverlayer.node());\n Registry.call('animate', gd, frame, animOpts);\n };\n\n sliceTop.on('mouseover', onMouseOver);\n sliceTop.on('mouseout', onMouseOut);\n sliceTop.on('click', onClick);\n};\n\nfunction makeEventData(pt, trace, keys) {\n var cdi = pt.data.data;\n\n var out = {\n curveNumber: trace.index,\n pointNumber: cdi.i,\n data: trace._input,\n fullData: trace,\n\n // TODO more things like 'children', 'siblings', 'hierarchy?\n };\n\n for(var i = 0; i < keys.length; i++) {\n var key = keys[i];\n if(key in pt) out[key] = pt[key];\n }\n // handle special case of parent\n if('parentString' in pt && !helpers.isHierarchyRoot(pt)) out.parent = pt.parentString;\n\n appendArrayPointValue(out, trace, cdi.i);\n\n return out;\n}\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../../components/color');\nvar setCursor = require('../../lib/setcursor');\nvar pieHelpers = require('../pie/helpers');\n\nexports.findEntryWithLevel = function(hierarchy, level) {\n var out;\n if(level) {\n hierarchy.eachAfter(function(pt) {\n if(exports.getPtId(pt) === level) {\n return out = pt.copy();\n }\n });\n }\n return out || hierarchy;\n};\n\nexports.findEntryWithChild = function(hierarchy, childId) {\n var out;\n hierarchy.eachAfter(function(pt) {\n var children = pt.children || [];\n for(var i = 0; i < children.length; i++) {\n var child = children[i];\n if(exports.getPtId(child) === childId) {\n return out = pt.copy();\n }\n }\n });\n return out || hierarchy;\n};\n\nexports.isEntry = function(pt) {\n return !pt.parent;\n};\n\nexports.isLeaf = function(pt) {\n return !pt.children;\n};\n\nexports.getPtId = function(pt) {\n return pt.data.data.id;\n};\n\nexports.getPtLabel = function(pt) {\n return pt.data.data.label;\n};\n\nexports.getValue = function(d) {\n return d.value;\n};\n\nexports.isHierarchyRoot = function(pt) {\n return getParentId(pt) === '';\n};\n\nexports.setSliceCursor = function(sliceTop, gd, opts) {\n var hide = opts.isTransitioning;\n if(!hide) {\n var pt = sliceTop.datum();\n hide = (\n (opts.hideOnRoot && exports.isHierarchyRoot(pt)) ||\n (opts.hideOnLeaves && exports.isLeaf(pt))\n );\n }\n setCursor(sliceTop, hide ? null : 'pointer');\n};\n\nfunction determineOutsideTextFont(trace, pt, layoutFont) {\n return {\n color: exports.getOutsideTextFontKey('color', trace, pt, layoutFont),\n family: exports.getOutsideTextFontKey('family', trace, pt, layoutFont),\n size: exports.getOutsideTextFontKey('size', trace, pt, layoutFont),\n weight: exports.getOutsideTextFontKey('weight', trace, pt, layoutFont),\n style: exports.getOutsideTextFontKey('style', trace, pt, layoutFont),\n variant: exports.getOutsideTextFontKey('variant', trace, pt, layoutFont),\n textcase: exports.getOutsideTextFontKey('textcase', trace, pt, layoutFont),\n lineposition: exports.getOutsideTextFontKey('lineposition', trace, pt, layoutFont),\n shadow: exports.getOutsideTextFontKey('shadow', trace, pt, layoutFont),\n };\n}\n\nfunction determineInsideTextFont(trace, pt, layoutFont, opts) {\n var onPathbar = (opts || {}).onPathbar;\n\n var cdi = pt.data.data;\n var ptNumber = cdi.i;\n\n var customColor = Lib.castOption(trace, ptNumber,\n (onPathbar ? 'pathbar.textfont' : 'insidetextfont') + '.color'\n );\n\n if(!customColor && trace._input.textfont) {\n // Why not simply using trace.textfont? Because if not set, it\n // defaults to layout.font which has a default color. But if\n // textfont.color and insidetextfont.color don't supply a value,\n // a contrasting color shall be used.\n customColor = Lib.castOption(trace._input, ptNumber, 'textfont.color');\n }\n\n return {\n color: customColor || Color.contrast(cdi.color),\n family: exports.getInsideTextFontKey('family', trace, pt, layoutFont, opts),\n size: exports.getInsideTextFontKey('size', trace, pt, layoutFont, opts),\n weight: exports.getInsideTextFontKey('weight', trace, pt, layoutFont, opts),\n style: exports.getInsideTextFontKey('style', trace, pt, layoutFont, opts),\n variant: exports.getInsideTextFontKey('variant', trace, pt, layoutFont, opts),\n textcase: exports.getInsideTextFontKey('textcase', trace, pt, layoutFont, opts),\n lineposition: exports.getInsideTextFontKey('lineposition', trace, pt, layoutFont, opts),\n shadow: exports.getInsideTextFontKey('shadow', trace, pt, layoutFont, opts),\n };\n}\n\nexports.getInsideTextFontKey = function(keyStr, trace, pt, layoutFont, opts) {\n var onPathbar = (opts || {}).onPathbar;\n var cont = onPathbar ? 'pathbar.textfont' : 'insidetextfont';\n var ptNumber = pt.data.data.i;\n\n return (\n Lib.castOption(trace, ptNumber, cont + '.' + keyStr) ||\n Lib.castOption(trace, ptNumber, 'textfont.' + keyStr) ||\n layoutFont.size\n );\n};\n\nexports.getOutsideTextFontKey = function(keyStr, trace, pt, layoutFont) {\n var ptNumber = pt.data.data.i;\n\n return (\n Lib.castOption(trace, ptNumber, 'outsidetextfont.' + keyStr) ||\n Lib.castOption(trace, ptNumber, 'textfont.' + keyStr) ||\n layoutFont.size\n );\n};\n\nexports.isOutsideText = function(trace, pt) {\n return !trace._hasColorscale && exports.isHierarchyRoot(pt);\n};\n\nexports.determineTextFont = function(trace, pt, layoutFont, opts) {\n return exports.isOutsideText(trace, pt) ?\n determineOutsideTextFont(trace, pt, layoutFont) :\n determineInsideTextFont(trace, pt, layoutFont, opts);\n};\n\nexports.hasTransition = function(transitionOpts) {\n // We could optimize hasTransition per trace,\n // as sunburst, treemap & icicle have no cross-trace logic!\n return !!(transitionOpts && transitionOpts.duration > 0);\n};\n\nexports.getMaxDepth = function(trace) {\n return trace.maxdepth >= 0 ? trace.maxdepth : Infinity;\n};\n\nexports.isHeader = function(pt, trace) { // it is only used in treemap.\n return !(exports.isLeaf(pt) || pt.depth === trace._maxDepth - 1);\n};\n\nfunction getParentId(pt) {\n return pt.data.data.pid;\n}\n\nexports.getParent = function(hierarchy, pt) {\n return exports.findEntryWithLevel(hierarchy, getParentId(pt));\n};\n\nexports.listPath = function(d, keyStr) {\n var parent = d.parent;\n if(!parent) return [];\n var list = keyStr ? [parent.data[keyStr]] : [parent];\n return exports.listPath(parent, keyStr).concat(list);\n};\n\nexports.getPath = function(d) {\n return exports.listPath(d, 'label').join('/') + '/';\n};\n\nexports.formatValue = pieHelpers.formatPieValue;\n\n// TODO: should combine the two in a separate PR - Also please note Lib.formatPercent should support separators.\nexports.formatPercent = function(v, separators) {\n var tx = Lib.formatPercent(v, 0); // use funnel(area) version\n if(tx === '0%') tx = pieHelpers.formatPiePercent(v, separators); // use pie version\n return tx;\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'sunburst',\n basePlotModule: require('./base_plot'),\n categories: [],\n animatable: true,\n\n attributes: require('./attributes'),\n layoutAttributes: require('./layout_attributes'),\n supplyDefaults: require('./defaults'),\n supplyLayoutDefaults: require('./layout_defaults'),\n\n calc: require('./calc').calc,\n crossTraceCalc: require('./calc').crossTraceCalc,\n\n plot: require('./plot').plot,\n style: require('./style').style,\n\n colorbar: require('../scatter/marker_colorbar'),\n\n meta: {\n description: [\n 'Visualize hierarchal data spanning outward radially from root to leaves.',\n 'The sunburst sectors are determined by the entries in *labels* or *ids*',\n 'and in *parents*.'\n ].join(' ')\n }\n};\n","'use strict';\n\nmodule.exports = {\n sunburstcolorway: {\n valType: 'colorlist',\n editType: 'calc',\n description: [\n 'Sets the default sunburst slice colors. Defaults to the main',\n '`colorway` used for trace colors. If you specify a new',\n 'list here it can still be extended with lighter and darker',\n 'colors, see `extendsunburstcolors`.'\n ].join(' ')\n },\n extendsunburstcolors: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'If `true`, the sunburst slice colors (whether given by `sunburstcolorway` or',\n 'inherited from `colorway`) will be extended to three times its',\n 'original length by first repeating every color 20% lighter then',\n 'each color 20% darker. This is intended to reduce the likelihood',\n 'of reusing the same color when you have many slices, but you can',\n 'set `false` to disable.',\n 'Colors provided in the trace, using `marker.colors`, are never',\n 'extended.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar layoutAttributes = require('./layout_attributes');\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n coerce('sunburstcolorway', layoutOut.colorway);\n coerce('extendsunburstcolors');\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar d3Hierarchy = require('d3-hierarchy');\nvar interpolate = require('d3-interpolate').interpolate;\n\nvar Drawing = require('../../components/drawing');\nvar Lib = require('../../lib');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar uniformText = require('../bar/uniform_text');\nvar recordMinTextSize = uniformText.recordMinTextSize;\nvar clearMinTextSize = uniformText.clearMinTextSize;\nvar piePlot = require('../pie/plot');\nvar getRotationAngle = require('../pie/helpers').getRotationAngle;\nvar computeTransform = piePlot.computeTransform;\nvar transformInsideText = piePlot.transformInsideText;\nvar styleOne = require('./style').styleOne;\nvar resizeText = require('../bar/style').resizeText;\nvar attachFxHandlers = require('./fx');\nvar constants = require('./constants');\nvar helpers = require('./helpers');\n\nexports.plot = function(gd, cdmodule, transitionOpts, makeOnCompleteCallback) {\n var fullLayout = gd._fullLayout;\n var layer = fullLayout._sunburstlayer;\n var join, onComplete;\n\n // If transition config is provided, then it is only a partial replot and traces not\n // updated are removed.\n var isFullReplot = !transitionOpts;\n var hasTransition = !fullLayout.uniformtext.mode && helpers.hasTransition(transitionOpts);\n\n clearMinTextSize('sunburst', fullLayout);\n\n join = layer.selectAll('g.trace.sunburst')\n .data(cdmodule, function(cd) { return cd[0].trace.uid; });\n\n // using same 'stroke-linejoin' as pie traces\n join.enter().append('g')\n .classed('trace', true)\n .classed('sunburst', true)\n .attr('stroke-linejoin', 'round');\n\n join.order();\n\n if(hasTransition) {\n if(makeOnCompleteCallback) {\n // If it was passed a callback to register completion, make a callback. If\n // this is created, then it must be executed on completion, otherwise the\n // pos-transition redraw will not execute:\n onComplete = makeOnCompleteCallback();\n }\n\n var transition = d3.transition()\n .duration(transitionOpts.duration)\n .ease(transitionOpts.easing)\n .each('end', function() { onComplete && onComplete(); })\n .each('interrupt', function() { onComplete && onComplete(); });\n\n transition.each(function() {\n // Must run the selection again since otherwise enters/updates get grouped together\n // and these get executed out of order. Except we need them in order!\n layer.selectAll('g.trace').each(function(cd) {\n plotOne(gd, cd, this, transitionOpts);\n });\n });\n } else {\n join.each(function(cd) {\n plotOne(gd, cd, this, transitionOpts);\n });\n\n if(fullLayout.uniformtext.mode) {\n resizeText(gd, fullLayout._sunburstlayer.selectAll('.trace'), 'sunburst');\n }\n }\n\n if(isFullReplot) {\n join.exit().remove();\n }\n};\n\nfunction plotOne(gd, cd, element, transitionOpts) {\n var isStatic = gd._context.staticPlot;\n\n var fullLayout = gd._fullLayout;\n var hasTransition = !fullLayout.uniformtext.mode && helpers.hasTransition(transitionOpts);\n\n var gTrace = d3.select(element);\n var slices = gTrace.selectAll('g.slice');\n\n var cd0 = cd[0];\n var trace = cd0.trace;\n var hierarchy = cd0.hierarchy;\n var entry = helpers.findEntryWithLevel(hierarchy, trace.level);\n var maxDepth = helpers.getMaxDepth(trace);\n\n var gs = fullLayout._size;\n var domain = trace.domain;\n var vpw = gs.w * (domain.x[1] - domain.x[0]);\n var vph = gs.h * (domain.y[1] - domain.y[0]);\n var rMax = 0.5 * Math.min(vpw, vph);\n var cx = cd0.cx = gs.l + gs.w * (domain.x[1] + domain.x[0]) / 2;\n var cy = cd0.cy = gs.t + gs.h * (1 - domain.y[0]) - vph / 2;\n\n if(!entry) {\n return slices.remove();\n }\n\n // previous root 'pt' (can be empty)\n var prevEntry = null;\n // stash of 'previous' position data used by tweening functions\n var prevLookup = {};\n\n if(hasTransition) {\n // Important: do this before binding new sliceData!\n slices.each(function(pt) {\n prevLookup[helpers.getPtId(pt)] = {\n rpx0: pt.rpx0,\n rpx1: pt.rpx1,\n x0: pt.x0,\n x1: pt.x1,\n transform: pt.transform\n };\n\n if(!prevEntry && helpers.isEntry(pt)) {\n prevEntry = pt;\n }\n });\n }\n\n // N.B. slice data isn't the calcdata,\n // grab corresponding calcdata item in sliceData[i].data.data\n var sliceData = partition(entry).descendants();\n\n var maxHeight = entry.height + 1;\n var yOffset = 0;\n var cutoff = maxDepth;\n // N.B. handle multiple-root special case\n if(cd0.hasMultipleRoots && helpers.isHierarchyRoot(entry)) {\n sliceData = sliceData.slice(1);\n maxHeight -= 1;\n yOffset = 1;\n cutoff += 1;\n }\n\n // filter out slices that won't show up on graph\n sliceData = sliceData.filter(function(pt) { return pt.y1 <= cutoff; });\n\n var baseX = getRotationAngle(trace.rotation);\n if(baseX) {\n sliceData.forEach(function(pt) {\n pt.x0 += baseX;\n pt.x1 += baseX;\n });\n }\n\n // partition span ('y') to sector radial px value\n var maxY = Math.min(maxHeight, maxDepth);\n var y2rpx = function(y) { return (y - yOffset) / maxY * rMax; };\n // (radial px value, partition angle ('x')) to px [x,y]\n var rx2px = function(r, x) { return [r * Math.cos(x), -r * Math.sin(x)]; };\n // slice path generation fn\n var pathSlice = function(d) { return Lib.pathAnnulus(d.rpx0, d.rpx1, d.x0, d.x1, cx, cy); };\n // slice text translate x/y\n\n var getTargetX = function(d) { return cx + getTextXY(d)[0] * (d.transform.rCenter || 0) + (d.transform.x || 0); };\n var getTargetY = function(d) { return cy + getTextXY(d)[1] * (d.transform.rCenter || 0) + (d.transform.y || 0); };\n\n slices = slices.data(sliceData, helpers.getPtId);\n\n slices.enter().append('g')\n .classed('slice', true);\n\n if(hasTransition) {\n slices.exit().transition()\n .each(function() {\n var sliceTop = d3.select(this);\n\n var slicePath = sliceTop.select('path.surface');\n slicePath.transition().attrTween('d', function(pt2) {\n var interp = makeExitSliceInterpolator(pt2);\n return function(t) { return pathSlice(interp(t)); };\n });\n\n var sliceTextGroup = sliceTop.select('g.slicetext');\n sliceTextGroup.attr('opacity', 0);\n })\n .remove();\n } else {\n slices.exit().remove();\n }\n\n slices.order();\n\n // next x1 (i.e. sector end angle) of previous entry\n var nextX1ofPrevEntry = null;\n if(hasTransition && prevEntry) {\n var prevEntryId = helpers.getPtId(prevEntry);\n slices.each(function(pt) {\n if(nextX1ofPrevEntry === null && (helpers.getPtId(pt) === prevEntryId)) {\n nextX1ofPrevEntry = pt.x1;\n }\n });\n }\n\n var updateSlices = slices;\n if(hasTransition) {\n updateSlices = updateSlices.transition().each('end', function() {\n // N.B. gd._transitioning is (still) *true* by the time\n // transition updates get here\n var sliceTop = d3.select(this);\n helpers.setSliceCursor(sliceTop, gd, {\n hideOnRoot: true,\n hideOnLeaves: true,\n isTransitioning: false\n });\n });\n }\n\n updateSlices.each(function(pt) {\n var sliceTop = d3.select(this);\n\n var slicePath = Lib.ensureSingle(sliceTop, 'path', 'surface', function(s) {\n s.style('pointer-events', isStatic ? 'none' : 'all');\n });\n\n pt.rpx0 = y2rpx(pt.y0);\n pt.rpx1 = y2rpx(pt.y1);\n pt.xmid = (pt.x0 + pt.x1) / 2;\n pt.pxmid = rx2px(pt.rpx1, pt.xmid);\n pt.midangle = -(pt.xmid - Math.PI / 2);\n pt.startangle = -(pt.x0 - Math.PI / 2);\n pt.stopangle = -(pt.x1 - Math.PI / 2);\n pt.halfangle = 0.5 * Math.min(Lib.angleDelta(pt.x0, pt.x1) || Math.PI, Math.PI);\n pt.ring = 1 - (pt.rpx0 / pt.rpx1);\n pt.rInscribed = getInscribedRadiusFraction(pt, trace);\n\n if(hasTransition) {\n slicePath.transition().attrTween('d', function(pt2) {\n var interp = makeUpdateSliceInterpolator(pt2);\n return function(t) { return pathSlice(interp(t)); };\n });\n } else {\n slicePath.attr('d', pathSlice);\n }\n\n sliceTop\n .call(attachFxHandlers, entry, gd, cd, {\n eventDataKeys: constants.eventDataKeys,\n transitionTime: constants.CLICK_TRANSITION_TIME,\n transitionEasing: constants.CLICK_TRANSITION_EASING\n })\n .call(helpers.setSliceCursor, gd, {\n hideOnRoot: true,\n hideOnLeaves: true,\n isTransitioning: gd._transitioning\n });\n\n slicePath.call(styleOne, pt, trace, gd);\n\n var sliceTextGroup = Lib.ensureSingle(sliceTop, 'g', 'slicetext');\n var sliceText = Lib.ensureSingle(sliceTextGroup, 'text', '', function(s) {\n // prohibit tex interpretation until we can handle\n // tex and regular text together\n s.attr('data-notex', 1);\n });\n\n var font = Lib.ensureUniformFontSize(gd, helpers.determineTextFont(trace, pt, fullLayout.font));\n\n sliceText.text(exports.formatSliceLabel(pt, entry, trace, cd, fullLayout))\n .classed('slicetext', true)\n .attr('text-anchor', 'middle')\n .call(Drawing.font, font)\n .call(svgTextUtils.convertToTspans, gd);\n\n // position the text relative to the slice\n var textBB = Drawing.bBox(sliceText.node());\n pt.transform = transformInsideText(textBB, pt, cd0);\n pt.transform.targetX = getTargetX(pt);\n pt.transform.targetY = getTargetY(pt);\n\n var strTransform = function(d, textBB) {\n var transform = d.transform;\n computeTransform(transform, textBB);\n\n transform.fontSize = font.size;\n recordMinTextSize(trace.type, transform, fullLayout);\n\n return Lib.getTextTransform(transform);\n };\n\n if(hasTransition) {\n sliceText.transition().attrTween('transform', function(pt2) {\n var interp = makeUpdateTextInterpolator(pt2);\n return function(t) { return strTransform(interp(t), textBB); };\n });\n } else {\n sliceText.attr('transform', strTransform(pt, textBB));\n }\n });\n\n function makeExitSliceInterpolator(pt) {\n var id = helpers.getPtId(pt);\n var prev = prevLookup[id];\n var entryPrev = prevLookup[helpers.getPtId(entry)];\n var next;\n\n if(entryPrev) {\n var a = (pt.x1 > entryPrev.x1 ? 2 * Math.PI : 0) + baseX;\n // if pt to remove:\n // - if 'below' where the root-node used to be: shrink it radially inward\n // - otherwise, collapse it clockwise or counterclockwise which ever is shortest to theta=0\n next = pt.rpx1 < entryPrev.rpx1 ?\n {x0: pt.x0, x1: pt.x1, rpx0: 0, rpx1: 0} :\n {x0: a, x1: a, rpx0: pt.rpx0, rpx1: pt.rpx1};\n } else {\n // this happens when maxdepth is set, when leaves must\n // be removed and the rootPt is new (i.e. does not have a 'prev' object)\n var parent;\n var parentId = helpers.getPtId(pt.parent);\n slices.each(function(pt2) {\n if(helpers.getPtId(pt2) === parentId) {\n return parent = pt2;\n }\n });\n var parentChildren = parent.children;\n var ci;\n parentChildren.forEach(function(pt2, i) {\n if(helpers.getPtId(pt2) === id) {\n return ci = i;\n }\n });\n var n = parentChildren.length;\n var interp = interpolate(parent.x0, parent.x1);\n next = {\n rpx0: rMax, rpx1: rMax,\n x0: interp(ci / n), x1: interp((ci + 1) / n)\n };\n }\n\n return interpolate(prev, next);\n }\n\n function makeUpdateSliceInterpolator(pt) {\n var prev0 = prevLookup[helpers.getPtId(pt)];\n var prev;\n var next = {x0: pt.x0, x1: pt.x1, rpx0: pt.rpx0, rpx1: pt.rpx1};\n\n if(prev0) {\n // if pt already on graph, this is easy\n prev = prev0;\n } else {\n // for new pts:\n if(prevEntry) {\n // if trace was visible before\n if(pt.parent) {\n if(nextX1ofPrevEntry) {\n // if new branch, twist it in clockwise or\n // counterclockwise which ever is shorter to\n // its final angle\n var a = (pt.x1 > nextX1ofPrevEntry ? 2 * Math.PI : 0) + baseX;\n prev = {x0: a, x1: a};\n } else {\n // if new leaf (when maxdepth is set),\n // grow it radially and angularly from\n // its parent node\n prev = {rpx0: rMax, rpx1: rMax};\n Lib.extendFlat(prev, interpX0X1FromParent(pt));\n }\n } else {\n // if new root-node, grow it radially\n prev = {rpx0: 0, rpx1: 0};\n }\n } else {\n // start sector of new traces from theta=0\n prev = {x0: baseX, x1: baseX};\n }\n }\n\n return interpolate(prev, next);\n }\n\n function makeUpdateTextInterpolator(pt) {\n var prev0 = prevLookup[helpers.getPtId(pt)];\n var prev;\n var transform = pt.transform;\n\n if(prev0) {\n prev = prev0;\n } else {\n prev = {\n rpx1: pt.rpx1,\n transform: {\n textPosAngle: transform.textPosAngle,\n scale: 0,\n rotate: transform.rotate,\n rCenter: transform.rCenter,\n x: transform.x,\n y: transform.y\n }\n };\n\n // for new pts:\n if(prevEntry) {\n // if trace was visible before\n if(pt.parent) {\n if(nextX1ofPrevEntry) {\n // if new branch, twist it in clockwise or\n // counterclockwise which ever is shorter to\n // its final angle\n var a = pt.x1 > nextX1ofPrevEntry ? 2 * Math.PI : 0;\n prev.x0 = prev.x1 = a;\n } else {\n // if leaf\n Lib.extendFlat(prev, interpX0X1FromParent(pt));\n }\n } else {\n // if new root-node\n prev.x0 = prev.x1 = baseX;\n }\n } else {\n // on new traces\n prev.x0 = prev.x1 = baseX;\n }\n }\n\n var textPosAngleFn = interpolate(prev.transform.textPosAngle, pt.transform.textPosAngle);\n var rpx1Fn = interpolate(prev.rpx1, pt.rpx1);\n var x0Fn = interpolate(prev.x0, pt.x0);\n var x1Fn = interpolate(prev.x1, pt.x1);\n var scaleFn = interpolate(prev.transform.scale, transform.scale);\n var rotateFn = interpolate(prev.transform.rotate, transform.rotate);\n\n // smooth out start/end from entry, to try to keep text inside sector\n // while keeping transition smooth\n var pow = transform.rCenter === 0 ? 3 :\n prev.transform.rCenter === 0 ? 1 / 3 :\n 1;\n var _rCenterFn = interpolate(prev.transform.rCenter, transform.rCenter);\n var rCenterFn = function(t) { return _rCenterFn(Math.pow(t, pow)); };\n\n return function(t) {\n var rpx1 = rpx1Fn(t);\n var x0 = x0Fn(t);\n var x1 = x1Fn(t);\n var rCenter = rCenterFn(t);\n var pxmid = rx2px(rpx1, (x0 + x1) / 2);\n var textPosAngle = textPosAngleFn(t);\n\n var d = {\n pxmid: pxmid,\n rpx1: rpx1,\n transform: {\n textPosAngle: textPosAngle,\n rCenter: rCenter,\n x: transform.x,\n y: transform.y\n }\n };\n\n recordMinTextSize(trace.type, transform, fullLayout);\n return {\n transform: {\n targetX: getTargetX(d),\n targetY: getTargetY(d),\n scale: scaleFn(t),\n rotate: rotateFn(t),\n rCenter: rCenter\n }\n };\n };\n }\n\n function interpX0X1FromParent(pt) {\n var parent = pt.parent;\n var parentPrev = prevLookup[helpers.getPtId(parent)];\n var out = {};\n\n if(parentPrev) {\n // if parent is visible\n var parentChildren = parent.children;\n var ci = parentChildren.indexOf(pt);\n var n = parentChildren.length;\n var interp = interpolate(parentPrev.x0, parentPrev.x1);\n out.x0 = interp(ci / n);\n out.x1 = interp(ci / n);\n } else {\n // w/o visible parent\n // TODO !!! HOW ???\n out.x0 = out.x1 = 0;\n }\n\n return out;\n }\n}\n\n// x[0-1] keys are angles [radians]\n// y[0-1] keys are hierarchy heights [integers]\nfunction partition(entry) {\n return d3Hierarchy.partition()\n .size([2 * Math.PI, entry.height + 1])(entry);\n}\n\nexports.formatSliceLabel = function(pt, entry, trace, cd, fullLayout) {\n var texttemplate = trace.texttemplate;\n var textinfo = trace.textinfo;\n\n if(!texttemplate && (!textinfo || textinfo === 'none')) {\n return '';\n }\n\n var separators = fullLayout.separators;\n var cd0 = cd[0];\n var cdi = pt.data.data;\n var hierarchy = cd0.hierarchy;\n var isRoot = helpers.isHierarchyRoot(pt);\n var parent = helpers.getParent(hierarchy, pt);\n var val = helpers.getValue(pt);\n\n if(!texttemplate) {\n var parts = textinfo.split('+');\n var hasFlag = function(flag) { return parts.indexOf(flag) !== -1; };\n var thisText = [];\n var tx;\n\n if(hasFlag('label') && cdi.label) {\n thisText.push(cdi.label);\n }\n\n if(cdi.hasOwnProperty('v') && hasFlag('value')) {\n thisText.push(helpers.formatValue(cdi.v, separators));\n }\n\n if(!isRoot) {\n if(hasFlag('current path')) {\n thisText.push(helpers.getPath(pt.data));\n }\n\n var nPercent = 0;\n if(hasFlag('percent parent')) nPercent++;\n if(hasFlag('percent entry')) nPercent++;\n if(hasFlag('percent root')) nPercent++;\n var hasMultiplePercents = nPercent > 1;\n\n if(nPercent) {\n var percent;\n var addPercent = function(key) {\n tx = helpers.formatPercent(percent, separators);\n\n if(hasMultiplePercents) tx += ' of ' + key;\n thisText.push(tx);\n };\n\n if(hasFlag('percent parent') && !isRoot) {\n percent = val / helpers.getValue(parent);\n addPercent('parent');\n }\n if(hasFlag('percent entry')) {\n percent = val / helpers.getValue(entry);\n addPercent('entry');\n }\n if(hasFlag('percent root')) {\n percent = val / helpers.getValue(hierarchy);\n addPercent('root');\n }\n }\n }\n\n if(hasFlag('text')) {\n tx = Lib.castOption(trace, cdi.i, 'text');\n if(Lib.isValidTextValue(tx)) thisText.push(tx);\n }\n\n return thisText.join('
');\n }\n\n var txt = Lib.castOption(trace, cdi.i, 'texttemplate');\n if(!txt) return '';\n var obj = {};\n if(cdi.label) obj.label = cdi.label;\n if(cdi.hasOwnProperty('v')) {\n obj.value = cdi.v;\n obj.valueLabel = helpers.formatValue(cdi.v, separators);\n }\n\n obj.currentPath = helpers.getPath(pt.data);\n\n if(!isRoot) {\n obj.percentParent = val / helpers.getValue(parent);\n obj.percentParentLabel = helpers.formatPercent(\n obj.percentParent, separators\n );\n obj.parent = helpers.getPtLabel(parent);\n }\n\n obj.percentEntry = val / helpers.getValue(entry);\n obj.percentEntryLabel = helpers.formatPercent(\n obj.percentEntry, separators\n );\n obj.entry = helpers.getPtLabel(entry);\n\n obj.percentRoot = val / helpers.getValue(hierarchy);\n obj.percentRootLabel = helpers.formatPercent(\n obj.percentRoot, separators\n );\n obj.root = helpers.getPtLabel(hierarchy);\n\n if(cdi.hasOwnProperty('color')) {\n obj.color = cdi.color;\n }\n var ptTx = Lib.castOption(trace, cdi.i, 'text');\n if(Lib.isValidTextValue(ptTx) || ptTx === '') obj.text = ptTx;\n obj.customdata = Lib.castOption(trace, cdi.i, 'customdata');\n return Lib.texttemplateString(txt, obj, fullLayout._d3locale, obj, trace._meta || {});\n};\n\nfunction getInscribedRadiusFraction(pt) {\n if(pt.rpx0 === 0 && Lib.isFullCircle([pt.x0, pt.x1])) {\n // special case of 100% with no hole\n return 1;\n } else {\n return Math.max(0, Math.min(\n 1 / (1 + 1 / Math.sin(pt.halfangle)),\n pt.ring / 2\n ));\n }\n}\n\nfunction getTextXY(d) {\n return getCoords(d.rpx1, d.transform.textPosAngle);\n}\n\nfunction getCoords(r, angle) {\n return [r * Math.sin(angle), -r * Math.cos(angle)];\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Color = require('../../components/color');\nvar Lib = require('../../lib');\nvar resizeText = require('../bar/uniform_text').resizeText;\nvar fillOne = require('./fill_one');\n\nfunction style(gd) {\n var s = gd._fullLayout._sunburstlayer.selectAll('.trace');\n resizeText(gd, s, 'sunburst');\n\n s.each(function(cd) {\n var gTrace = d3.select(this);\n var cd0 = cd[0];\n var trace = cd0.trace;\n\n gTrace.style('opacity', trace.opacity);\n\n gTrace.selectAll('path.surface').each(function(pt) {\n d3.select(this).call(styleOne, pt, trace, gd);\n });\n });\n}\n\nfunction styleOne(s, pt, trace, gd) {\n var cdi = pt.data.data;\n var isLeaf = !pt.children;\n var ptNumber = cdi.i;\n var lineColor = Lib.castOption(trace, ptNumber, 'marker.line.color') || Color.defaultLine;\n var lineWidth = Lib.castOption(trace, ptNumber, 'marker.line.width') || 0;\n\n s.call(fillOne, pt, trace, gd)\n .style('stroke-width', lineWidth)\n .call(Color.stroke, lineColor)\n .style('opacity', isLeaf ? trace.leaf.opacity : null);\n}\n\nmodule.exports = {\n style: style,\n styleOne: styleOne\n};\n","'use strict';\n\nvar Color = require('../../components/color');\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar baseAttrs = require('../../plots/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\n\nfunction makeContourProjAttr(axLetter) {\n return {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether or not these contour lines are projected',\n 'on the', axLetter, 'plane.',\n 'If `highlight` is set to *true* (the default), the projected',\n 'lines are shown on hover.',\n 'If `show` is set to *true*, the projected lines are shown',\n 'in permanence.'\n ].join(' ')\n };\n}\n\nfunction makeContourAttr(axLetter) {\n return {\n show: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether or not contour lines about the', axLetter,\n 'dimension are drawn.'\n ].join(' ')\n },\n start: {\n valType: 'number',\n dflt: null,\n editType: 'plot',\n // impliedEdits: {'^autocontour': false},\n description: [\n 'Sets the starting contour level value.',\n 'Must be less than `contours.end`'\n ].join(' ')\n },\n end: {\n valType: 'number',\n dflt: null,\n editType: 'plot',\n // impliedEdits: {'^autocontour': false},\n description: [\n 'Sets the end contour level value.',\n 'Must be more than `contours.start`'\n ].join(' ')\n },\n size: {\n valType: 'number',\n dflt: null,\n min: 0,\n editType: 'plot',\n // impliedEdits: {'^autocontour': false},\n description: [\n 'Sets the step between each contour level.',\n 'Must be positive.'\n ].join(' ')\n },\n project: {\n x: makeContourProjAttr('x'),\n y: makeContourProjAttr('y'),\n z: makeContourProjAttr('z')\n },\n color: {\n valType: 'color',\n dflt: Color.defaultLine,\n description: 'Sets the color of the contour lines.'\n },\n usecolormap: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'An alternate to *color*.',\n 'Determines whether or not the contour lines are colored using',\n 'the trace *colorscale*.'\n ].join(' ')\n },\n width: {\n valType: 'number',\n min: 1,\n max: 16,\n dflt: 2,\n description: 'Sets the width of the contour lines.'\n },\n highlight: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Determines whether or not contour lines about the', axLetter,\n 'dimension are highlighted on hover.'\n ].join(' ')\n },\n highlightcolor: {\n valType: 'color',\n dflt: Color.defaultLine,\n description: 'Sets the color of the highlighted contour lines.'\n },\n highlightwidth: {\n valType: 'number',\n min: 1,\n max: 16,\n dflt: 2,\n description: 'Sets the width of the highlighted contour lines.'\n }\n };\n}\n\nvar attrs = module.exports = overrideAll(extendFlat({\n z: {\n valType: 'data_array',\n description: 'Sets the z coordinates.'\n },\n x: {\n valType: 'data_array',\n description: 'Sets the x coordinates.'\n },\n y: {\n valType: 'data_array',\n description: 'Sets the y coordinates.'\n },\n\n text: {\n valType: 'string',\n dflt: '',\n arrayOk: true,\n description: [\n 'Sets the text elements associated with each z value.',\n 'If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,',\n 'these elements will be seen in the hover labels.'\n ].join(' ')\n },\n hovertext: {\n valType: 'string',\n dflt: '',\n arrayOk: true,\n description: 'Same as `text`.'\n },\n hovertemplate: hovertemplateAttrs(),\n\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n zhoverformat: axisHoverFormat('z'),\n\n connectgaps: {\n valType: 'boolean',\n dflt: false,\n editType: 'calc',\n description: [\n 'Determines whether or not gaps',\n '(i.e. {nan} or missing values)',\n 'in the `z` data are filled in.'\n ].join(' ')\n },\n\n surfacecolor: {\n valType: 'data_array',\n description: [\n 'Sets the surface color values,',\n 'used for setting a color scale independent of `z`.'\n ].join(' ')\n },\n},\n\ncolorScaleAttrs('', {\n colorAttr: 'z or surfacecolor',\n showScaleDflt: true,\n autoColorDflt: false,\n editTypeOverride: 'calc'\n}), {\n contours: {\n x: makeContourAttr('x'),\n y: makeContourAttr('y'),\n z: makeContourAttr('z')\n },\n hidesurface: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether or not a surface is drawn.',\n 'For example, set `hidesurface` to *false*',\n '`contours.x.show` to *true* and',\n '`contours.y.show` to *true* to draw a wire frame plot.'\n ].join(' ')\n },\n\n lightposition: {\n x: {\n valType: 'number',\n min: -1e5,\n max: 1e5,\n dflt: 10,\n description: 'Numeric vector, representing the X coordinate for each vertex.'\n },\n y: {\n valType: 'number',\n min: -1e5,\n max: 1e5,\n dflt: 1e4,\n description: 'Numeric vector, representing the Y coordinate for each vertex.'\n },\n z: {\n valType: 'number',\n min: -1e5,\n max: 1e5,\n dflt: 0,\n description: 'Numeric vector, representing the Z coordinate for each vertex.'\n }\n },\n\n lighting: {\n ambient: {\n valType: 'number',\n min: 0.00,\n max: 1.0,\n dflt: 0.8,\n description: 'Ambient light increases overall color visibility but can wash out the image.'\n },\n diffuse: {\n valType: 'number',\n min: 0.00,\n max: 1.00,\n dflt: 0.8,\n description: 'Represents the extent that incident rays are reflected in a range of angles.'\n },\n specular: {\n valType: 'number',\n min: 0.00,\n max: 2.00,\n dflt: 0.05,\n description: 'Represents the level that incident rays are reflected in a single direction, causing shine.'\n },\n roughness: {\n valType: 'number',\n min: 0.00,\n max: 1.00,\n dflt: 0.5,\n description: 'Alters specular reflection; the rougher the surface, the wider and less contrasty the shine.'\n },\n fresnel: {\n valType: 'number',\n min: 0.00,\n max: 5.00,\n dflt: 0.2,\n description: [\n 'Represents the reflectance as a dependency of the viewing angle; e.g. paper is reflective',\n 'when viewing it from the edge of the paper (almost 90 degrees), causing shine.'\n ].join(' ')\n }\n },\n\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n description: [\n 'Sets the opacity of the surface.',\n 'Please note that in the case of using high `opacity` values for example a value',\n 'greater than or equal to 0.5 on two surfaces (and 0.25 with four surfaces), an',\n 'overlay of multiple transparent surfaces may not perfectly be sorted in depth by the',\n 'webgl API. This behavior may be improved in the near future and is subject to change.'\n ].join(' ')\n },\n\n opacityscale: {\n valType: 'any',\n editType: 'calc',\n description: [\n 'Sets the opacityscale.',\n 'The opacityscale must be an array containing',\n 'arrays mapping a normalized value to an opacity value.',\n 'At minimum, a mapping for the lowest (0) and highest (1)',\n 'values are required. For example,',\n '`[[0, 1], [0.5, 0.2], [1, 1]]` means that higher/lower values would have',\n 'higher opacity values and those in the middle would be more transparent',\n 'Alternatively, `opacityscale` may be a palette name string',\n 'of the following list: \\'min\\', \\'max\\', \\'extremes\\' and \\'uniform\\'.',\n 'The default is \\'uniform\\'.'\n ].join(' ')\n },\n\n _deprecated: {\n zauto: extendFlat({}, colorScaleAttrs.zauto, {\n description: 'Obsolete. Use `cauto` instead.'\n }),\n zmin: extendFlat({}, colorScaleAttrs.zmin, {\n description: 'Obsolete. Use `cmin` instead.'\n }),\n zmax: extendFlat({}, colorScaleAttrs.zmax, {\n description: 'Obsolete. Use `cmax` instead.'\n })\n },\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo),\n showlegend: extendFlat({}, baseAttrs.showlegend, {dflt: false}),\n}), 'calc', 'nested');\n\nattrs.x.editType = attrs.y.editType = attrs.z.editType = 'calc+clearAxisTypes';\nattrs.transforms = undefined;\n","'use strict';\n\nvar colorscaleCalc = require('../../components/colorscale/calc');\n\n\n// Compute auto-z and autocolorscale if applicable\nmodule.exports = function calc(gd, trace) {\n if(trace.surfacecolor) {\n colorscaleCalc(gd, trace, {\n vals: trace.surfacecolor,\n containerStr: '',\n cLetter: 'c'\n });\n } else {\n colorscaleCalc(gd, trace, {\n vals: trace.z,\n containerStr: '',\n cLetter: 'c'\n });\n }\n};\n","'use strict';\n\nvar createSurface = require('../../../stackgl_modules').gl_surface3d;\n\nvar ndarray = require('../../../stackgl_modules').ndarray;\nvar ndarrayInterp2d = require('../../../stackgl_modules').ndarray_linear_interpolate.d2;\n\nvar interp2d = require('../heatmap/interp2d');\nvar findEmpties = require('../heatmap/find_empties');\n\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar parseColorScale = require('../../lib/gl_format_color').parseColorScale;\nvar str2RgbaArray = require('../../lib/str2rgbarray');\nvar extractOpts = require('../../components/colorscale').extractOpts;\n\nfunction SurfaceTrace(scene, surface, uid) {\n this.scene = scene;\n this.uid = uid;\n this.surface = surface;\n this.data = null;\n this.showContour = [false, false, false];\n this.contourStart = [null, null, null];\n this.contourEnd = [null, null, null];\n this.contourSize = [0, 0, 0];\n this.minValues = [Infinity, Infinity, Infinity];\n this.maxValues = [-Infinity, -Infinity, -Infinity];\n this.dataScaleX = 1.0;\n this.dataScaleY = 1.0;\n this.refineData = true;\n this.objectOffset = [0, 0, 0];\n}\n\nvar proto = SurfaceTrace.prototype;\n\nproto.getXat = function(a, b, calendar, axis) {\n var v = (\n (!isArrayOrTypedArray(this.data.x)) ?\n a :\n (isArrayOrTypedArray(this.data.x[0])) ?\n this.data.x[b][a] :\n this.data.x[a]\n );\n\n return (calendar === undefined) ? v : axis.d2l(v, 0, calendar);\n};\n\nproto.getYat = function(a, b, calendar, axis) {\n var v = (\n (!isArrayOrTypedArray(this.data.y)) ?\n b :\n (isArrayOrTypedArray(this.data.y[0])) ?\n this.data.y[b][a] :\n this.data.y[b]\n );\n\n return (calendar === undefined) ? v : axis.d2l(v, 0, calendar);\n};\n\nproto.getZat = function(a, b, calendar, axis) {\n var v = this.data.z[b][a];\n\n if(v === null && this.data.connectgaps && this.data._interpolatedZ) {\n v = this.data._interpolatedZ[b][a];\n }\n\n return (calendar === undefined) ? v : axis.d2l(v, 0, calendar);\n};\n\nproto.handlePick = function(selection) {\n if(selection.object === this.surface) {\n var xRatio = (selection.data.index[0] - 1) / this.dataScaleX - 1;\n var yRatio = (selection.data.index[1] - 1) / this.dataScaleY - 1;\n\n var j = Math.max(Math.min(Math.round(xRatio), this.data.z[0].length - 1), 0);\n var k = Math.max(Math.min(Math.round(yRatio), this.data._ylength - 1), 0);\n\n selection.index = [j, k];\n\n selection.traceCoordinate = [\n this.getXat(j, k),\n this.getYat(j, k),\n this.getZat(j, k)\n ];\n\n selection.dataCoordinate = [\n this.getXat(j, k, this.data.xcalendar, this.scene.fullSceneLayout.xaxis),\n this.getYat(j, k, this.data.ycalendar, this.scene.fullSceneLayout.yaxis),\n this.getZat(j, k, this.data.zcalendar, this.scene.fullSceneLayout.zaxis)\n ];\n\n for(var i = 0; i < 3; i++) {\n var v = selection.dataCoordinate[i];\n if(v !== null && v !== undefined) {\n selection.dataCoordinate[i] *= this.scene.dataScale[i];\n }\n }\n\n var text = this.data.hovertext || this.data.text;\n if(isArrayOrTypedArray(text) && text[k] && text[k][j] !== undefined) {\n selection.textLabel = text[k][j];\n } else if(text) {\n selection.textLabel = text;\n } else {\n selection.textLabel = '';\n }\n\n selection.data.dataCoordinate = selection.dataCoordinate.slice();\n\n this.surface.highlight(selection.data);\n\n // Snap spikes to data coordinate\n this.scene.glplot.spikes.position = selection.dataCoordinate;\n\n return true;\n }\n};\n\nfunction isColormapCircular(colormap) {\n var first = colormap[0].rgb;\n var last = colormap[colormap.length - 1].rgb;\n\n return (\n first[0] === last[0] &&\n first[1] === last[1] &&\n first[2] === last[2] &&\n first[3] === last[3]\n );\n}\n\nvar shortPrimes = [\n 2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97,\n 101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199,\n 211, 223, 227, 229, 233, 239, 241, 251, 257, 263, 269, 271, 277, 281, 283, 293,\n 307, 311, 313, 317, 331, 337, 347, 349, 353, 359, 367, 373, 379, 383, 389, 397,\n 401, 409, 419, 421, 431, 433, 439, 443, 449, 457, 461, 463, 467, 479, 487, 491, 499,\n 503, 509, 521, 523, 541, 547, 557, 563, 569, 571, 577, 587, 593, 599,\n 601, 607, 613, 617, 619, 631, 641, 643, 647, 653, 659, 661, 673, 677, 683, 691,\n 701, 709, 719, 727, 733, 739, 743, 751, 757, 761, 769, 773, 787, 797,\n 809, 811, 821, 823, 827, 829, 839, 853, 857, 859, 863, 877, 881, 883, 887,\n 907, 911, 919, 929, 937, 941, 947, 953, 967, 971, 977, 983, 991, 997,\n 1009, 1013, 1019, 1021, 1031, 1033, 1039, 1049, 1051, 1061, 1063, 1069, 1087, 1091, 1093, 1097,\n 1103, 1109, 1117, 1123, 1129, 1151, 1153, 1163, 1171, 1181, 1187, 1193,\n 1201, 1213, 1217, 1223, 1229, 1231, 1237, 1249, 1259, 1277, 1279, 1283, 1289, 1291, 1297,\n 1301, 1303, 1307, 1319, 1321, 1327, 1361, 1367, 1373, 1381, 1399,\n 1409, 1423, 1427, 1429, 1433, 1439, 1447, 1451, 1453, 1459, 1471, 1481, 1483, 1487, 1489, 1493, 1499,\n 1511, 1523, 1531, 1543, 1549, 1553, 1559, 1567, 1571, 1579, 1583, 1597,\n 1601, 1607, 1609, 1613, 1619, 1621, 1627, 1637, 1657, 1663, 1667, 1669, 1693, 1697, 1699,\n 1709, 1721, 1723, 1733, 1741, 1747, 1753, 1759, 1777, 1783, 1787, 1789,\n 1801, 1811, 1823, 1831, 1847, 1861, 1867, 1871, 1873, 1877, 1879, 1889,\n 1901, 1907, 1913, 1931, 1933, 1949, 1951, 1973, 1979, 1987, 1993, 1997, 1999,\n 2003, 2011, 2017, 2027, 2029, 2039, 2053, 2063, 2069, 2081, 2083, 2087, 2089, 2099,\n 2111, 2113, 2129, 2131, 2137, 2141, 2143, 2153, 2161, 2179,\n 2203, 2207, 2213, 2221, 2237, 2239, 2243, 2251, 2267, 2269, 2273, 2281, 2287, 2293, 2297,\n 2309, 2311, 2333, 2339, 2341, 2347, 2351, 2357, 2371, 2377, 2381, 2383, 2389, 2393, 2399,\n 2411, 2417, 2423, 2437, 2441, 2447, 2459, 2467, 2473, 2477,\n 2503, 2521, 2531, 2539, 2543, 2549, 2551, 2557, 2579, 2591, 2593,\n 2609, 2617, 2621, 2633, 2647, 2657, 2659, 2663, 2671, 2677, 2683, 2687, 2689, 2693, 2699,\n 2707, 2711, 2713, 2719, 2729, 2731, 2741, 2749, 2753, 2767, 2777, 2789, 2791, 2797,\n 2801, 2803, 2819, 2833, 2837, 2843, 2851, 2857, 2861, 2879, 2887, 2897,\n 2903, 2909, 2917, 2927, 2939, 2953, 2957, 2963, 2969, 2971, 2999\n];\n\nfunction getPow(a, b) {\n if(a < b) return 0;\n var n = 0;\n while(Math.floor(a % b) === 0) {\n a /= b;\n n++;\n }\n return n;\n}\n\nfunction getFactors(a) {\n var powers = [];\n for(var i = 0; i < shortPrimes.length; i++) {\n var b = shortPrimes[i];\n powers.push(\n getPow(a, b)\n );\n }\n return powers;\n}\n\nfunction smallestDivisor(a) {\n var A = getFactors(a);\n var result = a;\n for(var i = 0; i < shortPrimes.length; i++) {\n if(A[i] > 0) {\n result = shortPrimes[i];\n break;\n }\n }\n return result;\n}\n\nfunction leastCommonMultiple(a, b) {\n if(a < 1 || b < 1) return undefined;\n var A = getFactors(a);\n var B = getFactors(b);\n var n = 1;\n for(var i = 0; i < shortPrimes.length; i++) {\n n *= Math.pow(\n shortPrimes[i], Math.max(A[i], B[i])\n );\n }\n return n;\n}\n\nfunction arrayLCM(A) {\n if(A.length === 0) return undefined;\n var n = 1;\n for(var i = 0; i < A.length; i++) {\n n = leastCommonMultiple(n, A[i]);\n }\n return n;\n}\n\nproto.calcXnums = function(xlen) {\n var i;\n var nums = [];\n for(i = 1; i < xlen; i++) {\n var a = this.getXat(i - 1, 0);\n var b = this.getXat(i, 0);\n\n if(b !== a &&\n a !== undefined && a !== null &&\n b !== undefined && b !== null) {\n nums[i - 1] = Math.abs(b - a);\n } else {\n nums[i - 1] = 0;\n }\n }\n\n var totalDist = 0;\n for(i = 1; i < xlen; i++) {\n totalDist += nums[i - 1];\n }\n\n for(i = 1; i < xlen; i++) {\n if(nums[i - 1] === 0) {\n nums[i - 1] = 1;\n } else {\n nums[i - 1] = Math.round(totalDist / nums[i - 1]);\n }\n }\n\n return nums;\n};\n\nproto.calcYnums = function(ylen) {\n var i;\n var nums = [];\n for(i = 1; i < ylen; i++) {\n var a = this.getYat(0, i - 1);\n var b = this.getYat(0, i);\n\n if(b !== a &&\n a !== undefined && a !== null &&\n b !== undefined && b !== null) {\n nums[i - 1] = Math.abs(b - a);\n } else {\n nums[i - 1] = 0;\n }\n }\n\n var totalDist = 0;\n for(i = 1; i < ylen; i++) {\n totalDist += nums[i - 1];\n }\n\n for(i = 1; i < ylen; i++) {\n if(nums[i - 1] === 0) {\n nums[i - 1] = 1;\n } else {\n nums[i - 1] = Math.round(totalDist / nums[i - 1]);\n }\n }\n\n return nums;\n};\n\nvar highlyComposites = [1, 2, 4, 6, 12, 24, 36, 48, 60, 120, 180, 240, 360, 720, 840, 1260];\n\nvar MIN_RESOLUTION = highlyComposites[9];\nvar MAX_RESOLUTION = highlyComposites[13];\n\nproto.estimateScale = function(resSrc, axis) {\n var nums = (axis === 0) ?\n this.calcXnums(resSrc) :\n this.calcYnums(resSrc);\n\n var resDst = 1 + arrayLCM(nums);\n\n while(resDst < MIN_RESOLUTION) {\n resDst *= 2;\n }\n\n while(resDst > MAX_RESOLUTION) {\n resDst--;\n resDst /= smallestDivisor(resDst);\n resDst++;\n\n if(resDst < MIN_RESOLUTION) {\n // resDst = MIN_RESOLUTION; // option 1: use min resolution\n resDst = MAX_RESOLUTION; // option 2: use max resolution\n }\n }\n\n var scale = Math.round(resDst / resSrc);\n return (scale > 1) ? scale : 1;\n};\n\n// based on Mikola Lysenko's ndarray-homography\n// see https://github.com/scijs/ndarray-homography\n\nfunction fnHomography(out, inp, X) {\n var w = X[8] + X[2] * inp[0] + X[5] * inp[1];\n out[0] = (X[6] + X[0] * inp[0] + X[3] * inp[1]) / w;\n out[1] = (X[7] + X[1] * inp[0] + X[4] * inp[1]) / w;\n return out;\n}\n\nfunction homography(dest, src, X) {\n warp(dest, src, fnHomography, X);\n return dest;\n}\n\n// based on Mikola Lysenko's ndarray-warp\n// see https://github.com/scijs/ndarray-warp\n\nfunction warp(dest, src, func, X) {\n var warped = [0, 0];\n var ni = dest.shape[0];\n var nj = dest.shape[1];\n for(var i = 0; i < ni; i++) {\n for(var j = 0; j < nj; j++) {\n func(warped, [i, j], X);\n dest.set(i, j, ndarrayInterp2d(src, warped[0], warped[1]));\n }\n }\n return dest;\n}\n\nproto.refineCoords = function(coords) {\n var scaleW = this.dataScaleX;\n var scaleH = this.dataScaleY;\n\n var width = coords[0].shape[0];\n var height = coords[0].shape[1];\n\n var newWidth = Math.floor(coords[0].shape[0] * scaleW + 1) | 0;\n var newHeight = Math.floor(coords[0].shape[1] * scaleH + 1) | 0;\n\n // Pad coords by +1\n var padWidth = 1 + width + 1;\n var padHeight = 1 + height + 1;\n var padImg = ndarray(new Float32Array(padWidth * padHeight), [padWidth, padHeight]);\n var X = [\n 1 / scaleW, 0, 0,\n 0, 1 / scaleH, 0,\n 0, 0, 1\n ];\n\n for(var i = 0; i < coords.length; ++i) {\n this.surface.padField(padImg, coords[i]);\n\n var scaledImg = ndarray(new Float32Array(newWidth * newHeight), [newWidth, newHeight]);\n homography(scaledImg, padImg, X);\n coords[i] = scaledImg;\n }\n};\n\nfunction insertIfNewLevel(arr, newValue) {\n var found = false;\n for(var k = 0; k < arr.length; k++) {\n if(newValue === arr[k]) {\n found = true;\n break;\n }\n }\n if(found === false) arr.push(newValue);\n}\n\nproto.setContourLevels = function() {\n var newLevels = [[], [], []];\n var useNewLevels = [false, false, false];\n var needsUpdate = false;\n\n var i, j, value;\n\n for(i = 0; i < 3; ++i) {\n if(this.showContour[i]) {\n needsUpdate = true;\n\n if(\n this.contourSize[i] > 0 &&\n this.contourStart[i] !== null &&\n this.contourEnd[i] !== null &&\n this.contourEnd[i] > this.contourStart[i]\n ) {\n useNewLevels[i] = true;\n\n for(j = this.contourStart[i]; j < this.contourEnd[i]; j += this.contourSize[i]) {\n value = j * this.scene.dataScale[i];\n\n insertIfNewLevel(newLevels[i], value);\n }\n }\n }\n }\n\n if(needsUpdate) {\n var allLevels = [[], [], []];\n for(i = 0; i < 3; ++i) {\n if(this.showContour[i]) {\n allLevels[i] = useNewLevels[i] ? newLevels[i] : this.scene.contourLevels[i];\n }\n }\n this.surface.update({ levels: allLevels });\n }\n};\n\nproto.update = function(data) {\n var scene = this.scene;\n var sceneLayout = scene.fullSceneLayout;\n var surface = this.surface;\n var colormap = parseColorScale(data);\n var scaleFactor = scene.dataScale;\n var xlen = data.z[0].length;\n var ylen = data._ylength;\n var contourLevels = scene.contourLevels;\n\n // Save data\n this.data = data;\n\n /*\n * Fill and transpose zdata.\n * Consistent with 'heatmap' and 'contour', plotly 'surface'\n * 'z' are such that sub-arrays correspond to y-coords\n * and that the sub-array entries correspond to a x-coords,\n * which is the transpose of 'gl-surface-plot'.\n */\n\n var i, j, k, v;\n var rawCoords = [];\n for(i = 0; i < 3; i++) {\n rawCoords[i] = [];\n for(j = 0; j < xlen; j++) {\n rawCoords[i][j] = [];\n /*\n for(k = 0; k < ylen; k++) {\n rawCoords[i][j][k] = undefined;\n }\n */\n }\n }\n\n // coords x, y & z\n for(j = 0; j < xlen; j++) {\n for(k = 0; k < ylen; k++) {\n rawCoords[0][j][k] = this.getXat(j, k, data.xcalendar, sceneLayout.xaxis);\n rawCoords[1][j][k] = this.getYat(j, k, data.ycalendar, sceneLayout.yaxis);\n rawCoords[2][j][k] = this.getZat(j, k, data.zcalendar, sceneLayout.zaxis);\n }\n }\n\n if(data.connectgaps) {\n data._emptypoints = findEmpties(rawCoords[2]);\n interp2d(rawCoords[2], data._emptypoints);\n\n data._interpolatedZ = [];\n for(j = 0; j < xlen; j++) {\n data._interpolatedZ[j] = [];\n for(k = 0; k < ylen; k++) {\n data._interpolatedZ[j][k] = rawCoords[2][j][k];\n }\n }\n }\n\n // Note: log axes are not defined in surfaces yet.\n // but they could be defined here...\n\n for(i = 0; i < 3; i++) {\n for(j = 0; j < xlen; j++) {\n for(k = 0; k < ylen; k++) {\n v = rawCoords[i][j][k];\n if(v === null || v === undefined) {\n rawCoords[i][j][k] = NaN;\n } else {\n v = rawCoords[i][j][k] *= scaleFactor[i];\n }\n }\n }\n }\n\n for(i = 0; i < 3; i++) {\n for(j = 0; j < xlen; j++) {\n for(k = 0; k < ylen; k++) {\n v = rawCoords[i][j][k];\n if(v !== null && v !== undefined) {\n if(this.minValues[i] > v) {\n this.minValues[i] = v;\n }\n if(this.maxValues[i] < v) {\n this.maxValues[i] = v;\n }\n }\n }\n }\n }\n\n for(i = 0; i < 3; i++) {\n this.objectOffset[i] = 0.5 * (this.minValues[i] + this.maxValues[i]);\n }\n\n for(i = 0; i < 3; i++) {\n for(j = 0; j < xlen; j++) {\n for(k = 0; k < ylen; k++) {\n v = rawCoords[i][j][k];\n if(v !== null && v !== undefined) {\n rawCoords[i][j][k] -= this.objectOffset[i];\n }\n }\n }\n }\n\n // convert processed raw data to Float32 matrices\n var coords = [\n ndarray(new Float32Array(xlen * ylen), [xlen, ylen]),\n ndarray(new Float32Array(xlen * ylen), [xlen, ylen]),\n ndarray(new Float32Array(xlen * ylen), [xlen, ylen])\n ];\n for(i = 0; i < 3; i++) {\n for(j = 0; j < xlen; j++) {\n for(k = 0; k < ylen; k++) {\n coords[i].set(j, k, rawCoords[i][j][k]);\n }\n }\n }\n rawCoords = []; // free memory\n\n var params = {\n colormap: colormap,\n levels: [[], [], []],\n showContour: [true, true, true],\n showSurface: !data.hidesurface,\n contourProject: [\n [false, false, false],\n [false, false, false],\n [false, false, false]\n ],\n contourWidth: [1, 1, 1],\n contourColor: [[1, 1, 1, 1], [1, 1, 1, 1], [1, 1, 1, 1]],\n contourTint: [1, 1, 1],\n dynamicColor: [[1, 1, 1, 1], [1, 1, 1, 1], [1, 1, 1, 1]],\n dynamicWidth: [1, 1, 1],\n dynamicTint: [1, 1, 1],\n opacityscale: data.opacityscale,\n opacity: data.opacity\n };\n\n var cOpts = extractOpts(data);\n params.intensityBounds = [cOpts.min, cOpts.max];\n\n // Refine surface color if necessary\n if(data.surfacecolor) {\n var intensity = ndarray(new Float32Array(xlen * ylen), [xlen, ylen]);\n\n for(j = 0; j < xlen; j++) {\n for(k = 0; k < ylen; k++) {\n intensity.set(j, k, data.surfacecolor[k][j]);\n }\n }\n\n coords.push(intensity);\n } else {\n // when 'z' is used as 'intensity',\n // we must scale its value\n params.intensityBounds[0] *= scaleFactor[2];\n params.intensityBounds[1] *= scaleFactor[2];\n }\n\n if(MAX_RESOLUTION < coords[0].shape[0] ||\n MAX_RESOLUTION < coords[0].shape[1]) {\n this.refineData = false;\n }\n\n if(this.refineData === true) {\n this.dataScaleX = this.estimateScale(coords[0].shape[0], 0);\n this.dataScaleY = this.estimateScale(coords[0].shape[1], 1);\n if(this.dataScaleX !== 1 || this.dataScaleY !== 1) {\n this.refineCoords(coords);\n }\n }\n\n if(data.surfacecolor) {\n params.intensity = coords.pop();\n }\n\n var highlightEnable = [true, true, true];\n var axis = ['x', 'y', 'z'];\n\n for(i = 0; i < 3; ++i) {\n var contourParams = data.contours[axis[i]];\n highlightEnable[i] = contourParams.highlight;\n\n params.showContour[i] = contourParams.show || contourParams.highlight;\n if(!params.showContour[i]) continue;\n\n params.contourProject[i] = [\n contourParams.project.x,\n contourParams.project.y,\n contourParams.project.z\n ];\n\n if(contourParams.show) {\n this.showContour[i] = true;\n params.levels[i] = contourLevels[i];\n surface.highlightColor[i] = params.contourColor[i] = str2RgbaArray(contourParams.color);\n\n if(contourParams.usecolormap) {\n surface.highlightTint[i] = params.contourTint[i] = 0;\n } else {\n surface.highlightTint[i] = params.contourTint[i] = 1;\n }\n params.contourWidth[i] = contourParams.width;\n\n this.contourStart[i] = contourParams.start;\n this.contourEnd[i] = contourParams.end;\n this.contourSize[i] = contourParams.size;\n } else {\n this.showContour[i] = false;\n\n this.contourStart[i] = null;\n this.contourEnd[i] = null;\n this.contourSize[i] = 0;\n }\n\n if(contourParams.highlight) {\n params.dynamicColor[i] = str2RgbaArray(contourParams.highlightcolor);\n params.dynamicWidth[i] = contourParams.highlightwidth;\n }\n }\n\n // see https://github.com/plotly/plotly.js/issues/940\n if(isColormapCircular(colormap)) {\n params.vertexColor = true;\n }\n\n params.objectOffset = this.objectOffset;\n\n params.coords = coords;\n surface.update(params);\n\n surface.visible = data.visible;\n surface.enableDynamic = highlightEnable;\n surface.enableHighlight = highlightEnable;\n\n surface.snapToData = true;\n\n if('lighting' in data) {\n surface.ambientLight = data.lighting.ambient;\n surface.diffuseLight = data.lighting.diffuse;\n surface.specularLight = data.lighting.specular;\n surface.roughness = data.lighting.roughness;\n surface.fresnel = data.lighting.fresnel;\n }\n\n if('lightposition' in data) {\n surface.lightPosition = [data.lightposition.x, data.lightposition.y, data.lightposition.z];\n }\n};\n\nproto.dispose = function() {\n this.scene.glplot.remove(this.surface);\n this.surface.dispose();\n};\n\nfunction createSurfaceTrace(scene, data) {\n var gl = scene.glplot.gl;\n var surface = createSurface({ gl: gl });\n var result = new SurfaceTrace(scene, surface, data.uid);\n surface._trace = result;\n result.update(data);\n scene.glplot.add(surface);\n return result;\n}\n\nmodule.exports = createSurfaceTrace;\n","'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\n\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar attributes = require('./attributes');\n\nvar MIN = 0.1; // Note: often we don't want the data cube to be disappeared\n\nfunction createWave(n, minOpacity) {\n var arr = [];\n var steps = 32; // Max: 256\n for(var i = 0; i < steps; i++) {\n var u = i / (steps - 1);\n var v = minOpacity + (1 - minOpacity) * (1 - Math.pow(Math.sin(n * u * Math.PI), 2));\n arr.push([\n u,\n Math.max(0, Math.min(1, v))\n ]);\n }\n return arr;\n}\n\nfunction isValidScaleArray(scl) {\n var highestVal = 0;\n\n if(!Array.isArray(scl) || scl.length < 2) return false;\n\n if(!scl[0] || !scl[scl.length - 1]) return false;\n\n if(+scl[0][0] !== 0 || +scl[scl.length - 1][0] !== 1) return false;\n\n for(var i = 0; i < scl.length; i++) {\n var si = scl[i];\n\n if(si.length !== 2 || +si[0] < highestVal) {\n return false;\n }\n\n highestVal = +si[0];\n }\n\n return true;\n}\n\nfunction supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n var i, j;\n\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var x = coerce('x');\n var y = coerce('y');\n\n var z = coerce('z');\n if(!z || !z.length ||\n (x ? (x.length < 1) : false) ||\n (y ? (y.length < 1) : false)\n ) {\n traceOut.visible = false;\n return;\n }\n\n traceOut._xlength = (Array.isArray(x) && Lib.isArrayOrTypedArray(x[0])) ? z.length : z[0].length;\n traceOut._ylength = z.length;\n\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleTraceDefaults');\n handleCalendarDefaults(traceIn, traceOut, ['x', 'y', 'z'], layout);\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n coerce('xhoverformat');\n coerce('yhoverformat');\n coerce('zhoverformat');\n\n // Coerce remaining properties\n [\n 'lighting.ambient',\n 'lighting.diffuse',\n 'lighting.specular',\n 'lighting.roughness',\n 'lighting.fresnel',\n 'lightposition.x',\n 'lightposition.y',\n 'lightposition.z',\n 'hidesurface',\n 'connectgaps',\n 'opacity'\n ].forEach(function(x) { coerce(x); });\n\n var surfaceColor = coerce('surfacecolor');\n\n var dims = ['x', 'y', 'z'];\n for(i = 0; i < 3; ++i) {\n var contourDim = 'contours.' + dims[i];\n var show = coerce(contourDim + '.show');\n var highlight = coerce(contourDim + '.highlight');\n\n if(show || highlight) {\n for(j = 0; j < 3; ++j) {\n coerce(contourDim + '.project.' + dims[j]);\n }\n }\n\n if(show) {\n coerce(contourDim + '.color');\n coerce(contourDim + '.width');\n coerce(contourDim + '.usecolormap');\n }\n\n if(highlight) {\n coerce(contourDim + '.highlightcolor');\n coerce(contourDim + '.highlightwidth');\n }\n\n coerce(contourDim + '.start');\n coerce(contourDim + '.end');\n coerce(contourDim + '.size');\n }\n\n // backward compatibility block\n if(!surfaceColor) {\n mapLegacy(traceIn, 'zmin', 'cmin');\n mapLegacy(traceIn, 'zmax', 'cmax');\n mapLegacy(traceIn, 'zauto', 'cauto');\n }\n\n // TODO if contours.?.usecolormap are false and hidesurface is true\n // the colorbar shouldn't be shown by default\n\n colorscaleDefaults(\n traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'c'}\n );\n\n opacityscaleDefaults(traceIn, traceOut, layout, coerce);\n\n // disable 1D transforms - currently surface does NOT support column data like heatmap does\n // you can use mesh3d for this use case, but not surface\n traceOut._length = null;\n}\n\nfunction opacityscaleDefaults(traceIn, traceOut, layout, coerce) {\n var opacityscale = coerce('opacityscale');\n if(opacityscale === 'max') {\n traceOut.opacityscale = [[0, MIN], [1, 1]];\n } else if(opacityscale === 'min') {\n traceOut.opacityscale = [[0, 1], [1, MIN]];\n } else if(opacityscale === 'extremes') {\n traceOut.opacityscale = createWave(1, MIN);\n } else if(!isValidScaleArray(opacityscale)) {\n traceOut.opacityscale = undefined;\n }\n}\n\nfunction mapLegacy(traceIn, oldAttr, newAttr) {\n if(oldAttr in traceIn && !(newAttr in traceIn)) {\n traceIn[newAttr] = traceIn[oldAttr];\n }\n}\n\nmodule.exports = {\n supplyDefaults: supplyDefaults,\n opacityscaleDefaults: opacityscaleDefaults\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults').supplyDefaults,\n colorbar: {\n min: 'cmin',\n max: 'cmax'\n },\n calc: require('./calc'),\n plot: require('./convert'),\n\n moduleType: 'trace',\n name: 'surface',\n basePlotModule: require('../../plots/gl3d'),\n categories: ['gl3d', '2dMap', 'showLegend'],\n meta: {\n description: [\n 'The data the describes the coordinates of the surface is set in `z`.',\n 'Data in `z` should be a {2D array}.',\n\n 'Coordinates in `x` and `y` can either be 1D {arrays}',\n 'or {2D arrays} (e.g. to graph parametric surfaces).',\n\n 'If not provided in `x` and `y`, the x and y coordinates are assumed',\n 'to be linear starting at 0 with a unit step.',\n\n 'The color scale corresponds to the `z` values by default.',\n 'For custom color scales, use `surfacecolor` which should be a {2D array},',\n 'where its bounds can be controlled using `cmin` and `cmax`.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar annAttrs = require('../../components/annotations/attributes');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar fontAttrs = require('../../plots/font_attributes');\nvar domainAttrs = require('../../plots/domain').attributes;\nvar descriptionOnlyNumbers = require('../../plots/cartesian/axis_format_attributes').descriptionOnlyNumbers;\n\nvar attrs = module.exports = overrideAll({\n domain: domainAttrs({name: 'table', trace: true}),\n\n columnwidth: {\n valType: 'number',\n arrayOk: true,\n dflt: null,\n description: [\n 'The width of columns expressed as a ratio. Columns fill the available width',\n 'in proportion of their specified column widths.'\n ].join(' ')\n },\n\n columnorder: {\n valType: 'data_array',\n description: [\n 'Specifies the rendered order of the data columns; for example, a value `2` at position `0`',\n 'means that column index `0` in the data will be rendered as the',\n 'third column, as columns have an index base of zero.'\n ].join(' ')\n },\n\n header: {\n\n values: {\n valType: 'data_array',\n dflt: [],\n description: [\n 'Header cell values. `values[m][n]` represents the value of the `n`th point in column `m`,',\n 'therefore the `values[m]` vector length for all columns must be the same (longer vectors',\n 'will be truncated). Each value must be a finite number or a string.'\n ].join(' ')\n },\n\n format: {\n valType: 'data_array',\n dflt: [],\n description: descriptionOnlyNumbers('cell value')\n },\n\n prefix: {\n valType: 'string',\n arrayOk: true,\n dflt: null,\n description: 'Prefix for cell values.'\n },\n\n suffix: {\n valType: 'string',\n arrayOk: true,\n dflt: null,\n description: 'Suffix for cell values.'\n },\n\n height: {\n valType: 'number',\n dflt: 28,\n description: 'The height of cells.'\n },\n\n align: extendFlat({}, annAttrs.align, {arrayOk: true}),\n\n line: {\n width: {\n valType: 'number',\n arrayOk: true,\n dflt: 1,\n },\n color: {\n valType: 'color',\n arrayOk: true,\n dflt: 'grey',\n }\n },\n\n fill: {\n color: {\n valType: 'color',\n arrayOk: true,\n dflt: 'white',\n description: [\n 'Sets the cell fill color. It accepts either a specific color',\n 'or an array of colors or a 2D array of colors.'\n ].join(' ')\n }\n },\n\n font: extendFlat({}, fontAttrs({arrayOk: true}))\n },\n\n cells: {\n\n values: {\n valType: 'data_array',\n dflt: [],\n description: [\n 'Cell values. `values[m][n]` represents the value of the `n`th point in column `m`,',\n 'therefore the `values[m]` vector length for all columns must be the same (longer vectors',\n 'will be truncated). Each value must be a finite number or a string.'\n ].join(' ')\n },\n\n format: {\n valType: 'data_array',\n dflt: [],\n description: descriptionOnlyNumbers('cell value')\n },\n\n prefix: {\n valType: 'string',\n arrayOk: true,\n dflt: null,\n description: 'Prefix for cell values.'\n },\n\n suffix: {\n valType: 'string',\n arrayOk: true,\n dflt: null,\n description: 'Suffix for cell values.'\n },\n\n height: {\n valType: 'number',\n dflt: 20,\n description: 'The height of cells.'\n },\n\n align: extendFlat({}, annAttrs.align, {arrayOk: true}),\n\n line: {\n width: {\n valType: 'number',\n arrayOk: true,\n dflt: 1,\n },\n color: {\n valType: 'color',\n arrayOk: true,\n dflt: 'grey',\n }\n },\n\n fill: {\n color: {\n valType: 'color',\n arrayOk: true,\n dflt: 'white',\n description: [\n 'Sets the cell fill color. It accepts either a specific color',\n 'or an array of colors or a 2D array of colors.'\n ].join(' ')\n }\n },\n\n font: extendFlat({}, fontAttrs({arrayOk: true}))\n }\n}, 'calc', 'from-root');\nattrs.transforms = undefined;\n","'use strict';\n\nvar getModuleCalcData = require('../../plots/get_data').getModuleCalcData;\nvar tablePlot = require('./plot');\n\nvar TABLE = 'table';\n\nexports.name = TABLE;\n\nexports.plot = function(gd) {\n var calcData = getModuleCalcData(gd.calcdata, TABLE)[0];\n if(calcData.length) tablePlot(gd, calcData);\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var hadTable = (oldFullLayout._has && oldFullLayout._has(TABLE));\n var hasTable = (newFullLayout._has && newFullLayout._has(TABLE));\n\n if(hadTable && !hasTable) {\n oldFullLayout._paperdiv.selectAll('.table').remove();\n }\n};\n","'use strict';\n\nvar wrap = require('../../lib/gup').wrap;\n\nmodule.exports = function calc() {\n // we don't actually need to include the trace here, since that will be added\n // by Plots.doCalcdata, and that's all we actually need later.\n return wrap({});\n};\n","'use strict';\n\nmodule.exports = {\n cellPad: 8,\n columnExtentOffset: 10,\n columnTitleOffset: 28,\n emptyHeaderHeight: 16,\n latexCheck: /^\\$.*\\$$/,\n goldenRatio: 1.618,\n lineBreaker: '
',\n maxDimensionCount: 60,\n overdrag: 45,\n releaseTransitionDuration: 120,\n releaseTransitionEase: 'cubic-out',\n scrollbarCaptureWidth: 18,\n scrollbarHideDelay: 1000,\n scrollbarHideDuration: 1000,\n scrollbarOffset: 5,\n scrollbarWidth: 8,\n transitionDuration: 100,\n transitionEase: 'cubic-out',\n uplift: 5,\n wrapSpacer: ' ',\n wrapSplitCharacter: ' ',\n cn: {\n // general class names\n table: 'table',\n tableControlView: 'table-control-view',\n scrollBackground: 'scroll-background',\n yColumn: 'y-column',\n columnBlock: 'column-block',\n scrollAreaClip: 'scroll-area-clip',\n scrollAreaClipRect: 'scroll-area-clip-rect',\n columnBoundary: 'column-boundary',\n columnBoundaryClippath: 'column-boundary-clippath',\n columnBoundaryRect: 'column-boundary-rect',\n columnCells: 'column-cells',\n columnCell: 'column-cell',\n cellRect: 'cell-rect',\n cellText: 'cell-text',\n cellTextHolder: 'cell-text-holder',\n\n // scroll related class names\n scrollbarKit: 'scrollbar-kit',\n scrollbar: 'scrollbar',\n scrollbarSlider: 'scrollbar-slider',\n scrollbarGlyph: 'scrollbar-glyph',\n scrollbarCaptureZone: 'scrollbar-capture-zone'\n }\n};\n","'use strict';\n\nvar c = require('./constants');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar isNumeric = require('fast-isnumeric');\nvar isTypedArray = require('../../lib/array').isTypedArray;\nvar isArrayOrTypedArray = require('../../lib/array').isArrayOrTypedArray;\n\n// pure functions, don't alter but passes on `gd` and parts of `trace` without deep copying\nmodule.exports = function calc(gd, trace) {\n var cellsValues = squareStringMatrix(trace.cells.values);\n var slicer = function(a) {\n return a.slice(trace.header.values.length, a.length);\n };\n var headerValuesIn = squareStringMatrix(trace.header.values);\n if(headerValuesIn.length && !headerValuesIn[0].length) {\n headerValuesIn[0] = [''];\n headerValuesIn = squareStringMatrix(headerValuesIn);\n }\n var headerValues = headerValuesIn\n .concat(slicer(cellsValues).map(function() {\n return emptyStrings((headerValuesIn[0] || ['']).length);\n }));\n\n var domain = trace.domain;\n var groupWidth = Math.floor(gd._fullLayout._size.w * (domain.x[1] - domain.x[0]));\n var groupHeight = Math.floor(gd._fullLayout._size.h * (domain.y[1] - domain.y[0]));\n var headerRowHeights = trace.header.values.length ?\n headerValues[0].map(function() { return trace.header.height; }) :\n [c.emptyHeaderHeight];\n var rowHeights = cellsValues.length ? cellsValues[0].map(function() { return trace.cells.height; }) : [];\n var headerHeight = headerRowHeights.reduce(sum, 0);\n var scrollHeight = groupHeight - headerHeight;\n var minimumFillHeight = scrollHeight + c.uplift;\n var anchorToRowBlock = makeAnchorToRowBlock(rowHeights, minimumFillHeight);\n var anchorToHeaderRowBlock = makeAnchorToRowBlock(headerRowHeights, headerHeight);\n var headerRowBlocks = makeRowBlock(anchorToHeaderRowBlock, []);\n var rowBlocks = makeRowBlock(anchorToRowBlock, headerRowBlocks);\n var uniqueKeys = {};\n\n var columnOrder = trace._fullInput.columnorder;\n if(isArrayOrTypedArray(columnOrder)) columnOrder = Array.from(columnOrder);\n columnOrder = columnOrder.concat(slicer(cellsValues.map(function(d, i) {return i;})));\n\n var columnWidths = headerValues.map(function(d, i) {\n var value = isArrayOrTypedArray(trace.columnwidth) ?\n trace.columnwidth[Math.min(i, trace.columnwidth.length - 1)] :\n trace.columnwidth;\n return isNumeric(value) ? Number(value) : 1;\n });\n var totalColumnWidths = columnWidths.reduce(sum, 0);\n\n // fit columns in the available vertical space as there's no vertical scrolling now\n columnWidths = columnWidths.map(function(d) { return d / totalColumnWidths * groupWidth; });\n\n var maxLineWidth = Math.max(arrayMax(trace.header.line.width), arrayMax(trace.cells.line.width));\n\n var calcdata = {\n // include staticPlot in the key so if it changes we delete and redraw\n key: trace.uid + gd._context.staticPlot,\n translateX: domain.x[0] * gd._fullLayout._size.w,\n translateY: gd._fullLayout._size.h * (1 - domain.y[1]),\n size: gd._fullLayout._size,\n width: groupWidth,\n maxLineWidth: maxLineWidth,\n height: groupHeight,\n columnOrder: columnOrder, // will be mutated on column move, todo use in callback\n groupHeight: groupHeight,\n rowBlocks: rowBlocks,\n headerRowBlocks: headerRowBlocks,\n scrollY: 0, // will be mutated on scroll\n cells: extendFlat({}, trace.cells, {values: cellsValues}),\n headerCells: extendFlat({}, trace.header, {values: headerValues}),\n gdColumns: headerValues.map(function(d) {return d[0];}),\n gdColumnsOriginalOrder: headerValues.map(function(d) {return d[0];}),\n prevPages: [0, 0],\n scrollbarState: {scrollbarScrollInProgress: false},\n columns: headerValues.map(function(label, i) {\n var foundKey = uniqueKeys[label];\n uniqueKeys[label] = (foundKey || 0) + 1;\n var key = label + '__' + uniqueKeys[label];\n return {\n key: key,\n label: label,\n specIndex: i,\n xIndex: columnOrder[i],\n xScale: xScale,\n x: undefined, // initialized below\n calcdata: undefined, // initialized below\n columnWidth: columnWidths[i]\n };\n })\n };\n\n calcdata.columns.forEach(function(col) {\n col.calcdata = calcdata;\n col.x = xScale(col);\n });\n\n return calcdata;\n};\n\nfunction arrayMax(maybeArray) {\n if(isArrayOrTypedArray(maybeArray)) {\n var max = 0;\n for(var i = 0; i < maybeArray.length; i++) {\n max = Math.max(max, arrayMax(maybeArray[i]));\n }\n return max;\n }\n return maybeArray;\n}\n\nfunction sum(a, b) { return a + b; }\n\n// fill matrix in place to equal lengths\n// and ensure it's uniformly 2D\nfunction squareStringMatrix(matrixIn) {\n var matrix = matrixIn.slice();\n var minLen = Infinity;\n var maxLen = 0;\n var i;\n for(i = 0; i < matrix.length; i++) {\n if(isTypedArray(matrix[i])) matrix[i] = Array.from(matrix[i]);\n else if(!isArrayOrTypedArray(matrix[i])) matrix[i] = [matrix[i]];\n minLen = Math.min(minLen, matrix[i].length);\n maxLen = Math.max(maxLen, matrix[i].length);\n }\n\n if(minLen !== maxLen) {\n for(i = 0; i < matrix.length; i++) {\n var padLen = maxLen - matrix[i].length;\n if(padLen) matrix[i] = matrix[i].concat(emptyStrings(padLen));\n }\n }\n return matrix;\n}\n\nfunction emptyStrings(len) {\n var padArray = new Array(len);\n for(var j = 0; j < len; j++) padArray[j] = '';\n return padArray;\n}\n\nfunction xScale(d) {\n return d.calcdata.columns.reduce(function(prev, next) {\n return next.xIndex < d.xIndex ? prev + next.columnWidth : prev;\n }, 0);\n}\n\nfunction makeRowBlock(anchorToRowBlock, auxiliary) {\n var blockAnchorKeys = Object.keys(anchorToRowBlock);\n return blockAnchorKeys.map(function(k) {return extendFlat({}, anchorToRowBlock[k], {auxiliaryBlocks: auxiliary});});\n}\n\nfunction makeAnchorToRowBlock(rowHeights, minimumFillHeight) {\n var anchorToRowBlock = {};\n var currentRowHeight;\n var currentAnchor = 0;\n var currentBlockHeight = 0;\n var currentBlock = makeIdentity();\n var currentFirstRowIndex = 0;\n var blockCounter = 0;\n for(var i = 0; i < rowHeights.length; i++) {\n currentRowHeight = rowHeights[i];\n currentBlock.rows.push({\n rowIndex: i,\n rowHeight: currentRowHeight\n });\n currentBlockHeight += currentRowHeight;\n if(currentBlockHeight >= minimumFillHeight || i === rowHeights.length - 1) {\n anchorToRowBlock[currentAnchor] = currentBlock;\n currentBlock.key = blockCounter++;\n currentBlock.firstRowIndex = currentFirstRowIndex;\n currentBlock.lastRowIndex = i;\n currentBlock = makeIdentity();\n currentAnchor += currentBlockHeight;\n currentFirstRowIndex = i + 1;\n currentBlockHeight = 0;\n }\n }\n\n return anchorToRowBlock;\n}\n\nfunction makeIdentity() {\n return {\n firstRowIndex: null,\n lastRowIndex: null,\n rows: []\n };\n}\n","'use strict';\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\n// pure functions, don't alter but passes on `gd` and parts of `trace` without deep copying\n\nexports.splitToPanels = function(d) {\n var prevPages = [0, 0];\n var headerPanel = extendFlat({}, d, {\n key: 'header',\n type: 'header',\n page: 0,\n prevPages: prevPages,\n currentRepaint: [null, null],\n dragHandle: true,\n values: d.calcdata.headerCells.values[d.specIndex],\n rowBlocks: d.calcdata.headerRowBlocks,\n calcdata: extendFlat({}, d.calcdata, {cells: d.calcdata.headerCells})\n });\n var revolverPanel1 = extendFlat({}, d, {\n key: 'cells1',\n type: 'cells',\n page: 0,\n prevPages: prevPages,\n currentRepaint: [null, null],\n dragHandle: false,\n values: d.calcdata.cells.values[d.specIndex],\n rowBlocks: d.calcdata.rowBlocks\n });\n var revolverPanel2 = extendFlat({}, d, {\n key: 'cells2',\n type: 'cells',\n page: 1,\n prevPages: prevPages,\n currentRepaint: [null, null],\n dragHandle: false,\n values: d.calcdata.cells.values[d.specIndex],\n rowBlocks: d.calcdata.rowBlocks\n });\n // order due to SVG using painter's algo:\n return [revolverPanel1, revolverPanel2, headerPanel];\n};\n\nexports.splitToCells = function(d) {\n var fromTo = rowFromTo(d);\n return (d.values || []).slice(fromTo[0], fromTo[1]).map(function(v, i) {\n // By keeping identical key, a DOM node removal, creation and addition is spared, important when visible\n // grid has a lot of elements (quadratic with xcol/ycol count).\n // But it has to be busted when `svgUtil.convertToTspans` is used as it reshapes cell subtrees asynchronously,\n // and by that time the user may have scrolled away, resulting in stale overwrites. The real solution will be\n // to turn `svgUtil.convertToTspans` into a cancelable request, in which case no key busting is needed.\n var buster = (typeof v === 'string') && v.match(/[<$&> ]/) ? '_keybuster_' + Math.random() : '';\n return {\n // keyWithinBlock: /*fromTo[0] + */i, // optimized future version - no busting\n // keyWithinBlock: fromTo[0] + i, // initial always-unoptimized version - janky scrolling with 5+ columns\n keyWithinBlock: i + buster, // current compromise: regular content is very fast; async content is possible\n key: fromTo[0] + i,\n column: d,\n calcdata: d.calcdata,\n page: d.page,\n rowBlocks: d.rowBlocks,\n value: v\n };\n });\n};\n\nfunction rowFromTo(d) {\n var rowBlock = d.rowBlocks[d.page];\n // fixme rowBlock truthiness check is due to ugly hack of placing 2nd panel as d.page = -1\n var rowFrom = rowBlock ? rowBlock.rows[0].rowIndex : 0;\n var rowTo = rowBlock ? rowFrom + rowBlock.rows.length : 0;\n return [rowFrom, rowTo];\n}\n","'use strict';\n\nvar Lib = require('../../lib');\nvar attributes = require('./attributes');\nvar handleDomainDefaults = require('../../plots/domain').defaults;\n\nfunction defaultColumnOrder(traceOut, coerce) {\n var specifiedColumnOrder = traceOut.columnorder || [];\n var commonLength = traceOut.header.values.length;\n var truncated = specifiedColumnOrder.slice(0, commonLength);\n var sorted = truncated.slice().sort(function(a, b) {return a - b;});\n var oneStepped = truncated.map(function(d) {return sorted.indexOf(d);});\n for(var i = oneStepped.length; i < commonLength; i++) {\n oneStepped.push(i);\n }\n coerce('columnorder', oneStepped);\n}\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n handleDomainDefaults(traceOut, layout, coerce);\n\n coerce('columnwidth');\n\n coerce('header.values');\n coerce('header.format');\n coerce('header.align');\n\n coerce('header.prefix');\n coerce('header.suffix');\n coerce('header.height');\n coerce('header.line.width');\n coerce('header.line.color');\n coerce('header.fill.color');\n Lib.coerceFont(coerce, 'header.font', layout.font);\n\n defaultColumnOrder(traceOut, coerce);\n\n coerce('cells.values');\n coerce('cells.format');\n coerce('cells.align');\n coerce('cells.prefix');\n coerce('cells.suffix');\n coerce('cells.height');\n coerce('cells.line.width');\n coerce('cells.line.color');\n coerce('cells.fill.color');\n Lib.coerceFont(coerce, 'cells.font', layout.font);\n\n // disable 1D transforms\n traceOut._length = null;\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n calc: require('./calc'),\n plot: require('./plot'),\n\n moduleType: 'trace',\n name: 'table',\n basePlotModule: require('./base_plot'),\n categories: ['noOpacity'],\n meta: {\n description: [\n 'Table view for detailed data viewing.',\n 'The data are arranged in a grid of rows and columns.',\n 'Most styling can be specified for columns, rows or individual cells.',\n 'Table is using a column-major order, ie. the grid is represented as a vector of column vectors.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar c = require('./constants');\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\nvar numberFormat = Lib.numberFormat;\nvar gup = require('../../lib/gup');\nvar Drawing = require('../../components/drawing');\nvar svgUtil = require('../../lib/svg_text_utils');\nvar raiseToTop = require('../../lib').raiseToTop;\nvar strTranslate = require('../../lib').strTranslate;\nvar cancelEeaseColumn = require('../../lib').cancelTransition;\nvar prepareData = require('./data_preparation_helper');\nvar splitData = require('./data_split_helpers');\nvar Color = require('../../components/color');\n\nmodule.exports = function plot(gd, wrappedTraceHolders) {\n var dynamic = !gd._context.staticPlot;\n\n var table = gd._fullLayout._paper.selectAll('.' + c.cn.table)\n .data(wrappedTraceHolders.map(function(wrappedTraceHolder) {\n var traceHolder = gup.unwrap(wrappedTraceHolder);\n var trace = traceHolder.trace;\n return prepareData(gd, trace);\n }), gup.keyFun);\n\n table.exit().remove();\n\n table.enter()\n .append('g')\n .classed(c.cn.table, true)\n .attr('overflow', 'visible')\n .style('box-sizing', 'content-box')\n .style('position', 'absolute')\n .style('left', 0)\n .style('overflow', 'visible')\n .style('shape-rendering', 'crispEdges')\n .style('pointer-events', 'all');\n\n table\n .attr('width', function(d) {return d.width + d.size.l + d.size.r;})\n .attr('height', function(d) {return d.height + d.size.t + d.size.b;})\n .attr('transform', function(d) {\n return strTranslate(d.translateX, d.translateY);\n });\n\n var tableControlView = table.selectAll('.' + c.cn.tableControlView)\n .data(gup.repeat, gup.keyFun);\n\n var cvEnter = tableControlView.enter()\n .append('g')\n .classed(c.cn.tableControlView, true)\n .style('box-sizing', 'content-box');\n if(dynamic) {\n var wheelEvent = 'onwheel' in document ? 'wheel' : 'mousewheel';\n cvEnter\n .on('mousemove', function(d) {\n tableControlView\n .filter(function(dd) {return d === dd;})\n .call(renderScrollbarKit, gd);\n })\n .on(wheelEvent, function(d) {\n if(d.scrollbarState.wheeling) return;\n d.scrollbarState.wheeling = true;\n var newY = d.scrollY + d3.event.deltaY;\n var noChange = makeDragRow(gd, tableControlView, null, newY)(d);\n if(!noChange) {\n d3.event.stopPropagation();\n d3.event.preventDefault();\n }\n d.scrollbarState.wheeling = false;\n })\n .call(renderScrollbarKit, gd, true);\n }\n\n tableControlView\n .attr('transform', function(d) {return strTranslate(d.size.l, d.size.t);});\n\n // scrollBackground merely ensures that mouse events are captured even on crazy fast scrollwheeling\n // otherwise rendering glitches may occur\n var scrollBackground = tableControlView.selectAll('.' + c.cn.scrollBackground)\n .data(gup.repeat, gup.keyFun);\n\n scrollBackground.enter()\n .append('rect')\n .classed(c.cn.scrollBackground, true)\n .attr('fill', 'none');\n\n scrollBackground\n .attr('width', function(d) {return d.width;})\n .attr('height', function(d) {return d.height;});\n\n tableControlView.each(function(d) {\n Drawing.setClipUrl(d3.select(this), scrollAreaBottomClipKey(gd, d), gd);\n });\n\n var yColumn = tableControlView.selectAll('.' + c.cn.yColumn)\n .data(function(vm) {return vm.columns;}, gup.keyFun);\n\n yColumn.enter()\n .append('g')\n .classed(c.cn.yColumn, true);\n\n yColumn.exit().remove();\n\n yColumn.attr('transform', function(d) {return strTranslate(d.x, 0);});\n\n if(dynamic) {\n yColumn.call(d3.behavior.drag()\n .origin(function(d) {\n var movedColumn = d3.select(this);\n easeColumn(movedColumn, d, -c.uplift);\n raiseToTop(this);\n d.calcdata.columnDragInProgress = true;\n renderScrollbarKit(tableControlView.filter(function(dd) {return d.calcdata.key === dd.key;}), gd);\n return d;\n })\n .on('drag', function(d) {\n var movedColumn = d3.select(this);\n var getter = function(dd) {return (d === dd ? d3.event.x : dd.x) + dd.columnWidth / 2;};\n d.x = Math.max(-c.overdrag, Math.min(d.calcdata.width + c.overdrag - d.columnWidth, d3.event.x));\n\n var sortableColumns = flatData(yColumn).filter(function(dd) {return dd.calcdata.key === d.calcdata.key;});\n var newOrder = sortableColumns.sort(function(a, b) {return getter(a) - getter(b);});\n newOrder.forEach(function(dd, i) {\n dd.xIndex = i;\n dd.x = d === dd ? dd.x : dd.xScale(dd);\n });\n\n yColumn.filter(function(dd) {return d !== dd;})\n .transition()\n .ease(c.transitionEase)\n .duration(c.transitionDuration)\n .attr('transform', function(d) {return strTranslate(d.x, 0);});\n movedColumn\n .call(cancelEeaseColumn)\n .attr('transform', strTranslate(d.x, -c.uplift));\n })\n .on('dragend', function(d) {\n var movedColumn = d3.select(this);\n var p = d.calcdata;\n d.x = d.xScale(d);\n d.calcdata.columnDragInProgress = false;\n easeColumn(movedColumn, d, 0);\n columnMoved(gd, p, p.columns.map(function(dd) {return dd.xIndex;}));\n })\n );\n }\n\n yColumn.each(function(d) {\n Drawing.setClipUrl(d3.select(this), columnBoundaryClipKey(gd, d), gd);\n });\n\n var columnBlock = yColumn.selectAll('.' + c.cn.columnBlock)\n .data(splitData.splitToPanels, gup.keyFun);\n\n columnBlock.enter()\n .append('g')\n .classed(c.cn.columnBlock, true)\n .attr('id', function(d) {return d.key;});\n\n columnBlock\n .style('cursor', function(d) {\n return d.dragHandle ? 'ew-resize' : d.calcdata.scrollbarState.barWiggleRoom ? 'ns-resize' : 'default';\n });\n\n var headerColumnBlock = columnBlock.filter(headerBlock);\n var cellsColumnBlock = columnBlock.filter(cellsBlock);\n\n if(dynamic) {\n cellsColumnBlock.call(d3.behavior.drag()\n .origin(function(d) {\n d3.event.stopPropagation();\n return d;\n })\n .on('drag', makeDragRow(gd, tableControlView, -1))\n .on('dragend', function() {\n // fixme emit plotly notification\n })\n );\n }\n\n // initial rendering: header is rendered first, as it may may have async LaTeX (show header first)\n // but blocks are _entered_ the way they are due to painter's algo (header on top)\n renderColumnCellTree(gd, tableControlView, headerColumnBlock, columnBlock);\n renderColumnCellTree(gd, tableControlView, cellsColumnBlock, columnBlock);\n\n var scrollAreaClip = tableControlView.selectAll('.' + c.cn.scrollAreaClip)\n .data(gup.repeat, gup.keyFun);\n\n scrollAreaClip.enter()\n .append('clipPath')\n .classed(c.cn.scrollAreaClip, true)\n .attr('id', function(d) {return scrollAreaBottomClipKey(gd, d);});\n\n var scrollAreaClipRect = scrollAreaClip.selectAll('.' + c.cn.scrollAreaClipRect)\n .data(gup.repeat, gup.keyFun);\n\n scrollAreaClipRect.enter()\n .append('rect')\n .classed(c.cn.scrollAreaClipRect, true)\n .attr('x', -c.overdrag)\n .attr('y', -c.uplift)\n .attr('fill', 'none');\n\n scrollAreaClipRect\n .attr('width', function(d) {return d.width + 2 * c.overdrag;})\n .attr('height', function(d) {return d.height + c.uplift;});\n\n var columnBoundary = yColumn.selectAll('.' + c.cn.columnBoundary)\n .data(gup.repeat, gup.keyFun);\n\n columnBoundary.enter()\n .append('g')\n .classed(c.cn.columnBoundary, true);\n\n var columnBoundaryClippath = yColumn.selectAll('.' + c.cn.columnBoundaryClippath)\n .data(gup.repeat, gup.keyFun);\n\n // SVG spec doesn't mandate wrapping into a and doesn't seem to cause a speed difference\n columnBoundaryClippath.enter()\n .append('clipPath')\n .classed(c.cn.columnBoundaryClippath, true);\n\n columnBoundaryClippath\n .attr('id', function(d) {return columnBoundaryClipKey(gd, d);});\n\n var columnBoundaryRect = columnBoundaryClippath.selectAll('.' + c.cn.columnBoundaryRect)\n .data(gup.repeat, gup.keyFun);\n\n columnBoundaryRect.enter()\n .append('rect')\n .classed(c.cn.columnBoundaryRect, true)\n .attr('fill', 'none');\n\n columnBoundaryRect\n .attr('width', function(d) { return d.columnWidth + 2 * roundHalfWidth(d); })\n .attr('height', function(d) {return d.calcdata.height + 2 * roundHalfWidth(d) + c.uplift;})\n .attr('x', function(d) { return -roundHalfWidth(d); })\n .attr('y', function(d) { return -roundHalfWidth(d); });\n\n updateBlockYPosition(null, cellsColumnBlock, tableControlView);\n};\n\nfunction roundHalfWidth(d) {\n return Math.ceil(d.calcdata.maxLineWidth / 2);\n}\n\nfunction scrollAreaBottomClipKey(gd, d) {\n return 'clip' + gd._fullLayout._uid + '_scrollAreaBottomClip_' + d.key;\n}\n\nfunction columnBoundaryClipKey(gd, d) {\n return 'clip' + gd._fullLayout._uid + '_columnBoundaryClippath_' + d.calcdata.key + '_' + d.specIndex;\n}\n\nfunction flatData(selection) {\n return [].concat.apply([], selection.map(function(g) {return g;}))\n .map(function(g) {return g.__data__;});\n}\n\nfunction renderScrollbarKit(tableControlView, gd, bypassVisibleBar) {\n function calcTotalHeight(d) {\n var blocks = d.rowBlocks;\n return firstRowAnchor(blocks, blocks.length - 1) + (blocks.length ? rowsHeight(blocks[blocks.length - 1], Infinity) : 1);\n }\n\n var scrollbarKit = tableControlView.selectAll('.' + c.cn.scrollbarKit)\n .data(gup.repeat, gup.keyFun);\n\n scrollbarKit.enter()\n .append('g')\n .classed(c.cn.scrollbarKit, true)\n .style('shape-rendering', 'geometricPrecision');\n\n scrollbarKit\n .each(function(d) {\n var s = d.scrollbarState;\n s.totalHeight = calcTotalHeight(d);\n s.scrollableAreaHeight = d.groupHeight - headerHeight(d);\n s.currentlyVisibleHeight = Math.min(s.totalHeight, s.scrollableAreaHeight);\n s.ratio = s.currentlyVisibleHeight / s.totalHeight;\n s.barLength = Math.max(s.ratio * s.currentlyVisibleHeight, c.goldenRatio * c.scrollbarWidth);\n s.barWiggleRoom = s.currentlyVisibleHeight - s.barLength;\n s.wiggleRoom = Math.max(0, s.totalHeight - s.scrollableAreaHeight);\n s.topY = s.barWiggleRoom === 0 ? 0 : (d.scrollY / s.wiggleRoom) * s.barWiggleRoom;\n s.bottomY = s.topY + s.barLength;\n s.dragMultiplier = s.wiggleRoom / s.barWiggleRoom;\n })\n .attr('transform', function(d) {\n var xPosition = d.width + c.scrollbarWidth / 2 + c.scrollbarOffset;\n return strTranslate(xPosition, headerHeight(d));\n });\n\n var scrollbar = scrollbarKit.selectAll('.' + c.cn.scrollbar)\n .data(gup.repeat, gup.keyFun);\n\n scrollbar.enter()\n .append('g')\n .classed(c.cn.scrollbar, true);\n\n var scrollbarSlider = scrollbar.selectAll('.' + c.cn.scrollbarSlider)\n .data(gup.repeat, gup.keyFun);\n\n scrollbarSlider.enter()\n .append('g')\n .classed(c.cn.scrollbarSlider, true);\n\n scrollbarSlider\n .attr('transform', function(d) {\n return strTranslate(0, d.scrollbarState.topY || 0);\n });\n\n var scrollbarGlyph = scrollbarSlider.selectAll('.' + c.cn.scrollbarGlyph)\n .data(gup.repeat, gup.keyFun);\n\n scrollbarGlyph.enter()\n .append('line')\n .classed(c.cn.scrollbarGlyph, true)\n .attr('stroke', 'black')\n .attr('stroke-width', c.scrollbarWidth)\n .attr('stroke-linecap', 'round')\n .attr('y1', c.scrollbarWidth / 2);\n\n scrollbarGlyph\n .attr('y2', function(d) {\n return d.scrollbarState.barLength - c.scrollbarWidth / 2;\n })\n .attr('stroke-opacity', function(d) {\n return d.columnDragInProgress || !d.scrollbarState.barWiggleRoom || bypassVisibleBar ? 0 : 0.4;\n });\n\n // cancel transition: possible pending (also, delayed) transition\n scrollbarGlyph\n .transition().delay(0).duration(0);\n\n scrollbarGlyph\n .transition().delay(c.scrollbarHideDelay).duration(c.scrollbarHideDuration)\n .attr('stroke-opacity', 0);\n\n var scrollbarCaptureZone = scrollbar.selectAll('.' + c.cn.scrollbarCaptureZone)\n .data(gup.repeat, gup.keyFun);\n\n scrollbarCaptureZone.enter()\n .append('line')\n .classed(c.cn.scrollbarCaptureZone, true)\n .attr('stroke', 'white')\n .attr('stroke-opacity', 0.01) // some browser might get rid of a 0 opacity element\n .attr('stroke-width', c.scrollbarCaptureWidth)\n .attr('stroke-linecap', 'butt')\n .attr('y1', 0)\n .on('mousedown', function(d) {\n var y = d3.event.y;\n var bbox = this.getBoundingClientRect();\n var s = d.scrollbarState;\n var pixelVal = y - bbox.top;\n var inverseScale = d3.scale.linear().domain([0, s.scrollableAreaHeight]).range([0, s.totalHeight]).clamp(true);\n if(!(s.topY <= pixelVal && pixelVal <= s.bottomY)) {\n makeDragRow(gd, tableControlView, null, inverseScale(pixelVal - s.barLength / 2))(d);\n }\n })\n .call(d3.behavior.drag()\n .origin(function(d) {\n d3.event.stopPropagation();\n d.scrollbarState.scrollbarScrollInProgress = true;\n return d;\n })\n .on('drag', makeDragRow(gd, tableControlView))\n .on('dragend', function() {\n // fixme emit Plotly event\n })\n );\n\n scrollbarCaptureZone\n .attr('y2', function(d) {\n return d.scrollbarState.scrollableAreaHeight;\n });\n\n // Remove scroll glyph and capture zone on static plots\n // as they don't render properly when converted to PDF\n // in the Chrome PDF viewer\n // https://github.com/plotly/streambed/issues/11618\n if(gd._context.staticPlot) {\n scrollbarGlyph.remove();\n scrollbarCaptureZone.remove();\n }\n}\n\nfunction renderColumnCellTree(gd, tableControlView, columnBlock, allColumnBlock) {\n // fixme this perf hotspot\n // this is performance critical code as scrolling calls it on every revolver switch\n // it appears sufficiently fast but there are plenty of low-hanging fruits for performance optimization\n\n var columnCells = renderColumnCells(columnBlock);\n\n var columnCell = renderColumnCell(columnCells);\n\n supplyStylingValues(columnCell);\n\n var cellRect = renderCellRect(columnCell);\n\n sizeAndStyleRect(cellRect);\n\n var cellTextHolder = renderCellTextHolder(columnCell);\n\n var cellText = renderCellText(cellTextHolder);\n\n setFont(cellText);\n populateCellText(cellText, tableControlView, allColumnBlock, gd);\n\n // doing this at the end when text, and text stlying are set\n setCellHeightAndPositionY(columnCell);\n}\n\nfunction renderColumnCells(columnBlock) {\n var columnCells = columnBlock.selectAll('.' + c.cn.columnCells)\n .data(gup.repeat, gup.keyFun);\n\n columnCells.enter()\n .append('g')\n .classed(c.cn.columnCells, true);\n\n columnCells.exit()\n .remove();\n\n return columnCells;\n}\n\nfunction renderColumnCell(columnCells) {\n var columnCell = columnCells.selectAll('.' + c.cn.columnCell)\n .data(splitData.splitToCells, function(d) {return d.keyWithinBlock;});\n\n columnCell.enter()\n .append('g')\n .classed(c.cn.columnCell, true);\n\n columnCell.exit()\n .remove();\n\n return columnCell;\n}\n\nfunction renderCellRect(columnCell) {\n var cellRect = columnCell.selectAll('.' + c.cn.cellRect)\n .data(gup.repeat, function(d) {return d.keyWithinBlock;});\n\n cellRect.enter()\n .append('rect')\n .classed(c.cn.cellRect, true);\n\n return cellRect;\n}\n\nfunction renderCellText(cellTextHolder) {\n var cellText = cellTextHolder.selectAll('.' + c.cn.cellText)\n .data(gup.repeat, function(d) {return d.keyWithinBlock;});\n\n cellText.enter()\n .append('text')\n .classed(c.cn.cellText, true)\n .style('cursor', function() {return 'auto';})\n .on('mousedown', function() {d3.event.stopPropagation();});\n\n return cellText;\n}\n\nfunction renderCellTextHolder(columnCell) {\n var cellTextHolder = columnCell.selectAll('.' + c.cn.cellTextHolder)\n .data(gup.repeat, function(d) {return d.keyWithinBlock;});\n\n cellTextHolder.enter()\n .append('g')\n .classed(c.cn.cellTextHolder, true)\n .style('shape-rendering', 'geometricPrecision');\n\n return cellTextHolder;\n}\n\nfunction supplyStylingValues(columnCell) {\n columnCell\n .each(function(d, i) {\n var spec = d.calcdata.cells.font;\n var col = d.column.specIndex;\n var font = {\n size: gridPick(spec.size, col, i),\n color: gridPick(spec.color, col, i),\n family: gridPick(spec.family, col, i),\n weight: gridPick(spec.weight, col, i),\n style: gridPick(spec.style, col, i),\n variant: gridPick(spec.variant, col, i),\n textcase: gridPick(spec.textcase, col, i),\n lineposition: gridPick(spec.lineposition, col, i),\n shadow: gridPick(spec.shadow, col, i),\n };\n d.rowNumber = d.key;\n d.align = gridPick(d.calcdata.cells.align, col, i);\n d.cellBorderWidth = gridPick(d.calcdata.cells.line.width, col, i);\n d.font = font;\n });\n}\n\nfunction setFont(cellText) {\n cellText\n .each(function(d) {\n Drawing.font(d3.select(this), d.font);\n });\n}\n\nfunction sizeAndStyleRect(cellRect) {\n cellRect\n .attr('width', function(d) {return d.column.columnWidth;})\n .attr('stroke-width', function(d) {return d.cellBorderWidth;})\n .each(function(d) {\n var atomicSelection = d3.select(this);\n Color.stroke(atomicSelection, gridPick(d.calcdata.cells.line.color, d.column.specIndex, d.rowNumber));\n Color.fill(atomicSelection, gridPick(d.calcdata.cells.fill.color, d.column.specIndex, d.rowNumber));\n });\n}\n\nfunction populateCellText(cellText, tableControlView, allColumnBlock, gd) {\n cellText\n .text(function(d) {\n var col = d.column.specIndex;\n var row = d.rowNumber;\n\n var userSuppliedContent = d.value;\n var stringSupplied = (typeof userSuppliedContent === 'string');\n var hasBreaks = stringSupplied && userSuppliedContent.match(/
/i);\n var userBrokenText = !stringSupplied || hasBreaks;\n d.mayHaveMarkup = stringSupplied && userSuppliedContent.match(/[<&>]/);\n\n var latex = isLatex(userSuppliedContent);\n d.latex = latex;\n\n var prefix = latex ? '' : gridPick(d.calcdata.cells.prefix, col, row) || '';\n var suffix = latex ? '' : gridPick(d.calcdata.cells.suffix, col, row) || '';\n var format = latex ? null : gridPick(d.calcdata.cells.format, col, row) || null;\n\n var prefixSuffixedText = prefix + (format ? numberFormat(format)(d.value) : d.value) + suffix;\n\n var hasWrapSplitCharacter;\n d.wrappingNeeded = !d.wrapped && !userBrokenText && !latex && (hasWrapSplitCharacter = hasWrapCharacter(prefixSuffixedText));\n d.cellHeightMayIncrease = hasBreaks || latex || d.mayHaveMarkup || (hasWrapSplitCharacter === void(0) ? hasWrapCharacter(prefixSuffixedText) : hasWrapSplitCharacter);\n d.needsConvertToTspans = d.mayHaveMarkup || d.wrappingNeeded || d.latex;\n\n var textToRender;\n if(d.wrappingNeeded) {\n var hrefPreservedText = c.wrapSplitCharacter === ' ' ? prefixSuffixedText.replace(/ pTop) {\n pages.push(blockIndex);\n }\n pTop += rowsHeight;\n\n // consider this nice final optimization; put it in `for` condition - caveat, currently the\n // block.allRowsHeight relies on being invalidated, so enabling this opt may not be safe\n // if(pages.length > 1) break;\n }\n\n return pages;\n}\n\nfunction updateBlockYPosition(gd, cellsColumnBlock, tableControlView) {\n var d = flatData(cellsColumnBlock)[0];\n if(d === undefined) return;\n var blocks = d.rowBlocks;\n var calcdata = d.calcdata;\n\n var bottom = firstRowAnchor(blocks, blocks.length);\n var scrollHeight = d.calcdata.groupHeight - headerHeight(d);\n var scrollY = calcdata.scrollY = Math.max(0, Math.min(bottom - scrollHeight, calcdata.scrollY));\n\n var pages = findPagesAndCacheHeights(blocks, scrollY, scrollHeight);\n if(pages.length === 1) {\n if(pages[0] === blocks.length - 1) {\n pages.unshift(pages[0] - 1);\n } else {\n pages.push(pages[0] + 1);\n }\n }\n\n // make phased out page jump by 2 while leaving stationary page intact\n if(pages[0] % 2) {\n pages.reverse();\n }\n\n cellsColumnBlock\n .each(function(d, i) {\n // these values will also be needed when a block is translated again due to growing cell height\n d.page = pages[i];\n d.scrollY = scrollY;\n });\n\n cellsColumnBlock\n .attr('transform', function(d) {\n var yTranslate = firstRowAnchor(d.rowBlocks, d.page) - d.scrollY;\n return strTranslate(0, yTranslate);\n });\n\n // conditionally rerendering panel 0 and 1\n if(gd) {\n conditionalPanelRerender(gd, tableControlView, cellsColumnBlock, pages, d.prevPages, d, 0);\n conditionalPanelRerender(gd, tableControlView, cellsColumnBlock, pages, d.prevPages, d, 1);\n renderScrollbarKit(tableControlView, gd);\n }\n}\n\nfunction makeDragRow(gd, allTableControlView, optionalMultiplier, optionalPosition) {\n return function dragRow(eventD) {\n // may come from whichever DOM event target: drag, wheel, bar... eventD corresponds to event target\n var d = eventD.calcdata ? eventD.calcdata : eventD;\n var tableControlView = allTableControlView.filter(function(dd) {return d.key === dd.key;});\n var multiplier = optionalMultiplier || d.scrollbarState.dragMultiplier;\n\n var initialScrollY = d.scrollY;\n\n d.scrollY = optionalPosition === void(0) ? d.scrollY + multiplier * d3.event.dy : optionalPosition;\n var cellsColumnBlock = tableControlView.selectAll('.' + c.cn.yColumn).selectAll('.' + c.cn.columnBlock).filter(cellsBlock);\n updateBlockYPosition(gd, cellsColumnBlock, tableControlView);\n\n // return false if we've \"used\" the scroll, ie it did something,\n // so the event shouldn't bubble (if appropriate)\n return d.scrollY === initialScrollY;\n };\n}\n\nfunction conditionalPanelRerender(gd, tableControlView, cellsColumnBlock, pages, prevPages, d, revolverIndex) {\n var shouldComponentUpdate = pages[revolverIndex] !== prevPages[revolverIndex];\n if(shouldComponentUpdate) {\n clearTimeout(d.currentRepaint[revolverIndex]);\n d.currentRepaint[revolverIndex] = setTimeout(function() {\n // setTimeout might lag rendering but yields a smoother scroll, because fast scrolling makes\n // some repaints invisible ie. wasteful (DOM work blocks the main thread)\n var toRerender = cellsColumnBlock.filter(function(d, i) {return i === revolverIndex && pages[i] !== prevPages[i];});\n renderColumnCellTree(gd, tableControlView, toRerender, cellsColumnBlock);\n prevPages[revolverIndex] = pages[revolverIndex];\n });\n }\n}\n\nfunction wrapTextMaker(columnBlock, element, tableControlView, gd) {\n return function wrapText() {\n var cellTextHolder = d3.select(element.parentNode);\n cellTextHolder\n .each(function(d) {\n var fragments = d.fragments;\n cellTextHolder.selectAll('tspan.line').each(function(dd, i) {\n fragments[i].width = this.getComputedTextLength();\n });\n // last element is only for measuring the separator character, so it's ignored:\n var separatorLength = fragments[fragments.length - 1].width;\n var rest = fragments.slice(0, -1);\n var currentRow = [];\n var currentAddition, currentAdditionLength;\n var currentRowLength = 0;\n var rowLengthLimit = d.column.columnWidth - 2 * c.cellPad;\n d.value = '';\n while(rest.length) {\n currentAddition = rest.shift();\n currentAdditionLength = currentAddition.width + separatorLength;\n if(currentRowLength + currentAdditionLength > rowLengthLimit) {\n d.value += currentRow.join(c.wrapSpacer) + c.lineBreaker;\n currentRow = [];\n currentRowLength = 0;\n }\n currentRow.push(currentAddition.text);\n currentRowLength += currentAdditionLength;\n }\n if(currentRowLength) {\n d.value += currentRow.join(c.wrapSpacer);\n }\n d.wrapped = true;\n });\n\n // the pre-wrapped text was rendered only for the text measurements\n cellTextHolder.selectAll('tspan.line').remove();\n\n // resupply text, now wrapped\n populateCellText(cellTextHolder.select('.' + c.cn.cellText), tableControlView, columnBlock, gd);\n d3.select(element.parentNode.parentNode).call(setCellHeightAndPositionY);\n };\n}\n\nfunction updateYPositionMaker(columnBlock, element, tableControlView, gd, d) {\n return function updateYPosition() {\n if(d.settledY) return;\n var cellTextHolder = d3.select(element.parentNode);\n var l = getBlock(d);\n var rowIndex = d.key - l.firstRowIndex;\n\n var declaredRowHeight = l.rows[rowIndex].rowHeight;\n\n var requiredHeight = d.cellHeightMayIncrease ? element.parentNode.getBoundingClientRect().height + 2 * c.cellPad : declaredRowHeight;\n\n var finalHeight = Math.max(requiredHeight, declaredRowHeight);\n var increase = finalHeight - l.rows[rowIndex].rowHeight;\n\n if(increase) {\n // current row height increased\n l.rows[rowIndex].rowHeight = finalHeight;\n\n columnBlock\n .selectAll('.' + c.cn.columnCell)\n .call(setCellHeightAndPositionY);\n\n updateBlockYPosition(null, columnBlock.filter(cellsBlock), 0);\n\n // if d.column.type === 'header', then the scrollbar has to be pushed downward to the scrollable area\n // if d.column.type === 'cells', it can still be relevant if total scrolling content height is less than the\n // scrollable window, as increases to row heights may need scrollbar updates\n renderScrollbarKit(tableControlView, gd, true);\n }\n\n cellTextHolder\n .attr('transform', function() {\n // this code block is only invoked for items where d.cellHeightMayIncrease is truthy\n var element = this;\n var columnCellElement = element.parentNode;\n var box = columnCellElement.getBoundingClientRect();\n var rectBox = d3.select(element.parentNode).select('.' + c.cn.cellRect).node().getBoundingClientRect();\n var currentTransform = element.transform.baseVal.consolidate();\n var yPosition = rectBox.top - box.top + (currentTransform ? currentTransform.matrix.f : c.cellPad);\n return strTranslate(xPosition(d, d3.select(element.parentNode).select('.' + c.cn.cellTextHolder).node().getBoundingClientRect().width), yPosition);\n });\n\n d.settledY = true;\n };\n}\n\nfunction xPosition(d, optionalWidth) {\n switch(d.align) {\n case 'left': return c.cellPad;\n case 'right': return d.column.columnWidth - (optionalWidth || 0) - c.cellPad;\n case 'center': return (d.column.columnWidth - (optionalWidth || 0)) / 2;\n default: return c.cellPad;\n }\n}\n\nfunction setCellHeightAndPositionY(columnCell) {\n columnCell\n .attr('transform', function(d) {\n var headerHeight = d.rowBlocks[0].auxiliaryBlocks.reduce(function(p, n) {return p + rowsHeight(n, Infinity);}, 0);\n var l = getBlock(d);\n var rowAnchor = rowsHeight(l, d.key);\n var yOffset = rowAnchor + headerHeight;\n return strTranslate(0, yOffset);\n })\n .selectAll('.' + c.cn.cellRect)\n .attr('height', function(d) {return getRow(getBlock(d), d.key).rowHeight;});\n}\n\nfunction firstRowAnchor(blocks, page) {\n var total = 0;\n for(var i = page - 1; i >= 0; i--) {\n total += allRowsHeight(blocks[i]);\n }\n return total;\n}\n\nfunction rowsHeight(rowBlock, key) {\n var total = 0;\n for(var i = 0; i < rowBlock.rows.length && rowBlock.rows[i].rowIndex < key; i++) {\n total += rowBlock.rows[i].rowHeight;\n }\n return total;\n}\n\nfunction allRowsHeight(rowBlock) {\n var cached = rowBlock.allRowsHeight;\n\n if(cached !== void(0)) {\n return cached;\n }\n\n var total = 0;\n for(var i = 0; i < rowBlock.rows.length; i++) {\n total += rowBlock.rows[i].rowHeight;\n }\n rowBlock.allRowsHeight = total;\n\n return total;\n}\n\nfunction getBlock(d) {return d.rowBlocks[d.page];}\nfunction getRow(l, i) {return l.rows[i - l.firstRowIndex];}\n","'use strict';\n\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\n\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar domainAttrs = require('../../plots/domain').attributes;\nvar pieAttrs = require('../pie/attributes');\nvar sunburstAttrs = require('../sunburst/attributes');\nvar constants = require('./constants');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar pattern = require('../../components/drawing/attributes').pattern;\n\nmodule.exports = {\n labels: sunburstAttrs.labels,\n parents: sunburstAttrs.parents,\n\n values: sunburstAttrs.values,\n branchvalues: sunburstAttrs.branchvalues,\n count: sunburstAttrs.count,\n\n level: sunburstAttrs.level,\n maxdepth: sunburstAttrs.maxdepth,\n\n tiling: {\n packing: {\n valType: 'enumerated',\n values: [\n 'squarify',\n 'binary',\n 'dice',\n 'slice',\n 'slice-dice',\n 'dice-slice'\n ],\n dflt: 'squarify',\n editType: 'plot',\n description: [\n 'Determines d3 treemap solver.',\n 'For more info please refer to https://github.com/d3/d3-hierarchy#treemap-tiling'\n ].join(' ')\n },\n\n squarifyratio: {\n valType: 'number',\n min: 1,\n dflt: 1,\n editType: 'plot',\n description: [\n 'When using *squarify* `packing` algorithm, according to https://github.com/d3/d3-hierarchy/blob/v3.1.1/README.md#squarify_ratio',\n 'this option specifies the desired aspect ratio of the generated rectangles.',\n 'The ratio must be specified as a number greater than or equal to one.',\n 'Note that the orientation of the generated rectangles (tall or wide)',\n 'is not implied by the ratio; for example, a ratio of two will attempt',\n 'to produce a mixture of rectangles whose width:height ratio is either 2:1 or 1:2.',\n 'When using *squarify*, unlike d3 which uses the Golden Ratio i.e. 1.618034,',\n 'Plotly applies 1 to increase squares in treemap layouts.'\n ].join(' ')\n },\n\n flip: {\n valType: 'flaglist',\n flags: [\n 'x',\n 'y'\n ],\n dflt: '',\n editType: 'plot',\n description: [\n 'Determines if the positions obtained from solver are flipped on each axis.'\n ].join(' ')\n },\n\n pad: {\n valType: 'number',\n min: 0,\n dflt: 3,\n editType: 'plot',\n description: [\n 'Sets the inner padding (in px).'\n ].join(' ')\n },\n\n editType: 'calc',\n },\n\n marker: extendFlat({\n pad: {\n t: {\n valType: 'number',\n min: 0,\n editType: 'plot',\n description: [\n 'Sets the padding form the top (in px).'\n ].join(' ')\n },\n l: {\n valType: 'number',\n min: 0,\n editType: 'plot',\n description: [\n 'Sets the padding form the left (in px).'\n ].join(' ')\n },\n r: {\n valType: 'number',\n min: 0,\n editType: 'plot',\n description: [\n 'Sets the padding form the right (in px).'\n ].join(' ')\n },\n b: {\n valType: 'number',\n min: 0,\n editType: 'plot',\n description: [\n 'Sets the padding form the bottom (in px).'\n ].join(' ')\n },\n\n editType: 'calc'\n },\n\n colors: sunburstAttrs.marker.colors,\n\n pattern: pattern,\n\n depthfade: {\n valType: 'enumerated',\n values: [true, false, 'reversed'],\n editType: 'style',\n description: [\n 'Determines if the sector colors are faded towards',\n 'the background from the leaves up to the headers.',\n 'This option is unavailable when a `colorscale` is present,',\n 'defaults to false when `marker.colors` is set,',\n 'but otherwise defaults to true.',\n 'When set to *reversed*, the fading direction is inverted,',\n 'that is the top elements within hierarchy are drawn with fully saturated colors',\n 'while the leaves are faded towards the background color.'\n ].join(' ')\n },\n\n line: sunburstAttrs.marker.line,\n\n cornerradius: {\n valType: 'number',\n min: 0,\n dflt: 0,\n editType: 'plot',\n description: [\n 'Sets the maximum rounding of corners (in px).'\n ].join(' ')\n },\n\n editType: 'calc',\n },\n colorScaleAttrs('marker', {\n colorAttr: 'colors',\n anim: false // TODO: set to anim: true?\n })\n ),\n\n pathbar: {\n visible: {\n valType: 'boolean',\n dflt: true,\n editType: 'plot',\n description: [\n 'Determines if the path bar is drawn',\n 'i.e. outside the trace `domain` and',\n 'with one pixel gap.'\n ].join(' ')\n },\n\n side: {\n valType: 'enumerated',\n values: [\n 'top',\n 'bottom'\n ],\n dflt: 'top',\n editType: 'plot',\n description: [\n 'Determines on which side of the the treemap the',\n '`pathbar` should be presented.'\n ].join(' ')\n },\n\n edgeshape: {\n valType: 'enumerated',\n values: [\n '>',\n '<',\n '|',\n '/',\n '\\\\'\n ],\n dflt: '>',\n editType: 'plot',\n description: [\n 'Determines which shape is used for edges between `barpath` labels.'\n ].join(' ')\n },\n\n thickness: {\n valType: 'number',\n min: 12,\n editType: 'plot',\n description: [\n 'Sets the thickness of `pathbar` (in px). If not specified the `pathbar.textfont.size` is used',\n 'with 3 pixles extra padding on each side.'\n ].join(' ')\n },\n\n textfont: extendFlat({}, pieAttrs.textfont, {\n description: 'Sets the font used inside `pathbar`.'\n }),\n\n editType: 'calc'\n },\n\n text: pieAttrs.text,\n textinfo: sunburstAttrs.textinfo,\n // TODO: incorporate `label` and `value` in the eventData\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: constants.eventDataKeys.concat(['label', 'value'])\n }),\n\n hovertext: pieAttrs.hovertext,\n hoverinfo: sunburstAttrs.hoverinfo,\n hovertemplate: hovertemplateAttrs({}, {\n keys: constants.eventDataKeys\n }),\n\n textfont: pieAttrs.textfont,\n insidetextfont: pieAttrs.insidetextfont,\n outsidetextfont: extendFlat({}, pieAttrs.outsidetextfont, {\n description: [\n 'Sets the font used for `textinfo` lying outside the sector.',\n 'This option refers to the root of the hierarchy',\n 'presented on top left corner of a treemap graph.',\n 'Please note that if a hierarchy has multiple root nodes,',\n 'this option won\\'t have any effect and `insidetextfont` would be used.'\n ].join(' ')\n }),\n\n textposition: {\n valType: 'enumerated',\n values: [\n 'top left', 'top center', 'top right',\n 'middle left', 'middle center', 'middle right',\n 'bottom left', 'bottom center', 'bottom right'\n ],\n dflt: 'top left',\n editType: 'plot',\n description: [\n 'Sets the positions of the `text` elements.'\n ].join(' ')\n },\n sort: pieAttrs.sort,\n root: sunburstAttrs.root,\n\n domain: domainAttrs({name: 'treemap', trace: true, editType: 'calc'}),\n};\n","'use strict';\n\nvar plots = require('../../plots/plots');\n\nexports.name = 'treemap';\n\nexports.plot = function(gd, traces, transitionOpts, makeOnCompleteCallback) {\n plots.plotBasePlot(exports.name, gd, traces, transitionOpts, makeOnCompleteCallback);\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n plots.cleanBasePlot(exports.name, newFullData, newFullLayout, oldFullData, oldFullLayout);\n};\n","'use strict';\n\nvar calc = require('../sunburst/calc');\n\nexports.calc = function(gd, trace) {\n return calc.calc(gd, trace);\n};\n\nexports.crossTraceCalc = function(gd) {\n return calc._runCrossTraceCalc('treemap', gd);\n};\n","'use strict';\n\nmodule.exports = {\n CLICK_TRANSITION_TIME: 750,\n CLICK_TRANSITION_EASING: 'poly',\n eventDataKeys: [\n // string\n 'currentPath',\n 'root',\n 'entry',\n // no need to add 'parent' here\n\n // percentages i.e. ratios\n 'percentRoot',\n 'percentEntry',\n 'percentParent'\n ],\n gapWithPathbar: 1 // i.e. one pixel\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar attributes = require('./attributes');\nvar Color = require('../../components/color');\nvar handleDomainDefaults = require('../../plots/domain').defaults;\nvar handleText = require('../bar/defaults').handleText;\nvar TEXTPAD = require('../bar/constants').TEXTPAD;\nvar handleMarkerDefaults = require('../pie/defaults').handleMarkerDefaults;\n\nvar Colorscale = require('../../components/colorscale');\nvar hasColorscale = Colorscale.hasColorscale;\nvar colorscaleDefaults = Colorscale.handleDefaults;\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var labels = coerce('labels');\n var parents = coerce('parents');\n\n if(!labels || !labels.length || !parents || !parents.length) {\n traceOut.visible = false;\n return;\n }\n\n var vals = coerce('values');\n if(vals && vals.length) {\n coerce('branchvalues');\n } else {\n coerce('count');\n }\n\n coerce('level');\n coerce('maxdepth');\n\n var packing = coerce('tiling.packing');\n if(packing === 'squarify') {\n coerce('tiling.squarifyratio');\n }\n\n coerce('tiling.flip');\n coerce('tiling.pad');\n\n var text = coerce('text');\n coerce('texttemplate');\n if(!traceOut.texttemplate) coerce('textinfo', Lib.isArrayOrTypedArray(text) ? 'text+label' : 'label');\n\n coerce('hovertext');\n coerce('hovertemplate');\n\n var hasPathbar = coerce('pathbar.visible');\n\n var textposition = 'auto';\n handleText(traceIn, traceOut, layout, coerce, textposition, {\n hasPathbar: hasPathbar,\n moduleHasSelected: false,\n moduleHasUnselected: false,\n moduleHasConstrain: false,\n moduleHasCliponaxis: false,\n moduleHasTextangle: false,\n moduleHasInsideanchor: false\n });\n coerce('textposition');\n var bottomText = traceOut.textposition.indexOf('bottom') !== -1;\n\n handleMarkerDefaults(traceIn, traceOut, layout, coerce);\n var withColorscale = traceOut._hasColorscale = (\n hasColorscale(traceIn, 'marker', 'colors') ||\n (traceIn.marker || {}).coloraxis // N.B. special logic to consider \"values\" colorscales\n );\n if(withColorscale) {\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: 'marker.', cLetter: 'c'});\n } else {\n coerce('marker.depthfade', !(traceOut.marker.colors || []).length);\n }\n\n var headerSize = traceOut.textfont.size * 2;\n\n coerce('marker.pad.t', bottomText ? headerSize / 4 : headerSize);\n coerce('marker.pad.l', headerSize / 4);\n coerce('marker.pad.r', headerSize / 4);\n coerce('marker.pad.b', bottomText ? headerSize : headerSize / 4);\n\n coerce('marker.cornerradius');\n\n traceOut._hovered = {\n marker: {\n line: {\n width: 2,\n color: Color.contrast(layout.paper_bgcolor)\n }\n }\n };\n\n if(hasPathbar) {\n // This works even for multi-line labels as treemap pathbar trim out line breaks\n coerce('pathbar.thickness', traceOut.pathbar.textfont.size + 2 * TEXTPAD);\n\n coerce('pathbar.side');\n coerce('pathbar.edgeshape');\n }\n\n coerce('sort');\n\n coerce('root.color');\n\n handleDomainDefaults(traceOut, layout, coerce);\n\n // do not support transforms for now\n traceOut._length = null;\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar helpers = require('../sunburst/helpers');\nvar uniformText = require('../bar/uniform_text');\nvar clearMinTextSize = uniformText.clearMinTextSize;\nvar resizeText = require('../bar/style').resizeText;\n\nvar plotOne = require('./plot_one');\n\nmodule.exports = function _plot(gd, cdmodule, transitionOpts, makeOnCompleteCallback, opts) {\n var type = opts.type;\n var drawDescendants = opts.drawDescendants;\n\n var fullLayout = gd._fullLayout;\n var layer = fullLayout['_' + type + 'layer'];\n var join, onComplete;\n\n // If transition config is provided, then it is only a partial replot and traces not\n // updated are removed.\n var isFullReplot = !transitionOpts;\n\n clearMinTextSize(type, fullLayout);\n\n join = layer.selectAll('g.trace.' + type)\n .data(cdmodule, function(cd) { return cd[0].trace.uid; });\n\n join.enter().append('g')\n .classed('trace', true)\n .classed(type, true);\n\n join.order();\n\n if(!fullLayout.uniformtext.mode && helpers.hasTransition(transitionOpts)) {\n if(makeOnCompleteCallback) {\n // If it was passed a callback to register completion, make a callback. If\n // this is created, then it must be executed on completion, otherwise the\n // pos-transition redraw will not execute:\n onComplete = makeOnCompleteCallback();\n }\n\n var transition = d3.transition()\n .duration(transitionOpts.duration)\n .ease(transitionOpts.easing)\n .each('end', function() { onComplete && onComplete(); })\n .each('interrupt', function() { onComplete && onComplete(); });\n\n transition.each(function() {\n // Must run the selection again since otherwise enters/updates get grouped together\n // and these get executed out of order. Except we need them in order!\n layer.selectAll('g.trace').each(function(cd) {\n plotOne(gd, cd, this, transitionOpts, drawDescendants);\n });\n });\n } else {\n join.each(function(cd) {\n plotOne(gd, cd, this, transitionOpts, drawDescendants);\n });\n\n if(fullLayout.uniformtext.mode) {\n resizeText(gd, layer.selectAll('.trace'), type);\n }\n }\n\n if(isFullReplot) {\n join.exit().remove();\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\nvar Drawing = require('../../components/drawing');\nvar svgTextUtils = require('../../lib/svg_text_utils');\n\nvar partition = require('./partition');\nvar styleOne = require('./style').styleOne;\nvar constants = require('./constants');\nvar helpers = require('../sunburst/helpers');\nvar attachFxHandlers = require('../sunburst/fx');\n\nvar onPathbar = true; // for Ancestors\n\nmodule.exports = function drawAncestors(gd, cd, entry, slices, opts) {\n var barDifY = opts.barDifY;\n var width = opts.width;\n var height = opts.height;\n var viewX = opts.viewX;\n var viewY = opts.viewY;\n var pathSlice = opts.pathSlice;\n var toMoveInsideSlice = opts.toMoveInsideSlice;\n var strTransform = opts.strTransform;\n var hasTransition = opts.hasTransition;\n var handleSlicesExit = opts.handleSlicesExit;\n var makeUpdateSliceInterpolator = opts.makeUpdateSliceInterpolator;\n var makeUpdateTextInterpolator = opts.makeUpdateTextInterpolator;\n var refRect = {};\n\n var isStatic = gd._context.staticPlot;\n\n var fullLayout = gd._fullLayout;\n var cd0 = cd[0];\n var trace = cd0.trace;\n var hierarchy = cd0.hierarchy;\n\n var eachWidth = width / trace._entryDepth;\n\n var pathIds = helpers.listPath(entry.data, 'id');\n\n var sliceData = partition(hierarchy.copy(), [width, height], {\n packing: 'dice',\n pad: {\n inner: 0,\n top: 0,\n left: 0,\n right: 0,\n bottom: 0\n }\n }).descendants();\n\n // edit slices that show up on graph\n sliceData = sliceData.filter(function(pt) {\n var level = pathIds.indexOf(pt.data.id);\n if(level === -1) return false;\n\n pt.x0 = eachWidth * level;\n pt.x1 = eachWidth * (level + 1);\n pt.y0 = barDifY;\n pt.y1 = barDifY + height;\n\n pt.onPathbar = true;\n\n return true;\n });\n\n sliceData.reverse();\n\n slices = slices.data(sliceData, helpers.getPtId);\n\n slices.enter().append('g')\n .classed('pathbar', true);\n\n handleSlicesExit(slices, onPathbar, refRect, [width, height], pathSlice);\n\n slices.order();\n\n var updateSlices = slices;\n if(hasTransition) {\n updateSlices = updateSlices.transition().each('end', function() {\n // N.B. gd._transitioning is (still) *true* by the time\n // transition updates get here\n var sliceTop = d3.select(this);\n helpers.setSliceCursor(sliceTop, gd, {\n hideOnRoot: false,\n hideOnLeaves: false,\n isTransitioning: false\n });\n });\n }\n\n updateSlices.each(function(pt) {\n // for bbox\n pt._x0 = viewX(pt.x0);\n pt._x1 = viewX(pt.x1);\n pt._y0 = viewY(pt.y0);\n pt._y1 = viewY(pt.y1);\n\n pt._hoverX = viewX(pt.x1 - Math.min(width, height) / 2);\n pt._hoverY = viewY(pt.y1 - height / 2);\n\n var sliceTop = d3.select(this);\n\n var slicePath = Lib.ensureSingle(sliceTop, 'path', 'surface', function(s) {\n s.style('pointer-events', isStatic ? 'none' : 'all');\n });\n\n if(hasTransition) {\n slicePath.transition().attrTween('d', function(pt2) {\n var interp = makeUpdateSliceInterpolator(pt2, onPathbar, refRect, [width, height]);\n return function(t) { return pathSlice(interp(t)); };\n });\n } else {\n slicePath.attr('d', pathSlice);\n }\n\n sliceTop\n .call(attachFxHandlers, entry, gd, cd, {\n styleOne: styleOne,\n eventDataKeys: constants.eventDataKeys,\n transitionTime: constants.CLICK_TRANSITION_TIME,\n transitionEasing: constants.CLICK_TRANSITION_EASING\n })\n .call(helpers.setSliceCursor, gd, {\n hideOnRoot: false,\n hideOnLeaves: false,\n isTransitioning: gd._transitioning\n });\n\n slicePath.call(styleOne, pt, trace, gd, {\n hovered: false\n });\n\n pt._text = (helpers.getPtLabel(pt) || '').split('
').join(' ') || '';\n\n var sliceTextGroup = Lib.ensureSingle(sliceTop, 'g', 'slicetext');\n var sliceText = Lib.ensureSingle(sliceTextGroup, 'text', '', function(s) {\n // prohibit tex interpretation until we can handle\n // tex and regular text together\n s.attr('data-notex', 1);\n });\n\n var font = Lib.ensureUniformFontSize(gd, helpers.determineTextFont(trace, pt, fullLayout.font, {\n onPathbar: true\n }));\n\n sliceText.text(pt._text || ' ') // use one space character instead of a blank string to avoid jumps during transition\n .classed('slicetext', true)\n .attr('text-anchor', 'start')\n .call(Drawing.font, font)\n .call(svgTextUtils.convertToTspans, gd);\n\n pt.textBB = Drawing.bBox(sliceText.node());\n pt.transform = toMoveInsideSlice(pt, {\n fontSize: font.size,\n onPathbar: true\n });\n pt.transform.fontSize = font.size;\n\n if(hasTransition) {\n sliceText.transition().attrTween('transform', function(pt2) {\n var interp = makeUpdateTextInterpolator(pt2, onPathbar, refRect, [width, height]);\n return function(t) { return strTransform(interp(t)); };\n });\n } else {\n sliceText.attr('transform', strTransform(pt));\n }\n });\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\nvar Drawing = require('../../components/drawing');\nvar svgTextUtils = require('../../lib/svg_text_utils');\n\nvar partition = require('./partition');\nvar styleOne = require('./style').styleOne;\nvar constants = require('./constants');\nvar helpers = require('../sunburst/helpers');\nvar attachFxHandlers = require('../sunburst/fx');\nvar formatSliceLabel = require('../sunburst/plot').formatSliceLabel;\n\nvar onPathbar = false; // for Descendants\n\nmodule.exports = function drawDescendants(gd, cd, entry, slices, opts) {\n var width = opts.width;\n var height = opts.height;\n var viewX = opts.viewX;\n var viewY = opts.viewY;\n var pathSlice = opts.pathSlice;\n var toMoveInsideSlice = opts.toMoveInsideSlice;\n var strTransform = opts.strTransform;\n var hasTransition = opts.hasTransition;\n var handleSlicesExit = opts.handleSlicesExit;\n var makeUpdateSliceInterpolator = opts.makeUpdateSliceInterpolator;\n var makeUpdateTextInterpolator = opts.makeUpdateTextInterpolator;\n var prevEntry = opts.prevEntry;\n var refRect = {};\n\n var isStatic = gd._context.staticPlot;\n\n var fullLayout = gd._fullLayout;\n var cd0 = cd[0];\n var trace = cd0.trace;\n\n var hasLeft = trace.textposition.indexOf('left') !== -1;\n var hasRight = trace.textposition.indexOf('right') !== -1;\n var hasBottom = trace.textposition.indexOf('bottom') !== -1;\n\n var noRoomForHeader = (!hasBottom && !trace.marker.pad.t) || (hasBottom && !trace.marker.pad.b);\n\n // N.B. slice data isn't the calcdata,\n // grab corresponding calcdata item in sliceData[i].data.data\n var allData = partition(entry, [width, height], {\n packing: trace.tiling.packing,\n squarifyratio: trace.tiling.squarifyratio,\n flipX: trace.tiling.flip.indexOf('x') > -1,\n flipY: trace.tiling.flip.indexOf('y') > -1,\n pad: {\n inner: trace.tiling.pad,\n top: trace.marker.pad.t,\n left: trace.marker.pad.l,\n right: trace.marker.pad.r,\n bottom: trace.marker.pad.b,\n }\n });\n\n var sliceData = allData.descendants();\n\n var minVisibleDepth = Infinity;\n var maxVisibleDepth = -Infinity;\n sliceData.forEach(function(pt) {\n var depth = pt.depth;\n if(depth >= trace._maxDepth) {\n // hide slices that won't show up on graph\n pt.x0 = pt.x1 = (pt.x0 + pt.x1) / 2;\n pt.y0 = pt.y1 = (pt.y0 + pt.y1) / 2;\n } else {\n minVisibleDepth = Math.min(minVisibleDepth, depth);\n maxVisibleDepth = Math.max(maxVisibleDepth, depth);\n }\n });\n\n slices = slices.data(sliceData, helpers.getPtId);\n\n trace._maxVisibleLayers = isFinite(maxVisibleDepth) ? maxVisibleDepth - minVisibleDepth + 1 : 0;\n\n slices.enter().append('g')\n .classed('slice', true);\n\n handleSlicesExit(slices, onPathbar, refRect, [width, height], pathSlice);\n\n slices.order();\n\n // next coords of previous entry\n var nextOfPrevEntry = null;\n if(hasTransition && prevEntry) {\n var prevEntryId = helpers.getPtId(prevEntry);\n slices.each(function(pt) {\n if(nextOfPrevEntry === null && (helpers.getPtId(pt) === prevEntryId)) {\n nextOfPrevEntry = {\n x0: pt.x0,\n x1: pt.x1,\n y0: pt.y0,\n y1: pt.y1\n };\n }\n });\n }\n\n var getRefRect = function() {\n return nextOfPrevEntry || {\n x0: 0,\n x1: width,\n y0: 0,\n y1: height\n };\n };\n\n var updateSlices = slices;\n if(hasTransition) {\n updateSlices = updateSlices.transition().each('end', function() {\n // N.B. gd._transitioning is (still) *true* by the time\n // transition updates get here\n var sliceTop = d3.select(this);\n helpers.setSliceCursor(sliceTop, gd, {\n hideOnRoot: true,\n hideOnLeaves: false,\n isTransitioning: false\n });\n });\n }\n\n updateSlices.each(function(pt) {\n var isHeader = helpers.isHeader(pt, trace);\n\n // for bbox\n pt._x0 = viewX(pt.x0);\n pt._x1 = viewX(pt.x1);\n pt._y0 = viewY(pt.y0);\n pt._y1 = viewY(pt.y1);\n\n pt._hoverX = viewX(pt.x1 - trace.marker.pad.r),\n pt._hoverY = hasBottom ?\n viewY(pt.y1 - trace.marker.pad.b / 2) :\n viewY(pt.y0 + trace.marker.pad.t / 2);\n\n var sliceTop = d3.select(this);\n\n var slicePath = Lib.ensureSingle(sliceTop, 'path', 'surface', function(s) {\n s.style('pointer-events', isStatic ? 'none' : 'all');\n });\n\n if(hasTransition) {\n slicePath.transition().attrTween('d', function(pt2) {\n var interp = makeUpdateSliceInterpolator(pt2, onPathbar, getRefRect(), [width, height]);\n return function(t) { return pathSlice(interp(t)); };\n });\n } else {\n slicePath.attr('d', pathSlice);\n }\n\n sliceTop\n .call(attachFxHandlers, entry, gd, cd, {\n styleOne: styleOne,\n eventDataKeys: constants.eventDataKeys,\n transitionTime: constants.CLICK_TRANSITION_TIME,\n transitionEasing: constants.CLICK_TRANSITION_EASING\n })\n .call(helpers.setSliceCursor, gd, { isTransitioning: gd._transitioning });\n\n slicePath.call(styleOne, pt, trace, gd, {\n hovered: false\n });\n\n if(pt.x0 === pt.x1 || pt.y0 === pt.y1) {\n pt._text = '';\n } else {\n if(isHeader) {\n pt._text = noRoomForHeader ? '' : helpers.getPtLabel(pt) || '';\n } else {\n pt._text = formatSliceLabel(pt, entry, trace, cd, fullLayout) || '';\n }\n }\n\n var sliceTextGroup = Lib.ensureSingle(sliceTop, 'g', 'slicetext');\n var sliceText = Lib.ensureSingle(sliceTextGroup, 'text', '', function(s) {\n // prohibit tex interpretation until we can handle\n // tex and regular text together\n s.attr('data-notex', 1);\n });\n\n var font = Lib.ensureUniformFontSize(gd, helpers.determineTextFont(trace, pt, fullLayout.font));\n\n\n var text = pt._text || ' '; // use one space character instead of a blank string to avoid jumps during transition\n var singleLineHeader = isHeader && text.indexOf('
') === -1;\n\n sliceText.text(text)\n .classed('slicetext', true)\n .attr('text-anchor', hasRight ? 'end' : (hasLeft || singleLineHeader) ? 'start' : 'middle')\n .call(Drawing.font, font)\n .call(svgTextUtils.convertToTspans, gd);\n\n pt.textBB = Drawing.bBox(sliceText.node());\n pt.transform = toMoveInsideSlice(pt, {\n fontSize: font.size,\n isHeader: isHeader\n });\n pt.transform.fontSize = font.size;\n\n if(hasTransition) {\n sliceText.transition().attrTween('transform', function(pt2) {\n var interp = makeUpdateTextInterpolator(pt2, onPathbar, getRefRect(), [width, height]);\n return function(t) { return strTransform(interp(t)); };\n });\n } else {\n sliceText.attr('transform', strTransform(pt));\n }\n });\n\n return nextOfPrevEntry;\n};\n","'use strict';\n\nmodule.exports = function flipTree(node, size, opts) {\n var tmp;\n\n if(opts.swapXY) {\n // swap x0 and y0\n tmp = node.x0;\n node.x0 = node.y0;\n node.y0 = tmp;\n\n // swap x1 and y1\n tmp = node.x1;\n node.x1 = node.y1;\n node.y1 = tmp;\n }\n\n if(opts.flipX) {\n tmp = node.x0;\n node.x0 = size[0] - node.x1;\n node.x1 = size[0] - tmp;\n }\n\n if(opts.flipY) {\n tmp = node.y0;\n node.y0 = size[1] - node.y1;\n node.y1 = size[1] - tmp;\n }\n\n var children = node.children;\n if(children) {\n for(var i = 0; i < children.length; i++) {\n flipTree(children[i], size, opts);\n }\n }\n};\n","'use strict';\n\nmodule.exports = {\n moduleType: 'trace',\n name: 'treemap',\n basePlotModule: require('./base_plot'),\n categories: [],\n animatable: true,\n\n attributes: require('./attributes'),\n layoutAttributes: require('./layout_attributes'),\n supplyDefaults: require('./defaults'),\n supplyLayoutDefaults: require('./layout_defaults'),\n\n calc: require('./calc').calc,\n crossTraceCalc: require('./calc').crossTraceCalc,\n\n plot: require('./plot'),\n style: require('./style').style,\n\n colorbar: require('../scatter/marker_colorbar'),\n\n meta: {\n description: [\n 'Visualize hierarchal data from leaves (and/or outer branches) towards root',\n 'with rectangles. The treemap sectors are determined by the entries in',\n '*labels* or *ids* and in *parents*.'\n ].join(' ')\n }\n};\n","'use strict';\n\nmodule.exports = {\n treemapcolorway: {\n valType: 'colorlist',\n editType: 'calc',\n description: [\n 'Sets the default treemap slice colors. Defaults to the main',\n '`colorway` used for trace colors. If you specify a new',\n 'list here it can still be extended with lighter and darker',\n 'colors, see `extendtreemapcolors`.'\n ].join(' ')\n },\n extendtreemapcolors: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'If `true`, the treemap slice colors (whether given by `treemapcolorway` or',\n 'inherited from `colorway`) will be extended to three times its',\n 'original length by first repeating every color 20% lighter then',\n 'each color 20% darker. This is intended to reduce the likelihood',\n 'of reusing the same color when you have many slices, but you can',\n 'set `false` to disable.',\n 'Colors provided in the trace, using `marker.colors`, are never',\n 'extended.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar layoutAttributes = require('./layout_attributes');\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n coerce('treemapcolorway', layoutOut.colorway);\n coerce('extendtreemapcolors');\n};\n","'use strict';\n\nvar d3Hierarchy = require('d3-hierarchy');\nvar flipTree = require('./flip_tree');\n\nmodule.exports = function partition(entry, size, opts) {\n var flipX = opts.flipX;\n var flipY = opts.flipY;\n var swapXY = opts.packing === 'dice-slice';\n\n var top = opts.pad[flipY ? 'bottom' : 'top'];\n var left = opts.pad[flipX ? 'right' : 'left'];\n var right = opts.pad[flipX ? 'left' : 'right'];\n var bottom = opts.pad[flipY ? 'top' : 'bottom'];\n\n var tmp;\n if(swapXY) {\n tmp = left;\n left = top;\n top = tmp;\n\n tmp = right;\n right = bottom;\n bottom = tmp;\n }\n\n var result = d3Hierarchy\n .treemap()\n .tile(getTilingMethod(opts.packing, opts.squarifyratio))\n .paddingInner(opts.pad.inner)\n .paddingLeft(left)\n .paddingRight(right)\n .paddingTop(top)\n .paddingBottom(bottom)\n .size(\n swapXY ? [size[1], size[0]] : size\n )(entry);\n\n if(swapXY || flipX || flipY) {\n flipTree(result, size, {\n swapXY: swapXY,\n flipX: flipX,\n flipY: flipY\n });\n }\n return result;\n};\n\nfunction getTilingMethod(key, squarifyratio) {\n switch(key) {\n case 'squarify':\n return d3Hierarchy.treemapSquarify.ratio(squarifyratio);\n case 'binary':\n return d3Hierarchy.treemapBinary;\n case 'dice':\n return d3Hierarchy.treemapDice;\n case 'slice':\n return d3Hierarchy.treemapSlice;\n default: // i.e. 'slice-dice' | 'dice-slice'\n return d3Hierarchy.treemapSliceDice;\n }\n}\n","'use strict';\n\nvar draw = require('./draw');\nvar drawDescendants = require('./draw_descendants');\n\nmodule.exports = function _plot(gd, cdmodule, transitionOpts, makeOnCompleteCallback) {\n return draw(gd, cdmodule, transitionOpts, makeOnCompleteCallback, {\n type: 'treemap',\n drawDescendants: drawDescendants\n });\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar interpolate = require('d3-interpolate').interpolate;\n\nvar helpers = require('../sunburst/helpers');\n\nvar Lib = require('../../lib');\nvar TEXTPAD = require('../bar/constants').TEXTPAD;\nvar barPlot = require('../bar/plot');\nvar toMoveInsideBar = barPlot.toMoveInsideBar;\nvar uniformText = require('../bar/uniform_text');\nvar recordMinTextSize = uniformText.recordMinTextSize;\nvar constants = require('./constants');\nvar drawAncestors = require('./draw_ancestors');\n\nfunction getKey(pt) {\n return helpers.isHierarchyRoot(pt) ?\n '' : // don't use the dummyId\n helpers.getPtId(pt);\n}\n\nmodule.exports = function plotOne(gd, cd, element, transitionOpts, drawDescendants) {\n var fullLayout = gd._fullLayout;\n var cd0 = cd[0];\n var trace = cd0.trace;\n var type = trace.type;\n var isIcicle = type === 'icicle';\n\n var hierarchy = cd0.hierarchy;\n var entry = helpers.findEntryWithLevel(hierarchy, trace.level);\n\n var gTrace = d3.select(element);\n var selAncestors = gTrace.selectAll('g.pathbar');\n var selDescendants = gTrace.selectAll('g.slice');\n\n if(!entry) {\n selAncestors.remove();\n selDescendants.remove();\n return;\n }\n\n var isRoot = helpers.isHierarchyRoot(entry);\n var hasTransition = !fullLayout.uniformtext.mode && helpers.hasTransition(transitionOpts);\n\n var maxDepth = helpers.getMaxDepth(trace);\n var hasVisibleDepth = function(pt) {\n return pt.data.depth - entry.data.depth < maxDepth;\n };\n\n var gs = fullLayout._size;\n var domain = trace.domain;\n\n var vpw = gs.w * (domain.x[1] - domain.x[0]);\n var vph = gs.h * (domain.y[1] - domain.y[0]);\n var barW = vpw;\n var barH = trace.pathbar.thickness;\n var barPad = trace.marker.line.width + constants.gapWithPathbar;\n var barDifY = !trace.pathbar.visible ? 0 :\n trace.pathbar.side.indexOf('bottom') > -1 ? vph + barPad : -(barH + barPad);\n\n var pathbarOrigin = {\n x0: barW, // slide to the right\n x1: barW,\n y0: barDifY,\n y1: barDifY + barH\n };\n\n var findClosestEdge = function(pt, ref, size) {\n var e = trace.tiling.pad;\n var isLeftOfRect = function(x) { return x - e <= ref.x0; };\n var isRightOfRect = function(x) { return x + e >= ref.x1; };\n var isBottomOfRect = function(y) { return y - e <= ref.y0; };\n var isTopOfRect = function(y) { return y + e >= ref.y1; };\n\n if(pt.x0 === ref.x0 && pt.x1 === ref.x1 && pt.y0 === ref.y0 && pt.y1 === ref.y1) {\n return {\n x0: pt.x0,\n x1: pt.x1,\n y0: pt.y0,\n y1: pt.y1\n };\n }\n\n return {\n x0: isLeftOfRect(pt.x0 - e) ? 0 : isRightOfRect(pt.x0 - e) ? size[0] : pt.x0,\n x1: isLeftOfRect(pt.x1 + e) ? 0 : isRightOfRect(pt.x1 + e) ? size[0] : pt.x1,\n y0: isBottomOfRect(pt.y0 - e) ? 0 : isTopOfRect(pt.y0 - e) ? size[1] : pt.y0,\n y1: isBottomOfRect(pt.y1 + e) ? 0 : isTopOfRect(pt.y1 + e) ? size[1] : pt.y1\n };\n };\n\n // stash of 'previous' position data used by tweening functions\n var prevEntry = null;\n var prevLookupPathbar = {};\n var prevLookupSlices = {};\n var nextOfPrevEntry = null;\n var getPrev = function(pt, onPathbar) {\n return onPathbar ?\n prevLookupPathbar[getKey(pt)] :\n prevLookupSlices[getKey(pt)];\n };\n\n var getOrigin = function(pt, onPathbar, refRect, size) {\n if(onPathbar) {\n return prevLookupPathbar[getKey(hierarchy)] || pathbarOrigin;\n } else {\n var ref = prevLookupSlices[trace.level] || refRect;\n\n if(hasVisibleDepth(pt)) { // case of an empty object - happens when maxdepth is set\n return findClosestEdge(pt, ref, size);\n }\n }\n return {};\n };\n\n // N.B. handle multiple-root special case\n if(cd0.hasMultipleRoots && isRoot) {\n maxDepth++;\n }\n\n trace._maxDepth = maxDepth;\n trace._backgroundColor = fullLayout.paper_bgcolor;\n trace._entryDepth = entry.data.depth;\n trace._atRootLevel = isRoot;\n\n var cenX = -vpw / 2 + gs.l + gs.w * (domain.x[1] + domain.x[0]) / 2;\n var cenY = -vph / 2 + gs.t + gs.h * (1 - (domain.y[1] + domain.y[0]) / 2);\n\n var viewMapX = function(x) { return cenX + x; };\n var viewMapY = function(y) { return cenY + y; };\n\n var barY0 = viewMapY(0);\n var barX0 = viewMapX(0);\n\n var viewBarX = function(x) { return barX0 + x; };\n var viewBarY = function(y) { return barY0 + y; };\n\n function pos(x, y) {\n return x + ',' + y;\n }\n\n var xStart = viewBarX(0);\n var limitX0 = function(p) { p.x = Math.max(xStart, p.x); };\n\n var edgeshape = trace.pathbar.edgeshape;\n\n // pathbar(directory) path generation fn\n var pathAncestor = function(d) {\n var _x0 = viewBarX(Math.max(Math.min(d.x0, d.x0), 0));\n var _x1 = viewBarX(Math.min(Math.max(d.x1, d.x1), barW));\n var _y0 = viewBarY(d.y0);\n var _y1 = viewBarY(d.y1);\n\n var halfH = barH / 2;\n\n var pL = {};\n var pR = {};\n\n pL.x = _x0;\n pR.x = _x1;\n\n pL.y = pR.y = (_y0 + _y1) / 2;\n\n var pA = {x: _x0, y: _y0};\n var pB = {x: _x1, y: _y0};\n var pC = {x: _x1, y: _y1};\n var pD = {x: _x0, y: _y1};\n\n if(edgeshape === '>') {\n pA.x -= halfH;\n pB.x -= halfH;\n pC.x -= halfH;\n pD.x -= halfH;\n } else if(edgeshape === '/') {\n pC.x -= halfH;\n pD.x -= halfH;\n pL.x -= halfH / 2;\n pR.x -= halfH / 2;\n } else if(edgeshape === '\\\\') {\n pA.x -= halfH;\n pB.x -= halfH;\n pL.x -= halfH / 2;\n pR.x -= halfH / 2;\n } else if(edgeshape === '<') {\n pL.x -= halfH;\n pR.x -= halfH;\n }\n\n limitX0(pA);\n limitX0(pD);\n limitX0(pL);\n\n limitX0(pB);\n limitX0(pC);\n limitX0(pR);\n\n return (\n 'M' + pos(pA.x, pA.y) +\n 'L' + pos(pB.x, pB.y) +\n 'L' + pos(pR.x, pR.y) +\n 'L' + pos(pC.x, pC.y) +\n 'L' + pos(pD.x, pD.y) +\n 'L' + pos(pL.x, pL.y) +\n 'Z'\n );\n };\n\n // Note that `pad` is just an integer for `icicle`` traces where\n // `pad` is a hashmap for treemap: pad.t, pad.b, pad.l, and pad.r\n var pad = trace[isIcicle ? 'tiling' : 'marker'].pad;\n\n var hasFlag = function(f) { return trace.textposition.indexOf(f) !== -1; };\n\n var hasTop = hasFlag('top');\n var hasLeft = hasFlag('left');\n var hasRight = hasFlag('right');\n var hasBottom = hasFlag('bottom');\n\n // slice path generation fn\n var pathDescendant = function(d) {\n var _x0 = viewMapX(d.x0);\n var _x1 = viewMapX(d.x1);\n var _y0 = viewMapY(d.y0);\n var _y1 = viewMapY(d.y1);\n\n var dx = _x1 - _x0;\n var dy = _y1 - _y0;\n if(!dx || !dy) return '';\n\n var cornerradius = trace.marker.cornerradius || 0;\n var r = Math.min(cornerradius, dx / 2, dy / 2);\n if(\n r &&\n d.data &&\n d.data.data &&\n d.data.data.label\n ) {\n if(hasTop) r = Math.min(r, pad.t);\n if(hasLeft) r = Math.min(r, pad.l);\n if(hasRight) r = Math.min(r, pad.r);\n if(hasBottom) r = Math.min(r, pad.b);\n }\n\n var arc = function(rx, ry) { return r ? 'a' + pos(r, r) + ' 0 0 1 ' + pos(rx, ry) : ''; };\n\n return (\n 'M' + pos(_x0, _y0 + r) +\n arc(r, -r) +\n 'L' + pos(_x1 - r, _y0) +\n arc(r, r) +\n 'L' + pos(_x1, _y1 - r) +\n arc(-r, r) +\n 'L' + pos(_x0 + r, _y1) +\n arc(-r, -r) + 'Z'\n );\n };\n\n var toMoveInsideSlice = function(pt, opts) {\n var x0 = pt.x0;\n var x1 = pt.x1;\n var y0 = pt.y0;\n var y1 = pt.y1;\n var textBB = pt.textBB;\n\n var _hasTop = hasTop || (opts.isHeader && !hasBottom);\n\n var anchor =\n _hasTop ? 'start' :\n hasBottom ? 'end' : 'middle';\n\n var _hasRight = hasFlag('right');\n var _hasLeft = hasFlag('left') || opts.onPathbar;\n\n var leftToRight =\n _hasLeft ? -1 :\n _hasRight ? 1 : 0;\n\n if(opts.isHeader) {\n x0 += (isIcicle ? pad : pad.l) - TEXTPAD;\n x1 -= (isIcicle ? pad : pad.r) - TEXTPAD;\n if(x0 >= x1) {\n var mid = (x0 + x1) / 2;\n x0 = mid;\n x1 = mid;\n }\n\n // limit the drawing area for headers\n var limY;\n if(hasBottom) {\n limY = y1 - (isIcicle ? pad : pad.b);\n if(y0 < limY && limY < y1) y0 = limY;\n } else {\n limY = y0 + (isIcicle ? pad : pad.t);\n if(y0 < limY && limY < y1) y1 = limY;\n }\n }\n\n // position the text relative to the slice\n var transform = toMoveInsideBar(x0, x1, y0, y1, textBB, {\n isHorizontal: false,\n constrained: true,\n angle: 0,\n anchor: anchor,\n leftToRight: leftToRight\n });\n transform.fontSize = opts.fontSize;\n\n transform.targetX = viewMapX(transform.targetX);\n transform.targetY = viewMapY(transform.targetY);\n\n if(isNaN(transform.targetX) || isNaN(transform.targetY)) {\n return {};\n }\n\n if(x0 !== x1 && y0 !== y1) {\n recordMinTextSize(trace.type, transform, fullLayout);\n }\n\n return {\n scale: transform.scale,\n rotate: transform.rotate,\n textX: transform.textX,\n textY: transform.textY,\n anchorX: transform.anchorX,\n anchorY: transform.anchorY,\n targetX: transform.targetX,\n targetY: transform.targetY\n };\n };\n\n var interpFromParent = function(pt, onPathbar) {\n var parentPrev;\n var i = 0;\n var Q = pt;\n while(!parentPrev && i < maxDepth) { // loop to find a parent/grandParent on the previous graph\n i++;\n Q = Q.parent;\n if(Q) {\n parentPrev = getPrev(Q, onPathbar);\n } else i = maxDepth;\n }\n return parentPrev || {};\n };\n\n var makeExitSliceInterpolator = function(pt, onPathbar, refRect, size) {\n var prev = getPrev(pt, onPathbar);\n var next;\n\n if(onPathbar) {\n next = pathbarOrigin;\n } else {\n var entryPrev = getPrev(entry, onPathbar);\n if(entryPrev) {\n // 'entryPrev' is here has the previous coordinates of the entry\n // node, which corresponds to the last \"clicked\" node when zooming in\n next = findClosestEdge(pt, entryPrev, size);\n } else {\n // this happens when maxdepth is set, when leaves must\n // be removed and the entry is new (i.e. does not have a 'prev' object)\n next = {};\n }\n }\n\n return interpolate(prev, next);\n };\n\n var makeUpdateSliceInterpolator = function(pt, onPathbar, refRect, size, opts) {\n var prev0 = getPrev(pt, onPathbar);\n var prev;\n\n if(prev0) {\n // if pt already on graph, this is easy\n prev = prev0;\n } else {\n // for new pts:\n if(onPathbar) {\n prev = pathbarOrigin;\n } else {\n if(prevEntry) {\n // if trace was visible before\n if(pt.parent) {\n var ref = nextOfPrevEntry || refRect;\n\n if(ref && !onPathbar) {\n prev = findClosestEdge(pt, ref, size);\n } else {\n // if new leaf (when maxdepth is set),\n // grow it from its parent node\n prev = {};\n Lib.extendFlat(prev, interpFromParent(pt, onPathbar));\n }\n } else {\n prev = Lib.extendFlat({}, pt);\n if(isIcicle) {\n if(opts.orientation === 'h') {\n if(opts.flipX) prev.x0 = pt.x1;\n else prev.x1 = 0;\n } else {\n if(opts.flipY) prev.y0 = pt.y1;\n else prev.y1 = 0;\n }\n }\n }\n } else {\n prev = {};\n }\n }\n }\n\n return interpolate(prev, {\n x0: pt.x0,\n x1: pt.x1,\n y0: pt.y0,\n y1: pt.y1\n });\n };\n\n var makeUpdateTextInterpolator = function(pt, onPathbar, refRect, size) {\n var prev0 = getPrev(pt, onPathbar);\n var prev = {};\n var origin = getOrigin(pt, onPathbar, refRect, size);\n\n Lib.extendFlat(prev, {\n transform: toMoveInsideSlice({\n x0: origin.x0,\n x1: origin.x1,\n y0: origin.y0,\n y1: origin.y1,\n textBB: pt.textBB,\n _text: pt._text\n }, {\n isHeader: helpers.isHeader(pt, trace)\n })\n });\n\n if(prev0) {\n // if pt already on graph, this is easy\n prev = prev0;\n } else {\n // for new pts:\n if(pt.parent) {\n Lib.extendFlat(prev, interpFromParent(pt, onPathbar));\n }\n }\n\n var transform = pt.transform;\n if(pt.x0 !== pt.x1 && pt.y0 !== pt.y1) {\n recordMinTextSize(trace.type, transform, fullLayout);\n }\n\n return interpolate(prev, {\n transform: {\n scale: transform.scale,\n rotate: transform.rotate,\n textX: transform.textX,\n textY: transform.textY,\n anchorX: transform.anchorX,\n anchorY: transform.anchorY,\n targetX: transform.targetX,\n targetY: transform.targetY\n }\n });\n };\n\n var handleSlicesExit = function(slices, onPathbar, refRect, size, pathSlice) {\n var width = size[0];\n var height = size[1];\n\n if(hasTransition) {\n slices.exit().transition()\n .each(function() {\n var sliceTop = d3.select(this);\n\n var slicePath = sliceTop.select('path.surface');\n slicePath.transition().attrTween('d', function(pt2) {\n var interp = makeExitSliceInterpolator(pt2, onPathbar, refRect, [width, height]);\n return function(t) { return pathSlice(interp(t)); };\n });\n\n var sliceTextGroup = sliceTop.select('g.slicetext');\n sliceTextGroup.attr('opacity', 0);\n })\n .remove();\n } else {\n slices.exit().remove();\n }\n };\n\n var strTransform = function(d) {\n var transform = d.transform;\n\n if(d.x0 !== d.x1 && d.y0 !== d.y1) {\n recordMinTextSize(trace.type, transform, fullLayout);\n }\n\n return Lib.getTextTransform({\n textX: transform.textX,\n textY: transform.textY,\n anchorX: transform.anchorX,\n anchorY: transform.anchorY,\n targetX: transform.targetX,\n targetY: transform.targetY,\n scale: transform.scale,\n rotate: transform.rotate\n });\n };\n\n if(hasTransition) {\n // Important: do this before binding new sliceData!\n\n selAncestors.each(function(pt) {\n prevLookupPathbar[getKey(pt)] = {\n x0: pt.x0,\n x1: pt.x1,\n y0: pt.y0,\n y1: pt.y1\n };\n\n if(pt.transform) {\n prevLookupPathbar[getKey(pt)].transform = {\n textX: pt.transform.textX,\n textY: pt.transform.textY,\n anchorX: pt.transform.anchorX,\n anchorY: pt.transform.anchorY,\n targetX: pt.transform.targetX,\n targetY: pt.transform.targetY,\n scale: pt.transform.scale,\n rotate: pt.transform.rotate\n };\n }\n });\n\n selDescendants.each(function(pt) {\n prevLookupSlices[getKey(pt)] = {\n x0: pt.x0,\n x1: pt.x1,\n y0: pt.y0,\n y1: pt.y1\n };\n\n if(pt.transform) {\n prevLookupSlices[getKey(pt)].transform = {\n textX: pt.transform.textX,\n textY: pt.transform.textY,\n anchorX: pt.transform.anchorX,\n anchorY: pt.transform.anchorY,\n targetX: pt.transform.targetX,\n targetY: pt.transform.targetY,\n scale: pt.transform.scale,\n rotate: pt.transform.rotate\n };\n }\n\n if(!prevEntry && helpers.isEntry(pt)) {\n prevEntry = pt;\n }\n });\n }\n\n nextOfPrevEntry = drawDescendants(gd, cd, entry, selDescendants, {\n width: vpw,\n height: vph,\n\n viewX: viewMapX,\n viewY: viewMapY,\n\n pathSlice: pathDescendant,\n toMoveInsideSlice: toMoveInsideSlice,\n\n prevEntry: prevEntry,\n makeUpdateSliceInterpolator: makeUpdateSliceInterpolator,\n makeUpdateTextInterpolator: makeUpdateTextInterpolator,\n\n handleSlicesExit: handleSlicesExit,\n hasTransition: hasTransition,\n strTransform: strTransform\n });\n\n if(trace.pathbar.visible) {\n drawAncestors(gd, cd, entry, selAncestors, {\n barDifY: barDifY,\n width: barW,\n height: barH,\n\n viewX: viewBarX,\n viewY: viewBarY,\n\n pathSlice: pathAncestor,\n toMoveInsideSlice: toMoveInsideSlice,\n\n makeUpdateSliceInterpolator: makeUpdateSliceInterpolator,\n makeUpdateTextInterpolator: makeUpdateTextInterpolator,\n\n handleSlicesExit: handleSlicesExit,\n hasTransition: hasTransition,\n strTransform: strTransform\n });\n } else {\n selAncestors.remove();\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Color = require('../../components/color');\nvar Lib = require('../../lib');\nvar helpers = require('../sunburst/helpers');\nvar resizeText = require('../bar/uniform_text').resizeText;\nvar fillOne = require('../sunburst/fill_one');\n\nfunction style(gd) {\n var s = gd._fullLayout._treemaplayer.selectAll('.trace');\n resizeText(gd, s, 'treemap');\n\n s.each(function(cd) {\n var gTrace = d3.select(this);\n var cd0 = cd[0];\n var trace = cd0.trace;\n\n gTrace.style('opacity', trace.opacity);\n\n gTrace.selectAll('path.surface').each(function(pt) {\n d3.select(this).call(styleOne, pt, trace, gd, {\n hovered: false\n });\n });\n });\n}\n\nfunction styleOne(s, pt, trace, gd, opts) {\n var hovered = (opts || {}).hovered;\n var cdi = pt.data.data;\n var ptNumber = cdi.i;\n var lineColor;\n var lineWidth;\n var fillColor = cdi.color;\n var isRoot = helpers.isHierarchyRoot(pt);\n var opacity = 1;\n\n if(hovered) {\n lineColor = trace._hovered.marker.line.color;\n lineWidth = trace._hovered.marker.line.width;\n } else {\n if(isRoot && fillColor === trace.root.color) {\n opacity = 100;\n lineColor = 'rgba(0,0,0,0)';\n lineWidth = 0;\n } else {\n lineColor = Lib.castOption(trace, ptNumber, 'marker.line.color') || Color.defaultLine;\n lineWidth = Lib.castOption(trace, ptNumber, 'marker.line.width') || 0;\n\n if(!trace._hasColorscale && !pt.onPathbar) {\n var depthfade = trace.marker.depthfade;\n if(depthfade) {\n var fadedColor = Color.combine(Color.addOpacity(trace._backgroundColor, 0.75), fillColor);\n var n;\n\n if(depthfade === true) {\n var maxDepth = helpers.getMaxDepth(trace);\n if(isFinite(maxDepth)) {\n if(helpers.isLeaf(pt)) {\n n = 0;\n } else {\n n = (trace._maxVisibleLayers) - (pt.data.depth - trace._entryDepth);\n }\n } else {\n n = pt.data.height + 1;\n }\n } else { // i.e. case of depthfade === 'reversed'\n n = pt.data.depth - trace._entryDepth;\n if(!trace._atRootLevel) n++;\n }\n\n if(n > 0) {\n for(var i = 0; i < n; i++) {\n var ratio = 0.5 * i / n;\n fillColor = Color.combine(Color.addOpacity(fadedColor, ratio), fillColor);\n }\n }\n }\n }\n }\n }\n\n s.call(fillOne, pt, trace, gd, fillColor)\n .style('stroke-width', lineWidth)\n .call(Color.stroke, lineColor)\n .style('opacity', opacity);\n}\n\nmodule.exports = {\n style: style,\n styleOne: styleOne\n};\n","'use strict';\n\nvar boxAttrs = require('../box/attributes');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\n\nmodule.exports = {\n y: boxAttrs.y,\n x: boxAttrs.x,\n x0: boxAttrs.x0,\n y0: boxAttrs.y0,\n\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n\n name: extendFlat({}, boxAttrs.name, {\n description: [\n 'Sets the trace name.',\n 'The trace name appears as the legend item and on hover.',\n 'For violin traces, the name will also be used for the position',\n 'coordinate, if `x` and `x0` (`y` and `y0` if horizontal) are',\n 'missing and the position axis is categorical.',\n 'Note that the trace name is also used as a default value',\n 'for attribute `scalegroup` (please see its description for details).'\n ].join(' ')\n }),\n orientation: extendFlat({}, boxAttrs.orientation, {\n description: [\n 'Sets the orientation of the violin(s).',\n 'If *v* (*h*), the distribution is visualized along',\n 'the vertical (horizontal).'\n ].join(' ')\n }),\n\n bandwidth: {\n valType: 'number',\n min: 0,\n editType: 'calc',\n description: [\n 'Sets the bandwidth used to compute the kernel density estimate.',\n 'By default, the bandwidth is determined by Silverman\\'s rule of thumb.'\n ].join(' ')\n },\n\n scalegroup: {\n valType: 'string',\n dflt: '',\n editType: 'calc',\n description: [\n 'If there are multiple violins that should be sized according to',\n 'to some metric (see `scalemode`), link them by providing a non-empty group id here',\n 'shared by every trace in the same group.',\n 'If a violin\\'s `width` is undefined, `scalegroup` will default to the trace\\'s name.',\n 'In this case, violins with the same names will be linked together'\n ].join(' ')\n },\n scalemode: {\n valType: 'enumerated',\n values: ['width', 'count'],\n dflt: 'width',\n editType: 'calc',\n description: [\n 'Sets the metric by which the width of each violin is determined.',\n '*width* means each violin has the same (max) width',\n '*count* means the violins are scaled by the number of sample points making',\n 'up each violin.'\n ].join(' ')\n },\n\n spanmode: {\n valType: 'enumerated',\n values: ['soft', 'hard', 'manual'],\n dflt: 'soft',\n editType: 'calc',\n description: [\n 'Sets the method by which the span in data space where the density function will be computed.',\n '*soft* means the span goes from the sample\\'s minimum value minus two bandwidths',\n 'to the sample\\'s maximum value plus two bandwidths.',\n '*hard* means the span goes from the sample\\'s minimum to its maximum value.',\n 'For custom span settings, use mode *manual* and fill in the `span` attribute.'\n ].join(' ')\n },\n span: {\n valType: 'info_array',\n items: [\n {valType: 'any', editType: 'calc'},\n {valType: 'any', editType: 'calc'}\n ],\n editType: 'calc',\n description: [\n 'Sets the span in data space for which the density function will be computed.',\n 'Has an effect only when `spanmode` is set to *manual*.'\n ].join(' ')\n },\n\n line: {\n color: {\n valType: 'color',\n editType: 'style',\n description: 'Sets the color of line bounding the violin(s).'\n },\n width: {\n valType: 'number',\n min: 0,\n dflt: 2,\n editType: 'style',\n description: 'Sets the width (in px) of line bounding the violin(s).'\n },\n editType: 'plot'\n },\n fillcolor: boxAttrs.fillcolor,\n\n points: extendFlat({}, boxAttrs.boxpoints, {\n description: [\n 'If *outliers*, only the sample points lying outside the whiskers',\n 'are shown',\n 'If *suspectedoutliers*, the outlier points are shown and',\n 'points either less than 4*Q1-3*Q3 or greater than 4*Q3-3*Q1',\n 'are highlighted (see `outliercolor`)',\n 'If *all*, all sample points are shown',\n 'If *false*, only the violins are shown with no sample points.',\n 'Defaults to *suspectedoutliers* when `marker.outliercolor` or',\n '`marker.line.outliercolor` is set,',\n 'otherwise defaults to *outliers*.'\n ].join(' ')\n }),\n jitter: extendFlat({}, boxAttrs.jitter, {\n description: [\n 'Sets the amount of jitter in the sample points drawn.',\n 'If *0*, the sample points align along the distribution axis.',\n 'If *1*, the sample points are drawn in a random jitter of width',\n 'equal to the width of the violins.'\n ].join(' ')\n }),\n pointpos: extendFlat({}, boxAttrs.pointpos, {\n description: [\n 'Sets the position of the sample points in relation to the violins.',\n 'If *0*, the sample points are places over the center of the violins.',\n 'Positive (negative) values correspond to positions to the',\n 'right (left) for vertical violins and above (below) for horizontal violins.'\n ].join(' ')\n }),\n\n width: extendFlat({}, boxAttrs.width, {\n description: [\n 'Sets the width of the violin in data coordinates.',\n 'If *0* (default value) the width is automatically selected based on the positions',\n 'of other violin traces in the same subplot.',\n ].join(' ')\n }),\n\n marker: boxAttrs.marker,\n text: boxAttrs.text,\n hovertext: boxAttrs.hovertext,\n hovertemplate: boxAttrs.hovertemplate,\n\n quartilemethod: boxAttrs.quartilemethod,\n\n box: {\n visible: {\n valType: 'boolean',\n dflt: false,\n editType: 'plot',\n description: [\n 'Determines if an miniature box plot is drawn inside the violins. '\n ].join(' ')\n },\n width: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0.25,\n editType: 'plot',\n description: [\n 'Sets the width of the inner box plots relative to',\n 'the violins\\' width.',\n 'For example, with 1, the inner box plots are as wide as the violins.'\n ].join(' ')\n },\n fillcolor: {\n valType: 'color',\n editType: 'style',\n description: 'Sets the inner box plot fill color.'\n },\n line: {\n color: {\n valType: 'color',\n editType: 'style',\n description: 'Sets the inner box plot bounding line color.'\n },\n width: {\n valType: 'number',\n min: 0,\n editType: 'style',\n description: 'Sets the inner box plot bounding line width.'\n },\n editType: 'style'\n },\n editType: 'plot'\n },\n\n meanline: {\n visible: {\n valType: 'boolean',\n dflt: false,\n editType: 'plot',\n description: [\n 'Determines if a line corresponding to the sample\\'s mean is shown',\n 'inside the violins.',\n 'If `box.visible` is turned on, the mean line is drawn inside the inner box.',\n 'Otherwise, the mean line is drawn from one side of the violin to other.'\n ].join(' ')\n },\n color: {\n valType: 'color',\n editType: 'style',\n description: 'Sets the mean line color.'\n },\n width: {\n valType: 'number',\n min: 0,\n editType: 'style',\n description: 'Sets the mean line width.'\n },\n editType: 'plot'\n },\n\n side: {\n valType: 'enumerated',\n values: ['both', 'positive', 'negative'],\n dflt: 'both',\n editType: 'calc',\n description: [\n 'Determines on which side of the position value the density function making up',\n 'one half of a violin is plotted.',\n 'Useful when comparing two violin traces under *overlay* mode, where one trace',\n 'has `side` set to *positive* and the other to *negative*.'\n ].join(' ')\n },\n\n offsetgroup: boxAttrs.offsetgroup,\n alignmentgroup: boxAttrs.alignmentgroup,\n\n selected: boxAttrs.selected,\n unselected: boxAttrs.unselected,\n\n hoveron: {\n valType: 'flaglist',\n flags: ['violins', 'points', 'kde'],\n dflt: 'violins+points+kde',\n extras: ['all'],\n editType: 'style',\n description: [\n 'Do the hover effects highlight individual violins',\n 'or sample points or the kernel density estimate or any combination of them?'\n ].join(' ')\n },\n zorder: boxAttrs.zorder\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar boxCalc = require('../box/calc');\nvar helpers = require('./helpers');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nmodule.exports = function calc(gd, trace) {\n var cd = boxCalc(gd, trace);\n\n if(cd[0].t.empty) return cd;\n\n var fullLayout = gd._fullLayout;\n var valAxis = Axes.getFromId(\n gd,\n trace[trace.orientation === 'h' ? 'xaxis' : 'yaxis']\n );\n\n var spanMin = Infinity;\n var spanMax = -Infinity;\n var maxKDE = 0;\n var maxCount = 0;\n\n for(var i = 0; i < cd.length; i++) {\n var cdi = cd[i];\n var vals = cdi.pts.map(helpers.extractVal);\n\n var bandwidth = cdi.bandwidth = calcBandwidth(trace, cdi, vals);\n var span = cdi.span = calcSpan(trace, cdi, valAxis, bandwidth);\n\n if(cdi.min === cdi.max && bandwidth === 0) {\n // if span is zero and bandwidth is zero, we want a violin with zero width\n span = cdi.span = [cdi.min, cdi.max];\n cdi.density = [{v: 1, t: span[0]}];\n cdi.bandwidth = bandwidth;\n maxKDE = Math.max(maxKDE, 1);\n } else {\n // step that well covers the bandwidth and is multiple of span distance\n var dist = span[1] - span[0];\n var n = Math.ceil(dist / (bandwidth / 3));\n var step = dist / n;\n\n if(!isFinite(step) || !isFinite(n)) {\n Lib.error('Something went wrong with computing the violin span');\n cd[0].t.empty = true;\n return cd;\n }\n\n var kde = helpers.makeKDE(cdi, trace, vals);\n cdi.density = new Array(n);\n\n for(var k = 0, t = span[0]; t < (span[1] + step / 2); k++, t += step) {\n var v = kde(t);\n cdi.density[k] = {v: v, t: t};\n maxKDE = Math.max(maxKDE, v);\n }\n }\n\n maxCount = Math.max(maxCount, vals.length);\n spanMin = Math.min(spanMin, span[0]);\n spanMax = Math.max(spanMax, span[1]);\n }\n\n var extremes = Axes.findExtremes(valAxis, [spanMin, spanMax], {padded: true});\n trace._extremes[valAxis._id] = extremes;\n\n if(trace.width) {\n cd[0].t.maxKDE = maxKDE;\n } else {\n var violinScaleGroupStats = fullLayout._violinScaleGroupStats;\n var scaleGroup = trace.scalegroup;\n var groupStats = violinScaleGroupStats[scaleGroup];\n\n if(groupStats) {\n groupStats.maxKDE = Math.max(groupStats.maxKDE, maxKDE);\n groupStats.maxCount = Math.max(groupStats.maxCount, maxCount);\n } else {\n violinScaleGroupStats[scaleGroup] = {\n maxKDE: maxKDE,\n maxCount: maxCount\n };\n }\n }\n\n cd[0].t.labels.kde = Lib._(gd, 'kde:');\n\n return cd;\n};\n\n// Default to Silveman's rule of thumb\n// - https://stats.stackexchange.com/a/6671\n// - https://en.wikipedia.org/wiki/Kernel_density_estimation#A_rule-of-thumb_bandwidth_estimator\n// - https://github.com/statsmodels/statsmodels/blob/master/statsmodels/nonparametric/bandwidths.py\nfunction silvermanRule(len, ssd, iqr) {\n var a = Math.min(ssd, iqr / 1.349);\n return 1.059 * a * Math.pow(len, -0.2);\n}\n\nfunction calcBandwidth(trace, cdi, vals) {\n var span = cdi.max - cdi.min;\n\n // If span is zero\n if(!span) {\n if(trace.bandwidth) {\n return trace.bandwidth;\n } else {\n // if span is zero and no bandwidth is specified\n // it returns zero bandwidth which is a special case\n return 0;\n }\n }\n\n // Limit how small the bandwidth can be.\n //\n // Silverman's rule of thumb can be \"very\" small\n // when IQR does a poor job at describing the spread\n // of the distribution.\n // We also want to limit custom bandwidths\n // to not blow up kde computations.\n\n if(trace.bandwidth) {\n return Math.max(trace.bandwidth, span / 1e4);\n } else {\n var len = vals.length;\n var ssd = Lib.stdev(vals, len - 1, cdi.mean);\n return Math.max(\n silvermanRule(len, ssd, cdi.q3 - cdi.q1),\n span / 100\n );\n }\n}\n\nfunction calcSpan(trace, cdi, valAxis, bandwidth) {\n var spanmode = trace.spanmode;\n var spanIn = trace.span || [];\n var spanTight = [cdi.min, cdi.max];\n var spanLoose = [cdi.min - 2 * bandwidth, cdi.max + 2 * bandwidth];\n var spanOut;\n\n function calcSpanItem(index) {\n var s = spanIn[index];\n var sc = valAxis.type === 'multicategory' ?\n valAxis.r2c(s) :\n valAxis.d2c(s, 0, trace[cdi.valLetter + 'calendar']);\n return sc === BADNUM ? spanLoose[index] : sc;\n }\n\n if(spanmode === 'soft') {\n spanOut = spanLoose;\n } else if(spanmode === 'hard') {\n spanOut = spanTight;\n } else {\n spanOut = [calcSpanItem(0), calcSpanItem(1)];\n }\n\n // to reuse the equal-range-item block\n var dummyAx = {\n type: 'linear',\n range: spanOut\n };\n Axes.setConvert(dummyAx);\n dummyAx.cleanRange();\n\n return spanOut;\n}\n","'use strict';\n\nvar setPositionOffset = require('../box/cross_trace_calc').setPositionOffset;\nvar orientations = ['v', 'h'];\n\nmodule.exports = function crossTraceCalc(gd, plotinfo) {\n var calcdata = gd.calcdata;\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n for(var i = 0; i < orientations.length; i++) {\n var orientation = orientations[i];\n var posAxis = orientation === 'h' ? ya : xa;\n var violinList = [];\n\n for(var j = 0; j < calcdata.length; j++) {\n var cd = calcdata[j];\n var t = cd[0].t;\n var trace = cd[0].trace;\n\n if(trace.visible === true && trace.type === 'violin' &&\n !t.empty &&\n trace.orientation === orientation &&\n trace.xaxis === xa._id &&\n trace.yaxis === ya._id\n ) {\n violinList.push(j);\n }\n }\n\n setPositionOffset('violin', gd, violinList, posAxis);\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../../components/color');\n\nvar boxDefaults = require('../box/defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n function coerce2(attr, dflt) {\n return Lib.coerce2(traceIn, traceOut, attributes, attr, dflt);\n }\n\n boxDefaults.handleSampleDefaults(traceIn, traceOut, coerce, layout);\n if(traceOut.visible === false) return;\n\n coerce('bandwidth');\n coerce('side');\n\n var width = coerce('width');\n if(!width) {\n coerce('scalegroup', traceOut.name);\n coerce('scalemode');\n }\n\n var span = coerce('span');\n var spanmodeDflt;\n if(Array.isArray(span)) spanmodeDflt = 'manual';\n coerce('spanmode', spanmodeDflt);\n\n var lineColor = coerce('line.color', (traceIn.marker || {}).color || defaultColor);\n var lineWidth = coerce('line.width');\n var fillColor = coerce('fillcolor', Color.addOpacity(traceOut.line.color, 0.5));\n\n boxDefaults.handlePointsDefaults(traceIn, traceOut, coerce, {prefix: ''});\n\n var boxWidth = coerce2('box.width');\n var boxFillColor = coerce2('box.fillcolor', fillColor);\n var boxLineColor = coerce2('box.line.color', lineColor);\n var boxLineWidth = coerce2('box.line.width', lineWidth);\n var boxVisible = coerce('box.visible', Boolean(boxWidth || boxFillColor || boxLineColor || boxLineWidth));\n if(!boxVisible) traceOut.box = {visible: false};\n\n var meanLineColor = coerce2('meanline.color', lineColor);\n var meanLineWidth = coerce2('meanline.width', lineWidth);\n var meanLineVisible = coerce('meanline.visible', Boolean(meanLineColor || meanLineWidth));\n if(!meanLineVisible) traceOut.meanline = {visible: false};\n\n coerce('quartilemethod');\n coerce('zorder');\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\n// Maybe add kernels more down the road,\n// but note that the default `spanmode: 'soft'` bounds might have\n// to become kernel-dependent\nvar kernels = {\n gaussian: function(v) {\n return (1 / Math.sqrt(2 * Math.PI)) * Math.exp(-0.5 * v * v);\n }\n};\n\nexports.makeKDE = function(calcItem, trace, vals) {\n var len = vals.length;\n var kernel = kernels.gaussian;\n var bandwidth = calcItem.bandwidth;\n var factor = 1 / (len * bandwidth);\n\n // don't use Lib.aggNums to skip isNumeric checks\n return function(x) {\n var sum = 0;\n for(var i = 0; i < len; i++) {\n sum += kernel((x - vals[i]) / bandwidth);\n }\n return factor * sum;\n };\n};\n\nexports.getPositionOnKdePath = function(calcItem, trace, valuePx) {\n var posLetter, valLetter;\n\n if(trace.orientation === 'h') {\n posLetter = 'y';\n valLetter = 'x';\n } else {\n posLetter = 'x';\n valLetter = 'y';\n }\n\n var pointOnPath = Lib.findPointOnPath(\n calcItem.path,\n valuePx,\n valLetter,\n {pathLength: calcItem.pathLength}\n );\n\n var posCenterPx = calcItem.posCenterPx;\n var posOnPath0 = pointOnPath[posLetter];\n var posOnPath1 = trace.side === 'both' ?\n 2 * posCenterPx - posOnPath0 :\n posCenterPx;\n\n return [posOnPath0, posOnPath1];\n};\n\nexports.getKdeValue = function(calcItem, trace, valueDist) {\n var vals = calcItem.pts.map(exports.extractVal);\n var kde = exports.makeKDE(calcItem, trace, vals);\n return kde(valueDist) / calcItem.posDensityScale;\n};\n\nexports.extractVal = function(o) { return o.v; };\n","'use strict';\n\nvar Color = require('../../components/color');\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar boxHoverPoints = require('../box/hover');\nvar helpers = require('./helpers');\n\nmodule.exports = function hoverPoints(pointData, xval, yval, hovermode, opts) {\n if(!opts) opts = {};\n var hoverLayer = opts.hoverLayer;\n\n var cd = pointData.cd;\n var trace = cd[0].trace;\n var hoveron = trace.hoveron;\n var hasHoveronViolins = hoveron.indexOf('violins') !== -1;\n var hasHoveronKDE = hoveron.indexOf('kde') !== -1;\n var closeData = [];\n var closePtData;\n var violinLineAttrs;\n\n if(hasHoveronViolins || hasHoveronKDE) {\n var closeBoxData = boxHoverPoints.hoverOnBoxes(pointData, xval, yval, hovermode);\n\n if(hasHoveronKDE && closeBoxData.length > 0) {\n var xa = pointData.xa;\n var ya = pointData.ya;\n var pLetter, vLetter, pAxis, vAxis, vVal;\n\n if(trace.orientation === 'h') {\n vVal = xval;\n pLetter = 'y';\n pAxis = ya;\n vLetter = 'x';\n vAxis = xa;\n } else {\n vVal = yval;\n pLetter = 'x';\n pAxis = xa;\n vLetter = 'y';\n vAxis = ya;\n }\n\n var di = cd[pointData.index];\n\n if(vVal >= di.span[0] && vVal <= di.span[1]) {\n var kdePointData = Lib.extendFlat({}, pointData);\n var vValPx = vAxis.c2p(vVal, true);\n var kdeVal = helpers.getKdeValue(di, trace, vVal);\n var pOnPath = helpers.getPositionOnKdePath(di, trace, vValPx);\n var paOffset = pAxis._offset;\n var paLength = pAxis._length;\n\n kdePointData[pLetter + '0'] = pOnPath[0];\n kdePointData[pLetter + '1'] = pOnPath[1];\n kdePointData[vLetter + '0'] = kdePointData[vLetter + '1'] = vValPx;\n kdePointData[vLetter + 'Label'] = vLetter + ': ' + Axes.hoverLabelText(vAxis, vVal, trace[vLetter + 'hoverformat']) + ', ' + cd[0].t.labels.kde + ' ' + kdeVal.toFixed(3);\n\n // move the spike to the KDE point\n var medId = 0;\n for(var k = 0; k < closeBoxData.length; k++) {\n if(closeBoxData[k].attr === 'med') {\n medId = k;\n break;\n }\n }\n\n kdePointData.spikeDistance = closeBoxData[medId].spikeDistance;\n var spikePosAttr = pLetter + 'Spike';\n kdePointData[spikePosAttr] = closeBoxData[medId][spikePosAttr];\n closeBoxData[medId].spikeDistance = undefined;\n closeBoxData[medId][spikePosAttr] = undefined;\n\n // no hovertemplate support yet\n kdePointData.hovertemplate = false;\n\n closeData.push(kdePointData);\n\n violinLineAttrs = {};\n violinLineAttrs[pLetter + '1'] = Lib.constrain(paOffset + pOnPath[0], paOffset, paOffset + paLength);\n violinLineAttrs[pLetter + '2'] = Lib.constrain(paOffset + pOnPath[1], paOffset, paOffset + paLength);\n violinLineAttrs[vLetter + '1'] = violinLineAttrs[vLetter + '2'] = vAxis._offset + vValPx;\n }\n }\n\n if(hasHoveronViolins) {\n closeData = closeData.concat(closeBoxData);\n }\n }\n\n if(hoveron.indexOf('points') !== -1) {\n closePtData = boxHoverPoints.hoverOnPoints(pointData, xval, yval);\n }\n\n // update violin line (if any)\n var violinLine = hoverLayer.selectAll('.violinline-' + trace.uid)\n .data(violinLineAttrs ? [0] : []);\n violinLine.enter().append('line')\n .classed('violinline-' + trace.uid, true)\n .attr('stroke-width', 1.5);\n violinLine.exit().remove();\n violinLine.attr(violinLineAttrs).call(Color.stroke, pointData.color);\n\n // same combine logic as box hoverPoints\n if(hovermode === 'closest') {\n if(closePtData) return [closePtData];\n return closeData;\n }\n if(closePtData) {\n closeData.push(closePtData);\n return closeData;\n }\n return closeData;\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n layoutAttributes: require('./layout_attributes'),\n supplyDefaults: require('./defaults'),\n crossTraceDefaults: require('../box/defaults').crossTraceDefaults,\n supplyLayoutDefaults: require('./layout_defaults'),\n calc: require('./calc'),\n crossTraceCalc: require('./cross_trace_calc'),\n plot: require('./plot'),\n style: require('./style'),\n styleOnSelect: require('../scatter/style').styleOnSelect,\n hoverPoints: require('./hover'),\n selectPoints: require('../box/select'),\n\n moduleType: 'trace',\n name: 'violin',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['cartesian', 'svg', 'symbols', 'oriented', 'box-violin', 'showLegend', 'violinLayout', 'zoomScale'],\n meta: {\n description: [\n 'In vertical (horizontal) violin plots,',\n 'statistics are computed using `y` (`x`) values.',\n 'By supplying an `x` (`y`) array, one violin per distinct x (y) value',\n 'is drawn',\n 'If no `x` (`y`) {array} is provided, a single violin is drawn.',\n 'That violin position is then positioned with',\n 'with `name` or with `x0` (`y0`) if provided.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar boxLayoutAttrs = require('../box/layout_attributes');\nvar extendFlat = require('../../lib').extendFlat;\n\nmodule.exports = {\n violinmode: extendFlat({}, boxLayoutAttrs.boxmode, {\n description: [\n 'Determines how violins at the same location coordinate',\n 'are displayed on the graph.',\n 'If *group*, the violins are plotted next to one another',\n 'centered around the shared location.',\n 'If *overlay*, the violins are plotted over one another,',\n 'you might need to set *opacity* to see them multiple violins.',\n 'Has no effect on traces that have *width* set.'\n ].join(' ')\n }),\n violingap: extendFlat({}, boxLayoutAttrs.boxgap, {\n description: [\n 'Sets the gap (in plot fraction) between violins of',\n 'adjacent location coordinates.',\n 'Has no effect on traces that have *width* set.'\n ].join(' ')\n }),\n violingroupgap: extendFlat({}, boxLayoutAttrs.boxgroupgap, {\n description: [\n 'Sets the gap (in plot fraction) between violins of',\n 'the same location coordinate.',\n 'Has no effect on traces that have *width* set.'\n ].join(' ')\n })\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar layoutAttributes = require('./layout_attributes');\nvar boxLayoutDefaults = require('../box/layout_defaults');\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut, fullData) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n boxLayoutDefaults._supply(layoutIn, layoutOut, fullData, coerce, 'violin');\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\nvar Drawing = require('../../components/drawing');\n\nvar boxPlot = require('../box/plot');\nvar linePoints = require('../scatter/line_points');\nvar helpers = require('./helpers');\n\nmodule.exports = function plot(gd, plotinfo, cdViolins, violinLayer) {\n var isStatic = gd._context.staticPlot;\n var fullLayout = gd._fullLayout;\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n function makePath(pts, trace) {\n var segments = linePoints(pts, {\n xaxis: xa,\n yaxis: ya,\n trace: trace,\n connectGaps: true,\n baseTolerance: 0.75,\n shape: 'spline',\n simplify: true,\n linearized: true\n });\n return Drawing.smoothopen(segments[0], 1);\n }\n\n Lib.makeTraceGroups(violinLayer, cdViolins, 'trace violins').each(function(cd) {\n var plotGroup = d3.select(this);\n var cd0 = cd[0];\n var t = cd0.t;\n var trace = cd0.trace;\n\n if(trace.visible !== true || t.empty) {\n plotGroup.remove();\n return;\n }\n\n var bPos = t.bPos;\n var bdPos = t.bdPos;\n var valAxis = plotinfo[t.valLetter + 'axis'];\n var posAxis = plotinfo[t.posLetter + 'axis'];\n var hasBothSides = trace.side === 'both';\n var hasPositiveSide = hasBothSides || trace.side === 'positive';\n var hasNegativeSide = hasBothSides || trace.side === 'negative';\n\n var violins = plotGroup.selectAll('path.violin').data(Lib.identity);\n\n violins.enter().append('path')\n .style('vector-effect', isStatic ? 'none' : 'non-scaling-stroke')\n .attr('class', 'violin');\n\n violins.exit().remove();\n\n violins.each(function(d) {\n var pathSel = d3.select(this);\n var density = d.density;\n var len = density.length;\n var posCenter = posAxis.c2l(d.pos + bPos, true);\n var posCenterPx = posAxis.l2p(posCenter);\n\n var scale;\n if(trace.width) {\n scale = t.maxKDE / bdPos;\n } else {\n var groupStats = fullLayout._violinScaleGroupStats[trace.scalegroup];\n scale = trace.scalemode === 'count' ?\n (groupStats.maxKDE / bdPos) * (groupStats.maxCount / d.pts.length) :\n groupStats.maxKDE / bdPos;\n }\n\n var pathPos, pathNeg, path;\n var i, k, pts, pt;\n\n if(hasPositiveSide) {\n pts = new Array(len);\n for(i = 0; i < len; i++) {\n pt = pts[i] = {};\n pt[t.posLetter] = posCenter + (density[i].v / scale);\n pt[t.valLetter] = valAxis.c2l(density[i].t, true);\n }\n pathPos = makePath(pts, trace);\n }\n\n if(hasNegativeSide) {\n pts = new Array(len);\n for(k = 0, i = len - 1; k < len; k++, i--) {\n pt = pts[k] = {};\n pt[t.posLetter] = posCenter - (density[i].v / scale);\n pt[t.valLetter] = valAxis.c2l(density[i].t, true);\n }\n pathNeg = makePath(pts, trace);\n }\n\n if(hasBothSides) {\n path = pathPos + 'L' + pathNeg.substr(1) + 'Z';\n } else {\n var startPt = [posCenterPx, valAxis.c2p(density[0].t)];\n var endPt = [posCenterPx, valAxis.c2p(density[len - 1].t)];\n\n if(trace.orientation === 'h') {\n startPt.reverse();\n endPt.reverse();\n }\n\n if(hasPositiveSide) {\n path = 'M' + startPt + 'L' + pathPos.substr(1) + 'L' + endPt;\n } else {\n path = 'M' + endPt + 'L' + pathNeg.substr(1) + 'L' + startPt;\n }\n }\n pathSel.attr('d', path);\n\n // save a few things used in getPositionOnKdePath, getKdeValue\n // on hover and for meanline draw block below\n d.posCenterPx = posCenterPx;\n d.posDensityScale = scale * bdPos;\n d.path = pathSel.node();\n d.pathLength = d.path.getTotalLength() / (hasBothSides ? 2 : 1);\n });\n\n var boxAttrs = trace.box;\n var boxWidth = boxAttrs.width;\n var boxLineWidth = (boxAttrs.line || {}).width;\n var bdPosScaled;\n var bPosPxOffset;\n\n if(hasBothSides) {\n bdPosScaled = bdPos * boxWidth;\n bPosPxOffset = 0;\n } else if(hasPositiveSide) {\n bdPosScaled = [0, bdPos * boxWidth / 2];\n bPosPxOffset = boxLineWidth * {x: 1, y: -1}[t.posLetter];\n } else {\n bdPosScaled = [bdPos * boxWidth / 2, 0];\n bPosPxOffset = boxLineWidth * {x: -1, y: 1}[t.posLetter];\n }\n\n // inner box\n boxPlot.plotBoxAndWhiskers(plotGroup, {pos: posAxis, val: valAxis}, trace, {\n bPos: bPos,\n bdPos: bdPosScaled,\n bPosPxOffset: bPosPxOffset\n });\n\n // meanline insider box\n boxPlot.plotBoxMean(plotGroup, {pos: posAxis, val: valAxis}, trace, {\n bPos: bPos,\n bdPos: bdPosScaled,\n bPosPxOffset: bPosPxOffset\n });\n\n var fn;\n if(!trace.box.visible && trace.meanline.visible) {\n fn = Lib.identity;\n }\n\n // N.B. use different class name than boxPlot.plotBoxMean,\n // to avoid selectAll conflict\n var meanPaths = plotGroup.selectAll('path.meanline').data(fn || []);\n meanPaths.enter().append('path')\n .attr('class', 'meanline')\n .style('fill', 'none')\n .style('vector-effect', isStatic ? 'none' : 'non-scaling-stroke');\n meanPaths.exit().remove();\n meanPaths.each(function(d) {\n var v = valAxis.c2p(d.mean, true);\n var p = helpers.getPositionOnKdePath(d, trace, v);\n\n d3.select(this).attr('d',\n trace.orientation === 'h' ?\n 'M' + v + ',' + p[0] + 'V' + p[1] :\n 'M' + p[0] + ',' + v + 'H' + p[1]\n );\n });\n\n boxPlot.plotPoints(plotGroup, {x: xa, y: ya}, trace, t);\n });\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Color = require('../../components/color');\nvar stylePoints = require('../scatter/style').stylePoints;\n\nmodule.exports = function style(gd) {\n var s = d3.select(gd).selectAll('g.trace.violins');\n\n s.style('opacity', function(d) { return d[0].trace.opacity; });\n\n s.each(function(d) {\n var trace = d[0].trace;\n var sel = d3.select(this);\n var box = trace.box || {};\n var boxLine = box.line || {};\n var meanline = trace.meanline || {};\n var meanLineWidth = meanline.width;\n\n sel.selectAll('path.violin')\n .style('stroke-width', trace.line.width + 'px')\n .call(Color.stroke, trace.line.color)\n .call(Color.fill, trace.fillcolor);\n\n sel.selectAll('path.box')\n .style('stroke-width', boxLine.width + 'px')\n .call(Color.stroke, boxLine.color)\n .call(Color.fill, box.fillcolor);\n\n var meanLineStyle = {\n 'stroke-width': meanLineWidth + 'px',\n 'stroke-dasharray': (2 * meanLineWidth) + 'px,' + meanLineWidth + 'px'\n };\n\n sel.selectAll('path.mean')\n .style(meanLineStyle)\n .call(Color.stroke, meanline.color);\n\n sel.selectAll('path.meanline')\n .style(meanLineStyle)\n .call(Color.stroke, meanline.color);\n\n stylePoints(sel, trace, gd);\n });\n};\n","'use strict';\n\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar isosurfaceAttrs = require('../isosurface/attributes');\nvar surfaceAttrs = require('../surface/attributes');\nvar baseAttrs = require('../../plots/attributes');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\n\nvar attrs = module.exports = overrideAll(extendFlat({\n x: isosurfaceAttrs.x,\n y: isosurfaceAttrs.y,\n z: isosurfaceAttrs.z,\n value: isosurfaceAttrs.value,\n isomin: isosurfaceAttrs.isomin,\n isomax: isosurfaceAttrs.isomax,\n surface: isosurfaceAttrs.surface,\n spaceframe: {\n show: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Displays/hides tetrahedron shapes between minimum and',\n 'maximum iso-values. Often useful when either caps or',\n 'surfaces are disabled or filled with values less than 1.'\n ].join(' ')\n },\n fill: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n description: [\n 'Sets the fill ratio of the `spaceframe` elements. The default fill value',\n 'is 1 meaning that they are entirely shaded. Applying a `fill` ratio less',\n 'than one would allow the creation of openings parallel to the edges.'\n ].join(' ')\n }\n },\n\n slices: isosurfaceAttrs.slices,\n caps: isosurfaceAttrs.caps,\n text: isosurfaceAttrs.text,\n hovertext: isosurfaceAttrs.hovertext,\n xhoverformat: isosurfaceAttrs.xhoverformat,\n yhoverformat: isosurfaceAttrs.yhoverformat,\n zhoverformat: isosurfaceAttrs.zhoverformat,\n valuehoverformat: isosurfaceAttrs.valuehoverformat,\n hovertemplate: isosurfaceAttrs.hovertemplate\n},\n\ncolorScaleAttrs('', {\n colorAttr: '`value`',\n showScaleDflt: true,\n editTypeOverride: 'calc'\n}), {\n\n colorbar: isosurfaceAttrs.colorbar,\n opacity: isosurfaceAttrs.opacity,\n opacityscale: surfaceAttrs.opacityscale,\n\n lightposition: isosurfaceAttrs.lightposition,\n lighting: isosurfaceAttrs.lighting,\n flatshading: isosurfaceAttrs.flatshading,\n contour: isosurfaceAttrs.contour,\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo),\n showlegend: extendFlat({}, baseAttrs.showlegend, {dflt: false})\n}), 'calc', 'nested');\n\nattrs.x.editType = attrs.y.editType = attrs.z.editType = attrs.value.editType = 'calc+clearAxisTypes';\nattrs.transforms = undefined;\n","'use strict';\n\nvar createMesh = require('../../../stackgl_modules').gl_mesh3d;\n\nvar parseColorScale = require('../../lib/gl_format_color').parseColorScale;\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar str2RgbaArray = require('../../lib/str2rgbarray');\nvar extractOpts = require('../../components/colorscale').extractOpts;\nvar zip3 = require('../../plots/gl3d/zip3');\n\nvar findNearestOnAxis = require('../isosurface/convert').findNearestOnAxis;\nvar generateIsoMeshes = require('../isosurface/convert').generateIsoMeshes;\n\nfunction VolumeTrace(scene, mesh, uid) {\n this.scene = scene;\n this.uid = uid;\n this.mesh = mesh;\n this.name = '';\n this.data = null;\n this.showContour = false;\n}\n\nvar proto = VolumeTrace.prototype;\n\nproto.handlePick = function(selection) {\n if(selection.object === this.mesh) {\n var rawId = selection.data.index;\n\n var x = this.data._meshX[rawId];\n var y = this.data._meshY[rawId];\n var z = this.data._meshZ[rawId];\n\n var height = this.data._Ys.length;\n var depth = this.data._Zs.length;\n\n var i = findNearestOnAxis(x, this.data._Xs).id;\n var j = findNearestOnAxis(y, this.data._Ys).id;\n var k = findNearestOnAxis(z, this.data._Zs).id;\n\n var selectIndex = selection.index = k + depth * j + depth * height * i;\n\n selection.traceCoordinate = [\n this.data._meshX[selectIndex],\n this.data._meshY[selectIndex],\n this.data._meshZ[selectIndex],\n this.data._value[selectIndex]\n ];\n\n var text = this.data.hovertext || this.data.text;\n if(isArrayOrTypedArray(text) && text[selectIndex] !== undefined) {\n selection.textLabel = text[selectIndex];\n } else if(text) {\n selection.textLabel = text;\n }\n\n return true;\n }\n};\n\nproto.update = function(data) {\n var scene = this.scene;\n var layout = scene.fullSceneLayout;\n\n this.data = generateIsoMeshes(data);\n\n // Unpack position data\n function toDataCoords(axis, coord, scale, calendar) {\n return coord.map(function(x) {\n return axis.d2l(x, 0, calendar) * scale;\n });\n }\n\n var positions = zip3(\n toDataCoords(layout.xaxis, data._meshX, scene.dataScale[0], data.xcalendar),\n toDataCoords(layout.yaxis, data._meshY, scene.dataScale[1], data.ycalendar),\n toDataCoords(layout.zaxis, data._meshZ, scene.dataScale[2], data.zcalendar));\n\n var cells = zip3(data._meshI, data._meshJ, data._meshK);\n\n var config = {\n positions: positions,\n cells: cells,\n lightPosition: [data.lightposition.x, data.lightposition.y, data.lightposition.z],\n ambient: data.lighting.ambient,\n diffuse: data.lighting.diffuse,\n specular: data.lighting.specular,\n roughness: data.lighting.roughness,\n fresnel: data.lighting.fresnel,\n vertexNormalsEpsilon: data.lighting.vertexnormalsepsilon,\n faceNormalsEpsilon: data.lighting.facenormalsepsilon,\n opacity: data.opacity,\n opacityscale: data.opacityscale,\n contourEnable: data.contour.show,\n contourColor: str2RgbaArray(data.contour.color).slice(0, 3),\n contourWidth: data.contour.width,\n useFacetNormals: data.flatshading\n };\n\n var cOpts = extractOpts(data);\n config.vertexIntensity = data._meshIntensity;\n config.vertexIntensityBounds = [cOpts.min, cOpts.max];\n config.colormap = parseColorScale(data);\n\n // Update mesh\n this.mesh.update(config);\n};\n\nproto.dispose = function() {\n this.scene.glplot.remove(this.mesh);\n this.mesh.dispose();\n};\n\nfunction createVolumeTrace(scene, data) {\n var gl = scene.glplot.gl;\n var mesh = createMesh({gl: gl});\n var result = new VolumeTrace(scene, mesh, data.uid);\n\n mesh._trace = result;\n result.update(data);\n scene.glplot.add(mesh);\n return result;\n}\n\nmodule.exports = createVolumeTrace;\n","'use strict';\n\nvar Lib = require('../../lib');\nvar attributes = require('./attributes');\nvar supplyIsoDefaults = require('../isosurface/defaults').supplyIsoDefaults;\nvar opacityscaleDefaults = require('../surface/defaults').opacityscaleDefaults;\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n supplyIsoDefaults(traceIn, traceOut, defaultColor, layout, coerce);\n\n opacityscaleDefaults(traceIn, traceOut, layout, coerce);\n};\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n calc: require('../isosurface/calc'),\n colorbar: {\n min: 'cmin',\n max: 'cmax'\n },\n plot: require('./convert'),\n\n moduleType: 'trace',\n name: 'volume',\n basePlotModule: require('../../plots/gl3d'),\n categories: ['gl3d', 'showLegend'],\n meta: {\n description: [\n 'Draws volume trace between iso-min and iso-max values with coordinates given by',\n 'four 1-dimensional arrays containing the `value`, `x`, `y` and `z` of every vertex',\n 'of a uniform or non-uniform 3-D grid. Horizontal or vertical slices, caps as well as',\n 'spaceframe between iso-min and iso-max values could also be drawn using this trace.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar barAttrs = require('../bar/attributes');\nvar lineAttrs = require('../scatter/attributes').line;\nvar baseAttrs = require('../../plots/attributes');\nvar axisHoverFormat = require('../../plots/cartesian/axis_format_attributes').axisHoverFormat;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar constants = require('./constants');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar Color = require('../../components/color');\n\nfunction directionAttrs(dirTxt) {\n return {\n marker: {\n color: extendFlat({}, barAttrs.marker.color, {\n arrayOk: false,\n editType: 'style',\n description: 'Sets the marker color of all ' + dirTxt + ' values.'\n }),\n line: {\n color: extendFlat({}, barAttrs.marker.line.color, {\n arrayOk: false,\n editType: 'style',\n description: 'Sets the line color of all ' + dirTxt + ' values.'\n }),\n width: extendFlat({}, barAttrs.marker.line.width, {\n arrayOk: false,\n editType: 'style',\n description: 'Sets the line width of all ' + dirTxt + ' values.'\n }),\n editType: 'style',\n },\n editType: 'style'\n },\n editType: 'style'\n };\n}\n\nmodule.exports = {\n measure: {\n valType: 'data_array',\n dflt: [],\n editType: 'calc',\n description: [\n 'An array containing types of values.',\n 'By default the values are considered as \\'relative\\'.',\n 'However; it is possible to use \\'total\\' to compute the sums.',\n 'Also \\'absolute\\' could be applied to reset the computed total',\n 'or to declare an initial value where needed.'\n ].join(' ')\n },\n\n base: {\n valType: 'number',\n dflt: null,\n arrayOk: false,\n editType: 'calc',\n description: [\n 'Sets where the bar base is drawn (in position axis units).'\n ].join(' ')\n },\n\n x: barAttrs.x,\n x0: barAttrs.x0,\n dx: barAttrs.dx,\n y: barAttrs.y,\n y0: barAttrs.y0,\n dy: barAttrs.dy,\n\n xperiod: barAttrs.xperiod,\n yperiod: barAttrs.yperiod,\n xperiod0: barAttrs.xperiod0,\n yperiod0: barAttrs.yperiod0,\n xperiodalignment: barAttrs.xperiodalignment,\n yperiodalignment: barAttrs.yperiodalignment,\n xhoverformat: axisHoverFormat('x'),\n yhoverformat: axisHoverFormat('y'),\n\n hovertext: barAttrs.hovertext,\n hovertemplate: hovertemplateAttrs({}, {\n keys: constants.eventDataKeys\n }),\n\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['name', 'x', 'y', 'text', 'initial', 'delta', 'final']\n }),\n\n textinfo: {\n valType: 'flaglist',\n flags: ['label', 'text', 'initial', 'delta', 'final'],\n extras: ['none'],\n editType: 'plot',\n arrayOk: false,\n description: [\n 'Determines which trace information appear on the graph.',\n 'In the case of having multiple waterfalls, totals',\n 'are computed separately (per trace).'\n ].join(' ')\n },\n // TODO: incorporate `label` and `value` in the eventData\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: constants.eventDataKeys.concat(['label'])\n }),\n text: barAttrs.text,\n textposition: barAttrs.textposition,\n insidetextanchor: barAttrs.insidetextanchor,\n textangle: barAttrs.textangle,\n textfont: barAttrs.textfont,\n insidetextfont: barAttrs.insidetextfont,\n outsidetextfont: barAttrs.outsidetextfont,\n constraintext: barAttrs.constraintext,\n\n cliponaxis: barAttrs.cliponaxis,\n orientation: barAttrs.orientation,\n\n offset: barAttrs.offset,\n width: barAttrs.width,\n\n increasing: directionAttrs('increasing'),\n decreasing: directionAttrs('decreasing'),\n totals: directionAttrs('intermediate sums and total'),\n\n connector: {\n line: {\n color: extendFlat({}, lineAttrs.color, {dflt: Color.defaultLine}),\n width: extendFlat({}, lineAttrs.width, {\n editType: 'plot', // i.e. to adjust bars is mode: 'between'. See https://github.com/plotly/plotly.js/issues/3787\n }),\n dash: lineAttrs.dash,\n editType: 'plot'\n },\n mode: {\n valType: 'enumerated',\n values: ['spanning', 'between'],\n dflt: 'between',\n editType: 'plot',\n description: [\n 'Sets the shape of connector lines.'\n ].join(' ')\n },\n visible: {\n valType: 'boolean',\n dflt: true,\n editType: 'plot',\n description: [\n 'Determines if connector lines are drawn. '\n ].join(' ')\n },\n editType: 'plot'\n },\n\n offsetgroup: barAttrs.offsetgroup,\n alignmentgroup: barAttrs.alignmentgroup,\n zorder: barAttrs.zorder\n};\n","'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\nvar alignPeriod = require('../../plots/cartesian/align_period');\nvar mergeArray = require('../../lib').mergeArray;\nvar calcSelection = require('../scatter/calc_selection');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nfunction isAbsolute(a) {\n return (a === 'a' || a === 'absolute');\n}\n\nfunction isTotal(a) {\n return (a === 't' || a === 'total');\n}\n\nmodule.exports = function calc(gd, trace) {\n var xa = Axes.getFromId(gd, trace.xaxis || 'x');\n var ya = Axes.getFromId(gd, trace.yaxis || 'y');\n var size, pos, origPos, pObj, hasPeriod, pLetter;\n\n if(trace.orientation === 'h') {\n size = xa.makeCalcdata(trace, 'x');\n origPos = ya.makeCalcdata(trace, 'y');\n pObj = alignPeriod(trace, ya, 'y', origPos);\n hasPeriod = !!trace.yperiodalignment;\n pLetter = 'y';\n } else {\n size = ya.makeCalcdata(trace, 'y');\n origPos = xa.makeCalcdata(trace, 'x');\n pObj = alignPeriod(trace, xa, 'x', origPos);\n hasPeriod = !!trace.xperiodalignment;\n pLetter = 'x';\n }\n pos = pObj.vals;\n\n // create the \"calculated data\" to plot\n var serieslen = Math.min(pos.length, size.length);\n var cd = new Array(serieslen);\n\n // set position and size (as well as for waterfall total size)\n var previousSum = 0;\n var newSize;\n // trace-wide flags\n var hasTotals = false;\n\n for(var i = 0; i < serieslen; i++) {\n var amount = size[i] || 0;\n\n var connectToNext = false;\n if(size[i] !== BADNUM || isTotal(trace.measure[i]) || isAbsolute(trace.measure[i])) {\n if(i + 1 < serieslen && (size[i + 1] !== BADNUM || isTotal(trace.measure[i + 1]) || isAbsolute(trace.measure[i + 1]))) {\n connectToNext = true;\n }\n }\n\n var cdi = cd[i] = {\n i: i,\n p: pos[i],\n s: amount,\n rawS: amount,\n cNext: connectToNext\n };\n\n if(isAbsolute(trace.measure[i])) {\n previousSum = cdi.s;\n\n cdi.isSum = true;\n cdi.dir = 'totals';\n cdi.s = previousSum;\n } else if(isTotal(trace.measure[i])) {\n cdi.isSum = true;\n cdi.dir = 'totals';\n cdi.s = previousSum;\n } else {\n // default: relative\n cdi.isSum = false;\n cdi.dir = cdi.rawS < 0 ? 'decreasing' : 'increasing';\n newSize = cdi.s;\n cdi.s = previousSum + newSize;\n previousSum += newSize;\n }\n\n if(cdi.dir === 'totals') {\n hasTotals = true;\n }\n\n if(hasPeriod) {\n cd[i].orig_p = origPos[i]; // used by hover\n cd[i][pLetter + 'End'] = pObj.ends[i];\n cd[i][pLetter + 'Start'] = pObj.starts[i];\n }\n\n if(trace.ids) {\n cdi.id = String(trace.ids[i]);\n }\n\n cdi.v = (trace.base || 0) + previousSum;\n }\n\n if(cd.length) cd[0].hasTotals = hasTotals;\n\n mergeArray(trace.text, cd, 'tx');\n mergeArray(trace.hovertext, cd, 'htx');\n calcSelection(cd, trace);\n\n return cd;\n};\n","'use strict';\n\nmodule.exports = {\n eventDataKeys: [\n 'initial',\n 'delta',\n 'final'\n ]\n};\n","'use strict';\n\nvar setGroupPositions = require('../bar/cross_trace_calc').setGroupPositions;\n\nmodule.exports = function crossTraceCalc(gd, plotinfo) {\n var fullLayout = gd._fullLayout;\n var fullData = gd._fullData;\n var calcdata = gd.calcdata;\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var waterfalls = [];\n var waterfallsVert = [];\n var waterfallsHorz = [];\n var cd, i;\n\n for(i = 0; i < fullData.length; i++) {\n var fullTrace = fullData[i];\n\n if(\n fullTrace.visible === true &&\n fullTrace.xaxis === xa._id &&\n fullTrace.yaxis === ya._id &&\n fullTrace.type === 'waterfall'\n ) {\n cd = calcdata[i];\n\n if(fullTrace.orientation === 'h') {\n waterfallsHorz.push(cd);\n } else {\n waterfallsVert.push(cd);\n }\n\n waterfalls.push(cd);\n }\n }\n\n var opts = {\n mode: fullLayout.waterfallmode,\n norm: fullLayout.waterfallnorm,\n gap: fullLayout.waterfallgap,\n groupgap: fullLayout.waterfallgroupgap\n };\n\n setGroupPositions(gd, xa, ya, waterfallsVert, opts);\n setGroupPositions(gd, ya, xa, waterfallsHorz, opts);\n\n for(i = 0; i < waterfalls.length; i++) {\n cd = waterfalls[i];\n\n for(var j = 0; j < cd.length; j++) {\n var di = cd[j];\n\n if(di.isSum === false) {\n di.s0 += (j === 0) ? 0 : cd[j - 1].s;\n }\n\n if(j + 1 < cd.length) {\n cd[j].nextP0 = cd[j + 1].p0;\n cd[j].nextS0 = cd[j + 1].s0;\n }\n }\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\n\nvar handleGroupingDefaults = require('../scatter/grouping_defaults');\nvar handleText = require('../bar/defaults').handleText;\nvar handleXYDefaults = require('../scatter/xy_defaults');\nvar handlePeriodDefaults = require('../scatter/period_defaults');\nvar attributes = require('./attributes');\nvar Color = require('../../components/color');\nvar delta = require('../../constants/delta.js');\n\nvar INCREASING_COLOR = delta.INCREASING.COLOR;\nvar DECREASING_COLOR = delta.DECREASING.COLOR;\nvar TOTALS_COLOR = '#4499FF';\n\nfunction handleDirection(coerce, direction, defaultColor) {\n coerce(direction + '.marker.color', defaultColor);\n coerce(direction + '.marker.line.color', Color.defaultLine);\n coerce(direction + '.marker.line.width');\n}\n\nfunction supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleXYDefaults(traceIn, traceOut, layout, coerce);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n handlePeriodDefaults(traceIn, traceOut, layout, coerce);\n coerce('xhoverformat');\n coerce('yhoverformat');\n\n coerce('measure');\n\n coerce('orientation', (traceOut.x && !traceOut.y) ? 'h' : 'v');\n coerce('base');\n coerce('offset');\n coerce('width');\n\n coerce('text');\n\n coerce('hovertext');\n coerce('hovertemplate');\n\n var textposition = coerce('textposition');\n handleText(traceIn, traceOut, layout, coerce, textposition, {\n moduleHasSelected: false,\n moduleHasUnselected: false,\n moduleHasConstrain: true,\n moduleHasCliponaxis: true,\n moduleHasTextangle: true,\n moduleHasInsideanchor: true\n });\n\n\n if(traceOut.textposition !== 'none') {\n coerce('texttemplate');\n if(!traceOut.texttemplate) coerce('textinfo');\n }\n\n handleDirection(coerce, 'increasing', INCREASING_COLOR);\n handleDirection(coerce, 'decreasing', DECREASING_COLOR);\n handleDirection(coerce, 'totals', TOTALS_COLOR);\n\n var connectorVisible = coerce('connector.visible');\n if(connectorVisible) {\n coerce('connector.mode');\n var connectorLineWidth = coerce('connector.line.width');\n if(connectorLineWidth) {\n coerce('connector.line.color');\n coerce('connector.line.dash');\n }\n }\n coerce('zorder');\n}\n\nfunction crossTraceDefaults(fullData, fullLayout) {\n var traceIn, traceOut;\n\n function coerce(attr) {\n return Lib.coerce(traceOut._input, traceOut, attributes, attr);\n }\n\n if(fullLayout.waterfallmode === 'group') {\n for(var i = 0; i < fullData.length; i++) {\n traceOut = fullData[i];\n traceIn = traceOut._input;\n\n handleGroupingDefaults(traceIn, traceOut, fullLayout, coerce);\n }\n }\n}\n\nmodule.exports = {\n supplyDefaults: supplyDefaults,\n crossTraceDefaults: crossTraceDefaults\n};\n","'use strict';\n\nmodule.exports = function eventData(out, pt /* , trace, cd, pointNumber */) {\n // standard cartesian event data\n out.x = 'xVal' in pt ? pt.xVal : pt.x;\n out.y = 'yVal' in pt ? pt.yVal : pt.y;\n\n // for funnel\n if('initial' in pt) out.initial = pt.initial;\n if('delta' in pt) out.delta = pt.delta;\n if('final' in pt) out.final = pt.final;\n\n if(pt.xa) out.xaxis = pt.xa;\n if(pt.ya) out.yaxis = pt.ya;\n\n return out;\n};\n","'use strict';\n\nvar hoverLabelText = require('../../plots/cartesian/axes').hoverLabelText;\nvar opacity = require('../../components/color').opacity;\nvar hoverOnBars = require('../bar/hover').hoverOnBars;\nvar delta = require('../../constants/delta.js');\n\nvar DIRSYMBOL = {\n increasing: delta.INCREASING.SYMBOL,\n decreasing: delta.DECREASING.SYMBOL\n};\n\nmodule.exports = function hoverPoints(pointData, xval, yval, hovermode, opts) {\n var point = hoverOnBars(pointData, xval, yval, hovermode, opts);\n if(!point) return;\n\n var cd = point.cd;\n var trace = cd[0].trace;\n var isHorizontal = (trace.orientation === 'h');\n\n var vLetter = isHorizontal ? 'x' : 'y';\n var vAxis = isHorizontal ? pointData.xa : pointData.ya;\n\n function formatNumber(a) {\n return hoverLabelText(vAxis, a, trace[vLetter + 'hoverformat']);\n }\n\n // the closest data point\n var index = point.index;\n var di = cd[index];\n\n var size = (di.isSum) ? di.b + di.s : di.rawS;\n\n point.initial = di.b + di.s - size;\n point.delta = size;\n point.final = point.initial + point.delta;\n\n var v = formatNumber(Math.abs(point.delta));\n point.deltaLabel = size < 0 ? '(' + v + ')' : v;\n point.finalLabel = formatNumber(point.final);\n point.initialLabel = formatNumber(point.initial);\n\n var hoverinfo = di.hi || trace.hoverinfo;\n var text = [];\n if(hoverinfo && hoverinfo !== 'none' && hoverinfo !== 'skip') {\n var isAll = (hoverinfo === 'all');\n var parts = hoverinfo.split('+');\n\n var hasFlag = function(flag) { return isAll || parts.indexOf(flag) !== -1; };\n\n if(!di.isSum) {\n if(hasFlag('final') &&\n (isHorizontal ? !hasFlag('x') : !hasFlag('y')) // don't display redundant info.\n ) {\n text.push(point.finalLabel);\n }\n if(hasFlag('delta')) {\n if(size < 0) {\n text.push(point.deltaLabel + ' ' + DIRSYMBOL.decreasing);\n } else {\n text.push(point.deltaLabel + ' ' + DIRSYMBOL.increasing);\n }\n }\n if(hasFlag('initial')) {\n text.push('Initial: ' + point.initialLabel);\n }\n }\n }\n\n if(text.length) point.extraText = text.join('
');\n\n point.color = getTraceColor(trace, di);\n\n return [point];\n};\n\nfunction getTraceColor(trace, di) {\n var cont = trace[di.dir].marker;\n var mc = cont.color;\n var mlc = cont.line.color;\n var mlw = cont.line.width;\n if(opacity(mc)) return mc;\n else if(opacity(mlc) && mlw) return mlc;\n}\n","'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n layoutAttributes: require('./layout_attributes'),\n supplyDefaults: require('./defaults').supplyDefaults,\n crossTraceDefaults: require('./defaults').crossTraceDefaults,\n supplyLayoutDefaults: require('./layout_defaults'),\n calc: require('./calc'),\n crossTraceCalc: require('./cross_trace_calc'),\n plot: require('./plot'),\n style: require('./style').style,\n hoverPoints: require('./hover'),\n eventData: require('./event_data'),\n\n selectPoints: require('../bar/select'),\n\n moduleType: 'trace',\n name: 'waterfall',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['bar-like', 'cartesian', 'svg', 'oriented', 'showLegend', 'zoomScale'],\n meta: {\n description: [\n 'Draws waterfall trace which is useful graph to displays the',\n 'contribution of various elements (either positive or negative)',\n 'in a bar chart. The data visualized by the span of the bars is',\n 'set in `y` if `orientation` is set to *v* (the default) and the',\n 'labels are set in `x`.',\n 'By setting `orientation` to *h*, the roles are interchanged.'\n ].join(' ')\n }\n};\n","'use strict';\n\nmodule.exports = {\n waterfallmode: {\n valType: 'enumerated',\n values: ['group', 'overlay'],\n dflt: 'group',\n editType: 'calc',\n description: [\n 'Determines how bars at the same location coordinate',\n 'are displayed on the graph.',\n 'With *group*, the bars are plotted next to one another',\n 'centered around the shared location.',\n 'With *overlay*, the bars are plotted over one another,',\n 'you might need to reduce *opacity* to see multiple bars.'\n ].join(' ')\n },\n waterfallgap: {\n valType: 'number',\n min: 0,\n max: 1,\n editType: 'calc',\n description: [\n 'Sets the gap (in plot fraction) between bars of',\n 'adjacent location coordinates.'\n ].join(' ')\n },\n waterfallgroupgap: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0,\n editType: 'calc',\n description: [\n 'Sets the gap (in plot fraction) between bars of',\n 'the same location coordinate.'\n ].join(' ')\n }\n};\n","'use strict';\n\nvar Lib = require('../../lib');\nvar layoutAttributes = require('./layout_attributes');\n\nmodule.exports = function(layoutIn, layoutOut, fullData) {\n var hasTraceType = false;\n\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n\n for(var i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n\n if(trace.visible && trace.type === 'waterfall') {\n hasTraceType = true;\n break;\n }\n }\n\n if(hasTraceType) {\n coerce('waterfallmode');\n coerce('waterfallgap', 0.2);\n coerce('waterfallgroupgap');\n }\n};\n","'use strict';\n\nvar d3 = require('@plotly/d3');\nvar Lib = require('../../lib');\nvar Drawing = require('../../components/drawing');\nvar BADNUM = require('../../constants/numerical').BADNUM;\nvar barPlot = require('../bar/plot');\nvar clearMinTextSize = require('../bar/uniform_text').clearMinTextSize;\n\nmodule.exports = function plot(gd, plotinfo, cdModule, traceLayer) {\n var fullLayout = gd._fullLayout;\n\n clearMinTextSize('waterfall', fullLayout);\n\n barPlot.plot(gd, plotinfo, cdModule, traceLayer, {\n mode: fullLayout.waterfallmode,\n norm: fullLayout.waterfallmode,\n gap: fullLayout.waterfallgap,\n groupgap: fullLayout.waterfallgroupgap\n });\n\n plotConnectors(gd, plotinfo, cdModule, traceLayer);\n};\n\nfunction plotConnectors(gd, plotinfo, cdModule, traceLayer) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n Lib.makeTraceGroups(traceLayer, cdModule, 'trace bars').each(function(cd) {\n var plotGroup = d3.select(this);\n var trace = cd[0].trace;\n\n var group = Lib.ensureSingle(plotGroup, 'g', 'lines');\n\n if(!trace.connector || !trace.connector.visible) {\n group.remove();\n return;\n }\n\n var isHorizontal = (trace.orientation === 'h');\n var mode = trace.connector.mode;\n\n var connectors = group.selectAll('g.line').data(Lib.identity);\n\n connectors.enter().append('g')\n .classed('line', true);\n\n connectors.exit().remove();\n\n var len = connectors.size();\n\n connectors.each(function(di, i) {\n // don't draw lines between nulls\n if(i !== len - 1 && !di.cNext) return;\n\n var xy = getXY(di, xa, ya, isHorizontal);\n var x = xy[0];\n var y = xy[1];\n\n var shape = '';\n\n if(\n x[0] !== BADNUM && y[0] !== BADNUM &&\n x[1] !== BADNUM && y[1] !== BADNUM\n ) {\n if(mode === 'spanning') {\n if(!di.isSum && i > 0) {\n if(isHorizontal) {\n shape += 'M' + x[0] + ',' + y[1] + 'V' + y[0];\n } else {\n shape += 'M' + x[1] + ',' + y[0] + 'H' + x[0];\n }\n }\n }\n\n if(mode !== 'between') {\n if(di.isSum || i < len - 1) {\n if(isHorizontal) {\n shape += 'M' + x[1] + ',' + y[0] + 'V' + y[1];\n } else {\n shape += 'M' + x[0] + ',' + y[1] + 'H' + x[1];\n }\n }\n }\n\n if(x[2] !== BADNUM && y[2] !== BADNUM) {\n if(isHorizontal) {\n shape += 'M' + x[1] + ',' + y[1] + 'V' + y[2];\n } else {\n shape += 'M' + x[1] + ',' + y[1] + 'H' + x[2];\n }\n }\n }\n\n if(shape === '') shape = 'M0,0Z';\n\n Lib.ensureSingle(d3.select(this), 'path')\n .attr('d', shape)\n .call(Drawing.setClipUrl, plotinfo.layerClipId, gd);\n });\n });\n}\n\nfunction getXY(di, xa, ya, isHorizontal) {\n var s = [];\n var p = [];\n\n var sAxis = isHorizontal ? xa : ya;\n var pAxis = isHorizontal ? ya : xa;\n\n s[0] = sAxis.c2p(di.s0, true);\n p[0] = pAxis.c2p(di.p0, true);\n\n s[1] = sAxis.c2p(di.s1, true);\n p[1] = pAxis.c2p(di.p1, true);\n\n s[2] = sAxis.c2p(di.nextS0, true);\n p[2] = pAxis.c2p(di.nextP0, true);\n\n return isHorizontal ? [s, p] : [p, s];\n}\n","'use strict';\n\nvar d3 = require('@plotly/d3');\n\nvar Drawing = require('../../components/drawing');\nvar Color = require('../../components/color');\nvar DESELECTDIM = require('../../constants/interactions').DESELECTDIM;\nvar barStyle = require('../bar/style');\nvar resizeText = require('../bar/uniform_text').resizeText;\nvar styleTextPoints = barStyle.styleTextPoints;\n\nfunction style(gd, cd, sel) {\n var s = sel ? sel : d3.select(gd).selectAll('g[class^=\"waterfalllayer\"]').selectAll('g.trace');\n resizeText(gd, s, 'waterfall');\n\n s.style('opacity', function(d) { return d[0].trace.opacity; });\n\n s.each(function(d) {\n var gTrace = d3.select(this);\n var trace = d[0].trace;\n\n gTrace.selectAll('.point > path').each(function(di) {\n if(!di.isBlank) {\n var cont = trace[di.dir].marker;\n\n d3.select(this)\n .call(Color.fill, cont.color)\n .call(Color.stroke, cont.line.color)\n .call(Drawing.dashLine, cont.line.dash, cont.line.width)\n .style('opacity', trace.selectedpoints && !di.selected ? DESELECTDIM : 1);\n }\n });\n\n styleTextPoints(gTrace, trace, gd);\n\n gTrace.selectAll('.lines').each(function() {\n var cont = trace.connector.line;\n\n Drawing.lineGroupStyle(\n d3.select(this).selectAll('path'),\n cont.width,\n cont.color,\n cont.dash\n );\n });\n });\n}\n\nmodule.exports = {\n style: style\n};\n","'use strict';\n\nvar Axes = require('../plots/cartesian/axes');\nvar Lib = require('../lib');\nvar PlotSchema = require('../plot_api/plot_schema');\nvar pointsAccessorFunction = require('./helpers').pointsAccessorFunction;\nvar BADNUM = require('../constants/numerical').BADNUM;\n\nexports.moduleType = 'transform';\n\nexports.name = 'aggregate';\n\nvar attrs = exports.attributes = {\n enabled: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether this aggregate transform is enabled or disabled.'\n ].join(' ')\n },\n groups: {\n // TODO: groupby should support string or array grouping this way too\n // currently groupby only allows a grouping array\n valType: 'string',\n strict: true,\n noBlank: true,\n arrayOk: true,\n dflt: 'x',\n editType: 'calc',\n description: [\n 'Sets the grouping target to which the aggregation is applied.',\n 'Data points with matching group values will be coalesced into',\n 'one point, using the supplied aggregation functions to reduce data',\n 'in other data arrays.',\n 'If a string, `groups` is assumed to be a reference to a data array',\n 'in the parent trace object.',\n 'To aggregate by nested variables, use *.* to access them.',\n 'For example, set `groups` to *marker.color* to aggregate',\n 'about the marker color array.',\n 'If an array, `groups` is itself the data array by which we aggregate.'\n ].join(' ')\n },\n aggregations: {\n _isLinkedToArray: 'aggregation',\n target: {\n valType: 'string',\n editType: 'calc',\n description: [\n 'A reference to the data array in the parent trace to aggregate.',\n 'To aggregate by nested variables, use *.* to access them.',\n 'For example, set `groups` to *marker.color* to aggregate',\n 'over the marker color array.',\n 'The referenced array must already exist, unless `func` is *count*,',\n 'and each array may only be referenced once.'\n ].join(' ')\n },\n func: {\n valType: 'enumerated',\n values: ['count', 'sum', 'avg', 'median', 'mode', 'rms', 'stddev', 'min', 'max', 'first', 'last', 'change', 'range'],\n dflt: 'first',\n editType: 'calc',\n description: [\n 'Sets the aggregation function.',\n 'All values from the linked `target`, corresponding to the same value',\n 'in the `groups` array, are collected and reduced by this function.',\n '*count* is simply the number of values in the `groups` array, so does',\n 'not even require the linked array to exist. *first* (*last*) is just',\n 'the first (last) linked value.',\n 'Invalid values are ignored, so for example in *avg* they do not',\n 'contribute to either the numerator or the denominator.',\n 'Any data type (numeric, date, category) may be aggregated with any',\n 'function, even though in certain cases it is unlikely to make sense,',\n 'for example a sum of dates or average of categories.',\n '*median* will return the average of the two central values if there is',\n 'an even count. *mode* will return the first value to reach the maximum',\n 'count, in case of a tie.',\n '*change* will return the difference between the first and last linked values.',\n '*range* will return the difference between the min and max linked values.'\n ].join(' ')\n },\n funcmode: {\n valType: 'enumerated',\n values: ['sample', 'population'],\n dflt: 'sample',\n editType: 'calc',\n description: [\n '*stddev* supports two formula variants: *sample* (normalize by N-1)',\n 'and *population* (normalize by N).'\n ].join(' ')\n },\n enabled: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether this aggregation function is enabled or disabled.'\n ].join(' ')\n },\n editType: 'calc'\n },\n editType: 'calc'\n};\n\nvar aggAttrs = attrs.aggregations;\n\n/**\n * Supply transform attributes defaults\n *\n * @param {object} transformIn\n * object linked to trace.transforms[i] with 'func' set to exports.name\n * @param {object} traceOut\n * the _fullData trace this transform applies to\n * @param {object} layout\n * the plot's (not-so-full) layout\n * @param {object} traceIn\n * the input data trace this transform applies to\n *\n * @return {object} transformOut\n * copy of transformIn that contains attribute defaults\n */\nexports.supplyDefaults = function(transformIn, traceOut) {\n var transformOut = {};\n var i;\n\n function coerce(attr, dflt) {\n return Lib.coerce(transformIn, transformOut, attrs, attr, dflt);\n }\n\n var enabled = coerce('enabled');\n\n if(!enabled) return transformOut;\n\n /*\n * Normally _arrayAttrs is calculated during doCalc, but that comes later.\n * Anyway this can change due to *count* aggregations (see below) so it's not\n * necessarily the same set.\n *\n * For performance we turn it into an object of truthy values\n * we'll use 1 for arrays we haven't aggregated yet, 0 for finished arrays,\n * as distinct from undefined which means this array isn't present in the input\n * missing arrays can still be aggregate outputs for *count* aggregations.\n */\n var arrayAttrArray = PlotSchema.findArrayAttributes(traceOut);\n var arrayAttrs = {};\n for(i = 0; i < arrayAttrArray.length; i++) arrayAttrs[arrayAttrArray[i]] = 1;\n\n var groups = coerce('groups');\n\n if(!Array.isArray(groups)) {\n if(!arrayAttrs[groups]) {\n transformOut.enabled = false;\n return transformOut;\n }\n arrayAttrs[groups] = 0;\n }\n\n var aggregationsIn = transformIn.aggregations || [];\n var aggregationsOut = transformOut.aggregations = new Array(aggregationsIn.length);\n var aggregationOut;\n\n function coercei(attr, dflt) {\n return Lib.coerce(aggregationsIn[i], aggregationOut, aggAttrs, attr, dflt);\n }\n\n for(i = 0; i < aggregationsIn.length; i++) {\n aggregationOut = {_index: i};\n var target = coercei('target');\n var func = coercei('func');\n var enabledi = coercei('enabled');\n\n // add this aggregation to the output only if it's the first instance\n // of a valid target attribute - or an unused target attribute with \"count\"\n if(enabledi && target && (arrayAttrs[target] || (func === 'count' && arrayAttrs[target] === undefined))) {\n if(func === 'stddev') coercei('funcmode');\n\n arrayAttrs[target] = 0;\n aggregationsOut[i] = aggregationOut;\n } else aggregationsOut[i] = {enabled: false, _index: i};\n }\n\n // any array attributes we haven't yet covered, fill them with the default aggregation\n for(i = 0; i < arrayAttrArray.length; i++) {\n if(arrayAttrs[arrayAttrArray[i]]) {\n aggregationsOut.push({\n target: arrayAttrArray[i],\n func: aggAttrs.func.dflt,\n enabled: true,\n _index: -1\n });\n }\n }\n\n return transformOut;\n};\n\n\nexports.calcTransform = function(gd, trace, opts) {\n if(!opts.enabled) return;\n\n var groups = opts.groups;\n\n var groupArray = Lib.getTargetArray(trace, {target: groups});\n if(!groupArray) return;\n\n var i, vi, groupIndex, newGrouping;\n\n var groupIndices = {};\n var indexToPoints = {};\n var groupings = [];\n\n var originalPointsAccessor = pointsAccessorFunction(trace.transforms, opts);\n\n var len = groupArray.length;\n if(trace._length) len = Math.min(len, trace._length);\n\n for(i = 0; i < len; i++) {\n vi = groupArray[i];\n groupIndex = groupIndices[vi];\n if(groupIndex === undefined) {\n groupIndices[vi] = groupings.length;\n newGrouping = [i];\n groupings.push(newGrouping);\n indexToPoints[groupIndices[vi]] = originalPointsAccessor(i);\n } else {\n groupings[groupIndex].push(i);\n indexToPoints[groupIndices[vi]] = (indexToPoints[groupIndices[vi]] || []).concat(originalPointsAccessor(i));\n }\n }\n\n opts._indexToPoints = indexToPoints;\n\n var aggregations = opts.aggregations;\n\n for(i = 0; i < aggregations.length; i++) {\n aggregateOneArray(gd, trace, groupings, aggregations[i]);\n }\n\n if(typeof groups === 'string') {\n aggregateOneArray(gd, trace, groupings, {\n target: groups,\n func: 'first',\n enabled: true\n });\n }\n\n trace._length = groupings.length;\n};\n\nfunction aggregateOneArray(gd, trace, groupings, aggregation) {\n if(!aggregation.enabled) return;\n\n var attr = aggregation.target;\n var targetNP = Lib.nestedProperty(trace, attr);\n var arrayIn = targetNP.get();\n var conversions = Axes.getDataConversions(gd, trace, attr, arrayIn);\n var func = getAggregateFunction(aggregation, conversions);\n\n var arrayOut = new Array(groupings.length);\n for(var i = 0; i < groupings.length; i++) {\n arrayOut[i] = func(arrayIn, groupings[i]);\n }\n targetNP.set(arrayOut);\n\n if(aggregation.func === 'count') {\n // count does not depend on an input array, so it's likely not part of _arrayAttrs yet\n // but after this transform it most definitely *is* an array attribute.\n Lib.pushUnique(trace._arrayAttrs, attr);\n }\n}\n\nfunction getAggregateFunction(opts, conversions) {\n var func = opts.func;\n var d2c = conversions.d2c;\n var c2d = conversions.c2d;\n\n switch(func) {\n // count, first, and last don't depend on anything about the data\n // point back to pure functions for performance\n case 'count':\n return count;\n case 'first':\n return first;\n case 'last':\n return last;\n\n case 'sum':\n // This will produce output in all cases even though it's nonsensical\n // for date or category data.\n return function(array, indices) {\n var total = 0;\n for(var i = 0; i < indices.length; i++) {\n var vi = d2c(array[indices[i]]);\n if(vi !== BADNUM) total += vi;\n }\n return c2d(total);\n };\n\n case 'avg':\n // Generally meaningless for category data but it still does something.\n return function(array, indices) {\n var total = 0;\n var cnt = 0;\n for(var i = 0; i < indices.length; i++) {\n var vi = d2c(array[indices[i]]);\n if(vi !== BADNUM) {\n total += vi;\n cnt++;\n }\n }\n return cnt ? c2d(total / cnt) : BADNUM;\n };\n\n case 'min':\n return function(array, indices) {\n var out = Infinity;\n for(var i = 0; i < indices.length; i++) {\n var vi = d2c(array[indices[i]]);\n if(vi !== BADNUM) out = Math.min(out, vi);\n }\n return (out === Infinity) ? BADNUM : c2d(out);\n };\n\n case 'max':\n return function(array, indices) {\n var out = -Infinity;\n for(var i = 0; i < indices.length; i++) {\n var vi = d2c(array[indices[i]]);\n if(vi !== BADNUM) out = Math.max(out, vi);\n }\n return (out === -Infinity) ? BADNUM : c2d(out);\n };\n\n case 'range':\n return function(array, indices) {\n var min = Infinity;\n var max = -Infinity;\n for(var i = 0; i < indices.length; i++) {\n var vi = d2c(array[indices[i]]);\n if(vi !== BADNUM) {\n min = Math.min(min, vi);\n max = Math.max(max, vi);\n }\n }\n return (max === -Infinity || min === Infinity) ? BADNUM : c2d(max - min);\n };\n\n case 'change':\n return function(array, indices) {\n var first = d2c(array[indices[0]]);\n var last = d2c(array[indices[indices.length - 1]]);\n return (first === BADNUM || last === BADNUM) ? BADNUM : c2d(last - first);\n };\n\n case 'median':\n return function(array, indices) {\n var sortCalc = [];\n for(var i = 0; i < indices.length; i++) {\n var vi = d2c(array[indices[i]]);\n if(vi !== BADNUM) sortCalc.push(vi);\n }\n if(!sortCalc.length) return BADNUM;\n sortCalc.sort(Lib.sorterAsc);\n var mid = (sortCalc.length - 1) / 2;\n return c2d((sortCalc[Math.floor(mid)] + sortCalc[Math.ceil(mid)]) / 2);\n };\n\n case 'mode':\n return function(array, indices) {\n var counts = {};\n var maxCnt = 0;\n var out = BADNUM;\n for(var i = 0; i < indices.length; i++) {\n var vi = d2c(array[indices[i]]);\n if(vi !== BADNUM) {\n var counti = counts[vi] = (counts[vi] || 0) + 1;\n if(counti > maxCnt) {\n maxCnt = counti;\n out = vi;\n }\n }\n }\n return maxCnt ? c2d(out) : BADNUM;\n };\n\n case 'rms':\n return function(array, indices) {\n var total = 0;\n var cnt = 0;\n for(var i = 0; i < indices.length; i++) {\n var vi = d2c(array[indices[i]]);\n if(vi !== BADNUM) {\n total += vi * vi;\n cnt++;\n }\n }\n return cnt ? c2d(Math.sqrt(total / cnt)) : BADNUM;\n };\n\n case 'stddev':\n return function(array, indices) {\n // balance numerical stability with performance:\n // so that we call d2c once per element but don't need to\n // store them, reference all to the first element\n var total = 0;\n var total2 = 0;\n var cnt = 1;\n var v0 = BADNUM;\n var i;\n for(i = 0; i < indices.length && v0 === BADNUM; i++) {\n v0 = d2c(array[indices[i]]);\n }\n if(v0 === BADNUM) return BADNUM;\n\n for(; i < indices.length; i++) {\n var vi = d2c(array[indices[i]]);\n if(vi !== BADNUM) {\n var dv = vi - v0;\n total += dv;\n total2 += dv * dv;\n cnt++;\n }\n }\n\n // This is population std dev, if we want sample std dev\n // we would need (...) / (cnt - 1)\n // Also note there's no c2d here - that means for dates the result\n // is a number of milliseconds, and for categories it's a number\n // of category differences, which is not generically meaningful but\n // as in other cases we don't forbid it.\n var norm = (opts.funcmode === 'sample') ? (cnt - 1) : cnt;\n // this is debatable: should a count of 1 return sample stddev of\n // 0 or undefined?\n if(!norm) return 0;\n return Math.sqrt((total2 - (total * total / cnt)) / norm);\n };\n }\n}\n\nfunction count(array, indices) {\n return indices.length;\n}\n\nfunction first(array, indices) {\n return array[indices[0]];\n}\n\nfunction last(array, indices) {\n return array[indices[indices.length - 1]];\n}\n","'use strict';\n\nvar Lib = require('../lib');\nvar Registry = require('../registry');\nvar Axes = require('../plots/cartesian/axes');\nvar pointsAccessorFunction = require('./helpers').pointsAccessorFunction;\n\nvar filterOps = require('../constants/filter_ops');\nvar COMPARISON_OPS = filterOps.COMPARISON_OPS;\nvar INTERVAL_OPS = filterOps.INTERVAL_OPS;\nvar SET_OPS = filterOps.SET_OPS;\n\nexports.moduleType = 'transform';\n\nexports.name = 'filter';\n\nexports.attributes = {\n enabled: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether this filter transform is enabled or disabled.'\n ].join(' ')\n },\n target: {\n valType: 'string',\n strict: true,\n noBlank: true,\n arrayOk: true,\n dflt: 'x',\n editType: 'calc',\n description: [\n 'Sets the filter target by which the filter is applied.',\n\n 'If a string, `target` is assumed to be a reference to a data array',\n 'in the parent trace object.',\n 'To filter about nested variables, use *.* to access them.',\n 'For example, set `target` to *marker.color* to filter',\n 'about the marker color array.',\n\n 'If an array, `target` is then the data array by which the filter is applied.'\n ].join(' ')\n },\n operation: {\n valType: 'enumerated',\n values: []\n .concat(COMPARISON_OPS)\n .concat(INTERVAL_OPS)\n .concat(SET_OPS),\n dflt: '=',\n editType: 'calc',\n description: [\n 'Sets the filter operation.',\n\n '*=* keeps items equal to `value`',\n '*!=* keeps items not equal to `value`',\n\n '*<* keeps items less than `value`',\n '*<=* keeps items less than or equal to `value`',\n\n '*>* keeps items greater than `value`',\n '*>=* keeps items greater than or equal to `value`',\n\n '*[]* keeps items inside `value[0]` to `value[1]` including both bounds',\n '*()* keeps items inside `value[0]` to `value[1]` excluding both bounds',\n '*[)* keeps items inside `value[0]` to `value[1]` including `value[0]` but excluding `value[1]',\n '*(]* keeps items inside `value[0]` to `value[1]` excluding `value[0]` but including `value[1]',\n\n '*][* keeps items outside `value[0]` to `value[1]` and equal to both bounds',\n '*)(* keeps items outside `value[0]` to `value[1]`',\n '*](* keeps items outside `value[0]` to `value[1]` and equal to `value[0]`',\n '*)[* keeps items outside `value[0]` to `value[1]` and equal to `value[1]`',\n\n '*{}* keeps items present in a set of values',\n '*}{* keeps items not present in a set of values'\n ].join(' ')\n },\n value: {\n valType: 'any',\n dflt: 0,\n editType: 'calc',\n description: [\n 'Sets the value or values by which to filter.',\n\n 'Values are expected to be in the same type as the data linked',\n 'to `target`.',\n\n 'When `operation` is set to one of',\n 'the comparison values (' + COMPARISON_OPS + ')',\n '`value` is expected to be a number or a string.',\n\n 'When `operation` is set to one of the interval values',\n '(' + INTERVAL_OPS + ')',\n '`value` is expected to be 2-item array where the first item',\n 'is the lower bound and the second item is the upper bound.',\n\n 'When `operation`, is set to one of the set values',\n '(' + SET_OPS + ')',\n '`value` is expected to be an array with as many items as',\n 'the desired set elements.'\n ].join(' ')\n },\n preservegaps: {\n valType: 'boolean',\n dflt: false,\n editType: 'calc',\n description: [\n 'Determines whether or not gaps in data arrays produced by the filter operation',\n 'are preserved.',\n 'Setting this to *true* might be useful when plotting a line chart',\n 'with `connectgaps` set to *false*.'\n ].join(' ')\n },\n editType: 'calc'\n};\n\nexports.supplyDefaults = function(transformIn) {\n var transformOut = {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(transformIn, transformOut, exports.attributes, attr, dflt);\n }\n\n var enabled = coerce('enabled');\n\n if(enabled) {\n var target = coerce('target');\n\n if(Lib.isArrayOrTypedArray(target) && target.length === 0) {\n transformOut.enabled = false;\n return transformOut;\n }\n\n coerce('preservegaps');\n coerce('operation');\n coerce('value');\n\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleDefaults');\n handleCalendarDefaults(transformIn, transformOut, 'valuecalendar', null);\n handleCalendarDefaults(transformIn, transformOut, 'targetcalendar', null);\n }\n\n return transformOut;\n};\n\nexports.calcTransform = function(gd, trace, opts) {\n if(!opts.enabled) return;\n\n var targetArray = Lib.getTargetArray(trace, opts);\n if(!targetArray) return;\n\n var target = opts.target;\n\n var len = targetArray.length;\n if(trace._length) len = Math.min(len, trace._length);\n\n var targetCalendar = opts.targetcalendar;\n var arrayAttrs = trace._arrayAttrs;\n var preservegaps = opts.preservegaps;\n\n // even if you provide targetcalendar, if target is a string and there\n // is a calendar attribute matching target it will get used instead.\n if(typeof target === 'string') {\n var attrTargetCalendar = Lib.nestedProperty(trace, target + 'calendar').get();\n if(attrTargetCalendar) targetCalendar = attrTargetCalendar;\n }\n\n var d2c = Axes.getDataToCoordFunc(gd, trace, target, targetArray);\n var filterFunc = getFilterFunc(opts, d2c, targetCalendar);\n var originalArrays = {};\n var indexToPoints = {};\n var index = 0;\n\n function forAllAttrs(fn, index) {\n for(var j = 0; j < arrayAttrs.length; j++) {\n var np = Lib.nestedProperty(trace, arrayAttrs[j]);\n fn(np, index);\n }\n }\n\n var initFn;\n var fillFn;\n if(preservegaps) {\n initFn = function(np) {\n originalArrays[np.astr] = Lib.extendDeep([], np.get());\n np.set(new Array(len));\n };\n fillFn = function(np, index) {\n var val = originalArrays[np.astr][index];\n np.get()[index] = val;\n };\n } else {\n initFn = function(np) {\n originalArrays[np.astr] = Lib.extendDeep([], np.get());\n np.set([]);\n };\n fillFn = function(np, index) {\n var val = originalArrays[np.astr][index];\n np.get().push(val);\n };\n }\n\n // copy all original array attribute values, and clear arrays in trace\n forAllAttrs(initFn);\n\n var originalPointsAccessor = pointsAccessorFunction(trace.transforms, opts);\n\n // loop through filter array, fill trace arrays if passed\n for(var i = 0; i < len; i++) {\n var passed = filterFunc(targetArray[i]);\n if(passed) {\n forAllAttrs(fillFn, i);\n indexToPoints[index++] = originalPointsAccessor(i);\n } else if(preservegaps) index++;\n }\n\n opts._indexToPoints = indexToPoints;\n trace._length = index;\n};\n\nfunction getFilterFunc(opts, d2c, targetCalendar) {\n var operation = opts.operation;\n var value = opts.value;\n var hasArrayValue = Lib.isArrayOrTypedArray(value);\n\n function isOperationIn(array) {\n return array.indexOf(operation) !== -1;\n }\n\n var d2cValue = function(v) { return d2c(v, 0, opts.valuecalendar); };\n var d2cTarget = function(v) { return d2c(v, 0, targetCalendar); };\n\n var coercedValue;\n\n if(isOperationIn(COMPARISON_OPS)) {\n coercedValue = hasArrayValue ? d2cValue(value[0]) : d2cValue(value);\n } else if(isOperationIn(INTERVAL_OPS)) {\n coercedValue = hasArrayValue ?\n [d2cValue(value[0]), d2cValue(value[1])] :\n [d2cValue(value), d2cValue(value)];\n } else if(isOperationIn(SET_OPS)) {\n coercedValue = hasArrayValue ? value.map(d2cValue) : [d2cValue(value)];\n }\n\n switch(operation) {\n case '=':\n return function(v) { return d2cTarget(v) === coercedValue; };\n\n case '!=':\n return function(v) { return d2cTarget(v) !== coercedValue; };\n\n case '<':\n return function(v) { return d2cTarget(v) < coercedValue; };\n\n case '<=':\n return function(v) { return d2cTarget(v) <= coercedValue; };\n\n case '>':\n return function(v) { return d2cTarget(v) > coercedValue; };\n\n case '>=':\n return function(v) { return d2cTarget(v) >= coercedValue; };\n\n case '[]':\n return function(v) {\n var cv = d2cTarget(v);\n return cv >= coercedValue[0] && cv <= coercedValue[1];\n };\n\n case '()':\n return function(v) {\n var cv = d2cTarget(v);\n return cv > coercedValue[0] && cv < coercedValue[1];\n };\n\n case '[)':\n return function(v) {\n var cv = d2cTarget(v);\n return cv >= coercedValue[0] && cv < coercedValue[1];\n };\n\n case '(]':\n return function(v) {\n var cv = d2cTarget(v);\n return cv > coercedValue[0] && cv <= coercedValue[1];\n };\n\n case '][':\n return function(v) {\n var cv = d2cTarget(v);\n return cv <= coercedValue[0] || cv >= coercedValue[1];\n };\n\n case ')(':\n return function(v) {\n var cv = d2cTarget(v);\n return cv < coercedValue[0] || cv > coercedValue[1];\n };\n\n case '](':\n return function(v) {\n var cv = d2cTarget(v);\n return cv <= coercedValue[0] || cv > coercedValue[1];\n };\n\n case ')[':\n return function(v) {\n var cv = d2cTarget(v);\n return cv < coercedValue[0] || cv >= coercedValue[1];\n };\n\n case '{}':\n return function(v) {\n return coercedValue.indexOf(d2cTarget(v)) !== -1;\n };\n\n case '}{':\n return function(v) {\n return coercedValue.indexOf(d2cTarget(v)) === -1;\n };\n }\n}\n","'use strict';\n\nvar Lib = require('../lib');\nvar PlotSchema = require('../plot_api/plot_schema');\nvar Plots = require('../plots/plots');\nvar pointsAccessorFunction = require('./helpers').pointsAccessorFunction;\n\nexports.moduleType = 'transform';\n\nexports.name = 'groupby';\n\nexports.attributes = {\n enabled: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether this group-by transform is enabled or disabled.'\n ].join(' ')\n },\n groups: {\n valType: 'data_array',\n dflt: [],\n editType: 'calc',\n description: [\n 'Sets the groups in which the trace data will be split.',\n 'For example, with `x` set to *[1, 2, 3, 4]* and',\n '`groups` set to *[\\'a\\', \\'b\\', \\'a\\', \\'b\\']*,',\n 'the groupby transform with split in one trace',\n 'with `x` [1, 3] and one trace with `x` [2, 4].'\n ].join(' ')\n },\n nameformat: {\n valType: 'string',\n editType: 'calc',\n description: [\n 'Pattern by which grouped traces are named. If only one trace is present,',\n 'defaults to the group name (`\"%{group}\"`), otherwise defaults to the group name',\n 'with trace name (`\"%{group} (%{trace})\"`). Available escape sequences are `%{group}`, which',\n 'inserts the group name, and `%{trace}`, which inserts the trace name. If grouping',\n 'GDP data by country when more than one trace is present, for example, the',\n 'default \"%{group} (%{trace})\" would return \"Monaco (GDP per capita)\".'\n ].join(' ')\n },\n styles: {\n _isLinkedToArray: 'style',\n target: {\n valType: 'string',\n editType: 'calc',\n description: [\n 'The group value which receives these styles.'\n ].join(' ')\n },\n value: {\n valType: 'any',\n dflt: {},\n editType: 'calc',\n description: [\n 'Sets each group styles.',\n 'For example, with `groups` set to *[\\'a\\', \\'b\\', \\'a\\', \\'b\\']*',\n 'and `styles` set to *[{target: \\'a\\', value: { marker: { color: \\'red\\' } }}]',\n 'marker points in group *\\'a\\'* will be drawn in red.'\n ].join(' '),\n _compareAsJSON: true\n },\n editType: 'calc'\n },\n editType: 'calc'\n};\n\n/**\n * Supply transform attributes defaults\n *\n * @param {object} transformIn\n * object linked to trace.transforms[i] with 'type' set to exports.name\n * @param {object} traceOut\n * the _fullData trace this transform applies to\n * @param {object} layout\n * the plot's (not-so-full) layout\n * @param {object} traceIn\n * the input data trace this transform applies to\n *\n * @return {object} transformOut\n * copy of transformIn that contains attribute defaults\n */\nexports.supplyDefaults = function(transformIn, traceOut, layout) {\n var i;\n var transformOut = {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(transformIn, transformOut, exports.attributes, attr, dflt);\n }\n\n var enabled = coerce('enabled');\n\n if(!enabled) return transformOut;\n\n coerce('groups');\n coerce('nameformat', layout._dataLength > 1 ? '%{group} (%{trace})' : '%{group}');\n\n var styleIn = transformIn.styles;\n var styleOut = transformOut.styles = [];\n\n if(styleIn) {\n for(i = 0; i < styleIn.length; i++) {\n var thisStyle = styleOut[i] = {};\n Lib.coerce(styleIn[i], styleOut[i], exports.attributes.styles, 'target');\n var value = Lib.coerce(styleIn[i], styleOut[i], exports.attributes.styles, 'value');\n\n // so that you can edit value in place and have Plotly.react notice it, or\n // rebuild it every time and have Plotly.react NOT think it changed:\n // use _compareAsJSON to say we should diff the _JSON_value\n if(Lib.isPlainObject(value)) thisStyle.value = Lib.extendDeep({}, value);\n else if(value) delete thisStyle.value;\n }\n }\n\n return transformOut;\n};\n\n\n/**\n * Apply transform !!!\n *\n * @param {array} data\n * array of transformed traces (is [fullTrace] upon first transform)\n *\n * @param {object} state\n * state object which includes:\n * - transform {object} full transform attributes\n * - fullTrace {object} full trace object which is being transformed\n * - fullData {array} full pre-transform(s) data array\n * - layout {object} the plot's (not-so-full) layout\n *\n * @return {object} newData\n * array of transformed traces\n */\nexports.transform = function(data, state) {\n var newTraces, i, j;\n var newData = [];\n\n for(i = 0; i < data.length; i++) {\n newTraces = transformOne(data[i], state);\n\n for(j = 0; j < newTraces.length; j++) {\n newData.push(newTraces[j]);\n }\n }\n\n return newData;\n};\n\nfunction transformOne(trace, state) {\n var i, j, k, attr, srcArray, groupName, newTrace, transforms, arrayLookup;\n var groupNameObj;\n\n var opts = state.transform;\n var transformIndex = state.transformIndex;\n var groups = trace.transforms[transformIndex].groups;\n var originalPointsAccessor = pointsAccessorFunction(trace.transforms, opts);\n\n if(!(Lib.isArrayOrTypedArray(groups)) || groups.length === 0) {\n return [trace];\n }\n\n var groupNames = Lib.filterUnique(groups);\n var newData = new Array(groupNames.length);\n var len = groups.length;\n\n var arrayAttrs = PlotSchema.findArrayAttributes(trace);\n\n var styles = opts.styles || [];\n var styleLookup = {};\n for(i = 0; i < styles.length; i++) {\n styleLookup[styles[i].target] = styles[i].value;\n }\n\n if(opts.styles) {\n groupNameObj = Lib.keyedContainer(opts, 'styles', 'target', 'value.name');\n }\n\n // An index to map group name --> expanded trace index\n var indexLookup = {};\n var indexCnts = {};\n\n for(i = 0; i < groupNames.length; i++) {\n groupName = groupNames[i];\n indexLookup[groupName] = i;\n indexCnts[groupName] = 0;\n\n // Start with a deep extend that just copies array references.\n newTrace = newData[i] = Lib.extendDeepNoArrays({}, trace);\n newTrace._group = groupName;\n newTrace.transforms[transformIndex]._indexToPoints = {};\n\n var suppliedName = null;\n if(groupNameObj) {\n suppliedName = groupNameObj.get(groupName);\n }\n\n if(suppliedName || suppliedName === '') {\n newTrace.name = suppliedName;\n } else {\n newTrace.name = Lib.templateString(opts.nameformat, {\n trace: trace.name,\n group: groupName\n });\n }\n\n // In order for groups to apply correctly to other transform data (e.g.\n // a filter transform), we have to break the connection and clone the\n // transforms so that each group writes grouped values into a different\n // destination. This function does not break the array reference\n // connection between the split transforms it creates. That's handled in\n // initialize, which creates a new empty array for each arrayAttr.\n transforms = newTrace.transforms;\n newTrace.transforms = [];\n for(j = 0; j < transforms.length; j++) {\n newTrace.transforms[j] = Lib.extendDeepNoArrays({}, transforms[j]);\n }\n\n // Initialize empty arrays for the arrayAttrs, to be split in the next step\n for(j = 0; j < arrayAttrs.length; j++) {\n Lib.nestedProperty(newTrace, arrayAttrs[j]).set([]);\n }\n }\n\n // For each array attribute including those nested inside this and other\n // transforms (small note that we technically only need to do this for\n // transforms that have not yet been applied):\n for(k = 0; k < arrayAttrs.length; k++) {\n attr = arrayAttrs[k];\n\n // Cache all the arrays to which we'll push:\n for(j = 0, arrayLookup = []; j < groupNames.length; j++) {\n arrayLookup[j] = Lib.nestedProperty(newData[j], attr).get();\n }\n\n // Get the input data:\n srcArray = Lib.nestedProperty(trace, attr).get();\n\n // Send each data point to the appropriate expanded trace:\n for(j = 0; j < len; j++) {\n // Map group data --> trace index --> array and push data onto it\n arrayLookup[indexLookup[groups[j]]].push(srcArray[j]);\n }\n }\n\n for(j = 0; j < len; j++) {\n newTrace = newData[indexLookup[groups[j]]];\n\n var indexToPoints = newTrace.transforms[transformIndex]._indexToPoints;\n indexToPoints[indexCnts[groups[j]]] = originalPointsAccessor(j);\n indexCnts[groups[j]]++;\n }\n\n for(i = 0; i < groupNames.length; i++) {\n groupName = groupNames[i];\n newTrace = newData[i];\n\n Plots.clearExpandedTraceDefaultColors(newTrace);\n\n // there's no need to coerce styleLookup[groupName] here\n // as another round of supplyDefaults is done on the transformed traces\n newTrace = Lib.extendDeepNoArrays(newTrace, styleLookup[groupName] || {});\n }\n\n return newData;\n}\n","'use strict';\n\nexports.pointsAccessorFunction = function(transforms, opts) {\n var tr;\n var prevIndexToPoints;\n for(var i = 0; i < transforms.length; i++) {\n tr = transforms[i];\n if(tr === opts) break;\n if(!tr._indexToPoints || tr.enabled === false) continue;\n prevIndexToPoints = tr._indexToPoints;\n }\n var originalPointsAccessor = prevIndexToPoints ?\n function(i) {return prevIndexToPoints[i];} :\n function(i) {return [i];};\n return originalPointsAccessor;\n};\n","'use strict';\n\nvar Lib = require('../lib');\nvar Axes = require('../plots/cartesian/axes');\nvar pointsAccessorFunction = require('./helpers').pointsAccessorFunction;\n\nvar BADNUM = require('../constants/numerical').BADNUM;\n\nexports.moduleType = 'transform';\n\nexports.name = 'sort';\n\nexports.attributes = {\n enabled: {\n valType: 'boolean',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether this sort transform is enabled or disabled.'\n ].join(' ')\n },\n target: {\n valType: 'string',\n strict: true,\n noBlank: true,\n arrayOk: true,\n dflt: 'x',\n editType: 'calc',\n description: [\n 'Sets the target by which the sort transform is applied.',\n\n 'If a string, *target* is assumed to be a reference to a data array',\n 'in the parent trace object.',\n 'To sort about nested variables, use *.* to access them.',\n 'For example, set `target` to *marker.size* to sort',\n 'about the marker size array.',\n\n 'If an array, *target* is then the data array by which',\n 'the sort transform is applied.'\n ].join(' ')\n },\n order: {\n valType: 'enumerated',\n values: ['ascending', 'descending'],\n dflt: 'ascending',\n editType: 'calc',\n description: [\n 'Sets the sort transform order.'\n ].join(' ')\n },\n editType: 'calc'\n};\n\nexports.supplyDefaults = function(transformIn) {\n var transformOut = {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(transformIn, transformOut, exports.attributes, attr, dflt);\n }\n\n var enabled = coerce('enabled');\n\n if(enabled) {\n coerce('target');\n coerce('order');\n }\n\n return transformOut;\n};\n\nexports.calcTransform = function(gd, trace, opts) {\n if(!opts.enabled) return;\n\n var targetArray = Lib.getTargetArray(trace, opts);\n if(!targetArray) return;\n\n var target = opts.target;\n\n var len = targetArray.length;\n if(trace._length) len = Math.min(len, trace._length);\n\n var arrayAttrs = trace._arrayAttrs;\n var d2c = Axes.getDataToCoordFunc(gd, trace, target, targetArray);\n var indices = getIndices(opts, targetArray, d2c, len);\n var originalPointsAccessor = pointsAccessorFunction(trace.transforms, opts);\n var indexToPoints = {};\n var i, j;\n\n for(i = 0; i < arrayAttrs.length; i++) {\n var np = Lib.nestedProperty(trace, arrayAttrs[i]);\n var arrayOld = np.get();\n var arrayNew = new Array(len);\n\n for(j = 0; j < len; j++) {\n arrayNew[j] = arrayOld[indices[j]];\n }\n\n np.set(arrayNew);\n }\n\n for(j = 0; j < len; j++) {\n indexToPoints[j] = originalPointsAccessor(indices[j]);\n }\n\n opts._indexToPoints = indexToPoints;\n trace._length = len;\n};\n\nfunction getIndices(opts, targetArray, d2c, len) {\n var sortedArray = new Array(len);\n var indices = new Array(len);\n var i;\n\n for(i = 0; i < len; i++) {\n sortedArray[i] = {v: targetArray[i], i: i};\n }\n\n sortedArray.sort(getSortFunc(opts, d2c));\n\n for(i = 0; i < len; i++) {\n indices[i] = sortedArray[i].i;\n }\n\n return indices;\n}\n\nfunction getSortFunc(opts, d2c) {\n switch(opts.order) {\n case 'ascending':\n return function(a, b) {\n var ac = d2c(a.v);\n var bc = d2c(b.v);\n if(ac === BADNUM) {\n return 1;\n }\n if(bc === BADNUM) {\n return -1;\n }\n return ac - bc;\n };\n case 'descending':\n return function(a, b) {\n var ac = d2c(a.v);\n var bc = d2c(b.v);\n if(ac === BADNUM) {\n return 1;\n }\n if(bc === BADNUM) {\n return -1;\n }\n return bc - ac;\n };\n }\n}\n","'use strict';\n\n// package version injected by `npm run preprocess`\nexports.version = '2.35.2';\n","/******/ (function() { // webpackBootstrap\n/******/ \tvar __webpack_modules__ = ({\n\n/***/ 1964:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports = {\n alpha_shape: __webpack_require__(3502),\n convex_hull: __webpack_require__(7352),\n delaunay_triangulate: __webpack_require__(7642),\n gl_cone3d: __webpack_require__(6405),\n gl_error3d: __webpack_require__(9165),\n gl_heatmap2d: __webpack_require__(2510),\n gl_line3d: __webpack_require__(5714),\n gl_mesh3d: __webpack_require__(7201),\n gl_plot2d: __webpack_require__(1850),\n gl_plot3d: __webpack_require__(4100),\n gl_pointcloud2d: __webpack_require__(4696),\n gl_scatter3d: __webpack_require__(8418),\n gl_select_box: __webpack_require__(3161),\n gl_spikes2d: __webpack_require__(4098),\n gl_streamtube3d: __webpack_require__(7815),\n gl_surface3d: __webpack_require__(9499),\n ndarray: __webpack_require__(9618),\n ndarray_linear_interpolate: __webpack_require__(4317)\n};\n\n/***/ }),\n\n/***/ 4793:\n/***/ (function(__unused_webpack_module, exports, __webpack_require__) {\n\n\"use strict\";\nvar __webpack_unused_export__;\n/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\n/* eslint-disable no-proto */\n\n\n\nfunction _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError(\"Cannot call a class as a function\"); }\nfunction _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, \"value\" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } }\nfunction _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, \"prototype\", { writable: !1 }), e; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == _typeof(i) ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != _typeof(i)) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nfunction _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }\nfunction _possibleConstructorReturn(t, e) { if (e && (\"object\" == _typeof(e) || \"function\" == typeof e)) return e; if (void 0 !== e) throw new TypeError(\"Derived constructors may only return object or undefined\"); return _assertThisInitialized(t); }\nfunction _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); return e; }\nfunction _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }\nfunction _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); }\nfunction _inherits(t, e) { if (\"function\" != typeof e && null !== e) throw new TypeError(\"Super expression must either be null or a function\"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, \"prototype\", { writable: !1 }), e && _setPrototypeOf(t, e); }\nfunction _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); }\nfunction _typeof(o) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o; }, _typeof(o); }\nvar base64 = __webpack_require__(7507);\nvar ieee754 = __webpack_require__(3778);\nvar customInspectSymbol = typeof Symbol === 'function' && typeof Symbol['for'] === 'function' // eslint-disable-line dot-notation\n? Symbol['for']('nodejs.util.inspect.custom') // eslint-disable-line dot-notation\n: null;\nexports.hp = Buffer;\n__webpack_unused_export__ = SlowBuffer;\nexports.IS = 50;\nvar K_MAX_LENGTH = 0x7fffffff;\n__webpack_unused_export__ = K_MAX_LENGTH;\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Print warning and recommend using `buffer` v4.x which has an Object\n * implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * We report that the browser does not support typed arrays if the are not subclassable\n * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n * for __proto__ and has a buggy typed array implementation.\n */\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport();\nif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' && typeof console.error === 'function') {\n console.error('This browser lacks typed array (Uint8Array) support which is required by ' + '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.');\n}\nfunction typedArraySupport() {\n // Can typed array instances can be augmented?\n try {\n var arr = new Uint8Array(1);\n var proto = {\n foo: function foo() {\n return 42;\n }\n };\n Object.setPrototypeOf(proto, Uint8Array.prototype);\n Object.setPrototypeOf(arr, proto);\n return arr.foo() === 42;\n } catch (e) {\n return false;\n }\n}\nObject.defineProperty(Buffer.prototype, 'parent', {\n enumerable: true,\n get: function get() {\n if (!Buffer.isBuffer(this)) return undefined;\n return this.buffer;\n }\n});\nObject.defineProperty(Buffer.prototype, 'offset', {\n enumerable: true,\n get: function get() {\n if (!Buffer.isBuffer(this)) return undefined;\n return this.byteOffset;\n }\n});\nfunction createBuffer(length) {\n if (length > K_MAX_LENGTH) {\n throw new RangeError('The value \"' + length + '\" is invalid for option \"size\"');\n }\n // Return an augmented `Uint8Array` instance\n var buf = new Uint8Array(length);\n Object.setPrototypeOf(buf, Buffer.prototype);\n return buf;\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer(arg, encodingOrOffset, length) {\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new TypeError('The \"string\" argument must be of type string. Received type number');\n }\n return allocUnsafe(arg);\n }\n return from(arg, encodingOrOffset, length);\n}\nBuffer.poolSize = 8192; // not used by this implementation\n\nfunction from(value, encodingOrOffset, length) {\n if (typeof value === 'string') {\n return fromString(value, encodingOrOffset);\n }\n if (ArrayBuffer.isView(value)) {\n return fromArrayView(value);\n }\n if (value == null) {\n throw new TypeError('The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' + 'or Array-like Object. Received type ' + _typeof(value));\n }\n if (isInstance(value, ArrayBuffer) || value && isInstance(value.buffer, ArrayBuffer)) {\n return fromArrayBuffer(value, encodingOrOffset, length);\n }\n if (typeof SharedArrayBuffer !== 'undefined' && (isInstance(value, SharedArrayBuffer) || value && isInstance(value.buffer, SharedArrayBuffer))) {\n return fromArrayBuffer(value, encodingOrOffset, length);\n }\n if (typeof value === 'number') {\n throw new TypeError('The \"value\" argument must not be of type number. Received type number');\n }\n var valueOf = value.valueOf && value.valueOf();\n if (valueOf != null && valueOf !== value) {\n return Buffer.from(valueOf, encodingOrOffset, length);\n }\n var b = fromObject(value);\n if (b) return b;\n if (typeof Symbol !== 'undefined' && Symbol.toPrimitive != null && typeof value[Symbol.toPrimitive] === 'function') {\n return Buffer.from(value[Symbol.toPrimitive]('string'), encodingOrOffset, length);\n }\n throw new TypeError('The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' + 'or Array-like Object. Received type ' + _typeof(value));\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(value, encodingOrOffset, length);\n};\n\n// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n// https://github.com/feross/buffer/pull/148\nObject.setPrototypeOf(Buffer.prototype, Uint8Array.prototype);\nObject.setPrototypeOf(Buffer, Uint8Array);\nfunction assertSize(size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be of type number');\n } else if (size < 0) {\n throw new RangeError('The value \"' + size + '\" is invalid for option \"size\"');\n }\n}\nfunction alloc(size, fill, encoding) {\n assertSize(size);\n if (size <= 0) {\n return createBuffer(size);\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpreted as a start offset.\n return typeof encoding === 'string' ? createBuffer(size).fill(fill, encoding) : createBuffer(size).fill(fill);\n }\n return createBuffer(size);\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(size, fill, encoding);\n};\nfunction allocUnsafe(size) {\n assertSize(size);\n return createBuffer(size < 0 ? 0 : checked(size) | 0);\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(size);\n};\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(size);\n};\nfunction fromString(string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8';\n }\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding);\n }\n var length = byteLength(string, encoding) | 0;\n var buf = createBuffer(length);\n var actual = buf.write(string, encoding);\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n buf = buf.slice(0, actual);\n }\n return buf;\n}\nfunction fromArrayLike(array) {\n var length = array.length < 0 ? 0 : checked(array.length) | 0;\n var buf = createBuffer(length);\n for (var i = 0; i < length; i += 1) {\n buf[i] = array[i] & 255;\n }\n return buf;\n}\nfunction fromArrayView(arrayView) {\n if (isInstance(arrayView, Uint8Array)) {\n var copy = new Uint8Array(arrayView);\n return fromArrayBuffer(copy.buffer, copy.byteOffset, copy.byteLength);\n }\n return fromArrayLike(arrayView);\n}\nfunction fromArrayBuffer(array, byteOffset, length) {\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\"offset\" is outside of buffer bounds');\n }\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\"length\" is outside of buffer bounds');\n }\n var buf;\n if (byteOffset === undefined && length === undefined) {\n buf = new Uint8Array(array);\n } else if (length === undefined) {\n buf = new Uint8Array(array, byteOffset);\n } else {\n buf = new Uint8Array(array, byteOffset, length);\n }\n\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(buf, Buffer.prototype);\n return buf;\n}\nfunction fromObject(obj) {\n if (Buffer.isBuffer(obj)) {\n var len = checked(obj.length) | 0;\n var buf = createBuffer(len);\n if (buf.length === 0) {\n return buf;\n }\n obj.copy(buf, 0, 0, len);\n return buf;\n }\n if (obj.length !== undefined) {\n if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n return createBuffer(0);\n }\n return fromArrayLike(obj);\n }\n if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n return fromArrayLike(obj.data);\n }\n}\nfunction checked(length) {\n // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= K_MAX_LENGTH) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' + 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes');\n }\n return length | 0;\n}\nfunction SlowBuffer(length) {\n if (+length != length) {\n // eslint-disable-line eqeqeq\n length = 0;\n }\n return Buffer.alloc(+length);\n}\nBuffer.isBuffer = function isBuffer(b) {\n return b != null && b._isBuffer === true && b !== Buffer.prototype; // so Buffer.isBuffer(Buffer.prototype) will be false\n};\nBuffer.compare = function compare(a, b) {\n if (isInstance(a, Uint8Array)) a = Buffer.from(a, a.offset, a.byteLength);\n if (isInstance(b, Uint8Array)) b = Buffer.from(b, b.offset, b.byteLength);\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError('The \"buf1\", \"buf2\" arguments must be one of type Buffer or Uint8Array');\n }\n if (a === b) return 0;\n var x = a.length;\n var y = b.length;\n for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i];\n y = b[i];\n break;\n }\n }\n if (x < y) return -1;\n if (y < x) return 1;\n return 0;\n};\nBuffer.isEncoding = function isEncoding(encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true;\n default:\n return false;\n }\n};\nBuffer.concat = function concat(list, length) {\n if (!Array.isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers');\n }\n if (list.length === 0) {\n return Buffer.alloc(0);\n }\n var i;\n if (length === undefined) {\n length = 0;\n for (i = 0; i < list.length; ++i) {\n length += list[i].length;\n }\n }\n var buffer = Buffer.allocUnsafe(length);\n var pos = 0;\n for (i = 0; i < list.length; ++i) {\n var buf = list[i];\n if (isInstance(buf, Uint8Array)) {\n if (pos + buf.length > buffer.length) {\n if (!Buffer.isBuffer(buf)) buf = Buffer.from(buf);\n buf.copy(buffer, pos);\n } else {\n Uint8Array.prototype.set.call(buffer, buf, pos);\n }\n } else if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers');\n } else {\n buf.copy(buffer, pos);\n }\n pos += buf.length;\n }\n return buffer;\n};\nfunction byteLength(string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length;\n }\n if (ArrayBuffer.isView(string) || isInstance(string, ArrayBuffer)) {\n return string.byteLength;\n }\n if (typeof string !== 'string') {\n throw new TypeError('The \"string\" argument must be one of type string, Buffer, or ArrayBuffer. ' + 'Received type ' + _typeof(string));\n }\n var len = string.length;\n var mustMatch = arguments.length > 2 && arguments[2] === true;\n if (!mustMatch && len === 0) return 0;\n\n // Use a for loop to avoid recursion\n var loweredCase = false;\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len;\n case 'utf8':\n case 'utf-8':\n return utf8ToBytes(string).length;\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2;\n case 'hex':\n return len >>> 1;\n case 'base64':\n return base64ToBytes(string).length;\n default:\n if (loweredCase) {\n return mustMatch ? -1 : utf8ToBytes(string).length; // assume utf8\n }\n encoding = ('' + encoding).toLowerCase();\n loweredCase = true;\n }\n }\n}\nBuffer.byteLength = byteLength;\nfunction slowToString(encoding, start, end) {\n var loweredCase = false;\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0;\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return '';\n }\n if (end === undefined || end > this.length) {\n end = this.length;\n }\n if (end <= 0) {\n return '';\n }\n\n // Force coercion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0;\n start >>>= 0;\n if (end <= start) {\n return '';\n }\n if (!encoding) encoding = 'utf8';\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end);\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end);\n case 'ascii':\n return asciiSlice(this, start, end);\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end);\n case 'base64':\n return base64Slice(this, start, end);\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end);\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding);\n encoding = (encoding + '').toLowerCase();\n loweredCase = true;\n }\n }\n}\n\n// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n// reliably in a browserify context because there could be multiple different\n// copies of the 'buffer' package in use. This method works even for Buffer\n// instances that were created from another copy of the `buffer` package.\n// See: https://github.com/feross/buffer/issues/154\nBuffer.prototype._isBuffer = true;\nfunction swap(b, n, m) {\n var i = b[n];\n b[n] = b[m];\n b[m] = i;\n}\nBuffer.prototype.swap16 = function swap16() {\n var len = this.length;\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits');\n }\n for (var i = 0; i < len; i += 2) {\n swap(this, i, i + 1);\n }\n return this;\n};\nBuffer.prototype.swap32 = function swap32() {\n var len = this.length;\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits');\n }\n for (var i = 0; i < len; i += 4) {\n swap(this, i, i + 3);\n swap(this, i + 1, i + 2);\n }\n return this;\n};\nBuffer.prototype.swap64 = function swap64() {\n var len = this.length;\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits');\n }\n for (var i = 0; i < len; i += 8) {\n swap(this, i, i + 7);\n swap(this, i + 1, i + 6);\n swap(this, i + 2, i + 5);\n swap(this, i + 3, i + 4);\n }\n return this;\n};\nBuffer.prototype.toString = function toString() {\n var length = this.length;\n if (length === 0) return '';\n if (arguments.length === 0) return utf8Slice(this, 0, length);\n return slowToString.apply(this, arguments);\n};\nBuffer.prototype.toLocaleString = Buffer.prototype.toString;\nBuffer.prototype.equals = function equals(b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer');\n if (this === b) return true;\n return Buffer.compare(this, b) === 0;\n};\nBuffer.prototype.inspect = function inspect() {\n var str = '';\n var max = exports.IS;\n str = this.toString('hex', 0, max).replace(/(.{2})/g, '$1 ').trim();\n if (this.length > max) str += ' ... ';\n return '';\n};\nif (customInspectSymbol) {\n Buffer.prototype[customInspectSymbol] = Buffer.prototype.inspect;\n}\nBuffer.prototype.compare = function compare(target, start, end, thisStart, thisEnd) {\n if (isInstance(target, Uint8Array)) {\n target = Buffer.from(target, target.offset, target.byteLength);\n }\n if (!Buffer.isBuffer(target)) {\n throw new TypeError('The \"target\" argument must be one of type Buffer or Uint8Array. ' + 'Received type ' + _typeof(target));\n }\n if (start === undefined) {\n start = 0;\n }\n if (end === undefined) {\n end = target ? target.length : 0;\n }\n if (thisStart === undefined) {\n thisStart = 0;\n }\n if (thisEnd === undefined) {\n thisEnd = this.length;\n }\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index');\n }\n if (thisStart >= thisEnd && start >= end) {\n return 0;\n }\n if (thisStart >= thisEnd) {\n return -1;\n }\n if (start >= end) {\n return 1;\n }\n start >>>= 0;\n end >>>= 0;\n thisStart >>>= 0;\n thisEnd >>>= 0;\n if (this === target) return 0;\n var x = thisEnd - thisStart;\n var y = end - start;\n var len = Math.min(x, y);\n var thisCopy = this.slice(thisStart, thisEnd);\n var targetCopy = target.slice(start, end);\n for (var i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i];\n y = targetCopy[i];\n break;\n }\n }\n if (x < y) return -1;\n if (y < x) return 1;\n return 0;\n};\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf(buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1;\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset;\n byteOffset = 0;\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff;\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000;\n }\n byteOffset = +byteOffset; // Coerce to Number.\n if (numberIsNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : buffer.length - 1;\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset;\n if (byteOffset >= buffer.length) {\n if (dir) return -1;else byteOffset = buffer.length - 1;\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0;else return -1;\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding);\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1;\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir);\n } else if (typeof val === 'number') {\n val = val & 0xFF; // Search for a byte value [0-255]\n if (typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset);\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset);\n }\n }\n return arrayIndexOf(buffer, [val], byteOffset, encoding, dir);\n }\n throw new TypeError('val must be string, number or Buffer');\n}\nfunction arrayIndexOf(arr, val, byteOffset, encoding, dir) {\n var indexSize = 1;\n var arrLength = arr.length;\n var valLength = val.length;\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase();\n if (encoding === 'ucs2' || encoding === 'ucs-2' || encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1;\n }\n indexSize = 2;\n arrLength /= 2;\n valLength /= 2;\n byteOffset /= 2;\n }\n }\n function read(buf, i) {\n if (indexSize === 1) {\n return buf[i];\n } else {\n return buf.readUInt16BE(i * indexSize);\n }\n }\n var i;\n if (dir) {\n var foundIndex = -1;\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i;\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize;\n } else {\n if (foundIndex !== -1) i -= i - foundIndex;\n foundIndex = -1;\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength;\n for (i = byteOffset; i >= 0; i--) {\n var found = true;\n for (var j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false;\n break;\n }\n }\n if (found) return i;\n }\n }\n return -1;\n}\nBuffer.prototype.includes = function includes(val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1;\n};\nBuffer.prototype.indexOf = function indexOf(val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true);\n};\nBuffer.prototype.lastIndexOf = function lastIndexOf(val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false);\n};\nfunction hexWrite(buf, string, offset, length) {\n offset = Number(offset) || 0;\n var remaining = buf.length - offset;\n if (!length) {\n length = remaining;\n } else {\n length = Number(length);\n if (length > remaining) {\n length = remaining;\n }\n }\n var strLen = string.length;\n if (length > strLen / 2) {\n length = strLen / 2;\n }\n var i;\n for (i = 0; i < length; ++i) {\n var parsed = parseInt(string.substr(i * 2, 2), 16);\n if (numberIsNaN(parsed)) return i;\n buf[offset + i] = parsed;\n }\n return i;\n}\nfunction utf8Write(buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length);\n}\nfunction asciiWrite(buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length);\n}\nfunction base64Write(buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length);\n}\nfunction ucs2Write(buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length);\n}\nBuffer.prototype.write = function write(string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8';\n length = this.length;\n offset = 0;\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset;\n length = this.length;\n offset = 0;\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset >>> 0;\n if (isFinite(length)) {\n length = length >>> 0;\n if (encoding === undefined) encoding = 'utf8';\n } else {\n encoding = length;\n length = undefined;\n }\n } else {\n throw new Error('Buffer.write(string, encoding, offset[, length]) is no longer supported');\n }\n var remaining = this.length - offset;\n if (length === undefined || length > remaining) length = remaining;\n if (string.length > 0 && (length < 0 || offset < 0) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds');\n }\n if (!encoding) encoding = 'utf8';\n var loweredCase = false;\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length);\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length);\n case 'ascii':\n case 'latin1':\n case 'binary':\n return asciiWrite(this, string, offset, length);\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length);\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length);\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding);\n encoding = ('' + encoding).toLowerCase();\n loweredCase = true;\n }\n }\n};\nBuffer.prototype.toJSON = function toJSON() {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n };\n};\nfunction base64Slice(buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf);\n } else {\n return base64.fromByteArray(buf.slice(start, end));\n }\n}\nfunction utf8Slice(buf, start, end) {\n end = Math.min(buf.length, end);\n var res = [];\n var i = start;\n while (i < end) {\n var firstByte = buf[i];\n var codePoint = null;\n var bytesPerSequence = firstByte > 0xEF ? 4 : firstByte > 0xDF ? 3 : firstByte > 0xBF ? 2 : 1;\n if (i + bytesPerSequence <= end) {\n var secondByte = void 0,\n thirdByte = void 0,\n fourthByte = void 0,\n tempCodePoint = void 0;\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte;\n }\n break;\n case 2:\n secondByte = buf[i + 1];\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | secondByte & 0x3F;\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint;\n }\n }\n break;\n case 3:\n secondByte = buf[i + 1];\n thirdByte = buf[i + 2];\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | thirdByte & 0x3F;\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint;\n }\n }\n break;\n case 4:\n secondByte = buf[i + 1];\n thirdByte = buf[i + 2];\n fourthByte = buf[i + 3];\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | fourthByte & 0x3F;\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint;\n }\n }\n }\n }\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD;\n bytesPerSequence = 1;\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000;\n res.push(codePoint >>> 10 & 0x3FF | 0xD800);\n codePoint = 0xDC00 | codePoint & 0x3FF;\n }\n res.push(codePoint);\n i += bytesPerSequence;\n }\n return decodeCodePointsArray(res);\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000;\nfunction decodeCodePointsArray(codePoints) {\n var len = codePoints.length;\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints); // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n var res = '';\n var i = 0;\n while (i < len) {\n res += String.fromCharCode.apply(String, codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH));\n }\n return res;\n}\nfunction asciiSlice(buf, start, end) {\n var ret = '';\n end = Math.min(buf.length, end);\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F);\n }\n return ret;\n}\nfunction latin1Slice(buf, start, end) {\n var ret = '';\n end = Math.min(buf.length, end);\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i]);\n }\n return ret;\n}\nfunction hexSlice(buf, start, end) {\n var len = buf.length;\n if (!start || start < 0) start = 0;\n if (!end || end < 0 || end > len) end = len;\n var out = '';\n for (var i = start; i < end; ++i) {\n out += hexSliceLookupTable[buf[i]];\n }\n return out;\n}\nfunction utf16leSlice(buf, start, end) {\n var bytes = buf.slice(start, end);\n var res = '';\n // If bytes.length is odd, the last 8 bits must be ignored (same as node.js)\n for (var i = 0; i < bytes.length - 1; i += 2) {\n res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256);\n }\n return res;\n}\nBuffer.prototype.slice = function slice(start, end) {\n var len = this.length;\n start = ~~start;\n end = end === undefined ? len : ~~end;\n if (start < 0) {\n start += len;\n if (start < 0) start = 0;\n } else if (start > len) {\n start = len;\n }\n if (end < 0) {\n end += len;\n if (end < 0) end = 0;\n } else if (end > len) {\n end = len;\n }\n if (end < start) end = start;\n var newBuf = this.subarray(start, end);\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(newBuf, Buffer.prototype);\n return newBuf;\n};\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset(offset, ext, length) {\n if (offset % 1 !== 0 || offset < 0) throw new RangeError('offset is not uint');\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length');\n}\nBuffer.prototype.readUintLE = Buffer.prototype.readUIntLE = function readUIntLE(offset, byteLength, noAssert) {\n offset = offset >>> 0;\n byteLength = byteLength >>> 0;\n if (!noAssert) checkOffset(offset, byteLength, this.length);\n var val = this[offset];\n var mul = 1;\n var i = 0;\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul;\n }\n return val;\n};\nBuffer.prototype.readUintBE = Buffer.prototype.readUIntBE = function readUIntBE(offset, byteLength, noAssert) {\n offset = offset >>> 0;\n byteLength = byteLength >>> 0;\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length);\n }\n var val = this[offset + --byteLength];\n var mul = 1;\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul;\n }\n return val;\n};\nBuffer.prototype.readUint8 = Buffer.prototype.readUInt8 = function readUInt8(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 1, this.length);\n return this[offset];\n};\nBuffer.prototype.readUint16LE = Buffer.prototype.readUInt16LE = function readUInt16LE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 2, this.length);\n return this[offset] | this[offset + 1] << 8;\n};\nBuffer.prototype.readUint16BE = Buffer.prototype.readUInt16BE = function readUInt16BE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 2, this.length);\n return this[offset] << 8 | this[offset + 1];\n};\nBuffer.prototype.readUint32LE = Buffer.prototype.readUInt32LE = function readUInt32LE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 4, this.length);\n return (this[offset] | this[offset + 1] << 8 | this[offset + 2] << 16) + this[offset + 3] * 0x1000000;\n};\nBuffer.prototype.readUint32BE = Buffer.prototype.readUInt32BE = function readUInt32BE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 4, this.length);\n return this[offset] * 0x1000000 + (this[offset + 1] << 16 | this[offset + 2] << 8 | this[offset + 3]);\n};\nBuffer.prototype.readBigUInt64LE = defineBigIntMethod(function readBigUInt64LE(offset) {\n offset = offset >>> 0;\n validateNumber(offset, 'offset');\n var first = this[offset];\n var last = this[offset + 7];\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8);\n }\n var lo = first + this[++offset] * Math.pow(2, 8) + this[++offset] * Math.pow(2, 16) + this[++offset] * Math.pow(2, 24);\n var hi = this[++offset] + this[++offset] * Math.pow(2, 8) + this[++offset] * Math.pow(2, 16) + last * Math.pow(2, 24);\n return BigInt(lo) + (BigInt(hi) << BigInt(32));\n});\nBuffer.prototype.readBigUInt64BE = defineBigIntMethod(function readBigUInt64BE(offset) {\n offset = offset >>> 0;\n validateNumber(offset, 'offset');\n var first = this[offset];\n var last = this[offset + 7];\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8);\n }\n var hi = first * Math.pow(2, 24) + this[++offset] * Math.pow(2, 16) + this[++offset] * Math.pow(2, 8) + this[++offset];\n var lo = this[++offset] * Math.pow(2, 24) + this[++offset] * Math.pow(2, 16) + this[++offset] * Math.pow(2, 8) + last;\n return (BigInt(hi) << BigInt(32)) + BigInt(lo);\n});\nBuffer.prototype.readIntLE = function readIntLE(offset, byteLength, noAssert) {\n offset = offset >>> 0;\n byteLength = byteLength >>> 0;\n if (!noAssert) checkOffset(offset, byteLength, this.length);\n var val = this[offset];\n var mul = 1;\n var i = 0;\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul;\n }\n mul *= 0x80;\n if (val >= mul) val -= Math.pow(2, 8 * byteLength);\n return val;\n};\nBuffer.prototype.readIntBE = function readIntBE(offset, byteLength, noAssert) {\n offset = offset >>> 0;\n byteLength = byteLength >>> 0;\n if (!noAssert) checkOffset(offset, byteLength, this.length);\n var i = byteLength;\n var mul = 1;\n var val = this[offset + --i];\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul;\n }\n mul *= 0x80;\n if (val >= mul) val -= Math.pow(2, 8 * byteLength);\n return val;\n};\nBuffer.prototype.readInt8 = function readInt8(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 1, this.length);\n if (!(this[offset] & 0x80)) return this[offset];\n return (0xff - this[offset] + 1) * -1;\n};\nBuffer.prototype.readInt16LE = function readInt16LE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 2, this.length);\n var val = this[offset] | this[offset + 1] << 8;\n return val & 0x8000 ? val | 0xFFFF0000 : val;\n};\nBuffer.prototype.readInt16BE = function readInt16BE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 2, this.length);\n var val = this[offset + 1] | this[offset] << 8;\n return val & 0x8000 ? val | 0xFFFF0000 : val;\n};\nBuffer.prototype.readInt32LE = function readInt32LE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 4, this.length);\n return this[offset] | this[offset + 1] << 8 | this[offset + 2] << 16 | this[offset + 3] << 24;\n};\nBuffer.prototype.readInt32BE = function readInt32BE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 4, this.length);\n return this[offset] << 24 | this[offset + 1] << 16 | this[offset + 2] << 8 | this[offset + 3];\n};\nBuffer.prototype.readBigInt64LE = defineBigIntMethod(function readBigInt64LE(offset) {\n offset = offset >>> 0;\n validateNumber(offset, 'offset');\n var first = this[offset];\n var last = this[offset + 7];\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8);\n }\n var val = this[offset + 4] + this[offset + 5] * Math.pow(2, 8) + this[offset + 6] * Math.pow(2, 16) + (last << 24); // Overflow\n\n return (BigInt(val) << BigInt(32)) + BigInt(first + this[++offset] * Math.pow(2, 8) + this[++offset] * Math.pow(2, 16) + this[++offset] * Math.pow(2, 24));\n});\nBuffer.prototype.readBigInt64BE = defineBigIntMethod(function readBigInt64BE(offset) {\n offset = offset >>> 0;\n validateNumber(offset, 'offset');\n var first = this[offset];\n var last = this[offset + 7];\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8);\n }\n var val = (first << 24) +\n // Overflow\n this[++offset] * Math.pow(2, 16) + this[++offset] * Math.pow(2, 8) + this[++offset];\n return (BigInt(val) << BigInt(32)) + BigInt(this[++offset] * Math.pow(2, 24) + this[++offset] * Math.pow(2, 16) + this[++offset] * Math.pow(2, 8) + last);\n});\nBuffer.prototype.readFloatLE = function readFloatLE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 4, this.length);\n return ieee754.read(this, offset, true, 23, 4);\n};\nBuffer.prototype.readFloatBE = function readFloatBE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 4, this.length);\n return ieee754.read(this, offset, false, 23, 4);\n};\nBuffer.prototype.readDoubleLE = function readDoubleLE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 8, this.length);\n return ieee754.read(this, offset, true, 52, 8);\n};\nBuffer.prototype.readDoubleBE = function readDoubleBE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 8, this.length);\n return ieee754.read(this, offset, false, 52, 8);\n};\nfunction checkInt(buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance');\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds');\n if (offset + ext > buf.length) throw new RangeError('Index out of range');\n}\nBuffer.prototype.writeUintLE = Buffer.prototype.writeUIntLE = function writeUIntLE(value, offset, byteLength, noAssert) {\n value = +value;\n offset = offset >>> 0;\n byteLength = byteLength >>> 0;\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1;\n checkInt(this, value, offset, byteLength, maxBytes, 0);\n }\n var mul = 1;\n var i = 0;\n this[offset] = value & 0xFF;\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = value / mul & 0xFF;\n }\n return offset + byteLength;\n};\nBuffer.prototype.writeUintBE = Buffer.prototype.writeUIntBE = function writeUIntBE(value, offset, byteLength, noAssert) {\n value = +value;\n offset = offset >>> 0;\n byteLength = byteLength >>> 0;\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1;\n checkInt(this, value, offset, byteLength, maxBytes, 0);\n }\n var i = byteLength - 1;\n var mul = 1;\n this[offset + i] = value & 0xFF;\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = value / mul & 0xFF;\n }\n return offset + byteLength;\n};\nBuffer.prototype.writeUint8 = Buffer.prototype.writeUInt8 = function writeUInt8(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0);\n this[offset] = value & 0xff;\n return offset + 1;\n};\nBuffer.prototype.writeUint16LE = Buffer.prototype.writeUInt16LE = function writeUInt16LE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0);\n this[offset] = value & 0xff;\n this[offset + 1] = value >>> 8;\n return offset + 2;\n};\nBuffer.prototype.writeUint16BE = Buffer.prototype.writeUInt16BE = function writeUInt16BE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0);\n this[offset] = value >>> 8;\n this[offset + 1] = value & 0xff;\n return offset + 2;\n};\nBuffer.prototype.writeUint32LE = Buffer.prototype.writeUInt32LE = function writeUInt32LE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0);\n this[offset + 3] = value >>> 24;\n this[offset + 2] = value >>> 16;\n this[offset + 1] = value >>> 8;\n this[offset] = value & 0xff;\n return offset + 4;\n};\nBuffer.prototype.writeUint32BE = Buffer.prototype.writeUInt32BE = function writeUInt32BE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0);\n this[offset] = value >>> 24;\n this[offset + 1] = value >>> 16;\n this[offset + 2] = value >>> 8;\n this[offset + 3] = value & 0xff;\n return offset + 4;\n};\nfunction wrtBigUInt64LE(buf, value, offset, min, max) {\n checkIntBI(value, min, max, buf, offset, 7);\n var lo = Number(value & BigInt(0xffffffff));\n buf[offset++] = lo;\n lo = lo >> 8;\n buf[offset++] = lo;\n lo = lo >> 8;\n buf[offset++] = lo;\n lo = lo >> 8;\n buf[offset++] = lo;\n var hi = Number(value >> BigInt(32) & BigInt(0xffffffff));\n buf[offset++] = hi;\n hi = hi >> 8;\n buf[offset++] = hi;\n hi = hi >> 8;\n buf[offset++] = hi;\n hi = hi >> 8;\n buf[offset++] = hi;\n return offset;\n}\nfunction wrtBigUInt64BE(buf, value, offset, min, max) {\n checkIntBI(value, min, max, buf, offset, 7);\n var lo = Number(value & BigInt(0xffffffff));\n buf[offset + 7] = lo;\n lo = lo >> 8;\n buf[offset + 6] = lo;\n lo = lo >> 8;\n buf[offset + 5] = lo;\n lo = lo >> 8;\n buf[offset + 4] = lo;\n var hi = Number(value >> BigInt(32) & BigInt(0xffffffff));\n buf[offset + 3] = hi;\n hi = hi >> 8;\n buf[offset + 2] = hi;\n hi = hi >> 8;\n buf[offset + 1] = hi;\n hi = hi >> 8;\n buf[offset] = hi;\n return offset + 8;\n}\nBuffer.prototype.writeBigUInt64LE = defineBigIntMethod(function writeBigUInt64LE(value) {\n var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n return wrtBigUInt64LE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'));\n});\nBuffer.prototype.writeBigUInt64BE = defineBigIntMethod(function writeBigUInt64BE(value) {\n var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n return wrtBigUInt64BE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'));\n});\nBuffer.prototype.writeIntLE = function writeIntLE(value, offset, byteLength, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) {\n var limit = Math.pow(2, 8 * byteLength - 1);\n checkInt(this, value, offset, byteLength, limit - 1, -limit);\n }\n var i = 0;\n var mul = 1;\n var sub = 0;\n this[offset] = value & 0xFF;\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1;\n }\n this[offset + i] = (value / mul >> 0) - sub & 0xFF;\n }\n return offset + byteLength;\n};\nBuffer.prototype.writeIntBE = function writeIntBE(value, offset, byteLength, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) {\n var limit = Math.pow(2, 8 * byteLength - 1);\n checkInt(this, value, offset, byteLength, limit - 1, -limit);\n }\n var i = byteLength - 1;\n var mul = 1;\n var sub = 0;\n this[offset + i] = value & 0xFF;\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1;\n }\n this[offset + i] = (value / mul >> 0) - sub & 0xFF;\n }\n return offset + byteLength;\n};\nBuffer.prototype.writeInt8 = function writeInt8(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80);\n if (value < 0) value = 0xff + value + 1;\n this[offset] = value & 0xff;\n return offset + 1;\n};\nBuffer.prototype.writeInt16LE = function writeInt16LE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000);\n this[offset] = value & 0xff;\n this[offset + 1] = value >>> 8;\n return offset + 2;\n};\nBuffer.prototype.writeInt16BE = function writeInt16BE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000);\n this[offset] = value >>> 8;\n this[offset + 1] = value & 0xff;\n return offset + 2;\n};\nBuffer.prototype.writeInt32LE = function writeInt32LE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000);\n this[offset] = value & 0xff;\n this[offset + 1] = value >>> 8;\n this[offset + 2] = value >>> 16;\n this[offset + 3] = value >>> 24;\n return offset + 4;\n};\nBuffer.prototype.writeInt32BE = function writeInt32BE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000);\n if (value < 0) value = 0xffffffff + value + 1;\n this[offset] = value >>> 24;\n this[offset + 1] = value >>> 16;\n this[offset + 2] = value >>> 8;\n this[offset + 3] = value & 0xff;\n return offset + 4;\n};\nBuffer.prototype.writeBigInt64LE = defineBigIntMethod(function writeBigInt64LE(value) {\n var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n return wrtBigUInt64LE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'));\n});\nBuffer.prototype.writeBigInt64BE = defineBigIntMethod(function writeBigInt64BE(value) {\n var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n return wrtBigUInt64BE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'));\n});\nfunction checkIEEE754(buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range');\n if (offset < 0) throw new RangeError('Index out of range');\n}\nfunction writeFloat(buf, value, offset, littleEndian, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38);\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4);\n return offset + 4;\n}\nBuffer.prototype.writeFloatLE = function writeFloatLE(value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert);\n};\nBuffer.prototype.writeFloatBE = function writeFloatBE(value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert);\n};\nfunction writeDouble(buf, value, offset, littleEndian, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308);\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8);\n return offset + 8;\n}\nBuffer.prototype.writeDoubleLE = function writeDoubleLE(value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert);\n};\nBuffer.prototype.writeDoubleBE = function writeDoubleBE(value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert);\n};\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy(target, targetStart, start, end) {\n if (!Buffer.isBuffer(target)) throw new TypeError('argument should be a Buffer');\n if (!start) start = 0;\n if (!end && end !== 0) end = this.length;\n if (targetStart >= target.length) targetStart = target.length;\n if (!targetStart) targetStart = 0;\n if (end > 0 && end < start) end = start;\n\n // Copy 0 bytes; we're done\n if (end === start) return 0;\n if (target.length === 0 || this.length === 0) return 0;\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds');\n }\n if (start < 0 || start >= this.length) throw new RangeError('Index out of range');\n if (end < 0) throw new RangeError('sourceEnd out of bounds');\n\n // Are we oob?\n if (end > this.length) end = this.length;\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start;\n }\n var len = end - start;\n if (this === target && typeof Uint8Array.prototype.copyWithin === 'function') {\n // Use built-in when available, missing from IE11\n this.copyWithin(targetStart, start, end);\n } else {\n Uint8Array.prototype.set.call(target, this.subarray(start, end), targetStart);\n }\n return len;\n};\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill(val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start;\n start = 0;\n end = this.length;\n } else if (typeof end === 'string') {\n encoding = end;\n end = this.length;\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string');\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding);\n }\n if (val.length === 1) {\n var code = val.charCodeAt(0);\n if (encoding === 'utf8' && code < 128 || encoding === 'latin1') {\n // Fast path: If `val` fits into a single byte, use that numeric value.\n val = code;\n }\n }\n } else if (typeof val === 'number') {\n val = val & 255;\n } else if (typeof val === 'boolean') {\n val = Number(val);\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index');\n }\n if (end <= start) {\n return this;\n }\n start = start >>> 0;\n end = end === undefined ? this.length : end >>> 0;\n if (!val) val = 0;\n var i;\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val;\n }\n } else {\n var bytes = Buffer.isBuffer(val) ? val : Buffer.from(val, encoding);\n var len = bytes.length;\n if (len === 0) {\n throw new TypeError('The value \"' + val + '\" is invalid for argument \"value\"');\n }\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len];\n }\n }\n return this;\n};\n\n// CUSTOM ERRORS\n// =============\n\n// Simplified versions from Node, changed for Buffer-only usage\nvar errors = {};\nfunction E(sym, getMessage, Base) {\n errors[sym] = /*#__PURE__*/function (_Base) {\n function NodeError() {\n var _this;\n _classCallCheck(this, NodeError);\n _this = _callSuper(this, NodeError);\n Object.defineProperty(_this, 'message', {\n value: getMessage.apply(_this, arguments),\n writable: true,\n configurable: true\n });\n\n // Add the error code to the name to include it in the stack trace.\n _this.name = \"\".concat(_this.name, \" [\").concat(sym, \"]\");\n // Access the stack to generate the error message including the error code\n // from the name.\n _this.stack; // eslint-disable-line no-unused-expressions\n // Reset the name to the actual name.\n delete _this.name;\n return _this;\n }\n _inherits(NodeError, _Base);\n return _createClass(NodeError, [{\n key: \"code\",\n get: function get() {\n return sym;\n },\n set: function set(value) {\n Object.defineProperty(this, 'code', {\n configurable: true,\n enumerable: true,\n value: value,\n writable: true\n });\n }\n }, {\n key: \"toString\",\n value: function toString() {\n return \"\".concat(this.name, \" [\").concat(sym, \"]: \").concat(this.message);\n }\n }]);\n }(Base);\n}\nE('ERR_BUFFER_OUT_OF_BOUNDS', function (name) {\n if (name) {\n return \"\".concat(name, \" is outside of buffer bounds\");\n }\n return 'Attempt to access memory outside buffer bounds';\n}, RangeError);\nE('ERR_INVALID_ARG_TYPE', function (name, actual) {\n return \"The \\\"\".concat(name, \"\\\" argument must be of type number. Received type \").concat(_typeof(actual));\n}, TypeError);\nE('ERR_OUT_OF_RANGE', function (str, range, input) {\n var msg = \"The value of \\\"\".concat(str, \"\\\" is out of range.\");\n var received = input;\n if (Number.isInteger(input) && Math.abs(input) > Math.pow(2, 32)) {\n received = addNumericalSeparator(String(input));\n } else if (typeof input === 'bigint') {\n received = String(input);\n if (input > Math.pow(BigInt(2), BigInt(32)) || input < -Math.pow(BigInt(2), BigInt(32))) {\n received = addNumericalSeparator(received);\n }\n received += 'n';\n }\n msg += \" It must be \".concat(range, \". Received \").concat(received);\n return msg;\n}, RangeError);\nfunction addNumericalSeparator(val) {\n var res = '';\n var i = val.length;\n var start = val[0] === '-' ? 1 : 0;\n for (; i >= start + 4; i -= 3) {\n res = \"_\".concat(val.slice(i - 3, i)).concat(res);\n }\n return \"\".concat(val.slice(0, i)).concat(res);\n}\n\n// CHECK FUNCTIONS\n// ===============\n\nfunction checkBounds(buf, offset, byteLength) {\n validateNumber(offset, 'offset');\n if (buf[offset] === undefined || buf[offset + byteLength] === undefined) {\n boundsError(offset, buf.length - (byteLength + 1));\n }\n}\nfunction checkIntBI(value, min, max, buf, offset, byteLength) {\n if (value > max || value < min) {\n var n = typeof min === 'bigint' ? 'n' : '';\n var range;\n if (byteLength > 3) {\n if (min === 0 || min === BigInt(0)) {\n range = \">= 0\".concat(n, \" and < 2\").concat(n, \" ** \").concat((byteLength + 1) * 8).concat(n);\n } else {\n range = \">= -(2\".concat(n, \" ** \").concat((byteLength + 1) * 8 - 1).concat(n, \") and < 2 ** \") + \"\".concat((byteLength + 1) * 8 - 1).concat(n);\n }\n } else {\n range = \">= \".concat(min).concat(n, \" and <= \").concat(max).concat(n);\n }\n throw new errors.ERR_OUT_OF_RANGE('value', range, value);\n }\n checkBounds(buf, offset, byteLength);\n}\nfunction validateNumber(value, name) {\n if (typeof value !== 'number') {\n throw new errors.ERR_INVALID_ARG_TYPE(name, 'number', value);\n }\n}\nfunction boundsError(value, length, type) {\n if (Math.floor(value) !== value) {\n validateNumber(value, type);\n throw new errors.ERR_OUT_OF_RANGE(type || 'offset', 'an integer', value);\n }\n if (length < 0) {\n throw new errors.ERR_BUFFER_OUT_OF_BOUNDS();\n }\n throw new errors.ERR_OUT_OF_RANGE(type || 'offset', \">= \".concat(type ? 1 : 0, \" and <= \").concat(length), value);\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g;\nfunction base64clean(str) {\n // Node takes equal signs as end of the Base64 encoding\n str = str.split('=')[0];\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = str.trim().replace(INVALID_BASE64_RE, '');\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return '';\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '=';\n }\n return str;\n}\nfunction utf8ToBytes(string, units) {\n units = units || Infinity;\n var codePoint;\n var length = string.length;\n var leadSurrogate = null;\n var bytes = [];\n for (var i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i);\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n continue;\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n continue;\n }\n\n // valid lead\n leadSurrogate = codePoint;\n continue;\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n leadSurrogate = codePoint;\n continue;\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000;\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n }\n leadSurrogate = null;\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break;\n bytes.push(codePoint);\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break;\n bytes.push(codePoint >> 0x6 | 0xC0, codePoint & 0x3F | 0x80);\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break;\n bytes.push(codePoint >> 0xC | 0xE0, codePoint >> 0x6 & 0x3F | 0x80, codePoint & 0x3F | 0x80);\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break;\n bytes.push(codePoint >> 0x12 | 0xF0, codePoint >> 0xC & 0x3F | 0x80, codePoint >> 0x6 & 0x3F | 0x80, codePoint & 0x3F | 0x80);\n } else {\n throw new Error('Invalid code point');\n }\n }\n return bytes;\n}\nfunction asciiToBytes(str) {\n var byteArray = [];\n for (var i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF);\n }\n return byteArray;\n}\nfunction utf16leToBytes(str, units) {\n var c, hi, lo;\n var byteArray = [];\n for (var i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break;\n c = str.charCodeAt(i);\n hi = c >> 8;\n lo = c % 256;\n byteArray.push(lo);\n byteArray.push(hi);\n }\n return byteArray;\n}\nfunction base64ToBytes(str) {\n return base64.toByteArray(base64clean(str));\n}\nfunction blitBuffer(src, dst, offset, length) {\n var i;\n for (i = 0; i < length; ++i) {\n if (i + offset >= dst.length || i >= src.length) break;\n dst[i + offset] = src[i];\n }\n return i;\n}\n\n// ArrayBuffer or Uint8Array objects from other contexts (i.e. iframes) do not pass\n// the `instanceof` check but they should be treated as of that type.\n// See: https://github.com/feross/buffer/issues/166\nfunction isInstance(obj, type) {\n return obj instanceof type || obj != null && obj.constructor != null && obj.constructor.name != null && obj.constructor.name === type.name;\n}\nfunction numberIsNaN(obj) {\n // For IE11 support\n return obj !== obj; // eslint-disable-line no-self-compare\n}\n\n// Create lookup table for `toString('hex')`\n// See: https://github.com/feross/buffer/issues/219\nvar hexSliceLookupTable = function () {\n var alphabet = '0123456789abcdef';\n var table = new Array(256);\n for (var i = 0; i < 16; ++i) {\n var i16 = i * 16;\n for (var j = 0; j < 16; ++j) {\n table[i16 + j] = alphabet[i] + alphabet[j];\n }\n }\n return table;\n}();\n\n// Return not function with Error if BigInt not supported\nfunction defineBigIntMethod(fn) {\n return typeof BigInt === 'undefined' ? BufferBigIntNotDefined : fn;\n}\nfunction BufferBigIntNotDefined() {\n throw new Error('BigInt not supported');\n}\n\n/***/ }),\n\n/***/ 9216:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nmodule.exports = isMobile;\nmodule.exports.isMobile = isMobile;\nmodule.exports[\"default\"] = isMobile;\nvar mobileRE = /(android|bb\\d+|meego).+mobile|armv7l|avantgo|bada\\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\\/|plucker|pocket|psp|series[46]0|samsungbrowser.*mobile|symbian|treo|up\\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino/i;\nvar notMobileRE = /CrOS/;\nvar tabletRE = /android|ipad|playbook|silk/i;\nfunction isMobile(opts) {\n if (!opts) opts = {};\n var ua = opts.ua;\n if (!ua && typeof navigator !== 'undefined') ua = navigator.userAgent;\n if (ua && ua.headers && typeof ua.headers['user-agent'] === 'string') {\n ua = ua.headers['user-agent'];\n }\n if (typeof ua !== 'string') return false;\n var result = mobileRE.test(ua) && !notMobileRE.test(ua) || !!opts.tablet && tabletRE.test(ua);\n if (!result && opts.tablet && opts.featureDetect && navigator && navigator.maxTouchPoints > 1 && ua.indexOf('Macintosh') !== -1 && ua.indexOf('Safari') !== -1) {\n result = true;\n }\n return result;\n}\n\n/***/ }),\n\n/***/ 6296:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = createViewController\n\nvar createTurntable = __webpack_require__(7261)\nvar createOrbit = __webpack_require__(9977)\nvar createMatrix = __webpack_require__(4192)\n\nfunction ViewController(controllers, mode) {\n this._controllerNames = Object.keys(controllers)\n this._controllerList = this._controllerNames.map(function(n) {\n return controllers[n]\n })\n this._mode = mode\n this._active = controllers[mode]\n if(!this._active) {\n this._mode = 'turntable'\n this._active = controllers.turntable\n }\n this.modes = this._controllerNames\n this.computedMatrix = this._active.computedMatrix\n this.computedEye = this._active.computedEye\n this.computedUp = this._active.computedUp\n this.computedCenter = this._active.computedCenter\n this.computedRadius = this._active.computedRadius\n}\n\nvar proto = ViewController.prototype\n\nproto.flush = function(a0) {\n var cc = this._controllerList\n for (var i = 0; i < cc.length; ++i) {\n cc[i].flush(a0)\n }\n}\nproto.idle = function(a0) {\n var cc = this._controllerList\n for (var i = 0; i < cc.length; ++i) {\n cc[i].idle(a0)\n }\n}\nproto.lookAt = function(a0, a1, a2, a3) {\n var cc = this._controllerList\n for (var i = 0; i < cc.length; ++i) {\n cc[i].lookAt(a0, a1, a2, a3)\n }\n}\nproto.rotate = function(a0, a1, a2, a3) {\n var cc = this._controllerList\n for (var i = 0; i < cc.length; ++i) {\n cc[i].rotate(a0, a1, a2, a3)\n }\n}\nproto.pan = function(a0, a1, a2, a3) {\n var cc = this._controllerList\n for (var i = 0; i < cc.length; ++i) {\n cc[i].pan(a0, a1, a2, a3)\n }\n}\nproto.translate = function(a0, a1, a2, a3) {\n var cc = this._controllerList\n for (var i = 0; i < cc.length; ++i) {\n cc[i].translate(a0, a1, a2, a3)\n }\n}\nproto.setMatrix = function(a0, a1) {\n var cc = this._controllerList\n for (var i = 0; i < cc.length; ++i) {\n cc[i].setMatrix(a0, a1)\n }\n}\nproto.setDistanceLimits = function(a0, a1) {\n var cc = this._controllerList\n for (var i = 0; i < cc.length; ++i) {\n cc[i].setDistanceLimits(a0, a1)\n }\n}\nproto.setDistance = function(a0, a1) {\n var cc = this._controllerList\n for (var i = 0; i < cc.length; ++i) {\n cc[i].setDistance(a0, a1)\n }\n}\n\nproto.recalcMatrix = function(t) {\n this._active.recalcMatrix(t)\n}\n\nproto.getDistance = function(t) {\n return this._active.getDistance(t)\n}\nproto.getDistanceLimits = function(out) {\n return this._active.getDistanceLimits(out)\n}\n\nproto.lastT = function() {\n return this._active.lastT()\n}\n\nproto.setMode = function(mode) {\n if(mode === this._mode) {\n return\n }\n var idx = this._controllerNames.indexOf(mode)\n if(idx < 0) {\n return\n }\n var prev = this._active\n var next = this._controllerList[idx]\n var lastT = Math.max(prev.lastT(), next.lastT())\n\n prev.recalcMatrix(lastT)\n next.setMatrix(lastT, prev.computedMatrix)\n\n this._active = next\n this._mode = mode\n\n //Update matrix properties\n this.computedMatrix = this._active.computedMatrix\n this.computedEye = this._active.computedEye\n this.computedUp = this._active.computedUp\n this.computedCenter = this._active.computedCenter\n this.computedRadius = this._active.computedRadius\n}\n\nproto.getMode = function() {\n return this._mode\n}\n\nfunction createViewController(options) {\n options = options || {}\n\n var eye = options.eye || [0,0,1]\n var center = options.center || [0,0,0]\n var up = options.up || [0,1,0]\n var limits = options.distanceLimits || [0, Infinity]\n var mode = options.mode || 'turntable'\n\n var turntable = createTurntable()\n var orbit = createOrbit()\n var matrix = createMatrix()\n\n turntable.setDistanceLimits(limits[0], limits[1])\n turntable.lookAt(0, eye, center, up)\n orbit.setDistanceLimits(limits[0], limits[1])\n orbit.lookAt(0, eye, center, up)\n matrix.setDistanceLimits(limits[0], limits[1])\n matrix.lookAt(0, eye, center, up)\n\n return new ViewController({\n turntable: turntable,\n orbit: orbit,\n matrix: matrix\n }, mode)\n}\n\n/***/ }),\n\n/***/ 7169:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar weakMap = typeof WeakMap === 'undefined' ? __webpack_require__(1538) : WeakMap\nvar createBuffer = __webpack_require__(2762)\nvar createVAO = __webpack_require__(8116)\n\nvar TriangleCache = new weakMap()\n\nfunction createABigTriangle(gl) {\n\n var triangleVAO = TriangleCache.get(gl)\n var handle = triangleVAO && (triangleVAO._triangleBuffer.handle || triangleVAO._triangleBuffer.buffer)\n if(!handle || !gl.isBuffer(handle)) {\n var buf = createBuffer(gl, new Float32Array([-1, -1, -1, 4, 4, -1]))\n triangleVAO = createVAO(gl, [\n { buffer: buf,\n type: gl.FLOAT,\n size: 2\n }\n ])\n triangleVAO._triangleBuffer = buf\n TriangleCache.set(gl, triangleVAO)\n }\n triangleVAO.bind()\n gl.drawArrays(gl.TRIANGLES, 0, 3)\n triangleVAO.unbind()\n}\n\nmodule.exports = createABigTriangle\n\n\n/***/ }),\n\n/***/ 1085:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar padLeft = __webpack_require__(1371)\n\nmodule.exports = addLineNumbers\nfunction addLineNumbers (string, start, delim) {\n start = typeof start === 'number' ? start : 1\n delim = delim || ': '\n\n var lines = string.split(/\\r?\\n/)\n var totalDigits = String(lines.length + start - 1).length\n return lines.map(function (line, i) {\n var c = i + start\n var digits = String(c).length\n var prefix = padLeft(c, totalDigits - digits)\n return prefix + delim + line\n }).join('\\n')\n}\n\n\n/***/ }),\n\n/***/ 3952:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = affineHull\n\nvar orient = __webpack_require__(3250)\n\nfunction linearlyIndependent(points, d) {\n var nhull = new Array(d+1)\n for(var i=0; i 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n\n\n/***/ }),\n\n/***/ 3865:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar rationalize = __webpack_require__(869)\n\nmodule.exports = add\n\nfunction add(a, b) {\n return rationalize(\n a[0].mul(b[1]).add(b[0].mul(a[1])),\n a[1].mul(b[1]))\n}\n\n\n/***/ }),\n\n/***/ 1318:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nmodule.exports = cmp\n\nfunction cmp(a, b) {\n return a[0].mul(b[1]).cmp(b[0].mul(a[1]))\n}\n\n\n/***/ }),\n\n/***/ 8697:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar rationalize = __webpack_require__(869)\n\nmodule.exports = div\n\nfunction div(a, b) {\n return rationalize(a[0].mul(b[1]), a[1].mul(b[0]))\n}\n\n\n/***/ }),\n\n/***/ 7842:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar isRat = __webpack_require__(6330)\nvar isBN = __webpack_require__(1533)\nvar num2bn = __webpack_require__(2651)\nvar str2bn = __webpack_require__(4387)\nvar rationalize = __webpack_require__(869)\nvar div = __webpack_require__(8697)\n\nmodule.exports = makeRational\n\nfunction makeRational(numer, denom) {\n if(isRat(numer)) {\n if(denom) {\n return div(numer, makeRational(denom))\n }\n return [numer[0].clone(), numer[1].clone()]\n }\n var shift = 0\n var a, b\n if(isBN(numer)) {\n a = numer.clone()\n } else if(typeof numer === 'string') {\n a = str2bn(numer)\n } else if(numer === 0) {\n return [num2bn(0), num2bn(1)]\n } else if(numer === Math.floor(numer)) {\n a = num2bn(numer)\n } else {\n while(numer !== Math.floor(numer)) {\n numer = numer * Math.pow(2, 256)\n shift -= 256\n }\n a = num2bn(numer)\n }\n if(isRat(denom)) {\n a.mul(denom[1])\n b = denom[0].clone()\n } else if(isBN(denom)) {\n b = denom.clone()\n } else if(typeof denom === 'string') {\n b = str2bn(denom)\n } else if(!denom) {\n b = num2bn(1)\n } else if(denom === Math.floor(denom)) {\n b = num2bn(denom)\n } else {\n while(denom !== Math.floor(denom)) {\n denom = denom * Math.pow(2, 256)\n shift += 256\n }\n b = num2bn(denom)\n }\n if(shift > 0) {\n a = a.ushln(shift)\n } else if(shift < 0) {\n b = b.ushln(-shift)\n }\n return rationalize(a, b)\n}\n\n\n/***/ }),\n\n/***/ 6330:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar isBN = __webpack_require__(1533)\n\nmodule.exports = isRat\n\nfunction isRat(x) {\n return Array.isArray(x) && x.length === 2 && isBN(x[0]) && isBN(x[1])\n}\n\n\n/***/ }),\n\n/***/ 5716:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar BN = __webpack_require__(6859)\n\nmodule.exports = sign\n\nfunction sign (x) {\n return x.cmp(new BN(0))\n}\n\n\n/***/ }),\n\n/***/ 1369:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar sign = __webpack_require__(5716)\n\nmodule.exports = bn2num\n\n//TODO: Make this better\nfunction bn2num(b) {\n var l = b.length\n var words = b.words\n var out = 0\n if (l === 1) {\n out = words[0]\n } else if (l === 2) {\n out = words[0] + (words[1] * 0x4000000)\n } else {\n for (var i = 0; i < l; i++) {\n var w = words[i]\n out += w * Math.pow(0x4000000, i)\n }\n }\n return sign(b) * out\n}\n\n\n/***/ }),\n\n/***/ 4025:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar db = __webpack_require__(2361)\nvar ctz = (__webpack_require__(8828).countTrailingZeros)\n\nmodule.exports = ctzNumber\n\n//Counts the number of trailing zeros\nfunction ctzNumber(x) {\n var l = ctz(db.lo(x))\n if(l < 32) {\n return l\n }\n var h = ctz(db.hi(x))\n if(h > 20) {\n return 52\n }\n return h + 32\n}\n\n\n/***/ }),\n\n/***/ 1533:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar BN = __webpack_require__(6859)\n\nmodule.exports = isBN\n\n//Test if x is a bignumber\n//FIXME: obviously this is the wrong way to do it\nfunction isBN(x) {\n return x && typeof x === 'object' && Boolean(x.words)\n}\n\n\n/***/ }),\n\n/***/ 2651:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar BN = __webpack_require__(6859)\nvar db = __webpack_require__(2361)\n\nmodule.exports = num2bn\n\nfunction num2bn(x) {\n var e = db.exponent(x)\n if(e < 52) {\n return new BN(x)\n } else {\n return (new BN(x * Math.pow(2, 52-e))).ushln(e-52)\n }\n}\n\n\n/***/ }),\n\n/***/ 869:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar num2bn = __webpack_require__(2651)\nvar sign = __webpack_require__(5716)\n\nmodule.exports = rationalize\n\nfunction rationalize(numer, denom) {\n var snumer = sign(numer)\n var sdenom = sign(denom)\n if(snumer === 0) {\n return [num2bn(0), num2bn(1)]\n }\n if(sdenom === 0) {\n return [num2bn(0), num2bn(0)]\n }\n if(sdenom < 0) {\n numer = numer.neg()\n denom = denom.neg()\n }\n var d = numer.gcd(denom)\n if(d.cmpn(1)) {\n return [ numer.div(d), denom.div(d) ]\n }\n return [ numer, denom ]\n}\n\n\n/***/ }),\n\n/***/ 4387:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar BN = __webpack_require__(6859)\n\nmodule.exports = str2BN\n\nfunction str2BN(x) {\n return new BN(x)\n}\n\n\n/***/ }),\n\n/***/ 6504:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar rationalize = __webpack_require__(869)\n\nmodule.exports = mul\n\nfunction mul(a, b) {\n return rationalize(a[0].mul(b[0]), a[1].mul(b[1]))\n}\n\n\n/***/ }),\n\n/***/ 7721:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar bnsign = __webpack_require__(5716)\n\nmodule.exports = sign\n\nfunction sign(x) {\n return bnsign(x[0]) * bnsign(x[1])\n}\n\n\n/***/ }),\n\n/***/ 5572:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar rationalize = __webpack_require__(869)\n\nmodule.exports = sub\n\nfunction sub(a, b) {\n return rationalize(a[0].mul(b[1]).sub(a[1].mul(b[0])), a[1].mul(b[1]))\n}\n\n\n/***/ }),\n\n/***/ 946:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar bn2num = __webpack_require__(1369)\nvar ctz = __webpack_require__(4025)\n\nmodule.exports = roundRat\n\n// Round a rational to the closest float\nfunction roundRat (f) {\n var a = f[0]\n var b = f[1]\n if (a.cmpn(0) === 0) {\n return 0\n }\n var h = a.abs().divmod(b.abs())\n var iv = h.div\n var x = bn2num(iv)\n var ir = h.mod\n var sgn = (a.negative !== b.negative) ? -1 : 1\n if (ir.cmpn(0) === 0) {\n return sgn * x\n }\n if (x) {\n var s = ctz(x) + 4\n var y = bn2num(ir.ushln(s).divRound(b))\n return sgn * (x + y * Math.pow(2, -s))\n } else {\n var ybits = b.bitLength() - ir.bitLength() + 53\n var y = bn2num(ir.ushln(ybits).divRound(b))\n if (ybits < 1023) {\n return sgn * y * Math.pow(2, -ybits)\n }\n y *= Math.pow(2, -1023)\n return sgn * y * Math.pow(2, 1023 - ybits)\n }\n}\n\n\n/***/ }),\n\n/***/ 2478:\n/***/ (function(module) {\n\n\"use strict\";\n\n\n// (a, y, c, l, h) = (array, y[, cmp, lo, hi])\n\nfunction ge(a, y, c, l, h) {\n var i = h + 1;\n while (l <= h) {\n var m = (l + h) >>> 1, x = a[m];\n var p = (c !== undefined) ? c(x, y) : (x - y);\n if (p >= 0) { i = m; h = m - 1 } else { l = m + 1 }\n }\n return i;\n};\n\nfunction gt(a, y, c, l, h) {\n var i = h + 1;\n while (l <= h) {\n var m = (l + h) >>> 1, x = a[m];\n var p = (c !== undefined) ? c(x, y) : (x - y);\n if (p > 0) { i = m; h = m - 1 } else { l = m + 1 }\n }\n return i;\n};\n\nfunction lt(a, y, c, l, h) {\n var i = l - 1;\n while (l <= h) {\n var m = (l + h) >>> 1, x = a[m];\n var p = (c !== undefined) ? c(x, y) : (x - y);\n if (p < 0) { i = m; l = m + 1 } else { h = m - 1 }\n }\n return i;\n};\n\nfunction le(a, y, c, l, h) {\n var i = l - 1;\n while (l <= h) {\n var m = (l + h) >>> 1, x = a[m];\n var p = (c !== undefined) ? c(x, y) : (x - y);\n if (p <= 0) { i = m; l = m + 1 } else { h = m - 1 }\n }\n return i;\n};\n\nfunction eq(a, y, c, l, h) {\n while (l <= h) {\n var m = (l + h) >>> 1, x = a[m];\n var p = (c !== undefined) ? c(x, y) : (x - y);\n if (p === 0) { return m }\n if (p <= 0) { l = m + 1 } else { h = m - 1 }\n }\n return -1;\n};\n\nfunction norm(a, y, c, l, h, f) {\n if (typeof c === 'function') {\n return f(a, y, c, (l === undefined) ? 0 : l | 0, (h === undefined) ? a.length - 1 : h | 0);\n }\n return f(a, y, undefined, (c === undefined) ? 0 : c | 0, (l === undefined) ? a.length - 1 : l | 0);\n}\n\nmodule.exports = {\n ge: function(a, y, c, l, h) { return norm(a, y, c, l, h, ge)},\n gt: function(a, y, c, l, h) { return norm(a, y, c, l, h, gt)},\n lt: function(a, y, c, l, h) { return norm(a, y, c, l, h, lt)},\n le: function(a, y, c, l, h) { return norm(a, y, c, l, h, le)},\n eq: function(a, y, c, l, h) { return norm(a, y, c, l, h, eq)}\n}\n\n\n/***/ }),\n\n/***/ 8828:\n/***/ (function(__unused_webpack_module, exports) {\n\n\"use strict\";\n/**\n * Bit twiddling hacks for JavaScript.\n *\n * Author: Mikola Lysenko\n *\n * Ported from Stanford bit twiddling hack library:\n * http://graphics.stanford.edu/~seander/bithacks.html\n */\n\n \"use restrict\";\n\n//Number of bits in an integer\nvar INT_BITS = 32;\n\n//Constants\nexports.INT_BITS = INT_BITS;\nexports.INT_MAX = 0x7fffffff;\nexports.INT_MIN = -1<<(INT_BITS-1);\n\n//Returns -1, 0, +1 depending on sign of x\nexports.sign = function(v) {\n return (v > 0) - (v < 0);\n}\n\n//Computes absolute value of integer\nexports.abs = function(v) {\n var mask = v >> (INT_BITS-1);\n return (v ^ mask) - mask;\n}\n\n//Computes minimum of integers x and y\nexports.min = function(x, y) {\n return y ^ ((x ^ y) & -(x < y));\n}\n\n//Computes maximum of integers x and y\nexports.max = function(x, y) {\n return x ^ ((x ^ y) & -(x < y));\n}\n\n//Checks if a number is a power of two\nexports.isPow2 = function(v) {\n return !(v & (v-1)) && (!!v);\n}\n\n//Computes log base 2 of v\nexports.log2 = function(v) {\n var r, shift;\n r = (v > 0xFFFF) << 4; v >>>= r;\n shift = (v > 0xFF ) << 3; v >>>= shift; r |= shift;\n shift = (v > 0xF ) << 2; v >>>= shift; r |= shift;\n shift = (v > 0x3 ) << 1; v >>>= shift; r |= shift;\n return r | (v >> 1);\n}\n\n//Computes log base 10 of v\nexports.log10 = function(v) {\n return (v >= 1000000000) ? 9 : (v >= 100000000) ? 8 : (v >= 10000000) ? 7 :\n (v >= 1000000) ? 6 : (v >= 100000) ? 5 : (v >= 10000) ? 4 :\n (v >= 1000) ? 3 : (v >= 100) ? 2 : (v >= 10) ? 1 : 0;\n}\n\n//Counts number of bits\nexports.popCount = function(v) {\n v = v - ((v >>> 1) & 0x55555555);\n v = (v & 0x33333333) + ((v >>> 2) & 0x33333333);\n return ((v + (v >>> 4) & 0xF0F0F0F) * 0x1010101) >>> 24;\n}\n\n//Counts number of trailing zeros\nfunction countTrailingZeros(v) {\n var c = 32;\n v &= -v;\n if (v) c--;\n if (v & 0x0000FFFF) c -= 16;\n if (v & 0x00FF00FF) c -= 8;\n if (v & 0x0F0F0F0F) c -= 4;\n if (v & 0x33333333) c -= 2;\n if (v & 0x55555555) c -= 1;\n return c;\n}\nexports.countTrailingZeros = countTrailingZeros;\n\n//Rounds to next power of 2\nexports.nextPow2 = function(v) {\n v += v === 0;\n --v;\n v |= v >>> 1;\n v |= v >>> 2;\n v |= v >>> 4;\n v |= v >>> 8;\n v |= v >>> 16;\n return v + 1;\n}\n\n//Rounds down to previous power of 2\nexports.prevPow2 = function(v) {\n v |= v >>> 1;\n v |= v >>> 2;\n v |= v >>> 4;\n v |= v >>> 8;\n v |= v >>> 16;\n return v - (v>>>1);\n}\n\n//Computes parity of word\nexports.parity = function(v) {\n v ^= v >>> 16;\n v ^= v >>> 8;\n v ^= v >>> 4;\n v &= 0xf;\n return (0x6996 >>> v) & 1;\n}\n\nvar REVERSE_TABLE = new Array(256);\n\n(function(tab) {\n for(var i=0; i<256; ++i) {\n var v = i, r = i, s = 7;\n for (v >>>= 1; v; v >>>= 1) {\n r <<= 1;\n r |= v & 1;\n --s;\n }\n tab[i] = (r << s) & 0xff;\n }\n})(REVERSE_TABLE);\n\n//Reverse bits in a 32 bit word\nexports.reverse = function(v) {\n return (REVERSE_TABLE[ v & 0xff] << 24) |\n (REVERSE_TABLE[(v >>> 8) & 0xff] << 16) |\n (REVERSE_TABLE[(v >>> 16) & 0xff] << 8) |\n REVERSE_TABLE[(v >>> 24) & 0xff];\n}\n\n//Interleave bits of 2 coordinates with 16 bits. Useful for fast quadtree codes\nexports.interleave2 = function(x, y) {\n x &= 0xFFFF;\n x = (x | (x << 8)) & 0x00FF00FF;\n x = (x | (x << 4)) & 0x0F0F0F0F;\n x = (x | (x << 2)) & 0x33333333;\n x = (x | (x << 1)) & 0x55555555;\n\n y &= 0xFFFF;\n y = (y | (y << 8)) & 0x00FF00FF;\n y = (y | (y << 4)) & 0x0F0F0F0F;\n y = (y | (y << 2)) & 0x33333333;\n y = (y | (y << 1)) & 0x55555555;\n\n return x | (y << 1);\n}\n\n//Extracts the nth interleaved component\nexports.deinterleave2 = function(v, n) {\n v = (v >>> n) & 0x55555555;\n v = (v | (v >>> 1)) & 0x33333333;\n v = (v | (v >>> 2)) & 0x0F0F0F0F;\n v = (v | (v >>> 4)) & 0x00FF00FF;\n v = (v | (v >>> 16)) & 0x000FFFF;\n return (v << 16) >> 16;\n}\n\n\n//Interleave bits of 3 coordinates, each with 10 bits. Useful for fast octree codes\nexports.interleave3 = function(x, y, z) {\n x &= 0x3FF;\n x = (x | (x<<16)) & 4278190335;\n x = (x | (x<<8)) & 251719695;\n x = (x | (x<<4)) & 3272356035;\n x = (x | (x<<2)) & 1227133513;\n\n y &= 0x3FF;\n y = (y | (y<<16)) & 4278190335;\n y = (y | (y<<8)) & 251719695;\n y = (y | (y<<4)) & 3272356035;\n y = (y | (y<<2)) & 1227133513;\n x |= (y << 1);\n \n z &= 0x3FF;\n z = (z | (z<<16)) & 4278190335;\n z = (z | (z<<8)) & 251719695;\n z = (z | (z<<4)) & 3272356035;\n z = (z | (z<<2)) & 1227133513;\n \n return x | (z << 2);\n}\n\n//Extracts nth interleaved component of a 3-tuple\nexports.deinterleave3 = function(v, n) {\n v = (v >>> n) & 1227133513;\n v = (v | (v>>>2)) & 3272356035;\n v = (v | (v>>>4)) & 251719695;\n v = (v | (v>>>8)) & 4278190335;\n v = (v | (v>>>16)) & 0x3FF;\n return (v<<22)>>22;\n}\n\n//Computes next combination in colexicographic order (this is mistakenly called nextPermutation on the bit twiddling hacks page)\nexports.nextCombination = function(v) {\n var t = v | (v - 1);\n return (t + 1) | (((~t & -~t) - 1) >>> (countTrailingZeros(v) + 1));\n}\n\n\n\n/***/ }),\n\n/***/ 6859:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n/* module decorator */ module = __webpack_require__.nmd(module);\n(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = (__webpack_require__(7790).Buffer);\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this.strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})( false || module, this);\n\n\n/***/ }),\n\n/***/ 6204:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nmodule.exports = boundary\n\nfunction boundary (cells) {\n var i, j, k\n var n = cells.length\n var sz = 0\n for (i = 0; i < n; ++i) {\n sz += cells[i].length\n }\n var result = new Array(sz)\n var ptr = 0\n for (i = 0; i < n; ++i) {\n var c = cells[i]\n var d = c.length\n for (j = 0; j < d; ++j) {\n var b = result[ptr++] = new Array(d - 1)\n var p = 0\n for (k = 0; k < d; ++k) {\n if (k === j) {\n continue\n }\n b[p++] = c[k]\n }\n if (j & 1) {\n var tmp = b[1]\n b[1] = b[0]\n b[0] = tmp\n }\n }\n }\n return result\n}\n\n\n/***/ }),\n\n/***/ 6867:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = boxIntersectWrapper\n\nvar pool = __webpack_require__(1888)\nvar sweep = __webpack_require__(855)\nvar boxIntersectIter = __webpack_require__(7150)\n\nfunction boxEmpty(d, box) {\n for(var j=0; j>>1\n if(d <= 0) {\n return\n }\n\n var retval\n\n //Convert red boxes\n var redList = pool.mallocDouble(2*d*n)\n var redIds = pool.mallocInt32(n)\n n = convertBoxes(red, d, redList, redIds)\n\n if(n > 0) {\n if(d === 1 && full) {\n //Special case: 1d complete\n sweep.init(n)\n retval = sweep.sweepComplete(\n d, visit,\n 0, n, redList, redIds,\n 0, n, redList, redIds)\n } else {\n\n //Convert blue boxes\n var blueList = pool.mallocDouble(2*d*m)\n var blueIds = pool.mallocInt32(m)\n m = convertBoxes(blue, d, blueList, blueIds)\n\n if(m > 0) {\n sweep.init(n+m)\n\n if(d === 1) {\n //Special case: 1d bipartite\n retval = sweep.sweepBipartite(\n d, visit,\n 0, n, redList, redIds,\n 0, m, blueList, blueIds)\n } else {\n //General case: d>1\n retval = boxIntersectIter(\n d, visit, full,\n n, redList, redIds,\n m, blueList, blueIds)\n }\n\n pool.free(blueList)\n pool.free(blueIds)\n }\n }\n\n pool.free(redList)\n pool.free(redIds)\n }\n\n return retval\n}\n\n\nvar RESULT\n\nfunction appendItem(i,j) {\n RESULT.push([i,j])\n}\n\nfunction intersectFullArray(x) {\n RESULT = []\n boxIntersect(x, x, appendItem, true)\n return RESULT\n}\n\nfunction intersectBipartiteArray(x, y) {\n RESULT = []\n boxIntersect(x, y, appendItem, false)\n return RESULT\n}\n\n//User-friendly wrapper, handle full input and no-visitor cases\nfunction boxIntersectWrapper(arg0, arg1, arg2) {\n switch(arguments.length) {\n case 1:\n return intersectFullArray(arg0)\n case 2:\n if(typeof arg1 === 'function') {\n return boxIntersect(arg0, arg0, arg1, true)\n } else {\n return intersectBipartiteArray(arg0, arg1)\n }\n case 3:\n return boxIntersect(arg0, arg1, arg2, false)\n default:\n throw new Error('box-intersect: Invalid arguments')\n }\n}\n\n/***/ }),\n\n/***/ 2455:\n/***/ (function(__unused_webpack_module, exports) {\n\n\"use strict\";\n\n\nfunction full() {\n function bruteForceRedFull(d, ax, vv, rs, re, rb, ri, bs, be, bb, bi) {\n var es = 2 * d\n for (var i = rs, rp = es * rs; i < re; ++i, rp += es) {\n var x0 = rb[ax + rp], x1 = rb[ax + rp + d], xi = ri[i]\n Q: for (var j = bs, bp = es * bs; j < be; ++j, bp += es) {\n var y0 = bb[ax + bp], y1 = bb[ax + bp + d], yi = bi[j]\n if (y1 < x0 || x1 < y0) continue\n for (var k = ax + 1; k < d; ++k) {\n var r0 = rb[k + rp], r1 = rb[k + d + rp], b0 = bb[k + bp], b1 = bb[k + d + bp]\n if (r1 < b0 || b1 < r0) continue Q\n }\n var rv = vv(xi, yi)\n if (rv !== void 0) return rv\n }\n }\n }\n function bruteForceBlueFull(d, ax, vv, rs, re, rb, ri, bs, be, bb, bi) {\n var es = 2 * d\n for (var j = bs, bp = es * bs; j < be; ++j, bp += es) {\n var y0 = bb[ax + bp], y1 = bb[ax + bp + d], yi = bi[j]\n Q: for (var i = rs, rp = es * rs; i < re; ++i, rp += es) {\n var x0 = rb[ax + rp], x1 = rb[ax + rp + d], xi = ri[i]\n if (y1 < x0 || x1 < y0) continue\n for (var k = ax + 1; k < d; ++k) {\n var r0 = rb[k + rp], r1 = rb[k + d + rp], b0 = bb[k + bp], b1 = bb[k + d + bp]\n if (r1 < b0 || b1 < r0) continue Q\n }\n var rv = vv(xi, yi)\n if (rv !== void 0) return rv\n }\n }\n }\n function bruteForceFull(d, ax, vv, rs, re, rb, ri, bs, be, bb, bi) {\n if (re - rs > be - bs) {\n return bruteForceRedFull(d, ax, vv, rs, re, rb, ri, bs, be, bb, bi)\n }\n else {\n return bruteForceBlueFull(d, ax, vv, rs, re, rb, ri, bs, be, bb, bi)\n }\n }\n return bruteForceFull\n}\n\nfunction partial() {\n function bruteForceRedFlip(d, ax, vv, rs, re, rb, ri, bs, be, bb, bi) {\n var es = 2 * d\n for (var i = rs, rp = es * rs; i < re; ++i, rp += es) {\n var x0 = rb[ax + rp], x1 = rb[ax + rp + d], xi = ri[i]\n Q: for (var j = bs, bp = es * bs; j < be; ++j, bp += es) {\n var y0 = bb[ax + bp], yi = bi[j]\n if (y0 <= x0 || x1 < y0) continue\n for (var k = ax + 1; k < d; ++k) {\n var r0 = rb[k + rp], r1 = rb[k + d + rp], b0 = bb[k + bp], b1 = bb[k + d + bp]\n if (r1 < b0 || b1 < r0) continue Q\n }\n var rv = vv(yi, xi)\n if (rv !== void 0) return rv\n }\n }\n }\n function bruteForceRed(d, ax, vv, rs, re, rb, ri, bs, be, bb, bi) {\n var es = 2 * d\n for (var i = rs, rp = es * rs; i < re; ++i, rp += es) {\n var x0 = rb[ax + rp], x1 = rb[ax + rp + d], xi = ri[i]\n Q: for (var j = bs, bp = es * bs; j < be; ++j, bp += es) {\n var y0 = bb[ax + bp], yi = bi[j]\n if (y0 < x0 || x1 < y0) continue\n for (var k = ax + 1; k < d; ++k) {\n var r0 = rb[k + rp], r1 = rb[k + d + rp], b0 = bb[k + bp], b1 = bb[k + d + bp]\n if (r1 < b0 || b1 < r0) continue Q\n }\n var rv = vv(xi, yi)\n if (rv !== void 0) return rv\n }\n }\n }\n function bruteForceBlueFlip(d, ax, vv, rs, re, rb, ri, bs, be, bb, bi) {\n var es = 2 * d\n for (var j = bs, bp = es * bs; j < be; ++j, bp += es) {\n var y0 = bb[ax + bp], yi = bi[j]\n Q: for (var i = rs, rp = es * rs; i < re; ++i, rp += es) {\n var x0 = rb[ax + rp], x1 = rb[ax + rp + d], xi = ri[i]\n if (y0 <= x0 || x1 < y0) continue\n for (var k = ax + 1; k < d; ++k) {\n var r0 = rb[k + rp], r1 = rb[k + d + rp], b0 = bb[k + bp], b1 = bb[k + d + bp]\n if (r1 < b0 || b1 < r0) continue Q\n }\n var rv = vv(yi, xi)\n if (rv !== void 0) return rv\n }\n }\n }\n function bruteForceBlue(d, ax, vv, rs, re, rb, ri, bs, be, bb, bi) {\n var es = 2 * d\n for (var j = bs, bp = es * bs; j < be; ++j, bp += es) {\n var y0 = bb[ax + bp], yi = bi[j]\n Q: for (var i = rs, rp = es * rs; i < re; ++i, rp += es) {\n var x0 = rb[ax + rp], x1 = rb[ax + rp + d], xi = ri[i]\n if (y0 < x0 || x1 < y0) continue\n for (var k = ax + 1; k < d; ++k) {\n var r0 = rb[k + rp], r1 = rb[k + d + rp], b0 = bb[k + bp], b1 = bb[k + d + bp]\n if (r1 < b0 || b1 < r0) continue Q\n }\n var rv = vv(xi, yi)\n if (rv !== void 0) return rv\n }\n }\n }\n function bruteForcePartial(d, ax, vv, fp, rs, re, rb, ri, bs, be, bb, bi) {\n if (re - rs > be - bs) {\n if (fp) {\n return bruteForceRedFlip(d, ax, vv, rs, re, rb, ri, bs, be, bb, bi)\n }\n else {\n return bruteForceRed(d, ax, vv, rs, re, rb, ri, bs, be, bb, bi)\n }\n }\n else {\n if (fp) {\n return bruteForceBlueFlip(d, ax, vv, rs, re, rb, ri, bs, be, bb, bi)\n }\n else {\n return bruteForceBlue(d, ax, vv, rs, re, rb, ri, bs, be, bb, bi)\n }\n }\n }\n return bruteForcePartial\n}\n\nfunction bruteForcePlanner(isFull) {\n return isFull ? full() : partial()\n\n}\n\nexports.partial = bruteForcePlanner(false)\nexports.full = bruteForcePlanner(true)\n\n/***/ }),\n\n/***/ 7150:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = boxIntersectIter\n\nvar pool = __webpack_require__(1888)\nvar bits = __webpack_require__(8828)\nvar bruteForce = __webpack_require__(2455)\nvar bruteForcePartial = bruteForce.partial\nvar bruteForceFull = bruteForce.full\nvar sweep = __webpack_require__(855)\nvar findMedian = __webpack_require__(3545)\nvar genPartition = __webpack_require__(8105)\n\n//Twiddle parameters\nvar BRUTE_FORCE_CUTOFF = 128 //Cut off for brute force search\nvar SCAN_CUTOFF = (1<<22) //Cut off for two way scan\nvar SCAN_COMPLETE_CUTOFF = (1<<22)\n\n//Partition functions\nvar partitionInteriorContainsInterval = genPartition(\n '!(lo>=p0)&&!(p1>=hi)')\n\nvar partitionStartEqual = genPartition(\n 'lo===p0')\n\nvar partitionStartLessThan = genPartition(\n 'lo 0) {\n top -= 1\n\n var iptr = top * IFRAME_SIZE\n var axis = BOX_ISTACK[iptr]\n var redStart = BOX_ISTACK[iptr+1]\n var redEnd = BOX_ISTACK[iptr+2]\n var blueStart = BOX_ISTACK[iptr+3]\n var blueEnd = BOX_ISTACK[iptr+4]\n var state = BOX_ISTACK[iptr+5]\n\n var dptr = top * DFRAME_SIZE\n var lo = BOX_DSTACK[dptr]\n var hi = BOX_DSTACK[dptr+1]\n\n //Unpack state info\n var flip = (state & 1)\n var full = !!(state & 16)\n\n //Unpack indices\n var red = xBoxes\n var redIndex = xIndex\n var blue = yBoxes\n var blueIndex = yIndex\n if(flip) {\n red = yBoxes\n redIndex = yIndex\n blue = xBoxes\n blueIndex = xIndex\n }\n\n if(state & 2) {\n redEnd = partitionStartLessThan(\n d, axis,\n redStart, redEnd, red, redIndex,\n hi)\n if(redStart >= redEnd) {\n continue\n }\n }\n if(state & 4) {\n redStart = partitionEndLessThanEqual(\n d, axis,\n redStart, redEnd, red, redIndex,\n lo)\n if(redStart >= redEnd) {\n continue\n }\n }\n\n var redCount = redEnd - redStart\n var blueCount = blueEnd - blueStart\n\n if(full) {\n if(d * redCount * (redCount + blueCount) < SCAN_COMPLETE_CUTOFF) {\n retval = sweep.scanComplete(\n d, axis, visit,\n redStart, redEnd, red, redIndex,\n blueStart, blueEnd, blue, blueIndex)\n if(retval !== void 0) {\n return retval\n }\n continue\n }\n } else {\n if(d * Math.min(redCount, blueCount) < BRUTE_FORCE_CUTOFF) {\n //If input small, then use brute force\n retval = bruteForcePartial(\n d, axis, visit, flip,\n redStart, redEnd, red, redIndex,\n blueStart, blueEnd, blue, blueIndex)\n if(retval !== void 0) {\n return retval\n }\n continue\n } else if(d * redCount * blueCount < SCAN_CUTOFF) {\n //If input medium sized, then use sweep and prune\n retval = sweep.scanBipartite(\n d, axis, visit, flip,\n redStart, redEnd, red, redIndex,\n blueStart, blueEnd, blue, blueIndex)\n if(retval !== void 0) {\n return retval\n }\n continue\n }\n }\n\n //First, find all red intervals whose interior contains (lo,hi)\n var red0 = partitionInteriorContainsInterval(\n d, axis,\n redStart, redEnd, red, redIndex,\n lo, hi)\n\n //Lower dimensional case\n if(redStart < red0) {\n\n if(d * (red0 - redStart) < BRUTE_FORCE_CUTOFF) {\n //Special case for small inputs: use brute force\n retval = bruteForceFull(\n d, axis+1, visit,\n redStart, red0, red, redIndex,\n blueStart, blueEnd, blue, blueIndex)\n if(retval !== void 0) {\n return retval\n }\n } else if(axis === d-2) {\n if(flip) {\n retval = sweep.sweepBipartite(\n d, visit,\n blueStart, blueEnd, blue, blueIndex,\n redStart, red0, red, redIndex)\n } else {\n retval = sweep.sweepBipartite(\n d, visit,\n redStart, red0, red, redIndex,\n blueStart, blueEnd, blue, blueIndex)\n }\n if(retval !== void 0) {\n return retval\n }\n } else {\n iterPush(top++,\n axis+1,\n redStart, red0,\n blueStart, blueEnd,\n flip,\n -Infinity, Infinity)\n iterPush(top++,\n axis+1,\n blueStart, blueEnd,\n redStart, red0,\n flip^1,\n -Infinity, Infinity)\n }\n }\n\n //Divide and conquer phase\n if(red0 < redEnd) {\n\n //Cut blue into 3 parts:\n //\n // Points < mid point\n // Points = mid point\n // Points > mid point\n //\n var blue0 = findMedian(\n d, axis,\n blueStart, blueEnd, blue, blueIndex)\n var mid = blue[elemSize * blue0 + axis]\n var blue1 = partitionStartEqual(\n d, axis,\n blue0, blueEnd, blue, blueIndex,\n mid)\n\n //Right case\n if(blue1 < blueEnd) {\n iterPush(top++,\n axis,\n red0, redEnd,\n blue1, blueEnd,\n (flip|4) + (full ? 16 : 0),\n mid, hi)\n }\n\n //Left case\n if(blueStart < blue0) {\n iterPush(top++,\n axis,\n red0, redEnd,\n blueStart, blue0,\n (flip|2) + (full ? 16 : 0),\n lo, mid)\n }\n\n //Center case (the hard part)\n if(blue0 + 1 === blue1) {\n //Optimization: Range with exactly 1 point, use a brute force scan\n if(full) {\n retval = onePointFull(\n d, axis, visit,\n red0, redEnd, red, redIndex,\n blue0, blue, blueIndex[blue0])\n } else {\n retval = onePointPartial(\n d, axis, visit, flip,\n red0, redEnd, red, redIndex,\n blue0, blue, blueIndex[blue0])\n }\n if(retval !== void 0) {\n return retval\n }\n } else if(blue0 < blue1) {\n var red1\n if(full) {\n //If full intersection, need to handle special case\n red1 = partitionContainsPoint(\n d, axis,\n red0, redEnd, red, redIndex,\n mid)\n if(red0 < red1) {\n var redX = partitionStartEqual(\n d, axis,\n red0, red1, red, redIndex,\n mid)\n if(axis === d-2) {\n //Degenerate sweep intersection:\n // [red0, redX] with [blue0, blue1]\n if(red0 < redX) {\n retval = sweep.sweepComplete(\n d, visit,\n red0, redX, red, redIndex,\n blue0, blue1, blue, blueIndex)\n if(retval !== void 0) {\n return retval\n }\n }\n\n //Normal sweep intersection:\n // [redX, red1] with [blue0, blue1]\n if(redX < red1) {\n retval = sweep.sweepBipartite(\n d, visit,\n redX, red1, red, redIndex,\n blue0, blue1, blue, blueIndex)\n if(retval !== void 0) {\n return retval\n }\n }\n } else {\n if(red0 < redX) {\n iterPush(top++,\n axis+1,\n red0, redX,\n blue0, blue1,\n 16,\n -Infinity, Infinity)\n }\n if(redX < red1) {\n iterPush(top++,\n axis+1,\n redX, red1,\n blue0, blue1,\n 0,\n -Infinity, Infinity)\n iterPush(top++,\n axis+1,\n blue0, blue1,\n redX, red1,\n 1,\n -Infinity, Infinity)\n }\n }\n }\n } else {\n if(flip) {\n red1 = partitionContainsPointProper(\n d, axis,\n red0, redEnd, red, redIndex,\n mid)\n } else {\n red1 = partitionContainsPoint(\n d, axis,\n red0, redEnd, red, redIndex,\n mid)\n }\n if(red0 < red1) {\n if(axis === d-2) {\n if(flip) {\n retval = sweep.sweepBipartite(\n d, visit,\n blue0, blue1, blue, blueIndex,\n red0, red1, red, redIndex)\n } else {\n retval = sweep.sweepBipartite(\n d, visit,\n red0, red1, red, redIndex,\n blue0, blue1, blue, blueIndex)\n }\n } else {\n iterPush(top++,\n axis+1,\n red0, red1,\n blue0, blue1,\n flip,\n -Infinity, Infinity)\n iterPush(top++,\n axis+1,\n blue0, blue1,\n red0, red1,\n flip^1,\n -Infinity, Infinity)\n }\n }\n }\n }\n }\n }\n}\n\n/***/ }),\n\n/***/ 3545:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = findMedian\n\nvar genPartition = __webpack_require__(8105)\n\nvar partitionStartLessThan = genPartition('lostart && boxes[ptr+axis] > x;\n --j, ptr-=elemSize) {\n //Swap\n var aPtr = ptr\n var bPtr = ptr+elemSize\n for(var k=0; k>> 1)\n var elemSize = 2*d\n var pivot = mid\n var value = boxes[elemSize*mid+axis]\n\n while(lo < hi) {\n if(hi - lo < PARTITION_THRESHOLD) {\n insertionSort(d, axis, lo, hi, boxes, ids)\n value = boxes[elemSize*mid+axis]\n break\n }\n\n //Select pivot using median-of-3\n var count = hi - lo\n var pivot0 = (Math.random()*count+lo)|0\n var value0 = boxes[elemSize*pivot0 + axis]\n var pivot1 = (Math.random()*count+lo)|0\n var value1 = boxes[elemSize*pivot1 + axis]\n var pivot2 = (Math.random()*count+lo)|0\n var value2 = boxes[elemSize*pivot2 + axis]\n if(value0 <= value1) {\n if(value2 >= value1) {\n pivot = pivot1\n value = value1\n } else if(value0 >= value2) {\n pivot = pivot0\n value = value0\n } else {\n pivot = pivot2\n value = value2\n }\n } else {\n if(value1 >= value2) {\n pivot = pivot1\n value = value1\n } else if(value2 >= value0) {\n pivot = pivot0\n value = value0\n } else {\n pivot = pivot2\n value = value2\n }\n }\n\n //Swap pivot to end of array\n var aPtr = elemSize * (hi-1)\n var bPtr = elemSize * pivot\n for(var i=0; i=p0)&&!(p1>=hi)': lo_lessThan_p0_and_p1_lessThan_hi\n}\n\nfunction genPartition(predicate) {\n return P2F[predicate]\n}\n\n// lo===p0\nfunction lo_equal_p0(a, b, c, d, e, f, p0) {\n for (var j = 2 * a, k = j * c, l = k, m = c, n = b, o = a + b, p = c; d > p; ++p, k += j) {\n var lo = e[k + n];\n if (lo === p0) if (m === p) m += 1, l += j; else {\n for (var s = 0; j > s; ++s) {\n var t = e[k + s]; e[k + s] = e[l], e[l++] = t\n } var u = f[p]; f[p] = f[m], f[m++] = u\n }\n }\n return m\n}\n\n// lo p; ++p, k += j) {\n var lo = e[k + n];\n if (lo < p0) if (m === p) m += 1, l += j; else {\n for (var s = 0; j > s; ++s) {\n var t = e[k + s]; e[k + s] = e[l], e[l++] = t\n } var u = f[p]; f[p] = f[m], f[m++] = u\n }\n }\n return m\n}\n\n// lo<=p0\nfunction lo_lessOrEqual_p0(a, b, c, d, e, f, p0) {\n for (var j = 2 * a, k = j * c, l = k, m = c, n = b, o = a + b, p = c; d > p; ++p, k += j) {\n var hi = e[k + o];\n if (hi <= p0) if (m === p) m += 1, l += j; else {\n for (var s = 0; j > s; ++s) {\n var t = e[k + s]; e[k + s] = e[l], e[l++] = t\n }\n var u = f[p]; f[p] = f[m], f[m++] = u\n }\n } return m\n}\n\n// hi<=p0\nfunction hi_lessOrEqual_p0(a, b, c, d, e, f, p0) {\n for (var j = 2 * a, k = j * c, l = k, m = c, n = b, o = a + b, p = c; d > p; ++p, k += j) {\n var hi = e[k + o];\n if (hi <= p0) if (m === p) m += 1, l += j; else {\n for (var s = 0; j > s; ++s) {\n var t = e[k + s]; e[k + s] = e[l], e[l++] = t\n }\n var u = f[p]; f[p] = f[m], f[m++] = u\n }\n }\n return m\n}\n\n// lo<=p0&&p0<=hi\nfunction lo_lassOrEqual_p0_and_p0_lessOrEqual_hi(a, b, c, d, e, f, p0) {\n for (var j = 2 * a, k = j * c, l = k, m = c, n = b, o = a + b, p = c; d > p; ++p, k += j) {\n var lo = e[k + n], hi = e[k + o];\n if (lo <= p0 && p0 <= hi) if (m === p) m += 1, l += j; else {\n for (var s = 0; j > s; ++s) {\n var t = e[k + s]; e[k + s] = e[l], e[l++] = t\n }\n var u = f[p]; f[p] = f[m], f[m++] = u\n }\n }\n return m\n}\n\n// lo p; ++p, k += j) {\n var lo = e[k + n], hi = e[k + o];\n if (lo < p0 && p0 <= hi) if (m === p) m += 1, l += j; else {\n for (var s = 0; j > s; ++s) {\n var t = e[k + s]; e[k + s] = e[l], e[l++] = t\n }\n var u = f[p]; f[p] = f[m], f[m++] = u\n }\n }\n return m\n}\n\n// !(lo>=p0)&&!(p1>=hi)\nfunction lo_lessThan_p0_and_p1_lessThan_hi(a, b, c, d, e, f, p0, p1) {\n for (var j = 2 * a, k = j * c, l = k, m = c, n = b, o = a + b, p = c; d > p; ++p, k += j) {\n var lo = e[k + n], hi = e[k + o];\n if (!(lo >= p0) && !(p1 >= hi)) if (m === p) m += 1, l += j; else {\n for (var s = 0; j > s; ++s) {\n var t = e[k + s]; e[k + s] = e[l], e[l++] = t\n }\n var u = f[p]; f[p] = f[m], f[m++] = u\n }\n }\n return m\n}\n\n\n/***/ }),\n\n/***/ 1811:\n/***/ (function(module) {\n\n\"use strict\";\n\n\n//This code is extracted from ndarray-sort\n//It is inlined here as a temporary workaround\n\nmodule.exports = wrapper;\n\nvar INSERT_SORT_CUTOFF = 32\n\nfunction wrapper(data, n0) {\n if (n0 <= 4*INSERT_SORT_CUTOFF) {\n insertionSort(0, n0 - 1, data);\n } else {\n quickSort(0, n0 - 1, data);\n }\n}\n\nfunction insertionSort(left, right, data) {\n var ptr = 2*(left+1)\n for(var i=left+1; i<=right; ++i) {\n var a = data[ptr++]\n var b = data[ptr++]\n var j = i\n var jptr = ptr-2\n while(j-- > left) {\n var x = data[jptr-2]\n var y = data[jptr-1]\n if(x < a) {\n break\n } else if(x === a && y < b) {\n break\n }\n data[jptr] = x\n data[jptr+1] = y\n jptr -= 2\n }\n data[jptr] = a\n data[jptr+1] = b\n }\n}\n\nfunction swap(i, j, data) {\n i *= 2\n j *= 2\n var x = data[i]\n var y = data[i+1]\n data[i] = data[j]\n data[i+1] = data[j+1]\n data[j] = x\n data[j+1] = y\n}\n\nfunction move(i, j, data) {\n i *= 2\n j *= 2\n data[i] = data[j]\n data[i+1] = data[j+1]\n}\n\nfunction rotate(i, j, k, data) {\n i *= 2\n j *= 2\n k *= 2\n var x = data[i]\n var y = data[i+1]\n data[i] = data[j]\n data[i+1] = data[j+1]\n data[j] = data[k]\n data[j+1] = data[k+1]\n data[k] = x\n data[k+1] = y\n}\n\nfunction shufflePivot(i, j, px, py, data) {\n i *= 2\n j *= 2\n data[i] = data[j]\n data[j] = px\n data[i+1] = data[j+1]\n data[j+1] = py\n}\n\nfunction compare(i, j, data) {\n i *= 2\n j *= 2\n var x = data[i],\n y = data[j]\n if(x < y) {\n return false\n } else if(x === y) {\n return data[i+1] > data[j+1]\n }\n return true\n}\n\nfunction comparePivot(i, y, b, data) {\n i *= 2\n var x = data[i]\n if(x < y) {\n return true\n } else if(x === y) {\n return data[i+1] < b\n }\n return false\n}\n\nfunction quickSort(left, right, data) {\n var sixth = (right - left + 1) / 6 | 0, \n index1 = left + sixth, \n index5 = right - sixth, \n index3 = left + right >> 1, \n index2 = index3 - sixth, \n index4 = index3 + sixth, \n el1 = index1, \n el2 = index2, \n el3 = index3, \n el4 = index4, \n el5 = index5, \n less = left + 1, \n great = right - 1, \n tmp = 0\n if(compare(el1, el2, data)) {\n tmp = el1\n el1 = el2\n el2 = tmp\n }\n if(compare(el4, el5, data)) {\n tmp = el4\n el4 = el5\n el5 = tmp\n }\n if(compare(el1, el3, data)) {\n tmp = el1\n el1 = el3\n el3 = tmp\n }\n if(compare(el2, el3, data)) {\n tmp = el2\n el2 = el3\n el3 = tmp\n }\n if(compare(el1, el4, data)) {\n tmp = el1\n el1 = el4\n el4 = tmp\n }\n if(compare(el3, el4, data)) {\n tmp = el3\n el3 = el4\n el4 = tmp\n }\n if(compare(el2, el5, data)) {\n tmp = el2\n el2 = el5\n el5 = tmp\n }\n if(compare(el2, el3, data)) {\n tmp = el2\n el2 = el3\n el3 = tmp\n }\n if(compare(el4, el5, data)) {\n tmp = el4\n el4 = el5\n el5 = tmp\n }\n\n var pivot1X = data[2*el2]\n var pivot1Y = data[2*el2+1]\n var pivot2X = data[2*el4]\n var pivot2Y = data[2*el4+1]\n\n var ptr0 = 2 * el1;\n var ptr2 = 2 * el3;\n var ptr4 = 2 * el5;\n var ptr5 = 2 * index1;\n var ptr6 = 2 * index3;\n var ptr7 = 2 * index5;\n for (var i1 = 0; i1 < 2; ++i1) {\n var x = data[ptr0+i1];\n var y = data[ptr2+i1];\n var z = data[ptr4+i1];\n data[ptr5+i1] = x;\n data[ptr6+i1] = y;\n data[ptr7+i1] = z;\n }\n\n move(index2, left, data)\n move(index4, right, data)\n for (var k = less; k <= great; ++k) {\n if (comparePivot(k, pivot1X, pivot1Y, data)) {\n if (k !== less) {\n swap(k, less, data)\n }\n ++less;\n } else {\n if (!comparePivot(k, pivot2X, pivot2Y, data)) {\n while (true) {\n if (!comparePivot(great, pivot2X, pivot2Y, data)) {\n if (--great < k) {\n break;\n }\n continue;\n } else {\n if (comparePivot(great, pivot1X, pivot1Y, data)) {\n rotate(k, less, great, data)\n ++less;\n --great;\n } else {\n swap(k, great, data)\n --great;\n }\n break;\n }\n }\n }\n }\n }\n shufflePivot(left, less-1, pivot1X, pivot1Y, data)\n shufflePivot(right, great+1, pivot2X, pivot2Y, data)\n if (less - 2 - left <= INSERT_SORT_CUTOFF) {\n insertionSort(left, less - 2, data);\n } else {\n quickSort(left, less - 2, data);\n }\n if (right - (great + 2) <= INSERT_SORT_CUTOFF) {\n insertionSort(great + 2, right, data);\n } else {\n quickSort(great + 2, right, data);\n }\n if (great - less <= INSERT_SORT_CUTOFF) {\n insertionSort(less, great, data);\n } else {\n quickSort(less, great, data);\n }\n}\n\n/***/ }),\n\n/***/ 855:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = {\n init: sqInit,\n sweepBipartite: sweepBipartite,\n sweepComplete: sweepComplete,\n scanBipartite: scanBipartite,\n scanComplete: scanComplete\n}\n\nvar pool = __webpack_require__(1888)\nvar bits = __webpack_require__(8828)\nvar isort = __webpack_require__(1811)\n\n//Flag for blue\nvar BLUE_FLAG = (1<<28)\n\n//1D sweep event queue stuff (use pool to save space)\nvar INIT_CAPACITY = 1024\nvar RED_SWEEP_QUEUE = pool.mallocInt32(INIT_CAPACITY)\nvar RED_SWEEP_INDEX = pool.mallocInt32(INIT_CAPACITY)\nvar BLUE_SWEEP_QUEUE = pool.mallocInt32(INIT_CAPACITY)\nvar BLUE_SWEEP_INDEX = pool.mallocInt32(INIT_CAPACITY)\nvar COMMON_SWEEP_QUEUE = pool.mallocInt32(INIT_CAPACITY)\nvar COMMON_SWEEP_INDEX = pool.mallocInt32(INIT_CAPACITY)\nvar SWEEP_EVENTS = pool.mallocDouble(INIT_CAPACITY * 8)\n\n//Reserves memory for the 1D sweep data structures\nfunction sqInit(count) {\n var rcount = bits.nextPow2(count)\n if(RED_SWEEP_QUEUE.length < rcount) {\n pool.free(RED_SWEEP_QUEUE)\n RED_SWEEP_QUEUE = pool.mallocInt32(rcount)\n }\n if(RED_SWEEP_INDEX.length < rcount) {\n pool.free(RED_SWEEP_INDEX)\n RED_SWEEP_INDEX = pool.mallocInt32(rcount)\n }\n if(BLUE_SWEEP_QUEUE.length < rcount) {\n pool.free(BLUE_SWEEP_QUEUE)\n BLUE_SWEEP_QUEUE = pool.mallocInt32(rcount)\n }\n if(BLUE_SWEEP_INDEX.length < rcount) {\n pool.free(BLUE_SWEEP_INDEX)\n BLUE_SWEEP_INDEX = pool.mallocInt32(rcount)\n }\n if(COMMON_SWEEP_QUEUE.length < rcount) {\n pool.free(COMMON_SWEEP_QUEUE)\n COMMON_SWEEP_QUEUE = pool.mallocInt32(rcount)\n }\n if(COMMON_SWEEP_INDEX.length < rcount) {\n pool.free(COMMON_SWEEP_INDEX)\n COMMON_SWEEP_INDEX = pool.mallocInt32(rcount)\n }\n var eventLength = 8 * rcount\n if(SWEEP_EVENTS.length < eventLength) {\n pool.free(SWEEP_EVENTS)\n SWEEP_EVENTS = pool.mallocDouble(eventLength)\n }\n}\n\n//Remove an item from the active queue in O(1)\nfunction sqPop(queue, index, count, item) {\n var idx = index[item]\n var top = queue[count-1]\n queue[idx] = top\n index[top] = idx\n}\n\n//Insert an item into the active queue in O(1)\nfunction sqPush(queue, index, count, item) {\n queue[count] = item\n index[item] = count\n}\n\n//Recursion base case: use 1D sweep algorithm\nfunction sweepBipartite(\n d, visit,\n redStart, redEnd, red, redIndex,\n blueStart, blueEnd, blue, blueIndex) {\n\n //store events as pairs [coordinate, idx]\n //\n // red create: -(idx+1)\n // red destroy: idx\n // blue create: -(idx+BLUE_FLAG)\n // blue destroy: idx+BLUE_FLAG\n //\n var ptr = 0\n var elemSize = 2*d\n var istart = d-1\n var iend = elemSize-1\n\n for(var i=redStart; iright\n var n = ptr >>> 1\n isort(SWEEP_EVENTS, n)\n \n var redActive = 0\n var blueActive = 0\n for(var i=0; i= BLUE_FLAG) {\n //blue destroy event\n e = (e-BLUE_FLAG)|0\n sqPop(BLUE_SWEEP_QUEUE, BLUE_SWEEP_INDEX, blueActive--, e)\n } else if(e >= 0) {\n //red destroy event\n sqPop(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive--, e)\n } else if(e <= -BLUE_FLAG) {\n //blue create event\n e = (-e-BLUE_FLAG)|0\n for(var j=0; jright\n var n = ptr >>> 1\n isort(SWEEP_EVENTS, n)\n \n var redActive = 0\n var blueActive = 0\n var commonActive = 0\n for(var i=0; i>1) === (SWEEP_EVENTS[2*i+3]>>1)) {\n color = 2\n i += 1\n }\n \n if(e < 0) {\n //Create event\n var id = -(e>>1) - 1\n\n //Intersect with common\n for(var j=0; j>1) - 1\n if(color === 0) {\n //Red\n sqPop(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive--, id)\n } else if(color === 1) {\n //Blue\n sqPop(BLUE_SWEEP_QUEUE, BLUE_SWEEP_INDEX, blueActive--, id)\n } else if(color === 2) {\n //Both\n sqPop(COMMON_SWEEP_QUEUE, COMMON_SWEEP_INDEX, commonActive--, id)\n }\n }\n }\n}\n\n//Sweep and prune/scanline algorithm:\n// Scan along axis, detect intersections\n// Brute force all boxes along axis\nfunction scanBipartite(\n d, axis, visit, flip,\n redStart, redEnd, red, redIndex,\n blueStart, blueEnd, blue, blueIndex) {\n \n var ptr = 0\n var elemSize = 2*d\n var istart = axis\n var iend = axis+d\n\n var redShift = 1\n var blueShift = 1\n if(flip) {\n blueShift = BLUE_FLAG\n } else {\n redShift = BLUE_FLAG\n }\n\n for(var i=redStart; iright\n var n = ptr >>> 1\n isort(SWEEP_EVENTS, n)\n \n var redActive = 0\n for(var i=0; i= BLUE_FLAG) {\n isRed = !flip\n idx -= BLUE_FLAG \n } else {\n isRed = !!flip\n idx -= 1\n }\n if(isRed) {\n sqPush(RED_SWEEP_QUEUE, RED_SWEEP_INDEX, redActive++, idx)\n } else {\n var blueId = blueIndex[idx]\n var bluePtr = elemSize * idx\n \n var b0 = blue[bluePtr+axis+1]\n var b1 = blue[bluePtr+axis+1+d]\n\nred_loop:\n for(var j=0; jright\n var n = ptr >>> 1\n isort(SWEEP_EVENTS, n)\n \n var redActive = 0\n for(var i=0; i= BLUE_FLAG) {\n RED_SWEEP_QUEUE[redActive++] = idx - BLUE_FLAG\n } else {\n idx -= 1\n var blueId = blueIndex[idx]\n var bluePtr = elemSize * idx\n\n var b0 = blue[bluePtr+axis+1]\n var b1 = blue[bluePtr+axis+1+d]\n\nred_loop:\n for(var j=0; j=0; --j) {\n if(RED_SWEEP_QUEUE[j] === idx) {\n for(var k=j+1; k 0) {\n var b = stack.pop()\n var a = stack.pop()\n\n //Find opposite pairs\n var x = -1, y = -1\n var star = stars[a]\n for(var i=1; i= 0) {\n continue\n }\n\n //Flip the edge\n triangulation.flip(a, b)\n\n //Test flipping neighboring edges\n testFlip(points, triangulation, stack, x, a, y)\n testFlip(points, triangulation, stack, a, y, x)\n testFlip(points, triangulation, stack, y, b, x)\n testFlip(points, triangulation, stack, b, x, y)\n }\n}\n\n\n/***/ }),\n\n/***/ 5023:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar bsearch = __webpack_require__(2478)\n\nmodule.exports = classifyFaces\n\nfunction FaceIndex(cells, neighbor, constraint, flags, active, next, boundary) {\n this.cells = cells\n this.neighbor = neighbor\n this.flags = flags\n this.constraint = constraint\n this.active = active\n this.next = next\n this.boundary = boundary\n}\n\nvar proto = FaceIndex.prototype\n\nfunction compareCell(a, b) {\n return a[0] - b[0] ||\n a[1] - b[1] ||\n a[2] - b[2]\n}\n\nproto.locate = (function() {\n var key = [0,0,0]\n return function(a, b, c) {\n var x = a, y = b, z = c\n if(b < c) {\n if(b < a) {\n x = b\n y = c\n z = a\n }\n } else if(c < a) {\n x = c\n y = a\n z = b\n }\n if(x < 0) {\n return -1\n }\n key[0] = x\n key[1] = y\n key[2] = z\n return bsearch.eq(this.cells, key, compareCell)\n }\n})()\n\nfunction indexCells(triangulation, infinity) {\n //First get cells and canonicalize\n var cells = triangulation.cells()\n var nc = cells.length\n for(var i=0; i 0 || next.length > 0) {\n while(active.length > 0) {\n var t = active.pop()\n if(flags[t] === -side) {\n continue\n }\n flags[t] = side\n var c = cells[t]\n for(var j=0; j<3; ++j) {\n var f = neighbor[3*t+j]\n if(f >= 0 && flags[f] === 0) {\n if(constraint[3*t+j]) {\n next.push(f)\n } else {\n active.push(f)\n flags[f] = side\n }\n }\n }\n }\n\n //Swap arrays and loop\n var tmp = next\n next = active\n active = tmp\n next.length = 0\n side = -side\n }\n\n var result = filterCells(cells, flags, target)\n if(infinity) {\n return result.concat(index.boundary)\n }\n return result\n}\n\n\n/***/ }),\n\n/***/ 8902:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar bsearch = __webpack_require__(2478)\nvar orient = (__webpack_require__(3250)[3])\n\nvar EVENT_POINT = 0\nvar EVENT_END = 1\nvar EVENT_START = 2\n\nmodule.exports = monotoneTriangulate\n\n//A partial convex hull fragment, made of two unimonotone polygons\nfunction PartialHull(a, b, idx, lowerIds, upperIds) {\n this.a = a\n this.b = b\n this.idx = idx\n this.lowerIds = lowerIds\n this.upperIds = upperIds\n}\n\n//An event in the sweep line procedure\nfunction Event(a, b, type, idx) {\n this.a = a\n this.b = b\n this.type = type\n this.idx = idx\n}\n\n//This is used to compare events for the sweep line procedure\n// Points are:\n// 1. sorted lexicographically\n// 2. sorted by type (point < end < start)\n// 3. segments sorted by winding order\n// 4. sorted by index\nfunction compareEvent(a, b) {\n var d =\n (a.a[0] - b.a[0]) ||\n (a.a[1] - b.a[1]) ||\n (a.type - b.type)\n if(d) { return d }\n if(a.type !== EVENT_POINT) {\n d = orient(a.a, a.b, b.b)\n if(d) { return d }\n }\n return a.idx - b.idx\n}\n\nfunction testPoint(hull, p) {\n return orient(hull.a, hull.b, p)\n}\n\nfunction addPoint(cells, hulls, points, p, idx) {\n var lo = bsearch.lt(hulls, p, testPoint)\n var hi = bsearch.gt(hulls, p, testPoint)\n for(var i=lo; i 1 && orient(\n points[lowerIds[m-2]],\n points[lowerIds[m-1]],\n p) > 0) {\n cells.push(\n [lowerIds[m-1],\n lowerIds[m-2],\n idx])\n m -= 1\n }\n lowerIds.length = m\n lowerIds.push(idx)\n\n //Insert p into upper hull\n var upperIds = hull.upperIds\n var m = upperIds.length\n while(m > 1 && orient(\n points[upperIds[m-2]],\n points[upperIds[m-1]],\n p) < 0) {\n cells.push(\n [upperIds[m-2],\n upperIds[m-1],\n idx])\n m -= 1\n }\n upperIds.length = m\n upperIds.push(idx)\n }\n}\n\nfunction findSplit(hull, edge) {\n var d\n if(hull.a[0] < edge.a[0]) {\n d = orient(hull.a, hull.b, edge.a)\n } else {\n d = orient(edge.b, edge.a, hull.a)\n }\n if(d) { return d }\n if(edge.b[0] < hull.b[0]) {\n d = orient(hull.a, hull.b, edge.b)\n } else {\n d = orient(edge.b, edge.a, hull.b)\n }\n return d || hull.idx - edge.idx\n}\n\nfunction splitHulls(hulls, points, event) {\n var splitIdx = bsearch.le(hulls, event, findSplit)\n var hull = hulls[splitIdx]\n var upperIds = hull.upperIds\n var x = upperIds[upperIds.length-1]\n hull.upperIds = [x]\n hulls.splice(splitIdx+1, 0,\n new PartialHull(event.a, event.b, event.idx, [x], upperIds))\n}\n\n\nfunction mergeHulls(hulls, points, event) {\n //Swap pointers for merge search\n var tmp = event.a\n event.a = event.b\n event.b = tmp\n var mergeIdx = bsearch.eq(hulls, event, findSplit)\n var upper = hulls[mergeIdx]\n var lower = hulls[mergeIdx-1]\n lower.upperIds = upper.upperIds\n hulls.splice(mergeIdx, 1)\n}\n\n\nfunction monotoneTriangulate(points, edges) {\n\n var numPoints = points.length\n var numEdges = edges.length\n\n var events = []\n\n //Create point events\n for(var i=0; i b[0]) {\n events.push(\n new Event(b, a, EVENT_START, i),\n new Event(a, b, EVENT_END, i))\n }\n }\n\n //Sort events\n events.sort(compareEvent)\n\n //Initialize hull\n var minX = events[0].a[0] - (1 + Math.abs(events[0].a[0])) * Math.pow(2, -52)\n var hull = [ new PartialHull([minX, 1], [minX, 0], -1, [], [], [], []) ]\n\n //Process events in order\n var cells = []\n for(var i=0, numEvents=events.length; i= 0\n }\n})()\n\nproto.removeTriangle = function(i, j, k) {\n var stars = this.stars\n removePair(stars[i], j, k)\n removePair(stars[j], k, i)\n removePair(stars[k], i, j)\n}\n\nproto.addTriangle = function(i, j, k) {\n var stars = this.stars\n stars[i].push(j, k)\n stars[j].push(k, i)\n stars[k].push(i, j)\n}\n\nproto.opposite = function(j, i) {\n var list = this.stars[i]\n for(var k=1, n=list.length; k= 0; --i) {\n var junction = junctions[i]\n e = junction[0]\n\n var edge = edges[e]\n var s = edge[0]\n var t = edge[1]\n\n // Check if edge is not lexicographically sorted\n var a = floatPoints[s]\n var b = floatPoints[t]\n if (((a[0] - b[0]) || (a[1] - b[1])) < 0) {\n var tmp = s\n s = t\n t = tmp\n }\n\n // Split leading edge\n edge[0] = s\n var last = edge[1] = junction[1]\n\n // If we are grouping edges by color, remember to track data\n var color\n if (useColor) {\n color = edge[2]\n }\n\n // Split other edges\n while (i > 0 && junctions[i - 1][0] === e) {\n var junction = junctions[--i]\n var next = junction[1]\n if (useColor) {\n edges.push([last, next, color])\n } else {\n edges.push([last, next])\n }\n last = next\n }\n\n // Add final edge\n if (useColor) {\n edges.push([last, t, color])\n } else {\n edges.push([last, t])\n }\n }\n\n // Return constructed rational points\n return ratPoints\n}\n\n// Merge overlapping points\nfunction dedupPoints (floatPoints, ratPoints, floatBounds) {\n var numPoints = ratPoints.length\n var uf = new UnionFind(numPoints)\n\n // Compute rational bounds\n var bounds = []\n for (var i = 0; i < ratPoints.length; ++i) {\n var p = ratPoints[i]\n var xb = boundRat(p[0])\n var yb = boundRat(p[1])\n bounds.push([\n nextafter(xb[0], -Infinity),\n nextafter(yb[0], -Infinity),\n nextafter(xb[1], Infinity),\n nextafter(yb[1], Infinity)\n ])\n }\n\n // Link all points with over lapping boxes\n boxIntersect(bounds, function (i, j) {\n uf.link(i, j)\n })\n\n // Do 1 pass over points to combine points in label sets\n var noDupes = true\n var labels = new Array(numPoints)\n for (var i = 0; i < numPoints; ++i) {\n var j = uf.find(i)\n if (j !== i) {\n // Clear no-dupes flag, zero out label\n noDupes = false\n // Make each point the top-left point from its cell\n floatPoints[j] = [\n Math.min(floatPoints[i][0], floatPoints[j][0]),\n Math.min(floatPoints[i][1], floatPoints[j][1])\n ]\n }\n }\n\n // If no duplicates, return null to signal termination\n if (noDupes) {\n return null\n }\n\n var ptr = 0\n for (var i = 0; i < numPoints; ++i) {\n var j = uf.find(i)\n if (j === i) {\n labels[i] = ptr\n floatPoints[ptr++] = floatPoints[i]\n } else {\n labels[i] = -1\n }\n }\n\n floatPoints.length = ptr\n\n // Do a second pass to fix up missing labels\n for (var i = 0; i < numPoints; ++i) {\n if (labels[i] < 0) {\n labels[i] = labels[uf.find(i)]\n }\n }\n\n // Return resulting union-find data structure\n return labels\n}\n\nfunction compareLex2 (a, b) { return (a[0] - b[0]) || (a[1] - b[1]) }\nfunction compareLex3 (a, b) {\n var d = (a[0] - b[0]) || (a[1] - b[1])\n if (d) {\n return d\n }\n if (a[2] < b[2]) {\n return -1\n } else if (a[2] > b[2]) {\n return 1\n }\n return 0\n}\n\n// Remove duplicate edge labels\nfunction dedupEdges (edges, labels, useColor) {\n if (edges.length === 0) {\n return\n }\n if (labels) {\n for (var i = 0; i < edges.length; ++i) {\n var e = edges[i]\n var a = labels[e[0]]\n var b = labels[e[1]]\n e[0] = Math.min(a, b)\n e[1] = Math.max(a, b)\n }\n } else {\n for (var i = 0; i < edges.length; ++i) {\n var e = edges[i]\n var a = e[0]\n var b = e[1]\n e[0] = Math.min(a, b)\n e[1] = Math.max(a, b)\n }\n }\n if (useColor) {\n edges.sort(compareLex3)\n } else {\n edges.sort(compareLex2)\n }\n var ptr = 1\n for (var i = 1; i < edges.length; ++i) {\n var prev = edges[i - 1]\n var next = edges[i]\n if (next[0] === prev[0] && next[1] === prev[1] &&\n (!useColor || next[2] === prev[2])) {\n continue\n }\n edges[ptr++] = next\n }\n edges.length = ptr\n}\n\nfunction preRound (points, edges, useColor) {\n var labels = dedupPoints(points, [], boundPoints(points))\n dedupEdges(edges, labels, useColor)\n return !!labels\n}\n\n// Repeat until convergence\nfunction snapRound (points, edges, useColor) {\n // 1. find edge crossings\n var edgeBounds = boundEdges(points, edges)\n var crossings = getCrossings(points, edges, edgeBounds)\n\n // 2. find t-junctions\n var vertBounds = boundPoints(points)\n var tjunctions = getTJunctions(points, edges, edgeBounds, vertBounds)\n\n // 3. cut edges, construct rational points\n var ratPoints = cutEdges(points, edges, crossings, tjunctions, useColor)\n\n // 4. dedupe verts\n var labels = dedupPoints(points, ratPoints, vertBounds)\n\n // 5. dedupe edges\n dedupEdges(edges, labels, useColor)\n\n // 6. check termination\n if (!labels) {\n return (crossings.length > 0 || tjunctions.length > 0)\n }\n\n // More iterations necessary\n return true\n}\n\n// Main loop, runs PSLG clean up until completion\nfunction cleanPSLG (points, edges, colors) {\n // If using colors, augment edges with color data\n var prevEdges\n if (colors) {\n prevEdges = edges\n var augEdges = new Array(edges.length)\n for (var i = 0; i < edges.length; ++i) {\n var e = edges[i]\n augEdges[i] = [e[0], e[1], colors[i]]\n }\n edges = augEdges\n }\n\n // First round: remove duplicate edges and points\n var modified = preRound(points, edges, !!colors)\n\n // Run snap rounding until convergence\n while (snapRound(points, edges, !!colors)) {\n modified = true\n }\n\n // Strip color tags\n if (!!colors && modified) {\n prevEdges.length = 0\n colors.length = 0\n for (var i = 0; i < edges.length; ++i) {\n var e = edges[i]\n prevEdges.push([e[0], e[1]])\n colors.push(e[2])\n }\n }\n\n return modified\n}\n\n\n/***/ }),\n\n/***/ 3637:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = solveIntersection\n\nvar ratMul = __webpack_require__(6504)\nvar ratDiv = __webpack_require__(8697)\nvar ratSub = __webpack_require__(5572)\nvar ratSign = __webpack_require__(7721)\nvar rvSub = __webpack_require__(544)\nvar rvAdd = __webpack_require__(2653)\nvar rvMuls = __webpack_require__(8987)\n\nfunction ratPerp (a, b) {\n return ratSub(ratMul(a[0], b[1]), ratMul(a[1], b[0]))\n}\n\n// Solve for intersection\n// x = a + t (b-a)\n// (x - c) ^ (d-c) = 0\n// (t * (b-a) + (a-c) ) ^ (d-c) = 0\n// t * (b-a)^(d-c) = (d-c)^(a-c)\n// t = (d-c)^(a-c) / (b-a)^(d-c)\n\nfunction solveIntersection (a, b, c, d) {\n var ba = rvSub(b, a)\n var dc = rvSub(d, c)\n\n var baXdc = ratPerp(ba, dc)\n\n if (ratSign(baXdc) === 0) {\n return null\n }\n\n var ac = rvSub(a, c)\n var dcXac = ratPerp(dc, ac)\n\n var t = ratDiv(dcXac, baXdc)\n var s = rvMuls(ba, t)\n var r = rvAdd(a, s)\n\n return r\n}\n\n\n/***/ }),\n\n/***/ 3642:\n/***/ (function(module) {\n\nmodule.exports={\n\t\"jet\":[{\"index\":0,\"rgb\":[0,0,131]},{\"index\":0.125,\"rgb\":[0,60,170]},{\"index\":0.375,\"rgb\":[5,255,255]},{\"index\":0.625,\"rgb\":[255,255,0]},{\"index\":0.875,\"rgb\":[250,0,0]},{\"index\":1,\"rgb\":[128,0,0]}],\n\n\t\"hsv\":[{\"index\":0,\"rgb\":[255,0,0]},{\"index\":0.169,\"rgb\":[253,255,2]},{\"index\":0.173,\"rgb\":[247,255,2]},{\"index\":0.337,\"rgb\":[0,252,4]},{\"index\":0.341,\"rgb\":[0,252,10]},{\"index\":0.506,\"rgb\":[1,249,255]},{\"index\":0.671,\"rgb\":[2,0,253]},{\"index\":0.675,\"rgb\":[8,0,253]},{\"index\":0.839,\"rgb\":[255,0,251]},{\"index\":0.843,\"rgb\":[255,0,245]},{\"index\":1,\"rgb\":[255,0,6]}],\n\n\t\"hot\":[{\"index\":0,\"rgb\":[0,0,0]},{\"index\":0.3,\"rgb\":[230,0,0]},{\"index\":0.6,\"rgb\":[255,210,0]},{\"index\":1,\"rgb\":[255,255,255]}],\n\n\t\"spring\":[{\"index\":0,\"rgb\":[255,0,255]},{\"index\":1,\"rgb\":[255,255,0]}],\n\n\t\"summer\":[{\"index\":0,\"rgb\":[0,128,102]},{\"index\":1,\"rgb\":[255,255,102]}],\n\n\t\"autumn\":[{\"index\":0,\"rgb\":[255,0,0]},{\"index\":1,\"rgb\":[255,255,0]}],\n\n\t\"winter\":[{\"index\":0,\"rgb\":[0,0,255]},{\"index\":1,\"rgb\":[0,255,128]}],\n\n\t\"bone\":[{\"index\":0,\"rgb\":[0,0,0]},{\"index\":0.376,\"rgb\":[84,84,116]},{\"index\":0.753,\"rgb\":[169,200,200]},{\"index\":1,\"rgb\":[255,255,255]}],\n\n\t\"copper\":[{\"index\":0,\"rgb\":[0,0,0]},{\"index\":0.804,\"rgb\":[255,160,102]},{\"index\":1,\"rgb\":[255,199,127]}],\n\n\t\"greys\":[{\"index\":0,\"rgb\":[0,0,0]},{\"index\":1,\"rgb\":[255,255,255]}],\n\n\t\"yignbu\":[{\"index\":0,\"rgb\":[8,29,88]},{\"index\":0.125,\"rgb\":[37,52,148]},{\"index\":0.25,\"rgb\":[34,94,168]},{\"index\":0.375,\"rgb\":[29,145,192]},{\"index\":0.5,\"rgb\":[65,182,196]},{\"index\":0.625,\"rgb\":[127,205,187]},{\"index\":0.75,\"rgb\":[199,233,180]},{\"index\":0.875,\"rgb\":[237,248,217]},{\"index\":1,\"rgb\":[255,255,217]}],\n\n\t\"greens\":[{\"index\":0,\"rgb\":[0,68,27]},{\"index\":0.125,\"rgb\":[0,109,44]},{\"index\":0.25,\"rgb\":[35,139,69]},{\"index\":0.375,\"rgb\":[65,171,93]},{\"index\":0.5,\"rgb\":[116,196,118]},{\"index\":0.625,\"rgb\":[161,217,155]},{\"index\":0.75,\"rgb\":[199,233,192]},{\"index\":0.875,\"rgb\":[229,245,224]},{\"index\":1,\"rgb\":[247,252,245]}],\n\n\t\"yiorrd\":[{\"index\":0,\"rgb\":[128,0,38]},{\"index\":0.125,\"rgb\":[189,0,38]},{\"index\":0.25,\"rgb\":[227,26,28]},{\"index\":0.375,\"rgb\":[252,78,42]},{\"index\":0.5,\"rgb\":[253,141,60]},{\"index\":0.625,\"rgb\":[254,178,76]},{\"index\":0.75,\"rgb\":[254,217,118]},{\"index\":0.875,\"rgb\":[255,237,160]},{\"index\":1,\"rgb\":[255,255,204]}],\n\n\t\"bluered\":[{\"index\":0,\"rgb\":[0,0,255]},{\"index\":1,\"rgb\":[255,0,0]}],\n\n\t\"rdbu\":[{\"index\":0,\"rgb\":[5,10,172]},{\"index\":0.35,\"rgb\":[106,137,247]},{\"index\":0.5,\"rgb\":[190,190,190]},{\"index\":0.6,\"rgb\":[220,170,132]},{\"index\":0.7,\"rgb\":[230,145,90]},{\"index\":1,\"rgb\":[178,10,28]}],\n\n\t\"picnic\":[{\"index\":0,\"rgb\":[0,0,255]},{\"index\":0.1,\"rgb\":[51,153,255]},{\"index\":0.2,\"rgb\":[102,204,255]},{\"index\":0.3,\"rgb\":[153,204,255]},{\"index\":0.4,\"rgb\":[204,204,255]},{\"index\":0.5,\"rgb\":[255,255,255]},{\"index\":0.6,\"rgb\":[255,204,255]},{\"index\":0.7,\"rgb\":[255,153,255]},{\"index\":0.8,\"rgb\":[255,102,204]},{\"index\":0.9,\"rgb\":[255,102,102]},{\"index\":1,\"rgb\":[255,0,0]}],\n\n\t\"rainbow\":[{\"index\":0,\"rgb\":[150,0,90]},{\"index\":0.125,\"rgb\":[0,0,200]},{\"index\":0.25,\"rgb\":[0,25,255]},{\"index\":0.375,\"rgb\":[0,152,255]},{\"index\":0.5,\"rgb\":[44,255,150]},{\"index\":0.625,\"rgb\":[151,255,0]},{\"index\":0.75,\"rgb\":[255,234,0]},{\"index\":0.875,\"rgb\":[255,111,0]},{\"index\":1,\"rgb\":[255,0,0]}],\n\n\t\"portland\":[{\"index\":0,\"rgb\":[12,51,131]},{\"index\":0.25,\"rgb\":[10,136,186]},{\"index\":0.5,\"rgb\":[242,211,56]},{\"index\":0.75,\"rgb\":[242,143,56]},{\"index\":1,\"rgb\":[217,30,30]}],\n\n\t\"blackbody\":[{\"index\":0,\"rgb\":[0,0,0]},{\"index\":0.2,\"rgb\":[230,0,0]},{\"index\":0.4,\"rgb\":[230,210,0]},{\"index\":0.7,\"rgb\":[255,255,255]},{\"index\":1,\"rgb\":[160,200,255]}],\n\n\t\"earth\":[{\"index\":0,\"rgb\":[0,0,130]},{\"index\":0.1,\"rgb\":[0,180,180]},{\"index\":0.2,\"rgb\":[40,210,40]},{\"index\":0.4,\"rgb\":[230,230,50]},{\"index\":0.6,\"rgb\":[120,70,20]},{\"index\":1,\"rgb\":[255,255,255]}],\n\n\t\"electric\":[{\"index\":0,\"rgb\":[0,0,0]},{\"index\":0.15,\"rgb\":[30,0,100]},{\"index\":0.4,\"rgb\":[120,0,100]},{\"index\":0.6,\"rgb\":[160,90,0]},{\"index\":0.8,\"rgb\":[230,200,0]},{\"index\":1,\"rgb\":[255,250,220]}],\n\n\t\"alpha\": [{\"index\":0, \"rgb\": [255,255,255,0]},{\"index\":1, \"rgb\": [255,255,255,1]}],\n\n\t\"viridis\": [{\"index\":0,\"rgb\":[68,1,84]},{\"index\":0.13,\"rgb\":[71,44,122]},{\"index\":0.25,\"rgb\":[59,81,139]},{\"index\":0.38,\"rgb\":[44,113,142]},{\"index\":0.5,\"rgb\":[33,144,141]},{\"index\":0.63,\"rgb\":[39,173,129]},{\"index\":0.75,\"rgb\":[92,200,99]},{\"index\":0.88,\"rgb\":[170,220,50]},{\"index\":1,\"rgb\":[253,231,37]}],\n\n\t\"inferno\": [{\"index\":0,\"rgb\":[0,0,4]},{\"index\":0.13,\"rgb\":[31,12,72]},{\"index\":0.25,\"rgb\":[85,15,109]},{\"index\":0.38,\"rgb\":[136,34,106]},{\"index\":0.5,\"rgb\":[186,54,85]},{\"index\":0.63,\"rgb\":[227,89,51]},{\"index\":0.75,\"rgb\":[249,140,10]},{\"index\":0.88,\"rgb\":[249,201,50]},{\"index\":1,\"rgb\":[252,255,164]}],\n\n\t\"magma\": [{\"index\":0,\"rgb\":[0,0,4]},{\"index\":0.13,\"rgb\":[28,16,68]},{\"index\":0.25,\"rgb\":[79,18,123]},{\"index\":0.38,\"rgb\":[129,37,129]},{\"index\":0.5,\"rgb\":[181,54,122]},{\"index\":0.63,\"rgb\":[229,80,100]},{\"index\":0.75,\"rgb\":[251,135,97]},{\"index\":0.88,\"rgb\":[254,194,135]},{\"index\":1,\"rgb\":[252,253,191]}],\n\n\t\"plasma\": [{\"index\":0,\"rgb\":[13,8,135]},{\"index\":0.13,\"rgb\":[75,3,161]},{\"index\":0.25,\"rgb\":[125,3,168]},{\"index\":0.38,\"rgb\":[168,34,150]},{\"index\":0.5,\"rgb\":[203,70,121]},{\"index\":0.63,\"rgb\":[229,107,93]},{\"index\":0.75,\"rgb\":[248,148,65]},{\"index\":0.88,\"rgb\":[253,195,40]},{\"index\":1,\"rgb\":[240,249,33]}],\n\n\t\"warm\": [{\"index\":0,\"rgb\":[125,0,179]},{\"index\":0.13,\"rgb\":[172,0,187]},{\"index\":0.25,\"rgb\":[219,0,170]},{\"index\":0.38,\"rgb\":[255,0,130]},{\"index\":0.5,\"rgb\":[255,63,74]},{\"index\":0.63,\"rgb\":[255,123,0]},{\"index\":0.75,\"rgb\":[234,176,0]},{\"index\":0.88,\"rgb\":[190,228,0]},{\"index\":1,\"rgb\":[147,255,0]}],\n\n\t\"cool\": [{\"index\":0,\"rgb\":[125,0,179]},{\"index\":0.13,\"rgb\":[116,0,218]},{\"index\":0.25,\"rgb\":[98,74,237]},{\"index\":0.38,\"rgb\":[68,146,231]},{\"index\":0.5,\"rgb\":[0,204,197]},{\"index\":0.63,\"rgb\":[0,247,146]},{\"index\":0.75,\"rgb\":[0,255,88]},{\"index\":0.88,\"rgb\":[40,255,8]},{\"index\":1,\"rgb\":[147,255,0]}],\n\n\t\"rainbow-soft\": [{\"index\":0,\"rgb\":[125,0,179]},{\"index\":0.1,\"rgb\":[199,0,180]},{\"index\":0.2,\"rgb\":[255,0,121]},{\"index\":0.3,\"rgb\":[255,108,0]},{\"index\":0.4,\"rgb\":[222,194,0]},{\"index\":0.5,\"rgb\":[150,255,0]},{\"index\":0.6,\"rgb\":[0,255,55]},{\"index\":0.7,\"rgb\":[0,246,150]},{\"index\":0.8,\"rgb\":[50,167,222]},{\"index\":0.9,\"rgb\":[103,51,235]},{\"index\":1,\"rgb\":[124,0,186]}],\n\n\t\"bathymetry\": [{\"index\":0,\"rgb\":[40,26,44]},{\"index\":0.13,\"rgb\":[59,49,90]},{\"index\":0.25,\"rgb\":[64,76,139]},{\"index\":0.38,\"rgb\":[63,110,151]},{\"index\":0.5,\"rgb\":[72,142,158]},{\"index\":0.63,\"rgb\":[85,174,163]},{\"index\":0.75,\"rgb\":[120,206,163]},{\"index\":0.88,\"rgb\":[187,230,172]},{\"index\":1,\"rgb\":[253,254,204]}],\n\n\t\"cdom\": [{\"index\":0,\"rgb\":[47,15,62]},{\"index\":0.13,\"rgb\":[87,23,86]},{\"index\":0.25,\"rgb\":[130,28,99]},{\"index\":0.38,\"rgb\":[171,41,96]},{\"index\":0.5,\"rgb\":[206,67,86]},{\"index\":0.63,\"rgb\":[230,106,84]},{\"index\":0.75,\"rgb\":[242,149,103]},{\"index\":0.88,\"rgb\":[249,193,135]},{\"index\":1,\"rgb\":[254,237,176]}],\n\n\t\"chlorophyll\": [{\"index\":0,\"rgb\":[18,36,20]},{\"index\":0.13,\"rgb\":[25,63,41]},{\"index\":0.25,\"rgb\":[24,91,59]},{\"index\":0.38,\"rgb\":[13,119,72]},{\"index\":0.5,\"rgb\":[18,148,80]},{\"index\":0.63,\"rgb\":[80,173,89]},{\"index\":0.75,\"rgb\":[132,196,122]},{\"index\":0.88,\"rgb\":[175,221,162]},{\"index\":1,\"rgb\":[215,249,208]}],\n\n\t\"density\": [{\"index\":0,\"rgb\":[54,14,36]},{\"index\":0.13,\"rgb\":[89,23,80]},{\"index\":0.25,\"rgb\":[110,45,132]},{\"index\":0.38,\"rgb\":[120,77,178]},{\"index\":0.5,\"rgb\":[120,113,213]},{\"index\":0.63,\"rgb\":[115,151,228]},{\"index\":0.75,\"rgb\":[134,185,227]},{\"index\":0.88,\"rgb\":[177,214,227]},{\"index\":1,\"rgb\":[230,241,241]}],\n\n\t\"freesurface-blue\": [{\"index\":0,\"rgb\":[30,4,110]},{\"index\":0.13,\"rgb\":[47,14,176]},{\"index\":0.25,\"rgb\":[41,45,236]},{\"index\":0.38,\"rgb\":[25,99,212]},{\"index\":0.5,\"rgb\":[68,131,200]},{\"index\":0.63,\"rgb\":[114,156,197]},{\"index\":0.75,\"rgb\":[157,181,203]},{\"index\":0.88,\"rgb\":[200,208,216]},{\"index\":1,\"rgb\":[241,237,236]}],\n\n\t\"freesurface-red\": [{\"index\":0,\"rgb\":[60,9,18]},{\"index\":0.13,\"rgb\":[100,17,27]},{\"index\":0.25,\"rgb\":[142,20,29]},{\"index\":0.38,\"rgb\":[177,43,27]},{\"index\":0.5,\"rgb\":[192,87,63]},{\"index\":0.63,\"rgb\":[205,125,105]},{\"index\":0.75,\"rgb\":[216,162,148]},{\"index\":0.88,\"rgb\":[227,199,193]},{\"index\":1,\"rgb\":[241,237,236]}],\n\n\t\"oxygen\": [{\"index\":0,\"rgb\":[64,5,5]},{\"index\":0.13,\"rgb\":[106,6,15]},{\"index\":0.25,\"rgb\":[144,26,7]},{\"index\":0.38,\"rgb\":[168,64,3]},{\"index\":0.5,\"rgb\":[188,100,4]},{\"index\":0.63,\"rgb\":[206,136,11]},{\"index\":0.75,\"rgb\":[220,174,25]},{\"index\":0.88,\"rgb\":[231,215,44]},{\"index\":1,\"rgb\":[248,254,105]}],\n\n\t\"par\": [{\"index\":0,\"rgb\":[51,20,24]},{\"index\":0.13,\"rgb\":[90,32,35]},{\"index\":0.25,\"rgb\":[129,44,34]},{\"index\":0.38,\"rgb\":[159,68,25]},{\"index\":0.5,\"rgb\":[182,99,19]},{\"index\":0.63,\"rgb\":[199,134,22]},{\"index\":0.75,\"rgb\":[212,171,35]},{\"index\":0.88,\"rgb\":[221,210,54]},{\"index\":1,\"rgb\":[225,253,75]}],\n\n\t\"phase\": [{\"index\":0,\"rgb\":[145,105,18]},{\"index\":0.13,\"rgb\":[184,71,38]},{\"index\":0.25,\"rgb\":[186,58,115]},{\"index\":0.38,\"rgb\":[160,71,185]},{\"index\":0.5,\"rgb\":[110,97,218]},{\"index\":0.63,\"rgb\":[50,123,164]},{\"index\":0.75,\"rgb\":[31,131,110]},{\"index\":0.88,\"rgb\":[77,129,34]},{\"index\":1,\"rgb\":[145,105,18]}],\n\n\t\"salinity\": [{\"index\":0,\"rgb\":[42,24,108]},{\"index\":0.13,\"rgb\":[33,50,162]},{\"index\":0.25,\"rgb\":[15,90,145]},{\"index\":0.38,\"rgb\":[40,118,137]},{\"index\":0.5,\"rgb\":[59,146,135]},{\"index\":0.63,\"rgb\":[79,175,126]},{\"index\":0.75,\"rgb\":[120,203,104]},{\"index\":0.88,\"rgb\":[193,221,100]},{\"index\":1,\"rgb\":[253,239,154]}],\n\n\t\"temperature\": [{\"index\":0,\"rgb\":[4,35,51]},{\"index\":0.13,\"rgb\":[23,51,122]},{\"index\":0.25,\"rgb\":[85,59,157]},{\"index\":0.38,\"rgb\":[129,79,143]},{\"index\":0.5,\"rgb\":[175,95,130]},{\"index\":0.63,\"rgb\":[222,112,101]},{\"index\":0.75,\"rgb\":[249,146,66]},{\"index\":0.88,\"rgb\":[249,196,65]},{\"index\":1,\"rgb\":[232,250,91]}],\n\n\t\"turbidity\": [{\"index\":0,\"rgb\":[34,31,27]},{\"index\":0.13,\"rgb\":[65,50,41]},{\"index\":0.25,\"rgb\":[98,69,52]},{\"index\":0.38,\"rgb\":[131,89,57]},{\"index\":0.5,\"rgb\":[161,112,59]},{\"index\":0.63,\"rgb\":[185,140,66]},{\"index\":0.75,\"rgb\":[202,174,88]},{\"index\":0.88,\"rgb\":[216,209,126]},{\"index\":1,\"rgb\":[233,246,171]}],\n\n\t\"velocity-blue\": [{\"index\":0,\"rgb\":[17,32,64]},{\"index\":0.13,\"rgb\":[35,52,116]},{\"index\":0.25,\"rgb\":[29,81,156]},{\"index\":0.38,\"rgb\":[31,113,162]},{\"index\":0.5,\"rgb\":[50,144,169]},{\"index\":0.63,\"rgb\":[87,173,176]},{\"index\":0.75,\"rgb\":[149,196,189]},{\"index\":0.88,\"rgb\":[203,221,211]},{\"index\":1,\"rgb\":[254,251,230]}],\n\n\t\"velocity-green\": [{\"index\":0,\"rgb\":[23,35,19]},{\"index\":0.13,\"rgb\":[24,64,38]},{\"index\":0.25,\"rgb\":[11,95,45]},{\"index\":0.38,\"rgb\":[39,123,35]},{\"index\":0.5,\"rgb\":[95,146,12]},{\"index\":0.63,\"rgb\":[152,165,18]},{\"index\":0.75,\"rgb\":[201,186,69]},{\"index\":0.88,\"rgb\":[233,216,137]},{\"index\":1,\"rgb\":[255,253,205]}],\n\n\t\"cubehelix\": [{\"index\":0,\"rgb\":[0,0,0]},{\"index\":0.07,\"rgb\":[22,5,59]},{\"index\":0.13,\"rgb\":[60,4,105]},{\"index\":0.2,\"rgb\":[109,1,135]},{\"index\":0.27,\"rgb\":[161,0,147]},{\"index\":0.33,\"rgb\":[210,2,142]},{\"index\":0.4,\"rgb\":[251,11,123]},{\"index\":0.47,\"rgb\":[255,29,97]},{\"index\":0.53,\"rgb\":[255,54,69]},{\"index\":0.6,\"rgb\":[255,85,46]},{\"index\":0.67,\"rgb\":[255,120,34]},{\"index\":0.73,\"rgb\":[255,157,37]},{\"index\":0.8,\"rgb\":[241,191,57]},{\"index\":0.87,\"rgb\":[224,220,93]},{\"index\":0.93,\"rgb\":[218,241,142]},{\"index\":1,\"rgb\":[227,253,198]}]\n};\n\n\n/***/ }),\n\n/***/ 6729:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n/*\n * Ben Postlethwaite\n * January 2013\n * License MIT\n */\n\n\nvar colorScale = __webpack_require__(3642);\nvar lerp = __webpack_require__(395)\n\nmodule.exports = createColormap;\n\nfunction createColormap (spec) {\n /*\n * Default Options\n */\n var indicies, fromrgba, torgba,\n nsteps, cmap, colormap, format,\n nshades, colors, alpha, i;\n\n if ( !spec ) spec = {};\n\n nshades = (spec.nshades || 72) - 1;\n format = spec.format || 'hex';\n\n colormap = spec.colormap;\n if (!colormap) colormap = 'jet';\n\n if (typeof colormap === 'string') {\n colormap = colormap.toLowerCase();\n\n if (!colorScale[colormap]) {\n throw Error(colormap + ' not a supported colorscale');\n }\n\n cmap = colorScale[colormap];\n\n } else if (Array.isArray(colormap)) {\n cmap = colormap.slice();\n\n } else {\n throw Error('unsupported colormap option', colormap);\n }\n\n if (cmap.length > nshades + 1) {\n throw new Error(\n colormap+' map requires nshades to be at least size '+cmap.length\n );\n }\n\n if (!Array.isArray(spec.alpha)) {\n\n if (typeof spec.alpha === 'number') {\n alpha = [spec.alpha, spec.alpha];\n\n } else {\n alpha = [1, 1];\n }\n\n } else if (spec.alpha.length !== 2) {\n alpha = [1, 1];\n\n } else {\n alpha = spec.alpha.slice();\n }\n\n // map index points from 0..1 to 0..n-1\n indicies = cmap.map(function(c) {\n return Math.round(c.index * nshades);\n });\n\n // Add alpha channel to the map\n alpha[0] = Math.min(Math.max(alpha[0], 0), 1);\n alpha[1] = Math.min(Math.max(alpha[1], 0), 1);\n\n var steps = cmap.map(function(c, i) {\n var index = cmap[i].index\n\n var rgba = cmap[i].rgb.slice();\n\n // if user supplies their own map use it\n if (rgba.length === 4 && rgba[3] >= 0 && rgba[3] <= 1) {\n return rgba\n }\n rgba[3] = alpha[0] + (alpha[1] - alpha[0])*index;\n\n return rgba\n })\n\n\n /*\n * map increasing linear values between indicies to\n * linear steps in colorvalues\n */\n var colors = []\n for (i = 0; i < indicies.length-1; ++i) {\n nsteps = indicies[i+1] - indicies[i];\n fromrgba = steps[i];\n torgba = steps[i+1];\n\n for (var j = 0; j < nsteps; j++) {\n var amt = j / nsteps\n colors.push([\n Math.round(lerp(fromrgba[0], torgba[0], amt)),\n Math.round(lerp(fromrgba[1], torgba[1], amt)),\n Math.round(lerp(fromrgba[2], torgba[2], amt)),\n lerp(fromrgba[3], torgba[3], amt)\n ])\n }\n }\n\n //add 1 step as last value\n colors.push(cmap[cmap.length - 1].rgb.concat(alpha[1]))\n\n if (format === 'hex') colors = colors.map( rgb2hex );\n else if (format === 'rgbaString') colors = colors.map( rgbaStr );\n else if (format === 'float') colors = colors.map( rgb2float );\n\n return colors;\n};\n\nfunction rgb2float (rgba) {\n return [\n rgba[0] / 255,\n rgba[1] / 255,\n rgba[2] / 255,\n rgba[3]\n ]\n}\n\nfunction rgb2hex (rgba) {\n var dig, hex = '#';\n for (var i = 0; i < 3; ++i) {\n dig = rgba[i];\n dig = dig.toString(16);\n hex += ('00' + dig).substr( dig.length );\n }\n return hex;\n}\n\nfunction rgbaStr (rgba) {\n return 'rgba(' + rgba.join(',') + ')';\n}\n\n\n/***/ }),\n\n/***/ 3140:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = compareAngle\n\nvar orient = __webpack_require__(3250)\nvar sgn = __webpack_require__(8572)\nvar twoSum = __webpack_require__(9362)\nvar robustProduct = __webpack_require__(5382)\nvar robustSum = __webpack_require__(8210)\n\nfunction testInterior(a, b, c) {\n var x0 = twoSum(a[0], -b[0])\n var y0 = twoSum(a[1], -b[1])\n var x1 = twoSum(c[0], -b[0])\n var y1 = twoSum(c[1], -b[1])\n\n var d = robustSum(\n robustProduct(x0, x1),\n robustProduct(y0, y1))\n\n return d[d.length-1] >= 0\n}\n\nfunction compareAngle(a, b, c, d) {\n var bcd = orient(b, c, d)\n if(bcd === 0) {\n //Handle degenerate cases\n var sabc = sgn(orient(a, b, c))\n var sabd = sgn(orient(a, b, d))\n if(sabc === sabd) {\n if(sabc === 0) {\n var ic = testInterior(a, b, c)\n var id = testInterior(a, b, d)\n if(ic === id) {\n return 0\n } else if(ic) {\n return 1\n } else {\n return -1\n }\n }\n return 0\n } else if(sabd === 0) {\n if(sabc > 0) {\n return -1\n } else if(testInterior(a, b, d)) {\n return -1\n } else {\n return 1\n }\n } else if(sabc === 0) {\n if(sabd > 0) {\n return 1\n } else if(testInterior(a, b, c)) {\n return 1\n } else {\n return -1\n }\n }\n return sgn(sabd - sabc)\n }\n var abc = orient(a, b, c)\n if(abc > 0) {\n if(bcd > 0 && orient(a, b, d) > 0) {\n return 1\n }\n return -1\n } else if(abc < 0) {\n if(bcd > 0 || orient(a, b, d) > 0) {\n return 1\n }\n return -1\n } else {\n var abd = orient(a, b, d)\n if(abd > 0) {\n return 1\n } else {\n if(testInterior(a, b, c)) {\n return 1\n } else {\n return -1\n }\n }\n }\n}\n\n/***/ }),\n\n/***/ 8572:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nmodule.exports = function signum(x) {\n if(x < 0) { return -1 }\n if(x > 0) { return 1 }\n return 0.0\n}\n\n/***/ }),\n\n/***/ 8507:\n/***/ (function(module) {\n\nmodule.exports = compareCells\n\nvar min = Math.min\n\nfunction compareInt(a, b) {\n return a - b\n}\n\nfunction compareCells(a, b) {\n var n = a.length\n , t = a.length - b.length\n if(t) {\n return t\n }\n switch(n) {\n case 0:\n return 0\n case 1:\n return a[0] - b[0]\n case 2:\n return (a[0]+a[1]-b[0]-b[1]) ||\n min(a[0],a[1]) - min(b[0],b[1])\n case 3:\n var l1 = a[0]+a[1]\n , m1 = b[0]+b[1]\n t = l1+a[2] - (m1+b[2])\n if(t) {\n return t\n }\n var l0 = min(a[0], a[1])\n , m0 = min(b[0], b[1])\n return min(l0, a[2]) - min(m0, b[2]) ||\n min(l0+a[2], l1) - min(m0+b[2], m1)\n case 4:\n var aw=a[0], ax=a[1], ay=a[2], az=a[3]\n , bw=b[0], bx=b[1], by=b[2], bz=b[3]\n return (aw+ax+ay+az)-(bw+bx+by+bz) ||\n min(aw,ax,ay,az)-min(bw,bx,by,bz,bw) ||\n min(aw+ax,aw+ay,aw+az,ax+ay,ax+az,ay+az) -\n min(bw+bx,bw+by,bw+bz,bx+by,bx+bz,by+bz) ||\n min(aw+ax+ay,aw+ax+az,aw+ay+az,ax+ay+az) -\n min(bw+bx+by,bw+bx+bz,bw+by+bz,bx+by+bz)\n default:\n var as = a.slice().sort(compareInt)\n var bs = b.slice().sort(compareInt)\n for(var i=0; i points[hi][0]) {\n hi = i\n }\n }\n if(lo < hi) {\n return [[lo], [hi]]\n } else if(lo > hi) {\n return [[hi], [lo]]\n } else {\n return [[lo]]\n }\n}\n\n/***/ }),\n\n/***/ 4750:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = convexHull2D\n\nvar monotoneHull = __webpack_require__(3090)\n\nfunction convexHull2D(points) {\n var hull = monotoneHull(points)\n var h = hull.length\n if(h <= 2) {\n return []\n }\n var edges = new Array(h)\n var a = hull[h-1]\n for(var i=0; i= front[k]) {\n x += 1\n }\n }\n c[j] = x\n }\n }\n }\n return cells\n}\n\nfunction convexHullnD(points, d) {\n try {\n return ich(points, true)\n } catch(e) {\n //If point set is degenerate, try to find a basis and rerun it\n var ah = aff(points)\n if(ah.length <= d) {\n //No basis, no try\n return []\n }\n var npoints = permute(points, ah)\n var nhull = ich(npoints, true)\n return invPermute(nhull, ah)\n }\n}\n\n/***/ }),\n\n/***/ 4769:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nfunction dcubicHermite(p0, v0, p1, v1, t, f) {\n var dh00 = 6*t*t-6*t,\n dh10 = 3*t*t-4*t + 1,\n dh01 = -6*t*t+6*t,\n dh11 = 3*t*t-2*t\n if(p0.length) {\n if(!f) {\n f = new Array(p0.length)\n }\n for(var i=p0.length-1; i>=0; --i) {\n f[i] = dh00*p0[i] + dh10*v0[i] + dh01*p1[i] + dh11*v1[i]\n }\n return f\n }\n return dh00*p0 + dh10*v0 + dh01*p1[i] + dh11*v1\n}\n\nfunction cubicHermite(p0, v0, p1, v1, t, f) {\n var ti = (t-1), t2 = t*t, ti2 = ti*ti,\n h00 = (1+2*t)*ti2,\n h10 = t*ti2,\n h01 = t2*(3-2*t),\n h11 = t2*ti\n if(p0.length) {\n if(!f) {\n f = new Array(p0.length)\n }\n for(var i=p0.length-1; i>=0; --i) {\n f[i] = h00*p0[i] + h10*v0[i] + h01*p1[i] + h11*v1[i]\n }\n return f\n }\n return h00*p0 + h10*v0 + h01*p1 + h11*v1\n}\n\nmodule.exports = cubicHermite\nmodule.exports.derivative = dcubicHermite\n\n/***/ }),\n\n/***/ 7642:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar ch = __webpack_require__(8954)\nvar uniq = __webpack_require__(1682)\n\nmodule.exports = triangulate\n\nfunction LiftedPoint(p, i) {\n this.point = p\n this.index = i\n}\n\nfunction compareLifted(a, b) {\n var ap = a.point\n var bp = b.point\n var d = ap.length\n for(var i=0; i= 2) {\n return false\n }\n }\n cell[j] = v\n }\n return true\n })\n } else {\n hull = hull.filter(function(cell) {\n for(var i=0; i<=d; ++i) {\n var v = dindex[cell[i]]\n if(v < 0) {\n return false\n }\n cell[i] = v\n }\n return true\n })\n }\n\n if(d & 1) {\n for(var i=0; i>> 31\n}\n\nmodule.exports.exponent = function(n) {\n var b = module.exports.hi(n)\n return ((b<<1) >>> 21) - 1023\n}\n\nmodule.exports.fraction = function(n) {\n var lo = module.exports.lo(n)\n var hi = module.exports.hi(n)\n var b = hi & ((1<<20) - 1)\n if(hi & 0x7ff00000) {\n b += (1<<20)\n }\n return [lo, b]\n}\n\nmodule.exports.denormalized = function(n) {\n var hi = module.exports.hi(n)\n return !(hi & 0x7ff00000)\n}\n\n/***/ }),\n\n/***/ 1338:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nfunction dupe_array(count, value, i) {\n var c = count[i]|0\n if(c <= 0) {\n return []\n }\n var result = new Array(c), j\n if(i === count.length-1) {\n for(j=0; j 0) {\n return dupe_number(count|0, value)\n }\n break\n case \"object\":\n if(typeof (count.length) === \"number\") {\n return dupe_array(count, value, 0)\n }\n break\n }\n return []\n}\n\nmodule.exports = dupe\n\n/***/ }),\n\n/***/ 3134:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = edgeToAdjacency\n\nvar uniq = __webpack_require__(1682)\n\nfunction edgeToAdjacency(edges, numVertices) {\n var numEdges = edges.length\n if(typeof numVertices !== \"number\") {\n numVertices = 0\n for(var i=0; i= n-1) {\n var ptr = state.length-1\n var tf = t - time[n-1]\n for(var i=0; i= n-1) {\n var ptr = state.length-1\n var tf = t - time[n-1]\n for(var i=0; i=0; --i) {\n if(velocity[--ptr]) {\n return false\n }\n }\n return true\n}\n\nproto.jump = function(t) {\n var t0 = this.lastT()\n var d = this.dimension\n if(t < t0 || arguments.length !== d+1) {\n return\n }\n var state = this._state\n var velocity = this._velocity\n var ptr = state.length-this.dimension\n var bounds = this.bounds\n var lo = bounds[0]\n var hi = bounds[1]\n this._time.push(t0, t)\n for(var j=0; j<2; ++j) {\n for(var i=0; i0; --i) {\n state.push(clamp(lo[i-1], hi[i-1], arguments[i]))\n velocity.push(0)\n }\n}\n\nproto.push = function(t) {\n var t0 = this.lastT()\n var d = this.dimension\n if(t < t0 || arguments.length !== d+1) {\n return\n }\n var state = this._state\n var velocity = this._velocity\n var ptr = state.length-this.dimension\n var dt = t - t0\n var bounds = this.bounds\n var lo = bounds[0]\n var hi = bounds[1]\n var sf = (dt > 1e-6) ? 1/dt : 0\n this._time.push(t)\n for(var i=d; i>0; --i) {\n var xc = clamp(lo[i-1], hi[i-1], arguments[i])\n state.push(xc)\n velocity.push((xc - state[ptr++]) * sf)\n }\n}\n\nproto.set = function(t) {\n var d = this.dimension\n if(t < this.lastT() || arguments.length !== d+1) {\n return\n }\n var state = this._state\n var velocity = this._velocity\n var bounds = this.bounds\n var lo = bounds[0]\n var hi = bounds[1]\n this._time.push(t)\n for(var i=d; i>0; --i) {\n state.push(clamp(lo[i-1], hi[i-1], arguments[i]))\n velocity.push(0)\n }\n}\n\nproto.move = function(t) {\n var t0 = this.lastT()\n var d = this.dimension\n if(t <= t0 || arguments.length !== d+1) {\n return\n }\n var state = this._state\n var velocity = this._velocity\n var statePtr = state.length - this.dimension\n var bounds = this.bounds\n var lo = bounds[0]\n var hi = bounds[1]\n var dt = t - t0\n var sf = (dt > 1e-6) ? 1/dt : 0.0\n this._time.push(t)\n for(var i=d; i>0; --i) {\n var dx = arguments[i]\n state.push(clamp(lo[i-1], hi[i-1], state[statePtr++] + dx))\n velocity.push(dx * sf)\n }\n}\n\nproto.idle = function(t) {\n var t0 = this.lastT()\n if(t < t0) {\n return\n }\n var d = this.dimension\n var state = this._state\n var velocity = this._velocity\n var statePtr = state.length-d\n var bounds = this.bounds\n var lo = bounds[0]\n var hi = bounds[1]\n var dt = t - t0\n this._time.push(t)\n for(var i=d-1; i>=0; --i) {\n state.push(clamp(lo[i], hi[i], state[statePtr] + dt * velocity[statePtr]))\n velocity.push(0)\n statePtr += 1\n }\n}\n\nfunction getZero(d) {\n var result = new Array(d)\n for(var i=0; i=0; --s) {\n var n = n_stack[s]\n if(d_stack[s] <= 0) {\n n_stack[s] = new RBNode(n._color, n.key, n.value, n_stack[s+1], n.right, n._count+1)\n } else {\n n_stack[s] = new RBNode(n._color, n.key, n.value, n.left, n_stack[s+1], n._count+1)\n }\n }\n //Rebalance tree using rotations\n //console.log(\"start insert\", key, d_stack)\n for(var s=n_stack.length-1; s>1; --s) {\n var p = n_stack[s-1]\n var n = n_stack[s]\n if(p._color === BLACK || n._color === BLACK) {\n break\n }\n var pp = n_stack[s-2]\n if(pp.left === p) {\n if(p.left === n) {\n var y = pp.right\n if(y && y._color === RED) {\n //console.log(\"LLr\")\n p._color = BLACK\n pp.right = repaint(BLACK, y)\n pp._color = RED\n s -= 1\n } else {\n //console.log(\"LLb\")\n pp._color = RED\n pp.left = p.right\n p._color = BLACK\n p.right = pp\n n_stack[s-2] = p\n n_stack[s-1] = n\n recount(pp)\n recount(p)\n if(s >= 3) {\n var ppp = n_stack[s-3]\n if(ppp.left === pp) {\n ppp.left = p\n } else {\n ppp.right = p\n }\n }\n break\n }\n } else {\n var y = pp.right\n if(y && y._color === RED) {\n //console.log(\"LRr\")\n p._color = BLACK\n pp.right = repaint(BLACK, y)\n pp._color = RED\n s -= 1\n } else {\n //console.log(\"LRb\")\n p.right = n.left\n pp._color = RED\n pp.left = n.right\n n._color = BLACK\n n.left = p\n n.right = pp\n n_stack[s-2] = n\n n_stack[s-1] = p\n recount(pp)\n recount(p)\n recount(n)\n if(s >= 3) {\n var ppp = n_stack[s-3]\n if(ppp.left === pp) {\n ppp.left = n\n } else {\n ppp.right = n\n }\n }\n break\n }\n }\n } else {\n if(p.right === n) {\n var y = pp.left\n if(y && y._color === RED) {\n //console.log(\"RRr\", y.key)\n p._color = BLACK\n pp.left = repaint(BLACK, y)\n pp._color = RED\n s -= 1\n } else {\n //console.log(\"RRb\")\n pp._color = RED\n pp.right = p.left\n p._color = BLACK\n p.left = pp\n n_stack[s-2] = p\n n_stack[s-1] = n\n recount(pp)\n recount(p)\n if(s >= 3) {\n var ppp = n_stack[s-3]\n if(ppp.right === pp) {\n ppp.right = p\n } else {\n ppp.left = p\n }\n }\n break\n }\n } else {\n var y = pp.left\n if(y && y._color === RED) {\n //console.log(\"RLr\")\n p._color = BLACK\n pp.left = repaint(BLACK, y)\n pp._color = RED\n s -= 1\n } else {\n //console.log(\"RLb\")\n p.left = n.right\n pp._color = RED\n pp.right = n.left\n n._color = BLACK\n n.right = p\n n.left = pp\n n_stack[s-2] = n\n n_stack[s-1] = p\n recount(pp)\n recount(p)\n recount(n)\n if(s >= 3) {\n var ppp = n_stack[s-3]\n if(ppp.right === pp) {\n ppp.right = n\n } else {\n ppp.left = n\n }\n }\n break\n }\n }\n }\n }\n //Return new tree\n n_stack[0]._color = BLACK\n return new RedBlackTree(cmp, n_stack[0])\n}\n\n\n//Visit all nodes inorder\nfunction doVisitFull(visit, node) {\n if(node.left) {\n var v = doVisitFull(visit, node.left)\n if(v) { return v }\n }\n var v = visit(node.key, node.value)\n if(v) { return v }\n if(node.right) {\n return doVisitFull(visit, node.right)\n }\n}\n\n//Visit half nodes in order\nfunction doVisitHalf(lo, compare, visit, node) {\n var l = compare(lo, node.key)\n if(l <= 0) {\n if(node.left) {\n var v = doVisitHalf(lo, compare, visit, node.left)\n if(v) { return v }\n }\n var v = visit(node.key, node.value)\n if(v) { return v }\n }\n if(node.right) {\n return doVisitHalf(lo, compare, visit, node.right)\n }\n}\n\n//Visit all nodes within a range\nfunction doVisit(lo, hi, compare, visit, node) {\n var l = compare(lo, node.key)\n var h = compare(hi, node.key)\n var v\n if(l <= 0) {\n if(node.left) {\n v = doVisit(lo, hi, compare, visit, node.left)\n if(v) { return v }\n }\n if(h > 0) {\n v = visit(node.key, node.value)\n if(v) { return v }\n }\n }\n if(h > 0 && node.right) {\n return doVisit(lo, hi, compare, visit, node.right)\n }\n}\n\n\nproto.forEach = function rbTreeForEach(visit, lo, hi) {\n if(!this.root) {\n return\n }\n switch(arguments.length) {\n case 1:\n return doVisitFull(visit, this.root)\n break\n\n case 2:\n return doVisitHalf(lo, this._compare, visit, this.root)\n break\n\n case 3:\n if(this._compare(lo, hi) >= 0) {\n return\n }\n return doVisit(lo, hi, this._compare, visit, this.root)\n break\n }\n}\n\n//First item in list\nObject.defineProperty(proto, \"begin\", {\n get: function() {\n var stack = []\n var n = this.root\n while(n) {\n stack.push(n)\n n = n.left\n }\n return new RedBlackTreeIterator(this, stack)\n }\n})\n\n//Last item in list\nObject.defineProperty(proto, \"end\", {\n get: function() {\n var stack = []\n var n = this.root\n while(n) {\n stack.push(n)\n n = n.right\n }\n return new RedBlackTreeIterator(this, stack)\n }\n})\n\n//Find the ith item in the tree\nproto.at = function(idx) {\n if(idx < 0) {\n return new RedBlackTreeIterator(this, [])\n }\n var n = this.root\n var stack = []\n while(true) {\n stack.push(n)\n if(n.left) {\n if(idx < n.left._count) {\n n = n.left\n continue\n }\n idx -= n.left._count\n }\n if(!idx) {\n return new RedBlackTreeIterator(this, stack)\n }\n idx -= 1\n if(n.right) {\n if(idx >= n.right._count) {\n break\n }\n n = n.right\n } else {\n break\n }\n }\n return new RedBlackTreeIterator(this, [])\n}\n\nproto.ge = function(key) {\n var cmp = this._compare\n var n = this.root\n var stack = []\n var last_ptr = 0\n while(n) {\n var d = cmp(key, n.key)\n stack.push(n)\n if(d <= 0) {\n last_ptr = stack.length\n }\n if(d <= 0) {\n n = n.left\n } else {\n n = n.right\n }\n }\n stack.length = last_ptr\n return new RedBlackTreeIterator(this, stack)\n}\n\nproto.gt = function(key) {\n var cmp = this._compare\n var n = this.root\n var stack = []\n var last_ptr = 0\n while(n) {\n var d = cmp(key, n.key)\n stack.push(n)\n if(d < 0) {\n last_ptr = stack.length\n }\n if(d < 0) {\n n = n.left\n } else {\n n = n.right\n }\n }\n stack.length = last_ptr\n return new RedBlackTreeIterator(this, stack)\n}\n\nproto.lt = function(key) {\n var cmp = this._compare\n var n = this.root\n var stack = []\n var last_ptr = 0\n while(n) {\n var d = cmp(key, n.key)\n stack.push(n)\n if(d > 0) {\n last_ptr = stack.length\n }\n if(d <= 0) {\n n = n.left\n } else {\n n = n.right\n }\n }\n stack.length = last_ptr\n return new RedBlackTreeIterator(this, stack)\n}\n\nproto.le = function(key) {\n var cmp = this._compare\n var n = this.root\n var stack = []\n var last_ptr = 0\n while(n) {\n var d = cmp(key, n.key)\n stack.push(n)\n if(d >= 0) {\n last_ptr = stack.length\n }\n if(d < 0) {\n n = n.left\n } else {\n n = n.right\n }\n }\n stack.length = last_ptr\n return new RedBlackTreeIterator(this, stack)\n}\n\n//Finds the item with key if it exists\nproto.find = function(key) {\n var cmp = this._compare\n var n = this.root\n var stack = []\n while(n) {\n var d = cmp(key, n.key)\n stack.push(n)\n if(d === 0) {\n return new RedBlackTreeIterator(this, stack)\n }\n if(d <= 0) {\n n = n.left\n } else {\n n = n.right\n }\n }\n return new RedBlackTreeIterator(this, [])\n}\n\n//Removes item with key from tree\nproto.remove = function(key) {\n var iter = this.find(key)\n if(iter) {\n return iter.remove()\n }\n return this\n}\n\n//Returns the item at `key`\nproto.get = function(key) {\n var cmp = this._compare\n var n = this.root\n while(n) {\n var d = cmp(key, n.key)\n if(d === 0) {\n return n.value\n }\n if(d <= 0) {\n n = n.left\n } else {\n n = n.right\n }\n }\n return\n}\n\n//Iterator for red black tree\nfunction RedBlackTreeIterator(tree, stack) {\n this.tree = tree\n this._stack = stack\n}\n\nvar iproto = RedBlackTreeIterator.prototype\n\n//Test if iterator is valid\nObject.defineProperty(iproto, \"valid\", {\n get: function() {\n return this._stack.length > 0\n }\n})\n\n//Node of the iterator\nObject.defineProperty(iproto, \"node\", {\n get: function() {\n if(this._stack.length > 0) {\n return this._stack[this._stack.length-1]\n }\n return null\n },\n enumerable: true\n})\n\n//Makes a copy of an iterator\niproto.clone = function() {\n return new RedBlackTreeIterator(this.tree, this._stack.slice())\n}\n\n//Swaps two nodes\nfunction swapNode(n, v) {\n n.key = v.key\n n.value = v.value\n n.left = v.left\n n.right = v.right\n n._color = v._color\n n._count = v._count\n}\n\n//Fix up a double black node in a tree\nfunction fixDoubleBlack(stack) {\n var n, p, s, z\n for(var i=stack.length-1; i>=0; --i) {\n n = stack[i]\n if(i === 0) {\n n._color = BLACK\n return\n }\n //console.log(\"visit node:\", n.key, i, stack[i].key, stack[i-1].key)\n p = stack[i-1]\n if(p.left === n) {\n //console.log(\"left child\")\n s = p.right\n if(s.right && s.right._color === RED) {\n //console.log(\"case 1: right sibling child red\")\n s = p.right = cloneNode(s)\n z = s.right = cloneNode(s.right)\n p.right = s.left\n s.left = p\n s.right = z\n s._color = p._color\n n._color = BLACK\n p._color = BLACK\n z._color = BLACK\n recount(p)\n recount(s)\n if(i > 1) {\n var pp = stack[i-2]\n if(pp.left === p) {\n pp.left = s\n } else {\n pp.right = s\n }\n }\n stack[i-1] = s\n return\n } else if(s.left && s.left._color === RED) {\n //console.log(\"case 1: left sibling child red\")\n s = p.right = cloneNode(s)\n z = s.left = cloneNode(s.left)\n p.right = z.left\n s.left = z.right\n z.left = p\n z.right = s\n z._color = p._color\n p._color = BLACK\n s._color = BLACK\n n._color = BLACK\n recount(p)\n recount(s)\n recount(z)\n if(i > 1) {\n var pp = stack[i-2]\n if(pp.left === p) {\n pp.left = z\n } else {\n pp.right = z\n }\n }\n stack[i-1] = z\n return\n }\n if(s._color === BLACK) {\n if(p._color === RED) {\n //console.log(\"case 2: black sibling, red parent\", p.right.value)\n p._color = BLACK\n p.right = repaint(RED, s)\n return\n } else {\n //console.log(\"case 2: black sibling, black parent\", p.right.value)\n p.right = repaint(RED, s)\n continue \n }\n } else {\n //console.log(\"case 3: red sibling\")\n s = cloneNode(s)\n p.right = s.left\n s.left = p\n s._color = p._color\n p._color = RED\n recount(p)\n recount(s)\n if(i > 1) {\n var pp = stack[i-2]\n if(pp.left === p) {\n pp.left = s\n } else {\n pp.right = s\n }\n }\n stack[i-1] = s\n stack[i] = p\n if(i+1 < stack.length) {\n stack[i+1] = n\n } else {\n stack.push(n)\n }\n i = i+2\n }\n } else {\n //console.log(\"right child\")\n s = p.left\n if(s.left && s.left._color === RED) {\n //console.log(\"case 1: left sibling child red\", p.value, p._color)\n s = p.left = cloneNode(s)\n z = s.left = cloneNode(s.left)\n p.left = s.right\n s.right = p\n s.left = z\n s._color = p._color\n n._color = BLACK\n p._color = BLACK\n z._color = BLACK\n recount(p)\n recount(s)\n if(i > 1) {\n var pp = stack[i-2]\n if(pp.right === p) {\n pp.right = s\n } else {\n pp.left = s\n }\n }\n stack[i-1] = s\n return\n } else if(s.right && s.right._color === RED) {\n //console.log(\"case 1: right sibling child red\")\n s = p.left = cloneNode(s)\n z = s.right = cloneNode(s.right)\n p.left = z.right\n s.right = z.left\n z.right = p\n z.left = s\n z._color = p._color\n p._color = BLACK\n s._color = BLACK\n n._color = BLACK\n recount(p)\n recount(s)\n recount(z)\n if(i > 1) {\n var pp = stack[i-2]\n if(pp.right === p) {\n pp.right = z\n } else {\n pp.left = z\n }\n }\n stack[i-1] = z\n return\n }\n if(s._color === BLACK) {\n if(p._color === RED) {\n //console.log(\"case 2: black sibling, red parent\")\n p._color = BLACK\n p.left = repaint(RED, s)\n return\n } else {\n //console.log(\"case 2: black sibling, black parent\")\n p.left = repaint(RED, s)\n continue \n }\n } else {\n //console.log(\"case 3: red sibling\")\n s = cloneNode(s)\n p.left = s.right\n s.right = p\n s._color = p._color\n p._color = RED\n recount(p)\n recount(s)\n if(i > 1) {\n var pp = stack[i-2]\n if(pp.right === p) {\n pp.right = s\n } else {\n pp.left = s\n }\n }\n stack[i-1] = s\n stack[i] = p\n if(i+1 < stack.length) {\n stack[i+1] = n\n } else {\n stack.push(n)\n }\n i = i+2\n }\n }\n }\n}\n\n//Removes item at iterator from tree\niproto.remove = function() {\n var stack = this._stack\n if(stack.length === 0) {\n return this.tree\n }\n //First copy path to node\n var cstack = new Array(stack.length)\n var n = stack[stack.length-1]\n cstack[cstack.length-1] = new RBNode(n._color, n.key, n.value, n.left, n.right, n._count)\n for(var i=stack.length-2; i>=0; --i) {\n var n = stack[i]\n if(n.left === stack[i+1]) {\n cstack[i] = new RBNode(n._color, n.key, n.value, cstack[i+1], n.right, n._count)\n } else {\n cstack[i] = new RBNode(n._color, n.key, n.value, n.left, cstack[i+1], n._count)\n }\n }\n\n //Get node\n n = cstack[cstack.length-1]\n //console.log(\"start remove: \", n.value)\n\n //If not leaf, then swap with previous node\n if(n.left && n.right) {\n //console.log(\"moving to leaf\")\n\n //First walk to previous leaf\n var split = cstack.length\n n = n.left\n while(n.right) {\n cstack.push(n)\n n = n.right\n }\n //Copy path to leaf\n var v = cstack[split-1]\n cstack.push(new RBNode(n._color, v.key, v.value, n.left, n.right, n._count))\n cstack[split-1].key = n.key\n cstack[split-1].value = n.value\n\n //Fix up stack\n for(var i=cstack.length-2; i>=split; --i) {\n n = cstack[i]\n cstack[i] = new RBNode(n._color, n.key, n.value, n.left, cstack[i+1], n._count)\n }\n cstack[split-1].left = cstack[split]\n }\n //console.log(\"stack=\", cstack.map(function(v) { return v.value }))\n\n //Remove leaf node\n n = cstack[cstack.length-1]\n if(n._color === RED) {\n //Easy case: removing red leaf\n //console.log(\"RED leaf\")\n var p = cstack[cstack.length-2]\n if(p.left === n) {\n p.left = null\n } else if(p.right === n) {\n p.right = null\n }\n cstack.pop()\n for(var i=0; i 0) {\n return this._stack[this._stack.length-1].key\n }\n return\n },\n enumerable: true\n})\n\n//Returns value\nObject.defineProperty(iproto, \"value\", {\n get: function() {\n if(this._stack.length > 0) {\n return this._stack[this._stack.length-1].value\n }\n return\n },\n enumerable: true\n})\n\n\n//Returns the position of this iterator in the sorted list\nObject.defineProperty(iproto, \"index\", {\n get: function() {\n var idx = 0\n var stack = this._stack\n if(stack.length === 0) {\n var r = this.tree.root\n if(r) {\n return r._count\n }\n return 0\n } else if(stack[stack.length-1].left) {\n idx = stack[stack.length-1].left._count\n }\n for(var s=stack.length-2; s>=0; --s) {\n if(stack[s+1] === stack[s].right) {\n ++idx\n if(stack[s].left) {\n idx += stack[s].left._count\n }\n }\n }\n return idx\n },\n enumerable: true\n})\n\n//Advances iterator to next element in list\niproto.next = function() {\n var stack = this._stack\n if(stack.length === 0) {\n return\n }\n var n = stack[stack.length-1]\n if(n.right) {\n n = n.right\n while(n) {\n stack.push(n)\n n = n.left\n }\n } else {\n stack.pop()\n while(stack.length > 0 && stack[stack.length-1].right === n) {\n n = stack[stack.length-1]\n stack.pop()\n }\n }\n}\n\n//Checks if iterator is at end of tree\nObject.defineProperty(iproto, \"hasNext\", {\n get: function() {\n var stack = this._stack\n if(stack.length === 0) {\n return false\n }\n if(stack[stack.length-1].right) {\n return true\n }\n for(var s=stack.length-1; s>0; --s) {\n if(stack[s-1].left === stack[s]) {\n return true\n }\n }\n return false\n }\n})\n\n//Update value\niproto.update = function(value) {\n var stack = this._stack\n if(stack.length === 0) {\n throw new Error(\"Can't update empty node!\")\n }\n var cstack = new Array(stack.length)\n var n = stack[stack.length-1]\n cstack[cstack.length-1] = new RBNode(n._color, n.key, value, n.left, n.right, n._count)\n for(var i=stack.length-2; i>=0; --i) {\n n = stack[i]\n if(n.left === stack[i+1]) {\n cstack[i] = new RBNode(n._color, n.key, n.value, cstack[i+1], n.right, n._count)\n } else {\n cstack[i] = new RBNode(n._color, n.key, n.value, n.left, cstack[i+1], n._count)\n }\n }\n return new RedBlackTree(this.tree._compare, cstack[0])\n}\n\n//Moves iterator backward one element\niproto.prev = function() {\n var stack = this._stack\n if(stack.length === 0) {\n return\n }\n var n = stack[stack.length-1]\n if(n.left) {\n n = n.left\n while(n) {\n stack.push(n)\n n = n.right\n }\n } else {\n stack.pop()\n while(stack.length > 0 && stack[stack.length-1].left === n) {\n n = stack[stack.length-1]\n stack.pop()\n }\n }\n}\n\n//Checks if iterator is at start of tree\nObject.defineProperty(iproto, \"hasPrev\", {\n get: function() {\n var stack = this._stack\n if(stack.length === 0) {\n return false\n }\n if(stack[stack.length-1].left) {\n return true\n }\n for(var s=stack.length-1; s>0; --s) {\n if(stack[s-1].right === stack[s]) {\n return true\n }\n }\n return false\n }\n})\n\n//Default comparison function\nfunction defaultCompare(a, b) {\n if(a < b) {\n return -1\n }\n if(a > b) {\n return 1\n }\n return 0\n}\n\n//Build a tree\nfunction createRBTree(compare) {\n return new RedBlackTree(compare || defaultCompare, null)\n}\n\n/***/ }),\n\n/***/ 3837:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = createAxes\n\nvar createText = __webpack_require__(4935)\nvar createLines = __webpack_require__(501)\nvar createBackground = __webpack_require__(5304)\nvar getCubeProperties = __webpack_require__(6429)\nvar Ticks = __webpack_require__(6444)\n\nvar identity = new Float32Array([\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1])\n\nvar ab = ArrayBuffer\nvar dv = DataView\n\nfunction isTypedArray(a) {\n return ab.isView(a) && !(a instanceof dv)\n}\n\nfunction isArrayOrTypedArray(a) {\n return Array.isArray(a) || isTypedArray(a)\n}\n\nfunction copyVec3(a, b) {\n a[0] = b[0]\n a[1] = b[1]\n a[2] = b[2]\n return a\n}\n\nfunction Axes(gl) {\n this.gl = gl\n\n this.pixelRatio = 1\n\n this.bounds = [ [-10, -10, -10],\n [ 10, 10, 10] ]\n this.ticks = [ [], [], [] ]\n this.autoTicks = true\n this.tickSpacing = [ 1, 1, 1 ]\n\n this.tickEnable = [ true, true, true ]\n this.tickFont = [ 'sans-serif', 'sans-serif', 'sans-serif' ]\n this.tickFontStyle = [ 'normal', 'normal', 'normal' ]\n this.tickFontWeight = [ 'normal', 'normal', 'normal' ]\n this.tickFontVariant = [ 'normal', 'normal', 'normal' ]\n this.tickSize = [ 12, 12, 12 ]\n this.tickAngle = [ 0, 0, 0 ]\n this.tickAlign = [ 'auto', 'auto', 'auto' ]\n this.tickColor = [ [0,0,0,1], [0,0,0,1], [0,0,0,1] ]\n this.tickPad = [ 10, 10, 10 ]\n\n this.lastCubeProps = {\n cubeEdges: [0,0,0],\n axis: [0,0,0]\n }\n\n this.labels = [ 'x', 'y', 'z' ]\n this.labelEnable = [ true, true, true ]\n this.labelFont = [ 'sans-serif', 'sans-serif', 'sans-serif' ]\n this.labelFontStyle = [ 'normal', 'normal', 'normal' ]\n this.labelFontWeight = [ 'normal', 'normal', 'normal' ]\n this.labelFontVariant = [ 'normal', 'normal', 'normal' ]\n this.labelSize = [ 20, 20, 20 ]\n this.labelAngle = [ 0, 0, 0 ]\n this.labelAlign = [ 'auto', 'auto', 'auto' ]\n this.labelColor = [ [0,0,0,1], [0,0,0,1], [0,0,0,1] ]\n this.labelPad = [ 10, 10, 10 ]\n\n this.lineEnable = [ true, true, true ]\n this.lineMirror = [ false, false, false ]\n this.lineWidth = [ 1, 1, 1 ]\n this.lineColor = [ [0,0,0,1], [0,0,0,1], [0,0,0,1] ]\n\n this.lineTickEnable = [ true, true, true ]\n this.lineTickMirror = [ false, false, false ]\n this.lineTickLength = [ 0, 0, 0 ]\n this.lineTickWidth = [ 1, 1, 1 ]\n this.lineTickColor = [ [0,0,0,1], [0,0,0,1], [0,0,0,1] ]\n\n this.gridEnable = [ true, true, true ]\n this.gridWidth = [ 1, 1, 1 ]\n this.gridColor = [ [0,0,0,1], [0,0,0,1], [0,0,0,1] ]\n\n this.zeroEnable = [ true, true, true ]\n this.zeroLineColor = [ [0,0,0,1], [0,0,0,1], [0,0,0,1] ]\n this.zeroLineWidth = [ 2, 2, 2 ]\n\n this.backgroundEnable = [ false, false, false ]\n this.backgroundColor = [ [0.8, 0.8, 0.8, 0.5],\n [0.8, 0.8, 0.8, 0.5],\n [0.8, 0.8, 0.8, 0.5] ]\n\n this._firstInit = true\n this._text = null\n this._lines = null\n this._background = createBackground(gl)\n}\n\nvar proto = Axes.prototype\n\nproto.update = function(options) {\n options = options || {}\n\n //Option parsing helper functions\n function parseOption(nest, cons, name) {\n if(name in options) {\n var opt = options[name]\n var prev = this[name]\n var next\n if(nest ? (isArrayOrTypedArray(opt) && isArrayOrTypedArray(opt[0])) :\n isArrayOrTypedArray(opt) ) {\n this[name] = next = [ cons(opt[0]), cons(opt[1]), cons(opt[2]) ]\n } else {\n this[name] = next = [ cons(opt), cons(opt), cons(opt) ]\n }\n for(var i=0; i<3; ++i) {\n if(next[i] !== prev[i]) {\n return true\n }\n }\n }\n return false\n }\n\n var NUMBER = parseOption.bind(this, false, Number)\n var BOOLEAN = parseOption.bind(this, false, Boolean)\n var STRING = parseOption.bind(this, false, String)\n var COLOR = parseOption.bind(this, true, function(v) {\n if(isArrayOrTypedArray(v)) {\n if(v.length === 3) {\n return [ +v[0], +v[1], +v[2], 1.0 ]\n } else if(v.length === 4) {\n return [ +v[0], +v[1], +v[2], +v[3] ]\n }\n }\n return [ 0, 0, 0, 1 ]\n })\n\n //Tick marks and bounds\n var nextTicks\n var ticksUpdate = false\n var boundsChanged = false\n if('bounds' in options) {\n var bounds = options.bounds\ni_loop:\n for(var i=0; i<2; ++i) {\n for(var j=0; j<3; ++j) {\n if(bounds[i][j] !== this.bounds[i][j]) {\n boundsChanged = true\n }\n this.bounds[i][j] = bounds[i][j]\n }\n }\n }\n if('ticks' in options) {\n nextTicks = options.ticks\n ticksUpdate = true\n this.autoTicks = false\n for(var i=0; i<3; ++i) {\n this.tickSpacing[i] = 0.0\n }\n } else if(NUMBER('tickSpacing')) {\n this.autoTicks = true\n boundsChanged = true\n }\n\n if(this._firstInit) {\n if(!('ticks' in options || 'tickSpacing' in options)) {\n this.autoTicks = true\n }\n\n //Force tick recomputation on first update\n boundsChanged = true\n ticksUpdate = true\n this._firstInit = false\n }\n\n if(boundsChanged && this.autoTicks) {\n nextTicks = Ticks.create(this.bounds, this.tickSpacing)\n ticksUpdate = true\n }\n\n //Compare next ticks to previous ticks, only update if needed\n if(ticksUpdate) {\n for(var i=0; i<3; ++i) {\n nextTicks[i].sort(function(a,b) {\n return a.x-b.x\n })\n }\n if(Ticks.equal(nextTicks, this.ticks)) {\n ticksUpdate = false\n } else {\n this.ticks = nextTicks\n }\n }\n\n //Parse tick properties\n BOOLEAN('tickEnable')\n\n //If font changes, must rebuild vbo\n if(STRING('tickFont')) ticksUpdate = true\n if(STRING('tickFontStyle')) ticksUpdate = true\n if(STRING('tickFontWeight')) ticksUpdate = true\n if(STRING('tickFontVariant')) ticksUpdate = true\n\n NUMBER('tickSize')\n NUMBER('tickAngle')\n NUMBER('tickPad')\n COLOR('tickColor')\n\n //Axis labels\n var labelUpdate = STRING('labels')\n\n if(STRING('labelFont')) labelUpdate = true\n if(STRING('labelFontStyle')) labelUpdate = true\n if(STRING('labelFontWeight')) labelUpdate = true\n if(STRING('labelFontVariant')) labelUpdate = true\n\n BOOLEAN('labelEnable')\n NUMBER('labelSize')\n NUMBER('labelPad')\n COLOR('labelColor')\n\n //Axis lines\n BOOLEAN('lineEnable')\n BOOLEAN('lineMirror')\n NUMBER('lineWidth')\n COLOR('lineColor')\n\n //Axis line ticks\n BOOLEAN('lineTickEnable')\n BOOLEAN('lineTickMirror')\n NUMBER('lineTickLength')\n NUMBER('lineTickWidth')\n COLOR('lineTickColor')\n\n //Grid lines\n BOOLEAN('gridEnable')\n NUMBER('gridWidth')\n COLOR('gridColor')\n\n //Zero line\n BOOLEAN('zeroEnable')\n COLOR('zeroLineColor')\n NUMBER('zeroLineWidth')\n\n //Background\n BOOLEAN('backgroundEnable')\n COLOR('backgroundColor')\n\n var labelFontOpts = [\n {\n family: this.labelFont[0],\n style: this.labelFontStyle[0],\n weight: this.labelFontWeight[0],\n variant: this.labelFontVariant[0],\n },\n {\n family: this.labelFont[1],\n style: this.labelFontStyle[1],\n weight: this.labelFontWeight[1],\n variant: this.labelFontVariant[1],\n },\n {\n family: this.labelFont[2],\n style: this.labelFontStyle[2],\n weight: this.labelFontWeight[2],\n variant: this.labelFontVariant[2],\n }\n ]\n\n var tickFontOpts = [\n {\n family: this.tickFont[0],\n style: this.tickFontStyle[0],\n weight: this.tickFontWeight[0],\n variant: this.tickFontVariant[0],\n },\n {\n family: this.tickFont[1],\n style: this.tickFontStyle[1],\n weight: this.tickFontWeight[1],\n variant: this.tickFontVariant[1],\n },\n {\n family: this.tickFont[2],\n style: this.tickFontStyle[2],\n weight: this.tickFontWeight[2],\n variant: this.tickFontVariant[2],\n }\n ]\n\n //Update text if necessary\n if(!this._text) {\n this._text = createText(\n this.gl,\n this.bounds,\n this.labels,\n labelFontOpts,\n this.ticks,\n tickFontOpts)\n } else if(this._text && (labelUpdate || ticksUpdate)) {\n this._text.update(\n this.bounds,\n this.labels,\n labelFontOpts,\n this.ticks,\n tickFontOpts)\n }\n\n //Update lines if necessary\n if(this._lines && ticksUpdate) {\n this._lines.dispose()\n this._lines = null\n }\n if(!this._lines) {\n this._lines = createLines(this.gl, this.bounds, this.ticks)\n }\n}\n\nfunction OffsetInfo() {\n this.primalOffset = [0,0,0]\n this.primalMinor = [0,0,0]\n this.mirrorOffset = [0,0,0]\n this.mirrorMinor = [0,0,0]\n}\n\nvar LINE_OFFSET = [ new OffsetInfo(), new OffsetInfo(), new OffsetInfo() ]\n\nfunction computeLineOffset(result, i, bounds, cubeEdges, cubeAxis) {\n var primalOffset = result.primalOffset\n var primalMinor = result.primalMinor\n var dualOffset = result.mirrorOffset\n var dualMinor = result.mirrorMinor\n var e = cubeEdges[i]\n\n //Calculate offsets\n for(var j=0; j<3; ++j) {\n if(i === j) {\n continue\n }\n var a = primalOffset,\n b = dualOffset,\n c = primalMinor,\n d = dualMinor\n if(e & (1< 0) {\n c[j] = -1\n d[j] = 0\n } else {\n c[j] = 0\n d[j] = +1\n }\n }\n}\n\nvar CUBE_ENABLE = [0,0,0]\nvar DEFAULT_PARAMS = {\n model: identity,\n view: identity,\n projection: identity,\n _ortho: false\n}\n\nproto.isOpaque = function() {\n return true\n}\n\nproto.isTransparent = function() {\n return false\n}\n\nproto.drawTransparent = function(params) {}\n\nvar ALIGN_OPTION_AUTO = 0 // i.e. as defined in the shader the text would rotate to stay upwards range: [-90,90]\n\nvar PRIMAL_MINOR = [0,0,0]\nvar MIRROR_MINOR = [0,0,0]\nvar PRIMAL_OFFSET = [0,0,0]\n\nproto.draw = function(params) {\n params = params || DEFAULT_PARAMS\n\n var gl = this.gl\n\n //Geometry for camera and axes\n var model = params.model || identity\n var view = params.view || identity\n var projection = params.projection || identity\n var bounds = this.bounds\n var isOrtho = params._ortho || false\n\n //Unpack axis info\n var cubeParams = getCubeProperties(model, view, projection, bounds, isOrtho)\n var cubeEdges = cubeParams.cubeEdges\n var cubeAxis = cubeParams.axis\n\n var cx = view[12]\n var cy = view[13]\n var cz = view[14]\n var cw = view[15]\n\n var orthoFix = (isOrtho) ? 2 : 1 // double up padding for orthographic ticks & labels\n var pixelScaleF = orthoFix * this.pixelRatio * (projection[3]*cx + projection[7]*cy + projection[11]*cz + projection[15]*cw) / gl.drawingBufferHeight\n\n for(var i=0; i<3; ++i) {\n this.lastCubeProps.cubeEdges[i] = cubeEdges[i]\n this.lastCubeProps.axis[i] = cubeAxis[i]\n }\n\n //Compute axis info\n var lineOffset = LINE_OFFSET\n for(var i=0; i<3; ++i) {\n computeLineOffset(\n LINE_OFFSET[i],\n i,\n this.bounds,\n cubeEdges,\n cubeAxis)\n }\n\n //Set up state parameters\n var gl = this.gl\n\n //Draw background first\n var cubeEnable = CUBE_ENABLE\n for(var i=0; i<3; ++i) {\n if(this.backgroundEnable[i]) {\n cubeEnable[i] = cubeAxis[i]\n } else {\n cubeEnable[i] = 0\n }\n }\n\n this._background.draw(\n model,\n view,\n projection,\n bounds,\n cubeEnable,\n this.backgroundColor)\n\n //Draw lines\n this._lines.bind(\n model,\n view,\n projection,\n this)\n\n //First draw grid lines and zero lines\n for(var i=0; i<3; ++i) {\n var x = [0,0,0]\n if(cubeAxis[i] > 0) {\n x[i] = bounds[1][i]\n } else {\n x[i] = bounds[0][i]\n }\n\n //Draw grid lines\n for(var j=0; j<2; ++j) {\n var u = (i + 1 + j) % 3\n var v = (i + 1 + (j^1)) % 3\n if(this.gridEnable[u]) {\n this._lines.drawGrid(u, v, this.bounds, x, this.gridColor[u], this.gridWidth[u]*this.pixelRatio)\n }\n }\n\n //Draw zero lines (need to do this AFTER all grid lines are drawn)\n for(var j=0; j<2; ++j) {\n var u = (i + 1 + j) % 3\n var v = (i + 1 + (j^1)) % 3\n if(this.zeroEnable[v]) {\n //Check if zero line in bounds\n if(Math.min(bounds[0][v], bounds[1][v]) <= 0 && Math.max(bounds[0][v], bounds[1][v]) >= 0) {\n this._lines.drawZero(u, v, this.bounds, x, this.zeroLineColor[v], this.zeroLineWidth[v]*this.pixelRatio)\n }\n }\n }\n }\n\n //Then draw axis lines and tick marks\n for(var i=0; i<3; ++i) {\n\n //Draw axis lines\n if(this.lineEnable[i]) {\n this._lines.drawAxisLine(i, this.bounds, lineOffset[i].primalOffset, this.lineColor[i], this.lineWidth[i]*this.pixelRatio)\n }\n if(this.lineMirror[i]) {\n this._lines.drawAxisLine(i, this.bounds, lineOffset[i].mirrorOffset, this.lineColor[i], this.lineWidth[i]*this.pixelRatio)\n }\n\n //Compute minor axes\n var primalMinor = copyVec3(PRIMAL_MINOR, lineOffset[i].primalMinor)\n var mirrorMinor = copyVec3(MIRROR_MINOR, lineOffset[i].mirrorMinor)\n var tickLength = this.lineTickLength\n for(var j=0; j<3; ++j) {\n var scaleFactor = pixelScaleF / model[5*j]\n primalMinor[j] *= tickLength[j] * scaleFactor\n mirrorMinor[j] *= tickLength[j] * scaleFactor\n }\n\n\n\n //Draw axis line ticks\n if(this.lineTickEnable[i]) {\n this._lines.drawAxisTicks(i, lineOffset[i].primalOffset, primalMinor, this.lineTickColor[i], this.lineTickWidth[i]*this.pixelRatio)\n }\n if(this.lineTickMirror[i]) {\n this._lines.drawAxisTicks(i, lineOffset[i].mirrorOffset, mirrorMinor, this.lineTickColor[i], this.lineTickWidth[i]*this.pixelRatio)\n }\n }\n this._lines.unbind()\n\n //Draw text sprites\n this._text.bind(\n model,\n view,\n projection,\n this.pixelRatio)\n\n var alignOpt // options in shader are from this list {-1, 0, 1, 2, 3, ..., n}\n // -1: backward compatible\n // 0: raw data\n // 1: auto align, free angles\n // 2: auto align, horizontal or vertical\n //3-n: auto align, round to n directions e.g. 12 -> round to angles with 30-degree steps\n\n var hv_ratio = 0.5 // can have an effect on the ratio between horizontals and verticals when using option 2\n\n var enableAlign\n var alignDir\n\n function alignTo(i) {\n alignDir = [0,0,0]\n alignDir[i] = 1\n }\n\n function solveTickAlignments(i, minor, major) {\n\n var i1 = (i + 1) % 3\n var i2 = (i + 2) % 3\n\n var A = minor[i1]\n var B = minor[i2]\n var C = major[i1]\n var D = major[i2]\n\n if ((A > 0) && (D > 0)) { alignTo(i1); return; }\n else if ((A > 0) && (D < 0)) { alignTo(i1); return; }\n else if ((A < 0) && (D > 0)) { alignTo(i1); return; }\n else if ((A < 0) && (D < 0)) { alignTo(i1); return; }\n else if ((B > 0) && (C > 0)) { alignTo(i2); return; }\n else if ((B > 0) && (C < 0)) { alignTo(i2); return; }\n else if ((B < 0) && (C > 0)) { alignTo(i2); return; }\n else if ((B < 0) && (C < 0)) { alignTo(i2); return; }\n }\n\n for(var i=0; i<3; ++i) {\n\n var minor = lineOffset[i].primalMinor\n var major = lineOffset[i].mirrorMinor\n\n var offset = copyVec3(PRIMAL_OFFSET, lineOffset[i].primalOffset)\n\n for(var j=0; j<3; ++j) {\n if(this.lineTickEnable[i]) {\n offset[j] += pixelScaleF * minor[j] * Math.max(this.lineTickLength[j], 0) / model[5*j]\n }\n }\n\n var axis = [0,0,0]\n axis[i] = 1\n\n //Draw tick text\n if(this.tickEnable[i]) {\n\n if(this.tickAngle[i] === -3600) {\n this.tickAngle[i] = 0\n this.tickAlign[i] = 'auto'\n } else {\n this.tickAlign[i] = -1\n }\n\n enableAlign = 1;\n\n alignOpt = [this.tickAlign[i], hv_ratio, enableAlign]\n if(alignOpt[0] === 'auto') alignOpt[0] = ALIGN_OPTION_AUTO\n else alignOpt[0] = parseInt('' + alignOpt[0])\n\n alignDir = [0,0,0]\n solveTickAlignments(i, minor, major)\n\n //Add tick padding\n for(var j=0; j<3; ++j) {\n offset[j] += pixelScaleF * minor[j] * this.tickPad[j] / model[5*j]\n }\n\n //Draw axis\n this._text.drawTicks(\n i,\n this.tickSize[i],\n this.tickAngle[i],\n offset,\n this.tickColor[i],\n axis,\n alignDir,\n alignOpt)\n }\n\n //Draw labels\n if(this.labelEnable[i]) {\n\n enableAlign = 0\n alignDir = [0,0,0]\n if(this.labels[i].length > 4) { // for large label axis enable alignDir to axis\n alignTo(i)\n enableAlign = 1\n }\n\n alignOpt = [this.labelAlign[i], hv_ratio, enableAlign]\n if(alignOpt[0] === 'auto') alignOpt[0] = ALIGN_OPTION_AUTO\n else alignOpt[0] = parseInt('' + alignOpt[0])\n\n //Add label padding\n for(var j=0; j<3; ++j) {\n offset[j] += pixelScaleF * minor[j] * this.labelPad[j] / model[5*j]\n }\n offset[i] += 0.5 * (bounds[0][i] + bounds[1][i])\n\n //Draw axis\n this._text.drawLabel(\n i,\n this.labelSize[i],\n this.labelAngle[i],\n offset,\n this.labelColor[i],\n [0,0,0],\n alignDir,\n alignOpt)\n }\n }\n\n this._text.unbind()\n}\n\nproto.dispose = function() {\n this._text.dispose()\n this._lines.dispose()\n this._background.dispose()\n this._lines = null\n this._text = null\n this._background = null\n this.gl = null\n}\n\nfunction createAxes(gl, options) {\n var axes = new Axes(gl)\n axes.update(options)\n return axes\n}\n\n\n/***/ }),\n\n/***/ 5304:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = createBackgroundCube\n\nvar createBuffer = __webpack_require__(2762)\nvar createVAO = __webpack_require__(8116)\nvar createShader = (__webpack_require__(1879).bg)\n\nfunction BackgroundCube(gl, buffer, vao, shader) {\n this.gl = gl\n this.buffer = buffer\n this.vao = vao\n this.shader = shader\n}\n\nvar proto = BackgroundCube.prototype\n\nproto.draw = function(model, view, projection, bounds, enable, colors) {\n var needsBG = false\n for(var i=0; i<3; ++i) {\n needsBG = needsBG || enable[i]\n }\n if(!needsBG) {\n return\n }\n\n var gl = this.gl\n\n gl.enable(gl.POLYGON_OFFSET_FILL)\n gl.polygonOffset(1, 2)\n\n this.shader.bind()\n this.shader.uniforms = {\n model: model,\n view: view,\n projection: projection,\n bounds: bounds,\n enable: enable,\n colors: colors\n }\n this.vao.bind()\n this.vao.draw(this.gl.TRIANGLES, 36)\n this.vao.unbind()\n\n gl.disable(gl.POLYGON_OFFSET_FILL)\n}\n\nproto.dispose = function() {\n this.vao.dispose()\n this.buffer.dispose()\n this.shader.dispose()\n}\n\nfunction createBackgroundCube(gl) {\n //Create cube vertices\n var vertices = []\n var indices = []\n var ptr = 0\n for(var d=0; d<3; ++d) {\n var u = (d+1) % 3\n var v = (d+2) % 3\n var x = [0,0,0]\n var c = [0,0,0]\n for(var s=-1; s<=1; s+=2) {\n indices.push(ptr, ptr+2, ptr+1,\n ptr+1, ptr+2, ptr+3)\n x[d] = s\n c[d] = s\n for(var i=-1; i<=1; i+=2) {\n x[u] = i\n for(var j=-1; j<=1; j+=2) {\n x[v] = j\n vertices.push(x[0], x[1], x[2],\n c[0], c[1], c[2])\n ptr += 1\n }\n }\n //Swap u and v\n var tt = u\n u = v\n v = tt\n }\n }\n\n //Allocate buffer and vertex array\n var buffer = createBuffer(gl, new Float32Array(vertices))\n var elements = createBuffer(gl, new Uint16Array(indices), gl.ELEMENT_ARRAY_BUFFER)\n var vao = createVAO(gl, [\n {\n buffer: buffer,\n type: gl.FLOAT,\n size: 3,\n offset: 0,\n stride: 24\n },\n {\n buffer: buffer,\n type: gl.FLOAT,\n size: 3,\n offset: 12,\n stride: 24\n }\n ], elements)\n\n //Create shader object\n var shader = createShader(gl)\n shader.attributes.position.location = 0\n shader.attributes.normal.location = 1\n\n return new BackgroundCube(gl, buffer, vao, shader)\n}\n\n\n/***/ }),\n\n/***/ 6429:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = getCubeEdges\n\nvar bits = __webpack_require__(8828)\nvar multiply = __webpack_require__(6760)\nvar splitPoly = __webpack_require__(5202)\nvar orient = __webpack_require__(3250)\n\nvar mvp = new Array(16)\nvar pCubeVerts = new Array(8)\nvar cubeVerts = new Array(8)\nvar x = new Array(3)\nvar zero3 = [0,0,0]\n\n;(function() {\n for(var i=0; i<8; ++i) {\n pCubeVerts[i] =[1,1,1,1]\n cubeVerts[i] = [1,1,1]\n }\n})()\n\n\nfunction transformHg(result, x, mat) {\n for(var i=0; i<4; ++i) {\n result[i] = mat[12+i]\n for(var j=0; j<3; ++j) {\n result[i] += x[j]*mat[4*j+i]\n }\n }\n}\n\nvar FRUSTUM_PLANES = [\n [ 0, 0, 1, 0, 0],\n [ 0, 0,-1, 1, 0],\n [ 0,-1, 0, 1, 0],\n [ 0, 1, 0, 1, 0],\n [-1, 0, 0, 1, 0],\n [ 1, 0, 0, 1, 0]\n]\n\nfunction polygonArea(p) {\n for(var i=0; i o0) {\n closest |= 1< o0) {\n closest |= 1< cubeVerts[i][1]) {\n bottom = i\n }\n }\n\n //Find left/right neighbors of bottom vertex\n var left = -1\n for(var i=0; i<3; ++i) {\n var idx = bottom ^ (1< cubeVerts[right][0]) {\n right = idx\n }\n }\n\n //Determine edge axis coordinates\n var cubeEdges = CUBE_EDGES\n cubeEdges[0] = cubeEdges[1] = cubeEdges[2] = 0\n cubeEdges[bits.log2(left^bottom)] = bottom&left\n cubeEdges[bits.log2(bottom^right)] = bottom&right\n var top = right ^ 7\n if(top === closest || top === farthest) {\n top = left ^ 7\n cubeEdges[bits.log2(right^top)] = top&right\n } else {\n cubeEdges[bits.log2(left^top)] = top&left\n }\n\n //Determine visible faces\n var axis = CUBE_AXIS\n var cutCorner = closest\n for(var d=0; d<3; ++d) {\n if(cutCorner & (1< HALF_PI) && (b <= ONE_AND_HALF_PI)) ?\\n b - PI :\\n b;\\n}\\n\\nfloat look_horizontal_or_vertical(float a, float ratio) {\\n // ratio controls the ratio between being horizontal to (vertical + horizontal)\\n // if ratio is set to 0.5 then it is 50%, 50%.\\n // when using a higher ratio e.g. 0.75 the result would\\n // likely be more horizontal than vertical.\\n\\n float b = positive_angle(a);\\n\\n return\\n (b < ( ratio) * HALF_PI) ? 0.0 :\\n (b < (2.0 - ratio) * HALF_PI) ? -HALF_PI :\\n (b < (2.0 + ratio) * HALF_PI) ? 0.0 :\\n (b < (4.0 - ratio) * HALF_PI) ? HALF_PI :\\n 0.0;\\n}\\n\\nfloat roundTo(float a, float b) {\\n return float(b * floor((a + 0.5 * b) / b));\\n}\\n\\nfloat look_round_n_directions(float a, int n) {\\n float b = positive_angle(a);\\n float div = TWO_PI / float(n);\\n float c = roundTo(b, div);\\n return look_upwards(c);\\n}\\n\\nfloat applyAlignOption(float rawAngle, float delta) {\\n return\\n (option > 2) ? look_round_n_directions(rawAngle + delta, option) : // option 3-n: round to n directions\\n (option == 2) ? look_horizontal_or_vertical(rawAngle + delta, hv_ratio) : // horizontal or vertical\\n (option == 1) ? rawAngle + delta : // use free angle, and flip to align with one direction of the axis\\n (option == 0) ? look_upwards(rawAngle) : // use free angle, and stay upwards\\n (option ==-1) ? 0.0 : // useful for backward compatibility, all texts remains horizontal\\n rawAngle; // otherwise return back raw input angle\\n}\\n\\nbool isAxisTitle = (axis.x == 0.0) &&\\n (axis.y == 0.0) &&\\n (axis.z == 0.0);\\n\\nvoid main() {\\n //Compute world offset\\n float axisDistance = position.z;\\n vec3 dataPosition = axisDistance * axis + offset;\\n\\n float beta = angle; // i.e. user defined attributes for each tick\\n\\n float axisAngle;\\n float clipAngle;\\n float flip;\\n\\n if (enableAlign) {\\n axisAngle = (isAxisTitle) ? HALF_PI :\\n computeViewAngle(dataPosition, dataPosition + axis);\\n clipAngle = computeViewAngle(dataPosition, dataPosition + alignDir);\\n\\n axisAngle += (sin(axisAngle) < 0.0) ? PI : 0.0;\\n clipAngle += (sin(clipAngle) < 0.0) ? PI : 0.0;\\n\\n flip = (dot(vec2(cos(axisAngle), sin(axisAngle)),\\n vec2(sin(clipAngle),-cos(clipAngle))) > 0.0) ? 1.0 : 0.0;\\n\\n beta += applyAlignOption(clipAngle, flip * PI);\\n }\\n\\n //Compute plane offset\\n vec2 planeCoord = position.xy * pixelScale;\\n\\n mat2 planeXform = scale * mat2(\\n cos(beta), sin(beta),\\n -sin(beta), cos(beta)\\n );\\n\\n vec2 viewOffset = 2.0 * planeXform * planeCoord / resolution;\\n\\n //Compute clip position\\n vec3 clipPosition = project(dataPosition);\\n\\n //Apply text offset in clip coordinates\\n clipPosition += vec3(viewOffset, 0.0);\\n\\n //Done\\n gl_Position = vec4(clipPosition, 1.0);\\n}\\n\"])\nvar textFrag = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nuniform vec4 color;\\nvoid main() {\\n gl_FragColor = color;\\n}\"])\nexports.Q = function(gl) {\n return createShader(gl, textVert, textFrag, null, [\n {name: 'position', type: 'vec3'}\n ])\n}\n\nvar bgVert = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nattribute vec3 position;\\nattribute vec3 normal;\\n\\nuniform mat4 model, view, projection;\\nuniform vec3 enable;\\nuniform vec3 bounds[2];\\n\\nvarying vec3 colorChannel;\\n\\nvoid main() {\\n\\n vec3 signAxis = sign(bounds[1] - bounds[0]);\\n\\n vec3 realNormal = signAxis * normal;\\n\\n if(dot(realNormal, enable) > 0.0) {\\n vec3 minRange = min(bounds[0], bounds[1]);\\n vec3 maxRange = max(bounds[0], bounds[1]);\\n vec3 nPosition = mix(minRange, maxRange, 0.5 * (position + 1.0));\\n gl_Position = projection * (view * (model * vec4(nPosition, 1.0)));\\n } else {\\n gl_Position = vec4(0,0,0,0);\\n }\\n\\n colorChannel = abs(realNormal);\\n}\\n\"])\nvar bgFrag = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nuniform vec4 colors[3];\\n\\nvarying vec3 colorChannel;\\n\\nvoid main() {\\n gl_FragColor = colorChannel.x * colors[0] +\\n colorChannel.y * colors[1] +\\n colorChannel.z * colors[2];\\n}\"])\nexports.bg = function(gl) {\n return createShader(gl, bgVert, bgFrag, null, [\n {name: 'position', type: 'vec3'},\n {name: 'normal', type: 'vec3'}\n ])\n}\n\n\n/***/ }),\n\n/***/ 4935:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = createTextSprites\n\nvar createBuffer = __webpack_require__(2762)\nvar createVAO = __webpack_require__(8116)\nvar vectorizeText = __webpack_require__(4359)\nvar createShader = (__webpack_require__(1879)/* .text */ .Q)\n\nvar globals = window || process.global || {}\nvar __TEXT_CACHE = globals.__TEXT_CACHE || {}\nglobals.__TEXT_CACHE = {}\n\n//Vertex buffer format for text is:\n//\n/// [x,y,z] = Spatial coordinate\n//\n\nvar VERTEX_SIZE = 3\n\nfunction TextSprites(\n gl,\n shader,\n buffer,\n vao) {\n this.gl = gl\n this.shader = shader\n this.buffer = buffer\n this.vao = vao\n this.tickOffset =\n this.tickCount =\n this.labelOffset =\n this.labelCount = null\n}\n\nvar proto = TextSprites.prototype\n\n//Bind textures for rendering\nvar SHAPE = [0,0]\nproto.bind = function(model, view, projection, pixelScale) {\n this.vao.bind()\n this.shader.bind()\n var uniforms = this.shader.uniforms\n uniforms.model = model\n uniforms.view = view\n uniforms.projection = projection\n uniforms.pixelScale = pixelScale\n SHAPE[0] = this.gl.drawingBufferWidth\n SHAPE[1] = this.gl.drawingBufferHeight\n this.shader.uniforms.resolution = SHAPE\n}\n\nproto.unbind = function() {\n this.vao.unbind()\n}\n\nproto.update = function(bounds, labels, labelFont, ticks, tickFont) {\n var data = []\n\n function addItem(t, text, font, size, lineSpacing, styletags) {\n var fontKey = [\n font.style,\n font.weight,\n font.variant,\n font.family\n ].join('_')\n\n var fontcache = __TEXT_CACHE[fontKey]\n if(!fontcache) {\n fontcache = __TEXT_CACHE[fontKey] = {}\n }\n var mesh = fontcache[text]\n if(!mesh) {\n mesh = fontcache[text] = tryVectorizeText(text, {\n triangles: true,\n font: font.family,\n fontStyle: font.style,\n fontWeight: font.weight,\n fontVariant: font.variant,\n textAlign: 'center',\n textBaseline: 'middle',\n lineSpacing: lineSpacing,\n styletags: styletags\n })\n }\n var scale = (size || 12) / 12\n var positions = mesh.positions\n var cells = mesh.cells\n for(var i=0, nc=cells.length; i=0; --j) {\n var p = positions[c[j]]\n data.push(scale*p[0], -scale*p[1], t)\n }\n }\n }\n\n //Generate sprites for all 3 axes, store data in texture atlases\n var tickOffset = [0,0,0]\n var tickCount = [0,0,0]\n var labelOffset = [0,0,0]\n var labelCount = [0,0,0]\n var lineSpacing = 1.25\n var styletags = {\n breaklines:true,\n bolds: true,\n italics: true,\n subscripts:true,\n superscripts:true\n }\n for(var d=0; d<3; ++d) {\n\n //Generate label\n labelOffset[d] = (data.length/VERTEX_SIZE)|0\n addItem(\n 0.5*(bounds[0][d]+bounds[1][d]),\n labels[d],\n labelFont[d],\n 12, // labelFontSize\n lineSpacing,\n styletags\n )\n labelCount[d] = ((data.length/VERTEX_SIZE)|0) - labelOffset[d]\n\n //Generate sprites for tick marks\n tickOffset[d] = (data.length/VERTEX_SIZE)|0\n for(var i=0; i= 0) {\n sigFigs = stepStr.length - u - 1\n }\n var shift = Math.pow(10, sigFigs)\n var x = Math.round(spacing * i * shift)\n var xstr = x + \"\"\n if(xstr.indexOf(\"e\") >= 0) {\n return xstr\n }\n var xi = x / shift, xf = x % shift\n if(x < 0) {\n xi = -Math.ceil(xi)|0\n xf = (-xf)|0\n } else {\n xi = Math.floor(xi)|0\n xf = xf|0\n }\n var xis = \"\" + xi \n if(x < 0) {\n xis = \"-\" + xis\n }\n if(sigFigs) {\n var xs = \"\" + xf\n while(xs.length < sigFigs) {\n xs = \"0\" + xs\n }\n return xis + \".\" + xs\n } else {\n return xis\n }\n}\n\nfunction defaultTicks(bounds, tickSpacing) {\n var array = []\n for(var d=0; d<3; ++d) {\n var ticks = []\n var m = 0.5*(bounds[0][d]+bounds[1][d])\n for(var t=0; t*tickSpacing[d]<=bounds[1][d]; ++t) {\n ticks.push({x: t*tickSpacing[d], text: prettyPrint(tickSpacing[d], t)})\n }\n for(var t=-1; t*tickSpacing[d]>=bounds[0][d]; --t) {\n ticks.push({x: t*tickSpacing[d], text: prettyPrint(tickSpacing[d], t)})\n }\n array.push(ticks)\n }\n return array\n}\n\nfunction ticksEqual(ticksA, ticksB) {\n for(var i=0; i<3; ++i) {\n if(ticksA[i].length !== ticksB[i].length) {\n return false\n }\n for(var j=0; j len) {\n throw new Error(\"gl-buffer: If resizing buffer, must not specify offset\")\n }\n gl.bufferSubData(type, offset, data)\n return len\n}\n\nfunction makeScratchTypeArray(array, dtype) {\n var res = pool.malloc(array.length, dtype)\n var n = array.length\n for(var i=0; i=0; --i) {\n if(stride[i] !== n) {\n return false\n }\n n *= shape[i]\n }\n return true\n}\n\nproto.update = function(array, offset) {\n if(typeof offset !== \"number\") {\n offset = -1\n }\n this.bind()\n if(typeof array === \"object\" && typeof array.shape !== \"undefined\") { //ndarray\n var dtype = array.dtype\n if(SUPPORTED_TYPES.indexOf(dtype) < 0) {\n dtype = \"float32\"\n }\n if(this.type === this.gl.ELEMENT_ARRAY_BUFFER) {\n var ext = gl.getExtension('OES_element_index_uint')\n if(ext && dtype !== \"uint16\") {\n dtype = \"uint32\"\n } else {\n dtype = \"uint16\"\n }\n }\n if(dtype === array.dtype && isPacked(array.shape, array.stride)) {\n if(array.offset === 0 && array.data.length === array.shape[0]) {\n this.length = updateTypeArray(this.gl, this.type, this.length, this.usage, array.data, offset)\n } else {\n this.length = updateTypeArray(this.gl, this.type, this.length, this.usage, array.data.subarray(array.offset, array.shape[0]), offset)\n }\n } else {\n var tmp = pool.malloc(array.size, dtype)\n var ndt = ndarray(tmp, array.shape)\n ops.assign(ndt, array)\n if(offset < 0) {\n this.length = updateTypeArray(this.gl, this.type, this.length, this.usage, tmp, offset)\n } else {\n this.length = updateTypeArray(this.gl, this.type, this.length, this.usage, tmp.subarray(0, array.size), offset)\n }\n pool.free(tmp)\n }\n } else if(Array.isArray(array)) { //Vanilla array\n var t\n if(this.type === this.gl.ELEMENT_ARRAY_BUFFER) {\n t = makeScratchTypeArray(array, \"uint16\")\n } else {\n t = makeScratchTypeArray(array, \"float32\")\n }\n if(offset < 0) {\n this.length = updateTypeArray(this.gl, this.type, this.length, this.usage, t, offset)\n } else {\n this.length = updateTypeArray(this.gl, this.type, this.length, this.usage, t.subarray(0, array.length), offset)\n }\n pool.free(t)\n } else if(typeof array === \"object\" && typeof array.length === \"number\") { //Typed array\n this.length = updateTypeArray(this.gl, this.type, this.length, this.usage, array, offset)\n } else if(typeof array === \"number\" || array === undefined) { //Number/default\n if(offset >= 0) {\n throw new Error(\"gl-buffer: Cannot specify offset when resizing buffer\")\n }\n array = array | 0\n if(array <= 0) {\n array = 1\n }\n this.gl.bufferData(this.type, array|0, this.usage)\n this.length = array\n } else { //Error, case should not happen\n throw new Error(\"gl-buffer: Invalid data type\")\n }\n}\n\nfunction createBuffer(gl, data, type, usage) {\n type = type || gl.ARRAY_BUFFER\n usage = usage || gl.DYNAMIC_DRAW\n if(type !== gl.ARRAY_BUFFER && type !== gl.ELEMENT_ARRAY_BUFFER) {\n throw new Error(\"gl-buffer: Invalid type for webgl buffer, must be either gl.ARRAY_BUFFER or gl.ELEMENT_ARRAY_BUFFER\")\n }\n if(usage !== gl.DYNAMIC_DRAW && usage !== gl.STATIC_DRAW && usage !== gl.STREAM_DRAW) {\n throw new Error(\"gl-buffer: Invalid usage for buffer, must be either gl.DYNAMIC_DRAW, gl.STATIC_DRAW or gl.STREAM_DRAW\")\n }\n var handle = gl.createBuffer()\n var result = new GLBuffer(gl, type, handle, 0, usage)\n result.update(data)\n return result\n}\n\nmodule.exports = createBuffer\n\n\n/***/ }),\n\n/***/ 6405:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar vec3 = __webpack_require__(2931);\n\nmodule.exports = function(vectorfield, bounds) {\n\tvar positions = vectorfield.positions;\n\tvar vectors = vectorfield.vectors;\n\tvar geo = {\n\t\tpositions: [],\n\t\tvertexIntensity: [],\n\t\tvertexIntensityBounds: vectorfield.vertexIntensityBounds,\n\t\tvectors: [],\n\t\tcells: [],\n\t\tconeOffset: vectorfield.coneOffset,\n\t\tcolormap: vectorfield.colormap\n\t};\n\n\tif (vectorfield.positions.length === 0) {\n\t\tif (bounds) {\n\t\t\tbounds[0] = [0,0,0];\n\t\t\tbounds[1] = [0,0,0];\n\t\t}\n\t\treturn geo;\n\t}\n\n\t// Compute bounding box for the dataset.\n\t// Compute maximum velocity for the dataset to use for scaling the cones.\n\tvar maxNorm = 0;\n\tvar minX = Infinity, maxX = -Infinity;\n\tvar minY = Infinity, maxY = -Infinity;\n\tvar minZ = Infinity, maxZ = -Infinity;\n\tvar p2 = null;\n\tvar u2 = null;\n\tvar positionVectors = [];\n\tvar vectorScale = Infinity;\n\tvar skipIt = false;\n\tvar rawSizemodemode = vectorfield.coneSizemode === 'raw';\n\tfor (var i = 0; i < positions.length; i++) {\n\t\tvar p = positions[i];\n\t\tminX = Math.min(p[0], minX);\n\t\tmaxX = Math.max(p[0], maxX);\n\t\tminY = Math.min(p[1], minY);\n\t\tmaxY = Math.max(p[1], maxY);\n\t\tminZ = Math.min(p[2], minZ);\n\t\tmaxZ = Math.max(p[2], maxZ);\n\t\tvar u = vectors[i];\n\n\t\tif (vec3.length(u) > maxNorm) {\n\t\t\tmaxNorm = vec3.length(u);\n\t\t}\n\t\tif (i && !rawSizemodemode) {\n\t\t\t// Find vector scale [w/ units of time] using \"successive\" positions\n\t\t\t// (not \"adjacent\" with would be O(n^2)),\n\t\t\t//\n\t\t\t// The vector scale corresponds to the minimum \"time\" to travel across two\n\t\t\t// two adjacent positions at the average velocity of those two adjacent positions\n\n\t\t\tvar q = (2 * vec3.distance(p2, p) / (vec3.length(u2) + vec3.length(u)));\n\t\t\tif(q) {\n\t\t\t\tvectorScale = Math.min(vectorScale, q);\n\t\t\t\tskipIt = false;\n\t\t\t} else {\n\t\t\t\tskipIt = true;\n\t\t\t}\n\t\t}\n\t\tif(!skipIt) {\n\t\t\tp2 = p;\n\t\t\tu2 = u;\n\t\t}\n\t\tpositionVectors.push(u);\n\t}\n\tvar minV = [minX, minY, minZ];\n\tvar maxV = [maxX, maxY, maxZ];\n\tif (bounds) {\n\t\tbounds[0] = minV;\n\t\tbounds[1] = maxV;\n\t}\n\tif (maxNorm === 0) {\n\t\tmaxNorm = 1;\n\t}\n\n\t// Inverted max norm would map vector with norm maxNorm to 1 coord space units in length\n\tvar invertedMaxNorm = 1 / maxNorm;\n\n\tif (!isFinite(vectorScale)) {\n\t\tvectorScale = 1.0;\n\t}\n\tgeo.vectorScale = vectorScale;\n\n\tvar coneScale = vectorfield.coneSize || (\n\t\trawSizemodemode ? 1 :0.5\n\t);\n\n\tif (vectorfield.absoluteConeSize) {\n\t\tconeScale = vectorfield.absoluteConeSize * invertedMaxNorm;\n\t}\n\n\tgeo.coneScale = coneScale;\n\n\t// Build the cone model.\n\tfor (var i = 0, j = 0; i < positions.length; i++) {\n\t\tvar p = positions[i];\n\t\tvar x = p[0], y = p[1], z = p[2];\n\t\tvar d = positionVectors[i];\n\t\tvar intensity = vec3.length(d) * invertedMaxNorm;\n\t\tfor (var k = 0, l = 8; k < l; k++) {\n\t\t\tgeo.positions.push([x, y, z, j++]);\n\t\t\tgeo.positions.push([x, y, z, j++]);\n\t\t\tgeo.positions.push([x, y, z, j++]);\n\t\t\tgeo.positions.push([x, y, z, j++]);\n\t\t\tgeo.positions.push([x, y, z, j++]);\n\t\t\tgeo.positions.push([x, y, z, j++]);\n\n\t\t\tgeo.vectors.push(d);\n\t\t\tgeo.vectors.push(d);\n\t\t\tgeo.vectors.push(d);\n\t\t\tgeo.vectors.push(d);\n\t\t\tgeo.vectors.push(d);\n\t\t\tgeo.vectors.push(d);\n\n\t\t\tgeo.vertexIntensity.push(intensity, intensity, intensity);\n\t\t\tgeo.vertexIntensity.push(intensity, intensity, intensity);\n\n\t\t\tvar m = geo.positions.length;\n\t\t\tgeo.cells.push([m-6, m-5, m-4], [m-3, m-2, m-1]);\n\t\t}\n\t}\n\n\treturn geo;\n};\n\nvar shaders = __webpack_require__(614);\nmodule.exports.createMesh = __webpack_require__(9060);\nmodule.exports.createConeMesh = function(gl, params) {\n\treturn module.exports.createMesh(gl, params, {\n\t\tshaders: shaders,\n\t\ttraceType: 'cone'\n\t});\n}\n\n\n/***/ }),\n\n/***/ 9060:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar createShader = __webpack_require__(9405)\nvar createBuffer = __webpack_require__(2762)\nvar createVAO = __webpack_require__(8116)\nvar createTexture = __webpack_require__(7766)\nvar multiply = __webpack_require__(6760)\nvar invert = __webpack_require__(7608)\nvar ndarray = __webpack_require__(9618)\nvar colormap = __webpack_require__(6729)\n\nvar IDENTITY = [\n 1,0,0,0,\n 0,1,0,0,\n 0,0,1,0,\n 0,0,0,1]\n\nfunction VectorMesh(gl\n , texture\n , triShader\n , pickShader\n , trianglePositions\n , triangleVectors\n , triangleIds\n , triangleColors\n , triangleUVs\n , triangleVAO\n , traceType) {\n\n this.gl = gl\n this.pixelRatio = 1\n this.cells = []\n this.positions = []\n this.intensity = []\n this.texture = texture\n this.dirty = true\n\n this.triShader = triShader\n this.pickShader = pickShader\n\n this.trianglePositions = trianglePositions\n this.triangleVectors = triangleVectors\n this.triangleColors = triangleColors\n this.triangleUVs = triangleUVs\n this.triangleIds = triangleIds\n this.triangleVAO = triangleVAO\n this.triangleCount = 0\n\n this.pickId = 1\n this.bounds = [\n [ Infinity, Infinity, Infinity],\n [-Infinity,-Infinity,-Infinity] ]\n this.clipBounds = [\n [-Infinity,-Infinity,-Infinity],\n [ Infinity, Infinity, Infinity] ]\n\n this.lightPosition = [1e5, 1e5, 0]\n this.ambientLight = 0.8\n this.diffuseLight = 0.8\n this.specularLight = 2.0\n this.roughness = 0.5\n this.fresnel = 1.5\n\n this.opacity = 1\n\n this.traceType = traceType\n this.tubeScale = 1 // used in streamtube\n this.coneScale = 2 // used in cone\n this.vectorScale = 1 // used in cone\n this.coneOffset = 0.25 // used in cone\n\n this._model = IDENTITY\n this._view = IDENTITY\n this._projection = IDENTITY\n this._resolution = [1,1]\n}\n\nvar proto = VectorMesh.prototype\n\nproto.isOpaque = function() {\n return this.opacity >= 1\n}\n\nproto.isTransparent = function() {\n return this.opacity < 1\n}\n\nproto.pickSlots = 1\n\nproto.setPickBase = function(id) {\n this.pickId = id\n}\n\nfunction genColormap(param) {\n var colors = colormap({\n colormap: param\n , nshades: 256\n , format: 'rgba'\n })\n\n var result = new Uint8Array(256*4)\n for(var i=0; i<256; ++i) {\n var c = colors[i]\n for(var j=0; j<3; ++j) {\n result[4*i+j] = c[j]\n }\n result[4*i+3] = c[3]*255\n }\n\n return ndarray(result, [256,256,4], [4,0,1])\n}\n\nfunction takeZComponent(array) {\n var n = array.length\n var result = new Array(n)\n for(var i=0; i 0) {\n var shader = this.triShader\n shader.bind()\n shader.uniforms = uniforms\n\n this.triangleVAO.bind()\n gl.drawArrays(gl.TRIANGLES, 0, this.triangleCount*3)\n this.triangleVAO.unbind()\n }\n}\n\nproto.drawPick = function(params) {\n params = params || {}\n\n var gl = this.gl\n\n var model = params.model || IDENTITY\n var view = params.view || IDENTITY\n var projection = params.projection || IDENTITY\n\n var clipBounds = [[-1e6,-1e6,-1e6],[1e6,1e6,1e6]]\n for(var i=0; i<3; ++i) {\n clipBounds[0][i] = Math.max(clipBounds[0][i], this.clipBounds[0][i])\n clipBounds[1][i] = Math.min(clipBounds[1][i], this.clipBounds[1][i])\n }\n\n //Save camera parameters\n this._model = [].slice.call(model)\n this._view = [].slice.call(view)\n this._projection = [].slice.call(projection)\n this._resolution = [gl.drawingBufferWidth, gl.drawingBufferHeight]\n\n var uniforms = {\n model: model,\n view: view,\n projection: projection,\n clipBounds: clipBounds,\n\n tubeScale: this.tubeScale,\n vectorScale: this.vectorScale,\n coneScale: this.coneScale,\n coneOffset: this.coneOffset,\n\n pickId: this.pickId / 255.0,\n }\n\n var shader = this.pickShader\n shader.bind()\n shader.uniforms = uniforms\n\n if(this.triangleCount > 0) {\n this.triangleVAO.bind()\n gl.drawArrays(gl.TRIANGLES, 0, this.triangleCount*3)\n this.triangleVAO.unbind()\n }\n}\n\n\nproto.pick = function(pickData) {\n if(!pickData) {\n return null\n }\n if(pickData.id !== this.pickId) {\n return null\n }\n\n var cellId = pickData.value[0] + 256*pickData.value[1] + 65536*pickData.value[2]\n var cell = this.cells[cellId]\n var pos = this.positions[cell[1]].slice(0, 3)\n\n var result = {\n position: pos,\n dataCoordinate: pos,\n index: Math.floor(cell[1] / 48)\n }\n\n\n if(this.traceType === 'cone') {\n result.index = Math.floor(cell[1] / 48)\n } else if(this.traceType === 'streamtube') {\n result.intensity = this.intensity[cell[1]]\n result.velocity = this.vectors[cell[1]].slice(0, 3)\n result.divergence = this.vectors[cell[1]][3]\n result.index = cellId\n }\n\n return result\n}\n\n\nproto.dispose = function() {\n this.texture.dispose()\n\n this.triShader.dispose()\n this.pickShader.dispose()\n\n this.triangleVAO.dispose()\n this.trianglePositions.dispose()\n this.triangleVectors.dispose()\n this.triangleColors.dispose()\n this.triangleUVs.dispose()\n this.triangleIds.dispose()\n}\n\nfunction createMeshShader(gl, shaders) {\n var shader = createShader(gl,\n shaders.meshShader.vertex,\n shaders.meshShader.fragment,\n null,\n shaders.meshShader.attributes\n )\n\n shader.attributes.position.location = 0\n shader.attributes.color.location = 2\n shader.attributes.uv.location = 3\n shader.attributes.vector.location = 4\n return shader\n}\n\n\nfunction createPickShader(gl, shaders) {\n var shader = createShader(gl,\n shaders.pickShader.vertex,\n shaders.pickShader.fragment,\n null,\n shaders.pickShader.attributes\n )\n\n shader.attributes.position.location = 0\n shader.attributes.id.location = 1\n shader.attributes.vector.location = 4\n return shader\n}\n\n\nfunction createVectorMesh(gl, params, opts) {\n var shaders = opts.shaders\n\n if (arguments.length === 1) {\n params = gl\n gl = params.gl\n }\n\n\n var triShader = createMeshShader(gl, shaders)\n var pickShader = createPickShader(gl, shaders)\n var meshTexture = createTexture(gl,\n ndarray(new Uint8Array([255,255,255,255]), [1,1,4]))\n meshTexture.generateMipmap()\n meshTexture.minFilter = gl.LINEAR_MIPMAP_LINEAR\n meshTexture.magFilter = gl.LINEAR\n\n var trianglePositions = createBuffer(gl)\n var triangleVectors = createBuffer(gl)\n var triangleColors = createBuffer(gl)\n var triangleUVs = createBuffer(gl)\n var triangleIds = createBuffer(gl)\n var triangleVAO = createVAO(gl, [\n { buffer: trianglePositions,\n type: gl.FLOAT,\n size: 4\n },\n { buffer: triangleIds,\n type: gl.UNSIGNED_BYTE,\n size: 4,\n normalized: true\n },\n { buffer: triangleColors,\n type: gl.FLOAT,\n size: 4\n },\n { buffer: triangleUVs,\n type: gl.FLOAT,\n size: 2\n },\n { buffer: triangleVectors,\n type: gl.FLOAT,\n size: 4\n }\n ])\n\n var mesh = new VectorMesh(gl\n , meshTexture\n , triShader\n , pickShader\n , trianglePositions\n , triangleVectors\n , triangleIds\n , triangleColors\n , triangleUVs\n , triangleVAO\n , opts.traceType || 'cone'\n )\n\n mesh.update(params)\n\n return mesh\n}\n\nmodule.exports = createVectorMesh\n\n\n/***/ }),\n\n/***/ 614:\n/***/ (function(__unused_webpack_module, exports, __webpack_require__) {\n\nvar glslify = __webpack_require__(3236)\n\nvar triVertSrc = glslify([\"precision highp float;\\n\\nprecision highp float;\\n#define GLSLIFY 1\\n\\nvec3 getOrthogonalVector(vec3 v) {\\n // Return up-vector for only-z vector.\\n // Return ax + by + cz = 0, a point that lies on the plane that has v as a normal and that isn't (0,0,0).\\n // From the above if-statement we have ||a|| > 0 U ||b|| > 0.\\n // Assign z = 0, x = -b, y = a:\\n // a*-b + b*a + c*0 = -ba + ba + 0 = 0\\n if (v.x*v.x > v.z*v.z || v.y*v.y > v.z*v.z) {\\n return normalize(vec3(-v.y, v.x, 0.0));\\n } else {\\n return normalize(vec3(0.0, v.z, -v.y));\\n }\\n}\\n\\n// Calculate the cone vertex and normal at the given index.\\n//\\n// The returned vertex is for a cone with its top at origin and height of 1.0,\\n// pointing in the direction of the vector attribute.\\n//\\n// Each cone is made up of a top vertex, a center base vertex and base perimeter vertices.\\n// These vertices are used to make up the triangles of the cone by the following:\\n// segment + 0 top vertex\\n// segment + 1 perimeter vertex a+1\\n// segment + 2 perimeter vertex a\\n// segment + 3 center base vertex\\n// segment + 4 perimeter vertex a\\n// segment + 5 perimeter vertex a+1\\n// Where segment is the number of the radial segment * 6 and a is the angle at that radial segment.\\n// To go from index to segment, floor(index / 6)\\n// To go from segment to angle, 2*pi * (segment/segmentCount)\\n// To go from index to segment index, index - (segment*6)\\n//\\nvec3 getConePosition(vec3 d, float rawIndex, float coneOffset, out vec3 normal) {\\n\\n const float segmentCount = 8.0;\\n\\n float index = rawIndex - floor(rawIndex /\\n (segmentCount * 6.0)) *\\n (segmentCount * 6.0);\\n\\n float segment = floor(0.001 + index/6.0);\\n float segmentIndex = index - (segment*6.0);\\n\\n normal = -normalize(d);\\n\\n if (segmentIndex > 2.99 && segmentIndex < 3.01) {\\n return mix(vec3(0.0), -d, coneOffset);\\n }\\n\\n float nextAngle = (\\n (segmentIndex > 0.99 && segmentIndex < 1.01) ||\\n (segmentIndex > 4.99 && segmentIndex < 5.01)\\n ) ? 1.0 : 0.0;\\n float angle = 2.0 * 3.14159 * ((segment + nextAngle) / segmentCount);\\n\\n vec3 v1 = mix(d, vec3(0.0), coneOffset);\\n vec3 v2 = v1 - d;\\n\\n vec3 u = getOrthogonalVector(d);\\n vec3 v = normalize(cross(u, d));\\n\\n vec3 x = u * cos(angle) * length(d)*0.25;\\n vec3 y = v * sin(angle) * length(d)*0.25;\\n vec3 v3 = v2 + x + y;\\n if (segmentIndex < 3.0) {\\n vec3 tx = u * sin(angle);\\n vec3 ty = v * -cos(angle);\\n vec3 tangent = tx + ty;\\n normal = normalize(cross(v3 - v1, tangent));\\n }\\n\\n if (segmentIndex == 0.0) {\\n return mix(d, vec3(0.0), coneOffset);\\n }\\n return v3;\\n}\\n\\nattribute vec3 vector;\\nattribute vec4 color, position;\\nattribute vec2 uv;\\n\\nuniform float vectorScale, coneScale, coneOffset;\\nuniform mat4 model, view, projection, inverseModel;\\nuniform vec3 eyePosition, lightPosition;\\n\\nvarying vec3 f_normal, f_lightDirection, f_eyeDirection, f_data, f_position;\\nvarying vec4 f_color;\\nvarying vec2 f_uv;\\n\\nvoid main() {\\n // Scale the vector magnitude to stay constant with\\n // model & view changes.\\n vec3 normal;\\n vec3 XYZ = getConePosition(mat3(model) * ((vectorScale * coneScale) * vector), position.w, coneOffset, normal);\\n vec4 conePosition = model * vec4(position.xyz, 1.0) + vec4(XYZ, 0.0);\\n\\n //Lighting geometry parameters\\n vec4 cameraCoordinate = view * conePosition;\\n cameraCoordinate.xyz /= cameraCoordinate.w;\\n f_lightDirection = lightPosition - cameraCoordinate.xyz;\\n f_eyeDirection = eyePosition - cameraCoordinate.xyz;\\n f_normal = normalize((vec4(normal, 0.0) * inverseModel).xyz);\\n\\n // vec4 m_position = model * vec4(conePosition, 1.0);\\n vec4 t_position = view * conePosition;\\n gl_Position = projection * t_position;\\n\\n f_color = color;\\n f_data = conePosition.xyz;\\n f_position = position.xyz;\\n f_uv = uv;\\n}\\n\"])\nvar triFragSrc = glslify([\"#extension GL_OES_standard_derivatives : enable\\n\\nprecision highp float;\\n#define GLSLIFY 1\\n\\nfloat beckmannDistribution(float x, float roughness) {\\n float NdotH = max(x, 0.0001);\\n float cos2Alpha = NdotH * NdotH;\\n float tan2Alpha = (cos2Alpha - 1.0) / cos2Alpha;\\n float roughness2 = roughness * roughness;\\n float denom = 3.141592653589793 * roughness2 * cos2Alpha * cos2Alpha;\\n return exp(tan2Alpha / roughness2) / denom;\\n}\\n\\nfloat cookTorranceSpecular(\\n vec3 lightDirection,\\n vec3 viewDirection,\\n vec3 surfaceNormal,\\n float roughness,\\n float fresnel) {\\n\\n float VdotN = max(dot(viewDirection, surfaceNormal), 0.0);\\n float LdotN = max(dot(lightDirection, surfaceNormal), 0.0);\\n\\n //Half angle vector\\n vec3 H = normalize(lightDirection + viewDirection);\\n\\n //Geometric term\\n float NdotH = max(dot(surfaceNormal, H), 0.0);\\n float VdotH = max(dot(viewDirection, H), 0.000001);\\n float LdotH = max(dot(lightDirection, H), 0.000001);\\n float G1 = (2.0 * NdotH * VdotN) / VdotH;\\n float G2 = (2.0 * NdotH * LdotN) / LdotH;\\n float G = min(1.0, min(G1, G2));\\n \\n //Distribution term\\n float D = beckmannDistribution(NdotH, roughness);\\n\\n //Fresnel term\\n float F = pow(1.0 - VdotN, fresnel);\\n\\n //Multiply terms and done\\n return G * F * D / max(3.14159265 * VdotN, 0.000001);\\n}\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nuniform vec3 clipBounds[2];\\nuniform float roughness, fresnel, kambient, kdiffuse, kspecular, opacity;\\nuniform sampler2D texture;\\n\\nvarying vec3 f_normal, f_lightDirection, f_eyeDirection, f_data, f_position;\\nvarying vec4 f_color;\\nvarying vec2 f_uv;\\n\\nvoid main() {\\n if (outOfRange(clipBounds[0], clipBounds[1], f_position)) discard;\\n vec3 N = normalize(f_normal);\\n vec3 L = normalize(f_lightDirection);\\n vec3 V = normalize(f_eyeDirection);\\n\\n if(gl_FrontFacing) {\\n N = -N;\\n }\\n\\n float specular = min(1.0, max(0.0, cookTorranceSpecular(L, V, N, roughness, fresnel)));\\n float diffuse = min(kambient + kdiffuse * max(dot(N, L), 0.0), 1.0);\\n\\n vec4 surfaceColor = f_color * texture2D(texture, f_uv);\\n vec4 litColor = surfaceColor.a * vec4(diffuse * surfaceColor.rgb + kspecular * vec3(1,1,1) * specular, 1.0);\\n\\n gl_FragColor = litColor * opacity;\\n}\\n\"])\nvar pickVertSrc = glslify([\"precision highp float;\\n\\nprecision highp float;\\n#define GLSLIFY 1\\n\\nvec3 getOrthogonalVector(vec3 v) {\\n // Return up-vector for only-z vector.\\n // Return ax + by + cz = 0, a point that lies on the plane that has v as a normal and that isn't (0,0,0).\\n // From the above if-statement we have ||a|| > 0 U ||b|| > 0.\\n // Assign z = 0, x = -b, y = a:\\n // a*-b + b*a + c*0 = -ba + ba + 0 = 0\\n if (v.x*v.x > v.z*v.z || v.y*v.y > v.z*v.z) {\\n return normalize(vec3(-v.y, v.x, 0.0));\\n } else {\\n return normalize(vec3(0.0, v.z, -v.y));\\n }\\n}\\n\\n// Calculate the cone vertex and normal at the given index.\\n//\\n// The returned vertex is for a cone with its top at origin and height of 1.0,\\n// pointing in the direction of the vector attribute.\\n//\\n// Each cone is made up of a top vertex, a center base vertex and base perimeter vertices.\\n// These vertices are used to make up the triangles of the cone by the following:\\n// segment + 0 top vertex\\n// segment + 1 perimeter vertex a+1\\n// segment + 2 perimeter vertex a\\n// segment + 3 center base vertex\\n// segment + 4 perimeter vertex a\\n// segment + 5 perimeter vertex a+1\\n// Where segment is the number of the radial segment * 6 and a is the angle at that radial segment.\\n// To go from index to segment, floor(index / 6)\\n// To go from segment to angle, 2*pi * (segment/segmentCount)\\n// To go from index to segment index, index - (segment*6)\\n//\\nvec3 getConePosition(vec3 d, float rawIndex, float coneOffset, out vec3 normal) {\\n\\n const float segmentCount = 8.0;\\n\\n float index = rawIndex - floor(rawIndex /\\n (segmentCount * 6.0)) *\\n (segmentCount * 6.0);\\n\\n float segment = floor(0.001 + index/6.0);\\n float segmentIndex = index - (segment*6.0);\\n\\n normal = -normalize(d);\\n\\n if (segmentIndex > 2.99 && segmentIndex < 3.01) {\\n return mix(vec3(0.0), -d, coneOffset);\\n }\\n\\n float nextAngle = (\\n (segmentIndex > 0.99 && segmentIndex < 1.01) ||\\n (segmentIndex > 4.99 && segmentIndex < 5.01)\\n ) ? 1.0 : 0.0;\\n float angle = 2.0 * 3.14159 * ((segment + nextAngle) / segmentCount);\\n\\n vec3 v1 = mix(d, vec3(0.0), coneOffset);\\n vec3 v2 = v1 - d;\\n\\n vec3 u = getOrthogonalVector(d);\\n vec3 v = normalize(cross(u, d));\\n\\n vec3 x = u * cos(angle) * length(d)*0.25;\\n vec3 y = v * sin(angle) * length(d)*0.25;\\n vec3 v3 = v2 + x + y;\\n if (segmentIndex < 3.0) {\\n vec3 tx = u * sin(angle);\\n vec3 ty = v * -cos(angle);\\n vec3 tangent = tx + ty;\\n normal = normalize(cross(v3 - v1, tangent));\\n }\\n\\n if (segmentIndex == 0.0) {\\n return mix(d, vec3(0.0), coneOffset);\\n }\\n return v3;\\n}\\n\\nattribute vec4 vector;\\nattribute vec4 position;\\nattribute vec4 id;\\n\\nuniform mat4 model, view, projection;\\nuniform float vectorScale, coneScale, coneOffset;\\n\\nvarying vec3 f_position;\\nvarying vec4 f_id;\\n\\nvoid main() {\\n vec3 normal;\\n vec3 XYZ = getConePosition(mat3(model) * ((vectorScale * coneScale) * vector.xyz), position.w, coneOffset, normal);\\n vec4 conePosition = model * vec4(position.xyz, 1.0) + vec4(XYZ, 0.0);\\n gl_Position = projection * (view * conePosition);\\n f_id = id;\\n f_position = position.xyz;\\n}\\n\"])\nvar pickFragSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nuniform vec3 clipBounds[2];\\nuniform float pickId;\\n\\nvarying vec3 f_position;\\nvarying vec4 f_id;\\n\\nvoid main() {\\n if (outOfRange(clipBounds[0], clipBounds[1], f_position)) discard;\\n\\n gl_FragColor = vec4(pickId, f_id.xyz);\\n}\"])\n\nexports.meshShader = {\n vertex: triVertSrc,\n fragment: triFragSrc,\n attributes: [\n {name: 'position', type: 'vec4'},\n {name: 'color', type: 'vec4'},\n {name: 'uv', type: 'vec2'},\n {name: 'vector', type: 'vec3'}\n ]\n}\nexports.pickShader = {\n vertex: pickVertSrc,\n fragment: pickFragSrc,\n attributes: [\n {name: 'position', type: 'vec4'},\n {name: 'id', type: 'vec4'},\n {name: 'vector', type: 'vec3'}\n ]\n}\n\n\n/***/ }),\n\n/***/ 737:\n/***/ (function(module) {\n\nmodule.exports = {\n 0: 'NONE',\n 1: 'ONE',\n 2: 'LINE_LOOP',\n 3: 'LINE_STRIP',\n 4: 'TRIANGLES',\n 5: 'TRIANGLE_STRIP',\n 6: 'TRIANGLE_FAN',\n 256: 'DEPTH_BUFFER_BIT',\n 512: 'NEVER',\n 513: 'LESS',\n 514: 'EQUAL',\n 515: 'LEQUAL',\n 516: 'GREATER',\n 517: 'NOTEQUAL',\n 518: 'GEQUAL',\n 519: 'ALWAYS',\n 768: 'SRC_COLOR',\n 769: 'ONE_MINUS_SRC_COLOR',\n 770: 'SRC_ALPHA',\n 771: 'ONE_MINUS_SRC_ALPHA',\n 772: 'DST_ALPHA',\n 773: 'ONE_MINUS_DST_ALPHA',\n 774: 'DST_COLOR',\n 775: 'ONE_MINUS_DST_COLOR',\n 776: 'SRC_ALPHA_SATURATE',\n 1024: 'STENCIL_BUFFER_BIT',\n 1028: 'FRONT',\n 1029: 'BACK',\n 1032: 'FRONT_AND_BACK',\n 1280: 'INVALID_ENUM',\n 1281: 'INVALID_VALUE',\n 1282: 'INVALID_OPERATION',\n 1285: 'OUT_OF_MEMORY',\n 1286: 'INVALID_FRAMEBUFFER_OPERATION',\n 2304: 'CW',\n 2305: 'CCW',\n 2849: 'LINE_WIDTH',\n 2884: 'CULL_FACE',\n 2885: 'CULL_FACE_MODE',\n 2886: 'FRONT_FACE',\n 2928: 'DEPTH_RANGE',\n 2929: 'DEPTH_TEST',\n 2930: 'DEPTH_WRITEMASK',\n 2931: 'DEPTH_CLEAR_VALUE',\n 2932: 'DEPTH_FUNC',\n 2960: 'STENCIL_TEST',\n 2961: 'STENCIL_CLEAR_VALUE',\n 2962: 'STENCIL_FUNC',\n 2963: 'STENCIL_VALUE_MASK',\n 2964: 'STENCIL_FAIL',\n 2965: 'STENCIL_PASS_DEPTH_FAIL',\n 2966: 'STENCIL_PASS_DEPTH_PASS',\n 2967: 'STENCIL_REF',\n 2968: 'STENCIL_WRITEMASK',\n 2978: 'VIEWPORT',\n 3024: 'DITHER',\n 3042: 'BLEND',\n 3088: 'SCISSOR_BOX',\n 3089: 'SCISSOR_TEST',\n 3106: 'COLOR_CLEAR_VALUE',\n 3107: 'COLOR_WRITEMASK',\n 3317: 'UNPACK_ALIGNMENT',\n 3333: 'PACK_ALIGNMENT',\n 3379: 'MAX_TEXTURE_SIZE',\n 3386: 'MAX_VIEWPORT_DIMS',\n 3408: 'SUBPIXEL_BITS',\n 3410: 'RED_BITS',\n 3411: 'GREEN_BITS',\n 3412: 'BLUE_BITS',\n 3413: 'ALPHA_BITS',\n 3414: 'DEPTH_BITS',\n 3415: 'STENCIL_BITS',\n 3553: 'TEXTURE_2D',\n 4352: 'DONT_CARE',\n 4353: 'FASTEST',\n 4354: 'NICEST',\n 5120: 'BYTE',\n 5121: 'UNSIGNED_BYTE',\n 5122: 'SHORT',\n 5123: 'UNSIGNED_SHORT',\n 5124: 'INT',\n 5125: 'UNSIGNED_INT',\n 5126: 'FLOAT',\n 5386: 'INVERT',\n 5890: 'TEXTURE',\n 6401: 'STENCIL_INDEX',\n 6402: 'DEPTH_COMPONENT',\n 6406: 'ALPHA',\n 6407: 'RGB',\n 6408: 'RGBA',\n 6409: 'LUMINANCE',\n 6410: 'LUMINANCE_ALPHA',\n 7680: 'KEEP',\n 7681: 'REPLACE',\n 7682: 'INCR',\n 7683: 'DECR',\n 7936: 'VENDOR',\n 7937: 'RENDERER',\n 7938: 'VERSION',\n 9728: 'NEAREST',\n 9729: 'LINEAR',\n 9984: 'NEAREST_MIPMAP_NEAREST',\n 9985: 'LINEAR_MIPMAP_NEAREST',\n 9986: 'NEAREST_MIPMAP_LINEAR',\n 9987: 'LINEAR_MIPMAP_LINEAR',\n 10240: 'TEXTURE_MAG_FILTER',\n 10241: 'TEXTURE_MIN_FILTER',\n 10242: 'TEXTURE_WRAP_S',\n 10243: 'TEXTURE_WRAP_T',\n 10497: 'REPEAT',\n 10752: 'POLYGON_OFFSET_UNITS',\n 16384: 'COLOR_BUFFER_BIT',\n 32769: 'CONSTANT_COLOR',\n 32770: 'ONE_MINUS_CONSTANT_COLOR',\n 32771: 'CONSTANT_ALPHA',\n 32772: 'ONE_MINUS_CONSTANT_ALPHA',\n 32773: 'BLEND_COLOR',\n 32774: 'FUNC_ADD',\n 32777: 'BLEND_EQUATION_RGB',\n 32778: 'FUNC_SUBTRACT',\n 32779: 'FUNC_REVERSE_SUBTRACT',\n 32819: 'UNSIGNED_SHORT_4_4_4_4',\n 32820: 'UNSIGNED_SHORT_5_5_5_1',\n 32823: 'POLYGON_OFFSET_FILL',\n 32824: 'POLYGON_OFFSET_FACTOR',\n 32854: 'RGBA4',\n 32855: 'RGB5_A1',\n 32873: 'TEXTURE_BINDING_2D',\n 32926: 'SAMPLE_ALPHA_TO_COVERAGE',\n 32928: 'SAMPLE_COVERAGE',\n 32936: 'SAMPLE_BUFFERS',\n 32937: 'SAMPLES',\n 32938: 'SAMPLE_COVERAGE_VALUE',\n 32939: 'SAMPLE_COVERAGE_INVERT',\n 32968: 'BLEND_DST_RGB',\n 32969: 'BLEND_SRC_RGB',\n 32970: 'BLEND_DST_ALPHA',\n 32971: 'BLEND_SRC_ALPHA',\n 33071: 'CLAMP_TO_EDGE',\n 33170: 'GENERATE_MIPMAP_HINT',\n 33189: 'DEPTH_COMPONENT16',\n 33306: 'DEPTH_STENCIL_ATTACHMENT',\n 33635: 'UNSIGNED_SHORT_5_6_5',\n 33648: 'MIRRORED_REPEAT',\n 33901: 'ALIASED_POINT_SIZE_RANGE',\n 33902: 'ALIASED_LINE_WIDTH_RANGE',\n 33984: 'TEXTURE0',\n 33985: 'TEXTURE1',\n 33986: 'TEXTURE2',\n 33987: 'TEXTURE3',\n 33988: 'TEXTURE4',\n 33989: 'TEXTURE5',\n 33990: 'TEXTURE6',\n 33991: 'TEXTURE7',\n 33992: 'TEXTURE8',\n 33993: 'TEXTURE9',\n 33994: 'TEXTURE10',\n 33995: 'TEXTURE11',\n 33996: 'TEXTURE12',\n 33997: 'TEXTURE13',\n 33998: 'TEXTURE14',\n 33999: 'TEXTURE15',\n 34000: 'TEXTURE16',\n 34001: 'TEXTURE17',\n 34002: 'TEXTURE18',\n 34003: 'TEXTURE19',\n 34004: 'TEXTURE20',\n 34005: 'TEXTURE21',\n 34006: 'TEXTURE22',\n 34007: 'TEXTURE23',\n 34008: 'TEXTURE24',\n 34009: 'TEXTURE25',\n 34010: 'TEXTURE26',\n 34011: 'TEXTURE27',\n 34012: 'TEXTURE28',\n 34013: 'TEXTURE29',\n 34014: 'TEXTURE30',\n 34015: 'TEXTURE31',\n 34016: 'ACTIVE_TEXTURE',\n 34024: 'MAX_RENDERBUFFER_SIZE',\n 34041: 'DEPTH_STENCIL',\n 34055: 'INCR_WRAP',\n 34056: 'DECR_WRAP',\n 34067: 'TEXTURE_CUBE_MAP',\n 34068: 'TEXTURE_BINDING_CUBE_MAP',\n 34069: 'TEXTURE_CUBE_MAP_POSITIVE_X',\n 34070: 'TEXTURE_CUBE_MAP_NEGATIVE_X',\n 34071: 'TEXTURE_CUBE_MAP_POSITIVE_Y',\n 34072: 'TEXTURE_CUBE_MAP_NEGATIVE_Y',\n 34073: 'TEXTURE_CUBE_MAP_POSITIVE_Z',\n 34074: 'TEXTURE_CUBE_MAP_NEGATIVE_Z',\n 34076: 'MAX_CUBE_MAP_TEXTURE_SIZE',\n 34338: 'VERTEX_ATTRIB_ARRAY_ENABLED',\n 34339: 'VERTEX_ATTRIB_ARRAY_SIZE',\n 34340: 'VERTEX_ATTRIB_ARRAY_STRIDE',\n 34341: 'VERTEX_ATTRIB_ARRAY_TYPE',\n 34342: 'CURRENT_VERTEX_ATTRIB',\n 34373: 'VERTEX_ATTRIB_ARRAY_POINTER',\n 34466: 'NUM_COMPRESSED_TEXTURE_FORMATS',\n 34467: 'COMPRESSED_TEXTURE_FORMATS',\n 34660: 'BUFFER_SIZE',\n 34661: 'BUFFER_USAGE',\n 34816: 'STENCIL_BACK_FUNC',\n 34817: 'STENCIL_BACK_FAIL',\n 34818: 'STENCIL_BACK_PASS_DEPTH_FAIL',\n 34819: 'STENCIL_BACK_PASS_DEPTH_PASS',\n 34877: 'BLEND_EQUATION_ALPHA',\n 34921: 'MAX_VERTEX_ATTRIBS',\n 34922: 'VERTEX_ATTRIB_ARRAY_NORMALIZED',\n 34930: 'MAX_TEXTURE_IMAGE_UNITS',\n 34962: 'ARRAY_BUFFER',\n 34963: 'ELEMENT_ARRAY_BUFFER',\n 34964: 'ARRAY_BUFFER_BINDING',\n 34965: 'ELEMENT_ARRAY_BUFFER_BINDING',\n 34975: 'VERTEX_ATTRIB_ARRAY_BUFFER_BINDING',\n 35040: 'STREAM_DRAW',\n 35044: 'STATIC_DRAW',\n 35048: 'DYNAMIC_DRAW',\n 35632: 'FRAGMENT_SHADER',\n 35633: 'VERTEX_SHADER',\n 35660: 'MAX_VERTEX_TEXTURE_IMAGE_UNITS',\n 35661: 'MAX_COMBINED_TEXTURE_IMAGE_UNITS',\n 35663: 'SHADER_TYPE',\n 35664: 'FLOAT_VEC2',\n 35665: 'FLOAT_VEC3',\n 35666: 'FLOAT_VEC4',\n 35667: 'INT_VEC2',\n 35668: 'INT_VEC3',\n 35669: 'INT_VEC4',\n 35670: 'BOOL',\n 35671: 'BOOL_VEC2',\n 35672: 'BOOL_VEC3',\n 35673: 'BOOL_VEC4',\n 35674: 'FLOAT_MAT2',\n 35675: 'FLOAT_MAT3',\n 35676: 'FLOAT_MAT4',\n 35678: 'SAMPLER_2D',\n 35680: 'SAMPLER_CUBE',\n 35712: 'DELETE_STATUS',\n 35713: 'COMPILE_STATUS',\n 35714: 'LINK_STATUS',\n 35715: 'VALIDATE_STATUS',\n 35716: 'INFO_LOG_LENGTH',\n 35717: 'ATTACHED_SHADERS',\n 35718: 'ACTIVE_UNIFORMS',\n 35719: 'ACTIVE_UNIFORM_MAX_LENGTH',\n 35720: 'SHADER_SOURCE_LENGTH',\n 35721: 'ACTIVE_ATTRIBUTES',\n 35722: 'ACTIVE_ATTRIBUTE_MAX_LENGTH',\n 35724: 'SHADING_LANGUAGE_VERSION',\n 35725: 'CURRENT_PROGRAM',\n 36003: 'STENCIL_BACK_REF',\n 36004: 'STENCIL_BACK_VALUE_MASK',\n 36005: 'STENCIL_BACK_WRITEMASK',\n 36006: 'FRAMEBUFFER_BINDING',\n 36007: 'RENDERBUFFER_BINDING',\n 36048: 'FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE',\n 36049: 'FRAMEBUFFER_ATTACHMENT_OBJECT_NAME',\n 36050: 'FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL',\n 36051: 'FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE',\n 36053: 'FRAMEBUFFER_COMPLETE',\n 36054: 'FRAMEBUFFER_INCOMPLETE_ATTACHMENT',\n 36055: 'FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT',\n 36057: 'FRAMEBUFFER_INCOMPLETE_DIMENSIONS',\n 36061: 'FRAMEBUFFER_UNSUPPORTED',\n 36064: 'COLOR_ATTACHMENT0',\n 36096: 'DEPTH_ATTACHMENT',\n 36128: 'STENCIL_ATTACHMENT',\n 36160: 'FRAMEBUFFER',\n 36161: 'RENDERBUFFER',\n 36162: 'RENDERBUFFER_WIDTH',\n 36163: 'RENDERBUFFER_HEIGHT',\n 36164: 'RENDERBUFFER_INTERNAL_FORMAT',\n 36168: 'STENCIL_INDEX8',\n 36176: 'RENDERBUFFER_RED_SIZE',\n 36177: 'RENDERBUFFER_GREEN_SIZE',\n 36178: 'RENDERBUFFER_BLUE_SIZE',\n 36179: 'RENDERBUFFER_ALPHA_SIZE',\n 36180: 'RENDERBUFFER_DEPTH_SIZE',\n 36181: 'RENDERBUFFER_STENCIL_SIZE',\n 36194: 'RGB565',\n 36336: 'LOW_FLOAT',\n 36337: 'MEDIUM_FLOAT',\n 36338: 'HIGH_FLOAT',\n 36339: 'LOW_INT',\n 36340: 'MEDIUM_INT',\n 36341: 'HIGH_INT',\n 36346: 'SHADER_COMPILER',\n 36347: 'MAX_VERTEX_UNIFORM_VECTORS',\n 36348: 'MAX_VARYING_VECTORS',\n 36349: 'MAX_FRAGMENT_UNIFORM_VECTORS',\n 37440: 'UNPACK_FLIP_Y_WEBGL',\n 37441: 'UNPACK_PREMULTIPLY_ALPHA_WEBGL',\n 37442: 'CONTEXT_LOST_WEBGL',\n 37443: 'UNPACK_COLORSPACE_CONVERSION_WEBGL',\n 37444: 'BROWSER_DEFAULT_WEBGL'\n}\n\n\n/***/ }),\n\n/***/ 5171:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar gl10 = __webpack_require__(737)\n\nmodule.exports = function lookupConstant (number) {\n return gl10[number]\n}\n\n\n/***/ }),\n\n/***/ 9165:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = createErrorBars\n\nvar createBuffer = __webpack_require__(2762)\nvar createVAO = __webpack_require__(8116)\nvar createShader = __webpack_require__(3436)\n\nvar IDENTITY = [1,0,0,0,\n 0,1,0,0,\n 0,0,1,0,\n 0,0,0,1]\n\nfunction ErrorBars(gl, buffer, vao, shader) {\n this.gl = gl\n this.shader = shader\n this.buffer = buffer\n this.vao = vao\n this.pixelRatio = 1\n this.bounds = [[ Infinity, Infinity, Infinity], [-Infinity,-Infinity,-Infinity]]\n this.clipBounds = [[-Infinity,-Infinity,-Infinity], [ Infinity, Infinity, Infinity]]\n this.lineWidth = [1,1,1]\n this.capSize = [10,10,10]\n this.lineCount = [0,0,0]\n this.lineOffset = [0,0,0]\n this.opacity = 1\n this.hasAlpha = false\n}\n\nvar proto = ErrorBars.prototype\n\nproto.isOpaque = function() {\n return !this.hasAlpha\n}\n\nproto.isTransparent = function() {\n return this.hasAlpha\n}\n\nproto.drawTransparent = proto.draw = function(cameraParams) {\n var gl = this.gl\n var uniforms = this.shader.uniforms\n\n this.shader.bind()\n var view = uniforms.view = cameraParams.view || IDENTITY\n var projection = uniforms.projection = cameraParams.projection || IDENTITY\n uniforms.model = cameraParams.model || IDENTITY\n uniforms.clipBounds = this.clipBounds\n uniforms.opacity = this.opacity\n\n\n var cx = view[12]\n var cy = view[13]\n var cz = view[14]\n var cw = view[15]\n\n var isOrtho = cameraParams._ortho || false\n var orthoFix = (isOrtho) ? 2 : 1 // double up padding for orthographic ticks & labels\n var pixelScaleF = orthoFix * this.pixelRatio * (projection[3]*cx + projection[7]*cy + projection[11]*cz + projection[15]*cw) / gl.drawingBufferHeight\n\n this.vao.bind()\n for(var i=0; i<3; ++i) {\n gl.lineWidth(this.lineWidth[i] * this.pixelRatio)\n uniforms.capSize = this.capSize[i] * pixelScaleF\n if (this.lineCount[i]) {\n gl.drawArrays(gl.LINES, this.lineOffset[i], this.lineCount[i])\n }\n }\n this.vao.unbind()\n}\n\nfunction updateBounds(bounds, point) {\n for(var i=0; i<3; ++i) {\n bounds[0][i] = Math.min(bounds[0][i], point[i])\n bounds[1][i] = Math.max(bounds[1][i], point[i])\n }\n}\n\nvar FACE_TABLE = (function(){\n var table = new Array(3)\n for(var d=0; d<3; ++d) {\n var row = []\n for(var j=1; j<=2; ++j) {\n for(var s=-1; s<=1; s+=2) {\n var u = (j+d) % 3\n var y = [0,0,0]\n y[u] = s\n row.push(y)\n }\n }\n table[d] = row\n }\n return table\n})()\n\n\nfunction emitFace(verts, x, c, d) {\n var offsets = FACE_TABLE[d]\n for(var i=0; i 0) {\n var x = p.slice()\n x[j] += e[1][j]\n verts.push(p[0], p[1], p[2],\n c[0], c[1], c[2], c[3],\n 0, 0, 0,\n x[0], x[1], x[2],\n c[0], c[1], c[2], c[3],\n 0, 0, 0)\n updateBounds(this.bounds, x)\n vertexCount += 2 + emitFace(verts, x, c, j)\n }\n }\n this.lineCount[j] = vertexCount - this.lineOffset[j]\n }\n this.buffer.update(verts)\n }\n}\n\nproto.dispose = function() {\n this.shader.dispose()\n this.buffer.dispose()\n this.vao.dispose()\n}\n\nfunction createErrorBars(options) {\n var gl = options.gl\n var buffer = createBuffer(gl)\n var vao = createVAO(gl, [\n {\n buffer: buffer,\n type: gl.FLOAT,\n size: 3,\n offset: 0,\n stride: 40\n },\n {\n buffer: buffer,\n type: gl.FLOAT,\n size: 4,\n offset: 12,\n stride: 40\n },\n {\n buffer: buffer,\n type: gl.FLOAT,\n size: 3,\n offset: 28,\n stride: 40\n }\n ])\n\n var shader = createShader(gl)\n shader.attributes.position.location = 0\n shader.attributes.color.location = 1\n shader.attributes.offset.location = 2\n\n var result = new ErrorBars(gl, buffer, vao, shader)\n result.update(options)\n return result\n}\n\n\n/***/ }),\n\n/***/ 3436:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar glslify = __webpack_require__(3236)\nvar createShader = __webpack_require__(9405)\n\nvar vertSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nattribute vec3 position, offset;\\nattribute vec4 color;\\nuniform mat4 model, view, projection;\\nuniform float capSize;\\nvarying vec4 fragColor;\\nvarying vec3 fragPosition;\\n\\nvoid main() {\\n vec4 worldPosition = model * vec4(position, 1.0);\\n worldPosition = (worldPosition / worldPosition.w) + vec4(capSize * offset, 0.0);\\n gl_Position = projection * (view * worldPosition);\\n fragColor = color;\\n fragPosition = position;\\n}\"])\nvar fragSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nuniform vec3 clipBounds[2];\\nuniform float opacity;\\nvarying vec3 fragPosition;\\nvarying vec4 fragColor;\\n\\nvoid main() {\\n if (\\n outOfRange(clipBounds[0], clipBounds[1], fragPosition) ||\\n fragColor.a * opacity == 0.\\n ) discard;\\n\\n gl_FragColor = opacity * fragColor;\\n}\"])\n\nmodule.exports = function(gl) {\n return createShader(gl, vertSrc, fragSrc, null, [\n {name: 'position', type: 'vec3'},\n {name: 'color', type: 'vec4'},\n {name: 'offset', type: 'vec3'}\n ])\n}\n\n\n/***/ }),\n\n/***/ 2260:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar createTexture = __webpack_require__(7766)\n\nmodule.exports = createFBO\n\nvar colorAttachmentArrays = null\nvar FRAMEBUFFER_UNSUPPORTED\nvar FRAMEBUFFER_INCOMPLETE_ATTACHMENT\nvar FRAMEBUFFER_INCOMPLETE_DIMENSIONS\nvar FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT\n\nfunction saveFBOState(gl) {\n var fbo = gl.getParameter(gl.FRAMEBUFFER_BINDING)\n var rbo = gl.getParameter(gl.RENDERBUFFER_BINDING)\n var tex = gl.getParameter(gl.TEXTURE_BINDING_2D)\n return [fbo, rbo, tex]\n}\n\nfunction restoreFBOState(gl, data) {\n gl.bindFramebuffer(gl.FRAMEBUFFER, data[0])\n gl.bindRenderbuffer(gl.RENDERBUFFER, data[1])\n gl.bindTexture(gl.TEXTURE_2D, data[2])\n}\n\nfunction lazyInitColorAttachments(gl, ext) {\n var maxColorAttachments = gl.getParameter(ext.MAX_COLOR_ATTACHMENTS_WEBGL)\n colorAttachmentArrays = new Array(maxColorAttachments + 1)\n for(var i=0; i<=maxColorAttachments; ++i) {\n var x = new Array(maxColorAttachments)\n for(var j=0; j 1) {\n ext.drawBuffersWEBGL(colorAttachmentArrays[numColors])\n }\n\n //Allocate depth/stencil buffers\n var WEBGL_depth_texture = gl.getExtension('WEBGL_depth_texture')\n if(WEBGL_depth_texture) {\n if(useStencil) {\n fbo.depth = initTexture(gl, width, height,\n WEBGL_depth_texture.UNSIGNED_INT_24_8_WEBGL,\n gl.DEPTH_STENCIL,\n gl.DEPTH_STENCIL_ATTACHMENT)\n } else if(useDepth) {\n fbo.depth = initTexture(gl, width, height,\n gl.UNSIGNED_SHORT,\n gl.DEPTH_COMPONENT,\n gl.DEPTH_ATTACHMENT)\n }\n } else {\n if(useDepth && useStencil) {\n fbo._depth_rb = initRenderBuffer(gl, width, height, gl.DEPTH_STENCIL, gl.DEPTH_STENCIL_ATTACHMENT)\n } else if(useDepth) {\n fbo._depth_rb = initRenderBuffer(gl, width, height, gl.DEPTH_COMPONENT16, gl.DEPTH_ATTACHMENT)\n } else if(useStencil) {\n fbo._depth_rb = initRenderBuffer(gl, width, height, gl.STENCIL_INDEX, gl.STENCIL_ATTACHMENT)\n }\n }\n\n //Check frame buffer state\n var status = gl.checkFramebufferStatus(gl.FRAMEBUFFER)\n if(status !== gl.FRAMEBUFFER_COMPLETE) {\n\n //Release all partially allocated resources\n fbo._destroyed = true\n\n //Release all resources\n gl.bindFramebuffer(gl.FRAMEBUFFER, null)\n gl.deleteFramebuffer(fbo.handle)\n fbo.handle = null\n if(fbo.depth) {\n fbo.depth.dispose()\n fbo.depth = null\n }\n if(fbo._depth_rb) {\n gl.deleteRenderbuffer(fbo._depth_rb)\n fbo._depth_rb = null\n }\n for(var i=0; i maxFBOSize ||\n h < 0 || h > maxFBOSize) {\n throw new Error('gl-fbo: Can\\'t resize FBO, invalid dimensions')\n }\n\n //Update shape\n fbo._shape[0] = w\n fbo._shape[1] = h\n\n //Save framebuffer state\n var state = saveFBOState(gl)\n\n //Resize framebuffer attachments\n for(var i=0; i maxFBOSize || height < 0 || height > maxFBOSize) {\n throw new Error('gl-fbo: Parameters are too large for FBO')\n }\n\n //Handle each option type\n options = options || {}\n\n //Figure out number of color buffers to use\n var numColors = 1\n if('color' in options) {\n numColors = Math.max(options.color|0, 0)\n if(numColors < 0) {\n throw new Error('gl-fbo: Must specify a nonnegative number of colors')\n }\n if(numColors > 1) {\n //Check if multiple render targets supported\n if(!WEBGL_draw_buffers) {\n throw new Error('gl-fbo: Multiple draw buffer extension not supported')\n } else if(numColors > gl.getParameter(WEBGL_draw_buffers.MAX_COLOR_ATTACHMENTS_WEBGL)) {\n throw new Error('gl-fbo: Context does not support ' + numColors + ' draw buffers')\n }\n }\n }\n\n //Determine whether to use floating point textures\n var colorType = gl.UNSIGNED_BYTE\n var OES_texture_float = gl.getExtension('OES_texture_float')\n if(options.float && numColors > 0) {\n if(!OES_texture_float) {\n throw new Error('gl-fbo: Context does not support floating point textures')\n }\n colorType = gl.FLOAT\n } else if(options.preferFloat && numColors > 0) {\n if(OES_texture_float) {\n colorType = gl.FLOAT\n }\n }\n\n //Check if we should use depth buffer\n var useDepth = true\n if('depth' in options) {\n useDepth = !!options.depth\n }\n\n //Check if we should use a stencil buffer\n var useStencil = false\n if('stencil' in options) {\n useStencil = !!options.stencil\n }\n\n return new Framebuffer(\n gl,\n width,\n height,\n colorType,\n numColors,\n useDepth,\n useStencil,\n WEBGL_draw_buffers)\n}\n\n\n/***/ }),\n\n/***/ 2992:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\nvar sprintf = (__webpack_require__(3387).sprintf);\nvar glConstants = __webpack_require__(5171);\nvar shaderName = __webpack_require__(1848);\nvar addLineNumbers = __webpack_require__(1085);\n\nmodule.exports = formatCompilerError;\n\nfunction formatCompilerError(errLog, src, type) {\n \"use strict\";\n\n var name = shaderName(src) || 'of unknown name (see npm glsl-shader-name)';\n\n var typeName = 'unknown type';\n if (type !== undefined) {\n typeName = type === glConstants.FRAGMENT_SHADER ? 'fragment' : 'vertex'\n }\n\n var longForm = sprintf('Error compiling %s shader %s:\\n', typeName, name);\n var shortForm = sprintf(\"%s%s\", longForm, errLog);\n\n var errorStrings = errLog.split('\\n');\n var errors = {};\n\n for (var i = 0; i < errorStrings.length; i++) {\n var errorString = errorStrings[i];\n if (errorString === '' || errorString === \"\\0\") continue;\n var lineNo = parseInt(errorString.split(':')[2]);\n if (isNaN(lineNo)) {\n throw new Error(sprintf('Could not parse error: %s', errorString));\n }\n errors[lineNo] = errorString;\n }\n\n var lines = addLineNumbers(src).split('\\n');\n\n for (var i = 0; i < lines.length; i++) {\n if (!errors[i+3] && !errors[i+2] && !errors[i+1]) continue;\n var line = lines[i];\n longForm += line + '\\n';\n if (errors[i+1]) {\n var e = errors[i+1];\n e = e.substr(e.split(':', 3).join(':').length + 1).trim();\n longForm += sprintf('^^^ %s\\n\\n', e);\n }\n }\n\n return {\n long: longForm.trim(),\n short: shortForm.trim()\n };\n}\n\n\n\n/***/ }),\n\n/***/ 2510:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = createHeatmap2D\n\nvar bsearch = __webpack_require__(2478)\nvar iota = __webpack_require__(7762)\nvar pool = __webpack_require__(1888)\nvar createShader = __webpack_require__(9405)\nvar createBuffer = __webpack_require__(2762)\n\nvar shaders = __webpack_require__(6768)\n\nfunction GLHeatmap2D (\n plot,\n shader,\n pickShader,\n positionBuffer,\n weightBuffer,\n colorBuffer,\n idBuffer) {\n this.plot = plot\n this.shader = shader\n this.pickShader = pickShader\n this.positionBuffer = positionBuffer\n this.weightBuffer = weightBuffer\n this.colorBuffer = colorBuffer\n this.idBuffer = idBuffer\n this.xData = []\n this.yData = []\n this.shape = [0, 0]\n this.bounds = [Infinity, Infinity, -Infinity, -Infinity]\n this.pickOffset = 0\n}\n\nvar proto = GLHeatmap2D.prototype\n\nvar WEIGHTS = [\n 0, 0,\n 1, 0,\n 0, 1,\n 1, 0,\n 1, 1,\n 0, 1\n]\n\nproto.draw = (function () {\n var MATRIX = [\n 1, 0, 0,\n 0, 1, 0,\n 0, 0, 1\n ]\n\n return function () {\n var plot = this.plot\n var shader = this.shader\n var bounds = this.bounds\n var numVertices = this.numVertices\n\n if (numVertices <= 0) {\n return\n }\n\n var gl = plot.gl\n var dataBox = plot.dataBox\n\n var boundX = bounds[2] - bounds[0]\n var boundY = bounds[3] - bounds[1]\n var dataX = dataBox[2] - dataBox[0]\n var dataY = dataBox[3] - dataBox[1]\n\n MATRIX[0] = 2.0 * boundX / dataX\n MATRIX[4] = 2.0 * boundY / dataY\n MATRIX[6] = 2.0 * (bounds[0] - dataBox[0]) / dataX - 1.0\n MATRIX[7] = 2.0 * (bounds[1] - dataBox[1]) / dataY - 1.0\n\n shader.bind()\n\n var uniforms = shader.uniforms\n uniforms.viewTransform = MATRIX\n\n uniforms.shape = this.shape\n\n var attributes = shader.attributes\n this.positionBuffer.bind()\n attributes.position.pointer()\n\n this.weightBuffer.bind()\n attributes.weight.pointer(gl.UNSIGNED_BYTE, false)\n\n this.colorBuffer.bind()\n attributes.color.pointer(gl.UNSIGNED_BYTE, true)\n\n gl.drawArrays(gl.TRIANGLES, 0, numVertices)\n }\n})()\n\nproto.drawPick = (function () {\n var MATRIX = [\n 1, 0, 0,\n 0, 1, 0,\n 0, 0, 1\n ]\n\n var PICK_VECTOR = [0, 0, 0, 0]\n\n return function (pickOffset) {\n var plot = this.plot\n var shader = this.pickShader\n var bounds = this.bounds\n var numVertices = this.numVertices\n\n if (numVertices <= 0) {\n return\n }\n\n var gl = plot.gl\n var dataBox = plot.dataBox\n\n var boundX = bounds[2] - bounds[0]\n var boundY = bounds[3] - bounds[1]\n var dataX = dataBox[2] - dataBox[0]\n var dataY = dataBox[3] - dataBox[1]\n\n MATRIX[0] = 2.0 * boundX / dataX\n MATRIX[4] = 2.0 * boundY / dataY\n MATRIX[6] = 2.0 * (bounds[0] - dataBox[0]) / dataX - 1.0\n MATRIX[7] = 2.0 * (bounds[1] - dataBox[1]) / dataY - 1.0\n\n for (var i = 0; i < 4; ++i) {\n PICK_VECTOR[i] = (pickOffset >> (i * 8)) & 0xff\n }\n\n this.pickOffset = pickOffset\n\n shader.bind()\n\n var uniforms = shader.uniforms\n uniforms.viewTransform = MATRIX\n uniforms.pickOffset = PICK_VECTOR\n uniforms.shape = this.shape\n\n var attributes = shader.attributes\n this.positionBuffer.bind()\n attributes.position.pointer()\n\n this.weightBuffer.bind()\n attributes.weight.pointer(gl.UNSIGNED_BYTE, false)\n\n this.idBuffer.bind()\n attributes.pickId.pointer(gl.UNSIGNED_BYTE, false)\n\n gl.drawArrays(gl.TRIANGLES, 0, numVertices)\n\n return pickOffset + this.shape[0] * this.shape[1]\n }\n})()\n\nproto.pick = function (x, y, value) {\n var pickOffset = this.pickOffset\n var pointCount = this.shape[0] * this.shape[1]\n if (value < pickOffset || value >= pickOffset + pointCount) {\n return null\n }\n var pointId = value - pickOffset\n var xData = this.xData\n var yData = this.yData\n return {\n object: this,\n pointId: pointId,\n dataCoord: [\n xData[pointId % this.shape[0]],\n yData[(pointId / this.shape[0]) | 0]]\n }\n}\n\nproto.update = function (options) {\n options = options || {}\n\n var shape = options.shape || [0, 0]\n\n var x = options.x || iota(shape[0])\n var y = options.y || iota(shape[1])\n var z = options.z || new Float32Array(shape[0] * shape[1])\n\n var isSmooth = options.zsmooth !== false\n\n this.xData = x\n this.yData = y\n\n var colorLevels = options.colorLevels || [0]\n var colorValues = options.colorValues || [0, 0, 0, 1]\n var colorCount = colorLevels.length\n\n var bounds = this.bounds\n var lox, loy, hix, hiy\n if (isSmooth) {\n lox = bounds[0] = x[0]\n loy = bounds[1] = y[0]\n hix = bounds[2] = x[x.length - 1]\n hiy = bounds[3] = y[y.length - 1]\n } else {\n // To get squares to centre on data values\n lox = bounds[0] = x[0] + (x[1] - x[0]) / 2 // starting x value\n loy = bounds[1] = y[0] + (y[1] - y[0]) / 2 // starting y value\n\n // Bounds needs to add half a square on each end\n hix = bounds[2] = x[x.length - 1] + (x[x.length - 1] - x[x.length - 2]) / 2\n hiy = bounds[3] = y[y.length - 1] + (y[y.length - 1] - y[y.length - 2]) / 2\n\n // N.B. Resolution = 1 / range\n }\n var xs = 1.0 / (hix - lox)\n var ys = 1.0 / (hiy - loy)\n\n var numX = shape[0]\n var numY = shape[1]\n\n this.shape = [numX, numY]\n\n var numVerts = (\n isSmooth ? (numX - 1) * (numY - 1) : numX * numY\n ) * (WEIGHTS.length >>> 1)\n\n this.numVertices = numVerts\n\n var colors = pool.mallocUint8(numVerts * 4)\n var positions = pool.mallocFloat32(numVerts * 2)\n var weights = pool.mallocUint8 (numVerts * 2)\n var ids = pool.mallocUint32(numVerts)\n\n var ptr = 0\n\n var ni = isSmooth ? numX - 1 : numX\n var nj = isSmooth ? numY - 1 : numY\n\n for (var j = 0; j < nj; ++j) {\n var yc0, yc1\n\n if (isSmooth) {\n yc0 = ys * (y[j] - loy)\n yc1 = ys * (y[j + 1] - loy)\n } else {\n yc0 = j < numY - 1 ? ys * (y[j] - (y[j + 1] - y[j])/2 - loy) : ys * (y[j] - (y[j] - y[j - 1])/2 - loy)\n yc1 = j < numY - 1 ? ys * (y[j] + (y[j + 1] - y[j])/2 - loy) : ys * (y[j] + (y[j] - y[j - 1])/2 - loy)\n }\n\n for (var i = 0; i < ni; ++i) {\n var xc0, xc1\n\n if (isSmooth) {\n xc0 = xs * (x[i] - lox)\n xc1 = xs * (x[i + 1] - lox)\n } else {\n xc0 = i < numX - 1 ? xs * (x[i] - (x[i + 1] - x[i])/2 - lox) : xs * (x[i] - (x[i] - x[i - 1])/2 - lox)\n xc1 = i < numX - 1 ? xs * (x[i] + (x[i + 1] - x[i])/2 - lox) : xs * (x[i] + (x[i] - x[i - 1])/2 - lox)\n }\n\n for (var dd = 0; dd < WEIGHTS.length; dd += 2) {\n var dx = WEIGHTS[dd]\n var dy = WEIGHTS[dd + 1]\n var offset = isSmooth ? (j + dy) * numX + (i + dx) : j * numX + i\n var zc = z[offset]\n var colorIdx = bsearch.le(colorLevels, zc)\n var r, g, b, a\n if (colorIdx < 0) {\n r = colorValues[0]\n g = colorValues[1]\n b = colorValues[2]\n a = colorValues[3]\n } else if (colorIdx === colorCount - 1) {\n r = colorValues[4 * colorCount - 4]\n g = colorValues[4 * colorCount - 3]\n b = colorValues[4 * colorCount - 2]\n a = colorValues[4 * colorCount - 1]\n } else {\n var t = (zc - colorLevels[colorIdx]) /\n (colorLevels[colorIdx + 1] - colorLevels[colorIdx])\n var ti = 1.0 - t\n var i0 = 4 * colorIdx\n var i1 = 4 * (colorIdx + 1)\n r = ti * colorValues[i0] + t * colorValues[i1]\n g = ti * colorValues[i0 + 1] + t * colorValues[i1 + 1]\n b = ti * colorValues[i0 + 2] + t * colorValues[i1 + 2]\n a = ti * colorValues[i0 + 3] + t * colorValues[i1 + 3]\n }\n\n colors[4 * ptr] = 255 * r\n colors[4 * ptr + 1] = 255 * g\n colors[4 * ptr + 2] = 255 * b\n colors[4 * ptr + 3] = 255 * a\n\n positions[2*ptr] = xc0*.5 + xc1*.5;\n positions[2*ptr+1] = yc0*.5 + yc1*.5;\n\n weights[2*ptr] = dx;\n weights[2*ptr+1] = dy;\n\n ids[ptr] = j * numX + i\n\n ptr += 1\n }\n }\n }\n\n this.positionBuffer.update(positions)\n this.weightBuffer.update(weights)\n this.colorBuffer.update(colors)\n this.idBuffer.update(ids)\n\n pool.free(positions)\n pool.free(colors)\n pool.free(weights)\n pool.free(ids)\n}\n\nproto.dispose = function () {\n this.shader.dispose()\n this.pickShader.dispose()\n this.positionBuffer.dispose()\n this.weightBuffer.dispose()\n this.colorBuffer.dispose()\n this.idBuffer.dispose()\n this.plot.removeObject(this)\n}\n\nfunction createHeatmap2D (plot, options) {\n var gl = plot.gl\n\n var shader = createShader(gl, shaders.vertex, shaders.fragment)\n var pickShader = createShader(gl, shaders.pickVertex, shaders.pickFragment)\n\n var positionBuffer = createBuffer(gl)\n var weightBuffer = createBuffer(gl)\n var colorBuffer = createBuffer(gl)\n var idBuffer = createBuffer(gl)\n\n var heatmap = new GLHeatmap2D(\n plot,\n shader,\n pickShader,\n positionBuffer,\n weightBuffer,\n colorBuffer,\n idBuffer)\n\n heatmap.update(options)\n plot.addObject(heatmap)\n\n return heatmap\n}\n\n\n/***/ }),\n\n/***/ 6768:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar glslify = __webpack_require__(3236)\n\nmodule.exports = {\n fragment: glslify([\"precision lowp float;\\n#define GLSLIFY 1\\nvarying vec4 fragColor;\\nvoid main() {\\n gl_FragColor = vec4(fragColor.rgb * fragColor.a, fragColor.a);\\n}\\n\"]),\n vertex: glslify([\"precision mediump float;\\n#define GLSLIFY 1\\n\\nattribute vec2 position;\\nattribute vec4 color;\\nattribute vec2 weight;\\n\\nuniform vec2 shape;\\nuniform mat3 viewTransform;\\n\\nvarying vec4 fragColor;\\n\\nvoid main() {\\n vec3 vPosition = viewTransform * vec3( position + (weight-.5)/(shape-1.) , 1.0);\\n fragColor = color;\\n gl_Position = vec4(vPosition.xy, 0, vPosition.z);\\n}\\n\"]),\n pickFragment: glslify([\"precision mediump float;\\n#define GLSLIFY 1\\n\\nvarying vec4 fragId;\\nvarying vec2 vWeight;\\n\\nuniform vec2 shape;\\nuniform vec4 pickOffset;\\n\\nvoid main() {\\n vec2 d = step(.5, vWeight);\\n vec4 id = fragId + pickOffset;\\n id.x += d.x + d.y*shape.x;\\n\\n id.y += floor(id.x / 256.0);\\n id.x -= floor(id.x / 256.0) * 256.0;\\n\\n id.z += floor(id.y / 256.0);\\n id.y -= floor(id.y / 256.0) * 256.0;\\n\\n id.w += floor(id.z / 256.0);\\n id.z -= floor(id.z / 256.0) * 256.0;\\n\\n gl_FragColor = id/255.;\\n}\\n\"]),\n pickVertex: glslify([\"precision mediump float;\\n#define GLSLIFY 1\\n\\nattribute vec2 position;\\nattribute vec4 pickId;\\nattribute vec2 weight;\\n\\nuniform vec2 shape;\\nuniform mat3 viewTransform;\\n\\nvarying vec4 fragId;\\nvarying vec2 vWeight;\\n\\nvoid main() {\\n vWeight = weight;\\n\\n fragId = pickId;\\n\\n vec3 vPosition = viewTransform * vec3( position + (weight-.5)/(shape-1.) , 1.0);\\n gl_Position = vec4(vPosition.xy, 0, vPosition.z);\\n}\\n\"])\n}\n\n\n/***/ }),\n\n/***/ 7319:\n/***/ (function(__unused_webpack_module, exports, __webpack_require__) {\n\nvar glslify = __webpack_require__(3236)\nvar createShader = __webpack_require__(9405)\n\nvar vertSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nattribute vec3 position, nextPosition;\\nattribute float arcLength, lineWidth;\\nattribute vec4 color;\\n\\nuniform vec2 screenShape;\\nuniform float pixelRatio;\\nuniform mat4 model, view, projection;\\n\\nvarying vec4 fragColor;\\nvarying vec3 worldPosition;\\nvarying float pixelArcLength;\\n\\nvec4 project(vec3 p) {\\n return projection * (view * (model * vec4(p, 1.0)));\\n}\\n\\nvoid main() {\\n vec4 startPoint = project(position);\\n vec4 endPoint = project(nextPosition);\\n\\n vec2 A = startPoint.xy / startPoint.w;\\n vec2 B = endPoint.xy / endPoint.w;\\n\\n float clipAngle = atan(\\n (B.y - A.y) * screenShape.y,\\n (B.x - A.x) * screenShape.x\\n );\\n\\n vec2 offset = 0.5 * pixelRatio * lineWidth * vec2(\\n sin(clipAngle),\\n -cos(clipAngle)\\n ) / screenShape;\\n\\n gl_Position = vec4(startPoint.xy + startPoint.w * offset, startPoint.zw);\\n\\n worldPosition = position;\\n pixelArcLength = arcLength;\\n fragColor = color;\\n}\\n\"])\nvar forwardFrag = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nuniform vec3 clipBounds[2];\\nuniform sampler2D dashTexture;\\nuniform float dashScale;\\nuniform float opacity;\\n\\nvarying vec3 worldPosition;\\nvarying float pixelArcLength;\\nvarying vec4 fragColor;\\n\\nvoid main() {\\n if (\\n outOfRange(clipBounds[0], clipBounds[1], worldPosition) ||\\n fragColor.a * opacity == 0.\\n ) discard;\\n\\n float dashWeight = texture2D(dashTexture, vec2(dashScale * pixelArcLength, 0)).r;\\n if(dashWeight < 0.5) {\\n discard;\\n }\\n gl_FragColor = fragColor * opacity;\\n}\\n\"])\nvar pickFrag = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\n#define FLOAT_MAX 1.70141184e38\\n#define FLOAT_MIN 1.17549435e-38\\n\\n// https://github.com/mikolalysenko/glsl-read-float/blob/master/index.glsl\\nvec4 packFloat(float v) {\\n float av = abs(v);\\n\\n //Handle special cases\\n if(av < FLOAT_MIN) {\\n return vec4(0.0, 0.0, 0.0, 0.0);\\n } else if(v > FLOAT_MAX) {\\n return vec4(127.0, 128.0, 0.0, 0.0) / 255.0;\\n } else if(v < -FLOAT_MAX) {\\n return vec4(255.0, 128.0, 0.0, 0.0) / 255.0;\\n }\\n\\n vec4 c = vec4(0,0,0,0);\\n\\n //Compute exponent and mantissa\\n float e = floor(log2(av));\\n float m = av * pow(2.0, -e) - 1.0;\\n\\n //Unpack mantissa\\n c[1] = floor(128.0 * m);\\n m -= c[1] / 128.0;\\n c[2] = floor(32768.0 * m);\\n m -= c[2] / 32768.0;\\n c[3] = floor(8388608.0 * m);\\n\\n //Unpack exponent\\n float ebias = e + 127.0;\\n c[0] = floor(ebias / 2.0);\\n ebias -= c[0] * 2.0;\\n c[1] += floor(ebias) * 128.0;\\n\\n //Unpack sign bit\\n c[0] += 128.0 * step(0.0, -v);\\n\\n //Scale back to range\\n return c / 255.0;\\n}\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nuniform float pickId;\\nuniform vec3 clipBounds[2];\\n\\nvarying vec3 worldPosition;\\nvarying float pixelArcLength;\\nvarying vec4 fragColor;\\n\\nvoid main() {\\n if (outOfRange(clipBounds[0], clipBounds[1], worldPosition)) discard;\\n\\n gl_FragColor = vec4(pickId/255.0, packFloat(pixelArcLength).xyz);\\n}\"])\n\nvar ATTRIBUTES = [\n {name: 'position', type: 'vec3'},\n {name: 'nextPosition', type: 'vec3'},\n {name: 'arcLength', type: 'float'},\n {name: 'lineWidth', type: 'float'},\n {name: 'color', type: 'vec4'}\n]\n\nexports.createShader = function(gl) {\n return createShader(gl, vertSrc, forwardFrag, null, ATTRIBUTES)\n}\n\nexports.createPickShader = function(gl) {\n return createShader(gl, vertSrc, pickFrag, null, ATTRIBUTES)\n}\n\n\n/***/ }),\n\n/***/ 5714:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = createLinePlot\n\nvar createBuffer = __webpack_require__(2762)\nvar createVAO = __webpack_require__(8116)\nvar createTexture = __webpack_require__(7766)\n\nvar UINT8_VIEW = new Uint8Array(4)\nvar FLOAT_VIEW = new Float32Array(UINT8_VIEW.buffer)\n// https://github.com/mikolalysenko/glsl-read-float/blob/master/index.js\nfunction unpackFloat(x, y, z, w) {\n UINT8_VIEW[0] = w\n UINT8_VIEW[1] = z\n UINT8_VIEW[2] = y\n UINT8_VIEW[3] = x\n return FLOAT_VIEW[0]\n}\n\nvar bsearch = __webpack_require__(2478)\nvar ndarray = __webpack_require__(9618)\nvar shaders = __webpack_require__(7319)\n\nvar createShader = shaders.createShader\nvar createPickShader = shaders.createPickShader\n\nvar identity = [1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1]\n\nfunction distance (a, b) {\n var s = 0.0\n for (var i = 0; i < 3; ++i) {\n var d = a[i] - b[i]\n s += d * d\n }\n return Math.sqrt(s)\n}\n\nfunction filterClipBounds (bounds) {\n var result = [[-1e6, -1e6, -1e6], [1e6, 1e6, 1e6]]\n for (var i = 0; i < 3; ++i) {\n result[0][i] = Math.max(bounds[0][i], result[0][i])\n result[1][i] = Math.min(bounds[1][i], result[1][i])\n }\n return result\n}\n\nfunction PickResult (tau, position, index, dataCoordinate) {\n this.arcLength = tau\n this.position = position\n this.index = index\n this.dataCoordinate = dataCoordinate\n}\n\nfunction LinePlot (gl, shader, pickShader, buffer, vao, texture) {\n this.gl = gl\n this.shader = shader\n this.pickShader = pickShader\n this.buffer = buffer\n this.vao = vao\n this.clipBounds = [\n [ -Infinity, -Infinity, -Infinity ],\n [ Infinity, Infinity, Infinity ]]\n this.points = []\n this.arcLength = []\n this.vertexCount = 0\n this.bounds = [[0, 0, 0], [0, 0, 0]]\n this.pickId = 0\n this.lineWidth = 1\n this.texture = texture\n this.dashScale = 1\n this.opacity = 1\n this.hasAlpha = false\n this.dirty = true\n this.pixelRatio = 1\n}\n\nvar proto = LinePlot.prototype\n\nproto.isTransparent = function () {\n return this.hasAlpha\n}\n\nproto.isOpaque = function () {\n return !this.hasAlpha\n}\n\nproto.pickSlots = 1\n\nproto.setPickBase = function (id) {\n this.pickId = id\n}\n\nproto.drawTransparent = proto.draw = function (camera) {\n if (!this.vertexCount) return\n var gl = this.gl\n var shader = this.shader\n var vao = this.vao\n shader.bind()\n shader.uniforms = {\n model: camera.model || identity,\n view: camera.view || identity,\n projection: camera.projection || identity,\n clipBounds: filterClipBounds(this.clipBounds),\n dashTexture: this.texture.bind(),\n dashScale: this.dashScale / this.arcLength[this.arcLength.length - 1],\n opacity: this.opacity,\n screenShape: [gl.drawingBufferWidth, gl.drawingBufferHeight],\n pixelRatio: this.pixelRatio\n }\n vao.bind()\n vao.draw(gl.TRIANGLE_STRIP, this.vertexCount)\n vao.unbind()\n}\n\nproto.drawPick = function (camera) {\n if (!this.vertexCount) return\n var gl = this.gl\n var shader = this.pickShader\n var vao = this.vao\n shader.bind()\n shader.uniforms = {\n model: camera.model || identity,\n view: camera.view || identity,\n projection: camera.projection || identity,\n pickId: this.pickId,\n clipBounds: filterClipBounds(this.clipBounds),\n screenShape: [gl.drawingBufferWidth, gl.drawingBufferHeight],\n pixelRatio: this.pixelRatio\n }\n vao.bind()\n vao.draw(gl.TRIANGLE_STRIP, this.vertexCount)\n vao.unbind()\n}\n\nproto.update = function (options) {\n var i, j\n\n this.dirty = true\n\n var connectGaps = !!options.connectGaps\n\n if ('dashScale' in options) {\n this.dashScale = options.dashScale\n }\n\n this.hasAlpha = false // default to no transparent draw\n if ('opacity' in options) {\n this.opacity = +options.opacity\n if(this.opacity < 1) {\n this.hasAlpha = true;\n }\n }\n\n // Recalculate buffer data\n var buffer = []\n var arcLengthArray = []\n var pointArray = []\n var arcLength = 0.0\n var vertexCount = 0\n var bounds = [\n [ Infinity, Infinity, Infinity ],\n [ -Infinity, -Infinity, -Infinity ]]\n\n var positions = options.position || options.positions\n if (positions) {\n\n // Default color\n var colors = options.color || options.colors || [0, 0, 0, 1]\n\n var lineWidth = options.lineWidth || 1\n\n var hadGap = false\n\n fill_loop:\n for (i = 1; i < positions.length; ++i) {\n var a = positions[i - 1]\n var b = positions[i]\n\n arcLengthArray.push(arcLength)\n pointArray.push(a.slice())\n\n for (j = 0; j < 3; ++j) {\n if (isNaN(a[j]) || isNaN(b[j]) ||\n !isFinite(a[j]) || !isFinite(b[j])) {\n\n if (!connectGaps && buffer.length > 0) {\n for (var k = 0; k < 24; ++k) {\n buffer.push(buffer[buffer.length - 12])\n }\n vertexCount += 2\n hadGap = true\n }\n\n continue fill_loop\n }\n bounds[0][j] = Math.min(bounds[0][j], a[j], b[j])\n bounds[1][j] = Math.max(bounds[1][j], a[j], b[j])\n }\n\n var acolor, bcolor\n if (Array.isArray(colors[0])) {\n acolor = (colors.length > i - 1) ? colors[i - 1] : // using index value\n (colors.length > 0) ? colors[colors.length - 1] : // using last item\n [0, 0, 0, 1]; // using black\n\n bcolor = (colors.length > i) ? colors[i] : // using index value\n (colors.length > 0) ? colors[colors.length - 1] : // using last item\n [0, 0, 0, 1]; // using black\n } else {\n acolor = bcolor = colors\n }\n\n if (acolor.length === 3) {\n acolor = [acolor[0], acolor[1], acolor[2], 1]\n }\n if (bcolor.length === 3) {\n bcolor = [bcolor[0], bcolor[1], bcolor[2], 1]\n }\n\n if(!this.hasAlpha && acolor[3] < 1) this.hasAlpha = true\n\n var w0\n if (Array.isArray(lineWidth)) {\n w0 = (lineWidth.length > i - 1) ? lineWidth[i - 1] : // using index value\n (lineWidth.length > 0) ? lineWidth[lineWidth.length - 1] : // using last item\n [0, 0, 0, 1]; // using black\n } else {\n w0 = lineWidth\n }\n\n var t0 = arcLength\n arcLength += distance(a, b)\n\n if (hadGap) {\n for (j = 0; j < 2; ++j) {\n buffer.push(\n a[0], a[1], a[2], b[0], b[1], b[2], t0, w0, acolor[0], acolor[1], acolor[2], acolor[3])\n }\n vertexCount += 2\n hadGap = false\n }\n\n buffer.push(\n a[0], a[1], a[2], b[0], b[1], b[2], t0, w0, acolor[0], acolor[1], acolor[2], acolor[3],\n a[0], a[1], a[2], b[0], b[1], b[2], t0, -w0, acolor[0], acolor[1], acolor[2], acolor[3],\n b[0], b[1], b[2], a[0], a[1], a[2], arcLength, -w0, bcolor[0], bcolor[1], bcolor[2], bcolor[3],\n b[0], b[1], b[2], a[0], a[1], a[2], arcLength, w0, bcolor[0], bcolor[1], bcolor[2], bcolor[3])\n\n vertexCount += 4\n }\n }\n this.buffer.update(buffer)\n\n arcLengthArray.push(arcLength)\n pointArray.push(positions[positions.length - 1].slice())\n\n this.bounds = bounds\n\n this.vertexCount = vertexCount\n\n this.points = pointArray\n this.arcLength = arcLengthArray\n\n if ('dashes' in options) {\n var dashArray = options.dashes\n\n // Calculate prefix sum\n var prefixSum = dashArray.slice()\n prefixSum.unshift(0)\n for (i = 1; i < prefixSum.length; ++i) {\n prefixSum[i] = prefixSum[i - 1] + prefixSum[i]\n }\n\n var dashTexture = ndarray(new Array(256 * 4), [256, 1, 4])\n for (i = 0; i < 256; ++i) {\n for (j = 0; j < 4; ++j) {\n dashTexture.set(i, 0, j, 0)\n }\n if (bsearch.le(prefixSum, prefixSum[prefixSum.length - 1] * i / 255.0) & 1) {\n dashTexture.set(i, 0, 0, 0)\n } else {\n dashTexture.set(i, 0, 0, 255)\n }\n }\n\n this.texture.setPixels(dashTexture)\n }\n}\n\nproto.dispose = function () {\n this.shader.dispose()\n this.vao.dispose()\n this.buffer.dispose()\n}\n\nproto.pick = function (selection) {\n if (!selection) {\n return null\n }\n if (selection.id !== this.pickId) {\n return null\n }\n var tau = unpackFloat(\n selection.value[0],\n selection.value[1],\n selection.value[2],\n 0)\n var index = bsearch.le(this.arcLength, tau)\n if (index < 0) {\n return null\n }\n if (index === this.arcLength.length - 1) {\n return new PickResult(\n this.arcLength[this.arcLength.length - 1],\n this.points[this.points.length - 1].slice(),\n index)\n }\n var a = this.points[index]\n var b = this.points[Math.min(index + 1, this.points.length - 1)]\n var t = (tau - this.arcLength[index]) / (this.arcLength[index + 1] - this.arcLength[index])\n var ti = 1.0 - t\n var x = [0, 0, 0]\n for (var i = 0; i < 3; ++i) {\n x[i] = ti * a[i] + t * b[i]\n }\n var dataIndex = Math.min((t < 0.5) ? index : (index + 1), this.points.length - 1)\n return new PickResult(\n tau,\n x,\n dataIndex,\n this.points[dataIndex])\n}\n\nfunction createLinePlot (options) {\n var gl = options.gl || (options.scene && options.scene.gl)\n\n var shader = createShader(gl)\n shader.attributes.position.location = 0\n shader.attributes.nextPosition.location = 1\n shader.attributes.arcLength.location = 2\n shader.attributes.lineWidth.location = 3\n shader.attributes.color.location = 4\n\n var pickShader = createPickShader(gl)\n pickShader.attributes.position.location = 0\n pickShader.attributes.nextPosition.location = 1\n pickShader.attributes.arcLength.location = 2\n pickShader.attributes.lineWidth.location = 3\n pickShader.attributes.color.location = 4\n\n var buffer = createBuffer(gl)\n var vao = createVAO(gl, [\n {\n 'buffer': buffer,\n 'size': 3,\n 'offset': 0,\n 'stride': 48\n },\n {\n 'buffer': buffer,\n 'size': 3,\n 'offset': 12,\n 'stride': 48\n },\n {\n 'buffer': buffer,\n 'size': 1,\n 'offset': 24,\n 'stride': 48\n },\n {\n 'buffer': buffer,\n 'size': 1,\n 'offset': 28,\n 'stride': 48\n },\n {\n 'buffer': buffer,\n 'size': 4,\n 'offset': 32,\n 'stride': 48\n }\n ])\n\n // Create texture for dash pattern\n var defaultTexture = ndarray(new Array(256 * 4), [256, 1, 4])\n for (var i = 0; i < 256 * 4; ++i) {\n defaultTexture.data[i] = 255\n }\n var texture = createTexture(gl, defaultTexture)\n texture.wrap = gl.REPEAT\n\n var linePlot = new LinePlot(gl, shader, pickShader, buffer, vao, texture)\n linePlot.update(options)\n return linePlot\n}\n\n\n/***/ }),\n\n/***/ 1903:\n/***/ (function(module) {\n\nmodule.exports = clone;\n\n/**\n * Creates a new mat4 initialized with values from an existing matrix\n *\n * @param {mat4} a matrix to clone\n * @returns {mat4} a new 4x4 matrix\n */\nfunction clone(a) {\n var out = new Float32Array(16);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n};\n\n/***/ }),\n\n/***/ 6864:\n/***/ (function(module) {\n\nmodule.exports = create;\n\n/**\n * Creates a new identity mat4\n *\n * @returns {mat4} a new 4x4 matrix\n */\nfunction create() {\n var out = new Float32Array(16);\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n};\n\n/***/ }),\n\n/***/ 9921:\n/***/ (function(module) {\n\nmodule.exports = determinant;\n\n/**\n * Calculates the determinant of a mat4\n *\n * @param {mat4} a the source matrix\n * @returns {Number} determinant of a\n */\nfunction determinant(a) {\n var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32;\n\n // Calculate the determinant\n return b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n};\n\n/***/ }),\n\n/***/ 7399:\n/***/ (function(module) {\n\nmodule.exports = fromQuat;\n\n/**\n * Creates a matrix from a quaternion rotation.\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @returns {mat4} out\n */\nfunction fromQuat(out, q) {\n var x = q[0], y = q[1], z = q[2], w = q[3],\n x2 = x + x,\n y2 = y + y,\n z2 = z + z,\n\n xx = x * x2,\n yx = y * x2,\n yy = y * y2,\n zx = z * x2,\n zy = z * y2,\n zz = z * z2,\n wx = w * x2,\n wy = w * y2,\n wz = w * z2;\n\n out[0] = 1 - yy - zz;\n out[1] = yx + wz;\n out[2] = zx - wy;\n out[3] = 0;\n\n out[4] = yx - wz;\n out[5] = 1 - xx - zz;\n out[6] = zy + wx;\n out[7] = 0;\n\n out[8] = zx + wy;\n out[9] = zy - wx;\n out[10] = 1 - xx - yy;\n out[11] = 0;\n\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n\n return out;\n};\n\n/***/ }),\n\n/***/ 6743:\n/***/ (function(module) {\n\nmodule.exports = fromRotationTranslation;\n\n/**\n * Creates a matrix from a quaternion rotation and vector translation\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.translate(dest, vec);\n * var quatMat = mat4.create();\n * quat4.toMat4(quat, quatMat);\n * mat4.multiply(dest, quatMat);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {vec3} v Translation vector\n * @returns {mat4} out\n */\nfunction fromRotationTranslation(out, q, v) {\n // Quaternion math\n var x = q[0], y = q[1], z = q[2], w = q[3],\n x2 = x + x,\n y2 = y + y,\n z2 = z + z,\n\n xx = x * x2,\n xy = x * y2,\n xz = x * z2,\n yy = y * y2,\n yz = y * z2,\n zz = z * z2,\n wx = w * x2,\n wy = w * y2,\n wz = w * z2;\n\n out[0] = 1 - (yy + zz);\n out[1] = xy + wz;\n out[2] = xz - wy;\n out[3] = 0;\n out[4] = xy - wz;\n out[5] = 1 - (xx + zz);\n out[6] = yz + wx;\n out[7] = 0;\n out[8] = xz + wy;\n out[9] = yz - wx;\n out[10] = 1 - (xx + yy);\n out[11] = 0;\n out[12] = v[0];\n out[13] = v[1];\n out[14] = v[2];\n out[15] = 1;\n \n return out;\n};\n\n/***/ }),\n\n/***/ 7894:\n/***/ (function(module) {\n\nmodule.exports = identity;\n\n/**\n * Set a mat4 to the identity matrix\n *\n * @param {mat4} out the receiving matrix\n * @returns {mat4} out\n */\nfunction identity(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n};\n\n/***/ }),\n\n/***/ 7608:\n/***/ (function(module) {\n\nmodule.exports = invert;\n\n/**\n * Inverts a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nfunction invert(out, a) {\n var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n b00 = a00 * a11 - a01 * a10,\n b01 = a00 * a12 - a02 * a10,\n b02 = a00 * a13 - a03 * a10,\n b03 = a01 * a12 - a02 * a11,\n b04 = a01 * a13 - a03 * a11,\n b05 = a02 * a13 - a03 * a12,\n b06 = a20 * a31 - a21 * a30,\n b07 = a20 * a32 - a22 * a30,\n b08 = a20 * a33 - a23 * a30,\n b09 = a21 * a32 - a22 * a31,\n b10 = a21 * a33 - a23 * a31,\n b11 = a22 * a33 - a23 * a32,\n\n // Calculate the determinant\n det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n if (!det) { \n return null; \n }\n det = 1.0 / det;\n\n out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n out[1] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n out[2] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n out[3] = (a22 * b04 - a21 * b05 - a23 * b03) * det;\n out[4] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n out[5] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n out[6] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n out[7] = (a20 * b05 - a22 * b02 + a23 * b01) * det;\n out[8] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n out[9] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n out[10] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n out[11] = (a21 * b02 - a20 * b04 - a23 * b00) * det;\n out[12] = (a11 * b07 - a10 * b09 - a12 * b06) * det;\n out[13] = (a00 * b09 - a01 * b07 + a02 * b06) * det;\n out[14] = (a31 * b01 - a30 * b03 - a32 * b00) * det;\n out[15] = (a20 * b03 - a21 * b01 + a22 * b00) * det;\n\n return out;\n};\n\n/***/ }),\n\n/***/ 6582:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar identity = __webpack_require__(7894);\n\nmodule.exports = lookAt;\n\n/**\n * Generates a look-at matrix with the given eye position, focal point, and up axis\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {vec3} eye Position of the viewer\n * @param {vec3} center Point the viewer is looking at\n * @param {vec3} up vec3 pointing up\n * @returns {mat4} out\n */\nfunction lookAt(out, eye, center, up) {\n var x0, x1, x2, y0, y1, y2, z0, z1, z2, len,\n eyex = eye[0],\n eyey = eye[1],\n eyez = eye[2],\n upx = up[0],\n upy = up[1],\n upz = up[2],\n centerx = center[0],\n centery = center[1],\n centerz = center[2];\n\n if (Math.abs(eyex - centerx) < 0.000001 &&\n Math.abs(eyey - centery) < 0.000001 &&\n Math.abs(eyez - centerz) < 0.000001) {\n return identity(out);\n }\n\n z0 = eyex - centerx;\n z1 = eyey - centery;\n z2 = eyez - centerz;\n\n len = 1 / Math.sqrt(z0 * z0 + z1 * z1 + z2 * z2);\n z0 *= len;\n z1 *= len;\n z2 *= len;\n\n x0 = upy * z2 - upz * z1;\n x1 = upz * z0 - upx * z2;\n x2 = upx * z1 - upy * z0;\n len = Math.sqrt(x0 * x0 + x1 * x1 + x2 * x2);\n if (!len) {\n x0 = 0;\n x1 = 0;\n x2 = 0;\n } else {\n len = 1 / len;\n x0 *= len;\n x1 *= len;\n x2 *= len;\n }\n\n y0 = z1 * x2 - z2 * x1;\n y1 = z2 * x0 - z0 * x2;\n y2 = z0 * x1 - z1 * x0;\n\n len = Math.sqrt(y0 * y0 + y1 * y1 + y2 * y2);\n if (!len) {\n y0 = 0;\n y1 = 0;\n y2 = 0;\n } else {\n len = 1 / len;\n y0 *= len;\n y1 *= len;\n y2 *= len;\n }\n\n out[0] = x0;\n out[1] = y0;\n out[2] = z0;\n out[3] = 0;\n out[4] = x1;\n out[5] = y1;\n out[6] = z1;\n out[7] = 0;\n out[8] = x2;\n out[9] = y2;\n out[10] = z2;\n out[11] = 0;\n out[12] = -(x0 * eyex + x1 * eyey + x2 * eyez);\n out[13] = -(y0 * eyex + y1 * eyey + y2 * eyez);\n out[14] = -(z0 * eyex + z1 * eyey + z2 * eyez);\n out[15] = 1;\n\n return out;\n};\n\n/***/ }),\n\n/***/ 6760:\n/***/ (function(module) {\n\nmodule.exports = multiply;\n\n/**\n * Multiplies two mat4's\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the first operand\n * @param {mat4} b the second operand\n * @returns {mat4} out\n */\nfunction multiply(out, a, b) {\n var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n\n // Cache only the current line of the second matrix\n var b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3]; \n out[0] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n out[1] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n out[2] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n out[3] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n b0 = b[4]; b1 = b[5]; b2 = b[6]; b3 = b[7];\n out[4] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n out[5] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n out[6] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n out[7] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n b0 = b[8]; b1 = b[9]; b2 = b[10]; b3 = b[11];\n out[8] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n out[9] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n out[10] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n out[11] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n b0 = b[12]; b1 = b[13]; b2 = b[14]; b3 = b[15];\n out[12] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n out[13] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n out[14] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n out[15] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n return out;\n};\n\n/***/ }),\n\n/***/ 4040:\n/***/ (function(module) {\n\nmodule.exports = ortho;\n\n/**\n * Generates a orthogonal projection matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} left Left bound of the frustum\n * @param {number} right Right bound of the frustum\n * @param {number} bottom Bottom bound of the frustum\n * @param {number} top Top bound of the frustum\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nfunction ortho(out, left, right, bottom, top, near, far) {\n var lr = 1 / (left - right),\n bt = 1 / (bottom - top),\n nf = 1 / (near - far);\n out[0] = -2 * lr;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = -2 * bt;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 2 * nf;\n out[11] = 0;\n out[12] = (left + right) * lr;\n out[13] = (top + bottom) * bt;\n out[14] = (far + near) * nf;\n out[15] = 1;\n return out;\n};\n\n/***/ }),\n\n/***/ 4772:\n/***/ (function(module) {\n\nmodule.exports = perspective;\n\n/**\n * Generates a perspective projection matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} fovy Vertical field of view in radians\n * @param {number} aspect Aspect ratio. typically viewport width/height\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nfunction perspective(out, fovy, aspect, near, far) {\n var f = 1.0 / Math.tan(fovy / 2),\n nf = 1 / (near - far);\n out[0] = f / aspect;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = f;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = (far + near) * nf;\n out[11] = -1;\n out[12] = 0;\n out[13] = 0;\n out[14] = (2 * far * near) * nf;\n out[15] = 0;\n return out;\n};\n\n/***/ }),\n\n/***/ 6079:\n/***/ (function(module) {\n\nmodule.exports = rotate;\n\n/**\n * Rotates a mat4 by the given angle\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @param {vec3} axis the axis to rotate around\n * @returns {mat4} out\n */\nfunction rotate(out, a, rad, axis) {\n var x = axis[0], y = axis[1], z = axis[2],\n len = Math.sqrt(x * x + y * y + z * z),\n s, c, t,\n a00, a01, a02, a03,\n a10, a11, a12, a13,\n a20, a21, a22, a23,\n b00, b01, b02,\n b10, b11, b12,\n b20, b21, b22;\n\n if (Math.abs(len) < 0.000001) { return null; }\n \n len = 1 / len;\n x *= len;\n y *= len;\n z *= len;\n\n s = Math.sin(rad);\n c = Math.cos(rad);\n t = 1 - c;\n\n a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3];\n a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7];\n a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11];\n\n // Construct the elements of the rotation matrix\n b00 = x * x * t + c; b01 = y * x * t + z * s; b02 = z * x * t - y * s;\n b10 = x * y * t - z * s; b11 = y * y * t + c; b12 = z * y * t + x * s;\n b20 = x * z * t + y * s; b21 = y * z * t - x * s; b22 = z * z * t + c;\n\n // Perform rotation-specific matrix multiplication\n out[0] = a00 * b00 + a10 * b01 + a20 * b02;\n out[1] = a01 * b00 + a11 * b01 + a21 * b02;\n out[2] = a02 * b00 + a12 * b01 + a22 * b02;\n out[3] = a03 * b00 + a13 * b01 + a23 * b02;\n out[4] = a00 * b10 + a10 * b11 + a20 * b12;\n out[5] = a01 * b10 + a11 * b11 + a21 * b12;\n out[6] = a02 * b10 + a12 * b11 + a22 * b12;\n out[7] = a03 * b10 + a13 * b11 + a23 * b12;\n out[8] = a00 * b20 + a10 * b21 + a20 * b22;\n out[9] = a01 * b20 + a11 * b21 + a21 * b22;\n out[10] = a02 * b20 + a12 * b21 + a22 * b22;\n out[11] = a03 * b20 + a13 * b21 + a23 * b22;\n\n if (a !== out) { // If the source and destination differ, copy the unchanged last row\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n }\n return out;\n};\n\n/***/ }),\n\n/***/ 5567:\n/***/ (function(module) {\n\nmodule.exports = rotateX;\n\n/**\n * Rotates a matrix by the given angle around the X axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nfunction rotateX(out, a, rad) {\n var s = Math.sin(rad),\n c = Math.cos(rad),\n a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7],\n a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n\n if (a !== out) { // If the source and destination differ, copy the unchanged rows\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n }\n\n // Perform axis-specific matrix multiplication\n out[4] = a10 * c + a20 * s;\n out[5] = a11 * c + a21 * s;\n out[6] = a12 * c + a22 * s;\n out[7] = a13 * c + a23 * s;\n out[8] = a20 * c - a10 * s;\n out[9] = a21 * c - a11 * s;\n out[10] = a22 * c - a12 * s;\n out[11] = a23 * c - a13 * s;\n return out;\n};\n\n/***/ }),\n\n/***/ 2408:\n/***/ (function(module) {\n\nmodule.exports = rotateY;\n\n/**\n * Rotates a matrix by the given angle around the Y axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nfunction rotateY(out, a, rad) {\n var s = Math.sin(rad),\n c = Math.cos(rad),\n a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3],\n a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n\n if (a !== out) { // If the source and destination differ, copy the unchanged rows\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n }\n\n // Perform axis-specific matrix multiplication\n out[0] = a00 * c - a20 * s;\n out[1] = a01 * c - a21 * s;\n out[2] = a02 * c - a22 * s;\n out[3] = a03 * c - a23 * s;\n out[8] = a00 * s + a20 * c;\n out[9] = a01 * s + a21 * c;\n out[10] = a02 * s + a22 * c;\n out[11] = a03 * s + a23 * c;\n return out;\n};\n\n/***/ }),\n\n/***/ 7089:\n/***/ (function(module) {\n\nmodule.exports = rotateZ;\n\n/**\n * Rotates a matrix by the given angle around the Z axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nfunction rotateZ(out, a, rad) {\n var s = Math.sin(rad),\n c = Math.cos(rad),\n a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3],\n a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n\n if (a !== out) { // If the source and destination differ, copy the unchanged last row\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n }\n\n // Perform axis-specific matrix multiplication\n out[0] = a00 * c + a10 * s;\n out[1] = a01 * c + a11 * s;\n out[2] = a02 * c + a12 * s;\n out[3] = a03 * c + a13 * s;\n out[4] = a10 * c - a00 * s;\n out[5] = a11 * c - a01 * s;\n out[6] = a12 * c - a02 * s;\n out[7] = a13 * c - a03 * s;\n return out;\n};\n\n/***/ }),\n\n/***/ 2504:\n/***/ (function(module) {\n\nmodule.exports = scale;\n\n/**\n * Scales the mat4 by the dimensions in the given vec3\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to scale\n * @param {vec3} v the vec3 to scale the matrix by\n * @returns {mat4} out\n **/\nfunction scale(out, a, v) {\n var x = v[0], y = v[1], z = v[2];\n\n out[0] = a[0] * x;\n out[1] = a[1] * x;\n out[2] = a[2] * x;\n out[3] = a[3] * x;\n out[4] = a[4] * y;\n out[5] = a[5] * y;\n out[6] = a[6] * y;\n out[7] = a[7] * y;\n out[8] = a[8] * z;\n out[9] = a[9] * z;\n out[10] = a[10] * z;\n out[11] = a[11] * z;\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n};\n\n/***/ }),\n\n/***/ 7656:\n/***/ (function(module) {\n\nmodule.exports = translate;\n\n/**\n * Translate a mat4 by the given vector\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to translate\n * @param {vec3} v vector to translate by\n * @returns {mat4} out\n */\nfunction translate(out, a, v) {\n var x = v[0], y = v[1], z = v[2],\n a00, a01, a02, a03,\n a10, a11, a12, a13,\n a20, a21, a22, a23;\n\n if (a === out) {\n out[12] = a[0] * x + a[4] * y + a[8] * z + a[12];\n out[13] = a[1] * x + a[5] * y + a[9] * z + a[13];\n out[14] = a[2] * x + a[6] * y + a[10] * z + a[14];\n out[15] = a[3] * x + a[7] * y + a[11] * z + a[15];\n } else {\n a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3];\n a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7];\n a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11];\n\n out[0] = a00; out[1] = a01; out[2] = a02; out[3] = a03;\n out[4] = a10; out[5] = a11; out[6] = a12; out[7] = a13;\n out[8] = a20; out[9] = a21; out[10] = a22; out[11] = a23;\n\n out[12] = a00 * x + a10 * y + a20 * z + a[12];\n out[13] = a01 * x + a11 * y + a21 * z + a[13];\n out[14] = a02 * x + a12 * y + a22 * z + a[14];\n out[15] = a03 * x + a13 * y + a23 * z + a[15];\n }\n\n return out;\n};\n\n/***/ }),\n\n/***/ 5665:\n/***/ (function(module) {\n\nmodule.exports = transpose;\n\n/**\n * Transpose the values of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nfunction transpose(out, a) {\n // If we are transposing ourselves we can skip a few steps but have to cache some values\n if (out === a) {\n var a01 = a[1], a02 = a[2], a03 = a[3],\n a12 = a[6], a13 = a[7],\n a23 = a[11];\n\n out[1] = a[4];\n out[2] = a[8];\n out[3] = a[12];\n out[4] = a01;\n out[6] = a[9];\n out[7] = a[13];\n out[8] = a02;\n out[9] = a12;\n out[11] = a[14];\n out[12] = a03;\n out[13] = a13;\n out[14] = a23;\n } else {\n out[0] = a[0];\n out[1] = a[4];\n out[2] = a[8];\n out[3] = a[12];\n out[4] = a[1];\n out[5] = a[5];\n out[6] = a[9];\n out[7] = a[13];\n out[8] = a[2];\n out[9] = a[6];\n out[10] = a[10];\n out[11] = a[14];\n out[12] = a[3];\n out[13] = a[7];\n out[14] = a[11];\n out[15] = a[15];\n }\n \n return out;\n};\n\n/***/ }),\n\n/***/ 7626:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar barycentric = __webpack_require__(2642)\nvar closestPointToTriangle = __webpack_require__(9346)\n\nmodule.exports = closestPointToPickLocation\n\nfunction xformMatrix(m, v) {\n var out = [0,0,0,0]\n for(var i=0; i<4; ++i) {\n for(var j=0; j<4; ++j) {\n out[j] += m[4*i + j] * v[i]\n }\n }\n return out\n}\n\nfunction projectVertex(v, model, view, projection, resolution) {\n var p = xformMatrix(projection,\n xformMatrix(view,\n xformMatrix(model, [v[0], v[1], v[2], 1])))\n for(var i=0; i<3; ++i) {\n p[i] /= p[3]\n }\n return [ 0.5 * resolution[0] * (1.0+p[0]), 0.5 * resolution[1] * (1.0-p[1]) ]\n}\n\nfunction barycentricCoord(simplex, point) {\n if(simplex.length === 2) {\n var d0 = 0.0\n var d1 = 0.0\n for(var i=0; i<2; ++i) {\n d0 += Math.pow(point[i] - simplex[0][i], 2)\n d1 += Math.pow(point[i] - simplex[1][i], 2)\n }\n d0 = Math.sqrt(d0)\n d1 = Math.sqrt(d1)\n if(d0+d1 < 1e-6) {\n return [1,0]\n }\n return [d1/(d0+d1),d0/(d1+d0)]\n } else if(simplex.length === 3) {\n var closestPoint = [0,0]\n closestPointToTriangle(simplex[0], simplex[1], simplex[2], point, closestPoint)\n return barycentric(simplex, closestPoint)\n }\n return []\n}\n\nfunction interpolate(simplex, weights) {\n var result = [0,0,0]\n for(var i=0; i 1.0001) {\n return null\n }\n s += weights[i]\n }\n if(Math.abs(s - 1.0) > 0.001) {\n return null\n }\n return [closestIndex, interpolate(simplex, weights), weights]\n}\n\n/***/ }),\n\n/***/ 840:\n/***/ (function(__unused_webpack_module, exports, __webpack_require__) {\n\nvar glslify = __webpack_require__(3236)\n\nvar triVertSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nattribute vec3 position, normal;\\nattribute vec4 color;\\nattribute vec2 uv;\\n\\nuniform mat4 model\\n , view\\n , projection\\n , inverseModel;\\nuniform vec3 eyePosition\\n , lightPosition;\\n\\nvarying vec3 f_normal\\n , f_lightDirection\\n , f_eyeDirection\\n , f_data;\\nvarying vec4 f_color;\\nvarying vec2 f_uv;\\n\\nvec4 project(vec3 p) {\\n return projection * (view * (model * vec4(p, 1.0)));\\n}\\n\\nvoid main() {\\n gl_Position = project(position);\\n\\n //Lighting geometry parameters\\n vec4 cameraCoordinate = view * vec4(position , 1.0);\\n cameraCoordinate.xyz /= cameraCoordinate.w;\\n f_lightDirection = lightPosition - cameraCoordinate.xyz;\\n f_eyeDirection = eyePosition - cameraCoordinate.xyz;\\n f_normal = normalize((vec4(normal, 0.0) * inverseModel).xyz);\\n\\n f_color = color;\\n f_data = position;\\n f_uv = uv;\\n}\\n\"])\nvar triFragSrc = glslify([\"#extension GL_OES_standard_derivatives : enable\\n\\nprecision highp float;\\n#define GLSLIFY 1\\n\\nfloat beckmannDistribution(float x, float roughness) {\\n float NdotH = max(x, 0.0001);\\n float cos2Alpha = NdotH * NdotH;\\n float tan2Alpha = (cos2Alpha - 1.0) / cos2Alpha;\\n float roughness2 = roughness * roughness;\\n float denom = 3.141592653589793 * roughness2 * cos2Alpha * cos2Alpha;\\n return exp(tan2Alpha / roughness2) / denom;\\n}\\n\\nfloat cookTorranceSpecular(\\n vec3 lightDirection,\\n vec3 viewDirection,\\n vec3 surfaceNormal,\\n float roughness,\\n float fresnel) {\\n\\n float VdotN = max(dot(viewDirection, surfaceNormal), 0.0);\\n float LdotN = max(dot(lightDirection, surfaceNormal), 0.0);\\n\\n //Half angle vector\\n vec3 H = normalize(lightDirection + viewDirection);\\n\\n //Geometric term\\n float NdotH = max(dot(surfaceNormal, H), 0.0);\\n float VdotH = max(dot(viewDirection, H), 0.000001);\\n float LdotH = max(dot(lightDirection, H), 0.000001);\\n float G1 = (2.0 * NdotH * VdotN) / VdotH;\\n float G2 = (2.0 * NdotH * LdotN) / LdotH;\\n float G = min(1.0, min(G1, G2));\\n \\n //Distribution term\\n float D = beckmannDistribution(NdotH, roughness);\\n\\n //Fresnel term\\n float F = pow(1.0 - VdotN, fresnel);\\n\\n //Multiply terms and done\\n return G * F * D / max(3.14159265 * VdotN, 0.000001);\\n}\\n\\n//#pragma glslify: beckmann = require(glsl-specular-beckmann) // used in gl-surface3d\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nuniform vec3 clipBounds[2];\\nuniform float roughness\\n , fresnel\\n , kambient\\n , kdiffuse\\n , kspecular;\\nuniform sampler2D texture;\\n\\nvarying vec3 f_normal\\n , f_lightDirection\\n , f_eyeDirection\\n , f_data;\\nvarying vec4 f_color;\\nvarying vec2 f_uv;\\n\\nvoid main() {\\n if (f_color.a == 0.0 ||\\n outOfRange(clipBounds[0], clipBounds[1], f_data)\\n ) discard;\\n\\n vec3 N = normalize(f_normal);\\n vec3 L = normalize(f_lightDirection);\\n vec3 V = normalize(f_eyeDirection);\\n\\n if(gl_FrontFacing) {\\n N = -N;\\n }\\n\\n float specular = min(1.0, max(0.0, cookTorranceSpecular(L, V, N, roughness, fresnel)));\\n //float specular = max(0.0, beckmann(L, V, N, roughness)); // used in gl-surface3d\\n\\n float diffuse = min(kambient + kdiffuse * max(dot(N, L), 0.0), 1.0);\\n\\n vec4 surfaceColor = vec4(f_color.rgb, 1.0) * texture2D(texture, f_uv);\\n vec4 litColor = surfaceColor.a * vec4(diffuse * surfaceColor.rgb + kspecular * vec3(1,1,1) * specular, 1.0);\\n\\n gl_FragColor = litColor * f_color.a;\\n}\\n\"])\nvar edgeVertSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nattribute vec3 position;\\nattribute vec4 color;\\nattribute vec2 uv;\\n\\nuniform mat4 model, view, projection;\\n\\nvarying vec4 f_color;\\nvarying vec3 f_data;\\nvarying vec2 f_uv;\\n\\nvoid main() {\\n gl_Position = projection * (view * (model * vec4(position, 1.0)));\\n f_color = color;\\n f_data = position;\\n f_uv = uv;\\n}\"])\nvar edgeFragSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nuniform vec3 clipBounds[2];\\nuniform sampler2D texture;\\nuniform float opacity;\\n\\nvarying vec4 f_color;\\nvarying vec3 f_data;\\nvarying vec2 f_uv;\\n\\nvoid main() {\\n if (outOfRange(clipBounds[0], clipBounds[1], f_data)) discard;\\n\\n gl_FragColor = f_color * texture2D(texture, f_uv) * opacity;\\n}\"])\nvar pointVertSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nattribute vec3 position;\\nattribute vec4 color;\\nattribute vec2 uv;\\nattribute float pointSize;\\n\\nuniform mat4 model, view, projection;\\nuniform vec3 clipBounds[2];\\n\\nvarying vec4 f_color;\\nvarying vec2 f_uv;\\n\\nvoid main() {\\n if (outOfRange(clipBounds[0], clipBounds[1], position)) {\\n\\n gl_Position = vec4(0.0, 0.0 ,0.0 ,0.0);\\n } else {\\n gl_Position = projection * (view * (model * vec4(position, 1.0)));\\n }\\n gl_PointSize = pointSize;\\n f_color = color;\\n f_uv = uv;\\n}\"])\nvar pointFragSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nuniform sampler2D texture;\\nuniform float opacity;\\n\\nvarying vec4 f_color;\\nvarying vec2 f_uv;\\n\\nvoid main() {\\n vec2 pointR = gl_PointCoord.xy - vec2(0.5, 0.5);\\n if(dot(pointR, pointR) > 0.25) {\\n discard;\\n }\\n gl_FragColor = f_color * texture2D(texture, f_uv) * opacity;\\n}\"])\nvar pickVertSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nattribute vec3 position;\\nattribute vec4 id;\\n\\nuniform mat4 model, view, projection;\\n\\nvarying vec3 f_position;\\nvarying vec4 f_id;\\n\\nvoid main() {\\n gl_Position = projection * (view * (model * vec4(position, 1.0)));\\n f_id = id;\\n f_position = position;\\n}\"])\nvar pickFragSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nuniform vec3 clipBounds[2];\\nuniform float pickId;\\n\\nvarying vec3 f_position;\\nvarying vec4 f_id;\\n\\nvoid main() {\\n if (outOfRange(clipBounds[0], clipBounds[1], f_position)) discard;\\n\\n gl_FragColor = vec4(pickId, f_id.xyz);\\n}\"])\nvar pickPointVertSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nattribute vec3 position;\\nattribute float pointSize;\\nattribute vec4 id;\\n\\nuniform mat4 model, view, projection;\\nuniform vec3 clipBounds[2];\\n\\nvarying vec3 f_position;\\nvarying vec4 f_id;\\n\\nvoid main() {\\n if (outOfRange(clipBounds[0], clipBounds[1], position)) {\\n\\n gl_Position = vec4(0.0, 0.0, 0.0, 0.0);\\n } else {\\n gl_Position = projection * (view * (model * vec4(position, 1.0)));\\n gl_PointSize = pointSize;\\n }\\n f_id = id;\\n f_position = position;\\n}\"])\nvar contourVertSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nattribute vec3 position;\\n\\nuniform mat4 model, view, projection;\\n\\nvoid main() {\\n gl_Position = projection * (view * (model * vec4(position, 1.0)));\\n}\"])\nvar contourFragSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nuniform vec3 contourColor;\\n\\nvoid main() {\\n gl_FragColor = vec4(contourColor, 1.0);\\n}\\n\"])\n\nexports.meshShader = {\n vertex: triVertSrc,\n fragment: triFragSrc,\n attributes: [\n {name: 'position', type: 'vec3'},\n {name: 'normal', type: 'vec3'},\n {name: 'color', type: 'vec4'},\n {name: 'uv', type: 'vec2'}\n ]\n}\nexports.wireShader = {\n vertex: edgeVertSrc,\n fragment: edgeFragSrc,\n attributes: [\n {name: 'position', type: 'vec3'},\n {name: 'color', type: 'vec4'},\n {name: 'uv', type: 'vec2'}\n ]\n}\nexports.pointShader = {\n vertex: pointVertSrc,\n fragment: pointFragSrc,\n attributes: [\n {name: 'position', type: 'vec3'},\n {name: 'color', type: 'vec4'},\n {name: 'uv', type: 'vec2'},\n {name: 'pointSize', type: 'float'}\n ]\n}\nexports.pickShader = {\n vertex: pickVertSrc,\n fragment: pickFragSrc,\n attributes: [\n {name: 'position', type: 'vec3'},\n {name: 'id', type: 'vec4'}\n ]\n}\nexports.pointPickShader = {\n vertex: pickPointVertSrc,\n fragment: pickFragSrc,\n attributes: [\n {name: 'position', type: 'vec3'},\n {name: 'pointSize', type: 'float'},\n {name: 'id', type: 'vec4'}\n ]\n}\nexports.contourShader = {\n vertex: contourVertSrc,\n fragment: contourFragSrc,\n attributes: [\n {name: 'position', type: 'vec3'}\n ]\n}\n\n\n/***/ }),\n\n/***/ 7201:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar DEFAULT_VERTEX_NORMALS_EPSILON = 1e-6; // may be too large if triangles are very small\nvar DEFAULT_FACE_NORMALS_EPSILON = 1e-6;\n\nvar createShader = __webpack_require__(9405)\nvar createBuffer = __webpack_require__(2762)\nvar createVAO = __webpack_require__(8116)\nvar createTexture = __webpack_require__(7766)\nvar normals = __webpack_require__(8406)\nvar multiply = __webpack_require__(6760)\nvar invert = __webpack_require__(7608)\nvar ndarray = __webpack_require__(9618)\nvar colormap = __webpack_require__(6729)\nvar getContour = __webpack_require__(7765)\nvar pool = __webpack_require__(1888)\nvar shaders = __webpack_require__(840)\nvar closestPoint = __webpack_require__(7626)\n\nvar meshShader = shaders.meshShader\nvar wireShader = shaders.wireShader\nvar pointShader = shaders.pointShader\nvar pickShader = shaders.pickShader\nvar pointPickShader = shaders.pointPickShader\nvar contourShader = shaders.contourShader\n\nvar IDENTITY = [\n 1,0,0,0,\n 0,1,0,0,\n 0,0,1,0,\n 0,0,0,1]\n\n\nfunction SimplicialMesh(gl\n , texture\n , triShader\n , lineShader\n , pointShader\n , pickShader\n , pointPickShader\n , contourShader\n , trianglePositions\n , triangleIds\n , triangleColors\n , triangleUVs\n , triangleNormals\n , triangleVAO\n , edgePositions\n , edgeIds\n , edgeColors\n , edgeUVs\n , edgeVAO\n , pointPositions\n , pointIds\n , pointColors\n , pointUVs\n , pointSizes\n , pointVAO\n , contourPositions\n , contourVAO) {\n\n this.gl = gl\n this.pixelRatio = 1\n this.cells = []\n this.positions = []\n this.intensity = []\n this.texture = texture\n this.dirty = true\n\n this.triShader = triShader\n this.lineShader = lineShader\n this.pointShader = pointShader\n this.pickShader = pickShader\n this.pointPickShader = pointPickShader\n this.contourShader = contourShader\n\n this.trianglePositions = trianglePositions\n this.triangleColors = triangleColors\n this.triangleNormals = triangleNormals\n this.triangleUVs = triangleUVs\n this.triangleIds = triangleIds\n this.triangleVAO = triangleVAO\n this.triangleCount = 0\n\n this.lineWidth = 1\n this.edgePositions = edgePositions\n this.edgeColors = edgeColors\n this.edgeUVs = edgeUVs\n this.edgeIds = edgeIds\n this.edgeVAO = edgeVAO\n this.edgeCount = 0\n\n this.pointPositions = pointPositions\n this.pointColors = pointColors\n this.pointUVs = pointUVs\n this.pointSizes = pointSizes\n this.pointIds = pointIds\n this.pointVAO = pointVAO\n this.pointCount = 0\n\n this.contourLineWidth = 1\n this.contourPositions = contourPositions\n this.contourVAO = contourVAO\n this.contourCount = 0\n this.contourColor = [0,0,0]\n this.contourEnable = true\n\n this.pickVertex = true;\n this.pickId = 1\n this.bounds = [\n [ Infinity, Infinity, Infinity],\n [-Infinity,-Infinity,-Infinity] ]\n this.clipBounds = [\n [-Infinity,-Infinity,-Infinity],\n [ Infinity, Infinity, Infinity] ]\n\n this.lightPosition = [1e5, 1e5, 0]\n this.ambientLight = 0.8\n this.diffuseLight = 0.8\n this.specularLight = 2.0\n this.roughness = 0.5\n this.fresnel = 1.5\n\n this.opacity = 1.0\n this.hasAlpha = false\n this.opacityscale = false\n\n this._model = IDENTITY\n this._view = IDENTITY\n this._projection = IDENTITY\n this._resolution = [1,1]\n}\n\nvar proto = SimplicialMesh.prototype\n\nproto.isOpaque = function() {\n return !this.hasAlpha\n}\n\nproto.isTransparent = function() {\n return this.hasAlpha\n}\n\nproto.pickSlots = 1\n\nproto.setPickBase = function(id) {\n this.pickId = id\n}\n\nfunction getOpacityFromScale(ratio, opacityscale) {\n\n if(!opacityscale) return 1\n if(!opacityscale.length) return 1\n\n for(var i = 0; i < opacityscale.length; ++i) {\n if(opacityscale.length < 2) return 1\n if(opacityscale[i][0] === ratio) return opacityscale[i][1]\n if(opacityscale[i][0] > ratio && i > 0) {\n var d = (opacityscale[i][0] - ratio) / (opacityscale[i][0] - opacityscale[i - 1][0])\n return opacityscale[i][1] * (1 - d) + d * opacityscale[i - 1][1]\n }\n }\n\n return 1\n}\n\nfunction genColormap(param, opacityscale) {\n var colors = colormap({\n colormap: param\n , nshades: 256\n , format: 'rgba'\n })\n\n var result = new Uint8Array(256*4)\n for(var i=0; i<256; ++i) {\n var c = colors[i]\n for(var j=0; j<3; ++j) {\n result[4*i+j] = c[j]\n }\n if(!opacityscale) {\n result[4*i+3] = 255 * c[3]\n } else {\n result[4*i+3] = 255 * getOpacityFromScale(i / 255.0, opacityscale)\n }\n }\n\n return ndarray(result, [256,256,4], [4,0,1])\n}\n\nfunction takeZComponent(array) {\n var n = array.length\n var result = new Array(n)\n for(var i=0; i 0) {\n var shader = this.triShader\n shader.bind()\n shader.uniforms = uniforms\n\n this.triangleVAO.bind()\n gl.drawArrays(gl.TRIANGLES, 0, this.triangleCount*3)\n this.triangleVAO.unbind()\n }\n\n if(this.edgeCount > 0 && this.lineWidth > 0) {\n var shader = this.lineShader\n shader.bind()\n shader.uniforms = uniforms\n\n this.edgeVAO.bind()\n gl.lineWidth(this.lineWidth * this.pixelRatio)\n gl.drawArrays(gl.LINES, 0, this.edgeCount*2)\n this.edgeVAO.unbind()\n }\n\n if(this.pointCount > 0) {\n var shader = this.pointShader\n shader.bind()\n shader.uniforms = uniforms\n\n this.pointVAO.bind()\n gl.drawArrays(gl.POINTS, 0, this.pointCount)\n this.pointVAO.unbind()\n }\n\n if(this.contourEnable && this.contourCount > 0 && this.contourLineWidth > 0) {\n var shader = this.contourShader\n shader.bind()\n shader.uniforms = uniforms\n\n this.contourVAO.bind()\n gl.drawArrays(gl.LINES, 0, this.contourCount)\n this.contourVAO.unbind()\n }\n}\n\nproto.drawPick = function(params) {\n params = params || {}\n\n var gl = this.gl\n\n var model = params.model || IDENTITY\n var view = params.view || IDENTITY\n var projection = params.projection || IDENTITY\n\n var clipBounds = [[-1e6,-1e6,-1e6],[1e6,1e6,1e6]]\n for(var i=0; i<3; ++i) {\n clipBounds[0][i] = Math.max(clipBounds[0][i], this.clipBounds[0][i])\n clipBounds[1][i] = Math.min(clipBounds[1][i], this.clipBounds[1][i])\n }\n\n //Save camera parameters\n this._model = [].slice.call(model)\n this._view = [].slice.call(view)\n this._projection = [].slice.call(projection)\n this._resolution = [gl.drawingBufferWidth, gl.drawingBufferHeight]\n\n var uniforms = {\n model: model,\n view: view,\n projection: projection,\n clipBounds: clipBounds,\n pickId: this.pickId / 255.0,\n }\n\n var shader = this.pickShader\n shader.bind()\n shader.uniforms = uniforms\n\n if(this.triangleCount > 0) {\n this.triangleVAO.bind()\n gl.drawArrays(gl.TRIANGLES, 0, this.triangleCount*3)\n this.triangleVAO.unbind()\n }\n\n if(this.edgeCount > 0) {\n this.edgeVAO.bind()\n gl.lineWidth(this.lineWidth * this.pixelRatio)\n gl.drawArrays(gl.LINES, 0, this.edgeCount*2)\n this.edgeVAO.unbind()\n }\n\n if(this.pointCount > 0) {\n var shader = this.pointPickShader\n shader.bind()\n shader.uniforms = uniforms\n\n this.pointVAO.bind()\n gl.drawArrays(gl.POINTS, 0, this.pointCount)\n this.pointVAO.unbind()\n }\n}\n\n\nproto.pick = function(pickData) {\n if(!pickData) {\n return null\n }\n if(pickData.id !== this.pickId) {\n return null\n }\n\n var cellId = pickData.value[0] + 256*pickData.value[1] + 65536*pickData.value[2]\n var cell = this.cells[cellId]\n var positions = this.positions\n\n var simplex = new Array(cell.length)\n for(var i=0; i tickOffset[start]) {\n shader.uniforms.dataAxis = DATA_AXIS\n shader.uniforms.screenOffset = SCREEN_OFFSET\n shader.uniforms.color = textColor[axis]\n shader.uniforms.angle = textAngle[axis]\n gl.drawArrays(\n gl.TRIANGLES,\n tickOffset[start],\n tickOffset[end] - tickOffset[start])\n }\n }\n if(labelEnable[axis] && labelCount) {\n SCREEN_OFFSET[axis^1] -= screenScale * pixelRatio * labelPad[axis]\n shader.uniforms.dataAxis = ZERO_2\n shader.uniforms.screenOffset = SCREEN_OFFSET\n shader.uniforms.color = labelColor[axis]\n shader.uniforms.angle = labelAngle[axis]\n gl.drawArrays(\n gl.TRIANGLES,\n labelOffset,\n labelCount)\n }\n\n SCREEN_OFFSET[axis^1] = screenScale * viewBox[2+(axis^1)] - 1.0\n if(tickEnable[axis+2]) {\n SCREEN_OFFSET[axis^1] += screenScale * pixelRatio * tickPad[axis+2]\n if(start < end && tickOffset[end] > tickOffset[start]) {\n shader.uniforms.dataAxis = DATA_AXIS\n shader.uniforms.screenOffset = SCREEN_OFFSET\n shader.uniforms.color = textColor[axis+2]\n shader.uniforms.angle = textAngle[axis+2]\n gl.drawArrays(\n gl.TRIANGLES,\n tickOffset[start],\n tickOffset[end] - tickOffset[start])\n }\n }\n if(labelEnable[axis+2] && labelCount) {\n SCREEN_OFFSET[axis^1] += screenScale * pixelRatio * labelPad[axis+2]\n shader.uniforms.dataAxis = ZERO_2\n shader.uniforms.screenOffset = SCREEN_OFFSET\n shader.uniforms.color = labelColor[axis+2]\n shader.uniforms.angle = labelAngle[axis+2]\n gl.drawArrays(\n gl.TRIANGLES,\n labelOffset,\n labelCount)\n }\n\n }\n})()\n\nproto.drawTitle = (function() {\n var DATA_AXIS = [0,0]\n var SCREEN_OFFSET = [0,0]\n\n return function() {\n var plot = this.plot\n var shader = this.shader\n var gl = plot.gl\n var screenBox = plot.screenBox\n var titleCenter = plot.titleCenter\n var titleAngle = plot.titleAngle\n var titleColor = plot.titleColor\n var pixelRatio = plot.pixelRatio\n\n if(!this.titleCount) {\n return\n }\n\n for(var i=0; i<2; ++i) {\n SCREEN_OFFSET[i] = 2.0 * (titleCenter[i]*pixelRatio - screenBox[i]) /\n (screenBox[2+i] - screenBox[i]) - 1\n }\n\n shader.bind()\n shader.uniforms.dataAxis = DATA_AXIS\n shader.uniforms.screenOffset = SCREEN_OFFSET\n shader.uniforms.angle = titleAngle\n shader.uniforms.color = titleColor\n\n gl.drawArrays(gl.TRIANGLES, this.titleOffset, this.titleCount)\n }\n})()\n\nproto.bind = (function() {\n var DATA_SHIFT = [0,0]\n var DATA_SCALE = [0,0]\n var TEXT_SCALE = [0,0]\n\n return function() {\n var plot = this.plot\n var shader = this.shader\n var bounds = plot._tickBounds\n var dataBox = plot.dataBox\n var screenBox = plot.screenBox\n var viewBox = plot.viewBox\n\n shader.bind()\n\n //Set up coordinate scaling uniforms\n for(var i=0; i<2; ++i) {\n\n var lo = bounds[i]\n var hi = bounds[i+2]\n var boundScale = hi - lo\n var dataCenter = 0.5 * (dataBox[i+2] + dataBox[i])\n var dataWidth = (dataBox[i+2] - dataBox[i])\n\n var viewLo = viewBox[i]\n var viewHi = viewBox[i+2]\n var viewScale = viewHi - viewLo\n var screenLo = screenBox[i]\n var screenHi = screenBox[i+2]\n var screenScale = screenHi - screenLo\n\n DATA_SCALE[i] = 2.0 * boundScale / dataWidth * viewScale / screenScale\n DATA_SHIFT[i] = 2.0 * (lo - dataCenter) / dataWidth * viewScale / screenScale\n }\n\n TEXT_SCALE[1] = 2.0 * plot.pixelRatio / (screenBox[3] - screenBox[1])\n TEXT_SCALE[0] = TEXT_SCALE[1] * (screenBox[3] - screenBox[1]) / (screenBox[2] - screenBox[0])\n\n shader.uniforms.dataScale = DATA_SCALE\n shader.uniforms.dataShift = DATA_SHIFT\n shader.uniforms.textScale = TEXT_SCALE\n\n //Set attributes\n this.vbo.bind()\n shader.attributes.textCoordinate.pointer()\n }\n})()\n\nproto.update = function(options) {\n var vertices = []\n var axesTicks = options.ticks\n var bounds = options.bounds\n var i, j, k, data, scale, dimension\n\n for(dimension=0; dimension<2; ++dimension) {\n var offsets = [Math.floor(vertices.length/3)], tickX = [-Infinity]\n\n //Copy vertices over to buffer\n var ticks = axesTicks[dimension]\n for(i=0; i= 0)) {\n continue\n }\n\n var zeroIntercept = screenBox[i] -\n dataBox[i] * (screenBox[i+2] - screenBox[i]) / (dataBox[i+2] - dataBox[i])\n\n if(i === 0) {\n line.drawLine(\n zeroIntercept, screenBox[1], zeroIntercept, screenBox[3],\n zeroLineWidth[i],\n zeroLineColor[i])\n } else {\n line.drawLine(\n screenBox[0], zeroIntercept, screenBox[2], zeroIntercept,\n zeroLineWidth[i],\n zeroLineColor[i])\n }\n }\n }\n\n //Draw traces\n for(var i=0; i=0; --i) {\n this.objects[i].dispose()\n }\n this.objects.length = 0\n for(var i=this.overlays.length-1; i>=0; --i) {\n this.overlays[i].dispose()\n }\n this.overlays.length = 0\n\n this.gl = null\n}\n\nproto.addObject = function(object) {\n if(this.objects.indexOf(object) < 0) {\n this.objects.push(object)\n this.setDirty()\n }\n}\n\nproto.removeObject = function(object) {\n var objects = this.objects\n for(var i=0; i Math.abs(dy)) {\n view.rotate(t, 0, 0, -dx * flipX * Math.PI * camera.rotateSpeed / window.innerWidth)\n } else {\n if(!camera._ortho) {\n var kzoom = -camera.zoomSpeed * flipY * dy / window.innerHeight * (t - view.lastT()) / 20.0\n view.pan(t, 0, 0, distance * (Math.exp(kzoom) - 1))\n }\n }\n }, true)\n }\n\n camera.enableMouseListeners()\n\n return camera\n}\n\n\n/***/ }),\n\n/***/ 799:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar glslify = __webpack_require__(3236)\nvar createShader = __webpack_require__(9405)\n\nvar vertSrc = glslify([\"precision mediump float;\\n#define GLSLIFY 1\\nattribute vec2 position;\\nvarying vec2 uv;\\nvoid main() {\\n uv = position;\\n gl_Position = vec4(position, 0, 1);\\n}\"])\nvar fragSrc = glslify([\"precision mediump float;\\n#define GLSLIFY 1\\n\\nuniform sampler2D accumBuffer;\\nvarying vec2 uv;\\n\\nvoid main() {\\n vec4 accum = texture2D(accumBuffer, 0.5 * (uv + 1.0));\\n gl_FragColor = min(vec4(1,1,1,1), accum);\\n}\"])\n\nmodule.exports = function(gl) {\n return createShader(gl, vertSrc, fragSrc, null, [ { name: 'position', type: 'vec2'}])\n}\n\n\n/***/ }),\n\n/***/ 4100:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar createCamera = __webpack_require__(4437)\nvar createAxes = __webpack_require__(3837)\nvar axesRanges = __webpack_require__(5445)\nvar createSpikes = __webpack_require__(4449)\nvar createSelect = __webpack_require__(3589)\nvar createFBO = __webpack_require__(2260)\nvar drawTriangle = __webpack_require__(7169)\nvar mouseChange = __webpack_require__(351)\nvar perspective = __webpack_require__(4772)\nvar ortho = __webpack_require__(4040)\nvar createShader = __webpack_require__(799)\nvar isMobile = __webpack_require__(9216)({ tablet: true, featureDetect: true })\n\nmodule.exports = {\n createScene: createScene,\n createCamera: createCamera\n}\n\nfunction MouseSelect() {\n this.mouse = [-1,-1]\n this.screen = null\n this.distance = Infinity\n this.index = null\n this.dataCoordinate = null\n this.dataPosition = null\n this.object = null\n this.data = null\n}\n\nfunction getContext(canvas, options) {\n var gl = null\n try {\n gl = canvas.getContext('webgl', options)\n if(!gl) {\n gl = canvas.getContext('experimental-webgl', options)\n }\n } catch(e) {\n return null\n }\n return gl\n}\n\nfunction roundUpPow10(x) {\n var y = Math.round(Math.log(Math.abs(x)) / Math.log(10))\n if(y < 0) {\n var base = Math.round(Math.pow(10, -y))\n return Math.ceil(x*base) / base\n } else if(y > 0) {\n var base = Math.round(Math.pow(10, y))\n return Math.ceil(x/base) * base\n }\n return Math.ceil(x)\n}\n\nfunction defaultBool(x) {\n if(typeof x === 'boolean') {\n return x\n }\n return true\n}\n\nfunction createScene(options) {\n options = options || {}\n options.camera = options.camera || {}\n\n var canvas = options.canvas\n if(!canvas) {\n canvas = document.createElement('canvas')\n if(options.container) {\n var container = options.container\n container.appendChild(canvas)\n } else {\n document.body.appendChild(canvas)\n }\n }\n\n var gl = options.gl\n if(!gl) {\n if(options.glOptions) {\n isMobile = !!options.glOptions.preserveDrawingBuffer\n }\n\n gl = getContext(canvas,\n options.glOptions || {\n premultipliedAlpha: true,\n antialias: true,\n preserveDrawingBuffer: isMobile\n })\n }\n if(!gl) {\n throw new Error('webgl not supported')\n }\n\n //Initial bounds\n var bounds = options.bounds || [[-10,-10,-10], [10,10,10]]\n\n //Create selection\n var selection = new MouseSelect()\n\n //Accumulation buffer\n var accumBuffer = createFBO(gl,\n gl.drawingBufferWidth, gl.drawingBufferHeight, {\n preferFloat: !isMobile\n })\n\n var accumShader = createShader(gl)\n\n var isOrtho =\n (options.cameraObject && options.cameraObject._ortho === true) ||\n (options.camera.projection && options.camera.projection.type === 'orthographic') ||\n false\n\n //Create a camera\n var cameraOptions = {\n eye: options.camera.eye || [2,0,0],\n center: options.camera.center || [0,0,0],\n up: options.camera.up || [0,1,0],\n zoomMin: options.camera.zoomMax || 0.1,\n zoomMax: options.camera.zoomMin || 100,\n mode: options.camera.mode || 'turntable',\n _ortho: isOrtho\n }\n\n //Create axes\n var axesOptions = options.axes || {}\n var axes = createAxes(gl, axesOptions)\n axes.enable = !axesOptions.disable\n\n //Create spikes\n var spikeOptions = options.spikes || {}\n var spikes = createSpikes(gl, spikeOptions)\n\n //Object list is empty initially\n var objects = []\n var pickBufferIds = []\n var pickBufferCount = []\n var pickBuffers = []\n\n //Dirty flag, skip redraw if scene static\n var dirty = true\n var pickDirty = true\n\n var projection = new Array(16)\n var model = new Array(16)\n\n var cameraParams = {\n view: null,\n projection: projection,\n model: model,\n _ortho: false\n }\n\n var pickDirty = true\n\n var viewShape = [ gl.drawingBufferWidth, gl.drawingBufferHeight ]\n\n var camera = options.cameraObject || createCamera(canvas, cameraOptions)\n\n //Create scene object\n var scene = {\n gl: gl,\n contextLost: false,\n pixelRatio: options.pixelRatio || 1,\n canvas: canvas,\n selection: selection,\n camera: camera,\n axes: axes,\n axesPixels: null,\n spikes: spikes,\n bounds: bounds,\n objects: objects,\n shape: viewShape,\n aspect: options.aspectRatio || [1,1,1],\n pickRadius: options.pickRadius || 10,\n zNear: options.zNear || 0.01,\n zFar: options.zFar || 1000,\n fovy: options.fovy || Math.PI/4,\n clearColor: options.clearColor || [0,0,0,0],\n autoResize: defaultBool(options.autoResize),\n autoBounds: defaultBool(options.autoBounds),\n autoScale: !!options.autoScale,\n autoCenter: defaultBool(options.autoCenter),\n clipToBounds: defaultBool(options.clipToBounds),\n snapToData: !!options.snapToData,\n onselect: options.onselect || null,\n onrender: options.onrender || null,\n onclick: options.onclick || null,\n cameraParams: cameraParams,\n oncontextloss: null,\n mouseListener: null,\n _stopped: false,\n\n getAspectratio: function() {\n return {\n x: this.aspect[0],\n y: this.aspect[1],\n z: this.aspect[2]\n }\n },\n\n setAspectratio: function(aspectratio) {\n this.aspect[0] = aspectratio.x\n this.aspect[1] = aspectratio.y\n this.aspect[2] = aspectratio.z\n pickDirty = true\n },\n\n setBounds: function(axisIndex, range) {\n this.bounds[0][axisIndex] = range.min\n this.bounds[1][axisIndex] = range.max\n },\n\n setClearColor: function(clearColor) {\n this.clearColor = clearColor\n },\n\n clearRGBA: function() {\n this.gl.clearColor(\n this.clearColor[0],\n this.clearColor[1],\n this.clearColor[2],\n this.clearColor[3]\n )\n\n this.gl.clear(\n this.gl.COLOR_BUFFER_BIT |\n this.gl.DEPTH_BUFFER_BIT\n )\n }\n }\n\n var pickShape = [ (gl.drawingBufferWidth/scene.pixelRatio)|0, (gl.drawingBufferHeight/scene.pixelRatio)|0 ]\n\n function resizeListener() {\n if(scene._stopped) {\n return\n }\n if(!scene.autoResize) {\n return\n }\n var parent = canvas.parentNode\n var width = 1\n var height = 1\n if(parent && parent !== document.body) {\n width = parent.clientWidth\n height = parent.clientHeight\n } else {\n width = window.innerWidth\n height = window.innerHeight\n }\n var nextWidth = Math.ceil(width * scene.pixelRatio)|0\n var nextHeight = Math.ceil(height * scene.pixelRatio)|0\n if(nextWidth !== canvas.width || nextHeight !== canvas.height) {\n canvas.width = nextWidth\n canvas.height = nextHeight\n var style = canvas.style\n style.position = style.position || 'absolute'\n style.left = '0px'\n style.top = '0px'\n style.width = width + 'px'\n style.height = height + 'px'\n dirty = true\n }\n }\n if(scene.autoResize) {\n resizeListener()\n }\n window.addEventListener('resize', resizeListener)\n\n function reallocPickIds() {\n var numObjs = objects.length\n var numPick = pickBuffers.length\n for(var i=0; i 0 && pickBufferCount[numPick-1] === 0) {\n pickBufferCount.pop()\n pickBuffers.pop().dispose()\n }\n }\n\n scene.update = function(options) {\n\n if(scene._stopped) {\n return\n }\n options = options || {}\n dirty = true\n pickDirty = true\n }\n\n scene.add = function(obj) {\n if(scene._stopped) {\n return\n }\n obj.axes = axes\n objects.push(obj)\n pickBufferIds.push(-1)\n dirty = true\n pickDirty = true\n reallocPickIds()\n }\n\n scene.remove = function(obj) {\n if(scene._stopped) {\n return\n }\n var idx = objects.indexOf(obj)\n if(idx < 0) {\n return\n }\n objects.splice(idx, 1)\n pickBufferIds.pop()\n dirty = true\n pickDirty = true\n reallocPickIds()\n }\n\n scene.dispose = function() {\n if(scene._stopped) {\n return\n }\n\n scene._stopped = true\n\n window.removeEventListener('resize', resizeListener)\n canvas.removeEventListener('webglcontextlost', checkContextLoss)\n scene.mouseListener.enabled = false\n\n if(scene.contextLost) {\n return\n }\n\n //Destroy objects\n axes.dispose()\n spikes.dispose()\n for(var i=0; i selection.distance) {\n continue\n }\n for(var j=0; j 1.0) {\\n discard;\\n }\\n baseColor = mix(borderColor, color, step(radius, centerFraction));\\n gl_FragColor = vec4(baseColor.rgb * baseColor.a, baseColor.a);\\n }\\n}\\n\"])\nexports.pickVertex = glslify([\"precision mediump float;\\n#define GLSLIFY 1\\n\\nattribute vec2 position;\\nattribute vec4 pickId;\\n\\nuniform mat3 matrix;\\nuniform float pointSize;\\nuniform vec4 pickOffset;\\n\\nvarying vec4 fragId;\\n\\nvoid main() {\\n vec3 hgPosition = matrix * vec3(position, 1);\\n gl_Position = vec4(hgPosition.xy, 0, hgPosition.z);\\n gl_PointSize = pointSize;\\n\\n vec4 id = pickId + pickOffset;\\n id.y += floor(id.x / 256.0);\\n id.x -= floor(id.x / 256.0) * 256.0;\\n\\n id.z += floor(id.y / 256.0);\\n id.y -= floor(id.y / 256.0) * 256.0;\\n\\n id.w += floor(id.z / 256.0);\\n id.z -= floor(id.z / 256.0) * 256.0;\\n\\n fragId = id;\\n}\\n\"])\nexports.pickFragment = glslify([\"precision mediump float;\\n#define GLSLIFY 1\\n\\nvarying vec4 fragId;\\n\\nvoid main() {\\n float radius = length(2.0 * gl_PointCoord.xy - 1.0);\\n if(radius > 1.0) {\\n discard;\\n }\\n gl_FragColor = fragId / 255.0;\\n}\\n\"])\n\n\n/***/ }),\n\n/***/ 4696:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar createShader = __webpack_require__(9405)\nvar createBuffer = __webpack_require__(2762)\n\nvar pool = __webpack_require__(1888)\n\nvar SHADERS = __webpack_require__(6640)\n\nmodule.exports = createPointcloud2D\n\nfunction Pointcloud2D(plot, offsetBuffer, pickBuffer, shader, pickShader) {\n this.plot = plot\n this.offsetBuffer = offsetBuffer\n this.pickBuffer = pickBuffer\n this.shader = shader\n this.pickShader = pickShader\n this.sizeMin = 0.5\n this.sizeMinCap = 2\n this.sizeMax = 20\n this.areaRatio = 1.0\n this.pointCount = 0\n this.color = [1, 0, 0, 1]\n this.borderColor = [0, 0, 0, 1]\n this.blend = false\n this.pickOffset = 0\n this.points = null\n}\n\nvar proto = Pointcloud2D.prototype\n\nproto.dispose = function() {\n this.shader.dispose()\n this.pickShader.dispose()\n this.offsetBuffer.dispose()\n this.pickBuffer.dispose()\n this.plot.removeObject(this)\n}\n\nproto.update = function(options) {\n\n var i\n\n options = options || {}\n\n function dflt(opt, value) {\n if(opt in options) {\n return options[opt]\n }\n return value\n }\n\n this.sizeMin = dflt('sizeMin', 0.5)\n // this.sizeMinCap = dflt('sizeMinCap', 2)\n this.sizeMax = dflt('sizeMax', 20)\n this.color = dflt('color', [1, 0, 0, 1]).slice()\n this.areaRatio = dflt('areaRatio', 1)\n this.borderColor = dflt('borderColor', [0, 0, 0, 1]).slice()\n this.blend = dflt('blend', false)\n\n //Update point data\n\n // Attempt straight-through processing (STP) to avoid allocation and copy\n // TODO eventually abstract out STP logic, maybe into `pool` or a layer above\n var pointCount = options.positions.length >>> 1\n var dataStraightThrough = options.positions instanceof Float32Array\n var idStraightThrough = options.idToIndex instanceof Int32Array && options.idToIndex.length >= pointCount // permit larger to help reuse\n\n var data = options.positions\n var packed = dataStraightThrough ? data : pool.mallocFloat32(data.length)\n var packedId = idStraightThrough ? options.idToIndex : pool.mallocInt32(pointCount)\n\n if(!dataStraightThrough) {\n packed.set(data)\n }\n\n if(!idStraightThrough) {\n packed.set(data)\n for(i = 0; i < pointCount; i++) {\n packedId[i] = i\n }\n }\n\n this.points = data\n\n this.offsetBuffer.update(packed)\n this.pickBuffer.update(packedId)\n\n if(!dataStraightThrough) {\n pool.free(packed)\n }\n\n if(!idStraightThrough) {\n pool.free(packedId)\n }\n\n this.pointCount = pointCount\n this.pickOffset = 0\n}\n\nfunction count(points, dataBox) {\n var visiblePointCountEstimate = 0\n var length = points.length >>> 1\n var i\n for(i = 0; i < length; i++) {\n var x = points[i * 2]\n var y = points[i * 2 + 1]\n if(x >= dataBox[0] && x <= dataBox[2] && y >= dataBox[1] && y <= dataBox[3])\n visiblePointCountEstimate++\n }\n return visiblePointCountEstimate\n}\n\nproto.unifiedDraw = (function() {\n var MATRIX = [1, 0, 0,\n 0, 1, 0,\n 0, 0, 1]\n var PICK_VEC4 = [0, 0, 0, 0]\nreturn function(pickOffset) {\n var pick = pickOffset !== void(0)\n\n var shader = pick ? this.pickShader : this.shader\n var gl = this.plot.gl\n var dataBox = this.plot.dataBox\n\n if(this.pointCount === 0) {\n return pickOffset\n }\n\n var dataX = dataBox[2] - dataBox[0]\n var dataY = dataBox[3] - dataBox[1]\n\n var visiblePointCountEstimate = count(this.points, dataBox)\n var basicPointSize = this.plot.pickPixelRatio * Math.max(Math.min(this.sizeMinCap, this.sizeMin), Math.min(this.sizeMax, this.sizeMax / Math.pow(visiblePointCountEstimate, 0.33333)))\n\n MATRIX[0] = 2.0 / dataX\n MATRIX[4] = 2.0 / dataY\n MATRIX[6] = -2.0 * dataBox[0] / dataX - 1.0\n MATRIX[7] = -2.0 * dataBox[1] / dataY - 1.0\n\n this.offsetBuffer.bind()\n\n shader.bind()\n shader.attributes.position.pointer()\n shader.uniforms.matrix = MATRIX\n shader.uniforms.color = this.color\n shader.uniforms.borderColor = this.borderColor\n shader.uniforms.pointCloud = basicPointSize < 5\n shader.uniforms.pointSize = basicPointSize\n shader.uniforms.centerFraction = Math.min(1, Math.max(0, Math.sqrt(1 - this.areaRatio)))\n\n if(pick) {\n\n PICK_VEC4[0] = ( pickOffset & 0xff)\n PICK_VEC4[1] = ((pickOffset >> 8) & 0xff)\n PICK_VEC4[2] = ((pickOffset >> 16) & 0xff)\n PICK_VEC4[3] = ((pickOffset >> 24) & 0xff)\n\n this.pickBuffer.bind()\n shader.attributes.pickId.pointer(gl.UNSIGNED_BYTE)\n shader.uniforms.pickOffset = PICK_VEC4\n this.pickOffset = pickOffset\n }\n\n // Worth switching these off, but we can't make assumptions about other\n // renderers, so let's restore it after each draw\n var blend = gl.getParameter(gl.BLEND)\n var dither = gl.getParameter(gl.DITHER)\n\n if(blend && !this.blend)\n gl.disable(gl.BLEND)\n if(dither)\n gl.disable(gl.DITHER)\n\n gl.drawArrays(gl.POINTS, 0, this.pointCount)\n\n if(blend && !this.blend)\n gl.enable(gl.BLEND)\n if(dither)\n gl.enable(gl.DITHER)\n\n return pickOffset + this.pointCount\n}\n})()\n\nproto.draw = proto.unifiedDraw\nproto.drawPick = proto.unifiedDraw\n\nproto.pick = function(x, y, value) {\n var pickOffset = this.pickOffset\n var pointCount = this.pointCount\n if(value < pickOffset || value >= pickOffset + pointCount) {\n return null\n }\n var pointId = value - pickOffset\n var points = this.points\n return {\n object: this,\n pointId: pointId,\n dataCoord: [points[2 * pointId], points[2 * pointId + 1] ]\n }\n}\n\nfunction createPointcloud2D(plot, options) {\n var gl = plot.gl\n var buffer = createBuffer(gl)\n var pickBuffer = createBuffer(gl)\n var shader = createShader(gl, SHADERS.pointVertex, SHADERS.pointFragment)\n var pickShader = createShader(gl, SHADERS.pickVertex, SHADERS.pickFragment)\n\n var result = new Pointcloud2D(plot, buffer, pickBuffer, shader, pickShader)\n result.update(options)\n\n //Register with plot\n plot.addObject(result)\n\n return result\n}\n\n\n/***/ }),\n\n/***/ 783:\n/***/ (function(module) {\n\nmodule.exports = slerp\n\n/**\n * Performs a spherical linear interpolation between two quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {quat} out\n */\nfunction slerp (out, a, b, t) {\n // benchmarks:\n // http://jsperf.com/quaternion-slerp-implementations\n\n var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n bx = b[0], by = b[1], bz = b[2], bw = b[3]\n\n var omega, cosom, sinom, scale0, scale1\n\n // calc cosine\n cosom = ax * bx + ay * by + az * bz + aw * bw\n // adjust signs (if necessary)\n if (cosom < 0.0) {\n cosom = -cosom\n bx = -bx\n by = -by\n bz = -bz\n bw = -bw\n }\n // calculate coefficients\n if ((1.0 - cosom) > 0.000001) {\n // standard case (slerp)\n omega = Math.acos(cosom)\n sinom = Math.sin(omega)\n scale0 = Math.sin((1.0 - t) * omega) / sinom\n scale1 = Math.sin(t * omega) / sinom\n } else {\n // \"from\" and \"to\" quaternions are very close\n // ... so we can do a linear interpolation\n scale0 = 1.0 - t\n scale1 = t\n }\n // calculate final values\n out[0] = scale0 * ax + scale1 * bx\n out[1] = scale0 * ay + scale1 * by\n out[2] = scale0 * az + scale1 * bz\n out[3] = scale0 * aw + scale1 * bw\n\n return out\n}\n\n\n/***/ }),\n\n/***/ 5964:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nmodule.exports = function(a){\n return (!a && a !== 0) ? '' : a.toString();\n}\n\n\n/***/ }),\n\n/***/ 9366:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar vectorizeText = __webpack_require__(4359)\n\nmodule.exports = getGlyph\n\nvar GLYPH_CACHE = {}\n\nfunction getGlyph(symbol, font, pixelRatio) {\n var fontKey = [\n font.style,\n font.weight,\n font.variant,\n font.family\n ].join('_')\n\n var fontCache = GLYPH_CACHE[fontKey]\n if(!fontCache) {\n fontCache = GLYPH_CACHE[fontKey] = {}\n }\n if(symbol in fontCache) {\n return fontCache[symbol]\n }\n\n var config = {\n textAlign: \"center\",\n textBaseline: \"middle\",\n lineHeight: 1.0,\n font: font.family,\n fontStyle: font.style,\n fontWeight: font.weight,\n fontVariant: font.variant,\n lineSpacing: 1.25,\n styletags: {\n breaklines:true,\n bolds: true,\n italics: true,\n subscripts:true,\n superscripts:true\n }\n }\n\n //Get line and triangle meshes for glyph\n config.triangles = true\n var triSymbol = vectorizeText(symbol, config)\n config.triangles = false\n var lineSymbol = vectorizeText(symbol, config)\n\n var i, j\n\n if(pixelRatio && pixelRatio !== 1) {\n for(i = 0; i < triSymbol.positions.length; ++i){\n for(j = 0; j < triSymbol.positions[i].length; ++j){\n triSymbol.positions[i][j] /= pixelRatio;\n }\n }\n\n for(i = 0; i < lineSymbol.positions.length; ++i){\n for(j = 0; j < lineSymbol.positions[i].length; ++j){\n lineSymbol.positions[i][j] /= pixelRatio;\n }\n }\n }\n\n //Calculate bounding box\n var bounds = [[Infinity,Infinity], [-Infinity,-Infinity]]\n var n = lineSymbol.positions.length\n for(i = 0; i < n; ++i) {\n var p = lineSymbol.positions[i]\n for(j=0; j<2; ++j) {\n bounds[0][j] = Math.min(bounds[0][j], p[j])\n bounds[1][j] = Math.max(bounds[1][j], p[j])\n }\n }\n\n //Save cached symbol\n return fontCache[symbol] = [triSymbol, lineSymbol, bounds]\n}\n\n/***/ }),\n\n/***/ 1283:\n/***/ (function(__unused_webpack_module, exports, __webpack_require__) {\n\nvar createShaderWrapper = __webpack_require__(9405)\nvar glslify = __webpack_require__(3236)\n\nvar perspectiveVertSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nattribute vec3 position;\\nattribute vec4 color;\\nattribute vec2 glyph;\\nattribute vec4 id;\\n\\nuniform vec4 highlightId;\\nuniform float highlightScale;\\nuniform mat4 model, view, projection;\\nuniform vec3 clipBounds[2];\\n\\nvarying vec4 interpColor;\\nvarying vec4 pickId;\\nvarying vec3 dataCoordinate;\\n\\nvoid main() {\\n if (outOfRange(clipBounds[0], clipBounds[1], position)) {\\n\\n gl_Position = vec4(0,0,0,0);\\n } else {\\n float scale = 1.0;\\n if(distance(highlightId, id) < 0.0001) {\\n scale = highlightScale;\\n }\\n\\n vec4 worldPosition = model * vec4(position, 1);\\n vec4 viewPosition = view * worldPosition;\\n viewPosition = viewPosition / viewPosition.w;\\n vec4 clipPosition = projection * (viewPosition + scale * vec4(glyph.x, -glyph.y, 0, 0));\\n\\n gl_Position = clipPosition;\\n interpColor = color;\\n pickId = id;\\n dataCoordinate = position;\\n }\\n}\"])\nvar orthographicVertSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nattribute vec3 position;\\nattribute vec4 color;\\nattribute vec2 glyph;\\nattribute vec4 id;\\n\\nuniform mat4 model, view, projection;\\nuniform vec2 screenSize;\\nuniform vec3 clipBounds[2];\\nuniform float highlightScale, pixelRatio;\\nuniform vec4 highlightId;\\n\\nvarying vec4 interpColor;\\nvarying vec4 pickId;\\nvarying vec3 dataCoordinate;\\n\\nvoid main() {\\n if (outOfRange(clipBounds[0], clipBounds[1], position)) {\\n\\n gl_Position = vec4(0,0,0,0);\\n } else {\\n float scale = pixelRatio;\\n if(distance(highlightId.bgr, id.bgr) < 0.001) {\\n scale *= highlightScale;\\n }\\n\\n vec4 worldPosition = model * vec4(position, 1.0);\\n vec4 viewPosition = view * worldPosition;\\n vec4 clipPosition = projection * viewPosition;\\n clipPosition /= clipPosition.w;\\n\\n gl_Position = clipPosition + vec4(screenSize * scale * vec2(glyph.x, -glyph.y), 0.0, 0.0);\\n interpColor = color;\\n pickId = id;\\n dataCoordinate = position;\\n }\\n}\"])\nvar projectionVertSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nattribute vec3 position;\\nattribute vec4 color;\\nattribute vec2 glyph;\\nattribute vec4 id;\\n\\nuniform float highlightScale;\\nuniform vec4 highlightId;\\nuniform vec3 axes[2];\\nuniform mat4 model, view, projection;\\nuniform vec2 screenSize;\\nuniform vec3 clipBounds[2];\\nuniform float scale, pixelRatio;\\n\\nvarying vec4 interpColor;\\nvarying vec4 pickId;\\nvarying vec3 dataCoordinate;\\n\\nvoid main() {\\n if (outOfRange(clipBounds[0], clipBounds[1], position)) {\\n\\n gl_Position = vec4(0,0,0,0);\\n } else {\\n float lscale = pixelRatio * scale;\\n if(distance(highlightId, id) < 0.0001) {\\n lscale *= highlightScale;\\n }\\n\\n vec4 clipCenter = projection * (view * (model * vec4(position, 1)));\\n vec3 dataPosition = position + 0.5*lscale*(axes[0] * glyph.x + axes[1] * glyph.y) * clipCenter.w * screenSize.y;\\n vec4 clipPosition = projection * (view * (model * vec4(dataPosition, 1)));\\n\\n gl_Position = clipPosition;\\n interpColor = color;\\n pickId = id;\\n dataCoordinate = dataPosition;\\n }\\n}\\n\"])\nvar drawFragSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nuniform vec3 fragClipBounds[2];\\nuniform float opacity;\\n\\nvarying vec4 interpColor;\\nvarying vec3 dataCoordinate;\\n\\nvoid main() {\\n if (\\n outOfRange(fragClipBounds[0], fragClipBounds[1], dataCoordinate) ||\\n interpColor.a * opacity == 0.\\n ) discard;\\n gl_FragColor = interpColor * opacity;\\n}\\n\"])\nvar pickFragSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nuniform vec3 fragClipBounds[2];\\nuniform float pickGroup;\\n\\nvarying vec4 pickId;\\nvarying vec3 dataCoordinate;\\n\\nvoid main() {\\n if (outOfRange(fragClipBounds[0], fragClipBounds[1], dataCoordinate)) discard;\\n\\n gl_FragColor = vec4(pickGroup, pickId.bgr);\\n}\"])\n\nvar ATTRIBUTES = [\n {name: 'position', type: 'vec3'},\n {name: 'color', type: 'vec4'},\n {name: 'glyph', type: 'vec2'},\n {name: 'id', type: 'vec4'}\n]\n\nvar perspective = {\n vertex: perspectiveVertSrc,\n fragment: drawFragSrc,\n attributes: ATTRIBUTES\n },\n ortho = {\n vertex: orthographicVertSrc,\n fragment: drawFragSrc,\n attributes: ATTRIBUTES\n },\n project = {\n vertex: projectionVertSrc,\n fragment: drawFragSrc,\n attributes: ATTRIBUTES\n },\n pickPerspective = {\n vertex: perspectiveVertSrc,\n fragment: pickFragSrc,\n attributes: ATTRIBUTES\n },\n pickOrtho = {\n vertex: orthographicVertSrc,\n fragment: pickFragSrc,\n attributes: ATTRIBUTES\n },\n pickProject = {\n vertex: projectionVertSrc,\n fragment: pickFragSrc,\n attributes: ATTRIBUTES\n }\n\nfunction createShader(gl, src) {\n var shader = createShaderWrapper(gl, src)\n var attr = shader.attributes\n attr.position.location = 0\n attr.color.location = 1\n attr.glyph.location = 2\n attr.id.location = 3\n return shader\n}\n\nexports.createPerspective = function(gl) {\n return createShader(gl, perspective)\n}\nexports.createOrtho = function(gl) {\n return createShader(gl, ortho)\n}\nexports.createProject = function(gl) {\n return createShader(gl, project)\n}\nexports.createPickPerspective = function(gl) {\n return createShader(gl, pickPerspective)\n}\nexports.createPickOrtho = function(gl) {\n return createShader(gl, pickOrtho)\n}\nexports.createPickProject = function(gl) {\n return createShader(gl, pickProject)\n}\n\n\n/***/ }),\n\n/***/ 8418:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar isAllBlank = __webpack_require__(5219)\nvar createBuffer = __webpack_require__(2762)\nvar createVAO = __webpack_require__(8116)\nvar pool = __webpack_require__(1888)\nvar mat4mult = __webpack_require__(6760)\nvar shaders = __webpack_require__(1283)\nvar getGlyph = __webpack_require__(9366)\nvar getSimpleString = __webpack_require__(5964)\n\nvar IDENTITY = [1,0,0,0,\n 0,1,0,0,\n 0,0,1,0,\n 0,0,0,1]\n\nvar ab = ArrayBuffer\nvar dv = DataView\n\nfunction isTypedArray(a) {\n return ab.isView(a) && !(a instanceof dv)\n}\n\nfunction isArrayOrTypedArray(a) {\n return Array.isArray(a) || isTypedArray(a)\n}\n\nmodule.exports = createPointCloud\n\nfunction transformMat4(x, m) {\n var x0 = x[0]\n var x1 = x[1]\n var x2 = x[2]\n var x3 = x[3]\n x[0] = m[0] * x0 + m[4] * x1 + m[8] * x2 + m[12] * x3\n x[1] = m[1] * x0 + m[5] * x1 + m[9] * x2 + m[13] * x3\n x[2] = m[2] * x0 + m[6] * x1 + m[10] * x2 + m[14] * x3\n x[3] = m[3] * x0 + m[7] * x1 + m[11] * x2 + m[15] * x3\n return x\n}\n\nfunction project(p, v, m, x) {\n transformMat4(x, x, m)\n transformMat4(x, x, v)\n return transformMat4(x, x, p)\n}\n\nfunction ScatterPlotPickResult(index, position) {\n this.index = index\n this.dataCoordinate = this.position = position\n}\n\nfunction fixOpacity(a) {\n if(a === true) return 1\n if(a > 1) return 1\n return a\n}\n\nfunction PointCloud(\n gl,\n shader,\n orthoShader,\n projectShader,\n pointBuffer,\n colorBuffer,\n glyphBuffer,\n idBuffer,\n vao,\n pickPerspectiveShader,\n pickOrthoShader,\n pickProjectShader) {\n\n this.gl = gl\n\n this.pixelRatio = 1\n\n this.shader = shader\n this.orthoShader = orthoShader\n this.projectShader = projectShader\n\n this.pointBuffer = pointBuffer\n this.colorBuffer = colorBuffer\n this.glyphBuffer = glyphBuffer\n this.idBuffer = idBuffer\n this.vao = vao\n this.vertexCount = 0\n this.lineVertexCount = 0\n\n this.opacity = 1\n this.hasAlpha = false\n\n this.lineWidth = 0\n this.projectScale = [2.0/3.0, 2.0/3.0, 2.0/3.0]\n this.projectOpacity = [1, 1, 1]\n this.projectHasAlpha = false\n\n this.pickId = 0\n this.pickPerspectiveShader = pickPerspectiveShader\n this.pickOrthoShader = pickOrthoShader\n this.pickProjectShader = pickProjectShader\n this.points = []\n\n this._selectResult = new ScatterPlotPickResult(0, [0,0,0])\n\n this.useOrtho = true\n this.bounds = [[ Infinity,Infinity,Infinity],\n [-Infinity,-Infinity,-Infinity]]\n\n //Axes projections\n this.axesProject = [ true, true, true ]\n this.axesBounds = [[-Infinity,-Infinity,-Infinity],\n [ Infinity, Infinity, Infinity]]\n\n this.highlightId = [1,1,1,1]\n this.highlightScale = 2\n\n this.clipBounds = [[-Infinity,-Infinity,-Infinity],\n [ Infinity, Infinity, Infinity]]\n\n this.dirty = true\n}\n\nvar proto = PointCloud.prototype\n\nproto.pickSlots = 1\n\nproto.setPickBase = function(pickBase) {\n this.pickId = pickBase\n}\n\nproto.isTransparent = function() {\n if(this.hasAlpha) {\n return true\n }\n for(var i=0; i<3; ++i) {\n if(this.axesProject[i] && this.projectHasAlpha) {\n return true\n }\n }\n return false\n}\n\nproto.isOpaque = function() {\n if(!this.hasAlpha) {\n return true\n }\n for(var i=0; i<3; ++i) {\n if(this.axesProject[i] && !this.projectHasAlpha) {\n return true\n }\n }\n return false\n}\n\nvar VIEW_SHAPE = [0,0]\nvar U_VEC = [0,0,0]\nvar V_VEC = [0,0,0]\nvar MU_VEC = [0,0,0,1]\nvar MV_VEC = [0,0,0,1]\nvar SCRATCH_MATRIX = IDENTITY.slice()\nvar SCRATCH_VEC = [0,0,0]\nvar CLIP_BOUNDS = [[0,0,0], [0,0,0]]\n\nfunction zeroVec(a) {\n a[0] = a[1] = a[2] = 0\n return a\n}\n\nfunction augment(hg, af) {\n hg[0] = af[0]\n hg[1] = af[1]\n hg[2] = af[2]\n hg[3] = 1\n return hg\n}\n\nfunction setComponent(out, v, i, x) {\n out[0] = v[0]\n out[1] = v[1]\n out[2] = v[2]\n out[i] = x\n return out\n}\n\nfunction getClipBounds(bounds) {\n var result = CLIP_BOUNDS\n for(var i=0; i<2; ++i) {\n for(var j=0; j<3; ++j) {\n result[i][j] = Math.max(Math.min(bounds[i][j], 1e8), -1e8)\n }\n }\n return result\n}\n\nfunction drawProject(shader, points, camera, pixelRatio) {\n var axesProject = points.axesProject\n\n var gl = points.gl\n var uniforms = shader.uniforms\n var model = camera.model || IDENTITY\n var view = camera.view || IDENTITY\n var projection = camera.projection || IDENTITY\n var bounds = points.axesBounds\n var clipBounds = getClipBounds(points.clipBounds)\n\n var cubeAxis\n if(points.axes && points.axes.lastCubeProps) {\n cubeAxis = points.axes.lastCubeProps.axis\n } else {\n cubeAxis = [1,1,1]\n }\n\n VIEW_SHAPE[0] = 2.0/gl.drawingBufferWidth\n VIEW_SHAPE[1] = 2.0/gl.drawingBufferHeight\n\n shader.bind()\n uniforms.view = view\n uniforms.projection = projection\n uniforms.screenSize = VIEW_SHAPE\n uniforms.highlightId = points.highlightId\n uniforms.highlightScale = points.highlightScale\n uniforms.clipBounds = clipBounds\n uniforms.pickGroup = points.pickId / 255.0\n uniforms.pixelRatio = pixelRatio\n\n for(var i=0; i<3; ++i) {\n if(!axesProject[i]) {\n continue\n }\n\n uniforms.scale = points.projectScale[i]\n uniforms.opacity = points.projectOpacity[i]\n\n //Project model matrix\n var pmodel = SCRATCH_MATRIX\n for(var j=0; j<16; ++j) {\n pmodel[j] = 0\n }\n for(var j=0; j<4; ++j) {\n pmodel[5*j] = 1\n }\n pmodel[5*i] = 0\n if(cubeAxis[i] < 0) {\n pmodel[12+i] = bounds[0][i]\n } else {\n pmodel[12+i] = bounds[1][i]\n }\n mat4mult(pmodel, model, pmodel)\n uniforms.model = pmodel\n\n //Compute initial axes\n var u = (i+1)%3\n var v = (i+2)%3\n var du = zeroVec(U_VEC)\n var dv = zeroVec(V_VEC)\n du[u] = 1\n dv[v] = 1\n\n //Align orientation relative to viewer\n var mdu = project(projection, view, model, augment(MU_VEC, du))\n var mdv = project(projection, view, model, augment(MV_VEC, dv))\n if(Math.abs(mdu[1]) > Math.abs(mdv[1])) {\n var tmp = mdu\n mdu = mdv\n mdv = tmp\n tmp = du\n du = dv\n dv = tmp\n var t = u\n u = v\n v = t\n }\n if(mdu[0] < 0) {\n du[u] = -1\n }\n if(mdv[1] > 0) {\n dv[v] = -1\n }\n var su = 0.0\n var sv = 0.0\n for(var j=0; j<4; ++j) {\n su += Math.pow(model[4*u+j], 2)\n sv += Math.pow(model[4*v+j], 2)\n }\n du[u] /= Math.sqrt(su)\n dv[v] /= Math.sqrt(sv)\n uniforms.axes[0] = du\n uniforms.axes[1] = dv\n\n //Update fragment clip bounds\n uniforms.fragClipBounds[0] = setComponent(SCRATCH_VEC, clipBounds[0], i, -1e8)\n uniforms.fragClipBounds[1] = setComponent(SCRATCH_VEC, clipBounds[1], i, 1e8)\n\n points.vao.bind()\n\n //Draw interior\n points.vao.draw(gl.TRIANGLES, points.vertexCount)\n\n //Draw edges\n if(points.lineWidth > 0) {\n gl.lineWidth(points.lineWidth * pixelRatio)\n points.vao.draw(gl.LINES, points.lineVertexCount, points.vertexCount)\n }\n\n points.vao.unbind()\n }\n}\n\n\nvar NEG_INFINITY3 = [-1e8, -1e8, -1e8]\nvar POS_INFINITY3 = [1e8, 1e8, 1e8]\nvar CLIP_GROUP = [NEG_INFINITY3, POS_INFINITY3]\n\nfunction drawFull(shader, pshader, points, camera, pixelRatio, transparent, forceDraw) {\n var gl = points.gl\n\n if(transparent === points.projectHasAlpha || forceDraw) {\n drawProject(pshader, points, camera, pixelRatio)\n }\n\n if(transparent === points.hasAlpha || forceDraw) {\n\n shader.bind()\n var uniforms = shader.uniforms\n\n uniforms.model = camera.model || IDENTITY\n uniforms.view = camera.view || IDENTITY\n uniforms.projection = camera.projection || IDENTITY\n\n VIEW_SHAPE[0] = 2.0/gl.drawingBufferWidth\n VIEW_SHAPE[1] = 2.0/gl.drawingBufferHeight\n uniforms.screenSize = VIEW_SHAPE\n\n uniforms.highlightId = points.highlightId\n uniforms.highlightScale = points.highlightScale\n\n uniforms.fragClipBounds = CLIP_GROUP\n uniforms.clipBounds = points.axes.bounds\n\n uniforms.opacity = points.opacity\n uniforms.pickGroup = points.pickId / 255.0\n\n uniforms.pixelRatio = pixelRatio\n\n points.vao.bind()\n\n //Draw interior\n points.vao.draw(gl.TRIANGLES, points.vertexCount)\n\n //Draw edges\n if(points.lineWidth > 0) {\n gl.lineWidth(points.lineWidth * pixelRatio)\n points.vao.draw(gl.LINES, points.lineVertexCount, points.vertexCount)\n }\n\n points.vao.unbind()\n }\n\n\n}\n\nproto.draw = function(camera) {\n var shader = this.useOrtho ? this.orthoShader : this.shader\n drawFull(shader, this.projectShader, this, camera, this.pixelRatio, false, false)\n}\n\nproto.drawTransparent = function(camera) {\n var shader = this.useOrtho ? this.orthoShader : this.shader\n drawFull(shader, this.projectShader, this, camera, this.pixelRatio, true, false)\n}\n\nproto.drawPick = function(camera) {\n var shader = this.useOrtho ? this.pickOrthoShader : this.pickPerspectiveShader\n drawFull(shader, this.pickProjectShader, this, camera, 1, true, true)\n}\n\nproto.pick = function(selected) {\n if(!selected) {\n return null\n }\n if(selected.id !== this.pickId) {\n return null\n }\n var x = selected.value[2] + (selected.value[1]<<8) + (selected.value[0]<<16)\n if(x >= this.pointCount || x < 0) {\n return null\n }\n\n //Unpack result\n var coord = this.points[x]\n var result = this._selectResult\n result.index = x\n for(var i=0; i<3; ++i) {\n result.position[i] = result.dataCoordinate[i] = coord[i]\n }\n return result\n}\n\nproto.highlight = function(selection) {\n if(!selection) {\n this.highlightId = [1,1,1,1]\n } else {\n var pointId = selection.index\n var a0 = pointId &0xff\n var a1 = (pointId>>8) &0xff\n var a2 = (pointId>>16)&0xff\n this.highlightId = [a0/255.0, a1/255.0, a2/255.0, 0]\n }\n}\n\nfunction get_glyphData(glyphs, index, font, pixelRatio) {\n var str\n\n // use the data if presented in an array\n if(isArrayOrTypedArray(glyphs)) {\n if(index < glyphs.length) {\n str = glyphs[index]\n } else {\n str = undefined\n }\n } else {\n str = glyphs\n }\n\n str = getSimpleString(str) // this would handle undefined cases\n\n var visible = true\n if(isAllBlank(str)) {\n str = '▼' // Note: this special character may have minimum number of surfaces\n visible = false\n }\n\n if(!font) font = {}\n\n var family = font.family\n if(isArrayOrTypedArray(family)) family = family[index]\n if(!family) family = \"normal\"\n\n var weight = font.weight\n if(isArrayOrTypedArray(weight)) weight = weight[index]\n if(!weight) weight = \"normal\"\n\n var style = font.style\n if(isArrayOrTypedArray(style)) style = style[index]\n if(!style) style = \"normal\"\n\n var variant = font.variant\n if(isArrayOrTypedArray(variant)) variant = variant[index]\n if(!variant) variant = \"normal\"\n\n var glyph = getGlyph(str, {\n family: family,\n weight: weight,\n style: style,\n variant: variant,\n }, pixelRatio)\n\n\n var glyph = getGlyph(str, font, pixelRatio)\n\n return { mesh:glyph[0],\n lines:glyph[1],\n bounds:glyph[2],\n visible:visible };\n}\n\n\n\nproto.update = function(options) {\n\n options = options || {}\n\n if('perspective' in options) {\n this.useOrtho = !options.perspective\n }\n if('orthographic' in options) {\n this.useOrtho = !!options.orthographic\n }\n if('lineWidth' in options) {\n this.lineWidth = options.lineWidth\n }\n if('project' in options) {\n if(isArrayOrTypedArray(options.project)) {\n this.axesProject = options.project\n } else {\n var v = !!options.project\n this.axesProject = [v,v,v]\n }\n }\n if('projectScale' in options) {\n if(isArrayOrTypedArray(options.projectScale)) {\n this.projectScale = options.projectScale.slice()\n } else {\n var s = +options.projectScale\n this.projectScale = [s,s,s]\n }\n }\n\n this.projectHasAlpha = false // default to no transparent draw\n if('projectOpacity' in options) {\n if(isArrayOrTypedArray(options.projectOpacity)) {\n this.projectOpacity = options.projectOpacity.slice()\n } else {\n var s = +options.projectOpacity\n this.projectOpacity = [s,s,s]\n }\n for(var i=0; i<3; ++i) {\n this.projectOpacity[i] = fixOpacity(this.projectOpacity[i]);\n if(this.projectOpacity[i] < 1) {\n this.projectHasAlpha = true;\n }\n }\n }\n\n this.hasAlpha = false // default to no transparent draw\n if('opacity' in options) {\n this.opacity = fixOpacity(options.opacity)\n if(this.opacity < 1) {\n this.hasAlpha = true;\n }\n }\n\n //Set dirty flag\n this.dirty = true\n\n //Create new buffers\n var points = options.position\n\n //Text font\n var font = {\n family: options.font || 'normal',\n style: options.fontStyle || 'normal',\n weight: options.fontWeight || 'normal',\n variant: options.fontVariant || 'normal'\n }\n\n var alignment = options.alignment || [0,0]\n\n var alignmentX;\n var alignmentY;\n if (alignment.length === 2) {\n alignmentX = alignment[0]\n alignmentY = alignment[1]\n } else {\n alignmentX = []\n alignmentY = []\n for (var i = 0; i < alignment.length; ++i) {\n alignmentX[i] = alignment[i][0]\n alignmentY[i] = alignment[i][1]\n }\n }\n\n //Bounds\n var lowerBound = [ Infinity, Infinity, Infinity]\n var upperBound = [-Infinity,-Infinity,-Infinity]\n\n //Unpack options\n var glyphs = options.glyph\n var colors = options.color\n var sizes = options.size\n var angles = options.angle\n var lineColors = options.lineColor\n\n //Picking geometry\n var pickCounter = -1\n\n //First do pass to compute buffer sizes\n var triVertexCount = 0\n var lineVertexCount = 0\n\n var numPoints = 0;\n\n if(points.length) {\n\n //Count number of points and buffer size\n numPoints = points.length\n\n count_loop:\n for(var i=0; i 0) {\n var triOffset = 0\n var lineOffset = triVertexCount\n var color = [0,0,0,1]\n var lineColor = [0,0,0,1]\n\n var isColorArray = isArrayOrTypedArray(colors) && isArrayOrTypedArray(colors[0])\n var isLineColorArray = isArrayOrTypedArray(lineColors) && isArrayOrTypedArray(lineColors[0])\n\n fill_loop:\n for(var i=0; i 0) ? (1 - glyphBounds[0][0]) :\n (textOffsetX < 0) ? (1 + glyphBounds[1][0]) : 1;\n\n textOffsetY *= (textOffsetY > 0) ? (1 - glyphBounds[0][1]) :\n (textOffsetY < 0) ? (1 + glyphBounds[1][1]) : 1;\n\n var textOffset = [textOffsetX, textOffsetY]\n\n //Write out inner marker\n var cells = glyphMesh.cells || []\n var verts = glyphMesh.positions || []\n\n for(var j=0; j 0) {\n\n //Draw border\n var w = lineWidth * pixelRatio\n boxes.drawBox(loX-w, loY-w, hiX+w, loY+w, borderColor)\n boxes.drawBox(loX-w, hiY-w, hiX+w, hiY+w, borderColor)\n boxes.drawBox(loX-w, loY-w, loX+w, hiY+w, borderColor)\n boxes.drawBox(hiX-w, loY-w, hiX+w, hiY+w, borderColor)\n }\n}\n\nproto.update = function(options) {\n options = options || {}\n\n this.innerFill = !!options.innerFill\n this.outerFill = !!options.outerFill\n this.innerColor = (options.innerColor || [0,0,0,0.5]).slice()\n this.outerColor = (options.outerColor || [0,0,0,0.5]).slice()\n this.borderColor = (options.borderColor || [0,0,0,1]).slice()\n this.borderWidth = options.borderWidth || 0\n this.selectBox = (options.selectBox || this.selectBox).slice()\n}\n\nproto.dispose = function() {\n this.boxBuffer.dispose()\n this.boxShader.dispose()\n this.plot.removeOverlay(this)\n}\n\nfunction createSelectBox(plot, options) {\n var gl = plot.gl\n var buffer = createBuffer(gl, [\n 0, 0,\n 0, 1,\n 1, 0,\n 1, 1 ])\n var shader = createShader(gl, SHADERS.boxVertex, SHADERS.boxFragment)\n var selectBox = new SelectBox(plot, buffer, shader)\n selectBox.update(options)\n plot.addOverlay(selectBox)\n return selectBox\n}\n\n\n/***/ }),\n\n/***/ 3589:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = createSelectBuffer\n\nvar createFBO = __webpack_require__(2260)\nvar pool = __webpack_require__(1888)\nvar ndarray = __webpack_require__(9618)\nvar nextPow2 = (__webpack_require__(8828).nextPow2)\n\nvar selectRange = function(arr, x, y) {\n var closestD2 = 1e8\n var closestX = -1\n var closestY = -1\n\n var ni = arr.shape[0]\n var nj = arr.shape[1]\n for(var i = 0; i < ni; i++) {\n for(var j = 0; j < nj; j++) {\n var r = arr.get(i, j, 0)\n var g = arr.get(i, j, 1)\n var b = arr.get(i, j, 2)\n var a = arr.get(i, j, 3)\n\n if(r < 255 || g < 255 || b < 255 || a < 255) {\n var dx = x - i\n var dy = y - j\n var d2 = dx*dx + dy*dy\n if(d2 < closestD2) {\n closestD2 = d2\n closestX = i\n closestY = j\n }\n }\n }\n }\n\n return [closestX, closestY, closestD2]\n}\n\nfunction SelectResult(x, y, id, value, distance) {\n this.coord = [x, y]\n this.id = id\n this.value = value\n this.distance = distance\n}\n\nfunction SelectBuffer(gl, fbo, buffer) {\n this.gl = gl\n this.fbo = fbo\n this.buffer = buffer\n this._readTimeout = null\n var self = this\n\n this._readCallback = function() {\n if(!self.gl) {\n return\n }\n fbo.bind()\n gl.readPixels(0,0,fbo.shape[0],fbo.shape[1],gl.RGBA,gl.UNSIGNED_BYTE,self.buffer)\n self._readTimeout = null\n }\n}\n\nvar proto = SelectBuffer.prototype\n\nObject.defineProperty(proto, 'shape', {\n get: function() {\n if(!this.gl) {\n return [0,0]\n }\n return this.fbo.shape.slice()\n },\n set: function(v) {\n if(!this.gl) {\n return\n }\n this.fbo.shape = v\n var c = this.fbo.shape[0]\n var r = this.fbo.shape[1]\n if(r*c*4 > this.buffer.length) {\n pool.free(this.buffer)\n var buffer = this.buffer = pool.mallocUint8(nextPow2(r*c*4))\n for(var i=0; i oldAttribCount) {\n for(i = oldAttribCount; i < newAttribCount; i++) {\n this.gl.enableVertexAttribArray(i)\n }\n } else if(oldAttribCount > newAttribCount) {\n for(i = newAttribCount; i < oldAttribCount; i++) {\n this.gl.disableVertexAttribArray(i)\n }\n }\n\n this.gl.lastAttribCount = newAttribCount\n\n this.gl.useProgram(this.program)\n}\n\nproto.dispose = function() {\n\n // disabling vertex attributes so new shader starts with zero\n // and it's also useful if all shaders are disposed but the\n // gl context is reused for subsequent replotting\n var oldAttribCount = this.gl.lastAttribCount\n for (var i = 0; i < oldAttribCount; i++) {\n this.gl.disableVertexAttribArray(i)\n }\n this.gl.lastAttribCount = 0\n\n if(this._fref) {\n this._fref.dispose()\n }\n if(this._vref) {\n this._vref.dispose()\n }\n this.attributes =\n this.types =\n this.vertShader =\n this.fragShader =\n this.program =\n this._relink =\n this._fref =\n this._vref = null\n}\n\nfunction compareAttributes(a, b) {\n if(a.name < b.name) {\n return -1\n }\n return 1\n}\n\n//Update export hook for glslify-live\nproto.update = function(\n vertSource\n , fragSource\n , uniforms\n , attributes) {\n\n //If only one object passed, assume glslify style output\n if(!fragSource || arguments.length === 1) {\n var obj = vertSource\n vertSource = obj.vertex\n fragSource = obj.fragment\n uniforms = obj.uniforms\n attributes = obj.attributes\n }\n\n var wrapper = this\n var gl = wrapper.gl\n\n //Compile vertex and fragment shaders\n var pvref = wrapper._vref\n wrapper._vref = shaderCache.shader(gl, gl.VERTEX_SHADER, vertSource)\n if(pvref) {\n pvref.dispose()\n }\n wrapper.vertShader = wrapper._vref.shader\n var pfref = this._fref\n wrapper._fref = shaderCache.shader(gl, gl.FRAGMENT_SHADER, fragSource)\n if(pfref) {\n pfref.dispose()\n }\n wrapper.fragShader = wrapper._fref.shader\n\n //If uniforms/attributes is not specified, use RT reflection\n if(!uniforms || !attributes) {\n\n //Create initial test program\n var testProgram = gl.createProgram()\n gl.attachShader(testProgram, wrapper.fragShader)\n gl.attachShader(testProgram, wrapper.vertShader)\n gl.linkProgram(testProgram)\n if(!gl.getProgramParameter(testProgram, gl.LINK_STATUS)) {\n var errLog = gl.getProgramInfoLog(testProgram)\n throw new GLError(errLog, 'Error linking program:' + errLog)\n }\n\n //Load data from runtime\n uniforms = uniforms || runtime.uniforms(gl, testProgram)\n attributes = attributes || runtime.attributes(gl, testProgram)\n\n //Release test program\n gl.deleteProgram(testProgram)\n }\n\n //Sort attributes lexicographically\n // overrides undefined WebGL behavior for attribute locations\n attributes = attributes.slice()\n attributes.sort(compareAttributes)\n\n //Convert attribute types, read out locations\n var attributeUnpacked = []\n var attributeNames = []\n var attributeLocations = []\n var i\n for(i=0; i= 0) {\n var size = attr.type.charAt(attr.type.length-1)|0\n var locVector = new Array(size)\n for(var j=0; j= 0) {\n curLocation += 1\n }\n attributeLocations[i] = curLocation\n }\n }\n\n //Rebuild program and recompute all uniform locations\n var uniformLocations = new Array(uniforms.length)\n function relink() {\n wrapper.program = shaderCache.program(\n gl\n , wrapper._vref\n , wrapper._fref\n , attributeNames\n , attributeLocations)\n\n for(var i=0; i= 0) {\n var d = type.charCodeAt(type.length-1) - 48\n if(d < 2 || d > 4) {\n throw new GLError('', 'Invalid data type for attribute ' + name + ': ' + type)\n }\n addVectorAttribute(\n gl\n , wrapper\n , locs[0]\n , locations\n , d\n , obj\n , name)\n } else if(type.indexOf('mat') >= 0) {\n var d = type.charCodeAt(type.length-1) - 48\n if(d < 2 || d > 4) {\n throw new GLError('', 'Invalid data type for attribute ' + name + ': ' + type)\n }\n addMatrixAttribute(\n gl\n , wrapper\n , locs\n , locations\n , d\n , obj\n , name)\n } else {\n throw new GLError('', 'Unknown data type for attribute ' + name + ': ' + type)\n }\n break\n }\n }\n return obj\n}\n\n\n/***/ }),\n\n/***/ 3327:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar coallesceUniforms = __webpack_require__(216)\nvar GLError = __webpack_require__(8866)\n\nmodule.exports = createUniformWrapper\n\n//Binds a function and returns a value\nfunction identity(x) {\n return function() {\n return x\n }\n}\n\nfunction makeVector(length, fill) {\n var result = new Array(length)\n for(var i=0; i 4) {\n throw new GLError('', 'Invalid data type')\n }\n switch(t.charAt(0)) {\n case 'b':\n case 'i':\n gl['uniform' + d + 'iv'](locations[idx], objPath)\n break\n case 'v':\n gl['uniform' + d + 'fv'](locations[idx], objPath)\n break\n default:\n throw new GLError('', 'Unrecognized data type for vector ' + name + ': ' + t)\n }\n } else if(t.indexOf('mat') === 0 && t.length === 4) {\n d = t.charCodeAt(t.length-1) - 48\n if(d < 2 || d > 4) {\n throw new GLError('', 'Invalid uniform dimension type for matrix ' + name + ': ' + t)\n }\n gl['uniformMatrix' + d + 'fv'](locations[idx], false, objPath)\n break\n } else {\n throw new GLError('', 'Unknown uniform data type for ' + name + ': ' + t)\n }\n }\n }\n }\n }\n }\n\n function enumerateIndices(prefix, type) {\n if(typeof type !== 'object') {\n return [ [prefix, type] ]\n }\n var indices = []\n for(var id in type) {\n var prop = type[id]\n var tprefix = prefix\n if(parseInt(id) + '' === id) {\n tprefix += '[' + id + ']'\n } else {\n tprefix += '.' + id\n }\n if(typeof prop === 'object') {\n indices.push.apply(indices, enumerateIndices(tprefix, prop))\n } else {\n indices.push([tprefix, prop])\n }\n }\n return indices\n }\n\n\n function defaultValue(type) {\n switch(type) {\n case 'bool':\n return false\n case 'int':\n case 'sampler2D':\n case 'samplerCube':\n return 0\n case 'float':\n return 0.0\n default:\n var vidx = type.indexOf('vec')\n if(0 <= vidx && vidx <= 1 && type.length === 4 + vidx) {\n var d = type.charCodeAt(type.length-1) - 48\n if(d < 2 || d > 4) {\n throw new GLError('', 'Invalid data type')\n }\n if(type.charAt(0) === 'b') {\n return makeVector(d, false)\n }\n return makeVector(d, 0)\n } else if(type.indexOf('mat') === 0 && type.length === 4) {\n var d = type.charCodeAt(type.length-1) - 48\n if(d < 2 || d > 4) {\n throw new GLError('', 'Invalid uniform dimension type for matrix ' + name + ': ' + type)\n }\n return makeVector(d*d, 0)\n } else {\n throw new GLError('', 'Unknown uniform data type for ' + name + ': ' + type)\n }\n }\n }\n\n function storeProperty(obj, prop, type) {\n if(typeof type === 'object') {\n var child = processObject(type)\n Object.defineProperty(obj, prop, {\n get: identity(child),\n set: makeSetter(type),\n enumerable: true,\n configurable: false\n })\n } else {\n if(locations[type]) {\n Object.defineProperty(obj, prop, {\n get: makeGetter(type),\n set: makeSetter(type),\n enumerable: true,\n configurable: false\n })\n } else {\n obj[prop] = defaultValue(uniforms[type].type)\n }\n }\n }\n\n function processObject(obj) {\n var result\n if(Array.isArray(obj)) {\n result = new Array(obj.length)\n for(var i=0; i 1) {\n if(!(x[0] in o)) {\n o[x[0]] = []\n }\n o = o[x[0]]\n for(var k=1; k 1) {\n for(var j=0; j 0 U ||b|| > 0.\\n // Assign z = 0, x = -b, y = a:\\n // a*-b + b*a + c*0 = -ba + ba + 0 = 0\\n if (v.x*v.x > v.z*v.z || v.y*v.y > v.z*v.z) {\\n return normalize(vec3(-v.y, v.x, 0.0));\\n } else {\\n return normalize(vec3(0.0, v.z, -v.y));\\n }\\n}\\n\\n// Calculate the tube vertex and normal at the given index.\\n//\\n// The returned vertex is for a tube ring with its center at origin, radius of length(d), pointing in the direction of d.\\n//\\n// Each tube segment is made up of a ring of vertices.\\n// These vertices are used to make up the triangles of the tube by connecting them together in the vertex array.\\n// The indexes of tube segments run from 0 to 8.\\n//\\nvec3 getTubePosition(vec3 d, float index, out vec3 normal) {\\n float segmentCount = 8.0;\\n\\n float angle = 2.0 * 3.14159 * (index / segmentCount);\\n\\n vec3 u = getOrthogonalVector(d);\\n vec3 v = normalize(cross(u, d));\\n\\n vec3 x = u * cos(angle) * length(d);\\n vec3 y = v * sin(angle) * length(d);\\n vec3 v3 = x + y;\\n\\n normal = normalize(v3);\\n\\n return v3;\\n}\\n\\nattribute vec4 vector;\\nattribute vec4 color, position;\\nattribute vec2 uv;\\n\\nuniform float vectorScale, tubeScale;\\nuniform mat4 model, view, projection, inverseModel;\\nuniform vec3 eyePosition, lightPosition;\\n\\nvarying vec3 f_normal, f_lightDirection, f_eyeDirection, f_data, f_position;\\nvarying vec4 f_color;\\nvarying vec2 f_uv;\\n\\nvoid main() {\\n // Scale the vector magnitude to stay constant with\\n // model & view changes.\\n vec3 normal;\\n vec3 XYZ = getTubePosition(mat3(model) * (tubeScale * vector.w * normalize(vector.xyz)), position.w, normal);\\n vec4 tubePosition = model * vec4(position.xyz, 1.0) + vec4(XYZ, 0.0);\\n\\n //Lighting geometry parameters\\n vec4 cameraCoordinate = view * tubePosition;\\n cameraCoordinate.xyz /= cameraCoordinate.w;\\n f_lightDirection = lightPosition - cameraCoordinate.xyz;\\n f_eyeDirection = eyePosition - cameraCoordinate.xyz;\\n f_normal = normalize((vec4(normal, 0.0) * inverseModel).xyz);\\n\\n // vec4 m_position = model * vec4(tubePosition, 1.0);\\n vec4 t_position = view * tubePosition;\\n gl_Position = projection * t_position;\\n\\n f_color = color;\\n f_data = tubePosition.xyz;\\n f_position = position.xyz;\\n f_uv = uv;\\n}\\n\"])\nvar triFragSrc = glslify([\"#extension GL_OES_standard_derivatives : enable\\n\\nprecision highp float;\\n#define GLSLIFY 1\\n\\nfloat beckmannDistribution(float x, float roughness) {\\n float NdotH = max(x, 0.0001);\\n float cos2Alpha = NdotH * NdotH;\\n float tan2Alpha = (cos2Alpha - 1.0) / cos2Alpha;\\n float roughness2 = roughness * roughness;\\n float denom = 3.141592653589793 * roughness2 * cos2Alpha * cos2Alpha;\\n return exp(tan2Alpha / roughness2) / denom;\\n}\\n\\nfloat cookTorranceSpecular(\\n vec3 lightDirection,\\n vec3 viewDirection,\\n vec3 surfaceNormal,\\n float roughness,\\n float fresnel) {\\n\\n float VdotN = max(dot(viewDirection, surfaceNormal), 0.0);\\n float LdotN = max(dot(lightDirection, surfaceNormal), 0.0);\\n\\n //Half angle vector\\n vec3 H = normalize(lightDirection + viewDirection);\\n\\n //Geometric term\\n float NdotH = max(dot(surfaceNormal, H), 0.0);\\n float VdotH = max(dot(viewDirection, H), 0.000001);\\n float LdotH = max(dot(lightDirection, H), 0.000001);\\n float G1 = (2.0 * NdotH * VdotN) / VdotH;\\n float G2 = (2.0 * NdotH * LdotN) / LdotH;\\n float G = min(1.0, min(G1, G2));\\n \\n //Distribution term\\n float D = beckmannDistribution(NdotH, roughness);\\n\\n //Fresnel term\\n float F = pow(1.0 - VdotN, fresnel);\\n\\n //Multiply terms and done\\n return G * F * D / max(3.14159265 * VdotN, 0.000001);\\n}\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nuniform vec3 clipBounds[2];\\nuniform float roughness, fresnel, kambient, kdiffuse, kspecular, opacity;\\nuniform sampler2D texture;\\n\\nvarying vec3 f_normal, f_lightDirection, f_eyeDirection, f_data, f_position;\\nvarying vec4 f_color;\\nvarying vec2 f_uv;\\n\\nvoid main() {\\n if (outOfRange(clipBounds[0], clipBounds[1], f_position)) discard;\\n vec3 N = normalize(f_normal);\\n vec3 L = normalize(f_lightDirection);\\n vec3 V = normalize(f_eyeDirection);\\n\\n if(gl_FrontFacing) {\\n N = -N;\\n }\\n\\n float specular = min(1.0, max(0.0, cookTorranceSpecular(L, V, N, roughness, fresnel)));\\n float diffuse = min(kambient + kdiffuse * max(dot(N, L), 0.0), 1.0);\\n\\n vec4 surfaceColor = f_color * texture2D(texture, f_uv);\\n vec4 litColor = surfaceColor.a * vec4(diffuse * surfaceColor.rgb + kspecular * vec3(1,1,1) * specular, 1.0);\\n\\n gl_FragColor = litColor * opacity;\\n}\\n\"])\nvar pickVertSrc = glslify([\"precision highp float;\\n\\nprecision highp float;\\n#define GLSLIFY 1\\n\\nvec3 getOrthogonalVector(vec3 v) {\\n // Return up-vector for only-z vector.\\n // Return ax + by + cz = 0, a point that lies on the plane that has v as a normal and that isn't (0,0,0).\\n // From the above if-statement we have ||a|| > 0 U ||b|| > 0.\\n // Assign z = 0, x = -b, y = a:\\n // a*-b + b*a + c*0 = -ba + ba + 0 = 0\\n if (v.x*v.x > v.z*v.z || v.y*v.y > v.z*v.z) {\\n return normalize(vec3(-v.y, v.x, 0.0));\\n } else {\\n return normalize(vec3(0.0, v.z, -v.y));\\n }\\n}\\n\\n// Calculate the tube vertex and normal at the given index.\\n//\\n// The returned vertex is for a tube ring with its center at origin, radius of length(d), pointing in the direction of d.\\n//\\n// Each tube segment is made up of a ring of vertices.\\n// These vertices are used to make up the triangles of the tube by connecting them together in the vertex array.\\n// The indexes of tube segments run from 0 to 8.\\n//\\nvec3 getTubePosition(vec3 d, float index, out vec3 normal) {\\n float segmentCount = 8.0;\\n\\n float angle = 2.0 * 3.14159 * (index / segmentCount);\\n\\n vec3 u = getOrthogonalVector(d);\\n vec3 v = normalize(cross(u, d));\\n\\n vec3 x = u * cos(angle) * length(d);\\n vec3 y = v * sin(angle) * length(d);\\n vec3 v3 = x + y;\\n\\n normal = normalize(v3);\\n\\n return v3;\\n}\\n\\nattribute vec4 vector;\\nattribute vec4 position;\\nattribute vec4 id;\\n\\nuniform mat4 model, view, projection;\\nuniform float tubeScale;\\n\\nvarying vec3 f_position;\\nvarying vec4 f_id;\\n\\nvoid main() {\\n vec3 normal;\\n vec3 XYZ = getTubePosition(mat3(model) * (tubeScale * vector.w * normalize(vector.xyz)), position.w, normal);\\n vec4 tubePosition = model * vec4(position.xyz, 1.0) + vec4(XYZ, 0.0);\\n\\n gl_Position = projection * (view * tubePosition);\\n f_id = id;\\n f_position = position.xyz;\\n}\\n\"])\nvar pickFragSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nuniform vec3 clipBounds[2];\\nuniform float pickId;\\n\\nvarying vec3 f_position;\\nvarying vec4 f_id;\\n\\nvoid main() {\\n if (outOfRange(clipBounds[0], clipBounds[1], f_position)) discard;\\n\\n gl_FragColor = vec4(pickId, f_id.xyz);\\n}\"])\n\nexports.meshShader = {\n vertex: triVertSrc,\n fragment: triFragSrc,\n attributes: [\n {name: 'position', type: 'vec4'},\n {name: 'color', type: 'vec4'},\n {name: 'uv', type: 'vec2'},\n {name: 'vector', type: 'vec4'}\n ]\n}\nexports.pickShader = {\n vertex: pickVertSrc,\n fragment: pickFragSrc,\n attributes: [\n {name: 'position', type: 'vec4'},\n {name: 'id', type: 'vec4'},\n {name: 'vector', type: 'vec4'}\n ]\n}\n\n\n/***/ }),\n\n/***/ 7815:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar vec3 = __webpack_require__(2931);\nvar vec4 = __webpack_require__(9970);\nvar GRID_TYPES = ['xyz', 'xzy', 'yxz', 'yzx', 'zxy', 'zyx'];\n\nvar streamToTube = function(stream, maxDivergence, minDistance, maxNorm) {\n\tvar points = stream.points;\n\tvar velocities = stream.velocities;\n\tvar divergences = stream.divergences;\n\n\tvar verts = [];\n\tvar faces = [];\n\tvar vectors = [];\n\tvar previousVerts = [];\n\tvar currentVerts = [];\n\tvar intensities = [];\n\tvar previousIntensity = 0;\n\tvar currentIntensity = 0;\n\tvar currentVector = vec4.create();\n\tvar previousVector = vec4.create();\n\n\tvar facets = 8;\n\n\tfor (var i = 0; i < points.length; i++) {\n\t\tvar p = points[i];\n\t\tvar fwd = velocities[i];\n\t\tvar r = divergences[i];\n\t\tif (maxDivergence === 0) {\n\t\t\tr = minDistance * 0.05;\n\t\t}\n\t\tcurrentIntensity = vec3.length(fwd) / maxNorm;\n\n\t\tcurrentVector = vec4.create();\n\t\tvec3.copy(currentVector, fwd);\n\t\tcurrentVector[3] = r;\n\n\t\tfor (var a = 0; a < facets; a++) {\n\t\t\tcurrentVerts[a] = [p[0], p[1], p[2], a];\n\t\t}\n\t\tif (previousVerts.length > 0) {\n\t\t\tfor (var a = 0; a < facets; a++) {\n\t\t\t\tvar a1 = (a+1) % facets;\n\t\t\t\tverts.push(\n\t\t\t\t\tpreviousVerts[a],\n\t\t\t\t\tcurrentVerts[a],\n\t\t\t\t\tcurrentVerts[a1],\n\n\t\t\t\t\tcurrentVerts[a1],\n\t\t\t\t\tpreviousVerts[a1],\n\t\t\t\t\tpreviousVerts[a]\n\t\t\t\t);\n\t\t\t\tvectors.push(\n\t\t\t\t\tpreviousVector,\n\t\t\t\t\tcurrentVector,\n\t\t\t\t\tcurrentVector,\n\n\t\t\t\t\tcurrentVector,\n\t\t\t\t\tpreviousVector,\n\t\t\t\t\tpreviousVector\n\t\t\t\t);\n\t\t\t\tintensities.push(\n\t\t\t\t\tpreviousIntensity,\n\t\t\t\t\tcurrentIntensity,\n\t\t\t\t\tcurrentIntensity,\n\n\t\t\t\t\tcurrentIntensity,\n\t\t\t\t\tpreviousIntensity,\n\t\t\t\t\tpreviousIntensity\n\t\t\t\t);\n\n\t\t\t\tvar len = verts.length;\n\t\t\t\tfaces.push(\n\t\t\t\t\t[len-6, len-5, len-4],\n\t\t\t\t\t[len-3, len-2, len-1]\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t\tvar tmp1 = previousVerts;\n\t\tpreviousVerts = currentVerts;\n\t\tcurrentVerts = tmp1;\n\n\t\tvar tmp2 = previousVector;\n\t\tpreviousVector = currentVector;\n\t\tcurrentVector = tmp2;\n\n\t\tvar tmp3 = previousIntensity;\n\t\tpreviousIntensity = currentIntensity;\n\t\tcurrentIntensity = tmp3;\n\t}\n\treturn {\n\t\tpositions: verts,\n\t\tcells: faces,\n\t\tvectors: vectors,\n\t\tvertexIntensity: intensities\n\t};\n};\n\nvar createTubes = function(streams, colormap, maxDivergence, minDistance) {\n\n\tvar maxNorm = 0;\n\tfor (var i=0; i v) return i-1;\n }\n return i;\n};\n\nvar clamp = function(v, min, max) {\n\treturn v < min ? min : (v > max ? max : v);\n};\n\nvar sampleMeshgrid = function(point, vectorField, gridInfo) {\n\tvar vectors = vectorField.vectors;\n\tvar meshgrid = vectorField.meshgrid;\n\n\tvar x = point[0];\n\tvar y = point[1];\n\tvar z = point[2];\n\n\tvar w = meshgrid[0].length;\n\tvar h = meshgrid[1].length;\n\tvar d = meshgrid[2].length;\n\n\t// Find the index of the nearest smaller value in the meshgrid for each coordinate of (x,y,z).\n\t// The nearest smaller value index for x is the index x0 such that\n\t// meshgrid[0][x0] < x and for all x1 > x0, meshgrid[0][x1] >= x.\n\tvar x0 = findLastSmallerIndex(meshgrid[0], x);\n\tvar y0 = findLastSmallerIndex(meshgrid[1], y);\n\tvar z0 = findLastSmallerIndex(meshgrid[2], z);\n\n\t// Get the nearest larger meshgrid value indices.\n\t// From the above \"nearest smaller value\", we know that\n\t// meshgrid[0][x0] < x\n\t// meshgrid[0][x0+1] >= x\n\tvar x1 = x0 + 1;\n\tvar y1 = y0 + 1;\n\tvar z1 = z0 + 1;\n\n\tx0 = clamp(x0, 0, w-1);\n\tx1 = clamp(x1, 0, w-1);\n\ty0 = clamp(y0, 0, h-1);\n\ty1 = clamp(y1, 0, h-1);\n\tz0 = clamp(z0, 0, d-1);\n\tz1 = clamp(z1, 0, d-1);\n\n\t// Reject points outside the meshgrid, return a zero vector.\n\tif (x0 < 0 || y0 < 0 || z0 < 0 || x1 > w-1 || y1 > h-1 || z1 > d-1) {\n\t\treturn vec3.create();\n\t}\n\n\t// Normalize point coordinates to 0..1 scaling factor between x0 and x1.\n\tvar mX0 = meshgrid[0][x0];\n\tvar mX1 = meshgrid[0][x1];\n\tvar mY0 = meshgrid[1][y0];\n\tvar mY1 = meshgrid[1][y1];\n\tvar mZ0 = meshgrid[2][z0];\n\tvar mZ1 = meshgrid[2][z1];\n\tvar xf = (x - mX0) / (mX1 - mX0);\n\tvar yf = (y - mY0) / (mY1 - mY0);\n\tvar zf = (z - mZ0) / (mZ1 - mZ0);\n\n\tif (!isFinite(xf)) xf = 0.5;\n\tif (!isFinite(yf)) yf = 0.5;\n\tif (!isFinite(zf)) zf = 0.5;\n\n\tvar x0off;\n\tvar x1off;\n\tvar y0off;\n\tvar y1off;\n\tvar z0off;\n\tvar z1off;\n\n\tif(gridInfo.reversedX) {\n\t\tx0 = w - 1 - x0;\n\t\tx1 = w - 1 - x1;\n\t}\n\n\tif(gridInfo.reversedY) {\n\t\ty0 = h - 1 - y0;\n\t\ty1 = h - 1 - y1;\n\t}\n\n\tif(gridInfo.reversedZ) {\n\t\tz0 = d - 1 - z0;\n\t\tz1 = d - 1 - z1;\n\t}\n\n\tswitch(gridInfo.filled) {\n\t\tcase 5: // 'zyx'\n\t\t\tz0off = z0;\n\t\t\tz1off = z1;\n\t\t\ty0off = y0*d;\n\t\t\ty1off = y1*d;\n\t\t\tx0off = x0*d*h;\n\t\t\tx1off = x1*d*h;\n\t\t\tbreak;\n\n\t\tcase 4: // 'zxy'\n\t\t\tz0off = z0;\n\t\t\tz1off = z1;\n\t\t\tx0off = x0*d;\n\t\t\tx1off = x1*d;\n\t\t\ty0off = y0*d*w;\n\t\t\ty1off = y1*d*w;\n\t\t\tbreak;\n\n\t\tcase 3: // 'yzx'\n\t\t\ty0off = y0;\n\t\t\ty1off = y1;\n\t\t\tz0off = z0*h;\n\t\t\tz1off = z1*h;\n\t\t\tx0off = x0*h*d;\n\t\t\tx1off = x1*h*d;\n\t\t\tbreak;\n\n\t\tcase 2: // 'yxz'\n\t\t\ty0off = y0;\n\t\t\ty1off = y1;\n\t\t\tx0off = x0*h;\n\t\t\tx1off = x1*h;\n\t\t\tz0off = z0*h*w;\n\t\t\tz1off = z1*h*w;\n\t\t\tbreak;\n\n\t\tcase 1: // 'xzy'\n\t\t\tx0off = x0;\n\t\t\tx1off = x1;\n\t\t\tz0off = z0*w;\n\t\t\tz1off = z1*w;\n\t\t\ty0off = y0*w*d;\n\t\t\ty1off = y1*w*d;\n\t\t\tbreak;\n\n\t\tdefault: // case 0: // 'xyz'\n\t\t\tx0off = x0;\n\t\t\tx1off = x1;\n\t\t\ty0off = y0*w;\n\t\t\ty1off = y1*w;\n\t\t\tz0off = z0*w*h;\n\t\t\tz1off = z1*w*h;\n\t\t\tbreak;\n\t}\n\n\t// Sample data vectors around the (x,y,z) point.\n\tvar v000 = vectors[x0off + y0off + z0off];\n\tvar v001 = vectors[x0off + y0off + z1off];\n\tvar v010 = vectors[x0off + y1off + z0off];\n\tvar v011 = vectors[x0off + y1off + z1off];\n\tvar v100 = vectors[x1off + y0off + z0off];\n\tvar v101 = vectors[x1off + y0off + z1off];\n\tvar v110 = vectors[x1off + y1off + z0off];\n\tvar v111 = vectors[x1off + y1off + z1off];\n\n\tvar c00 = vec3.create();\n\tvar c01 = vec3.create();\n\tvar c10 = vec3.create();\n\tvar c11 = vec3.create();\n\n\tvec3.lerp(c00, v000, v100, xf);\n\tvec3.lerp(c01, v001, v101, xf);\n\tvec3.lerp(c10, v010, v110, xf);\n\tvec3.lerp(c11, v011, v111, xf);\n\n\tvar c0 = vec3.create();\n\tvar c1 = vec3.create();\n\n\tvec3.lerp(c0, c00, c10, yf);\n\tvec3.lerp(c1, c01, c11, yf);\n\n\tvar c = vec3.create();\n\n\tvec3.lerp(c, c0, c1, zf);\n\n\treturn c;\n};\n\n\nvar vabs = function(dst, v) {\n\tvar x = v[0];\n\tvar y = v[1];\n\tvar z = v[2];\n\tdst[0] = x < 0 ? -x : x;\n\tdst[1] = y < 0 ? -y : y;\n\tdst[2] = z < 0 ? -z : z;\n\treturn dst;\n};\n\nvar findMinSeparation = function(xs) {\n\tvar minSeparation = Infinity;\n\txs.sort(function(a, b) { return a - b; });\n\tvar len = xs.length;\n\tfor (var i=1; i maxX ||\n\t\t\ty < minY || y > maxY ||\n\t\t\tz < minZ || z > maxZ\n\t\t);\n\t};\n\n\tvar boundsSize = vec3.distance(bounds[0], bounds[1]);\n\tvar maxStepSize = 10 * boundsSize / maxLength;\n\tvar maxStepSizeSq = maxStepSize * maxStepSize;\n\n\tvar minDistance = 1;\n\tvar maxDivergence = 0; // For component-wise divergence vec3.create();\n\n\t// In case we need to do component-wise divergence visualization\n\t// var tmp = vec3.create();\n\n\tvar len = positions.length;\n\tif (len > 1) {\n\t\tminDistance = calculateMinPositionDistance(positions);\n\t}\n\n\tfor (var i = 0; i < len; i++) {\n\t\tvar p = vec3.create();\n\t\tvec3.copy(p, positions[i]);\n\n\t\tvar stream = [p];\n\t\tvar velocities = [];\n\t\tvar v = getVelocity(p);\n\t\tvar op = p;\n\t\tvelocities.push(v);\n\n\t\tvar divergences = [];\n\n\t\tvar dv = getDivergence(p, v);\n\t\tvar dvLength = vec3.length(dv);\n\t\tif (isFinite(dvLength) && dvLength > maxDivergence) {\n\t\t\tmaxDivergence = dvLength;\n\t\t}\n\t\t// In case we need to do component-wise divergence visualization\n\t\t// vec3.max(maxDivergence, maxDivergence, vabs(tmp, dv));\n\t\tdivergences.push(dvLength);\n\n\t\tstreams.push({points: stream, velocities: velocities, divergences: divergences});\n\n\t\tvar j = 0;\n\n\t\twhile (j < maxLength * 100 && stream.length < maxLength && inBounds(p)) {\n\t\t\tj++;\n\t\t\tvar np = vec3.clone(v);\n\t\t\tvar sqLen = vec3.squaredLength(np);\n\t\t\tif (sqLen === 0) {\n\t\t\t\tbreak;\n\t\t\t} else if (sqLen > maxStepSizeSq) {\n\t\t\t\tvec3.scale(np, np, maxStepSize / Math.sqrt(sqLen));\n\t\t\t}\n\t\t\tvec3.add(np, np, p);\n\n\t\t\tv = getVelocity(np);\n\n\t\t\tif (vec3.squaredDistance(op, np) - maxStepSizeSq > -0.0001 * maxStepSizeSq) {\n\t\t\t\tstream.push(np);\n\t\t\t\top = np;\n\t\t\t\tvelocities.push(v);\n\t\t\t\tvar dv = getDivergence(np, v);\n\t\t\t\tvar dvLength = vec3.length(dv);\n\t\t\t\tif (isFinite(dvLength) && dvLength > maxDivergence) {\n\t\t\t\t\tmaxDivergence = dvLength;\n\t\t\t\t}\n\t\t\t\t// In case we need to do component-wise divergence visualization\n\t\t\t\t//vec3.max(maxDivergence, maxDivergence, vabs(tmp, dv));\n\t\t\t\tdivergences.push(dvLength);\n\t\t\t}\n\n\t\t\tp = np;\n\t\t}\n\t}\n\n\tvar tubes = createTubes(streams, vectorField.colormap, maxDivergence, minDistance);\n\n\tif (absoluteTubeSize) {\n\t\ttubes.tubeScale = absoluteTubeSize;\n\t} else {\n\t\t// Avoid division by zero.\n\t\tif (maxDivergence === 0) {\n\t\t\tmaxDivergence = 1;\n\t\t}\n\t\ttubes.tubeScale = tubeSize * 0.5 * minDistance / maxDivergence;\n\t}\n\n\treturn tubes;\n};\n\nvar shaders = __webpack_require__(6740);\nvar createMesh = (__webpack_require__(6405).createMesh);\nmodule.exports.createTubeMesh = function(gl, params) {\n\treturn createMesh(gl, params, {\n\t\tshaders: shaders,\n\t\ttraceType: 'streamtube'\n\t});\n}\n\n\n/***/ }),\n\n/***/ 990:\n/***/ (function(__unused_webpack_module, exports, __webpack_require__) {\n\nvar createShader = __webpack_require__(9405)\nvar glslify = __webpack_require__(3236)\n\nvar vertSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nattribute vec4 uv;\\nattribute vec3 f;\\nattribute vec3 normal;\\n\\nuniform vec3 objectOffset;\\nuniform mat4 model, view, projection, inverseModel;\\nuniform vec3 lightPosition, eyePosition;\\nuniform sampler2D colormap;\\n\\nvarying float value, kill;\\nvarying vec3 worldCoordinate;\\nvarying vec2 planeCoordinate;\\nvarying vec3 lightDirection, eyeDirection, surfaceNormal;\\nvarying vec4 vColor;\\n\\nvoid main() {\\n vec3 localCoordinate = vec3(uv.zw, f.x);\\n worldCoordinate = objectOffset + localCoordinate;\\n mat4 objectOffsetTranslation = mat4(1.0) + mat4(vec4(0), vec4(0), vec4(0), vec4(objectOffset, 0));\\n vec4 worldPosition = (model * objectOffsetTranslation) * vec4(localCoordinate, 1.0);\\n vec4 clipPosition = projection * (view * worldPosition);\\n gl_Position = clipPosition;\\n kill = f.y;\\n value = f.z;\\n planeCoordinate = uv.xy;\\n\\n vColor = texture2D(colormap, vec2(value, value));\\n\\n //Lighting geometry parameters\\n vec4 cameraCoordinate = view * worldPosition;\\n cameraCoordinate.xyz /= cameraCoordinate.w;\\n lightDirection = lightPosition - cameraCoordinate.xyz;\\n eyeDirection = eyePosition - cameraCoordinate.xyz;\\n surfaceNormal = normalize((vec4(normal,0) * inverseModel).xyz);\\n}\\n\"])\nvar fragSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nfloat beckmannDistribution(float x, float roughness) {\\n float NdotH = max(x, 0.0001);\\n float cos2Alpha = NdotH * NdotH;\\n float tan2Alpha = (cos2Alpha - 1.0) / cos2Alpha;\\n float roughness2 = roughness * roughness;\\n float denom = 3.141592653589793 * roughness2 * cos2Alpha * cos2Alpha;\\n return exp(tan2Alpha / roughness2) / denom;\\n}\\n\\nfloat beckmannSpecular(\\n vec3 lightDirection,\\n vec3 viewDirection,\\n vec3 surfaceNormal,\\n float roughness) {\\n return beckmannDistribution(dot(surfaceNormal, normalize(lightDirection + viewDirection)), roughness);\\n}\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nuniform vec3 lowerBound, upperBound;\\nuniform float contourTint;\\nuniform vec4 contourColor;\\nuniform sampler2D colormap;\\nuniform vec3 clipBounds[2];\\nuniform float roughness, fresnel, kambient, kdiffuse, kspecular, opacity;\\nuniform float vertexColor;\\n\\nvarying float value, kill;\\nvarying vec3 worldCoordinate;\\nvarying vec3 lightDirection, eyeDirection, surfaceNormal;\\nvarying vec4 vColor;\\n\\nvoid main() {\\n if (\\n kill > 0.0 ||\\n vColor.a == 0.0 ||\\n outOfRange(clipBounds[0], clipBounds[1], worldCoordinate)\\n ) discard;\\n\\n vec3 N = normalize(surfaceNormal);\\n vec3 V = normalize(eyeDirection);\\n vec3 L = normalize(lightDirection);\\n\\n if(gl_FrontFacing) {\\n N = -N;\\n }\\n\\n float specular = max(beckmannSpecular(L, V, N, roughness), 0.);\\n float diffuse = min(kambient + kdiffuse * max(dot(N, L), 0.0), 1.0);\\n\\n //decide how to interpolate color — in vertex or in fragment\\n vec4 surfaceColor =\\n step(vertexColor, .5) * texture2D(colormap, vec2(value, value)) +\\n step(.5, vertexColor) * vColor;\\n\\n vec4 litColor = surfaceColor.a * vec4(diffuse * surfaceColor.rgb + kspecular * vec3(1,1,1) * specular, 1.0);\\n\\n gl_FragColor = mix(litColor, contourColor, contourTint) * opacity;\\n}\\n\"])\nvar contourVertSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nattribute vec4 uv;\\nattribute float f;\\n\\nuniform vec3 objectOffset;\\nuniform mat3 permutation;\\nuniform mat4 model, view, projection;\\nuniform float height, zOffset;\\nuniform sampler2D colormap;\\n\\nvarying float value, kill;\\nvarying vec3 worldCoordinate;\\nvarying vec2 planeCoordinate;\\nvarying vec3 lightDirection, eyeDirection, surfaceNormal;\\nvarying vec4 vColor;\\n\\nvoid main() {\\n vec3 dataCoordinate = permutation * vec3(uv.xy, height);\\n worldCoordinate = objectOffset + dataCoordinate;\\n mat4 objectOffsetTranslation = mat4(1.0) + mat4(vec4(0), vec4(0), vec4(0), vec4(objectOffset, 0));\\n vec4 worldPosition = (model * objectOffsetTranslation) * vec4(dataCoordinate, 1.0);\\n\\n vec4 clipPosition = projection * (view * worldPosition);\\n clipPosition.z += zOffset;\\n\\n gl_Position = clipPosition;\\n value = f + objectOffset.z;\\n kill = -1.0;\\n planeCoordinate = uv.zw;\\n\\n vColor = texture2D(colormap, vec2(value, value));\\n\\n //Don't do lighting for contours\\n surfaceNormal = vec3(1,0,0);\\n eyeDirection = vec3(0,1,0);\\n lightDirection = vec3(0,0,1);\\n}\\n\"])\nvar pickSrc = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nbool outOfRange(float a, float b, float p) {\\n return ((p > max(a, b)) || \\n (p < min(a, b)));\\n}\\n\\nbool outOfRange(vec2 a, vec2 b, vec2 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y));\\n}\\n\\nbool outOfRange(vec3 a, vec3 b, vec3 p) {\\n return (outOfRange(a.x, b.x, p.x) ||\\n outOfRange(a.y, b.y, p.y) ||\\n outOfRange(a.z, b.z, p.z));\\n}\\n\\nbool outOfRange(vec4 a, vec4 b, vec4 p) {\\n return outOfRange(a.xyz, b.xyz, p.xyz);\\n}\\n\\nuniform vec2 shape;\\nuniform vec3 clipBounds[2];\\nuniform float pickId;\\n\\nvarying float value, kill;\\nvarying vec3 worldCoordinate;\\nvarying vec2 planeCoordinate;\\nvarying vec3 surfaceNormal;\\n\\nvec2 splitFloat(float v) {\\n float vh = 255.0 * v;\\n float upper = floor(vh);\\n float lower = fract(vh);\\n return vec2(upper / 255.0, floor(lower * 16.0) / 16.0);\\n}\\n\\nvoid main() {\\n if ((kill > 0.0) ||\\n (outOfRange(clipBounds[0], clipBounds[1], worldCoordinate))) discard;\\n\\n vec2 ux = splitFloat(planeCoordinate.x / shape.x);\\n vec2 uy = splitFloat(planeCoordinate.y / shape.y);\\n gl_FragColor = vec4(pickId, ux.x, uy.x, ux.y + (uy.y/16.0));\\n}\\n\"])\n\nexports.createShader = function (gl) {\n var shader = createShader(gl, vertSrc, fragSrc, null, [\n {name: 'uv', type: 'vec4'},\n {name: 'f', type: 'vec3'},\n {name: 'normal', type: 'vec3'}\n ])\n shader.attributes.uv.location = 0\n shader.attributes.f.location = 1\n shader.attributes.normal.location = 2\n return shader\n}\nexports.createPickShader = function (gl) {\n var shader = createShader(gl, vertSrc, pickSrc, null, [\n {name: 'uv', type: 'vec4'},\n {name: 'f', type: 'vec3'},\n {name: 'normal', type: 'vec3'}\n ])\n shader.attributes.uv.location = 0\n shader.attributes.f.location = 1\n shader.attributes.normal.location = 2\n return shader\n}\nexports.createContourShader = function (gl) {\n var shader = createShader(gl, contourVertSrc, fragSrc, null, [\n {name: 'uv', type: 'vec4'},\n {name: 'f', type: 'float'}\n ])\n shader.attributes.uv.location = 0\n shader.attributes.f.location = 1\n return shader\n}\nexports.createPickContourShader = function (gl) {\n var shader = createShader(gl, contourVertSrc, pickSrc, null, [\n {name: 'uv', type: 'vec4'},\n {name: 'f', type: 'float'}\n ])\n shader.attributes.uv.location = 0\n shader.attributes.f.location = 1\n return shader\n}\n\n\n/***/ }),\n\n/***/ 9499:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = createSurfacePlot\n\nvar bits = __webpack_require__(8828)\nvar createBuffer = __webpack_require__(2762)\nvar createVAO = __webpack_require__(8116)\nvar createTexture = __webpack_require__(7766)\nvar pool = __webpack_require__(1888)\nvar colormap = __webpack_require__(6729)\nvar ops = __webpack_require__(5298)\nvar pack = __webpack_require__(9994)\nvar ndarray = __webpack_require__(9618)\nvar surfaceNets = __webpack_require__(3711)\nvar multiply = __webpack_require__(6760)\nvar invert = __webpack_require__(7608)\nvar bsearch = __webpack_require__(2478)\nvar gradient = __webpack_require__(6199)\nvar shaders = __webpack_require__(990)\n\nvar createShader = shaders.createShader\nvar createContourShader = shaders.createContourShader\nvar createPickShader = shaders.createPickShader\nvar createPickContourShader = shaders.createPickContourShader\n\nvar SURFACE_VERTEX_SIZE = 4 * (4 + 3 + 3)\n\nvar IDENTITY = [\n 1, 0, 0, 0,\n 0, 1, 0, 0,\n 0, 0, 1, 0,\n 0, 0, 0, 1 ]\n\nvar QUAD = [\n [0, 0],\n [0, 1],\n [1, 0],\n [1, 1],\n [1, 0],\n [0, 1]\n]\n\nvar PERMUTATIONS = [\n [0, 0, 0, 0, 0, 0, 0, 0, 0],\n [0, 0, 0, 0, 0, 0, 0, 0, 0],\n [0, 0, 0, 0, 0, 0, 0, 0, 0]\n]\n\n;(function () {\n for (var i = 0; i < 3; ++i) {\n var p = PERMUTATIONS[i]\n var u = (i + 1) % 3\n var v = (i + 2) % 3\n p[u + 0] = 1\n p[v + 3] = 1\n p[i + 6] = 1\n }\n})()\n\nfunction SurfacePickResult (position, index, uv, level, dataCoordinate) {\n this.position = position\n this.index = index\n this.uv = uv\n this.level = level\n this.dataCoordinate = dataCoordinate\n}\n\nvar N_COLORS = 256\n\nfunction SurfacePlot (\n gl,\n shape,\n bounds,\n shader,\n pickShader,\n coordinates,\n vao,\n colorMap,\n contourShader,\n contourPickShader,\n contourBuffer,\n contourVAO,\n dynamicBuffer,\n dynamicVAO,\n objectOffset) {\n this.gl = gl\n this.shape = shape\n this.bounds = bounds\n this.objectOffset = objectOffset\n this.intensityBounds = []\n\n this._shader = shader\n this._pickShader = pickShader\n this._coordinateBuffer = coordinates\n this._vao = vao\n this._colorMap = colorMap\n\n this._contourShader = contourShader\n this._contourPickShader = contourPickShader\n this._contourBuffer = contourBuffer\n this._contourVAO = contourVAO\n this._contourOffsets = [[], [], []]\n this._contourCounts = [[], [], []]\n this._vertexCount = 0\n\n this._pickResult = new SurfacePickResult([0, 0, 0], [0, 0], [0, 0], [0, 0, 0], [0, 0, 0])\n\n this._dynamicBuffer = dynamicBuffer\n this._dynamicVAO = dynamicVAO\n this._dynamicOffsets = [0, 0, 0]\n this._dynamicCounts = [0, 0, 0]\n\n this.contourWidth = [ 1, 1, 1 ]\n this.contourLevels = [[1], [1], [1]]\n this.contourTint = [0, 0, 0]\n this.contourColor = [[0.5, 0.5, 0.5, 1], [0.5, 0.5, 0.5, 1], [0.5, 0.5, 0.5, 1]]\n\n this.showContour = true\n this.showSurface = true\n\n this.enableHighlight = [true, true, true]\n this.highlightColor = [[0, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 1]]\n this.highlightTint = [ 1, 1, 1 ]\n this.highlightLevel = [-1, -1, -1]\n\n // Dynamic contour options\n this.enableDynamic = [ true, true, true ]\n this.dynamicLevel = [ NaN, NaN, NaN ]\n this.dynamicColor = [ [0, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 1] ]\n this.dynamicTint = [ 1, 1, 1 ]\n this.dynamicWidth = [ 1, 1, 1 ]\n\n this.axesBounds = [[Infinity, Infinity, Infinity], [-Infinity, -Infinity, -Infinity]]\n this.surfaceProject = [ false, false, false ]\n this.contourProject = [[ false, false, false ],\n [ false, false, false ],\n [ false, false, false ]]\n\n this.colorBounds = [ false, false ]\n\n // Store xyz fields, need this for picking\n this._field = [\n ndarray(pool.mallocFloat(1024), [0, 0]),\n ndarray(pool.mallocFloat(1024), [0, 0]),\n ndarray(pool.mallocFloat(1024), [0, 0]) ]\n\n this.pickId = 1\n this.clipBounds = [[-Infinity, -Infinity, -Infinity], [Infinity, Infinity, Infinity]]\n\n this.snapToData = false\n\n this.pixelRatio = 1\n\n this.opacity = 1.0\n\n this.lightPosition = [10, 10000, 0]\n this.ambientLight = 0.8\n this.diffuseLight = 0.8\n this.specularLight = 2.0\n this.roughness = 0.5\n this.fresnel = 1.5\n this.vertexColor = 0\n\n this.dirty = true\n}\n\nvar proto = SurfacePlot.prototype\n\nproto.genColormap = function (name, opacityscale) {\n var hasAlpha = false\n\n var x = pack([colormap({\n colormap: name,\n nshades: N_COLORS,\n format: 'rgba'\n }).map(function (c, i) {\n var a = opacityscale ? getOpacityFromScale(i / 255.0, opacityscale) : c[3]\n if(a < 1) hasAlpha = true\n return [c[0], c[1], c[2], 255 * a]\n })])\n ops.divseq(x, 255.0)\n\n this.hasAlphaScale = hasAlpha\n return x\n}\n\nproto.isTransparent = function () {\n return this.opacity < 1 || this.hasAlphaScale\n}\n\nproto.isOpaque = function () {\n return !this.isTransparent()\n}\n\nproto.pickSlots = 1\n\nproto.setPickBase = function (id) {\n this.pickId = id\n}\n\nfunction getOpacityFromScale(ratio, opacityscale) { // copied form gl-mesh3d\n if(!opacityscale) return 1\n if(!opacityscale.length) return 1\n\n for(var i = 0; i < opacityscale.length; ++i) {\n if(opacityscale.length < 2) return 1\n if(opacityscale[i][0] === ratio) return opacityscale[i][1]\n if(opacityscale[i][0] > ratio && i > 0) {\n var d = (opacityscale[i][0] - ratio) / (opacityscale[i][0] - opacityscale[i - 1][0])\n return opacityscale[i][1] * (1 - d) + d * opacityscale[i - 1][1]\n }\n }\n\n return 1\n}\n\nvar ZERO_VEC = [0, 0, 0]\n\nvar PROJECT_DATA = {\n showSurface: false,\n showContour: false,\n projections: [IDENTITY.slice(), IDENTITY.slice(), IDENTITY.slice()],\n clipBounds: [\n [[0, 0, 0], [0, 0, 0]],\n [[0, 0, 0], [0, 0, 0]],\n [[0, 0, 0], [0, 0, 0]]]\n}\n\nfunction computeProjectionData (camera, obj) {\n var i, j, k\n\n // Compute cube properties\n var cubeAxis = (obj.axes && obj.axes.lastCubeProps.axis) || ZERO_VEC\n\n var showSurface = obj.showSurface\n var showContour = obj.showContour\n\n for (i = 0; i < 3; ++i) {\n showSurface = showSurface || obj.surfaceProject[i]\n for (j = 0; j < 3; ++j) {\n showContour = showContour || obj.contourProject[i][j]\n }\n }\n\n for (i = 0; i < 3; ++i) {\n // Construct projection onto axis\n var axisSquish = PROJECT_DATA.projections[i]\n for (j = 0; j < 16; ++j) {\n axisSquish[j] = 0\n }\n for (j = 0; j < 4; ++j) {\n axisSquish[5 * j] = 1\n }\n axisSquish[5 * i] = 0\n axisSquish[12 + i] = obj.axesBounds[+(cubeAxis[i] > 0)][i]\n multiply(axisSquish, camera.model, axisSquish)\n\n var nclipBounds = PROJECT_DATA.clipBounds[i]\n for (k = 0; k < 2; ++k) {\n for (j = 0; j < 3; ++j) {\n nclipBounds[k][j] = camera.clipBounds[k][j]\n }\n }\n nclipBounds[0][i] = -1e8\n nclipBounds[1][i] = 1e8\n }\n\n PROJECT_DATA.showSurface = showSurface\n PROJECT_DATA.showContour = showContour\n\n return PROJECT_DATA\n}\n\nvar UNIFORMS = {\n model: IDENTITY,\n view: IDENTITY,\n projection: IDENTITY,\n inverseModel: IDENTITY.slice(),\n lowerBound: [0, 0, 0],\n upperBound: [0, 0, 0],\n colorMap: 0,\n clipBounds: [[0, 0, 0], [0, 0, 0]],\n height: 0.0,\n contourTint: 0,\n contourColor: [0, 0, 0, 1],\n permutation: [1, 0, 0, 0, 1, 0, 0, 0, 1],\n zOffset: -1e-4,\n objectOffset: [0, 0, 0],\n kambient: 1,\n kdiffuse: 1,\n kspecular: 1,\n lightPosition: [1000, 1000, 1000],\n eyePosition: [0, 0, 0],\n roughness: 1,\n fresnel: 1,\n opacity: 1,\n vertexColor: 0\n}\n\nvar MATRIX_INVERSE = IDENTITY.slice()\nvar DEFAULT_PERM = [1, 0, 0, 0, 1, 0, 0, 0, 1]\n\nfunction drawCore (params, transparent) {\n params = params || {}\n var gl = this.gl\n\n gl.disable(gl.CULL_FACE)\n\n this._colorMap.bind(0)\n\n var uniforms = UNIFORMS\n uniforms.model = params.model || IDENTITY\n uniforms.view = params.view || IDENTITY\n uniforms.projection = params.projection || IDENTITY\n uniforms.lowerBound = [this.bounds[0][0], this.bounds[0][1], this.colorBounds[0] || this.bounds[0][2]]\n uniforms.upperBound = [this.bounds[1][0], this.bounds[1][1], this.colorBounds[1] || this.bounds[1][2]]\n uniforms.objectOffset = this.objectOffset\n uniforms.contourColor = this.contourColor[0]\n\n uniforms.inverseModel = invert(uniforms.inverseModel, uniforms.model)\n\n for (var i = 0; i < 2; ++i) {\n var clipClamped = uniforms.clipBounds[i]\n for (var j = 0; j < 3; ++j) {\n clipClamped[j] = Math.min(Math.max(this.clipBounds[i][j], -1e8), 1e8)\n }\n }\n\n uniforms.kambient = this.ambientLight\n uniforms.kdiffuse = this.diffuseLight\n uniforms.kspecular = this.specularLight\n\n uniforms.roughness = this.roughness\n uniforms.fresnel = this.fresnel\n uniforms.opacity = this.opacity\n\n uniforms.height = 0.0\n uniforms.permutation = DEFAULT_PERM\n\n uniforms.vertexColor = this.vertexColor\n\n // Compute camera matrix inverse\n var invCameraMatrix = MATRIX_INVERSE\n multiply(invCameraMatrix, uniforms.view, uniforms.model)\n multiply(invCameraMatrix, uniforms.projection, invCameraMatrix)\n invert(invCameraMatrix, invCameraMatrix)\n\n for (i = 0; i < 3; ++i) {\n uniforms.eyePosition[i] = invCameraMatrix[12 + i] / invCameraMatrix[15]\n }\n\n var w = invCameraMatrix[15]\n for (i = 0; i < 3; ++i) {\n w += this.lightPosition[i] * invCameraMatrix[4 * i + 3]\n }\n for (i = 0; i < 3; ++i) {\n var s = invCameraMatrix[12 + i]\n for (j = 0; j < 3; ++j) {\n s += invCameraMatrix[4 * j + i] * this.lightPosition[j]\n }\n uniforms.lightPosition[i] = s / w\n }\n\n var projectData = computeProjectionData(uniforms, this)\n\n if (projectData.showSurface) {\n // Set up uniforms\n this._shader.bind()\n this._shader.uniforms = uniforms\n\n // Draw it\n this._vao.bind()\n\n if (this.showSurface && this._vertexCount) {\n this._vao.draw(gl.TRIANGLES, this._vertexCount)\n }\n\n // Draw projections of surface\n for (i = 0; i < 3; ++i) {\n if (!this.surfaceProject[i] || !this.vertexCount) {\n continue\n }\n this._shader.uniforms.model = projectData.projections[i]\n this._shader.uniforms.clipBounds = projectData.clipBounds[i]\n this._vao.draw(gl.TRIANGLES, this._vertexCount)\n }\n\n this._vao.unbind()\n }\n\n if (projectData.showContour) {\n var shader = this._contourShader\n\n // Don't apply lighting to contours\n uniforms.kambient = 1.0\n uniforms.kdiffuse = 0.0\n uniforms.kspecular = 0.0\n uniforms.opacity = 1.0\n\n shader.bind()\n shader.uniforms = uniforms\n\n // Draw contour lines\n var vao = this._contourVAO\n vao.bind()\n\n // Draw contour levels\n for (i = 0; i < 3; ++i) {\n shader.uniforms.permutation = PERMUTATIONS[i]\n gl.lineWidth(this.contourWidth[i] * this.pixelRatio)\n\n for (j = 0; j < this.contourLevels[i].length; ++j) {\n if (j === this.highlightLevel[i]) {\n shader.uniforms.contourColor = this.highlightColor[i]\n shader.uniforms.contourTint = this.highlightTint[i]\n } else if (j === 0 || (j - 1) === this.highlightLevel[i]) {\n shader.uniforms.contourColor = this.contourColor[i]\n shader.uniforms.contourTint = this.contourTint[i]\n }\n if (!this._contourCounts[i][j]) {\n continue\n }\n\n shader.uniforms.height = this.contourLevels[i][j]\n vao.draw(gl.LINES, this._contourCounts[i][j], this._contourOffsets[i][j])\n }\n }\n\n // Draw projections of surface\n for (i = 0; i < 3; ++i) {\n shader.uniforms.model = projectData.projections[i]\n shader.uniforms.clipBounds = projectData.clipBounds[i]\n for (j = 0; j < 3; ++j) {\n if (!this.contourProject[i][j]) {\n continue\n }\n shader.uniforms.permutation = PERMUTATIONS[j]\n gl.lineWidth(this.contourWidth[j] * this.pixelRatio)\n for (var k = 0; k < this.contourLevels[j].length; ++k) {\n if (k === this.highlightLevel[j]) {\n shader.uniforms.contourColor = this.highlightColor[j]\n shader.uniforms.contourTint = this.highlightTint[j]\n } else if (k === 0 || (k - 1) === this.highlightLevel[j]) {\n shader.uniforms.contourColor = this.contourColor[j]\n shader.uniforms.contourTint = this.contourTint[j]\n }\n if (!this._contourCounts[j][k]) {\n continue\n }\n\n shader.uniforms.height = this.contourLevels[j][k]\n vao.draw(gl.LINES, this._contourCounts[j][k], this._contourOffsets[j][k])\n }\n }\n }\n\n vao.unbind()\n\n // Draw dynamic contours\n vao = this._dynamicVAO\n vao.bind()\n\n // Draw contour levels\n for (i = 0; i < 3; ++i) {\n if (this._dynamicCounts[i] === 0) {\n continue\n }\n\n shader.uniforms.model = uniforms.model\n shader.uniforms.clipBounds = uniforms.clipBounds\n shader.uniforms.permutation = PERMUTATIONS[i]\n gl.lineWidth(this.dynamicWidth[i] * this.pixelRatio)\n\n shader.uniforms.contourColor = this.dynamicColor[i]\n shader.uniforms.contourTint = this.dynamicTint[i]\n shader.uniforms.height = this.dynamicLevel[i]\n vao.draw(gl.LINES, this._dynamicCounts[i], this._dynamicOffsets[i])\n\n for (j = 0; j < 3; ++j) {\n if (!this.contourProject[j][i]) {\n continue\n }\n\n shader.uniforms.model = projectData.projections[j]\n shader.uniforms.clipBounds = projectData.clipBounds[j]\n vao.draw(gl.LINES, this._dynamicCounts[i], this._dynamicOffsets[i])\n }\n }\n\n vao.unbind()\n }\n}\n\nproto.draw = function (params) {\n return drawCore.call(this, params, false)\n}\n\nproto.drawTransparent = function (params) {\n return drawCore.call(this, params, true)\n}\n\nvar PICK_UNIFORMS = {\n model: IDENTITY,\n view: IDENTITY,\n projection: IDENTITY,\n inverseModel: IDENTITY,\n clipBounds: [[0, 0, 0], [0, 0, 0]],\n height: 0.0,\n shape: [0, 0],\n pickId: 0,\n lowerBound: [0, 0, 0],\n upperBound: [0, 0, 0],\n zOffset: 0.0,\n objectOffset: [0, 0, 0],\n permutation: [1, 0, 0, 0, 1, 0, 0, 0, 1],\n lightPosition: [0, 0, 0],\n eyePosition: [0, 0, 0]\n}\n\nproto.drawPick = function (params) {\n params = params || {}\n var gl = this.gl\n gl.disable(gl.CULL_FACE)\n\n var uniforms = PICK_UNIFORMS\n uniforms.model = params.model || IDENTITY\n uniforms.view = params.view || IDENTITY\n uniforms.projection = params.projection || IDENTITY\n uniforms.shape = this._field[2].shape\n uniforms.pickId = this.pickId / 255.0\n uniforms.lowerBound = this.bounds[0]\n uniforms.upperBound = this.bounds[1]\n uniforms.objectOffset = this.objectOffset\n uniforms.permutation = DEFAULT_PERM\n\n for (var i = 0; i < 2; ++i) {\n var clipClamped = uniforms.clipBounds[i]\n for (var j = 0; j < 3; ++j) {\n clipClamped[j] = Math.min(Math.max(this.clipBounds[i][j], -1e8), 1e8)\n }\n }\n\n var projectData = computeProjectionData(uniforms, this)\n\n if (projectData.showSurface) {\n // Set up uniforms\n this._pickShader.bind()\n this._pickShader.uniforms = uniforms\n\n // Draw it\n this._vao.bind()\n this._vao.draw(gl.TRIANGLES, this._vertexCount)\n\n // Draw projections of surface\n for (i = 0; i < 3; ++i) {\n if (!this.surfaceProject[i]) {\n continue\n }\n this._pickShader.uniforms.model = projectData.projections[i]\n this._pickShader.uniforms.clipBounds = projectData.clipBounds[i]\n this._vao.draw(gl.TRIANGLES, this._vertexCount)\n }\n\n this._vao.unbind()\n }\n\n if (projectData.showContour) {\n var shader = this._contourPickShader\n\n shader.bind()\n shader.uniforms = uniforms\n\n var vao = this._contourVAO\n vao.bind()\n\n for (j = 0; j < 3; ++j) {\n gl.lineWidth(this.contourWidth[j] * this.pixelRatio)\n shader.uniforms.permutation = PERMUTATIONS[j]\n for (i = 0; i < this.contourLevels[j].length; ++i) {\n if (this._contourCounts[j][i]) {\n shader.uniforms.height = this.contourLevels[j][i]\n vao.draw(gl.LINES, this._contourCounts[j][i], this._contourOffsets[j][i])\n }\n }\n }\n\n // Draw projections of surface\n for (i = 0; i < 3; ++i) {\n shader.uniforms.model = projectData.projections[i]\n shader.uniforms.clipBounds = projectData.clipBounds[i]\n\n for (j = 0; j < 3; ++j) {\n if (!this.contourProject[i][j]) {\n continue\n }\n\n shader.uniforms.permutation = PERMUTATIONS[j]\n gl.lineWidth(this.contourWidth[j] * this.pixelRatio)\n for (var k = 0; k < this.contourLevels[j].length; ++k) {\n if (this._contourCounts[j][k]) {\n shader.uniforms.height = this.contourLevels[j][k]\n vao.draw(gl.LINES, this._contourCounts[j][k], this._contourOffsets[j][k])\n }\n }\n }\n }\n\n vao.unbind()\n }\n}\n\nproto.pick = function (selection) {\n if (!selection) {\n return null\n }\n\n if (selection.id !== this.pickId) {\n return null\n }\n\n var shape = this._field[2].shape\n\n var result = this._pickResult\n\n // Compute uv coordinate\n var x = shape[0] * (selection.value[0] + (selection.value[2] >> 4) / 16.0) / 255.0\n var ix = Math.floor(x)\n var fx = x - ix\n\n var y = shape[1] * (selection.value[1] + (selection.value[2] & 15) / 16.0) / 255.0\n var iy = Math.floor(y)\n var fy = y - iy\n\n ix += 1\n iy += 1\n\n // Compute xyz coordinate\n var pos = result.position\n pos[0] = pos[1] = pos[2] = 0\n for (var dx = 0; dx < 2; ++dx) {\n var s = dx ? fx : 1.0 - fx\n for (var dy = 0; dy < 2; ++dy) {\n var t = dy ? fy : 1.0 - fy\n\n var r = ix + dx\n var c = iy + dy\n var w = s * t\n\n for (var i = 0; i < 3; ++i) {\n pos[i] += this._field[i].get(r, c) * w\n }\n }\n }\n\n // Find closest level\n var levelIndex = this._pickResult.level\n for (var j = 0; j < 3; ++j) {\n levelIndex[j] = bsearch.le(this.contourLevels[j], pos[j])\n if (levelIndex[j] < 0) {\n if (this.contourLevels[j].length > 0) {\n levelIndex[j] = 0\n }\n } else if (levelIndex[j] < this.contourLevels[j].length - 1) {\n var a = this.contourLevels[j][levelIndex[j]]\n var b = this.contourLevels[j][levelIndex[j] + 1]\n if (Math.abs(a - pos[j]) > Math.abs(b - pos[j])) {\n levelIndex[j] += 1\n }\n }\n }\n\n result.index[0] = fx < 0.5 ? ix : (ix + 1)\n result.index[1] = fy < 0.5 ? iy : (iy + 1)\n\n result.uv[0] = x / shape[0]\n result.uv[1] = y / shape[1]\n\n for (i = 0; i < 3; ++i) {\n result.dataCoordinate[i] = this._field[i].get(result.index[0], result.index[1])\n }\n\n return result\n}\n\nproto.padField = function(dstField, srcField) {\n var srcShape = srcField.shape.slice()\n var dstShape = dstField.shape.slice()\n\n // Center\n ops.assign(dstField.lo(1, 1).hi(srcShape[0], srcShape[1]), srcField)\n\n // Edges\n ops.assign(dstField.lo(1).hi(srcShape[0], 1),\n srcField.hi(srcShape[0], 1))\n ops.assign(dstField.lo(1, dstShape[1] - 1).hi(srcShape[0], 1),\n srcField.lo(0, srcShape[1] - 1).hi(srcShape[0], 1))\n ops.assign(dstField.lo(0, 1).hi(1, srcShape[1]),\n srcField.hi(1))\n ops.assign(dstField.lo(dstShape[0] - 1, 1).hi(1, srcShape[1]),\n srcField.lo(srcShape[0] - 1))\n // Corners\n dstField.set(0, 0, srcField.get(0, 0))\n dstField.set(0, dstShape[1] - 1, srcField.get(0, srcShape[1] - 1))\n dstField.set(dstShape[0] - 1, 0, srcField.get(srcShape[0] - 1, 0))\n dstField.set(dstShape[0] - 1, dstShape[1] - 1, srcField.get(srcShape[0] - 1, srcShape[1] - 1))\n}\n\nfunction handleArray (param, ctor) {\n if (Array.isArray(param)) {\n return [ ctor(param[0]), ctor(param[1]), ctor(param[2]) ]\n }\n return [ ctor(param), ctor(param), ctor(param) ]\n}\n\nfunction toColor (x) {\n if (Array.isArray(x)) {\n if (x.length === 3) {\n return [x[0], x[1], x[2], 1]\n }\n return [x[0], x[1], x[2], x[3]]\n }\n return [0, 0, 0, 1]\n}\n\nfunction handleColor (param) {\n if (Array.isArray(param)) {\n if (Array.isArray(param)) {\n return [\n toColor(param[0]),\n toColor(param[1]),\n toColor(param[2]) ]\n } else {\n var c = toColor(param)\n return [\n c.slice(),\n c.slice(),\n c.slice() ]\n }\n }\n}\n\nproto.update = function (params) {\n params = params || {}\n\n this.objectOffset = params.objectOffset || this.objectOffset\n\n this.dirty = true\n\n if ('contourWidth' in params) {\n this.contourWidth = handleArray(params.contourWidth, Number)\n }\n if ('showContour' in params) {\n this.showContour = handleArray(params.showContour, Boolean)\n }\n if ('showSurface' in params) {\n this.showSurface = !!params.showSurface\n }\n if ('contourTint' in params) {\n this.contourTint = handleArray(params.contourTint, Boolean)\n }\n if ('contourColor' in params) {\n this.contourColor = handleColor(params.contourColor)\n }\n if ('contourProject' in params) {\n this.contourProject = handleArray(params.contourProject, function (x) {\n return handleArray(x, Boolean)\n })\n }\n if ('surfaceProject' in params) {\n this.surfaceProject = params.surfaceProject\n }\n if ('dynamicColor' in params) {\n this.dynamicColor = handleColor(params.dynamicColor)\n }\n if ('dynamicTint' in params) {\n this.dynamicTint = handleArray(params.dynamicTint, Number)\n }\n if ('dynamicWidth' in params) {\n this.dynamicWidth = handleArray(params.dynamicWidth, Number)\n }\n if ('opacity' in params) {\n this.opacity = params.opacity\n }\n if('opacityscale' in params) {\n this.opacityscale = params.opacityscale\n }\n if ('colorBounds' in params) {\n this.colorBounds = params.colorBounds\n }\n if ('vertexColor' in params) {\n this.vertexColor = params.vertexColor ? 1 : 0;\n }\n if ('colormap' in params) {\n this._colorMap.setPixels(this.genColormap(params.colormap, this.opacityscale))\n }\n\n var field = params.field || (params.coords && params.coords[2]) || null\n var levelsChanged = false\n\n if (!field) {\n if (this._field[2].shape[0] || this._field[2].shape[2]) {\n field = this._field[2].lo(1, 1).hi(this._field[2].shape[0] - 2, this._field[2].shape[1] - 2)\n } else {\n field = this._field[2].hi(0, 0)\n }\n }\n\n // Update field\n if ('field' in params || 'coords' in params) {\n var fsize = (field.shape[0] + 2) * (field.shape[1] + 2)\n\n // Resize if necessary\n if (fsize > this._field[2].data.length) {\n pool.freeFloat(this._field[2].data)\n this._field[2].data = pool.mallocFloat(bits.nextPow2(fsize))\n }\n\n // Pad field\n this._field[2] = ndarray(this._field[2].data, [field.shape[0] + 2, field.shape[1] + 2])\n this.padField(this._field[2], field)\n\n // Save shape of field\n this.shape = field.shape.slice()\n var shape = this.shape\n\n // Resize coordinate fields if necessary\n for (var i = 0; i < 2; ++i) {\n if (this._field[2].size > this._field[i].data.length) {\n pool.freeFloat(this._field[i].data)\n this._field[i].data = pool.mallocFloat(this._field[2].size)\n }\n this._field[i] = ndarray(this._field[i].data, [shape[0] + 2, shape[1] + 2])\n }\n\n // Generate x/y coordinates\n if (params.coords) {\n var coords = params.coords\n if (!Array.isArray(coords) || coords.length !== 3) {\n throw new Error('gl-surface: invalid coordinates for x/y')\n }\n for (i = 0; i < 2; ++i) {\n var coord = coords[i]\n for (j = 0; j < 2; ++j) {\n if (coord.shape[j] !== shape[j]) {\n throw new Error('gl-surface: coords have incorrect shape')\n }\n }\n this.padField(this._field[i], coord)\n }\n } else if (params.ticks) {\n var ticks = params.ticks\n if (!Array.isArray(ticks) || ticks.length !== 2) {\n throw new Error('gl-surface: invalid ticks')\n }\n for (i = 0; i < 2; ++i) {\n var tick = ticks[i]\n if (Array.isArray(tick) || tick.length) {\n tick = ndarray(tick)\n }\n if (tick.shape[0] !== shape[i]) {\n throw new Error('gl-surface: invalid tick length')\n }\n // Make a copy view of the tick array\n var tick2 = ndarray(tick.data, shape)\n tick2.stride[i] = tick.stride[0]\n tick2.stride[i ^ 1] = 0\n\n // Fill in field array\n this.padField(this._field[i], tick2)\n }\n } else {\n for (i = 0; i < 2; ++i) {\n var offset = [0, 0]\n offset[i] = 1\n this._field[i] = ndarray(this._field[i].data, [shape[0] + 2, shape[1] + 2], offset, 0)\n }\n this._field[0].set(0, 0, 0)\n for (var j = 0; j < shape[0]; ++j) {\n this._field[0].set(j + 1, 0, j)\n }\n this._field[0].set(shape[0] + 1, 0, shape[0] - 1)\n this._field[1].set(0, 0, 0)\n for (j = 0; j < shape[1]; ++j) {\n this._field[1].set(0, j + 1, j)\n }\n this._field[1].set(0, shape[1] + 1, shape[1] - 1)\n }\n\n // Save shape\n var fields = this._field\n\n // Compute surface normals\n var dfields = ndarray(pool.mallocFloat(fields[2].size * 3 * 2), [3, shape[0] + 2, shape[1] + 2, 2])\n for (i = 0; i < 3; ++i) {\n gradient(dfields.pick(i), fields[i], 'mirror')\n }\n var normals = ndarray(pool.mallocFloat(fields[2].size * 3), [shape[0] + 2, shape[1] + 2, 3])\n for (i = 0; i < shape[0] + 2; ++i) {\n for (j = 0; j < shape[1] + 2; ++j) {\n var dxdu = dfields.get(0, i, j, 0)\n var dxdv = dfields.get(0, i, j, 1)\n var dydu = dfields.get(1, i, j, 0)\n var dydv = dfields.get(1, i, j, 1)\n var dzdu = dfields.get(2, i, j, 0)\n var dzdv = dfields.get(2, i, j, 1)\n\n var nx = dydu * dzdv - dydv * dzdu\n var ny = dzdu * dxdv - dzdv * dxdu\n var nz = dxdu * dydv - dxdv * dydu\n\n var nl = Math.sqrt(nx * nx + ny * ny + nz * nz)\n if (nl < 1e-8) {\n nl = Math.max(Math.abs(nx), Math.abs(ny), Math.abs(nz))\n if (nl < 1e-8) {\n nz = 1.0\n ny = nx = 0.0\n nl = 1.0\n } else {\n nl = 1.0 / nl\n }\n } else {\n nl = 1.0 / Math.sqrt(nl)\n }\n\n normals.set(i, j, 0, nx * nl)\n normals.set(i, j, 1, ny * nl)\n normals.set(i, j, 2, nz * nl)\n }\n }\n pool.free(dfields.data)\n\n // Initialize surface\n var lo = [ Infinity, Infinity, Infinity ]\n var hi = [ -Infinity, -Infinity, -Infinity ]\n var lo_intensity = Infinity\n var hi_intensity = -Infinity\n var count = (shape[0] - 1) * (shape[1] - 1) * 6\n var tverts = pool.mallocFloat(bits.nextPow2(10 * count))\n var tptr = 0\n var vertexCount = 0\n for (i = 0; i < shape[0] - 1; ++i) {\n j_loop:\n for (j = 0; j < shape[1] - 1; ++j) {\n // Test for NaNs\n for (var dx = 0; dx < 2; ++dx) {\n for (var dy = 0; dy < 2; ++dy) {\n for (var k = 0; k < 3; ++k) {\n var f = this._field[k].get(1 + i + dx, 1 + j + dy)\n if (isNaN(f) || !isFinite(f)) {\n continue j_loop\n }\n }\n }\n }\n for (k = 0; k < 6; ++k) {\n var r = i + QUAD[k][0]\n var c = j + QUAD[k][1]\n\n var tx = this._field[0].get(r + 1, c + 1)\n var ty = this._field[1].get(r + 1, c + 1)\n f = this._field[2].get(r + 1, c + 1)\n\n nx = normals.get(r + 1, c + 1, 0)\n ny = normals.get(r + 1, c + 1, 1)\n nz = normals.get(r + 1, c + 1, 2)\n\n if (params.intensity) {\n vf = params.intensity.get(r, c)\n }\n\n var vf = (params.intensity) ?\n params.intensity.get(r, c) :\n f + this.objectOffset[2];\n\n tverts[tptr++] = r\n tverts[tptr++] = c\n tverts[tptr++] = tx\n tverts[tptr++] = ty\n tverts[tptr++] = f\n tverts[tptr++] = 0\n tverts[tptr++] = vf\n tverts[tptr++] = nx\n tverts[tptr++] = ny\n tverts[tptr++] = nz\n\n lo[0] = Math.min(lo[0], tx + this.objectOffset[0])\n lo[1] = Math.min(lo[1], ty + this.objectOffset[1])\n lo[2] = Math.min(lo[2], f + this.objectOffset[2])\n lo_intensity = Math.min(lo_intensity, vf)\n\n hi[0] = Math.max(hi[0], tx + this.objectOffset[0])\n hi[1] = Math.max(hi[1], ty + this.objectOffset[1])\n hi[2] = Math.max(hi[2], f + this.objectOffset[2])\n hi_intensity = Math.max(hi_intensity, vf)\n\n vertexCount += 1\n }\n }\n }\n\n if (params.intensityBounds) {\n lo_intensity = +params.intensityBounds[0]\n hi_intensity = +params.intensityBounds[1]\n }\n\n // Scale all vertex intensities\n for (i = 6; i < tptr; i += 10) {\n tverts[i] = (tverts[i] - lo_intensity) / (hi_intensity - lo_intensity)\n }\n\n this._vertexCount = vertexCount\n this._coordinateBuffer.update(tverts.subarray(0, tptr))\n pool.freeFloat(tverts)\n pool.free(normals.data)\n\n // Update bounds\n this.bounds = [lo, hi]\n\n // Save intensity\n this.intensity = params.intensity || this._field[2]\n\n if(this.intensityBounds[0] !== lo_intensity || this.intensityBounds[1] !== hi_intensity) {\n levelsChanged = true\n }\n\n // Save intensity bound\n this.intensityBounds = [lo_intensity, hi_intensity]\n }\n\n // Update level crossings\n if ('levels' in params) {\n var levels = params.levels\n if (!Array.isArray(levels[0])) {\n levels = [ [], [], levels ]\n } else {\n levels = levels.slice()\n }\n for (i = 0; i < 3; ++i) {\n levels[i] = levels[i].slice()\n levels[i].sort(function (a, b) {\n return a - b\n })\n }\n for (i = 0; i < 3; ++i) {\n for (j = 0; j < levels[i].length; ++j) {\n levels[i][j] -= this.objectOffset[i]\n }\n }\n change_test:\n for (i = 0; i < 3; ++i) {\n if (levels[i].length !== this.contourLevels[i].length) {\n levelsChanged = true\n break\n }\n for (j = 0; j < levels[i].length; ++j) {\n if (levels[i][j] !== this.contourLevels[i][j]) {\n levelsChanged = true\n break change_test\n }\n }\n }\n this.contourLevels = levels\n }\n\n if (levelsChanged) {\n fields = this._field\n shape = this.shape\n\n // Update contour lines\n var contourVerts = []\n\n for (var dim = 0; dim < 3; ++dim) {\n var contourLevel = this.contourLevels[dim]\n\n var levelOffsets = []\n var levelCounts = []\n\n var parts = [0, 0, 0]\n\n for (i = 0; i < contourLevel.length; ++i) {\n var graph = surfaceNets(this._field[dim], contourLevel[i])\n\n levelOffsets.push((contourVerts.length / 5) | 0)\n vertexCount = 0\n\n edge_loop:\n for (j = 0; j < graph.cells.length; ++j) {\n var e = graph.cells[j]\n for (k = 0; k < 2; ++k) {\n var p = graph.positions[e[k]]\n\n var x = p[0]\n var ix = Math.floor(x) | 0\n var fx = x - ix\n\n var y = p[1]\n var iy = Math.floor(y) | 0\n var fy = y - iy\n\n var hole = false\n axis_loop:\n for (var axis = 0; axis < 3; ++axis) {\n parts[axis] = 0.0\n var iu = (dim + axis + 1) % 3\n for (dx = 0; dx < 2; ++dx) {\n var s = dx ? fx : 1.0 - fx\n r = Math.min(Math.max(ix + dx, 0), shape[0]) | 0\n for (dy = 0; dy < 2; ++dy) {\n var t = dy ? fy : 1.0 - fy\n c = Math.min(Math.max(iy + dy, 0), shape[1]) | 0\n\n if (axis < 2) {\n f = this._field[iu].get(r, c)\n } else {\n f = (this.intensity.get(r, c) - this.intensityBounds[0]) / (this.intensityBounds[1] - this.intensityBounds[0])\n }\n if (!isFinite(f) || isNaN(f)) {\n hole = true\n break axis_loop\n }\n\n var w = s * t\n parts[axis] += w * f\n }\n }\n }\n\n if (!hole) {\n contourVerts.push(\n parts[0],\n parts[1],\n p[0],\n p[1],\n parts[2]\n )\n vertexCount += 1\n } else {\n if (k > 0) {\n // If we already added first edge, pop off verts\n for (var l = 0; l < 5; ++l) {\n contourVerts.pop()\n }\n vertexCount -= 1\n }\n continue edge_loop\n }\n }\n }\n levelCounts.push(vertexCount)\n }\n\n // Store results\n this._contourOffsets[dim] = levelOffsets\n this._contourCounts[dim] = levelCounts\n\n }\n\n var floatBuffer = pool.mallocFloat(contourVerts.length)\n for (i = 0; i < contourVerts.length; ++i) {\n floatBuffer[i] = contourVerts[i]\n }\n this._contourBuffer.update(floatBuffer)\n pool.freeFloat(floatBuffer)\n }\n}\n\nproto.dispose = function () {\n this._shader.dispose()\n this._vao.dispose()\n this._coordinateBuffer.dispose()\n this._colorMap.dispose()\n this._contourBuffer.dispose()\n this._contourVAO.dispose()\n this._contourShader.dispose()\n this._contourPickShader.dispose()\n this._dynamicBuffer.dispose()\n this._dynamicVAO.dispose()\n for (var i = 0; i < 3; ++i) {\n pool.freeFloat(this._field[i].data)\n }\n}\n\nproto.highlight = function (selection) {\n var i\n\n if (!selection) {\n this._dynamicCounts = [0, 0, 0]\n this.dyanamicLevel = [NaN, NaN, NaN]\n this.highlightLevel = [-1, -1, -1]\n return\n }\n\n for (i = 0; i < 3; ++i) {\n if (this.enableHighlight[i]) {\n this.highlightLevel[i] = selection.level[i]\n } else {\n this.highlightLevel[i] = -1\n }\n }\n\n var levels\n if (this.snapToData) {\n levels = selection.dataCoordinate\n } else {\n levels = selection.position\n }\n for (i = 0; i < 3; ++i) {\n levels[i] -= this.objectOffset[i]\n }\n if ((!this.enableDynamic[0] || levels[0] === this.dynamicLevel[0]) &&\n (!this.enableDynamic[1] || levels[1] === this.dynamicLevel[1]) &&\n (!this.enableDynamic[2] || levels[2] === this.dynamicLevel[2])) {\n return\n }\n\n var vertexCount = 0\n var shape = this.shape\n var scratchBuffer = pool.mallocFloat(12 * shape[0] * shape[1])\n\n for (var d = 0; d < 3; ++d) {\n if (!this.enableDynamic[d]) {\n this.dynamicLevel[d] = NaN\n this._dynamicCounts[d] = 0\n continue\n }\n\n this.dynamicLevel[d] = levels[d]\n\n var u = (d + 1) % 3\n var v = (d + 2) % 3\n\n var f = this._field[d]\n var g = this._field[u]\n var h = this._field[v]\n\n var graph = surfaceNets(f, levels[d])\n var edges = graph.cells\n var positions = graph.positions\n\n this._dynamicOffsets[d] = vertexCount\n\n for (i = 0; i < edges.length; ++i) {\n var e = edges[i]\n for (var j = 0; j < 2; ++j) {\n var p = positions[e[j]]\n\n var x = +p[0]\n var ix = x | 0\n var jx = Math.min(ix + 1, shape[0]) | 0\n var fx = x - ix\n var hx = 1.0 - fx\n\n var y = +p[1]\n var iy = y | 0\n var jy = Math.min(iy + 1, shape[1]) | 0\n var fy = y - iy\n var hy = 1.0 - fy\n\n var w00 = hx * hy\n var w01 = hx * fy\n var w10 = fx * hy\n var w11 = fx * fy\n\n var cu = w00 * g.get(ix, iy) +\n w01 * g.get(ix, jy) +\n w10 * g.get(jx, iy) +\n w11 * g.get(jx, jy)\n\n var cv = w00 * h.get(ix, iy) +\n w01 * h.get(ix, jy) +\n w10 * h.get(jx, iy) +\n w11 * h.get(jx, jy)\n\n if (isNaN(cu) || isNaN(cv)) {\n if (j) {\n vertexCount -= 1\n }\n break\n }\n\n scratchBuffer[2 * vertexCount + 0] = cu\n scratchBuffer[2 * vertexCount + 1] = cv\n\n vertexCount += 1\n }\n }\n\n this._dynamicCounts[d] = vertexCount - this._dynamicOffsets[d]\n }\n\n this._dynamicBuffer.update(scratchBuffer.subarray(0, 2 * vertexCount))\n pool.freeFloat(scratchBuffer)\n}\n\nfunction createSurfacePlot (params) {\n var gl = params.gl\n\n var shader = createShader(gl)\n var pickShader = createPickShader(gl)\n var contourShader = createContourShader(gl)\n var contourPickShader = createPickContourShader(gl)\n\n var coordinateBuffer = createBuffer(gl)\n var vao = createVAO(gl, [\n { buffer: coordinateBuffer,\n size: 4,\n stride: SURFACE_VERTEX_SIZE,\n offset: 0\n },\n { buffer: coordinateBuffer,\n size: 3,\n stride: SURFACE_VERTEX_SIZE,\n offset: 16\n },\n {\n buffer: coordinateBuffer,\n size: 3,\n stride: SURFACE_VERTEX_SIZE,\n offset: 28\n }\n ])\n\n var contourBuffer = createBuffer(gl)\n var contourVAO = createVAO(gl, [\n {\n buffer: contourBuffer,\n size: 4,\n stride: 20,\n offset: 0\n },\n {\n buffer: contourBuffer,\n size: 1,\n stride: 20,\n offset: 16\n }\n ])\n\n var dynamicBuffer = createBuffer(gl)\n var dynamicVAO = createVAO(gl, [\n {\n buffer: dynamicBuffer,\n size: 2,\n type: gl.FLOAT\n }])\n\n var cmap = createTexture(gl, 1, N_COLORS, gl.RGBA, gl.UNSIGNED_BYTE)\n cmap.minFilter = gl.LINEAR\n cmap.magFilter = gl.LINEAR\n\n var surface = new SurfacePlot(\n gl,\n [0, 0], // shape\n [[0, 0, 0], [0, 0, 0]], // bounds\n shader,\n pickShader,\n coordinateBuffer,\n vao,\n cmap,\n contourShader,\n contourPickShader,\n contourBuffer,\n contourVAO,\n dynamicBuffer,\n dynamicVAO,\n [0, 0, 0] // objectOffset\n )\n\n var nparams = {\n levels: [[], [], []]\n }\n for (var id in params) {\n nparams[id] = params[id]\n }\n nparams.colormap = nparams.colormap || 'jet'\n\n surface.update(nparams)\n\n return surface\n}\n\n\n/***/ }),\n\n/***/ 7766:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar ndarray = __webpack_require__(9618)\nvar ops = __webpack_require__(5298)\nvar pool = __webpack_require__(1888)\n\nmodule.exports = createTexture2D\n\nvar linearTypes = null\nvar filterTypes = null\nvar wrapTypes = null\n\nfunction lazyInitLinearTypes(gl) {\n linearTypes = [\n gl.LINEAR,\n gl.NEAREST_MIPMAP_LINEAR,\n gl.LINEAR_MIPMAP_NEAREST,\n gl.LINEAR_MIPMAP_NEAREST\n ]\n filterTypes = [\n gl.NEAREST,\n gl.LINEAR,\n gl.NEAREST_MIPMAP_NEAREST,\n gl.NEAREST_MIPMAP_LINEAR,\n gl.LINEAR_MIPMAP_NEAREST,\n gl.LINEAR_MIPMAP_LINEAR\n ]\n wrapTypes = [\n gl.REPEAT,\n gl.CLAMP_TO_EDGE,\n gl.MIRRORED_REPEAT\n ]\n}\n\nfunction acceptTextureDOM (obj) {\n return (\n ('undefined' != typeof HTMLCanvasElement && obj instanceof HTMLCanvasElement) ||\n ('undefined' != typeof HTMLImageElement && obj instanceof HTMLImageElement) ||\n ('undefined' != typeof HTMLVideoElement && obj instanceof HTMLVideoElement) ||\n ('undefined' != typeof ImageData && obj instanceof ImageData))\n}\n\nvar convertFloatToUint8 = function(out, inp) {\n ops.muls(out, inp, 255.0)\n}\n\nfunction reshapeTexture(tex, w, h) {\n var gl = tex.gl\n var maxSize = gl.getParameter(gl.MAX_TEXTURE_SIZE)\n if(w < 0 || w > maxSize || h < 0 || h > maxSize) {\n throw new Error('gl-texture2d: Invalid texture size')\n }\n tex._shape = [w, h]\n tex.bind()\n gl.texImage2D(gl.TEXTURE_2D, 0, tex.format, w, h, 0, tex.format, tex.type, null)\n tex._mipLevels = [0]\n return tex\n}\n\nfunction Texture2D(gl, handle, width, height, format, type) {\n this.gl = gl\n this.handle = handle\n this.format = format\n this.type = type\n this._shape = [width, height]\n this._mipLevels = [0]\n this._magFilter = gl.NEAREST\n this._minFilter = gl.NEAREST\n this._wrapS = gl.CLAMP_TO_EDGE\n this._wrapT = gl.CLAMP_TO_EDGE\n this._anisoSamples = 1\n\n var parent = this\n var wrapVector = [this._wrapS, this._wrapT]\n Object.defineProperties(wrapVector, [\n {\n get: function() {\n return parent._wrapS\n },\n set: function(v) {\n return parent.wrapS = v\n }\n },\n {\n get: function() {\n return parent._wrapT\n },\n set: function(v) {\n return parent.wrapT = v\n }\n }\n ])\n this._wrapVector = wrapVector\n\n var shapeVector = [this._shape[0], this._shape[1]]\n Object.defineProperties(shapeVector, [\n {\n get: function() {\n return parent._shape[0]\n },\n set: function(v) {\n return parent.width = v\n }\n },\n {\n get: function() {\n return parent._shape[1]\n },\n set: function(v) {\n return parent.height = v\n }\n }\n ])\n this._shapeVector = shapeVector\n}\n\nvar proto = Texture2D.prototype\n\nObject.defineProperties(proto, {\n minFilter: {\n get: function() {\n return this._minFilter\n },\n set: function(v) {\n this.bind()\n var gl = this.gl\n if(this.type === gl.FLOAT && linearTypes.indexOf(v) >= 0) {\n if(!gl.getExtension('OES_texture_float_linear')) {\n v = gl.NEAREST\n }\n }\n if(filterTypes.indexOf(v) < 0) {\n throw new Error('gl-texture2d: Unknown filter mode ' + v)\n }\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, v)\n return this._minFilter = v\n }\n },\n magFilter: {\n get: function() {\n return this._magFilter\n },\n set: function(v) {\n this.bind()\n var gl = this.gl\n if(this.type === gl.FLOAT && linearTypes.indexOf(v) >= 0) {\n if(!gl.getExtension('OES_texture_float_linear')) {\n v = gl.NEAREST\n }\n }\n if(filterTypes.indexOf(v) < 0) {\n throw new Error('gl-texture2d: Unknown filter mode ' + v)\n }\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, v)\n return this._magFilter = v\n }\n },\n mipSamples: {\n get: function() {\n return this._anisoSamples\n },\n set: function(i) {\n var psamples = this._anisoSamples\n this._anisoSamples = Math.max(i, 1)|0\n if(psamples !== this._anisoSamples) {\n var ext = this.gl.getExtension('EXT_texture_filter_anisotropic')\n if(ext) {\n this.gl.texParameterf(this.gl.TEXTURE_2D, ext.TEXTURE_MAX_ANISOTROPY_EXT, this._anisoSamples)\n }\n }\n return this._anisoSamples\n }\n },\n wrapS: {\n get: function() {\n return this._wrapS\n },\n set: function(v) {\n this.bind()\n if(wrapTypes.indexOf(v) < 0) {\n throw new Error('gl-texture2d: Unknown wrap mode ' + v)\n }\n this.gl.texParameteri(this.gl.TEXTURE_2D, this.gl.TEXTURE_WRAP_S, v)\n return this._wrapS = v\n }\n },\n wrapT: {\n get: function() {\n return this._wrapT\n },\n set: function(v) {\n this.bind()\n if(wrapTypes.indexOf(v) < 0) {\n throw new Error('gl-texture2d: Unknown wrap mode ' + v)\n }\n this.gl.texParameteri(this.gl.TEXTURE_2D, this.gl.TEXTURE_WRAP_T, v)\n return this._wrapT = v\n }\n },\n wrap: {\n get: function() {\n return this._wrapVector\n },\n set: function(v) {\n if(!Array.isArray(v)) {\n v = [v,v]\n }\n if(v.length !== 2) {\n throw new Error('gl-texture2d: Must specify wrap mode for rows and columns')\n }\n for(var i=0; i<2; ++i) {\n if(wrapTypes.indexOf(v[i]) < 0) {\n throw new Error('gl-texture2d: Unknown wrap mode ' + v)\n }\n }\n this._wrapS = v[0]\n this._wrapT = v[1]\n\n var gl = this.gl\n this.bind()\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, this._wrapS)\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, this._wrapT)\n\n return v\n }\n },\n shape: {\n get: function() {\n return this._shapeVector\n },\n set: function(x) {\n if(!Array.isArray(x)) {\n x = [x|0,x|0]\n } else {\n if(x.length !== 2) {\n throw new Error('gl-texture2d: Invalid texture shape')\n }\n }\n reshapeTexture(this, x[0]|0, x[1]|0)\n return [x[0]|0, x[1]|0]\n }\n },\n width: {\n get: function() {\n return this._shape[0]\n },\n set: function(w) {\n w = w|0\n reshapeTexture(this, w, this._shape[1])\n return w\n }\n },\n height: {\n get: function() {\n return this._shape[1]\n },\n set: function(h) {\n h = h|0\n reshapeTexture(this, this._shape[0], h)\n return h\n }\n }\n})\n\nproto.bind = function(unit) {\n var gl = this.gl\n if(unit !== undefined) {\n gl.activeTexture(gl.TEXTURE0 + (unit|0))\n }\n gl.bindTexture(gl.TEXTURE_2D, this.handle)\n if(unit !== undefined) {\n return (unit|0)\n }\n return gl.getParameter(gl.ACTIVE_TEXTURE) - gl.TEXTURE0\n}\n\nproto.dispose = function() {\n this.gl.deleteTexture(this.handle)\n}\n\nproto.generateMipmap = function() {\n this.bind()\n this.gl.generateMipmap(this.gl.TEXTURE_2D)\n\n //Update mip levels\n var l = Math.min(this._shape[0], this._shape[1])\n for(var i=0; l>0; ++i, l>>>=1) {\n if(this._mipLevels.indexOf(i) < 0) {\n this._mipLevels.push(i)\n }\n }\n}\n\nproto.setPixels = function(data, x_off, y_off, mip_level) {\n var gl = this.gl\n this.bind()\n if(Array.isArray(x_off)) {\n mip_level = y_off\n y_off = x_off[1]|0\n x_off = x_off[0]|0\n } else {\n x_off = x_off || 0\n y_off = y_off || 0\n }\n mip_level = mip_level || 0\n var directData = acceptTextureDOM(data) ? data : data.raw\n if(directData) {\n var needsMip = this._mipLevels.indexOf(mip_level) < 0\n if(needsMip) {\n gl.texImage2D(gl.TEXTURE_2D, 0, this.format, this.format, this.type, directData)\n this._mipLevels.push(mip_level)\n } else {\n gl.texSubImage2D(gl.TEXTURE_2D, mip_level, x_off, y_off, this.format, this.type, directData)\n }\n } else if(data.shape && data.stride && data.data) {\n if(data.shape.length < 2 ||\n x_off + data.shape[1] > this._shape[1]>>>mip_level ||\n y_off + data.shape[0] > this._shape[0]>>>mip_level ||\n x_off < 0 ||\n y_off < 0) {\n throw new Error('gl-texture2d: Texture dimensions are out of bounds')\n }\n texSubImageArray(gl, x_off, y_off, mip_level, this.format, this.type, this._mipLevels, data)\n } else {\n throw new Error('gl-texture2d: Unsupported data type')\n }\n}\n\n\nfunction isPacked(shape, stride) {\n if(shape.length === 3) {\n return (stride[2] === 1) &&\n (stride[1] === shape[0]*shape[2]) &&\n (stride[0] === shape[2])\n }\n return (stride[0] === 1) &&\n (stride[1] === shape[0])\n}\n\nfunction texSubImageArray(gl, x_off, y_off, mip_level, cformat, ctype, mipLevels, array) {\n var dtype = array.dtype\n var shape = array.shape.slice()\n if(shape.length < 2 || shape.length > 3) {\n throw new Error('gl-texture2d: Invalid ndarray, must be 2d or 3d')\n }\n var type = 0, format = 0\n var packed = isPacked(shape, array.stride.slice())\n if(dtype === 'float32') {\n type = gl.FLOAT\n } else if(dtype === 'float64') {\n type = gl.FLOAT\n packed = false\n dtype = 'float32'\n } else if(dtype === 'uint8') {\n type = gl.UNSIGNED_BYTE\n } else {\n type = gl.UNSIGNED_BYTE\n packed = false\n dtype = 'uint8'\n }\n var channels = 1\n if(shape.length === 2) {\n format = gl.LUMINANCE\n shape = [shape[0], shape[1], 1]\n array = ndarray(array.data, shape, [array.stride[0], array.stride[1], 1], array.offset)\n } else if(shape.length === 3) {\n if(shape[2] === 1) {\n format = gl.ALPHA\n } else if(shape[2] === 2) {\n format = gl.LUMINANCE_ALPHA\n } else if(shape[2] === 3) {\n format = gl.RGB\n } else if(shape[2] === 4) {\n format = gl.RGBA\n } else {\n throw new Error('gl-texture2d: Invalid shape for pixel coords')\n }\n channels = shape[2]\n } else {\n throw new Error('gl-texture2d: Invalid shape for texture')\n }\n //For 1-channel textures allow conversion between formats\n if((format === gl.LUMINANCE || format === gl.ALPHA) &&\n (cformat === gl.LUMINANCE || cformat === gl.ALPHA)) {\n format = cformat\n }\n if(format !== cformat) {\n throw new Error('gl-texture2d: Incompatible texture format for setPixels')\n }\n var size = array.size\n var needsMip = mipLevels.indexOf(mip_level) < 0\n if(needsMip) {\n mipLevels.push(mip_level)\n }\n if(type === ctype && packed) {\n //Array data types are compatible, can directly copy into texture\n if(array.offset === 0 && array.data.length === size) {\n if(needsMip) {\n gl.texImage2D(gl.TEXTURE_2D, mip_level, cformat, shape[0], shape[1], 0, cformat, ctype, array.data)\n } else {\n gl.texSubImage2D(gl.TEXTURE_2D, mip_level, x_off, y_off, shape[0], shape[1], cformat, ctype, array.data)\n }\n } else {\n if(needsMip) {\n gl.texImage2D(gl.TEXTURE_2D, mip_level, cformat, shape[0], shape[1], 0, cformat, ctype, array.data.subarray(array.offset, array.offset+size))\n } else {\n gl.texSubImage2D(gl.TEXTURE_2D, mip_level, x_off, y_off, shape[0], shape[1], cformat, ctype, array.data.subarray(array.offset, array.offset+size))\n }\n }\n } else {\n //Need to do type conversion to pack data into buffer\n var pack_buffer\n if(ctype === gl.FLOAT) {\n pack_buffer = pool.mallocFloat32(size)\n } else {\n pack_buffer = pool.mallocUint8(size)\n }\n var pack_view = ndarray(pack_buffer, shape, [shape[2], shape[2]*shape[0], 1])\n if(type === gl.FLOAT && ctype === gl.UNSIGNED_BYTE) {\n convertFloatToUint8(pack_view, array)\n } else {\n ops.assign(pack_view, array)\n }\n if(needsMip) {\n gl.texImage2D(gl.TEXTURE_2D, mip_level, cformat, shape[0], shape[1], 0, cformat, ctype, pack_buffer.subarray(0, size))\n } else {\n gl.texSubImage2D(gl.TEXTURE_2D, mip_level, x_off, y_off, shape[0], shape[1], cformat, ctype, pack_buffer.subarray(0, size))\n }\n if(ctype === gl.FLOAT) {\n pool.freeFloat32(pack_buffer)\n } else {\n pool.freeUint8(pack_buffer)\n }\n }\n}\n\nfunction initTexture(gl) {\n var tex = gl.createTexture()\n gl.bindTexture(gl.TEXTURE_2D, tex)\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST)\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST)\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE)\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE)\n return tex\n}\n\nfunction createTextureShape(gl, width, height, format, type) {\n var maxTextureSize = gl.getParameter(gl.MAX_TEXTURE_SIZE)\n if(width < 0 || width > maxTextureSize || height < 0 || height > maxTextureSize) {\n throw new Error('gl-texture2d: Invalid texture shape')\n }\n if(type === gl.FLOAT && !gl.getExtension('OES_texture_float')) {\n throw new Error('gl-texture2d: Floating point textures not supported on this platform')\n }\n var tex = initTexture(gl)\n gl.texImage2D(gl.TEXTURE_2D, 0, format, width, height, 0, format, type, null)\n return new Texture2D(gl, tex, width, height, format, type)\n}\n\nfunction createTextureDOM(gl, directData, width, height, format, type) {\n var tex = initTexture(gl)\n gl.texImage2D(gl.TEXTURE_2D, 0, format, format, type, directData)\n return new Texture2D(gl, tex, width, height, format, type)\n}\n\n//Creates a texture from an ndarray\nfunction createTextureArray(gl, array) {\n var dtype = array.dtype\n var shape = array.shape.slice()\n var maxSize = gl.getParameter(gl.MAX_TEXTURE_SIZE)\n if(shape[0] < 0 || shape[0] > maxSize || shape[1] < 0 || shape[1] > maxSize) {\n throw new Error('gl-texture2d: Invalid texture size')\n }\n var packed = isPacked(shape, array.stride.slice())\n var type = 0\n if(dtype === 'float32') {\n type = gl.FLOAT\n } else if(dtype === 'float64') {\n type = gl.FLOAT\n packed = false\n dtype = 'float32'\n } else if(dtype === 'uint8') {\n type = gl.UNSIGNED_BYTE\n } else {\n type = gl.UNSIGNED_BYTE\n packed = false\n dtype = 'uint8'\n }\n var format = 0\n if(shape.length === 2) {\n format = gl.LUMINANCE\n shape = [shape[0], shape[1], 1]\n array = ndarray(array.data, shape, [array.stride[0], array.stride[1], 1], array.offset)\n } else if(shape.length === 3) {\n if(shape[2] === 1) {\n format = gl.ALPHA\n } else if(shape[2] === 2) {\n format = gl.LUMINANCE_ALPHA\n } else if(shape[2] === 3) {\n format = gl.RGB\n } else if(shape[2] === 4) {\n format = gl.RGBA\n } else {\n throw new Error('gl-texture2d: Invalid shape for pixel coords')\n }\n } else {\n throw new Error('gl-texture2d: Invalid shape for texture')\n }\n if(type === gl.FLOAT && !gl.getExtension('OES_texture_float')) {\n type = gl.UNSIGNED_BYTE\n packed = false\n }\n var buffer, buf_store\n var size = array.size\n if(!packed) {\n var stride = [shape[2], shape[2]*shape[0], 1]\n buf_store = pool.malloc(size, dtype)\n var buf_array = ndarray(buf_store, shape, stride, 0)\n if((dtype === 'float32' || dtype === 'float64') && type === gl.UNSIGNED_BYTE) {\n convertFloatToUint8(buf_array, array)\n } else {\n ops.assign(buf_array, array)\n }\n buffer = buf_store.subarray(0, size)\n } else if (array.offset === 0 && array.data.length === size) {\n buffer = array.data\n } else {\n buffer = array.data.subarray(array.offset, array.offset + size)\n }\n var tex = initTexture(gl)\n gl.texImage2D(gl.TEXTURE_2D, 0, format, shape[0], shape[1], 0, format, type, buffer)\n if(!packed) {\n pool.free(buf_store)\n }\n return new Texture2D(gl, tex, shape[0], shape[1], format, type)\n}\n\nfunction createTexture2D(gl) {\n if(arguments.length <= 1) {\n throw new Error('gl-texture2d: Missing arguments for texture2d constructor')\n }\n if(!linearTypes) {\n lazyInitLinearTypes(gl)\n }\n if(typeof arguments[1] === 'number') {\n return createTextureShape(gl, arguments[1], arguments[2], arguments[3]||gl.RGBA, arguments[4]||gl.UNSIGNED_BYTE)\n }\n if(Array.isArray(arguments[1])) {\n return createTextureShape(gl, arguments[1][0]|0, arguments[1][1]|0, arguments[2]||gl.RGBA, arguments[3]||gl.UNSIGNED_BYTE)\n }\n if(typeof arguments[1] === 'object') {\n var obj = arguments[1]\n var directData = acceptTextureDOM(obj) ? obj : obj.raw\n if (directData) {\n return createTextureDOM(gl, directData, obj.width|0, obj.height|0, arguments[2]||gl.RGBA, arguments[3]||gl.UNSIGNED_BYTE)\n } else if(obj.shape && obj.data && obj.stride) {\n return createTextureArray(gl, obj)\n }\n }\n throw new Error('gl-texture2d: Invalid arguments for texture2d constructor')\n}\n\n\n/***/ }),\n\n/***/ 1433:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nfunction doBind(gl, elements, attributes) {\n if(elements) {\n elements.bind()\n } else {\n gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, null)\n }\n var nattribs = gl.getParameter(gl.MAX_VERTEX_ATTRIBS)|0\n if(attributes) {\n if(attributes.length > nattribs) {\n throw new Error(\"gl-vao: Too many vertex attributes\")\n }\n for(var i=0; i 1.0){\n return 0\n } else {\n return Math.acos(cosine)\n } \n}\n\n\n/***/ }),\n\n/***/ 9226:\n/***/ (function(module) {\n\nmodule.exports = ceil\n\n/**\n * Math.ceil the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to ceil\n * @returns {vec3} out\n */\nfunction ceil(out, a) {\n out[0] = Math.ceil(a[0])\n out[1] = Math.ceil(a[1])\n out[2] = Math.ceil(a[2])\n return out\n}\n\n\n/***/ }),\n\n/***/ 3126:\n/***/ (function(module) {\n\nmodule.exports = clone;\n\n/**\n * Creates a new vec3 initialized with values from an existing vector\n *\n * @param {vec3} a vector to clone\n * @returns {vec3} a new 3D vector\n */\nfunction clone(a) {\n var out = new Float32Array(3)\n out[0] = a[0]\n out[1] = a[1]\n out[2] = a[2]\n return out\n}\n\n/***/ }),\n\n/***/ 3990:\n/***/ (function(module) {\n\nmodule.exports = copy;\n\n/**\n * Copy the values from one vec3 to another\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the source vector\n * @returns {vec3} out\n */\nfunction copy(out, a) {\n out[0] = a[0]\n out[1] = a[1]\n out[2] = a[2]\n return out\n}\n\n/***/ }),\n\n/***/ 1091:\n/***/ (function(module) {\n\nmodule.exports = create;\n\n/**\n * Creates a new, empty vec3\n *\n * @returns {vec3} a new 3D vector\n */\nfunction create() {\n var out = new Float32Array(3)\n out[0] = 0\n out[1] = 0\n out[2] = 0\n return out\n}\n\n/***/ }),\n\n/***/ 5911:\n/***/ (function(module) {\n\nmodule.exports = cross;\n\n/**\n * Computes the cross product of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nfunction cross(out, a, b) {\n var ax = a[0], ay = a[1], az = a[2],\n bx = b[0], by = b[1], bz = b[2]\n\n out[0] = ay * bz - az * by\n out[1] = az * bx - ax * bz\n out[2] = ax * by - ay * bx\n return out\n}\n\n/***/ }),\n\n/***/ 5455:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(7056)\n\n\n/***/ }),\n\n/***/ 7056:\n/***/ (function(module) {\n\nmodule.exports = distance;\n\n/**\n * Calculates the euclidian distance between two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} distance between a and b\n */\nfunction distance(a, b) {\n var x = b[0] - a[0],\n y = b[1] - a[1],\n z = b[2] - a[2]\n return Math.sqrt(x*x + y*y + z*z)\n}\n\n/***/ }),\n\n/***/ 4008:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(6690)\n\n\n/***/ }),\n\n/***/ 6690:\n/***/ (function(module) {\n\nmodule.exports = divide;\n\n/**\n * Divides two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nfunction divide(out, a, b) {\n out[0] = a[0] / b[0]\n out[1] = a[1] / b[1]\n out[2] = a[2] / b[2]\n return out\n}\n\n/***/ }),\n\n/***/ 244:\n/***/ (function(module) {\n\nmodule.exports = dot;\n\n/**\n * Calculates the dot product of two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} dot product of a and b\n */\nfunction dot(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2]\n}\n\n/***/ }),\n\n/***/ 2613:\n/***/ (function(module) {\n\nmodule.exports = 0.000001\n\n\n/***/ }),\n\n/***/ 9922:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports = equals\n\nvar EPSILON = __webpack_require__(2613)\n\n/**\n * Returns whether or not the vectors have approximately the same elements in the same position.\n *\n * @param {vec3} a The first vector.\n * @param {vec3} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\nfunction equals(a, b) {\n var a0 = a[0]\n var a1 = a[1]\n var a2 = a[2]\n var b0 = b[0]\n var b1 = b[1]\n var b2 = b[2]\n return (Math.abs(a0 - b0) <= EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) &&\n Math.abs(a1 - b1) <= EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) &&\n Math.abs(a2 - b2) <= EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)))\n}\n\n\n/***/ }),\n\n/***/ 9265:\n/***/ (function(module) {\n\nmodule.exports = exactEquals\n\n/**\n * Returns whether or not the vectors exactly have the same elements in the same position (when compared with ===)\n *\n * @param {vec3} a The first vector.\n * @param {vec3} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\nfunction exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2]\n}\n\n\n/***/ }),\n\n/***/ 2681:\n/***/ (function(module) {\n\nmodule.exports = floor\n\n/**\n * Math.floor the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to floor\n * @returns {vec3} out\n */\nfunction floor(out, a) {\n out[0] = Math.floor(a[0])\n out[1] = Math.floor(a[1])\n out[2] = Math.floor(a[2])\n return out\n}\n\n\n/***/ }),\n\n/***/ 5137:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports = forEach;\n\nvar vec = __webpack_require__(1091)()\n\n/**\n * Perform some operation over an array of vec3s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec3. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec3s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nfunction forEach(a, stride, offset, count, fn, arg) {\n var i, l\n if(!stride) {\n stride = 3\n }\n\n if(!offset) {\n offset = 0\n }\n \n if(count) {\n l = Math.min((count * stride) + offset, a.length)\n } else {\n l = a.length\n }\n\n for(i = offset; i < l; i += stride) {\n vec[0] = a[i] \n vec[1] = a[i+1] \n vec[2] = a[i+2]\n fn(vec, vec, arg)\n a[i] = vec[0] \n a[i+1] = vec[1] \n a[i+2] = vec[2]\n }\n \n return a\n}\n\n/***/ }),\n\n/***/ 2825:\n/***/ (function(module) {\n\nmodule.exports = fromValues;\n\n/**\n * Creates a new vec3 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} a new 3D vector\n */\nfunction fromValues(x, y, z) {\n var out = new Float32Array(3)\n out[0] = x\n out[1] = y\n out[2] = z\n return out\n}\n\n/***/ }),\n\n/***/ 2931:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports = {\n EPSILON: __webpack_require__(2613)\n , create: __webpack_require__(1091)\n , clone: __webpack_require__(3126)\n , angle: __webpack_require__(8192)\n , fromValues: __webpack_require__(2825)\n , copy: __webpack_require__(3990)\n , set: __webpack_require__(1463)\n , equals: __webpack_require__(9922)\n , exactEquals: __webpack_require__(9265)\n , add: __webpack_require__(5632)\n , subtract: __webpack_require__(6843)\n , sub: __webpack_require__(2229)\n , multiply: __webpack_require__(5847)\n , mul: __webpack_require__(4505)\n , divide: __webpack_require__(6690)\n , div: __webpack_require__(4008)\n , min: __webpack_require__(8107)\n , max: __webpack_require__(7417)\n , floor: __webpack_require__(2681)\n , ceil: __webpack_require__(9226)\n , round: __webpack_require__(2447)\n , scale: __webpack_require__(6621)\n , scaleAndAdd: __webpack_require__(8489)\n , distance: __webpack_require__(7056)\n , dist: __webpack_require__(5455)\n , squaredDistance: __webpack_require__(2953)\n , sqrDist: __webpack_require__(6141)\n , length: __webpack_require__(1387)\n , len: __webpack_require__(868)\n , squaredLength: __webpack_require__(3066)\n , sqrLen: __webpack_require__(5486)\n , negate: __webpack_require__(5093)\n , inverse: __webpack_require__(811)\n , normalize: __webpack_require__(3536)\n , dot: __webpack_require__(244)\n , cross: __webpack_require__(5911)\n , lerp: __webpack_require__(6658)\n , random: __webpack_require__(7636)\n , transformMat4: __webpack_require__(5673)\n , transformMat3: __webpack_require__(492)\n , transformQuat: __webpack_require__(264)\n , rotateX: __webpack_require__(6894)\n , rotateY: __webpack_require__(109)\n , rotateZ: __webpack_require__(8692)\n , forEach: __webpack_require__(5137)\n}\n\n\n/***/ }),\n\n/***/ 811:\n/***/ (function(module) {\n\nmodule.exports = inverse;\n\n/**\n * Returns the inverse of the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to invert\n * @returns {vec3} out\n */\nfunction inverse(out, a) {\n out[0] = 1.0 / a[0]\n out[1] = 1.0 / a[1]\n out[2] = 1.0 / a[2]\n return out\n}\n\n/***/ }),\n\n/***/ 868:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(1387)\n\n\n/***/ }),\n\n/***/ 1387:\n/***/ (function(module) {\n\nmodule.exports = length;\n\n/**\n * Calculates the length of a vec3\n *\n * @param {vec3} a vector to calculate length of\n * @returns {Number} length of a\n */\nfunction length(a) {\n var x = a[0],\n y = a[1],\n z = a[2]\n return Math.sqrt(x*x + y*y + z*z)\n}\n\n/***/ }),\n\n/***/ 6658:\n/***/ (function(module) {\n\nmodule.exports = lerp;\n\n/**\n * Performs a linear interpolation between two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec3} out\n */\nfunction lerp(out, a, b, t) {\n var ax = a[0],\n ay = a[1],\n az = a[2]\n out[0] = ax + t * (b[0] - ax)\n out[1] = ay + t * (b[1] - ay)\n out[2] = az + t * (b[2] - az)\n return out\n}\n\n/***/ }),\n\n/***/ 7417:\n/***/ (function(module) {\n\nmodule.exports = max;\n\n/**\n * Returns the maximum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nfunction max(out, a, b) {\n out[0] = Math.max(a[0], b[0])\n out[1] = Math.max(a[1], b[1])\n out[2] = Math.max(a[2], b[2])\n return out\n}\n\n/***/ }),\n\n/***/ 8107:\n/***/ (function(module) {\n\nmodule.exports = min;\n\n/**\n * Returns the minimum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nfunction min(out, a, b) {\n out[0] = Math.min(a[0], b[0])\n out[1] = Math.min(a[1], b[1])\n out[2] = Math.min(a[2], b[2])\n return out\n}\n\n/***/ }),\n\n/***/ 4505:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(5847)\n\n\n/***/ }),\n\n/***/ 5847:\n/***/ (function(module) {\n\nmodule.exports = multiply;\n\n/**\n * Multiplies two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nfunction multiply(out, a, b) {\n out[0] = a[0] * b[0]\n out[1] = a[1] * b[1]\n out[2] = a[2] * b[2]\n return out\n}\n\n/***/ }),\n\n/***/ 5093:\n/***/ (function(module) {\n\nmodule.exports = negate;\n\n/**\n * Negates the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to negate\n * @returns {vec3} out\n */\nfunction negate(out, a) {\n out[0] = -a[0]\n out[1] = -a[1]\n out[2] = -a[2]\n return out\n}\n\n/***/ }),\n\n/***/ 3536:\n/***/ (function(module) {\n\nmodule.exports = normalize;\n\n/**\n * Normalize a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to normalize\n * @returns {vec3} out\n */\nfunction normalize(out, a) {\n var x = a[0],\n y = a[1],\n z = a[2]\n var len = x*x + y*y + z*z\n if (len > 0) {\n //TODO: evaluate use of glm_invsqrt here?\n len = 1 / Math.sqrt(len)\n out[0] = a[0] * len\n out[1] = a[1] * len\n out[2] = a[2] * len\n }\n return out\n}\n\n/***/ }),\n\n/***/ 7636:\n/***/ (function(module) {\n\nmodule.exports = random;\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec3} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec3} out\n */\nfunction random(out, scale) {\n scale = scale || 1.0\n\n var r = Math.random() * 2.0 * Math.PI\n var z = (Math.random() * 2.0) - 1.0\n var zScale = Math.sqrt(1.0-z*z) * scale\n\n out[0] = Math.cos(r) * zScale\n out[1] = Math.sin(r) * zScale\n out[2] = z * scale\n return out\n}\n\n/***/ }),\n\n/***/ 6894:\n/***/ (function(module) {\n\nmodule.exports = rotateX;\n\n/**\n * Rotate a 3D vector around the x-axis\n * @param {vec3} out The receiving vec3\n * @param {vec3} a The vec3 point to rotate\n * @param {vec3} b The origin of the rotation\n * @param {Number} c The angle of rotation\n * @returns {vec3} out\n */\nfunction rotateX(out, a, b, c){\n var by = b[1]\n var bz = b[2]\n\n // Translate point to the origin\n var py = a[1] - by\n var pz = a[2] - bz\n\n var sc = Math.sin(c)\n var cc = Math.cos(c)\n\n // perform rotation and translate to correct position\n out[0] = a[0]\n out[1] = by + py * cc - pz * sc\n out[2] = bz + py * sc + pz * cc\n\n return out\n}\n\n\n/***/ }),\n\n/***/ 109:\n/***/ (function(module) {\n\nmodule.exports = rotateY;\n\n/**\n * Rotate a 3D vector around the y-axis\n * @param {vec3} out The receiving vec3\n * @param {vec3} a The vec3 point to rotate\n * @param {vec3} b The origin of the rotation\n * @param {Number} c The angle of rotation\n * @returns {vec3} out\n */\nfunction rotateY(out, a, b, c){\n var bx = b[0]\n var bz = b[2]\n\n // translate point to the origin\n var px = a[0] - bx\n var pz = a[2] - bz\n \n var sc = Math.sin(c)\n var cc = Math.cos(c)\n \n // perform rotation and translate to correct position\n out[0] = bx + pz * sc + px * cc\n out[1] = a[1]\n out[2] = bz + pz * cc - px * sc\n \n return out\n}\n\n\n/***/ }),\n\n/***/ 8692:\n/***/ (function(module) {\n\nmodule.exports = rotateZ;\n\n/**\n * Rotate a 3D vector around the z-axis\n * @param {vec3} out The receiving vec3\n * @param {vec3} a The vec3 point to rotate\n * @param {vec3} b The origin of the rotation\n * @param {Number} c The angle of rotation\n * @returns {vec3} out\n */\nfunction rotateZ(out, a, b, c){\n var bx = b[0]\n var by = b[1]\n\n //Translate point to the origin\n var px = a[0] - bx\n var py = a[1] - by\n \n var sc = Math.sin(c)\n var cc = Math.cos(c)\n\n // perform rotation and translate to correct position\n out[0] = bx + px * cc - py * sc\n out[1] = by + px * sc + py * cc\n out[2] = a[2]\n \n return out\n}\n\n\n/***/ }),\n\n/***/ 2447:\n/***/ (function(module) {\n\nmodule.exports = round\n\n/**\n * Math.round the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to round\n * @returns {vec3} out\n */\nfunction round(out, a) {\n out[0] = Math.round(a[0])\n out[1] = Math.round(a[1])\n out[2] = Math.round(a[2])\n return out\n}\n\n\n/***/ }),\n\n/***/ 6621:\n/***/ (function(module) {\n\nmodule.exports = scale;\n\n/**\n * Scales a vec3 by a scalar number\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec3} out\n */\nfunction scale(out, a, b) {\n out[0] = a[0] * b\n out[1] = a[1] * b\n out[2] = a[2] * b\n return out\n}\n\n/***/ }),\n\n/***/ 8489:\n/***/ (function(module) {\n\nmodule.exports = scaleAndAdd;\n\n/**\n * Adds two vec3's after scaling the second operand by a scalar value\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec3} out\n */\nfunction scaleAndAdd(out, a, b, scale) {\n out[0] = a[0] + (b[0] * scale)\n out[1] = a[1] + (b[1] * scale)\n out[2] = a[2] + (b[2] * scale)\n return out\n}\n\n/***/ }),\n\n/***/ 1463:\n/***/ (function(module) {\n\nmodule.exports = set;\n\n/**\n * Set the components of a vec3 to the given values\n *\n * @param {vec3} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} out\n */\nfunction set(out, x, y, z) {\n out[0] = x\n out[1] = y\n out[2] = z\n return out\n}\n\n/***/ }),\n\n/***/ 6141:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(2953)\n\n\n/***/ }),\n\n/***/ 5486:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(3066)\n\n\n/***/ }),\n\n/***/ 2953:\n/***/ (function(module) {\n\nmodule.exports = squaredDistance;\n\n/**\n * Calculates the squared euclidian distance between two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} squared distance between a and b\n */\nfunction squaredDistance(a, b) {\n var x = b[0] - a[0],\n y = b[1] - a[1],\n z = b[2] - a[2]\n return x*x + y*y + z*z\n}\n\n/***/ }),\n\n/***/ 3066:\n/***/ (function(module) {\n\nmodule.exports = squaredLength;\n\n/**\n * Calculates the squared length of a vec3\n *\n * @param {vec3} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nfunction squaredLength(a) {\n var x = a[0],\n y = a[1],\n z = a[2]\n return x*x + y*y + z*z\n}\n\n/***/ }),\n\n/***/ 2229:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(6843)\n\n\n/***/ }),\n\n/***/ 6843:\n/***/ (function(module) {\n\nmodule.exports = subtract;\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nfunction subtract(out, a, b) {\n out[0] = a[0] - b[0]\n out[1] = a[1] - b[1]\n out[2] = a[2] - b[2]\n return out\n}\n\n/***/ }),\n\n/***/ 492:\n/***/ (function(module) {\n\nmodule.exports = transformMat3;\n\n/**\n * Transforms the vec3 with a mat3.\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {mat4} m the 3x3 matrix to transform with\n * @returns {vec3} out\n */\nfunction transformMat3(out, a, m) {\n var x = a[0], y = a[1], z = a[2]\n out[0] = x * m[0] + y * m[3] + z * m[6]\n out[1] = x * m[1] + y * m[4] + z * m[7]\n out[2] = x * m[2] + y * m[5] + z * m[8]\n return out\n}\n\n/***/ }),\n\n/***/ 5673:\n/***/ (function(module) {\n\nmodule.exports = transformMat4;\n\n/**\n * Transforms the vec3 with a mat4.\n * 4th vector component is implicitly '1'\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec3} out\n */\nfunction transformMat4(out, a, m) {\n var x = a[0], y = a[1], z = a[2],\n w = m[3] * x + m[7] * y + m[11] * z + m[15]\n w = w || 1.0\n out[0] = (m[0] * x + m[4] * y + m[8] * z + m[12]) / w\n out[1] = (m[1] * x + m[5] * y + m[9] * z + m[13]) / w\n out[2] = (m[2] * x + m[6] * y + m[10] * z + m[14]) / w\n return out\n}\n\n/***/ }),\n\n/***/ 264:\n/***/ (function(module) {\n\nmodule.exports = transformQuat;\n\n/**\n * Transforms the vec3 with a quat\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {quat} q quaternion to transform with\n * @returns {vec3} out\n */\nfunction transformQuat(out, a, q) {\n // benchmarks: http://jsperf.com/quaternion-transform-vec3-implementations\n\n var x = a[0], y = a[1], z = a[2],\n qx = q[0], qy = q[1], qz = q[2], qw = q[3],\n\n // calculate quat * vec\n ix = qw * x + qy * z - qz * y,\n iy = qw * y + qz * x - qx * z,\n iz = qw * z + qx * y - qy * x,\n iw = -qx * x - qy * y - qz * z\n\n // calculate result * inverse quat\n out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy\n out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz\n out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx\n return out\n}\n\n/***/ }),\n\n/***/ 4361:\n/***/ (function(module) {\n\nmodule.exports = add\n\n/**\n * Adds two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nfunction add (out, a, b) {\n out[0] = a[0] + b[0]\n out[1] = a[1] + b[1]\n out[2] = a[2] + b[2]\n out[3] = a[3] + b[3]\n return out\n}\n\n\n/***/ }),\n\n/***/ 2335:\n/***/ (function(module) {\n\nmodule.exports = clone\n\n/**\n * Creates a new vec4 initialized with values from an existing vector\n *\n * @param {vec4} a vector to clone\n * @returns {vec4} a new 4D vector\n */\nfunction clone (a) {\n var out = new Float32Array(4)\n out[0] = a[0]\n out[1] = a[1]\n out[2] = a[2]\n out[3] = a[3]\n return out\n}\n\n\n/***/ }),\n\n/***/ 2933:\n/***/ (function(module) {\n\nmodule.exports = copy\n\n/**\n * Copy the values from one vec4 to another\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the source vector\n * @returns {vec4} out\n */\nfunction copy (out, a) {\n out[0] = a[0]\n out[1] = a[1]\n out[2] = a[2]\n out[3] = a[3]\n return out\n}\n\n\n/***/ }),\n\n/***/ 7536:\n/***/ (function(module) {\n\nmodule.exports = create\n\n/**\n * Creates a new, empty vec4\n *\n * @returns {vec4} a new 4D vector\n */\nfunction create () {\n var out = new Float32Array(4)\n out[0] = 0\n out[1] = 0\n out[2] = 0\n out[3] = 0\n return out\n}\n\n\n/***/ }),\n\n/***/ 4691:\n/***/ (function(module) {\n\nmodule.exports = distance\n\n/**\n * Calculates the euclidian distance between two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} distance between a and b\n */\nfunction distance (a, b) {\n var x = b[0] - a[0],\n y = b[1] - a[1],\n z = b[2] - a[2],\n w = b[3] - a[3]\n return Math.sqrt(x * x + y * y + z * z + w * w)\n}\n\n\n/***/ }),\n\n/***/ 1373:\n/***/ (function(module) {\n\nmodule.exports = divide\n\n/**\n * Divides two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nfunction divide (out, a, b) {\n out[0] = a[0] / b[0]\n out[1] = a[1] / b[1]\n out[2] = a[2] / b[2]\n out[3] = a[3] / b[3]\n return out\n}\n\n\n/***/ }),\n\n/***/ 3750:\n/***/ (function(module) {\n\nmodule.exports = dot\n\n/**\n * Calculates the dot product of two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} dot product of a and b\n */\nfunction dot (a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3]\n}\n\n\n/***/ }),\n\n/***/ 3390:\n/***/ (function(module) {\n\nmodule.exports = fromValues\n\n/**\n * Creates a new vec4 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} a new 4D vector\n */\nfunction fromValues (x, y, z, w) {\n var out = new Float32Array(4)\n out[0] = x\n out[1] = y\n out[2] = z\n out[3] = w\n return out\n}\n\n\n/***/ }),\n\n/***/ 9970:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports = {\n create: __webpack_require__(7536),\n clone: __webpack_require__(2335),\n fromValues: __webpack_require__(3390),\n copy: __webpack_require__(2933),\n set: __webpack_require__(4578),\n add: __webpack_require__(4361),\n subtract: __webpack_require__(6860),\n multiply: __webpack_require__(3576),\n divide: __webpack_require__(1373),\n min: __webpack_require__(2334),\n max: __webpack_require__(160),\n scale: __webpack_require__(9288),\n scaleAndAdd: __webpack_require__(4844),\n distance: __webpack_require__(4691),\n squaredDistance: __webpack_require__(7960),\n length: __webpack_require__(6808),\n squaredLength: __webpack_require__(483),\n negate: __webpack_require__(1498),\n inverse: __webpack_require__(4494),\n normalize: __webpack_require__(5177),\n dot: __webpack_require__(3750),\n lerp: __webpack_require__(2573),\n random: __webpack_require__(9131),\n transformMat4: __webpack_require__(5352),\n transformQuat: __webpack_require__(4041)\n}\n\n\n/***/ }),\n\n/***/ 4494:\n/***/ (function(module) {\n\nmodule.exports = inverse\n\n/**\n * Returns the inverse of the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to invert\n * @returns {vec4} out\n */\nfunction inverse (out, a) {\n out[0] = 1.0 / a[0]\n out[1] = 1.0 / a[1]\n out[2] = 1.0 / a[2]\n out[3] = 1.0 / a[3]\n return out\n}\n\n\n/***/ }),\n\n/***/ 6808:\n/***/ (function(module) {\n\nmodule.exports = length\n\n/**\n * Calculates the length of a vec4\n *\n * @param {vec4} a vector to calculate length of\n * @returns {Number} length of a\n */\nfunction length (a) {\n var x = a[0],\n y = a[1],\n z = a[2],\n w = a[3]\n return Math.sqrt(x * x + y * y + z * z + w * w)\n}\n\n\n/***/ }),\n\n/***/ 2573:\n/***/ (function(module) {\n\nmodule.exports = lerp\n\n/**\n * Performs a linear interpolation between two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec4} out\n */\nfunction lerp (out, a, b, t) {\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3]\n out[0] = ax + t * (b[0] - ax)\n out[1] = ay + t * (b[1] - ay)\n out[2] = az + t * (b[2] - az)\n out[3] = aw + t * (b[3] - aw)\n return out\n}\n\n\n/***/ }),\n\n/***/ 160:\n/***/ (function(module) {\n\nmodule.exports = max\n\n/**\n * Returns the maximum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nfunction max (out, a, b) {\n out[0] = Math.max(a[0], b[0])\n out[1] = Math.max(a[1], b[1])\n out[2] = Math.max(a[2], b[2])\n out[3] = Math.max(a[3], b[3])\n return out\n}\n\n\n/***/ }),\n\n/***/ 2334:\n/***/ (function(module) {\n\nmodule.exports = min\n\n/**\n * Returns the minimum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nfunction min (out, a, b) {\n out[0] = Math.min(a[0], b[0])\n out[1] = Math.min(a[1], b[1])\n out[2] = Math.min(a[2], b[2])\n out[3] = Math.min(a[3], b[3])\n return out\n}\n\n\n/***/ }),\n\n/***/ 3576:\n/***/ (function(module) {\n\nmodule.exports = multiply\n\n/**\n * Multiplies two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nfunction multiply (out, a, b) {\n out[0] = a[0] * b[0]\n out[1] = a[1] * b[1]\n out[2] = a[2] * b[2]\n out[3] = a[3] * b[3]\n return out\n}\n\n\n/***/ }),\n\n/***/ 1498:\n/***/ (function(module) {\n\nmodule.exports = negate\n\n/**\n * Negates the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to negate\n * @returns {vec4} out\n */\nfunction negate (out, a) {\n out[0] = -a[0]\n out[1] = -a[1]\n out[2] = -a[2]\n out[3] = -a[3]\n return out\n}\n\n\n/***/ }),\n\n/***/ 5177:\n/***/ (function(module) {\n\nmodule.exports = normalize\n\n/**\n * Normalize a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to normalize\n * @returns {vec4} out\n */\nfunction normalize (out, a) {\n var x = a[0],\n y = a[1],\n z = a[2],\n w = a[3]\n var len = x * x + y * y + z * z + w * w\n if (len > 0) {\n len = 1 / Math.sqrt(len)\n out[0] = x * len\n out[1] = y * len\n out[2] = z * len\n out[3] = w * len\n }\n return out\n}\n\n\n/***/ }),\n\n/***/ 9131:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar vecNormalize = __webpack_require__(5177)\nvar vecScale = __webpack_require__(9288)\n\nmodule.exports = random\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec4} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec4} out\n */\nfunction random (out, scale) {\n scale = scale || 1.0\n\n // TODO: This is a pretty awful way of doing this. Find something better.\n out[0] = Math.random()\n out[1] = Math.random()\n out[2] = Math.random()\n out[3] = Math.random()\n vecNormalize(out, out)\n vecScale(out, out, scale)\n return out\n}\n\n\n/***/ }),\n\n/***/ 9288:\n/***/ (function(module) {\n\nmodule.exports = scale\n\n/**\n * Scales a vec4 by a scalar number\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec4} out\n */\nfunction scale (out, a, b) {\n out[0] = a[0] * b\n out[1] = a[1] * b\n out[2] = a[2] * b\n out[3] = a[3] * b\n return out\n}\n\n\n/***/ }),\n\n/***/ 4844:\n/***/ (function(module) {\n\nmodule.exports = scaleAndAdd\n\n/**\n * Adds two vec4's after scaling the second operand by a scalar value\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec4} out\n */\nfunction scaleAndAdd (out, a, b, scale) {\n out[0] = a[0] + (b[0] * scale)\n out[1] = a[1] + (b[1] * scale)\n out[2] = a[2] + (b[2] * scale)\n out[3] = a[3] + (b[3] * scale)\n return out\n}\n\n\n/***/ }),\n\n/***/ 4578:\n/***/ (function(module) {\n\nmodule.exports = set\n\n/**\n * Set the components of a vec4 to the given values\n *\n * @param {vec4} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} out\n */\nfunction set (out, x, y, z, w) {\n out[0] = x\n out[1] = y\n out[2] = z\n out[3] = w\n return out\n}\n\n\n/***/ }),\n\n/***/ 7960:\n/***/ (function(module) {\n\nmodule.exports = squaredDistance\n\n/**\n * Calculates the squared euclidian distance between two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} squared distance between a and b\n */\nfunction squaredDistance (a, b) {\n var x = b[0] - a[0],\n y = b[1] - a[1],\n z = b[2] - a[2],\n w = b[3] - a[3]\n return x * x + y * y + z * z + w * w\n}\n\n\n/***/ }),\n\n/***/ 483:\n/***/ (function(module) {\n\nmodule.exports = squaredLength\n\n/**\n * Calculates the squared length of a vec4\n *\n * @param {vec4} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nfunction squaredLength (a) {\n var x = a[0],\n y = a[1],\n z = a[2],\n w = a[3]\n return x * x + y * y + z * z + w * w\n}\n\n\n/***/ }),\n\n/***/ 6860:\n/***/ (function(module) {\n\nmodule.exports = subtract\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nfunction subtract (out, a, b) {\n out[0] = a[0] - b[0]\n out[1] = a[1] - b[1]\n out[2] = a[2] - b[2]\n out[3] = a[3] - b[3]\n return out\n}\n\n\n/***/ }),\n\n/***/ 5352:\n/***/ (function(module) {\n\nmodule.exports = transformMat4\n\n/**\n * Transforms the vec4 with a mat4.\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec4} out\n */\nfunction transformMat4 (out, a, m) {\n var x = a[0], y = a[1], z = a[2], w = a[3]\n out[0] = m[0] * x + m[4] * y + m[8] * z + m[12] * w\n out[1] = m[1] * x + m[5] * y + m[9] * z + m[13] * w\n out[2] = m[2] * x + m[6] * y + m[10] * z + m[14] * w\n out[3] = m[3] * x + m[7] * y + m[11] * z + m[15] * w\n return out\n}\n\n\n/***/ }),\n\n/***/ 4041:\n/***/ (function(module) {\n\nmodule.exports = transformQuat\n\n/**\n * Transforms the vec4 with a quat\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to transform\n * @param {quat} q quaternion to transform with\n * @returns {vec4} out\n */\nfunction transformQuat (out, a, q) {\n var x = a[0], y = a[1], z = a[2],\n qx = q[0], qy = q[1], qz = q[2], qw = q[3],\n\n // calculate quat * vec\n ix = qw * x + qy * z - qz * y,\n iy = qw * y + qz * x - qx * z,\n iz = qw * z + qx * y - qy * x,\n iw = -qx * x - qy * y - qz * z\n\n // calculate result * inverse quat\n out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy\n out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz\n out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx\n out[3] = a[3]\n return out\n}\n\n\n/***/ }),\n\n/***/ 1848:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar tokenize = __webpack_require__(4905)\nvar atob = __webpack_require__(6468)\n\nmodule.exports = getName\n\nfunction getName(src) {\n var tokens = Array.isArray(src)\n ? src\n : tokenize(src)\n\n for (var i = 0; i < tokens.length; i++) {\n var token = tokens[i]\n if (token.type !== 'preprocessor') continue\n var match = token.data.match(/\\#define\\s+SHADER_NAME(_B64)?\\s+(.+)$/)\n if (!match) continue\n if (!match[2]) continue\n\n var b64 = match[1]\n var name = match[2]\n\n return (b64 ? atob(name) : name).trim()\n }\n}\n\n\n/***/ }),\n\n/***/ 5874:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports = tokenize\r\n\r\nvar literals100 = __webpack_require__(620)\r\n , operators = __webpack_require__(7827)\r\n , builtins100 = __webpack_require__(6852)\r\n , literals300es = __webpack_require__(7932)\r\n , builtins300es = __webpack_require__(3508)\r\n\r\nvar NORMAL = 999 // <-- never emitted\r\n , TOKEN = 9999 // <-- never emitted\r\n , BLOCK_COMMENT = 0\r\n , LINE_COMMENT = 1\r\n , PREPROCESSOR = 2\r\n , OPERATOR = 3\r\n , INTEGER = 4\r\n , FLOAT = 5\r\n , IDENT = 6\r\n , BUILTIN = 7\r\n , KEYWORD = 8\r\n , WHITESPACE = 9\r\n , EOF = 10\r\n , HEX = 11\r\n\r\nvar map = [\r\n 'block-comment'\r\n , 'line-comment'\r\n , 'preprocessor'\r\n , 'operator'\r\n , 'integer'\r\n , 'float'\r\n , 'ident'\r\n , 'builtin'\r\n , 'keyword'\r\n , 'whitespace'\r\n , 'eof'\r\n , 'integer'\r\n]\r\n\r\nfunction tokenize(opt) {\r\n var i = 0\r\n , total = 0\r\n , mode = NORMAL\r\n , c\r\n , last\r\n , content = []\r\n , tokens = []\r\n , token_idx = 0\r\n , token_offs = 0\r\n , line = 1\r\n , col = 0\r\n , start = 0\r\n , isnum = false\r\n , isoperator = false\r\n , input = ''\r\n , len\r\n\r\n opt = opt || {}\r\n var allBuiltins = builtins100\r\n var allLiterals = literals100\r\n if (opt.version === '300 es') {\r\n allBuiltins = builtins300es\r\n allLiterals = literals300es\r\n }\r\n\r\n // cache by name\r\n var builtinsDict = {}, literalsDict = {}\r\n for (var i = 0; i < allBuiltins.length; i++) {\r\n builtinsDict[allBuiltins[i]] = true\r\n }\r\n for (var i = 0; i < allLiterals.length; i++) {\r\n literalsDict[allLiterals[i]] = true\r\n }\r\n\r\n return function(data) {\r\n tokens = []\r\n if (data !== null) return write(data)\r\n return end()\r\n }\r\n\r\n function token(data) {\r\n if (data.length) {\r\n tokens.push({\r\n type: map[mode]\r\n , data: data\r\n , position: start\r\n , line: line\r\n , column: col\r\n })\r\n }\r\n }\r\n\r\n function write(chunk) {\r\n i = 0\r\n\r\n if (chunk.toString) chunk = chunk.toString()\r\n\r\n input += chunk.replace(/\\r\\n/g, '\\n')\r\n len = input.length\r\n\r\n\r\n var last\r\n\r\n while(c = input[i], i < len) {\r\n last = i\r\n\r\n switch(mode) {\r\n case BLOCK_COMMENT: i = block_comment(); break\r\n case LINE_COMMENT: i = line_comment(); break\r\n case PREPROCESSOR: i = preprocessor(); break\r\n case OPERATOR: i = operator(); break\r\n case INTEGER: i = integer(); break\r\n case HEX: i = hex(); break\r\n case FLOAT: i = decimal(); break\r\n case TOKEN: i = readtoken(); break\r\n case WHITESPACE: i = whitespace(); break\r\n case NORMAL: i = normal(); break\r\n }\r\n\r\n if(last !== i) {\r\n switch(input[last]) {\r\n case '\\n': col = 0; ++line; break\r\n default: ++col; break\r\n }\r\n }\r\n }\r\n\r\n total += i\r\n input = input.slice(i)\r\n return tokens\r\n }\r\n\r\n function end(chunk) {\r\n if(content.length) {\r\n token(content.join(''))\r\n }\r\n\r\n mode = EOF\r\n token('(eof)')\r\n return tokens\r\n }\r\n\r\n function normal() {\r\n content = content.length ? [] : content\r\n\r\n if(last === '/' && c === '*') {\r\n start = total + i - 1\r\n mode = BLOCK_COMMENT\r\n last = c\r\n return i + 1\r\n }\r\n\r\n if(last === '/' && c === '/') {\r\n start = total + i - 1\r\n mode = LINE_COMMENT\r\n last = c\r\n return i + 1\r\n }\r\n\r\n if(c === '#') {\r\n mode = PREPROCESSOR\r\n start = total + i\r\n return i\r\n }\r\n\r\n if(/\\s/.test(c)) {\r\n mode = WHITESPACE\r\n start = total + i\r\n return i\r\n }\r\n\r\n isnum = /\\d/.test(c)\r\n isoperator = /[^\\w_]/.test(c)\r\n\r\n start = total + i\r\n mode = isnum ? INTEGER : isoperator ? OPERATOR : TOKEN\r\n return i\r\n }\r\n\r\n function whitespace() {\r\n if(/[^\\s]/g.test(c)) {\r\n token(content.join(''))\r\n mode = NORMAL\r\n return i\r\n }\r\n content.push(c)\r\n last = c\r\n return i + 1\r\n }\r\n\r\n function preprocessor() {\r\n if((c === '\\r' || c === '\\n') && last !== '\\\\') {\r\n token(content.join(''))\r\n mode = NORMAL\r\n return i\r\n }\r\n content.push(c)\r\n last = c\r\n return i + 1\r\n }\r\n\r\n function line_comment() {\r\n return preprocessor()\r\n }\r\n\r\n function block_comment() {\r\n if(c === '/' && last === '*') {\r\n content.push(c)\r\n token(content.join(''))\r\n mode = NORMAL\r\n return i + 1\r\n }\r\n\r\n content.push(c)\r\n last = c\r\n return i + 1\r\n }\r\n\r\n function operator() {\r\n if(last === '.' && /\\d/.test(c)) {\r\n mode = FLOAT\r\n return i\r\n }\r\n\r\n if(last === '/' && c === '*') {\r\n mode = BLOCK_COMMENT\r\n return i\r\n }\r\n\r\n if(last === '/' && c === '/') {\r\n mode = LINE_COMMENT\r\n return i\r\n }\r\n\r\n if(c === '.' && content.length) {\r\n while(determine_operator(content));\r\n\r\n mode = FLOAT\r\n return i\r\n }\r\n\r\n if(c === ';' || c === ')' || c === '(') {\r\n if(content.length) while(determine_operator(content));\r\n token(c)\r\n mode = NORMAL\r\n return i + 1\r\n }\r\n\r\n var is_composite_operator = content.length === 2 && c !== '='\r\n if(/[\\w_\\d\\s]/.test(c) || is_composite_operator) {\r\n while(determine_operator(content));\r\n mode = NORMAL\r\n return i\r\n }\r\n\r\n content.push(c)\r\n last = c\r\n return i + 1\r\n }\r\n\r\n function determine_operator(buf) {\r\n var j = 0\r\n , idx\r\n , res\r\n\r\n do {\r\n idx = operators.indexOf(buf.slice(0, buf.length + j).join(''))\r\n res = operators[idx]\r\n\r\n if(idx === -1) {\r\n if(j-- + buf.length > 0) continue\r\n res = buf.slice(0, 1).join('')\r\n }\r\n\r\n token(res)\r\n\r\n start += res.length\r\n content = content.slice(res.length)\r\n return content.length\r\n } while(1)\r\n }\r\n\r\n function hex() {\r\n if(/[^a-fA-F0-9]/.test(c)) {\r\n token(content.join(''))\r\n mode = NORMAL\r\n return i\r\n }\r\n\r\n content.push(c)\r\n last = c\r\n return i + 1\r\n }\r\n\r\n function integer() {\r\n if(c === '.') {\r\n content.push(c)\r\n mode = FLOAT\r\n last = c\r\n return i + 1\r\n }\r\n\r\n if(/[eE]/.test(c)) {\r\n content.push(c)\r\n mode = FLOAT\r\n last = c\r\n return i + 1\r\n }\r\n\r\n if(c === 'x' && content.length === 1 && content[0] === '0') {\r\n mode = HEX\r\n content.push(c)\r\n last = c\r\n return i + 1\r\n }\r\n\r\n if(/[^\\d]/.test(c)) {\r\n token(content.join(''))\r\n mode = NORMAL\r\n return i\r\n }\r\n\r\n content.push(c)\r\n last = c\r\n return i + 1\r\n }\r\n\r\n function decimal() {\r\n if(c === 'f') {\r\n content.push(c)\r\n last = c\r\n i += 1\r\n }\r\n\r\n if(/[eE]/.test(c)) {\r\n content.push(c)\r\n last = c\r\n return i + 1\r\n }\r\n\r\n if ((c === '-' || c === '+') && /[eE]/.test(last)) {\r\n content.push(c)\r\n last = c\r\n return i + 1\r\n }\r\n\r\n if(/[^\\d]/.test(c)) {\r\n token(content.join(''))\r\n mode = NORMAL\r\n return i\r\n }\r\n\r\n content.push(c)\r\n last = c\r\n return i + 1\r\n }\r\n\r\n function readtoken() {\r\n if(/[^\\d\\w_]/.test(c)) {\r\n var contentstr = content.join('')\r\n if(literalsDict[contentstr]) {\r\n mode = KEYWORD\r\n } else if(builtinsDict[contentstr]) {\r\n mode = BUILTIN\r\n } else {\r\n mode = IDENT\r\n }\r\n token(content.join(''))\r\n mode = NORMAL\r\n return i\r\n }\r\n content.push(c)\r\n last = c\r\n return i + 1\r\n }\r\n}\r\n\n\n/***/ }),\n\n/***/ 3508:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n// 300es builtins/reserved words that were previously valid in v100\r\nvar v100 = __webpack_require__(6852)\r\n\r\n// The texture2D|Cube functions have been removed\r\n// And the gl_ features are updated\r\nv100 = v100.slice().filter(function (b) {\r\n return !/^(gl\\_|texture)/.test(b)\r\n})\r\n\r\nmodule.exports = v100.concat([\r\n // the updated gl_ constants\r\n 'gl_VertexID'\r\n , 'gl_InstanceID'\r\n , 'gl_Position'\r\n , 'gl_PointSize'\r\n , 'gl_FragCoord'\r\n , 'gl_FrontFacing'\r\n , 'gl_FragDepth'\r\n , 'gl_PointCoord'\r\n , 'gl_MaxVertexAttribs'\r\n , 'gl_MaxVertexUniformVectors'\r\n , 'gl_MaxVertexOutputVectors'\r\n , 'gl_MaxFragmentInputVectors'\r\n , 'gl_MaxVertexTextureImageUnits'\r\n , 'gl_MaxCombinedTextureImageUnits'\r\n , 'gl_MaxTextureImageUnits'\r\n , 'gl_MaxFragmentUniformVectors'\r\n , 'gl_MaxDrawBuffers'\r\n , 'gl_MinProgramTexelOffset'\r\n , 'gl_MaxProgramTexelOffset'\r\n , 'gl_DepthRangeParameters'\r\n , 'gl_DepthRange'\r\n\r\n // other builtins\r\n , 'trunc'\r\n , 'round'\r\n , 'roundEven'\r\n , 'isnan'\r\n , 'isinf'\r\n , 'floatBitsToInt'\r\n , 'floatBitsToUint'\r\n , 'intBitsToFloat'\r\n , 'uintBitsToFloat'\r\n , 'packSnorm2x16'\r\n , 'unpackSnorm2x16'\r\n , 'packUnorm2x16'\r\n , 'unpackUnorm2x16'\r\n , 'packHalf2x16'\r\n , 'unpackHalf2x16'\r\n , 'outerProduct'\r\n , 'transpose'\r\n , 'determinant'\r\n , 'inverse'\r\n , 'texture'\r\n , 'textureSize'\r\n , 'textureProj'\r\n , 'textureLod'\r\n , 'textureOffset'\r\n , 'texelFetch'\r\n , 'texelFetchOffset'\r\n , 'textureProjOffset'\r\n , 'textureLodOffset'\r\n , 'textureProjLod'\r\n , 'textureProjLodOffset'\r\n , 'textureGrad'\r\n , 'textureGradOffset'\r\n , 'textureProjGrad'\r\n , 'textureProjGradOffset'\r\n])\r\n\n\n/***/ }),\n\n/***/ 6852:\n/***/ (function(module) {\n\nmodule.exports = [\r\n // Keep this list sorted\r\n 'abs'\r\n , 'acos'\r\n , 'all'\r\n , 'any'\r\n , 'asin'\r\n , 'atan'\r\n , 'ceil'\r\n , 'clamp'\r\n , 'cos'\r\n , 'cross'\r\n , 'dFdx'\r\n , 'dFdy'\r\n , 'degrees'\r\n , 'distance'\r\n , 'dot'\r\n , 'equal'\r\n , 'exp'\r\n , 'exp2'\r\n , 'faceforward'\r\n , 'floor'\r\n , 'fract'\r\n , 'gl_BackColor'\r\n , 'gl_BackLightModelProduct'\r\n , 'gl_BackLightProduct'\r\n , 'gl_BackMaterial'\r\n , 'gl_BackSecondaryColor'\r\n , 'gl_ClipPlane'\r\n , 'gl_ClipVertex'\r\n , 'gl_Color'\r\n , 'gl_DepthRange'\r\n , 'gl_DepthRangeParameters'\r\n , 'gl_EyePlaneQ'\r\n , 'gl_EyePlaneR'\r\n , 'gl_EyePlaneS'\r\n , 'gl_EyePlaneT'\r\n , 'gl_Fog'\r\n , 'gl_FogCoord'\r\n , 'gl_FogFragCoord'\r\n , 'gl_FogParameters'\r\n , 'gl_FragColor'\r\n , 'gl_FragCoord'\r\n , 'gl_FragData'\r\n , 'gl_FragDepth'\r\n , 'gl_FragDepthEXT'\r\n , 'gl_FrontColor'\r\n , 'gl_FrontFacing'\r\n , 'gl_FrontLightModelProduct'\r\n , 'gl_FrontLightProduct'\r\n , 'gl_FrontMaterial'\r\n , 'gl_FrontSecondaryColor'\r\n , 'gl_LightModel'\r\n , 'gl_LightModelParameters'\r\n , 'gl_LightModelProducts'\r\n , 'gl_LightProducts'\r\n , 'gl_LightSource'\r\n , 'gl_LightSourceParameters'\r\n , 'gl_MaterialParameters'\r\n , 'gl_MaxClipPlanes'\r\n , 'gl_MaxCombinedTextureImageUnits'\r\n , 'gl_MaxDrawBuffers'\r\n , 'gl_MaxFragmentUniformComponents'\r\n , 'gl_MaxLights'\r\n , 'gl_MaxTextureCoords'\r\n , 'gl_MaxTextureImageUnits'\r\n , 'gl_MaxTextureUnits'\r\n , 'gl_MaxVaryingFloats'\r\n , 'gl_MaxVertexAttribs'\r\n , 'gl_MaxVertexTextureImageUnits'\r\n , 'gl_MaxVertexUniformComponents'\r\n , 'gl_ModelViewMatrix'\r\n , 'gl_ModelViewMatrixInverse'\r\n , 'gl_ModelViewMatrixInverseTranspose'\r\n , 'gl_ModelViewMatrixTranspose'\r\n , 'gl_ModelViewProjectionMatrix'\r\n , 'gl_ModelViewProjectionMatrixInverse'\r\n , 'gl_ModelViewProjectionMatrixInverseTranspose'\r\n , 'gl_ModelViewProjectionMatrixTranspose'\r\n , 'gl_MultiTexCoord0'\r\n , 'gl_MultiTexCoord1'\r\n , 'gl_MultiTexCoord2'\r\n , 'gl_MultiTexCoord3'\r\n , 'gl_MultiTexCoord4'\r\n , 'gl_MultiTexCoord5'\r\n , 'gl_MultiTexCoord6'\r\n , 'gl_MultiTexCoord7'\r\n , 'gl_Normal'\r\n , 'gl_NormalMatrix'\r\n , 'gl_NormalScale'\r\n , 'gl_ObjectPlaneQ'\r\n , 'gl_ObjectPlaneR'\r\n , 'gl_ObjectPlaneS'\r\n , 'gl_ObjectPlaneT'\r\n , 'gl_Point'\r\n , 'gl_PointCoord'\r\n , 'gl_PointParameters'\r\n , 'gl_PointSize'\r\n , 'gl_Position'\r\n , 'gl_ProjectionMatrix'\r\n , 'gl_ProjectionMatrixInverse'\r\n , 'gl_ProjectionMatrixInverseTranspose'\r\n , 'gl_ProjectionMatrixTranspose'\r\n , 'gl_SecondaryColor'\r\n , 'gl_TexCoord'\r\n , 'gl_TextureEnvColor'\r\n , 'gl_TextureMatrix'\r\n , 'gl_TextureMatrixInverse'\r\n , 'gl_TextureMatrixInverseTranspose'\r\n , 'gl_TextureMatrixTranspose'\r\n , 'gl_Vertex'\r\n , 'greaterThan'\r\n , 'greaterThanEqual'\r\n , 'inversesqrt'\r\n , 'length'\r\n , 'lessThan'\r\n , 'lessThanEqual'\r\n , 'log'\r\n , 'log2'\r\n , 'matrixCompMult'\r\n , 'max'\r\n , 'min'\r\n , 'mix'\r\n , 'mod'\r\n , 'normalize'\r\n , 'not'\r\n , 'notEqual'\r\n , 'pow'\r\n , 'radians'\r\n , 'reflect'\r\n , 'refract'\r\n , 'sign'\r\n , 'sin'\r\n , 'smoothstep'\r\n , 'sqrt'\r\n , 'step'\r\n , 'tan'\r\n , 'texture2D'\r\n , 'texture2DLod'\r\n , 'texture2DProj'\r\n , 'texture2DProjLod'\r\n , 'textureCube'\r\n , 'textureCubeLod'\r\n , 'texture2DLodEXT'\r\n , 'texture2DProjLodEXT'\r\n , 'textureCubeLodEXT'\r\n , 'texture2DGradEXT'\r\n , 'texture2DProjGradEXT'\r\n , 'textureCubeGradEXT'\r\n]\r\n\n\n/***/ }),\n\n/***/ 7932:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar v100 = __webpack_require__(620)\r\n\r\nmodule.exports = v100.slice().concat([\r\n 'layout'\r\n , 'centroid'\r\n , 'smooth'\r\n , 'case'\r\n , 'mat2x2'\r\n , 'mat2x3'\r\n , 'mat2x4'\r\n , 'mat3x2'\r\n , 'mat3x3'\r\n , 'mat3x4'\r\n , 'mat4x2'\r\n , 'mat4x3'\r\n , 'mat4x4'\r\n , 'uvec2'\r\n , 'uvec3'\r\n , 'uvec4'\r\n , 'samplerCubeShadow'\r\n , 'sampler2DArray'\r\n , 'sampler2DArrayShadow'\r\n , 'isampler2D'\r\n , 'isampler3D'\r\n , 'isamplerCube'\r\n , 'isampler2DArray'\r\n , 'usampler2D'\r\n , 'usampler3D'\r\n , 'usamplerCube'\r\n , 'usampler2DArray'\r\n , 'coherent'\r\n , 'restrict'\r\n , 'readonly'\r\n , 'writeonly'\r\n , 'resource'\r\n , 'atomic_uint'\r\n , 'noperspective'\r\n , 'patch'\r\n , 'sample'\r\n , 'subroutine'\r\n , 'common'\r\n , 'partition'\r\n , 'active'\r\n , 'filter'\r\n , 'image1D'\r\n , 'image2D'\r\n , 'image3D'\r\n , 'imageCube'\r\n , 'iimage1D'\r\n , 'iimage2D'\r\n , 'iimage3D'\r\n , 'iimageCube'\r\n , 'uimage1D'\r\n , 'uimage2D'\r\n , 'uimage3D'\r\n , 'uimageCube'\r\n , 'image1DArray'\r\n , 'image2DArray'\r\n , 'iimage1DArray'\r\n , 'iimage2DArray'\r\n , 'uimage1DArray'\r\n , 'uimage2DArray'\r\n , 'image1DShadow'\r\n , 'image2DShadow'\r\n , 'image1DArrayShadow'\r\n , 'image2DArrayShadow'\r\n , 'imageBuffer'\r\n , 'iimageBuffer'\r\n , 'uimageBuffer'\r\n , 'sampler1DArray'\r\n , 'sampler1DArrayShadow'\r\n , 'isampler1D'\r\n , 'isampler1DArray'\r\n , 'usampler1D'\r\n , 'usampler1DArray'\r\n , 'isampler2DRect'\r\n , 'usampler2DRect'\r\n , 'samplerBuffer'\r\n , 'isamplerBuffer'\r\n , 'usamplerBuffer'\r\n , 'sampler2DMS'\r\n , 'isampler2DMS'\r\n , 'usampler2DMS'\r\n , 'sampler2DMSArray'\r\n , 'isampler2DMSArray'\r\n , 'usampler2DMSArray'\r\n])\r\n\n\n/***/ }),\n\n/***/ 620:\n/***/ (function(module) {\n\nmodule.exports = [\r\n // current\r\n 'precision'\r\n , 'highp'\r\n , 'mediump'\r\n , 'lowp'\r\n , 'attribute'\r\n , 'const'\r\n , 'uniform'\r\n , 'varying'\r\n , 'break'\r\n , 'continue'\r\n , 'do'\r\n , 'for'\r\n , 'while'\r\n , 'if'\r\n , 'else'\r\n , 'in'\r\n , 'out'\r\n , 'inout'\r\n , 'float'\r\n , 'int'\r\n , 'uint'\r\n , 'void'\r\n , 'bool'\r\n , 'true'\r\n , 'false'\r\n , 'discard'\r\n , 'return'\r\n , 'mat2'\r\n , 'mat3'\r\n , 'mat4'\r\n , 'vec2'\r\n , 'vec3'\r\n , 'vec4'\r\n , 'ivec2'\r\n , 'ivec3'\r\n , 'ivec4'\r\n , 'bvec2'\r\n , 'bvec3'\r\n , 'bvec4'\r\n , 'sampler1D'\r\n , 'sampler2D'\r\n , 'sampler3D'\r\n , 'samplerCube'\r\n , 'sampler1DShadow'\r\n , 'sampler2DShadow'\r\n , 'struct'\r\n\r\n // future\r\n , 'asm'\r\n , 'class'\r\n , 'union'\r\n , 'enum'\r\n , 'typedef'\r\n , 'template'\r\n , 'this'\r\n , 'packed'\r\n , 'goto'\r\n , 'switch'\r\n , 'default'\r\n , 'inline'\r\n , 'noinline'\r\n , 'volatile'\r\n , 'public'\r\n , 'static'\r\n , 'extern'\r\n , 'external'\r\n , 'interface'\r\n , 'long'\r\n , 'short'\r\n , 'double'\r\n , 'half'\r\n , 'fixed'\r\n , 'unsigned'\r\n , 'input'\r\n , 'output'\r\n , 'hvec2'\r\n , 'hvec3'\r\n , 'hvec4'\r\n , 'dvec2'\r\n , 'dvec3'\r\n , 'dvec4'\r\n , 'fvec2'\r\n , 'fvec3'\r\n , 'fvec4'\r\n , 'sampler2DRect'\r\n , 'sampler3DRect'\r\n , 'sampler2DRectShadow'\r\n , 'sizeof'\r\n , 'cast'\r\n , 'namespace'\r\n , 'using'\r\n]\r\n\n\n/***/ }),\n\n/***/ 7827:\n/***/ (function(module) {\n\nmodule.exports = [\r\n '<<='\r\n , '>>='\r\n , '++'\r\n , '--'\r\n , '<<'\r\n , '>>'\r\n , '<='\r\n , '>='\r\n , '=='\r\n , '!='\r\n , '&&'\r\n , '||'\r\n , '+='\r\n , '-='\r\n , '*='\r\n , '/='\r\n , '%='\r\n , '&='\r\n , '^^'\r\n , '^='\r\n , '|='\r\n , '('\r\n , ')'\r\n , '['\r\n , ']'\r\n , '.'\r\n , '!'\r\n , '~'\r\n , '*'\r\n , '/'\r\n , '%'\r\n , '+'\r\n , '-'\r\n , '<'\r\n , '>'\r\n , '&'\r\n , '^'\r\n , '|'\r\n , '?'\r\n , ':'\r\n , '='\r\n , ','\r\n , ';'\r\n , '{'\r\n , '}'\r\n]\r\n\n\n/***/ }),\n\n/***/ 4905:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar tokenize = __webpack_require__(5874)\r\n\r\nmodule.exports = tokenizeString\r\n\r\nfunction tokenizeString(str, opt) {\r\n var generator = tokenize(opt)\r\n var tokens = []\r\n\r\n tokens = tokens.concat(generator(str))\r\n tokens = tokens.concat(generator(null))\r\n\r\n return tokens\r\n}\r\n\n\n/***/ }),\n\n/***/ 3236:\n/***/ (function(module) {\n\nmodule.exports = function(strings) {\n if (typeof strings === 'string') strings = [strings]\n var exprs = [].slice.call(arguments,1)\n var parts = []\n for (var i = 0; i < strings.length-1; i++) {\n parts.push(strings[i], exprs[i] || '')\n }\n parts.push(strings[i])\n return parts.join('')\n}\n\n\n/***/ }),\n\n/***/ 7520:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\r\n\r\nvar isBrowser = __webpack_require__(9507)\r\n\r\nfunction detect() {\r\n\tvar supported = false\r\n\r\n\ttry {\r\n\t\tvar opts = Object.defineProperty({}, 'passive', {\r\n\t\t\tget: function() {\r\n\t\t\t\tsupported = true\r\n\t\t\t}\r\n\t\t})\r\n\r\n\t\twindow.addEventListener('test', null, opts)\r\n\t\twindow.removeEventListener('test', null, opts)\r\n\t} catch(e) {\r\n\t\tsupported = false\r\n\t}\r\n\r\n\treturn supported\r\n}\r\n\r\nmodule.exports = isBrowser && detect()\r\n\n\n/***/ }),\n\n/***/ 3778:\n/***/ (function(__unused_webpack_module, exports) {\n\n/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh */\nexports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = ((value * c) - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n\n\n/***/ }),\n\n/***/ 8954:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\n//High level idea:\n// 1. Use Clarkson's incremental construction to find convex hull\n// 2. Point location in triangulation by jump and walk\n\nmodule.exports = incrementalConvexHull\n\nvar orient = __webpack_require__(3250)\nvar compareCell = (__webpack_require__(6803)/* .compareCells */ .Fw)\n\nfunction Simplex(vertices, adjacent, boundary) {\n this.vertices = vertices\n this.adjacent = adjacent\n this.boundary = boundary\n this.lastVisited = -1\n}\n\nSimplex.prototype.flip = function() {\n var t = this.vertices[0]\n this.vertices[0] = this.vertices[1]\n this.vertices[1] = t\n var u = this.adjacent[0]\n this.adjacent[0] = this.adjacent[1]\n this.adjacent[1] = u\n}\n\nfunction GlueFacet(vertices, cell, index) {\n this.vertices = vertices\n this.cell = cell\n this.index = index\n}\n\nfunction compareGlue(a, b) {\n return compareCell(a.vertices, b.vertices)\n}\n\nfunction wrapper(test) {\n return function() {\n var tuple = this.tuple\n return test.apply(this, tuple)\n }\n}\n\nfunction bakeOrient(d) {\n var test = orient[d+1]\n if(!test) {\n test = orient\n }\n return wrapper(test)\n}\n\nvar BAKED = []\n\nfunction Triangulation(dimension, vertices, simplices) {\n this.dimension = dimension\n this.vertices = vertices\n this.simplices = simplices\n this.interior = simplices.filter(function(c) {\n return !c.boundary\n })\n\n this.tuple = new Array(dimension+1)\n for(var i=0; i<=dimension; ++i) {\n this.tuple[i] = this.vertices[i]\n }\n\n var o = BAKED[dimension]\n if(!o) {\n o = BAKED[dimension] = bakeOrient(dimension)\n }\n this.orient = o\n}\n\nvar proto = Triangulation.prototype\n\n//Degenerate situation where we are on boundary, but coplanar to face\nproto.handleBoundaryDegeneracy = function(cell, point) {\n var d = this.dimension\n var n = this.vertices.length - 1\n var tuple = this.tuple\n var verts = this.vertices\n\n //Dumb solution: Just do dfs from boundary cell until we find any peak, or terminate\n var toVisit = [ cell ]\n cell.lastVisited = -n\n while(toVisit.length > 0) {\n cell = toVisit.pop()\n var cellAdj = cell.adjacent\n for(var i=0; i<=d; ++i) {\n var neighbor = cellAdj[i]\n if(!neighbor.boundary || neighbor.lastVisited <= -n) {\n continue\n }\n var nv = neighbor.vertices\n for(var j=0; j<=d; ++j) {\n var vv = nv[j]\n if(vv < 0) {\n tuple[j] = point\n } else {\n tuple[j] = verts[vv]\n }\n }\n var o = this.orient()\n if(o > 0) {\n return neighbor\n }\n neighbor.lastVisited = -n\n if(o === 0) {\n toVisit.push(neighbor)\n }\n }\n }\n return null\n}\n\nproto.walk = function(point, random) {\n //Alias local properties\n var n = this.vertices.length - 1\n var d = this.dimension\n var verts = this.vertices\n var tuple = this.tuple\n\n //Compute initial jump cell\n var initIndex = random ? (this.interior.length * Math.random())|0 : (this.interior.length-1)\n var cell = this.interior[ initIndex ]\n\n //Start walking\nouterLoop:\n while(!cell.boundary) {\n var cellVerts = cell.vertices\n var cellAdj = cell.adjacent\n\n for(var i=0; i<=d; ++i) {\n tuple[i] = verts[cellVerts[i]]\n }\n cell.lastVisited = n\n\n //Find farthest adjacent cell\n for(var i=0; i<=d; ++i) {\n var neighbor = cellAdj[i]\n if(neighbor.lastVisited >= n) {\n continue\n }\n var prev = tuple[i]\n tuple[i] = point\n var o = this.orient()\n tuple[i] = prev\n if(o < 0) {\n cell = neighbor\n continue outerLoop\n } else {\n if(!neighbor.boundary) {\n neighbor.lastVisited = n\n } else {\n neighbor.lastVisited = -n\n }\n }\n }\n return\n }\n\n return cell\n}\n\nproto.addPeaks = function(point, cell) {\n var n = this.vertices.length - 1\n var d = this.dimension\n var verts = this.vertices\n var tuple = this.tuple\n var interior = this.interior\n var simplices = this.simplices\n\n //Walking finished at boundary, time to add peaks\n var tovisit = [ cell ]\n\n //Stretch initial boundary cell into a peak\n cell.lastVisited = n\n cell.vertices[cell.vertices.indexOf(-1)] = n\n cell.boundary = false\n interior.push(cell)\n\n //Record a list of all new boundaries created by added peaks so we can glue them together when we are all done\n var glueFacets = []\n\n //Do a traversal of the boundary walking outward from starting peak\n while(tovisit.length > 0) {\n //Pop off peak and walk over adjacent cells\n var cell = tovisit.pop()\n var cellVerts = cell.vertices\n var cellAdj = cell.adjacent\n var indexOfN = cellVerts.indexOf(n)\n if(indexOfN < 0) {\n continue\n }\n\n for(var i=0; i<=d; ++i) {\n if(i === indexOfN) {\n continue\n }\n\n //For each boundary neighbor of the cell\n var neighbor = cellAdj[i]\n if(!neighbor.boundary || neighbor.lastVisited >= n) {\n continue\n }\n\n var nv = neighbor.vertices\n\n //Test if neighbor is a peak\n if(neighbor.lastVisited !== -n) {\n //Compute orientation of p relative to each boundary peak\n var indexOfNeg1 = 0\n for(var j=0; j<=d; ++j) {\n if(nv[j] < 0) {\n indexOfNeg1 = j\n tuple[j] = point\n } else {\n tuple[j] = verts[nv[j]]\n }\n }\n var o = this.orient()\n\n //Test if neighbor cell is also a peak\n if(o > 0) {\n nv[indexOfNeg1] = n\n neighbor.boundary = false\n interior.push(neighbor)\n tovisit.push(neighbor)\n neighbor.lastVisited = n\n continue\n } else {\n neighbor.lastVisited = -n\n }\n }\n\n var na = neighbor.adjacent\n\n //Otherwise, replace neighbor with new face\n var vverts = cellVerts.slice()\n var vadj = cellAdj.slice()\n var ncell = new Simplex(vverts, vadj, true)\n simplices.push(ncell)\n\n //Connect to neighbor\n var opposite = na.indexOf(cell)\n if(opposite < 0) {\n continue\n }\n na[opposite] = ncell\n vadj[indexOfN] = neighbor\n\n //Connect to cell\n vverts[i] = -1\n vadj[i] = cell\n cellAdj[i] = ncell\n\n //Flip facet\n ncell.flip()\n\n //Add to glue list\n for(var j=0; j<=d; ++j) {\n var uu = vverts[j]\n if(uu < 0 || uu === n) {\n continue\n }\n var nface = new Array(d-1)\n var nptr = 0\n for(var k=0; k<=d; ++k) {\n var vv = vverts[k]\n if(vv < 0 || k === j) {\n continue\n }\n nface[nptr++] = vv\n }\n glueFacets.push(new GlueFacet(nface, ncell, j))\n }\n }\n }\n\n //Glue boundary facets together\n glueFacets.sort(compareGlue)\n\n for(var i=0; i+1= 0) {\n bcell[ptr++] = cv[j]\n } else {\n parity = j&1\n }\n }\n if(parity === (d&1)) {\n var t = bcell[0]\n bcell[0] = bcell[1]\n bcell[1] = t\n }\n boundary.push(bcell)\n }\n }\n return boundary\n}\n\nfunction incrementalConvexHull(points, randomSearch) {\n var n = points.length\n if(n === 0) {\n throw new Error(\"Must have at least d+1 points\")\n }\n var d = points[0].length\n if(n <= d) {\n throw new Error(\"Must input at least d+1 points\")\n }\n\n //FIXME: This could be degenerate, but need to select d+1 non-coplanar points to bootstrap process\n var initialSimplex = points.slice(0, d+1)\n\n //Make sure initial simplex is positively oriented\n var o = orient.apply(void 0, initialSimplex)\n if(o === 0) {\n throw new Error(\"Input not in general position\")\n }\n var initialCoords = new Array(d+1)\n for(var i=0; i<=d; ++i) {\n initialCoords[i] = i\n }\n if(o < 0) {\n initialCoords[0] = 1\n initialCoords[1] = 0\n }\n\n //Create initial topological index, glue pointers together (kind of messy)\n var initialCell = new Simplex(initialCoords, new Array(d+1), false)\n var boundary = initialCell.adjacent\n var list = new Array(d+2)\n for(var i=0; i<=d; ++i) {\n var verts = initialCoords.slice()\n for(var j=0; j<=d; ++j) {\n if(j === i) {\n verts[j] = -1\n }\n }\n var t = verts[0]\n verts[0] = verts[1]\n verts[1] = t\n var cell = new Simplex(verts, new Array(d+1), true)\n boundary[i] = cell\n list[i] = cell\n }\n list[d+1] = initialCell\n for(var i=0; i<=d; ++i) {\n var verts = boundary[i].vertices\n var adj = boundary[i].adjacent\n for(var j=0; j<=d; ++j) {\n var v = verts[j]\n if(v < 0) {\n adj[j] = initialCell\n continue\n }\n for(var k=0; k<=d; ++k) {\n if(boundary[k].vertices.indexOf(v) < 0) {\n adj[j] = boundary[k]\n }\n }\n }\n }\n\n //Initialize triangles\n var triangles = new Triangulation(d, initialSimplex, list)\n\n //Insert remaining points\n var useRandom = !!randomSearch\n for(var i=d+1; i 3*(weight+1)) {\n rebuildWithInterval(this, interval)\n } else {\n this.left.insert(interval)\n }\n } else {\n this.left = createIntervalTree([interval])\n }\n } else if(interval[0] > this.mid) {\n if(this.right) {\n if(4*(this.right.count+1) > 3*(weight+1)) {\n rebuildWithInterval(this, interval)\n } else {\n this.right.insert(interval)\n }\n } else {\n this.right = createIntervalTree([interval])\n }\n } else {\n var l = bounds.ge(this.leftPoints, interval, compareBegin)\n var r = bounds.ge(this.rightPoints, interval, compareEnd)\n this.leftPoints.splice(l, 0, interval)\n this.rightPoints.splice(r, 0, interval)\n }\n}\n\nproto.remove = function(interval) {\n var weight = this.count - this.leftPoints\n if(interval[1] < this.mid) {\n if(!this.left) {\n return NOT_FOUND\n }\n var rw = this.right ? this.right.count : 0\n if(4 * rw > 3 * (weight-1)) {\n return rebuildWithoutInterval(this, interval)\n }\n var r = this.left.remove(interval)\n if(r === EMPTY) {\n this.left = null\n this.count -= 1\n return SUCCESS\n } else if(r === SUCCESS) {\n this.count -= 1\n }\n return r\n } else if(interval[0] > this.mid) {\n if(!this.right) {\n return NOT_FOUND\n }\n var lw = this.left ? this.left.count : 0\n if(4 * lw > 3 * (weight-1)) {\n return rebuildWithoutInterval(this, interval)\n }\n var r = this.right.remove(interval)\n if(r === EMPTY) {\n this.right = null\n this.count -= 1\n return SUCCESS\n } else if(r === SUCCESS) {\n this.count -= 1\n }\n return r\n } else {\n if(this.count === 1) {\n if(this.leftPoints[0] === interval) {\n return EMPTY\n } else {\n return NOT_FOUND\n }\n }\n if(this.leftPoints.length === 1 && this.leftPoints[0] === interval) {\n if(this.left && this.right) {\n var p = this\n var n = this.left\n while(n.right) {\n p = n\n n = n.right\n }\n if(p === this) {\n n.right = this.right\n } else {\n var l = this.left\n var r = this.right\n p.count -= n.count\n p.right = n.left\n n.left = l\n n.right = r\n }\n copy(this, n)\n this.count = (this.left?this.left.count:0) + (this.right?this.right.count:0) + this.leftPoints.length\n } else if(this.left) {\n copy(this, this.left)\n } else {\n copy(this, this.right)\n }\n return SUCCESS\n }\n for(var l = bounds.ge(this.leftPoints, interval, compareBegin); l=0 && arr[i][1] >= lo; --i) {\n var r = cb(arr[i])\n if(r) { return r }\n }\n}\n\nfunction reportRange(arr, cb) {\n for(var i=0; i this.mid) {\n if(this.right) {\n var r = this.right.queryPoint(x, cb)\n if(r) { return r }\n }\n return reportRightRange(this.rightPoints, x, cb)\n } else {\n return reportRange(this.leftPoints, cb)\n }\n}\n\nproto.queryInterval = function(lo, hi, cb) {\n if(lo < this.mid && this.left) {\n var r = this.left.queryInterval(lo, hi, cb)\n if(r) { return r }\n }\n if(hi > this.mid && this.right) {\n var r = this.right.queryInterval(lo, hi, cb)\n if(r) { return r }\n }\n if(hi < this.mid) {\n return reportLeftRange(this.leftPoints, hi, cb)\n } else if(lo > this.mid) {\n return reportRightRange(this.rightPoints, lo, cb)\n } else {\n return reportRange(this.leftPoints, cb)\n }\n}\n\nfunction compareNumbers(a, b) {\n return a - b\n}\n\nfunction compareBegin(a, b) {\n var d = a[0] - b[0]\n if(d) { return d }\n return a[1] - b[1]\n}\n\nfunction compareEnd(a, b) {\n var d = a[1] - b[1]\n if(d) { return d }\n return a[0] - b[0]\n}\n\nfunction createIntervalTree(intervals) {\n if(intervals.length === 0) {\n return null\n }\n var pts = []\n for(var i=0; i>1]\n\n var leftIntervals = []\n var rightIntervals = []\n var centerIntervals = []\n for(var i=0; i\n * @license MIT\n */\n\n// The _isBuffer check is for Safari 5-7 support, because it's missing\n// Object.prototype.constructor. Remove this eventually\nmodule.exports = function (obj) {\n return obj != null && (isBuffer(obj) || isSlowBuffer(obj) || !!obj._isBuffer)\n}\n\nfunction isBuffer (obj) {\n return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj)\n}\n\n// For Node v0.10 support. Remove this eventually.\nfunction isSlowBuffer (obj) {\n return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isBuffer(obj.slice(0, 0))\n}\n\n\n/***/ }),\n\n/***/ 5219:\n/***/ (function(module) {\n\n\"use strict\";\n\r\n\r\n/**\r\n * Is this string all whitespace?\r\n * This solution kind of makes my brain hurt, but it's significantly faster\r\n * than !str.trim() or any other solution I could find.\r\n *\r\n * whitespace codes from: http://en.wikipedia.org/wiki/Whitespace_character\r\n * and verified with:\r\n *\r\n * for(var i = 0; i < 65536; i++) {\r\n * var s = String.fromCharCode(i);\r\n * if(+s===0 && !s.trim()) console.log(i, s);\r\n * }\r\n *\r\n * which counts a couple of these as *not* whitespace, but finds nothing else\r\n * that *is* whitespace. Note that charCodeAt stops at 16 bits, but it appears\r\n * that there are no whitespace characters above this, and code points above\r\n * this do not map onto white space characters.\r\n */\r\n\r\nmodule.exports = function(str){\r\n var l = str.length,\r\n a;\r\n for(var i = 0; i < l; i++) {\r\n a = str.charCodeAt(i);\r\n if((a < 9 || a > 13) && (a !== 32) && (a !== 133) && (a !== 160) &&\r\n (a !== 5760) && (a !== 6158) && (a < 8192 || a > 8205) &&\r\n (a !== 8232) && (a !== 8233) && (a !== 8239) && (a !== 8287) &&\r\n (a !== 8288) && (a !== 12288) && (a !== 65279)) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n}\r\n\n\n/***/ }),\n\n/***/ 395:\n/***/ (function(module) {\n\nfunction lerp(v0, v1, t) {\n return v0*(1-t)+v1*t\n}\nmodule.exports = lerp\n\n/***/ }),\n\n/***/ 2652:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n/*jshint unused:true*/\n/*\nInput: matrix ; a 4x4 matrix\nOutput: translation ; a 3 component vector\n scale ; a 3 component vector\n skew ; skew factors XY,XZ,YZ represented as a 3 component vector\n perspective ; a 4 component vector\n quaternion ; a 4 component vector\nReturns false if the matrix cannot be decomposed, true if it can\n\n\nReferences:\nhttps://github.com/kamicane/matrix3d/blob/master/lib/Matrix3d.js\nhttps://github.com/ChromiumWebApps/chromium/blob/master/ui/gfx/transform_util.cc\nhttp://www.w3.org/TR/css3-transforms/#decomposing-a-3d-matrix\n*/\n\nvar normalize = __webpack_require__(4335)\n\nvar create = __webpack_require__(6864)\nvar clone = __webpack_require__(1903)\nvar determinant = __webpack_require__(9921)\nvar invert = __webpack_require__(7608)\nvar transpose = __webpack_require__(5665)\nvar vec3 = {\n length: __webpack_require__(1387),\n normalize: __webpack_require__(3536),\n dot: __webpack_require__(244),\n cross: __webpack_require__(5911)\n}\n\nvar tmp = create()\nvar perspectiveMatrix = create()\nvar tmpVec4 = [0, 0, 0, 0]\nvar row = [ [0,0,0], [0,0,0], [0,0,0] ]\nvar pdum3 = [0,0,0]\n\nmodule.exports = function decomposeMat4(matrix, translation, scale, skew, perspective, quaternion) {\n if (!translation) translation = [0,0,0]\n if (!scale) scale = [0,0,0]\n if (!skew) skew = [0,0,0]\n if (!perspective) perspective = [0,0,0,1]\n if (!quaternion) quaternion = [0,0,0,1]\n\n //normalize, if not possible then bail out early\n if (!normalize(tmp, matrix))\n return false\n\n // perspectiveMatrix is used to solve for perspective, but it also provides\n // an easy way to test for singularity of the upper 3x3 component.\n clone(perspectiveMatrix, tmp)\n\n perspectiveMatrix[3] = 0\n perspectiveMatrix[7] = 0\n perspectiveMatrix[11] = 0\n perspectiveMatrix[15] = 1\n\n // If the perspectiveMatrix is not invertible, we are also unable to\n // decompose, so we'll bail early. Constant taken from SkMatrix44::invert.\n if (Math.abs(determinant(perspectiveMatrix) < 1e-8))\n return false\n\n var a03 = tmp[3], a13 = tmp[7], a23 = tmp[11],\n a30 = tmp[12], a31 = tmp[13], a32 = tmp[14], a33 = tmp[15]\n\n // First, isolate perspective.\n if (a03 !== 0 || a13 !== 0 || a23 !== 0) {\n tmpVec4[0] = a03\n tmpVec4[1] = a13\n tmpVec4[2] = a23\n tmpVec4[3] = a33\n\n // Solve the equation by inverting perspectiveMatrix and multiplying\n // rightHandSide by the inverse.\n // resuing the perspectiveMatrix here since it's no longer needed\n var ret = invert(perspectiveMatrix, perspectiveMatrix)\n if (!ret) return false\n transpose(perspectiveMatrix, perspectiveMatrix)\n\n //multiply by transposed inverse perspective matrix, into perspective vec4\n vec4multMat4(perspective, tmpVec4, perspectiveMatrix)\n } else { \n //no perspective\n perspective[0] = perspective[1] = perspective[2] = 0\n perspective[3] = 1\n }\n\n // Next take care of translation\n translation[0] = a30\n translation[1] = a31\n translation[2] = a32\n\n // Now get scale and shear. 'row' is a 3 element array of 3 component vectors\n mat3from4(row, tmp)\n\n // Compute X scale factor and normalize first row.\n scale[0] = vec3.length(row[0])\n vec3.normalize(row[0], row[0])\n\n // Compute XY shear factor and make 2nd row orthogonal to 1st.\n skew[0] = vec3.dot(row[0], row[1])\n combine(row[1], row[1], row[0], 1.0, -skew[0])\n\n // Now, compute Y scale and normalize 2nd row.\n scale[1] = vec3.length(row[1])\n vec3.normalize(row[1], row[1])\n skew[0] /= scale[1]\n\n // Compute XZ and YZ shears, orthogonalize 3rd row\n skew[1] = vec3.dot(row[0], row[2])\n combine(row[2], row[2], row[0], 1.0, -skew[1])\n skew[2] = vec3.dot(row[1], row[2])\n combine(row[2], row[2], row[1], 1.0, -skew[2])\n\n // Next, get Z scale and normalize 3rd row.\n scale[2] = vec3.length(row[2])\n vec3.normalize(row[2], row[2])\n skew[1] /= scale[2]\n skew[2] /= scale[2]\n\n\n // At this point, the matrix (in rows) is orthonormal.\n // Check for a coordinate system flip. If the determinant\n // is -1, then negate the matrix and the scaling factors.\n vec3.cross(pdum3, row[1], row[2])\n if (vec3.dot(row[0], pdum3) < 0) {\n for (var i = 0; i < 3; i++) {\n scale[i] *= -1;\n row[i][0] *= -1\n row[i][1] *= -1\n row[i][2] *= -1\n }\n }\n\n // Now, get the rotations out\n quaternion[0] = 0.5 * Math.sqrt(Math.max(1 + row[0][0] - row[1][1] - row[2][2], 0))\n quaternion[1] = 0.5 * Math.sqrt(Math.max(1 - row[0][0] + row[1][1] - row[2][2], 0))\n quaternion[2] = 0.5 * Math.sqrt(Math.max(1 - row[0][0] - row[1][1] + row[2][2], 0))\n quaternion[3] = 0.5 * Math.sqrt(Math.max(1 + row[0][0] + row[1][1] + row[2][2], 0))\n\n if (row[2][1] > row[1][2])\n quaternion[0] = -quaternion[0]\n if (row[0][2] > row[2][0])\n quaternion[1] = -quaternion[1]\n if (row[1][0] > row[0][1])\n quaternion[2] = -quaternion[2]\n return true\n}\n\n//will be replaced by gl-vec4 eventually\nfunction vec4multMat4(out, a, m) {\n var x = a[0], y = a[1], z = a[2], w = a[3];\n out[0] = m[0] * x + m[4] * y + m[8] * z + m[12] * w;\n out[1] = m[1] * x + m[5] * y + m[9] * z + m[13] * w;\n out[2] = m[2] * x + m[6] * y + m[10] * z + m[14] * w;\n out[3] = m[3] * x + m[7] * y + m[11] * z + m[15] * w;\n return out;\n}\n\n//gets upper-left of a 4x4 matrix into a 3x3 of vectors\nfunction mat3from4(out, mat4x4) {\n out[0][0] = mat4x4[0]\n out[0][1] = mat4x4[1]\n out[0][2] = mat4x4[2]\n \n out[1][0] = mat4x4[4]\n out[1][1] = mat4x4[5]\n out[1][2] = mat4x4[6]\n\n out[2][0] = mat4x4[8]\n out[2][1] = mat4x4[9]\n out[2][2] = mat4x4[10]\n}\n\nfunction combine(out, a, b, scale1, scale2) {\n out[0] = a[0] * scale1 + b[0] * scale2\n out[1] = a[1] * scale1 + b[1] * scale2\n out[2] = a[2] * scale1 + b[2] * scale2\n}\n\n/***/ }),\n\n/***/ 4335:\n/***/ (function(module) {\n\nmodule.exports = function normalize(out, mat) {\n var m44 = mat[15]\n // Cannot normalize.\n if (m44 === 0) \n return false\n var scale = 1 / m44\n for (var i=0; i<16; i++)\n out[i] = mat[i] * scale\n return true\n}\n\n/***/ }),\n\n/***/ 7442:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar lerp = __webpack_require__(6658)\n\nvar recompose = __webpack_require__(7182)\nvar decompose = __webpack_require__(2652)\nvar determinant = __webpack_require__(9921)\nvar slerp = __webpack_require__(8648)\n\nvar state0 = state()\nvar state1 = state()\nvar tmp = state()\n\nmodule.exports = interpolate\nfunction interpolate(out, start, end, alpha) {\n if (determinant(start) === 0 || determinant(end) === 0)\n return false\n\n //decompose the start and end matrices into individual components\n var r0 = decompose(start, state0.translate, state0.scale, state0.skew, state0.perspective, state0.quaternion)\n var r1 = decompose(end, state1.translate, state1.scale, state1.skew, state1.perspective, state1.quaternion)\n if (!r0 || !r1)\n return false \n\n\n //now lerp/slerp the start and end components into a temporary lerp(tmptranslate, state0.translate, state1.translate, alpha)\n lerp(tmp.translate, state0.translate, state1.translate, alpha)\n lerp(tmp.skew, state0.skew, state1.skew, alpha)\n lerp(tmp.scale, state0.scale, state1.scale, alpha)\n lerp(tmp.perspective, state0.perspective, state1.perspective, alpha)\n slerp(tmp.quaternion, state0.quaternion, state1.quaternion, alpha)\n\n //and recompose into our 'out' matrix\n recompose(out, tmp.translate, tmp.scale, tmp.skew, tmp.perspective, tmp.quaternion)\n return true\n}\n\nfunction state() {\n return {\n translate: vec3(),\n scale: vec3(1),\n skew: vec3(),\n perspective: vec4(),\n quaternion: vec4()\n }\n}\n\nfunction vec3(n) {\n return [n||0,n||0,n||0]\n}\n\nfunction vec4() {\n return [0,0,0,1]\n}\n\n/***/ }),\n\n/***/ 7182:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n/*\nInput: translation ; a 3 component vector\n scale ; a 3 component vector\n skew ; skew factors XY,XZ,YZ represented as a 3 component vector\n perspective ; a 4 component vector\n quaternion ; a 4 component vector\nOutput: matrix ; a 4x4 matrix\n\nFrom: http://www.w3.org/TR/css3-transforms/#recomposing-to-a-3d-matrix\n*/\n\nvar mat4 = {\n identity: __webpack_require__(7894),\n translate: __webpack_require__(7656),\n multiply: __webpack_require__(6760),\n create: __webpack_require__(6864),\n scale: __webpack_require__(2504),\n fromRotationTranslation: __webpack_require__(6743)\n}\n\nvar rotationMatrix = mat4.create()\nvar temp = mat4.create()\n\nmodule.exports = function recomposeMat4(matrix, translation, scale, skew, perspective, quaternion) {\n mat4.identity(matrix)\n\n //apply translation & rotation\n mat4.fromRotationTranslation(matrix, quaternion, translation)\n\n //apply perspective\n matrix[3] = perspective[0]\n matrix[7] = perspective[1]\n matrix[11] = perspective[2]\n matrix[15] = perspective[3]\n \n // apply skew\n // temp is a identity 4x4 matrix initially\n mat4.identity(temp)\n\n if (skew[2] !== 0) {\n temp[9] = skew[2]\n mat4.multiply(matrix, matrix, temp)\n }\n\n if (skew[1] !== 0) {\n temp[9] = 0\n temp[8] = skew[1]\n mat4.multiply(matrix, matrix, temp)\n }\n\n if (skew[0] !== 0) {\n temp[8] = 0\n temp[4] = skew[0]\n mat4.multiply(matrix, matrix, temp)\n }\n\n //apply scale\n mat4.scale(matrix, matrix, scale)\n return matrix\n}\n\n/***/ }),\n\n/***/ 4192:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar bsearch = __webpack_require__(2478)\nvar m4interp = __webpack_require__(7442)\nvar invert44 = __webpack_require__(7608)\nvar rotateX = __webpack_require__(5567)\nvar rotateY = __webpack_require__(2408)\nvar rotateZ = __webpack_require__(7089)\nvar lookAt = __webpack_require__(6582)\nvar translate = __webpack_require__(7656)\nvar scale = __webpack_require__(2504)\nvar normalize = __webpack_require__(3536)\n\nvar DEFAULT_CENTER = [0,0,0]\n\nmodule.exports = createMatrixCameraController\n\nfunction MatrixCameraController(initialMatrix) {\n this._components = initialMatrix.slice()\n this._time = [0]\n this.prevMatrix = initialMatrix.slice()\n this.nextMatrix = initialMatrix.slice()\n this.computedMatrix = initialMatrix.slice()\n this.computedInverse = initialMatrix.slice()\n this.computedEye = [0,0,0]\n this.computedUp = [0,0,0]\n this.computedCenter = [0,0,0]\n this.computedRadius = [0]\n this._limits = [-Infinity, Infinity]\n}\n\nvar proto = MatrixCameraController.prototype\n\nproto.recalcMatrix = function(t) {\n var time = this._time\n var tidx = bsearch.le(time, t)\n var mat = this.computedMatrix\n if(tidx < 0) {\n return\n }\n var comps = this._components\n if(tidx === time.length-1) {\n var ptr = 16*tidx\n for(var i=0; i<16; ++i) {\n mat[i] = comps[ptr++]\n }\n } else {\n var dt = (time[tidx+1] - time[tidx])\n var ptr = 16*tidx\n var prev = this.prevMatrix\n var allEqual = true\n for(var i=0; i<16; ++i) {\n prev[i] = comps[ptr++]\n }\n var next = this.nextMatrix\n for(var i=0; i<16; ++i) {\n next[i] = comps[ptr++]\n allEqual = allEqual && (prev[i] === next[i])\n }\n if(dt < 1e-6 || allEqual) {\n for(var i=0; i<16; ++i) {\n mat[i] = prev[i]\n }\n } else {\n m4interp(mat, prev, next, (t - time[tidx])/dt)\n }\n }\n\n var up = this.computedUp\n up[0] = mat[1]\n up[1] = mat[5]\n up[2] = mat[9]\n normalize(up, up)\n\n var imat = this.computedInverse\n invert44(imat, mat)\n var eye = this.computedEye\n var w = imat[15]\n eye[0] = imat[12]/w\n eye[1] = imat[13]/w\n eye[2] = imat[14]/w\n\n var center = this.computedCenter\n var radius = Math.exp(this.computedRadius[0])\n for(var i=0; i<3; ++i) {\n center[i] = eye[i] - mat[2+4*i] * radius\n }\n}\n\nproto.idle = function(t) {\n if(t < this.lastT()) {\n return\n }\n var mc = this._components\n var ptr = mc.length-16\n for(var i=0; i<16; ++i) {\n mc.push(mc[ptr++])\n }\n this._time.push(t)\n}\n\nproto.flush = function(t) {\n var idx = bsearch.gt(this._time, t) - 2\n if(idx < 0) {\n return\n }\n this._time.splice(0, idx)\n this._components.splice(0, 16*idx)\n}\n\nproto.lastT = function() {\n return this._time[this._time.length-1]\n}\n\nproto.lookAt = function(t, eye, center, up) {\n this.recalcMatrix(t)\n eye = eye || this.computedEye\n center = center || DEFAULT_CENTER\n up = up || this.computedUp\n this.setMatrix(t, lookAt(this.computedMatrix, eye, center, up))\n var d2 = 0.0\n for(var i=0; i<3; ++i) {\n d2 += Math.pow(center[i] - eye[i], 2)\n }\n d2 = Math.log(Math.sqrt(d2))\n this.computedRadius[0] = d2\n}\n\nproto.rotate = function(t, yaw, pitch, roll) {\n this.recalcMatrix(t)\n var mat = this.computedInverse\n if(yaw) rotateY(mat, mat, yaw)\n if(pitch) rotateX(mat, mat, pitch)\n if(roll) rotateZ(mat, mat, roll)\n this.setMatrix(t, invert44(this.computedMatrix, mat))\n}\n\nvar tvec = [0,0,0]\n\nproto.pan = function(t, dx, dy, dz) {\n tvec[0] = -(dx || 0.0)\n tvec[1] = -(dy || 0.0)\n tvec[2] = -(dz || 0.0)\n this.recalcMatrix(t)\n var mat = this.computedInverse\n translate(mat, mat, tvec)\n this.setMatrix(t, invert44(mat, mat))\n}\n\nproto.translate = function(t, dx, dy, dz) {\n tvec[0] = dx || 0.0\n tvec[1] = dy || 0.0\n tvec[2] = dz || 0.0\n this.recalcMatrix(t)\n var mat = this.computedMatrix\n translate(mat, mat, tvec)\n this.setMatrix(t, mat)\n}\n\nproto.setMatrix = function(t, mat) {\n if(t < this.lastT()) {\n return\n }\n this._time.push(t)\n for(var i=0; i<16; ++i) {\n this._components.push(mat[i])\n }\n}\n\nproto.setDistance = function(t, d) {\n this.computedRadius[0] = d\n}\n\nproto.setDistanceLimits = function(a,b) {\n var lim = this._limits\n lim[0] = a\n lim[1] = b\n}\n\nproto.getDistanceLimits = function(out) {\n var lim = this._limits\n if(out) {\n out[0] = lim[0]\n out[1] = lim[1]\n return out\n }\n return lim\n}\n\nfunction createMatrixCameraController(options) {\n options = options || {}\n var matrix = options.matrix || \n [1,0,0,0,\n 0,1,0,0,\n 0,0,1,0,\n 0,0,0,1]\n return new MatrixCameraController(matrix)\n}\n\n\n/***/ }),\n\n/***/ 3090:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = monotoneConvexHull2D\n\nvar orient = (__webpack_require__(3250)[3])\n\nfunction monotoneConvexHull2D(points) {\n var n = points.length\n\n if(n < 3) {\n var result = new Array(n)\n for(var i=0; i 1 && orient(\n points[lower[m-2]], \n points[lower[m-1]], \n p) <= 0) {\n m -= 1\n lower.pop()\n }\n lower.push(idx)\n\n //Insert into upper list\n m = upper.length\n while(m > 1 && orient(\n points[upper[m-2]], \n points[upper[m-1]], \n p) >= 0) {\n m -= 1\n upper.pop()\n }\n upper.push(idx)\n }\n\n //Merge lists together\n var result = new Array(upper.length + lower.length - 2)\n var ptr = 0\n for(var i=0, nl=lower.length; i0; --j) {\n result[ptr++] = upper[j]\n }\n\n //Return result\n return result\n}\n\n/***/ }),\n\n/***/ 351:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = mouseListen\n\nvar mouse = __webpack_require__(4687)\n\nfunction mouseListen (element, callback) {\n if (!callback) {\n callback = element\n element = window\n }\n\n var buttonState = 0\n var x = 0\n var y = 0\n var mods = {\n shift: false,\n alt: false,\n control: false,\n meta: false\n }\n var attached = false\n\n function updateMods (ev) {\n var changed = false\n if ('altKey' in ev) {\n changed = changed || ev.altKey !== mods.alt\n mods.alt = !!ev.altKey\n }\n if ('shiftKey' in ev) {\n changed = changed || ev.shiftKey !== mods.shift\n mods.shift = !!ev.shiftKey\n }\n if ('ctrlKey' in ev) {\n changed = changed || ev.ctrlKey !== mods.control\n mods.control = !!ev.ctrlKey\n }\n if ('metaKey' in ev) {\n changed = changed || ev.metaKey !== mods.meta\n mods.meta = !!ev.metaKey\n }\n return changed\n }\n\n function handleEvent (nextButtons, ev) {\n var nextX = mouse.x(ev)\n var nextY = mouse.y(ev)\n if ('buttons' in ev) {\n nextButtons = ev.buttons | 0\n }\n if (nextButtons !== buttonState ||\n nextX !== x ||\n nextY !== y ||\n updateMods(ev)) {\n buttonState = nextButtons | 0\n x = nextX || 0\n y = nextY || 0\n callback && callback(buttonState, x, y, mods)\n }\n }\n\n function clearState (ev) {\n handleEvent(0, ev)\n }\n\n function handleBlur () {\n if (buttonState ||\n x ||\n y ||\n mods.shift ||\n mods.alt ||\n mods.meta ||\n mods.control) {\n x = y = 0\n buttonState = 0\n mods.shift = mods.alt = mods.control = mods.meta = false\n callback && callback(0, 0, 0, mods)\n }\n }\n\n function handleMods (ev) {\n if (updateMods(ev)) {\n callback && callback(buttonState, x, y, mods)\n }\n }\n\n function handleMouseMove (ev) {\n if (mouse.buttons(ev) === 0) {\n handleEvent(0, ev)\n } else {\n handleEvent(buttonState, ev)\n }\n }\n\n function handleMouseDown (ev) {\n handleEvent(buttonState | mouse.buttons(ev), ev)\n }\n\n function handleMouseUp (ev) {\n handleEvent(buttonState & ~mouse.buttons(ev), ev)\n }\n\n function attachListeners () {\n if (attached) {\n return\n }\n attached = true\n\n element.addEventListener('mousemove', handleMouseMove)\n\n element.addEventListener('mousedown', handleMouseDown)\n\n element.addEventListener('mouseup', handleMouseUp)\n\n element.addEventListener('mouseleave', clearState)\n element.addEventListener('mouseenter', clearState)\n element.addEventListener('mouseout', clearState)\n element.addEventListener('mouseover', clearState)\n\n element.addEventListener('blur', handleBlur)\n\n element.addEventListener('keyup', handleMods)\n element.addEventListener('keydown', handleMods)\n element.addEventListener('keypress', handleMods)\n\n if (element !== window) {\n window.addEventListener('blur', handleBlur)\n\n window.addEventListener('keyup', handleMods)\n window.addEventListener('keydown', handleMods)\n window.addEventListener('keypress', handleMods)\n }\n }\n\n function detachListeners () {\n if (!attached) {\n return\n }\n attached = false\n\n element.removeEventListener('mousemove', handleMouseMove)\n\n element.removeEventListener('mousedown', handleMouseDown)\n\n element.removeEventListener('mouseup', handleMouseUp)\n\n element.removeEventListener('mouseleave', clearState)\n element.removeEventListener('mouseenter', clearState)\n element.removeEventListener('mouseout', clearState)\n element.removeEventListener('mouseover', clearState)\n\n element.removeEventListener('blur', handleBlur)\n\n element.removeEventListener('keyup', handleMods)\n element.removeEventListener('keydown', handleMods)\n element.removeEventListener('keypress', handleMods)\n\n if (element !== window) {\n window.removeEventListener('blur', handleBlur)\n\n window.removeEventListener('keyup', handleMods)\n window.removeEventListener('keydown', handleMods)\n window.removeEventListener('keypress', handleMods)\n }\n }\n\n // Attach listeners\n attachListeners()\n\n var result = {\n element: element\n }\n\n Object.defineProperties(result, {\n enabled: {\n get: function () { return attached },\n set: function (f) {\n if (f) {\n attachListeners()\n } else {\n detachListeners()\n }\n },\n enumerable: true\n },\n buttons: {\n get: function () { return buttonState },\n enumerable: true\n },\n x: {\n get: function () { return x },\n enumerable: true\n },\n y: {\n get: function () { return y },\n enumerable: true\n },\n mods: {\n get: function () { return mods },\n enumerable: true\n }\n })\n\n return result\n}\n\n\n/***/ }),\n\n/***/ 24:\n/***/ (function(module) {\n\nvar rootPosition = { left: 0, top: 0 }\n\nmodule.exports = mouseEventOffset\nfunction mouseEventOffset (ev, target, out) {\n target = target || ev.currentTarget || ev.srcElement\n if (!Array.isArray(out)) {\n out = [ 0, 0 ]\n }\n var cx = ev.clientX || 0\n var cy = ev.clientY || 0\n var rect = getBoundingClientOffset(target)\n out[0] = cx - rect.left\n out[1] = cy - rect.top\n return out\n}\n\nfunction getBoundingClientOffset (element) {\n if (element === window ||\n element === document ||\n element === document.body) {\n return rootPosition\n } else {\n return element.getBoundingClientRect()\n }\n}\n\n\n/***/ }),\n\n/***/ 4687:\n/***/ (function(__unused_webpack_module, exports) {\n\n\"use strict\";\n\n\nfunction mouseButtons(ev) {\n if(typeof ev === 'object') {\n if('buttons' in ev) {\n return ev.buttons\n } else if('which' in ev) {\n var b = ev.which\n if(b === 2) {\n return 4\n } else if(b === 3) {\n return 2\n } else if(b > 0) {\n return 1<<(b-1)\n }\n } else if('button' in ev) {\n var b = ev.button\n if(b === 1) {\n return 4\n } else if(b === 2) {\n return 2\n } else if(b >= 0) {\n return 1< 0) {\n i1 = 1\n P[X++] = phase(d0[p0], x0, x1, x2)\n p0 += u0_0\n if (s0 > 0) {\n i0 = 1\n c0_0 = d0[p0]\n b0 = P[X] = phase(c0_0, x0, x1, x2)\n b1 = P[X + e1]\n b2 = P[X + e2]\n b3 = P[X + e3]\n if (b0 !== b1 || b0 !== b2 || b0 !== b3) {\n c0_1 = d0[p0 + d0_1]\n c0_2 = d0[p0 + d0_2]\n c0_3 = d0[p0 + d0_3]\n vertex(i0, i1, c0_0, c0_1, c0_2, c0_3, b0, b1, b2, b3, x0, x1, x2)\n v0 = V[X] = N++\n }\n X += 1\n p0 += u0_0\n for (i0 = 2; i0 < s0; ++i0) {\n c0_0 = d0[p0]\n b0 = P[X] = phase(c0_0, x0, x1, x2)\n b1 = P[X + e1]\n b2 = P[X + e2]\n b3 = P[X + e3]\n if (b0 !== b1 || b0 !== b2 || b0 !== b3) {\n c0_1 = d0[p0 + d0_1]\n c0_2 = d0[p0 + d0_2]\n c0_3 = d0[p0 + d0_3]\n vertex(i0, i1, c0_0, c0_1, c0_2, c0_3, b0, b1, b2, b3, x0, x1, x2)\n v0 = V[X] = N++\n if (b3 !== b1) {\n face(V[X + e1], v0, c0_3, c0_1, b3, b1, x0, x1, x2)\n }\n }\n X += 1\n p0 += u0_0\n }\n }\n p0 += u0_1\n X = 0\n T = e1\n e1 = y1\n y1 = T\n T = e2\n e2 = y2\n y2 = T\n T = e3\n e3 = y3\n y3 = T\n for (i1 = 2; i1 < s1; ++i1) {\n P[X++] = phase(d0[p0], x0, x1, x2)\n p0 += u0_0\n if (s0 > 0) {\n i0 = 1\n c0_0 = d0[p0]\n b0 = P[X] = phase(c0_0, x0, x1, x2)\n b1 = P[X + e1]\n b2 = P[X + e2]\n b3 = P[X + e3]\n if (b0 !== b1 || b0 !== b2 || b0 !== b3) {\n c0_1 = d0[p0 + d0_1]\n c0_2 = d0[p0 + d0_2]\n c0_3 = d0[p0 + d0_3]\n vertex(i0, i1, c0_0, c0_1, c0_2, c0_3, b0, b1, b2, b3, x0, x1, x2)\n v0 = V[X] = N++\n if (b3 !== b2) {\n face(V[X + e2], v0, c0_2, c0_3, b2, b3, x0, x1, x2)\n }\n }\n X += 1\n p0 += u0_0\n for (i0 = 2; i0 < s0; ++i0) {\n c0_0 = d0[p0]\n b0 = P[X] = phase(c0_0, x0, x1, x2)\n b1 = P[X + e1]\n b2 = P[X + e2]\n b3 = P[X + e3]\n if (b0 !== b1 || b0 !== b2 || b0 !== b3) {\n c0_1 = d0[p0 + d0_1]\n c0_2 = d0[p0 + d0_2]\n c0_3 = d0[p0 + d0_3]\n vertex(i0, i1, c0_0, c0_1, c0_2, c0_3, b0, b1, b2, b3, x0, x1, x2)\n v0 = V[X] = N++\n if (b3 !== b2) {\n face(V[X + e2], v0, c0_2, c0_3, b2, b3, x0, x1, x2)\n }\n if (b3 !== b1) {\n face(V[X + e1], v0, c0_3, c0_1, b3, b1, x0, x1, x2)\n }\n }\n X += 1\n p0 += u0_0\n }\n }\n if (i1 & 1) {\n X = 0\n }\n T = e1\n e1 = y1\n y1 = T\n T = e2\n e2 = y2\n y2 = T\n T = e3\n e3 = y3\n y3 = T\n p0 += u0_1\n }\n }\n freeUint32(V)\n freeUint32(P)\n }\n },\n \"false,1,0\": function anonymous(vertex, face, phase, mallocUint32, freeUint32) {\n return function extractContour1_0(a0, x0, x1, x2) {\n var s0 = a0.shape[0] | 0,\n s1 = a0.shape[1] | 0,\n d0 = a0.data,\n o0 = a0.offset | 0,\n t0_0 = a0.stride[0] | 0,\n t0_1 = a0.stride[1] | 0,\n p0 = o0,\n c0_0,\n d0_1 = -t0_0 | 0,\n c0_1 = 0,\n d0_2 = -t0_1 | 0,\n c0_2 = 0,\n d0_3 = (-t0_0 - t0_1) | 0,\n c0_3 = 0,\n u0_1 = t0_1 | 0,\n u0_0 = (t0_0 - t0_1 * s1) | 0,\n i0 = 0,\n i1 = 0,\n N = 0,\n Q = (2 * s1) | 0,\n P = mallocUint32(Q),\n V = mallocUint32(Q),\n X = 0,\n b0 = 0,\n e2 = -1 | 0,\n y2 = -1 | 0,\n b2 = 0,\n e1 = -s1 | 0,\n y1 = s1 | 0,\n b1 = 0,\n e3 = (-s1 - 1) | 0,\n y3 = (s1 - 1) | 0,\n b3 = 0,\n v0 = 0,\n T = 0\n for (i1 = 0; i1 < s1; ++i1) {\n P[X++] = phase(d0[p0], x0, x1, x2)\n p0 += u0_1\n }\n p0 += u0_0\n if (s0 > 0) {\n i0 = 1\n P[X++] = phase(d0[p0], x0, x1, x2)\n p0 += u0_1\n if (s1 > 0) {\n i1 = 1\n c0_0 = d0[p0]\n b0 = P[X] = phase(c0_0, x0, x1, x2)\n b1 = P[X + e1]\n b2 = P[X + e2]\n b3 = P[X + e3]\n if (b0 !== b1 || b0 !== b2 || b0 !== b3) {\n c0_1 = d0[p0 + d0_1]\n c0_2 = d0[p0 + d0_2]\n c0_3 = d0[p0 + d0_3]\n vertex(i0, i1, c0_0, c0_1, c0_2, c0_3, b0, b1, b2, b3, x0, x1, x2)\n v0 = V[X] = N++\n }\n X += 1\n p0 += u0_1\n for (i1 = 2; i1 < s1; ++i1) {\n c0_0 = d0[p0]\n b0 = P[X] = phase(c0_0, x0, x1, x2)\n b1 = P[X + e1]\n b2 = P[X + e2]\n b3 = P[X + e3]\n if (b0 !== b1 || b0 !== b2 || b0 !== b3) {\n c0_1 = d0[p0 + d0_1]\n c0_2 = d0[p0 + d0_2]\n c0_3 = d0[p0 + d0_3]\n vertex(i0, i1, c0_0, c0_1, c0_2, c0_3, b0, b1, b2, b3, x0, x1, x2)\n v0 = V[X] = N++\n if (b3 !== b2) {\n face(V[X + e2], v0, c0_2, c0_3, b2, b3, x0, x1, x2)\n }\n }\n X += 1\n p0 += u0_1\n }\n }\n p0 += u0_0\n X = 0\n T = e1\n e1 = y1\n y1 = T\n T = e2\n e2 = y2\n y2 = T\n T = e3\n e3 = y3\n y3 = T\n for (i0 = 2; i0 < s0; ++i0) {\n P[X++] = phase(d0[p0], x0, x1, x2)\n p0 += u0_1\n if (s1 > 0) {\n i1 = 1\n c0_0 = d0[p0]\n b0 = P[X] = phase(c0_0, x0, x1, x2)\n b1 = P[X + e1]\n b2 = P[X + e2]\n b3 = P[X + e3]\n if (b0 !== b1 || b0 !== b2 || b0 !== b3) {\n c0_1 = d0[p0 + d0_1]\n c0_2 = d0[p0 + d0_2]\n c0_3 = d0[p0 + d0_3]\n vertex(i0, i1, c0_0, c0_1, c0_2, c0_3, b0, b1, b2, b3, x0, x1, x2)\n v0 = V[X] = N++\n if (b3 !== b1) {\n face(V[X + e1], v0, c0_3, c0_1, b3, b1, x0, x1, x2)\n }\n }\n X += 1\n p0 += u0_1\n for (i1 = 2; i1 < s1; ++i1) {\n c0_0 = d0[p0]\n b0 = P[X] = phase(c0_0, x0, x1, x2)\n b1 = P[X + e1]\n b2 = P[X + e2]\n b3 = P[X + e3]\n if (b0 !== b1 || b0 !== b2 || b0 !== b3) {\n c0_1 = d0[p0 + d0_1]\n c0_2 = d0[p0 + d0_2]\n c0_3 = d0[p0 + d0_3]\n vertex(i0, i1, c0_0, c0_1, c0_2, c0_3, b0, b1, b2, b3, x0, x1, x2)\n v0 = V[X] = N++\n if (b3 !== b2) {\n face(V[X + e2], v0, c0_2, c0_3, b2, b3, x0, x1, x2)\n }\n if (b3 !== b1) {\n face(V[X + e1], v0, c0_3, c0_1, b3, b1, x0, x1, x2)\n }\n }\n X += 1\n p0 += u0_1\n }\n }\n if (i0 & 1) {\n X = 0\n }\n T = e1\n e1 = y1\n y1 = T\n T = e2\n e2 = y2\n y2 = T\n T = e3\n e3 = y3\n y3 = T\n p0 += u0_0\n }\n }\n freeUint32(V)\n freeUint32(P)\n }\n },\n}\n\n//Generates the surface procedure\nfunction compileSurfaceProcedure(vertexFunc, faceFunc, phaseFunc, scalarArgs, order, typesig) {\n var key = [typesig, order].join(',')\n var proc = allFns[key]\n\n return proc(\n vertexFunc,\n faceFunc,\n phaseFunc,\n pool.mallocUint32,\n pool.freeUint32)\n}\n\nfunction createSurfaceExtractor(args) {\n function error(msg) {\n throw new Error(\"ndarray-extract-contour: \" + msg)\n }\n if(typeof args !== \"object\") {\n error(\"Must specify arguments\")\n }\n var order = args.order\n if(!Array.isArray(order)) {\n error(\"Must specify order\")\n }\n var arrays = args.arrayArguments||1\n if(arrays < 1) {\n error(\"Must have at least one array argument\")\n }\n var scalars = args.scalarArguments||0\n if(scalars < 0) {\n error(\"Scalar arg count must be > 0\")\n }\n if(typeof args.vertex !== \"function\") {\n error(\"Must specify vertex creation function\")\n }\n if(typeof args.cell !== \"function\") {\n error(\"Must specify cell creation function\")\n }\n if(typeof args.phase !== \"function\") {\n error(\"Must specify phase function\")\n }\n var getters = args.getters || []\n var typesig = new Array(arrays)\n for(var i=0; i= 0) {\n typesig[i] = true\n } else {\n typesig[i] = false\n }\n }\n return compileSurfaceProcedure(\n args.vertex,\n args.cell,\n args.phase,\n scalars,\n order,\n typesig)\n}\n\n/***/ }),\n\n/***/ 6199:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar dup = __webpack_require__(1338)\n\nvar CACHED_CWiseOp = {\n zero: function(SS, a0, t0, p0) {\n var s0 = SS[0], t0p0 = t0[0]\n p0 |= 0\n var i0 = 0, d0s0 = t0p0\n for (i0 = 0; i0 < s0; ++i0) {\n a0[p0] = 0\n p0 += d0s0\n }\n },\n\n fdTemplate1: function(SS, a0, t0, p0, a1, t1, p1) {\n var s0 = SS[0], t0p0 = t0[0], t1p0 = t1[0], q0 = -1 * t0p0, q1 = t0p0\n p0 |= 0\n p1 |= 0\n var i0 = 0, d0s0 = t0p0, d1s0 = t1p0\n for (i0 = 0; i0 < s0; ++i0) {\n a1[p1] = 0.5 * (a0[p0 + q0] - a0[p0 + q1])\n p0 += d0s0\n p1 += d1s0\n }\n },\n\n fdTemplate2: function(SS, a0, t0, p0, a1, t1, p1, a2, t2, p2) {\n var s0 = SS[0], s1 = SS[1], t0p0 = t0[0], t0p1 = t0[1], t1p0 = t1[0], t1p1 = t1[1], t2p0 = t2[0], t2p1 = t2[1], q0 = -1 * t0p0, q1 = t0p0, q2 = -1 * t0p1, q3 = t0p1\n p0 |= 0\n p1 |= 0\n p2 |= 0\n var i0 = 0, i1 = 0, d0s0 = t0p1, d0s1 = (t0p0 - s1 * t0p1), d1s0 = t1p1, d1s1 = (t1p0 - s1 * t1p1), d2s0 = t2p1, d2s1 = (t2p0 - s1 * t2p1)\n for (i1 = 0; i1 < s0; ++i1) {\n for (i0 = 0; i0 < s1; ++i0) {\n a1[p1] = 0.5 * (a0[p0 + q0] - a0[p0 + q1]); a2[p2] = 0.5 * (a0[p0 + q2] - a0[p0 + q3])\n p0 += d0s0\n p1 += d1s0\n p2 += d2s0\n }\n p0 += d0s1\n p1 += d1s1\n p2 += d2s1\n }\n }\n}\n\nvar CACHED_thunk = {\n cdiff: function(compile) {\n var CACHED = {}\n return function cdiff_cwise_thunk(array0, array1, array2) {\n var t0 = array0.dtype, r0 = array0.order, t1 = array1.dtype, r1 = array1.order, t2 = array2.dtype, r2 = array2.order, type = [t0, r0.join(), t1, r1.join(), t2, r2.join()].join(), proc = CACHED[type]\n if (!proc) { CACHED[type] = proc = compile([t0, r0, t1, r1, t2, r2]) } return proc(array0.shape.slice(0), array0.data, array0.stride, array0.offset | 0, array1.data, array1.stride, array1.offset | 0, array2.data, array2.stride, array2.offset | 0)\n }\n },\n\n zero: function(compile) {\n var CACHED = {}\n return function zero_cwise_thunk(array0) {\n var t0 = array0.dtype, r0 = array0.order, type = [t0, r0.join()].join(), proc = CACHED[type]\n if (!proc) { CACHED[type] = proc = compile([t0, r0]) } return proc(array0.shape.slice(0), array0.data, array0.stride, array0.offset | 0)\n }\n },\n\n fdTemplate1: function(compile) {\n var CACHED = {}\n return function fdTemplate1_cwise_thunk(array0, array1) {\n var t0 = array0.dtype, r0 = array0.order, t1 = array1.dtype, r1 = array1.order, type = [t0, r0.join(), t1, r1.join()].join(), proc = CACHED[type]\n if (!proc) { CACHED[type] = proc = compile([t0, r0, t1, r1]) } return proc(array0.shape.slice(0), array0.data, array0.stride, array0.offset | 0, array1.data, array1.stride, array1.offset | 0)\n }\n },\n\n fdTemplate2: function(compile) {\n var CACHED = {}\n return function fdTemplate2_cwise_thunk(array0, array1, array4) {\n var t0 = array0.dtype, r0 = array0.order, t1 = array1.dtype, r1 = array1.order, t4 = array4.dtype, r4 = array4.order, type = [t0, r0.join(), t1, r1.join(), t4, r4.join()].join(), proc = CACHED[type]\n if (!proc) { CACHED[type] = proc = compile([t0, r0, t1, r1, t4, r4]) } return proc(array0.shape.slice(0), array0.data, array0.stride, array0.offset | 0, array1.data, array1.stride, array1.offset | 0, array4.data, array4.stride, array4.offset | 0)\n }\n },\n}\n\nfunction createThunk(proc) {\n var thunk = CACHED_thunk[proc.funcName]\n return thunk(compile.bind(undefined, proc))\n}\n\nfunction compile(proc) {\n return CACHED_CWiseOp[proc.funcName]\n}\n\nfunction cwiseCompiler(user_args) {\n return createThunk({\n funcName: user_args.funcName\n })\n}\n\n\nvar TEMPLATE_CACHE = {}\nvar GRADIENT_CACHE = {}\n\nvar EmptyProc = {\n body: \"\",\n args: [],\n thisVars: [],\n localVars: []\n}\n\nvar centralDiff = cwiseCompiler({\n funcName: 'cdiff'\n})\n\nvar zeroOut = cwiseCompiler({\n funcName: 'zero'\n})\n\nfunction generateTemplate(d) {\n if(d in TEMPLATE_CACHE) {\n return TEMPLATE_CACHE[d]\n }\n return TEMPLATE_CACHE[d] = cwiseCompiler({\n funcName: 'fdTemplate' + d\n })\n}\n\nfunction CACHED_link(diff, zero, grad1, grad2) {\n return function(dst, src) {\n var s = src.shape.slice()\n if ( true && s[0] > 2 && s[1] > 2) {\n grad2(\n src\n .pick(-1, -1)\n .lo(1, 1)\n .hi(s[0] - 2, s[1] - 2),\n dst\n .pick(-1, -1, 0)\n .lo(1, 1)\n .hi(s[0] - 2, s[1] - 2),\n dst\n .pick(-1, -1, 1)\n .lo(1, 1)\n .hi(s[0] - 2, s[1] - 2)\n )\n }\n if ( true && s[1] > 2) {\n grad1(\n src\n .pick(0, -1)\n .lo(1)\n .hi(s[1] - 2),\n dst\n .pick(0, -1, 1)\n .lo(1)\n .hi(s[1] - 2)\n )\n zero(\n dst\n .pick(0, -1, 0)\n .lo(1)\n .hi(s[1] - 2)\n )\n }\n if ( true && s[1] > 2) {\n grad1(\n src\n .pick(s[0] - 1, -1)\n .lo(1)\n .hi(s[1] - 2),\n dst\n .pick(s[0] - 1, -1, 1)\n .lo(1)\n .hi(s[1] - 2)\n )\n zero(\n dst\n .pick(s[0] - 1, -1, 0)\n .lo(1)\n .hi(s[1] - 2)\n )\n }\n if ( true && s[0] > 2) {\n grad1(\n src\n .pick(-1, 0)\n .lo(1)\n .hi(s[0] - 2),\n dst\n .pick(-1, 0, 0)\n .lo(1)\n .hi(s[0] - 2)\n )\n zero(\n dst\n .pick(-1, 0, 1)\n .lo(1)\n .hi(s[0] - 2)\n )\n }\n if ( true && s[0] > 2) {\n grad1(\n src\n .pick(-1, s[1] - 1)\n .lo(1)\n .hi(s[0] - 2),\n dst\n .pick(-1, s[1] - 1, 0)\n .lo(1)\n .hi(s[0] - 2)\n )\n zero(\n dst\n .pick(-1, s[1] - 1, 1)\n .lo(1)\n .hi(s[0] - 2)\n )\n }\n dst.set(0, 0, 0, 0)\n dst.set(0, 0, 1, 0)\n dst.set(s[0] - 1, 0, 0, 0)\n dst.set(s[0] - 1, 0, 1, 0)\n dst.set(0, s[1] - 1, 0, 0)\n dst.set(0, s[1] - 1, 1, 0)\n dst.set(s[0] - 1, s[1] - 1, 0, 0)\n dst.set(s[0] - 1, s[1] - 1, 1, 0)\n return dst\n }\n}\n\n\nfunction generateGradient(boundaryConditions) {\n var token = boundaryConditions.join()\n var proc = GRADIENT_CACHE[token]\n if(proc) {\n return proc\n }\n\n var d = boundaryConditions.length\n\n var linkArgs = [ centralDiff, zeroOut ]\n for(var i=1; i<=d; ++i) {\n linkArgs.push(generateTemplate(i))\n }\n\n var link = CACHED_link\n\n var proc = link.apply(void 0, linkArgs)\n\n GRADIENT_CACHE[token] = proc\n return proc\n}\n\nmodule.exports = function gradient(out, inp, bc) {\n if(!Array.isArray(bc)) {\n if(typeof bc === 'string') {\n bc = dup(inp.dimension, bc)\n } else {\n bc = dup(inp.dimension, 'clamp')\n }\n }\n if(inp.size === 0) {\n return out\n }\n if(inp.dimension === 0) {\n out.set(0)\n return out\n }\n var cached = generateGradient(bc)\n return cached(out, inp)\n}\n\n/***/ }),\n\n/***/ 4317:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nfunction interp1d(arr, x) {\n var ix = Math.floor(x)\n , fx = x - ix\n , s0 = 0 <= ix && ix < arr.shape[0]\n , s1 = 0 <= ix+1 && ix+1 < arr.shape[0]\n , w0 = s0 ? +arr.get(ix) : 0.0\n , w1 = s1 ? +arr.get(ix+1) : 0.0\n return (1.0-fx)*w0 + fx*w1\n}\n\nfunction interp2d(arr, x, y) {\n var ix = Math.floor(x)\n , fx = x - ix\n , s0 = 0 <= ix && ix < arr.shape[0]\n , s1 = 0 <= ix+1 && ix+1 < arr.shape[0]\n , iy = Math.floor(y)\n , fy = y - iy\n , t0 = 0 <= iy && iy < arr.shape[1]\n , t1 = 0 <= iy+1 && iy+1 < arr.shape[1]\n , w00 = s0&&t0 ? arr.get(ix ,iy ) : 0.0\n , w01 = s0&&t1 ? arr.get(ix ,iy+1) : 0.0\n , w10 = s1&&t0 ? arr.get(ix+1,iy ) : 0.0\n , w11 = s1&&t1 ? arr.get(ix+1,iy+1) : 0.0\n return (1.0-fy) * ((1.0-fx)*w00 + fx*w10) + fy * ((1.0-fx)*w01 + fx*w11)\n}\n\nfunction interp3d(arr, x, y, z) {\n var ix = Math.floor(x)\n , fx = x - ix\n , s0 = 0 <= ix && ix < arr.shape[0]\n , s1 = 0 <= ix+1 && ix+1 < arr.shape[0]\n , iy = Math.floor(y)\n , fy = y - iy\n , t0 = 0 <= iy && iy < arr.shape[1]\n , t1 = 0 <= iy+1 && iy+1 < arr.shape[1]\n , iz = Math.floor(z)\n , fz = z - iz\n , u0 = 0 <= iz && iz < arr.shape[2]\n , u1 = 0 <= iz+1 && iz+1 < arr.shape[2]\n , w000 = s0&&t0&&u0 ? arr.get(ix,iy,iz) : 0.0\n , w010 = s0&&t1&&u0 ? arr.get(ix,iy+1,iz) : 0.0\n , w100 = s1&&t0&&u0 ? arr.get(ix+1,iy,iz) : 0.0\n , w110 = s1&&t1&&u0 ? arr.get(ix+1,iy+1,iz) : 0.0\n , w001 = s0&&t0&&u1 ? arr.get(ix,iy,iz+1) : 0.0\n , w011 = s0&&t1&&u1 ? arr.get(ix,iy+1,iz+1) : 0.0\n , w101 = s1&&t0&&u1 ? arr.get(ix+1,iy,iz+1) : 0.0\n , w111 = s1&&t1&&u1 ? arr.get(ix+1,iy+1,iz+1) : 0.0\n return (1.0-fz) * ((1.0-fy) * ((1.0-fx)*w000 + fx*w100) + fy * ((1.0-fx)*w010 + fx*w110)) + fz * ((1.0-fy) * ((1.0-fx)*w001 + fx*w101) + fy * ((1.0-fx)*w011 + fx*w111))\n}\n\nfunction interpNd(arr) {\n var d = arr.shape.length|0\n , ix = new Array(d)\n , fx = new Array(d)\n , s0 = new Array(d)\n , s1 = new Array(d)\n , i, t\n for(i=0; i 0;) {\n if (j1 < 64) {\n s0 = j1\n j1 = 0\n } else {\n s0 = 64\n j1 -= 64\n }\n for (var j2 = SS[1] | 0; j2 > 0;) {\n if (j2 < 64) {\n s1 = j2\n j2 = 0\n } else {\n s1 = 64\n j2 -= 64\n }\n p0 = (offset0 + j1 * t0p0 + j2 * t0p1)\n p1 = (offset1 + j1 * t1p0 + j2 * t1p1)\n var i0 = 0, i1 = 0, i2 = 0, d0s0 = t0p2, d0s1 = (t0p0 - s2 * t0p2), d0s2 = (t0p1 - s0 * t0p0), d1s0 = t1p2, d1s1 = (t1p0 - s2 * t1p2), d1s2 = (t1p1 - s0 * t1p0)\n for (i2 = 0; i2 < s1; ++i2) {\n for (i1 = 0; i1 < s0; ++i1) {\n for (i0 = 0; i0 < s2; ++i0) {\n a0[p0] = a1[p1] * Y0\n p0 += d0s0\n p1 += d1s0\n }\n p0 += d0s1\n p1 += d1s1\n }\n p0 += d0s2\n p1 += d1s2\n }\n }\n }\n }\n },\n 'float32,1,0,float32,1,0': function () {\n return function assign_cwise_loop_1s0m2f32(SS, a0, t0, p0, a1, t1, p1) {\n var s0 = SS[0], s1 = SS[1], t0p0 = t0[0], t0p1 = t0[1], t1p0 = t1[0], t1p1 = t1[1]\n p0 |= 0\n p1 |= 0\n var i0 = 0, i1 = 0, d0s0 = t0p1, d0s1 = (t0p0 - s1 * t0p1), d1s0 = t1p1, d1s1 = (t1p0 - s1 * t1p1)\n for (i1 = 0; i1 < s0; ++i1) {\n for (i0 = 0; i0 < s1; ++i0) {\n a0[p0] = a1[p1]\n p0 += d0s0\n p1 += d1s0\n }\n p0 += d0s1\n p1 += d1s1\n }\n }\n },\n 'float32,1,0,float32,0,1': function () {\n return function assign_cwise_loop_1s0m0f32(SS, a0, t0, p0, a1, t1, p1) {\n var s0 = SS[0], s1 = SS[1], t0p0 = t0[0], t0p1 = t0[1], t1p0 = t1[0], t1p1 = t1[1]\n p0 |= 0\n p1 |= 0\n var offset0 = p0\n var offset1 = p1\n for (var j0 = SS[1] | 0; j0 > 0;) {\n if (j0 < 64) {\n s1 = j0\n j0 = 0\n } else {\n s1 = 64\n j0 -= 64\n }\n for (var j1 = SS[0] | 0; j1 > 0;) {\n if (j1 < 64) {\n s0 = j1\n j1 = 0\n } else {\n s0 = 64\n j1 -= 64\n }\n p0 = (offset0 + j0 * t0p1 + j1 * t0p0)\n p1 = (offset1 + j0 * t1p1 + j1 * t1p0)\n var i0 = 0, i1 = 0, d0s0 = t0p1, d0s1 = (t0p0 - s1 * t0p1), d1s0 = t1p1, d1s1 = (t1p0 - s1 * t1p1)\n for (i1 = 0; i1 < s0; ++i1) {\n for (i0 = 0; i0 < s1; ++i0) {\n a0[p0] = a1[p1]\n p0 += d0s0\n p1 += d1s0\n }\n p0 += d0s1\n p1 += d1s1\n }\n }\n }\n }\n },\n 'uint8,2,0,1,uint8,1,2,0': function () {\n return function assign_cwise_loop_2s0s1m0u8(SS, a0, t0, p0, a1, t1, p1) {\n var s0 = SS[0], s1 = SS[1], s2 = SS[2], t0p0 = t0[0], t0p1 = t0[1], t0p2 = t0[2], t1p0 = t1[0], t1p1 = t1[1], t1p2 = t1[2]\n p0 |= 0\n p1 |= 0\n var offset0 = p0\n var offset1 = p1\n for (var j0 = SS[2] | 0; j0 > 0;) {\n if (j0 < 64) {\n s2 = j0\n j0 = 0\n } else {\n s2 = 64\n j0 -= 64\n }\n for (var j1 = SS[0] | 0; j1 > 0;) {\n if (j1 < 64) {\n s0 = j1\n j1 = 0\n } else {\n s0 = 64\n j1 -= 64\n }\n for (var j2 = SS[1] | 0; j2 > 0;) {\n if (j2 < 64) {\n s1 = j2\n j2 = 0\n } else {\n s1 = 64\n j2 -= 64\n }\n p0 = (offset0 + j0 * t0p2 + j1 * t0p0 + j2 * t0p1)\n p1 = (offset1 + j0 * t1p2 + j1 * t1p0 + j2 * t1p1)\n var i0 = 0, i1 = 0, i2 = 0, d0s0 = t0p2, d0s1 = (t0p0 - s2 * t0p2), d0s2 = (t0p1 - s0 * t0p0), d1s0 = t1p2, d1s1 = (t1p0 - s2 * t1p2), d1s2 = (t1p1 - s0 * t1p0)\n for (i2 = 0; i2 < s1; ++i2) {\n for (i1 = 0; i1 < s0; ++i1) {\n for (i0 = 0; i0 < s2; ++i0) {\n a0[p0] = a1[p1]\n p0 += d0s0\n p1 += d1s0\n }\n p0 += d0s1\n p1 += d1s1\n }\n p0 += d0s2\n p1 += d1s2\n }\n }\n }\n }\n }\n },\n 'uint8,2,0,1,array,2,0,1': function () {\n return function assign_cwise_loop_2s0s1m3u8a(SS, a0, t0, p0, a1, t1, p1) {\n var s0 = SS[0], s1 = SS[1], s2 = SS[2], t0p0 = t0[0], t0p1 = t0[1], t0p2 = t0[2], t1p0 = t1[0], t1p1 = t1[1], t1p2 = t1[2]\n p0 |= 0\n p1 |= 0\n var i0 = 0, i1 = 0, i2 = 0, d0s0 = t0p2, d0s1 = (t0p0 - s2 * t0p2), d0s2 = (t0p1 - s0 * t0p0), d1s0 = t1p2, d1s1 = (t1p0 - s2 * t1p2), d1s2 = (t1p1 - s0 * t1p0)\n for (i2 = 0; i2 < s1; ++i2) {\n for (i1 = 0; i1 < s0; ++i1) {\n for (i0 = 0; i0 < s2; ++i0) {\n a0[p0] = a1[p1]\n p0 += d0s0\n p1 += d1s0\n }\n p0 += d0s1\n p1 += d1s1\n }\n p0 += d0s2\n p1 += d1s2\n }\n }\n },\n}\n\n//Generates a cwise operator\nfunction generateCWiseOp(proc, typesig) {\n var key = typesig.join(',')\n var f = CACHED_CWiseOp[key]\n return f()\n}\n\nvar compile = generateCWiseOp\n\nvar CACHED_thunk = {\n mul: function (compile) {\n var CACHED = {}\n return function mul_cwise_thunk(array0, array1, array2) {\n var t0 = array0.dtype,\n r0 = array0.order,\n t1 = array1.dtype,\n r1 = array1.order,\n t2 = array2.dtype,\n r2 = array2.order,\n type = [t0, r0.join(), t1, r1.join(), t2, r2.join()].join(),\n proc = CACHED[type]\n if (!proc) {\n CACHED[type] = proc = compile([t0, r0, t1, r1, t2, r2])\n }\n return proc(\n array0.shape.slice(0),\n array0.data,\n array0.stride,\n array0.offset | 0,\n array1.data,\n array1.stride,\n array1.offset | 0,\n array2.data,\n array2.stride,\n array2.offset | 0\n )\n }\n },\n muls: function (compile) {\n var CACHED = {}\n return function muls_cwise_thunk(array0, array1, scalar2) {\n var t0 = array0.dtype,\n r0 = array0.order,\n t1 = array1.dtype,\n r1 = array1.order,\n type = [t0, r0.join(), t1, r1.join()].join(),\n proc = CACHED[type]\n if (!proc) {\n CACHED[type] = proc = compile([t0, r0, t1, r1])\n }\n return proc(\n array0.shape.slice(0),\n array0.data,\n array0.stride,\n array0.offset | 0,\n array1.data,\n array1.stride,\n array1.offset | 0,\n scalar2\n )\n }\n },\n mulseq: function (compile) {\n var CACHED = {}\n return function mulseq_cwise_thunk(array0, scalar1) {\n var t0 = array0.dtype,\n r0 = array0.order,\n type = [t0, r0.join()].join(),\n proc = CACHED[type]\n if (!proc) {\n CACHED[type] = proc = compile([t0, r0])\n }\n return proc(array0.shape.slice(0), array0.data, array0.stride, array0.offset | 0, scalar1)\n }\n },\n div: function (compile) {\n var CACHED = {}\n return function div_cwise_thunk(array0, array1, array2) {\n var t0 = array0.dtype,\n r0 = array0.order,\n t1 = array1.dtype,\n r1 = array1.order,\n t2 = array2.dtype,\n r2 = array2.order,\n type = [t0, r0.join(), t1, r1.join(), t2, r2.join()].join(),\n proc = CACHED[type]\n if (!proc) {\n CACHED[type] = proc = compile([t0, r0, t1, r1, t2, r2])\n }\n return proc(\n array0.shape.slice(0),\n array0.data,\n array0.stride,\n array0.offset | 0,\n array1.data,\n array1.stride,\n array1.offset | 0,\n array2.data,\n array2.stride,\n array2.offset | 0\n )\n }\n },\n divs: function (compile) {\n var CACHED = {}\n return function divs_cwise_thunk(array0, array1, scalar2) {\n var t0 = array0.dtype,\n r0 = array0.order,\n t1 = array1.dtype,\n r1 = array1.order,\n type = [t0, r0.join(), t1, r1.join()].join(),\n proc = CACHED[type]\n if (!proc) {\n CACHED[type] = proc = compile([t0, r0, t1, r1])\n }\n return proc(\n array0.shape.slice(0),\n array0.data,\n array0.stride,\n array0.offset | 0,\n array1.data,\n array1.stride,\n array1.offset | 0,\n scalar2\n )\n }\n },\n divseq: function (compile) {\n var CACHED = {}\n return function divseq_cwise_thunk(array0, scalar1) {\n var t0 = array0.dtype,\n r0 = array0.order,\n type = [t0, r0.join()].join(),\n proc = CACHED[type]\n if (!proc) {\n CACHED[type] = proc = compile([t0, r0])\n }\n return proc(array0.shape.slice(0), array0.data, array0.stride, array0.offset | 0, scalar1)\n }\n },\n assign: function (compile) {\n var CACHED = {}\n return function assign_cwise_thunk(array0, array1) {\n var t0 = array0.dtype,\n r0 = array0.order,\n t1 = array1.dtype,\n r1 = array1.order,\n type = [t0, r0.join(), t1, r1.join()].join(),\n proc = CACHED[type]\n if (!proc) {\n CACHED[type] = proc = compile([t0, r0, t1, r1])\n }\n return proc(\n array0.shape.slice(0),\n array0.data,\n array0.stride,\n array0.offset | 0,\n array1.data,\n array1.stride,\n array1.offset | 0\n )\n }\n },\n}\n\nfunction createThunk(proc) {\n var thunk = CACHED_thunk[proc.funcName]\n return thunk(compile.bind(undefined, proc))\n}\n\nfunction makeOp(user_args) {\n return createThunk({\n funcName: user_args.funcName\n })\n}\n\nvar assign_ops = {\n mul: \"*\",\n div: \"/\",\n}\n;(function(){\n for(var id in assign_ops) {\n exports[id] = makeOp({\n funcName: id\n })\n exports[id+\"s\"] = makeOp({\n funcName: id+\"s\"\n })\n exports[id+\"seq\"] = makeOp({\n funcName: id+\"seq\"\n })\n }\n})();\n\nexports.assign = makeOp({\n funcName: \"assign\" })\n\n\n/***/ }),\n\n/***/ 9994:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar ndarray = __webpack_require__(9618)\nvar do_convert = __webpack_require__(8277)\n\nmodule.exports = function convert(arr, result) {\n var shape = [], c = arr, sz = 1\n while(Array.isArray(c)) {\n shape.push(c.length)\n sz *= c.length\n c = c[0]\n }\n if(shape.length === 0) {\n return ndarray()\n }\n if(!result) {\n result = ndarray(new Float64Array(sz), shape)\n }\n do_convert(result, arr)\n return result\n}\n\n\n/***/ }),\n\n/***/ 8277:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nfunction CwiseOp() {\n return function (SS, a0, t0, p0, Y0) {\n var s0 = SS[0],\n s1 = SS[1],\n s2 = SS[2],\n t0p0 = t0[0],\n t0p1 = t0[1],\n t0p2 = t0[2],\n index = [0, 0, 0];\n p0 |= 0;\n var i0 = 0,\n i1 = 0,\n i2 = 0,\n d0s0 = t0p2,\n d0s1 = t0p1 - s2 * t0p2,\n d0s2 = t0p0 - s1 * t0p1;\n for (i2 = 0; i2 < s0; ++i2) {\n for (i1 = 0; i1 < s1; ++i1) {\n for (i0 = 0; i0 < s2; ++i0) {\n {\n var _inline_1_v = Y0,\n _inline_1_i;\n for (\n _inline_1_i = 0;\n _inline_1_i < index.length - 1;\n ++_inline_1_i\n ) {\n _inline_1_v = _inline_1_v[index[_inline_1_i]];\n }\n a0[p0] = _inline_1_v[index[index.length - 1]];\n }\n p0 += d0s0;\n ++index[2];\n }\n p0 += d0s1;\n index[2] -= s2;\n ++index[1];\n }\n p0 += d0s2;\n index[1] -= s1;\n ++index[0];\n }\n };\n}\n\n//Generates a cwise operator\nfunction generateCWiseOp() {\n return CwiseOp()\n}\n\nvar compile = generateCWiseOp\n\nfunction thunk(compile) {\n var CACHED = {};\n return function convert_cwise_thunk(array0, scalar1) {\n var t0 = array0.dtype,\n r0 = array0.order,\n type = [t0, r0.join()].join(),\n proc = CACHED[type];\n if (!proc) {\n CACHED[type] = proc = compile([t0, r0]);\n }\n return proc(\n array0.shape.slice(0),\n array0.data,\n array0.stride,\n array0.offset | 0,\n scalar1\n );\n };\n}\n\nfunction createThunk(proc) {\n return thunk(compile.bind(undefined, proc))\n}\n\nfunction compileCwise(user_args) {\n return createThunk({\n funcName: user_args.funcName\n })\n}\n\nmodule.exports = compileCwise({\n funcName: \"convert\"\n});\n\n\n/***/ }),\n\n/***/ 7640:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar pool = __webpack_require__(1888)\n\nfunction getMallocFree(dtype) {\n switch(dtype) {\n case \"uint32\":\n return [pool.mallocUint32, pool.freeUint32]\n default:\n return null\n }\n}\n\nvar CACHED_insertionSort = {\n \"uint32,1,0\": function (malloc, free) {\n return function ndarrayInsertionSort1d0uint32(left, right, data, offset, s0, s1, n0, n1, d1, e1, f1) {\n var i,\n j,\n cptr,\n ptr = left * s0 + offset,\n i1,\n scratch = malloc(n1),\n dptr,\n sptr,\n a,\n b\n for (i = left + 1; i <= right; ++i) {\n j = i\n ptr += s0\n cptr = ptr\n dptr = 0\n sptr = ptr\n for (i1 = 0; i1 < n1; ++i1) {\n scratch[dptr++] = data[sptr]\n sptr += d1\n }\n __g: while (j-- > left) {\n dptr = 0\n sptr = cptr - s0\n __l: for (i1 = 0; i1 < n1; ++i1) {\n a = data[sptr]\n b = scratch[dptr]\n if (a < b) {\n break __g\n }\n if (a > b) {\n break __l\n }\n sptr += e1\n dptr += f1\n }\n dptr = cptr\n sptr = cptr - s0\n for (i1 = 0; i1 < n1; ++i1) {\n data[dptr] = data[sptr]\n dptr += d1\n sptr += d1\n }\n cptr -= s0\n }\n dptr = cptr\n sptr = 0\n for (i1 = 0; i1 < n1; ++i1) {\n data[dptr] = scratch[sptr++]\n dptr += d1\n }\n }\n free(scratch)\n }\n },\n}\n\nfunction createInsertionSort(order, dtype) {\n var allocator = getMallocFree(dtype)\n var key = [dtype, order].join(',')\n var result = CACHED_insertionSort[key]\n\n if(allocator) {\n return result(allocator[0], allocator[1])\n } else {\n return result()\n }\n}\n\nvar CACHED_quickSort = {\n \"uint32,1,0\": function (insertionSort, malloc, free) {\n return function ndarrayQuickSort1d0uint32(left, right, data, offset, s0, s1, n0, n1, d1, e1, f1) {\n var sixth = ((right - left + 1) / 6) | 0,\n index1 = left + sixth,\n index5 = right - sixth,\n index3 = (left + right) >> 1,\n index2 = index3 - sixth,\n index4 = index3 + sixth,\n el1 = index1,\n el2 = index2,\n el3 = index3,\n el4 = index4,\n el5 = index5,\n less = left + 1,\n great = right - 1,\n pivots_are_equal = true,\n tmp,\n tmp0,\n x,\n y,\n z,\n k,\n ptr0,\n ptr1,\n ptr2,\n comp_pivot1 = 0,\n comp_pivot2 = 0,\n comp = 0,\n i1,\n b_ptr0,\n b_ptr1,\n b_ptr2,\n b_ptr3,\n b_ptr4,\n b_ptr5,\n b_ptr6,\n b_ptr7,\n ptr3,\n ptr4,\n ptr5,\n ptr6,\n ptr7,\n pivot_ptr,\n ptr_shift,\n elementSize = n1,\n pivot1 = malloc(elementSize),\n pivot2 = malloc(elementSize)\n b_ptr0 = s0 * el1\n b_ptr1 = s0 * el2\n ptr_shift = offset\n __l1: for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n comp = data[ptr0] - data[ptr1]\n if (comp > 0) {\n tmp0 = el1\n el1 = el2\n el2 = tmp0\n break __l1\n }\n if (comp < 0) {\n break __l1\n }\n ptr_shift += e1\n }\n b_ptr0 = s0 * el4\n b_ptr1 = s0 * el5\n ptr_shift = offset\n __l2: for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n comp = data[ptr0] - data[ptr1]\n if (comp > 0) {\n tmp0 = el4\n el4 = el5\n el5 = tmp0\n break __l2\n }\n if (comp < 0) {\n break __l2\n }\n ptr_shift += e1\n }\n b_ptr0 = s0 * el1\n b_ptr1 = s0 * el3\n ptr_shift = offset\n __l3: for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n comp = data[ptr0] - data[ptr1]\n if (comp > 0) {\n tmp0 = el1\n el1 = el3\n el3 = tmp0\n break __l3\n }\n if (comp < 0) {\n break __l3\n }\n ptr_shift += e1\n }\n b_ptr0 = s0 * el2\n b_ptr1 = s0 * el3\n ptr_shift = offset\n __l4: for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n comp = data[ptr0] - data[ptr1]\n if (comp > 0) {\n tmp0 = el2\n el2 = el3\n el3 = tmp0\n break __l4\n }\n if (comp < 0) {\n break __l4\n }\n ptr_shift += e1\n }\n b_ptr0 = s0 * el1\n b_ptr1 = s0 * el4\n ptr_shift = offset\n __l5: for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n comp = data[ptr0] - data[ptr1]\n if (comp > 0) {\n tmp0 = el1\n el1 = el4\n el4 = tmp0\n break __l5\n }\n if (comp < 0) {\n break __l5\n }\n ptr_shift += e1\n }\n b_ptr0 = s0 * el3\n b_ptr1 = s0 * el4\n ptr_shift = offset\n __l6: for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n comp = data[ptr0] - data[ptr1]\n if (comp > 0) {\n tmp0 = el3\n el3 = el4\n el4 = tmp0\n break __l6\n }\n if (comp < 0) {\n break __l6\n }\n ptr_shift += e1\n }\n b_ptr0 = s0 * el2\n b_ptr1 = s0 * el5\n ptr_shift = offset\n __l7: for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n comp = data[ptr0] - data[ptr1]\n if (comp > 0) {\n tmp0 = el2\n el2 = el5\n el5 = tmp0\n break __l7\n }\n if (comp < 0) {\n break __l7\n }\n ptr_shift += e1\n }\n b_ptr0 = s0 * el2\n b_ptr1 = s0 * el3\n ptr_shift = offset\n __l8: for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n comp = data[ptr0] - data[ptr1]\n if (comp > 0) {\n tmp0 = el2\n el2 = el3\n el3 = tmp0\n break __l8\n }\n if (comp < 0) {\n break __l8\n }\n ptr_shift += e1\n }\n b_ptr0 = s0 * el4\n b_ptr1 = s0 * el5\n ptr_shift = offset\n __l9: for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n comp = data[ptr0] - data[ptr1]\n if (comp > 0) {\n tmp0 = el4\n el4 = el5\n el5 = tmp0\n break __l9\n }\n if (comp < 0) {\n break __l9\n }\n ptr_shift += e1\n }\n b_ptr0 = s0 * el1\n b_ptr1 = s0 * el2\n b_ptr2 = s0 * el3\n b_ptr3 = s0 * el4\n b_ptr4 = s0 * el5\n b_ptr5 = s0 * index1\n b_ptr6 = s0 * index3\n b_ptr7 = s0 * index5\n pivot_ptr = 0\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n ptr2 = b_ptr2 + ptr_shift\n ptr3 = b_ptr3 + ptr_shift\n ptr4 = b_ptr4 + ptr_shift\n ptr5 = b_ptr5 + ptr_shift\n ptr6 = b_ptr6 + ptr_shift\n ptr7 = b_ptr7 + ptr_shift\n pivot1[pivot_ptr] = data[ptr1]\n pivot2[pivot_ptr] = data[ptr3]\n pivots_are_equal = pivots_are_equal && pivot1[pivot_ptr] === pivot2[pivot_ptr]\n x = data[ptr0]\n y = data[ptr2]\n z = data[ptr4]\n data[ptr5] = x\n data[ptr6] = y\n data[ptr7] = z\n ++pivot_ptr\n ptr_shift += d1\n }\n b_ptr0 = s0 * index2\n b_ptr1 = s0 * left\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n data[ptr0] = data[ptr1]\n ptr_shift += d1\n }\n b_ptr0 = s0 * index4\n b_ptr1 = s0 * right\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n data[ptr0] = data[ptr1]\n ptr_shift += d1\n }\n if (pivots_are_equal) {\n for (k = less; k <= great; ++k) {\n ptr0 = offset + k * s0\n pivot_ptr = 0\n __l10: for (i1 = 0; i1 < n1; ++i1) {\n comp = data[ptr0] - pivot1[pivot_ptr]\n if (comp !== 0) {\n break __l10\n }\n pivot_ptr += f1\n ptr0 += e1\n }\n if (comp === 0) {\n continue\n }\n if (comp < 0) {\n if (k !== less) {\n b_ptr0 = s0 * k\n b_ptr1 = s0 * less\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n tmp = data[ptr0]\n data[ptr0] = data[ptr1]\n data[ptr1] = tmp\n ptr_shift += d1\n }\n }\n ++less\n } else {\n while (true) {\n ptr0 = offset + great * s0\n pivot_ptr = 0\n __l11: for (i1 = 0; i1 < n1; ++i1) {\n comp = data[ptr0] - pivot1[pivot_ptr]\n if (comp !== 0) {\n break __l11\n }\n pivot_ptr += f1\n ptr0 += e1\n }\n if (comp > 0) {\n great--\n } else if (comp < 0) {\n b_ptr0 = s0 * k\n b_ptr1 = s0 * less\n b_ptr2 = s0 * great\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n ptr2 = b_ptr2 + ptr_shift\n tmp = data[ptr0]\n data[ptr0] = data[ptr1]\n data[ptr1] = data[ptr2]\n data[ptr2] = tmp\n ptr_shift += d1\n }\n ++less\n --great\n break\n } else {\n b_ptr0 = s0 * k\n b_ptr1 = s0 * great\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n tmp = data[ptr0]\n data[ptr0] = data[ptr1]\n data[ptr1] = tmp\n ptr_shift += d1\n }\n --great\n break\n }\n }\n }\n }\n } else {\n for (k = less; k <= great; ++k) {\n ptr0 = offset + k * s0\n pivot_ptr = 0\n __l12: for (i1 = 0; i1 < n1; ++i1) {\n comp_pivot1 = data[ptr0] - pivot1[pivot_ptr]\n if (comp_pivot1 !== 0) {\n break __l12\n }\n pivot_ptr += f1\n ptr0 += e1\n }\n if (comp_pivot1 < 0) {\n if (k !== less) {\n b_ptr0 = s0 * k\n b_ptr1 = s0 * less\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n tmp = data[ptr0]\n data[ptr0] = data[ptr1]\n data[ptr1] = tmp\n ptr_shift += d1\n }\n }\n ++less\n } else {\n ptr0 = offset + k * s0\n pivot_ptr = 0\n __l13: for (i1 = 0; i1 < n1; ++i1) {\n comp_pivot2 = data[ptr0] - pivot2[pivot_ptr]\n if (comp_pivot2 !== 0) {\n break __l13\n }\n pivot_ptr += f1\n ptr0 += e1\n }\n if (comp_pivot2 > 0) {\n while (true) {\n ptr0 = offset + great * s0\n pivot_ptr = 0\n __l14: for (i1 = 0; i1 < n1; ++i1) {\n comp = data[ptr0] - pivot2[pivot_ptr]\n if (comp !== 0) {\n break __l14\n }\n pivot_ptr += f1\n ptr0 += e1\n }\n if (comp > 0) {\n if (--great < k) {\n break\n }\n continue\n } else {\n ptr0 = offset + great * s0\n pivot_ptr = 0\n __l15: for (i1 = 0; i1 < n1; ++i1) {\n comp = data[ptr0] - pivot1[pivot_ptr]\n if (comp !== 0) {\n break __l15\n }\n pivot_ptr += f1\n ptr0 += e1\n }\n if (comp < 0) {\n b_ptr0 = s0 * k\n b_ptr1 = s0 * less\n b_ptr2 = s0 * great\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n ptr2 = b_ptr2 + ptr_shift\n tmp = data[ptr0]\n data[ptr0] = data[ptr1]\n data[ptr1] = data[ptr2]\n data[ptr2] = tmp\n ptr_shift += d1\n }\n ++less\n --great\n } else {\n b_ptr0 = s0 * k\n b_ptr1 = s0 * great\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n tmp = data[ptr0]\n data[ptr0] = data[ptr1]\n data[ptr1] = tmp\n ptr_shift += d1\n }\n --great\n }\n break\n }\n }\n }\n }\n }\n }\n b_ptr0 = s0 * left\n b_ptr1 = s0 * (less - 1)\n pivot_ptr = 0\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n data[ptr0] = data[ptr1]\n data[ptr1] = pivot1[pivot_ptr]\n ++pivot_ptr\n ptr_shift += d1\n }\n b_ptr0 = s0 * right\n b_ptr1 = s0 * (great + 1)\n pivot_ptr = 0\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n data[ptr0] = data[ptr1]\n data[ptr1] = pivot2[pivot_ptr]\n ++pivot_ptr\n ptr_shift += d1\n }\n if (less - 2 - left <= 32) {\n insertionSort(left, less - 2, data, offset, s0, s1, n0, n1, d1, e1, f1)\n } else {\n ndarrayQuickSort1d0uint32(left, less - 2, data, offset, s0, s1, n0, n1, d1, e1, f1)\n }\n if (right - (great + 2) <= 32) {\n insertionSort(great + 2, right, data, offset, s0, s1, n0, n1, d1, e1, f1)\n } else {\n ndarrayQuickSort1d0uint32(great + 2, right, data, offset, s0, s1, n0, n1, d1, e1, f1)\n }\n if (pivots_are_equal) {\n free(pivot1)\n free(pivot2)\n return\n }\n if (less < index1 && great > index5) {\n __l16: while (true) {\n ptr0 = offset + less * s0\n pivot_ptr = 0\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n if (data[ptr0] !== pivot1[pivot_ptr]) {\n break __l16\n }\n ++pivot_ptr\n ptr0 += d1\n }\n ++less\n }\n __l17: while (true) {\n ptr0 = offset + great * s0\n pivot_ptr = 0\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n if (data[ptr0] !== pivot2[pivot_ptr]) {\n break __l17\n }\n ++pivot_ptr\n ptr0 += d1\n }\n --great\n }\n for (k = less; k <= great; ++k) {\n ptr0 = offset + k * s0\n pivot_ptr = 0\n __l18: for (i1 = 0; i1 < n1; ++i1) {\n comp_pivot1 = data[ptr0] - pivot1[pivot_ptr]\n if (comp_pivot1 !== 0) {\n break __l18\n }\n pivot_ptr += f1\n ptr0 += e1\n }\n if (comp_pivot1 === 0) {\n if (k !== less) {\n b_ptr0 = s0 * k\n b_ptr1 = s0 * less\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n tmp = data[ptr0]\n data[ptr0] = data[ptr1]\n data[ptr1] = tmp\n ptr_shift += d1\n }\n }\n ++less\n } else {\n ptr0 = offset + k * s0\n pivot_ptr = 0\n __l19: for (i1 = 0; i1 < n1; ++i1) {\n comp_pivot2 = data[ptr0] - pivot2[pivot_ptr]\n if (comp_pivot2 !== 0) {\n break __l19\n }\n pivot_ptr += f1\n ptr0 += e1\n }\n if (comp_pivot2 === 0) {\n while (true) {\n ptr0 = offset + great * s0\n pivot_ptr = 0\n __l20: for (i1 = 0; i1 < n1; ++i1) {\n comp = data[ptr0] - pivot2[pivot_ptr]\n if (comp !== 0) {\n break __l20\n }\n pivot_ptr += f1\n ptr0 += e1\n }\n if (comp === 0) {\n if (--great < k) {\n break\n }\n continue\n } else {\n ptr0 = offset + great * s0\n pivot_ptr = 0\n __l21: for (i1 = 0; i1 < n1; ++i1) {\n comp = data[ptr0] - pivot1[pivot_ptr]\n if (comp !== 0) {\n break __l21\n }\n pivot_ptr += f1\n ptr0 += e1\n }\n if (comp < 0) {\n b_ptr0 = s0 * k\n b_ptr1 = s0 * less\n b_ptr2 = s0 * great\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n ptr2 = b_ptr2 + ptr_shift\n tmp = data[ptr0]\n data[ptr0] = data[ptr1]\n data[ptr1] = data[ptr2]\n data[ptr2] = tmp\n ptr_shift += d1\n }\n ++less\n --great\n } else {\n b_ptr0 = s0 * k\n b_ptr1 = s0 * great\n ptr_shift = offset\n for (i1 = 0; i1 < n1; ++i1) {\n ptr0 = b_ptr0 + ptr_shift\n ptr1 = b_ptr1 + ptr_shift\n tmp = data[ptr0]\n data[ptr0] = data[ptr1]\n data[ptr1] = tmp\n ptr_shift += d1\n }\n --great\n }\n break\n }\n }\n }\n }\n }\n }\n free(pivot1)\n free(pivot2)\n if (great - less <= 32) {\n insertionSort(less, great, data, offset, s0, s1, n0, n1, d1, e1, f1)\n } else {\n ndarrayQuickSort1d0uint32(less, great, data, offset, s0, s1, n0, n1, d1, e1, f1)\n }\n }\n },\n}\n\nfunction createQuickSort(order, dtype, insertionSort) {\n var allocator = getMallocFree(dtype)\n var key = [dtype, order].join(',')\n var result = CACHED_quickSort[key]\n\n if(order.length > 1 && allocator) {\n return result(insertionSort, allocator[0], allocator[1])\n } else {\n return result(insertionSort)\n }\n}\n\nvar CACHED_sort = {\n \"uint32,1,0\": function (insertionSort, quickSort) {\n return function (array) {\n var data = array.data,\n offset = array.offset | 0,\n shape = array.shape,\n stride = array.stride,\n s0 = stride[0] | 0,\n n0 = shape[0] | 0,\n s1 = stride[1] | 0,\n n1 = shape[1] | 0,\n d1 = s1,\n e1 = s1,\n f1 = 1\n if (n0 <= 32) {\n insertionSort(0, n0 - 1, data, offset, s0, s1, n0, n1, d1, e1, f1)\n } else {\n quickSort(0, n0 - 1, data, offset, s0, s1, n0, n1, d1, e1, f1)\n }\n }\n },\n}\n\nfunction compileSort(order, dtype) {\n var key = [dtype, order].join(',')\n var result = CACHED_sort[key]\n\n var insertionSort = createInsertionSort(order, dtype)\n var quickSort = createQuickSort(order, dtype, insertionSort)\n return result(insertionSort, quickSort)\n}\n\nmodule.exports = compileSort\n\n/***/ }),\n\n/***/ 446:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar compile = __webpack_require__(7640)\nvar CACHE = {}\n\nfunction sort(array) {\n var order = array.order\n var dtype = array.dtype\n var typeSig = [order, dtype ]\n var typeName = typeSig.join(\":\")\n var compiled = CACHE[typeName]\n if(!compiled) {\n CACHE[typeName] = compiled = compile(order, dtype)\n }\n compiled(array)\n return array\n}\n\nmodule.exports = sort\n\n/***/ }),\n\n/***/ 9618:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar isBuffer = __webpack_require__(7163)\n\nvar hasTypedArrays = ((typeof Float64Array) !== \"undefined\")\n\nfunction compare1st(a, b) {\n return a[0] - b[0]\n}\n\nfunction order() {\n var stride = this.stride\n var terms = new Array(stride.length)\n var i\n for(i=0; i= 0) {\n d = i0 | 0\n b += c0 * d\n a0 -= d\n }\n return new View(this.data, a0, c0, b)\n }\n proto.step = function step(i0) {\n var a0 = this.shape[0],\n b0 = this.stride[0],\n c = this.offset,\n d = 0,\n ceil = Math.ceil\n if (typeof i0 === \"number\") {\n d = i0 | 0\n if (d < 0) {\n c += b0 * (a0 - 1)\n a0 = ceil(-a0 / d)\n } else {\n a0 = ceil(a0 / d)\n }\n b0 *= d\n }\n return new View(this.data, a0, b0, c)\n }\n proto.transpose = function transpose(i0) {\n i0 = i0 === undefined ? 0 : i0 | 0\n var a = this.shape,\n b = this.stride\n return new View(this.data, a[i0], b[i0], this.offset)\n }\n proto.pick = function pick(i0) {\n var a = [],\n b = [],\n c = this.offset\n if (typeof i0 === \"number\" && i0 >= 0) {\n c = (c + this.stride[0] * i0) | 0\n } else {\n a.push(this.shape[0])\n b.push(this.stride[0])\n }\n var ctor = CTOR_LIST[a.length + 1]\n return ctor(this.data, a, b, c)\n }\n return function construct(data, shape, stride, offset) {\n return new View(data, shape[0], stride[0], offset)\n }\n },\n 2: function (dtype, CTOR_LIST, ORDER) {\n function View(a, b0, b1, c0, c1, d) {\n this.data = a\n this.shape = [b0, b1]\n this.stride = [c0, c1]\n this.offset = d | 0\n }\n var proto = View.prototype\n proto.dtype = dtype\n proto.dimension = 2\n Object.defineProperty(proto, \"size\", {\n get: function size() {\n return this.shape[0] * this.shape[1]\n },\n })\n Object.defineProperty(proto, \"order\", {\n get: function order() {\n return Math.abs(this.stride[0]) > Math.abs(this.stride[1]) ? [1, 0] : [0, 1]\n },\n })\n proto.set = function set(i0, i1, v) {\n return dtype === \"generic\"\n ? this.data.set(this.offset + this.stride[0] * i0 + this.stride[1] * i1, v)\n : (this.data[this.offset + this.stride[0] * i0 + this.stride[1] * i1] = v)\n }\n proto.get = function get(i0, i1) {\n return dtype === \"generic\"\n ? this.data.get(this.offset + this.stride[0] * i0 + this.stride[1] * i1)\n : this.data[this.offset + this.stride[0] * i0 + this.stride[1] * i1]\n }\n proto.index = function index(i0, i1) {\n return this.offset + this.stride[0] * i0 + this.stride[1] * i1\n }\n proto.hi = function hi(i0, i1) {\n return new View(\n this.data,\n typeof i0 !== \"number\" || i0 < 0 ? this.shape[0] : i0 | 0,\n typeof i1 !== \"number\" || i1 < 0 ? this.shape[1] : i1 | 0,\n this.stride[0],\n this.stride[1],\n this.offset\n )\n }\n proto.lo = function lo(i0, i1) {\n var b = this.offset,\n d = 0,\n a0 = this.shape[0],\n a1 = this.shape[1],\n c0 = this.stride[0],\n c1 = this.stride[1]\n if (typeof i0 === \"number\" && i0 >= 0) {\n d = i0 | 0\n b += c0 * d\n a0 -= d\n }\n if (typeof i1 === \"number\" && i1 >= 0) {\n d = i1 | 0\n b += c1 * d\n a1 -= d\n }\n return new View(this.data, a0, a1, c0, c1, b)\n }\n proto.step = function step(i0, i1) {\n var a0 = this.shape[0],\n a1 = this.shape[1],\n b0 = this.stride[0],\n b1 = this.stride[1],\n c = this.offset,\n d = 0,\n ceil = Math.ceil\n if (typeof i0 === \"number\") {\n d = i0 | 0\n if (d < 0) {\n c += b0 * (a0 - 1)\n a0 = ceil(-a0 / d)\n } else {\n a0 = ceil(a0 / d)\n }\n b0 *= d\n }\n if (typeof i1 === \"number\") {\n d = i1 | 0\n if (d < 0) {\n c += b1 * (a1 - 1)\n a1 = ceil(-a1 / d)\n } else {\n a1 = ceil(a1 / d)\n }\n b1 *= d\n }\n return new View(this.data, a0, a1, b0, b1, c)\n }\n proto.transpose = function transpose(i0, i1) {\n i0 = i0 === undefined ? 0 : i0 | 0\n i1 = i1 === undefined ? 1 : i1 | 0\n var a = this.shape,\n b = this.stride\n return new View(this.data, a[i0], a[i1], b[i0], b[i1], this.offset)\n }\n proto.pick = function pick(i0, i1) {\n var a = [],\n b = [],\n c = this.offset\n if (typeof i0 === \"number\" && i0 >= 0) {\n c = (c + this.stride[0] * i0) | 0\n } else {\n a.push(this.shape[0])\n b.push(this.stride[0])\n }\n if (typeof i1 === \"number\" && i1 >= 0) {\n c = (c + this.stride[1] * i1) | 0\n } else {\n a.push(this.shape[1])\n b.push(this.stride[1])\n }\n var ctor = CTOR_LIST[a.length + 1]\n return ctor(this.data, a, b, c)\n }\n return function construct(data, shape, stride, offset) {\n return new View(data, shape[0], shape[1], stride[0], stride[1], offset)\n }\n },\n 3: function (dtype, CTOR_LIST, ORDER) {\n function View(a, b0, b1, b2, c0, c1, c2, d) {\n this.data = a\n this.shape = [b0, b1, b2]\n this.stride = [c0, c1, c2]\n this.offset = d | 0\n }\n var proto = View.prototype\n proto.dtype = dtype\n proto.dimension = 3\n Object.defineProperty(proto, \"size\", {\n get: function size() {\n return this.shape[0] * this.shape[1] * this.shape[2]\n },\n })\n Object.defineProperty(proto, \"order\", {\n get: function order() {\n var s0 = Math.abs(this.stride[0]),\n s1 = Math.abs(this.stride[1]),\n s2 = Math.abs(this.stride[2])\n if (s0 > s1) {\n if (s1 > s2) {\n return [2, 1, 0]\n } else if (s0 > s2) {\n return [1, 2, 0]\n } else {\n return [1, 0, 2]\n }\n } else if (s0 > s2) {\n return [2, 0, 1]\n } else if (s2 > s1) {\n return [0, 1, 2]\n } else {\n return [0, 2, 1]\n }\n },\n })\n proto.set = function set(i0, i1, i2, v) {\n return dtype === \"generic\"\n ? this.data.set(this.offset + this.stride[0] * i0 + this.stride[1] * i1 + this.stride[2] * i2, v)\n : (this.data[this.offset + this.stride[0] * i0 + this.stride[1] * i1 + this.stride[2] * i2] = v)\n }\n proto.get = function get(i0, i1, i2) {\n return dtype === \"generic\"\n ? this.data.get(this.offset + this.stride[0] * i0 + this.stride[1] * i1 + this.stride[2] * i2)\n : this.data[this.offset + this.stride[0] * i0 + this.stride[1] * i1 + this.stride[2] * i2]\n }\n proto.index = function index(i0, i1, i2) {\n return this.offset + this.stride[0] * i0 + this.stride[1] * i1 + this.stride[2] * i2\n }\n proto.hi = function hi(i0, i1, i2) {\n return new View(\n this.data,\n typeof i0 !== \"number\" || i0 < 0 ? this.shape[0] : i0 | 0,\n typeof i1 !== \"number\" || i1 < 0 ? this.shape[1] : i1 | 0,\n typeof i2 !== \"number\" || i2 < 0 ? this.shape[2] : i2 | 0,\n this.stride[0],\n this.stride[1],\n this.stride[2],\n this.offset\n )\n }\n proto.lo = function lo(i0, i1, i2) {\n var b = this.offset,\n d = 0,\n a0 = this.shape[0],\n a1 = this.shape[1],\n a2 = this.shape[2],\n c0 = this.stride[0],\n c1 = this.stride[1],\n c2 = this.stride[2]\n if (typeof i0 === \"number\" && i0 >= 0) {\n d = i0 | 0\n b += c0 * d\n a0 -= d\n }\n if (typeof i1 === \"number\" && i1 >= 0) {\n d = i1 | 0\n b += c1 * d\n a1 -= d\n }\n if (typeof i2 === \"number\" && i2 >= 0) {\n d = i2 | 0\n b += c2 * d\n a2 -= d\n }\n return new View(this.data, a0, a1, a2, c0, c1, c2, b)\n }\n proto.step = function step(i0, i1, i2) {\n var a0 = this.shape[0],\n a1 = this.shape[1],\n a2 = this.shape[2],\n b0 = this.stride[0],\n b1 = this.stride[1],\n b2 = this.stride[2],\n c = this.offset,\n d = 0,\n ceil = Math.ceil\n if (typeof i0 === \"number\") {\n d = i0 | 0\n if (d < 0) {\n c += b0 * (a0 - 1)\n a0 = ceil(-a0 / d)\n } else {\n a0 = ceil(a0 / d)\n }\n b0 *= d\n }\n if (typeof i1 === \"number\") {\n d = i1 | 0\n if (d < 0) {\n c += b1 * (a1 - 1)\n a1 = ceil(-a1 / d)\n } else {\n a1 = ceil(a1 / d)\n }\n b1 *= d\n }\n if (typeof i2 === \"number\") {\n d = i2 | 0\n if (d < 0) {\n c += b2 * (a2 - 1)\n a2 = ceil(-a2 / d)\n } else {\n a2 = ceil(a2 / d)\n }\n b2 *= d\n }\n return new View(this.data, a0, a1, a2, b0, b1, b2, c)\n }\n proto.transpose = function transpose(i0, i1, i2) {\n i0 = i0 === undefined ? 0 : i0 | 0\n i1 = i1 === undefined ? 1 : i1 | 0\n i2 = i2 === undefined ? 2 : i2 | 0\n var a = this.shape,\n b = this.stride\n return new View(this.data, a[i0], a[i1], a[i2], b[i0], b[i1], b[i2], this.offset)\n }\n proto.pick = function pick(i0, i1, i2) {\n var a = [],\n b = [],\n c = this.offset\n if (typeof i0 === \"number\" && i0 >= 0) {\n c = (c + this.stride[0] * i0) | 0\n } else {\n a.push(this.shape[0])\n b.push(this.stride[0])\n }\n if (typeof i1 === \"number\" && i1 >= 0) {\n c = (c + this.stride[1] * i1) | 0\n } else {\n a.push(this.shape[1])\n b.push(this.stride[1])\n }\n if (typeof i2 === \"number\" && i2 >= 0) {\n c = (c + this.stride[2] * i2) | 0\n } else {\n a.push(this.shape[2])\n b.push(this.stride[2])\n }\n var ctor = CTOR_LIST[a.length + 1]\n return ctor(this.data, a, b, c)\n }\n return function construct(data, shape, stride, offset) {\n return new View(data, shape[0], shape[1], shape[2], stride[0], stride[1], stride[2], offset)\n }\n },\n 4: function (dtype, CTOR_LIST, ORDER) {\n function View(a, b0, b1, b2, b3, c0, c1, c2, c3, d) {\n this.data = a\n this.shape = [b0, b1, b2, b3]\n this.stride = [c0, c1, c2, c3]\n this.offset = d | 0\n }\n var proto = View.prototype\n proto.dtype = dtype\n proto.dimension = 4\n Object.defineProperty(proto, \"size\", {\n get: function size() {\n return this.shape[0] * this.shape[1] * this.shape[2] * this.shape[3]\n },\n })\n Object.defineProperty(proto, \"order\", { get: ORDER })\n proto.set = function set(i0, i1, i2, i3, v) {\n return dtype === \"generic\"\n ? this.data.set(this.offset + this.stride[0] * i0 + this.stride[1] * i1 + this.stride[2] * i2 + this.stride[3] * i3, v)\n : (this.data[this.offset + this.stride[0] * i0 + this.stride[1] * i1 + this.stride[2] * i2 + this.stride[3] * i3] = v)\n }\n proto.get = function get(i0, i1, i2, i3) {\n return dtype === \"generic\"\n ? this.data.get(this.offset + this.stride[0] * i0 + this.stride[1] * i1 + this.stride[2] * i2 + this.stride[3] * i3)\n : this.data[this.offset + this.stride[0] * i0 + this.stride[1] * i1 + this.stride[2] * i2 + this.stride[3] * i3]\n }\n proto.index = function index(i0, i1, i2, i3) {\n return this.offset + this.stride[0] * i0 + this.stride[1] * i1 + this.stride[2] * i2 + this.stride[3] * i3\n }\n proto.hi = function hi(i0, i1, i2, i3) {\n return new View(\n this.data,\n typeof i0 !== \"number\" || i0 < 0 ? this.shape[0] : i0 | 0,\n typeof i1 !== \"number\" || i1 < 0 ? this.shape[1] : i1 | 0,\n typeof i2 !== \"number\" || i2 < 0 ? this.shape[2] : i2 | 0,\n typeof i3 !== \"number\" || i3 < 0 ? this.shape[3] : i3 | 0,\n this.stride[0],\n this.stride[1],\n this.stride[2],\n this.stride[3],\n this.offset\n )\n }\n proto.lo = function lo(i0, i1, i2, i3) {\n var b = this.offset,\n d = 0,\n a0 = this.shape[0],\n a1 = this.shape[1],\n a2 = this.shape[2],\n a3 = this.shape[3],\n c0 = this.stride[0],\n c1 = this.stride[1],\n c2 = this.stride[2],\n c3 = this.stride[3]\n if (typeof i0 === \"number\" && i0 >= 0) {\n d = i0 | 0\n b += c0 * d\n a0 -= d\n }\n if (typeof i1 === \"number\" && i1 >= 0) {\n d = i1 | 0\n b += c1 * d\n a1 -= d\n }\n if (typeof i2 === \"number\" && i2 >= 0) {\n d = i2 | 0\n b += c2 * d\n a2 -= d\n }\n if (typeof i3 === \"number\" && i3 >= 0) {\n d = i3 | 0\n b += c3 * d\n a3 -= d\n }\n return new View(this.data, a0, a1, a2, a3, c0, c1, c2, c3, b)\n }\n proto.step = function step(i0, i1, i2, i3) {\n var a0 = this.shape[0],\n a1 = this.shape[1],\n a2 = this.shape[2],\n a3 = this.shape[3],\n b0 = this.stride[0],\n b1 = this.stride[1],\n b2 = this.stride[2],\n b3 = this.stride[3],\n c = this.offset,\n d = 0,\n ceil = Math.ceil\n if (typeof i0 === \"number\") {\n d = i0 | 0\n if (d < 0) {\n c += b0 * (a0 - 1)\n a0 = ceil(-a0 / d)\n } else {\n a0 = ceil(a0 / d)\n }\n b0 *= d\n }\n if (typeof i1 === \"number\") {\n d = i1 | 0\n if (d < 0) {\n c += b1 * (a1 - 1)\n a1 = ceil(-a1 / d)\n } else {\n a1 = ceil(a1 / d)\n }\n b1 *= d\n }\n if (typeof i2 === \"number\") {\n d = i2 | 0\n if (d < 0) {\n c += b2 * (a2 - 1)\n a2 = ceil(-a2 / d)\n } else {\n a2 = ceil(a2 / d)\n }\n b2 *= d\n }\n if (typeof i3 === \"number\") {\n d = i3 | 0\n if (d < 0) {\n c += b3 * (a3 - 1)\n a3 = ceil(-a3 / d)\n } else {\n a3 = ceil(a3 / d)\n }\n b3 *= d\n }\n return new View(this.data, a0, a1, a2, a3, b0, b1, b2, b3, c)\n }\n proto.transpose = function transpose(i0, i1, i2, i3) {\n i0 = i0 === undefined ? 0 : i0 | 0\n i1 = i1 === undefined ? 1 : i1 | 0\n i2 = i2 === undefined ? 2 : i2 | 0\n i3 = i3 === undefined ? 3 : i3 | 0\n var a = this.shape,\n b = this.stride\n return new View(this.data, a[i0], a[i1], a[i2], a[i3], b[i0], b[i1], b[i2], b[i3], this.offset)\n }\n proto.pick = function pick(i0, i1, i2, i3) {\n var a = [],\n b = [],\n c = this.offset\n if (typeof i0 === \"number\" && i0 >= 0) {\n c = (c + this.stride[0] * i0) | 0\n } else {\n a.push(this.shape[0])\n b.push(this.stride[0])\n }\n if (typeof i1 === \"number\" && i1 >= 0) {\n c = (c + this.stride[1] * i1) | 0\n } else {\n a.push(this.shape[1])\n b.push(this.stride[1])\n }\n if (typeof i2 === \"number\" && i2 >= 0) {\n c = (c + this.stride[2] * i2) | 0\n } else {\n a.push(this.shape[2])\n b.push(this.stride[2])\n }\n if (typeof i3 === \"number\" && i3 >= 0) {\n c = (c + this.stride[3] * i3) | 0\n } else {\n a.push(this.shape[3])\n b.push(this.stride[3])\n }\n var ctor = CTOR_LIST[a.length + 1]\n return ctor(this.data, a, b, c)\n }\n return function construct(data, shape, stride, offset) {\n return new View(data, shape[0], shape[1], shape[2], shape[3], stride[0], stride[1], stride[2], stride[3], offset)\n }\n },\n 5: function anonymous(dtype, CTOR_LIST, ORDER) {\n function View(a, b0, b1, b2, b3, b4, c0, c1, c2, c3, c4, d) {\n this.data = a\n this.shape = [b0, b1, b2, b3, b4]\n this.stride = [c0, c1, c2, c3, c4]\n this.offset = d | 0\n }\n var proto = View.prototype\n proto.dtype = dtype\n proto.dimension = 5\n Object.defineProperty(proto, \"size\", {\n get: function size() {\n return this.shape[0] * this.shape[1] * this.shape[2] * this.shape[3] * this.shape[4]\n },\n })\n Object.defineProperty(proto, \"order\", { get: ORDER })\n proto.set = function set(i0, i1, i2, i3, i4, v) {\n return dtype === \"generic\"\n ? this.data.set(\n this.offset +\n this.stride[0] * i0 +\n this.stride[1] * i1 +\n this.stride[2] * i2 +\n this.stride[3] * i3 +\n this.stride[4] * i4,\n v\n )\n : (this.data[\n this.offset +\n this.stride[0] * i0 +\n this.stride[1] * i1 +\n this.stride[2] * i2 +\n this.stride[3] * i3 +\n this.stride[4] * i4\n ] = v)\n }\n proto.get = function get(i0, i1, i2, i3, i4) {\n return dtype === \"generic\"\n ? this.data.get(\n this.offset +\n this.stride[0] * i0 +\n this.stride[1] * i1 +\n this.stride[2] * i2 +\n this.stride[3] * i3 +\n this.stride[4] * i4\n )\n : this.data[\n this.offset +\n this.stride[0] * i0 +\n this.stride[1] * i1 +\n this.stride[2] * i2 +\n this.stride[3] * i3 +\n this.stride[4] * i4\n ]\n }\n proto.index = function index(i0, i1, i2, i3, i4) {\n return (\n this.offset +\n this.stride[0] * i0 +\n this.stride[1] * i1 +\n this.stride[2] * i2 +\n this.stride[3] * i3 +\n this.stride[4] * i4\n )\n }\n proto.hi = function hi(i0, i1, i2, i3, i4) {\n return new View(\n this.data,\n typeof i0 !== \"number\" || i0 < 0 ? this.shape[0] : i0 | 0,\n typeof i1 !== \"number\" || i1 < 0 ? this.shape[1] : i1 | 0,\n typeof i2 !== \"number\" || i2 < 0 ? this.shape[2] : i2 | 0,\n typeof i3 !== \"number\" || i3 < 0 ? this.shape[3] : i3 | 0,\n typeof i4 !== \"number\" || i4 < 0 ? this.shape[4] : i4 | 0,\n this.stride[0],\n this.stride[1],\n this.stride[2],\n this.stride[3],\n this.stride[4],\n this.offset\n )\n }\n proto.lo = function lo(i0, i1, i2, i3, i4) {\n var b = this.offset,\n d = 0,\n a0 = this.shape[0],\n a1 = this.shape[1],\n a2 = this.shape[2],\n a3 = this.shape[3],\n a4 = this.shape[4],\n c0 = this.stride[0],\n c1 = this.stride[1],\n c2 = this.stride[2],\n c3 = this.stride[3],\n c4 = this.stride[4]\n if (typeof i0 === \"number\" && i0 >= 0) {\n d = i0 | 0\n b += c0 * d\n a0 -= d\n }\n if (typeof i1 === \"number\" && i1 >= 0) {\n d = i1 | 0\n b += c1 * d\n a1 -= d\n }\n if (typeof i2 === \"number\" && i2 >= 0) {\n d = i2 | 0\n b += c2 * d\n a2 -= d\n }\n if (typeof i3 === \"number\" && i3 >= 0) {\n d = i3 | 0\n b += c3 * d\n a3 -= d\n }\n if (typeof i4 === \"number\" && i4 >= 0) {\n d = i4 | 0\n b += c4 * d\n a4 -= d\n }\n return new View(this.data, a0, a1, a2, a3, a4, c0, c1, c2, c3, c4, b)\n }\n proto.step = function step(i0, i1, i2, i3, i4) {\n var a0 = this.shape[0],\n a1 = this.shape[1],\n a2 = this.shape[2],\n a3 = this.shape[3],\n a4 = this.shape[4],\n b0 = this.stride[0],\n b1 = this.stride[1],\n b2 = this.stride[2],\n b3 = this.stride[3],\n b4 = this.stride[4],\n c = this.offset,\n d = 0,\n ceil = Math.ceil\n if (typeof i0 === \"number\") {\n d = i0 | 0\n if (d < 0) {\n c += b0 * (a0 - 1)\n a0 = ceil(-a0 / d)\n } else {\n a0 = ceil(a0 / d)\n }\n b0 *= d\n }\n if (typeof i1 === \"number\") {\n d = i1 | 0\n if (d < 0) {\n c += b1 * (a1 - 1)\n a1 = ceil(-a1 / d)\n } else {\n a1 = ceil(a1 / d)\n }\n b1 *= d\n }\n if (typeof i2 === \"number\") {\n d = i2 | 0\n if (d < 0) {\n c += b2 * (a2 - 1)\n a2 = ceil(-a2 / d)\n } else {\n a2 = ceil(a2 / d)\n }\n b2 *= d\n }\n if (typeof i3 === \"number\") {\n d = i3 | 0\n if (d < 0) {\n c += b3 * (a3 - 1)\n a3 = ceil(-a3 / d)\n } else {\n a3 = ceil(a3 / d)\n }\n b3 *= d\n }\n if (typeof i4 === \"number\") {\n d = i4 | 0\n if (d < 0) {\n c += b4 * (a4 - 1)\n a4 = ceil(-a4 / d)\n } else {\n a4 = ceil(a4 / d)\n }\n b4 *= d\n }\n return new View(this.data, a0, a1, a2, a3, a4, b0, b1, b2, b3, b4, c)\n }\n proto.transpose = function transpose(i0, i1, i2, i3, i4) {\n i0 = i0 === undefined ? 0 : i0 | 0\n i1 = i1 === undefined ? 1 : i1 | 0\n i2 = i2 === undefined ? 2 : i2 | 0\n i3 = i3 === undefined ? 3 : i3 | 0\n i4 = i4 === undefined ? 4 : i4 | 0\n var a = this.shape,\n b = this.stride\n return new View(this.data, a[i0], a[i1], a[i2], a[i3], a[i4], b[i0], b[i1], b[i2], b[i3], b[i4], this.offset)\n }\n proto.pick = function pick(i0, i1, i2, i3, i4) {\n var a = [],\n b = [],\n c = this.offset\n if (typeof i0 === \"number\" && i0 >= 0) {\n c = (c + this.stride[0] * i0) | 0\n } else {\n a.push(this.shape[0])\n b.push(this.stride[0])\n }\n if (typeof i1 === \"number\" && i1 >= 0) {\n c = (c + this.stride[1] * i1) | 0\n } else {\n a.push(this.shape[1])\n b.push(this.stride[1])\n }\n if (typeof i2 === \"number\" && i2 >= 0) {\n c = (c + this.stride[2] * i2) | 0\n } else {\n a.push(this.shape[2])\n b.push(this.stride[2])\n }\n if (typeof i3 === \"number\" && i3 >= 0) {\n c = (c + this.stride[3] * i3) | 0\n } else {\n a.push(this.shape[3])\n b.push(this.stride[3])\n }\n if (typeof i4 === \"number\" && i4 >= 0) {\n c = (c + this.stride[4] * i4) | 0\n } else {\n a.push(this.shape[4])\n b.push(this.stride[4])\n }\n var ctor = CTOR_LIST[a.length + 1]\n return ctor(this.data, a, b, c)\n }\n return function construct(data, shape, stride, offset) {\n return new View(\n data,\n shape[0],\n shape[1],\n shape[2],\n shape[3],\n shape[4],\n stride[0],\n stride[1],\n stride[2],\n stride[3],\n stride[4],\n offset\n )\n }\n },\n}\n\n\nfunction compileConstructor(inType, inDimension) {\n var dKey = inDimension === -1 ? 'T' : String(inDimension)\n\n var procedure = allFns[dKey]\n if(inDimension === -1) {\n return procedure(inType)\n } else if(inDimension === 0) {\n return procedure(inType, CACHED_CONSTRUCTORS[inType][0])\n }\n return procedure(inType, CACHED_CONSTRUCTORS[inType], order)\n}\n\nfunction arrayDType(data) {\n if(isBuffer(data)) {\n return \"buffer\"\n }\n if(hasTypedArrays) {\n switch(Object.prototype.toString.call(data)) {\n case \"[object Float64Array]\":\n return \"float64\"\n case \"[object Float32Array]\":\n return \"float32\"\n case \"[object Int8Array]\":\n return \"int8\"\n case \"[object Int16Array]\":\n return \"int16\"\n case \"[object Int32Array]\":\n return \"int32\"\n case \"[object Uint8ClampedArray]\":\n return \"uint8_clamped\"\n case \"[object Uint8Array]\":\n return \"uint8\"\n case \"[object Uint16Array]\":\n return \"uint16\"\n case \"[object Uint32Array]\":\n return \"uint32\"\n case \"[object BigInt64Array]\":\n return \"bigint64\"\n case \"[object BigUint64Array]\":\n return \"biguint64\"\n }\n }\n if(Array.isArray(data)) {\n return \"array\"\n }\n return \"generic\"\n}\n\nvar CACHED_CONSTRUCTORS = {\n \"generic\":[],\n \"buffer\":[],\n \"array\":[],\n\n // typed arrays\n \"float32\":[],\n \"float64\":[],\n \"int8\":[],\n \"int16\":[],\n \"int32\":[],\n \"uint8_clamped\":[],\n \"uint8\":[],\n \"uint16\":[],\n \"uint32\":[],\n \"bigint64\": [],\n \"biguint64\": []\n}\n\n;(function() {\n for(var id in CACHED_CONSTRUCTORS) {\n CACHED_CONSTRUCTORS[id].push(compileConstructor(id, -1))\n }\n});\n\nfunction wrappedNDArrayCtor(data, shape, stride, offset) {\n if(data === undefined) {\n var ctor = CACHED_CONSTRUCTORS.array[0]\n return ctor([])\n } else if(typeof data === \"number\") {\n data = [data]\n }\n if(shape === undefined) {\n shape = [ data.length ]\n }\n var d = shape.length\n if(stride === undefined) {\n stride = new Array(d)\n for(var i=d-1, sz=1; i>=0; --i) {\n stride[i] = sz\n sz *= shape[i]\n }\n }\n if(offset === undefined) {\n offset = 0\n for(var i=0; i>>0\n\nmodule.exports = nextafter\n\nfunction nextafter(x, y) {\n if(isNaN(x) || isNaN(y)) {\n return NaN\n }\n if(x === y) {\n return x\n }\n if(x === 0) {\n if(y < 0) {\n return -SMALLEST_DENORM\n } else {\n return SMALLEST_DENORM\n }\n }\n var hi = doubleBits.hi(x)\n var lo = doubleBits.lo(x)\n if((y > x) === (x > 0)) {\n if(lo === UINT_MAX) {\n hi += 1\n lo = 0\n } else {\n lo += 1\n }\n } else {\n if(lo === 0) {\n lo = UINT_MAX\n hi -= 1\n } else {\n lo -= 1\n }\n }\n return doubleBits.pack(lo, hi)\n}\n\n/***/ }),\n\n/***/ 8406:\n/***/ (function(__unused_webpack_module, exports) {\n\nvar DEFAULT_NORMALS_EPSILON = 1e-6;\nvar DEFAULT_FACE_EPSILON = 1e-6;\n\n//Estimate the vertex normals of a mesh\nexports.vertexNormals = function(faces, positions, specifiedEpsilon) {\n\n var N = positions.length;\n var normals = new Array(N);\n var epsilon = specifiedEpsilon === void(0) ? DEFAULT_NORMALS_EPSILON : specifiedEpsilon;\n\n //Initialize normal array\n for(var i=0; i epsilon) {\n var norm = normals[c];\n var w = 1.0 / Math.sqrt(m01 * m21);\n for(var k=0; k<3; ++k) {\n var u = (k+1)%3;\n var v = (k+2)%3;\n norm[k] += w * (d21[u] * d01[v] - d21[v] * d01[u]);\n }\n }\n }\n }\n\n //Scale all normals to unit length\n for(var i=0; i epsilon) {\n var w = 1.0 / Math.sqrt(m);\n for(var k=0; k<3; ++k) {\n norm[k] *= w;\n }\n } else {\n for(var k=0; k<3; ++k) {\n norm[k] = 0.0;\n }\n }\n }\n\n //Return the resulting set of patches\n return normals;\n}\n\n//Compute face normals of a mesh\nexports.faceNormals = function(faces, positions, specifiedEpsilon) {\n\n var N = faces.length;\n var normals = new Array(N);\n var epsilon = specifiedEpsilon === void(0) ? DEFAULT_FACE_EPSILON : specifiedEpsilon;\n\n for(var i=0; i epsilon) {\n l = 1.0 / Math.sqrt(l);\n } else {\n l = 0.0;\n }\n for(var j=0; j<3; ++j) {\n n[j] *= l;\n }\n normals[i] = n;\n }\n return normals;\n}\n\n\n\n\n/***/ }),\n\n/***/ 4081:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nmodule.exports = quatFromFrame\n\nfunction quatFromFrame(\n out,\n rx, ry, rz,\n ux, uy, uz,\n fx, fy, fz) {\n var tr = rx + uy + fz\n if(l > 0) {\n var l = Math.sqrt(tr + 1.0)\n out[0] = 0.5 * (uz - fy) / l\n out[1] = 0.5 * (fx - rz) / l\n out[2] = 0.5 * (ry - uy) / l\n out[3] = 0.5 * l\n } else {\n var tf = Math.max(rx, uy, fz)\n var l = Math.sqrt(2 * tf - tr + 1.0)\n if(rx >= tf) {\n //x y z order\n out[0] = 0.5 * l\n out[1] = 0.5 * (ux + ry) / l\n out[2] = 0.5 * (fx + rz) / l\n out[3] = 0.5 * (uz - fy) / l\n } else if(uy >= tf) {\n //y z x order\n out[0] = 0.5 * (ry + ux) / l\n out[1] = 0.5 * l\n out[2] = 0.5 * (fy + uz) / l\n out[3] = 0.5 * (fx - rz) / l\n } else {\n //z x y order\n out[0] = 0.5 * (rz + fx) / l\n out[1] = 0.5 * (uz + fy) / l\n out[2] = 0.5 * l\n out[3] = 0.5 * (ry - ux) / l\n }\n }\n return out\n}\n\n/***/ }),\n\n/***/ 9977:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = createOrbitController\n\nvar filterVector = __webpack_require__(9215)\nvar lookAt = __webpack_require__(6582)\nvar mat4FromQuat = __webpack_require__(7399)\nvar invert44 = __webpack_require__(7608)\nvar quatFromFrame = __webpack_require__(4081)\n\nfunction len3(x,y,z) {\n return Math.sqrt(Math.pow(x,2) + Math.pow(y,2) + Math.pow(z,2))\n}\n\nfunction len4(w,x,y,z) {\n return Math.sqrt(Math.pow(w,2) + Math.pow(x,2) + Math.pow(y,2) + Math.pow(z,2))\n}\n\nfunction normalize4(out, a) {\n var ax = a[0]\n var ay = a[1]\n var az = a[2]\n var aw = a[3]\n var al = len4(ax, ay, az, aw)\n if(al > 1e-6) {\n out[0] = ax/al\n out[1] = ay/al\n out[2] = az/al\n out[3] = aw/al\n } else {\n out[0] = out[1] = out[2] = 0.0\n out[3] = 1.0\n }\n}\n\nfunction OrbitCameraController(initQuat, initCenter, initRadius) {\n this.radius = filterVector([initRadius])\n this.center = filterVector(initCenter)\n this.rotation = filterVector(initQuat)\n\n this.computedRadius = this.radius.curve(0)\n this.computedCenter = this.center.curve(0)\n this.computedRotation = this.rotation.curve(0)\n this.computedUp = [0.1,0,0]\n this.computedEye = [0.1,0,0]\n this.computedMatrix = [0.1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]\n\n this.recalcMatrix(0)\n}\n\nvar proto = OrbitCameraController.prototype\n\nproto.lastT = function() {\n return Math.max(\n this.radius.lastT(),\n this.center.lastT(),\n this.rotation.lastT())\n}\n\nproto.recalcMatrix = function(t) {\n this.radius.curve(t)\n this.center.curve(t)\n this.rotation.curve(t)\n\n var quat = this.computedRotation\n normalize4(quat, quat)\n\n var mat = this.computedMatrix\n mat4FromQuat(mat, quat)\n\n var center = this.computedCenter\n var eye = this.computedEye\n var up = this.computedUp\n var radius = Math.exp(this.computedRadius[0])\n\n eye[0] = center[0] + radius * mat[2]\n eye[1] = center[1] + radius * mat[6]\n eye[2] = center[2] + radius * mat[10]\n up[0] = mat[1]\n up[1] = mat[5]\n up[2] = mat[9]\n\n for(var i=0; i<3; ++i) {\n var rr = 0.0\n for(var j=0; j<3; ++j) {\n rr += mat[i+4*j] * eye[j]\n }\n mat[12+i] = -rr\n }\n}\n\nproto.getMatrix = function(t, result) {\n this.recalcMatrix(t)\n var m = this.computedMatrix\n if(result) {\n for(var i=0; i<16; ++i) {\n result[i] = m[i]\n }\n return result\n }\n return m\n}\n\nproto.idle = function(t) {\n this.center.idle(t)\n this.radius.idle(t)\n this.rotation.idle(t)\n}\n\nproto.flush = function(t) {\n this.center.flush(t)\n this.radius.flush(t)\n this.rotation.flush(t)\n}\n\nproto.pan = function(t, dx, dy, dz) {\n dx = dx || 0.0\n dy = dy || 0.0\n dz = dz || 0.0\n\n this.recalcMatrix(t)\n var mat = this.computedMatrix\n\n var ux = mat[1]\n var uy = mat[5]\n var uz = mat[9]\n var ul = len3(ux, uy, uz)\n ux /= ul\n uy /= ul\n uz /= ul\n\n var rx = mat[0]\n var ry = mat[4]\n var rz = mat[8]\n var ru = rx * ux + ry * uy + rz * uz\n rx -= ux * ru\n ry -= uy * ru\n rz -= uz * ru\n var rl = len3(rx, ry, rz)\n rx /= rl\n ry /= rl\n rz /= rl\n\n var fx = mat[2]\n var fy = mat[6]\n var fz = mat[10]\n var fu = fx * ux + fy * uy + fz * uz\n var fr = fx * rx + fy * ry + fz * rz\n fx -= fu * ux + fr * rx\n fy -= fu * uy + fr * ry\n fz -= fu * uz + fr * rz\n var fl = len3(fx, fy, fz)\n fx /= fl\n fy /= fl\n fz /= fl\n\n var vx = rx * dx + ux * dy\n var vy = ry * dx + uy * dy\n var vz = rz * dx + uz * dy\n\n this.center.move(t, vx, vy, vz)\n\n //Update z-component of radius\n var radius = Math.exp(this.computedRadius[0])\n radius = Math.max(1e-4, radius + dz)\n this.radius.set(t, Math.log(radius))\n}\n\nproto.rotate = function(t, dx, dy, dz) {\n this.recalcMatrix(t)\n\n dx = dx||0.0\n dy = dy||0.0\n\n var mat = this.computedMatrix\n\n var rx = mat[0]\n var ry = mat[4]\n var rz = mat[8]\n\n var ux = mat[1]\n var uy = mat[5]\n var uz = mat[9]\n\n var fx = mat[2]\n var fy = mat[6]\n var fz = mat[10]\n\n var qx = dx * rx + dy * ux\n var qy = dx * ry + dy * uy\n var qz = dx * rz + dy * uz\n\n var bx = -(fy * qz - fz * qy)\n var by = -(fz * qx - fx * qz)\n var bz = -(fx * qy - fy * qx) \n var bw = Math.sqrt(Math.max(0.0, 1.0 - Math.pow(bx,2) - Math.pow(by,2) - Math.pow(bz,2)))\n var bl = len4(bx, by, bz, bw)\n if(bl > 1e-6) {\n bx /= bl\n by /= bl\n bz /= bl\n bw /= bl\n } else {\n bx = by = bz = 0.0\n bw = 1.0\n }\n\n var rotation = this.computedRotation\n var ax = rotation[0]\n var ay = rotation[1]\n var az = rotation[2]\n var aw = rotation[3]\n\n var cx = ax*bw + aw*bx + ay*bz - az*by\n var cy = ay*bw + aw*by + az*bx - ax*bz\n var cz = az*bw + aw*bz + ax*by - ay*bx\n var cw = aw*bw - ax*bx - ay*by - az*bz\n \n //Apply roll\n if(dz) {\n bx = fx\n by = fy\n bz = fz\n var s = Math.sin(dz) / len3(bx, by, bz)\n bx *= s\n by *= s\n bz *= s\n bw = Math.cos(dx)\n cx = cx*bw + cw*bx + cy*bz - cz*by\n cy = cy*bw + cw*by + cz*bx - cx*bz\n cz = cz*bw + cw*bz + cx*by - cy*bx\n cw = cw*bw - cx*bx - cy*by - cz*bz\n }\n\n var cl = len4(cx, cy, cz, cw)\n if(cl > 1e-6) {\n cx /= cl\n cy /= cl\n cz /= cl\n cw /= cl\n } else {\n cx = cy = cz = 0.0\n cw = 1.0\n }\n\n this.rotation.set(t, cx, cy, cz, cw)\n}\n\nproto.lookAt = function(t, eye, center, up) {\n this.recalcMatrix(t)\n\n center = center || this.computedCenter\n eye = eye || this.computedEye\n up = up || this.computedUp\n\n var mat = this.computedMatrix\n lookAt(mat, eye, center, up)\n\n var rotation = this.computedRotation\n quatFromFrame(rotation,\n mat[0], mat[1], mat[2],\n mat[4], mat[5], mat[6],\n mat[8], mat[9], mat[10])\n normalize4(rotation, rotation)\n this.rotation.set(t, rotation[0], rotation[1], rotation[2], rotation[3])\n\n var fl = 0.0\n for(var i=0; i<3; ++i) {\n fl += Math.pow(center[i] - eye[i], 2)\n }\n this.radius.set(t, 0.5 * Math.log(Math.max(fl, 1e-6)))\n\n this.center.set(t, center[0], center[1], center[2])\n}\n\nproto.translate = function(t, dx, dy, dz) {\n this.center.move(t,\n dx||0.0,\n dy||0.0,\n dz||0.0)\n}\n\nproto.setMatrix = function(t, matrix) {\n\n var rotation = this.computedRotation\n quatFromFrame(rotation,\n matrix[0], matrix[1], matrix[2],\n matrix[4], matrix[5], matrix[6],\n matrix[8], matrix[9], matrix[10])\n normalize4(rotation, rotation)\n this.rotation.set(t, rotation[0], rotation[1], rotation[2], rotation[3])\n\n var mat = this.computedMatrix\n invert44(mat, matrix)\n var w = mat[15]\n if(Math.abs(w) > 1e-6) {\n var cx = mat[12]/w\n var cy = mat[13]/w\n var cz = mat[14]/w\n\n this.recalcMatrix(t) \n var r = Math.exp(this.computedRadius[0])\n this.center.set(t, cx-mat[2]*r, cy-mat[6]*r, cz-mat[10]*r)\n this.radius.idle(t)\n } else {\n this.center.idle(t)\n this.radius.idle(t)\n }\n}\n\nproto.setDistance = function(t, d) {\n if(d > 0) {\n this.radius.set(t, Math.log(d))\n }\n}\n\nproto.setDistanceLimits = function(lo, hi) {\n if(lo > 0) {\n lo = Math.log(lo)\n } else {\n lo = -Infinity \n }\n if(hi > 0) {\n hi = Math.log(hi)\n } else {\n hi = Infinity\n }\n hi = Math.max(hi, lo)\n this.radius.bounds[0][0] = lo\n this.radius.bounds[1][0] = hi\n}\n\nproto.getDistanceLimits = function(out) {\n var bounds = this.radius.bounds\n if(out) {\n out[0] = Math.exp(bounds[0][0])\n out[1] = Math.exp(bounds[1][0])\n return out\n }\n return [ Math.exp(bounds[0][0]), Math.exp(bounds[1][0]) ]\n}\n\nproto.toJSON = function() {\n this.recalcMatrix(this.lastT())\n return {\n center: this.computedCenter.slice(),\n rotation: this.computedRotation.slice(),\n distance: Math.log(this.computedRadius[0]),\n zoomMin: this.radius.bounds[0][0],\n zoomMax: this.radius.bounds[1][0]\n }\n}\n\nproto.fromJSON = function(options) {\n var t = this.lastT()\n var c = options.center\n if(c) {\n this.center.set(t, c[0], c[1], c[2])\n }\n var r = options.rotation\n if(r) {\n this.rotation.set(t, r[0], r[1], r[2], r[3])\n }\n var d = options.distance\n if(d && d > 0) {\n this.radius.set(t, Math.log(d))\n }\n this.setDistanceLimits(options.zoomMin, options.zoomMax)\n}\n\nfunction createOrbitController(options) {\n options = options || {}\n var center = options.center || [0,0,0]\n var rotation = options.rotation || [0,0,0,1]\n var radius = options.radius || 1.0\n\n center = [].slice.call(center, 0, 3)\n rotation = [].slice.call(rotation, 0, 4)\n normalize4(rotation, rotation)\n\n var result = new OrbitCameraController(\n rotation,\n center,\n Math.log(radius))\n\n result.setDistanceLimits(options.zoomMin, options.zoomMax)\n\n if('eye' in options || 'up' in options) {\n result.lookAt(0, options.eye, options.center, options.up)\n }\n\n return result\n}\n\n/***/ }),\n\n/***/ 1371:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n/*!\n * pad-left \n *\n * Copyright (c) 2014-2015, Jon Schlinkert.\n * Licensed under the MIT license.\n */\n\n\n\nvar repeat = __webpack_require__(3233);\n\nmodule.exports = function padLeft(str, num, ch) {\n ch = typeof ch !== 'undefined' ? (ch + '') : ' ';\n return repeat(ch, num) + str;\n};\n\n/***/ }),\n\n/***/ 3202:\n/***/ (function(module) {\n\nmodule.exports = function parseUnit(str, out) {\n if (!out)\n out = [ 0, '' ]\n\n str = String(str)\n var num = parseFloat(str, 10)\n out[0] = num\n out[1] = str.match(/[\\d.\\-\\+]*\\s*(.*)/)[1] || ''\n return out\n}\n\n/***/ }),\n\n/***/ 3088:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = planarDual\n\nvar compareAngle = __webpack_require__(3140)\n\nfunction planarDual(cells, positions) {\n\n var numVertices = positions.length|0\n var numEdges = cells.length\n var adj = [new Array(numVertices), new Array(numVertices)]\n for(var i=0; i 0) {\n nextCell = adj[i][b][0]\n nextDir = i\n break\n }\n }\n nextVertex = nextCell[nextDir^1]\n\n for(var dir=0; dir<2; ++dir) {\n var nbhd = adj[dir][b]\n for(var k=0; k 0) {\n nextCell = e\n nextVertex = p\n nextDir = dir\n }\n }\n }\n if(noCut) {\n return nextVertex\n }\n if(nextCell) {\n cut(nextCell, nextDir)\n }\n return nextVertex\n }\n\n function extractCycle(v, dir) {\n var e0 = adj[dir][v][0]\n var cycle = [v]\n cut(e0, dir)\n var u = e0[dir^1]\n var d0 = dir\n while(true) {\n while(u !== v) {\n cycle.push(u)\n u = next(cycle[cycle.length-2], u, false)\n }\n if(adj[0][v].length + adj[1][v].length === 0) {\n break\n }\n var a = cycle[cycle.length-1]\n var b = v\n var c = cycle[1]\n var d = next(a, b, true)\n if(compareAngle(positions[a], positions[b], positions[c], positions[d]) < 0) {\n break\n }\n cycle.push(v)\n u = next(a, b)\n }\n return cycle\n }\n\n function shouldGlue(pcycle, ncycle) {\n return (ncycle[1] === ncycle[ncycle.length-1])\n }\n\n for(var i=0; i 0) {\n var ni = adj[0][i].length\n var ncycle = extractCycle(i,j)\n if(shouldGlue(pcycle, ncycle)) {\n //Glue together trivial cycles\n pcycle.push.apply(pcycle, ncycle)\n } else {\n if(pcycle.length > 0) {\n cycles.push(pcycle)\n }\n pcycle = ncycle\n }\n }\n if(pcycle.length > 0) {\n cycles.push(pcycle)\n }\n }\n }\n\n //Combine paths and loops together\n return cycles\n}\n\n/***/ }),\n\n/***/ 5609:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = trimLeaves\n\nvar e2a = __webpack_require__(3134)\n\nfunction trimLeaves(edges, positions) {\n var adj = e2a(edges, positions.length)\n var live = new Array(positions.length)\n var nbhd = new Array(positions.length)\n\n var dead = []\n for(var i=0; i 0) {\n var v = dead.pop()\n live[v] = false\n var n = adj[v]\n for(var i=0; i 0\n }\n\n //Extract all clockwise faces\n faces = faces.filter(ccw)\n\n //Detect which loops are contained in one another to handle parent-of relation\n var numFaces = faces.length\n var parent = new Array(numFaces)\n var containment = new Array(numFaces)\n for(var i=0; i 0) {\n var top = toVisit.pop()\n var nbhd = fadj[top]\n uniq(nbhd, function(a,b) {\n return a-b\n })\n var nnbhr = nbhd.length\n var p = parity[top]\n var polyline\n if(p === 0) {\n var c = faces[top]\n polyline = [c]\n }\n for(var i=0; i= 0) {\n continue\n }\n parity[f] = p^1\n toVisit.push(f)\n if(p === 0) {\n var c = faces[f]\n if(!sharedBoundary(c)) {\n c.reverse()\n polyline.push(c)\n }\n }\n }\n if(p === 0) {\n result.push(polyline)\n }\n }\n\n return result\n}\n\n/***/ }),\n\n/***/ 5085:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports = preprocessPolygon\n\nvar orient = (__webpack_require__(3250)[3])\nvar makeSlabs = __webpack_require__(4209)\nvar makeIntervalTree = __webpack_require__(3352)\nvar bsearch = __webpack_require__(2478)\n\nfunction visitInterval() {\n return true\n}\n\nfunction intervalSearch(table) {\n return function(x, y) {\n var tree = table[x]\n if(tree) {\n return !!tree.queryPoint(y, visitInterval)\n }\n return false\n }\n}\n\nfunction buildVerticalIndex(segments) {\n var table = {}\n for(var i=0; i 0 && coordinates[bucket] === p[0]) {\n root = slabs[bucket-1]\n } else {\n return 1\n }\n }\n var lastOrientation = 1\n while(root) {\n var s = root.key\n var o = orient(p, s[0], s[1])\n if(s[0][0] < s[1][0]) {\n if(o < 0) {\n root = root.left\n } else if(o > 0) {\n lastOrientation = -1\n root = root.right\n } else {\n return 0\n }\n } else {\n if(o > 0) {\n root = root.left\n } else if(o < 0) {\n lastOrientation = 1\n root = root.right\n } else {\n return 0\n }\n }\n }\n return lastOrientation\n }\n}\n\nfunction classifyEmpty(p) {\n return 1\n}\n\nfunction createClassifyVertical(testVertical) {\n return function classify(p) {\n if(testVertical(p[0], p[1])) {\n return 0\n }\n return 1\n }\n}\n\nfunction createClassifyPointDegen(testVertical, testNormal) {\n return function classify(p) {\n if(testVertical(p[0], p[1])) {\n return 0\n }\n return testNormal(p)\n }\n}\n\nfunction preprocessPolygon(loops) {\n //Compute number of loops\n var numLoops = loops.length\n\n //Unpack segments\n var segments = []\n var vsegments = []\n var ptr = 0\n for(var i=0; i= a00) {\n s = 1.0;\n sqrDistance = a00 + 2.0*b0 + c;\n } else {\n s = -b0/a00;\n sqrDistance = b0*s + c;\n }\n } else {\n s = 0;\n if (b1 >= 0) {\n t = 0;\n sqrDistance = c;\n } else if (-b1 >= a11) {\n t = 1;\n sqrDistance = a11 + 2.0*b1 + c;\n } else {\n t = -b1/a11;\n sqrDistance = b1*t + c;\n }\n }\n } else { // region 3\n s = 0;\n if (b1 >= 0) {\n t = 0;\n sqrDistance = c;\n } else if (-b1 >= a11) {\n t = 1;\n sqrDistance = a11 + 2.0*b1 + c;\n } else {\n t = -b1/a11;\n sqrDistance = b1*t + c;\n }\n }\n } else if (t < 0) { // region 5\n t = 0;\n if (b0 >= 0) {\n s = 0;\n sqrDistance = c;\n } else if (-b0 >= a00) {\n s = 1;\n sqrDistance = a00 + 2.0*b0 + c;\n } else {\n s = -b0/a00;\n sqrDistance = b0*s + c;\n }\n } else { // region 0\n // minimum at interior point\n var invDet = 1.0 / det;\n s *= invDet;\n t *= invDet;\n sqrDistance = s*(a00*s + a01*t + 2.0*b0) + t*(a01*s + a11*t + 2.0*b1) + c;\n }\n } else {\n var tmp0, tmp1, numer, denom;\n \n if (s < 0) { // region 2\n tmp0 = a01 + b0;\n tmp1 = a11 + b1;\n if (tmp1 > tmp0) {\n numer = tmp1 - tmp0;\n denom = a00 - 2.0*a01 + a11;\n if (numer >= denom) {\n s = 1;\n t = 0;\n sqrDistance = a00 + 2.0*b0 + c;\n } else {\n s = numer/denom;\n t = 1 - s;\n sqrDistance = s*(a00*s + a01*t + 2.0*b0) +\n t*(a01*s + a11*t + 2.0*b1) + c;\n }\n } else {\n s = 0;\n if (tmp1 <= 0) {\n t = 1;\n sqrDistance = a11 + 2.0*b1 + c;\n } else if (b1 >= 0) {\n t = 0;\n sqrDistance = c;\n } else {\n t = -b1/a11;\n sqrDistance = b1*t + c;\n }\n }\n } else if (t < 0) { // region 6\n tmp0 = a01 + b1;\n tmp1 = a00 + b0;\n if (tmp1 > tmp0) {\n numer = tmp1 - tmp0;\n denom = a00 - 2.0*a01 + a11;\n if (numer >= denom) {\n t = 1;\n s = 0;\n sqrDistance = a11 + 2.0*b1 + c;\n } else {\n t = numer/denom;\n s = 1 - t;\n sqrDistance = s*(a00*s + a01*t + 2.0*b0) +\n t*(a01*s + a11*t + 2.0*b1) + c;\n }\n } else {\n t = 0;\n if (tmp1 <= 0) {\n s = 1;\n sqrDistance = a00 + 2.0*b0 + c;\n } else if (b0 >= 0) {\n s = 0;\n sqrDistance = c;\n } else {\n s = -b0/a00;\n sqrDistance = b0*s + c;\n }\n }\n } else { // region 1\n numer = a11 + b1 - a01 - b0;\n if (numer <= 0) {\n s = 0;\n t = 1;\n sqrDistance = a11 + 2.0*b1 + c;\n } else {\n denom = a00 - 2.0*a01 + a11;\n if (numer >= denom) {\n s = 1;\n t = 0;\n sqrDistance = a00 + 2.0*b0 + c;\n } else {\n s = numer/denom;\n t = 1 - s;\n sqrDistance = s*(a00*s + a01*t + 2.0*b0) +\n t*(a01*s + a11*t + 2.0*b1) + c;\n }\n }\n }\n }\n var u = 1.0 - s - t;\n for(var i=0; i 0) {\n var f = cells[ptr-1]\n if(compareCell(c, f) === 0 &&\n orientation(f) !== o) {\n ptr -= 1\n continue\n }\n }\n cells[ptr++] = c\n }\n cells.length = ptr\n return cells\n}\n\n\n/***/ }),\n\n/***/ 3233:\n/***/ (function(module) {\n\n\"use strict\";\n/*!\n * repeat-string \n *\n * Copyright (c) 2014-2015, Jon Schlinkert.\n * Licensed under the MIT License.\n */\n\n\n\n/**\n * Results cache\n */\n\nvar res = '';\nvar cache;\n\n/**\n * Expose `repeat`\n */\n\nmodule.exports = repeat;\n\n/**\n * Repeat the given `string` the specified `number`\n * of times.\n *\n * **Example:**\n *\n * ```js\n * var repeat = require('repeat-string');\n * repeat('A', 5);\n * //=> AAAAA\n * ```\n *\n * @param {String} `string` The string to repeat\n * @param {Number} `number` The number of times to repeat the string\n * @return {String} Repeated string\n * @api public\n */\n\nfunction repeat(str, num) {\n if (typeof str !== 'string') {\n throw new TypeError('expected a string');\n }\n\n // cover common, quick use cases\n if (num === 1) return str;\n if (num === 2) return str + str;\n\n var max = str.length * num;\n if (cache !== str || typeof cache === 'undefined') {\n cache = str;\n res = '';\n } else if (res.length >= max) {\n return res.substr(0, max);\n }\n\n while (max > res.length && num > 1) {\n if (num & 1) {\n res += str;\n }\n\n num >>= 1;\n str += str;\n }\n\n res += str;\n res = res.substr(0, max);\n return res;\n}\n\n\n/***/ }),\n\n/***/ 3025:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nmodule.exports =\n __webpack_require__.g.performance &&\n __webpack_require__.g.performance.now ? function now() {\n return performance.now()\n } : Date.now || function now() {\n return +new Date\n }\n\n\n/***/ }),\n\n/***/ 7004:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nmodule.exports = compressExpansion\n\nfunction compressExpansion(e) {\n var m = e.length\n var Q = e[e.length-1]\n var bottom = m\n for(var i=m-2; i>=0; --i) {\n var a = Q\n var b = e[i]\n Q = a + b\n var bv = Q - a\n var q = b - bv\n if(q) {\n e[--bottom] = Q\n Q = q\n }\n }\n var top = 0\n for(var i=bottom; i 0) {\n if(r <= 0) {\n return det\n } else {\n s = l + r\n }\n } else if(l < 0) {\n if(r >= 0) {\n return det\n } else {\n s = -(l + r)\n }\n } else {\n return det\n }\n var tol = ERRBOUND3 * s\n if(det >= tol || det <= -tol) {\n return det\n }\n return orientation3Exact(a, b, c)\n },\n function orientation4(a,b,c,d) {\n var adx = a[0] - d[0]\n var bdx = b[0] - d[0]\n var cdx = c[0] - d[0]\n var ady = a[1] - d[1]\n var bdy = b[1] - d[1]\n var cdy = c[1] - d[1]\n var adz = a[2] - d[2]\n var bdz = b[2] - d[2]\n var cdz = c[2] - d[2]\n var bdxcdy = bdx * cdy\n var cdxbdy = cdx * bdy\n var cdxady = cdx * ady\n var adxcdy = adx * cdy\n var adxbdy = adx * bdy\n var bdxady = bdx * ady\n var det = adz * (bdxcdy - cdxbdy)\n + bdz * (cdxady - adxcdy)\n + cdz * (adxbdy - bdxady)\n var permanent = (Math.abs(bdxcdy) + Math.abs(cdxbdy)) * Math.abs(adz)\n + (Math.abs(cdxady) + Math.abs(adxcdy)) * Math.abs(bdz)\n + (Math.abs(adxbdy) + Math.abs(bdxady)) * Math.abs(cdz)\n var tol = ERRBOUND4 * permanent\n if ((det > tol) || (-det > tol)) {\n return det\n }\n return orientation4Exact(a,b,c,d)\n }\n]\n\nfunction slowOrient(args) {\n var proc = CACHED[args.length]\n if(!proc) {\n proc = CACHED[args.length] = orientation(args.length)\n }\n return proc.apply(undefined, args)\n}\n\nfunction proc (slow, o0, o1, o2, o3, o4, o5) {\n return function getOrientation(a0, a1, a2, a3, a4) {\n switch (arguments.length) {\n case 0:\n case 1:\n return 0;\n case 2:\n return o2(a0, a1)\n case 3:\n return o3(a0, a1, a2)\n case 4:\n return o4(a0, a1, a2, a3)\n case 5:\n return o5(a0, a1, a2, a3, a4)\n }\n\n var s = new Array(arguments.length)\n for (var i = 0; i < arguments.length; ++i) {\n s[i] = arguments[i]\n }\n return slow(s)\n }\n}\n\nfunction generateOrientationProc() {\n while(CACHED.length <= NUM_EXPAND) {\n CACHED.push(orientation(CACHED.length))\n }\n module.exports = proc.apply(undefined, [slowOrient].concat(CACHED))\n for(var i=0; i<=NUM_EXPAND; ++i) {\n module.exports[i] = CACHED[i]\n }\n}\n\ngenerateOrientationProc()\n\n/***/ }),\n\n/***/ 5382:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar robustSum = __webpack_require__(8210)\nvar robustScale = __webpack_require__(3012)\n\nmodule.exports = robustProduct\n\nfunction robustProduct(a, b) {\n if(a.length === 1) {\n return robustScale(b, a[0])\n }\n if(b.length === 1) {\n return robustScale(a, b[0])\n }\n if(a.length === 0 || b.length === 0) {\n return [0]\n }\n var r = [0]\n if(a.length < b.length) {\n for(var i=0; i 0 && y0 > 0) || (x0 < 0 && y0 < 0)) {\n return false\n }\n\n var x1 = orient(b0, a0, a1)\n var y1 = orient(b1, a0, a1)\n if((x1 > 0 && y1 > 0) || (x1 < 0 && y1 < 0)) {\n return false\n }\n\n //Check for degenerate collinear case\n if(x0 === 0 && y0 === 0 && x1 === 0 && y1 === 0) {\n return checkCollinear(a0, a1, b0, b1)\n }\n\n return true\n}\n\n/***/ }),\n\n/***/ 8545:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nmodule.exports = robustSubtract\n\n//Easy case: Add two scalars\nfunction scalarScalar(a, b) {\n var x = a + b\n var bv = x - a\n var av = x - bv\n var br = b - bv\n var ar = a - av\n var y = ar + br\n if(y) {\n return [y, x]\n }\n return [x]\n}\n\nfunction robustSubtract(e, f) {\n var ne = e.length|0\n var nf = f.length|0\n if(ne === 1 && nf === 1) {\n return scalarScalar(e[0], -f[0])\n }\n var n = ne + nf\n var g = new Array(n)\n var count = 0\n var eptr = 0\n var fptr = 0\n var abs = Math.abs\n var ei = e[eptr]\n var ea = abs(ei)\n var fi = -f[fptr]\n var fa = abs(fi)\n var a, b\n if(ea < fa) {\n b = ei\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n ea = abs(ei)\n }\n } else {\n b = fi\n fptr += 1\n if(fptr < nf) {\n fi = -f[fptr]\n fa = abs(fi)\n }\n }\n if((eptr < ne && ea < fa) || (fptr >= nf)) {\n a = ei\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n ea = abs(ei)\n }\n } else {\n a = fi\n fptr += 1\n if(fptr < nf) {\n fi = -f[fptr]\n fa = abs(fi)\n }\n }\n var x = a + b\n var bv = x - a\n var y = b - bv\n var q0 = y\n var q1 = x\n var _x, _bv, _av, _br, _ar\n while(eptr < ne && fptr < nf) {\n if(ea < fa) {\n a = ei\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n ea = abs(ei)\n }\n } else {\n a = fi\n fptr += 1\n if(fptr < nf) {\n fi = -f[fptr]\n fa = abs(fi)\n }\n }\n b = q0\n x = a + b\n bv = x - a\n y = b - bv\n if(y) {\n g[count++] = y\n }\n _x = q1 + x\n _bv = _x - q1\n _av = _x - _bv\n _br = x - _bv\n _ar = q1 - _av\n q0 = _ar + _br\n q1 = _x\n }\n while(eptr < ne) {\n a = ei\n b = q0\n x = a + b\n bv = x - a\n y = b - bv\n if(y) {\n g[count++] = y\n }\n _x = q1 + x\n _bv = _x - q1\n _av = _x - _bv\n _br = x - _bv\n _ar = q1 - _av\n q0 = _ar + _br\n q1 = _x\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n }\n }\n while(fptr < nf) {\n a = fi\n b = q0\n x = a + b\n bv = x - a\n y = b - bv\n if(y) {\n g[count++] = y\n } \n _x = q1 + x\n _bv = _x - q1\n _av = _x - _bv\n _br = x - _bv\n _ar = q1 - _av\n q0 = _ar + _br\n q1 = _x\n fptr += 1\n if(fptr < nf) {\n fi = -f[fptr]\n }\n }\n if(q0) {\n g[count++] = q0\n }\n if(q1) {\n g[count++] = q1\n }\n if(!count) {\n g[count++] = 0.0 \n }\n g.length = count\n return g\n}\n\n/***/ }),\n\n/***/ 8210:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nmodule.exports = linearExpansionSum\n\n//Easy case: Add two scalars\nfunction scalarScalar(a, b) {\n var x = a + b\n var bv = x - a\n var av = x - bv\n var br = b - bv\n var ar = a - av\n var y = ar + br\n if(y) {\n return [y, x]\n }\n return [x]\n}\n\nfunction linearExpansionSum(e, f) {\n var ne = e.length|0\n var nf = f.length|0\n if(ne === 1 && nf === 1) {\n return scalarScalar(e[0], f[0])\n }\n var n = ne + nf\n var g = new Array(n)\n var count = 0\n var eptr = 0\n var fptr = 0\n var abs = Math.abs\n var ei = e[eptr]\n var ea = abs(ei)\n var fi = f[fptr]\n var fa = abs(fi)\n var a, b\n if(ea < fa) {\n b = ei\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n ea = abs(ei)\n }\n } else {\n b = fi\n fptr += 1\n if(fptr < nf) {\n fi = f[fptr]\n fa = abs(fi)\n }\n }\n if((eptr < ne && ea < fa) || (fptr >= nf)) {\n a = ei\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n ea = abs(ei)\n }\n } else {\n a = fi\n fptr += 1\n if(fptr < nf) {\n fi = f[fptr]\n fa = abs(fi)\n }\n }\n var x = a + b\n var bv = x - a\n var y = b - bv\n var q0 = y\n var q1 = x\n var _x, _bv, _av, _br, _ar\n while(eptr < ne && fptr < nf) {\n if(ea < fa) {\n a = ei\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n ea = abs(ei)\n }\n } else {\n a = fi\n fptr += 1\n if(fptr < nf) {\n fi = f[fptr]\n fa = abs(fi)\n }\n }\n b = q0\n x = a + b\n bv = x - a\n y = b - bv\n if(y) {\n g[count++] = y\n }\n _x = q1 + x\n _bv = _x - q1\n _av = _x - _bv\n _br = x - _bv\n _ar = q1 - _av\n q0 = _ar + _br\n q1 = _x\n }\n while(eptr < ne) {\n a = ei\n b = q0\n x = a + b\n bv = x - a\n y = b - bv\n if(y) {\n g[count++] = y\n }\n _x = q1 + x\n _bv = _x - q1\n _av = _x - _bv\n _br = x - _bv\n _ar = q1 - _av\n q0 = _ar + _br\n q1 = _x\n eptr += 1\n if(eptr < ne) {\n ei = e[eptr]\n }\n }\n while(fptr < nf) {\n a = fi\n b = q0\n x = a + b\n bv = x - a\n y = b - bv\n if(y) {\n g[count++] = y\n } \n _x = q1 + x\n _bv = _x - q1\n _av = _x - _bv\n _br = x - _bv\n _ar = q1 - _av\n q0 = _ar + _br\n q1 = _x\n fptr += 1\n if(fptr < nf) {\n fi = f[fptr]\n }\n }\n if(q0) {\n g[count++] = q0\n }\n if(q1) {\n g[count++] = q1\n }\n if(!count) {\n g[count++] = 0.0 \n }\n g.length = count\n return g\n}\n\n/***/ }),\n\n/***/ 9127:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = boundary\n\nvar bnd = __webpack_require__(6204)\nvar reduce = __webpack_require__(5771)\n\nfunction boundary(cells) {\n return reduce(bnd(cells))\n}\n\n\n/***/ }),\n\n/***/ 7765:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = extractContour\n\nvar ndarray = __webpack_require__(9618)\nvar pool = __webpack_require__(1888)\nvar ndsort = __webpack_require__(446)\n\nvar contourAlgorithm = __webpack_require__(1570)\n\nfunction getDimension(cells) {\n var numCells = cells.length\n var d = 0\n for(var i=0; i> 1,\n v = E[2 * m + 1]\n if (v === b) {\n return m\n }\n if (b < v) {\n h = m\n } else {\n l = m + 1\n }\n }\n return l\n }\n function getContour0d(F, E, C, S) {\n var n = F.length,\n R = []\n for (var i = 0; i < n; ++i) {\n var c = F[i],\n l = c.length\n }\n return R\n }\n return getContour0d\n },\n function cellPolygonizer_1() {\n function B(C, E, i, j) {\n var a = Math.min(i, j) | 0,\n b = Math.max(i, j) | 0,\n l = C[2 * a],\n h = C[2 * a + 1]\n while (l < h) {\n var m = (l + h) >> 1,\n v = E[2 * m + 1]\n if (v === b) {\n return m\n }\n if (b < v) {\n h = m\n } else {\n l = m + 1\n }\n }\n return l\n }\n function getContour1d(F, E, C, S) {\n var n = F.length,\n R = []\n for (var i = 0; i < n; ++i) {\n var c = F[i],\n l = c.length\n if (l === 2) {\n var M = (S[c[0]] << 0) + (S[c[1]] << 1)\n if (M === 0 || M === 3) {\n continue\n }\n switch (M) {\n case 0:\n break\n case 1:\n R.push([B(C, E, c[0], c[1])])\n break\n case 2:\n R.push([B(C, E, c[1], c[0])])\n break\n case 3:\n break\n }\n }\n }\n return R\n }\n return getContour1d\n },\n function cellPolygonizer_2() {\n function B(C, E, i, j) {\n var a = Math.min(i, j) | 0,\n b = Math.max(i, j) | 0,\n l = C[2 * a],\n h = C[2 * a + 1]\n while (l < h) {\n var m = (l + h) >> 1,\n v = E[2 * m + 1]\n if (v === b) {\n return m\n }\n if (b < v) {\n h = m\n } else {\n l = m + 1\n }\n }\n return l\n }\n function getContour2d(F, E, C, S) {\n var n = F.length,\n R = []\n for (var i = 0; i < n; ++i) {\n var c = F[i],\n l = c.length\n if (l === 3) {\n var M = (S[c[0]] << 0) + (S[c[1]] << 1) + (S[c[2]] << 2)\n if (M === 0 || M === 7) {\n continue\n }\n switch (M) {\n case 0:\n break\n case 1:\n R.push([B(C, E, c[0], c[2]), B(C, E, c[0], c[1])])\n break\n case 2:\n R.push([B(C, E, c[1], c[0]), B(C, E, c[1], c[2])])\n break\n case 3:\n R.push([B(C, E, c[0], c[2]), B(C, E, c[1], c[2])])\n break\n case 4:\n R.push([B(C, E, c[2], c[1]), B(C, E, c[2], c[0])])\n break\n case 5:\n R.push([B(C, E, c[2], c[1]), B(C, E, c[0], c[1])])\n break\n case 6:\n R.push([B(C, E, c[1], c[0]), B(C, E, c[2], c[0])])\n break\n case 7:\n break\n }\n } else if (l === 2) {\n var M = (S[c[0]] << 0) + (S[c[1]] << 1)\n if (M === 0 || M === 3) {\n continue\n }\n switch (M) {\n case 0:\n break\n case 1:\n R.push([B(C, E, c[0], c[1])])\n break\n case 2:\n R.push([B(C, E, c[1], c[0])])\n break\n case 3:\n break\n }\n }\n }\n return R\n }\n return getContour2d\n },\n function cellPolygonizer_3() {\n function B(C, E, i, j) {\n var a = Math.min(i, j) | 0,\n b = Math.max(i, j) | 0,\n l = C[2 * a],\n h = C[2 * a + 1]\n while (l < h) {\n var m = (l + h) >> 1,\n v = E[2 * m + 1]\n if (v === b) {\n return m\n }\n if (b < v) {\n h = m\n } else {\n l = m + 1\n }\n }\n return l\n }\n function getContour3d(F, E, C, S) {\n var n = F.length,\n R = []\n for (var i = 0; i < n; ++i) {\n var c = F[i],\n l = c.length\n if (l === 4) {\n var M = (S[c[0]] << 0) + (S[c[1]] << 1) + (S[c[2]] << 2) + (S[c[3]] << 3)\n if (M === 0 || M === 15) {\n continue\n }\n switch (M) {\n case 0:\n break\n case 1:\n R.push([B(C, E, c[0], c[1]), B(C, E, c[0], c[2]), B(C, E, c[0], c[3])])\n break\n case 2:\n R.push([B(C, E, c[1], c[2]), B(C, E, c[1], c[0]), B(C, E, c[1], c[3])])\n break\n case 3:\n R.push([B(C, E, c[1], c[2]), B(C, E, c[0], c[2]), B(C, E, c[0], c[3])], [B(C, E, c[1], c[3]), B(C, E, c[1], c[2]), B(C, E, c[0], c[3])])\n break\n case 4:\n R.push([B(C, E, c[2], c[0]), B(C, E, c[2], c[1]), B(C, E, c[2], c[3])])\n break\n case 5:\n R.push([B(C, E, c[0], c[1]), B(C, E, c[2], c[1]), B(C, E, c[0], c[3])], [B(C, E, c[2], c[1]), B(C, E, c[2], c[3]), B(C, E, c[0], c[3])])\n break\n case 6:\n R.push([B(C, E, c[2], c[0]), B(C, E, c[1], c[0]), B(C, E, c[1], c[3])], [B(C, E, c[2], c[3]), B(C, E, c[2], c[0]), B(C, E, c[1], c[3])])\n break\n case 7:\n R.push([B(C, E, c[0], c[3]), B(C, E, c[1], c[3]), B(C, E, c[2], c[3])])\n break\n case 8:\n R.push([B(C, E, c[3], c[1]), B(C, E, c[3], c[0]), B(C, E, c[3], c[2])])\n break\n case 9:\n R.push([B(C, E, c[3], c[1]), B(C, E, c[0], c[1]), B(C, E, c[0], c[2])], [B(C, E, c[3], c[2]), B(C, E, c[3], c[1]), B(C, E, c[0], c[2])])\n break\n case 10:\n R.push([B(C, E, c[1], c[0]), B(C, E, c[3], c[0]), B(C, E, c[1], c[2])], [B(C, E, c[3], c[0]), B(C, E, c[3], c[2]), B(C, E, c[1], c[2])])\n break\n case 11:\n R.push([B(C, E, c[1], c[2]), B(C, E, c[0], c[2]), B(C, E, c[3], c[2])])\n break\n case 12:\n R.push([B(C, E, c[3], c[0]), B(C, E, c[2], c[0]), B(C, E, c[2], c[1])], [B(C, E, c[3], c[1]), B(C, E, c[3], c[0]), B(C, E, c[2], c[1])])\n break\n case 13:\n R.push([B(C, E, c[0], c[1]), B(C, E, c[2], c[1]), B(C, E, c[3], c[1])])\n break\n case 14:\n R.push([B(C, E, c[2], c[0]), B(C, E, c[1], c[0]), B(C, E, c[3], c[0])])\n break\n case 15:\n break\n }\n } else if (l === 3) {\n var M = (S[c[0]] << 0) + (S[c[1]] << 1) + (S[c[2]] << 2)\n if (M === 0 || M === 7) {\n continue\n }\n switch (M) {\n case 0:\n break\n case 1:\n R.push([B(C, E, c[0], c[2]), B(C, E, c[0], c[1])])\n break\n case 2:\n R.push([B(C, E, c[1], c[0]), B(C, E, c[1], c[2])])\n break\n case 3:\n R.push([B(C, E, c[0], c[2]), B(C, E, c[1], c[2])])\n break\n case 4:\n R.push([B(C, E, c[2], c[1]), B(C, E, c[2], c[0])])\n break\n case 5:\n R.push([B(C, E, c[2], c[1]), B(C, E, c[0], c[1])])\n break\n case 6:\n R.push([B(C, E, c[1], c[0]), B(C, E, c[2], c[0])])\n break\n case 7:\n break\n }\n } else if (l === 2) {\n var M = (S[c[0]] << 0) + (S[c[1]] << 1)\n if (M === 0 || M === 3) {\n continue\n }\n switch (M) {\n case 0:\n break\n case 1:\n R.push([B(C, E, c[0], c[1])])\n break\n case 2:\n R.push([B(C, E, c[1], c[0])])\n break\n case 3:\n break\n }\n }\n }\n return R\n }\n return getContour3d\n }\n]\n\nfunction getPolygonizer(d) {\n return allFns[d]();\n}\n\n\n/***/ }),\n\n/***/ 6803:\n/***/ (function(__unused_webpack_module, exports, __webpack_require__) {\n\n\"use strict\";\nvar __webpack_unused_export__;\n \"use restrict\";\n\nvar bits = __webpack_require__(8828)\n , UnionFind = __webpack_require__(1755)\n\n//Returns the dimension of a cell complex\nfunction dimension(cells) {\n var d = 0\n , max = Math.max\n for(var i=0, il=cells.length; i> 1\n , s = compareCells(cells[mid], c)\n if(s <= 0) {\n if(s === 0) {\n r = mid\n }\n lo = mid + 1\n } else if(s > 0) {\n hi = mid - 1\n }\n }\n return r\n}\n__webpack_unused_export__ = findCell;\n\n//Builds an index for an n-cell. This is more general than dual, but less efficient\nfunction incidence(from_cells, to_cells) {\n var index = new Array(from_cells.length)\n for(var i=0, il=index.length; i= from_cells.length || compareCells(from_cells[idx], b) !== 0) {\n break\n }\n }\n }\n }\n return index\n}\n__webpack_unused_export__ = incidence\n\n//Computes the dual of the mesh. This is basically an optimized version of buildIndex for the situation where from_cells is just the list of vertices\nfunction dual(cells, vertex_count) {\n if(!vertex_count) {\n return incidence(unique(skeleton(cells, 0)), cells, 0)\n }\n var res = new Array(vertex_count)\n for(var i=0; i>> k) & 1) {\n b.push(c[k])\n }\n }\n result.push(b)\n }\n }\n return normalize(result)\n}\n__webpack_unused_export__ = explode\n\n//Enumerates all of the n-cells of a cell complex\nfunction skeleton(cells, n) {\n if(n < 0) {\n return []\n }\n var result = []\n , k0 = (1<<(n+1))-1\n for(var i=0; i 0) - (v < 0);\n}\n\n//Computes absolute value of integer\nexports.abs = function(v) {\n var mask = v >> (INT_BITS-1);\n return (v ^ mask) - mask;\n}\n\n//Computes minimum of integers x and y\nexports.min = function(x, y) {\n return y ^ ((x ^ y) & -(x < y));\n}\n\n//Computes maximum of integers x and y\nexports.max = function(x, y) {\n return x ^ ((x ^ y) & -(x < y));\n}\n\n//Checks if a number is a power of two\nexports.isPow2 = function(v) {\n return !(v & (v-1)) && (!!v);\n}\n\n//Computes log base 2 of v\nexports.log2 = function(v) {\n var r, shift;\n r = (v > 0xFFFF) << 4; v >>>= r;\n shift = (v > 0xFF ) << 3; v >>>= shift; r |= shift;\n shift = (v > 0xF ) << 2; v >>>= shift; r |= shift;\n shift = (v > 0x3 ) << 1; v >>>= shift; r |= shift;\n return r | (v >> 1);\n}\n\n//Computes log base 10 of v\nexports.log10 = function(v) {\n return (v >= 1000000000) ? 9 : (v >= 100000000) ? 8 : (v >= 10000000) ? 7 :\n (v >= 1000000) ? 6 : (v >= 100000) ? 5 : (v >= 10000) ? 4 :\n (v >= 1000) ? 3 : (v >= 100) ? 2 : (v >= 10) ? 1 : 0;\n}\n\n//Counts number of bits\nexports.popCount = function(v) {\n v = v - ((v >>> 1) & 0x55555555);\n v = (v & 0x33333333) + ((v >>> 2) & 0x33333333);\n return ((v + (v >>> 4) & 0xF0F0F0F) * 0x1010101) >>> 24;\n}\n\n//Counts number of trailing zeros\nfunction countTrailingZeros(v) {\n var c = 32;\n v &= -v;\n if (v) c--;\n if (v & 0x0000FFFF) c -= 16;\n if (v & 0x00FF00FF) c -= 8;\n if (v & 0x0F0F0F0F) c -= 4;\n if (v & 0x33333333) c -= 2;\n if (v & 0x55555555) c -= 1;\n return c;\n}\nexports.countTrailingZeros = countTrailingZeros;\n\n//Rounds to next power of 2\nexports.nextPow2 = function(v) {\n v += v === 0;\n --v;\n v |= v >>> 1;\n v |= v >>> 2;\n v |= v >>> 4;\n v |= v >>> 8;\n v |= v >>> 16;\n return v + 1;\n}\n\n//Rounds down to previous power of 2\nexports.prevPow2 = function(v) {\n v |= v >>> 1;\n v |= v >>> 2;\n v |= v >>> 4;\n v |= v >>> 8;\n v |= v >>> 16;\n return v - (v>>>1);\n}\n\n//Computes parity of word\nexports.parity = function(v) {\n v ^= v >>> 16;\n v ^= v >>> 8;\n v ^= v >>> 4;\n v &= 0xf;\n return (0x6996 >>> v) & 1;\n}\n\nvar REVERSE_TABLE = new Array(256);\n\n(function(tab) {\n for(var i=0; i<256; ++i) {\n var v = i, r = i, s = 7;\n for (v >>>= 1; v; v >>>= 1) {\n r <<= 1;\n r |= v & 1;\n --s;\n }\n tab[i] = (r << s) & 0xff;\n }\n})(REVERSE_TABLE);\n\n//Reverse bits in a 32 bit word\nexports.reverse = function(v) {\n return (REVERSE_TABLE[ v & 0xff] << 24) |\n (REVERSE_TABLE[(v >>> 8) & 0xff] << 16) |\n (REVERSE_TABLE[(v >>> 16) & 0xff] << 8) |\n REVERSE_TABLE[(v >>> 24) & 0xff];\n}\n\n//Interleave bits of 2 coordinates with 16 bits. Useful for fast quadtree codes\nexports.interleave2 = function(x, y) {\n x &= 0xFFFF;\n x = (x | (x << 8)) & 0x00FF00FF;\n x = (x | (x << 4)) & 0x0F0F0F0F;\n x = (x | (x << 2)) & 0x33333333;\n x = (x | (x << 1)) & 0x55555555;\n\n y &= 0xFFFF;\n y = (y | (y << 8)) & 0x00FF00FF;\n y = (y | (y << 4)) & 0x0F0F0F0F;\n y = (y | (y << 2)) & 0x33333333;\n y = (y | (y << 1)) & 0x55555555;\n\n return x | (y << 1);\n}\n\n//Extracts the nth interleaved component\nexports.deinterleave2 = function(v, n) {\n v = (v >>> n) & 0x55555555;\n v = (v | (v >>> 1)) & 0x33333333;\n v = (v | (v >>> 2)) & 0x0F0F0F0F;\n v = (v | (v >>> 4)) & 0x00FF00FF;\n v = (v | (v >>> 16)) & 0x000FFFF;\n return (v << 16) >> 16;\n}\n\n\n//Interleave bits of 3 coordinates, each with 10 bits. Useful for fast octree codes\nexports.interleave3 = function(x, y, z) {\n x &= 0x3FF;\n x = (x | (x<<16)) & 4278190335;\n x = (x | (x<<8)) & 251719695;\n x = (x | (x<<4)) & 3272356035;\n x = (x | (x<<2)) & 1227133513;\n\n y &= 0x3FF;\n y = (y | (y<<16)) & 4278190335;\n y = (y | (y<<8)) & 251719695;\n y = (y | (y<<4)) & 3272356035;\n y = (y | (y<<2)) & 1227133513;\n x |= (y << 1);\n \n z &= 0x3FF;\n z = (z | (z<<16)) & 4278190335;\n z = (z | (z<<8)) & 251719695;\n z = (z | (z<<4)) & 3272356035;\n z = (z | (z<<2)) & 1227133513;\n \n return x | (z << 2);\n}\n\n//Extracts nth interleaved component of a 3-tuple\nexports.deinterleave3 = function(v, n) {\n v = (v >>> n) & 1227133513;\n v = (v | (v>>>2)) & 3272356035;\n v = (v | (v>>>4)) & 251719695;\n v = (v | (v>>>8)) & 4278190335;\n v = (v | (v>>>16)) & 0x3FF;\n return (v<<22)>>22;\n}\n\n//Computes next combination in colexicographic order (this is mistakenly called nextPermutation on the bit twiddling hacks page)\nexports.nextCombination = function(v) {\n var t = v | (v - 1);\n return (t + 1) | (((~t & -~t) - 1) >>> (countTrailingZeros(v) + 1));\n}\n\n\n\n/***/ }),\n\n/***/ 2014:\n/***/ (function(__unused_webpack_module, exports, __webpack_require__) {\n\n\"use strict\";\n \"use restrict\";\n\nvar bits = __webpack_require__(3105)\n , UnionFind = __webpack_require__(4623)\n\n//Returns the dimension of a cell complex\nfunction dimension(cells) {\n var d = 0\n , max = Math.max\n for(var i=0, il=cells.length; i> 1\n , s = compareCells(cells[mid], c)\n if(s <= 0) {\n if(s === 0) {\n r = mid\n }\n lo = mid + 1\n } else if(s > 0) {\n hi = mid - 1\n }\n }\n return r\n}\nexports.findCell = findCell;\n\n//Builds an index for an n-cell. This is more general than dual, but less efficient\nfunction incidence(from_cells, to_cells) {\n var index = new Array(from_cells.length)\n for(var i=0, il=index.length; i= from_cells.length || compareCells(from_cells[idx], b) !== 0) {\n break\n }\n }\n }\n }\n return index\n}\nexports.incidence = incidence\n\n//Computes the dual of the mesh. This is basically an optimized version of buildIndex for the situation where from_cells is just the list of vertices\nfunction dual(cells, vertex_count) {\n if(!vertex_count) {\n return incidence(unique(skeleton(cells, 0)), cells, 0)\n }\n var res = new Array(vertex_count)\n for(var i=0; i>> k) & 1) {\n b.push(c[k])\n }\n }\n result.push(b)\n }\n }\n return normalize(result)\n}\nexports.explode = explode\n\n//Enumerates all of the n-cells of a cell complex\nfunction skeleton(cells, n) {\n if(n < 0) {\n return []\n }\n var result = []\n , k0 = (1<<(n+1))-1\n for(var i=0; i> 1\n }\n return (i >> 1) - 1\n }\n\n //Bubble element i down the heap\n function heapDown(i) {\n var w = heapWeight(i)\n while(true) {\n var tw = w\n var left = 2*i + 1\n var right = 2*(i + 1)\n var next = i\n if(left < heapCount) {\n var lw = heapWeight(left)\n if(lw < tw) {\n next = left\n tw = lw\n }\n }\n if(right < heapCount) {\n var rw = heapWeight(right)\n if(rw < tw) {\n next = right\n }\n }\n if(next === i) {\n return i\n }\n heapSwap(i, next)\n i = next \n }\n }\n\n //Bubbles element i up the heap\n function heapUp(i) {\n var w = heapWeight(i)\n while(i > 0) {\n var parent = heapParent(i)\n if(parent >= 0) {\n var pw = heapWeight(parent)\n if(w < pw) {\n heapSwap(i, parent)\n i = parent\n continue\n }\n }\n return i\n }\n }\n\n //Pop minimum element\n function heapPop() {\n if(heapCount > 0) {\n var head = heap[0]\n heapSwap(0, heapCount-1)\n heapCount -= 1\n heapDown(0)\n return head\n }\n return -1\n }\n\n //Update heap item i\n function heapUpdate(i, w) {\n var a = heap[i]\n if(weights[a] === w) {\n return i\n }\n weights[a] = -Infinity\n heapUp(i)\n heapPop()\n weights[a] = w\n heapCount += 1\n return heapUp(heapCount-1)\n }\n\n //Kills a vertex (assume vertex already removed from heap)\n function kill(i) {\n if(dead[i]) {\n return\n }\n //Kill vertex\n dead[i] = true\n //Fixup topology\n var s = inv[i]\n var t = outv[i]\n if(inv[t] >= 0) {\n inv[t] = s\n }\n if(outv[s] >= 0) {\n outv[s] = t\n }\n\n //Update weights on s and t\n if(index[s] >= 0) {\n heapUpdate(index[s], computeWeight(s))\n }\n if(index[t] >= 0) {\n heapUpdate(index[t], computeWeight(t))\n }\n }\n\n //Initialize weights and heap\n var heap = []\n var index = new Array(n)\n for(var i=0; i>1; i>=0; --i) {\n heapDown(i)\n }\n \n //Kill vertices\n while(true) {\n var hmin = heapPop()\n if((hmin < 0) || (weights[hmin] > minArea)) {\n break\n }\n kill(hmin)\n }\n\n //Build collapsed vertex table\n var npositions = []\n for(var i=0; i= 0 && tout >= 0 && tin !== tout) {\n var cin = index[tin]\n var cout = index[tout]\n if(cin !== cout) {\n ncells.push([ cin, cout ])\n }\n }\n })\n\n //Normalize result\n sc.unique(sc.normalize(ncells))\n\n //Return final list of cells\n return {\n positions: npositions,\n edges: ncells\n }\n}\n\n/***/ }),\n\n/***/ 1303:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = orderSegments\n\nvar orient = __webpack_require__(3250)\n\nfunction horizontalOrder(a, b) {\n var bl, br\n if(b[0][0] < b[1][0]) {\n bl = b[0]\n br = b[1]\n } else if(b[0][0] > b[1][0]) {\n bl = b[1]\n br = b[0]\n } else {\n var alo = Math.min(a[0][1], a[1][1])\n var ahi = Math.max(a[0][1], a[1][1])\n var blo = Math.min(b[0][1], b[1][1])\n var bhi = Math.max(b[0][1], b[1][1])\n if(ahi < blo) {\n return ahi - blo\n }\n if(alo > bhi) {\n return alo - bhi\n }\n return ahi - bhi\n }\n var al, ar\n if(a[0][1] < a[1][1]) {\n al = a[0]\n ar = a[1]\n } else {\n al = a[1]\n ar = a[0]\n }\n var d = orient(br, bl, al)\n if(d) {\n return d\n }\n d = orient(br, bl, ar)\n if(d) {\n return d\n }\n return ar - br\n}\n\nfunction orderSegments(b, a) {\n var al, ar\n if(a[0][0] < a[1][0]) {\n al = a[0]\n ar = a[1]\n } else if(a[0][0] > a[1][0]) {\n al = a[1]\n ar = a[0]\n } else {\n return horizontalOrder(a, b)\n }\n var bl, br\n if(b[0][0] < b[1][0]) {\n bl = b[0]\n br = b[1]\n } else if(b[0][0] > b[1][0]) {\n bl = b[1]\n br = b[0]\n } else {\n return -horizontalOrder(b, a)\n }\n var d1 = orient(al, ar, br)\n var d2 = orient(al, ar, bl)\n if(d1 < 0) {\n if(d2 <= 0) {\n return d1\n }\n } else if(d1 > 0) {\n if(d2 >= 0) {\n return d1\n }\n } else if(d2) {\n return d2\n }\n d1 = orient(br, bl, ar)\n d2 = orient(br, bl, al)\n if(d1 < 0) {\n if(d2 <= 0) {\n return d1\n }\n } else if(d1 > 0) {\n if(d2 >= 0) {\n return d1\n }\n } else if(d2) {\n return d2\n }\n return ar[0] - br[0]\n}\n\n/***/ }),\n\n/***/ 4209:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = createSlabDecomposition\n\nvar bounds = __webpack_require__(2478)\nvar createRBTree = __webpack_require__(3840)\nvar orient = __webpack_require__(3250)\nvar orderSegments = __webpack_require__(1303)\n\nfunction SlabDecomposition(slabs, coordinates, horizontal) {\n this.slabs = slabs\n this.coordinates = coordinates\n this.horizontal = horizontal\n}\n\nvar proto = SlabDecomposition.prototype\n\nfunction compareHorizontal(e, y) {\n return e.y - y\n}\n\nfunction searchBucket(root, p) {\n var lastNode = null\n while(root) {\n var seg = root.key\n var l, r\n if(seg[0][0] < seg[1][0]) {\n l = seg[0]\n r = seg[1]\n } else {\n l = seg[1]\n r = seg[0]\n }\n var o = orient(l, r, p)\n if(o < 0) {\n root = root.left\n } else if(o > 0) {\n if(p[0] !== seg[1][0]) {\n lastNode = root\n root = root.right\n } else {\n var val = searchBucket(root.right, p)\n if(val) {\n return val\n }\n root = root.left\n }\n } else {\n if(p[0] !== seg[1][0]) {\n return root\n } else {\n var val = searchBucket(root.right, p)\n if(val) {\n return val\n }\n root = root.left\n }\n }\n }\n return lastNode\n}\n\nproto.castUp = function(p) {\n var bucket = bounds.le(this.coordinates, p[0])\n if(bucket < 0) {\n return -1\n }\n var root = this.slabs[bucket]\n var hitNode = searchBucket(this.slabs[bucket], p)\n var lastHit = -1\n if(hitNode) {\n lastHit = hitNode.value\n }\n //Edge case: need to handle horizontal segments (sucks)\n if(this.coordinates[bucket] === p[0]) {\n var lastSegment = null\n if(hitNode) {\n lastSegment = hitNode.key\n }\n if(bucket > 0) {\n var otherHitNode = searchBucket(this.slabs[bucket-1], p)\n if(otherHitNode) {\n if(lastSegment) {\n if(orderSegments(otherHitNode.key, lastSegment) > 0) {\n lastSegment = otherHitNode.key\n lastHit = otherHitNode.value\n }\n } else {\n lastHit = otherHitNode.value\n lastSegment = otherHitNode.key\n }\n }\n }\n var horiz = this.horizontal[bucket]\n if(horiz.length > 0) {\n var hbucket = bounds.ge(horiz, p[1], compareHorizontal)\n if(hbucket < horiz.length) {\n var e = horiz[hbucket]\n if(p[1] === e.y) {\n if(e.closed) {\n return e.index\n } else {\n while(hbucket < horiz.length-1 && horiz[hbucket+1].y === p[1]) {\n hbucket = hbucket+1\n e = horiz[hbucket]\n if(e.closed) {\n return e.index\n }\n }\n if(e.y === p[1] && !e.start) {\n hbucket = hbucket+1\n if(hbucket >= horiz.length) {\n return lastHit\n }\n e = horiz[hbucket]\n }\n }\n }\n //Check if e is above/below last segment\n if(e.start) {\n if(lastSegment) {\n var o = orient(lastSegment[0], lastSegment[1], [p[0], e.y])\n if(lastSegment[0][0] > lastSegment[1][0]) {\n o = -o\n }\n if(o > 0) {\n lastHit = e.index\n }\n } else {\n lastHit = e.index\n }\n } else if(e.y !== p[1]) {\n lastHit = e.index\n }\n }\n }\n }\n return lastHit\n}\n\nfunction IntervalSegment(y, index, start, closed) {\n this.y = y\n this.index = index\n this.start = start\n this.closed = closed\n}\n\nfunction Event(x, segment, create, index) {\n this.x = x\n this.segment = segment\n this.create = create\n this.index = index\n}\n\n\nfunction createSlabDecomposition(segments) {\n var numSegments = segments.length\n var numEvents = 2 * numSegments\n var events = new Array(numEvents)\n for(var i=0; i 1.0) {\n t = 1.0\n }\n var ti = 1.0 - t\n var n = a.length\n var r = new Array(n)\n for(var i=0; i 0) || (a > 0 && b < 0)) {\n var p = lerpW(s, b, t, a)\n pos.push(p)\n neg.push(p.slice())\n }\n if(b < 0) {\n neg.push(t.slice())\n } else if(b > 0) {\n pos.push(t.slice())\n } else {\n pos.push(t.slice())\n neg.push(t.slice())\n }\n a = b\n }\n return { positive: pos, negative: neg }\n}\n\nfunction positive(points, plane) {\n var pos = []\n var a = planeT(points[points.length-1], plane)\n for(var s=points[points.length-1], t=points[0], i=0; i 0) || (a > 0 && b < 0)) {\n pos.push(lerpW(s, b, t, a))\n }\n if(b >= 0) {\n pos.push(t.slice())\n }\n a = b\n }\n return pos\n}\n\nfunction negative(points, plane) {\n var neg = []\n var a = planeT(points[points.length-1], plane)\n for(var s=points[points.length-1], t=points[0], i=0; i 0) || (a > 0 && b < 0)) {\n neg.push(lerpW(s, b, t, a))\n }\n if(b <= 0) {\n neg.push(t.slice())\n }\n a = b\n }\n return neg\n}\n\n/***/ }),\n\n/***/ 3387:\n/***/ (function(module, exports, __webpack_require__) {\n\nvar __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */\n\n!function() {\n 'use strict'\n\n var re = {\n not_string: /[^s]/,\n not_bool: /[^t]/,\n not_type: /[^T]/,\n not_primitive: /[^v]/,\n number: /[diefg]/,\n numeric_arg: /[bcdiefguxX]/,\n json: /[j]/,\n not_json: /[^j]/,\n text: /^[^\\x25]+/,\n modulo: /^\\x25{2}/,\n placeholder: /^\\x25(?:([1-9]\\d*)\\$|\\(([^)]+)\\))?(\\+)?(0|'[^$])?(-)?(\\d+)?(?:\\.(\\d+))?([b-gijostTuvxX])/,\n key: /^([a-z_][a-z_\\d]*)/i,\n key_access: /^\\.([a-z_][a-z_\\d]*)/i,\n index_access: /^\\[(\\d+)\\]/,\n sign: /^[+-]/\n }\n\n function sprintf(key) {\n // `arguments` is not an array, but should be fine for this call\n return sprintf_format(sprintf_parse(key), arguments)\n }\n\n function vsprintf(fmt, argv) {\n return sprintf.apply(null, [fmt].concat(argv || []))\n }\n\n function sprintf_format(parse_tree, argv) {\n var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign\n for (i = 0; i < tree_length; i++) {\n if (typeof parse_tree[i] === 'string') {\n output += parse_tree[i]\n }\n else if (typeof parse_tree[i] === 'object') {\n ph = parse_tree[i] // convenience purposes only\n if (ph.keys) { // keyword argument\n arg = argv[cursor]\n for (k = 0; k < ph.keys.length; k++) {\n if (arg == undefined) {\n throw new Error(sprintf('[sprintf] Cannot access property \"%s\" of undefined value \"%s\"', ph.keys[k], ph.keys[k-1]))\n }\n arg = arg[ph.keys[k]]\n }\n }\n else if (ph.param_no) { // positional argument (explicit)\n arg = argv[ph.param_no]\n }\n else { // positional argument (implicit)\n arg = argv[cursor++]\n }\n\n if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) {\n arg = arg()\n }\n\n if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) {\n throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg))\n }\n\n if (re.number.test(ph.type)) {\n is_positive = arg >= 0\n }\n\n switch (ph.type) {\n case 'b':\n arg = parseInt(arg, 10).toString(2)\n break\n case 'c':\n arg = String.fromCharCode(parseInt(arg, 10))\n break\n case 'd':\n case 'i':\n arg = parseInt(arg, 10)\n break\n case 'j':\n arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0)\n break\n case 'e':\n arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential()\n break\n case 'f':\n arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg)\n break\n case 'g':\n arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg)\n break\n case 'o':\n arg = (parseInt(arg, 10) >>> 0).toString(8)\n break\n case 's':\n arg = String(arg)\n arg = (ph.precision ? arg.substring(0, ph.precision) : arg)\n break\n case 't':\n arg = String(!!arg)\n arg = (ph.precision ? arg.substring(0, ph.precision) : arg)\n break\n case 'T':\n arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase()\n arg = (ph.precision ? arg.substring(0, ph.precision) : arg)\n break\n case 'u':\n arg = parseInt(arg, 10) >>> 0\n break\n case 'v':\n arg = arg.valueOf()\n arg = (ph.precision ? arg.substring(0, ph.precision) : arg)\n break\n case 'x':\n arg = (parseInt(arg, 10) >>> 0).toString(16)\n break\n case 'X':\n arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase()\n break\n }\n if (re.json.test(ph.type)) {\n output += arg\n }\n else {\n if (re.number.test(ph.type) && (!is_positive || ph.sign)) {\n sign = is_positive ? '+' : '-'\n arg = arg.toString().replace(re.sign, '')\n }\n else {\n sign = ''\n }\n pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' '\n pad_length = ph.width - (sign + arg).length\n pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : ''\n output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg)\n }\n }\n }\n return output\n }\n\n var sprintf_cache = Object.create(null)\n\n function sprintf_parse(fmt) {\n if (sprintf_cache[fmt]) {\n return sprintf_cache[fmt]\n }\n\n var _fmt = fmt, match, parse_tree = [], arg_names = 0\n while (_fmt) {\n if ((match = re.text.exec(_fmt)) !== null) {\n parse_tree.push(match[0])\n }\n else if ((match = re.modulo.exec(_fmt)) !== null) {\n parse_tree.push('%')\n }\n else if ((match = re.placeholder.exec(_fmt)) !== null) {\n if (match[2]) {\n arg_names |= 1\n var field_list = [], replacement_field = match[2], field_match = []\n if ((field_match = re.key.exec(replacement_field)) !== null) {\n field_list.push(field_match[1])\n while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') {\n if ((field_match = re.key_access.exec(replacement_field)) !== null) {\n field_list.push(field_match[1])\n }\n else if ((field_match = re.index_access.exec(replacement_field)) !== null) {\n field_list.push(field_match[1])\n }\n else {\n throw new SyntaxError('[sprintf] failed to parse named argument key')\n }\n }\n }\n else {\n throw new SyntaxError('[sprintf] failed to parse named argument key')\n }\n match[2] = field_list\n }\n else {\n arg_names |= 2\n }\n if (arg_names === 3) {\n throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported')\n }\n\n parse_tree.push(\n {\n placeholder: match[0],\n param_no: match[1],\n keys: match[2],\n sign: match[3],\n pad_char: match[4],\n align: match[5],\n width: match[6],\n precision: match[7],\n type: match[8]\n }\n )\n }\n else {\n throw new SyntaxError('[sprintf] unexpected placeholder')\n }\n _fmt = _fmt.substring(match[0].length)\n }\n return sprintf_cache[fmt] = parse_tree\n }\n\n /**\n * export to either browser or node.js\n */\n /* eslint-disable quote-props */\n if (true) {\n exports.sprintf = sprintf\n exports.vsprintf = vsprintf\n }\n if (typeof window !== 'undefined') {\n window['sprintf'] = sprintf\n window['vsprintf'] = vsprintf\n\n if (true) {\n !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() {\n return {\n 'sprintf': sprintf,\n 'vsprintf': vsprintf\n }\n }).call(exports, __webpack_require__, exports, module),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__))\n }\n }\n /* eslint-enable quote-props */\n}(); // eslint-disable-line\n\n\n/***/ }),\n\n/***/ 3711:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = surfaceNets\n\nvar generateContourExtractor = __webpack_require__(2640)\nvar zeroCrossings = __webpack_require__(781)\n\nvar allFns = {\n \"2d\": function (genContour, order, dtype) {\n var contour = genContour({\n order: order,\n scalarArguments: 3,\n getters: dtype === \"generic\" ? [0] : undefined,\n phase: function phaseFunc(p, a, b, c) {\n return (p > c) | 0;\n },\n vertex: function vertexFunc(d0, d1, v0, v1, v2, v3, p0, p1, p2, p3, a, b, c) {\n var m = ((p0 << 0) + (p1 << 1) + (p2 << 2) + (p3 << 3)) | 0;\n if (m === 0 || m === 15) {\n return;\n }\n switch (m) {\n case 0:\n a.push([d0 - 0.5, d1 - 0.5]);\n break;\n case 1:\n a.push([d0 - 0.25 - (0.25 * (v1 + v0 - 2 * c)) / (v0 - v1), d1 - 0.25 - (0.25 * (v2 + v0 - 2 * c)) / (v0 - v2)]);\n break;\n case 2:\n a.push([d0 - 0.75 - (0.25 * (-v1 - v0 + 2 * c)) / (v1 - v0), d1 - 0.25 - (0.25 * (v3 + v1 - 2 * c)) / (v1 - v3)]);\n break;\n case 3:\n a.push([d0 - 0.5, d1 - 0.5 - (0.5 * (v2 + v0 + v3 + v1 - 4 * c)) / (v0 - v2 + v1 - v3)]);\n break;\n case 4:\n a.push([d0 - 0.25 - (0.25 * (v3 + v2 - 2 * c)) / (v2 - v3), d1 - 0.75 - (0.25 * (-v2 - v0 + 2 * c)) / (v2 - v0)]);\n break;\n case 5:\n a.push([d0 - 0.5 - (0.5 * (v1 + v0 + v3 + v2 - 4 * c)) / (v0 - v1 + v2 - v3), d1 - 0.5]);\n break;\n case 6:\n a.push([d0 - 0.5 - (0.25 * (-v1 - v0 + v3 + v2)) / (v1 - v0 + v2 - v3), d1 - 0.5 - (0.25 * (-v2 - v0 + v3 + v1)) / (v2 - v0 + v1 - v3)]);\n break;\n case 7:\n a.push([d0 - 0.75 - (0.25 * (v3 + v2 - 2 * c)) / (v2 - v3), d1 - 0.75 - (0.25 * (v3 + v1 - 2 * c)) / (v1 - v3)]);\n break;\n case 8:\n a.push([d0 - 0.75 - (0.25 * (-v3 - v2 + 2 * c)) / (v3 - v2), d1 - 0.75 - (0.25 * (-v3 - v1 + 2 * c)) / (v3 - v1)]);\n break;\n case 9:\n a.push([d0 - 0.5 - (0.25 * (v1 + v0 + -v3 - v2)) / (v0 - v1 + v3 - v2), d1 - 0.5 - (0.25 * (v2 + v0 + -v3 - v1)) / (v0 - v2 + v3 - v1)]);\n break;\n case 10:\n a.push([d0 - 0.5 - (0.5 * (-v1 - v0 + -v3 - v2 + 4 * c)) / (v1 - v0 + v3 - v2), d1 - 0.5]);\n break;\n case 11:\n a.push([d0 - 0.25 - (0.25 * (-v3 - v2 + 2 * c)) / (v3 - v2), d1 - 0.75 - (0.25 * (v2 + v0 - 2 * c)) / (v0 - v2)]);\n break;\n case 12:\n a.push([d0 - 0.5, d1 - 0.5 - (0.5 * (-v2 - v0 + -v3 - v1 + 4 * c)) / (v2 - v0 + v3 - v1)]);\n break;\n case 13:\n a.push([d0 - 0.75 - (0.25 * (v1 + v0 - 2 * c)) / (v0 - v1), d1 - 0.25 - (0.25 * (-v3 - v1 + 2 * c)) / (v3 - v1)]);\n break;\n case 14:\n a.push([d0 - 0.25 - (0.25 * (-v1 - v0 + 2 * c)) / (v1 - v0), d1 - 0.25 - (0.25 * (-v2 - v0 + 2 * c)) / (v2 - v0)]);\n break;\n case 15:\n a.push([d0 - 0.5, d1 - 0.5]);\n break;\n }\n },\n cell: function cellFunc(v0, v1, c0, c1, p0, p1, a, b, c) {\n if (p0) {\n b.push([v0, v1]);\n } else {\n b.push([v1, v0]);\n }\n },\n });\n return function (array, level) {\n var verts = [],\n cells = [];\n contour(array, verts, cells, level);\n return { positions: verts, cells: cells };\n };\n }\n}\n\nfunction buildSurfaceNets(order, dtype) {\n var inKey = order.length + 'd'\n var fn = allFns[inKey]\n if(fn) return fn(generateContourExtractor, order, dtype)\n}\n\n//1D case: Need to handle specially\nfunction mesh1D(array, level) {\n var zc = zeroCrossings(array, level)\n var n = zc.length\n var npos = new Array(n)\n var ncel = new Array(n)\n for(var i=0; i0) {\n shapeX += 0.02\n }\n }\n\n var data = new Float32Array(bufferSize)\n var ptr = 0\n var xOffset = -0.5 * shapeX\n for(var i=0; i Math.max(vy, vz)) {\n u[2] = 1\n } else if(vy > Math.max(vx, vz)) {\n u[0] = 1\n } else {\n u[1] = 1\n }\n\n var vv = 0\n var uv = 0\n for(var i=0; i<3; ++i ) {\n vv += v[i] * v[i]\n uv += u[i] * v[i]\n }\n for(var i=0; i<3; ++i) {\n u[i] -= (uv / vv) * v[i]\n }\n normalize3(u, u)\n return u\n}\n\nfunction TurntableController(zoomMin, zoomMax, center, up, right, radius, theta, phi) {\n this.center = filterVector(center)\n this.up = filterVector(up)\n this.right = filterVector(right)\n this.radius = filterVector([radius])\n this.angle = filterVector([theta, phi])\n this.angle.bounds = [[-Infinity,-Math.PI/2], [Infinity,Math.PI/2]]\n this.setDistanceLimits(zoomMin, zoomMax)\n\n this.computedCenter = this.center.curve(0)\n this.computedUp = this.up.curve(0)\n this.computedRight = this.right.curve(0)\n this.computedRadius = this.radius.curve(0)\n this.computedAngle = this.angle.curve(0)\n this.computedToward = [0,0,0]\n this.computedEye = [0,0,0]\n this.computedMatrix = new Array(16)\n for(var i=0; i<16; ++i) {\n this.computedMatrix[i] = 0.5\n }\n\n this.recalcMatrix(0)\n}\n\nvar proto = TurntableController.prototype\n\nproto.setDistanceLimits = function(minDist, maxDist) {\n if(minDist > 0) {\n minDist = Math.log(minDist)\n } else {\n minDist = -Infinity\n }\n if(maxDist > 0) {\n maxDist = Math.log(maxDist)\n } else {\n maxDist = Infinity\n }\n maxDist = Math.max(maxDist, minDist)\n this.radius.bounds[0][0] = minDist\n this.radius.bounds[1][0] = maxDist\n}\n\nproto.getDistanceLimits = function(out) {\n var bounds = this.radius.bounds[0]\n if(out) {\n out[0] = Math.exp(bounds[0][0])\n out[1] = Math.exp(bounds[1][0])\n return out\n }\n return [ Math.exp(bounds[0][0]), Math.exp(bounds[1][0]) ]\n}\n\nproto.recalcMatrix = function(t) {\n //Recompute curves\n this.center.curve(t)\n this.up.curve(t)\n this.right.curve(t)\n this.radius.curve(t)\n this.angle.curve(t)\n\n //Compute frame for camera matrix\n var up = this.computedUp\n var right = this.computedRight\n var uu = 0.0\n var ur = 0.0\n for(var i=0; i<3; ++i) {\n ur += up[i] * right[i]\n uu += up[i] * up[i]\n }\n var ul = Math.sqrt(uu)\n var rr = 0.0\n for(var i=0; i<3; ++i) {\n right[i] -= up[i] * ur / uu\n rr += right[i] * right[i]\n up[i] /= ul\n }\n var rl = Math.sqrt(rr)\n for(var i=0; i<3; ++i) {\n right[i] /= rl\n }\n\n //Compute toward vector\n var toward = this.computedToward\n cross(toward, up, right)\n normalize3(toward, toward)\n\n //Compute angular parameters\n var radius = Math.exp(this.computedRadius[0])\n var theta = this.computedAngle[0]\n var phi = this.computedAngle[1]\n\n var ctheta = Math.cos(theta)\n var stheta = Math.sin(theta)\n var cphi = Math.cos(phi)\n var sphi = Math.sin(phi)\n\n var center = this.computedCenter\n\n var wx = ctheta * cphi \n var wy = stheta * cphi\n var wz = sphi\n\n var sx = -ctheta * sphi\n var sy = -stheta * sphi\n var sz = cphi\n\n var eye = this.computedEye\n var mat = this.computedMatrix\n for(var i=0; i<3; ++i) {\n var x = wx * right[i] + wy * toward[i] + wz * up[i]\n mat[4*i+1] = sx * right[i] + sy * toward[i] + sz * up[i]\n mat[4*i+2] = x\n mat[4*i+3] = 0.0\n }\n\n var ax = mat[1]\n var ay = mat[5]\n var az = mat[9]\n var bx = mat[2]\n var by = mat[6]\n var bz = mat[10]\n var cx = ay * bz - az * by\n var cy = az * bx - ax * bz\n var cz = ax * by - ay * bx\n var cl = len3(cx, cy, cz)\n cx /= cl\n cy /= cl\n cz /= cl\n mat[0] = cx\n mat[4] = cy\n mat[8] = cz\n\n for(var i=0; i<3; ++i) {\n eye[i] = center[i] + mat[2+4*i]*radius\n }\n\n for(var i=0; i<3; ++i) {\n var rr = 0.0\n for(var j=0; j<3; ++j) {\n rr += mat[i+4*j] * eye[j]\n }\n mat[12+i] = -rr\n }\n mat[15] = 1.0\n}\n\nproto.getMatrix = function(t, result) {\n this.recalcMatrix(t)\n var mat = this.computedMatrix\n if(result) {\n for(var i=0; i<16; ++i) {\n result[i] = mat[i]\n }\n return result\n }\n return mat\n}\n\nvar zAxis = [0,0,0]\nproto.rotate = function(t, dtheta, dphi, droll) {\n this.angle.move(t, dtheta, dphi)\n if(droll) {\n this.recalcMatrix(t)\n\n var mat = this.computedMatrix\n zAxis[0] = mat[2]\n zAxis[1] = mat[6]\n zAxis[2] = mat[10]\n\n var up = this.computedUp\n var right = this.computedRight\n var toward = this.computedToward\n\n for(var i=0; i<3; ++i) {\n mat[4*i] = up[i]\n mat[4*i+1] = right[i]\n mat[4*i+2] = toward[i]\n }\n rotateM(mat, mat, droll, zAxis)\n for(var i=0; i<3; ++i) {\n up[i] = mat[4*i]\n right[i] = mat[4*i+1]\n }\n\n this.up.set(t, up[0], up[1], up[2])\n this.right.set(t, right[0], right[1], right[2])\n }\n}\n\nproto.pan = function(t, dx, dy, dz) {\n dx = dx || 0.0\n dy = dy || 0.0\n dz = dz || 0.0\n\n this.recalcMatrix(t)\n var mat = this.computedMatrix\n\n var dist = Math.exp(this.computedRadius[0])\n\n var ux = mat[1]\n var uy = mat[5]\n var uz = mat[9]\n var ul = len3(ux, uy, uz)\n ux /= ul\n uy /= ul\n uz /= ul\n\n var rx = mat[0]\n var ry = mat[4]\n var rz = mat[8]\n var ru = rx * ux + ry * uy + rz * uz\n rx -= ux * ru\n ry -= uy * ru\n rz -= uz * ru\n var rl = len3(rx, ry, rz)\n rx /= rl\n ry /= rl\n rz /= rl\n\n var vx = rx * dx + ux * dy\n var vy = ry * dx + uy * dy\n var vz = rz * dx + uz * dy\n this.center.move(t, vx, vy, vz)\n\n //Update z-component of radius\n var radius = Math.exp(this.computedRadius[0])\n radius = Math.max(1e-4, radius + dz)\n this.radius.set(t, Math.log(radius))\n}\n\nproto.translate = function(t, dx, dy, dz) {\n this.center.move(t,\n dx||0.0,\n dy||0.0,\n dz||0.0)\n}\n\n//Recenters the coordinate axes\nproto.setMatrix = function(t, mat, axes, noSnap) {\n \n //Get the axes for tare\n var ushift = 1\n if(typeof axes === 'number') {\n ushift = (axes)|0\n } \n if(ushift < 0 || ushift > 3) {\n ushift = 1\n }\n var vshift = (ushift + 2) % 3\n var fshift = (ushift + 1) % 3\n\n //Recompute state for new t value\n if(!mat) { \n this.recalcMatrix(t)\n mat = this.computedMatrix\n }\n\n //Get right and up vectors\n var ux = mat[ushift]\n var uy = mat[ushift+4]\n var uz = mat[ushift+8]\n if(!noSnap) {\n var ul = len3(ux, uy, uz)\n ux /= ul\n uy /= ul\n uz /= ul\n } else {\n var ax = Math.abs(ux)\n var ay = Math.abs(uy)\n var az = Math.abs(uz)\n var am = Math.max(ax,ay,az)\n if(ax === am) {\n ux = (ux < 0) ? -1 : 1\n uy = uz = 0\n } else if(az === am) {\n uz = (uz < 0) ? -1 : 1\n ux = uy = 0\n } else {\n uy = (uy < 0) ? -1 : 1\n ux = uz = 0\n }\n }\n\n var rx = mat[vshift]\n var ry = mat[vshift+4]\n var rz = mat[vshift+8]\n var ru = rx * ux + ry * uy + rz * uz\n rx -= ux * ru\n ry -= uy * ru\n rz -= uz * ru\n var rl = len3(rx, ry, rz)\n rx /= rl\n ry /= rl\n rz /= rl\n \n var fx = uy * rz - uz * ry\n var fy = uz * rx - ux * rz\n var fz = ux * ry - uy * rx\n var fl = len3(fx, fy, fz)\n fx /= fl\n fy /= fl\n fz /= fl\n\n this.center.jump(t, ex, ey, ez)\n this.radius.idle(t)\n this.up.jump(t, ux, uy, uz)\n this.right.jump(t, rx, ry, rz)\n\n var phi, theta\n if(ushift === 2) {\n var cx = mat[1]\n var cy = mat[5]\n var cz = mat[9]\n var cr = cx * rx + cy * ry + cz * rz\n var cf = cx * fx + cy * fy + cz * fz\n if(tu < 0) {\n phi = -Math.PI/2\n } else {\n phi = Math.PI/2\n }\n theta = Math.atan2(cf, cr)\n } else {\n var tx = mat[2]\n var ty = mat[6]\n var tz = mat[10]\n var tu = tx * ux + ty * uy + tz * uz\n var tr = tx * rx + ty * ry + tz * rz\n var tf = tx * fx + ty * fy + tz * fz\n\n phi = Math.asin(clamp1(tu))\n theta = Math.atan2(tf, tr)\n }\n\n this.angle.jump(t, theta, phi)\n\n this.recalcMatrix(t)\n var dx = mat[2]\n var dy = mat[6]\n var dz = mat[10]\n\n var imat = this.computedMatrix\n invert44(imat, mat)\n var w = imat[15]\n var ex = imat[12] / w\n var ey = imat[13] / w\n var ez = imat[14] / w\n\n var gs = Math.exp(this.computedRadius[0])\n this.center.jump(t, ex-dx*gs, ey-dy*gs, ez-dz*gs)\n}\n\nproto.lastT = function() {\n return Math.max(\n this.center.lastT(),\n this.up.lastT(),\n this.right.lastT(),\n this.radius.lastT(),\n this.angle.lastT())\n}\n\nproto.idle = function(t) {\n this.center.idle(t)\n this.up.idle(t)\n this.right.idle(t)\n this.radius.idle(t)\n this.angle.idle(t)\n}\n\nproto.flush = function(t) {\n this.center.flush(t)\n this.up.flush(t)\n this.right.flush(t)\n this.radius.flush(t)\n this.angle.flush(t)\n}\n\nproto.setDistance = function(t, d) {\n if(d > 0) {\n this.radius.set(t, Math.log(d))\n }\n}\n\nproto.lookAt = function(t, eye, center, up) {\n this.recalcMatrix(t)\n\n eye = eye || this.computedEye\n center = center || this.computedCenter\n up = up || this.computedUp\n\n var ux = up[0]\n var uy = up[1]\n var uz = up[2]\n var ul = len3(ux, uy, uz)\n if(ul < 1e-6) {\n return\n }\n ux /= ul\n uy /= ul\n uz /= ul\n\n var tx = eye[0] - center[0]\n var ty = eye[1] - center[1]\n var tz = eye[2] - center[2]\n var tl = len3(tx, ty, tz)\n if(tl < 1e-6) {\n return\n }\n tx /= tl\n ty /= tl\n tz /= tl\n\n var right = this.computedRight\n var rx = right[0]\n var ry = right[1]\n var rz = right[2]\n var ru = ux*rx + uy*ry + uz*rz\n rx -= ru * ux\n ry -= ru * uy\n rz -= ru * uz\n var rl = len3(rx, ry, rz)\n\n if(rl < 0.01) {\n rx = uy * tz - uz * ty\n ry = uz * tx - ux * tz\n rz = ux * ty - uy * tx\n rl = len3(rx, ry, rz)\n if(rl < 1e-6) {\n return\n }\n }\n rx /= rl\n ry /= rl\n rz /= rl\n\n this.up.set(t, ux, uy, uz)\n this.right.set(t, rx, ry, rz)\n this.center.set(t, center[0], center[1], center[2])\n this.radius.set(t, Math.log(tl))\n\n var fx = uy * rz - uz * ry\n var fy = uz * rx - ux * rz\n var fz = ux * ry - uy * rx\n var fl = len3(fx, fy, fz)\n fx /= fl\n fy /= fl\n fz /= fl\n\n var tu = ux*tx + uy*ty + uz*tz\n var tr = rx*tx + ry*ty + rz*tz\n var tf = fx*tx + fy*ty + fz*tz\n\n var phi = Math.asin(clamp1(tu))\n var theta = Math.atan2(tf, tr)\n\n var angleState = this.angle._state\n var lastTheta = angleState[angleState.length-1]\n var lastPhi = angleState[angleState.length-2]\n lastTheta = lastTheta % (2.0 * Math.PI)\n var dp = Math.abs(lastTheta + 2.0 * Math.PI - theta)\n var d0 = Math.abs(lastTheta - theta)\n var dn = Math.abs(lastTheta - 2.0 * Math.PI - theta)\n if(dp < d0) {\n lastTheta += 2.0 * Math.PI\n }\n if(dn < d0) {\n lastTheta -= 2.0 * Math.PI\n }\n\n this.angle.jump(this.angle.lastT(), lastTheta, lastPhi)\n this.angle.set(t, theta, phi)\n}\n\nfunction createTurntableController(options) {\n options = options || {}\n\n var center = options.center || [0,0,0]\n var up = options.up || [0,1,0]\n var right = options.right || findOrthoPair(up)\n var radius = options.radius || 1.0\n var theta = options.theta || 0.0\n var phi = options.phi || 0.0\n\n center = [].slice.call(center, 0, 3)\n\n up = [].slice.call(up, 0, 3)\n normalize3(up, up)\n\n right = [].slice.call(right, 0, 3)\n normalize3(right, right)\n\n if('eye' in options) {\n var eye = options.eye\n var toward = [\n eye[0]-center[0],\n eye[1]-center[1],\n eye[2]-center[2]\n ]\n cross(right, toward, up)\n if(len3(right[0], right[1], right[2]) < 1e-6) {\n right = findOrthoPair(up)\n } else {\n normalize3(right, right)\n }\n\n radius = len3(toward[0], toward[1], toward[2])\n\n var ut = dot3(up, toward) / radius\n var rt = dot3(right, toward) / radius\n phi = Math.acos(ut)\n theta = Math.acos(rt)\n }\n\n //Use logarithmic coordinates for radius\n radius = Math.log(radius)\n\n //Return the controller\n return new TurntableController(\n options.zoomMin,\n options.zoomMax,\n center,\n up,\n right,\n radius,\n theta,\n phi)\n}\n\n/***/ }),\n\n/***/ 5250:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nmodule.exports = twoProduct\n\nvar SPLITTER = +(Math.pow(2, 27) + 1.0)\n\nfunction twoProduct(a, b, result) {\n var x = a * b\n\n var c = SPLITTER * a\n var abig = c - a\n var ahi = c - abig\n var alo = a - ahi\n\n var d = SPLITTER * b\n var bbig = d - b\n var bhi = d - bbig\n var blo = b - bhi\n\n var err1 = x - (ahi * bhi)\n var err2 = err1 - (alo * bhi)\n var err3 = err2 - (ahi * blo)\n\n var y = alo * blo - err3\n\n if(result) {\n result[0] = y\n result[1] = x\n return result\n }\n\n return [ y, x ]\n}\n\n/***/ }),\n\n/***/ 9362:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nmodule.exports = fastTwoSum\n\nfunction fastTwoSum(a, b, result) {\n\tvar x = a + b\n\tvar bv = x - a\n\tvar av = x - bv\n\tvar br = b - bv\n\tvar ar = a - av\n\tif(result) {\n\t\tresult[0] = ar + br\n\t\tresult[1] = x\n\t\treturn result\n\t}\n\treturn [ar+br, x]\n}\n\n/***/ }),\n\n/***/ 1888:\n/***/ (function(__unused_webpack_module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar bits = __webpack_require__(8828)\nvar dup = __webpack_require__(1338)\nvar Buffer = (__webpack_require__(4793)/* .Buffer */ .hp)\n\n//Legacy pool support\nif(!__webpack_require__.g.__TYPEDARRAY_POOL) {\n __webpack_require__.g.__TYPEDARRAY_POOL = {\n UINT8 : dup([32, 0])\n , UINT16 : dup([32, 0])\n , UINT32 : dup([32, 0])\n , BIGUINT64 : dup([32, 0])\n , INT8 : dup([32, 0])\n , INT16 : dup([32, 0])\n , INT32 : dup([32, 0])\n , BIGINT64 : dup([32, 0])\n , FLOAT : dup([32, 0])\n , DOUBLE : dup([32, 0])\n , DATA : dup([32, 0])\n , UINT8C : dup([32, 0])\n , BUFFER : dup([32, 0])\n }\n}\n\nvar hasUint8C = (typeof Uint8ClampedArray) !== 'undefined'\nvar hasBigUint64 = (typeof BigUint64Array) !== 'undefined'\nvar hasBigInt64 = (typeof BigInt64Array) !== 'undefined'\nvar POOL = __webpack_require__.g.__TYPEDARRAY_POOL\n\n//Upgrade pool\nif(!POOL.UINT8C) {\n POOL.UINT8C = dup([32, 0])\n}\nif(!POOL.BIGUINT64) {\n POOL.BIGUINT64 = dup([32, 0])\n}\nif(!POOL.BIGINT64) {\n POOL.BIGINT64 = dup([32, 0])\n}\nif(!POOL.BUFFER) {\n POOL.BUFFER = dup([32, 0])\n}\n\n//New technique: Only allocate from ArrayBufferView and Buffer\nvar DATA = POOL.DATA\n , BUFFER = POOL.BUFFER\n\nexports.free = function free(array) {\n if(Buffer.isBuffer(array)) {\n BUFFER[bits.log2(array.length)].push(array)\n } else {\n if(Object.prototype.toString.call(array) !== '[object ArrayBuffer]') {\n array = array.buffer\n }\n if(!array) {\n return\n }\n var n = array.length || array.byteLength\n var log_n = bits.log2(n)|0\n DATA[log_n].push(array)\n }\n}\n\nfunction freeArrayBuffer(buffer) {\n if(!buffer) {\n return\n }\n var n = buffer.length || buffer.byteLength\n var log_n = bits.log2(n)\n DATA[log_n].push(buffer)\n}\n\nfunction freeTypedArray(array) {\n freeArrayBuffer(array.buffer)\n}\n\nexports.freeUint8 =\nexports.freeUint16 =\nexports.freeUint32 =\nexports.freeBigUint64 =\nexports.freeInt8 =\nexports.freeInt16 =\nexports.freeInt32 =\nexports.freeBigInt64 =\nexports.freeFloat32 = \nexports.freeFloat =\nexports.freeFloat64 = \nexports.freeDouble = \nexports.freeUint8Clamped = \nexports.freeDataView = freeTypedArray\n\nexports.freeArrayBuffer = freeArrayBuffer\n\nexports.freeBuffer = function freeBuffer(array) {\n BUFFER[bits.log2(array.length)].push(array)\n}\n\nexports.malloc = function malloc(n, dtype) {\n if(dtype === undefined || dtype === 'arraybuffer') {\n return mallocArrayBuffer(n)\n } else {\n switch(dtype) {\n case 'uint8':\n return mallocUint8(n)\n case 'uint16':\n return mallocUint16(n)\n case 'uint32':\n return mallocUint32(n)\n case 'int8':\n return mallocInt8(n)\n case 'int16':\n return mallocInt16(n)\n case 'int32':\n return mallocInt32(n)\n case 'float':\n case 'float32':\n return mallocFloat(n)\n case 'double':\n case 'float64':\n return mallocDouble(n)\n case 'uint8_clamped':\n return mallocUint8Clamped(n)\n case 'bigint64':\n return mallocBigInt64(n)\n case 'biguint64':\n return mallocBigUint64(n)\n case 'buffer':\n return mallocBuffer(n)\n case 'data':\n case 'dataview':\n return mallocDataView(n)\n\n default:\n return null\n }\n }\n return null\n}\n\nfunction mallocArrayBuffer(n) {\n var n = bits.nextPow2(n)\n var log_n = bits.log2(n)\n var d = DATA[log_n]\n if(d.length > 0) {\n return d.pop()\n }\n return new ArrayBuffer(n)\n}\nexports.mallocArrayBuffer = mallocArrayBuffer\n\nfunction mallocUint8(n) {\n return new Uint8Array(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocUint8 = mallocUint8\n\nfunction mallocUint16(n) {\n return new Uint16Array(mallocArrayBuffer(2*n), 0, n)\n}\nexports.mallocUint16 = mallocUint16\n\nfunction mallocUint32(n) {\n return new Uint32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocUint32 = mallocUint32\n\nfunction mallocInt8(n) {\n return new Int8Array(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocInt8 = mallocInt8\n\nfunction mallocInt16(n) {\n return new Int16Array(mallocArrayBuffer(2*n), 0, n)\n}\nexports.mallocInt16 = mallocInt16\n\nfunction mallocInt32(n) {\n return new Int32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocInt32 = mallocInt32\n\nfunction mallocFloat(n) {\n return new Float32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocFloat32 = exports.mallocFloat = mallocFloat\n\nfunction mallocDouble(n) {\n return new Float64Array(mallocArrayBuffer(8*n), 0, n)\n}\nexports.mallocFloat64 = exports.mallocDouble = mallocDouble\n\nfunction mallocUint8Clamped(n) {\n if(hasUint8C) {\n return new Uint8ClampedArray(mallocArrayBuffer(n), 0, n)\n } else {\n return mallocUint8(n)\n }\n}\nexports.mallocUint8Clamped = mallocUint8Clamped\n\nfunction mallocBigUint64(n) {\n if(hasBigUint64) {\n return new BigUint64Array(mallocArrayBuffer(8*n), 0, n)\n } else {\n return null;\n }\n}\nexports.mallocBigUint64 = mallocBigUint64\n\nfunction mallocBigInt64(n) {\n if (hasBigInt64) {\n return new BigInt64Array(mallocArrayBuffer(8*n), 0, n)\n } else {\n return null;\n }\n}\nexports.mallocBigInt64 = mallocBigInt64\n\nfunction mallocDataView(n) {\n return new DataView(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocDataView = mallocDataView\n\nfunction mallocBuffer(n) {\n n = bits.nextPow2(n)\n var log_n = bits.log2(n)\n var cache = BUFFER[log_n]\n if(cache.length > 0) {\n return cache.pop()\n }\n return new Buffer(n)\n}\nexports.mallocBuffer = mallocBuffer\n\nexports.clearCache = function clearCache() {\n for(var i=0; i<32; ++i) {\n POOL.UINT8[i].length = 0\n POOL.UINT16[i].length = 0\n POOL.UINT32[i].length = 0\n POOL.INT8[i].length = 0\n POOL.INT16[i].length = 0\n POOL.INT32[i].length = 0\n POOL.FLOAT[i].length = 0\n POOL.DOUBLE[i].length = 0\n POOL.BIGUINT64[i].length = 0\n POOL.BIGINT64[i].length = 0\n POOL.UINT8C[i].length = 0\n DATA[i].length = 0\n BUFFER[i].length = 0\n }\n}\n\n\n/***/ }),\n\n/***/ 1755:\n/***/ (function(module) {\n\n\"use strict\";\n \"use restrict\";\n\nmodule.exports = UnionFind;\n\nfunction UnionFind(count) {\n this.roots = new Array(count);\n this.ranks = new Array(count);\n \n for(var i=0; i\"\n var clsTag = \"\"\n\n var nOPN = opnTag.length\n var nCLS = clsTag.length\n\n var isRecursive = (TAG_CHR[0] === CHR_super0) ||\n (TAG_CHR[0] === CHR_sub0);\n\n var a = 0\n var b = -nCLS\n while (a > -1) {\n a = str.indexOf(opnTag, a)\n if(a === -1) break\n\n b = str.indexOf(clsTag, a + nOPN)\n if(b === -1) break\n\n if(b <= a) break\n\n for(var i = a; i < b + nCLS; ++i){\n if((i < a + nOPN) || (i >= b)) {\n map[i] = null\n str = str.substr(0, i) + \" \" + str.substr(i + 1)\n } else {\n if(map[i] !== null) {\n var pos = map[i].indexOf(TAG_CHR[0])\n if(pos === -1) {\n map[i] += TAG_CHR\n } else { // i.e. to handle multiple sub/super-scripts\n if(isRecursive) {\n // i.e to increase the sub/sup number\n map[i] = map[i].substr(0, pos + 1) + (1 + parseInt(map[i][pos + 1])) + map[i].substr(pos + 2)\n }\n }\n }\n }\n }\n\n var start = a + nOPN\n var remainingStr = str.substr(start, b - start)\n\n var c = remainingStr.indexOf(opnTag)\n if(c !== -1) a = c\n else a = b + nCLS\n }\n\n return map\n}\n\nfunction transformPositions(positions, options, size) {\n var align = options.textAlign || \"start\"\n var baseline = options.textBaseline || \"alphabetic\"\n\n var lo = [1<<30, 1<<30]\n var hi = [0,0]\n var n = positions.length\n for(var i=0; i/g, '\\n') // replace
tags with \\n in the string\n } else {\n rawString = rawString.replace(/\\/g, ' ') // don't accept
tags in the input and replace with space in this case\n }\n\n var activeStyle = \"\"\n var map = []\n for(j = 0; j < rawString.length; ++j) {\n map[j] = activeStyle\n }\n\n if(styletags.bolds === true) map = parseTag(TAG_bold, CHR_bold, rawString, map)\n if(styletags.italics === true) map = parseTag(TAG_italic, CHR_italic, rawString, map)\n if(styletags.superscripts === true) map = parseTag(TAG_super, CHR_super, rawString, map)\n if(styletags.subscripts === true) map = parseTag(TAG_sub, CHR_sub, rawString, map)\n\n var allStyles = []\n var plainText = \"\"\n for(j = 0; j < rawString.length; ++j) {\n if(map[j] !== null) {\n plainText += rawString[j]\n allStyles.push(map[j])\n }\n }\n\n var allTexts = plainText.split('\\n')\n\n var numberOfLines = allTexts.length\n var lineHeight = Math.round(lineSpacing * fontSize)\n var offsetX = fontSize\n var offsetY = fontSize * 2\n var maxWidth = 0\n var minHeight = numberOfLines * lineHeight + offsetY\n\n if(canvas.height < minHeight) {\n canvas.height = minHeight\n }\n\n context.fillStyle = \"#000\"\n context.fillRect(0, 0, canvas.width, canvas.height)\n\n context.fillStyle = \"#fff\"\n var i, j, xPos, yPos, zPos\n var nDone = 0\n\n var buffer = \"\"\n function writeBuffer() {\n if(buffer !== \"\") {\n var delta = context.measureText(buffer).width\n\n context.fillText(buffer, offsetX + xPos, offsetY + yPos)\n xPos += delta\n }\n }\n\n function getTextFontSize() {\n return \"\" + Math.round(zPos) + \"px \";\n }\n\n function changeStyle(oldStyle, newStyle) {\n var ctxFont = \"\" + context.font;\n\n if(styletags.subscripts === true) {\n var oldIndex_Sub = oldStyle.indexOf(CHR_sub0);\n var newIndex_Sub = newStyle.indexOf(CHR_sub0);\n\n var oldSub = (oldIndex_Sub > -1) ? parseInt(oldStyle[1 + oldIndex_Sub]) : 0;\n var newSub = (newIndex_Sub > -1) ? parseInt(newStyle[1 + newIndex_Sub]) : 0;\n\n if(oldSub !== newSub) {\n ctxFont = ctxFont.replace(getTextFontSize(), \"?px \")\n zPos *= Math.pow(0.75, (newSub - oldSub))\n ctxFont = ctxFont.replace(\"?px \", getTextFontSize())\n }\n yPos += 0.25 * lineHeight * (newSub - oldSub);\n }\n\n if(styletags.superscripts === true) {\n var oldIndex_Super = oldStyle.indexOf(CHR_super0);\n var newIndex_Super = newStyle.indexOf(CHR_super0);\n\n var oldSuper = (oldIndex_Super > -1) ? parseInt(oldStyle[1 + oldIndex_Super]) : 0;\n var newSuper = (newIndex_Super > -1) ? parseInt(newStyle[1 + newIndex_Super]) : 0;\n\n if(oldSuper !== newSuper) {\n ctxFont = ctxFont.replace(getTextFontSize(), \"?px \")\n zPos *= Math.pow(0.75, (newSuper - oldSuper))\n ctxFont = ctxFont.replace(\"?px \", getTextFontSize())\n }\n yPos -= 0.25 * lineHeight * (newSuper - oldSuper);\n }\n\n if(styletags.bolds === true) {\n var wasBold = (oldStyle.indexOf(CHR_bold) > -1)\n var is_Bold = (newStyle.indexOf(CHR_bold) > -1)\n\n if(!wasBold && is_Bold) {\n if(wasItalic) {\n ctxFont = ctxFont.replace(\"italic \", \"italic bold \")\n } else {\n ctxFont = \"bold \" + ctxFont\n }\n }\n if(wasBold && !is_Bold) {\n ctxFont = ctxFont.replace(\"bold \", '')\n }\n }\n\n if(styletags.italics === true) {\n var wasItalic = (oldStyle.indexOf(CHR_italic) > -1)\n var is_Italic = (newStyle.indexOf(CHR_italic) > -1)\n\n if(!wasItalic && is_Italic) {\n ctxFont = \"italic \" + ctxFont\n }\n if(wasItalic && !is_Italic) {\n ctxFont = ctxFont.replace(\"italic \", '')\n }\n }\n context.font = ctxFont\n }\n\n for(i = 0; i < numberOfLines; ++i) {\n var txt = allTexts[i] + '\\n'\n xPos = 0\n yPos = i * lineHeight\n zPos = fontSize\n\n buffer = \"\"\n \n for(j = 0; j < txt.length; ++j) {\n var style = (j + nDone < allStyles.length) ? allStyles[j + nDone] : allStyles[allStyles.length - 1]\n if(activeStyle === style) {\n buffer += txt[j]\n } else {\n writeBuffer()\n buffer = txt[j]\n\n if(style !== undefined) {\n changeStyle(activeStyle, style)\n activeStyle = style\n }\n }\n }\n writeBuffer()\n\n nDone += txt.length\n\n var width = Math.round(xPos + 2 * offsetX) | 0\n if(maxWidth < width) maxWidth = width\n }\n\n //Cut pixels from image\n var xCut = maxWidth\n var yCut = offsetY + lineHeight * numberOfLines\n var pixels = ndarray(context.getImageData(0, 0, xCut, yCut).data, [yCut, xCut, 4])\n return pixels.pick(-1, -1, 0).transpose(1, 0)\n}\n\nfunction getContour(pixels, doSimplify) {\n var contour = surfaceNets(pixels, 128)\n if(doSimplify) {\n return simplify(contour.cells, contour.positions, 0.25)\n }\n return {\n edges: contour.cells,\n positions: contour.positions\n }\n}\n\nfunction processPixelsImpl(pixels, options, size, simplify) {\n //Extract contour\n var contour = getContour(pixels, simplify)\n\n //Apply warp to positions\n var positions = transformPositions(contour.positions, options, size)\n var edges = contour.edges\n var flip = \"ccw\" === options.orientation\n\n //Clean up the PSLG, resolve self intersections, etc.\n cleanPSLG(positions, edges)\n\n //If triangulate flag passed, triangulate the result\n if(options.polygons || options.polygon || options.polyline) {\n var result = toPolygonCrappy(edges, positions)\n var nresult = new Array(result.length)\n for(var i=0; i 0) size =\n options.size\n\n if(options.lineSpacing &&\n options.lineSpacing > 0) lineSpacing =\n options.lineSpacing\n\n if(options.styletags &&\n options.styletags.breaklines) styletags.breaklines =\n options.styletags.breaklines ? true : false\n\n if(options.styletags &&\n options.styletags.bolds) styletags.bolds =\n options.styletags.bolds ? true : false\n\n if(options.styletags &&\n options.styletags.italics) styletags.italics =\n options.styletags.italics ? true : false\n\n if(options.styletags &&\n options.styletags.subscripts) styletags.subscripts =\n options.styletags.subscripts ? true : false\n\n if(options.styletags &&\n options.styletags.superscripts) styletags.superscripts =\n options.styletags.superscripts ? true : false\n }\n\n context.font = [\n options.fontStyle,\n options.fontVariant,\n options.fontWeight,\n size + \"px\",\n options.font\n ].filter(function(d) {return d}).join(\" \")\n context.textAlign = \"start\"\n context.textBaseline = \"alphabetic\"\n context.direction = \"ltr\"\n\n var pixels = getPixels(canvas, context, str, size, lineSpacing, styletags)\n\n return processPixels(pixels, options, size)\n}\n\n\n/***/ }),\n\n/***/ 1538:\n/***/ (function(module) {\n\n// Copyright (C) 2011 Google Inc.\n//\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n// http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\n/**\n * @fileoverview Install a leaky WeakMap emulation on platforms that\n * don't provide a built-in one.\n *\n *

Assumes that an ES5 platform where, if {@code WeakMap} is\n * already present, then it conforms to the anticipated ES6\n * specification. To run this file on an ES5 or almost ES5\n * implementation where the {@code WeakMap} specification does not\n * quite conform, run repairES5.js first.\n *\n *

Even though WeakMapModule is not global, the linter thinks it\n * is, which is why it is in the overrides list below.\n *\n *

NOTE: Before using this WeakMap emulation in a non-SES\n * environment, see the note below about hiddenRecord.\n *\n * @author Mark S. Miller\n * @requires crypto, ArrayBuffer, Uint8Array, navigator, console\n * @overrides WeakMap, ses, Proxy\n * @overrides WeakMapModule\n */\n\n/**\n * This {@code WeakMap} emulation is observably equivalent to the\n * ES-Harmony WeakMap, but with leakier garbage collection properties.\n *\n *

As with true WeakMaps, in this emulation, a key does not\n * retain maps indexed by that key and (crucially) a map does not\n * retain the keys it indexes. A map by itself also does not retain\n * the values associated with that map.\n *\n *

However, the values associated with a key in some map are\n * retained so long as that key is retained and those associations are\n * not overridden. For example, when used to support membranes, all\n * values exported from a given membrane will live for the lifetime\n * they would have had in the absence of an interposed membrane. Even\n * when the membrane is revoked, all objects that would have been\n * reachable in the absence of revocation will still be reachable, as\n * far as the GC can tell, even though they will no longer be relevant\n * to ongoing computation.\n *\n *

The API implemented here is approximately the API as implemented\n * in FF6.0a1 and agreed to by MarkM, Andreas Gal, and Dave Herman,\n * rather than the offially approved proposal page. TODO(erights):\n * upgrade the ecmascript WeakMap proposal page to explain this API\n * change and present to EcmaScript committee for their approval.\n *\n *

The first difference between the emulation here and that in\n * FF6.0a1 is the presence of non enumerable {@code get___, has___,\n * set___, and delete___} methods on WeakMap instances to represent\n * what would be the hidden internal properties of a primitive\n * implementation. Whereas the FF6.0a1 WeakMap.prototype methods\n * require their {@code this} to be a genuine WeakMap instance (i.e.,\n * an object of {@code [[Class]]} \"WeakMap}), since there is nothing\n * unforgeable about the pseudo-internal method names used here,\n * nothing prevents these emulated prototype methods from being\n * applied to non-WeakMaps with pseudo-internal methods of the same\n * names.\n *\n *

Another difference is that our emulated {@code\n * WeakMap.prototype} is not itself a WeakMap. A problem with the\n * current FF6.0a1 API is that WeakMap.prototype is itself a WeakMap\n * providing ambient mutability and an ambient communications\n * channel. Thus, if a WeakMap is already present and has this\n * problem, repairES5.js wraps it in a safe wrappper in order to\n * prevent access to this channel. (See\n * PATCH_MUTABLE_FROZEN_WEAKMAP_PROTO in repairES5.js).\n */\n\n/**\n * If this is a full secureable ES5 platform and the ES-Harmony {@code WeakMap} is\n * absent, install an approximate emulation.\n *\n *

If WeakMap is present but cannot store some objects, use our approximate\n * emulation as a wrapper.\n *\n *

If this is almost a secureable ES5 platform, then WeakMap.js\n * should be run after repairES5.js.\n *\n *

See {@code WeakMap} for documentation of the garbage collection\n * properties of this WeakMap emulation.\n */\n(function WeakMapModule() {\n \"use strict\";\n\n if (typeof ses !== 'undefined' && ses.ok && !ses.ok()) {\n // already too broken, so give up\n return;\n }\n\n /**\n * In some cases (current Firefox), we must make a choice betweeen a\n * WeakMap which is capable of using all varieties of host objects as\n * keys and one which is capable of safely using proxies as keys. See\n * comments below about HostWeakMap and DoubleWeakMap for details.\n *\n * This function (which is a global, not exposed to guests) marks a\n * WeakMap as permitted to do what is necessary to index all host\n * objects, at the cost of making it unsafe for proxies.\n *\n * Do not apply this function to anything which is not a genuine\n * fresh WeakMap.\n */\n function weakMapPermitHostObjects(map) {\n // identity of function used as a secret -- good enough and cheap\n if (map.permitHostObjects___) {\n map.permitHostObjects___(weakMapPermitHostObjects);\n }\n }\n if (typeof ses !== 'undefined') {\n ses.weakMapPermitHostObjects = weakMapPermitHostObjects;\n }\n\n // IE 11 has no Proxy but has a broken WeakMap such that we need to patch\n // it using DoubleWeakMap; this flag tells DoubleWeakMap so.\n var doubleWeakMapCheckSilentFailure = false;\n\n // Check if there is already a good-enough WeakMap implementation, and if so\n // exit without replacing it.\n if (typeof WeakMap === 'function') {\n var HostWeakMap = WeakMap;\n // There is a WeakMap -- is it good enough?\n if (typeof navigator !== 'undefined' &&\n /Firefox/.test(navigator.userAgent)) {\n // We're now *assuming not*, because as of this writing (2013-05-06)\n // Firefox's WeakMaps have a miscellany of objects they won't accept, and\n // we don't want to make an exhaustive list, and testing for just one\n // will be a problem if that one is fixed alone (as they did for Event).\n\n // If there is a platform that we *can* reliably test on, here's how to\n // do it:\n // var problematic = ... ;\n // var testHostMap = new HostWeakMap();\n // try {\n // testHostMap.set(problematic, 1); // Firefox 20 will throw here\n // if (testHostMap.get(problematic) === 1) {\n // return;\n // }\n // } catch (e) {}\n\n } else {\n // IE 11 bug: WeakMaps silently fail to store frozen objects.\n var testMap = new HostWeakMap();\n var testObject = Object.freeze({});\n testMap.set(testObject, 1);\n if (testMap.get(testObject) !== 1) {\n doubleWeakMapCheckSilentFailure = true;\n // Fall through to installing our WeakMap.\n } else {\n module.exports = WeakMap;\n return;\n }\n }\n }\n\n var hop = Object.prototype.hasOwnProperty;\n var gopn = Object.getOwnPropertyNames;\n var defProp = Object.defineProperty;\n var isExtensible = Object.isExtensible;\n\n /**\n * Security depends on HIDDEN_NAME being both unguessable and\n * undiscoverable by untrusted code.\n *\n *

Given the known weaknesses of Math.random() on existing\n * browsers, it does not generate unguessability we can be confident\n * of.\n *\n *

It is the monkey patching logic in this file that is intended\n * to ensure undiscoverability. The basic idea is that there are\n * three fundamental means of discovering properties of an object:\n * The for/in loop, Object.keys(), and Object.getOwnPropertyNames(),\n * as well as some proposed ES6 extensions that appear on our\n * whitelist. The first two only discover enumerable properties, and\n * we only use HIDDEN_NAME to name a non-enumerable property, so the\n * only remaining threat should be getOwnPropertyNames and some\n * proposed ES6 extensions that appear on our whitelist. We monkey\n * patch them to remove HIDDEN_NAME from the list of properties they\n * returns.\n *\n *

TODO(erights): On a platform with built-in Proxies, proxies\n * could be used to trap and thereby discover the HIDDEN_NAME, so we\n * need to monkey patch Proxy.create, Proxy.createFunction, etc, in\n * order to wrap the provided handler with the real handler which\n * filters out all traps using HIDDEN_NAME.\n *\n *

TODO(erights): Revisit Mike Stay's suggestion that we use an\n * encapsulated function at a not-necessarily-secret name, which\n * uses the Stiegler shared-state rights amplification pattern to\n * reveal the associated value only to the WeakMap in which this key\n * is associated with that value. Since only the key retains the\n * function, the function can also remember the key without causing\n * leakage of the key, so this doesn't violate our general gc\n * goals. In addition, because the name need not be a guarded\n * secret, we could efficiently handle cross-frame frozen keys.\n */\n var HIDDEN_NAME_PREFIX = 'weakmap:';\n var HIDDEN_NAME = HIDDEN_NAME_PREFIX + 'ident:' + Math.random() + '___';\n\n if (typeof crypto !== 'undefined' &&\n typeof crypto.getRandomValues === 'function' &&\n typeof ArrayBuffer === 'function' &&\n typeof Uint8Array === 'function') {\n var ab = new ArrayBuffer(25);\n var u8s = new Uint8Array(ab);\n crypto.getRandomValues(u8s);\n HIDDEN_NAME = HIDDEN_NAME_PREFIX + 'rand:' +\n Array.prototype.map.call(u8s, function(u8) {\n return (u8 % 36).toString(36);\n }).join('') + '___';\n }\n\n function isNotHiddenName(name) {\n return !(\n name.substr(0, HIDDEN_NAME_PREFIX.length) == HIDDEN_NAME_PREFIX &&\n name.substr(name.length - 3) === '___');\n }\n\n /**\n * Monkey patch getOwnPropertyNames to avoid revealing the\n * HIDDEN_NAME.\n *\n *

The ES5.1 spec requires each name to appear only once, but as\n * of this writing, this requirement is controversial for ES6, so we\n * made this code robust against this case. If the resulting extra\n * search turns out to be expensive, we can probably relax this once\n * ES6 is adequately supported on all major browsers, iff no browser\n * versions we support at that time have relaxed this constraint\n * without providing built-in ES6 WeakMaps.\n */\n defProp(Object, 'getOwnPropertyNames', {\n value: function fakeGetOwnPropertyNames(obj) {\n return gopn(obj).filter(isNotHiddenName);\n }\n });\n\n /**\n * getPropertyNames is not in ES5 but it is proposed for ES6 and\n * does appear in our whitelist, so we need to clean it too.\n */\n if ('getPropertyNames' in Object) {\n var originalGetPropertyNames = Object.getPropertyNames;\n defProp(Object, 'getPropertyNames', {\n value: function fakeGetPropertyNames(obj) {\n return originalGetPropertyNames(obj).filter(isNotHiddenName);\n }\n });\n }\n\n /**\n *

To treat objects as identity-keys with reasonable efficiency\n * on ES5 by itself (i.e., without any object-keyed collections), we\n * need to add a hidden property to such key objects when we\n * can. This raises several issues:\n *

    \n *
  • Arranging to add this property to objects before we lose the\n * chance, and\n *
  • Hiding the existence of this new property from most\n * JavaScript code.\n *
  • Preventing certification theft, where one object is\n * created falsely claiming to be the key of an association\n * actually keyed by another object.\n *
  • Preventing value theft, where untrusted code with\n * access to a key object but not a weak map nevertheless\n * obtains access to the value associated with that key in that\n * weak map.\n *
\n * We do so by\n *
    \n *
  • Making the name of the hidden property unguessable, so \"[]\"\n * indexing, which we cannot intercept, cannot be used to access\n * a property without knowing the name.\n *
  • Making the hidden property non-enumerable, so we need not\n * worry about for-in loops or {@code Object.keys},\n *
  • monkey patching those reflective methods that would\n * prevent extensions, to add this hidden property first,\n *
  • monkey patching those methods that would reveal this\n * hidden property.\n *
\n * Unfortunately, because of same-origin iframes, we cannot reliably\n * add this hidden property before an object becomes\n * non-extensible. Instead, if we encounter a non-extensible object\n * without a hidden record that we can detect (whether or not it has\n * a hidden record stored under a name secret to us), then we just\n * use the key object itself to represent its identity in a brute\n * force leaky map stored in the weak map, losing all the advantages\n * of weakness for these.\n */\n function getHiddenRecord(key) {\n if (key !== Object(key)) {\n throw new TypeError('Not an object: ' + key);\n }\n var hiddenRecord = key[HIDDEN_NAME];\n if (hiddenRecord && hiddenRecord.key === key) { return hiddenRecord; }\n if (!isExtensible(key)) {\n // Weak map must brute force, as explained in doc-comment above.\n return void 0;\n }\n\n // The hiddenRecord and the key point directly at each other, via\n // the \"key\" and HIDDEN_NAME properties respectively. The key\n // field is for quickly verifying that this hidden record is an\n // own property, not a hidden record from up the prototype chain.\n //\n // NOTE: Because this WeakMap emulation is meant only for systems like\n // SES where Object.prototype is frozen without any numeric\n // properties, it is ok to use an object literal for the hiddenRecord.\n // This has two advantages:\n // * It is much faster in a performance critical place\n // * It avoids relying on Object.create(null), which had been\n // problematic on Chrome 28.0.1480.0. See\n // https://code.google.com/p/google-caja/issues/detail?id=1687\n hiddenRecord = { key: key };\n\n // When using this WeakMap emulation on platforms where\n // Object.prototype might not be frozen and Object.create(null) is\n // reliable, use the following two commented out lines instead.\n // hiddenRecord = Object.create(null);\n // hiddenRecord.key = key;\n\n // Please contact us if you need this to work on platforms where\n // Object.prototype might not be frozen and\n // Object.create(null) might not be reliable.\n\n try {\n defProp(key, HIDDEN_NAME, {\n value: hiddenRecord,\n writable: false,\n enumerable: false,\n configurable: false\n });\n return hiddenRecord;\n } catch (error) {\n // Under some circumstances, isExtensible seems to misreport whether\n // the HIDDEN_NAME can be defined.\n // The circumstances have not been isolated, but at least affect\n // Node.js v0.10.26 on TravisCI / Linux, but not the same version of\n // Node.js on OS X.\n return void 0;\n }\n }\n\n /**\n * Monkey patch operations that would make their argument\n * non-extensible.\n *\n *

The monkey patched versions throw a TypeError if their\n * argument is not an object, so it should only be done to functions\n * that should throw a TypeError anyway if their argument is not an\n * object.\n */\n (function(){\n var oldFreeze = Object.freeze;\n defProp(Object, 'freeze', {\n value: function identifyingFreeze(obj) {\n getHiddenRecord(obj);\n return oldFreeze(obj);\n }\n });\n var oldSeal = Object.seal;\n defProp(Object, 'seal', {\n value: function identifyingSeal(obj) {\n getHiddenRecord(obj);\n return oldSeal(obj);\n }\n });\n var oldPreventExtensions = Object.preventExtensions;\n defProp(Object, 'preventExtensions', {\n value: function identifyingPreventExtensions(obj) {\n getHiddenRecord(obj);\n return oldPreventExtensions(obj);\n }\n });\n })();\n\n function constFunc(func) {\n func.prototype = null;\n return Object.freeze(func);\n }\n\n var calledAsFunctionWarningDone = false;\n function calledAsFunctionWarning() {\n // Future ES6 WeakMap is currently (2013-09-10) expected to reject WeakMap()\n // but we used to permit it and do it ourselves, so warn only.\n if (!calledAsFunctionWarningDone && typeof console !== 'undefined') {\n calledAsFunctionWarningDone = true;\n console.warn('WeakMap should be invoked as new WeakMap(), not ' +\n 'WeakMap(). This will be an error in the future.');\n }\n }\n\n var nextId = 0;\n\n var OurWeakMap = function() {\n if (!(this instanceof OurWeakMap)) { // approximate test for new ...()\n calledAsFunctionWarning();\n }\n\n // We are currently (12/25/2012) never encountering any prematurely\n // non-extensible keys.\n var keys = []; // brute force for prematurely non-extensible keys.\n var values = []; // brute force for corresponding values.\n var id = nextId++;\n\n function get___(key, opt_default) {\n var index;\n var hiddenRecord = getHiddenRecord(key);\n if (hiddenRecord) {\n return id in hiddenRecord ? hiddenRecord[id] : opt_default;\n } else {\n index = keys.indexOf(key);\n return index >= 0 ? values[index] : opt_default;\n }\n }\n\n function has___(key) {\n var hiddenRecord = getHiddenRecord(key);\n if (hiddenRecord) {\n return id in hiddenRecord;\n } else {\n return keys.indexOf(key) >= 0;\n }\n }\n\n function set___(key, value) {\n var index;\n var hiddenRecord = getHiddenRecord(key);\n if (hiddenRecord) {\n hiddenRecord[id] = value;\n } else {\n index = keys.indexOf(key);\n if (index >= 0) {\n values[index] = value;\n } else {\n // Since some browsers preemptively terminate slow turns but\n // then continue computing with presumably corrupted heap\n // state, we here defensively get keys.length first and then\n // use it to update both the values and keys arrays, keeping\n // them in sync.\n index = keys.length;\n values[index] = value;\n // If we crash here, values will be one longer than keys.\n keys[index] = key;\n }\n }\n return this;\n }\n\n function delete___(key) {\n var hiddenRecord = getHiddenRecord(key);\n var index, lastIndex;\n if (hiddenRecord) {\n return id in hiddenRecord && delete hiddenRecord[id];\n } else {\n index = keys.indexOf(key);\n if (index < 0) {\n return false;\n }\n // Since some browsers preemptively terminate slow turns but\n // then continue computing with potentially corrupted heap\n // state, we here defensively get keys.length first and then use\n // it to update both the keys and the values array, keeping\n // them in sync. We update the two with an order of assignments,\n // such that any prefix of these assignments will preserve the\n // key/value correspondence, either before or after the delete.\n // Note that this needs to work correctly when index === lastIndex.\n lastIndex = keys.length - 1;\n keys[index] = void 0;\n // If we crash here, there's a void 0 in the keys array, but\n // no operation will cause a \"keys.indexOf(void 0)\", since\n // getHiddenRecord(void 0) will always throw an error first.\n values[index] = values[lastIndex];\n // If we crash here, values[index] cannot be found here,\n // because keys[index] is void 0.\n keys[index] = keys[lastIndex];\n // If index === lastIndex and we crash here, then keys[index]\n // is still void 0, since the aliasing killed the previous key.\n keys.length = lastIndex;\n // If we crash here, keys will be one shorter than values.\n values.length = lastIndex;\n return true;\n }\n }\n\n return Object.create(OurWeakMap.prototype, {\n get___: { value: constFunc(get___) },\n has___: { value: constFunc(has___) },\n set___: { value: constFunc(set___) },\n delete___: { value: constFunc(delete___) }\n });\n };\n\n OurWeakMap.prototype = Object.create(Object.prototype, {\n get: {\n /**\n * Return the value most recently associated with key, or\n * opt_default if none.\n */\n value: function get(key, opt_default) {\n return this.get___(key, opt_default);\n },\n writable: true,\n configurable: true\n },\n\n has: {\n /**\n * Is there a value associated with key in this WeakMap?\n */\n value: function has(key) {\n return this.has___(key);\n },\n writable: true,\n configurable: true\n },\n\n set: {\n /**\n * Associate value with key in this WeakMap, overwriting any\n * previous association if present.\n */\n value: function set(key, value) {\n return this.set___(key, value);\n },\n writable: true,\n configurable: true\n },\n\n 'delete': {\n /**\n * Remove any association for key in this WeakMap, returning\n * whether there was one.\n *\n *

Note that the boolean return here does not work like the\n * {@code delete} operator. The {@code delete} operator returns\n * whether the deletion succeeds at bringing about a state in\n * which the deleted property is absent. The {@code delete}\n * operator therefore returns true if the property was already\n * absent, whereas this {@code delete} method returns false if\n * the association was already absent.\n */\n value: function remove(key) {\n return this.delete___(key);\n },\n writable: true,\n configurable: true\n }\n });\n\n if (typeof HostWeakMap === 'function') {\n (function() {\n // If we got here, then the platform has a WeakMap but we are concerned\n // that it may refuse to store some key types. Therefore, make a map\n // implementation which makes use of both as possible.\n\n // In this mode we are always using double maps, so we are not proxy-safe.\n // This combination does not occur in any known browser, but we had best\n // be safe.\n if (doubleWeakMapCheckSilentFailure && typeof Proxy !== 'undefined') {\n Proxy = undefined;\n }\n\n function DoubleWeakMap() {\n if (!(this instanceof OurWeakMap)) { // approximate test for new ...()\n calledAsFunctionWarning();\n }\n\n // Preferable, truly weak map.\n var hmap = new HostWeakMap();\n\n // Our hidden-property-based pseudo-weak-map. Lazily initialized in the\n // 'set' implementation; thus we can avoid performing extra lookups if\n // we know all entries actually stored are entered in 'hmap'.\n var omap = undefined;\n\n // Hidden-property maps are not compatible with proxies because proxies\n // can observe the hidden name and either accidentally expose it or fail\n // to allow the hidden property to be set. Therefore, we do not allow\n // arbitrary WeakMaps to switch to using hidden properties, but only\n // those which need the ability, and unprivileged code is not allowed\n // to set the flag.\n //\n // (Except in doubleWeakMapCheckSilentFailure mode in which case we\n // disable proxies.)\n var enableSwitching = false;\n\n function dget(key, opt_default) {\n if (omap) {\n return hmap.has(key) ? hmap.get(key)\n : omap.get___(key, opt_default);\n } else {\n return hmap.get(key, opt_default);\n }\n }\n\n function dhas(key) {\n return hmap.has(key) || (omap ? omap.has___(key) : false);\n }\n\n var dset;\n if (doubleWeakMapCheckSilentFailure) {\n dset = function(key, value) {\n hmap.set(key, value);\n if (!hmap.has(key)) {\n if (!omap) { omap = new OurWeakMap(); }\n omap.set(key, value);\n }\n return this;\n };\n } else {\n dset = function(key, value) {\n if (enableSwitching) {\n try {\n hmap.set(key, value);\n } catch (e) {\n if (!omap) { omap = new OurWeakMap(); }\n omap.set___(key, value);\n }\n } else {\n hmap.set(key, value);\n }\n return this;\n };\n }\n\n function ddelete(key) {\n var result = !!hmap['delete'](key);\n if (omap) { return omap.delete___(key) || result; }\n return result;\n }\n\n return Object.create(OurWeakMap.prototype, {\n get___: { value: constFunc(dget) },\n has___: { value: constFunc(dhas) },\n set___: { value: constFunc(dset) },\n delete___: { value: constFunc(ddelete) },\n permitHostObjects___: { value: constFunc(function(token) {\n if (token === weakMapPermitHostObjects) {\n enableSwitching = true;\n } else {\n throw new Error('bogus call to permitHostObjects___');\n }\n })}\n });\n }\n DoubleWeakMap.prototype = OurWeakMap.prototype;\n module.exports = DoubleWeakMap;\n\n // define .constructor to hide OurWeakMap ctor\n Object.defineProperty(WeakMap.prototype, 'constructor', {\n value: WeakMap,\n enumerable: false, // as default .constructor is\n configurable: true,\n writable: true\n });\n })();\n } else {\n // There is no host WeakMap, so we must use the emulation.\n\n // Emulated WeakMaps are incompatible with native proxies (because proxies\n // can observe the hidden name), so we must disable Proxy usage (in\n // ArrayLike and Domado, currently).\n if (typeof Proxy !== 'undefined') {\n Proxy = undefined;\n }\n\n module.exports = OurWeakMap;\n }\n})();\n\n\n/***/ }),\n\n/***/ 236:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar hiddenStore = __webpack_require__(8284);\n\nmodule.exports = createStore;\n\nfunction createStore() {\n var key = {};\n\n return function (obj) {\n if ((typeof obj !== 'object' || obj === null) &&\n typeof obj !== 'function'\n ) {\n throw new Error('Weakmap-shim: Key must be object')\n }\n\n var store = obj.valueOf(key);\n return store && store.identity === key ?\n store : hiddenStore(obj, key);\n };\n}\n\n\n/***/ }),\n\n/***/ 8284:\n/***/ (function(module) {\n\nmodule.exports = hiddenStore;\n\nfunction hiddenStore(obj, key) {\n var store = { identity: key };\n var valueOf = obj.valueOf;\n\n Object.defineProperty(obj, \"valueOf\", {\n value: function (value) {\n return value !== key ?\n valueOf.apply(this, arguments) : store;\n },\n writable: true\n });\n\n return store;\n}\n\n\n/***/ }),\n\n/***/ 606:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n// Original - @Gozola.\n// https://gist.github.com/Gozala/1269991\n// This is a reimplemented version (with a few bug fixes).\n\nvar createStore = __webpack_require__(236);\n\nmodule.exports = weakMap;\n\nfunction weakMap() {\n var privates = createStore();\n\n return {\n 'get': function (key, fallback) {\n var store = privates(key)\n return store.hasOwnProperty('value') ?\n store.value : fallback\n },\n 'set': function (key, value) {\n privates(key).value = value;\n return this;\n },\n 'has': function(key) {\n return 'value' in privates(key);\n },\n 'delete': function (key) {\n return delete privates(key).value;\n }\n }\n}\n\n\n/***/ }),\n\n/***/ 3349:\n/***/ (function(module) {\n\n\"use strict\";\n\n\nfunction CWiseOp() {\n return function(SS, a0, t0, p0, Y0, Y1) {\n var s0 = SS[0],\n t0p0 = t0[0],\n index = [0],\n q0 = t0p0\n p0 |= 0\n var i0 = 0,\n d0s0 = t0p0\n for (i0 = 0; i0 < s0; ++i0) {\n {\n var da = a0[p0] - Y1\n var db = a0[p0 + q0] - Y1\n if (da >= 0 !== db >= 0) {\n Y0.push(index[0] + 0.5 + (0.5 * (da + db)) / (da - db))\n }\n }\n p0 += d0s0\n ++index[0]\n }\n }\n}\n\n//Generates a cwise operator\nfunction generateCWiseOp() {\n return CWiseOp()\n}\n\nvar compile = generateCWiseOp\n\nfunction thunk(compile) {\n var CACHED = {}\n return function zeroCrossings_cwise_thunk(array0, scalar2, scalar3) {\n var t0 = array0.dtype,\n r0 = array0.order,\n type = [t0, r0.join()].join(),\n proc = CACHED[type]\n\n if (!proc) {\n CACHED[type] = proc = compile([t0, r0])\n }\n\n return proc(array0.shape.slice(0), array0.data, array0.stride, array0.offset | 0, scalar2, scalar3)\n }\n}\n\nfunction createThunk(proc) {\n return thunk(compile.bind(undefined, proc))\n}\n\nfunction compileCwise(user_args) {\n return createThunk({\n funcName: user_args.funcName\n })\n}\n\nmodule.exports = compileCwise({\n funcName: 'zeroCrossings'\n})\n\n\n/***/ }),\n\n/***/ 781:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\n\"use strict\";\n\n\nmodule.exports = findZeroCrossings\n\nvar core = __webpack_require__(3349)\n\nfunction findZeroCrossings(array, level) {\n var cross = []\n level = +level || 0.0\n core(array.hi(array.shape[0]-1), cross, level)\n return cross\n}\n\n/***/ }),\n\n/***/ 7790:\n/***/ (function() {\n\n/* (ignored) */\n\n/***/ })\n\n/******/ \t});\n/************************************************************************/\n/******/ \t// The module cache\n/******/ \tvar __webpack_module_cache__ = {};\n/******/ \t\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/ \t\t// Check if module is in cache\n/******/ \t\tvar cachedModule = __webpack_module_cache__[moduleId];\n/******/ \t\tif (cachedModule !== undefined) {\n/******/ \t\t\treturn cachedModule.exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = __webpack_module_cache__[moduleId] = {\n/******/ \t\t\tid: moduleId,\n/******/ \t\t\tloaded: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/ \t\n/******/ \t\t// Execute the module function\n/******/ \t\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/ \t\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.loaded = true;\n/******/ \t\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/ \t\n/************************************************************************/\n/******/ \t/* webpack/runtime/global */\n/******/ \t!function() {\n/******/ \t\t__webpack_require__.g = (function() {\n/******/ \t\t\tif (typeof globalThis === 'object') return globalThis;\n/******/ \t\t\ttry {\n/******/ \t\t\t\treturn this || new Function('return this')();\n/******/ \t\t\t} catch (e) {\n/******/ \t\t\t\tif (typeof window === 'object') return window;\n/******/ \t\t\t}\n/******/ \t\t})();\n/******/ \t}();\n/******/ \t\n/******/ \t/* webpack/runtime/node module decorator */\n/******/ \t!function() {\n/******/ \t\t__webpack_require__.nmd = function(module) {\n/******/ \t\t\tmodule.paths = [];\n/******/ \t\t\tif (!module.children) module.children = [];\n/******/ \t\t\treturn module;\n/******/ \t\t};\n/******/ \t}();\n/******/ \t\n/************************************************************************/\n/******/ \t\n/******/ \t// startup\n/******/ \t// Load entry module and return exports\n/******/ \t// This entry module is referenced by other modules so it can't be inlined\n/******/ \tvar __webpack_exports__ = __webpack_require__(1964);\n/******/ \tmodule.exports = __webpack_exports__;\n/******/ \t\n/******/ })()\n;","// ray-casting algorithm based on\n// https://wrf.ecse.rpi.edu/Research/Short_Notes/pnpoly.html\n\nmodule.exports = function pointInPolygonNested (point, vs, start, end) {\n var x = point[0], y = point[1];\n var inside = false;\n if (start === undefined) start = 0;\n if (end === undefined) end = vs.length;\n var len = end - start;\n for (var i = 0, j = len - 1; i < len; j = i++) {\n var xi = vs[i+start][0], yi = vs[i+start][1];\n var xj = vs[j+start][0], yj = vs[j+start][1];\n var intersect = ((yi > y) !== (yj > y))\n && (x < (xj - xi) * (y - yi) / (yj - yi) + xi);\n if (intersect) inside = !inside;\n }\n return inside;\n};\n","/*\n * @copyright 2016 Sean Connelly (@voidqk), http://syntheti.cc\n * @license MIT\n * @preserve Project Home: https://github.com/voidqk/polybooljs\n */\n\nvar BuildLog = require('./lib/build-log');\nvar Epsilon = require('./lib/epsilon');\nvar Intersecter = require('./lib/intersecter');\nvar SegmentChainer = require('./lib/segment-chainer');\nvar SegmentSelector = require('./lib/segment-selector');\nvar GeoJSON = require('./lib/geojson');\n\nvar buildLog = false;\nvar epsilon = Epsilon();\n\nvar PolyBool;\nPolyBool = {\n\t// getter/setter for buildLog\n\tbuildLog: function(bl){\n\t\tif (bl === true)\n\t\t\tbuildLog = BuildLog();\n\t\telse if (bl === false)\n\t\t\tbuildLog = false;\n\t\treturn buildLog === false ? false : buildLog.list;\n\t},\n\t// getter/setter for epsilon\n\tepsilon: function(v){\n\t\treturn epsilon.epsilon(v);\n\t},\n\n\t// core API\n\tsegments: function(poly){\n\t\tvar i = Intersecter(true, epsilon, buildLog);\n\t\tpoly.regions.forEach(i.addRegion);\n\t\treturn {\n\t\t\tsegments: i.calculate(poly.inverted),\n\t\t\tinverted: poly.inverted\n\t\t};\n\t},\n\tcombine: function(segments1, segments2){\n\t\tvar i3 = Intersecter(false, epsilon, buildLog);\n\t\treturn {\n\t\t\tcombined: i3.calculate(\n\t\t\t\tsegments1.segments, segments1.inverted,\n\t\t\t\tsegments2.segments, segments2.inverted\n\t\t\t),\n\t\t\tinverted1: segments1.inverted,\n\t\t\tinverted2: segments2.inverted\n\t\t};\n\t},\n\tselectUnion: function(combined){\n\t\treturn {\n\t\t\tsegments: SegmentSelector.union(combined.combined, buildLog),\n\t\t\tinverted: combined.inverted1 || combined.inverted2\n\t\t}\n\t},\n\tselectIntersect: function(combined){\n\t\treturn {\n\t\t\tsegments: SegmentSelector.intersect(combined.combined, buildLog),\n\t\t\tinverted: combined.inverted1 && combined.inverted2\n\t\t}\n\t},\n\tselectDifference: function(combined){\n\t\treturn {\n\t\t\tsegments: SegmentSelector.difference(combined.combined, buildLog),\n\t\t\tinverted: combined.inverted1 && !combined.inverted2\n\t\t}\n\t},\n\tselectDifferenceRev: function(combined){\n\t\treturn {\n\t\t\tsegments: SegmentSelector.differenceRev(combined.combined, buildLog),\n\t\t\tinverted: !combined.inverted1 && combined.inverted2\n\t\t}\n\t},\n\tselectXor: function(combined){\n\t\treturn {\n\t\t\tsegments: SegmentSelector.xor(combined.combined, buildLog),\n\t\t\tinverted: combined.inverted1 !== combined.inverted2\n\t\t}\n\t},\n\tpolygon: function(segments){\n\t\treturn {\n\t\t\tregions: SegmentChainer(segments.segments, epsilon, buildLog),\n\t\t\tinverted: segments.inverted\n\t\t};\n\t},\n\n\t// GeoJSON converters\n\tpolygonFromGeoJSON: function(geojson){\n\t\treturn GeoJSON.toPolygon(PolyBool, geojson);\n\t},\n\tpolygonToGeoJSON: function(poly){\n\t\treturn GeoJSON.fromPolygon(PolyBool, epsilon, poly);\n\t},\n\n\t// helper functions for common operations\n\tunion: function(poly1, poly2){\n\t\treturn operate(poly1, poly2, PolyBool.selectUnion);\n\t},\n\tintersect: function(poly1, poly2){\n\t\treturn operate(poly1, poly2, PolyBool.selectIntersect);\n\t},\n\tdifference: function(poly1, poly2){\n\t\treturn operate(poly1, poly2, PolyBool.selectDifference);\n\t},\n\tdifferenceRev: function(poly1, poly2){\n\t\treturn operate(poly1, poly2, PolyBool.selectDifferenceRev);\n\t},\n\txor: function(poly1, poly2){\n\t\treturn operate(poly1, poly2, PolyBool.selectXor);\n\t}\n};\n\nfunction operate(poly1, poly2, selector){\n\tvar seg1 = PolyBool.segments(poly1);\n\tvar seg2 = PolyBool.segments(poly2);\n\tvar comb = PolyBool.combine(seg1, seg2);\n\tvar seg3 = selector(comb);\n\treturn PolyBool.polygon(seg3);\n}\n\nif (typeof window === 'object')\n\twindow.PolyBool = PolyBool;\n\nmodule.exports = PolyBool;\n","// (c) Copyright 2016, Sean Connelly (@voidqk), http://syntheti.cc\n// MIT License\n// Project Home: https://github.com/voidqk/polybooljs\n\n//\n// used strictly for logging the processing of the algorithm... only useful if you intend on\n// looking under the covers (for pretty UI's or debugging)\n//\n\nfunction BuildLog(){\n\tvar my;\n\tvar nextSegmentId = 0;\n\tvar curVert = false;\n\n\tfunction push(type, data){\n\t\tmy.list.push({\n\t\t\ttype: type,\n\t\t\tdata: data ? JSON.parse(JSON.stringify(data)) : void 0\n\t\t});\n\t\treturn my;\n\t}\n\n\tmy = {\n\t\tlist: [],\n\t\tsegmentId: function(){\n\t\t\treturn nextSegmentId++;\n\t\t},\n\t\tcheckIntersection: function(seg1, seg2){\n\t\t\treturn push('check', { seg1: seg1, seg2: seg2 });\n\t\t},\n\t\tsegmentChop: function(seg, end){\n\t\t\tpush('div_seg', { seg: seg, pt: end });\n\t\t\treturn push('chop', { seg: seg, pt: end });\n\t\t},\n\t\tstatusRemove: function(seg){\n\t\t\treturn push('pop_seg', { seg: seg });\n\t\t},\n\t\tsegmentUpdate: function(seg){\n\t\t\treturn push('seg_update', { seg: seg });\n\t\t},\n\t\tsegmentNew: function(seg, primary){\n\t\t\treturn push('new_seg', { seg: seg, primary: primary });\n\t\t},\n\t\tsegmentRemove: function(seg){\n\t\t\treturn push('rem_seg', { seg: seg });\n\t\t},\n\t\ttempStatus: function(seg, above, below){\n\t\t\treturn push('temp_status', { seg: seg, above: above, below: below });\n\t\t},\n\t\trewind: function(seg){\n\t\t\treturn push('rewind', { seg: seg });\n\t\t},\n\t\tstatus: function(seg, above, below){\n\t\t\treturn push('status', { seg: seg, above: above, below: below });\n\t\t},\n\t\tvert: function(x){\n\t\t\tif (x === curVert)\n\t\t\t\treturn my;\n\t\t\tcurVert = x;\n\t\t\treturn push('vert', { x: x });\n\t\t},\n\t\tlog: function(data){\n\t\t\tif (typeof data !== 'string')\n\t\t\t\tdata = JSON.stringify(data, false, ' ');\n\t\t\treturn push('log', { txt: data });\n\t\t},\n\t\treset: function(){\n\t\t\treturn push('reset');\n\t\t},\n\t\tselected: function(segs){\n\t\t\treturn push('selected', { segs: segs });\n\t\t},\n\t\tchainStart: function(seg){\n\t\t\treturn push('chain_start', { seg: seg });\n\t\t},\n\t\tchainRemoveHead: function(index, pt){\n\t\t\treturn push('chain_rem_head', { index: index, pt: pt });\n\t\t},\n\t\tchainRemoveTail: function(index, pt){\n\t\t\treturn push('chain_rem_tail', { index: index, pt: pt });\n\t\t},\n\t\tchainNew: function(pt1, pt2){\n\t\t\treturn push('chain_new', { pt1: pt1, pt2: pt2 });\n\t\t},\n\t\tchainMatch: function(index){\n\t\t\treturn push('chain_match', { index: index });\n\t\t},\n\t\tchainClose: function(index){\n\t\t\treturn push('chain_close', { index: index });\n\t\t},\n\t\tchainAddHead: function(index, pt){\n\t\t\treturn push('chain_add_head', { index: index, pt: pt });\n\t\t},\n\t\tchainAddTail: function(index, pt){\n\t\t\treturn push('chain_add_tail', { index: index, pt: pt, });\n\t\t},\n\t\tchainConnect: function(index1, index2){\n\t\t\treturn push('chain_con', { index1: index1, index2: index2 });\n\t\t},\n\t\tchainReverse: function(index){\n\t\t\treturn push('chain_rev', { index: index });\n\t\t},\n\t\tchainJoin: function(index1, index2){\n\t\t\treturn push('chain_join', { index1: index1, index2: index2 });\n\t\t},\n\t\tdone: function(){\n\t\t\treturn push('done');\n\t\t}\n\t};\n\treturn my;\n}\n\nmodule.exports = BuildLog;\n","// (c) Copyright 2016, Sean Connelly (@voidqk), http://syntheti.cc\n// MIT License\n// Project Home: https://github.com/voidqk/polybooljs\n\n//\n// provides the raw computation functions that takes epsilon into account\n//\n// zero is defined to be between (-epsilon, epsilon) exclusive\n//\n\nfunction Epsilon(eps){\n\tif (typeof eps !== 'number')\n\t\teps = 0.0000000001; // sane default? sure why not\n\tvar my = {\n\t\tepsilon: function(v){\n\t\t\tif (typeof v === 'number')\n\t\t\t\teps = v;\n\t\t\treturn eps;\n\t\t},\n\t\tpointAboveOrOnLine: function(pt, left, right){\n\t\t\tvar Ax = left[0];\n\t\t\tvar Ay = left[1];\n\t\t\tvar Bx = right[0];\n\t\t\tvar By = right[1];\n\t\t\tvar Cx = pt[0];\n\t\t\tvar Cy = pt[1];\n\t\t\treturn (Bx - Ax) * (Cy - Ay) - (By - Ay) * (Cx - Ax) >= -eps;\n\t\t},\n\t\tpointBetween: function(p, left, right){\n\t\t\t// p must be collinear with left->right\n\t\t\t// returns false if p == left, p == right, or left == right\n\t\t\tvar d_py_ly = p[1] - left[1];\n\t\t\tvar d_rx_lx = right[0] - left[0];\n\t\t\tvar d_px_lx = p[0] - left[0];\n\t\t\tvar d_ry_ly = right[1] - left[1];\n\n\t\t\tvar dot = d_px_lx * d_rx_lx + d_py_ly * d_ry_ly;\n\t\t\t// if `dot` is 0, then `p` == `left` or `left` == `right` (reject)\n\t\t\t// if `dot` is less than 0, then `p` is to the left of `left` (reject)\n\t\t\tif (dot < eps)\n\t\t\t\treturn false;\n\n\t\t\tvar sqlen = d_rx_lx * d_rx_lx + d_ry_ly * d_ry_ly;\n\t\t\t// if `dot` > `sqlen`, then `p` is to the right of `right` (reject)\n\t\t\t// therefore, if `dot - sqlen` is greater than 0, then `p` is to the right of `right` (reject)\n\t\t\tif (dot - sqlen > -eps)\n\t\t\t\treturn false;\n\n\t\t\treturn true;\n\t\t},\n\t\tpointsSameX: function(p1, p2){\n\t\t\treturn Math.abs(p1[0] - p2[0]) < eps;\n\t\t},\n\t\tpointsSameY: function(p1, p2){\n\t\t\treturn Math.abs(p1[1] - p2[1]) < eps;\n\t\t},\n\t\tpointsSame: function(p1, p2){\n\t\t\treturn my.pointsSameX(p1, p2) && my.pointsSameY(p1, p2);\n\t\t},\n\t\tpointsCompare: function(p1, p2){\n\t\t\t// returns -1 if p1 is smaller, 1 if p2 is smaller, 0 if equal\n\t\t\tif (my.pointsSameX(p1, p2))\n\t\t\t\treturn my.pointsSameY(p1, p2) ? 0 : (p1[1] < p2[1] ? -1 : 1);\n\t\t\treturn p1[0] < p2[0] ? -1 : 1;\n\t\t},\n\t\tpointsCollinear: function(pt1, pt2, pt3){\n\t\t\t// does pt1->pt2->pt3 make a straight line?\n\t\t\t// essentially this is just checking to see if the slope(pt1->pt2) === slope(pt2->pt3)\n\t\t\t// if slopes are equal, then they must be collinear, because they share pt2\n\t\t\tvar dx1 = pt1[0] - pt2[0];\n\t\t\tvar dy1 = pt1[1] - pt2[1];\n\t\t\tvar dx2 = pt2[0] - pt3[0];\n\t\t\tvar dy2 = pt2[1] - pt3[1];\n\t\t\treturn Math.abs(dx1 * dy2 - dx2 * dy1) < eps;\n\t\t},\n\t\tlinesIntersect: function(a0, a1, b0, b1){\n\t\t\t// returns false if the lines are coincident (e.g., parallel or on top of each other)\n\t\t\t//\n\t\t\t// returns an object if the lines intersect:\n\t\t\t// {\n\t\t\t// pt: [x, y], where the intersection point is at\n\t\t\t// alongA: where intersection point is along A,\n\t\t\t// alongB: where intersection point is along B\n\t\t\t// }\n\t\t\t//\n\t\t\t// alongA and alongB will each be one of: -2, -1, 0, 1, 2\n\t\t\t//\n\t\t\t// with the following meaning:\n\t\t\t//\n\t\t\t// -2 intersection point is before segment's first point\n\t\t\t// -1 intersection point is directly on segment's first point\n\t\t\t// 0 intersection point is between segment's first and second points (exclusive)\n\t\t\t// 1 intersection point is directly on segment's second point\n\t\t\t// 2 intersection point is after segment's second point\n\t\t\tvar adx = a1[0] - a0[0];\n\t\t\tvar ady = a1[1] - a0[1];\n\t\t\tvar bdx = b1[0] - b0[0];\n\t\t\tvar bdy = b1[1] - b0[1];\n\n\t\t\tvar axb = adx * bdy - ady * bdx;\n\t\t\tif (Math.abs(axb) < eps)\n\t\t\t\treturn false; // lines are coincident\n\n\t\t\tvar dx = a0[0] - b0[0];\n\t\t\tvar dy = a0[1] - b0[1];\n\n\t\t\tvar A = (bdx * dy - bdy * dx) / axb;\n\t\t\tvar B = (adx * dy - ady * dx) / axb;\n\n\t\t\tvar ret = {\n\t\t\t\talongA: 0,\n\t\t\t\talongB: 0,\n\t\t\t\tpt: [\n\t\t\t\t\ta0[0] + A * adx,\n\t\t\t\t\ta0[1] + A * ady\n\t\t\t\t]\n\t\t\t};\n\n\t\t\t// categorize where intersection point is along A and B\n\n\t\t\tif (A <= -eps)\n\t\t\t\tret.alongA = -2;\n\t\t\telse if (A < eps)\n\t\t\t\tret.alongA = -1;\n\t\t\telse if (A - 1 <= -eps)\n\t\t\t\tret.alongA = 0;\n\t\t\telse if (A - 1 < eps)\n\t\t\t\tret.alongA = 1;\n\t\t\telse\n\t\t\t\tret.alongA = 2;\n\n\t\t\tif (B <= -eps)\n\t\t\t\tret.alongB = -2;\n\t\t\telse if (B < eps)\n\t\t\t\tret.alongB = -1;\n\t\t\telse if (B - 1 <= -eps)\n\t\t\t\tret.alongB = 0;\n\t\t\telse if (B - 1 < eps)\n\t\t\t\tret.alongB = 1;\n\t\t\telse\n\t\t\t\tret.alongB = 2;\n\n\t\t\treturn ret;\n\t\t},\n\t\tpointInsideRegion: function(pt, region){\n\t\t\tvar x = pt[0];\n\t\t\tvar y = pt[1];\n\t\t\tvar last_x = region[region.length - 1][0];\n\t\t\tvar last_y = region[region.length - 1][1];\n\t\t\tvar inside = false;\n\t\t\tfor (var i = 0; i < region.length; i++){\n\t\t\t\tvar curr_x = region[i][0];\n\t\t\t\tvar curr_y = region[i][1];\n\n\t\t\t\t// if y is between curr_y and last_y, and\n\t\t\t\t// x is to the right of the boundary created by the line\n\t\t\t\tif ((curr_y - y > eps) != (last_y - y > eps) &&\n\t\t\t\t\t(last_x - curr_x) * (y - curr_y) / (last_y - curr_y) + curr_x - x > eps)\n\t\t\t\t\tinside = !inside\n\n\t\t\t\tlast_x = curr_x;\n\t\t\t\tlast_y = curr_y;\n\t\t\t}\n\t\t\treturn inside;\n\t\t}\n\t};\n\treturn my;\n}\n\nmodule.exports = Epsilon;\n","// (c) Copyright 2017, Sean Connelly (@voidqk), http://syntheti.cc\n// MIT License\n// Project Home: https://github.com/voidqk/polybooljs\n\n//\n// convert between PolyBool polygon format and GeoJSON formats (Polygon and MultiPolygon)\n//\n\nvar GeoJSON = {\n\t// convert a GeoJSON object to a PolyBool polygon\n\ttoPolygon: function(PolyBool, geojson){\n\n\t\t// converts list of LineString's to segments\n\t\tfunction GeoPoly(coords){\n\t\t\t// check for empty coords\n\t\t\tif (coords.length <= 0)\n\t\t\t\treturn PolyBool.segments({ inverted: false, regions: [] });\n\n\t\t\t// convert LineString to segments\n\t\t\tfunction LineString(ls){\n\t\t\t\t// remove tail which should be the same as head\n\t\t\t\tvar reg = ls.slice(0, ls.length - 1);\n\t\t\t\treturn PolyBool.segments({ inverted: false, regions: [reg] });\n\t\t\t}\n\n\t\t\t// the first LineString is considered the outside\n\t\t\tvar out = LineString(coords[0]);\n\n\t\t\t// the rest of the LineStrings are considered interior holes, so subtract them from the\n\t\t\t// current result\n\t\t\tfor (var i = 1; i < coords.length; i++)\n\t\t\t\tout = PolyBool.selectDifference(PolyBool.combine(out, LineString(coords[i])));\n\n\t\t\treturn out;\n\t\t}\n\n\t\tif (geojson.type === 'Polygon'){\n\t\t\t// single polygon, so just convert it and we're done\n\t\t\treturn PolyBool.polygon(GeoPoly(geojson.coordinates));\n\t\t}\n\t\telse if (geojson.type === 'MultiPolygon'){\n\t\t\t// multiple polygons, so union all the polygons together\n\t\t\tvar out = PolyBool.segments({ inverted: false, regions: [] });\n\t\t\tfor (var i = 0; i < geojson.coordinates.length; i++)\n\t\t\t\tout = PolyBool.selectUnion(PolyBool.combine(out, GeoPoly(geojson.coordinates[i])));\n\t\t\treturn PolyBool.polygon(out);\n\t\t}\n\t\tthrow new Error('PolyBool: Cannot convert GeoJSON object to PolyBool polygon');\n\t},\n\n\t// convert a PolyBool polygon to a GeoJSON object\n\tfromPolygon: function(PolyBool, eps, poly){\n\t\t// make sure out polygon is clean\n\t\tpoly = PolyBool.polygon(PolyBool.segments(poly));\n\n\t\t// test if r1 is inside r2\n\t\tfunction regionInsideRegion(r1, r2){\n\t\t\t// we're guaranteed no lines intersect (because the polygon is clean), but a vertex\n\t\t\t// could be on the edge -- so we just average pt[0] and pt[1] to produce a point on the\n\t\t\t// edge of the first line, which cannot be on an edge\n\t\t\treturn eps.pointInsideRegion([\n\t\t\t\t(r1[0][0] + r1[1][0]) * 0.5,\n\t\t\t\t(r1[0][1] + r1[1][1]) * 0.5\n\t\t\t], r2);\n\t\t}\n\n\t\t// calculate inside heirarchy\n\t\t//\n\t\t// _____________________ _______ roots -> A -> F\n\t\t// | A | | F | | |\n\t\t// | _______ _______ | | ___ | +-- B +-- G\n\t\t// | | B | | C | | | | | | | |\n\t\t// | | ___ | | ___ | | | | | | | +-- D\n\t\t// | | | D | | | | E | | | | | G | | |\n\t\t// | | |___| | | |___| | | | | | | +-- C\n\t\t// | |_______| |_______| | | |___| | |\n\t\t// |_____________________| |_______| +-- E\n\n\t\tfunction newNode(region){\n\t\t\treturn {\n\t\t\t\tregion: region,\n\t\t\t\tchildren: []\n\t\t\t};\n\t\t}\n\n\t\tvar roots = newNode(null);\n\n\t\tfunction addChild(root, region){\n\t\t\t// first check if we're inside any children\n\t\t\tfor (var i = 0; i < root.children.length; i++){\n\t\t\t\tvar child = root.children[i];\n\t\t\t\tif (regionInsideRegion(region, child.region)){\n\t\t\t\t\t// we are, so insert inside them instead\n\t\t\t\t\taddChild(child, region);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// not inside any children, so check to see if any children are inside us\n\t\t\tvar node = newNode(region);\n\t\t\tfor (var i = 0; i < root.children.length; i++){\n\t\t\t\tvar child = root.children[i];\n\t\t\t\tif (regionInsideRegion(child.region, region)){\n\t\t\t\t\t// oops... move the child beneath us, and remove them from root\n\t\t\t\t\tnode.children.push(child);\n\t\t\t\t\troot.children.splice(i, 1);\n\t\t\t\t\ti--;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// now we can add ourselves\n\t\t\troot.children.push(node);\n\t\t}\n\n\t\t// add all regions to the root\n\t\tfor (var i = 0; i < poly.regions.length; i++){\n\t\t\tvar region = poly.regions[i];\n\t\t\tif (region.length < 3) // regions must have at least 3 points (sanity check)\n\t\t\t\tcontinue;\n\t\t\taddChild(roots, region);\n\t\t}\n\n\t\t// with our heirarchy, we can distinguish between exterior borders, and interior holes\n\t\t// the root nodes are exterior, children are interior, children's children are exterior,\n\t\t// children's children's children are interior, etc\n\n\t\t// while we're at it, exteriors are counter-clockwise, and interiors are clockwise\n\n\t\tfunction forceWinding(region, clockwise){\n\t\t\t// first, see if we're clockwise or counter-clockwise\n\t\t\t// https://en.wikipedia.org/wiki/Shoelace_formula\n\t\t\tvar winding = 0;\n\t\t\tvar last_x = region[region.length - 1][0];\n\t\t\tvar last_y = region[region.length - 1][1];\n\t\t\tvar copy = [];\n\t\t\tfor (var i = 0; i < region.length; i++){\n\t\t\t\tvar curr_x = region[i][0];\n\t\t\t\tvar curr_y = region[i][1];\n\t\t\t\tcopy.push([curr_x, curr_y]); // create a copy while we're at it\n\t\t\t\twinding += curr_y * last_x - curr_x * last_y;\n\t\t\t\tlast_x = curr_x;\n\t\t\t\tlast_y = curr_y;\n\t\t\t}\n\t\t\t// this assumes Cartesian coordinates (Y is positive going up)\n\t\t\tvar isclockwise = winding < 0;\n\t\t\tif (isclockwise !== clockwise)\n\t\t\t\tcopy.reverse();\n\t\t\t// while we're here, the last point must be the first point...\n\t\t\tcopy.push([copy[0][0], copy[0][1]]);\n\t\t\treturn copy;\n\t\t}\n\n\t\tvar geopolys = [];\n\n\t\tfunction addExterior(node){\n\t\t\tvar poly = [forceWinding(node.region, false)];\n\t\t\tgeopolys.push(poly);\n\t\t\t// children of exteriors are interior\n\t\t\tfor (var i = 0; i < node.children.length; i++)\n\t\t\t\tpoly.push(getInterior(node.children[i]));\n\t\t}\n\n\t\tfunction getInterior(node){\n\t\t\t// children of interiors are exterior\n\t\t\tfor (var i = 0; i < node.children.length; i++)\n\t\t\t\taddExterior(node.children[i]);\n\t\t\t// return the clockwise interior\n\t\t\treturn forceWinding(node.region, true);\n\t\t}\n\n\t\t// root nodes are exterior\n\t\tfor (var i = 0; i < roots.children.length; i++)\n\t\t\taddExterior(roots.children[i]);\n\n\t\t// lastly, construct the approrpriate GeoJSON object\n\n\t\tif (geopolys.length <= 0) // empty GeoJSON Polygon\n\t\t\treturn { type: 'Polygon', coordinates: [] };\n\t\tif (geopolys.length == 1) // use a GeoJSON Polygon\n\t\t\treturn { type: 'Polygon', coordinates: geopolys[0] };\n\t\treturn { // otherwise, use a GeoJSON MultiPolygon\n\t\t\ttype: 'MultiPolygon',\n\t\t\tcoordinates: geopolys\n\t\t};\n\t}\n};\n\nmodule.exports = GeoJSON;\n","// (c) Copyright 2016, Sean Connelly (@voidqk), http://syntheti.cc\n// MIT License\n// Project Home: https://github.com/voidqk/polybooljs\n\n//\n// this is the core work-horse\n//\n\nvar LinkedList = require('./linked-list');\n\nfunction Intersecter(selfIntersection, eps, buildLog){\n\t// selfIntersection is true/false depending on the phase of the overall algorithm\n\n\t//\n\t// segment creation\n\t//\n\n\tfunction segmentNew(start, end){\n\t\treturn {\n\t\t\tid: buildLog ? buildLog.segmentId() : -1,\n\t\t\tstart: start,\n\t\t\tend: end,\n\t\t\tmyFill: {\n\t\t\t\tabove: null, // is there fill above us?\n\t\t\t\tbelow: null // is there fill below us?\n\t\t\t},\n\t\t\totherFill: null\n\t\t};\n\t}\n\n\tfunction segmentCopy(start, end, seg){\n\t\treturn {\n\t\t\tid: buildLog ? buildLog.segmentId() : -1,\n\t\t\tstart: start,\n\t\t\tend: end,\n\t\t\tmyFill: {\n\t\t\t\tabove: seg.myFill.above,\n\t\t\t\tbelow: seg.myFill.below\n\t\t\t},\n\t\t\totherFill: null\n\t\t};\n\t}\n\n\t//\n\t// event logic\n\t//\n\n\tvar event_root = LinkedList.create();\n\n\tfunction eventCompare(p1_isStart, p1_1, p1_2, p2_isStart, p2_1, p2_2){\n\t\t// compare the selected points first\n\t\tvar comp = eps.pointsCompare(p1_1, p2_1);\n\t\tif (comp !== 0)\n\t\t\treturn comp;\n\t\t// the selected points are the same\n\n\t\tif (eps.pointsSame(p1_2, p2_2)) // if the non-selected points are the same too...\n\t\t\treturn 0; // then the segments are equal\n\n\t\tif (p1_isStart !== p2_isStart) // if one is a start and the other isn't...\n\t\t\treturn p1_isStart ? 1 : -1; // favor the one that isn't the start\n\n\t\t// otherwise, we'll have to calculate which one is below the other manually\n\t\treturn eps.pointAboveOrOnLine(p1_2,\n\t\t\tp2_isStart ? p2_1 : p2_2, // order matters\n\t\t\tp2_isStart ? p2_2 : p2_1\n\t\t) ? 1 : -1;\n\t}\n\n\tfunction eventAdd(ev, other_pt){\n\t\tevent_root.insertBefore(ev, function(here){\n\t\t\t// should ev be inserted before here?\n\t\t\tvar comp = eventCompare(\n\t\t\t\tev .isStart, ev .pt, other_pt,\n\t\t\t\there.isStart, here.pt, here.other.pt\n\t\t\t);\n\t\t\treturn comp < 0;\n\t\t});\n\t}\n\n\tfunction eventAddSegmentStart(seg, primary){\n\t\tvar ev_start = LinkedList.node({\n\t\t\tisStart: true,\n\t\t\tpt: seg.start,\n\t\t\tseg: seg,\n\t\t\tprimary: primary,\n\t\t\tother: null,\n\t\t\tstatus: null\n\t\t});\n\t\teventAdd(ev_start, seg.end);\n\t\treturn ev_start;\n\t}\n\n\tfunction eventAddSegmentEnd(ev_start, seg, primary){\n\t\tvar ev_end = LinkedList.node({\n\t\t\tisStart: false,\n\t\t\tpt: seg.end,\n\t\t\tseg: seg,\n\t\t\tprimary: primary,\n\t\t\tother: ev_start,\n\t\t\tstatus: null\n\t\t});\n\t\tev_start.other = ev_end;\n\t\teventAdd(ev_end, ev_start.pt);\n\t}\n\n\tfunction eventAddSegment(seg, primary){\n\t\tvar ev_start = eventAddSegmentStart(seg, primary);\n\t\teventAddSegmentEnd(ev_start, seg, primary);\n\t\treturn ev_start;\n\t}\n\n\tfunction eventUpdateEnd(ev, end){\n\t\t// slides an end backwards\n\t\t// (start)------------(end) to:\n\t\t// (start)---(end)\n\n\t\tif (buildLog)\n\t\t\tbuildLog.segmentChop(ev.seg, end);\n\n\t\tev.other.remove();\n\t\tev.seg.end = end;\n\t\tev.other.pt = end;\n\t\teventAdd(ev.other, ev.pt);\n\t}\n\n\tfunction eventDivide(ev, pt){\n\t\tvar ns = segmentCopy(pt, ev.seg.end, ev.seg);\n\t\teventUpdateEnd(ev, pt);\n\t\treturn eventAddSegment(ns, ev.primary);\n\t}\n\n\tfunction calculate(primaryPolyInverted, secondaryPolyInverted){\n\t\t// if selfIntersection is true then there is no secondary polygon, so that isn't used\n\n\t\t//\n\t\t// status logic\n\t\t//\n\n\t\tvar status_root = LinkedList.create();\n\n\t\tfunction statusCompare(ev1, ev2){\n\t\t\tvar a1 = ev1.seg.start;\n\t\t\tvar a2 = ev1.seg.end;\n\t\t\tvar b1 = ev2.seg.start;\n\t\t\tvar b2 = ev2.seg.end;\n\n\t\t\tif (eps.pointsCollinear(a1, b1, b2)){\n\t\t\t\tif (eps.pointsCollinear(a2, b1, b2))\n\t\t\t\t\treturn 1;//eventCompare(true, a1, a2, true, b1, b2);\n\t\t\t\treturn eps.pointAboveOrOnLine(a2, b1, b2) ? 1 : -1;\n\t\t\t}\n\t\t\treturn eps.pointAboveOrOnLine(a1, b1, b2) ? 1 : -1;\n\t\t}\n\n\t\tfunction statusFindSurrounding(ev){\n\t\t\treturn status_root.findTransition(function(here){\n\t\t\t\tvar comp = statusCompare(ev, here.ev);\n\t\t\t\treturn comp > 0;\n\t\t\t});\n\t\t}\n\n\t\tfunction checkIntersection(ev1, ev2){\n\t\t\t// returns the segment equal to ev1, or false if nothing equal\n\n\t\t\tvar seg1 = ev1.seg;\n\t\t\tvar seg2 = ev2.seg;\n\t\t\tvar a1 = seg1.start;\n\t\t\tvar a2 = seg1.end;\n\t\t\tvar b1 = seg2.start;\n\t\t\tvar b2 = seg2.end;\n\n\t\t\tif (buildLog)\n\t\t\t\tbuildLog.checkIntersection(seg1, seg2);\n\n\t\t\tvar i = eps.linesIntersect(a1, a2, b1, b2);\n\n\t\t\tif (i === false){\n\t\t\t\t// segments are parallel or coincident\n\n\t\t\t\t// if points aren't collinear, then the segments are parallel, so no intersections\n\t\t\t\tif (!eps.pointsCollinear(a1, a2, b1))\n\t\t\t\t\treturn false;\n\t\t\t\t// otherwise, segments are on top of each other somehow (aka coincident)\n\n\t\t\t\tif (eps.pointsSame(a1, b2) || eps.pointsSame(a2, b1))\n\t\t\t\t\treturn false; // segments touch at endpoints... no intersection\n\n\t\t\t\tvar a1_equ_b1 = eps.pointsSame(a1, b1);\n\t\t\t\tvar a2_equ_b2 = eps.pointsSame(a2, b2);\n\n\t\t\t\tif (a1_equ_b1 && a2_equ_b2)\n\t\t\t\t\treturn ev2; // segments are exactly equal\n\n\t\t\t\tvar a1_between = !a1_equ_b1 && eps.pointBetween(a1, b1, b2);\n\t\t\t\tvar a2_between = !a2_equ_b2 && eps.pointBetween(a2, b1, b2);\n\n\t\t\t\t// handy for debugging:\n\t\t\t\t// buildLog.log({\n\t\t\t\t//\ta1_equ_b1: a1_equ_b1,\n\t\t\t\t//\ta2_equ_b2: a2_equ_b2,\n\t\t\t\t//\ta1_between: a1_between,\n\t\t\t\t//\ta2_between: a2_between\n\t\t\t\t// });\n\n\t\t\t\tif (a1_equ_b1){\n\t\t\t\t\tif (a2_between){\n\t\t\t\t\t\t// (a1)---(a2)\n\t\t\t\t\t\t// (b1)----------(b2)\n\t\t\t\t\t\teventDivide(ev2, a2);\n\t\t\t\t\t}\n\t\t\t\t\telse{\n\t\t\t\t\t\t// (a1)----------(a2)\n\t\t\t\t\t\t// (b1)---(b2)\n\t\t\t\t\t\teventDivide(ev1, b2);\n\t\t\t\t\t}\n\t\t\t\t\treturn ev2;\n\t\t\t\t}\n\t\t\t\telse if (a1_between){\n\t\t\t\t\tif (!a2_equ_b2){\n\t\t\t\t\t\t// make a2 equal to b2\n\t\t\t\t\t\tif (a2_between){\n\t\t\t\t\t\t\t// (a1)---(a2)\n\t\t\t\t\t\t\t// (b1)-----------------(b2)\n\t\t\t\t\t\t\teventDivide(ev2, a2);\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse{\n\t\t\t\t\t\t\t// (a1)----------(a2)\n\t\t\t\t\t\t\t// (b1)----------(b2)\n\t\t\t\t\t\t\teventDivide(ev1, b2);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// (a1)---(a2)\n\t\t\t\t\t// (b1)----------(b2)\n\t\t\t\t\teventDivide(ev2, a1);\n\t\t\t\t}\n\t\t\t}\n\t\t\telse{\n\t\t\t\t// otherwise, lines intersect at i.pt, which may or may not be between the endpoints\n\n\t\t\t\t// is A divided between its endpoints? (exclusive)\n\t\t\t\tif (i.alongA === 0){\n\t\t\t\t\tif (i.alongB === -1) // yes, at exactly b1\n\t\t\t\t\t\teventDivide(ev1, b1);\n\t\t\t\t\telse if (i.alongB === 0) // yes, somewhere between B's endpoints\n\t\t\t\t\t\teventDivide(ev1, i.pt);\n\t\t\t\t\telse if (i.alongB === 1) // yes, at exactly b2\n\t\t\t\t\t\teventDivide(ev1, b2);\n\t\t\t\t}\n\n\t\t\t\t// is B divided between its endpoints? (exclusive)\n\t\t\t\tif (i.alongB === 0){\n\t\t\t\t\tif (i.alongA === -1) // yes, at exactly a1\n\t\t\t\t\t\teventDivide(ev2, a1);\n\t\t\t\t\telse if (i.alongA === 0) // yes, somewhere between A's endpoints (exclusive)\n\t\t\t\t\t\teventDivide(ev2, i.pt);\n\t\t\t\t\telse if (i.alongA === 1) // yes, at exactly a2\n\t\t\t\t\t\teventDivide(ev2, a2);\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn false;\n\t\t}\n\n\t\t//\n\t\t// main event loop\n\t\t//\n\t\tvar segments = [];\n\t\twhile (!event_root.isEmpty()){\n\t\t\tvar ev = event_root.getHead();\n\n\t\t\tif (buildLog)\n\t\t\t\tbuildLog.vert(ev.pt[0]);\n\n\t\t\tif (ev.isStart){\n\n\t\t\t\tif (buildLog)\n\t\t\t\t\tbuildLog.segmentNew(ev.seg, ev.primary);\n\n\t\t\t\tvar surrounding = statusFindSurrounding(ev);\n\t\t\t\tvar above = surrounding.before ? surrounding.before.ev : null;\n\t\t\t\tvar below = surrounding.after ? surrounding.after.ev : null;\n\n\t\t\t\tif (buildLog){\n\t\t\t\t\tbuildLog.tempStatus(\n\t\t\t\t\t\tev.seg,\n\t\t\t\t\t\tabove ? above.seg : false,\n\t\t\t\t\t\tbelow ? below.seg : false\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\tfunction checkBothIntersections(){\n\t\t\t\t\tif (above){\n\t\t\t\t\t\tvar eve = checkIntersection(ev, above);\n\t\t\t\t\t\tif (eve)\n\t\t\t\t\t\t\treturn eve;\n\t\t\t\t\t}\n\t\t\t\t\tif (below)\n\t\t\t\t\t\treturn checkIntersection(ev, below);\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\n\t\t\t\tvar eve = checkBothIntersections();\n\t\t\t\tif (eve){\n\t\t\t\t\t// ev and eve are equal\n\t\t\t\t\t// we'll keep eve and throw away ev\n\n\t\t\t\t\t// merge ev.seg's fill information into eve.seg\n\n\t\t\t\t\tif (selfIntersection){\n\t\t\t\t\t\tvar toggle; // are we a toggling edge?\n\t\t\t\t\t\tif (ev.seg.myFill.below === null)\n\t\t\t\t\t\t\ttoggle = true;\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\ttoggle = ev.seg.myFill.above !== ev.seg.myFill.below;\n\n\t\t\t\t\t\t// merge two segments that belong to the same polygon\n\t\t\t\t\t\t// think of this as sandwiching two segments together, where `eve.seg` is\n\t\t\t\t\t\t// the bottom -- this will cause the above fill flag to toggle\n\t\t\t\t\t\tif (toggle)\n\t\t\t\t\t\t\teve.seg.myFill.above = !eve.seg.myFill.above;\n\t\t\t\t\t}\n\t\t\t\t\telse{\n\t\t\t\t\t\t// merge two segments that belong to different polygons\n\t\t\t\t\t\t// each segment has distinct knowledge, so no special logic is needed\n\t\t\t\t\t\t// note that this can only happen once per segment in this phase, because we\n\t\t\t\t\t\t// are guaranteed that all self-intersections are gone\n\t\t\t\t\t\teve.seg.otherFill = ev.seg.myFill;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (buildLog)\n\t\t\t\t\t\tbuildLog.segmentUpdate(eve.seg);\n\n\t\t\t\t\tev.other.remove();\n\t\t\t\t\tev.remove();\n\t\t\t\t}\n\n\t\t\t\tif (event_root.getHead() !== ev){\n\t\t\t\t\t// something was inserted before us in the event queue, so loop back around and\n\t\t\t\t\t// process it before continuing\n\t\t\t\t\tif (buildLog)\n\t\t\t\t\t\tbuildLog.rewind(ev.seg);\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t//\n\t\t\t\t// calculate fill flags\n\t\t\t\t//\n\t\t\t\tif (selfIntersection){\n\t\t\t\t\tvar toggle; // are we a toggling edge?\n\t\t\t\t\tif (ev.seg.myFill.below === null) // if we are a new segment...\n\t\t\t\t\t\ttoggle = true; // then we toggle\n\t\t\t\t\telse // we are a segment that has previous knowledge from a division\n\t\t\t\t\t\ttoggle = ev.seg.myFill.above !== ev.seg.myFill.below; // calculate toggle\n\n\t\t\t\t\t// next, calculate whether we are filled below us\n\t\t\t\t\tif (!below){ // if nothing is below us...\n\t\t\t\t\t\t// we are filled below us if the polygon is inverted\n\t\t\t\t\t\tev.seg.myFill.below = primaryPolyInverted;\n\t\t\t\t\t}\n\t\t\t\t\telse{\n\t\t\t\t\t\t// otherwise, we know the answer -- it's the same if whatever is below\n\t\t\t\t\t\t// us is filled above it\n\t\t\t\t\t\tev.seg.myFill.below = below.seg.myFill.above;\n\t\t\t\t\t}\n\n\t\t\t\t\t// since now we know if we're filled below us, we can calculate whether\n\t\t\t\t\t// we're filled above us by applying toggle to whatever is below us\n\t\t\t\t\tif (toggle)\n\t\t\t\t\t\tev.seg.myFill.above = !ev.seg.myFill.below;\n\t\t\t\t\telse\n\t\t\t\t\t\tev.seg.myFill.above = ev.seg.myFill.below;\n\t\t\t\t}\n\t\t\t\telse{\n\t\t\t\t\t// now we fill in any missing transition information, since we are all-knowing\n\t\t\t\t\t// at this point\n\n\t\t\t\t\tif (ev.seg.otherFill === null){\n\t\t\t\t\t\t// if we don't have other information, then we need to figure out if we're\n\t\t\t\t\t\t// inside the other polygon\n\t\t\t\t\t\tvar inside;\n\t\t\t\t\t\tif (!below){\n\t\t\t\t\t\t\t// if nothing is below us, then we're inside if the other polygon is\n\t\t\t\t\t\t\t// inverted\n\t\t\t\t\t\t\tinside =\n\t\t\t\t\t\t\t\tev.primary ? secondaryPolyInverted : primaryPolyInverted;\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse{ // otherwise, something is below us\n\t\t\t\t\t\t\t// so copy the below segment's other polygon's above\n\t\t\t\t\t\t\tif (ev.primary === below.primary)\n\t\t\t\t\t\t\t\tinside = below.seg.otherFill.above;\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tinside = below.seg.myFill.above;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tev.seg.otherFill = {\n\t\t\t\t\t\t\tabove: inside,\n\t\t\t\t\t\t\tbelow: inside\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (buildLog){\n\t\t\t\t\tbuildLog.status(\n\t\t\t\t\t\tev.seg,\n\t\t\t\t\t\tabove ? above.seg : false,\n\t\t\t\t\t\tbelow ? below.seg : false\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\t// insert the status and remember it for later removal\n\t\t\t\tev.other.status = surrounding.insert(LinkedList.node({ ev: ev }));\n\t\t\t}\n\t\t\telse{\n\t\t\t\tvar st = ev.status;\n\n\t\t\t\tif (st === null){\n\t\t\t\t\tthrow new Error('PolyBool: Zero-length segment detected; your epsilon is ' +\n\t\t\t\t\t\t'probably too small or too large');\n\t\t\t\t}\n\n\t\t\t\t// removing the status will create two new adjacent edges, so we'll need to check\n\t\t\t\t// for those\n\t\t\t\tif (status_root.exists(st.prev) && status_root.exists(st.next))\n\t\t\t\t\tcheckIntersection(st.prev.ev, st.next.ev);\n\n\t\t\t\tif (buildLog)\n\t\t\t\t\tbuildLog.statusRemove(st.ev.seg);\n\n\t\t\t\t// remove the status\n\t\t\t\tst.remove();\n\n\t\t\t\t// if we've reached this point, we've calculated everything there is to know, so\n\t\t\t\t// save the segment for reporting\n\t\t\t\tif (!ev.primary){\n\t\t\t\t\t// make sure `seg.myFill` actually points to the primary polygon though\n\t\t\t\t\tvar s = ev.seg.myFill;\n\t\t\t\t\tev.seg.myFill = ev.seg.otherFill;\n\t\t\t\t\tev.seg.otherFill = s;\n\t\t\t\t}\n\t\t\t\tsegments.push(ev.seg);\n\t\t\t}\n\n\t\t\t// remove the event and continue\n\t\t\tevent_root.getHead().remove();\n\t\t}\n\n\t\tif (buildLog)\n\t\t\tbuildLog.done();\n\n\t\treturn segments;\n\t}\n\n\t// return the appropriate API depending on what we're doing\n\tif (!selfIntersection){\n\t\t// performing combination of polygons, so only deal with already-processed segments\n\t\treturn {\n\t\t\tcalculate: function(segments1, inverted1, segments2, inverted2){\n\t\t\t\t// segmentsX come from the self-intersection API, or this API\n\t\t\t\t// invertedX is whether we treat that list of segments as an inverted polygon or not\n\t\t\t\t// returns segments that can be used for further operations\n\t\t\t\tsegments1.forEach(function(seg){\n\t\t\t\t\teventAddSegment(segmentCopy(seg.start, seg.end, seg), true);\n\t\t\t\t});\n\t\t\t\tsegments2.forEach(function(seg){\n\t\t\t\t\teventAddSegment(segmentCopy(seg.start, seg.end, seg), false);\n\t\t\t\t});\n\t\t\t\treturn calculate(inverted1, inverted2);\n\t\t\t}\n\t\t};\n\t}\n\n\t// otherwise, performing self-intersection, so deal with regions\n\treturn {\n\t\taddRegion: function(region){\n\t\t\t// regions are a list of points:\n\t\t\t// [ [0, 0], [100, 0], [50, 100] ]\n\t\t\t// you can add multiple regions before running calculate\n\t\t\tvar pt1;\n\t\t\tvar pt2 = region[region.length - 1];\n\t\t\tfor (var i = 0; i < region.length; i++){\n\t\t\t\tpt1 = pt2;\n\t\t\t\tpt2 = region[i];\n\n\t\t\t\tvar forward = eps.pointsCompare(pt1, pt2);\n\t\t\t\tif (forward === 0) // points are equal, so we have a zero-length segment\n\t\t\t\t\tcontinue; // just skip it\n\n\t\t\t\teventAddSegment(\n\t\t\t\t\tsegmentNew(\n\t\t\t\t\t\tforward < 0 ? pt1 : pt2,\n\t\t\t\t\t\tforward < 0 ? pt2 : pt1\n\t\t\t\t\t),\n\t\t\t\t\ttrue\n\t\t\t\t);\n\t\t\t}\n\t\t},\n\t\tcalculate: function(inverted){\n\t\t\t// is the polygon inverted?\n\t\t\t// returns segments\n\t\t\treturn calculate(inverted, false);\n\t\t}\n\t};\n}\n\nmodule.exports = Intersecter;\n","// (c) Copyright 2016, Sean Connelly (@voidqk), http://syntheti.cc\n// MIT License\n// Project Home: https://github.com/voidqk/polybooljs\n\n//\n// simple linked list implementation that allows you to traverse down nodes and save positions\n//\n\nvar LinkedList = {\n\tcreate: function(){\n\t\tvar my = {\n\t\t\troot: { root: true, next: null },\n\t\t\texists: function(node){\n\t\t\t\tif (node === null || node === my.root)\n\t\t\t\t\treturn false;\n\t\t\t\treturn true;\n\t\t\t},\n\t\t\tisEmpty: function(){\n\t\t\t\treturn my.root.next === null;\n\t\t\t},\n\t\t\tgetHead: function(){\n\t\t\t\treturn my.root.next;\n\t\t\t},\n\t\t\tinsertBefore: function(node, check){\n\t\t\t\tvar last = my.root;\n\t\t\t\tvar here = my.root.next;\n\t\t\t\twhile (here !== null){\n\t\t\t\t\tif (check(here)){\n\t\t\t\t\t\tnode.prev = here.prev;\n\t\t\t\t\t\tnode.next = here;\n\t\t\t\t\t\there.prev.next = node;\n\t\t\t\t\t\there.prev = node;\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t\tlast = here;\n\t\t\t\t\there = here.next;\n\t\t\t\t}\n\t\t\t\tlast.next = node;\n\t\t\t\tnode.prev = last;\n\t\t\t\tnode.next = null;\n\t\t\t},\n\t\t\tfindTransition: function(check){\n\t\t\t\tvar prev = my.root;\n\t\t\t\tvar here = my.root.next;\n\t\t\t\twhile (here !== null){\n\t\t\t\t\tif (check(here))\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tprev = here;\n\t\t\t\t\there = here.next;\n\t\t\t\t}\n\t\t\t\treturn {\n\t\t\t\t\tbefore: prev === my.root ? null : prev,\n\t\t\t\t\tafter: here,\n\t\t\t\t\tinsert: function(node){\n\t\t\t\t\t\tnode.prev = prev;\n\t\t\t\t\t\tnode.next = here;\n\t\t\t\t\t\tprev.next = node;\n\t\t\t\t\t\tif (here !== null)\n\t\t\t\t\t\t\there.prev = node;\n\t\t\t\t\t\treturn node;\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t}\n\t\t};\n\t\treturn my;\n\t},\n\tnode: function(data){\n\t\tdata.prev = null;\n\t\tdata.next = null;\n\t\tdata.remove = function(){\n\t\t\tdata.prev.next = data.next;\n\t\t\tif (data.next)\n\t\t\t\tdata.next.prev = data.prev;\n\t\t\tdata.prev = null;\n\t\t\tdata.next = null;\n\t\t};\n\t\treturn data;\n\t}\n};\n\nmodule.exports = LinkedList;\n","// (c) Copyright 2016, Sean Connelly (@voidqk), http://syntheti.cc\n// MIT License\n// Project Home: https://github.com/voidqk/polybooljs\n\n//\n// converts a list of segments into a list of regions, while also removing unnecessary verticies\n//\n\nfunction SegmentChainer(segments, eps, buildLog){\n\tvar chains = [];\n\tvar regions = [];\n\n\tsegments.forEach(function(seg){\n\t\tvar pt1 = seg.start;\n\t\tvar pt2 = seg.end;\n\t\tif (eps.pointsSame(pt1, pt2)){\n\t\t\tconsole.warn('PolyBool: Warning: Zero-length segment detected; your epsilon is ' +\n\t\t\t\t'probably too small or too large');\n\t\t\treturn;\n\t\t}\n\n\t\tif (buildLog)\n\t\t\tbuildLog.chainStart(seg);\n\n\t\t// search for two chains that this segment matches\n\t\tvar first_match = {\n\t\t\tindex: 0,\n\t\t\tmatches_head: false,\n\t\t\tmatches_pt1: false\n\t\t};\n\t\tvar second_match = {\n\t\t\tindex: 0,\n\t\t\tmatches_head: false,\n\t\t\tmatches_pt1: false\n\t\t};\n\t\tvar next_match = first_match;\n\t\tfunction setMatch(index, matches_head, matches_pt1){\n\t\t\t// return true if we've matched twice\n\t\t\tnext_match.index = index;\n\t\t\tnext_match.matches_head = matches_head;\n\t\t\tnext_match.matches_pt1 = matches_pt1;\n\t\t\tif (next_match === first_match){\n\t\t\t\tnext_match = second_match;\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tnext_match = null;\n\t\t\treturn true; // we've matched twice, we're done here\n\t\t}\n\t\tfor (var i = 0; i < chains.length; i++){\n\t\t\tvar chain = chains[i];\n\t\t\tvar head = chain[0];\n\t\t\tvar head2 = chain[1];\n\t\t\tvar tail = chain[chain.length - 1];\n\t\t\tvar tail2 = chain[chain.length - 2];\n\t\t\tif (eps.pointsSame(head, pt1)){\n\t\t\t\tif (setMatch(i, true, true))\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t\telse if (eps.pointsSame(head, pt2)){\n\t\t\t\tif (setMatch(i, true, false))\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t\telse if (eps.pointsSame(tail, pt1)){\n\t\t\t\tif (setMatch(i, false, true))\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t\telse if (eps.pointsSame(tail, pt2)){\n\t\t\t\tif (setMatch(i, false, false))\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tif (next_match === first_match){\n\t\t\t// we didn't match anything, so create a new chain\n\t\t\tchains.push([ pt1, pt2 ]);\n\t\t\tif (buildLog)\n\t\t\t\tbuildLog.chainNew(pt1, pt2);\n\t\t\treturn;\n\t\t}\n\n\t\tif (next_match === second_match){\n\t\t\t// we matched a single chain\n\n\t\t\tif (buildLog)\n\t\t\t\tbuildLog.chainMatch(first_match.index);\n\n\t\t\t// add the other point to the apporpriate end, and check to see if we've closed the\n\t\t\t// chain into a loop\n\n\t\t\tvar index = first_match.index;\n\t\t\tvar pt = first_match.matches_pt1 ? pt2 : pt1; // if we matched pt1, then we add pt2, etc\n\t\t\tvar addToHead = first_match.matches_head; // if we matched at head, then add to the head\n\n\t\t\tvar chain = chains[index];\n\t\t\tvar grow = addToHead ? chain[0] : chain[chain.length - 1];\n\t\t\tvar grow2 = addToHead ? chain[1] : chain[chain.length - 2];\n\t\t\tvar oppo = addToHead ? chain[chain.length - 1] : chain[0];\n\t\t\tvar oppo2 = addToHead ? chain[chain.length - 2] : chain[1];\n\n\t\t\tif (eps.pointsCollinear(grow2, grow, pt)){\n\t\t\t\t// grow isn't needed because it's directly between grow2 and pt:\n\t\t\t\t// grow2 ---grow---> pt\n\t\t\t\tif (addToHead){\n\t\t\t\t\tif (buildLog)\n\t\t\t\t\t\tbuildLog.chainRemoveHead(first_match.index, pt);\n\t\t\t\t\tchain.shift();\n\t\t\t\t}\n\t\t\t\telse{\n\t\t\t\t\tif (buildLog)\n\t\t\t\t\t\tbuildLog.chainRemoveTail(first_match.index, pt);\n\t\t\t\t\tchain.pop();\n\t\t\t\t}\n\t\t\t\tgrow = grow2; // old grow is gone... new grow is what grow2 was\n\t\t\t}\n\n\t\t\tif (eps.pointsSame(oppo, pt)){\n\t\t\t\t// we're closing the loop, so remove chain from chains\n\t\t\t\tchains.splice(index, 1);\n\n\t\t\t\tif (eps.pointsCollinear(oppo2, oppo, grow)){\n\t\t\t\t\t// oppo isn't needed because it's directly between oppo2 and grow:\n\t\t\t\t\t// oppo2 ---oppo--->grow\n\t\t\t\t\tif (addToHead){\n\t\t\t\t\t\tif (buildLog)\n\t\t\t\t\t\t\tbuildLog.chainRemoveTail(first_match.index, grow);\n\t\t\t\t\t\tchain.pop();\n\t\t\t\t\t}\n\t\t\t\t\telse{\n\t\t\t\t\t\tif (buildLog)\n\t\t\t\t\t\t\tbuildLog.chainRemoveHead(first_match.index, grow);\n\t\t\t\t\t\tchain.shift();\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (buildLog)\n\t\t\t\t\tbuildLog.chainClose(first_match.index);\n\n\t\t\t\t// we have a closed chain!\n\t\t\t\tregions.push(chain);\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// not closing a loop, so just add it to the apporpriate side\n\t\t\tif (addToHead){\n\t\t\t\tif (buildLog)\n\t\t\t\t\tbuildLog.chainAddHead(first_match.index, pt);\n\t\t\t\tchain.unshift(pt);\n\t\t\t}\n\t\t\telse{\n\t\t\t\tif (buildLog)\n\t\t\t\t\tbuildLog.chainAddTail(first_match.index, pt);\n\t\t\t\tchain.push(pt);\n\t\t\t}\n\t\t\treturn;\n\t\t}\n\n\t\t// otherwise, we matched two chains, so we need to combine those chains together\n\n\t\tfunction reverseChain(index){\n\t\t\tif (buildLog)\n\t\t\t\tbuildLog.chainReverse(index);\n\t\t\tchains[index].reverse(); // gee, that's easy\n\t\t}\n\n\t\tfunction appendChain(index1, index2){\n\t\t\t// index1 gets index2 appended to it, and index2 is removed\n\t\t\tvar chain1 = chains[index1];\n\t\t\tvar chain2 = chains[index2];\n\t\t\tvar tail = chain1[chain1.length - 1];\n\t\t\tvar tail2 = chain1[chain1.length - 2];\n\t\t\tvar head = chain2[0];\n\t\t\tvar head2 = chain2[1];\n\n\t\t\tif (eps.pointsCollinear(tail2, tail, head)){\n\t\t\t\t// tail isn't needed because it's directly between tail2 and head\n\t\t\t\t// tail2 ---tail---> head\n\t\t\t\tif (buildLog)\n\t\t\t\t\tbuildLog.chainRemoveTail(index1, tail);\n\t\t\t\tchain1.pop();\n\t\t\t\ttail = tail2; // old tail is gone... new tail is what tail2 was\n\t\t\t}\n\n\t\t\tif (eps.pointsCollinear(tail, head, head2)){\n\t\t\t\t// head isn't needed because it's directly between tail and head2\n\t\t\t\t// tail ---head---> head2\n\t\t\t\tif (buildLog)\n\t\t\t\t\tbuildLog.chainRemoveHead(index2, head);\n\t\t\t\tchain2.shift();\n\t\t\t}\n\n\t\t\tif (buildLog)\n\t\t\t\tbuildLog.chainJoin(index1, index2);\n\t\t\tchains[index1] = chain1.concat(chain2);\n\t\t\tchains.splice(index2, 1);\n\t\t}\n\n\t\tvar F = first_match.index;\n\t\tvar S = second_match.index;\n\n\t\tif (buildLog)\n\t\t\tbuildLog.chainConnect(F, S);\n\n\t\tvar reverseF = chains[F].length < chains[S].length; // reverse the shorter chain, if needed\n\t\tif (first_match.matches_head){\n\t\t\tif (second_match.matches_head){\n\t\t\t\tif (reverseF){\n\t\t\t\t\t// <<<< F <<<< --- >>>> S >>>>\n\t\t\t\t\treverseChain(F);\n\t\t\t\t\t// >>>> F >>>> --- >>>> S >>>>\n\t\t\t\t\tappendChain(F, S);\n\t\t\t\t}\n\t\t\t\telse{\n\t\t\t\t\t// <<<< F <<<< --- >>>> S >>>>\n\t\t\t\t\treverseChain(S);\n\t\t\t\t\t// <<<< F <<<< --- <<<< S <<<< logically same as:\n\t\t\t\t\t// >>>> S >>>> --- >>>> F >>>>\n\t\t\t\t\tappendChain(S, F);\n\t\t\t\t}\n\t\t\t}\n\t\t\telse{\n\t\t\t\t// <<<< F <<<< --- <<<< S <<<< logically same as:\n\t\t\t\t// >>>> S >>>> --- >>>> F >>>>\n\t\t\t\tappendChain(S, F);\n\t\t\t}\n\t\t}\n\t\telse{\n\t\t\tif (second_match.matches_head){\n\t\t\t\t// >>>> F >>>> --- >>>> S >>>>\n\t\t\t\tappendChain(F, S);\n\t\t\t}\n\t\t\telse{\n\t\t\t\tif (reverseF){\n\t\t\t\t\t// >>>> F >>>> --- <<<< S <<<<\n\t\t\t\t\treverseChain(F);\n\t\t\t\t\t// <<<< F <<<< --- <<<< S <<<< logically same as:\n\t\t\t\t\t// >>>> S >>>> --- >>>> F >>>>\n\t\t\t\t\tappendChain(S, F);\n\t\t\t\t}\n\t\t\t\telse{\n\t\t\t\t\t// >>>> F >>>> --- <<<< S <<<<\n\t\t\t\t\treverseChain(S);\n\t\t\t\t\t// >>>> F >>>> --- >>>> S >>>>\n\t\t\t\t\tappendChain(F, S);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n\n\treturn regions;\n}\n\nmodule.exports = SegmentChainer;\n","// (c) Copyright 2016, Sean Connelly (@voidqk), http://syntheti.cc\n// MIT License\n// Project Home: https://github.com/voidqk/polybooljs\n\n//\n// filter a list of segments based on boolean operations\n//\n\nfunction select(segments, selection, buildLog){\n\tvar result = [];\n\tsegments.forEach(function(seg){\n\t\tvar index =\n\t\t\t(seg.myFill.above ? 8 : 0) +\n\t\t\t(seg.myFill.below ? 4 : 0) +\n\t\t\t((seg.otherFill && seg.otherFill.above) ? 2 : 0) +\n\t\t\t((seg.otherFill && seg.otherFill.below) ? 1 : 0);\n\t\tif (selection[index] !== 0){\n\t\t\t// copy the segment to the results, while also calculating the fill status\n\t\t\tresult.push({\n\t\t\t\tid: buildLog ? buildLog.segmentId() : -1,\n\t\t\t\tstart: seg.start,\n\t\t\t\tend: seg.end,\n\t\t\t\tmyFill: {\n\t\t\t\t\tabove: selection[index] === 1, // 1 if filled above\n\t\t\t\t\tbelow: selection[index] === 2 // 2 if filled below\n\t\t\t\t},\n\t\t\t\totherFill: null\n\t\t\t});\n\t\t}\n\t});\n\n\tif (buildLog)\n\t\tbuildLog.selected(result);\n\n\treturn result;\n}\n\nvar SegmentSelector = {\n\tunion: function(segments, buildLog){ // primary | secondary\n\t\t// above1 below1 above2 below2 Keep? Value\n\t\t// 0 0 0 0 => no 0\n\t\t// 0 0 0 1 => yes filled below 2\n\t\t// 0 0 1 0 => yes filled above 1\n\t\t// 0 0 1 1 => no 0\n\t\t// 0 1 0 0 => yes filled below 2\n\t\t// 0 1 0 1 => yes filled below 2\n\t\t// 0 1 1 0 => no 0\n\t\t// 0 1 1 1 => no 0\n\t\t// 1 0 0 0 => yes filled above 1\n\t\t// 1 0 0 1 => no 0\n\t\t// 1 0 1 0 => yes filled above 1\n\t\t// 1 0 1 1 => no 0\n\t\t// 1 1 0 0 => no 0\n\t\t// 1 1 0 1 => no 0\n\t\t// 1 1 1 0 => no 0\n\t\t// 1 1 1 1 => no 0\n\t\treturn select(segments, [\n\t\t\t0, 2, 1, 0,\n\t\t\t2, 2, 0, 0,\n\t\t\t1, 0, 1, 0,\n\t\t\t0, 0, 0, 0\n\t\t], buildLog);\n\t},\n\tintersect: function(segments, buildLog){ // primary & secondary\n\t\t// above1 below1 above2 below2 Keep? Value\n\t\t// 0 0 0 0 => no 0\n\t\t// 0 0 0 1 => no 0\n\t\t// 0 0 1 0 => no 0\n\t\t// 0 0 1 1 => no 0\n\t\t// 0 1 0 0 => no 0\n\t\t// 0 1 0 1 => yes filled below 2\n\t\t// 0 1 1 0 => no 0\n\t\t// 0 1 1 1 => yes filled below 2\n\t\t// 1 0 0 0 => no 0\n\t\t// 1 0 0 1 => no 0\n\t\t// 1 0 1 0 => yes filled above 1\n\t\t// 1 0 1 1 => yes filled above 1\n\t\t// 1 1 0 0 => no 0\n\t\t// 1 1 0 1 => yes filled below 2\n\t\t// 1 1 1 0 => yes filled above 1\n\t\t// 1 1 1 1 => no 0\n\t\treturn select(segments, [\n\t\t\t0, 0, 0, 0,\n\t\t\t0, 2, 0, 2,\n\t\t\t0, 0, 1, 1,\n\t\t\t0, 2, 1, 0\n\t\t], buildLog);\n\t},\n\tdifference: function(segments, buildLog){ // primary - secondary\n\t\t// above1 below1 above2 below2 Keep? Value\n\t\t// 0 0 0 0 => no 0\n\t\t// 0 0 0 1 => no 0\n\t\t// 0 0 1 0 => no 0\n\t\t// 0 0 1 1 => no 0\n\t\t// 0 1 0 0 => yes filled below 2\n\t\t// 0 1 0 1 => no 0\n\t\t// 0 1 1 0 => yes filled below 2\n\t\t// 0 1 1 1 => no 0\n\t\t// 1 0 0 0 => yes filled above 1\n\t\t// 1 0 0 1 => yes filled above 1\n\t\t// 1 0 1 0 => no 0\n\t\t// 1 0 1 1 => no 0\n\t\t// 1 1 0 0 => no 0\n\t\t// 1 1 0 1 => yes filled above 1\n\t\t// 1 1 1 0 => yes filled below 2\n\t\t// 1 1 1 1 => no 0\n\t\treturn select(segments, [\n\t\t\t0, 0, 0, 0,\n\t\t\t2, 0, 2, 0,\n\t\t\t1, 1, 0, 0,\n\t\t\t0, 1, 2, 0\n\t\t], buildLog);\n\t},\n\tdifferenceRev: function(segments, buildLog){ // secondary - primary\n\t\t// above1 below1 above2 below2 Keep? Value\n\t\t// 0 0 0 0 => no 0\n\t\t// 0 0 0 1 => yes filled below 2\n\t\t// 0 0 1 0 => yes filled above 1\n\t\t// 0 0 1 1 => no 0\n\t\t// 0 1 0 0 => no 0\n\t\t// 0 1 0 1 => no 0\n\t\t// 0 1 1 0 => yes filled above 1\n\t\t// 0 1 1 1 => yes filled above 1\n\t\t// 1 0 0 0 => no 0\n\t\t// 1 0 0 1 => yes filled below 2\n\t\t// 1 0 1 0 => no 0\n\t\t// 1 0 1 1 => yes filled below 2\n\t\t// 1 1 0 0 => no 0\n\t\t// 1 1 0 1 => no 0\n\t\t// 1 1 1 0 => no 0\n\t\t// 1 1 1 1 => no 0\n\t\treturn select(segments, [\n\t\t\t0, 2, 1, 0,\n\t\t\t0, 0, 1, 1,\n\t\t\t0, 2, 0, 2,\n\t\t\t0, 0, 0, 0\n\t\t], buildLog);\n\t},\n\txor: function(segments, buildLog){ // primary ^ secondary\n\t\t// above1 below1 above2 below2 Keep? Value\n\t\t// 0 0 0 0 => no 0\n\t\t// 0 0 0 1 => yes filled below 2\n\t\t// 0 0 1 0 => yes filled above 1\n\t\t// 0 0 1 1 => no 0\n\t\t// 0 1 0 0 => yes filled below 2\n\t\t// 0 1 0 1 => no 0\n\t\t// 0 1 1 0 => no 0\n\t\t// 0 1 1 1 => yes filled above 1\n\t\t// 1 0 0 0 => yes filled above 1\n\t\t// 1 0 0 1 => no 0\n\t\t// 1 0 1 0 => no 0\n\t\t// 1 0 1 1 => yes filled below 2\n\t\t// 1 1 0 0 => no 0\n\t\t// 1 1 0 1 => yes filled above 1\n\t\t// 1 1 1 0 => yes filled below 2\n\t\t// 1 1 1 1 => no 0\n\t\treturn select(segments, [\n\t\t\t0, 2, 1, 0,\n\t\t\t2, 0, 0, 1,\n\t\t\t1, 0, 0, 2,\n\t\t\t0, 1, 2, 0\n\t\t], buildLog);\n\t}\n};\n\nmodule.exports = SegmentSelector;\n","'use strict';\n\n/** @type {import('.')} */\nmodule.exports = [\n\t'Float32Array',\n\t'Float64Array',\n\t'Int8Array',\n\t'Int16Array',\n\t'Int32Array',\n\t'Uint8Array',\n\t'Uint8ClampedArray',\n\t'Uint16Array',\n\t'Uint32Array',\n\t'BigInt64Array',\n\t'BigUint64Array'\n];\n","'use strict';\n\n\nvar Transform = require('stream').Transform;\nvar streamParser = require('stream-parser');\n\n\nfunction ParserStream() {\n Transform.call(this, { readableObjectMode: true });\n}\n\n// Inherit from Transform\nParserStream.prototype = Object.create(Transform.prototype);\nParserStream.prototype.constructor = ParserStream;\n\nstreamParser(ParserStream.prototype);\n\n\nexports.ParserStream = ParserStream;\n\n\nexports.sliceEq = function (src, start, dest) {\n for (var i = start, j = 0; j < dest.length;) {\n if (src[i++] !== dest[j++]) return false;\n }\n return true;\n};\n\nexports.str2arr = function (str, format) {\n var arr = [], i = 0;\n\n if (format && format === 'hex') {\n while (i < str.length) {\n arr.push(parseInt(str.slice(i, i + 2), 16));\n i += 2;\n }\n } else {\n for (; i < str.length; i++) {\n /* eslint-disable no-bitwise */\n arr.push(str.charCodeAt(i) & 0xFF);\n }\n }\n\n return arr;\n};\n\nexports.readUInt16LE = function (data, offset) {\n return data[offset] | (data[offset + 1] << 8);\n};\n\nexports.readUInt16BE = function (data, offset) {\n return data[offset + 1] | (data[offset] << 8);\n};\n\nexports.readUInt32LE = function (data, offset) {\n return data[offset] |\n (data[offset + 1] << 8) |\n (data[offset + 2] << 16) |\n (data[offset + 3] * 0x1000000);\n};\n\nexports.readUInt32BE = function (data, offset) {\n return data[offset + 3] |\n (data[offset + 2] << 8) |\n (data[offset + 1] << 16) |\n (data[offset] * 0x1000000);\n};\n\n\nfunction ProbeError(message, code, statusCode) {\n Error.call(this);\n\n // Include stack trace in error object\n if (Error.captureStackTrace) {\n // Chrome and NodeJS\n Error.captureStackTrace(this, this.constructor);\n } else {\n // FF, IE 10+ and Safari 6+. Fallback for others\n this.stack = (new Error()).stack || '';\n }\n\n this.name = this.constructor.name;\n\n this.message = message;\n if (code) this.code = code;\n if (statusCode) this.statusCode = statusCode;\n}\n\n// Inherit from Error\nProbeError.prototype = Object.create(Error.prototype);\nProbeError.prototype.constructor = ProbeError;\n\n\nexports.ProbeError = ProbeError;\n","\n/* eslint-disable no-bitwise */\n/* eslint-disable consistent-return */\n\n'use strict';\n\n//////////////////////////////////////////////////////////////////////////\n// Helpers\n//\nfunction error(message, code) {\n var err = new Error(message);\n err.code = code;\n return err;\n}\n\n\nfunction utf8_decode(str) {\n try {\n return decodeURIComponent(escape(str));\n } catch (_) {\n return str;\n }\n}\n\n\n//////////////////////////////////////////////////////////////////////////\n// Exif parser\n//\n// Input:\n// - jpeg_bin: Uint8Array - jpeg file\n// - exif_start: Number - start of TIFF header (after Exif\\0\\0)\n// - exif_end: Number - end of Exif segment\n// - on_entry: Number - callback\n//\nfunction ExifParser(jpeg_bin, exif_start, exif_end) {\n // Uint8Array, exif without signature (which isn't included in offsets)\n this.input = jpeg_bin.subarray(exif_start, exif_end);\n\n // offset correction for `on_entry` callback\n this.start = exif_start;\n\n // Check TIFF header (includes byte alignment and first IFD offset)\n var sig = String.fromCharCode.apply(null, this.input.subarray(0, 4));\n\n if (sig !== 'II\\x2A\\0' && sig !== 'MM\\0\\x2A') {\n throw error('invalid TIFF signature', 'EBADDATA');\n }\n\n // true if motorola (big endian) byte alignment, false if intel\n this.big_endian = sig[0] === 'M';\n}\n\n\nExifParser.prototype.each = function (on_entry) {\n // allow premature exit\n this.aborted = false;\n\n var offset = this.read_uint32(4);\n\n this.ifds_to_read = [ {\n id: 0,\n offset: offset\n } ];\n\n while (this.ifds_to_read.length > 0 && !this.aborted) {\n var i = this.ifds_to_read.shift();\n if (!i.offset) continue;\n this.scan_ifd(i.id, i.offset, on_entry);\n }\n};\n\n\nExifParser.prototype.read_uint16 = function (offset) {\n var d = this.input;\n if (offset + 2 > d.length) throw error('unexpected EOF', 'EBADDATA');\n\n return this.big_endian ?\n d[offset] * 0x100 + d[offset + 1] :\n d[offset] + d[offset + 1] * 0x100;\n};\n\n\nExifParser.prototype.read_uint32 = function (offset) {\n var d = this.input;\n if (offset + 4 > d.length) throw error('unexpected EOF', 'EBADDATA');\n\n return this.big_endian ?\n d[offset] * 0x1000000 + d[offset + 1] * 0x10000 + d[offset + 2] * 0x100 + d[offset + 3] :\n d[offset] + d[offset + 1] * 0x100 + d[offset + 2] * 0x10000 + d[offset + 3] * 0x1000000;\n};\n\n\nExifParser.prototype.is_subifd_link = function (ifd, tag) {\n return (ifd === 0 && tag === 0x8769) || // SubIFD\n (ifd === 0 && tag === 0x8825) || // GPS Info\n (ifd === 0x8769 && tag === 0xA005); // Interop IFD\n};\n\n\n// Returns byte length of a single component of a given format\n//\nExifParser.prototype.exif_format_length = function (format) {\n switch (format) {\n case 1: // byte\n case 2: // ascii\n case 6: // sbyte\n case 7: // undefined\n return 1;\n\n case 3: // short\n case 8: // sshort\n return 2;\n\n case 4: // long\n case 9: // slong\n case 11: // float\n return 4;\n\n case 5: // rational\n case 10: // srational\n case 12: // double\n return 8;\n\n default:\n // unknown type\n return 0;\n }\n};\n\n\n// Reads Exif data\n//\nExifParser.prototype.exif_format_read = function (format, offset) {\n var v;\n\n switch (format) {\n case 1: // byte\n case 2: // ascii\n v = this.input[offset];\n return v;\n\n case 6: // sbyte\n v = this.input[offset];\n return v | (v & 0x80) * 0x1fffffe;\n\n case 3: // short\n v = this.read_uint16(offset);\n return v;\n\n case 8: // sshort\n v = this.read_uint16(offset);\n return v | (v & 0x8000) * 0x1fffe;\n\n case 4: // long\n v = this.read_uint32(offset);\n return v;\n\n case 9: // slong\n v = this.read_uint32(offset);\n return v | 0;\n\n case 5: // rational\n case 10: // srational\n case 11: // float\n case 12: // double\n return null; // not implemented\n\n case 7: // undefined\n return null; // blob\n\n default:\n // unknown type\n return null;\n }\n};\n\n\nExifParser.prototype.scan_ifd = function (ifd_no, offset, on_entry) {\n var entry_count = this.read_uint16(offset);\n\n offset += 2;\n\n for (var i = 0; i < entry_count; i++) {\n var tag = this.read_uint16(offset);\n var format = this.read_uint16(offset + 2);\n var count = this.read_uint32(offset + 4);\n\n var comp_length = this.exif_format_length(format);\n var data_length = count * comp_length;\n var data_offset = data_length <= 4 ? offset + 8 : this.read_uint32(offset + 8);\n var is_subifd_link = false;\n\n if (data_offset + data_length > this.input.length) {\n throw error('unexpected EOF', 'EBADDATA');\n }\n\n var value = [];\n var comp_offset = data_offset;\n\n for (var j = 0; j < count; j++, comp_offset += comp_length) {\n var item = this.exif_format_read(format, comp_offset);\n if (item === null) {\n value = null;\n break;\n }\n value.push(item);\n }\n\n if (Array.isArray(value) && format === 2) {\n value = utf8_decode(String.fromCharCode.apply(null, value));\n if (value && value[value.length - 1] === '\\0') value = value.slice(0, -1);\n }\n\n if (this.is_subifd_link(ifd_no, tag)) {\n if (Array.isArray(value) && Number.isInteger(value[0]) && value[0] > 0) {\n this.ifds_to_read.push({\n id: tag,\n offset: value[0]\n });\n is_subifd_link = true;\n }\n }\n\n var entry = {\n is_big_endian: this.big_endian,\n ifd: ifd_no,\n tag: tag,\n format: format,\n count: count,\n entry_offset: offset + this.start,\n data_length: data_length,\n data_offset: data_offset + this.start,\n value: value,\n is_subifd_link: is_subifd_link\n };\n\n if (on_entry(entry) === false) {\n this.aborted = true;\n return;\n }\n\n offset += 12;\n }\n\n if (ifd_no === 0) {\n this.ifds_to_read.push({\n id: 1,\n offset: this.read_uint32(offset)\n });\n }\n};\n\n\nmodule.exports.ExifParser = ExifParser;\n\n// returns orientation stored in Exif (1-8), 0 if none was found, -1 if error\nmodule.exports.get_orientation = function (data) {\n var orientation = 0;\n try {\n new ExifParser(data, 0, data.length).each(function (entry) {\n if (entry.ifd === 0 && entry.tag === 0x112 && Array.isArray(entry.value)) {\n orientation = entry.value[0];\n return false;\n }\n });\n return orientation;\n } catch (err) {\n return -1;\n }\n};\n","// Utils used to parse miaf-based files (avif/heic/heif)\n//\n// ISO media file spec:\n// https://web.archive.org/web/20180219054429/http://l.web.umkc.edu/lizhu/teaching/2016sp.video-communication/ref/mp4.pdf\n//\n// ISO image file format spec:\n// https://standards.iso.org/ittf/PubliclyAvailableStandards/c066067_ISO_IEC_23008-12_2017.zip\n//\n\n'use strict';\n\n/* eslint-disable consistent-return */\n/* eslint-disable no-bitwise */\n\nvar readUInt16BE = require('./common').readUInt16BE;\nvar readUInt32BE = require('./common').readUInt32BE;\n\n/*\n * interface Box {\n * size: uint32; // if size == 0, box lasts until EOF\n * boxtype: char[4];\n * largesize?: uint64; // only if size == 1\n * usertype?: char[16]; // only if boxtype == 'uuid'\n * }\n */\nfunction unbox(data, offset) {\n if (data.length < 4 + offset) return null;\n\n var size = readUInt32BE(data, offset);\n\n // size includes first 4 bytes (length)\n if (data.length < size + offset || size < 8) return null;\n\n // if size === 1, real size is following uint64 (only for big boxes, not needed)\n // if size === 0, real size is until the end of the file (only for big boxes, not needed)\n\n return {\n boxtype: String.fromCharCode.apply(null, data.slice(offset + 4, offset + 8)),\n data: data.slice(offset + 8, offset + size),\n end: offset + size\n };\n}\n\n\nmodule.exports.unbox = unbox;\n\n\n// parses `meta` -> `iprp` -> `ipco` box, returns:\n// {\n// sizes: [ { width, height } ],\n// transforms: [ { type, value } ]\n// }\nfunction scan_ipco(data, sandbox) {\n var offset = 0;\n\n for (;;) {\n var box = unbox(data, offset);\n if (!box) break;\n\n switch (box.boxtype) {\n case 'ispe':\n sandbox.sizes.push({\n width: readUInt32BE(box.data, 4),\n height: readUInt32BE(box.data, 8)\n });\n break;\n\n case 'irot':\n sandbox.transforms.push({\n type: 'irot',\n value: box.data[0] & 3\n });\n break;\n\n case 'imir':\n sandbox.transforms.push({\n type: 'imir',\n value: box.data[0] & 1\n });\n break;\n }\n\n offset = box.end;\n }\n}\n\n\nfunction readUIntBE(data, offset, size) {\n var result = 0;\n\n for (var i = 0; i < size; i++) {\n result = result * 256 + (data[offset + i] || 0);\n }\n\n return result;\n}\n\n\n// parses `meta` -> `iloc` box\nfunction scan_iloc(data, sandbox) {\n var offset_size = (data[4] >> 4) & 0xF;\n var length_size = data[4] & 0xF;\n var base_offset_size = (data[5] >> 4) & 0xF;\n var item_count = readUInt16BE(data, 6);\n var offset = 8;\n\n for (var i = 0; i < item_count; i++) {\n var item_ID = readUInt16BE(data, offset);\n offset += 2;\n\n var data_reference_index = readUInt16BE(data, offset);\n offset += 2;\n\n var base_offset = readUIntBE(data, offset, base_offset_size);\n offset += base_offset_size;\n\n var extent_count = readUInt16BE(data, offset);\n offset += 2;\n\n if (data_reference_index === 0 && extent_count === 1) {\n var first_extent_offset = readUIntBE(data, offset, offset_size);\n var first_extent_length = readUIntBE(data, offset + offset_size, length_size);\n sandbox.item_loc[item_ID] = { length: first_extent_length, offset: first_extent_offset + base_offset };\n }\n\n offset += extent_count * (offset_size + length_size);\n }\n}\n\n\n// parses `meta` -> `iinf` box\nfunction scan_iinf(data, sandbox) {\n var item_count = readUInt16BE(data, 4);\n var offset = 6;\n\n for (var i = 0; i < item_count; i++) {\n var box = unbox(data, offset);\n if (!box) break;\n if (box.boxtype === 'infe') {\n var item_id = readUInt16BE(box.data, 4);\n var item_name = '';\n\n for (var pos = 8; pos < box.data.length && box.data[pos]; pos++) {\n item_name += String.fromCharCode(box.data[pos]);\n }\n\n sandbox.item_inf[item_name] = item_id;\n }\n offset = box.end;\n }\n}\n\n\n// parses `meta` -> `iprp` box\nfunction scan_iprp(data, sandbox) {\n var offset = 0;\n\n for (;;) {\n var box = unbox(data, offset);\n if (!box) break;\n if (box.boxtype === 'ipco') scan_ipco(box.data, sandbox);\n offset = box.end;\n }\n}\n\n\n// parses `meta` box\nfunction scan_meta(data, sandbox) {\n var offset = 4; // version + flags\n\n for (;;) {\n var box = unbox(data, offset);\n if (!box) break;\n if (box.boxtype === 'iprp') scan_iprp(box.data, sandbox);\n if (box.boxtype === 'iloc') scan_iloc(box.data, sandbox);\n if (box.boxtype === 'iinf') scan_iinf(box.data, sandbox);\n offset = box.end;\n }\n}\n\n\n// get image with largest single dimension as base\nfunction getMaxSize(sizes) {\n var maxWidthSize = sizes.reduce(function (a, b) {\n return a.width > b.width || (a.width === b.width && a.height > b.height) ? a : b;\n });\n\n var maxHeightSize = sizes.reduce(function (a, b) {\n return a.height > b.height || (a.height === b.height && a.width > b.width) ? a : b;\n });\n\n var maxSize;\n\n if (maxWidthSize.width > maxHeightSize.height ||\n (maxWidthSize.width === maxHeightSize.height && maxWidthSize.height > maxHeightSize.width)) {\n maxSize = maxWidthSize;\n } else {\n maxSize = maxHeightSize;\n }\n\n return maxSize;\n}\n\n\nmodule.exports.readSizeFromMeta = function (data) {\n var sandbox = {\n sizes: [],\n transforms: [],\n item_inf: {},\n item_loc: {}\n };\n\n scan_meta(data, sandbox);\n\n if (!sandbox.sizes.length) return;\n\n var maxSize = getMaxSize(sandbox.sizes);\n\n var orientation = 1;\n\n // convert imir/irot to exif orientation\n sandbox.transforms.forEach(function (transform) {\n var rotate_ccw = { 1: 6, 2: 5, 3: 8, 4: 7, 5: 4, 6: 3, 7: 2, 8: 1 };\n var mirror_vert = { 1: 4, 2: 3, 3: 2, 4: 1, 5: 6, 6: 5, 7: 8, 8: 7 };\n\n if (transform.type === 'imir') {\n if (transform.value === 0) {\n // vertical flip\n orientation = mirror_vert[orientation];\n } else {\n // horizontal flip = vertical flip + 180 deg rotation\n orientation = mirror_vert[orientation];\n orientation = rotate_ccw[orientation];\n orientation = rotate_ccw[orientation];\n }\n }\n\n if (transform.type === 'irot') {\n // counter-clockwise rotation 90 deg 0-3 times\n for (var i = 0; i < transform.value; i++) {\n orientation = rotate_ccw[orientation];\n }\n }\n });\n\n var exif_location = null;\n\n if (sandbox.item_inf.Exif) {\n exif_location = sandbox.item_loc[sandbox.item_inf.Exif];\n }\n\n return {\n width: maxSize.width,\n height: maxSize.height,\n orientation: sandbox.transforms.length ? orientation : null,\n variants: sandbox.sizes,\n exif_location: exif_location\n };\n};\n\n\nmodule.exports.getMimeType = function (data) {\n var brand = String.fromCharCode.apply(null, data.slice(0, 4));\n var compat = {};\n\n compat[brand] = true;\n\n for (var i = 8; i < data.length; i += 4) {\n compat[String.fromCharCode.apply(null, data.slice(i, i + 4))] = true;\n }\n\n // heic and avif are superset of miaf, so they should all list mif1 as compatible\n if (!compat.mif1 && !compat.msf1 && !compat.miaf) return;\n\n if (brand === 'avif' || brand === 'avis' || brand === 'avio') {\n // `.avifs` and `image/avif-sequence` are removed from spec, all files have single type\n return { type: 'avif', mime: 'image/avif' };\n }\n\n // https://nokiatech.github.io/heif/technical.html\n if (brand === 'heic' || brand === 'heix') {\n return { type: 'heic', mime: 'image/heic' };\n }\n\n if (brand === 'hevc' || brand === 'hevx') {\n return { type: 'heic', mime: 'image/heic-sequence' };\n }\n\n if (compat.avif || compat.avis) {\n return { type: 'avif', mime: 'image/avif' };\n }\n\n if (compat.heic || compat.heix || compat.hevc || compat.hevx || compat.heis) {\n if (compat.msf1) {\n return { type: 'heif', mime: 'image/heif-sequence' };\n }\n return { type: 'heif', mime: 'image/heif' };\n }\n\n return { type: 'avif', mime: 'image/avif' };\n};\n","// Utils used to parse miaf-based files (avif/heic/heif)\n//\n// - image collections are not supported (only last size is reported)\n// - images with metadata encoded after image data are not supported\n// - images without any `ispe` box are not supported\n//\n\n/* eslint-disable consistent-return */\n\n'use strict';\n\n\nvar str2arr = require('../common').str2arr;\nvar sliceEq = require('../common').sliceEq;\nvar readUInt32BE = require('../common').readUInt32BE;\nvar miaf = require('../miaf_utils');\nvar exif = require('../exif_utils');\n\nvar SIG_FTYP = str2arr('ftyp');\n\n\nmodule.exports = function (data) {\n // ISO media file (avif format) starts with ftyp box:\n // 0000 0020 6674 7970 6176 6966\n // (length) f t y p a v i f\n //\n if (!sliceEq(data, 4, SIG_FTYP)) return;\n\n var firstBox = miaf.unbox(data, 0);\n if (!firstBox) return;\n\n var fileType = miaf.getMimeType(firstBox.data);\n if (!fileType) return;\n\n var meta, offset = firstBox.end;\n\n for (;;) {\n var box = miaf.unbox(data, offset);\n if (!box) break;\n offset = box.end;\n\n // mdat block SHOULD be last (but not strictly required),\n // so it's unlikely that metadata is after it\n if (box.boxtype === 'mdat') return;\n if (box.boxtype === 'meta') {\n meta = box.data;\n break;\n }\n }\n\n if (!meta) return;\n\n var imgSize = miaf.readSizeFromMeta(meta);\n\n if (!imgSize) return;\n\n var result = {\n width: imgSize.width,\n height: imgSize.height,\n type: fileType.type,\n mime: fileType.mime,\n wUnits: 'px',\n hUnits: 'px'\n };\n\n if (imgSize.variants.length > 1) {\n result.variants = imgSize.variants;\n }\n\n if (imgSize.orientation) {\n result.orientation = imgSize.orientation;\n }\n\n if (imgSize.exif_location &&\n imgSize.exif_location.offset + imgSize.exif_location.length <= data.length) {\n\n var sig_offset = readUInt32BE(data, imgSize.exif_location.offset);\n var exif_data = data.slice(\n imgSize.exif_location.offset + sig_offset + 4,\n imgSize.exif_location.offset + imgSize.exif_location.length);\n\n var orientation = exif.get_orientation(exif_data);\n\n if (orientation > 0) result.orientation = orientation;\n }\n\n return result;\n};\n","'use strict';\n\n/* eslint-disable consistent-return */\n\nvar str2arr = require('../common').str2arr;\nvar sliceEq = require('../common').sliceEq;\nvar readUInt16LE = require('../common').readUInt16LE;\n\nvar SIG_BM = str2arr('BM');\n\n\nmodule.exports = function (data) {\n if (data.length < 26) return;\n\n if (!sliceEq(data, 0, SIG_BM)) return;\n\n return {\n width: readUInt16LE(data, 18),\n height: readUInt16LE(data, 22),\n type: 'bmp',\n mime: 'image/bmp',\n wUnits: 'px',\n hUnits: 'px'\n };\n};\n","'use strict';\n\n/* eslint-disable consistent-return */\n\nvar str2arr = require('../common').str2arr;\nvar sliceEq = require('../common').sliceEq;\nvar readUInt16LE = require('../common').readUInt16LE;\n\n\nvar SIG_GIF87a = str2arr('GIF87a');\nvar SIG_GIF89a = str2arr('GIF89a');\n\n\nmodule.exports = function (data) {\n if (data.length < 10) return;\n\n if (!sliceEq(data, 0, SIG_GIF87a) && !sliceEq(data, 0, SIG_GIF89a)) return;\n\n return {\n width: readUInt16LE(data, 6),\n height: readUInt16LE(data, 8),\n type: 'gif',\n mime: 'image/gif',\n wUnits: 'px',\n hUnits: 'px'\n };\n};\n","'use strict';\n\n/* eslint-disable consistent-return */\n\nvar readUInt16LE = require('../common').readUInt16LE;\n\nvar HEADER = 0;\nvar TYPE_ICO = 1;\nvar INDEX_SIZE = 16;\n\n// Format specification:\n// https://en.wikipedia.org/wiki/ICO_(file_format)#Icon_resource_structure\nmodule.exports = function (data) {\n var header = readUInt16LE(data, 0);\n var type = readUInt16LE(data, 2);\n var numImages = readUInt16LE(data, 4);\n\n if (header !== HEADER || type !== TYPE_ICO || !numImages) {\n return;\n }\n\n var variants = [];\n var maxSize = { width: 0, height: 0 };\n\n for (var i = 0; i < numImages; i++) {\n var width = data[6 + INDEX_SIZE * i] || 256;\n var height = data[6 + INDEX_SIZE * i + 1] || 256;\n var size = { width: width, height: height };\n variants.push(size);\n\n if (width > maxSize.width || height > maxSize.height) {\n maxSize = size;\n }\n }\n\n return {\n width: maxSize.width,\n height: maxSize.height,\n variants: variants,\n type: 'ico',\n mime: 'image/x-icon',\n wUnits: 'px',\n hUnits: 'px'\n };\n};\n","'use strict';\n\n/* eslint-disable consistent-return */\n\nvar readUInt16BE = require('../common').readUInt16BE;\nvar str2arr = require('../common').str2arr;\nvar sliceEq = require('../common').sliceEq;\nvar exif = require('../exif_utils');\n\n\nvar SIG_EXIF = str2arr('Exif\\0\\0');\n\n\nmodule.exports = function (data) {\n if (data.length < 2) return;\n\n // first marker of the file MUST be 0xFFD8,\n // following by either 0xFFE0, 0xFFE2 or 0xFFE3\n if (data[0] !== 0xFF || data[1] !== 0xD8 || data[2] !== 0xFF) return;\n\n var offset = 2;\n\n for (;;) {\n // skip until we see 0xFF, see https://github.com/nodeca/probe-image-size/issues/68\n for (;;) {\n if (data.length - offset < 2) return;\n if (data[offset++] === 0xFF) break;\n }\n\n var code = data[offset++];\n var length;\n\n // skip padding bytes\n while (code === 0xFF) code = data[offset++];\n\n // standalone markers, according to JPEG 1992,\n // http://www.w3.org/Graphics/JPEG/itu-t81.pdf, see Table B.1\n if ((0xD0 <= code && code <= 0xD9) || code === 0x01) {\n length = 0;\n } else if (0xC0 <= code && code <= 0xFE) {\n // the rest of the unreserved markers\n if (data.length - offset < 2) return;\n\n length = readUInt16BE(data, offset) - 2;\n offset += 2;\n } else {\n // unknown markers\n return;\n }\n\n if (code === 0xD9 /* EOI */ || code === 0xDA /* SOS */) {\n // end of the datastream\n return;\n }\n\n var orientation;\n\n // try to get orientation from Exif segment\n if (code === 0xE1 && length >= 10 && sliceEq(data, offset, SIG_EXIF)) {\n orientation = exif.get_orientation(data.slice(offset + 6, offset + length));\n }\n\n if (length >= 5 &&\n (0xC0 <= code && code <= 0xCF) &&\n code !== 0xC4 && code !== 0xC8 && code !== 0xCC) {\n\n if (data.length - offset < length) return;\n\n var result = {\n width: readUInt16BE(data, offset + 3),\n height: readUInt16BE(data, offset + 1),\n type: 'jpg',\n mime: 'image/jpeg',\n wUnits: 'px',\n hUnits: 'px'\n };\n\n if (orientation > 0) {\n result.orientation = orientation;\n }\n\n return result;\n }\n\n offset += length;\n }\n};\n","'use strict';\n\n/* eslint-disable consistent-return */\n\nvar str2arr = require('../common').str2arr;\nvar sliceEq = require('../common').sliceEq;\nvar readUInt32BE = require('../common').readUInt32BE;\n\n\nvar SIG_PNG = str2arr('\\x89PNG\\r\\n\\x1a\\n');\nvar SIG_IHDR = str2arr('IHDR');\n\n\nmodule.exports = function (data) {\n if (data.length < 24) return;\n\n // check PNG signature\n if (!sliceEq(data, 0, SIG_PNG)) return;\n\n // check that first chunk is IHDR\n if (!sliceEq(data, 12, SIG_IHDR)) return;\n\n return {\n width: readUInt32BE(data, 16),\n height: readUInt32BE(data, 20),\n type: 'png',\n mime: 'image/png',\n wUnits: 'px',\n hUnits: 'px'\n };\n};\n","'use strict';\n\n/* eslint-disable consistent-return */\n\nvar str2arr = require('../common').str2arr;\nvar sliceEq = require('../common').sliceEq;\nvar readUInt32BE = require('../common').readUInt32BE;\n\n\nvar SIG_8BPS = str2arr('8BPS\\x00\\x01');\n\n\nmodule.exports = function (data) {\n if (data.length < 6 + 16) return;\n\n // signature + version\n if (!sliceEq(data, 0, SIG_8BPS)) return;\n\n return {\n width: readUInt32BE(data, 6 + 12),\n height: readUInt32BE(data, 6 + 8),\n type: 'psd',\n mime: 'image/vnd.adobe.photoshop',\n wUnits: 'px',\n hUnits: 'px'\n };\n};\n","'use strict';\n\n/* eslint-disable consistent-return */\n\nfunction isWhiteSpace(chr) {\n return chr === 0x20 || chr === 0x09 || chr === 0x0D || chr === 0x0A;\n}\n\n// Filter NaN, Infinity, < 0\nfunction isFinitePositive(val) {\n return typeof val === 'number' && isFinite(val) && val > 0;\n}\n\nfunction canBeSvg(buf) {\n var i = 0, max = buf.length;\n\n // byte order mark, https://github.com/nodeca/probe-image-size/issues/57\n if (buf[0] === 0xEF && buf[1] === 0xBB && buf[2] === 0xBF) i = 3;\n\n while (i < max && isWhiteSpace(buf[i])) i++;\n\n if (i === max) return false;\n return buf[i] === 0x3c; /* < */\n}\n\n\n// skip `` or ``\nvar SVG_HEADER_RE = /<[-_.:a-zA-Z0-9][^>]*>/;\n\n// test if the top level element is svg + optional namespace,\n// used to skip svg embedded in html\nvar SVG_TAG_RE = /^<([-_.:a-zA-Z0-9]+:)?svg\\s/;\n\nvar SVG_WIDTH_RE = /[^-]\\bwidth=\"([^%]+?)\"|[^-]\\bwidth='([^%]+?)'/;\nvar SVG_HEIGHT_RE = /\\bheight=\"([^%]+?)\"|\\bheight='([^%]+?)'/;\nvar SVG_VIEWBOX_RE = /\\bview[bB]ox=\"(.+?)\"|\\bview[bB]ox='(.+?)'/;\nvar SVG_UNITS_RE = /in$|mm$|cm$|pt$|pc$|px$|em$|ex$/;\n\nfunction svgAttrs(str) {\n var width = str.match(SVG_WIDTH_RE);\n var height = str.match(SVG_HEIGHT_RE);\n var viewbox = str.match(SVG_VIEWBOX_RE);\n\n return {\n width: width && (width[1] || width[2]),\n height: height && (height[1] || height[2]),\n viewbox: viewbox && (viewbox[1] || viewbox[2])\n };\n}\n\n\nfunction units(str) {\n if (!SVG_UNITS_RE.test(str)) return 'px';\n\n return str.match(SVG_UNITS_RE)[0];\n}\n\n\nmodule.exports = function (data) {\n if (!canBeSvg(data)) return;\n\n var str = '';\n\n for (var i = 0; i < data.length; i++) {\n // 1. We can't rely on buffer features\n // 2. Don't care about UTF16 because ascii is enougth for our goals\n str += String.fromCharCode(data[i]);\n }\n\n // get top level element\n var svgTag = (str.match(SVG_HEADER_RE) || [ '' ])[0];\n\n // test if top level element is \n if (!SVG_TAG_RE.test(svgTag)) return;\n\n var attrs = svgAttrs(svgTag);\n var width = parseFloat(attrs.width);\n var height = parseFloat(attrs.height);\n\n // Extract from direct values\n\n if (attrs.width && attrs.height) {\n if (!isFinitePositive(width) || !isFinitePositive(height)) return;\n\n return {\n width: width,\n height: height,\n type: 'svg',\n mime: 'image/svg+xml',\n wUnits: units(attrs.width),\n hUnits: units(attrs.height)\n };\n }\n\n // Extract from viewbox\n\n var parts = (attrs.viewbox || '').split(' ');\n var viewbox = {\n width: parts[2],\n height: parts[3]\n };\n var vbWidth = parseFloat(viewbox.width);\n var vbHeight = parseFloat(viewbox.height);\n\n if (!isFinitePositive(vbWidth) || !isFinitePositive(vbHeight)) return;\n if (units(viewbox.width) !== units(viewbox.height)) return;\n\n var ratio = vbWidth / vbHeight;\n\n if (attrs.width) {\n if (!isFinitePositive(width)) return;\n\n return {\n width: width,\n height: width / ratio,\n type: 'svg',\n mime: 'image/svg+xml',\n wUnits: units(attrs.width),\n hUnits: units(attrs.width)\n };\n }\n\n if (attrs.height) {\n if (!isFinitePositive(height)) return;\n\n return {\n width: height * ratio,\n height: height,\n type: 'svg',\n mime: 'image/svg+xml',\n wUnits: units(attrs.height),\n hUnits: units(attrs.height)\n };\n }\n\n return {\n width: vbWidth,\n height: vbHeight,\n type: 'svg',\n mime: 'image/svg+xml',\n wUnits: units(viewbox.width),\n hUnits: units(viewbox.height)\n };\n};\n","'use strict';\n\n/* eslint-disable consistent-return */\n\nvar str2arr = require('../common').str2arr;\nvar sliceEq = require('../common').sliceEq;\nvar readUInt16LE = require('../common').readUInt16LE;\nvar readUInt16BE = require('../common').readUInt16BE;\nvar readUInt32LE = require('../common').readUInt32LE;\nvar readUInt32BE = require('../common').readUInt32BE;\n\n\nvar SIG_1 = str2arr('II\\x2A\\0');\nvar SIG_2 = str2arr('MM\\0\\x2A');\n\n\nfunction readUInt16(buffer, offset, is_big_endian) {\n return is_big_endian ? readUInt16BE(buffer, offset) : readUInt16LE(buffer, offset);\n}\n\nfunction readUInt32(buffer, offset, is_big_endian) {\n return is_big_endian ? readUInt32BE(buffer, offset) : readUInt32LE(buffer, offset);\n}\n\nfunction readIFDValue(data, data_offset, is_big_endian) {\n var type = readUInt16(data, data_offset + 2, is_big_endian);\n var values = readUInt32(data, data_offset + 4, is_big_endian);\n\n if (values !== 1 || (type !== 3 && type !== 4)) return null;\n\n if (type === 3) {\n return readUInt16(data, data_offset + 8, is_big_endian);\n }\n\n return readUInt32(data, data_offset + 8, is_big_endian);\n}\n\nmodule.exports = function (data) {\n if (data.length < 8) return;\n\n // check TIFF signature\n if (!sliceEq(data, 0, SIG_1) && !sliceEq(data, 0, SIG_2)) return;\n\n var is_big_endian = (data[0] === 77 /* 'MM' */);\n var count = readUInt32(data, 4, is_big_endian) - 8;\n\n if (count < 0) return;\n\n // skip until IFD\n var offset = count + 8;\n\n if (data.length - offset < 2) return;\n\n // read number of IFD entries\n var ifd_size = readUInt16(data, offset + 0, is_big_endian) * 12;\n\n if (ifd_size <= 0) return;\n\n offset += 2;\n\n // read all IFD entries\n if (data.length - offset < ifd_size) return;\n\n var i, width, height, tag;\n\n for (i = 0; i < ifd_size; i += 12) {\n tag = readUInt16(data, offset + i, is_big_endian);\n\n if (tag === 256) {\n width = readIFDValue(data, offset + i, is_big_endian);\n } else if (tag === 257) {\n height = readIFDValue(data, offset + i, is_big_endian);\n }\n }\n\n if (width && height) {\n return {\n width: width,\n height: height,\n type: 'tiff',\n mime: 'image/tiff',\n wUnits: 'px',\n hUnits: 'px'\n };\n }\n};\n","'use strict';\n\n/* eslint-disable no-bitwise */\n/* eslint-disable consistent-return */\n\nvar str2arr = require('../common').str2arr;\nvar sliceEq = require('../common').sliceEq;\nvar readUInt16LE = require('../common').readUInt16LE;\nvar readUInt32LE = require('../common').readUInt32LE;\nvar exif = require('../exif_utils');\n\n\nvar SIG_RIFF = str2arr('RIFF');\nvar SIG_WEBP = str2arr('WEBP');\n\n\nfunction parseVP8(data, offset) {\n if (data[offset + 3] !== 0x9D || data[offset + 4] !== 0x01 || data[offset + 5] !== 0x2A) {\n // bad code block signature\n return;\n }\n\n return {\n width: readUInt16LE(data, offset + 6) & 0x3FFF,\n height: readUInt16LE(data, offset + 8) & 0x3FFF,\n type: 'webp',\n mime: 'image/webp',\n wUnits: 'px',\n hUnits: 'px'\n };\n}\n\n\nfunction parseVP8L(data, offset) {\n if (data[offset] !== 0x2F) return;\n\n var bits = readUInt32LE(data, offset + 1);\n\n return {\n width: (bits & 0x3FFF) + 1,\n height: ((bits >> 14) & 0x3FFF) + 1,\n type: 'webp',\n mime: 'image/webp',\n wUnits: 'px',\n hUnits: 'px'\n };\n}\n\n\nfunction parseVP8X(data, offset) {\n return {\n // TODO: replace with `data.readUIntLE(8, 3) + 1`\n // when 0.10 support is dropped\n width: ((data[offset + 6] << 16) | (data[offset + 5] << 8) | data[offset + 4]) + 1,\n height: ((data[offset + 9] << offset) | (data[offset + 8] << 8) | data[offset + 7]) + 1,\n type: 'webp',\n mime: 'image/webp',\n wUnits: 'px',\n hUnits: 'px'\n };\n}\n\n\nmodule.exports = function (data) {\n if (data.length < 16) return;\n\n // check /^RIFF....WEBPVP8([ LX])$/ signature\n if (!sliceEq(data, 0, SIG_RIFF) && !sliceEq(data, 8, SIG_WEBP)) return;\n\n var offset = 12;\n var result = null;\n var exif_orientation = 0;\n var fileLength = readUInt32LE(data, 4) + 8;\n\n if (fileLength > data.length) return;\n\n while (offset + 8 < fileLength) {\n if (data[offset] === 0) {\n // after each chunk of odd size there should be 0 byte of padding, skip those\n offset++;\n continue;\n }\n\n var header = String.fromCharCode.apply(null, data.slice(offset, offset + 4));\n var length = readUInt32LE(data, offset + 4);\n\n if (header === 'VP8 ' && length >= 10) {\n result = result || parseVP8(data, offset + 8);\n } else if (header === 'VP8L' && length >= 9) {\n result = result || parseVP8L(data, offset + 8);\n } else if (header === 'VP8X' && length >= 10) {\n result = result || parseVP8X(data, offset + 8);\n } else if (header === 'EXIF') {\n exif_orientation = exif.get_orientation(data.slice(offset + 8, offset + 8 + length));\n\n // exif is the last chunk we care about, stop after it\n offset = Infinity;\n }\n\n offset += 8 + length;\n }\n\n if (!result) return;\n\n if (exif_orientation > 0) {\n result.orientation = exif_orientation;\n }\n\n return result;\n};\n","'use strict';\n\n\nmodule.exports = {\n avif: require('./parse_sync/avif'),\n bmp: require('./parse_sync/bmp'),\n gif: require('./parse_sync/gif'),\n ico: require('./parse_sync/ico'),\n jpeg: require('./parse_sync/jpeg'),\n png: require('./parse_sync/png'),\n psd: require('./parse_sync/psd'),\n svg: require('./parse_sync/svg'),\n tiff: require('./parse_sync/tiff'),\n webp: require('./parse_sync/webp')\n};\n","'use strict';\n\n\nvar parsers = require('./lib/parsers_sync');\n\n\nfunction probeBuffer(buffer) {\n var parser_names = Object.keys(parsers);\n\n for (var i = 0; i < parser_names.length; i++) {\n var result = parsers[parser_names[i]](buffer);\n\n if (result) return result;\n }\n\n return null;\n}\n\n\n///////////////////////////////////////////////////////////////////////\n// Exports\n//\n\nmodule.exports = function get_image_size(src) {\n return probeBuffer(src);\n};\n\nmodule.exports.parsers = parsers;\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bigint: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","'use strict';\n\nvar replace = String.prototype.replace;\nvar percentTwenties = /%20/g;\n\nvar Format = {\n RFC1738: 'RFC1738',\n RFC3986: 'RFC3986'\n};\n\nmodule.exports = {\n 'default': Format.RFC3986,\n formatters: {\n RFC1738: function (value) {\n return replace.call(value, percentTwenties, '+');\n },\n RFC3986: function (value) {\n return String(value);\n }\n },\n RFC1738: Format.RFC1738,\n RFC3986: Format.RFC3986\n};\n","'use strict';\n\nvar stringify = require('./stringify');\nvar parse = require('./parse');\nvar formats = require('./formats');\n\nmodule.exports = {\n formats: formats,\n parse: parse,\n stringify: stringify\n};\n","'use strict';\n\nvar utils = require('./utils');\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar defaults = {\n allowDots: false,\n allowEmptyArrays: false,\n allowPrototypes: false,\n allowSparse: false,\n arrayLimit: 20,\n charset: 'utf-8',\n charsetSentinel: false,\n comma: false,\n decodeDotInKeys: false,\n decoder: utils.decode,\n delimiter: '&',\n depth: 5,\n duplicates: 'combine',\n ignoreQueryPrefix: false,\n interpretNumericEntities: false,\n parameterLimit: 1000,\n parseArrays: true,\n plainObjects: false,\n strictDepth: false,\n strictNullHandling: false\n};\n\nvar interpretNumericEntities = function (str) {\n return str.replace(/&#(\\d+);/g, function ($0, numberStr) {\n return String.fromCharCode(parseInt(numberStr, 10));\n });\n};\n\nvar parseArrayValue = function (val, options) {\n if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) {\n return val.split(',');\n }\n\n return val;\n};\n\n// This is what browsers will submit when the ✓ character occurs in an\n// application/x-www-form-urlencoded body and the encoding of the page containing\n// the form is iso-8859-1, or when the submitted form has an accept-charset\n// attribute of iso-8859-1. Presumably also with other charsets that do not contain\n// the ✓ character, such as us-ascii.\nvar isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓')\n\n// These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded.\nvar charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓')\n\nvar parseValues = function parseQueryStringValues(str, options) {\n var obj = { __proto__: null };\n\n var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\\?/, '') : str;\n cleanStr = cleanStr.replace(/%5B/gi, '[').replace(/%5D/gi, ']');\n var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit;\n var parts = cleanStr.split(options.delimiter, limit);\n var skipIndex = -1; // Keep track of where the utf8 sentinel was found\n var i;\n\n var charset = options.charset;\n if (options.charsetSentinel) {\n for (i = 0; i < parts.length; ++i) {\n if (parts[i].indexOf('utf8=') === 0) {\n if (parts[i] === charsetSentinel) {\n charset = 'utf-8';\n } else if (parts[i] === isoSentinel) {\n charset = 'iso-8859-1';\n }\n skipIndex = i;\n i = parts.length; // The eslint settings do not allow break;\n }\n }\n }\n\n for (i = 0; i < parts.length; ++i) {\n if (i === skipIndex) {\n continue;\n }\n var part = parts[i];\n\n var bracketEqualsPos = part.indexOf(']=');\n var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1;\n\n var key, val;\n if (pos === -1) {\n key = options.decoder(part, defaults.decoder, charset, 'key');\n val = options.strictNullHandling ? null : '';\n } else {\n key = options.decoder(part.slice(0, pos), defaults.decoder, charset, 'key');\n val = utils.maybeMap(\n parseArrayValue(part.slice(pos + 1), options),\n function (encodedVal) {\n return options.decoder(encodedVal, defaults.decoder, charset, 'value');\n }\n );\n }\n\n if (val && options.interpretNumericEntities && charset === 'iso-8859-1') {\n val = interpretNumericEntities(val);\n }\n\n if (part.indexOf('[]=') > -1) {\n val = isArray(val) ? [val] : val;\n }\n\n var existing = has.call(obj, key);\n if (existing && options.duplicates === 'combine') {\n obj[key] = utils.combine(obj[key], val);\n } else if (!existing || options.duplicates === 'last') {\n obj[key] = val;\n }\n }\n\n return obj;\n};\n\nvar parseObject = function (chain, val, options, valuesParsed) {\n var leaf = valuesParsed ? val : parseArrayValue(val, options);\n\n for (var i = chain.length - 1; i >= 0; --i) {\n var obj;\n var root = chain[i];\n\n if (root === '[]' && options.parseArrays) {\n obj = options.allowEmptyArrays && (leaf === '' || (options.strictNullHandling && leaf === null))\n ? []\n : [].concat(leaf);\n } else {\n obj = options.plainObjects ? Object.create(null) : {};\n var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root;\n var decodedRoot = options.decodeDotInKeys ? cleanRoot.replace(/%2E/g, '.') : cleanRoot;\n var index = parseInt(decodedRoot, 10);\n if (!options.parseArrays && decodedRoot === '') {\n obj = { 0: leaf };\n } else if (\n !isNaN(index)\n && root !== decodedRoot\n && String(index) === decodedRoot\n && index >= 0\n && (options.parseArrays && index <= options.arrayLimit)\n ) {\n obj = [];\n obj[index] = leaf;\n } else if (decodedRoot !== '__proto__') {\n obj[decodedRoot] = leaf;\n }\n }\n\n leaf = obj;\n }\n\n return leaf;\n};\n\nvar parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) {\n if (!givenKey) {\n return;\n }\n\n // Transform dot notation to bracket notation\n var key = options.allowDots ? givenKey.replace(/\\.([^.[]+)/g, '[$1]') : givenKey;\n\n // The regex chunks\n\n var brackets = /(\\[[^[\\]]*])/;\n var child = /(\\[[^[\\]]*])/g;\n\n // Get the parent\n\n var segment = options.depth > 0 && brackets.exec(key);\n var parent = segment ? key.slice(0, segment.index) : key;\n\n // Stash the parent if it exists\n\n var keys = [];\n if (parent) {\n // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties\n if (!options.plainObjects && has.call(Object.prototype, parent)) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n\n keys.push(parent);\n }\n\n // Loop through children appending to the array until we hit depth\n\n var i = 0;\n while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) {\n i += 1;\n if (!options.plainObjects && has.call(Object.prototype, segment[1].slice(1, -1))) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n keys.push(segment[1]);\n }\n\n // If there's a remainder, check strictDepth option for throw, else just add whatever is left\n\n if (segment) {\n if (options.strictDepth === true) {\n throw new RangeError('Input depth exceeded depth option of ' + options.depth + ' and strictDepth is true');\n }\n keys.push('[' + key.slice(segment.index) + ']');\n }\n\n return parseObject(keys, val, options, valuesParsed);\n};\n\nvar normalizeParseOptions = function normalizeParseOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (typeof opts.allowEmptyArrays !== 'undefined' && typeof opts.allowEmptyArrays !== 'boolean') {\n throw new TypeError('`allowEmptyArrays` option can only be `true` or `false`, when provided');\n }\n\n if (typeof opts.decodeDotInKeys !== 'undefined' && typeof opts.decodeDotInKeys !== 'boolean') {\n throw new TypeError('`decodeDotInKeys` option can only be `true` or `false`, when provided');\n }\n\n if (opts.decoder !== null && typeof opts.decoder !== 'undefined' && typeof opts.decoder !== 'function') {\n throw new TypeError('Decoder has to be a function.');\n }\n\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n var charset = typeof opts.charset === 'undefined' ? defaults.charset : opts.charset;\n\n var duplicates = typeof opts.duplicates === 'undefined' ? defaults.duplicates : opts.duplicates;\n\n if (duplicates !== 'combine' && duplicates !== 'first' && duplicates !== 'last') {\n throw new TypeError('The duplicates option must be either combine, first, or last');\n }\n\n var allowDots = typeof opts.allowDots === 'undefined' ? opts.decodeDotInKeys === true ? true : defaults.allowDots : !!opts.allowDots;\n\n return {\n allowDots: allowDots,\n allowEmptyArrays: typeof opts.allowEmptyArrays === 'boolean' ? !!opts.allowEmptyArrays : defaults.allowEmptyArrays,\n allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults.allowPrototypes,\n allowSparse: typeof opts.allowSparse === 'boolean' ? opts.allowSparse : defaults.allowSparse,\n arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults.arrayLimit,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n comma: typeof opts.comma === 'boolean' ? opts.comma : defaults.comma,\n decodeDotInKeys: typeof opts.decodeDotInKeys === 'boolean' ? opts.decodeDotInKeys : defaults.decodeDotInKeys,\n decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults.decoder,\n delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults.delimiter,\n // eslint-disable-next-line no-implicit-coercion, no-extra-parens\n depth: (typeof opts.depth === 'number' || opts.depth === false) ? +opts.depth : defaults.depth,\n duplicates: duplicates,\n ignoreQueryPrefix: opts.ignoreQueryPrefix === true,\n interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults.interpretNumericEntities,\n parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults.parameterLimit,\n parseArrays: opts.parseArrays !== false,\n plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults.plainObjects,\n strictDepth: typeof opts.strictDepth === 'boolean' ? !!opts.strictDepth : defaults.strictDepth,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (str, opts) {\n var options = normalizeParseOptions(opts);\n\n if (str === '' || str === null || typeof str === 'undefined') {\n return options.plainObjects ? Object.create(null) : {};\n }\n\n var tempObj = typeof str === 'string' ? parseValues(str, options) : str;\n var obj = options.plainObjects ? Object.create(null) : {};\n\n // Iterate over the keys and setup the new object\n\n var keys = Object.keys(tempObj);\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string');\n obj = utils.merge(obj, newObj, options);\n }\n\n if (options.allowSparse === true) {\n return obj;\n }\n\n return utils.compact(obj);\n};\n","'use strict';\n\nvar getSideChannel = require('side-channel');\nvar utils = require('./utils');\nvar formats = require('./formats');\nvar has = Object.prototype.hasOwnProperty;\n\nvar arrayPrefixGenerators = {\n brackets: function brackets(prefix) {\n return prefix + '[]';\n },\n comma: 'comma',\n indices: function indices(prefix, key) {\n return prefix + '[' + key + ']';\n },\n repeat: function repeat(prefix) {\n return prefix;\n }\n};\n\nvar isArray = Array.isArray;\nvar push = Array.prototype.push;\nvar pushToArray = function (arr, valueOrArray) {\n push.apply(arr, isArray(valueOrArray) ? valueOrArray : [valueOrArray]);\n};\n\nvar toISO = Date.prototype.toISOString;\n\nvar defaultFormat = formats['default'];\nvar defaults = {\n addQueryPrefix: false,\n allowDots: false,\n allowEmptyArrays: false,\n arrayFormat: 'indices',\n charset: 'utf-8',\n charsetSentinel: false,\n delimiter: '&',\n encode: true,\n encodeDotInKeys: false,\n encoder: utils.encode,\n encodeValuesOnly: false,\n format: defaultFormat,\n formatter: formats.formatters[defaultFormat],\n // deprecated\n indices: false,\n serializeDate: function serializeDate(date) {\n return toISO.call(date);\n },\n skipNulls: false,\n strictNullHandling: false\n};\n\nvar isNonNullishPrimitive = function isNonNullishPrimitive(v) {\n return typeof v === 'string'\n || typeof v === 'number'\n || typeof v === 'boolean'\n || typeof v === 'symbol'\n || typeof v === 'bigint';\n};\n\nvar sentinel = {};\n\nvar stringify = function stringify(\n object,\n prefix,\n generateArrayPrefix,\n commaRoundTrip,\n allowEmptyArrays,\n strictNullHandling,\n skipNulls,\n encodeDotInKeys,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n format,\n formatter,\n encodeValuesOnly,\n charset,\n sideChannel\n) {\n var obj = object;\n\n var tmpSc = sideChannel;\n var step = 0;\n var findFlag = false;\n while ((tmpSc = tmpSc.get(sentinel)) !== void undefined && !findFlag) {\n // Where object last appeared in the ref tree\n var pos = tmpSc.get(object);\n step += 1;\n if (typeof pos !== 'undefined') {\n if (pos === step) {\n throw new RangeError('Cyclic object value');\n } else {\n findFlag = true; // Break while\n }\n }\n if (typeof tmpSc.get(sentinel) === 'undefined') {\n step = 0;\n }\n }\n\n if (typeof filter === 'function') {\n obj = filter(prefix, obj);\n } else if (obj instanceof Date) {\n obj = serializeDate(obj);\n } else if (generateArrayPrefix === 'comma' && isArray(obj)) {\n obj = utils.maybeMap(obj, function (value) {\n if (value instanceof Date) {\n return serializeDate(value);\n }\n return value;\n });\n }\n\n if (obj === null) {\n if (strictNullHandling) {\n return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key', format) : prefix;\n }\n\n obj = '';\n }\n\n if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) {\n if (encoder) {\n var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key', format);\n return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value', format))];\n }\n return [formatter(prefix) + '=' + formatter(String(obj))];\n }\n\n var values = [];\n\n if (typeof obj === 'undefined') {\n return values;\n }\n\n var objKeys;\n if (generateArrayPrefix === 'comma' && isArray(obj)) {\n // we need to join elements in\n if (encodeValuesOnly && encoder) {\n obj = utils.maybeMap(obj, encoder);\n }\n objKeys = [{ value: obj.length > 0 ? obj.join(',') || null : void undefined }];\n } else if (isArray(filter)) {\n objKeys = filter;\n } else {\n var keys = Object.keys(obj);\n objKeys = sort ? keys.sort(sort) : keys;\n }\n\n var encodedPrefix = encodeDotInKeys ? prefix.replace(/\\./g, '%2E') : prefix;\n\n var adjustedPrefix = commaRoundTrip && isArray(obj) && obj.length === 1 ? encodedPrefix + '[]' : encodedPrefix;\n\n if (allowEmptyArrays && isArray(obj) && obj.length === 0) {\n return adjustedPrefix + '[]';\n }\n\n for (var j = 0; j < objKeys.length; ++j) {\n var key = objKeys[j];\n var value = typeof key === 'object' && typeof key.value !== 'undefined' ? key.value : obj[key];\n\n if (skipNulls && value === null) {\n continue;\n }\n\n var encodedKey = allowDots && encodeDotInKeys ? key.replace(/\\./g, '%2E') : key;\n var keyPrefix = isArray(obj)\n ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(adjustedPrefix, encodedKey) : adjustedPrefix\n : adjustedPrefix + (allowDots ? '.' + encodedKey : '[' + encodedKey + ']');\n\n sideChannel.set(object, step);\n var valueSideChannel = getSideChannel();\n valueSideChannel.set(sentinel, sideChannel);\n pushToArray(values, stringify(\n value,\n keyPrefix,\n generateArrayPrefix,\n commaRoundTrip,\n allowEmptyArrays,\n strictNullHandling,\n skipNulls,\n encodeDotInKeys,\n generateArrayPrefix === 'comma' && encodeValuesOnly && isArray(obj) ? null : encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n format,\n formatter,\n encodeValuesOnly,\n charset,\n valueSideChannel\n ));\n }\n\n return values;\n};\n\nvar normalizeStringifyOptions = function normalizeStringifyOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (typeof opts.allowEmptyArrays !== 'undefined' && typeof opts.allowEmptyArrays !== 'boolean') {\n throw new TypeError('`allowEmptyArrays` option can only be `true` or `false`, when provided');\n }\n\n if (typeof opts.encodeDotInKeys !== 'undefined' && typeof opts.encodeDotInKeys !== 'boolean') {\n throw new TypeError('`encodeDotInKeys` option can only be `true` or `false`, when provided');\n }\n\n if (opts.encoder !== null && typeof opts.encoder !== 'undefined' && typeof opts.encoder !== 'function') {\n throw new TypeError('Encoder has to be a function.');\n }\n\n var charset = opts.charset || defaults.charset;\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n\n var format = formats['default'];\n if (typeof opts.format !== 'undefined') {\n if (!has.call(formats.formatters, opts.format)) {\n throw new TypeError('Unknown format option provided.');\n }\n format = opts.format;\n }\n var formatter = formats.formatters[format];\n\n var filter = defaults.filter;\n if (typeof opts.filter === 'function' || isArray(opts.filter)) {\n filter = opts.filter;\n }\n\n var arrayFormat;\n if (opts.arrayFormat in arrayPrefixGenerators) {\n arrayFormat = opts.arrayFormat;\n } else if ('indices' in opts) {\n arrayFormat = opts.indices ? 'indices' : 'repeat';\n } else {\n arrayFormat = defaults.arrayFormat;\n }\n\n if ('commaRoundTrip' in opts && typeof opts.commaRoundTrip !== 'boolean') {\n throw new TypeError('`commaRoundTrip` must be a boolean, or absent');\n }\n\n var allowDots = typeof opts.allowDots === 'undefined' ? opts.encodeDotInKeys === true ? true : defaults.allowDots : !!opts.allowDots;\n\n return {\n addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix,\n allowDots: allowDots,\n allowEmptyArrays: typeof opts.allowEmptyArrays === 'boolean' ? !!opts.allowEmptyArrays : defaults.allowEmptyArrays,\n arrayFormat: arrayFormat,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n commaRoundTrip: opts.commaRoundTrip,\n delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter,\n encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode,\n encodeDotInKeys: typeof opts.encodeDotInKeys === 'boolean' ? opts.encodeDotInKeys : defaults.encodeDotInKeys,\n encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder,\n encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly,\n filter: filter,\n format: format,\n formatter: formatter,\n serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate,\n skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls,\n sort: typeof opts.sort === 'function' ? opts.sort : null,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (object, opts) {\n var obj = object;\n var options = normalizeStringifyOptions(opts);\n\n var objKeys;\n var filter;\n\n if (typeof options.filter === 'function') {\n filter = options.filter;\n obj = filter('', obj);\n } else if (isArray(options.filter)) {\n filter = options.filter;\n objKeys = filter;\n }\n\n var keys = [];\n\n if (typeof obj !== 'object' || obj === null) {\n return '';\n }\n\n var generateArrayPrefix = arrayPrefixGenerators[options.arrayFormat];\n var commaRoundTrip = generateArrayPrefix === 'comma' && options.commaRoundTrip;\n\n if (!objKeys) {\n objKeys = Object.keys(obj);\n }\n\n if (options.sort) {\n objKeys.sort(options.sort);\n }\n\n var sideChannel = getSideChannel();\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n\n if (options.skipNulls && obj[key] === null) {\n continue;\n }\n pushToArray(keys, stringify(\n obj[key],\n key,\n generateArrayPrefix,\n commaRoundTrip,\n options.allowEmptyArrays,\n options.strictNullHandling,\n options.skipNulls,\n options.encodeDotInKeys,\n options.encode ? options.encoder : null,\n options.filter,\n options.sort,\n options.allowDots,\n options.serializeDate,\n options.format,\n options.formatter,\n options.encodeValuesOnly,\n options.charset,\n sideChannel\n ));\n }\n\n var joined = keys.join(options.delimiter);\n var prefix = options.addQueryPrefix === true ? '?' : '';\n\n if (options.charsetSentinel) {\n if (options.charset === 'iso-8859-1') {\n // encodeURIComponent('✓'), the \"numeric entity\" representation of a checkmark\n prefix += 'utf8=%26%2310003%3B&';\n } else {\n // encodeURIComponent('✓')\n prefix += 'utf8=%E2%9C%93&';\n }\n }\n\n return joined.length > 0 ? prefix + joined : '';\n};\n","'use strict';\n\nvar formats = require('./formats');\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar hexTable = (function () {\n var array = [];\n for (var i = 0; i < 256; ++i) {\n array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase());\n }\n\n return array;\n}());\n\nvar compactQueue = function compactQueue(queue) {\n while (queue.length > 1) {\n var item = queue.pop();\n var obj = item.obj[item.prop];\n\n if (isArray(obj)) {\n var compacted = [];\n\n for (var j = 0; j < obj.length; ++j) {\n if (typeof obj[j] !== 'undefined') {\n compacted.push(obj[j]);\n }\n }\n\n item.obj[item.prop] = compacted;\n }\n }\n};\n\nvar arrayToObject = function arrayToObject(source, options) {\n var obj = options && options.plainObjects ? Object.create(null) : {};\n for (var i = 0; i < source.length; ++i) {\n if (typeof source[i] !== 'undefined') {\n obj[i] = source[i];\n }\n }\n\n return obj;\n};\n\nvar merge = function merge(target, source, options) {\n /* eslint no-param-reassign: 0 */\n if (!source) {\n return target;\n }\n\n if (typeof source !== 'object') {\n if (isArray(target)) {\n target.push(source);\n } else if (target && typeof target === 'object') {\n if ((options && (options.plainObjects || options.allowPrototypes)) || !has.call(Object.prototype, source)) {\n target[source] = true;\n }\n } else {\n return [target, source];\n }\n\n return target;\n }\n\n if (!target || typeof target !== 'object') {\n return [target].concat(source);\n }\n\n var mergeTarget = target;\n if (isArray(target) && !isArray(source)) {\n mergeTarget = arrayToObject(target, options);\n }\n\n if (isArray(target) && isArray(source)) {\n source.forEach(function (item, i) {\n if (has.call(target, i)) {\n var targetItem = target[i];\n if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') {\n target[i] = merge(targetItem, item, options);\n } else {\n target.push(item);\n }\n } else {\n target[i] = item;\n }\n });\n return target;\n }\n\n return Object.keys(source).reduce(function (acc, key) {\n var value = source[key];\n\n if (has.call(acc, key)) {\n acc[key] = merge(acc[key], value, options);\n } else {\n acc[key] = value;\n }\n return acc;\n }, mergeTarget);\n};\n\nvar assign = function assignSingleSource(target, source) {\n return Object.keys(source).reduce(function (acc, key) {\n acc[key] = source[key];\n return acc;\n }, target);\n};\n\nvar decode = function (str, decoder, charset) {\n var strWithoutPlus = str.replace(/\\+/g, ' ');\n if (charset === 'iso-8859-1') {\n // unescape never throws, no try...catch needed:\n return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape);\n }\n // utf-8\n try {\n return decodeURIComponent(strWithoutPlus);\n } catch (e) {\n return strWithoutPlus;\n }\n};\n\nvar limit = 1024;\n\n/* eslint operator-linebreak: [2, \"before\"] */\n\nvar encode = function encode(str, defaultEncoder, charset, kind, format) {\n // This code was originally written by Brian White (mscdex) for the io.js core querystring library.\n // It has been adapted here for stricter adherence to RFC 3986\n if (str.length === 0) {\n return str;\n }\n\n var string = str;\n if (typeof str === 'symbol') {\n string = Symbol.prototype.toString.call(str);\n } else if (typeof str !== 'string') {\n string = String(str);\n }\n\n if (charset === 'iso-8859-1') {\n return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) {\n return '%26%23' + parseInt($0.slice(2), 16) + '%3B';\n });\n }\n\n var out = '';\n for (var j = 0; j < string.length; j += limit) {\n var segment = string.length >= limit ? string.slice(j, j + limit) : string;\n var arr = [];\n\n for (var i = 0; i < segment.length; ++i) {\n var c = segment.charCodeAt(i);\n if (\n c === 0x2D // -\n || c === 0x2E // .\n || c === 0x5F // _\n || c === 0x7E // ~\n || (c >= 0x30 && c <= 0x39) // 0-9\n || (c >= 0x41 && c <= 0x5A) // a-z\n || (c >= 0x61 && c <= 0x7A) // A-Z\n || (format === formats.RFC1738 && (c === 0x28 || c === 0x29)) // ( )\n ) {\n arr[arr.length] = segment.charAt(i);\n continue;\n }\n\n if (c < 0x80) {\n arr[arr.length] = hexTable[c];\n continue;\n }\n\n if (c < 0x800) {\n arr[arr.length] = hexTable[0xC0 | (c >> 6)]\n + hexTable[0x80 | (c & 0x3F)];\n continue;\n }\n\n if (c < 0xD800 || c >= 0xE000) {\n arr[arr.length] = hexTable[0xE0 | (c >> 12)]\n + hexTable[0x80 | ((c >> 6) & 0x3F)]\n + hexTable[0x80 | (c & 0x3F)];\n continue;\n }\n\n i += 1;\n c = 0x10000 + (((c & 0x3FF) << 10) | (segment.charCodeAt(i) & 0x3FF));\n\n arr[arr.length] = hexTable[0xF0 | (c >> 18)]\n + hexTable[0x80 | ((c >> 12) & 0x3F)]\n + hexTable[0x80 | ((c >> 6) & 0x3F)]\n + hexTable[0x80 | (c & 0x3F)];\n }\n\n out += arr.join('');\n }\n\n return out;\n};\n\nvar compact = function compact(value) {\n var queue = [{ obj: { o: value }, prop: 'o' }];\n var refs = [];\n\n for (var i = 0; i < queue.length; ++i) {\n var item = queue[i];\n var obj = item.obj[item.prop];\n\n var keys = Object.keys(obj);\n for (var j = 0; j < keys.length; ++j) {\n var key = keys[j];\n var val = obj[key];\n if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) {\n queue.push({ obj: obj, prop: key });\n refs.push(val);\n }\n }\n }\n\n compactQueue(queue);\n\n return value;\n};\n\nvar isRegExp = function isRegExp(obj) {\n return Object.prototype.toString.call(obj) === '[object RegExp]';\n};\n\nvar isBuffer = function isBuffer(obj) {\n if (!obj || typeof obj !== 'object') {\n return false;\n }\n\n return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj));\n};\n\nvar combine = function combine(a, b) {\n return [].concat(a, b);\n};\n\nvar maybeMap = function maybeMap(val, fn) {\n if (isArray(val)) {\n var mapped = [];\n for (var i = 0; i < val.length; i += 1) {\n mapped.push(fn(val[i]));\n }\n return mapped;\n }\n return fn(val);\n};\n\nmodule.exports = {\n arrayToObject: arrayToObject,\n assign: assign,\n combine: combine,\n compact: compact,\n decode: decode,\n encode: encode,\n isBuffer: isBuffer,\n isRegExp: isRegExp,\n maybeMap: maybeMap,\n merge: merge\n};\n","var now = require('performance-now')\n , root = typeof window === 'undefined' ? global : window\n , vendors = ['moz', 'webkit']\n , suffix = 'AnimationFrame'\n , raf = root['request' + suffix]\n , caf = root['cancel' + suffix] || root['cancelRequest' + suffix]\n\nfor(var i = 0; !raf && i < vendors.length; i++) {\n raf = root[vendors[i] + 'Request' + suffix]\n caf = root[vendors[i] + 'Cancel' + suffix]\n || root[vendors[i] + 'CancelRequest' + suffix]\n}\n\n// Some versions of FF have rAF but not cAF\nif(!raf || !caf) {\n var last = 0\n , id = 0\n , queue = []\n , frameDuration = 1000 / 60\n\n raf = function(callback) {\n if(queue.length === 0) {\n var _now = now()\n , next = Math.max(0, frameDuration - (_now - last))\n last = next + _now\n setTimeout(function() {\n var cp = queue.slice(0)\n // Clear queue here to prevent\n // callbacks from appending listeners\n // to the current frame's queue\n queue.length = 0\n for(var i = 0; i < cp.length; i++) {\n if(!cp[i].cancelled) {\n try{\n cp[i].callback(last)\n } catch(e) {\n setTimeout(function() { throw e }, 0)\n }\n }\n }\n }, Math.round(next))\n }\n queue.push({\n handle: ++id,\n callback: callback,\n cancelled: false\n })\n return id\n }\n\n caf = function(handle) {\n for(var i = 0; i < queue.length; i++) {\n if(queue[i].handle === handle) {\n queue[i].cancelled = true\n }\n }\n }\n}\n\nmodule.exports = function(fn) {\n // Wrap in a new function to prevent\n // `cancel` potentially being assigned\n // to the native rAF function\n return raf.call(root, fn)\n}\nmodule.exports.cancel = function() {\n caf.apply(root, arguments)\n}\nmodule.exports.polyfill = function(object) {\n if (!object) {\n object = root;\n }\n object.requestAnimationFrame = raf\n object.cancelAnimationFrame = caf\n}\n","/**\n * @license React\n * react-dom.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n/*\n Modernizr 3.0.0pre (Custom Build) | MIT\n*/\n'use strict';var aa=require(\"react\"),ca=require(\"scheduler\");function p(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;cb}return!1}function v(a,b,c,d,e,f,g){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f;this.removeEmptyString=g}var z={};\n\"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style\".split(\" \").forEach(function(a){z[a]=new v(a,0,!1,a,null,!1,!1)});[[\"acceptCharset\",\"accept-charset\"],[\"className\",\"class\"],[\"htmlFor\",\"for\"],[\"httpEquiv\",\"http-equiv\"]].forEach(function(a){var b=a[0];z[b]=new v(b,1,!1,a[1],null,!1,!1)});[\"contentEditable\",\"draggable\",\"spellCheck\",\"value\"].forEach(function(a){z[a]=new v(a,2,!1,a.toLowerCase(),null,!1,!1)});\n[\"autoReverse\",\"externalResourcesRequired\",\"focusable\",\"preserveAlpha\"].forEach(function(a){z[a]=new v(a,2,!1,a,null,!1,!1)});\"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope\".split(\" \").forEach(function(a){z[a]=new v(a,3,!1,a.toLowerCase(),null,!1,!1)});\n[\"checked\",\"multiple\",\"muted\",\"selected\"].forEach(function(a){z[a]=new v(a,3,!0,a,null,!1,!1)});[\"capture\",\"download\"].forEach(function(a){z[a]=new v(a,4,!1,a,null,!1,!1)});[\"cols\",\"rows\",\"size\",\"span\"].forEach(function(a){z[a]=new v(a,6,!1,a,null,!1,!1)});[\"rowSpan\",\"start\"].forEach(function(a){z[a]=new v(a,5,!1,a.toLowerCase(),null,!1,!1)});var ra=/[\\-:]([a-z])/g;function sa(a){return a[1].toUpperCase()}\n\"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height\".split(\" \").forEach(function(a){var b=a.replace(ra,\nsa);z[b]=new v(b,1,!1,a,null,!1,!1)});\"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type\".split(\" \").forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/1999/xlink\",!1,!1)});[\"xml:base\",\"xml:lang\",\"xml:space\"].forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/XML/1998/namespace\",!1,!1)});[\"tabIndex\",\"crossOrigin\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!1,!1)});\nz.xlinkHref=new v(\"xlinkHref\",1,!1,\"xlink:href\",\"http://www.w3.org/1999/xlink\",!0,!1);[\"src\",\"href\",\"action\",\"formAction\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!0,!0)});\nfunction ta(a,b,c,d){var e=z.hasOwnProperty(b)?z[b]:null;if(null!==e?0!==e.type:d||!(2h||e[g]!==f[h]){var k=\"\\n\"+e[g].replace(\" at new \",\" at \");a.displayName&&k.includes(\"\")&&(k=k.replace(\"\",a.displayName));return k}while(1<=g&&0<=h)}break}}}finally{Na=!1,Error.prepareStackTrace=c}return(a=a?a.displayName||a.name:\"\")?Ma(a):\"\"}\nfunction Pa(a){switch(a.tag){case 5:return Ma(a.type);case 16:return Ma(\"Lazy\");case 13:return Ma(\"Suspense\");case 19:return Ma(\"SuspenseList\");case 0:case 2:case 15:return a=Oa(a.type,!1),a;case 11:return a=Oa(a.type.render,!1),a;case 1:return a=Oa(a.type,!0),a;default:return\"\"}}\nfunction Qa(a){if(null==a)return null;if(\"function\"===typeof a)return a.displayName||a.name||null;if(\"string\"===typeof a)return a;switch(a){case ya:return\"Fragment\";case wa:return\"Portal\";case Aa:return\"Profiler\";case za:return\"StrictMode\";case Ea:return\"Suspense\";case Fa:return\"SuspenseList\"}if(\"object\"===typeof a)switch(a.$$typeof){case Ca:return(a.displayName||\"Context\")+\".Consumer\";case Ba:return(a._context.displayName||\"Context\")+\".Provider\";case Da:var b=a.render;a=a.displayName;a||(a=b.displayName||\nb.name||\"\",a=\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");return a;case Ga:return b=a.displayName||null,null!==b?b:Qa(a.type)||\"Memo\";case Ha:b=a._payload;a=a._init;try{return Qa(a(b))}catch(c){}}return null}\nfunction Ra(a){var b=a.type;switch(a.tag){case 24:return\"Cache\";case 9:return(b.displayName||\"Context\")+\".Consumer\";case 10:return(b._context.displayName||\"Context\")+\".Provider\";case 18:return\"DehydratedFragment\";case 11:return a=b.render,a=a.displayName||a.name||\"\",b.displayName||(\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");case 7:return\"Fragment\";case 5:return b;case 4:return\"Portal\";case 3:return\"Root\";case 6:return\"Text\";case 16:return Qa(b);case 8:return b===za?\"StrictMode\":\"Mode\";case 22:return\"Offscreen\";\ncase 12:return\"Profiler\";case 21:return\"Scope\";case 13:return\"Suspense\";case 19:return\"SuspenseList\";case 25:return\"TracingMarker\";case 1:case 0:case 17:case 2:case 14:case 15:if(\"function\"===typeof b)return b.displayName||b.name||null;if(\"string\"===typeof b)return b}return null}function Sa(a){switch(typeof a){case \"boolean\":case \"number\":case \"string\":case \"undefined\":return a;case \"object\":return a;default:return\"\"}}\nfunction Ta(a){var b=a.type;return(a=a.nodeName)&&\"input\"===a.toLowerCase()&&(\"checkbox\"===b||\"radio\"===b)}\nfunction Ua(a){var b=Ta(a)?\"checked\":\"value\",c=Object.getOwnPropertyDescriptor(a.constructor.prototype,b),d=\"\"+a[b];if(!a.hasOwnProperty(b)&&\"undefined\"!==typeof c&&\"function\"===typeof c.get&&\"function\"===typeof c.set){var e=c.get,f=c.set;Object.defineProperty(a,b,{configurable:!0,get:function(){return e.call(this)},set:function(a){d=\"\"+a;f.call(this,a)}});Object.defineProperty(a,b,{enumerable:c.enumerable});return{getValue:function(){return d},setValue:function(a){d=\"\"+a},stopTracking:function(){a._valueTracker=\nnull;delete a[b]}}}}function Va(a){a._valueTracker||(a._valueTracker=Ua(a))}function Wa(a){if(!a)return!1;var b=a._valueTracker;if(!b)return!0;var c=b.getValue();var d=\"\";a&&(d=Ta(a)?a.checked?\"true\":\"false\":a.value);a=d;return a!==c?(b.setValue(a),!0):!1}function Xa(a){a=a||(\"undefined\"!==typeof document?document:void 0);if(\"undefined\"===typeof a)return null;try{return a.activeElement||a.body}catch(b){return a.body}}\nfunction Ya(a,b){var c=b.checked;return A({},b,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=c?c:a._wrapperState.initialChecked})}function Za(a,b){var c=null==b.defaultValue?\"\":b.defaultValue,d=null!=b.checked?b.checked:b.defaultChecked;c=Sa(null!=b.value?b.value:c);a._wrapperState={initialChecked:d,initialValue:c,controlled:\"checkbox\"===b.type||\"radio\"===b.type?null!=b.checked:null!=b.value}}function ab(a,b){b=b.checked;null!=b&&ta(a,\"checked\",b,!1)}\nfunction bb(a,b){ab(a,b);var c=Sa(b.value),d=b.type;if(null!=c)if(\"number\"===d){if(0===c&&\"\"===a.value||a.value!=c)a.value=\"\"+c}else a.value!==\"\"+c&&(a.value=\"\"+c);else if(\"submit\"===d||\"reset\"===d){a.removeAttribute(\"value\");return}b.hasOwnProperty(\"value\")?cb(a,b.type,c):b.hasOwnProperty(\"defaultValue\")&&cb(a,b.type,Sa(b.defaultValue));null==b.checked&&null!=b.defaultChecked&&(a.defaultChecked=!!b.defaultChecked)}\nfunction db(a,b,c){if(b.hasOwnProperty(\"value\")||b.hasOwnProperty(\"defaultValue\")){var d=b.type;if(!(\"submit\"!==d&&\"reset\"!==d||void 0!==b.value&&null!==b.value))return;b=\"\"+a._wrapperState.initialValue;c||b===a.value||(a.value=b);a.defaultValue=b}c=a.name;\"\"!==c&&(a.name=\"\");a.defaultChecked=!!a._wrapperState.initialChecked;\"\"!==c&&(a.name=c)}\nfunction cb(a,b,c){if(\"number\"!==b||Xa(a.ownerDocument)!==a)null==c?a.defaultValue=\"\"+a._wrapperState.initialValue:a.defaultValue!==\"\"+c&&(a.defaultValue=\"\"+c)}var eb=Array.isArray;\nfunction fb(a,b,c,d){a=a.options;if(b){b={};for(var e=0;e\"+b.valueOf().toString()+\"\";for(b=mb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});\nfunction ob(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}\nvar pb={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,\nzoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},qb=[\"Webkit\",\"ms\",\"Moz\",\"O\"];Object.keys(pb).forEach(function(a){qb.forEach(function(b){b=b+a.charAt(0).toUpperCase()+a.substring(1);pb[b]=pb[a]})});function rb(a,b,c){return null==b||\"boolean\"===typeof b||\"\"===b?\"\":c||\"number\"!==typeof b||0===b||pb.hasOwnProperty(a)&&pb[a]?(\"\"+b).trim():b+\"px\"}\nfunction sb(a,b){a=a.style;for(var c in b)if(b.hasOwnProperty(c)){var d=0===c.indexOf(\"--\"),e=rb(c,b[c],d);\"float\"===c&&(c=\"cssFloat\");d?a.setProperty(c,e):a[c]=e}}var tb=A({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});\nfunction ub(a,b){if(b){if(tb[a]&&(null!=b.children||null!=b.dangerouslySetInnerHTML))throw Error(p(137,a));if(null!=b.dangerouslySetInnerHTML){if(null!=b.children)throw Error(p(60));if(\"object\"!==typeof b.dangerouslySetInnerHTML||!(\"__html\"in b.dangerouslySetInnerHTML))throw Error(p(61));}if(null!=b.style&&\"object\"!==typeof b.style)throw Error(p(62));}}\nfunction vb(a,b){if(-1===a.indexOf(\"-\"))return\"string\"===typeof b.is;switch(a){case \"annotation-xml\":case \"color-profile\":case \"font-face\":case \"font-face-src\":case \"font-face-uri\":case \"font-face-format\":case \"font-face-name\":case \"missing-glyph\":return!1;default:return!0}}var wb=null;function xb(a){a=a.target||a.srcElement||window;a.correspondingUseElement&&(a=a.correspondingUseElement);return 3===a.nodeType?a.parentNode:a}var yb=null,zb=null,Ab=null;\nfunction Bb(a){if(a=Cb(a)){if(\"function\"!==typeof yb)throw Error(p(280));var b=a.stateNode;b&&(b=Db(b),yb(a.stateNode,a.type,b))}}function Eb(a){zb?Ab?Ab.push(a):Ab=[a]:zb=a}function Fb(){if(zb){var a=zb,b=Ab;Ab=zb=null;Bb(a);if(b)for(a=0;a>>=0;return 0===a?32:31-(pc(a)/qc|0)|0}var rc=64,sc=4194304;\nfunction tc(a){switch(a&-a){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return a&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return a&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;\ndefault:return a}}function uc(a,b){var c=a.pendingLanes;if(0===c)return 0;var d=0,e=a.suspendedLanes,f=a.pingedLanes,g=c&268435455;if(0!==g){var h=g&~e;0!==h?d=tc(h):(f&=g,0!==f&&(d=tc(f)))}else g=c&~e,0!==g?d=tc(g):0!==f&&(d=tc(f));if(0===d)return 0;if(0!==b&&b!==d&&0===(b&e)&&(e=d&-d,f=b&-b,e>=f||16===e&&0!==(f&4194240)))return b;0!==(d&4)&&(d|=c&16);b=a.entangledLanes;if(0!==b)for(a=a.entanglements,b&=d;0c;c++)b.push(a);return b}\nfunction Ac(a,b,c){a.pendingLanes|=b;536870912!==b&&(a.suspendedLanes=0,a.pingedLanes=0);a=a.eventTimes;b=31-oc(b);a[b]=c}function Bc(a,b){var c=a.pendingLanes&~b;a.pendingLanes=b;a.suspendedLanes=0;a.pingedLanes=0;a.expiredLanes&=b;a.mutableReadLanes&=b;a.entangledLanes&=b;b=a.entanglements;var d=a.eventTimes;for(a=a.expirationTimes;0=be),ee=String.fromCharCode(32),fe=!1;\nfunction ge(a,b){switch(a){case \"keyup\":return-1!==$d.indexOf(b.keyCode);case \"keydown\":return 229!==b.keyCode;case \"keypress\":case \"mousedown\":case \"focusout\":return!0;default:return!1}}function he(a){a=a.detail;return\"object\"===typeof a&&\"data\"in a?a.data:null}var ie=!1;function je(a,b){switch(a){case \"compositionend\":return he(b);case \"keypress\":if(32!==b.which)return null;fe=!0;return ee;case \"textInput\":return a=b.data,a===ee&&fe?null:a;default:return null}}\nfunction ke(a,b){if(ie)return\"compositionend\"===a||!ae&&ge(a,b)?(a=nd(),md=ld=kd=null,ie=!1,a):null;switch(a){case \"paste\":return null;case \"keypress\":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=Je(c)}}function Le(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?Le(a,b.parentNode):\"contains\"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}\nfunction Me(){for(var a=window,b=Xa();b instanceof a.HTMLIFrameElement;){try{var c=\"string\"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=Xa(a.document)}return b}function Ne(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&(\"input\"===b&&(\"text\"===a.type||\"search\"===a.type||\"tel\"===a.type||\"url\"===a.type||\"password\"===a.type)||\"textarea\"===b||\"true\"===a.contentEditable)}\nfunction Oe(a){var b=Me(),c=a.focusedElem,d=a.selectionRange;if(b!==c&&c&&c.ownerDocument&&Le(c.ownerDocument.documentElement,c)){if(null!==d&&Ne(c))if(b=d.start,a=d.end,void 0===a&&(a=b),\"selectionStart\"in c)c.selectionStart=b,c.selectionEnd=Math.min(a,c.value.length);else if(a=(b=c.ownerDocument||document)&&b.defaultView||window,a.getSelection){a=a.getSelection();var e=c.textContent.length,f=Math.min(d.start,e);d=void 0===d.end?f:Math.min(d.end,e);!a.extend&&f>d&&(e=d,d=f,f=e);e=Ke(c,f);var g=Ke(c,\nd);e&&g&&(1!==a.rangeCount||a.anchorNode!==e.node||a.anchorOffset!==e.offset||a.focusNode!==g.node||a.focusOffset!==g.offset)&&(b=b.createRange(),b.setStart(e.node,e.offset),a.removeAllRanges(),f>d?(a.addRange(b),a.extend(g.node,g.offset)):(b.setEnd(g.node,g.offset),a.addRange(b)))}b=[];for(a=c;a=a.parentNode;)1===a.nodeType&&b.push({element:a,left:a.scrollLeft,top:a.scrollTop});\"function\"===typeof c.focus&&c.focus();for(c=0;c=document.documentMode,Qe=null,Re=null,Se=null,Te=!1;\nfunction Ue(a,b,c){var d=c.window===c?c.document:9===c.nodeType?c:c.ownerDocument;Te||null==Qe||Qe!==Xa(d)||(d=Qe,\"selectionStart\"in d&&Ne(d)?d={start:d.selectionStart,end:d.selectionEnd}:(d=(d.ownerDocument&&d.ownerDocument.defaultView||window).getSelection(),d={anchorNode:d.anchorNode,anchorOffset:d.anchorOffset,focusNode:d.focusNode,focusOffset:d.focusOffset}),Se&&Ie(Se,d)||(Se=d,d=oe(Re,\"onSelect\"),0Tf||(a.current=Sf[Tf],Sf[Tf]=null,Tf--)}function G(a,b){Tf++;Sf[Tf]=a.current;a.current=b}var Vf={},H=Uf(Vf),Wf=Uf(!1),Xf=Vf;function Yf(a,b){var c=a.type.contextTypes;if(!c)return Vf;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}\nfunction Zf(a){a=a.childContextTypes;return null!==a&&void 0!==a}function $f(){E(Wf);E(H)}function ag(a,b,c){if(H.current!==Vf)throw Error(p(168));G(H,b);G(Wf,c)}function bg(a,b,c){var d=a.stateNode;b=b.childContextTypes;if(\"function\"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in b))throw Error(p(108,Ra(a)||\"Unknown\",e));return A({},c,d)}\nfunction cg(a){a=(a=a.stateNode)&&a.__reactInternalMemoizedMergedChildContext||Vf;Xf=H.current;G(H,a);G(Wf,Wf.current);return!0}function dg(a,b,c){var d=a.stateNode;if(!d)throw Error(p(169));c?(a=bg(a,b,Xf),d.__reactInternalMemoizedMergedChildContext=a,E(Wf),E(H),G(H,a)):E(Wf);G(Wf,c)}var eg=null,fg=!1,gg=!1;function hg(a){null===eg?eg=[a]:eg.push(a)}function ig(a){fg=!0;hg(a)}\nfunction jg(){if(!gg&&null!==eg){gg=!0;var a=0,b=C;try{var c=eg;for(C=1;a>=g;e-=g;rg=1<<32-oc(b)+e|c<w?(x=u,u=null):x=u.sibling;var n=r(e,u,h[w],k);if(null===n){null===u&&(u=x);break}a&&u&&null===n.alternate&&b(e,u);g=f(n,g,w);null===m?l=n:m.sibling=n;m=n;u=x}if(w===h.length)return c(e,u),I&&tg(e,w),l;if(null===u){for(;ww?(x=m,m=null):x=m.sibling;var t=r(e,m,n.value,k);if(null===t){null===m&&(m=x);break}a&&m&&null===t.alternate&&b(e,m);g=f(t,g,w);null===u?l=t:u.sibling=t;u=t;m=x}if(n.done)return c(e,\nm),I&&tg(e,w),l;if(null===m){for(;!n.done;w++,n=h.next())n=q(e,n.value,k),null!==n&&(g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);I&&tg(e,w);return l}for(m=d(e,m);!n.done;w++,n=h.next())n=y(m,e,w,n.value,k),null!==n&&(a&&null!==n.alternate&&m.delete(null===n.key?w:n.key),g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);a&&m.forEach(function(a){return b(e,a)});I&&tg(e,w);return l}function J(a,d,f,h){\"object\"===typeof f&&null!==f&&f.type===ya&&null===f.key&&(f=f.props.children);if(\"object\"===typeof f&&null!==f){switch(f.$$typeof){case va:a:{for(var k=\nf.key,l=d;null!==l;){if(l.key===k){k=f.type;if(k===ya){if(7===l.tag){c(a,l.sibling);d=e(l,f.props.children);d.return=a;a=d;break a}}else if(l.elementType===k||\"object\"===typeof k&&null!==k&&k.$$typeof===Ha&&uh(k)===l.type){c(a,l.sibling);d=e(l,f.props);d.ref=sh(a,l,f);d.return=a;a=d;break a}c(a,l);break}else b(a,l);l=l.sibling}f.type===ya?(d=Ah(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=yh(f.type,f.key,f.props,null,a.mode,h),h.ref=sh(a,d,f),h.return=a,a=h)}return g(a);case wa:a:{for(l=f.key;null!==\nd;){if(d.key===l)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[]);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=d.sibling}d=zh(f,a.mode,h);d.return=a;a=d}return g(a);case Ha:return l=f._init,J(a,d,l(f._payload),h)}if(eb(f))return n(a,d,f,h);if(Ka(f))return t(a,d,f,h);th(a,f)}return\"string\"===typeof f&&\"\"!==f||\"number\"===typeof f?(f=\"\"+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f),d.return=a,a=d):\n(c(a,d),d=xh(f,a.mode,h),d.return=a,a=d),g(a)):c(a,d)}return J}var Bh=vh(!0),Ch=vh(!1),Dh={},Eh=Uf(Dh),Fh=Uf(Dh),Gh=Uf(Dh);function Hh(a){if(a===Dh)throw Error(p(174));return a}function Ih(a,b){G(Gh,b);G(Fh,a);G(Eh,Dh);a=b.nodeType;switch(a){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:lb(null,\"\");break;default:a=8===a?b.parentNode:b,b=a.namespaceURI||null,a=a.tagName,b=lb(b,a)}E(Eh);G(Eh,b)}function Jh(){E(Eh);E(Fh);E(Gh)}\nfunction Kh(a){Hh(Gh.current);var b=Hh(Eh.current);var c=lb(b,a.type);b!==c&&(G(Fh,a),G(Eh,c))}function Lh(a){Fh.current===a&&(E(Eh),E(Fh))}var M=Uf(0);\nfunction Mh(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||\"$?\"===c.data||\"$!\"===c.data))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.flags&128))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}var Nh=[];\nfunction Oh(){for(var a=0;ac?c:4;a(!0);var d=Qh.transition;Qh.transition={};try{a(!1),b()}finally{C=c,Qh.transition=d}}function Fi(){return di().memoizedState}\nfunction Gi(a,b,c){var d=lh(a);c={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,c);else if(c=Yg(a,b,c,d),null!==c){var e=L();mh(c,a,d,e);Ji(c,b,d)}}\nfunction ri(a,b,c){var d=lh(a),e={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,e);else{var f=a.alternate;if(0===a.lanes&&(null===f||0===f.lanes)&&(f=b.lastRenderedReducer,null!==f))try{var g=b.lastRenderedState,h=f(g,c);e.hasEagerState=!0;e.eagerState=h;if(He(h,g)){var k=b.interleaved;null===k?(e.next=e,Xg(b)):(e.next=k.next,k.next=e);b.interleaved=e;return}}catch(l){}finally{}c=Yg(a,b,e,d);null!==c&&(e=L(),mh(c,a,d,e),Ji(c,b,d))}}\nfunction Hi(a){var b=a.alternate;return a===N||null!==b&&b===N}function Ii(a,b){Th=Sh=!0;var c=a.pending;null===c?b.next=b:(b.next=c.next,c.next=b);a.pending=b}function Ji(a,b,c){if(0!==(c&4194240)){var d=b.lanes;d&=a.pendingLanes;c|=d;b.lanes=c;Cc(a,c)}}\nvar ai={readContext:Vg,useCallback:Q,useContext:Q,useEffect:Q,useImperativeHandle:Q,useInsertionEffect:Q,useLayoutEffect:Q,useMemo:Q,useReducer:Q,useRef:Q,useState:Q,useDebugValue:Q,useDeferredValue:Q,useTransition:Q,useMutableSource:Q,useSyncExternalStore:Q,useId:Q,unstable_isNewReconciler:!1},Yh={readContext:Vg,useCallback:function(a,b){ci().memoizedState=[a,void 0===b?null:b];return a},useContext:Vg,useEffect:vi,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return ti(4194308,\n4,yi.bind(null,b,a),c)},useLayoutEffect:function(a,b){return ti(4194308,4,a,b)},useInsertionEffect:function(a,b){return ti(4,2,a,b)},useMemo:function(a,b){var c=ci();b=void 0===b?null:b;a=a();c.memoizedState=[a,b];return a},useReducer:function(a,b,c){var d=ci();b=void 0!==c?c(b):b;d.memoizedState=d.baseState=b;a={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:a,lastRenderedState:b};d.queue=a;a=a.dispatch=Gi.bind(null,N,a);return[d.memoizedState,a]},useRef:function(a){var b=\nci();a={current:a};return b.memoizedState=a},useState:qi,useDebugValue:Ai,useDeferredValue:function(a){return ci().memoizedState=a},useTransition:function(){var a=qi(!1),b=a[0];a=Ei.bind(null,a[1]);ci().memoizedState=a;return[b,a]},useMutableSource:function(){},useSyncExternalStore:function(a,b,c){var d=N,e=ci();if(I){if(void 0===c)throw Error(p(407));c=c()}else{c=b();if(null===R)throw Error(p(349));0!==(Rh&30)||ni(d,b,c)}e.memoizedState=c;var f={value:c,getSnapshot:b};e.queue=f;vi(ki.bind(null,d,\nf,a),[a]);d.flags|=2048;li(9,mi.bind(null,d,f,c,b),void 0,null);return c},useId:function(){var a=ci(),b=R.identifierPrefix;if(I){var c=sg;var d=rg;c=(d&~(1<<32-oc(d)-1)).toString(32)+c;b=\":\"+b+\"R\"+c;c=Uh++;0\\x3c/script>\",a=a.removeChild(a.firstChild)):\n\"string\"===typeof d.is?a=g.createElement(c,{is:d.is}):(a=g.createElement(c),\"select\"===c&&(g=a,d.multiple?g.multiple=!0:d.size&&(g.size=d.size))):a=g.createElementNS(a,c);a[Of]=b;a[Pf]=d;Aj(a,b,!1,!1);b.stateNode=a;a:{g=vb(c,d);switch(c){case \"dialog\":D(\"cancel\",a);D(\"close\",a);e=d;break;case \"iframe\":case \"object\":case \"embed\":D(\"load\",a);e=d;break;case \"video\":case \"audio\":for(e=0;eHj&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304)}else{if(!d)if(a=Mh(g),null!==a){if(b.flags|=128,d=!0,c=a.updateQueue,null!==c&&(b.updateQueue=c,b.flags|=4),Ej(f,!0),null===f.tail&&\"hidden\"===f.tailMode&&!g.alternate&&!I)return S(b),null}else 2*B()-f.renderingStartTime>Hj&&1073741824!==c&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304);f.isBackwards?(g.sibling=b.child,b.child=g):(c=f.last,null!==c?c.sibling=g:b.child=g,f.last=g)}if(null!==f.tail)return b=f.tail,f.rendering=\nb,f.tail=b.sibling,f.renderingStartTime=B(),b.sibling=null,c=M.current,G(M,d?c&1|2:c&1),b;S(b);return null;case 22:case 23:return Ij(),d=null!==b.memoizedState,null!==a&&null!==a.memoizedState!==d&&(b.flags|=8192),d&&0!==(b.mode&1)?0!==(gj&1073741824)&&(S(b),b.subtreeFlags&6&&(b.flags|=8192)):S(b),null;case 24:return null;case 25:return null}throw Error(p(156,b.tag));}\nfunction Jj(a,b){wg(b);switch(b.tag){case 1:return Zf(b.type)&&$f(),a=b.flags,a&65536?(b.flags=a&-65537|128,b):null;case 3:return Jh(),E(Wf),E(H),Oh(),a=b.flags,0!==(a&65536)&&0===(a&128)?(b.flags=a&-65537|128,b):null;case 5:return Lh(b),null;case 13:E(M);a=b.memoizedState;if(null!==a&&null!==a.dehydrated){if(null===b.alternate)throw Error(p(340));Ig()}a=b.flags;return a&65536?(b.flags=a&-65537|128,b):null;case 19:return E(M),null;case 4:return Jh(),null;case 10:return Rg(b.type._context),null;case 22:case 23:return Ij(),\nnull;case 24:return null;default:return null}}var Kj=!1,U=!1,Lj=\"function\"===typeof WeakSet?WeakSet:Set,V=null;function Mj(a,b){var c=a.ref;if(null!==c)if(\"function\"===typeof c)try{c(null)}catch(d){W(a,b,d)}else c.current=null}function Nj(a,b,c){try{c()}catch(d){W(a,b,d)}}var Oj=!1;\nfunction Pj(a,b){Cf=dd;a=Me();if(Ne(a)){if(\"selectionStart\"in a)var c={start:a.selectionStart,end:a.selectionEnd};else a:{c=(c=a.ownerDocument)&&c.defaultView||window;var d=c.getSelection&&c.getSelection();if(d&&0!==d.rangeCount){c=d.anchorNode;var e=d.anchorOffset,f=d.focusNode;d=d.focusOffset;try{c.nodeType,f.nodeType}catch(F){c=null;break a}var g=0,h=-1,k=-1,l=0,m=0,q=a,r=null;b:for(;;){for(var y;;){q!==c||0!==e&&3!==q.nodeType||(h=g+e);q!==f||0!==d&&3!==q.nodeType||(k=g+d);3===q.nodeType&&(g+=\nq.nodeValue.length);if(null===(y=q.firstChild))break;r=q;q=y}for(;;){if(q===a)break b;r===c&&++l===e&&(h=g);r===f&&++m===d&&(k=g);if(null!==(y=q.nextSibling))break;q=r;r=q.parentNode}q=y}c=-1===h||-1===k?null:{start:h,end:k}}else c=null}c=c||{start:0,end:0}}else c=null;Df={focusedElem:a,selectionRange:c};dd=!1;for(V=b;null!==V;)if(b=V,a=b.child,0!==(b.subtreeFlags&1028)&&null!==a)a.return=b,V=a;else for(;null!==V;){b=V;try{var n=b.alternate;if(0!==(b.flags&1024))switch(b.tag){case 0:case 11:case 15:break;\ncase 1:if(null!==n){var t=n.memoizedProps,J=n.memoizedState,x=b.stateNode,w=x.getSnapshotBeforeUpdate(b.elementType===b.type?t:Lg(b.type,t),J);x.__reactInternalSnapshotBeforeUpdate=w}break;case 3:var u=b.stateNode.containerInfo;1===u.nodeType?u.textContent=\"\":9===u.nodeType&&u.documentElement&&u.removeChild(u.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(p(163));}}catch(F){W(b,b.return,F)}a=b.sibling;if(null!==a){a.return=b.return;V=a;break}V=b.return}n=Oj;Oj=!1;return n}\nfunction Qj(a,b,c){var d=b.updateQueue;d=null!==d?d.lastEffect:null;if(null!==d){var e=d=d.next;do{if((e.tag&a)===a){var f=e.destroy;e.destroy=void 0;void 0!==f&&Nj(b,c,f)}e=e.next}while(e!==d)}}function Rj(a,b){b=b.updateQueue;b=null!==b?b.lastEffect:null;if(null!==b){var c=b=b.next;do{if((c.tag&a)===a){var d=c.create;c.destroy=d()}c=c.next}while(c!==b)}}function Sj(a){var b=a.ref;if(null!==b){var c=a.stateNode;switch(a.tag){case 5:a=c;break;default:a=c}\"function\"===typeof b?b(a):b.current=a}}\nfunction Tj(a){var b=a.alternate;null!==b&&(a.alternate=null,Tj(b));a.child=null;a.deletions=null;a.sibling=null;5===a.tag&&(b=a.stateNode,null!==b&&(delete b[Of],delete b[Pf],delete b[of],delete b[Qf],delete b[Rf]));a.stateNode=null;a.return=null;a.dependencies=null;a.memoizedProps=null;a.memoizedState=null;a.pendingProps=null;a.stateNode=null;a.updateQueue=null}function Uj(a){return 5===a.tag||3===a.tag||4===a.tag}\nfunction Vj(a){a:for(;;){for(;null===a.sibling;){if(null===a.return||Uj(a.return))return null;a=a.return}a.sibling.return=a.return;for(a=a.sibling;5!==a.tag&&6!==a.tag&&18!==a.tag;){if(a.flags&2)continue a;if(null===a.child||4===a.tag)continue a;else a.child.return=a,a=a.child}if(!(a.flags&2))return a.stateNode}}\nfunction Wj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?8===c.nodeType?c.parentNode.insertBefore(a,b):c.insertBefore(a,b):(8===c.nodeType?(b=c.parentNode,b.insertBefore(a,c)):(b=c,b.appendChild(a)),c=c._reactRootContainer,null!==c&&void 0!==c||null!==b.onclick||(b.onclick=Bf));else if(4!==d&&(a=a.child,null!==a))for(Wj(a,b,c),a=a.sibling;null!==a;)Wj(a,b,c),a=a.sibling}\nfunction Xj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?c.insertBefore(a,b):c.appendChild(a);else if(4!==d&&(a=a.child,null!==a))for(Xj(a,b,c),a=a.sibling;null!==a;)Xj(a,b,c),a=a.sibling}var X=null,Yj=!1;function Zj(a,b,c){for(c=c.child;null!==c;)ak(a,b,c),c=c.sibling}\nfunction ak(a,b,c){if(lc&&\"function\"===typeof lc.onCommitFiberUnmount)try{lc.onCommitFiberUnmount(kc,c)}catch(h){}switch(c.tag){case 5:U||Mj(c,b);case 6:var d=X,e=Yj;X=null;Zj(a,b,c);X=d;Yj=e;null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?a.parentNode.removeChild(c):a.removeChild(c)):X.removeChild(c.stateNode));break;case 18:null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?Kf(a.parentNode,c):1===a.nodeType&&Kf(a,c),bd(a)):Kf(X,c.stateNode));break;case 4:d=X;e=Yj;X=c.stateNode.containerInfo;Yj=!0;\nZj(a,b,c);X=d;Yj=e;break;case 0:case 11:case 14:case 15:if(!U&&(d=c.updateQueue,null!==d&&(d=d.lastEffect,null!==d))){e=d=d.next;do{var f=e,g=f.destroy;f=f.tag;void 0!==g&&(0!==(f&2)?Nj(c,b,g):0!==(f&4)&&Nj(c,b,g));e=e.next}while(e!==d)}Zj(a,b,c);break;case 1:if(!U&&(Mj(c,b),d=c.stateNode,\"function\"===typeof d.componentWillUnmount))try{d.props=c.memoizedProps,d.state=c.memoizedState,d.componentWillUnmount()}catch(h){W(c,b,h)}Zj(a,b,c);break;case 21:Zj(a,b,c);break;case 22:c.mode&1?(U=(d=U)||null!==\nc.memoizedState,Zj(a,b,c),U=d):Zj(a,b,c);break;default:Zj(a,b,c)}}function bk(a){var b=a.updateQueue;if(null!==b){a.updateQueue=null;var c=a.stateNode;null===c&&(c=a.stateNode=new Lj);b.forEach(function(b){var d=ck.bind(null,a,b);c.has(b)||(c.add(b),b.then(d,d))})}}\nfunction dk(a,b){var c=b.deletions;if(null!==c)for(var d=0;de&&(e=g);d&=~f}d=e;d=B()-d;d=(120>d?120:480>d?480:1080>d?1080:1920>d?1920:3E3>d?3E3:4320>d?4320:1960*mk(d/1960))-d;if(10a?16:a;if(null===xk)var d=!1;else{a=xk;xk=null;yk=0;if(0!==(K&6))throw Error(p(331));var e=K;K|=4;for(V=a.current;null!==V;){var f=V,g=f.child;if(0!==(V.flags&16)){var h=f.deletions;if(null!==h){for(var k=0;kB()-gk?Lk(a,0):sk|=c);Ek(a,b)}function Zk(a,b){0===b&&(0===(a.mode&1)?b=1:(b=sc,sc<<=1,0===(sc&130023424)&&(sc=4194304)));var c=L();a=Zg(a,b);null!==a&&(Ac(a,b,c),Ek(a,c))}function vj(a){var b=a.memoizedState,c=0;null!==b&&(c=b.retryLane);Zk(a,c)}\nfunction ck(a,b){var c=0;switch(a.tag){case 13:var d=a.stateNode;var e=a.memoizedState;null!==e&&(c=e.retryLane);break;case 19:d=a.stateNode;break;default:throw Error(p(314));}null!==d&&d.delete(b);Zk(a,c)}var Wk;\nWk=function(a,b,c){if(null!==a)if(a.memoizedProps!==b.pendingProps||Wf.current)Ug=!0;else{if(0===(a.lanes&c)&&0===(b.flags&128))return Ug=!1,zj(a,b,c);Ug=0!==(a.flags&131072)?!0:!1}else Ug=!1,I&&0!==(b.flags&1048576)&&ug(b,ng,b.index);b.lanes=0;switch(b.tag){case 2:var d=b.type;jj(a,b);a=b.pendingProps;var e=Yf(b,H.current);Tg(b,c);e=Xh(null,b,d,a,e,c);var f=bi();b.flags|=1;\"object\"===typeof e&&null!==e&&\"function\"===typeof e.render&&void 0===e.$$typeof?(b.tag=1,b.memoizedState=null,b.updateQueue=\nnull,Zf(d)?(f=!0,cg(b)):f=!1,b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null,ah(b),e.updater=nh,b.stateNode=e,e._reactInternals=b,rh(b,d,a,c),b=kj(null,b,d,!0,f,c)):(b.tag=0,I&&f&&vg(b),Yi(null,b,e,c),b=b.child);return b;case 16:d=b.elementType;a:{jj(a,b);a=b.pendingProps;e=d._init;d=e(d._payload);b.type=d;e=b.tag=$k(d);a=Lg(d,a);switch(e){case 0:b=dj(null,b,d,a,c);break a;case 1:b=ij(null,b,d,a,c);break a;case 11:b=Zi(null,b,d,a,c);break a;case 14:b=aj(null,b,d,Lg(d.type,a),c);break a}throw Error(p(306,\nd,\"\"));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),dj(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),ij(a,b,d,e,c);case 3:a:{lj(b);if(null===a)throw Error(p(387));d=b.pendingProps;f=b.memoizedState;e=f.element;bh(a,b);gh(b,d,null,c);var g=b.memoizedState;d=g.element;if(f.isDehydrated)if(f={element:d,isDehydrated:!1,cache:g.cache,pendingSuspenseBoundaries:g.pendingSuspenseBoundaries,transitions:g.transitions},b.updateQueue.baseState=\nf,b.memoizedState=f,b.flags&256){e=Ki(Error(p(423)),b);b=mj(a,b,d,c,e);break a}else if(d!==e){e=Ki(Error(p(424)),b);b=mj(a,b,d,c,e);break a}else for(yg=Lf(b.stateNode.containerInfo.firstChild),xg=b,I=!0,zg=null,c=Ch(b,null,d,c),b.child=c;c;)c.flags=c.flags&-3|4096,c=c.sibling;else{Ig();if(d===e){b=$i(a,b,c);break a}Yi(a,b,d,c)}b=b.child}return b;case 5:return Kh(b),null===a&&Eg(b),d=b.type,e=b.pendingProps,f=null!==a?a.memoizedProps:null,g=e.children,Ef(d,e)?g=null:null!==f&&Ef(d,f)&&(b.flags|=32),\nhj(a,b),Yi(a,b,g,c),b.child;case 6:return null===a&&Eg(b),null;case 13:return pj(a,b,c);case 4:return Ih(b,b.stateNode.containerInfo),d=b.pendingProps,null===a?b.child=Bh(b,null,d,c):Yi(a,b,d,c),b.child;case 11:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),Zi(a,b,d,e,c);case 7:return Yi(a,b,b.pendingProps,c),b.child;case 8:return Yi(a,b,b.pendingProps.children,c),b.child;case 12:return Yi(a,b,b.pendingProps.children,c),b.child;case 10:a:{d=b.type._context;e=b.pendingProps;f=b.memoizedProps;\ng=e.value;G(Mg,d._currentValue);d._currentValue=g;if(null!==f)if(He(f.value,g)){if(f.children===e.children&&!Wf.current){b=$i(a,b,c);break a}}else for(f=b.child,null!==f&&(f.return=b);null!==f;){var h=f.dependencies;if(null!==h){g=f.child;for(var k=h.firstContext;null!==k;){if(k.context===d){if(1===f.tag){k=ch(-1,c&-c);k.tag=2;var l=f.updateQueue;if(null!==l){l=l.shared;var m=l.pending;null===m?k.next=k:(k.next=m.next,m.next=k);l.pending=k}}f.lanes|=c;k=f.alternate;null!==k&&(k.lanes|=c);Sg(f.return,\nc,b);h.lanes|=c;break}k=k.next}}else if(10===f.tag)g=f.type===b.type?null:f.child;else if(18===f.tag){g=f.return;if(null===g)throw Error(p(341));g.lanes|=c;h=g.alternate;null!==h&&(h.lanes|=c);Sg(g,c,b);g=f.sibling}else g=f.child;if(null!==g)g.return=f;else for(g=f;null!==g;){if(g===b){g=null;break}f=g.sibling;if(null!==f){f.return=g.return;g=f;break}g=g.return}f=g}Yi(a,b,e.children,c);b=b.child}return b;case 9:return e=b.type,d=b.pendingProps.children,Tg(b,c),e=Vg(e),d=d(e),b.flags|=1,Yi(a,b,d,c),\nb.child;case 14:return d=b.type,e=Lg(d,b.pendingProps),e=Lg(d.type,e),aj(a,b,d,e,c);case 15:return cj(a,b,b.type,b.pendingProps,c);case 17:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),jj(a,b),b.tag=1,Zf(d)?(a=!0,cg(b)):a=!1,Tg(b,c),ph(b,d,e),rh(b,d,e,c),kj(null,b,d,!0,a,c);case 19:return yj(a,b,c);case 22:return ej(a,b,c)}throw Error(p(156,b.tag));};function Gk(a,b){return ac(a,b)}\nfunction al(a,b,c,d){this.tag=a;this.key=c;this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null;this.index=0;this.ref=null;this.pendingProps=b;this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null;this.mode=d;this.subtreeFlags=this.flags=0;this.deletions=null;this.childLanes=this.lanes=0;this.alternate=null}function Bg(a,b,c,d){return new al(a,b,c,d)}function bj(a){a=a.prototype;return!(!a||!a.isReactComponent)}\nfunction $k(a){if(\"function\"===typeof a)return bj(a)?1:0;if(void 0!==a&&null!==a){a=a.$$typeof;if(a===Da)return 11;if(a===Ga)return 14}return 2}\nfunction wh(a,b){var c=a.alternate;null===c?(c=Bg(a.tag,b,a.key,a.mode),c.elementType=a.elementType,c.type=a.type,c.stateNode=a.stateNode,c.alternate=a,a.alternate=c):(c.pendingProps=b,c.type=a.type,c.flags=0,c.subtreeFlags=0,c.deletions=null);c.flags=a.flags&14680064;c.childLanes=a.childLanes;c.lanes=a.lanes;c.child=a.child;c.memoizedProps=a.memoizedProps;c.memoizedState=a.memoizedState;c.updateQueue=a.updateQueue;b=a.dependencies;c.dependencies=null===b?null:{lanes:b.lanes,firstContext:b.firstContext};\nc.sibling=a.sibling;c.index=a.index;c.ref=a.ref;return c}\nfunction yh(a,b,c,d,e,f){var g=2;d=a;if(\"function\"===typeof a)bj(a)&&(g=1);else if(\"string\"===typeof a)g=5;else a:switch(a){case ya:return Ah(c.children,e,f,b);case za:g=8;e|=8;break;case Aa:return a=Bg(12,c,b,e|2),a.elementType=Aa,a.lanes=f,a;case Ea:return a=Bg(13,c,b,e),a.elementType=Ea,a.lanes=f,a;case Fa:return a=Bg(19,c,b,e),a.elementType=Fa,a.lanes=f,a;case Ia:return qj(c,e,f,b);default:if(\"object\"===typeof a&&null!==a)switch(a.$$typeof){case Ba:g=10;break a;case Ca:g=9;break a;case Da:g=11;\nbreak a;case Ga:g=14;break a;case Ha:g=16;d=null;break a}throw Error(p(130,null==a?a:typeof a,\"\"));}b=Bg(g,c,b,e);b.elementType=a;b.type=d;b.lanes=f;return b}function Ah(a,b,c,d){a=Bg(7,a,d,b);a.lanes=c;return a}function qj(a,b,c,d){a=Bg(22,a,d,b);a.elementType=Ia;a.lanes=c;a.stateNode={isHidden:!1};return a}function xh(a,b,c){a=Bg(6,a,null,b);a.lanes=c;return a}\nfunction zh(a,b,c){b=Bg(4,null!==a.children?a.children:[],a.key,b);b.lanes=c;b.stateNode={containerInfo:a.containerInfo,pendingChildren:null,implementation:a.implementation};return b}\nfunction bl(a,b,c,d,e){this.tag=b;this.containerInfo=a;this.finishedWork=this.pingCache=this.current=this.pendingChildren=null;this.timeoutHandle=-1;this.callbackNode=this.pendingContext=this.context=null;this.callbackPriority=0;this.eventTimes=zc(0);this.expirationTimes=zc(-1);this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0;this.entanglements=zc(0);this.identifierPrefix=d;this.onRecoverableError=e;this.mutableSourceEagerHydrationData=\nnull}function cl(a,b,c,d,e,f,g,h,k){a=new bl(a,b,c,h,k);1===b?(b=1,!0===f&&(b|=8)):b=0;f=Bg(3,null,null,b);a.current=f;f.stateNode=a;f.memoizedState={element:d,isDehydrated:c,cache:null,transitions:null,pendingSuspenseBoundaries:null};ah(f);return a}function dl(a,b,c){var d=3 {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","const sortByOffset = ({ offset: offset1 }, { offset: offset2 }) => offset1 - offset2;\n\n/**\n * Sorts a given pallet by it's stops offset.\n * @param palette\n * @returns {PaletteColor[]}\n */\nconst sortPalette = (palette) => {\n\treturn palette.sort(sortByOffset);\n};\n\nexport default sortPalette;","/**\n * Executes nothing.\n */\nconst noop = () => {};\n\nexport default noop;","/**\n * Snaps an angle if needed\n * @param {Number} angle - The angle to snap\n * @param {Number} snap - The snapping to use\n * @returns {Number}\n */\nconst snapAngle = (angle, snap = 0) => {\n\tconst module = angle % snap;\n\n\tif (module === 0) { return angle; }\n\n\tconst snappingAddition = module > snap / 2 ? snap - module : (-1 * module);\n\treturn angle + snappingAddition;\n};\n\nexport default snapAngle;","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}","export default function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","export const rgbRegExp = new RegExp(/\\d+/g);\n\nconst formatNumber = (num) => Number(num);\n\nconst isValidRgb = (r, g, b, a) => {\n return [r, g ,b].every((i) => i >= 0 && i <= 255) && (!a || (a >= 0 && a <= 1));\n};\n\n/**\n * Parses a rba / rgba string, ensure it's validness\n * @param {String} rgbString\n * @returns {Object}\n */\nconst parseRgb = (rgbString) => {\n const [r, g, b, ...a] = rgbString.match(rgbRegExp);\n const opacity = a.join('.') || 1;\n\n return isValidRgb(r, g, b, opacity) ? {\n r: formatNumber(r),\n g: formatNumber(g),\n b: formatNumber(b),\n a: formatNumber(opacity)\n } : undefined;\n};\n\nexport default parseRgb;\n","export const hexRegExp = new RegExp(/^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i);\nexport const sortHexRegExp = new RegExp(/^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i);\n\nconst formatHexNumber = (item) => parseInt(\n item.repeat(3 - item.length),\n 16\n);\n\n/**\n * Converts a hex color string into rgb\n * @param {String} hex - Hex color string\n * @param {Number} opacity - The opacity to use\n * @returns {Object}\n */\nconst hexToRgb = (hex, opacity = 1) => {\n const result = hexRegExp.exec(hex) || sortHexRegExp.exec(hex);\n\n return result ? {\n r: formatHexNumber(result[1]),\n g: formatHexNumber(result[2]),\n b: formatHexNumber(result[3]),\n a: opacity\n } : undefined;\n};\n\nexport default hexToRgb;\n","import formatRgb from '../colors/formatRgb';\nimport parseRgb, { rgbRegExp } from '../colors/parseRgb';\nimport hexToRgb, { hexRegExp, sortHexRegExp } from '../colors/hexToRgb';\n\nconst colorClassifiers = [\n { regexps: [hexRegExp, sortHexRegExp], handler: hexToRgb },\n { regexps: [rgbRegExp], handler: parseRgb }\n];\n\nconst getStopColor = (color, opacity) => {\n const classifier = colorClassifiers.find(({ regexps }) =>\n regexps.some((regexp) => regexp.test(color))\n );\n\n if (!classifier) {\n throw new Error(`Stop color - ${color} does not follow one of the accepted formats Hex / Rgb / Rgba `);\n }\n\n const parsedColor = classifier.handler(color, opacity);\n\n return formatRgb(parsedColor);\n};\n\nexport default getStopColor;\n","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _toArray(arr) {\n return arrayWithHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableRest();\n}","/**\n * Formats an rgba into a css rgb/a property\n * @returns {String}\n */\nconst formatRgb = ({ r, g, b, a = 1}) => a !== 1 ? `rgba(${r}, ${g}, ${b}, ${a})`\n : `rgb(${r}, ${g}, ${b})`;\n\nexport default formatRgb;\n","/**\n * Returns an offset\n * @param {String} offset - Stop offset, Can contain %\n * @returns {Number}\n */\nconst getStopOffset = (offset) => {\n offset = offset.toString().trim();\n\n if (offset.endsWith('%')) {\n return Number(offset.replace('%', ''));\n }\n\n // Assume 0-1 as percentage when offset has no %\n return Number(offset) * 100;\n};\n\nexport default getStopOffset;\n","/**\n * The amount of degrees in circle\n * @type {Number}\n */\nexport const CIRCLE_DEGREES = 360;\n\n/**\n * The gradient angle start point ratio\n * @type {Number}\n */\nexport const START_POINT_RATIO = CIRCLE_DEGREES / 4;\n\n/**\n * The gradient angle end point ratio\n * @type {Number}\n */\nexport const END_POINT_RATIO = CIRCLE_DEGREES * (3 / 4);\n\n/**\n * The epsilon representation\n * @type {Number}\n */\nexport const EPSILON = Math.pow(2, -52);\n","import {\n CIRCLE_DEGREES,\n START_POINT_RATIO,\n END_POINT_RATIO,\n EPSILON\n} from './constants';\n\n/**\n * Formats a cord point, ensure it's value\n * @param {Number} value\n * @returns {Number}\n */\nconst formatPoint = (value) => (value <= 0 || (Math.abs(value) <= EPSILON)) ? 0 : value;\n\n/**\n * Calculates a angle point by sin / cos\n * @param {Number} angle\n * @returns {{x: Number, y: Number}}\n */\nconst anglePoint = (angle) => ({\n x: formatPoint(Math.cos(angle)),\n y: formatPoint(Math.sin(angle))\n});\n\n/**\n * Turns a given degree into radians\n * @param {Number} degrees\n * @returns {Number}\n */\nconst degreesToRadians = (degrees) => ((degrees * Math.PI) / 180);\n\n/**\n * Returns a start / end coordinates of a given angle\n * @param {Number} angle\n * @returns {x1: Number, y1: Number, x2: Number, y2: Number}}\n */\nconst angleToGradientCords = (angle = 0) => {\n const adjustedAngle = ((CIRCLE_DEGREES - angle) % CIRCLE_DEGREES);\n\n const startPoint = anglePoint(degreesToRadians(START_POINT_RATIO - adjustedAngle));\n const endPoint = anglePoint(degreesToRadians(END_POINT_RATIO - adjustedAngle));\n\n return {\n x1: startPoint.x,\n y1: startPoint.y,\n x2: endPoint.x,\n y2: endPoint.y\n };\n};\n\nexport default angleToGradientCords;\n","import getStopColor from '../getStopColor';\nimport getStopOffset from '../getStopOffset';\nimport angleToGradientCords from '../angleToGradientCords';\n\n/**\n * Formats into linear gradient background property\n * @param {Number} angle - The linear gradient degree\n * @param {Stop[]} stops - The linear gradient stops\n * @param {GradientType} type - The gradient type\n * @returns {String}\n */\nconst asBackground = ({ angle, stops, type }) => {\n\tconst anglePrefix = type === 'linear' ? `${angle}deg, ` : '';\n\n\treturn stops.length === 1 ? stops[0].color : `${type}-gradient(${anglePrefix}${\n\t\tstops\n\t\t\t.map(stop => `${stop.color} ${stop.offset}%`)\n\t\t\t.join(', ', )\n\t})`;\n};\n\n/**\n * Returns a given gradient palette and angle a background preview\n * @param {PaletteColor[]} palette\n * @param {Number} angle\n * @param {GradientType} gradientType\n */\nconst getGradientPreview = (palette, angle = 90, gradientType = 'linear') => {\n\tconst gradient = angleToGradientCords(angle);\n\n\tconst stops = palette.map(({ offset, color, opacity }) => ({\n\t\toffset: getStopOffset(offset),\n\t\tcolor: getStopColor(color, opacity)\n\t}));\n\n\tconst background = asBackground({\n\t\tangle,\n\t\tstops,\n\t\ttype: gradientType\n\t});\n\n\treturn { gradient, background, angle };\n};\n\nexport default getGradientPreview;","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}","export default function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n\n var _s, _e;\n\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"react\");","export default function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}","import { number, string, bool, arrayOf, func, shape } from 'prop-types';\n\nconst STOP_SHAPE = shape({\n\tid: number.isRequired,\n\tcolor: string.isRequired,\n\toffset: number.isRequired,\n\tisActive: bool.isRequired,\n\tpointX: number\n});\n\nconst LIMITS_SHAPE = shape({\n\tmin: number.isRequired,\n\tmax: number.isRequired,\n\tdrop: number,\n});\n\nconst PALETTE_COLOR_SHAPE = shape({\n\tid: number,\n\tcolor: string.isRequired,\n\toffset: string.isRequired,\n\topacity: number,\n});\n\nexport const STOP_PROP_TYPES = {\n\tstop: STOP_SHAPE.isRequired,\n\tlimits: LIMITS_SHAPE.isRequired,\n\tonPosChange: func.isRequired,\n\tonDeleteColor: func.isRequired,\n\tonDragStart: func,\n\tonDragEnd: func\n};\n\nexport const STOPS_HOLDER_PROP_TYPES = {\n\twidth: number.isRequired,\n\tstops: arrayOf(STOP_SHAPE),\n\tlimits: LIMITS_SHAPE,\n\tdisabled: bool,\n\tonPosChange: func.isRequired,\n\tonAddColor: func.isRequired,\n\tonDeleteColor: func.isRequired,\n\tonDragStart: func,\n\tonDragEnd: func,\n};\n\nexport const PALETTE_PROP_TYPES = {\n\twidth: number.isRequired,\n\theight: number.isRequired,\n\tpalette: arrayOf(PALETTE_COLOR_SHAPE).isRequired\n};\n\nexport const GRADIENT_PICKER_PROP_TYPES = {\n\tonPaletteChange: func.isRequired,\n\tpaletteHeight: number,\n\twidth: number,\n\tstopRemovalDrop: number,\n\tmaxStops: number,\n\tminStops: number,\n\tflatStyle: bool,\n\tpalette: arrayOf(PALETTE_COLOR_SHAPE)\n};\n\nexport const ANGLE_PICKER_PROP_TYPES = {\n\tangle: number.isRequired,\n\tsetAngle: func.isRequired,\n\tsize: number,\n\tsnap: number\n};\n\nexport const GRADIENT_PICKER_POPOVER_PROP_TYPES = {\n\t...GRADIENT_PICKER_PROP_TYPES,\n\t...ANGLE_PICKER_PROP_TYPES,\n\tshowAnglePicker: bool,\n\tshowGradientTypePicker: bool,\n\topen: bool.isRequired,\n\tsetOpen: func.isRequired,\n\ttrigger: func,\n};","import { useState, useEffect } from 'react';\nimport { noop } from '../../../lib';\nimport { EVENTS } from './constants';\n\nconst DRAG_HANDLERS = {\n\tMOUSE: {\n\t\tstop: (e) => {\n\t\t\te.preventDefault();\n\t\t\te.stopPropagation();\n\t\t},\n\t\tcoordinates: ({ clientX, clientY }) => ({ clientX, clientY }),\n\t\tdragEvent: { name: EVENTS.MOUSEMOVE },\n\t\tdragEndEvent: { name: EVENTS.MOUSEUP }\n\t},\n\tTOUCH: {\n\t\tstop: noop,\n\t\tcoordinates: (e) => {\n\t\t\tconst [touch] = e.touches;\n\t\t\treturn { clientX: touch.clientX, clientY: touch.clientY };\n\t\t},\n\t\tdragEvent: { name: EVENTS.TOUCHMOVE, options: { cancelable: true, passive: true } },\n\t\tdragEndEvent: { name: EVENTS.TOUCHEND }\n\t}\n};\n\nconst isTouch = (e) => e.type === EVENTS.TOUCHSTART;\n\nconst useDragging = ({ onDragStart = noop, onDrag, onDragEnd = noop }) => {\n\tconst [context, setContext] = useState({});\n\tconst [dragging, setDragging] = useState(false);\n\n\tconst dragHandler = (e) => {\n\t\tconst handler = isTouch(e) ? DRAG_HANDLERS.TOUCH : DRAG_HANDLERS.MOUSE;\n\n\t\thandler.stop(e);\n\n\t\tif (!e.button) activate(e, handler);\n\t};\n\n\tconst activate = (e, handler) => {\n\t\tsetDragging(true);\n\t\tcontext.handler = handler;\n\n\t\tonDragStart(handler.coordinates(e));\n\t};\n\n\tconst deactivate = () => {\n\t\tsetDragging(false);\n\n\t\tonDragEnd(context.change);\n\t\tsetContext({});\n\t};\n\n\tconst handleDrag = (e) => {\n\t\tconst { handler } = context;\n\t\tif (!dragging) return;\n\n\t\tcontext.change = onDrag(handler.coordinates(e));\n\t};\n\n\tuseEffect(() => {\n\t\tconst { handler } = context;\n\t\tif (!handler) return;\n\n\t\tconst { dragEvent, dragEndEvent } = handler;\n\n\t\tif (dragging) {\n\t\t\tdocument.addEventListener(dragEvent.name, handleDrag, dragEndEvent.options);\n\t\t\tdocument.addEventListener(dragEndEvent.name, deactivate);\n\t\t}\n\n\t\treturn () => {\n\t\t\tdocument.removeEventListener(dragEvent.name, handleDrag, dragEndEvent.options);\n\t\t\tdocument.removeEventListener(dragEndEvent.name, deactivate);\n\t\t};\n\t}, [dragging]);\n\n\treturn [\n\t\tdragHandler,\n\t\tactivate,\n\t\tdeactivate\n\t];\n};\n\nexport default useDragging;","/**\n * The drag supported events\n * Object\n */\nexport const EVENTS = {\n\tMOUSEDOWN: 'mousedown',\n\tMOUSEMOVE: 'mousemove',\n\tMOUSEUP: 'mouseup',\n\tTOUCHSTART: 'touchstart',\n\tTOUCHMOVE: 'touchmove',\n\tTOUCHEND: 'touchend'\n};","import React, { useRef } from 'react';\nimport { ANGLE_PICKER_PROP_TYPES } from '../propTypes';\nimport useDragging from '../hooks/useDragging';\nimport {\n\tcenterOffset,\n\tclampAngle,\n\tsnapAngle,\n\tpointDegrees\n} from '../../lib';\nimport './index.scss';\n\nconst AnglePicker = ({\n\tangle,\n\tsetAngle,\n\tsize = 24,\n\tsnap = 5\n}) => {\n\tconst pickerRef = useRef();\n\tconst sizeStyle = { height: size, width: size };\n\n\tconst onAngleChange = ({ clientX, clientY }, useSnap = false) => {\n\t\tconst center = centerOffset(pickerRef.current);\n\t\tconst degrees = pointDegrees(clientX, clientY, center);\n\n\t\tconst clamped = clampAngle(degrees);\n\t\tconst angle = useSnap ? snapAngle(clamped, snap) : clamped;\n\n\t\tsetAngle(angle);\n\t};\n\n\tconst [drag] = useDragging({\n\t\tonDragStart: (e) => onAngleChange(e, true),\n\t\tonDrag: onAngleChange,\n\t\tonDragEnd: (angle) => {\n\t\t\tif (!angle) return;\n\t\t\tconst snappedAngle = snapAngle(angle, snap);\n\n\t\t\tsetAngle(snappedAngle);\n\t\t}\n\t});\n\n\treturn (\n\t\t<>\n\t\t\t

\n\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t\n\t\t\t
\n\t\t\t
\n\t\t\t\t setAngle(angle - 1)}>−\n\t\t\t\t\n\t\t\t\t setAngle(angle + 1)}>+\n\t\t\t
\n\t\t\n\t);\n};\n\nAnglePicker.propTypes = ANGLE_PICKER_PROP_TYPES;\n\nexport default AnglePicker;\n","/**\n * Returns a DOM element center offset\n * @param {HTMLElement} el\n * @returns {{ x: Number, y: Number }}\n */\nconst centerOffset = (el) => {\n\tif (!el) return { y: 0, x: 0 };\n\n\tconst { top, left, height, width } = el.getBoundingClientRect();\n\n\treturn {\n\t\ty: top + height / 2,\n\t\tx: left + width / 2\n\t};\n};\n\nexport default centerOffset;","/**\n * Returns a given point, It's matched angle in degrees from the center\n * @param {Number} pointX - The point X\n * @param {Number} pointY - The point Y\n * @param {Object} center - Represents the center to calculate the point's angle from.\n * @returns {Number}\n */\nconst pointDegrees = (pointX, pointY, center) => {\n\tconst y = pointY - center.y;\n\tconst x = pointX - center.x;\n\n\tconst radians = Math.atan2(y, x);\n\treturn Math.round(radians * (180/Math.PI)) + 90;\n};\n\n\nexport default pointDegrees;","/**\n * Clamps an angle into given boundaries\n * @param {Number} angle\n * @param {Number} min\n * @param {Number} max\n * @returns {Number}\n */\nconst clampAngle = (angle, min = 0, max = 360) => {\n\tif (angle < min) {\n\t\treturn 360 + angle;\n\t}\n\n\tif (angle > max) {\n\t\treturn angle - 360;\n\t}\n\n\treturn angle;\n};\n\nexport default clampAngle;","import objectWithoutPropertiesLoose from \"./objectWithoutPropertiesLoose.js\";\nexport default function _objectWithoutProperties(source, excluded) {\n if (source == null) return {};\n var target = objectWithoutPropertiesLoose(source, excluded);\n var key, i;\n\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n\n for (i = 0; i < sourceSymbolKeys.length; i++) {\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n\n return target;\n}","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}","import arrayWithoutHoles from \"./arrayWithoutHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableSpread from \"./nonIterableSpread.js\";\nexport default function _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}","export default function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","export default function _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}","import React, { useState, useRef, useEffect } from 'react';\nimport { noop } from '../../lib';\nimport { STOP_PROP_TYPES } from '../propTypes';\nimport useStopDragging from './hooks/useStopDragging';\nimport './index.scss';\n\nconst ColorStop = ({ stop, limits, onPosChange, onDeleteColor, onDragStart = noop, onDragEnd = noop}) => {\n\tconst colorStopRef = useRef();\n\tconst [allowRemoveOnDoubleClick, setAllowRemoveOnDoubleClick] = useState(false)\n\tconst [drag] = useStopDragging({\n\t\tstop,\n\t\tlimits,\n\t\tonPosChange,\n\t\tonDragStart,\n\t\tonDragEnd,\n\t\tonDeleteColor,\n\t\tcolorStopRef\n\t});\n\n\tuseEffect(() => {\n\t\tsetTimeout(() => setAllowRemoveOnDoubleClick(true), 500);\n\t}, []);\n\n\tconst { offset, color, isActive, opacity } = stop;\n\n\treturn (\n\t\t
{\n\t\t\t\tallowRemoveOnDoubleClick && onDeleteColor(stop.id)\n\t\t\t}}\n\t\t\tonTouchStart={drag}>\n\t\t\t
\n\t\t
\n\t);\n};\n\nColorStop.propTypes = STOP_PROP_TYPES;\n\nexport default ColorStop;\n","import { useState } from 'react';\nimport useDragging from '../../hooks/useDragging';\n\n/**\n * Limits a client drag movement within given min / max\n * @param {Number} offset - The current clientX\n * @param {Number} min - Min boundary\n * @param {Number} max - Max boundary\n * @returns {Number}\n */\nconst limitPos = (offset, min, max) => Math.max(Math.min(offset, max), min);\n\nconst getColorStopRefTop = (ref) => {\n\tif (!ref.current) return 0;\n\treturn ref.current.getBoundingClientRect().top;\n};\n\nconst useStopDragging = ({ limits, stop, initialPos, colorStopRef, onPosChange, onDragStart, onDragEnd, onDeleteColor}) => {\n\tconst [posStart, setPosStart] = useState(initialPos);\n\n\tconst handleDrag = ({ clientX, clientY }) => {\n\t\tconst { id, offset } = stop;\n\t\tconst { min, max } = limits;\n\n\t\t// Removing if out of drop limit on Y axis.\n\t\tconst top = getColorStopRefTop(colorStopRef);\n\t\tif (Math.abs(clientY - top) > limits.drop) {\n\t\t\t//deactivate();\n\t\t\treturn onDeleteColor(id);\n\t\t}\n\n\t\t// Limit movements\n\t\tconst dragOffset = offset - posStart;\n\t\tconst limitedPos = limitPos(dragOffset + clientX, min, max);\n\n\t\tonPosChange({ id, offset: limitedPos });\n\t};\n\n\tconst [drag] = useDragging({\n\t\tonDragStart: ({ clientX }) => {\n\t\t\tsetPosStart(clientX);\n\n\t\t\tonDragStart(stop.id);\n\t\t},\n\t\tonDrag: handleDrag,\n\t\tonDragEnd: () => onDragEnd(stop.id)\n\t});\n\n\treturn [\n\t\tdrag,\n\t];\n};\n\nexport default useStopDragging;","import React from 'react';\nimport ColorStop from '../ColorStop/index';\nimport { STOPS_HOLDER_PROP_TYPES } from '../propTypes';\n\nconst getStopsHolderStyle = (width, disabled) => ({\n\twidth,\n\theight: 17,\n\tposition: 'relative',\n\tcursor: disabled ? 'default' : 'crosshair'\n});\n\nconst ColorStopsHolder = ({ width, stops, disabled = false, onAddColor, ...rest }) => {\n\n\tconst handleColorAdd = (e) => {\n\t\te.preventDefault();\n\n\t\tif (e.button) return;\n\n\t\tconst offset = e.clientX - e.target.getBoundingClientRect().left;\n\t\tonAddColor({ offset });\n\t};\n\n\treturn (\n\t\t
\n\t\t\t{stops.map(stop =>\n\t\t\t\t\n\t\t\t)}\n\t\t
\n\t);\n};\n\nColorStopsHolder.propTypes = STOPS_HOLDER_PROP_TYPES;\n\nexport default ColorStopsHolder;\n","import React, { useMemo } from 'react';\nimport { sortPalette } from '../../lib';\nimport { PALETTE_PROP_TYPES } from '../propTypes';\n\nconst generateGradientId = () => '' + Math.random().toString(36).substr(2, 9);\n\nconst Palette = ({ palette, width, height }) => {\n\tconst sortedPalette = sortPalette(palette);\n\tconst gradientId = useMemo(generateGradientId, [palette.length]);\n\n\treturn (\n\t\t
\n\t\t\t\n\t\t\t\t\n\t\t\t\t\t {\n\t\t\t\t\t\tsortedPalette.map(({ id, offset, color, opacity = 1 }) =>\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t)}\n\t\t\t\t\t\n\t\t\t\t\n\t\t\t\t\n\t\t\t\n\t\t
\n\t);\n};\n\nPalette.propTypes = PALETTE_PROP_TYPES;\n\nexport default Palette;\n","export const COLORS = [\n\t{ value: '#000000', name: 'black' },\n\t{ value: '#808080', name: 'gray' },\n\t{ value: '#C0C0C0', name: 'silver' },\n\t{ value: '#FFFFFF', name: 'white' },\n\t{ value: '#FF0000', name: 'red' },\n\t{ value: '#800000', name: 'maroon' },\n\t{ value: '#FFFF00', name: 'yellow' },\n\t{ value: '#808000', name: 'olive' },\n\t{ value: '#00FF00', name: 'lime' },\n\t{ value: '#008000', name: 'green' },\n\t{ value: '#00FFFF', name: 'aqua' },\n\t{ value: '#008080', name: 'teal' },\n\t{ value: '#0000FF', name: 'blue' },\n\t{ value: '#000080', name: 'navy' },\n\t{ value: '#FF00FF', name: 'fuchsia' },\n\t{ value: '#800080', name: 'purple' }\n];\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport { COLORS } from './constants';\nimport './index.scss';\n\nconst ColorPicker = ({ onSelect }) => (\n\t
\n\t\t{COLORS.map(({ value, name, }) =>\n\t\t\t
onSelect(value)}\n\t\t\t\tkey={name}\n\t\t\t\ttitle={name}\n\t\t\t\tstyle={{ backgroundColor: value }}\n\t\t\t/>\n\t\t)}\n\t
\n);\n\nColorPicker.propTypes = {\n\tcolor: PropTypes.string.isRequired,\n\tonSelect: PropTypes.func.isRequired\n};\n\nexport default ColorPicker;\n","const STOP_WIDTH = 10;\n\nexport const HALF_STOP_WIDTH = STOP_WIDTH / 2;\n\nexport const DEFAULT_STOP_REMOVAL_DROP = 50;\n\nexport const DEFAULT_WIDTH = 220;\n\nexport const DEFAULT_HEIGHT = 32;\n\nexport const DEFAULT_MAX_STOPS = 5;\n\nexport const DEFAULT_MIN_STOPS = 2;","import React, { useState, useMemo } from 'react';\nimport ColorStopsHolder from '../ColorStopsHolder/index';\nimport Palette from '../Palette/index';\nimport ColorPicker from '../ColorPicker/index';\nimport { GRADIENT_PICKER_PROP_TYPES } from '../propTypes/index';\nimport { sortPalette, noop } from '../../lib/index';\nimport {\n\tHALF_STOP_WIDTH,\n\tDEFAULT_HEIGHT,\n\tDEFAULT_WIDTH,\n\tDEFAULT_STOP_REMOVAL_DROP,\n\tDEFAULT_MAX_STOPS,\n\tDEFAULT_MIN_STOPS\n} from './constants';\nimport './index.scss';\n\nconst nextColorId = (palette) => Math.max(...palette.map(({ id }) => id)) + 1;\n\nconst mapIdToPalette = (palette) => palette.map((color, index) => ({\n\t...color,\n\tid: color.id || index + 1\n}));\n\nconst mapPaletteToStops = ({ palette, activeId, width }) => palette.map((color) => ({\n\t...color,\n\tid: color.id,\n\toffset: width * color.offset - HALF_STOP_WIDTH,\n\tisActive: color.id === activeId\n}));\n\nconst getPaletteColor = (palette, id) => {\n\tconst color = palette.find(color => color.id === id) || palette[0];\n\n\treturn { ...color, offset: Number(color.offset) };\n};\n\nconst GradientPicker = ({\n\tpalette,\n\tpaletteHeight = DEFAULT_HEIGHT,\n\twidth = DEFAULT_WIDTH,\n\tstopRemovalDrop = DEFAULT_STOP_REMOVAL_DROP,\n\tminStops = DEFAULT_MIN_STOPS,\n\tmaxStops = DEFAULT_MAX_STOPS,\n\tchildren,\n\tflatStyle = false,\n\tonPaletteChange,\n\tonColorStopSelect = noop\n}) => {\n\tpalette = mapIdToPalette(palette);\n\n\tconst [defaultActiveColor] = palette;\n\tconst [activeColorId, setActiveColorId] = useState(defaultActiveColor.id);\n\n\tconst limits = useMemo(() => {\n\t\tconst min = -HALF_STOP_WIDTH;\n\t\tconst max = width - HALF_STOP_WIDTH;\n\n\t\treturn { min, max, drop: stopRemovalDrop };\n\t}, [width]);\n\n\tconst handleColorAdd = ({ offset }) => {\n\t\tif (palette.length >= maxStops) return;\n\n\t\tconst { color } = getPaletteColor(palette, activeColorId);\n\t\tconst entry = { id: nextColorId(palette), offset: offset / width, color };\n\n\t\tconst updatedPalette = [...palette, entry];\n\n\t\tsetActiveColorId(entry.id);\n\t\thandlePaletteChange(updatedPalette);\n\t};\n\n\tconst handleColorDelete = (id) => {\n\t\tif (palette.length <= minStops) return;\n\n\t\tconst updatedPalette = palette.filter(c => c.id !== id);\n\t\tconst activeId = updatedPalette.reduce((a, x) => x.offset < a.offset ? x : a, updatedPalette[0]).id;\n\n\t\tsetActiveColorId(activeId);\n\t\thandlePaletteChange(updatedPalette);\n\t};\n\n\tconst onStopDragStart = (id) => {\n\t\tif (id !== activeColorId) {\n\t\t\tsetActiveColorId(id);\n\n\t\t\tconst color = palette.find((color) => color.id === id);\n\t\t\tonColorStopSelect(color);\n\t\t}\n\t};\n\n\tconst handleColorSelect = (color, opacity = 1) => {\n\t\tpalette = palette.map(c =>\n\t\t\tactiveColorId === c.id ? { ...c, color, opacity } : c\n\t\t);\n\n\t\thandlePaletteChange(palette);\n\t};\n\n\tconst handlePaletteChange = (palette) => {\n\t\tconst sortedPalette = sortPalette(palette)\n\t\t\t.map(({ offset, id, ...rest }) => ({\n\t\t\t\t...rest,\n\t\t\t\tid,\n\t\t\t\toffset: Number(offset).toFixed(3),\n\t\t\t\tactive: id === activeColorId\n\t\t\t}));\n\n\t\tonPaletteChange(sortedPalette);\n\t};\n\n\tconst handleStopPosChange = ({ id, offset }) => {\n\t\tconst updatedPalette = palette.map(c =>\n\t\t\tid === c.id ? { ...c, offset: (offset + HALF_STOP_WIDTH) / width } : c\n\t\t);\n\n\t\thandlePaletteChange(updatedPalette);\n\t};\n\n\tconst colorPicker = () => {\n\t\tconst { color, opacity } = getPaletteColor(palette, activeColorId);\n\n\t\tconst props = {\n\t\t\tcolor,\n\t\t\topacity,\n\t\t\t...(flatStyle && {\n\t\t\t\twidth,\n\t\t\t\tclassName: 'gp-flat',\n\t\t\t}),\n\t\t\tonSelect: handleColorSelect\n\t\t};\n\n\t\tif (!children) {\n\t\t\treturn ;\n\t\t}\n\n\t\tconst child = React.Children.only(children);\n\t\treturn React.cloneElement(child, props);\n\t};\n\n\tconst paletteWidth = width - HALF_STOP_WIDTH;\n\tconst stopsHolderDisabled = palette.length >= maxStops;\n\n\treturn (\n\t\t
\n\t\t\t\n\t\t\t\n\t\t\t{colorPicker()}\n\t\t
\n\t);\n};\n\nGradientPicker.propTypes = GRADIENT_PICKER_PROP_TYPES;\n\nexport default GradientPicker;","import React from 'react';\nimport { func, string } from 'prop-types';\nimport './index.scss';\n\nexport const GRADIENT_TYPES = {\n\tLINEAR: 'linear',\n\tRADIAL: 'radial'\n};\n\nconst GradientTypePicker = ({\n\tgradientType,\n\tonGradientTypeChange\n}) => {\n\tconst linearActive = gradientType === GRADIENT_TYPES.LINEAR;\n\n\treturn (\n\t\t\n\t\t\t onGradientTypeChange(GRADIENT_TYPES.LINEAR)}/>\n\t\t\t onGradientTypeChange(GRADIENT_TYPES.RADIAL)}/>\n\t\t\n\t);\n};\n\nGradientTypePicker.propTypes = {\n\tgradientType: string,\n\tonGradientTypeChange: func\n};\n\nexport default GradientTypePicker;\n","import React, { useState } from 'react';\nimport { GRADIENT_PICKER_POPOVER_PROP_TYPES } from '../propTypes';\nimport { getGradientPreview } from '../../lib';\nimport AnglePicker from '../AnglePicker';\nimport GradientPicker from '../GradientPicker';\nimport GradientTypePicker, { GRADIENT_TYPES } from '../GradientTypePicker';\nimport './index.scss';\n\nconst defaultTrigger = (background, togglePicker) => (\n\t
\n\t\t
\n\t
\n);\n\nconst GradientPickerPopover = ({\n\tpalette,\n\topen = false,\n\tsetOpen,\n\ttrigger = defaultTrigger,\n\tshowAnglePicker = true,\n\tshowGradientTypePicker = true,\n\tangle,\n\tsetAngle,\n\tgradientType: controlledGradientType,\n\tsetGradientType: setControlledGradientType,\n\t...gradientPickerProps\n}) => {\n\tconst [internalGradientType, setInternalGradientType] = useState(GRADIENT_TYPES.LINEAR);\n\tconst gradientType = controlledGradientType || internalGradientType;\n\tconst setGradientType = setControlledGradientType || setInternalGradientType;\n\n\tconst togglePicker = () => setOpen(!open);\n\tconst { background } = getGradientPreview(palette, angle, gradientType);\n\n\tconst showControlPanel = showGradientTypePicker || showAnglePicker;\n\tconst supportsAnglePicker = gradientType === GRADIENT_TYPES.LINEAR;\n\n\treturn (\n\t\t
\n\t\t\t{ trigger(background, togglePicker) }\n\t\t\t{ open && (\n\t\t\t\t<>\n\t\t\t\t\t
setOpen(false)}/>\n\t\t\t\t\t
\n\t\t\t\t\t\t{ showControlPanel && (\n\t\t\t\t\t\t\t
\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t{ (showAnglePicker && supportsAnglePicker) && (\n\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t
\n\t\t\t\t\t\t)}\n\t\t\t\t\t\t\n\t\t\t\t\t
\n\t\t\t\t\n\t\t\t)}\n\t\t
\n\t);\n};\n\nGradientPickerPopover.propTypes = GRADIENT_PICKER_POPOVER_PROP_TYPES;\n\nexport { GRADIENT_TYPES };\n\nexport default GradientPickerPopover;","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __rest = (this && this.__rest) || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar plotly = require(\"plotly.js\");\nvar React = require(\"react\");\n/***\n * Usage:\n * console.log(points, event)}>\n */\nvar PlotlyChart = /** @class */ (function (_super) {\n __extends(PlotlyChart, _super);\n function PlotlyChart() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.container = null;\n _this.resize = function () {\n if (_this.container) {\n plotly.Plots.resize(_this.container);\n }\n };\n _this.draw = function (props) { return __awaiter(_this, void 0, void 0, function () {\n var data, layout, config, _a;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n data = props.data, layout = props.layout, config = props.config;\n if (!this.container) return [3 /*break*/, 2];\n // plotly.react will not destroy the old plot: https://plot.ly/javascript/plotlyjs-function-reference/#plotlyreact\n _a = this;\n return [4 /*yield*/, plotly.react(this.container, data, Object.assign({}, layout), config)];\n case 1:\n // plotly.react will not destroy the old plot: https://plot.ly/javascript/plotlyjs-function-reference/#plotlyreact\n _a.container = _b.sent();\n this.attachListeners();\n _b.label = 2;\n case 2: return [2 /*return*/];\n }\n });\n }); };\n return _this;\n }\n PlotlyChart.prototype.attachListeners = function () {\n if (this.props.onAfterExport) {\n this.container.on('plotly_afterexport', this.props.onAfterExport);\n }\n if (this.props.onAfterPlot) {\n this.container.on('plotly_afterplot', this.props.onAfterPlot);\n }\n if (this.props.onAnimated) {\n this.container.on('plotly_animated', this.props.onAnimated);\n }\n if (this.props.onAnimatingFrame) {\n this.container.on('plotly_animatingframe', this.props.onAnimatingFrame);\n }\n if (this.props.onAnimationInterrupted) {\n this.container.on('plotly_animationinterrupted', this.props.onAnimationInterrupted);\n }\n if (this.props.onAutoSize) {\n this.container.on('plotly_autosize', this.props.onAutoSize);\n }\n if (this.props.onBeforeExport) {\n this.container.on('plotly_beforeexport', this.props.onBeforeExport);\n }\n // did not find onButtonClicked in @types/plotly.js?\n // if (this.props.onButtonClicked) {\n // this.container!.on('plotly_buttonclicked', this.props.onButtonClicked);\n // }\n if (this.props.onClick) {\n this.container.removeAllListeners(\"plotly_click\");\n this.container.on('plotly_click', this.props.onClick);\n }\n if (this.props.onClickAnnotation) {\n this.container.removeAllListeners(\"plotly_clickannotation\");\n this.container.on('plotly_clickannotation', this.props.onClickAnnotation);\n }\n if (this.props.onDeselect) {\n this.container.removeAllListeners(\"plotly_deselect\");\n this.container.on('plotly_deselect', this.props.onDeselect);\n }\n if (this.props.onDoubleClick) {\n this.container.removeAllListeners(\"plotly_doubleclick\");\n this.container.on('plotly_doubleclick', this.props.onDoubleClick);\n }\n if (this.props.onFramework) {\n this.container.removeAllListeners(\"plotly_framework\");\n this.container.on('plotly_framework', this.props.onFramework);\n }\n if (this.props.onHover) {\n this.container.removeAllListeners(\"plotly_hover\");\n this.container.on('plotly_hover', this.props.onHover);\n }\n if (this.props.onLegendClick) {\n this.container.removeAllListeners(\"plotly_legendclick\");\n this.container.on('plotly_legendclick', this.props.onLegendClick);\n }\n if (this.props.onLegendDoubleClick) {\n this.container.removeAllListeners(\"plotly_legenddoubleclick\");\n this.container.on('plotly_legenddoubleclick', this.props.onLegendDoubleClick);\n }\n if (this.props.onRelayout) {\n this.container.removeAllListeners(\"plotly_relayout\");\n this.container.on('plotly_relayout', this.props.onRelayout);\n }\n if (this.props.onRestyle) {\n this.container.removeAllListeners(\"plotly_restyle\");\n this.container.on('plotly_restyle', this.props.onRestyle);\n }\n if (this.props.onRedraw) {\n this.container.removeAllListeners(\"plotly_redraw\");\n this.container.on('plotly_redraw', this.props.onRedraw);\n }\n if (this.props.onSelecting) {\n this.container.removeAllListeners(\"plotly_selecting\");\n this.container.on('plotly_selecting', this.props.onSelecting);\n }\n if (this.props.onSliderChange) {\n this.container.removeAllListeners(\"plotly_sliderchange\");\n this.container.on('plotly_sliderchange', this.props.onSliderChange);\n }\n if (this.props.onSliderEnd) {\n this.container.removeAllListeners(\"plotly_sliderend\");\n this.container.on('plotly_sliderend', this.props.onSliderEnd);\n }\n if (this.props.onSliderStart) {\n this.container.removeAllListeners(\"plotly_sliderstart\");\n this.container.on('plotly_sliderstart', this.props.onSliderStart);\n }\n if (this.props.onTransitioning) {\n this.container.removeAllListeners(\"plotly_transitioning\");\n this.container.on('plotly_transitioning', this.props.onTransitioning);\n }\n if (this.props.onTransitionInterrupted) {\n this.container.removeAllListeners(\"plotly_transitioninterrupted\");\n this.container.on('plotly_transitioninterrupted', this.props.onTransitionInterrupted);\n }\n if (this.props.onUnHover) {\n this.container.removeAllListeners(\"plotly_unhover\");\n this.container.on('plotly_unhover', this.props.onUnHover);\n }\n if (this.props.onEvent) {\n this.container.removeAllListeners(\"plotly_event\");\n this.container.on('plotly_event', this.props.onEvent);\n }\n window.addEventListener('resize', this.resize);\n };\n PlotlyChart.prototype.componentWillReceiveProps = function (nextProps) {\n this.draw(nextProps);\n };\n PlotlyChart.prototype.componentDidMount = function () {\n this.draw(this.props);\n };\n PlotlyChart.prototype.componentWillUnmount = function () {\n if (this.container) {\n plotly.purge(this.container);\n }\n window.removeEventListener('resize', this.resize);\n };\n PlotlyChart.prototype.render = function () {\n var _this = this;\n var _a = this.props, data = _a.data, layout = _a.layout, config = _a.config, onAfterExport = _a.onAfterExport, onAfterPlot = _a.onAfterPlot, onAnimated = _a.onAnimated, onAnimatingFrame = _a.onAnimatingFrame, onAnimationInterrupted = _a.onAnimationInterrupted, onAutoSize = _a.onAutoSize, onBeforeExport = _a.onBeforeExport, onClick = _a.onClick, onClickAnnotation = _a.onClickAnnotation, onDeselect = _a.onDeselect, onDoubleClick = _a.onDoubleClick, onFramework = _a.onFramework, onHover = _a.onHover, onLegendClick = _a.onLegendClick, onLegendDoubleClick = _a.onLegendDoubleClick, onRelayout = _a.onRelayout, onRestyle = _a.onRestyle, onRedraw = _a.onRedraw, onSelected = _a.onSelected, onSelecting = _a.onSelecting, onSliderChange = _a.onSliderChange, onSliderEnd = _a.onSliderEnd, onSliderStart = _a.onSliderStart, onTransitioning = _a.onTransitioning, onTransitionInterrupted = _a.onTransitionInterrupted, onUnHover = _a.onUnHover, onEvent = _a.onEvent, other = __rest(_a, [\"data\", \"layout\", \"config\", \"onAfterExport\", \"onAfterPlot\", \"onAnimated\", \"onAnimatingFrame\", \"onAnimationInterrupted\", \"onAutoSize\", \"onBeforeExport\", \"onClick\", \"onClickAnnotation\", \"onDeselect\", \"onDoubleClick\", \"onFramework\", \"onHover\", \"onLegendClick\", \"onLegendDoubleClick\", \"onRelayout\", \"onRestyle\", \"onRedraw\", \"onSelected\", \"onSelecting\", \"onSliderChange\", \"onSliderEnd\", \"onSliderStart\", \"onTransitioning\", \"onTransitionInterrupted\", \"onUnHover\", \"onEvent\"]);\n return (React.createElement(\"div\", __assign({}, other, { ref: function (node) { return __awaiter(_this, void 0, void 0, function () {\n var _a;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n if (!(node && !this.container)) return [3 /*break*/, 2];\n _a = this;\n return [4 /*yield*/, plotly.newPlot(node, data, Object.assign({}, layout), config)];\n case 1:\n _a.container = _b.sent();\n this.attachListeners();\n _b.label = 2;\n case 2: return [2 /*return*/];\n }\n });\n }); } })));\n };\n return PlotlyChart;\n}(React.Component));\nexports.default = PlotlyChart;\n","/**\n * @license React\n * react-jsx-runtime.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var f=require(\"react\"),k=Symbol.for(\"react.element\"),l=Symbol.for(\"react.fragment\"),m=Object.prototype.hasOwnProperty,n=f.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,p={key:!0,ref:!0,__self:!0,__source:!0};\nfunction q(c,a,g){var b,d={},e=null,h=null;void 0!==g&&(e=\"\"+g);void 0!==a.key&&(e=\"\"+a.key);void 0!==a.ref&&(h=a.ref);for(b in a)m.call(a,b)&&!p.hasOwnProperty(b)&&(d[b]=a[b]);if(c&&c.defaultProps)for(b in a=c.defaultProps,a)void 0===d[b]&&(d[b]=a[b]);return{$$typeof:k,type:c,key:e,ref:h,props:d,_owner:n.current}}exports.Fragment=l;exports.jsx=q;exports.jsxs=q;\n","/**\n * @license React\n * react.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var l=Symbol.for(\"react.element\"),n=Symbol.for(\"react.portal\"),p=Symbol.for(\"react.fragment\"),q=Symbol.for(\"react.strict_mode\"),r=Symbol.for(\"react.profiler\"),t=Symbol.for(\"react.provider\"),u=Symbol.for(\"react.context\"),v=Symbol.for(\"react.forward_ref\"),w=Symbol.for(\"react.suspense\"),x=Symbol.for(\"react.memo\"),y=Symbol.for(\"react.lazy\"),z=Symbol.iterator;function A(a){if(null===a||\"object\"!==typeof a)return null;a=z&&a[z]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}\nvar B={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},C=Object.assign,D={};function E(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}E.prototype.isReactComponent={};\nE.prototype.setState=function(a,b){if(\"object\"!==typeof a&&\"function\"!==typeof a&&null!=a)throw Error(\"setState(...): takes an object of state variables to update or a function which returns an object of state variables.\");this.updater.enqueueSetState(this,a,b,\"setState\")};E.prototype.forceUpdate=function(a){this.updater.enqueueForceUpdate(this,a,\"forceUpdate\")};function F(){}F.prototype=E.prototype;function G(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}var H=G.prototype=new F;\nH.constructor=G;C(H,E.prototype);H.isPureReactComponent=!0;var I=Array.isArray,J=Object.prototype.hasOwnProperty,K={current:null},L={key:!0,ref:!0,__self:!0,__source:!0};\nfunction M(a,b,e){var d,c={},k=null,h=null;if(null!=b)for(d in void 0!==b.ref&&(h=b.ref),void 0!==b.key&&(k=\"\"+b.key),b)J.call(b,d)&&!L.hasOwnProperty(d)&&(c[d]=b[d]);var g=arguments.length-2;if(1===g)c.children=e;else if(1 1 && arguments[1] !== undefined ? arguments[1] : 'span';\n\n return function (_React$Component) {\n _inherits(Active, _React$Component);\n\n function Active() {\n var _ref;\n\n var _temp, _this, _ret;\n\n _classCallCheck(this, Active);\n\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = Active.__proto__ || Object.getPrototypeOf(Active)).call.apply(_ref, [this].concat(args))), _this), _this.state = { active: false }, _this.handleMouseDown = function () {\n return _this.setState({ active: true });\n }, _this.handleMouseUp = function () {\n return _this.setState({ active: false });\n }, _this.render = function () {\n return _react2.default.createElement(\n Span,\n { onMouseDown: _this.handleMouseDown, onMouseUp: _this.handleMouseUp },\n _react2.default.createElement(Component, _extends({}, _this.props, _this.state))\n );\n }, _temp), _possibleConstructorReturn(_this, _ret);\n }\n\n return Active;\n }(_react2.default.Component);\n};\n\nexports.default = active;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hover = undefined;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar hover = exports.hover = function hover(Component) {\n var Span = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'span';\n\n return function (_React$Component) {\n _inherits(Hover, _React$Component);\n\n function Hover() {\n var _ref;\n\n var _temp, _this, _ret;\n\n _classCallCheck(this, Hover);\n\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = Hover.__proto__ || Object.getPrototypeOf(Hover)).call.apply(_ref, [this].concat(args))), _this), _this.state = { hover: false }, _this.handleMouseOver = function () {\n return _this.setState({ hover: true });\n }, _this.handleMouseOut = function () {\n return _this.setState({ hover: false });\n }, _this.render = function () {\n return _react2.default.createElement(\n Span,\n { onMouseOver: _this.handleMouseOver, onMouseOut: _this.handleMouseOut },\n _react2.default.createElement(Component, _extends({}, _this.props, _this.state))\n );\n }, _temp), _possibleConstructorReturn(_this, _ret);\n }\n\n return Hover;\n }(_react2.default.Component);\n};\n\nexports.default = hover;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.flattenNames = undefined;\n\nvar _isString2 = require('lodash/isString');\n\nvar _isString3 = _interopRequireDefault(_isString2);\n\nvar _forOwn2 = require('lodash/forOwn');\n\nvar _forOwn3 = _interopRequireDefault(_forOwn2);\n\nvar _isPlainObject2 = require('lodash/isPlainObject');\n\nvar _isPlainObject3 = _interopRequireDefault(_isPlainObject2);\n\nvar _map2 = require('lodash/map');\n\nvar _map3 = _interopRequireDefault(_map2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar flattenNames = exports.flattenNames = function flattenNames() {\n var things = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];\n\n var names = [];\n\n (0, _map3.default)(things, function (thing) {\n if (Array.isArray(thing)) {\n flattenNames(thing).map(function (name) {\n return names.push(name);\n });\n } else if ((0, _isPlainObject3.default)(thing)) {\n (0, _forOwn3.default)(thing, function (value, key) {\n value === true && names.push(key);\n names.push(key + '-' + value);\n });\n } else if ((0, _isString3.default)(thing)) {\n names.push(thing);\n }\n });\n\n return names;\n};\n\nexports.default = flattenNames;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ReactCSS = exports.loop = exports.handleActive = exports.handleHover = exports.hover = undefined;\n\nvar _flattenNames = require('./flattenNames');\n\nvar _flattenNames2 = _interopRequireDefault(_flattenNames);\n\nvar _mergeClasses = require('./mergeClasses');\n\nvar _mergeClasses2 = _interopRequireDefault(_mergeClasses);\n\nvar _autoprefix = require('./autoprefix');\n\nvar _autoprefix2 = _interopRequireDefault(_autoprefix);\n\nvar _hover2 = require('./components/hover');\n\nvar _hover3 = _interopRequireDefault(_hover2);\n\nvar _active = require('./components/active');\n\nvar _active2 = _interopRequireDefault(_active);\n\nvar _loop2 = require('./loop');\n\nvar _loop3 = _interopRequireDefault(_loop2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.hover = _hover3.default;\nexports.handleHover = _hover3.default;\nexports.handleActive = _active2.default;\nexports.loop = _loop3.default;\nvar ReactCSS = exports.ReactCSS = function ReactCSS(classes) {\n for (var _len = arguments.length, activations = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n activations[_key - 1] = arguments[_key];\n }\n\n var activeNames = (0, _flattenNames2.default)(activations);\n var merged = (0, _mergeClasses2.default)(classes, activeNames);\n return (0, _autoprefix2.default)(merged);\n};\n\nexports.default = ReactCSS;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar loopable = function loopable(i, length) {\n var props = {};\n var setProp = function setProp(name) {\n var value = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n\n props[name] = value;\n };\n\n i === 0 && setProp('first-child');\n i === length - 1 && setProp('last-child');\n (i === 0 || i % 2 === 0) && setProp('even');\n Math.abs(i % 2) === 1 && setProp('odd');\n setProp('nth-child', i);\n\n return props;\n};\n\nexports.default = loopable;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.mergeClasses = undefined;\n\nvar _forOwn2 = require('lodash/forOwn');\n\nvar _forOwn3 = _interopRequireDefault(_forOwn2);\n\nvar _cloneDeep2 = require('lodash/cloneDeep');\n\nvar _cloneDeep3 = _interopRequireDefault(_cloneDeep2);\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar mergeClasses = exports.mergeClasses = function mergeClasses(classes) {\n var activeNames = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];\n\n var styles = classes.default && (0, _cloneDeep3.default)(classes.default) || {};\n activeNames.map(function (name) {\n var toMerge = classes[name];\n if (toMerge) {\n (0, _forOwn3.default)(toMerge, function (value, key) {\n if (!styles[key]) {\n styles[key] = {};\n }\n\n styles[key] = _extends({}, styles[key], toMerge[key]);\n });\n }\n\n return name;\n });\n return styles;\n};\n\nexports.default = mergeClasses;","'use strict'\n\nconst getBounds = require('array-bounds')\nconst rgba = require('color-normalize')\nconst updateDiff = require('update-diff')\nconst pick = require('pick-by-alias')\nconst extend = require('object-assign')\nconst flatten = require('flatten-vertex-data')\nconst {float32, fract32} = require('to-float32')\n\nmodule.exports = Error2D\n\nconst WEIGHTS = [\n\t//direction, lineWidth shift, capSize shift\n\n\t// x-error bar\n\t[1, 0, 0, 1, 0, 0],\n\t[1, 0, 0, -1, 0, 0],\n\t[-1, 0, 0, -1, 0, 0],\n\n\t[-1, 0, 0, -1, 0, 0],\n\t[-1, 0, 0, 1, 0, 0],\n\t[1, 0, 0, 1, 0, 0],\n\n\t// x-error right cap\n\t[1, 0, -1, 0, 0, 1],\n\t[1, 0, -1, 0, 0, -1],\n\t[1, 0, 1, 0, 0, -1],\n\n\t[1, 0, 1, 0, 0, -1],\n\t[1, 0, 1, 0, 0, 1],\n\t[1, 0, -1, 0, 0, 1],\n\n\t// x-error left cap\n\t[-1, 0, -1, 0, 0, 1],\n\t[-1, 0, -1, 0, 0, -1],\n\t[-1, 0, 1, 0, 0, -1],\n\n\t[-1, 0, 1, 0, 0, -1],\n\t[-1, 0, 1, 0, 0, 1],\n\t[-1, 0, -1, 0, 0, 1],\n\n\t// y-error bar\n\t[0, 1, 1, 0, 0, 0],\n\t[0, 1, -1, 0, 0, 0],\n\t[0, -1, -1, 0, 0, 0],\n\n\t[0, -1, -1, 0, 0, 0],\n\t[0, 1, 1, 0, 0, 0],\n\t[0, -1, 1, 0, 0, 0],\n\n\t// y-error top cap\n\t[0, 1, 0, -1, 1, 0],\n\t[0, 1, 0, -1, -1, 0],\n\t[0, 1, 0, 1, -1, 0],\n\n\t[0, 1, 0, 1, 1, 0],\n\t[0, 1, 0, -1, 1, 0],\n\t[0, 1, 0, 1, -1, 0],\n\n\t// y-error bottom cap\n\t[0, -1, 0, -1, 1, 0],\n\t[0, -1, 0, -1, -1, 0],\n\t[0, -1, 0, 1, -1, 0],\n\n\t[0, -1, 0, 1, 1, 0],\n\t[0, -1, 0, -1, 1, 0],\n\t[0, -1, 0, 1, -1, 0]\n]\n\n\nfunction Error2D (regl, options) {\n\tif (typeof regl === 'function') {\n\t\tif (!options) options = {}\n\t\toptions.regl = regl\n\t}\n\telse {\n\t\toptions = regl\n\t}\n\tif (options.length) options.positions = options\n\tregl = options.regl\n\n\tif (!regl.hasExtension('ANGLE_instanced_arrays')) {\n\t\tthrow Error('regl-error2d: `ANGLE_instanced_arrays` extension should be enabled');\n\t}\n\n\t// persistent variables\n\tlet gl = regl._gl, drawErrors, positionBuffer, positionFractBuffer, colorBuffer, errorBuffer, meshBuffer,\n\t\t\tdefaults = {\n\t\t\t\tcolor: 'black',\n\t\t\t\tcapSize: 5,\n\t\t\t\tlineWidth: 1,\n\t\t\t\topacity: 1,\n\t\t\t\tviewport: null,\n\t\t\t\trange: null,\n\t\t\t\toffset: 0,\n\t\t\t\tcount: 0,\n\t\t\t\tbounds: null,\n\t\t\t\tpositions: [],\n\t\t\t\terrors: []\n\t\t\t}, groups = []\n\n\t//color per-point\n\tcolorBuffer = regl.buffer({\n\t\tusage: 'dynamic',\n\t\ttype: 'uint8',\n\t\tdata: new Uint8Array(0)\n\t})\n\t//xy-position per-point\n\tpositionBuffer = regl.buffer({\n\t\tusage: 'dynamic',\n\t\ttype: 'float',\n\t\tdata: new Uint8Array(0)\n\t})\n\t//xy-position float32-fraction\n\tpositionFractBuffer = regl.buffer({\n\t\tusage: 'dynamic',\n\t\ttype: 'float',\n\t\tdata: new Uint8Array(0)\n\t})\n\t//4 errors per-point\n\terrorBuffer = regl.buffer({\n\t\tusage: 'dynamic',\n\t\ttype: 'float',\n\t\tdata: new Uint8Array(0)\n\t})\n\t//error bar mesh\n\tmeshBuffer = regl.buffer({\n\t\tusage: 'static',\n\t\ttype: 'float',\n\t\tdata: WEIGHTS\n\t})\n\n\tupdate(options)\n\n\t//drawing method\n\tdrawErrors = regl({\n\t\tvert: `\n\t\tprecision highp float;\n\n\t\tattribute vec2 position, positionFract;\n\t\tattribute vec4 error;\n\t\tattribute vec4 color;\n\n\t\tattribute vec2 direction, lineOffset, capOffset;\n\n\t\tuniform vec4 viewport;\n\t\tuniform float lineWidth, capSize;\n\t\tuniform vec2 scale, scaleFract, translate, translateFract;\n\n\t\tvarying vec4 fragColor;\n\n\t\tvoid main() {\n\t\t\tfragColor = color / 255.;\n\n\t\t\tvec2 pixelOffset = lineWidth * lineOffset + (capSize + lineWidth) * capOffset;\n\n\t\t\tvec2 dxy = -step(.5, direction.xy) * error.xz + step(direction.xy, vec2(-.5)) * error.yw;\n\n\t\t\tvec2 position = position + dxy;\n\n\t\t\tvec2 pos = (position + translate) * scale\n\t\t\t\t+ (positionFract + translateFract) * scale\n\t\t\t\t+ (position + translate) * scaleFract\n\t\t\t\t+ (positionFract + translateFract) * scaleFract;\n\n\t\t\tpos += pixelOffset / viewport.zw;\n\n\t\t\tgl_Position = vec4(pos * 2. - 1., 0, 1);\n\t\t}\n\t\t`,\n\n\t\tfrag: `\n\t\tprecision highp float;\n\n\t\tvarying vec4 fragColor;\n\n\t\tuniform float opacity;\n\n\t\tvoid main() {\n\t\t\tgl_FragColor = fragColor;\n\t\t\tgl_FragColor.a *= opacity;\n\t\t}\n\t\t`,\n\n\t\tuniforms: {\n\t\t\trange: regl.prop('range'),\n\t\t\tlineWidth: regl.prop('lineWidth'),\n\t\t\tcapSize: regl.prop('capSize'),\n\t\t\topacity: regl.prop('opacity'),\n\t\t\tscale: regl.prop('scale'),\n\t\t\ttranslate: regl.prop('translate'),\n\t\t\tscaleFract: regl.prop('scaleFract'),\n\t\t\ttranslateFract: regl.prop('translateFract'),\n\t\t\tviewport: (ctx, prop) => [prop.viewport.x, prop.viewport.y, ctx.viewportWidth, ctx.viewportHeight]\n\t\t},\n\n\t\tattributes: {\n\t\t\t//dynamic attributes\n\t\t\tcolor: {\n\t\t\t\tbuffer: colorBuffer,\n\t\t\t\toffset: (ctx, prop) => prop.offset * 4,\n\t\t\t\tdivisor: 1,\n\t\t\t},\n\t\t\tposition: {\n\t\t\t\tbuffer: positionBuffer,\n\t\t\t\toffset: (ctx, prop) => prop.offset * 8,\n\t\t\t\tdivisor: 1\n\t\t\t},\n\t\t\tpositionFract: {\n\t\t\t\tbuffer: positionFractBuffer,\n\t\t\t\toffset: (ctx, prop) => prop.offset * 8,\n\t\t\t\tdivisor: 1\n\t\t\t},\n\t\t\terror: {\n\t\t\t\tbuffer: errorBuffer,\n\t\t\t\toffset: (ctx, prop) => prop.offset * 16,\n\t\t\t\tdivisor: 1\n\t\t\t},\n\n\t\t\t//static attributes\n\t\t\tdirection: {\n\t\t\t\tbuffer: meshBuffer,\n\t\t\t\tstride: 24,\n\t\t\t\toffset: 0\n\t\t\t},\n\t\t\tlineOffset: {\n\t\t\t\tbuffer: meshBuffer,\n\t\t\t\tstride: 24,\n\t\t\t\toffset: 8\n\t\t\t},\n\t\t\tcapOffset: {\n\t\t\t\tbuffer: meshBuffer,\n\t\t\t\tstride: 24,\n\t\t\t\toffset: 16\n\t\t\t}\n\t\t},\n\n\t\tprimitive: 'triangles',\n\n\t\tblend: {\n\t\t\tenable: true,\n\t\t\tcolor: [0,0,0,0],\n\t\t\tequation: {\n\t\t\t\trgb: 'add',\n\t\t\t\talpha: 'add'\n\t\t\t},\n\t\t\tfunc: {\n\t\t\t\tsrcRGB: 'src alpha',\n\t\t\t\tdstRGB: 'one minus src alpha',\n\t\t\t\tsrcAlpha: 'one minus dst alpha',\n\t\t\t\tdstAlpha: 'one'\n\t\t\t}\n\t\t},\n\n\t\tdepth: {\n\t\t\tenable: false\n\t\t},\n\n\t\tscissor: {\n\t\t\tenable: true,\n\t\t\tbox: regl.prop('viewport')\n\t\t},\n\t\tviewport: regl.prop('viewport'),\n\t\tstencil: false,\n\n\t\tinstances: regl.prop('count'),\n\t\tcount: WEIGHTS.length\n\t})\n\n\t//expose API\n\textend(error2d, {\n\t\tupdate: update,\n\t\tdraw: draw,\n\t\tdestroy: destroy,\n\t\tregl: regl,\n\t\tgl: gl,\n\t\tcanvas: gl.canvas,\n\t\tgroups: groups\n\t})\n\n\treturn error2d\n\n\tfunction error2d (opts) {\n\t\t//update\n\t\tif (opts) {\n\t\t\tupdate(opts)\n\t\t}\n\n\t\t//destroy\n\t\telse if (opts === null) {\n\t\t\tdestroy()\n\t\t}\n\n\t\tdraw()\n\t}\n\n\n\t//main draw method\n\tfunction draw (options) {\n\t\tif (typeof options === 'number') return drawGroup(options)\n\n\t\t//make options a batch\n\t\tif (options && !Array.isArray(options)) options = [options]\n\n\n\t\tregl._refresh()\n\n\t\t//render multiple polylines via regl batch\n\t\tgroups.forEach((s, i) => {\n\t\t\tif (!s) return\n\n\t\t\tif (options) {\n\t\t\t\tif (!options[i]) s.draw = false\n\t\t\t\telse s.draw = true\n\t\t\t}\n\n\t\t\t//ignore draw flag for one pass\n\t\t\tif (!s.draw) {\n\t\t\t\ts.draw = true;\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\tdrawGroup(i)\n\t\t})\n\t}\n\n\t//draw single error group by id\n\tfunction drawGroup (s) {\n\t\tif (typeof s === 'number') s = groups[s]\n\t\tif (s == null) return\n\n\t\tif (!(s && s.count && s.color && s.opacity && s.positions && s.positions.length > 1)) return\n\n\t\ts.scaleRatio = [\n\t\t\ts.scale[0] * s.viewport.width,\n\t\t\ts.scale[1] * s.viewport.height\n\t\t]\n\n\t\tdrawErrors(s)\n\n\t\tif (s.after) s.after(s)\n\t}\n\n\tfunction update (options) {\n\t\tif (!options) return\n\n\t\t//direct points argument\n\t\tif (options.length != null) {\n\t\t\tif (typeof options[0] === 'number') options = [{positions: options}]\n\t\t}\n\n\t\t//make options a batch\n\t\telse if (!Array.isArray(options)) options = [options]\n\n\t\t//global count of points\n\t\tlet pointCount = 0, errorCount = 0\n\n\t\terror2d.groups = groups = options.map((options, i) => {\n\t\t\tlet group = groups[i]\n\n\t\t\tif (!options) return group\n\t\t\telse if (typeof options === 'function') options = {after: options}\n\t\t\telse if (typeof options[0] === 'number') options = {positions: options}\n\n\t\t\t//copy options to avoid mutation & handle aliases\n\t\t\toptions = pick(options, {\n\t\t\t\tcolor: 'color colors fill',\n\t\t\t\tcapSize: 'capSize cap capsize cap-size',\n\t\t\t\tlineWidth: 'lineWidth line-width width line thickness',\n\t\t\t\topacity: 'opacity alpha',\n\t\t\t\trange: 'range dataBox',\n\t\t\t\tviewport: 'viewport viewBox',\n\t\t\t\terrors: 'errors error',\n\t\t\t\tpositions: 'positions position data points'\n\t\t\t})\n\n\t\t\tif (!group) {\n\t\t\t\tgroups[i] = group = {\n\t\t\t\t\tid: i,\n\t\t\t\t\tscale: null,\n\t\t\t\t\ttranslate: null,\n\t\t\t\t\tscaleFract: null,\n\t\t\t\t\ttranslateFract: null,\n\t\t\t\t\tdraw: true\n\t\t\t\t}\n\t\t\t\toptions = extend({}, defaults, options)\n\t\t\t}\n\n\t\t\tupdateDiff(group, options, [{\n\t\t\t\tlineWidth: v => +v * .5,\n\t\t\t\tcapSize: v => +v * .5,\n\t\t\t\topacity: parseFloat,\n\t\t\t\terrors: errors => {\n\t\t\t\t\terrors = flatten(errors)\n\n\t\t\t\t\terrorCount += errors.length\n\t\t\t\t\treturn errors\n\t\t\t\t},\n\t\t\t\tpositions: (positions, state) => {\n\t\t\t\t\tpositions = flatten(positions, 'float64')\n\t\t\t\t\tstate.count = Math.floor(positions.length / 2)\n\t\t\t\t\tstate.bounds = getBounds(positions, 2)\n\t\t\t\t\tstate.offset = pointCount\n\n\t\t\t\t\tpointCount += state.count\n\n\t\t\t\t\treturn positions\n\t\t\t\t}\n\t\t\t}, {\n\t\t\t\tcolor: (colors, state) => {\n\t\t\t\t\tlet count = state.count\n\n\t\t\t\t\tif (!colors) colors = 'transparent'\n\n\t\t\t\t\t// 'black' or [0,0,0,0] case\n\t\t\t\t\tif (!Array.isArray(colors) || typeof colors[0] === 'number') {\n\t\t\t\t\t\tlet color = colors\n\t\t\t\t\t\tcolors = Array(count)\n\t\t\t\t\t\tfor (let i = 0; i < count; i++) {\n\t\t\t\t\t\t\tcolors[i] = color\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (colors.length < count) throw Error('Not enough colors')\n\n\t\t\t\t\tlet colorData = new Uint8Array(count * 4)\n\n\t\t\t\t\t//convert colors to float arrays\n\t\t\t\t\tfor (let i = 0; i < count; i++) {\n\t\t\t\t\t\tlet c = rgba(colors[i], 'uint8')\n\t\t\t\t\t\tcolorData.set(c, i * 4)\n\t\t\t\t\t}\n\n\t\t\t\t\treturn colorData\n\t\t\t\t},\n\n\t\t\t\trange: (range, state, options) => {\n\t\t\t\t\tlet bounds = state.bounds\n\t\t\t\t\tif (!range) range = bounds\n\n\t\t\t\t\tstate.scale = [1 / (range[2] - range[0]), 1 / (range[3] - range[1])]\n\t\t\t\t\tstate.translate = [-range[0], -range[1]]\n\n\t\t\t\t\tstate.scaleFract = fract32(state.scale)\n\t\t\t\t\tstate.translateFract = fract32(state.translate)\n\n\t\t\t\t\treturn range\n\t\t\t\t},\n\n\t\t\t\tviewport: vp => {\n\t\t\t\t\tlet viewport\n\n\t\t\t\t\tif (Array.isArray(vp)) {\n\t\t\t\t\t\tviewport = {\n\t\t\t\t\t\t\tx: vp[0],\n\t\t\t\t\t\t\ty: vp[1],\n\t\t\t\t\t\t\twidth: vp[2] - vp[0],\n\t\t\t\t\t\t\theight: vp[3] - vp[1]\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\telse if (vp) {\n\t\t\t\t\t\tviewport = {\n\t\t\t\t\t\t\tx: vp.x || vp.left || 0,\n\t\t\t\t\t\t\ty: vp.y || vp.top || 0\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (vp.right) viewport.width = vp.right - viewport.x\n\t\t\t\t\t\telse viewport.width = vp.w || vp.width || 0\n\n\t\t\t\t\t\tif (vp.bottom) viewport.height = vp.bottom - viewport.y\n\t\t\t\t\t\telse viewport.height = vp.h || vp.height || 0\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tviewport = {\n\t\t\t\t\t\t\tx: 0, y: 0,\n\t\t\t\t\t\t\twidth: gl.drawingBufferWidth,\n\t\t\t\t\t\t\theight: gl.drawingBufferHeight\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\treturn viewport\n\t\t\t\t}\n\t\t\t}])\n\n\t\t\treturn group\n\t\t})\n\n\t\tif (pointCount || errorCount) {\n\t\t\tlet len = groups.reduce((acc, group, i) => {\n\t\t\t\treturn acc + (group ? group.count : 0)\n\t\t\t}, 0)\n\n\t\t\tlet positionData = new Float64Array(len * 2)\n\t\t\tlet colorData = new Uint8Array(len * 4)\n\t\t\tlet errorData = new Float32Array(len * 4)\n\n\t\t\tgroups.forEach((group, i) => {\n\t\t\t\tif (!group) return\n\t\t\t\tlet {positions, count, offset, color, errors} = group\n\t\t\t\tif (!count) return\n\n\t\t\t\tcolorData.set(color, offset * 4)\n\t\t\t\terrorData.set(errors, offset * 4)\n\t\t\t\tpositionData.set(positions, offset * 2)\n\t\t\t})\n\n\t\t\tvar float_data = float32(positionData)\n\t\t\tpositionBuffer(float_data)\n\t\t\tvar frac_data = fract32(positionData, float_data)\n\t\t\tpositionFractBuffer(frac_data)\n\t\t\tcolorBuffer(colorData)\n\t\t\terrorBuffer(errorData)\n\t\t}\n\n\t}\n\n\tfunction destroy () {\n\t\tpositionBuffer.destroy()\n\t\tpositionFractBuffer.destroy()\n\t\tcolorBuffer.destroy()\n\t\terrorBuffer.destroy()\n\t\tmeshBuffer.destroy()\n\t}\n}\n","'use strict'\n\n\nconst rgba = require('color-normalize')\nconst getBounds = require('array-bounds')\nconst extend = require('object-assign')\nconst pick = require('pick-by-alias')\nconst flatten = require('flatten-vertex-data')\nconst triangulate = require('earcut')\nconst normalize = require('array-normalize')\nconst { float32, fract32 } = require('to-float32')\nconst WeakMap = require('es6-weak-map')\nconst parseRect = require('parse-rect')\nconst findIndex = require('array-find-index')\n\nconst rectVert = `\nprecision highp float;\n\nattribute vec2 aCoord, bCoord, aCoordFract, bCoordFract;\nattribute vec4 color;\nattribute float lineEnd, lineTop;\n\nuniform vec2 scale, scaleFract, translate, translateFract;\nuniform float thickness, pixelRatio, id, depth;\nuniform vec4 viewport;\n\nvarying vec4 fragColor;\nvarying vec2 tangent;\n\nvec2 project(vec2 position, vec2 positionFract, vec2 scale, vec2 scaleFract, vec2 translate, vec2 translateFract) {\n\t// the order is important\n\treturn position * scale + translate\n + positionFract * scale + translateFract\n + position * scaleFract\n + positionFract * scaleFract;\n}\n\nvoid main() {\n\tfloat lineStart = 1. - lineEnd;\n\tfloat lineOffset = lineTop * 2. - 1.;\n\n\tvec2 diff = (bCoord + bCoordFract - aCoord - aCoordFract);\n\ttangent = normalize(diff * scale * viewport.zw);\n\tvec2 normal = vec2(-tangent.y, tangent.x);\n\n\tvec2 position = project(aCoord, aCoordFract, scale, scaleFract, translate, translateFract) * lineStart\n\t\t+ project(bCoord, bCoordFract, scale, scaleFract, translate, translateFract) * lineEnd\n\n\t\t+ thickness * normal * .5 * lineOffset / viewport.zw;\n\n\tgl_Position = vec4(position * 2.0 - 1.0, depth, 1);\n\n\tfragColor = color / 255.;\n}\n`\n\nconst rectFrag =`\nprecision highp float;\n\nuniform float dashLength, pixelRatio, thickness, opacity, id;\nuniform sampler2D dashTexture;\n\nvarying vec4 fragColor;\nvarying vec2 tangent;\n\nvoid main() {\n\tfloat alpha = 1.;\n\n\tfloat t = fract(dot(tangent, gl_FragCoord.xy) / dashLength) * .5 + .25;\n\tfloat dash = texture2D(dashTexture, vec2(t, .5)).r;\n\n\tgl_FragColor = fragColor;\n\tgl_FragColor.a *= alpha * opacity * dash;\n}\n`\n\nconst fillVert = `\nprecision highp float;\n\nattribute vec2 position, positionFract;\n\nuniform vec4 color;\nuniform vec2 scale, scaleFract, translate, translateFract;\nuniform float pixelRatio, id;\nuniform vec4 viewport;\nuniform float opacity;\n\nvarying vec4 fragColor;\n\nconst float MAX_LINES = 256.;\n\nvoid main() {\n\tfloat depth = (MAX_LINES - 4. - id) / (MAX_LINES);\n\n\tvec2 position = position * scale + translate\n + positionFract * scale + translateFract\n + position * scaleFract\n + positionFract * scaleFract;\n\n\tgl_Position = vec4(position * 2.0 - 1.0, depth, 1);\n\n\tfragColor = color / 255.;\n\tfragColor.a *= opacity;\n}\n`\n\nconst fillFrag = `\nprecision highp float;\nvarying vec4 fragColor;\n\nvoid main() {\n\tgl_FragColor = fragColor;\n}\n`\n\nconst milterVert = `\nprecision highp float;\n\nattribute vec2 aCoord, bCoord, nextCoord, prevCoord;\nattribute vec4 aColor, bColor;\nattribute float lineEnd, lineTop;\n\nuniform vec2 scale, translate;\nuniform float thickness, pixelRatio, id, depth;\nuniform vec4 viewport;\nuniform float miterLimit, miterMode;\n\nvarying vec4 fragColor;\nvarying vec4 startCutoff, endCutoff;\nvarying vec2 tangent;\nvarying vec2 startCoord, endCoord;\nvarying float enableStartMiter, enableEndMiter;\n\nconst float REVERSE_THRESHOLD = -.875;\nconst float MIN_DIFF = 1e-6;\n\n// TODO: possible optimizations: avoid overcalculating all for vertices and calc just one instead\n// TODO: precalculate dot products, normalize things beforehead etc.\n// TODO: refactor to rectangular algorithm\n\nfloat distToLine(vec2 p, vec2 a, vec2 b) {\n\tvec2 diff = b - a;\n\tvec2 perp = normalize(vec2(-diff.y, diff.x));\n\treturn dot(p - a, perp);\n}\n\nbool isNaN( float val ){\n return ( val < 0.0 || 0.0 < val || val == 0.0 ) ? false : true;\n}\n\nvoid main() {\n\tvec2 aCoord = aCoord, bCoord = bCoord, prevCoord = prevCoord, nextCoord = nextCoord;\n\n vec2 adjustedScale;\n adjustedScale.x = (abs(scale.x) < MIN_DIFF) ? MIN_DIFF : scale.x;\n adjustedScale.y = (abs(scale.y) < MIN_DIFF) ? MIN_DIFF : scale.y;\n\n vec2 scaleRatio = adjustedScale * viewport.zw;\n\tvec2 normalWidth = thickness / scaleRatio;\n\n\tfloat lineStart = 1. - lineEnd;\n\tfloat lineBot = 1. - lineTop;\n\n\tfragColor = (lineStart * aColor + lineEnd * bColor) / 255.;\n\n\tif (isNaN(aCoord.x) || isNaN(aCoord.y) || isNaN(bCoord.x) || isNaN(bCoord.y)) return;\n\n\tif (aCoord == prevCoord) prevCoord = aCoord + normalize(bCoord - aCoord);\n\tif (bCoord == nextCoord) nextCoord = bCoord - normalize(bCoord - aCoord);\n\n\n\tvec2 prevDiff = aCoord - prevCoord;\n\tvec2 currDiff = bCoord - aCoord;\n\tvec2 nextDiff = nextCoord - bCoord;\n\n\tvec2 prevTangent = normalize(prevDiff * scaleRatio);\n\tvec2 currTangent = normalize(currDiff * scaleRatio);\n\tvec2 nextTangent = normalize(nextDiff * scaleRatio);\n\n\tvec2 prevNormal = vec2(-prevTangent.y, prevTangent.x);\n\tvec2 currNormal = vec2(-currTangent.y, currTangent.x);\n\tvec2 nextNormal = vec2(-nextTangent.y, nextTangent.x);\n\n\tvec2 startJoinDirection = normalize(prevTangent - currTangent);\n\tvec2 endJoinDirection = normalize(currTangent - nextTangent);\n\n\t// collapsed/unidirectional segment cases\n\t// FIXME: there should be more elegant solution\n\tvec2 prevTanDiff = abs(prevTangent - currTangent);\n\tvec2 nextTanDiff = abs(nextTangent - currTangent);\n\tif (max(prevTanDiff.x, prevTanDiff.y) < MIN_DIFF) {\n\t\tstartJoinDirection = currNormal;\n\t}\n\tif (max(nextTanDiff.x, nextTanDiff.y) < MIN_DIFF) {\n\t\tendJoinDirection = currNormal;\n\t}\n\tif (aCoord == bCoord) {\n\t\tendJoinDirection = startJoinDirection;\n\t\tcurrNormal = prevNormal;\n\t\tcurrTangent = prevTangent;\n\t}\n\n\ttangent = currTangent;\n\n\t//calculate join shifts relative to normals\n\tfloat startJoinShift = dot(currNormal, startJoinDirection);\n\tfloat endJoinShift = dot(currNormal, endJoinDirection);\n\n\tfloat startMiterRatio = abs(1. / startJoinShift);\n\tfloat endMiterRatio = abs(1. / endJoinShift);\n\n\tvec2 startJoin = startJoinDirection * startMiterRatio;\n\tvec2 endJoin = endJoinDirection * endMiterRatio;\n\n\tvec2 startTopJoin, startBotJoin, endTopJoin, endBotJoin;\n\tstartTopJoin = sign(startJoinShift) * startJoin * .5;\n\tstartBotJoin = -startTopJoin;\n\n\tendTopJoin = sign(endJoinShift) * endJoin * .5;\n\tendBotJoin = -endTopJoin;\n\n\tvec2 aTopCoord = aCoord + normalWidth * startTopJoin;\n\tvec2 bTopCoord = bCoord + normalWidth * endTopJoin;\n\tvec2 aBotCoord = aCoord + normalWidth * startBotJoin;\n\tvec2 bBotCoord = bCoord + normalWidth * endBotJoin;\n\n\t//miter anti-clipping\n\tfloat baClipping = distToLine(bCoord, aCoord, aBotCoord) / dot(normalize(normalWidth * endBotJoin), normalize(normalWidth.yx * vec2(-startBotJoin.y, startBotJoin.x)));\n\tfloat abClipping = distToLine(aCoord, bCoord, bTopCoord) / dot(normalize(normalWidth * startBotJoin), normalize(normalWidth.yx * vec2(-endBotJoin.y, endBotJoin.x)));\n\n\t//prevent close to reverse direction switch\n\tbool prevReverse = dot(currTangent, prevTangent) <= REVERSE_THRESHOLD && abs(dot(currTangent, prevNormal)) * min(length(prevDiff), length(currDiff)) < length(normalWidth * currNormal);\n\tbool nextReverse = dot(currTangent, nextTangent) <= REVERSE_THRESHOLD && abs(dot(currTangent, nextNormal)) * min(length(nextDiff), length(currDiff)) < length(normalWidth * currNormal);\n\n\tif (prevReverse) {\n\t\t//make join rectangular\n\t\tvec2 miterShift = normalWidth * startJoinDirection * miterLimit * .5;\n\t\tfloat normalAdjust = 1. - min(miterLimit / startMiterRatio, 1.);\n\t\taBotCoord = aCoord + miterShift - normalAdjust * normalWidth * currNormal * .5;\n\t\taTopCoord = aCoord + miterShift + normalAdjust * normalWidth * currNormal * .5;\n\t}\n\telse if (!nextReverse && baClipping > 0. && baClipping < length(normalWidth * endBotJoin)) {\n\t\t//handle miter clipping\n\t\tbTopCoord -= normalWidth * endTopJoin;\n\t\tbTopCoord += normalize(endTopJoin * normalWidth) * baClipping;\n\t}\n\n\tif (nextReverse) {\n\t\t//make join rectangular\n\t\tvec2 miterShift = normalWidth * endJoinDirection * miterLimit * .5;\n\t\tfloat normalAdjust = 1. - min(miterLimit / endMiterRatio, 1.);\n\t\tbBotCoord = bCoord + miterShift - normalAdjust * normalWidth * currNormal * .5;\n\t\tbTopCoord = bCoord + miterShift + normalAdjust * normalWidth * currNormal * .5;\n\t}\n\telse if (!prevReverse && abClipping > 0. && abClipping < length(normalWidth * startBotJoin)) {\n\t\t//handle miter clipping\n\t\taBotCoord -= normalWidth * startBotJoin;\n\t\taBotCoord += normalize(startBotJoin * normalWidth) * abClipping;\n\t}\n\n\tvec2 aTopPosition = (aTopCoord) * adjustedScale + translate;\n\tvec2 aBotPosition = (aBotCoord) * adjustedScale + translate;\n\n\tvec2 bTopPosition = (bTopCoord) * adjustedScale + translate;\n\tvec2 bBotPosition = (bBotCoord) * adjustedScale + translate;\n\n\t//position is normalized 0..1 coord on the screen\n\tvec2 position = (aTopPosition * lineTop + aBotPosition * lineBot) * lineStart + (bTopPosition * lineTop + bBotPosition * lineBot) * lineEnd;\n\n\tstartCoord = aCoord * scaleRatio + translate * viewport.zw + viewport.xy;\n\tendCoord = bCoord * scaleRatio + translate * viewport.zw + viewport.xy;\n\n\tgl_Position = vec4(position * 2.0 - 1.0, depth, 1);\n\n\tenableStartMiter = step(dot(currTangent, prevTangent), .5);\n\tenableEndMiter = step(dot(currTangent, nextTangent), .5);\n\n\t//bevel miter cutoffs\n\tif (miterMode == 1.) {\n\t\tif (enableStartMiter == 1.) {\n\t\t\tvec2 startMiterWidth = vec2(startJoinDirection) * thickness * miterLimit * .5;\n\t\t\tstartCutoff = vec4(aCoord, aCoord);\n\t\t\tstartCutoff.zw += vec2(-startJoinDirection.y, startJoinDirection.x) / scaleRatio;\n\t\t\tstartCutoff = startCutoff * scaleRatio.xyxy + translate.xyxy * viewport.zwzw;\n\t\t\tstartCutoff += viewport.xyxy;\n\t\t\tstartCutoff += startMiterWidth.xyxy;\n\t\t}\n\n\t\tif (enableEndMiter == 1.) {\n\t\t\tvec2 endMiterWidth = vec2(endJoinDirection) * thickness * miterLimit * .5;\n\t\t\tendCutoff = vec4(bCoord, bCoord);\n\t\t\tendCutoff.zw += vec2(-endJoinDirection.y, endJoinDirection.x) / scaleRatio;\n\t\t\tendCutoff = endCutoff * scaleRatio.xyxy + translate.xyxy * viewport.zwzw;\n\t\t\tendCutoff += viewport.xyxy;\n\t\t\tendCutoff += endMiterWidth.xyxy;\n\t\t}\n\t}\n\n\t//round miter cutoffs\n\telse if (miterMode == 2.) {\n\t\tif (enableStartMiter == 1.) {\n\t\t\tvec2 startMiterWidth = vec2(startJoinDirection) * thickness * abs(dot(startJoinDirection, currNormal)) * .5;\n\t\t\tstartCutoff = vec4(aCoord, aCoord);\n\t\t\tstartCutoff.zw += vec2(-startJoinDirection.y, startJoinDirection.x) / scaleRatio;\n\t\t\tstartCutoff = startCutoff * scaleRatio.xyxy + translate.xyxy * viewport.zwzw;\n\t\t\tstartCutoff += viewport.xyxy;\n\t\t\tstartCutoff += startMiterWidth.xyxy;\n\t\t}\n\n\t\tif (enableEndMiter == 1.) {\n\t\t\tvec2 endMiterWidth = vec2(endJoinDirection) * thickness * abs(dot(endJoinDirection, currNormal)) * .5;\n\t\t\tendCutoff = vec4(bCoord, bCoord);\n\t\t\tendCutoff.zw += vec2(-endJoinDirection.y, endJoinDirection.x) / scaleRatio;\n\t\t\tendCutoff = endCutoff * scaleRatio.xyxy + translate.xyxy * viewport.zwzw;\n\t\t\tendCutoff += viewport.xyxy;\n\t\t\tendCutoff += endMiterWidth.xyxy;\n\t\t}\n\t}\n}\n`\n\nconst milterFrag = `\nprecision highp float;\n\nuniform float dashLength, pixelRatio, thickness, opacity, id, miterMode;\nuniform sampler2D dashTexture;\n\nvarying vec4 fragColor;\nvarying vec2 tangent;\nvarying vec4 startCutoff, endCutoff;\nvarying vec2 startCoord, endCoord;\nvarying float enableStartMiter, enableEndMiter;\n\nfloat distToLine(vec2 p, vec2 a, vec2 b) {\n\tvec2 diff = b - a;\n\tvec2 perp = normalize(vec2(-diff.y, diff.x));\n\treturn dot(p - a, perp);\n}\n\nvoid main() {\n\tfloat alpha = 1., distToStart, distToEnd;\n\tfloat cutoff = thickness * .5;\n\n\t//bevel miter\n\tif (miterMode == 1.) {\n\t\tif (enableStartMiter == 1.) {\n\t\t\tdistToStart = distToLine(gl_FragCoord.xy, startCutoff.xy, startCutoff.zw);\n\t\t\tif (distToStart < -1.) {\n\t\t\t\tdiscard;\n\t\t\t\treturn;\n\t\t\t}\n\t\t\talpha *= min(max(distToStart + 1., 0.), 1.);\n\t\t}\n\n\t\tif (enableEndMiter == 1.) {\n\t\t\tdistToEnd = distToLine(gl_FragCoord.xy, endCutoff.xy, endCutoff.zw);\n\t\t\tif (distToEnd < -1.) {\n\t\t\t\tdiscard;\n\t\t\t\treturn;\n\t\t\t}\n\t\t\talpha *= min(max(distToEnd + 1., 0.), 1.);\n\t\t}\n\t}\n\n\t// round miter\n\telse if (miterMode == 2.) {\n\t\tif (enableStartMiter == 1.) {\n\t\t\tdistToStart = distToLine(gl_FragCoord.xy, startCutoff.xy, startCutoff.zw);\n\t\t\tif (distToStart < 0.) {\n\t\t\t\tfloat radius = length(gl_FragCoord.xy - startCoord);\n\n\t\t\t\tif(radius > cutoff + .5) {\n\t\t\t\t\tdiscard;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\talpha -= smoothstep(cutoff - .5, cutoff + .5, radius);\n\t\t\t}\n\t\t}\n\n\t\tif (enableEndMiter == 1.) {\n\t\t\tdistToEnd = distToLine(gl_FragCoord.xy, endCutoff.xy, endCutoff.zw);\n\t\t\tif (distToEnd < 0.) {\n\t\t\t\tfloat radius = length(gl_FragCoord.xy - endCoord);\n\n\t\t\t\tif(radius > cutoff + .5) {\n\t\t\t\t\tdiscard;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\talpha -= smoothstep(cutoff - .5, cutoff + .5, radius);\n\t\t\t}\n\t\t}\n\t}\n\n\tfloat t = fract(dot(tangent, gl_FragCoord.xy) / dashLength) * .5 + .25;\n\tfloat dash = texture2D(dashTexture, vec2(t, .5)).r;\n\n\tgl_FragColor = fragColor;\n\tgl_FragColor.a *= alpha * opacity * dash;\n}\n`\n\n\nmodule.exports = Line2D\n\n\n/** @constructor */\nfunction Line2D (regl, options) {\n\tif (!(this instanceof Line2D)) return new Line2D(regl, options)\n\n\tif (typeof regl === 'function') {\n\t\tif (!options) options = {}\n\t\toptions.regl = regl\n\t}\n\telse {\n\t\toptions = regl\n\t}\n\tif (options.length) options.positions = options\n\tregl = options.regl\n\n\tif (!regl.hasExtension('ANGLE_instanced_arrays')) {\n\t\tthrow Error('regl-error2d: `ANGLE_instanced_arrays` extension should be enabled');\n\t}\n\n\t// persistent variables\n\tthis.gl = regl._gl\n\tthis.regl = regl\n\n\t// list of options for lines\n\tthis.passes = []\n\n\t// cached shaders instance\n\tthis.shaders = Line2D.shaders.has(regl) ? Line2D.shaders.get(regl) : Line2D.shaders.set(regl, Line2D.createShaders(regl)).get(regl)\n\n\n\t// init defaults\n\tthis.update(options)\n}\n\n\nLine2D.dashMult = 2\nLine2D.maxPatternLength = 256\nLine2D.precisionThreshold = 3e6\nLine2D.maxPoints = 1e4\nLine2D.maxLines = 2048\n\n\n// cache of created draw calls per-regl instance\nLine2D.shaders = new WeakMap()\n\n\n// create static shaders once\nLine2D.createShaders = function (regl) {\n\tlet offsetBuffer = regl.buffer({\n\t\tusage: 'static',\n\t\ttype: 'float',\n\t\tdata: [0,1, 0,0, 1,1, 1,0]\n\t})\n\n\tlet shaderOptions = {\n\t\tprimitive: 'triangle strip',\n\t\tinstances: regl.prop('count'),\n\t\tcount: 4,\n\t\toffset: 0,\n\n\t\tuniforms: {\n\t\t\tmiterMode: (ctx, prop) => prop.join === 'round' ? 2 : 1,\n\t\t\tmiterLimit: regl.prop('miterLimit'),\n\t\t\tscale: regl.prop('scale'),\n\t\t\tscaleFract: regl.prop('scaleFract'),\n\t\t\ttranslateFract: regl.prop('translateFract'),\n\t\t\ttranslate: regl.prop('translate'),\n\t\t\tthickness: regl.prop('thickness'),\n\t\t\tdashTexture: regl.prop('dashTexture'),\n\t\t\topacity: regl.prop('opacity'),\n\t\t\tpixelRatio: regl.context('pixelRatio'),\n\t\t\tid: regl.prop('id'),\n\t\t\tdashLength: regl.prop('dashLength'),\n\t\t\tviewport: (c, p) => [p.viewport.x, p.viewport.y, c.viewportWidth, c.viewportHeight],\n\t\t\tdepth: regl.prop('depth')\n\t\t},\n\n\t\tblend: {\n\t\t\tenable: true,\n\t\t\tcolor: [0,0,0,0],\n\t\t\tequation: {\n\t\t\t\trgb: 'add',\n\t\t\t\talpha: 'add'\n\t\t\t},\n\t\t\tfunc: {\n\t\t\t\tsrcRGB: 'src alpha',\n\t\t\t\tdstRGB: 'one minus src alpha',\n\t\t\t\tsrcAlpha: 'one minus dst alpha',\n\t\t\t\tdstAlpha: 'one'\n\t\t\t}\n\t\t},\n\t\tdepth: {\n\t\t\tenable: (c, p) => {\n\t\t\t\treturn !p.overlay\n\t\t\t}\n\t\t},\n\t\tstencil: {enable: false},\n\t\tscissor: {\n\t\t\tenable: true,\n\t\t\tbox: regl.prop('viewport')\n\t\t},\n\t\tviewport: regl.prop('viewport')\n\t}\n\n\n\t// simplified rectangular line shader\n\tlet drawRectLine = regl(extend({\n\t\tvert: rectVert,\n\t\tfrag: rectFrag,\n\n\t\tattributes: {\n\t\t\t// if point is at the end of segment\n\t\t\tlineEnd: {\n\t\t\t\tbuffer: offsetBuffer,\n\t\t\t\tdivisor: 0,\n\t\t\t\tstride: 8,\n\t\t\t\toffset: 0\n\t\t\t},\n\t\t\t// if point is at the top of segment\n\t\t\tlineTop: {\n\t\t\t\tbuffer: offsetBuffer,\n\t\t\t\tdivisor: 0,\n\t\t\t\tstride: 8,\n\t\t\t\toffset: 4\n\t\t\t},\n\t\t\t// beginning of line coordinate\n\t\t\taCoord: {\n\t\t\t\tbuffer: regl.prop('positionBuffer'),\n\t\t\t\tstride: 8,\n\t\t\t\toffset: 8,\n\t\t\t\tdivisor: 1\n\t\t\t},\n\t\t\t// end of line coordinate\n\t\t\tbCoord: {\n\t\t\t\tbuffer: regl.prop('positionBuffer'),\n\t\t\t\tstride: 8,\n\t\t\t\toffset: 16,\n\t\t\t\tdivisor: 1\n\t\t\t},\n\t\t\taCoordFract: {\n\t\t\t\tbuffer: regl.prop('positionFractBuffer'),\n\t\t\t\tstride: 8,\n\t\t\t\toffset: 8,\n\t\t\t\tdivisor: 1\n\t\t\t},\n\t\t\tbCoordFract: {\n\t\t\t\tbuffer: regl.prop('positionFractBuffer'),\n\t\t\t\tstride: 8,\n\t\t\t\toffset: 16,\n\t\t\t\tdivisor: 1\n\t\t\t},\n\t\t\tcolor: {\n\t\t\t\tbuffer: regl.prop('colorBuffer'),\n\t\t\t\tstride: 4,\n\t\t\t\toffset: 0,\n\t\t\t\tdivisor: 1\n\t\t\t}\n\t\t}\n\t}, shaderOptions))\n\n\t// create regl draw\n\tlet drawMiterLine\n\n\ttry {\n\t\tdrawMiterLine = regl(extend({\n\t\t\t// culling removes polygon creasing\n\t\t\tcull: {\n\t\t\t\tenable: true,\n\t\t\t\tface: 'back'\n\t\t\t},\n\n\t\t\tvert: milterVert,\n\t\t\tfrag: milterFrag,\n\n\t\t\tattributes: {\n\t\t\t\t// is line end\n\t\t\t\tlineEnd: {\n\t\t\t\t\tbuffer: offsetBuffer,\n\t\t\t\t\tdivisor: 0,\n\t\t\t\t\tstride: 8,\n\t\t\t\t\toffset: 0\n\t\t\t\t},\n\t\t\t\t// is line top\n\t\t\t\tlineTop: {\n\t\t\t\t\tbuffer: offsetBuffer,\n\t\t\t\t\tdivisor: 0,\n\t\t\t\t\tstride: 8,\n\t\t\t\t\toffset: 4\n\t\t\t\t},\n\t\t\t\t// left color\n\t\t\t\taColor: {\n\t\t\t\t\tbuffer: regl.prop('colorBuffer'),\n\t\t\t\t\tstride: 4,\n\t\t\t\t\toffset: 0,\n\t\t\t\t\tdivisor: 1\n\t\t\t\t},\n\t\t\t\t// right color\n\t\t\t\tbColor: {\n\t\t\t\t\tbuffer: regl.prop('colorBuffer'),\n\t\t\t\t\tstride: 4,\n\t\t\t\t\toffset: 4,\n\t\t\t\t\tdivisor: 1\n\t\t\t\t},\n\t\t\t\tprevCoord: {\n\t\t\t\t\tbuffer: regl.prop('positionBuffer'),\n\t\t\t\t\tstride: 8,\n\t\t\t\t\toffset: 0,\n\t\t\t\t\tdivisor: 1\n\t\t\t\t},\n\t\t\t\taCoord: {\n\t\t\t\t\tbuffer: regl.prop('positionBuffer'),\n\t\t\t\t\tstride: 8,\n\t\t\t\t\toffset: 8,\n\t\t\t\t\tdivisor: 1\n\t\t\t\t},\n\t\t\t\tbCoord: {\n\t\t\t\t\tbuffer: regl.prop('positionBuffer'),\n\t\t\t\t\tstride: 8,\n\t\t\t\t\toffset: 16,\n\t\t\t\t\tdivisor: 1\n\t\t\t\t},\n\t\t\t\tnextCoord: {\n\t\t\t\t\tbuffer: regl.prop('positionBuffer'),\n\t\t\t\t\tstride: 8,\n\t\t\t\t\toffset: 24,\n\t\t\t\t\tdivisor: 1\n\t\t\t\t}\n\t\t\t}\n\t\t}, shaderOptions))\n\t} catch (e) {\n\t\t// IE/bad Webkit fallback\n\t\tdrawMiterLine = drawRectLine\n\t}\n\n\t// fill shader\n\tlet drawFill = regl({\n\t\tprimitive: 'triangle',\n\t\telements: (ctx, prop) => prop.triangles,\n\t\toffset: 0,\n\n\t\tvert: fillVert,\n\t\tfrag: fillFrag,\n\n\t\tuniforms: {\n\t\t\tscale: regl.prop('scale'),\n\t\t\tcolor: regl.prop('fill'),\n\t\t\tscaleFract: regl.prop('scaleFract'),\n\t\t\ttranslateFract: regl.prop('translateFract'),\n\t\t\ttranslate: regl.prop('translate'),\n\t\t\topacity: regl.prop('opacity'),\n\t\t\tpixelRatio: regl.context('pixelRatio'),\n\t\t\tid: regl.prop('id'),\n\t\t\tviewport: (ctx, prop) => [prop.viewport.x, prop.viewport.y, ctx.viewportWidth, ctx.viewportHeight]\n\t\t},\n\n\t\tattributes: {\n\t\t\tposition: {\n\t\t\t\tbuffer: regl.prop('positionBuffer'),\n\t\t\t\tstride: 8,\n\t\t\t\toffset: 8\n\t\t\t},\n\t\t\tpositionFract: {\n\t\t\t\tbuffer: regl.prop('positionFractBuffer'),\n\t\t\t\tstride: 8,\n\t\t\t\toffset: 8\n\t\t\t}\n\t\t},\n\n\t\tblend: shaderOptions.blend,\n\n\t\tdepth: { enable: false },\n\t\tscissor: shaderOptions.scissor,\n\t\tstencil: shaderOptions.stencil,\n\t\tviewport: shaderOptions.viewport\n\t})\n\n\treturn {\n\t\tfill: drawFill, rect: drawRectLine, miter: drawMiterLine\n\t}\n}\n\n\n// used to for new lines instances\nLine2D.defaults = {\n\tdashes: null,\n\tjoin: 'miter',\n\tmiterLimit: 1,\n\tthickness: 10,\n\tcap: 'square',\n\tcolor: 'black',\n\topacity: 1,\n\toverlay: false,\n\tviewport: null,\n\trange: null,\n\tclose: false,\n\tfill: null\n}\n\n\nLine2D.prototype.render = function (...args) {\n\tif (args.length) {\n\t\tthis.update(...args)\n\t}\n\n\tthis.draw()\n}\n\n\nLine2D.prototype.draw = function (...args) {\n\t// render multiple polylines via regl batch\n\t(args.length ? args : this.passes).forEach((s, i) => {\n\t\t// render array pass as a list of passes\n\t\tif (s && Array.isArray(s)) return this.draw(...s)\n\n\t\tif (typeof s === 'number') s = this.passes[s]\n\n\t\tif (!(s && s.count > 1 && s.opacity)) return\n\n\t\tthis.regl._refresh()\n\n\t\tif (s.fill && s.triangles && s.triangles.length > 2) {\n\t\t\tthis.shaders.fill(s)\n\t\t}\n\n\t\tif (!s.thickness) return\n\n\t\t// high scale is only available for rect mode with precision\n\t\tif (s.scale[0] * s.viewport.width > Line2D.precisionThreshold || s.scale[1] * s.viewport.height > Line2D.precisionThreshold) {\n\t\t\tthis.shaders.rect(s)\n\t\t}\n\n\t\t// thin this.passes or too many points are rendered as simplified rect shader\n\t\telse if (s.join === 'rect' || (!s.join && (s.thickness <= 2 || s.count >= Line2D.maxPoints))) {\n\t\t\tthis.shaders.rect(s)\n\t\t}\n\t\telse {\n\t\t\tthis.shaders.miter(s)\n\t\t}\n\t})\n\n\treturn this\n}\n\nLine2D.prototype.update = function (options) {\n\tif (!options) return\n\n\tif (options.length != null) {\n\t\tif (typeof options[0] === 'number') options = [{positions: options}]\n\t}\n\n\t// make options a batch\n\telse if (!Array.isArray(options)) options = [options]\n\n\tlet { regl, gl } = this\n\n\t// process per-line settings\n\toptions.forEach((o, i) => {\n\t\tlet state = this.passes[i]\n\n\t\tif (o === undefined) return\n\n\t\t// null-argument removes pass\n\t\tif (o === null) {\n\t\t\tthis.passes[i] = null\n\t\t\treturn\n\t\t}\n\n\t\tif (typeof o[0] === 'number') o = {positions: o}\n\n\t\t// handle aliases\n\t\to = pick(o, {\n\t\t\tpositions: 'positions points data coords',\n\t\t\tthickness: 'thickness lineWidth lineWidths line-width linewidth width stroke-width strokewidth strokeWidth',\n\t\t\tjoin: 'lineJoin linejoin join type mode',\n\t\t\tmiterLimit: 'miterlimit miterLimit',\n\t\t\tdashes: 'dash dashes dasharray dash-array dashArray',\n\t\t\tcolor: 'color colour stroke colors colours stroke-color strokeColor',\n\t\t\tfill: 'fill fill-color fillColor',\n\t\t\topacity: 'alpha opacity',\n\t\t\toverlay: 'overlay crease overlap intersect',\n\t\t\tclose: 'closed close closed-path closePath',\n\t\t\trange: 'range dataBox',\n\t\t\tviewport: 'viewport viewBox',\n\t\t\thole: 'holes hole hollow',\n\t\t\tsplitNull: 'splitNull'\n\t\t})\n\n\t\t// init state\n\t\tif (!state) {\n\t\t\tthis.passes[i] = state = {\n\t\t\t\tid: i,\n\t\t\t\tscale: null,\n\t\t\t\tscaleFract: null,\n\t\t\t\ttranslate: null,\n\t\t\t\ttranslateFract: null,\n\t\t\t\tcount: 0,\n\t\t\t\thole: [],\n\t\t\t\tdepth: 0,\n\n\t\t\t\tdashLength: 1,\n\t\t\t\tdashTexture: regl.texture({\n\t\t\t\t\tchannels: 1,\n\t\t\t\t\tdata: new Uint8Array([255]),\n\t\t\t\t\twidth: 1,\n\t\t\t\t\theight: 1,\n\t\t\t\t\tmag: 'linear',\n\t\t\t\t\tmin: 'linear'\n\t\t\t\t}),\n\n\t\t\t\tcolorBuffer: regl.buffer({\n\t\t\t\t\tusage: 'dynamic',\n\t\t\t\t\ttype: 'uint8',\n\t\t\t\t\tdata: new Uint8Array()\n\t\t\t\t}),\n\t\t\t\tpositionBuffer: regl.buffer({\n\t\t\t\t\tusage: 'dynamic',\n\t\t\t\t\ttype: 'float',\n\t\t\t\t\tdata: new Uint8Array()\n\t\t\t\t}),\n\t\t\t\tpositionFractBuffer: regl.buffer({\n\t\t\t\t\tusage: 'dynamic',\n\t\t\t\t\ttype: 'float',\n\t\t\t\t\tdata: new Uint8Array()\n\t\t\t\t})\n\t\t\t}\n\n\t\t\to = extend({}, Line2D.defaults, o)\n\t\t}\n\t\tif (o.thickness != null) state.thickness = parseFloat(o.thickness)\n\t\tif (o.opacity != null) state.opacity = parseFloat(o.opacity)\n\t\tif (o.miterLimit != null) state.miterLimit = parseFloat(o.miterLimit)\n\t\tif (o.overlay != null) {\n\t\t\tstate.overlay = !!o.overlay\n\t\t\tif (i < Line2D.maxLines) {\n\t\t\t\tstate.depth = 2 * (Line2D.maxLines - 1 - i % Line2D.maxLines) / Line2D.maxLines - 1.;\n\t\t\t}\n\t\t}\n\t\tif (o.join != null) state.join = o.join\n\t\tif (o.hole != null) state.hole = o.hole\n\t\tif (o.fill != null) state.fill = !o.fill ? null : rgba(o.fill, 'uint8')\n\t\tif (o.viewport != null) state.viewport = parseRect(o.viewport)\n\n\t\tif (!state.viewport) {\n\t\t\tstate.viewport = parseRect([\n\t\t\t\tgl.drawingBufferWidth,\n\t\t\t\tgl.drawingBufferHeight\n\t\t\t])\n\t\t}\n\n\t\tif (o.close != null) state.close = o.close\n\n\t\t// reset positions\n\t\tif (o.positions === null) o.positions = []\n\t\tif (o.positions) {\n\t\t\tlet positions, count\n\n\t\t\t// if positions are an object with x/y\n\t\t\tif (o.positions.x && o.positions.y) {\n\t\t\t\tlet xPos = o.positions.x\n\t\t\t\tlet yPos = o.positions.y\n\t\t\t\tcount = state.count = Math.max(\n\t\t\t\t\txPos.length,\n\t\t\t\t\tyPos.length\n\t\t\t\t)\n\t\t\t\tpositions = new Float64Array(count * 2)\n\t\t\t\tfor (let i = 0; i < count; i++) {\n\t\t\t\t\tpositions[i * 2] = xPos[i]\n\t\t\t\t\tpositions[i * 2 + 1] = yPos[i]\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tpositions = flatten(o.positions, 'float64')\n\t\t\t\tcount = state.count = Math.floor(positions.length / 2)\n\t\t\t}\n\n\t\t\tlet bounds = state.bounds = getBounds(positions, 2)\n\n\t\t\t// create fill positions\n\t\t\t// FIXME: fill positions can be set only along with positions\n\t\t\tif (state.fill) {\n\t\t\t\tlet pos = []\n\n\t\t\t\t// filter bad vertices and remap triangles to ensure shape\n\t\t\t\tlet ids = {}\n\t\t\t\tlet lastId = 0\n\n\t\t\t\tfor (let i = 0, ptr = 0, l = state.count; i < l; i++) {\n\t\t\t\t\tlet x = positions[i*2]\n\t\t\t\t\tlet y = positions[i*2 + 1]\n\t\t\t\t\tif (isNaN(x) || isNaN(y) || x == null || y == null) {\n\t\t\t\t\t\tx = positions[lastId*2]\n\t\t\t\t\t\ty = positions[lastId*2 + 1]\n\t\t\t\t\t\tids[i] = lastId\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tlastId = i\n\t\t\t\t\t}\n\t\t\t\t\tpos[ptr++] = x\n\t\t\t\t\tpos[ptr++] = y\n\t\t\t\t}\n\n\t\t\t\t// split the input into multiple polygon at Null/NaN\n\t\t\t\tif(o.splitNull){\n\t\t\t\t\t// use \"ids\" to track the boundary of segment\n\t\t\t\t\t// the keys in \"ids\" is the end boundary of a segment, or split point\n\n\t\t\t\t\t// make sure there is at least one segment\n\t\t\t\t\tif(!(state.count-1 in ids)) ids[state.count] = state.count-1\n\n\t\t\t\t\tlet splits = Object.keys(ids).map(Number).sort((a, b) => a - b)\n\n\t\t\t\t\tlet split_triangles = []\n\t\t\t\t\tlet base = 0\n\n\t\t\t\t\t// do not split holes\n\t\t\t\t\tlet hole_base = state.hole != null ? state.hole[0] : null\n\t\t\t\t\tif(hole_base != null){\n\t\t\t\t\t\tlet last_id = findIndex(splits, (e)=>e>=hole_base)\n\t\t\t\t\t\tsplits = splits.slice(0,last_id)\n\t\t\t\t\t\tsplits.push(hole_base)\n\t\t\t\t\t}\n\n\t\t\t\t\tfor (let i = 0; i < splits.length; i++)\n\t\t\t\t\t{\n\t\t\t\t\t\t// create temporary pos array with only one segment and all the holes\n\t\t\t\t\t\tlet seg_pos = pos.slice(base*2, splits[i]*2).concat(\n\t\t\t\t\t\t\thole_base ? pos.slice(hole_base*2) : []\n\t\t\t\t\t\t)\n\t\t\t\t\t\tlet hole = (state.hole || []).map((e) => e-hole_base+(splits[i]-base) )\n\t\t\t\t\t\tlet triangles = triangulate(seg_pos, hole)\n\t\t\t\t\t\t// map triangle index back to the original pos buffer\n\t\t\t\t\t\ttriangles = triangles.map(\n\t\t\t\t\t\t\t(e)=> e + base + ((e + base < splits[i]) ? 0 : hole_base - splits[i])\n\t\t\t\t\t\t)\n\t\t\t\t\t\tsplit_triangles.push(...triangles)\n\n\t\t\t\t\t\t// skip split point\n\t\t\t\t\t\tbase = splits[i] + 1\n\t\t\t\t\t}\n\t\t\t\t\tfor (let i = 0, l = split_triangles.length; i < l; i++) {\n\t\t\t\t\t\tif (ids[split_triangles[i]] != null) split_triangles[i] = ids[split_triangles[i]]\n\t\t\t\t\t}\n\n\t\t\t\t\tstate.triangles = split_triangles\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\t// treat the wholw input as a single polygon\n\t\t\t\t\tlet triangles = triangulate(pos, state.hole || [])\n\n\t\t\t\t\tfor (let i = 0, l = triangles.length; i < l; i++) {\n\t\t\t\t\t\tif (ids[triangles[i]] != null) triangles[i] = ids[triangles[i]]\n\t\t\t\t\t}\n\n\t\t\t\t\tstate.triangles = triangles\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// update position buffers\n\t\t\tlet npos = new Float64Array(positions)\n\t\t\tnormalize(npos, 2, bounds)\n\n\t\t\tlet positionData = new Float64Array(count * 2 + 6)\n\n\t\t\t// rotate first segment join\n\t\t\tif (state.close) {\n\t\t\t\tif (positions[0] === positions[count*2 - 2] &&\n\t\t\t\t\tpositions[1] === positions[count*2 - 1]) {\n\t\t\t\t\tpositionData[0] = npos[count*2 - 4]\n\t\t\t\t\tpositionData[1] = npos[count*2 - 3]\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tpositionData[0] = npos[count*2 - 2]\n\t\t\t\t\tpositionData[1] = npos[count*2 - 1]\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tpositionData[0] = npos[0]\n\t\t\t\tpositionData[1] = npos[1]\n\t\t\t}\n\n\t\t\tpositionData.set(npos, 2)\n\n\t\t\t// add last segment\n\t\t\tif (state.close) {\n\t\t\t\t// ignore coinciding start/end\n\t\t\t\tif (positions[0] === positions[count*2 - 2] &&\n\t\t\t\t\tpositions[1] === positions[count*2 - 1]) {\n\t\t\t\t\tpositionData[count*2 + 2] = npos[2]\n\t\t\t\t\tpositionData[count*2 + 3] = npos[3]\n\t\t\t\t\tstate.count -= 1\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tpositionData[count*2 + 2] = npos[0]\n\t\t\t\t\tpositionData[count*2 + 3] = npos[1]\n\t\t\t\t\tpositionData[count*2 + 4] = npos[2]\n\t\t\t\t\tpositionData[count*2 + 5] = npos[3]\n\t\t\t\t}\n\t\t\t}\n\t\t\t// add stub\n\t\t\telse {\n\t\t\t\tpositionData[count*2 + 2] = npos[count*2 - 2]\n\t\t\t\tpositionData[count*2 + 3] = npos[count*2 - 1]\n\t\t\t\tpositionData[count*2 + 4] = npos[count*2 - 2]\n\t\t\t\tpositionData[count*2 + 5] = npos[count*2 - 1]\n\t\t\t}\n\n\t\t\tvar float_data = float32(positionData)\n\t\t\tstate.positionBuffer(float_data)\n\t\t\tvar frac_data = fract32(positionData, float_data)\n\t\t\tstate.positionFractBuffer(frac_data)\n\t\t}\n\n\t\tif (o.range) {\n\t\t\tstate.range = o.range\n\t\t} else if (!state.range) {\n\t\t\tstate.range = state.bounds\n\t\t}\n\n\t\tif ((o.range || o.positions) && state.count) {\n\t\t\tlet bounds = state.bounds\n\n\t\t\tlet boundsW = bounds[2] - bounds[0],\n\t\t\t\tboundsH = bounds[3] - bounds[1]\n\n\t\t\tlet rangeW = state.range[2] - state.range[0],\n\t\t\t\trangeH = state.range[3] - state.range[1]\n\n\t\t\tstate.scale = [\n\t\t\t\tboundsW / rangeW,\n\t\t\t\tboundsH / rangeH\n\t\t\t]\n\t\t\tstate.translate = [\n\t\t\t\t-state.range[0] / rangeW + bounds[0] / rangeW || 0,\n\t\t\t\t-state.range[1] / rangeH + bounds[1] / rangeH || 0\n\t\t\t]\n\n\t\t\tstate.scaleFract = fract32(state.scale)\n\t\t\tstate.translateFract = fract32(state.translate)\n\t\t}\n\n\t\tif (o.dashes) {\n\t\t\tlet dashLength = 0., dashData\n\n\t\t\tif (!o.dashes || o.dashes.length < 2) {\n\t\t\t\tdashLength = 1.\n\t\t\t\tdashData = new Uint8Array([255, 255, 255, 255, 255, 255, 255, 255])\n\t\t\t}\n\n\t\t\telse {\n\t\t\t\tdashLength = 0.;\n\t\t\t\tfor(let i = 0; i < o.dashes.length; ++i) {\n\t\t\t\t\tdashLength += o.dashes[i]\n\t\t\t\t}\n\t\t\t\tdashData = new Uint8Array(dashLength * Line2D.dashMult)\n\t\t\t\tlet ptr = 0\n\t\t\t\tlet fillColor = 255\n\n\t\t\t\t// repeat texture two times to provide smooth 0-step\n\t\t\t\tfor (let k = 0; k < 2; k++) {\n\t\t\t\t\tfor(let i = 0; i < o.dashes.length; ++i) {\n\t\t\t\t\t\tfor(let j = 0, l = o.dashes[i] * Line2D.dashMult * .5; j < l; ++j) {\n\t\t\t\t\t\t\tdashData[ptr++] = fillColor\n\t\t\t\t\t\t}\n\t\t\t\t\t\tfillColor ^= 255\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tstate.dashLength = dashLength\n\t\t\tstate.dashTexture({\n\t\t\t\tchannels: 1,\n\t\t\t\tdata: dashData,\n\t\t\t\twidth: dashData.length,\n\t\t\t\theight: 1,\n\t\t\t\tmag: 'linear',\n\t\t\t\tmin: 'linear'\n\t\t\t}, 0, 0)\n\t\t}\n\n\t\tif (o.color) {\n\t\t\tlet count = state.count\n\t\t\tlet colors = o.color\n\n\t\t\tif (!colors) colors = 'transparent'\n\n\t\t\tlet colorData = new Uint8Array(count * 4 + 4)\n\n\t\t\t// convert colors to typed arrays\n\t\t\tif (!Array.isArray(colors) || typeof colors[0] === 'number') {\n\t\t\t\tlet c = rgba(colors, 'uint8')\n\n\t\t\t\tfor (let i = 0; i < count + 1; i++) {\n\t\t\t\t\tcolorData.set(c, i * 4)\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tfor (let i = 0; i < count; i++) {\n\t\t\t\t\tlet c = rgba(colors[i], 'uint8')\n\t\t\t\t\tcolorData.set(c, i * 4)\n\t\t\t\t}\n\t\t\t\tcolorData.set(rgba(colors[0], 'uint8'), count * 4)\n\t\t\t}\n\n\t\t\tstate.colorBuffer({\n\t\t\t\tusage: 'dynamic',\n\t\t\t\ttype: 'uint8',\n\t\t\t\tdata: colorData\n\t\t\t})\n\t\t}\n\t})\n\n\t// remove unmentioned passes\n\tif (options.length < this.passes.length) {\n\t\tfor (let i = options.length; i < this.passes.length; i++) {\n\t\t\tlet pass = this.passes[i]\n\t\t\tif (!pass) continue\n\t\t\tpass.colorBuffer.destroy()\n\t\t\tpass.positionBuffer.destroy()\n\t\t\tpass.dashTexture.destroy()\n\t\t}\n\t\tthis.passes.length = options.length\n\t}\n\n\t// remove null items\n\tlet passes = []\n\tfor (let i = 0; i < this.passes.length; i++) {\n\t\tif (this.passes[i] !== null) passes.push(this.passes[i])\n\t}\n\tthis.passes = passes\n\n\treturn this\n}\n\nLine2D.prototype.destroy = function () {\n\tthis.passes.forEach(pass => {\n\t\tpass.colorBuffer.destroy()\n\t\tpass.positionBuffer.destroy()\n\t\tpass.dashTexture.destroy()\n\t})\n\n\tthis.passes.length = 0\n\n\treturn this\n}\n","'use strict';\n\nfunction _iterableToArrayLimit(arr, i) {\n var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (null != _i) {\n var _s,\n _e,\n _x,\n _r,\n _arr = [],\n _n = !0,\n _d = !1;\n try {\n if (_x = (_i = _i.call(arr)).next, 0 === i) {\n if (Object(_i) !== _i) return;\n _n = !1;\n } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0);\n } catch (err) {\n _d = !0, _e = err;\n } finally {\n try {\n if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return;\n } finally {\n if (_d) throw _e;\n }\n }\n return _arr;\n }\n}\nfunction _slicedToArray(arr, i) {\n return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();\n}\nfunction _toConsumableArray(arr) {\n return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();\n}\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return _arrayLikeToArray(arr);\n}\nfunction _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\nfunction _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);\n}\nfunction _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n return arr2;\n}\nfunction _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\nvar rgba = require('color-normalize');\nvar getBounds = require('array-bounds');\nvar colorId = require('color-id');\nvar cluster = require('@plotly/point-cluster');\nvar extend = require('object-assign');\nvar glslify = require('glslify');\nvar pick = require('pick-by-alias');\nvar updateDiff = require('update-diff');\nvar flatten = require('flatten-vertex-data');\nvar ie = require('is-iexplorer');\nvar f32 = require('to-float32');\nvar parseRect = require('parse-rect');\nvar scatter = Scatter;\nfunction Scatter(regl, options) {\n var _this = this;\n if (!(this instanceof Scatter)) return new Scatter(regl, options);\n if (typeof regl === 'function') {\n if (!options) options = {};\n options.regl = regl;\n } else {\n options = regl;\n regl = null;\n }\n if (options && options.length) options.positions = options;\n regl = options.regl;\n\n // persistent variables\n var gl = regl._gl,\n paletteTexture,\n palette = [],\n paletteIds = {},\n // state\n groups = [],\n // textures for marker keys\n markerTextures = [null],\n markerCache = [null];\n var maxColors = 255,\n maxSize = 100;\n\n // direct color buffer mode\n // IE does not support palette anyways\n this.tooManyColors = ie;\n\n // texture with color palette\n paletteTexture = regl.texture({\n data: new Uint8Array(maxColors * 4),\n width: maxColors,\n height: 1,\n type: 'uint8',\n format: 'rgba',\n wrapS: 'clamp',\n wrapT: 'clamp',\n mag: 'nearest',\n min: 'nearest'\n });\n extend(this, {\n regl: regl,\n gl: gl,\n groups: groups,\n markerCache: markerCache,\n markerTextures: markerTextures,\n palette: palette,\n paletteIds: paletteIds,\n paletteTexture: paletteTexture,\n maxColors: maxColors,\n maxSize: maxSize,\n canvas: gl.canvas\n });\n this.update(options);\n\n // common shader options\n var shaderOptions = {\n uniforms: {\n constPointSize: !!options.constPointSize,\n opacity: regl.prop('opacity'),\n paletteSize: function paletteSize(ctx, prop) {\n return [_this.tooManyColors ? 0 : maxColors, paletteTexture.height];\n },\n pixelRatio: regl.context('pixelRatio'),\n scale: regl.prop('scale'),\n scaleFract: regl.prop('scaleFract'),\n translate: regl.prop('translate'),\n translateFract: regl.prop('translateFract'),\n markerTexture: regl.prop('markerTexture'),\n paletteTexture: paletteTexture\n },\n attributes: {\n // FIXME: optimize these parts\n x: function x(ctx, prop) {\n return prop.xAttr || {\n buffer: prop.positionBuffer,\n stride: 8,\n offset: 0\n };\n },\n y: function y(ctx, prop) {\n return prop.yAttr || {\n buffer: prop.positionBuffer,\n stride: 8,\n offset: 4\n };\n },\n xFract: function xFract(ctx, prop) {\n return prop.xAttr ? {\n constant: [0, 0]\n } : {\n buffer: prop.positionFractBuffer,\n stride: 8,\n offset: 0\n };\n },\n yFract: function yFract(ctx, prop) {\n return prop.yAttr ? {\n constant: [0, 0]\n } : {\n buffer: prop.positionFractBuffer,\n stride: 8,\n offset: 4\n };\n },\n size: function size(ctx, prop) {\n return prop.size.length ? {\n buffer: prop.sizeBuffer,\n stride: 2,\n offset: 0\n } : {\n constant: [Math.round(prop.size * 255 / _this.maxSize)]\n };\n },\n borderSize: function borderSize(ctx, prop) {\n return prop.borderSize.length ? {\n buffer: prop.sizeBuffer,\n stride: 2,\n offset: 1\n } : {\n constant: [Math.round(prop.borderSize * 255 / _this.maxSize)]\n };\n },\n colorId: function colorId(ctx, prop) {\n return prop.color.length ? {\n buffer: prop.colorBuffer,\n stride: _this.tooManyColors ? 8 : 4,\n offset: 0\n } : {\n constant: _this.tooManyColors ? palette.slice(prop.color * 4, prop.color * 4 + 4) : [prop.color]\n };\n },\n borderColorId: function borderColorId(ctx, prop) {\n return prop.borderColor.length ? {\n buffer: prop.colorBuffer,\n stride: _this.tooManyColors ? 8 : 4,\n offset: _this.tooManyColors ? 4 : 2\n } : {\n constant: _this.tooManyColors ? palette.slice(prop.borderColor * 4, prop.borderColor * 4 + 4) : [prop.borderColor]\n };\n },\n isActive: function isActive(ctx, prop) {\n return prop.activation === true ? {\n constant: [1]\n } : prop.activation ? prop.activation : {\n constant: [0]\n };\n }\n },\n blend: {\n enable: true,\n color: [0, 0, 0, 1],\n // photoshop blending\n func: {\n srcRGB: 'src alpha',\n dstRGB: 'one minus src alpha',\n srcAlpha: 'one minus dst alpha',\n dstAlpha: 'one'\n }\n },\n scissor: {\n enable: true,\n box: regl.prop('viewport')\n },\n viewport: regl.prop('viewport'),\n stencil: {\n enable: false\n },\n depth: {\n enable: false\n },\n elements: regl.prop('elements'),\n count: regl.prop('count'),\n offset: regl.prop('offset'),\n primitive: 'points'\n };\n\n // draw sdf-marker\n var markerOptions = extend({}, shaderOptions);\n markerOptions.frag = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nuniform float opacity;\\nuniform sampler2D markerTexture;\\n\\nvarying vec4 fragColor, fragBorderColor;\\nvarying float fragWidth, fragBorderColorLevel, fragColorLevel;\\n\\nfloat smoothStep(float x, float y) {\\n return 1.0 / (1.0 + exp(50.0*(x - y)));\\n}\\n\\nvoid main() {\\n float dist = texture2D(markerTexture, gl_PointCoord).r, delta = fragWidth;\\n\\n // max-distance alpha\\n if (dist < 0.003) discard;\\n\\n // null-border case\\n if (fragBorderColorLevel == fragColorLevel || fragBorderColor.a == 0.) {\\n float colorAmt = smoothstep(.5 - delta, .5 + delta, dist);\\n gl_FragColor = vec4(fragColor.rgb, colorAmt * fragColor.a * opacity);\\n }\\n else {\\n float borderColorAmt = smoothstep(fragBorderColorLevel - delta, fragBorderColorLevel + delta, dist);\\n float colorAmt = smoothstep(fragColorLevel - delta, fragColorLevel + delta, dist);\\n\\n vec4 color = fragBorderColor;\\n color.a *= borderColorAmt;\\n color = mix(color, fragColor, colorAmt);\\n color.a *= opacity;\\n\\n gl_FragColor = color;\\n }\\n\\n}\\n\"]);\n markerOptions.vert = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nattribute float x, y, xFract, yFract;\\nattribute float size, borderSize;\\nattribute vec4 colorId, borderColorId;\\nattribute float isActive;\\n\\n// `invariant` effectively turns off optimizations for the position.\\n// We need this because -fast-math on M1 Macs is re-ordering\\n// floating point operations in a way that causes floating point\\n// precision limits to put points in the wrong locations.\\ninvariant gl_Position;\\n\\nuniform bool constPointSize;\\nuniform float pixelRatio;\\nuniform vec2 scale, scaleFract, translate, translateFract, paletteSize;\\nuniform sampler2D paletteTexture;\\n\\nconst float maxSize = 100.;\\nconst float borderLevel = .5;\\n\\nvarying vec4 fragColor, fragBorderColor;\\nvarying float fragPointSize, fragBorderRadius, fragWidth, fragBorderColorLevel, fragColorLevel;\\n\\nfloat pointSizeScale = (constPointSize) ? 2. : pixelRatio;\\n\\nbool isDirect = (paletteSize.x < 1.);\\n\\nvec4 getColor(vec4 id) {\\n return isDirect ? id / 255. : texture2D(paletteTexture,\\n vec2(\\n (id.x + .5) / paletteSize.x,\\n (id.y + .5) / paletteSize.y\\n )\\n );\\n}\\n\\nvoid main() {\\n // ignore inactive points\\n if (isActive == 0.) return;\\n\\n vec2 position = vec2(x, y);\\n vec2 positionFract = vec2(xFract, yFract);\\n\\n vec4 color = getColor(colorId);\\n vec4 borderColor = getColor(borderColorId);\\n\\n float size = size * maxSize / 255.;\\n float borderSize = borderSize * maxSize / 255.;\\n\\n gl_PointSize = 2. * size * pointSizeScale;\\n fragPointSize = size * pixelRatio;\\n\\n vec2 pos = (position + translate) * scale\\n + (positionFract + translateFract) * scale\\n + (position + translate) * scaleFract\\n + (positionFract + translateFract) * scaleFract;\\n\\n gl_Position = vec4(pos * 2. - 1., 0., 1.);\\n\\n fragColor = color;\\n fragBorderColor = borderColor;\\n fragWidth = 1. / gl_PointSize;\\n\\n fragBorderColorLevel = clamp(borderLevel - borderLevel * borderSize / size, 0., 1.);\\n fragColorLevel = clamp(borderLevel + (1. - borderLevel) * borderSize / size, 0., 1.);\\n}\\n\"]);\n this.drawMarker = regl(markerOptions);\n\n // draw circle\n var circleOptions = extend({}, shaderOptions);\n circleOptions.frag = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nvarying vec4 fragColor, fragBorderColor;\\nvarying float fragBorderRadius, fragWidth;\\n\\nuniform float opacity;\\n\\nfloat smoothStep(float edge0, float edge1, float x) {\\n\\tfloat t;\\n\\tt = clamp((x - edge0) / (edge1 - edge0), 0.0, 1.0);\\n\\treturn t * t * (3.0 - 2.0 * t);\\n}\\n\\nvoid main() {\\n\\tfloat radius, alpha = 1.0, delta = fragWidth;\\n\\n\\tradius = length(2.0 * gl_PointCoord.xy - 1.0);\\n\\n\\tif (radius > 1.0 + delta) {\\n\\t\\tdiscard;\\n\\t}\\n\\n\\talpha -= smoothstep(1.0 - delta, 1.0 + delta, radius);\\n\\n\\tfloat borderRadius = fragBorderRadius;\\n\\tfloat ratio = smoothstep(borderRadius - delta, borderRadius + delta, radius);\\n\\tvec4 color = mix(fragColor, fragBorderColor, ratio);\\n\\tcolor.a *= alpha * opacity;\\n\\tgl_FragColor = color;\\n}\\n\"]);\n circleOptions.vert = glslify([\"precision highp float;\\n#define GLSLIFY 1\\n\\nattribute float x, y, xFract, yFract;\\nattribute float size, borderSize;\\nattribute vec4 colorId, borderColorId;\\nattribute float isActive;\\n\\n// `invariant` effectively turns off optimizations for the position.\\n// We need this because -fast-math on M1 Macs is re-ordering\\n// floating point operations in a way that causes floating point\\n// precision limits to put points in the wrong locations.\\ninvariant gl_Position;\\n\\nuniform bool constPointSize;\\nuniform float pixelRatio;\\nuniform vec2 paletteSize, scale, scaleFract, translate, translateFract;\\nuniform sampler2D paletteTexture;\\n\\nconst float maxSize = 100.;\\n\\nvarying vec4 fragColor, fragBorderColor;\\nvarying float fragBorderRadius, fragWidth;\\n\\nfloat pointSizeScale = (constPointSize) ? 2. : pixelRatio;\\n\\nbool isDirect = (paletteSize.x < 1.);\\n\\nvec4 getColor(vec4 id) {\\n return isDirect ? id / 255. : texture2D(paletteTexture,\\n vec2(\\n (id.x + .5) / paletteSize.x,\\n (id.y + .5) / paletteSize.y\\n )\\n );\\n}\\n\\nvoid main() {\\n // ignore inactive points\\n if (isActive == 0.) return;\\n\\n vec2 position = vec2(x, y);\\n vec2 positionFract = vec2(xFract, yFract);\\n\\n vec4 color = getColor(colorId);\\n vec4 borderColor = getColor(borderColorId);\\n\\n float size = size * maxSize / 255.;\\n float borderSize = borderSize * maxSize / 255.;\\n\\n gl_PointSize = (size + borderSize) * pointSizeScale;\\n\\n vec2 pos = (position + translate) * scale\\n + (positionFract + translateFract) * scale\\n + (position + translate) * scaleFract\\n + (positionFract + translateFract) * scaleFract;\\n\\n gl_Position = vec4(pos * 2. - 1., 0., 1.);\\n\\n fragBorderRadius = 1. - 2. * borderSize / (size + borderSize);\\n fragColor = color;\\n fragBorderColor = borderColor.a == 0. || borderSize == 0. ? vec4(color.rgb, 0.) : borderColor;\\n fragWidth = 1. / gl_PointSize;\\n}\\n\"]);\n\n // polyfill IE\n if (ie) {\n circleOptions.frag = circleOptions.frag.replace('smoothstep', 'smoothStep');\n markerOptions.frag = markerOptions.frag.replace('smoothstep', 'smoothStep');\n }\n this.drawCircle = regl(circleOptions);\n}\n\n// single pass defaults\nScatter.defaults = {\n color: 'black',\n borderColor: 'transparent',\n borderSize: 0,\n size: 12,\n opacity: 1,\n marker: undefined,\n viewport: null,\n range: null,\n pixelSize: null,\n count: 0,\n offset: 0,\n bounds: null,\n positions: [],\n snap: 1e4\n};\n\n// update & redraw\nScatter.prototype.render = function () {\n if (arguments.length) {\n this.update.apply(this, arguments);\n }\n this.draw();\n return this;\n};\n\n// draw all groups or only indicated ones\nScatter.prototype.draw = function () {\n var _this2 = this;\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n var groups = this.groups;\n\n // if directly array passed - treat as passes\n if (args.length === 1 && Array.isArray(args[0]) && (args[0][0] === null || Array.isArray(args[0][0]))) {\n args = args[0];\n }\n\n // FIXME: remove once https://github.com/regl-project/regl/issues/474 resolved\n this.regl._refresh();\n if (args.length) {\n for (var i = 0; i < args.length; i++) {\n this.drawItem(i, args[i]);\n }\n }\n // draw all passes\n else {\n groups.forEach(function (group, i) {\n _this2.drawItem(i);\n });\n }\n return this;\n};\n\n// draw specific scatter group\nScatter.prototype.drawItem = function (id, els) {\n var groups = this.groups;\n var group = groups[id];\n\n // debug viewport\n // let { viewport } = group\n // gl.enable(gl.SCISSOR_TEST);\n // gl.scissor(viewport.x, viewport.y, viewport.width, viewport.height);\n // gl.clearColor(0, 0, 0, .5);\n // gl.clear(gl.COLOR_BUFFER_BIT);\n\n if (typeof els === 'number') {\n id = els;\n group = groups[els];\n els = null;\n }\n if (!(group && group.count && group.opacity)) return;\n\n // draw circles\n if (group.activation[0]) {\n // TODO: optimize this performance by making groups and regl.this props\n this.drawCircle(this.getMarkerDrawOptions(0, group, els));\n }\n\n // draw all other available markers\n var batch = [];\n for (var i = 1; i < group.activation.length; i++) {\n if (!group.activation[i] || group.activation[i] !== true && !group.activation[i].data.length) continue;\n batch.push.apply(batch, _toConsumableArray(this.getMarkerDrawOptions(i, group, els)));\n }\n if (batch.length) {\n this.drawMarker(batch);\n }\n};\n\n// get options for the marker ids\nScatter.prototype.getMarkerDrawOptions = function (markerId, group, elements) {\n var range = group.range,\n tree = group.tree,\n viewport = group.viewport,\n activation = group.activation,\n selectionBuffer = group.selectionBuffer,\n count = group.count;\n var regl = this.regl;\n\n // direct points\n if (!tree) {\n // if elements array - draw unclustered points\n if (elements) {\n return [extend({}, group, {\n markerTexture: this.markerTextures[markerId],\n activation: activation[markerId],\n count: elements.length,\n elements: elements,\n offset: 0\n })];\n }\n return [extend({}, group, {\n markerTexture: this.markerTextures[markerId],\n activation: activation[markerId],\n offset: 0\n })];\n }\n\n // clustered points\n var batch = [];\n var lod = tree.range(range, {\n lod: true,\n px: [(range[2] - range[0]) / viewport.width, (range[3] - range[1]) / viewport.height]\n });\n\n // enable elements by using selection buffer\n if (elements) {\n var markerActivation = activation[markerId];\n var mask = markerActivation.data;\n var data = new Uint8Array(count);\n for (var i = 0; i < elements.length; i++) {\n var id = elements[i];\n data[id] = mask ? mask[id] : 1;\n }\n selectionBuffer.subdata(data);\n }\n for (var l = lod.length; l--;) {\n var _lod$l = _slicedToArray(lod[l], 2),\n from = _lod$l[0],\n to = _lod$l[1];\n batch.push(extend({}, group, {\n markerTexture: this.markerTextures[markerId],\n activation: elements ? selectionBuffer : activation[markerId],\n offset: from,\n count: to - from\n }));\n }\n return batch;\n};\n\n// update groups options\nScatter.prototype.update = function () {\n var _this3 = this;\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n if (!args.length) return;\n\n // passes are as single array\n if (args.length === 1 && Array.isArray(args[0])) args = args[0];\n var groups = this.groups,\n gl = this.gl,\n regl = this.regl,\n maxSize = this.maxSize,\n maxColors = this.maxColors,\n palette = this.palette;\n this.groups = groups = args.map(function (options, i) {\n var group = groups[i];\n if (options === undefined) return group;\n if (options === null) options = {\n positions: null\n };else if (typeof options === 'function') options = {\n ondraw: options\n };else if (typeof options[0] === 'number') options = {\n positions: options\n };\n\n // copy options to avoid mutation & handle aliases\n options = pick(options, {\n positions: 'positions data points',\n snap: 'snap cluster lod tree',\n size: 'sizes size radius',\n borderSize: 'borderSizes borderSize border-size bordersize borderWidth borderWidths border-width borderwidth stroke-width strokeWidth strokewidth outline',\n color: 'colors color fill fill-color fillColor',\n borderColor: 'borderColors borderColor stroke stroke-color strokeColor',\n marker: 'markers marker shape',\n range: 'range dataBox databox',\n viewport: 'viewport viewPort viewBox viewbox',\n opacity: 'opacity alpha transparency',\n bounds: 'bound bounds boundaries limits',\n tooManyColors: 'tooManyColors palette paletteMode optimizePalette enablePalette'\n });\n if (options.positions === null) options.positions = [];\n if (options.tooManyColors != null) _this3.tooManyColors = options.tooManyColors;\n if (!group) {\n groups[i] = group = {\n id: i,\n scale: null,\n translate: null,\n scaleFract: null,\n translateFract: null,\n // buffers for active markers\n activation: [],\n // buffer for filtered markers\n selectionBuffer: regl.buffer({\n data: new Uint8Array(0),\n usage: 'stream',\n type: 'uint8'\n }),\n // buffers with data: it is faster to switch them per-pass\n // than provide one congregate buffer\n sizeBuffer: regl.buffer({\n data: new Uint8Array(0),\n usage: 'dynamic',\n type: 'uint8'\n }),\n colorBuffer: regl.buffer({\n data: new Uint8Array(0),\n usage: 'dynamic',\n type: 'uint8'\n }),\n positionBuffer: regl.buffer({\n data: new Uint8Array(0),\n usage: 'dynamic',\n type: 'float'\n }),\n positionFractBuffer: regl.buffer({\n data: new Uint8Array(0),\n usage: 'dynamic',\n type: 'float'\n })\n };\n options = extend({}, Scatter.defaults, options);\n }\n\n // force update triggers\n if (options.positions && !('marker' in options)) {\n options.marker = group.marker;\n delete group.marker;\n }\n\n // updating markers cause recalculating snapping\n if (options.marker && !('positions' in options)) {\n options.positions = group.positions;\n delete group.positions;\n }\n\n // global count of points\n var hasSize = 0,\n hasColor = 0;\n updateDiff(group, options, [{\n snap: true,\n size: function size(s, group) {\n if (s == null) s = Scatter.defaults.size;\n hasSize += s && s.length ? 1 : 0;\n return s;\n },\n borderSize: function borderSize(s, group) {\n if (s == null) s = Scatter.defaults.borderSize;\n hasSize += s && s.length ? 1 : 0;\n return s;\n },\n opacity: parseFloat,\n // add colors to palette, save references\n color: function color(c, group) {\n if (c == null) c = Scatter.defaults.color;\n c = _this3.updateColor(c);\n hasColor++;\n return c;\n },\n borderColor: function borderColor(c, group) {\n if (c == null) c = Scatter.defaults.borderColor;\n c = _this3.updateColor(c);\n hasColor++;\n return c;\n },\n bounds: function bounds(_bounds, group, options) {\n if (!('range' in options)) options.range = null;\n return _bounds;\n },\n positions: function positions(_positions, group, options) {\n var snap = group.snap;\n var positionBuffer = group.positionBuffer,\n positionFractBuffer = group.positionFractBuffer,\n selectionBuffer = group.selectionBuffer;\n\n // separate buffers for x/y coordinates\n if (_positions.x || _positions.y) {\n if (_positions.x.length) {\n group.xAttr = {\n buffer: regl.buffer(_positions.x),\n offset: 0,\n stride: 4,\n count: _positions.x.length\n };\n } else {\n group.xAttr = {\n buffer: _positions.x.buffer,\n offset: _positions.x.offset * 4 || 0,\n stride: (_positions.x.stride || 1) * 4,\n count: _positions.x.count\n };\n }\n if (_positions.y.length) {\n group.yAttr = {\n buffer: regl.buffer(_positions.y),\n offset: 0,\n stride: 4,\n count: _positions.y.length\n };\n } else {\n group.yAttr = {\n buffer: _positions.y.buffer,\n offset: _positions.y.offset * 4 || 0,\n stride: (_positions.y.stride || 1) * 4,\n count: _positions.y.count\n };\n }\n group.count = Math.max(group.xAttr.count, group.yAttr.count);\n return _positions;\n }\n _positions = flatten(_positions, 'float64');\n var count = group.count = Math.floor(_positions.length / 2);\n var bounds = group.bounds = count ? getBounds(_positions, 2) : null;\n\n // if range is not provided updated - recalc it\n if (!options.range && !group.range) {\n delete group.range;\n options.range = bounds;\n }\n\n // reset marker\n if (!options.marker && !group.marker) {\n delete group.marker;\n options.marker = null;\n }\n\n // build cluster tree if required\n if (snap && (snap === true || count > snap)) {\n group.tree = cluster(_positions, {\n bounds: bounds\n });\n }\n // existing tree instance\n else if (snap && snap.length) {\n group.tree = snap;\n }\n if (group.tree) {\n var opts = {\n primitive: 'points',\n usage: 'static',\n data: group.tree,\n type: 'uint32'\n };\n if (group.elements) group.elements(opts);else group.elements = regl.elements(opts);\n }\n\n // update position buffers\n var float_data = f32.float32(_positions);\n positionBuffer({\n data: float_data,\n usage: 'dynamic'\n });\n var frac_data = f32.fract32(_positions, float_data);\n positionFractBuffer({\n data: frac_data,\n usage: 'dynamic'\n });\n\n // expand selectionBuffer\n selectionBuffer({\n data: new Uint8Array(count),\n type: 'uint8',\n usage: 'stream'\n });\n return _positions;\n }\n }, {\n // create marker ids corresponding to known marker textures\n marker: function marker(markers, group, options) {\n var activation = group.activation;\n\n // reset marker elements\n activation.forEach(function (buffer) {\n return buffer && buffer.destroy && buffer.destroy();\n });\n activation.length = 0;\n\n // single sdf marker\n if (!markers || typeof markers[0] === 'number') {\n var id = _this3.addMarker(markers);\n activation[id] = true;\n }\n\n // per-point markers use mask buffers to enable markers in vert shader\n else {\n var markerMasks = [];\n for (var _i = 0, l = Math.min(markers.length, group.count); _i < l; _i++) {\n var _id = _this3.addMarker(markers[_i]);\n if (!markerMasks[_id]) markerMasks[_id] = new Uint8Array(group.count);\n\n // enable marker by default\n markerMasks[_id][_i] = 1;\n }\n for (var _id2 = 0; _id2 < markerMasks.length; _id2++) {\n if (!markerMasks[_id2]) continue;\n var opts = {\n data: markerMasks[_id2],\n type: 'uint8',\n usage: 'static'\n };\n if (!activation[_id2]) {\n activation[_id2] = regl.buffer(opts);\n } else {\n activation[_id2](opts);\n }\n activation[_id2].data = markerMasks[_id2];\n }\n }\n return markers;\n },\n range: function range(_range, group, options) {\n var bounds = group.bounds;\n\n // FIXME: why do we need this?\n if (!bounds) return;\n if (!_range) _range = bounds;\n group.scale = [1 / (_range[2] - _range[0]), 1 / (_range[3] - _range[1])];\n group.translate = [-_range[0], -_range[1]];\n group.scaleFract = f32.fract(group.scale);\n group.translateFract = f32.fract(group.translate);\n return _range;\n },\n viewport: function viewport(vp) {\n var rect = parseRect(vp || [gl.drawingBufferWidth, gl.drawingBufferHeight]);\n\n // normalize viewport to the canvas coordinates\n // rect.y = gl.drawingBufferHeight - rect.height - rect.y\n\n return rect;\n }\n }]);\n\n // update size buffer, if needed\n if (hasSize) {\n var _group = group,\n count = _group.count,\n size = _group.size,\n borderSize = _group.borderSize,\n sizeBuffer = _group.sizeBuffer;\n var sizes = new Uint8Array(count * 2);\n if (size.length || borderSize.length) {\n for (var _i2 = 0; _i2 < count; _i2++) {\n // we downscale size to allow for fractions\n sizes[_i2 * 2] = Math.round((size[_i2] == null ? size : size[_i2]) * 255 / maxSize);\n sizes[_i2 * 2 + 1] = Math.round((borderSize[_i2] == null ? borderSize : borderSize[_i2]) * 255 / maxSize);\n }\n }\n sizeBuffer({\n data: sizes,\n usage: 'dynamic'\n });\n }\n\n // update color buffer if needed\n if (hasColor) {\n var _group2 = group,\n _count = _group2.count,\n color = _group2.color,\n borderColor = _group2.borderColor,\n colorBuffer = _group2.colorBuffer;\n var colors;\n\n // if too many colors - put colors to buffer directly\n if (_this3.tooManyColors) {\n if (color.length || borderColor.length) {\n colors = new Uint8Array(_count * 8);\n for (var _i3 = 0; _i3 < _count; _i3++) {\n var _colorId = color[_i3];\n colors[_i3 * 8] = palette[_colorId * 4];\n colors[_i3 * 8 + 1] = palette[_colorId * 4 + 1];\n colors[_i3 * 8 + 2] = palette[_colorId * 4 + 2];\n colors[_i3 * 8 + 3] = palette[_colorId * 4 + 3];\n var borderColorId = borderColor[_i3];\n colors[_i3 * 8 + 4] = palette[borderColorId * 4];\n colors[_i3 * 8 + 5] = palette[borderColorId * 4 + 1];\n colors[_i3 * 8 + 6] = palette[borderColorId * 4 + 2];\n colors[_i3 * 8 + 7] = palette[borderColorId * 4 + 3];\n }\n }\n }\n\n // if limited amount of colors - keep palette color picking\n // that saves significant memory\n else {\n if (color.length || borderColor.length) {\n // we need slight data increase by 2 due to vec4 borderId in shader\n colors = new Uint8Array(_count * 4 + 2);\n for (var _i4 = 0; _i4 < _count; _i4++) {\n // put color coords in palette texture\n if (color[_i4] != null) {\n colors[_i4 * 4] = color[_i4] % maxColors;\n colors[_i4 * 4 + 1] = Math.floor(color[_i4] / maxColors);\n }\n if (borderColor[_i4] != null) {\n colors[_i4 * 4 + 2] = borderColor[_i4] % maxColors;\n colors[_i4 * 4 + 3] = Math.floor(borderColor[_i4] / maxColors);\n }\n }\n }\n }\n colorBuffer({\n data: colors || new Uint8Array(0),\n type: 'uint8',\n usage: 'dynamic'\n });\n }\n return group;\n });\n};\n\n// get (and create) marker texture id\nScatter.prototype.addMarker = function (sdf) {\n var markerTextures = this.markerTextures,\n regl = this.regl,\n markerCache = this.markerCache;\n var pos = sdf == null ? 0 : markerCache.indexOf(sdf);\n if (pos >= 0) return pos;\n\n // convert sdf to 0..255 range\n var distArr;\n if (sdf instanceof Uint8Array || sdf instanceof Uint8ClampedArray) {\n distArr = sdf;\n } else {\n distArr = new Uint8Array(sdf.length);\n for (var i = 0, l = sdf.length; i < l; i++) {\n distArr[i] = sdf[i] * 255;\n }\n }\n var radius = Math.floor(Math.sqrt(distArr.length));\n pos = markerTextures.length;\n markerCache.push(sdf);\n markerTextures.push(regl.texture({\n channels: 1,\n data: distArr,\n radius: radius,\n mag: 'linear',\n min: 'linear'\n }));\n return pos;\n};\n\n// register color to palette, return it's index or list of indexes\nScatter.prototype.updateColor = function (colors) {\n var paletteIds = this.paletteIds,\n palette = this.palette,\n maxColors = this.maxColors;\n if (!Array.isArray(colors)) {\n colors = [colors];\n }\n var idx = [];\n\n // if color groups - flatten them\n if (typeof colors[0] === 'number') {\n var grouped = [];\n if (Array.isArray(colors)) {\n for (var i = 0; i < colors.length; i += 4) {\n grouped.push(colors.slice(i, i + 4));\n }\n } else {\n for (var _i5 = 0; _i5 < colors.length; _i5 += 4) {\n grouped.push(colors.subarray(_i5, _i5 + 4));\n }\n }\n colors = grouped;\n }\n for (var _i6 = 0; _i6 < colors.length; _i6++) {\n var color = colors[_i6];\n color = rgba(color, 'uint8');\n var id = colorId(color, false);\n\n // if new color - save it\n if (paletteIds[id] == null) {\n var pos = palette.length;\n paletteIds[id] = Math.floor(pos / 4);\n palette[pos] = color[0];\n palette[pos + 1] = color[1];\n palette[pos + 2] = color[2];\n palette[pos + 3] = color[3];\n }\n idx[_i6] = paletteIds[id];\n }\n\n // detect if too many colors in palette\n if (!this.tooManyColors && palette.length > maxColors * 4) this.tooManyColors = true;\n\n // limit max color\n this.updatePalette(palette);\n\n // keep static index for single-color property\n return idx.length === 1 ? idx[0] : idx;\n};\nScatter.prototype.updatePalette = function (palette) {\n if (this.tooManyColors) return;\n var maxColors = this.maxColors,\n paletteTexture = this.paletteTexture;\n var requiredHeight = Math.ceil(palette.length * .25 / maxColors);\n\n // pad data\n if (requiredHeight > 1) {\n palette = palette.slice();\n for (var i = palette.length * .25 % maxColors; i < requiredHeight * maxColors; i++) {\n palette.push(0, 0, 0, 0);\n }\n }\n\n // ensure height\n if (paletteTexture.height < requiredHeight) {\n paletteTexture.resize(maxColors, requiredHeight);\n }\n\n // update full data\n paletteTexture.subimage({\n width: Math.min(palette.length * .25, maxColors),\n height: requiredHeight,\n data: palette\n }, 0, 0);\n};\n\n// remove unused stuff\nScatter.prototype.destroy = function () {\n this.groups.forEach(function (group) {\n group.sizeBuffer.destroy();\n group.positionBuffer.destroy();\n group.positionFractBuffer.destroy();\n group.colorBuffer.destroy();\n group.activation.forEach(function (b) {\n return b && b.destroy && b.destroy();\n });\n group.selectionBuffer.destroy();\n if (group.elements) group.elements.destroy();\n });\n this.groups.length = 0;\n this.paletteTexture.destroy();\n this.markerTextures.forEach(function (txt) {\n return txt && txt.destroy && txt.destroy();\n });\n return this;\n};\n\nvar extend$1 = require('object-assign');\nvar reglScatter2d = function reglScatter2d(regl, options) {\n var scatter$1 = new scatter(regl, options);\n var render = scatter$1.render.bind(scatter$1);\n\n // expose API\n extend$1(render, {\n render: render,\n update: scatter$1.update.bind(scatter$1),\n draw: scatter$1.draw.bind(scatter$1),\n destroy: scatter$1.destroy.bind(scatter$1),\n regl: scatter$1.regl,\n gl: scatter$1.gl,\n canvas: scatter$1.gl.canvas,\n groups: scatter$1.groups,\n markers: scatter$1.markerCache,\n palette: scatter$1.palette\n });\n return render;\n};\n\nmodule.exports = reglScatter2d;\n","'use strict'\n\n\nconst createScatter = require('regl-scatter2d')\nconst pick = require('pick-by-alias')\nconst getBounds = require('array-bounds')\nconst raf = require('raf')\nconst arrRange = require('array-range')\nconst rect = require('parse-rect')\nconst flatten = require('flatten-vertex-data')\n\n\nmodule.exports = SPLOM\n\n\n// @constructor\nfunction SPLOM (regl, options) {\n\tif (!(this instanceof SPLOM)) return new SPLOM(regl, options)\n\n\t// render passes\n\tthis.traces = []\n\n\t// passes for scatter, combined across traces\n\tthis.passes = {}\n\n\tthis.regl = regl\n\n\t// main scatter drawing instance\n\tthis.scatter = createScatter(regl)\n\n\tthis.canvas = this.scatter.canvas\n}\n\n\n// update & draw passes once per frame\nSPLOM.prototype.render = function (...args) {\n\tif (args.length) {\n\t\tthis.update(...args)\n\t}\n\n\tif (this.regl.attributes.preserveDrawingBuffer) return this.draw()\n\n\t// make sure draw is not called more often than once a frame\n\tif (this.dirty) {\n\t\tif (this.planned == null) {\n\t\t\tthis.planned = raf(() => {\n\t\t\t\tthis.draw()\n\t\t\t\tthis.dirty = true\n\t\t\t\tthis.planned = null\n\t\t\t})\n\t\t}\n\t}\n\telse {\n\t\tthis.draw()\n\t\tthis.dirty = true\n\t\traf(() => {\n\t\t\tthis.dirty = false\n\t\t})\n\t}\n\n\treturn this\n}\n\n\n// update passes\nSPLOM.prototype.update = function (...args) {\n\tif (!args.length) return\n\n\tfor (let i = 0; i < args.length; i++) {\n\t\tthis.updateItem(i, args[i])\n\t}\n\n\t// remove nulled passes\n\tthis.traces = this.traces.filter(Boolean)\n\n\t// FIXME: update passes independently\n\tlet passes = []\n\tlet offset = 0\n\tfor (let i = 0; i < this.traces.length; i++) {\n\t\tlet trace = this.traces[i]\n\t\tlet tracePasses = this.traces[i].passes\n\t\tfor (let j = 0; j < tracePasses.length; j++) {\n\t\t\tpasses.push(this.passes[tracePasses[j]])\n\t\t}\n\t\t// save offset of passes\n\t\ttrace.passOffset = offset\n\t\toffset += trace.passes.length\n\t}\n\n\tthis.scatter.update(...passes)\n\n\treturn this\n}\n\n\n// update trace by index, not supposed to be called directly\nSPLOM.prototype.updateItem = function (i, options) {\n\tlet { regl } = this\n\n\t// remove pass if null\n\tif (options === null) {\n\t\tthis.traces[i] = null\n\t\treturn this\n\t}\n\n\tif (!options) return this\n\n\tlet o = pick(options, {\n\t\tdata: 'data items columns rows values dimensions samples x',\n\t\tsnap: 'snap cluster',\n\t\tsize: 'sizes size radius',\n\t\tcolor: 'colors color fill fill-color fillColor',\n\t\topacity: 'opacity alpha transparency opaque',\n\t\tborderSize: 'borderSizes borderSize border-size bordersize borderWidth borderWidths border-width borderwidth stroke-width strokeWidth strokewidth outline',\n\t\tborderColor: 'borderColors borderColor bordercolor stroke stroke-color strokeColor',\n\t\tmarker: 'markers marker shape',\n\t\trange: 'range ranges databox dataBox',\n\t\tviewport: 'viewport viewBox viewbox',\n\t\tdomain: 'domain domains area areas',\n\t\tpadding: 'pad padding paddings pads margin margins',\n\t\ttranspose: 'transpose transposed',\n\t\tdiagonal: 'diagonal diag showDiagonal',\n\t\tupper: 'upper up top upperhalf upperHalf showupperhalf showUpper showUpperHalf',\n\t\tlower: 'lower low bottom lowerhalf lowerHalf showlowerhalf showLowerHalf showLower'\n\t})\n\n\t// we provide regl buffer per-trace, since trace data can be changed\n\tlet trace = (this.traces[i] || (this.traces[i] = {\n\t\tid: i,\n\t\tbuffer: regl.buffer({\n\t\t\tusage: 'dynamic',\n\t\t\ttype: 'float',\n\t\t\tdata: new Uint8Array()\n\t\t}),\n\t\tcolor: 'black',\n\t\tmarker: null,\n\t\tsize: 12,\n\t\tborderColor: 'transparent',\n\t\tborderSize: 1,\n\t\tviewport: rect([regl._gl.drawingBufferWidth, regl._gl.drawingBufferHeight]),\n\t\tpadding: [0, 0, 0, 0],\n\t\topacity: 1,\n\t\tdiagonal: true,\n\t\tupper: true,\n\t\tlower: true\n\t}))\n\n\n\t// save styles\n\tif (o.color != null) {\n\t\ttrace.color = o.color\n\t}\n\tif (o.size != null) {\n\t\ttrace.size = o.size\n\t}\n\tif (o.marker != null) {\n\t\ttrace.marker = o.marker\n\t}\n\tif (o.borderColor != null) {\n\t\ttrace.borderColor = o.borderColor\n\t}\n\tif (o.borderSize != null) {\n\t\ttrace.borderSize = o.borderSize\n\t}\n\tif (o.opacity != null) {\n\t\ttrace.opacity = o.opacity\n\t}\n\tif (o.viewport) {\n\t\ttrace.viewport = rect(o.viewport)\n\t}\n\tif (o.diagonal != null) trace.diagonal = o.diagonal\n\tif (o.upper != null) trace.upper = o.upper\n\tif (o.lower != null) trace.lower = o.lower\n\n\t// put flattened data into buffer\n\tif (o.data) {\n\t\ttrace.buffer(flatten(o.data))\n\t\ttrace.columns = o.data.length\n\t\ttrace.count = o.data[0].length\n\n\t\t// detect bounds per-column\n\t\ttrace.bounds = []\n\n\t\tfor (let i = 0; i < trace.columns; i++) {\n\t\t\ttrace.bounds[i] = getBounds(o.data[i], 1)\n\t\t}\n\t}\n\n\t// add proper range updating markers\n\tlet multirange\n\tif (o.range) {\n\t\ttrace.range = o.range\n\t\tmultirange = trace.range && typeof trace.range[0] !== 'number'\n\t}\n\n\tif (o.domain) {\n\t\ttrace.domain = o.domain\n\t}\n\tlet multipadding = false\n\tif (o.padding != null) {\n\t\t// multiple paddings\n\t\tif (Array.isArray(o.padding) && o.padding.length === trace.columns && typeof o.padding[o.padding.length - 1] === 'number') {\n\t\t\ttrace.padding = o.padding.map(getPad)\n\t\t\tmultipadding = true\n\t\t}\n\t\t// single padding\n\t\telse {\n\t\t\ttrace.padding = getPad(o.padding)\n\t\t}\n\t}\n\n\t// create passes\n\tlet m = trace.columns\n\tlet n = trace.count\n\n\tlet w = trace.viewport.width\n\tlet h = trace.viewport.height\n\tlet left = trace.viewport.x\n\tlet top = trace.viewport.y\n\tlet iw = w / m\n\tlet ih = h / m\n\n\ttrace.passes = []\n\n\tfor (let i = 0; i < m; i++) {\n\t\tfor (let j = 0; j < m; j++) {\n\t\t\tif (!trace.diagonal && j === i) continue\n\t\t\tif (!trace.upper && i > j) continue\n\t\t\tif (!trace.lower && i < j) continue\n\n\t\t\tlet key = passId(trace.id, i, j)\n\n\t\t\tlet pass = this.passes[key] || (this.passes[key] = {})\n\n\t\t\tif (o.data) {\n\t\t\t\tif (o.transpose) {\n\t\t\t\t\tpass.positions = {\n\t\t\t\t\t\tx: {buffer: trace.buffer, offset: j, count: n, stride: m},\n\t\t\t\t\t\ty: {buffer: trace.buffer, offset: i, count: n, stride: m}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tpass.positions = {\n\t\t\t\t\t\tx: {buffer: trace.buffer, offset: j * n, count: n},\n\t\t\t\t\t\ty: {buffer: trace.buffer, offset: i * n, count: n}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tpass.bounds = getBox(trace.bounds, i, j)\n\t\t\t}\n\n\t\t\tif (o.domain || o.viewport || o.data) {\n\t\t\t\tlet pad = multipadding ? getBox(trace.padding, i, j) : trace.padding\n\t\t\t\tif (trace.domain) {\n\t\t\t\t\tlet [lox, loy, hix, hiy] = getBox(trace.domain, i, j)\n\n\t\t\t\t\tpass.viewport = [\n\t\t\t\t\t\tleft + lox * w + pad[0],\n\t\t\t\t\t\ttop + loy * h + pad[1],\n\t\t\t\t\t\tleft + hix * w - pad[2],\n\t\t\t\t\t\ttop + hiy * h - pad[3]\n\t\t\t\t\t]\n\t\t\t\t}\n\t\t\t\t// consider auto-domain equipartial\n\t\t\t\telse {\n\t\t\t\t\tpass.viewport = [\n\t\t\t\t\t\tleft + j * iw + iw * pad[0],\n\t\t\t\t\t\ttop + i * ih + ih * pad[1],\n\t\t\t\t\t\tleft + (j + 1) * iw - iw * pad[2],\n\t\t\t\t\t\ttop + (i + 1) * ih - ih * pad[3]\n\t\t\t\t\t]\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (o.color) pass.color = trace.color\n\t\t\tif (o.size) pass.size = trace.size\n\t\t\tif (o.marker) pass.marker = trace.marker\n\t\t\tif (o.borderSize) pass.borderSize = trace.borderSize\n\t\t\tif (o.borderColor) pass.borderColor = trace.borderColor\n\t\t\tif (o.opacity) pass.opacity = trace.opacity\n\n\t\t\tif (o.range) {\n\t\t\t\tpass.range = multirange ? getBox(trace.range, i, j) : trace.range || pass.bounds\n\t\t\t}\n\n\t\t\ttrace.passes.push(key)\n\t\t}\n\t}\n\n\treturn this\n}\n\n\n// draw all or passed passes\nSPLOM.prototype.draw = function (...args) {\n\tif (!args.length) {\n\t\tthis.scatter.draw()\n\t}\n\telse {\n\t\tlet idx = []\n\t\tfor (let i = 0; i < args.length; i++) {\n\t\t\t// draw(0, 2, 5) - draw traces\n\t\t\tif (typeof args[i] === 'number' ) {\n\t\t\t\tlet { passes, passOffset } = this.traces[args[i]]\n\t\t\t\tidx.push(...arrRange(passOffset, passOffset + passes.length))\n\t\t\t}\n\t\t\t// draw([0, 1, 2 ...], [3, 4, 5]) - draw points\n\t\t\telse if (args[i].length) {\n\t\t\t\tlet els = args[i]\n\t\t\t\tlet { passes, passOffset } = this.traces[i]\n\t\t\t\tpasses = passes.map((passId, i) => {\n\t\t\t\t\tidx[passOffset + i] = els\n\t\t\t\t})\n\t\t\t}\n\t\t}\n\t\tthis.scatter.draw(...idx)\n\t}\n\n\treturn this\n}\n\n\n// dispose resources\nSPLOM.prototype.destroy = function () {\n\tthis.traces.forEach(trace => {\n\t\tif (trace.buffer && trace.buffer.destroy) trace.buffer.destroy()\n\t})\n\tthis.traces = null\n\tthis.passes = null\n\n\tthis.scatter.destroy()\n\n\treturn this\n}\n\n\n// return pass corresponding to trace i- j- square\nfunction passId (trace, i, j) {\n\tlet id = (trace.id != null ? trace.id : trace)\n\tlet n = i\n\tlet m = j\n\tlet key = id << 16 | (n & 0xff) << 8 | m & 0xff\n\n\treturn key\n}\n\n\n// return bounding box corresponding to a pass\nfunction getBox (items, i, j) {\n\tlet ilox, iloy, ihix, ihiy, jlox, jloy, jhix, jhiy\n\tlet iitem = items[i], jitem = items[j]\n\n\tif (iitem.length > 2) {\n\t\tilox = iitem[0]\n\t\tihix = iitem[2]\n\t\tiloy = iitem[1]\n\t\tihiy = iitem[3]\n\t}\n\telse if (iitem.length) {\n\t\tilox = iloy = iitem[0]\n\t\tihix = ihiy = iitem[1]\n\t}\n\telse {\n\t\tilox = iitem.x\n\t\tiloy = iitem.y\n\t\tihix = iitem.x + iitem.width\n\t\tihiy = iitem.y + iitem.height\n\t}\n\n\tif (jitem.length > 2) {\n\t\tjlox = jitem[0]\n\t\tjhix = jitem[2]\n\t\tjloy = jitem[1]\n\t\tjhiy = jitem[3]\n\t}\n\telse if (jitem.length) {\n\t\tjlox = jloy = jitem[0]\n\t\tjhix = jhiy = jitem[1]\n\t}\n\telse {\n\t\tjlox = jitem.x\n\t\tjloy = jitem.y\n\t\tjhix = jitem.x + jitem.width\n\t\tjhiy = jitem.y + jitem.height\n\t}\n\n\treturn [ jlox, iloy, jhix, ihiy ]\n}\n\n\nfunction getPad (arg) {\n\tif (typeof arg === 'number') return [arg, arg, arg, arg]\n\telse if (arg.length === 2) return [arg[0], arg[1], arg[0], arg[1]]\n\telse {\n\t\tlet box = rect(arg)\n\t\treturn [box.x, box.y, box.x + box.width, box.y + box.height]\n\t}\n}\n","(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global.createREGL = factory());\n}(this, (function () { 'use strict';\n\nvar extend = function (base, opts) {\n var keys = Object.keys(opts)\n for (var i = 0; i < keys.length; ++i) {\n base[keys[i]] = opts[keys[i]]\n }\n return base\n}\n\nvar VARIABLE_COUNTER = 0\n\nvar DYN_FUNC = 0\nvar DYN_CONSTANT = 5\nvar DYN_ARRAY = 6\n\nfunction DynamicVariable (type, data) {\n this.id = (VARIABLE_COUNTER++)\n this.type = type\n this.data = data\n}\n\nfunction escapeStr (str) {\n return str.replace(/\\\\/g, '\\\\\\\\').replace(/\"/g, '\\\\\"')\n}\n\nfunction splitParts (str) {\n if (str.length === 0) {\n return []\n }\n\n var firstChar = str.charAt(0)\n var lastChar = str.charAt(str.length - 1)\n\n if (str.length > 1 &&\n firstChar === lastChar &&\n (firstChar === '\"' || firstChar === \"'\")) {\n return ['\"' + escapeStr(str.substr(1, str.length - 2)) + '\"']\n }\n\n var parts = /\\[(false|true|null|\\d+|'[^']*'|\"[^\"]*\")\\]/.exec(str)\n if (parts) {\n return (\n splitParts(str.substr(0, parts.index))\n .concat(splitParts(parts[1]))\n .concat(splitParts(str.substr(parts.index + parts[0].length)))\n )\n }\n\n var subparts = str.split('.')\n if (subparts.length === 1) {\n return ['\"' + escapeStr(str) + '\"']\n }\n\n var result = []\n for (var i = 0; i < subparts.length; ++i) {\n result = result.concat(splitParts(subparts[i]))\n }\n return result\n}\n\nfunction toAccessorString (str) {\n return '[' + splitParts(str).join('][') + ']'\n}\n\nfunction defineDynamic (type, data) {\n return new DynamicVariable(type, toAccessorString(data + ''))\n}\n\nfunction isDynamic (x) {\n return (typeof x === 'function' && !x._reglType) || (x instanceof DynamicVariable)\n}\n\nfunction unbox (x, path) {\n if (typeof x === 'function') {\n return new DynamicVariable(DYN_FUNC, x)\n } else if (typeof x === 'number' || typeof x === 'boolean') {\n return new DynamicVariable(DYN_CONSTANT, x)\n } else if (Array.isArray(x)) {\n return new DynamicVariable(DYN_ARRAY, x.map(function (y, i) { return unbox(y, path + '[' + i + ']') }))\n } else if (x instanceof DynamicVariable) {\n return x\n }\n \n}\n\nvar dynamic = {\n DynamicVariable: DynamicVariable,\n define: defineDynamic,\n isDynamic: isDynamic,\n unbox: unbox,\n accessor: toAccessorString\n};\n\n/* globals requestAnimationFrame, cancelAnimationFrame */\nvar raf = {\n next: typeof requestAnimationFrame === 'function'\n ? function (cb) { return requestAnimationFrame(cb) }\n : function (cb) { return setTimeout(cb, 16) },\n cancel: typeof cancelAnimationFrame === 'function'\n ? function (raf) { return cancelAnimationFrame(raf) }\n : clearTimeout\n};\n\n/* globals performance */\nvar clock = (typeof performance !== 'undefined' && performance.now)\n ? function () { return performance.now() }\n : function () { return +(new Date()) };\n\nfunction createStringStore () {\n var stringIds = { '': 0 }\n var stringValues = ['']\n return {\n id: function (str) {\n var result = stringIds[str]\n if (result) {\n return result\n }\n result = stringIds[str] = stringValues.length\n stringValues.push(str)\n return result\n },\n\n str: function (id) {\n return stringValues[id]\n }\n }\n}\n\n// Context and canvas creation helper functions\n\nfunction createCanvas (element, onDone, pixelRatio) {\n var canvas = document.createElement('canvas')\n extend(canvas.style, {\n border: 0,\n margin: 0,\n padding: 0,\n top: 0,\n left: 0,\n width: '100%',\n height: '100%'\n })\n element.appendChild(canvas)\n\n if (element === document.body) {\n canvas.style.position = 'absolute'\n extend(element.style, {\n margin: 0,\n padding: 0\n })\n }\n\n function resize () {\n var w = window.innerWidth\n var h = window.innerHeight\n if (element !== document.body) {\n var bounds = canvas.getBoundingClientRect()\n w = bounds.right - bounds.left\n h = bounds.bottom - bounds.top\n }\n canvas.width = pixelRatio * w\n canvas.height = pixelRatio * h\n }\n\n var resizeObserver\n if (element !== document.body && typeof ResizeObserver === 'function') {\n // ignore 'ResizeObserver' is not defined\n // eslint-disable-next-line\n resizeObserver = new ResizeObserver(function () {\n // setTimeout to avoid flicker\n setTimeout(resize)\n })\n resizeObserver.observe(element)\n } else {\n window.addEventListener('resize', resize, false)\n }\n\n function onDestroy () {\n if (resizeObserver) {\n resizeObserver.disconnect()\n } else {\n window.removeEventListener('resize', resize)\n }\n element.removeChild(canvas)\n }\n\n resize()\n\n return {\n canvas: canvas,\n onDestroy: onDestroy\n }\n}\n\nfunction createContext (canvas, contextAttributes) {\n function get (name) {\n try {\n return canvas.getContext(name, contextAttributes)\n } catch (e) {\n return null\n }\n }\n return (\n get('webgl') ||\n get('experimental-webgl') ||\n get('webgl-experimental')\n )\n}\n\nfunction isHTMLElement (obj) {\n return (\n typeof obj.nodeName === 'string' &&\n typeof obj.appendChild === 'function' &&\n typeof obj.getBoundingClientRect === 'function'\n )\n}\n\nfunction isWebGLContext (obj) {\n return (\n typeof obj.drawArrays === 'function' ||\n typeof obj.drawElements === 'function'\n )\n}\n\nfunction parseExtensions (input) {\n if (typeof input === 'string') {\n return input.split()\n }\n \n return input\n}\n\nfunction getElement (desc) {\n if (typeof desc === 'string') {\n \n return document.querySelector(desc)\n }\n return desc\n}\n\nfunction parseArgs (args_) {\n var args = args_ || {}\n var element, container, canvas, gl\n var contextAttributes = {}\n var extensions = []\n var optionalExtensions = []\n var pixelRatio = (typeof window === 'undefined' ? 1 : window.devicePixelRatio)\n var profile = false\n var cachedCode = {}\n var onDone = function (err) {\n if (err) {\n \n }\n }\n var onDestroy = function () {}\n if (typeof args === 'string') {\n \n element = document.querySelector(args)\n \n } else if (typeof args === 'object') {\n if (isHTMLElement(args)) {\n element = args\n } else if (isWebGLContext(args)) {\n gl = args\n canvas = gl.canvas\n } else {\n \n if ('gl' in args) {\n gl = args.gl\n } else if ('canvas' in args) {\n canvas = getElement(args.canvas)\n } else if ('container' in args) {\n container = getElement(args.container)\n }\n if ('attributes' in args) {\n contextAttributes = args.attributes\n \n }\n if ('extensions' in args) {\n extensions = parseExtensions(args.extensions)\n }\n if ('optionalExtensions' in args) {\n optionalExtensions = parseExtensions(args.optionalExtensions)\n }\n if ('onDone' in args) {\n \n onDone = args.onDone\n }\n if ('profile' in args) {\n profile = !!args.profile\n }\n if ('pixelRatio' in args) {\n pixelRatio = +args.pixelRatio\n \n }\n if ('cachedCode' in args) {\n \n cachedCode = args.cachedCode\n }\n }\n } else {\n \n }\n\n if (element) {\n if (element.nodeName.toLowerCase() === 'canvas') {\n canvas = element\n } else {\n container = element\n }\n }\n\n if (!gl) {\n if (!canvas) {\n \n var result = createCanvas(container || document.body, onDone, pixelRatio)\n if (!result) {\n return null\n }\n canvas = result.canvas\n onDestroy = result.onDestroy\n }\n // workaround for chromium bug, premultiplied alpha value is platform dependent\n if (contextAttributes.premultipliedAlpha === undefined) contextAttributes.premultipliedAlpha = true\n gl = createContext(canvas, contextAttributes)\n }\n\n if (!gl) {\n onDestroy()\n onDone('webgl not supported, try upgrading your browser or graphics drivers http://get.webgl.org')\n return null\n }\n\n return {\n gl: gl,\n canvas: canvas,\n container: container,\n extensions: extensions,\n optionalExtensions: optionalExtensions,\n pixelRatio: pixelRatio,\n profile: profile,\n cachedCode: cachedCode,\n onDone: onDone,\n onDestroy: onDestroy\n }\n}\n\nfunction createExtensionCache (gl, config) {\n var extensions = {}\n\n function tryLoadExtension (name_) {\n \n var name = name_.toLowerCase()\n var ext\n try {\n ext = extensions[name] = gl.getExtension(name)\n } catch (e) {}\n return !!ext\n }\n\n for (var i = 0; i < config.extensions.length; ++i) {\n var name = config.extensions[i]\n if (!tryLoadExtension(name)) {\n config.onDestroy()\n config.onDone('\"' + name + '\" extension is not supported by the current WebGL context, try upgrading your system or a different browser')\n return null\n }\n }\n\n config.optionalExtensions.forEach(tryLoadExtension)\n\n return {\n extensions: extensions,\n restore: function () {\n Object.keys(extensions).forEach(function (name) {\n if (extensions[name] && !tryLoadExtension(name)) {\n throw new Error('(regl): error restoring extension ' + name)\n }\n })\n }\n }\n}\n\nfunction loop (n, f) {\n var result = Array(n)\n for (var i = 0; i < n; ++i) {\n result[i] = f(i)\n }\n return result\n}\n\nvar GL_BYTE = 5120\nvar GL_UNSIGNED_BYTE$1 = 5121\nvar GL_SHORT = 5122\nvar GL_UNSIGNED_SHORT = 5123\nvar GL_INT = 5124\nvar GL_UNSIGNED_INT = 5125\nvar GL_FLOAT$1 = 5126\n\nfunction nextPow16 (v) {\n for (var i = 16; i <= (1 << 28); i *= 16) {\n if (v <= i) {\n return i\n }\n }\n return 0\n}\n\nfunction log2 (v) {\n var r, shift\n r = (v > 0xFFFF) << 4\n v >>>= r\n shift = (v > 0xFF) << 3\n v >>>= shift; r |= shift\n shift = (v > 0xF) << 2\n v >>>= shift; r |= shift\n shift = (v > 0x3) << 1\n v >>>= shift; r |= shift\n return r | (v >> 1)\n}\n\nfunction createPool () {\n var bufferPool = loop(8, function () {\n return []\n })\n\n function alloc (n) {\n var sz = nextPow16(n)\n var bin = bufferPool[log2(sz) >> 2]\n if (bin.length > 0) {\n return bin.pop()\n }\n return new ArrayBuffer(sz)\n }\n\n function free (buf) {\n bufferPool[log2(buf.byteLength) >> 2].push(buf)\n }\n\n function allocType (type, n) {\n var result = null\n switch (type) {\n case GL_BYTE:\n result = new Int8Array(alloc(n), 0, n)\n break\n case GL_UNSIGNED_BYTE$1:\n result = new Uint8Array(alloc(n), 0, n)\n break\n case GL_SHORT:\n result = new Int16Array(alloc(2 * n), 0, n)\n break\n case GL_UNSIGNED_SHORT:\n result = new Uint16Array(alloc(2 * n), 0, n)\n break\n case GL_INT:\n result = new Int32Array(alloc(4 * n), 0, n)\n break\n case GL_UNSIGNED_INT:\n result = new Uint32Array(alloc(4 * n), 0, n)\n break\n case GL_FLOAT$1:\n result = new Float32Array(alloc(4 * n), 0, n)\n break\n default:\n return null\n }\n if (result.length !== n) {\n return result.subarray(0, n)\n }\n return result\n }\n\n function freeType (array) {\n free(array.buffer)\n }\n\n return {\n alloc: alloc,\n free: free,\n allocType: allocType,\n freeType: freeType\n }\n}\n\nvar pool = createPool()\n\n// zero pool for initial zero data\npool.zero = createPool()\n\nvar GL_SUBPIXEL_BITS = 0x0D50\nvar GL_RED_BITS = 0x0D52\nvar GL_GREEN_BITS = 0x0D53\nvar GL_BLUE_BITS = 0x0D54\nvar GL_ALPHA_BITS = 0x0D55\nvar GL_DEPTH_BITS = 0x0D56\nvar GL_STENCIL_BITS = 0x0D57\n\nvar GL_ALIASED_POINT_SIZE_RANGE = 0x846D\nvar GL_ALIASED_LINE_WIDTH_RANGE = 0x846E\n\nvar GL_MAX_TEXTURE_SIZE = 0x0D33\nvar GL_MAX_VIEWPORT_DIMS = 0x0D3A\nvar GL_MAX_VERTEX_ATTRIBS = 0x8869\nvar GL_MAX_VERTEX_UNIFORM_VECTORS = 0x8DFB\nvar GL_MAX_VARYING_VECTORS = 0x8DFC\nvar GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS = 0x8B4D\nvar GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS = 0x8B4C\nvar GL_MAX_TEXTURE_IMAGE_UNITS = 0x8872\nvar GL_MAX_FRAGMENT_UNIFORM_VECTORS = 0x8DFD\nvar GL_MAX_CUBE_MAP_TEXTURE_SIZE = 0x851C\nvar GL_MAX_RENDERBUFFER_SIZE = 0x84E8\n\nvar GL_VENDOR = 0x1F00\nvar GL_RENDERER = 0x1F01\nvar GL_VERSION = 0x1F02\nvar GL_SHADING_LANGUAGE_VERSION = 0x8B8C\n\nvar GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT = 0x84FF\n\nvar GL_MAX_COLOR_ATTACHMENTS_WEBGL = 0x8CDF\nvar GL_MAX_DRAW_BUFFERS_WEBGL = 0x8824\n\nvar GL_TEXTURE_2D = 0x0DE1\nvar GL_TEXTURE_CUBE_MAP = 0x8513\nvar GL_TEXTURE_CUBE_MAP_POSITIVE_X = 0x8515\nvar GL_TEXTURE0 = 0x84C0\nvar GL_RGBA = 0x1908\nvar GL_FLOAT = 0x1406\nvar GL_UNSIGNED_BYTE = 0x1401\nvar GL_FRAMEBUFFER = 0x8D40\nvar GL_FRAMEBUFFER_COMPLETE = 0x8CD5\nvar GL_COLOR_ATTACHMENT0 = 0x8CE0\nvar GL_COLOR_BUFFER_BIT$1 = 0x4000\n\nvar wrapLimits = function (gl, extensions) {\n var maxAnisotropic = 1\n if (extensions.ext_texture_filter_anisotropic) {\n maxAnisotropic = gl.getParameter(GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT)\n }\n\n var maxDrawbuffers = 1\n var maxColorAttachments = 1\n if (extensions.webgl_draw_buffers) {\n maxDrawbuffers = gl.getParameter(GL_MAX_DRAW_BUFFERS_WEBGL)\n maxColorAttachments = gl.getParameter(GL_MAX_COLOR_ATTACHMENTS_WEBGL)\n }\n\n // detect if reading float textures is available (Safari doesn't support)\n var readFloat = !!extensions.oes_texture_float\n if (readFloat) {\n var readFloatTexture = gl.createTexture()\n gl.bindTexture(GL_TEXTURE_2D, readFloatTexture)\n gl.texImage2D(GL_TEXTURE_2D, 0, GL_RGBA, 1, 1, 0, GL_RGBA, GL_FLOAT, null)\n\n var fbo = gl.createFramebuffer()\n gl.bindFramebuffer(GL_FRAMEBUFFER, fbo)\n gl.framebufferTexture2D(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_TEXTURE_2D, readFloatTexture, 0)\n gl.bindTexture(GL_TEXTURE_2D, null)\n\n if (gl.checkFramebufferStatus(GL_FRAMEBUFFER) !== GL_FRAMEBUFFER_COMPLETE) readFloat = false\n\n else {\n gl.viewport(0, 0, 1, 1)\n gl.clearColor(1.0, 0.0, 0.0, 1.0)\n gl.clear(GL_COLOR_BUFFER_BIT$1)\n var pixels = pool.allocType(GL_FLOAT, 4)\n gl.readPixels(0, 0, 1, 1, GL_RGBA, GL_FLOAT, pixels)\n\n if (gl.getError()) readFloat = false\n else {\n gl.deleteFramebuffer(fbo)\n gl.deleteTexture(readFloatTexture)\n\n readFloat = pixels[0] === 1.0\n }\n\n pool.freeType(pixels)\n }\n }\n\n // detect non power of two cube textures support (IE doesn't support)\n var isIE = typeof navigator !== 'undefined' && (/MSIE/.test(navigator.userAgent) || /Trident\\//.test(navigator.appVersion) || /Edge/.test(navigator.userAgent))\n\n var npotTextureCube = true\n\n if (!isIE) {\n var cubeTexture = gl.createTexture()\n var data = pool.allocType(GL_UNSIGNED_BYTE, 36)\n gl.activeTexture(GL_TEXTURE0)\n gl.bindTexture(GL_TEXTURE_CUBE_MAP, cubeTexture)\n gl.texImage2D(GL_TEXTURE_CUBE_MAP_POSITIVE_X, 0, GL_RGBA, 3, 3, 0, GL_RGBA, GL_UNSIGNED_BYTE, data)\n pool.freeType(data)\n gl.bindTexture(GL_TEXTURE_CUBE_MAP, null)\n gl.deleteTexture(cubeTexture)\n npotTextureCube = !gl.getError()\n }\n\n return {\n // drawing buffer bit depth\n colorBits: [\n gl.getParameter(GL_RED_BITS),\n gl.getParameter(GL_GREEN_BITS),\n gl.getParameter(GL_BLUE_BITS),\n gl.getParameter(GL_ALPHA_BITS)\n ],\n depthBits: gl.getParameter(GL_DEPTH_BITS),\n stencilBits: gl.getParameter(GL_STENCIL_BITS),\n subpixelBits: gl.getParameter(GL_SUBPIXEL_BITS),\n\n // supported extensions\n extensions: Object.keys(extensions).filter(function (ext) {\n return !!extensions[ext]\n }),\n\n // max aniso samples\n maxAnisotropic: maxAnisotropic,\n\n // max draw buffers\n maxDrawbuffers: maxDrawbuffers,\n maxColorAttachments: maxColorAttachments,\n\n // point and line size ranges\n pointSizeDims: gl.getParameter(GL_ALIASED_POINT_SIZE_RANGE),\n lineWidthDims: gl.getParameter(GL_ALIASED_LINE_WIDTH_RANGE),\n maxViewportDims: gl.getParameter(GL_MAX_VIEWPORT_DIMS),\n maxCombinedTextureUnits: gl.getParameter(GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS),\n maxCubeMapSize: gl.getParameter(GL_MAX_CUBE_MAP_TEXTURE_SIZE),\n maxRenderbufferSize: gl.getParameter(GL_MAX_RENDERBUFFER_SIZE),\n maxTextureUnits: gl.getParameter(GL_MAX_TEXTURE_IMAGE_UNITS),\n maxTextureSize: gl.getParameter(GL_MAX_TEXTURE_SIZE),\n maxAttributes: gl.getParameter(GL_MAX_VERTEX_ATTRIBS),\n maxVertexUniforms: gl.getParameter(GL_MAX_VERTEX_UNIFORM_VECTORS),\n maxVertexTextureUnits: gl.getParameter(GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS),\n maxVaryingVectors: gl.getParameter(GL_MAX_VARYING_VECTORS),\n maxFragmentUniforms: gl.getParameter(GL_MAX_FRAGMENT_UNIFORM_VECTORS),\n\n // vendor info\n glsl: gl.getParameter(GL_SHADING_LANGUAGE_VERSION),\n renderer: gl.getParameter(GL_RENDERER),\n vendor: gl.getParameter(GL_VENDOR),\n version: gl.getParameter(GL_VERSION),\n\n // quirks\n readFloat: readFloat,\n npotTextureCube: npotTextureCube\n }\n}\n\nvar isTypedArray = function (x) {\n return (\n x instanceof Uint8Array ||\n x instanceof Uint16Array ||\n x instanceof Uint32Array ||\n x instanceof Int8Array ||\n x instanceof Int16Array ||\n x instanceof Int32Array ||\n x instanceof Float32Array ||\n x instanceof Float64Array ||\n x instanceof Uint8ClampedArray\n )\n}\n\nfunction isNDArrayLike (obj) {\n return (\n !!obj &&\n typeof obj === 'object' &&\n Array.isArray(obj.shape) &&\n Array.isArray(obj.stride) &&\n typeof obj.offset === 'number' &&\n obj.shape.length === obj.stride.length &&\n (Array.isArray(obj.data) ||\n isTypedArray(obj.data)))\n}\n\nvar values = function (obj) {\n return Object.keys(obj).map(function (key) { return obj[key] })\n}\n\nvar flattenUtils = {\n shape: arrayShape$1,\n flatten: flattenArray\n};\n\nfunction flatten1D (array, nx, out) {\n for (var i = 0; i < nx; ++i) {\n out[i] = array[i]\n }\n}\n\nfunction flatten2D (array, nx, ny, out) {\n var ptr = 0\n for (var i = 0; i < nx; ++i) {\n var row = array[i]\n for (var j = 0; j < ny; ++j) {\n out[ptr++] = row[j]\n }\n }\n}\n\nfunction flatten3D (array, nx, ny, nz, out, ptr_) {\n var ptr = ptr_\n for (var i = 0; i < nx; ++i) {\n var row = array[i]\n for (var j = 0; j < ny; ++j) {\n var col = row[j]\n for (var k = 0; k < nz; ++k) {\n out[ptr++] = col[k]\n }\n }\n }\n}\n\nfunction flattenRec (array, shape, level, out, ptr) {\n var stride = 1\n for (var i = level + 1; i < shape.length; ++i) {\n stride *= shape[i]\n }\n var n = shape[level]\n if (shape.length - level === 4) {\n var nx = shape[level + 1]\n var ny = shape[level + 2]\n var nz = shape[level + 3]\n for (i = 0; i < n; ++i) {\n flatten3D(array[i], nx, ny, nz, out, ptr)\n ptr += stride\n }\n } else {\n for (i = 0; i < n; ++i) {\n flattenRec(array[i], shape, level + 1, out, ptr)\n ptr += stride\n }\n }\n}\n\nfunction flattenArray (array, shape, type, out_) {\n var sz = 1\n if (shape.length) {\n for (var i = 0; i < shape.length; ++i) {\n sz *= shape[i]\n }\n } else {\n sz = 0\n }\n var out = out_ || pool.allocType(type, sz)\n switch (shape.length) {\n case 0:\n break\n case 1:\n flatten1D(array, shape[0], out)\n break\n case 2:\n flatten2D(array, shape[0], shape[1], out)\n break\n case 3:\n flatten3D(array, shape[0], shape[1], shape[2], out, 0)\n break\n default:\n flattenRec(array, shape, 0, out, 0)\n }\n return out\n}\n\nfunction arrayShape$1 (array_) {\n var shape = []\n for (var array = array_; array.length; array = array[0]) {\n shape.push(array.length)\n }\n return shape\n}\n\nvar arrayTypes = {\n\t\"[object Int8Array]\": 5120,\n\t\"[object Int16Array]\": 5122,\n\t\"[object Int32Array]\": 5124,\n\t\"[object Uint8Array]\": 5121,\n\t\"[object Uint8ClampedArray]\": 5121,\n\t\"[object Uint16Array]\": 5123,\n\t\"[object Uint32Array]\": 5125,\n\t\"[object Float32Array]\": 5126,\n\t\"[object Float64Array]\": 5121,\n\t\"[object ArrayBuffer]\": 5121\n};\n\nvar int8 = 5120;\nvar int16 = 5122;\nvar int32 = 5124;\nvar uint8 = 5121;\nvar uint16 = 5123;\nvar uint32 = 5125;\nvar float = 5126;\nvar float32 = 5126;\nvar glTypes = {\n\tint8: int8,\n\tint16: int16,\n\tint32: int32,\n\tuint8: uint8,\n\tuint16: uint16,\n\tuint32: uint32,\n\tfloat: float,\n\tfloat32: float32\n};\n\nvar dynamic$1 = 35048;\nvar stream = 35040;\nvar usageTypes = {\n\tdynamic: dynamic$1,\n\tstream: stream,\n\t\"static\": 35044\n};\n\nvar arrayFlatten = flattenUtils.flatten\nvar arrayShape = flattenUtils.shape\n\nvar GL_STATIC_DRAW = 0x88E4\nvar GL_STREAM_DRAW = 0x88E0\n\nvar GL_UNSIGNED_BYTE$2 = 5121\nvar GL_FLOAT$2 = 5126\n\nvar DTYPES_SIZES = []\nDTYPES_SIZES[5120] = 1 // int8\nDTYPES_SIZES[5122] = 2 // int16\nDTYPES_SIZES[5124] = 4 // int32\nDTYPES_SIZES[5121] = 1 // uint8\nDTYPES_SIZES[5123] = 2 // uint16\nDTYPES_SIZES[5125] = 4 // uint32\nDTYPES_SIZES[5126] = 4 // float32\n\nfunction typedArrayCode (data) {\n return arrayTypes[Object.prototype.toString.call(data)] | 0\n}\n\nfunction copyArray (out, inp) {\n for (var i = 0; i < inp.length; ++i) {\n out[i] = inp[i]\n }\n}\n\nfunction transpose (\n result, data, shapeX, shapeY, strideX, strideY, offset) {\n var ptr = 0\n for (var i = 0; i < shapeX; ++i) {\n for (var j = 0; j < shapeY; ++j) {\n result[ptr++] = data[strideX * i + strideY * j + offset]\n }\n }\n}\n\nfunction wrapBufferState (gl, stats, config, destroyBuffer) {\n var bufferCount = 0\n var bufferSet = {}\n\n function REGLBuffer (type) {\n this.id = bufferCount++\n this.buffer = gl.createBuffer()\n this.type = type\n this.usage = GL_STATIC_DRAW\n this.byteLength = 0\n this.dimension = 1\n this.dtype = GL_UNSIGNED_BYTE$2\n\n this.persistentData = null\n\n if (config.profile) {\n this.stats = { size: 0 }\n }\n }\n\n REGLBuffer.prototype.bind = function () {\n gl.bindBuffer(this.type, this.buffer)\n }\n\n REGLBuffer.prototype.destroy = function () {\n destroy(this)\n }\n\n var streamPool = []\n\n function createStream (type, data) {\n var buffer = streamPool.pop()\n if (!buffer) {\n buffer = new REGLBuffer(type)\n }\n buffer.bind()\n initBufferFromData(buffer, data, GL_STREAM_DRAW, 0, 1, false)\n return buffer\n }\n\n function destroyStream (stream$$1) {\n streamPool.push(stream$$1)\n }\n\n function initBufferFromTypedArray (buffer, data, usage) {\n buffer.byteLength = data.byteLength\n gl.bufferData(buffer.type, data, usage)\n }\n\n function initBufferFromData (buffer, data, usage, dtype, dimension, persist) {\n var shape\n buffer.usage = usage\n if (Array.isArray(data)) {\n buffer.dtype = dtype || GL_FLOAT$2\n if (data.length > 0) {\n var flatData\n if (Array.isArray(data[0])) {\n shape = arrayShape(data)\n var dim = 1\n for (var i = 1; i < shape.length; ++i) {\n dim *= shape[i]\n }\n buffer.dimension = dim\n flatData = arrayFlatten(data, shape, buffer.dtype)\n initBufferFromTypedArray(buffer, flatData, usage)\n if (persist) {\n buffer.persistentData = flatData\n } else {\n pool.freeType(flatData)\n }\n } else if (typeof data[0] === 'number') {\n buffer.dimension = dimension\n var typedData = pool.allocType(buffer.dtype, data.length)\n copyArray(typedData, data)\n initBufferFromTypedArray(buffer, typedData, usage)\n if (persist) {\n buffer.persistentData = typedData\n } else {\n pool.freeType(typedData)\n }\n } else if (isTypedArray(data[0])) {\n buffer.dimension = data[0].length\n buffer.dtype = dtype || typedArrayCode(data[0]) || GL_FLOAT$2\n flatData = arrayFlatten(\n data,\n [data.length, data[0].length],\n buffer.dtype)\n initBufferFromTypedArray(buffer, flatData, usage)\n if (persist) {\n buffer.persistentData = flatData\n } else {\n pool.freeType(flatData)\n }\n } else {\n \n }\n }\n } else if (isTypedArray(data)) {\n buffer.dtype = dtype || typedArrayCode(data)\n buffer.dimension = dimension\n initBufferFromTypedArray(buffer, data, usage)\n if (persist) {\n buffer.persistentData = new Uint8Array(new Uint8Array(data.buffer))\n }\n } else if (isNDArrayLike(data)) {\n shape = data.shape\n var stride = data.stride\n var offset = data.offset\n\n var shapeX = 0\n var shapeY = 0\n var strideX = 0\n var strideY = 0\n if (shape.length === 1) {\n shapeX = shape[0]\n shapeY = 1\n strideX = stride[0]\n strideY = 0\n } else if (shape.length === 2) {\n shapeX = shape[0]\n shapeY = shape[1]\n strideX = stride[0]\n strideY = stride[1]\n } else {\n \n }\n\n buffer.dtype = dtype || typedArrayCode(data.data) || GL_FLOAT$2\n buffer.dimension = shapeY\n\n var transposeData = pool.allocType(buffer.dtype, shapeX * shapeY)\n transpose(transposeData,\n data.data,\n shapeX, shapeY,\n strideX, strideY,\n offset)\n initBufferFromTypedArray(buffer, transposeData, usage)\n if (persist) {\n buffer.persistentData = transposeData\n } else {\n pool.freeType(transposeData)\n }\n } else if (data instanceof ArrayBuffer) {\n buffer.dtype = GL_UNSIGNED_BYTE$2\n buffer.dimension = dimension\n initBufferFromTypedArray(buffer, data, usage)\n if (persist) {\n buffer.persistentData = new Uint8Array(new Uint8Array(data))\n }\n } else {\n \n }\n }\n\n function destroy (buffer) {\n stats.bufferCount--\n\n // remove attribute link\n destroyBuffer(buffer)\n\n var handle = buffer.buffer\n \n gl.deleteBuffer(handle)\n buffer.buffer = null\n delete bufferSet[buffer.id]\n }\n\n function createBuffer (options, type, deferInit, persistent) {\n stats.bufferCount++\n\n var buffer = new REGLBuffer(type)\n bufferSet[buffer.id] = buffer\n\n function reglBuffer (options) {\n var usage = GL_STATIC_DRAW\n var data = null\n var byteLength = 0\n var dtype = 0\n var dimension = 1\n if (Array.isArray(options) ||\n isTypedArray(options) ||\n isNDArrayLike(options) ||\n options instanceof ArrayBuffer) {\n data = options\n } else if (typeof options === 'number') {\n byteLength = options | 0\n } else if (options) {\n \n\n if ('data' in options) {\n \n data = options.data\n }\n\n if ('usage' in options) {\n \n usage = usageTypes[options.usage]\n }\n\n if ('type' in options) {\n \n dtype = glTypes[options.type]\n }\n\n if ('dimension' in options) {\n \n dimension = options.dimension | 0\n }\n\n if ('length' in options) {\n \n byteLength = options.length | 0\n }\n }\n\n buffer.bind()\n if (!data) {\n // #475\n if (byteLength) gl.bufferData(buffer.type, byteLength, usage)\n buffer.dtype = dtype || GL_UNSIGNED_BYTE$2\n buffer.usage = usage\n buffer.dimension = dimension\n buffer.byteLength = byteLength\n } else {\n initBufferFromData(buffer, data, usage, dtype, dimension, persistent)\n }\n\n if (config.profile) {\n buffer.stats.size = buffer.byteLength * DTYPES_SIZES[buffer.dtype]\n }\n\n return reglBuffer\n }\n\n function setSubData (data, offset) {\n \n\n gl.bufferSubData(buffer.type, offset, data)\n }\n\n function subdata (data, offset_) {\n var offset = (offset_ || 0) | 0\n var shape\n buffer.bind()\n if (isTypedArray(data) || data instanceof ArrayBuffer) {\n setSubData(data, offset)\n } else if (Array.isArray(data)) {\n if (data.length > 0) {\n if (typeof data[0] === 'number') {\n var converted = pool.allocType(buffer.dtype, data.length)\n copyArray(converted, data)\n setSubData(converted, offset)\n pool.freeType(converted)\n } else if (Array.isArray(data[0]) || isTypedArray(data[0])) {\n shape = arrayShape(data)\n var flatData = arrayFlatten(data, shape, buffer.dtype)\n setSubData(flatData, offset)\n pool.freeType(flatData)\n } else {\n \n }\n }\n } else if (isNDArrayLike(data)) {\n shape = data.shape\n var stride = data.stride\n\n var shapeX = 0\n var shapeY = 0\n var strideX = 0\n var strideY = 0\n if (shape.length === 1) {\n shapeX = shape[0]\n shapeY = 1\n strideX = stride[0]\n strideY = 0\n } else if (shape.length === 2) {\n shapeX = shape[0]\n shapeY = shape[1]\n strideX = stride[0]\n strideY = stride[1]\n } else {\n \n }\n var dtype = Array.isArray(data.data)\n ? buffer.dtype\n : typedArrayCode(data.data)\n\n var transposeData = pool.allocType(dtype, shapeX * shapeY)\n transpose(transposeData,\n data.data,\n shapeX, shapeY,\n strideX, strideY,\n data.offset)\n setSubData(transposeData, offset)\n pool.freeType(transposeData)\n } else {\n \n }\n return reglBuffer\n }\n\n if (!deferInit) {\n reglBuffer(options)\n }\n\n reglBuffer._reglType = 'buffer'\n reglBuffer._buffer = buffer\n reglBuffer.subdata = subdata\n if (config.profile) {\n reglBuffer.stats = buffer.stats\n }\n reglBuffer.destroy = function () { destroy(buffer) }\n\n return reglBuffer\n }\n\n function restoreBuffers () {\n values(bufferSet).forEach(function (buffer) {\n buffer.buffer = gl.createBuffer()\n gl.bindBuffer(buffer.type, buffer.buffer)\n gl.bufferData(\n buffer.type, buffer.persistentData || buffer.byteLength, buffer.usage)\n })\n }\n\n if (config.profile) {\n stats.getTotalBufferSize = function () {\n var total = 0\n // TODO: Right now, the streams are not part of the total count.\n Object.keys(bufferSet).forEach(function (key) {\n total += bufferSet[key].stats.size\n })\n return total\n }\n }\n\n return {\n create: createBuffer,\n\n createStream: createStream,\n destroyStream: destroyStream,\n\n clear: function () {\n values(bufferSet).forEach(destroy)\n streamPool.forEach(destroy)\n },\n\n getBuffer: function (wrapper) {\n if (wrapper && wrapper._buffer instanceof REGLBuffer) {\n return wrapper._buffer\n }\n return null\n },\n\n restore: restoreBuffers,\n\n _initBuffer: initBufferFromData\n }\n}\n\nvar points = 0;\nvar point = 0;\nvar lines = 1;\nvar line = 1;\nvar triangles = 4;\nvar triangle = 4;\nvar primTypes = {\n\tpoints: points,\n\tpoint: point,\n\tlines: lines,\n\tline: line,\n\ttriangles: triangles,\n\ttriangle: triangle,\n\t\"line loop\": 2,\n\t\"line strip\": 3,\n\t\"triangle strip\": 5,\n\t\"triangle fan\": 6\n};\n\nvar GL_POINTS = 0\nvar GL_LINES = 1\nvar GL_TRIANGLES = 4\n\nvar GL_BYTE$1 = 5120\nvar GL_UNSIGNED_BYTE$3 = 5121\nvar GL_SHORT$1 = 5122\nvar GL_UNSIGNED_SHORT$1 = 5123\nvar GL_INT$1 = 5124\nvar GL_UNSIGNED_INT$1 = 5125\n\nvar GL_ELEMENT_ARRAY_BUFFER = 34963\n\nvar GL_STREAM_DRAW$1 = 0x88E0\nvar GL_STATIC_DRAW$1 = 0x88E4\n\nfunction wrapElementsState (gl, extensions, bufferState, stats) {\n var elementSet = {}\n var elementCount = 0\n\n var elementTypes = {\n 'uint8': GL_UNSIGNED_BYTE$3,\n 'uint16': GL_UNSIGNED_SHORT$1\n }\n\n if (extensions.oes_element_index_uint) {\n elementTypes.uint32 = GL_UNSIGNED_INT$1\n }\n\n function REGLElementBuffer (buffer) {\n this.id = elementCount++\n elementSet[this.id] = this\n this.buffer = buffer\n this.primType = GL_TRIANGLES\n this.vertCount = 0\n this.type = 0\n }\n\n REGLElementBuffer.prototype.bind = function () {\n this.buffer.bind()\n }\n\n var bufferPool = []\n\n function createElementStream (data) {\n var result = bufferPool.pop()\n if (!result) {\n result = new REGLElementBuffer(bufferState.create(\n null,\n GL_ELEMENT_ARRAY_BUFFER,\n true,\n false)._buffer)\n }\n initElements(result, data, GL_STREAM_DRAW$1, -1, -1, 0, 0)\n return result\n }\n\n function destroyElementStream (elements) {\n bufferPool.push(elements)\n }\n\n function initElements (\n elements,\n data,\n usage,\n prim,\n count,\n byteLength,\n type) {\n elements.buffer.bind()\n var dtype\n if (data) {\n var predictedType = type\n if (!type && (\n !isTypedArray(data) ||\n (isNDArrayLike(data) && !isTypedArray(data.data)))) {\n predictedType = extensions.oes_element_index_uint\n ? GL_UNSIGNED_INT$1\n : GL_UNSIGNED_SHORT$1\n }\n bufferState._initBuffer(\n elements.buffer,\n data,\n usage,\n predictedType,\n 3)\n } else {\n gl.bufferData(GL_ELEMENT_ARRAY_BUFFER, byteLength, usage)\n elements.buffer.dtype = dtype || GL_UNSIGNED_BYTE$3\n elements.buffer.usage = usage\n elements.buffer.dimension = 3\n elements.buffer.byteLength = byteLength\n }\n\n dtype = type\n if (!type) {\n switch (elements.buffer.dtype) {\n case GL_UNSIGNED_BYTE$3:\n case GL_BYTE$1:\n dtype = GL_UNSIGNED_BYTE$3\n break\n\n case GL_UNSIGNED_SHORT$1:\n case GL_SHORT$1:\n dtype = GL_UNSIGNED_SHORT$1\n break\n\n case GL_UNSIGNED_INT$1:\n case GL_INT$1:\n dtype = GL_UNSIGNED_INT$1\n break\n\n default:\n \n }\n elements.buffer.dtype = dtype\n }\n elements.type = dtype\n\n // Check oes_element_index_uint extension\n \n\n // try to guess default primitive type and arguments\n var vertCount = count\n if (vertCount < 0) {\n vertCount = elements.buffer.byteLength\n if (dtype === GL_UNSIGNED_SHORT$1) {\n vertCount >>= 1\n } else if (dtype === GL_UNSIGNED_INT$1) {\n vertCount >>= 2\n }\n }\n elements.vertCount = vertCount\n\n // try to guess primitive type from cell dimension\n var primType = prim\n if (prim < 0) {\n primType = GL_TRIANGLES\n var dimension = elements.buffer.dimension\n if (dimension === 1) primType = GL_POINTS\n if (dimension === 2) primType = GL_LINES\n if (dimension === 3) primType = GL_TRIANGLES\n }\n elements.primType = primType\n }\n\n function destroyElements (elements) {\n stats.elementsCount--\n\n \n delete elementSet[elements.id]\n elements.buffer.destroy()\n elements.buffer = null\n }\n\n function createElements (options, persistent) {\n var buffer = bufferState.create(null, GL_ELEMENT_ARRAY_BUFFER, true)\n var elements = new REGLElementBuffer(buffer._buffer)\n stats.elementsCount++\n\n function reglElements (options) {\n if (!options) {\n buffer()\n elements.primType = GL_TRIANGLES\n elements.vertCount = 0\n elements.type = GL_UNSIGNED_BYTE$3\n } else if (typeof options === 'number') {\n buffer(options)\n elements.primType = GL_TRIANGLES\n elements.vertCount = options | 0\n elements.type = GL_UNSIGNED_BYTE$3\n } else {\n var data = null\n var usage = GL_STATIC_DRAW$1\n var primType = -1\n var vertCount = -1\n var byteLength = 0\n var dtype = 0\n if (Array.isArray(options) ||\n isTypedArray(options) ||\n isNDArrayLike(options)) {\n data = options\n } else {\n \n if ('data' in options) {\n data = options.data\n \n }\n if ('usage' in options) {\n \n usage = usageTypes[options.usage]\n }\n if ('primitive' in options) {\n \n primType = primTypes[options.primitive]\n }\n if ('count' in options) {\n \n vertCount = options.count | 0\n }\n if ('type' in options) {\n \n dtype = elementTypes[options.type]\n }\n if ('length' in options) {\n byteLength = options.length | 0\n } else {\n byteLength = vertCount\n if (dtype === GL_UNSIGNED_SHORT$1 || dtype === GL_SHORT$1) {\n byteLength *= 2\n } else if (dtype === GL_UNSIGNED_INT$1 || dtype === GL_INT$1) {\n byteLength *= 4\n }\n }\n }\n initElements(\n elements,\n data,\n usage,\n primType,\n vertCount,\n byteLength,\n dtype)\n }\n\n return reglElements\n }\n\n reglElements(options)\n\n reglElements._reglType = 'elements'\n reglElements._elements = elements\n reglElements.subdata = function (data, offset) {\n buffer.subdata(data, offset)\n return reglElements\n }\n reglElements.destroy = function () {\n destroyElements(elements)\n }\n\n return reglElements\n }\n\n return {\n create: createElements,\n createStream: createElementStream,\n destroyStream: destroyElementStream,\n getElements: function (elements) {\n if (typeof elements === 'function' &&\n elements._elements instanceof REGLElementBuffer) {\n return elements._elements\n }\n return null\n },\n clear: function () {\n values(elementSet).forEach(destroyElements)\n }\n }\n}\n\nvar FLOAT = new Float32Array(1)\nvar INT = new Uint32Array(FLOAT.buffer)\n\nvar GL_UNSIGNED_SHORT$3 = 5123\n\nfunction convertToHalfFloat (array) {\n var ushorts = pool.allocType(GL_UNSIGNED_SHORT$3, array.length)\n\n for (var i = 0; i < array.length; ++i) {\n if (isNaN(array[i])) {\n ushorts[i] = 0xffff\n } else if (array[i] === Infinity) {\n ushorts[i] = 0x7c00\n } else if (array[i] === -Infinity) {\n ushorts[i] = 0xfc00\n } else {\n FLOAT[0] = array[i]\n var x = INT[0]\n\n var sgn = (x >>> 31) << 15\n var exp = ((x << 1) >>> 24) - 127\n var frac = (x >> 13) & ((1 << 10) - 1)\n\n if (exp < -24) {\n // round non-representable denormals to 0\n ushorts[i] = sgn\n } else if (exp < -14) {\n // handle denormals\n var s = -14 - exp\n ushorts[i] = sgn + ((frac + (1 << 10)) >> s)\n } else if (exp > 15) {\n // round overflow to +/- Infinity\n ushorts[i] = sgn + 0x7c00\n } else {\n // otherwise convert directly\n ushorts[i] = sgn + ((exp + 15) << 10) + frac\n }\n }\n }\n\n return ushorts\n}\n\nfunction isArrayLike (s) {\n return Array.isArray(s) || isTypedArray(s)\n}\n\nvar GL_COMPRESSED_TEXTURE_FORMATS = 0x86A3\n\nvar GL_TEXTURE_2D$1 = 0x0DE1\nvar GL_TEXTURE_CUBE_MAP$1 = 0x8513\nvar GL_TEXTURE_CUBE_MAP_POSITIVE_X$1 = 0x8515\n\nvar GL_RGBA$1 = 0x1908\nvar GL_ALPHA = 0x1906\nvar GL_RGB = 0x1907\nvar GL_LUMINANCE = 0x1909\nvar GL_LUMINANCE_ALPHA = 0x190A\n\nvar GL_RGBA4 = 0x8056\nvar GL_RGB5_A1 = 0x8057\nvar GL_RGB565 = 0x8D62\n\nvar GL_UNSIGNED_SHORT_4_4_4_4 = 0x8033\nvar GL_UNSIGNED_SHORT_5_5_5_1 = 0x8034\nvar GL_UNSIGNED_SHORT_5_6_5 = 0x8363\nvar GL_UNSIGNED_INT_24_8_WEBGL = 0x84FA\n\nvar GL_DEPTH_COMPONENT = 0x1902\nvar GL_DEPTH_STENCIL = 0x84F9\n\nvar GL_SRGB_EXT = 0x8C40\nvar GL_SRGB_ALPHA_EXT = 0x8C42\n\nvar GL_HALF_FLOAT_OES = 0x8D61\n\nvar GL_COMPRESSED_RGB_S3TC_DXT1_EXT = 0x83F0\nvar GL_COMPRESSED_RGBA_S3TC_DXT1_EXT = 0x83F1\nvar GL_COMPRESSED_RGBA_S3TC_DXT3_EXT = 0x83F2\nvar GL_COMPRESSED_RGBA_S3TC_DXT5_EXT = 0x83F3\n\nvar GL_COMPRESSED_RGB_ATC_WEBGL = 0x8C92\nvar GL_COMPRESSED_RGBA_ATC_EXPLICIT_ALPHA_WEBGL = 0x8C93\nvar GL_COMPRESSED_RGBA_ATC_INTERPOLATED_ALPHA_WEBGL = 0x87EE\n\nvar GL_COMPRESSED_RGB_PVRTC_4BPPV1_IMG = 0x8C00\nvar GL_COMPRESSED_RGB_PVRTC_2BPPV1_IMG = 0x8C01\nvar GL_COMPRESSED_RGBA_PVRTC_4BPPV1_IMG = 0x8C02\nvar GL_COMPRESSED_RGBA_PVRTC_2BPPV1_IMG = 0x8C03\n\nvar GL_COMPRESSED_RGB_ETC1_WEBGL = 0x8D64\n\nvar GL_UNSIGNED_BYTE$4 = 0x1401\nvar GL_UNSIGNED_SHORT$2 = 0x1403\nvar GL_UNSIGNED_INT$2 = 0x1405\nvar GL_FLOAT$3 = 0x1406\n\nvar GL_TEXTURE_WRAP_S = 0x2802\nvar GL_TEXTURE_WRAP_T = 0x2803\n\nvar GL_REPEAT = 0x2901\nvar GL_CLAMP_TO_EDGE = 0x812F\nvar GL_MIRRORED_REPEAT = 0x8370\n\nvar GL_TEXTURE_MAG_FILTER = 0x2800\nvar GL_TEXTURE_MIN_FILTER = 0x2801\n\nvar GL_NEAREST = 0x2600\nvar GL_LINEAR = 0x2601\nvar GL_NEAREST_MIPMAP_NEAREST = 0x2700\nvar GL_LINEAR_MIPMAP_NEAREST = 0x2701\nvar GL_NEAREST_MIPMAP_LINEAR = 0x2702\nvar GL_LINEAR_MIPMAP_LINEAR = 0x2703\n\nvar GL_GENERATE_MIPMAP_HINT = 0x8192\nvar GL_DONT_CARE = 0x1100\nvar GL_FASTEST = 0x1101\nvar GL_NICEST = 0x1102\n\nvar GL_TEXTURE_MAX_ANISOTROPY_EXT = 0x84FE\n\nvar GL_UNPACK_ALIGNMENT = 0x0CF5\nvar GL_UNPACK_FLIP_Y_WEBGL = 0x9240\nvar GL_UNPACK_PREMULTIPLY_ALPHA_WEBGL = 0x9241\nvar GL_UNPACK_COLORSPACE_CONVERSION_WEBGL = 0x9243\n\nvar GL_BROWSER_DEFAULT_WEBGL = 0x9244\n\nvar GL_TEXTURE0$1 = 0x84C0\n\nvar MIPMAP_FILTERS = [\n GL_NEAREST_MIPMAP_NEAREST,\n GL_NEAREST_MIPMAP_LINEAR,\n GL_LINEAR_MIPMAP_NEAREST,\n GL_LINEAR_MIPMAP_LINEAR\n]\n\nvar CHANNELS_FORMAT = [\n 0,\n GL_LUMINANCE,\n GL_LUMINANCE_ALPHA,\n GL_RGB,\n GL_RGBA$1\n]\n\nvar FORMAT_CHANNELS = {}\nFORMAT_CHANNELS[GL_LUMINANCE] =\nFORMAT_CHANNELS[GL_ALPHA] =\nFORMAT_CHANNELS[GL_DEPTH_COMPONENT] = 1\nFORMAT_CHANNELS[GL_DEPTH_STENCIL] =\nFORMAT_CHANNELS[GL_LUMINANCE_ALPHA] = 2\nFORMAT_CHANNELS[GL_RGB] =\nFORMAT_CHANNELS[GL_SRGB_EXT] = 3\nFORMAT_CHANNELS[GL_RGBA$1] =\nFORMAT_CHANNELS[GL_SRGB_ALPHA_EXT] = 4\n\nfunction objectName (str) {\n return '[object ' + str + ']'\n}\n\nvar CANVAS_CLASS = objectName('HTMLCanvasElement')\nvar OFFSCREENCANVAS_CLASS = objectName('OffscreenCanvas')\nvar CONTEXT2D_CLASS = objectName('CanvasRenderingContext2D')\nvar BITMAP_CLASS = objectName('ImageBitmap')\nvar IMAGE_CLASS = objectName('HTMLImageElement')\nvar VIDEO_CLASS = objectName('HTMLVideoElement')\n\nvar PIXEL_CLASSES = Object.keys(arrayTypes).concat([\n CANVAS_CLASS,\n OFFSCREENCANVAS_CLASS,\n CONTEXT2D_CLASS,\n BITMAP_CLASS,\n IMAGE_CLASS,\n VIDEO_CLASS\n])\n\n// for every texture type, store\n// the size in bytes.\nvar TYPE_SIZES = []\nTYPE_SIZES[GL_UNSIGNED_BYTE$4] = 1\nTYPE_SIZES[GL_FLOAT$3] = 4\nTYPE_SIZES[GL_HALF_FLOAT_OES] = 2\n\nTYPE_SIZES[GL_UNSIGNED_SHORT$2] = 2\nTYPE_SIZES[GL_UNSIGNED_INT$2] = 4\n\nvar FORMAT_SIZES_SPECIAL = []\nFORMAT_SIZES_SPECIAL[GL_RGBA4] = 2\nFORMAT_SIZES_SPECIAL[GL_RGB5_A1] = 2\nFORMAT_SIZES_SPECIAL[GL_RGB565] = 2\nFORMAT_SIZES_SPECIAL[GL_DEPTH_STENCIL] = 4\n\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGB_S3TC_DXT1_EXT] = 0.5\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGBA_S3TC_DXT1_EXT] = 0.5\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGBA_S3TC_DXT3_EXT] = 1\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGBA_S3TC_DXT5_EXT] = 1\n\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGB_ATC_WEBGL] = 0.5\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGBA_ATC_EXPLICIT_ALPHA_WEBGL] = 1\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGBA_ATC_INTERPOLATED_ALPHA_WEBGL] = 1\n\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGB_PVRTC_4BPPV1_IMG] = 0.5\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGB_PVRTC_2BPPV1_IMG] = 0.25\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGBA_PVRTC_4BPPV1_IMG] = 0.5\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGBA_PVRTC_2BPPV1_IMG] = 0.25\n\nFORMAT_SIZES_SPECIAL[GL_COMPRESSED_RGB_ETC1_WEBGL] = 0.5\n\nfunction isNumericArray (arr) {\n return (\n Array.isArray(arr) &&\n (arr.length === 0 ||\n typeof arr[0] === 'number'))\n}\n\nfunction isRectArray (arr) {\n if (!Array.isArray(arr)) {\n return false\n }\n var width = arr.length\n if (width === 0 || !isArrayLike(arr[0])) {\n return false\n }\n return true\n}\n\nfunction classString (x) {\n return Object.prototype.toString.call(x)\n}\n\nfunction isCanvasElement (object) {\n return classString(object) === CANVAS_CLASS\n}\n\nfunction isOffscreenCanvas (object) {\n return classString(object) === OFFSCREENCANVAS_CLASS\n}\n\nfunction isContext2D (object) {\n return classString(object) === CONTEXT2D_CLASS\n}\n\nfunction isBitmap (object) {\n return classString(object) === BITMAP_CLASS\n}\n\nfunction isImageElement (object) {\n return classString(object) === IMAGE_CLASS\n}\n\nfunction isVideoElement (object) {\n return classString(object) === VIDEO_CLASS\n}\n\nfunction isPixelData (object) {\n if (!object) {\n return false\n }\n var className = classString(object)\n if (PIXEL_CLASSES.indexOf(className) >= 0) {\n return true\n }\n return (\n isNumericArray(object) ||\n isRectArray(object) ||\n isNDArrayLike(object))\n}\n\nfunction typedArrayCode$1 (data) {\n return arrayTypes[Object.prototype.toString.call(data)] | 0\n}\n\nfunction convertData (result, data) {\n var n = data.length\n switch (result.type) {\n case GL_UNSIGNED_BYTE$4:\n case GL_UNSIGNED_SHORT$2:\n case GL_UNSIGNED_INT$2:\n case GL_FLOAT$3:\n var converted = pool.allocType(result.type, n)\n converted.set(data)\n result.data = converted\n break\n\n case GL_HALF_FLOAT_OES:\n result.data = convertToHalfFloat(data)\n break\n\n default:\n \n }\n}\n\nfunction preConvert (image, n) {\n return pool.allocType(\n image.type === GL_HALF_FLOAT_OES\n ? GL_FLOAT$3\n : image.type, n)\n}\n\nfunction postConvert (image, data) {\n if (image.type === GL_HALF_FLOAT_OES) {\n image.data = convertToHalfFloat(data)\n pool.freeType(data)\n } else {\n image.data = data\n }\n}\n\nfunction transposeData (image, array, strideX, strideY, strideC, offset) {\n var w = image.width\n var h = image.height\n var c = image.channels\n var n = w * h * c\n var data = preConvert(image, n)\n\n var p = 0\n for (var i = 0; i < h; ++i) {\n for (var j = 0; j < w; ++j) {\n for (var k = 0; k < c; ++k) {\n data[p++] = array[strideX * j + strideY * i + strideC * k + offset]\n }\n }\n }\n\n postConvert(image, data)\n}\n\nfunction getTextureSize (format, type, width, height, isMipmap, isCube) {\n var s\n if (typeof FORMAT_SIZES_SPECIAL[format] !== 'undefined') {\n // we have a special array for dealing with weird color formats such as RGB5A1\n s = FORMAT_SIZES_SPECIAL[format]\n } else {\n s = FORMAT_CHANNELS[format] * TYPE_SIZES[type]\n }\n\n if (isCube) {\n s *= 6\n }\n\n if (isMipmap) {\n // compute the total size of all the mipmaps.\n var total = 0\n\n var w = width\n while (w >= 1) {\n // we can only use mipmaps on a square image,\n // so we can simply use the width and ignore the height:\n total += s * w * w\n w /= 2\n }\n return total\n } else {\n return s * width * height\n }\n}\n\nfunction createTextureSet (\n gl, extensions, limits, reglPoll, contextState, stats, config) {\n // -------------------------------------------------------\n // Initialize constants and parameter tables here\n // -------------------------------------------------------\n var mipmapHint = {\n \"don't care\": GL_DONT_CARE,\n 'dont care': GL_DONT_CARE,\n 'nice': GL_NICEST,\n 'fast': GL_FASTEST\n }\n\n var wrapModes = {\n 'repeat': GL_REPEAT,\n 'clamp': GL_CLAMP_TO_EDGE,\n 'mirror': GL_MIRRORED_REPEAT\n }\n\n var magFilters = {\n 'nearest': GL_NEAREST,\n 'linear': GL_LINEAR\n }\n\n var minFilters = extend({\n 'mipmap': GL_LINEAR_MIPMAP_LINEAR,\n 'nearest mipmap nearest': GL_NEAREST_MIPMAP_NEAREST,\n 'linear mipmap nearest': GL_LINEAR_MIPMAP_NEAREST,\n 'nearest mipmap linear': GL_NEAREST_MIPMAP_LINEAR,\n 'linear mipmap linear': GL_LINEAR_MIPMAP_LINEAR\n }, magFilters)\n\n var colorSpace = {\n 'none': 0,\n 'browser': GL_BROWSER_DEFAULT_WEBGL\n }\n\n var textureTypes = {\n 'uint8': GL_UNSIGNED_BYTE$4,\n 'rgba4': GL_UNSIGNED_SHORT_4_4_4_4,\n 'rgb565': GL_UNSIGNED_SHORT_5_6_5,\n 'rgb5 a1': GL_UNSIGNED_SHORT_5_5_5_1\n }\n\n var textureFormats = {\n 'alpha': GL_ALPHA,\n 'luminance': GL_LUMINANCE,\n 'luminance alpha': GL_LUMINANCE_ALPHA,\n 'rgb': GL_RGB,\n 'rgba': GL_RGBA$1,\n 'rgba4': GL_RGBA4,\n 'rgb5 a1': GL_RGB5_A1,\n 'rgb565': GL_RGB565\n }\n\n var compressedTextureFormats = {}\n\n if (extensions.ext_srgb) {\n textureFormats.srgb = GL_SRGB_EXT\n textureFormats.srgba = GL_SRGB_ALPHA_EXT\n }\n\n if (extensions.oes_texture_float) {\n textureTypes.float32 = textureTypes.float = GL_FLOAT$3\n }\n\n if (extensions.oes_texture_half_float) {\n textureTypes['float16'] = textureTypes['half float'] = GL_HALF_FLOAT_OES\n }\n\n if (extensions.webgl_depth_texture) {\n extend(textureFormats, {\n 'depth': GL_DEPTH_COMPONENT,\n 'depth stencil': GL_DEPTH_STENCIL\n })\n\n extend(textureTypes, {\n 'uint16': GL_UNSIGNED_SHORT$2,\n 'uint32': GL_UNSIGNED_INT$2,\n 'depth stencil': GL_UNSIGNED_INT_24_8_WEBGL\n })\n }\n\n if (extensions.webgl_compressed_texture_s3tc) {\n extend(compressedTextureFormats, {\n 'rgb s3tc dxt1': GL_COMPRESSED_RGB_S3TC_DXT1_EXT,\n 'rgba s3tc dxt1': GL_COMPRESSED_RGBA_S3TC_DXT1_EXT,\n 'rgba s3tc dxt3': GL_COMPRESSED_RGBA_S3TC_DXT3_EXT,\n 'rgba s3tc dxt5': GL_COMPRESSED_RGBA_S3TC_DXT5_EXT\n })\n }\n\n if (extensions.webgl_compressed_texture_atc) {\n extend(compressedTextureFormats, {\n 'rgb atc': GL_COMPRESSED_RGB_ATC_WEBGL,\n 'rgba atc explicit alpha': GL_COMPRESSED_RGBA_ATC_EXPLICIT_ALPHA_WEBGL,\n 'rgba atc interpolated alpha': GL_COMPRESSED_RGBA_ATC_INTERPOLATED_ALPHA_WEBGL\n })\n }\n\n if (extensions.webgl_compressed_texture_pvrtc) {\n extend(compressedTextureFormats, {\n 'rgb pvrtc 4bppv1': GL_COMPRESSED_RGB_PVRTC_4BPPV1_IMG,\n 'rgb pvrtc 2bppv1': GL_COMPRESSED_RGB_PVRTC_2BPPV1_IMG,\n 'rgba pvrtc 4bppv1': GL_COMPRESSED_RGBA_PVRTC_4BPPV1_IMG,\n 'rgba pvrtc 2bppv1': GL_COMPRESSED_RGBA_PVRTC_2BPPV1_IMG\n })\n }\n\n if (extensions.webgl_compressed_texture_etc1) {\n compressedTextureFormats['rgb etc1'] = GL_COMPRESSED_RGB_ETC1_WEBGL\n }\n\n // Copy over all texture formats\n var supportedCompressedFormats = Array.prototype.slice.call(\n gl.getParameter(GL_COMPRESSED_TEXTURE_FORMATS))\n Object.keys(compressedTextureFormats).forEach(function (name) {\n var format = compressedTextureFormats[name]\n if (supportedCompressedFormats.indexOf(format) >= 0) {\n textureFormats[name] = format\n }\n })\n\n var supportedFormats = Object.keys(textureFormats)\n limits.textureFormats = supportedFormats\n\n // associate with every format string its\n // corresponding GL-value.\n var textureFormatsInvert = []\n Object.keys(textureFormats).forEach(function (key) {\n var val = textureFormats[key]\n textureFormatsInvert[val] = key\n })\n\n // associate with every type string its\n // corresponding GL-value.\n var textureTypesInvert = []\n Object.keys(textureTypes).forEach(function (key) {\n var val = textureTypes[key]\n textureTypesInvert[val] = key\n })\n\n var magFiltersInvert = []\n Object.keys(magFilters).forEach(function (key) {\n var val = magFilters[key]\n magFiltersInvert[val] = key\n })\n\n var minFiltersInvert = []\n Object.keys(minFilters).forEach(function (key) {\n var val = minFilters[key]\n minFiltersInvert[val] = key\n })\n\n var wrapModesInvert = []\n Object.keys(wrapModes).forEach(function (key) {\n var val = wrapModes[key]\n wrapModesInvert[val] = key\n })\n\n // colorFormats[] gives the format (channels) associated to an\n // internalformat\n var colorFormats = supportedFormats.reduce(function (color, key) {\n var glenum = textureFormats[key]\n if (glenum === GL_LUMINANCE ||\n glenum === GL_ALPHA ||\n glenum === GL_LUMINANCE ||\n glenum === GL_LUMINANCE_ALPHA ||\n glenum === GL_DEPTH_COMPONENT ||\n glenum === GL_DEPTH_STENCIL ||\n (extensions.ext_srgb &&\n (glenum === GL_SRGB_EXT ||\n glenum === GL_SRGB_ALPHA_EXT))) {\n color[glenum] = glenum\n } else if (glenum === GL_RGB5_A1 || key.indexOf('rgba') >= 0) {\n color[glenum] = GL_RGBA$1\n } else {\n color[glenum] = GL_RGB\n }\n return color\n }, {})\n\n function TexFlags () {\n // format info\n this.internalformat = GL_RGBA$1\n this.format = GL_RGBA$1\n this.type = GL_UNSIGNED_BYTE$4\n this.compressed = false\n\n // pixel storage\n this.premultiplyAlpha = false\n this.flipY = false\n this.unpackAlignment = 1\n this.colorSpace = GL_BROWSER_DEFAULT_WEBGL\n\n // shape info\n this.width = 0\n this.height = 0\n this.channels = 0\n }\n\n function copyFlags (result, other) {\n result.internalformat = other.internalformat\n result.format = other.format\n result.type = other.type\n result.compressed = other.compressed\n\n result.premultiplyAlpha = other.premultiplyAlpha\n result.flipY = other.flipY\n result.unpackAlignment = other.unpackAlignment\n result.colorSpace = other.colorSpace\n\n result.width = other.width\n result.height = other.height\n result.channels = other.channels\n }\n\n function parseFlags (flags, options) {\n if (typeof options !== 'object' || !options) {\n return\n }\n\n if ('premultiplyAlpha' in options) {\n \n flags.premultiplyAlpha = options.premultiplyAlpha\n }\n\n if ('flipY' in options) {\n \n flags.flipY = options.flipY\n }\n\n if ('alignment' in options) {\n \n flags.unpackAlignment = options.alignment\n }\n\n if ('colorSpace' in options) {\n \n flags.colorSpace = colorSpace[options.colorSpace]\n }\n\n if ('type' in options) {\n var type = options.type\n \n \n \n \n flags.type = textureTypes[type]\n }\n\n var w = flags.width\n var h = flags.height\n var c = flags.channels\n var hasChannels = false\n if ('shape' in options) {\n \n w = options.shape[0]\n h = options.shape[1]\n if (options.shape.length === 3) {\n c = options.shape[2]\n \n hasChannels = true\n }\n \n \n } else {\n if ('radius' in options) {\n w = h = options.radius\n \n }\n if ('width' in options) {\n w = options.width\n \n }\n if ('height' in options) {\n h = options.height\n \n }\n if ('channels' in options) {\n c = options.channels\n \n hasChannels = true\n }\n }\n flags.width = w | 0\n flags.height = h | 0\n flags.channels = c | 0\n\n var hasFormat = false\n if ('format' in options) {\n var formatStr = options.format\n \n \n var internalformat = flags.internalformat = textureFormats[formatStr]\n flags.format = colorFormats[internalformat]\n if (formatStr in textureTypes) {\n if (!('type' in options)) {\n flags.type = textureTypes[formatStr]\n }\n }\n if (formatStr in compressedTextureFormats) {\n flags.compressed = true\n }\n hasFormat = true\n }\n\n // Reconcile channels and format\n if (!hasChannels && hasFormat) {\n flags.channels = FORMAT_CHANNELS[flags.format]\n } else if (hasChannels && !hasFormat) {\n if (flags.channels !== CHANNELS_FORMAT[flags.format]) {\n flags.format = flags.internalformat = CHANNELS_FORMAT[flags.channels]\n }\n } else if (hasFormat && hasChannels) {\n \n }\n }\n\n function setFlags (flags) {\n gl.pixelStorei(GL_UNPACK_FLIP_Y_WEBGL, flags.flipY)\n gl.pixelStorei(GL_UNPACK_PREMULTIPLY_ALPHA_WEBGL, flags.premultiplyAlpha)\n gl.pixelStorei(GL_UNPACK_COLORSPACE_CONVERSION_WEBGL, flags.colorSpace)\n gl.pixelStorei(GL_UNPACK_ALIGNMENT, flags.unpackAlignment)\n }\n\n // -------------------------------------------------------\n // Tex image data\n // -------------------------------------------------------\n function TexImage () {\n TexFlags.call(this)\n\n this.xOffset = 0\n this.yOffset = 0\n\n // data\n this.data = null\n this.needsFree = false\n\n // html element\n this.element = null\n\n // copyTexImage info\n this.needsCopy = false\n }\n\n function parseImage (image, options) {\n var data = null\n if (isPixelData(options)) {\n data = options\n } else if (options) {\n \n parseFlags(image, options)\n if ('x' in options) {\n image.xOffset = options.x | 0\n }\n if ('y' in options) {\n image.yOffset = options.y | 0\n }\n if (isPixelData(options.data)) {\n data = options.data\n }\n }\n\n \n\n if (options.copy) {\n \n var viewW = contextState.viewportWidth\n var viewH = contextState.viewportHeight\n image.width = image.width || (viewW - image.xOffset)\n image.height = image.height || (viewH - image.yOffset)\n image.needsCopy = true\n \n } else if (!data) {\n image.width = image.width || 1\n image.height = image.height || 1\n image.channels = image.channels || 4\n } else if (isTypedArray(data)) {\n image.channels = image.channels || 4\n image.data = data\n if (!('type' in options) && image.type === GL_UNSIGNED_BYTE$4) {\n image.type = typedArrayCode$1(data)\n }\n } else if (isNumericArray(data)) {\n image.channels = image.channels || 4\n convertData(image, data)\n image.alignment = 1\n image.needsFree = true\n } else if (isNDArrayLike(data)) {\n var array = data.data\n if (!Array.isArray(array) && image.type === GL_UNSIGNED_BYTE$4) {\n image.type = typedArrayCode$1(array)\n }\n var shape = data.shape\n var stride = data.stride\n var shapeX, shapeY, shapeC, strideX, strideY, strideC\n if (shape.length === 3) {\n shapeC = shape[2]\n strideC = stride[2]\n } else {\n \n shapeC = 1\n strideC = 1\n }\n shapeX = shape[0]\n shapeY = shape[1]\n strideX = stride[0]\n strideY = stride[1]\n image.alignment = 1\n image.width = shapeX\n image.height = shapeY\n image.channels = shapeC\n image.format = image.internalformat = CHANNELS_FORMAT[shapeC]\n image.needsFree = true\n transposeData(image, array, strideX, strideY, strideC, data.offset)\n } else if (isCanvasElement(data) || isOffscreenCanvas(data) || isContext2D(data)) {\n if (isCanvasElement(data) || isOffscreenCanvas(data)) {\n image.element = data\n } else {\n image.element = data.canvas\n }\n image.width = image.element.width\n image.height = image.element.height\n image.channels = 4\n } else if (isBitmap(data)) {\n image.element = data\n image.width = data.width\n image.height = data.height\n image.channels = 4\n } else if (isImageElement(data)) {\n image.element = data\n image.width = data.naturalWidth\n image.height = data.naturalHeight\n image.channels = 4\n } else if (isVideoElement(data)) {\n image.element = data\n image.width = data.videoWidth\n image.height = data.videoHeight\n image.channels = 4\n } else if (isRectArray(data)) {\n var w = image.width || data[0].length\n var h = image.height || data.length\n var c = image.channels\n if (isArrayLike(data[0][0])) {\n c = c || data[0][0].length\n } else {\n c = c || 1\n }\n var arrayShape = flattenUtils.shape(data)\n var n = 1\n for (var dd = 0; dd < arrayShape.length; ++dd) {\n n *= arrayShape[dd]\n }\n var allocData = preConvert(image, n)\n flattenUtils.flatten(data, arrayShape, '', allocData)\n postConvert(image, allocData)\n image.alignment = 1\n image.width = w\n image.height = h\n image.channels = c\n image.format = image.internalformat = CHANNELS_FORMAT[c]\n image.needsFree = true\n }\n\n if (image.type === GL_FLOAT$3) {\n \n } else if (image.type === GL_HALF_FLOAT_OES) {\n \n }\n\n // do compressed texture validation here.\n }\n\n function setImage (info, target, miplevel) {\n var element = info.element\n var data = info.data\n var internalformat = info.internalformat\n var format = info.format\n var type = info.type\n var width = info.width\n var height = info.height\n\n setFlags(info)\n\n if (element) {\n gl.texImage2D(target, miplevel, format, format, type, element)\n } else if (info.compressed) {\n gl.compressedTexImage2D(target, miplevel, internalformat, width, height, 0, data)\n } else if (info.needsCopy) {\n reglPoll()\n gl.copyTexImage2D(\n target, miplevel, format, info.xOffset, info.yOffset, width, height, 0)\n } else {\n gl.texImage2D(target, miplevel, format, width, height, 0, format, type, data || null)\n }\n }\n\n function setSubImage (info, target, x, y, miplevel) {\n var element = info.element\n var data = info.data\n var internalformat = info.internalformat\n var format = info.format\n var type = info.type\n var width = info.width\n var height = info.height\n\n setFlags(info)\n\n if (element) {\n gl.texSubImage2D(\n target, miplevel, x, y, format, type, element)\n } else if (info.compressed) {\n gl.compressedTexSubImage2D(\n target, miplevel, x, y, internalformat, width, height, data)\n } else if (info.needsCopy) {\n reglPoll()\n gl.copyTexSubImage2D(\n target, miplevel, x, y, info.xOffset, info.yOffset, width, height)\n } else {\n gl.texSubImage2D(\n target, miplevel, x, y, width, height, format, type, data)\n }\n }\n\n // texImage pool\n var imagePool = []\n\n function allocImage () {\n return imagePool.pop() || new TexImage()\n }\n\n function freeImage (image) {\n if (image.needsFree) {\n pool.freeType(image.data)\n }\n TexImage.call(image)\n imagePool.push(image)\n }\n\n // -------------------------------------------------------\n // Mip map\n // -------------------------------------------------------\n function MipMap () {\n TexFlags.call(this)\n\n this.genMipmaps = false\n this.mipmapHint = GL_DONT_CARE\n this.mipmask = 0\n this.images = Array(16)\n }\n\n function parseMipMapFromShape (mipmap, width, height) {\n var img = mipmap.images[0] = allocImage()\n mipmap.mipmask = 1\n img.width = mipmap.width = width\n img.height = mipmap.height = height\n img.channels = mipmap.channels = 4\n }\n\n function parseMipMapFromObject (mipmap, options) {\n var imgData = null\n if (isPixelData(options)) {\n imgData = mipmap.images[0] = allocImage()\n copyFlags(imgData, mipmap)\n parseImage(imgData, options)\n mipmap.mipmask = 1\n } else {\n parseFlags(mipmap, options)\n if (Array.isArray(options.mipmap)) {\n var mipData = options.mipmap\n for (var i = 0; i < mipData.length; ++i) {\n imgData = mipmap.images[i] = allocImage()\n copyFlags(imgData, mipmap)\n imgData.width >>= i\n imgData.height >>= i\n parseImage(imgData, mipData[i])\n mipmap.mipmask |= (1 << i)\n }\n } else {\n imgData = mipmap.images[0] = allocImage()\n copyFlags(imgData, mipmap)\n parseImage(imgData, options)\n mipmap.mipmask = 1\n }\n }\n copyFlags(mipmap, mipmap.images[0])\n\n // For textures of the compressed format WEBGL_compressed_texture_s3tc\n // we must have that\n //\n // \"When level equals zero width and height must be a multiple of 4.\n // When level is greater than 0 width and height must be 0, 1, 2 or a multiple of 4. \"\n //\n // but we do not yet support having multiple mipmap levels for compressed textures,\n // so we only test for level zero.\n\n if (\n mipmap.compressed &&\n (\n mipmap.internalformat === GL_COMPRESSED_RGB_S3TC_DXT1_EXT ||\n mipmap.internalformat === GL_COMPRESSED_RGBA_S3TC_DXT1_EXT ||\n mipmap.internalformat === GL_COMPRESSED_RGBA_S3TC_DXT3_EXT ||\n mipmap.internalformat === GL_COMPRESSED_RGBA_S3TC_DXT5_EXT\n )\n ) {\n \n }\n }\n\n function setMipMap (mipmap, target) {\n var images = mipmap.images\n for (var i = 0; i < images.length; ++i) {\n if (!images[i]) {\n return\n }\n setImage(images[i], target, i)\n }\n }\n\n var mipPool = []\n\n function allocMipMap () {\n var result = mipPool.pop() || new MipMap()\n TexFlags.call(result)\n result.mipmask = 0\n for (var i = 0; i < 16; ++i) {\n result.images[i] = null\n }\n return result\n }\n\n function freeMipMap (mipmap) {\n var images = mipmap.images\n for (var i = 0; i < images.length; ++i) {\n if (images[i]) {\n freeImage(images[i])\n }\n images[i] = null\n }\n mipPool.push(mipmap)\n }\n\n // -------------------------------------------------------\n // Tex info\n // -------------------------------------------------------\n function TexInfo () {\n this.minFilter = GL_NEAREST\n this.magFilter = GL_NEAREST\n\n this.wrapS = GL_CLAMP_TO_EDGE\n this.wrapT = GL_CLAMP_TO_EDGE\n\n this.anisotropic = 1\n\n this.genMipmaps = false\n this.mipmapHint = GL_DONT_CARE\n }\n\n function parseTexInfo (info, options) {\n if ('min' in options) {\n var minFilter = options.min\n \n info.minFilter = minFilters[minFilter]\n if (MIPMAP_FILTERS.indexOf(info.minFilter) >= 0 && !('faces' in options)) {\n info.genMipmaps = true\n }\n }\n\n if ('mag' in options) {\n var magFilter = options.mag\n \n info.magFilter = magFilters[magFilter]\n }\n\n var wrapS = info.wrapS\n var wrapT = info.wrapT\n if ('wrap' in options) {\n var wrap = options.wrap\n if (typeof wrap === 'string') {\n \n wrapS = wrapT = wrapModes[wrap]\n } else if (Array.isArray(wrap)) {\n \n \n wrapS = wrapModes[wrap[0]]\n wrapT = wrapModes[wrap[1]]\n }\n } else {\n if ('wrapS' in options) {\n var optWrapS = options.wrapS\n \n wrapS = wrapModes[optWrapS]\n }\n if ('wrapT' in options) {\n var optWrapT = options.wrapT\n \n wrapT = wrapModes[optWrapT]\n }\n }\n info.wrapS = wrapS\n info.wrapT = wrapT\n\n if ('anisotropic' in options) {\n var anisotropic = options.anisotropic\n \n info.anisotropic = options.anisotropic\n }\n\n if ('mipmap' in options) {\n var hasMipMap = false\n switch (typeof options.mipmap) {\n case 'string':\n \n info.mipmapHint = mipmapHint[options.mipmap]\n info.genMipmaps = true\n hasMipMap = true\n break\n\n case 'boolean':\n hasMipMap = info.genMipmaps = options.mipmap\n break\n\n case 'object':\n \n info.genMipmaps = false\n hasMipMap = true\n break\n\n default:\n \n }\n if (hasMipMap && !('min' in options)) {\n info.minFilter = GL_NEAREST_MIPMAP_NEAREST\n }\n }\n }\n\n function setTexInfo (info, target) {\n gl.texParameteri(target, GL_TEXTURE_MIN_FILTER, info.minFilter)\n gl.texParameteri(target, GL_TEXTURE_MAG_FILTER, info.magFilter)\n gl.texParameteri(target, GL_TEXTURE_WRAP_S, info.wrapS)\n gl.texParameteri(target, GL_TEXTURE_WRAP_T, info.wrapT)\n if (extensions.ext_texture_filter_anisotropic) {\n gl.texParameteri(target, GL_TEXTURE_MAX_ANISOTROPY_EXT, info.anisotropic)\n }\n if (info.genMipmaps) {\n gl.hint(GL_GENERATE_MIPMAP_HINT, info.mipmapHint)\n gl.generateMipmap(target)\n }\n }\n\n // -------------------------------------------------------\n // Full texture object\n // -------------------------------------------------------\n var textureCount = 0\n var textureSet = {}\n var numTexUnits = limits.maxTextureUnits\n var textureUnits = Array(numTexUnits).map(function () {\n return null\n })\n\n function REGLTexture (target) {\n TexFlags.call(this)\n this.mipmask = 0\n this.internalformat = GL_RGBA$1\n\n this.id = textureCount++\n\n this.refCount = 1\n\n this.target = target\n this.texture = gl.createTexture()\n\n this.unit = -1\n this.bindCount = 0\n\n this.texInfo = new TexInfo()\n\n if (config.profile) {\n this.stats = { size: 0 }\n }\n }\n\n function tempBind (texture) {\n gl.activeTexture(GL_TEXTURE0$1)\n gl.bindTexture(texture.target, texture.texture)\n }\n\n function tempRestore () {\n var prev = textureUnits[0]\n if (prev) {\n gl.bindTexture(prev.target, prev.texture)\n } else {\n gl.bindTexture(GL_TEXTURE_2D$1, null)\n }\n }\n\n function destroy (texture) {\n var handle = texture.texture\n \n var unit = texture.unit\n var target = texture.target\n if (unit >= 0) {\n gl.activeTexture(GL_TEXTURE0$1 + unit)\n gl.bindTexture(target, null)\n textureUnits[unit] = null\n }\n gl.deleteTexture(handle)\n texture.texture = null\n texture.params = null\n texture.pixels = null\n texture.refCount = 0\n delete textureSet[texture.id]\n stats.textureCount--\n }\n\n extend(REGLTexture.prototype, {\n bind: function () {\n var texture = this\n texture.bindCount += 1\n var unit = texture.unit\n if (unit < 0) {\n for (var i = 0; i < numTexUnits; ++i) {\n var other = textureUnits[i]\n if (other) {\n if (other.bindCount > 0) {\n continue\n }\n other.unit = -1\n }\n textureUnits[i] = texture\n unit = i\n break\n }\n if (unit >= numTexUnits) {\n \n }\n if (config.profile && stats.maxTextureUnits < (unit + 1)) {\n stats.maxTextureUnits = unit + 1 // +1, since the units are zero-based\n }\n texture.unit = unit\n gl.activeTexture(GL_TEXTURE0$1 + unit)\n gl.bindTexture(texture.target, texture.texture)\n }\n return unit\n },\n\n unbind: function () {\n this.bindCount -= 1\n },\n\n decRef: function () {\n if (--this.refCount <= 0) {\n destroy(this)\n }\n }\n })\n\n function createTexture2D (a, b) {\n var texture = new REGLTexture(GL_TEXTURE_2D$1)\n textureSet[texture.id] = texture\n stats.textureCount++\n\n function reglTexture2D (a, b) {\n var texInfo = texture.texInfo\n TexInfo.call(texInfo)\n var mipData = allocMipMap()\n\n if (typeof a === 'number') {\n if (typeof b === 'number') {\n parseMipMapFromShape(mipData, a | 0, b | 0)\n } else {\n parseMipMapFromShape(mipData, a | 0, a | 0)\n }\n } else if (a) {\n \n parseTexInfo(texInfo, a)\n parseMipMapFromObject(mipData, a)\n } else {\n // empty textures get assigned a default shape of 1x1\n parseMipMapFromShape(mipData, 1, 1)\n }\n\n if (texInfo.genMipmaps) {\n mipData.mipmask = (mipData.width << 1) - 1\n }\n texture.mipmask = mipData.mipmask\n\n copyFlags(texture, mipData)\n\n \n texture.internalformat = mipData.internalformat\n\n reglTexture2D.width = mipData.width\n reglTexture2D.height = mipData.height\n\n tempBind(texture)\n setMipMap(mipData, GL_TEXTURE_2D$1)\n setTexInfo(texInfo, GL_TEXTURE_2D$1)\n tempRestore()\n\n freeMipMap(mipData)\n\n if (config.profile) {\n texture.stats.size = getTextureSize(\n texture.internalformat,\n texture.type,\n mipData.width,\n mipData.height,\n texInfo.genMipmaps,\n false)\n }\n reglTexture2D.format = textureFormatsInvert[texture.internalformat]\n reglTexture2D.type = textureTypesInvert[texture.type]\n\n reglTexture2D.mag = magFiltersInvert[texInfo.magFilter]\n reglTexture2D.min = minFiltersInvert[texInfo.minFilter]\n\n reglTexture2D.wrapS = wrapModesInvert[texInfo.wrapS]\n reglTexture2D.wrapT = wrapModesInvert[texInfo.wrapT]\n\n return reglTexture2D\n }\n\n function subimage (image, x_, y_, level_) {\n \n\n var x = x_ | 0\n var y = y_ | 0\n var level = level_ | 0\n\n var imageData = allocImage()\n copyFlags(imageData, texture)\n imageData.width = 0\n imageData.height = 0\n parseImage(imageData, image)\n imageData.width = imageData.width || ((texture.width >> level) - x)\n imageData.height = imageData.height || ((texture.height >> level) - y)\n\n \n \n \n \n\n tempBind(texture)\n setSubImage(imageData, GL_TEXTURE_2D$1, x, y, level)\n tempRestore()\n\n freeImage(imageData)\n\n return reglTexture2D\n }\n\n function resize (w_, h_) {\n var w = w_ | 0\n var h = (h_ | 0) || w\n if (w === texture.width && h === texture.height) {\n return reglTexture2D\n }\n\n reglTexture2D.width = texture.width = w\n reglTexture2D.height = texture.height = h\n\n tempBind(texture)\n\n for (var i = 0; texture.mipmask >> i; ++i) {\n var _w = w >> i\n var _h = h >> i\n if (!_w || !_h) break\n gl.texImage2D(\n GL_TEXTURE_2D$1,\n i,\n texture.format,\n _w,\n _h,\n 0,\n texture.format,\n texture.type,\n null)\n }\n tempRestore()\n\n // also, recompute the texture size.\n if (config.profile) {\n texture.stats.size = getTextureSize(\n texture.internalformat,\n texture.type,\n w,\n h,\n false,\n false)\n }\n\n return reglTexture2D\n }\n\n reglTexture2D(a, b)\n\n reglTexture2D.subimage = subimage\n reglTexture2D.resize = resize\n reglTexture2D._reglType = 'texture2d'\n reglTexture2D._texture = texture\n if (config.profile) {\n reglTexture2D.stats = texture.stats\n }\n reglTexture2D.destroy = function () {\n texture.decRef()\n }\n\n return reglTexture2D\n }\n\n function createTextureCube (a0, a1, a2, a3, a4, a5) {\n var texture = new REGLTexture(GL_TEXTURE_CUBE_MAP$1)\n textureSet[texture.id] = texture\n stats.cubeCount++\n\n var faces = new Array(6)\n\n function reglTextureCube (a0, a1, a2, a3, a4, a5) {\n var i\n var texInfo = texture.texInfo\n TexInfo.call(texInfo)\n for (i = 0; i < 6; ++i) {\n faces[i] = allocMipMap()\n }\n\n if (typeof a0 === 'number' || !a0) {\n var s = (a0 | 0) || 1\n for (i = 0; i < 6; ++i) {\n parseMipMapFromShape(faces[i], s, s)\n }\n } else if (typeof a0 === 'object') {\n if (a1) {\n parseMipMapFromObject(faces[0], a0)\n parseMipMapFromObject(faces[1], a1)\n parseMipMapFromObject(faces[2], a2)\n parseMipMapFromObject(faces[3], a3)\n parseMipMapFromObject(faces[4], a4)\n parseMipMapFromObject(faces[5], a5)\n } else {\n parseTexInfo(texInfo, a0)\n parseFlags(texture, a0)\n if ('faces' in a0) {\n var faceInput = a0.faces\n \n for (i = 0; i < 6; ++i) {\n \n copyFlags(faces[i], texture)\n parseMipMapFromObject(faces[i], faceInput[i])\n }\n } else {\n for (i = 0; i < 6; ++i) {\n parseMipMapFromObject(faces[i], a0)\n }\n }\n }\n } else {\n \n }\n\n copyFlags(texture, faces[0])\n \n\n if (texInfo.genMipmaps) {\n texture.mipmask = (faces[0].width << 1) - 1\n } else {\n texture.mipmask = faces[0].mipmask\n }\n\n \n texture.internalformat = faces[0].internalformat\n\n reglTextureCube.width = faces[0].width\n reglTextureCube.height = faces[0].height\n\n tempBind(texture)\n for (i = 0; i < 6; ++i) {\n setMipMap(faces[i], GL_TEXTURE_CUBE_MAP_POSITIVE_X$1 + i)\n }\n setTexInfo(texInfo, GL_TEXTURE_CUBE_MAP$1)\n tempRestore()\n\n if (config.profile) {\n texture.stats.size = getTextureSize(\n texture.internalformat,\n texture.type,\n reglTextureCube.width,\n reglTextureCube.height,\n texInfo.genMipmaps,\n true)\n }\n\n reglTextureCube.format = textureFormatsInvert[texture.internalformat]\n reglTextureCube.type = textureTypesInvert[texture.type]\n\n reglTextureCube.mag = magFiltersInvert[texInfo.magFilter]\n reglTextureCube.min = minFiltersInvert[texInfo.minFilter]\n\n reglTextureCube.wrapS = wrapModesInvert[texInfo.wrapS]\n reglTextureCube.wrapT = wrapModesInvert[texInfo.wrapT]\n\n for (i = 0; i < 6; ++i) {\n freeMipMap(faces[i])\n }\n\n return reglTextureCube\n }\n\n function subimage (face, image, x_, y_, level_) {\n \n \n\n var x = x_ | 0\n var y = y_ | 0\n var level = level_ | 0\n\n var imageData = allocImage()\n copyFlags(imageData, texture)\n imageData.width = 0\n imageData.height = 0\n parseImage(imageData, image)\n imageData.width = imageData.width || ((texture.width >> level) - x)\n imageData.height = imageData.height || ((texture.height >> level) - y)\n\n \n \n \n \n\n tempBind(texture)\n setSubImage(imageData, GL_TEXTURE_CUBE_MAP_POSITIVE_X$1 + face, x, y, level)\n tempRestore()\n\n freeImage(imageData)\n\n return reglTextureCube\n }\n\n function resize (radius_) {\n var radius = radius_ | 0\n if (radius === texture.width) {\n return\n }\n\n reglTextureCube.width = texture.width = radius\n reglTextureCube.height = texture.height = radius\n\n tempBind(texture)\n for (var i = 0; i < 6; ++i) {\n for (var j = 0; texture.mipmask >> j; ++j) {\n gl.texImage2D(\n GL_TEXTURE_CUBE_MAP_POSITIVE_X$1 + i,\n j,\n texture.format,\n radius >> j,\n radius >> j,\n 0,\n texture.format,\n texture.type,\n null)\n }\n }\n tempRestore()\n\n if (config.profile) {\n texture.stats.size = getTextureSize(\n texture.internalformat,\n texture.type,\n reglTextureCube.width,\n reglTextureCube.height,\n false,\n true)\n }\n\n return reglTextureCube\n }\n\n reglTextureCube(a0, a1, a2, a3, a4, a5)\n\n reglTextureCube.subimage = subimage\n reglTextureCube.resize = resize\n reglTextureCube._reglType = 'textureCube'\n reglTextureCube._texture = texture\n if (config.profile) {\n reglTextureCube.stats = texture.stats\n }\n reglTextureCube.destroy = function () {\n texture.decRef()\n }\n\n return reglTextureCube\n }\n\n // Called when regl is destroyed\n function destroyTextures () {\n for (var i = 0; i < numTexUnits; ++i) {\n gl.activeTexture(GL_TEXTURE0$1 + i)\n gl.bindTexture(GL_TEXTURE_2D$1, null)\n textureUnits[i] = null\n }\n values(textureSet).forEach(destroy)\n\n stats.cubeCount = 0\n stats.textureCount = 0\n }\n\n if (config.profile) {\n stats.getTotalTextureSize = function () {\n var total = 0\n Object.keys(textureSet).forEach(function (key) {\n total += textureSet[key].stats.size\n })\n return total\n }\n }\n\n function restoreTextures () {\n for (var i = 0; i < numTexUnits; ++i) {\n var tex = textureUnits[i]\n if (tex) {\n tex.bindCount = 0\n tex.unit = -1\n textureUnits[i] = null\n }\n }\n\n values(textureSet).forEach(function (texture) {\n texture.texture = gl.createTexture()\n gl.bindTexture(texture.target, texture.texture)\n for (var i = 0; i < 32; ++i) {\n if ((texture.mipmask & (1 << i)) === 0) {\n continue\n }\n if (texture.target === GL_TEXTURE_2D$1) {\n gl.texImage2D(GL_TEXTURE_2D$1,\n i,\n texture.internalformat,\n texture.width >> i,\n texture.height >> i,\n 0,\n texture.internalformat,\n texture.type,\n null)\n } else {\n for (var j = 0; j < 6; ++j) {\n gl.texImage2D(GL_TEXTURE_CUBE_MAP_POSITIVE_X$1 + j,\n i,\n texture.internalformat,\n texture.width >> i,\n texture.height >> i,\n 0,\n texture.internalformat,\n texture.type,\n null)\n }\n }\n }\n setTexInfo(texture.texInfo, texture.target)\n })\n }\n\n function refreshTextures () {\n for (var i = 0; i < numTexUnits; ++i) {\n var tex = textureUnits[i]\n if (tex) {\n tex.bindCount = 0\n tex.unit = -1\n textureUnits[i] = null\n }\n gl.activeTexture(GL_TEXTURE0$1 + i)\n gl.bindTexture(GL_TEXTURE_2D$1, null)\n gl.bindTexture(GL_TEXTURE_CUBE_MAP$1, null)\n }\n }\n\n return {\n create2D: createTexture2D,\n createCube: createTextureCube,\n clear: destroyTextures,\n getTexture: function (wrapper) {\n return null\n },\n restore: restoreTextures,\n refresh: refreshTextures\n }\n}\n\nvar GL_RENDERBUFFER = 0x8D41\n\nvar GL_RGBA4$1 = 0x8056\nvar GL_RGB5_A1$1 = 0x8057\nvar GL_RGB565$1 = 0x8D62\nvar GL_DEPTH_COMPONENT16 = 0x81A5\nvar GL_STENCIL_INDEX8 = 0x8D48\nvar GL_DEPTH_STENCIL$1 = 0x84F9\n\nvar GL_SRGB8_ALPHA8_EXT = 0x8C43\n\nvar GL_RGBA32F_EXT = 0x8814\n\nvar GL_RGBA16F_EXT = 0x881A\nvar GL_RGB16F_EXT = 0x881B\n\nvar FORMAT_SIZES = []\n\nFORMAT_SIZES[GL_RGBA4$1] = 2\nFORMAT_SIZES[GL_RGB5_A1$1] = 2\nFORMAT_SIZES[GL_RGB565$1] = 2\n\nFORMAT_SIZES[GL_DEPTH_COMPONENT16] = 2\nFORMAT_SIZES[GL_STENCIL_INDEX8] = 1\nFORMAT_SIZES[GL_DEPTH_STENCIL$1] = 4\n\nFORMAT_SIZES[GL_SRGB8_ALPHA8_EXT] = 4\nFORMAT_SIZES[GL_RGBA32F_EXT] = 16\nFORMAT_SIZES[GL_RGBA16F_EXT] = 8\nFORMAT_SIZES[GL_RGB16F_EXT] = 6\n\nfunction getRenderbufferSize (format, width, height) {\n return FORMAT_SIZES[format] * width * height\n}\n\nvar wrapRenderbuffers = function (gl, extensions, limits, stats, config) {\n var formatTypes = {\n 'rgba4': GL_RGBA4$1,\n 'rgb565': GL_RGB565$1,\n 'rgb5 a1': GL_RGB5_A1$1,\n 'depth': GL_DEPTH_COMPONENT16,\n 'stencil': GL_STENCIL_INDEX8,\n 'depth stencil': GL_DEPTH_STENCIL$1\n }\n\n if (extensions.ext_srgb) {\n formatTypes['srgba'] = GL_SRGB8_ALPHA8_EXT\n }\n\n if (extensions.ext_color_buffer_half_float) {\n formatTypes['rgba16f'] = GL_RGBA16F_EXT\n formatTypes['rgb16f'] = GL_RGB16F_EXT\n }\n\n if (extensions.webgl_color_buffer_float) {\n formatTypes['rgba32f'] = GL_RGBA32F_EXT\n }\n\n var formatTypesInvert = []\n Object.keys(formatTypes).forEach(function (key) {\n var val = formatTypes[key]\n formatTypesInvert[val] = key\n })\n\n var renderbufferCount = 0\n var renderbufferSet = {}\n\n function REGLRenderbuffer (renderbuffer) {\n this.id = renderbufferCount++\n this.refCount = 1\n\n this.renderbuffer = renderbuffer\n\n this.format = GL_RGBA4$1\n this.width = 0\n this.height = 0\n\n if (config.profile) {\n this.stats = { size: 0 }\n }\n }\n\n REGLRenderbuffer.prototype.decRef = function () {\n if (--this.refCount <= 0) {\n destroy(this)\n }\n }\n\n function destroy (rb) {\n var handle = rb.renderbuffer\n \n gl.bindRenderbuffer(GL_RENDERBUFFER, null)\n gl.deleteRenderbuffer(handle)\n rb.renderbuffer = null\n rb.refCount = 0\n delete renderbufferSet[rb.id]\n stats.renderbufferCount--\n }\n\n function createRenderbuffer (a, b) {\n var renderbuffer = new REGLRenderbuffer(gl.createRenderbuffer())\n renderbufferSet[renderbuffer.id] = renderbuffer\n stats.renderbufferCount++\n\n function reglRenderbuffer (a, b) {\n var w = 0\n var h = 0\n var format = GL_RGBA4$1\n\n if (typeof a === 'object' && a) {\n var options = a\n if ('shape' in options) {\n var shape = options.shape\n \n w = shape[0] | 0\n h = shape[1] | 0\n } else {\n if ('radius' in options) {\n w = h = options.radius | 0\n }\n if ('width' in options) {\n w = options.width | 0\n }\n if ('height' in options) {\n h = options.height | 0\n }\n }\n if ('format' in options) {\n \n format = formatTypes[options.format]\n }\n } else if (typeof a === 'number') {\n w = a | 0\n if (typeof b === 'number') {\n h = b | 0\n } else {\n h = w\n }\n } else if (!a) {\n w = h = 1\n } else {\n \n }\n\n // check shape\n \n\n if (w === renderbuffer.width &&\n h === renderbuffer.height &&\n format === renderbuffer.format) {\n return\n }\n\n reglRenderbuffer.width = renderbuffer.width = w\n reglRenderbuffer.height = renderbuffer.height = h\n renderbuffer.format = format\n\n gl.bindRenderbuffer(GL_RENDERBUFFER, renderbuffer.renderbuffer)\n gl.renderbufferStorage(GL_RENDERBUFFER, format, w, h)\n\n \n\n if (config.profile) {\n renderbuffer.stats.size = getRenderbufferSize(renderbuffer.format, renderbuffer.width, renderbuffer.height)\n }\n reglRenderbuffer.format = formatTypesInvert[renderbuffer.format]\n\n return reglRenderbuffer\n }\n\n function resize (w_, h_) {\n var w = w_ | 0\n var h = (h_ | 0) || w\n\n if (w === renderbuffer.width && h === renderbuffer.height) {\n return reglRenderbuffer\n }\n\n // check shape\n \n\n reglRenderbuffer.width = renderbuffer.width = w\n reglRenderbuffer.height = renderbuffer.height = h\n\n gl.bindRenderbuffer(GL_RENDERBUFFER, renderbuffer.renderbuffer)\n gl.renderbufferStorage(GL_RENDERBUFFER, renderbuffer.format, w, h)\n\n \n\n // also, recompute size.\n if (config.profile) {\n renderbuffer.stats.size = getRenderbufferSize(\n renderbuffer.format, renderbuffer.width, renderbuffer.height)\n }\n\n return reglRenderbuffer\n }\n\n reglRenderbuffer(a, b)\n\n reglRenderbuffer.resize = resize\n reglRenderbuffer._reglType = 'renderbuffer'\n reglRenderbuffer._renderbuffer = renderbuffer\n if (config.profile) {\n reglRenderbuffer.stats = renderbuffer.stats\n }\n reglRenderbuffer.destroy = function () {\n renderbuffer.decRef()\n }\n\n return reglRenderbuffer\n }\n\n if (config.profile) {\n stats.getTotalRenderbufferSize = function () {\n var total = 0\n Object.keys(renderbufferSet).forEach(function (key) {\n total += renderbufferSet[key].stats.size\n })\n return total\n }\n }\n\n function restoreRenderbuffers () {\n values(renderbufferSet).forEach(function (rb) {\n rb.renderbuffer = gl.createRenderbuffer()\n gl.bindRenderbuffer(GL_RENDERBUFFER, rb.renderbuffer)\n gl.renderbufferStorage(GL_RENDERBUFFER, rb.format, rb.width, rb.height)\n })\n gl.bindRenderbuffer(GL_RENDERBUFFER, null)\n }\n\n return {\n create: createRenderbuffer,\n clear: function () {\n values(renderbufferSet).forEach(destroy)\n },\n restore: restoreRenderbuffers\n }\n}\n\n// We store these constants so that the minifier can inline them\nvar GL_FRAMEBUFFER$1 = 0x8D40\nvar GL_RENDERBUFFER$1 = 0x8D41\n\nvar GL_TEXTURE_2D$2 = 0x0DE1\nvar GL_TEXTURE_CUBE_MAP_POSITIVE_X$2 = 0x8515\n\nvar GL_COLOR_ATTACHMENT0$1 = 0x8CE0\nvar GL_DEPTH_ATTACHMENT = 0x8D00\nvar GL_STENCIL_ATTACHMENT = 0x8D20\nvar GL_DEPTH_STENCIL_ATTACHMENT = 0x821A\n\nvar GL_FRAMEBUFFER_COMPLETE$1 = 0x8CD5\nvar GL_HALF_FLOAT_OES$1 = 0x8D61\nvar GL_UNSIGNED_BYTE$5 = 0x1401\nvar GL_FLOAT$4 = 0x1406\n\nvar GL_RGB$1 = 0x1907\nvar GL_RGBA$2 = 0x1908\n\n// for every texture format, store\n// the number of channels\nvar textureFormatChannels = []\ntextureFormatChannels[GL_RGBA$2] = 4\ntextureFormatChannels[GL_RGB$1] = 3\n\n// for every texture type, store\n// the size in bytes.\nvar textureTypeSizes = []\ntextureTypeSizes[GL_UNSIGNED_BYTE$5] = 1\ntextureTypeSizes[GL_FLOAT$4] = 4\ntextureTypeSizes[GL_HALF_FLOAT_OES$1] = 2\n\nfunction wrapFBOState (\n gl,\n extensions,\n limits,\n textureState,\n renderbufferState,\n stats) {\n var framebufferState = {\n cur: null,\n next: null,\n dirty: false,\n setFBO: null\n }\n\n var colorTextureFormats = ['rgba']\n var colorRenderbufferFormats = ['rgba4', 'rgb565', 'rgb5 a1']\n\n if (extensions.ext_srgb) {\n colorRenderbufferFormats.push('srgba')\n }\n\n if (extensions.ext_color_buffer_half_float) {\n colorRenderbufferFormats.push('rgba16f', 'rgb16f')\n }\n\n if (extensions.webgl_color_buffer_float) {\n colorRenderbufferFormats.push('rgba32f')\n }\n\n var colorTypes = ['uint8']\n if (extensions.oes_texture_half_float) {\n colorTypes.push('half float', 'float16')\n }\n if (extensions.oes_texture_float) {\n colorTypes.push('float', 'float32')\n }\n\n function FramebufferAttachment (target, texture, renderbuffer) {\n this.target = target\n this.texture = texture\n this.renderbuffer = renderbuffer\n\n var w = 0\n var h = 0\n if (texture) {\n w = texture.width\n h = texture.height\n } else if (renderbuffer) {\n w = renderbuffer.width\n h = renderbuffer.height\n }\n this.width = w\n this.height = h\n }\n\n function decRef (attachment) {\n if (attachment) {\n if (attachment.texture) {\n attachment.texture._texture.decRef()\n }\n if (attachment.renderbuffer) {\n attachment.renderbuffer._renderbuffer.decRef()\n }\n }\n }\n\n function incRefAndCheckShape (attachment, width, height) {\n if (!attachment) {\n return\n }\n if (attachment.texture) {\n var texture = attachment.texture._texture\n var tw = Math.max(1, texture.width)\n var th = Math.max(1, texture.height)\n \n texture.refCount += 1\n } else {\n var renderbuffer = attachment.renderbuffer._renderbuffer\n \n renderbuffer.refCount += 1\n }\n }\n\n function attach (location, attachment) {\n if (attachment) {\n if (attachment.texture) {\n gl.framebufferTexture2D(\n GL_FRAMEBUFFER$1,\n location,\n attachment.target,\n attachment.texture._texture.texture,\n 0)\n } else {\n gl.framebufferRenderbuffer(\n GL_FRAMEBUFFER$1,\n location,\n GL_RENDERBUFFER$1,\n attachment.renderbuffer._renderbuffer.renderbuffer)\n }\n }\n }\n\n function parseAttachment (attachment) {\n var target = GL_TEXTURE_2D$2\n var texture = null\n var renderbuffer = null\n\n var data = attachment\n if (typeof attachment === 'object') {\n data = attachment.data\n if ('target' in attachment) {\n target = attachment.target | 0\n }\n }\n\n \n\n var type = data._reglType\n if (type === 'texture2d') {\n texture = data\n \n } else if (type === 'textureCube') {\n texture = data\n \n } else if (type === 'renderbuffer') {\n renderbuffer = data\n target = GL_RENDERBUFFER$1\n } else {\n \n }\n\n return new FramebufferAttachment(target, texture, renderbuffer)\n }\n\n function allocAttachment (\n width,\n height,\n isTexture,\n format,\n type) {\n if (isTexture) {\n var texture = textureState.create2D({\n width: width,\n height: height,\n format: format,\n type: type\n })\n texture._texture.refCount = 0\n return new FramebufferAttachment(GL_TEXTURE_2D$2, texture, null)\n } else {\n var rb = renderbufferState.create({\n width: width,\n height: height,\n format: format\n })\n rb._renderbuffer.refCount = 0\n return new FramebufferAttachment(GL_RENDERBUFFER$1, null, rb)\n }\n }\n\n function unwrapAttachment (attachment) {\n return attachment && (attachment.texture || attachment.renderbuffer)\n }\n\n function resizeAttachment (attachment, w, h) {\n if (attachment) {\n if (attachment.texture) {\n attachment.texture.resize(w, h)\n } else if (attachment.renderbuffer) {\n attachment.renderbuffer.resize(w, h)\n }\n attachment.width = w\n attachment.height = h\n }\n }\n\n var framebufferCount = 0\n var framebufferSet = {}\n\n function REGLFramebuffer () {\n this.id = framebufferCount++\n framebufferSet[this.id] = this\n\n this.framebuffer = gl.createFramebuffer()\n this.width = 0\n this.height = 0\n\n this.colorAttachments = []\n this.depthAttachment = null\n this.stencilAttachment = null\n this.depthStencilAttachment = null\n }\n\n function decFBORefs (framebuffer) {\n framebuffer.colorAttachments.forEach(decRef)\n decRef(framebuffer.depthAttachment)\n decRef(framebuffer.stencilAttachment)\n decRef(framebuffer.depthStencilAttachment)\n }\n\n function destroy (framebuffer) {\n var handle = framebuffer.framebuffer\n \n gl.deleteFramebuffer(handle)\n framebuffer.framebuffer = null\n stats.framebufferCount--\n delete framebufferSet[framebuffer.id]\n }\n\n function updateFramebuffer (framebuffer) {\n var i\n\n gl.bindFramebuffer(GL_FRAMEBUFFER$1, framebuffer.framebuffer)\n var colorAttachments = framebuffer.colorAttachments\n for (i = 0; i < colorAttachments.length; ++i) {\n attach(GL_COLOR_ATTACHMENT0$1 + i, colorAttachments[i])\n }\n for (i = colorAttachments.length; i < limits.maxColorAttachments; ++i) {\n gl.framebufferTexture2D(\n GL_FRAMEBUFFER$1,\n GL_COLOR_ATTACHMENT0$1 + i,\n GL_TEXTURE_2D$2,\n null,\n 0)\n }\n\n gl.framebufferTexture2D(\n GL_FRAMEBUFFER$1,\n GL_DEPTH_STENCIL_ATTACHMENT,\n GL_TEXTURE_2D$2,\n null,\n 0)\n gl.framebufferTexture2D(\n GL_FRAMEBUFFER$1,\n GL_DEPTH_ATTACHMENT,\n GL_TEXTURE_2D$2,\n null,\n 0)\n gl.framebufferTexture2D(\n GL_FRAMEBUFFER$1,\n GL_STENCIL_ATTACHMENT,\n GL_TEXTURE_2D$2,\n null,\n 0)\n\n attach(GL_DEPTH_ATTACHMENT, framebuffer.depthAttachment)\n attach(GL_STENCIL_ATTACHMENT, framebuffer.stencilAttachment)\n attach(GL_DEPTH_STENCIL_ATTACHMENT, framebuffer.depthStencilAttachment)\n\n // Check status code\n var status = gl.checkFramebufferStatus(GL_FRAMEBUFFER$1)\n if (!gl.isContextLost() && status !== GL_FRAMEBUFFER_COMPLETE$1) {\n \n }\n\n gl.bindFramebuffer(GL_FRAMEBUFFER$1, framebufferState.next ? framebufferState.next.framebuffer : null)\n framebufferState.cur = framebufferState.next\n\n // FIXME: Clear error code here. This is a work around for a bug in\n // headless-gl\n gl.getError()\n }\n\n function createFBO (a0, a1) {\n var framebuffer = new REGLFramebuffer()\n stats.framebufferCount++\n\n function reglFramebuffer (a, b) {\n var i\n\n \n\n var width = 0\n var height = 0\n\n var needsDepth = true\n var needsStencil = true\n\n var colorBuffer = null\n var colorTexture = true\n var colorFormat = 'rgba'\n var colorType = 'uint8'\n var colorCount = 1\n\n var depthBuffer = null\n var stencilBuffer = null\n var depthStencilBuffer = null\n var depthStencilTexture = false\n\n if (typeof a === 'number') {\n width = a | 0\n height = (b | 0) || width\n } else if (!a) {\n width = height = 1\n } else {\n \n var options = a\n\n if ('shape' in options) {\n var shape = options.shape\n \n width = shape[0]\n height = shape[1]\n } else {\n if ('radius' in options) {\n width = height = options.radius\n }\n if ('width' in options) {\n width = options.width\n }\n if ('height' in options) {\n height = options.height\n }\n }\n\n if ('color' in options ||\n 'colors' in options) {\n colorBuffer =\n options.color ||\n options.colors\n if (Array.isArray(colorBuffer)) {\n \n }\n }\n\n if (!colorBuffer) {\n if ('colorCount' in options) {\n colorCount = options.colorCount | 0\n \n }\n\n if ('colorTexture' in options) {\n colorTexture = !!options.colorTexture\n colorFormat = 'rgba4'\n }\n\n if ('colorType' in options) {\n colorType = options.colorType\n if (!colorTexture) {\n if (colorType === 'half float' || colorType === 'float16') {\n \n colorFormat = 'rgba16f'\n } else if (colorType === 'float' || colorType === 'float32') {\n \n colorFormat = 'rgba32f'\n }\n } else {\n \n \n }\n \n }\n\n if ('colorFormat' in options) {\n colorFormat = options.colorFormat\n if (colorTextureFormats.indexOf(colorFormat) >= 0) {\n colorTexture = true\n } else if (colorRenderbufferFormats.indexOf(colorFormat) >= 0) {\n colorTexture = false\n } else {\n \n }\n }\n }\n\n if ('depthTexture' in options || 'depthStencilTexture' in options) {\n depthStencilTexture = !!(options.depthTexture ||\n options.depthStencilTexture)\n \n }\n\n if ('depth' in options) {\n if (typeof options.depth === 'boolean') {\n needsDepth = options.depth\n } else {\n depthBuffer = options.depth\n needsStencil = false\n }\n }\n\n if ('stencil' in options) {\n if (typeof options.stencil === 'boolean') {\n needsStencil = options.stencil\n } else {\n stencilBuffer = options.stencil\n needsDepth = false\n }\n }\n\n if ('depthStencil' in options) {\n if (typeof options.depthStencil === 'boolean') {\n needsDepth = needsStencil = options.depthStencil\n } else {\n depthStencilBuffer = options.depthStencil\n needsDepth = false\n needsStencil = false\n }\n }\n }\n\n // parse attachments\n var colorAttachments = null\n var depthAttachment = null\n var stencilAttachment = null\n var depthStencilAttachment = null\n\n // Set up color attachments\n if (Array.isArray(colorBuffer)) {\n colorAttachments = colorBuffer.map(parseAttachment)\n } else if (colorBuffer) {\n colorAttachments = [parseAttachment(colorBuffer)]\n } else {\n colorAttachments = new Array(colorCount)\n for (i = 0; i < colorCount; ++i) {\n colorAttachments[i] = allocAttachment(\n width,\n height,\n colorTexture,\n colorFormat,\n colorType)\n }\n }\n\n \n \n\n width = width || colorAttachments[0].width\n height = height || colorAttachments[0].height\n\n if (depthBuffer) {\n depthAttachment = parseAttachment(depthBuffer)\n } else if (needsDepth && !needsStencil) {\n depthAttachment = allocAttachment(\n width,\n height,\n depthStencilTexture,\n 'depth',\n 'uint32')\n }\n\n if (stencilBuffer) {\n stencilAttachment = parseAttachment(stencilBuffer)\n } else if (needsStencil && !needsDepth) {\n stencilAttachment = allocAttachment(\n width,\n height,\n false,\n 'stencil',\n 'uint8')\n }\n\n if (depthStencilBuffer) {\n depthStencilAttachment = parseAttachment(depthStencilBuffer)\n } else if (!depthBuffer && !stencilBuffer && needsStencil && needsDepth) {\n depthStencilAttachment = allocAttachment(\n width,\n height,\n depthStencilTexture,\n 'depth stencil',\n 'depth stencil')\n }\n\n \n\n var commonColorAttachmentSize = null\n\n for (i = 0; i < colorAttachments.length; ++i) {\n incRefAndCheckShape(colorAttachments[i], width, height)\n \n\n if (colorAttachments[i] && colorAttachments[i].texture) {\n var colorAttachmentSize =\n textureFormatChannels[colorAttachments[i].texture._texture.format] *\n textureTypeSizes[colorAttachments[i].texture._texture.type]\n\n if (commonColorAttachmentSize === null) {\n commonColorAttachmentSize = colorAttachmentSize\n } else {\n // We need to make sure that all color attachments have the same number of bitplanes\n // (that is, the same numer of bits per pixel)\n // This is required by the GLES2.0 standard. See the beginning of Chapter 4 in that document.\n \n }\n }\n }\n incRefAndCheckShape(depthAttachment, width, height)\n \n incRefAndCheckShape(stencilAttachment, width, height)\n \n incRefAndCheckShape(depthStencilAttachment, width, height)\n \n\n // decrement references\n decFBORefs(framebuffer)\n\n framebuffer.width = width\n framebuffer.height = height\n\n framebuffer.colorAttachments = colorAttachments\n framebuffer.depthAttachment = depthAttachment\n framebuffer.stencilAttachment = stencilAttachment\n framebuffer.depthStencilAttachment = depthStencilAttachment\n\n reglFramebuffer.color = colorAttachments.map(unwrapAttachment)\n reglFramebuffer.depth = unwrapAttachment(depthAttachment)\n reglFramebuffer.stencil = unwrapAttachment(stencilAttachment)\n reglFramebuffer.depthStencil = unwrapAttachment(depthStencilAttachment)\n\n reglFramebuffer.width = framebuffer.width\n reglFramebuffer.height = framebuffer.height\n\n updateFramebuffer(framebuffer)\n\n return reglFramebuffer\n }\n\n function resize (w_, h_) {\n \n\n var w = Math.max(w_ | 0, 1)\n var h = Math.max((h_ | 0) || w, 1)\n if (w === framebuffer.width && h === framebuffer.height) {\n return reglFramebuffer\n }\n\n // resize all buffers\n var colorAttachments = framebuffer.colorAttachments\n for (var i = 0; i < colorAttachments.length; ++i) {\n resizeAttachment(colorAttachments[i], w, h)\n }\n resizeAttachment(framebuffer.depthAttachment, w, h)\n resizeAttachment(framebuffer.stencilAttachment, w, h)\n resizeAttachment(framebuffer.depthStencilAttachment, w, h)\n\n framebuffer.width = reglFramebuffer.width = w\n framebuffer.height = reglFramebuffer.height = h\n\n updateFramebuffer(framebuffer)\n\n return reglFramebuffer\n }\n\n reglFramebuffer(a0, a1)\n\n return extend(reglFramebuffer, {\n resize: resize,\n _reglType: 'framebuffer',\n _framebuffer: framebuffer,\n destroy: function () {\n destroy(framebuffer)\n decFBORefs(framebuffer)\n },\n use: function (block) {\n framebufferState.setFBO({\n framebuffer: reglFramebuffer\n }, block)\n }\n })\n }\n\n function createCubeFBO (options) {\n var faces = Array(6)\n\n function reglFramebufferCube (a) {\n var i\n\n \n\n var params = {\n color: null\n }\n\n var radius = 0\n\n var colorBuffer = null\n var colorFormat = 'rgba'\n var colorType = 'uint8'\n var colorCount = 1\n\n if (typeof a === 'number') {\n radius = a | 0\n } else if (!a) {\n radius = 1\n } else {\n \n var options = a\n\n if ('shape' in options) {\n var shape = options.shape\n \n \n radius = shape[0]\n } else {\n if ('radius' in options) {\n radius = options.radius | 0\n }\n if ('width' in options) {\n radius = options.width | 0\n if ('height' in options) {\n \n }\n } else if ('height' in options) {\n radius = options.height | 0\n }\n }\n\n if ('color' in options ||\n 'colors' in options) {\n colorBuffer =\n options.color ||\n options.colors\n if (Array.isArray(colorBuffer)) {\n \n }\n }\n\n if (!colorBuffer) {\n if ('colorCount' in options) {\n colorCount = options.colorCount | 0\n \n }\n\n if ('colorType' in options) {\n \n colorType = options.colorType\n }\n\n if ('colorFormat' in options) {\n colorFormat = options.colorFormat\n \n }\n }\n\n if ('depth' in options) {\n params.depth = options.depth\n }\n\n if ('stencil' in options) {\n params.stencil = options.stencil\n }\n\n if ('depthStencil' in options) {\n params.depthStencil = options.depthStencil\n }\n }\n\n var colorCubes\n if (colorBuffer) {\n if (Array.isArray(colorBuffer)) {\n colorCubes = []\n for (i = 0; i < colorBuffer.length; ++i) {\n colorCubes[i] = colorBuffer[i]\n }\n } else {\n colorCubes = [ colorBuffer ]\n }\n } else {\n colorCubes = Array(colorCount)\n var cubeMapParams = {\n radius: radius,\n format: colorFormat,\n type: colorType\n }\n for (i = 0; i < colorCount; ++i) {\n colorCubes[i] = textureState.createCube(cubeMapParams)\n }\n }\n\n // Check color cubes\n params.color = Array(colorCubes.length)\n for (i = 0; i < colorCubes.length; ++i) {\n var cube = colorCubes[i]\n \n radius = radius || cube.width\n \n params.color[i] = {\n target: GL_TEXTURE_CUBE_MAP_POSITIVE_X$2,\n data: colorCubes[i]\n }\n }\n\n for (i = 0; i < 6; ++i) {\n for (var j = 0; j < colorCubes.length; ++j) {\n params.color[j].target = GL_TEXTURE_CUBE_MAP_POSITIVE_X$2 + i\n }\n // reuse depth-stencil attachments across all cube maps\n if (i > 0) {\n params.depth = faces[0].depth\n params.stencil = faces[0].stencil\n params.depthStencil = faces[0].depthStencil\n }\n if (faces[i]) {\n (faces[i])(params)\n } else {\n faces[i] = createFBO(params)\n }\n }\n\n return extend(reglFramebufferCube, {\n width: radius,\n height: radius,\n color: colorCubes\n })\n }\n\n function resize (radius_) {\n var i\n var radius = radius_ | 0\n \n\n if (radius === reglFramebufferCube.width) {\n return reglFramebufferCube\n }\n\n var colors = reglFramebufferCube.color\n for (i = 0; i < colors.length; ++i) {\n colors[i].resize(radius)\n }\n\n for (i = 0; i < 6; ++i) {\n faces[i].resize(radius)\n }\n\n reglFramebufferCube.width = reglFramebufferCube.height = radius\n\n return reglFramebufferCube\n }\n\n reglFramebufferCube(options)\n\n return extend(reglFramebufferCube, {\n faces: faces,\n resize: resize,\n _reglType: 'framebufferCube',\n destroy: function () {\n faces.forEach(function (f) {\n f.destroy()\n })\n }\n })\n }\n\n function restoreFramebuffers () {\n framebufferState.cur = null\n framebufferState.next = null\n framebufferState.dirty = true\n values(framebufferSet).forEach(function (fb) {\n fb.framebuffer = gl.createFramebuffer()\n updateFramebuffer(fb)\n })\n }\n\n return extend(framebufferState, {\n getFramebuffer: function (object) {\n if (typeof object === 'function' && object._reglType === 'framebuffer') {\n var fbo = object._framebuffer\n if (fbo instanceof REGLFramebuffer) {\n return fbo\n }\n }\n return null\n },\n create: createFBO,\n createCube: createCubeFBO,\n clear: function () {\n values(framebufferSet).forEach(destroy)\n },\n restore: restoreFramebuffers\n })\n}\n\nvar GL_FLOAT$5 = 5126\nvar GL_ARRAY_BUFFER$1 = 34962\nvar GL_ELEMENT_ARRAY_BUFFER$1 = 34963\n\nfunction AttributeRecord () {\n this.state = 0\n\n this.x = 0.0\n this.y = 0.0\n this.z = 0.0\n this.w = 0.0\n\n this.buffer = null\n this.size = 0\n this.normalized = false\n this.type = GL_FLOAT$5\n this.offset = 0\n this.stride = 0\n this.divisor = 0\n}\n\nfunction wrapAttributeState (\n gl,\n extensions,\n limits,\n stats,\n bufferState,\n elementState,\n drawState) {\n var NUM_ATTRIBUTES = limits.maxAttributes\n var attributeBindings = new Array(NUM_ATTRIBUTES)\n for (var i = 0; i < NUM_ATTRIBUTES; ++i) {\n attributeBindings[i] = new AttributeRecord()\n }\n var vaoCount = 0\n var vaoSet = {}\n\n var state = {\n Record: AttributeRecord,\n scope: {},\n state: attributeBindings,\n currentVAO: null,\n targetVAO: null,\n restore: extVAO() ? restoreVAO : function () {},\n createVAO: createVAO,\n getVAO: getVAO,\n destroyBuffer: destroyBuffer,\n setVAO: extVAO() ? setVAOEXT : setVAOEmulated,\n clear: extVAO() ? destroyVAOEXT : function () {}\n }\n\n function destroyBuffer (buffer) {\n for (var i = 0; i < attributeBindings.length; ++i) {\n var record = attributeBindings[i]\n if (record.buffer === buffer) {\n gl.disableVertexAttribArray(i)\n record.buffer = null\n }\n }\n }\n\n function extVAO () {\n return extensions.oes_vertex_array_object\n }\n\n function extInstanced () {\n return extensions.angle_instanced_arrays\n }\n\n function getVAO (vao) {\n if (typeof vao === 'function' && vao._vao) {\n return vao._vao\n }\n return null\n }\n\n function setVAOEXT (vao) {\n if (vao === state.currentVAO) {\n return\n }\n var ext = extVAO()\n if (vao) {\n ext.bindVertexArrayOES(vao.vao)\n } else {\n ext.bindVertexArrayOES(null)\n }\n state.currentVAO = vao\n }\n\n function setVAOEmulated (vao) {\n if (vao === state.currentVAO) {\n return\n }\n if (vao) {\n vao.bindAttrs()\n } else {\n var exti = extInstanced()\n for (var i = 0; i < attributeBindings.length; ++i) {\n var binding = attributeBindings[i]\n if (binding.buffer) {\n gl.enableVertexAttribArray(i)\n binding.buffer.bind()\n gl.vertexAttribPointer(i, binding.size, binding.type, binding.normalized, binding.stride, binding.offfset)\n if (exti && binding.divisor) {\n exti.vertexAttribDivisorANGLE(i, binding.divisor)\n }\n } else {\n gl.disableVertexAttribArray(i)\n gl.vertexAttrib4f(i, binding.x, binding.y, binding.z, binding.w)\n }\n }\n if (drawState.elements) {\n gl.bindBuffer(GL_ELEMENT_ARRAY_BUFFER$1, drawState.elements.buffer.buffer)\n } else {\n gl.bindBuffer(GL_ELEMENT_ARRAY_BUFFER$1, null)\n }\n }\n state.currentVAO = vao\n }\n\n function destroyVAOEXT () {\n values(vaoSet).forEach(function (vao) {\n vao.destroy()\n })\n }\n\n function REGLVAO () {\n this.id = ++vaoCount\n this.attributes = []\n this.elements = null\n this.ownsElements = false\n this.count = 0\n this.offset = 0\n this.instances = -1\n this.primitive = 4\n var extension = extVAO()\n if (extension) {\n this.vao = extension.createVertexArrayOES()\n } else {\n this.vao = null\n }\n vaoSet[this.id] = this\n this.buffers = []\n }\n\n REGLVAO.prototype.bindAttrs = function () {\n var exti = extInstanced()\n var attributes = this.attributes\n for (var i = 0; i < attributes.length; ++i) {\n var attr = attributes[i]\n if (attr.buffer) {\n gl.enableVertexAttribArray(i)\n gl.bindBuffer(GL_ARRAY_BUFFER$1, attr.buffer.buffer)\n gl.vertexAttribPointer(i, attr.size, attr.type, attr.normalized, attr.stride, attr.offset)\n if (exti && attr.divisor) {\n exti.vertexAttribDivisorANGLE(i, attr.divisor)\n }\n } else {\n gl.disableVertexAttribArray(i)\n gl.vertexAttrib4f(i, attr.x, attr.y, attr.z, attr.w)\n }\n }\n for (var j = attributes.length; j < NUM_ATTRIBUTES; ++j) {\n gl.disableVertexAttribArray(j)\n }\n var elements = elementState.getElements(this.elements)\n if (elements) {\n gl.bindBuffer(GL_ELEMENT_ARRAY_BUFFER$1, elements.buffer.buffer)\n } else {\n gl.bindBuffer(GL_ELEMENT_ARRAY_BUFFER$1, null)\n }\n }\n\n REGLVAO.prototype.refresh = function () {\n var ext = extVAO()\n if (ext) {\n ext.bindVertexArrayOES(this.vao)\n this.bindAttrs()\n state.currentVAO = null\n ext.bindVertexArrayOES(null)\n }\n }\n\n REGLVAO.prototype.destroy = function () {\n if (this.vao) {\n var extension = extVAO()\n if (this === state.currentVAO) {\n state.currentVAO = null\n extension.bindVertexArrayOES(null)\n }\n extension.deleteVertexArrayOES(this.vao)\n this.vao = null\n }\n if (this.ownsElements) {\n this.elements.destroy()\n this.elements = null\n this.ownsElements = false\n }\n if (vaoSet[this.id]) {\n delete vaoSet[this.id]\n stats.vaoCount -= 1\n }\n }\n\n function restoreVAO () {\n var ext = extVAO()\n if (ext) {\n values(vaoSet).forEach(function (vao) {\n vao.refresh()\n })\n }\n }\n\n function createVAO (_attr) {\n var vao = new REGLVAO()\n stats.vaoCount += 1\n\n function updateVAO (options) {\n var attributes\n if (Array.isArray(options)) {\n attributes = options\n if (vao.elements && vao.ownsElements) {\n vao.elements.destroy()\n }\n vao.elements = null\n vao.ownsElements = false\n vao.offset = 0\n vao.count = 0\n vao.instances = -1\n vao.primitive = 4\n } else {\n \n \n if (options.elements) {\n var elements = options.elements\n if (vao.ownsElements) {\n if (typeof elements === 'function' && elements._reglType === 'elements') {\n vao.elements.destroy()\n vao.ownsElements = false\n } else {\n vao.elements(elements)\n vao.ownsElements = false\n }\n } else if (elementState.getElements(options.elements)) {\n vao.elements = options.elements\n vao.ownsElements = false\n } else {\n vao.elements = elementState.create(options.elements)\n vao.ownsElements = true\n }\n } else {\n vao.elements = null\n vao.ownsElements = false\n }\n attributes = options.attributes\n\n // set default vao\n vao.offset = 0\n vao.count = -1\n vao.instances = -1\n vao.primitive = 4\n\n // copy element properties\n if (vao.elements) {\n vao.count = vao.elements._elements.vertCount\n vao.primitive = vao.elements._elements.primType\n }\n\n if ('offset' in options) {\n vao.offset = options.offset | 0\n }\n if ('count' in options) {\n vao.count = options.count | 0\n }\n if ('instances' in options) {\n vao.instances = options.instances | 0\n }\n if ('primitive' in options) {\n \n vao.primitive = primTypes[options.primitive]\n }\n\n \n \n }\n\n \n \n\n var bufUpdated = {}\n var nattributes = vao.attributes\n nattributes.length = attributes.length\n for (var i = 0; i < attributes.length; ++i) {\n var spec = attributes[i]\n var rec = nattributes[i] = new AttributeRecord()\n var data = spec.data || spec\n if (Array.isArray(data) || isTypedArray(data) || isNDArrayLike(data)) {\n var buf\n if (vao.buffers[i]) {\n buf = vao.buffers[i]\n if (isTypedArray(data) && buf._buffer.byteLength >= data.byteLength) {\n buf.subdata(data)\n } else {\n buf.destroy()\n vao.buffers[i] = null\n }\n }\n if (!vao.buffers[i]) {\n buf = vao.buffers[i] = bufferState.create(spec, GL_ARRAY_BUFFER$1, false, true)\n }\n rec.buffer = bufferState.getBuffer(buf)\n rec.size = rec.buffer.dimension | 0\n rec.normalized = false\n rec.type = rec.buffer.dtype\n rec.offset = 0\n rec.stride = 0\n rec.divisor = 0\n rec.state = 1\n bufUpdated[i] = 1\n } else if (bufferState.getBuffer(spec)) {\n rec.buffer = bufferState.getBuffer(spec)\n rec.size = rec.buffer.dimension | 0\n rec.normalized = false\n rec.type = rec.buffer.dtype\n rec.offset = 0\n rec.stride = 0\n rec.divisor = 0\n rec.state = 1\n } else if (bufferState.getBuffer(spec.buffer)) {\n rec.buffer = bufferState.getBuffer(spec.buffer)\n rec.size = ((+spec.size) || rec.buffer.dimension) | 0\n rec.normalized = !!spec.normalized || false\n if ('type' in spec) {\n \n rec.type = glTypes[spec.type]\n } else {\n rec.type = rec.buffer.dtype\n }\n rec.offset = (spec.offset || 0) | 0\n rec.stride = (spec.stride || 0) | 0\n rec.divisor = (spec.divisor || 0) | 0\n rec.state = 1\n\n \n \n \n \n \n } else if ('x' in spec) {\n \n rec.x = +spec.x || 0\n rec.y = +spec.y || 0\n rec.z = +spec.z || 0\n rec.w = +spec.w || 0\n rec.state = 2\n } else {\n \n }\n }\n\n // retire unused buffers\n for (var j = 0; j < vao.buffers.length; ++j) {\n if (!bufUpdated[j] && vao.buffers[j]) {\n vao.buffers[j].destroy()\n vao.buffers[j] = null\n }\n }\n\n vao.refresh()\n return updateVAO\n }\n\n updateVAO.destroy = function () {\n for (var j = 0; j < vao.buffers.length; ++j) {\n if (vao.buffers[j]) {\n vao.buffers[j].destroy()\n }\n }\n vao.buffers.length = 0\n\n if (vao.ownsElements) {\n vao.elements.destroy()\n vao.elements = null\n vao.ownsElements = false\n }\n\n vao.destroy()\n }\n\n updateVAO._vao = vao\n updateVAO._reglType = 'vao'\n\n return updateVAO(_attr)\n }\n\n return state\n}\n\nvar GL_FRAGMENT_SHADER = 35632\nvar GL_VERTEX_SHADER = 35633\n\nvar GL_ACTIVE_UNIFORMS = 0x8B86\nvar GL_ACTIVE_ATTRIBUTES = 0x8B89\n\nfunction wrapShaderState (gl, stringStore, stats, config) {\n // ===================================================\n // glsl compilation and linking\n // ===================================================\n var fragShaders = {}\n var vertShaders = {}\n\n function ActiveInfo (name, id, location, info) {\n this.name = name\n this.id = id\n this.location = location\n this.info = info\n }\n\n function insertActiveInfo (list, info) {\n for (var i = 0; i < list.length; ++i) {\n if (list[i].id === info.id) {\n list[i].location = info.location\n return\n }\n }\n list.push(info)\n }\n\n function getShader (type, id, command) {\n var cache = type === GL_FRAGMENT_SHADER ? fragShaders : vertShaders\n var shader = cache[id]\n\n if (!shader) {\n var source = stringStore.str(id)\n shader = gl.createShader(type)\n gl.shaderSource(shader, source)\n gl.compileShader(shader)\n \n cache[id] = shader\n }\n\n return shader\n }\n\n // ===================================================\n // program linking\n // ===================================================\n var programCache = {}\n var programList = []\n\n var PROGRAM_COUNTER = 0\n\n function REGLProgram (fragId, vertId) {\n this.id = PROGRAM_COUNTER++\n this.fragId = fragId\n this.vertId = vertId\n this.program = null\n this.uniforms = []\n this.attributes = []\n this.refCount = 1\n\n if (config.profile) {\n this.stats = {\n uniformsCount: 0,\n attributesCount: 0\n }\n }\n }\n\n function linkProgram (desc, command, attributeLocations) {\n var i, info\n\n // -------------------------------\n // compile & link\n // -------------------------------\n var fragShader = getShader(GL_FRAGMENT_SHADER, desc.fragId)\n var vertShader = getShader(GL_VERTEX_SHADER, desc.vertId)\n\n var program = desc.program = gl.createProgram()\n gl.attachShader(program, fragShader)\n gl.attachShader(program, vertShader)\n if (attributeLocations) {\n for (i = 0; i < attributeLocations.length; ++i) {\n var binding = attributeLocations[i]\n gl.bindAttribLocation(program, binding[0], binding[1])\n }\n }\n\n gl.linkProgram(program)\n \n\n // -------------------------------\n // grab uniforms\n // -------------------------------\n var numUniforms = gl.getProgramParameter(program, GL_ACTIVE_UNIFORMS)\n if (config.profile) {\n desc.stats.uniformsCount = numUniforms\n }\n var uniforms = desc.uniforms\n for (i = 0; i < numUniforms; ++i) {\n info = gl.getActiveUniform(program, i)\n if (info) {\n if (info.size > 1) {\n for (var j = 0; j < info.size; ++j) {\n var name = info.name.replace('[0]', '[' + j + ']')\n insertActiveInfo(uniforms, new ActiveInfo(\n name,\n stringStore.id(name),\n gl.getUniformLocation(program, name),\n info))\n }\n } else {\n insertActiveInfo(uniforms, new ActiveInfo(\n info.name,\n stringStore.id(info.name),\n gl.getUniformLocation(program, info.name),\n info))\n }\n }\n }\n\n // -------------------------------\n // grab attributes\n // -------------------------------\n var numAttributes = gl.getProgramParameter(program, GL_ACTIVE_ATTRIBUTES)\n if (config.profile) {\n desc.stats.attributesCount = numAttributes\n }\n\n var attributes = desc.attributes\n for (i = 0; i < numAttributes; ++i) {\n info = gl.getActiveAttrib(program, i)\n if (info) {\n insertActiveInfo(attributes, new ActiveInfo(\n info.name,\n stringStore.id(info.name),\n gl.getAttribLocation(program, info.name),\n info))\n }\n }\n }\n\n if (config.profile) {\n stats.getMaxUniformsCount = function () {\n var m = 0\n programList.forEach(function (desc) {\n if (desc.stats.uniformsCount > m) {\n m = desc.stats.uniformsCount\n }\n })\n return m\n }\n\n stats.getMaxAttributesCount = function () {\n var m = 0\n programList.forEach(function (desc) {\n if (desc.stats.attributesCount > m) {\n m = desc.stats.attributesCount\n }\n })\n return m\n }\n }\n\n function restoreShaders () {\n fragShaders = {}\n vertShaders = {}\n for (var i = 0; i < programList.length; ++i) {\n linkProgram(programList[i], null, programList[i].attributes.map(function (info) {\n return [info.location, info.name]\n }))\n }\n }\n\n return {\n clear: function () {\n var deleteShader = gl.deleteShader.bind(gl)\n values(fragShaders).forEach(deleteShader)\n fragShaders = {}\n values(vertShaders).forEach(deleteShader)\n vertShaders = {}\n\n programList.forEach(function (desc) {\n gl.deleteProgram(desc.program)\n })\n programList.length = 0\n programCache = {}\n\n stats.shaderCount = 0\n },\n\n program: function (vertId, fragId, command, attribLocations) {\n \n \n\n var cache = programCache[fragId]\n if (!cache) {\n cache = programCache[fragId] = {}\n }\n var prevProgram = cache[vertId]\n if (prevProgram) {\n prevProgram.refCount++\n if (!attribLocations) {\n return prevProgram\n }\n }\n var program = new REGLProgram(fragId, vertId)\n stats.shaderCount++\n linkProgram(program, command, attribLocations)\n if (!prevProgram) {\n cache[vertId] = program\n }\n programList.push(program)\n return extend(program, {\n destroy: function () {\n program.refCount--\n if (program.refCount <= 0) {\n gl.deleteProgram(program.program)\n var idx = programList.indexOf(program)\n programList.splice(idx, 1)\n stats.shaderCount--\n }\n // no program is linked to this vert anymore\n if (cache[program.vertId].refCount <= 0) {\n gl.deleteShader(vertShaders[program.vertId])\n delete vertShaders[program.vertId]\n delete programCache[program.fragId][program.vertId]\n }\n // no program is linked to this frag anymore\n if (!Object.keys(programCache[program.fragId]).length) {\n gl.deleteShader(fragShaders[program.fragId])\n delete fragShaders[program.fragId]\n delete programCache[program.fragId]\n }\n }\n })\n },\n\n restore: restoreShaders,\n\n shader: getShader,\n\n frag: -1,\n vert: -1\n }\n}\n\nvar GL_RGBA$3 = 6408\nvar GL_UNSIGNED_BYTE$6 = 5121\nvar GL_PACK_ALIGNMENT = 0x0D05\nvar GL_FLOAT$6 = 0x1406 // 5126\n\nfunction wrapReadPixels (\n gl,\n framebufferState,\n reglPoll,\n context,\n glAttributes,\n extensions,\n limits) {\n function readPixelsImpl (input) {\n var type\n if (framebufferState.next === null) {\n \n type = GL_UNSIGNED_BYTE$6\n } else {\n \n type = framebufferState.next.colorAttachments[0].texture._texture.type\n\n \n }\n\n var x = 0\n var y = 0\n var width = context.framebufferWidth\n var height = context.framebufferHeight\n var data = null\n\n if (isTypedArray(input)) {\n data = input\n } else if (input) {\n \n x = input.x | 0\n y = input.y | 0\n \n \n width = (input.width || (context.framebufferWidth - x)) | 0\n height = (input.height || (context.framebufferHeight - y)) | 0\n data = input.data || null\n }\n\n // sanity check input.data\n if (data) {\n if (type === GL_UNSIGNED_BYTE$6) {\n \n } else if (type === GL_FLOAT$6) {\n \n }\n }\n\n \n \n\n // Update WebGL state\n reglPoll()\n\n // Compute size\n var size = width * height * 4\n\n // Allocate data\n if (!data) {\n if (type === GL_UNSIGNED_BYTE$6) {\n data = new Uint8Array(size)\n } else if (type === GL_FLOAT$6) {\n data = data || new Float32Array(size)\n }\n }\n\n // Type check\n \n \n\n // Run read pixels\n gl.pixelStorei(GL_PACK_ALIGNMENT, 4)\n gl.readPixels(x, y, width, height, GL_RGBA$3,\n type,\n data)\n\n return data\n }\n\n function readPixelsFBO (options) {\n var result\n framebufferState.setFBO({\n framebuffer: options.framebuffer\n }, function () {\n result = readPixelsImpl(options)\n })\n return result\n }\n\n function readPixels (options) {\n if (!options || !('framebuffer' in options)) {\n return readPixelsImpl(options)\n } else {\n return readPixelsFBO(options)\n }\n }\n\n return readPixels\n}\n\n/*\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-256, as defined\n * in FIPS 180-2\n * Version 2.2 Copyright Angel Marin, Paul Johnston 2000 - 2009.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for details.\n * Also http://anmar.eu.org/projects/jssha2/\n */\n\n/*\n * Configurable variables. You may need to tweak these to be compatible with\n * the server-side, but the defaults work in most cases.\n */\nvar hexcase = 0; /* hex output format. 0 - lowercase; 1 - uppercase */\nvar b64pad = \"\"; /* base-64 pad character. \"=\" for strict RFC compliance */\n\n/*\n * These are the functions you'll usually want to call\n * They take string arguments and return either hex or base-64 encoded strings\n */\nfunction hex_sha256(s) { return rstr2hex(rstr_sha256(str2rstr_utf8(s))); }\n/*\n * Calculate the sha256 of a raw string\n */\nfunction rstr_sha256(s)\n{\n return binb2rstr(binb_sha256(rstr2binb(s), s.length * 8));\n}\n\n/*\n * Calculate the HMAC-sha256 of a key and some data (raw strings)\n */\nfunction rstr_hmac_sha256(key, data)\n{\n var bkey = rstr2binb(key);\n if(bkey.length > 16) bkey = binb_sha256(bkey, key.length * 8);\n\n var ipad = Array(16), opad = Array(16);\n for(var i = 0; i < 16; i++)\n {\n ipad[i] = bkey[i] ^ 0x36363636;\n opad[i] = bkey[i] ^ 0x5C5C5C5C;\n }\n\n var hash = binb_sha256(ipad.concat(rstr2binb(data)), 512 + data.length * 8);\n return binb2rstr(binb_sha256(opad.concat(hash), 512 + 256));\n}\n\n/*\n * Convert a raw string to a hex string\n */\nfunction rstr2hex(input)\n{\n var hex_tab = hexcase ? \"0123456789ABCDEF\" : \"0123456789abcdef\";\n var output = \"\";\n var x;\n for(var i = 0; i < input.length; i++)\n {\n x = input.charCodeAt(i);\n output += hex_tab.charAt((x >>> 4) & 0x0F)\n + hex_tab.charAt( x & 0x0F);\n }\n return output;\n}\n\n/*\n * Convert a raw string to a base-64 string\n */\nfunction rstr2b64(input)\n{\n var tab = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\";\n var output = \"\";\n var len = input.length;\n for(var i = 0; i < len; i += 3)\n {\n var triplet = (input.charCodeAt(i) << 16)\n | (i + 1 < len ? input.charCodeAt(i+1) << 8 : 0)\n | (i + 2 < len ? input.charCodeAt(i+2) : 0);\n for(var j = 0; j < 4; j++)\n {\n if(i * 8 + j * 6 > input.length * 8) output += b64pad;\n else output += tab.charAt((triplet >>> 6*(3-j)) & 0x3F);\n }\n }\n return output;\n}\n\n/*\n * Convert a raw string to an arbitrary string encoding\n */\nfunction rstr2any(input, encoding)\n{\n var divisor = encoding.length;\n var remainders = Array();\n var i, q, x, quotient;\n\n /* Convert to an array of 16-bit big-endian values, forming the dividend */\n var dividend = Array(Math.ceil(input.length / 2));\n for(i = 0; i < dividend.length; i++)\n {\n dividend[i] = (input.charCodeAt(i * 2) << 8) | input.charCodeAt(i * 2 + 1);\n }\n\n /*\n * Repeatedly perform a long division. The binary array forms the dividend,\n * the length of the encoding is the divisor. Once computed, the quotient\n * forms the dividend for the next step. We stop when the dividend is zero.\n * All remainders are stored for later use.\n */\n while(dividend.length > 0)\n {\n quotient = Array();\n x = 0;\n for(i = 0; i < dividend.length; i++)\n {\n x = (x << 16) + dividend[i];\n q = Math.floor(x / divisor);\n x -= q * divisor;\n if(quotient.length > 0 || q > 0)\n quotient[quotient.length] = q;\n }\n remainders[remainders.length] = x;\n dividend = quotient;\n }\n\n /* Convert the remainders to the output string */\n var output = \"\";\n for(i = remainders.length - 1; i >= 0; i--)\n output += encoding.charAt(remainders[i]);\n\n /* Append leading zero equivalents */\n var full_length = Math.ceil(input.length * 8 /\n (Math.log(encoding.length) / Math.log(2)))\n for(i = output.length; i < full_length; i++)\n output = encoding[0] + output;\n\n return output;\n}\n\n/*\n * Encode a string as utf-8.\n * For efficiency, this assumes the input is valid utf-16.\n */\nfunction str2rstr_utf8(input)\n{\n var output = \"\";\n var i = -1;\n var x, y;\n\n while(++i < input.length)\n {\n /* Decode utf-16 surrogate pairs */\n x = input.charCodeAt(i);\n y = i + 1 < input.length ? input.charCodeAt(i + 1) : 0;\n if(0xD800 <= x && x <= 0xDBFF && 0xDC00 <= y && y <= 0xDFFF)\n {\n x = 0x10000 + ((x & 0x03FF) << 10) + (y & 0x03FF);\n i++;\n }\n\n /* Encode output as utf-8 */\n if(x <= 0x7F)\n output += String.fromCharCode(x);\n else if(x <= 0x7FF)\n output += String.fromCharCode(0xC0 | ((x >>> 6 ) & 0x1F),\n 0x80 | ( x & 0x3F));\n else if(x <= 0xFFFF)\n output += String.fromCharCode(0xE0 | ((x >>> 12) & 0x0F),\n 0x80 | ((x >>> 6 ) & 0x3F),\n 0x80 | ( x & 0x3F));\n else if(x <= 0x1FFFFF)\n output += String.fromCharCode(0xF0 | ((x >>> 18) & 0x07),\n 0x80 | ((x >>> 12) & 0x3F),\n 0x80 | ((x >>> 6 ) & 0x3F),\n 0x80 | ( x & 0x3F));\n }\n return output;\n}\n\n/*\n * Convert a raw string to an array of big-endian words\n * Characters >255 have their high-byte silently ignored.\n */\nfunction rstr2binb(input)\n{\n var output = Array(input.length >> 2);\n for(var i = 0; i < output.length; i++)\n output[i] = 0;\n for(var i = 0; i < input.length * 8; i += 8)\n output[i>>5] |= (input.charCodeAt(i / 8) & 0xFF) << (24 - i % 32);\n return output;\n}\n\n/*\n * Convert an array of big-endian words to a string\n */\nfunction binb2rstr(input)\n{\n var output = \"\";\n for(var i = 0; i < input.length * 32; i += 8)\n output += String.fromCharCode((input[i>>5] >>> (24 - i % 32)) & 0xFF);\n return output;\n}\n\n/*\n * Main sha256 function, with its support functions\n */\nfunction sha256_S (X, n) {return ( X >>> n ) | (X << (32 - n));}\nfunction sha256_R (X, n) {return ( X >>> n );}\nfunction sha256_Ch(x, y, z) {return ((x & y) ^ ((~x) & z));}\nfunction sha256_Maj(x, y, z) {return ((x & y) ^ (x & z) ^ (y & z));}\nfunction sha256_Sigma0256(x) {return (sha256_S(x, 2) ^ sha256_S(x, 13) ^ sha256_S(x, 22));}\nfunction sha256_Sigma1256(x) {return (sha256_S(x, 6) ^ sha256_S(x, 11) ^ sha256_S(x, 25));}\nfunction sha256_Gamma0256(x) {return (sha256_S(x, 7) ^ sha256_S(x, 18) ^ sha256_R(x, 3));}\nfunction sha256_Gamma1256(x) {return (sha256_S(x, 17) ^ sha256_S(x, 19) ^ sha256_R(x, 10));}\nvar sha256_K = new Array\n(\n 1116352408, 1899447441, -1245643825, -373957723, 961987163, 1508970993,\n -1841331548, -1424204075, -670586216, 310598401, 607225278, 1426881987,\n 1925078388, -2132889090, -1680079193, -1046744716, -459576895, -272742522,\n 264347078, 604807628, 770255983, 1249150122, 1555081692, 1996064986,\n -1740746414, -1473132947, -1341970488, -1084653625, -958395405, -710438585,\n 113926993, 338241895, 666307205, 773529912, 1294757372, 1396182291,\n 1695183700, 1986661051, -2117940946, -1838011259, -1564481375, -1474664885,\n -1035236496, -949202525, -778901479, -694614492, -200395387, 275423344,\n 430227734, 506948616, 659060556, 883997877, 958139571, 1322822218,\n 1537002063, 1747873779, 1955562222, 2024104815, -2067236844, -1933114872,\n -1866530822, -1538233109, -1090935817, -965641998\n);\n\nfunction binb_sha256(m, l)\n{\n var HASH = new Array(1779033703, -1150833019, 1013904242, -1521486534,\n 1359893119, -1694144372, 528734635, 1541459225);\n var W = new Array(64);\n var a, b, c, d, e, f, g, h;\n var i, j, T1, T2;\n\n /* append padding */\n m[l >> 5] |= 0x80 << (24 - l % 32);\n m[((l + 64 >> 9) << 4) + 15] = l;\n\n for(i = 0; i < m.length; i += 16)\n {\n a = HASH[0];\n b = HASH[1];\n c = HASH[2];\n d = HASH[3];\n e = HASH[4];\n f = HASH[5];\n g = HASH[6];\n h = HASH[7];\n\n for(j = 0; j < 64; j++)\n {\n if (j < 16) W[j] = m[j + i];\n else W[j] = safe_add(safe_add(safe_add(sha256_Gamma1256(W[j - 2]), W[j - 7]),\n sha256_Gamma0256(W[j - 15])), W[j - 16]);\n\n T1 = safe_add(safe_add(safe_add(safe_add(h, sha256_Sigma1256(e)), sha256_Ch(e, f, g)),\n sha256_K[j]), W[j]);\n T2 = safe_add(sha256_Sigma0256(a), sha256_Maj(a, b, c));\n h = g;\n g = f;\n f = e;\n e = safe_add(d, T1);\n d = c;\n c = b;\n b = a;\n a = safe_add(T1, T2);\n }\n\n HASH[0] = safe_add(a, HASH[0]);\n HASH[1] = safe_add(b, HASH[1]);\n HASH[2] = safe_add(c, HASH[2]);\n HASH[3] = safe_add(d, HASH[3]);\n HASH[4] = safe_add(e, HASH[4]);\n HASH[5] = safe_add(f, HASH[5]);\n HASH[6] = safe_add(g, HASH[6]);\n HASH[7] = safe_add(h, HASH[7]);\n }\n return HASH;\n}\n\nfunction safe_add (x, y)\n{\n var lsw = (x & 0xFFFF) + (y & 0xFFFF);\n var msw = (x >> 16) + (y >> 16) + (lsw >> 16);\n return (msw << 16) | (lsw & 0xFFFF);\n}\n\nfunction slice (x) {\n return Array.prototype.slice.call(x)\n}\n\nfunction join (x) {\n return slice(x).join('')\n}\n\nfunction createEnvironment (options) {\n var cache = options && options.cache\n\n // Unique variable id counter\n var varCounter = 0\n\n // Linked values are passed from this scope into the generated code block\n // Calling link() passes a value into the generated scope and returns\n // the variable name which it is bound to\n var linkedNames = []\n var linkedValues = []\n var isStable = []\n function link (value, options) {\n var stable = options && options.stable\n if (!stable) {\n for (var i = 0; i < linkedValues.length; ++i) {\n if (linkedValues[i] === value && !isStable[i]) {\n return linkedNames[i]\n }\n }\n }\n\n var name = 'g' + (varCounter++)\n linkedNames.push(name)\n linkedValues.push(value)\n isStable.push(stable)\n return name\n }\n\n // create a code block\n function block () {\n var code = []\n function push () {\n code.push.apply(code, slice(arguments))\n }\n\n var vars = []\n function def () {\n var name = 'v' + (varCounter++)\n vars.push(name)\n\n if (arguments.length > 0) {\n code.push(name, '=')\n code.push.apply(code, slice(arguments))\n code.push(';')\n }\n\n return name\n }\n\n return extend(push, {\n def: def,\n toString: function () {\n return join([\n (vars.length > 0 ? 'var ' + vars.join(',') + ';' : ''),\n join(code)\n ])\n }\n })\n }\n\n function scope () {\n var entry = block()\n var exit = block()\n\n var entryToString = entry.toString\n var exitToString = exit.toString\n\n function save (object, prop) {\n exit(object, prop, '=', entry.def(object, prop), ';')\n }\n\n return extend(function () {\n entry.apply(entry, slice(arguments))\n }, {\n def: entry.def,\n entry: entry,\n exit: exit,\n save: save,\n set: function (object, prop, value) {\n save(object, prop)\n entry(object, prop, '=', value, ';')\n },\n toString: function () {\n return entryToString() + exitToString()\n }\n })\n }\n\n function conditional () {\n var pred = join(arguments)\n var thenBlock = scope()\n var elseBlock = scope()\n\n var thenToString = thenBlock.toString\n var elseToString = elseBlock.toString\n\n return extend(thenBlock, {\n then: function () {\n thenBlock.apply(thenBlock, slice(arguments))\n return this\n },\n else: function () {\n elseBlock.apply(elseBlock, slice(arguments))\n return this\n },\n toString: function () {\n var elseClause = elseToString()\n if (elseClause) {\n elseClause = 'else{' + elseClause + '}'\n }\n return join([\n 'if(', pred, '){',\n thenToString(),\n '}', elseClause\n ])\n }\n })\n }\n\n // procedure list\n var globalBlock = block()\n var procedures = {}\n function proc (name, count) {\n var args = []\n function arg () {\n var name = 'a' + args.length\n args.push(name)\n return name\n }\n\n count = count || 0\n for (var i = 0; i < count; ++i) {\n arg()\n }\n\n var body = scope()\n var bodyToString = body.toString\n\n var result = procedures[name] = extend(body, {\n arg: arg,\n toString: function () {\n return join([\n 'function(', args.join(), '){',\n bodyToString(),\n '}'\n ])\n }\n })\n\n return result\n }\n\n function compile () {\n var code = ['\"use strict\";',\n globalBlock,\n 'return {']\n Object.keys(procedures).forEach(function (name) {\n code.push('\"', name, '\":', procedures[name].toString(), ',')\n })\n code.push('}')\n var src = join(code)\n .replace(/;/g, ';\\n')\n .replace(/}/g, '}\\n')\n .replace(/{/g, '{\\n')\n\n var key\n if (cache) {\n key = hex_sha256(src);\n\n if (cache[key]) {\n return cache[key].apply(null, linkedValues)\n }\n }\n\n var proc = Function.apply(null, linkedNames.concat(src))\n\n if (cache) {\n cache[key] = proc\n }\n return proc.apply(null, linkedValues)\n }\n\n return {\n global: globalBlock,\n link: link,\n block: block,\n proc: proc,\n scope: scope,\n cond: conditional,\n compile: compile\n }\n}\n\n// \"cute\" names for vector components\nvar CUTE_COMPONENTS = 'xyzw'.split('')\n\nvar GL_UNSIGNED_BYTE$7 = 5121\n\nvar ATTRIB_STATE_POINTER = 1\nvar ATTRIB_STATE_CONSTANT = 2\n\nvar DYN_FUNC$1 = 0\nvar DYN_PROP$1 = 1\nvar DYN_CONTEXT$1 = 2\nvar DYN_STATE$1 = 3\nvar DYN_THUNK = 4\nvar DYN_CONSTANT$1 = 5\nvar DYN_ARRAY$1 = 6\n\nvar S_DITHER = 'dither'\nvar S_BLEND_ENABLE = 'blend.enable'\nvar S_BLEND_COLOR = 'blend.color'\nvar S_BLEND_EQUATION = 'blend.equation'\nvar S_BLEND_FUNC = 'blend.func'\nvar S_DEPTH_ENABLE = 'depth.enable'\nvar S_DEPTH_FUNC = 'depth.func'\nvar S_DEPTH_RANGE = 'depth.range'\nvar S_DEPTH_MASK = 'depth.mask'\nvar S_COLOR_MASK = 'colorMask'\nvar S_CULL_ENABLE = 'cull.enable'\nvar S_CULL_FACE = 'cull.face'\nvar S_FRONT_FACE = 'frontFace'\nvar S_LINE_WIDTH = 'lineWidth'\nvar S_POLYGON_OFFSET_ENABLE = 'polygonOffset.enable'\nvar S_POLYGON_OFFSET_OFFSET = 'polygonOffset.offset'\nvar S_SAMPLE_ALPHA = 'sample.alpha'\nvar S_SAMPLE_ENABLE = 'sample.enable'\nvar S_SAMPLE_COVERAGE = 'sample.coverage'\nvar S_STENCIL_ENABLE = 'stencil.enable'\nvar S_STENCIL_MASK = 'stencil.mask'\nvar S_STENCIL_FUNC = 'stencil.func'\nvar S_STENCIL_OPFRONT = 'stencil.opFront'\nvar S_STENCIL_OPBACK = 'stencil.opBack'\nvar S_SCISSOR_ENABLE = 'scissor.enable'\nvar S_SCISSOR_BOX = 'scissor.box'\nvar S_VIEWPORT = 'viewport'\n\nvar S_PROFILE = 'profile'\n\nvar S_FRAMEBUFFER = 'framebuffer'\nvar S_VERT = 'vert'\nvar S_FRAG = 'frag'\nvar S_ELEMENTS = 'elements'\nvar S_PRIMITIVE = 'primitive'\nvar S_COUNT = 'count'\nvar S_OFFSET = 'offset'\nvar S_INSTANCES = 'instances'\nvar S_VAO = 'vao'\n\nvar SUFFIX_WIDTH = 'Width'\nvar SUFFIX_HEIGHT = 'Height'\n\nvar S_FRAMEBUFFER_WIDTH = S_FRAMEBUFFER + SUFFIX_WIDTH\nvar S_FRAMEBUFFER_HEIGHT = S_FRAMEBUFFER + SUFFIX_HEIGHT\nvar S_VIEWPORT_WIDTH = S_VIEWPORT + SUFFIX_WIDTH\nvar S_VIEWPORT_HEIGHT = S_VIEWPORT + SUFFIX_HEIGHT\nvar S_DRAWINGBUFFER = 'drawingBuffer'\nvar S_DRAWINGBUFFER_WIDTH = S_DRAWINGBUFFER + SUFFIX_WIDTH\nvar S_DRAWINGBUFFER_HEIGHT = S_DRAWINGBUFFER + SUFFIX_HEIGHT\n\nvar NESTED_OPTIONS = [\n S_BLEND_FUNC,\n S_BLEND_EQUATION,\n S_STENCIL_FUNC,\n S_STENCIL_OPFRONT,\n S_STENCIL_OPBACK,\n S_SAMPLE_COVERAGE,\n S_VIEWPORT,\n S_SCISSOR_BOX,\n S_POLYGON_OFFSET_OFFSET\n]\n\nvar GL_ARRAY_BUFFER$2 = 34962\nvar GL_ELEMENT_ARRAY_BUFFER$2 = 34963\n\nvar GL_CULL_FACE = 0x0B44\nvar GL_BLEND = 0x0BE2\nvar GL_DITHER = 0x0BD0\nvar GL_STENCIL_TEST = 0x0B90\nvar GL_DEPTH_TEST = 0x0B71\nvar GL_SCISSOR_TEST = 0x0C11\nvar GL_POLYGON_OFFSET_FILL = 0x8037\nvar GL_SAMPLE_ALPHA_TO_COVERAGE = 0x809E\nvar GL_SAMPLE_COVERAGE = 0x80A0\n\nvar GL_FLOAT$7 = 5126\nvar GL_FLOAT_VEC2 = 35664\nvar GL_FLOAT_VEC3 = 35665\nvar GL_FLOAT_VEC4 = 35666\nvar GL_INT$2 = 5124\nvar GL_INT_VEC2 = 35667\nvar GL_INT_VEC3 = 35668\nvar GL_INT_VEC4 = 35669\nvar GL_BOOL = 35670\nvar GL_BOOL_VEC2 = 35671\nvar GL_BOOL_VEC3 = 35672\nvar GL_BOOL_VEC4 = 35673\nvar GL_FLOAT_MAT2 = 35674\nvar GL_FLOAT_MAT3 = 35675\nvar GL_FLOAT_MAT4 = 35676\nvar GL_SAMPLER_2D = 35678\nvar GL_SAMPLER_CUBE = 35680\n\nvar GL_TRIANGLES$1 = 4\n\nvar GL_FRONT = 1028\nvar GL_BACK = 1029\nvar GL_CW = 0x0900\nvar GL_CCW = 0x0901\nvar GL_MIN_EXT = 0x8007\nvar GL_MAX_EXT = 0x8008\nvar GL_ALWAYS = 519\nvar GL_KEEP = 7680\nvar GL_ZERO = 0\nvar GL_ONE = 1\nvar GL_FUNC_ADD = 0x8006\nvar GL_LESS = 513\n\nvar GL_FRAMEBUFFER$2 = 0x8D40\nvar GL_COLOR_ATTACHMENT0$2 = 0x8CE0\n\nvar blendFuncs = {\n '0': 0,\n '1': 1,\n 'zero': 0,\n 'one': 1,\n 'src color': 768,\n 'one minus src color': 769,\n 'src alpha': 770,\n 'one minus src alpha': 771,\n 'dst color': 774,\n 'one minus dst color': 775,\n 'dst alpha': 772,\n 'one minus dst alpha': 773,\n 'constant color': 32769,\n 'one minus constant color': 32770,\n 'constant alpha': 32771,\n 'one minus constant alpha': 32772,\n 'src alpha saturate': 776\n}\n\nvar compareFuncs = {\n 'never': 512,\n 'less': 513,\n '<': 513,\n 'equal': 514,\n '=': 514,\n '==': 514,\n '===': 514,\n 'lequal': 515,\n '<=': 515,\n 'greater': 516,\n '>': 516,\n 'notequal': 517,\n '!=': 517,\n '!==': 517,\n 'gequal': 518,\n '>=': 518,\n 'always': 519\n}\n\nvar stencilOps = {\n '0': 0,\n 'zero': 0,\n 'keep': 7680,\n 'replace': 7681,\n 'increment': 7682,\n 'decrement': 7683,\n 'increment wrap': 34055,\n 'decrement wrap': 34056,\n 'invert': 5386\n}\n\nvar orientationType = {\n 'cw': GL_CW,\n 'ccw': GL_CCW\n}\n\nfunction isBufferArgs (x) {\n return Array.isArray(x) ||\n isTypedArray(x) ||\n isNDArrayLike(x)\n}\n\n// Make sure viewport is processed first\nfunction sortState (state) {\n return state.sort(function (a, b) {\n if (a === S_VIEWPORT) {\n return -1\n } else if (b === S_VIEWPORT) {\n return 1\n }\n return (a < b) ? -1 : 1\n })\n}\n\nfunction Declaration (thisDep, contextDep, propDep, append) {\n this.thisDep = thisDep\n this.contextDep = contextDep\n this.propDep = propDep\n this.append = append\n}\n\nfunction isStatic (decl) {\n return decl && !(decl.thisDep || decl.contextDep || decl.propDep)\n}\n\nfunction createStaticDecl (append) {\n return new Declaration(false, false, false, append)\n}\n\nfunction createDynamicDecl (dyn, append) {\n var type = dyn.type\n if (type === DYN_FUNC$1) {\n var numArgs = dyn.data.length\n return new Declaration(\n true,\n numArgs >= 1,\n numArgs >= 2,\n append)\n } else if (type === DYN_THUNK) {\n var data = dyn.data\n return new Declaration(\n data.thisDep,\n data.contextDep,\n data.propDep,\n append)\n } else if (type === DYN_CONSTANT$1) {\n return new Declaration(\n false,\n false,\n false,\n append)\n } else if (type === DYN_ARRAY$1) {\n var thisDep = false\n var contextDep = false\n var propDep = false\n for (var i = 0; i < dyn.data.length; ++i) {\n var subDyn = dyn.data[i]\n if (subDyn.type === DYN_PROP$1) {\n propDep = true\n } else if (subDyn.type === DYN_CONTEXT$1) {\n contextDep = true\n } else if (subDyn.type === DYN_STATE$1) {\n thisDep = true\n } else if (subDyn.type === DYN_FUNC$1) {\n thisDep = true\n var subArgs = subDyn.data\n if (subArgs >= 1) {\n contextDep = true\n }\n if (subArgs >= 2) {\n propDep = true\n }\n } else if (subDyn.type === DYN_THUNK) {\n thisDep = thisDep || subDyn.data.thisDep\n contextDep = contextDep || subDyn.data.contextDep\n propDep = propDep || subDyn.data.propDep\n }\n }\n return new Declaration(\n thisDep,\n contextDep,\n propDep,\n append)\n } else {\n return new Declaration(\n type === DYN_STATE$1,\n type === DYN_CONTEXT$1,\n type === DYN_PROP$1,\n append)\n }\n}\n\nvar SCOPE_DECL = new Declaration(false, false, false, function () {})\n\nfunction reglCore (\n gl,\n stringStore,\n extensions,\n limits,\n bufferState,\n elementState,\n textureState,\n framebufferState,\n uniformState,\n attributeState,\n shaderState,\n drawState,\n contextState,\n timer,\n cachedCode,\n config) {\n var AttributeRecord = attributeState.Record\n\n var blendEquations = {\n 'add': 32774,\n 'subtract': 32778,\n 'reverse subtract': 32779\n }\n if (extensions.ext_blend_minmax) {\n blendEquations.min = GL_MIN_EXT\n blendEquations.max = GL_MAX_EXT\n }\n\n var extInstancing = extensions.angle_instanced_arrays\n var extDrawBuffers = extensions.webgl_draw_buffers\n var extVertexArrays = extensions.oes_vertex_array_object\n\n // ===================================================\n // ===================================================\n // WEBGL STATE\n // ===================================================\n // ===================================================\n var currentState = {\n dirty: true,\n profile: config.profile\n }\n var nextState = {}\n var GL_STATE_NAMES = []\n var GL_FLAGS = {}\n var GL_VARIABLES = {}\n\n function propName (name) {\n return name.replace('.', '_')\n }\n\n function stateFlag (sname, cap, init) {\n var name = propName(sname)\n GL_STATE_NAMES.push(sname)\n nextState[name] = currentState[name] = !!init\n GL_FLAGS[name] = cap\n }\n\n function stateVariable (sname, func, init) {\n var name = propName(sname)\n GL_STATE_NAMES.push(sname)\n if (Array.isArray(init)) {\n currentState[name] = init.slice()\n nextState[name] = init.slice()\n } else {\n currentState[name] = nextState[name] = init\n }\n GL_VARIABLES[name] = func\n }\n \n function hasVariableReference (exp) {\n if (!isNaN(exp)) {\n return false;\n }\n // strengthen this function if variable values can be non-(null/number) literals.\n return true;\n }\n\n // Dithering\n stateFlag(S_DITHER, GL_DITHER)\n\n // Blending\n stateFlag(S_BLEND_ENABLE, GL_BLEND)\n stateVariable(S_BLEND_COLOR, 'blendColor', [0, 0, 0, 0])\n stateVariable(S_BLEND_EQUATION, 'blendEquationSeparate',\n [GL_FUNC_ADD, GL_FUNC_ADD])\n stateVariable(S_BLEND_FUNC, 'blendFuncSeparate',\n [GL_ONE, GL_ZERO, GL_ONE, GL_ZERO])\n\n // Depth\n stateFlag(S_DEPTH_ENABLE, GL_DEPTH_TEST, true)\n stateVariable(S_DEPTH_FUNC, 'depthFunc', GL_LESS)\n stateVariable(S_DEPTH_RANGE, 'depthRange', [0, 1])\n stateVariable(S_DEPTH_MASK, 'depthMask', true)\n\n // Color mask\n stateVariable(S_COLOR_MASK, S_COLOR_MASK, [true, true, true, true])\n\n // Face culling\n stateFlag(S_CULL_ENABLE, GL_CULL_FACE)\n stateVariable(S_CULL_FACE, 'cullFace', GL_BACK)\n\n // Front face orientation\n stateVariable(S_FRONT_FACE, S_FRONT_FACE, GL_CCW)\n\n // Line width\n stateVariable(S_LINE_WIDTH, S_LINE_WIDTH, 1)\n\n // Polygon offset\n stateFlag(S_POLYGON_OFFSET_ENABLE, GL_POLYGON_OFFSET_FILL)\n stateVariable(S_POLYGON_OFFSET_OFFSET, 'polygonOffset', [0, 0])\n\n // Sample coverage\n stateFlag(S_SAMPLE_ALPHA, GL_SAMPLE_ALPHA_TO_COVERAGE)\n stateFlag(S_SAMPLE_ENABLE, GL_SAMPLE_COVERAGE)\n stateVariable(S_SAMPLE_COVERAGE, 'sampleCoverage', [1, false])\n\n // Stencil\n stateFlag(S_STENCIL_ENABLE, GL_STENCIL_TEST)\n stateVariable(S_STENCIL_MASK, 'stencilMask', -1)\n stateVariable(S_STENCIL_FUNC, 'stencilFunc', [GL_ALWAYS, 0, -1])\n stateVariable(S_STENCIL_OPFRONT, 'stencilOpSeparate',\n [GL_FRONT, GL_KEEP, GL_KEEP, GL_KEEP])\n stateVariable(S_STENCIL_OPBACK, 'stencilOpSeparate',\n [GL_BACK, GL_KEEP, GL_KEEP, GL_KEEP])\n\n // Scissor\n stateFlag(S_SCISSOR_ENABLE, GL_SCISSOR_TEST)\n stateVariable(S_SCISSOR_BOX, 'scissor',\n [0, 0, gl.drawingBufferWidth, gl.drawingBufferHeight])\n\n // Viewport\n stateVariable(S_VIEWPORT, S_VIEWPORT,\n [0, 0, gl.drawingBufferWidth, gl.drawingBufferHeight])\n\n // ===================================================\n // ===================================================\n // ENVIRONMENT\n // ===================================================\n // ===================================================\n var sharedState = {\n gl: gl,\n context: contextState,\n strings: stringStore,\n next: nextState,\n current: currentState,\n draw: drawState,\n elements: elementState,\n buffer: bufferState,\n shader: shaderState,\n attributes: attributeState.state,\n vao: attributeState,\n uniforms: uniformState,\n framebuffer: framebufferState,\n extensions: extensions,\n\n timer: timer,\n isBufferArgs: isBufferArgs\n }\n\n var sharedConstants = {\n primTypes: primTypes,\n compareFuncs: compareFuncs,\n blendFuncs: blendFuncs,\n blendEquations: blendEquations,\n stencilOps: stencilOps,\n glTypes: glTypes,\n orientationType: orientationType\n }\n\n \n\n if (extDrawBuffers) {\n sharedConstants.backBuffer = [GL_BACK]\n sharedConstants.drawBuffer = loop(limits.maxDrawbuffers, function (i) {\n if (i === 0) {\n return [0]\n }\n return loop(i, function (j) {\n return GL_COLOR_ATTACHMENT0$2 + j\n })\n })\n }\n\n var drawCallCounter = 0\n function createREGLEnvironment () {\n var env = createEnvironment({cache: cachedCode})\n var link = env.link\n var global = env.global\n env.id = drawCallCounter++\n\n env.batchId = '0'\n\n // link shared state\n var SHARED = link(sharedState)\n var shared = env.shared = {\n props: 'a0'\n }\n Object.keys(sharedState).forEach(function (prop) {\n shared[prop] = global.def(SHARED, '.', prop)\n })\n\n // Inject runtime assertion stuff for debug builds\n \n\n // Copy GL state variables over\n var nextVars = env.next = {}\n var currentVars = env.current = {}\n Object.keys(GL_VARIABLES).forEach(function (variable) {\n if (Array.isArray(currentState[variable])) {\n nextVars[variable] = global.def(shared.next, '.', variable)\n currentVars[variable] = global.def(shared.current, '.', variable)\n }\n })\n\n // Initialize shared constants\n var constants = env.constants = {}\n Object.keys(sharedConstants).forEach(function (name) {\n constants[name] = global.def(JSON.stringify(sharedConstants[name]))\n })\n\n // Helper function for calling a block\n env.invoke = function (block, x) {\n switch (x.type) {\n case DYN_FUNC$1:\n var argList = [\n 'this',\n shared.context,\n shared.props,\n env.batchId\n ]\n return block.def(\n link(x.data), '.call(',\n argList.slice(0, Math.max(x.data.length + 1, 4)),\n ')')\n case DYN_PROP$1:\n return block.def(shared.props, x.data)\n case DYN_CONTEXT$1:\n return block.def(shared.context, x.data)\n case DYN_STATE$1:\n return block.def('this', x.data)\n case DYN_THUNK:\n x.data.append(env, block)\n return x.data.ref\n case DYN_CONSTANT$1:\n return x.data.toString()\n case DYN_ARRAY$1:\n return x.data.map(function (y) {\n return env.invoke(block, y)\n })\n }\n }\n\n env.attribCache = {}\n\n var scopeAttribs = {}\n env.scopeAttrib = function (name) {\n var id = stringStore.id(name)\n if (id in scopeAttribs) {\n return scopeAttribs[id]\n }\n var binding = attributeState.scope[id]\n if (!binding) {\n binding = attributeState.scope[id] = new AttributeRecord()\n }\n var result = scopeAttribs[id] = link(binding)\n return result\n }\n\n return env\n }\n\n // ===================================================\n // ===================================================\n // PARSING\n // ===================================================\n // ===================================================\n function parseProfile (options) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n\n var profileEnable\n if (S_PROFILE in staticOptions) {\n var value = !!staticOptions[S_PROFILE]\n profileEnable = createStaticDecl(function (env, scope) {\n return value\n })\n profileEnable.enable = value\n } else if (S_PROFILE in dynamicOptions) {\n var dyn = dynamicOptions[S_PROFILE]\n profileEnable = createDynamicDecl(dyn, function (env, scope) {\n return env.invoke(scope, dyn)\n })\n }\n\n return profileEnable\n }\n\n function parseFramebuffer (options, env) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n\n if (S_FRAMEBUFFER in staticOptions) {\n var framebuffer = staticOptions[S_FRAMEBUFFER]\n if (framebuffer) {\n framebuffer = framebufferState.getFramebuffer(framebuffer)\n \n return createStaticDecl(function (env, block) {\n var FRAMEBUFFER = env.link(framebuffer)\n var shared = env.shared\n block.set(\n shared.framebuffer,\n '.next',\n FRAMEBUFFER)\n var CONTEXT = shared.context\n block.set(\n CONTEXT,\n '.' + S_FRAMEBUFFER_WIDTH,\n FRAMEBUFFER + '.width')\n block.set(\n CONTEXT,\n '.' + S_FRAMEBUFFER_HEIGHT,\n FRAMEBUFFER + '.height')\n return FRAMEBUFFER\n })\n } else {\n return createStaticDecl(function (env, scope) {\n var shared = env.shared\n scope.set(\n shared.framebuffer,\n '.next',\n 'null')\n var CONTEXT = shared.context\n scope.set(\n CONTEXT,\n '.' + S_FRAMEBUFFER_WIDTH,\n CONTEXT + '.' + S_DRAWINGBUFFER_WIDTH)\n scope.set(\n CONTEXT,\n '.' + S_FRAMEBUFFER_HEIGHT,\n CONTEXT + '.' + S_DRAWINGBUFFER_HEIGHT)\n return 'null'\n })\n }\n } else if (S_FRAMEBUFFER in dynamicOptions) {\n var dyn = dynamicOptions[S_FRAMEBUFFER]\n return createDynamicDecl(dyn, function (env, scope) {\n var FRAMEBUFFER_FUNC = env.invoke(scope, dyn)\n var shared = env.shared\n var FRAMEBUFFER_STATE = shared.framebuffer\n var FRAMEBUFFER = scope.def(\n FRAMEBUFFER_STATE, '.getFramebuffer(', FRAMEBUFFER_FUNC, ')')\n\n \n\n scope.set(\n FRAMEBUFFER_STATE,\n '.next',\n FRAMEBUFFER)\n var CONTEXT = shared.context\n scope.set(\n CONTEXT,\n '.' + S_FRAMEBUFFER_WIDTH,\n FRAMEBUFFER + '?' + FRAMEBUFFER + '.width:' +\n CONTEXT + '.' + S_DRAWINGBUFFER_WIDTH)\n scope.set(\n CONTEXT,\n '.' + S_FRAMEBUFFER_HEIGHT,\n FRAMEBUFFER +\n '?' + FRAMEBUFFER + '.height:' +\n CONTEXT + '.' + S_DRAWINGBUFFER_HEIGHT)\n return FRAMEBUFFER\n })\n } else {\n return null\n }\n }\n\n function parseViewportScissor (options, framebuffer, env) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n\n function parseBox (param) {\n if (param in staticOptions) {\n var box = staticOptions[param]\n \n\n var isStatic = true\n var x = box.x | 0\n var y = box.y | 0\n var w, h\n if ('width' in box) {\n w = box.width | 0\n \n } else {\n isStatic = false\n }\n if ('height' in box) {\n h = box.height | 0\n \n } else {\n isStatic = false\n }\n\n return new Declaration(\n !isStatic && framebuffer && framebuffer.thisDep,\n !isStatic && framebuffer && framebuffer.contextDep,\n !isStatic && framebuffer && framebuffer.propDep,\n function (env, scope) {\n var CONTEXT = env.shared.context\n var BOX_W = w\n if (!('width' in box)) {\n BOX_W = scope.def(CONTEXT, '.', S_FRAMEBUFFER_WIDTH, '-', x)\n }\n var BOX_H = h\n if (!('height' in box)) {\n BOX_H = scope.def(CONTEXT, '.', S_FRAMEBUFFER_HEIGHT, '-', y)\n }\n return [x, y, BOX_W, BOX_H]\n })\n } else if (param in dynamicOptions) {\n var dynBox = dynamicOptions[param]\n var result = createDynamicDecl(dynBox, function (env, scope) {\n var BOX = env.invoke(scope, dynBox)\n\n \n\n var CONTEXT = env.shared.context\n var BOX_X = scope.def(BOX, '.x|0')\n var BOX_Y = scope.def(BOX, '.y|0')\n var BOX_W = scope.def(\n '\"width\" in ', BOX, '?', BOX, '.width|0:',\n '(', CONTEXT, '.', S_FRAMEBUFFER_WIDTH, '-', BOX_X, ')')\n var BOX_H = scope.def(\n '\"height\" in ', BOX, '?', BOX, '.height|0:',\n '(', CONTEXT, '.', S_FRAMEBUFFER_HEIGHT, '-', BOX_Y, ')')\n\n \n\n return [BOX_X, BOX_Y, BOX_W, BOX_H]\n })\n if (framebuffer) {\n result.thisDep = result.thisDep || framebuffer.thisDep\n result.contextDep = result.contextDep || framebuffer.contextDep\n result.propDep = result.propDep || framebuffer.propDep\n }\n return result\n } else if (framebuffer) {\n return new Declaration(\n framebuffer.thisDep,\n framebuffer.contextDep,\n framebuffer.propDep,\n function (env, scope) {\n var CONTEXT = env.shared.context\n return [\n 0, 0,\n scope.def(CONTEXT, '.', S_FRAMEBUFFER_WIDTH),\n scope.def(CONTEXT, '.', S_FRAMEBUFFER_HEIGHT)]\n })\n } else {\n return null\n }\n }\n\n var viewport = parseBox(S_VIEWPORT)\n\n if (viewport) {\n var prevViewport = viewport\n viewport = new Declaration(\n viewport.thisDep,\n viewport.contextDep,\n viewport.propDep,\n function (env, scope) {\n var VIEWPORT = prevViewport.append(env, scope)\n var CONTEXT = env.shared.context\n scope.set(\n CONTEXT,\n '.' + S_VIEWPORT_WIDTH,\n VIEWPORT[2])\n scope.set(\n CONTEXT,\n '.' + S_VIEWPORT_HEIGHT,\n VIEWPORT[3])\n return VIEWPORT\n })\n }\n\n return {\n viewport: viewport,\n scissor_box: parseBox(S_SCISSOR_BOX)\n }\n }\n\n function parseAttribLocations (options, attributes) {\n var staticOptions = options.static\n var staticProgram =\n typeof staticOptions[S_FRAG] === 'string' &&\n typeof staticOptions[S_VERT] === 'string'\n if (staticProgram) {\n if (Object.keys(attributes.dynamic).length > 0) {\n return null\n }\n var staticAttributes = attributes.static\n var sAttributes = Object.keys(staticAttributes)\n if (sAttributes.length > 0 && typeof staticAttributes[sAttributes[0]] === 'number') {\n var bindings = []\n for (var i = 0; i < sAttributes.length; ++i) {\n \n bindings.push([staticAttributes[sAttributes[i]] | 0, sAttributes[i]])\n }\n return bindings\n }\n }\n return null\n }\n\n function parseProgram (options, env, attribLocations) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n\n function parseShader (name) {\n if (name in staticOptions) {\n var id = stringStore.id(staticOptions[name])\n \n var result = createStaticDecl(function () {\n return id\n })\n result.id = id\n return result\n } else if (name in dynamicOptions) {\n var dyn = dynamicOptions[name]\n return createDynamicDecl(dyn, function (env, scope) {\n var str = env.invoke(scope, dyn)\n var id = scope.def(env.shared.strings, '.id(', str, ')')\n \n return id\n })\n }\n return null\n }\n\n var frag = parseShader(S_FRAG)\n var vert = parseShader(S_VERT)\n\n var program = null\n var progVar\n if (isStatic(frag) && isStatic(vert)) {\n program = shaderState.program(vert.id, frag.id, null, attribLocations)\n progVar = createStaticDecl(function (env, scope) {\n return env.link(program)\n })\n } else {\n progVar = new Declaration(\n (frag && frag.thisDep) || (vert && vert.thisDep),\n (frag && frag.contextDep) || (vert && vert.contextDep),\n (frag && frag.propDep) || (vert && vert.propDep),\n function (env, scope) {\n var SHADER_STATE = env.shared.shader\n var fragId\n if (frag) {\n fragId = frag.append(env, scope)\n } else {\n fragId = scope.def(SHADER_STATE, '.', S_FRAG)\n }\n var vertId\n if (vert) {\n vertId = vert.append(env, scope)\n } else {\n vertId = scope.def(SHADER_STATE, '.', S_VERT)\n }\n var progDef = SHADER_STATE + '.program(' + vertId + ',' + fragId\n \n return scope.def(progDef + ')')\n })\n }\n\n return {\n frag: frag,\n vert: vert,\n progVar: progVar,\n program: program\n }\n }\n\n function parseDraw (options, env) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n\n // TODO: should use VAO to get default values for offset properties\n // should move vao parse into here and out of the old stuff\n\n var staticDraw = {}\n var vaoActive = false\n\n function parseVAO () {\n if (S_VAO in staticOptions) {\n var vao = staticOptions[S_VAO]\n if (vao !== null && attributeState.getVAO(vao) === null) {\n vao = attributeState.createVAO(vao)\n }\n\n vaoActive = true\n staticDraw.vao = vao\n\n return createStaticDecl(function (env) {\n var vaoRef = attributeState.getVAO(vao)\n if (vaoRef) {\n return env.link(vaoRef)\n } else {\n return 'null'\n }\n })\n } else if (S_VAO in dynamicOptions) {\n vaoActive = true\n var dyn = dynamicOptions[S_VAO]\n return createDynamicDecl(dyn, function (env, scope) {\n var vaoRef = env.invoke(scope, dyn)\n return scope.def(env.shared.vao + '.getVAO(' + vaoRef + ')')\n })\n }\n return null\n }\n\n var vao = parseVAO()\n\n var elementsActive = false\n\n function parseElements () {\n if (S_ELEMENTS in staticOptions) {\n var elements = staticOptions[S_ELEMENTS]\n staticDraw.elements = elements\n if (isBufferArgs(elements)) {\n var e = staticDraw.elements = elementState.create(elements, true)\n elements = elementState.getElements(e)\n elementsActive = true\n } else if (elements) {\n elements = elementState.getElements(elements)\n elementsActive = true\n \n }\n\n var result = createStaticDecl(function (env, scope) {\n if (elements) {\n var result = env.link(elements)\n env.ELEMENTS = result\n return result\n }\n env.ELEMENTS = null\n return null\n })\n result.value = elements\n return result\n } else if (S_ELEMENTS in dynamicOptions) {\n elementsActive = true\n\n var dyn = dynamicOptions[S_ELEMENTS]\n return createDynamicDecl(dyn, function (env, scope) {\n var shared = env.shared\n\n var IS_BUFFER_ARGS = shared.isBufferArgs\n var ELEMENT_STATE = shared.elements\n\n var elementDefn = env.invoke(scope, dyn)\n var elements = scope.def('null')\n var elementStream = scope.def(IS_BUFFER_ARGS, '(', elementDefn, ')')\n\n var ifte = env.cond(elementStream)\n .then(elements, '=', ELEMENT_STATE, '.createStream(', elementDefn, ');')\n .else(elements, '=', ELEMENT_STATE, '.getElements(', elementDefn, ');')\n\n \n\n scope.entry(ifte)\n scope.exit(\n env.cond(elementStream)\n .then(ELEMENT_STATE, '.destroyStream(', elements, ');'))\n\n env.ELEMENTS = elements\n\n return elements\n })\n } else if (vaoActive) {\n return new Declaration(\n vao.thisDep,\n vao.contextDep,\n vao.propDep,\n function (env, scope) {\n return scope.def(env.shared.vao + '.currentVAO?' + env.shared.elements + '.getElements(' + env.shared.vao + '.currentVAO.elements):null')\n })\n }\n return null\n }\n\n var elements = parseElements()\n\n function parsePrimitive () {\n if (S_PRIMITIVE in staticOptions) {\n var primitive = staticOptions[S_PRIMITIVE]\n staticDraw.primitive = primitive\n \n return createStaticDecl(function (env, scope) {\n return primTypes[primitive]\n })\n } else if (S_PRIMITIVE in dynamicOptions) {\n var dynPrimitive = dynamicOptions[S_PRIMITIVE]\n return createDynamicDecl(dynPrimitive, function (env, scope) {\n var PRIM_TYPES = env.constants.primTypes\n var prim = env.invoke(scope, dynPrimitive)\n \n return scope.def(PRIM_TYPES, '[', prim, ']')\n })\n } else if (elementsActive) {\n if (isStatic(elements)) {\n if (elements.value) {\n return createStaticDecl(function (env, scope) {\n return scope.def(env.ELEMENTS, '.primType')\n })\n } else {\n return createStaticDecl(function () {\n return GL_TRIANGLES$1\n })\n }\n } else {\n return new Declaration(\n elements.thisDep,\n elements.contextDep,\n elements.propDep,\n function (env, scope) {\n var elements = env.ELEMENTS\n return scope.def(elements, '?', elements, '.primType:', GL_TRIANGLES$1)\n })\n }\n } else if (vaoActive) {\n return new Declaration(\n vao.thisDep,\n vao.contextDep,\n vao.propDep,\n function (env, scope) {\n return scope.def(env.shared.vao + '.currentVAO?' + env.shared.vao + '.currentVAO.primitive:' + GL_TRIANGLES$1)\n })\n }\n return null\n }\n\n function parseParam (param, isOffset) {\n if (param in staticOptions) {\n var value = staticOptions[param] | 0\n if (isOffset) {\n staticDraw.offset = value\n } else {\n staticDraw.instances = value\n }\n \n return createStaticDecl(function (env, scope) {\n if (isOffset) {\n env.OFFSET = value\n }\n return value\n })\n } else if (param in dynamicOptions) {\n var dynValue = dynamicOptions[param]\n return createDynamicDecl(dynValue, function (env, scope) {\n var result = env.invoke(scope, dynValue)\n if (isOffset) {\n env.OFFSET = result\n \n }\n return result\n })\n } else if (isOffset) {\n if (elementsActive) {\n return createStaticDecl(function (env, scope) {\n env.OFFSET = 0\n return 0\n })\n } else if (vaoActive) {\n return new Declaration(\n vao.thisDep,\n vao.contextDep,\n vao.propDep,\n function (env, scope) {\n return scope.def(env.shared.vao + '.currentVAO?' + env.shared.vao + '.currentVAO.offset:0')\n })\n }\n } else if (vaoActive) {\n return new Declaration(\n vao.thisDep,\n vao.contextDep,\n vao.propDep,\n function (env, scope) {\n return scope.def(env.shared.vao + '.currentVAO?' + env.shared.vao + '.currentVAO.instances:-1')\n })\n }\n return null\n }\n\n var OFFSET = parseParam(S_OFFSET, true)\n\n function parseVertCount () {\n if (S_COUNT in staticOptions) {\n var count = staticOptions[S_COUNT] | 0\n staticDraw.count = count\n \n return createStaticDecl(function () {\n return count\n })\n } else if (S_COUNT in dynamicOptions) {\n var dynCount = dynamicOptions[S_COUNT]\n return createDynamicDecl(dynCount, function (env, scope) {\n var result = env.invoke(scope, dynCount)\n \n return result\n })\n } else if (elementsActive) {\n if (isStatic(elements)) {\n if (elements) {\n if (OFFSET) {\n return new Declaration(\n OFFSET.thisDep,\n OFFSET.contextDep,\n OFFSET.propDep,\n function (env, scope) {\n var result = scope.def(\n env.ELEMENTS, '.vertCount-', env.OFFSET)\n\n \n\n return result\n })\n } else {\n return createStaticDecl(function (env, scope) {\n return scope.def(env.ELEMENTS, '.vertCount')\n })\n }\n } else {\n var result = createStaticDecl(function () {\n return -1\n })\n \n return result\n }\n } else {\n var variable = new Declaration(\n elements.thisDep || OFFSET.thisDep,\n elements.contextDep || OFFSET.contextDep,\n elements.propDep || OFFSET.propDep,\n function (env, scope) {\n var elements = env.ELEMENTS\n if (env.OFFSET) {\n return scope.def(elements, '?', elements, '.vertCount-',\n env.OFFSET, ':-1')\n }\n return scope.def(elements, '?', elements, '.vertCount:-1')\n })\n \n return variable\n }\n } else if (vaoActive) {\n var countVariable = new Declaration(\n vao.thisDep,\n vao.contextDep,\n vao.propDep,\n function (env, scope) {\n return scope.def(env.shared.vao, '.currentVAO?', env.shared.vao, '.currentVAO.count:-1')\n })\n return countVariable\n }\n return null\n }\n\n var primitive = parsePrimitive()\n var count = parseVertCount()\n var instances = parseParam(S_INSTANCES, false)\n\n return {\n elements: elements,\n primitive: primitive,\n count: count,\n instances: instances,\n offset: OFFSET,\n vao: vao,\n\n vaoActive: vaoActive,\n elementsActive: elementsActive,\n\n // static draw props\n static: staticDraw\n }\n }\n\n function parseGLState (options, env) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n\n var STATE = {}\n\n GL_STATE_NAMES.forEach(function (prop) {\n var param = propName(prop)\n\n function parseParam (parseStatic, parseDynamic) {\n if (prop in staticOptions) {\n var value = parseStatic(staticOptions[prop])\n STATE[param] = createStaticDecl(function () {\n return value\n })\n } else if (prop in dynamicOptions) {\n var dyn = dynamicOptions[prop]\n STATE[param] = createDynamicDecl(dyn, function (env, scope) {\n return parseDynamic(env, scope, env.invoke(scope, dyn))\n })\n }\n }\n\n switch (prop) {\n case S_CULL_ENABLE:\n case S_BLEND_ENABLE:\n case S_DITHER:\n case S_STENCIL_ENABLE:\n case S_DEPTH_ENABLE:\n case S_SCISSOR_ENABLE:\n case S_POLYGON_OFFSET_ENABLE:\n case S_SAMPLE_ALPHA:\n case S_SAMPLE_ENABLE:\n case S_DEPTH_MASK:\n return parseParam(\n function (value) {\n \n return value\n },\n function (env, scope, value) {\n \n return value\n })\n\n case S_DEPTH_FUNC:\n return parseParam(\n function (value) {\n \n return compareFuncs[value]\n },\n function (env, scope, value) {\n var COMPARE_FUNCS = env.constants.compareFuncs\n \n return scope.def(COMPARE_FUNCS, '[', value, ']')\n })\n\n case S_DEPTH_RANGE:\n return parseParam(\n function (value) {\n \n return value\n },\n function (env, scope, value) {\n \n\n var Z_NEAR = scope.def('+', value, '[0]')\n var Z_FAR = scope.def('+', value, '[1]')\n return [Z_NEAR, Z_FAR]\n })\n\n case S_BLEND_FUNC:\n return parseParam(\n function (value) {\n \n var srcRGB = ('srcRGB' in value ? value.srcRGB : value.src)\n var srcAlpha = ('srcAlpha' in value ? value.srcAlpha : value.src)\n var dstRGB = ('dstRGB' in value ? value.dstRGB : value.dst)\n var dstAlpha = ('dstAlpha' in value ? value.dstAlpha : value.dst)\n \n \n \n \n\n \n\n return [\n blendFuncs[srcRGB],\n blendFuncs[dstRGB],\n blendFuncs[srcAlpha],\n blendFuncs[dstAlpha]\n ]\n },\n function (env, scope, value) {\n var BLEND_FUNCS = env.constants.blendFuncs\n\n \n\n function read (prefix, suffix) {\n var func = scope.def(\n '\"', prefix, suffix, '\" in ', value,\n '?', value, '.', prefix, suffix,\n ':', value, '.', prefix)\n\n \n\n return func\n }\n\n var srcRGB = read('src', 'RGB')\n var dstRGB = read('dst', 'RGB')\n\n \n\n var SRC_RGB = scope.def(BLEND_FUNCS, '[', srcRGB, ']')\n var SRC_ALPHA = scope.def(BLEND_FUNCS, '[', read('src', 'Alpha'), ']')\n var DST_RGB = scope.def(BLEND_FUNCS, '[', dstRGB, ']')\n var DST_ALPHA = scope.def(BLEND_FUNCS, '[', read('dst', 'Alpha'), ']')\n\n return [SRC_RGB, DST_RGB, SRC_ALPHA, DST_ALPHA]\n })\n\n case S_BLEND_EQUATION:\n return parseParam(\n function (value) {\n if (typeof value === 'string') {\n \n return [\n blendEquations[value],\n blendEquations[value]\n ]\n } else if (typeof value === 'object') {\n \n \n return [\n blendEquations[value.rgb],\n blendEquations[value.alpha]\n ]\n } else {\n \n }\n },\n function (env, scope, value) {\n var BLEND_EQUATIONS = env.constants.blendEquations\n\n var RGB = scope.def()\n var ALPHA = scope.def()\n\n var ifte = env.cond('typeof ', value, '===\"string\"')\n\n \n\n ifte.then(\n RGB, '=', ALPHA, '=', BLEND_EQUATIONS, '[', value, '];')\n ifte.else(\n RGB, '=', BLEND_EQUATIONS, '[', value, '.rgb];',\n ALPHA, '=', BLEND_EQUATIONS, '[', value, '.alpha];')\n\n scope(ifte)\n\n return [RGB, ALPHA]\n })\n\n case S_BLEND_COLOR:\n return parseParam(\n function (value) {\n \n return loop(4, function (i) {\n return +value[i]\n })\n },\n function (env, scope, value) {\n \n return loop(4, function (i) {\n return scope.def('+', value, '[', i, ']')\n })\n })\n\n case S_STENCIL_MASK:\n return parseParam(\n function (value) {\n \n return value | 0\n },\n function (env, scope, value) {\n \n return scope.def(value, '|0')\n })\n\n case S_STENCIL_FUNC:\n return parseParam(\n function (value) {\n \n var cmp = value.cmp || 'keep'\n var ref = value.ref || 0\n var mask = 'mask' in value ? value.mask : -1\n \n \n \n return [\n compareFuncs[cmp],\n ref,\n mask\n ]\n },\n function (env, scope, value) {\n var COMPARE_FUNCS = env.constants.compareFuncs\n \n var cmp = scope.def(\n '\"cmp\" in ', value,\n '?', COMPARE_FUNCS, '[', value, '.cmp]',\n ':', GL_KEEP)\n var ref = scope.def(value, '.ref|0')\n var mask = scope.def(\n '\"mask\" in ', value,\n '?', value, '.mask|0:-1')\n return [cmp, ref, mask]\n })\n\n case S_STENCIL_OPFRONT:\n case S_STENCIL_OPBACK:\n return parseParam(\n function (value) {\n \n var fail = value.fail || 'keep'\n var zfail = value.zfail || 'keep'\n var zpass = value.zpass || 'keep'\n \n \n \n return [\n prop === S_STENCIL_OPBACK ? GL_BACK : GL_FRONT,\n stencilOps[fail],\n stencilOps[zfail],\n stencilOps[zpass]\n ]\n },\n function (env, scope, value) {\n var STENCIL_OPS = env.constants.stencilOps\n\n \n\n function read (name) {\n \n\n return scope.def(\n '\"', name, '\" in ', value,\n '?', STENCIL_OPS, '[', value, '.', name, ']:',\n GL_KEEP)\n }\n\n return [\n prop === S_STENCIL_OPBACK ? GL_BACK : GL_FRONT,\n read('fail'),\n read('zfail'),\n read('zpass')\n ]\n })\n\n case S_POLYGON_OFFSET_OFFSET:\n return parseParam(\n function (value) {\n \n var factor = value.factor | 0\n var units = value.units | 0\n \n \n return [factor, units]\n },\n function (env, scope, value) {\n \n\n var FACTOR = scope.def(value, '.factor|0')\n var UNITS = scope.def(value, '.units|0')\n\n return [FACTOR, UNITS]\n })\n\n case S_CULL_FACE:\n return parseParam(\n function (value) {\n var face = 0\n if (value === 'front') {\n face = GL_FRONT\n } else if (value === 'back') {\n face = GL_BACK\n }\n \n return face\n },\n function (env, scope, value) {\n \n return scope.def(value, '===\"front\"?', GL_FRONT, ':', GL_BACK)\n })\n\n case S_LINE_WIDTH:\n return parseParam(\n function (value) {\n \n return value\n },\n function (env, scope, value) {\n \n\n return value\n })\n\n case S_FRONT_FACE:\n return parseParam(\n function (value) {\n \n return orientationType[value]\n },\n function (env, scope, value) {\n \n return scope.def(value + '===\"cw\"?' + GL_CW + ':' + GL_CCW)\n })\n\n case S_COLOR_MASK:\n return parseParam(\n function (value) {\n \n return value.map(function (v) { return !!v })\n },\n function (env, scope, value) {\n \n return loop(4, function (i) {\n return '!!' + value + '[' + i + ']'\n })\n })\n\n case S_SAMPLE_COVERAGE:\n return parseParam(\n function (value) {\n \n var sampleValue = 'value' in value ? value.value : 1\n var sampleInvert = !!value.invert\n \n return [sampleValue, sampleInvert]\n },\n function (env, scope, value) {\n \n var VALUE = scope.def(\n '\"value\" in ', value, '?+', value, '.value:1')\n var INVERT = scope.def('!!', value, '.invert')\n return [VALUE, INVERT]\n })\n }\n })\n\n return STATE\n }\n\n function parseUniforms (uniforms, env) {\n var staticUniforms = uniforms.static\n var dynamicUniforms = uniforms.dynamic\n\n var UNIFORMS = {}\n\n Object.keys(staticUniforms).forEach(function (name) {\n var value = staticUniforms[name]\n var result\n if (typeof value === 'number' ||\n typeof value === 'boolean') {\n result = createStaticDecl(function () {\n return value\n })\n } else if (typeof value === 'function') {\n var reglType = value._reglType\n if (reglType === 'texture2d' ||\n reglType === 'textureCube') {\n result = createStaticDecl(function (env) {\n return env.link(value)\n })\n } else if (reglType === 'framebuffer' ||\n reglType === 'framebufferCube') {\n \n result = createStaticDecl(function (env) {\n return env.link(value.color[0])\n })\n } else {\n \n }\n } else if (isArrayLike(value)) {\n result = createStaticDecl(function (env) {\n var ITEM = env.global.def('[',\n loop(value.length, function (i) {\n \n return value[i]\n }), ']')\n return ITEM\n })\n } else {\n \n }\n result.value = value\n UNIFORMS[name] = result\n })\n\n Object.keys(dynamicUniforms).forEach(function (key) {\n var dyn = dynamicUniforms[key]\n UNIFORMS[key] = createDynamicDecl(dyn, function (env, scope) {\n return env.invoke(scope, dyn)\n })\n })\n\n return UNIFORMS\n }\n\n function parseAttributes (attributes, env) {\n var staticAttributes = attributes.static\n var dynamicAttributes = attributes.dynamic\n\n var attributeDefs = {}\n\n Object.keys(staticAttributes).forEach(function (attribute) {\n var value = staticAttributes[attribute]\n var id = stringStore.id(attribute)\n\n var record = new AttributeRecord()\n if (isBufferArgs(value)) {\n record.state = ATTRIB_STATE_POINTER\n record.buffer = bufferState.getBuffer(\n bufferState.create(value, GL_ARRAY_BUFFER$2, false, true))\n record.type = 0\n } else {\n var buffer = bufferState.getBuffer(value)\n if (buffer) {\n record.state = ATTRIB_STATE_POINTER\n record.buffer = buffer\n record.type = 0\n } else {\n \n if ('constant' in value) {\n var constant = value.constant\n record.buffer = 'null'\n record.state = ATTRIB_STATE_CONSTANT\n if (typeof constant === 'number') {\n record.x = constant\n } else {\n \n CUTE_COMPONENTS.forEach(function (c, i) {\n if (i < constant.length) {\n record[c] = constant[i]\n }\n })\n }\n } else {\n if (isBufferArgs(value.buffer)) {\n buffer = bufferState.getBuffer(\n bufferState.create(value.buffer, GL_ARRAY_BUFFER$2, false, true))\n } else {\n buffer = bufferState.getBuffer(value.buffer)\n }\n \n\n var offset = value.offset | 0\n \n\n var stride = value.stride | 0\n \n\n var size = value.size | 0\n \n\n var normalized = !!value.normalized\n\n var type = 0\n if ('type' in value) {\n \n type = glTypes[value.type]\n }\n\n var divisor = value.divisor | 0\n \n\n record.buffer = buffer\n record.state = ATTRIB_STATE_POINTER\n record.size = size\n record.normalized = normalized\n record.type = type || buffer.dtype\n record.offset = offset\n record.stride = stride\n record.divisor = divisor\n }\n }\n }\n\n attributeDefs[attribute] = createStaticDecl(function (env, scope) {\n var cache = env.attribCache\n if (id in cache) {\n return cache[id]\n }\n var result = {\n isStream: false\n }\n Object.keys(record).forEach(function (key) {\n result[key] = record[key]\n })\n if (record.buffer) {\n result.buffer = env.link(record.buffer)\n result.type = result.type || (result.buffer + '.dtype')\n }\n cache[id] = result\n return result\n })\n })\n\n Object.keys(dynamicAttributes).forEach(function (attribute) {\n var dyn = dynamicAttributes[attribute]\n\n function appendAttributeCode (env, block) {\n var VALUE = env.invoke(block, dyn)\n\n var shared = env.shared\n var constants = env.constants\n\n var IS_BUFFER_ARGS = shared.isBufferArgs\n var BUFFER_STATE = shared.buffer\n\n // Perform validation on attribute\n \n\n // allocate names for result\n var result = {\n isStream: block.def(false)\n }\n var defaultRecord = new AttributeRecord()\n defaultRecord.state = ATTRIB_STATE_POINTER\n Object.keys(defaultRecord).forEach(function (key) {\n result[key] = block.def('' + defaultRecord[key])\n })\n\n var BUFFER = result.buffer\n var TYPE = result.type\n block(\n 'if(', IS_BUFFER_ARGS, '(', VALUE, ')){',\n result.isStream, '=true;',\n BUFFER, '=', BUFFER_STATE, '.createStream(', GL_ARRAY_BUFFER$2, ',', VALUE, ');',\n TYPE, '=', BUFFER, '.dtype;',\n '}else{',\n BUFFER, '=', BUFFER_STATE, '.getBuffer(', VALUE, ');',\n 'if(', BUFFER, '){',\n TYPE, '=', BUFFER, '.dtype;',\n '}else if(\"constant\" in ', VALUE, '){',\n result.state, '=', ATTRIB_STATE_CONSTANT, ';',\n 'if(typeof ' + VALUE + '.constant === \"number\"){',\n result[CUTE_COMPONENTS[0]], '=', VALUE, '.constant;',\n CUTE_COMPONENTS.slice(1).map(function (n) {\n return result[n]\n }).join('='), '=0;',\n '}else{',\n CUTE_COMPONENTS.map(function (name, i) {\n return (\n result[name] + '=' + VALUE + '.constant.length>' + i +\n '?' + VALUE + '.constant[' + i + ']:0;'\n )\n }).join(''),\n '}}else{',\n 'if(', IS_BUFFER_ARGS, '(', VALUE, '.buffer)){',\n BUFFER, '=', BUFFER_STATE, '.createStream(', GL_ARRAY_BUFFER$2, ',', VALUE, '.buffer);',\n '}else{',\n BUFFER, '=', BUFFER_STATE, '.getBuffer(', VALUE, '.buffer);',\n '}',\n TYPE, '=\"type\" in ', VALUE, '?',\n constants.glTypes, '[', VALUE, '.type]:', BUFFER, '.dtype;',\n result.normalized, '=!!', VALUE, '.normalized;')\n function emitReadRecord (name) {\n block(result[name], '=', VALUE, '.', name, '|0;')\n }\n emitReadRecord('size')\n emitReadRecord('offset')\n emitReadRecord('stride')\n emitReadRecord('divisor')\n\n block('}}')\n\n block.exit(\n 'if(', result.isStream, '){',\n BUFFER_STATE, '.destroyStream(', BUFFER, ');',\n '}')\n\n return result\n }\n\n attributeDefs[attribute] = createDynamicDecl(dyn, appendAttributeCode)\n })\n\n return attributeDefs\n }\n\n function parseContext (context) {\n var staticContext = context.static\n var dynamicContext = context.dynamic\n var result = {}\n\n Object.keys(staticContext).forEach(function (name) {\n var value = staticContext[name]\n result[name] = createStaticDecl(function (env, scope) {\n if (typeof value === 'number' || typeof value === 'boolean') {\n return '' + value\n } else {\n return env.link(value)\n }\n })\n })\n\n Object.keys(dynamicContext).forEach(function (name) {\n var dyn = dynamicContext[name]\n result[name] = createDynamicDecl(dyn, function (env, scope) {\n return env.invoke(scope, dyn)\n })\n })\n\n return result\n }\n\n function parseArguments (options, attributes, uniforms, context, env) {\n var staticOptions = options.static\n var dynamicOptions = options.dynamic\n\n \n\n var attribLocations = parseAttribLocations(options, attributes)\n\n var framebuffer = parseFramebuffer(options, env)\n var viewportAndScissor = parseViewportScissor(options, framebuffer, env)\n var draw = parseDraw(options, env)\n var state = parseGLState(options, env)\n var shader = parseProgram(options, env, attribLocations)\n\n function copyBox (name) {\n var defn = viewportAndScissor[name]\n if (defn) {\n state[name] = defn\n }\n }\n copyBox(S_VIEWPORT)\n copyBox(propName(S_SCISSOR_BOX))\n\n var dirty = Object.keys(state).length > 0\n\n var result = {\n framebuffer: framebuffer,\n draw: draw,\n shader: shader,\n state: state,\n dirty: dirty,\n scopeVAO: null,\n drawVAO: null,\n useVAO: false,\n attributes: {}\n }\n\n result.profile = parseProfile(options, env)\n result.uniforms = parseUniforms(uniforms, env)\n result.drawVAO = result.scopeVAO = draw.vao\n // special case: check if we can statically allocate a vertex array object for this program\n if (!result.drawVAO &&\n shader.program &&\n !attribLocations &&\n extensions.angle_instanced_arrays &&\n draw.static.elements) {\n var useVAO = true\n var staticBindings = shader.program.attributes.map(function (attr) {\n var binding = attributes.static[attr]\n useVAO = useVAO && !!binding\n return binding\n })\n if (useVAO && staticBindings.length > 0) {\n var vao = attributeState.getVAO(attributeState.createVAO({\n attributes: staticBindings,\n elements: draw.static.elements\n }))\n result.drawVAO = new Declaration(null, null, null, function (env, scope) {\n return env.link(vao)\n })\n result.useVAO = true\n }\n }\n if (attribLocations) {\n result.useVAO = true\n } else {\n result.attributes = parseAttributes(attributes, env)\n }\n result.context = parseContext(context, env)\n return result\n }\n\n // ===================================================\n // ===================================================\n // COMMON UPDATE FUNCTIONS\n // ===================================================\n // ===================================================\n function emitContext (env, scope, context) {\n var shared = env.shared\n var CONTEXT = shared.context\n\n var contextEnter = env.scope()\n\n Object.keys(context).forEach(function (name) {\n scope.save(CONTEXT, '.' + name)\n var defn = context[name]\n var value = defn.append(env, scope)\n if (Array.isArray(value)) {\n contextEnter(CONTEXT, '.', name, '=[', value.join(), '];')\n } else {\n contextEnter(CONTEXT, '.', name, '=', value, ';')\n }\n })\n\n scope(contextEnter)\n }\n\n // ===================================================\n // ===================================================\n // COMMON DRAWING FUNCTIONS\n // ===================================================\n // ===================================================\n function emitPollFramebuffer (env, scope, framebuffer, skipCheck) {\n var shared = env.shared\n\n var GL = shared.gl\n var FRAMEBUFFER_STATE = shared.framebuffer\n var EXT_DRAW_BUFFERS\n if (extDrawBuffers) {\n EXT_DRAW_BUFFERS = scope.def(shared.extensions, '.webgl_draw_buffers')\n }\n\n var constants = env.constants\n\n var DRAW_BUFFERS = constants.drawBuffer\n var BACK_BUFFER = constants.backBuffer\n\n var NEXT\n if (framebuffer) {\n NEXT = framebuffer.append(env, scope)\n } else {\n NEXT = scope.def(FRAMEBUFFER_STATE, '.next')\n }\n\n if (!skipCheck) {\n scope('if(', NEXT, '!==', FRAMEBUFFER_STATE, '.cur){')\n }\n scope(\n 'if(', NEXT, '){',\n GL, '.bindFramebuffer(', GL_FRAMEBUFFER$2, ',', NEXT, '.framebuffer);')\n if (extDrawBuffers) {\n scope(EXT_DRAW_BUFFERS, '.drawBuffersWEBGL(',\n DRAW_BUFFERS, '[', NEXT, '.colorAttachments.length]);')\n }\n scope('}else{',\n GL, '.bindFramebuffer(', GL_FRAMEBUFFER$2, ',null);')\n if (extDrawBuffers) {\n scope(EXT_DRAW_BUFFERS, '.drawBuffersWEBGL(', BACK_BUFFER, ');')\n }\n scope(\n '}',\n FRAMEBUFFER_STATE, '.cur=', NEXT, ';')\n if (!skipCheck) {\n scope('}')\n }\n }\n\n function emitPollState (env, scope, args) {\n var shared = env.shared\n\n var GL = shared.gl\n\n var CURRENT_VARS = env.current\n var NEXT_VARS = env.next\n var CURRENT_STATE = shared.current\n var NEXT_STATE = shared.next\n\n var block = env.cond(CURRENT_STATE, '.dirty')\n\n GL_STATE_NAMES.forEach(function (prop) {\n var param = propName(prop)\n if (param in args.state) {\n return\n }\n\n var NEXT, CURRENT\n if (param in NEXT_VARS) {\n NEXT = NEXT_VARS[param]\n CURRENT = CURRENT_VARS[param]\n var parts = loop(currentState[param].length, function (i) {\n return block.def(NEXT, '[', i, ']')\n })\n block(env.cond(parts.map(function (p, i) {\n return p + '!==' + CURRENT + '[' + i + ']'\n }).join('||'))\n .then(\n GL, '.', GL_VARIABLES[param], '(', parts, ');',\n parts.map(function (p, i) {\n return CURRENT + '[' + i + ']=' + p\n }).join(';'), ';'))\n } else {\n NEXT = block.def(NEXT_STATE, '.', param)\n var ifte = env.cond(NEXT, '!==', CURRENT_STATE, '.', param)\n block(ifte)\n if (param in GL_FLAGS) {\n ifte(\n env.cond(NEXT)\n .then(GL, '.enable(', GL_FLAGS[param], ');')\n .else(GL, '.disable(', GL_FLAGS[param], ');'),\n CURRENT_STATE, '.', param, '=', NEXT, ';')\n } else {\n ifte(\n GL, '.', GL_VARIABLES[param], '(', NEXT, ');',\n CURRENT_STATE, '.', param, '=', NEXT, ';')\n }\n }\n })\n if (Object.keys(args.state).length === 0) {\n block(CURRENT_STATE, '.dirty=false;')\n }\n scope(block)\n }\n\n function emitSetOptions (env, scope, options, filter) {\n var shared = env.shared\n var CURRENT_VARS = env.current\n var CURRENT_STATE = shared.current\n var GL = shared.gl\n var VALUE\n sortState(Object.keys(options)).forEach(function (param) {\n var defn = options[param]\n if (filter && !filter(defn)) {\n return\n }\n var variable = defn.append(env, scope)\n if (GL_FLAGS[param]) {\n var flag = GL_FLAGS[param]\n if (isStatic(defn)) {\n VALUE = env.link(variable, {stable: true})\n scope(env.cond(VALUE)\n .then(GL, '.enable(', flag, ');')\n .else(GL, '.disable(', flag, ');'))\n scope(CURRENT_STATE, '.', param, '=', VALUE, ';')\n } else {\n scope(env.cond(variable)\n .then(GL, '.enable(', flag, ');')\n .else(GL, '.disable(', flag, ');'))\n scope(CURRENT_STATE, '.', param, '=', variable, ';')\n }\n } else if (isArrayLike(variable)) {\n var CURRENT = CURRENT_VARS[param]\n scope(\n GL, '.', GL_VARIABLES[param], '(', variable, ');',\n variable.map(function (v, i) {\n return CURRENT + '[' + i + ']=' + v\n }).join(';'), ';')\n } else {\n if (isStatic(defn)) {\n VALUE = env.link(variable, {stable: true})\n scope(\n GL, '.', GL_VARIABLES[param], '(', VALUE, ');',\n CURRENT_STATE, '.', param, '=', VALUE, ';')\n } else {\n scope(\n GL, '.', GL_VARIABLES[param], '(', variable, ');',\n CURRENT_STATE, '.', param, '=', variable, ';')\n }\n }\n })\n }\n\n function injectExtensions (env, scope) {\n if (extInstancing) {\n env.instancing = scope.def(\n env.shared.extensions, '.angle_instanced_arrays')\n }\n }\n\n function emitProfile (env, scope, args, useScope, incrementCounter) {\n var shared = env.shared\n var STATS = env.stats\n var CURRENT_STATE = shared.current\n var TIMER = shared.timer\n var profileArg = args.profile\n\n function perfCounter () {\n if (typeof performance === 'undefined') {\n return 'Date.now()'\n } else {\n return 'performance.now()'\n }\n }\n\n var CPU_START, QUERY_COUNTER\n function emitProfileStart (block) {\n CPU_START = scope.def()\n block(CPU_START, '=', perfCounter(), ';')\n if (typeof incrementCounter === 'string') {\n block(STATS, '.count+=', incrementCounter, ';')\n } else {\n block(STATS, '.count++;')\n }\n if (timer) {\n if (useScope) {\n QUERY_COUNTER = scope.def()\n block(QUERY_COUNTER, '=', TIMER, '.getNumPendingQueries();')\n } else {\n block(TIMER, '.beginQuery(', STATS, ');')\n }\n }\n }\n\n function emitProfileEnd (block) {\n block(STATS, '.cpuTime+=', perfCounter(), '-', CPU_START, ';')\n if (timer) {\n if (useScope) {\n block(TIMER, '.pushScopeStats(',\n QUERY_COUNTER, ',',\n TIMER, '.getNumPendingQueries(),',\n STATS, ');')\n } else {\n block(TIMER, '.endQuery();')\n }\n }\n }\n\n function scopeProfile (value) {\n var prev = scope.def(CURRENT_STATE, '.profile')\n scope(CURRENT_STATE, '.profile=', value, ';')\n scope.exit(CURRENT_STATE, '.profile=', prev, ';')\n }\n\n var USE_PROFILE\n if (profileArg) {\n if (isStatic(profileArg)) {\n if (profileArg.enable) {\n emitProfileStart(scope)\n emitProfileEnd(scope.exit)\n scopeProfile('true')\n } else {\n scopeProfile('false')\n }\n return\n }\n USE_PROFILE = profileArg.append(env, scope)\n scopeProfile(USE_PROFILE)\n } else {\n USE_PROFILE = scope.def(CURRENT_STATE, '.profile')\n }\n\n var start = env.block()\n emitProfileStart(start)\n scope('if(', USE_PROFILE, '){', start, '}')\n var end = env.block()\n emitProfileEnd(end)\n scope.exit('if(', USE_PROFILE, '){', end, '}')\n }\n\n function emitAttributes (env, scope, args, attributes, filter) {\n var shared = env.shared\n\n function typeLength (x) {\n switch (x) {\n case GL_FLOAT_VEC2:\n case GL_INT_VEC2:\n case GL_BOOL_VEC2:\n return 2\n case GL_FLOAT_VEC3:\n case GL_INT_VEC3:\n case GL_BOOL_VEC3:\n return 3\n case GL_FLOAT_VEC4:\n case GL_INT_VEC4:\n case GL_BOOL_VEC4:\n return 4\n default:\n return 1\n }\n }\n\n function emitBindAttribute (ATTRIBUTE, size, record) {\n var GL = shared.gl\n\n var LOCATION = scope.def(ATTRIBUTE, '.location')\n var BINDING = scope.def(shared.attributes, '[', LOCATION, ']')\n\n var STATE = record.state\n var BUFFER = record.buffer\n var CONST_COMPONENTS = [\n record.x,\n record.y,\n record.z,\n record.w\n ]\n\n var COMMON_KEYS = [\n 'buffer',\n 'normalized',\n 'offset',\n 'stride'\n ]\n\n function emitBuffer () {\n scope(\n 'if(!', BINDING, '.buffer){',\n GL, '.enableVertexAttribArray(', LOCATION, ');}')\n\n var TYPE = record.type\n var SIZE\n if (!record.size) {\n SIZE = size\n } else {\n SIZE = scope.def(record.size, '||', size)\n }\n\n scope('if(',\n BINDING, '.type!==', TYPE, '||',\n BINDING, '.size!==', SIZE, '||',\n COMMON_KEYS.map(function (key) {\n return BINDING + '.' + key + '!==' + record[key]\n }).join('||'),\n '){',\n GL, '.bindBuffer(', GL_ARRAY_BUFFER$2, ',', BUFFER, '.buffer);',\n GL, '.vertexAttribPointer(', [\n LOCATION,\n SIZE,\n TYPE,\n record.normalized,\n record.stride,\n record.offset\n ], ');',\n BINDING, '.type=', TYPE, ';',\n BINDING, '.size=', SIZE, ';',\n COMMON_KEYS.map(function (key) {\n return BINDING + '.' + key + '=' + record[key] + ';'\n }).join(''),\n '}')\n\n if (extInstancing) {\n var DIVISOR = record.divisor\n scope(\n 'if(', BINDING, '.divisor!==', DIVISOR, '){',\n env.instancing, '.vertexAttribDivisorANGLE(', [LOCATION, DIVISOR], ');',\n BINDING, '.divisor=', DIVISOR, ';}')\n }\n }\n\n function emitConstant () {\n scope(\n 'if(', BINDING, '.buffer){',\n GL, '.disableVertexAttribArray(', LOCATION, ');',\n BINDING, '.buffer=null;',\n '}if(', CUTE_COMPONENTS.map(function (c, i) {\n return BINDING + '.' + c + '!==' + CONST_COMPONENTS[i]\n }).join('||'), '){',\n GL, '.vertexAttrib4f(', LOCATION, ',', CONST_COMPONENTS, ');',\n CUTE_COMPONENTS.map(function (c, i) {\n return BINDING + '.' + c + '=' + CONST_COMPONENTS[i] + ';'\n }).join(''),\n '}')\n }\n\n if (STATE === ATTRIB_STATE_POINTER) {\n emitBuffer()\n } else if (STATE === ATTRIB_STATE_CONSTANT) {\n emitConstant()\n } else {\n scope('if(', STATE, '===', ATTRIB_STATE_POINTER, '){')\n emitBuffer()\n scope('}else{')\n emitConstant()\n scope('}')\n }\n }\n\n attributes.forEach(function (attribute) {\n var name = attribute.name\n var arg = args.attributes[name]\n var record\n if (arg) {\n if (!filter(arg)) {\n return\n }\n record = arg.append(env, scope)\n } else {\n if (!filter(SCOPE_DECL)) {\n return\n }\n var scopeAttrib = env.scopeAttrib(name)\n \n record = {}\n Object.keys(new AttributeRecord()).forEach(function (key) {\n record[key] = scope.def(scopeAttrib, '.', key)\n })\n }\n emitBindAttribute(\n env.link(attribute), typeLength(attribute.info.type), record)\n })\n }\n\n function emitUniforms (env, scope, args, uniforms, filter, isBatchInnerLoop) {\n var shared = env.shared\n var GL = shared.gl\n\n var infix\n for (var i = 0; i < uniforms.length; ++i) {\n var uniform = uniforms[i]\n var name = uniform.name\n var type = uniform.info.type\n var arg = args.uniforms[name]\n var UNIFORM = env.link(uniform)\n var LOCATION = UNIFORM + '.location'\n\n var VALUE\n if (arg) {\n if (!filter(arg)) {\n continue\n }\n if (isStatic(arg)) {\n var value = arg.value\n \n if (type === GL_SAMPLER_2D || type === GL_SAMPLER_CUBE) {\n \n var TEX_VALUE = env.link(value._texture || value.color[0]._texture)\n scope(GL, '.uniform1i(', LOCATION, ',', TEX_VALUE + '.bind());')\n scope.exit(TEX_VALUE, '.unbind();')\n } else if (\n type === GL_FLOAT_MAT2 ||\n type === GL_FLOAT_MAT3 ||\n type === GL_FLOAT_MAT4) {\n \n var MAT_VALUE = env.global.def('new Float32Array([' +\n Array.prototype.slice.call(value) + '])')\n var dim = 2\n if (type === GL_FLOAT_MAT3) {\n dim = 3\n } else if (type === GL_FLOAT_MAT4) {\n dim = 4\n }\n scope(\n GL, '.uniformMatrix', dim, 'fv(',\n LOCATION, ',false,', MAT_VALUE, ');')\n } else {\n switch (type) {\n case GL_FLOAT$7:\n \n infix = '1f'\n break\n case GL_FLOAT_VEC2:\n \n infix = '2f'\n break\n case GL_FLOAT_VEC3:\n \n infix = '3f'\n break\n case GL_FLOAT_VEC4:\n \n infix = '4f'\n break\n case GL_BOOL:\n \n infix = '1i'\n break\n case GL_INT$2:\n \n infix = '1i'\n break\n case GL_BOOL_VEC2:\n \n infix = '2i'\n break\n case GL_INT_VEC2:\n \n infix = '2i'\n break\n case GL_BOOL_VEC3:\n \n infix = '3i'\n break\n case GL_INT_VEC3:\n \n infix = '3i'\n break\n case GL_BOOL_VEC4:\n \n infix = '4i'\n break\n case GL_INT_VEC4:\n \n infix = '4i'\n break\n }\n scope(GL, '.uniform', infix, '(', LOCATION, ',',\n isArrayLike(value) ? Array.prototype.slice.call(value) : value,\n ');')\n }\n continue\n } else {\n VALUE = arg.append(env, scope)\n }\n } else {\n if (!filter(SCOPE_DECL)) {\n continue\n }\n VALUE = scope.def(shared.uniforms, '[', stringStore.id(name), ']')\n }\n\n if (type === GL_SAMPLER_2D) {\n \n scope(\n 'if(', VALUE, '&&', VALUE, '._reglType===\"framebuffer\"){',\n VALUE, '=', VALUE, '.color[0];',\n '}')\n } else if (type === GL_SAMPLER_CUBE) {\n \n scope(\n 'if(', VALUE, '&&', VALUE, '._reglType===\"framebufferCube\"){',\n VALUE, '=', VALUE, '.color[0];',\n '}')\n }\n\n // perform type validation\n \n\n var unroll = 1\n switch (type) {\n case GL_SAMPLER_2D:\n case GL_SAMPLER_CUBE:\n var TEX = scope.def(VALUE, '._texture')\n scope(GL, '.uniform1i(', LOCATION, ',', TEX, '.bind());')\n scope.exit(TEX, '.unbind();')\n continue\n\n case GL_INT$2:\n case GL_BOOL:\n infix = '1i'\n break\n\n case GL_INT_VEC2:\n case GL_BOOL_VEC2:\n infix = '2i'\n unroll = 2\n break\n\n case GL_INT_VEC3:\n case GL_BOOL_VEC3:\n infix = '3i'\n unroll = 3\n break\n\n case GL_INT_VEC4:\n case GL_BOOL_VEC4:\n infix = '4i'\n unroll = 4\n break\n\n case GL_FLOAT$7:\n infix = '1f'\n break\n\n case GL_FLOAT_VEC2:\n infix = '2f'\n unroll = 2\n break\n\n case GL_FLOAT_VEC3:\n infix = '3f'\n unroll = 3\n break\n\n case GL_FLOAT_VEC4:\n infix = '4f'\n unroll = 4\n break\n\n case GL_FLOAT_MAT2:\n infix = 'Matrix2fv'\n break\n\n case GL_FLOAT_MAT3:\n infix = 'Matrix3fv'\n break\n\n case GL_FLOAT_MAT4:\n infix = 'Matrix4fv'\n break\n }\n\n if (infix.charAt(0) === 'M') {\n scope(GL, '.uniform', infix, '(', LOCATION, ',')\n var matSize = Math.pow(type - GL_FLOAT_MAT2 + 2, 2)\n var STORAGE = env.global.def('new Float32Array(', matSize, ')')\n if (Array.isArray(VALUE)) {\n scope(\n 'false,(',\n loop(matSize, function (i) {\n return STORAGE + '[' + i + ']=' + VALUE[i]\n }), ',', STORAGE, ')')\n } else {\n scope(\n 'false,(Array.isArray(', VALUE, ')||', VALUE, ' instanceof Float32Array)?', VALUE, ':(',\n loop(matSize, function (i) {\n return STORAGE + '[' + i + ']=' + VALUE + '[' + i + ']'\n }), ',', STORAGE, ')')\n }\n scope(');')\n } else if (unroll > 1) {\n var prev = []\n var cur = []\n for (var j = 0; j < unroll; ++j) {\n if (Array.isArray(VALUE)) {\n cur.push(VALUE[j])\n } else {\n cur.push(scope.def(VALUE + '[' + j + ']'))\n }\n if (isBatchInnerLoop) {\n prev.push(scope.def())\n }\n }\n if (isBatchInnerLoop) {\n scope('if(!', env.batchId, '||', prev.map(function (p, i) {\n return p + '!==' + cur[i]\n }).join('||'), '){', prev.map(function (p, i) {\n return p + '=' + cur[i] + ';'\n }).join(''))\n }\n scope(GL, '.uniform', infix, '(', LOCATION, ',', cur.join(','), ');')\n if (isBatchInnerLoop) {\n scope('}')\n }\n } else {\n \n if (isBatchInnerLoop) {\n var prevS = scope.def()\n scope('if(!', env.batchId, '||', prevS, '!==', VALUE, '){',\n prevS, '=', VALUE, ';')\n }\n scope(GL, '.uniform', infix, '(', LOCATION, ',', VALUE, ');')\n if (isBatchInnerLoop) {\n scope('}')\n }\n }\n }\n }\n\n function emitDraw (env, outer, inner, args) {\n var shared = env.shared\n var GL = shared.gl\n var DRAW_STATE = shared.draw\n\n var drawOptions = args.draw\n\n function emitElements () {\n var defn = drawOptions.elements\n var ELEMENTS\n var scope = outer\n if (defn) {\n if ((defn.contextDep && args.contextDynamic) || defn.propDep) {\n scope = inner\n }\n ELEMENTS = defn.append(env, scope)\n if (drawOptions.elementsActive) {\n scope(\n 'if(' + ELEMENTS + ')' +\n GL + '.bindBuffer(' + GL_ELEMENT_ARRAY_BUFFER$2 + ',' + ELEMENTS + '.buffer.buffer);')\n }\n } else {\n ELEMENTS = scope.def()\n scope(\n ELEMENTS, '=', DRAW_STATE, '.', S_ELEMENTS, ';',\n 'if(', ELEMENTS, '){',\n GL, '.bindBuffer(', GL_ELEMENT_ARRAY_BUFFER$2, ',', ELEMENTS, '.buffer.buffer);}',\n 'else if(', shared.vao, '.currentVAO){',\n ELEMENTS, '=', env.shared.elements + '.getElements(' + shared.vao, '.currentVAO.elements);',\n (!extVertexArrays ? 'if(' + ELEMENTS + ')' + GL + '.bindBuffer(' + GL_ELEMENT_ARRAY_BUFFER$2 + ',' + ELEMENTS + '.buffer.buffer);' : ''),\n '}')\n }\n return ELEMENTS\n }\n\n function emitCount () {\n var defn = drawOptions.count\n var COUNT\n var scope = outer\n if (defn) {\n if ((defn.contextDep && args.contextDynamic) || defn.propDep) {\n scope = inner\n }\n COUNT = defn.append(env, scope)\n \n } else {\n COUNT = scope.def(DRAW_STATE, '.', S_COUNT)\n \n }\n return COUNT\n }\n\n var ELEMENTS = emitElements()\n function emitValue (name) {\n var defn = drawOptions[name]\n if (defn) {\n if ((defn.contextDep && args.contextDynamic) || defn.propDep) {\n return defn.append(env, inner)\n } else {\n return defn.append(env, outer)\n }\n } else {\n return outer.def(DRAW_STATE, '.', name)\n }\n }\n\n var PRIMITIVE = emitValue(S_PRIMITIVE)\n var OFFSET = emitValue(S_OFFSET)\n\n var COUNT = emitCount()\n if (typeof COUNT === 'number') {\n if (COUNT === 0) {\n return\n }\n } else {\n inner('if(', COUNT, '){')\n inner.exit('}')\n }\n\n var INSTANCES, EXT_INSTANCING\n if (extInstancing) {\n INSTANCES = emitValue(S_INSTANCES)\n EXT_INSTANCING = env.instancing\n }\n\n var ELEMENT_TYPE = ELEMENTS + '.type'\n\n var elementsStatic = drawOptions.elements && isStatic(drawOptions.elements) && !drawOptions.vaoActive\n\n function emitInstancing () {\n function drawElements () {\n inner(EXT_INSTANCING, '.drawElementsInstancedANGLE(', [\n PRIMITIVE,\n COUNT,\n ELEMENT_TYPE,\n OFFSET + '<<((' + ELEMENT_TYPE + '-' + GL_UNSIGNED_BYTE$7 + ')>>1)',\n INSTANCES\n ], ');')\n }\n\n function drawArrays () {\n inner(EXT_INSTANCING, '.drawArraysInstancedANGLE(',\n [PRIMITIVE, OFFSET, COUNT, INSTANCES], ');')\n }\n\n if (ELEMENTS && ELEMENTS !== 'null') {\n if (!elementsStatic) {\n inner('if(', ELEMENTS, '){')\n drawElements()\n inner('}else{')\n drawArrays()\n inner('}')\n } else {\n drawElements()\n }\n } else {\n drawArrays()\n }\n }\n\n function emitRegular () {\n function drawElements () {\n inner(GL + '.drawElements(' + [\n PRIMITIVE,\n COUNT,\n ELEMENT_TYPE,\n OFFSET + '<<((' + ELEMENT_TYPE + '-' + GL_UNSIGNED_BYTE$7 + ')>>1)'\n ] + ');')\n }\n\n function drawArrays () {\n inner(GL + '.drawArrays(' + [PRIMITIVE, OFFSET, COUNT] + ');')\n }\n\n if (ELEMENTS && ELEMENTS !== 'null') {\n if (!elementsStatic) {\n inner('if(', ELEMENTS, '){')\n drawElements()\n inner('}else{')\n drawArrays()\n inner('}')\n } else {\n drawElements()\n }\n } else {\n drawArrays()\n }\n }\n\n if (extInstancing && (typeof INSTANCES !== 'number' || INSTANCES >= 0)) {\n if (typeof INSTANCES === 'string') {\n inner('if(', INSTANCES, '>0){')\n emitInstancing()\n inner('}else if(', INSTANCES, '<0){')\n emitRegular()\n inner('}')\n } else {\n emitInstancing()\n }\n } else {\n emitRegular()\n }\n }\n\n function createBody (emitBody, parentEnv, args, program, count) {\n var env = createREGLEnvironment()\n var scope = env.proc('body', count)\n \n if (extInstancing) {\n env.instancing = scope.def(\n env.shared.extensions, '.angle_instanced_arrays')\n }\n emitBody(env, scope, args, program)\n return env.compile().body\n }\n\n // ===================================================\n // ===================================================\n // DRAW PROC\n // ===================================================\n // ===================================================\n function emitDrawBody (env, draw, args, program) {\n injectExtensions(env, draw)\n if (args.useVAO) {\n if (args.drawVAO) {\n draw(env.shared.vao, '.setVAO(', args.drawVAO.append(env, draw), ');')\n } else {\n draw(env.shared.vao, '.setVAO(', env.shared.vao, '.targetVAO);')\n }\n } else {\n draw(env.shared.vao, '.setVAO(null);')\n emitAttributes(env, draw, args, program.attributes, function () {\n return true\n })\n }\n emitUniforms(env, draw, args, program.uniforms, function () {\n return true\n }, false)\n emitDraw(env, draw, draw, args)\n }\n\n function emitDrawProc (env, args) {\n var draw = env.proc('draw', 1)\n\n injectExtensions(env, draw)\n\n emitContext(env, draw, args.context)\n emitPollFramebuffer(env, draw, args.framebuffer)\n\n emitPollState(env, draw, args)\n emitSetOptions(env, draw, args.state)\n\n emitProfile(env, draw, args, false, true)\n\n var program = args.shader.progVar.append(env, draw)\n draw(env.shared.gl, '.useProgram(', program, '.program);')\n\n if (args.shader.program) {\n emitDrawBody(env, draw, args, args.shader.program)\n } else {\n draw(env.shared.vao, '.setVAO(null);')\n var drawCache = env.global.def('{}')\n var PROG_ID = draw.def(program, '.id')\n var CACHED_PROC = draw.def(drawCache, '[', PROG_ID, ']')\n draw(\n env.cond(CACHED_PROC)\n .then(CACHED_PROC, '.call(this,a0);')\n .else(\n CACHED_PROC, '=', drawCache, '[', PROG_ID, ']=',\n env.link(function (program) {\n return createBody(emitDrawBody, env, args, program, 1)\n }), '(', program, ');',\n CACHED_PROC, '.call(this,a0);'))\n }\n\n if (Object.keys(args.state).length > 0) {\n draw(env.shared.current, '.dirty=true;')\n }\n if (env.shared.vao) {\n draw(env.shared.vao, '.setVAO(null);')\n }\n }\n\n // ===================================================\n // ===================================================\n // BATCH PROC\n // ===================================================\n // ===================================================\n\n function emitBatchDynamicShaderBody (env, scope, args, program) {\n env.batchId = 'a1'\n\n injectExtensions(env, scope)\n\n function all () {\n return true\n }\n\n emitAttributes(env, scope, args, program.attributes, all)\n emitUniforms(env, scope, args, program.uniforms, all, false)\n emitDraw(env, scope, scope, args)\n }\n\n function emitBatchBody (env, scope, args, program) {\n injectExtensions(env, scope)\n\n var contextDynamic = args.contextDep\n\n var BATCH_ID = scope.def()\n var PROP_LIST = 'a0'\n var NUM_PROPS = 'a1'\n var PROPS = scope.def()\n env.shared.props = PROPS\n env.batchId = BATCH_ID\n\n var outer = env.scope()\n var inner = env.scope()\n\n scope(\n outer.entry,\n 'for(', BATCH_ID, '=0;', BATCH_ID, '<', NUM_PROPS, ';++', BATCH_ID, '){',\n PROPS, '=', PROP_LIST, '[', BATCH_ID, '];',\n inner,\n '}',\n outer.exit)\n\n function isInnerDefn (defn) {\n return ((defn.contextDep && contextDynamic) || defn.propDep)\n }\n\n function isOuterDefn (defn) {\n return !isInnerDefn(defn)\n }\n\n if (args.needsContext) {\n emitContext(env, inner, args.context)\n }\n if (args.needsFramebuffer) {\n emitPollFramebuffer(env, inner, args.framebuffer)\n }\n emitSetOptions(env, inner, args.state, isInnerDefn)\n\n if (args.profile && isInnerDefn(args.profile)) {\n emitProfile(env, inner, args, false, true)\n }\n\n if (!program) {\n var progCache = env.global.def('{}')\n var PROGRAM = args.shader.progVar.append(env, inner)\n var PROG_ID = inner.def(PROGRAM, '.id')\n var CACHED_PROC = inner.def(progCache, '[', PROG_ID, ']')\n inner(\n env.shared.gl, '.useProgram(', PROGRAM, '.program);',\n 'if(!', CACHED_PROC, '){',\n CACHED_PROC, '=', progCache, '[', PROG_ID, ']=',\n env.link(function (program) {\n return createBody(\n emitBatchDynamicShaderBody, env, args, program, 2)\n }), '(', PROGRAM, ');}',\n CACHED_PROC, '.call(this,a0[', BATCH_ID, '],', BATCH_ID, ');')\n } else {\n if (args.useVAO) {\n if (args.drawVAO) {\n if (isInnerDefn(args.drawVAO)) {\n // vao is a prop\n inner(env.shared.vao, '.setVAO(', args.drawVAO.append(env, inner), ');')\n } else {\n // vao is invariant\n outer(env.shared.vao, '.setVAO(', args.drawVAO.append(env, outer), ');')\n }\n } else {\n // scoped vao binding\n outer(env.shared.vao, '.setVAO(', env.shared.vao, '.targetVAO);')\n }\n } else {\n outer(env.shared.vao, '.setVAO(null);')\n emitAttributes(env, outer, args, program.attributes, isOuterDefn)\n emitAttributes(env, inner, args, program.attributes, isInnerDefn)\n }\n emitUniforms(env, outer, args, program.uniforms, isOuterDefn, false)\n emitUniforms(env, inner, args, program.uniforms, isInnerDefn, true)\n emitDraw(env, outer, inner, args)\n }\n }\n\n function emitBatchProc (env, args) {\n var batch = env.proc('batch', 2)\n env.batchId = '0'\n\n injectExtensions(env, batch)\n\n // Check if any context variables depend on props\n var contextDynamic = false\n var needsContext = true\n Object.keys(args.context).forEach(function (name) {\n contextDynamic = contextDynamic || args.context[name].propDep\n })\n if (!contextDynamic) {\n emitContext(env, batch, args.context)\n needsContext = false\n }\n\n // framebuffer state affects framebufferWidth/height context vars\n var framebuffer = args.framebuffer\n var needsFramebuffer = false\n if (framebuffer) {\n if (framebuffer.propDep) {\n contextDynamic = needsFramebuffer = true\n } else if (framebuffer.contextDep && contextDynamic) {\n needsFramebuffer = true\n }\n if (!needsFramebuffer) {\n emitPollFramebuffer(env, batch, framebuffer)\n }\n } else {\n emitPollFramebuffer(env, batch, null)\n }\n\n // viewport is weird because it can affect context vars\n if (args.state.viewport && args.state.viewport.propDep) {\n contextDynamic = true\n }\n\n function isInnerDefn (defn) {\n return (defn.contextDep && contextDynamic) || defn.propDep\n }\n\n // set webgl options\n emitPollState(env, batch, args)\n emitSetOptions(env, batch, args.state, function (defn) {\n return !isInnerDefn(defn)\n })\n\n if (!args.profile || !isInnerDefn(args.profile)) {\n emitProfile(env, batch, args, false, 'a1')\n }\n\n // Save these values to args so that the batch body routine can use them\n args.contextDep = contextDynamic\n args.needsContext = needsContext\n args.needsFramebuffer = needsFramebuffer\n\n // determine if shader is dynamic\n var progDefn = args.shader.progVar\n if ((progDefn.contextDep && contextDynamic) || progDefn.propDep) {\n emitBatchBody(\n env,\n batch,\n args,\n null)\n } else {\n var PROGRAM = progDefn.append(env, batch)\n batch(env.shared.gl, '.useProgram(', PROGRAM, '.program);')\n if (args.shader.program) {\n emitBatchBody(\n env,\n batch,\n args,\n args.shader.program)\n } else {\n batch(env.shared.vao, '.setVAO(null);')\n var batchCache = env.global.def('{}')\n var PROG_ID = batch.def(PROGRAM, '.id')\n var CACHED_PROC = batch.def(batchCache, '[', PROG_ID, ']')\n batch(\n env.cond(CACHED_PROC)\n .then(CACHED_PROC, '.call(this,a0,a1);')\n .else(\n CACHED_PROC, '=', batchCache, '[', PROG_ID, ']=',\n env.link(function (program) {\n return createBody(emitBatchBody, env, args, program, 2)\n }), '(', PROGRAM, ');',\n CACHED_PROC, '.call(this,a0,a1);'))\n }\n }\n\n if (Object.keys(args.state).length > 0) {\n batch(env.shared.current, '.dirty=true;')\n }\n\n if (env.shared.vao) {\n batch(env.shared.vao, '.setVAO(null);')\n }\n }\n\n // ===================================================\n // ===================================================\n // SCOPE COMMAND\n // ===================================================\n // ===================================================\n function emitScopeProc (env, args) {\n var scope = env.proc('scope', 3)\n env.batchId = 'a2'\n\n var shared = env.shared\n var CURRENT_STATE = shared.current\n\n emitContext(env, scope, args.context)\n\n if (args.framebuffer) {\n args.framebuffer.append(env, scope)\n }\n\n sortState(Object.keys(args.state)).forEach(function (name) {\n var defn = args.state[name]\n var value = defn.append(env, scope)\n if (isArrayLike(value)) {\n value.forEach(function (v, i) {\n if (hasVariableReference(v)) {\n scope.set(env.next[name], '[' + i + ']', v)\n } else {\n scope.set(env.next[name], '[' + i + ']', env.link(v, {stable: true}))\n }\n })\n } else {\n if (isStatic(defn)) {\n scope.set(shared.next, '.' + name, env.link(value, {stable: true}))\n } else {\n scope.set(shared.next, '.' + name, value)\n }\n }\n })\n\n emitProfile(env, scope, args, true, true)\n\n ;[S_ELEMENTS, S_OFFSET, S_COUNT, S_INSTANCES, S_PRIMITIVE].forEach(\n function (opt) {\n var variable = args.draw[opt]\n if (!variable) {\n return\n }\n var VARIABLE = variable.append(env, scope)\n if (hasVariableReference(VARIABLE)) {\n scope.set(shared.draw, '.' + opt, VARIABLE)\n } else {\n scope.set(shared.draw, '.' + opt, env.link(VARIABLE), {stable: true})\n }\n })\n\n Object.keys(args.uniforms).forEach(function (opt) {\n var value = args.uniforms[opt].append(env, scope)\n if (Array.isArray(value)) {\n value = '[' + value.map(function (v) {\n if (hasVariableReference(v)) {\n return v;\n } else {\n return env.link(v, {stable: true})\n }\n }) + ']'\n }\n scope.set(\n shared.uniforms,\n '[' + env.link(stringStore.id(opt), {stable: true}) + ']',\n value)\n })\n\n Object.keys(args.attributes).forEach(function (name) {\n var record = args.attributes[name].append(env, scope)\n var scopeAttrib = env.scopeAttrib(name)\n Object.keys(new AttributeRecord()).forEach(function (prop) {\n scope.set(scopeAttrib, '.' + prop, record[prop])\n })\n })\n\n if (args.scopeVAO) {\n var VARIABLE = args.scopeVAO.append(env, scope)\n if (hasVariableReference(VARIABLE)) {\n scope.set(shared.vao, '.targetVAO', VARIABLE)\n } else {\n scope.set(shared.vao, '.targetVAO', env.link(VARIABLE, {stable: true}))\n }\n }\n\n function saveShader (name) {\n var shader = args.shader[name]\n if (shader) {\n var VARIABLE = shader.append(env, scope)\n if (hasVariableReference(VARIABLE)) {\n scope.set(shared.shader, '.' + name, VARIABLE)\n } else {\n scope.set(shared.shader, '.' + name, env.link(VARIABLE, {stable: true}))\n }\n }\n }\n saveShader(S_VERT)\n saveShader(S_FRAG)\n\n if (Object.keys(args.state).length > 0) {\n scope(CURRENT_STATE, '.dirty=true;')\n scope.exit(CURRENT_STATE, '.dirty=true;')\n }\n\n scope('a1(', env.shared.context, ',a0,', env.batchId, ');')\n }\n\n function isDynamicObject (object) {\n if (typeof object !== 'object' || isArrayLike(object)) {\n return\n }\n var props = Object.keys(object)\n for (var i = 0; i < props.length; ++i) {\n if (dynamic.isDynamic(object[props[i]])) {\n return true\n }\n }\n return false\n }\n\n function splatObject (env, options, name) {\n var object = options.static[name]\n if (!object || !isDynamicObject(object)) {\n return\n }\n\n var globals = env.global\n var keys = Object.keys(object)\n var thisDep = false\n var contextDep = false\n var propDep = false\n var objectRef = env.global.def('{}')\n keys.forEach(function (key) {\n var value = object[key]\n if (dynamic.isDynamic(value)) {\n if (typeof value === 'function') {\n value = object[key] = dynamic.unbox(value)\n }\n var deps = createDynamicDecl(value, null)\n thisDep = thisDep || deps.thisDep\n propDep = propDep || deps.propDep\n contextDep = contextDep || deps.contextDep\n } else {\n globals(objectRef, '.', key, '=')\n switch (typeof value) {\n case 'number':\n globals(value)\n break\n case 'string':\n globals('\"', value, '\"')\n break\n case 'object':\n if (Array.isArray(value)) {\n globals('[', value.join(), ']')\n }\n break\n default:\n globals(env.link(value))\n break\n }\n globals(';')\n }\n })\n\n function appendBlock (env, block) {\n keys.forEach(function (key) {\n var value = object[key]\n if (!dynamic.isDynamic(value)) {\n return\n }\n var ref = env.invoke(block, value)\n block(objectRef, '.', key, '=', ref, ';')\n })\n }\n\n options.dynamic[name] = new dynamic.DynamicVariable(DYN_THUNK, {\n thisDep: thisDep,\n contextDep: contextDep,\n propDep: propDep,\n ref: objectRef,\n append: appendBlock\n })\n delete options.static[name]\n }\n\n // ===========================================================================\n // ===========================================================================\n // MAIN DRAW COMMAND\n // ===========================================================================\n // ===========================================================================\n function compileCommand (options, attributes, uniforms, context, stats) {\n var env = createREGLEnvironment()\n\n // link stats, so that we can easily access it in the program.\n env.stats = env.link(stats)\n\n // splat options and attributes to allow for dynamic nested properties\n Object.keys(attributes.static).forEach(function (key) {\n splatObject(env, attributes, key)\n })\n NESTED_OPTIONS.forEach(function (name) {\n splatObject(env, options, name)\n })\n\n var args = parseArguments(options, attributes, uniforms, context, env)\n\n if (args.shader.program) {\n args.shader.program.attributes.sort(function (a, b) {\n return a.name < b.name ? -1 : 1\n })\n args.shader.program.uniforms.sort(function (a, b) {\n return a.name < b.name ? -1 : 1\n })\n }\n\n emitDrawProc(env, args)\n emitScopeProc(env, args)\n emitBatchProc(env, args)\n\n return extend(env.compile(), {\n destroy: function () {\n args.shader.program.destroy()\n }\n })\n }\n\n // ===========================================================================\n // ===========================================================================\n // POLL / REFRESH\n // ===========================================================================\n // ===========================================================================\n return {\n next: nextState,\n current: currentState,\n procs: (function () {\n var env = createREGLEnvironment()\n var poll = env.proc('poll')\n var refresh = env.proc('refresh')\n var common = env.block()\n poll(common)\n refresh(common)\n\n var shared = env.shared\n var GL = shared.gl\n var NEXT_STATE = shared.next\n var CURRENT_STATE = shared.current\n\n common(CURRENT_STATE, '.dirty=false;')\n\n emitPollFramebuffer(env, poll)\n emitPollFramebuffer(env, refresh, null, true)\n\n // Refresh updates all attribute state changes\n var INSTANCING\n if (extInstancing) {\n INSTANCING = env.link(extInstancing)\n }\n\n // update vertex array bindings\n if (extensions.oes_vertex_array_object) {\n refresh(env.link(extensions.oes_vertex_array_object), '.bindVertexArrayOES(null);')\n }\n var BINDING = refresh.def(shared.attributes)\n var TEMP_BINDING = refresh.def(0)\n\n var ifte = env.cond(TEMP_BINDING, '.buffer')\n ifte.then(\n GL, '.enableVertexAttribArray(i);',\n GL, '.bindBuffer(',\n GL_ARRAY_BUFFER$2, ',',\n TEMP_BINDING, '.buffer.buffer);',\n GL, '.vertexAttribPointer(i,',\n TEMP_BINDING, '.size,',\n TEMP_BINDING, '.type,',\n TEMP_BINDING, '.normalized,',\n TEMP_BINDING, '.stride,',\n TEMP_BINDING, '.offset);'\n ).else(\n GL, '.disableVertexAttribArray(i);',\n GL, '.vertexAttrib4f(i,',\n TEMP_BINDING, '.x,',\n TEMP_BINDING, '.y,',\n TEMP_BINDING, '.z,',\n TEMP_BINDING, '.w);',\n TEMP_BINDING, '.buffer=null;')\n var MAX_ATTRIBUTES = env.link(limits.maxAttributes, {stable: true})\n refresh(\n 'for(var i=0;i<', MAX_ATTRIBUTES, ';++i){',\n TEMP_BINDING, '=', BINDING, '[i];',\n ifte,\n '}'\n )\n\n if (extInstancing) {\n refresh(\n 'for(var i=0;i<', MAX_ATTRIBUTES, ';++i){',\n INSTANCING, '.vertexAttribDivisorANGLE(i,',\n BINDING, '[i].divisor);',\n '}')\n }\n refresh(\n env.shared.vao, '.currentVAO=null;',\n env.shared.vao, '.setVAO(', env.shared.vao, '.targetVAO);')\n\n Object.keys(GL_FLAGS).forEach(function (flag) {\n var cap = GL_FLAGS[flag]\n var NEXT = common.def(NEXT_STATE, '.', flag)\n var block = env.block()\n block('if(', NEXT, '){',\n GL, '.enable(', cap, ')}else{',\n GL, '.disable(', cap, ')}',\n CURRENT_STATE, '.', flag, '=', NEXT, ';')\n refresh(block)\n poll(\n 'if(', NEXT, '!==', CURRENT_STATE, '.', flag, '){',\n block,\n '}')\n })\n\n Object.keys(GL_VARIABLES).forEach(function (name) {\n var func = GL_VARIABLES[name]\n var init = currentState[name]\n var NEXT, CURRENT\n var block = env.block()\n block(GL, '.', func, '(')\n if (isArrayLike(init)) {\n var n = init.length\n NEXT = env.global.def(NEXT_STATE, '.', name)\n CURRENT = env.global.def(CURRENT_STATE, '.', name)\n block(\n loop(n, function (i) {\n return NEXT + '[' + i + ']'\n }), ');',\n loop(n, function (i) {\n return CURRENT + '[' + i + ']=' + NEXT + '[' + i + '];'\n }).join(''))\n poll(\n 'if(', loop(n, function (i) {\n return NEXT + '[' + i + ']!==' + CURRENT + '[' + i + ']'\n }).join('||'), '){',\n block,\n '}')\n } else {\n NEXT = common.def(NEXT_STATE, '.', name)\n CURRENT = common.def(CURRENT_STATE, '.', name)\n block(\n NEXT, ');',\n CURRENT_STATE, '.', name, '=', NEXT, ';')\n poll(\n 'if(', NEXT, '!==', CURRENT, '){',\n block,\n '}')\n }\n refresh(block)\n })\n\n return env.compile()\n })(),\n compile: compileCommand\n }\n}\n\nfunction stats () {\n return {\n vaoCount: 0,\n bufferCount: 0,\n elementsCount: 0,\n framebufferCount: 0,\n shaderCount: 0,\n textureCount: 0,\n cubeCount: 0,\n renderbufferCount: 0,\n maxTextureUnits: 0\n }\n}\n\nvar GL_QUERY_RESULT_EXT = 0x8866\nvar GL_QUERY_RESULT_AVAILABLE_EXT = 0x8867\nvar GL_TIME_ELAPSED_EXT = 0x88BF\n\nvar createTimer = function (gl, extensions) {\n if (!extensions.ext_disjoint_timer_query) {\n return null\n }\n\n // QUERY POOL BEGIN\n var queryPool = []\n function allocQuery () {\n return queryPool.pop() || extensions.ext_disjoint_timer_query.createQueryEXT()\n }\n function freeQuery (query) {\n queryPool.push(query)\n }\n // QUERY POOL END\n\n var pendingQueries = []\n function beginQuery (stats) {\n var query = allocQuery()\n extensions.ext_disjoint_timer_query.beginQueryEXT(GL_TIME_ELAPSED_EXT, query)\n pendingQueries.push(query)\n pushScopeStats(pendingQueries.length - 1, pendingQueries.length, stats)\n }\n\n function endQuery () {\n extensions.ext_disjoint_timer_query.endQueryEXT(GL_TIME_ELAPSED_EXT)\n }\n\n //\n // Pending stats pool.\n //\n function PendingStats () {\n this.startQueryIndex = -1\n this.endQueryIndex = -1\n this.sum = 0\n this.stats = null\n }\n var pendingStatsPool = []\n function allocPendingStats () {\n return pendingStatsPool.pop() || new PendingStats()\n }\n function freePendingStats (pendingStats) {\n pendingStatsPool.push(pendingStats)\n }\n // Pending stats pool end\n\n var pendingStats = []\n function pushScopeStats (start, end, stats) {\n var ps = allocPendingStats()\n ps.startQueryIndex = start\n ps.endQueryIndex = end\n ps.sum = 0\n ps.stats = stats\n pendingStats.push(ps)\n }\n\n // we should call this at the beginning of the frame,\n // in order to update gpuTime\n var timeSum = []\n var queryPtr = []\n function update () {\n var ptr, i\n\n var n = pendingQueries.length\n if (n === 0) {\n return\n }\n\n // Reserve space\n queryPtr.length = Math.max(queryPtr.length, n + 1)\n timeSum.length = Math.max(timeSum.length, n + 1)\n timeSum[0] = 0\n queryPtr[0] = 0\n\n // Update all pending timer queries\n var queryTime = 0\n ptr = 0\n for (i = 0; i < pendingQueries.length; ++i) {\n var query = pendingQueries[i]\n if (extensions.ext_disjoint_timer_query.getQueryObjectEXT(query, GL_QUERY_RESULT_AVAILABLE_EXT)) {\n queryTime += extensions.ext_disjoint_timer_query.getQueryObjectEXT(query, GL_QUERY_RESULT_EXT)\n freeQuery(query)\n } else {\n pendingQueries[ptr++] = query\n }\n timeSum[i + 1] = queryTime\n queryPtr[i + 1] = ptr\n }\n pendingQueries.length = ptr\n\n // Update all pending stat queries\n ptr = 0\n for (i = 0; i < pendingStats.length; ++i) {\n var stats = pendingStats[i]\n var start = stats.startQueryIndex\n var end = stats.endQueryIndex\n stats.sum += timeSum[end] - timeSum[start]\n var startPtr = queryPtr[start]\n var endPtr = queryPtr[end]\n if (endPtr === startPtr) {\n stats.stats.gpuTime += stats.sum / 1e6\n freePendingStats(stats)\n } else {\n stats.startQueryIndex = startPtr\n stats.endQueryIndex = endPtr\n pendingStats[ptr++] = stats\n }\n }\n pendingStats.length = ptr\n }\n\n return {\n beginQuery: beginQuery,\n endQuery: endQuery,\n pushScopeStats: pushScopeStats,\n update: update,\n getNumPendingQueries: function () {\n return pendingQueries.length\n },\n clear: function () {\n queryPool.push.apply(queryPool, pendingQueries)\n for (var i = 0; i < queryPool.length; i++) {\n extensions.ext_disjoint_timer_query.deleteQueryEXT(queryPool[i])\n }\n pendingQueries.length = 0\n queryPool.length = 0\n },\n restore: function () {\n pendingQueries.length = 0\n queryPool.length = 0\n }\n }\n}\n\nvar GL_COLOR_BUFFER_BIT = 16384\nvar GL_DEPTH_BUFFER_BIT = 256\nvar GL_STENCIL_BUFFER_BIT = 1024\n\nvar GL_ARRAY_BUFFER = 34962\n\nvar CONTEXT_LOST_EVENT = 'webglcontextlost'\nvar CONTEXT_RESTORED_EVENT = 'webglcontextrestored'\n\nvar DYN_PROP = 1\nvar DYN_CONTEXT = 2\nvar DYN_STATE = 3\n\nfunction find (haystack, needle) {\n for (var i = 0; i < haystack.length; ++i) {\n if (haystack[i] === needle) {\n return i\n }\n }\n return -1\n}\n\nfunction wrapREGL (args) {\n var config = parseArgs(args)\n if (!config) {\n return null\n }\n\n var gl = config.gl\n var glAttributes = gl.getContextAttributes()\n var contextLost = gl.isContextLost()\n\n var extensionState = createExtensionCache(gl, config)\n if (!extensionState) {\n return null\n }\n\n var stringStore = createStringStore()\n var stats$$1 = stats()\n var cachedCode = config.cachedCode || {};\n var extensions = extensionState.extensions\n var timer = createTimer(gl, extensions)\n\n var START_TIME = clock()\n var WIDTH = gl.drawingBufferWidth\n var HEIGHT = gl.drawingBufferHeight\n\n var contextState = {\n tick: 0,\n time: 0,\n viewportWidth: WIDTH,\n viewportHeight: HEIGHT,\n framebufferWidth: WIDTH,\n framebufferHeight: HEIGHT,\n drawingBufferWidth: WIDTH,\n drawingBufferHeight: HEIGHT,\n pixelRatio: config.pixelRatio\n }\n var uniformState = {}\n var drawState = {\n elements: null,\n primitive: 4, // GL_TRIANGLES\n count: -1,\n offset: 0,\n instances: -1\n }\n\n var limits = wrapLimits(gl, extensions)\n var bufferState = wrapBufferState(\n gl,\n stats$$1,\n config,\n destroyBuffer)\n var elementState = wrapElementsState(gl, extensions, bufferState, stats$$1)\n var attributeState = wrapAttributeState(\n gl,\n extensions,\n limits,\n stats$$1,\n bufferState,\n elementState,\n drawState)\n function destroyBuffer (buffer) {\n return attributeState.destroyBuffer(buffer)\n }\n var shaderState = wrapShaderState(gl, stringStore, stats$$1, config)\n var textureState = createTextureSet(\n gl,\n extensions,\n limits,\n function () { core.procs.poll() },\n contextState,\n stats$$1,\n config)\n var renderbufferState = wrapRenderbuffers(gl, extensions, limits, stats$$1, config)\n var framebufferState = wrapFBOState(\n gl,\n extensions,\n limits,\n textureState,\n renderbufferState,\n stats$$1)\n var core = reglCore(\n gl,\n stringStore,\n extensions,\n limits,\n bufferState,\n elementState,\n textureState,\n framebufferState,\n uniformState,\n attributeState,\n shaderState,\n drawState,\n contextState,\n timer,\n cachedCode,\n config)\n var readPixels = wrapReadPixels(\n gl,\n framebufferState,\n core.procs.poll,\n contextState,\n glAttributes, extensions, limits)\n\n var nextState = core.next\n var canvas = gl.canvas\n\n var rafCallbacks = []\n var lossCallbacks = []\n var restoreCallbacks = []\n var destroyCallbacks = [config.onDestroy]\n\n var activeRAF = null\n function handleRAF () {\n if (rafCallbacks.length === 0) {\n if (timer) {\n timer.update()\n }\n activeRAF = null\n return\n }\n\n // schedule next animation frame\n activeRAF = raf.next(handleRAF)\n\n // poll for changes\n poll()\n\n // fire a callback for all pending rafs\n for (var i = rafCallbacks.length - 1; i >= 0; --i) {\n var cb = rafCallbacks[i]\n if (cb) {\n cb(contextState, null, 0)\n }\n }\n\n // flush all pending webgl calls\n gl.flush()\n\n // poll GPU timers *after* gl.flush so we don't delay command dispatch\n if (timer) {\n timer.update()\n }\n }\n\n function startRAF () {\n if (!activeRAF && rafCallbacks.length > 0) {\n activeRAF = raf.next(handleRAF)\n }\n }\n\n function stopRAF () {\n if (activeRAF) {\n raf.cancel(handleRAF)\n activeRAF = null\n }\n }\n\n function handleContextLoss (event) {\n event.preventDefault()\n\n // set context lost flag\n contextLost = true\n\n // pause request animation frame\n stopRAF()\n\n // lose context\n lossCallbacks.forEach(function (cb) {\n cb()\n })\n }\n\n function handleContextRestored (event) {\n // clear error code\n gl.getError()\n\n // clear context lost flag\n contextLost = false\n\n // refresh state\n extensionState.restore()\n shaderState.restore()\n bufferState.restore()\n textureState.restore()\n renderbufferState.restore()\n framebufferState.restore()\n attributeState.restore()\n if (timer) {\n timer.restore()\n }\n\n // refresh state\n core.procs.refresh()\n\n // restart RAF\n startRAF()\n\n // restore context\n restoreCallbacks.forEach(function (cb) {\n cb()\n })\n }\n\n if (canvas) {\n canvas.addEventListener(CONTEXT_LOST_EVENT, handleContextLoss, false)\n canvas.addEventListener(CONTEXT_RESTORED_EVENT, handleContextRestored, false)\n }\n\n function destroy () {\n rafCallbacks.length = 0\n stopRAF()\n\n if (canvas) {\n canvas.removeEventListener(CONTEXT_LOST_EVENT, handleContextLoss)\n canvas.removeEventListener(CONTEXT_RESTORED_EVENT, handleContextRestored)\n }\n\n shaderState.clear()\n framebufferState.clear()\n renderbufferState.clear()\n attributeState.clear()\n textureState.clear()\n elementState.clear()\n bufferState.clear()\n\n if (timer) {\n timer.clear()\n }\n\n destroyCallbacks.forEach(function (cb) {\n cb()\n })\n }\n\n function compileProcedure (options) {\n \n \n\n function flattenNestedOptions (options) {\n var result = extend({}, options)\n delete result.uniforms\n delete result.attributes\n delete result.context\n delete result.vao\n\n if ('stencil' in result && result.stencil.op) {\n result.stencil.opBack = result.stencil.opFront = result.stencil.op\n delete result.stencil.op\n }\n\n function merge (name) {\n if (name in result) {\n var child = result[name]\n delete result[name]\n Object.keys(child).forEach(function (prop) {\n result[name + '.' + prop] = child[prop]\n })\n }\n }\n merge('blend')\n merge('depth')\n merge('cull')\n merge('stencil')\n merge('polygonOffset')\n merge('scissor')\n merge('sample')\n\n if ('vao' in options) {\n result.vao = options.vao\n }\n\n return result\n }\n\n function separateDynamic (object, useArrays) {\n var staticItems = {}\n var dynamicItems = {}\n Object.keys(object).forEach(function (option) {\n var value = object[option]\n if (dynamic.isDynamic(value)) {\n dynamicItems[option] = dynamic.unbox(value, option)\n return\n } else if (useArrays && Array.isArray(value)) {\n for (var i = 0; i < value.length; ++i) {\n if (dynamic.isDynamic(value[i])) {\n dynamicItems[option] = dynamic.unbox(value, option)\n return\n }\n }\n }\n staticItems[option] = value\n })\n return {\n dynamic: dynamicItems,\n static: staticItems\n }\n }\n\n // Treat context variables separate from other dynamic variables\n var context = separateDynamic(options.context || {}, true)\n var uniforms = separateDynamic(options.uniforms || {}, true)\n var attributes = separateDynamic(options.attributes || {}, false)\n var opts = separateDynamic(flattenNestedOptions(options), false)\n\n var stats$$1 = {\n gpuTime: 0.0,\n cpuTime: 0.0,\n count: 0\n }\n\n var compiled = core.compile(opts, attributes, uniforms, context, stats$$1)\n\n var draw = compiled.draw\n var batch = compiled.batch\n var scope = compiled.scope\n\n // FIXME: we should modify code generation for batch commands so this\n // isn't necessary\n var EMPTY_ARRAY = []\n function reserve (count) {\n while (EMPTY_ARRAY.length < count) {\n EMPTY_ARRAY.push(null)\n }\n return EMPTY_ARRAY\n }\n\n function REGLCommand (args, body) {\n var i\n if (contextLost) {\n \n }\n if (typeof args === 'function') {\n return scope.call(this, null, args, 0)\n } else if (typeof body === 'function') {\n if (typeof args === 'number') {\n for (i = 0; i < args; ++i) {\n scope.call(this, null, body, i)\n }\n } else if (Array.isArray(args)) {\n for (i = 0; i < args.length; ++i) {\n scope.call(this, args[i], body, i)\n }\n } else {\n return scope.call(this, args, body, 0)\n }\n } else if (typeof args === 'number') {\n if (args > 0) {\n return batch.call(this, reserve(args | 0), args | 0)\n }\n } else if (Array.isArray(args)) {\n if (args.length) {\n return batch.call(this, args, args.length)\n }\n } else {\n return draw.call(this, args)\n }\n }\n\n return extend(REGLCommand, {\n stats: stats$$1,\n destroy: function () {\n compiled.destroy()\n }\n })\n }\n\n var setFBO = framebufferState.setFBO = compileProcedure({\n framebuffer: dynamic.define.call(null, DYN_PROP, 'framebuffer')\n })\n\n function clearImpl (_, options) {\n var clearFlags = 0\n core.procs.poll()\n\n var c = options.color\n if (c) {\n gl.clearColor(+c[0] || 0, +c[1] || 0, +c[2] || 0, +c[3] || 0)\n clearFlags |= GL_COLOR_BUFFER_BIT\n }\n if ('depth' in options) {\n gl.clearDepth(+options.depth)\n clearFlags |= GL_DEPTH_BUFFER_BIT\n }\n if ('stencil' in options) {\n gl.clearStencil(options.stencil | 0)\n clearFlags |= GL_STENCIL_BUFFER_BIT\n }\n\n \n gl.clear(clearFlags)\n }\n\n function clear (options) {\n \n if ('framebuffer' in options) {\n if (options.framebuffer &&\n options.framebuffer_reglType === 'framebufferCube') {\n for (var i = 0; i < 6; ++i) {\n setFBO(extend({\n framebuffer: options.framebuffer.faces[i]\n }, options), clearImpl)\n }\n } else {\n setFBO(options, clearImpl)\n }\n } else {\n clearImpl(null, options)\n }\n }\n\n function frame (cb) {\n \n rafCallbacks.push(cb)\n\n function cancel () {\n // FIXME: should we check something other than equals cb here?\n // what if a user calls frame twice with the same callback...\n //\n var i = find(rafCallbacks, cb)\n \n function pendingCancel () {\n var index = find(rafCallbacks, pendingCancel)\n rafCallbacks[index] = rafCallbacks[rafCallbacks.length - 1]\n rafCallbacks.length -= 1\n if (rafCallbacks.length <= 0) {\n stopRAF()\n }\n }\n rafCallbacks[i] = pendingCancel\n }\n\n startRAF()\n\n return {\n cancel: cancel\n }\n }\n\n // poll viewport\n function pollViewport () {\n var viewport = nextState.viewport\n var scissorBox = nextState.scissor_box\n viewport[0] = viewport[1] = scissorBox[0] = scissorBox[1] = 0\n contextState.viewportWidth =\n contextState.framebufferWidth =\n contextState.drawingBufferWidth =\n viewport[2] =\n scissorBox[2] = gl.drawingBufferWidth\n contextState.viewportHeight =\n contextState.framebufferHeight =\n contextState.drawingBufferHeight =\n viewport[3] =\n scissorBox[3] = gl.drawingBufferHeight\n }\n\n function poll () {\n contextState.tick += 1\n contextState.time = now()\n pollViewport()\n core.procs.poll()\n }\n\n function refresh () {\n textureState.refresh()\n pollViewport()\n core.procs.refresh()\n if (timer) {\n timer.update()\n }\n }\n\n function now () {\n return (clock() - START_TIME) / 1000.0\n }\n\n refresh()\n\n function addListener (event, callback) {\n \n\n var callbacks\n switch (event) {\n case 'frame':\n return frame(callback)\n case 'lost':\n callbacks = lossCallbacks\n break\n case 'restore':\n callbacks = restoreCallbacks\n break\n case 'destroy':\n callbacks = destroyCallbacks\n break\n default:\n \n }\n\n callbacks.push(callback)\n return {\n cancel: function () {\n for (var i = 0; i < callbacks.length; ++i) {\n if (callbacks[i] === callback) {\n callbacks[i] = callbacks[callbacks.length - 1]\n callbacks.pop()\n return\n }\n }\n }\n }\n }\n\n function getCachedCode() {\n return cachedCode\n }\n\n function preloadCachedCode(moreCache) {\n Object.entries(moreCache).forEach(function (kv) {\n cachedCode[kv[0]] = kv[1]\n })\n }\n\n var regl = extend(compileProcedure, {\n // Clear current FBO\n clear: clear,\n\n // Short cuts for dynamic variables\n prop: dynamic.define.bind(null, DYN_PROP),\n context: dynamic.define.bind(null, DYN_CONTEXT),\n this: dynamic.define.bind(null, DYN_STATE),\n\n // executes an empty draw command\n draw: compileProcedure({}),\n\n // Resources\n buffer: function (options) {\n return bufferState.create(options, GL_ARRAY_BUFFER, false, false)\n },\n elements: function (options) {\n return elementState.create(options, false)\n },\n texture: textureState.create2D,\n cube: textureState.createCube,\n renderbuffer: renderbufferState.create,\n framebuffer: framebufferState.create,\n framebufferCube: framebufferState.createCube,\n vao: attributeState.createVAO,\n\n // Expose context attributes\n attributes: glAttributes,\n\n // Frame rendering\n frame: frame,\n on: addListener,\n\n // System limits\n limits: limits,\n hasExtension: function (name) {\n return limits.extensions.indexOf(name.toLowerCase()) >= 0\n },\n\n // Read pixels\n read: readPixels,\n\n // Destroy regl and all associated resources\n destroy: destroy,\n\n // Direct GL state manipulation\n _gl: gl,\n _refresh: refresh,\n\n poll: function () {\n poll()\n if (timer) {\n timer.update()\n }\n },\n\n // Current time\n now: now,\n\n // regl Statistics Information\n stats: stats$$1,\n\n // cache generated code\n getCachedCode: getCachedCode,\n preloadCachedCode: preloadCachedCode\n })\n\n config.onDone(null, regl)\n\n return regl\n}\n\nreturn wrapREGL;\n\n})));\n","/*! safe-buffer. MIT License. Feross Aboukhadijeh */\n/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.prototype = Object.create(Buffer.prototype)\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","/**\n * @license React\n * scheduler.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';function f(a,b){var c=a.length;a.push(b);a:for(;0>>1,e=a[d];if(0>>1;dg(C,c))ng(x,C)?(a[d]=x,a[n]=c,d=n):(a[d]=C,a[m]=c,d=m);else if(ng(x,c))a[d]=x,a[n]=c,d=n;else break a}}return b}\nfunction g(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}if(\"object\"===typeof performance&&\"function\"===typeof performance.now){var l=performance;exports.unstable_now=function(){return l.now()}}else{var p=Date,q=p.now();exports.unstable_now=function(){return p.now()-q}}var r=[],t=[],u=1,v=null,y=3,z=!1,A=!1,B=!1,D=\"function\"===typeof setTimeout?setTimeout:null,E=\"function\"===typeof clearTimeout?clearTimeout:null,F=\"undefined\"!==typeof setImmediate?setImmediate:null;\n\"undefined\"!==typeof navigator&&void 0!==navigator.scheduling&&void 0!==navigator.scheduling.isInputPending&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function G(a){for(var b=h(t);null!==b;){if(null===b.callback)k(t);else if(b.startTime<=a)k(t),b.sortIndex=b.expirationTime,f(r,b);else break;b=h(t)}}function H(a){B=!1;G(a);if(!A)if(null!==h(r))A=!0,I(J);else{var b=h(t);null!==b&&K(H,b.startTime-a)}}\nfunction J(a,b){A=!1;B&&(B=!1,E(L),L=-1);z=!0;var c=y;try{G(b);for(v=h(r);null!==v&&(!(v.expirationTime>b)||a&&!M());){var d=v.callback;if(\"function\"===typeof d){v.callback=null;y=v.priorityLevel;var e=d(v.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?v.callback=e:v===h(r)&&k(r);G(b)}else k(r);v=h(r)}if(null!==v)var w=!0;else{var m=h(t);null!==m&&K(H,m.startTime-b);w=!1}return w}finally{v=null,y=c,z=!1}}var N=!1,O=null,L=-1,P=5,Q=-1;\nfunction M(){return exports.unstable_now()-Qa||125d?(a.sortIndex=c,f(t,a),null===h(r)&&a===h(t)&&(B?(E(L),L=-1):B=!0,K(H,c-d))):(a.sortIndex=e,f(r,a),A||z||(A=!0,I(J)));return a};\nexports.unstable_shouldYield=M;exports.unstable_wrapCallback=function(a){var b=y;return function(){var c=y;y=b;try{return a.apply(this,arguments)}finally{y=c}}};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/scheduler.production.min.js');\n} else {\n module.exports = require('./cjs/scheduler.development.js');\n}\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\nvar define = require('define-data-property');\nvar hasDescriptors = require('has-property-descriptors')();\nvar gOPD = require('gopd');\n\nvar $TypeError = require('es-errors/type');\nvar $floor = GetIntrinsic('%Math.floor%');\n\n/** @type {import('.')} */\nmodule.exports = function setFunctionLength(fn, length) {\n\tif (typeof fn !== 'function') {\n\t\tthrow new $TypeError('`fn` is not a function');\n\t}\n\tif (typeof length !== 'number' || length < 0 || length > 0xFFFFFFFF || $floor(length) !== length) {\n\t\tthrow new $TypeError('`length` must be a positive 32-bit integer');\n\t}\n\n\tvar loose = arguments.length > 2 && !!arguments[2];\n\n\tvar functionLengthIsConfigurable = true;\n\tvar functionLengthIsWritable = true;\n\tif ('length' in fn && gOPD) {\n\t\tvar desc = gOPD(fn, 'length');\n\t\tif (desc && !desc.configurable) {\n\t\t\tfunctionLengthIsConfigurable = false;\n\t\t}\n\t\tif (desc && !desc.writable) {\n\t\t\tfunctionLengthIsWritable = false;\n\t\t}\n\t}\n\n\tif (functionLengthIsConfigurable || functionLengthIsWritable || !loose) {\n\t\tif (hasDescriptors) {\n\t\t\tdefine(/** @type {Parameters[0]} */ (fn), 'length', length, true, true);\n\t\t} else {\n\t\t\tdefine(/** @type {Parameters[0]} */ (fn), 'length', length);\n\t\t}\n\t}\n\treturn fn;\n};\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\nvar callBound = require('call-bind/callBound');\nvar inspect = require('object-inspect');\n\nvar $TypeError = require('es-errors/type');\nvar $WeakMap = GetIntrinsic('%WeakMap%', true);\nvar $Map = GetIntrinsic('%Map%', true);\n\nvar $weakMapGet = callBound('WeakMap.prototype.get', true);\nvar $weakMapSet = callBound('WeakMap.prototype.set', true);\nvar $weakMapHas = callBound('WeakMap.prototype.has', true);\nvar $mapGet = callBound('Map.prototype.get', true);\nvar $mapSet = callBound('Map.prototype.set', true);\nvar $mapHas = callBound('Map.prototype.has', true);\n\n/*\n* This function traverses the list returning the node corresponding to the given key.\n*\n* That node is also moved to the head of the list, so that if it's accessed again we don't need to traverse the whole list. By doing so, all the recently used nodes can be accessed relatively quickly.\n*/\n/** @type {import('.').listGetNode} */\nvar listGetNode = function (list, key) { // eslint-disable-line consistent-return\n\t/** @type {typeof list | NonNullable<(typeof list)['next']>} */\n\tvar prev = list;\n\t/** @type {(typeof list)['next']} */\n\tvar curr;\n\tfor (; (curr = prev.next) !== null; prev = curr) {\n\t\tif (curr.key === key) {\n\t\t\tprev.next = curr.next;\n\t\t\t// eslint-disable-next-line no-extra-parens\n\t\t\tcurr.next = /** @type {NonNullable} */ (list.next);\n\t\t\tlist.next = curr; // eslint-disable-line no-param-reassign\n\t\t\treturn curr;\n\t\t}\n\t}\n};\n\n/** @type {import('.').listGet} */\nvar listGet = function (objects, key) {\n\tvar node = listGetNode(objects, key);\n\treturn node && node.value;\n};\n/** @type {import('.').listSet} */\nvar listSet = function (objects, key, value) {\n\tvar node = listGetNode(objects, key);\n\tif (node) {\n\t\tnode.value = value;\n\t} else {\n\t\t// Prepend the new node to the beginning of the list\n\t\tobjects.next = /** @type {import('.').ListNode} */ ({ // eslint-disable-line no-param-reassign, no-extra-parens\n\t\t\tkey: key,\n\t\t\tnext: objects.next,\n\t\t\tvalue: value\n\t\t});\n\t}\n};\n/** @type {import('.').listHas} */\nvar listHas = function (objects, key) {\n\treturn !!listGetNode(objects, key);\n};\n\n/** @type {import('.')} */\nmodule.exports = function getSideChannel() {\n\t/** @type {WeakMap} */ var $wm;\n\t/** @type {Map} */ var $m;\n\t/** @type {import('.').RootNode} */ var $o;\n\n\t/** @type {import('.').Channel} */\n\tvar channel = {\n\t\tassert: function (key) {\n\t\t\tif (!channel.has(key)) {\n\t\t\t\tthrow new $TypeError('Side channel does not contain ' + inspect(key));\n\t\t\t}\n\t\t},\n\t\tget: function (key) { // eslint-disable-line consistent-return\n\t\t\tif ($WeakMap && key && (typeof key === 'object' || typeof key === 'function')) {\n\t\t\t\tif ($wm) {\n\t\t\t\t\treturn $weakMapGet($wm, key);\n\t\t\t\t}\n\t\t\t} else if ($Map) {\n\t\t\t\tif ($m) {\n\t\t\t\t\treturn $mapGet($m, key);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif ($o) { // eslint-disable-line no-lonely-if\n\t\t\t\t\treturn listGet($o, key);\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\thas: function (key) {\n\t\t\tif ($WeakMap && key && (typeof key === 'object' || typeof key === 'function')) {\n\t\t\t\tif ($wm) {\n\t\t\t\t\treturn $weakMapHas($wm, key);\n\t\t\t\t}\n\t\t\t} else if ($Map) {\n\t\t\t\tif ($m) {\n\t\t\t\t\treturn $mapHas($m, key);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif ($o) { // eslint-disable-line no-lonely-if\n\t\t\t\t\treturn listHas($o, key);\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn false;\n\t\t},\n\t\tset: function (key, value) {\n\t\t\tif ($WeakMap && key && (typeof key === 'object' || typeof key === 'function')) {\n\t\t\t\tif (!$wm) {\n\t\t\t\t\t$wm = new $WeakMap();\n\t\t\t\t}\n\t\t\t\t$weakMapSet($wm, key, value);\n\t\t\t} else if ($Map) {\n\t\t\t\tif (!$m) {\n\t\t\t\t\t$m = new $Map();\n\t\t\t\t}\n\t\t\t\t$mapSet($m, key, value);\n\t\t\t} else {\n\t\t\t\tif (!$o) {\n\t\t\t\t\t// Initialize the linked list as an empty node, so that we don't have to special-case handling of the first node: we can always refer to it as (previous node).next, instead of something like (list).head\n\t\t\t\t\t$o = { key: {}, next: null };\n\t\t\t\t}\n\t\t\t\tlistSet($o, key, value);\n\t\t\t}\n\t\t}\n\t};\n\treturn channel;\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nmodule.exports = Stream;\n\nvar EE = require('events').EventEmitter;\nvar inherits = require('inherits');\n\ninherits(Stream, EE);\nStream.Readable = require('readable-stream/lib/_stream_readable.js');\nStream.Writable = require('readable-stream/lib/_stream_writable.js');\nStream.Duplex = require('readable-stream/lib/_stream_duplex.js');\nStream.Transform = require('readable-stream/lib/_stream_transform.js');\nStream.PassThrough = require('readable-stream/lib/_stream_passthrough.js');\nStream.finished = require('readable-stream/lib/internal/streams/end-of-stream.js')\nStream.pipeline = require('readable-stream/lib/internal/streams/pipeline.js')\n\n// Backwards-compat with node 0.4.x\nStream.Stream = Stream;\n\n\n\n// old-style streams. Note that the pipe method (the only relevant\n// part of this class) is overridden in the Readable class.\n\nfunction Stream() {\n EE.call(this);\n}\n\nStream.prototype.pipe = function(dest, options) {\n var source = this;\n\n function ondata(chunk) {\n if (dest.writable) {\n if (false === dest.write(chunk) && source.pause) {\n source.pause();\n }\n }\n }\n\n source.on('data', ondata);\n\n function ondrain() {\n if (source.readable && source.resume) {\n source.resume();\n }\n }\n\n dest.on('drain', ondrain);\n\n // If the 'end' option is not supplied, dest.end() will be called when\n // source gets the 'end' or 'close' events. Only dest.end() once.\n if (!dest._isStdio && (!options || options.end !== false)) {\n source.on('end', onend);\n source.on('close', onclose);\n }\n\n var didOnEnd = false;\n function onend() {\n if (didOnEnd) return;\n didOnEnd = true;\n\n dest.end();\n }\n\n\n function onclose() {\n if (didOnEnd) return;\n didOnEnd = true;\n\n if (typeof dest.destroy === 'function') dest.destroy();\n }\n\n // don't leave dangling pipes when there are errors.\n function onerror(er) {\n cleanup();\n if (EE.listenerCount(this, 'error') === 0) {\n throw er; // Unhandled stream error in pipe.\n }\n }\n\n source.on('error', onerror);\n dest.on('error', onerror);\n\n // remove all the event listeners that were added.\n function cleanup() {\n source.removeListener('data', ondata);\n dest.removeListener('drain', ondrain);\n\n source.removeListener('end', onend);\n source.removeListener('close', onclose);\n\n source.removeListener('error', onerror);\n dest.removeListener('error', onerror);\n\n source.removeListener('end', cleanup);\n source.removeListener('close', cleanup);\n\n dest.removeListener('close', cleanup);\n }\n\n source.on('end', cleanup);\n source.on('close', cleanup);\n\n dest.on('close', cleanup);\n\n dest.emit('pipe', source);\n\n // Allow for unix-like usage: A.pipe(B).pipe(C)\n return dest;\n};\n","'use strict';\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nvar codes = {};\n\nfunction createErrorType(code, message, Base) {\n if (!Base) {\n Base = Error;\n }\n\n function getMessage(arg1, arg2, arg3) {\n if (typeof message === 'string') {\n return message;\n } else {\n return message(arg1, arg2, arg3);\n }\n }\n\n var NodeError =\n /*#__PURE__*/\n function (_Base) {\n _inheritsLoose(NodeError, _Base);\n\n function NodeError(arg1, arg2, arg3) {\n return _Base.call(this, getMessage(arg1, arg2, arg3)) || this;\n }\n\n return NodeError;\n }(Base);\n\n NodeError.prototype.name = Base.name;\n NodeError.prototype.code = code;\n codes[code] = NodeError;\n} // https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js\n\n\nfunction oneOf(expected, thing) {\n if (Array.isArray(expected)) {\n var len = expected.length;\n expected = expected.map(function (i) {\n return String(i);\n });\n\n if (len > 2) {\n return \"one of \".concat(thing, \" \").concat(expected.slice(0, len - 1).join(', '), \", or \") + expected[len - 1];\n } else if (len === 2) {\n return \"one of \".concat(thing, \" \").concat(expected[0], \" or \").concat(expected[1]);\n } else {\n return \"of \".concat(thing, \" \").concat(expected[0]);\n }\n } else {\n return \"of \".concat(thing, \" \").concat(String(expected));\n }\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith\n\n\nfunction startsWith(str, search, pos) {\n return str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith\n\n\nfunction endsWith(str, search, this_len) {\n if (this_len === undefined || this_len > str.length) {\n this_len = str.length;\n }\n\n return str.substring(this_len - search.length, this_len) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes\n\n\nfunction includes(str, search, start) {\n if (typeof start !== 'number') {\n start = 0;\n }\n\n if (start + search.length > str.length) {\n return false;\n } else {\n return str.indexOf(search, start) !== -1;\n }\n}\n\ncreateErrorType('ERR_INVALID_OPT_VALUE', function (name, value) {\n return 'The value \"' + value + '\" is invalid for option \"' + name + '\"';\n}, TypeError);\ncreateErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) {\n // determiner: 'must be' or 'must not be'\n var determiner;\n\n if (typeof expected === 'string' && startsWith(expected, 'not ')) {\n determiner = 'must not be';\n expected = expected.replace(/^not /, '');\n } else {\n determiner = 'must be';\n }\n\n var msg;\n\n if (endsWith(name, ' argument')) {\n // For cases like 'first argument'\n msg = \"The \".concat(name, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n } else {\n var type = includes(name, '.') ? 'property' : 'argument';\n msg = \"The \\\"\".concat(name, \"\\\" \").concat(type, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n }\n\n msg += \". Received type \".concat(typeof actual);\n return msg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF');\ncreateErrorType('ERR_METHOD_NOT_IMPLEMENTED', function (name) {\n return 'The ' + name + ' method is not implemented';\n});\ncreateErrorType('ERR_STREAM_PREMATURE_CLOSE', 'Premature close');\ncreateErrorType('ERR_STREAM_DESTROYED', function (name) {\n return 'Cannot call ' + name + ' after a stream was destroyed';\n});\ncreateErrorType('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times');\ncreateErrorType('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable');\ncreateErrorType('ERR_STREAM_WRITE_AFTER_END', 'write after end');\ncreateErrorType('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError);\ncreateErrorType('ERR_UNKNOWN_ENCODING', function (arg) {\n return 'Unknown encoding: ' + arg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_UNSHIFT_AFTER_END_EVENT', 'stream.unshift() after end event');\nmodule.exports.codes = codes;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n\n'use strict';\n\n/**/\nvar objectKeys = Object.keys || function (obj) {\n var keys = [];\n for (var key in obj) keys.push(key);\n return keys;\n};\n/**/\n\nmodule.exports = Duplex;\nvar Readable = require('./_stream_readable');\nvar Writable = require('./_stream_writable');\nrequire('inherits')(Duplex, Readable);\n{\n // Allow the keys array to be GC'ed.\n var keys = objectKeys(Writable.prototype);\n for (var v = 0; v < keys.length; v++) {\n var method = keys[v];\n if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n }\n}\nfunction Duplex(options) {\n if (!(this instanceof Duplex)) return new Duplex(options);\n Readable.call(this, options);\n Writable.call(this, options);\n this.allowHalfOpen = true;\n if (options) {\n if (options.readable === false) this.readable = false;\n if (options.writable === false) this.writable = false;\n if (options.allowHalfOpen === false) {\n this.allowHalfOpen = false;\n this.once('end', onend);\n }\n }\n}\nObject.defineProperty(Duplex.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\n\n// the no-half-open enforcer\nfunction onend() {\n // If the writable side ended, then we're ok.\n if (this._writableState.ended) return;\n\n // no more data can be written.\n // But allow more writes to happen in this tick.\n process.nextTick(onEndNT, this);\n}\nfunction onEndNT(self) {\n self.end();\n}\nObject.defineProperty(Duplex.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined || this._writableState === undefined) {\n return false;\n }\n return this._readableState.destroyed && this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (this._readableState === undefined || this._writableState === undefined) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n this._writableState.destroyed = value;\n }\n});","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n\n'use strict';\n\nmodule.exports = PassThrough;\nvar Transform = require('./_stream_transform');\nrequire('inherits')(PassThrough, Transform);\nfunction PassThrough(options) {\n if (!(this instanceof PassThrough)) return new PassThrough(options);\n Transform.call(this, options);\n}\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n cb(null, chunk);\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nmodule.exports = Readable;\n\n/**/\nvar Duplex;\n/**/\n\nReadable.ReadableState = ReadableState;\n\n/**/\nvar EE = require('events').EventEmitter;\nvar EElistenerCount = function EElistenerCount(emitter, type) {\n return emitter.listeners(type).length;\n};\n/**/\n\n/**/\nvar Stream = require('./internal/streams/stream');\n/**/\n\nvar Buffer = require('buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\n/**/\nvar debugUtil = require('util');\nvar debug;\nif (debugUtil && debugUtil.debuglog) {\n debug = debugUtil.debuglog('stream');\n} else {\n debug = function debug() {};\n}\n/**/\n\nvar BufferList = require('./internal/streams/buffer_list');\nvar destroyImpl = require('./internal/streams/destroy');\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT;\n\n// Lazy loaded to improve the startup performance.\nvar StringDecoder;\nvar createReadableStreamAsyncIterator;\nvar from;\nrequire('inherits')(Readable, Stream);\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nvar kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];\nfunction prependListener(emitter, event, fn) {\n // Sadly this is not cacheable as some libraries bundle their own\n // event emitter implementation with them.\n if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn);\n\n // This is a hack to make sure that our error handler is attached before any\n // userland ones. NEVER DO THIS. This is here only because this code needs\n // to continue to work with older versions of Node.js that do not include\n // the prependListener() method. The goal is to eventually remove this hack.\n if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];\n}\nfunction ReadableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex;\n\n // object stream flag. Used to make read(n) ignore n and to\n // make all the buffer merging and length checks go away\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode;\n\n // the point at which it stops calling _read() to fill the buffer\n // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex);\n\n // A linked list is used to store data chunks instead of an array because the\n // linked list can remove elements from the beginning faster than\n // array.shift()\n this.buffer = new BufferList();\n this.length = 0;\n this.pipes = null;\n this.pipesCount = 0;\n this.flowing = null;\n this.ended = false;\n this.endEmitted = false;\n this.reading = false;\n\n // a flag to be able to tell if the event 'readable'/'data' is emitted\n // immediately, or on a later tick. We set this to true at first, because\n // any actions that shouldn't happen until \"later\" should generally also\n // not happen before the first read call.\n this.sync = true;\n\n // whenever we return null, then we set a flag to say\n // that we're awaiting a 'readable' event emission.\n this.needReadable = false;\n this.emittedReadable = false;\n this.readableListening = false;\n this.resumeScheduled = false;\n this.paused = true;\n\n // Should close be emitted on destroy. Defaults to true.\n this.emitClose = options.emitClose !== false;\n\n // Should .destroy() be called after 'end' (and potentially 'finish')\n this.autoDestroy = !!options.autoDestroy;\n\n // has it been destroyed\n this.destroyed = false;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // the number of writers that are awaiting a drain event in .pipe()s\n this.awaitDrain = 0;\n\n // if true, a maybeReadMore has been scheduled\n this.readingMore = false;\n this.decoder = null;\n this.encoding = null;\n if (options.encoding) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this.decoder = new StringDecoder(options.encoding);\n this.encoding = options.encoding;\n }\n}\nfunction Readable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n if (!(this instanceof Readable)) return new Readable(options);\n\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the ReadableState constructor, at least with V8 6.5\n var isDuplex = this instanceof Duplex;\n this._readableState = new ReadableState(options, this, isDuplex);\n\n // legacy\n this.readable = true;\n if (options) {\n if (typeof options.read === 'function') this._read = options.read;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n }\n Stream.call(this);\n}\nObject.defineProperty(Readable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined) {\n return false;\n }\n return this._readableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._readableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n }\n});\nReadable.prototype.destroy = destroyImpl.destroy;\nReadable.prototype._undestroy = destroyImpl.undestroy;\nReadable.prototype._destroy = function (err, cb) {\n cb(err);\n};\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function (chunk, encoding) {\n var state = this._readableState;\n var skipChunkCheck;\n if (!state.objectMode) {\n if (typeof chunk === 'string') {\n encoding = encoding || state.defaultEncoding;\n if (encoding !== state.encoding) {\n chunk = Buffer.from(chunk, encoding);\n encoding = '';\n }\n skipChunkCheck = true;\n }\n } else {\n skipChunkCheck = true;\n }\n return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);\n};\n\n// Unshift should *always* be something directly out of read()\nReadable.prototype.unshift = function (chunk) {\n return readableAddChunk(this, chunk, null, true, false);\n};\nfunction readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {\n debug('readableAddChunk', chunk);\n var state = stream._readableState;\n if (chunk === null) {\n state.reading = false;\n onEofChunk(stream, state);\n } else {\n var er;\n if (!skipChunkCheck) er = chunkInvalid(state, chunk);\n if (er) {\n errorOrDestroy(stream, er);\n } else if (state.objectMode || chunk && chunk.length > 0) {\n if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n if (addToFront) {\n if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true);\n } else if (state.ended) {\n errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF());\n } else if (state.destroyed) {\n return false;\n } else {\n state.reading = false;\n if (state.decoder && !encoding) {\n chunk = state.decoder.write(chunk);\n if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);\n } else {\n addChunk(stream, state, chunk, false);\n }\n }\n } else if (!addToFront) {\n state.reading = false;\n maybeReadMore(stream, state);\n }\n }\n\n // We can push more data if we are below the highWaterMark.\n // Also, if we have no data yet, we can stand some more bytes.\n // This is to work around cases where hwm=0, such as the repl.\n return !state.ended && (state.length < state.highWaterMark || state.length === 0);\n}\nfunction addChunk(stream, state, chunk, addToFront) {\n if (state.flowing && state.length === 0 && !state.sync) {\n state.awaitDrain = 0;\n stream.emit('data', chunk);\n } else {\n // update the buffer info.\n state.length += state.objectMode ? 1 : chunk.length;\n if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n if (state.needReadable) emitReadable(stream);\n }\n maybeReadMore(stream, state);\n}\nfunction chunkInvalid(state, chunk) {\n var er;\n if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk);\n }\n return er;\n}\nReadable.prototype.isPaused = function () {\n return this._readableState.flowing === false;\n};\n\n// backwards compatibility.\nReadable.prototype.setEncoding = function (enc) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n var decoder = new StringDecoder(enc);\n this._readableState.decoder = decoder;\n // If setEncoding(null), decoder.encoding equals utf8\n this._readableState.encoding = this._readableState.decoder.encoding;\n\n // Iterate over current buffer to convert already stored Buffers:\n var p = this._readableState.buffer.head;\n var content = '';\n while (p !== null) {\n content += decoder.write(p.data);\n p = p.next;\n }\n this._readableState.buffer.clear();\n if (content !== '') this._readableState.buffer.push(content);\n this._readableState.length = content.length;\n return this;\n};\n\n// Don't raise the hwm > 1GB\nvar MAX_HWM = 0x40000000;\nfunction computeNewHighWaterMark(n) {\n if (n >= MAX_HWM) {\n // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE.\n n = MAX_HWM;\n } else {\n // Get the next highest power of 2 to prevent increasing hwm excessively in\n // tiny amounts\n n--;\n n |= n >>> 1;\n n |= n >>> 2;\n n |= n >>> 4;\n n |= n >>> 8;\n n |= n >>> 16;\n n++;\n }\n return n;\n}\n\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction howMuchToRead(n, state) {\n if (n <= 0 || state.length === 0 && state.ended) return 0;\n if (state.objectMode) return 1;\n if (n !== n) {\n // Only flow one buffer at a time\n if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;\n }\n // If we're asking for more than the current hwm, then raise the hwm.\n if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n if (n <= state.length) return n;\n // Don't have enough\n if (!state.ended) {\n state.needReadable = true;\n return 0;\n }\n return state.length;\n}\n\n// you can override either this method, or the async _read(n) below.\nReadable.prototype.read = function (n) {\n debug('read', n);\n n = parseInt(n, 10);\n var state = this._readableState;\n var nOrig = n;\n if (n !== 0) state.emittedReadable = false;\n\n // if we're doing read(0) to trigger a readable event, but we\n // already have a bunch of data in the buffer, then just trigger\n // the 'readable' event and move on.\n if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) {\n debug('read: emitReadable', state.length, state.ended);\n if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n return null;\n }\n n = howMuchToRead(n, state);\n\n // if we've ended, and we're now clear, then finish it up.\n if (n === 0 && state.ended) {\n if (state.length === 0) endReadable(this);\n return null;\n }\n\n // All the actual chunk generation logic needs to be\n // *below* the call to _read. The reason is that in certain\n // synthetic stream cases, such as passthrough streams, _read\n // may be a completely synchronous operation which may change\n // the state of the read buffer, providing enough data when\n // before there was *not* enough.\n //\n // So, the steps are:\n // 1. Figure out what the state of things will be after we do\n // a read from the buffer.\n //\n // 2. If that resulting state will trigger a _read, then call _read.\n // Note that this may be asynchronous, or synchronous. Yes, it is\n // deeply ugly to write APIs this way, but that still doesn't mean\n // that the Readable class should behave improperly, as streams are\n // designed to be sync/async agnostic.\n // Take note if the _read call is sync or async (ie, if the read call\n // has returned yet), so that we know whether or not it's safe to emit\n // 'readable' etc.\n //\n // 3. Actually pull the requested chunks out of the buffer and return.\n\n // if we need a readable event, then we need to do some reading.\n var doRead = state.needReadable;\n debug('need readable', doRead);\n\n // if we currently have less than the highWaterMark, then also read some\n if (state.length === 0 || state.length - n < state.highWaterMark) {\n doRead = true;\n debug('length less than watermark', doRead);\n }\n\n // however, if we've ended, then there's no point, and if we're already\n // reading, then it's unnecessary.\n if (state.ended || state.reading) {\n doRead = false;\n debug('reading or ended', doRead);\n } else if (doRead) {\n debug('do read');\n state.reading = true;\n state.sync = true;\n // if the length is currently zero, then we *need* a readable event.\n if (state.length === 0) state.needReadable = true;\n // call internal read method\n this._read(state.highWaterMark);\n state.sync = false;\n // If _read pushed data synchronously, then `reading` will be false,\n // and we need to re-evaluate how much data we can return to the user.\n if (!state.reading) n = howMuchToRead(nOrig, state);\n }\n var ret;\n if (n > 0) ret = fromList(n, state);else ret = null;\n if (ret === null) {\n state.needReadable = state.length <= state.highWaterMark;\n n = 0;\n } else {\n state.length -= n;\n state.awaitDrain = 0;\n }\n if (state.length === 0) {\n // If we have nothing in the buffer, then we want to know\n // as soon as we *do* get something into the buffer.\n if (!state.ended) state.needReadable = true;\n\n // If we tried to read() past the EOF, then emit end on the next tick.\n if (nOrig !== n && state.ended) endReadable(this);\n }\n if (ret !== null) this.emit('data', ret);\n return ret;\n};\nfunction onEofChunk(stream, state) {\n debug('onEofChunk');\n if (state.ended) return;\n if (state.decoder) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) {\n state.buffer.push(chunk);\n state.length += state.objectMode ? 1 : chunk.length;\n }\n }\n state.ended = true;\n if (state.sync) {\n // if we are sync, wait until next tick to emit the data.\n // Otherwise we risk emitting data in the flow()\n // the readable code triggers during a read() call\n emitReadable(stream);\n } else {\n // emit 'readable' now to make sure it gets picked up.\n state.needReadable = false;\n if (!state.emittedReadable) {\n state.emittedReadable = true;\n emitReadable_(stream);\n }\n }\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow. This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n var state = stream._readableState;\n debug('emitReadable', state.needReadable, state.emittedReadable);\n state.needReadable = false;\n if (!state.emittedReadable) {\n debug('emitReadable', state.flowing);\n state.emittedReadable = true;\n process.nextTick(emitReadable_, stream);\n }\n}\nfunction emitReadable_(stream) {\n var state = stream._readableState;\n debug('emitReadable_', state.destroyed, state.length, state.ended);\n if (!state.destroyed && (state.length || state.ended)) {\n stream.emit('readable');\n state.emittedReadable = false;\n }\n\n // The stream needs another readable event if\n // 1. It is not flowing, as the flow mechanism will take\n // care of it.\n // 2. It is not ended.\n // 3. It is below the highWaterMark, so we can schedule\n // another readable later.\n state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark;\n flow(stream);\n}\n\n// at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data. that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n if (!state.readingMore) {\n state.readingMore = true;\n process.nextTick(maybeReadMore_, stream, state);\n }\n}\nfunction maybeReadMore_(stream, state) {\n // Attempt to read more data if we should.\n //\n // The conditions for reading more data are (one of):\n // - Not enough data buffered (state.length < state.highWaterMark). The loop\n // is responsible for filling the buffer with enough data if such data\n // is available. If highWaterMark is 0 and we are not in the flowing mode\n // we should _not_ attempt to buffer any extra data. We'll get more data\n // when the stream consumer calls read() instead.\n // - No data in the buffer, and the stream is in flowing mode. In this mode\n // the loop below is responsible for ensuring read() is called. Failing to\n // call read here would abort the flow and there's no other mechanism for\n // continuing the flow if the stream consumer has just subscribed to the\n // 'data' event.\n //\n // In addition to the above conditions to keep reading data, the following\n // conditions prevent the data from being read:\n // - The stream has ended (state.ended).\n // - There is already a pending 'read' operation (state.reading). This is a\n // case where the the stream has called the implementation defined _read()\n // method, but they are processing the call asynchronously and have _not_\n // called push() with new data. In this case we skip performing more\n // read()s. The execution ends in this method again after the _read() ends\n // up calling push() with more data.\n while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) {\n var len = state.length;\n debug('maybeReadMore read 0');\n stream.read(0);\n if (len === state.length)\n // didn't get any data, stop spinning.\n break;\n }\n state.readingMore = false;\n}\n\n// abstract method. to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function (n) {\n errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()'));\n};\nReadable.prototype.pipe = function (dest, pipeOpts) {\n var src = this;\n var state = this._readableState;\n switch (state.pipesCount) {\n case 0:\n state.pipes = dest;\n break;\n case 1:\n state.pipes = [state.pipes, dest];\n break;\n default:\n state.pipes.push(dest);\n break;\n }\n state.pipesCount += 1;\n debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n var endFn = doEnd ? onend : unpipe;\n if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn);\n dest.on('unpipe', onunpipe);\n function onunpipe(readable, unpipeInfo) {\n debug('onunpipe');\n if (readable === src) {\n if (unpipeInfo && unpipeInfo.hasUnpiped === false) {\n unpipeInfo.hasUnpiped = true;\n cleanup();\n }\n }\n }\n function onend() {\n debug('onend');\n dest.end();\n }\n\n // when the dest drains, it reduces the awaitDrain counter\n // on the source. This would be more elegant with a .once()\n // handler in flow(), but adding and removing repeatedly is\n // too slow.\n var ondrain = pipeOnDrain(src);\n dest.on('drain', ondrain);\n var cleanedUp = false;\n function cleanup() {\n debug('cleanup');\n // cleanup event handlers once the pipe is broken\n dest.removeListener('close', onclose);\n dest.removeListener('finish', onfinish);\n dest.removeListener('drain', ondrain);\n dest.removeListener('error', onerror);\n dest.removeListener('unpipe', onunpipe);\n src.removeListener('end', onend);\n src.removeListener('end', unpipe);\n src.removeListener('data', ondata);\n cleanedUp = true;\n\n // if the reader is waiting for a drain event from this\n // specific writer, then it would cause it to never start\n // flowing again.\n // So, if this is awaiting a drain, then we just call it now.\n // If we don't know, then assume that we are waiting for one.\n if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n }\n src.on('data', ondata);\n function ondata(chunk) {\n debug('ondata');\n var ret = dest.write(chunk);\n debug('dest.write', ret);\n if (ret === false) {\n // If the user unpiped during `dest.write()`, it is possible\n // to get stuck in a permanently paused state if that write\n // also returned false.\n // => Check whether `dest` is still a piping destination.\n if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {\n debug('false write response, pause', state.awaitDrain);\n state.awaitDrain++;\n }\n src.pause();\n }\n }\n\n // if the dest has an error, then stop piping into it.\n // however, don't suppress the throwing behavior for this.\n function onerror(er) {\n debug('onerror', er);\n unpipe();\n dest.removeListener('error', onerror);\n if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er);\n }\n\n // Make sure our error handler is attached before userland ones.\n prependListener(dest, 'error', onerror);\n\n // Both close and finish should trigger unpipe, but only once.\n function onclose() {\n dest.removeListener('finish', onfinish);\n unpipe();\n }\n dest.once('close', onclose);\n function onfinish() {\n debug('onfinish');\n dest.removeListener('close', onclose);\n unpipe();\n }\n dest.once('finish', onfinish);\n function unpipe() {\n debug('unpipe');\n src.unpipe(dest);\n }\n\n // tell the dest that it's being piped to\n dest.emit('pipe', src);\n\n // start the flow if it hasn't been started already.\n if (!state.flowing) {\n debug('pipe resume');\n src.resume();\n }\n return dest;\n};\nfunction pipeOnDrain(src) {\n return function pipeOnDrainFunctionResult() {\n var state = src._readableState;\n debug('pipeOnDrain', state.awaitDrain);\n if (state.awaitDrain) state.awaitDrain--;\n if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n state.flowing = true;\n flow(src);\n }\n };\n}\nReadable.prototype.unpipe = function (dest) {\n var state = this._readableState;\n var unpipeInfo = {\n hasUnpiped: false\n };\n\n // if we're not piping anywhere, then do nothing.\n if (state.pipesCount === 0) return this;\n\n // just one destination. most common case.\n if (state.pipesCount === 1) {\n // passed in one, but it's not the right one.\n if (dest && dest !== state.pipes) return this;\n if (!dest) dest = state.pipes;\n\n // got a match.\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n if (dest) dest.emit('unpipe', this, unpipeInfo);\n return this;\n }\n\n // slow case. multiple pipe destinations.\n\n if (!dest) {\n // remove all.\n var dests = state.pipes;\n var len = state.pipesCount;\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n for (var i = 0; i < len; i++) dests[i].emit('unpipe', this, {\n hasUnpiped: false\n });\n return this;\n }\n\n // try to find the right one.\n var index = indexOf(state.pipes, dest);\n if (index === -1) return this;\n state.pipes.splice(index, 1);\n state.pipesCount -= 1;\n if (state.pipesCount === 1) state.pipes = state.pipes[0];\n dest.emit('unpipe', this, unpipeInfo);\n return this;\n};\n\n// set up data events if they are asked for\n// Ensure readable listeners eventually get something\nReadable.prototype.on = function (ev, fn) {\n var res = Stream.prototype.on.call(this, ev, fn);\n var state = this._readableState;\n if (ev === 'data') {\n // update readableListening so that resume() may be a no-op\n // a few lines down. This is needed to support once('readable').\n state.readableListening = this.listenerCount('readable') > 0;\n\n // Try start flowing on next tick if stream isn't explicitly paused\n if (state.flowing !== false) this.resume();\n } else if (ev === 'readable') {\n if (!state.endEmitted && !state.readableListening) {\n state.readableListening = state.needReadable = true;\n state.flowing = false;\n state.emittedReadable = false;\n debug('on readable', state.length, state.reading);\n if (state.length) {\n emitReadable(this);\n } else if (!state.reading) {\n process.nextTick(nReadingNextTick, this);\n }\n }\n }\n return res;\n};\nReadable.prototype.addListener = Readable.prototype.on;\nReadable.prototype.removeListener = function (ev, fn) {\n var res = Stream.prototype.removeListener.call(this, ev, fn);\n if (ev === 'readable') {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n return res;\n};\nReadable.prototype.removeAllListeners = function (ev) {\n var res = Stream.prototype.removeAllListeners.apply(this, arguments);\n if (ev === 'readable' || ev === undefined) {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n return res;\n};\nfunction updateReadableListening(self) {\n var state = self._readableState;\n state.readableListening = self.listenerCount('readable') > 0;\n if (state.resumeScheduled && !state.paused) {\n // flowing needs to be set to true now, otherwise\n // the upcoming resume will not flow.\n state.flowing = true;\n\n // crude way to check if we should resume\n } else if (self.listenerCount('data') > 0) {\n self.resume();\n }\n}\nfunction nReadingNextTick(self) {\n debug('readable nexttick read 0');\n self.read(0);\n}\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function () {\n var state = this._readableState;\n if (!state.flowing) {\n debug('resume');\n // we flow only if there is no one listening\n // for readable, but we still have to call\n // resume()\n state.flowing = !state.readableListening;\n resume(this, state);\n }\n state.paused = false;\n return this;\n};\nfunction resume(stream, state) {\n if (!state.resumeScheduled) {\n state.resumeScheduled = true;\n process.nextTick(resume_, stream, state);\n }\n}\nfunction resume_(stream, state) {\n debug('resume', state.reading);\n if (!state.reading) {\n stream.read(0);\n }\n state.resumeScheduled = false;\n stream.emit('resume');\n flow(stream);\n if (state.flowing && !state.reading) stream.read(0);\n}\nReadable.prototype.pause = function () {\n debug('call pause flowing=%j', this._readableState.flowing);\n if (this._readableState.flowing !== false) {\n debug('pause');\n this._readableState.flowing = false;\n this.emit('pause');\n }\n this._readableState.paused = true;\n return this;\n};\nfunction flow(stream) {\n var state = stream._readableState;\n debug('flow', state.flowing);\n while (state.flowing && stream.read() !== null);\n}\n\n// wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function (stream) {\n var _this = this;\n var state = this._readableState;\n var paused = false;\n stream.on('end', function () {\n debug('wrapped end');\n if (state.decoder && !state.ended) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) _this.push(chunk);\n }\n _this.push(null);\n });\n stream.on('data', function (chunk) {\n debug('wrapped data');\n if (state.decoder) chunk = state.decoder.write(chunk);\n\n // don't skip over falsy values in objectMode\n if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n var ret = _this.push(chunk);\n if (!ret) {\n paused = true;\n stream.pause();\n }\n });\n\n // proxy all the other methods.\n // important when wrapping filters and duplexes.\n for (var i in stream) {\n if (this[i] === undefined && typeof stream[i] === 'function') {\n this[i] = function methodWrap(method) {\n return function methodWrapReturnFunction() {\n return stream[method].apply(stream, arguments);\n };\n }(i);\n }\n }\n\n // proxy certain important events.\n for (var n = 0; n < kProxyEvents.length; n++) {\n stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));\n }\n\n // when we try to consume some more bytes, simply unpause the\n // underlying stream.\n this._read = function (n) {\n debug('wrapped _read', n);\n if (paused) {\n paused = false;\n stream.resume();\n }\n };\n return this;\n};\nif (typeof Symbol === 'function') {\n Readable.prototype[Symbol.asyncIterator] = function () {\n if (createReadableStreamAsyncIterator === undefined) {\n createReadableStreamAsyncIterator = require('./internal/streams/async_iterator');\n }\n return createReadableStreamAsyncIterator(this);\n };\n}\nObject.defineProperty(Readable.prototype, 'readableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.highWaterMark;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState && this._readableState.buffer;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableFlowing', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.flowing;\n },\n set: function set(state) {\n if (this._readableState) {\n this._readableState.flowing = state;\n }\n }\n});\n\n// exposed for testing purposes only.\nReadable._fromList = fromList;\nObject.defineProperty(Readable.prototype, 'readableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.length;\n }\n});\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromList(n, state) {\n // nothing buffered\n if (state.length === 0) return null;\n var ret;\n if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {\n // read it all, truncate the list\n if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length);\n state.buffer.clear();\n } else {\n // read part of list\n ret = state.buffer.consume(n, state.decoder);\n }\n return ret;\n}\nfunction endReadable(stream) {\n var state = stream._readableState;\n debug('endReadable', state.endEmitted);\n if (!state.endEmitted) {\n state.ended = true;\n process.nextTick(endReadableNT, state, stream);\n }\n}\nfunction endReadableNT(state, stream) {\n debug('endReadableNT', state.endEmitted, state.length);\n\n // Check that we didn't get one last unshift.\n if (!state.endEmitted && state.length === 0) {\n state.endEmitted = true;\n stream.readable = false;\n stream.emit('end');\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the writable side is ready for autoDestroy as well\n var wState = stream._writableState;\n if (!wState || wState.autoDestroy && wState.finished) {\n stream.destroy();\n }\n }\n }\n}\nif (typeof Symbol === 'function') {\n Readable.from = function (iterable, opts) {\n if (from === undefined) {\n from = require('./internal/streams/from');\n }\n return from(Readable, iterable, opts);\n };\n}\nfunction indexOf(xs, x) {\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) return i;\n }\n return -1;\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a transform stream is a readable/writable stream where you do\n// something with the data. Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored. (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation. For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes. When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up. When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer. When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks. If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk. However,\n// a pathological inflate type of transform can cause excessive buffering\n// here. For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output. In this case, you could write a very small\n// amount of input, and end up with a very large amount of output. In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform. A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n\n'use strict';\n\nmodule.exports = Transform;\nvar _require$codes = require('../errors').codes,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_TRANSFORM_ALREADY_TRANSFORMING = _require$codes.ERR_TRANSFORM_ALREADY_TRANSFORMING,\n ERR_TRANSFORM_WITH_LENGTH_0 = _require$codes.ERR_TRANSFORM_WITH_LENGTH_0;\nvar Duplex = require('./_stream_duplex');\nrequire('inherits')(Transform, Duplex);\nfunction afterTransform(er, data) {\n var ts = this._transformState;\n ts.transforming = false;\n var cb = ts.writecb;\n if (cb === null) {\n return this.emit('error', new ERR_MULTIPLE_CALLBACK());\n }\n ts.writechunk = null;\n ts.writecb = null;\n if (data != null)\n // single equals check for both `null` and `undefined`\n this.push(data);\n cb(er);\n var rs = this._readableState;\n rs.reading = false;\n if (rs.needReadable || rs.length < rs.highWaterMark) {\n this._read(rs.highWaterMark);\n }\n}\nfunction Transform(options) {\n if (!(this instanceof Transform)) return new Transform(options);\n Duplex.call(this, options);\n this._transformState = {\n afterTransform: afterTransform.bind(this),\n needTransform: false,\n transforming: false,\n writecb: null,\n writechunk: null,\n writeencoding: null\n };\n\n // start out asking for a readable event once data is transformed.\n this._readableState.needReadable = true;\n\n // we have implemented the _read method, and done the other things\n // that Readable wants before the first _read call, so unset the\n // sync guard flag.\n this._readableState.sync = false;\n if (options) {\n if (typeof options.transform === 'function') this._transform = options.transform;\n if (typeof options.flush === 'function') this._flush = options.flush;\n }\n\n // When the writable side finishes, then flush out anything remaining.\n this.on('prefinish', prefinish);\n}\nfunction prefinish() {\n var _this = this;\n if (typeof this._flush === 'function' && !this._readableState.destroyed) {\n this._flush(function (er, data) {\n done(_this, er, data);\n });\n } else {\n done(this, null, null);\n }\n}\nTransform.prototype.push = function (chunk, encoding) {\n this._transformState.needTransform = false;\n return Duplex.prototype.push.call(this, chunk, encoding);\n};\n\n// This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side. You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk. If you pass\n// an error, then that'll put the hurt on the whole operation. If you\n// never call cb(), then you'll never get another chunk.\nTransform.prototype._transform = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_transform()'));\n};\nTransform.prototype._write = function (chunk, encoding, cb) {\n var ts = this._transformState;\n ts.writecb = cb;\n ts.writechunk = chunk;\n ts.writeencoding = encoding;\n if (!ts.transforming) {\n var rs = this._readableState;\n if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n }\n};\n\n// Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\nTransform.prototype._read = function (n) {\n var ts = this._transformState;\n if (ts.writechunk !== null && !ts.transforming) {\n ts.transforming = true;\n this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n } else {\n // mark that we need a transform, so that any data that comes in\n // will get processed, now that we've asked for it.\n ts.needTransform = true;\n }\n};\nTransform.prototype._destroy = function (err, cb) {\n Duplex.prototype._destroy.call(this, err, function (err2) {\n cb(err2);\n });\n};\nfunction done(stream, er, data) {\n if (er) return stream.emit('error', er);\n if (data != null)\n // single equals check for both `null` and `undefined`\n stream.push(data);\n\n // TODO(BridgeAR): Write a test for these two error cases\n // if there's nothing in the write buffer, then that means\n // that nothing more will ever be provided\n if (stream._writableState.length) throw new ERR_TRANSFORM_WITH_LENGTH_0();\n if (stream._transformState.transforming) throw new ERR_TRANSFORM_ALREADY_TRANSFORMING();\n return stream.push(null);\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n\n'use strict';\n\nmodule.exports = Writable;\n\n/* */\nfunction WriteReq(chunk, encoding, cb) {\n this.chunk = chunk;\n this.encoding = encoding;\n this.callback = cb;\n this.next = null;\n}\n\n// It seems a linked list but it is not\n// there will be only 2 of these for each stream\nfunction CorkedRequest(state) {\n var _this = this;\n this.next = null;\n this.entry = null;\n this.finish = function () {\n onCorkedFinish(_this, state);\n };\n}\n/* */\n\n/**/\nvar Duplex;\n/**/\n\nWritable.WritableState = WritableState;\n\n/**/\nvar internalUtil = {\n deprecate: require('util-deprecate')\n};\n/**/\n\n/**/\nvar Stream = require('./internal/streams/stream');\n/**/\n\nvar Buffer = require('buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\nvar destroyImpl = require('./internal/streams/destroy');\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_STREAM_CANNOT_PIPE = _require$codes.ERR_STREAM_CANNOT_PIPE,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED,\n ERR_STREAM_NULL_VALUES = _require$codes.ERR_STREAM_NULL_VALUES,\n ERR_STREAM_WRITE_AFTER_END = _require$codes.ERR_STREAM_WRITE_AFTER_END,\n ERR_UNKNOWN_ENCODING = _require$codes.ERR_UNKNOWN_ENCODING;\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nrequire('inherits')(Writable, Stream);\nfunction nop() {}\nfunction WritableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream,\n // e.g. options.readableObjectMode vs. options.writableObjectMode, etc.\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex;\n\n // object stream flag to indicate whether or not this stream\n // contains buffers or objects.\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode;\n\n // the point at which write() starts returning false\n // Note: 0 is a valid value, means that we always return false if\n // the entire buffer is not flushed immediately on write()\n this.highWaterMark = getHighWaterMark(this, options, 'writableHighWaterMark', isDuplex);\n\n // if _final has been called\n this.finalCalled = false;\n\n // drain event flag.\n this.needDrain = false;\n // at the start of calling end()\n this.ending = false;\n // when end() has been called, and returned\n this.ended = false;\n // when 'finish' is emitted\n this.finished = false;\n\n // has it been destroyed\n this.destroyed = false;\n\n // should we decode strings into buffers before passing to _write?\n // this is here so that some node-core streams can optimize string\n // handling at a lower level.\n var noDecode = options.decodeStrings === false;\n this.decodeStrings = !noDecode;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // not an actual buffer we keep track of, but a measurement\n // of how much we're waiting to get pushed to some underlying\n // socket or file.\n this.length = 0;\n\n // a flag to see when we're in the middle of a write.\n this.writing = false;\n\n // when true all writes will be buffered until .uncork() call\n this.corked = 0;\n\n // a flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n this.sync = true;\n\n // a flag to know if we're processing previously buffered items, which\n // may call the _write() callback in the same tick, so that we don't\n // end up in an overlapped onwrite situation.\n this.bufferProcessing = false;\n\n // the callback that's passed to _write(chunk,cb)\n this.onwrite = function (er) {\n onwrite(stream, er);\n };\n\n // the callback that the user supplies to write(chunk,encoding,cb)\n this.writecb = null;\n\n // the amount that is being written when _write is called.\n this.writelen = 0;\n this.bufferedRequest = null;\n this.lastBufferedRequest = null;\n\n // number of pending user-supplied write callbacks\n // this must be 0 before 'finish' can be emitted\n this.pendingcb = 0;\n\n // emit prefinish if the only thing we're waiting for is _write cbs\n // This is relevant for synchronous Transform streams\n this.prefinished = false;\n\n // True if the error was already emitted and should not be thrown again\n this.errorEmitted = false;\n\n // Should close be emitted on destroy. Defaults to true.\n this.emitClose = options.emitClose !== false;\n\n // Should .destroy() be called after 'finish' (and potentially 'end')\n this.autoDestroy = !!options.autoDestroy;\n\n // count buffered requests\n this.bufferedRequestCount = 0;\n\n // allocate the first CorkedRequest, there is always\n // one allocated and free to use, and we maintain at most two\n this.corkedRequestsFree = new CorkedRequest(this);\n}\nWritableState.prototype.getBuffer = function getBuffer() {\n var current = this.bufferedRequest;\n var out = [];\n while (current) {\n out.push(current);\n current = current.next;\n }\n return out;\n};\n(function () {\n try {\n Object.defineProperty(WritableState.prototype, 'buffer', {\n get: internalUtil.deprecate(function writableStateBufferGetter() {\n return this.getBuffer();\n }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003')\n });\n } catch (_) {}\n})();\n\n// Test _writableState for inheritance to account for Duplex streams,\n// whose prototype chain only points to Readable.\nvar realHasInstance;\nif (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {\n realHasInstance = Function.prototype[Symbol.hasInstance];\n Object.defineProperty(Writable, Symbol.hasInstance, {\n value: function value(object) {\n if (realHasInstance.call(this, object)) return true;\n if (this !== Writable) return false;\n return object && object._writableState instanceof WritableState;\n }\n });\n} else {\n realHasInstance = function realHasInstance(object) {\n return object instanceof this;\n };\n}\nfunction Writable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n\n // Writable ctor is applied to Duplexes, too.\n // `realHasInstance` is necessary because using plain `instanceof`\n // would return false, as no `_writableState` property is attached.\n\n // Trying to use the custom `instanceof` for Writable here will also break the\n // Node.js LazyTransform implementation, which has a non-trivial getter for\n // `_writableState` that would lead to infinite recursion.\n\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the WritableState constructor, at least with V8 6.5\n var isDuplex = this instanceof Duplex;\n if (!isDuplex && !realHasInstance.call(Writable, this)) return new Writable(options);\n this._writableState = new WritableState(options, this, isDuplex);\n\n // legacy.\n this.writable = true;\n if (options) {\n if (typeof options.write === 'function') this._write = options.write;\n if (typeof options.writev === 'function') this._writev = options.writev;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n if (typeof options.final === 'function') this._final = options.final;\n }\n Stream.call(this);\n}\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function () {\n errorOrDestroy(this, new ERR_STREAM_CANNOT_PIPE());\n};\nfunction writeAfterEnd(stream, cb) {\n var er = new ERR_STREAM_WRITE_AFTER_END();\n // TODO: defer error events consistently everywhere, not just the cb\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n}\n\n// Checks that a user-supplied chunk is valid, especially for the particular\n// mode the stream is in. Currently this means that `null` is never accepted\n// and undefined/non-string values are only allowed in object mode.\nfunction validChunk(stream, state, chunk, cb) {\n var er;\n if (chunk === null) {\n er = new ERR_STREAM_NULL_VALUES();\n } else if (typeof chunk !== 'string' && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer'], chunk);\n }\n if (er) {\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n return false;\n }\n return true;\n}\nWritable.prototype.write = function (chunk, encoding, cb) {\n var state = this._writableState;\n var ret = false;\n var isBuf = !state.objectMode && _isUint8Array(chunk);\n if (isBuf && !Buffer.isBuffer(chunk)) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n if (typeof cb !== 'function') cb = nop;\n if (state.ending) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) {\n state.pendingcb++;\n ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb);\n }\n return ret;\n};\nWritable.prototype.cork = function () {\n this._writableState.corked++;\n};\nWritable.prototype.uncork = function () {\n var state = this._writableState;\n if (state.corked) {\n state.corked--;\n if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n }\n};\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n // node::ParseEncoding() requires lower case.\n if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new ERR_UNKNOWN_ENCODING(encoding);\n this._writableState.defaultEncoding = encoding;\n return this;\n};\nObject.defineProperty(Writable.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nfunction decodeChunk(state, chunk, encoding) {\n if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n return chunk;\n}\nObject.defineProperty(Writable.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\n\n// if we're already writing something, then just put this\n// in the queue, and wait our turn. Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) {\n if (!isBuf) {\n var newChunk = decodeChunk(state, chunk, encoding);\n if (chunk !== newChunk) {\n isBuf = true;\n encoding = 'buffer';\n chunk = newChunk;\n }\n }\n var len = state.objectMode ? 1 : chunk.length;\n state.length += len;\n var ret = state.length < state.highWaterMark;\n // we must ensure that previous needDrain will not be reset to false.\n if (!ret) state.needDrain = true;\n if (state.writing || state.corked) {\n var last = state.lastBufferedRequest;\n state.lastBufferedRequest = {\n chunk: chunk,\n encoding: encoding,\n isBuf: isBuf,\n callback: cb,\n next: null\n };\n if (last) {\n last.next = state.lastBufferedRequest;\n } else {\n state.bufferedRequest = state.lastBufferedRequest;\n }\n state.bufferedRequestCount += 1;\n } else {\n doWrite(stream, state, false, len, chunk, encoding, cb);\n }\n return ret;\n}\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n state.writelen = len;\n state.writecb = cb;\n state.writing = true;\n state.sync = true;\n if (state.destroyed) state.onwrite(new ERR_STREAM_DESTROYED('write'));else if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n state.sync = false;\n}\nfunction onwriteError(stream, state, sync, er, cb) {\n --state.pendingcb;\n if (sync) {\n // defer the callback if we are being called synchronously\n // to avoid piling up things on the stack\n process.nextTick(cb, er);\n // this can emit finish, and it will always happen\n // after error\n process.nextTick(finishMaybe, stream, state);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n } else {\n // the caller expect this to happen before if\n // it is async\n cb(er);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n // this can emit finish, but finish must\n // always follow error\n finishMaybe(stream, state);\n }\n}\nfunction onwriteStateUpdate(state) {\n state.writing = false;\n state.writecb = null;\n state.length -= state.writelen;\n state.writelen = 0;\n}\nfunction onwrite(stream, er) {\n var state = stream._writableState;\n var sync = state.sync;\n var cb = state.writecb;\n if (typeof cb !== 'function') throw new ERR_MULTIPLE_CALLBACK();\n onwriteStateUpdate(state);\n if (er) onwriteError(stream, state, sync, er, cb);else {\n // Check if we're actually ready to finish, but don't emit yet\n var finished = needFinish(state) || stream.destroyed;\n if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n clearBuffer(stream, state);\n }\n if (sync) {\n process.nextTick(afterWrite, stream, state, finished, cb);\n } else {\n afterWrite(stream, state, finished, cb);\n }\n }\n}\nfunction afterWrite(stream, state, finished, cb) {\n if (!finished) onwriteDrain(stream, state);\n state.pendingcb--;\n cb();\n finishMaybe(stream, state);\n}\n\n// Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\nfunction onwriteDrain(stream, state) {\n if (state.length === 0 && state.needDrain) {\n state.needDrain = false;\n stream.emit('drain');\n }\n}\n\n// if there's something in the buffer waiting, then process it\nfunction clearBuffer(stream, state) {\n state.bufferProcessing = true;\n var entry = state.bufferedRequest;\n if (stream._writev && entry && entry.next) {\n // Fast case, write everything using _writev()\n var l = state.bufferedRequestCount;\n var buffer = new Array(l);\n var holder = state.corkedRequestsFree;\n holder.entry = entry;\n var count = 0;\n var allBuffers = true;\n while (entry) {\n buffer[count] = entry;\n if (!entry.isBuf) allBuffers = false;\n entry = entry.next;\n count += 1;\n }\n buffer.allBuffers = allBuffers;\n doWrite(stream, state, true, state.length, buffer, '', holder.finish);\n\n // doWrite is almost always async, defer these to save a bit of time\n // as the hot path ends with doWrite\n state.pendingcb++;\n state.lastBufferedRequest = null;\n if (holder.next) {\n state.corkedRequestsFree = holder.next;\n holder.next = null;\n } else {\n state.corkedRequestsFree = new CorkedRequest(state);\n }\n state.bufferedRequestCount = 0;\n } else {\n // Slow case, write chunks one-by-one\n while (entry) {\n var chunk = entry.chunk;\n var encoding = entry.encoding;\n var cb = entry.callback;\n var len = state.objectMode ? 1 : chunk.length;\n doWrite(stream, state, false, len, chunk, encoding, cb);\n entry = entry.next;\n state.bufferedRequestCount--;\n // if we didn't call the onwrite immediately, then\n // it means that we need to wait until it does.\n // also, that means that the chunk and cb are currently\n // being processed, so move the buffer counter past them.\n if (state.writing) {\n break;\n }\n }\n if (entry === null) state.lastBufferedRequest = null;\n }\n state.bufferedRequest = entry;\n state.bufferProcessing = false;\n}\nWritable.prototype._write = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_write()'));\n};\nWritable.prototype._writev = null;\nWritable.prototype.end = function (chunk, encoding, cb) {\n var state = this._writableState;\n if (typeof chunk === 'function') {\n cb = chunk;\n chunk = null;\n encoding = null;\n } else if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n if (chunk !== null && chunk !== undefined) this.write(chunk, encoding);\n\n // .end() fully uncorks\n if (state.corked) {\n state.corked = 1;\n this.uncork();\n }\n\n // ignore unnecessary end() calls.\n if (!state.ending) endWritable(this, state, cb);\n return this;\n};\nObject.defineProperty(Writable.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\nfunction needFinish(state) {\n return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\nfunction callFinal(stream, state) {\n stream._final(function (err) {\n state.pendingcb--;\n if (err) {\n errorOrDestroy(stream, err);\n }\n state.prefinished = true;\n stream.emit('prefinish');\n finishMaybe(stream, state);\n });\n}\nfunction prefinish(stream, state) {\n if (!state.prefinished && !state.finalCalled) {\n if (typeof stream._final === 'function' && !state.destroyed) {\n state.pendingcb++;\n state.finalCalled = true;\n process.nextTick(callFinal, stream, state);\n } else {\n state.prefinished = true;\n stream.emit('prefinish');\n }\n }\n}\nfunction finishMaybe(stream, state) {\n var need = needFinish(state);\n if (need) {\n prefinish(stream, state);\n if (state.pendingcb === 0) {\n state.finished = true;\n stream.emit('finish');\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the readable side is ready for autoDestroy as well\n var rState = stream._readableState;\n if (!rState || rState.autoDestroy && rState.endEmitted) {\n stream.destroy();\n }\n }\n }\n }\n return need;\n}\nfunction endWritable(stream, state, cb) {\n state.ending = true;\n finishMaybe(stream, state);\n if (cb) {\n if (state.finished) process.nextTick(cb);else stream.once('finish', cb);\n }\n state.ended = true;\n stream.writable = false;\n}\nfunction onCorkedFinish(corkReq, state, err) {\n var entry = corkReq.entry;\n corkReq.entry = null;\n while (entry) {\n var cb = entry.callback;\n state.pendingcb--;\n cb(err);\n entry = entry.next;\n }\n\n // reuse the free corkReq.\n state.corkedRequestsFree.next = corkReq;\n}\nObject.defineProperty(Writable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._writableState === undefined) {\n return false;\n }\n return this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._writableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._writableState.destroyed = value;\n }\n});\nWritable.prototype.destroy = destroyImpl.destroy;\nWritable.prototype._undestroy = destroyImpl.undestroy;\nWritable.prototype._destroy = function (err, cb) {\n cb(err);\n};","'use strict';\n\nvar _Object$setPrototypeO;\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nvar finished = require('./end-of-stream');\nvar kLastResolve = Symbol('lastResolve');\nvar kLastReject = Symbol('lastReject');\nvar kError = Symbol('error');\nvar kEnded = Symbol('ended');\nvar kLastPromise = Symbol('lastPromise');\nvar kHandlePromise = Symbol('handlePromise');\nvar kStream = Symbol('stream');\nfunction createIterResult(value, done) {\n return {\n value: value,\n done: done\n };\n}\nfunction readAndResolve(iter) {\n var resolve = iter[kLastResolve];\n if (resolve !== null) {\n var data = iter[kStream].read();\n // we defer if data is null\n // we can be expecting either 'end' or\n // 'error'\n if (data !== null) {\n iter[kLastPromise] = null;\n iter[kLastResolve] = null;\n iter[kLastReject] = null;\n resolve(createIterResult(data, false));\n }\n }\n}\nfunction onReadable(iter) {\n // we wait for the next tick, because it might\n // emit an error with process.nextTick\n process.nextTick(readAndResolve, iter);\n}\nfunction wrapForNext(lastPromise, iter) {\n return function (resolve, reject) {\n lastPromise.then(function () {\n if (iter[kEnded]) {\n resolve(createIterResult(undefined, true));\n return;\n }\n iter[kHandlePromise](resolve, reject);\n }, reject);\n };\n}\nvar AsyncIteratorPrototype = Object.getPrototypeOf(function () {});\nvar ReadableStreamAsyncIteratorPrototype = Object.setPrototypeOf((_Object$setPrototypeO = {\n get stream() {\n return this[kStream];\n },\n next: function next() {\n var _this = this;\n // if we have detected an error in the meanwhile\n // reject straight away\n var error = this[kError];\n if (error !== null) {\n return Promise.reject(error);\n }\n if (this[kEnded]) {\n return Promise.resolve(createIterResult(undefined, true));\n }\n if (this[kStream].destroyed) {\n // We need to defer via nextTick because if .destroy(err) is\n // called, the error will be emitted via nextTick, and\n // we cannot guarantee that there is no error lingering around\n // waiting to be emitted.\n return new Promise(function (resolve, reject) {\n process.nextTick(function () {\n if (_this[kError]) {\n reject(_this[kError]);\n } else {\n resolve(createIterResult(undefined, true));\n }\n });\n });\n }\n\n // if we have multiple next() calls\n // we will wait for the previous Promise to finish\n // this logic is optimized to support for await loops,\n // where next() is only called once at a time\n var lastPromise = this[kLastPromise];\n var promise;\n if (lastPromise) {\n promise = new Promise(wrapForNext(lastPromise, this));\n } else {\n // fast path needed to support multiple this.push()\n // without triggering the next() queue\n var data = this[kStream].read();\n if (data !== null) {\n return Promise.resolve(createIterResult(data, false));\n }\n promise = new Promise(this[kHandlePromise]);\n }\n this[kLastPromise] = promise;\n return promise;\n }\n}, _defineProperty(_Object$setPrototypeO, Symbol.asyncIterator, function () {\n return this;\n}), _defineProperty(_Object$setPrototypeO, \"return\", function _return() {\n var _this2 = this;\n // destroy(err, cb) is a private API\n // we can guarantee we have that here, because we control the\n // Readable class this is attached to\n return new Promise(function (resolve, reject) {\n _this2[kStream].destroy(null, function (err) {\n if (err) {\n reject(err);\n return;\n }\n resolve(createIterResult(undefined, true));\n });\n });\n}), _Object$setPrototypeO), AsyncIteratorPrototype);\nvar createReadableStreamAsyncIterator = function createReadableStreamAsyncIterator(stream) {\n var _Object$create;\n var iterator = Object.create(ReadableStreamAsyncIteratorPrototype, (_Object$create = {}, _defineProperty(_Object$create, kStream, {\n value: stream,\n writable: true\n }), _defineProperty(_Object$create, kLastResolve, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kLastReject, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kError, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kEnded, {\n value: stream._readableState.endEmitted,\n writable: true\n }), _defineProperty(_Object$create, kHandlePromise, {\n value: function value(resolve, reject) {\n var data = iterator[kStream].read();\n if (data) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(data, false));\n } else {\n iterator[kLastResolve] = resolve;\n iterator[kLastReject] = reject;\n }\n },\n writable: true\n }), _Object$create));\n iterator[kLastPromise] = null;\n finished(stream, function (err) {\n if (err && err.code !== 'ERR_STREAM_PREMATURE_CLOSE') {\n var reject = iterator[kLastReject];\n // reject if we are waiting for data in the Promise\n // returned by next() and store the error\n if (reject !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n reject(err);\n }\n iterator[kError] = err;\n return;\n }\n var resolve = iterator[kLastResolve];\n if (resolve !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(undefined, true));\n }\n iterator[kEnded] = true;\n });\n stream.on('readable', onReadable.bind(null, iterator));\n return iterator;\n};\nmodule.exports = createReadableStreamAsyncIterator;","'use strict';\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nvar _require = require('buffer'),\n Buffer = _require.Buffer;\nvar _require2 = require('util'),\n inspect = _require2.inspect;\nvar custom = inspect && inspect.custom || 'inspect';\nfunction copyBuffer(src, target, offset) {\n Buffer.prototype.copy.call(src, target, offset);\n}\nmodule.exports = /*#__PURE__*/function () {\n function BufferList() {\n _classCallCheck(this, BufferList);\n this.head = null;\n this.tail = null;\n this.length = 0;\n }\n _createClass(BufferList, [{\n key: \"push\",\n value: function push(v) {\n var entry = {\n data: v,\n next: null\n };\n if (this.length > 0) this.tail.next = entry;else this.head = entry;\n this.tail = entry;\n ++this.length;\n }\n }, {\n key: \"unshift\",\n value: function unshift(v) {\n var entry = {\n data: v,\n next: this.head\n };\n if (this.length === 0) this.tail = entry;\n this.head = entry;\n ++this.length;\n }\n }, {\n key: \"shift\",\n value: function shift() {\n if (this.length === 0) return;\n var ret = this.head.data;\n if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;\n --this.length;\n return ret;\n }\n }, {\n key: \"clear\",\n value: function clear() {\n this.head = this.tail = null;\n this.length = 0;\n }\n }, {\n key: \"join\",\n value: function join(s) {\n if (this.length === 0) return '';\n var p = this.head;\n var ret = '' + p.data;\n while (p = p.next) ret += s + p.data;\n return ret;\n }\n }, {\n key: \"concat\",\n value: function concat(n) {\n if (this.length === 0) return Buffer.alloc(0);\n var ret = Buffer.allocUnsafe(n >>> 0);\n var p = this.head;\n var i = 0;\n while (p) {\n copyBuffer(p.data, ret, i);\n i += p.data.length;\n p = p.next;\n }\n return ret;\n }\n\n // Consumes a specified amount of bytes or characters from the buffered data.\n }, {\n key: \"consume\",\n value: function consume(n, hasStrings) {\n var ret;\n if (n < this.head.data.length) {\n // `slice` is the same for buffers and strings.\n ret = this.head.data.slice(0, n);\n this.head.data = this.head.data.slice(n);\n } else if (n === this.head.data.length) {\n // First chunk is a perfect match.\n ret = this.shift();\n } else {\n // Result spans more than one buffer.\n ret = hasStrings ? this._getString(n) : this._getBuffer(n);\n }\n return ret;\n }\n }, {\n key: \"first\",\n value: function first() {\n return this.head.data;\n }\n\n // Consumes a specified amount of characters from the buffered data.\n }, {\n key: \"_getString\",\n value: function _getString(n) {\n var p = this.head;\n var c = 1;\n var ret = p.data;\n n -= ret.length;\n while (p = p.next) {\n var str = p.data;\n var nb = n > str.length ? str.length : n;\n if (nb === str.length) ret += str;else ret += str.slice(0, n);\n n -= nb;\n if (n === 0) {\n if (nb === str.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = str.slice(nb);\n }\n break;\n }\n ++c;\n }\n this.length -= c;\n return ret;\n }\n\n // Consumes a specified amount of bytes from the buffered data.\n }, {\n key: \"_getBuffer\",\n value: function _getBuffer(n) {\n var ret = Buffer.allocUnsafe(n);\n var p = this.head;\n var c = 1;\n p.data.copy(ret);\n n -= p.data.length;\n while (p = p.next) {\n var buf = p.data;\n var nb = n > buf.length ? buf.length : n;\n buf.copy(ret, ret.length - n, 0, nb);\n n -= nb;\n if (n === 0) {\n if (nb === buf.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = buf.slice(nb);\n }\n break;\n }\n ++c;\n }\n this.length -= c;\n return ret;\n }\n\n // Make sure the linked list only shows the minimal necessary information.\n }, {\n key: custom,\n value: function value(_, options) {\n return inspect(this, _objectSpread(_objectSpread({}, options), {}, {\n // Only inspect one level.\n depth: 0,\n // It should not recurse.\n customInspect: false\n }));\n }\n }]);\n return BufferList;\n}();","'use strict';\n\n// undocumented cb() API, needed for core, not for public API\nfunction destroy(err, cb) {\n var _this = this;\n var readableDestroyed = this._readableState && this._readableState.destroyed;\n var writableDestroyed = this._writableState && this._writableState.destroyed;\n if (readableDestroyed || writableDestroyed) {\n if (cb) {\n cb(err);\n } else if (err) {\n if (!this._writableState) {\n process.nextTick(emitErrorNT, this, err);\n } else if (!this._writableState.errorEmitted) {\n this._writableState.errorEmitted = true;\n process.nextTick(emitErrorNT, this, err);\n }\n }\n return this;\n }\n\n // we set destroyed to true before firing error callbacks in order\n // to make it re-entrance safe in case destroy() is called within callbacks\n\n if (this._readableState) {\n this._readableState.destroyed = true;\n }\n\n // if this is a duplex stream mark the writable part as destroyed as well\n if (this._writableState) {\n this._writableState.destroyed = true;\n }\n this._destroy(err || null, function (err) {\n if (!cb && err) {\n if (!_this._writableState) {\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else if (!_this._writableState.errorEmitted) {\n _this._writableState.errorEmitted = true;\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n } else if (cb) {\n process.nextTick(emitCloseNT, _this);\n cb(err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n });\n return this;\n}\nfunction emitErrorAndCloseNT(self, err) {\n emitErrorNT(self, err);\n emitCloseNT(self);\n}\nfunction emitCloseNT(self) {\n if (self._writableState && !self._writableState.emitClose) return;\n if (self._readableState && !self._readableState.emitClose) return;\n self.emit('close');\n}\nfunction undestroy() {\n if (this._readableState) {\n this._readableState.destroyed = false;\n this._readableState.reading = false;\n this._readableState.ended = false;\n this._readableState.endEmitted = false;\n }\n if (this._writableState) {\n this._writableState.destroyed = false;\n this._writableState.ended = false;\n this._writableState.ending = false;\n this._writableState.finalCalled = false;\n this._writableState.prefinished = false;\n this._writableState.finished = false;\n this._writableState.errorEmitted = false;\n }\n}\nfunction emitErrorNT(self, err) {\n self.emit('error', err);\n}\nfunction errorOrDestroy(stream, err) {\n // We have tests that rely on errors being emitted\n // in the same tick, so changing this is semver major.\n // For now when you opt-in to autoDestroy we allow\n // the error to be emitted nextTick. In a future\n // semver major update we should change the default to this.\n\n var rState = stream._readableState;\n var wState = stream._writableState;\n if (rState && rState.autoDestroy || wState && wState.autoDestroy) stream.destroy(err);else stream.emit('error', err);\n}\nmodule.exports = {\n destroy: destroy,\n undestroy: undestroy,\n errorOrDestroy: errorOrDestroy\n};","// Ported from https://github.com/mafintosh/end-of-stream with\n// permission from the author, Mathias Buus (@mafintosh).\n\n'use strict';\n\nvar ERR_STREAM_PREMATURE_CLOSE = require('../../../errors').codes.ERR_STREAM_PREMATURE_CLOSE;\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n callback.apply(this, args);\n };\n}\nfunction noop() {}\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\nfunction eos(stream, opts, callback) {\n if (typeof opts === 'function') return eos(stream, null, opts);\n if (!opts) opts = {};\n callback = once(callback || noop);\n var readable = opts.readable || opts.readable !== false && stream.readable;\n var writable = opts.writable || opts.writable !== false && stream.writable;\n var onlegacyfinish = function onlegacyfinish() {\n if (!stream.writable) onfinish();\n };\n var writableEnded = stream._writableState && stream._writableState.finished;\n var onfinish = function onfinish() {\n writable = false;\n writableEnded = true;\n if (!readable) callback.call(stream);\n };\n var readableEnded = stream._readableState && stream._readableState.endEmitted;\n var onend = function onend() {\n readable = false;\n readableEnded = true;\n if (!writable) callback.call(stream);\n };\n var onerror = function onerror(err) {\n callback.call(stream, err);\n };\n var onclose = function onclose() {\n var err;\n if (readable && !readableEnded) {\n if (!stream._readableState || !stream._readableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n if (writable && !writableEnded) {\n if (!stream._writableState || !stream._writableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n };\n var onrequest = function onrequest() {\n stream.req.on('finish', onfinish);\n };\n if (isRequest(stream)) {\n stream.on('complete', onfinish);\n stream.on('abort', onclose);\n if (stream.req) onrequest();else stream.on('request', onrequest);\n } else if (writable && !stream._writableState) {\n // legacy streams\n stream.on('end', onlegacyfinish);\n stream.on('close', onlegacyfinish);\n }\n stream.on('end', onend);\n stream.on('finish', onfinish);\n if (opts.error !== false) stream.on('error', onerror);\n stream.on('close', onclose);\n return function () {\n stream.removeListener('complete', onfinish);\n stream.removeListener('abort', onclose);\n stream.removeListener('request', onrequest);\n if (stream.req) stream.req.removeListener('finish', onfinish);\n stream.removeListener('end', onlegacyfinish);\n stream.removeListener('close', onlegacyfinish);\n stream.removeListener('finish', onfinish);\n stream.removeListener('end', onend);\n stream.removeListener('error', onerror);\n stream.removeListener('close', onclose);\n };\n}\nmodule.exports = eos;","module.exports = function () {\n throw new Error('Readable.from is not available in the browser')\n};\n","// Ported from https://github.com/mafintosh/pump with\n// permission from the author, Mathias Buus (@mafintosh).\n\n'use strict';\n\nvar eos;\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n callback.apply(void 0, arguments);\n };\n}\nvar _require$codes = require('../../../errors').codes,\n ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED;\nfunction noop(err) {\n // Rethrow the error if it exists to avoid swallowing it\n if (err) throw err;\n}\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\nfunction destroyer(stream, reading, writing, callback) {\n callback = once(callback);\n var closed = false;\n stream.on('close', function () {\n closed = true;\n });\n if (eos === undefined) eos = require('./end-of-stream');\n eos(stream, {\n readable: reading,\n writable: writing\n }, function (err) {\n if (err) return callback(err);\n closed = true;\n callback();\n });\n var destroyed = false;\n return function (err) {\n if (closed) return;\n if (destroyed) return;\n destroyed = true;\n\n // request.destroy just do .end - .abort is what we want\n if (isRequest(stream)) return stream.abort();\n if (typeof stream.destroy === 'function') return stream.destroy();\n callback(err || new ERR_STREAM_DESTROYED('pipe'));\n };\n}\nfunction call(fn) {\n fn();\n}\nfunction pipe(from, to) {\n return from.pipe(to);\n}\nfunction popCallback(streams) {\n if (!streams.length) return noop;\n if (typeof streams[streams.length - 1] !== 'function') return noop;\n return streams.pop();\n}\nfunction pipeline() {\n for (var _len = arguments.length, streams = new Array(_len), _key = 0; _key < _len; _key++) {\n streams[_key] = arguments[_key];\n }\n var callback = popCallback(streams);\n if (Array.isArray(streams[0])) streams = streams[0];\n if (streams.length < 2) {\n throw new ERR_MISSING_ARGS('streams');\n }\n var error;\n var destroys = streams.map(function (stream, i) {\n var reading = i < streams.length - 1;\n var writing = i > 0;\n return destroyer(stream, reading, writing, function (err) {\n if (!error) error = err;\n if (err) destroys.forEach(call);\n if (reading) return;\n destroys.forEach(call);\n callback(error);\n });\n });\n return streams.reduce(pipe);\n}\nmodule.exports = pipeline;","'use strict';\n\nvar ERR_INVALID_OPT_VALUE = require('../../../errors').codes.ERR_INVALID_OPT_VALUE;\nfunction highWaterMarkFrom(options, isDuplex, duplexKey) {\n return options.highWaterMark != null ? options.highWaterMark : isDuplex ? options[duplexKey] : null;\n}\nfunction getHighWaterMark(state, options, duplexKey, isDuplex) {\n var hwm = highWaterMarkFrom(options, isDuplex, duplexKey);\n if (hwm != null) {\n if (!(isFinite(hwm) && Math.floor(hwm) === hwm) || hwm < 0) {\n var name = isDuplex ? duplexKey : 'highWaterMark';\n throw new ERR_INVALID_OPT_VALUE(name, hwm);\n }\n return Math.floor(hwm);\n }\n\n // Default value\n return state.objectMode ? 16 : 16 * 1024;\n}\nmodule.exports = {\n getHighWaterMark: getHighWaterMark\n};","module.exports = require('events').EventEmitter;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n/**/\n\nvar Buffer = require('safe-buffer').Buffer;\n/**/\n\nvar isEncoding = Buffer.isEncoding || function (encoding) {\n encoding = '' + encoding;\n switch (encoding && encoding.toLowerCase()) {\n case 'hex':case 'utf8':case 'utf-8':case 'ascii':case 'binary':case 'base64':case 'ucs2':case 'ucs-2':case 'utf16le':case 'utf-16le':case 'raw':\n return true;\n default:\n return false;\n }\n};\n\nfunction _normalizeEncoding(enc) {\n if (!enc) return 'utf8';\n var retried;\n while (true) {\n switch (enc) {\n case 'utf8':\n case 'utf-8':\n return 'utf8';\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return 'utf16le';\n case 'latin1':\n case 'binary':\n return 'latin1';\n case 'base64':\n case 'ascii':\n case 'hex':\n return enc;\n default:\n if (retried) return; // undefined\n enc = ('' + enc).toLowerCase();\n retried = true;\n }\n }\n};\n\n// Do not cache `Buffer.isEncoding` when checking encoding names as some\n// modules monkey-patch it to support additional encodings\nfunction normalizeEncoding(enc) {\n var nenc = _normalizeEncoding(enc);\n if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc);\n return nenc || enc;\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters.\nexports.StringDecoder = StringDecoder;\nfunction StringDecoder(encoding) {\n this.encoding = normalizeEncoding(encoding);\n var nb;\n switch (this.encoding) {\n case 'utf16le':\n this.text = utf16Text;\n this.end = utf16End;\n nb = 4;\n break;\n case 'utf8':\n this.fillLast = utf8FillLast;\n nb = 4;\n break;\n case 'base64':\n this.text = base64Text;\n this.end = base64End;\n nb = 3;\n break;\n default:\n this.write = simpleWrite;\n this.end = simpleEnd;\n return;\n }\n this.lastNeed = 0;\n this.lastTotal = 0;\n this.lastChar = Buffer.allocUnsafe(nb);\n}\n\nStringDecoder.prototype.write = function (buf) {\n if (buf.length === 0) return '';\n var r;\n var i;\n if (this.lastNeed) {\n r = this.fillLast(buf);\n if (r === undefined) return '';\n i = this.lastNeed;\n this.lastNeed = 0;\n } else {\n i = 0;\n }\n if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i);\n return r || '';\n};\n\nStringDecoder.prototype.end = utf8End;\n\n// Returns only complete characters in a Buffer\nStringDecoder.prototype.text = utf8Text;\n\n// Attempts to complete a partial non-UTF-8 character using bytes from a Buffer\nStringDecoder.prototype.fillLast = function (buf) {\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length);\n this.lastNeed -= buf.length;\n};\n\n// Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a\n// continuation byte. If an invalid byte is detected, -2 is returned.\nfunction utf8CheckByte(byte) {\n if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4;\n return byte >> 6 === 0x02 ? -1 : -2;\n}\n\n// Checks at most 3 bytes at the end of a Buffer in order to detect an\n// incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4)\n// needed to complete the UTF-8 character (if applicable) are returned.\nfunction utf8CheckIncomplete(self, buf, i) {\n var j = buf.length - 1;\n if (j < i) return 0;\n var nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 1;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 2;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) {\n if (nb === 2) nb = 0;else self.lastNeed = nb - 3;\n }\n return nb;\n }\n return 0;\n}\n\n// Validates as many continuation bytes for a multi-byte UTF-8 character as\n// needed or are available. If we see a non-continuation byte where we expect\n// one, we \"replace\" the validated continuation bytes we've seen so far with\n// a single UTF-8 replacement character ('\\ufffd'), to match v8's UTF-8 decoding\n// behavior. The continuation byte check is included three times in the case\n// where all of the continuation bytes for a character exist in the same buffer.\n// It is also done this way as a slight performance increase instead of using a\n// loop.\nfunction utf8CheckExtraBytes(self, buf, p) {\n if ((buf[0] & 0xC0) !== 0x80) {\n self.lastNeed = 0;\n return '\\ufffd';\n }\n if (self.lastNeed > 1 && buf.length > 1) {\n if ((buf[1] & 0xC0) !== 0x80) {\n self.lastNeed = 1;\n return '\\ufffd';\n }\n if (self.lastNeed > 2 && buf.length > 2) {\n if ((buf[2] & 0xC0) !== 0x80) {\n self.lastNeed = 2;\n return '\\ufffd';\n }\n }\n }\n}\n\n// Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer.\nfunction utf8FillLast(buf) {\n var p = this.lastTotal - this.lastNeed;\n var r = utf8CheckExtraBytes(this, buf, p);\n if (r !== undefined) return r;\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, p, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, p, 0, buf.length);\n this.lastNeed -= buf.length;\n}\n\n// Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a\n// partial character, the character's bytes are buffered until the required\n// number of bytes are available.\nfunction utf8Text(buf, i) {\n var total = utf8CheckIncomplete(this, buf, i);\n if (!this.lastNeed) return buf.toString('utf8', i);\n this.lastTotal = total;\n var end = buf.length - (total - this.lastNeed);\n buf.copy(this.lastChar, 0, end);\n return buf.toString('utf8', i, end);\n}\n\n// For UTF-8, a replacement character is added when ending on a partial\n// character.\nfunction utf8End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + '\\ufffd';\n return r;\n}\n\n// UTF-16LE typically needs two bytes per character, but even if we have an even\n// number of bytes available, we need to check if we end on a leading/high\n// surrogate. In that case, we need to wait for the next two bytes in order to\n// decode the last character properly.\nfunction utf16Text(buf, i) {\n if ((buf.length - i) % 2 === 0) {\n var r = buf.toString('utf16le', i);\n if (r) {\n var c = r.charCodeAt(r.length - 1);\n if (c >= 0xD800 && c <= 0xDBFF) {\n this.lastNeed = 2;\n this.lastTotal = 4;\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n return r.slice(0, -1);\n }\n }\n return r;\n }\n this.lastNeed = 1;\n this.lastTotal = 2;\n this.lastChar[0] = buf[buf.length - 1];\n return buf.toString('utf16le', i, buf.length - 1);\n}\n\n// For UTF-16LE we do not explicitly append special replacement characters if we\n// end on a partial character, we simply let v8 handle that.\nfunction utf16End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) {\n var end = this.lastTotal - this.lastNeed;\n return r + this.lastChar.toString('utf16le', 0, end);\n }\n return r;\n}\n\nfunction base64Text(buf, i) {\n var n = (buf.length - i) % 3;\n if (n === 0) return buf.toString('base64', i);\n this.lastNeed = 3 - n;\n this.lastTotal = 3;\n if (n === 1) {\n this.lastChar[0] = buf[buf.length - 1];\n } else {\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n }\n return buf.toString('base64', i, buf.length - n);\n}\n\nfunction base64End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed);\n return r;\n}\n\n// Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex)\nfunction simpleWrite(buf) {\n return buf.toString(this.encoding);\n}\n\nfunction simpleEnd(buf) {\n return buf && buf.length ? this.write(buf) : '';\n}","\n/**\n * Module dependencies.\n */\n\nvar assert = require('assert');\nvar debug = require('debug')('stream-parser');\n\n/**\n * Module exports.\n */\n\nmodule.exports = Parser;\n\n/**\n * Parser states.\n */\n\nvar INIT = -1;\nvar BUFFERING = 0;\nvar SKIPPING = 1;\nvar PASSTHROUGH = 2;\n\n/**\n * The `Parser` stream mixin works with either `Writable` or `Transform` stream\n * instances/subclasses. Provides a convenient generic \"parsing\" API:\n *\n * _bytes(n, cb) - buffers \"n\" bytes and then calls \"cb\" with the \"chunk\"\n * _skipBytes(n, cb) - skips \"n\" bytes and then calls \"cb\" when done\n *\n * If you extend a `Transform` stream, then the `_passthrough()` function is also\n * added:\n *\n * _passthrough(n, cb) - passes through \"n\" bytes untouched and then calls \"cb\"\n *\n * @param {Stream} stream Transform or Writable stream instance to extend\n * @api public\n */\n\nfunction Parser (stream) {\n var isTransform = stream && 'function' == typeof stream._transform;\n var isWritable = stream && 'function' == typeof stream._write;\n\n if (!isTransform && !isWritable) throw new Error('must pass a Writable or Transform stream in');\n debug('extending Parser into stream');\n\n // Transform streams and Writable streams get `_bytes()` and `_skipBytes()`\n stream._bytes = _bytes;\n stream._skipBytes = _skipBytes;\n\n // only Transform streams get the `_passthrough()` function\n if (isTransform) stream._passthrough = _passthrough;\n\n // take control of the streams2 callback functions for this stream\n if (isTransform) {\n stream._transform = transform;\n } else {\n stream._write = write;\n }\n}\n\nfunction init (stream) {\n debug('initializing parser stream');\n\n // number of bytes left to parser for the next \"chunk\"\n stream._parserBytesLeft = 0;\n\n // array of Buffer instances that make up the next \"chunk\"\n stream._parserBuffers = [];\n\n // number of bytes parsed so far for the next \"chunk\"\n stream._parserBuffered = 0;\n\n // flag that keeps track of if what the parser should do with bytes received\n stream._parserState = INIT;\n\n // the callback for the next \"chunk\"\n stream._parserCallback = null;\n\n // XXX: backwards compat with the old Transform API... remove at some point..\n if ('function' == typeof stream.push) {\n stream._parserOutput = stream.push.bind(stream);\n }\n\n stream._parserInit = true;\n}\n\n/**\n * Buffers `n` bytes and then invokes `fn` once that amount has been collected.\n *\n * @param {Number} n the number of bytes to buffer\n * @param {Function} fn callback function to invoke when `n` bytes are buffered\n * @api public\n */\n\nfunction _bytes (n, fn) {\n assert(!this._parserCallback, 'there is already a \"callback\" set!');\n assert(isFinite(n) && n > 0, 'can only buffer a finite number of bytes > 0, got \"' + n + '\"');\n if (!this._parserInit) init(this);\n debug('buffering %o bytes', n);\n this._parserBytesLeft = n;\n this._parserCallback = fn;\n this._parserState = BUFFERING;\n}\n\n/**\n * Skips over the next `n` bytes, then invokes `fn` once that amount has\n * been discarded.\n *\n * @param {Number} n the number of bytes to discard\n * @param {Function} fn callback function to invoke when `n` bytes have been skipped\n * @api public\n */\n\nfunction _skipBytes (n, fn) {\n assert(!this._parserCallback, 'there is already a \"callback\" set!');\n assert(n > 0, 'can only skip > 0 bytes, got \"' + n + '\"');\n if (!this._parserInit) init(this);\n debug('skipping %o bytes', n);\n this._parserBytesLeft = n;\n this._parserCallback = fn;\n this._parserState = SKIPPING;\n}\n\n/**\n * Passes through `n` bytes to the readable side of this stream untouched,\n * then invokes `fn` once that amount has been passed through.\n *\n * @param {Number} n the number of bytes to pass through\n * @param {Function} fn callback function to invoke when `n` bytes have passed through\n * @api public\n */\n\nfunction _passthrough (n, fn) {\n assert(!this._parserCallback, 'There is already a \"callback\" set!');\n assert(n > 0, 'can only pass through > 0 bytes, got \"' + n + '\"');\n if (!this._parserInit) init(this);\n debug('passing through %o bytes', n);\n this._parserBytesLeft = n;\n this._parserCallback = fn;\n this._parserState = PASSTHROUGH;\n}\n\n/**\n * The `_write()` callback function implementation.\n *\n * @api private\n */\n\nfunction write (chunk, encoding, fn) {\n if (!this._parserInit) init(this);\n debug('write(%o bytes)', chunk.length);\n\n // XXX: old Writable stream API compat... remove at some point...\n if ('function' == typeof encoding) fn = encoding;\n\n data(this, chunk, null, fn);\n}\n\n/**\n * The `_transform()` callback function implementation.\n *\n * @api private\n */\n\n\nfunction transform (chunk, output, fn) {\n if (!this._parserInit) init(this);\n debug('transform(%o bytes)', chunk.length);\n\n // XXX: old Transform stream API compat... remove at some point...\n if ('function' != typeof output) {\n output = this._parserOutput;\n }\n\n data(this, chunk, output, fn);\n}\n\n/**\n * The internal buffering/passthrough logic...\n *\n * This `_data` function get's \"trampolined\" to prevent stack overflows for tight\n * loops. This technique requires us to return a \"thunk\" function for any\n * synchronous action. Async stuff breaks the trampoline, but that's ok since it's\n * working with a new stack at that point anyway.\n *\n * @api private\n */\n\nfunction _data (stream, chunk, output, fn) {\n if (stream._parserBytesLeft <= 0) {\n return fn(new Error('got data but not currently parsing anything'));\n }\n\n if (chunk.length <= stream._parserBytesLeft) {\n // small buffer fits within the \"_parserBytesLeft\" window\n return function () {\n return process(stream, chunk, output, fn);\n };\n } else {\n // large buffer needs to be sliced on \"_parserBytesLeft\" and processed\n return function () {\n var b = chunk.slice(0, stream._parserBytesLeft);\n return process(stream, b, output, function (err) {\n if (err) return fn(err);\n if (chunk.length > b.length) {\n return function () {\n return _data(stream, chunk.slice(b.length), output, fn);\n };\n }\n });\n };\n }\n}\n\n/**\n * The internal `process` function gets called by the `data` function when\n * something \"interesting\" happens. This function takes care of buffering the\n * bytes when buffering, passing through the bytes when doing that, and invoking\n * the user callback when the number of bytes has been reached.\n *\n * @api private\n */\n\nfunction process (stream, chunk, output, fn) {\n stream._parserBytesLeft -= chunk.length;\n debug('%o bytes left for stream piece', stream._parserBytesLeft);\n\n if (stream._parserState === BUFFERING) {\n // buffer\n stream._parserBuffers.push(chunk);\n stream._parserBuffered += chunk.length;\n } else if (stream._parserState === PASSTHROUGH) {\n // passthrough\n output(chunk);\n }\n // don't need to do anything for the SKIPPING case\n\n if (0 === stream._parserBytesLeft) {\n // done with stream \"piece\", invoke the callback\n var cb = stream._parserCallback;\n if (cb && stream._parserState === BUFFERING && stream._parserBuffers.length > 1) {\n chunk = Buffer.concat(stream._parserBuffers, stream._parserBuffered);\n }\n if (stream._parserState !== BUFFERING) {\n chunk = null;\n }\n stream._parserCallback = null;\n stream._parserBuffered = 0;\n stream._parserState = INIT;\n stream._parserBuffers.splice(0); // empty\n\n if (cb) {\n var args = [];\n if (chunk) {\n // buffered\n args.push(chunk);\n } else {\n // passthrough\n }\n if (output) {\n // on a Transform stream, has \"output\" function\n args.push(output);\n }\n var async = cb.length > args.length;\n if (async) {\n args.push(trampoline(fn));\n }\n // invoke cb\n var rtn = cb.apply(stream, args);\n if (!async || fn === rtn) return fn;\n }\n } else {\n // need more bytes\n return fn;\n }\n}\n\nvar data = trampoline(_data);\n\n/**\n * Generic thunk-based \"trampoline\" helper function.\n *\n * @param {Function} input function\n * @return {Function} \"trampolined\" function\n * @api private\n */\n\nfunction trampoline (fn) {\n return function () {\n var result = fn.apply(this, arguments);\n\n while ('function' == typeof result) {\n result = result();\n }\n\n return result;\n };\n}\n","/**\n * This is the web browser implementation of `debug()`.\n *\n * Expose `debug()` as the module.\n */\n\nexports = module.exports = require('./debug');\nexports.log = log;\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = 'undefined' != typeof chrome\n && 'undefined' != typeof chrome.storage\n ? chrome.storage.local\n : localstorage();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n 'lightseagreen',\n 'forestgreen',\n 'goldenrod',\n 'dodgerblue',\n 'darkorchid',\n 'crimson'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\nfunction useColors() {\n // NB: In an Electron preload script, document will be defined but not fully\n // initialized. Since we know we're in Chrome, we'll just detect this case\n // explicitly\n if (typeof window !== 'undefined' && window.process && window.process.type === 'renderer') {\n return true;\n }\n\n // is webkit? http://stackoverflow.com/a/16459606/376773\n // document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n return (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n // is firebug? http://stackoverflow.com/a/398120/376773\n (typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n // is firefox >= v31?\n // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/) && parseInt(RegExp.$1, 10) >= 31) ||\n // double check webkit in userAgent just in case we are in a worker\n (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nexports.formatters.j = function(v) {\n try {\n return JSON.stringify(v);\n } catch (err) {\n return '[UnexpectedJSONParseError]: ' + err.message;\n }\n};\n\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n var useColors = this.useColors;\n\n args[0] = (useColors ? '%c' : '')\n + this.namespace\n + (useColors ? ' %c' : ' ')\n + args[0]\n + (useColors ? '%c ' : ' ')\n + '+' + exports.humanize(this.diff);\n\n if (!useColors) return;\n\n var c = 'color: ' + this.color;\n args.splice(1, 0, c, 'color: inherit')\n\n // the final \"%c\" is somewhat tricky, because there could be other\n // arguments passed either before or after the %c, so we need to\n // figure out the correct index to insert the CSS into\n var index = 0;\n var lastC = 0;\n args[0].replace(/%[a-zA-Z%]/g, function(match) {\n if ('%%' === match) return;\n index++;\n if ('%c' === match) {\n // we only are interested in the *last* %c\n // (the user may have provided their own)\n lastC = index;\n }\n });\n\n args.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.log()` when available.\n * No-op when `console.log` is not a \"function\".\n *\n * @api public\n */\n\nfunction log() {\n // this hackery is required for IE8/9, where\n // the `console.log` function doesn't have 'apply'\n return 'object' === typeof console\n && console.log\n && Function.prototype.apply.call(console.log, console, arguments);\n}\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\n\nfunction save(namespaces) {\n try {\n if (null == namespaces) {\n exports.storage.removeItem('debug');\n } else {\n exports.storage.debug = namespaces;\n }\n } catch(e) {}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\n\nfunction load() {\n var r;\n try {\n r = exports.storage.debug;\n } catch(e) {}\n\n // If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n if (!r && typeof process !== 'undefined' && 'env' in process) {\n r = process.env.DEBUG;\n }\n\n return r;\n}\n\n/**\n * Enable namespaces listed in `localStorage.debug` initially.\n */\n\nexports.enable(load());\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n try {\n return window.localStorage;\n } catch (e) {}\n}\n","\n/**\n * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n *\n * Expose `debug()` as the module.\n */\n\nexports = module.exports = createDebug.debug = createDebug['default'] = createDebug;\nexports.coerce = coerce;\nexports.disable = disable;\nexports.enable = enable;\nexports.enabled = enabled;\nexports.humanize = require('ms');\n\n/**\n * The currently active debug mode names, and names to skip.\n */\n\nexports.names = [];\nexports.skips = [];\n\n/**\n * Map of special \"%n\" handling functions, for the debug \"format\" argument.\n *\n * Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n */\n\nexports.formatters = {};\n\n/**\n * Previous log timestamp.\n */\n\nvar prevTime;\n\n/**\n * Select a color.\n * @param {String} namespace\n * @return {Number}\n * @api private\n */\n\nfunction selectColor(namespace) {\n var hash = 0, i;\n\n for (i in namespace) {\n hash = ((hash << 5) - hash) + namespace.charCodeAt(i);\n hash |= 0; // Convert to 32bit integer\n }\n\n return exports.colors[Math.abs(hash) % exports.colors.length];\n}\n\n/**\n * Create a debugger with the given `namespace`.\n *\n * @param {String} namespace\n * @return {Function}\n * @api public\n */\n\nfunction createDebug(namespace) {\n\n function debug() {\n // disabled?\n if (!debug.enabled) return;\n\n var self = debug;\n\n // set `diff` timestamp\n var curr = +new Date();\n var ms = curr - (prevTime || curr);\n self.diff = ms;\n self.prev = prevTime;\n self.curr = curr;\n prevTime = curr;\n\n // turn the `arguments` into a proper Array\n var args = new Array(arguments.length);\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i];\n }\n\n args[0] = exports.coerce(args[0]);\n\n if ('string' !== typeof args[0]) {\n // anything else let's inspect with %O\n args.unshift('%O');\n }\n\n // apply any `formatters` transformations\n var index = 0;\n args[0] = args[0].replace(/%([a-zA-Z%])/g, function(match, format) {\n // if we encounter an escaped % then don't increase the array index\n if (match === '%%') return match;\n index++;\n var formatter = exports.formatters[format];\n if ('function' === typeof formatter) {\n var val = args[index];\n match = formatter.call(self, val);\n\n // now we need to remove `args[index]` since it's inlined in the `format`\n args.splice(index, 1);\n index--;\n }\n return match;\n });\n\n // apply env-specific formatting (colors, etc.)\n exports.formatArgs.call(self, args);\n\n var logFn = debug.log || exports.log || console.log.bind(console);\n logFn.apply(self, args);\n }\n\n debug.namespace = namespace;\n debug.enabled = exports.enabled(namespace);\n debug.useColors = exports.useColors();\n debug.color = selectColor(namespace);\n\n // env-specific initialization logic for debug instances\n if ('function' === typeof exports.init) {\n exports.init(debug);\n }\n\n return debug;\n}\n\n/**\n * Enables a debug mode by namespaces. This can include modes\n * separated by a colon and wildcards.\n *\n * @param {String} namespaces\n * @api public\n */\n\nfunction enable(namespaces) {\n exports.save(namespaces);\n\n exports.names = [];\n exports.skips = [];\n\n var split = (typeof namespaces === 'string' ? namespaces : '').split(/[\\s,]+/);\n var len = split.length;\n\n for (var i = 0; i < len; i++) {\n if (!split[i]) continue; // ignore empty strings\n namespaces = split[i].replace(/\\*/g, '.*?');\n if (namespaces[0] === '-') {\n exports.skips.push(new RegExp('^' + namespaces.substr(1) + '$'));\n } else {\n exports.names.push(new RegExp('^' + namespaces + '$'));\n }\n }\n}\n\n/**\n * Disable debug output.\n *\n * @api public\n */\n\nfunction disable() {\n exports.enable('');\n}\n\n/**\n * Returns true if the given mode name is enabled, false otherwise.\n *\n * @param {String} name\n * @return {Boolean}\n * @api public\n */\n\nfunction enabled(name) {\n var i, len;\n for (i = 0, len = exports.skips.length; i < len; i++) {\n if (exports.skips[i].test(name)) {\n return false;\n }\n }\n for (i = 0, len = exports.names.length; i < len; i++) {\n if (exports.names[i].test(name)) {\n return true;\n }\n }\n return false;\n}\n\n/**\n * Coerce `val`.\n *\n * @param {Mixed} val\n * @return {Mixed}\n * @api private\n */\n\nfunction coerce(val) {\n if (val instanceof Error) return val.stack || val.message;\n return val;\n}\n","/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function(val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isNaN(val) === false) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^((?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n if (ms >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (ms >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (ms >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (ms >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n return plural(ms, d, 'day') ||\n plural(ms, h, 'hour') ||\n plural(ms, m, 'minute') ||\n plural(ms, s, 'second') ||\n ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, n, name) {\n if (ms < n) {\n return;\n }\n if (ms < n * 1.5) {\n return Math.floor(ms / n) + ' ' + name;\n }\n return Math.ceil(ms / n) + ' ' + name + 's';\n}\n","'use strict'\r\n\r\nvar paren = require('parenthesis')\r\n\r\nmodule.exports = function splitBy (string, separator, o) {\r\n\tif (string == null) throw Error('First argument should be a string')\r\n\tif (separator == null) throw Error('Separator should be a string or a RegExp')\r\n\r\n\tif (!o) o = {}\r\n\telse if (typeof o === 'string' || Array.isArray(o)) {\r\n\t\to = {ignore: o}\r\n\t}\r\n\r\n\tif (o.escape == null) o.escape = true\r\n\tif (o.ignore == null) o.ignore = ['[]', '()', '{}', '<>', '\"\"', \"''\", '``', '“”', '«»']\r\n\telse {\r\n\t\tif (typeof o.ignore === 'string') {o.ignore = [o.ignore]}\r\n\r\n\t\to.ignore = o.ignore.map(function (pair) {\r\n\t\t\t// '\"' → '\"\"'\r\n\t\t\tif (pair.length === 1) pair = pair + pair\r\n\t\t\treturn pair\r\n\t\t})\r\n\t}\r\n\r\n\tvar tokens = paren.parse(string, {flat: true, brackets: o.ignore})\r\n\tvar str = tokens[0]\r\n\r\n\tvar parts = str.split(separator)\r\n\r\n\t// join parts separated by escape\r\n\tif (o.escape) {\r\n\t\tvar cleanParts = []\r\n\t\tfor (var i = 0; i < parts.length; i++) {\r\n\t\t\tvar prev = parts[i]\r\n\t\t\tvar part = parts[i + 1]\r\n\r\n\t\t\tif (prev[prev.length - 1] === '\\\\' && prev[prev.length - 2] !== '\\\\') {\r\n\t\t\t\tcleanParts.push(prev + separator + part)\r\n\t\t\t\ti++\r\n\t\t\t}\r\n\t\t\telse {\r\n\t\t\t\tcleanParts.push(prev)\r\n\t\t\t}\r\n\t\t}\r\n\t\tparts = cleanParts\r\n\t}\r\n\r\n\t// open parens pack & apply unquotes, if any\r\n\tfor (var i = 0; i < parts.length; i++) {\r\n\t\ttokens[0] = parts[i]\r\n\t\tparts[i] = paren.stringify(tokens, {flat: true})\r\n\t}\r\n\r\n\treturn parts\r\n}\r\n","\"use strict\"\n\nmodule.exports = stronglyConnectedComponents\n\nfunction stronglyConnectedComponents(adjList) {\n var numVertices = adjList.length;\n var index = new Array(numVertices)\n var lowValue = new Array(numVertices)\n var active = new Array(numVertices)\n var child = new Array(numVertices)\n var scc = new Array(numVertices)\n var sccLinks = new Array(numVertices)\n \n //Initialize tables\n for(var i=0; i 0) {\n v = T[T.length-1]\n var e = adjList[v]\n if (child[v] < e.length) { // If we're not done iterating over the children, first try finishing that.\n for(var i=child[v]; i= 0) {\n // Node v is not yet assigned an scc, but once it is that scc can apparently reach scc[u].\n sccLinks[v].push(scc[u])\n }\n }\n child[v] = i // Remember where we left off.\n } else { // If we're done iterating over the children, check whether we have an scc.\n if(lowValue[v] === index[v]) { // TODO: It /might/ be true that T is always a prefix of S (at this point!!!), and if so, this could be used here.\n var component = []\n var links = [], linkCount = 0\n for(var i=S.length-1; i>=0; --i) {\n var w = S[i]\n active[w] = false\n component.push(w)\n links.push(sccLinks[w])\n linkCount += sccLinks[w].length\n scc[w] = components.length\n if(w === v) {\n S.length = i\n break\n }\n }\n components.push(component)\n var allLinks = new Array(linkCount)\n for(var i=0; i 1) {\n dot = 1;\n }\n\n if (dot < -1) {\n dot = -1;\n }\n\n return sign * Math.acos(dot);\n};\n\nvar getArcCenter = function getArcCenter(px, py, cx, cy, rx, ry, largeArcFlag, sweepFlag, sinphi, cosphi, pxp, pyp) {\n var rxsq = Math.pow(rx, 2);\n var rysq = Math.pow(ry, 2);\n var pxpsq = Math.pow(pxp, 2);\n var pypsq = Math.pow(pyp, 2);\n\n var radicant = rxsq * rysq - rxsq * pypsq - rysq * pxpsq;\n\n if (radicant < 0) {\n radicant = 0;\n }\n\n radicant /= rxsq * pypsq + rysq * pxpsq;\n radicant = Math.sqrt(radicant) * (largeArcFlag === sweepFlag ? -1 : 1);\n\n var centerxp = radicant * rx / ry * pyp;\n var centeryp = radicant * -ry / rx * pxp;\n\n var centerx = cosphi * centerxp - sinphi * centeryp + (px + cx) / 2;\n var centery = sinphi * centerxp + cosphi * centeryp + (py + cy) / 2;\n\n var vx1 = (pxp - centerxp) / rx;\n var vy1 = (pyp - centeryp) / ry;\n var vx2 = (-pxp - centerxp) / rx;\n var vy2 = (-pyp - centeryp) / ry;\n\n var ang1 = vectorAngle(1, 0, vx1, vy1);\n var ang2 = vectorAngle(vx1, vy1, vx2, vy2);\n\n if (sweepFlag === 0 && ang2 > 0) {\n ang2 -= TAU;\n }\n\n if (sweepFlag === 1 && ang2 < 0) {\n ang2 += TAU;\n }\n\n return [centerx, centery, ang1, ang2];\n};\n\nvar arcToBezier = function arcToBezier(_ref2) {\n var px = _ref2.px,\n py = _ref2.py,\n cx = _ref2.cx,\n cy = _ref2.cy,\n rx = _ref2.rx,\n ry = _ref2.ry,\n _ref2$xAxisRotation = _ref2.xAxisRotation,\n xAxisRotation = _ref2$xAxisRotation === undefined ? 0 : _ref2$xAxisRotation,\n _ref2$largeArcFlag = _ref2.largeArcFlag,\n largeArcFlag = _ref2$largeArcFlag === undefined ? 0 : _ref2$largeArcFlag,\n _ref2$sweepFlag = _ref2.sweepFlag,\n sweepFlag = _ref2$sweepFlag === undefined ? 0 : _ref2$sweepFlag;\n\n var curves = [];\n\n if (rx === 0 || ry === 0) {\n return [];\n }\n\n var sinphi = Math.sin(xAxisRotation * TAU / 360);\n var cosphi = Math.cos(xAxisRotation * TAU / 360);\n\n var pxp = cosphi * (px - cx) / 2 + sinphi * (py - cy) / 2;\n var pyp = -sinphi * (px - cx) / 2 + cosphi * (py - cy) / 2;\n\n if (pxp === 0 && pyp === 0) {\n return [];\n }\n\n rx = Math.abs(rx);\n ry = Math.abs(ry);\n\n var lambda = Math.pow(pxp, 2) / Math.pow(rx, 2) + Math.pow(pyp, 2) / Math.pow(ry, 2);\n\n if (lambda > 1) {\n rx *= Math.sqrt(lambda);\n ry *= Math.sqrt(lambda);\n }\n\n var _getArcCenter = getArcCenter(px, py, cx, cy, rx, ry, largeArcFlag, sweepFlag, sinphi, cosphi, pxp, pyp),\n _getArcCenter2 = _slicedToArray(_getArcCenter, 4),\n centerx = _getArcCenter2[0],\n centery = _getArcCenter2[1],\n ang1 = _getArcCenter2[2],\n ang2 = _getArcCenter2[3];\n\n // If 'ang2' == 90.0000000001, then `ratio` will evaluate to\n // 1.0000000001. This causes `segments` to be greater than one, which is an\n // unecessary split, and adds extra points to the bezier curve. To alleviate\n // this issue, we round to 1.0 when the ratio is close to 1.0.\n\n\n var ratio = Math.abs(ang2) / (TAU / 4);\n if (Math.abs(1.0 - ratio) < 0.0000001) {\n ratio = 1.0;\n }\n\n var segments = Math.max(Math.ceil(ratio), 1);\n\n ang2 /= segments;\n\n for (var i = 0; i < segments; i++) {\n curves.push(approxUnitArc(ang1, ang2));\n ang1 += ang2;\n }\n\n return curves.map(function (curve) {\n var _mapToEllipse = mapToEllipse(curve[0], rx, ry, cosphi, sinphi, centerx, centery),\n x1 = _mapToEllipse.x,\n y1 = _mapToEllipse.y;\n\n var _mapToEllipse2 = mapToEllipse(curve[1], rx, ry, cosphi, sinphi, centerx, centery),\n x2 = _mapToEllipse2.x,\n y2 = _mapToEllipse2.y;\n\n var _mapToEllipse3 = mapToEllipse(curve[2], rx, ry, cosphi, sinphi, centerx, centery),\n x = _mapToEllipse3.x,\n y = _mapToEllipse3.y;\n\n return { x1: x1, y1: y1, x2: x2, y2: y2, x: x, y: y };\n });\n};\n\nexport default arcToBezier;","'use strict'\r\n\r\nvar parse = require('parse-svg-path')\r\nvar abs = require('abs-svg-path')\r\nvar normalize = require('normalize-svg-path')\r\nvar isSvgPath = require('is-svg-path')\r\n\r\nmodule.exports = pathBounds\r\n\r\n\r\nfunction pathBounds(path) {\r\n // ES6 string tpl call\r\n if (Array.isArray(path) && path.length === 1 && typeof path[0] === 'string') path = path[0]\r\n\r\n // svg path string\r\n if (typeof path === 'string') {\r\n if (!isSvgPath(path)) throw Error('String is not an SVG path.')\r\n path = parse(path)\r\n }\r\n\r\n if (!Array.isArray(path)) throw Error('Argument should be a string or an array of path segments.')\r\n\r\n path = abs(path)\r\n path = normalize(path)\r\n\r\n if (!path.length) return [0, 0, 0, 0]\r\n\r\n var bounds = [Infinity, Infinity, -Infinity, -Infinity]\r\n\r\n for (var i = 0, l = path.length; i < l; i++) {\r\n var points = path[i].slice(1)\r\n\r\n for (var j = 0; j < points.length; j += 2) {\r\n if (points[j + 0] < bounds[0]) bounds[0] = points[j + 0]\r\n if (points[j + 1] < bounds[1]) bounds[1] = points[j + 1]\r\n if (points[j + 0] > bounds[2]) bounds[2] = points[j + 0]\r\n if (points[j + 1] > bounds[3]) bounds[3] = points[j + 1]\r\n }\r\n }\r\n\r\n return bounds\r\n}\r\n","'use strict'\r\n\r\nvar pathBounds = require('svg-path-bounds')\r\nvar parsePath = require('parse-svg-path')\r\nvar drawPath = require('draw-svg-path')\r\nvar isSvgPath = require('is-svg-path')\r\nvar bitmapSdf = require('bitmap-sdf')\r\n\r\nvar canvas = document.createElement('canvas')\r\nvar ctx = canvas.getContext('2d')\r\n\r\n\r\nmodule.exports = pathSdf\r\n\r\n\r\nfunction pathSdf (path, options) {\r\n\tif (!isSvgPath(path)) throw Error('Argument should be valid svg path string')\r\n\r\n\tif (!options) options = {}\r\n\r\n\tvar w, h\r\n\tif (options.shape) {\r\n\t\tw = options.shape[0]\r\n\t\th = options.shape[1]\r\n\t}\r\n\telse {\r\n\t\tw = canvas.width = options.w || options.width || 200\r\n\t\th = canvas.height = options.h || options.height || 200\r\n\t}\r\n\tvar size = Math.min(w, h)\r\n\r\n\tvar stroke = options.stroke || 0\r\n\r\n\tvar viewbox = options.viewbox || options.viewBox || pathBounds(path)\r\n\tvar scale = [w / (viewbox[2] - viewbox[0]), h / (viewbox[3] - viewbox[1])]\r\n\tvar maxScale = Math.min(scale[0] || 0, scale[1] || 0) / 2\r\n\r\n\t//clear ctx\r\n\tctx.fillStyle = 'black'\r\n\tctx.fillRect(0, 0, w, h)\r\n\r\n\tctx.fillStyle = 'white'\r\n\r\n\tif (stroke)\t{\r\n\t\tif (typeof stroke != 'number') stroke = 1\r\n\t\tif (stroke > 0) {\r\n\t\t\tctx.strokeStyle = 'white'\r\n\t\t}\r\n\t\telse {\r\n\t\t\tctx.strokeStyle = 'black'\r\n\t\t}\r\n\r\n\t\tctx.lineWidth = Math.abs(stroke)\r\n\t}\r\n\r\n\tctx.translate(w * .5, h * .5)\r\n\tctx.scale(maxScale, maxScale)\r\n\r\n\t//if canvas svg paths api is available\r\n\tif (isPath2DSupported()) {\r\n\t\tvar path2d = new Path2D(path)\r\n\t\tctx.fill(path2d)\r\n\t\tstroke && ctx.stroke(path2d)\r\n\t}\r\n\t//fallback to bezier-curves\r\n\telse {\r\n\t\tvar segments = parsePath(path)\r\n\t\tdrawPath(ctx, segments)\r\n\t\tctx.fill()\r\n\t\tstroke && ctx.stroke()\r\n\t}\r\n\r\n\tctx.setTransform(1, 0, 0, 1, 0, 0);\r\n\r\n\tvar data = bitmapSdf(ctx, {\r\n\t\tcutoff: options.cutoff != null ? options.cutoff : .5,\r\n\t\tradius: options.radius != null ? options.radius : size * .5\r\n\t})\r\n\r\n\treturn data\r\n}\r\n\r\nvar path2DSupported\r\n\r\nfunction isPath2DSupported () {\r\n\tif (path2DSupported != null) return path2DSupported\r\n\r\n\tvar ctx = document.createElement('canvas').getContext('2d')\r\n\tctx.canvas.width = ctx.canvas.height = 1\r\n\r\n\tif (!window.Path2D) return path2DSupported = false\r\n\r\n\tvar path = new Path2D('M0,0h1v1h-1v-1Z')\r\n\r\n\tctx.fillStyle = 'black'\r\n\tctx.fill(path)\r\n\r\n\tvar idata = ctx.getImageData(0,0,1,1)\r\n\r\n\treturn path2DSupported = idata && idata.data && idata.data[3] === 255\r\n}\r\n","/* @module to-float32 */\r\n\r\n'use strict'\r\n\r\nmodule.exports = float32\r\nmodule.exports.float32 =\r\nmodule.exports.float = float32\r\nmodule.exports.fract32 =\r\nmodule.exports.fract = fract32\r\n\r\nvar narr = new Float32Array(1)\r\n\r\n// Returns fractional part of float32 array\r\nfunction fract32 (arr, fract) {\r\n\tif (arr.length) {\r\n\t\tif (arr instanceof Float32Array) return new Float32Array(arr.length);\r\n\t\tif (!(fract instanceof Float32Array)) fract = float32(arr)\r\n\t\tfor (var i = 0, l = fract.length; i < l; i++) {\r\n\t\t\tfract[i] = arr[i] - fract[i]\r\n\t\t}\r\n\t\treturn fract\r\n\t}\r\n\r\n\t// number\r\n\treturn float32(arr - float32(arr))\r\n}\r\n\r\n// Make sure data is float32 array\r\nfunction float32 (arr) {\r\n\tif (arr.length) {\r\n\t\tif (arr instanceof Float32Array) return arr\r\n\t\treturn new Float32Array(arr);\r\n\t}\r\n\r\n\t// number\r\n\tnarr[0] = arr\r\n\treturn narr[0]\r\n}\r\n","'use strict'\n\nvar parseUnit = require('parse-unit')\n\nmodule.exports = toPX\n\nvar PIXELS_PER_INCH = getSizeBrutal('in', document.body) // 96\n\n\nfunction getPropertyInPX(element, prop) {\n var parts = parseUnit(getComputedStyle(element).getPropertyValue(prop))\n return parts[0] * toPX(parts[1], element)\n}\n\n//This brutal hack is needed\nfunction getSizeBrutal(unit, element) {\n var testDIV = document.createElement('div')\n testDIV.style['height'] = '128' + unit\n element.appendChild(testDIV)\n var size = getPropertyInPX(testDIV, 'height') / 128\n element.removeChild(testDIV)\n return size\n}\n\nfunction toPX(str, element) {\n if (!str) return null\n\n element = element || document.body\n str = (str + '' || 'px').trim().toLowerCase()\n if(element === window || element === document) {\n element = document.body\n }\n\n switch(str) {\n case '%': //Ambiguous, not sure if we should use width or height\n return element.clientHeight / 100.0\n case 'ch':\n case 'ex':\n return getSizeBrutal(str, element)\n case 'em':\n return getPropertyInPX(element, 'font-size')\n case 'rem':\n return getPropertyInPX(document.body, 'font-size')\n case 'vw':\n return window.innerWidth/100\n case 'vh':\n return window.innerHeight/100\n case 'vmin':\n return Math.min(window.innerWidth, window.innerHeight) / 100\n case 'vmax':\n return Math.max(window.innerWidth, window.innerHeight) / 100\n case 'in':\n return PIXELS_PER_INCH\n case 'cm':\n return PIXELS_PER_INCH / 2.54\n case 'mm':\n return PIXELS_PER_INCH / 25.4\n case 'pt':\n return PIXELS_PER_INCH / 72\n case 'pc':\n return PIXELS_PER_INCH / 6\n case 'px':\n return 1\n }\n\n // detect number of units\n var parts = parseUnit(str)\n if (!isNaN(parts[0]) && parts[1]) {\n var px = toPX(parts[1], element)\n return typeof px === 'number' ? parts[0] * px : null\n }\n\n return null\n}\n","export default function(x) {\n return x;\n}\n","import reverse from \"./reverse.js\";\nimport transform from \"./transform.js\";\n\nexport default function(topology, o) {\n if (typeof o === \"string\") o = topology.objects[o];\n return o.type === \"GeometryCollection\"\n ? {type: \"FeatureCollection\", features: o.geometries.map(function(o) { return feature(topology, o); })}\n : feature(topology, o);\n}\n\nfunction feature(topology, o) {\n var id = o.id,\n bbox = o.bbox,\n properties = o.properties == null ? {} : o.properties,\n geometry = object(topology, o);\n return id == null && bbox == null ? {type: \"Feature\", properties: properties, geometry: geometry}\n : bbox == null ? {type: \"Feature\", id: id, properties: properties, geometry: geometry}\n : {type: \"Feature\", id: id, bbox: bbox, properties: properties, geometry: geometry};\n}\n\nexport function object(topology, o) {\n var transformPoint = transform(topology.transform),\n arcs = topology.arcs;\n\n function arc(i, points) {\n if (points.length) points.pop();\n for (var a = arcs[i < 0 ? ~i : i], k = 0, n = a.length; k < n; ++k) {\n points.push(transformPoint(a[k], k));\n }\n if (i < 0) reverse(points, n);\n }\n\n function point(p) {\n return transformPoint(p);\n }\n\n function line(arcs) {\n var points = [];\n for (var i = 0, n = arcs.length; i < n; ++i) arc(arcs[i], points);\n if (points.length < 2) points.push(points[0]); // This should never happen per the specification.\n return points;\n }\n\n function ring(arcs) {\n var points = line(arcs);\n while (points.length < 4) points.push(points[0]); // This may happen if an arc has only two points.\n return points;\n }\n\n function polygon(arcs) {\n return arcs.map(ring);\n }\n\n function geometry(o) {\n var type = o.type, coordinates;\n switch (type) {\n case \"GeometryCollection\": return {type: type, geometries: o.geometries.map(geometry)};\n case \"Point\": coordinates = point(o.coordinates); break;\n case \"MultiPoint\": coordinates = o.coordinates.map(point); break;\n case \"LineString\": coordinates = line(o.arcs); break;\n case \"MultiLineString\": coordinates = o.arcs.map(line); break;\n case \"Polygon\": coordinates = polygon(o.arcs); break;\n case \"MultiPolygon\": coordinates = o.arcs.map(polygon); break;\n default: return null;\n }\n return {type: type, coordinates: coordinates};\n }\n\n return geometry(o);\n}\n","import identity from \"./identity.js\";\n\nexport default function(transform) {\n if (transform == null) return identity;\n var x0,\n y0,\n kx = transform.scale[0],\n ky = transform.scale[1],\n dx = transform.translate[0],\n dy = transform.translate[1];\n return function(input, i) {\n if (!i) x0 = y0 = 0;\n var j = 2, n = input.length, output = new Array(n);\n output[0] = (x0 += input[0]) * kx + dx;\n output[1] = (y0 += input[1]) * ky + dy;\n while (j < n) output[j] = input[j], ++j;\n return output;\n };\n}\n","export default function(array, n) {\n var t, j = array.length, i = j - n;\n while (i < --j) t = array[i], array[i++] = array[j], array[j] = t;\n}\n","\"use strict\";\n\nvar isPrototype = require(\"../prototype/is\");\n\nmodule.exports = function (value) {\n\tif (typeof value !== \"function\") return false;\n\n\tif (!hasOwnProperty.call(value, \"length\")) return false;\n\n\ttry {\n\t\tif (typeof value.length !== \"number\") return false;\n\t\tif (typeof value.call !== \"function\") return false;\n\t\tif (typeof value.apply !== \"function\") return false;\n\t} catch (error) {\n\t\treturn false;\n\t}\n\n\treturn !isPrototype(value);\n};\n","\"use strict\";\n\nvar stringCoerce = require(\"../string/coerce\")\n , toShortString = require(\"./to-short-string\");\n\nmodule.exports = function (errorMessage, value, inputOptions) {\n\tif (inputOptions && inputOptions.errorMessage) {\n\t\terrorMessage = stringCoerce(inputOptions.errorMessage);\n\t}\n\n\tvar valueInsertIndex = errorMessage.indexOf(\"%v\");\n\tvar valueToken = valueInsertIndex > -1 ? toShortString(value) : null;\n\tif (inputOptions && inputOptions.name) {\n\t\tvar nameInsertIndex = errorMessage.indexOf(\"%n\");\n\t\tif (nameInsertIndex > -1) {\n\t\t\tif (valueInsertIndex > -1) {\n\t\t\t\tvar firstToken, secondToken, firstInsertIndex, secondInsertIndex;\n\t\t\t\tif (nameInsertIndex > valueInsertIndex) {\n\t\t\t\t\tfirstToken = valueToken;\n\t\t\t\t\tfirstInsertIndex = valueInsertIndex;\n\t\t\t\t\tsecondToken = inputOptions.name;\n\t\t\t\t\tsecondInsertIndex = nameInsertIndex;\n\t\t\t\t} else {\n\t\t\t\t\tfirstToken = inputOptions.name;\n\t\t\t\t\tfirstInsertIndex = nameInsertIndex;\n\t\t\t\t\tsecondToken = valueToken;\n\t\t\t\t\tsecondInsertIndex = valueInsertIndex;\n\t\t\t\t}\n\t\t\t\treturn (\n\t\t\t\t\terrorMessage.slice(0, firstInsertIndex) +\n\t\t\t\t\tfirstToken +\n\t\t\t\t\terrorMessage.slice(firstInsertIndex + 2, secondInsertIndex) +\n\t\t\t\t\tsecondToken +\n\t\t\t\t\terrorMessage.slice(secondInsertIndex + 2)\n\t\t\t\t);\n\t\t\t}\n\t\t\treturn (\n\t\t\t\terrorMessage.slice(0, nameInsertIndex) +\n\t\t\t\tinputOptions.name +\n\t\t\t\terrorMessage.slice(nameInsertIndex + 2)\n\t\t\t);\n\t\t}\n\t}\n\tif (valueInsertIndex > -1) {\n\t\treturn (\n\t\t\terrorMessage.slice(0, valueInsertIndex) +\n\t\t\tvalueToken +\n\t\t\terrorMessage.slice(valueInsertIndex + 2)\n\t\t);\n\t}\n\treturn errorMessage;\n};\n","\"use strict\";\n\nvar isValue = require(\"../value/is\")\n , resolveErrorMessage = require(\"./resolve-error-message\");\n\nmodule.exports = function (value, defaultMessage, inputOptions) {\n\tif (inputOptions && !isValue(value)) {\n\t\tif (\"default\" in inputOptions) return inputOptions[\"default\"];\n\t\tif (inputOptions.isOptional) return null;\n\t}\n\tvar ErrorConstructor = (inputOptions && inputOptions.Error) || TypeError;\n\tvar error = new ErrorConstructor(resolveErrorMessage(defaultMessage, value, inputOptions));\n\tif (inputOptions && inputOptions.errorCode) error.code = inputOptions.errorCode;\n\tthrow error;\n};\n","\"use strict\";\n\nmodule.exports = function (value) {\n\ttry {\n\t\treturn value.toString();\n\t} catch (error) {\n\t\ttry { return String(value); }\n\t\tcatch (error2) { return null; }\n\t}\n};\n","\"use strict\";\n\nvar safeToString = require(\"./safe-to-string\");\n\nvar reNewLine = /[\\n\\r\\u2028\\u2029]/g;\n\nmodule.exports = function (value) {\n\tvar string = safeToString(value);\n\tif (string === null) return \"\";\n\t// Trim if too long\n\tif (string.length > 100) string = string.slice(0, 99) + \"…\";\n\t// Replace eventual new lines\n\tstring = string.replace(reNewLine, function (char) {\n\t\tswitch (char) {\n\t\t\tcase \"\\n\":\n\t\t\t\treturn \"\\\\n\";\n\t\t\tcase \"\\r\":\n\t\t\t\treturn \"\\\\r\";\n\t\t\tcase \"\\u2028\":\n\t\t\t\treturn \"\\\\u2028\";\n\t\t\tcase \"\\u2029\":\n\t\t\t\treturn \"\\\\u2029\";\n\t\t\t/* istanbul ignore next */\n\t\t\tdefault:\n\t\t\t\tthrow new Error(\"Unexpected character\");\n\t\t}\n\t});\n\treturn string;\n};\n","\"use strict\";\n\nvar isValue = require(\"../value/is\");\n\n// prettier-ignore\nvar possibleTypes = { \"object\": true, \"function\": true, \"undefined\": true /* document.all */ };\n\nmodule.exports = function (value) {\n\tif (!isValue(value)) return false;\n\treturn hasOwnProperty.call(possibleTypes, typeof value);\n};\n","\"use strict\";\n\nvar resolveException = require(\"../lib/resolve-exception\")\n , is = require(\"./is\");\n\nmodule.exports = function (value/*, options*/) {\n\tif (is(value)) return value;\n\tvar options = arguments[1];\n\tvar errorMessage =\n\t\toptions && options.name\n\t\t\t? \"Expected a plain function for %n, received %v\"\n\t\t\t: \"%v is not a plain function\";\n\treturn resolveException(value, errorMessage, options);\n};\n","\"use strict\";\n\nvar isFunction = require(\"../function/is\");\n\nvar classRe = /^\\s*class[\\s{/}]/, functionToString = Function.prototype.toString;\n\nmodule.exports = function (value) {\n\tif (!isFunction(value)) return false;\n\tif (classRe.test(functionToString.call(value))) return false;\n\treturn true;\n};\n","\"use strict\";\n\nvar isObject = require(\"../object/is\");\n\nmodule.exports = function (value) {\n\tif (!isObject(value)) return false;\n\ttry {\n\t\tif (!value.constructor) return false;\n\t\treturn value.constructor.prototype === value;\n\t} catch (error) {\n\t\treturn false;\n\t}\n};\n","\"use strict\";\n\nvar isValue = require(\"../value/is\")\n , isObject = require(\"../object/is\");\n\nvar objectToString = Object.prototype.toString;\n\nmodule.exports = function (value) {\n\tif (!isValue(value)) return null;\n\tif (isObject(value)) {\n\t\t// Reject Object.prototype.toString coercion\n\t\tvar valueToString = value.toString;\n\t\tif (typeof valueToString !== \"function\") return null;\n\t\tif (valueToString === objectToString) return null;\n\t\t// Note: It can be object coming from other realm, still as there's no ES3 and CSP compliant\n\t\t// way to resolve its realm's Object.prototype.toString it's left as not addressed edge case\n\t}\n\ttry {\n\t\treturn \"\" + value; // Ensure implicit coercion\n\t} catch (error) {\n\t\treturn null;\n\t}\n};\n","\"use strict\";\n\nvar resolveException = require(\"../lib/resolve-exception\")\n , is = require(\"./is\");\n\nmodule.exports = function (value/*, options*/) {\n\tif (is(value)) return value;\n\tvar options = arguments[1];\n\tvar errorMessage =\n\t\toptions && options.name ? \"Expected a value for %n, received %v\" : \"Cannot use %v\";\n\treturn resolveException(value, errorMessage, options);\n};\n","\"use strict\";\n\n// ES3 safe\nvar _undefined = void 0;\n\nmodule.exports = function (value) { return value !== _undefined && value !== null; };\n","'use strict'\n\nvar bits = require('bit-twiddle')\nvar dup = require('dup')\nvar Buffer = require('buffer').Buffer\n\n//Legacy pool support\nif(!global.__TYPEDARRAY_POOL) {\n global.__TYPEDARRAY_POOL = {\n UINT8 : dup([32, 0])\n , UINT16 : dup([32, 0])\n , UINT32 : dup([32, 0])\n , BIGUINT64 : dup([32, 0])\n , INT8 : dup([32, 0])\n , INT16 : dup([32, 0])\n , INT32 : dup([32, 0])\n , BIGINT64 : dup([32, 0])\n , FLOAT : dup([32, 0])\n , DOUBLE : dup([32, 0])\n , DATA : dup([32, 0])\n , UINT8C : dup([32, 0])\n , BUFFER : dup([32, 0])\n }\n}\n\nvar hasUint8C = (typeof Uint8ClampedArray) !== 'undefined'\nvar hasBigUint64 = (typeof BigUint64Array) !== 'undefined'\nvar hasBigInt64 = (typeof BigInt64Array) !== 'undefined'\nvar POOL = global.__TYPEDARRAY_POOL\n\n//Upgrade pool\nif(!POOL.UINT8C) {\n POOL.UINT8C = dup([32, 0])\n}\nif(!POOL.BIGUINT64) {\n POOL.BIGUINT64 = dup([32, 0])\n}\nif(!POOL.BIGINT64) {\n POOL.BIGINT64 = dup([32, 0])\n}\nif(!POOL.BUFFER) {\n POOL.BUFFER = dup([32, 0])\n}\n\n//New technique: Only allocate from ArrayBufferView and Buffer\nvar DATA = POOL.DATA\n , BUFFER = POOL.BUFFER\n\nexports.free = function free(array) {\n if(Buffer.isBuffer(array)) {\n BUFFER[bits.log2(array.length)].push(array)\n } else {\n if(Object.prototype.toString.call(array) !== '[object ArrayBuffer]') {\n array = array.buffer\n }\n if(!array) {\n return\n }\n var n = array.length || array.byteLength\n var log_n = bits.log2(n)|0\n DATA[log_n].push(array)\n }\n}\n\nfunction freeArrayBuffer(buffer) {\n if(!buffer) {\n return\n }\n var n = buffer.length || buffer.byteLength\n var log_n = bits.log2(n)\n DATA[log_n].push(buffer)\n}\n\nfunction freeTypedArray(array) {\n freeArrayBuffer(array.buffer)\n}\n\nexports.freeUint8 =\nexports.freeUint16 =\nexports.freeUint32 =\nexports.freeBigUint64 =\nexports.freeInt8 =\nexports.freeInt16 =\nexports.freeInt32 =\nexports.freeBigInt64 =\nexports.freeFloat32 = \nexports.freeFloat =\nexports.freeFloat64 = \nexports.freeDouble = \nexports.freeUint8Clamped = \nexports.freeDataView = freeTypedArray\n\nexports.freeArrayBuffer = freeArrayBuffer\n\nexports.freeBuffer = function freeBuffer(array) {\n BUFFER[bits.log2(array.length)].push(array)\n}\n\nexports.malloc = function malloc(n, dtype) {\n if(dtype === undefined || dtype === 'arraybuffer') {\n return mallocArrayBuffer(n)\n } else {\n switch(dtype) {\n case 'uint8':\n return mallocUint8(n)\n case 'uint16':\n return mallocUint16(n)\n case 'uint32':\n return mallocUint32(n)\n case 'int8':\n return mallocInt8(n)\n case 'int16':\n return mallocInt16(n)\n case 'int32':\n return mallocInt32(n)\n case 'float':\n case 'float32':\n return mallocFloat(n)\n case 'double':\n case 'float64':\n return mallocDouble(n)\n case 'uint8_clamped':\n return mallocUint8Clamped(n)\n case 'bigint64':\n return mallocBigInt64(n)\n case 'biguint64':\n return mallocBigUint64(n)\n case 'buffer':\n return mallocBuffer(n)\n case 'data':\n case 'dataview':\n return mallocDataView(n)\n\n default:\n return null\n }\n }\n return null\n}\n\nfunction mallocArrayBuffer(n) {\n var n = bits.nextPow2(n)\n var log_n = bits.log2(n)\n var d = DATA[log_n]\n if(d.length > 0) {\n return d.pop()\n }\n return new ArrayBuffer(n)\n}\nexports.mallocArrayBuffer = mallocArrayBuffer\n\nfunction mallocUint8(n) {\n return new Uint8Array(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocUint8 = mallocUint8\n\nfunction mallocUint16(n) {\n return new Uint16Array(mallocArrayBuffer(2*n), 0, n)\n}\nexports.mallocUint16 = mallocUint16\n\nfunction mallocUint32(n) {\n return new Uint32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocUint32 = mallocUint32\n\nfunction mallocInt8(n) {\n return new Int8Array(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocInt8 = mallocInt8\n\nfunction mallocInt16(n) {\n return new Int16Array(mallocArrayBuffer(2*n), 0, n)\n}\nexports.mallocInt16 = mallocInt16\n\nfunction mallocInt32(n) {\n return new Int32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocInt32 = mallocInt32\n\nfunction mallocFloat(n) {\n return new Float32Array(mallocArrayBuffer(4*n), 0, n)\n}\nexports.mallocFloat32 = exports.mallocFloat = mallocFloat\n\nfunction mallocDouble(n) {\n return new Float64Array(mallocArrayBuffer(8*n), 0, n)\n}\nexports.mallocFloat64 = exports.mallocDouble = mallocDouble\n\nfunction mallocUint8Clamped(n) {\n if(hasUint8C) {\n return new Uint8ClampedArray(mallocArrayBuffer(n), 0, n)\n } else {\n return mallocUint8(n)\n }\n}\nexports.mallocUint8Clamped = mallocUint8Clamped\n\nfunction mallocBigUint64(n) {\n if(hasBigUint64) {\n return new BigUint64Array(mallocArrayBuffer(8*n), 0, n)\n } else {\n return null;\n }\n}\nexports.mallocBigUint64 = mallocBigUint64\n\nfunction mallocBigInt64(n) {\n if (hasBigInt64) {\n return new BigInt64Array(mallocArrayBuffer(8*n), 0, n)\n } else {\n return null;\n }\n}\nexports.mallocBigInt64 = mallocBigInt64\n\nfunction mallocDataView(n) {\n return new DataView(mallocArrayBuffer(n), 0, n)\n}\nexports.mallocDataView = mallocDataView\n\nfunction mallocBuffer(n) {\n n = bits.nextPow2(n)\n var log_n = bits.log2(n)\n var cache = BUFFER[log_n]\n if(cache.length > 0) {\n return cache.pop()\n }\n return new Buffer(n)\n}\nexports.mallocBuffer = mallocBuffer\n\nexports.clearCache = function clearCache() {\n for(var i=0; i<32; ++i) {\n POOL.UINT8[i].length = 0\n POOL.UINT16[i].length = 0\n POOL.UINT32[i].length = 0\n POOL.INT8[i].length = 0\n POOL.INT16[i].length = 0\n POOL.INT32[i].length = 0\n POOL.FLOAT[i].length = 0\n POOL.DOUBLE[i].length = 0\n POOL.BIGUINT64[i].length = 0\n POOL.BIGINT64[i].length = 0\n POOL.UINT8C[i].length = 0\n DATA[i].length = 0\n BUFFER[i].length = 0\n }\n}\n","var reg = /[\\'\\\"]/\n\nmodule.exports = function unquote(str) {\n if (!str) {\n return ''\n }\n if (reg.test(str.charAt(0))) {\n str = str.substr(1)\n }\n if (reg.test(str.charAt(str.length - 1))) {\n str = str.substr(0, str.length - 1)\n }\n return str\n}\n","/**\r\n * @module update-diff\r\n */\r\n\r\n'use strict'\r\n\r\nmodule.exports = function updateDiff (obj, diff, mappers) {\r\n\tif (!Array.isArray(mappers)) mappers = [].slice.call(arguments, 2)\r\n\r\n\tfor (var i = 0, l = mappers.length; i < l; i++) {\r\n\t\tvar dict = mappers[i]\r\n\t\tfor (var prop in dict) {\r\n\t\t\tif (diff[prop] !== undefined && !Array.isArray(diff[prop]) && obj[prop] === diff[prop]) continue\r\n\r\n\t\t\tif (prop in diff) {\r\n\t\t\t\tvar result\r\n\r\n\t\t\t\tif (dict[prop] === true) result = diff[prop]\r\n\t\t\t\telse if (dict[prop] === false) continue\r\n\t\t\t\telse if (typeof dict[prop] === 'function') {\r\n\t\t\t\t\tresult = dict[prop](diff[prop], obj, diff)\r\n\t\t\t\t\tif (result === undefined) continue\r\n\t\t\t\t}\r\n\r\n\t\t\t\tobj[prop] = result\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\treturn obj\r\n}\r\n","/**\n * @license React\n * use-sync-external-store-shim.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var e=require(\"react\");function h(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var k=\"function\"===typeof Object.is?Object.is:h,l=e.useState,m=e.useEffect,n=e.useLayoutEffect,p=e.useDebugValue;function q(a,b){var d=b(),f=l({inst:{value:d,getSnapshot:b}}),c=f[0].inst,g=f[1];n(function(){c.value=d;c.getSnapshot=b;r(c)&&g({inst:c})},[a,d,b]);m(function(){r(c)&&g({inst:c});return a(function(){r(c)&&g({inst:c})})},[a]);p(d);return d}\nfunction r(a){var b=a.getSnapshot;a=a.value;try{var d=b();return!k(a,d)}catch(f){return!0}}function t(a,b){return b()}var u=\"undefined\"===typeof window||\"undefined\"===typeof window.document||\"undefined\"===typeof window.document.createElement?t:q;exports.useSyncExternalStore=void 0!==e.useSyncExternalStore?e.useSyncExternalStore:u;\n","/**\n * @license React\n * use-sync-external-store-shim/with-selector.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var h=require(\"react\"),n=require(\"use-sync-external-store/shim\");function p(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var q=\"function\"===typeof Object.is?Object.is:p,r=n.useSyncExternalStore,t=h.useRef,u=h.useEffect,v=h.useMemo,w=h.useDebugValue;\nexports.useSyncExternalStoreWithSelector=function(a,b,e,l,g){var c=t(null);if(null===c.current){var f={hasValue:!1,value:null};c.current=f}else f=c.current;c=v(function(){function a(a){if(!c){c=!0;d=a;a=l(a);if(void 0!==g&&f.hasValue){var b=f.value;if(g(b,a))return k=b}return k=a}b=k;if(q(d,a))return b;var e=l(a);if(void 0!==g&&g(b,e))return b;d=a;return k=e}var c=!1,d,k,m=void 0===e?null:e;return[function(){return a(b())},null===m?void 0:function(){return a(m())}]},[b,e,l,g]);var d=r(a,c[0],c[1]);\nu(function(){f.hasValue=!0;f.value=d},[d]);w(d);return d};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim.production.min.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim.development.js');\n}\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim/with-selector.production.min.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim/with-selector.development.js');\n}\n","\n/**\n * Module exports.\n */\n\nmodule.exports = deprecate;\n\n/**\n * Mark that a method should not be used.\n * Returns a modified function which warns once by default.\n *\n * If `localStorage.noDeprecation = true` is set, then it is a no-op.\n *\n * If `localStorage.throwDeprecation = true` is set, then deprecated functions\n * will throw an Error when invoked.\n *\n * If `localStorage.traceDeprecation = true` is set, then deprecated functions\n * will invoke `console.trace()` instead of `console.error()`.\n *\n * @param {Function} fn - the function to deprecate\n * @param {String} msg - the string to print to the console when `fn` is invoked\n * @returns {Function} a new \"deprecated\" version of `fn`\n * @api public\n */\n\nfunction deprecate (fn, msg) {\n if (config('noDeprecation')) {\n return fn;\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (config('throwDeprecation')) {\n throw new Error(msg);\n } else if (config('traceDeprecation')) {\n console.trace(msg);\n } else {\n console.warn(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n}\n\n/**\n * Checks `localStorage` for boolean values for the given `name`.\n *\n * @param {String} name\n * @returns {Boolean}\n * @api private\n */\n\nfunction config (name) {\n // accessing global.localStorage can trigger a DOMException in sandboxed iframes\n try {\n if (!global.localStorage) return false;\n } catch (_) {\n return false;\n }\n var val = global.localStorage[name];\n if (null == val) return false;\n return String(val).toLowerCase() === 'true';\n}\n","module.exports = function isBuffer(arg) {\n return arg && typeof arg === 'object'\n && typeof arg.copy === 'function'\n && typeof arg.fill === 'function'\n && typeof arg.readUInt8 === 'function';\n}","// Currently in sync with Node.js lib/internal/util/types.js\n// https://github.com/nodejs/node/commit/112cc7c27551254aa2b17098fb774867f05ed0d9\n\n'use strict';\n\nvar isArgumentsObject = require('is-arguments');\nvar isGeneratorFunction = require('is-generator-function');\nvar whichTypedArray = require('which-typed-array');\nvar isTypedArray = require('is-typed-array');\n\nfunction uncurryThis(f) {\n return f.call.bind(f);\n}\n\nvar BigIntSupported = typeof BigInt !== 'undefined';\nvar SymbolSupported = typeof Symbol !== 'undefined';\n\nvar ObjectToString = uncurryThis(Object.prototype.toString);\n\nvar numberValue = uncurryThis(Number.prototype.valueOf);\nvar stringValue = uncurryThis(String.prototype.valueOf);\nvar booleanValue = uncurryThis(Boolean.prototype.valueOf);\n\nif (BigIntSupported) {\n var bigIntValue = uncurryThis(BigInt.prototype.valueOf);\n}\n\nif (SymbolSupported) {\n var symbolValue = uncurryThis(Symbol.prototype.valueOf);\n}\n\nfunction checkBoxedPrimitive(value, prototypeValueOf) {\n if (typeof value !== 'object') {\n return false;\n }\n try {\n prototypeValueOf(value);\n return true;\n } catch(e) {\n return false;\n }\n}\n\nexports.isArgumentsObject = isArgumentsObject;\nexports.isGeneratorFunction = isGeneratorFunction;\nexports.isTypedArray = isTypedArray;\n\n// Taken from here and modified for better browser support\n// https://github.com/sindresorhus/p-is-promise/blob/cda35a513bda03f977ad5cde3a079d237e82d7ef/index.js\nfunction isPromise(input) {\n\treturn (\n\t\t(\n\t\t\ttypeof Promise !== 'undefined' &&\n\t\t\tinput instanceof Promise\n\t\t) ||\n\t\t(\n\t\t\tinput !== null &&\n\t\t\ttypeof input === 'object' &&\n\t\t\ttypeof input.then === 'function' &&\n\t\t\ttypeof input.catch === 'function'\n\t\t)\n\t);\n}\nexports.isPromise = isPromise;\n\nfunction isArrayBufferView(value) {\n if (typeof ArrayBuffer !== 'undefined' && ArrayBuffer.isView) {\n return ArrayBuffer.isView(value);\n }\n\n return (\n isTypedArray(value) ||\n isDataView(value)\n );\n}\nexports.isArrayBufferView = isArrayBufferView;\n\n\nfunction isUint8Array(value) {\n return whichTypedArray(value) === 'Uint8Array';\n}\nexports.isUint8Array = isUint8Array;\n\nfunction isUint8ClampedArray(value) {\n return whichTypedArray(value) === 'Uint8ClampedArray';\n}\nexports.isUint8ClampedArray = isUint8ClampedArray;\n\nfunction isUint16Array(value) {\n return whichTypedArray(value) === 'Uint16Array';\n}\nexports.isUint16Array = isUint16Array;\n\nfunction isUint32Array(value) {\n return whichTypedArray(value) === 'Uint32Array';\n}\nexports.isUint32Array = isUint32Array;\n\nfunction isInt8Array(value) {\n return whichTypedArray(value) === 'Int8Array';\n}\nexports.isInt8Array = isInt8Array;\n\nfunction isInt16Array(value) {\n return whichTypedArray(value) === 'Int16Array';\n}\nexports.isInt16Array = isInt16Array;\n\nfunction isInt32Array(value) {\n return whichTypedArray(value) === 'Int32Array';\n}\nexports.isInt32Array = isInt32Array;\n\nfunction isFloat32Array(value) {\n return whichTypedArray(value) === 'Float32Array';\n}\nexports.isFloat32Array = isFloat32Array;\n\nfunction isFloat64Array(value) {\n return whichTypedArray(value) === 'Float64Array';\n}\nexports.isFloat64Array = isFloat64Array;\n\nfunction isBigInt64Array(value) {\n return whichTypedArray(value) === 'BigInt64Array';\n}\nexports.isBigInt64Array = isBigInt64Array;\n\nfunction isBigUint64Array(value) {\n return whichTypedArray(value) === 'BigUint64Array';\n}\nexports.isBigUint64Array = isBigUint64Array;\n\nfunction isMapToString(value) {\n return ObjectToString(value) === '[object Map]';\n}\nisMapToString.working = (\n typeof Map !== 'undefined' &&\n isMapToString(new Map())\n);\n\nfunction isMap(value) {\n if (typeof Map === 'undefined') {\n return false;\n }\n\n return isMapToString.working\n ? isMapToString(value)\n : value instanceof Map;\n}\nexports.isMap = isMap;\n\nfunction isSetToString(value) {\n return ObjectToString(value) === '[object Set]';\n}\nisSetToString.working = (\n typeof Set !== 'undefined' &&\n isSetToString(new Set())\n);\nfunction isSet(value) {\n if (typeof Set === 'undefined') {\n return false;\n }\n\n return isSetToString.working\n ? isSetToString(value)\n : value instanceof Set;\n}\nexports.isSet = isSet;\n\nfunction isWeakMapToString(value) {\n return ObjectToString(value) === '[object WeakMap]';\n}\nisWeakMapToString.working = (\n typeof WeakMap !== 'undefined' &&\n isWeakMapToString(new WeakMap())\n);\nfunction isWeakMap(value) {\n if (typeof WeakMap === 'undefined') {\n return false;\n }\n\n return isWeakMapToString.working\n ? isWeakMapToString(value)\n : value instanceof WeakMap;\n}\nexports.isWeakMap = isWeakMap;\n\nfunction isWeakSetToString(value) {\n return ObjectToString(value) === '[object WeakSet]';\n}\nisWeakSetToString.working = (\n typeof WeakSet !== 'undefined' &&\n isWeakSetToString(new WeakSet())\n);\nfunction isWeakSet(value) {\n return isWeakSetToString(value);\n}\nexports.isWeakSet = isWeakSet;\n\nfunction isArrayBufferToString(value) {\n return ObjectToString(value) === '[object ArrayBuffer]';\n}\nisArrayBufferToString.working = (\n typeof ArrayBuffer !== 'undefined' &&\n isArrayBufferToString(new ArrayBuffer())\n);\nfunction isArrayBuffer(value) {\n if (typeof ArrayBuffer === 'undefined') {\n return false;\n }\n\n return isArrayBufferToString.working\n ? isArrayBufferToString(value)\n : value instanceof ArrayBuffer;\n}\nexports.isArrayBuffer = isArrayBuffer;\n\nfunction isDataViewToString(value) {\n return ObjectToString(value) === '[object DataView]';\n}\nisDataViewToString.working = (\n typeof ArrayBuffer !== 'undefined' &&\n typeof DataView !== 'undefined' &&\n isDataViewToString(new DataView(new ArrayBuffer(1), 0, 1))\n);\nfunction isDataView(value) {\n if (typeof DataView === 'undefined') {\n return false;\n }\n\n return isDataViewToString.working\n ? isDataViewToString(value)\n : value instanceof DataView;\n}\nexports.isDataView = isDataView;\n\n// Store a copy of SharedArrayBuffer in case it's deleted elsewhere\nvar SharedArrayBufferCopy = typeof SharedArrayBuffer !== 'undefined' ? SharedArrayBuffer : undefined;\nfunction isSharedArrayBufferToString(value) {\n return ObjectToString(value) === '[object SharedArrayBuffer]';\n}\nfunction isSharedArrayBuffer(value) {\n if (typeof SharedArrayBufferCopy === 'undefined') {\n return false;\n }\n\n if (typeof isSharedArrayBufferToString.working === 'undefined') {\n isSharedArrayBufferToString.working = isSharedArrayBufferToString(new SharedArrayBufferCopy());\n }\n\n return isSharedArrayBufferToString.working\n ? isSharedArrayBufferToString(value)\n : value instanceof SharedArrayBufferCopy;\n}\nexports.isSharedArrayBuffer = isSharedArrayBuffer;\n\nfunction isAsyncFunction(value) {\n return ObjectToString(value) === '[object AsyncFunction]';\n}\nexports.isAsyncFunction = isAsyncFunction;\n\nfunction isMapIterator(value) {\n return ObjectToString(value) === '[object Map Iterator]';\n}\nexports.isMapIterator = isMapIterator;\n\nfunction isSetIterator(value) {\n return ObjectToString(value) === '[object Set Iterator]';\n}\nexports.isSetIterator = isSetIterator;\n\nfunction isGeneratorObject(value) {\n return ObjectToString(value) === '[object Generator]';\n}\nexports.isGeneratorObject = isGeneratorObject;\n\nfunction isWebAssemblyCompiledModule(value) {\n return ObjectToString(value) === '[object WebAssembly.Module]';\n}\nexports.isWebAssemblyCompiledModule = isWebAssemblyCompiledModule;\n\nfunction isNumberObject(value) {\n return checkBoxedPrimitive(value, numberValue);\n}\nexports.isNumberObject = isNumberObject;\n\nfunction isStringObject(value) {\n return checkBoxedPrimitive(value, stringValue);\n}\nexports.isStringObject = isStringObject;\n\nfunction isBooleanObject(value) {\n return checkBoxedPrimitive(value, booleanValue);\n}\nexports.isBooleanObject = isBooleanObject;\n\nfunction isBigIntObject(value) {\n return BigIntSupported && checkBoxedPrimitive(value, bigIntValue);\n}\nexports.isBigIntObject = isBigIntObject;\n\nfunction isSymbolObject(value) {\n return SymbolSupported && checkBoxedPrimitive(value, symbolValue);\n}\nexports.isSymbolObject = isSymbolObject;\n\nfunction isBoxedPrimitive(value) {\n return (\n isNumberObject(value) ||\n isStringObject(value) ||\n isBooleanObject(value) ||\n isBigIntObject(value) ||\n isSymbolObject(value)\n );\n}\nexports.isBoxedPrimitive = isBoxedPrimitive;\n\nfunction isAnyArrayBuffer(value) {\n return typeof Uint8Array !== 'undefined' && (\n isArrayBuffer(value) ||\n isSharedArrayBuffer(value)\n );\n}\nexports.isAnyArrayBuffer = isAnyArrayBuffer;\n\n['isProxy', 'isExternal', 'isModuleNamespaceObject'].forEach(function(method) {\n Object.defineProperty(exports, method, {\n enumerable: false,\n value: function() {\n throw new Error(method + ' is not supported in userland');\n }\n });\n});\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar getOwnPropertyDescriptors = Object.getOwnPropertyDescriptors ||\n function getOwnPropertyDescriptors(obj) {\n var keys = Object.keys(obj);\n var descriptors = {};\n for (var i = 0; i < keys.length; i++) {\n descriptors[keys[i]] = Object.getOwnPropertyDescriptor(obj, keys[i]);\n }\n return descriptors;\n };\n\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function(f) {\n if (!isString(f)) {\n var objects = [];\n for (var i = 0; i < arguments.length; i++) {\n objects.push(inspect(arguments[i]));\n }\n return objects.join(' ');\n }\n\n var i = 1;\n var args = arguments;\n var len = args.length;\n var str = String(f).replace(formatRegExp, function(x) {\n if (x === '%%') return '%';\n if (i >= len) return x;\n switch (x) {\n case '%s': return String(args[i++]);\n case '%d': return Number(args[i++]);\n case '%j':\n try {\n return JSON.stringify(args[i++]);\n } catch (_) {\n return '[Circular]';\n }\n default:\n return x;\n }\n });\n for (var x = args[i]; i < len; x = args[++i]) {\n if (isNull(x) || !isObject(x)) {\n str += ' ' + x;\n } else {\n str += ' ' + inspect(x);\n }\n }\n return str;\n};\n\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function(fn, msg) {\n if (typeof process !== 'undefined' && process.noDeprecation === true) {\n return fn;\n }\n\n // Allow for deprecating things in the process of starting up.\n if (typeof process === 'undefined') {\n return function() {\n return exports.deprecate(fn, msg).apply(this, arguments);\n };\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (process.throwDeprecation) {\n throw new Error(msg);\n } else if (process.traceDeprecation) {\n console.trace(msg);\n } else {\n console.error(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n};\n\n\nvar debugs = {};\nvar debugEnvRegex = /^$/;\n\nif (process.env.NODE_DEBUG) {\n var debugEnv = process.env.NODE_DEBUG;\n debugEnv = debugEnv.replace(/[|\\\\{}()[\\]^$+?.]/g, '\\\\$&')\n .replace(/\\*/g, '.*')\n .replace(/,/g, '$|^')\n .toUpperCase();\n debugEnvRegex = new RegExp('^' + debugEnv + '$', 'i');\n}\nexports.debuglog = function(set) {\n set = set.toUpperCase();\n if (!debugs[set]) {\n if (debugEnvRegex.test(set)) {\n var pid = process.pid;\n debugs[set] = function() {\n var msg = exports.format.apply(exports, arguments);\n console.error('%s %d: %s', set, pid, msg);\n };\n } else {\n debugs[set] = function() {};\n }\n }\n return debugs[set];\n};\n\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n // default options\n var ctx = {\n seen: [],\n stylize: stylizeNoColor\n };\n // legacy...\n if (arguments.length >= 3) ctx.depth = arguments[2];\n if (arguments.length >= 4) ctx.colors = arguments[3];\n if (isBoolean(opts)) {\n // legacy...\n ctx.showHidden = opts;\n } else if (opts) {\n // got an \"options\" object\n exports._extend(ctx, opts);\n }\n // set default options\n if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n if (isUndefined(ctx.depth)) ctx.depth = 2;\n if (isUndefined(ctx.colors)) ctx.colors = false;\n if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n if (ctx.colors) ctx.stylize = stylizeWithColor;\n return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n 'bold' : [1, 22],\n 'italic' : [3, 23],\n 'underline' : [4, 24],\n 'inverse' : [7, 27],\n 'white' : [37, 39],\n 'grey' : [90, 39],\n 'black' : [30, 39],\n 'blue' : [34, 39],\n 'cyan' : [36, 39],\n 'green' : [32, 39],\n 'magenta' : [35, 39],\n 'red' : [31, 39],\n 'yellow' : [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n 'special': 'cyan',\n 'number': 'yellow',\n 'boolean': 'yellow',\n 'undefined': 'grey',\n 'null': 'bold',\n 'string': 'green',\n 'date': 'magenta',\n // \"name\": intentionally not styling\n 'regexp': 'red'\n};\n\n\nfunction stylizeWithColor(str, styleType) {\n var style = inspect.styles[styleType];\n\n if (style) {\n return '\\u001b[' + inspect.colors[style][0] + 'm' + str +\n '\\u001b[' + inspect.colors[style][1] + 'm';\n } else {\n return str;\n }\n}\n\n\nfunction stylizeNoColor(str, styleType) {\n return str;\n}\n\n\nfunction arrayToHash(array) {\n var hash = {};\n\n array.forEach(function(val, idx) {\n hash[val] = true;\n });\n\n return hash;\n}\n\n\nfunction formatValue(ctx, value, recurseTimes) {\n // Provide a hook for user-specified inspect functions.\n // Check that value is an object with an inspect function on it\n if (ctx.customInspect &&\n value &&\n isFunction(value.inspect) &&\n // Filter out the util module, it's inspect function is special\n value.inspect !== exports.inspect &&\n // Also filter out any prototype objects using the circular check.\n !(value.constructor && value.constructor.prototype === value)) {\n var ret = value.inspect(recurseTimes, ctx);\n if (!isString(ret)) {\n ret = formatValue(ctx, ret, recurseTimes);\n }\n return ret;\n }\n\n // Primitive types cannot have properties\n var primitive = formatPrimitive(ctx, value);\n if (primitive) {\n return primitive;\n }\n\n // Look up the keys of the object.\n var keys = Object.keys(value);\n var visibleKeys = arrayToHash(keys);\n\n if (ctx.showHidden) {\n keys = Object.getOwnPropertyNames(value);\n }\n\n // IE doesn't make error fields non-enumerable\n // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n if (isError(value)\n && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n return formatError(value);\n }\n\n // Some type of object without properties can be shortcutted.\n if (keys.length === 0) {\n if (isFunction(value)) {\n var name = value.name ? ': ' + value.name : '';\n return ctx.stylize('[Function' + name + ']', 'special');\n }\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n }\n if (isDate(value)) {\n return ctx.stylize(Date.prototype.toString.call(value), 'date');\n }\n if (isError(value)) {\n return formatError(value);\n }\n }\n\n var base = '', array = false, braces = ['{', '}'];\n\n // Make Array say that they are Array\n if (isArray(value)) {\n array = true;\n braces = ['[', ']'];\n }\n\n // Make functions say that they are functions\n if (isFunction(value)) {\n var n = value.name ? ': ' + value.name : '';\n base = ' [Function' + n + ']';\n }\n\n // Make RegExps say that they are RegExps\n if (isRegExp(value)) {\n base = ' ' + RegExp.prototype.toString.call(value);\n }\n\n // Make dates with properties first say the date\n if (isDate(value)) {\n base = ' ' + Date.prototype.toUTCString.call(value);\n }\n\n // Make error with message first say the error\n if (isError(value)) {\n base = ' ' + formatError(value);\n }\n\n if (keys.length === 0 && (!array || value.length == 0)) {\n return braces[0] + base + braces[1];\n }\n\n if (recurseTimes < 0) {\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n } else {\n return ctx.stylize('[Object]', 'special');\n }\n }\n\n ctx.seen.push(value);\n\n var output;\n if (array) {\n output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n } else {\n output = keys.map(function(key) {\n return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n });\n }\n\n ctx.seen.pop();\n\n return reduceToSingleString(output, base, braces);\n}\n\n\nfunction formatPrimitive(ctx, value) {\n if (isUndefined(value))\n return ctx.stylize('undefined', 'undefined');\n if (isString(value)) {\n var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '')\n .replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"') + '\\'';\n return ctx.stylize(simple, 'string');\n }\n if (isNumber(value))\n return ctx.stylize('' + value, 'number');\n if (isBoolean(value))\n return ctx.stylize('' + value, 'boolean');\n // For some reason typeof null is \"object\", so special case here.\n if (isNull(value))\n return ctx.stylize('null', 'null');\n}\n\n\nfunction formatError(value) {\n return '[' + Error.prototype.toString.call(value) + ']';\n}\n\n\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n var output = [];\n for (var i = 0, l = value.length; i < l; ++i) {\n if (hasOwnProperty(value, String(i))) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n String(i), true));\n } else {\n output.push('');\n }\n }\n keys.forEach(function(key) {\n if (!key.match(/^\\d+$/)) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n key, true));\n }\n });\n return output;\n}\n\n\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n var name, str, desc;\n desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };\n if (desc.get) {\n if (desc.set) {\n str = ctx.stylize('[Getter/Setter]', 'special');\n } else {\n str = ctx.stylize('[Getter]', 'special');\n }\n } else {\n if (desc.set) {\n str = ctx.stylize('[Setter]', 'special');\n }\n }\n if (!hasOwnProperty(visibleKeys, key)) {\n name = '[' + key + ']';\n }\n if (!str) {\n if (ctx.seen.indexOf(desc.value) < 0) {\n if (isNull(recurseTimes)) {\n str = formatValue(ctx, desc.value, null);\n } else {\n str = formatValue(ctx, desc.value, recurseTimes - 1);\n }\n if (str.indexOf('\\n') > -1) {\n if (array) {\n str = str.split('\\n').map(function(line) {\n return ' ' + line;\n }).join('\\n').slice(2);\n } else {\n str = '\\n' + str.split('\\n').map(function(line) {\n return ' ' + line;\n }).join('\\n');\n }\n }\n } else {\n str = ctx.stylize('[Circular]', 'special');\n }\n }\n if (isUndefined(name)) {\n if (array && key.match(/^\\d+$/)) {\n return str;\n }\n name = JSON.stringify('' + key);\n if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n name = name.slice(1, -1);\n name = ctx.stylize(name, 'name');\n } else {\n name = name.replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"')\n .replace(/(^\"|\"$)/g, \"'\");\n name = ctx.stylize(name, 'string');\n }\n }\n\n return name + ': ' + str;\n}\n\n\nfunction reduceToSingleString(output, base, braces) {\n var numLinesEst = 0;\n var length = output.reduce(function(prev, cur) {\n numLinesEst++;\n if (cur.indexOf('\\n') >= 0) numLinesEst++;\n return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n }, 0);\n\n if (length > 60) {\n return braces[0] +\n (base === '' ? '' : base + '\\n ') +\n ' ' +\n output.join(',\\n ') +\n ' ' +\n braces[1];\n }\n\n return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nexports.types = require('./support/types');\n\nfunction isArray(ar) {\n return Array.isArray(ar);\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\nexports.types.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\nexports.types.isDate = isDate;\n\nfunction isError(e) {\n return isObject(e) &&\n (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\nexports.types.isNativeError = isError;\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n return arg === null ||\n typeof arg === 'boolean' ||\n typeof arg === 'number' ||\n typeof arg === 'string' ||\n typeof arg === 'symbol' || // ES6 symbol\n typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('./support/isBuffer');\n\nfunction objectToString(o) {\n return Object.prototype.toString.call(o);\n}\n\n\nfunction pad(n) {\n return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\n\n\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',\n 'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n var d = new Date();\n var time = [pad(d.getHours()),\n pad(d.getMinutes()),\n pad(d.getSeconds())].join(':');\n return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function() {\n console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n * prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\n\nexports._extend = function(origin, add) {\n // Don't do anything if add isn't an object\n if (!add || !isObject(add)) return origin;\n\n var keys = Object.keys(add);\n var i = keys.length;\n while (i--) {\n origin[keys[i]] = add[keys[i]];\n }\n return origin;\n};\n\nfunction hasOwnProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nvar kCustomPromisifiedSymbol = typeof Symbol !== 'undefined' ? Symbol('util.promisify.custom') : undefined;\n\nexports.promisify = function promisify(original) {\n if (typeof original !== 'function')\n throw new TypeError('The \"original\" argument must be of type Function');\n\n if (kCustomPromisifiedSymbol && original[kCustomPromisifiedSymbol]) {\n var fn = original[kCustomPromisifiedSymbol];\n if (typeof fn !== 'function') {\n throw new TypeError('The \"util.promisify.custom\" argument must be of type Function');\n }\n Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn, enumerable: false, writable: false, configurable: true\n });\n return fn;\n }\n\n function fn() {\n var promiseResolve, promiseReject;\n var promise = new Promise(function (resolve, reject) {\n promiseResolve = resolve;\n promiseReject = reject;\n });\n\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n args.push(function (err, value) {\n if (err) {\n promiseReject(err);\n } else {\n promiseResolve(value);\n }\n });\n\n try {\n original.apply(this, args);\n } catch (err) {\n promiseReject(err);\n }\n\n return promise;\n }\n\n Object.setPrototypeOf(fn, Object.getPrototypeOf(original));\n\n if (kCustomPromisifiedSymbol) Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn, enumerable: false, writable: false, configurable: true\n });\n return Object.defineProperties(\n fn,\n getOwnPropertyDescriptors(original)\n );\n}\n\nexports.promisify.custom = kCustomPromisifiedSymbol\n\nfunction callbackifyOnRejected(reason, cb) {\n // `!reason` guard inspired by bluebird (Ref: https://goo.gl/t5IS6M).\n // Because `null` is a special error value in callbacks which means \"no error\n // occurred\", we error-wrap so the callback consumer can distinguish between\n // \"the promise rejected with null\" or \"the promise fulfilled with undefined\".\n if (!reason) {\n var newReason = new Error('Promise was rejected with a falsy value');\n newReason.reason = reason;\n reason = newReason;\n }\n return cb(reason);\n}\n\nfunction callbackify(original) {\n if (typeof original !== 'function') {\n throw new TypeError('The \"original\" argument must be of type Function');\n }\n\n // We DO NOT return the promise as it gives the user a false sense that\n // the promise is actually somehow related to the callback's execution\n // and that the callback throwing will reject the promise.\n function callbackified() {\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n\n var maybeCb = args.pop();\n if (typeof maybeCb !== 'function') {\n throw new TypeError('The last argument must be of type Function');\n }\n var self = this;\n var cb = function() {\n return maybeCb.apply(self, arguments);\n };\n // In true node style we process the callback on `nextTick` with all the\n // implications (stack, `uncaughtException`, `async_hooks`)\n original.apply(this, args)\n .then(function(ret) { process.nextTick(cb.bind(null, null, ret)) },\n function(rej) { process.nextTick(callbackifyOnRejected.bind(null, rej, cb)) });\n }\n\n Object.setPrototypeOf(callbackified, Object.getPrototypeOf(original));\n Object.defineProperties(callbackified,\n getOwnPropertyDescriptors(original));\n return callbackified;\n}\nexports.callbackify = callbackify;\n","var getContext = require('get-canvas-context')\n\nmodule.exports = function getWebGLContext (opt) {\n return getContext('webgl', opt)\n}\n","'use strict';\n\nvar forEach = require('for-each');\nvar availableTypedArrays = require('available-typed-arrays');\nvar callBind = require('call-bind');\nvar callBound = require('call-bind/callBound');\nvar gOPD = require('gopd');\n\n/** @type {(O: object) => string} */\nvar $toString = callBound('Object.prototype.toString');\nvar hasToStringTag = require('has-tostringtag/shams')();\n\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\nvar typedArrays = availableTypedArrays();\n\nvar $slice = callBound('String.prototype.slice');\nvar getPrototypeOf = Object.getPrototypeOf; // require('getprototypeof');\n\n/** @type {(array: readonly T[], value: unknown) => number} */\nvar $indexOf = callBound('Array.prototype.indexOf', true) || function indexOf(array, value) {\n\tfor (var i = 0; i < array.length; i += 1) {\n\t\tif (array[i] === value) {\n\t\t\treturn i;\n\t\t}\n\t}\n\treturn -1;\n};\n\n/** @typedef {(receiver: import('.').TypedArray) => string | typeof Uint8Array.prototype.slice.call | typeof Uint8Array.prototype.set.call} Getter */\n/** @type {{ [k in `\\$${import('.').TypedArrayName}`]?: Getter } & { __proto__: null }} */\nvar cache = { __proto__: null };\nif (hasToStringTag && gOPD && getPrototypeOf) {\n\tforEach(typedArrays, function (typedArray) {\n\t\tvar arr = new g[typedArray]();\n\t\tif (Symbol.toStringTag in arr) {\n\t\t\tvar proto = getPrototypeOf(arr);\n\t\t\t// @ts-expect-error TS won't narrow inside a closure\n\t\t\tvar descriptor = gOPD(proto, Symbol.toStringTag);\n\t\t\tif (!descriptor) {\n\t\t\t\tvar superProto = getPrototypeOf(proto);\n\t\t\t\t// @ts-expect-error TS won't narrow inside a closure\n\t\t\t\tdescriptor = gOPD(superProto, Symbol.toStringTag);\n\t\t\t}\n\t\t\t// @ts-expect-error TODO: fix\n\t\t\tcache['$' + typedArray] = callBind(descriptor.get);\n\t\t}\n\t});\n} else {\n\tforEach(typedArrays, function (typedArray) {\n\t\tvar arr = new g[typedArray]();\n\t\tvar fn = arr.slice || arr.set;\n\t\tif (fn) {\n\t\t\t// @ts-expect-error TODO: fix\n\t\t\tcache['$' + typedArray] = callBind(fn);\n\t\t}\n\t});\n}\n\n/** @type {(value: object) => false | import('.').TypedArrayName} */\nvar tryTypedArrays = function tryAllTypedArrays(value) {\n\t/** @type {ReturnType} */ var found = false;\n\tforEach(\n\t\t// eslint-disable-next-line no-extra-parens\n\t\t/** @type {Record<`\\$${TypedArrayName}`, Getter>} */ /** @type {any} */ (cache),\n\t\t/** @type {(getter: Getter, name: `\\$${import('.').TypedArrayName}`) => void} */\n\t\tfunction (getter, typedArray) {\n\t\t\tif (!found) {\n\t\t\t\ttry {\n\t\t\t\t// @ts-expect-error TODO: fix\n\t\t\t\t\tif ('$' + getter(value) === typedArray) {\n\t\t\t\t\t\tfound = $slice(typedArray, 1);\n\t\t\t\t\t}\n\t\t\t\t} catch (e) { /**/ }\n\t\t\t}\n\t\t}\n\t);\n\treturn found;\n};\n\n/** @type {(value: object) => false | import('.').TypedArrayName} */\nvar trySlices = function tryAllSlices(value) {\n\t/** @type {ReturnType} */ var found = false;\n\tforEach(\n\t\t// eslint-disable-next-line no-extra-parens\n\t\t/** @type {Record<`\\$${TypedArrayName}`, Getter>} */ /** @type {any} */ (cache),\n\t\t/** @type {(getter: typeof cache, name: `\\$${import('.').TypedArrayName}`) => void} */ function (getter, name) {\n\t\t\tif (!found) {\n\t\t\t\ttry {\n\t\t\t\t\t// @ts-expect-error TODO: fix\n\t\t\t\t\tgetter(value);\n\t\t\t\t\tfound = $slice(name, 1);\n\t\t\t\t} catch (e) { /**/ }\n\t\t\t}\n\t\t}\n\t);\n\treturn found;\n};\n\n/** @type {import('.')} */\nmodule.exports = function whichTypedArray(value) {\n\tif (!value || typeof value !== 'object') { return false; }\n\tif (!hasToStringTag) {\n\t\t/** @type {string} */\n\t\tvar tag = $slice($toString(value), 8, -1);\n\t\tif ($indexOf(typedArrays, tag) > -1) {\n\t\t\treturn tag;\n\t\t}\n\t\tif (tag !== 'Object') {\n\t\t\treturn false;\n\t\t}\n\t\t// node < 0.6 hits here on real Typed Arrays\n\t\treturn trySlices(value);\n\t}\n\tif (!gOPD) { return null; } // unknown engine\n\treturn tryTypedArrays(value);\n};\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Traditional Chinese calendar for jQuery v2.0.2.\n Written by Nicolas Riesco (enquiries@nicolasriesco.net) December 2016.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar main = require('../main');\nvar assign = require('object-assign');\n\n\nvar gregorianCalendar = main.instance();\n\n/** Implementation of the traditional Chinese calendar.\n Source of calendar tables https://github.com/isee15/Lunar-Solar-Calendar-Converter .\n @class ChineseCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction ChineseCalendar(language) {\n this.local = this.regionalOptions[language || ''] || this.regionalOptions[''];\n}\n\nChineseCalendar.prototype = new main.baseCalendar;\n\nassign(ChineseCalendar.prototype, {\n /** The calendar name.\n @memberof ChineseCalendar */\n name: 'Chinese',\n /** Julian date of start of Gregorian epoch: 1 January 0001 CE.\n @memberof GregorianCalendar */\n jdEpoch: 1721425.5,\n /** true if has a year zero, false if not.\n @memberof ChineseCalendar */\n hasYearZero: false,\n /** The minimum month number.\n This calendar uses month indices to account for intercalary months. \n @memberof ChineseCalendar */\n minMonth: 0,\n /** The first month in the year.\n This calendar uses month indices to account for intercalary months. \n @memberof ChineseCalendar */\n firstMonth: 0,\n /** The minimum day number.\n @memberof ChineseCalendar */\n minDay: 1,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof ChineseCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left. */\n regionalOptions: { // Localisations\n '': {\n name: 'Chinese',\n epochs: ['BEC', 'EC'],\n monthNumbers: function(date, padded) {\n if (typeof date === 'string') {\n var match = date.match(MONTH_NUMBER_REGEXP);\n return (match) ? match[0] : '';\n }\n\n var year = this._validateYear(date);\n var monthIndex = date.month();\n\n var month = '' + this.toChineseMonth(year, monthIndex);\n\n if (padded && month.length < 2) {\n month = \"0\" + month;\n }\n\n if (this.isIntercalaryMonth(year, monthIndex)) {\n month += 'i';\n }\n\n return month;\n },\n monthNames: function(date) {\n if (typeof date === 'string') {\n var match = date.match(MONTH_NAME_REGEXP);\n return (match) ? match[0] : '';\n }\n\n var year = this._validateYear(date);\n var monthIndex = date.month();\n\n var month = this.toChineseMonth(year, monthIndex);\n\n var monthName = ['一月','二月','三月','四月','五月','六月',\n '七月','八月','九月','十月','十一月','十二月'][month - 1];\n\n if (this.isIntercalaryMonth(year, monthIndex)) {\n monthName = '闰' + monthName;\n }\n\n return monthName;\n },\n monthNamesShort: function(date) {\n if (typeof date === 'string') {\n var match = date.match(MONTH_SHORT_NAME_REGEXP);\n return (match) ? match[0] : '';\n }\n\n var year = this._validateYear(date);\n var monthIndex = date.month();\n\n var month = this.toChineseMonth(year, monthIndex);\n\n var monthName = ['一','二','三','四','五','六',\n '七','八','九','十','十一','十二'][month - 1];\n\n if (this.isIntercalaryMonth(year, monthIndex)) {\n monthName = '闰' + monthName;\n }\n\n return monthName;\n },\n parseMonth: function(year, monthString) {\n year = this._validateYear(year);\n var month = parseInt(monthString);\n var isIntercalary;\n\n if (!isNaN(month)) {\n var i = monthString[monthString.length - 1];\n isIntercalary = (i === 'i' || i === 'I');\n } else {\n if (monthString[0] === '闰') {\n isIntercalary = true;\n monthString = monthString.substring(1);\n }\n if (monthString[monthString.length - 1] === '月') {\n monthString = monthString.substring(0, monthString.length - 1);\n }\n month = 1 +\n ['一','二','三','四','五','六',\n '七','八','九','十','十一','十二'].indexOf(monthString);\n }\n\n var monthIndex = this.toMonthIndex(year, month, isIntercalary);\n return monthIndex;\n },\n dayNames: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],\n dayNamesShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n dayNamesMin: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],\n digits: null,\n dateFormat: 'yyyy/mm/dd',\n firstDay: 1,\n isRTL: false\n }\n },\n\n /** Check that a candidate date is from the same calendar and is valid.\n @memberof BaseCalendar\n @private\n @param year {CDate|number} The date or the year to validate.\n @param error {string} Error message if invalid.\n @return {number} The year.\n @throws Error if year out of range. */\n _validateYear: function(year, error) {\n if (year.year) {\n year = year.year();\n }\n\n if (typeof year !== 'number' || year < 1888 || year > 2111) {\n throw error.replace(/\\{0\\}/, this.local.name);\n }\n\n return year;\n },\n\n /** Retrieve the month index (i.e. accounting for intercalary months).\n @memberof ChineseCalendar\n @param year {number} The year.\n @param month {number} The month (1 for first month).\n @param [isIntercalary=false] {boolean} If month is intercalary.\n @return {number} The month index (0 for first month).\n @throws Error if an invalid month/year or a different calendar used. */\n toMonthIndex: function(year, month, isIntercalary) {\n // compute intercalary month in the year (0 if none)\n var intercalaryMonth = this.intercalaryMonth(year);\n\n // validate month\n var invalidIntercalaryMonth = \n (isIntercalary && month !== intercalaryMonth);\n if (invalidIntercalaryMonth || month < 1 || month > 12) {\n throw main.local.invalidMonth\n .replace(/\\{0\\}/, this.local.name);\n }\n\n // compute month index\n var monthIndex;\n\n if (!intercalaryMonth) {\n monthIndex = month - 1;\n } else if(!isIntercalary && month <= intercalaryMonth) {\n monthIndex = month - 1;\n } else {\n monthIndex = month;\n }\n\n return monthIndex;\n },\n\n /** Retrieve the month (i.e. accounting for intercalary months).\n @memberof ChineseCalendar\n @param year {CDate|number} The date or the year to examine.\n @param monthIndex {number} The month index (0 for first month).\n @return {number} The month (1 for first month).\n @throws Error if an invalid month/year or a different calendar used. */\n toChineseMonth: function(year, monthIndex) {\n if (year.year) {\n year = year.year();\n monthIndex = year.month();\n }\n\n // compute intercalary month in the year (0 if none)\n var intercalaryMonth = this.intercalaryMonth(year);\n\n // validate month\n var maxMonthIndex = (intercalaryMonth) ? 12 : 11;\n if (monthIndex < 0 || monthIndex > maxMonthIndex) {\n throw main.local.invalidMonth\n .replace(/\\{0\\}/, this.local.name);\n }\n\n // compute Chinese month\n var month;\n\n if (!intercalaryMonth) {\n month = monthIndex + 1;\n } else if(monthIndex < intercalaryMonth) {\n month = monthIndex + 1;\n } else {\n month = monthIndex;\n }\n\n return month;\n },\n\n /** Determine the intercalary month of a year (if any).\n @memberof ChineseCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The intercalary month number, or 0 if none.\n @throws Error if an invalid year or a different calendar used. */\n intercalaryMonth: function(year) {\n year = this._validateYear(year);\n\n var monthDaysTable = LUNAR_MONTH_DAYS[year - LUNAR_MONTH_DAYS[0]];\n var intercalaryMonth = monthDaysTable >> 13;\n\n return intercalaryMonth;\n },\n\n /** Determine whether this date is an intercalary month.\n @memberof ChineseCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [monthIndex] {number} The month index to examine.\n @return {boolean} true if this is an intercalary month, false if not.\n @throws Error if an invalid year or a different calendar used. */\n isIntercalaryMonth: function(year, monthIndex) {\n if (year.year) {\n year = year.year();\n monthIndex = year.month();\n }\n\n var intercalaryMonth = this.intercalaryMonth(year);\n\n return !!intercalaryMonth && intercalaryMonth === monthIndex;\n },\n\n /** Determine whether this date is in a leap year.\n @memberof ChineseCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function(year) {\n return (this.intercalaryMonth(year) !== 0);\n },\n\n /** Determine the week of the year for a date - ISO 8601.\n @memberof ChineseCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [monthIndex] {number} The month index to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function(year, monthIndex, day) {\n // compute Chinese new year\n var validatedYear =\n this._validateYear(year, main.local.invalidyear);\n var packedDate =\n CHINESE_NEW_YEAR[validatedYear - CHINESE_NEW_YEAR[0]];\n\n var y = (packedDate >> 9) & 0xFFF;\n var m = (packedDate >> 5) & 0x0F;\n var d = packedDate & 0x1F;\n \n // find first Thrusday of the year\n var firstThursday;\n firstThursday = gregorianCalendar.newDate(y, m, d);\n firstThursday.add(4 - (firstThursday.dayOfWeek() || 7), 'd');\n\n // compute days from first Thursday\n var offset =\n this.toJD(year, monthIndex, day) - firstThursday.toJD();\n return 1 + Math.floor(offset / 7);\n },\n\n /** Retrieve the number of months in a year.\n @memberof ChineseCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The number of months.\n @throws Error if an invalid year or a different calendar used. */\n monthsInYear: function(year) {\n return (this.leapYear(year)) ? 13 : 12;\n },\n\n /** Retrieve the number of days in a month.\n @memberof ChineseCalendar\n @param year {CDate|number} The date to examine or the year of the month.\n @param [monthIndex] {number} The month index.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function(year, monthIndex) {\n if (year.year) {\n monthIndex = year.month();\n year = year.year();\n }\n\n year = this._validateYear(year);\n\n var monthDaysTable = LUNAR_MONTH_DAYS[year - LUNAR_MONTH_DAYS[0]];\n\n var intercalaryMonth = monthDaysTable >> 13;\n var maxMonthIndex = (intercalaryMonth) ? 12 : 11;\n if (monthIndex > maxMonthIndex) {\n throw main.local.invalidMonth\n .replace(/\\{0\\}/, this.local.name);\n }\n\n var daysInMonth = (monthDaysTable & (1 << (12 - monthIndex))) ?\n 30 : 29;\n\n return daysInMonth;\n },\n\n /** Determine whether this date is a week day.\n @memberof ChineseCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [monthIndex] {number} The month index to examine.\n @param [day] {number} The day to examine.\n @return {boolean} true if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function(year, monthIndex, day) {\n return (this.dayOfWeek(year, monthIndex, day) || 7) < 6;\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof ChineseCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [monthIndex] {number} The month index to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function(year, monthIndex, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n year = this._validateYear(date.year());\n monthIndex = date.month();\n day = date.day();\n\n var isIntercalary = this.isIntercalaryMonth(year, monthIndex);\n var month = this.toChineseMonth(year, monthIndex);\n\n var solar = toSolar(year, month, day, isIntercalary);\n\n return gregorianCalendar.toJD(solar.year, solar.month, solar.day);\n },\n\n /** Create a new date from a Julian date.\n @memberof ChineseCalendar\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function(jd) {\n var date = gregorianCalendar.fromJD(jd);\n var lunar = toLunar(date.year(), date.month(), date.day());\n var monthIndex = this.toMonthIndex(\n lunar.year, lunar.month, lunar.isIntercalary);\n return this.newDate(lunar.year, monthIndex, lunar.day);\n },\n\n /** Create a new date from a string.\n @memberof ChineseCalendar\n @param dateString {string} String representing a Chinese date\n @return {CDate} The new date.\n @throws Error if an invalid date. */\n fromString: function(dateString) {\n var match = dateString.match(DATE_REGEXP);\n\n var year = this._validateYear(+match[1]);\n\n var month = +match[2];\n var isIntercalary = !!match[3];\n var monthIndex = this.toMonthIndex(year, month, isIntercalary);\n\n var day = +match[4];\n\n return this.newDate(year, monthIndex, day);\n },\n\n /** Add period(s) to a date.\n Cater for no year zero.\n @memberof ChineseCalendar\n @param date {CDate} The starting date.\n @param offset {number} The number of periods to adjust by.\n @param period {string} One of 'y' for year, 'm' for month, 'w' for week, 'd' for day.\n @return {CDate} The updated date.\n @throws Error if a different calendar used. */\n add: function(date, offset, period) {\n var year = date.year();\n var monthIndex = date.month();\n var isIntercalary = this.isIntercalaryMonth(year, monthIndex);\n var month = this.toChineseMonth(year, monthIndex);\n\n var cdate = Object.getPrototypeOf(ChineseCalendar.prototype)\n .add.call(this, date, offset, period);\n\n if (period === 'y') {\n // Resync month\n var resultYear = cdate.year();\n var resultMonthIndex = cdate.month();\n\n // Using the fact the month index of an intercalary month\n // equals its month number:\n var resultCanBeIntercalaryMonth =\n this.isIntercalaryMonth(resultYear, month);\n\n var correctedMonthIndex =\n (isIntercalary && resultCanBeIntercalaryMonth) ?\n this.toMonthIndex(resultYear, month, true) :\n this.toMonthIndex(resultYear, month, false);\n\n if (correctedMonthIndex !== resultMonthIndex) {\n cdate.month(correctedMonthIndex);\n }\n }\n\n return cdate;\n },\n});\n\n// Used by ChineseCalendar.prototype.fromString\nvar DATE_REGEXP = /^\\s*(-?\\d\\d\\d\\d|\\d\\d)[-/](\\d?\\d)([iI]?)[-/](\\d?\\d)/m;\nvar MONTH_NUMBER_REGEXP = /^\\d?\\d[iI]?/m;\nvar MONTH_NAME_REGEXP = /^闰?十?[一二三四五六七八九]?月/m;\nvar MONTH_SHORT_NAME_REGEXP = /^闰?十?[一二三四五六七八九]?/m;\n\n// Chinese calendar implementation\nmain.calendars.chinese = ChineseCalendar;\n\n// Chinese calendar tables from year 1888 to 2111\n//\n// Source:\n// https://github.com/isee15/Lunar-Solar-Calendar-Converter.git\n\n// Table of intercalary months and days per month from year 1888 to 2111\n//\n// bit (12 - i): days in the i^th month\n// (= 0 if i^th lunar month has 29 days)\n// (= 1 if i^th lunar month has 30 days)\n// (first month in lunar year is i = 0)\n// bits (13,14,15,16): intercalary month\n// (= 0 if lunar year has no intercalary month)\nvar LUNAR_MONTH_DAYS = [1887, 0x1694, 0x16aa, 0x4ad5,\n 0xab6, 0xc4b7, 0x4ae, 0xa56, 0xb52a, 0x1d2a, 0xd54, 0x75aa, 0x156a,\n 0x1096d, 0x95c, 0x14ae, 0xaa4d, 0x1a4c, 0x1b2a, 0x8d55, 0xad4,\n 0x135a, 0x495d, 0x95c, 0xd49b, 0x149a, 0x1a4a, 0xbaa5, 0x16a8,\n 0x1ad4, 0x52da, 0x12b6, 0xe937, 0x92e, 0x1496, 0xb64b, 0xd4a,\n 0xda8, 0x95b5, 0x56c, 0x12ae, 0x492f, 0x92e, 0xcc96, 0x1a94,\n 0x1d4a, 0xada9, 0xb5a, 0x56c, 0x726e, 0x125c, 0xf92d, 0x192a,\n 0x1a94, 0xdb4a, 0x16aa, 0xad4, 0x955b, 0x4ba, 0x125a, 0x592b,\n 0x152a, 0xf695, 0xd94, 0x16aa, 0xaab5, 0x9b4, 0x14b6, 0x6a57,\n 0xa56, 0x1152a, 0x1d2a, 0xd54, 0xd5aa, 0x156a, 0x96c, 0x94ae,\n 0x14ae, 0xa4c, 0x7d26, 0x1b2a, 0xeb55, 0xad4, 0x12da, 0xa95d,\n 0x95a, 0x149a, 0x9a4d, 0x1a4a, 0x11aa5, 0x16a8, 0x16d4, 0xd2da,\n 0x12b6, 0x936, 0x9497, 0x1496, 0x1564b, 0xd4a, 0xda8, 0xd5b4,\n 0x156c, 0x12ae, 0xa92f, 0x92e, 0xc96, 0x6d4a, 0x1d4a, 0x10d65,\n 0xb58, 0x156c, 0xb26d, 0x125c, 0x192c, 0x9a95, 0x1a94, 0x1b4a,\n 0x4b55, 0xad4, 0xf55b, 0x4ba, 0x125a, 0xb92b, 0x152a, 0x1694,\n 0x96aa, 0x15aa, 0x12ab5, 0x974, 0x14b6, 0xca57, 0xa56, 0x1526,\n 0x8e95, 0xd54, 0x15aa, 0x49b5, 0x96c, 0xd4ae, 0x149c, 0x1a4c,\n 0xbd26, 0x1aa6, 0xb54, 0x6d6a, 0x12da, 0x1695d, 0x95a, 0x149a,\n 0xda4b, 0x1a4a, 0x1aa4, 0xbb54, 0x16b4, 0xada, 0x495b, 0x936,\n 0xf497, 0x1496, 0x154a, 0xb6a5, 0xda4, 0x15b4, 0x6ab6, 0x126e,\n 0x1092f, 0x92e, 0xc96, 0xcd4a, 0x1d4a, 0xd64, 0x956c, 0x155c,\n 0x125c, 0x792e, 0x192c, 0xfa95, 0x1a94, 0x1b4a, 0xab55, 0xad4,\n 0x14da, 0x8a5d, 0xa5a, 0x1152b, 0x152a, 0x1694, 0xd6aa, 0x15aa,\n 0xab4, 0x94ba, 0x14b6, 0xa56, 0x7527, 0xd26, 0xee53, 0xd54, 0x15aa,\n 0xa9b5, 0x96c, 0x14ae, 0x8a4e, 0x1a4c, 0x11d26, 0x1aa4, 0x1b54,\n 0xcd6a, 0xada, 0x95c, 0x949d, 0x149a, 0x1a2a, 0x5b25, 0x1aa4,\n 0xfb52, 0x16b4, 0xaba, 0xa95b, 0x936, 0x1496, 0x9a4b, 0x154a,\n 0x136a5, 0xda4, 0x15ac];\n\n// Table of Chinese New Years from year 1888 to 2111\n// \n// bits (0 to 4): solar day\n// bits (5 to 8): solar month\n// bits (9 to 20): solar year\nvar CHINESE_NEW_YEAR = [1887, 0xec04c, 0xec23f, 0xec435, 0xec649,\n 0xec83e, 0xeca51, 0xecc46, 0xece3a, 0xed04d, 0xed242, 0xed436,\n 0xed64a, 0xed83f, 0xeda53, 0xedc48, 0xede3d, 0xee050, 0xee244,\n 0xee439, 0xee64d, 0xee842, 0xeea36, 0xeec4a, 0xeee3e, 0xef052,\n 0xef246, 0xef43a, 0xef64e, 0xef843, 0xefa37, 0xefc4b, 0xefe41,\n 0xf0054, 0xf0248, 0xf043c, 0xf0650, 0xf0845, 0xf0a38, 0xf0c4d,\n 0xf0e42, 0xf1037, 0xf124a, 0xf143e, 0xf1651, 0xf1846, 0xf1a3a,\n 0xf1c4e, 0xf1e44, 0xf2038, 0xf224b, 0xf243f, 0xf2653, 0xf2848,\n 0xf2a3b, 0xf2c4f, 0xf2e45, 0xf3039, 0xf324d, 0xf3442, 0xf3636,\n 0xf384a, 0xf3a3d, 0xf3c51, 0xf3e46, 0xf403b, 0xf424e, 0xf4443,\n 0xf4638, 0xf484c, 0xf4a3f, 0xf4c52, 0xf4e48, 0xf503c, 0xf524f,\n 0xf5445, 0xf5639, 0xf584d, 0xf5a42, 0xf5c35, 0xf5e49, 0xf603e,\n 0xf6251, 0xf6446, 0xf663b, 0xf684f, 0xf6a43, 0xf6c37, 0xf6e4b,\n 0xf703f, 0xf7252, 0xf7447, 0xf763c, 0xf7850, 0xf7a45, 0xf7c39,\n 0xf7e4d, 0xf8042, 0xf8254, 0xf8449, 0xf863d, 0xf8851, 0xf8a46,\n 0xf8c3b, 0xf8e4f, 0xf9044, 0xf9237, 0xf944a, 0xf963f, 0xf9853,\n 0xf9a47, 0xf9c3c, 0xf9e50, 0xfa045, 0xfa238, 0xfa44c, 0xfa641,\n 0xfa836, 0xfaa49, 0xfac3d, 0xfae52, 0xfb047, 0xfb23a, 0xfb44e,\n 0xfb643, 0xfb837, 0xfba4a, 0xfbc3f, 0xfbe53, 0xfc048, 0xfc23c,\n 0xfc450, 0xfc645, 0xfc839, 0xfca4c, 0xfcc41, 0xfce36, 0xfd04a,\n 0xfd23d, 0xfd451, 0xfd646, 0xfd83a, 0xfda4d, 0xfdc43, 0xfde37,\n 0xfe04b, 0xfe23f, 0xfe453, 0xfe648, 0xfe83c, 0xfea4f, 0xfec44,\n 0xfee38, 0xff04c, 0xff241, 0xff436, 0xff64a, 0xff83e, 0xffa51,\n 0xffc46, 0xffe3a, 0x10004e, 0x100242, 0x100437, 0x10064b, 0x100841,\n 0x100a53, 0x100c48, 0x100e3c, 0x10104f, 0x101244, 0x101438,\n 0x10164c, 0x101842, 0x101a35, 0x101c49, 0x101e3d, 0x102051,\n 0x102245, 0x10243a, 0x10264e, 0x102843, 0x102a37, 0x102c4b,\n 0x102e3f, 0x103053, 0x103247, 0x10343b, 0x10364f, 0x103845,\n 0x103a38, 0x103c4c, 0x103e42, 0x104036, 0x104249, 0x10443d,\n 0x104651, 0x104846, 0x104a3a, 0x104c4e, 0x104e43, 0x105038,\n 0x10524a, 0x10543e, 0x105652, 0x105847, 0x105a3b, 0x105c4f,\n 0x105e45, 0x106039, 0x10624c, 0x106441, 0x106635, 0x106849,\n 0x106a3d, 0x106c51, 0x106e47, 0x10703c, 0x10724f, 0x107444,\n 0x107638, 0x10784c, 0x107a3f, 0x107c53, 0x107e48];\n\nfunction toLunar(yearOrDate, monthOrResult, day, result) {\n var solarDate;\n var lunarDate;\n\n if(typeof yearOrDate === 'object') {\n solarDate = yearOrDate;\n lunarDate = monthOrResult || {};\n\n } else {\n var isValidYear = (typeof yearOrDate === 'number') &&\n (yearOrDate >= 1888) && (yearOrDate <= 2111);\n if(!isValidYear)\n throw new Error(\"Solar year outside range 1888-2111\");\n\n var isValidMonth = (typeof monthOrResult === 'number') &&\n (monthOrResult >= 1) && (monthOrResult <= 12);\n if(!isValidMonth)\n throw new Error(\"Solar month outside range 1 - 12\");\n\n var isValidDay = (typeof day === 'number') && (day >= 1) && (day <= 31);\n if(!isValidDay)\n throw new Error(\"Solar day outside range 1 - 31\");\n\n solarDate = {\n year: yearOrDate,\n month: monthOrResult,\n day: day,\n };\n lunarDate = result || {};\n }\n\n // Compute Chinese new year and lunar year\n var chineseNewYearPackedDate =\n CHINESE_NEW_YEAR[solarDate.year - CHINESE_NEW_YEAR[0]];\n\n var packedDate = (solarDate.year << 9) | (solarDate.month << 5)\n | solarDate.day;\n\n lunarDate.year = (packedDate >= chineseNewYearPackedDate) ?\n solarDate.year :\n solarDate.year - 1;\n\n chineseNewYearPackedDate =\n CHINESE_NEW_YEAR[lunarDate.year - CHINESE_NEW_YEAR[0]];\n\n var y = (chineseNewYearPackedDate >> 9) & 0xFFF;\n var m = (chineseNewYearPackedDate >> 5) & 0x0F;\n var d = chineseNewYearPackedDate & 0x1F;\n\n // Compute days from new year\n var daysFromNewYear;\n\n var chineseNewYearJSDate = new Date(y, m -1, d);\n var jsDate = new Date(solarDate.year, solarDate.month - 1, solarDate.day);\n\n daysFromNewYear = Math.round(\n (jsDate - chineseNewYearJSDate) / (24 * 3600 * 1000));\n\n // Compute lunar month and day\n var monthDaysTable = LUNAR_MONTH_DAYS[lunarDate.year - LUNAR_MONTH_DAYS[0]];\n\n var i;\n for(i = 0; i < 13; i++) {\n var daysInMonth = (monthDaysTable & (1 << (12 - i))) ? 30 : 29;\n\n if (daysFromNewYear < daysInMonth) {\n break;\n }\n\n daysFromNewYear -= daysInMonth;\n }\n\n var intercalaryMonth = monthDaysTable >> 13;\n if (!intercalaryMonth || i < intercalaryMonth) {\n lunarDate.isIntercalary = false;\n lunarDate.month = 1 + i;\n } else if (i === intercalaryMonth) {\n lunarDate.isIntercalary = true;\n lunarDate.month = i;\n } else {\n lunarDate.isIntercalary = false;\n lunarDate.month = i;\n }\n\n lunarDate.day = 1 + daysFromNewYear;\n\n return lunarDate;\n}\n\nfunction toSolar(yearOrDate, monthOrResult, day, isIntercalaryOrResult, result) {\n var solarDate;\n var lunarDate;\n\n if(typeof yearOrDate === 'object') {\n lunarDate = yearOrDate;\n solarDate = monthOrResult || {};\n\n } else {\n var isValidYear = (typeof yearOrDate === 'number') &&\n (yearOrDate >= 1888) && (yearOrDate <= 2111);\n if(!isValidYear)\n throw new Error(\"Lunar year outside range 1888-2111\");\n\n var isValidMonth = (typeof monthOrResult === 'number') &&\n (monthOrResult >= 1) && (monthOrResult <= 12);\n if(!isValidMonth)\n throw new Error(\"Lunar month outside range 1 - 12\");\n\n var isValidDay = (typeof day === 'number') && (day >= 1) && (day <= 30);\n if(!isValidDay)\n throw new Error(\"Lunar day outside range 1 - 30\");\n\n var isIntercalary;\n if(typeof isIntercalaryOrResult === 'object') {\n isIntercalary = false;\n solarDate = isIntercalaryOrResult;\n } else {\n isIntercalary = !!isIntercalaryOrResult;\n solarDate = result || {};\n }\n\n lunarDate = {\n year: yearOrDate,\n month: monthOrResult,\n day: day,\n isIntercalary: isIntercalary,\n };\n }\n\n // Compute days from new year\n var daysFromNewYear;\n\n daysFromNewYear = lunarDate.day - 1;\n\n var monthDaysTable = LUNAR_MONTH_DAYS[lunarDate.year - LUNAR_MONTH_DAYS[0]];\n var intercalaryMonth = monthDaysTable >> 13;\n\n var monthsFromNewYear;\n if (!intercalaryMonth) {\n monthsFromNewYear = lunarDate.month - 1;\n } else if (lunarDate.month > intercalaryMonth) {\n monthsFromNewYear = lunarDate.month;\n } else if (lunarDate.isIntercalary) {\n monthsFromNewYear = lunarDate.month;\n } else {\n monthsFromNewYear = lunarDate.month - 1;\n }\n\n for(var i = 0; i < monthsFromNewYear; i++) {\n var daysInMonth = (monthDaysTable & (1 << (12 - i))) ? 30 : 29;\n daysFromNewYear += daysInMonth;\n }\n\n // Compute Chinese new year\n var packedDate = CHINESE_NEW_YEAR[lunarDate.year - CHINESE_NEW_YEAR[0]];\n\n var y = (packedDate >> 9) & 0xFFF;\n var m = (packedDate >> 5) & 0x0F;\n var d = packedDate & 0x1F;\n\n // Compute solar date\n var jsDate = new Date(y, m - 1, d + daysFromNewYear);\n\n solarDate.year = jsDate.getFullYear();\n solarDate.month = 1 + jsDate.getMonth();\n solarDate.day = jsDate.getDate();\n\n return solarDate;\n}\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Coptic calendar for jQuery v2.0.2.\n Written by Keith Wood (wood.keith{at}optusnet.com.au) February 2010.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar main = require('../main');\nvar assign = require('object-assign');\n\n\n/** Implementation of the Coptic calendar.\n See http://en.wikipedia.org/wiki/Coptic_calendar.\n See also Calendrical Calculations: The Millennium Edition\n (http://emr.cs.iit.edu/home/reingold/calendar-book/index.shtml).\n @class CopticCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction CopticCalendar(language) {\n this.local = this.regionalOptions[language || ''] || this.regionalOptions[''];\n}\n\nCopticCalendar.prototype = new main.baseCalendar;\n\nassign(CopticCalendar.prototype, {\n /** The calendar name.\n @memberof CopticCalendar */\n name: 'Coptic',\n /** Julian date of start of Coptic epoch: 29 August 284 CE (Gregorian).\n @memberof CopticCalendar */\n jdEpoch: 1825029.5,\n /** Days per month in a common year.\n @memberof CopticCalendar */\n daysPerMonth: [30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 5],\n /** true if has a year zero, false if not.\n @memberof CopticCalendar */\n hasYearZero: false,\n /** The minimum month number.\n @memberof CopticCalendar */\n minMonth: 1,\n /** The first month in the year.\n @memberof CopticCalendar */\n firstMonth: 1,\n /** The minimum day number.\n @memberof CopticCalendar */\n minDay: 1,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof CopticCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left. */\n regionalOptions: { // Localisations\n '': {\n name: 'Coptic',\n epochs: ['BAM', 'AM'],\n monthNames: ['Thout', 'Paopi', 'Hathor', 'Koiak', 'Tobi', 'Meshir',\n 'Paremhat', 'Paremoude', 'Pashons', 'Paoni', 'Epip', 'Mesori', 'Pi Kogi Enavot'],\n monthNamesShort: ['Tho', 'Pao', 'Hath', 'Koi', 'Tob', 'Mesh',\n 'Pat', 'Pad', 'Pash', 'Pao', 'Epi', 'Meso', 'PiK'],\n dayNames: ['Tkyriaka', 'Pesnau', 'Pshoment', 'Peftoou', 'Ptiou', 'Psoou', 'Psabbaton'],\n dayNamesShort: ['Tky', 'Pes', 'Psh', 'Pef', 'Pti', 'Pso', 'Psa'],\n dayNamesMin: ['Tk', 'Pes', 'Psh', 'Pef', 'Pt', 'Pso', 'Psa'],\n digits: null,\n dateFormat: 'dd/mm/yyyy',\n firstDay: 0,\n isRTL: false\n }\n },\n\n /** Determine whether this date is in a leap year.\n @memberof CopticCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n var year = date.year() + (date.year() < 0 ? 1 : 0); // No year zero\n return year % 4 === 3 || year % 4 === -1;\n },\n\n /** Retrieve the number of months in a year.\n @memberof CopticCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The number of months.\n @throws Error if an invalid year or a different calendar used. */\n monthsInYear: function(year) {\n this._validate(year, this.minMonth, this.minDay,\n main.local.invalidYear || main.regionalOptions[''].invalidYear);\n return 13;\n },\n\n /** Determine the week of the year for a date.\n @memberof CopticCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number) the month to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function(year, month, day) {\n // Find Sunday of this week starting on Sunday\n var checkDate = this.newDate(year, month, day);\n checkDate.add(-checkDate.dayOfWeek(), 'd');\n return Math.floor((checkDate.dayOfYear() - 1) / 7) + 1;\n },\n\n /** Retrieve the number of days in a month.\n @memberof CopticCalendar\n @param year {CDate|number} The date to examine or the year of the month.\n @param [month] {number} The month.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function(year, month) {\n var date = this._validate(year, month, this.minDay, main.local.invalidMonth);\n return this.daysPerMonth[date.month() - 1] +\n (date.month() === 13 && this.leapYear(date.year()) ? 1 : 0);\n },\n\n /** Determine whether this date is a week day.\n @memberof CopticCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param month {number} The month to examine.\n @param day {number} The day to examine.\n @return {boolean} true if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function(year, month, day) {\n return (this.dayOfWeek(year, month, day) || 7) < 6;\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof CopticCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number) the month to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n year = date.year();\n if (year < 0) { year++; } // No year zero\n return date.day() + (date.month() - 1) * 30 +\n (year - 1) * 365 + Math.floor(year / 4) + this.jdEpoch - 1;\n },\n\n /** Create a new date from a Julian date.\n @memberof CopticCalendar\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function(jd) {\n var c = Math.floor(jd) + 0.5 - this.jdEpoch;\n var year = Math.floor((c - Math.floor((c + 366) / 1461)) / 365) + 1;\n if (year <= 0) { year--; } // No year zero\n c = Math.floor(jd) + 0.5 - this.newDate(year, 1, 1).toJD();\n var month = Math.floor(c / 30) + 1;\n var day = c - (month - 1) * 30 + 1;\n return this.newDate(year, month, day);\n }\n});\n\n// Coptic calendar implementation\nmain.calendars.coptic = CopticCalendar;\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Discworld calendar for jQuery v2.0.2.\n Written by Keith Wood (wood.keith{at}optusnet.com.au) January 2016.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar main = require('../main');\nvar assign = require('object-assign');\n\n\n/** Implementation of the Discworld calendar - Unseen University version.\n See also http://wiki.lspace.org/mediawiki/Discworld_calendar\n and http://discworld.wikia.com/wiki/Discworld_calendar.\n @class DiscworldCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction DiscworldCalendar(language) {\n this.local = this.regionalOptions[language || ''] || this.regionalOptions[''];\n}\n\nDiscworldCalendar.prototype = new main.baseCalendar;\n\nassign(DiscworldCalendar.prototype, {\n /** The calendar name.\n @memberof DiscworldCalendar */\n name: 'Discworld',\n /** Julian date of start of Discworld epoch: 1 January 0001 CE.\n @memberof DiscworldCalendar */\n jdEpoch: 1721425.5,\n /** Days per month in a common year.\n @memberof DiscworldCalendar */\n daysPerMonth: [16, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32],\n /** true if has a year zero, false if not.\n @memberof DiscworldCalendar */\n hasYearZero: false,\n /** The minimum month number.\n @memberof DiscworldCalendar */\n minMonth: 1,\n /** The first month in the year.\n @memberof DiscworldCalendar */\n firstMonth: 1,\n /** The minimum day number.\n @memberof DiscworldCalendar */\n minDay: 1,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof DiscworldCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left. */\n regionalOptions: { // Localisations\n '': {\n name: 'Discworld',\n epochs: ['BUC', 'UC'],\n monthNames: ['Ick', 'Offle', 'February', 'March', 'April', 'May', 'June',\n 'Grune', 'August', 'Spune', 'Sektober', 'Ember', 'December'],\n monthNamesShort: ['Ick', 'Off', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Gru', 'Aug', 'Spu', 'Sek', 'Emb', 'Dec'],\n dayNames: ['Sunday', 'Octeday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],\n dayNamesShort: ['Sun', 'Oct', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n dayNamesMin: ['Su', 'Oc', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],\n digits: null,\n dateFormat: 'yyyy/mm/dd',\n firstDay: 2,\n isRTL: false\n }\n },\n\n /** Determine whether this date is in a leap year.\n @memberof DiscworldCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function(year) {\n this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n return false;\n },\n\n /** Retrieve the number of months in a year.\n @memberof DiscworldCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The number of months.\n @throws Error if an invalid year or a different calendar used. */\n monthsInYear: function(year) {\n this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n return 13;\n },\n\n /** Retrieve the number of days in a year.\n @memberof DiscworldCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The number of days.\n @throws Error if an invalid year or a different calendar used. */\n daysInYear: function(year) {\n this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n return 400;\n },\n\n /** Determine the week of the year for a date.\n @memberof DiscworldCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function(year, month, day) {\n // Find Sunday of this week starting on Sunday\n var checkDate = this.newDate(year, month, day);\n checkDate.add(-checkDate.dayOfWeek(), 'd');\n return Math.floor((checkDate.dayOfYear() - 1) / 8) + 1;\n },\n\n /** Retrieve the number of days in a month.\n @memberof DiscworldCalendar\n @param year {CDate|number} The date to examine or the year of the month.\n @param [month] {number} The month.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function(year, month) {\n var date = this._validate(year, month, this.minDay, main.local.invalidMonth);\n return this.daysPerMonth[date.month() - 1];\n },\n\n /** Retrieve the number of days in a week.\n @memberof DiscworldCalendar\n @return {number} The number of days. */\n daysInWeek: function() {\n return 8;\n },\n\n /** Retrieve the day of the week for a date.\n @memberof DiscworldCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The day of the week: 0 to number of days - 1.\n @throws Error if an invalid date or a different calendar used. */\n dayOfWeek: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n return (date.day() + 1) % 8;\n },\n\n /** Determine whether this date is a week day.\n @memberof DiscworldCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {boolean} true if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function(year, month, day) {\n var dow = this.dayOfWeek(year, month, day);\n return (dow >= 2 && dow <= 6);\n },\n\n /** Retrieve additional information about a date.\n @memberof DiscworldCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {object} Additional information - contents depends on calendar.\n @throws Error if an invalid date or a different calendar used. */\n extraInfo: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n return {century: centuries[Math.floor((date.year() - 1) / 100) + 1] || ''};\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof DiscworldCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n year = date.year() + (date.year() < 0 ? 1 : 0);\n month = date.month();\n day = date.day();\n return day + (month > 1 ? 16 : 0) + (month > 2 ? (month - 2) * 32 : 0) +\n (year - 1) * 400 + this.jdEpoch - 1;\n },\n\n /** Create a new date from a Julian date.\n @memberof DiscworldCalendar\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function(jd) {\n jd = Math.floor(jd + 0.5) - Math.floor(this.jdEpoch) - 1;\n var year = Math.floor(jd / 400) + 1;\n jd -= (year - 1) * 400;\n jd += (jd > 15 ? 16 : 0);\n var month = Math.floor(jd / 32) + 1;\n var day = jd - (month - 1) * 32 + 1;\n return this.newDate(year <= 0 ? year - 1 : year, month, day);\n }\n});\n\n// Names of the centuries\nvar centuries = {\n 20: 'Fruitbat',\n 21: 'Anchovy'\n};\n\n// Discworld calendar implementation\nmain.calendars.discworld = DiscworldCalendar;\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Ethiopian calendar for jQuery v2.0.2.\n Written by Keith Wood (wood.keith{at}optusnet.com.au) February 2010.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar main = require('../main');\nvar assign = require('object-assign');\n\n\n/** Implementation of the Ethiopian calendar.\n See http://en.wikipedia.org/wiki/Ethiopian_calendar.\n See also Calendrical Calculations: The Millennium Edition\n (http://emr.cs.iit.edu/home/reingold/calendar-book/index.shtml).\n @class EthiopianCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction EthiopianCalendar(language) {\n this.local = this.regionalOptions[language || ''] || this.regionalOptions[''];\n}\n\nEthiopianCalendar.prototype = new main.baseCalendar;\n\nassign(EthiopianCalendar.prototype, {\n /** The calendar name.\n @memberof EthiopianCalendar */\n name: 'Ethiopian',\n /** Julian date of start of Ethiopian epoch: 27 August 8 CE (Gregorian).\n @memberof EthiopianCalendar */\n jdEpoch: 1724220.5,\n /** Days per month in a common year.\n @memberof EthiopianCalendar */\n daysPerMonth: [30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 5],\n /** true if has a year zero, false if not.\n @memberof EthiopianCalendar */\n hasYearZero: false,\n /** The minimum month number.\n @memberof EthiopianCalendar */\n minMonth: 1,\n /** The first month in the year.\n @memberof EthiopianCalendar */\n firstMonth: 1,\n /** The minimum day number.\n @memberof EthiopianCalendar */\n minDay: 1,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof EthiopianCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left. */\n regionalOptions: { // Localisations\n '': {\n name: 'Ethiopian',\n epochs: ['BEE', 'EE'],\n monthNames: ['Meskerem', 'Tikemet', 'Hidar', 'Tahesas', 'Tir', 'Yekatit',\n 'Megabit', 'Miazia', 'Genbot', 'Sene', 'Hamle', 'Nehase', 'Pagume'],\n monthNamesShort: ['Mes', 'Tik', 'Hid', 'Tah', 'Tir', 'Yek',\n 'Meg', 'Mia', 'Gen', 'Sen', 'Ham', 'Neh', 'Pag'],\n dayNames: ['Ehud', 'Segno', 'Maksegno', 'Irob', 'Hamus', 'Arb', 'Kidame'],\n dayNamesShort: ['Ehu', 'Seg', 'Mak', 'Iro', 'Ham', 'Arb', 'Kid'],\n dayNamesMin: ['Eh', 'Se', 'Ma', 'Ir', 'Ha', 'Ar', 'Ki'],\n digits: null,\n dateFormat: 'dd/mm/yyyy',\n firstDay: 0,\n isRTL: false\n }\n },\n\n /** Determine whether this date is in a leap year.\n @memberof EthiopianCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n var year = date.year() + (date.year() < 0 ? 1 : 0); // No year zero\n return year % 4 === 3 || year % 4 === -1;\n },\n\n /** Retrieve the number of months in a year.\n @memberof EthiopianCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The number of months.\n @throws Error if an invalid year or a different calendar used. */\n monthsInYear: function(year) {\n this._validate(year, this.minMonth, this.minDay,\n main.local.invalidYear || main.regionalOptions[''].invalidYear);\n return 13;\n },\n\n /** Determine the week of the year for a date.\n @memberof EthiopianCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function(year, month, day) {\n // Find Sunday of this week starting on Sunday\n var checkDate = this.newDate(year, month, day);\n checkDate.add(-checkDate.dayOfWeek(), 'd');\n return Math.floor((checkDate.dayOfYear() - 1) / 7) + 1;\n },\n\n /** Retrieve the number of days in a month.\n @memberof EthiopianCalendar\n @param year {CDate|number} The date to examine or the year of the month.\n @param [month] {number} The month.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function(year, month) {\n var date = this._validate(year, month, this.minDay, main.local.invalidMonth);\n return this.daysPerMonth[date.month() - 1] +\n (date.month() === 13 && this.leapYear(date.year()) ? 1 : 0);\n },\n\n /** Determine whether this date is a week day.\n @memberof EthiopianCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {boolean} true if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function(year, month, day) {\n return (this.dayOfWeek(year, month, day) || 7) < 6;\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof EthiopianCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n year = date.year();\n if (year < 0) { year++; } // No year zero\n return date.day() + (date.month() - 1) * 30 +\n (year - 1) * 365 + Math.floor(year / 4) + this.jdEpoch - 1;\n },\n\n /** Create a new date from a Julian date.\n @memberof EthiopianCalendar\n @param jd {number} the Julian date to convert.\n @return {CDate} the equivalent date. */\n fromJD: function(jd) {\n var c = Math.floor(jd) + 0.5 - this.jdEpoch;\n var year = Math.floor((c - Math.floor((c + 366) / 1461)) / 365) + 1;\n if (year <= 0) { year--; } // No year zero\n c = Math.floor(jd) + 0.5 - this.newDate(year, 1, 1).toJD();\n var month = Math.floor(c / 30) + 1;\n var day = c - (month - 1) * 30 + 1;\n return this.newDate(year, month, day);\n }\n});\n\n// Ethiopian calendar implementation\nmain.calendars.ethiopian = EthiopianCalendar;\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Hebrew calendar for jQuery v2.0.2.\n Written by Keith Wood (wood.keith{at}optusnet.com.au) August 2009.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar main = require('../main');\nvar assign = require('object-assign');\n\n\n/** Implementation of the Hebrew civil calendar.\n Based on code from http://www.fourmilab.ch/documents/calendar/.\n See also http://en.wikipedia.org/wiki/Hebrew_calendar.\n @class HebrewCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction HebrewCalendar(language) {\n this.local = this.regionalOptions[language || ''] || this.regionalOptions[''];\n}\n\nHebrewCalendar.prototype = new main.baseCalendar;\n\nassign(HebrewCalendar.prototype, {\n /** The calendar name.\n @memberof HebrewCalendar */\n name: 'Hebrew',\n /** Julian date of start of Hebrew epoch: 7 October 3761 BCE.\n @memberof HebrewCalendar */\n jdEpoch: 347995.5,\n /** Days per month in a common year.\n @memberof HebrewCalendar */\n daysPerMonth: [30, 29, 30, 29, 30, 29, 30, 29, 30, 29, 30, 29, 29],\n /** true if has a year zero, false if not.\n @memberof HebrewCalendar */\n hasYearZero: false,\n /** The minimum month number.\n @memberof HebrewCalendar */\n minMonth: 1,\n /** The first month in the year.\n @memberof HebrewCalendar */\n firstMonth: 7,\n /** The minimum day number.\n @memberof HebrewCalendar */\n minDay: 1,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof HebrewCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left. */\n regionalOptions: { // Localisations\n '': {\n name: 'Hebrew',\n epochs: ['BAM', 'AM'],\n monthNames: ['Nisan', 'Iyar', 'Sivan', 'Tammuz', 'Av', 'Elul',\n 'Tishrei', 'Cheshvan', 'Kislev', 'Tevet', 'Shevat', 'Adar', 'Adar II'],\n monthNamesShort: ['Nis', 'Iya', 'Siv', 'Tam', 'Av', 'Elu', 'Tis', 'Che', 'Kis', 'Tev', 'She', 'Ada', 'Ad2'],\n dayNames: ['Yom Rishon', 'Yom Sheni', 'Yom Shlishi', 'Yom Revi\\'i', 'Yom Chamishi', 'Yom Shishi', 'Yom Shabbat'],\n dayNamesShort: ['Ris', 'She', 'Shl', 'Rev', 'Cha', 'Shi', 'Sha'],\n dayNamesMin: ['Ri','She','Shl','Re','Ch','Shi','Sha'],\n digits: null,\n dateFormat: 'dd/mm/yyyy',\n firstDay: 0,\n isRTL: false\n }\n },\n\n /** Determine whether this date is in a leap year.\n @memberof HebrewCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n return this._leapYear(date.year());\n },\n\n /** Determine whether this date is in a leap year.\n @memberof HebrewCalendar\n @private\n @param year {number} The year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n _leapYear: function(year) {\n year = (year < 0 ? year + 1 : year);\n return mod(year * 7 + 1, 19) < 7;\n },\n\n /** Retrieve the number of months in a year.\n @memberof HebrewCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The number of months.\n @throws Error if an invalid year or a different calendar used. */\n monthsInYear: function(year) {\n this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n return this._leapYear(year.year ? year.year() : year) ? 13 : 12;\n },\n\n /** Determine the week of the year for a date.\n @memberof HebrewCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function(year, month, day) {\n // Find Sunday of this week starting on Sunday\n var checkDate = this.newDate(year, month, day);\n checkDate.add(-checkDate.dayOfWeek(), 'd');\n return Math.floor((checkDate.dayOfYear() - 1) / 7) + 1;\n },\n\n /** Retrieve the number of days in a year.\n @memberof HebrewCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The number of days.\n @throws Error if an invalid year or a different calendar used. */\n daysInYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n year = date.year();\n return this.toJD((year === -1 ? +1 : year + 1), 7, 1) - this.toJD(year, 7, 1);\n },\n\n /** Retrieve the number of days in a month.\n @memberof HebrewCalendar\n @param year {CDate|number} The date to examine or the year of the month.\n @param [month] {number} The month.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function(year, month) {\n if (year.year) {\n month = year.month();\n year = year.year();\n }\n this._validate(year, month, this.minDay, main.local.invalidMonth);\n return (month === 12 && this.leapYear(year) ? 30 : // Adar I\n (month === 8 && mod(this.daysInYear(year), 10) === 5 ? 30 : // Cheshvan in shlemah year\n (month === 9 && mod(this.daysInYear(year), 10) === 3 ? 29 : // Kislev in chaserah year\n this.daysPerMonth[month - 1])));\n },\n\n /** Determine whether this date is a week day.\n @memberof HebrewCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {boolean} true if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function(year, month, day) {\n return this.dayOfWeek(year, month, day) !== 6;\n },\n\n /** Retrieve additional information about a date - year type.\n @memberof HebrewCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {object} Additional information - contents depends on calendar.\n @throws Error if an invalid date or a different calendar used. */\n extraInfo: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n return {yearType: (this.leapYear(date) ? 'embolismic' : 'common') + ' ' +\n ['deficient', 'regular', 'complete'][this.daysInYear(date) % 10 - 3]};\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof HebrewCalendar\n @param year {CDate)|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n year = date.year();\n month = date.month();\n day = date.day();\n var adjYear = (year <= 0 ? year + 1 : year);\n var jd = this.jdEpoch + this._delay1(adjYear) +\n this._delay2(adjYear) + day + 1;\n if (month < 7) {\n for (var m = 7; m <= this.monthsInYear(year); m++) {\n jd += this.daysInMonth(year, m);\n }\n for (var m = 1; m < month; m++) {\n jd += this.daysInMonth(year, m);\n }\n }\n else {\n for (var m = 7; m < month; m++) {\n jd += this.daysInMonth(year, m);\n }\n }\n return jd;\n },\n\n /** Test for delay of start of new year and to avoid\n Sunday, Wednesday, or Friday as start of the new year.\n @memberof HebrewCalendar\n @private\n @param year {number} The year to examine.\n @return {number} The days to offset by. */\n _delay1: function(year) {\n var months = Math.floor((235 * year - 234) / 19);\n var parts = 12084 + 13753 * months;\n var day = months * 29 + Math.floor(parts / 25920);\n if (mod(3 * (day + 1), 7) < 3) {\n day++;\n }\n return day;\n },\n\n /** Check for delay in start of new year due to length of adjacent years.\n @memberof HebrewCalendar\n @private\n @param year {number} The year to examine.\n @return {number} The days to offset by. */\n _delay2: function(year) {\n var last = this._delay1(year - 1);\n var present = this._delay1(year);\n var next = this._delay1(year + 1);\n return ((next - present) === 356 ? 2 : ((present - last) === 382 ? 1 : 0));\n },\n\n /** Create a new date from a Julian date.\n @memberof HebrewCalendar\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function(jd) {\n jd = Math.floor(jd) + 0.5;\n var year = Math.floor(((jd - this.jdEpoch) * 98496.0) / 35975351.0) - 1;\n while (jd >= this.toJD((year === -1 ? +1 : year + 1), 7, 1)) {\n year++;\n }\n var month = (jd < this.toJD(year, 1, 1)) ? 7 : 1;\n while (jd > this.toJD(year, month, this.daysInMonth(year, month))) {\n month++;\n }\n var day = jd - this.toJD(year, month, 1) + 1;\n return this.newDate(year, month, day);\n }\n});\n\n// Modulus function which works for non-integers.\nfunction mod(a, b) {\n return a - (b * Math.floor(a / b));\n}\n\n// Hebrew calendar implementation\nmain.calendars.hebrew = HebrewCalendar;\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Islamic calendar for jQuery v2.0.2.\n Written by Keith Wood (wood.keith{at}optusnet.com.au) August 2009.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar main = require('../main');\nvar assign = require('object-assign');\n\n\n/** Implementation of the Islamic or '16 civil' calendar.\n Based on code from http://www.iranchamber.com/calendar/converter/iranian_calendar_converter.php.\n See also http://en.wikipedia.org/wiki/Islamic_calendar.\n @class IslamicCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction IslamicCalendar(language) {\n this.local = this.regionalOptions[language || ''] || this.regionalOptions[''];\n}\n\nIslamicCalendar.prototype = new main.baseCalendar;\n\nassign(IslamicCalendar.prototype, {\n /** The calendar name.\n @memberof IslamicCalendar */\n name: 'Islamic',\n /** Julian date of start of Islamic epoch: 16 July 622 CE.\n @memberof IslamicCalendar */\n jdEpoch: 1948439.5,\n /** Days per month in a common year.\n @memberof IslamicCalendar */\n daysPerMonth: [30, 29, 30, 29, 30, 29, 30, 29, 30, 29, 30, 29],\n /** true if has a year zero, false if not.\n @memberof IslamicCalendar */\n hasYearZero: false,\n /** The minimum month number.\n @memberof IslamicCalendar */\n minMonth: 1,\n /** The first month in the year.\n @memberof IslamicCalendar */\n firstMonth: 1,\n /** The minimum day number.\n @memberof IslamicCalendar */\n minDay: 1,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof IslamicCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left. */\n regionalOptions: { // Localisations\n '': {\n name: 'Islamic',\n epochs: ['BH', 'AH'],\n monthNames: ['Muharram', 'Safar', 'Rabi\\' al-awwal', 'Rabi\\' al-thani', 'Jumada al-awwal', 'Jumada al-thani',\n 'Rajab', 'Sha\\'aban', 'Ramadan', 'Shawwal', 'Dhu al-Qi\\'dah', 'Dhu al-Hijjah'],\n monthNamesShort: ['Muh', 'Saf', 'Rab1', 'Rab2', 'Jum1', 'Jum2', 'Raj', 'Sha\\'', 'Ram', 'Shaw', 'DhuQ', 'DhuH'],\n dayNames: ['Yawm al-ahad', 'Yawm al-ithnayn', 'Yawm ath-thulaathaa\\'',\n 'Yawm al-arbi\\'aa\\'', 'Yawm al-khamīs', 'Yawm al-jum\\'a', 'Yawm as-sabt'],\n dayNamesShort: ['Aha', 'Ith', 'Thu', 'Arb', 'Kha', 'Jum', 'Sab'],\n dayNamesMin: ['Ah','It','Th','Ar','Kh','Ju','Sa'],\n digits: null,\n dateFormat: 'yyyy/mm/dd',\n firstDay: 6,\n isRTL: false\n }\n },\n\n /** Determine whether this date is in a leap year.\n @memberof IslamicCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n return (date.year() * 11 + 14) % 30 < 11;\n },\n\n /** Determine the week of the year for a date.\n @memberof IslamicCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function(year, month, day) {\n // Find Sunday of this week starting on Sunday\n var checkDate = this.newDate(year, month, day);\n checkDate.add(-checkDate.dayOfWeek(), 'd');\n return Math.floor((checkDate.dayOfYear() - 1) / 7) + 1;\n },\n\n /** Retrieve the number of days in a year.\n @memberof IslamicCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The number of days.\n @throws Error if an invalid year or a different calendar used. */\n daysInYear: function(year) {\n return (this.leapYear(year) ? 355 : 354);\n },\n\n /** Retrieve the number of days in a month.\n @memberof IslamicCalendar\n @param year {CDate|number} The date to examine or the year of the month.\n @param [month] {number} The month.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function(year, month) {\n var date = this._validate(year, month, this.minDay, main.local.invalidMonth);\n return this.daysPerMonth[date.month() - 1] +\n (date.month() === 12 && this.leapYear(date.year()) ? 1 : 0);\n },\n\n /** Determine whether this date is a week day.\n @memberof IslamicCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {boolean} true if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function(year, month, day) {\n return this.dayOfWeek(year, month, day) !== 5;\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof IslamicCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n year = date.year();\n month = date.month();\n day = date.day();\n year = (year <= 0 ? year + 1 : year);\n return day + Math.ceil(29.5 * (month - 1)) + (year - 1) * 354 +\n Math.floor((3 + (11 * year)) / 30) + this.jdEpoch - 1;\n },\n\n /** Create a new date from a Julian date.\n @memberof IslamicCalendar\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function(jd) {\n jd = Math.floor(jd) + 0.5;\n var year = Math.floor((30 * (jd - this.jdEpoch) + 10646) / 10631);\n year = (year <= 0 ? year - 1 : year);\n var month = Math.min(12, Math.ceil((jd - 29 - this.toJD(year, 1, 1)) / 29.5) + 1);\n var day = jd - this.toJD(year, month, 1) + 1;\n return this.newDate(year, month, day);\n }\n});\n\n// Islamic (16 civil) calendar implementation\nmain.calendars.islamic = IslamicCalendar;\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Julian calendar for jQuery v2.0.2.\n Written by Keith Wood (wood.keith{at}optusnet.com.au) August 2009.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar main = require('../main');\nvar assign = require('object-assign');\n\n\n/** Implementation of the Julian calendar.\n Based on code from http://www.fourmilab.ch/documents/calendar/.\n See also http://en.wikipedia.org/wiki/Julian_calendar.\n @class JulianCalendar\n @augments BaseCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction JulianCalendar(language) {\n this.local = this.regionalOptions[language || ''] || this.regionalOptions[''];\n}\n\nJulianCalendar.prototype = new main.baseCalendar;\n\nassign(JulianCalendar.prototype, {\n /** The calendar name.\n @memberof JulianCalendar */\n name: 'Julian',\n /** Julian date of start of Julian epoch: 1 January 0001 AD = 30 December 0001 BCE.\n @memberof JulianCalendar */\n jdEpoch: 1721423.5,\n /** Days per month in a common year.\n @memberof JulianCalendar */\n daysPerMonth: [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31],\n /** true if has a year zero, false if not.\n @memberof JulianCalendar */\n hasYearZero: false,\n /** The minimum month number.\n @memberof JulianCalendar */\n minMonth: 1,\n /** The first month in the year.\n @memberof JulianCalendar */\n firstMonth: 1,\n /** The minimum day number.\n @memberof JulianCalendar */\n minDay: 1,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof JulianCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left. */\n regionalOptions: { // Localisations\n '': {\n name: 'Julian',\n epochs: ['BC', 'AD'],\n monthNames: ['January', 'February', 'March', 'April', 'May', 'June',\n 'July', 'August', 'September', 'October', 'November', 'December'],\n monthNamesShort: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n dayNames: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],\n dayNamesShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n dayNamesMin: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],\n digits: null,\n dateFormat: 'mm/dd/yyyy',\n firstDay: 0,\n isRTL: false\n }\n },\n\n /** Determine whether this date is in a leap year.\n @memberof JulianCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n var year = (date.year() < 0 ? date.year() + 1 : date.year()); // No year zero\n return (year % 4) === 0;\n },\n\n /** Determine the week of the year for a date - ISO 8601.\n @memberof JulianCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function(year, month, day) {\n // Find Thursday of this week starting on Monday\n var checkDate = this.newDate(year, month, day);\n checkDate.add(4 - (checkDate.dayOfWeek() || 7), 'd');\n return Math.floor((checkDate.dayOfYear() - 1) / 7) + 1;\n },\n\n /** Retrieve the number of days in a month.\n @memberof JulianCalendar\n @param year {CDate|number} The date to examine or the year of the month.\n @param [month] {number} The month.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function(year, month) {\n var date = this._validate(year, month, this.minDay, main.local.invalidMonth);\n return this.daysPerMonth[date.month() - 1] +\n (date.month() === 2 && this.leapYear(date.year()) ? 1 : 0);\n },\n\n /** Determine whether this date is a week day.\n @memberof JulianCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {boolean} True if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function(year, month, day) {\n return (this.dayOfWeek(year, month, day) || 7) < 6;\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof JulianCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n year = date.year();\n month = date.month();\n day = date.day();\n if (year < 0) { year++; } // No year zero\n // Jean Meeus algorithm, \"Astronomical Algorithms\", 1991\n if (month <= 2) {\n year--;\n month += 12;\n }\n return Math.floor(365.25 * (year + 4716)) +\n Math.floor(30.6001 * (month + 1)) + day - 1524.5;\n },\n\n /** Create a new date from a Julian date.\n @memberof JulianCalendar\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function(jd) {\n // Jean Meeus algorithm, \"Astronomical Algorithms\", 1991\n var a = Math.floor(jd + 0.5);\n var b = a + 1524;\n var c = Math.floor((b - 122.1) / 365.25);\n var d = Math.floor(365.25 * c);\n var e = Math.floor((b - d) / 30.6001);\n var month = e - Math.floor(e < 14 ? 1 : 13);\n var year = c - Math.floor(month > 2 ? 4716 : 4715);\n var day = b - d - Math.floor(30.6001 * e);\n if (year <= 0) { year--; } // No year zero\n return this.newDate(year, month, day);\n }\n});\n\n// Julian calendar implementation\nmain.calendars.julian = JulianCalendar;\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Mayan calendar for jQuery v2.0.2.\n Written by Keith Wood (wood.keith{at}optusnet.com.au) August 2009.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar main = require('../main');\nvar assign = require('object-assign');\n\n\n/** Implementation of the Mayan Long Count calendar.\n See also http://en.wikipedia.org/wiki/Mayan_calendar.\n @class MayanCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction MayanCalendar(language) {\n this.local = this.regionalOptions[language || ''] || this.regionalOptions[''];\n}\n\nMayanCalendar.prototype = new main.baseCalendar;\n\nassign(MayanCalendar.prototype, {\n /** The calendar name.\n @memberof MayanCalendar */\n name: 'Mayan',\n /** Julian date of start of Mayan epoch: 11 August 3114 BCE.\n @memberof MayanCalendar */\n jdEpoch: 584282.5,\n /** true if has a year zero, false if not.\n @memberof MayanCalendar */\n hasYearZero: true,\n /** The minimum month number.\n @memberof MayanCalendar */\n minMonth: 0,\n /** The first month in the year.\n @memberof MayanCalendar */\n firstMonth: 0,\n /** The minimum day number.\n @memberof MayanCalendar */\n minDay: 0,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof MayanCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left.\n @property haabMonths {string[]} The names of the Haab months.\n @property tzolkinMonths {string[]} The names of the Tzolkin months. */\n regionalOptions: { // Localisations\n '': {\n name: 'Mayan',\n epochs: ['', ''],\n monthNames: ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9',\n '10', '11', '12', '13', '14', '15', '16', '17'],\n monthNamesShort: ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9',\n '10', '11', '12', '13', '14', '15', '16', '17'],\n dayNames: ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9',\n '10', '11', '12', '13', '14', '15', '16', '17', '18', '19'],\n dayNamesShort: ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9',\n '10', '11', '12', '13', '14', '15', '16', '17', '18', '19'],\n dayNamesMin: ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9',\n '10', '11', '12', '13', '14', '15', '16', '17', '18', '19'],\n digits: null,\n dateFormat: 'YYYY.m.d',\n firstDay: 0,\n isRTL: false,\n haabMonths: ['Pop', 'Uo', 'Zip', 'Zotz', 'Tzec', 'Xul', 'Yaxkin', 'Mol', 'Chen', 'Yax',\n 'Zac', 'Ceh', 'Mac', 'Kankin', 'Muan', 'Pax', 'Kayab', 'Cumku', 'Uayeb'],\n tzolkinMonths: ['Imix', 'Ik', 'Akbal', 'Kan', 'Chicchan', 'Cimi', 'Manik', 'Lamat', 'Muluc', 'Oc',\n 'Chuen', 'Eb', 'Ben', 'Ix', 'Men', 'Cib', 'Caban', 'Etznab', 'Cauac', 'Ahau']\n }\n },\n\n /** Determine whether this date is in a leap year.\n @memberof MayanCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function(year) {\n this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n return false;\n },\n\n /** Format the year, if not a simple sequential number.\n @memberof MayanCalendar\n @param year {CDate|number} The date to format or the year to format.\n @return {string} The formatted year.\n @throws Error if an invalid year or a different calendar used. */\n formatYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n year = date.year();\n var baktun = Math.floor(year / 400);\n year = year % 400;\n year += (year < 0 ? 400 : 0);\n var katun = Math.floor(year / 20);\n return baktun + '.' + katun + '.' + (year % 20);\n },\n\n /** Convert from the formatted year back to a single number.\n @memberof MayanCalendar\n @param years {string} The year as n.n.n.\n @return {number} The sequential year.\n @throws Error if an invalid value is supplied. */\n forYear: function(years) {\n years = years.split('.');\n if (years.length < 3) {\n throw 'Invalid Mayan year';\n }\n var year = 0;\n for (var i = 0; i < years.length; i++) {\n var y = parseInt(years[i], 10);\n if (Math.abs(y) > 19 || (i > 0 && y < 0)) {\n throw 'Invalid Mayan year';\n }\n year = year * 20 + y;\n }\n return year;\n },\n\n /** Retrieve the number of months in a year.\n @memberof MayanCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The number of months.\n @throws Error if an invalid year or a different calendar used. */\n monthsInYear: function(year) {\n this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n return 18;\n },\n\n /** Determine the week of the year for a date.\n @memberof MayanCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function(year, month, day) {\n this._validate(year, month, day, main.local.invalidDate);\n return 0;\n },\n\n /** Retrieve the number of days in a year.\n @memberof MayanCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The number of days.\n @throws Error if an invalid year or a different calendar used. */\n daysInYear: function(year) {\n this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n return 360;\n },\n\n /** Retrieve the number of days in a month.\n @memberof MayanCalendar\n @param year {CDate|number} The date to examine or the year of the month.\n @param [month] {number} The month.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function(year, month) {\n this._validate(year, month, this.minDay, main.local.invalidMonth);\n return 20;\n },\n\n /** Retrieve the number of days in a week.\n @memberof MayanCalendar\n @return {number} The number of days. */\n daysInWeek: function() {\n return 5; // Just for formatting\n },\n\n /** Retrieve the day of the week for a date.\n @memberof MayanCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The day of the week: 0 to number of days - 1.\n @throws Error if an invalid date or a different calendar used. */\n dayOfWeek: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n return date.day();\n },\n\n /** Determine whether this date is a week day.\n @memberof MayanCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {boolean} true if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function(year, month, day) {\n this._validate(year, month, day, main.local.invalidDate);\n return true;\n },\n\n /** Retrieve additional information about a date - Haab and Tzolkin equivalents.\n @memberof MayanCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {object} Additional information - contents depends on calendar.\n @throws Error if an invalid date or a different calendar used. */\n extraInfo: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n var jd = date.toJD();\n var haab = this._toHaab(jd);\n var tzolkin = this._toTzolkin(jd);\n return {haabMonthName: this.local.haabMonths[haab[0] - 1],\n haabMonth: haab[0], haabDay: haab[1],\n tzolkinDayName: this.local.tzolkinMonths[tzolkin[0] - 1],\n tzolkinDay: tzolkin[0], tzolkinTrecena: tzolkin[1]};\n },\n\n /** Retrieve Haab date from a Julian date.\n @memberof MayanCalendar\n @private\n @param jd {number} The Julian date.\n @return {number[]} Corresponding Haab month and day. */\n _toHaab: function(jd) {\n jd -= this.jdEpoch;\n var day = mod(jd + 8 + ((18 - 1) * 20), 365);\n return [Math.floor(day / 20) + 1, mod(day, 20)];\n },\n\n /** Retrieve Tzolkin date from a Julian date.\n @memberof MayanCalendar\n @private\n @param jd {number} The Julian date.\n @return {number[]} Corresponding Tzolkin day and trecena. */\n _toTzolkin: function(jd) {\n jd -= this.jdEpoch;\n return [amod(jd + 20, 20), amod(jd + 4, 13)];\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof MayanCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n return date.day() + (date.month() * 20) + (date.year() * 360) + this.jdEpoch;\n },\n\n /** Create a new date from a Julian date.\n @memberof MayanCalendar\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function(jd) {\n jd = Math.floor(jd) + 0.5 - this.jdEpoch;\n var year = Math.floor(jd / 360);\n jd = jd % 360;\n jd += (jd < 0 ? 360 : 0);\n var month = Math.floor(jd / 20);\n var day = jd % 20;\n return this.newDate(year, month, day);\n }\n});\n\n// Modulus function which works for non-integers.\nfunction mod(a, b) {\n return a - (b * Math.floor(a / b));\n}\n\n// Modulus function which returns numerator if modulus is zero.\nfunction amod(a, b) {\n return mod(a - 1, b) + 1;\n}\n\n// Mayan calendar implementation\nmain.calendars.mayan = MayanCalendar;\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Nanakshahi calendar for jQuery v2.0.2.\n Written by Keith Wood (wood.keith{at}optusnet.com.au) January 2016.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar main = require('../main');\nvar assign = require('object-assign');\n\n\n/** Implementation of the Nanakshahi calendar.\n See also https://en.wikipedia.org/wiki/Nanakshahi_calendar.\n @class NanakshahiCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction NanakshahiCalendar(language) {\n this.local = this.regionalOptions[language || ''] || this.regionalOptions[''];\n}\n\nNanakshahiCalendar.prototype = new main.baseCalendar;\n\nvar gregorian = main.instance('gregorian');\n\nassign(NanakshahiCalendar.prototype, {\n /** The calendar name.\n @memberof NanakshahiCalendar */\n name: 'Nanakshahi',\n /** Julian date of start of Nanakshahi epoch: 14 March 1469 CE.\n @memberof NanakshahiCalendar */\n jdEpoch: 2257673.5,\n /** Days per month in a common year.\n @memberof NanakshahiCalendar */\n daysPerMonth: [31, 31, 31, 31, 31, 30, 30, 30, 30, 30, 30, 30],\n /** true if has a year zero, false if not.\n @memberof NanakshahiCalendar */\n hasYearZero: false,\n /** The minimum month number.\n @memberof NanakshahiCalendar */\n minMonth: 1,\n /** The first month in the year.\n @memberof NanakshahiCalendar */\n firstMonth: 1,\n /** The minimum day number.\n @memberof NanakshahiCalendar */\n minDay: 1,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof NanakshahiCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left. */\n regionalOptions: { // Localisations\n '': {\n name: 'Nanakshahi',\n epochs: ['BN', 'AN'],\n monthNames: ['Chet', 'Vaisakh', 'Jeth', 'Harh', 'Sawan', 'Bhadon',\n 'Assu', 'Katak', 'Maghar', 'Poh', 'Magh', 'Phagun'],\n monthNamesShort: ['Che', 'Vai', 'Jet', 'Har', 'Saw', 'Bha', 'Ass', 'Kat', 'Mgr', 'Poh', 'Mgh', 'Pha'],\n dayNames: ['Somvaar', 'Mangalvar', 'Budhvaar', 'Veervaar', 'Shukarvaar', 'Sanicharvaar', 'Etvaar'],\n dayNamesShort: ['Som', 'Mangal', 'Budh', 'Veer', 'Shukar', 'Sanichar', 'Et'],\n dayNamesMin: ['So', 'Ma', 'Bu', 'Ve', 'Sh', 'Sa', 'Et'],\n digits: null,\n dateFormat: 'dd-mm-yyyy',\n firstDay: 0,\n isRTL: false\n }\n },\n\n /** Determine whether this date is in a leap year.\n @memberof NanakshahiCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay,\n main.local.invalidYear || main.regionalOptions[''].invalidYear);\n return gregorian.leapYear(date.year() + (date.year() < 1 ? 1 : 0) + 1469);\n },\n\n /** Determine the week of the year for a date.\n @memberof NanakshahiCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function(year, month, day) {\n // Find Monday of this week starting on Monday\n var checkDate = this.newDate(year, month, day);\n checkDate.add(1 - (checkDate.dayOfWeek() || 7), 'd');\n return Math.floor((checkDate.dayOfYear() - 1) / 7) + 1;\n },\n\n /** Retrieve the number of days in a month.\n @memberof NanakshahiCalendar\n @param year {CDate|number} The date to examine or the year of the month.\n @param [month] {number} The month.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function(year, month) {\n var date = this._validate(year, month, this.minDay, main.local.invalidMonth);\n return this.daysPerMonth[date.month() - 1] +\n (date.month() === 12 && this.leapYear(date.year()) ? 1 : 0);\n },\n\n /** Determine whether this date is a week day.\n @memberof NanakshahiCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {boolean} true if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function(year, month, day) {\n return (this.dayOfWeek(year, month, day) || 7) < 6;\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof NanakshahiCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidMonth);\n var year = date.year();\n if (year < 0) { year++; } // No year zero\n var doy = date.day();\n for (var m = 1; m < date.month(); m++) {\n doy += this.daysPerMonth[m - 1];\n }\n return doy + gregorian.toJD(year + 1468, 3, 13);\n },\n\n /** Create a new date from a Julian date.\n @memberof NanakshahiCalendar\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function(jd) {\n jd = Math.floor(jd + 0.5);\n var year = Math.floor((jd - (this.jdEpoch - 1)) / 366);\n while (jd >= this.toJD(year + 1, 1, 1)) {\n year++;\n }\n var day = jd - Math.floor(this.toJD(year, 1, 1) + 0.5) + 1;\n var month = 1;\n while (day > this.daysInMonth(year, month)) {\n day -= this.daysInMonth(year, month);\n month++;\n }\n return this.newDate(year, month, day);\n }\n});\n\n// Nanakshahi calendar implementation\nmain.calendars.nanakshahi = NanakshahiCalendar;\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Nepali calendar for jQuery v2.0.2.\n Written by Artur Neumann (ict.projects{at}nepal.inf.org) April 2013.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar main = require('../main');\nvar assign = require('object-assign');\n\n\n/** Implementation of the Nepali civil calendar.\n Based on the ideas from \n http://codeissue.com/articles/a04e050dea7468f/algorithm-to-convert-english-date-to-nepali-date-using-c-net\n and http://birenj2ee.blogspot.com/2011/04/nepali-calendar-in-java.html\n See also http://en.wikipedia.org/wiki/Nepali_calendar\n and https://en.wikipedia.org/wiki/Bikram_Samwat.\n @class NepaliCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction NepaliCalendar(language) {\n this.local = this.regionalOptions[language || ''] || this.regionalOptions[''];\n}\n\nNepaliCalendar.prototype = new main.baseCalendar;\n\nassign(NepaliCalendar.prototype, {\n /** The calendar name.\n @memberof NepaliCalendar */\n name: 'Nepali',\n /** Julian date of start of Nepali epoch: 14 April 57 BCE.\n @memberof NepaliCalendar */\n jdEpoch: 1700709.5,\n /** Days per month in a common year.\n @memberof NepaliCalendar */\n daysPerMonth: [31, 31, 32, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n /** true if has a year zero, false if not.\n @memberof NepaliCalendar */\n hasYearZero: false,\n /** The minimum month number.\n @memberof NepaliCalendar */\n minMonth: 1,\n /** The first month in the year.\n @memberof NepaliCalendar */\n firstMonth: 1,\n /** The minimum day number.\n @memberof NepaliCalendar */\n minDay: 1, \n /** The number of days in the year.\n @memberof NepaliCalendar */\n daysPerYear: 365,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof NepaliCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left. */\n regionalOptions: { // Localisations\n '': {\n name: 'Nepali',\n epochs: ['BBS', 'ABS'],\n monthNames: ['Baisakh', 'Jestha', 'Ashadh', 'Shrawan', 'Bhadra', 'Ashwin',\n 'Kartik', 'Mangsir', 'Paush', 'Mangh', 'Falgun', 'Chaitra'],\n monthNamesShort: ['Bai', 'Je', 'As', 'Shra', 'Bha', 'Ash', 'Kar', 'Mang', 'Pau', 'Ma', 'Fal', 'Chai'],\n dayNames: ['Aaitabaar', 'Sombaar', 'Manglbaar', 'Budhabaar', 'Bihibaar', 'Shukrabaar', 'Shanibaar'],\n dayNamesShort: ['Aaita', 'Som', 'Mangl', 'Budha', 'Bihi', 'Shukra', 'Shani'],\n dayNamesMin: ['Aai', 'So', 'Man', 'Bu', 'Bi', 'Shu', 'Sha'],\n digits: null,\n dateFormat: 'dd/mm/yyyy',\n firstDay: 1,\n isRTL: false\n }\n },\n\n /** Determine whether this date is in a leap year.\n @memberof NepaliCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function(year) {\n return this.daysInYear(year) !== this.daysPerYear;\n },\n\n /** Determine the week of the year for a date.\n @memberof NepaliCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function(year, month, day) {\n // Find Sunday of this week starting on Sunday\n var checkDate = this.newDate(year, month, day);\n checkDate.add(-checkDate.dayOfWeek(), 'd');\n return Math.floor((checkDate.dayOfYear() - 1) / 7) + 1;\n },\n\n /** Retrieve the number of days in a year.\n @memberof NepaliCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The number of days.\n @throws Error if an invalid year or a different calendar used. */\n daysInYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n year = date.year();\n if (typeof this.NEPALI_CALENDAR_DATA[year] === 'undefined') {\n return this.daysPerYear;\n }\n var daysPerYear = 0;\n for (var month_number = this.minMonth; month_number <= 12; month_number++) {\n daysPerYear += this.NEPALI_CALENDAR_DATA[year][month_number];\n }\n return daysPerYear;\n },\n\n /** Retrieve the number of days in a month.\n @memberof NepaliCalendar\n @param year {CDate|number| The date to examine or the year of the month.\n @param [month] {number} The month.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function(year, month) {\n if (year.year) {\n month = year.month();\n year = year.year();\n }\n this._validate(year, month, this.minDay, main.local.invalidMonth);\n return (typeof this.NEPALI_CALENDAR_DATA[year] === 'undefined' ?\n this.daysPerMonth[month - 1] : this.NEPALI_CALENDAR_DATA[year][month]);\n },\n\n /** Determine whether this date is a week day.\n @memberof NepaliCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {boolean} true if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function(year, month, day) {\n return this.dayOfWeek(year, month, day) !== 6;\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof NepaliCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function(nepaliYear, nepaliMonth, nepaliDay) {\n var date = this._validate(nepaliYear, nepaliMonth, nepaliDay, main.local.invalidDate);\n nepaliYear = date.year();\n nepaliMonth = date.month();\n nepaliDay = date.day();\n var gregorianCalendar = main.instance();\n var gregorianDayOfYear = 0; // We will add all the days that went by since\n // the 1st. January and then we can get the Gregorian Date\n var nepaliMonthToCheck = nepaliMonth;\n var nepaliYearToCheck = nepaliYear;\n this._createMissingCalendarData(nepaliYear);\n // Get the correct year\n var gregorianYear = nepaliYear - (nepaliMonthToCheck > 9 || (nepaliMonthToCheck === 9 &&\n nepaliDay >= this.NEPALI_CALENDAR_DATA[nepaliYearToCheck][0]) ? 56 : 57);\n // First we add the amount of days in the actual Nepali month as the day of year in the\n // Gregorian one because at least this days are gone since the 1st. Jan. \n if (nepaliMonth !== 9) {\n gregorianDayOfYear = nepaliDay;\n nepaliMonthToCheck--;\n }\n // Now we loop throw all Nepali month and add the amount of days to gregorianDayOfYear \n // we do this till we reach Paush (9th month). 1st. January always falls in this month \n while (nepaliMonthToCheck !== 9) {\n if (nepaliMonthToCheck <= 0) {\n nepaliMonthToCheck = 12;\n nepaliYearToCheck--;\n } \n gregorianDayOfYear += this.NEPALI_CALENDAR_DATA[nepaliYearToCheck][nepaliMonthToCheck];\n nepaliMonthToCheck--;\n } \n // If the date that has to be converted is in Paush (month no. 9) we have to do some other calculation\n if (nepaliMonth === 9) {\n // Add the days that are passed since the first day of Paush and substract the\n // amount of days that lie between 1st. Jan and 1st Paush\n gregorianDayOfYear += nepaliDay - this.NEPALI_CALENDAR_DATA[nepaliYearToCheck][0];\n // For the first days of Paush we are now in negative values,\n // because in the end of the gregorian year we substract\n // 365 / 366 days (P.S. remember math in school + - gives -)\n if (gregorianDayOfYear < 0) {\n gregorianDayOfYear += gregorianCalendar.daysInYear(gregorianYear);\n }\n }\n else {\n gregorianDayOfYear += this.NEPALI_CALENDAR_DATA[nepaliYearToCheck][9] -\n this.NEPALI_CALENDAR_DATA[nepaliYearToCheck][0];\n } \n return gregorianCalendar.newDate(gregorianYear, 1 ,1).add(gregorianDayOfYear, 'd').toJD();\n },\n \n /** Create a new date from a Julian date.\n @memberof NepaliCalendar\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function(jd) {\n var gregorianCalendar = main.instance();\n var gregorianDate = gregorianCalendar.fromJD(jd);\n var gregorianYear = gregorianDate.year();\n var gregorianDayOfYear = gregorianDate.dayOfYear();\n var nepaliYear = gregorianYear + 56; //this is not final, it could be also +57 but +56 is always true for 1st Jan.\n this._createMissingCalendarData(nepaliYear);\n var nepaliMonth = 9; // Jan 1 always fall in Nepali month Paush which is the 9th month of Nepali calendar.\n // Get the Nepali day in Paush (month 9) of 1st January \n var dayOfFirstJanInPaush = this.NEPALI_CALENDAR_DATA[nepaliYear][0];\n // Check how many days are left of Paush .\n // Days calculated from 1st Jan till the end of the actual Nepali month, \n // we use this value to check if the gregorian Date is in the actual Nepali month.\n var daysSinceJanFirstToEndOfNepaliMonth =\n this.NEPALI_CALENDAR_DATA[nepaliYear][nepaliMonth] - dayOfFirstJanInPaush + 1;\n // If the gregorian day-of-year is smaller o equal than the sum of days between the 1st January and \n // the end of the actual nepali month we found the correct nepali month.\n // Example: \n // The 4th February 2011 is the gregorianDayOfYear 35 (31 days of January + 4)\n // 1st January 2011 is in the nepali year 2067, where 1st. January is in the 17th day of Paush (9th month)\n // In 2067 Paush has 30days, This means (30-17+1=14) there are 14days between 1st January and end of Paush \n // (including 17th January)\n // The gregorianDayOfYear (35) is bigger than 14, so we check the next month\n // The next nepali month (Mangh) has 29 days \n // 29+14=43, this is bigger than gregorianDayOfYear(35) so, we found the correct nepali month\n while (gregorianDayOfYear > daysSinceJanFirstToEndOfNepaliMonth) {\n nepaliMonth++;\n if (nepaliMonth > 12) {\n nepaliMonth = 1;\n nepaliYear++;\n } \n daysSinceJanFirstToEndOfNepaliMonth += this.NEPALI_CALENDAR_DATA[nepaliYear][nepaliMonth];\n }\n // The last step is to calculate the nepali day-of-month\n // to continue our example from before:\n // we calculated there are 43 days from 1st. January (17 Paush) till end of Mangh (29 days)\n // when we subtract from this 43 days the day-of-year of the the Gregorian date (35),\n // we know how far the searched day is away from the end of the Nepali month.\n // So we simply subtract this number from the amount of days in this month (30) \n var nepaliDayOfMonth = this.NEPALI_CALENDAR_DATA[nepaliYear][nepaliMonth] -\n (daysSinceJanFirstToEndOfNepaliMonth - gregorianDayOfYear); \n return this.newDate(nepaliYear, nepaliMonth, nepaliDayOfMonth);\n },\n \n /** Creates missing data in the NEPALI_CALENDAR_DATA table.\n This data will not be correct but just give an estimated result. Mostly -/+ 1 day\n @private\n @param nepaliYear {number} The missing year number. */\n _createMissingCalendarData: function(nepaliYear) {\n var tmp_calendar_data = this.daysPerMonth.slice(0);\n tmp_calendar_data.unshift(17);\n for (var nepaliYearToCreate = (nepaliYear - 1); nepaliYearToCreate < (nepaliYear + 2); nepaliYearToCreate++) {\n if (typeof this.NEPALI_CALENDAR_DATA[nepaliYearToCreate] === 'undefined') {\n this.NEPALI_CALENDAR_DATA[nepaliYearToCreate] = tmp_calendar_data;\n }\n }\n },\n \n NEPALI_CALENDAR_DATA: {\n // These data are from http://www.ashesh.com.np\n 1970: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 1971: [18, 31, 31, 32, 31, 32, 30, 30, 29, 30, 29, 30, 30],\n 1972: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 30],\n 1973: [19, 30, 32, 31, 32, 31, 30, 30, 30, 29, 30, 29, 31],\n 1974: [19, 31, 31, 32, 30, 31, 31, 30, 29, 30, 29, 30, 30],\n 1975: [18, 31, 31, 32, 32, 30, 31, 30, 29, 30, 29, 30, 30],\n 1976: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 1977: [18, 31, 32, 31, 32, 31, 31, 29, 30, 29, 30, 29, 31],\n 1978: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 1979: [18, 31, 31, 32, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 1980: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 1981: [18, 31, 31, 31, 32, 31, 31, 29, 30, 30, 29, 30, 30],\n 1982: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 1983: [18, 31, 31, 32, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 1984: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 1985: [18, 31, 31, 31, 32, 31, 31, 29, 30, 30, 29, 30, 30],\n 1986: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 1987: [18, 31, 32, 31, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 1988: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 1989: [18, 31, 31, 31, 32, 31, 31, 30, 29, 30, 29, 30, 30],\n 1990: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 1991: [18, 31, 32, 31, 32, 31, 30, 30, 29, 30, 29, 30, 30], \n // These data are from http://nepalicalendar.rat32.com/index.php\n 1992: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 30, 29, 31],\n 1993: [18, 31, 31, 31, 32, 31, 31, 30, 29, 30, 29, 30, 30],\n 1994: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 1995: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 30],\n 1996: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 30, 29, 31],\n 1997: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 1998: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 1999: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2000: [17, 30, 32, 31, 32, 31, 30, 30, 30, 29, 30, 29, 31],\n 2001: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2002: [18, 31, 31, 32, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 2003: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2004: [17, 30, 32, 31, 32, 31, 30, 30, 30, 29, 30, 29, 31],\n 2005: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2006: [18, 31, 31, 32, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 2007: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2008: [17, 31, 31, 31, 32, 31, 31, 29, 30, 30, 29, 29, 31],\n 2009: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2010: [18, 31, 31, 32, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 2011: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2012: [17, 31, 31, 31, 32, 31, 31, 29, 30, 30, 29, 30, 30],\n 2013: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2014: [18, 31, 31, 32, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 2015: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2016: [17, 31, 31, 31, 32, 31, 31, 29, 30, 30, 29, 30, 30],\n 2017: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2018: [18, 31, 32, 31, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 2019: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 30, 29, 31],\n 2020: [17, 31, 31, 31, 32, 31, 31, 30, 29, 30, 29, 30, 30],\n 2021: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2022: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 30],\n 2023: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 30, 29, 31],\n 2024: [17, 31, 31, 31, 32, 31, 31, 30, 29, 30, 29, 30, 30],\n 2025: [18, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2026: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2027: [17, 30, 32, 31, 32, 31, 30, 30, 30, 29, 30, 29, 31],\n 2028: [17, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2029: [18, 31, 31, 32, 31, 32, 30, 30, 29, 30, 29, 30, 30],\n 2030: [17, 31, 32, 31, 32, 31, 30, 30, 30, 30, 30, 30, 31],\n 2031: [17, 31, 32, 31, 32, 31, 31, 31, 31, 31, 31, 31, 31],\n 2032: [17, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32],\n 2033: [18, 31, 31, 32, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 2034: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2035: [17, 30, 32, 31, 32, 31, 31, 29, 30, 30, 29, 29, 31],\n 2036: [17, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2037: [18, 31, 31, 32, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 2038: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2039: [17, 31, 31, 31, 32, 31, 31, 29, 30, 30, 29, 30, 30],\n 2040: [17, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2041: [18, 31, 31, 32, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 2042: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2043: [17, 31, 31, 31, 32, 31, 31, 29, 30, 30, 29, 30, 30],\n 2044: [17, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2045: [18, 31, 32, 31, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 2046: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2047: [17, 31, 31, 31, 32, 31, 31, 30, 29, 30, 29, 30, 30],\n 2048: [17, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2049: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 30],\n 2050: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 30, 29, 31],\n 2051: [17, 31, 31, 31, 32, 31, 31, 30, 29, 30, 29, 30, 30],\n 2052: [17, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2053: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 30],\n 2054: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 30, 29, 31],\n 2055: [17, 31, 31, 32, 31, 31, 31, 30, 29, 30, 30, 29, 30],\n 2056: [17, 31, 31, 32, 31, 32, 30, 30, 29, 30, 29, 30, 30],\n 2057: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2058: [17, 30, 32, 31, 32, 31, 30, 30, 30, 29, 30, 29, 31],\n 2059: [17, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2060: [17, 31, 31, 32, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 2061: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2062: [17, 30, 32, 31, 32, 31, 31, 29, 30, 29, 30, 29, 31],\n 2063: [17, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2064: [17, 31, 31, 32, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 2065: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2066: [17, 31, 31, 31, 32, 31, 31, 29, 30, 30, 29, 29, 31],\n 2067: [17, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2068: [17, 31, 31, 32, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 2069: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2070: [17, 31, 31, 31, 32, 31, 31, 29, 30, 30, 29, 30, 30],\n 2071: [17, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2072: [17, 31, 32, 31, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 2073: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 31],\n 2074: [17, 31, 31, 31, 32, 31, 31, 30, 29, 30, 29, 30, 30],\n 2075: [17, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2076: [16, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 30],\n 2077: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 30, 29, 31],\n 2078: [17, 31, 31, 31, 32, 31, 31, 30, 29, 30, 29, 30, 30],\n 2079: [17, 31, 31, 32, 31, 31, 31, 30, 29, 30, 29, 30, 30],\n 2080: [16, 31, 32, 31, 32, 31, 30, 30, 30, 29, 29, 30, 30],\n // These data are from http://www.ashesh.com.np/nepali-calendar/\n 2081: [17, 31, 31, 32, 32, 31, 30, 30, 30, 29, 30, 30, 30],\n 2082: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 30, 30, 30],\n 2083: [17, 31, 31, 32, 31, 31, 30, 30, 30, 29, 30, 30, 30],\n 2084: [17, 31, 31, 32, 31, 31, 30, 30, 30, 29, 30, 30, 30],\n 2085: [17, 31, 32, 31, 32, 31, 31, 30, 30, 29, 30, 30, 30],\n 2086: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 30, 30, 30],\n 2087: [16, 31, 31, 32, 31, 31, 31, 30, 30, 29, 30, 30, 30],\n 2088: [16, 30, 31, 32, 32, 30, 31, 30, 30, 29, 30, 30, 30],\n 2089: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 30, 30, 30],\n 2090: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 30, 30, 30],\n 2091: [16, 31, 31, 32, 31, 31, 31, 30, 30, 29, 30, 30, 30],\n 2092: [16, 31, 31, 32, 32, 31, 30, 30, 30, 29, 30, 30, 30],\n 2093: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 30, 30, 30],\n 2094: [17, 31, 31, 32, 31, 31, 30, 30, 30, 29, 30, 30, 30],\n 2095: [17, 31, 31, 32, 31, 31, 31, 30, 29, 30, 30, 30, 30],\n 2096: [17, 30, 31, 32, 32, 31, 30, 30, 29, 30, 29, 30, 30],\n 2097: [17, 31, 32, 31, 32, 31, 30, 30, 30, 29, 30, 30, 30],\n 2098: [17, 31, 31, 32, 31, 31, 31, 29, 30, 29, 30, 30, 31],\n 2099: [17, 31, 31, 32, 31, 31, 31, 30, 29, 29, 30, 30, 30],\n 2100: [17, 31, 32, 31, 32, 30, 31, 30, 29, 30, 29, 30, 30] \n }\n}); \n\n// Nepali calendar implementation\nmain.calendars.nepali = NepaliCalendar;\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Persian calendar for jQuery v2.0.2.\n Written by Keith Wood (wood.keith{at}optusnet.com.au) August 2009.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar main = require('../main');\nvar assign = require('object-assign');\n\n\n/** Implementation of the Persian or Jalali calendar.\n Based on code from http://www.iranchamber.com/calendar/converter/iranian_calendar_converter.php.\n See also http://en.wikipedia.org/wiki/Iranian_calendar.\n @class PersianCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction PersianCalendar(language) {\n this.local = this.regionalOptions[language || ''] || this.regionalOptions[''];\n}\n\nPersianCalendar.prototype = new main.baseCalendar;\n\nassign(PersianCalendar.prototype, {\n /** The calendar name.\n @memberof PersianCalendar */\n name: 'Persian',\n /** Julian date of start of Persian epoch: 19 March 622 CE.\n @memberof PersianCalendar */\n jdEpoch: 1948320.5,\n /** Days per month in a common year.\n @memberof PersianCalendar */\n daysPerMonth: [31, 31, 31, 31, 31, 31, 30, 30, 30, 30, 30, 29],\n /** true if has a year zero, false if not.\n @memberof PersianCalendar */\n hasYearZero: false,\n /** The minimum month number.\n @memberof PersianCalendar */\n minMonth: 1,\n /** The first month in the year.\n @memberof PersianCalendar */\n firstMonth: 1,\n /** The minimum day number.\n @memberof PersianCalendar */\n minDay: 1,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof PersianCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left. */\n regionalOptions: { // Localisations\n '': {\n name: 'Persian',\n epochs: ['BP', 'AP'],\n monthNames: ['Farvardin', 'Ordibehesht', 'Khordad', 'Tir', 'Mordad', 'Shahrivar',\n 'Mehr', 'Aban', 'Azar', 'Day', 'Bahman', 'Esfand'],\n monthNamesShort: ['Far', 'Ord', 'Kho', 'Tir', 'Mor', 'Sha', 'Meh', 'Aba', 'Aza', 'Day', 'Bah', 'Esf'],\n dayNames: ['Yekshambe', 'Doshambe', 'Seshambe', 'Chæharshambe', 'Panjshambe', 'Jom\\'e', 'Shambe'],\n dayNamesShort: ['Yek', 'Do', 'Se', 'Chæ', 'Panj', 'Jom', 'Sha'],\n dayNamesMin: ['Ye','Do','Se','Ch','Pa','Jo','Sh'],\n digits: null,\n dateFormat: 'yyyy/mm/dd',\n firstDay: 6,\n isRTL: false\n }\n },\n\n /** Determine whether this date is in a leap year.\n @memberof PersianCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n return (((((date.year() - (date.year() > 0 ? 474 : 473)) % 2820) +\n 474 + 38) * 682) % 2816) < 682;\n },\n\n /** Determine the week of the year for a date.\n @memberof PersianCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function(year, month, day) {\n // Find Saturday of this week starting on Saturday\n var checkDate = this.newDate(year, month, day);\n checkDate.add(-((checkDate.dayOfWeek() + 1) % 7), 'd');\n return Math.floor((checkDate.dayOfYear() - 1) / 7) + 1;\n },\n\n /** Retrieve the number of days in a month.\n @memberof PersianCalendar\n @param year {CDate|number} The date to examine or the year of the month.\n @param [month] {number} The month.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function(year, month) {\n var date = this._validate(year, month, this.minDay, main.local.invalidMonth);\n return this.daysPerMonth[date.month() - 1] +\n (date.month() === 12 && this.leapYear(date.year()) ? 1 : 0);\n },\n\n /** Determine whether this date is a week day.\n @memberof PersianCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {boolean} true if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function(year, month, day) {\n return this.dayOfWeek(year, month, day) !== 5;\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof PersianCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n year = date.year();\n month = date.month();\n day = date.day();\n var epBase = year - (year >= 0 ? 474 : 473);\n var epYear = 474 + mod(epBase, 2820);\n return day + (month <= 7 ? (month - 1) * 31 : (month - 1) * 30 + 6) +\n Math.floor((epYear * 682 - 110) / 2816) + (epYear - 1) * 365 +\n Math.floor(epBase / 2820) * 1029983 + this.jdEpoch - 1;\n },\n\n /** Create a new date from a Julian date.\n @memberof PersianCalendar\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function(jd) {\n jd = Math.floor(jd) + 0.5;\n var depoch = jd - this.toJD(475, 1, 1);\n var cycle = Math.floor(depoch / 1029983);\n var cyear = mod(depoch, 1029983);\n var ycycle = 2820;\n if (cyear !== 1029982) {\n var aux1 = Math.floor(cyear / 366);\n var aux2 = mod(cyear, 366);\n ycycle = Math.floor(((2134 * aux1) + (2816 * aux2) + 2815) / 1028522) + aux1 + 1;\n }\n var year = ycycle + (2820 * cycle) + 474;\n year = (year <= 0 ? year - 1 : year);\n var yday = jd - this.toJD(year, 1, 1) + 1;\n var month = (yday <= 186 ? Math.ceil(yday / 31) : Math.ceil((yday - 6) / 30));\n var day = jd - this.toJD(year, month, 1) + 1;\n return this.newDate(year, month, day);\n }\n});\n\n// Modulus function which works for non-integers.\nfunction mod(a, b) {\n return a - (b * Math.floor(a / b));\n}\n\n// Persian (Jalali) calendar implementation\nmain.calendars.persian = PersianCalendar;\nmain.calendars.jalali = PersianCalendar;\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Taiwanese (Minguo) calendar for jQuery v2.0.2.\n Written by Keith Wood (wood.keith{at}optusnet.com.au) February 2010.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar main = require('../main');\nvar assign = require('object-assign');\n\n\nvar gregorianCalendar = main.instance();\n\n/** Implementation of the Taiwanese calendar.\n See http://en.wikipedia.org/wiki/Minguo_calendar.\n @class TaiwanCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction TaiwanCalendar(language) {\n this.local = this.regionalOptions[language || ''] || this.regionalOptions[''];\n}\n\nTaiwanCalendar.prototype = new main.baseCalendar;\n\nassign(TaiwanCalendar.prototype, {\n /** The calendar name.\n @memberof TaiwanCalendar */\n name: 'Taiwan',\n /** Julian date of start of Taiwan epoch: 1 January 1912 CE (Gregorian).\n @memberof TaiwanCalendar */\n jdEpoch: 2419402.5,\n /** Difference in years between Taiwan and Gregorian calendars.\n @memberof TaiwanCalendar */\n yearsOffset: 1911,\n /** Days per month in a common year.\n @memberof TaiwanCalendar */\n daysPerMonth: [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31],\n /** true if has a year zero, false if not.\n @memberof TaiwanCalendar */\n hasYearZero: false,\n /** The minimum month number.\n @memberof TaiwanCalendar */\n minMonth: 1,\n /** The first month in the year.\n @memberof TaiwanCalendar */\n firstMonth: 1,\n /** The minimum day number.\n @memberof TaiwanCalendar */\n minDay: 1,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof TaiwanCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left. */\n regionalOptions: { // Localisations\n '': {\n name: 'Taiwan',\n epochs: ['BROC', 'ROC'],\n monthNames: ['January', 'February', 'March', 'April', 'May', 'June',\n 'July', 'August', 'September', 'October', 'November', 'December'],\n monthNamesShort: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n dayNames: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],\n dayNamesShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n dayNamesMin: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],\n digits: null,\n dateFormat: 'yyyy/mm/dd',\n firstDay: 1,\n isRTL: false\n }\n },\n\n /** Determine whether this date is in a leap year.\n @memberof TaiwanCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n var year = this._t2gYear(date.year());\n return gregorianCalendar.leapYear(year);\n },\n\n /** Determine the week of the year for a date - ISO 8601.\n @memberof TaiwanCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function(year, month, day) {\n var date = this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n var year = this._t2gYear(date.year());\n return gregorianCalendar.weekOfYear(year, date.month(), date.day());\n },\n\n /** Retrieve the number of days in a month.\n @memberof TaiwanCalendar\n @param year {CDate|number} The date to examine or the year of the month.\n @param [month] {number} The month.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function(year, month) {\n var date = this._validate(year, month, this.minDay, main.local.invalidMonth);\n return this.daysPerMonth[date.month() - 1] +\n (date.month() === 2 && this.leapYear(date.year()) ? 1 : 0);\n },\n\n /** Determine whether this date is a week day.\n @memberof TaiwanCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {boolean} true if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function(year, month, day) {\n return (this.dayOfWeek(year, month, day) || 7) < 6;\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof TaiwanCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n var year = this._t2gYear(date.year());\n return gregorianCalendar.toJD(year, date.month(), date.day());\n },\n\n /** Create a new date from a Julian date.\n @memberof TaiwanCalendar\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function(jd) {\n var date = gregorianCalendar.fromJD(jd);\n var year = this._g2tYear(date.year());\n return this.newDate(year, date.month(), date.day());\n },\n\n /** Convert Taiwanese to Gregorian year.\n @memberof TaiwanCalendar\n @private\n @param year {number} The Taiwanese year.\n @return {number} The corresponding Gregorian year. */\n _t2gYear: function(year) {\n return year + this.yearsOffset + (year >= -this.yearsOffset && year <= -1 ? 1 : 0);\n },\n\n /** Convert Gregorian to Taiwanese year.\n @memberof TaiwanCalendar\n @private\n @param year {number} The Gregorian year.\n @return {number} The corresponding Taiwanese year. */\n _g2tYear: function(year) {\n return year - this.yearsOffset - (year >= 1 && year <= this.yearsOffset ? 1 : 0);\n }\n});\n\n// Taiwan calendar implementation\nmain.calendars.taiwan = TaiwanCalendar;\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Thai calendar for jQuery v2.0.2.\n Written by Keith Wood (wood.keith{at}optusnet.com.au) February 2010.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar main = require('../main');\nvar assign = require('object-assign');\n\n\nvar gregorianCalendar = main.instance();\n\n/** Implementation of the Thai calendar.\n See http://en.wikipedia.org/wiki/Thai_calendar.\n @class ThaiCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction ThaiCalendar(language) {\n this.local = this.regionalOptions[language || ''] || this.regionalOptions[''];\n}\n\nThaiCalendar.prototype = new main.baseCalendar;\n\nassign(ThaiCalendar.prototype, {\n /** The calendar name.\n @memberof ThaiCalendar */\n name: 'Thai',\n /** Julian date of start of Thai epoch: 1 January 543 BCE (Gregorian).\n @memberof ThaiCalendar */\n jdEpoch: 1523098.5,\n /** Difference in years between Thai and Gregorian calendars.\n @memberof ThaiCalendar */\n yearsOffset: 543, \n /** Days per month in a common year.\n @memberof ThaiCalendar */\n daysPerMonth: [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31],\n /** true if has a year zero, false if not.\n @memberof ThaiCalendar */\n hasYearZero: false,\n /** The minimum month number.\n @memberof ThaiCalendar */\n minMonth: 1,\n /** The first month in the year.\n @memberof ThaiCalendar */\n firstMonth: 1,\n /** The minimum day number.\n @memberof ThaiCalendar */\n minDay: 1,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof ThaiCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left. */\n regionalOptions: { // Localisations\n '': {\n name: 'Thai',\n epochs: ['BBE', 'BE'],\n monthNames: ['January', 'February', 'March', 'April', 'May', 'June',\n 'July', 'August', 'September', 'October', 'November', 'December'],\n monthNamesShort: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n dayNames: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],\n dayNamesShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n dayNamesMin: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],\n digits: null,\n dateFormat: 'dd/mm/yyyy',\n firstDay: 0,\n isRTL: false\n }\n },\n\n /** Determine whether this date is in a leap year.\n @memberof ThaiCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n var year = this._t2gYear(date.year());\n return gregorianCalendar.leapYear(year);\n },\n\n /** Determine the week of the year for a date - ISO 8601.\n @memberof ThaiCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function(year, month, day) {\n var date = this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n var year = this._t2gYear(date.year());\n return gregorianCalendar.weekOfYear(year, date.month(), date.day());\n },\n\n /** Retrieve the number of days in a month.\n @memberof ThaiCalendar\n @param year {CDate|number} The date to examine or the year of the month.\n @param [month] {number} The month.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function(year, month) {\n var date = this._validate(year, month, this.minDay, main.local.invalidMonth);\n return this.daysPerMonth[date.month() - 1] +\n (date.month() === 2 && this.leapYear(date.year()) ? 1 : 0);\n },\n\n /** Determine whether this date is a week day.\n @memberof ThaiCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {boolean} true if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function(year, month, day) {\n return (this.dayOfWeek(year, month, day) || 7) < 6;\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof ThaiCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function(year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n var year = this._t2gYear(date.year());\n return gregorianCalendar.toJD(year, date.month(), date.day());\n },\n\n /** Create a new date from a Julian date.\n @memberof ThaiCalendar\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function(jd) {\n var date = gregorianCalendar.fromJD(jd);\n var year = this._g2tYear(date.year());\n return this.newDate(year, date.month(), date.day());\n },\n\n /** Convert Thai to Gregorian year.\n @memberof ThaiCalendar\n @private\n @param year {number} The Thai year.\n @return {number} The corresponding Gregorian year. */\n _t2gYear: function(year) {\n return year - this.yearsOffset - (year >= 1 && year <= this.yearsOffset ? 1 : 0);\n },\n\n /** Convert Gregorian to Thai year.\n @memberof ThaiCalendar\n @private\n @param year {number} The Gregorian year.\n @return {number} The corresponding Thai year. */\n _g2tYear: function(year) {\n return year + this.yearsOffset + (year >= -this.yearsOffset && year <= -1 ? 1 : 0);\n }\n});\n\n// Thai calendar implementation\nmain.calendars.thai = ThaiCalendar;\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n UmmAlQura calendar for jQuery v2.0.2.\n Written by Amro Osama March 2013.\n Modified by Binnooh.com & www.elm.sa - 2014 - Added dates back to 1276 Hijri year.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar main = require('../main');\nvar assign = require('object-assign');\n\n\n/** Implementation of the UmmAlQura or 'saudi' calendar.\n See also http://en.wikipedia.org/wiki/Islamic_calendar#Saudi_Arabia.27s_Umm_al-Qura_calendar.\n http://www.ummulqura.org.sa/About.aspx\n http://www.staff.science.uu.nl/~gent0113/islam/ummalqura.htm\n @class UmmAlQuraCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction UmmAlQuraCalendar(language) {\n this.local = this.regionalOptions[language || ''] || this.regionalOptions[''];\n}\n\nUmmAlQuraCalendar.prototype = new main.baseCalendar;\n\nassign(UmmAlQuraCalendar.prototype, {\n /** The calendar name.\n @memberof UmmAlQuraCalendar */\n name: 'UmmAlQura',\n //jdEpoch: 1948440, // Julian date of start of UmmAlQura epoch: 14 March 1937 CE\n //daysPerMonth: // Days per month in a common year, replaced by a method.\n /** true if has a year zero, false if not.\n @memberof UmmAlQuraCalendar */\n hasYearZero: false,\n /** The minimum month number.\n @memberof UmmAlQuraCalendar */\n minMonth: 1,\n /** The first month in the year.\n @memberof UmmAlQuraCalendar */\n firstMonth: 1,\n /** The minimum day number.\n @memberof UmmAlQuraCalendar */\n minDay: 1,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof UmmAlQuraCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left. */\n regionalOptions: { // Localisations\n '': {\n name: 'Umm al-Qura',\n epochs: ['BH', 'AH'],\n monthNames: ['Al-Muharram', 'Safar', 'Rabi\\' al-awwal', 'Rabi\\' Al-Thani', 'Jumada Al-Awwal', 'Jumada Al-Thani',\n 'Rajab', 'Sha\\'aban', 'Ramadan', 'Shawwal', 'Dhu al-Qi\\'dah', 'Dhu al-Hijjah'],\n monthNamesShort: ['Muh', 'Saf', 'Rab1', 'Rab2', 'Jum1', 'Jum2', 'Raj', 'Sha\\'', 'Ram', 'Shaw', 'DhuQ', 'DhuH'],\n dayNames: ['Yawm al-Ahad', 'Yawm al-Ithnain', 'Yawm al-Thalāthā’', 'Yawm al-Arba‘ā’', 'Yawm al-Khamīs', 'Yawm al-Jum‘a', 'Yawm al-Sabt'],\n dayNamesMin: ['Ah', 'Ith', 'Th', 'Ar', 'Kh', 'Ju', 'Sa'],\n digits: null,\n dateFormat: 'yyyy/mm/dd',\n firstDay: 6,\n isRTL: true\n }\n },\n\n /** Determine whether this date is in a leap year.\n @memberof UmmAlQuraCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function (year) {\n var date = this._validate(year, this.minMonth, this.minDay, main.local.invalidYear);\n return (this.daysInYear(date.year()) === 355);\n },\n\n /** Determine the week of the year for a date.\n @memberof UmmAlQuraCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function (year, month, day) {\n // Find Sunday of this week starting on Sunday\n var checkDate = this.newDate(year, month, day);\n checkDate.add(-checkDate.dayOfWeek(), 'd');\n return Math.floor((checkDate.dayOfYear() - 1) / 7) + 1;\n },\n\n /** Retrieve the number of days in a year.\n @memberof UmmAlQuraCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The number of days.\n @throws Error if an invalid year or a different calendar used. */\n daysInYear: function (year) {\n var daysCount = 0;\n for (var i = 1; i <= 12; i++) {\n daysCount += this.daysInMonth(year, i);\n }\n return daysCount;\n },\n\n /** Retrieve the number of days in a month.\n @memberof UmmAlQuraCalendar\n @param year {CDate|number} The date to examine or the year of the month.\n @param [month] {number} The month.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function (year, month) {\n var date = this._validate(year, month, this.minDay, main.local.invalidMonth);\n var mcjdn = date.toJD() - 2400000 + 0.5; // Modified Chronological Julian Day Number (MCJDN)\n // the MCJDN's of the start of the lunations in the Umm al-Qura calendar are stored in the 'ummalqura_dat' array\n var index = 0;\n for (var i = 0; i < ummalqura_dat.length; i++) {\n if (ummalqura_dat[i] > mcjdn) {\n return (ummalqura_dat[index] - ummalqura_dat[index - 1]);\n }\n index++;\n }\n return 30; // Unknown outside\n },\n\n /** Determine whether this date is a week day.\n @memberof UmmAlQuraCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {boolean} true if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function (year, month, day) {\n return this.dayOfWeek(year, month, day) !== 5;\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof UmmAlQuraCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function (year, month, day) {\n var date = this._validate(year, month, day, main.local.invalidDate);\n var index = (12 * (date.year() - 1)) + date.month() - 15292;\n var mcjdn = date.day() + ummalqura_dat[index - 1] - 1;\n return mcjdn + 2400000 - 0.5; // Modified Chronological Julian Day Number (MCJDN)\n },\n\n /** Create a new date from a Julian date.\n @memberof UmmAlQuraCalendar\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function (jd) {\n var mcjdn = jd - 2400000 + 0.5; // Modified Chronological Julian Day Number (MCJDN)\n // the MCJDN's of the start of the lunations in the Umm al-Qura calendar \n // are stored in the 'ummalqura_dat' array\n var index = 0;\n for (var i = 0; i < ummalqura_dat.length; i++) {\n if (ummalqura_dat[i] > mcjdn) break;\n index++;\n }\n var lunation = index + 15292; //UmmAlQura Lunation Number\n var ii = Math.floor((lunation - 1) / 12);\n var year = ii + 1;\n var month = lunation - 12 * ii;\n var day = mcjdn - ummalqura_dat[index - 1] + 1;\n return this.newDate(year, month, day);\n },\n\n /** Determine whether a date is valid for this calendar.\n @memberof UmmAlQuraCalendar\n @param year {number} The year to examine.\n @param month {number} The month to examine.\n @param day {number} The day to examine.\n @return {boolean} true if a valid date, false if not. */\n isValid: function(year, month, day) {\n var valid = main.baseCalendar.prototype.isValid.apply(this, arguments);\n if (valid) {\n year = (year.year != null ? year.year : year);\n valid = (year >= 1276 && year <= 1500);\n }\n return valid;\n },\n\n /** Check that a candidate date is from the same calendar and is valid.\n @memberof UmmAlQuraCalendar\n @private\n @param year {CDate|number} The date to validate or the year to validate.\n @param month {number} The month to validate.\n @param day {number} The day to validate.\n @param error {string} Error message if invalid.\n @throws Error if different calendars used or invalid date. */\n _validate: function(year, month, day, error) {\n var date = main.baseCalendar.prototype._validate.apply(this, arguments);\n if (date.year < 1276 || date.year > 1500) {\n throw error.replace(/\\{0\\}/, this.local.name);\n }\n return date;\n }\n});\n\n// UmmAlQura calendar implementation\nmain.calendars.ummalqura = UmmAlQuraCalendar;\n\nvar ummalqura_dat = [\n 20, 50, 79, 109, 138, 168, 197, 227, 256, 286, 315, 345, 374, 404, 433, 463, 492, 522, 551, 581, \n 611, 641, 670, 700, 729, 759, 788, 818, 847, 877, 906, 936, 965, 995, 1024, 1054, 1083, 1113, 1142, 1172,\n 1201, 1231, 1260, 1290, 1320, 1350, 1379, 1409, 1438, 1468, 1497, 1527, 1556, 1586, 1615, 1645, 1674, 1704, 1733, 1763,\n 1792, 1822, 1851, 1881, 1910, 1940, 1969, 1999, 2028, 2058, 2087, 2117, 2146, 2176, 2205, 2235, 2264, 2294, 2323, 2353,\n 2383, 2413, 2442, 2472, 2501, 2531, 2560, 2590, 2619, 2649, 2678, 2708, 2737, 2767, 2796, 2826, 2855, 2885, 2914, 2944,\n 2973, 3003, 3032, 3062, 3091, 3121, 3150, 3180, 3209, 3239, 3268, 3298, 3327, 3357, 3386, 3416, 3446, 3476, 3505, 3535,\n 3564, 3594, 3623, 3653, 3682, 3712, 3741, 3771, 3800, 3830, 3859, 3889, 3918, 3948, 3977, 4007, 4036, 4066, 4095, 4125,\n 4155, 4185, 4214, 4244, 4273, 4303, 4332, 4362, 4391, 4421, 4450, 4480, 4509, 4539, 4568, 4598, 4627, 4657, 4686, 4716,\n 4745, 4775, 4804, 4834, 4863, 4893, 4922, 4952, 4981, 5011, 5040, 5070, 5099, 5129, 5158, 5188, 5218, 5248, 5277, 5307,\n 5336, 5366, 5395, 5425, 5454, 5484, 5513, 5543, 5572, 5602, 5631, 5661, 5690, 5720, 5749, 5779, 5808, 5838, 5867, 5897,\n 5926, 5956, 5985, 6015, 6044, 6074, 6103, 6133, 6162, 6192, 6221, 6251, 6281, 6311, 6340, 6370, 6399, 6429, 6458, 6488,\n 6517, 6547, 6576, 6606, 6635, 6665, 6694, 6724, 6753, 6783, 6812, 6842, 6871, 6901, 6930, 6960, 6989, 7019, 7048, 7078,\n 7107, 7137, 7166, 7196, 7225, 7255, 7284, 7314, 7344, 7374, 7403, 7433, 7462, 7492, 7521, 7551, 7580, 7610, 7639, 7669,\n 7698, 7728, 7757, 7787, 7816, 7846, 7875, 7905, 7934, 7964, 7993, 8023, 8053, 8083, 8112, 8142, 8171, 8201, 8230, 8260,\n 8289, 8319, 8348, 8378, 8407, 8437, 8466, 8496, 8525, 8555, 8584, 8614, 8643, 8673, 8702, 8732, 8761, 8791, 8821, 8850,\n 8880, 8909, 8938, 8968, 8997, 9027, 9056, 9086, 9115, 9145, 9175, 9205, 9234, 9264, 9293, 9322, 9352, 9381, 9410, 9440,\n 9470, 9499, 9529, 9559, 9589, 9618, 9648, 9677, 9706, 9736, 9765, 9794, 9824, 9853, 9883, 9913, 9943, 9972, 10002, 10032,\n 10061, 10090, 10120, 10149, 10178, 10208, 10237, 10267, 10297, 10326, 10356, 10386, 10415, 10445, 10474, 10504, 10533, 10562, 10592, 10621,\n 10651, 10680, 10710, 10740, 10770, 10799, 10829, 10858, 10888, 10917, 10947, 10976, 11005, 11035, 11064, 11094, 11124, 11153, 11183, 11213,\n 11242, 11272, 11301, 11331, 11360, 11389, 11419, 11448, 11478, 11507, 11537, 11567, 11596, 11626, 11655, 11685, 11715, 11744, 11774, 11803,\n 11832, 11862, 11891, 11921, 11950, 11980, 12010, 12039, 12069, 12099, 12128, 12158, 12187, 12216, 12246, 12275, 12304, 12334, 12364, 12393,\n 12423, 12453, 12483, 12512, 12542, 12571, 12600, 12630, 12659, 12688, 12718, 12747, 12777, 12807, 12837, 12866, 12896, 12926, 12955, 12984,\n 13014, 13043, 13072, 13102, 13131, 13161, 13191, 13220, 13250, 13280, 13310, 13339, 13368, 13398, 13427, 13456, 13486, 13515, 13545, 13574,\n 13604, 13634, 13664, 13693, 13723, 13752, 13782, 13811, 13840, 13870, 13899, 13929, 13958, 13988, 14018, 14047, 14077, 14107, 14136, 14166,\n 14195, 14224, 14254, 14283, 14313, 14342, 14372, 14401, 14431, 14461, 14490, 14520, 14550, 14579, 14609, 14638, 14667, 14697, 14726, 14756,\n 14785, 14815, 14844, 14874, 14904, 14933, 14963, 14993, 15021, 15051, 15081, 15110, 15140, 15169, 15199, 15228, 15258, 15287, 15317, 15347,\n 15377, 15406, 15436, 15465, 15494, 15524, 15553, 15582, 15612, 15641, 15671, 15701, 15731, 15760, 15790, 15820, 15849, 15878, 15908, 15937,\n 15966, 15996, 16025, 16055, 16085, 16114, 16144, 16174, 16204, 16233, 16262, 16292, 16321, 16350, 16380, 16409, 16439, 16468, 16498, 16528,\n 16558, 16587, 16617, 16646, 16676, 16705, 16734, 16764, 16793, 16823, 16852, 16882, 16912, 16941, 16971, 17001, 17030, 17060, 17089, 17118,\n 17148, 17177, 17207, 17236, 17266, 17295, 17325, 17355, 17384, 17414, 17444, 17473, 17502, 17532, 17561, 17591, 17620, 17650, 17679, 17709,\n 17738, 17768, 17798, 17827, 17857, 17886, 17916, 17945, 17975, 18004, 18034, 18063, 18093, 18122, 18152, 18181, 18211, 18241, 18270, 18300,\n 18330, 18359, 18388, 18418, 18447, 18476, 18506, 18535, 18565, 18595, 18625, 18654, 18684, 18714, 18743, 18772, 18802, 18831, 18860, 18890,\n 18919, 18949, 18979, 19008, 19038, 19068, 19098, 19127, 19156, 19186, 19215, 19244, 19274, 19303, 19333, 19362, 19392, 19422, 19452, 19481,\n 19511, 19540, 19570, 19599, 19628, 19658, 19687, 19717, 19746, 19776, 19806, 19836, 19865, 19895, 19924, 19954, 19983, 20012, 20042, 20071,\n 20101, 20130, 20160, 20190, 20219, 20249, 20279, 20308, 20338, 20367, 20396, 20426, 20455, 20485, 20514, 20544, 20573, 20603, 20633, 20662,\n 20692, 20721, 20751, 20780, 20810, 20839, 20869, 20898, 20928, 20957, 20987, 21016, 21046, 21076, 21105, 21135, 21164, 21194, 21223, 21253,\n 21282, 21312, 21341, 21371, 21400, 21430, 21459, 21489, 21519, 21548, 21578, 21607, 21637, 21666, 21696, 21725, 21754, 21784, 21813, 21843,\n 21873, 21902, 21932, 21962, 21991, 22021, 22050, 22080, 22109, 22138, 22168, 22197, 22227, 22256, 22286, 22316, 22346, 22375, 22405, 22434,\n 22464, 22493, 22522, 22552, 22581, 22611, 22640, 22670, 22700, 22730, 22759, 22789, 22818, 22848, 22877, 22906, 22936, 22965, 22994, 23024,\n 23054, 23083, 23113, 23143, 23173, 23202, 23232, 23261, 23290, 23320, 23349, 23379, 23408, 23438, 23467, 23497, 23527, 23556, 23586, 23616,\n 23645, 23674, 23704, 23733, 23763, 23792, 23822, 23851, 23881, 23910, 23940, 23970, 23999, 24029, 24058, 24088, 24117, 24147, 24176, 24206,\n 24235, 24265, 24294, 24324, 24353, 24383, 24413, 24442, 24472, 24501, 24531, 24560, 24590, 24619, 24648, 24678, 24707, 24737, 24767, 24796,\n 24826, 24856, 24885, 24915, 24944, 24974, 25003, 25032, 25062, 25091, 25121, 25150, 25180, 25210, 25240, 25269, 25299, 25328, 25358, 25387,\n 25416, 25446, 25475, 25505, 25534, 25564, 25594, 25624, 25653, 25683, 25712, 25742, 25771, 25800, 25830, 25859, 25888, 25918, 25948, 25977,\n 26007, 26037, 26067, 26096, 26126, 26155, 26184, 26214, 26243, 26272, 26302, 26332, 26361, 26391, 26421, 26451, 26480, 26510, 26539, 26568,\n 26598, 26627, 26656, 26686, 26715, 26745, 26775, 26805, 26834, 26864, 26893, 26923, 26952, 26982, 27011, 27041, 27070, 27099, 27129, 27159,\n 27188, 27218, 27248, 27277, 27307, 27336, 27366, 27395, 27425, 27454, 27484, 27513, 27542, 27572, 27602, 27631, 27661, 27691, 27720, 27750,\n 27779, 27809, 27838, 27868, 27897, 27926, 27956, 27985, 28015, 28045, 28074, 28104, 28134, 28163, 28193, 28222, 28252, 28281, 28310, 28340,\n 28369, 28399, 28428, 28458, 28488, 28517, 28547, 28577,\n // From 1356\n 28607, 28636, 28665, 28695, 28724, 28754, 28783, 28813, 28843, 28872, 28901, 28931, 28960, 28990, 29019, 29049, 29078, 29108, 29137, 29167,\n 29196, 29226, 29255, 29285, 29315, 29345, 29375, 29404, 29434, 29463, 29492, 29522, 29551, 29580, 29610, 29640, 29669, 29699, 29729, 29759,\n 29788, 29818, 29847, 29876, 29906, 29935, 29964, 29994, 30023, 30053, 30082, 30112, 30141, 30171, 30200, 30230, 30259, 30289, 30318, 30348,\n 30378, 30408, 30437, 30467, 30496, 30526, 30555, 30585, 30614, 30644, 30673, 30703, 30732, 30762, 30791, 30821, 30850, 30880, 30909, 30939,\n 30968, 30998, 31027, 31057, 31086, 31116, 31145, 31175, 31204, 31234, 31263, 31293, 31322, 31352, 31381, 31411, 31441, 31471, 31500, 31530,\n 31559, 31589, 31618, 31648, 31676, 31706, 31736, 31766, 31795, 31825, 31854, 31884, 31913, 31943, 31972, 32002, 32031, 32061, 32090, 32120,\n 32150, 32180, 32209, 32239, 32268, 32298, 32327, 32357, 32386, 32416, 32445, 32475, 32504, 32534, 32563, 32593, 32622, 32652, 32681, 32711,\n 32740, 32770, 32799, 32829, 32858, 32888, 32917, 32947, 32976, 33006, 33035, 33065, 33094, 33124, 33153, 33183, 33213, 33243, 33272, 33302,\n 33331, 33361, 33390, 33420, 33450, 33479, 33509, 33539, 33568, 33598, 33627, 33657, 33686, 33716, 33745, 33775, 33804, 33834, 33863, 33893,\n 33922, 33952, 33981, 34011, 34040, 34069, 34099, 34128, 34158, 34187, 34217, 34247, 34277, 34306, 34336, 34365, 34395, 34424, 34454, 34483,\n 34512, 34542, 34571, 34601, 34631, 34660, 34690, 34719, 34749, 34778, 34808, 34837, 34867, 34896, 34926, 34955, 34985, 35015, 35044, 35074,\n 35103, 35133, 35162, 35192, 35222, 35251, 35280, 35310, 35340, 35370, 35399, 35429, 35458, 35488, 35517, 35547, 35576, 35605, 35635, 35665,\n 35694, 35723, 35753, 35782, 35811, 35841, 35871, 35901, 35930, 35960, 35989, 36019, 36048, 36078, 36107, 36136, 36166, 36195, 36225, 36254,\n 36284, 36314, 36343, 36373, 36403, 36433, 36462, 36492, 36521, 36551, 36580, 36610, 36639, 36669, 36698, 36728, 36757, 36786, 36816, 36845,\n 36875, 36904, 36934, 36963, 36993, 37022, 37052, 37081, 37111, 37141, 37170, 37200, 37229, 37259, 37288, 37318, 37347, 37377, 37406, 37436,\n 37465, 37495, 37524, 37554, 37584, 37613, 37643, 37672, 37701, 37731, 37760, 37790, 37819, 37849, 37878, 37908, 37938, 37967, 37997, 38027,\n 38056, 38085, 38115, 38144, 38174, 38203, 38233, 38262, 38292, 38322, 38351, 38381, 38410, 38440, 38469, 38499, 38528, 38558, 38587, 38617,\n 38646, 38676, 38705, 38735, 38764, 38794, 38823, 38853, 38882, 38912, 38941, 38971, 39001, 39030, 39059, 39089, 39118, 39148, 39178, 39208,\n 39237, 39267, 39297, 39326, 39355, 39385, 39414, 39444, 39473, 39503, 39532, 39562, 39592, 39621, 39650, 39680, 39709, 39739, 39768, 39798,\n 39827, 39857, 39886, 39916, 39946, 39975, 40005, 40035, 40064, 40094, 40123, 40153, 40182, 40212, 40241, 40271, 40300, 40330, 40359, 40389,\n 40418, 40448, 40477, 40507, 40536, 40566, 40595, 40625, 40655, 40685, 40714, 40744, 40773, 40803, 40832, 40862, 40892, 40921, 40951, 40980,\n 41009, 41039, 41068, 41098, 41127, 41157, 41186, 41216, 41245, 41275, 41304, 41334, 41364, 41393, 41422, 41452, 41481, 41511, 41540, 41570,\n 41599, 41629, 41658, 41688, 41718, 41748, 41777, 41807, 41836, 41865, 41894, 41924, 41953, 41983, 42012, 42042, 42072, 42102, 42131, 42161,\n 42190, 42220, 42249, 42279, 42308, 42337, 42367, 42397, 42426, 42456, 42485, 42515, 42545, 42574, 42604, 42633, 42662, 42692, 42721, 42751,\n 42780, 42810, 42839, 42869, 42899, 42929, 42958, 42988, 43017, 43046, 43076, 43105, 43135, 43164, 43194, 43223, 43253, 43283, 43312, 43342,\n 43371, 43401, 43430, 43460, 43489, 43519, 43548, 43578, 43607, 43637, 43666, 43696, 43726, 43755, 43785, 43814, 43844, 43873, 43903, 43932,\n 43962, 43991, 44021, 44050, 44080, 44109, 44139, 44169, 44198, 44228, 44258, 44287, 44317, 44346, 44375, 44405, 44434, 44464, 44493, 44523,\n 44553, 44582, 44612, 44641, 44671, 44700, 44730, 44759, 44788, 44818, 44847, 44877, 44906, 44936, 44966, 44996, 45025, 45055, 45084, 45114,\n 45143, 45172, 45202, 45231, 45261, 45290, 45320, 45350, 45380, 45409, 45439, 45468, 45498, 45527, 45556, 45586, 45615, 45644, 45674, 45704,\n 45733, 45763, 45793, 45823, 45852, 45882, 45911, 45940, 45970, 45999, 46028, 46058, 46088, 46117, 46147, 46177, 46206, 46236, 46265, 46295,\n 46324, 46354, 46383, 46413, 46442, 46472, 46501, 46531, 46560, 46590, 46620, 46649, 46679, 46708, 46738, 46767, 46797, 46826, 46856, 46885,\n 46915, 46944, 46974, 47003, 47033, 47063, 47092, 47122, 47151, 47181, 47210, 47240, 47269, 47298, 47328, 47357, 47387, 47417, 47446, 47476,\n 47506, 47535, 47565, 47594, 47624, 47653, 47682, 47712, 47741, 47771, 47800, 47830, 47860, 47890, 47919, 47949, 47978, 48008, 48037, 48066,\n 48096, 48125, 48155, 48184, 48214, 48244, 48273, 48303, 48333, 48362, 48392, 48421, 48450, 48480, 48509, 48538, 48568, 48598, 48627, 48657,\n 48687, 48717, 48746, 48776, 48805, 48834, 48864, 48893, 48922, 48952, 48982, 49011, 49041, 49071, 49100, 49130, 49160, 49189, 49218, 49248,\n 49277, 49306, 49336, 49365, 49395, 49425, 49455, 49484, 49514, 49543, 49573, 49602, 49632, 49661, 49690, 49720, 49749, 49779, 49809, 49838,\n 49868, 49898, 49927, 49957, 49986, 50016, 50045, 50075, 50104, 50133, 50163, 50192, 50222, 50252, 50281, 50311, 50340, 50370, 50400, 50429,\n 50459, 50488, 50518, 50547, 50576, 50606, 50635, 50665, 50694, 50724, 50754, 50784, 50813, 50843, 50872, 50902, 50931, 50960, 50990, 51019,\n 51049, 51078, 51108, 51138, 51167, 51197, 51227, 51256, 51286, 51315, 51345, 51374, 51403, 51433, 51462, 51492, 51522, 51552, 51582, 51611,\n 51641, 51670, 51699, 51729, 51758, 51787, 51816, 51846, 51876, 51906, 51936, 51965, 51995, 52025, 52054, 52083, 52113, 52142, 52171, 52200,\n 52230, 52260, 52290, 52319, 52349, 52379, 52408, 52438, 52467, 52497, 52526, 52555, 52585, 52614, 52644, 52673, 52703, 52733, 52762, 52792,\n 52822, 52851, 52881, 52910, 52939, 52969, 52998, 53028, 53057, 53087, 53116, 53146, 53176, 53205, 53235, 53264, 53294, 53324, 53353, 53383,\n 53412, 53441, 53471, 53500, 53530, 53559, 53589, 53619, 53648, 53678, 53708, 53737, 53767, 53796, 53825, 53855, 53884, 53913, 53943, 53973,\n 54003, 54032, 54062, 54092, 54121, 54151, 54180, 54209, 54239, 54268, 54297, 54327, 54357, 54387, 54416, 54446, 54476, 54505, 54535, 54564,\n 54593, 54623, 54652, 54681, 54711, 54741, 54770, 54800, 54830, 54859, 54889, 54919, 54948, 54977, 55007, 55036, 55066, 55095, 55125, 55154,\n 55184, 55213, 55243, 55273, 55302, 55332, 55361, 55391, 55420, 55450, 55479, 55508, 55538, 55567, 55597, 55627, 55657, 55686, 55716, 55745,\n 55775, 55804, 55834, 55863, 55892, 55922, 55951, 55981, 56011, 56040, 56070, 56100, 56129, 56159, 56188, 56218, 56247, 56276, 56306, 56335,\n 56365, 56394, 56424, 56454, 56483, 56513, 56543, 56572, 56601, 56631, 56660, 56690, 56719, 56749, 56778, 56808, 56837, 56867, 56897, 56926,\n 56956, 56985, 57015, 57044, 57074, 57103, 57133, 57162, 57192, 57221, 57251, 57280, 57310, 57340, 57369, 57399, 57429, 57458, 57487, 57517,\n 57546, 57576, 57605, 57634, 57664, 57694, 57723, 57753, 57783, 57813, 57842, 57871, 57901, 57930, 57959, 57989, 58018, 58048, 58077, 58107,\n 58137, 58167, 58196, 58226, 58255, 58285, 58314, 58343, 58373, 58402, 58432, 58461, 58491, 58521, 58551, 58580, 58610, 58639, 58669, 58698,\n 58727, 58757, 58786, 58816, 58845, 58875, 58905, 58934, 58964, 58994, 59023, 59053, 59082, 59111, 59141, 59170, 59200, 59229, 59259, 59288,\n 59318, 59348, 59377, 59407, 59436, 59466, 59495, 59525, 59554, 59584, 59613, 59643, 59672, 59702, 59731, 59761, 59791, 59820, 59850, 59879,\n 59909, 59939, 59968, 59997, 60027, 60056, 60086, 60115, 60145, 60174, 60204, 60234, 60264, 60293, 60323, 60352, 60381, 60411, 60440, 60469,\n 60499, 60528, 60558, 60588, 60618, 60648, 60677, 60707, 60736, 60765, 60795, 60824, 60853, 60883, 60912, 60942, 60972, 61002, 61031, 61061,\n 61090, 61120, 61149, 61179, 61208, 61237, 61267, 61296, 61326, 61356, 61385, 61415, 61445, 61474, 61504, 61533, 61563, 61592, 61621, 61651,\n 61680, 61710, 61739, 61769, 61799, 61828, 61858, 61888, 61917, 61947, 61976, 62006, 62035, 62064, 62094, 62123, 62153, 62182, 62212, 62242,\n 62271, 62301, 62331, 62360, 62390, 62419, 62448, 62478, 62507, 62537, 62566, 62596, 62625, 62655, 62685, 62715, 62744, 62774, 62803, 62832,\n 62862, 62891, 62921, 62950, 62980, 63009, 63039, 63069, 63099, 63128, 63157, 63187, 63216, 63246, 63275, 63305, 63334, 63363, 63393, 63423,\n 63453, 63482, 63512, 63541, 63571, 63600, 63630, 63659, 63689, 63718, 63747, 63777, 63807, 63836, 63866, 63895, 63925, 63955, 63984, 64014,\n 64043, 64073, 64102, 64131, 64161, 64190, 64220, 64249, 64279, 64309, 64339, 64368, 64398, 64427, 64457, 64486, 64515, 64545, 64574, 64603,\n 64633, 64663, 64692, 64722, 64752, 64782, 64811, 64841, 64870, 64899, 64929, 64958, 64987, 65017, 65047, 65076, 65106, 65136, 65166, 65195,\n 65225, 65254, 65283, 65313, 65342, 65371, 65401, 65431, 65460, 65490, 65520, 65549, 65579, 65608, 65638, 65667, 65697, 65726, 65755, 65785,\n 65815, 65844, 65874, 65903, 65933, 65963, 65992, 66022, 66051, 66081, 66110, 66140, 66169, 66199, 66228, 66258, 66287, 66317, 66346, 66376,\n 66405, 66435, 66465, 66494, 66524, 66553, 66583, 66612, 66641, 66671, 66700, 66730, 66760, 66789, 66819, 66849, 66878, 66908, 66937, 66967,\n 66996, 67025, 67055, 67084, 67114, 67143, 67173, 67203, 67233, 67262, 67292, 67321, 67351, 67380, 67409, 67439, 67468, 67497, 67527, 67557,\n 67587, 67617, 67646, 67676, 67705, 67735, 67764, 67793, 67823, 67852, 67882, 67911, 67941, 67971, 68000, 68030, 68060, 68089, 68119, 68148,\n 68177, 68207, 68236, 68266, 68295, 68325, 68354, 68384, 68414, 68443, 68473, 68502, 68532, 68561, 68591, 68620, 68650, 68679, 68708, 68738,\n 68768, 68797, 68827, 68857, 68886, 68916, 68946, 68975, 69004, 69034, 69063, 69092, 69122, 69152, 69181, 69211, 69240, 69270, 69300, 69330,\n 69359, 69388, 69418, 69447, 69476, 69506, 69535, 69565, 69595, 69624, 69654, 69684, 69713, 69743, 69772, 69802, 69831, 69861, 69890, 69919,\n 69949, 69978, 70008, 70038, 70067, 70097, 70126, 70156, 70186, 70215, 70245, 70274, 70303, 70333, 70362, 70392, 70421, 70451, 70481, 70510,\n 70540, 70570, 70599, 70629, 70658, 70687, 70717, 70746, 70776, 70805, 70835, 70864, 70894, 70924, 70954, 70983, 71013, 71042, 71071, 71101,\n 71130, 71159, 71189, 71218, 71248, 71278, 71308, 71337, 71367, 71397, 71426, 71455, 71485, 71514, 71543, 71573, 71602, 71632, 71662, 71691,\n 71721, 71751, 71781, 71810, 71839, 71869, 71898, 71927, 71957, 71986, 72016, 72046, 72075, 72105, 72135, 72164, 72194, 72223, 72253, 72282,\n 72311, 72341, 72370, 72400, 72429, 72459, 72489, 72518, 72548, 72577, 72607, 72637, 72666, 72695, 72725, 72754, 72784, 72813, 72843, 72872,\n 72902, 72931, 72961, 72991, 73020, 73050, 73080, 73109, 73139, 73168, 73197, 73227, 73256, 73286, 73315, 73345, 73375, 73404, 73434, 73464,\n 73493, 73523, 73552, 73581, 73611, 73640, 73669, 73699, 73729, 73758, 73788, 73818, 73848, 73877, 73907, 73936, 73965, 73995, 74024, 74053,\n 74083, 74113, 74142, 74172, 74202, 74231, 74261, 74291, 74320, 74349, 74379, 74408, 74437, 74467, 74497, 74526, 74556, 74586, 74615, 74645,\n 74675, 74704, 74733, 74763, 74792, 74822, 74851, 74881, 74910, 74940, 74969, 74999, 75029, 75058, 75088, 75117, 75147, 75176, 75206, 75235,\n 75264, 75294, 75323, 75353, 75383, 75412, 75442, 75472, 75501, 75531, 75560, 75590, 75619, 75648, 75678, 75707, 75737, 75766, 75796, 75826,\n 75856, 75885, 75915, 75944, 75974, 76003, 76032, 76062, 76091, 76121, 76150, 76180, 76210, 76239, 76269, 76299, 76328, 76358, 76387, 76416,\n 76446, 76475, 76505, 76534, 76564, 76593, 76623, 76653, 76682, 76712, 76741, 76771, 76801, 76830, 76859, 76889, 76918, 76948, 76977, 77007,\n 77036, 77066, 77096, 77125, 77155, 77185, 77214, 77243, 77273, 77302, 77332, 77361, 77390, 77420, 77450, 77479, 77509, 77539, 77569, 77598,\n 77627, 77657, 77686, 77715, 77745, 77774, 77804, 77833, 77863, 77893, 77923, 77952, 77982, 78011, 78041, 78070, 78099, 78129, 78158, 78188,\n 78217, 78247, 78277, 78307, 78336, 78366, 78395, 78425, 78454, 78483, 78513, 78542, 78572, 78601, 78631, 78661, 78690, 78720, 78750, 78779,\n 78808, 78838, 78867, 78897, 78926, 78956, 78985, 79015, 79044, 79074, 79104, 79133, 79163, 79192, 79222, 79251, 79281, 79310, 79340, 79369,\n 79399, 79428, 79458, 79487, 79517, 79546, 79576, 79606, 79635, 79665, 79695, 79724, 79753, 79783, 79812, 79841, 79871, 79900, 79930, 79960,\n 79990];\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Calendars for jQuery v2.0.2.\n Written by Keith Wood (wood.keith{at}optusnet.com.au) August 2009.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar assign = require('object-assign');\n\n\nfunction Calendars() {\n this.regionalOptions = [];\n this.regionalOptions[''] = {\n invalidCalendar: 'Calendar {0} not found',\n invalidDate: 'Invalid {0} date',\n invalidMonth: 'Invalid {0} month',\n invalidYear: 'Invalid {0} year',\n differentCalendars: 'Cannot mix {0} and {1} dates'\n };\n this.local = this.regionalOptions[''];\n this.calendars = {};\n this._localCals = {};\n}\n\n/** Create the calendars plugin.\n

Provides support for various world calendars in a consistent manner.

\n @class Calendars\n @example _exports.instance('julian').newDate(2014, 12, 25) */\nassign(Calendars.prototype, {\n\n /** Obtain a calendar implementation and localisation.\n @memberof Calendars\n @param [name='gregorian'] {string} The name of the calendar, e.g. 'gregorian', 'persian', 'islamic'.\n @param [language=''] {string} The language code to use for localisation (default is English).\n @return {Calendar} The calendar and localisation.\n @throws Error if calendar not found. */\n instance: function(name, language) {\n name = (name || 'gregorian').toLowerCase();\n language = language || '';\n var cal = this._localCals[name + '-' + language];\n if (!cal && this.calendars[name]) {\n cal = new this.calendars[name](language);\n this._localCals[name + '-' + language] = cal;\n }\n if (!cal) {\n throw (this.local.invalidCalendar || this.regionalOptions[''].invalidCalendar).\n replace(/\\{0\\}/, name);\n }\n return cal;\n },\n\n /** Create a new date - for today if no other parameters given.\n @memberof Calendars\n @param year {CDate|number} The date to copy or the year for the date.\n @param [month] {number} The month for the date.\n @param [day] {number} The day for the date.\n @param [calendar='gregorian'] {BaseCalendar|string} The underlying calendar or the name of the calendar.\n @param [language=''] {string} The language to use for localisation (default English).\n @return {CDate} The new date.\n @throws Error if an invalid date. */\n newDate: function(year, month, day, calendar, language) {\n calendar = (year != null && year.year ? year.calendar() : (typeof calendar === 'string' ?\n this.instance(calendar, language) : calendar)) || this.instance();\n return calendar.newDate(year, month, day);\n },\n \n /** A simple digit substitution function for localising numbers via the Calendar digits option.\n @member Calendars\n @param digits {string[]} The substitute digits, for 0 through 9.\n @return {function} The substitution function. */\n substituteDigits: function(digits) {\n return function(value) {\n return (value + '').replace(/[0-9]/g, function(digit) {\n return digits[digit];\n });\n }\n },\n \n /** Digit substitution function for localising Chinese style numbers via the Calendar digits option.\n @member Calendars\n @param digits {string[]} The substitute digits, for 0 through 9.\n @param powers {string[]} The characters denoting powers of 10, i.e. 1, 10, 100, 1000.\n @return {function} The substitution function. */\n substituteChineseDigits: function(digits, powers) {\n return function(value) {\n var localNumber = '';\n var power = 0;\n while (value > 0) {\n var units = value % 10;\n localNumber = (units === 0 ? '' : digits[units] + powers[power]) + localNumber;\n power++;\n value = Math.floor(value / 10);\n }\n if (localNumber.indexOf(digits[1] + powers[1]) === 0) {\n localNumber = localNumber.substr(1);\n }\n return localNumber || digits[0];\n }\n }\n});\n\n/** Generic date, based on a particular calendar.\n @class CDate\n @param calendar {BaseCalendar} The underlying calendar implementation.\n @param year {number} The year for this date.\n @param month {number} The month for this date.\n @param day {number} The day for this date.\n @return {CDate} The date object.\n @throws Error if an invalid date. */\nfunction CDate(calendar, year, month, day) {\n this._calendar = calendar;\n this._year = year;\n this._month = month;\n this._day = day;\n if (this._calendar._validateLevel === 0 &&\n !this._calendar.isValid(this._year, this._month, this._day)) {\n throw (_exports.local.invalidDate || _exports.regionalOptions[''].invalidDate).\n replace(/\\{0\\}/, this._calendar.local.name);\n }\n}\n\n/** Pad a numeric value with leading zeroes.\n @private\n @param value {number} The number to format.\n @param length {number} The minimum length.\n @return {string} The formatted number. */\nfunction pad(value, length) {\n value = '' + value;\n return '000000'.substring(0, length - value.length) + value;\n}\n\nassign(CDate.prototype, {\n\n /** Create a new date.\n @memberof CDate\n @param [year] {CDate|number} The date to copy or the year for the date (default this date).\n @param [month] {number} The month for the date.\n @param [day] {number} The day for the date.\n @return {CDate} The new date.\n @throws Error if an invalid date. */\n newDate: function(year, month, day) {\n return this._calendar.newDate((year == null ? this : year), month, day);\n },\n\n /** Set or retrieve the year for this date.\n @memberof CDate\n @param [year] {number} The year for the date.\n @return {number|CDate} The date's year (if no parameter) or the updated date.\n @throws Error if an invalid date. */\n year: function(year) {\n return (arguments.length === 0 ? this._year : this.set(year, 'y'));\n },\n\n /** Set or retrieve the month for this date.\n @memberof CDate\n @param [month] {number} The month for the date.\n @return {number|CDate} The date's month (if no parameter) or the updated date.\n @throws Error if an invalid date. */\n month: function(month) {\n return (arguments.length === 0 ? this._month : this.set(month, 'm'));\n },\n\n /** Set or retrieve the day for this date.\n @memberof CDate\n @param [day] {number} The day for the date.\n @return {number|CData} The date's day (if no parameter) or the updated date.\n @throws Error if an invalid date. */\n day: function(day) {\n return (arguments.length === 0 ? this._day : this.set(day, 'd'));\n },\n\n /** Set new values for this date.\n @memberof CDate\n @param year {number} The year for the date.\n @param month {number} The month for the date.\n @param day {number} The day for the date.\n @return {CDate} The updated date.\n @throws Error if an invalid date. */\n date: function(year, month, day) {\n if (!this._calendar.isValid(year, month, day)) {\n throw (_exports.local.invalidDate || _exports.regionalOptions[''].invalidDate).\n replace(/\\{0\\}/, this._calendar.local.name);\n }\n this._year = year;\n this._month = month;\n this._day = day;\n return this;\n },\n\n /** Determine whether this date is in a leap year.\n @memberof CDate\n @return {boolean} true if this is a leap year, false if not. */\n leapYear: function() {\n return this._calendar.leapYear(this);\n },\n\n /** Retrieve the epoch designator for this date, e.g. BCE or CE.\n @memberof CDate\n @return {string} The current epoch. */\n epoch: function() {\n return this._calendar.epoch(this);\n },\n\n /** Format the year, if not a simple sequential number.\n @memberof CDate\n @return {string} The formatted year. */\n formatYear: function() {\n return this._calendar.formatYear(this);\n },\n\n /** Retrieve the month of the year for this date,\n i.e. the month's position within a numbered year.\n @memberof CDate\n @return {number} The month of the year: minMonth to months per year. */\n monthOfYear: function() {\n return this._calendar.monthOfYear(this);\n },\n\n /** Retrieve the week of the year for this date.\n @memberof CDate\n @return {number} The week of the year: 1 to weeks per year. */\n weekOfYear: function() {\n return this._calendar.weekOfYear(this);\n },\n\n /** Retrieve the number of days in the year for this date.\n @memberof CDate\n @return {number} The number of days in this year. */\n daysInYear: function() {\n return this._calendar.daysInYear(this);\n },\n\n /** Retrieve the day of the year for this date.\n @memberof CDate\n @return {number} The day of the year: 1 to days per year. */\n dayOfYear: function() {\n return this._calendar.dayOfYear(this);\n },\n\n /** Retrieve the number of days in the month for this date.\n @memberof CDate\n @return {number} The number of days. */\n daysInMonth: function() {\n return this._calendar.daysInMonth(this);\n },\n\n /** Retrieve the day of the week for this date.\n @memberof CDate\n @return {number} The day of the week: 0 to number of days - 1. */\n dayOfWeek: function() {\n return this._calendar.dayOfWeek(this);\n },\n\n /** Determine whether this date is a week day.\n @memberof CDate\n @return {boolean} true if a week day, false if not. */\n weekDay: function() {\n return this._calendar.weekDay(this);\n },\n\n /** Retrieve additional information about this date.\n @memberof CDate\n @return {object} Additional information - contents depends on calendar. */\n extraInfo: function() {\n return this._calendar.extraInfo(this);\n },\n\n /** Add period(s) to a date.\n @memberof CDate\n @param offset {number} The number of periods to adjust by.\n @param period {string} One of 'y' for year, 'm' for month, 'w' for week, 'd' for day.\n @return {CDate} The updated date. */\n add: function(offset, period) {\n return this._calendar.add(this, offset, period);\n },\n\n /** Set a portion of the date.\n @memberof CDate\n @param value {number} The new value for the period.\n @param period {string} One of 'y' for year, 'm' for month, 'd' for day.\n @return {CDate} The updated date.\n @throws Error if not a valid date. */\n set: function(value, period) {\n return this._calendar.set(this, value, period);\n },\n\n /** Compare this date to another date.\n @memberof CDate\n @param date {CDate} The other date.\n @return {number} -1 if this date is before the other date,\n 0 if they are equal, or +1 if this date is after the other date. */\n compareTo: function(date) {\n if (this._calendar.name !== date._calendar.name) {\n throw (_exports.local.differentCalendars || _exports.regionalOptions[''].differentCalendars).\n replace(/\\{0\\}/, this._calendar.local.name).replace(/\\{1\\}/, date._calendar.local.name);\n }\n var c = (this._year !== date._year ? this._year - date._year :\n this._month !== date._month ? this.monthOfYear() - date.monthOfYear() :\n this._day - date._day);\n return (c === 0 ? 0 : (c < 0 ? -1 : +1));\n },\n\n /** Retrieve the calendar backing this date.\n @memberof CDate\n @return {BaseCalendar} The calendar implementation. */\n calendar: function() {\n return this._calendar;\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof CDate\n @return {number} The equivalent Julian date. */\n toJD: function() {\n return this._calendar.toJD(this);\n },\n\n /** Create a new date from a Julian date.\n @memberof CDate\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function(jd) {\n return this._calendar.fromJD(jd);\n },\n\n /** Convert this date to a standard (Gregorian) JavaScript Date.\n @memberof CDate\n @return {Date} The equivalent JavaScript date. */\n toJSDate: function() {\n return this._calendar.toJSDate(this);\n },\n\n /** Create a new date from a standard (Gregorian) JavaScript Date.\n @memberof CDate\n @param jsd {Date} The JavaScript date to convert.\n @return {CDate} The equivalent date. */\n fromJSDate: function(jsd) {\n return this._calendar.fromJSDate(jsd);\n },\n\n /** Convert to a string for display.\n @memberof CDate\n @return {string} This date as a string. */\n toString: function() {\n return (this.year() < 0 ? '-' : '') + pad(Math.abs(this.year()), 4) +\n '-' + pad(this.month(), 2) + '-' + pad(this.day(), 2);\n }\n});\n\n/** Basic functionality for all calendars.\n Other calendars should extend this:\n
OtherCalendar.prototype = new BaseCalendar;
\n @class BaseCalendar */\nfunction BaseCalendar() {\n this.shortYearCutoff = '+10';\n}\n\nassign(BaseCalendar.prototype, {\n _validateLevel: 0, // \"Stack\" to turn validation on/off\n\n /** Create a new date within this calendar - today if no parameters given.\n @memberof BaseCalendar\n @param year {CDate|number} The date to duplicate or the year for the date.\n @param [month] {number} The month for the date.\n @param [day] {number} The day for the date.\n @return {CDate} The new date.\n @throws Error if not a valid date or a different calendar used. */\n newDate: function(year, month, day) {\n if (year == null) {\n return this.today();\n }\n if (year.year) {\n this._validate(year, month, day,\n _exports.local.invalidDate || _exports.regionalOptions[''].invalidDate);\n day = year.day();\n month = year.month();\n year = year.year();\n }\n return new CDate(this, year, month, day);\n },\n\n /** Create a new date for today.\n @memberof BaseCalendar\n @return {CDate} Today's date. */\n today: function() {\n return this.fromJSDate(new Date());\n },\n\n /** Retrieve the epoch designator for this date.\n @memberof BaseCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {string} The current epoch.\n @throws Error if an invalid year or a different calendar used. */\n epoch: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay,\n _exports.local.invalidYear || _exports.regionalOptions[''].invalidYear);\n return (date.year() < 0 ? this.local.epochs[0] : this.local.epochs[1]);\n },\n\n /** Format the year, if not a simple sequential number\n @memberof BaseCalendar\n @param year {CDate|number} The date to format or the year to format.\n @return {string} The formatted year.\n @throws Error if an invalid year or a different calendar used. */\n formatYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay,\n _exports.local.invalidYear || _exports.regionalOptions[''].invalidYear);\n return (date.year() < 0 ? '-' : '') + pad(Math.abs(date.year()), 4)\n },\n\n /** Retrieve the number of months in a year.\n @memberof BaseCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The number of months.\n @throws Error if an invalid year or a different calendar used. */\n monthsInYear: function(year) {\n this._validate(year, this.minMonth, this.minDay,\n _exports.local.invalidYear || _exports.regionalOptions[''].invalidYear);\n return 12;\n },\n\n /** Calculate the month's ordinal position within the year -\n for those calendars that don't start at month 1!\n @memberof BaseCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param month {number} The month to examine.\n @return {number} The ordinal position, starting from minMonth.\n @throws Error if an invalid year/month or a different calendar used. */\n monthOfYear: function(year, month) {\n var date = this._validate(year, month, this.minDay,\n _exports.local.invalidMonth || _exports.regionalOptions[''].invalidMonth);\n return (date.month() + this.monthsInYear(date) - this.firstMonth) %\n this.monthsInYear(date) + this.minMonth;\n },\n\n /** Calculate actual month from ordinal position, starting from minMonth.\n @memberof BaseCalendar\n @param year {number} The year to examine.\n @param ord {number} The month's ordinal position.\n @return {number} The month's number.\n @throws Error if an invalid year/month. */\n fromMonthOfYear: function(year, ord) {\n var m = (ord + this.firstMonth - 2 * this.minMonth) %\n this.monthsInYear(year) + this.minMonth;\n this._validate(year, m, this.minDay,\n _exports.local.invalidMonth || _exports.regionalOptions[''].invalidMonth);\n return m;\n },\n\n /** Retrieve the number of days in a year.\n @memberof BaseCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {number} The number of days.\n @throws Error if an invalid year or a different calendar used. */\n daysInYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay,\n _exports.local.invalidYear || _exports.regionalOptions[''].invalidYear);\n return (this.leapYear(date) ? 366 : 365);\n },\n\n /** Retrieve the day of the year for a date.\n @memberof BaseCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {number} The day of the year.\n @throws Error if an invalid date or a different calendar used. */\n dayOfYear: function(year, month, day) {\n var date = this._validate(year, month, day,\n _exports.local.invalidDate || _exports.regionalOptions[''].invalidDate);\n return date.toJD() - this.newDate(date.year(),\n this.fromMonthOfYear(date.year(), this.minMonth), this.minDay).toJD() + 1;\n },\n\n /** Retrieve the number of days in a week.\n @memberof BaseCalendar\n @return {number} The number of days. */\n daysInWeek: function() {\n return 7;\n },\n\n /** Retrieve the day of the week for a date.\n @memberof BaseCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The day of the week: 0 to number of days - 1.\n @throws Error if an invalid date or a different calendar used. */\n dayOfWeek: function(year, month, day) {\n var date = this._validate(year, month, day,\n _exports.local.invalidDate || _exports.regionalOptions[''].invalidDate);\n return (Math.floor(this.toJD(date)) + 2) % this.daysInWeek();\n },\n\n /** Retrieve additional information about a date.\n @memberof BaseCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {object} Additional information - contents depends on calendar.\n @throws Error if an invalid date or a different calendar used. */\n extraInfo: function(year, month, day) {\n this._validate(year, month, day,\n _exports.local.invalidDate || _exports.regionalOptions[''].invalidDate);\n return {};\n },\n\n /** Add period(s) to a date.\n Cater for no year zero.\n @memberof BaseCalendar\n @param date {CDate} The starting date.\n @param offset {number} The number of periods to adjust by.\n @param period {string} One of 'y' for year, 'm' for month, 'w' for week, 'd' for day.\n @return {CDate} The updated date.\n @throws Error if a different calendar used. */\n add: function(date, offset, period) {\n this._validate(date, this.minMonth, this.minDay,\n _exports.local.invalidDate || _exports.regionalOptions[''].invalidDate);\n return this._correctAdd(date, this._add(date, offset, period), offset, period);\n },\n\n /** Add period(s) to a date.\n @memberof BaseCalendar\n @private\n @param date {CDate} The starting date.\n @param offset {number} The number of periods to adjust by.\n @param period {string} One of 'y' for year, 'm' for month, 'w' for week, 'd' for day.\n @return {CDate} The updated date. */\n _add: function(date, offset, period) {\n this._validateLevel++;\n if (period === 'd' || period === 'w') {\n var jd = date.toJD() + offset * (period === 'w' ? this.daysInWeek() : 1);\n var d = date.calendar().fromJD(jd);\n this._validateLevel--;\n return [d.year(), d.month(), d.day()];\n }\n try {\n var y = date.year() + (period === 'y' ? offset : 0);\n var m = date.monthOfYear() + (period === 'm' ? offset : 0);\n var d = date.day();// + (period === 'd' ? offset : 0) +\n //(period === 'w' ? offset * this.daysInWeek() : 0);\n var resyncYearMonth = function(calendar) {\n while (m < calendar.minMonth) {\n y--;\n m += calendar.monthsInYear(y);\n }\n var yearMonths = calendar.monthsInYear(y);\n while (m > yearMonths - 1 + calendar.minMonth) {\n y++;\n m -= yearMonths;\n yearMonths = calendar.monthsInYear(y);\n }\n };\n if (period === 'y') {\n if (date.month() !== this.fromMonthOfYear(y, m)) { // Hebrew\n m = this.newDate(y, date.month(), this.minDay).monthOfYear();\n }\n m = Math.min(m, this.monthsInYear(y));\n d = Math.min(d, this.daysInMonth(y, this.fromMonthOfYear(y, m)));\n }\n else if (period === 'm') {\n resyncYearMonth(this);\n d = Math.min(d, this.daysInMonth(y, this.fromMonthOfYear(y, m)));\n }\n var ymd = [y, this.fromMonthOfYear(y, m), d];\n this._validateLevel--;\n return ymd;\n }\n catch (e) {\n this._validateLevel--;\n throw e;\n }\n },\n\n /** Correct a candidate date after adding period(s) to a date.\n Handle no year zero if necessary.\n @memberof BaseCalendar\n @private\n @param date {CDate} The starting date.\n @param ymd {number[]} The added date.\n @param offset {number} The number of periods to adjust by.\n @param period {string} One of 'y' for year, 'm' for month, 'w' for week, 'd' for day.\n @return {CDate} The updated date. */\n _correctAdd: function(date, ymd, offset, period) {\n if (!this.hasYearZero && (period === 'y' || period === 'm')) {\n if (ymd[0] === 0 || // In year zero\n (date.year() > 0) !== (ymd[0] > 0)) { // Crossed year zero\n var adj = {y: [1, 1, 'y'], m: [1, this.monthsInYear(-1), 'm'],\n w: [this.daysInWeek(), this.daysInYear(-1), 'd'],\n d: [1, this.daysInYear(-1), 'd']}[period];\n var dir = (offset < 0 ? -1 : +1);\n ymd = this._add(date, offset * adj[0] + dir * adj[1], adj[2]);\n }\n }\n return date.date(ymd[0], ymd[1], ymd[2]);\n },\n\n /** Set a portion of the date.\n @memberof BaseCalendar\n @param date {CDate} The starting date.\n @param value {number} The new value for the period.\n @param period {string} One of 'y' for year, 'm' for month, 'd' for day.\n @return {CDate} The updated date.\n @throws Error if an invalid date or a different calendar used. */\n set: function(date, value, period) {\n this._validate(date, this.minMonth, this.minDay,\n _exports.local.invalidDate || _exports.regionalOptions[''].invalidDate);\n var y = (period === 'y' ? value : date.year());\n var m = (period === 'm' ? value : date.month());\n var d = (period === 'd' ? value : date.day());\n if (period === 'y' || period === 'm') {\n d = Math.min(d, this.daysInMonth(y, m));\n }\n return date.date(y, m, d);\n },\n\n /** Determine whether a date is valid for this calendar.\n @memberof BaseCalendar\n @param year {number} The year to examine.\n @param month {number} The month to examine.\n @param day {number} The day to examine.\n @return {boolean} true if a valid date, false if not. */\n isValid: function(year, month, day) {\n this._validateLevel++;\n var valid = (this.hasYearZero || year !== 0);\n if (valid) {\n var date = this.newDate(year, month, this.minDay);\n valid = (month >= this.minMonth && month - this.minMonth < this.monthsInYear(date)) &&\n (day >= this.minDay && day - this.minDay < this.daysInMonth(date));\n }\n this._validateLevel--;\n return valid;\n },\n\n /** Convert the date to a standard (Gregorian) JavaScript Date.\n @memberof BaseCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {Date} The equivalent JavaScript date.\n @throws Error if an invalid date or a different calendar used. */\n toJSDate: function(year, month, day) {\n var date = this._validate(year, month, day,\n _exports.local.invalidDate || _exports.regionalOptions[''].invalidDate);\n return _exports.instance().fromJD(this.toJD(date)).toJSDate();\n },\n\n /** Convert the date from a standard (Gregorian) JavaScript Date.\n @memberof BaseCalendar\n @param jsd {Date} The JavaScript date.\n @return {CDate} The equivalent calendar date. */\n fromJSDate: function(jsd) {\n return this.fromJD(_exports.instance().fromJSDate(jsd).toJD());\n },\n\n /** Check that a candidate date is from the same calendar and is valid.\n @memberof BaseCalendar\n @private\n @param year {CDate|number} The date to validate or the year to validate.\n @param [month] {number} The month to validate.\n @param [day] {number} The day to validate.\n @param error {string} Rrror message if invalid.\n @throws Error if different calendars used or invalid date. */\n _validate: function(year, month, day, error) {\n if (year.year) {\n if (this._validateLevel === 0 && this.name !== year.calendar().name) {\n throw (_exports.local.differentCalendars || _exports.regionalOptions[''].differentCalendars).\n replace(/\\{0\\}/, this.local.name).replace(/\\{1\\}/, year.calendar().local.name);\n }\n return year;\n }\n try {\n this._validateLevel++;\n if (this._validateLevel === 1 && !this.isValid(year, month, day)) {\n throw error.replace(/\\{0\\}/, this.local.name);\n }\n var date = this.newDate(year, month, day);\n this._validateLevel--;\n return date;\n }\n catch (e) {\n this._validateLevel--;\n throw e;\n }\n }\n});\n\n/** Implementation of the Proleptic Gregorian Calendar.\n See http://en.wikipedia.org/wiki/Gregorian_calendar\n and http://en.wikipedia.org/wiki/Proleptic_Gregorian_calendar.\n @class GregorianCalendar\n @augments BaseCalendar\n @param [language=''] {string} The language code (default English) for localisation. */\nfunction GregorianCalendar(language) {\n this.local = this.regionalOptions[language] || this.regionalOptions[''];\n}\n\nGregorianCalendar.prototype = new BaseCalendar;\n\nassign(GregorianCalendar.prototype, {\n /** The calendar name.\n @memberof GregorianCalendar */\n name: 'Gregorian',\n /** Julian date of start of Gregorian epoch: 1 January 0001 CE.\n @memberof GregorianCalendar */\n jdEpoch: 1721425.5,\n /** Days per month in a common year.\n @memberof GregorianCalendar */\n daysPerMonth: [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31],\n /** true if has a year zero, false if not.\n @memberof GregorianCalendar */\n hasYearZero: false,\n /** The minimum month number.\n @memberof GregorianCalendar */\n minMonth: 1,\n /** The first month in the year.\n @memberof GregorianCalendar */\n firstMonth: 1,\n /** The minimum day number.\n @memberof GregorianCalendar */\n minDay: 1,\n\n /** Localisations for the plugin.\n Entries are objects indexed by the language code ('' being the default US/English).\n Each object has the following attributes.\n @memberof GregorianCalendar\n @property name {string} The calendar name.\n @property epochs {string[]} The epoch names.\n @property monthNames {string[]} The long names of the months of the year.\n @property monthNamesShort {string[]} The short names of the months of the year.\n @property dayNames {string[]} The long names of the days of the week.\n @property dayNamesShort {string[]} The short names of the days of the week.\n @property dayNamesMin {string[]} The minimal names of the days of the week.\n @property dateFormat {string} The date format for this calendar.\n See the options on formatDate for details.\n @property firstDay {number} The number of the first day of the week, starting at 0.\n @property isRTL {number} true if this localisation reads right-to-left. */\n regionalOptions: { // Localisations\n '': {\n name: 'Gregorian',\n epochs: ['BCE', 'CE'],\n monthNames: ['January', 'February', 'March', 'April', 'May', 'June',\n 'July', 'August', 'September', 'October', 'November', 'December'],\n monthNamesShort: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n dayNames: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],\n dayNamesShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n dayNamesMin: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],\n digits: null,\n dateFormat: 'mm/dd/yyyy',\n firstDay: 0,\n isRTL: false\n }\n },\n \n /** Determine whether this date is in a leap year.\n @memberof GregorianCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @return {boolean} true if this is a leap year, false if not.\n @throws Error if an invalid year or a different calendar used. */\n leapYear: function(year) {\n var date = this._validate(year, this.minMonth, this.minDay,\n _exports.local.invalidYear || _exports.regionalOptions[''].invalidYear);\n var year = date.year() + (date.year() < 0 ? 1 : 0); // No year zero\n return year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0);\n },\n\n /** Determine the week of the year for a date - ISO 8601.\n @memberof GregorianCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {number} The week of the year, starting from 1.\n @throws Error if an invalid date or a different calendar used. */\n weekOfYear: function(year, month, day) {\n // Find Thursday of this week starting on Monday\n var checkDate = this.newDate(year, month, day);\n checkDate.add(4 - (checkDate.dayOfWeek() || 7), 'd');\n return Math.floor((checkDate.dayOfYear() - 1) / 7) + 1;\n },\n\n /** Retrieve the number of days in a month.\n @memberof GregorianCalendar\n @param year {CDate|number} The date to examine or the year of the month.\n @param [month] {number} The month.\n @return {number} The number of days in this month.\n @throws Error if an invalid month/year or a different calendar used. */\n daysInMonth: function(year, month) {\n var date = this._validate(year, month, this.minDay,\n _exports.local.invalidMonth || _exports.regionalOptions[''].invalidMonth);\n return this.daysPerMonth[date.month() - 1] +\n (date.month() === 2 && this.leapYear(date.year()) ? 1 : 0);\n },\n\n /** Determine whether this date is a week day.\n @memberof GregorianCalendar\n @param year {CDate|number} The date to examine or the year to examine.\n @param [month] {number} The month to examine.\n @param [day] {number} The day to examine.\n @return {boolean} true if a week day, false if not.\n @throws Error if an invalid date or a different calendar used. */\n weekDay: function(year, month, day) {\n return (this.dayOfWeek(year, month, day) || 7) < 6;\n },\n\n /** Retrieve the Julian date equivalent for this date,\n i.e. days since January 1, 4713 BCE Greenwich noon.\n @memberof GregorianCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {number} The equivalent Julian date.\n @throws Error if an invalid date or a different calendar used. */\n toJD: function(year, month, day) {\n var date = this._validate(year, month, day,\n _exports.local.invalidDate || _exports.regionalOptions[''].invalidDate);\n year = date.year();\n month = date.month();\n day = date.day();\n if (year < 0) { year++; } // No year zero\n // Jean Meeus algorithm, \"Astronomical Algorithms\", 1991\n if (month < 3) {\n month += 12;\n year--;\n }\n var a = Math.floor(year / 100);\n var b = 2 - a + Math.floor(a / 4);\n return Math.floor(365.25 * (year + 4716)) +\n Math.floor(30.6001 * (month + 1)) + day + b - 1524.5;\n },\n\n /** Create a new date from a Julian date.\n @memberof GregorianCalendar\n @param jd {number} The Julian date to convert.\n @return {CDate} The equivalent date. */\n fromJD: function(jd) {\n // Jean Meeus algorithm, \"Astronomical Algorithms\", 1991\n var z = Math.floor(jd + 0.5);\n var a = Math.floor((z - 1867216.25) / 36524.25);\n a = z + 1 + a - Math.floor(a / 4);\n var b = a + 1524;\n var c = Math.floor((b - 122.1) / 365.25);\n var d = Math.floor(365.25 * c);\n var e = Math.floor((b - d) / 30.6001);\n var day = b - d - Math.floor(e * 30.6001);\n var month = e - (e > 13.5 ? 13 : 1);\n var year = c - (month > 2.5 ? 4716 : 4715);\n if (year <= 0) { year--; } // No year zero\n return this.newDate(year, month, day);\n },\n\n /** Convert this date to a standard (Gregorian) JavaScript Date.\n @memberof GregorianCalendar\n @param year {CDate|number} The date to convert or the year to convert.\n @param [month] {number} The month to convert.\n @param [day] {number} The day to convert.\n @return {Date} The equivalent JavaScript date.\n @throws Error if an invalid date or a different calendar used. */\n toJSDate: function(year, month, day) {\n var date = this._validate(year, month, day,\n _exports.local.invalidDate || _exports.regionalOptions[''].invalidDate);\n var jsd = new Date(date.year(), date.month() - 1, date.day());\n jsd.setHours(0);\n jsd.setMinutes(0);\n jsd.setSeconds(0);\n jsd.setMilliseconds(0);\n // Hours may be non-zero on daylight saving cut-over:\n // > 12 when midnight changeover, but then cannot generate\n // midnight datetime, so jump to 1AM, otherwise reset.\n jsd.setHours(jsd.getHours() > 12 ? jsd.getHours() + 2 : 0);\n return jsd;\n },\n\n /** Create a new date from a standard (Gregorian) JavaScript Date.\n @memberof GregorianCalendar\n @param jsd {Date} The JavaScript date to convert.\n @return {CDate} The equivalent date. */\n fromJSDate: function(jsd) {\n return this.newDate(jsd.getFullYear(), jsd.getMonth() + 1, jsd.getDate());\n }\n});\n\n// Singleton manager\nvar _exports = module.exports = new Calendars();\n\n// Date template\n_exports.cdate = CDate;\n\n// Base calendar template\n_exports.baseCalendar = BaseCalendar;\n\n// Gregorian calendar implementation\n_exports.calendars.gregorian = GregorianCalendar;\n\n","/*\n * World Calendars\n * https://github.com/alexcjohnson/world-calendars\n *\n * Batch-converted from kbwood/calendars\n * Many thanks to Keith Wood and all of the contributors to the original project!\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n/* http://keith-wood.name/calendars.html\n Calendars extras for jQuery v2.0.2.\n Written by Keith Wood (wood.keith{at}optusnet.com.au) August 2009.\n Available under the MIT (http://keith-wood.name/licence.html) license. \n Please attribute the author if you use it. */\n\nvar assign = require('object-assign');\nvar main = require('./main');\n\n\nassign(main.regionalOptions[''], {\n invalidArguments: 'Invalid arguments',\n invalidFormat: 'Cannot format a date from another calendar',\n missingNumberAt: 'Missing number at position {0}',\n unknownNameAt: 'Unknown name at position {0}',\n unexpectedLiteralAt: 'Unexpected literal at position {0}',\n unexpectedText: 'Additional text found at end'\n});\nmain.local = main.regionalOptions[''];\n\nassign(main.cdate.prototype, {\n\n /** Format this date.\n Found in the jquery.calendars.plus.js module.\n @memberof CDate\n @param [format] {string} The date format to use (see formatDate).\n @param [settings] {object} Options for the formatDate function.\n @return {string} The formatted date. */\n formatDate: function(format, settings) {\n if (typeof format !== 'string') {\n settings = format;\n format = '';\n }\n return this._calendar.formatDate(format || '', this, settings);\n }\n});\n\nassign(main.baseCalendar.prototype, {\n\n UNIX_EPOCH: main.instance().newDate(1970, 1, 1).toJD(),\n SECS_PER_DAY: 24 * 60 * 60,\n TICKS_EPOCH: main.instance().jdEpoch, // 1 January 0001 CE\n TICKS_PER_DAY: 24 * 60 * 60 * 10000000,\n\n /** Date form for ATOM (RFC 3339/ISO 8601).\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar */\n ATOM: 'yyyy-mm-dd',\n /** Date form for cookies.\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar */\n COOKIE: 'D, dd M yyyy',\n /** Date form for full date.\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar */\n FULL: 'DD, MM d, yyyy',\n /** Date form for ISO 8601.\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar */\n ISO_8601: 'yyyy-mm-dd',\n /** Date form for Julian date.\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar */\n JULIAN: 'J',\n /** Date form for RFC 822.\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar */\n RFC_822: 'D, d M yy',\n /** Date form for RFC 850.\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar */\n RFC_850: 'DD, dd-M-yy',\n /** Date form for RFC 1036.\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar */\n RFC_1036: 'D, d M yy',\n /** Date form for RFC 1123.\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar */\n RFC_1123: 'D, d M yyyy',\n /** Date form for RFC 2822.\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar */\n RFC_2822: 'D, d M yyyy',\n /** Date form for RSS (RFC 822).\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar */\n RSS: 'D, d M yy',\n /** Date form for Windows ticks.\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar */\n TICKS: '!',\n /** Date form for Unix timestamp.\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar */\n TIMESTAMP: '@',\n /** Date form for W3c (ISO 8601).\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar */\n W3C: 'yyyy-mm-dd',\n\n /** Format a date object into a string value.\n The format can be combinations of the following:\n
    \n
  • d - day of month (no leading zero)
  • \n
  • dd - day of month (two digit)
  • \n
  • o - day of year (no leading zeros)
  • \n
  • oo - day of year (three digit)
  • \n
  • D - day name short
  • \n
  • DD - day name long
  • \n
  • w - week of year (no leading zero)
  • \n
  • ww - week of year (two digit)
  • \n
  • m - month of year (no leading zero)
  • \n
  • mm - month of year (two digit)
  • \n
  • M - month name short
  • \n
  • MM - month name long
  • \n
  • yy - year (two digit)
  • \n
  • yyyy - year (four digit)
  • \n
  • YYYY - formatted year
  • \n
  • J - Julian date (days since January 1, 4713 BCE Greenwich noon)
  • \n
  • @ - Unix timestamp (s since 01/01/1970)
  • \n
  • ! - Windows ticks (100ns since 01/01/0001)
  • \n
  • '...' - literal text
  • \n
  • '' - single quote
  • \n
\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar\n @param [format] {string} The desired format of the date (defaults to calendar format).\n @param date {CDate} The date value to format.\n @param [settings] {object} Addition options, whose attributes include:\n @property [dayNamesShort] {string[]} Abbreviated names of the days from Sunday.\n @property [dayNames] {string[]} Names of the days from Sunday.\n @property [monthNamesShort] {string[]} Abbreviated names of the months.\n @property [monthNames] {string[]} Names of the months.\n @property [calculateWeek] {CalendarsPickerCalculateWeek} Function that determines week of the year.\n @property [localNumbers=false] {boolean} true to localise numbers (if available),\n false to use normal Arabic numerals.\n @return {string} The date in the above format.\n @throws Errors if the date is from a different calendar. */\n formatDate: function(format, date, settings) {\n if (typeof format !== 'string') {\n settings = date;\n date = format;\n format = '';\n }\n if (!date) {\n return '';\n }\n if (date.calendar() !== this) {\n throw main.local.invalidFormat || main.regionalOptions[''].invalidFormat;\n }\n format = format || this.local.dateFormat;\n settings = settings || {};\n var dayNamesShort = settings.dayNamesShort || this.local.dayNamesShort;\n var dayNames = settings.dayNames || this.local.dayNames;\n var monthNumbers = settings.monthNumbers || this.local.monthNumbers;\n var monthNamesShort = settings.monthNamesShort || this.local.monthNamesShort;\n var monthNames = settings.monthNames || this.local.monthNames;\n var calculateWeek = settings.calculateWeek || this.local.calculateWeek;\n // Check whether a format character is doubled\n var doubled = function(match, step) {\n var matches = 1;\n while (iFormat + matches < format.length && format.charAt(iFormat + matches) === match) {\n matches++;\n }\n iFormat += matches - 1;\n return Math.floor(matches / (step || 1)) > 1;\n };\n // Format a number, with leading zeroes if necessary\n var formatNumber = function(match, value, len, step) {\n var num = '' + value;\n if (doubled(match, step)) {\n while (num.length < len) {\n num = '0' + num;\n }\n }\n return num;\n };\n // Format a name, short or long as requested\n var formatName = function(match, value, shortNames, longNames) {\n return (doubled(match) ? longNames[value] : shortNames[value]);\n };\n // Format month number\n // (e.g. Chinese calendar needs to account for intercalary months)\n var calendar = this;\n var formatMonth = function(date) {\n return (typeof monthNumbers === 'function') ?\n monthNumbers.call(calendar, date, doubled('m')) :\n localiseNumbers(formatNumber('m', date.month(), 2));\n };\n // Format a month name, short or long as requested\n var formatMonthName = function(date, useLongName) {\n if (useLongName) {\n return (typeof monthNames === 'function') ?\n monthNames.call(calendar, date) :\n monthNames[date.month() - calendar.minMonth];\n } else {\n return (typeof monthNamesShort === 'function') ?\n monthNamesShort.call(calendar, date) :\n monthNamesShort[date.month() - calendar.minMonth];\n }\n };\n // Localise numbers if requested and available\n var digits = this.local.digits;\n var localiseNumbers = function(value) {\n return (settings.localNumbers && digits ? digits(value) : value);\n };\n var output = '';\n var literal = false;\n for (var iFormat = 0; iFormat < format.length; iFormat++) {\n if (literal) {\n if (format.charAt(iFormat) === \"'\" && !doubled(\"'\")) {\n literal = false;\n }\n else {\n output += format.charAt(iFormat);\n }\n }\n else {\n switch (format.charAt(iFormat)) {\n case 'd': output += localiseNumbers(formatNumber('d', date.day(), 2)); break;\n case 'D': output += formatName('D', date.dayOfWeek(),\n dayNamesShort, dayNames); break;\n case 'o': output += formatNumber('o', date.dayOfYear(), 3); break;\n case 'w': output += formatNumber('w', date.weekOfYear(), 2); break;\n case 'm': output += formatMonth(date); break;\n case 'M': output += formatMonthName(date, doubled('M')); break;\n case 'y':\n output += (doubled('y', 2) ? date.year() :\n (date.year() % 100 < 10 ? '0' : '') + date.year() % 100);\n break;\n case 'Y':\n doubled('Y', 2);\n output += date.formatYear();\n break;\n case 'J': output += date.toJD(); break;\n case '@': output += (date.toJD() - this.UNIX_EPOCH) * this.SECS_PER_DAY; break;\n case '!': output += (date.toJD() - this.TICKS_EPOCH) * this.TICKS_PER_DAY; break;\n case \"'\":\n if (doubled(\"'\")) {\n output += \"'\";\n }\n else {\n literal = true;\n }\n break;\n default:\n output += format.charAt(iFormat);\n }\n }\n }\n return output;\n },\n\n /** Parse a string value into a date object.\n See formatDate for the possible formats, plus:\n
    \n
  • * - ignore rest of string
  • \n
\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar\n @param format {string} The expected format of the date ('' for default calendar format).\n @param value {string} The date in the above format.\n @param [settings] {object} Additional options whose attributes include:\n @property [shortYearCutoff] {number} The cutoff year for determining the century.\n @property [dayNamesShort] {string[]} Abbreviated names of the days from Sunday.\n @property [dayNames] {string[]} Names of the days from Sunday.\n @property [monthNamesShort] {string[]} Abbreviated names of the months.\n @property [monthNames] {string[]} Names of the months.\n @return {CDate} The extracted date value or null if value is blank.\n @throws Errors if the format and/or value are missing,\n if the value doesn't match the format, or if the date is invalid. */\n parseDate: function(format, value, settings) {\n if (value == null) {\n throw main.local.invalidArguments || main.regionalOptions[''].invalidArguments;\n }\n value = (typeof value === 'object' ? value.toString() : value + '');\n if (value === '') {\n return null;\n }\n format = format || this.local.dateFormat;\n settings = settings || {};\n var shortYearCutoff = settings.shortYearCutoff || this.shortYearCutoff;\n shortYearCutoff = (typeof shortYearCutoff !== 'string' ? shortYearCutoff :\n this.today().year() % 100 + parseInt(shortYearCutoff, 10));\n var dayNamesShort = settings.dayNamesShort || this.local.dayNamesShort;\n var dayNames = settings.dayNames || this.local.dayNames;\n var parseMonth = settings.parseMonth || this.local.parseMonth;\n var monthNumbers = settings.monthNumbers || this.local.monthNumbers;\n var monthNamesShort = settings.monthNamesShort || this.local.monthNamesShort;\n var monthNames = settings.monthNames || this.local.monthNames;\n var jd = -1;\n var year = -1;\n var month = -1;\n var day = -1;\n var doy = -1;\n var shortYear = false;\n var literal = false;\n // Check whether a format character is doubled\n var doubled = function(match, step) {\n var matches = 1;\n while (iFormat + matches < format.length && format.charAt(iFormat + matches) === match) {\n matches++;\n }\n iFormat += matches - 1;\n return Math.floor(matches / (step || 1)) > 1;\n };\n // Extract a number from the string value\n var getNumber = function(match, step) {\n var isDoubled = doubled(match, step);\n var size = [2, 3, isDoubled ? 4 : 2, isDoubled ? 4 : 2, 10, 11, 20]['oyYJ@!'.indexOf(match) + 1];\n var digits = new RegExp('^-?\\\\d{1,' + size + '}');\n var num = value.substring(iValue).match(digits);\n if (!num) {\n throw (main.local.missingNumberAt || main.regionalOptions[''].missingNumberAt).\n replace(/\\{0\\}/, iValue);\n }\n iValue += num[0].length;\n return parseInt(num[0], 10);\n };\n // Extract a month number from the string value\n var calendar = this;\n var getMonthNumber = function() {\n if (typeof monthNumbers === 'function') {\n doubled('m'); // update iFormat\n var month = monthNumbers.call(calendar, value.substring(iValue));\n iValue += month.length;\n return month;\n }\n\n return getNumber('m');\n };\n // Extract a name from the string value and convert to an index\n var getName = function(match, shortNames, longNames, step) {\n var names = (doubled(match, step) ? longNames : shortNames);\n for (var i = 0; i < names.length; i++) {\n if (value.substr(iValue, names[i].length).toLowerCase() === names[i].toLowerCase()) {\n iValue += names[i].length;\n return i + calendar.minMonth;\n }\n }\n throw (main.local.unknownNameAt || main.regionalOptions[''].unknownNameAt).\n replace(/\\{0\\}/, iValue);\n };\n // Extract a month number from the string value\n var getMonthName = function() {\n if (typeof monthNames === 'function') {\n var month = doubled('M') ?\n monthNames.call(calendar, value.substring(iValue)) :\n monthNamesShort.call(calendar, value.substring(iValue));\n iValue += month.length;\n return month;\n }\n\n return getName('M', monthNamesShort, monthNames);\n };\n // Confirm that a literal character matches the string value\n var checkLiteral = function() {\n if (value.charAt(iValue) !== format.charAt(iFormat)) {\n throw (main.local.unexpectedLiteralAt ||\n main.regionalOptions[''].unexpectedLiteralAt).replace(/\\{0\\}/, iValue);\n }\n iValue++;\n };\n var iValue = 0;\n for (var iFormat = 0; iFormat < format.length; iFormat++) {\n if (literal) {\n if (format.charAt(iFormat) === \"'\" && !doubled(\"'\")) {\n literal = false;\n }\n else {\n checkLiteral();\n }\n }\n else {\n switch (format.charAt(iFormat)) {\n case 'd': day = getNumber('d'); break;\n case 'D': getName('D', dayNamesShort, dayNames); break;\n case 'o': doy = getNumber('o'); break;\n case 'w': getNumber('w'); break;\n case 'm': month = getMonthNumber(); break;\n case 'M': month = getMonthName(); break;\n case 'y':\n var iSave = iFormat;\n shortYear = !doubled('y', 2);\n iFormat = iSave;\n year = getNumber('y', 2);\n break;\n case 'Y': year = getNumber('Y', 2); break;\n case 'J':\n jd = getNumber('J') + 0.5;\n if (value.charAt(iValue) === '.') {\n iValue++;\n getNumber('J');\n }\n break;\n case '@': jd = getNumber('@') / this.SECS_PER_DAY + this.UNIX_EPOCH; break;\n case '!': jd = getNumber('!') / this.TICKS_PER_DAY + this.TICKS_EPOCH; break;\n case '*': iValue = value.length; break;\n case \"'\":\n if (doubled(\"'\")) {\n checkLiteral();\n }\n else {\n literal = true;\n }\n break;\n default: checkLiteral();\n }\n }\n }\n if (iValue < value.length) {\n throw main.local.unexpectedText || main.regionalOptions[''].unexpectedText;\n }\n if (year === -1) {\n year = this.today().year();\n }\n else if (year < 100 && shortYear) {\n year += (shortYearCutoff === -1 ? 1900 : this.today().year() -\n this.today().year() % 100 - (year <= shortYearCutoff ? 0 : 100));\n }\n if (typeof month === 'string') {\n month = parseMonth.call(this, year, month);\n }\n if (doy > -1) {\n month = 1;\n day = doy;\n for (var dim = this.daysInMonth(year, month); day > dim; dim = this.daysInMonth(year, month)) {\n month++;\n day -= dim;\n }\n }\n return (jd > -1 ? this.fromJD(jd) : this.newDate(year, month, day));\n },\n\n /** A date may be specified as an exact value or a relative one.\n Found in the jquery.calendars.plus.js module.\n @memberof BaseCalendar\n @param dateSpec {CDate|number|string} The date as an object or string in the given format or\n an offset - numeric days from today, or string amounts and periods, e.g. '+1m +2w'.\n @param defaultDate {CDate} The date to use if no other supplied, may be null.\n @param currentDate {CDate} The current date as a possible basis for relative dates,\n if null today is used (optional)\n @param [dateFormat] {string} The expected date format - see formatDate.\n @param [settings] {object} Additional options whose attributes include:\n @property [shortYearCutoff] {number} The cutoff year for determining the century.\n @property [dayNamesShort] {string[]} Abbreviated names of the days from Sunday.\n @property [dayNames] {string[]} Names of the days from Sunday.\n @property [monthNamesShort] {string[]} Abbreviated names of the months.\n @property [monthNames] {string[]} Names of the months.\n @return {CDate} The decoded date. */\n determineDate: function(dateSpec, defaultDate, currentDate, dateFormat, settings) {\n if (currentDate && typeof currentDate !== 'object') {\n settings = dateFormat;\n dateFormat = currentDate;\n currentDate = null;\n }\n if (typeof dateFormat !== 'string') {\n settings = dateFormat;\n dateFormat = '';\n }\n var calendar = this;\n var offsetString = function(offset) {\n try {\n return calendar.parseDate(dateFormat, offset, settings);\n }\n catch (e) {\n // Ignore\n }\n offset = offset.toLowerCase();\n var date = (offset.match(/^c/) && currentDate ?\n currentDate.newDate() : null) || calendar.today();\n var pattern = /([+-]?[0-9]+)\\s*(d|w|m|y)?/g;\n var matches = pattern.exec(offset);\n while (matches) {\n date.add(parseInt(matches[1], 10), matches[2] || 'd');\n matches = pattern.exec(offset);\n }\n return date;\n };\n defaultDate = (defaultDate ? defaultDate.newDate() : null);\n dateSpec = (dateSpec == null ? defaultDate :\n (typeof dateSpec === 'string' ? offsetString(dateSpec) : (typeof dateSpec === 'number' ?\n (isNaN(dateSpec) || dateSpec === Infinity || dateSpec === -Infinity ? defaultDate :\n calendar.today().add(dateSpec, 'd')) : calendar.newDate(dateSpec))));\n return dateSpec;\n }\n});\n\n","// extracted by mini-css-extract-plugin\nexport default {};","function _extends() {\n return module.exports = _extends = Object.assign ? Object.assign.bind() : function (n) {\n for (var e = 1; e < arguments.length; e++) {\n var t = arguments[e];\n for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]);\n }\n return n;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports, _extends.apply(null, arguments);\n}\nmodule.exports = _extends, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _interopRequireDefault(e) {\n return e && e.__esModule ? e : {\n \"default\": e\n };\n}\nmodule.exports = _interopRequireDefault, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _objectWithoutPropertiesLoose(r, e) {\n if (null == r) return {};\n var t = {};\n for (var n in r) if ({}.hasOwnProperty.call(r, n)) {\n if (e.includes(n)) continue;\n t[n] = r[n];\n }\n return t;\n}\nmodule.exports = _objectWithoutPropertiesLoose, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","'use strict';\n\nvar possibleNames = require('possible-typed-array-names');\n\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\n\n/** @type {import('.')} */\nmodule.exports = function availableTypedArrays() {\n\tvar /** @type {ReturnType} */ out = [];\n\tfor (var i = 0; i < possibleNames.length; i++) {\n\t\tif (typeof g[possibleNames[i]] === 'function') {\n\t\t\t// @ts-expect-error\n\t\t\tout[out.length] = possibleNames[i];\n\t\t}\n\t}\n\treturn out;\n};\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n};\r\n","'use strict';\n\nmodule.exports = Point;\n\n/**\n * A standalone point geometry with useful accessor, comparison, and\n * modification methods.\n *\n * @class Point\n * @param {Number} x the x-coordinate. this could be longitude or screen\n * pixels, or any other sort of unit.\n * @param {Number} y the y-coordinate. this could be latitude or screen\n * pixels, or any other sort of unit.\n * @example\n * var point = new Point(-77, 38);\n */\nfunction Point(x, y) {\n this.x = x;\n this.y = y;\n}\n\nPoint.prototype = {\n\n /**\n * Clone this point, returning a new point that can be modified\n * without affecting the old one.\n * @return {Point} the clone\n */\n clone: function() { return new Point(this.x, this.y); },\n\n /**\n * Add this point's x & y coordinates to another point,\n * yielding a new point.\n * @param {Point} p the other point\n * @return {Point} output point\n */\n add: function(p) { return this.clone()._add(p); },\n\n /**\n * Subtract this point's x & y coordinates to from point,\n * yielding a new point.\n * @param {Point} p the other point\n * @return {Point} output point\n */\n sub: function(p) { return this.clone()._sub(p); },\n\n /**\n * Multiply this point's x & y coordinates by point,\n * yielding a new point.\n * @param {Point} p the other point\n * @return {Point} output point\n */\n multByPoint: function(p) { return this.clone()._multByPoint(p); },\n\n /**\n * Divide this point's x & y coordinates by point,\n * yielding a new point.\n * @param {Point} p the other point\n * @return {Point} output point\n */\n divByPoint: function(p) { return this.clone()._divByPoint(p); },\n\n /**\n * Multiply this point's x & y coordinates by a factor,\n * yielding a new point.\n * @param {Point} k factor\n * @return {Point} output point\n */\n mult: function(k) { return this.clone()._mult(k); },\n\n /**\n * Divide this point's x & y coordinates by a factor,\n * yielding a new point.\n * @param {Point} k factor\n * @return {Point} output point\n */\n div: function(k) { return this.clone()._div(k); },\n\n /**\n * Rotate this point around the 0, 0 origin by an angle a,\n * given in radians\n * @param {Number} a angle to rotate around, in radians\n * @return {Point} output point\n */\n rotate: function(a) { return this.clone()._rotate(a); },\n\n /**\n * Rotate this point around p point by an angle a,\n * given in radians\n * @param {Number} a angle to rotate around, in radians\n * @param {Point} p Point to rotate around\n * @return {Point} output point\n */\n rotateAround: function(a,p) { return this.clone()._rotateAround(a,p); },\n\n /**\n * Multiply this point by a 4x1 transformation matrix\n * @param {Array} m transformation matrix\n * @return {Point} output point\n */\n matMult: function(m) { return this.clone()._matMult(m); },\n\n /**\n * Calculate this point but as a unit vector from 0, 0, meaning\n * that the distance from the resulting point to the 0, 0\n * coordinate will be equal to 1 and the angle from the resulting\n * point to the 0, 0 coordinate will be the same as before.\n * @return {Point} unit vector point\n */\n unit: function() { return this.clone()._unit(); },\n\n /**\n * Compute a perpendicular point, where the new y coordinate\n * is the old x coordinate and the new x coordinate is the old y\n * coordinate multiplied by -1\n * @return {Point} perpendicular point\n */\n perp: function() { return this.clone()._perp(); },\n\n /**\n * Return a version of this point with the x & y coordinates\n * rounded to integers.\n * @return {Point} rounded point\n */\n round: function() { return this.clone()._round(); },\n\n /**\n * Return the magitude of this point: this is the Euclidean\n * distance from the 0, 0 coordinate to this point's x and y\n * coordinates.\n * @return {Number} magnitude\n */\n mag: function() {\n return Math.sqrt(this.x * this.x + this.y * this.y);\n },\n\n /**\n * Judge whether this point is equal to another point, returning\n * true or false.\n * @param {Point} other the other point\n * @return {boolean} whether the points are equal\n */\n equals: function(other) {\n return this.x === other.x &&\n this.y === other.y;\n },\n\n /**\n * Calculate the distance from this point to another point\n * @param {Point} p the other point\n * @return {Number} distance\n */\n dist: function(p) {\n return Math.sqrt(this.distSqr(p));\n },\n\n /**\n * Calculate the distance from this point to another point,\n * without the square root step. Useful if you're comparing\n * relative distances.\n * @param {Point} p the other point\n * @return {Number} distance\n */\n distSqr: function(p) {\n var dx = p.x - this.x,\n dy = p.y - this.y;\n return dx * dx + dy * dy;\n },\n\n /**\n * Get the angle from the 0, 0 coordinate to this point, in radians\n * coordinates.\n * @return {Number} angle\n */\n angle: function() {\n return Math.atan2(this.y, this.x);\n },\n\n /**\n * Get the angle from this point to another point, in radians\n * @param {Point} b the other point\n * @return {Number} angle\n */\n angleTo: function(b) {\n return Math.atan2(this.y - b.y, this.x - b.x);\n },\n\n /**\n * Get the angle between this point and another point, in radians\n * @param {Point} b the other point\n * @return {Number} angle\n */\n angleWith: function(b) {\n return this.angleWithSep(b.x, b.y);\n },\n\n /*\n * Find the angle of the two vectors, solving the formula for\n * the cross product a x b = |a||b|sin(θ) for θ.\n * @param {Number} x the x-coordinate\n * @param {Number} y the y-coordinate\n * @return {Number} the angle in radians\n */\n angleWithSep: function(x, y) {\n return Math.atan2(\n this.x * y - this.y * x,\n this.x * x + this.y * y);\n },\n\n _matMult: function(m) {\n var x = m[0] * this.x + m[1] * this.y,\n y = m[2] * this.x + m[3] * this.y;\n this.x = x;\n this.y = y;\n return this;\n },\n\n _add: function(p) {\n this.x += p.x;\n this.y += p.y;\n return this;\n },\n\n _sub: function(p) {\n this.x -= p.x;\n this.y -= p.y;\n return this;\n },\n\n _mult: function(k) {\n this.x *= k;\n this.y *= k;\n return this;\n },\n\n _div: function(k) {\n this.x /= k;\n this.y /= k;\n return this;\n },\n\n _multByPoint: function(p) {\n this.x *= p.x;\n this.y *= p.y;\n return this;\n },\n\n _divByPoint: function(p) {\n this.x /= p.x;\n this.y /= p.y;\n return this;\n },\n\n _unit: function() {\n this._div(this.mag());\n return this;\n },\n\n _perp: function() {\n var y = this.y;\n this.y = this.x;\n this.x = -y;\n return this;\n },\n\n _rotate: function(angle) {\n var cos = Math.cos(angle),\n sin = Math.sin(angle),\n x = cos * this.x - sin * this.y,\n y = sin * this.x + cos * this.y;\n this.x = x;\n this.y = y;\n return this;\n },\n\n _rotateAround: function(angle, p) {\n var cos = Math.cos(angle),\n sin = Math.sin(angle),\n x = p.x + cos * (this.x - p.x) - sin * (this.y - p.y),\n y = p.y + sin * (this.x - p.x) + cos * (this.y - p.y);\n this.x = x;\n this.y = y;\n return this;\n },\n\n _round: function() {\n this.x = Math.round(this.x);\n this.y = Math.round(this.y);\n return this;\n }\n};\n\n/**\n * Construct a point from an array if necessary, otherwise if the input\n * is already a Point, or an unknown type, return it unchanged\n * @param {Array|Point|*} a any kind of input value\n * @return {Point} constructed point, or passed-through value.\n * @example\n * // this\n * var point = Point.convert([0, 1]);\n * // is equivalent to\n * var point = new Point(0, 1);\n */\nPoint.convert = function (a) {\n if (a instanceof Point) {\n return a;\n }\n if (Array.isArray(a)) {\n return new Point(a[0], a[1]);\n }\n return a;\n};\n","'use strict';\n\nmodule.exports = UnitBezier;\n\nfunction UnitBezier(p1x, p1y, p2x, p2y) {\n // Calculate the polynomial coefficients, implicit first and last control points are (0,0) and (1,1).\n this.cx = 3.0 * p1x;\n this.bx = 3.0 * (p2x - p1x) - this.cx;\n this.ax = 1.0 - this.cx - this.bx;\n\n this.cy = 3.0 * p1y;\n this.by = 3.0 * (p2y - p1y) - this.cy;\n this.ay = 1.0 - this.cy - this.by;\n\n this.p1x = p1x;\n this.p1y = p1y;\n this.p2x = p2x;\n this.p2y = p2y;\n}\n\nUnitBezier.prototype = {\n sampleCurveX: function (t) {\n // `ax t^3 + bx t^2 + cx t' expanded using Horner's rule.\n return ((this.ax * t + this.bx) * t + this.cx) * t;\n },\n\n sampleCurveY: function (t) {\n return ((this.ay * t + this.by) * t + this.cy) * t;\n },\n\n sampleCurveDerivativeX: function (t) {\n return (3.0 * this.ax * t + 2.0 * this.bx) * t + this.cx;\n },\n\n solveCurveX: function (x, epsilon) {\n if (epsilon === undefined) epsilon = 1e-6;\n\n if (x < 0.0) return 0.0;\n if (x > 1.0) return 1.0;\n\n var t = x;\n\n // First try a few iterations of Newton's method - normally very fast.\n for (var i = 0; i < 8; i++) {\n var x2 = this.sampleCurveX(t) - x;\n if (Math.abs(x2) < epsilon) return t;\n\n var d2 = this.sampleCurveDerivativeX(t);\n if (Math.abs(d2) < 1e-6) break;\n\n t = t - x2 / d2;\n }\n\n // Fall back to the bisection method for reliability.\n var t0 = 0.0;\n var t1 = 1.0;\n t = x;\n\n for (i = 0; i < 20; i++) {\n x2 = this.sampleCurveX(t);\n if (Math.abs(x2 - x) < epsilon) break;\n\n if (x > x2) {\n t0 = t;\n } else {\n t1 = t;\n }\n\n t = (t1 - t0) * 0.5 + t0;\n }\n\n return t;\n },\n\n solve: function (x, epsilon) {\n return this.sampleCurveY(this.solveCurveX(x, epsilon));\n }\n};\n","let supportsOffscreenCanvas: boolean;\n\nexport function offscreenCanvasSupported(): boolean {\n if (supportsOffscreenCanvas == null) {\n supportsOffscreenCanvas = typeof OffscreenCanvas !== 'undefined' &&\n new OffscreenCanvas(1, 1).getContext('2d') &&\n typeof createImageBitmap === 'function';\n }\n\n return supportsOffscreenCanvas;\n}\n","import {offscreenCanvasSupported} from './offscreen_canvas_supported';\n\nlet offscreenCanvasDistorted: boolean;\n\n/**\n * Some browsers don't return the exact pixels from a canvas to prevent user fingerprinting (see #3185).\n * This function writes pixels to an OffscreenCanvas and reads them back using getImageData, returning false\n * if they don't match.\n *\n * @returns true if the browser supports OffscreenCanvas but it distorts getImageData results, false otherwise.\n */\nexport function isOffscreenCanvasDistorted(): boolean {\n if (offscreenCanvasDistorted == null) {\n offscreenCanvasDistorted = false;\n if (offscreenCanvasSupported()) {\n const size = 5;\n const canvas = new OffscreenCanvas(size, size);\n const context = canvas.getContext('2d', {willReadFrequently: true});\n if (context) {\n // fill each pixel with an RGB value that should make the byte at index i equal to i (except alpha channel):\n // [0, 1, 2, 255, 4, 5, 6, 255, 8, 9, 10, 255, ...]\n for (let i = 0; i < size * size; i++) {\n const base = i * 4;\n context.fillStyle = `rgb(${base},${base + 1},${base + 2})`;\n context.fillRect(i % size, Math.floor(i / size), 1, 1);\n }\n const data = context.getImageData(0, 0, size, size).data;\n for (let i = 0; i < size * size * 4; i++) {\n if (i % 4 !== 3 && data[i] !== i) {\n offscreenCanvasDistorted = true;\n break;\n }\n }\n }\n }\n }\n\n return offscreenCanvasDistorted || false;\n}\n","import Point from '@mapbox/point-geometry';\nimport UnitBezier from '@mapbox/unitbezier';\nimport {isOffscreenCanvasDistorted} from './offscreen_canvas_distorted';\nimport type {Size} from './image';\nimport type {WorkerGlobalScopeInterface} from './web_worker';\n\n/**\n * For a given collection of 2D points, returns their axis-aligned bounding box,\n * in the format [minX, minY, maxX, maxY].\n */\nexport function getAABB(points: Array): [number, number, number, number] {\n let tlX = Infinity;\n let tlY = Infinity;\n let brX = -Infinity;\n let brY = -Infinity;\n\n for (const p of points) {\n tlX = Math.min(tlX, p.x);\n tlY = Math.min(tlY, p.y);\n brX = Math.max(brX, p.x);\n brY = Math.max(brY, p.y);\n }\n\n return [tlX, tlY, brX, brY];\n}\n\n/**\n * Given a value `t` that varies between 0 and 1, return\n * an interpolation function that eases between 0 and 1 in a pleasing\n * cubic in-out fashion.\n */\nexport function easeCubicInOut(t: number): number {\n if (t <= 0) return 0;\n if (t >= 1) return 1;\n const t2 = t * t,\n t3 = t2 * t;\n return 4 * (t < 0.5 ? t3 : 3 * (t - t2) + t3 - 0.75);\n}\n\n/**\n * Given given (x, y), (x1, y1) control points for a bezier curve,\n * return a function that interpolates along that curve.\n *\n * @param p1x - control point 1 x coordinate\n * @param p1y - control point 1 y coordinate\n * @param p2x - control point 2 x coordinate\n * @param p2y - control point 2 y coordinate\n */\nexport function bezier(p1x: number, p1y: number, p2x: number, p2y: number): (t: number) => number {\n const bezier = new UnitBezier(p1x, p1y, p2x, p2y);\n return (t: number) => {\n return bezier.solve(t);\n };\n}\n\n/**\n * A default bezier-curve powered easing function with\n * control points (0.25, 0.1) and (0.25, 1)\n */\nexport const defaultEasing = bezier(0.25, 0.1, 0.25, 1);\n\n/**\n * constrain n to the given range via min + max\n *\n * @param n - value\n * @param min - the minimum value to be returned\n * @param max - the maximum value to be returned\n * @returns the clamped value\n */\nexport function clamp(n: number, min: number, max: number): number {\n return Math.min(max, Math.max(min, n));\n}\n\n/**\n * constrain n to the given range, excluding the minimum, via modular arithmetic\n *\n * @param n - value\n * @param min - the minimum value to be returned, exclusive\n * @param max - the maximum value to be returned, inclusive\n * @returns constrained number\n */\nexport function wrap(n: number, min: number, max: number): number {\n const d = max - min;\n const w = ((n - min) % d + d) % d + min;\n return (w === min) ? max : w;\n}\n\n/**\n * Compute the difference between the keys in one object and the keys\n * in another object.\n *\n * @returns keys difference\n */\nexport function keysDifference(\n obj: {[key: string]: S},\n other: {[key: string]: T}\n): Array {\n const difference = [];\n for (const i in obj) {\n if (!(i in other)) {\n difference.push(i);\n }\n }\n return difference;\n}\n\n/**\n * Given a destination object and optionally many source objects,\n * copy all properties from the source objects into the destination.\n * The last source object given overrides properties from previous\n * source objects.\n *\n * @param dest - destination object\n * @param sources - sources from which properties are pulled\n */\nexport function extend(dest: T, source: U): T & U;\nexport function extend(dest: T, source1: U, source2: V): T & U & V;\nexport function extend(dest: T, source1: U, source2: V, source3: W): T & U & V & W;\nexport function extend(dest: object, ...sources: Array): any;\nexport function extend(dest: object, ...sources: Array): any {\n for (const src of sources) {\n for (const k in src) {\n dest[k] = src[k];\n }\n }\n return dest;\n}\n\n// See https://stackoverflow.com/questions/49401866/all-possible-keys-of-an-union-type\ntype KeysOfUnion = T extends T ? keyof T: never;\n\n/**\n * Given an object and a number of properties as strings, return version\n * of that object with only those properties.\n *\n * @param src - the object\n * @param properties - an array of property names chosen\n * to appear on the resulting object.\n * @returns object with limited properties.\n * @example\n * ```ts\n * let foo = { name: 'Charlie', age: 10 };\n * let justName = pick(foo, ['name']); // justName = { name: 'Charlie' }\n * ```\n */\nexport function pick(src: T, properties: Array>): Partial {\n const result: Partial = {};\n for (let i = 0; i < properties.length; i++) {\n const k = properties[i];\n if (k in src) {\n result[k] = src[k];\n }\n }\n return result;\n}\n\nlet id = 1;\n\n/**\n * Return a unique numeric id, starting at 1 and incrementing with\n * each call.\n *\n * @returns unique numeric id.\n */\nexport function uniqueId(): number {\n return id++;\n}\n\n/**\n * Return whether a given value is a power of two\n */\nexport function isPowerOfTwo(value: number): boolean {\n return (Math.log(value) / Math.LN2) % 1 === 0;\n}\n\n/**\n * Return the next power of two, or the input value if already a power of two\n */\nexport function nextPowerOfTwo(value: number): number {\n if (value <= 1) return 1;\n return Math.pow(2, Math.ceil(Math.log(value) / Math.LN2));\n}\n\n/**\n * Create an object by mapping all the values of an existing object while\n * preserving their keys.\n */\nexport function mapObject(input: any, iterator: Function, context?: any): any {\n const output = {};\n for (const key in input) {\n output[key] = iterator.call(context || this, input[key], key, input);\n }\n return output;\n}\n\n/**\n * Create an object by filtering out values of an existing object.\n */\nexport function filterObject(input: any, iterator: Function, context?: any): any {\n const output = {};\n for (const key in input) {\n if (iterator.call(context || this, input[key], key, input)) {\n output[key] = input[key];\n }\n }\n return output;\n}\n\n/**\n * Deeply compares two object literals.\n * @param a - first object literal to be compared\n * @param b - second object literal to be compared\n * @returns true if the two object literals are deeply equal, false otherwise\n */\nexport function deepEqual(a?: unknown | null, b?: unknown | null): boolean {\n if (Array.isArray(a)) {\n if (!Array.isArray(b) || a.length !== b.length) return false;\n for (let i = 0; i < a.length; i++) {\n if (!deepEqual(a[i], b[i])) return false;\n }\n return true;\n }\n if (typeof a === 'object' && a !== null && b !== null) {\n if (!(typeof b === 'object')) return false;\n const keys = Object.keys(a);\n if (keys.length !== Object.keys(b).length) return false;\n for (const key in a) {\n if (!deepEqual(a[key], b[key])) return false;\n }\n return true;\n }\n return a === b;\n}\n\n/**\n * Deeply clones two objects.\n */\nexport function clone(input: T): T {\n if (Array.isArray(input)) {\n return input.map(clone) as any as T;\n } else if (typeof input === 'object' && input) {\n return mapObject(input, clone) as any as T;\n } else {\n return input;\n }\n}\n\n/**\n * Check if two arrays have at least one common element.\n */\nexport function arraysIntersect(a: Array, b: Array): boolean {\n for (let l = 0; l < a.length; l++) {\n if (b.indexOf(a[l]) >= 0) return true;\n }\n return false;\n}\n\n/**\n * Print a warning message to the console and ensure duplicate warning messages\n * are not printed.\n */\nconst warnOnceHistory: {[key: string]: boolean} = {};\n\nexport function warnOnce(message: string): void {\n if (!warnOnceHistory[message]) {\n // console isn't defined in some WebWorkers, see #2558\n if (typeof console !== 'undefined') console.warn(message);\n warnOnceHistory[message] = true;\n }\n}\n\n/**\n * Indicates if the provided Points are in a counter clockwise (true) or clockwise (false) order\n *\n * @returns true for a counter clockwise set of points\n */\n// https://bryceboe.com/2006/10/23/line-segment-intersection-algorithm/\nexport function isCounterClockwise(a: Point, b: Point, c: Point): boolean {\n return (c.y - a.y) * (b.x - a.x) > (b.y - a.y) * (c.x - a.x);\n}\n\n/**\n * For two lines a and b in 2d space, defined by any two points along the lines,\n * find the intersection point, or return null if the lines are parallel\n *\n * @param a1 - First point on line a\n * @param a2 - Second point on line a\n * @param b1 - First point on line b\n * @param b2 - Second point on line b\n *\n * @returns the intersection point of the two lines or null if they are parallel\n */\nexport function findLineIntersection(a1: Point, a2: Point, b1: Point, b2: Point): Point | null {\n const aDeltaY = a2.y - a1.y;\n const aDeltaX = a2.x - a1.x;\n const bDeltaY = b2.y - b1.y;\n const bDeltaX = b2.x - b1.x;\n\n const denominator = (bDeltaY * aDeltaX) - (bDeltaX * aDeltaY);\n\n if (denominator === 0) {\n // Lines are parallel\n return null;\n }\n\n const originDeltaY = a1.y - b1.y;\n const originDeltaX = a1.x - b1.x;\n const aInterpolation = (bDeltaX * originDeltaY - bDeltaY * originDeltaX) / denominator;\n\n // Find intersection by projecting out from origin of first segment\n return new Point(a1.x + (aInterpolation * aDeltaX), a1.y + (aInterpolation * aDeltaY));\n}\n\n/**\n * Converts spherical coordinates to cartesian coordinates.\n *\n * @param spherical - Spherical coordinates, in [radial, azimuthal, polar]\n * @returns cartesian coordinates in [x, y, z]\n */\n\nexport function sphericalToCartesian([r, azimuthal, polar]: [number, number, number]): {\n x: number;\n y: number;\n z: number;\n} {\n // We abstract \"north\"/\"up\" (compass-wise) to be 0° when really this is 90° (π/2):\n // correct for that here\n azimuthal += 90;\n\n // Convert azimuthal and polar angles to radians\n azimuthal *= Math.PI / 180;\n polar *= Math.PI / 180;\n\n return {\n x: r * Math.cos(azimuthal) * Math.sin(polar),\n y: r * Math.sin(azimuthal) * Math.sin(polar),\n z: r * Math.cos(polar)\n };\n}\n\n/**\n * Returns true if the when run in the web-worker context.\n *\n * @returns `true` if the when run in the web-worker context.\n */\nexport function isWorker(self: any): self is WorkerGlobalScopeInterface {\n // @ts-ignore\n return typeof WorkerGlobalScope !== 'undefined' && typeof self !== 'undefined' && self instanceof WorkerGlobalScope;\n}\n\n/**\n * Parses data from 'Cache-Control' headers.\n *\n * @param cacheControl - Value of 'Cache-Control' header\n * @returns object containing parsed header info.\n */\n\nexport function parseCacheControl(cacheControl: string): any {\n // Taken from [Wreck](https://github.com/hapijs/wreck)\n const re = /(?:^|(?:\\s*\\,\\s*))([^\\x00-\\x20\\(\\)<>@\\,;\\:\\\\\"\\/\\[\\]\\?\\=\\{\\}\\x7F]+)(?:\\=(?:([^\\x00-\\x20\\(\\)<>@\\,;\\:\\\\\"\\/\\[\\]\\?\\=\\{\\}\\x7F]+)|(?:\\\"((?:[^\"\\\\]|\\\\.)*)\\\")))?/g;\n\n const header = {};\n cacheControl.replace(re, ($0, $1, $2, $3) => {\n const value = $2 || $3;\n header[$1] = value ? value.toLowerCase() : true;\n return '';\n });\n\n if (header['max-age']) {\n const maxAge = parseInt(header['max-age'], 10);\n if (isNaN(maxAge)) delete header['max-age'];\n else header['max-age'] = maxAge;\n }\n\n return header;\n}\n\nlet _isSafari = null;\n\n/**\n * Returns true when run in WebKit derived browsers.\n * This is used as a workaround for a memory leak in Safari caused by using Transferable objects to\n * transfer data between WebWorkers and the main thread.\n * https://github.com/mapbox/mapbox-gl-js/issues/8771\n *\n * This should be removed once the underlying Safari issue is fixed.\n *\n * @param scope - Since this function is used both on the main thread and WebWorker context,\n * let the calling scope pass in the global scope object.\n * @returns `true` when run in WebKit derived browsers.\n */\nexport function isSafari(scope: any): boolean {\n if (_isSafari == null) {\n const userAgent = scope.navigator ? scope.navigator.userAgent : null;\n _isSafari = !!scope.safari ||\n !!(userAgent && (/\\b(iPad|iPhone|iPod)\\b/.test(userAgent) || (!!userAgent.match('Safari') && !userAgent.match('Chrome'))));\n }\n return _isSafari;\n}\n\nexport function storageAvailable(type: string): boolean {\n try {\n const storage = window[type];\n storage.setItem('_mapbox_test_', 1);\n storage.removeItem('_mapbox_test_');\n return true;\n } catch (e) {\n return false;\n }\n}\n\n// The following methods are from https://developer.mozilla.org/en-US/docs/Web/API/WindowBase64/Base64_encoding_and_decoding#The_Unicode_Problem\n//Unicode compliant base64 encoder for strings\nexport function b64EncodeUnicode(str: string) {\n return btoa(\n encodeURIComponent(str).replace(/%([0-9A-F]{2})/g,\n (match, p1) => {\n return String.fromCharCode(Number('0x' + p1)); //eslint-disable-line\n }\n )\n );\n}\n\n// Unicode compliant decoder for base64-encoded strings\nexport function b64DecodeUnicode(str: string) {\n return decodeURIComponent(atob(str).split('').map((c) => {\n return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2); //eslint-disable-line\n }).join(''));\n}\n\nexport function isImageBitmap(image: any): image is ImageBitmap {\n return typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap;\n}\n\n/**\n * Converts an ArrayBuffer to an ImageBitmap.\n *\n * Used mostly for testing purposes only, because mocking libs don't know how to work with ArrayBuffers, but work\n * perfectly fine with ImageBitmaps. Might also be used for environments (other than testing) not supporting\n * ArrayBuffers.\n *\n * @param data - Data to convert\n * @returns - A promise resolved when the conversion is finished\n */\nexport const arrayBufferToImageBitmap = async (data: ArrayBuffer): Promise => {\n if (data.byteLength === 0) {\n return createImageBitmap(new ImageData(1, 1));\n }\n const blob: Blob = new Blob([new Uint8Array(data)], {type: 'image/png'});\n try {\n return createImageBitmap(blob);\n } catch (e) {\n throw new Error(`Could not load image because of ${e.message}. Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported.`);\n }\n};\n\nconst transparentPngUrl = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAC0lEQVQYV2NgAAIAAAUAAarVyFEAAAAASUVORK5CYII=';\n\n/**\n * Converts an ArrayBuffer to an HTMLImageElement.\n *\n * Used mostly for testing purposes only, because mocking libs don't know how to work with ArrayBuffers, but work\n * perfectly fine with ImageBitmaps. Might also be used for environments (other than testing) not supporting\n * ArrayBuffers.\n *\n * @param data - Data to convert\n * @returns - A promise resolved when the conversion is finished\n */\nexport const arrayBufferToImage = (data: ArrayBuffer): Promise => {\n return new Promise((resolve, reject) => {\n const img: HTMLImageElement = new Image();\n img.onload = () => {\n resolve(img);\n URL.revokeObjectURL(img.src);\n // prevent image dataURI memory leak in Safari;\n // but don't free the image immediately because it might be uploaded in the next frame\n // https://github.com/mapbox/mapbox-gl-js/issues/10226\n img.onload = null;\n window.requestAnimationFrame(() => { img.src = transparentPngUrl; });\n };\n img.onerror = () => reject(new Error('Could not load image. Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported.'));\n const blob: Blob = new Blob([new Uint8Array(data)], {type: 'image/png'});\n img.src = data.byteLength ? URL.createObjectURL(blob) : transparentPngUrl;\n });\n};\n\n/**\n * Computes the webcodecs VideoFrame API options to select a rectangle out of\n * an image and write it into the destination rectangle.\n *\n * Rect (x/y/width/height) select the overlapping rectangle from the source image\n * and layout (offset/stride) write that overlapping rectangle to the correct place\n * in the destination image.\n *\n * Offset is the byte offset in the dest image that the first pixel appears at\n * and stride is the number of bytes to the start of the next row:\n * ┌───────────┐\n * │ dest │\n * │ ┌───┼───────┐\n * │offset→│▓▓▓│ source│\n * │ │▓▓▓│ │\n * │ └───┼───────┘\n * │stride ⇠╌╌╌│\n * │╌╌╌╌╌╌→ │\n * └───────────┘\n *\n * @param image - source image containing a width and height attribute\n * @param x - top-left x coordinate to read from the image\n * @param y - top-left y coordinate to read from the image\n * @param width - width of the rectangle to read from the image\n * @param height - height of the rectangle to read from the image\n * @returns the layout and rect options to pass into VideoFrame API\n */\nfunction computeVideoFrameParameters(image: Size, x: number, y: number, width: number, height: number): VideoFrameCopyToOptions {\n const destRowOffset = Math.max(-x, 0) * 4;\n const firstSourceRow = Math.max(0, y);\n const firstDestRow = firstSourceRow - y;\n const offset = firstDestRow * width * 4 + destRowOffset;\n const stride = width * 4;\n\n const sourceLeft = Math.max(0, x);\n const sourceTop = Math.max(0, y);\n const sourceRight = Math.min(image.width, x + width);\n const sourceBottom = Math.min(image.height, y + height);\n return {\n rect: {\n x: sourceLeft,\n y: sourceTop,\n width: sourceRight - sourceLeft,\n height: sourceBottom - sourceTop\n },\n layout: [{offset, stride}]\n };\n}\n\n/**\n * Reads pixels from an ImageBitmap/Image/canvas using webcodec VideoFrame API.\n *\n * @param data - image, imagebitmap, or canvas to parse\n * @param x - top-left x coordinate to read from the image\n * @param y - top-left y coordinate to read from the image\n * @param width - width of the rectangle to read from the image\n * @param height - height of the rectangle to read from the image\n * @returns a promise containing the parsed RGBA pixel values of the image, or the error if an error occurred\n */\nexport async function readImageUsingVideoFrame(\n image: HTMLImageElement | HTMLCanvasElement | ImageBitmap | OffscreenCanvas,\n x: number, y: number, width: number, height: number\n): Promise {\n if (typeof VideoFrame === 'undefined') {\n throw new Error('VideoFrame not supported');\n }\n const frame = new VideoFrame(image, {timestamp: 0});\n try {\n const format = frame?.format;\n if (!format || !(format.startsWith('BGR') || format.startsWith('RGB'))) {\n throw new Error(`Unrecognized format ${format}`);\n }\n const swapBR = format.startsWith('BGR');\n const result = new Uint8ClampedArray(width * height * 4);\n await frame.copyTo(result, computeVideoFrameParameters(image, x, y, width, height));\n if (swapBR) {\n for (let i = 0; i < result.length; i += 4) {\n const tmp = result[i];\n result[i] = result[i + 2];\n result[i + 2] = tmp;\n }\n }\n return result;\n } finally {\n frame.close();\n }\n}\n\nlet offscreenCanvas: OffscreenCanvas;\nlet offscreenCanvasContext: OffscreenCanvasRenderingContext2D;\n\n/**\n * Reads pixels from an ImageBitmap/Image/canvas using OffscreenCanvas\n *\n * @param data - image, imagebitmap, or canvas to parse\n * @param x - top-left x coordinate to read from the image\n * @param y - top-left y coordinate to read from the image\n * @param width - width of the rectangle to read from the image\n * @param height - height of the rectangle to read from the image\n * @returns a promise containing the parsed RGBA pixel values of the image, or the error if an error occurred\n */\nexport function readImageDataUsingOffscreenCanvas(\n imgBitmap: HTMLImageElement | HTMLCanvasElement | ImageBitmap | OffscreenCanvas,\n x: number, y: number, width: number, height: number\n): Uint8ClampedArray {\n const origWidth = imgBitmap.width;\n const origHeight = imgBitmap.height;\n // Lazily initialize OffscreenCanvas\n if (!offscreenCanvas || !offscreenCanvasContext) {\n // Dem tiles are typically 256x256\n offscreenCanvas = new OffscreenCanvas(origWidth, origHeight);\n offscreenCanvasContext = offscreenCanvas.getContext('2d', {willReadFrequently: true});\n }\n\n offscreenCanvas.width = origWidth;\n offscreenCanvas.height = origHeight;\n\n offscreenCanvasContext.drawImage(imgBitmap, 0, 0, origWidth, origHeight);\n const imgData = offscreenCanvasContext.getImageData(x, y, width, height);\n offscreenCanvasContext.clearRect(0, 0, origWidth, origHeight);\n return imgData.data;\n}\n\n/**\n * Reads RGBA pixels from an preferring OffscreenCanvas, but falling back to VideoFrame if supported and\n * the browser is mangling OffscreenCanvas getImageData results.\n *\n * @param data - image, imagebitmap, or canvas to parse\n * @param x - top-left x coordinate to read from the image\n * @param y - top-left y coordinate to read from the image\n * @param width - width of the rectangle to read from the image\n * @param height - height of the rectangle to read from the image\n * @returns a promise containing the parsed RGBA pixel values of the image\n */\nexport async function getImageData(\n image: HTMLImageElement | HTMLCanvasElement | ImageBitmap | OffscreenCanvas,\n x: number, y: number, width: number, height: number\n): Promise {\n if (isOffscreenCanvasDistorted()) {\n try {\n return await readImageUsingVideoFrame(image, x, y, width, height);\n } catch (e) {\n // fall back to OffscreenCanvas\n }\n }\n return readImageDataUsingOffscreenCanvas(image, x, y, width, height);\n}\n\nexport interface Subscription {\n unsubscribe(): void;\n}\n\nexport interface Subscriber {\n addEventListener: typeof window.addEventListener;\n removeEventListener: typeof window.removeEventListener;\n}\n\n/**\n * This method is used in order to register an event listener using a lambda function.\n * The return value will allow unsubscribing from the event, without the need to store the method reference.\n * @param target - The target\n * @param message - The message\n * @param listener - The listener\n * @param options - The options\n * @returns a subscription object that can be used to unsubscribe from the event\n */\nexport function subscribe(target: Subscriber, message: keyof WindowEventMap, listener: (...args: any) => void, options: boolean | AddEventListenerOptions): Subscription {\n target.addEventListener(message, listener, options);\n return {\n unsubscribe: () => {\n target.removeEventListener(message, listener, options);\n }\n };\n}\n\n/**\n * This method converts degrees to radians.\n * The return value is the radian value.\n * @param degrees - The number of degrees\n * @returns radians\n */\nexport function degreesToRadians(degrees: number): number {\n return degrees * Math.PI / 180;\n}\n\n/**\n * Makes optional keys required and add the the undefined type.\n *\n * ```\n * interface Test {\n * foo: number;\n * bar?: number;\n * baz: number | undefined;\n * }\n *\n * Complete {\n * foo: number;\n * bar: number | undefined;\n * baz: number | undefined;\n * }\n *\n * ```\n *\n * See https://medium.com/terria/typescript-transforming-optional-properties-to-required-properties-that-may-be-undefined-7482cb4e1585\n */\n\nexport type Complete = {\n [P in keyof Required]: Pick extends Required> ? T[P] : (T[P] | undefined);\n}\n\nexport type TileJSON = {\n tilejson: '2.2.0' | '2.1.0' | '2.0.1' | '2.0.0' | '1.0.0';\n name?: string;\n description?: string;\n version?: string;\n attribution?: string;\n template?: string;\n tiles: Array;\n grids?: Array;\n data?: Array;\n minzoom?: number;\n maxzoom?: number;\n bounds?: [number, number, number, number];\n center?: [number, number, number];\n vector_layers: [{id: string}]; // this is partial but enough for what we need\n};\n\n/**\n * The maximum world tile zoom (Z).\n * In other words, the upper bound supported for tile zoom.\n */\nexport const MAX_TILE_ZOOM = 25;\n\n/**\n * The minimum world tile zoom (Z).\n * In other words, the lower bound supported for tile zoom.\n */\nexport const MIN_TILE_ZOOM = 0;\n","/**\n * An error message to use when an operation is aborted\n */\nexport const ABORT_ERROR = 'AbortError';\n\n/**\n * Check if an error is an abort error\n * @param error - An error object\n * @returns - true if the error is an abort error\n */\nexport function isAbortError(error: Error): boolean {\n return error.message === ABORT_ERROR;\n}\n\n/**\n * Use this when you need to create an abort error.\n * @returns An error object with the message \"AbortError\"\n */\nexport function createAbortError(): Error {\n return new Error(ABORT_ERROR);\n}\n","import type {RequestParameters, GetResourceResponse} from './ajax';\n\n/**\n * This method type is used to register a protocol handler.\n * Use the abort controller for aborting requests.\n * Return a promise with the relevant resource response.\n */\nexport type AddProtocolAction = (requestParameters: RequestParameters, abortController: AbortController) => Promise>\n\n/**\n * This is a global config object used to store the configuration\n * It is available in the workers as well.\n * Only serializable data should be stored in it.\n */\ntype Config = {\n MAX_PARALLEL_IMAGE_REQUESTS: number;\n MAX_PARALLEL_IMAGE_REQUESTS_PER_FRAME: number;\n MAX_TILE_CACHE_ZOOM_LEVELS: number;\n REGISTERED_PROTOCOLS: {[x: string]: AddProtocolAction };\n WORKER_URL: string;\n};\n\nexport const config: Config = {\n MAX_PARALLEL_IMAGE_REQUESTS: 16,\n MAX_PARALLEL_IMAGE_REQUESTS_PER_FRAME: 8,\n MAX_TILE_CACHE_ZOOM_LEVELS: 5,\n REGISTERED_PROTOCOLS: {},\n WORKER_URL: ''\n};\n","import {AddProtocolAction, config} from '../util/config';\n\nexport function getProtocol(url: string) {\n return config.REGISTERED_PROTOCOLS[url.substring(0, url.indexOf('://'))];\n}\n/**\n * Adds a custom load resource function that will be called when using a URL that starts with a custom url schema.\n * This will happen in the main thread, and workers might call it if they don't know how to handle the protocol.\n * The example below will be triggered for custom:// urls defined in the sources list in the style definitions.\n * The function passed will receive the request parameters and should return with the resulting resource,\n * for example a pbf vector tile, non-compressed, represented as ArrayBuffer.\n *\n * @param customProtocol - the protocol to hook, for example 'custom'\n * @param loadFn - the function to use when trying to fetch a tile specified by the customProtocol\n * @example\n * ```ts\n * // This will fetch a file using the fetch API (this is obviously a non interesting example...)\n * addProtocol('custom', async (params, abortController) => {\n * const t = await fetch(`https://${params.url.split(\"://\")[1]}`);\n * if (t.status == 200) {\n * const buffer = await t.arrayBuffer();\n * return {data: buffer}\n * } else {\n * throw new Error(`Tile fetch error: ${t.statusText}`);\n * }\n * });\n * // the following is an example of a way to return an error when trying to load a tile\n * addProtocol('custom2', async (params, abortController) => {\n * throw new Error('someErrorMessage'));\n * });\n * ```\n */\nexport function addProtocol(customProtocol: string, loadFn: AddProtocolAction) {\n config.REGISTERED_PROTOCOLS[customProtocol] = loadFn;\n}\n\n/**\n * Removes a previously added protocol in the main thread.\n *\n * @param customProtocol - the custom protocol to remove registration for\n * @example\n * ```ts\n * removeProtocol('custom');\n * ```\n */\nexport function removeProtocol(customProtocol: string) {\n delete config.REGISTERED_PROTOCOLS[customProtocol];\n}\n","import {extend, isWorker} from './util';\nimport {createAbortError} from './abort_error';\nimport {getProtocol} from '../source/protocol_crud';\nimport {MessageType} from './actor_messages';\n\n/**\n * This is used to identify the global dispatcher id when sending a message from the worker without a target map id.\n */\nexport const GLOBAL_DISPATCHER_ID = 'global-dispatcher';\n\n/**\n * A type used to store the tile's expiration date and cache control definition\n */\nexport type ExpiryData = {cacheControl?: string | null; expires?: Date | string | null};\n\n/**\n * A `RequestParameters` object to be returned from Map.options.transformRequest callbacks.\n * @example\n * ```ts\n * // use transformRequest to modify requests that begin with `http://myHost`\n * transformRequest: function(url, resourceType) {\n * if (resourceType === 'Source' && url.indexOf('http://myHost') > -1) {\n * return {\n * url: url.replace('http', 'https'),\n * headers: { 'my-custom-header': true },\n * credentials: 'include' // Include cookies for cross-origin requests\n * }\n * }\n * }\n * ```\n */\nexport type RequestParameters = {\n /**\n * The URL to be requested.\n */\n url: string;\n /**\n * The headers to be sent with the request.\n */\n headers?: any;\n /**\n * Request method `'GET' | 'POST' | 'PUT'`.\n */\n method?: 'GET' | 'POST' | 'PUT';\n /**\n * Request body.\n */\n body?: string;\n /**\n * Response body type to be returned.\n */\n type?: 'string' | 'json' | 'arrayBuffer' | 'image';\n /**\n * `'same-origin'|'include'` Use 'include' to send cookies with cross-origin requests.\n */\n credentials?: 'same-origin' | 'include';\n /**\n * If `true`, Resource Timing API information will be collected for these transformed requests and returned in a resourceTiming property of relevant data events.\n */\n collectResourceTiming?: boolean;\n /**\n * Parameters supported only by browser fetch API. Property of the Request interface contains the cache mode of the request. It controls how the request will interact with the browser's HTTP cache. (https://developer.mozilla.org/en-US/docs/Web/API/Request/cache)\n */\n cache?: RequestCache;\n};\n\n/**\n * The response object returned from a successful AJAx request\n */\nexport type GetResourceResponse = ExpiryData & {\n data: T;\n}\n\n/**\n * The response callback used in various places\n */\nexport type ResponseCallback = (\n error?: Error | null,\n data?: T | null,\n cacheControl?: string | null,\n expires?: string | Date | null\n) => void;\n\n/**\n * An error thrown when a HTTP request results in an error response.\n */\nexport class AJAXError extends Error {\n /**\n * The response's HTTP status code.\n */\n status: number;\n\n /**\n * The response's HTTP status text.\n */\n statusText: string;\n\n /**\n * The request's URL.\n */\n url: string;\n\n /**\n * The response's body.\n */\n body: Blob;\n\n /**\n * @param status - The response's HTTP status code.\n * @param statusText - The response's HTTP status text.\n * @param url - The request's URL.\n * @param body - The response's body.\n */\n constructor(status: number, statusText: string, url: string, body: Blob) {\n super(`AJAXError: ${statusText} (${status}): ${url}`);\n this.status = status;\n this.statusText = statusText;\n this.url = url;\n this.body = body;\n }\n}\n\n/**\n * Ensure that we're sending the correct referrer from blob URL worker bundles.\n * For files loaded from the local file system, `location.origin` will be set\n * to the string(!) \"null\" (Firefox), or \"file://\" (Chrome, Safari, Edge),\n * and we will set an empty referrer. Otherwise, we're using the document's URL.\n */\nexport const getReferrer = () => isWorker(self) ?\n self.worker && self.worker.referrer :\n (window.location.protocol === 'blob:' ? window.parent : window).location.href;\n\n/**\n * Determines whether a URL is a file:// URL. This is obviously the case if it begins\n * with file://. Relative URLs are also file:// URLs iff the original document was loaded\n * via a file:// URL.\n * @param url - The URL to check\n * @returns `true` if the URL is a file:// URL, `false` otherwise\n */\nconst isFileURL = url => /^file:/.test(url) || (/^file:/.test(getReferrer()) && !/^\\w+:/.test(url));\n\nasync function makeFetchRequest(requestParameters: RequestParameters, abortController: AbortController): Promise> {\n const request = new Request(requestParameters.url, {\n method: requestParameters.method || 'GET',\n body: requestParameters.body,\n credentials: requestParameters.credentials,\n headers: requestParameters.headers,\n cache: requestParameters.cache,\n referrer: getReferrer(),\n signal: abortController.signal\n });\n\n // If the user has already set an Accept header, do not overwrite it here\n if (requestParameters.type === 'json' && !request.headers.has('Accept')) {\n request.headers.set('Accept', 'application/json');\n }\n\n const response = await fetch(request);\n if (!response.ok) {\n const body = await response.blob();\n throw new AJAXError(response.status, response.statusText, requestParameters.url, body);\n }\n let parsePromise: Promise;\n if ((requestParameters.type === 'arrayBuffer' || requestParameters.type === 'image')) {\n parsePromise = response.arrayBuffer();\n } else if (requestParameters.type === 'json') {\n parsePromise = response.json();\n } else {\n parsePromise = response.text();\n }\n const result = await parsePromise;\n if (abortController.signal.aborted) {\n throw createAbortError();\n }\n return {data: result, cacheControl: response.headers.get('Cache-Control'), expires: response.headers.get('Expires')};\n}\n\nfunction makeXMLHttpRequest(requestParameters: RequestParameters, abortController: AbortController): Promise> {\n return new Promise((resolve, reject) => {\n const xhr: XMLHttpRequest = new XMLHttpRequest();\n\n xhr.open(requestParameters.method || 'GET', requestParameters.url, true);\n if (requestParameters.type === 'arrayBuffer' || requestParameters.type === 'image') {\n xhr.responseType = 'arraybuffer';\n }\n for (const k in requestParameters.headers) {\n xhr.setRequestHeader(k, requestParameters.headers[k]);\n }\n if (requestParameters.type === 'json') {\n xhr.responseType = 'text';\n // Do not overwrite the user-provided Accept header\n if (!requestParameters.headers?.Accept) {\n xhr.setRequestHeader('Accept', 'application/json');\n }\n }\n xhr.withCredentials = requestParameters.credentials === 'include';\n xhr.onerror = () => {\n reject(new Error(xhr.statusText));\n };\n xhr.onload = () => {\n if (abortController.signal.aborted) {\n return;\n }\n if (((xhr.status >= 200 && xhr.status < 300) || xhr.status === 0) && xhr.response !== null) {\n let data: unknown = xhr.response;\n if (requestParameters.type === 'json') {\n // We're manually parsing JSON here to get better error messages.\n try {\n data = JSON.parse(xhr.response);\n } catch (err) {\n reject(err);\n return;\n }\n }\n resolve({data, cacheControl: xhr.getResponseHeader('Cache-Control'), expires: xhr.getResponseHeader('Expires')});\n } else {\n const body = new Blob([xhr.response], {type: xhr.getResponseHeader('Content-Type')});\n reject(new AJAXError(xhr.status, xhr.statusText, requestParameters.url, body));\n }\n };\n abortController.signal.addEventListener('abort', () => {\n xhr.abort();\n reject(createAbortError());\n });\n xhr.send(requestParameters.body);\n });\n}\n\n/**\n * We're trying to use the Fetch API if possible. However, requests for resources with the file:// URI scheme don't work with the Fetch API.\n * In this case we unconditionally use XHR on the current thread since referrers don't matter.\n * This method can also use the registered method if `addProtocol` was called.\n * @param requestParameters - The request parameters\n * @param abortController - The abort controller allowing to cancel the request\n * @returns a promise resolving to the response, including cache control and expiry data\n */\nexport const makeRequest = function(requestParameters: RequestParameters, abortController: AbortController): Promise> {\n if (/:\\/\\//.test(requestParameters.url) && !(/^https?:|^file:/.test(requestParameters.url))) {\n const protocolLoadFn = getProtocol(requestParameters.url);\n if (protocolLoadFn) {\n return protocolLoadFn(requestParameters, abortController);\n }\n if (isWorker(self) && self.worker && self.worker.actor) {\n return self.worker.actor.sendAsync({type: MessageType.getResource, data: requestParameters, targetMapId: GLOBAL_DISPATCHER_ID}, abortController);\n }\n }\n if (!isFileURL(requestParameters.url)) {\n if (fetch && Request && AbortController && Object.prototype.hasOwnProperty.call(Request.prototype, 'signal')) {\n return makeFetchRequest(requestParameters, abortController);\n }\n if (isWorker(self) && self.worker && self.worker.actor) {\n return self.worker.actor.sendAsync({type: MessageType.getResource, data: requestParameters, mustQueue: true, targetMapId: GLOBAL_DISPATCHER_ID}, abortController);\n }\n }\n return makeXMLHttpRequest(requestParameters, abortController);\n};\n\nexport const getJSON = (requestParameters: RequestParameters, abortController: AbortController): Promise<{data: T} & ExpiryData> => {\n return makeRequest(extend(requestParameters, {type: 'json'}), abortController);\n};\n\nexport const getArrayBuffer = (requestParameters: RequestParameters, abortController: AbortController): Promise<{data: ArrayBuffer} & ExpiryData> => {\n return makeRequest(extend(requestParameters, {type: 'arrayBuffer'}), abortController);\n};\n\nexport function sameOrigin(inComingUrl: string) {\n // A relative URL \"/foo\" or \"./foo\" will throw exception in URL's ctor,\n // try-catch is expansive so just use a heuristic check to avoid it\n // also check data URL\n if (!inComingUrl ||\n inComingUrl.indexOf('://') <= 0 || // relative URL\n inComingUrl.indexOf('data:image/') === 0 || // data image URL\n inComingUrl.indexOf('blob:') === 0) { // blob\n return true;\n }\n const urlObj = new URL(inComingUrl);\n const locationObj = window.location;\n return urlObj.protocol === locationObj.protocol && urlObj.host === locationObj.host;\n}\n\nexport const getVideo = (urls: Array): Promise => {\n const video: HTMLVideoElement = window.document.createElement('video');\n video.muted = true;\n return new Promise((resolve) => {\n video.onloadstart = () => {\n resolve(video);\n };\n for (const url of urls) {\n const s: HTMLSourceElement = window.document.createElement('source');\n if (!sameOrigin(url)) {\n video.crossOrigin = 'Anonymous';\n }\n s.src = url;\n video.appendChild(s);\n }\n });\n};\n","import {extend} from './util';\n\n/**\n * A listener method used as a callback to events\n */\nexport type Listener = (a: any) => any;\n\ntype Listeners = {[_: string]: Array};\n\nfunction _addEventListener(type: string, listener: Listener, listenerList: Listeners) {\n const listenerExists = listenerList[type] && listenerList[type].indexOf(listener) !== -1;\n if (!listenerExists) {\n listenerList[type] = listenerList[type] || [];\n listenerList[type].push(listener);\n }\n}\n\nfunction _removeEventListener(type: string, listener: Listener, listenerList: Listeners) {\n if (listenerList && listenerList[type]) {\n const index = listenerList[type].indexOf(listener);\n if (index !== -1) {\n listenerList[type].splice(index, 1);\n }\n }\n}\n\n/**\n * The event class\n */\nexport class Event {\n readonly type: string;\n\n constructor(type: string, data: any = {}) {\n extend(this, data);\n this.type = type;\n }\n}\n\ninterface ErrorLike {\n message: string;\n}\n\n/**\n * An error event\n */\nexport class ErrorEvent extends Event {\n error: ErrorLike;\n\n constructor(error: ErrorLike, data: any = {}) {\n super('error', extend({error}, data));\n }\n}\n\n/**\n * Methods mixed in to other classes for event capabilities.\n *\n * @group Event Related\n */\nexport class Evented {\n _listeners: Listeners;\n _oneTimeListeners: Listeners;\n _eventedParent: Evented;\n _eventedParentData: any | (() => any);\n\n /**\n * Adds a listener to a specified event type.\n *\n * @param type - The event type to add a listen for.\n * @param listener - The function to be called when the event is fired.\n * The listener function is called with the data object passed to `fire`,\n * extended with `target` and `type` properties.\n */\n on(type: string, listener: Listener): this {\n this._listeners = this._listeners || {};\n _addEventListener(type, listener, this._listeners);\n\n return this;\n }\n\n /**\n * Removes a previously registered event listener.\n *\n * @param type - The event type to remove listeners for.\n * @param listener - The listener function to remove.\n */\n off(type: string, listener: Listener) {\n _removeEventListener(type, listener, this._listeners);\n _removeEventListener(type, listener, this._oneTimeListeners);\n\n return this;\n }\n\n /**\n * Adds a listener that will be called only once to a specified event type.\n *\n * The listener will be called first time the event fires after the listener is registered.\n *\n * @param type - The event type to listen for.\n * @param listener - The function to be called when the event is fired the first time.\n * @returns `this` or a promise if a listener is not provided\n */\n once(type: string, listener?: Listener): this | Promise {\n if (!listener) {\n return new Promise((resolve) => this.once(type, resolve));\n }\n this._oneTimeListeners = this._oneTimeListeners || {};\n _addEventListener(type, listener, this._oneTimeListeners);\n\n return this;\n }\n\n fire(event: Event | string, properties?: any) {\n // Compatibility with (type: string, properties: Object) signature from previous versions.\n // See https://github.com/mapbox/mapbox-gl-js/issues/6522,\n // https://github.com/mapbox/mapbox-gl-draw/issues/766\n if (typeof event === 'string') {\n event = new Event(event, properties || {});\n }\n\n const type = event.type;\n\n if (this.listens(type)) {\n (event as any).target = this;\n\n // make sure adding or removing listeners inside other listeners won't cause an infinite loop\n const listeners = this._listeners && this._listeners[type] ? this._listeners[type].slice() : [];\n for (const listener of listeners) {\n listener.call(this, event);\n }\n\n const oneTimeListeners = this._oneTimeListeners && this._oneTimeListeners[type] ? this._oneTimeListeners[type].slice() : [];\n for (const listener of oneTimeListeners) {\n _removeEventListener(type, listener, this._oneTimeListeners);\n listener.call(this, event);\n }\n\n const parent = this._eventedParent;\n if (parent) {\n extend(\n event,\n typeof this._eventedParentData === 'function' ? this._eventedParentData() : this._eventedParentData\n );\n parent.fire(event);\n }\n\n // To ensure that no error events are dropped, print them to the\n // console if they have no listeners.\n } else if (event instanceof ErrorEvent) {\n console.error(event.error);\n }\n\n return this;\n }\n\n /**\n * Returns a true if this instance of Evented or any forwardeed instances of Evented have a listener for the specified type.\n *\n * @param type - The event type\n * @returns `true` if there is at least one registered listener for specified event type, `false` otherwise\n */\n listens(type: string): boolean {\n return (\n (this._listeners && this._listeners[type] && this._listeners[type].length > 0) ||\n (this._oneTimeListeners && this._oneTimeListeners[type] && this._oneTimeListeners[type].length > 0) ||\n (this._eventedParent && this._eventedParent.listens(type))\n );\n }\n\n /**\n * Bubble all events fired by this instance of Evented to this parent instance of Evented.\n */\n setEventedParent(parent?: Evented | null, data?: any | (() => any)) {\n this._eventedParent = parent;\n this._eventedParentData = data;\n\n return this;\n }\n}\n","var $version = 8;\nvar $root = {\n\tversion: {\n\t\trequired: true,\n\t\ttype: \"enum\",\n\t\tvalues: [\n\t\t\t8\n\t\t]\n\t},\n\tname: {\n\t\ttype: \"string\"\n\t},\n\tmetadata: {\n\t\ttype: \"*\"\n\t},\n\tcenter: {\n\t\ttype: \"array\",\n\t\tvalue: \"number\"\n\t},\n\tzoom: {\n\t\ttype: \"number\"\n\t},\n\tbearing: {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tperiod: 360,\n\t\tunits: \"degrees\"\n\t},\n\tpitch: {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tunits: \"degrees\"\n\t},\n\tlight: {\n\t\ttype: \"light\"\n\t},\n\tsky: {\n\t\ttype: \"sky\"\n\t},\n\tprojection: {\n\t\ttype: \"projection\"\n\t},\n\tterrain: {\n\t\ttype: \"terrain\"\n\t},\n\tsources: {\n\t\trequired: true,\n\t\ttype: \"sources\"\n\t},\n\tsprite: {\n\t\ttype: \"sprite\"\n\t},\n\tglyphs: {\n\t\ttype: \"string\"\n\t},\n\ttransition: {\n\t\ttype: \"transition\"\n\t},\n\tlayers: {\n\t\trequired: true,\n\t\ttype: \"array\",\n\t\tvalue: \"layer\"\n\t}\n};\nvar sources = {\n\t\"*\": {\n\t\ttype: \"source\"\n\t}\n};\nvar source = [\n\t\"source_vector\",\n\t\"source_raster\",\n\t\"source_raster_dem\",\n\t\"source_geojson\",\n\t\"source_video\",\n\t\"source_image\"\n];\nvar source_vector = {\n\ttype: {\n\t\trequired: true,\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvector: {\n\t\t\t}\n\t\t}\n\t},\n\turl: {\n\t\ttype: \"string\"\n\t},\n\ttiles: {\n\t\ttype: \"array\",\n\t\tvalue: \"string\"\n\t},\n\tbounds: {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 4,\n\t\t\"default\": [\n\t\t\t-180,\n\t\t\t-85.051129,\n\t\t\t180,\n\t\t\t85.051129\n\t\t]\n\t},\n\tscheme: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\txyz: {\n\t\t\t},\n\t\t\ttms: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"xyz\"\n\t},\n\tminzoom: {\n\t\ttype: \"number\",\n\t\t\"default\": 0\n\t},\n\tmaxzoom: {\n\t\ttype: \"number\",\n\t\t\"default\": 22\n\t},\n\tattribution: {\n\t\ttype: \"string\"\n\t},\n\tpromoteId: {\n\t\ttype: \"promoteId\"\n\t},\n\tvolatile: {\n\t\ttype: \"boolean\",\n\t\t\"default\": false\n\t},\n\t\"*\": {\n\t\ttype: \"*\"\n\t}\n};\nvar source_raster = {\n\ttype: {\n\t\trequired: true,\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\traster: {\n\t\t\t}\n\t\t}\n\t},\n\turl: {\n\t\ttype: \"string\"\n\t},\n\ttiles: {\n\t\ttype: \"array\",\n\t\tvalue: \"string\"\n\t},\n\tbounds: {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 4,\n\t\t\"default\": [\n\t\t\t-180,\n\t\t\t-85.051129,\n\t\t\t180,\n\t\t\t85.051129\n\t\t]\n\t},\n\tminzoom: {\n\t\ttype: \"number\",\n\t\t\"default\": 0\n\t},\n\tmaxzoom: {\n\t\ttype: \"number\",\n\t\t\"default\": 22\n\t},\n\ttileSize: {\n\t\ttype: \"number\",\n\t\t\"default\": 512,\n\t\tunits: \"pixels\"\n\t},\n\tscheme: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\txyz: {\n\t\t\t},\n\t\t\ttms: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"xyz\"\n\t},\n\tattribution: {\n\t\ttype: \"string\"\n\t},\n\tvolatile: {\n\t\ttype: \"boolean\",\n\t\t\"default\": false\n\t},\n\t\"*\": {\n\t\ttype: \"*\"\n\t}\n};\nvar source_raster_dem = {\n\ttype: {\n\t\trequired: true,\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\t\"raster-dem\": {\n\t\t\t}\n\t\t}\n\t},\n\turl: {\n\t\ttype: \"string\"\n\t},\n\ttiles: {\n\t\ttype: \"array\",\n\t\tvalue: \"string\"\n\t},\n\tbounds: {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 4,\n\t\t\"default\": [\n\t\t\t-180,\n\t\t\t-85.051129,\n\t\t\t180,\n\t\t\t85.051129\n\t\t]\n\t},\n\tminzoom: {\n\t\ttype: \"number\",\n\t\t\"default\": 0\n\t},\n\tmaxzoom: {\n\t\ttype: \"number\",\n\t\t\"default\": 22\n\t},\n\ttileSize: {\n\t\ttype: \"number\",\n\t\t\"default\": 512,\n\t\tunits: \"pixels\"\n\t},\n\tattribution: {\n\t\ttype: \"string\"\n\t},\n\tencoding: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tterrarium: {\n\t\t\t},\n\t\t\tmapbox: {\n\t\t\t},\n\t\t\tcustom: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"mapbox\"\n\t},\n\tredFactor: {\n\t\ttype: \"number\",\n\t\t\"default\": 1\n\t},\n\tblueFactor: {\n\t\ttype: \"number\",\n\t\t\"default\": 1\n\t},\n\tgreenFactor: {\n\t\ttype: \"number\",\n\t\t\"default\": 1\n\t},\n\tbaseShift: {\n\t\ttype: \"number\",\n\t\t\"default\": 0\n\t},\n\tvolatile: {\n\t\ttype: \"boolean\",\n\t\t\"default\": false\n\t},\n\t\"*\": {\n\t\ttype: \"*\"\n\t}\n};\nvar source_geojson = {\n\ttype: {\n\t\trequired: true,\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tgeojson: {\n\t\t\t}\n\t\t}\n\t},\n\tdata: {\n\t\trequired: true,\n\t\ttype: \"*\"\n\t},\n\tmaxzoom: {\n\t\ttype: \"number\",\n\t\t\"default\": 18\n\t},\n\tattribution: {\n\t\ttype: \"string\"\n\t},\n\tbuffer: {\n\t\ttype: \"number\",\n\t\t\"default\": 128,\n\t\tmaximum: 512,\n\t\tminimum: 0\n\t},\n\tfilter: {\n\t\ttype: \"*\"\n\t},\n\ttolerance: {\n\t\ttype: \"number\",\n\t\t\"default\": 0.375\n\t},\n\tcluster: {\n\t\ttype: \"boolean\",\n\t\t\"default\": false\n\t},\n\tclusterRadius: {\n\t\ttype: \"number\",\n\t\t\"default\": 50,\n\t\tminimum: 0\n\t},\n\tclusterMaxZoom: {\n\t\ttype: \"number\"\n\t},\n\tclusterMinPoints: {\n\t\ttype: \"number\"\n\t},\n\tclusterProperties: {\n\t\ttype: \"*\"\n\t},\n\tlineMetrics: {\n\t\ttype: \"boolean\",\n\t\t\"default\": false\n\t},\n\tgenerateId: {\n\t\ttype: \"boolean\",\n\t\t\"default\": false\n\t},\n\tpromoteId: {\n\t\ttype: \"promoteId\"\n\t}\n};\nvar source_video = {\n\ttype: {\n\t\trequired: true,\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvideo: {\n\t\t\t}\n\t\t}\n\t},\n\turls: {\n\t\trequired: true,\n\t\ttype: \"array\",\n\t\tvalue: \"string\"\n\t},\n\tcoordinates: {\n\t\trequired: true,\n\t\ttype: \"array\",\n\t\tlength: 4,\n\t\tvalue: {\n\t\t\ttype: \"array\",\n\t\t\tlength: 2,\n\t\t\tvalue: \"number\"\n\t\t}\n\t}\n};\nvar source_image = {\n\ttype: {\n\t\trequired: true,\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\timage: {\n\t\t\t}\n\t\t}\n\t},\n\turl: {\n\t\trequired: true,\n\t\ttype: \"string\"\n\t},\n\tcoordinates: {\n\t\trequired: true,\n\t\ttype: \"array\",\n\t\tlength: 4,\n\t\tvalue: {\n\t\t\ttype: \"array\",\n\t\t\tlength: 2,\n\t\t\tvalue: \"number\"\n\t\t}\n\t}\n};\nvar layer = {\n\tid: {\n\t\ttype: \"string\",\n\t\trequired: true\n\t},\n\ttype: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tfill: {\n\t\t\t},\n\t\t\tline: {\n\t\t\t},\n\t\t\tsymbol: {\n\t\t\t},\n\t\t\tcircle: {\n\t\t\t},\n\t\t\theatmap: {\n\t\t\t},\n\t\t\t\"fill-extrusion\": {\n\t\t\t},\n\t\t\traster: {\n\t\t\t},\n\t\t\thillshade: {\n\t\t\t},\n\t\t\tbackground: {\n\t\t\t}\n\t\t},\n\t\trequired: true\n\t},\n\tmetadata: {\n\t\ttype: \"*\"\n\t},\n\tsource: {\n\t\ttype: \"string\"\n\t},\n\t\"source-layer\": {\n\t\ttype: \"string\"\n\t},\n\tminzoom: {\n\t\ttype: \"number\",\n\t\tminimum: 0,\n\t\tmaximum: 24\n\t},\n\tmaxzoom: {\n\t\ttype: \"number\",\n\t\tminimum: 0,\n\t\tmaximum: 24\n\t},\n\tfilter: {\n\t\ttype: \"filter\"\n\t},\n\tlayout: {\n\t\ttype: \"layout\"\n\t},\n\tpaint: {\n\t\ttype: \"paint\"\n\t}\n};\nvar layout = [\n\t\"layout_fill\",\n\t\"layout_line\",\n\t\"layout_circle\",\n\t\"layout_heatmap\",\n\t\"layout_fill-extrusion\",\n\t\"layout_symbol\",\n\t\"layout_raster\",\n\t\"layout_hillshade\",\n\t\"layout_background\"\n];\nvar layout_background = {\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar layout_fill = {\n\t\"fill-sort-key\": {\n\t\ttype: \"number\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar layout_circle = {\n\t\"circle-sort-key\": {\n\t\ttype: \"number\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar layout_heatmap = {\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar layout_line = {\n\t\"line-cap\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tbutt: {\n\t\t\t},\n\t\t\tround: {\n\t\t\t},\n\t\t\tsquare: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"butt\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"line-join\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tbevel: {\n\t\t\t},\n\t\t\tround: {\n\t\t\t},\n\t\t\tmiter: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"miter\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"line-miter-limit\": {\n\t\ttype: \"number\",\n\t\t\"default\": 2,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"line-join\": \"miter\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"line-round-limit\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1.05,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"line-join\": \"round\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"line-sort-key\": {\n\t\ttype: \"number\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar layout_symbol = {\n\t\"symbol-placement\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tpoint: {\n\t\t\t},\n\t\t\tline: {\n\t\t\t},\n\t\t\t\"line-center\": {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"point\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"symbol-spacing\": {\n\t\ttype: \"number\",\n\t\t\"default\": 250,\n\t\tminimum: 1,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"symbol-placement\": \"line\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"symbol-avoid-edges\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"symbol-sort-key\": {\n\t\ttype: \"number\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"symbol-z-order\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tauto: {\n\t\t\t},\n\t\t\t\"viewport-y\": {\n\t\t\t},\n\t\t\tsource: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"auto\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-allow-overlap\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\trequires: [\n\t\t\t\"icon-image\",\n\t\t\t{\n\t\t\t\t\"!\": \"icon-overlap\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-overlap\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tnever: {\n\t\t\t},\n\t\t\talways: {\n\t\t\t},\n\t\t\tcooperative: {\n\t\t\t}\n\t\t},\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-ignore-placement\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-optional\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\trequires: [\n\t\t\t\"icon-image\",\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-rotation-alignment\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t},\n\t\t\tauto: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"auto\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-size\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tunits: \"factor of the original icon size\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-text-fit\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tnone: {\n\t\t\t},\n\t\t\twidth: {\n\t\t\t},\n\t\t\theight: {\n\t\t\t},\n\t\t\tboth: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"none\",\n\t\trequires: [\n\t\t\t\"icon-image\",\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-text-fit-padding\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 4,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0,\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"icon-image\",\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"icon-text-fit\": [\n\t\t\t\t\t\"both\",\n\t\t\t\t\t\"width\",\n\t\t\t\t\t\"height\"\n\t\t\t\t]\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-image\": {\n\t\ttype: \"resolvedImage\",\n\t\ttokens: true,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-rotate\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tperiod: 360,\n\t\tunits: \"degrees\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-padding\": {\n\t\ttype: \"padding\",\n\t\t\"default\": [\n\t\t\t2\n\t\t],\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-keep-upright\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\trequires: [\n\t\t\t\"icon-image\",\n\t\t\t{\n\t\t\t\t\"icon-rotation-alignment\": \"map\"\n\t\t\t},\n\t\t\t{\n\t\t\t\t\"symbol-placement\": [\n\t\t\t\t\t\"line\",\n\t\t\t\t\t\"line-center\"\n\t\t\t\t]\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-offset\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tcenter: {\n\t\t\t},\n\t\t\tleft: {\n\t\t\t},\n\t\t\tright: {\n\t\t\t},\n\t\t\ttop: {\n\t\t\t},\n\t\t\tbottom: {\n\t\t\t},\n\t\t\t\"top-left\": {\n\t\t\t},\n\t\t\t\"top-right\": {\n\t\t\t},\n\t\t\t\"bottom-left\": {\n\t\t\t},\n\t\t\t\"bottom-right\": {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"center\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-pitch-alignment\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t},\n\t\t\tauto: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"auto\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-pitch-alignment\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t},\n\t\t\tauto: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"auto\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-rotation-alignment\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t},\n\t\t\t\"viewport-glyph\": {\n\t\t\t},\n\t\t\tauto: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"auto\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-field\": {\n\t\ttype: \"formatted\",\n\t\t\"default\": \"\",\n\t\ttokens: true,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-font\": {\n\t\ttype: \"array\",\n\t\tvalue: \"string\",\n\t\t\"default\": [\n\t\t\t\"Open Sans Regular\",\n\t\t\t\"Arial Unicode MS Regular\"\n\t\t],\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-size\": {\n\t\ttype: \"number\",\n\t\t\"default\": 16,\n\t\tminimum: 0,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-max-width\": {\n\t\ttype: \"number\",\n\t\t\"default\": 10,\n\t\tminimum: 0,\n\t\tunits: \"ems\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-line-height\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1.2,\n\t\tunits: \"ems\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-letter-spacing\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tunits: \"ems\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-justify\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tauto: {\n\t\t\t},\n\t\t\tleft: {\n\t\t\t},\n\t\t\tcenter: {\n\t\t\t},\n\t\t\tright: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"center\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-radial-offset\": {\n\t\ttype: \"number\",\n\t\tunits: \"ems\",\n\t\t\"default\": 0,\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\t\"property-type\": \"data-driven\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t}\n\t},\n\t\"text-variable-anchor\": {\n\t\ttype: \"array\",\n\t\tvalue: \"enum\",\n\t\tvalues: {\n\t\t\tcenter: {\n\t\t\t},\n\t\t\tleft: {\n\t\t\t},\n\t\t\tright: {\n\t\t\t},\n\t\t\ttop: {\n\t\t\t},\n\t\t\tbottom: {\n\t\t\t},\n\t\t\t\"top-left\": {\n\t\t\t},\n\t\t\t\"top-right\": {\n\t\t\t},\n\t\t\t\"bottom-left\": {\n\t\t\t},\n\t\t\t\"bottom-right\": {\n\t\t\t}\n\t\t},\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"symbol-placement\": [\n\t\t\t\t\t\"point\"\n\t\t\t\t]\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-variable-anchor-offset\": {\n\t\ttype: \"variableAnchorOffsetCollection\",\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"symbol-placement\": [\n\t\t\t\t\t\"point\"\n\t\t\t\t]\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tcenter: {\n\t\t\t},\n\t\t\tleft: {\n\t\t\t},\n\t\t\tright: {\n\t\t\t},\n\t\t\ttop: {\n\t\t\t},\n\t\t\tbottom: {\n\t\t\t},\n\t\t\t\"top-left\": {\n\t\t\t},\n\t\t\t\"top-right\": {\n\t\t\t},\n\t\t\t\"bottom-left\": {\n\t\t\t},\n\t\t\t\"bottom-right\": {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"center\",\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"!\": \"text-variable-anchor\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-max-angle\": {\n\t\ttype: \"number\",\n\t\t\"default\": 45,\n\t\tunits: \"degrees\",\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"symbol-placement\": [\n\t\t\t\t\t\"line\",\n\t\t\t\t\t\"line-center\"\n\t\t\t\t]\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-writing-mode\": {\n\t\ttype: \"array\",\n\t\tvalue: \"enum\",\n\t\tvalues: {\n\t\t\thorizontal: {\n\t\t\t},\n\t\t\tvertical: {\n\t\t\t}\n\t\t},\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"symbol-placement\": [\n\t\t\t\t\t\"point\"\n\t\t\t\t]\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-rotate\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tperiod: 360,\n\t\tunits: \"degrees\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-padding\": {\n\t\ttype: \"number\",\n\t\t\"default\": 2,\n\t\tminimum: 0,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-keep-upright\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": true,\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"text-rotation-alignment\": \"map\"\n\t\t\t},\n\t\t\t{\n\t\t\t\t\"symbol-placement\": [\n\t\t\t\t\t\"line\",\n\t\t\t\t\t\"line-center\"\n\t\t\t\t]\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-transform\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tnone: {\n\t\t\t},\n\t\t\tuppercase: {\n\t\t\t},\n\t\t\tlowercase: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"none\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-offset\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tunits: \"ems\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"!\": \"text-radial-offset\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-allow-overlap\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t{\n\t\t\t\t\"!\": \"text-overlap\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-overlap\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tnever: {\n\t\t\t},\n\t\t\talways: {\n\t\t\t},\n\t\t\tcooperative: {\n\t\t\t}\n\t\t},\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-ignore-placement\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-optional\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": false,\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar layout_raster = {\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar layout_hillshade = {\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n};\nvar filter = {\n\ttype: \"array\",\n\tvalue: \"*\"\n};\nvar filter_operator = {\n\ttype: \"enum\",\n\tvalues: {\n\t\t\"==\": {\n\t\t},\n\t\t\"!=\": {\n\t\t},\n\t\t\">\": {\n\t\t},\n\t\t\">=\": {\n\t\t},\n\t\t\"<\": {\n\t\t},\n\t\t\"<=\": {\n\t\t},\n\t\t\"in\": {\n\t\t},\n\t\t\"!in\": {\n\t\t},\n\t\tall: {\n\t\t},\n\t\tany: {\n\t\t},\n\t\tnone: {\n\t\t},\n\t\thas: {\n\t\t},\n\t\t\"!has\": {\n\t\t}\n\t}\n};\nvar geometry_type = {\n\ttype: \"enum\",\n\tvalues: {\n\t\tPoint: {\n\t\t},\n\t\tLineString: {\n\t\t},\n\t\tPolygon: {\n\t\t}\n\t}\n};\nvar function_stop = {\n\ttype: \"array\",\n\tminimum: 0,\n\tmaximum: 24,\n\tvalue: [\n\t\t\"number\",\n\t\t\"color\"\n\t],\n\tlength: 2\n};\nvar expression$1 = {\n\ttype: \"array\",\n\tvalue: \"*\",\n\tminimum: 1\n};\nvar light = {\n\tanchor: {\n\t\ttype: \"enum\",\n\t\t\"default\": \"viewport\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"property-type\": \"data-constant\",\n\t\ttransition: false,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t}\n\t},\n\tposition: {\n\t\ttype: \"array\",\n\t\t\"default\": [\n\t\t\t1.15,\n\t\t\t210,\n\t\t\t30\n\t\t],\n\t\tlength: 3,\n\t\tvalue: \"number\",\n\t\t\"property-type\": \"data-constant\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t}\n\t},\n\tcolor: {\n\t\ttype: \"color\",\n\t\t\"property-type\": \"data-constant\",\n\t\t\"default\": \"#ffffff\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\ttransition: true\n\t},\n\tintensity: {\n\t\ttype: \"number\",\n\t\t\"property-type\": \"data-constant\",\n\t\t\"default\": 0.5,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\ttransition: true\n\t}\n};\nvar sky = {\n\t\"sky-color\": {\n\t\ttype: \"color\",\n\t\t\"property-type\": \"data-constant\",\n\t\t\"default\": \"#88C6FC\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\ttransition: true\n\t},\n\t\"horizon-color\": {\n\t\ttype: \"color\",\n\t\t\"property-type\": \"data-constant\",\n\t\t\"default\": \"#ffffff\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\ttransition: true\n\t},\n\t\"fog-color\": {\n\t\ttype: \"color\",\n\t\t\"property-type\": \"data-constant\",\n\t\t\"default\": \"#ffffff\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\ttransition: true\n\t},\n\t\"fog-ground-blend\": {\n\t\ttype: \"number\",\n\t\t\"property-type\": \"data-constant\",\n\t\t\"default\": 0.5,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\ttransition: true\n\t},\n\t\"horizon-fog-blend\": {\n\t\ttype: \"number\",\n\t\t\"property-type\": \"data-constant\",\n\t\t\"default\": 0.8,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\ttransition: true\n\t},\n\t\"sky-horizon-blend\": {\n\t\ttype: \"number\",\n\t\t\"property-type\": \"data-constant\",\n\t\t\"default\": 0.8,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\ttransition: true\n\t},\n\t\"atmosphere-blend\": {\n\t\ttype: \"number\",\n\t\t\"property-type\": \"data-constant\",\n\t\t\"default\": 0.8,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\ttransition: true\n\t}\n};\nvar terrain = {\n\tsource: {\n\t\ttype: \"string\",\n\t\trequired: true\n\t},\n\texaggeration: {\n\t\ttype: \"number\",\n\t\tminimum: 0,\n\t\t\"default\": 1\n\t}\n};\nvar projection = {\n\ttype: {\n\t\ttype: \"enum\",\n\t\t\"default\": \"mercator\",\n\t\tvalues: {\n\t\t\tmercator: {\n\t\t\t},\n\t\t\tglobe: {\n\t\t\t}\n\t\t}\n\t}\n};\nvar paint = [\n\t\"paint_fill\",\n\t\"paint_line\",\n\t\"paint_circle\",\n\t\"paint_heatmap\",\n\t\"paint_fill-extrusion\",\n\t\"paint_symbol\",\n\t\"paint_raster\",\n\t\"paint_hillshade\",\n\t\"paint_background\"\n];\nvar paint_fill = {\n\t\"fill-antialias\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": true,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"fill-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"fill-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"!\": \"fill-pattern\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"fill-outline-color\": {\n\t\ttype: \"color\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"!\": \"fill-pattern\"\n\t\t\t},\n\t\t\t{\n\t\t\t\t\"fill-antialias\": true\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"fill-translate\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"fill-translate-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"map\",\n\t\trequires: [\n\t\t\t\"fill-translate\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"fill-pattern\": {\n\t\ttype: \"resolvedImage\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"cross-faded-data-driven\"\n\t}\n};\nvar paint_line = {\n\t\"line-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"line-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"!\": \"line-pattern\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"line-translate\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"line-translate-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"map\",\n\t\trequires: [\n\t\t\t\"line-translate\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"line-width\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"line-gap-width\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"line-offset\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"line-blur\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"line-dasharray\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"line widths\",\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"!\": \"line-pattern\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"cross-faded\"\n\t},\n\t\"line-pattern\": {\n\t\ttype: \"resolvedImage\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"cross-faded-data-driven\"\n\t},\n\t\"line-gradient\": {\n\t\ttype: \"color\",\n\t\ttransition: false,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"!\": \"line-dasharray\"\n\t\t\t},\n\t\t\t{\n\t\t\t\t\"!\": \"line-pattern\"\n\t\t\t},\n\t\t\t{\n\t\t\t\tsource: \"geojson\",\n\t\t\t\thas: {\n\t\t\t\t\tlineMetrics: true\n\t\t\t\t}\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"line-progress\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"color-ramp\"\n\t}\n};\nvar paint_circle = {\n\t\"circle-radius\": {\n\t\ttype: \"number\",\n\t\t\"default\": 5,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"circle-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"circle-blur\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"circle-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"circle-translate\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"circle-translate-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"map\",\n\t\trequires: [\n\t\t\t\"circle-translate\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"circle-pitch-scale\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"map\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"circle-pitch-alignment\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"viewport\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"circle-stroke-width\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"circle-stroke-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"circle-stroke-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t}\n};\nvar paint_heatmap = {\n\t\"heatmap-radius\": {\n\t\ttype: \"number\",\n\t\t\"default\": 30,\n\t\tminimum: 1,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"heatmap-weight\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\ttransition: false,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"heatmap-intensity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"heatmap-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": [\n\t\t\t\"interpolate\",\n\t\t\t[\n\t\t\t\t\"linear\"\n\t\t\t],\n\t\t\t[\n\t\t\t\t\"heatmap-density\"\n\t\t\t],\n\t\t\t0,\n\t\t\t\"rgba(0, 0, 255, 0)\",\n\t\t\t0.1,\n\t\t\t\"royalblue\",\n\t\t\t0.3,\n\t\t\t\"cyan\",\n\t\t\t0.5,\n\t\t\t\"lime\",\n\t\t\t0.7,\n\t\t\t\"yellow\",\n\t\t\t1,\n\t\t\t\"red\"\n\t\t],\n\t\ttransition: false,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"heatmap-density\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"color-ramp\"\n\t},\n\t\"heatmap-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t}\n};\nvar paint_symbol = {\n\t\"icon-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-halo-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"rgba(0, 0, 0, 0)\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-halo-width\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-halo-blur\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"icon-translate\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"icon-image\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"icon-translate-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"map\",\n\t\trequires: [\n\t\t\t\"icon-image\",\n\t\t\t\"icon-translate\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\toverridable: true,\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-halo-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"rgba(0, 0, 0, 0)\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-halo-width\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-halo-blur\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"text-translate\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\trequires: [\n\t\t\t\"text-field\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"text-translate-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"map\",\n\t\trequires: [\n\t\t\t\"text-field\",\n\t\t\t\"text-translate\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t}\n};\nvar paint_raster = {\n\t\"raster-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"raster-hue-rotate\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tperiod: 360,\n\t\ttransition: true,\n\t\tunits: \"degrees\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"raster-brightness-min\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"raster-brightness-max\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"raster-saturation\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: -1,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"raster-contrast\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: -1,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"raster-resampling\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tlinear: {\n\t\t\t},\n\t\t\tnearest: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"linear\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"raster-fade-duration\": {\n\t\ttype: \"number\",\n\t\t\"default\": 300,\n\t\tminimum: 0,\n\t\ttransition: false,\n\t\tunits: \"milliseconds\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t}\n};\nvar paint_hillshade = {\n\t\"hillshade-illumination-direction\": {\n\t\ttype: \"number\",\n\t\t\"default\": 335,\n\t\tminimum: 0,\n\t\tmaximum: 359,\n\t\ttransition: false,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"hillshade-illumination-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"viewport\",\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"hillshade-exaggeration\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0.5,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"hillshade-shadow-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"hillshade-highlight-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#FFFFFF\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"hillshade-accent-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t}\n};\nvar paint_background = {\n\t\"background-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"!\": \"background-pattern\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"background-pattern\": {\n\t\ttype: \"resolvedImage\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"cross-faded\"\n\t},\n\t\"background-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t}\n};\nvar transition = {\n\tduration: {\n\t\ttype: \"number\",\n\t\t\"default\": 300,\n\t\tminimum: 0,\n\t\tunits: \"milliseconds\"\n\t},\n\tdelay: {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\tunits: \"milliseconds\"\n\t}\n};\nvar promoteId = {\n\t\"*\": {\n\t\ttype: \"string\"\n\t}\n};\nvar v8Spec = {\n\t$version: $version,\n\t$root: $root,\n\tsources: sources,\n\tsource: source,\n\tsource_vector: source_vector,\n\tsource_raster: source_raster,\n\tsource_raster_dem: source_raster_dem,\n\tsource_geojson: source_geojson,\n\tsource_video: source_video,\n\tsource_image: source_image,\n\tlayer: layer,\n\tlayout: layout,\n\tlayout_background: layout_background,\n\tlayout_fill: layout_fill,\n\tlayout_circle: layout_circle,\n\tlayout_heatmap: layout_heatmap,\n\t\"layout_fill-extrusion\": {\n\tvisibility: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tvisible: {\n\t\t\t},\n\t\t\tnone: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"visible\",\n\t\t\"property-type\": \"constant\"\n\t}\n},\n\tlayout_line: layout_line,\n\tlayout_symbol: layout_symbol,\n\tlayout_raster: layout_raster,\n\tlayout_hillshade: layout_hillshade,\n\tfilter: filter,\n\tfilter_operator: filter_operator,\n\tgeometry_type: geometry_type,\n\t\"function\": {\n\texpression: {\n\t\ttype: \"expression\"\n\t},\n\tstops: {\n\t\ttype: \"array\",\n\t\tvalue: \"function_stop\"\n\t},\n\tbase: {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0\n\t},\n\tproperty: {\n\t\ttype: \"string\",\n\t\t\"default\": \"$zoom\"\n\t},\n\ttype: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tidentity: {\n\t\t\t},\n\t\t\texponential: {\n\t\t\t},\n\t\t\tinterval: {\n\t\t\t},\n\t\t\tcategorical: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"exponential\"\n\t},\n\tcolorSpace: {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\trgb: {\n\t\t\t},\n\t\t\tlab: {\n\t\t\t},\n\t\t\thcl: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"rgb\"\n\t},\n\t\"default\": {\n\t\ttype: \"*\",\n\t\trequired: false\n\t}\n},\n\tfunction_stop: function_stop,\n\texpression: expression$1,\n\tlight: light,\n\tsky: sky,\n\tterrain: terrain,\n\tprojection: projection,\n\tpaint: paint,\n\tpaint_fill: paint_fill,\n\t\"paint_fill-extrusion\": {\n\t\"fill-extrusion-opacity\": {\n\t\ttype: \"number\",\n\t\t\"default\": 1,\n\t\tminimum: 0,\n\t\tmaximum: 1,\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"fill-extrusion-color\": {\n\t\ttype: \"color\",\n\t\t\"default\": \"#000000\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t{\n\t\t\t\t\"!\": \"fill-extrusion-pattern\"\n\t\t\t}\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"fill-extrusion-translate\": {\n\t\ttype: \"array\",\n\t\tvalue: \"number\",\n\t\tlength: 2,\n\t\t\"default\": [\n\t\t\t0,\n\t\t\t0\n\t\t],\n\t\ttransition: true,\n\t\tunits: \"pixels\",\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"fill-extrusion-translate-anchor\": {\n\t\ttype: \"enum\",\n\t\tvalues: {\n\t\t\tmap: {\n\t\t\t},\n\t\t\tviewport: {\n\t\t\t}\n\t\t},\n\t\t\"default\": \"map\",\n\t\trequires: [\n\t\t\t\"fill-extrusion-translate\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t},\n\t\"fill-extrusion-pattern\": {\n\t\ttype: \"resolvedImage\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"cross-faded-data-driven\"\n\t},\n\t\"fill-extrusion-height\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\tunits: \"meters\",\n\t\ttransition: true,\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"fill-extrusion-base\": {\n\t\ttype: \"number\",\n\t\t\"default\": 0,\n\t\tminimum: 0,\n\t\tunits: \"meters\",\n\t\ttransition: true,\n\t\trequires: [\n\t\t\t\"fill-extrusion-height\"\n\t\t],\n\t\texpression: {\n\t\t\tinterpolated: true,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\",\n\t\t\t\t\"feature\",\n\t\t\t\t\"feature-state\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-driven\"\n\t},\n\t\"fill-extrusion-vertical-gradient\": {\n\t\ttype: \"boolean\",\n\t\t\"default\": true,\n\t\ttransition: false,\n\t\texpression: {\n\t\t\tinterpolated: false,\n\t\t\tparameters: [\n\t\t\t\t\"zoom\"\n\t\t\t]\n\t\t},\n\t\t\"property-type\": \"data-constant\"\n\t}\n},\n\tpaint_line: paint_line,\n\tpaint_circle: paint_circle,\n\tpaint_heatmap: paint_heatmap,\n\tpaint_symbol: paint_symbol,\n\tpaint_raster: paint_raster,\n\tpaint_hillshade: paint_hillshade,\n\tpaint_background: paint_background,\n\ttransition: transition,\n\t\"property-type\": {\n\t\"data-driven\": {\n\t\ttype: \"property-type\"\n\t},\n\t\"cross-faded\": {\n\t\ttype: \"property-type\"\n\t},\n\t\"cross-faded-data-driven\": {\n\t\ttype: \"property-type\"\n\t},\n\t\"color-ramp\": {\n\t\ttype: \"property-type\"\n\t},\n\t\"data-constant\": {\n\t\ttype: \"property-type\"\n\t},\n\tconstant: {\n\t\ttype: \"property-type\"\n\t}\n},\n\tpromoteId: promoteId\n};\n\nconst refProperties = ['type', 'source', 'source-layer', 'minzoom', 'maxzoom', 'filter', 'layout'];\n\nfunction deref(layer, parent) {\n const result = {};\n for (const k in layer) {\n if (k !== 'ref') {\n result[k] = layer[k];\n }\n }\n refProperties.forEach((k) => {\n if (k in parent) {\n result[k] = parent[k];\n }\n });\n return result;\n}\n/**\n * Given an array of layers, some of which may contain `ref` properties\n * whose value is the `id` of another property, return a new array where\n * such layers have been augmented with the 'type', 'source', etc. properties\n * from the parent layer, and the `ref` property has been removed.\n *\n * The input is not modified. The output may contain references to portions\n * of the input.\n *\n * @private\n * @param {Array} layers\n * @returns {Array}\n */\nfunction derefLayers(layers) {\n layers = layers.slice();\n const map = Object.create(null);\n for (let i = 0; i < layers.length; i++) {\n map[layers[i].id] = layers[i];\n }\n for (let i = 0; i < layers.length; i++) {\n if ('ref' in layers[i]) {\n layers[i] = deref(layers[i], map[layers[i].ref]);\n }\n }\n return layers;\n}\n\n/**\n * Deeply compares two object literals.\n *\n * @private\n */\nfunction deepEqual(a, b) {\n if (Array.isArray(a)) {\n if (!Array.isArray(b) || a.length !== b.length)\n return false;\n for (let i = 0; i < a.length; i++) {\n if (!deepEqual(a[i], b[i]))\n return false;\n }\n return true;\n }\n if (typeof a === 'object' && a !== null && b !== null) {\n if (!(typeof b === 'object'))\n return false;\n const keys = Object.keys(a);\n if (keys.length !== Object.keys(b).length)\n return false;\n for (const key in a) {\n if (!deepEqual(a[key], b[key]))\n return false;\n }\n return true;\n }\n return a === b;\n}\n\n/**\n * The main reason for this method is to allow type check when adding a command to the array.\n * @param commands - The commands array to add to\n * @param command - The command to add\n */\nfunction addCommand(commands, command) {\n commands.push(command);\n}\nfunction addSource(sourceId, after, commands) {\n addCommand(commands, { command: 'addSource', args: [sourceId, after[sourceId]] });\n}\nfunction removeSource(sourceId, commands, sourcesRemoved) {\n addCommand(commands, { command: 'removeSource', args: [sourceId] });\n sourcesRemoved[sourceId] = true;\n}\nfunction updateSource(sourceId, after, commands, sourcesRemoved) {\n removeSource(sourceId, commands, sourcesRemoved);\n addSource(sourceId, after, commands);\n}\nfunction canUpdateGeoJSON(before, after, sourceId) {\n let prop;\n for (prop in before[sourceId]) {\n if (!Object.prototype.hasOwnProperty.call(before[sourceId], prop))\n continue;\n if (prop !== 'data' && !deepEqual(before[sourceId][prop], after[sourceId][prop])) {\n return false;\n }\n }\n for (prop in after[sourceId]) {\n if (!Object.prototype.hasOwnProperty.call(after[sourceId], prop))\n continue;\n if (prop !== 'data' && !deepEqual(before[sourceId][prop], after[sourceId][prop])) {\n return false;\n }\n }\n return true;\n}\nfunction diffSources(before, after, commands, sourcesRemoved) {\n before = before || {};\n after = after || {};\n let sourceId;\n // look for sources to remove\n for (sourceId in before) {\n if (!Object.prototype.hasOwnProperty.call(before, sourceId))\n continue;\n if (!Object.prototype.hasOwnProperty.call(after, sourceId)) {\n removeSource(sourceId, commands, sourcesRemoved);\n }\n }\n // look for sources to add/update\n for (sourceId in after) {\n if (!Object.prototype.hasOwnProperty.call(after, sourceId))\n continue;\n if (!Object.prototype.hasOwnProperty.call(before, sourceId)) {\n addSource(sourceId, after, commands);\n }\n else if (!deepEqual(before[sourceId], after[sourceId])) {\n if (before[sourceId].type === 'geojson' && after[sourceId].type === 'geojson' && canUpdateGeoJSON(before, after, sourceId)) {\n addCommand(commands, { command: 'setGeoJSONSourceData', args: [sourceId, after[sourceId].data] });\n }\n else {\n // no update command, must remove then add\n updateSource(sourceId, after, commands, sourcesRemoved);\n }\n }\n }\n}\nfunction diffLayerPropertyChanges(before, after, commands, layerId, klass, command) {\n before = before || {};\n after = after || {};\n for (const prop in before) {\n if (!Object.prototype.hasOwnProperty.call(before, prop))\n continue;\n if (!deepEqual(before[prop], after[prop])) {\n commands.push({ command, args: [layerId, prop, after[prop], klass] });\n }\n }\n for (const prop in after) {\n if (!Object.prototype.hasOwnProperty.call(after, prop) || Object.prototype.hasOwnProperty.call(before, prop))\n continue;\n if (!deepEqual(before[prop], after[prop])) {\n commands.push({ command, args: [layerId, prop, after[prop], klass] });\n }\n }\n}\nfunction pluckId(layer) {\n return layer.id;\n}\nfunction indexById(group, layer) {\n group[layer.id] = layer;\n return group;\n}\nfunction diffLayers(before, after, commands) {\n before = before || [];\n after = after || [];\n // order of layers by id\n const beforeOrder = before.map(pluckId);\n const afterOrder = after.map(pluckId);\n // index of layer by id\n const beforeIndex = before.reduce(indexById, {});\n const afterIndex = after.reduce(indexById, {});\n // track order of layers as if they have been mutated\n const tracker = beforeOrder.slice();\n // layers that have been added do not need to be diffed\n const clean = Object.create(null);\n let layerId;\n let beforeLayer;\n let afterLayer;\n let insertBeforeLayerId;\n let prop;\n // remove layers\n for (let i = 0, d = 0; i < beforeOrder.length; i++) {\n layerId = beforeOrder[i];\n if (!Object.prototype.hasOwnProperty.call(afterIndex, layerId)) {\n addCommand(commands, { command: 'removeLayer', args: [layerId] });\n tracker.splice(tracker.indexOf(layerId, d), 1);\n }\n else {\n // limit where in tracker we need to look for a match\n d++;\n }\n }\n // add/reorder layers\n for (let i = 0, d = 0; i < afterOrder.length; i++) {\n // work backwards as insert is before an existing layer\n layerId = afterOrder[afterOrder.length - 1 - i];\n if (tracker[tracker.length - 1 - i] === layerId)\n continue;\n if (Object.prototype.hasOwnProperty.call(beforeIndex, layerId)) {\n // remove the layer before we insert at the correct position\n addCommand(commands, { command: 'removeLayer', args: [layerId] });\n tracker.splice(tracker.lastIndexOf(layerId, tracker.length - d), 1);\n }\n else {\n // limit where in tracker we need to look for a match\n d++;\n }\n // add layer at correct position\n insertBeforeLayerId = tracker[tracker.length - i];\n addCommand(commands, { command: 'addLayer', args: [afterIndex[layerId], insertBeforeLayerId] });\n tracker.splice(tracker.length - i, 0, layerId);\n clean[layerId] = true;\n }\n // update layers\n for (let i = 0; i < afterOrder.length; i++) {\n layerId = afterOrder[i];\n beforeLayer = beforeIndex[layerId];\n afterLayer = afterIndex[layerId];\n // no need to update if previously added (new or moved)\n if (clean[layerId] || deepEqual(beforeLayer, afterLayer))\n continue;\n // If source, source-layer, or type have changes, then remove the layer\n // and add it back 'from scratch'.\n if (!deepEqual(beforeLayer.source, afterLayer.source) || !deepEqual(beforeLayer['source-layer'], afterLayer['source-layer']) || !deepEqual(beforeLayer.type, afterLayer.type)) {\n addCommand(commands, { command: 'removeLayer', args: [layerId] });\n // we add the layer back at the same position it was already in, so\n // there's no need to update the `tracker`\n insertBeforeLayerId = tracker[tracker.lastIndexOf(layerId) + 1];\n addCommand(commands, { command: 'addLayer', args: [afterLayer, insertBeforeLayerId] });\n continue;\n }\n // layout, paint, filter, minzoom, maxzoom\n diffLayerPropertyChanges(beforeLayer.layout, afterLayer.layout, commands, layerId, null, 'setLayoutProperty');\n diffLayerPropertyChanges(beforeLayer.paint, afterLayer.paint, commands, layerId, null, 'setPaintProperty');\n if (!deepEqual(beforeLayer.filter, afterLayer.filter)) {\n addCommand(commands, { command: 'setFilter', args: [layerId, afterLayer.filter] });\n }\n if (!deepEqual(beforeLayer.minzoom, afterLayer.minzoom) || !deepEqual(beforeLayer.maxzoom, afterLayer.maxzoom)) {\n addCommand(commands, { command: 'setLayerZoomRange', args: [layerId, afterLayer.minzoom, afterLayer.maxzoom] });\n }\n // handle all other layer props, including paint.*\n for (prop in beforeLayer) {\n if (!Object.prototype.hasOwnProperty.call(beforeLayer, prop))\n continue;\n if (prop === 'layout' || prop === 'paint' || prop === 'filter' ||\n prop === 'metadata' || prop === 'minzoom' || prop === 'maxzoom')\n continue;\n if (prop.indexOf('paint.') === 0) {\n diffLayerPropertyChanges(beforeLayer[prop], afterLayer[prop], commands, layerId, prop.slice(6), 'setPaintProperty');\n }\n else if (!deepEqual(beforeLayer[prop], afterLayer[prop])) {\n addCommand(commands, { command: 'setLayerProperty', args: [layerId, prop, afterLayer[prop]] });\n }\n }\n for (prop in afterLayer) {\n if (!Object.prototype.hasOwnProperty.call(afterLayer, prop) || Object.prototype.hasOwnProperty.call(beforeLayer, prop))\n continue;\n if (prop === 'layout' || prop === 'paint' || prop === 'filter' ||\n prop === 'metadata' || prop === 'minzoom' || prop === 'maxzoom')\n continue;\n if (prop.indexOf('paint.') === 0) {\n diffLayerPropertyChanges(beforeLayer[prop], afterLayer[prop], commands, layerId, prop.slice(6), 'setPaintProperty');\n }\n else if (!deepEqual(beforeLayer[prop], afterLayer[prop])) {\n addCommand(commands, { command: 'setLayerProperty', args: [layerId, prop, afterLayer[prop]] });\n }\n }\n }\n}\n/**\n * Diff two stylesheet\n *\n * Creates semanticly aware diffs that can easily be applied at runtime.\n * Operations produced by the diff closely resemble the maplibre-gl-js API. Any\n * error creating the diff will fall back to the 'setStyle' operation.\n *\n * Example diff:\n * [\n * { command: 'setConstant', args: ['@water', '#0000FF'] },\n * { command: 'setPaintProperty', args: ['background', 'background-color', 'black'] }\n * ]\n *\n * @private\n * @param {*} [before] stylesheet to compare from\n * @param {*} after stylesheet to compare to\n * @returns Array list of changes\n */\nfunction diffStyles(before, after) {\n if (!before)\n return [{ command: 'setStyle', args: [after] }];\n let commands = [];\n try {\n // Handle changes to top-level properties\n if (!deepEqual(before.version, after.version)) {\n return [{ command: 'setStyle', args: [after] }];\n }\n if (!deepEqual(before.center, after.center)) {\n commands.push({ command: 'setCenter', args: [after.center] });\n }\n if (!deepEqual(before.zoom, after.zoom)) {\n commands.push({ command: 'setZoom', args: [after.zoom] });\n }\n if (!deepEqual(before.bearing, after.bearing)) {\n commands.push({ command: 'setBearing', args: [after.bearing] });\n }\n if (!deepEqual(before.pitch, after.pitch)) {\n commands.push({ command: 'setPitch', args: [after.pitch] });\n }\n if (!deepEqual(before.sprite, after.sprite)) {\n commands.push({ command: 'setSprite', args: [after.sprite] });\n }\n if (!deepEqual(before.glyphs, after.glyphs)) {\n commands.push({ command: 'setGlyphs', args: [after.glyphs] });\n }\n if (!deepEqual(before.transition, after.transition)) {\n commands.push({ command: 'setTransition', args: [after.transition] });\n }\n if (!deepEqual(before.light, after.light)) {\n commands.push({ command: 'setLight', args: [after.light] });\n }\n if (!deepEqual(before.terrain, after.terrain)) {\n commands.push({ command: 'setTerrain', args: [after.terrain] });\n }\n if (!deepEqual(before.sky, after.sky)) {\n commands.push({ command: 'setSky', args: [after.sky] });\n }\n if (!deepEqual(before.projection, after.projection)) {\n commands.push({ command: 'setProjection', args: [after.projection] });\n }\n // Handle changes to `sources`\n // If a source is to be removed, we also--before the removeSource\n // command--need to remove all the style layers that depend on it.\n const sourcesRemoved = {};\n // First collect the {add,remove}Source commands\n const removeOrAddSourceCommands = [];\n diffSources(before.sources, after.sources, removeOrAddSourceCommands, sourcesRemoved);\n // Push a removeLayer command for each style layer that depends on a\n // source that's being removed.\n // Also, exclude any such layers them from the input to `diffLayers`\n // below, so that diffLayers produces the appropriate `addLayers`\n // command\n const beforeLayers = [];\n if (before.layers) {\n before.layers.forEach((layer) => {\n if ('source' in layer && sourcesRemoved[layer.source]) {\n commands.push({ command: 'removeLayer', args: [layer.id] });\n }\n else {\n beforeLayers.push(layer);\n }\n });\n }\n commands = commands.concat(removeOrAddSourceCommands);\n // Handle changes to `layers`\n diffLayers(beforeLayers, after.layers, commands);\n }\n catch (e) {\n // fall back to setStyle\n console.warn('Unable to compute style diff:', e);\n commands = [{ command: 'setStyle', args: [after] }];\n }\n return commands;\n}\n\n// Note: Do not inherit from Error. It breaks when transpiling to ES5.\nclass ValidationError {\n constructor(key, value, message, identifier) {\n this.message = (key ? `${key}: ` : '') + message;\n if (identifier)\n this.identifier = identifier;\n if (value !== null && value !== undefined && value.__line__) {\n this.line = value.__line__;\n }\n }\n}\n\n// Note: Do not inherit from Error. It breaks when transpiling to ES5.\nclass ParsingError {\n constructor(error) {\n this.error = error;\n this.message = error.message;\n const match = error.message.match(/line (\\d+)/);\n this.line = match ? parseInt(match[1], 10) : 0;\n }\n}\n\nfunction extendBy(output, ...inputs) {\n for (const input of inputs) {\n for (const k in input) {\n output[k] = input[k];\n }\n }\n return output;\n}\n\nclass ExpressionParsingError extends Error {\n constructor(key, message) {\n super(message);\n this.message = message;\n this.key = key;\n }\n}\n\n/**\n * Tracks `let` bindings during expression parsing.\n * @private\n */\nclass Scope {\n constructor(parent, bindings = []) {\n this.parent = parent;\n this.bindings = {};\n for (const [name, expression] of bindings) {\n this.bindings[name] = expression;\n }\n }\n concat(bindings) {\n return new Scope(this, bindings);\n }\n get(name) {\n if (this.bindings[name]) {\n return this.bindings[name];\n }\n if (this.parent) {\n return this.parent.get(name);\n }\n throw new Error(`${name} not found in scope.`);\n }\n has(name) {\n if (this.bindings[name])\n return true;\n return this.parent ? this.parent.has(name) : false;\n }\n}\n\nconst NullType = { kind: 'null' };\nconst NumberType = { kind: 'number' };\nconst StringType = { kind: 'string' };\nconst BooleanType = { kind: 'boolean' };\nconst ColorType = { kind: 'color' };\nconst ObjectType = { kind: 'object' };\nconst ValueType = { kind: 'value' };\nconst ErrorType = { kind: 'error' };\nconst CollatorType = { kind: 'collator' };\nconst FormattedType = { kind: 'formatted' };\nconst PaddingType = { kind: 'padding' };\nconst ResolvedImageType = { kind: 'resolvedImage' };\nconst VariableAnchorOffsetCollectionType = { kind: 'variableAnchorOffsetCollection' };\nfunction array$1(itemType, N) {\n return {\n kind: 'array',\n itemType,\n N\n };\n}\nfunction toString$1(type) {\n if (type.kind === 'array') {\n const itemType = toString$1(type.itemType);\n return typeof type.N === 'number' ?\n `array<${itemType}, ${type.N}>` :\n type.itemType.kind === 'value' ? 'array' : `array<${itemType}>`;\n }\n else {\n return type.kind;\n }\n}\nconst valueMemberTypes = [\n NullType,\n NumberType,\n StringType,\n BooleanType,\n ColorType,\n FormattedType,\n ObjectType,\n array$1(ValueType),\n PaddingType,\n ResolvedImageType,\n VariableAnchorOffsetCollectionType\n];\n/**\n * Returns null if `t` is a subtype of `expected`; otherwise returns an\n * error message.\n * @private\n */\nfunction checkSubtype(expected, t) {\n if (t.kind === 'error') {\n // Error is a subtype of every type\n return null;\n }\n else if (expected.kind === 'array') {\n if (t.kind === 'array' &&\n ((t.N === 0 && t.itemType.kind === 'value') || !checkSubtype(expected.itemType, t.itemType)) &&\n (typeof expected.N !== 'number' || expected.N === t.N)) {\n return null;\n }\n }\n else if (expected.kind === t.kind) {\n return null;\n }\n else if (expected.kind === 'value') {\n for (const memberType of valueMemberTypes) {\n if (!checkSubtype(memberType, t)) {\n return null;\n }\n }\n }\n return `Expected ${toString$1(expected)} but found ${toString$1(t)} instead.`;\n}\nfunction isValidType(provided, allowedTypes) {\n return allowedTypes.some(t => t.kind === provided.kind);\n}\nfunction isValidNativeType(provided, allowedTypes) {\n return allowedTypes.some(t => {\n if (t === 'null') {\n return provided === null;\n }\n else if (t === 'array') {\n return Array.isArray(provided);\n }\n else if (t === 'object') {\n return provided && !Array.isArray(provided) && typeof provided === 'object';\n }\n else {\n return t === typeof provided;\n }\n });\n}\n/**\n * Verify whether the specified type is of the same type as the specified sample.\n *\n * @param provided Type to verify\n * @param sample Sample type to reference\n * @returns `true` if both objects are of the same type, `false` otherwise\n * @example basic types\n * if (verifyType(outputType, ValueType)) {\n * // type narrowed to:\n * outputType.kind; // 'value'\n * }\n * @example array types\n * if (verifyType(outputType, array(NumberType))) {\n * // type narrowed to:\n * outputType.kind; // 'array'\n * outputType.itemType; // NumberTypeT\n * outputType.itemType.kind; // 'number'\n * }\n */\nfunction verifyType(provided, sample) {\n if (provided.kind === 'array' && sample.kind === 'array') {\n return provided.itemType.kind === sample.itemType.kind && typeof provided.N === 'number';\n }\n return provided.kind === sample.kind;\n}\n\n// See https://observablehq.com/@mbostock/lab-and-rgb\nconst Xn = 0.96422, Yn = 1, Zn = 0.82521, t0 = 4 / 29, t1 = 6 / 29, t2 = 3 * t1 * t1, t3 = t1 * t1 * t1, deg2rad = Math.PI / 180, rad2deg = 180 / Math.PI;\nfunction constrainAngle(angle) {\n angle = angle % 360;\n if (angle < 0) {\n angle += 360;\n }\n return angle;\n}\nfunction rgbToLab([r, g, b, alpha]) {\n r = rgb2xyz(r);\n g = rgb2xyz(g);\n b = rgb2xyz(b);\n let x, z;\n const y = xyz2lab((0.2225045 * r + 0.7168786 * g + 0.0606169 * b) / Yn);\n if (r === g && g === b) {\n x = z = y;\n }\n else {\n x = xyz2lab((0.4360747 * r + 0.3850649 * g + 0.1430804 * b) / Xn);\n z = xyz2lab((0.0139322 * r + 0.0971045 * g + 0.7141733 * b) / Zn);\n }\n const l = 116 * y - 16;\n return [(l < 0) ? 0 : l, 500 * (x - y), 200 * (y - z), alpha];\n}\nfunction rgb2xyz(x) {\n return (x <= 0.04045) ? x / 12.92 : Math.pow((x + 0.055) / 1.055, 2.4);\n}\nfunction xyz2lab(t) {\n return (t > t3) ? Math.pow(t, 1 / 3) : t / t2 + t0;\n}\nfunction labToRgb([l, a, b, alpha]) {\n let y = (l + 16) / 116, x = isNaN(a) ? y : y + a / 500, z = isNaN(b) ? y : y - b / 200;\n y = Yn * lab2xyz(y);\n x = Xn * lab2xyz(x);\n z = Zn * lab2xyz(z);\n return [\n xyz2rgb(3.1338561 * x - 1.6168667 * y - 0.4906146 * z), // D50 -> sRGB\n xyz2rgb(-0.9787684 * x + 1.9161415 * y + 0.0334540 * z),\n xyz2rgb(0.0719453 * x - 0.2289914 * y + 1.4052427 * z),\n alpha,\n ];\n}\nfunction xyz2rgb(x) {\n x = (x <= 0.00304) ? 12.92 * x : 1.055 * Math.pow(x, 1 / 2.4) - 0.055;\n return (x < 0) ? 0 : (x > 1) ? 1 : x; // clip to 0..1 range\n}\nfunction lab2xyz(t) {\n return (t > t1) ? t * t * t : t2 * (t - t0);\n}\nfunction rgbToHcl(rgbColor) {\n const [l, a, b, alpha] = rgbToLab(rgbColor);\n const c = Math.sqrt(a * a + b * b);\n const h = Math.round(c * 10000) ? constrainAngle(Math.atan2(b, a) * rad2deg) : NaN;\n return [h, c, l, alpha];\n}\nfunction hclToRgb([h, c, l, alpha]) {\n h = isNaN(h) ? 0 : h * deg2rad;\n return labToRgb([l, Math.cos(h) * c, Math.sin(h) * c, alpha]);\n}\n// https://drafts.csswg.org/css-color-4/#hsl-to-rgb\nfunction hslToRgb([h, s, l, alpha]) {\n h = constrainAngle(h);\n s /= 100;\n l /= 100;\n function f(n) {\n const k = (n + h / 30) % 12;\n const a = s * Math.min(l, 1 - l);\n return l - a * Math.max(-1, Math.min(k - 3, 9 - k, 1));\n }\n return [f(0), f(8), f(4), alpha];\n}\n\n/**\n * CSS color parser compliant with CSS Color 4 Specification.\n * Supports: named colors, `transparent` keyword, all rgb hex notations,\n * rgb(), rgba(), hsl() and hsla() functions.\n * Does not round the parsed values to integers from the range 0..255.\n *\n * Syntax:\n *\n * = | \n * = | \n *\n * rgb() = rgb( {3} [ / ]? ) | rgb( {3} [ / ]? )\n * rgb() = rgb( #{3} , ? ) | rgb( #{3} , ? )\n *\n * hsl() = hsl( [ / ]? )\n * hsl() = hsl( , , , ? )\n *\n * Caveats:\n * - - with optional `deg` suffix; `grad`, `rad`, `turn` are not supported\n * - `none` keyword is not supported\n * - comments inside rgb()/hsl() are not supported\n * - legacy color syntax rgba() is supported with an identical grammar and behavior to rgb()\n * - legacy color syntax hsla() is supported with an identical grammar and behavior to hsl()\n *\n * @param input CSS color string to parse.\n * @returns Color in sRGB color space, with `red`, `green`, `blue`\n * and `alpha` channels normalized to the range 0..1,\n * or `undefined` if the input is not a valid color string.\n */\nfunction parseCssColor(input) {\n input = input.toLowerCase().trim();\n if (input === 'transparent') {\n return [0, 0, 0, 0];\n }\n // 'white', 'black', 'blue'\n const namedColorsMatch = namedColors[input];\n if (namedColorsMatch) {\n const [r, g, b] = namedColorsMatch;\n return [r / 255, g / 255, b / 255, 1];\n }\n // #f0c, #f0cf, #ff00cc, #ff00ccff\n if (input.startsWith('#')) {\n const hexRegexp = /^#(?:[0-9a-f]{3,4}|[0-9a-f]{6}|[0-9a-f]{8})$/;\n if (hexRegexp.test(input)) {\n const step = input.length < 6 ? 1 : 2;\n let i = 1;\n return [\n parseHex(input.slice(i, i += step)),\n parseHex(input.slice(i, i += step)),\n parseHex(input.slice(i, i += step)),\n parseHex(input.slice(i, i + step) || 'ff'),\n ];\n }\n }\n // rgb(128 0 0), rgb(50% 0% 0%), rgba(255,0,255,0.6), rgb(255 0 255 / 60%), rgb(100% 0% 100% /.6)\n if (input.startsWith('rgb')) {\n const rgbRegExp = /^rgba?\\(\\s*([\\de.+-]+)(%)?(?:\\s+|\\s*(,)\\s*)([\\de.+-]+)(%)?(?:\\s+|\\s*(,)\\s*)([\\de.+-]+)(%)?(?:\\s*([,\\/])\\s*([\\de.+-]+)(%)?)?\\s*\\)$/;\n const rgbMatch = input.match(rgbRegExp);\n if (rgbMatch) {\n const [_, // eslint-disable-line @typescript-eslint/no-unused-vars\n r, // \n rp, // % (optional)\n f1, // , (optional)\n g, // \n gp, // % (optional)\n f2, // , (optional)\n b, // \n bp, // % (optional)\n f3, // ,|/ (optional)\n a, // (optional)\n ap, // % (optional)\n ] = rgbMatch;\n const argFormat = [f1 || ' ', f2 || ' ', f3].join('');\n if (argFormat === ' ' ||\n argFormat === ' /' ||\n argFormat === ',,' ||\n argFormat === ',,,') {\n const valFormat = [rp, gp, bp].join('');\n const maxValue = (valFormat === '%%%') ? 100 :\n (valFormat === '') ? 255 : 0;\n if (maxValue) {\n const rgba = [\n clamp(+r / maxValue, 0, 1),\n clamp(+g / maxValue, 0, 1),\n clamp(+b / maxValue, 0, 1),\n a ? parseAlpha(+a, ap) : 1,\n ];\n if (validateNumbers(rgba)) {\n return rgba;\n }\n // invalid numbers\n }\n // values must be all numbers or all percentages\n }\n return; // comma optional syntax requires no commas at all\n }\n }\n // hsl(120 50% 80%), hsla(120deg,50%,80%,.9), hsl(12e1 50% 80% / 90%)\n const hslRegExp = /^hsla?\\(\\s*([\\de.+-]+)(?:deg)?(?:\\s+|\\s*(,)\\s*)([\\de.+-]+)%(?:\\s+|\\s*(,)\\s*)([\\de.+-]+)%(?:\\s*([,\\/])\\s*([\\de.+-]+)(%)?)?\\s*\\)$/;\n const hslMatch = input.match(hslRegExp);\n if (hslMatch) {\n const [_, // eslint-disable-line @typescript-eslint/no-unused-vars\n h, // \n f1, // , (optional)\n s, // \n f2, // , (optional)\n l, // \n f3, // ,|/ (optional)\n a, // (optional)\n ap, // % (optional)\n ] = hslMatch;\n const argFormat = [f1 || ' ', f2 || ' ', f3].join('');\n if (argFormat === ' ' ||\n argFormat === ' /' ||\n argFormat === ',,' ||\n argFormat === ',,,') {\n const hsla = [\n +h,\n clamp(+s, 0, 100),\n clamp(+l, 0, 100),\n a ? parseAlpha(+a, ap) : 1,\n ];\n if (validateNumbers(hsla)) {\n return hslToRgb(hsla);\n }\n // invalid numbers\n }\n // comma optional syntax requires no commas at all\n }\n}\nfunction parseHex(hex) {\n return parseInt(hex.padEnd(2, hex), 16) / 255;\n}\nfunction parseAlpha(a, asPercentage) {\n return clamp(asPercentage ? (a / 100) : a, 0, 1);\n}\nfunction clamp(n, min, max) {\n return Math.min(Math.max(min, n), max);\n}\n/**\n * The regular expression for numeric values is not super specific, and it may\n * happen that it will accept a value that is not a valid number. In order to\n * detect and eliminate such values this function exists.\n *\n * @param array Array of uncertain numbers.\n * @returns `true` if the specified array contains only valid numbers, `false` otherwise.\n */\nfunction validateNumbers(array) {\n return !array.some(Number.isNaN);\n}\n/**\n * To generate:\n * - visit {@link https://www.w3.org/TR/css-color-4/#named-colors}\n * - run in the console:\n * @example\n * copy(`{\\n${[...document.querySelector('.named-color-table tbody').children].map((tr) => `${tr.cells[2].textContent.trim()}: [${tr.cells[4].textContent.trim().split(/\\s+/).join(', ')}],`).join('\\n')}\\n}`);\n */\nconst namedColors = {\n aliceblue: [240, 248, 255],\n antiquewhite: [250, 235, 215],\n aqua: [0, 255, 255],\n aquamarine: [127, 255, 212],\n azure: [240, 255, 255],\n beige: [245, 245, 220],\n bisque: [255, 228, 196],\n black: [0, 0, 0],\n blanchedalmond: [255, 235, 205],\n blue: [0, 0, 255],\n blueviolet: [138, 43, 226],\n brown: [165, 42, 42],\n burlywood: [222, 184, 135],\n cadetblue: [95, 158, 160],\n chartreuse: [127, 255, 0],\n chocolate: [210, 105, 30],\n coral: [255, 127, 80],\n cornflowerblue: [100, 149, 237],\n cornsilk: [255, 248, 220],\n crimson: [220, 20, 60],\n cyan: [0, 255, 255],\n darkblue: [0, 0, 139],\n darkcyan: [0, 139, 139],\n darkgoldenrod: [184, 134, 11],\n darkgray: [169, 169, 169],\n darkgreen: [0, 100, 0],\n darkgrey: [169, 169, 169],\n darkkhaki: [189, 183, 107],\n darkmagenta: [139, 0, 139],\n darkolivegreen: [85, 107, 47],\n darkorange: [255, 140, 0],\n darkorchid: [153, 50, 204],\n darkred: [139, 0, 0],\n darksalmon: [233, 150, 122],\n darkseagreen: [143, 188, 143],\n darkslateblue: [72, 61, 139],\n darkslategray: [47, 79, 79],\n darkslategrey: [47, 79, 79],\n darkturquoise: [0, 206, 209],\n darkviolet: [148, 0, 211],\n deeppink: [255, 20, 147],\n deepskyblue: [0, 191, 255],\n dimgray: [105, 105, 105],\n dimgrey: [105, 105, 105],\n dodgerblue: [30, 144, 255],\n firebrick: [178, 34, 34],\n floralwhite: [255, 250, 240],\n forestgreen: [34, 139, 34],\n fuchsia: [255, 0, 255],\n gainsboro: [220, 220, 220],\n ghostwhite: [248, 248, 255],\n gold: [255, 215, 0],\n goldenrod: [218, 165, 32],\n gray: [128, 128, 128],\n green: [0, 128, 0],\n greenyellow: [173, 255, 47],\n grey: [128, 128, 128],\n honeydew: [240, 255, 240],\n hotpink: [255, 105, 180],\n indianred: [205, 92, 92],\n indigo: [75, 0, 130],\n ivory: [255, 255, 240],\n khaki: [240, 230, 140],\n lavender: [230, 230, 250],\n lavenderblush: [255, 240, 245],\n lawngreen: [124, 252, 0],\n lemonchiffon: [255, 250, 205],\n lightblue: [173, 216, 230],\n lightcoral: [240, 128, 128],\n lightcyan: [224, 255, 255],\n lightgoldenrodyellow: [250, 250, 210],\n lightgray: [211, 211, 211],\n lightgreen: [144, 238, 144],\n lightgrey: [211, 211, 211],\n lightpink: [255, 182, 193],\n lightsalmon: [255, 160, 122],\n lightseagreen: [32, 178, 170],\n lightskyblue: [135, 206, 250],\n lightslategray: [119, 136, 153],\n lightslategrey: [119, 136, 153],\n lightsteelblue: [176, 196, 222],\n lightyellow: [255, 255, 224],\n lime: [0, 255, 0],\n limegreen: [50, 205, 50],\n linen: [250, 240, 230],\n magenta: [255, 0, 255],\n maroon: [128, 0, 0],\n mediumaquamarine: [102, 205, 170],\n mediumblue: [0, 0, 205],\n mediumorchid: [186, 85, 211],\n mediumpurple: [147, 112, 219],\n mediumseagreen: [60, 179, 113],\n mediumslateblue: [123, 104, 238],\n mediumspringgreen: [0, 250, 154],\n mediumturquoise: [72, 209, 204],\n mediumvioletred: [199, 21, 133],\n midnightblue: [25, 25, 112],\n mintcream: [245, 255, 250],\n mistyrose: [255, 228, 225],\n moccasin: [255, 228, 181],\n navajowhite: [255, 222, 173],\n navy: [0, 0, 128],\n oldlace: [253, 245, 230],\n olive: [128, 128, 0],\n olivedrab: [107, 142, 35],\n orange: [255, 165, 0],\n orangered: [255, 69, 0],\n orchid: [218, 112, 214],\n palegoldenrod: [238, 232, 170],\n palegreen: [152, 251, 152],\n paleturquoise: [175, 238, 238],\n palevioletred: [219, 112, 147],\n papayawhip: [255, 239, 213],\n peachpuff: [255, 218, 185],\n peru: [205, 133, 63],\n pink: [255, 192, 203],\n plum: [221, 160, 221],\n powderblue: [176, 224, 230],\n purple: [128, 0, 128],\n rebeccapurple: [102, 51, 153],\n red: [255, 0, 0],\n rosybrown: [188, 143, 143],\n royalblue: [65, 105, 225],\n saddlebrown: [139, 69, 19],\n salmon: [250, 128, 114],\n sandybrown: [244, 164, 96],\n seagreen: [46, 139, 87],\n seashell: [255, 245, 238],\n sienna: [160, 82, 45],\n silver: [192, 192, 192],\n skyblue: [135, 206, 235],\n slateblue: [106, 90, 205],\n slategray: [112, 128, 144],\n slategrey: [112, 128, 144],\n snow: [255, 250, 250],\n springgreen: [0, 255, 127],\n steelblue: [70, 130, 180],\n tan: [210, 180, 140],\n teal: [0, 128, 128],\n thistle: [216, 191, 216],\n tomato: [255, 99, 71],\n turquoise: [64, 224, 208],\n violet: [238, 130, 238],\n wheat: [245, 222, 179],\n white: [255, 255, 255],\n whitesmoke: [245, 245, 245],\n yellow: [255, 255, 0],\n yellowgreen: [154, 205, 50],\n};\n\n/**\n * Color representation used by WebGL.\n * Defined in sRGB color space and pre-blended with alpha.\n * @private\n */\nclass Color {\n /**\n * @param r Red component premultiplied by `alpha` 0..1\n * @param g Green component premultiplied by `alpha` 0..1\n * @param b Blue component premultiplied by `alpha` 0..1\n * @param [alpha=1] Alpha component 0..1\n * @param [premultiplied=true] Whether the `r`, `g` and `b` values have already\n * been multiplied by alpha. If `true` nothing happens if `false` then they will\n * be multiplied automatically.\n */\n constructor(r, g, b, alpha = 1, premultiplied = true) {\n this.r = r;\n this.g = g;\n this.b = b;\n this.a = alpha;\n if (!premultiplied) {\n this.r *= alpha;\n this.g *= alpha;\n this.b *= alpha;\n if (!alpha) {\n // alpha = 0 erases completely rgb channels. This behavior is not desirable\n // if this particular color is later used in color interpolation.\n // Because of that, a reference to original color is saved.\n this.overwriteGetter('rgb', [r, g, b, alpha]);\n }\n }\n }\n /**\n * Parses CSS color strings and converts colors to sRGB color space if needed.\n * Officially supported color formats:\n * - keyword, e.g. 'aquamarine' or 'steelblue'\n * - hex (with 3, 4, 6 or 8 digits), e.g. '#f0f' or '#e9bebea9'\n * - rgb and rgba, e.g. 'rgb(0,240,120)' or 'rgba(0%,94%,47%,0.1)' or 'rgb(0 240 120 / .3)'\n * - hsl and hsla, e.g. 'hsl(0,0%,83%)' or 'hsla(0,0%,83%,.5)' or 'hsl(0 0% 83% / 20%)'\n *\n * @param input CSS color string to parse.\n * @returns A `Color` instance, or `undefined` if the input is not a valid color string.\n */\n static parse(input) {\n // in zoom-and-property function input could be an instance of Color class\n if (input instanceof Color) {\n return input;\n }\n if (typeof input !== 'string') {\n return;\n }\n const rgba = parseCssColor(input);\n if (rgba) {\n return new Color(...rgba, false);\n }\n }\n /**\n * Used in color interpolation and by 'to-rgba' expression.\n *\n * @returns Gien color, with reversed alpha blending, in sRGB color space.\n */\n get rgb() {\n const { r, g, b, a } = this;\n const f = a || Infinity; // reverse alpha blending factor\n return this.overwriteGetter('rgb', [r / f, g / f, b / f, a]);\n }\n /**\n * Used in color interpolation.\n *\n * @returns Gien color, with reversed alpha blending, in HCL color space.\n */\n get hcl() {\n return this.overwriteGetter('hcl', rgbToHcl(this.rgb));\n }\n /**\n * Used in color interpolation.\n *\n * @returns Gien color, with reversed alpha blending, in LAB color space.\n */\n get lab() {\n return this.overwriteGetter('lab', rgbToLab(this.rgb));\n }\n /**\n * Lazy getter pattern. When getter is called for the first time lazy value\n * is calculated and then overwrites getter function in given object instance.\n *\n * @example:\n * const redColor = Color.parse('red');\n * let x = redColor.hcl; // this will invoke `get hcl()`, which will calculate\n * // the value of red in HCL space and invoke this `overwriteGetter` function\n * // which in turn will set a field with a key 'hcl' in the `redColor` object.\n * // In other words it will override `get hcl()` from its `Color` prototype\n * // with its own property: hcl = [calculated red value in hcl].\n * let y = redColor.hcl; // next call will no longer invoke getter but simply\n * // return the previously calculated value\n * x === y; // true - `x` is exactly the same object as `y`\n *\n * @param getterKey Getter key\n * @param lazyValue Lazily calculated value to be memoized by current instance\n * @private\n */\n overwriteGetter(getterKey, lazyValue) {\n Object.defineProperty(this, getterKey, { value: lazyValue });\n return lazyValue;\n }\n /**\n * Used by 'to-string' expression.\n *\n * @returns Serialized color in format `rgba(r,g,b,a)`\n * where r,g,b are numbers within 0..255 and alpha is number within 1..0\n *\n * @example\n * var purple = new Color.parse('purple');\n * purple.toString; // = \"rgba(128,0,128,1)\"\n * var translucentGreen = new Color.parse('rgba(26, 207, 26, .73)');\n * translucentGreen.toString(); // = \"rgba(26,207,26,0.73)\"\n */\n toString() {\n const [r, g, b, a] = this.rgb;\n return `rgba(${[r, g, b].map(n => Math.round(n * 255)).join(',')},${a})`;\n }\n}\nColor.black = new Color(0, 0, 0, 1);\nColor.white = new Color(1, 1, 1, 1);\nColor.transparent = new Color(0, 0, 0, 0);\nColor.red = new Color(1, 0, 0, 1);\n\n// Flow type declarations for Intl cribbed from\n// https://github.com/facebook/flow/issues/1270\nclass Collator {\n constructor(caseSensitive, diacriticSensitive, locale) {\n if (caseSensitive)\n this.sensitivity = diacriticSensitive ? 'variant' : 'case';\n else\n this.sensitivity = diacriticSensitive ? 'accent' : 'base';\n this.locale = locale;\n this.collator = new Intl.Collator(this.locale ? this.locale : [], { sensitivity: this.sensitivity, usage: 'search' });\n }\n compare(lhs, rhs) {\n return this.collator.compare(lhs, rhs);\n }\n resolvedLocale() {\n // We create a Collator without \"usage: search\" because we don't want\n // the search options encoded in our result (e.g. \"en-u-co-search\")\n return new Intl.Collator(this.locale ? this.locale : [])\n .resolvedOptions().locale;\n }\n}\n\nclass FormattedSection {\n constructor(text, image, scale, fontStack, textColor) {\n this.text = text;\n this.image = image;\n this.scale = scale;\n this.fontStack = fontStack;\n this.textColor = textColor;\n }\n}\nclass Formatted {\n constructor(sections) {\n this.sections = sections;\n }\n static fromString(unformatted) {\n return new Formatted([new FormattedSection(unformatted, null, null, null, null)]);\n }\n isEmpty() {\n if (this.sections.length === 0)\n return true;\n return !this.sections.some(section => section.text.length !== 0 ||\n (section.image && section.image.name.length !== 0));\n }\n static factory(text) {\n if (text instanceof Formatted) {\n return text;\n }\n else {\n return Formatted.fromString(text);\n }\n }\n toString() {\n if (this.sections.length === 0)\n return '';\n return this.sections.map(section => section.text).join('');\n }\n}\n\n/**\n * A set of four numbers representing padding around a box. Create instances from\n * bare arrays or numeric values using the static method `Padding.parse`.\n * @private\n */\nclass Padding {\n constructor(values) {\n this.values = values.slice();\n }\n /**\n * Numeric padding values\n * @param input A padding value\n * @returns A `Padding` instance, or `undefined` if the input is not a valid padding value.\n */\n static parse(input) {\n if (input instanceof Padding) {\n return input;\n }\n // Backwards compatibility: bare number is treated the same as array with single value.\n // Padding applies to all four sides.\n if (typeof input === 'number') {\n return new Padding([input, input, input, input]);\n }\n if (!Array.isArray(input)) {\n return undefined;\n }\n if (input.length < 1 || input.length > 4) {\n return undefined;\n }\n for (const val of input) {\n if (typeof val !== 'number') {\n return undefined;\n }\n }\n // Expand shortcut properties into explicit 4-sided values\n switch (input.length) {\n case 1:\n input = [input[0], input[0], input[0], input[0]];\n break;\n case 2:\n input = [input[0], input[1], input[0], input[1]];\n break;\n case 3:\n input = [input[0], input[1], input[2], input[1]];\n break;\n }\n return new Padding(input);\n }\n toString() {\n return JSON.stringify(this.values);\n }\n}\n\n/** Set of valid anchor positions, as a set for validation */\nconst anchors = new Set(['center', 'left', 'right', 'top', 'bottom', 'top-left', 'top-right', 'bottom-left', 'bottom-right']);\n/**\n * Utility class to assist managing values for text-variable-anchor-offset property. Create instances from\n * bare arrays using the static method `VariableAnchorOffsetCollection.parse`.\n * @private\n */\nclass VariableAnchorOffsetCollection {\n constructor(values) {\n this.values = values.slice();\n }\n static parse(input) {\n if (input instanceof VariableAnchorOffsetCollection) {\n return input;\n }\n if (!Array.isArray(input) ||\n input.length < 1 ||\n input.length % 2 !== 0) {\n return undefined;\n }\n for (let i = 0; i < input.length; i += 2) {\n // Elements in even positions should be anchor positions; Elements in odd positions should be offset values\n const anchorValue = input[i];\n const offsetValue = input[i + 1];\n if (typeof anchorValue !== 'string' || !anchors.has(anchorValue)) {\n return undefined;\n }\n if (!Array.isArray(offsetValue) || offsetValue.length !== 2 || typeof offsetValue[0] !== 'number' || typeof offsetValue[1] !== 'number') {\n return undefined;\n }\n }\n return new VariableAnchorOffsetCollection(input);\n }\n toString() {\n return JSON.stringify(this.values);\n }\n}\n\nclass ResolvedImage {\n constructor(options) {\n this.name = options.name;\n this.available = options.available;\n }\n toString() {\n return this.name;\n }\n static fromString(name) {\n if (!name)\n return null; // treat empty values as no image\n return new ResolvedImage({ name, available: false });\n }\n}\n\nfunction validateRGBA(r, g, b, a) {\n if (!(typeof r === 'number' && r >= 0 && r <= 255 &&\n typeof g === 'number' && g >= 0 && g <= 255 &&\n typeof b === 'number' && b >= 0 && b <= 255)) {\n const value = typeof a === 'number' ? [r, g, b, a] : [r, g, b];\n return `Invalid rgba value [${value.join(', ')}]: 'r', 'g', and 'b' must be between 0 and 255.`;\n }\n if (!(typeof a === 'undefined' || (typeof a === 'number' && a >= 0 && a <= 1))) {\n return `Invalid rgba value [${[r, g, b, a].join(', ')}]: 'a' must be between 0 and 1.`;\n }\n return null;\n}\nfunction isValue(mixed) {\n if (mixed === null ||\n typeof mixed === 'string' ||\n typeof mixed === 'boolean' ||\n typeof mixed === 'number' ||\n mixed instanceof Color ||\n mixed instanceof Collator ||\n mixed instanceof Formatted ||\n mixed instanceof Padding ||\n mixed instanceof VariableAnchorOffsetCollection ||\n mixed instanceof ResolvedImage) {\n return true;\n }\n else if (Array.isArray(mixed)) {\n for (const item of mixed) {\n if (!isValue(item)) {\n return false;\n }\n }\n return true;\n }\n else if (typeof mixed === 'object') {\n for (const key in mixed) {\n if (!isValue(mixed[key])) {\n return false;\n }\n }\n return true;\n }\n else {\n return false;\n }\n}\nfunction typeOf(value) {\n if (value === null) {\n return NullType;\n }\n else if (typeof value === 'string') {\n return StringType;\n }\n else if (typeof value === 'boolean') {\n return BooleanType;\n }\n else if (typeof value === 'number') {\n return NumberType;\n }\n else if (value instanceof Color) {\n return ColorType;\n }\n else if (value instanceof Collator) {\n return CollatorType;\n }\n else if (value instanceof Formatted) {\n return FormattedType;\n }\n else if (value instanceof Padding) {\n return PaddingType;\n }\n else if (value instanceof VariableAnchorOffsetCollection) {\n return VariableAnchorOffsetCollectionType;\n }\n else if (value instanceof ResolvedImage) {\n return ResolvedImageType;\n }\n else if (Array.isArray(value)) {\n const length = value.length;\n let itemType;\n for (const item of value) {\n const t = typeOf(item);\n if (!itemType) {\n itemType = t;\n }\n else if (itemType === t) {\n continue;\n }\n else {\n itemType = ValueType;\n break;\n }\n }\n return array$1(itemType || ValueType, length);\n }\n else {\n return ObjectType;\n }\n}\nfunction toString(value) {\n const type = typeof value;\n if (value === null) {\n return '';\n }\n else if (type === 'string' || type === 'number' || type === 'boolean') {\n return String(value);\n }\n else if (value instanceof Color || value instanceof Formatted || value instanceof Padding || value instanceof VariableAnchorOffsetCollection || value instanceof ResolvedImage) {\n return value.toString();\n }\n else {\n return JSON.stringify(value);\n }\n}\n\nclass Literal {\n constructor(type, value) {\n this.type = type;\n this.value = value;\n }\n static parse(args, context) {\n if (args.length !== 2)\n return context.error(`'literal' expression requires exactly one argument, but found ${args.length - 1} instead.`);\n if (!isValue(args[1]))\n return context.error('invalid value');\n const value = args[1];\n let type = typeOf(value);\n // special case: infer the item type if possible for zero-length arrays\n const expected = context.expectedType;\n if (type.kind === 'array' &&\n type.N === 0 &&\n expected &&\n expected.kind === 'array' &&\n (typeof expected.N !== 'number' || expected.N === 0)) {\n type = expected;\n }\n return new Literal(type, value);\n }\n evaluate() {\n return this.value;\n }\n eachChild() { }\n outputDefined() {\n return true;\n }\n}\n\nclass RuntimeError {\n constructor(message) {\n this.name = 'ExpressionEvaluationError';\n this.message = message;\n }\n toJSON() {\n return this.message;\n }\n}\n\nconst types$1 = {\n string: StringType,\n number: NumberType,\n boolean: BooleanType,\n object: ObjectType\n};\nclass Assertion {\n constructor(type, args) {\n this.type = type;\n this.args = args;\n }\n static parse(args, context) {\n if (args.length < 2)\n return context.error('Expected at least one argument.');\n let i = 1;\n let type;\n const name = args[0];\n if (name === 'array') {\n let itemType;\n if (args.length > 2) {\n const type = args[1];\n if (typeof type !== 'string' || !(type in types$1) || type === 'object')\n return context.error('The item type argument of \"array\" must be one of string, number, boolean', 1);\n itemType = types$1[type];\n i++;\n }\n else {\n itemType = ValueType;\n }\n let N;\n if (args.length > 3) {\n if (args[2] !== null &&\n (typeof args[2] !== 'number' ||\n args[2] < 0 ||\n args[2] !== Math.floor(args[2]))) {\n return context.error('The length argument to \"array\" must be a positive integer literal', 2);\n }\n N = args[2];\n i++;\n }\n type = array$1(itemType, N);\n }\n else {\n if (!types$1[name])\n throw new Error(`Types doesn't contain name = ${name}`);\n type = types$1[name];\n }\n const parsed = [];\n for (; i < args.length; i++) {\n const input = context.parse(args[i], i, ValueType);\n if (!input)\n return null;\n parsed.push(input);\n }\n return new Assertion(type, parsed);\n }\n evaluate(ctx) {\n for (let i = 0; i < this.args.length; i++) {\n const value = this.args[i].evaluate(ctx);\n const error = checkSubtype(this.type, typeOf(value));\n if (!error) {\n return value;\n }\n else if (i === this.args.length - 1) {\n throw new RuntimeError(`Expected value to be of type ${toString$1(this.type)}, but found ${toString$1(typeOf(value))} instead.`);\n }\n }\n throw new Error();\n }\n eachChild(fn) {\n this.args.forEach(fn);\n }\n outputDefined() {\n return this.args.every(arg => arg.outputDefined());\n }\n}\n\nconst types = {\n 'to-boolean': BooleanType,\n 'to-color': ColorType,\n 'to-number': NumberType,\n 'to-string': StringType\n};\n/**\n * Special form for error-coalescing coercion expressions \"to-number\",\n * \"to-color\". Since these coercions can fail at runtime, they accept multiple\n * arguments, only evaluating one at a time until one succeeds.\n *\n * @private\n */\nclass Coercion {\n constructor(type, args) {\n this.type = type;\n this.args = args;\n }\n static parse(args, context) {\n if (args.length < 2)\n return context.error('Expected at least one argument.');\n const name = args[0];\n if (!types[name])\n throw new Error(`Can't parse ${name} as it is not part of the known types`);\n if ((name === 'to-boolean' || name === 'to-string') && args.length !== 2)\n return context.error('Expected one argument.');\n const type = types[name];\n const parsed = [];\n for (let i = 1; i < args.length; i++) {\n const input = context.parse(args[i], i, ValueType);\n if (!input)\n return null;\n parsed.push(input);\n }\n return new Coercion(type, parsed);\n }\n evaluate(ctx) {\n switch (this.type.kind) {\n case 'boolean':\n return Boolean(this.args[0].evaluate(ctx));\n case 'color': {\n let input;\n let error;\n for (const arg of this.args) {\n input = arg.evaluate(ctx);\n error = null;\n if (input instanceof Color) {\n return input;\n }\n else if (typeof input === 'string') {\n const c = ctx.parseColor(input);\n if (c)\n return c;\n }\n else if (Array.isArray(input)) {\n if (input.length < 3 || input.length > 4) {\n error = `Invalid rbga value ${JSON.stringify(input)}: expected an array containing either three or four numeric values.`;\n }\n else {\n error = validateRGBA(input[0], input[1], input[2], input[3]);\n }\n if (!error) {\n return new Color(input[0] / 255, input[1] / 255, input[2] / 255, input[3]);\n }\n }\n }\n throw new RuntimeError(error || `Could not parse color from value '${typeof input === 'string' ? input : JSON.stringify(input)}'`);\n }\n case 'padding': {\n let input;\n for (const arg of this.args) {\n input = arg.evaluate(ctx);\n const pad = Padding.parse(input);\n if (pad) {\n return pad;\n }\n }\n throw new RuntimeError(`Could not parse padding from value '${typeof input === 'string' ? input : JSON.stringify(input)}'`);\n }\n case 'variableAnchorOffsetCollection': {\n let input;\n for (const arg of this.args) {\n input = arg.evaluate(ctx);\n const coll = VariableAnchorOffsetCollection.parse(input);\n if (coll) {\n return coll;\n }\n }\n throw new RuntimeError(`Could not parse variableAnchorOffsetCollection from value '${typeof input === 'string' ? input : JSON.stringify(input)}'`);\n }\n case 'number': {\n let value = null;\n for (const arg of this.args) {\n value = arg.evaluate(ctx);\n if (value === null)\n return 0;\n const num = Number(value);\n if (isNaN(num))\n continue;\n return num;\n }\n throw new RuntimeError(`Could not convert ${JSON.stringify(value)} to number.`);\n }\n case 'formatted':\n // There is no explicit 'to-formatted' but this coercion can be implicitly\n // created by properties that expect the 'formatted' type.\n return Formatted.fromString(toString(this.args[0].evaluate(ctx)));\n case 'resolvedImage':\n return ResolvedImage.fromString(toString(this.args[0].evaluate(ctx)));\n default:\n return toString(this.args[0].evaluate(ctx));\n }\n }\n eachChild(fn) {\n this.args.forEach(fn);\n }\n outputDefined() {\n return this.args.every(arg => arg.outputDefined());\n }\n}\n\nconst geometryTypes = ['Unknown', 'Point', 'LineString', 'Polygon'];\nclass EvaluationContext {\n constructor() {\n this.globals = null;\n this.feature = null;\n this.featureState = null;\n this.formattedSection = null;\n this._parseColorCache = {};\n this.availableImages = null;\n this.canonical = null;\n }\n id() {\n return this.feature && 'id' in this.feature ? this.feature.id : null;\n }\n geometryType() {\n return this.feature ? typeof this.feature.type === 'number' ? geometryTypes[this.feature.type] : this.feature.type : null;\n }\n geometry() {\n return this.feature && 'geometry' in this.feature ? this.feature.geometry : null;\n }\n canonicalID() {\n return this.canonical;\n }\n properties() {\n return this.feature && this.feature.properties || {};\n }\n parseColor(input) {\n let cached = this._parseColorCache[input];\n if (!cached) {\n cached = this._parseColorCache[input] = Color.parse(input);\n }\n return cached;\n }\n}\n\n/**\n * State associated parsing at a given point in an expression tree.\n * @private\n */\nclass ParsingContext {\n constructor(registry, isConstantFunc, path = [], expectedType, scope = new Scope(), errors = []) {\n this.registry = registry;\n this.path = path;\n this.key = path.map(part => `[${part}]`).join('');\n this.scope = scope;\n this.errors = errors;\n this.expectedType = expectedType;\n this._isConstant = isConstantFunc;\n }\n /**\n * @param expr the JSON expression to parse\n * @param index the optional argument index if this expression is an argument of a parent expression that's being parsed\n * @param options\n * @param options.omitTypeAnnotations set true to omit inferred type annotations. Caller beware: with this option set, the parsed expression's type will NOT satisfy `expectedType` if it would normally be wrapped in an inferred annotation.\n * @private\n */\n parse(expr, index, expectedType, bindings, options = {}) {\n if (index) {\n return this.concat(index, expectedType, bindings)._parse(expr, options);\n }\n return this._parse(expr, options);\n }\n _parse(expr, options) {\n if (expr === null || typeof expr === 'string' || typeof expr === 'boolean' || typeof expr === 'number') {\n expr = ['literal', expr];\n }\n function annotate(parsed, type, typeAnnotation) {\n if (typeAnnotation === 'assert') {\n return new Assertion(type, [parsed]);\n }\n else if (typeAnnotation === 'coerce') {\n return new Coercion(type, [parsed]);\n }\n else {\n return parsed;\n }\n }\n if (Array.isArray(expr)) {\n if (expr.length === 0) {\n return this.error('Expected an array with at least one element. If you wanted a literal array, use [\"literal\", []].');\n }\n const op = expr[0];\n if (typeof op !== 'string') {\n this.error(`Expression name must be a string, but found ${typeof op} instead. If you wanted a literal array, use [\"literal\", [...]].`, 0);\n return null;\n }\n const Expr = this.registry[op];\n if (Expr) {\n let parsed = Expr.parse(expr, this);\n if (!parsed)\n return null;\n if (this.expectedType) {\n const expected = this.expectedType;\n const actual = parsed.type;\n // When we expect a number, string, boolean, or array but have a value, wrap it in an assertion.\n // When we expect a color or formatted string, but have a string or value, wrap it in a coercion.\n // Otherwise, we do static type-checking.\n //\n // These behaviors are overridable for:\n // * The \"coalesce\" operator, which needs to omit type annotations.\n // * String-valued properties (e.g. `text-field`), where coercion is more convenient than assertion.\n //\n if ((expected.kind === 'string' || expected.kind === 'number' || expected.kind === 'boolean' || expected.kind === 'object' || expected.kind === 'array') && actual.kind === 'value') {\n parsed = annotate(parsed, expected, options.typeAnnotation || 'assert');\n }\n else if ((expected.kind === 'color' || expected.kind === 'formatted' || expected.kind === 'resolvedImage') && (actual.kind === 'value' || actual.kind === 'string')) {\n parsed = annotate(parsed, expected, options.typeAnnotation || 'coerce');\n }\n else if (expected.kind === 'padding' && (actual.kind === 'value' || actual.kind === 'number' || actual.kind === 'array')) {\n parsed = annotate(parsed, expected, options.typeAnnotation || 'coerce');\n }\n else if (expected.kind === 'variableAnchorOffsetCollection' && (actual.kind === 'value' || actual.kind === 'array')) {\n parsed = annotate(parsed, expected, options.typeAnnotation || 'coerce');\n }\n else if (this.checkSubtype(expected, actual)) {\n return null;\n }\n }\n // If an expression's arguments are all literals, we can evaluate\n // it immediately and replace it with a literal value in the\n // parsed/compiled result. Expressions that expect an image should\n // not be resolved here so we can later get the available images.\n if (!(parsed instanceof Literal) && (parsed.type.kind !== 'resolvedImage') && this._isConstant(parsed)) {\n const ec = new EvaluationContext();\n try {\n parsed = new Literal(parsed.type, parsed.evaluate(ec));\n }\n catch (e) {\n this.error(e.message);\n return null;\n }\n }\n return parsed;\n }\n return this.error(`Unknown expression \"${op}\". If you wanted a literal array, use [\"literal\", [...]].`, 0);\n }\n else if (typeof expr === 'undefined') {\n return this.error('\\'undefined\\' value invalid. Use null instead.');\n }\n else if (typeof expr === 'object') {\n return this.error('Bare objects invalid. Use [\"literal\", {...}] instead.');\n }\n else {\n return this.error(`Expected an array, but found ${typeof expr} instead.`);\n }\n }\n /**\n * Returns a copy of this context suitable for parsing the subexpression at\n * index `index`, optionally appending to 'let' binding map.\n *\n * Note that `errors` property, intended for collecting errors while\n * parsing, is copied by reference rather than cloned.\n * @private\n */\n concat(index, expectedType, bindings) {\n const path = typeof index === 'number' ? this.path.concat(index) : this.path;\n const scope = bindings ? this.scope.concat(bindings) : this.scope;\n return new ParsingContext(this.registry, this._isConstant, path, expectedType || null, scope, this.errors);\n }\n /**\n * Push a parsing (or type checking) error into the `this.errors`\n * @param error The message\n * @param keys Optionally specify the source of the error at a child\n * of the current expression at `this.key`.\n * @private\n */\n error(error, ...keys) {\n const key = `${this.key}${keys.map(k => `[${k}]`).join('')}`;\n this.errors.push(new ExpressionParsingError(key, error));\n }\n /**\n * Returns null if `t` is a subtype of `expected`; otherwise returns an\n * error message and also pushes it to `this.errors`.\n * @param expected The expected type\n * @param t The actual type\n * @returns null if `t` is a subtype of `expected`; otherwise returns an error message\n */\n checkSubtype(expected, t) {\n const error = checkSubtype(expected, t);\n if (error)\n this.error(error);\n return error;\n }\n}\n\nclass Let {\n constructor(bindings, result) {\n this.type = result.type;\n this.bindings = [].concat(bindings);\n this.result = result;\n }\n evaluate(ctx) {\n return this.result.evaluate(ctx);\n }\n eachChild(fn) {\n for (const binding of this.bindings) {\n fn(binding[1]);\n }\n fn(this.result);\n }\n static parse(args, context) {\n if (args.length < 4)\n return context.error(`Expected at least 3 arguments, but found ${args.length - 1} instead.`);\n const bindings = [];\n for (let i = 1; i < args.length - 1; i += 2) {\n const name = args[i];\n if (typeof name !== 'string') {\n return context.error(`Expected string, but found ${typeof name} instead.`, i);\n }\n if (/[^a-zA-Z0-9_]/.test(name)) {\n return context.error('Variable names must contain only alphanumeric characters or \\'_\\'.', i);\n }\n const value = context.parse(args[i + 1], i + 1);\n if (!value)\n return null;\n bindings.push([name, value]);\n }\n const result = context.parse(args[args.length - 1], args.length - 1, context.expectedType, bindings);\n if (!result)\n return null;\n return new Let(bindings, result);\n }\n outputDefined() {\n return this.result.outputDefined();\n }\n}\n\nclass Var {\n constructor(name, boundExpression) {\n this.type = boundExpression.type;\n this.name = name;\n this.boundExpression = boundExpression;\n }\n static parse(args, context) {\n if (args.length !== 2 || typeof args[1] !== 'string')\n return context.error('\\'var\\' expression requires exactly one string literal argument.');\n const name = args[1];\n if (!context.scope.has(name)) {\n return context.error(`Unknown variable \"${name}\". Make sure \"${name}\" has been bound in an enclosing \"let\" expression before using it.`, 1);\n }\n return new Var(name, context.scope.get(name));\n }\n evaluate(ctx) {\n return this.boundExpression.evaluate(ctx);\n }\n eachChild() { }\n outputDefined() {\n return false;\n }\n}\n\nclass At {\n constructor(type, index, input) {\n this.type = type;\n this.index = index;\n this.input = input;\n }\n static parse(args, context) {\n if (args.length !== 3)\n return context.error(`Expected 2 arguments, but found ${args.length - 1} instead.`);\n const index = context.parse(args[1], 1, NumberType);\n const input = context.parse(args[2], 2, array$1(context.expectedType || ValueType));\n if (!index || !input)\n return null;\n const t = input.type;\n return new At(t.itemType, index, input);\n }\n evaluate(ctx) {\n const index = this.index.evaluate(ctx);\n const array = this.input.evaluate(ctx);\n if (index < 0) {\n throw new RuntimeError(`Array index out of bounds: ${index} < 0.`);\n }\n if (index >= array.length) {\n throw new RuntimeError(`Array index out of bounds: ${index} > ${array.length - 1}.`);\n }\n if (index !== Math.floor(index)) {\n throw new RuntimeError(`Array index must be an integer, but found ${index} instead.`);\n }\n return array[index];\n }\n eachChild(fn) {\n fn(this.index);\n fn(this.input);\n }\n outputDefined() {\n return false;\n }\n}\n\nclass In {\n constructor(needle, haystack) {\n this.type = BooleanType;\n this.needle = needle;\n this.haystack = haystack;\n }\n static parse(args, context) {\n if (args.length !== 3) {\n return context.error(`Expected 2 arguments, but found ${args.length - 1} instead.`);\n }\n const needle = context.parse(args[1], 1, ValueType);\n const haystack = context.parse(args[2], 2, ValueType);\n if (!needle || !haystack)\n return null;\n if (!isValidType(needle.type, [BooleanType, StringType, NumberType, NullType, ValueType])) {\n return context.error(`Expected first argument to be of type boolean, string, number or null, but found ${toString$1(needle.type)} instead`);\n }\n return new In(needle, haystack);\n }\n evaluate(ctx) {\n const needle = this.needle.evaluate(ctx);\n const haystack = this.haystack.evaluate(ctx);\n if (!haystack)\n return false;\n if (!isValidNativeType(needle, ['boolean', 'string', 'number', 'null'])) {\n throw new RuntimeError(`Expected first argument to be of type boolean, string, number or null, but found ${toString$1(typeOf(needle))} instead.`);\n }\n if (!isValidNativeType(haystack, ['string', 'array'])) {\n throw new RuntimeError(`Expected second argument to be of type array or string, but found ${toString$1(typeOf(haystack))} instead.`);\n }\n return haystack.indexOf(needle) >= 0;\n }\n eachChild(fn) {\n fn(this.needle);\n fn(this.haystack);\n }\n outputDefined() {\n return true;\n }\n}\n\nclass IndexOf {\n constructor(needle, haystack, fromIndex) {\n this.type = NumberType;\n this.needle = needle;\n this.haystack = haystack;\n this.fromIndex = fromIndex;\n }\n static parse(args, context) {\n if (args.length <= 2 || args.length >= 5) {\n return context.error(`Expected 3 or 4 arguments, but found ${args.length - 1} instead.`);\n }\n const needle = context.parse(args[1], 1, ValueType);\n const haystack = context.parse(args[2], 2, ValueType);\n if (!needle || !haystack)\n return null;\n if (!isValidType(needle.type, [BooleanType, StringType, NumberType, NullType, ValueType])) {\n return context.error(`Expected first argument to be of type boolean, string, number or null, but found ${toString$1(needle.type)} instead`);\n }\n if (args.length === 4) {\n const fromIndex = context.parse(args[3], 3, NumberType);\n if (!fromIndex)\n return null;\n return new IndexOf(needle, haystack, fromIndex);\n }\n else {\n return new IndexOf(needle, haystack);\n }\n }\n evaluate(ctx) {\n const needle = this.needle.evaluate(ctx);\n const haystack = this.haystack.evaluate(ctx);\n if (!isValidNativeType(needle, ['boolean', 'string', 'number', 'null'])) {\n throw new RuntimeError(`Expected first argument to be of type boolean, string, number or null, but found ${toString$1(typeOf(needle))} instead.`);\n }\n let fromIndex;\n if (this.fromIndex) {\n fromIndex = this.fromIndex.evaluate(ctx);\n }\n if (isValidNativeType(haystack, ['string'])) {\n const rawIndex = haystack.indexOf(needle, fromIndex);\n if (rawIndex === -1) {\n return -1;\n }\n else {\n // The index may be affected by surrogate pairs, so get the length of the preceding substring.\n return [...haystack.slice(0, rawIndex)].length;\n }\n }\n else if (isValidNativeType(haystack, ['array'])) {\n return haystack.indexOf(needle, fromIndex);\n }\n else {\n throw new RuntimeError(`Expected second argument to be of type array or string, but found ${toString$1(typeOf(haystack))} instead.`);\n }\n }\n eachChild(fn) {\n fn(this.needle);\n fn(this.haystack);\n if (this.fromIndex) {\n fn(this.fromIndex);\n }\n }\n outputDefined() {\n return false;\n }\n}\n\nclass Match {\n constructor(inputType, outputType, input, cases, outputs, otherwise) {\n this.inputType = inputType;\n this.type = outputType;\n this.input = input;\n this.cases = cases;\n this.outputs = outputs;\n this.otherwise = otherwise;\n }\n static parse(args, context) {\n if (args.length < 5)\n return context.error(`Expected at least 4 arguments, but found only ${args.length - 1}.`);\n if (args.length % 2 !== 1)\n return context.error('Expected an even number of arguments.');\n let inputType;\n let outputType;\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n const cases = {};\n const outputs = [];\n for (let i = 2; i < args.length - 1; i += 2) {\n let labels = args[i];\n const value = args[i + 1];\n if (!Array.isArray(labels)) {\n labels = [labels];\n }\n const labelContext = context.concat(i);\n if (labels.length === 0) {\n return labelContext.error('Expected at least one branch label.');\n }\n for (const label of labels) {\n if (typeof label !== 'number' && typeof label !== 'string') {\n return labelContext.error('Branch labels must be numbers or strings.');\n }\n else if (typeof label === 'number' && Math.abs(label) > Number.MAX_SAFE_INTEGER) {\n return labelContext.error(`Branch labels must be integers no larger than ${Number.MAX_SAFE_INTEGER}.`);\n }\n else if (typeof label === 'number' && Math.floor(label) !== label) {\n return labelContext.error('Numeric branch labels must be integer values.');\n }\n else if (!inputType) {\n inputType = typeOf(label);\n }\n else if (labelContext.checkSubtype(inputType, typeOf(label))) {\n return null;\n }\n if (typeof cases[String(label)] !== 'undefined') {\n return labelContext.error('Branch labels must be unique.');\n }\n cases[String(label)] = outputs.length;\n }\n const result = context.parse(value, i, outputType);\n if (!result)\n return null;\n outputType = outputType || result.type;\n outputs.push(result);\n }\n const input = context.parse(args[1], 1, ValueType);\n if (!input)\n return null;\n const otherwise = context.parse(args[args.length - 1], args.length - 1, outputType);\n if (!otherwise)\n return null;\n if (input.type.kind !== 'value' && context.concat(1).checkSubtype(inputType, input.type)) {\n return null;\n }\n return new Match(inputType, outputType, input, cases, outputs, otherwise);\n }\n evaluate(ctx) {\n const input = this.input.evaluate(ctx);\n const output = (typeOf(input) === this.inputType && this.outputs[this.cases[input]]) || this.otherwise;\n return output.evaluate(ctx);\n }\n eachChild(fn) {\n fn(this.input);\n this.outputs.forEach(fn);\n fn(this.otherwise);\n }\n outputDefined() {\n return this.outputs.every(out => out.outputDefined()) && this.otherwise.outputDefined();\n }\n}\n\nclass Case {\n constructor(type, branches, otherwise) {\n this.type = type;\n this.branches = branches;\n this.otherwise = otherwise;\n }\n static parse(args, context) {\n if (args.length < 4)\n return context.error(`Expected at least 3 arguments, but found only ${args.length - 1}.`);\n if (args.length % 2 !== 0)\n return context.error('Expected an odd number of arguments.');\n let outputType;\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n const branches = [];\n for (let i = 1; i < args.length - 1; i += 2) {\n const test = context.parse(args[i], i, BooleanType);\n if (!test)\n return null;\n const result = context.parse(args[i + 1], i + 1, outputType);\n if (!result)\n return null;\n branches.push([test, result]);\n outputType = outputType || result.type;\n }\n const otherwise = context.parse(args[args.length - 1], args.length - 1, outputType);\n if (!otherwise)\n return null;\n if (!outputType)\n throw new Error('Can\\'t infer output type');\n return new Case(outputType, branches, otherwise);\n }\n evaluate(ctx) {\n for (const [test, expression] of this.branches) {\n if (test.evaluate(ctx)) {\n return expression.evaluate(ctx);\n }\n }\n return this.otherwise.evaluate(ctx);\n }\n eachChild(fn) {\n for (const [test, expression] of this.branches) {\n fn(test);\n fn(expression);\n }\n fn(this.otherwise);\n }\n outputDefined() {\n return this.branches.every(([_, out]) => out.outputDefined()) && this.otherwise.outputDefined();\n }\n}\n\nclass Slice {\n constructor(type, input, beginIndex, endIndex) {\n this.type = type;\n this.input = input;\n this.beginIndex = beginIndex;\n this.endIndex = endIndex;\n }\n static parse(args, context) {\n if (args.length <= 2 || args.length >= 5) {\n return context.error(`Expected 3 or 4 arguments, but found ${args.length - 1} instead.`);\n }\n const input = context.parse(args[1], 1, ValueType);\n const beginIndex = context.parse(args[2], 2, NumberType);\n if (!input || !beginIndex)\n return null;\n if (!isValidType(input.type, [array$1(ValueType), StringType, ValueType])) {\n return context.error(`Expected first argument to be of type array or string, but found ${toString$1(input.type)} instead`);\n }\n if (args.length === 4) {\n const endIndex = context.parse(args[3], 3, NumberType);\n if (!endIndex)\n return null;\n return new Slice(input.type, input, beginIndex, endIndex);\n }\n else {\n return new Slice(input.type, input, beginIndex);\n }\n }\n evaluate(ctx) {\n const input = this.input.evaluate(ctx);\n const beginIndex = this.beginIndex.evaluate(ctx);\n let endIndex;\n if (this.endIndex) {\n endIndex = this.endIndex.evaluate(ctx);\n }\n if (isValidNativeType(input, ['string'])) {\n // Indices may be affected by surrogate pairs.\n return [...input].slice(beginIndex, endIndex).join('');\n }\n else if (isValidNativeType(input, ['array'])) {\n return input.slice(beginIndex, endIndex);\n }\n else {\n throw new RuntimeError(`Expected first argument to be of type array or string, but found ${toString$1(typeOf(input))} instead.`);\n }\n }\n eachChild(fn) {\n fn(this.input);\n fn(this.beginIndex);\n if (this.endIndex) {\n fn(this.endIndex);\n }\n }\n outputDefined() {\n return false;\n }\n}\n\n/**\n * Returns the index of the last stop <= input, or 0 if it doesn't exist.\n * @private\n */\nfunction findStopLessThanOrEqualTo(stops, input) {\n const lastIndex = stops.length - 1;\n let lowerIndex = 0;\n let upperIndex = lastIndex;\n let currentIndex = 0;\n let currentValue, nextValue;\n while (lowerIndex <= upperIndex) {\n currentIndex = Math.floor((lowerIndex + upperIndex) / 2);\n currentValue = stops[currentIndex];\n nextValue = stops[currentIndex + 1];\n if (currentValue <= input) {\n if (currentIndex === lastIndex || input < nextValue) { // Search complete\n return currentIndex;\n }\n lowerIndex = currentIndex + 1;\n }\n else if (currentValue > input) {\n upperIndex = currentIndex - 1;\n }\n else {\n throw new RuntimeError('Input is not a number.');\n }\n }\n return 0;\n}\n\nclass Step {\n constructor(type, input, stops) {\n this.type = type;\n this.input = input;\n this.labels = [];\n this.outputs = [];\n for (const [label, expression] of stops) {\n this.labels.push(label);\n this.outputs.push(expression);\n }\n }\n static parse(args, context) {\n if (args.length - 1 < 4) {\n return context.error(`Expected at least 4 arguments, but found only ${args.length - 1}.`);\n }\n if ((args.length - 1) % 2 !== 0) {\n return context.error('Expected an even number of arguments.');\n }\n const input = context.parse(args[1], 1, NumberType);\n if (!input)\n return null;\n const stops = [];\n let outputType = null;\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n for (let i = 1; i < args.length; i += 2) {\n const label = i === 1 ? -Infinity : args[i];\n const value = args[i + 1];\n const labelKey = i;\n const valueKey = i + 1;\n if (typeof label !== 'number') {\n return context.error('Input/output pairs for \"step\" expressions must be defined using literal numeric values (not computed expressions) for the input values.', labelKey);\n }\n if (stops.length && stops[stops.length - 1][0] >= label) {\n return context.error('Input/output pairs for \"step\" expressions must be arranged with input values in strictly ascending order.', labelKey);\n }\n const parsed = context.parse(value, valueKey, outputType);\n if (!parsed)\n return null;\n outputType = outputType || parsed.type;\n stops.push([label, parsed]);\n }\n return new Step(outputType, input, stops);\n }\n evaluate(ctx) {\n const labels = this.labels;\n const outputs = this.outputs;\n if (labels.length === 1) {\n return outputs[0].evaluate(ctx);\n }\n const value = this.input.evaluate(ctx);\n if (value <= labels[0]) {\n return outputs[0].evaluate(ctx);\n }\n const stopCount = labels.length;\n if (value >= labels[stopCount - 1]) {\n return outputs[stopCount - 1].evaluate(ctx);\n }\n const index = findStopLessThanOrEqualTo(labels, value);\n return outputs[index].evaluate(ctx);\n }\n eachChild(fn) {\n fn(this.input);\n for (const expression of this.outputs) {\n fn(expression);\n }\n }\n outputDefined() {\n return this.outputs.every(out => out.outputDefined());\n }\n}\n\nfunction getDefaultExportFromCjs (x) {\n\treturn x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x['default'] : x;\n}\n\nvar unitbezier = UnitBezier;\n\nfunction UnitBezier(p1x, p1y, p2x, p2y) {\n // Calculate the polynomial coefficients, implicit first and last control points are (0,0) and (1,1).\n this.cx = 3.0 * p1x;\n this.bx = 3.0 * (p2x - p1x) - this.cx;\n this.ax = 1.0 - this.cx - this.bx;\n\n this.cy = 3.0 * p1y;\n this.by = 3.0 * (p2y - p1y) - this.cy;\n this.ay = 1.0 - this.cy - this.by;\n\n this.p1x = p1x;\n this.p1y = p1y;\n this.p2x = p2x;\n this.p2y = p2y;\n}\n\nUnitBezier.prototype = {\n sampleCurveX: function (t) {\n // `ax t^3 + bx t^2 + cx t' expanded using Horner's rule.\n return ((this.ax * t + this.bx) * t + this.cx) * t;\n },\n\n sampleCurveY: function (t) {\n return ((this.ay * t + this.by) * t + this.cy) * t;\n },\n\n sampleCurveDerivativeX: function (t) {\n return (3.0 * this.ax * t + 2.0 * this.bx) * t + this.cx;\n },\n\n solveCurveX: function (x, epsilon) {\n if (epsilon === undefined) epsilon = 1e-6;\n\n if (x < 0.0) return 0.0;\n if (x > 1.0) return 1.0;\n\n var t = x;\n\n // First try a few iterations of Newton's method - normally very fast.\n for (var i = 0; i < 8; i++) {\n var x2 = this.sampleCurveX(t) - x;\n if (Math.abs(x2) < epsilon) return t;\n\n var d2 = this.sampleCurveDerivativeX(t);\n if (Math.abs(d2) < 1e-6) break;\n\n t = t - x2 / d2;\n }\n\n // Fall back to the bisection method for reliability.\n var t0 = 0.0;\n var t1 = 1.0;\n t = x;\n\n for (i = 0; i < 20; i++) {\n x2 = this.sampleCurveX(t);\n if (Math.abs(x2 - x) < epsilon) break;\n\n if (x > x2) {\n t0 = t;\n } else {\n t1 = t;\n }\n\n t = (t1 - t0) * 0.5 + t0;\n }\n\n return t;\n },\n\n solve: function (x, epsilon) {\n return this.sampleCurveY(this.solveCurveX(x, epsilon));\n }\n};\n\nvar UnitBezier$1 = /*@__PURE__*/getDefaultExportFromCjs(unitbezier);\n\n/**\n * Checks whether the specified color space is one of the supported interpolation color spaces.\n *\n * @param colorSpace Color space key to verify.\n * @returns `true` if the specified color space is one of the supported\n * interpolation color spaces, `false` otherwise\n */\nfunction isSupportedInterpolationColorSpace(colorSpace) {\n return colorSpace === 'rgb' || colorSpace === 'hcl' || colorSpace === 'lab';\n}\n/**\n * @param interpolationType Interpolation type\n * @returns interpolation fn\n * @deprecated use `interpolate[type]` instead\n */\nconst interpolateFactory = (interpolationType) => {\n switch (interpolationType) {\n case 'number': return number;\n case 'color': return color;\n case 'array': return array;\n case 'padding': return padding;\n case 'variableAnchorOffsetCollection': return variableAnchorOffsetCollection;\n }\n};\nfunction number(from, to, t) {\n return from + t * (to - from);\n}\nfunction color(from, to, t, spaceKey = 'rgb') {\n switch (spaceKey) {\n case 'rgb': {\n const [r, g, b, alpha] = array(from.rgb, to.rgb, t);\n return new Color(r, g, b, alpha, false);\n }\n case 'hcl': {\n const [hue0, chroma0, light0, alphaF] = from.hcl;\n const [hue1, chroma1, light1, alphaT] = to.hcl;\n // https://github.com/gka/chroma.js/blob/cd1b3c0926c7a85cbdc3b1453b3a94006de91a92/src/interpolator/_hsx.js\n let hue, chroma;\n if (!isNaN(hue0) && !isNaN(hue1)) {\n let dh = hue1 - hue0;\n if (hue1 > hue0 && dh > 180) {\n dh -= 360;\n }\n else if (hue1 < hue0 && hue0 - hue1 > 180) {\n dh += 360;\n }\n hue = hue0 + t * dh;\n }\n else if (!isNaN(hue0)) {\n hue = hue0;\n if (light1 === 1 || light1 === 0)\n chroma = chroma0;\n }\n else if (!isNaN(hue1)) {\n hue = hue1;\n if (light0 === 1 || light0 === 0)\n chroma = chroma1;\n }\n else {\n hue = NaN;\n }\n const [r, g, b, alpha] = hclToRgb([\n hue,\n chroma !== null && chroma !== void 0 ? chroma : number(chroma0, chroma1, t),\n number(light0, light1, t),\n number(alphaF, alphaT, t),\n ]);\n return new Color(r, g, b, alpha, false);\n }\n case 'lab': {\n const [r, g, b, alpha] = labToRgb(array(from.lab, to.lab, t));\n return new Color(r, g, b, alpha, false);\n }\n }\n}\nfunction array(from, to, t) {\n return from.map((d, i) => {\n return number(d, to[i], t);\n });\n}\nfunction padding(from, to, t) {\n return new Padding(array(from.values, to.values, t));\n}\nfunction variableAnchorOffsetCollection(from, to, t) {\n const fromValues = from.values;\n const toValues = to.values;\n if (fromValues.length !== toValues.length) {\n throw new RuntimeError(`Cannot interpolate values of different length. from: ${from.toString()}, to: ${to.toString()}`);\n }\n const output = [];\n for (let i = 0; i < fromValues.length; i += 2) {\n // Anchor entries must match\n if (fromValues[i] !== toValues[i]) {\n throw new RuntimeError(`Cannot interpolate values containing mismatched anchors. from[${i}]: ${fromValues[i]}, to[${i}]: ${toValues[i]}`);\n }\n output.push(fromValues[i]);\n // Interpolate the offset values for each anchor\n const [fx, fy] = fromValues[i + 1];\n const [tx, ty] = toValues[i + 1];\n output.push([number(fx, tx, t), number(fy, ty, t)]);\n }\n return new VariableAnchorOffsetCollection(output);\n}\nconst interpolate = {\n number,\n color,\n array,\n padding,\n variableAnchorOffsetCollection\n};\n\nclass Interpolate {\n constructor(type, operator, interpolation, input, stops) {\n this.type = type;\n this.operator = operator;\n this.interpolation = interpolation;\n this.input = input;\n this.labels = [];\n this.outputs = [];\n for (const [label, expression] of stops) {\n this.labels.push(label);\n this.outputs.push(expression);\n }\n }\n static interpolationFactor(interpolation, input, lower, upper) {\n let t = 0;\n if (interpolation.name === 'exponential') {\n t = exponentialInterpolation(input, interpolation.base, lower, upper);\n }\n else if (interpolation.name === 'linear') {\n t = exponentialInterpolation(input, 1, lower, upper);\n }\n else if (interpolation.name === 'cubic-bezier') {\n const c = interpolation.controlPoints;\n const ub = new UnitBezier$1(c[0], c[1], c[2], c[3]);\n t = ub.solve(exponentialInterpolation(input, 1, lower, upper));\n }\n return t;\n }\n static parse(args, context) {\n let [operator, interpolation, input, ...rest] = args;\n if (!Array.isArray(interpolation) || interpolation.length === 0) {\n return context.error('Expected an interpolation type expression.', 1);\n }\n if (interpolation[0] === 'linear') {\n interpolation = { name: 'linear' };\n }\n else if (interpolation[0] === 'exponential') {\n const base = interpolation[1];\n if (typeof base !== 'number')\n return context.error('Exponential interpolation requires a numeric base.', 1, 1);\n interpolation = {\n name: 'exponential',\n base\n };\n }\n else if (interpolation[0] === 'cubic-bezier') {\n const controlPoints = interpolation.slice(1);\n if (controlPoints.length !== 4 ||\n controlPoints.some(t => typeof t !== 'number' || t < 0 || t > 1)) {\n return context.error('Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.', 1);\n }\n interpolation = {\n name: 'cubic-bezier',\n controlPoints: controlPoints\n };\n }\n else {\n return context.error(`Unknown interpolation type ${String(interpolation[0])}`, 1, 0);\n }\n if (args.length - 1 < 4) {\n return context.error(`Expected at least 4 arguments, but found only ${args.length - 1}.`);\n }\n if ((args.length - 1) % 2 !== 0) {\n return context.error('Expected an even number of arguments.');\n }\n input = context.parse(input, 2, NumberType);\n if (!input)\n return null;\n const stops = [];\n let outputType = null;\n if (operator === 'interpolate-hcl' || operator === 'interpolate-lab') {\n outputType = ColorType;\n }\n else if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n for (let i = 0; i < rest.length; i += 2) {\n const label = rest[i];\n const value = rest[i + 1];\n const labelKey = i + 3;\n const valueKey = i + 4;\n if (typeof label !== 'number') {\n return context.error('Input/output pairs for \"interpolate\" expressions must be defined using literal numeric values (not computed expressions) for the input values.', labelKey);\n }\n if (stops.length && stops[stops.length - 1][0] >= label) {\n return context.error('Input/output pairs for \"interpolate\" expressions must be arranged with input values in strictly ascending order.', labelKey);\n }\n const parsed = context.parse(value, valueKey, outputType);\n if (!parsed)\n return null;\n outputType = outputType || parsed.type;\n stops.push([label, parsed]);\n }\n if (!verifyType(outputType, NumberType) &&\n !verifyType(outputType, ColorType) &&\n !verifyType(outputType, PaddingType) &&\n !verifyType(outputType, VariableAnchorOffsetCollectionType) &&\n !verifyType(outputType, array$1(NumberType))) {\n return context.error(`Type ${toString$1(outputType)} is not interpolatable.`);\n }\n return new Interpolate(outputType, operator, interpolation, input, stops);\n }\n evaluate(ctx) {\n const labels = this.labels;\n const outputs = this.outputs;\n if (labels.length === 1) {\n return outputs[0].evaluate(ctx);\n }\n const value = this.input.evaluate(ctx);\n if (value <= labels[0]) {\n return outputs[0].evaluate(ctx);\n }\n const stopCount = labels.length;\n if (value >= labels[stopCount - 1]) {\n return outputs[stopCount - 1].evaluate(ctx);\n }\n const index = findStopLessThanOrEqualTo(labels, value);\n const lower = labels[index];\n const upper = labels[index + 1];\n const t = Interpolate.interpolationFactor(this.interpolation, value, lower, upper);\n const outputLower = outputs[index].evaluate(ctx);\n const outputUpper = outputs[index + 1].evaluate(ctx);\n switch (this.operator) {\n case 'interpolate':\n return interpolate[this.type.kind](outputLower, outputUpper, t);\n case 'interpolate-hcl':\n return interpolate.color(outputLower, outputUpper, t, 'hcl');\n case 'interpolate-lab':\n return interpolate.color(outputLower, outputUpper, t, 'lab');\n }\n }\n eachChild(fn) {\n fn(this.input);\n for (const expression of this.outputs) {\n fn(expression);\n }\n }\n outputDefined() {\n return this.outputs.every(out => out.outputDefined());\n }\n}\n/**\n * Returns a ratio that can be used to interpolate between exponential function\n * stops.\n * How it works: Two consecutive stop values define a (scaled and shifted) exponential function `f(x) = a * base^x + b`, where `base` is the user-specified base,\n * and `a` and `b` are constants affording sufficient degrees of freedom to fit\n * the function to the given stops.\n *\n * Here's a bit of algebra that lets us compute `f(x)` directly from the stop\n * values without explicitly solving for `a` and `b`:\n *\n * First stop value: `f(x0) = y0 = a * base^x0 + b`\n * Second stop value: `f(x1) = y1 = a * base^x1 + b`\n * => `y1 - y0 = a(base^x1 - base^x0)`\n * => `a = (y1 - y0)/(base^x1 - base^x0)`\n *\n * Desired value: `f(x) = y = a * base^x + b`\n * => `f(x) = y0 + a * (base^x - base^x0)`\n *\n * From the above, we can replace the `a` in `a * (base^x - base^x0)` and do a\n * little algebra:\n * ```\n * a * (base^x - base^x0) = (y1 - y0)/(base^x1 - base^x0) * (base^x - base^x0)\n * = (y1 - y0) * (base^x - base^x0) / (base^x1 - base^x0)\n * ```\n *\n * If we let `(base^x - base^x0) / (base^x1 base^x0)`, then we have\n * `f(x) = y0 + (y1 - y0) * ratio`. In other words, `ratio` may be treated as\n * an interpolation factor between the two stops' output values.\n *\n * (Note: a slightly different form for `ratio`,\n * `(base^(x-x0) - 1) / (base^(x1-x0) - 1) `, is equivalent, but requires fewer\n * expensive `Math.pow()` operations.)\n *\n * @private\n*/\nfunction exponentialInterpolation(input, base, lowerValue, upperValue) {\n const difference = upperValue - lowerValue;\n const progress = input - lowerValue;\n if (difference === 0) {\n return 0;\n }\n else if (base === 1) {\n return progress / difference;\n }\n else {\n return (Math.pow(base, progress) - 1) / (Math.pow(base, difference) - 1);\n }\n}\n\nclass Coalesce {\n constructor(type, args) {\n this.type = type;\n this.args = args;\n }\n static parse(args, context) {\n if (args.length < 2) {\n return context.error('Expectected at least one argument.');\n }\n let outputType = null;\n const expectedType = context.expectedType;\n if (expectedType && expectedType.kind !== 'value') {\n outputType = expectedType;\n }\n const parsedArgs = [];\n for (const arg of args.slice(1)) {\n const parsed = context.parse(arg, 1 + parsedArgs.length, outputType, undefined, { typeAnnotation: 'omit' });\n if (!parsed)\n return null;\n outputType = outputType || parsed.type;\n parsedArgs.push(parsed);\n }\n if (!outputType)\n throw new Error('No output type');\n // Above, we parse arguments without inferred type annotation so that\n // they don't produce a runtime error for `null` input, which would\n // preempt the desired null-coalescing behavior.\n // Thus, if any of our arguments would have needed an annotation, we\n // need to wrap the enclosing coalesce expression with it instead.\n const needsAnnotation = expectedType &&\n parsedArgs.some(arg => checkSubtype(expectedType, arg.type));\n return needsAnnotation ?\n new Coalesce(ValueType, parsedArgs) :\n new Coalesce(outputType, parsedArgs);\n }\n evaluate(ctx) {\n let result = null;\n let argCount = 0;\n let requestedImageName;\n for (const arg of this.args) {\n argCount++;\n result = arg.evaluate(ctx);\n // we need to keep track of the first requested image in a coalesce statement\n // if coalesce can't find a valid image, we return the first image name so styleimagemissing can fire\n if (result && result instanceof ResolvedImage && !result.available) {\n if (!requestedImageName) {\n requestedImageName = result.name;\n }\n result = null;\n if (argCount === this.args.length) {\n result = requestedImageName;\n }\n }\n if (result !== null)\n break;\n }\n return result;\n }\n eachChild(fn) {\n this.args.forEach(fn);\n }\n outputDefined() {\n return this.args.every(arg => arg.outputDefined());\n }\n}\n\nfunction isComparableType(op, type) {\n if (op === '==' || op === '!=') {\n // equality operator\n return type.kind === 'boolean' ||\n type.kind === 'string' ||\n type.kind === 'number' ||\n type.kind === 'null' ||\n type.kind === 'value';\n }\n else {\n // ordering operator\n return type.kind === 'string' ||\n type.kind === 'number' ||\n type.kind === 'value';\n }\n}\nfunction eq(ctx, a, b) { return a === b; }\nfunction neq(ctx, a, b) { return a !== b; }\nfunction lt(ctx, a, b) { return a < b; }\nfunction gt(ctx, a, b) { return a > b; }\nfunction lteq(ctx, a, b) { return a <= b; }\nfunction gteq(ctx, a, b) { return a >= b; }\nfunction eqCollate(ctx, a, b, c) { return c.compare(a, b) === 0; }\nfunction neqCollate(ctx, a, b, c) { return !eqCollate(ctx, a, b, c); }\nfunction ltCollate(ctx, a, b, c) { return c.compare(a, b) < 0; }\nfunction gtCollate(ctx, a, b, c) { return c.compare(a, b) > 0; }\nfunction lteqCollate(ctx, a, b, c) { return c.compare(a, b) <= 0; }\nfunction gteqCollate(ctx, a, b, c) { return c.compare(a, b) >= 0; }\n/**\n * Special form for comparison operators, implementing the signatures:\n * - (T, T, ?Collator) => boolean\n * - (T, value, ?Collator) => boolean\n * - (value, T, ?Collator) => boolean\n *\n * For inequalities, T must be either value, string, or number. For ==/!=, it\n * can also be boolean or null.\n *\n * Equality semantics are equivalent to Javascript's strict equality (===/!==)\n * -- i.e., when the arguments' types don't match, == evaluates to false, != to\n * true.\n *\n * When types don't match in an ordering comparison, a runtime error is thrown.\n *\n * @private\n */\nfunction makeComparison(op, compareBasic, compareWithCollator) {\n const isOrderComparison = op !== '==' && op !== '!=';\n return class Comparison {\n constructor(lhs, rhs, collator) {\n this.type = BooleanType;\n this.lhs = lhs;\n this.rhs = rhs;\n this.collator = collator;\n this.hasUntypedArgument = lhs.type.kind === 'value' || rhs.type.kind === 'value';\n }\n static parse(args, context) {\n if (args.length !== 3 && args.length !== 4)\n return context.error('Expected two or three arguments.');\n const op = args[0];\n let lhs = context.parse(args[1], 1, ValueType);\n if (!lhs)\n return null;\n if (!isComparableType(op, lhs.type)) {\n return context.concat(1).error(`\"${op}\" comparisons are not supported for type '${toString$1(lhs.type)}'.`);\n }\n let rhs = context.parse(args[2], 2, ValueType);\n if (!rhs)\n return null;\n if (!isComparableType(op, rhs.type)) {\n return context.concat(2).error(`\"${op}\" comparisons are not supported for type '${toString$1(rhs.type)}'.`);\n }\n if (lhs.type.kind !== rhs.type.kind &&\n lhs.type.kind !== 'value' &&\n rhs.type.kind !== 'value') {\n return context.error(`Cannot compare types '${toString$1(lhs.type)}' and '${toString$1(rhs.type)}'.`);\n }\n if (isOrderComparison) {\n // typing rules specific to less/greater than operators\n if (lhs.type.kind === 'value' && rhs.type.kind !== 'value') {\n // (value, T)\n lhs = new Assertion(rhs.type, [lhs]);\n }\n else if (lhs.type.kind !== 'value' && rhs.type.kind === 'value') {\n // (T, value)\n rhs = new Assertion(lhs.type, [rhs]);\n }\n }\n let collator = null;\n if (args.length === 4) {\n if (lhs.type.kind !== 'string' &&\n rhs.type.kind !== 'string' &&\n lhs.type.kind !== 'value' &&\n rhs.type.kind !== 'value') {\n return context.error('Cannot use collator to compare non-string types.');\n }\n collator = context.parse(args[3], 3, CollatorType);\n if (!collator)\n return null;\n }\n return new Comparison(lhs, rhs, collator);\n }\n evaluate(ctx) {\n const lhs = this.lhs.evaluate(ctx);\n const rhs = this.rhs.evaluate(ctx);\n if (isOrderComparison && this.hasUntypedArgument) {\n const lt = typeOf(lhs);\n const rt = typeOf(rhs);\n // check that type is string or number, and equal\n if (lt.kind !== rt.kind || !(lt.kind === 'string' || lt.kind === 'number')) {\n throw new RuntimeError(`Expected arguments for \"${op}\" to be (string, string) or (number, number), but found (${lt.kind}, ${rt.kind}) instead.`);\n }\n }\n if (this.collator && !isOrderComparison && this.hasUntypedArgument) {\n const lt = typeOf(lhs);\n const rt = typeOf(rhs);\n if (lt.kind !== 'string' || rt.kind !== 'string') {\n return compareBasic(ctx, lhs, rhs);\n }\n }\n return this.collator ?\n compareWithCollator(ctx, lhs, rhs, this.collator.evaluate(ctx)) :\n compareBasic(ctx, lhs, rhs);\n }\n eachChild(fn) {\n fn(this.lhs);\n fn(this.rhs);\n if (this.collator) {\n fn(this.collator);\n }\n }\n outputDefined() {\n return true;\n }\n };\n}\nconst Equals = makeComparison('==', eq, eqCollate);\nconst NotEquals = makeComparison('!=', neq, neqCollate);\nconst LessThan = makeComparison('<', lt, ltCollate);\nconst GreaterThan = makeComparison('>', gt, gtCollate);\nconst LessThanOrEqual = makeComparison('<=', lteq, lteqCollate);\nconst GreaterThanOrEqual = makeComparison('>=', gteq, gteqCollate);\n\nclass CollatorExpression {\n constructor(caseSensitive, diacriticSensitive, locale) {\n this.type = CollatorType;\n this.locale = locale;\n this.caseSensitive = caseSensitive;\n this.diacriticSensitive = diacriticSensitive;\n }\n static parse(args, context) {\n if (args.length !== 2)\n return context.error('Expected one argument.');\n const options = args[1];\n if (typeof options !== 'object' || Array.isArray(options))\n return context.error('Collator options argument must be an object.');\n const caseSensitive = context.parse(options['case-sensitive'] === undefined ? false : options['case-sensitive'], 1, BooleanType);\n if (!caseSensitive)\n return null;\n const diacriticSensitive = context.parse(options['diacritic-sensitive'] === undefined ? false : options['diacritic-sensitive'], 1, BooleanType);\n if (!diacriticSensitive)\n return null;\n let locale = null;\n if (options['locale']) {\n locale = context.parse(options['locale'], 1, StringType);\n if (!locale)\n return null;\n }\n return new CollatorExpression(caseSensitive, diacriticSensitive, locale);\n }\n evaluate(ctx) {\n return new Collator(this.caseSensitive.evaluate(ctx), this.diacriticSensitive.evaluate(ctx), this.locale ? this.locale.evaluate(ctx) : null);\n }\n eachChild(fn) {\n fn(this.caseSensitive);\n fn(this.diacriticSensitive);\n if (this.locale) {\n fn(this.locale);\n }\n }\n outputDefined() {\n // Technically the set of possible outputs is the combinatoric set of Collators produced\n // by all possible outputs of locale/caseSensitive/diacriticSensitive\n // But for the primary use of Collators in comparison operators, we ignore the Collator's\n // possible outputs anyway, so we can get away with leaving this false for now.\n return false;\n }\n}\n\nclass NumberFormat {\n constructor(number, locale, currency, minFractionDigits, maxFractionDigits) {\n this.type = StringType;\n this.number = number;\n this.locale = locale;\n this.currency = currency;\n this.minFractionDigits = minFractionDigits;\n this.maxFractionDigits = maxFractionDigits;\n }\n static parse(args, context) {\n if (args.length !== 3)\n return context.error('Expected two arguments.');\n const number = context.parse(args[1], 1, NumberType);\n if (!number)\n return null;\n const options = args[2];\n if (typeof options !== 'object' || Array.isArray(options))\n return context.error('NumberFormat options argument must be an object.');\n let locale = null;\n if (options['locale']) {\n locale = context.parse(options['locale'], 1, StringType);\n if (!locale)\n return null;\n }\n let currency = null;\n if (options['currency']) {\n currency = context.parse(options['currency'], 1, StringType);\n if (!currency)\n return null;\n }\n let minFractionDigits = null;\n if (options['min-fraction-digits']) {\n minFractionDigits = context.parse(options['min-fraction-digits'], 1, NumberType);\n if (!minFractionDigits)\n return null;\n }\n let maxFractionDigits = null;\n if (options['max-fraction-digits']) {\n maxFractionDigits = context.parse(options['max-fraction-digits'], 1, NumberType);\n if (!maxFractionDigits)\n return null;\n }\n return new NumberFormat(number, locale, currency, minFractionDigits, maxFractionDigits);\n }\n evaluate(ctx) {\n return new Intl.NumberFormat(this.locale ? this.locale.evaluate(ctx) : [], {\n style: this.currency ? 'currency' : 'decimal',\n currency: this.currency ? this.currency.evaluate(ctx) : undefined,\n minimumFractionDigits: this.minFractionDigits ? this.minFractionDigits.evaluate(ctx) : undefined,\n maximumFractionDigits: this.maxFractionDigits ? this.maxFractionDigits.evaluate(ctx) : undefined,\n }).format(this.number.evaluate(ctx));\n }\n eachChild(fn) {\n fn(this.number);\n if (this.locale) {\n fn(this.locale);\n }\n if (this.currency) {\n fn(this.currency);\n }\n if (this.minFractionDigits) {\n fn(this.minFractionDigits);\n }\n if (this.maxFractionDigits) {\n fn(this.maxFractionDigits);\n }\n }\n outputDefined() {\n return false;\n }\n}\n\nclass FormatExpression {\n constructor(sections) {\n this.type = FormattedType;\n this.sections = sections;\n }\n static parse(args, context) {\n if (args.length < 2) {\n return context.error('Expected at least one argument.');\n }\n const firstArg = args[1];\n if (!Array.isArray(firstArg) && typeof firstArg === 'object') {\n return context.error('First argument must be an image or text section.');\n }\n const sections = [];\n let nextTokenMayBeObject = false;\n for (let i = 1; i <= args.length - 1; ++i) {\n const arg = args[i];\n if (nextTokenMayBeObject && typeof arg === 'object' && !Array.isArray(arg)) {\n nextTokenMayBeObject = false;\n let scale = null;\n if (arg['font-scale']) {\n scale = context.parse(arg['font-scale'], 1, NumberType);\n if (!scale)\n return null;\n }\n let font = null;\n if (arg['text-font']) {\n font = context.parse(arg['text-font'], 1, array$1(StringType));\n if (!font)\n return null;\n }\n let textColor = null;\n if (arg['text-color']) {\n textColor = context.parse(arg['text-color'], 1, ColorType);\n if (!textColor)\n return null;\n }\n const lastExpression = sections[sections.length - 1];\n lastExpression.scale = scale;\n lastExpression.font = font;\n lastExpression.textColor = textColor;\n }\n else {\n const content = context.parse(args[i], 1, ValueType);\n if (!content)\n return null;\n const kind = content.type.kind;\n if (kind !== 'string' && kind !== 'value' && kind !== 'null' && kind !== 'resolvedImage')\n return context.error('Formatted text type must be \\'string\\', \\'value\\', \\'image\\' or \\'null\\'.');\n nextTokenMayBeObject = true;\n sections.push({ content, scale: null, font: null, textColor: null });\n }\n }\n return new FormatExpression(sections);\n }\n evaluate(ctx) {\n const evaluateSection = section => {\n const evaluatedContent = section.content.evaluate(ctx);\n if (typeOf(evaluatedContent) === ResolvedImageType) {\n return new FormattedSection('', evaluatedContent, null, null, null);\n }\n return new FormattedSection(toString(evaluatedContent), null, section.scale ? section.scale.evaluate(ctx) : null, section.font ? section.font.evaluate(ctx).join(',') : null, section.textColor ? section.textColor.evaluate(ctx) : null);\n };\n return new Formatted(this.sections.map(evaluateSection));\n }\n eachChild(fn) {\n for (const section of this.sections) {\n fn(section.content);\n if (section.scale) {\n fn(section.scale);\n }\n if (section.font) {\n fn(section.font);\n }\n if (section.textColor) {\n fn(section.textColor);\n }\n }\n }\n outputDefined() {\n // Technically the combinatoric set of all children\n // Usually, this.text will be undefined anyway\n return false;\n }\n}\n\nclass ImageExpression {\n constructor(input) {\n this.type = ResolvedImageType;\n this.input = input;\n }\n static parse(args, context) {\n if (args.length !== 2) {\n return context.error('Expected two arguments.');\n }\n const name = context.parse(args[1], 1, StringType);\n if (!name)\n return context.error('No image name provided.');\n return new ImageExpression(name);\n }\n evaluate(ctx) {\n const evaluatedImageName = this.input.evaluate(ctx);\n const value = ResolvedImage.fromString(evaluatedImageName);\n if (value && ctx.availableImages)\n value.available = ctx.availableImages.indexOf(evaluatedImageName) > -1;\n return value;\n }\n eachChild(fn) {\n fn(this.input);\n }\n outputDefined() {\n // The output of image is determined by the list of available images in the evaluation context\n return false;\n }\n}\n\nclass Length {\n constructor(input) {\n this.type = NumberType;\n this.input = input;\n }\n static parse(args, context) {\n if (args.length !== 2)\n return context.error(`Expected 1 argument, but found ${args.length - 1} instead.`);\n const input = context.parse(args[1], 1);\n if (!input)\n return null;\n if (input.type.kind !== 'array' && input.type.kind !== 'string' && input.type.kind !== 'value')\n return context.error(`Expected argument of type string or array, but found ${toString$1(input.type)} instead.`);\n return new Length(input);\n }\n evaluate(ctx) {\n const input = this.input.evaluate(ctx);\n if (typeof input === 'string') {\n // The length may be affected by surrogate pairs.\n return [...input].length;\n }\n else if (Array.isArray(input)) {\n return input.length;\n }\n else {\n throw new RuntimeError(`Expected value to be of type string or array, but found ${toString$1(typeOf(input))} instead.`);\n }\n }\n eachChild(fn) {\n fn(this.input);\n }\n outputDefined() {\n return false;\n }\n}\n\nconst EXTENT = 8192;\nfunction getTileCoordinates(p, canonical) {\n const x = mercatorXfromLng(p[0]);\n const y = mercatorYfromLat(p[1]);\n const tilesAtZoom = Math.pow(2, canonical.z);\n return [Math.round(x * tilesAtZoom * EXTENT), Math.round(y * tilesAtZoom * EXTENT)];\n}\nfunction getLngLatFromTileCoord(coord, canonical) {\n const tilesAtZoom = Math.pow(2, canonical.z);\n const x = (coord[0] / EXTENT + canonical.x) / tilesAtZoom;\n const y = (coord[1] / EXTENT + canonical.y) / tilesAtZoom;\n return [lngFromMercatorXfromLng(x), latFromMercatorY(y)];\n}\nfunction mercatorXfromLng(lng) {\n return (180 + lng) / 360;\n}\nfunction lngFromMercatorXfromLng(mercatorX) {\n return mercatorX * 360 - 180;\n}\nfunction mercatorYfromLat(lat) {\n return (180 - (180 / Math.PI * Math.log(Math.tan(Math.PI / 4 + lat * Math.PI / 360)))) / 360;\n}\nfunction latFromMercatorY(mercatorY) {\n return 360 / Math.PI * Math.atan(Math.exp((180 - mercatorY * 360) * Math.PI / 180)) - 90;\n}\nfunction updateBBox(bbox, coord) {\n bbox[0] = Math.min(bbox[0], coord[0]);\n bbox[1] = Math.min(bbox[1], coord[1]);\n bbox[2] = Math.max(bbox[2], coord[0]);\n bbox[3] = Math.max(bbox[3], coord[1]);\n}\nfunction boxWithinBox(bbox1, bbox2) {\n if (bbox1[0] <= bbox2[0])\n return false;\n if (bbox1[2] >= bbox2[2])\n return false;\n if (bbox1[1] <= bbox2[1])\n return false;\n if (bbox1[3] >= bbox2[3])\n return false;\n return true;\n}\nfunction rayIntersect(p, p1, p2) {\n return ((p1[1] > p[1]) !== (p2[1] > p[1])) && (p[0] < (p2[0] - p1[0]) * (p[1] - p1[1]) / (p2[1] - p1[1]) + p1[0]);\n}\nfunction pointOnBoundary(p, p1, p2) {\n const x1 = p[0] - p1[0];\n const y1 = p[1] - p1[1];\n const x2 = p[0] - p2[0];\n const y2 = p[1] - p2[1];\n return (x1 * y2 - x2 * y1 === 0) && (x1 * x2 <= 0) && (y1 * y2 <= 0);\n}\n// a, b are end points for line segment1, c and d are end points for line segment2\nfunction segmentIntersectSegment(a, b, c, d) {\n // check if two segments are parallel or not\n // precondition is end point a, b is inside polygon, if line a->b is\n // parallel to polygon edge c->d, then a->b won't intersect with c->d\n const vectorP = [b[0] - a[0], b[1] - a[1]];\n const vectorQ = [d[0] - c[0], d[1] - c[1]];\n if (perp(vectorQ, vectorP) === 0)\n return false;\n // If lines are intersecting with each other, the relative location should be:\n // a and b lie in different sides of segment c->d\n // c and d lie in different sides of segment a->b\n if (twoSided(a, b, c, d) && twoSided(c, d, a, b))\n return true;\n return false;\n}\nfunction lineIntersectPolygon(p1, p2, polygon) {\n for (const ring of polygon) {\n // loop through every edge of the ring\n for (let j = 0; j < ring.length - 1; ++j) {\n if (segmentIntersectSegment(p1, p2, ring[j], ring[j + 1])) {\n return true;\n }\n }\n }\n return false;\n}\n// ray casting algorithm for detecting if point is in polygon\nfunction pointWithinPolygon(point, rings, trueIfOnBoundary = false) {\n let inside = false;\n for (const ring of rings) {\n for (let j = 0; j < ring.length - 1; j++) {\n if (pointOnBoundary(point, ring[j], ring[j + 1]))\n return trueIfOnBoundary;\n if (rayIntersect(point, ring[j], ring[j + 1]))\n inside = !inside;\n }\n }\n return inside;\n}\nfunction pointWithinPolygons(point, polygons) {\n for (const polygon of polygons) {\n if (pointWithinPolygon(point, polygon))\n return true;\n }\n return false;\n}\nfunction lineStringWithinPolygon(line, polygon) {\n // First, check if geometry points of line segments are all inside polygon\n for (const point of line) {\n if (!pointWithinPolygon(point, polygon)) {\n return false;\n }\n }\n // Second, check if there is line segment intersecting polygon edge\n for (let i = 0; i < line.length - 1; ++i) {\n if (lineIntersectPolygon(line[i], line[i + 1], polygon)) {\n return false;\n }\n }\n return true;\n}\nfunction lineStringWithinPolygons(line, polygons) {\n for (const polygon of polygons) {\n if (lineStringWithinPolygon(line, polygon))\n return true;\n }\n return false;\n}\nfunction perp(v1, v2) {\n return (v1[0] * v2[1] - v1[1] * v2[0]);\n}\n// check if p1 and p2 are in different sides of line segment q1->q2\nfunction twoSided(p1, p2, q1, q2) {\n // q1->p1 (x1, y1), q1->p2 (x2, y2), q1->q2 (x3, y3)\n const x1 = p1[0] - q1[0];\n const y1 = p1[1] - q1[1];\n const x2 = p2[0] - q1[0];\n const y2 = p2[1] - q1[1];\n const x3 = q2[0] - q1[0];\n const y3 = q2[1] - q1[1];\n const det1 = (x1 * y3 - x3 * y1);\n const det2 = (x2 * y3 - x3 * y2);\n if ((det1 > 0 && det2 < 0) || (det1 < 0 && det2 > 0))\n return true;\n return false;\n}\n\nfunction getTilePolygon(coordinates, bbox, canonical) {\n const polygon = [];\n for (let i = 0; i < coordinates.length; i++) {\n const ring = [];\n for (let j = 0; j < coordinates[i].length; j++) {\n const coord = getTileCoordinates(coordinates[i][j], canonical);\n updateBBox(bbox, coord);\n ring.push(coord);\n }\n polygon.push(ring);\n }\n return polygon;\n}\nfunction getTilePolygons(coordinates, bbox, canonical) {\n const polygons = [];\n for (let i = 0; i < coordinates.length; i++) {\n const polygon = getTilePolygon(coordinates[i], bbox, canonical);\n polygons.push(polygon);\n }\n return polygons;\n}\nfunction updatePoint(p, bbox, polyBBox, worldSize) {\n if (p[0] < polyBBox[0] || p[0] > polyBBox[2]) {\n const halfWorldSize = worldSize * 0.5;\n let shift = (p[0] - polyBBox[0] > halfWorldSize) ? -worldSize : (polyBBox[0] - p[0] > halfWorldSize) ? worldSize : 0;\n if (shift === 0) {\n shift = (p[0] - polyBBox[2] > halfWorldSize) ? -worldSize : (polyBBox[2] - p[0] > halfWorldSize) ? worldSize : 0;\n }\n p[0] += shift;\n }\n updateBBox(bbox, p);\n}\nfunction resetBBox(bbox) {\n bbox[0] = bbox[1] = Infinity;\n bbox[2] = bbox[3] = -Infinity;\n}\nfunction getTilePoints(geometry, pointBBox, polyBBox, canonical) {\n const worldSize = Math.pow(2, canonical.z) * EXTENT;\n const shifts = [canonical.x * EXTENT, canonical.y * EXTENT];\n const tilePoints = [];\n for (const points of geometry) {\n for (const point of points) {\n const p = [point.x + shifts[0], point.y + shifts[1]];\n updatePoint(p, pointBBox, polyBBox, worldSize);\n tilePoints.push(p);\n }\n }\n return tilePoints;\n}\nfunction getTileLines(geometry, lineBBox, polyBBox, canonical) {\n const worldSize = Math.pow(2, canonical.z) * EXTENT;\n const shifts = [canonical.x * EXTENT, canonical.y * EXTENT];\n const tileLines = [];\n for (const line of geometry) {\n const tileLine = [];\n for (const point of line) {\n const p = [point.x + shifts[0], point.y + shifts[1]];\n updateBBox(lineBBox, p);\n tileLine.push(p);\n }\n tileLines.push(tileLine);\n }\n if (lineBBox[2] - lineBBox[0] <= worldSize / 2) {\n resetBBox(lineBBox);\n for (const line of tileLines) {\n for (const p of line) {\n updatePoint(p, lineBBox, polyBBox, worldSize);\n }\n }\n }\n return tileLines;\n}\nfunction pointsWithinPolygons(ctx, polygonGeometry) {\n const pointBBox = [Infinity, Infinity, -Infinity, -Infinity];\n const polyBBox = [Infinity, Infinity, -Infinity, -Infinity];\n const canonical = ctx.canonicalID();\n if (polygonGeometry.type === 'Polygon') {\n const tilePolygon = getTilePolygon(polygonGeometry.coordinates, polyBBox, canonical);\n const tilePoints = getTilePoints(ctx.geometry(), pointBBox, polyBBox, canonical);\n if (!boxWithinBox(pointBBox, polyBBox))\n return false;\n for (const point of tilePoints) {\n if (!pointWithinPolygon(point, tilePolygon))\n return false;\n }\n }\n if (polygonGeometry.type === 'MultiPolygon') {\n const tilePolygons = getTilePolygons(polygonGeometry.coordinates, polyBBox, canonical);\n const tilePoints = getTilePoints(ctx.geometry(), pointBBox, polyBBox, canonical);\n if (!boxWithinBox(pointBBox, polyBBox))\n return false;\n for (const point of tilePoints) {\n if (!pointWithinPolygons(point, tilePolygons))\n return false;\n }\n }\n return true;\n}\nfunction linesWithinPolygons(ctx, polygonGeometry) {\n const lineBBox = [Infinity, Infinity, -Infinity, -Infinity];\n const polyBBox = [Infinity, Infinity, -Infinity, -Infinity];\n const canonical = ctx.canonicalID();\n if (polygonGeometry.type === 'Polygon') {\n const tilePolygon = getTilePolygon(polygonGeometry.coordinates, polyBBox, canonical);\n const tileLines = getTileLines(ctx.geometry(), lineBBox, polyBBox, canonical);\n if (!boxWithinBox(lineBBox, polyBBox))\n return false;\n for (const line of tileLines) {\n if (!lineStringWithinPolygon(line, tilePolygon))\n return false;\n }\n }\n if (polygonGeometry.type === 'MultiPolygon') {\n const tilePolygons = getTilePolygons(polygonGeometry.coordinates, polyBBox, canonical);\n const tileLines = getTileLines(ctx.geometry(), lineBBox, polyBBox, canonical);\n if (!boxWithinBox(lineBBox, polyBBox))\n return false;\n for (const line of tileLines) {\n if (!lineStringWithinPolygons(line, tilePolygons))\n return false;\n }\n }\n return true;\n}\nclass Within {\n constructor(geojson, geometries) {\n this.type = BooleanType;\n this.geojson = geojson;\n this.geometries = geometries;\n }\n static parse(args, context) {\n if (args.length !== 2)\n return context.error(`'within' expression requires exactly one argument, but found ${args.length - 1} instead.`);\n if (isValue(args[1])) {\n const geojson = args[1];\n if (geojson.type === 'FeatureCollection') {\n const polygonsCoords = [];\n for (const polygon of geojson.features) {\n const { type, coordinates } = polygon.geometry;\n if (type === 'Polygon') {\n polygonsCoords.push(coordinates);\n }\n if (type === 'MultiPolygon') {\n polygonsCoords.push(...coordinates);\n }\n }\n if (polygonsCoords.length) {\n const multipolygonWrapper = {\n type: 'MultiPolygon',\n coordinates: polygonsCoords\n };\n return new Within(geojson, multipolygonWrapper);\n }\n }\n else if (geojson.type === 'Feature') {\n const type = geojson.geometry.type;\n if (type === 'Polygon' || type === 'MultiPolygon') {\n return new Within(geojson, geojson.geometry);\n }\n }\n else if (geojson.type === 'Polygon' || geojson.type === 'MultiPolygon') {\n return new Within(geojson, geojson);\n }\n }\n return context.error('\\'within\\' expression requires valid geojson object that contains polygon geometry type.');\n }\n evaluate(ctx) {\n if (ctx.geometry() != null && ctx.canonicalID() != null) {\n if (ctx.geometryType() === 'Point') {\n return pointsWithinPolygons(ctx, this.geometries);\n }\n else if (ctx.geometryType() === 'LineString') {\n return linesWithinPolygons(ctx, this.geometries);\n }\n }\n return false;\n }\n eachChild() { }\n outputDefined() {\n return true;\n }\n}\n\nclass TinyQueue {\n constructor(data = [], compare = (a, b) => (a < b ? -1 : a > b ? 1 : 0)) {\n this.data = data;\n this.length = this.data.length;\n this.compare = compare;\n\n if (this.length > 0) {\n for (let i = (this.length >> 1) - 1; i >= 0; i--) this._down(i);\n }\n }\n\n push(item) {\n this.data.push(item);\n this._up(this.length++);\n }\n\n pop() {\n if (this.length === 0) return undefined;\n\n const top = this.data[0];\n const bottom = this.data.pop();\n\n if (--this.length > 0) {\n this.data[0] = bottom;\n this._down(0);\n }\n\n return top;\n }\n\n peek() {\n return this.data[0];\n }\n\n _up(pos) {\n const {data, compare} = this;\n const item = data[pos];\n\n while (pos > 0) {\n const parent = (pos - 1) >> 1;\n const current = data[parent];\n if (compare(item, current) >= 0) break;\n data[pos] = current;\n pos = parent;\n }\n\n data[pos] = item;\n }\n\n _down(pos) {\n const {data, compare} = this;\n const halfLength = this.length >> 1;\n const item = data[pos];\n\n while (pos < halfLength) {\n let bestChild = (pos << 1) + 1; // initially it is the left child\n const right = bestChild + 1;\n\n if (right < this.length && compare(data[right], data[bestChild]) < 0) {\n bestChild = right;\n }\n if (compare(data[bestChild], item) >= 0) break;\n\n data[pos] = data[bestChild];\n pos = bestChild;\n }\n\n data[pos] = item;\n }\n}\n\nfunction quickselect(arr, k, left, right, compare) {\n quickselectStep(arr, k, left, right || (arr.length - 1), compare || defaultCompare);\n}\n\nfunction quickselectStep(arr, k, left, right, compare) {\n\n while (right > left) {\n if (right - left > 600) {\n var n = right - left + 1;\n var m = k - left + 1;\n var z = Math.log(n);\n var s = 0.5 * Math.exp(2 * z / 3);\n var sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n var newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n var newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n quickselectStep(arr, k, newLeft, newRight, compare);\n }\n\n var t = arr[k];\n var i = left;\n var j = right;\n\n swap(arr, left, k);\n if (compare(arr[right], t) > 0) swap(arr, left, right);\n\n while (i < j) {\n swap(arr, i, j);\n i++;\n j--;\n while (compare(arr[i], t) < 0) i++;\n while (compare(arr[j], t) > 0) j--;\n }\n\n if (compare(arr[left], t) === 0) swap(arr, left, j);\n else {\n j++;\n swap(arr, j, right);\n }\n\n if (j <= k) left = j + 1;\n if (k <= j) right = j - 1;\n }\n}\n\nfunction swap(arr, i, j) {\n var tmp = arr[i];\n arr[i] = arr[j];\n arr[j] = tmp;\n}\n\nfunction defaultCompare(a, b) {\n return a < b ? -1 : a > b ? 1 : 0;\n}\n\n/**\n * Classifies an array of rings into polygons with outer rings and holes\n * @param rings - the rings to classify\n * @param maxRings - the maximum number of rings to include in a polygon, use 0 to include all rings\n * @returns an array of polygons with internal rings as holes\n */\nfunction classifyRings(rings, maxRings) {\n const len = rings.length;\n if (len <= 1)\n return [rings];\n const polygons = [];\n let polygon;\n let ccw;\n for (const ring of rings) {\n const area = calculateSignedArea(ring);\n if (area === 0)\n continue;\n ring.area = Math.abs(area);\n if (ccw === undefined)\n ccw = area < 0;\n if (ccw === area < 0) {\n if (polygon)\n polygons.push(polygon);\n polygon = [ring];\n }\n else {\n polygon.push(ring);\n }\n }\n if (polygon)\n polygons.push(polygon);\n // Earcut performance degrades with the # of rings in a polygon. For this\n // reason, we limit strip out all but the `maxRings` largest rings.\n if (maxRings > 1) {\n for (let j = 0; j < polygons.length; j++) {\n if (polygons[j].length <= maxRings)\n continue;\n quickselect(polygons[j], maxRings, 1, polygons[j].length - 1, compareAreas);\n polygons[j] = polygons[j].slice(0, maxRings);\n }\n }\n return polygons;\n}\nfunction compareAreas(a, b) {\n return b.area - a.area;\n}\n/**\n * Returns the signed area for the polygon ring. Positive areas are exterior rings and\n * have a clockwise winding. Negative areas are interior rings and have a counter clockwise\n * ordering.\n *\n * @param ring - Exterior or interior ring\n * @returns Signed area\n */\nfunction calculateSignedArea(ring) {\n let sum = 0;\n for (let i = 0, len = ring.length, j = len - 1, p1, p2; i < len; j = i++) {\n p1 = ring[i];\n p2 = ring[j];\n sum += (p2.x - p1.x) * (p1.y + p2.y);\n }\n return sum;\n}\n\n// This is taken from https://github.com/mapbox/cheap-ruler/ in order to take only the relevant parts\n// Values that define WGS84 ellipsoid model of the Earth\nconst RE = 6378.137; // equatorial radius\nconst FE = 1 / 298.257223563; // flattening\nconst E2 = FE * (2 - FE);\nconst RAD = Math.PI / 180;\nclass CheapRuler {\n constructor(lat) {\n // Curvature formulas from https://en.wikipedia.org/wiki/Earth_radius#Meridional\n const m = RAD * RE * 1000;\n const coslat = Math.cos(lat * RAD);\n const w2 = 1 / (1 - E2 * (1 - coslat * coslat));\n const w = Math.sqrt(w2);\n // multipliers for converting longitude and latitude degrees into distance\n this.kx = m * w * coslat; // based on normal radius of curvature\n this.ky = m * w * w2 * (1 - E2); // based on meridonal radius of curvature\n }\n /**\n * Given two points of the form [longitude, latitude], returns the distance.\n *\n * @param a - point [longitude, latitude]\n * @param b - point [longitude, latitude]\n * @returns distance\n * @example\n * const distance = ruler.distance([30.5, 50.5], [30.51, 50.49]);\n * //=distance\n */\n distance(a, b) {\n const dx = this.wrap(a[0] - b[0]) * this.kx;\n const dy = (a[1] - b[1]) * this.ky;\n return Math.sqrt(dx * dx + dy * dy);\n }\n /**\n * Returns an object of the form {point, index, t}, where point is closest point on the line\n * from the given point, index is the start index of the segment with the closest point,\n * and t is a parameter from 0 to 1 that indicates where the closest point is on that segment.\n *\n * @param line - an array of points that form the line\n * @param p - point [longitude, latitude]\n * @returns the nearest point, its index in the array and the proportion along the line\n * @example\n * const point = ruler.pointOnLine(line, [-67.04, 50.5]).point;\n * //=point\n */\n pointOnLine(line, p) {\n let minDist = Infinity;\n let minX, minY, minI, minT;\n for (let i = 0; i < line.length - 1; i++) {\n let x = line[i][0];\n let y = line[i][1];\n let dx = this.wrap(line[i + 1][0] - x) * this.kx;\n let dy = (line[i + 1][1] - y) * this.ky;\n let t = 0;\n if (dx !== 0 || dy !== 0) {\n t = (this.wrap(p[0] - x) * this.kx * dx + (p[1] - y) * this.ky * dy) / (dx * dx + dy * dy);\n if (t > 1) {\n x = line[i + 1][0];\n y = line[i + 1][1];\n }\n else if (t > 0) {\n x += (dx / this.kx) * t;\n y += (dy / this.ky) * t;\n }\n }\n dx = this.wrap(p[0] - x) * this.kx;\n dy = (p[1] - y) * this.ky;\n const sqDist = dx * dx + dy * dy;\n if (sqDist < minDist) {\n minDist = sqDist;\n minX = x;\n minY = y;\n minI = i;\n minT = t;\n }\n }\n return {\n point: [minX, minY],\n index: minI,\n t: Math.max(0, Math.min(1, minT))\n };\n }\n wrap(deg) {\n while (deg < -180)\n deg += 360;\n while (deg > 180)\n deg -= 360;\n return deg;\n }\n}\n\nconst MinPointsSize = 100;\nconst MinLinePointsSize = 50;\nfunction compareDistPair(a, b) {\n return b[0] - a[0];\n}\nfunction getRangeSize(range) {\n return range[1] - range[0] + 1;\n}\nfunction isRangeSafe(range, threshold) {\n return range[1] >= range[0] && range[1] < threshold;\n}\nfunction splitRange(range, isLine) {\n if (range[0] > range[1]) {\n return [null, null];\n }\n const size = getRangeSize(range);\n if (isLine) {\n if (size === 2) {\n return [range, null];\n }\n const size1 = Math.floor(size / 2);\n return [[range[0], range[0] + size1],\n [range[0] + size1, range[1]]];\n }\n if (size === 1) {\n return [range, null];\n }\n const size1 = Math.floor(size / 2) - 1;\n return [[range[0], range[0] + size1],\n [range[0] + size1 + 1, range[1]]];\n}\nfunction getBBox(coords, range) {\n if (!isRangeSafe(range, coords.length)) {\n return [Infinity, Infinity, -Infinity, -Infinity];\n }\n const bbox = [Infinity, Infinity, -Infinity, -Infinity];\n for (let i = range[0]; i <= range[1]; ++i) {\n updateBBox(bbox, coords[i]);\n }\n return bbox;\n}\nfunction getPolygonBBox(polygon) {\n const bbox = [Infinity, Infinity, -Infinity, -Infinity];\n for (const ring of polygon) {\n for (const coord of ring) {\n updateBBox(bbox, coord);\n }\n }\n return bbox;\n}\nfunction isValidBBox(bbox) {\n return bbox[0] !== -Infinity && bbox[1] !== -Infinity && bbox[2] !== Infinity && bbox[3] !== Infinity;\n}\n// Calculate the distance between two bounding boxes.\n// Calculate the delta in x and y direction, and use two fake points {0.0, 0.0}\n// and {dx, dy} to calculate the distance. Distance will be 0.0 if bounding box are overlapping.\nfunction bboxToBBoxDistance(bbox1, bbox2, ruler) {\n if (!isValidBBox(bbox1) || !isValidBBox(bbox2)) {\n return NaN;\n }\n let dx = 0.0;\n let dy = 0.0;\n // bbox1 in left side\n if (bbox1[2] < bbox2[0]) {\n dx = bbox2[0] - bbox1[2];\n }\n // bbox1 in right side\n if (bbox1[0] > bbox2[2]) {\n dx = bbox1[0] - bbox2[2];\n }\n // bbox1 in above side\n if (bbox1[1] > bbox2[3]) {\n dy = bbox1[1] - bbox2[3];\n }\n // bbox1 in down side\n if (bbox1[3] < bbox2[1]) {\n dy = bbox2[1] - bbox1[3];\n }\n return ruler.distance([0.0, 0.0], [dx, dy]);\n}\nfunction pointToLineDistance(point, line, ruler) {\n const nearestPoint = ruler.pointOnLine(line, point);\n return ruler.distance(point, nearestPoint.point);\n}\nfunction segmentToSegmentDistance(p1, p2, q1, q2, ruler) {\n const dist1 = Math.min(pointToLineDistance(p1, [q1, q2], ruler), pointToLineDistance(p2, [q1, q2], ruler));\n const dist2 = Math.min(pointToLineDistance(q1, [p1, p2], ruler), pointToLineDistance(q2, [p1, p2], ruler));\n return Math.min(dist1, dist2);\n}\nfunction lineToLineDistance(line1, range1, line2, range2, ruler) {\n const rangeSafe = isRangeSafe(range1, line1.length) && isRangeSafe(range2, line2.length);\n if (!rangeSafe) {\n return Infinity;\n }\n let dist = Infinity;\n for (let i = range1[0]; i < range1[1]; ++i) {\n const p1 = line1[i];\n const p2 = line1[i + 1];\n for (let j = range2[0]; j < range2[1]; ++j) {\n const q1 = line2[j];\n const q2 = line2[j + 1];\n if (segmentIntersectSegment(p1, p2, q1, q2)) {\n return 0.0;\n }\n dist = Math.min(dist, segmentToSegmentDistance(p1, p2, q1, q2, ruler));\n }\n }\n return dist;\n}\nfunction pointsToPointsDistance(points1, range1, points2, range2, ruler) {\n const rangeSafe = isRangeSafe(range1, points1.length) && isRangeSafe(range2, points2.length);\n if (!rangeSafe) {\n return NaN;\n }\n let dist = Infinity;\n for (let i = range1[0]; i <= range1[1]; ++i) {\n for (let j = range2[0]; j <= range2[1]; ++j) {\n dist = Math.min(dist, ruler.distance(points1[i], points2[j]));\n if (dist === 0.0) {\n return dist;\n }\n }\n }\n return dist;\n}\nfunction pointToPolygonDistance(point, polygon, ruler) {\n if (pointWithinPolygon(point, polygon, true)) {\n return 0.0;\n }\n let dist = Infinity;\n for (const ring of polygon) {\n const front = ring[0];\n const back = ring[ring.length - 1];\n if (front !== back) {\n dist = Math.min(dist, pointToLineDistance(point, [back, front], ruler));\n if (dist === 0.0) {\n return dist;\n }\n }\n const nearestPoint = ruler.pointOnLine(ring, point);\n dist = Math.min(dist, ruler.distance(point, nearestPoint.point));\n if (dist === 0.0) {\n return dist;\n }\n }\n return dist;\n}\nfunction lineToPolygonDistance(line, range, polygon, ruler) {\n if (!isRangeSafe(range, line.length)) {\n return NaN;\n }\n for (let i = range[0]; i <= range[1]; ++i) {\n if (pointWithinPolygon(line[i], polygon, true)) {\n return 0.0;\n }\n }\n let dist = Infinity;\n for (let i = range[0]; i < range[1]; ++i) {\n const p1 = line[i];\n const p2 = line[i + 1];\n for (const ring of polygon) {\n for (let j = 0, len = ring.length, k = len - 1; j < len; k = j++) {\n const q1 = ring[k];\n const q2 = ring[j];\n if (segmentIntersectSegment(p1, p2, q1, q2)) {\n return 0.0;\n }\n dist = Math.min(dist, segmentToSegmentDistance(p1, p2, q1, q2, ruler));\n }\n }\n }\n return dist;\n}\nfunction polygonIntersect(poly1, poly2) {\n for (const ring of poly1) {\n for (const point of ring) {\n if (pointWithinPolygon(point, poly2, true)) {\n return true;\n }\n }\n }\n return false;\n}\nfunction polygonToPolygonDistance(polygon1, polygon2, ruler, currentMiniDist = Infinity) {\n const bbox1 = getPolygonBBox(polygon1);\n const bbox2 = getPolygonBBox(polygon2);\n if (currentMiniDist !== Infinity && bboxToBBoxDistance(bbox1, bbox2, ruler) >= currentMiniDist) {\n return currentMiniDist;\n }\n if (boxWithinBox(bbox1, bbox2)) {\n if (polygonIntersect(polygon1, polygon2)) {\n return 0.0;\n }\n }\n else if (polygonIntersect(polygon2, polygon1)) {\n return 0.0;\n }\n let dist = Infinity;\n for (const ring1 of polygon1) {\n for (let i = 0, len1 = ring1.length, l = len1 - 1; i < len1; l = i++) {\n const p1 = ring1[l];\n const p2 = ring1[i];\n for (const ring2 of polygon2) {\n for (let j = 0, len2 = ring2.length, k = len2 - 1; j < len2; k = j++) {\n const q1 = ring2[k];\n const q2 = ring2[j];\n if (segmentIntersectSegment(p1, p2, q1, q2)) {\n return 0.0;\n }\n dist = Math.min(dist, segmentToSegmentDistance(p1, p2, q1, q2, ruler));\n }\n }\n }\n }\n return dist;\n}\nfunction updateQueue(distQueue, miniDist, ruler, points, polyBBox, rangeA) {\n if (!rangeA) {\n return;\n }\n const tempDist = bboxToBBoxDistance(getBBox(points, rangeA), polyBBox, ruler);\n // Insert new pair to the queue if the bbox distance is less than\n // miniDist, The pair with biggest distance will be at the top\n if (tempDist < miniDist) {\n distQueue.push([tempDist, rangeA, [0, 0]]);\n }\n}\nfunction updateQueueTwoSets(distQueue, miniDist, ruler, pointSet1, pointSet2, range1, range2) {\n if (!range1 || !range2) {\n return;\n }\n const tempDist = bboxToBBoxDistance(getBBox(pointSet1, range1), getBBox(pointSet2, range2), ruler);\n // Insert new pair to the queue if the bbox distance is less than\n // miniDist, The pair with biggest distance will be at the top\n if (tempDist < miniDist) {\n distQueue.push([tempDist, range1, range2]);\n }\n}\n// Divide and conquer, the time complexity is O(n*lgn), faster than Brute force\n// O(n*n) Most of the time, use index for in-place processing.\nfunction pointsToPolygonDistance(points, isLine, polygon, ruler, currentMiniDist = Infinity) {\n let miniDist = Math.min(ruler.distance(points[0], polygon[0][0]), currentMiniDist);\n if (miniDist === 0.0) {\n return miniDist;\n }\n const distQueue = new TinyQueue([[0, [0, points.length - 1], [0, 0]]], compareDistPair);\n const polyBBox = getPolygonBBox(polygon);\n while (distQueue.length > 0) {\n const distPair = distQueue.pop();\n if (distPair[0] >= miniDist) {\n continue;\n }\n const range = distPair[1];\n // In case the set size are relatively small, we could use brute-force directly\n const threshold = isLine ? MinLinePointsSize : MinPointsSize;\n if (getRangeSize(range) <= threshold) {\n if (!isRangeSafe(range, points.length)) {\n return NaN;\n }\n if (isLine) {\n const tempDist = lineToPolygonDistance(points, range, polygon, ruler);\n if (isNaN(tempDist) || tempDist === 0.0) {\n return tempDist;\n }\n miniDist = Math.min(miniDist, tempDist);\n }\n else {\n for (let i = range[0]; i <= range[1]; ++i) {\n const tempDist = pointToPolygonDistance(points[i], polygon, ruler);\n miniDist = Math.min(miniDist, tempDist);\n if (miniDist === 0.0) {\n return 0.0;\n }\n }\n }\n }\n else {\n const newRangesA = splitRange(range, isLine);\n updateQueue(distQueue, miniDist, ruler, points, polyBBox, newRangesA[0]);\n updateQueue(distQueue, miniDist, ruler, points, polyBBox, newRangesA[1]);\n }\n }\n return miniDist;\n}\nfunction pointSetToPointSetDistance(pointSet1, isLine1, pointSet2, isLine2, ruler, currentMiniDist = Infinity) {\n let miniDist = Math.min(currentMiniDist, ruler.distance(pointSet1[0], pointSet2[0]));\n if (miniDist === 0.0) {\n return miniDist;\n }\n const distQueue = new TinyQueue([[0, [0, pointSet1.length - 1], [0, pointSet2.length - 1]]], compareDistPair);\n while (distQueue.length > 0) {\n const distPair = distQueue.pop();\n if (distPair[0] >= miniDist) {\n continue;\n }\n const rangeA = distPair[1];\n const rangeB = distPair[2];\n const threshold1 = isLine1 ? MinLinePointsSize : MinPointsSize;\n const threshold2 = isLine2 ? MinLinePointsSize : MinPointsSize;\n // In case the set size are relatively small, we could use brute-force directly\n if (getRangeSize(rangeA) <= threshold1 && getRangeSize(rangeB) <= threshold2) {\n if (!isRangeSafe(rangeA, pointSet1.length) && isRangeSafe(rangeB, pointSet2.length)) {\n return NaN;\n }\n let tempDist;\n if (isLine1 && isLine2) {\n tempDist = lineToLineDistance(pointSet1, rangeA, pointSet2, rangeB, ruler);\n miniDist = Math.min(miniDist, tempDist);\n }\n else if (isLine1 && !isLine2) {\n const sublibe = pointSet1.slice(rangeA[0], rangeA[1] + 1);\n for (let i = rangeB[0]; i <= rangeB[1]; ++i) {\n tempDist = pointToLineDistance(pointSet2[i], sublibe, ruler);\n miniDist = Math.min(miniDist, tempDist);\n if (miniDist === 0.0) {\n return miniDist;\n }\n }\n }\n else if (!isLine1 && isLine2) {\n const sublibe = pointSet2.slice(rangeB[0], rangeB[1] + 1);\n for (let i = rangeA[0]; i <= rangeA[1]; ++i) {\n tempDist = pointToLineDistance(pointSet1[i], sublibe, ruler);\n miniDist = Math.min(miniDist, tempDist);\n if (miniDist === 0.0) {\n return miniDist;\n }\n }\n }\n else {\n tempDist = pointsToPointsDistance(pointSet1, rangeA, pointSet2, rangeB, ruler);\n miniDist = Math.min(miniDist, tempDist);\n }\n }\n else {\n const newRangesA = splitRange(rangeA, isLine1);\n const newRangesB = splitRange(rangeB, isLine2);\n updateQueueTwoSets(distQueue, miniDist, ruler, pointSet1, pointSet2, newRangesA[0], newRangesB[0]);\n updateQueueTwoSets(distQueue, miniDist, ruler, pointSet1, pointSet2, newRangesA[0], newRangesB[1]);\n updateQueueTwoSets(distQueue, miniDist, ruler, pointSet1, pointSet2, newRangesA[1], newRangesB[0]);\n updateQueueTwoSets(distQueue, miniDist, ruler, pointSet1, pointSet2, newRangesA[1], newRangesB[1]);\n }\n }\n return miniDist;\n}\nfunction pointToGeometryDistance(ctx, geometries) {\n const tilePoints = ctx.geometry();\n const pointPosition = tilePoints.flat().map(p => getLngLatFromTileCoord([p.x, p.y], ctx.canonical));\n if (tilePoints.length === 0) {\n return NaN;\n }\n const ruler = new CheapRuler(pointPosition[0][1]);\n let dist = Infinity;\n for (const geometry of geometries) {\n switch (geometry.type) {\n case 'Point':\n dist = Math.min(dist, pointSetToPointSetDistance(pointPosition, false, [geometry.coordinates], false, ruler, dist));\n break;\n case 'LineString':\n dist = Math.min(dist, pointSetToPointSetDistance(pointPosition, false, geometry.coordinates, true, ruler, dist));\n break;\n case 'Polygon':\n dist = Math.min(dist, pointsToPolygonDistance(pointPosition, false, geometry.coordinates, ruler, dist));\n break;\n }\n if (dist === 0.0) {\n return dist;\n }\n }\n return dist;\n}\nfunction lineStringToGeometryDistance(ctx, geometries) {\n const tileLine = ctx.geometry();\n const linePositions = tileLine.flat().map(p => getLngLatFromTileCoord([p.x, p.y], ctx.canonical));\n if (tileLine.length === 0) {\n return NaN;\n }\n const ruler = new CheapRuler(linePositions[0][1]);\n let dist = Infinity;\n for (const geometry of geometries) {\n switch (geometry.type) {\n case 'Point':\n dist = Math.min(dist, pointSetToPointSetDistance(linePositions, true, [geometry.coordinates], false, ruler, dist));\n break;\n case 'LineString':\n dist = Math.min(dist, pointSetToPointSetDistance(linePositions, true, geometry.coordinates, true, ruler, dist));\n break;\n case 'Polygon':\n dist = Math.min(dist, pointsToPolygonDistance(linePositions, true, geometry.coordinates, ruler, dist));\n break;\n }\n if (dist === 0.0) {\n return dist;\n }\n }\n return dist;\n}\nfunction polygonToGeometryDistance(ctx, geometries) {\n const tilePolygon = ctx.geometry();\n if (tilePolygon.length === 0 || tilePolygon[0].length === 0) {\n return NaN;\n }\n const polygons = classifyRings(tilePolygon, 0).map(polygon => {\n return polygon.map(ring => {\n return ring.map(p => getLngLatFromTileCoord([p.x, p.y], ctx.canonical));\n });\n });\n const ruler = new CheapRuler(polygons[0][0][0][1]);\n let dist = Infinity;\n for (const geometry of geometries) {\n for (const polygon of polygons) {\n switch (geometry.type) {\n case 'Point':\n dist = Math.min(dist, pointsToPolygonDistance([geometry.coordinates], false, polygon, ruler, dist));\n break;\n case 'LineString':\n dist = Math.min(dist, pointsToPolygonDistance(geometry.coordinates, true, polygon, ruler, dist));\n break;\n case 'Polygon':\n dist = Math.min(dist, polygonToPolygonDistance(polygon, geometry.coordinates, ruler, dist));\n break;\n }\n if (dist === 0.0) {\n return dist;\n }\n }\n }\n return dist;\n}\nfunction toSimpleGeometry(geometry) {\n if (geometry.type === 'MultiPolygon') {\n return geometry.coordinates.map(polygon => {\n return {\n type: 'Polygon',\n coordinates: polygon\n };\n });\n }\n if (geometry.type === 'MultiLineString') {\n return geometry.coordinates.map(lineString => {\n return {\n type: 'LineString',\n coordinates: lineString\n };\n });\n }\n if (geometry.type === 'MultiPoint') {\n return geometry.coordinates.map(point => {\n return {\n type: 'Point',\n coordinates: point\n };\n });\n }\n return [geometry];\n}\nclass Distance {\n constructor(geojson, geometries) {\n this.type = NumberType;\n this.geojson = geojson;\n this.geometries = geometries;\n }\n static parse(args, context) {\n if (args.length !== 2)\n return context.error(`'distance' expression requires exactly one argument, but found ${args.length - 1} instead.`);\n if (isValue(args[1])) {\n const geojson = args[1];\n if (geojson.type === 'FeatureCollection') {\n return new Distance(geojson, geojson.features.map(feature => toSimpleGeometry(feature.geometry)).flat());\n }\n else if (geojson.type === 'Feature') {\n return new Distance(geojson, toSimpleGeometry(geojson.geometry));\n }\n else if ('type' in geojson && 'coordinates' in geojson) {\n return new Distance(geojson, toSimpleGeometry(geojson));\n }\n }\n return context.error('\\'distance\\' expression requires valid geojson object that contains polygon geometry type.');\n }\n evaluate(ctx) {\n if (ctx.geometry() != null && ctx.canonicalID() != null) {\n if (ctx.geometryType() === 'Point') {\n return pointToGeometryDistance(ctx, this.geometries);\n }\n else if (ctx.geometryType() === 'LineString') {\n return lineStringToGeometryDistance(ctx, this.geometries);\n }\n else if (ctx.geometryType() === 'Polygon') {\n return polygonToGeometryDistance(ctx, this.geometries);\n }\n }\n return NaN;\n }\n eachChild() { }\n outputDefined() {\n return true;\n }\n}\n\nconst expressions$1 = {\n // special forms\n '==': Equals,\n '!=': NotEquals,\n '>': GreaterThan,\n '<': LessThan,\n '>=': GreaterThanOrEqual,\n '<=': LessThanOrEqual,\n 'array': Assertion,\n 'at': At,\n 'boolean': Assertion,\n 'case': Case,\n 'coalesce': Coalesce,\n 'collator': CollatorExpression,\n 'format': FormatExpression,\n 'image': ImageExpression,\n 'in': In,\n 'index-of': IndexOf,\n 'interpolate': Interpolate,\n 'interpolate-hcl': Interpolate,\n 'interpolate-lab': Interpolate,\n 'length': Length,\n 'let': Let,\n 'literal': Literal,\n 'match': Match,\n 'number': Assertion,\n 'number-format': NumberFormat,\n 'object': Assertion,\n 'slice': Slice,\n 'step': Step,\n 'string': Assertion,\n 'to-boolean': Coercion,\n 'to-color': Coercion,\n 'to-number': Coercion,\n 'to-string': Coercion,\n 'var': Var,\n 'within': Within,\n 'distance': Distance\n};\n\nclass CompoundExpression {\n constructor(name, type, evaluate, args) {\n this.name = name;\n this.type = type;\n this._evaluate = evaluate;\n this.args = args;\n }\n evaluate(ctx) {\n return this._evaluate(ctx, this.args);\n }\n eachChild(fn) {\n this.args.forEach(fn);\n }\n outputDefined() {\n return false;\n }\n static parse(args, context) {\n const op = args[0];\n const definition = CompoundExpression.definitions[op];\n if (!definition) {\n return context.error(`Unknown expression \"${op}\". If you wanted a literal array, use [\"literal\", [...]].`, 0);\n }\n // Now check argument types against each signature\n const type = Array.isArray(definition) ?\n definition[0] : definition.type;\n const availableOverloads = Array.isArray(definition) ?\n [[definition[1], definition[2]]] :\n definition.overloads;\n const overloads = availableOverloads.filter(([signature]) => (!Array.isArray(signature) || // varags\n signature.length === args.length - 1 // correct param count\n ));\n let signatureContext = null;\n for (const [params, evaluate] of overloads) {\n // Use a fresh context for each attempted signature so that, if\n // we eventually succeed, we haven't polluted `context.errors`.\n signatureContext = new ParsingContext(context.registry, isExpressionConstant, context.path, null, context.scope);\n // First parse all the args, potentially coercing to the\n // types expected by this overload.\n const parsedArgs = [];\n let argParseFailed = false;\n for (let i = 1; i < args.length; i++) {\n const arg = args[i];\n const expectedType = Array.isArray(params) ?\n params[i - 1] :\n params.type;\n const parsed = signatureContext.parse(arg, 1 + parsedArgs.length, expectedType);\n if (!parsed) {\n argParseFailed = true;\n break;\n }\n parsedArgs.push(parsed);\n }\n if (argParseFailed) {\n // Couldn't coerce args of this overload to expected type, move\n // on to next one.\n continue;\n }\n if (Array.isArray(params)) {\n if (params.length !== parsedArgs.length) {\n signatureContext.error(`Expected ${params.length} arguments, but found ${parsedArgs.length} instead.`);\n continue;\n }\n }\n for (let i = 0; i < parsedArgs.length; i++) {\n const expected = Array.isArray(params) ? params[i] : params.type;\n const arg = parsedArgs[i];\n signatureContext.concat(i + 1).checkSubtype(expected, arg.type);\n }\n if (signatureContext.errors.length === 0) {\n return new CompoundExpression(op, type, evaluate, parsedArgs);\n }\n }\n if (overloads.length === 1) {\n context.errors.push(...signatureContext.errors);\n }\n else {\n const expected = overloads.length ? overloads : availableOverloads;\n const signatures = expected\n .map(([params]) => stringifySignature(params))\n .join(' | ');\n const actualTypes = [];\n // For error message, re-parse arguments without trying to\n // apply any coercions\n for (let i = 1; i < args.length; i++) {\n const parsed = context.parse(args[i], 1 + actualTypes.length);\n if (!parsed)\n return null;\n actualTypes.push(toString$1(parsed.type));\n }\n context.error(`Expected arguments of type ${signatures}, but found (${actualTypes.join(', ')}) instead.`);\n }\n return null;\n }\n static register(registry, definitions) {\n CompoundExpression.definitions = definitions;\n for (const name in definitions) {\n registry[name] = CompoundExpression;\n }\n }\n}\nfunction rgba(ctx, [r, g, b, a]) {\n r = r.evaluate(ctx);\n g = g.evaluate(ctx);\n b = b.evaluate(ctx);\n const alpha = a ? a.evaluate(ctx) : 1;\n const error = validateRGBA(r, g, b, alpha);\n if (error)\n throw new RuntimeError(error);\n return new Color(r / 255, g / 255, b / 255, alpha, false);\n}\nfunction has(key, obj) {\n return key in obj;\n}\nfunction get(key, obj) {\n const v = obj[key];\n return typeof v === 'undefined' ? null : v;\n}\nfunction binarySearch(v, a, i, j) {\n while (i <= j) {\n const m = (i + j) >> 1;\n if (a[m] === v)\n return true;\n if (a[m] > v)\n j = m - 1;\n else\n i = m + 1;\n }\n return false;\n}\nfunction varargs(type) {\n return { type };\n}\nCompoundExpression.register(expressions$1, {\n 'error': [\n ErrorType,\n [StringType],\n (ctx, [v]) => { throw new RuntimeError(v.evaluate(ctx)); }\n ],\n 'typeof': [\n StringType,\n [ValueType],\n (ctx, [v]) => toString$1(typeOf(v.evaluate(ctx)))\n ],\n 'to-rgba': [\n array$1(NumberType, 4),\n [ColorType],\n (ctx, [v]) => {\n const [r, g, b, a] = v.evaluate(ctx).rgb;\n return [r * 255, g * 255, b * 255, a];\n },\n ],\n 'rgb': [\n ColorType,\n [NumberType, NumberType, NumberType],\n rgba\n ],\n 'rgba': [\n ColorType,\n [NumberType, NumberType, NumberType, NumberType],\n rgba\n ],\n 'has': {\n type: BooleanType,\n overloads: [\n [\n [StringType],\n (ctx, [key]) => has(key.evaluate(ctx), ctx.properties())\n ], [\n [StringType, ObjectType],\n (ctx, [key, obj]) => has(key.evaluate(ctx), obj.evaluate(ctx))\n ]\n ]\n },\n 'get': {\n type: ValueType,\n overloads: [\n [\n [StringType],\n (ctx, [key]) => get(key.evaluate(ctx), ctx.properties())\n ], [\n [StringType, ObjectType],\n (ctx, [key, obj]) => get(key.evaluate(ctx), obj.evaluate(ctx))\n ]\n ]\n },\n 'feature-state': [\n ValueType,\n [StringType],\n (ctx, [key]) => get(key.evaluate(ctx), ctx.featureState || {})\n ],\n 'properties': [\n ObjectType,\n [],\n (ctx) => ctx.properties()\n ],\n 'geometry-type': [\n StringType,\n [],\n (ctx) => ctx.geometryType()\n ],\n 'id': [\n ValueType,\n [],\n (ctx) => ctx.id()\n ],\n 'zoom': [\n NumberType,\n [],\n (ctx) => ctx.globals.zoom\n ],\n 'heatmap-density': [\n NumberType,\n [],\n (ctx) => ctx.globals.heatmapDensity || 0\n ],\n 'line-progress': [\n NumberType,\n [],\n (ctx) => ctx.globals.lineProgress || 0\n ],\n 'accumulated': [\n ValueType,\n [],\n (ctx) => ctx.globals.accumulated === undefined ? null : ctx.globals.accumulated\n ],\n '+': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => {\n let result = 0;\n for (const arg of args) {\n result += arg.evaluate(ctx);\n }\n return result;\n }\n ],\n '*': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => {\n let result = 1;\n for (const arg of args) {\n result *= arg.evaluate(ctx);\n }\n return result;\n }\n ],\n '-': {\n type: NumberType,\n overloads: [\n [\n [NumberType, NumberType],\n (ctx, [a, b]) => a.evaluate(ctx) - b.evaluate(ctx)\n ], [\n [NumberType],\n (ctx, [a]) => -a.evaluate(ctx)\n ]\n ]\n },\n '/': [\n NumberType,\n [NumberType, NumberType],\n (ctx, [a, b]) => a.evaluate(ctx) / b.evaluate(ctx)\n ],\n '%': [\n NumberType,\n [NumberType, NumberType],\n (ctx, [a, b]) => a.evaluate(ctx) % b.evaluate(ctx)\n ],\n 'ln2': [\n NumberType,\n [],\n () => Math.LN2\n ],\n 'pi': [\n NumberType,\n [],\n () => Math.PI\n ],\n 'e': [\n NumberType,\n [],\n () => Math.E\n ],\n '^': [\n NumberType,\n [NumberType, NumberType],\n (ctx, [b, e]) => Math.pow(b.evaluate(ctx), e.evaluate(ctx))\n ],\n 'sqrt': [\n NumberType,\n [NumberType],\n (ctx, [x]) => Math.sqrt(x.evaluate(ctx))\n ],\n 'log10': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.log(n.evaluate(ctx)) / Math.LN10\n ],\n 'ln': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.log(n.evaluate(ctx))\n ],\n 'log2': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.log(n.evaluate(ctx)) / Math.LN2\n ],\n 'sin': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.sin(n.evaluate(ctx))\n ],\n 'cos': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.cos(n.evaluate(ctx))\n ],\n 'tan': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.tan(n.evaluate(ctx))\n ],\n 'asin': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.asin(n.evaluate(ctx))\n ],\n 'acos': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.acos(n.evaluate(ctx))\n ],\n 'atan': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.atan(n.evaluate(ctx))\n ],\n 'min': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => Math.min(...args.map(arg => arg.evaluate(ctx)))\n ],\n 'max': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => Math.max(...args.map(arg => arg.evaluate(ctx)))\n ],\n 'abs': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.abs(n.evaluate(ctx))\n ],\n 'round': [\n NumberType,\n [NumberType],\n (ctx, [n]) => {\n const v = n.evaluate(ctx);\n // Javascript's Math.round() rounds towards +Infinity for halfway\n // values, even when they're negative. It's more common to round\n // away from 0 (e.g., this is what python and C++ do)\n return v < 0 ? -Math.round(-v) : Math.round(v);\n }\n ],\n 'floor': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.floor(n.evaluate(ctx))\n ],\n 'ceil': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.ceil(n.evaluate(ctx))\n ],\n 'filter-==': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => ctx.properties()[k.value] === v.value\n ],\n 'filter-id-==': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => ctx.id() === v.value\n ],\n 'filter-type-==': [\n BooleanType,\n [StringType],\n (ctx, [v]) => ctx.geometryType() === v.value\n ],\n 'filter-<': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[k.value];\n const b = v.value;\n return typeof a === typeof b && a < b;\n }\n ],\n 'filter-id-<': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = v.value;\n return typeof a === typeof b && a < b;\n }\n ],\n 'filter->': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[k.value];\n const b = v.value;\n return typeof a === typeof b && a > b;\n }\n ],\n 'filter-id->': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = v.value;\n return typeof a === typeof b && a > b;\n }\n ],\n 'filter-<=': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[k.value];\n const b = v.value;\n return typeof a === typeof b && a <= b;\n }\n ],\n 'filter-id-<=': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = v.value;\n return typeof a === typeof b && a <= b;\n }\n ],\n 'filter->=': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[k.value];\n const b = v.value;\n return typeof a === typeof b && a >= b;\n }\n ],\n 'filter-id->=': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = v.value;\n return typeof a === typeof b && a >= b;\n }\n ],\n 'filter-has': [\n BooleanType,\n [ValueType],\n (ctx, [k]) => k.value in ctx.properties()\n ],\n 'filter-has-id': [\n BooleanType,\n [],\n (ctx) => (ctx.id() !== null && ctx.id() !== undefined)\n ],\n 'filter-type-in': [\n BooleanType,\n [array$1(StringType)],\n (ctx, [v]) => v.value.indexOf(ctx.geometryType()) >= 0\n ],\n 'filter-id-in': [\n BooleanType,\n [array$1(ValueType)],\n (ctx, [v]) => v.value.indexOf(ctx.id()) >= 0\n ],\n 'filter-in-small': [\n BooleanType,\n [StringType, array$1(ValueType)],\n // assumes v is an array literal\n (ctx, [k, v]) => v.value.indexOf(ctx.properties()[k.value]) >= 0\n ],\n 'filter-in-large': [\n BooleanType,\n [StringType, array$1(ValueType)],\n // assumes v is a array literal with values sorted in ascending order and of a single type\n (ctx, [k, v]) => binarySearch(ctx.properties()[k.value], v.value, 0, v.value.length - 1)\n ],\n 'all': {\n type: BooleanType,\n overloads: [\n [\n [BooleanType, BooleanType],\n (ctx, [a, b]) => a.evaluate(ctx) && b.evaluate(ctx)\n ],\n [\n varargs(BooleanType),\n (ctx, args) => {\n for (const arg of args) {\n if (!arg.evaluate(ctx))\n return false;\n }\n return true;\n }\n ]\n ]\n },\n 'any': {\n type: BooleanType,\n overloads: [\n [\n [BooleanType, BooleanType],\n (ctx, [a, b]) => a.evaluate(ctx) || b.evaluate(ctx)\n ],\n [\n varargs(BooleanType),\n (ctx, args) => {\n for (const arg of args) {\n if (arg.evaluate(ctx))\n return true;\n }\n return false;\n }\n ]\n ]\n },\n '!': [\n BooleanType,\n [BooleanType],\n (ctx, [b]) => !b.evaluate(ctx)\n ],\n 'is-supported-script': [\n BooleanType,\n [StringType],\n // At parse time this will always return true, so we need to exclude this expression with isGlobalPropertyConstant\n (ctx, [s]) => {\n const isSupportedScript = ctx.globals && ctx.globals.isSupportedScript;\n if (isSupportedScript) {\n return isSupportedScript(s.evaluate(ctx));\n }\n return true;\n }\n ],\n 'upcase': [\n StringType,\n [StringType],\n (ctx, [s]) => s.evaluate(ctx).toUpperCase()\n ],\n 'downcase': [\n StringType,\n [StringType],\n (ctx, [s]) => s.evaluate(ctx).toLowerCase()\n ],\n 'concat': [\n StringType,\n varargs(ValueType),\n (ctx, args) => args.map(arg => toString(arg.evaluate(ctx))).join('')\n ],\n 'resolved-locale': [\n StringType,\n [CollatorType],\n (ctx, [collator]) => collator.evaluate(ctx).resolvedLocale()\n ]\n});\nfunction stringifySignature(signature) {\n if (Array.isArray(signature)) {\n return `(${signature.map(toString$1).join(', ')})`;\n }\n else {\n return `(${toString$1(signature.type)}...)`;\n }\n}\nfunction isExpressionConstant(expression) {\n if (expression instanceof Var) {\n return isExpressionConstant(expression.boundExpression);\n }\n else if (expression instanceof CompoundExpression && expression.name === 'error') {\n return false;\n }\n else if (expression instanceof CollatorExpression) {\n // Although the results of a Collator expression with fixed arguments\n // generally shouldn't change between executions, we can't serialize them\n // as constant expressions because results change based on environment.\n return false;\n }\n else if (expression instanceof Within) {\n return false;\n }\n else if (expression instanceof Distance) {\n return false;\n }\n const isTypeAnnotation = expression instanceof Coercion ||\n expression instanceof Assertion;\n let childrenConstant = true;\n expression.eachChild(child => {\n // We can _almost_ assume that if `expressions` children are constant,\n // they would already have been evaluated to Literal values when they\n // were parsed. Type annotations are the exception, because they might\n // have been inferred and added after a child was parsed.\n // So we recurse into isConstant() for the children of type annotations,\n // but otherwise simply check whether they are Literals.\n if (isTypeAnnotation) {\n childrenConstant = childrenConstant && isExpressionConstant(child);\n }\n else {\n childrenConstant = childrenConstant && child instanceof Literal;\n }\n });\n if (!childrenConstant) {\n return false;\n }\n return isFeatureConstant(expression) &&\n isGlobalPropertyConstant(expression, ['zoom', 'heatmap-density', 'line-progress', 'accumulated', 'is-supported-script']);\n}\nfunction isFeatureConstant(e) {\n if (e instanceof CompoundExpression) {\n if (e.name === 'get' && e.args.length === 1) {\n return false;\n }\n else if (e.name === 'feature-state') {\n return false;\n }\n else if (e.name === 'has' && e.args.length === 1) {\n return false;\n }\n else if (e.name === 'properties' ||\n e.name === 'geometry-type' ||\n e.name === 'id') {\n return false;\n }\n else if (/^filter-/.test(e.name)) {\n return false;\n }\n }\n if (e instanceof Within) {\n return false;\n }\n if (e instanceof Distance) {\n return false;\n }\n let result = true;\n e.eachChild(arg => {\n if (result && !isFeatureConstant(arg)) {\n result = false;\n }\n });\n return result;\n}\nfunction isStateConstant(e) {\n if (e instanceof CompoundExpression) {\n if (e.name === 'feature-state') {\n return false;\n }\n }\n let result = true;\n e.eachChild(arg => {\n if (result && !isStateConstant(arg)) {\n result = false;\n }\n });\n return result;\n}\nfunction isGlobalPropertyConstant(e, properties) {\n if (e instanceof CompoundExpression && properties.indexOf(e.name) >= 0) {\n return false;\n }\n let result = true;\n e.eachChild((arg) => {\n if (result && !isGlobalPropertyConstant(arg, properties)) {\n result = false;\n }\n });\n return result;\n}\n\nfunction success(value) {\n return { result: 'success', value };\n}\nfunction error(value) {\n return { result: 'error', value };\n}\n\nfunction supportsPropertyExpression(spec) {\n return spec['property-type'] === 'data-driven' || spec['property-type'] === 'cross-faded-data-driven';\n}\nfunction supportsZoomExpression(spec) {\n return !!spec.expression && spec.expression.parameters.indexOf('zoom') > -1;\n}\nfunction supportsInterpolation(spec) {\n return !!spec.expression && spec.expression.interpolated;\n}\n\nfunction getType(val) {\n if (val instanceof Number) {\n return 'number';\n }\n else if (val instanceof String) {\n return 'string';\n }\n else if (val instanceof Boolean) {\n return 'boolean';\n }\n else if (Array.isArray(val)) {\n return 'array';\n }\n else if (val === null) {\n return 'null';\n }\n else {\n return typeof val;\n }\n}\n\nfunction isFunction$1(value) {\n return typeof value === 'object' && value !== null && !Array.isArray(value);\n}\nfunction identityFunction(x) {\n return x;\n}\nfunction createFunction(parameters, propertySpec) {\n const isColor = propertySpec.type === 'color';\n const zoomAndFeatureDependent = parameters.stops && typeof parameters.stops[0][0] === 'object';\n const featureDependent = zoomAndFeatureDependent || parameters.property !== undefined;\n const zoomDependent = zoomAndFeatureDependent || !featureDependent;\n const type = parameters.type || (supportsInterpolation(propertySpec) ? 'exponential' : 'interval');\n if (isColor || propertySpec.type === 'padding') {\n const parseFn = isColor ? Color.parse : Padding.parse;\n parameters = extendBy({}, parameters);\n if (parameters.stops) {\n parameters.stops = parameters.stops.map((stop) => {\n return [stop[0], parseFn(stop[1])];\n });\n }\n if (parameters.default) {\n parameters.default = parseFn(parameters.default);\n }\n else {\n parameters.default = parseFn(propertySpec.default);\n }\n }\n if (parameters.colorSpace && !isSupportedInterpolationColorSpace(parameters.colorSpace)) {\n throw new Error(`Unknown color space: \"${parameters.colorSpace}\"`);\n }\n let innerFun;\n let hashedStops;\n let categoricalKeyType;\n if (type === 'exponential') {\n innerFun = evaluateExponentialFunction;\n }\n else if (type === 'interval') {\n innerFun = evaluateIntervalFunction;\n }\n else if (type === 'categorical') {\n innerFun = evaluateCategoricalFunction;\n // For categorical functions, generate an Object as a hashmap of the stops for fast searching\n hashedStops = Object.create(null);\n for (const stop of parameters.stops) {\n hashedStops[stop[0]] = stop[1];\n }\n // Infer key type based on first stop key-- used to encforce strict type checking later\n categoricalKeyType = typeof parameters.stops[0][0];\n }\n else if (type === 'identity') {\n innerFun = evaluateIdentityFunction;\n }\n else {\n throw new Error(`Unknown function type \"${type}\"`);\n }\n if (zoomAndFeatureDependent) {\n const featureFunctions = {};\n const zoomStops = [];\n for (let s = 0; s < parameters.stops.length; s++) {\n const stop = parameters.stops[s];\n const zoom = stop[0].zoom;\n if (featureFunctions[zoom] === undefined) {\n featureFunctions[zoom] = {\n zoom,\n type: parameters.type,\n property: parameters.property,\n default: parameters.default,\n stops: []\n };\n zoomStops.push(zoom);\n }\n featureFunctions[zoom].stops.push([stop[0].value, stop[1]]);\n }\n const featureFunctionStops = [];\n for (const z of zoomStops) {\n featureFunctionStops.push([featureFunctions[z].zoom, createFunction(featureFunctions[z], propertySpec)]);\n }\n const interpolationType = { name: 'linear' };\n return {\n kind: 'composite',\n interpolationType,\n interpolationFactor: Interpolate.interpolationFactor.bind(undefined, interpolationType),\n zoomStops: featureFunctionStops.map(s => s[0]),\n evaluate({ zoom }, properties) {\n return evaluateExponentialFunction({\n stops: featureFunctionStops,\n base: parameters.base\n }, propertySpec, zoom).evaluate(zoom, properties);\n }\n };\n }\n else if (zoomDependent) {\n const interpolationType = type === 'exponential' ?\n { name: 'exponential', base: parameters.base !== undefined ? parameters.base : 1 } : null;\n return {\n kind: 'camera',\n interpolationType,\n interpolationFactor: Interpolate.interpolationFactor.bind(undefined, interpolationType),\n zoomStops: parameters.stops.map(s => s[0]),\n evaluate: ({ zoom }) => innerFun(parameters, propertySpec, zoom, hashedStops, categoricalKeyType)\n };\n }\n else {\n return {\n kind: 'source',\n evaluate(_, feature) {\n const value = feature && feature.properties ? feature.properties[parameters.property] : undefined;\n if (value === undefined) {\n return coalesce$1(parameters.default, propertySpec.default);\n }\n return innerFun(parameters, propertySpec, value, hashedStops, categoricalKeyType);\n }\n };\n }\n}\nfunction coalesce$1(a, b, c) {\n if (a !== undefined)\n return a;\n if (b !== undefined)\n return b;\n if (c !== undefined)\n return c;\n}\nfunction evaluateCategoricalFunction(parameters, propertySpec, input, hashedStops, keyType) {\n const evaluated = typeof input === keyType ? hashedStops[input] : undefined; // Enforce strict typing on input\n return coalesce$1(evaluated, parameters.default, propertySpec.default);\n}\nfunction evaluateIntervalFunction(parameters, propertySpec, input) {\n // Edge cases\n if (getType(input) !== 'number')\n return coalesce$1(parameters.default, propertySpec.default);\n const n = parameters.stops.length;\n if (n === 1)\n return parameters.stops[0][1];\n if (input <= parameters.stops[0][0])\n return parameters.stops[0][1];\n if (input >= parameters.stops[n - 1][0])\n return parameters.stops[n - 1][1];\n const index = findStopLessThanOrEqualTo(parameters.stops.map((stop) => stop[0]), input);\n return parameters.stops[index][1];\n}\nfunction evaluateExponentialFunction(parameters, propertySpec, input) {\n const base = parameters.base !== undefined ? parameters.base : 1;\n // Edge cases\n if (getType(input) !== 'number')\n return coalesce$1(parameters.default, propertySpec.default);\n const n = parameters.stops.length;\n if (n === 1)\n return parameters.stops[0][1];\n if (input <= parameters.stops[0][0])\n return parameters.stops[0][1];\n if (input >= parameters.stops[n - 1][0])\n return parameters.stops[n - 1][1];\n const index = findStopLessThanOrEqualTo(parameters.stops.map((stop) => stop[0]), input);\n const t = interpolationFactor(input, base, parameters.stops[index][0], parameters.stops[index + 1][0]);\n const outputLower = parameters.stops[index][1];\n const outputUpper = parameters.stops[index + 1][1];\n const interp = interpolate[propertySpec.type] || identityFunction;\n if (typeof outputLower.evaluate === 'function') {\n return {\n evaluate(...args) {\n const evaluatedLower = outputLower.evaluate.apply(undefined, args);\n const evaluatedUpper = outputUpper.evaluate.apply(undefined, args);\n // Special case for fill-outline-color, which has no spec default.\n if (evaluatedLower === undefined || evaluatedUpper === undefined) {\n return undefined;\n }\n return interp(evaluatedLower, evaluatedUpper, t, parameters.colorSpace);\n }\n };\n }\n return interp(outputLower, outputUpper, t, parameters.colorSpace);\n}\nfunction evaluateIdentityFunction(parameters, propertySpec, input) {\n switch (propertySpec.type) {\n case 'color':\n input = Color.parse(input);\n break;\n case 'formatted':\n input = Formatted.fromString(input.toString());\n break;\n case 'resolvedImage':\n input = ResolvedImage.fromString(input.toString());\n break;\n case 'padding':\n input = Padding.parse(input);\n break;\n default:\n if (getType(input) !== propertySpec.type && (propertySpec.type !== 'enum' || !propertySpec.values[input])) {\n input = undefined;\n }\n }\n return coalesce$1(input, parameters.default, propertySpec.default);\n}\n/**\n * Returns a ratio that can be used to interpolate between exponential function\n * stops.\n *\n * How it works:\n * Two consecutive stop values define a (scaled and shifted) exponential\n * function `f(x) = a * base^x + b`, where `base` is the user-specified base,\n * and `a` and `b` are constants affording sufficient degrees of freedom to fit\n * the function to the given stops.\n *\n * Here's a bit of algebra that lets us compute `f(x)` directly from the stop\n * values without explicitly solving for `a` and `b`:\n *\n * First stop value: `f(x0) = y0 = a * base^x0 + b`\n * Second stop value: `f(x1) = y1 = a * base^x1 + b`\n * => `y1 - y0 = a(base^x1 - base^x0)`\n * => `a = (y1 - y0)/(base^x1 - base^x0)`\n *\n * Desired value: `f(x) = y = a * base^x + b`\n * => `f(x) = y0 + a * (base^x - base^x0)`\n *\n * From the above, we can replace the `a` in `a * (base^x - base^x0)` and do a\n * little algebra:\n * ```\n * a * (base^x - base^x0) = (y1 - y0)/(base^x1 - base^x0) * (base^x - base^x0)\n * = (y1 - y0) * (base^x - base^x0) / (base^x1 - base^x0)\n * ```\n *\n * If we let `(base^x - base^x0) / (base^x1 base^x0)`, then we have\n * `f(x) = y0 + (y1 - y0) * ratio`. In other words, `ratio` may be treated as\n * an interpolation factor between the two stops' output values.\n *\n * (Note: a slightly different form for `ratio`,\n * `(base^(x-x0) - 1) / (base^(x1-x0) - 1) `, is equivalent, but requires fewer\n * expensive `Math.pow()` operations.)\n *\n * @private\n */\nfunction interpolationFactor(input, base, lowerValue, upperValue) {\n const difference = upperValue - lowerValue;\n const progress = input - lowerValue;\n if (difference === 0) {\n return 0;\n }\n else if (base === 1) {\n return progress / difference;\n }\n else {\n return (Math.pow(base, progress) - 1) / (Math.pow(base, difference) - 1);\n }\n}\n\nclass StyleExpression {\n constructor(expression, propertySpec) {\n this.expression = expression;\n this._warningHistory = {};\n this._evaluator = new EvaluationContext();\n this._defaultValue = propertySpec ? getDefaultValue(propertySpec) : null;\n this._enumValues = propertySpec && propertySpec.type === 'enum' ? propertySpec.values : null;\n }\n evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection) {\n this._evaluator.globals = globals;\n this._evaluator.feature = feature;\n this._evaluator.featureState = featureState;\n this._evaluator.canonical = canonical;\n this._evaluator.availableImages = availableImages || null;\n this._evaluator.formattedSection = formattedSection;\n return this.expression.evaluate(this._evaluator);\n }\n evaluate(globals, feature, featureState, canonical, availableImages, formattedSection) {\n this._evaluator.globals = globals;\n this._evaluator.feature = feature || null;\n this._evaluator.featureState = featureState || null;\n this._evaluator.canonical = canonical;\n this._evaluator.availableImages = availableImages || null;\n this._evaluator.formattedSection = formattedSection || null;\n try {\n const val = this.expression.evaluate(this._evaluator);\n // eslint-disable-next-line no-self-compare\n if (val === null || val === undefined || (typeof val === 'number' && val !== val)) {\n return this._defaultValue;\n }\n if (this._enumValues && !(val in this._enumValues)) {\n throw new RuntimeError(`Expected value to be one of ${Object.keys(this._enumValues).map(v => JSON.stringify(v)).join(', ')}, but found ${JSON.stringify(val)} instead.`);\n }\n return val;\n }\n catch (e) {\n if (!this._warningHistory[e.message]) {\n this._warningHistory[e.message] = true;\n if (typeof console !== 'undefined') {\n console.warn(e.message);\n }\n }\n return this._defaultValue;\n }\n }\n}\nfunction isExpression(expression) {\n return Array.isArray(expression) && expression.length > 0 &&\n typeof expression[0] === 'string' && expression[0] in expressions$1;\n}\n/**\n * Parse and typecheck the given style spec JSON expression. If\n * options.defaultValue is provided, then the resulting StyleExpression's\n * `evaluate()` method will handle errors by logging a warning (once per\n * message) and returning the default value. Otherwise, it will throw\n * evaluation errors.\n *\n * @private\n */\nfunction createExpression(expression, propertySpec) {\n const parser = new ParsingContext(expressions$1, isExpressionConstant, [], propertySpec ? getExpectedType(propertySpec) : undefined);\n // For string-valued properties, coerce to string at the top level rather than asserting.\n const parsed = parser.parse(expression, undefined, undefined, undefined, propertySpec && propertySpec.type === 'string' ? { typeAnnotation: 'coerce' } : undefined);\n if (!parsed) {\n return error(parser.errors);\n }\n return success(new StyleExpression(parsed, propertySpec));\n}\nclass ZoomConstantExpression {\n constructor(kind, expression) {\n this.kind = kind;\n this._styleExpression = expression;\n this.isStateDependent = kind !== 'constant' && !isStateConstant(expression.expression);\n }\n evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection) {\n return this._styleExpression.evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection);\n }\n evaluate(globals, feature, featureState, canonical, availableImages, formattedSection) {\n return this._styleExpression.evaluate(globals, feature, featureState, canonical, availableImages, formattedSection);\n }\n}\nclass ZoomDependentExpression {\n constructor(kind, expression, zoomStops, interpolationType) {\n this.kind = kind;\n this.zoomStops = zoomStops;\n this._styleExpression = expression;\n this.isStateDependent = kind !== 'camera' && !isStateConstant(expression.expression);\n this.interpolationType = interpolationType;\n }\n evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection) {\n return this._styleExpression.evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection);\n }\n evaluate(globals, feature, featureState, canonical, availableImages, formattedSection) {\n return this._styleExpression.evaluate(globals, feature, featureState, canonical, availableImages, formattedSection);\n }\n interpolationFactor(input, lower, upper) {\n if (this.interpolationType) {\n return Interpolate.interpolationFactor(this.interpolationType, input, lower, upper);\n }\n else {\n return 0;\n }\n }\n}\nfunction isZoomExpression(expression) {\n return expression._styleExpression !== undefined;\n}\nfunction createPropertyExpression(expressionInput, propertySpec) {\n const expression = createExpression(expressionInput, propertySpec);\n if (expression.result === 'error') {\n return expression;\n }\n const parsed = expression.value.expression;\n const isFeatureConstantResult = isFeatureConstant(parsed);\n if (!isFeatureConstantResult && !supportsPropertyExpression(propertySpec)) {\n return error([new ExpressionParsingError('', 'data expressions not supported')]);\n }\n const isZoomConstant = isGlobalPropertyConstant(parsed, ['zoom']);\n if (!isZoomConstant && !supportsZoomExpression(propertySpec)) {\n return error([new ExpressionParsingError('', 'zoom expressions not supported')]);\n }\n const zoomCurve = findZoomCurve(parsed);\n if (!zoomCurve && !isZoomConstant) {\n return error([new ExpressionParsingError('', '\"zoom\" expression may only be used as input to a top-level \"step\" or \"interpolate\" expression.')]);\n }\n else if (zoomCurve instanceof ExpressionParsingError) {\n return error([zoomCurve]);\n }\n else if (zoomCurve instanceof Interpolate && !supportsInterpolation(propertySpec)) {\n return error([new ExpressionParsingError('', '\"interpolate\" expressions cannot be used with this property')]);\n }\n if (!zoomCurve) {\n return success(isFeatureConstantResult ?\n new ZoomConstantExpression('constant', expression.value) :\n new ZoomConstantExpression('source', expression.value));\n }\n const interpolationType = zoomCurve instanceof Interpolate ? zoomCurve.interpolation : undefined;\n return success(isFeatureConstantResult ?\n new ZoomDependentExpression('camera', expression.value, zoomCurve.labels, interpolationType) :\n new ZoomDependentExpression('composite', expression.value, zoomCurve.labels, interpolationType));\n}\n// serialization wrapper for old-style stop functions normalized to the\n// expression interface\nclass StylePropertyFunction {\n constructor(parameters, specification) {\n this._parameters = parameters;\n this._specification = specification;\n extendBy(this, createFunction(this._parameters, this._specification));\n }\n static deserialize(serialized) {\n return new StylePropertyFunction(serialized._parameters, serialized._specification);\n }\n static serialize(input) {\n return {\n _parameters: input._parameters,\n _specification: input._specification\n };\n }\n}\nfunction normalizePropertyExpression(value, specification) {\n if (isFunction$1(value)) {\n return new StylePropertyFunction(value, specification);\n }\n else if (isExpression(value)) {\n const expression = createPropertyExpression(value, specification);\n if (expression.result === 'error') {\n // this should have been caught in validation\n throw new Error(expression.value.map(err => `${err.key}: ${err.message}`).join(', '));\n }\n return expression.value;\n }\n else {\n let constant = value;\n if (specification.type === 'color' && typeof value === 'string') {\n constant = Color.parse(value);\n }\n else if (specification.type === 'padding' && (typeof value === 'number' || Array.isArray(value))) {\n constant = Padding.parse(value);\n }\n else if (specification.type === 'variableAnchorOffsetCollection' && Array.isArray(value)) {\n constant = VariableAnchorOffsetCollection.parse(value);\n }\n return {\n kind: 'constant',\n evaluate: () => constant\n };\n }\n}\n// Zoom-dependent expressions may only use [\"zoom\"] as the input to a top-level \"step\" or \"interpolate\"\n// expression (collectively referred to as a \"curve\"). The curve may be wrapped in one or more \"let\" or\n// \"coalesce\" expressions.\nfunction findZoomCurve(expression) {\n let result = null;\n if (expression instanceof Let) {\n result = findZoomCurve(expression.result);\n }\n else if (expression instanceof Coalesce) {\n for (const arg of expression.args) {\n result = findZoomCurve(arg);\n if (result) {\n break;\n }\n }\n }\n else if ((expression instanceof Step || expression instanceof Interpolate) &&\n expression.input instanceof CompoundExpression &&\n expression.input.name === 'zoom') {\n result = expression;\n }\n if (result instanceof ExpressionParsingError) {\n return result;\n }\n expression.eachChild((child) => {\n const childResult = findZoomCurve(child);\n if (childResult instanceof ExpressionParsingError) {\n result = childResult;\n }\n else if (!result && childResult) {\n result = new ExpressionParsingError('', '\"zoom\" expression may only be used as input to a top-level \"step\" or \"interpolate\" expression.');\n }\n else if (result && childResult && result !== childResult) {\n result = new ExpressionParsingError('', 'Only one zoom-based \"step\" or \"interpolate\" subexpression may be used in an expression.');\n }\n });\n return result;\n}\nfunction getExpectedType(spec) {\n const types = {\n color: ColorType,\n string: StringType,\n number: NumberType,\n enum: StringType,\n boolean: BooleanType,\n formatted: FormattedType,\n padding: PaddingType,\n resolvedImage: ResolvedImageType,\n variableAnchorOffsetCollection: VariableAnchorOffsetCollectionType\n };\n if (spec.type === 'array') {\n return array$1(types[spec.value] || ValueType, spec.length);\n }\n return types[spec.type];\n}\nfunction getDefaultValue(spec) {\n if (spec.type === 'color' && isFunction$1(spec.default)) {\n // Special case for heatmap-color: it uses the 'default:' to define a\n // default color ramp, but createExpression expects a simple value to fall\n // back to in case of runtime errors\n return new Color(0, 0, 0, 0);\n }\n else if (spec.type === 'color') {\n return Color.parse(spec.default) || null;\n }\n else if (spec.type === 'padding') {\n return Padding.parse(spec.default) || null;\n }\n else if (spec.type === 'variableAnchorOffsetCollection') {\n return VariableAnchorOffsetCollection.parse(spec.default) || null;\n }\n else if (spec.default === undefined) {\n return null;\n }\n else {\n return spec.default;\n }\n}\n\nfunction isExpressionFilter(filter) {\n if (filter === true || filter === false) {\n return true;\n }\n if (!Array.isArray(filter) || filter.length === 0) {\n return false;\n }\n switch (filter[0]) {\n case 'has':\n return filter.length >= 2 && filter[1] !== '$id' && filter[1] !== '$type';\n case 'in':\n return filter.length >= 3 && (typeof filter[1] !== 'string' || Array.isArray(filter[2]));\n case '!in':\n case '!has':\n case 'none':\n return false;\n case '==':\n case '!=':\n case '>':\n case '>=':\n case '<':\n case '<=':\n return filter.length !== 3 || (Array.isArray(filter[1]) || Array.isArray(filter[2]));\n case 'any':\n case 'all':\n for (const f of filter.slice(1)) {\n if (!isExpressionFilter(f) && typeof f !== 'boolean') {\n return false;\n }\n }\n return true;\n default:\n return true;\n }\n}\nconst filterSpec = {\n 'type': 'boolean',\n 'default': false,\n 'transition': false,\n 'property-type': 'data-driven',\n 'expression': {\n 'interpolated': false,\n 'parameters': ['zoom', 'feature']\n }\n};\n/**\n * Given a filter expressed as nested arrays, return a new function\n * that evaluates whether a given feature (with a .properties or .tags property)\n * passes its test.\n *\n * @private\n * @param {Array} filter MapLibre filter\n * @returns {Function} filter-evaluating function\n */\nfunction createFilter(filter) {\n if (filter === null || filter === undefined) {\n return { filter: () => true, needGeometry: false };\n }\n if (!isExpressionFilter(filter)) {\n filter = convertFilter$1(filter);\n }\n const compiled = createExpression(filter, filterSpec);\n if (compiled.result === 'error') {\n throw new Error(compiled.value.map(err => `${err.key}: ${err.message}`).join(', '));\n }\n else {\n const needGeometry = geometryNeeded(filter);\n return { filter: (globalProperties, feature, canonical) => compiled.value.evaluate(globalProperties, feature, {}, canonical),\n needGeometry };\n }\n}\n// Comparison function to sort numbers and strings\nfunction compare(a, b) {\n return a < b ? -1 : a > b ? 1 : 0;\n}\nfunction geometryNeeded(filter) {\n if (!Array.isArray(filter))\n return false;\n if (filter[0] === 'within' || filter[0] === 'distance')\n return true;\n for (let index = 1; index < filter.length; index++) {\n if (geometryNeeded(filter[index]))\n return true;\n }\n return false;\n}\nfunction convertFilter$1(filter) {\n if (!filter)\n return true;\n const op = filter[0];\n if (filter.length <= 1)\n return (op !== 'any');\n const converted = op === '==' ? convertComparisonOp$1(filter[1], filter[2], '==') :\n op === '!=' ? convertNegation(convertComparisonOp$1(filter[1], filter[2], '==')) :\n op === '<' ||\n op === '>' ||\n op === '<=' ||\n op === '>=' ? convertComparisonOp$1(filter[1], filter[2], op) :\n op === 'any' ? convertDisjunctionOp(filter.slice(1)) :\n op === 'all' ? ['all'].concat(filter.slice(1).map(convertFilter$1)) :\n op === 'none' ? ['all'].concat(filter.slice(1).map(convertFilter$1).map(convertNegation)) :\n op === 'in' ? convertInOp$1(filter[1], filter.slice(2)) :\n op === '!in' ? convertNegation(convertInOp$1(filter[1], filter.slice(2))) :\n op === 'has' ? convertHasOp$1(filter[1]) :\n op === '!has' ? convertNegation(convertHasOp$1(filter[1])) :\n true;\n return converted;\n}\nfunction convertComparisonOp$1(property, value, op) {\n switch (property) {\n case '$type':\n return [`filter-type-${op}`, value];\n case '$id':\n return [`filter-id-${op}`, value];\n default:\n return [`filter-${op}`, property, value];\n }\n}\nfunction convertDisjunctionOp(filters) {\n return ['any'].concat(filters.map(convertFilter$1));\n}\nfunction convertInOp$1(property, values) {\n if (values.length === 0) {\n return false;\n }\n switch (property) {\n case '$type':\n return ['filter-type-in', ['literal', values]];\n case '$id':\n return ['filter-id-in', ['literal', values]];\n default:\n if (values.length > 200 && !values.some(v => typeof v !== typeof values[0])) {\n return ['filter-in-large', property, ['literal', values.sort(compare)]];\n }\n else {\n return ['filter-in-small', property, ['literal', values]];\n }\n }\n}\nfunction convertHasOp$1(property) {\n switch (property) {\n case '$type':\n return true;\n case '$id':\n return ['filter-has-id'];\n default:\n return ['filter-has', property];\n }\n}\nfunction convertNegation(filter) {\n return ['!', filter];\n}\n\n/*\n * Convert the given filter to an expression, storing the expected types for\n * any feature properties referenced in expectedTypes.\n *\n * These expected types are needed in order to construct preflight type checks\n * needed for handling 'any' filters. A preflight type check is necessary in\n * order to mimic legacy filters' semantics around expected type mismatches.\n * For example, consider the legacy filter:\n *\n * [\"any\", [\"all\", [\">\", \"y\", 0], [\">\", \"y\", 0]], [\">\", \"x\", 0]]\n *\n * Naively, we might convert this to the expression:\n *\n * [\"any\", [\"all\", [\">\", [\"get\", \"y\"], 0], [\">\", [\"get\", \"z\"], 0]], [\">\", [\"get\", \"x\"], 0]]\n *\n * But if we tried to evaluate this against, say `{x: 1, y: null, z: 0}`, the\n * [\">\", [\"get\", \"y\"], 0] would cause an evaluation error, leading to the\n * entire filter returning false. Legacy filter semantics, though, ask for\n * [\">\", \"y\", 0] to simply return `false` when `y` is of the wrong type,\n * allowing the subsequent terms of the outer \"any\" expression to be evaluated\n * (resulting, in this case, in a `true` value, because x > 0).\n *\n * We account for this by inserting a preflight type-checking expression before\n * each \"any\" term, allowing us to avoid evaluating the actual converted filter\n * if any type mismatches would cause it to produce an evalaution error:\n *\n * [\"any\",\n * [\"case\",\n * [\"all\", [\"==\", [\"typeof\", [\"get\", \"y\"]], \"number\"], [\"==\", [\"typeof\", [\"get\", \"z\"], \"number]],\n * [\"all\", [\">\", [\"get\", \"y\"], 0], [\">\", [\"get\", \"z\"], 0]],\n * false\n * ],\n * [\"case\",\n * [\"==\", [\"typeof\", [\"get\", \"x\"], \"number\"]],\n * [\">\", [\"get\", \"x\"], 0],\n * false\n * ]\n * ]\n *\n * An alternative, possibly more direct approach would be to use type checks\n * in the conversion of each comparison operator, so that the converted version\n * of each individual ==, >=, etc. would mimic the legacy filter semantics. The\n * downside of this approach is that it can lead to many more type checks than\n * would otherwise be necessary: outside the context of an \"any\" expression,\n * bailing out due to a runtime type error (expression semantics) and returning\n * false (legacy filter semantics) are equivalent: they cause the filter to\n * produce a `false` result.\n */\nfunction convertFilter(filter, expectedTypes = {}) {\n if (isExpressionFilter(filter))\n return filter;\n if (!filter)\n return true;\n const legacyFilter = filter;\n const legacyOp = legacyFilter[0];\n if (filter.length <= 1)\n return (legacyOp !== 'any');\n switch (legacyOp) {\n case '==':\n case '!=':\n case '<':\n case '>':\n case '<=':\n case '>=': {\n const [, property, value] = filter;\n return convertComparisonOp(property, value, legacyOp, expectedTypes);\n }\n case 'any': {\n const [, ...conditions] = legacyFilter;\n const children = conditions.map((f) => {\n const types = {};\n const child = convertFilter(f, types);\n const typechecks = runtimeTypeChecks(types);\n return typechecks === true ? child : ['case', typechecks, child, false];\n });\n return ['any', ...children];\n }\n case 'all': {\n const [, ...conditions] = legacyFilter;\n const children = conditions.map(f => convertFilter(f, expectedTypes));\n return children.length > 1 ? ['all', ...children] : children[0];\n }\n case 'none': {\n const [, ...conditions] = legacyFilter;\n return ['!', convertFilter(['any', ...conditions], {})];\n }\n case 'in': {\n const [, property, ...values] = legacyFilter;\n return convertInOp(property, values);\n }\n case '!in': {\n const [, property, ...values] = legacyFilter;\n return convertInOp(property, values, true);\n }\n case 'has':\n return convertHasOp(legacyFilter[1]);\n case '!has':\n return ['!', convertHasOp(legacyFilter[1])];\n default:\n return true;\n }\n}\n// Given a set of feature properties and an expected type for each one,\n// construct an boolean expression that tests whether each property has the\n// right type.\n// E.g.: for {name: 'string', population: 'number'}, return\n// [ 'all',\n// ['==', ['typeof', ['get', 'name'], 'string']],\n// ['==', ['typeof', ['get', 'population'], 'number]]\n// ]\nfunction runtimeTypeChecks(expectedTypes) {\n const conditions = [];\n for (const property in expectedTypes) {\n const get = property === '$id' ? ['id'] : ['get', property];\n conditions.push(['==', ['typeof', get], expectedTypes[property]]);\n }\n if (conditions.length === 0)\n return true;\n if (conditions.length === 1)\n return conditions[0];\n return ['all', ...conditions];\n}\nfunction convertComparisonOp(property, value, op, expectedTypes) {\n let get;\n if (property === '$type') {\n return [op, ['geometry-type'], value];\n }\n else if (property === '$id') {\n get = ['id'];\n }\n else {\n get = ['get', property];\n }\n if (expectedTypes && value !== null) {\n const type = typeof value;\n expectedTypes[property] = type;\n }\n if (op === '==' && property !== '$id' && value === null) {\n return [\n 'all',\n ['has', property], // missing property != null for legacy filters\n ['==', get, null]\n ];\n }\n else if (op === '!=' && property !== '$id' && value === null) {\n return [\n 'any',\n ['!', ['has', property]], // missing property != null for legacy filters\n ['!=', get, null]\n ];\n }\n return [op, get, value];\n}\nfunction convertInOp(property, values, negate = false) {\n if (values.length === 0)\n return negate;\n let get;\n if (property === '$type') {\n get = ['geometry-type'];\n }\n else if (property === '$id') {\n get = ['id'];\n }\n else {\n get = ['get', property];\n }\n // Determine if the list of values to be searched is homogenously typed.\n // If so (and if the type is string or number), then we can use a\n // [match, input, [...values], true, false] construction rather than a\n // bunch of `==` tests.\n let uniformTypes = true;\n const type = typeof values[0];\n for (const value of values) {\n if (typeof value !== type) {\n uniformTypes = false;\n break;\n }\n }\n if (uniformTypes && (type === 'string' || type === 'number')) {\n // Match expressions must have unique values.\n const uniqueValues = values.sort().filter((v, i) => i === 0 || values[i - 1] !== v);\n return ['match', get, uniqueValues, !negate, negate];\n }\n if (negate) {\n return ['all', ...values.map(v => ['!=', get, v])];\n }\n else {\n return ['any', ...values.map(v => ['==', get, v])];\n }\n}\nfunction convertHasOp(property) {\n if (property === '$type') {\n return true;\n }\n else if (property === '$id') {\n return ['!=', ['id'], null];\n }\n else {\n return ['has', property];\n }\n}\n\nfunction convertLiteral(value) {\n return typeof value === 'object' ? ['literal', value] : value;\n}\nfunction convertFunction(parameters, propertySpec) {\n let stops = parameters.stops;\n if (!stops) {\n // identity function\n return convertIdentityFunction(parameters, propertySpec);\n }\n const zoomAndFeatureDependent = stops && typeof stops[0][0] === 'object';\n const featureDependent = zoomAndFeatureDependent || parameters.property !== undefined;\n const zoomDependent = zoomAndFeatureDependent || !featureDependent;\n stops = stops.map((stop) => {\n if (!featureDependent && propertySpec.tokens && typeof stop[1] === 'string') {\n return [stop[0], convertTokenString(stop[1])];\n }\n return [stop[0], convertLiteral(stop[1])];\n });\n if (zoomAndFeatureDependent) {\n return convertZoomAndPropertyFunction(parameters, propertySpec, stops);\n }\n else if (zoomDependent) {\n return convertZoomFunction(parameters, propertySpec, stops);\n }\n else {\n return convertPropertyFunction(parameters, propertySpec, stops);\n }\n}\nfunction convertIdentityFunction(parameters, propertySpec) {\n const get = ['get', parameters.property];\n if (parameters.default === undefined) {\n // By default, expressions for string-valued properties get coerced. To preserve\n // legacy function semantics, insert an explicit assertion instead.\n return propertySpec.type === 'string' ? ['string', get] : get;\n }\n else if (propertySpec.type === 'enum') {\n return [\n 'match',\n get,\n Object.keys(propertySpec.values),\n get,\n parameters.default\n ];\n }\n else {\n const expression = [propertySpec.type === 'color' ? 'to-color' : propertySpec.type, get, convertLiteral(parameters.default)];\n if (propertySpec.type === 'array') {\n expression.splice(1, 0, propertySpec.value, propertySpec.length || null);\n }\n return expression;\n }\n}\nfunction getInterpolateOperator(parameters) {\n switch (parameters.colorSpace) {\n case 'hcl': return 'interpolate-hcl';\n case 'lab': return 'interpolate-lab';\n default: return 'interpolate';\n }\n}\nfunction convertZoomAndPropertyFunction(parameters, propertySpec, stops) {\n const featureFunctionParameters = {};\n const featureFunctionStops = {};\n const zoomStops = [];\n for (let s = 0; s < stops.length; s++) {\n const stop = stops[s];\n const zoom = stop[0].zoom;\n if (featureFunctionParameters[zoom] === undefined) {\n featureFunctionParameters[zoom] = {\n zoom,\n type: parameters.type,\n property: parameters.property,\n default: parameters.default,\n };\n featureFunctionStops[zoom] = [];\n zoomStops.push(zoom);\n }\n featureFunctionStops[zoom].push([stop[0].value, stop[1]]);\n }\n // the interpolation type for the zoom dimension of a zoom-and-property\n // function is determined directly from the style property specification\n // for which it's being used: linear for interpolatable properties, step\n // otherwise.\n const functionType = getFunctionType({}, propertySpec);\n if (functionType === 'exponential') {\n const expression = [getInterpolateOperator(parameters), ['linear'], ['zoom']];\n for (const z of zoomStops) {\n const output = convertPropertyFunction(featureFunctionParameters[z], propertySpec, featureFunctionStops[z]);\n appendStopPair(expression, z, output, false);\n }\n return expression;\n }\n else {\n const expression = ['step', ['zoom']];\n for (const z of zoomStops) {\n const output = convertPropertyFunction(featureFunctionParameters[z], propertySpec, featureFunctionStops[z]);\n appendStopPair(expression, z, output, true);\n }\n fixupDegenerateStepCurve(expression);\n return expression;\n }\n}\nfunction coalesce(a, b) {\n if (a !== undefined)\n return a;\n if (b !== undefined)\n return b;\n}\nfunction getFallback(parameters, propertySpec) {\n const defaultValue = convertLiteral(coalesce(parameters.default, propertySpec.default));\n /*\n * Some fields with type: resolvedImage have an undefined default.\n * Because undefined is an invalid value for resolvedImage, set fallback to\n * an empty string instead of undefined to ensure output\n * passes validation.\n */\n if (defaultValue === undefined && propertySpec.type === 'resolvedImage') {\n return '';\n }\n return defaultValue;\n}\nfunction convertPropertyFunction(parameters, propertySpec, stops) {\n const type = getFunctionType(parameters, propertySpec);\n const get = ['get', parameters.property];\n if (type === 'categorical' && typeof stops[0][0] === 'boolean') {\n const expression = ['case'];\n for (const stop of stops) {\n expression.push(['==', get, stop[0]], stop[1]);\n }\n expression.push(getFallback(parameters, propertySpec));\n return expression;\n }\n else if (type === 'categorical') {\n const expression = ['match', get];\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], false);\n }\n expression.push(getFallback(parameters, propertySpec));\n return expression;\n }\n else if (type === 'interval') {\n const expression = ['step', ['number', get]];\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], true);\n }\n fixupDegenerateStepCurve(expression);\n return parameters.default === undefined ? expression : [\n 'case',\n ['==', ['typeof', get], 'number'],\n expression,\n convertLiteral(parameters.default)\n ];\n }\n else if (type === 'exponential') {\n const base = parameters.base !== undefined ? parameters.base : 1;\n const expression = [\n getInterpolateOperator(parameters),\n base === 1 ? ['linear'] : ['exponential', base],\n ['number', get]\n ];\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], false);\n }\n return parameters.default === undefined ? expression : [\n 'case',\n ['==', ['typeof', get], 'number'],\n expression,\n convertLiteral(parameters.default)\n ];\n }\n else {\n throw new Error(`Unknown property function type ${type}`);\n }\n}\nfunction convertZoomFunction(parameters, propertySpec, stops, input = ['zoom']) {\n const type = getFunctionType(parameters, propertySpec);\n let expression;\n let isStep = false;\n if (type === 'interval') {\n expression = ['step', input];\n isStep = true;\n }\n else if (type === 'exponential') {\n const base = parameters.base !== undefined ? parameters.base : 1;\n expression = [getInterpolateOperator(parameters), base === 1 ? ['linear'] : ['exponential', base], input];\n }\n else {\n throw new Error(`Unknown zoom function type \"${type}\"`);\n }\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], isStep);\n }\n fixupDegenerateStepCurve(expression);\n return expression;\n}\nfunction fixupDegenerateStepCurve(expression) {\n // degenerate step curve (i.e. a constant function): add a noop stop\n if (expression[0] === 'step' && expression.length === 3) {\n expression.push(0);\n expression.push(expression[3]);\n }\n}\nfunction appendStopPair(curve, input, output, isStep) {\n // Skip duplicate stop values. They were not validated for functions, but they are for expressions.\n // https://github.com/mapbox/mapbox-gl-js/issues/4107\n if (curve.length > 3 && input === curve[curve.length - 2]) {\n return;\n }\n // step curves don't get the first input value, as it is redundant.\n if (!(isStep && curve.length === 2)) {\n curve.push(input);\n }\n curve.push(output);\n}\nfunction getFunctionType(parameters, propertySpec) {\n if (parameters.type) {\n return parameters.type;\n }\n else {\n return propertySpec.expression.interpolated ? 'exponential' : 'interval';\n }\n}\n// \"String with {name} token\" => [\"concat\", \"String with \", [\"get\", \"name\"], \" token\"]\nfunction convertTokenString(s) {\n const result = ['concat'];\n const re = /{([^{}]+)}/g;\n let pos = 0;\n for (let match = re.exec(s); match !== null; match = re.exec(s)) {\n const literal = s.slice(pos, re.lastIndex - match[0].length);\n pos = re.lastIndex;\n if (literal.length > 0)\n result.push(literal);\n result.push(['get', match[1]]);\n }\n if (result.length === 1) {\n return s;\n }\n if (pos < s.length) {\n result.push(s.slice(pos));\n }\n else if (result.length === 2) {\n return ['to-string', result[1]];\n }\n return result;\n}\n\nfunction getPropertyReference(propertyName) {\n for (let i = 0; i < v8Spec.layout.length; i++) {\n for (const key in v8Spec[v8Spec.layout[i]]) {\n if (key === propertyName)\n return v8Spec[v8Spec.layout[i]][key];\n }\n }\n for (let i = 0; i < v8Spec.paint.length; i++) {\n for (const key in v8Spec[v8Spec.paint[i]]) {\n if (key === propertyName)\n return v8Spec[v8Spec.paint[i]][key];\n }\n }\n return null;\n}\nfunction eachSource(style, callback) {\n for (const k in style.sources) {\n callback(style.sources[k]);\n }\n}\nfunction eachLayer(style, callback) {\n for (const layer of style.layers) {\n callback(layer);\n }\n}\nfunction eachProperty(style, options, callback) {\n function inner(layer, propertyType) {\n const properties = layer[propertyType];\n if (!properties)\n return;\n Object.keys(properties).forEach((key) => {\n callback({\n path: [layer.id, propertyType, key],\n key,\n value: properties[key],\n reference: getPropertyReference(key),\n set(x) {\n properties[key] = x;\n }\n });\n });\n }\n eachLayer(style, (layer) => {\n if (options.paint) {\n inner(layer, 'paint');\n }\n if (options.layout) {\n inner(layer, 'layout');\n }\n });\n}\n\nfunction stringify$1(obj) {\n const type = typeof obj;\n if (type === 'number' || type === 'boolean' || type === 'string' || obj === undefined || obj === null)\n return JSON.stringify(obj);\n if (Array.isArray(obj)) {\n let str = '[';\n for (const val of obj) {\n str += `${stringify$1(val)},`;\n }\n return `${str}]`;\n }\n const keys = Object.keys(obj).sort();\n let str = '{';\n for (let i = 0; i < keys.length; i++) {\n str += `${JSON.stringify(keys[i])}:${stringify$1(obj[keys[i]])},`;\n }\n return `${str}}`;\n}\nfunction getKey(layer) {\n let key = '';\n for (const k of refProperties) {\n key += `/${stringify$1(layer[k])}`;\n }\n return key;\n}\n/**\n * Given an array of layers, return an array of arrays of layers where all\n * layers in each group have identical layout-affecting properties. These\n * are the properties that were formerly used by explicit `ref` mechanism\n * for layers: 'type', 'source', 'source-layer', 'minzoom', 'maxzoom',\n * 'filter', and 'layout'.\n *\n * The input is not modified. The output layers are references to the\n * input layers.\n *\n * @private\n * @param {Array} layers\n * @param {Object} [cachedKeys] - an object to keep already calculated keys.\n * @returns {Array>}\n */\nfunction groupByLayout(layers, cachedKeys) {\n const groups = {};\n for (let i = 0; i < layers.length; i++) {\n const k = (cachedKeys && cachedKeys[layers[i].id]) || getKey(layers[i]);\n // update the cache if there is one\n if (cachedKeys)\n cachedKeys[layers[i].id] = k;\n let group = groups[k];\n if (!group) {\n group = groups[k] = [];\n }\n group.push(layers[i]);\n }\n const result = [];\n for (const k in groups) {\n result.push(groups[k]);\n }\n return result;\n}\n\nfunction emptyStyle() {\n const style = {};\n const version = v8Spec['$version'];\n for (const styleKey in v8Spec['$root']) {\n const spec = v8Spec['$root'][styleKey];\n if (spec.required) {\n let value = null;\n if (styleKey === 'version') {\n value = version;\n }\n else {\n if (spec.type === 'array') {\n value = [];\n }\n else {\n value = {};\n }\n }\n if (value != null) {\n style[styleKey] = value;\n }\n }\n }\n return style;\n}\n\nfunction validateConstants(options) {\n const key = options.key;\n const constants = options.value;\n if (constants) {\n return [new ValidationError(key, constants, 'constants have been deprecated as of v8')];\n }\n else {\n return [];\n }\n}\n\n// Turn jsonlint-lines-primitives objects into primitive objects\nfunction unbundle(value) {\n if (value instanceof Number || value instanceof String || value instanceof Boolean) {\n return value.valueOf();\n }\n else {\n return value;\n }\n}\nfunction deepUnbundle(value) {\n if (Array.isArray(value)) {\n return value.map(deepUnbundle);\n }\n else if (value instanceof Object && !(value instanceof Number || value instanceof String || value instanceof Boolean)) {\n const unbundledValue = {};\n for (const key in value) {\n unbundledValue[key] = deepUnbundle(value[key]);\n }\n return unbundledValue;\n }\n return unbundle(value);\n}\n\nfunction validateObject(options) {\n const key = options.key;\n const object = options.value;\n const elementSpecs = options.valueSpec || {};\n const elementValidators = options.objectElementValidators || {};\n const style = options.style;\n const styleSpec = options.styleSpec;\n const validateSpec = options.validateSpec;\n let errors = [];\n const type = getType(object);\n if (type !== 'object') {\n return [new ValidationError(key, object, `object expected, ${type} found`)];\n }\n for (const objectKey in object) {\n const elementSpecKey = objectKey.split('.')[0]; // treat 'paint.*' as 'paint'\n const elementSpec = elementSpecs[elementSpecKey] || elementSpecs['*'];\n let validateElement;\n if (elementValidators[elementSpecKey]) {\n validateElement = elementValidators[elementSpecKey];\n }\n else if (elementSpecs[elementSpecKey]) {\n validateElement = validateSpec;\n }\n else if (elementValidators['*']) {\n validateElement = elementValidators['*'];\n }\n else if (elementSpecs['*']) {\n validateElement = validateSpec;\n }\n else {\n errors.push(new ValidationError(key, object[objectKey], `unknown property \"${objectKey}\"`));\n continue;\n }\n errors = errors.concat(validateElement({\n key: (key ? `${key}.` : key) + objectKey,\n value: object[objectKey],\n valueSpec: elementSpec,\n style,\n styleSpec,\n object,\n objectKey,\n validateSpec,\n }, object));\n }\n for (const elementSpecKey in elementSpecs) {\n // Don't check `required` when there's a custom validator for that property.\n if (elementValidators[elementSpecKey]) {\n continue;\n }\n if (elementSpecs[elementSpecKey].required && elementSpecs[elementSpecKey]['default'] === undefined && object[elementSpecKey] === undefined) {\n errors.push(new ValidationError(key, object, `missing required property \"${elementSpecKey}\"`));\n }\n }\n return errors;\n}\n\nfunction validateArray(options) {\n const array = options.value;\n const arraySpec = options.valueSpec;\n const validateSpec = options.validateSpec;\n const style = options.style;\n const styleSpec = options.styleSpec;\n const key = options.key;\n const validateArrayElement = options.arrayElementValidator || validateSpec;\n if (getType(array) !== 'array') {\n return [new ValidationError(key, array, `array expected, ${getType(array)} found`)];\n }\n if (arraySpec.length && array.length !== arraySpec.length) {\n return [new ValidationError(key, array, `array length ${arraySpec.length} expected, length ${array.length} found`)];\n }\n if (arraySpec['min-length'] && array.length < arraySpec['min-length']) {\n return [new ValidationError(key, array, `array length at least ${arraySpec['min-length']} expected, length ${array.length} found`)];\n }\n let arrayElementSpec = {\n 'type': arraySpec.value,\n 'values': arraySpec.values\n };\n if (styleSpec.$version < 7) {\n arrayElementSpec['function'] = arraySpec.function;\n }\n if (getType(arraySpec.value) === 'object') {\n arrayElementSpec = arraySpec.value;\n }\n let errors = [];\n for (let i = 0; i < array.length; i++) {\n errors = errors.concat(validateArrayElement({\n array,\n arrayIndex: i,\n value: array[i],\n valueSpec: arrayElementSpec,\n validateSpec: options.validateSpec,\n style,\n styleSpec,\n key: `${key}[${i}]`\n }));\n }\n return errors;\n}\n\nfunction validateNumber(options) {\n const key = options.key;\n const value = options.value;\n const valueSpec = options.valueSpec;\n let type = getType(value);\n // eslint-disable-next-line no-self-compare\n if (type === 'number' && value !== value) {\n type = 'NaN';\n }\n if (type !== 'number') {\n return [new ValidationError(key, value, `number expected, ${type} found`)];\n }\n if ('minimum' in valueSpec && value < valueSpec.minimum) {\n return [new ValidationError(key, value, `${value} is less than the minimum value ${valueSpec.minimum}`)];\n }\n if ('maximum' in valueSpec && value > valueSpec.maximum) {\n return [new ValidationError(key, value, `${value} is greater than the maximum value ${valueSpec.maximum}`)];\n }\n return [];\n}\n\nfunction validateFunction(options) {\n const functionValueSpec = options.valueSpec;\n const functionType = unbundle(options.value.type);\n let stopKeyType;\n let stopDomainValues = {};\n let previousStopDomainValue;\n let previousStopDomainZoom;\n const isZoomFunction = functionType !== 'categorical' && options.value.property === undefined;\n const isPropertyFunction = !isZoomFunction;\n const isZoomAndPropertyFunction = getType(options.value.stops) === 'array' &&\n getType(options.value.stops[0]) === 'array' &&\n getType(options.value.stops[0][0]) === 'object';\n const errors = validateObject({\n key: options.key,\n value: options.value,\n valueSpec: options.styleSpec.function,\n validateSpec: options.validateSpec,\n style: options.style,\n styleSpec: options.styleSpec,\n objectElementValidators: {\n stops: validateFunctionStops,\n default: validateFunctionDefault\n }\n });\n if (functionType === 'identity' && isZoomFunction) {\n errors.push(new ValidationError(options.key, options.value, 'missing required property \"property\"'));\n }\n if (functionType !== 'identity' && !options.value.stops) {\n errors.push(new ValidationError(options.key, options.value, 'missing required property \"stops\"'));\n }\n if (functionType === 'exponential' && options.valueSpec.expression && !supportsInterpolation(options.valueSpec)) {\n errors.push(new ValidationError(options.key, options.value, 'exponential functions not supported'));\n }\n if (options.styleSpec.$version >= 8) {\n if (isPropertyFunction && !supportsPropertyExpression(options.valueSpec)) {\n errors.push(new ValidationError(options.key, options.value, 'property functions not supported'));\n }\n else if (isZoomFunction && !supportsZoomExpression(options.valueSpec)) {\n errors.push(new ValidationError(options.key, options.value, 'zoom functions not supported'));\n }\n }\n if ((functionType === 'categorical' || isZoomAndPropertyFunction) && options.value.property === undefined) {\n errors.push(new ValidationError(options.key, options.value, '\"property\" property is required'));\n }\n return errors;\n function validateFunctionStops(options) {\n if (functionType === 'identity') {\n return [new ValidationError(options.key, options.value, 'identity function may not have a \"stops\" property')];\n }\n let errors = [];\n const value = options.value;\n errors = errors.concat(validateArray({\n key: options.key,\n value,\n valueSpec: options.valueSpec,\n validateSpec: options.validateSpec,\n style: options.style,\n styleSpec: options.styleSpec,\n arrayElementValidator: validateFunctionStop\n }));\n if (getType(value) === 'array' && value.length === 0) {\n errors.push(new ValidationError(options.key, value, 'array must have at least one stop'));\n }\n return errors;\n }\n function validateFunctionStop(options) {\n let errors = [];\n const value = options.value;\n const key = options.key;\n if (getType(value) !== 'array') {\n return [new ValidationError(key, value, `array expected, ${getType(value)} found`)];\n }\n if (value.length !== 2) {\n return [new ValidationError(key, value, `array length 2 expected, length ${value.length} found`)];\n }\n if (isZoomAndPropertyFunction) {\n if (getType(value[0]) !== 'object') {\n return [new ValidationError(key, value, `object expected, ${getType(value[0])} found`)];\n }\n if (value[0].zoom === undefined) {\n return [new ValidationError(key, value, 'object stop key must have zoom')];\n }\n if (value[0].value === undefined) {\n return [new ValidationError(key, value, 'object stop key must have value')];\n }\n if (previousStopDomainZoom && previousStopDomainZoom > unbundle(value[0].zoom)) {\n return [new ValidationError(key, value[0].zoom, 'stop zoom values must appear in ascending order')];\n }\n if (unbundle(value[0].zoom) !== previousStopDomainZoom) {\n previousStopDomainZoom = unbundle(value[0].zoom);\n previousStopDomainValue = undefined;\n stopDomainValues = {};\n }\n errors = errors.concat(validateObject({\n key: `${key}[0]`,\n value: value[0],\n valueSpec: { zoom: {} },\n validateSpec: options.validateSpec,\n style: options.style,\n styleSpec: options.styleSpec,\n objectElementValidators: { zoom: validateNumber, value: validateStopDomainValue }\n }));\n }\n else {\n errors = errors.concat(validateStopDomainValue({\n key: `${key}[0]`,\n value: value[0],\n valueSpec: {},\n validateSpec: options.validateSpec,\n style: options.style,\n styleSpec: options.styleSpec\n }, value));\n }\n if (isExpression(deepUnbundle(value[1]))) {\n return errors.concat([new ValidationError(`${key}[1]`, value[1], 'expressions are not allowed in function stops.')]);\n }\n return errors.concat(options.validateSpec({\n key: `${key}[1]`,\n value: value[1],\n valueSpec: functionValueSpec,\n validateSpec: options.validateSpec,\n style: options.style,\n styleSpec: options.styleSpec\n }));\n }\n function validateStopDomainValue(options, stop) {\n const type = getType(options.value);\n const value = unbundle(options.value);\n const reportValue = options.value !== null ? options.value : stop;\n if (!stopKeyType) {\n stopKeyType = type;\n }\n else if (type !== stopKeyType) {\n return [new ValidationError(options.key, reportValue, `${type} stop domain type must match previous stop domain type ${stopKeyType}`)];\n }\n if (type !== 'number' && type !== 'string' && type !== 'boolean') {\n return [new ValidationError(options.key, reportValue, 'stop domain value must be a number, string, or boolean')];\n }\n if (type !== 'number' && functionType !== 'categorical') {\n let message = `number expected, ${type} found`;\n if (supportsPropertyExpression(functionValueSpec) && functionType === undefined) {\n message += '\\nIf you intended to use a categorical function, specify `\"type\": \"categorical\"`.';\n }\n return [new ValidationError(options.key, reportValue, message)];\n }\n if (functionType === 'categorical' && type === 'number' && (!isFinite(value) || Math.floor(value) !== value)) {\n return [new ValidationError(options.key, reportValue, `integer expected, found ${value}`)];\n }\n if (functionType !== 'categorical' && type === 'number' && previousStopDomainValue !== undefined && value < previousStopDomainValue) {\n return [new ValidationError(options.key, reportValue, 'stop domain values must appear in ascending order')];\n }\n else {\n previousStopDomainValue = value;\n }\n if (functionType === 'categorical' && value in stopDomainValues) {\n return [new ValidationError(options.key, reportValue, 'stop domain values must be unique')];\n }\n else {\n stopDomainValues[value] = true;\n }\n return [];\n }\n function validateFunctionDefault(options) {\n return options.validateSpec({\n key: options.key,\n value: options.value,\n valueSpec: functionValueSpec,\n validateSpec: options.validateSpec,\n style: options.style,\n styleSpec: options.styleSpec\n });\n }\n}\n\nfunction validateExpression(options) {\n const expression = (options.expressionContext === 'property' ? createPropertyExpression : createExpression)(deepUnbundle(options.value), options.valueSpec);\n if (expression.result === 'error') {\n return expression.value.map((error) => {\n return new ValidationError(`${options.key}${error.key}`, options.value, error.message);\n });\n }\n const expressionObj = expression.value.expression || expression.value._styleExpression.expression;\n if (options.expressionContext === 'property' && (options.propertyKey === 'text-font') &&\n !expressionObj.outputDefined()) {\n return [new ValidationError(options.key, options.value, `Invalid data expression for \"${options.propertyKey}\". Output values must be contained as literals within the expression.`)];\n }\n if (options.expressionContext === 'property' && options.propertyType === 'layout' &&\n (!isStateConstant(expressionObj))) {\n return [new ValidationError(options.key, options.value, '\"feature-state\" data expressions are not supported with layout properties.')];\n }\n if (options.expressionContext === 'filter' && !isStateConstant(expressionObj)) {\n return [new ValidationError(options.key, options.value, '\"feature-state\" data expressions are not supported with filters.')];\n }\n if (options.expressionContext && options.expressionContext.indexOf('cluster') === 0) {\n if (!isGlobalPropertyConstant(expressionObj, ['zoom', 'feature-state'])) {\n return [new ValidationError(options.key, options.value, '\"zoom\" and \"feature-state\" expressions are not supported with cluster properties.')];\n }\n if (options.expressionContext === 'cluster-initial' && !isFeatureConstant(expressionObj)) {\n return [new ValidationError(options.key, options.value, 'Feature data expressions are not supported with initial expression part of cluster properties.')];\n }\n }\n return [];\n}\n\nfunction validateBoolean(options) {\n const value = options.value;\n const key = options.key;\n const type = getType(value);\n if (type !== 'boolean') {\n return [new ValidationError(key, value, `boolean expected, ${type} found`)];\n }\n return [];\n}\n\nfunction validateColor(options) {\n const key = options.key;\n const value = options.value;\n const type = getType(value);\n if (type !== 'string') {\n return [new ValidationError(key, value, `color expected, ${type} found`)];\n }\n if (!Color.parse(String(value))) { // cast String object to string primitive\n return [new ValidationError(key, value, `color expected, \"${value}\" found`)];\n }\n return [];\n}\n\nfunction validateEnum(options) {\n const key = options.key;\n const value = options.value;\n const valueSpec = options.valueSpec;\n const errors = [];\n if (Array.isArray(valueSpec.values)) { // <=v7\n if (valueSpec.values.indexOf(unbundle(value)) === -1) {\n errors.push(new ValidationError(key, value, `expected one of [${valueSpec.values.join(', ')}], ${JSON.stringify(value)} found`));\n }\n }\n else { // >=v8\n if (Object.keys(valueSpec.values).indexOf(unbundle(value)) === -1) {\n errors.push(new ValidationError(key, value, `expected one of [${Object.keys(valueSpec.values).join(', ')}], ${JSON.stringify(value)} found`));\n }\n }\n return errors;\n}\n\nfunction validateFilter(options) {\n if (isExpressionFilter(deepUnbundle(options.value))) {\n return validateExpression(extendBy({}, options, {\n expressionContext: 'filter',\n valueSpec: { value: 'boolean' }\n }));\n }\n else {\n return validateNonExpressionFilter(options);\n }\n}\nfunction validateNonExpressionFilter(options) {\n const value = options.value;\n const key = options.key;\n if (getType(value) !== 'array') {\n return [new ValidationError(key, value, `array expected, ${getType(value)} found`)];\n }\n const styleSpec = options.styleSpec;\n let type;\n let errors = [];\n if (value.length < 1) {\n return [new ValidationError(key, value, 'filter array must have at least 1 element')];\n }\n errors = errors.concat(validateEnum({\n key: `${key}[0]`,\n value: value[0],\n valueSpec: styleSpec.filter_operator,\n style: options.style,\n styleSpec: options.styleSpec\n }));\n switch (unbundle(value[0])) {\n case '<':\n case '<=':\n case '>':\n case '>=':\n if (value.length >= 2 && unbundle(value[1]) === '$type') {\n errors.push(new ValidationError(key, value, `\"$type\" cannot be use with operator \"${value[0]}\"`));\n }\n /* falls through */\n case '==':\n case '!=':\n if (value.length !== 3) {\n errors.push(new ValidationError(key, value, `filter array for operator \"${value[0]}\" must have 3 elements`));\n }\n /* falls through */\n case 'in':\n case '!in':\n if (value.length >= 2) {\n type = getType(value[1]);\n if (type !== 'string') {\n errors.push(new ValidationError(`${key}[1]`, value[1], `string expected, ${type} found`));\n }\n }\n for (let i = 2; i < value.length; i++) {\n type = getType(value[i]);\n if (unbundle(value[1]) === '$type') {\n errors = errors.concat(validateEnum({\n key: `${key}[${i}]`,\n value: value[i],\n valueSpec: styleSpec.geometry_type,\n style: options.style,\n styleSpec: options.styleSpec\n }));\n }\n else if (type !== 'string' && type !== 'number' && type !== 'boolean') {\n errors.push(new ValidationError(`${key}[${i}]`, value[i], `string, number, or boolean expected, ${type} found`));\n }\n }\n break;\n case 'any':\n case 'all':\n case 'none':\n for (let i = 1; i < value.length; i++) {\n errors = errors.concat(validateNonExpressionFilter({\n key: `${key}[${i}]`,\n value: value[i],\n style: options.style,\n styleSpec: options.styleSpec\n }));\n }\n break;\n case 'has':\n case '!has':\n type = getType(value[1]);\n if (value.length !== 2) {\n errors.push(new ValidationError(key, value, `filter array for \"${value[0]}\" operator must have 2 elements`));\n }\n else if (type !== 'string') {\n errors.push(new ValidationError(`${key}[1]`, value[1], `string expected, ${type} found`));\n }\n break;\n }\n return errors;\n}\n\nfunction validateProperty(options, propertyType) {\n const key = options.key;\n const validateSpec = options.validateSpec;\n const style = options.style;\n const styleSpec = options.styleSpec;\n const value = options.value;\n const propertyKey = options.objectKey;\n const layerSpec = styleSpec[`${propertyType}_${options.layerType}`];\n if (!layerSpec)\n return [];\n const transitionMatch = propertyKey.match(/^(.*)-transition$/);\n if (propertyType === 'paint' && transitionMatch && layerSpec[transitionMatch[1]] && layerSpec[transitionMatch[1]].transition) {\n return validateSpec({\n key,\n value,\n valueSpec: styleSpec.transition,\n style,\n styleSpec\n });\n }\n const valueSpec = options.valueSpec || layerSpec[propertyKey];\n if (!valueSpec) {\n return [new ValidationError(key, value, `unknown property \"${propertyKey}\"`)];\n }\n let tokenMatch;\n if (getType(value) === 'string' && supportsPropertyExpression(valueSpec) && !valueSpec.tokens && (tokenMatch = /^{([^}]+)}$/.exec(value))) {\n return [new ValidationError(key, value, `\"${propertyKey}\" does not support interpolation syntax\\n` +\n `Use an identity property function instead: \\`{ \"type\": \"identity\", \"property\": ${JSON.stringify(tokenMatch[1])} }\\`.`)];\n }\n const errors = [];\n if (options.layerType === 'symbol') {\n if (propertyKey === 'text-field' && style && !style.glyphs) {\n errors.push(new ValidationError(key, value, 'use of \"text-field\" requires a style \"glyphs\" property'));\n }\n if (propertyKey === 'text-font' && isFunction$1(deepUnbundle(value)) && unbundle(value.type) === 'identity') {\n errors.push(new ValidationError(key, value, '\"text-font\" does not support identity functions'));\n }\n }\n return errors.concat(validateSpec({\n key: options.key,\n value,\n valueSpec,\n style,\n styleSpec,\n expressionContext: 'property',\n propertyType,\n propertyKey\n }));\n}\n\nfunction validatePaintProperty(options) {\n return validateProperty(options, 'paint');\n}\n\nfunction validateLayoutProperty(options) {\n return validateProperty(options, 'layout');\n}\n\nfunction validateLayer(options) {\n let errors = [];\n const layer = options.value;\n const key = options.key;\n const style = options.style;\n const styleSpec = options.styleSpec;\n if (!layer.type && !layer.ref) {\n errors.push(new ValidationError(key, layer, 'either \"type\" or \"ref\" is required'));\n }\n let type = unbundle(layer.type);\n const ref = unbundle(layer.ref);\n if (layer.id) {\n const layerId = unbundle(layer.id);\n for (let i = 0; i < options.arrayIndex; i++) {\n const otherLayer = style.layers[i];\n if (unbundle(otherLayer.id) === layerId) {\n errors.push(new ValidationError(key, layer.id, `duplicate layer id \"${layer.id}\", previously used at line ${otherLayer.id.__line__}`));\n }\n }\n }\n if ('ref' in layer) {\n ['type', 'source', 'source-layer', 'filter', 'layout'].forEach((p) => {\n if (p in layer) {\n errors.push(new ValidationError(key, layer[p], `\"${p}\" is prohibited for ref layers`));\n }\n });\n let parent;\n style.layers.forEach((layer) => {\n if (unbundle(layer.id) === ref)\n parent = layer;\n });\n if (!parent) {\n errors.push(new ValidationError(key, layer.ref, `ref layer \"${ref}\" not found`));\n }\n else if (parent.ref) {\n errors.push(new ValidationError(key, layer.ref, 'ref cannot reference another ref layer'));\n }\n else {\n type = unbundle(parent.type);\n }\n }\n else if (type !== 'background') {\n if (!layer.source) {\n errors.push(new ValidationError(key, layer, 'missing required property \"source\"'));\n }\n else {\n const source = style.sources && style.sources[layer.source];\n const sourceType = source && unbundle(source.type);\n if (!source) {\n errors.push(new ValidationError(key, layer.source, `source \"${layer.source}\" not found`));\n }\n else if (sourceType === 'vector' && type === 'raster') {\n errors.push(new ValidationError(key, layer.source, `layer \"${layer.id}\" requires a raster source`));\n }\n else if (sourceType !== 'raster-dem' && type === 'hillshade') {\n errors.push(new ValidationError(key, layer.source, `layer \"${layer.id}\" requires a raster-dem source`));\n }\n else if (sourceType === 'raster' && type !== 'raster') {\n errors.push(new ValidationError(key, layer.source, `layer \"${layer.id}\" requires a vector source`));\n }\n else if (sourceType === 'vector' && !layer['source-layer']) {\n errors.push(new ValidationError(key, layer, `layer \"${layer.id}\" must specify a \"source-layer\"`));\n }\n else if (sourceType === 'raster-dem' && type !== 'hillshade') {\n errors.push(new ValidationError(key, layer.source, 'raster-dem source can only be used with layer type \\'hillshade\\'.'));\n }\n else if (type === 'line' && layer.paint && layer.paint['line-gradient'] &&\n (sourceType !== 'geojson' || !source.lineMetrics)) {\n errors.push(new ValidationError(key, layer, `layer \"${layer.id}\" specifies a line-gradient, which requires a GeoJSON source with \\`lineMetrics\\` enabled.`));\n }\n }\n }\n errors = errors.concat(validateObject({\n key,\n value: layer,\n valueSpec: styleSpec.layer,\n style: options.style,\n styleSpec: options.styleSpec,\n validateSpec: options.validateSpec,\n objectElementValidators: {\n '*'() {\n return [];\n },\n // We don't want to enforce the spec's `\"requires\": true` for backward compatibility with refs;\n // the actual requirement is validated above. See https://github.com/mapbox/mapbox-gl-js/issues/5772.\n type() {\n return options.validateSpec({\n key: `${key}.type`,\n value: layer.type,\n valueSpec: styleSpec.layer.type,\n style: options.style,\n styleSpec: options.styleSpec,\n validateSpec: options.validateSpec,\n object: layer,\n objectKey: 'type'\n });\n },\n filter: validateFilter,\n layout(options) {\n return validateObject({\n layer,\n key: options.key,\n value: options.value,\n style: options.style,\n styleSpec: options.styleSpec,\n validateSpec: options.validateSpec,\n objectElementValidators: {\n '*'(options) {\n return validateLayoutProperty(extendBy({ layerType: type }, options));\n }\n }\n });\n },\n paint(options) {\n return validateObject({\n layer,\n key: options.key,\n value: options.value,\n style: options.style,\n styleSpec: options.styleSpec,\n validateSpec: options.validateSpec,\n objectElementValidators: {\n '*'(options) {\n return validatePaintProperty(extendBy({ layerType: type }, options));\n }\n }\n });\n }\n }\n }));\n return errors;\n}\n\nfunction validateString(options) {\n const value = options.value;\n const key = options.key;\n const type = getType(value);\n if (type !== 'string') {\n return [new ValidationError(key, value, `string expected, ${type} found`)];\n }\n return [];\n}\n\nfunction validateRasterDEMSource(options) {\n var _a;\n const sourceName = (_a = options.sourceName) !== null && _a !== void 0 ? _a : '';\n const rasterDEM = options.value;\n const styleSpec = options.styleSpec;\n const rasterDEMSpec = styleSpec.source_raster_dem;\n const style = options.style;\n let errors = [];\n const rootType = getType(rasterDEM);\n if (rasterDEM === undefined) {\n return errors;\n }\n else if (rootType !== 'object') {\n errors.push(new ValidationError('source_raster_dem', rasterDEM, `object expected, ${rootType} found`));\n return errors;\n }\n const encoding = unbundle(rasterDEM.encoding);\n const isCustomEncoding = encoding === 'custom';\n const customEncodingKeys = ['redFactor', 'greenFactor', 'blueFactor', 'baseShift'];\n const encodingName = options.value.encoding ? `\"${options.value.encoding}\"` : 'Default';\n for (const key in rasterDEM) {\n if (!isCustomEncoding && customEncodingKeys.includes(key)) {\n errors.push(new ValidationError(key, rasterDEM[key], `In \"${sourceName}\": \"${key}\" is only valid when \"encoding\" is set to \"custom\". ${encodingName} encoding found`));\n }\n else if (rasterDEMSpec[key]) {\n errors = errors.concat(options.validateSpec({\n key,\n value: rasterDEM[key],\n valueSpec: rasterDEMSpec[key],\n validateSpec: options.validateSpec,\n style,\n styleSpec\n }));\n }\n else {\n errors.push(new ValidationError(key, rasterDEM[key], `unknown property \"${key}\"`));\n }\n }\n return errors;\n}\n\nconst objectElementValidators = {\n promoteId: validatePromoteId\n};\nfunction validateSource(options) {\n const value = options.value;\n const key = options.key;\n const styleSpec = options.styleSpec;\n const style = options.style;\n const validateSpec = options.validateSpec;\n if (!value.type) {\n return [new ValidationError(key, value, '\"type\" is required')];\n }\n const type = unbundle(value.type);\n let errors;\n switch (type) {\n case 'vector':\n case 'raster':\n errors = validateObject({\n key,\n value,\n valueSpec: styleSpec[`source_${type.replace('-', '_')}`],\n style: options.style,\n styleSpec,\n objectElementValidators,\n validateSpec,\n });\n return errors;\n case 'raster-dem':\n errors = validateRasterDEMSource({\n sourceName: key,\n value,\n style: options.style,\n styleSpec,\n validateSpec,\n });\n return errors;\n case 'geojson':\n errors = validateObject({\n key,\n value,\n valueSpec: styleSpec.source_geojson,\n style,\n styleSpec,\n validateSpec,\n objectElementValidators\n });\n if (value.cluster) {\n for (const prop in value.clusterProperties) {\n const [operator, mapExpr] = value.clusterProperties[prop];\n const reduceExpr = typeof operator === 'string' ? [operator, ['accumulated'], ['get', prop]] : operator;\n errors.push(...validateExpression({\n key: `${key}.${prop}.map`,\n value: mapExpr,\n validateSpec,\n expressionContext: 'cluster-map'\n }));\n errors.push(...validateExpression({\n key: `${key}.${prop}.reduce`,\n value: reduceExpr,\n validateSpec,\n expressionContext: 'cluster-reduce'\n }));\n }\n }\n return errors;\n case 'video':\n return validateObject({\n key,\n value,\n valueSpec: styleSpec.source_video,\n style,\n validateSpec,\n styleSpec\n });\n case 'image':\n return validateObject({\n key,\n value,\n valueSpec: styleSpec.source_image,\n style,\n validateSpec,\n styleSpec\n });\n case 'canvas':\n return [new ValidationError(key, null, 'Please use runtime APIs to add canvas sources, rather than including them in stylesheets.', 'source.canvas')];\n default:\n return validateEnum({\n key: `${key}.type`,\n value: value.type,\n valueSpec: { values: ['vector', 'raster', 'raster-dem', 'geojson', 'video', 'image'] },\n style,\n validateSpec,\n styleSpec\n });\n }\n}\nfunction validatePromoteId({ key, value }) {\n if (getType(value) === 'string') {\n return validateString({ key, value });\n }\n else {\n const errors = [];\n for (const prop in value) {\n errors.push(...validateString({ key: `${key}.${prop}`, value: value[prop] }));\n }\n return errors;\n }\n}\n\nfunction validateLight(options) {\n const light = options.value;\n const styleSpec = options.styleSpec;\n const lightSpec = styleSpec.light;\n const style = options.style;\n let errors = [];\n const rootType = getType(light);\n if (light === undefined) {\n return errors;\n }\n else if (rootType !== 'object') {\n errors = errors.concat([new ValidationError('light', light, `object expected, ${rootType} found`)]);\n return errors;\n }\n for (const key in light) {\n const transitionMatch = key.match(/^(.*)-transition$/);\n if (transitionMatch && lightSpec[transitionMatch[1]] && lightSpec[transitionMatch[1]].transition) {\n errors = errors.concat(options.validateSpec({\n key,\n value: light[key],\n valueSpec: styleSpec.transition,\n validateSpec: options.validateSpec,\n style,\n styleSpec\n }));\n }\n else if (lightSpec[key]) {\n errors = errors.concat(options.validateSpec({\n key,\n value: light[key],\n valueSpec: lightSpec[key],\n validateSpec: options.validateSpec,\n style,\n styleSpec\n }));\n }\n else {\n errors = errors.concat([new ValidationError(key, light[key], `unknown property \"${key}\"`)]);\n }\n }\n return errors;\n}\n\nfunction validateSky(options) {\n const sky = options.value;\n const styleSpec = options.styleSpec;\n const skySpec = styleSpec.sky;\n const style = options.style;\n const rootType = getType(sky);\n if (sky === undefined) {\n return [];\n }\n else if (rootType !== 'object') {\n return [new ValidationError('sky', sky, `object expected, ${rootType} found`)];\n }\n let errors = [];\n for (const key in sky) {\n if (skySpec[key]) {\n errors = errors.concat(options.validateSpec({\n key,\n value: sky[key],\n valueSpec: skySpec[key],\n style,\n styleSpec\n }));\n }\n else {\n errors = errors.concat([new ValidationError(key, sky[key], `unknown property \"${key}\"`)]);\n }\n }\n return errors;\n}\n\nfunction validateTerrain(options) {\n const terrain = options.value;\n const styleSpec = options.styleSpec;\n const terrainSpec = styleSpec.terrain;\n const style = options.style;\n let errors = [];\n const rootType = getType(terrain);\n if (terrain === undefined) {\n return errors;\n }\n else if (rootType !== 'object') {\n errors = errors.concat([new ValidationError('terrain', terrain, `object expected, ${rootType} found`)]);\n return errors;\n }\n for (const key in terrain) {\n if (terrainSpec[key]) {\n errors = errors.concat(options.validateSpec({\n key,\n value: terrain[key],\n valueSpec: terrainSpec[key],\n validateSpec: options.validateSpec,\n style,\n styleSpec\n }));\n }\n else {\n errors = errors.concat([new ValidationError(key, terrain[key], `unknown property \"${key}\"`)]);\n }\n }\n return errors;\n}\n\nfunction validateFormatted(options) {\n if (validateString(options).length === 0) {\n return [];\n }\n return validateExpression(options);\n}\n\nfunction validateImage(options) {\n if (validateString(options).length === 0) {\n return [];\n }\n return validateExpression(options);\n}\n\nfunction validatePadding(options) {\n const key = options.key;\n const value = options.value;\n const type = getType(value);\n if (type === 'array') {\n if (value.length < 1 || value.length > 4) {\n return [new ValidationError(key, value, `padding requires 1 to 4 values; ${value.length} values found`)];\n }\n const arrayElementSpec = {\n type: 'number'\n };\n let errors = [];\n for (let i = 0; i < value.length; i++) {\n errors = errors.concat(options.validateSpec({\n key: `${key}[${i}]`,\n value: value[i],\n validateSpec: options.validateSpec,\n valueSpec: arrayElementSpec\n }));\n }\n return errors;\n }\n else {\n return validateNumber({\n key,\n value,\n valueSpec: {}\n });\n }\n}\n\nfunction validateVariableAnchorOffsetCollection(options) {\n const key = options.key;\n const value = options.value;\n const type = getType(value);\n const styleSpec = options.styleSpec;\n if (type !== 'array' || value.length < 1 || value.length % 2 !== 0) {\n return [new ValidationError(key, value, 'variableAnchorOffsetCollection requires a non-empty array of even length')];\n }\n let errors = [];\n for (let i = 0; i < value.length; i += 2) {\n // Elements in even positions should be values from text-anchor enum\n errors = errors.concat(validateEnum({\n key: `${key}[${i}]`,\n value: value[i],\n valueSpec: styleSpec['layout_symbol']['text-anchor']\n }));\n // Elements in odd positions should be points (2-element numeric arrays)\n errors = errors.concat(validateArray({\n key: `${key}[${i + 1}]`,\n value: value[i + 1],\n valueSpec: {\n length: 2,\n value: 'number'\n },\n validateSpec: options.validateSpec,\n style: options.style,\n styleSpec\n }));\n }\n return errors;\n}\n\nfunction validateSprite(options) {\n let errors = [];\n const sprite = options.value;\n const key = options.key;\n if (!Array.isArray(sprite)) {\n return validateString({\n key,\n value: sprite\n });\n }\n else {\n const allSpriteIds = [];\n const allSpriteURLs = [];\n for (const i in sprite) {\n if (sprite[i].id && allSpriteIds.includes(sprite[i].id))\n errors.push(new ValidationError(key, sprite, `all the sprites' ids must be unique, but ${sprite[i].id} is duplicated`));\n allSpriteIds.push(sprite[i].id);\n if (sprite[i].url && allSpriteURLs.includes(sprite[i].url))\n errors.push(new ValidationError(key, sprite, `all the sprites' URLs must be unique, but ${sprite[i].url} is duplicated`));\n allSpriteURLs.push(sprite[i].url);\n const pairSpec = {\n id: {\n type: 'string',\n required: true,\n },\n url: {\n type: 'string',\n required: true,\n }\n };\n errors = errors.concat(validateObject({\n key: `${key}[${i}]`,\n value: sprite[i],\n valueSpec: pairSpec,\n validateSpec: options.validateSpec,\n }));\n }\n return errors;\n }\n}\n\nfunction validateProjection(options) {\n const projection = options.value;\n const styleSpec = options.styleSpec;\n const projectionSpec = styleSpec.projection;\n const style = options.style;\n const rootType = getType(projection);\n if (projection === undefined) {\n return [];\n }\n else if (rootType !== 'object') {\n return [new ValidationError('projection', projection, `object expected, ${rootType} found`)];\n }\n let errors = [];\n for (const key in projection) {\n if (projectionSpec[key]) {\n errors = errors.concat(options.validateSpec({\n key,\n value: projection[key],\n valueSpec: projectionSpec[key],\n style,\n styleSpec\n }));\n }\n else {\n errors = errors.concat([new ValidationError(key, projection[key], `unknown property \"${key}\"`)]);\n }\n }\n return errors;\n}\n\nconst VALIDATORS = {\n '*'() {\n return [];\n },\n 'array': validateArray,\n 'boolean': validateBoolean,\n 'number': validateNumber,\n 'color': validateColor,\n 'constants': validateConstants,\n 'enum': validateEnum,\n 'filter': validateFilter,\n 'function': validateFunction,\n 'layer': validateLayer,\n 'object': validateObject,\n 'source': validateSource,\n 'light': validateLight,\n 'sky': validateSky,\n 'terrain': validateTerrain,\n 'projection': validateProjection,\n 'string': validateString,\n 'formatted': validateFormatted,\n 'resolvedImage': validateImage,\n 'padding': validatePadding,\n 'variableAnchorOffsetCollection': validateVariableAnchorOffsetCollection,\n 'sprite': validateSprite,\n};\n/**\n * Main recursive validation function used internally.\n * You should use `validateStyleMin` in the browser or `validateStyle` in node env.\n * @param options - the options object\n * @param options.key - string representing location of validation in style tree. Used only\n * for more informative error reporting.\n * @param options.value - current value from style being evaluated. May be anything from a\n * high level object that needs to be descended into deeper or a simple\n * scalar value.\n * @param options.valueSpec - current spec being evaluated. Tracks value.\n * @param options.styleSpec - current full spec being evaluated.\n * @param options.validateSpec - the validate function itself\n * @param options.style - the style object\n * @param options.objectElementValidators - optional object of functions that will be called\n * @returns an array of errors, or an empty array if no errors are found.\n */\nfunction validate(options) {\n const value = options.value;\n const valueSpec = options.valueSpec;\n const styleSpec = options.styleSpec;\n options.validateSpec = validate;\n if (valueSpec.expression && isFunction$1(unbundle(value))) {\n return validateFunction(options);\n }\n else if (valueSpec.expression && isExpression(deepUnbundle(value))) {\n return validateExpression(options);\n }\n else if (valueSpec.type && VALIDATORS[valueSpec.type]) {\n return VALIDATORS[valueSpec.type](options);\n }\n else {\n const valid = validateObject(extendBy({}, options, {\n valueSpec: valueSpec.type ? styleSpec[valueSpec.type] : valueSpec\n }));\n return valid;\n }\n}\n\nfunction validateGlyphsUrl(options) {\n const value = options.value;\n const key = options.key;\n const errors = validateString(options);\n if (errors.length)\n return errors;\n if (value.indexOf('{fontstack}') === -1) {\n errors.push(new ValidationError(key, value, '\"glyphs\" url must include a \"{fontstack}\" token'));\n }\n if (value.indexOf('{range}') === -1) {\n errors.push(new ValidationError(key, value, '\"glyphs\" url must include a \"{range}\" token'));\n }\n return errors;\n}\n\n/**\n * Validate a MapLibre style against the style specification.\n * Use this when running in the browser.\n *\n * @param style - The style to be validated.\n * @param styleSpec - The style specification to validate against.\n * If omitted, the latest style spec is used.\n * @returns an array of errors, or an empty array if no errors are found.\n * @example\n * const validate = require('@maplibre/maplibre-gl-style-spec/').validateStyleMin;\n * const errors = validate(style);\n */\nfunction validateStyleMin(style, styleSpec = v8Spec) {\n let errors = [];\n errors = errors.concat(validate({\n key: '',\n value: style,\n valueSpec: styleSpec.$root,\n styleSpec,\n style,\n validateSpec: validate,\n objectElementValidators: {\n glyphs: validateGlyphsUrl,\n '*'() {\n return [];\n }\n }\n }));\n if (style['constants']) {\n errors = errors.concat(validateConstants({\n key: 'constants',\n value: style['constants'],\n style,\n styleSpec,\n validateSpec: validate,\n }));\n }\n return sortErrors(errors);\n}\nvalidateStyleMin.source = wrapCleanErrors(injectValidateSpec(validateSource));\nvalidateStyleMin.sprite = wrapCleanErrors(injectValidateSpec(validateSprite));\nvalidateStyleMin.glyphs = wrapCleanErrors(injectValidateSpec(validateGlyphsUrl));\nvalidateStyleMin.light = wrapCleanErrors(injectValidateSpec(validateLight));\nvalidateStyleMin.sky = wrapCleanErrors(injectValidateSpec(validateSky));\nvalidateStyleMin.terrain = wrapCleanErrors(injectValidateSpec(validateTerrain));\nvalidateStyleMin.layer = wrapCleanErrors(injectValidateSpec(validateLayer));\nvalidateStyleMin.filter = wrapCleanErrors(injectValidateSpec(validateFilter));\nvalidateStyleMin.paintProperty = wrapCleanErrors(injectValidateSpec(validatePaintProperty));\nvalidateStyleMin.layoutProperty = wrapCleanErrors(injectValidateSpec(validateLayoutProperty));\nfunction injectValidateSpec(validator) {\n return function (options) {\n return validator({\n ...options,\n validateSpec: validate,\n });\n };\n}\nfunction sortErrors(errors) {\n return [].concat(errors).sort((a, b) => {\n return a.line - b.line;\n });\n}\nfunction wrapCleanErrors(inner) {\n return function (...args) {\n return sortErrors(inner.apply(this, args));\n };\n}\n\n// Note: This regex matches even invalid JSON strings, but since we’re\n// working on the output of `JSON.stringify` we know that only valid strings\n// are present (unless the user supplied a weird `options.indent` but in\n// that case we don’t care since the output would be invalid anyway).\nconst stringOrChar = /(\"(?:[^\\\\\"]|\\\\.)*\")|[:,]/g;\n\nfunction stringify(passedObj, options = {}) {\n const indent = JSON.stringify(\n [1],\n undefined,\n options.indent === undefined ? 2 : options.indent\n ).slice(2, -3);\n\n const maxLength =\n indent === \"\"\n ? Infinity\n : options.maxLength === undefined\n ? 80\n : options.maxLength;\n\n let { replacer } = options;\n\n return (function _stringify(obj, currentIndent, reserved) {\n if (obj && typeof obj.toJSON === \"function\") {\n obj = obj.toJSON();\n }\n\n const string = JSON.stringify(obj, replacer);\n\n if (string === undefined) {\n return string;\n }\n\n const length = maxLength - currentIndent.length - reserved;\n\n if (string.length <= length) {\n const prettified = string.replace(\n stringOrChar,\n (match, stringLiteral) => {\n return stringLiteral || `${match} `;\n }\n );\n if (prettified.length <= length) {\n return prettified;\n }\n }\n\n if (replacer != null) {\n obj = JSON.parse(string);\n replacer = undefined;\n }\n\n if (typeof obj === \"object\" && obj !== null) {\n const nextIndent = currentIndent + indent;\n const items = [];\n let index = 0;\n let start;\n let end;\n\n if (Array.isArray(obj)) {\n start = \"[\";\n end = \"]\";\n const { length } = obj;\n for (; index < length; index++) {\n items.push(\n _stringify(obj[index], nextIndent, index === length - 1 ? 0 : 1) ||\n \"null\"\n );\n }\n } else {\n start = \"{\";\n end = \"}\";\n const keys = Object.keys(obj);\n const { length } = keys;\n for (; index < length; index++) {\n const key = keys[index];\n const keyPart = `${JSON.stringify(key)}: `;\n const value = _stringify(\n obj[key],\n nextIndent,\n keyPart.length + (index === length - 1 ? 0 : 1)\n );\n if (value !== undefined) {\n items.push(keyPart + value);\n }\n }\n }\n\n if (items.length > 0) {\n return [start, indent + items.join(`,\\n${nextIndent}`), end].join(\n `\\n${currentIndent}`\n );\n }\n }\n\n return string;\n })(passedObj, \"\", 0);\n}\n\nfunction sortKeysBy(obj, reference) {\n const result = {};\n for (const key in reference) {\n if (obj[key] !== undefined) {\n result[key] = obj[key];\n }\n }\n for (const key in obj) {\n if (result[key] === undefined) {\n result[key] = obj[key];\n }\n }\n return result;\n}\n/**\n * Format a MapLibre Style. Returns a stringified style with its keys\n * sorted in the same order as the reference style.\n *\n * The optional `space` argument is passed to\n * [`JSON.stringify`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify)\n * to generate formatted output.\n *\n * If `space` is unspecified, a default of `2` spaces will be used.\n *\n * @private\n * @param {Object} style a MapLibre Style\n * @param {number} [space] space argument to pass to `JSON.stringify`\n * @returns {string} stringified formatted JSON\n * @example\n * var fs = require('fs');\n * var format = require('maplibre-gl-style-spec').format;\n * var style = fs.readFileSync('./source.json', 'utf8');\n * fs.writeFileSync('./dest.json', format(style));\n * fs.writeFileSync('./dest.min.json', format(style, 0));\n */\nfunction format(style, space = 2) {\n style = sortKeysBy(style, v8Spec.$root);\n if (style.layers) {\n style.layers = style.layers.map((layer) => sortKeysBy(layer, v8Spec.layer));\n }\n return stringify(style, { indent: space });\n}\n\nfunction eachLayout(layer, callback) {\n for (const k in layer) {\n if (k.indexOf('layout') === 0) {\n callback(layer[k], k);\n }\n }\n}\nfunction eachPaint(layer, callback) {\n for (const k in layer) {\n if (k.indexOf('paint') === 0) {\n callback(layer[k], k);\n }\n }\n}\nfunction resolveConstant(style, value) {\n if (typeof value === 'string' && value[0] === '@') {\n return resolveConstant(style, style.constants[value]);\n }\n else {\n return value;\n }\n}\nfunction isFunction(value) {\n return Array.isArray(value.stops);\n}\nfunction renameProperty(obj, from, to) {\n obj[to] = obj[from];\n delete obj[from];\n}\nfunction migrateV8(style) {\n style.version = 8;\n // Rename properties, reverse coordinates in source and layers\n eachSource(style, (source) => {\n if (source.type === 'video' && source['url'] !== undefined) {\n renameProperty(source, 'url', 'urls');\n }\n if (source.type === 'video') {\n source.coordinates.forEach((coord) => {\n return coord.reverse();\n });\n }\n });\n eachLayer(style, (layer) => {\n eachLayout(layer, (layout) => {\n if (layout['symbol-min-distance'] !== undefined) {\n renameProperty(layout, 'symbol-min-distance', 'symbol-spacing');\n }\n });\n eachPaint(layer, (paint) => {\n if (paint['background-image'] !== undefined) {\n renameProperty(paint, 'background-image', 'background-pattern');\n }\n if (paint['line-image'] !== undefined) {\n renameProperty(paint, 'line-image', 'line-pattern');\n }\n if (paint['fill-image'] !== undefined) {\n renameProperty(paint, 'fill-image', 'fill-pattern');\n }\n });\n });\n // Inline Constants\n eachProperty(style, { paint: true, layout: true }, (property) => {\n const value = resolveConstant(style, property.value);\n if (isFunction(value)) {\n value.stops.forEach((stop) => {\n stop[1] = resolveConstant(style, stop[1]);\n });\n }\n property.set(value);\n });\n delete style['constants'];\n eachLayer(style, (layer) => {\n // get rid of text-max-size, icon-max-size\n // turn text-size, icon-size into layout properties\n // https://github.com/mapbox/mapbox-gl-style-spec/issues/255\n eachLayout(layer, (layout) => {\n delete layout['text-max-size'];\n delete layout['icon-max-size'];\n });\n eachPaint(layer, (paint) => {\n if (paint['text-size']) {\n if (!layer.layout)\n layer.layout = {};\n layer.layout['text-size'] = paint['text-size'];\n delete paint['text-size'];\n }\n if (paint['icon-size']) {\n if (!layer.layout)\n layer.layout = {};\n layer.layout['icon-size'] = paint['icon-size'];\n delete paint['icon-size'];\n }\n });\n });\n function migrateFontStack(font) {\n function splitAndTrim(string) {\n return string.split(',').map((s) => {\n return s.trim();\n });\n }\n if (Array.isArray(font)) {\n // Assume it's a previously migrated font-array.\n return font;\n }\n else if (typeof font === 'string') {\n return splitAndTrim(font);\n }\n else if (typeof font === 'object') {\n font.stops.forEach((stop) => {\n stop[1] = splitAndTrim(stop[1]);\n });\n return font;\n }\n else {\n throw new Error('unexpected font value');\n }\n }\n eachLayer(style, (layer) => {\n eachLayout(layer, (layout) => {\n if (layout['text-font']) {\n layout['text-font'] = migrateFontStack(layout['text-font']);\n }\n });\n });\n // Reverse order of symbol layers. This is an imperfect migration.\n //\n // The order of a symbol layer in the layers list affects two things:\n // - how it is drawn relative to other layers (like oneway arrows below bridges)\n // - the placement priority compared to other layers\n //\n // It's impossible to reverse the placement priority without breaking the draw order\n // in some cases. This migration only reverses the order of symbol layers that\n // are above all other types of layers.\n //\n // Symbol layers that are at the top of the map preserve their priority.\n // Symbol layers that are below another type (line, fill) of layer preserve their draw order.\n let firstSymbolLayer = 0;\n for (let i = style.layers.length - 1; i >= 0; i--) {\n const layer = style.layers[i];\n if (layer.type !== 'symbol') {\n firstSymbolLayer = i + 1;\n break;\n }\n }\n const symbolLayers = style.layers.splice(firstSymbolLayer);\n symbolLayers.reverse();\n style.layers = style.layers.concat(symbolLayers);\n return style;\n}\n\n/**\n * Migrate the given style object in place to use expressions. Specifically,\n * this will convert (a) \"stop\" functions, and (b) legacy filters to their\n * expression equivalents.\n * @param style The style object to migrate.\n * @returns The migrated style object.\n */\nfunction expressions(style) {\n const converted = [];\n eachLayer(style, (layer) => {\n if (layer.filter) {\n layer.filter = convertFilter(layer.filter);\n }\n });\n eachProperty(style, { paint: true, layout: true }, ({ path, value, reference, set }) => {\n if (isExpression(value))\n return;\n if (typeof value === 'object' && !Array.isArray(value)) {\n set(convertFunction(value, reference));\n converted.push(path.join('.'));\n }\n else if (reference.tokens && typeof value === 'string') {\n set(convertTokenString(value));\n }\n });\n return style;\n}\n\n/**\n * Migrate color style values to supported format.\n *\n * @param colorToMigrate Color value to migrate, could be a string or an expression.\n * @returns Color style value in supported format.\n */\nfunction migrateColors(colorToMigrate) {\n return JSON.parse(migrateHslColors(JSON.stringify(colorToMigrate)));\n}\n/**\n * Created to migrate from colors supported by the former CSS color parsing\n * library `csscolorparser` but not compliant with the CSS Color specification,\n * like `hsl(900, 0.15, 90%)`.\n *\n * @param colorToMigrate Serialized color style value.\n * @returns A serialized color style value in which all non-standard hsl color values\n * have been converted to a format that complies with the CSS Color specification.\n *\n * @example\n * migrateHslColors('\"hsl(900, 0.15, 90%)\"'); // returns '\"hsl(900, 15%, 90%)\"'\n * migrateHslColors('\"hsla(900, .15, .9)\"'); // returns '\"hsl(900, 15%, 90%)\"'\n * migrateHslColors('\"hsl(900, 15%, 90%)\"'); // returns '\"hsl(900, 15%, 90%)\"' - no changes\n */\nfunction migrateHslColors(colorToMigrate) {\n return colorToMigrate.replace(/\"hsla?\\((.+?)\\)\"/gi, (match, hslArgs) => {\n const argsMatch = hslArgs.match(/^(.+?)\\s*,\\s*(.+?)\\s*,\\s*(.+?)(?:\\s*,\\s*(.+))?$/i);\n if (argsMatch) {\n let [h, s, l, a] = argsMatch.slice(1);\n [s, l] = [s, l].map(v => v.endsWith('%') ? v : `${parseFloat(v) * 100}%`);\n return `\"hsl${typeof a === 'string' ? 'a' : ''}(${[h, s, l, a].filter(Boolean).join(',')})\"`;\n }\n return match;\n });\n}\n\n/**\n * Migrate a Mapbox/MapLibre GL Style to the latest version.\n *\n * @param style - a MapLibre Style\n * @returns a migrated style\n * @example\n * const fs = require('fs');\n * csont migrate = require('@maplibre/maplibre-gl-style-spec').migrate;\n * const style = fs.readFileSync('./style.json', 'utf8');\n * fs.writeFileSync('./style.json', JSON.stringify(migrate(style)));\n */\nfunction migrate(style) {\n let migrated = false;\n if (style.version === 7) {\n style = migrateV8(style);\n migrated = true;\n }\n if (style.version === 8) {\n migrated = !!expressions(style);\n migrated = true;\n }\n eachProperty(style, { paint: true, layout: true }, ({ value, reference, set }) => {\n if (reference.type === 'color') {\n set(migrateColors(value));\n }\n });\n if (!migrated) {\n throw new Error(`Cannot migrate from ${style.version}`);\n }\n return style;\n}\n\nconst v8 = v8Spec;\nconst expression = {\n StyleExpression,\n StylePropertyFunction,\n ZoomConstantExpression,\n ZoomDependentExpression,\n createExpression,\n createPropertyExpression,\n isExpression,\n isExpressionFilter,\n isZoomExpression,\n normalizePropertyExpression,\n};\nconst styleFunction = {\n convertFunction,\n createFunction,\n isFunction: isFunction$1\n};\nconst visit = { eachLayer, eachProperty, eachSource };\n\nexport { Color, ColorType, CompoundExpression, EvaluationContext, FormatExpression, Formatted, FormattedSection, FormattedType, Interpolate, Literal, NullType, Padding, ParsingError, ResolvedImage, Step, StyleExpression, StylePropertyFunction, ValidationError, VariableAnchorOffsetCollection, ZoomConstantExpression, ZoomDependentExpression, classifyRings, convertFilter, convertFunction, createExpression, createFunction, createPropertyExpression, derefLayers, diffStyles as diff, emptyStyle, expression, expressions$1 as expressions, createFilter as featureFilter, format, styleFunction as function, groupByLayout, interpolateFactory, interpolate as interpolates, isExpression, isFunction$1 as isFunction, isZoomExpression, v8Spec as latest, migrate, normalizePropertyExpression, supportsPropertyExpression, toString$1 as toString, typeOf, v8, validate, validateStyleMin, visit };\n//# sourceMappingURL=index.mjs.map\n","import {validateStyleMin} from '@maplibre/maplibre-gl-style-spec';\nimport {ErrorEvent} from '../util/evented';\n\nimport type {Evented} from '../util/evented';\n\ntype ValidationError = {\n message: string;\n line: number;\n identifier?: string;\n};\n\nexport type Validator = (a: any) => ReadonlyArray;\n\ntype ValidateStyle = {\n source: Validator;\n sprite: Validator;\n glyphs: Validator;\n layer: Validator;\n light: Validator;\n sky: Validator;\n terrain: Validator;\n filter: Validator;\n paintProperty: Validator;\n layoutProperty: Validator;\n (b: any, a?: any | null): ReadonlyArray;\n};\n\nexport const validateStyle = (validateStyleMin as unknown as ValidateStyle);\n\nexport const validateSource = validateStyle.source;\nexport const validateLight = validateStyle.light;\nexport const validateSky = validateStyle.sky;\nexport const validateTerrain = validateStyle.terrain;\nexport const validateFilter = validateStyle.filter;\nexport const validatePaintProperty = validateStyle.paintProperty;\nexport const validateLayoutProperty = validateStyle.layoutProperty;\n\nexport function emitValidationErrors(\n emitter: Evented,\n errors?: ReadonlyArray<{\n message: string;\n identifier?: string;\n }> | null\n): boolean {\n let hasErrors = false;\n if (errors && errors.length) {\n for (const error of errors) {\n emitter.fire(new ErrorEvent(new Error(error.message)));\n hasErrors = true;\n }\n }\n return hasErrors;\n}\n","/*\nThis file was copied from https://github.com/mapbox/grid-index and was\nmigrated from JavaScript to TypeScript.\n\nCopyright (c) 2016, Mapbox\n\nPermission to use, copy, modify, and/or distribute this software for any purpose\nwith or without fee is hereby granted, provided that the above copyright notice\nand this permission notice appear in all copies.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND\nFITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS\nOF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER\nTORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF\nTHIS SOFTWARE.\n*/\n\nconst NUM_PARAMS = 3;\n\nexport type SerializedGrid = {\n buffer: ArrayBuffer;\n};\n\nexport class TransferableGridIndex {\n cells: number[][];\n arrayBuffer: ArrayBuffer;\n d: number;\n keys: number[];\n bboxes: number[];\n n: number;\n extent: number;\n padding: number;\n scale: any;\n uid: number;\n min: number;\n max: number;\n\n constructor(extent: number | ArrayBuffer, n?: number, padding?: number) {\n const cells = this.cells = [];\n\n if (extent instanceof ArrayBuffer) {\n this.arrayBuffer = extent;\n const array = new Int32Array(this.arrayBuffer);\n extent = array[0];\n n = array[1];\n padding = array[2];\n\n this.d = n + 2 * padding;\n for (let k = 0; k < this.d * this.d; k++) {\n const start = array[NUM_PARAMS + k];\n const end = array[NUM_PARAMS + k + 1];\n cells.push(start === end ? null : array.subarray(start, end));\n }\n const keysOffset = array[NUM_PARAMS + cells.length];\n const bboxesOffset = array[NUM_PARAMS + cells.length + 1];\n this.keys = array.subarray(keysOffset, bboxesOffset) as any as number[];\n this.bboxes = array.subarray(bboxesOffset) as any as number[];\n\n this.insert = this._insertReadonly;\n\n } else {\n this.d = n + 2 * padding;\n for (let i = 0; i < this.d * this.d; i++) {\n cells.push([]);\n }\n this.keys = [];\n this.bboxes = [];\n }\n\n this.n = n;\n this.extent = extent;\n this.padding = padding;\n this.scale = n / extent;\n this.uid = 0;\n\n const p = (padding / n) * extent;\n this.min = -p;\n this.max = extent + p;\n }\n\n insert(key: number, x1: number, y1: number, x2: number, y2: number) {\n this._forEachCell(x1, y1, x2, y2, this._insertCell, this.uid++, undefined, undefined);\n this.keys.push(key);\n this.bboxes.push(x1);\n this.bboxes.push(y1);\n this.bboxes.push(x2);\n this.bboxes.push(y2);\n }\n\n _insertReadonly() {\n throw new Error('Cannot insert into a GridIndex created from an ArrayBuffer.');\n }\n\n _insertCell(x1: number, y1: number, x2: number, y2: number, cellIndex: number, uid: number) {\n this.cells[cellIndex].push(uid);\n }\n\n query(x1: number, y1: number, x2: number, y2: number, intersectionTest?: Function): number[] {\n const min = this.min;\n const max = this.max;\n if (x1 <= min && y1 <= min && max <= x2 && max <= y2 && !intersectionTest) {\n // We use `Array#slice` because `this.keys` may be a `Int32Array` and\n // some browsers (Safari and IE) do not support `TypedArray#slice`\n // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/TypedArray/slice#Browser_compatibility\n return Array.prototype.slice.call(this.keys);\n\n } else {\n const result = [];\n const seenUids = {};\n this._forEachCell(x1, y1, x2, y2, this._queryCell, result, seenUids, intersectionTest);\n return result;\n }\n }\n\n _queryCell(x1: number, y1: number, x2: number, y2:number, cellIndex:number, result, seenUids, intersectionTest: Function) {\n const cell = this.cells[cellIndex];\n if (cell !== null) {\n const keys = this.keys;\n const bboxes = this.bboxes;\n for (let u = 0; u < cell.length; u++) {\n const uid = cell[u];\n if (seenUids[uid] === undefined) {\n const offset = uid * 4;\n if (intersectionTest ?\n intersectionTest(bboxes[offset + 0], bboxes[offset + 1], bboxes[offset + 2], bboxes[offset + 3]) :\n ((x1 <= bboxes[offset + 2]) &&\n (y1 <= bboxes[offset + 3]) &&\n (x2 >= bboxes[offset + 0]) &&\n (y2 >= bboxes[offset + 1]))) {\n seenUids[uid] = true;\n result.push(keys[uid]);\n } else {\n seenUids[uid] = false;\n }\n }\n }\n }\n }\n\n _forEachCell(x1: number, y1: number, x2:number, y2:number, fn: Function, arg1, arg2, intersectionTest) {\n const cx1 = this._convertToCellCoord(x1);\n const cy1 = this._convertToCellCoord(y1);\n const cx2 = this._convertToCellCoord(x2);\n const cy2 = this._convertToCellCoord(y2);\n for (let x = cx1; x <= cx2; x++) {\n for (let y = cy1; y <= cy2; y++) {\n const cellIndex = this.d * y + x;\n if (intersectionTest && !intersectionTest(\n this._convertFromCellCoord(x),\n this._convertFromCellCoord(y),\n this._convertFromCellCoord(x + 1),\n this._convertFromCellCoord(y + 1))) continue;\n if (fn.call(this, x1, y1, x2, y2, cellIndex, arg1, arg2, intersectionTest)) return;\n }\n }\n }\n\n _convertFromCellCoord (x) {\n return (x - this.padding) / this.scale;\n }\n\n _convertToCellCoord(x) {\n return Math.max(0, Math.min(this.d - 1, Math.floor(x * this.scale) + this.padding));\n }\n\n toArrayBuffer(): ArrayBuffer {\n if (this.arrayBuffer) return this.arrayBuffer;\n\n const cells = this.cells;\n\n const metadataLength = NUM_PARAMS + this.cells.length + 1 + 1;\n let totalCellLength = 0;\n for (let i = 0; i < this.cells.length; i++) {\n totalCellLength += this.cells[i].length;\n }\n\n const array = new Int32Array(metadataLength + totalCellLength + this.keys.length + this.bboxes.length);\n array[0] = this.extent;\n array[1] = this.n;\n array[2] = this.padding;\n\n let offset = metadataLength;\n for (let k = 0; k < cells.length; k++) {\n const cell = cells[k];\n array[NUM_PARAMS + k] = offset;\n array.set(cell, offset);\n offset += cell.length;\n }\n\n array[NUM_PARAMS + cells.length] = offset;\n array.set(this.keys, offset);\n offset += this.keys.length;\n\n array[NUM_PARAMS + cells.length + 1] = offset;\n array.set(this.bboxes, offset);\n offset += this.bboxes.length;\n\n return array.buffer;\n }\n\n public static serialize(grid: TransferableGridIndex, transferables?: Array): SerializedGrid {\n const buffer = grid.toArrayBuffer();\n if (transferables) {\n transferables.push(buffer);\n }\n return {buffer};\n }\n\n public static deserialize(serialized: SerializedGrid): TransferableGridIndex {\n return new TransferableGridIndex(serialized.buffer);\n }\n}\n","import {TransferableGridIndex} from './transferable_grid_index';\nimport {Color, CompoundExpression, expressions, ResolvedImage, StylePropertyFunction,\n StyleExpression, ZoomDependentExpression, ZoomConstantExpression} from '@maplibre/maplibre-gl-style-spec';\nimport {AJAXError} from './ajax';\nimport {isImageBitmap} from './util';\n\n/**\n * A class that is serialized to and json, that can be constructed back to the original class in the worker or in the main thread\n */\ntype SerializedObject = {\n [_: string]: S;\n};\n\n/**\n * All the possible values that can be serialized and sent to and from the worker\n */\nexport type Serialized = null | void | boolean | number | string | Boolean | Number | String | Date | RegExp | ArrayBuffer | ArrayBufferView | ImageData | ImageBitmap | Blob | Array | SerializedObject;\n\ntype Registry = {\n [_: string]: {\n klass: {\n new (...args: any): any;\n deserialize?: (input: Serialized) => unknown;\n serialize?: (input: any, transferables: Transferable[]) => SerializedObject;\n };\n omit: ReadonlyArray;\n shallow: ReadonlyArray;\n };\n};\n\n/**\n * Register options\n */\ntype RegisterOptions = {\n /**\n * List of properties to omit from serialization (e.g., cached/computed properties)\n */\n omit?: ReadonlyArray;\n /**\n * List of properties that should be serialized by a simple shallow copy, rather than by a recursive call to serialize().\n */\n shallow?: ReadonlyArray;\n};\n\nconst registry: Registry = {};\n\n/**\n * Register the given class as serializable.\n *\n * @param options - the registration options\n */\nexport function register(\n name: string,\n klass: {\n new (...args: any): T;\n },\n options: RegisterOptions = {}\n) {\n if (registry[name]) throw new Error(`${name} is already registered.`);\n ((Object.defineProperty as any))(klass, '_classRegistryKey', {\n value: name,\n writeable: false\n });\n registry[name] = {\n klass,\n omit: options.omit as ReadonlyArray || [],\n shallow: options.shallow as ReadonlyArray || []\n };\n}\n\nregister('Object', Object);\nregister('TransferableGridIndex', TransferableGridIndex);\n\nregister('Color', Color);\nregister('Error', Error);\nregister('AJAXError', AJAXError);\nregister('ResolvedImage', ResolvedImage);\n\nregister('StylePropertyFunction', StylePropertyFunction);\nregister('StyleExpression', StyleExpression, {omit: ['_evaluator']});\n\nregister('ZoomDependentExpression', ZoomDependentExpression);\nregister('ZoomConstantExpression', ZoomConstantExpression);\nregister('CompoundExpression', CompoundExpression, {omit: ['_evaluate']});\nfor (const name in expressions) {\n if ((expressions[name] as any)._classRegistryKey) continue;\n register(`Expression_${name}`, expressions[name]);\n}\n\nfunction isArrayBuffer(value: any): value is ArrayBuffer {\n return value && typeof ArrayBuffer !== 'undefined' &&\n (value instanceof ArrayBuffer || (value.constructor && value.constructor.name === 'ArrayBuffer'));\n}\n\nfunction getClassRegistryKey(input: Object|SerializedObject): string {\n const klass = (input.constructor as any);\n return (input as SerializedObject).$name || klass._classRegistryKey;\n}\n\nfunction isRegistered(input: unknown): boolean {\n if (input === null || typeof input !== 'object') {\n return false;\n }\n const classRegistryKey = getClassRegistryKey(input);\n if (classRegistryKey && classRegistryKey !== 'Object') {\n return true;\n }\n return false;\n}\n\nfunction isSerializeHandledByBuiltin(input: unknown) {\n return (!isRegistered(input) && (\n input === null ||\n input === undefined ||\n typeof input === 'boolean' ||\n typeof input === 'number' ||\n typeof input === 'string' ||\n input instanceof Boolean ||\n input instanceof Number ||\n input instanceof String ||\n input instanceof Date ||\n input instanceof RegExp ||\n input instanceof Blob ||\n input instanceof Error ||\n isArrayBuffer(input) ||\n isImageBitmap(input) ||\n ArrayBuffer.isView(input) ||\n input instanceof ImageData)\n );\n}\n\n/**\n * Serialize the given object for transfer to or from a web worker.\n *\n * For non-builtin types, recursively serialize each property (possibly\n * omitting certain properties - see register()), and package the result along\n * with the constructor's `name` so that the appropriate constructor can be\n * looked up in `deserialize()`.\n *\n * If a `transferables` array is provided, add any transferable objects (i.e.,\n * any ArrayBuffers or ArrayBuffer views) to the list. (If a copy is needed,\n * this should happen in the client code, before using serialize().)\n */\nexport function serialize(input: unknown, transferables?: Array | null): Serialized {\n if (isSerializeHandledByBuiltin(input)) {\n if (isArrayBuffer(input) || isImageBitmap(input)) {\n if (transferables) {\n transferables.push(input);\n }\n }\n if (ArrayBuffer.isView(input)) {\n const view = input;\n if (transferables) {\n transferables.push(view.buffer);\n }\n }\n if (input instanceof ImageData) {\n if (transferables) {\n transferables.push(input.data.buffer);\n }\n }\n return input;\n }\n\n if (Array.isArray(input)) {\n const serialized: Array = [];\n for (const item of input) {\n serialized.push(serialize(item, transferables));\n }\n return serialized;\n }\n\n if (typeof input !== 'object') {\n throw new Error(`can't serialize object of type ${typeof input}`);\n }\n const classRegistryKey = getClassRegistryKey(input);\n if (!classRegistryKey) {\n throw new Error(`can't serialize object of unregistered class ${input.constructor.name}`);\n }\n if (!registry[classRegistryKey]) throw new Error(`${classRegistryKey} is not registered.`);\n const {klass} = registry[classRegistryKey];\n const properties: SerializedObject = klass.serialize ?\n // (Temporary workaround) allow a class to provide static\n // `serialize()` and `deserialize()` methods to bypass the generic\n // approach.\n // This temporary workaround lets us use the generic serialization\n // approach for objects whose members include instances of dynamic\n // StructArray types. Once we refactor StructArray to be static,\n // we can remove this complexity.\n (klass.serialize(input, transferables) as SerializedObject) : {};\n\n if (!klass.serialize) {\n for (const key in input) {\n if (!input.hasOwnProperty(key)) continue; // eslint-disable-line no-prototype-builtins\n if (registry[classRegistryKey].omit.indexOf(key) >= 0) continue;\n const property = input[key];\n properties[key] = registry[classRegistryKey].shallow.indexOf(key) >= 0 ?\n property :\n serialize(property, transferables);\n }\n if (input instanceof Error) {\n properties.message = input.message;\n }\n } else {\n if (transferables && properties === transferables[transferables.length - 1]) {\n throw new Error('statically serialized object won\\'t survive transfer of $name property');\n }\n }\n\n if (properties.$name) {\n throw new Error('$name property is reserved for worker serialization logic.');\n }\n if (classRegistryKey !== 'Object') {\n properties.$name = classRegistryKey;\n }\n\n return properties;\n}\n\nexport function deserialize(input: Serialized): unknown {\n if (isSerializeHandledByBuiltin(input)) {\n return input;\n }\n\n if (Array.isArray(input)) {\n return input.map(deserialize);\n }\n\n if (typeof input !== 'object') {\n throw new Error(`can't deserialize object of type ${typeof input}`);\n }\n const classRegistryKey = getClassRegistryKey(input) || 'Object';\n if (!registry[classRegistryKey]) {\n throw new Error(`can't deserialize unregistered class ${classRegistryKey}`);\n }\n const {klass} = registry[classRegistryKey];\n if (!klass) {\n throw new Error(`can't deserialize unregistered class ${classRegistryKey}`);\n }\n\n if (klass.deserialize) {\n return klass.deserialize(input);\n }\n\n const result = Object.create(klass.prototype);\n\n for (const key of Object.keys(input)) {\n if (key === '$name') continue;\n const value = (input as SerializedObject)[key];\n result[key] = registry[classRegistryKey].shallow.indexOf(key) >= 0 ? value : deserialize(value);\n }\n\n return result;\n}\n","export class ZoomHistory {\n lastZoom: number;\n lastFloorZoom: number;\n lastIntegerZoom: number;\n lastIntegerZoomTime: number;\n first: boolean;\n\n constructor() {\n this.first = true;\n }\n\n update(z: number, now: number) {\n const floorZ = Math.floor(z);\n\n if (this.first) {\n this.first = false;\n this.lastIntegerZoom = floorZ;\n this.lastIntegerZoomTime = 0;\n this.lastZoom = z;\n this.lastFloorZoom = floorZ;\n return true;\n }\n\n if (this.lastFloorZoom > floorZ) {\n this.lastIntegerZoom = floorZ + 1;\n this.lastIntegerZoomTime = now;\n } else if (this.lastFloorZoom < floorZ) {\n this.lastIntegerZoom = floorZ;\n this.lastIntegerZoomTime = now;\n }\n\n if (z !== this.lastZoom) {\n this.lastZoom = z;\n this.lastFloorZoom = floorZ;\n return true;\n }\n\n return false;\n }\n}\n","// The following table comes from .\n// Keep it synchronized with .\n\ntype UnicodeBlockLookup = {[key: string]: (char: number) => boolean};\n\nexport const unicodeBlockLookup: UnicodeBlockLookup = {\n // 'Basic Latin': (char) => char >= 0x0000 && char <= 0x007F,\n 'Latin-1 Supplement': (char) => char >= 0x0080 && char <= 0x00FF,\n // 'Latin Extended-A': (char) => char >= 0x0100 && char <= 0x017F,\n // 'Latin Extended-B': (char) => char >= 0x0180 && char <= 0x024F,\n // 'IPA Extensions': (char) => char >= 0x0250 && char <= 0x02AF,\n // 'Spacing Modifier Letters': (char) => char >= 0x02B0 && char <= 0x02FF,\n // 'Combining Diacritical Marks': (char) => char >= 0x0300 && char <= 0x036F,\n // 'Greek and Coptic': (char) => char >= 0x0370 && char <= 0x03FF,\n // 'Cyrillic': (char) => char >= 0x0400 && char <= 0x04FF,\n // 'Cyrillic Supplement': (char) => char >= 0x0500 && char <= 0x052F,\n // 'Armenian': (char) => char >= 0x0530 && char <= 0x058F,\n //'Hebrew': (char) => char >= 0x0590 && char <= 0x05FF,\n // 'Arabic': (char) => char >= 0x0600 && char <= 0x06FF,\n //'Syriac': (char) => char >= 0x0700 && char <= 0x074F,\n // 'Arabic Supplement': (char) => char >= 0x0750 && char <= 0x077F,\n // 'Thaana': (char) => char >= 0x0780 && char <= 0x07BF,\n // 'NKo': (char) => char >= 0x07C0 && char <= 0x07FF,\n // 'Samaritan': (char) => char >= 0x0800 && char <= 0x083F,\n // 'Mandaic': (char) => char >= 0x0840 && char <= 0x085F,\n // 'Syriac Supplement': (char) => char >= 0x0860 && char <= 0x086F,\n // 'Arabic Extended-B': (char) => char >= 0x0870 && char <= 0x089F,\n // 'Arabic Extended-A': (char) => char >= 0x08A0 && char <= 0x08FF,\n // 'Devanagari': (char) => char >= 0x0900 && char <= 0x097F,\n // 'Bengali': (char) => char >= 0x0980 && char <= 0x09FF,\n // 'Gurmukhi': (char) => char >= 0x0A00 && char <= 0x0A7F,\n // 'Gujarati': (char) => char >= 0x0A80 && char <= 0x0AFF,\n // 'Oriya': (char) => char >= 0x0B00 && char <= 0x0B7F,\n // 'Tamil': (char) => char >= 0x0B80 && char <= 0x0BFF,\n // 'Telugu': (char) => char >= 0x0C00 && char <= 0x0C7F,\n // 'Kannada': (char) => char >= 0x0C80 && char <= 0x0CFF,\n // 'Malayalam': (char) => char >= 0x0D00 && char <= 0x0D7F,\n // 'Sinhala': (char) => char >= 0x0D80 && char <= 0x0DFF,\n // 'Thai': (char) => char >= 0x0E00 && char <= 0x0E7F,\n // 'Lao': (char) => char >= 0x0E80 && char <= 0x0EFF,\n // 'Tibetan': (char) => char >= 0x0F00 && char <= 0x0FFF,\n // 'Myanmar': (char) => char >= 0x1000 && char <= 0x109F,\n // 'Georgian': (char) => char >= 0x10A0 && char <= 0x10FF,\n 'Hangul Jamo': (char) => char >= 0x1100 && char <= 0x11FF,\n // 'Ethiopic': (char) => char >= 0x1200 && char <= 0x137F,\n // 'Ethiopic Supplement': (char) => char >= 0x1380 && char <= 0x139F,\n // 'Cherokee': (char) => char >= 0x13A0 && char <= 0x13FF,\n // 'Unified Canadian Aboriginal Syllabics': (char) => char >= 0x1400 && char <= 0x167F,\n // 'Ogham': (char) => char >= 0x1680 && char <= 0x169F,\n // 'Runic': (char) => char >= 0x16A0 && char <= 0x16FF,\n // 'Tagalog': (char) => char >= 0x1700 && char <= 0x171F,\n // 'Hanunoo': (char) => char >= 0x1720 && char <= 0x173F,\n // 'Buhid': (char) => char >= 0x1740 && char <= 0x175F,\n // 'Tagbanwa': (char) => char >= 0x1760 && char <= 0x177F,\n 'Khmer': (char) => char >= 0x1780 && char <= 0x17FF,\n // 'Mongolian': (char) => char >= 0x1800 && char <= 0x18AF,\n // 'Unified Canadian Aboriginal Syllabics Extended': (char) => char >= 0x18B0 && char <= 0x18FF,\n // 'Limbu': (char) => char >= 0x1900 && char <= 0x194F,\n // 'Tai Le': (char) => char >= 0x1950 && char <= 0x197F,\n // 'New Tai Lue': (char) => char >= 0x1980 && char <= 0x19DF,\n // 'Khmer Symbols': (char) => char >= 0x19E0 && char <= 0x19FF,\n // 'Buginese': (char) => char >= 0x1A00 && char <= 0x1A1F,\n // 'Tai Tham': (char) => char >= 0x1A20 && char <= 0x1AAF,\n // 'Combining Diacritical Marks Extended': (char) => char >= 0x1AB0 && char <= 0x1AFF,\n // 'Balinese': (char) => char >= 0x1B00 && char <= 0x1B7F,\n // 'Sundanese': (char) => char >= 0x1B80 && char <= 0x1BBF,\n // 'Batak': (char) => char >= 0x1BC0 && char <= 0x1BFF,\n // 'Lepcha': (char) => char >= 0x1C00 && char <= 0x1C4F,\n // 'Ol Chiki': (char) => char >= 0x1C50 && char <= 0x1C7F,\n // 'Cyrillic Extended-C': (char) => char >= 0x1C80 && char <= 0x1C8F,\n // 'Georgian Extended': (char) => char >= 0x1C90 && char <= 0x1CBF,\n // 'Sundanese Supplement': (char) => char >= 0x1CC0 && char <= 0x1CCF,\n // 'Vedic Extensions': (char) => char >= 0x1CD0 && char <= 0x1CFF,\n // 'Phonetic Extensions': (char) => char >= 0x1D00 && char <= 0x1D7F,\n // 'Phonetic Extensions Supplement': (char) => char >= 0x1D80 && char <= 0x1DBF,\n // 'Combining Diacritical Marks Supplement': (char) => char >= 0x1DC0 && char <= 0x1DFF,\n // 'Latin Extended Additional': (char) => char >= 0x1E00 && char <= 0x1EFF,\n // 'Greek Extended': (char) => char >= 0x1F00 && char <= 0x1FFF,\n 'General Punctuation': (char) => char >= 0x2000 && char <= 0x206F,\n // 'Superscripts and Subscripts': (char) => char >= 0x2070 && char <= 0x209F,\n // 'Currency Symbols': (char) => char >= 0x20A0 && char <= 0x20CF,\n // 'Combining Diacritical Marks for Symbols': (char) => char >= 0x20D0 && char <= 0x20FF,\n 'Letterlike Symbols': (char) => char >= 0x2100 && char <= 0x214F,\n 'Number Forms': (char) => char >= 0x2150 && char <= 0x218F,\n // 'Arrows': (char) => char >= 0x2190 && char <= 0x21FF,\n // 'Mathematical Operators': (char) => char >= 0x2200 && char <= 0x22FF,\n 'Miscellaneous Technical': (char) => char >= 0x2300 && char <= 0x23FF,\n 'Control Pictures': (char) => char >= 0x2400 && char <= 0x243F,\n 'Optical Character Recognition': (char) => char >= 0x2440 && char <= 0x245F,\n 'Enclosed Alphanumerics': (char) => char >= 0x2460 && char <= 0x24FF,\n // 'Box Drawing': (char) => char >= 0x2500 && char <= 0x257F,\n // 'Block Elements': (char) => char >= 0x2580 && char <= 0x259F,\n 'Geometric Shapes': (char) => char >= 0x25A0 && char <= 0x25FF,\n 'Miscellaneous Symbols': (char) => char >= 0x2600 && char <= 0x26FF,\n // 'Dingbats': (char) => char >= 0x2700 && char <= 0x27BF,\n // 'Miscellaneous Mathematical Symbols-A': (char) => char >= 0x27C0 && char <= 0x27EF,\n // 'Supplemental Arrows-A': (char) => char >= 0x27F0 && char <= 0x27FF,\n // 'Braille Patterns': (char) => char >= 0x2800 && char <= 0x28FF,\n // 'Supplemental Arrows-B': (char) => char >= 0x2900 && char <= 0x297F,\n // 'Miscellaneous Mathematical Symbols-B': (char) => char >= 0x2980 && char <= 0x29FF,\n // 'Supplemental Mathematical Operators': (char) => char >= 0x2A00 && char <= 0x2AFF,\n 'Miscellaneous Symbols and Arrows': (char) => char >= 0x2B00 && char <= 0x2BFF,\n // 'Glagolitic': (char) => char >= 0x2C00 && char <= 0x2C5F,\n // 'Latin Extended-C': (char) => char >= 0x2C60 && char <= 0x2C7F,\n // 'Coptic': (char) => char >= 0x2C80 && char <= 0x2CFF,\n // 'Georgian Supplement': (char) => char >= 0x2D00 && char <= 0x2D2F,\n // 'Tifinagh': (char) => char >= 0x2D30 && char <= 0x2D7F,\n // 'Ethiopic Extended': (char) => char >= 0x2D80 && char <= 0x2DDF,\n // 'Cyrillic Extended-A': (char) => char >= 0x2DE0 && char <= 0x2DFF,\n // 'Supplemental Punctuation': (char) => char >= 0x2E00 && char <= 0x2E7F,\n // 'CJK Radicals Supplement': (char) => char >= 0x2E80 && char <= 0x2EFF,\n // 'Kangxi Radicals': (char) => char >= 0x2F00 && char <= 0x2FDF,\n 'Ideographic Description Characters': (char) => char >= 0x2FF0 && char <= 0x2FFF,\n 'CJK Symbols and Punctuation': (char) => char >= 0x3000 && char <= 0x303F,\n // 'Hiragana': (char) => char >= 0x3040 && char <= 0x309F,\n 'Katakana': (char) => char >= 0x30A0 && char <= 0x30FF,\n // 'Bopomofo': (char) => char >= 0x3100 && char <= 0x312F,\n // 'Hangul Compatibility Jamo': (char) => char >= 0x3130 && char <= 0x318F,\n 'Kanbun': (char) => char >= 0x3190 && char <= 0x319F,\n // 'Bopomofo Extended': (char) => char >= 0x31A0 && char <= 0x31BF,\n 'CJK Strokes': (char) => char >= 0x31C0 && char <= 0x31EF,\n // 'Katakana Phonetic Extensions': (char) => char >= 0x31F0 && char <= 0x31FF,\n 'Enclosed CJK Letters and Months': (char) => char >= 0x3200 && char <= 0x32FF,\n 'CJK Compatibility': (char) => char >= 0x3300 && char <= 0x33FF,\n // 'CJK Unified Ideographs Extension A': (char) => char >= 0x3400 && char <= 0x4DBF,\n 'Yijing Hexagram Symbols': (char) => char >= 0x4DC0 && char <= 0x4DFF,\n // 'CJK Unified Ideographs': (char) => char >= 0x4E00 && char <= 0x9FFF,\n // 'Yi Syllables': (char) => char >= 0xA000 && char <= 0xA48F,\n // 'Yi Radicals': (char) => char >= 0xA490 && char <= 0xA4CF,\n // 'Lisu': (char) => char >= 0xA4D0 && char <= 0xA4FF,\n // 'Vai': (char) => char >= 0xA500 && char <= 0xA63F,\n // 'Cyrillic Extended-B': (char) => char >= 0xA640 && char <= 0xA69F,\n // 'Bamum': (char) => char >= 0xA6A0 && char <= 0xA6FF,\n // 'Modifier Tone Letters': (char) => char >= 0xA700 && char <= 0xA71F,\n // 'Latin Extended-D': (char) => char >= 0xA720 && char <= 0xA7FF,\n // 'Syloti Nagri': (char) => char >= 0xA800 && char <= 0xA82F,\n // 'Common Indic Number Forms': (char) => char >= 0xA830 && char <= 0xA83F,\n // 'Phags-pa': (char) => char >= 0xA840 && char <= 0xA87F,\n // 'Saurashtra': (char) => char >= 0xA880 && char <= 0xA8DF,\n // 'Devanagari Extended': (char) => char >= 0xA8E0 && char <= 0xA8FF,\n // 'Kayah Li': (char) => char >= 0xA900 && char <= 0xA92F,\n // 'Rejang': (char) => char >= 0xA930 && char <= 0xA95F,\n // 'Hangul Jamo Extended-A': (char) => char >= 0xA960 && char <= 0xA97F,\n // 'Javanese': (char) => char >= 0xA980 && char <= 0xA9DF,\n // 'Myanmar Extended-B': (char) => char >= 0xA9E0 && char <= 0xA9FF,\n // 'Cham': (char) => char >= 0xAA00 && char <= 0xAA5F,\n // 'Myanmar Extended-A': (char) => char >= 0xAA60 && char <= 0xAA7F,\n // 'Tai Viet': (char) => char >= 0xAA80 && char <= 0xAADF,\n // 'Meetei Mayek Extensions': (char) => char >= 0xAAE0 && char <= 0xAAFF,\n // 'Ethiopic Extended-A': (char) => char >= 0xAB00 && char <= 0xAB2F,\n // 'Latin Extended-E': (char) => char >= 0xAB30 && char <= 0xAB6F,\n // 'Cherokee Supplement': (char) => char >= 0xAB70 && char <= 0xABBF,\n // 'Meetei Mayek': (char) => char >= 0xABC0 && char <= 0xABFF,\n // 'Hangul Syllables': (char) => char >= 0xAC00 && char <= 0xD7AF,\n // 'Hangul Jamo Extended-B': (char) => char >= 0xD7B0 && char <= 0xD7FF,\n // 'High Surrogates': (char) => char >= 0xD800 && char <= 0xDB7F,\n // 'High Private Use Surrogates': (char) => char >= 0xDB80 && char <= 0xDBFF,\n // 'Low Surrogates': (char) => char >= 0xDC00 && char <= 0xDFFF,\n 'Private Use Area': (char) => char >= 0xE000 && char <= 0xF8FF,\n // 'CJK Compatibility Ideographs': (char) => char >= 0xF900 && char <= 0xFAFF,\n // 'Alphabetic Presentation Forms': (char) => char >= 0xFB00 && char <= 0xFB4F,\n // 'Arabic Presentation Forms-A': (char) => char >= 0xFB50 && char <= 0xFDFF,\n // 'Variation Selectors': (char) => char >= 0xFE00 && char <= 0xFE0F,\n 'Vertical Forms': (char) => char >= 0xFE10 && char <= 0xFE1F,\n // 'Combining Half Marks': (char) => char >= 0xFE20 && char <= 0xFE2F,\n 'CJK Compatibility Forms': (char) => char >= 0xFE30 && char <= 0xFE4F,\n 'Small Form Variants': (char) => char >= 0xFE50 && char <= 0xFE6F,\n // 'Arabic Presentation Forms-B': (char) => char >= 0xFE70 && char <= 0xFEFF,\n 'Halfwidth and Fullwidth Forms': (char) => char >= 0xFF00 && char <= 0xFFEF\n // 'Specials': (char) => char >= 0xFFF0 && char <= 0xFFFF,\n // 'Linear B Syllabary': (char) => char >= 0x10000 && char <= 0x1007F,\n // 'Linear B Ideograms': (char) => char >= 0x10080 && char <= 0x100FF,\n // 'Aegean Numbers': (char) => char >= 0x10100 && char <= 0x1013F,\n // 'Ancient Greek Numbers': (char) => char >= 0x10140 && char <= 0x1018F,\n // 'Ancient Symbols': (char) => char >= 0x10190 && char <= 0x101CF,\n // 'Phaistos Disc': (char) => char >= 0x101D0 && char <= 0x101FF,\n // 'Lycian': (char) => char >= 0x10280 && char <= 0x1029F,\n // 'Carian': (char) => char >= 0x102A0 && char <= 0x102DF,\n // 'Coptic Epact Numbers': (char) => char >= 0x102E0 && char <= 0x102FF,\n // 'Old Italic': (char) => char >= 0x10300 && char <= 0x1032F,\n // 'Gothic': (char) => char >= 0x10330 && char <= 0x1034F,\n // 'Old Permic': (char) => char >= 0x10350 && char <= 0x1037F,\n // 'Ugaritic': (char) => char >= 0x10380 && char <= 0x1039F,\n // 'Old Persian': (char) => char >= 0x103A0 && char <= 0x103DF,\n // 'Deseret': (char) => char >= 0x10400 && char <= 0x1044F,\n // 'Shavian': (char) => char >= 0x10450 && char <= 0x1047F,\n // 'Osmanya': (char) => char >= 0x10480 && char <= 0x104AF,\n // 'Osage': (char) => char >= 0x104B0 && char <= 0x104FF,\n // 'Elbasan': (char) => char >= 0x10500 && char <= 0x1052F,\n // 'Caucasian Albanian': (char) => char >= 0x10530 && char <= 0x1056F,\n // 'Vithkuqi': (char) => char >= 0x10570 && char <= 0x105BF,\n // 'Todhri': (char) => char >= 0x105C0 && char <= 0x105FF,\n // 'Linear A': (char) => char >= 0x10600 && char <= 0x1077F,\n // 'Latin Extended-F': (char) => char >= 0x10780 && char <= 0x107BF,\n // 'Cypriot Syllabary': (char) => char >= 0x10800 && char <= 0x1083F,\n // 'Imperial Aramaic': (char) => char >= 0x10840 && char <= 0x1085F,\n // 'Palmyrene': (char) => char >= 0x10860 && char <= 0x1087F,\n // 'Nabataean': (char) => char >= 0x10880 && char <= 0x108AF,\n // 'Hatran': (char) => char >= 0x108E0 && char <= 0x108FF,\n // 'Phoenician': (char) => char >= 0x10900 && char <= 0x1091F,\n // 'Lydian': (char) => char >= 0x10920 && char <= 0x1093F,\n // 'Meroitic Hieroglyphs': (char) => char >= 0x10980 && char <= 0x1099F,\n // 'Meroitic Cursive': (char) => char >= 0x109A0 && char <= 0x109FF,\n // 'Kharoshthi': (char) => char >= 0x10A00 && char <= 0x10A5F,\n // 'Old South Arabian': (char) => char >= 0x10A60 && char <= 0x10A7F,\n // 'Old North Arabian': (char) => char >= 0x10A80 && char <= 0x10A9F,\n // 'Manichaean': (char) => char >= 0x10AC0 && char <= 0x10AFF,\n // 'Avestan': (char) => char >= 0x10B00 && char <= 0x10B3F,\n // 'Inscriptional Parthian': (char) => char >= 0x10B40 && char <= 0x10B5F,\n // 'Inscriptional Pahlavi': (char) => char >= 0x10B60 && char <= 0x10B7F,\n // 'Psalter Pahlavi': (char) => char >= 0x10B80 && char <= 0x10BAF,\n // 'Old Turkic': (char) => char >= 0x10C00 && char <= 0x10C4F,\n // 'Old Hungarian': (char) => char >= 0x10C80 && char <= 0x10CFF,\n // 'Hanifi Rohingya': (char) => char >= 0x10D00 && char <= 0x10D3F,\n // 'Garay': (char) => char >= 0x10D40 && char <= 0x10D8F,\n // 'Rumi Numeral Symbols': (char) => char >= 0x10E60 && char <= 0x10E7F,\n // 'Yezidi': (char) => char >= 0x10E80 && char <= 0x10EBF,\n // 'Arabic Extended-C': (char) => char >= 0x10EC0 && char <= 0x10EFF,\n // 'Old Sogdian': (char) => char >= 0x10F00 && char <= 0x10F2F,\n // 'Sogdian': (char) => char >= 0x10F30 && char <= 0x10F6F,\n // 'Old Uyghur': (char) => char >= 0x10F70 && char <= 0x10FAF,\n // 'Chorasmian': (char) => char >= 0x10FB0 && char <= 0x10FDF,\n // 'Elymaic': (char) => char >= 0x10FE0 && char <= 0x10FFF,\n // 'Brahmi': (char) => char >= 0x11000 && char <= 0x1107F,\n // 'Kaithi': (char) => char >= 0x11080 && char <= 0x110CF,\n // 'Sora Sompeng': (char) => char >= 0x110D0 && char <= 0x110FF,\n // 'Chakma': (char) => char >= 0x11100 && char <= 0x1114F,\n // 'Mahajani': (char) => char >= 0x11150 && char <= 0x1117F,\n // 'Sharada': (char) => char >= 0x11180 && char <= 0x111DF,\n // 'Sinhala Archaic Numbers': (char) => char >= 0x111E0 && char <= 0x111FF,\n // 'Khojki': (char) => char >= 0x11200 && char <= 0x1124F,\n // 'Multani': (char) => char >= 0x11280 && char <= 0x112AF,\n // 'Khudawadi': (char) => char >= 0x112B0 && char <= 0x112FF,\n // 'Grantha': (char) => char >= 0x11300 && char <= 0x1137F,\n // 'Tulu-Tigalari': (char) => char >= 0x11380 && char <= 0x113FF,\n // 'Newa': (char) => char >= 0x11400 && char <= 0x1147F,\n // 'Tirhuta': (char) => char >= 0x11480 && char <= 0x114DF,\n // 'Siddham': (char) => char >= 0x11580 && char <= 0x115FF,\n // 'Modi': (char) => char >= 0x11600 && char <= 0x1165F,\n // 'Mongolian Supplement': (char) => char >= 0x11660 && char <= 0x1167F,\n // 'Takri': (char) => char >= 0x11680 && char <= 0x116CF,\n // 'Myanmar Extended-C': (char) => char >= 0x116D0 && char <= 0x116FF,\n // 'Ahom': (char) => char >= 0x11700 && char <= 0x1174F,\n // 'Dogra': (char) => char >= 0x11800 && char <= 0x1184F,\n // 'Warang Citi': (char) => char >= 0x118A0 && char <= 0x118FF,\n // 'Dives Akuru': (char) => char >= 0x11900 && char <= 0x1195F,\n // 'Nandinagari': (char) => char >= 0x119A0 && char <= 0x119FF,\n // 'Zanabazar Square': (char) => char >= 0x11A00 && char <= 0x11A4F,\n // 'Soyombo': (char) => char >= 0x11A50 && char <= 0x11AAF,\n // 'Unified Canadian Aboriginal Syllabics Extended-A': (char) => char >= 0x11AB0 && char <= 0x11ABF,\n // 'Pau Cin Hau': (char) => char >= 0x11AC0 && char <= 0x11AFF,\n // 'Devanagari Extended-A': (char) => char >= 0x11B00 && char <= 0x11B5F,\n // 'Sunuwar': (char) => char >= 0x11BC0 && char <= 0x11BFF,\n // 'Bhaiksuki': (char) => char >= 0x11C00 && char <= 0x11C6F,\n // 'Marchen': (char) => char >= 0x11C70 && char <= 0x11CBF,\n // 'Masaram Gondi': (char) => char >= 0x11D00 && char <= 0x11D5F,\n // 'Gunjala Gondi': (char) => char >= 0x11D60 && char <= 0x11DAF,\n // 'Makasar': (char) => char >= 0x11EE0 && char <= 0x11EFF,\n // 'Kawi': (char) => char >= 0x11F00 && char <= 0x11F5F,\n // 'Lisu Supplement': (char) => char >= 0x11FB0 && char <= 0x11FBF,\n // 'Tamil Supplement': (char) => char >= 0x11FC0 && char <= 0x11FFF,\n // 'Cuneiform': (char) => char >= 0x12000 && char <= 0x123FF,\n // 'Cuneiform Numbers and Punctuation': (char) => char >= 0x12400 && char <= 0x1247F,\n // 'Early Dynastic Cuneiform': (char) => char >= 0x12480 && char <= 0x1254F,\n // 'Cypro-Minoan': (char) => char >= 0x12F90 && char <= 0x12FFF,\n // 'Egyptian Hieroglyphs': (char) => char >= 0x13000 && char <= 0x1342F,\n // 'Egyptian Hieroglyph Format Controls': (char) => char >= 0x13430 && char <= 0x1345F,\n // 'Egyptian Hieroglyphs Extended-A': (char) => char >= 0x13460 && char <= 0x143FF,\n // 'Anatolian Hieroglyphs': (char) => char >= 0x14400 && char <= 0x1467F,\n // 'Gurung Khema': (char) => char >= 0x16100 && char <= 0x1613F,\n // 'Bamum Supplement': (char) => char >= 0x16800 && char <= 0x16A3F,\n // 'Mro': (char) => char >= 0x16A40 && char <= 0x16A6F,\n // 'Tangsa': (char) => char >= 0x16A70 && char <= 0x16ACF,\n // 'Bassa Vah': (char) => char >= 0x16AD0 && char <= 0x16AFF,\n // 'Pahawh Hmong': (char) => char >= 0x16B00 && char <= 0x16B8F,\n // 'Kirat Rai': (char) => char >= 0x16D40 && char <= 0x16D7F,\n // 'Medefaidrin': (char) => char >= 0x16E40 && char <= 0x16E9F,\n // 'Miao': (char) => char >= 0x16F00 && char <= 0x16F9F,\n // 'Ideographic Symbols and Punctuation': (char) => char >= 0x16FE0 && char <= 0x16FFF,\n // 'Tangut': (char) => char >= 0x17000 && char <= 0x187FF,\n // 'Tangut Components': (char) => char >= 0x18800 && char <= 0x18AFF,\n // 'Khitan Small Script': (char) => char >= 0x18B00 && char <= 0x18CFF,\n // 'Tangut Supplement': (char) => char >= 0x18D00 && char <= 0x18D7F,\n // 'Kana Extended-B': (char) => char >= 0x1AFF0 && char <= 0x1AFFF,\n // 'Kana Supplement': (char) => char >= 0x1B000 && char <= 0x1B0FF,\n // 'Kana Extended-A': (char) => char >= 0x1B100 && char <= 0x1B12F,\n // 'Small Kana Extension': (char) => char >= 0x1B130 && char <= 0x1B16F,\n // 'Nushu': (char) => char >= 0x1B170 && char <= 0x1B2FF,\n // 'Duployan': (char) => char >= 0x1BC00 && char <= 0x1BC9F,\n // 'Shorthand Format Controls': (char) => char >= 0x1BCA0 && char <= 0x1BCAF,\n // 'Symbols for Legacy Computing Supplement': (char) => char >= 0x1CC00 && char <= 0x1CEBF,\n // 'Znamenny Musical Notation': (char) => char >= 0x1CF00 && char <= 0x1CFCF,\n // 'Byzantine Musical Symbols': (char) => char >= 0x1D000 && char <= 0x1D0FF,\n // 'Musical Symbols': (char) => char >= 0x1D100 && char <= 0x1D1FF,\n // 'Ancient Greek Musical Notation': (char) => char >= 0x1D200 && char <= 0x1D24F,\n // 'Kaktovik Numerals': (char) => char >= 0x1D2C0 && char <= 0x1D2DF,\n // 'Mayan Numerals': (char) => char >= 0x1D2E0 && char <= 0x1D2FF,\n // 'Tai Xuan Jing Symbols': (char) => char >= 0x1D300 && char <= 0x1D35F,\n // 'Counting Rod Numerals': (char) => char >= 0x1D360 && char <= 0x1D37F,\n // 'Mathematical Alphanumeric Symbols': (char) => char >= 0x1D400 && char <= 0x1D7FF,\n // 'Sutton SignWriting': (char) => char >= 0x1D800 && char <= 0x1DAAF,\n // 'Latin Extended-G': (char) => char >= 0x1DF00 && char <= 0x1DFFF,\n // 'Glagolitic Supplement': (char) => char >= 0x1E000 && char <= 0x1E02F,\n // 'Cyrillic Extended-D': (char) => char >= 0x1E030 && char <= 0x1E08F,\n // 'Nyiakeng Puachue Hmong': (char) => char >= 0x1E100 && char <= 0x1E14F,\n // 'Toto': (char) => char >= 0x1E290 && char <= 0x1E2BF,\n // 'Wancho': (char) => char >= 0x1E2C0 && char <= 0x1E2FF,\n // 'Nag Mundari': (char) => char >= 0x1E4D0 && char <= 0x1E4FF,\n // 'Ol Onal': (char) => char >= 0x1E5D0 && char <= 0x1E5FF,\n // 'Ethiopic Extended-B': (char) => char >= 0x1E7E0 && char <= 0x1E7FF,\n // 'Mende Kikakui': (char) => char >= 0x1E800 && char <= 0x1E8DF,\n // 'Adlam': (char) => char >= 0x1E900 && char <= 0x1E95F,\n // 'Indic Siyaq Numbers': (char) => char >= 0x1EC70 && char <= 0x1ECBF,\n // 'Ottoman Siyaq Numbers': (char) => char >= 0x1ED00 && char <= 0x1ED4F,\n // 'Arabic Mathematical Alphabetic Symbols': (char) => char >= 0x1EE00 && char <= 0x1EEFF,\n // 'Mahjong Tiles': (char) => char >= 0x1F000 && char <= 0x1F02F,\n // 'Domino Tiles': (char) => char >= 0x1F030 && char <= 0x1F09F,\n // 'Playing Cards': (char) => char >= 0x1F0A0 && char <= 0x1F0FF,\n // 'Enclosed Alphanumeric Supplement': (char) => char >= 0x1F100 && char <= 0x1F1FF,\n // 'Enclosed Ideographic Supplement': (char) => char >= 0x1F200 && char <= 0x1F2FF,\n // 'Miscellaneous Symbols and Pictographs': (char) => char >= 0x1F300 && char <= 0x1F5FF,\n // 'Emoticons': (char) => char >= 0x1F600 && char <= 0x1F64F,\n // 'Ornamental Dingbats': (char) => char >= 0x1F650 && char <= 0x1F67F,\n // 'Transport and Map Symbols': (char) => char >= 0x1F680 && char <= 0x1F6FF,\n // 'Alchemical Symbols': (char) => char >= 0x1F700 && char <= 0x1F77F,\n // 'Geometric Shapes Extended': (char) => char >= 0x1F780 && char <= 0x1F7FF,\n // 'Supplemental Arrows-C': (char) => char >= 0x1F800 && char <= 0x1F8FF,\n // 'Supplemental Symbols and Pictographs': (char) => char >= 0x1F900 && char <= 0x1F9FF,\n // 'Chess Symbols': (char) => char >= 0x1FA00 && char <= 0x1FA6F,\n // 'Symbols and Pictographs Extended-A': (char) => char >= 0x1FA70 && char <= 0x1FAFF,\n // 'Symbols for Legacy Computing': (char) => char >= 0x1FB00 && char <= 0x1FBFF,\n // 'CJK Unified Ideographs Extension B': (char) => char >= 0x20000 && char <= 0x2A6DF,\n // 'CJK Unified Ideographs Extension C': (char) => char >= 0x2A700 && char <= 0x2B73F,\n // 'CJK Unified Ideographs Extension D': (char) => char >= 0x2B740 && char <= 0x2B81F,\n // 'CJK Unified Ideographs Extension E': (char) => char >= 0x2B820 && char <= 0x2CEAF,\n // 'CJK Unified Ideographs Extension F': (char) => char >= 0x2CEB0 && char <= 0x2EBEF,\n // 'CJK Unified Ideographs Extension I': (char) => char >= 0x2EBF0 && char <= 0x2EE5F,\n // 'CJK Unified Ideographs Extension G': (char) => char >= 0x30000 && char <= 0x3134F,\n // 'CJK Unified Ideographs Extension H': (char) => char >= 0x31350 && char <= 0x323AF,\n // 'CJK Compatibility Ideographs Supplement': (char) => char >= 0x2F800 && char <= 0x2FA1F,\n // 'Tags': (char) => char >= 0xE0000 && char <= 0xE007F,\n // 'Variation Selectors Supplement': (char) => char >= 0xE0100 && char <= 0xE01EF,\n // 'Supplementary Private Use Area-A': (char) => char >= 0xF0000 && char <= 0xFFFFF,\n // 'Supplementary Private Use Area-B': (char) => char >= 0x100000 && char <= 0x10FFFF,\n};\n","/* eslint-disable new-cap */\n\nimport {unicodeBlockLookup as isChar} from './is_char_in_unicode_block';\n\nexport function allowsIdeographicBreaking(chars: string) {\n for (const char of chars) {\n if (!charAllowsIdeographicBreaking(char.charCodeAt(0))) return false;\n }\n return true;\n}\n\nexport function allowsVerticalWritingMode(chars: string) {\n for (const char of chars) {\n if (charHasUprightVerticalOrientation(char.charCodeAt(0))) return true;\n }\n return false;\n}\n\nexport function allowsLetterSpacing(chars: string) {\n for (const char of chars) {\n if (!charAllowsLetterSpacing(char.charCodeAt(0))) return false;\n }\n return true;\n}\n\n/**\n * Returns a regular expression matching the given script codes, excluding any\n * code that the execution environment lacks support for in regular expressions.\n */\nfunction sanitizedRegExpFromScriptCodes(scriptCodes: Array): RegExp {\n const supportedPropertyEscapes = scriptCodes.map(code => {\n try {\n return new RegExp(`\\\\p{sc=${code}}`, 'u').source;\n } catch (e) {\n return null;\n }\n }).filter(pe => pe);\n return new RegExp(supportedPropertyEscapes.join('|'), 'u');\n}\n\n/**\n * ISO 15924 script codes of scripts that disallow letter spacing as of Unicode\n * 16.0.0.\n *\n * In general, cursive scripts are incompatible with letter spacing.\n */\nconst cursiveScriptCodes = [\n 'Arab', // Arabic\n 'Dupl', // Duployan\n 'Mong', // Mongolian\n 'Ougr', // Old Uyghur\n 'Syrc', // Syriac\n];\n\nconst cursiveScriptRegExp = sanitizedRegExpFromScriptCodes(cursiveScriptCodes);\n\nexport function charAllowsLetterSpacing(char: number) {\n return !cursiveScriptRegExp.test(String.fromCodePoint(char));\n}\n\n/**\n * ISO 15924 script codes of scripts that allow ideographic line breaking beyond\n * the CJKV scripts that are considered ideographic in Unicode 16.0.0.\n */\nconst ideographicBreakingScriptCodes = [\n 'Bopo', // Bopomofo\n 'Hani', // Han\n 'Hira', // Hiragana\n 'Kana', // Katakana\n 'Kits', // Khitan Small Script\n 'Nshu', // Nushu\n 'Tang', // Tangut\n 'Yiii', // Yi\n];\n\nconst ideographicBreakingRegExp = sanitizedRegExpFromScriptCodes(ideographicBreakingScriptCodes);\n\nexport function charAllowsIdeographicBreaking(char: number) {\n // Return early for characters outside all ideographic ranges.\n if (char < 0x2E80) return false;\n\n if (isChar['CJK Compatibility Forms'](char)) return true;\n if (isChar['CJK Compatibility'](char)) return true;\n if (isChar['CJK Strokes'](char)) return true;\n if (isChar['CJK Symbols and Punctuation'](char)) return true;\n if (isChar['Enclosed CJK Letters and Months'](char)) return true;\n if (isChar['Halfwidth and Fullwidth Forms'](char)) return true;\n if (isChar['Ideographic Description Characters'](char)) return true;\n if (isChar['Vertical Forms'](char)) return true;\n return ideographicBreakingRegExp.test(String.fromCodePoint(char));\n}\n\n// The following logic comes from\n// .\n// Keep it synchronized with\n// .\n// The data file denotes with “U” or “Tu” any codepoint that may be drawn\n// upright in vertical text but does not distinguish between upright and\n// “neutral” characters.\n\n// Blocks in the Unicode supplementary planes are excluded from this module due\n// to .\n\n/**\n * Returns true if the given Unicode codepoint identifies a character with\n * upright orientation.\n *\n * A character has upright orientation if it is drawn upright (unrotated)\n * whether the line is oriented horizontally or vertically, even if both\n * adjacent characters can be rotated. For example, a Chinese character is\n * always drawn upright. An uprightly oriented character causes an adjacent\n * “neutral” character to be drawn upright as well.\n */\nexport function charHasUprightVerticalOrientation(char: number) {\n if (char === 0x02EA /* modifier letter yin departing tone mark */ ||\n char === 0x02EB /* modifier letter yang departing tone mark */) {\n return true;\n }\n\n // Return early for characters outside all ranges whose characters remain\n // upright in vertical writing mode.\n if (char < 0x1100) return false;\n\n if (isChar['CJK Compatibility Forms'](char)) {\n if (!((char >= 0xFE49 /* dashed overline */ && char <= 0xFE4F) /* wavy low line */)) {\n return true;\n }\n }\n if (isChar['CJK Compatibility'](char)) return true;\n if (isChar['CJK Strokes'](char)) return true;\n if (isChar['CJK Symbols and Punctuation'](char)) {\n if (!((char >= 0x3008 /* left angle bracket */ && char <= 0x3011) /* right black lenticular bracket */) &&\n !((char >= 0x3014 /* left tortoise shell bracket */ && char <= 0x301F) /* low double prime quotation mark */) &&\n char !== 0x3030 /* wavy dash */) {\n return true;\n }\n }\n if (isChar['Enclosed CJK Letters and Months'](char)) return true;\n if (isChar['Ideographic Description Characters'](char)) return true;\n if (isChar['Kanbun'](char)) return true;\n if (isChar['Katakana'](char)) {\n if (char !== 0x30FC /* katakana-hiragana prolonged sound mark */) {\n return true;\n }\n }\n if (isChar['Halfwidth and Fullwidth Forms'](char)) {\n if (char !== 0xFF08 /* fullwidth left parenthesis */ &&\n char !== 0xFF09 /* fullwidth right parenthesis */ &&\n char !== 0xFF0D /* fullwidth hyphen-minus */ &&\n !((char >= 0xFF1A /* fullwidth colon */ && char <= 0xFF1E) /* fullwidth greater-than sign */) &&\n char !== 0xFF3B /* fullwidth left square bracket */ &&\n char !== 0xFF3D /* fullwidth right square bracket */ &&\n char !== 0xFF3F /* fullwidth low line */ &&\n !(char >= 0xFF5B /* fullwidth left curly bracket */ && char <= 0xFFDF) &&\n char !== 0xFFE3 /* fullwidth macron */ &&\n !(char >= 0xFFE8 /* halfwidth forms light vertical */ && char <= 0xFFEF)) {\n return true;\n }\n }\n if (isChar['Small Form Variants'](char)) {\n if (!((char >= 0xFE58 /* small em dash */ && char <= 0xFE5E) /* small right tortoise shell bracket */) &&\n !((char >= 0xFE63 /* small hyphen-minus */ && char <= 0xFE66) /* small equals sign */)) {\n return true;\n }\n }\n if (isChar['Vertical Forms'](char)) return true;\n if (isChar['Yijing Hexagram Symbols'](char)) return true;\n\n if (/* Canadian Aboriginal */ /\\p{sc=Cans}/u.test(String.fromCodePoint(char))) return true;\n if (/* Hangul */ /\\p{sc=Hang}/u.test(String.fromCodePoint(char))) return true;\n if (ideographicBreakingRegExp.test(String.fromCodePoint(char))) return true;\n\n return false;\n}\n\n/**\n * Returns true if the given Unicode codepoint identifies a character with\n * neutral orientation.\n *\n * A character has neutral orientation if it may be drawn rotated or unrotated\n * when the line is oriented vertically, depending on the orientation of the\n * adjacent characters. For example, along a vertically oriented line, the vulgar\n * fraction ½ is drawn upright among Chinese characters but rotated among Latin\n * letters. A neutrally oriented character does not influence whether an\n * adjacent character is drawn upright or rotated.\n */\nexport function charHasNeutralVerticalOrientation(char: number) {\n if (isChar['Latin-1 Supplement'](char)) {\n if (char === 0x00A7 /* section sign */ ||\n char === 0x00A9 /* copyright sign */ ||\n char === 0x00AE /* registered sign */ ||\n char === 0x00B1 /* plus-minus sign */ ||\n char === 0x00BC /* vulgar fraction one quarter */ ||\n char === 0x00BD /* vulgar fraction one half */ ||\n char === 0x00BE /* vulgar fraction three quarters */ ||\n char === 0x00D7 /* multiplication sign */ ||\n char === 0x00F7 /* division sign */) {\n return true;\n }\n }\n if (isChar['General Punctuation'](char)) {\n if (char === 0x2016 /* double vertical line */ ||\n char === 0x2020 /* dagger */ ||\n char === 0x2021 /* double dagger */ ||\n char === 0x2030 /* per mille sign */ ||\n char === 0x2031 /* per ten thousand sign */ ||\n char === 0x203B /* reference mark */ ||\n char === 0x203C /* double exclamation mark */ ||\n char === 0x2042 /* asterism */ ||\n char === 0x2047 /* double question mark */ ||\n char === 0x2048 /* question exclamation mark */ ||\n char === 0x2049 /* exclamation question mark */ ||\n char === 0x2051 /* two asterisks aligned vertically */) {\n return true;\n }\n }\n if (isChar['Letterlike Symbols'](char)) return true;\n if (isChar['Number Forms'](char)) return true;\n if (isChar['Miscellaneous Technical'](char)) {\n if ((char >= 0x2300 /* diameter sign */ && char <= 0x2307 /* wavy line */) ||\n (char >= 0x230C /* bottom right crop */ && char <= 0x231F /* bottom right corner */) ||\n (char >= 0x2324 /* up arrowhead between two horizontal bars */ && char <= 0x2328 /* keyboard */) ||\n char === 0x232B /* erase to the left */ ||\n (char >= 0x237D /* shouldered open box */ && char <= 0x239A /* clear screen symbol */) ||\n (char >= 0x23BE /* dentistry symbol light vertical and top right */ && char <= 0x23CD /* square foot */) ||\n char === 0x23CF /* eject symbol */ ||\n (char >= 0x23D1 /* metrical breve */ && char <= 0x23DB /* fuse */) ||\n (char >= 0x23E2 /* white trapezium */ && char <= 0x23FF)) {\n return true;\n }\n }\n if (isChar['Control Pictures'](char) && char !== 0x2423 /* open box */) return true;\n if (isChar['Optical Character Recognition'](char)) return true;\n if (isChar['Enclosed Alphanumerics'](char)) return true;\n if (isChar['Geometric Shapes'](char)) return true;\n if (isChar['Miscellaneous Symbols'](char)) {\n if (!((char >= 0x261A /* black left pointing index */ && char <= 0x261F) /* white down pointing index */)) {\n return true;\n }\n }\n if (isChar['Miscellaneous Symbols and Arrows'](char)) {\n if ((char >= 0x2B12 /* square with top half black */ && char <= 0x2B2F /* white vertical ellipse */) ||\n (char >= 0x2B50 /* white medium star */ && char <= 0x2B59 /* heavy circled saltire */) ||\n (char >= 0x2BB8 /* upwards white arrow from bar with horizontal bar */ && char <= 0x2BEB)) {\n return true;\n }\n }\n if (isChar['CJK Symbols and Punctuation'](char)) return true;\n if (isChar['Katakana'](char)) return true;\n if (isChar['Private Use Area'](char)) return true;\n if (isChar['CJK Compatibility Forms'](char)) return true;\n if (isChar['Small Form Variants'](char)) return true;\n if (isChar['Halfwidth and Fullwidth Forms'](char)) return true;\n\n if (char === 0x221E /* infinity */ ||\n char === 0x2234 /* therefore */ ||\n char === 0x2235 /* because */ ||\n (char >= 0x2700 /* black safety scissors */ && char <= 0x2767 /* rotated floral heart bullet */) ||\n (char >= 0x2776 /* dingbat negative circled digit one */ && char <= 0x2793 /* dingbat negative circled sans-serif number ten */) ||\n char === 0xFFFC /* object replacement character */ ||\n char === 0xFFFD /* replacement character */) {\n return true;\n }\n\n return false;\n}\n\n/**\n * Returns true if the given Unicode codepoint identifies a character with\n * rotated orientation.\n *\n * A character has rotated orientation if it is drawn rotated when the line is\n * oriented vertically, even if both adjacent characters are upright. For\n * example, a Latin letter is drawn rotated along a vertical line. A rotated\n * character causes an adjacent “neutral” character to be drawn rotated as well.\n */\nexport function charHasRotatedVerticalOrientation(char: number) {\n return !(charHasUprightVerticalOrientation(char) ||\n charHasNeutralVerticalOrientation(char));\n}\n\nexport function charInComplexShapingScript(char: number) {\n return /\\p{sc=Arab}/u.test(String.fromCodePoint(char));\n}\n\n/**\n * ISO 15924 script codes of scripts that are primarily written horizontally\n * right-to-left according to Unicode 16.0.0.\n */\nconst rtlScriptCodes = [\n 'Adlm', // Adlam\n 'Arab', // Arabic\n 'Armi', // Imperial Aramaic\n 'Avst', // Avestan\n 'Chrs', // Chorasmian\n 'Cprt', // Cypriot\n 'Egyp', // Egyptian Hieroglyphs\n 'Elym', // Elymaic\n 'Gara', // Garay\n 'Hatr', // Hatran\n 'Hebr', // Hebrew\n 'Hung', // Old Hungarian\n 'Khar', // Kharoshthi\n 'Lydi', // Lydian\n 'Mand', // Mandaic\n 'Mani', // Manichaean\n 'Mend', // Mende Kikakui\n 'Merc', // Meroitic Cursive\n 'Mero', // Meroitic Hieroglyphs\n 'Narb', // Old North Arabian\n 'Nbat', // Nabataean\n 'Nkoo', // NKo\n 'Orkh', // Old Turkic\n 'Palm', // Palmyrene\n 'Phli', // Inscriptional Pahlavi\n 'Phlp', // Psalter Pahlavi\n 'Phnx', // Phoenician\n 'Prti', // Inscriptional Parthian\n 'Rohg', // Hanifi Rohingya\n 'Samr', // Samaritan\n 'Sarb', // Old South Arabian\n 'Sogo', // Old Sogdian\n 'Syrc', // Syriac\n 'Thaa', // Thaana\n 'Todr', // Todhri\n 'Yezi', // Yezidi\n];\n\nconst rtlScriptRegExp = sanitizedRegExpFromScriptCodes(rtlScriptCodes);\n\nexport function charInRTLScript(char: number) {\n return rtlScriptRegExp.test(String.fromCodePoint(char));\n}\n\nexport function charInSupportedScript(char: number, canRenderRTL: boolean) {\n // This is a rough heuristic: whether we \"can render\" a script\n // actually depends on the properties of the font being used\n // and whether differences from the ideal rendering are considered\n // semantically significant.\n\n // Even in Latin script, we \"can't render\" combinations such as the fi\n // ligature, but we don't consider that semantically significant.\n if (!canRenderRTL && charInRTLScript(char)) {\n return false;\n }\n if ((char >= 0x0900 && char <= 0x0DFF) ||\n // Main blocks for Indic scripts and Sinhala\n (char >= 0x0F00 && char <= 0x109F) ||\n // Main blocks for Tibetan and Myanmar\n isChar['Khmer'](char)) {\n // These blocks cover common scripts that require\n // complex text shaping, based on unicode script metadata:\n // https://www.unicode.org/repos/cldr/trunk/common/properties/scriptMetadata.txt\n // where \"Web Rank <= 32\" \"Shaping Required = YES\"\n return false;\n }\n return true;\n}\n\nexport function stringContainsRTLText(chars: string): boolean {\n for (const char of chars) {\n if (charInRTLScript(char.charCodeAt(0))) {\n return true;\n }\n }\n return false;\n}\n\nexport function isStringInSupportedScript(chars: string, canRenderRTL: boolean) {\n for (const char of chars) {\n if (!charInSupportedScript(char.charCodeAt(0), canRenderRTL)) {\n return false;\n }\n }\n return true;\n}\n","import {PluginState, RTLPluginStatus} from './rtl_text_plugin_status';\n\nexport interface RTLTextPlugin {\n applyArabicShaping: (a: string) => string;\n processBidirectionalText: ((b: string, a: Array) => Array);\n processStyledBidirectionalText: ((c: string, b: Array, a: Array) => Array<[string, Array]>);\n}\n\nclass RTLWorkerPlugin implements RTLTextPlugin {\n applyArabicShaping: (a: string) => string = null;\n processBidirectionalText: ((b: string, a: Array) => Array) = null;\n processStyledBidirectionalText: ((c: string, b: Array, a: Array) => Array<[string, Array]>) = null;\n pluginStatus: RTLPluginStatus = 'unavailable';\n pluginURL: string = null;\n\n setState(state: PluginState) {\n this.pluginStatus = state.pluginStatus;\n this.pluginURL = state.pluginURL;\n }\n\n getState(): PluginState {\n return {\n pluginStatus: this.pluginStatus,\n pluginURL: this.pluginURL\n };\n }\n\n setMethods(rtlTextPlugin: RTLTextPlugin) {\n this.applyArabicShaping = rtlTextPlugin.applyArabicShaping;\n this.processBidirectionalText = rtlTextPlugin.processBidirectionalText;\n this.processStyledBidirectionalText = rtlTextPlugin.processStyledBidirectionalText;\n }\n\n isParsed(): boolean {\n return this.applyArabicShaping != null &&\n this.processBidirectionalText != null &&\n this.processStyledBidirectionalText != null;\n }\n\n getPluginURL(): string {\n return this.pluginURL;\n }\n\n getRTLTextPluginStatus() {\n return this.pluginStatus;\n }\n}\n\nexport const rtlWorkerPlugin = new RTLWorkerPlugin();\n","import {ZoomHistory} from './zoom_history';\nimport {isStringInSupportedScript} from '../util/script_detection';\nimport {rtlWorkerPlugin} from '../source/rtl_text_plugin_worker';\n\nimport type {TransitionSpecification} from '@maplibre/maplibre-gl-style-spec';\n\nexport type CrossfadeParameters = {\n fromScale: number;\n toScale: number;\n t: number;\n};\n\n/**\n * @internal\n * A parameter that can be evaluated to a value\n */\nexport class EvaluationParameters {\n zoom: number;\n now: number;\n fadeDuration: number;\n zoomHistory: ZoomHistory;\n transition: TransitionSpecification;\n\n // \"options\" may also be another EvaluationParameters to copy, see CrossFadedProperty.possiblyEvaluate\n constructor(zoom: number, options?: any) {\n this.zoom = zoom;\n\n if (options) {\n this.now = options.now;\n this.fadeDuration = options.fadeDuration;\n this.zoomHistory = options.zoomHistory;\n this.transition = options.transition;\n } else {\n this.now = 0;\n this.fadeDuration = 0;\n this.zoomHistory = new ZoomHistory();\n this.transition = {};\n }\n }\n\n isSupportedScript(str: string): boolean {\n return isStringInSupportedScript(str, rtlWorkerPlugin.getRTLTextPluginStatus() === 'loaded');\n }\n\n crossFadingFactor() {\n if (this.fadeDuration === 0) {\n return 1;\n } else {\n return Math.min((this.now - this.zoomHistory.lastIntegerZoomTime) / this.fadeDuration, 1);\n }\n }\n\n getCrossfadeParameters(): CrossfadeParameters {\n const z = this.zoom;\n const fraction = z - Math.floor(z);\n const t = this.crossFadingFactor();\n\n return z > this.zoomHistory.lastIntegerZoom ?\n {fromScale: 2, toScale: 1, t: fraction + (1 - fraction) * t} :\n {fromScale: 0.5, toScale: 1, t: 1 - (1 - t) * fraction};\n }\n}\n","import {clone, extend, easeCubicInOut} from '../util/util';\nimport {interpolates, Color, StylePropertySpecification, normalizePropertyExpression,\n Feature,\n FeatureState,\n StylePropertyExpression,\n SourceExpression,\n CompositeExpression, TransitionSpecification,\n PropertyValueSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport {register} from '../util/web_worker_transfer';\nimport {EvaluationParameters} from './evaluation_parameters';\n\nimport {CanonicalTileID} from '../source/tile_id';\n\ntype TimePoint = number;\n\n/**\n * A from-to type\n */\nexport type CrossFaded = {\n to: T;\n from: T;\n};\n\n/**\n * @internal\n * Implementations of the `Property` interface:\n *\n * * Hold metadata about a property that's independent of any specific value: stuff like the type of the value,\n * the default value, etc. This comes from the style specification JSON.\n * * Define behavior that needs to be polymorphic across different properties: \"possibly evaluating\"\n * an input value (see below), and interpolating between two possibly-evaluted values.\n *\n * The type `T` is the fully-evaluated value type (e.g. `number`, `string`, `Color`).\n * The type `R` is the intermediate \"possibly evaluated\" value type. See below.\n *\n * There are two main implementations of the interface -- one for properties that allow data-driven values,\n * and one for properties that don't. There are a few \"special case\" implementations as well: one for properties\n * which cross-fade between two values rather than interpolating, one for `heatmap-color` and `line-gradient`,\n * and one for `light-position`.\n */\nexport interface Property {\n specification: StylePropertySpecification;\n possiblyEvaluate(\n value: PropertyValue,\n parameters: EvaluationParameters,\n canonical?: CanonicalTileID,\n availableImages?: Array\n ): R;\n interpolate(a: R, b: R, t: number): R;\n}\n\n/**\n * @internal\n * `PropertyValue` represents the value part of a property key-value unit. It's used to represent both\n * paint and layout property values, and regardless of whether or not their property supports data-driven\n * expressions.\n *\n * `PropertyValue` stores the raw input value as seen in a style or a runtime styling API call, i.e. one of the\n * following:\n *\n * * A constant value of the type appropriate for the property\n * * A function which produces a value of that type (but functions are quasi-deprecated in favor of expressions)\n * * An expression which produces a value of that type\n * * \"undefined\"/\"not present\", in which case the property is assumed to take on its default value.\n *\n * In addition to storing the original input value, `PropertyValue` also stores a normalized representation,\n * effectively treating functions as if they are expressions, and constant or default values as if they are\n * (constant) expressions.\n */\nexport class PropertyValue {\n property: Property;\n value: PropertyValueSpecification | void;\n expression: StylePropertyExpression;\n\n constructor(property: Property, value: PropertyValueSpecification | void) {\n this.property = property;\n this.value = value;\n this.expression = normalizePropertyExpression(value === undefined ? property.specification.default : value, property.specification);\n }\n\n isDataDriven(): boolean {\n return this.expression.kind === 'source' || this.expression.kind === 'composite';\n }\n\n possiblyEvaluate(\n parameters: EvaluationParameters,\n canonical?: CanonicalTileID,\n availableImages?: Array\n ): R {\n return this.property.possiblyEvaluate(this, parameters, canonical, availableImages);\n }\n}\n\nexport type TransitionParameters = {\n now: TimePoint;\n transition: TransitionSpecification;\n};\n\n/**\n * @internal\n * Paint properties are _transitionable_: they can change in a fluid manner, interpolating or cross-fading between\n * old and new value. The duration of the transition, and the delay before it begins, is configurable.\n *\n * `TransitionablePropertyValue` is a compositional class that stores both the property value and that transition\n * configuration.\n *\n * A `TransitionablePropertyValue` can calculate the next step in the evaluation chain for paint property values:\n * `TransitioningPropertyValue`.\n */\nclass TransitionablePropertyValue {\n property: Property;\n value: PropertyValue;\n transition: TransitionSpecification | void;\n\n constructor(property: Property) {\n this.property = property;\n this.value = new PropertyValue(property, undefined);\n }\n\n transitioned(parameters: TransitionParameters, prior: TransitioningPropertyValue): TransitioningPropertyValue {\n return new TransitioningPropertyValue(this.property, this.value, prior,\n extend({}, parameters.transition, this.transition), parameters.now);\n }\n\n untransitioned(): TransitioningPropertyValue {\n return new TransitioningPropertyValue(this.property, this.value, null, {}, 0);\n }\n}\n\n/**\n * @internal\n * `Transitionable` stores a map of all (property name, `TransitionablePropertyValue`) pairs for paint properties of a\n * given layer type. It can calculate the `TransitioningPropertyValue`s for all of them at once, producing a\n * `Transitioning` instance for the same set of properties.\n */\nexport class Transitionable {\n _properties: Properties;\n _values: {[K in keyof Props]: TransitionablePropertyValue};\n\n constructor(properties: Properties) {\n this._properties = properties;\n this._values = (Object.create(properties.defaultTransitionablePropertyValues) as any);\n }\n\n getValue(name: S): PropertyValueSpecification | void {\n return clone(this._values[name].value.value);\n }\n\n setValue(name: S, value: PropertyValueSpecification | void) {\n if (!Object.prototype.hasOwnProperty.call(this._values, name)) {\n this._values[name] = new TransitionablePropertyValue(this._values[name].property);\n }\n // Note that we do not _remove_ an own property in the case where a value is being reset\n // to the default: the transition might still be non-default.\n this._values[name].value = new PropertyValue(this._values[name].property, value === null ? undefined : clone(value));\n }\n\n getTransition(name: S): TransitionSpecification | void {\n return clone(this._values[name].transition);\n }\n\n setTransition(name: S, value: TransitionSpecification | void) {\n if (!Object.prototype.hasOwnProperty.call(this._values, name)) {\n this._values[name] = new TransitionablePropertyValue(this._values[name].property);\n }\n this._values[name].transition = clone(value) || undefined;\n }\n\n serialize() {\n const result: any = {};\n for (const property of Object.keys(this._values)) {\n const value = this.getValue(property as keyof Props);\n if (value !== undefined) {\n result[property] = value;\n }\n\n const transition = this.getTransition(property as keyof Props);\n if (transition !== undefined) {\n result[`${property}-transition`] = transition;\n }\n }\n return result;\n }\n\n transitioned(parameters: TransitionParameters, prior: Transitioning): Transitioning {\n const result = new Transitioning(this._properties);\n for (const property of Object.keys(this._values)) {\n result._values[property] = this._values[property].transitioned(parameters, prior._values[property]);\n }\n return result;\n }\n\n untransitioned(): Transitioning {\n const result = new Transitioning(this._properties);\n for (const property of Object.keys(this._values)) {\n result._values[property] = this._values[property].untransitioned();\n }\n return result;\n }\n}\n\n/**\n * @internal\n * `TransitioningPropertyValue` implements the first of two intermediate steps in the evaluation chain of a paint\n * property value. In this step, transitions between old and new values are handled: as long as the transition is in\n * progress, `TransitioningPropertyValue` maintains a reference to the prior value, and interpolates between it and\n * the new value based on the current time and the configured transition duration and delay. The product is the next\n * step in the evaluation chain: the \"possibly evaluated\" result type `R`. See below for more on this concept.\n */\nclass TransitioningPropertyValue {\n property: Property;\n value: PropertyValue;\n prior: TransitioningPropertyValue;\n begin: TimePoint;\n end: TimePoint;\n\n constructor(property: Property,\n value: PropertyValue,\n prior: TransitioningPropertyValue,\n transition: TransitionSpecification,\n now: TimePoint) {\n this.property = property;\n this.value = value;\n this.begin = now + transition.delay || 0;\n this.end = this.begin + transition.duration || 0;\n if (property.specification.transition && (transition.delay || transition.duration)) {\n this.prior = prior;\n }\n }\n\n possiblyEvaluate(\n parameters: EvaluationParameters,\n canonical: CanonicalTileID,\n availableImages: Array\n ): R {\n const now = parameters.now || 0;\n const finalValue = this.value.possiblyEvaluate(parameters, canonical, availableImages);\n const prior = this.prior;\n if (!prior) {\n // No prior value.\n return finalValue;\n } else if (now > this.end) {\n // Transition from prior value is now complete.\n this.prior = null;\n return finalValue;\n } else if (this.value.isDataDriven()) {\n // Transitions to data-driven properties are not supported.\n // We snap immediately to the data-driven value so that, when we perform layout,\n // we see the data-driven function and can use it to populate vertex buffers.\n this.prior = null;\n return finalValue;\n } else if (now < this.begin) {\n // Transition hasn't started yet.\n return prior.possiblyEvaluate(parameters, canonical, availableImages);\n } else {\n // Interpolate between recursively-calculated prior value and final.\n const t = (now - this.begin) / (this.end - this.begin);\n return this.property.interpolate(prior.possiblyEvaluate(parameters, canonical, availableImages), finalValue, easeCubicInOut(t));\n }\n }\n}\n\n/**\n * @internal\n * `Transitioning` stores a map of all (property name, `TransitioningPropertyValue`) pairs for paint properties of a\n * given layer type. It can calculate the possibly-evaluated values for all of them at once, producing a\n * `PossiblyEvaluated` instance for the same set of properties.\n */\nexport class Transitioning {\n _properties: Properties;\n _values: {[K in keyof Props]: PossiblyEvaluatedPropertyValue};\n\n constructor(properties: Properties) {\n this._properties = properties;\n this._values = (Object.create(properties.defaultTransitioningPropertyValues) as any);\n }\n\n possiblyEvaluate(\n parameters: EvaluationParameters,\n canonical?: CanonicalTileID,\n availableImages?: Array\n ): PossiblyEvaluated {\n const result = new PossiblyEvaluated(this._properties);\n for (const property of Object.keys(this._values)) {\n result._values[property] = this._values[property].possiblyEvaluate(parameters, canonical, availableImages);\n }\n return result;\n }\n\n hasTransition() {\n for (const property of Object.keys(this._values)) {\n if (this._values[property].prior) {\n return true;\n }\n }\n return false;\n }\n}\n\n// ------- Layout -------\n\n/**\n * Because layout properties are not transitionable, they have a simpler representation and evaluation chain than\n * paint properties: `PropertyValue`s are possibly evaluated, producing possibly evaluated values, which are then\n * fully evaluated.\n *\n * `Layout` stores a map of all (property name, `PropertyValue`) pairs for layout properties of a\n * given layer type. It can calculate the possibly-evaluated values for all of them at once, producing a\n * `PossiblyEvaluated` instance for the same set of properties.\n */\nexport class Layout {\n _properties: Properties;\n _values: {[K in keyof Props]: PropertyValue>};\n\n constructor(properties: Properties) {\n this._properties = properties;\n this._values = (Object.create(properties.defaultPropertyValues) as any);\n }\n\n hasValue(name: S) {\n return this._values[name].value !== undefined;\n }\n\n getValue(name: S) {\n return clone(this._values[name].value);\n }\n\n setValue(name: S, value: any) {\n this._values[name] = new PropertyValue(this._values[name].property, value === null ? undefined : clone(value)) as any;\n }\n\n serialize() {\n const result: any = {};\n for (const property of Object.keys(this._values)) {\n const value = this.getValue(property as keyof Props);\n if (value !== undefined) {\n result[property] = value;\n }\n }\n return result;\n }\n\n possiblyEvaluate(\n parameters: EvaluationParameters,\n canonical?: CanonicalTileID,\n availableImages?: Array\n ): PossiblyEvaluated {\n const result = new PossiblyEvaluated(this._properties);\n for (const property of Object.keys(this._values)) {\n result._values[property] = this._values[property].possiblyEvaluate(parameters, canonical, availableImages);\n }\n return result;\n }\n}\n\n// ------- PossiblyEvaluated -------\n\n/**\n * \"Possibly evaluated value\" is an intermediate stage in the evaluation chain for both paint and layout property\n * values. The purpose of this stage is to optimize away unnecessary recalculations for data-driven properties. Code\n * which uses data-driven property values must assume that the value is dependent on feature data, and request that it\n * be evaluated for each feature. But when that property value is in fact a constant or camera function, the calculation\n * will not actually depend on the feature, and we can benefit from returning the prior result of having done the\n * evaluation once, ahead of time, in an intermediate step whose inputs are just the value and \"global\" parameters\n * such as current zoom level.\n *\n * `PossiblyEvaluatedValue` represents the three possible outcomes of this step: if the input value was a constant or\n * camera expression, then the \"possibly evaluated\" result is a constant value. Otherwise, the input value was either\n * a source or composite expression, and we must defer final evaluation until supplied a feature. We separate\n * the source and composite cases because they are handled differently when generating GL attributes, buffers, and\n * uniforms.\n *\n * Note that `PossiblyEvaluatedValue` (and `PossiblyEvaluatedPropertyValue`, below) are _not_ used for properties that\n * do not allow data-driven values. For such properties, we know that the \"possibly evaluated\" result is always a constant\n * scalar value. See below.\n */\ntype PossiblyEvaluatedValue = {\n kind: 'constant';\n value: T;\n} | SourceExpression | CompositeExpression;\n\n/**\n * @internal\n * `PossiblyEvaluatedPropertyValue` is used for data-driven paint and layout property values. It holds a\n * `PossiblyEvaluatedValue` and the `GlobalProperties` that were used to generate it. You're not allowed to supply\n * a different set of `GlobalProperties` when performing the final evaluation because they would be ignored in the\n * case where the input value was a constant or camera function.\n */\nexport class PossiblyEvaluatedPropertyValue {\n property: DataDrivenProperty;\n value: PossiblyEvaluatedValue;\n parameters: EvaluationParameters;\n\n constructor(property: DataDrivenProperty, value: PossiblyEvaluatedValue, parameters: EvaluationParameters) {\n this.property = property;\n this.value = value;\n this.parameters = parameters;\n }\n\n isConstant(): boolean {\n return this.value.kind === 'constant';\n }\n\n constantOr(value: T): T {\n if (this.value.kind === 'constant') {\n return this.value.value;\n } else {\n return value;\n }\n }\n\n evaluate(\n feature: Feature,\n featureState: FeatureState,\n canonical?: CanonicalTileID,\n availableImages?: Array\n ): T {\n return this.property.evaluate(this.value, this.parameters, feature, featureState, canonical, availableImages);\n }\n}\n\n/**\n * @internal\n * `PossiblyEvaluated` stores a map of all (property name, `R`) pairs for paint or layout properties of a\n * given layer type.\n */\nexport class PossiblyEvaluated {\n _properties: Properties;\n _values: PossibleEvaluatedProps;\n\n constructor(properties: Properties) {\n this._properties = properties;\n this._values = Object.create(properties.defaultPossiblyEvaluatedValues);\n }\n\n get(name: S): PossibleEvaluatedProps[S] {\n return this._values[name];\n }\n}\n\n/**\n * @internal\n * An implementation of `Property` for properties that do not permit data-driven (source or composite) expressions.\n * This restriction allows us to declare statically that the result of possibly evaluating this kind of property\n * is in fact always the scalar type `T`, and can be used without further evaluating the value on a per-feature basis.\n */\nexport class DataConstantProperty implements Property {\n specification: StylePropertySpecification;\n\n constructor(specification: StylePropertySpecification) {\n this.specification = specification;\n }\n\n possiblyEvaluate(value: PropertyValue, parameters: EvaluationParameters): T {\n if (value.isDataDriven()) throw new Error('Value should not be data driven');\n return value.expression.evaluate(parameters);\n }\n\n interpolate(a: T, b: T, t: number): T {\n const interpolationType = this.specification.type as keyof typeof interpolates;\n const interpolationFn = interpolates[interpolationType] as ((from: T, to: T, t: number) => T) | undefined;\n if (interpolationFn) {\n return interpolationFn(a, b, t);\n } else {\n return a;\n }\n }\n}\n\n/**\n * @internal\n * An implementation of `Property` for properties that permit data-driven (source or composite) expressions.\n * The result of possibly evaluating this kind of property is `PossiblyEvaluatedPropertyValue`; obtaining\n * a scalar value `T` requires further evaluation on a per-feature basis.\n */\nexport class DataDrivenProperty implements Property> {\n specification: StylePropertySpecification;\n overrides: any;\n\n constructor(specification: StylePropertySpecification, overrides?: any) {\n this.specification = specification;\n this.overrides = overrides;\n }\n\n possiblyEvaluate(\n value: PropertyValue>,\n parameters: EvaluationParameters,\n canonical?: CanonicalTileID,\n availableImages?: Array\n ): PossiblyEvaluatedPropertyValue {\n if (value.expression.kind === 'constant' || value.expression.kind === 'camera') {\n return new PossiblyEvaluatedPropertyValue(this, {kind: 'constant', value: value.expression.evaluate(parameters, null, {}, canonical, availableImages)}, parameters);\n } else {\n return new PossiblyEvaluatedPropertyValue(this, value.expression, parameters);\n }\n }\n\n interpolate(\n a: PossiblyEvaluatedPropertyValue,\n b: PossiblyEvaluatedPropertyValue,\n t: number\n ): PossiblyEvaluatedPropertyValue {\n // If either possibly-evaluated value is non-constant, give up: we aren't able to interpolate data-driven values.\n if (a.value.kind !== 'constant' || b.value.kind !== 'constant') {\n return a;\n }\n\n // Special case hack solely for fill-outline-color. The undefined value is subsequently handled in\n // FillStyleLayer#recalculate, which sets fill-outline-color to the fill-color value if the former\n // is a PossiblyEvaluatedPropertyValue containing a constant undefined value. In addition to the\n // return value here, the other source of a PossiblyEvaluatedPropertyValue containing a constant\n // undefined value is the \"default value\" for fill-outline-color held in\n // `Properties#defaultPossiblyEvaluatedValues`, which serves as the prototype of\n // `PossiblyEvaluated#_values`.\n if (a.value.value === undefined || b.value.value === undefined) {\n return new PossiblyEvaluatedPropertyValue(this, {kind: 'constant', value: undefined}, a.parameters);\n }\n\n const interpolationType = this.specification.type as keyof typeof interpolates;\n const interpolationFn = interpolates[interpolationType] as ((from: T, to: T, t: number) => T) | undefined;\n if (interpolationFn) {\n const interpolatedValue = interpolationFn(a.value.value, b.value.value, t);\n return new PossiblyEvaluatedPropertyValue(this, {kind: 'constant', value: interpolatedValue}, a.parameters);\n } else {\n return a;\n }\n }\n\n evaluate(\n value: PossiblyEvaluatedValue,\n parameters: EvaluationParameters,\n feature: Feature,\n featureState: FeatureState,\n canonical?: CanonicalTileID,\n availableImages?: Array\n ): T {\n if (value.kind === 'constant') {\n return value.value;\n } else {\n return value.evaluate(parameters, feature, featureState, canonical, availableImages);\n }\n }\n}\n\n/**\n * @internal\n * An implementation of `Property` for data driven `line-pattern` which are transitioned by cross-fading\n * rather than interpolation.\n */\n\nexport class CrossFadedDataDrivenProperty extends DataDrivenProperty> {\n\n possiblyEvaluate(\n value: PropertyValue, PossiblyEvaluatedPropertyValue>>,\n parameters: EvaluationParameters,\n canonical?: CanonicalTileID,\n availableImages?: Array\n ): PossiblyEvaluatedPropertyValue> {\n if (value.value === undefined) {\n return new PossiblyEvaluatedPropertyValue(this, {kind: 'constant', value: undefined}, parameters);\n } else if (value.expression.kind === 'constant') {\n const evaluatedValue = value.expression.evaluate(parameters, null, {}, canonical, availableImages);\n const isImageExpression = value.property.specification.type as any === 'resolvedImage';\n const constantValue = isImageExpression && typeof evaluatedValue !== 'string' ? evaluatedValue.name : evaluatedValue;\n const constant = this._calculate(constantValue, constantValue, constantValue, parameters);\n return new PossiblyEvaluatedPropertyValue(this, {kind: 'constant', value: constant}, parameters);\n } else if (value.expression.kind === 'camera') {\n const cameraVal = this._calculate(\n value.expression.evaluate({zoom: parameters.zoom - 1.0}),\n value.expression.evaluate({zoom: parameters.zoom}),\n value.expression.evaluate({zoom: parameters.zoom + 1.0}),\n parameters);\n return new PossiblyEvaluatedPropertyValue(this, {kind: 'constant', value: cameraVal}, parameters);\n } else {\n // source or composite expression\n return new PossiblyEvaluatedPropertyValue(this, value.expression, parameters);\n }\n }\n\n evaluate(\n value: PossiblyEvaluatedValue>,\n globals: EvaluationParameters,\n feature: Feature,\n featureState: FeatureState,\n canonical?: CanonicalTileID,\n availableImages?: Array\n ): CrossFaded {\n if (value.kind === 'source') {\n const constant = value.evaluate(globals, feature, featureState, canonical, availableImages);\n return this._calculate(constant, constant, constant, globals);\n } else if (value.kind === 'composite') {\n return this._calculate(\n value.evaluate({zoom: Math.floor(globals.zoom) - 1.0}, feature, featureState),\n value.evaluate({zoom: Math.floor(globals.zoom)}, feature, featureState),\n value.evaluate({zoom: Math.floor(globals.zoom) + 1.0}, feature, featureState),\n globals);\n } else {\n return value.value;\n }\n }\n\n _calculate(min: T, mid: T, max: T, parameters: EvaluationParameters): CrossFaded {\n const z = parameters.zoom;\n return z > parameters.zoomHistory.lastIntegerZoom ? {from: min, to: mid} : {from: max, to: mid};\n }\n\n interpolate(a: PossiblyEvaluatedPropertyValue>): PossiblyEvaluatedPropertyValue> {\n return a;\n }\n}\n/**\n * @internal\n * An implementation of `Property` for `*-pattern` and `line-dasharray`, which are transitioned by cross-fading\n * rather than interpolation.\n */\nexport class CrossFadedProperty implements Property> {\n specification: StylePropertySpecification;\n\n constructor(specification: StylePropertySpecification) {\n this.specification = specification;\n }\n\n possiblyEvaluate(\n value: PropertyValue>,\n parameters: EvaluationParameters,\n canonical?: CanonicalTileID,\n availableImages?: Array\n ): CrossFaded {\n if (value.value === undefined) {\n return undefined;\n } else if (value.expression.kind === 'constant') {\n const constant = value.expression.evaluate(parameters, null, {}, canonical, availableImages);\n return this._calculate(constant, constant, constant, parameters);\n } else {\n return this._calculate(\n value.expression.evaluate(new EvaluationParameters(Math.floor(parameters.zoom - 1.0), parameters)),\n value.expression.evaluate(new EvaluationParameters(Math.floor(parameters.zoom), parameters)),\n value.expression.evaluate(new EvaluationParameters(Math.floor(parameters.zoom + 1.0), parameters)),\n parameters);\n }\n }\n\n _calculate(min: T, mid: T, max: T, parameters: EvaluationParameters): CrossFaded {\n const z = parameters.zoom;\n return z > parameters.zoomHistory.lastIntegerZoom ? {from: min, to: mid} : {from: max, to: mid};\n }\n\n interpolate(a?: CrossFaded | null): CrossFaded {\n return a;\n }\n}\n\n/**\n * @internal\n * An implementation of `Property` for `heatmap-color` and `line-gradient`. Interpolation is a no-op, and\n * evaluation returns a boolean value in order to indicate its presence, but the real\n * evaluation happens in StyleLayer classes.\n */\n\nexport class ColorRampProperty implements Property {\n specification: StylePropertySpecification;\n\n constructor(specification: StylePropertySpecification) {\n this.specification = specification;\n }\n\n possiblyEvaluate(\n value: PropertyValue,\n parameters: EvaluationParameters,\n canonical?: CanonicalTileID,\n availableImages?: Array\n ): boolean {\n return !!value.expression.evaluate(parameters, null, {}, canonical, availableImages);\n }\n\n interpolate(): boolean { return false; }\n}\n\n/**\n * @internal\n * `Properties` holds objects containing default values for the layout or paint property set of a given\n * layer type. These objects are immutable, and they are used as the prototypes for the `_values` members of\n * `Transitionable`, `Transitioning`, `Layout`, and `PossiblyEvaluated`. This allows these classes to avoid\n * doing work in the common case where a property has no explicit value set and should be considered to take\n * on the default value: using `for (const property of Object.keys(this._values))`, they can iterate over\n * only the _own_ properties of `_values`, skipping repeated calculation of transitions and possible/final\n * evaluations for defaults, the result of which will always be the same.\n */\nexport class Properties {\n properties: Props;\n defaultPropertyValues: {[K in keyof Props]: PropertyValue};\n defaultTransitionablePropertyValues: {[K in keyof Props]: TransitionablePropertyValue};\n defaultTransitioningPropertyValues: {[K in keyof Props]: TransitioningPropertyValue};\n defaultPossiblyEvaluatedValues: {[K in keyof Props]: PossiblyEvaluatedPropertyValue};\n overridableProperties: Array;\n\n constructor(properties: Props) {\n this.properties = properties;\n this.defaultPropertyValues = ({} as any);\n this.defaultTransitionablePropertyValues = ({} as any);\n this.defaultTransitioningPropertyValues = ({} as any);\n this.defaultPossiblyEvaluatedValues = ({} as any);\n this.overridableProperties = ([] as any);\n\n for (const property in properties) {\n const prop = properties[property] as any;\n if (prop.specification.overridable) {\n this.overridableProperties.push(property);\n }\n const defaultPropertyValue = this.defaultPropertyValues[property] =\n new PropertyValue(prop, undefined);\n const defaultTransitionablePropertyValue = this.defaultTransitionablePropertyValues[property] =\n new TransitionablePropertyValue(prop);\n this.defaultTransitioningPropertyValues[property] =\n defaultTransitionablePropertyValue.untransitioned();\n this.defaultPossiblyEvaluatedValues[property] =\n defaultPropertyValue.possiblyEvaluate({} as any);\n }\n }\n}\n\nregister('DataDrivenProperty', DataDrivenProperty);\nregister('DataConstantProperty', DataConstantProperty);\nregister('CrossFadedDataDrivenProperty', CrossFadedDataDrivenProperty);\nregister('CrossFadedProperty', CrossFadedProperty);\nregister('ColorRampProperty', ColorRampProperty);\n","import {filterObject} from '../util/util';\n\nimport {latest as styleSpec, supportsPropertyExpression} from '@maplibre/maplibre-gl-style-spec';\nimport {\n validateStyle,\n validateLayoutProperty,\n validatePaintProperty,\n emitValidationErrors\n} from './validate_style';\nimport {Evented} from '../util/evented';\nimport {Layout, Transitionable, Transitioning, Properties, PossiblyEvaluated, PossiblyEvaluatedPropertyValue} from './properties';\n\nimport type {Bucket} from '../data/bucket';\nimport type Point from '@mapbox/point-geometry';\nimport type {FeatureFilter, FeatureState,\n LayerSpecification,\n FilterSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {TransitionParameters, PropertyValue} from './properties';\nimport {EvaluationParameters} from './evaluation_parameters';\nimport type {CrossfadeParameters} from './evaluation_parameters';\n\nimport type {Transform} from '../geo/transform';\nimport type {CustomLayerInterface} from './style_layer/custom_style_layer';\nimport type {Map} from '../ui/map';\nimport type {StyleSetterOptions} from './style';\nimport {mat4} from 'gl-matrix';\nimport type {VectorTileFeature} from '@mapbox/vector-tile';\n\nconst TRANSITION_SUFFIX = '-transition';\n\n/**\n * A base class for style layers\n */\nexport abstract class StyleLayer extends Evented {\n id: string;\n metadata: unknown;\n type: LayerSpecification['type'] | CustomLayerInterface['type'];\n source: string;\n sourceLayer: string;\n minzoom: number;\n maxzoom: number;\n filter: FilterSpecification | void;\n visibility: 'visible' | 'none' | void;\n _crossfadeParameters: CrossfadeParameters;\n\n _unevaluatedLayout: Layout;\n readonly layout: unknown;\n\n _transitionablePaint: Transitionable;\n _transitioningPaint: Transitioning;\n readonly paint: unknown;\n\n _featureFilter: FeatureFilter;\n\n readonly onAdd: ((map: Map) => void);\n readonly onRemove: ((map: Map) => void);\n\n queryRadius?(bucket: Bucket): number;\n queryIntersectsFeature?(\n queryGeometry: Array,\n feature: VectorTileFeature,\n featureState: FeatureState,\n geometry: Array>,\n zoom: number,\n transform: Transform,\n pixelsToTileUnits: number,\n pixelPosMatrix: mat4\n ): boolean | number;\n\n constructor(layer: LayerSpecification | CustomLayerInterface, properties: Readonly<{\n layout?: Properties;\n paint?: Properties;\n }>) {\n super();\n\n this.id = layer.id;\n this.type = layer.type;\n this._featureFilter = {filter: () => true, needGeometry: false};\n\n if (layer.type === 'custom') return;\n\n layer = (layer as any as LayerSpecification);\n\n this.metadata = layer.metadata;\n this.minzoom = layer.minzoom;\n this.maxzoom = layer.maxzoom;\n\n if (layer.type !== 'background') {\n this.source = layer.source;\n this.sourceLayer = layer['source-layer'];\n this.filter = layer.filter;\n }\n\n if (properties.layout) {\n this._unevaluatedLayout = new Layout(properties.layout);\n }\n\n if (properties.paint) {\n this._transitionablePaint = new Transitionable(properties.paint);\n\n for (const property in layer.paint) {\n this.setPaintProperty(property, layer.paint[property], {validate: false});\n }\n for (const property in layer.layout) {\n this.setLayoutProperty(property, layer.layout[property], {validate: false});\n }\n\n this._transitioningPaint = this._transitionablePaint.untransitioned();\n //$FlowFixMe\n this.paint = new PossiblyEvaluated(properties.paint);\n }\n }\n\n getCrossfadeParameters() {\n return this._crossfadeParameters;\n }\n\n getLayoutProperty(name: string) {\n if (name === 'visibility') {\n return this.visibility;\n }\n\n return this._unevaluatedLayout.getValue(name);\n }\n\n setLayoutProperty(name: string, value: any, options: StyleSetterOptions = {}) {\n if (value !== null && value !== undefined) {\n const key = `layers.${this.id}.layout.${name}`;\n if (this._validate(validateLayoutProperty, key, name, value, options)) {\n return;\n }\n }\n\n if (name === 'visibility') {\n this.visibility = value;\n return;\n }\n\n this._unevaluatedLayout.setValue(name, value);\n }\n\n getPaintProperty(name: string) {\n if (name.endsWith(TRANSITION_SUFFIX)) {\n return this._transitionablePaint.getTransition(name.slice(0, -TRANSITION_SUFFIX.length));\n } else {\n return this._transitionablePaint.getValue(name);\n }\n }\n\n setPaintProperty(name: string, value: unknown, options: StyleSetterOptions = {}) {\n if (value !== null && value !== undefined) {\n const key = `layers.${this.id}.paint.${name}`;\n if (this._validate(validatePaintProperty, key, name, value, options)) {\n return false;\n }\n }\n\n if (name.endsWith(TRANSITION_SUFFIX)) {\n this._transitionablePaint.setTransition(name.slice(0, -TRANSITION_SUFFIX.length), (value as any) || undefined);\n return false;\n } else {\n const transitionable = this._transitionablePaint._values[name];\n const isCrossFadedProperty = transitionable.property.specification['property-type'] === 'cross-faded-data-driven';\n const wasDataDriven = transitionable.value.isDataDriven();\n const oldValue = transitionable.value;\n\n this._transitionablePaint.setValue(name, value);\n this._handleSpecialPaintPropertyUpdate(name);\n\n const newValue = this._transitionablePaint._values[name].value;\n const isDataDriven = newValue.isDataDriven();\n\n // if a cross-faded value is changed, we need to make sure the new icons get added to each tile's iconAtlas\n // so a call to _updateLayer is necessary, and we return true from this function so it gets called in\n // Style#setPaintProperty\n return isDataDriven || wasDataDriven || isCrossFadedProperty || this._handleOverridablePaintPropertyUpdate(name, oldValue, newValue);\n }\n }\n\n _handleSpecialPaintPropertyUpdate(_: string) {\n // No-op; can be overridden by derived classes.\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n _handleOverridablePaintPropertyUpdate(name: string, oldValue: PropertyValue, newValue: PropertyValue): boolean {\n // No-op; can be overridden by derived classes.\n return false;\n }\n\n isHidden(zoom: number) {\n if (this.minzoom && zoom < this.minzoom) return true;\n if (this.maxzoom && zoom >= this.maxzoom) return true;\n return this.visibility === 'none';\n }\n\n updateTransitions(parameters: TransitionParameters) {\n this._transitioningPaint = this._transitionablePaint.transitioned(parameters, this._transitioningPaint);\n }\n\n hasTransition() {\n return this._transitioningPaint.hasTransition();\n }\n\n recalculate(parameters: EvaluationParameters, availableImages: Array) {\n if (parameters.getCrossfadeParameters) {\n this._crossfadeParameters = parameters.getCrossfadeParameters();\n }\n\n if (this._unevaluatedLayout) {\n (this as any).layout = this._unevaluatedLayout.possiblyEvaluate(parameters, undefined, availableImages);\n }\n\n (this as any).paint = this._transitioningPaint.possiblyEvaluate(parameters, undefined, availableImages);\n }\n\n serialize(): LayerSpecification {\n const output: LayerSpecification = {\n 'id': this.id,\n 'type': this.type as LayerSpecification['type'],\n 'source': this.source,\n 'source-layer': this.sourceLayer,\n 'metadata': this.metadata,\n 'minzoom': this.minzoom,\n 'maxzoom': this.maxzoom,\n 'filter': this.filter as FilterSpecification,\n 'layout': this._unevaluatedLayout && this._unevaluatedLayout.serialize(),\n 'paint': this._transitionablePaint && this._transitionablePaint.serialize()\n };\n\n if (this.visibility) {\n output.layout = output.layout || {};\n output.layout.visibility = this.visibility;\n }\n\n return filterObject(output, (value, key) => {\n return value !== undefined &&\n !(key === 'layout' && !Object.keys(value).length) &&\n !(key === 'paint' && !Object.keys(value).length);\n });\n }\n\n _validate(validate: Function, key: string, name: string, value: unknown, options: StyleSetterOptions = {}) {\n if (options && options.validate === false) {\n return false;\n }\n return emitValidationErrors(this, validate.call(validateStyle, {\n key,\n layerType: this.type,\n objectKey: name,\n value,\n styleSpec,\n // Workaround for https://github.com/mapbox/mapbox-gl-js/issues/2407\n style: {glyphs: true, sprite: true}\n }));\n }\n\n is3D() {\n return false;\n }\n\n isTileClipped() {\n return false;\n }\n\n hasOffscreenPass() {\n return false;\n }\n\n resize() {\n // noop\n }\n\n isStateDependent() {\n for (const property in (this as any).paint._values) {\n const value = (this as any).paint.get(property);\n if (!(value instanceof PossiblyEvaluatedPropertyValue) || !supportsPropertyExpression(value.property.specification)) {\n continue;\n }\n\n if ((value.value.kind === 'source' || value.value.kind === 'composite') &&\n value.value.isStateDependent) {\n return true;\n }\n }\n return false;\n }\n}\n","// Note: all \"sizes\" are measured in bytes\n\n/**\n * @internal\n * A view type size\n */\nconst viewTypes = {\n 'Int8': Int8Array,\n 'Uint8': Uint8Array,\n 'Int16': Int16Array,\n 'Uint16': Uint16Array,\n 'Int32': Int32Array,\n 'Uint32': Uint32Array,\n 'Float32': Float32Array\n};\n\n/**\n * @internal\n * A view type size\n */\nexport type ViewType = keyof typeof viewTypes;\n\n/** @internal */\nclass Struct {\n _pos1: number;\n _pos2: number;\n _pos4: number;\n _pos8: number;\n readonly _structArray: StructArray;\n\n // The following properties are defined on the prototype of sub classes.\n size: number;\n\n /**\n * @param structArray - The StructArray the struct is stored in\n * @param index - The index of the struct in the StructArray.\n */\n constructor(structArray: StructArray, index: number) {\n (this as any)._structArray = structArray;\n this._pos1 = index * this.size;\n this._pos2 = this._pos1 / 2;\n this._pos4 = this._pos1 / 4;\n this._pos8 = this._pos1 / 8;\n }\n}\n\nconst DEFAULT_CAPACITY = 128;\nconst RESIZE_MULTIPLIER = 5;\n\n/**\n * @internal\n * A struct array member\n */\nexport type StructArrayMember = {\n name: string;\n type: ViewType;\n components: number;\n offset: number;\n};\n\nexport type StructArrayLayout = {\n members: Array;\n size: number;\n alignment: number;\n};\n\n/**\n * An array that can be deserialized\n */\nexport type SerializedStructArray = {\n length: number;\n arrayBuffer: ArrayBuffer;\n};\n\n/**\n * @internal\n * `StructArray` provides an abstraction over `ArrayBuffer` and `TypedArray`\n * making it behave like an array of typed structs.\n *\n * Conceptually, a StructArray is comprised of elements, i.e., instances of its\n * associated struct type. Each particular struct type, together with an\n * alignment size, determines the memory layout of a StructArray whose elements\n * are of that type. Thus, for each such layout that we need, we have\n * a corresponding StructArrayLayout class, inheriting from StructArray and\n * implementing `emplaceBack()` and `_refreshViews()`.\n *\n * In some cases, where we need to access particular elements of a StructArray,\n * we implement a more specific subclass that inherits from one of the\n * StructArrayLayouts and adds a `get(i): T` accessor that returns a structured\n * object whose properties are proxies into the underlying memory space for the\n * i-th element. This affords the convenience of working with (seemingly) plain\n * Javascript objects without the overhead of serializing/deserializing them\n * into ArrayBuffers for efficient web worker transfer.\n */\nabstract class StructArray {\n capacity: number;\n length: number;\n isTransferred: boolean;\n arrayBuffer: ArrayBuffer;\n uint8: Uint8Array;\n\n // The following properties are defined on the prototype.\n members: Array;\n bytesPerElement: number;\n abstract emplaceBack(...v: number[]);\n abstract emplace(i: number, ...v: number[]);\n\n constructor() {\n this.isTransferred = false;\n this.capacity = -1;\n this.resize(0);\n }\n\n /**\n * Serialize a StructArray instance. Serializes both the raw data and the\n * metadata needed to reconstruct the StructArray base class during\n * deserialization.\n */\n static serialize(array: StructArray, transferables?: Array): SerializedStructArray {\n\n array._trim();\n\n if (transferables) {\n array.isTransferred = true;\n transferables.push(array.arrayBuffer);\n }\n\n return {\n length: array.length,\n arrayBuffer: array.arrayBuffer,\n };\n }\n\n static deserialize(input: SerializedStructArray) {\n const structArray = Object.create(this.prototype);\n structArray.arrayBuffer = input.arrayBuffer;\n structArray.length = input.length;\n structArray.capacity = input.arrayBuffer.byteLength / structArray.bytesPerElement;\n structArray._refreshViews();\n return structArray;\n }\n\n /**\n * Resize the array to discard unused capacity.\n */\n _trim() {\n if (this.length !== this.capacity) {\n this.capacity = this.length;\n this.arrayBuffer = this.arrayBuffer.slice(0, this.length * this.bytesPerElement);\n this._refreshViews();\n }\n }\n\n /**\n * Resets the length of the array to 0 without de-allocating capacity.\n */\n clear() {\n this.length = 0;\n }\n\n /**\n * Resize the array.\n * If `n` is greater than the current length then additional elements with undefined values are added.\n * If `n` is less than the current length then the array will be reduced to the first `n` elements.\n * @param n - The new size of the array.\n */\n resize(n: number) {\n this.reserve(n);\n this.length = n;\n }\n\n /**\n * Indicate a planned increase in size, so that any necessary allocation may\n * be done once, ahead of time.\n * @param n - The expected size of the array.\n */\n reserve(n: number) {\n if (n > this.capacity) {\n this.capacity = Math.max(n, Math.floor(this.capacity * RESIZE_MULTIPLIER), DEFAULT_CAPACITY);\n this.arrayBuffer = new ArrayBuffer(this.capacity * this.bytesPerElement);\n\n const oldUint8Array = this.uint8;\n this._refreshViews();\n if (oldUint8Array) this.uint8.set(oldUint8Array);\n }\n }\n\n /**\n * Create TypedArray views for the current ArrayBuffer.\n */\n _refreshViews() {\n throw new Error('_refreshViews() must be implemented by each concrete StructArray layout');\n }\n}\n\n/**\n * Given a list of member fields, create a full StructArrayLayout, in\n * particular calculating the correct byte offset for each field. This data\n * is used at build time to generate StructArrayLayout_*#emplaceBack() and\n * other accessors, and at runtime for binding vertex buffer attributes.\n */\nfunction createLayout(\n members: Array<{\n name: string;\n type: ViewType;\n readonly components?: number;\n }>,\n alignment: number = 1\n): StructArrayLayout {\n\n let offset = 0;\n let maxSize = 0;\n const layoutMembers = members.map((member) => {\n const typeSize = sizeOf(member.type);\n const memberOffset = offset = align(offset, Math.max(alignment, typeSize));\n const components = member.components || 1;\n\n maxSize = Math.max(maxSize, typeSize);\n offset += typeSize * components;\n\n return {\n name: member.name,\n type: member.type,\n components,\n offset: memberOffset,\n };\n });\n\n const size = align(offset, Math.max(maxSize, alignment));\n\n return {\n members: layoutMembers,\n size,\n alignment\n };\n}\n\nfunction sizeOf(type: ViewType): number {\n return viewTypes[type].BYTES_PER_ELEMENT;\n}\n\nfunction align(offset: number, size: number): number {\n return Math.ceil(offset / size) * size;\n}\n\nexport {StructArray, Struct, viewTypes, createLayout};\n","// This file is generated. Edit build/generate-struct-arrays.ts, then run `npm run codegen`.\n\nimport {Struct, StructArray} from '../util/struct_array';\nimport {register} from '../util/web_worker_transfer';\nimport Point from '@mapbox/point-geometry';\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Int16[2]\n *\n */\nclass StructArrayLayout2i4 extends StructArray {\n uint8: Uint8Array;\n int16: Int16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1);\n }\n\n public emplace(i: number, v0: number, v1: number) {\n const o2 = i * 2;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n return i;\n }\n}\n\nStructArrayLayout2i4.prototype.bytesPerElement = 4;\nregister('StructArrayLayout2i4', StructArrayLayout2i4);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Int16[3]\n *\n */\nclass StructArrayLayout3i6 extends StructArray {\n uint8: Uint8Array;\n int16: Int16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number) {\n const o2 = i * 3;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.int16[o2 + 2] = v2;\n return i;\n }\n}\n\nStructArrayLayout3i6.prototype.bytesPerElement = 6;\nregister('StructArrayLayout3i6', StructArrayLayout3i6);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Int16[4]\n *\n */\nclass StructArrayLayout4i8 extends StructArray {\n uint8: Uint8Array;\n int16: Int16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number, v3: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number, v3: number) {\n const o2 = i * 4;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.int16[o2 + 2] = v2;\n this.int16[o2 + 3] = v3;\n return i;\n }\n}\n\nStructArrayLayout4i8.prototype.bytesPerElement = 8;\nregister('StructArrayLayout4i8', StructArrayLayout4i8);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Int16[2]\n * [4] - Int16[4]\n *\n */\nclass StructArrayLayout2i4i12 extends StructArray {\n uint8: Uint8Array;\n int16: Int16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number, v3: number, v4: number, v5: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number, v3: number, v4: number, v5: number) {\n const o2 = i * 6;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.int16[o2 + 2] = v2;\n this.int16[o2 + 3] = v3;\n this.int16[o2 + 4] = v4;\n this.int16[o2 + 5] = v5;\n return i;\n }\n}\n\nStructArrayLayout2i4i12.prototype.bytesPerElement = 12;\nregister('StructArrayLayout2i4i12', StructArrayLayout2i4i12);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Int16[2]\n * [4] - Uint8[4]\n *\n */\nclass StructArrayLayout2i4ub8 extends StructArray {\n uint8: Uint8Array;\n int16: Int16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number, v3: number, v4: number, v5: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number, v3: number, v4: number, v5: number) {\n const o2 = i * 4;\n const o1 = i * 8;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.uint8[o1 + 4] = v2;\n this.uint8[o1 + 5] = v3;\n this.uint8[o1 + 6] = v4;\n this.uint8[o1 + 7] = v5;\n return i;\n }\n}\n\nStructArrayLayout2i4ub8.prototype.bytesPerElement = 8;\nregister('StructArrayLayout2i4ub8', StructArrayLayout2i4ub8);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Float32[2]\n *\n */\nclass StructArrayLayout2f8 extends StructArray {\n uint8: Uint8Array;\n float32: Float32Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1);\n }\n\n public emplace(i: number, v0: number, v1: number) {\n const o4 = i * 2;\n this.float32[o4 + 0] = v0;\n this.float32[o4 + 1] = v1;\n return i;\n }\n}\n\nStructArrayLayout2f8.prototype.bytesPerElement = 8;\nregister('StructArrayLayout2f8', StructArrayLayout2f8);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Uint16[10]\n *\n */\nclass StructArrayLayout10ui20 extends StructArray {\n uint8: Uint8Array;\n uint16: Uint16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number, v3: number, v4: number, v5: number, v6: number, v7: number, v8: number, v9: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8, v9);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number, v3: number, v4: number, v5: number, v6: number, v7: number, v8: number, v9: number) {\n const o2 = i * 10;\n this.uint16[o2 + 0] = v0;\n this.uint16[o2 + 1] = v1;\n this.uint16[o2 + 2] = v2;\n this.uint16[o2 + 3] = v3;\n this.uint16[o2 + 4] = v4;\n this.uint16[o2 + 5] = v5;\n this.uint16[o2 + 6] = v6;\n this.uint16[o2 + 7] = v7;\n this.uint16[o2 + 8] = v8;\n this.uint16[o2 + 9] = v9;\n return i;\n }\n}\n\nStructArrayLayout10ui20.prototype.bytesPerElement = 20;\nregister('StructArrayLayout10ui20', StructArrayLayout10ui20);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Int16[4]\n * [8] - Uint16[4]\n * [16] - Int16[4]\n *\n */\nclass StructArrayLayout4i4ui4i24 extends StructArray {\n uint8: Uint8Array;\n int16: Int16Array;\n uint16: Uint16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number, v3: number, v4: number, v5: number, v6: number, v7: number, v8: number, v9: number, v10: number, v11: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number, v3: number, v4: number, v5: number, v6: number, v7: number, v8: number, v9: number, v10: number, v11: number) {\n const o2 = i * 12;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.int16[o2 + 2] = v2;\n this.int16[o2 + 3] = v3;\n this.uint16[o2 + 4] = v4;\n this.uint16[o2 + 5] = v5;\n this.uint16[o2 + 6] = v6;\n this.uint16[o2 + 7] = v7;\n this.int16[o2 + 8] = v8;\n this.int16[o2 + 9] = v9;\n this.int16[o2 + 10] = v10;\n this.int16[o2 + 11] = v11;\n return i;\n }\n}\n\nStructArrayLayout4i4ui4i24.prototype.bytesPerElement = 24;\nregister('StructArrayLayout4i4ui4i24', StructArrayLayout4i4ui4i24);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Float32[3]\n *\n */\nclass StructArrayLayout3f12 extends StructArray {\n uint8: Uint8Array;\n float32: Float32Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number) {\n const o4 = i * 3;\n this.float32[o4 + 0] = v0;\n this.float32[o4 + 1] = v1;\n this.float32[o4 + 2] = v2;\n return i;\n }\n}\n\nStructArrayLayout3f12.prototype.bytesPerElement = 12;\nregister('StructArrayLayout3f12', StructArrayLayout3f12);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Uint32[1]\n *\n */\nclass StructArrayLayout1ul4 extends StructArray {\n uint8: Uint8Array;\n uint32: Uint32Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.uint32 = new Uint32Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0);\n }\n\n public emplace(i: number, v0: number) {\n const o4 = i * 1;\n this.uint32[o4 + 0] = v0;\n return i;\n }\n}\n\nStructArrayLayout1ul4.prototype.bytesPerElement = 4;\nregister('StructArrayLayout1ul4', StructArrayLayout1ul4);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Int16[6]\n * [12] - Uint32[1]\n * [16] - Uint16[2]\n *\n */\nclass StructArrayLayout6i1ul2ui20 extends StructArray {\n uint8: Uint8Array;\n int16: Int16Array;\n uint32: Uint32Array;\n uint16: Uint16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n this.uint32 = new Uint32Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number, v3: number, v4: number, v5: number, v6: number, v7: number, v8: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number, v3: number, v4: number, v5: number, v6: number, v7: number, v8: number) {\n const o2 = i * 10;\n const o4 = i * 5;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.int16[o2 + 2] = v2;\n this.int16[o2 + 3] = v3;\n this.int16[o2 + 4] = v4;\n this.int16[o2 + 5] = v5;\n this.uint32[o4 + 3] = v6;\n this.uint16[o2 + 8] = v7;\n this.uint16[o2 + 9] = v8;\n return i;\n }\n}\n\nStructArrayLayout6i1ul2ui20.prototype.bytesPerElement = 20;\nregister('StructArrayLayout6i1ul2ui20', StructArrayLayout6i1ul2ui20);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Int16[2]\n * [4] - Int16[2]\n * [8] - Int16[2]\n *\n */\nclass StructArrayLayout2i2i2i12 extends StructArray {\n uint8: Uint8Array;\n int16: Int16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number, v3: number, v4: number, v5: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number, v3: number, v4: number, v5: number) {\n const o2 = i * 6;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.int16[o2 + 2] = v2;\n this.int16[o2 + 3] = v3;\n this.int16[o2 + 4] = v4;\n this.int16[o2 + 5] = v5;\n return i;\n }\n}\n\nStructArrayLayout2i2i2i12.prototype.bytesPerElement = 12;\nregister('StructArrayLayout2i2i2i12', StructArrayLayout2i2i2i12);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Float32[2]\n * [8] - Float32[1]\n * [12] - Int16[2]\n *\n */\nclass StructArrayLayout2f1f2i16 extends StructArray {\n uint8: Uint8Array;\n float32: Float32Array;\n int16: Int16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number, v3: number, v4: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number, v3: number, v4: number) {\n const o4 = i * 4;\n const o2 = i * 8;\n this.float32[o4 + 0] = v0;\n this.float32[o4 + 1] = v1;\n this.float32[o4 + 2] = v2;\n this.int16[o2 + 6] = v3;\n this.int16[o2 + 7] = v4;\n return i;\n }\n}\n\nStructArrayLayout2f1f2i16.prototype.bytesPerElement = 16;\nregister('StructArrayLayout2f1f2i16', StructArrayLayout2f1f2i16);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Uint8[2]\n * [4] - Float32[2]\n * [12] - Int16[2]\n *\n */\nclass StructArrayLayout2ub2f2i16 extends StructArray {\n uint8: Uint8Array;\n float32: Float32Array;\n int16: Int16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number, v3: number, v4: number, v5: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number, v3: number, v4: number, v5: number) {\n const o1 = i * 16;\n const o4 = i * 4;\n const o2 = i * 8;\n this.uint8[o1 + 0] = v0;\n this.uint8[o1 + 1] = v1;\n this.float32[o4 + 1] = v2;\n this.float32[o4 + 2] = v3;\n this.int16[o2 + 6] = v4;\n this.int16[o2 + 7] = v5;\n return i;\n }\n}\n\nStructArrayLayout2ub2f2i16.prototype.bytesPerElement = 16;\nregister('StructArrayLayout2ub2f2i16', StructArrayLayout2ub2f2i16);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Uint16[3]\n *\n */\nclass StructArrayLayout3ui6 extends StructArray {\n uint8: Uint8Array;\n uint16: Uint16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number) {\n const o2 = i * 3;\n this.uint16[o2 + 0] = v0;\n this.uint16[o2 + 1] = v1;\n this.uint16[o2 + 2] = v2;\n return i;\n }\n}\n\nStructArrayLayout3ui6.prototype.bytesPerElement = 6;\nregister('StructArrayLayout3ui6', StructArrayLayout3ui6);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Int16[2]\n * [4] - Uint16[2]\n * [8] - Uint32[3]\n * [20] - Uint16[3]\n * [28] - Float32[2]\n * [36] - Uint8[3]\n * [40] - Uint32[1]\n * [44] - Int16[1]\n *\n */\nclass StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48 extends StructArray {\n uint8: Uint8Array;\n int16: Int16Array;\n uint16: Uint16Array;\n uint32: Uint32Array;\n float32: Float32Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n this.uint32 = new Uint32Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number, v3: number, v4: number, v5: number, v6: number, v7: number, v8: number, v9: number, v10: number, v11: number, v12: number, v13: number, v14: number, v15: number, v16: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15, v16);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number, v3: number, v4: number, v5: number, v6: number, v7: number, v8: number, v9: number, v10: number, v11: number, v12: number, v13: number, v14: number, v15: number, v16: number) {\n const o2 = i * 24;\n const o4 = i * 12;\n const o1 = i * 48;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.uint16[o2 + 2] = v2;\n this.uint16[o2 + 3] = v3;\n this.uint32[o4 + 2] = v4;\n this.uint32[o4 + 3] = v5;\n this.uint32[o4 + 4] = v6;\n this.uint16[o2 + 10] = v7;\n this.uint16[o2 + 11] = v8;\n this.uint16[o2 + 12] = v9;\n this.float32[o4 + 7] = v10;\n this.float32[o4 + 8] = v11;\n this.uint8[o1 + 36] = v12;\n this.uint8[o1 + 37] = v13;\n this.uint8[o1 + 38] = v14;\n this.uint32[o4 + 10] = v15;\n this.int16[o2 + 22] = v16;\n return i;\n }\n}\n\nStructArrayLayout2i2ui3ul3ui2f3ub1ul1i48.prototype.bytesPerElement = 48;\nregister('StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48', StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Int16[8]\n * [16] - Uint16[15]\n * [48] - Uint32[1]\n * [52] - Float32[2]\n * [60] - Uint16[2]\n *\n */\nclass StructArrayLayout8i15ui1ul2f2ui64 extends StructArray {\n uint8: Uint8Array;\n int16: Int16Array;\n uint16: Uint16Array;\n uint32: Uint32Array;\n float32: Float32Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.int16 = new Int16Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n this.uint32 = new Uint32Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number, v3: number, v4: number, v5: number, v6: number, v7: number, v8: number, v9: number, v10: number, v11: number, v12: number, v13: number, v14: number, v15: number, v16: number, v17: number, v18: number, v19: number, v20: number, v21: number, v22: number, v23: number, v24: number, v25: number, v26: number, v27: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15, v16, v17, v18, v19, v20, v21, v22, v23, v24, v25, v26, v27);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number, v3: number, v4: number, v5: number, v6: number, v7: number, v8: number, v9: number, v10: number, v11: number, v12: number, v13: number, v14: number, v15: number, v16: number, v17: number, v18: number, v19: number, v20: number, v21: number, v22: number, v23: number, v24: number, v25: number, v26: number, v27: number) {\n const o2 = i * 32;\n const o4 = i * 16;\n this.int16[o2 + 0] = v0;\n this.int16[o2 + 1] = v1;\n this.int16[o2 + 2] = v2;\n this.int16[o2 + 3] = v3;\n this.int16[o2 + 4] = v4;\n this.int16[o2 + 5] = v5;\n this.int16[o2 + 6] = v6;\n this.int16[o2 + 7] = v7;\n this.uint16[o2 + 8] = v8;\n this.uint16[o2 + 9] = v9;\n this.uint16[o2 + 10] = v10;\n this.uint16[o2 + 11] = v11;\n this.uint16[o2 + 12] = v12;\n this.uint16[o2 + 13] = v13;\n this.uint16[o2 + 14] = v14;\n this.uint16[o2 + 15] = v15;\n this.uint16[o2 + 16] = v16;\n this.uint16[o2 + 17] = v17;\n this.uint16[o2 + 18] = v18;\n this.uint16[o2 + 19] = v19;\n this.uint16[o2 + 20] = v20;\n this.uint16[o2 + 21] = v21;\n this.uint16[o2 + 22] = v22;\n this.uint32[o4 + 12] = v23;\n this.float32[o4 + 13] = v24;\n this.float32[o4 + 14] = v25;\n this.uint16[o2 + 30] = v26;\n this.uint16[o2 + 31] = v27;\n return i;\n }\n}\n\nStructArrayLayout8i15ui1ul2f2ui64.prototype.bytesPerElement = 64;\nregister('StructArrayLayout8i15ui1ul2f2ui64', StructArrayLayout8i15ui1ul2f2ui64);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Float32[1]\n *\n */\nclass StructArrayLayout1f4 extends StructArray {\n uint8: Uint8Array;\n float32: Float32Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0);\n }\n\n public emplace(i: number, v0: number) {\n const o4 = i * 1;\n this.float32[o4 + 0] = v0;\n return i;\n }\n}\n\nStructArrayLayout1f4.prototype.bytesPerElement = 4;\nregister('StructArrayLayout1f4', StructArrayLayout1f4);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Uint16[1]\n * [4] - Float32[2]\n *\n */\nclass StructArrayLayout1ui2f12 extends StructArray {\n uint8: Uint8Array;\n uint16: Uint16Array;\n float32: Float32Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number) {\n const o2 = i * 6;\n const o4 = i * 3;\n this.uint16[o2 + 0] = v0;\n this.float32[o4 + 1] = v1;\n this.float32[o4 + 2] = v2;\n return i;\n }\n}\n\nStructArrayLayout1ui2f12.prototype.bytesPerElement = 12;\nregister('StructArrayLayout1ui2f12', StructArrayLayout1ui2f12);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Uint32[1]\n * [4] - Uint16[2]\n *\n */\nclass StructArrayLayout1ul2ui8 extends StructArray {\n uint8: Uint8Array;\n uint32: Uint32Array;\n uint16: Uint16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.uint32 = new Uint32Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number) {\n const o4 = i * 2;\n const o2 = i * 4;\n this.uint32[o4 + 0] = v0;\n this.uint16[o2 + 2] = v1;\n this.uint16[o2 + 3] = v2;\n return i;\n }\n}\n\nStructArrayLayout1ul2ui8.prototype.bytesPerElement = 8;\nregister('StructArrayLayout1ul2ui8', StructArrayLayout1ul2ui8);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Uint16[2]\n *\n */\nclass StructArrayLayout2ui4 extends StructArray {\n uint8: Uint8Array;\n uint16: Uint16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1);\n }\n\n public emplace(i: number, v0: number, v1: number) {\n const o2 = i * 2;\n this.uint16[o2 + 0] = v0;\n this.uint16[o2 + 1] = v1;\n return i;\n }\n}\n\nStructArrayLayout2ui4.prototype.bytesPerElement = 4;\nregister('StructArrayLayout2ui4', StructArrayLayout2ui4);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Uint16[1]\n *\n */\nclass StructArrayLayout1ui2 extends StructArray {\n uint8: Uint8Array;\n uint16: Uint16Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.uint16 = new Uint16Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0);\n }\n\n public emplace(i: number, v0: number) {\n const o2 = i * 1;\n this.uint16[o2 + 0] = v0;\n return i;\n }\n}\n\nStructArrayLayout1ui2.prototype.bytesPerElement = 2;\nregister('StructArrayLayout1ui2', StructArrayLayout1ui2);\n\n/**\n * @internal\n * Implementation of the StructArray layout:\n * [0] - Float32[4]\n *\n */\nclass StructArrayLayout4f16 extends StructArray {\n uint8: Uint8Array;\n float32: Float32Array;\n\n _refreshViews() {\n this.uint8 = new Uint8Array(this.arrayBuffer);\n this.float32 = new Float32Array(this.arrayBuffer);\n }\n\n public emplaceBack(v0: number, v1: number, v2: number, v3: number) {\n const i = this.length;\n this.resize(i + 1);\n return this.emplace(i, v0, v1, v2, v3);\n }\n\n public emplace(i: number, v0: number, v1: number, v2: number, v3: number) {\n const o4 = i * 4;\n this.float32[o4 + 0] = v0;\n this.float32[o4 + 1] = v1;\n this.float32[o4 + 2] = v2;\n this.float32[o4 + 3] = v3;\n return i;\n }\n}\n\nStructArrayLayout4f16.prototype.bytesPerElement = 16;\nregister('StructArrayLayout4f16', StructArrayLayout4f16);\n\n/** @internal */\nclass CollisionBoxStruct extends Struct {\n _structArray: CollisionBoxArray;\n get anchorPointX() { return this._structArray.int16[this._pos2 + 0]; }\n get anchorPointY() { return this._structArray.int16[this._pos2 + 1]; }\n get x1() { return this._structArray.int16[this._pos2 + 2]; }\n get y1() { return this._structArray.int16[this._pos2 + 3]; }\n get x2() { return this._structArray.int16[this._pos2 + 4]; }\n get y2() { return this._structArray.int16[this._pos2 + 5]; }\n get featureIndex() { return this._structArray.uint32[this._pos4 + 3]; }\n get sourceLayerIndex() { return this._structArray.uint16[this._pos2 + 8]; }\n get bucketIndex() { return this._structArray.uint16[this._pos2 + 9]; }\n get anchorPoint() { return new Point(this.anchorPointX, this.anchorPointY); }\n}\n\nCollisionBoxStruct.prototype.size = 20;\n\nexport type CollisionBox = CollisionBoxStruct;\n\n/** @internal */\nexport class CollisionBoxArray extends StructArrayLayout6i1ul2ui20 {\n /**\n * Return the CollisionBoxStruct at the given location in the array.\n * @param index The index of the element.\n */\n get(index: number): CollisionBoxStruct {\n return new CollisionBoxStruct(this, index);\n }\n}\n\nregister('CollisionBoxArray', CollisionBoxArray);\n\n/** @internal */\nclass PlacedSymbolStruct extends Struct {\n _structArray: PlacedSymbolArray;\n get anchorX() { return this._structArray.int16[this._pos2 + 0]; }\n get anchorY() { return this._structArray.int16[this._pos2 + 1]; }\n get glyphStartIndex() { return this._structArray.uint16[this._pos2 + 2]; }\n get numGlyphs() { return this._structArray.uint16[this._pos2 + 3]; }\n get vertexStartIndex() { return this._structArray.uint32[this._pos4 + 2]; }\n get lineStartIndex() { return this._structArray.uint32[this._pos4 + 3]; }\n get lineLength() { return this._structArray.uint32[this._pos4 + 4]; }\n get segment() { return this._structArray.uint16[this._pos2 + 10]; }\n get lowerSize() { return this._structArray.uint16[this._pos2 + 11]; }\n get upperSize() { return this._structArray.uint16[this._pos2 + 12]; }\n get lineOffsetX() { return this._structArray.float32[this._pos4 + 7]; }\n get lineOffsetY() { return this._structArray.float32[this._pos4 + 8]; }\n get writingMode() { return this._structArray.uint8[this._pos1 + 36]; }\n get placedOrientation() { return this._structArray.uint8[this._pos1 + 37]; }\n set placedOrientation(x: number) { this._structArray.uint8[this._pos1 + 37] = x; }\n get hidden() { return this._structArray.uint8[this._pos1 + 38]; }\n set hidden(x: number) { this._structArray.uint8[this._pos1 + 38] = x; }\n get crossTileID() { return this._structArray.uint32[this._pos4 + 10]; }\n set crossTileID(x: number) { this._structArray.uint32[this._pos4 + 10] = x; }\n get associatedIconIndex() { return this._structArray.int16[this._pos2 + 22]; }\n}\n\nPlacedSymbolStruct.prototype.size = 48;\n\nexport type PlacedSymbol = PlacedSymbolStruct;\n\n/** @internal */\nexport class PlacedSymbolArray extends StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48 {\n /**\n * Return the PlacedSymbolStruct at the given location in the array.\n * @param index The index of the element.\n */\n get(index: number): PlacedSymbolStruct {\n return new PlacedSymbolStruct(this, index);\n }\n}\n\nregister('PlacedSymbolArray', PlacedSymbolArray);\n\n/** @internal */\nclass SymbolInstanceStruct extends Struct {\n _structArray: SymbolInstanceArray;\n get anchorX() { return this._structArray.int16[this._pos2 + 0]; }\n get anchorY() { return this._structArray.int16[this._pos2 + 1]; }\n get rightJustifiedTextSymbolIndex() { return this._structArray.int16[this._pos2 + 2]; }\n get centerJustifiedTextSymbolIndex() { return this._structArray.int16[this._pos2 + 3]; }\n get leftJustifiedTextSymbolIndex() { return this._structArray.int16[this._pos2 + 4]; }\n get verticalPlacedTextSymbolIndex() { return this._structArray.int16[this._pos2 + 5]; }\n get placedIconSymbolIndex() { return this._structArray.int16[this._pos2 + 6]; }\n get verticalPlacedIconSymbolIndex() { return this._structArray.int16[this._pos2 + 7]; }\n get key() { return this._structArray.uint16[this._pos2 + 8]; }\n get textBoxStartIndex() { return this._structArray.uint16[this._pos2 + 9]; }\n get textBoxEndIndex() { return this._structArray.uint16[this._pos2 + 10]; }\n get verticalTextBoxStartIndex() { return this._structArray.uint16[this._pos2 + 11]; }\n get verticalTextBoxEndIndex() { return this._structArray.uint16[this._pos2 + 12]; }\n get iconBoxStartIndex() { return this._structArray.uint16[this._pos2 + 13]; }\n get iconBoxEndIndex() { return this._structArray.uint16[this._pos2 + 14]; }\n get verticalIconBoxStartIndex() { return this._structArray.uint16[this._pos2 + 15]; }\n get verticalIconBoxEndIndex() { return this._structArray.uint16[this._pos2 + 16]; }\n get featureIndex() { return this._structArray.uint16[this._pos2 + 17]; }\n get numHorizontalGlyphVertices() { return this._structArray.uint16[this._pos2 + 18]; }\n get numVerticalGlyphVertices() { return this._structArray.uint16[this._pos2 + 19]; }\n get numIconVertices() { return this._structArray.uint16[this._pos2 + 20]; }\n get numVerticalIconVertices() { return this._structArray.uint16[this._pos2 + 21]; }\n get useRuntimeCollisionCircles() { return this._structArray.uint16[this._pos2 + 22]; }\n get crossTileID() { return this._structArray.uint32[this._pos4 + 12]; }\n set crossTileID(x: number) { this._structArray.uint32[this._pos4 + 12] = x; }\n get textBoxScale() { return this._structArray.float32[this._pos4 + 13]; }\n get collisionCircleDiameter() { return this._structArray.float32[this._pos4 + 14]; }\n get textAnchorOffsetStartIndex() { return this._structArray.uint16[this._pos2 + 30]; }\n get textAnchorOffsetEndIndex() { return this._structArray.uint16[this._pos2 + 31]; }\n}\n\nSymbolInstanceStruct.prototype.size = 64;\n\nexport type SymbolInstance = SymbolInstanceStruct;\n\n/** @internal */\nexport class SymbolInstanceArray extends StructArrayLayout8i15ui1ul2f2ui64 {\n /**\n * Return the SymbolInstanceStruct at the given location in the array.\n * @param index The index of the element.\n */\n get(index: number): SymbolInstanceStruct {\n return new SymbolInstanceStruct(this, index);\n }\n}\n\nregister('SymbolInstanceArray', SymbolInstanceArray);\n\n/** @internal */\nexport class GlyphOffsetArray extends StructArrayLayout1f4 {\n getoffsetX(index: number) { return this.float32[index * 1 + 0]; }\n}\n\nregister('GlyphOffsetArray', GlyphOffsetArray);\n\n/** @internal */\nexport class SymbolLineVertexArray extends StructArrayLayout3i6 {\n getx(index: number) { return this.int16[index * 3 + 0]; }\n gety(index: number) { return this.int16[index * 3 + 1]; }\n gettileUnitDistanceFromAnchor(index: number) { return this.int16[index * 3 + 2]; }\n}\n\nregister('SymbolLineVertexArray', SymbolLineVertexArray);\n\n/** @internal */\nclass TextAnchorOffsetStruct extends Struct {\n _structArray: TextAnchorOffsetArray;\n get textAnchor() { return this._structArray.uint16[this._pos2 + 0]; }\n get textOffset0() { return this._structArray.float32[this._pos4 + 1]; }\n get textOffset1() { return this._structArray.float32[this._pos4 + 2]; }\n}\n\nTextAnchorOffsetStruct.prototype.size = 12;\n\nexport type TextAnchorOffset = TextAnchorOffsetStruct;\n\n/** @internal */\nexport class TextAnchorOffsetArray extends StructArrayLayout1ui2f12 {\n /**\n * Return the TextAnchorOffsetStruct at the given location in the array.\n * @param index The index of the element.\n */\n get(index: number): TextAnchorOffsetStruct {\n return new TextAnchorOffsetStruct(this, index);\n }\n}\n\nregister('TextAnchorOffsetArray', TextAnchorOffsetArray);\n\n/** @internal */\nclass FeatureIndexStruct extends Struct {\n _structArray: FeatureIndexArray;\n get featureIndex() { return this._structArray.uint32[this._pos4 + 0]; }\n get sourceLayerIndex() { return this._structArray.uint16[this._pos2 + 2]; }\n get bucketIndex() { return this._structArray.uint16[this._pos2 + 3]; }\n}\n\nFeatureIndexStruct.prototype.size = 8;\n\nexport type FeatureIndex = FeatureIndexStruct;\n\n/** @internal */\nexport class FeatureIndexArray extends StructArrayLayout1ul2ui8 {\n /**\n * Return the FeatureIndexStruct at the given location in the array.\n * @param index The index of the element.\n */\n get(index: number): FeatureIndexStruct {\n return new FeatureIndexStruct(this, index);\n }\n}\n\nregister('FeatureIndexArray', FeatureIndexArray);\n\nexport class PosArray extends StructArrayLayout2i4 {}\nexport class Pos3dArray extends StructArrayLayout3i6 {}\nexport class RasterBoundsArray extends StructArrayLayout4i8 {}\nexport class CircleLayoutArray extends StructArrayLayout2i4 {}\nexport class FillLayoutArray extends StructArrayLayout2i4 {}\nexport class FillExtrusionLayoutArray extends StructArrayLayout2i4i12 {}\nexport class HeatmapLayoutArray extends StructArrayLayout2i4 {}\nexport class LineLayoutArray extends StructArrayLayout2i4ub8 {}\nexport class LineExtLayoutArray extends StructArrayLayout2f8 {}\nexport class PatternLayoutArray extends StructArrayLayout10ui20 {}\nexport class SymbolLayoutArray extends StructArrayLayout4i4ui4i24 {}\nexport class SymbolDynamicLayoutArray extends StructArrayLayout3f12 {}\nexport class SymbolOpacityArray extends StructArrayLayout1ul4 {}\nexport class CollisionBoxLayoutArray extends StructArrayLayout2i2i2i12 {}\nexport class CollisionCircleLayoutArray extends StructArrayLayout2f1f2i16 {}\nexport class CollisionVertexArray extends StructArrayLayout2ub2f2i16 {}\nexport class QuadTriangleArray extends StructArrayLayout3ui6 {}\nexport class TriangleIndexArray extends StructArrayLayout3ui6 {}\nexport class LineIndexArray extends StructArrayLayout2ui4 {}\nexport class LineStripIndexArray extends StructArrayLayout1ui2 {}\nexport {\n StructArrayLayout2i4,\n StructArrayLayout3i6,\n StructArrayLayout4i8,\n StructArrayLayout2i4i12,\n StructArrayLayout2i4ub8,\n StructArrayLayout2f8,\n StructArrayLayout10ui20,\n StructArrayLayout4i4ui4i24,\n StructArrayLayout3f12,\n StructArrayLayout1ul4,\n StructArrayLayout6i1ul2ui20,\n StructArrayLayout2i2i2i12,\n StructArrayLayout2f1f2i16,\n StructArrayLayout2ub2f2i16,\n StructArrayLayout3ui6,\n StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48,\n StructArrayLayout8i15ui1ul2f2ui64,\n StructArrayLayout1f4,\n StructArrayLayout1ui2f12,\n StructArrayLayout1ul2ui8,\n StructArrayLayout2ui4,\n StructArrayLayout1ui2,\n StructArrayLayout4f16\n};\n","import {createLayout} from '../../util/struct_array';\n\nconst layout = createLayout([\n {name: 'a_pos', components: 2, type: 'Int16'}\n], 4);\n\nexport default layout;\nexport const {members, size, alignment} = layout;\n","import {warnOnce} from '../util/util';\n\nimport {register} from '../util/web_worker_transfer';\n\nimport type {VertexArrayObject} from '../render/vertex_array_object';\nimport type {StructArray} from '../util/struct_array';\n\n/**\n * @internal\n * A single segment of a vector\n */\nexport type Segment = {\n sortKey?: number;\n vertexOffset: number;\n primitiveOffset: number;\n vertexLength: number;\n primitiveLength: number;\n vaos: {[_: string]: VertexArrayObject};\n};\n\n/**\n * @internal\n * Used for calculations on vector segments\n */\nexport class SegmentVector {\n static MAX_VERTEX_ARRAY_LENGTH: number;\n segments: Array;\n\n constructor(segments: Array = []) {\n this.segments = segments;\n }\n\n prepareSegment(\n numVertices: number,\n layoutVertexArray: StructArray,\n indexArray: StructArray,\n sortKey?: number\n ): Segment {\n let segment: Segment = this.segments[this.segments.length - 1];\n if (numVertices > SegmentVector.MAX_VERTEX_ARRAY_LENGTH) warnOnce(`Max vertices per segment is ${SegmentVector.MAX_VERTEX_ARRAY_LENGTH}: bucket requested ${numVertices}`);\n if (!segment || segment.vertexLength + numVertices > SegmentVector.MAX_VERTEX_ARRAY_LENGTH || segment.sortKey !== sortKey) {\n segment = ({\n vertexOffset: layoutVertexArray.length,\n primitiveOffset: indexArray.length,\n vertexLength: 0,\n primitiveLength: 0\n } as any);\n if (sortKey !== undefined) segment.sortKey = sortKey;\n this.segments.push(segment);\n }\n return segment;\n }\n\n get() {\n return this.segments;\n }\n\n destroy() {\n for (const segment of this.segments) {\n for (const k in segment.vaos) {\n segment.vaos[k].destroy();\n }\n }\n }\n\n static simpleSegment(\n vertexOffset: number,\n primitiveOffset: number,\n vertexLength: number,\n primitiveLength: number\n ): SegmentVector {\n return new SegmentVector([{\n vertexOffset,\n primitiveOffset,\n vertexLength,\n primitiveLength,\n vaos: {},\n sortKey: 0\n }]);\n }\n}\n\n/**\n * The maximum size of a vertex array. This limit is imposed by WebGL's 16 bit\n * addressing of vertex buffers.\n */\nSegmentVector.MAX_VERTEX_ARRAY_LENGTH = Math.pow(2, 16) - 1;\n\nregister('SegmentVector', SegmentVector);\n","import {clamp} from '../util/util';\n\n/**\n * Packs two numbers, interpreted as 8-bit unsigned integers, into a single\n * float. Unpack them in the shader using the `unpack_float()` function,\n * defined in _prelude.vertex.glsl\n */\nexport function packUint8ToFloat(a: number, b: number) {\n // coerce a and b to 8-bit ints\n a = clamp(Math.floor(a), 0, 255);\n b = clamp(Math.floor(b), 0, 255);\n return 256 * a + b;\n}\n","import {createLayout} from '../../util/struct_array';\n\nexport const patternAttributes = createLayout([\n // [tl.x, tl.y, br.x, br.y]\n {name: 'a_pattern_from', components: 4, type: 'Uint16'},\n {name: 'a_pattern_to', components: 4, type: 'Uint16'},\n {name: 'a_pixel_ratio_from', components: 1, type: 'Uint16'},\n {name: 'a_pixel_ratio_to', components: 1, type: 'Uint16'},\n]);\n","/**\n * JS Implementation of MurmurHash3 (r136) (as of May 20, 2011)\n * \n * @author Gary Court\n * @see http://github.com/garycourt/murmurhash-js\n * @author Austin Appleby\n * @see http://sites.google.com/site/murmurhash/\n * \n * @param {string} key ASCII only\n * @param {number} seed Positive integer only\n * @return {number} 32-bit positive integer hash \n */\n\nfunction murmurhash3_32_gc(key, seed) {\n\tvar remainder, bytes, h1, h1b, c1, c1b, c2, c2b, k1, i;\n\t\n\tremainder = key.length & 3; // key.length % 4\n\tbytes = key.length - remainder;\n\th1 = seed;\n\tc1 = 0xcc9e2d51;\n\tc2 = 0x1b873593;\n\ti = 0;\n\t\n\twhile (i < bytes) {\n\t \tk1 = \n\t \t ((key.charCodeAt(i) & 0xff)) |\n\t \t ((key.charCodeAt(++i) & 0xff) << 8) |\n\t \t ((key.charCodeAt(++i) & 0xff) << 16) |\n\t \t ((key.charCodeAt(++i) & 0xff) << 24);\n\t\t++i;\n\t\t\n\t\tk1 = ((((k1 & 0xffff) * c1) + ((((k1 >>> 16) * c1) & 0xffff) << 16))) & 0xffffffff;\n\t\tk1 = (k1 << 15) | (k1 >>> 17);\n\t\tk1 = ((((k1 & 0xffff) * c2) + ((((k1 >>> 16) * c2) & 0xffff) << 16))) & 0xffffffff;\n\n\t\th1 ^= k1;\n h1 = (h1 << 13) | (h1 >>> 19);\n\t\th1b = ((((h1 & 0xffff) * 5) + ((((h1 >>> 16) * 5) & 0xffff) << 16))) & 0xffffffff;\n\t\th1 = (((h1b & 0xffff) + 0x6b64) + ((((h1b >>> 16) + 0xe654) & 0xffff) << 16));\n\t}\n\t\n\tk1 = 0;\n\t\n\tswitch (remainder) {\n\t\tcase 3: k1 ^= (key.charCodeAt(i + 2) & 0xff) << 16;\n\t\tcase 2: k1 ^= (key.charCodeAt(i + 1) & 0xff) << 8;\n\t\tcase 1: k1 ^= (key.charCodeAt(i) & 0xff);\n\t\t\n\t\tk1 = (((k1 & 0xffff) * c1) + ((((k1 >>> 16) * c1) & 0xffff) << 16)) & 0xffffffff;\n\t\tk1 = (k1 << 15) | (k1 >>> 17);\n\t\tk1 = (((k1 & 0xffff) * c2) + ((((k1 >>> 16) * c2) & 0xffff) << 16)) & 0xffffffff;\n\t\th1 ^= k1;\n\t}\n\t\n\th1 ^= key.length;\n\n\th1 ^= h1 >>> 16;\n\th1 = (((h1 & 0xffff) * 0x85ebca6b) + ((((h1 >>> 16) * 0x85ebca6b) & 0xffff) << 16)) & 0xffffffff;\n\th1 ^= h1 >>> 13;\n\th1 = ((((h1 & 0xffff) * 0xc2b2ae35) + ((((h1 >>> 16) * 0xc2b2ae35) & 0xffff) << 16))) & 0xffffffff;\n\th1 ^= h1 >>> 16;\n\n\treturn h1 >>> 0;\n}\n\nif(typeof module !== \"undefined\") {\n module.exports = murmurhash3_32_gc\n}","/**\n * JS Implementation of MurmurHash2\n * \n * @author Gary Court\n * @see http://github.com/garycourt/murmurhash-js\n * @author Austin Appleby\n * @see http://sites.google.com/site/murmurhash/\n * \n * @param {string} str ASCII only\n * @param {number} seed Positive integer only\n * @return {number} 32-bit positive integer hash\n */\n\nfunction murmurhash2_32_gc(str, seed) {\n var\n l = str.length,\n h = seed ^ l,\n i = 0,\n k;\n \n while (l >= 4) {\n \tk = \n \t ((str.charCodeAt(i) & 0xff)) |\n \t ((str.charCodeAt(++i) & 0xff) << 8) |\n \t ((str.charCodeAt(++i) & 0xff) << 16) |\n \t ((str.charCodeAt(++i) & 0xff) << 24);\n \n k = (((k & 0xffff) * 0x5bd1e995) + ((((k >>> 16) * 0x5bd1e995) & 0xffff) << 16));\n k ^= k >>> 24;\n k = (((k & 0xffff) * 0x5bd1e995) + ((((k >>> 16) * 0x5bd1e995) & 0xffff) << 16));\n\n\th = (((h & 0xffff) * 0x5bd1e995) + ((((h >>> 16) * 0x5bd1e995) & 0xffff) << 16)) ^ k;\n\n l -= 4;\n ++i;\n }\n \n switch (l) {\n case 3: h ^= (str.charCodeAt(i + 2) & 0xff) << 16;\n case 2: h ^= (str.charCodeAt(i + 1) & 0xff) << 8;\n case 1: h ^= (str.charCodeAt(i) & 0xff);\n h = (((h & 0xffff) * 0x5bd1e995) + ((((h >>> 16) * 0x5bd1e995) & 0xffff) << 16));\n }\n\n h ^= h >>> 13;\n h = (((h & 0xffff) * 0x5bd1e995) + ((((h >>> 16) * 0x5bd1e995) & 0xffff) << 16));\n h ^= h >>> 15;\n\n return h >>> 0;\n}\n\nif(typeof module !== undefined) {\n module.exports = murmurhash2_32_gc\n}\n","var murmur3 = require(\"./murmurhash3_gc.js\")\nvar murmur2 = require(\"./murmurhash2_gc.js\")\n\nmodule.exports = murmur3\nmodule.exports.murmur3 = murmur3\nmodule.exports.murmur2 = murmur2\n","import murmur3 from 'murmurhash-js';\nimport {register} from '../util/web_worker_transfer';\n\ntype SerializedFeaturePositionMap = {\n ids: Float64Array;\n positions: Uint32Array;\n};\n\ntype FeaturePosition = {\n index: number;\n start: number;\n end: number;\n};\n\n// A transferable data structure that maps feature ids to their indices and buffer offsets\nexport class FeaturePositionMap {\n ids: Array;\n positions: Array;\n indexed: boolean;\n\n constructor() {\n this.ids = [];\n this.positions = [];\n this.indexed = false;\n }\n\n add(id: unknown, index: number, start: number, end: number) {\n this.ids.push(getNumericId(id));\n this.positions.push(index, start, end);\n }\n\n getPositions(id: unknown): Array {\n if (!this.indexed) throw new Error('Trying to get index, but feature positions are not indexed');\n\n const intId = getNumericId(id);\n\n // binary search for the first occurrence of id in this.ids;\n // relies on ids/positions being sorted by id, which happens in serialization\n let i = 0;\n let j = this.ids.length - 1;\n while (i < j) {\n const m = (i + j) >> 1;\n if (this.ids[m] >= intId) {\n j = m;\n } else {\n i = m + 1;\n }\n }\n const positions = [];\n while (this.ids[i] === intId) {\n const index = this.positions[3 * i];\n const start = this.positions[3 * i + 1];\n const end = this.positions[3 * i + 2];\n positions.push({index, start, end});\n i++;\n }\n return positions;\n }\n\n static serialize(map: FeaturePositionMap, transferables: Array): SerializedFeaturePositionMap {\n const ids = new Float64Array(map.ids);\n const positions = new Uint32Array(map.positions);\n\n sort(ids, positions, 0, ids.length - 1);\n\n if (transferables) {\n transferables.push(ids.buffer, positions.buffer);\n }\n\n return {ids, positions};\n }\n\n static deserialize(obj: SerializedFeaturePositionMap): FeaturePositionMap {\n const map = new FeaturePositionMap();\n // after transferring, we only use these arrays statically (no pushes),\n // so TypedArray vs Array distinction that flow points out doesn't matter\n map.ids = (obj.ids as any);\n map.positions = (obj.positions as any);\n map.indexed = true;\n return map;\n }\n}\n\nfunction getNumericId(value: unknown) {\n const numValue = +value;\n if (!isNaN(numValue) && numValue <= Number.MAX_SAFE_INTEGER) {\n return numValue;\n }\n return murmur3(String(value));\n}\n\n// custom quicksort that sorts ids, indices and offsets together (by ids)\n// uses Hoare partitioning & manual tail call optimization to avoid worst case scenarios\nfunction sort(ids, positions, left, right) {\n while (left < right) {\n const pivot = ids[(left + right) >> 1];\n let i = left - 1;\n let j = right + 1;\n\n while (true) {\n do i++; while (ids[i] < pivot);\n do j--; while (ids[j] > pivot);\n if (i >= j) break;\n swap(ids, i, j);\n swap(positions, 3 * i, 3 * j);\n swap(positions, 3 * i + 1, 3 * j + 1);\n swap(positions, 3 * i + 2, 3 * j + 2);\n }\n\n if (j - left < right - j) {\n sort(ids, positions, left, j);\n left = j + 1;\n } else {\n sort(ids, positions, j + 1, right);\n right = j;\n }\n }\n}\n\nfunction swap(arr, i, j) {\n const tmp = arr[i];\n arr[i] = arr[j];\n arr[j] = tmp;\n}\n\nregister('FeaturePositionMap', FeaturePositionMap);\n","import {Color} from '@maplibre/maplibre-gl-style-spec';\n\nimport type {Context} from '../gl/context';\nimport {mat4, vec2, vec3, vec4} from 'gl-matrix';\n\ntype $ObjMap any> = {\n [K in keyof T]: F extends (v: T[K]) => infer R ? R : never;\n};\n\nexport type UniformValues = $ObjMap(u: Uniform) => V>;\nexport type UniformLocations = {[_: string]: WebGLUniformLocation};\n\n/**\n * @internal\n * A base uniform abstract class\n */\nabstract class Uniform {\n gl: WebGLRenderingContext|WebGL2RenderingContext;\n location: WebGLUniformLocation;\n current: T;\n\n constructor(context: Context, location: WebGLUniformLocation) {\n this.gl = context.gl;\n this.location = location;\n }\n\n abstract set(v: T): void;\n}\n\nclass Uniform1i extends Uniform {\n constructor(context: Context, location: WebGLUniformLocation) {\n super(context, location);\n this.current = 0;\n }\n\n set(v: number): void {\n if (this.current !== v) {\n this.current = v;\n this.gl.uniform1i(this.location, v);\n }\n }\n}\n\nclass Uniform1f extends Uniform {\n constructor(context: Context, location: WebGLUniformLocation) {\n super(context, location);\n this.current = 0;\n }\n\n set(v: number): void {\n if (this.current !== v) {\n this.current = v;\n this.gl.uniform1f(this.location, v);\n }\n }\n}\n\nclass Uniform2f extends Uniform {\n constructor(context: Context, location: WebGLUniformLocation) {\n super(context, location);\n this.current = [0, 0];\n }\n\n set(v: vec2): void {\n if (v[0] !== this.current[0] || v[1] !== this.current[1]) {\n this.current = v;\n this.gl.uniform2f(this.location, v[0], v[1]);\n }\n }\n}\n\nclass Uniform3f extends Uniform {\n constructor(context: Context, location: WebGLUniformLocation) {\n super(context, location);\n this.current = [0, 0, 0];\n }\n\n set(v: vec3): void {\n if (v[0] !== this.current[0] || v[1] !== this.current[1] || v[2] !== this.current[2]) {\n this.current = v;\n this.gl.uniform3f(this.location, v[0], v[1], v[2]);\n }\n }\n}\n\nclass Uniform4f extends Uniform {\n constructor(context: Context, location: WebGLUniformLocation) {\n super(context, location);\n this.current = [0, 0, 0, 0];\n }\n\n set(v: vec4): void {\n if (v[0] !== this.current[0] || v[1] !== this.current[1] ||\n v[2] !== this.current[2] || v[3] !== this.current[3]) {\n this.current = v;\n this.gl.uniform4f(this.location, v[0], v[1], v[2], v[3]);\n }\n }\n}\n\nclass UniformColor extends Uniform {\n constructor(context: Context, location: WebGLUniformLocation) {\n super(context, location);\n this.current = Color.transparent;\n }\n\n set(v: Color): void {\n if (v.r !== this.current.r || v.g !== this.current.g ||\n v.b !== this.current.b || v.a !== this.current.a) {\n this.current = v;\n this.gl.uniform4f(this.location, v.r, v.g, v.b, v.a);\n }\n }\n}\n\nconst emptyMat4 = new Float32Array(16) as mat4;\nclass UniformMatrix4f extends Uniform {\n constructor(context: Context, location: WebGLUniformLocation) {\n super(context, location);\n this.current = emptyMat4;\n }\n\n set(v: mat4): void {\n // The vast majority of matrix comparisons that will trip this set\n // happen at i=12 or i=0, so we check those first to avoid lots of\n // unnecessary iteration:\n if (v[12] !== this.current[12] || v[0] !== this.current[0]) {\n this.current = v;\n this.gl.uniformMatrix4fv(this.location, false, v);\n return;\n }\n for (let i = 1; i < 16; i++) {\n if (v[i] !== this.current[i]) {\n this.current = v;\n this.gl.uniformMatrix4fv(this.location, false, v);\n break;\n }\n }\n }\n}\n\nexport {\n Uniform,\n Uniform1i,\n Uniform1f,\n Uniform2f,\n Uniform3f,\n Uniform4f,\n UniformColor,\n UniformMatrix4f\n};\n\n/**\n * @internal\n * A uniform bindings\n */\nexport type UniformBindings = {[_: string]: Uniform};\n","import {packUint8ToFloat} from '../shaders/encode_attribute';\nimport {Color, supportsPropertyExpression} from '@maplibre/maplibre-gl-style-spec';\nimport {register} from '../util/web_worker_transfer';\nimport {PossiblyEvaluatedPropertyValue} from '../style/properties';\nimport {StructArrayLayout1f4, StructArrayLayout2f8, StructArrayLayout4f16, PatternLayoutArray} from './array_types.g';\nimport {clamp} from '../util/util';\nimport {patternAttributes} from './bucket/pattern_attributes';\nimport {EvaluationParameters} from '../style/evaluation_parameters';\nimport {FeaturePositionMap} from './feature_position_map';\nimport {Uniform, Uniform1f, UniformColor, Uniform4f} from '../render/uniform_binding';\n\nimport type {UniformLocations} from '../render/uniform_binding';\n\nimport type {CanonicalTileID} from '../source/tile_id';\nimport type {Context} from '../gl/context';\nimport type {TypedStyleLayer} from '../style/style_layer/typed_style_layer';\nimport type {CrossfadeParameters} from '../style/evaluation_parameters';\nimport type {StructArray, StructArrayMember} from '../util/struct_array';\nimport type {VertexBuffer} from '../gl/vertex_buffer';\nimport type {ImagePosition} from '../render/image_atlas';\nimport type {\n Feature,\n FeatureState,\n GlobalProperties,\n SourceExpression,\n CompositeExpression,\n FormattedSection\n} from '@maplibre/maplibre-gl-style-spec';\nimport type {FeatureStates} from '../source/source_state';\nimport type {VectorTileLayer} from '@mapbox/vector-tile';\n\nexport type BinderUniform = {\n name: string;\n property: string;\n binding: Uniform;\n};\n\nfunction packColor(color: Color): [number, number] {\n return [\n packUint8ToFloat(255 * color.r, 255 * color.g),\n packUint8ToFloat(255 * color.b, 255 * color.a)\n ];\n}\n\n/**\n * `Binder` is the interface definition for the strategies for constructing,\n * uploading, and binding paint property data as GLSL attributes. Most style-\n * spec properties have a 1:1 relationship to shader attribute/uniforms, but\n * some require multiple values per feature to be passed to the GPU, and in\n * those cases we bind multiple attributes/uniforms.\n *\n * It has three implementations, one for each of the three strategies we use:\n *\n * * For _constant_ properties -- those whose value is a constant, or the constant\n * result of evaluating a camera expression at a particular camera position -- we\n * don't need a vertex attribute buffer, and instead use a uniform.\n * * For data expressions, we use a vertex buffer with a single attribute value,\n * the evaluated result of the source function for the given feature.\n * * For composite expressions, we use a vertex buffer with two attributes: min and\n * max values covering the range of zooms at which we expect the tile to be\n * displayed. These values are calculated by evaluating the composite expression for\n * the given feature at strategically chosen zoom levels. In addition to this\n * attribute data, we also use a uniform value which the shader uses to interpolate\n * between the min and max value at the final displayed zoom level. The use of a\n * uniform allows us to cheaply update the value on every frame.\n *\n * Note that the shader source varies depending on whether we're using a uniform or\n * attribute. We dynamically compile shaders at runtime to accommodate this.\n */\ninterface AttributeBinder {\n populatePaintArray(\n length: number,\n feature: Feature,\n imagePositions: {[_: string]: ImagePosition},\n canonical?: CanonicalTileID,\n formattedSection?: FormattedSection\n ): void;\n updatePaintArray(\n start: number,\n length: number,\n feature: Feature,\n featureState: FeatureState,\n imagePositions: {[_: string]: ImagePosition}\n ): void;\n upload(a: Context): void;\n destroy(): void;\n}\n\ninterface UniformBinder {\n uniformNames: Array;\n setUniform(\n uniform: Uniform,\n globals: GlobalProperties,\n currentValue: PossiblyEvaluatedPropertyValue,\n uniformName: string\n ): void;\n getBinding(context: Context, location: WebGLUniformLocation, name: string): Partial>;\n}\n\nclass ConstantBinder implements UniformBinder {\n value: unknown;\n type: string;\n uniformNames: Array;\n\n constructor(value: unknown, names: Array, type: string) {\n this.value = value;\n this.uniformNames = names.map(name => `u_${name}`);\n this.type = type;\n }\n\n setUniform(\n uniform: Uniform,\n globals: GlobalProperties,\n currentValue: PossiblyEvaluatedPropertyValue\n ): void {\n uniform.set(currentValue.constantOr(this.value));\n }\n\n getBinding(context: Context, location: WebGLUniformLocation, _: string): Partial> {\n return (this.type === 'color') ?\n new UniformColor(context, location) :\n new Uniform1f(context, location);\n }\n}\n\nclass CrossFadedConstantBinder implements UniformBinder {\n uniformNames: Array;\n patternFrom: Array;\n patternTo: Array;\n pixelRatioFrom: number;\n pixelRatioTo: number;\n\n constructor(value: unknown, names: Array) {\n this.uniformNames = names.map(name => `u_${name}`);\n this.patternFrom = null;\n this.patternTo = null;\n this.pixelRatioFrom = 1.0;\n this.pixelRatioTo = 1.0;\n }\n\n setConstantPatternPositions(posTo: ImagePosition, posFrom: ImagePosition) {\n this.pixelRatioFrom = posFrom.pixelRatio;\n this.pixelRatioTo = posTo.pixelRatio;\n this.patternFrom = posFrom.tlbr;\n this.patternTo = posTo.tlbr;\n }\n\n setUniform(uniform: Uniform, globals: GlobalProperties, currentValue: PossiblyEvaluatedPropertyValue, uniformName: string) {\n const pos =\n uniformName === 'u_pattern_to' ? this.patternTo :\n uniformName === 'u_pattern_from' ? this.patternFrom :\n uniformName === 'u_pixel_ratio_to' ? this.pixelRatioTo :\n uniformName === 'u_pixel_ratio_from' ? this.pixelRatioFrom : null;\n if (pos) uniform.set(pos);\n }\n\n getBinding(context: Context, location: WebGLUniformLocation, name: string): Partial> {\n return name.substr(0, 9) === 'u_pattern' ?\n new Uniform4f(context, location) :\n new Uniform1f(context, location);\n }\n}\n\nclass SourceExpressionBinder implements AttributeBinder {\n expression: SourceExpression;\n type: string;\n maxValue: number;\n\n paintVertexArray: StructArray;\n paintVertexAttributes: Array;\n paintVertexBuffer: VertexBuffer;\n\n constructor(expression: SourceExpression, names: Array, type: string, PaintVertexArray: {\n new (...args: any): StructArray;\n }) {\n this.expression = expression;\n this.type = type;\n this.maxValue = 0;\n this.paintVertexAttributes = names.map((name) => ({\n name: `a_${name}`,\n type: 'Float32',\n components: type === 'color' ? 2 : 1,\n offset: 0\n }));\n this.paintVertexArray = new PaintVertexArray();\n }\n\n populatePaintArray(newLength: number, feature: Feature, imagePositions: {[_: string]: ImagePosition}, canonical?: CanonicalTileID, formattedSection?: FormattedSection) {\n const start = this.paintVertexArray.length;\n const value = this.expression.evaluate(new EvaluationParameters(0), feature, {}, canonical, [], formattedSection);\n this.paintVertexArray.resize(newLength);\n this._setPaintValue(start, newLength, value);\n }\n\n updatePaintArray(start: number, end: number, feature: Feature, featureState: FeatureState) {\n const value = this.expression.evaluate({zoom: 0}, feature, featureState);\n this._setPaintValue(start, end, value);\n }\n\n _setPaintValue(start, end, value) {\n if (this.type === 'color') {\n const color = packColor(value);\n for (let i = start; i < end; i++) {\n this.paintVertexArray.emplace(i, color[0], color[1]);\n }\n } else {\n for (let i = start; i < end; i++) {\n this.paintVertexArray.emplace(i, value);\n }\n this.maxValue = Math.max(this.maxValue, Math.abs(value));\n }\n }\n\n upload(context: Context) {\n if (this.paintVertexArray && this.paintVertexArray.arrayBuffer) {\n if (this.paintVertexBuffer && this.paintVertexBuffer.buffer) {\n this.paintVertexBuffer.updateData(this.paintVertexArray);\n } else {\n this.paintVertexBuffer = context.createVertexBuffer(this.paintVertexArray, this.paintVertexAttributes, this.expression.isStateDependent);\n }\n }\n }\n\n destroy() {\n if (this.paintVertexBuffer) {\n this.paintVertexBuffer.destroy();\n }\n }\n}\n\nclass CompositeExpressionBinder implements AttributeBinder, UniformBinder {\n expression: CompositeExpression;\n uniformNames: Array;\n type: string;\n useIntegerZoom: boolean;\n zoom: number;\n maxValue: number;\n\n paintVertexArray: StructArray;\n paintVertexAttributes: Array;\n paintVertexBuffer: VertexBuffer;\n\n constructor(expression: CompositeExpression, names: Array, type: string, useIntegerZoom: boolean, zoom: number, PaintVertexArray: {\n new (...args: any): StructArray;\n }) {\n this.expression = expression;\n this.uniformNames = names.map(name => `u_${name}_t`);\n this.type = type;\n this.useIntegerZoom = useIntegerZoom;\n this.zoom = zoom;\n this.maxValue = 0;\n this.paintVertexAttributes = names.map((name) => ({\n name: `a_${name}`,\n type: 'Float32',\n components: type === 'color' ? 4 : 2,\n offset: 0\n }));\n this.paintVertexArray = new PaintVertexArray();\n }\n\n populatePaintArray(newLength: number, feature: Feature, imagePositions: {[_: string]: ImagePosition}, canonical?: CanonicalTileID, formattedSection?: FormattedSection) {\n const min = this.expression.evaluate(new EvaluationParameters(this.zoom), feature, {}, canonical, [], formattedSection);\n const max = this.expression.evaluate(new EvaluationParameters(this.zoom + 1), feature, {}, canonical, [], formattedSection);\n const start = this.paintVertexArray.length;\n this.paintVertexArray.resize(newLength);\n this._setPaintValue(start, newLength, min, max);\n }\n\n updatePaintArray(start: number, end: number, feature: Feature, featureState: FeatureState) {\n const min = this.expression.evaluate({zoom: this.zoom}, feature, featureState);\n const max = this.expression.evaluate({zoom: this.zoom + 1}, feature, featureState);\n this._setPaintValue(start, end, min, max);\n }\n\n _setPaintValue(start, end, min, max) {\n if (this.type === 'color') {\n const minColor = packColor(min);\n const maxColor = packColor(max);\n for (let i = start; i < end; i++) {\n this.paintVertexArray.emplace(i, minColor[0], minColor[1], maxColor[0], maxColor[1]);\n }\n } else {\n for (let i = start; i < end; i++) {\n this.paintVertexArray.emplace(i, min, max);\n }\n this.maxValue = Math.max(this.maxValue, Math.abs(min), Math.abs(max));\n }\n }\n\n upload(context: Context) {\n if (this.paintVertexArray && this.paintVertexArray.arrayBuffer) {\n if (this.paintVertexBuffer && this.paintVertexBuffer.buffer) {\n this.paintVertexBuffer.updateData(this.paintVertexArray);\n } else {\n this.paintVertexBuffer = context.createVertexBuffer(this.paintVertexArray, this.paintVertexAttributes, this.expression.isStateDependent);\n }\n }\n }\n\n destroy() {\n if (this.paintVertexBuffer) {\n this.paintVertexBuffer.destroy();\n }\n }\n\n setUniform(uniform: Uniform, globals: GlobalProperties): void {\n const currentZoom = this.useIntegerZoom ? Math.floor(globals.zoom) : globals.zoom;\n const factor = clamp(this.expression.interpolationFactor(currentZoom, this.zoom, this.zoom + 1), 0, 1);\n uniform.set(factor);\n }\n\n getBinding(context: Context, location: WebGLUniformLocation, _: string): Uniform1f {\n return new Uniform1f(context, location);\n }\n}\n\nclass CrossFadedCompositeBinder implements AttributeBinder {\n expression: CompositeExpression;\n type: string;\n useIntegerZoom: boolean;\n zoom: number;\n layerId: string;\n\n zoomInPaintVertexArray: StructArray;\n zoomOutPaintVertexArray: StructArray;\n zoomInPaintVertexBuffer: VertexBuffer;\n zoomOutPaintVertexBuffer: VertexBuffer;\n paintVertexAttributes: Array;\n\n constructor(expression: CompositeExpression, type: string, useIntegerZoom: boolean, zoom: number, PaintVertexArray: {\n new (...args: any): StructArray;\n }, layerId: string) {\n this.expression = expression;\n this.type = type;\n this.useIntegerZoom = useIntegerZoom;\n this.zoom = zoom;\n this.layerId = layerId;\n\n this.zoomInPaintVertexArray = new PaintVertexArray();\n this.zoomOutPaintVertexArray = new PaintVertexArray();\n }\n\n populatePaintArray(length: number, feature: Feature, imagePositions: {[_: string]: ImagePosition}) {\n const start = this.zoomInPaintVertexArray.length;\n this.zoomInPaintVertexArray.resize(length);\n this.zoomOutPaintVertexArray.resize(length);\n this._setPaintValues(start, length, feature.patterns && feature.patterns[this.layerId], imagePositions);\n }\n\n updatePaintArray(start: number, end: number, feature: Feature, featureState: FeatureState, imagePositions: {[_: string]: ImagePosition}) {\n this._setPaintValues(start, end, feature.patterns && feature.patterns[this.layerId], imagePositions);\n }\n\n _setPaintValues(start, end, patterns, positions) {\n if (!positions || !patterns) return;\n\n const {min, mid, max} = patterns;\n const imageMin = positions[min];\n const imageMid = positions[mid];\n const imageMax = positions[max];\n if (!imageMin || !imageMid || !imageMax) return;\n\n // We populate two paint arrays because, for cross-faded properties, we don't know which direction\n // we're cross-fading to at layout time. In order to keep vertex attributes to a minimum and not pass\n // unnecessary vertex data to the shaders, we determine which to upload at draw time.\n for (let i = start; i < end; i++) {\n this.zoomInPaintVertexArray.emplace(i,\n imageMid.tl[0], imageMid.tl[1], imageMid.br[0], imageMid.br[1],\n imageMin.tl[0], imageMin.tl[1], imageMin.br[0], imageMin.br[1],\n imageMid.pixelRatio,\n imageMin.pixelRatio,\n );\n this.zoomOutPaintVertexArray.emplace(i,\n imageMid.tl[0], imageMid.tl[1], imageMid.br[0], imageMid.br[1],\n imageMax.tl[0], imageMax.tl[1], imageMax.br[0], imageMax.br[1],\n imageMid.pixelRatio,\n imageMax.pixelRatio,\n );\n }\n }\n\n upload(context: Context) {\n if (this.zoomInPaintVertexArray && this.zoomInPaintVertexArray.arrayBuffer && this.zoomOutPaintVertexArray && this.zoomOutPaintVertexArray.arrayBuffer) {\n this.zoomInPaintVertexBuffer = context.createVertexBuffer(this.zoomInPaintVertexArray, patternAttributes.members, this.expression.isStateDependent);\n this.zoomOutPaintVertexBuffer = context.createVertexBuffer(this.zoomOutPaintVertexArray, patternAttributes.members, this.expression.isStateDependent);\n }\n }\n\n destroy() {\n if (this.zoomOutPaintVertexBuffer) this.zoomOutPaintVertexBuffer.destroy();\n if (this.zoomInPaintVertexBuffer) this.zoomInPaintVertexBuffer.destroy();\n }\n}\n\n/**\n * @internal\n * ProgramConfiguration contains the logic for binding style layer properties and tile\n * layer feature data into GL program uniforms and vertex attributes.\n *\n * Non-data-driven property values are bound to shader uniforms. Data-driven property\n * values are bound to vertex attributes. In order to support a uniform GLSL syntax over\n * both, [Mapbox GL Shaders](https://github.com/mapbox/mapbox-gl-shaders) defines a `#pragma`\n * abstraction, which ProgramConfiguration is responsible for implementing. At runtime,\n * it examines the attributes of a particular layer, combines this with fixed knowledge\n * about how layers of the particular type are implemented, and determines which uniforms\n * and vertex attributes will be required. It can then substitute the appropriate text\n * into the shader source code, create and link a program, and bind the uniforms and\n * vertex attributes in preparation for drawing.\n *\n * When a vector tile is parsed, this same configuration information is used to\n * populate the attribute buffers needed for data-driven styling using the zoom\n * level and feature property data.\n */\nexport class ProgramConfiguration {\n binders: {[_: string]: AttributeBinder | UniformBinder};\n cacheKey: string;\n\n _buffers: Array;\n\n constructor(layer: TypedStyleLayer, zoom: number, filterProperties: (_: string) => boolean) {\n this.binders = {};\n this._buffers = [];\n\n const keys = [];\n\n for (const property in layer.paint._values) {\n if (!filterProperties(property)) continue;\n const value = (layer.paint as any).get(property);\n if (!(value instanceof PossiblyEvaluatedPropertyValue) || !supportsPropertyExpression(value.property.specification)) {\n continue;\n }\n const names = paintAttributeNames(property, layer.type);\n const expression = value.value;\n const type = value.property.specification.type;\n const useIntegerZoom = (value.property as any).useIntegerZoom;\n const propType = value.property.specification['property-type'];\n const isCrossFaded = propType === 'cross-faded' || propType === 'cross-faded-data-driven';\n\n if (expression.kind === 'constant') {\n this.binders[property] = isCrossFaded ?\n new CrossFadedConstantBinder(expression.value, names) :\n new ConstantBinder(expression.value, names, type);\n keys.push(`/u_${property}`);\n\n } else if (expression.kind === 'source' || isCrossFaded) {\n const StructArrayLayout = layoutType(property, type, 'source');\n this.binders[property] = isCrossFaded ?\n new CrossFadedCompositeBinder(expression as CompositeExpression, type, useIntegerZoom, zoom, StructArrayLayout, layer.id) :\n new SourceExpressionBinder(expression as SourceExpression, names, type, StructArrayLayout);\n keys.push(`/a_${property}`);\n\n } else {\n const StructArrayLayout = layoutType(property, type, 'composite');\n this.binders[property] = new CompositeExpressionBinder(expression, names, type, useIntegerZoom, zoom, StructArrayLayout);\n keys.push(`/z_${property}`);\n }\n }\n\n this.cacheKey = keys.sort().join('');\n }\n\n getMaxValue(property: string): number {\n const binder = this.binders[property];\n return binder instanceof SourceExpressionBinder || binder instanceof CompositeExpressionBinder ? binder.maxValue : 0;\n }\n\n populatePaintArrays(newLength: number, feature: Feature, imagePositions: {[_: string]: ImagePosition}, canonical?: CanonicalTileID, formattedSection?: FormattedSection) {\n for (const property in this.binders) {\n const binder = this.binders[property];\n if (binder instanceof SourceExpressionBinder || binder instanceof CompositeExpressionBinder || binder instanceof CrossFadedCompositeBinder)\n (binder as AttributeBinder).populatePaintArray(newLength, feature, imagePositions, canonical, formattedSection);\n }\n }\n setConstantPatternPositions(posTo: ImagePosition, posFrom: ImagePosition) {\n for (const property in this.binders) {\n const binder = this.binders[property];\n if (binder instanceof CrossFadedConstantBinder)\n binder.setConstantPatternPositions(posTo, posFrom);\n }\n }\n\n updatePaintArrays(\n featureStates: FeatureStates,\n featureMap: FeaturePositionMap,\n vtLayer: VectorTileLayer,\n layer: TypedStyleLayer,\n imagePositions: {[_: string]: ImagePosition}\n ): boolean {\n let dirty: boolean = false;\n for (const id in featureStates) {\n const positions = featureMap.getPositions(id);\n\n for (const pos of positions) {\n const feature = vtLayer.feature(pos.index);\n\n for (const property in this.binders) {\n const binder = this.binders[property];\n if ((binder instanceof SourceExpressionBinder || binder instanceof CompositeExpressionBinder ||\n binder instanceof CrossFadedCompositeBinder) && (binder as any).expression.isStateDependent === true) {\n //AHM: Remove after https://github.com/mapbox/mapbox-gl-js/issues/6255\n const value = (layer.paint as any).get(property);\n (binder as any).expression = value.value;\n (binder as AttributeBinder).updatePaintArray(pos.start, pos.end, feature, featureStates[id], imagePositions);\n dirty = true;\n }\n }\n }\n }\n return dirty;\n }\n\n defines(): Array {\n const result = [];\n for (const property in this.binders) {\n const binder = this.binders[property];\n if (binder instanceof ConstantBinder || binder instanceof CrossFadedConstantBinder) {\n result.push(...binder.uniformNames.map(name => `#define HAS_UNIFORM_${name}`));\n }\n }\n return result;\n }\n\n getBinderAttributes(): Array {\n const result = [];\n for (const property in this.binders) {\n const binder = this.binders[property];\n if (binder instanceof SourceExpressionBinder || binder instanceof CompositeExpressionBinder) {\n for (let i = 0; i < binder.paintVertexAttributes.length; i++) {\n result.push(binder.paintVertexAttributes[i].name);\n }\n } else if (binder instanceof CrossFadedCompositeBinder) {\n for (let i = 0; i < patternAttributes.members.length; i++) {\n result.push(patternAttributes.members[i].name);\n }\n }\n }\n return result;\n }\n\n getBinderUniforms(): Array {\n const uniforms = [];\n for (const property in this.binders) {\n const binder = this.binders[property];\n if (binder instanceof ConstantBinder || binder instanceof CrossFadedConstantBinder || binder instanceof CompositeExpressionBinder) {\n for (const uniformName of binder.uniformNames) {\n uniforms.push(uniformName);\n }\n }\n }\n return uniforms;\n }\n\n getPaintVertexBuffers(): Array {\n return this._buffers;\n }\n\n getUniforms(context: Context, locations: UniformLocations): Array {\n const uniforms = [];\n for (const property in this.binders) {\n const binder = this.binders[property];\n if (binder instanceof ConstantBinder || binder instanceof CrossFadedConstantBinder || binder instanceof CompositeExpressionBinder) {\n for (const name of binder.uniformNames) {\n if (locations[name]) {\n const binding = binder.getBinding(context, locations[name], name);\n uniforms.push({name, property, binding});\n }\n }\n }\n }\n return uniforms;\n }\n\n setUniforms(\n context: Context,\n binderUniforms: Array,\n properties: any,\n globals: GlobalProperties\n ) {\n // Uniform state bindings are owned by the Program, but we set them\n // from within the ProgramConfiguration's binder members.\n for (const {name, property, binding} of binderUniforms) {\n (this.binders[property] as any).setUniform(binding, globals, properties.get(property), name);\n }\n }\n\n updatePaintBuffers(crossfade?: CrossfadeParameters) {\n this._buffers = [];\n\n for (const property in this.binders) {\n const binder = this.binders[property];\n if (crossfade && binder instanceof CrossFadedCompositeBinder) {\n const patternVertexBuffer = crossfade.fromScale === 2 ? binder.zoomInPaintVertexBuffer : binder.zoomOutPaintVertexBuffer;\n if (patternVertexBuffer) this._buffers.push(patternVertexBuffer);\n\n } else if ((binder instanceof SourceExpressionBinder || binder instanceof CompositeExpressionBinder) && binder.paintVertexBuffer) {\n this._buffers.push(binder.paintVertexBuffer);\n }\n }\n }\n\n upload(context: Context) {\n for (const property in this.binders) {\n const binder = this.binders[property];\n if (binder instanceof SourceExpressionBinder || binder instanceof CompositeExpressionBinder || binder instanceof CrossFadedCompositeBinder)\n binder.upload(context);\n }\n this.updatePaintBuffers();\n }\n\n destroy() {\n for (const property in this.binders) {\n const binder = this.binders[property];\n if (binder instanceof SourceExpressionBinder || binder instanceof CompositeExpressionBinder || binder instanceof CrossFadedCompositeBinder)\n binder.destroy();\n }\n }\n}\n\nexport class ProgramConfigurationSet {\n programConfigurations: {[_: string]: ProgramConfiguration};\n needsUpload: boolean;\n _featureMap: FeaturePositionMap;\n _bufferOffset: number;\n\n constructor(layers: ReadonlyArray, zoom: number, filterProperties: (_: string) => boolean = () => true) {\n this.programConfigurations = {};\n for (const layer of layers) {\n this.programConfigurations[layer.id] = new ProgramConfiguration(layer, zoom, filterProperties);\n }\n this.needsUpload = false;\n this._featureMap = new FeaturePositionMap();\n this._bufferOffset = 0;\n }\n\n populatePaintArrays(length: number, feature: Feature, index: number, imagePositions: {[_: string]: ImagePosition}, canonical: CanonicalTileID, formattedSection?: FormattedSection) {\n for (const key in this.programConfigurations) {\n this.programConfigurations[key].populatePaintArrays(length, feature, imagePositions, canonical, formattedSection);\n }\n\n if (feature.id !== undefined) {\n this._featureMap.add(feature.id, index, this._bufferOffset, length);\n }\n this._bufferOffset = length;\n\n this.needsUpload = true;\n }\n\n updatePaintArrays(featureStates: FeatureStates, vtLayer: VectorTileLayer, layers: ReadonlyArray, imagePositions: {[_: string]: ImagePosition}) {\n for (const layer of layers) {\n this.needsUpload = this.programConfigurations[layer.id].updatePaintArrays(featureStates, this._featureMap, vtLayer, layer, imagePositions) || this.needsUpload;\n }\n }\n\n get(layerId: string) {\n return this.programConfigurations[layerId];\n }\n\n upload(context: Context) {\n if (!this.needsUpload) return;\n for (const layerId in this.programConfigurations) {\n this.programConfigurations[layerId].upload(context);\n }\n this.needsUpload = false;\n }\n\n destroy() {\n for (const layerId in this.programConfigurations) {\n this.programConfigurations[layerId].destroy();\n }\n }\n}\n\nfunction paintAttributeNames(property, type) {\n const attributeNameExceptions = {\n 'text-opacity': ['opacity'],\n 'icon-opacity': ['opacity'],\n 'text-color': ['fill_color'],\n 'icon-color': ['fill_color'],\n 'text-halo-color': ['halo_color'],\n 'icon-halo-color': ['halo_color'],\n 'text-halo-blur': ['halo_blur'],\n 'icon-halo-blur': ['halo_blur'],\n 'text-halo-width': ['halo_width'],\n 'icon-halo-width': ['halo_width'],\n 'line-gap-width': ['gapwidth'],\n 'line-pattern': ['pattern_to', 'pattern_from', 'pixel_ratio_to', 'pixel_ratio_from'],\n 'fill-pattern': ['pattern_to', 'pattern_from', 'pixel_ratio_to', 'pixel_ratio_from'],\n 'fill-extrusion-pattern': ['pattern_to', 'pattern_from', 'pixel_ratio_to', 'pixel_ratio_from'],\n };\n\n return attributeNameExceptions[property] || [property.replace(`${type}-`, '').replace(/-/g, '_')];\n}\n\nfunction getLayoutException(property) {\n const propertyExceptions = {\n 'line-pattern': {\n 'source': PatternLayoutArray,\n 'composite': PatternLayoutArray\n },\n 'fill-pattern': {\n 'source': PatternLayoutArray,\n 'composite': PatternLayoutArray\n },\n 'fill-extrusion-pattern': {\n 'source': PatternLayoutArray,\n 'composite': PatternLayoutArray\n }\n };\n\n return propertyExceptions[property];\n}\n\nfunction layoutType(property, type, binderType) {\n const defaultLayouts = {\n 'color': {\n 'source': StructArrayLayout2f8,\n 'composite': StructArrayLayout4f16\n },\n 'number': {\n 'source': StructArrayLayout1f4,\n 'composite': StructArrayLayout2f8\n }\n };\n\n const layoutException = getLayoutException(property);\n return layoutException && layoutException[binderType] || defaultLayouts[type][binderType];\n}\n\nregister('ConstantBinder', ConstantBinder);\nregister('CrossFadedConstantBinder', CrossFadedConstantBinder);\nregister('SourceExpressionBinder', SourceExpressionBinder);\nregister('CrossFadedCompositeBinder', CrossFadedCompositeBinder);\nregister('CompositeExpressionBinder', CompositeExpressionBinder);\nregister('ProgramConfiguration', ProgramConfiguration, {omit: ['_buffers']});\nregister('ProgramConfigurationSet', ProgramConfigurationSet);\n","/**\n * The maximum value of a coordinate in the internal tile coordinate system. Coordinates of\n * all source features normalized to this extent upon load.\n *\n * The value is a consequence of the following:\n *\n * * Vertex buffer store positions as signed 16 bit integers.\n * * One bit is lost for signedness to support tile buffers.\n * * One bit is lost because the line vertex buffer used to pack 1 bit of other data into the int.\n * * One bit is lost to support features extending past the extent on the right edge of the tile.\n * * This leaves us with 2^13 = 8192\n */\nexport const EXTENT = 8192;\n","import {warnOnce, clamp} from '../util/util';\n\nimport {EXTENT} from './extent';\n\nimport type Point from '@mapbox/point-geometry';\nimport type {VectorTileFeature} from '@mapbox/vector-tile';\n\n// These bounds define the minimum and maximum supported coordinate values.\n// While visible coordinates are within [0, EXTENT], tiles may theoretically\n// contain coordinates within [-Infinity, Infinity]. Our range is limited by the\n// number of bits used to represent the coordinate.\nconst BITS = 15;\nconst MAX = Math.pow(2, BITS - 1) - 1;\nconst MIN = -MAX - 1;\n\n/**\n * Loads a geometry from a VectorTileFeature and scales it to the common extent\n * used internally.\n * @param feature - the vector tile feature to load\n */\nexport function loadGeometry(feature: VectorTileFeature): Array> {\n const scale = EXTENT / feature.extent;\n const geometry = feature.loadGeometry();\n for (let r = 0; r < geometry.length; r++) {\n const ring = geometry[r];\n for (let p = 0; p < ring.length; p++) {\n const point = ring[p];\n // round here because mapbox-gl-native uses integers to represent\n // points and we need to do the same to avoid renering differences.\n const x = Math.round(point.x * scale);\n const y = Math.round(point.y * scale);\n\n point.x = clamp(x, MIN, MAX);\n point.y = clamp(y, MIN, MAX);\n\n if (x < point.x || x > point.x + 1 || y < point.y || y > point.y + 1) {\n // warn when exceeding allowed extent except for the 1-px-off case\n // https://github.com/mapbox/mapbox-gl-js/issues/8992\n warnOnce('Geometry exceeds allowed extent, reduce your vector tile buffer size');\n }\n }\n }\n return geometry;\n}\n","import {loadGeometry} from './load_geometry';\nimport type Point from '@mapbox/point-geometry';\nimport type {VectorTileFeature} from '@mapbox/vector-tile';\nimport type {Feature} from '@maplibre/maplibre-gl-style-spec';\n\ntype EvaluationFeature = Feature & { geometry: Array> };\n/**\n * Construct a new feature based on a VectorTileFeature for expression evaluation, the geometry of which\n * will be loaded based on necessity.\n * @param feature - the feature to evaluate\n * @param needGeometry - if set to true this will load the geometry\n */\nexport function toEvaluationFeature(feature: VectorTileFeature, needGeometry: boolean): EvaluationFeature {\n return {type: feature.type,\n id: feature.id,\n properties: feature.properties,\n geometry: needGeometry ? loadGeometry(feature) : []};\n}\n","import {CircleLayoutArray} from '../array_types.g';\n\nimport {members as layoutAttributes} from './circle_attributes';\nimport {SegmentVector} from '../segment';\nimport {ProgramConfigurationSet} from '../program_configuration';\nimport {TriangleIndexArray} from '../index_array_type';\nimport {loadGeometry} from '../load_geometry';\nimport {toEvaluationFeature} from '../evaluation_feature';\nimport {EXTENT} from '../extent';\nimport {register} from '../../util/web_worker_transfer';\nimport {EvaluationParameters} from '../../style/evaluation_parameters';\n\nimport type {CanonicalTileID} from '../../source/tile_id';\nimport type {\n Bucket,\n BucketParameters,\n BucketFeature,\n IndexedFeature,\n PopulateParameters\n} from '../bucket';\nimport type {CircleStyleLayer} from '../../style/style_layer/circle_style_layer';\nimport type {HeatmapStyleLayer} from '../../style/style_layer/heatmap_style_layer';\nimport type {Context} from '../../gl/context';\nimport type {IndexBuffer} from '../../gl/index_buffer';\nimport type {VertexBuffer} from '../../gl/vertex_buffer';\nimport type Point from '@mapbox/point-geometry';\nimport type {FeatureStates} from '../../source/source_state';\nimport type {ImagePosition} from '../../render/image_atlas';\nimport type {VectorTileLayer} from '@mapbox/vector-tile';\n\nfunction addCircleVertex(layoutVertexArray, x, y, extrudeX, extrudeY) {\n layoutVertexArray.emplaceBack(\n (x * 2) + ((extrudeX + 1) / 2),\n (y * 2) + ((extrudeY + 1) / 2));\n}\n\n/**\n * @internal\n * Circles are represented by two triangles.\n *\n * Each corner has a pos that is the center of the circle and an extrusion\n * vector that is where it points.\n */\nexport class CircleBucket implements Bucket {\n index: number;\n zoom: number;\n overscaling: number;\n layerIds: Array;\n layers: Array;\n stateDependentLayers: Array;\n stateDependentLayerIds: Array;\n\n layoutVertexArray: CircleLayoutArray;\n layoutVertexBuffer: VertexBuffer;\n\n indexArray: TriangleIndexArray;\n indexBuffer: IndexBuffer;\n\n hasPattern: boolean;\n programConfigurations: ProgramConfigurationSet;\n segments: SegmentVector;\n uploaded: boolean;\n\n constructor(options: BucketParameters) {\n this.zoom = options.zoom;\n this.overscaling = options.overscaling;\n this.layers = options.layers;\n this.layerIds = this.layers.map(layer => layer.id);\n this.index = options.index;\n this.hasPattern = false;\n\n this.layoutVertexArray = new CircleLayoutArray();\n this.indexArray = new TriangleIndexArray();\n this.segments = new SegmentVector();\n this.programConfigurations = new ProgramConfigurationSet(options.layers, options.zoom);\n this.stateDependentLayerIds = this.layers.filter((l) => l.isStateDependent()).map((l) => l.id);\n }\n\n populate(features: Array, options: PopulateParameters, canonical: CanonicalTileID) {\n const styleLayer = this.layers[0];\n const bucketFeatures: BucketFeature[] = [];\n let circleSortKey = null;\n let sortFeaturesByKey = false;\n\n // Heatmap layers are handled in this bucket and have no evaluated properties, so we check our access\n if (styleLayer.type === 'circle') {\n circleSortKey = (styleLayer as CircleStyleLayer).layout.get('circle-sort-key');\n sortFeaturesByKey = !circleSortKey.isConstant();\n }\n\n for (const {feature, id, index, sourceLayerIndex} of features) {\n const needGeometry = this.layers[0]._featureFilter.needGeometry;\n const evaluationFeature = toEvaluationFeature(feature, needGeometry);\n\n if (!this.layers[0]._featureFilter.filter(new EvaluationParameters(this.zoom), evaluationFeature, canonical)) continue;\n\n const sortKey = sortFeaturesByKey ?\n circleSortKey.evaluate(evaluationFeature, {}, canonical) :\n undefined;\n\n const bucketFeature: BucketFeature = {\n id,\n properties: feature.properties,\n type: feature.type,\n sourceLayerIndex,\n index,\n geometry: needGeometry ? evaluationFeature.geometry : loadGeometry(feature),\n patterns: {},\n sortKey\n };\n\n bucketFeatures.push(bucketFeature);\n\n }\n\n if (sortFeaturesByKey) {\n bucketFeatures.sort((a, b) => a.sortKey - b.sortKey);\n }\n\n for (const bucketFeature of bucketFeatures) {\n const {geometry, index, sourceLayerIndex} = bucketFeature;\n const feature = features[index].feature;\n\n this.addFeature(bucketFeature, geometry, index, canonical);\n options.featureIndex.insert(feature, geometry, index, sourceLayerIndex, this.index);\n }\n }\n\n update(states: FeatureStates, vtLayer: VectorTileLayer, imagePositions: {[_: string]: ImagePosition}) {\n if (!this.stateDependentLayers.length) return;\n this.programConfigurations.updatePaintArrays(states, vtLayer, this.stateDependentLayers, imagePositions);\n }\n\n isEmpty() {\n return this.layoutVertexArray.length === 0;\n }\n\n uploadPending() {\n return !this.uploaded || this.programConfigurations.needsUpload;\n }\n\n upload(context: Context) {\n if (!this.uploaded) {\n this.layoutVertexBuffer = context.createVertexBuffer(this.layoutVertexArray, layoutAttributes);\n this.indexBuffer = context.createIndexBuffer(this.indexArray);\n }\n this.programConfigurations.upload(context);\n this.uploaded = true;\n }\n\n destroy() {\n if (!this.layoutVertexBuffer) return;\n this.layoutVertexBuffer.destroy();\n this.indexBuffer.destroy();\n this.programConfigurations.destroy();\n this.segments.destroy();\n }\n\n addFeature(feature: BucketFeature, geometry: Array>, index: number, canonical: CanonicalTileID) {\n for (const ring of geometry) {\n for (const point of ring) {\n const x = point.x;\n const y = point.y;\n\n // Do not include points that are outside the tile boundaries.\n if (x < 0 || x >= EXTENT || y < 0 || y >= EXTENT) continue;\n\n // this geometry will be of the Point type, and we'll derive\n // two triangles from it.\n //\n // ┌─────────┐\n // │ 3 2 │\n // │ │\n // │ 0 1 │\n // └─────────┘\n\n const segment = this.segments.prepareSegment(4, this.layoutVertexArray, this.indexArray, feature.sortKey);\n const index = segment.vertexLength;\n\n addCircleVertex(this.layoutVertexArray, x, y, -1, -1);\n addCircleVertex(this.layoutVertexArray, x, y, 1, -1);\n addCircleVertex(this.layoutVertexArray, x, y, 1, 1);\n addCircleVertex(this.layoutVertexArray, x, y, -1, 1);\n\n this.indexArray.emplaceBack(index, index + 1, index + 2);\n this.indexArray.emplaceBack(index, index + 3, index + 2);\n\n segment.vertexLength += 4;\n segment.primitiveLength += 2;\n }\n }\n\n this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, feature, index, {}, canonical);\n }\n}\n\nregister('CircleBucket', CircleBucket, {omit: ['layers']});\n","import {isCounterClockwise} from './util';\n\nimport Point from '@mapbox/point-geometry';\n\nexport {polygonIntersectsBufferedPoint, polygonIntersectsMultiPolygon, polygonIntersectsBufferedMultiLine, polygonIntersectsPolygon, distToSegmentSquared, polygonIntersectsBox};\n\ntype Line = Array;\ntype MultiLine = Array;\ntype Ring = Array;\ntype Polygon = Array;\ntype MultiPolygon = Array;\n\nfunction polygonIntersectsPolygon(polygonA: Polygon, polygonB: Polygon) {\n for (let i = 0; i < polygonA.length; i++) {\n if (polygonContainsPoint(polygonB, polygonA[i])) return true;\n }\n\n for (let i = 0; i < polygonB.length; i++) {\n if (polygonContainsPoint(polygonA, polygonB[i])) return true;\n }\n\n if (lineIntersectsLine(polygonA, polygonB)) return true;\n\n return false;\n}\n\nfunction polygonIntersectsBufferedPoint(polygon: Polygon, point: Point, radius: number) {\n if (polygonContainsPoint(polygon, point)) return true;\n if (pointIntersectsBufferedLine(point, polygon, radius)) return true;\n return false;\n}\n\nfunction polygonIntersectsMultiPolygon(polygon: Polygon, multiPolygon: MultiPolygon) {\n\n if (polygon.length === 1) {\n return multiPolygonContainsPoint(multiPolygon, polygon[0]);\n }\n\n for (let m = 0; m < multiPolygon.length; m++) {\n const ring = multiPolygon[m];\n for (let n = 0; n < ring.length; n++) {\n if (polygonContainsPoint(polygon, ring[n])) return true;\n }\n }\n\n for (let i = 0; i < polygon.length; i++) {\n if (multiPolygonContainsPoint(multiPolygon, polygon[i])) return true;\n }\n\n for (let k = 0; k < multiPolygon.length; k++) {\n if (lineIntersectsLine(polygon, multiPolygon[k])) return true;\n }\n\n return false;\n}\n\nfunction polygonIntersectsBufferedMultiLine(polygon: Polygon, multiLine: MultiLine, radius: number) {\n for (let i = 0; i < multiLine.length; i++) {\n const line = multiLine[i];\n\n if (polygon.length >= 3) {\n for (let k = 0; k < line.length; k++) {\n if (polygonContainsPoint(polygon, line[k])) return true;\n }\n }\n\n if (lineIntersectsBufferedLine(polygon, line, radius)) return true;\n }\n return false;\n}\n\nfunction lineIntersectsBufferedLine(lineA: Line, lineB: Line, radius: number) {\n\n if (lineA.length > 1) {\n if (lineIntersectsLine(lineA, lineB)) return true;\n\n // Check whether any point in either line is within radius of the other line\n for (let j = 0; j < lineB.length; j++) {\n if (pointIntersectsBufferedLine(lineB[j], lineA, radius)) return true;\n }\n }\n\n for (let k = 0; k < lineA.length; k++) {\n if (pointIntersectsBufferedLine(lineA[k], lineB, radius)) return true;\n }\n\n return false;\n}\n\nfunction lineIntersectsLine(lineA: Line, lineB: Line) {\n if (lineA.length === 0 || lineB.length === 0) return false;\n for (let i = 0; i < lineA.length - 1; i++) {\n const a0 = lineA[i];\n const a1 = lineA[i + 1];\n for (let j = 0; j < lineB.length - 1; j++) {\n const b0 = lineB[j];\n const b1 = lineB[j + 1];\n if (lineSegmentIntersectsLineSegment(a0, a1, b0, b1)) return true;\n }\n }\n return false;\n}\n\nfunction lineSegmentIntersectsLineSegment(a0: Point, a1: Point, b0: Point, b1: Point) {\n return isCounterClockwise(a0, b0, b1) !== isCounterClockwise(a1, b0, b1) &&\n isCounterClockwise(a0, a1, b0) !== isCounterClockwise(a0, a1, b1);\n}\n\nfunction pointIntersectsBufferedLine(p: Point, line: Line, radius: number) {\n const radiusSquared = radius * radius;\n\n if (line.length === 1) return p.distSqr(line[0]) < radiusSquared;\n\n for (let i = 1; i < line.length; i++) {\n // Find line segments that have a distance <= radius^2 to p\n // In that case, we treat the line as \"containing point p\".\n const v = line[i - 1], w = line[i];\n if (distToSegmentSquared(p, v, w) < radiusSquared) return true;\n }\n return false;\n}\n\n// Code from https://stackoverflow.com/a/1501725/331379.\nfunction distToSegmentSquared(p: Point, v: Point, w: Point) {\n const l2 = v.distSqr(w);\n if (l2 === 0) return p.distSqr(v);\n const t = ((p.x - v.x) * (w.x - v.x) + (p.y - v.y) * (w.y - v.y)) / l2;\n if (t < 0) return p.distSqr(v);\n if (t > 1) return p.distSqr(w);\n return p.distSqr(w.sub(v)._mult(t)._add(v));\n}\n\n// point in polygon ray casting algorithm\nfunction multiPolygonContainsPoint(rings: Array, p: Point) {\n let c = false,\n ring, p1, p2;\n\n for (let k = 0; k < rings.length; k++) {\n ring = rings[k];\n for (let i = 0, j = ring.length - 1; i < ring.length; j = i++) {\n p1 = ring[i];\n p2 = ring[j];\n if (((p1.y > p.y) !== (p2.y > p.y)) && (p.x < (p2.x - p1.x) * (p.y - p1.y) / (p2.y - p1.y) + p1.x)) {\n c = !c;\n }\n }\n }\n return c;\n}\n\nfunction polygonContainsPoint(ring: Ring, p: Point) {\n let c = false;\n for (let i = 0, j = ring.length - 1; i < ring.length; j = i++) {\n const p1 = ring[i];\n const p2 = ring[j];\n if (((p1.y > p.y) !== (p2.y > p.y)) && (p.x < (p2.x - p1.x) * (p.y - p1.y) / (p2.y - p1.y) + p1.x)) {\n c = !c;\n }\n }\n return c;\n}\n\nfunction polygonIntersectsBox(ring: Ring, boxX1: number, boxY1: number, boxX2: number, boxY2: number) {\n for (const p of ring) {\n if (boxX1 <= p.x &&\n boxY1 <= p.y &&\n boxX2 >= p.x &&\n boxY2 >= p.y) return true;\n }\n\n const corners = [\n new Point(boxX1, boxY1),\n new Point(boxX1, boxY2),\n new Point(boxX2, boxY2),\n new Point(boxX2, boxY1)];\n\n if (ring.length > 2) {\n for (const corner of corners) {\n if (polygonContainsPoint(ring, corner)) return true;\n }\n }\n\n for (let i = 0; i < ring.length - 1; i++) {\n const p1 = ring[i];\n const p2 = ring[i + 1];\n if (edgeIntersectsBox(p1, p2, corners)) return true;\n }\n\n return false;\n}\n\nfunction edgeIntersectsBox(e1: Point, e2: Point, corners: Array) {\n const tl = corners[0];\n const br = corners[2];\n // the edge and box do not intersect in either the x or y dimensions\n if (((e1.x < tl.x) && (e2.x < tl.x)) ||\n ((e1.x > br.x) && (e2.x > br.x)) ||\n ((e1.y < tl.y) && (e2.y < tl.y)) ||\n ((e1.y > br.y) && (e2.y > br.y))) return false;\n\n // check if all corners of the box are on the same side of the edge\n const dir = isCounterClockwise(e1, e2, corners[0]);\n return dir !== isCounterClockwise(e1, e2, corners[1]) ||\n dir !== isCounterClockwise(e1, e2, corners[2]) ||\n dir !== isCounterClockwise(e1, e2, corners[3]);\n}\n","import Point from '@mapbox/point-geometry';\n\nimport type {PossiblyEvaluatedPropertyValue} from './properties';\nimport type {StyleLayer} from '../style/style_layer';\nimport type {CircleBucket} from '../data/bucket/circle_bucket';\nimport type {LineBucket} from '../data/bucket/line_bucket';\n\nexport function getMaximumPaintValue(\n property: string,\n layer: StyleLayer,\n bucket: CircleBucket | LineBucket\n): number {\n const value = ((layer.paint as any).get(property) as PossiblyEvaluatedPropertyValue).value;\n if (value.kind === 'constant') {\n return value.value;\n } else {\n return bucket.programConfigurations.get(layer.id).getMaxValue(property);\n }\n}\n\nexport function translateDistance(translate: [number, number]) {\n return Math.sqrt(translate[0] * translate[0] + translate[1] * translate[1]);\n}\n\nexport function translate(queryGeometry: Array,\n translate: [number, number],\n translateAnchor: 'viewport' | 'map',\n bearing: number,\n pixelsToTileUnits: number) {\n if (!translate[0] && !translate[1]) {\n return queryGeometry;\n }\n const pt = Point.convert(translate)._mult(pixelsToTileUnits);\n\n if (translateAnchor === 'viewport') {\n pt._rotate(-bearing);\n }\n\n const translated = [];\n for (let i = 0; i < queryGeometry.length; i++) {\n const point = queryGeometry[i];\n translated.push(point.sub(pt));\n }\n return translated;\n}\n\nexport function offsetLine(rings: Array>, offset: number) {\n const newRings: Array> = [];\n for (let ringIndex = 0; ringIndex < rings.length; ringIndex++) {\n const ring = rings[ringIndex];\n const newRing: Array = [];\n for (let index = 0; index < ring.length; index++) {\n const a = ring[index - 1];\n const b = ring[index];\n const c = ring[index + 1];\n const aToB = index === 0 ? new Point(0, 0) : b.sub(a)._unit()._perp();\n const bToC = index === ring.length - 1 ? new Point(0, 0) : c.sub(b)._unit()._perp();\n const extrude = aToB._add(bToC)._unit();\n\n const cosHalfAngle = extrude.x * bToC.x + extrude.y * bToC.y;\n if (cosHalfAngle !== 0) {\n extrude._mult(1 / cosHalfAngle);\n }\n\n newRing.push(extrude._mult(offset)._add(b));\n }\n newRings.push(newRing);\n }\n return newRings;\n}\n","// This file is generated. Edit build/generate-style-code.ts, then run 'npm run codegen'.\n/* eslint-disable */\n\nimport {latest as styleSpec} from '@maplibre/maplibre-gl-style-spec';\n\nimport {\n Properties,\n DataConstantProperty,\n DataDrivenProperty,\n CrossFadedDataDrivenProperty,\n CrossFadedProperty,\n ColorRampProperty,\n PossiblyEvaluatedPropertyValue,\n CrossFaded\n} from '../properties';\n\nimport type {Color, Formatted, Padding, ResolvedImage, VariableAnchorOffsetCollection} from '@maplibre/maplibre-gl-style-spec';\nimport {StylePropertySpecification} from '@maplibre/maplibre-gl-style-spec';\n\nexport type CircleLayoutProps = {\n \"circle-sort-key\": DataDrivenProperty,\n};\n\nexport type CircleLayoutPropsPossiblyEvaluated = {\n \"circle-sort-key\": PossiblyEvaluatedPropertyValue,\n};\n\nlet layout: Properties;\nconst getLayout = () => layout = layout || new Properties({\n \"circle-sort-key\": new DataDrivenProperty(styleSpec[\"layout_circle\"][\"circle-sort-key\"] as any as StylePropertySpecification),\n});\n\nexport type CirclePaintProps = {\n \"circle-radius\": DataDrivenProperty,\n \"circle-color\": DataDrivenProperty,\n \"circle-blur\": DataDrivenProperty,\n \"circle-opacity\": DataDrivenProperty,\n \"circle-translate\": DataConstantProperty<[number, number]>,\n \"circle-translate-anchor\": DataConstantProperty<\"map\" | \"viewport\">,\n \"circle-pitch-scale\": DataConstantProperty<\"map\" | \"viewport\">,\n \"circle-pitch-alignment\": DataConstantProperty<\"map\" | \"viewport\">,\n \"circle-stroke-width\": DataDrivenProperty,\n \"circle-stroke-color\": DataDrivenProperty,\n \"circle-stroke-opacity\": DataDrivenProperty,\n};\n\nexport type CirclePaintPropsPossiblyEvaluated = {\n \"circle-radius\": PossiblyEvaluatedPropertyValue,\n \"circle-color\": PossiblyEvaluatedPropertyValue,\n \"circle-blur\": PossiblyEvaluatedPropertyValue,\n \"circle-opacity\": PossiblyEvaluatedPropertyValue,\n \"circle-translate\": [number, number],\n \"circle-translate-anchor\": \"map\" | \"viewport\",\n \"circle-pitch-scale\": \"map\" | \"viewport\",\n \"circle-pitch-alignment\": \"map\" | \"viewport\",\n \"circle-stroke-width\": PossiblyEvaluatedPropertyValue,\n \"circle-stroke-color\": PossiblyEvaluatedPropertyValue,\n \"circle-stroke-opacity\": PossiblyEvaluatedPropertyValue,\n};\n\nlet paint: Properties;\nconst getPaint = () => paint = paint || new Properties({\n \"circle-radius\": new DataDrivenProperty(styleSpec[\"paint_circle\"][\"circle-radius\"] as any as StylePropertySpecification),\n \"circle-color\": new DataDrivenProperty(styleSpec[\"paint_circle\"][\"circle-color\"] as any as StylePropertySpecification),\n \"circle-blur\": new DataDrivenProperty(styleSpec[\"paint_circle\"][\"circle-blur\"] as any as StylePropertySpecification),\n \"circle-opacity\": new DataDrivenProperty(styleSpec[\"paint_circle\"][\"circle-opacity\"] as any as StylePropertySpecification),\n \"circle-translate\": new DataConstantProperty(styleSpec[\"paint_circle\"][\"circle-translate\"] as any as StylePropertySpecification),\n \"circle-translate-anchor\": new DataConstantProperty(styleSpec[\"paint_circle\"][\"circle-translate-anchor\"] as any as StylePropertySpecification),\n \"circle-pitch-scale\": new DataConstantProperty(styleSpec[\"paint_circle\"][\"circle-pitch-scale\"] as any as StylePropertySpecification),\n \"circle-pitch-alignment\": new DataConstantProperty(styleSpec[\"paint_circle\"][\"circle-pitch-alignment\"] as any as StylePropertySpecification),\n \"circle-stroke-width\": new DataDrivenProperty(styleSpec[\"paint_circle\"][\"circle-stroke-width\"] as any as StylePropertySpecification),\n \"circle-stroke-color\": new DataDrivenProperty(styleSpec[\"paint_circle\"][\"circle-stroke-color\"] as any as StylePropertySpecification),\n \"circle-stroke-opacity\": new DataDrivenProperty(styleSpec[\"paint_circle\"][\"circle-stroke-opacity\"] as any as StylePropertySpecification),\n});\n\nexport default ({ get paint() { return getPaint() }, get layout() { return getLayout() } });","/**\n * Common utilities\n * @module glMatrix\n */\n// Configuration Constants\nexport var EPSILON = 0.000001;\nexport var ARRAY_TYPE = typeof Float32Array !== 'undefined' ? Float32Array : Array;\nexport var RANDOM = Math.random;\n/**\n * Sets the type of array used when creating new vectors and matrices\n *\n * @param {Float32ArrayConstructor | ArrayConstructor} type Array type, such as Float32Array or Array\n */\n\nexport function setMatrixArrayType(type) {\n ARRAY_TYPE = type;\n}\nvar degree = Math.PI / 180;\n/**\n * Convert Degree To Radian\n *\n * @param {Number} a Angle in Degrees\n */\n\nexport function toRadian(a) {\n return a * degree;\n}\n/**\n * Tests whether or not the arguments have approximately the same value, within an absolute\n * or relative tolerance of glMatrix.EPSILON (an absolute tolerance is used for values less\n * than or equal to 1.0, and a relative tolerance is used for larger values)\n *\n * @param {Number} a The first number to test.\n * @param {Number} b The second number to test.\n * @returns {Boolean} True if the numbers are approximately equal, false otherwise.\n */\n\nexport function equals(a, b) {\n return Math.abs(a - b) <= EPSILON * Math.max(1.0, Math.abs(a), Math.abs(b));\n}\nif (!Math.hypot) Math.hypot = function () {\n var y = 0,\n i = arguments.length;\n\n while (i--) {\n y += arguments[i] * arguments[i];\n }\n\n return Math.sqrt(y);\n};","import * as glMatrix from \"./common.js\";\n/**\n * 4x4 Matrix
Format: column-major, when typed out it looks like row-major
The matrices are being post multiplied.\n * @module mat4\n */\n\n/**\n * Creates a new identity mat4\n *\n * @returns {mat4} a new 4x4 matrix\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(16);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n }\n\n out[0] = 1;\n out[5] = 1;\n out[10] = 1;\n out[15] = 1;\n return out;\n}\n/**\n * Creates a new mat4 initialized with values from an existing matrix\n *\n * @param {ReadonlyMat4} a matrix to clone\n * @returns {mat4} a new 4x4 matrix\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(16);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n}\n/**\n * Copy the values from one mat4 to another\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the source matrix\n * @returns {mat4} out\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n}\n/**\n * Create a new mat4 with the given values\n *\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\n * @param {Number} m03 Component in column 0, row 3 position (index 3)\n * @param {Number} m10 Component in column 1, row 0 position (index 4)\n * @param {Number} m11 Component in column 1, row 1 position (index 5)\n * @param {Number} m12 Component in column 1, row 2 position (index 6)\n * @param {Number} m13 Component in column 1, row 3 position (index 7)\n * @param {Number} m20 Component in column 2, row 0 position (index 8)\n * @param {Number} m21 Component in column 2, row 1 position (index 9)\n * @param {Number} m22 Component in column 2, row 2 position (index 10)\n * @param {Number} m23 Component in column 2, row 3 position (index 11)\n * @param {Number} m30 Component in column 3, row 0 position (index 12)\n * @param {Number} m31 Component in column 3, row 1 position (index 13)\n * @param {Number} m32 Component in column 3, row 2 position (index 14)\n * @param {Number} m33 Component in column 3, row 3 position (index 15)\n * @returns {mat4} A new mat4\n */\n\nexport function fromValues(m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33) {\n var out = new glMatrix.ARRAY_TYPE(16);\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m03;\n out[4] = m10;\n out[5] = m11;\n out[6] = m12;\n out[7] = m13;\n out[8] = m20;\n out[9] = m21;\n out[10] = m22;\n out[11] = m23;\n out[12] = m30;\n out[13] = m31;\n out[14] = m32;\n out[15] = m33;\n return out;\n}\n/**\n * Set the components of a mat4 to the given values\n *\n * @param {mat4} out the receiving matrix\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\n * @param {Number} m03 Component in column 0, row 3 position (index 3)\n * @param {Number} m10 Component in column 1, row 0 position (index 4)\n * @param {Number} m11 Component in column 1, row 1 position (index 5)\n * @param {Number} m12 Component in column 1, row 2 position (index 6)\n * @param {Number} m13 Component in column 1, row 3 position (index 7)\n * @param {Number} m20 Component in column 2, row 0 position (index 8)\n * @param {Number} m21 Component in column 2, row 1 position (index 9)\n * @param {Number} m22 Component in column 2, row 2 position (index 10)\n * @param {Number} m23 Component in column 2, row 3 position (index 11)\n * @param {Number} m30 Component in column 3, row 0 position (index 12)\n * @param {Number} m31 Component in column 3, row 1 position (index 13)\n * @param {Number} m32 Component in column 3, row 2 position (index 14)\n * @param {Number} m33 Component in column 3, row 3 position (index 15)\n * @returns {mat4} out\n */\n\nexport function set(out, m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33) {\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m03;\n out[4] = m10;\n out[5] = m11;\n out[6] = m12;\n out[7] = m13;\n out[8] = m20;\n out[9] = m21;\n out[10] = m22;\n out[11] = m23;\n out[12] = m30;\n out[13] = m31;\n out[14] = m32;\n out[15] = m33;\n return out;\n}\n/**\n * Set a mat4 to the identity matrix\n *\n * @param {mat4} out the receiving matrix\n * @returns {mat4} out\n */\n\nexport function identity(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\n * Transpose the values of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the source matrix\n * @returns {mat4} out\n */\n\nexport function transpose(out, a) {\n // If we are transposing ourselves we can skip a few steps but have to cache some values\n if (out === a) {\n var a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a12 = a[6],\n a13 = a[7];\n var a23 = a[11];\n out[1] = a[4];\n out[2] = a[8];\n out[3] = a[12];\n out[4] = a01;\n out[6] = a[9];\n out[7] = a[13];\n out[8] = a02;\n out[9] = a12;\n out[11] = a[14];\n out[12] = a03;\n out[13] = a13;\n out[14] = a23;\n } else {\n out[0] = a[0];\n out[1] = a[4];\n out[2] = a[8];\n out[3] = a[12];\n out[4] = a[1];\n out[5] = a[5];\n out[6] = a[9];\n out[7] = a[13];\n out[8] = a[2];\n out[9] = a[6];\n out[10] = a[10];\n out[11] = a[14];\n out[12] = a[3];\n out[13] = a[7];\n out[14] = a[11];\n out[15] = a[15];\n }\n\n return out;\n}\n/**\n * Inverts a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the source matrix\n * @returns {mat4} out\n */\n\nexport function invert(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n var b00 = a00 * a11 - a01 * a10;\n var b01 = a00 * a12 - a02 * a10;\n var b02 = a00 * a13 - a03 * a10;\n var b03 = a01 * a12 - a02 * a11;\n var b04 = a01 * a13 - a03 * a11;\n var b05 = a02 * a13 - a03 * a12;\n var b06 = a20 * a31 - a21 * a30;\n var b07 = a20 * a32 - a22 * a30;\n var b08 = a20 * a33 - a23 * a30;\n var b09 = a21 * a32 - a22 * a31;\n var b10 = a21 * a33 - a23 * a31;\n var b11 = a22 * a33 - a23 * a32; // Calculate the determinant\n\n var det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n out[1] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n out[2] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n out[3] = (a22 * b04 - a21 * b05 - a23 * b03) * det;\n out[4] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n out[5] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n out[6] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n out[7] = (a20 * b05 - a22 * b02 + a23 * b01) * det;\n out[8] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n out[9] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n out[10] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n out[11] = (a21 * b02 - a20 * b04 - a23 * b00) * det;\n out[12] = (a11 * b07 - a10 * b09 - a12 * b06) * det;\n out[13] = (a00 * b09 - a01 * b07 + a02 * b06) * det;\n out[14] = (a31 * b01 - a30 * b03 - a32 * b00) * det;\n out[15] = (a20 * b03 - a21 * b01 + a22 * b00) * det;\n return out;\n}\n/**\n * Calculates the adjugate of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the source matrix\n * @returns {mat4} out\n */\n\nexport function adjoint(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n out[0] = a11 * (a22 * a33 - a23 * a32) - a21 * (a12 * a33 - a13 * a32) + a31 * (a12 * a23 - a13 * a22);\n out[1] = -(a01 * (a22 * a33 - a23 * a32) - a21 * (a02 * a33 - a03 * a32) + a31 * (a02 * a23 - a03 * a22));\n out[2] = a01 * (a12 * a33 - a13 * a32) - a11 * (a02 * a33 - a03 * a32) + a31 * (a02 * a13 - a03 * a12);\n out[3] = -(a01 * (a12 * a23 - a13 * a22) - a11 * (a02 * a23 - a03 * a22) + a21 * (a02 * a13 - a03 * a12));\n out[4] = -(a10 * (a22 * a33 - a23 * a32) - a20 * (a12 * a33 - a13 * a32) + a30 * (a12 * a23 - a13 * a22));\n out[5] = a00 * (a22 * a33 - a23 * a32) - a20 * (a02 * a33 - a03 * a32) + a30 * (a02 * a23 - a03 * a22);\n out[6] = -(a00 * (a12 * a33 - a13 * a32) - a10 * (a02 * a33 - a03 * a32) + a30 * (a02 * a13 - a03 * a12));\n out[7] = a00 * (a12 * a23 - a13 * a22) - a10 * (a02 * a23 - a03 * a22) + a20 * (a02 * a13 - a03 * a12);\n out[8] = a10 * (a21 * a33 - a23 * a31) - a20 * (a11 * a33 - a13 * a31) + a30 * (a11 * a23 - a13 * a21);\n out[9] = -(a00 * (a21 * a33 - a23 * a31) - a20 * (a01 * a33 - a03 * a31) + a30 * (a01 * a23 - a03 * a21));\n out[10] = a00 * (a11 * a33 - a13 * a31) - a10 * (a01 * a33 - a03 * a31) + a30 * (a01 * a13 - a03 * a11);\n out[11] = -(a00 * (a11 * a23 - a13 * a21) - a10 * (a01 * a23 - a03 * a21) + a20 * (a01 * a13 - a03 * a11));\n out[12] = -(a10 * (a21 * a32 - a22 * a31) - a20 * (a11 * a32 - a12 * a31) + a30 * (a11 * a22 - a12 * a21));\n out[13] = a00 * (a21 * a32 - a22 * a31) - a20 * (a01 * a32 - a02 * a31) + a30 * (a01 * a22 - a02 * a21);\n out[14] = -(a00 * (a11 * a32 - a12 * a31) - a10 * (a01 * a32 - a02 * a31) + a30 * (a01 * a12 - a02 * a11));\n out[15] = a00 * (a11 * a22 - a12 * a21) - a10 * (a01 * a22 - a02 * a21) + a20 * (a01 * a12 - a02 * a11);\n return out;\n}\n/**\n * Calculates the determinant of a mat4\n *\n * @param {ReadonlyMat4} a the source matrix\n * @returns {Number} determinant of a\n */\n\nexport function determinant(a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n var b00 = a00 * a11 - a01 * a10;\n var b01 = a00 * a12 - a02 * a10;\n var b02 = a00 * a13 - a03 * a10;\n var b03 = a01 * a12 - a02 * a11;\n var b04 = a01 * a13 - a03 * a11;\n var b05 = a02 * a13 - a03 * a12;\n var b06 = a20 * a31 - a21 * a30;\n var b07 = a20 * a32 - a22 * a30;\n var b08 = a20 * a33 - a23 * a30;\n var b09 = a21 * a32 - a22 * a31;\n var b10 = a21 * a33 - a23 * a31;\n var b11 = a22 * a33 - a23 * a32; // Calculate the determinant\n\n return b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n}\n/**\n * Multiplies two mat4s\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the first operand\n * @param {ReadonlyMat4} b the second operand\n * @returns {mat4} out\n */\n\nexport function multiply(out, a, b) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15]; // Cache only the current line of the second matrix\n\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n out[0] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[1] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[2] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[3] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[4];\n b1 = b[5];\n b2 = b[6];\n b3 = b[7];\n out[4] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[5] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[6] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[7] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[8];\n b1 = b[9];\n b2 = b[10];\n b3 = b[11];\n out[8] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[9] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[10] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[11] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[12];\n b1 = b[13];\n b2 = b[14];\n b3 = b[15];\n out[12] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[13] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[14] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[15] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n return out;\n}\n/**\n * Translate a mat4 by the given vector\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the matrix to translate\n * @param {ReadonlyVec3} v vector to translate by\n * @returns {mat4} out\n */\n\nexport function translate(out, a, v) {\n var x = v[0],\n y = v[1],\n z = v[2];\n var a00, a01, a02, a03;\n var a10, a11, a12, a13;\n var a20, a21, a22, a23;\n\n if (a === out) {\n out[12] = a[0] * x + a[4] * y + a[8] * z + a[12];\n out[13] = a[1] * x + a[5] * y + a[9] * z + a[13];\n out[14] = a[2] * x + a[6] * y + a[10] * z + a[14];\n out[15] = a[3] * x + a[7] * y + a[11] * z + a[15];\n } else {\n a00 = a[0];\n a01 = a[1];\n a02 = a[2];\n a03 = a[3];\n a10 = a[4];\n a11 = a[5];\n a12 = a[6];\n a13 = a[7];\n a20 = a[8];\n a21 = a[9];\n a22 = a[10];\n a23 = a[11];\n out[0] = a00;\n out[1] = a01;\n out[2] = a02;\n out[3] = a03;\n out[4] = a10;\n out[5] = a11;\n out[6] = a12;\n out[7] = a13;\n out[8] = a20;\n out[9] = a21;\n out[10] = a22;\n out[11] = a23;\n out[12] = a00 * x + a10 * y + a20 * z + a[12];\n out[13] = a01 * x + a11 * y + a21 * z + a[13];\n out[14] = a02 * x + a12 * y + a22 * z + a[14];\n out[15] = a03 * x + a13 * y + a23 * z + a[15];\n }\n\n return out;\n}\n/**\n * Scales the mat4 by the dimensions in the given vec3 not using vectorization\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the matrix to scale\n * @param {ReadonlyVec3} v the vec3 to scale the matrix by\n * @returns {mat4} out\n **/\n\nexport function scale(out, a, v) {\n var x = v[0],\n y = v[1],\n z = v[2];\n out[0] = a[0] * x;\n out[1] = a[1] * x;\n out[2] = a[2] * x;\n out[3] = a[3] * x;\n out[4] = a[4] * y;\n out[5] = a[5] * y;\n out[6] = a[6] * y;\n out[7] = a[7] * y;\n out[8] = a[8] * z;\n out[9] = a[9] * z;\n out[10] = a[10] * z;\n out[11] = a[11] * z;\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n}\n/**\n * Rotates a mat4 by the given angle around the given axis\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @param {ReadonlyVec3} axis the axis to rotate around\n * @returns {mat4} out\n */\n\nexport function rotate(out, a, rad, axis) {\n var x = axis[0],\n y = axis[1],\n z = axis[2];\n var len = Math.hypot(x, y, z);\n var s, c, t;\n var a00, a01, a02, a03;\n var a10, a11, a12, a13;\n var a20, a21, a22, a23;\n var b00, b01, b02;\n var b10, b11, b12;\n var b20, b21, b22;\n\n if (len < glMatrix.EPSILON) {\n return null;\n }\n\n len = 1 / len;\n x *= len;\n y *= len;\n z *= len;\n s = Math.sin(rad);\n c = Math.cos(rad);\n t = 1 - c;\n a00 = a[0];\n a01 = a[1];\n a02 = a[2];\n a03 = a[3];\n a10 = a[4];\n a11 = a[5];\n a12 = a[6];\n a13 = a[7];\n a20 = a[8];\n a21 = a[9];\n a22 = a[10];\n a23 = a[11]; // Construct the elements of the rotation matrix\n\n b00 = x * x * t + c;\n b01 = y * x * t + z * s;\n b02 = z * x * t - y * s;\n b10 = x * y * t - z * s;\n b11 = y * y * t + c;\n b12 = z * y * t + x * s;\n b20 = x * z * t + y * s;\n b21 = y * z * t - x * s;\n b22 = z * z * t + c; // Perform rotation-specific matrix multiplication\n\n out[0] = a00 * b00 + a10 * b01 + a20 * b02;\n out[1] = a01 * b00 + a11 * b01 + a21 * b02;\n out[2] = a02 * b00 + a12 * b01 + a22 * b02;\n out[3] = a03 * b00 + a13 * b01 + a23 * b02;\n out[4] = a00 * b10 + a10 * b11 + a20 * b12;\n out[5] = a01 * b10 + a11 * b11 + a21 * b12;\n out[6] = a02 * b10 + a12 * b11 + a22 * b12;\n out[7] = a03 * b10 + a13 * b11 + a23 * b12;\n out[8] = a00 * b20 + a10 * b21 + a20 * b22;\n out[9] = a01 * b20 + a11 * b21 + a21 * b22;\n out[10] = a02 * b20 + a12 * b21 + a22 * b22;\n out[11] = a03 * b20 + a13 * b21 + a23 * b22;\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged last row\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n }\n\n return out;\n}\n/**\n * Rotates a matrix by the given angle around the X axis\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\n\nexport function rotateX(out, a, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n var a10 = a[4];\n var a11 = a[5];\n var a12 = a[6];\n var a13 = a[7];\n var a20 = a[8];\n var a21 = a[9];\n var a22 = a[10];\n var a23 = a[11];\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged rows\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n } // Perform axis-specific matrix multiplication\n\n\n out[4] = a10 * c + a20 * s;\n out[5] = a11 * c + a21 * s;\n out[6] = a12 * c + a22 * s;\n out[7] = a13 * c + a23 * s;\n out[8] = a20 * c - a10 * s;\n out[9] = a21 * c - a11 * s;\n out[10] = a22 * c - a12 * s;\n out[11] = a23 * c - a13 * s;\n return out;\n}\n/**\n * Rotates a matrix by the given angle around the Y axis\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\n\nexport function rotateY(out, a, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n var a00 = a[0];\n var a01 = a[1];\n var a02 = a[2];\n var a03 = a[3];\n var a20 = a[8];\n var a21 = a[9];\n var a22 = a[10];\n var a23 = a[11];\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged rows\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n } // Perform axis-specific matrix multiplication\n\n\n out[0] = a00 * c - a20 * s;\n out[1] = a01 * c - a21 * s;\n out[2] = a02 * c - a22 * s;\n out[3] = a03 * c - a23 * s;\n out[8] = a00 * s + a20 * c;\n out[9] = a01 * s + a21 * c;\n out[10] = a02 * s + a22 * c;\n out[11] = a03 * s + a23 * c;\n return out;\n}\n/**\n * Rotates a matrix by the given angle around the Z axis\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\n\nexport function rotateZ(out, a, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n var a00 = a[0];\n var a01 = a[1];\n var a02 = a[2];\n var a03 = a[3];\n var a10 = a[4];\n var a11 = a[5];\n var a12 = a[6];\n var a13 = a[7];\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged last row\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n } // Perform axis-specific matrix multiplication\n\n\n out[0] = a00 * c + a10 * s;\n out[1] = a01 * c + a11 * s;\n out[2] = a02 * c + a12 * s;\n out[3] = a03 * c + a13 * s;\n out[4] = a10 * c - a00 * s;\n out[5] = a11 * c - a01 * s;\n out[6] = a12 * c - a02 * s;\n out[7] = a13 * c - a03 * s;\n return out;\n}\n/**\n * Creates a matrix from a vector translation\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.translate(dest, dest, vec);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {ReadonlyVec3} v Translation vector\n * @returns {mat4} out\n */\n\nexport function fromTranslation(out, v) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = v[0];\n out[13] = v[1];\n out[14] = v[2];\n out[15] = 1;\n return out;\n}\n/**\n * Creates a matrix from a vector scaling\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.scale(dest, dest, vec);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {ReadonlyVec3} v Scaling vector\n * @returns {mat4} out\n */\n\nexport function fromScaling(out, v) {\n out[0] = v[0];\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = v[1];\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = v[2];\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\n * Creates a matrix from a given angle around a given axis\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.rotate(dest, dest, rad, axis);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @param {ReadonlyVec3} axis the axis to rotate around\n * @returns {mat4} out\n */\n\nexport function fromRotation(out, rad, axis) {\n var x = axis[0],\n y = axis[1],\n z = axis[2];\n var len = Math.hypot(x, y, z);\n var s, c, t;\n\n if (len < glMatrix.EPSILON) {\n return null;\n }\n\n len = 1 / len;\n x *= len;\n y *= len;\n z *= len;\n s = Math.sin(rad);\n c = Math.cos(rad);\n t = 1 - c; // Perform rotation-specific matrix multiplication\n\n out[0] = x * x * t + c;\n out[1] = y * x * t + z * s;\n out[2] = z * x * t - y * s;\n out[3] = 0;\n out[4] = x * y * t - z * s;\n out[5] = y * y * t + c;\n out[6] = z * y * t + x * s;\n out[7] = 0;\n out[8] = x * z * t + y * s;\n out[9] = y * z * t - x * s;\n out[10] = z * z * t + c;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\n * Creates a matrix from the given angle around the X axis\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.rotateX(dest, dest, rad);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\n\nexport function fromXRotation(out, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad); // Perform axis-specific matrix multiplication\n\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = c;\n out[6] = s;\n out[7] = 0;\n out[8] = 0;\n out[9] = -s;\n out[10] = c;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\n * Creates a matrix from the given angle around the Y axis\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.rotateY(dest, dest, rad);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\n\nexport function fromYRotation(out, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad); // Perform axis-specific matrix multiplication\n\n out[0] = c;\n out[1] = 0;\n out[2] = -s;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = s;\n out[9] = 0;\n out[10] = c;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\n * Creates a matrix from the given angle around the Z axis\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.rotateZ(dest, dest, rad);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\n\nexport function fromZRotation(out, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad); // Perform axis-specific matrix multiplication\n\n out[0] = c;\n out[1] = s;\n out[2] = 0;\n out[3] = 0;\n out[4] = -s;\n out[5] = c;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\n * Creates a matrix from a quaternion rotation and vector translation\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.translate(dest, vec);\n * let quatMat = mat4.create();\n * quat4.toMat4(quat, quatMat);\n * mat4.multiply(dest, quatMat);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {ReadonlyVec3} v Translation vector\n * @returns {mat4} out\n */\n\nexport function fromRotationTranslation(out, q, v) {\n // Quaternion math\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var xy = x * y2;\n var xz = x * z2;\n var yy = y * y2;\n var yz = y * z2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n out[0] = 1 - (yy + zz);\n out[1] = xy + wz;\n out[2] = xz - wy;\n out[3] = 0;\n out[4] = xy - wz;\n out[5] = 1 - (xx + zz);\n out[6] = yz + wx;\n out[7] = 0;\n out[8] = xz + wy;\n out[9] = yz - wx;\n out[10] = 1 - (xx + yy);\n out[11] = 0;\n out[12] = v[0];\n out[13] = v[1];\n out[14] = v[2];\n out[15] = 1;\n return out;\n}\n/**\n * Creates a new mat4 from a dual quat.\n *\n * @param {mat4} out Matrix\n * @param {ReadonlyQuat2} a Dual Quaternion\n * @returns {mat4} mat4 receiving operation result\n */\n\nexport function fromQuat2(out, a) {\n var translation = new glMatrix.ARRAY_TYPE(3);\n var bx = -a[0],\n by = -a[1],\n bz = -a[2],\n bw = a[3],\n ax = a[4],\n ay = a[5],\n az = a[6],\n aw = a[7];\n var magnitude = bx * bx + by * by + bz * bz + bw * bw; //Only scale if it makes sense\n\n if (magnitude > 0) {\n translation[0] = (ax * bw + aw * bx + ay * bz - az * by) * 2 / magnitude;\n translation[1] = (ay * bw + aw * by + az * bx - ax * bz) * 2 / magnitude;\n translation[2] = (az * bw + aw * bz + ax * by - ay * bx) * 2 / magnitude;\n } else {\n translation[0] = (ax * bw + aw * bx + ay * bz - az * by) * 2;\n translation[1] = (ay * bw + aw * by + az * bx - ax * bz) * 2;\n translation[2] = (az * bw + aw * bz + ax * by - ay * bx) * 2;\n }\n\n fromRotationTranslation(out, a, translation);\n return out;\n}\n/**\n * Returns the translation vector component of a transformation\n * matrix. If a matrix is built with fromRotationTranslation,\n * the returned vector will be the same as the translation vector\n * originally supplied.\n * @param {vec3} out Vector to receive translation component\n * @param {ReadonlyMat4} mat Matrix to be decomposed (input)\n * @return {vec3} out\n */\n\nexport function getTranslation(out, mat) {\n out[0] = mat[12];\n out[1] = mat[13];\n out[2] = mat[14];\n return out;\n}\n/**\n * Returns the scaling factor component of a transformation\n * matrix. If a matrix is built with fromRotationTranslationScale\n * with a normalized Quaternion paramter, the returned vector will be\n * the same as the scaling vector\n * originally supplied.\n * @param {vec3} out Vector to receive scaling factor component\n * @param {ReadonlyMat4} mat Matrix to be decomposed (input)\n * @return {vec3} out\n */\n\nexport function getScaling(out, mat) {\n var m11 = mat[0];\n var m12 = mat[1];\n var m13 = mat[2];\n var m21 = mat[4];\n var m22 = mat[5];\n var m23 = mat[6];\n var m31 = mat[8];\n var m32 = mat[9];\n var m33 = mat[10];\n out[0] = Math.hypot(m11, m12, m13);\n out[1] = Math.hypot(m21, m22, m23);\n out[2] = Math.hypot(m31, m32, m33);\n return out;\n}\n/**\n * Returns a quaternion representing the rotational component\n * of a transformation matrix. If a matrix is built with\n * fromRotationTranslation, the returned quaternion will be the\n * same as the quaternion originally supplied.\n * @param {quat} out Quaternion to receive the rotation component\n * @param {ReadonlyMat4} mat Matrix to be decomposed (input)\n * @return {quat} out\n */\n\nexport function getRotation(out, mat) {\n var scaling = new glMatrix.ARRAY_TYPE(3);\n getScaling(scaling, mat);\n var is1 = 1 / scaling[0];\n var is2 = 1 / scaling[1];\n var is3 = 1 / scaling[2];\n var sm11 = mat[0] * is1;\n var sm12 = mat[1] * is2;\n var sm13 = mat[2] * is3;\n var sm21 = mat[4] * is1;\n var sm22 = mat[5] * is2;\n var sm23 = mat[6] * is3;\n var sm31 = mat[8] * is1;\n var sm32 = mat[9] * is2;\n var sm33 = mat[10] * is3;\n var trace = sm11 + sm22 + sm33;\n var S = 0;\n\n if (trace > 0) {\n S = Math.sqrt(trace + 1.0) * 2;\n out[3] = 0.25 * S;\n out[0] = (sm23 - sm32) / S;\n out[1] = (sm31 - sm13) / S;\n out[2] = (sm12 - sm21) / S;\n } else if (sm11 > sm22 && sm11 > sm33) {\n S = Math.sqrt(1.0 + sm11 - sm22 - sm33) * 2;\n out[3] = (sm23 - sm32) / S;\n out[0] = 0.25 * S;\n out[1] = (sm12 + sm21) / S;\n out[2] = (sm31 + sm13) / S;\n } else if (sm22 > sm33) {\n S = Math.sqrt(1.0 + sm22 - sm11 - sm33) * 2;\n out[3] = (sm31 - sm13) / S;\n out[0] = (sm12 + sm21) / S;\n out[1] = 0.25 * S;\n out[2] = (sm23 + sm32) / S;\n } else {\n S = Math.sqrt(1.0 + sm33 - sm11 - sm22) * 2;\n out[3] = (sm12 - sm21) / S;\n out[0] = (sm31 + sm13) / S;\n out[1] = (sm23 + sm32) / S;\n out[2] = 0.25 * S;\n }\n\n return out;\n}\n/**\n * Creates a matrix from a quaternion rotation, vector translation and vector scale\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.translate(dest, vec);\n * let quatMat = mat4.create();\n * quat4.toMat4(quat, quatMat);\n * mat4.multiply(dest, quatMat);\n * mat4.scale(dest, scale)\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {ReadonlyVec3} v Translation vector\n * @param {ReadonlyVec3} s Scaling vector\n * @returns {mat4} out\n */\n\nexport function fromRotationTranslationScale(out, q, v, s) {\n // Quaternion math\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var xy = x * y2;\n var xz = x * z2;\n var yy = y * y2;\n var yz = y * z2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n var sx = s[0];\n var sy = s[1];\n var sz = s[2];\n out[0] = (1 - (yy + zz)) * sx;\n out[1] = (xy + wz) * sx;\n out[2] = (xz - wy) * sx;\n out[3] = 0;\n out[4] = (xy - wz) * sy;\n out[5] = (1 - (xx + zz)) * sy;\n out[6] = (yz + wx) * sy;\n out[7] = 0;\n out[8] = (xz + wy) * sz;\n out[9] = (yz - wx) * sz;\n out[10] = (1 - (xx + yy)) * sz;\n out[11] = 0;\n out[12] = v[0];\n out[13] = v[1];\n out[14] = v[2];\n out[15] = 1;\n return out;\n}\n/**\n * Creates a matrix from a quaternion rotation, vector translation and vector scale, rotating and scaling around the given origin\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.translate(dest, vec);\n * mat4.translate(dest, origin);\n * let quatMat = mat4.create();\n * quat4.toMat4(quat, quatMat);\n * mat4.multiply(dest, quatMat);\n * mat4.scale(dest, scale)\n * mat4.translate(dest, negativeOrigin);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {ReadonlyVec3} v Translation vector\n * @param {ReadonlyVec3} s Scaling vector\n * @param {ReadonlyVec3} o The origin vector around which to scale and rotate\n * @returns {mat4} out\n */\n\nexport function fromRotationTranslationScaleOrigin(out, q, v, s, o) {\n // Quaternion math\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var xy = x * y2;\n var xz = x * z2;\n var yy = y * y2;\n var yz = y * z2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n var sx = s[0];\n var sy = s[1];\n var sz = s[2];\n var ox = o[0];\n var oy = o[1];\n var oz = o[2];\n var out0 = (1 - (yy + zz)) * sx;\n var out1 = (xy + wz) * sx;\n var out2 = (xz - wy) * sx;\n var out4 = (xy - wz) * sy;\n var out5 = (1 - (xx + zz)) * sy;\n var out6 = (yz + wx) * sy;\n var out8 = (xz + wy) * sz;\n var out9 = (yz - wx) * sz;\n var out10 = (1 - (xx + yy)) * sz;\n out[0] = out0;\n out[1] = out1;\n out[2] = out2;\n out[3] = 0;\n out[4] = out4;\n out[5] = out5;\n out[6] = out6;\n out[7] = 0;\n out[8] = out8;\n out[9] = out9;\n out[10] = out10;\n out[11] = 0;\n out[12] = v[0] + ox - (out0 * ox + out4 * oy + out8 * oz);\n out[13] = v[1] + oy - (out1 * ox + out5 * oy + out9 * oz);\n out[14] = v[2] + oz - (out2 * ox + out6 * oy + out10 * oz);\n out[15] = 1;\n return out;\n}\n/**\n * Calculates a 4x4 matrix from the given quaternion\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {ReadonlyQuat} q Quaternion to create matrix from\n *\n * @returns {mat4} out\n */\n\nexport function fromQuat(out, q) {\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var yx = y * x2;\n var yy = y * y2;\n var zx = z * x2;\n var zy = z * y2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n out[0] = 1 - yy - zz;\n out[1] = yx + wz;\n out[2] = zx - wy;\n out[3] = 0;\n out[4] = yx - wz;\n out[5] = 1 - xx - zz;\n out[6] = zy + wx;\n out[7] = 0;\n out[8] = zx + wy;\n out[9] = zy - wx;\n out[10] = 1 - xx - yy;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\n * Generates a frustum matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {Number} left Left bound of the frustum\n * @param {Number} right Right bound of the frustum\n * @param {Number} bottom Bottom bound of the frustum\n * @param {Number} top Top bound of the frustum\n * @param {Number} near Near bound of the frustum\n * @param {Number} far Far bound of the frustum\n * @returns {mat4} out\n */\n\nexport function frustum(out, left, right, bottom, top, near, far) {\n var rl = 1 / (right - left);\n var tb = 1 / (top - bottom);\n var nf = 1 / (near - far);\n out[0] = near * 2 * rl;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = near * 2 * tb;\n out[6] = 0;\n out[7] = 0;\n out[8] = (right + left) * rl;\n out[9] = (top + bottom) * tb;\n out[10] = (far + near) * nf;\n out[11] = -1;\n out[12] = 0;\n out[13] = 0;\n out[14] = far * near * 2 * nf;\n out[15] = 0;\n return out;\n}\n/**\n * Generates a perspective projection matrix with the given bounds.\n * The near/far clip planes correspond to a normalized device coordinate Z range of [-1, 1],\n * which matches WebGL/OpenGL's clip volume.\n * Passing null/undefined/no value for far will generate infinite projection matrix.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} fovy Vertical field of view in radians\n * @param {number} aspect Aspect ratio. typically viewport width/height\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum, can be null or Infinity\n * @returns {mat4} out\n */\n\nexport function perspectiveNO(out, fovy, aspect, near, far) {\n var f = 1.0 / Math.tan(fovy / 2),\n nf;\n out[0] = f / aspect;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = f;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[11] = -1;\n out[12] = 0;\n out[13] = 0;\n out[15] = 0;\n\n if (far != null && far !== Infinity) {\n nf = 1 / (near - far);\n out[10] = (far + near) * nf;\n out[14] = 2 * far * near * nf;\n } else {\n out[10] = -1;\n out[14] = -2 * near;\n }\n\n return out;\n}\n/**\n * Alias for {@link mat4.perspectiveNO}\n * @function\n */\n\nexport var perspective = perspectiveNO;\n/**\n * Generates a perspective projection matrix suitable for WebGPU with the given bounds.\n * The near/far clip planes correspond to a normalized device coordinate Z range of [0, 1],\n * which matches WebGPU/Vulkan/DirectX/Metal's clip volume.\n * Passing null/undefined/no value for far will generate infinite projection matrix.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} fovy Vertical field of view in radians\n * @param {number} aspect Aspect ratio. typically viewport width/height\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum, can be null or Infinity\n * @returns {mat4} out\n */\n\nexport function perspectiveZO(out, fovy, aspect, near, far) {\n var f = 1.0 / Math.tan(fovy / 2),\n nf;\n out[0] = f / aspect;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = f;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[11] = -1;\n out[12] = 0;\n out[13] = 0;\n out[15] = 0;\n\n if (far != null && far !== Infinity) {\n nf = 1 / (near - far);\n out[10] = far * nf;\n out[14] = far * near * nf;\n } else {\n out[10] = -1;\n out[14] = -near;\n }\n\n return out;\n}\n/**\n * Generates a perspective projection matrix with the given field of view.\n * This is primarily useful for generating projection matrices to be used\n * with the still experiemental WebVR API.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {Object} fov Object containing the following values: upDegrees, downDegrees, leftDegrees, rightDegrees\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\n\nexport function perspectiveFromFieldOfView(out, fov, near, far) {\n var upTan = Math.tan(fov.upDegrees * Math.PI / 180.0);\n var downTan = Math.tan(fov.downDegrees * Math.PI / 180.0);\n var leftTan = Math.tan(fov.leftDegrees * Math.PI / 180.0);\n var rightTan = Math.tan(fov.rightDegrees * Math.PI / 180.0);\n var xScale = 2.0 / (leftTan + rightTan);\n var yScale = 2.0 / (upTan + downTan);\n out[0] = xScale;\n out[1] = 0.0;\n out[2] = 0.0;\n out[3] = 0.0;\n out[4] = 0.0;\n out[5] = yScale;\n out[6] = 0.0;\n out[7] = 0.0;\n out[8] = -((leftTan - rightTan) * xScale * 0.5);\n out[9] = (upTan - downTan) * yScale * 0.5;\n out[10] = far / (near - far);\n out[11] = -1.0;\n out[12] = 0.0;\n out[13] = 0.0;\n out[14] = far * near / (near - far);\n out[15] = 0.0;\n return out;\n}\n/**\n * Generates a orthogonal projection matrix with the given bounds.\n * The near/far clip planes correspond to a normalized device coordinate Z range of [-1, 1],\n * which matches WebGL/OpenGL's clip volume.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} left Left bound of the frustum\n * @param {number} right Right bound of the frustum\n * @param {number} bottom Bottom bound of the frustum\n * @param {number} top Top bound of the frustum\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\n\nexport function orthoNO(out, left, right, bottom, top, near, far) {\n var lr = 1 / (left - right);\n var bt = 1 / (bottom - top);\n var nf = 1 / (near - far);\n out[0] = -2 * lr;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = -2 * bt;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 2 * nf;\n out[11] = 0;\n out[12] = (left + right) * lr;\n out[13] = (top + bottom) * bt;\n out[14] = (far + near) * nf;\n out[15] = 1;\n return out;\n}\n/**\n * Alias for {@link mat4.orthoNO}\n * @function\n */\n\nexport var ortho = orthoNO;\n/**\n * Generates a orthogonal projection matrix with the given bounds.\n * The near/far clip planes correspond to a normalized device coordinate Z range of [0, 1],\n * which matches WebGPU/Vulkan/DirectX/Metal's clip volume.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} left Left bound of the frustum\n * @param {number} right Right bound of the frustum\n * @param {number} bottom Bottom bound of the frustum\n * @param {number} top Top bound of the frustum\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\n\nexport function orthoZO(out, left, right, bottom, top, near, far) {\n var lr = 1 / (left - right);\n var bt = 1 / (bottom - top);\n var nf = 1 / (near - far);\n out[0] = -2 * lr;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = -2 * bt;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = nf;\n out[11] = 0;\n out[12] = (left + right) * lr;\n out[13] = (top + bottom) * bt;\n out[14] = near * nf;\n out[15] = 1;\n return out;\n}\n/**\n * Generates a look-at matrix with the given eye position, focal point, and up axis.\n * If you want a matrix that actually makes an object look at another object, you should use targetTo instead.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {ReadonlyVec3} eye Position of the viewer\n * @param {ReadonlyVec3} center Point the viewer is looking at\n * @param {ReadonlyVec3} up vec3 pointing up\n * @returns {mat4} out\n */\n\nexport function lookAt(out, eye, center, up) {\n var x0, x1, x2, y0, y1, y2, z0, z1, z2, len;\n var eyex = eye[0];\n var eyey = eye[1];\n var eyez = eye[2];\n var upx = up[0];\n var upy = up[1];\n var upz = up[2];\n var centerx = center[0];\n var centery = center[1];\n var centerz = center[2];\n\n if (Math.abs(eyex - centerx) < glMatrix.EPSILON && Math.abs(eyey - centery) < glMatrix.EPSILON && Math.abs(eyez - centerz) < glMatrix.EPSILON) {\n return identity(out);\n }\n\n z0 = eyex - centerx;\n z1 = eyey - centery;\n z2 = eyez - centerz;\n len = 1 / Math.hypot(z0, z1, z2);\n z0 *= len;\n z1 *= len;\n z2 *= len;\n x0 = upy * z2 - upz * z1;\n x1 = upz * z0 - upx * z2;\n x2 = upx * z1 - upy * z0;\n len = Math.hypot(x0, x1, x2);\n\n if (!len) {\n x0 = 0;\n x1 = 0;\n x2 = 0;\n } else {\n len = 1 / len;\n x0 *= len;\n x1 *= len;\n x2 *= len;\n }\n\n y0 = z1 * x2 - z2 * x1;\n y1 = z2 * x0 - z0 * x2;\n y2 = z0 * x1 - z1 * x0;\n len = Math.hypot(y0, y1, y2);\n\n if (!len) {\n y0 = 0;\n y1 = 0;\n y2 = 0;\n } else {\n len = 1 / len;\n y0 *= len;\n y1 *= len;\n y2 *= len;\n }\n\n out[0] = x0;\n out[1] = y0;\n out[2] = z0;\n out[3] = 0;\n out[4] = x1;\n out[5] = y1;\n out[6] = z1;\n out[7] = 0;\n out[8] = x2;\n out[9] = y2;\n out[10] = z2;\n out[11] = 0;\n out[12] = -(x0 * eyex + x1 * eyey + x2 * eyez);\n out[13] = -(y0 * eyex + y1 * eyey + y2 * eyez);\n out[14] = -(z0 * eyex + z1 * eyey + z2 * eyez);\n out[15] = 1;\n return out;\n}\n/**\n * Generates a matrix that makes something look at something else.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {ReadonlyVec3} eye Position of the viewer\n * @param {ReadonlyVec3} center Point the viewer is looking at\n * @param {ReadonlyVec3} up vec3 pointing up\n * @returns {mat4} out\n */\n\nexport function targetTo(out, eye, target, up) {\n var eyex = eye[0],\n eyey = eye[1],\n eyez = eye[2],\n upx = up[0],\n upy = up[1],\n upz = up[2];\n var z0 = eyex - target[0],\n z1 = eyey - target[1],\n z2 = eyez - target[2];\n var len = z0 * z0 + z1 * z1 + z2 * z2;\n\n if (len > 0) {\n len = 1 / Math.sqrt(len);\n z0 *= len;\n z1 *= len;\n z2 *= len;\n }\n\n var x0 = upy * z2 - upz * z1,\n x1 = upz * z0 - upx * z2,\n x2 = upx * z1 - upy * z0;\n len = x0 * x0 + x1 * x1 + x2 * x2;\n\n if (len > 0) {\n len = 1 / Math.sqrt(len);\n x0 *= len;\n x1 *= len;\n x2 *= len;\n }\n\n out[0] = x0;\n out[1] = x1;\n out[2] = x2;\n out[3] = 0;\n out[4] = z1 * x2 - z2 * x1;\n out[5] = z2 * x0 - z0 * x2;\n out[6] = z0 * x1 - z1 * x0;\n out[7] = 0;\n out[8] = z0;\n out[9] = z1;\n out[10] = z2;\n out[11] = 0;\n out[12] = eyex;\n out[13] = eyey;\n out[14] = eyez;\n out[15] = 1;\n return out;\n}\n/**\n * Returns a string representation of a mat4\n *\n * @param {ReadonlyMat4} a matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\n\nexport function str(a) {\n return \"mat4(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \", \" + a[4] + \", \" + a[5] + \", \" + a[6] + \", \" + a[7] + \", \" + a[8] + \", \" + a[9] + \", \" + a[10] + \", \" + a[11] + \", \" + a[12] + \", \" + a[13] + \", \" + a[14] + \", \" + a[15] + \")\";\n}\n/**\n * Returns Frobenius norm of a mat4\n *\n * @param {ReadonlyMat4} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\n\nexport function frob(a) {\n return Math.hypot(a[0], a[1], a[2], a[3], a[4], a[5], a[6], a[7], a[8], a[9], a[10], a[11], a[12], a[13], a[14], a[15]);\n}\n/**\n * Adds two mat4's\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the first operand\n * @param {ReadonlyMat4} b the second operand\n * @returns {mat4} out\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n out[4] = a[4] + b[4];\n out[5] = a[5] + b[5];\n out[6] = a[6] + b[6];\n out[7] = a[7] + b[7];\n out[8] = a[8] + b[8];\n out[9] = a[9] + b[9];\n out[10] = a[10] + b[10];\n out[11] = a[11] + b[11];\n out[12] = a[12] + b[12];\n out[13] = a[13] + b[13];\n out[14] = a[14] + b[14];\n out[15] = a[15] + b[15];\n return out;\n}\n/**\n * Subtracts matrix b from matrix a\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the first operand\n * @param {ReadonlyMat4} b the second operand\n * @returns {mat4} out\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n out[4] = a[4] - b[4];\n out[5] = a[5] - b[5];\n out[6] = a[6] - b[6];\n out[7] = a[7] - b[7];\n out[8] = a[8] - b[8];\n out[9] = a[9] - b[9];\n out[10] = a[10] - b[10];\n out[11] = a[11] - b[11];\n out[12] = a[12] - b[12];\n out[13] = a[13] - b[13];\n out[14] = a[14] - b[14];\n out[15] = a[15] - b[15];\n return out;\n}\n/**\n * Multiply each element of the matrix by a scalar.\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the matrix to scale\n * @param {Number} b amount to scale the matrix's elements by\n * @returns {mat4} out\n */\n\nexport function multiplyScalar(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n out[4] = a[4] * b;\n out[5] = a[5] * b;\n out[6] = a[6] * b;\n out[7] = a[7] * b;\n out[8] = a[8] * b;\n out[9] = a[9] * b;\n out[10] = a[10] * b;\n out[11] = a[11] * b;\n out[12] = a[12] * b;\n out[13] = a[13] * b;\n out[14] = a[14] * b;\n out[15] = a[15] * b;\n return out;\n}\n/**\n * Adds two mat4's after multiplying each element of the second operand by a scalar value.\n *\n * @param {mat4} out the receiving vector\n * @param {ReadonlyMat4} a the first operand\n * @param {ReadonlyMat4} b the second operand\n * @param {Number} scale the amount to scale b's elements by before adding\n * @returns {mat4} out\n */\n\nexport function multiplyScalarAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n out[4] = a[4] + b[4] * scale;\n out[5] = a[5] + b[5] * scale;\n out[6] = a[6] + b[6] * scale;\n out[7] = a[7] + b[7] * scale;\n out[8] = a[8] + b[8] * scale;\n out[9] = a[9] + b[9] * scale;\n out[10] = a[10] + b[10] * scale;\n out[11] = a[11] + b[11] * scale;\n out[12] = a[12] + b[12] * scale;\n out[13] = a[13] + b[13] * scale;\n out[14] = a[14] + b[14] * scale;\n out[15] = a[15] + b[15] * scale;\n return out;\n}\n/**\n * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyMat4} a The first matrix.\n * @param {ReadonlyMat4} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3] && a[4] === b[4] && a[5] === b[5] && a[6] === b[6] && a[7] === b[7] && a[8] === b[8] && a[9] === b[9] && a[10] === b[10] && a[11] === b[11] && a[12] === b[12] && a[13] === b[13] && a[14] === b[14] && a[15] === b[15];\n}\n/**\n * Returns whether or not the matrices have approximately the same elements in the same position.\n *\n * @param {ReadonlyMat4} a The first matrix.\n * @param {ReadonlyMat4} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var a4 = a[4],\n a5 = a[5],\n a6 = a[6],\n a7 = a[7];\n var a8 = a[8],\n a9 = a[9],\n a10 = a[10],\n a11 = a[11];\n var a12 = a[12],\n a13 = a[13],\n a14 = a[14],\n a15 = a[15];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n var b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7];\n var b8 = b[8],\n b9 = b[9],\n b10 = b[10],\n b11 = b[11];\n var b12 = b[12],\n b13 = b[13],\n b14 = b[14],\n b15 = b[15];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3)) && Math.abs(a4 - b4) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a4), Math.abs(b4)) && Math.abs(a5 - b5) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a5), Math.abs(b5)) && Math.abs(a6 - b6) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a6), Math.abs(b6)) && Math.abs(a7 - b7) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a7), Math.abs(b7)) && Math.abs(a8 - b8) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a8), Math.abs(b8)) && Math.abs(a9 - b9) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a9), Math.abs(b9)) && Math.abs(a10 - b10) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a10), Math.abs(b10)) && Math.abs(a11 - b11) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a11), Math.abs(b11)) && Math.abs(a12 - b12) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a12), Math.abs(b12)) && Math.abs(a13 - b13) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a13), Math.abs(b13)) && Math.abs(a14 - b14) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a14), Math.abs(b14)) && Math.abs(a15 - b15) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a15), Math.abs(b15));\n}\n/**\n * Alias for {@link mat4.multiply}\n * @function\n */\n\nexport var mul = multiply;\n/**\n * Alias for {@link mat4.subtract}\n * @function\n */\n\nexport var sub = subtract;","import * as glMatrix from \"./common.js\";\n/**\n * 4 Dimensional Vector\n * @module vec4\n */\n\n/**\n * Creates a new, empty vec4\n *\n * @returns {vec4} a new 4D vector\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(4);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n }\n\n return out;\n}\n/**\n * Creates a new vec4 initialized with values from an existing vector\n *\n * @param {ReadonlyVec4} a vector to clone\n * @returns {vec4} a new 4D vector\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(4);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n return out;\n}\n/**\n * Creates a new vec4 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} a new 4D vector\n */\n\nexport function fromValues(x, y, z, w) {\n var out = new glMatrix.ARRAY_TYPE(4);\n out[0] = x;\n out[1] = y;\n out[2] = z;\n out[3] = w;\n return out;\n}\n/**\n * Copy the values from one vec4 to another\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the source vector\n * @returns {vec4} out\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n return out;\n}\n/**\n * Set the components of a vec4 to the given values\n *\n * @param {vec4} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} out\n */\n\nexport function set(out, x, y, z, w) {\n out[0] = x;\n out[1] = y;\n out[2] = z;\n out[3] = w;\n return out;\n}\n/**\n * Adds two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {vec4} out\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n return out;\n}\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {vec4} out\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n return out;\n}\n/**\n * Multiplies two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {vec4} out\n */\n\nexport function multiply(out, a, b) {\n out[0] = a[0] * b[0];\n out[1] = a[1] * b[1];\n out[2] = a[2] * b[2];\n out[3] = a[3] * b[3];\n return out;\n}\n/**\n * Divides two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {vec4} out\n */\n\nexport function divide(out, a, b) {\n out[0] = a[0] / b[0];\n out[1] = a[1] / b[1];\n out[2] = a[2] / b[2];\n out[3] = a[3] / b[3];\n return out;\n}\n/**\n * Math.ceil the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a vector to ceil\n * @returns {vec4} out\n */\n\nexport function ceil(out, a) {\n out[0] = Math.ceil(a[0]);\n out[1] = Math.ceil(a[1]);\n out[2] = Math.ceil(a[2]);\n out[3] = Math.ceil(a[3]);\n return out;\n}\n/**\n * Math.floor the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a vector to floor\n * @returns {vec4} out\n */\n\nexport function floor(out, a) {\n out[0] = Math.floor(a[0]);\n out[1] = Math.floor(a[1]);\n out[2] = Math.floor(a[2]);\n out[3] = Math.floor(a[3]);\n return out;\n}\n/**\n * Returns the minimum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {vec4} out\n */\n\nexport function min(out, a, b) {\n out[0] = Math.min(a[0], b[0]);\n out[1] = Math.min(a[1], b[1]);\n out[2] = Math.min(a[2], b[2]);\n out[3] = Math.min(a[3], b[3]);\n return out;\n}\n/**\n * Returns the maximum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {vec4} out\n */\n\nexport function max(out, a, b) {\n out[0] = Math.max(a[0], b[0]);\n out[1] = Math.max(a[1], b[1]);\n out[2] = Math.max(a[2], b[2]);\n out[3] = Math.max(a[3], b[3]);\n return out;\n}\n/**\n * Math.round the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a vector to round\n * @returns {vec4} out\n */\n\nexport function round(out, a) {\n out[0] = Math.round(a[0]);\n out[1] = Math.round(a[1]);\n out[2] = Math.round(a[2]);\n out[3] = Math.round(a[3]);\n return out;\n}\n/**\n * Scales a vec4 by a scalar number\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec4} out\n */\n\nexport function scale(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n return out;\n}\n/**\n * Adds two vec4's after scaling the second operand by a scalar value\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec4} out\n */\n\nexport function scaleAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n return out;\n}\n/**\n * Calculates the euclidian distance between two vec4's\n *\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {Number} distance between a and b\n */\n\nexport function distance(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n var w = b[3] - a[3];\n return Math.hypot(x, y, z, w);\n}\n/**\n * Calculates the squared euclidian distance between two vec4's\n *\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {Number} squared distance between a and b\n */\n\nexport function squaredDistance(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n var w = b[3] - a[3];\n return x * x + y * y + z * z + w * w;\n}\n/**\n * Calculates the length of a vec4\n *\n * @param {ReadonlyVec4} a vector to calculate length of\n * @returns {Number} length of a\n */\n\nexport function length(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var w = a[3];\n return Math.hypot(x, y, z, w);\n}\n/**\n * Calculates the squared length of a vec4\n *\n * @param {ReadonlyVec4} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\n\nexport function squaredLength(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var w = a[3];\n return x * x + y * y + z * z + w * w;\n}\n/**\n * Negates the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a vector to negate\n * @returns {vec4} out\n */\n\nexport function negate(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n out[2] = -a[2];\n out[3] = -a[3];\n return out;\n}\n/**\n * Returns the inverse of the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a vector to invert\n * @returns {vec4} out\n */\n\nexport function inverse(out, a) {\n out[0] = 1.0 / a[0];\n out[1] = 1.0 / a[1];\n out[2] = 1.0 / a[2];\n out[3] = 1.0 / a[3];\n return out;\n}\n/**\n * Normalize a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a vector to normalize\n * @returns {vec4} out\n */\n\nexport function normalize(out, a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var w = a[3];\n var len = x * x + y * y + z * z + w * w;\n\n if (len > 0) {\n len = 1 / Math.sqrt(len);\n }\n\n out[0] = x * len;\n out[1] = y * len;\n out[2] = z * len;\n out[3] = w * len;\n return out;\n}\n/**\n * Calculates the dot product of two vec4's\n *\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {Number} dot product of a and b\n */\n\nexport function dot(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];\n}\n/**\n * Returns the cross-product of three vectors in a 4-dimensional space\n *\n * @param {ReadonlyVec4} result the receiving vector\n * @param {ReadonlyVec4} U the first vector\n * @param {ReadonlyVec4} V the second vector\n * @param {ReadonlyVec4} W the third vector\n * @returns {vec4} result\n */\n\nexport function cross(out, u, v, w) {\n var A = v[0] * w[1] - v[1] * w[0],\n B = v[0] * w[2] - v[2] * w[0],\n C = v[0] * w[3] - v[3] * w[0],\n D = v[1] * w[2] - v[2] * w[1],\n E = v[1] * w[3] - v[3] * w[1],\n F = v[2] * w[3] - v[3] * w[2];\n var G = u[0];\n var H = u[1];\n var I = u[2];\n var J = u[3];\n out[0] = H * F - I * E + J * D;\n out[1] = -(G * F) + I * C - J * B;\n out[2] = G * E - H * C + J * A;\n out[3] = -(G * D) + H * B - I * A;\n return out;\n}\n/**\n * Performs a linear interpolation between two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec4} out\n */\n\nexport function lerp(out, a, b, t) {\n var ax = a[0];\n var ay = a[1];\n var az = a[2];\n var aw = a[3];\n out[0] = ax + t * (b[0] - ax);\n out[1] = ay + t * (b[1] - ay);\n out[2] = az + t * (b[2] - az);\n out[3] = aw + t * (b[3] - aw);\n return out;\n}\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec4} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec4} out\n */\n\nexport function random(out, scale) {\n scale = scale || 1.0; // Marsaglia, George. Choosing a Point from the Surface of a\n // Sphere. Ann. Math. Statist. 43 (1972), no. 2, 645--646.\n // http://projecteuclid.org/euclid.aoms/1177692644;\n\n var v1, v2, v3, v4;\n var s1, s2;\n\n do {\n v1 = glMatrix.RANDOM() * 2 - 1;\n v2 = glMatrix.RANDOM() * 2 - 1;\n s1 = v1 * v1 + v2 * v2;\n } while (s1 >= 1);\n\n do {\n v3 = glMatrix.RANDOM() * 2 - 1;\n v4 = glMatrix.RANDOM() * 2 - 1;\n s2 = v3 * v3 + v4 * v4;\n } while (s2 >= 1);\n\n var d = Math.sqrt((1 - s1) / s2);\n out[0] = scale * v1;\n out[1] = scale * v2;\n out[2] = scale * v3 * d;\n out[3] = scale * v4 * d;\n return out;\n}\n/**\n * Transforms the vec4 with a mat4.\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the vector to transform\n * @param {ReadonlyMat4} m matrix to transform with\n * @returns {vec4} out\n */\n\nexport function transformMat4(out, a, m) {\n var x = a[0],\n y = a[1],\n z = a[2],\n w = a[3];\n out[0] = m[0] * x + m[4] * y + m[8] * z + m[12] * w;\n out[1] = m[1] * x + m[5] * y + m[9] * z + m[13] * w;\n out[2] = m[2] * x + m[6] * y + m[10] * z + m[14] * w;\n out[3] = m[3] * x + m[7] * y + m[11] * z + m[15] * w;\n return out;\n}\n/**\n * Transforms the vec4 with a quat\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the vector to transform\n * @param {ReadonlyQuat} q quaternion to transform with\n * @returns {vec4} out\n */\n\nexport function transformQuat(out, a, q) {\n var x = a[0],\n y = a[1],\n z = a[2];\n var qx = q[0],\n qy = q[1],\n qz = q[2],\n qw = q[3]; // calculate quat * vec\n\n var ix = qw * x + qy * z - qz * y;\n var iy = qw * y + qz * x - qx * z;\n var iz = qw * z + qx * y - qy * x;\n var iw = -qx * x - qy * y - qz * z; // calculate result * inverse quat\n\n out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n out[3] = a[3];\n return out;\n}\n/**\n * Set the components of a vec4 to zero\n *\n * @param {vec4} out the receiving vector\n * @returns {vec4} out\n */\n\nexport function zero(out) {\n out[0] = 0.0;\n out[1] = 0.0;\n out[2] = 0.0;\n out[3] = 0.0;\n return out;\n}\n/**\n * Returns a string representation of a vector\n *\n * @param {ReadonlyVec4} a vector to represent as a string\n * @returns {String} string representation of the vector\n */\n\nexport function str(a) {\n return \"vec4(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \")\";\n}\n/**\n * Returns whether or not the vectors have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyVec4} a The first vector.\n * @param {ReadonlyVec4} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3];\n}\n/**\n * Returns whether or not the vectors have approximately the same elements in the same position.\n *\n * @param {ReadonlyVec4} a The first vector.\n * @param {ReadonlyVec4} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3));\n}\n/**\n * Alias for {@link vec4.subtract}\n * @function\n */\n\nexport var sub = subtract;\n/**\n * Alias for {@link vec4.multiply}\n * @function\n */\n\nexport var mul = multiply;\n/**\n * Alias for {@link vec4.divide}\n * @function\n */\n\nexport var div = divide;\n/**\n * Alias for {@link vec4.distance}\n * @function\n */\n\nexport var dist = distance;\n/**\n * Alias for {@link vec4.squaredDistance}\n * @function\n */\n\nexport var sqrDist = squaredDistance;\n/**\n * Alias for {@link vec4.length}\n * @function\n */\n\nexport var len = length;\n/**\n * Alias for {@link vec4.squaredLength}\n * @function\n */\n\nexport var sqrLen = squaredLength;\n/**\n * Perform some operation over an array of vec4s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec4. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec4s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\n\nexport var forEach = function () {\n var vec = create();\n return function (a, stride, offset, count, fn, arg) {\n var i, l;\n\n if (!stride) {\n stride = 4;\n }\n\n if (!offset) {\n offset = 0;\n }\n\n if (count) {\n l = Math.min(count * stride + offset, a.length);\n } else {\n l = a.length;\n }\n\n for (i = offset; i < l; i += stride) {\n vec[0] = a[i];\n vec[1] = a[i + 1];\n vec[2] = a[i + 2];\n vec[3] = a[i + 3];\n fn(vec, vec, arg);\n a[i] = vec[0];\n a[i + 1] = vec[1];\n a[i + 2] = vec[2];\n a[i + 3] = vec[3];\n }\n\n return a;\n };\n}();","import {StyleLayer} from '../style_layer';\n\nimport {CircleBucket} from '../../data/bucket/circle_bucket';\nimport {polygonIntersectsBufferedPoint} from '../../util/intersection_tests';\nimport {getMaximumPaintValue, translateDistance, translate} from '../query_utils';\nimport properties, {CircleLayoutPropsPossiblyEvaluated, CirclePaintPropsPossiblyEvaluated} from './circle_style_layer_properties.g';\nimport {Transitionable, Transitioning, Layout, PossiblyEvaluated} from '../properties';\nimport {mat4, vec4} from 'gl-matrix';\nimport Point from '@mapbox/point-geometry';\nimport type {FeatureState, LayerSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {Transform} from '../../geo/transform';\nimport type {Bucket, BucketParameters} from '../../data/bucket';\nimport type {CircleLayoutProps, CirclePaintProps} from './circle_style_layer_properties.g';\nimport type {VectorTileFeature} from '@mapbox/vector-tile';\n\n/**\n * A style layer that defines a circle\n */\nexport class CircleStyleLayer extends StyleLayer {\n _unevaluatedLayout: Layout;\n layout: PossiblyEvaluated;\n\n _transitionablePaint: Transitionable;\n _transitioningPaint: Transitioning;\n paint: PossiblyEvaluated;\n\n constructor(layer: LayerSpecification) {\n super(layer, properties);\n }\n\n createBucket(parameters: BucketParameters) {\n return new CircleBucket(parameters);\n }\n\n queryRadius(bucket: Bucket): number {\n const circleBucket: CircleBucket = (bucket as any);\n return getMaximumPaintValue('circle-radius', this, circleBucket) +\n getMaximumPaintValue('circle-stroke-width', this, circleBucket) +\n translateDistance(this.paint.get('circle-translate'));\n }\n\n queryIntersectsFeature(\n queryGeometry: Array,\n feature: VectorTileFeature,\n featureState: FeatureState,\n geometry: Array>,\n zoom: number,\n transform: Transform,\n pixelsToTileUnits: number,\n pixelPosMatrix: mat4\n ): boolean {\n const translatedPolygon = translate(queryGeometry,\n this.paint.get('circle-translate'),\n this.paint.get('circle-translate-anchor'),\n transform.angle, pixelsToTileUnits);\n const radius = this.paint.get('circle-radius').evaluate(feature, featureState);\n const stroke = this.paint.get('circle-stroke-width').evaluate(feature, featureState);\n const size = radius + stroke;\n\n // For pitch-alignment: map, compare feature geometry to query geometry in the plane of the tile\n // // Otherwise, compare geometry in the plane of the viewport\n // // A circle with fixed scaling relative to the viewport gets larger in tile space as it moves into the distance\n // // A circle with fixed scaling relative to the map gets smaller in viewport space as it moves into the distance\n const alignWithMap = this.paint.get('circle-pitch-alignment') === 'map';\n const transformedPolygon = alignWithMap ? translatedPolygon : projectQueryGeometry(translatedPolygon, pixelPosMatrix);\n const transformedSize = alignWithMap ? size * pixelsToTileUnits : size;\n\n for (const ring of geometry) {\n for (const point of ring) {\n\n const transformedPoint = alignWithMap ? point : projectPoint(point, pixelPosMatrix);\n\n let adjustedSize = transformedSize;\n const projectedCenter = vec4.transformMat4([] as any, [point.x, point.y, 0, 1], pixelPosMatrix);\n if (this.paint.get('circle-pitch-scale') === 'viewport' && this.paint.get('circle-pitch-alignment') === 'map') {\n adjustedSize *= projectedCenter[3] / transform.cameraToCenterDistance;\n } else if (this.paint.get('circle-pitch-scale') === 'map' && this.paint.get('circle-pitch-alignment') === 'viewport') {\n adjustedSize *= transform.cameraToCenterDistance / projectedCenter[3];\n }\n\n if (polygonIntersectsBufferedPoint(transformedPolygon, transformedPoint, adjustedSize)) return true;\n }\n }\n\n return false;\n }\n}\n\nfunction projectPoint(p: Point, pixelPosMatrix: mat4) {\n const point = vec4.transformMat4([] as any, [p.x, p.y, 0, 1], pixelPosMatrix);\n return new Point(point[0] / point[3], point[1] / point[3]);\n}\n\nfunction projectQueryGeometry(queryGeometry: Array, pixelPosMatrix: mat4) {\n return queryGeometry.map((p) => {\n return projectPoint(p, pixelPosMatrix);\n });\n}\n","import {CircleBucket} from './circle_bucket';\nimport {register} from '../../util/web_worker_transfer';\n\nimport type {HeatmapStyleLayer} from '../../style/style_layer/heatmap_style_layer';\n\nexport class HeatmapBucket extends CircleBucket {\n // Needed for flow to accept omit: ['layers'] below, due to\n // https://github.com/facebook/flow/issues/4262\n layers: Array;\n}\n\nregister('HeatmapBucket', HeatmapBucket, {omit: ['layers']});\n","// This file is generated. Edit build/generate-style-code.ts, then run 'npm run codegen'.\n/* eslint-disable */\n\nimport {latest as styleSpec} from '@maplibre/maplibre-gl-style-spec';\n\nimport {\n Properties,\n DataConstantProperty,\n DataDrivenProperty,\n CrossFadedDataDrivenProperty,\n CrossFadedProperty,\n ColorRampProperty,\n PossiblyEvaluatedPropertyValue,\n CrossFaded\n} from '../properties';\n\nimport type {Color, Formatted, Padding, ResolvedImage, VariableAnchorOffsetCollection} from '@maplibre/maplibre-gl-style-spec';\nimport {StylePropertySpecification} from '@maplibre/maplibre-gl-style-spec';\n\n\nexport type HeatmapPaintProps = {\n \"heatmap-radius\": DataDrivenProperty,\n \"heatmap-weight\": DataDrivenProperty,\n \"heatmap-intensity\": DataConstantProperty,\n \"heatmap-color\": ColorRampProperty,\n \"heatmap-opacity\": DataConstantProperty,\n};\n\nexport type HeatmapPaintPropsPossiblyEvaluated = {\n \"heatmap-radius\": PossiblyEvaluatedPropertyValue,\n \"heatmap-weight\": PossiblyEvaluatedPropertyValue,\n \"heatmap-intensity\": number,\n \"heatmap-color\": ColorRampProperty,\n \"heatmap-opacity\": number,\n};\n\nlet paint: Properties;\nconst getPaint = () => paint = paint || new Properties({\n \"heatmap-radius\": new DataDrivenProperty(styleSpec[\"paint_heatmap\"][\"heatmap-radius\"] as any as StylePropertySpecification),\n \"heatmap-weight\": new DataDrivenProperty(styleSpec[\"paint_heatmap\"][\"heatmap-weight\"] as any as StylePropertySpecification),\n \"heatmap-intensity\": new DataConstantProperty(styleSpec[\"paint_heatmap\"][\"heatmap-intensity\"] as any as StylePropertySpecification),\n \"heatmap-color\": new ColorRampProperty(styleSpec[\"paint_heatmap\"][\"heatmap-color\"] as any as StylePropertySpecification),\n \"heatmap-opacity\": new DataConstantProperty(styleSpec[\"paint_heatmap\"][\"heatmap-opacity\"] as any as StylePropertySpecification),\n});\n\nexport default ({ get paint() { return getPaint() } });","import {register} from './web_worker_transfer';\n\nexport type Size = {\n width: number;\n height: number;\n};\n\ntype Point2D = {\n x: number;\n y: number;\n};\n\nfunction createImage(image: any, {\n width,\n height\n}: Size, channels: number, data?: Uint8Array | Uint8ClampedArray) {\n if (!data) {\n data = new Uint8Array(width * height * channels);\n } else if (data instanceof Uint8ClampedArray) {\n data = new Uint8Array(data.buffer);\n } else if (data.length !== width * height * channels) {\n throw new RangeError(`mismatched image size. expected: ${data.length} but got: ${width * height * channels}`);\n }\n image.width = width;\n image.height = height;\n image.data = data;\n return image;\n}\n\nfunction resizeImage(image: any, {\n width,\n height\n}: Size, channels: number) {\n if (width === image.width && height === image.height) {\n return;\n }\n\n const newImage = createImage({}, {width, height}, channels);\n\n copyImage(image, newImage, {x: 0, y: 0}, {x: 0, y: 0}, {\n width: Math.min(image.width, width),\n height: Math.min(image.height, height)\n }, channels);\n\n image.width = width;\n image.height = height;\n image.data = newImage.data;\n}\n\nfunction copyImage(srcImg: any, dstImg: any, srcPt: Point2D, dstPt: Point2D, size: Size, channels: number) {\n if (size.width === 0 || size.height === 0) {\n return dstImg;\n }\n\n if (size.width > srcImg.width ||\n size.height > srcImg.height ||\n srcPt.x > srcImg.width - size.width ||\n srcPt.y > srcImg.height - size.height) {\n throw new RangeError('out of range source coordinates for image copy');\n }\n\n if (size.width > dstImg.width ||\n size.height > dstImg.height ||\n dstPt.x > dstImg.width - size.width ||\n dstPt.y > dstImg.height - size.height) {\n throw new RangeError('out of range destination coordinates for image copy');\n }\n\n const srcData = srcImg.data;\n const dstData = dstImg.data;\n\n if (srcData === dstData) throw new Error('srcData equals dstData, so image is already copied');\n\n for (let y = 0; y < size.height; y++) {\n const srcOffset = ((srcPt.y + y) * srcImg.width + srcPt.x) * channels;\n const dstOffset = ((dstPt.y + y) * dstImg.width + dstPt.x) * channels;\n for (let i = 0; i < size.width * channels; i++) {\n dstData[dstOffset + i] = srcData[srcOffset + i];\n }\n }\n return dstImg;\n}\n\n/**\n * An image with alpha color value\n */\nexport class AlphaImage {\n width: number;\n height: number;\n data: Uint8Array;\n\n constructor(size: Size, data?: Uint8Array | Uint8ClampedArray) {\n createImage(this, size, 1, data);\n }\n\n resize(size: Size) {\n resizeImage(this, size, 1);\n }\n\n clone() {\n return new AlphaImage({width: this.width, height: this.height}, new Uint8Array(this.data));\n }\n\n static copy(srcImg: AlphaImage, dstImg: AlphaImage, srcPt: Point2D, dstPt: Point2D, size: Size) {\n copyImage(srcImg, dstImg, srcPt, dstPt, size, 1);\n }\n}\n\n/**\n * An object to store image data not premultiplied, because ImageData is not premultiplied.\n * UNPACK_PREMULTIPLY_ALPHA_WEBGL must be used when uploading to a texture.\n */\nexport class RGBAImage {\n width: number;\n height: number;\n\n /**\n * data must be a Uint8Array instead of Uint8ClampedArray because texImage2D does not support Uint8ClampedArray in all browsers.\n */\n data: Uint8Array;\n\n constructor(size: Size, data?: Uint8Array | Uint8ClampedArray) {\n createImage(this, size, 4, data);\n }\n\n resize(size: Size) {\n resizeImage(this, size, 4);\n }\n\n replace(data: Uint8Array | Uint8ClampedArray, copy?: boolean) {\n if (copy) {\n this.data.set(data);\n } else if (data instanceof Uint8ClampedArray) {\n this.data = new Uint8Array(data.buffer);\n } else {\n this.data = data;\n }\n }\n\n clone() {\n return new RGBAImage({width: this.width, height: this.height}, new Uint8Array(this.data));\n }\n\n static copy(srcImg: RGBAImage | ImageData, dstImg: RGBAImage, srcPt: Point2D, dstPt: Point2D, size: Size) {\n copyImage(srcImg, dstImg, srcPt, dstPt, size, 4);\n }\n}\n\nregister('AlphaImage', AlphaImage);\nregister('RGBAImage', RGBAImage);\n","import {RGBAImage} from './image';\nimport {isPowerOfTwo} from './util';\n\nimport type {StylePropertyExpression} from '@maplibre/maplibre-gl-style-spec';\n\nexport type ColorRampParams = {\n expression: StylePropertyExpression;\n evaluationKey: string;\n resolution?: number;\n image?: RGBAImage;\n clips?: Array;\n};\n\n/**\n * Given an expression that should evaluate to a color ramp,\n * return a RGBA image representing that ramp expression.\n */\nexport function renderColorRamp(params: ColorRampParams): RGBAImage {\n const evaluationGlobals = {};\n const width = params.resolution || 256;\n const height = params.clips ? params.clips.length : 1;\n const image = params.image || new RGBAImage({width, height});\n\n if (!isPowerOfTwo(width)) throw new Error(`width is not a power of 2 - ${width}`);\n\n const renderPixel = (stride, index, progress) => {\n evaluationGlobals[params.evaluationKey] = progress;\n const pxColor = params.expression.evaluate(evaluationGlobals as any);\n // the colors are being unpremultiplied because Color uses\n // premultiplied values, and the Texture class expects unpremultiplied ones\n image.data[stride + index + 0] = Math.floor(pxColor.r * 255 / pxColor.a);\n image.data[stride + index + 1] = Math.floor(pxColor.g * 255 / pxColor.a);\n image.data[stride + index + 2] = Math.floor(pxColor.b * 255 / pxColor.a);\n image.data[stride + index + 3] = Math.floor(pxColor.a * 255);\n };\n\n if (!params.clips) {\n for (let i = 0, j = 0; i < width; i++, j += 4) {\n const progress = i / (width - 1);\n\n renderPixel(0, j, progress);\n }\n } else {\n for (let clip = 0, stride = 0; clip < height; ++clip, stride += width * 4) {\n for (let i = 0, j = 0; i < width; i++, j += 4) {\n // Remap progress between clips\n const progress = i / (width - 1);\n const {start, end} = params.clips[clip];\n const evaluationProgress = start * (1 - progress) + end * progress;\n renderPixel(stride, j, evaluationProgress);\n }\n }\n }\n\n return image;\n}\n","import {StyleLayer} from '../style_layer';\n\nimport {HeatmapBucket} from '../../data/bucket/heatmap_bucket';\nimport {RGBAImage} from '../../util/image';\nimport properties, {HeatmapPaintPropsPossiblyEvaluated} from './heatmap_style_layer_properties.g';\nimport {renderColorRamp} from '../../util/color_ramp';\nimport {Transitionable, Transitioning, PossiblyEvaluated} from '../properties';\n\nimport type {Texture} from '../../render/texture';\nimport type {Framebuffer} from '../../gl/framebuffer';\nimport type {HeatmapPaintProps} from './heatmap_style_layer_properties.g';\nimport type {LayerSpecification} from '@maplibre/maplibre-gl-style-spec';\n\nexport const HEATMAP_FULL_RENDER_FBO_KEY = 'big-fb';\n\n/**\n * A style layer that defines a heatmap\n */\nexport class HeatmapStyleLayer extends StyleLayer {\n\n heatmapFbos: Map;\n colorRamp: RGBAImage;\n colorRampTexture: Texture;\n\n _transitionablePaint: Transitionable;\n _transitioningPaint: Transitioning;\n paint: PossiblyEvaluated;\n\n createBucket(options: any) {\n return new HeatmapBucket(options);\n }\n\n constructor(layer: LayerSpecification) {\n super(layer, properties);\n\n this.heatmapFbos = new Map();\n // make sure color ramp texture is generated for default heatmap color too\n this._updateColorRamp();\n }\n\n _handleSpecialPaintPropertyUpdate(name: string) {\n if (name === 'heatmap-color') {\n this._updateColorRamp();\n }\n }\n\n _updateColorRamp() {\n const expression = this._transitionablePaint._values['heatmap-color'].value.expression;\n this.colorRamp = renderColorRamp({\n expression,\n evaluationKey: 'heatmapDensity',\n image: this.colorRamp\n });\n this.colorRampTexture = null;\n }\n\n resize() {\n if (this.heatmapFbos.has(HEATMAP_FULL_RENDER_FBO_KEY)) {\n this.heatmapFbos.delete(HEATMAP_FULL_RENDER_FBO_KEY);\n }\n }\n\n queryRadius(): number {\n return 0;\n }\n\n queryIntersectsFeature(): boolean {\n return false;\n }\n\n hasOffscreenPass() {\n return this.paint.get('heatmap-opacity') !== 0 && this.visibility !== 'none';\n }\n}\n","// This file is generated. Edit build/generate-style-code.ts, then run 'npm run codegen'.\n/* eslint-disable */\n\nimport {latest as styleSpec} from '@maplibre/maplibre-gl-style-spec';\n\nimport {\n Properties,\n DataConstantProperty,\n DataDrivenProperty,\n CrossFadedDataDrivenProperty,\n CrossFadedProperty,\n ColorRampProperty,\n PossiblyEvaluatedPropertyValue,\n CrossFaded\n} from '../properties';\n\nimport type {Color, Formatted, Padding, ResolvedImage, VariableAnchorOffsetCollection} from '@maplibre/maplibre-gl-style-spec';\nimport {StylePropertySpecification} from '@maplibre/maplibre-gl-style-spec';\n\n\nexport type HillshadePaintProps = {\n \"hillshade-illumination-direction\": DataConstantProperty,\n \"hillshade-illumination-anchor\": DataConstantProperty<\"map\" | \"viewport\">,\n \"hillshade-exaggeration\": DataConstantProperty,\n \"hillshade-shadow-color\": DataConstantProperty,\n \"hillshade-highlight-color\": DataConstantProperty,\n \"hillshade-accent-color\": DataConstantProperty,\n};\n\nexport type HillshadePaintPropsPossiblyEvaluated = {\n \"hillshade-illumination-direction\": number,\n \"hillshade-illumination-anchor\": \"map\" | \"viewport\",\n \"hillshade-exaggeration\": number,\n \"hillshade-shadow-color\": Color,\n \"hillshade-highlight-color\": Color,\n \"hillshade-accent-color\": Color,\n};\n\nlet paint: Properties;\nconst getPaint = () => paint = paint || new Properties({\n \"hillshade-illumination-direction\": new DataConstantProperty(styleSpec[\"paint_hillshade\"][\"hillshade-illumination-direction\"] as any as StylePropertySpecification),\n \"hillshade-illumination-anchor\": new DataConstantProperty(styleSpec[\"paint_hillshade\"][\"hillshade-illumination-anchor\"] as any as StylePropertySpecification),\n \"hillshade-exaggeration\": new DataConstantProperty(styleSpec[\"paint_hillshade\"][\"hillshade-exaggeration\"] as any as StylePropertySpecification),\n \"hillshade-shadow-color\": new DataConstantProperty(styleSpec[\"paint_hillshade\"][\"hillshade-shadow-color\"] as any as StylePropertySpecification),\n \"hillshade-highlight-color\": new DataConstantProperty(styleSpec[\"paint_hillshade\"][\"hillshade-highlight-color\"] as any as StylePropertySpecification),\n \"hillshade-accent-color\": new DataConstantProperty(styleSpec[\"paint_hillshade\"][\"hillshade-accent-color\"] as any as StylePropertySpecification),\n});\n\nexport default ({ get paint() { return getPaint() } });","import {StyleLayer} from '../style_layer';\n\nimport properties, {HillshadePaintPropsPossiblyEvaluated} from './hillshade_style_layer_properties.g';\nimport {Transitionable, Transitioning, PossiblyEvaluated} from '../properties';\n\nimport type {HillshadePaintProps} from './hillshade_style_layer_properties.g';\nimport type {LayerSpecification} from '@maplibre/maplibre-gl-style-spec';\n\nexport class HillshadeStyleLayer extends StyleLayer {\n _transitionablePaint: Transitionable;\n _transitioningPaint: Transitioning;\n paint: PossiblyEvaluated;\n\n constructor(layer: LayerSpecification) {\n super(layer, properties);\n }\n\n hasOffscreenPass() {\n return this.paint.get('hillshade-exaggeration') !== 0 && this.visibility !== 'none';\n }\n}\n","import {createLayout} from '../../util/struct_array';\n\nconst layout = createLayout([\n {name: 'a_pos', components: 2, type: 'Int16'}\n], 4);\n\nexport default layout;\nexport const {members, size, alignment} = layout;\n","\nexport default function earcut(data, holeIndices, dim = 2) {\n\n const hasHoles = holeIndices && holeIndices.length;\n const outerLen = hasHoles ? holeIndices[0] * dim : data.length;\n let outerNode = linkedList(data, 0, outerLen, dim, true);\n const triangles = [];\n\n if (!outerNode || outerNode.next === outerNode.prev) return triangles;\n\n let minX, minY, invSize;\n\n if (hasHoles) outerNode = eliminateHoles(data, holeIndices, outerNode, dim);\n\n // if the shape is not too simple, we'll use z-order curve hash later; calculate polygon bbox\n if (data.length > 80 * dim) {\n minX = Infinity;\n minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for (let i = dim; i < outerLen; i += dim) {\n const x = data[i];\n const y = data[i + 1];\n if (x < minX) minX = x;\n if (y < minY) minY = y;\n if (x > maxX) maxX = x;\n if (y > maxY) maxY = y;\n }\n\n // minX, minY and invSize are later used to transform coords into integers for z-order calculation\n invSize = Math.max(maxX - minX, maxY - minY);\n invSize = invSize !== 0 ? 32767 / invSize : 0;\n }\n\n earcutLinked(outerNode, triangles, dim, minX, minY, invSize, 0);\n\n return triangles;\n}\n\n// create a circular doubly linked list from polygon points in the specified winding order\nfunction linkedList(data, start, end, dim, clockwise) {\n let last;\n\n if (clockwise === (signedArea(data, start, end, dim) > 0)) {\n for (let i = start; i < end; i += dim) last = insertNode(i / dim | 0, data[i], data[i + 1], last);\n } else {\n for (let i = end - dim; i >= start; i -= dim) last = insertNode(i / dim | 0, data[i], data[i + 1], last);\n }\n\n if (last && equals(last, last.next)) {\n removeNode(last);\n last = last.next;\n }\n\n return last;\n}\n\n// eliminate colinear or duplicate points\nfunction filterPoints(start, end) {\n if (!start) return start;\n if (!end) end = start;\n\n let p = start,\n again;\n do {\n again = false;\n\n if (!p.steiner && (equals(p, p.next) || area(p.prev, p, p.next) === 0)) {\n removeNode(p);\n p = end = p.prev;\n if (p === p.next) break;\n again = true;\n\n } else {\n p = p.next;\n }\n } while (again || p !== end);\n\n return end;\n}\n\n// main ear slicing loop which triangulates a polygon (given as a linked list)\nfunction earcutLinked(ear, triangles, dim, minX, minY, invSize, pass) {\n if (!ear) return;\n\n // interlink polygon nodes in z-order\n if (!pass && invSize) indexCurve(ear, minX, minY, invSize);\n\n let stop = ear;\n\n // iterate through ears, slicing them one by one\n while (ear.prev !== ear.next) {\n const prev = ear.prev;\n const next = ear.next;\n\n if (invSize ? isEarHashed(ear, minX, minY, invSize) : isEar(ear)) {\n triangles.push(prev.i, ear.i, next.i); // cut off the triangle\n\n removeNode(ear);\n\n // skipping the next vertex leads to less sliver triangles\n ear = next.next;\n stop = next.next;\n\n continue;\n }\n\n ear = next;\n\n // if we looped through the whole remaining polygon and can't find any more ears\n if (ear === stop) {\n // try filtering points and slicing again\n if (!pass) {\n earcutLinked(filterPoints(ear), triangles, dim, minX, minY, invSize, 1);\n\n // if this didn't work, try curing all small self-intersections locally\n } else if (pass === 1) {\n ear = cureLocalIntersections(filterPoints(ear), triangles);\n earcutLinked(ear, triangles, dim, minX, minY, invSize, 2);\n\n // as a last resort, try splitting the remaining polygon into two\n } else if (pass === 2) {\n splitEarcut(ear, triangles, dim, minX, minY, invSize);\n }\n\n break;\n }\n }\n}\n\n// check whether a polygon node forms a valid ear with adjacent nodes\nfunction isEar(ear) {\n const a = ear.prev,\n b = ear,\n c = ear.next;\n\n if (area(a, b, c) >= 0) return false; // reflex, can't be an ear\n\n // now make sure we don't have other points inside the potential ear\n const ax = a.x, bx = b.x, cx = c.x, ay = a.y, by = b.y, cy = c.y;\n\n // triangle bbox; min & max are calculated like this for speed\n const x0 = ax < bx ? (ax < cx ? ax : cx) : (bx < cx ? bx : cx),\n y0 = ay < by ? (ay < cy ? ay : cy) : (by < cy ? by : cy),\n x1 = ax > bx ? (ax > cx ? ax : cx) : (bx > cx ? bx : cx),\n y1 = ay > by ? (ay > cy ? ay : cy) : (by > cy ? by : cy);\n\n let p = c.next;\n while (p !== a) {\n if (p.x >= x0 && p.x <= x1 && p.y >= y0 && p.y <= y1 &&\n pointInTriangle(ax, ay, bx, by, cx, cy, p.x, p.y) &&\n area(p.prev, p, p.next) >= 0) return false;\n p = p.next;\n }\n\n return true;\n}\n\nfunction isEarHashed(ear, minX, minY, invSize) {\n const a = ear.prev,\n b = ear,\n c = ear.next;\n\n if (area(a, b, c) >= 0) return false; // reflex, can't be an ear\n\n const ax = a.x, bx = b.x, cx = c.x, ay = a.y, by = b.y, cy = c.y;\n\n // triangle bbox; min & max are calculated like this for speed\n const x0 = ax < bx ? (ax < cx ? ax : cx) : (bx < cx ? bx : cx),\n y0 = ay < by ? (ay < cy ? ay : cy) : (by < cy ? by : cy),\n x1 = ax > bx ? (ax > cx ? ax : cx) : (bx > cx ? bx : cx),\n y1 = ay > by ? (ay > cy ? ay : cy) : (by > cy ? by : cy);\n\n // z-order range for the current triangle bbox;\n const minZ = zOrder(x0, y0, minX, minY, invSize),\n maxZ = zOrder(x1, y1, minX, minY, invSize);\n\n let p = ear.prevZ,\n n = ear.nextZ;\n\n // look for points inside the triangle in both directions\n while (p && p.z >= minZ && n && n.z <= maxZ) {\n if (p.x >= x0 && p.x <= x1 && p.y >= y0 && p.y <= y1 && p !== a && p !== c &&\n pointInTriangle(ax, ay, bx, by, cx, cy, p.x, p.y) && area(p.prev, p, p.next) >= 0) return false;\n p = p.prevZ;\n\n if (n.x >= x0 && n.x <= x1 && n.y >= y0 && n.y <= y1 && n !== a && n !== c &&\n pointInTriangle(ax, ay, bx, by, cx, cy, n.x, n.y) && area(n.prev, n, n.next) >= 0) return false;\n n = n.nextZ;\n }\n\n // look for remaining points in decreasing z-order\n while (p && p.z >= minZ) {\n if (p.x >= x0 && p.x <= x1 && p.y >= y0 && p.y <= y1 && p !== a && p !== c &&\n pointInTriangle(ax, ay, bx, by, cx, cy, p.x, p.y) && area(p.prev, p, p.next) >= 0) return false;\n p = p.prevZ;\n }\n\n // look for remaining points in increasing z-order\n while (n && n.z <= maxZ) {\n if (n.x >= x0 && n.x <= x1 && n.y >= y0 && n.y <= y1 && n !== a && n !== c &&\n pointInTriangle(ax, ay, bx, by, cx, cy, n.x, n.y) && area(n.prev, n, n.next) >= 0) return false;\n n = n.nextZ;\n }\n\n return true;\n}\n\n// go through all polygon nodes and cure small local self-intersections\nfunction cureLocalIntersections(start, triangles) {\n let p = start;\n do {\n const a = p.prev,\n b = p.next.next;\n\n if (!equals(a, b) && intersects(a, p, p.next, b) && locallyInside(a, b) && locallyInside(b, a)) {\n\n triangles.push(a.i, p.i, b.i);\n\n // remove two nodes involved\n removeNode(p);\n removeNode(p.next);\n\n p = start = b;\n }\n p = p.next;\n } while (p !== start);\n\n return filterPoints(p);\n}\n\n// try splitting polygon into two and triangulate them independently\nfunction splitEarcut(start, triangles, dim, minX, minY, invSize) {\n // look for a valid diagonal that divides the polygon into two\n let a = start;\n do {\n let b = a.next.next;\n while (b !== a.prev) {\n if (a.i !== b.i && isValidDiagonal(a, b)) {\n // split the polygon in two by the diagonal\n let c = splitPolygon(a, b);\n\n // filter colinear points around the cuts\n a = filterPoints(a, a.next);\n c = filterPoints(c, c.next);\n\n // run earcut on each half\n earcutLinked(a, triangles, dim, minX, minY, invSize, 0);\n earcutLinked(c, triangles, dim, minX, minY, invSize, 0);\n return;\n }\n b = b.next;\n }\n a = a.next;\n } while (a !== start);\n}\n\n// link every hole into the outer loop, producing a single-ring polygon without holes\nfunction eliminateHoles(data, holeIndices, outerNode, dim) {\n const queue = [];\n\n for (let i = 0, len = holeIndices.length; i < len; i++) {\n const start = holeIndices[i] * dim;\n const end = i < len - 1 ? holeIndices[i + 1] * dim : data.length;\n const list = linkedList(data, start, end, dim, false);\n if (list === list.next) list.steiner = true;\n queue.push(getLeftmost(list));\n }\n\n queue.sort(compareX);\n\n // process holes from left to right\n for (let i = 0; i < queue.length; i++) {\n outerNode = eliminateHole(queue[i], outerNode);\n }\n\n return outerNode;\n}\n\nfunction compareX(a, b) {\n return a.x - b.x;\n}\n\n// find a bridge between vertices that connects hole with an outer ring and and link it\nfunction eliminateHole(hole, outerNode) {\n const bridge = findHoleBridge(hole, outerNode);\n if (!bridge) {\n return outerNode;\n }\n\n const bridgeReverse = splitPolygon(bridge, hole);\n\n // filter collinear points around the cuts\n filterPoints(bridgeReverse, bridgeReverse.next);\n return filterPoints(bridge, bridge.next);\n}\n\n// David Eberly's algorithm for finding a bridge between hole and outer polygon\nfunction findHoleBridge(hole, outerNode) {\n let p = outerNode;\n const hx = hole.x;\n const hy = hole.y;\n let qx = -Infinity;\n let m;\n\n // find a segment intersected by a ray from the hole's leftmost point to the left;\n // segment's endpoint with lesser x will be potential connection point\n do {\n if (hy <= p.y && hy >= p.next.y && p.next.y !== p.y) {\n const x = p.x + (hy - p.y) * (p.next.x - p.x) / (p.next.y - p.y);\n if (x <= hx && x > qx) {\n qx = x;\n m = p.x < p.next.x ? p : p.next;\n if (x === hx) return m; // hole touches outer segment; pick leftmost endpoint\n }\n }\n p = p.next;\n } while (p !== outerNode);\n\n if (!m) return null;\n\n // look for points inside the triangle of hole point, segment intersection and endpoint;\n // if there are no points found, we have a valid connection;\n // otherwise choose the point of the minimum angle with the ray as connection point\n\n const stop = m;\n const mx = m.x;\n const my = m.y;\n let tanMin = Infinity;\n\n p = m;\n\n do {\n if (hx >= p.x && p.x >= mx && hx !== p.x &&\n pointInTriangle(hy < my ? hx : qx, hy, mx, my, hy < my ? qx : hx, hy, p.x, p.y)) {\n\n const tan = Math.abs(hy - p.y) / (hx - p.x); // tangential\n\n if (locallyInside(p, hole) &&\n (tan < tanMin || (tan === tanMin && (p.x > m.x || (p.x === m.x && sectorContainsSector(m, p)))))) {\n m = p;\n tanMin = tan;\n }\n }\n\n p = p.next;\n } while (p !== stop);\n\n return m;\n}\n\n// whether sector in vertex m contains sector in vertex p in the same coordinates\nfunction sectorContainsSector(m, p) {\n return area(m.prev, m, p.prev) < 0 && area(p.next, m, m.next) < 0;\n}\n\n// interlink polygon nodes in z-order\nfunction indexCurve(start, minX, minY, invSize) {\n let p = start;\n do {\n if (p.z === 0) p.z = zOrder(p.x, p.y, minX, minY, invSize);\n p.prevZ = p.prev;\n p.nextZ = p.next;\n p = p.next;\n } while (p !== start);\n\n p.prevZ.nextZ = null;\n p.prevZ = null;\n\n sortLinked(p);\n}\n\n// Simon Tatham's linked list merge sort algorithm\n// http://www.chiark.greenend.org.uk/~sgtatham/algorithms/listsort.html\nfunction sortLinked(list) {\n let numMerges;\n let inSize = 1;\n\n do {\n let p = list;\n let e;\n list = null;\n let tail = null;\n numMerges = 0;\n\n while (p) {\n numMerges++;\n let q = p;\n let pSize = 0;\n for (let i = 0; i < inSize; i++) {\n pSize++;\n q = q.nextZ;\n if (!q) break;\n }\n let qSize = inSize;\n\n while (pSize > 0 || (qSize > 0 && q)) {\n\n if (pSize !== 0 && (qSize === 0 || !q || p.z <= q.z)) {\n e = p;\n p = p.nextZ;\n pSize--;\n } else {\n e = q;\n q = q.nextZ;\n qSize--;\n }\n\n if (tail) tail.nextZ = e;\n else list = e;\n\n e.prevZ = tail;\n tail = e;\n }\n\n p = q;\n }\n\n tail.nextZ = null;\n inSize *= 2;\n\n } while (numMerges > 1);\n\n return list;\n}\n\n// z-order of a point given coords and inverse of the longer side of data bbox\nfunction zOrder(x, y, minX, minY, invSize) {\n // coords are transformed into non-negative 15-bit integer range\n x = (x - minX) * invSize | 0;\n y = (y - minY) * invSize | 0;\n\n x = (x | (x << 8)) & 0x00FF00FF;\n x = (x | (x << 4)) & 0x0F0F0F0F;\n x = (x | (x << 2)) & 0x33333333;\n x = (x | (x << 1)) & 0x55555555;\n\n y = (y | (y << 8)) & 0x00FF00FF;\n y = (y | (y << 4)) & 0x0F0F0F0F;\n y = (y | (y << 2)) & 0x33333333;\n y = (y | (y << 1)) & 0x55555555;\n\n return x | (y << 1);\n}\n\n// find the leftmost node of a polygon ring\nfunction getLeftmost(start) {\n let p = start,\n leftmost = start;\n do {\n if (p.x < leftmost.x || (p.x === leftmost.x && p.y < leftmost.y)) leftmost = p;\n p = p.next;\n } while (p !== start);\n\n return leftmost;\n}\n\n// check if a point lies within a convex triangle\nfunction pointInTriangle(ax, ay, bx, by, cx, cy, px, py) {\n return (cx - px) * (ay - py) >= (ax - px) * (cy - py) &&\n (ax - px) * (by - py) >= (bx - px) * (ay - py) &&\n (bx - px) * (cy - py) >= (cx - px) * (by - py);\n}\n\n// check if a diagonal between two polygon nodes is valid (lies in polygon interior)\nfunction isValidDiagonal(a, b) {\n return a.next.i !== b.i && a.prev.i !== b.i && !intersectsPolygon(a, b) && // dones't intersect other edges\n (locallyInside(a, b) && locallyInside(b, a) && middleInside(a, b) && // locally visible\n (area(a.prev, a, b.prev) || area(a, b.prev, b)) || // does not create opposite-facing sectors\n equals(a, b) && area(a.prev, a, a.next) > 0 && area(b.prev, b, b.next) > 0); // special zero-length case\n}\n\n// signed area of a triangle\nfunction area(p, q, r) {\n return (q.y - p.y) * (r.x - q.x) - (q.x - p.x) * (r.y - q.y);\n}\n\n// check if two points are equal\nfunction equals(p1, p2) {\n return p1.x === p2.x && p1.y === p2.y;\n}\n\n// check if two segments intersect\nfunction intersects(p1, q1, p2, q2) {\n const o1 = sign(area(p1, q1, p2));\n const o2 = sign(area(p1, q1, q2));\n const o3 = sign(area(p2, q2, p1));\n const o4 = sign(area(p2, q2, q1));\n\n if (o1 !== o2 && o3 !== o4) return true; // general case\n\n if (o1 === 0 && onSegment(p1, p2, q1)) return true; // p1, q1 and p2 are collinear and p2 lies on p1q1\n if (o2 === 0 && onSegment(p1, q2, q1)) return true; // p1, q1 and q2 are collinear and q2 lies on p1q1\n if (o3 === 0 && onSegment(p2, p1, q2)) return true; // p2, q2 and p1 are collinear and p1 lies on p2q2\n if (o4 === 0 && onSegment(p2, q1, q2)) return true; // p2, q2 and q1 are collinear and q1 lies on p2q2\n\n return false;\n}\n\n// for collinear points p, q, r, check if point q lies on segment pr\nfunction onSegment(p, q, r) {\n return q.x <= Math.max(p.x, r.x) && q.x >= Math.min(p.x, r.x) && q.y <= Math.max(p.y, r.y) && q.y >= Math.min(p.y, r.y);\n}\n\nfunction sign(num) {\n return num > 0 ? 1 : num < 0 ? -1 : 0;\n}\n\n// check if a polygon diagonal intersects any polygon segments\nfunction intersectsPolygon(a, b) {\n let p = a;\n do {\n if (p.i !== a.i && p.next.i !== a.i && p.i !== b.i && p.next.i !== b.i &&\n intersects(p, p.next, a, b)) return true;\n p = p.next;\n } while (p !== a);\n\n return false;\n}\n\n// check if a polygon diagonal is locally inside the polygon\nfunction locallyInside(a, b) {\n return area(a.prev, a, a.next) < 0 ?\n area(a, b, a.next) >= 0 && area(a, a.prev, b) >= 0 :\n area(a, b, a.prev) < 0 || area(a, a.next, b) < 0;\n}\n\n// check if the middle point of a polygon diagonal is inside the polygon\nfunction middleInside(a, b) {\n let p = a;\n let inside = false;\n const px = (a.x + b.x) / 2;\n const py = (a.y + b.y) / 2;\n do {\n if (((p.y > py) !== (p.next.y > py)) && p.next.y !== p.y &&\n (px < (p.next.x - p.x) * (py - p.y) / (p.next.y - p.y) + p.x))\n inside = !inside;\n p = p.next;\n } while (p !== a);\n\n return inside;\n}\n\n// link two polygon vertices with a bridge; if the vertices belong to the same ring, it splits polygon into two;\n// if one belongs to the outer ring and another to a hole, it merges it into a single ring\nfunction splitPolygon(a, b) {\n const a2 = createNode(a.i, a.x, a.y),\n b2 = createNode(b.i, b.x, b.y),\n an = a.next,\n bp = b.prev;\n\n a.next = b;\n b.prev = a;\n\n a2.next = an;\n an.prev = a2;\n\n b2.next = a2;\n a2.prev = b2;\n\n bp.next = b2;\n b2.prev = bp;\n\n return b2;\n}\n\n// create a node and optionally link it with previous one (in a circular doubly linked list)\nfunction insertNode(i, x, y, last) {\n const p = createNode(i, x, y);\n\n if (!last) {\n p.prev = p;\n p.next = p;\n\n } else {\n p.next = last.next;\n p.prev = last;\n last.next.prev = p;\n last.next = p;\n }\n return p;\n}\n\nfunction removeNode(p) {\n p.next.prev = p.prev;\n p.prev.next = p.next;\n\n if (p.prevZ) p.prevZ.nextZ = p.nextZ;\n if (p.nextZ) p.nextZ.prevZ = p.prevZ;\n}\n\nfunction createNode(i, x, y) {\n return {\n i, // vertex index in coordinates array\n x, y, // vertex coordinates\n prev: null, // previous and next vertex nodes in a polygon ring\n next: null,\n z: 0, // z-order curve value\n prevZ: null, // previous and next nodes in z-order\n nextZ: null,\n steiner: false // indicates whether this is a steiner point\n };\n}\n\n// return a percentage difference between the polygon area and its triangulation area;\n// used to verify correctness of triangulation\nexport function deviation(data, holeIndices, dim, triangles) {\n const hasHoles = holeIndices && holeIndices.length;\n const outerLen = hasHoles ? holeIndices[0] * dim : data.length;\n\n let polygonArea = Math.abs(signedArea(data, 0, outerLen, dim));\n if (hasHoles) {\n for (let i = 0, len = holeIndices.length; i < len; i++) {\n const start = holeIndices[i] * dim;\n const end = i < len - 1 ? holeIndices[i + 1] * dim : data.length;\n polygonArea -= Math.abs(signedArea(data, start, end, dim));\n }\n }\n\n let trianglesArea = 0;\n for (let i = 0; i < triangles.length; i += 3) {\n const a = triangles[i] * dim;\n const b = triangles[i + 1] * dim;\n const c = triangles[i + 2] * dim;\n trianglesArea += Math.abs(\n (data[a] - data[c]) * (data[b + 1] - data[a + 1]) -\n (data[a] - data[b]) * (data[c + 1] - data[a + 1]));\n }\n\n return polygonArea === 0 && trianglesArea === 0 ? 0 :\n Math.abs((trianglesArea - polygonArea) / polygonArea);\n}\n\nfunction signedArea(data, start, end, dim) {\n let sum = 0;\n for (let i = start, j = end - dim; i < end; i += dim) {\n sum += (data[j] - data[i]) * (data[i + 1] + data[j + 1]);\n j = i;\n }\n return sum;\n}\n\n// turn a polygon in a multi-dimensional array form (e.g. as in GeoJSON) into a form Earcut accepts\nexport function flatten(data) {\n const vertices = [];\n const holes = [];\n const dimensions = data[0][0].length;\n let holeIndex = 0;\n let prevLen = 0;\n\n for (const ring of data) {\n for (const p of ring) {\n for (let d = 0; d < dimensions; d++) vertices.push(p[d]);\n }\n if (prevLen) {\n holeIndex += prevLen;\n holes.push(holeIndex);\n }\n prevLen = ring.length;\n }\n return {vertices, holes, dimensions};\n}\n","import type {FillStyleLayer} from '../../style/style_layer/fill_style_layer';\nimport type {FillExtrusionStyleLayer} from '../../style/style_layer/fill_extrusion_style_layer';\nimport type {LineStyleLayer} from '../../style/style_layer/line_style_layer';\n\nimport type {\n BucketFeature,\n PopulateParameters\n} from '../bucket';\nimport {PossiblyEvaluated} from '../../style/properties';\n\ntype PatternStyleLayers = Array | Array | Array;\n\nexport function hasPattern(type: string, layers: PatternStyleLayers, options: PopulateParameters) {\n const patterns = options.patternDependencies;\n let hasPattern = false;\n\n for (const layer of layers) {\n const patternProperty = (layer.paint as PossiblyEvaluated).get(`${type}-pattern`);\n if (!patternProperty.isConstant()) {\n hasPattern = true;\n }\n\n const constantPattern = patternProperty.constantOr(null);\n if (constantPattern) {\n hasPattern = true;\n patterns[constantPattern.to] = true;\n patterns[constantPattern.from] = true;\n }\n }\n\n return hasPattern;\n}\n\nexport function addPatternDependencies(type: string, layers: PatternStyleLayers, patternFeature: BucketFeature, zoom: number, options: PopulateParameters) {\n const patterns = options.patternDependencies;\n for (const layer of layers) {\n const patternProperty = (layer.paint as PossiblyEvaluated).get(`${type}-pattern`);\n\n const patternPropertyValue = patternProperty.value;\n if (patternPropertyValue.kind !== 'constant') {\n let min = patternPropertyValue.evaluate({zoom: zoom - 1}, patternFeature, {}, options.availableImages);\n let mid = patternPropertyValue.evaluate({zoom}, patternFeature, {}, options.availableImages);\n let max = patternPropertyValue.evaluate({zoom: zoom + 1}, patternFeature, {}, options.availableImages);\n min = min && min.name ? min.name : min;\n mid = mid && mid.name ? mid.name : mid;\n max = max && max.name ? max.name : max;\n // add to patternDependencies\n patterns[min] = true;\n patterns[mid] = true;\n patterns[max] = true;\n\n // save for layout\n patternFeature.patterns[layer.id] = {min, mid, max};\n }\n }\n return patternFeature;\n}\n","import {FillLayoutArray} from '../array_types.g';\n\nimport {members as layoutAttributes} from './fill_attributes';\nimport {SegmentVector} from '../segment';\nimport {ProgramConfigurationSet} from '../program_configuration';\nimport {LineIndexArray, TriangleIndexArray} from '../index_array_type';\nimport earcut from 'earcut';\nimport {classifyRings} from '@maplibre/maplibre-gl-style-spec';\nconst EARCUT_MAX_RINGS = 500;\nimport {register} from '../../util/web_worker_transfer';\nimport {hasPattern, addPatternDependencies} from './pattern_bucket_features';\nimport {loadGeometry} from '../load_geometry';\nimport {toEvaluationFeature} from '../evaluation_feature';\nimport {EvaluationParameters} from '../../style/evaluation_parameters';\n\nimport type {CanonicalTileID} from '../../source/tile_id';\nimport type {\n Bucket,\n BucketParameters,\n BucketFeature,\n IndexedFeature,\n PopulateParameters\n} from '../bucket';\nimport type {FillStyleLayer} from '../../style/style_layer/fill_style_layer';\nimport type {Context} from '../../gl/context';\nimport type {IndexBuffer} from '../../gl/index_buffer';\nimport type {VertexBuffer} from '../../gl/vertex_buffer';\nimport type Point from '@mapbox/point-geometry';\nimport type {FeatureStates} from '../../source/source_state';\nimport type {ImagePosition} from '../../render/image_atlas';\nimport type {VectorTileLayer} from '@mapbox/vector-tile';\n\nexport class FillBucket implements Bucket {\n index: number;\n zoom: number;\n overscaling: number;\n layers: Array;\n layerIds: Array;\n stateDependentLayers: Array;\n stateDependentLayerIds: Array;\n patternFeatures: Array;\n\n layoutVertexArray: FillLayoutArray;\n layoutVertexBuffer: VertexBuffer;\n\n indexArray: TriangleIndexArray;\n indexBuffer: IndexBuffer;\n\n indexArray2: LineIndexArray;\n indexBuffer2: IndexBuffer;\n\n hasPattern: boolean;\n programConfigurations: ProgramConfigurationSet;\n segments: SegmentVector;\n segments2: SegmentVector;\n uploaded: boolean;\n\n constructor(options: BucketParameters) {\n this.zoom = options.zoom;\n this.overscaling = options.overscaling;\n this.layers = options.layers;\n this.layerIds = this.layers.map(layer => layer.id);\n this.index = options.index;\n this.hasPattern = false;\n this.patternFeatures = [];\n\n this.layoutVertexArray = new FillLayoutArray();\n this.indexArray = new TriangleIndexArray();\n this.indexArray2 = new LineIndexArray();\n this.programConfigurations = new ProgramConfigurationSet(options.layers, options.zoom);\n this.segments = new SegmentVector();\n this.segments2 = new SegmentVector();\n this.stateDependentLayerIds = this.layers.filter((l) => l.isStateDependent()).map((l) => l.id);\n }\n\n populate(features: Array, options: PopulateParameters, canonical: CanonicalTileID) {\n this.hasPattern = hasPattern('fill', this.layers, options);\n const fillSortKey = this.layers[0].layout.get('fill-sort-key');\n const sortFeaturesByKey = !fillSortKey.isConstant();\n const bucketFeatures: BucketFeature[] = [];\n\n for (const {feature, id, index, sourceLayerIndex} of features) {\n const needGeometry = this.layers[0]._featureFilter.needGeometry;\n const evaluationFeature = toEvaluationFeature(feature, needGeometry);\n\n if (!this.layers[0]._featureFilter.filter(new EvaluationParameters(this.zoom), evaluationFeature, canonical)) continue;\n\n const sortKey = sortFeaturesByKey ?\n fillSortKey.evaluate(evaluationFeature, {}, canonical, options.availableImages) :\n undefined;\n\n const bucketFeature: BucketFeature = {\n id,\n properties: feature.properties,\n type: feature.type,\n sourceLayerIndex,\n index,\n geometry: needGeometry ? evaluationFeature.geometry : loadGeometry(feature),\n patterns: {},\n sortKey\n };\n\n bucketFeatures.push(bucketFeature);\n }\n\n if (sortFeaturesByKey) {\n bucketFeatures.sort((a, b) => a.sortKey - b.sortKey);\n }\n\n for (const bucketFeature of bucketFeatures) {\n const {geometry, index, sourceLayerIndex} = bucketFeature;\n\n if (this.hasPattern) {\n const patternFeature = addPatternDependencies('fill', this.layers, bucketFeature, this.zoom, options);\n // pattern features are added only once the pattern is loaded into the image atlas\n // so are stored during populate until later updated with positions by tile worker in addFeatures\n this.patternFeatures.push(patternFeature);\n } else {\n this.addFeature(bucketFeature, geometry, index, canonical, {});\n }\n\n const feature = features[index].feature;\n options.featureIndex.insert(feature, geometry, index, sourceLayerIndex, this.index);\n }\n }\n\n update(states: FeatureStates, vtLayer: VectorTileLayer, imagePositions: {\n [_: string]: ImagePosition;\n }) {\n if (!this.stateDependentLayers.length) return;\n this.programConfigurations.updatePaintArrays(states, vtLayer, this.stateDependentLayers, imagePositions);\n }\n\n addFeatures(options: PopulateParameters, canonical: CanonicalTileID, imagePositions: {\n [_: string]: ImagePosition;\n }) {\n for (const feature of this.patternFeatures) {\n this.addFeature(feature, feature.geometry, feature.index, canonical, imagePositions);\n }\n }\n\n isEmpty() {\n return this.layoutVertexArray.length === 0;\n }\n\n uploadPending(): boolean {\n return !this.uploaded || this.programConfigurations.needsUpload;\n }\n upload(context: Context) {\n if (!this.uploaded) {\n this.layoutVertexBuffer = context.createVertexBuffer(this.layoutVertexArray, layoutAttributes);\n this.indexBuffer = context.createIndexBuffer(this.indexArray);\n this.indexBuffer2 = context.createIndexBuffer(this.indexArray2);\n }\n this.programConfigurations.upload(context);\n this.uploaded = true;\n }\n\n destroy() {\n if (!this.layoutVertexBuffer) return;\n this.layoutVertexBuffer.destroy();\n this.indexBuffer.destroy();\n this.indexBuffer2.destroy();\n this.programConfigurations.destroy();\n this.segments.destroy();\n this.segments2.destroy();\n }\n\n addFeature(feature: BucketFeature, geometry: Array>, index: number, canonical: CanonicalTileID, imagePositions: {\n [_: string]: ImagePosition;\n }) {\n for (const polygon of classifyRings(geometry, EARCUT_MAX_RINGS)) {\n let numVertices = 0;\n for (const ring of polygon) {\n numVertices += ring.length;\n }\n\n const triangleSegment = this.segments.prepareSegment(numVertices, this.layoutVertexArray, this.indexArray);\n const triangleIndex = triangleSegment.vertexLength;\n\n const flattened = [];\n const holeIndices = [];\n\n for (const ring of polygon) {\n if (ring.length === 0) {\n continue;\n }\n\n if (ring !== polygon[0]) {\n holeIndices.push(flattened.length / 2);\n }\n\n const lineSegment = this.segments2.prepareSegment(ring.length, this.layoutVertexArray, this.indexArray2);\n const lineIndex = lineSegment.vertexLength;\n\n this.layoutVertexArray.emplaceBack(ring[0].x, ring[0].y);\n this.indexArray2.emplaceBack(lineIndex + ring.length - 1, lineIndex);\n flattened.push(ring[0].x);\n flattened.push(ring[0].y);\n\n for (let i = 1; i < ring.length; i++) {\n this.layoutVertexArray.emplaceBack(ring[i].x, ring[i].y);\n this.indexArray2.emplaceBack(lineIndex + i - 1, lineIndex + i);\n flattened.push(ring[i].x);\n flattened.push(ring[i].y);\n }\n\n lineSegment.vertexLength += ring.length;\n lineSegment.primitiveLength += ring.length;\n }\n\n const indices = earcut(flattened, holeIndices);\n\n for (let i = 0; i < indices.length; i += 3) {\n this.indexArray.emplaceBack(\n triangleIndex + indices[i],\n triangleIndex + indices[i + 1],\n triangleIndex + indices[i + 2]);\n }\n\n triangleSegment.vertexLength += numVertices;\n triangleSegment.primitiveLength += indices.length / 3;\n }\n this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, feature, index, imagePositions, canonical);\n }\n}\n\nregister('FillBucket', FillBucket, {omit: ['layers', 'patternFeatures']});\n","// This file is generated. Edit build/generate-style-code.ts, then run 'npm run codegen'.\n/* eslint-disable */\n\nimport {latest as styleSpec} from '@maplibre/maplibre-gl-style-spec';\n\nimport {\n Properties,\n DataConstantProperty,\n DataDrivenProperty,\n CrossFadedDataDrivenProperty,\n CrossFadedProperty,\n ColorRampProperty,\n PossiblyEvaluatedPropertyValue,\n CrossFaded\n} from '../properties';\n\nimport type {Color, Formatted, Padding, ResolvedImage, VariableAnchorOffsetCollection} from '@maplibre/maplibre-gl-style-spec';\nimport {StylePropertySpecification} from '@maplibre/maplibre-gl-style-spec';\n\nexport type FillLayoutProps = {\n \"fill-sort-key\": DataDrivenProperty,\n};\n\nexport type FillLayoutPropsPossiblyEvaluated = {\n \"fill-sort-key\": PossiblyEvaluatedPropertyValue,\n};\n\nlet layout: Properties;\nconst getLayout = () => layout = layout || new Properties({\n \"fill-sort-key\": new DataDrivenProperty(styleSpec[\"layout_fill\"][\"fill-sort-key\"] as any as StylePropertySpecification),\n});\n\nexport type FillPaintProps = {\n \"fill-antialias\": DataConstantProperty,\n \"fill-opacity\": DataDrivenProperty,\n \"fill-color\": DataDrivenProperty,\n \"fill-outline-color\": DataDrivenProperty,\n \"fill-translate\": DataConstantProperty<[number, number]>,\n \"fill-translate-anchor\": DataConstantProperty<\"map\" | \"viewport\">,\n \"fill-pattern\": CrossFadedDataDrivenProperty,\n};\n\nexport type FillPaintPropsPossiblyEvaluated = {\n \"fill-antialias\": boolean,\n \"fill-opacity\": PossiblyEvaluatedPropertyValue,\n \"fill-color\": PossiblyEvaluatedPropertyValue,\n \"fill-outline-color\": PossiblyEvaluatedPropertyValue,\n \"fill-translate\": [number, number],\n \"fill-translate-anchor\": \"map\" | \"viewport\",\n \"fill-pattern\": PossiblyEvaluatedPropertyValue>,\n};\n\nlet paint: Properties;\nconst getPaint = () => paint = paint || new Properties({\n \"fill-antialias\": new DataConstantProperty(styleSpec[\"paint_fill\"][\"fill-antialias\"] as any as StylePropertySpecification),\n \"fill-opacity\": new DataDrivenProperty(styleSpec[\"paint_fill\"][\"fill-opacity\"] as any as StylePropertySpecification),\n \"fill-color\": new DataDrivenProperty(styleSpec[\"paint_fill\"][\"fill-color\"] as any as StylePropertySpecification),\n \"fill-outline-color\": new DataDrivenProperty(styleSpec[\"paint_fill\"][\"fill-outline-color\"] as any as StylePropertySpecification),\n \"fill-translate\": new DataConstantProperty(styleSpec[\"paint_fill\"][\"fill-translate\"] as any as StylePropertySpecification),\n \"fill-translate-anchor\": new DataConstantProperty(styleSpec[\"paint_fill\"][\"fill-translate-anchor\"] as any as StylePropertySpecification),\n \"fill-pattern\": new CrossFadedDataDrivenProperty(styleSpec[\"paint_fill\"][\"fill-pattern\"] as any as StylePropertySpecification),\n});\n\nexport default ({ get paint() { return getPaint() }, get layout() { return getLayout() } });","import {StyleLayer} from '../style_layer';\n\nimport {FillBucket} from '../../data/bucket/fill_bucket';\nimport {polygonIntersectsMultiPolygon} from '../../util/intersection_tests';\nimport {translateDistance, translate} from '../query_utils';\nimport properties, {FillLayoutPropsPossiblyEvaluated, FillPaintPropsPossiblyEvaluated} from './fill_style_layer_properties.g';\nimport {Transitionable, Transitioning, Layout, PossiblyEvaluated} from '../properties';\n\nimport type {FeatureState, LayerSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {BucketParameters} from '../../data/bucket';\nimport type Point from '@mapbox/point-geometry';\nimport type {FillLayoutProps, FillPaintProps} from './fill_style_layer_properties.g';\nimport type {EvaluationParameters} from '../evaluation_parameters';\nimport type {Transform} from '../../geo/transform';\nimport type {VectorTileFeature} from '@mapbox/vector-tile';\n\nexport class FillStyleLayer extends StyleLayer {\n _unevaluatedLayout: Layout;\n layout: PossiblyEvaluated;\n\n _transitionablePaint: Transitionable;\n _transitioningPaint: Transitioning;\n paint: PossiblyEvaluated;\n\n constructor(layer: LayerSpecification) {\n super(layer, properties);\n }\n\n recalculate(parameters: EvaluationParameters, availableImages: Array) {\n super.recalculate(parameters, availableImages);\n\n const outlineColor = this.paint._values['fill-outline-color'];\n if (outlineColor.value.kind === 'constant' && outlineColor.value.value === undefined) {\n this.paint._values['fill-outline-color'] = this.paint._values['fill-color'];\n }\n }\n\n createBucket(parameters: BucketParameters) {\n return new FillBucket(parameters);\n }\n\n queryRadius(): number {\n return translateDistance(this.paint.get('fill-translate'));\n }\n\n queryIntersectsFeature(\n queryGeometry: Array,\n feature: VectorTileFeature,\n featureState: FeatureState,\n geometry: Array>,\n zoom: number,\n transform: Transform,\n pixelsToTileUnits: number\n ): boolean {\n const translatedPolygon = translate(queryGeometry,\n this.paint.get('fill-translate'),\n this.paint.get('fill-translate-anchor'),\n transform.angle, pixelsToTileUnits);\n return polygonIntersectsMultiPolygon(translatedPolygon, geometry);\n }\n\n isTileClipped() {\n return true;\n }\n}\n","import {createLayout} from '../../util/struct_array';\n\nconst layout = createLayout([\n {name: 'a_pos', components: 2, type: 'Int16'},\n {name: 'a_normal_ed', components: 4, type: 'Int16'},\n], 4);\n\nexport const centroidAttributes = createLayout([\n {name: 'a_centroid', components: 2, type: 'Int16'}\n], 4);\n\nexport default layout;\nexport const {members, size, alignment} = layout;\n","'use strict';\n\nvar Point = require('@mapbox/point-geometry');\n\nmodule.exports = VectorTileFeature;\n\nfunction VectorTileFeature(pbf, end, extent, keys, values) {\n // Public\n this.properties = {};\n this.extent = extent;\n this.type = 0;\n\n // Private\n this._pbf = pbf;\n this._geometry = -1;\n this._keys = keys;\n this._values = values;\n\n pbf.readFields(readFeature, this, end);\n}\n\nfunction readFeature(tag, feature, pbf) {\n if (tag == 1) feature.id = pbf.readVarint();\n else if (tag == 2) readTag(pbf, feature);\n else if (tag == 3) feature.type = pbf.readVarint();\n else if (tag == 4) feature._geometry = pbf.pos;\n}\n\nfunction readTag(pbf, feature) {\n var end = pbf.readVarint() + pbf.pos;\n\n while (pbf.pos < end) {\n var key = feature._keys[pbf.readVarint()],\n value = feature._values[pbf.readVarint()];\n feature.properties[key] = value;\n }\n}\n\nVectorTileFeature.types = ['Unknown', 'Point', 'LineString', 'Polygon'];\n\nVectorTileFeature.prototype.loadGeometry = function() {\n var pbf = this._pbf;\n pbf.pos = this._geometry;\n\n var end = pbf.readVarint() + pbf.pos,\n cmd = 1,\n length = 0,\n x = 0,\n y = 0,\n lines = [],\n line;\n\n while (pbf.pos < end) {\n if (length <= 0) {\n var cmdLen = pbf.readVarint();\n cmd = cmdLen & 0x7;\n length = cmdLen >> 3;\n }\n\n length--;\n\n if (cmd === 1 || cmd === 2) {\n x += pbf.readSVarint();\n y += pbf.readSVarint();\n\n if (cmd === 1) { // moveTo\n if (line) lines.push(line);\n line = [];\n }\n\n line.push(new Point(x, y));\n\n } else if (cmd === 7) {\n\n // Workaround for https://github.com/mapbox/mapnik-vector-tile/issues/90\n if (line) {\n line.push(line[0].clone()); // closePolygon\n }\n\n } else {\n throw new Error('unknown command ' + cmd);\n }\n }\n\n if (line) lines.push(line);\n\n return lines;\n};\n\nVectorTileFeature.prototype.bbox = function() {\n var pbf = this._pbf;\n pbf.pos = this._geometry;\n\n var end = pbf.readVarint() + pbf.pos,\n cmd = 1,\n length = 0,\n x = 0,\n y = 0,\n x1 = Infinity,\n x2 = -Infinity,\n y1 = Infinity,\n y2 = -Infinity;\n\n while (pbf.pos < end) {\n if (length <= 0) {\n var cmdLen = pbf.readVarint();\n cmd = cmdLen & 0x7;\n length = cmdLen >> 3;\n }\n\n length--;\n\n if (cmd === 1 || cmd === 2) {\n x += pbf.readSVarint();\n y += pbf.readSVarint();\n if (x < x1) x1 = x;\n if (x > x2) x2 = x;\n if (y < y1) y1 = y;\n if (y > y2) y2 = y;\n\n } else if (cmd !== 7) {\n throw new Error('unknown command ' + cmd);\n }\n }\n\n return [x1, y1, x2, y2];\n};\n\nVectorTileFeature.prototype.toGeoJSON = function(x, y, z) {\n var size = this.extent * Math.pow(2, z),\n x0 = this.extent * x,\n y0 = this.extent * y,\n coords = this.loadGeometry(),\n type = VectorTileFeature.types[this.type],\n i, j;\n\n function project(line) {\n for (var j = 0; j < line.length; j++) {\n var p = line[j], y2 = 180 - (p.y + y0) * 360 / size;\n line[j] = [\n (p.x + x0) * 360 / size - 180,\n 360 / Math.PI * Math.atan(Math.exp(y2 * Math.PI / 180)) - 90\n ];\n }\n }\n\n switch (this.type) {\n case 1:\n var points = [];\n for (i = 0; i < coords.length; i++) {\n points[i] = coords[i][0];\n }\n coords = points;\n project(coords);\n break;\n\n case 2:\n for (i = 0; i < coords.length; i++) {\n project(coords[i]);\n }\n break;\n\n case 3:\n coords = classifyRings(coords);\n for (i = 0; i < coords.length; i++) {\n for (j = 0; j < coords[i].length; j++) {\n project(coords[i][j]);\n }\n }\n break;\n }\n\n if (coords.length === 1) {\n coords = coords[0];\n } else {\n type = 'Multi' + type;\n }\n\n var result = {\n type: \"Feature\",\n geometry: {\n type: type,\n coordinates: coords\n },\n properties: this.properties\n };\n\n if ('id' in this) {\n result.id = this.id;\n }\n\n return result;\n};\n\n// classifies an array of rings into polygons with outer rings and holes\n\nfunction classifyRings(rings) {\n var len = rings.length;\n\n if (len <= 1) return [rings];\n\n var polygons = [],\n polygon,\n ccw;\n\n for (var i = 0; i < len; i++) {\n var area = signedArea(rings[i]);\n if (area === 0) continue;\n\n if (ccw === undefined) ccw = area < 0;\n\n if (ccw === area < 0) {\n if (polygon) polygons.push(polygon);\n polygon = [rings[i]];\n\n } else {\n polygon.push(rings[i]);\n }\n }\n if (polygon) polygons.push(polygon);\n\n return polygons;\n}\n\nfunction signedArea(ring) {\n var sum = 0;\n for (var i = 0, len = ring.length, j = len - 1, p1, p2; i < len; j = i++) {\n p1 = ring[i];\n p2 = ring[j];\n sum += (p2.x - p1.x) * (p1.y + p2.y);\n }\n return sum;\n}\n","'use strict';\n\nvar VectorTileFeature = require('./vectortilefeature.js');\n\nmodule.exports = VectorTileLayer;\n\nfunction VectorTileLayer(pbf, end) {\n // Public\n this.version = 1;\n this.name = null;\n this.extent = 4096;\n this.length = 0;\n\n // Private\n this._pbf = pbf;\n this._keys = [];\n this._values = [];\n this._features = [];\n\n pbf.readFields(readLayer, this, end);\n\n this.length = this._features.length;\n}\n\nfunction readLayer(tag, layer, pbf) {\n if (tag === 15) layer.version = pbf.readVarint();\n else if (tag === 1) layer.name = pbf.readString();\n else if (tag === 5) layer.extent = pbf.readVarint();\n else if (tag === 2) layer._features.push(pbf.pos);\n else if (tag === 3) layer._keys.push(pbf.readString());\n else if (tag === 4) layer._values.push(readValueMessage(pbf));\n}\n\nfunction readValueMessage(pbf) {\n var value = null,\n end = pbf.readVarint() + pbf.pos;\n\n while (pbf.pos < end) {\n var tag = pbf.readVarint() >> 3;\n\n value = tag === 1 ? pbf.readString() :\n tag === 2 ? pbf.readFloat() :\n tag === 3 ? pbf.readDouble() :\n tag === 4 ? pbf.readVarint64() :\n tag === 5 ? pbf.readVarint() :\n tag === 6 ? pbf.readSVarint() :\n tag === 7 ? pbf.readBoolean() : null;\n }\n\n return value;\n}\n\n// return feature `i` from this layer as a `VectorTileFeature`\nVectorTileLayer.prototype.feature = function(i) {\n if (i < 0 || i >= this._features.length) throw new Error('feature index out of bounds');\n\n this._pbf.pos = this._features[i];\n\n var end = this._pbf.readVarint() + this._pbf.pos;\n return new VectorTileFeature(this._pbf, end, this.extent, this._keys, this._values);\n};\n","'use strict';\n\nvar VectorTileLayer = require('./vectortilelayer');\n\nmodule.exports = VectorTile;\n\nfunction VectorTile(pbf, end) {\n this.layers = pbf.readFields(readTile, {}, end);\n}\n\nfunction readTile(tag, layers, pbf) {\n if (tag === 3) {\n var layer = new VectorTileLayer(pbf, pbf.readVarint() + pbf.pos);\n if (layer.length) layers[layer.name] = layer;\n }\n}\n\n","module.exports.VectorTile = require('./lib/vectortile.js');\nmodule.exports.VectorTileFeature = require('./lib/vectortilefeature.js');\nmodule.exports.VectorTileLayer = require('./lib/vectortilelayer.js');\n","import {FillExtrusionLayoutArray, PosArray} from '../array_types.g';\n\nimport {members as layoutAttributes, centroidAttributes} from './fill_extrusion_attributes';\nimport {SegmentVector} from '../segment';\nimport {ProgramConfigurationSet} from '../program_configuration';\nimport {TriangleIndexArray} from '../index_array_type';\nimport {EXTENT} from '../extent';\nimport earcut from 'earcut';\nimport mvt from '@mapbox/vector-tile';\nconst vectorTileFeatureTypes = mvt.VectorTileFeature.types;\nimport {classifyRings} from '@maplibre/maplibre-gl-style-spec';\nconst EARCUT_MAX_RINGS = 500;\nimport {register} from '../../util/web_worker_transfer';\nimport {hasPattern, addPatternDependencies} from './pattern_bucket_features';\nimport {loadGeometry} from '../load_geometry';\nimport {toEvaluationFeature} from '../evaluation_feature';\nimport {EvaluationParameters} from '../../style/evaluation_parameters';\n\nimport type {CanonicalTileID} from '../../source/tile_id';\nimport type {\n Bucket,\n BucketParameters,\n BucketFeature,\n IndexedFeature,\n PopulateParameters\n} from '../bucket';\n\nimport type {FillExtrusionStyleLayer} from '../../style/style_layer/fill_extrusion_style_layer';\nimport type {Context} from '../../gl/context';\nimport type {IndexBuffer} from '../../gl/index_buffer';\nimport type {VertexBuffer} from '../../gl/vertex_buffer';\nimport type Point from '@mapbox/point-geometry';\nimport type {FeatureStates} from '../../source/source_state';\nimport type {ImagePosition} from '../../render/image_atlas';\nimport type {VectorTileLayer} from '@mapbox/vector-tile';\n\nconst FACTOR = Math.pow(2, 13);\n\nfunction addVertex(vertexArray, x, y, nx, ny, nz, t, e) {\n vertexArray.emplaceBack(\n // a_pos\n x,\n y,\n // a_normal_ed: 3-component normal and 1-component edgedistance\n Math.floor(nx * FACTOR) * 2 + t,\n ny * FACTOR * 2,\n nz * FACTOR * 2,\n // edgedistance (used for wrapping patterns around extrusion sides)\n Math.round(e)\n );\n}\n\nexport class FillExtrusionBucket implements Bucket {\n index: number;\n zoom: number;\n overscaling: number;\n layers: Array;\n layerIds: Array;\n stateDependentLayers: Array;\n stateDependentLayerIds: Array;\n\n layoutVertexArray: FillExtrusionLayoutArray;\n layoutVertexBuffer: VertexBuffer;\n\n centroidVertexArray: PosArray;\n centroidVertexBuffer: VertexBuffer;\n\n indexArray: TriangleIndexArray;\n indexBuffer: IndexBuffer;\n\n hasPattern: boolean;\n programConfigurations: ProgramConfigurationSet;\n segments: SegmentVector;\n uploaded: boolean;\n features: Array;\n\n constructor(options: BucketParameters) {\n this.zoom = options.zoom;\n this.overscaling = options.overscaling;\n this.layers = options.layers;\n this.layerIds = this.layers.map(layer => layer.id);\n this.index = options.index;\n this.hasPattern = false;\n\n this.layoutVertexArray = new FillExtrusionLayoutArray();\n this.centroidVertexArray = new PosArray();\n this.indexArray = new TriangleIndexArray();\n this.programConfigurations = new ProgramConfigurationSet(options.layers, options.zoom);\n this.segments = new SegmentVector();\n this.stateDependentLayerIds = this.layers.filter((l) => l.isStateDependent()).map((l) => l.id);\n }\n\n populate(features: Array, options: PopulateParameters, canonical: CanonicalTileID) {\n this.features = [];\n this.hasPattern = hasPattern('fill-extrusion', this.layers, options);\n\n for (const {feature, id, index, sourceLayerIndex} of features) {\n const needGeometry = this.layers[0]._featureFilter.needGeometry;\n const evaluationFeature = toEvaluationFeature(feature, needGeometry);\n\n if (!this.layers[0]._featureFilter.filter(new EvaluationParameters(this.zoom), evaluationFeature, canonical)) continue;\n\n const bucketFeature: BucketFeature = {\n id,\n sourceLayerIndex,\n index,\n geometry: needGeometry ? evaluationFeature.geometry : loadGeometry(feature),\n properties: feature.properties,\n type: feature.type,\n patterns: {}\n };\n\n if (this.hasPattern) {\n this.features.push(addPatternDependencies('fill-extrusion', this.layers, bucketFeature, this.zoom, options));\n } else {\n this.addFeature(bucketFeature, bucketFeature.geometry, index, canonical, {});\n }\n\n options.featureIndex.insert(feature, bucketFeature.geometry, index, sourceLayerIndex, this.index, true);\n }\n }\n\n addFeatures(options: PopulateParameters, canonical: CanonicalTileID, imagePositions: {[_: string]: ImagePosition}) {\n for (const feature of this.features) {\n const {geometry} = feature;\n this.addFeature(feature, geometry, feature.index, canonical, imagePositions);\n }\n }\n\n update(states: FeatureStates, vtLayer: VectorTileLayer, imagePositions: {[_: string]: ImagePosition}) {\n if (!this.stateDependentLayers.length) return;\n this.programConfigurations.updatePaintArrays(states, vtLayer, this.stateDependentLayers, imagePositions);\n }\n\n isEmpty() {\n return this.layoutVertexArray.length === 0 && this.centroidVertexArray.length === 0;\n }\n\n uploadPending() {\n return !this.uploaded || this.programConfigurations.needsUpload;\n }\n\n upload(context: Context) {\n if (!this.uploaded) {\n this.layoutVertexBuffer = context.createVertexBuffer(this.layoutVertexArray, layoutAttributes);\n this.centroidVertexBuffer = context.createVertexBuffer(this.centroidVertexArray, centroidAttributes.members, true);\n this.indexBuffer = context.createIndexBuffer(this.indexArray);\n }\n this.programConfigurations.upload(context);\n this.uploaded = true;\n }\n\n destroy() {\n if (!this.layoutVertexBuffer) return;\n this.layoutVertexBuffer.destroy();\n this.indexBuffer.destroy();\n this.programConfigurations.destroy();\n this.segments.destroy();\n this.centroidVertexBuffer.destroy();\n }\n\n addFeature(feature: BucketFeature, geometry: Array>, index: number, canonical: CanonicalTileID, imagePositions: {[_: string]: ImagePosition}) {\n for (const polygon of classifyRings(geometry, EARCUT_MAX_RINGS)) {\n\n const centroid = {x: 0, y: 0, vertexCount: 0};\n\n let numVertices = 0;\n for (const ring of polygon) {\n numVertices += ring.length;\n }\n let segment = this.segments.prepareSegment(4, this.layoutVertexArray, this.indexArray);\n\n for (const ring of polygon) {\n if (ring.length === 0) {\n continue;\n }\n\n if (isEntirelyOutside(ring)) {\n continue;\n }\n\n let edgeDistance = 0;\n\n for (let p = 0; p < ring.length; p++) {\n const p1 = ring[p];\n\n if (p >= 1) {\n const p2 = ring[p - 1];\n\n if (!isBoundaryEdge(p1, p2)) {\n if (segment.vertexLength + 4 > SegmentVector.MAX_VERTEX_ARRAY_LENGTH) {\n segment = this.segments.prepareSegment(4, this.layoutVertexArray, this.indexArray);\n }\n\n const perp = p1.sub(p2)._perp()._unit();\n const dist = p2.dist(p1);\n if (edgeDistance + dist > 32768) edgeDistance = 0;\n\n addVertex(this.layoutVertexArray, p1.x, p1.y, perp.x, perp.y, 0, 0, edgeDistance);\n addVertex(this.layoutVertexArray, p1.x, p1.y, perp.x, perp.y, 0, 1, edgeDistance);\n centroid.x += 2 * p1.x;\n centroid.y += 2 * p1.y;\n centroid.vertexCount += 2;\n\n edgeDistance += dist;\n\n addVertex(this.layoutVertexArray, p2.x, p2.y, perp.x, perp.y, 0, 0, edgeDistance);\n addVertex(this.layoutVertexArray, p2.x, p2.y, perp.x, perp.y, 0, 1, edgeDistance);\n centroid.x += 2 * p2.x;\n centroid.y += 2 * p2.y;\n centroid.vertexCount += 2;\n\n const bottomRight = segment.vertexLength;\n\n // ┌──────┐\n // │ 0 1 │ Counter-clockwise winding order.\n // │ │ Triangle 1: 0 => 2 => 1\n // │ 2 3 │ Triangle 2: 1 => 2 => 3\n // └──────┘\n this.indexArray.emplaceBack(bottomRight, bottomRight + 2, bottomRight + 1);\n this.indexArray.emplaceBack(bottomRight + 1, bottomRight + 2, bottomRight + 3);\n\n segment.vertexLength += 4;\n segment.primitiveLength += 2;\n }\n }\n }\n\n }\n\n if (segment.vertexLength + numVertices > SegmentVector.MAX_VERTEX_ARRAY_LENGTH) {\n segment = this.segments.prepareSegment(numVertices, this.layoutVertexArray, this.indexArray);\n }\n\n //Only triangulate and draw the area of the feature if it is a polygon\n //Other feature types (e.g. LineString) do not have area, so triangulation is pointless / undefined\n if (vectorTileFeatureTypes[feature.type] !== 'Polygon')\n continue;\n\n const flattened = [];\n const holeIndices = [];\n const triangleIndex = segment.vertexLength;\n\n for (const ring of polygon) {\n if (ring.length === 0) {\n continue;\n }\n\n if (ring !== polygon[0]) {\n holeIndices.push(flattened.length / 2);\n }\n\n for (let i = 0; i < ring.length; i++) {\n const p = ring[i];\n\n addVertex(this.layoutVertexArray, p.x, p.y, 0, 0, 1, 1, 0);\n centroid.x += p.x;\n centroid.y += p.y;\n centroid.vertexCount += 1;\n\n flattened.push(p.x);\n flattened.push(p.y);\n }\n\n }\n\n const indices = earcut(flattened, holeIndices);\n\n for (let j = 0; j < indices.length; j += 3) {\n // Counter-clockwise winding order.\n this.indexArray.emplaceBack(\n triangleIndex + indices[j],\n triangleIndex + indices[j + 2],\n triangleIndex + indices[j + 1]);\n }\n\n segment.primitiveLength += indices.length / 3;\n segment.vertexLength += numVertices;\n\n // remember polygon centroid to calculate elevation in GPU\n for (let i = 0; i < centroid.vertexCount; i++) {\n const averageX = Math.floor(centroid.x / centroid.vertexCount);\n const averageY = Math.floor(centroid.y / centroid.vertexCount);\n this.centroidVertexArray.emplaceBack(averageX, averageY);\n }\n\n }\n\n this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, feature, index, imagePositions, canonical);\n }\n}\n\nregister('FillExtrusionBucket', FillExtrusionBucket, {omit: ['layers', 'features']});\n\nfunction isBoundaryEdge(p1, p2) {\n return (p1.x === p2.x && (p1.x < 0 || p1.x > EXTENT)) ||\n (p1.y === p2.y && (p1.y < 0 || p1.y > EXTENT));\n}\n\nfunction isEntirelyOutside(ring) {\n return ring.every(p => p.x < 0) ||\n ring.every(p => p.x > EXTENT) ||\n ring.every(p => p.y < 0) ||\n ring.every(p => p.y > EXTENT);\n}\n","// This file is generated. Edit build/generate-style-code.ts, then run 'npm run codegen'.\n/* eslint-disable */\n\nimport {latest as styleSpec} from '@maplibre/maplibre-gl-style-spec';\n\nimport {\n Properties,\n DataConstantProperty,\n DataDrivenProperty,\n CrossFadedDataDrivenProperty,\n CrossFadedProperty,\n ColorRampProperty,\n PossiblyEvaluatedPropertyValue,\n CrossFaded\n} from '../properties';\n\nimport type {Color, Formatted, Padding, ResolvedImage, VariableAnchorOffsetCollection} from '@maplibre/maplibre-gl-style-spec';\nimport {StylePropertySpecification} from '@maplibre/maplibre-gl-style-spec';\n\n\nexport type FillExtrusionPaintProps = {\n \"fill-extrusion-opacity\": DataConstantProperty,\n \"fill-extrusion-color\": DataDrivenProperty,\n \"fill-extrusion-translate\": DataConstantProperty<[number, number]>,\n \"fill-extrusion-translate-anchor\": DataConstantProperty<\"map\" | \"viewport\">,\n \"fill-extrusion-pattern\": CrossFadedDataDrivenProperty,\n \"fill-extrusion-height\": DataDrivenProperty,\n \"fill-extrusion-base\": DataDrivenProperty,\n \"fill-extrusion-vertical-gradient\": DataConstantProperty,\n};\n\nexport type FillExtrusionPaintPropsPossiblyEvaluated = {\n \"fill-extrusion-opacity\": number,\n \"fill-extrusion-color\": PossiblyEvaluatedPropertyValue,\n \"fill-extrusion-translate\": [number, number],\n \"fill-extrusion-translate-anchor\": \"map\" | \"viewport\",\n \"fill-extrusion-pattern\": PossiblyEvaluatedPropertyValue>,\n \"fill-extrusion-height\": PossiblyEvaluatedPropertyValue,\n \"fill-extrusion-base\": PossiblyEvaluatedPropertyValue,\n \"fill-extrusion-vertical-gradient\": boolean,\n};\n\nlet paint: Properties;\nconst getPaint = () => paint = paint || new Properties({\n \"fill-extrusion-opacity\": new DataConstantProperty(styleSpec[\"paint_fill-extrusion\"][\"fill-extrusion-opacity\"] as any as StylePropertySpecification),\n \"fill-extrusion-color\": new DataDrivenProperty(styleSpec[\"paint_fill-extrusion\"][\"fill-extrusion-color\"] as any as StylePropertySpecification),\n \"fill-extrusion-translate\": new DataConstantProperty(styleSpec[\"paint_fill-extrusion\"][\"fill-extrusion-translate\"] as any as StylePropertySpecification),\n \"fill-extrusion-translate-anchor\": new DataConstantProperty(styleSpec[\"paint_fill-extrusion\"][\"fill-extrusion-translate-anchor\"] as any as StylePropertySpecification),\n \"fill-extrusion-pattern\": new CrossFadedDataDrivenProperty(styleSpec[\"paint_fill-extrusion\"][\"fill-extrusion-pattern\"] as any as StylePropertySpecification),\n \"fill-extrusion-height\": new DataDrivenProperty(styleSpec[\"paint_fill-extrusion\"][\"fill-extrusion-height\"] as any as StylePropertySpecification),\n \"fill-extrusion-base\": new DataDrivenProperty(styleSpec[\"paint_fill-extrusion\"][\"fill-extrusion-base\"] as any as StylePropertySpecification),\n \"fill-extrusion-vertical-gradient\": new DataConstantProperty(styleSpec[\"paint_fill-extrusion\"][\"fill-extrusion-vertical-gradient\"] as any as StylePropertySpecification),\n});\n\nexport default ({ get paint() { return getPaint() } });","import {StyleLayer} from '../style_layer';\n\nimport {FillExtrusionBucket} from '../../data/bucket/fill_extrusion_bucket';\nimport {polygonIntersectsPolygon, polygonIntersectsMultiPolygon} from '../../util/intersection_tests';\nimport {translateDistance, translate} from '../query_utils';\nimport properties, {FillExtrusionPaintPropsPossiblyEvaluated} from './fill_extrusion_style_layer_properties.g';\nimport {Transitionable, Transitioning, PossiblyEvaluated} from '../properties';\nimport {mat4, vec4} from 'gl-matrix';\nimport Point from '@mapbox/point-geometry';\nimport type {FeatureState, LayerSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {BucketParameters} from '../../data/bucket';\nimport type {FillExtrusionPaintProps} from './fill_extrusion_style_layer_properties.g';\nimport type {Transform} from '../../geo/transform';\nimport type {VectorTileFeature} from '@mapbox/vector-tile';\n\nexport class Point3D extends Point {\n z: number;\n}\n\nexport class FillExtrusionStyleLayer extends StyleLayer {\n _transitionablePaint: Transitionable;\n _transitioningPaint: Transitioning;\n paint: PossiblyEvaluated;\n\n constructor(layer: LayerSpecification) {\n super(layer, properties);\n }\n\n createBucket(parameters: BucketParameters) {\n return new FillExtrusionBucket(parameters);\n }\n\n queryRadius(): number {\n return translateDistance(this.paint.get('fill-extrusion-translate'));\n }\n\n is3D(): boolean {\n return true;\n }\n\n queryIntersectsFeature(\n queryGeometry: Array,\n feature: VectorTileFeature,\n featureState: FeatureState,\n geometry: Array>,\n zoom: number,\n transform: Transform,\n pixelsToTileUnits: number,\n pixelPosMatrix: mat4\n ): boolean | number {\n\n const translatedPolygon = translate(queryGeometry,\n this.paint.get('fill-extrusion-translate'),\n this.paint.get('fill-extrusion-translate-anchor'),\n transform.angle, pixelsToTileUnits);\n\n const height = this.paint.get('fill-extrusion-height').evaluate(feature, featureState);\n const base = this.paint.get('fill-extrusion-base').evaluate(feature, featureState);\n\n const projectedQueryGeometry = projectQueryGeometry(translatedPolygon, pixelPosMatrix, transform, 0);\n\n const projected = projectExtrusion(geometry, base, height, pixelPosMatrix);\n const projectedBase = projected[0];\n const projectedTop = projected[1];\n return checkIntersection(projectedBase, projectedTop, projectedQueryGeometry);\n }\n}\n\nfunction dot(a, b) {\n return a.x * b.x + a.y * b.y;\n}\n\nexport function getIntersectionDistance(projectedQueryGeometry: Array, projectedFace: Array) {\n\n if (projectedQueryGeometry.length === 1) {\n // For point queries calculate the z at which the point intersects the face\n // using barycentric coordinates.\n\n // Find the barycentric coordinates of the projected point within the first\n // triangle of the face, using only the xy plane. It doesn't matter if the\n // point is outside the first triangle because all the triangles in the face\n // are in the same plane.\n //\n // Check whether points are coincident and use other points if they are.\n let i = 0;\n const a = projectedFace[i++];\n let b;\n while (!b || a.equals(b)) {\n b = projectedFace[i++];\n if (!b) return Infinity;\n }\n\n // Loop until point `c` is not colinear with points `a` and `b`.\n for (; i < projectedFace.length; i++) {\n const c = projectedFace[i];\n\n const p = projectedQueryGeometry[0];\n\n const ab = b.sub(a);\n const ac = c.sub(a);\n const ap = p.sub(a);\n\n const dotABAB = dot(ab, ab);\n const dotABAC = dot(ab, ac);\n const dotACAC = dot(ac, ac);\n const dotAPAB = dot(ap, ab);\n const dotAPAC = dot(ap, ac);\n const denom = dotABAB * dotACAC - dotABAC * dotABAC;\n\n const v = (dotACAC * dotAPAB - dotABAC * dotAPAC) / denom;\n const w = (dotABAB * dotAPAC - dotABAC * dotAPAB) / denom;\n const u = 1 - v - w;\n\n // Use the barycentric weighting along with the original triangle z coordinates to get the point of intersection.\n const distance = a.z * u + b.z * v + c.z * w;\n\n if (isFinite(distance)) return distance;\n }\n\n return Infinity;\n\n } else {\n // The counts as closest is less clear when the query is a box. This\n // returns the distance to the nearest point on the face, whether it is\n // within the query or not. It could be more correct to return the\n // distance to the closest point within the query box but this would be\n // more complicated and expensive to calculate with little benefit.\n let closestDistance = Infinity;\n for (const p of projectedFace) {\n closestDistance = Math.min(closestDistance, p.z);\n }\n return closestDistance;\n }\n}\n\nfunction checkIntersection(projectedBase: Array>, projectedTop: Array>, projectedQueryGeometry: Array) {\n let closestDistance = Infinity;\n\n if (polygonIntersectsMultiPolygon(projectedQueryGeometry, projectedTop)) {\n closestDistance = getIntersectionDistance(projectedQueryGeometry, projectedTop[0]);\n }\n\n for (let r = 0; r < projectedTop.length; r++) {\n const ringTop = projectedTop[r];\n const ringBase = projectedBase[r];\n for (let p = 0; p < ringTop.length - 1; p++) {\n const topA = ringTop[p];\n const topB = ringTop[p + 1];\n const baseA = ringBase[p];\n const baseB = ringBase[p + 1];\n const face = [topA, topB, baseB, baseA, topA];\n if (polygonIntersectsPolygon(projectedQueryGeometry, face)) {\n closestDistance = Math.min(closestDistance, getIntersectionDistance(projectedQueryGeometry, face));\n }\n }\n }\n\n return closestDistance === Infinity ? false : closestDistance;\n}\n\n/*\n * Project the geometry using matrix `m`. This is essentially doing\n * `vec4.transformMat4([], [p.x, p.y, z, 1], m)` but the multiplication\n * is inlined so that parts of the projection that are the same across\n * different points can only be done once. This produced a measurable\n * performance improvement.\n */\nfunction projectExtrusion(geometry: Array>, zBase: number, zTop: number, m: mat4): [Array>, Array>] {\n const projectedBase = [] as Array>;\n const projectedTop = [] as Array>;\n const baseXZ = m[8] * zBase;\n const baseYZ = m[9] * zBase;\n const baseZZ = m[10] * zBase;\n const baseWZ = m[11] * zBase;\n const topXZ = m[8] * zTop;\n const topYZ = m[9] * zTop;\n const topZZ = m[10] * zTop;\n const topWZ = m[11] * zTop;\n\n for (const r of geometry) {\n const ringBase = [] as Array;\n const ringTop = [] as Array;\n for (const p of r) {\n const x = p.x;\n const y = p.y;\n\n const sX = m[0] * x + m[4] * y + m[12];\n const sY = m[1] * x + m[5] * y + m[13];\n const sZ = m[2] * x + m[6] * y + m[14];\n const sW = m[3] * x + m[7] * y + m[15];\n\n const baseX = sX + baseXZ;\n const baseY = sY + baseYZ;\n const baseZ = sZ + baseZZ;\n const baseW = sW + baseWZ;\n\n const topX = sX + topXZ;\n const topY = sY + topYZ;\n const topZ = sZ + topZZ;\n const topW = sW + topWZ;\n\n const b = new Point(baseX / baseW, baseY / baseW) as Point3D;\n b.z = baseZ / baseW;\n ringBase.push(b);\n\n const t = new Point(topX / topW, topY / topW) as Point3D;\n t.z = topZ / topW;\n ringTop.push(t);\n }\n projectedBase.push(ringBase);\n projectedTop.push(ringTop);\n }\n return [projectedBase, projectedTop];\n}\n\nfunction projectQueryGeometry(queryGeometry: Array, pixelPosMatrix: mat4, transform: Transform, z: number) {\n const projectedQueryGeometry = [];\n for (const p of queryGeometry) {\n const v = [p.x, p.y, z, 1] as vec4;\n vec4.transformMat4(v, v, pixelPosMatrix);\n projectedQueryGeometry.push(new Point(v[0] / v[3], v[1] / v[3]));\n }\n return projectedQueryGeometry;\n}\n","import {createLayout} from '../../util/struct_array';\n\nexport const lineLayoutAttributes = createLayout([\n {name: 'a_pos_normal', components: 2, type: 'Int16'},\n {name: 'a_data', components: 4, type: 'Uint8'}\n], 4);\n\nexport const {members, size, alignment} = lineLayoutAttributes;\n","import {createLayout} from '../../util/struct_array';\n\nexport const lineLayoutAttributesExt = createLayout([\n {name: 'a_uv_x', components: 1, type: 'Float32'},\n {name: 'a_split_index', components: 1, type: 'Float32'},\n]);\n\nexport const {members, size, alignment} = lineLayoutAttributesExt;\n","import {LineLayoutArray, LineExtLayoutArray} from '../array_types.g';\n\nimport {members as layoutAttributes} from './line_attributes';\nimport {members as layoutAttributesExt} from './line_attributes_ext';\nimport {SegmentVector} from '../segment';\nimport {ProgramConfigurationSet} from '../program_configuration';\nimport {TriangleIndexArray} from '../index_array_type';\nimport {EXTENT} from '../extent';\nimport mvt from '@mapbox/vector-tile';\nconst vectorTileFeatureTypes = mvt.VectorTileFeature.types;\nimport {register} from '../../util/web_worker_transfer';\nimport {hasPattern, addPatternDependencies} from './pattern_bucket_features';\nimport {loadGeometry} from '../load_geometry';\nimport {toEvaluationFeature} from '../evaluation_feature';\nimport {EvaluationParameters} from '../../style/evaluation_parameters';\n\nimport type {CanonicalTileID} from '../../source/tile_id';\nimport type {\n Bucket,\n BucketParameters,\n BucketFeature,\n IndexedFeature,\n PopulateParameters\n} from '../bucket';\nimport type {LineStyleLayer} from '../../style/style_layer/line_style_layer';\nimport type Point from '@mapbox/point-geometry';\nimport type {Segment} from '../segment';\nimport {RGBAImage} from '../../util/image';\nimport type {Context} from '../../gl/context';\nimport type {Texture} from '../../render/texture';\nimport type {IndexBuffer} from '../../gl/index_buffer';\nimport type {VertexBuffer} from '../../gl/vertex_buffer';\nimport type {FeatureStates} from '../../source/source_state';\nimport type {ImagePosition} from '../../render/image_atlas';\nimport type {VectorTileLayer} from '@mapbox/vector-tile';\n\n// NOTE ON EXTRUDE SCALE:\n// scale the extrusion vector so that the normal length is this value.\n// contains the \"texture\" normals (-1..1). this is distinct from the extrude\n// normals for line joins, because the x-value remains 0 for the texture\n// normal array, while the extrude normal actually moves the vertex to create\n// the acute/bevelled line join.\nconst EXTRUDE_SCALE = 63;\n\n/*\n * Sharp corners cause dashed lines to tilt because the distance along the line\n * is the same at both the inner and outer corners. To improve the appearance of\n * dashed lines we add extra points near sharp corners so that a smaller part\n * of the line is tilted.\n *\n * COS_HALF_SHARP_CORNER controls how sharp a corner has to be for us to add an\n * extra vertex. The default is 75 degrees.\n *\n * The newly created vertices are placed SHARP_CORNER_OFFSET pixels from the corner.\n */\nconst COS_HALF_SHARP_CORNER = Math.cos(75 / 2 * (Math.PI / 180));\nconst SHARP_CORNER_OFFSET = 15;\n\n// Angle per triangle for approximating round line joins.\nconst DEG_PER_TRIANGLE = 20;\n\n// The number of bits that is used to store the line distance in the buffer.\nconst LINE_DISTANCE_BUFFER_BITS = 15;\n\n// We don't have enough bits for the line distance as we'd like to have, so\n// use this value to scale the line distance (in tile units) down to a smaller\n// value. This lets us store longer distances while sacrificing precision.\nconst LINE_DISTANCE_SCALE = 1 / 2;\n\n// The maximum line distance, in tile units, that fits in the buffer.\nconst MAX_LINE_DISTANCE = Math.pow(2, LINE_DISTANCE_BUFFER_BITS - 1) / LINE_DISTANCE_SCALE;\n\ntype LineClips = {\n start: number;\n end: number;\n};\n\ntype GradientTexture = {\n texture?: Texture;\n gradient?: RGBAImage;\n version?: number;\n};\n\n/**\n * @internal\n * Line bucket class\n */\nexport class LineBucket implements Bucket {\n distance: number;\n totalDistance: number;\n maxLineLength: number;\n scaledDistance: number;\n lineClips?: LineClips;\n\n e1: number;\n e2: number;\n\n index: number;\n zoom: number;\n overscaling: number;\n layers: Array;\n layerIds: Array;\n gradients: {[x: string]: GradientTexture};\n stateDependentLayers: Array;\n stateDependentLayerIds: Array;\n patternFeatures: Array;\n lineClipsArray: Array;\n\n layoutVertexArray: LineLayoutArray;\n layoutVertexBuffer: VertexBuffer;\n layoutVertexArray2: LineExtLayoutArray;\n layoutVertexBuffer2: VertexBuffer;\n\n indexArray: TriangleIndexArray;\n indexBuffer: IndexBuffer;\n\n hasPattern: boolean;\n programConfigurations: ProgramConfigurationSet;\n segments: SegmentVector;\n uploaded: boolean;\n\n constructor(options: BucketParameters) {\n this.zoom = options.zoom;\n this.overscaling = options.overscaling;\n this.layers = options.layers;\n this.layerIds = this.layers.map(layer => layer.id);\n this.index = options.index;\n this.hasPattern = false;\n this.patternFeatures = [];\n this.lineClipsArray = [];\n this.gradients = {};\n this.layers.forEach(layer => {\n this.gradients[layer.id] = {};\n });\n\n this.layoutVertexArray = new LineLayoutArray();\n this.layoutVertexArray2 = new LineExtLayoutArray();\n this.indexArray = new TriangleIndexArray();\n this.programConfigurations = new ProgramConfigurationSet(options.layers, options.zoom);\n this.segments = new SegmentVector();\n this.maxLineLength = 0;\n\n this.stateDependentLayerIds = this.layers.filter((l) => l.isStateDependent()).map((l) => l.id);\n }\n\n populate(features: Array, options: PopulateParameters, canonical: CanonicalTileID) {\n this.hasPattern = hasPattern('line', this.layers, options);\n const lineSortKey = this.layers[0].layout.get('line-sort-key');\n const sortFeaturesByKey = !lineSortKey.isConstant();\n const bucketFeatures: BucketFeature[] = [];\n\n for (const {feature, id, index, sourceLayerIndex} of features) {\n const needGeometry = this.layers[0]._featureFilter.needGeometry;\n const evaluationFeature = toEvaluationFeature(feature, needGeometry);\n\n if (!this.layers[0]._featureFilter.filter(new EvaluationParameters(this.zoom), evaluationFeature, canonical)) continue;\n\n const sortKey = sortFeaturesByKey ?\n lineSortKey.evaluate(evaluationFeature, {}, canonical) :\n undefined;\n\n const bucketFeature: BucketFeature = {\n id,\n properties: feature.properties,\n type: feature.type,\n sourceLayerIndex,\n index,\n geometry: needGeometry ? evaluationFeature.geometry : loadGeometry(feature),\n patterns: {},\n sortKey\n };\n\n bucketFeatures.push(bucketFeature);\n }\n\n if (sortFeaturesByKey) {\n bucketFeatures.sort((a, b) => {\n return (a.sortKey) - (b.sortKey);\n });\n }\n\n for (const bucketFeature of bucketFeatures) {\n const {geometry, index, sourceLayerIndex} = bucketFeature;\n\n if (this.hasPattern) {\n const patternBucketFeature = addPatternDependencies('line', this.layers, bucketFeature, this.zoom, options);\n // pattern features are added only once the pattern is loaded into the image atlas\n // so are stored during populate until later updated with positions by tile worker in addFeatures\n this.patternFeatures.push(patternBucketFeature);\n } else {\n this.addFeature(bucketFeature, geometry, index, canonical, {});\n }\n\n const feature = features[index].feature;\n options.featureIndex.insert(feature, geometry, index, sourceLayerIndex, this.index);\n }\n }\n\n update(states: FeatureStates, vtLayer: VectorTileLayer, imagePositions: {[_: string]: ImagePosition}) {\n if (!this.stateDependentLayers.length) return;\n this.programConfigurations.updatePaintArrays(states, vtLayer, this.stateDependentLayers, imagePositions);\n }\n\n addFeatures(options: PopulateParameters, canonical: CanonicalTileID, imagePositions: {[_: string]: ImagePosition}) {\n for (const feature of this.patternFeatures) {\n this.addFeature(feature, feature.geometry, feature.index, canonical, imagePositions);\n }\n }\n\n isEmpty() {\n return this.layoutVertexArray.length === 0;\n }\n\n uploadPending() {\n return !this.uploaded || this.programConfigurations.needsUpload;\n }\n\n upload(context: Context) {\n if (!this.uploaded) {\n if (this.layoutVertexArray2.length !== 0) {\n this.layoutVertexBuffer2 = context.createVertexBuffer(this.layoutVertexArray2, layoutAttributesExt);\n }\n this.layoutVertexBuffer = context.createVertexBuffer(this.layoutVertexArray, layoutAttributes);\n this.indexBuffer = context.createIndexBuffer(this.indexArray);\n }\n this.programConfigurations.upload(context);\n this.uploaded = true;\n }\n\n destroy() {\n if (!this.layoutVertexBuffer) return;\n this.layoutVertexBuffer.destroy();\n this.indexBuffer.destroy();\n this.programConfigurations.destroy();\n this.segments.destroy();\n }\n\n lineFeatureClips(feature: BucketFeature): LineClips | undefined {\n if (!!feature.properties && Object.prototype.hasOwnProperty.call(feature.properties, 'mapbox_clip_start') && Object.prototype.hasOwnProperty.call(feature.properties, 'mapbox_clip_end')) {\n const start = +feature.properties['mapbox_clip_start'];\n const end = +feature.properties['mapbox_clip_end'];\n return {start, end};\n }\n }\n\n addFeature(feature: BucketFeature, geometry: Array>, index: number, canonical: CanonicalTileID, imagePositions: {[_: string]: ImagePosition}) {\n const layout = this.layers[0].layout;\n const join = layout.get('line-join').evaluate(feature, {});\n const cap = layout.get('line-cap');\n const miterLimit = layout.get('line-miter-limit');\n const roundLimit = layout.get('line-round-limit');\n this.lineClips = this.lineFeatureClips(feature);\n\n for (const line of geometry) {\n this.addLine(line, feature, join, cap, miterLimit, roundLimit);\n }\n\n this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, feature, index, imagePositions, canonical);\n }\n\n addLine(vertices: Array, feature: BucketFeature, join: string, cap: string, miterLimit: number, roundLimit: number) {\n this.distance = 0;\n this.scaledDistance = 0;\n this.totalDistance = 0;\n\n if (this.lineClips) {\n this.lineClipsArray.push(this.lineClips);\n // Calculate the total distance, in tile units, of this tiled line feature\n for (let i = 0; i < vertices.length - 1; i++) {\n this.totalDistance += vertices[i].dist(vertices[i + 1]);\n }\n this.updateScaledDistance();\n this.maxLineLength = Math.max(this.maxLineLength, this.totalDistance);\n }\n\n const isPolygon = vectorTileFeatureTypes[feature.type] === 'Polygon';\n\n // If the line has duplicate vertices at the ends, adjust start/length to remove them.\n let len = vertices.length;\n while (len >= 2 && vertices[len - 1].equals(vertices[len - 2])) {\n len--;\n }\n let first = 0;\n while (first < len - 1 && vertices[first].equals(vertices[first + 1])) {\n first++;\n }\n\n // Ignore invalid geometry.\n if (len < (isPolygon ? 3 : 2)) return;\n\n if (join === 'bevel') miterLimit = 1.05;\n\n const sharpCornerOffset = this.overscaling <= 16 ?\n SHARP_CORNER_OFFSET * EXTENT / (512 * this.overscaling) :\n 0;\n\n // we could be more precise, but it would only save a negligible amount of space\n const segment = this.segments.prepareSegment(len * 10, this.layoutVertexArray, this.indexArray);\n\n let currentVertex: Point;\n let prevVertex: Point;\n let nextVertex: Point;\n let prevNormal: Point;\n let nextNormal: Point;\n\n // the last two vertices added\n this.e1 = this.e2 = -1;\n\n if (isPolygon) {\n currentVertex = vertices[len - 2];\n nextNormal = vertices[first].sub(currentVertex)._unit()._perp();\n }\n\n for (let i = first; i < len; i++) {\n\n nextVertex = i === len - 1 ?\n (isPolygon ? vertices[first + 1] : undefined) : // if it's a polygon, treat the last vertex like the first\n vertices[i + 1]; // just the next vertex\n\n // if two consecutive vertices exist, skip the current one\n if (nextVertex && vertices[i].equals(nextVertex)) continue;\n\n if (nextNormal) prevNormal = nextNormal;\n if (currentVertex) prevVertex = currentVertex;\n\n currentVertex = vertices[i];\n\n // Calculate the normal towards the next vertex in this line. In case\n // there is no next vertex, pretend that the line is continuing straight,\n // meaning that we are just using the previous normal.\n nextNormal = nextVertex ? nextVertex.sub(currentVertex)._unit()._perp() : prevNormal;\n\n // If we still don't have a previous normal, this is the beginning of a\n // non-closed line, so we're doing a straight \"join\".\n prevNormal = prevNormal || nextNormal;\n\n // Determine the normal of the join extrusion. It is the angle bisector\n // of the segments between the previous line and the next line.\n // In the case of 180° angles, the prev and next normals cancel each other out:\n // prevNormal + nextNormal = (0, 0), its magnitude is 0, so the unit vector would be\n // undefined. In that case, we're keeping the joinNormal at (0, 0), so that the cosHalfAngle\n // below will also become 0 and miterLength will become Infinity.\n let joinNormal = prevNormal.add(nextNormal);\n if (joinNormal.x !== 0 || joinNormal.y !== 0) {\n joinNormal._unit();\n }\n /* joinNormal prevNormal\n * ↖ ↑\n * .________. prevVertex\n * |\n * nextNormal ← | currentVertex\n * |\n * nextVertex !\n *\n */\n\n // calculate cosines of the angle (and its half) using dot product\n const cosAngle = prevNormal.x * nextNormal.x + prevNormal.y * nextNormal.y;\n const cosHalfAngle = joinNormal.x * nextNormal.x + joinNormal.y * nextNormal.y;\n\n // Calculate the length of the miter (the ratio of the miter to the width)\n // as the inverse of cosine of the angle between next and join normals\n const miterLength = cosHalfAngle !== 0 ? 1 / cosHalfAngle : Infinity;\n\n // approximate angle from cosine\n const approxAngle = 2 * Math.sqrt(2 - 2 * cosHalfAngle);\n\n const isSharpCorner = cosHalfAngle < COS_HALF_SHARP_CORNER && prevVertex && nextVertex;\n const lineTurnsLeft = prevNormal.x * nextNormal.y - prevNormal.y * nextNormal.x > 0;\n\n if (isSharpCorner && i > first) {\n const prevSegmentLength = currentVertex.dist(prevVertex);\n if (prevSegmentLength > 2 * sharpCornerOffset) {\n const newPrevVertex = currentVertex.sub(currentVertex.sub(prevVertex)._mult(sharpCornerOffset / prevSegmentLength)._round());\n this.updateDistance(prevVertex, newPrevVertex);\n this.addCurrentVertex(newPrevVertex, prevNormal, 0, 0, segment);\n prevVertex = newPrevVertex;\n }\n }\n\n // The join if a middle vertex, otherwise the cap.\n const middleVertex = prevVertex && nextVertex;\n let currentJoin = middleVertex ? join : isPolygon ? 'butt' : cap;\n\n if (middleVertex && currentJoin === 'round') {\n if (miterLength < roundLimit) {\n currentJoin = 'miter';\n } else if (miterLength <= 2) {\n currentJoin = 'fakeround';\n }\n }\n\n if (currentJoin === 'miter' && miterLength > miterLimit) {\n currentJoin = 'bevel';\n }\n\n if (currentJoin === 'bevel') {\n // The maximum extrude length is 128 / 63 = 2 times the width of the line\n // so if miterLength >= 2 we need to draw a different type of bevel here.\n if (miterLength > 2) currentJoin = 'flipbevel';\n\n // If the miterLength is really small and the line bevel wouldn't be visible,\n // just draw a miter join to save a triangle.\n if (miterLength < miterLimit) currentJoin = 'miter';\n }\n\n // Calculate how far along the line the currentVertex is\n if (prevVertex) this.updateDistance(prevVertex, currentVertex);\n\n if (currentJoin === 'miter') {\n\n joinNormal._mult(miterLength);\n this.addCurrentVertex(currentVertex, joinNormal, 0, 0, segment);\n\n } else if (currentJoin === 'flipbevel') {\n // miter is too big, flip the direction to make a beveled join\n\n if (miterLength > 100) {\n // Almost parallel lines\n joinNormal = nextNormal.mult(-1);\n\n } else {\n const bevelLength = miterLength * prevNormal.add(nextNormal).mag() / prevNormal.sub(nextNormal).mag();\n joinNormal._perp()._mult(bevelLength * (lineTurnsLeft ? -1 : 1));\n }\n this.addCurrentVertex(currentVertex, joinNormal, 0, 0, segment);\n this.addCurrentVertex(currentVertex, joinNormal.mult(-1), 0, 0, segment);\n\n } else if (currentJoin === 'bevel' || currentJoin === 'fakeround') {\n const offset = -Math.sqrt(miterLength * miterLength - 1);\n const offsetA = lineTurnsLeft ? offset : 0;\n const offsetB = lineTurnsLeft ? 0 : offset;\n\n // Close previous segment with a bevel\n if (prevVertex) {\n this.addCurrentVertex(currentVertex, prevNormal, offsetA, offsetB, segment);\n }\n\n if (currentJoin === 'fakeround') {\n // The join angle is sharp enough that a round join would be visible.\n // Bevel joins fill the gap between segments with a single pie slice triangle.\n // Create a round join by adding multiple pie slices. The join isn't actually round, but\n // it looks like it is at the sizes we render lines at.\n\n // pick the number of triangles for approximating round join by based on the angle between normals\n const n = Math.round((approxAngle * 180 / Math.PI) / DEG_PER_TRIANGLE);\n\n for (let m = 1; m < n; m++) {\n let t = m / n;\n if (t !== 0.5) {\n // approximate spherical interpolation https://observablehq.com/@mourner/approximating-geometric-slerp\n const t2 = t - 0.5;\n const A = 1.0904 + cosAngle * (-3.2452 + cosAngle * (3.55645 - cosAngle * 1.43519));\n const B = 0.848013 + cosAngle * (-1.06021 + cosAngle * 0.215638);\n t = t + t * t2 * (t - 1) * (A * t2 * t2 + B);\n }\n const extrude = nextNormal.sub(prevNormal)._mult(t)._add(prevNormal)._unit()._mult(lineTurnsLeft ? -1 : 1);\n this.addHalfVertex(currentVertex, extrude.x, extrude.y, false, lineTurnsLeft, 0, segment);\n }\n }\n\n if (nextVertex) {\n // Start next segment\n this.addCurrentVertex(currentVertex, nextNormal, -offsetA, -offsetB, segment);\n }\n\n } else if (currentJoin === 'butt') {\n this.addCurrentVertex(currentVertex, joinNormal, 0, 0, segment); // butt cap\n\n } else if (currentJoin === 'square') {\n const offset = prevVertex ? 1 : -1; // closing or starting square cap\n this.addCurrentVertex(currentVertex, joinNormal, offset, offset, segment);\n\n } else if (currentJoin === 'round') {\n\n if (prevVertex) {\n // Close previous segment with butt\n this.addCurrentVertex(currentVertex, prevNormal, 0, 0, segment);\n\n // Add round cap or linejoin at end of segment\n this.addCurrentVertex(currentVertex, prevNormal, 1, 1, segment, true);\n }\n if (nextVertex) {\n // Add round cap before first segment\n this.addCurrentVertex(currentVertex, nextNormal, -1, -1, segment, true);\n\n // Start next segment with a butt\n this.addCurrentVertex(currentVertex, nextNormal, 0, 0, segment);\n }\n }\n\n if (isSharpCorner && i < len - 1) {\n const nextSegmentLength = currentVertex.dist(nextVertex);\n if (nextSegmentLength > 2 * sharpCornerOffset) {\n const newCurrentVertex = currentVertex.add(nextVertex.sub(currentVertex)._mult(sharpCornerOffset / nextSegmentLength)._round());\n this.updateDistance(currentVertex, newCurrentVertex);\n this.addCurrentVertex(newCurrentVertex, nextNormal, 0, 0, segment);\n currentVertex = newCurrentVertex;\n }\n }\n }\n }\n\n /**\n * Add two vertices to the buffers.\n *\n * @param p - the line vertex to add buffer vertices for\n * @param normal - vertex normal\n * @param endLeft - extrude to shift the left vertex along the line\n * @param endRight - extrude to shift the left vertex along the line\n * @param segment - the segment object to add the vertex to\n * @param round - whether this is a round cap\n */\n addCurrentVertex(p: Point, normal: Point, endLeft: number, endRight: number, segment: Segment, round: boolean = false) {\n // left and right extrude vectors, perpendicularly shifted by endLeft/endRight\n const leftX = normal.x + normal.y * endLeft;\n const leftY = normal.y - normal.x * endLeft;\n const rightX = -normal.x + normal.y * endRight;\n const rightY = -normal.y - normal.x * endRight;\n\n this.addHalfVertex(p, leftX, leftY, round, false, endLeft, segment);\n this.addHalfVertex(p, rightX, rightY, round, true, -endRight, segment);\n\n // There is a maximum \"distance along the line\" that we can store in the buffers.\n // When we get close to the distance, reset it to zero and add the vertex again with\n // a distance of zero. The max distance is determined by the number of bits we allocate\n // to `linesofar`.\n if (this.distance > MAX_LINE_DISTANCE / 2 && this.totalDistance === 0) {\n this.distance = 0;\n this.updateScaledDistance();\n this.addCurrentVertex(p, normal, endLeft, endRight, segment, round);\n }\n }\n\n addHalfVertex({x, y}: Point, extrudeX: number, extrudeY: number, round: boolean, up: boolean, dir: number, segment: Segment) {\n const totalDistance = this.lineClips ? this.scaledDistance * (MAX_LINE_DISTANCE - 1) : this.scaledDistance;\n // scale down so that we can store longer distances while sacrificing precision.\n const linesofarScaled = totalDistance * LINE_DISTANCE_SCALE;\n\n this.layoutVertexArray.emplaceBack(\n // a_pos_normal\n // Encode round/up the least significant bits\n (x << 1) + (round ? 1 : 0),\n (y << 1) + (up ? 1 : 0),\n // a_data\n // add 128 to store a byte in an unsigned byte\n Math.round(EXTRUDE_SCALE * extrudeX) + 128,\n Math.round(EXTRUDE_SCALE * extrudeY) + 128,\n // Encode the -1/0/1 direction value into the first two bits of .z of a_data.\n // Combine it with the lower 6 bits of `linesofarScaled` (shifted by 2 bits to make\n // room for the direction value). The upper 8 bits of `linesofarScaled` are placed in\n // the `w` component.\n ((dir === 0 ? 0 : (dir < 0 ? -1 : 1)) + 1) | ((linesofarScaled & 0x3F) << 2),\n linesofarScaled >> 6);\n\n // Constructs a second vertex buffer with higher precision line progress\n if (this.lineClips) {\n const progressRealigned = this.scaledDistance - this.lineClips.start;\n const endClipRealigned = this.lineClips.end - this.lineClips.start;\n const uvX = progressRealigned / endClipRealigned;\n this.layoutVertexArray2.emplaceBack(uvX, this.lineClipsArray.length);\n }\n\n const e = segment.vertexLength++;\n if (this.e1 >= 0 && this.e2 >= 0) {\n this.indexArray.emplaceBack(this.e1, this.e2, e);\n segment.primitiveLength++;\n }\n if (up) {\n this.e2 = e;\n } else {\n this.e1 = e;\n }\n }\n\n updateScaledDistance() {\n // Knowing the ratio of the full linestring covered by this tiled feature, as well\n // as the total distance (in tile units) of this tiled feature, and the distance\n // (in tile units) of the current vertex, we can determine the relative distance\n // of this vertex along the full linestring feature and scale it to [0, 2^15)\n this.scaledDistance = this.lineClips ?\n this.lineClips.start + (this.lineClips.end - this.lineClips.start) * this.distance / this.totalDistance :\n this.distance;\n }\n\n updateDistance(prev: Point, next: Point) {\n this.distance += prev.dist(next);\n this.updateScaledDistance();\n }\n}\n\nregister('LineBucket', LineBucket, {omit: ['layers', 'patternFeatures']});\n","// This file is generated. Edit build/generate-style-code.ts, then run 'npm run codegen'.\n/* eslint-disable */\n\nimport {latest as styleSpec} from '@maplibre/maplibre-gl-style-spec';\n\nimport {\n Properties,\n DataConstantProperty,\n DataDrivenProperty,\n CrossFadedDataDrivenProperty,\n CrossFadedProperty,\n ColorRampProperty,\n PossiblyEvaluatedPropertyValue,\n CrossFaded\n} from '../properties';\n\nimport type {Color, Formatted, Padding, ResolvedImage, VariableAnchorOffsetCollection} from '@maplibre/maplibre-gl-style-spec';\nimport {StylePropertySpecification} from '@maplibre/maplibre-gl-style-spec';\n\nexport type LineLayoutProps = {\n \"line-cap\": DataConstantProperty<\"butt\" | \"round\" | \"square\">,\n \"line-join\": DataDrivenProperty<\"bevel\" | \"round\" | \"miter\">,\n \"line-miter-limit\": DataConstantProperty,\n \"line-round-limit\": DataConstantProperty,\n \"line-sort-key\": DataDrivenProperty,\n};\n\nexport type LineLayoutPropsPossiblyEvaluated = {\n \"line-cap\": \"butt\" | \"round\" | \"square\",\n \"line-join\": PossiblyEvaluatedPropertyValue<\"bevel\" | \"round\" | \"miter\">,\n \"line-miter-limit\": number,\n \"line-round-limit\": number,\n \"line-sort-key\": PossiblyEvaluatedPropertyValue,\n};\n\nlet layout: Properties;\nconst getLayout = () => layout = layout || new Properties({\n \"line-cap\": new DataConstantProperty(styleSpec[\"layout_line\"][\"line-cap\"] as any as StylePropertySpecification),\n \"line-join\": new DataDrivenProperty(styleSpec[\"layout_line\"][\"line-join\"] as any as StylePropertySpecification),\n \"line-miter-limit\": new DataConstantProperty(styleSpec[\"layout_line\"][\"line-miter-limit\"] as any as StylePropertySpecification),\n \"line-round-limit\": new DataConstantProperty(styleSpec[\"layout_line\"][\"line-round-limit\"] as any as StylePropertySpecification),\n \"line-sort-key\": new DataDrivenProperty(styleSpec[\"layout_line\"][\"line-sort-key\"] as any as StylePropertySpecification),\n});\n\nexport type LinePaintProps = {\n \"line-opacity\": DataDrivenProperty,\n \"line-color\": DataDrivenProperty,\n \"line-translate\": DataConstantProperty<[number, number]>,\n \"line-translate-anchor\": DataConstantProperty<\"map\" | \"viewport\">,\n \"line-width\": DataDrivenProperty,\n \"line-gap-width\": DataDrivenProperty,\n \"line-offset\": DataDrivenProperty,\n \"line-blur\": DataDrivenProperty,\n \"line-dasharray\": CrossFadedProperty>,\n \"line-pattern\": CrossFadedDataDrivenProperty,\n \"line-gradient\": ColorRampProperty,\n};\n\nexport type LinePaintPropsPossiblyEvaluated = {\n \"line-opacity\": PossiblyEvaluatedPropertyValue,\n \"line-color\": PossiblyEvaluatedPropertyValue,\n \"line-translate\": [number, number],\n \"line-translate-anchor\": \"map\" | \"viewport\",\n \"line-width\": PossiblyEvaluatedPropertyValue,\n \"line-gap-width\": PossiblyEvaluatedPropertyValue,\n \"line-offset\": PossiblyEvaluatedPropertyValue,\n \"line-blur\": PossiblyEvaluatedPropertyValue,\n \"line-dasharray\": CrossFaded>,\n \"line-pattern\": PossiblyEvaluatedPropertyValue>,\n \"line-gradient\": ColorRampProperty,\n};\n\nlet paint: Properties;\nconst getPaint = () => paint = paint || new Properties({\n \"line-opacity\": new DataDrivenProperty(styleSpec[\"paint_line\"][\"line-opacity\"] as any as StylePropertySpecification),\n \"line-color\": new DataDrivenProperty(styleSpec[\"paint_line\"][\"line-color\"] as any as StylePropertySpecification),\n \"line-translate\": new DataConstantProperty(styleSpec[\"paint_line\"][\"line-translate\"] as any as StylePropertySpecification),\n \"line-translate-anchor\": new DataConstantProperty(styleSpec[\"paint_line\"][\"line-translate-anchor\"] as any as StylePropertySpecification),\n \"line-width\": new DataDrivenProperty(styleSpec[\"paint_line\"][\"line-width\"] as any as StylePropertySpecification),\n \"line-gap-width\": new DataDrivenProperty(styleSpec[\"paint_line\"][\"line-gap-width\"] as any as StylePropertySpecification),\n \"line-offset\": new DataDrivenProperty(styleSpec[\"paint_line\"][\"line-offset\"] as any as StylePropertySpecification),\n \"line-blur\": new DataDrivenProperty(styleSpec[\"paint_line\"][\"line-blur\"] as any as StylePropertySpecification),\n \"line-dasharray\": new CrossFadedProperty(styleSpec[\"paint_line\"][\"line-dasharray\"] as any as StylePropertySpecification),\n \"line-pattern\": new CrossFadedDataDrivenProperty(styleSpec[\"paint_line\"][\"line-pattern\"] as any as StylePropertySpecification),\n \"line-gradient\": new ColorRampProperty(styleSpec[\"paint_line\"][\"line-gradient\"] as any as StylePropertySpecification),\n});\n\nexport default ({ get paint() { return getPaint() }, get layout() { return getLayout() } });","import Point from '@mapbox/point-geometry';\n\nimport {StyleLayer} from '../style_layer';\nimport {LineBucket} from '../../data/bucket/line_bucket';\nimport {polygonIntersectsBufferedMultiLine} from '../../util/intersection_tests';\nimport {getMaximumPaintValue, translateDistance, translate, offsetLine} from '../query_utils';\nimport properties, {LineLayoutPropsPossiblyEvaluated, LinePaintPropsPossiblyEvaluated} from './line_style_layer_properties.g';\nimport {extend} from '../../util/util';\nimport {EvaluationParameters} from '../evaluation_parameters';\nimport {Transitionable, Transitioning, Layout, PossiblyEvaluated, DataDrivenProperty} from '../properties';\n\nimport {isZoomExpression, Step} from '@maplibre/maplibre-gl-style-spec';\nimport type {FeatureState, LayerSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {Bucket, BucketParameters} from '../../data/bucket';\nimport type {LineLayoutProps, LinePaintProps} from './line_style_layer_properties.g';\nimport type {Transform} from '../../geo/transform';\nimport type {VectorTileFeature} from '@mapbox/vector-tile';\n\nexport class LineFloorwidthProperty extends DataDrivenProperty {\n useIntegerZoom: true;\n\n possiblyEvaluate(value, parameters) {\n parameters = new EvaluationParameters(Math.floor(parameters.zoom), {\n now: parameters.now,\n fadeDuration: parameters.fadeDuration,\n zoomHistory: parameters.zoomHistory,\n transition: parameters.transition\n });\n return super.possiblyEvaluate(value, parameters);\n }\n\n evaluate(value, globals, feature, featureState) {\n globals = extend({}, globals, {zoom: Math.floor(globals.zoom)});\n return super.evaluate(value, globals, feature, featureState);\n }\n}\n\nlet lineFloorwidthProperty: LineFloorwidthProperty;\n\nexport class LineStyleLayer extends StyleLayer {\n _unevaluatedLayout: Layout;\n layout: PossiblyEvaluated;\n\n gradientVersion: number;\n stepInterpolant: boolean;\n\n _transitionablePaint: Transitionable;\n _transitioningPaint: Transitioning;\n paint: PossiblyEvaluated;\n\n constructor(layer: LayerSpecification) {\n super(layer, properties);\n this.gradientVersion = 0;\n if (!lineFloorwidthProperty) {\n lineFloorwidthProperty =\n new LineFloorwidthProperty(properties.paint.properties['line-width'].specification);\n lineFloorwidthProperty.useIntegerZoom = true;\n }\n }\n\n _handleSpecialPaintPropertyUpdate(name: string) {\n if (name === 'line-gradient') {\n const expression = this.gradientExpression();\n if (isZoomExpression(expression)) {\n this.stepInterpolant = expression._styleExpression.expression instanceof Step;\n } else {\n this.stepInterpolant = false;\n }\n this.gradientVersion = (this.gradientVersion + 1) % Number.MAX_SAFE_INTEGER;\n }\n }\n\n gradientExpression() {\n return this._transitionablePaint._values['line-gradient'].value.expression;\n }\n\n recalculate(parameters: EvaluationParameters, availableImages: Array) {\n super.recalculate(parameters, availableImages);\n (this.paint._values as any)['line-floorwidth'] =\n lineFloorwidthProperty.possiblyEvaluate(this._transitioningPaint._values['line-width'].value, parameters);\n }\n\n createBucket(parameters: BucketParameters) {\n return new LineBucket(parameters);\n }\n\n queryRadius(bucket: Bucket): number {\n const lineBucket: LineBucket = (bucket as any);\n const width = getLineWidth(\n getMaximumPaintValue('line-width', this, lineBucket),\n getMaximumPaintValue('line-gap-width', this, lineBucket));\n const offset = getMaximumPaintValue('line-offset', this, lineBucket);\n return width / 2 + Math.abs(offset) + translateDistance(this.paint.get('line-translate'));\n }\n\n queryIntersectsFeature(\n queryGeometry: Array,\n feature: VectorTileFeature,\n featureState: FeatureState,\n geometry: Array>,\n zoom: number,\n transform: Transform,\n pixelsToTileUnits: number\n ): boolean {\n const translatedPolygon = translate(queryGeometry,\n this.paint.get('line-translate'),\n this.paint.get('line-translate-anchor'),\n transform.angle, pixelsToTileUnits);\n const halfWidth = pixelsToTileUnits / 2 * getLineWidth(\n this.paint.get('line-width').evaluate(feature, featureState),\n this.paint.get('line-gap-width').evaluate(feature, featureState));\n const lineOffset = this.paint.get('line-offset').evaluate(feature, featureState);\n if (lineOffset) {\n geometry = offsetLine(geometry, lineOffset * pixelsToTileUnits);\n }\n\n return polygonIntersectsBufferedMultiLine(translatedPolygon, geometry, halfWidth);\n }\n\n isTileClipped() {\n return true;\n }\n}\n\nfunction getLineWidth(lineWidth, lineGapWidth) {\n if (lineGapWidth > 0) {\n return lineGapWidth + 2 * lineWidth;\n } else {\n return lineWidth;\n }\n}\n","import {createLayout} from '../../util/struct_array';\n\nexport const symbolLayoutAttributes = createLayout([\n {name: 'a_pos_offset', components: 4, type: 'Int16'},\n {name: 'a_data', components: 4, type: 'Uint16'},\n {name: 'a_pixeloffset', components: 4, type: 'Int16'}\n], 4);\n\nexport const dynamicLayoutAttributes = createLayout([\n {name: 'a_projected_pos', components: 3, type: 'Float32'}\n], 4);\n\nexport const placementOpacityAttributes = createLayout([\n {name: 'a_fade_opacity', components: 1, type: 'Uint32'}\n], 4);\n\nexport const collisionVertexAttributes = createLayout([\n {name: 'a_placed', components: 2, type: 'Uint8'},\n {name: 'a_shift', components: 2, type: 'Float32'},\n {name: 'a_box_real', components: 2, type: 'Int16'},\n]);\n\nexport const collisionBox = createLayout([\n // the box is centered around the anchor point\n {type: 'Int16', name: 'anchorPointX'},\n {type: 'Int16', name: 'anchorPointY'},\n\n // distances to the edges from the anchor\n {type: 'Int16', name: 'x1'},\n {type: 'Int16', name: 'y1'},\n {type: 'Int16', name: 'x2'},\n {type: 'Int16', name: 'y2'},\n\n // the index of the feature in the original vectortile\n {type: 'Uint32', name: 'featureIndex'},\n // the source layer the feature appears in\n {type: 'Uint16', name: 'sourceLayerIndex'},\n // the bucket the feature appears in\n {type: 'Uint16', name: 'bucketIndex'},\n]);\n\nexport const collisionBoxLayout = createLayout([ // used to render collision boxes for debugging purposes\n {name: 'a_pos', components: 2, type: 'Int16'},\n {name: 'a_anchor_pos', components: 2, type: 'Int16'},\n {name: 'a_extrude', components: 2, type: 'Int16'}\n], 4);\n\nexport const collisionCircleLayout = createLayout([ // used to render collision circles for debugging purposes\n {name: 'a_pos', components: 2, type: 'Float32'},\n {name: 'a_radius', components: 1, type: 'Float32'},\n {name: 'a_flags', components: 2, type: 'Int16'}\n], 4);\n\nexport const quadTriangle = createLayout([\n {name: 'triangle', components: 3, type: 'Uint16'},\n]);\n\nexport const placement = createLayout([\n {type: 'Int16', name: 'anchorX'},\n {type: 'Int16', name: 'anchorY'},\n {type: 'Uint16', name: 'glyphStartIndex'},\n {type: 'Uint16', name: 'numGlyphs'},\n {type: 'Uint32', name: 'vertexStartIndex'},\n {type: 'Uint32', name: 'lineStartIndex'},\n {type: 'Uint32', name: 'lineLength'},\n {type: 'Uint16', name: 'segment'},\n {type: 'Uint16', name: 'lowerSize'},\n {type: 'Uint16', name: 'upperSize'},\n {type: 'Float32', name: 'lineOffsetX'},\n {type: 'Float32', name: 'lineOffsetY'},\n {type: 'Uint8', name: 'writingMode'},\n {type: 'Uint8', name: 'placedOrientation'},\n {type: 'Uint8', name: 'hidden'},\n {type: 'Uint32', name: 'crossTileID'},\n {type: 'Int16', name: 'associatedIconIndex'}\n]);\n\nexport const symbolInstance = createLayout([\n {type: 'Int16', name: 'anchorX'},\n {type: 'Int16', name: 'anchorY'},\n {type: 'Int16', name: 'rightJustifiedTextSymbolIndex'},\n {type: 'Int16', name: 'centerJustifiedTextSymbolIndex'},\n {type: 'Int16', name: 'leftJustifiedTextSymbolIndex'},\n {type: 'Int16', name: 'verticalPlacedTextSymbolIndex'},\n {type: 'Int16', name: 'placedIconSymbolIndex'},\n {type: 'Int16', name: 'verticalPlacedIconSymbolIndex'},\n {type: 'Uint16', name: 'key'},\n {type: 'Uint16', name: 'textBoxStartIndex'},\n {type: 'Uint16', name: 'textBoxEndIndex'},\n {type: 'Uint16', name: 'verticalTextBoxStartIndex'},\n {type: 'Uint16', name: 'verticalTextBoxEndIndex'},\n {type: 'Uint16', name: 'iconBoxStartIndex'},\n {type: 'Uint16', name: 'iconBoxEndIndex'},\n {type: 'Uint16', name: 'verticalIconBoxStartIndex'},\n {type: 'Uint16', name: 'verticalIconBoxEndIndex'},\n {type: 'Uint16', name: 'featureIndex'},\n {type: 'Uint16', name: 'numHorizontalGlyphVertices'},\n {type: 'Uint16', name: 'numVerticalGlyphVertices'},\n {type: 'Uint16', name: 'numIconVertices'},\n {type: 'Uint16', name: 'numVerticalIconVertices'},\n {type: 'Uint16', name: 'useRuntimeCollisionCircles'},\n {type: 'Uint32', name: 'crossTileID'},\n {type: 'Float32', name: 'textBoxScale'},\n {type: 'Float32', name: 'collisionCircleDiameter'},\n {type: 'Uint16', name: 'textAnchorOffsetStartIndex'},\n {type: 'Uint16', name: 'textAnchorOffsetEndIndex'}\n]);\n\nexport const glyphOffset = createLayout([\n {type: 'Float32', name: 'offsetX'}\n]);\n\nexport const lineVertex = createLayout([\n {type: 'Int16', name: 'x'},\n {type: 'Int16', name: 'y'},\n {type: 'Int16', name: 'tileUnitDistanceFromAnchor'}\n]);\n\nexport const textAnchorOffset = createLayout([\n {type: 'Uint16', name: 'textAnchor'},\n {type: 'Float32', components: 2, name: 'textOffset'}\n]);\n","import {rtlWorkerPlugin} from '../source/rtl_text_plugin_worker';\n\nimport type {SymbolStyleLayer} from '../style/style_layer/symbol_style_layer';\nimport type {Feature} from '@maplibre/maplibre-gl-style-spec';\nimport {Formatted} from '@maplibre/maplibre-gl-style-spec';\n\nfunction transformTextInternal(text: string, layer: SymbolStyleLayer, feature: Feature) {\n const transform = layer.layout.get('text-transform').evaluate(feature, {});\n if (transform === 'uppercase') {\n text = text.toLocaleUpperCase();\n } else if (transform === 'lowercase') {\n text = text.toLocaleLowerCase();\n }\n\n if (rtlWorkerPlugin.applyArabicShaping) {\n text = rtlWorkerPlugin.applyArabicShaping(text);\n }\n\n return text;\n}\n\nexport function transformText(text: Formatted, layer: SymbolStyleLayer, feature: Feature): Formatted {\n text.sections.forEach(section => {\n section.text = transformTextInternal(section.text, layer, feature);\n });\n return text;\n}\n","import type {SymbolFeature} from '../data/bucket/symbol_bucket';\n\nexport function mergeLines(features: Array): Array {\n const leftIndex: {[_: string]: number} = {};\n const rightIndex: {[_: string]: number} = {};\n const mergedFeatures = [];\n let mergedIndex = 0;\n\n function add(k) {\n mergedFeatures.push(features[k]);\n mergedIndex++;\n }\n\n function mergeFromRight(leftKey: string, rightKey: string, geom) {\n const i = rightIndex[leftKey];\n delete rightIndex[leftKey];\n rightIndex[rightKey] = i;\n\n mergedFeatures[i].geometry[0].pop();\n mergedFeatures[i].geometry[0] = mergedFeatures[i].geometry[0].concat(geom[0]);\n return i;\n }\n\n function mergeFromLeft(leftKey: string, rightKey: string, geom) {\n const i = leftIndex[rightKey];\n delete leftIndex[rightKey];\n leftIndex[leftKey] = i;\n\n mergedFeatures[i].geometry[0].shift();\n mergedFeatures[i].geometry[0] = geom[0].concat(mergedFeatures[i].geometry[0]);\n return i;\n }\n\n function getKey(text, geom, onRight?) {\n const point = onRight ? geom[0][geom[0].length - 1] : geom[0][0];\n return `${text}:${point.x}:${point.y}`;\n }\n\n for (let k = 0; k < features.length; k++) {\n const feature = features[k];\n const geom = feature.geometry;\n const text = feature.text ? feature.text.toString() : null;\n\n if (!text) {\n add(k);\n continue;\n }\n\n const leftKey = getKey(text, geom),\n rightKey = getKey(text, geom, true);\n\n if ((leftKey in rightIndex) && (rightKey in leftIndex) && (rightIndex[leftKey] !== leftIndex[rightKey])) {\n // found lines with the same text adjacent to both ends of the current line, merge all three\n const j = mergeFromLeft(leftKey, rightKey, geom);\n const i = mergeFromRight(leftKey, rightKey, mergedFeatures[j].geometry);\n\n delete leftIndex[leftKey];\n delete rightIndex[rightKey];\n\n rightIndex[getKey(text, mergedFeatures[i].geometry, true)] = i;\n mergedFeatures[j].geometry = null;\n\n } else if (leftKey in rightIndex) {\n // found mergeable line adjacent to the start of the current line, merge\n mergeFromRight(leftKey, rightKey, geom);\n\n } else if (rightKey in leftIndex) {\n // found mergeable line adjacent to the end of the current line, merge\n mergeFromLeft(leftKey, rightKey, geom);\n\n } else {\n // no adjacent lines, add as a new item\n add(k);\n leftIndex[leftKey] = mergedIndex - 1;\n rightIndex[rightKey] = mergedIndex - 1;\n }\n }\n\n return mergedFeatures.filter((f) => f.geometry);\n}\n","import {charHasRotatedVerticalOrientation} from './script_detection';\n\nexport const verticalizedCharacterMap = {\n '!': '︕',\n '#': '#',\n '$': '$',\n '%': '%',\n '&': '&',\n '(': '︵',\n ')': '︶',\n '*': '*',\n '+': '+',\n ',': '︐',\n '-': '︲',\n '.': '・',\n '/': '/',\n ':': '︓',\n ';': '︔',\n '<': '︿',\n '=': '=',\n '>': '﹀',\n '?': '︖',\n '@': '@',\n '[': '﹇',\n '\\\\': '\',\n ']': '﹈',\n '^': '^',\n '_': '︳',\n '`': '`',\n '{': '︷',\n '|': '―',\n '}': '︸',\n '~': '~',\n '¢': '¢',\n '£': '£',\n '¥': '¥',\n '¦': '¦',\n '¬': '¬',\n '¯': ' ̄',\n '–': '︲',\n '—': '︱',\n '‘': '﹃',\n '’': '﹄',\n '“': '﹁',\n '”': '﹂',\n '…': '︙',\n '‧': '・',\n '₩': '₩',\n '、': '︑',\n '。': '︒',\n '〈': '︿',\n '〉': '﹀',\n '《': '︽',\n '》': '︾',\n '「': '﹁',\n '」': '﹂',\n '『': '﹃',\n '』': '﹄',\n '【': '︻',\n '】': '︼',\n '〔': '︹',\n '〕': '︺',\n '〖': '︗',\n '〗': '︘',\n '!': '︕',\n '(': '︵',\n ')': '︶',\n ',': '︐',\n '-': '︲',\n '.': '・',\n ':': '︓',\n ';': '︔',\n '<': '︿',\n '>': '﹀',\n '?': '︖',\n '[': '﹇',\n ']': '﹈',\n '_': '︳',\n '{': '︷',\n '|': '―',\n '}': '︸',\n '⦅': '︵',\n '⦆': '︶',\n '。': '︒',\n '「': '﹁',\n '」': '﹂'\n};\n\nexport function verticalizePunctuation(input: string) {\n let output = '';\n\n for (let i = 0; i < input.length; i++) {\n const nextCharCode = input.charCodeAt(i + 1) || null;\n const prevCharCode = input.charCodeAt(i - 1) || null;\n\n const canReplacePunctuation = (\n (!nextCharCode || !charHasRotatedVerticalOrientation(nextCharCode) || verticalizedCharacterMap[input[i + 1]]) &&\n (!prevCharCode || !charHasRotatedVerticalOrientation(prevCharCode) || verticalizedCharacterMap[input[i - 1]])\n );\n\n if (canReplacePunctuation && verticalizedCharacterMap[input[i]]) {\n output += verticalizedCharacterMap[input[i]];\n } else {\n output += input[i];\n }\n }\n\n return output;\n}\n\n","// ONE_EM constant used to go between \"em\" units used in style spec and \"points\" used internally for layout\n\nexport default 24;\n","/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh */\nexports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = ((value * c) - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n","'use strict';\n\nmodule.exports = Pbf;\n\nvar ieee754 = require('ieee754');\n\nfunction Pbf(buf) {\n this.buf = ArrayBuffer.isView && ArrayBuffer.isView(buf) ? buf : new Uint8Array(buf || 0);\n this.pos = 0;\n this.type = 0;\n this.length = this.buf.length;\n}\n\nPbf.Varint = 0; // varint: int32, int64, uint32, uint64, sint32, sint64, bool, enum\nPbf.Fixed64 = 1; // 64-bit: double, fixed64, sfixed64\nPbf.Bytes = 2; // length-delimited: string, bytes, embedded messages, packed repeated fields\nPbf.Fixed32 = 5; // 32-bit: float, fixed32, sfixed32\n\nvar SHIFT_LEFT_32 = (1 << 16) * (1 << 16),\n SHIFT_RIGHT_32 = 1 / SHIFT_LEFT_32;\n\n// Threshold chosen based on both benchmarking and knowledge about browser string\n// data structures (which currently switch structure types at 12 bytes or more)\nvar TEXT_DECODER_MIN_LENGTH = 12;\nvar utf8TextDecoder = typeof TextDecoder === 'undefined' ? null : new TextDecoder('utf-8');\n\nPbf.prototype = {\n\n destroy: function() {\n this.buf = null;\n },\n\n // === READING =================================================================\n\n readFields: function(readField, result, end) {\n end = end || this.length;\n\n while (this.pos < end) {\n var val = this.readVarint(),\n tag = val >> 3,\n startPos = this.pos;\n\n this.type = val & 0x7;\n readField(tag, result, this);\n\n if (this.pos === startPos) this.skip(val);\n }\n return result;\n },\n\n readMessage: function(readField, result) {\n return this.readFields(readField, result, this.readVarint() + this.pos);\n },\n\n readFixed32: function() {\n var val = readUInt32(this.buf, this.pos);\n this.pos += 4;\n return val;\n },\n\n readSFixed32: function() {\n var val = readInt32(this.buf, this.pos);\n this.pos += 4;\n return val;\n },\n\n // 64-bit int handling is based on github.com/dpw/node-buffer-more-ints (MIT-licensed)\n\n readFixed64: function() {\n var val = readUInt32(this.buf, this.pos) + readUInt32(this.buf, this.pos + 4) * SHIFT_LEFT_32;\n this.pos += 8;\n return val;\n },\n\n readSFixed64: function() {\n var val = readUInt32(this.buf, this.pos) + readInt32(this.buf, this.pos + 4) * SHIFT_LEFT_32;\n this.pos += 8;\n return val;\n },\n\n readFloat: function() {\n var val = ieee754.read(this.buf, this.pos, true, 23, 4);\n this.pos += 4;\n return val;\n },\n\n readDouble: function() {\n var val = ieee754.read(this.buf, this.pos, true, 52, 8);\n this.pos += 8;\n return val;\n },\n\n readVarint: function(isSigned) {\n var buf = this.buf,\n val, b;\n\n b = buf[this.pos++]; val = b & 0x7f; if (b < 0x80) return val;\n b = buf[this.pos++]; val |= (b & 0x7f) << 7; if (b < 0x80) return val;\n b = buf[this.pos++]; val |= (b & 0x7f) << 14; if (b < 0x80) return val;\n b = buf[this.pos++]; val |= (b & 0x7f) << 21; if (b < 0x80) return val;\n b = buf[this.pos]; val |= (b & 0x0f) << 28;\n\n return readVarintRemainder(val, isSigned, this);\n },\n\n readVarint64: function() { // for compatibility with v2.0.1\n return this.readVarint(true);\n },\n\n readSVarint: function() {\n var num = this.readVarint();\n return num % 2 === 1 ? (num + 1) / -2 : num / 2; // zigzag encoding\n },\n\n readBoolean: function() {\n return Boolean(this.readVarint());\n },\n\n readString: function() {\n var end = this.readVarint() + this.pos;\n var pos = this.pos;\n this.pos = end;\n\n if (end - pos >= TEXT_DECODER_MIN_LENGTH && utf8TextDecoder) {\n // longer strings are fast with the built-in browser TextDecoder API\n return readUtf8TextDecoder(this.buf, pos, end);\n }\n // short strings are fast with our custom implementation\n return readUtf8(this.buf, pos, end);\n },\n\n readBytes: function() {\n var end = this.readVarint() + this.pos,\n buffer = this.buf.subarray(this.pos, end);\n this.pos = end;\n return buffer;\n },\n\n // verbose for performance reasons; doesn't affect gzipped size\n\n readPackedVarint: function(arr, isSigned) {\n if (this.type !== Pbf.Bytes) return arr.push(this.readVarint(isSigned));\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) arr.push(this.readVarint(isSigned));\n return arr;\n },\n readPackedSVarint: function(arr) {\n if (this.type !== Pbf.Bytes) return arr.push(this.readSVarint());\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) arr.push(this.readSVarint());\n return arr;\n },\n readPackedBoolean: function(arr) {\n if (this.type !== Pbf.Bytes) return arr.push(this.readBoolean());\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) arr.push(this.readBoolean());\n return arr;\n },\n readPackedFloat: function(arr) {\n if (this.type !== Pbf.Bytes) return arr.push(this.readFloat());\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) arr.push(this.readFloat());\n return arr;\n },\n readPackedDouble: function(arr) {\n if (this.type !== Pbf.Bytes) return arr.push(this.readDouble());\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) arr.push(this.readDouble());\n return arr;\n },\n readPackedFixed32: function(arr) {\n if (this.type !== Pbf.Bytes) return arr.push(this.readFixed32());\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) arr.push(this.readFixed32());\n return arr;\n },\n readPackedSFixed32: function(arr) {\n if (this.type !== Pbf.Bytes) return arr.push(this.readSFixed32());\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) arr.push(this.readSFixed32());\n return arr;\n },\n readPackedFixed64: function(arr) {\n if (this.type !== Pbf.Bytes) return arr.push(this.readFixed64());\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) arr.push(this.readFixed64());\n return arr;\n },\n readPackedSFixed64: function(arr) {\n if (this.type !== Pbf.Bytes) return arr.push(this.readSFixed64());\n var end = readPackedEnd(this);\n arr = arr || [];\n while (this.pos < end) arr.push(this.readSFixed64());\n return arr;\n },\n\n skip: function(val) {\n var type = val & 0x7;\n if (type === Pbf.Varint) while (this.buf[this.pos++] > 0x7f) {}\n else if (type === Pbf.Bytes) this.pos = this.readVarint() + this.pos;\n else if (type === Pbf.Fixed32) this.pos += 4;\n else if (type === Pbf.Fixed64) this.pos += 8;\n else throw new Error('Unimplemented type: ' + type);\n },\n\n // === WRITING =================================================================\n\n writeTag: function(tag, type) {\n this.writeVarint((tag << 3) | type);\n },\n\n realloc: function(min) {\n var length = this.length || 16;\n\n while (length < this.pos + min) length *= 2;\n\n if (length !== this.length) {\n var buf = new Uint8Array(length);\n buf.set(this.buf);\n this.buf = buf;\n this.length = length;\n }\n },\n\n finish: function() {\n this.length = this.pos;\n this.pos = 0;\n return this.buf.subarray(0, this.length);\n },\n\n writeFixed32: function(val) {\n this.realloc(4);\n writeInt32(this.buf, val, this.pos);\n this.pos += 4;\n },\n\n writeSFixed32: function(val) {\n this.realloc(4);\n writeInt32(this.buf, val, this.pos);\n this.pos += 4;\n },\n\n writeFixed64: function(val) {\n this.realloc(8);\n writeInt32(this.buf, val & -1, this.pos);\n writeInt32(this.buf, Math.floor(val * SHIFT_RIGHT_32), this.pos + 4);\n this.pos += 8;\n },\n\n writeSFixed64: function(val) {\n this.realloc(8);\n writeInt32(this.buf, val & -1, this.pos);\n writeInt32(this.buf, Math.floor(val * SHIFT_RIGHT_32), this.pos + 4);\n this.pos += 8;\n },\n\n writeVarint: function(val) {\n val = +val || 0;\n\n if (val > 0xfffffff || val < 0) {\n writeBigVarint(val, this);\n return;\n }\n\n this.realloc(4);\n\n this.buf[this.pos++] = val & 0x7f | (val > 0x7f ? 0x80 : 0); if (val <= 0x7f) return;\n this.buf[this.pos++] = ((val >>>= 7) & 0x7f) | (val > 0x7f ? 0x80 : 0); if (val <= 0x7f) return;\n this.buf[this.pos++] = ((val >>>= 7) & 0x7f) | (val > 0x7f ? 0x80 : 0); if (val <= 0x7f) return;\n this.buf[this.pos++] = (val >>> 7) & 0x7f;\n },\n\n writeSVarint: function(val) {\n this.writeVarint(val < 0 ? -val * 2 - 1 : val * 2);\n },\n\n writeBoolean: function(val) {\n this.writeVarint(Boolean(val));\n },\n\n writeString: function(str) {\n str = String(str);\n this.realloc(str.length * 4);\n\n this.pos++; // reserve 1 byte for short string length\n\n var startPos = this.pos;\n // write the string directly to the buffer and see how much was written\n this.pos = writeUtf8(this.buf, str, this.pos);\n var len = this.pos - startPos;\n\n if (len >= 0x80) makeRoomForExtraLength(startPos, len, this);\n\n // finally, write the message length in the reserved place and restore the position\n this.pos = startPos - 1;\n this.writeVarint(len);\n this.pos += len;\n },\n\n writeFloat: function(val) {\n this.realloc(4);\n ieee754.write(this.buf, val, this.pos, true, 23, 4);\n this.pos += 4;\n },\n\n writeDouble: function(val) {\n this.realloc(8);\n ieee754.write(this.buf, val, this.pos, true, 52, 8);\n this.pos += 8;\n },\n\n writeBytes: function(buffer) {\n var len = buffer.length;\n this.writeVarint(len);\n this.realloc(len);\n for (var i = 0; i < len; i++) this.buf[this.pos++] = buffer[i];\n },\n\n writeRawMessage: function(fn, obj) {\n this.pos++; // reserve 1 byte for short message length\n\n // write the message directly to the buffer and see how much was written\n var startPos = this.pos;\n fn(obj, this);\n var len = this.pos - startPos;\n\n if (len >= 0x80) makeRoomForExtraLength(startPos, len, this);\n\n // finally, write the message length in the reserved place and restore the position\n this.pos = startPos - 1;\n this.writeVarint(len);\n this.pos += len;\n },\n\n writeMessage: function(tag, fn, obj) {\n this.writeTag(tag, Pbf.Bytes);\n this.writeRawMessage(fn, obj);\n },\n\n writePackedVarint: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedVarint, arr); },\n writePackedSVarint: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedSVarint, arr); },\n writePackedBoolean: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedBoolean, arr); },\n writePackedFloat: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedFloat, arr); },\n writePackedDouble: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedDouble, arr); },\n writePackedFixed32: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedFixed32, arr); },\n writePackedSFixed32: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedSFixed32, arr); },\n writePackedFixed64: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedFixed64, arr); },\n writePackedSFixed64: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedSFixed64, arr); },\n\n writeBytesField: function(tag, buffer) {\n this.writeTag(tag, Pbf.Bytes);\n this.writeBytes(buffer);\n },\n writeFixed32Field: function(tag, val) {\n this.writeTag(tag, Pbf.Fixed32);\n this.writeFixed32(val);\n },\n writeSFixed32Field: function(tag, val) {\n this.writeTag(tag, Pbf.Fixed32);\n this.writeSFixed32(val);\n },\n writeFixed64Field: function(tag, val) {\n this.writeTag(tag, Pbf.Fixed64);\n this.writeFixed64(val);\n },\n writeSFixed64Field: function(tag, val) {\n this.writeTag(tag, Pbf.Fixed64);\n this.writeSFixed64(val);\n },\n writeVarintField: function(tag, val) {\n this.writeTag(tag, Pbf.Varint);\n this.writeVarint(val);\n },\n writeSVarintField: function(tag, val) {\n this.writeTag(tag, Pbf.Varint);\n this.writeSVarint(val);\n },\n writeStringField: function(tag, str) {\n this.writeTag(tag, Pbf.Bytes);\n this.writeString(str);\n },\n writeFloatField: function(tag, val) {\n this.writeTag(tag, Pbf.Fixed32);\n this.writeFloat(val);\n },\n writeDoubleField: function(tag, val) {\n this.writeTag(tag, Pbf.Fixed64);\n this.writeDouble(val);\n },\n writeBooleanField: function(tag, val) {\n this.writeVarintField(tag, Boolean(val));\n }\n};\n\nfunction readVarintRemainder(l, s, p) {\n var buf = p.buf,\n h, b;\n\n b = buf[p.pos++]; h = (b & 0x70) >> 4; if (b < 0x80) return toNum(l, h, s);\n b = buf[p.pos++]; h |= (b & 0x7f) << 3; if (b < 0x80) return toNum(l, h, s);\n b = buf[p.pos++]; h |= (b & 0x7f) << 10; if (b < 0x80) return toNum(l, h, s);\n b = buf[p.pos++]; h |= (b & 0x7f) << 17; if (b < 0x80) return toNum(l, h, s);\n b = buf[p.pos++]; h |= (b & 0x7f) << 24; if (b < 0x80) return toNum(l, h, s);\n b = buf[p.pos++]; h |= (b & 0x01) << 31; if (b < 0x80) return toNum(l, h, s);\n\n throw new Error('Expected varint not more than 10 bytes');\n}\n\nfunction readPackedEnd(pbf) {\n return pbf.type === Pbf.Bytes ?\n pbf.readVarint() + pbf.pos : pbf.pos + 1;\n}\n\nfunction toNum(low, high, isSigned) {\n if (isSigned) {\n return high * 0x100000000 + (low >>> 0);\n }\n\n return ((high >>> 0) * 0x100000000) + (low >>> 0);\n}\n\nfunction writeBigVarint(val, pbf) {\n var low, high;\n\n if (val >= 0) {\n low = (val % 0x100000000) | 0;\n high = (val / 0x100000000) | 0;\n } else {\n low = ~(-val % 0x100000000);\n high = ~(-val / 0x100000000);\n\n if (low ^ 0xffffffff) {\n low = (low + 1) | 0;\n } else {\n low = 0;\n high = (high + 1) | 0;\n }\n }\n\n if (val >= 0x10000000000000000 || val < -0x10000000000000000) {\n throw new Error('Given varint doesn\\'t fit into 10 bytes');\n }\n\n pbf.realloc(10);\n\n writeBigVarintLow(low, high, pbf);\n writeBigVarintHigh(high, pbf);\n}\n\nfunction writeBigVarintLow(low, high, pbf) {\n pbf.buf[pbf.pos++] = low & 0x7f | 0x80; low >>>= 7;\n pbf.buf[pbf.pos++] = low & 0x7f | 0x80; low >>>= 7;\n pbf.buf[pbf.pos++] = low & 0x7f | 0x80; low >>>= 7;\n pbf.buf[pbf.pos++] = low & 0x7f | 0x80; low >>>= 7;\n pbf.buf[pbf.pos] = low & 0x7f;\n}\n\nfunction writeBigVarintHigh(high, pbf) {\n var lsb = (high & 0x07) << 4;\n\n pbf.buf[pbf.pos++] |= lsb | ((high >>>= 3) ? 0x80 : 0); if (!high) return;\n pbf.buf[pbf.pos++] = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) return;\n pbf.buf[pbf.pos++] = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) return;\n pbf.buf[pbf.pos++] = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) return;\n pbf.buf[pbf.pos++] = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) return;\n pbf.buf[pbf.pos++] = high & 0x7f;\n}\n\nfunction makeRoomForExtraLength(startPos, len, pbf) {\n var extraLen =\n len <= 0x3fff ? 1 :\n len <= 0x1fffff ? 2 :\n len <= 0xfffffff ? 3 : Math.floor(Math.log(len) / (Math.LN2 * 7));\n\n // if 1 byte isn't enough for encoding message length, shift the data to the right\n pbf.realloc(extraLen);\n for (var i = pbf.pos - 1; i >= startPos; i--) pbf.buf[i + extraLen] = pbf.buf[i];\n}\n\nfunction writePackedVarint(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeVarint(arr[i]); }\nfunction writePackedSVarint(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSVarint(arr[i]); }\nfunction writePackedFloat(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeFloat(arr[i]); }\nfunction writePackedDouble(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeDouble(arr[i]); }\nfunction writePackedBoolean(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeBoolean(arr[i]); }\nfunction writePackedFixed32(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeFixed32(arr[i]); }\nfunction writePackedSFixed32(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSFixed32(arr[i]); }\nfunction writePackedFixed64(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeFixed64(arr[i]); }\nfunction writePackedSFixed64(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSFixed64(arr[i]); }\n\n// Buffer code below from https://github.com/feross/buffer, MIT-licensed\n\nfunction readUInt32(buf, pos) {\n return ((buf[pos]) |\n (buf[pos + 1] << 8) |\n (buf[pos + 2] << 16)) +\n (buf[pos + 3] * 0x1000000);\n}\n\nfunction writeInt32(buf, val, pos) {\n buf[pos] = val;\n buf[pos + 1] = (val >>> 8);\n buf[pos + 2] = (val >>> 16);\n buf[pos + 3] = (val >>> 24);\n}\n\nfunction readInt32(buf, pos) {\n return ((buf[pos]) |\n (buf[pos + 1] << 8) |\n (buf[pos + 2] << 16)) +\n (buf[pos + 3] << 24);\n}\n\nfunction readUtf8(buf, pos, end) {\n var str = '';\n var i = pos;\n\n while (i < end) {\n var b0 = buf[i];\n var c = null; // codepoint\n var bytesPerSequence =\n b0 > 0xEF ? 4 :\n b0 > 0xDF ? 3 :\n b0 > 0xBF ? 2 : 1;\n\n if (i + bytesPerSequence > end) break;\n\n var b1, b2, b3;\n\n if (bytesPerSequence === 1) {\n if (b0 < 0x80) {\n c = b0;\n }\n } else if (bytesPerSequence === 2) {\n b1 = buf[i + 1];\n if ((b1 & 0xC0) === 0x80) {\n c = (b0 & 0x1F) << 0x6 | (b1 & 0x3F);\n if (c <= 0x7F) {\n c = null;\n }\n }\n } else if (bytesPerSequence === 3) {\n b1 = buf[i + 1];\n b2 = buf[i + 2];\n if ((b1 & 0xC0) === 0x80 && (b2 & 0xC0) === 0x80) {\n c = (b0 & 0xF) << 0xC | (b1 & 0x3F) << 0x6 | (b2 & 0x3F);\n if (c <= 0x7FF || (c >= 0xD800 && c <= 0xDFFF)) {\n c = null;\n }\n }\n } else if (bytesPerSequence === 4) {\n b1 = buf[i + 1];\n b2 = buf[i + 2];\n b3 = buf[i + 3];\n if ((b1 & 0xC0) === 0x80 && (b2 & 0xC0) === 0x80 && (b3 & 0xC0) === 0x80) {\n c = (b0 & 0xF) << 0x12 | (b1 & 0x3F) << 0xC | (b2 & 0x3F) << 0x6 | (b3 & 0x3F);\n if (c <= 0xFFFF || c >= 0x110000) {\n c = null;\n }\n }\n }\n\n if (c === null) {\n c = 0xFFFD;\n bytesPerSequence = 1;\n\n } else if (c > 0xFFFF) {\n c -= 0x10000;\n str += String.fromCharCode(c >>> 10 & 0x3FF | 0xD800);\n c = 0xDC00 | c & 0x3FF;\n }\n\n str += String.fromCharCode(c);\n i += bytesPerSequence;\n }\n\n return str;\n}\n\nfunction readUtf8TextDecoder(buf, pos, end) {\n return utf8TextDecoder.decode(buf.subarray(pos, end));\n}\n\nfunction writeUtf8(buf, str, pos) {\n for (var i = 0, c, lead; i < str.length; i++) {\n c = str.charCodeAt(i); // code point\n\n if (c > 0xD7FF && c < 0xE000) {\n if (lead) {\n if (c < 0xDC00) {\n buf[pos++] = 0xEF;\n buf[pos++] = 0xBF;\n buf[pos++] = 0xBD;\n lead = c;\n continue;\n } else {\n c = lead - 0xD800 << 10 | c - 0xDC00 | 0x10000;\n lead = null;\n }\n } else {\n if (c > 0xDBFF || (i + 1 === str.length)) {\n buf[pos++] = 0xEF;\n buf[pos++] = 0xBF;\n buf[pos++] = 0xBD;\n } else {\n lead = c;\n }\n continue;\n }\n } else if (lead) {\n buf[pos++] = 0xEF;\n buf[pos++] = 0xBF;\n buf[pos++] = 0xBD;\n lead = null;\n }\n\n if (c < 0x80) {\n buf[pos++] = c;\n } else {\n if (c < 0x800) {\n buf[pos++] = c >> 0x6 | 0xC0;\n } else {\n if (c < 0x10000) {\n buf[pos++] = c >> 0xC | 0xE0;\n } else {\n buf[pos++] = c >> 0x12 | 0xF0;\n buf[pos++] = c >> 0xC & 0x3F | 0x80;\n }\n buf[pos++] = c >> 0x6 & 0x3F | 0x80;\n }\n buf[pos++] = c & 0x3F | 0x80;\n }\n }\n return pos;\n}\n","import {AlphaImage} from '../util/image';\n\nimport Protobuf from 'pbf';\nconst border = 3;\n\nimport type {StyleGlyph} from './style_glyph';\n\nfunction readFontstacks(tag: number, glyphs: Array, pbf: Protobuf) {\n if (tag === 1) {\n pbf.readMessage(readFontstack, glyphs);\n }\n}\n\nfunction readFontstack(tag: number, glyphs: Array, pbf: Protobuf) {\n if (tag === 3) {\n const {id, bitmap, width, height, left, top, advance} = pbf.readMessage(readGlyph, {});\n glyphs.push({\n id,\n bitmap: new AlphaImage({\n width: width + 2 * border,\n height: height + 2 * border\n }, bitmap),\n metrics: {width, height, left, top, advance}\n });\n }\n}\n\nfunction readGlyph(tag: number, glyph: any, pbf: Protobuf) {\n if (tag === 1) glyph.id = pbf.readVarint();\n else if (tag === 2) glyph.bitmap = pbf.readBytes();\n else if (tag === 3) glyph.width = pbf.readVarint();\n else if (tag === 4) glyph.height = pbf.readVarint();\n else if (tag === 5) glyph.left = pbf.readSVarint();\n else if (tag === 6) glyph.top = pbf.readSVarint();\n else if (tag === 7) glyph.advance = pbf.readVarint();\n}\n\nexport function parseGlyphPbf(data: ArrayBuffer | Uint8Array): Array {\n return new Protobuf(data).readFields(readFontstacks, []);\n}\n\nexport const GLYPH_PBF_BORDER = border;\n","\nexport default function potpack(boxes) {\n\n // calculate total box area and maximum box width\n let area = 0;\n let maxWidth = 0;\n\n for (const box of boxes) {\n area += box.w * box.h;\n maxWidth = Math.max(maxWidth, box.w);\n }\n\n // sort the boxes for insertion by height, descending\n boxes.sort((a, b) => b.h - a.h);\n\n // aim for a squarish resulting container,\n // slightly adjusted for sub-100% space utilization\n const startWidth = Math.max(Math.ceil(Math.sqrt(area / 0.95)), maxWidth);\n\n // start with a single empty space, unbounded at the bottom\n const spaces = [{x: 0, y: 0, w: startWidth, h: Infinity}];\n\n let width = 0;\n let height = 0;\n\n for (const box of boxes) {\n // look through spaces backwards so that we check smaller spaces first\n for (let i = spaces.length - 1; i >= 0; i--) {\n const space = spaces[i];\n\n // look for empty spaces that can accommodate the current box\n if (box.w > space.w || box.h > space.h) continue;\n\n // found the space; add the box to its top-left corner\n // |-------|-------|\n // | box | |\n // |_______| |\n // | space |\n // |_______________|\n box.x = space.x;\n box.y = space.y;\n\n height = Math.max(height, box.y + box.h);\n width = Math.max(width, box.x + box.w);\n\n if (box.w === space.w && box.h === space.h) {\n // space matches the box exactly; remove it\n const last = spaces.pop();\n if (i < spaces.length) spaces[i] = last;\n\n } else if (box.h === space.h) {\n // space matches the box height; update it accordingly\n // |-------|---------------|\n // | box | updated space |\n // |_______|_______________|\n space.x += box.w;\n space.w -= box.w;\n\n } else if (box.w === space.w) {\n // space matches the box width; update it accordingly\n // |---------------|\n // | box |\n // |_______________|\n // | updated space |\n // |_______________|\n space.y += box.h;\n space.h -= box.h;\n\n } else {\n // otherwise the box splits the space into two spaces\n // |-------|-----------|\n // | box | new space |\n // |_______|___________|\n // | updated space |\n // |___________________|\n spaces.push({\n x: space.x + box.w,\n y: space.y,\n w: space.w - box.w,\n h: box.h\n });\n space.y += box.h;\n space.h -= box.h;\n }\n break;\n }\n }\n\n return {\n w: width, // container width\n h: height, // container height\n fill: (area / (width * height)) || 0 // space utilization\n };\n}\n","/* eslint-disable key-spacing */\nimport {RGBAImage} from '../util/image';\nimport {register} from '../util/web_worker_transfer';\nimport potpack from 'potpack';\n\nimport type {StyleImage} from '../style/style_image';\nimport {TextFit} from '../style/style_image';\nimport type {ImageManager} from './image_manager';\nimport type {Texture} from './texture';\nimport type {Rect} from './glyph_atlas';\nimport type {GetImagesResponse} from '../util/actor_messages';\n\nconst IMAGE_PADDING: number = 1;\nexport {IMAGE_PADDING};\n\nexport class ImagePosition {\n paddedRect: Rect;\n pixelRatio: number;\n version: number;\n stretchY: Array<[number, number]>;\n stretchX: Array<[number, number]>;\n content: [number, number, number, number];\n textFitWidth: TextFit;\n textFitHeight: TextFit;\n\n constructor(paddedRect: Rect, {\n pixelRatio,\n version,\n stretchX,\n stretchY,\n content,\n textFitWidth,\n textFitHeight\n }: StyleImage) {\n this.paddedRect = paddedRect;\n this.pixelRatio = pixelRatio;\n this.stretchX = stretchX;\n this.stretchY = stretchY;\n this.content = content;\n this.version = version;\n this.textFitWidth = textFitWidth;\n this.textFitHeight = textFitHeight;\n }\n\n get tl(): [number, number] {\n return [\n this.paddedRect.x + IMAGE_PADDING,\n this.paddedRect.y + IMAGE_PADDING\n ];\n }\n\n get br(): [number, number] {\n return [\n this.paddedRect.x + this.paddedRect.w - IMAGE_PADDING,\n this.paddedRect.y + this.paddedRect.h - IMAGE_PADDING\n ];\n }\n\n get tlbr(): Array {\n return this.tl.concat(this.br);\n }\n\n get displaySize(): [number, number] {\n return [\n (this.paddedRect.w - IMAGE_PADDING * 2) / this.pixelRatio,\n (this.paddedRect.h - IMAGE_PADDING * 2) / this.pixelRatio\n ];\n }\n}\n\n/**\n * A class holding all the images\n */\nexport class ImageAtlas {\n image: RGBAImage;\n iconPositions: {[_: string]: ImagePosition};\n patternPositions: {[_: string]: ImagePosition};\n haveRenderCallbacks: Array;\n uploaded: boolean;\n\n constructor(icons: GetImagesResponse, patterns: GetImagesResponse) {\n const iconPositions = {}, patternPositions = {};\n this.haveRenderCallbacks = [];\n\n const bins = [];\n\n this.addImages(icons, iconPositions, bins);\n this.addImages(patterns, patternPositions, bins);\n\n const {w, h} = potpack(bins);\n const image = new RGBAImage({width: w || 1, height: h || 1});\n\n for (const id in icons) {\n const src = icons[id];\n const bin = iconPositions[id].paddedRect;\n RGBAImage.copy(src.data, image, {x: 0, y: 0}, {x: bin.x + IMAGE_PADDING, y: bin.y + IMAGE_PADDING}, src.data);\n }\n\n for (const id in patterns) {\n const src = patterns[id];\n const bin = patternPositions[id].paddedRect;\n const x = bin.x + IMAGE_PADDING,\n y = bin.y + IMAGE_PADDING,\n w = src.data.width,\n h = src.data.height;\n\n RGBAImage.copy(src.data, image, {x: 0, y: 0}, {x, y}, src.data);\n // Add 1 pixel wrapped padding on each side of the image.\n RGBAImage.copy(src.data, image, {x: 0, y: h - 1}, {x, y: y - 1}, {width: w, height: 1}); // T\n RGBAImage.copy(src.data, image, {x: 0, y: 0}, {x, y: y + h}, {width: w, height: 1}); // B\n RGBAImage.copy(src.data, image, {x: w - 1, y: 0}, {x: x - 1, y}, {width: 1, height: h}); // L\n RGBAImage.copy(src.data, image, {x: 0, y: 0}, {x: x + w, y}, {width: 1, height: h}); // R\n }\n\n this.image = image;\n this.iconPositions = iconPositions;\n this.patternPositions = patternPositions;\n }\n\n addImages(images: {[_: string]: StyleImage}, positions: {[_: string]: ImagePosition}, bins: Array) {\n for (const id in images) {\n const src = images[id];\n const bin = {\n x: 0,\n y: 0,\n w: src.data.width + 2 * IMAGE_PADDING,\n h: src.data.height + 2 * IMAGE_PADDING,\n };\n bins.push(bin);\n positions[id] = new ImagePosition(bin, src);\n\n if (src.hasRenderCallback) {\n this.haveRenderCallbacks.push(id);\n }\n }\n }\n\n patchUpdatedImages(imageManager: ImageManager, texture: Texture) {\n imageManager.dispatchRenderCallbacks(this.haveRenderCallbacks);\n for (const name in imageManager.updatedImages) {\n this.patchUpdatedImage(this.iconPositions[name], imageManager.getImage(name), texture);\n this.patchUpdatedImage(this.patternPositions[name], imageManager.getImage(name), texture);\n }\n }\n\n patchUpdatedImage(position: ImagePosition, image: StyleImage, texture: Texture) {\n if (!position || !image) return;\n\n if (position.version === image.version) return;\n\n position.version = image.version;\n const [x, y] = position.tl;\n texture.update(image.data, undefined, {x, y});\n }\n\n}\n\nregister('ImagePosition', ImagePosition);\nregister('ImageAtlas', ImageAtlas);\n","import {\n charHasUprightVerticalOrientation,\n charAllowsIdeographicBreaking,\n charInComplexShapingScript\n} from '../util/script_detection';\nimport {verticalizePunctuation} from '../util/verticalize_punctuation';\nimport {rtlWorkerPlugin} from '../source/rtl_text_plugin_worker';\nimport ONE_EM from './one_em';\nimport {warnOnce} from '../util/util';\n\nimport type {StyleGlyph, GlyphMetrics} from '../style/style_glyph';\nimport {GLYPH_PBF_BORDER} from '../style/parse_glyph_pbf';\nimport {TextFit} from '../style/style_image';\nimport type {ImagePosition} from '../render/image_atlas';\nimport {IMAGE_PADDING} from '../render/image_atlas';\nimport type {Rect, GlyphPosition} from '../render/glyph_atlas';\nimport {Formatted, FormattedSection} from '@maplibre/maplibre-gl-style-spec';\n\nenum WritingMode {\n none = 0,\n horizontal = 1,\n vertical = 2,\n horizontalOnly = 3\n}\n\nconst SHAPING_DEFAULT_OFFSET = -17;\nexport {shapeText, shapeIcon, applyTextFit, fitIconToText, getAnchorAlignment, WritingMode, SHAPING_DEFAULT_OFFSET};\n\n// The position of a glyph relative to the text's anchor point.\nexport type PositionedGlyph = {\n glyph: number;\n imageName: string | null;\n x: number;\n y: number;\n vertical: boolean;\n scale: number;\n fontStack: string;\n sectionIndex: number;\n metrics: GlyphMetrics;\n rect: Rect | null;\n};\n\nexport type PositionedLine = {\n positionedGlyphs: Array;\n lineOffset: number;\n};\n\n// A collection of positioned glyphs and some metadata\nexport type Shaping = {\n positionedLines: Array;\n top: number;\n bottom: number;\n left: number;\n right: number;\n writingMode: WritingMode.horizontal | WritingMode.vertical;\n text: string;\n iconsInText: boolean;\n verticalizable: boolean;\n};\n\nfunction isEmpty(positionedLines: Array) {\n for (const line of positionedLines) {\n if (line.positionedGlyphs.length !== 0) {\n return false;\n }\n }\n return true;\n}\n\nexport type SymbolAnchor = 'center' | 'left' | 'right' | 'top' | 'bottom' | 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right';\nexport type TextJustify = 'left' | 'center' | 'right';\n\n// Max number of images in label is 6401 U+E000–U+F8FF that covers\n// Basic Multilingual Plane Unicode Private Use Area (PUA).\nconst PUAbegin = 0xE000;\nconst PUAend = 0xF8FF;\n\nclass SectionOptions {\n // Text options\n scale: number;\n fontStack: string;\n // Image options\n imageName: string | null;\n\n constructor() {\n this.scale = 1.0;\n this.fontStack = '';\n this.imageName = null;\n }\n\n static forText(scale: number | null, fontStack: string) {\n const textOptions = new SectionOptions();\n textOptions.scale = scale || 1;\n textOptions.fontStack = fontStack;\n return textOptions;\n }\n\n static forImage(imageName: string) {\n const imageOptions = new SectionOptions();\n imageOptions.imageName = imageName;\n return imageOptions;\n }\n\n}\n\nclass TaggedString {\n text: string;\n sectionIndex: Array; // maps each character in 'text' to its corresponding entry in 'sections'\n sections: Array;\n imageSectionID: number | null;\n\n constructor() {\n this.text = '';\n this.sectionIndex = [];\n this.sections = [];\n this.imageSectionID = null;\n }\n\n static fromFeature(text: Formatted, defaultFontStack: string) {\n const result = new TaggedString();\n for (let i = 0; i < text.sections.length; i++) {\n const section = text.sections[i];\n if (!section.image) {\n result.addTextSection(section, defaultFontStack);\n } else {\n result.addImageSection(section);\n }\n }\n return result;\n }\n\n length(): number {\n return this.text.length;\n }\n\n getSection(index: number): SectionOptions {\n return this.sections[this.sectionIndex[index]];\n }\n\n getSectionIndex(index: number): number {\n return this.sectionIndex[index];\n }\n\n getCharCode(index: number): number {\n return this.text.charCodeAt(index);\n }\n\n verticalizePunctuation() {\n this.text = verticalizePunctuation(this.text);\n }\n\n trim() {\n let beginningWhitespace = 0;\n for (let i = 0;\n i < this.text.length && whitespace[this.text.charCodeAt(i)];\n i++) {\n beginningWhitespace++;\n }\n let trailingWhitespace = this.text.length;\n for (let i = this.text.length - 1;\n i >= 0 && i >= beginningWhitespace && whitespace[this.text.charCodeAt(i)];\n i--) {\n trailingWhitespace--;\n }\n this.text = this.text.substring(beginningWhitespace, trailingWhitespace);\n this.sectionIndex = this.sectionIndex.slice(beginningWhitespace, trailingWhitespace);\n }\n\n substring(start: number, end: number): TaggedString {\n const substring = new TaggedString();\n substring.text = this.text.substring(start, end);\n substring.sectionIndex = this.sectionIndex.slice(start, end);\n substring.sections = this.sections;\n return substring;\n }\n\n toString(): string {\n return this.text;\n }\n\n getMaxScale() {\n return this.sectionIndex.reduce((max, index) => Math.max(max, this.sections[index].scale), 0);\n }\n\n addTextSection(section: FormattedSection, defaultFontStack: string) {\n this.text += section.text;\n this.sections.push(SectionOptions.forText(section.scale, section.fontStack || defaultFontStack));\n const index = this.sections.length - 1;\n for (let i = 0; i < section.text.length; ++i) {\n this.sectionIndex.push(index);\n }\n }\n\n addImageSection(section: FormattedSection) {\n const imageName = section.image ? section.image.name : '';\n if (imageName.length === 0) {\n warnOnce('Can\\'t add FormattedSection with an empty image.');\n return;\n }\n\n const nextImageSectionCharCode = this.getNextImageSectionCharCode();\n if (!nextImageSectionCharCode) {\n warnOnce(`Reached maximum number of images ${PUAend - PUAbegin + 2}`);\n return;\n }\n\n this.text += String.fromCharCode(nextImageSectionCharCode);\n this.sections.push(SectionOptions.forImage(imageName));\n this.sectionIndex.push(this.sections.length - 1);\n }\n\n getNextImageSectionCharCode(): number | null {\n if (!this.imageSectionID) {\n this.imageSectionID = PUAbegin;\n return this.imageSectionID;\n }\n\n if (this.imageSectionID >= PUAend) return null;\n return ++this.imageSectionID;\n }\n}\n\nfunction breakLines(input: TaggedString, lineBreakPoints: Array): Array {\n const lines = [];\n const text = input.text;\n let start = 0;\n for (const lineBreak of lineBreakPoints) {\n lines.push(input.substring(start, lineBreak));\n start = lineBreak;\n }\n\n if (start < text.length) {\n lines.push(input.substring(start, text.length));\n }\n return lines;\n}\n\nfunction shapeText(\n text: Formatted,\n glyphMap: {\n [_: string]: {\n [_: number]: StyleGlyph;\n };\n },\n glyphPositions: {\n [_: string]: {\n [_: number]: GlyphPosition;\n };\n },\n imagePositions: {[_: string]: ImagePosition},\n defaultFontStack: string,\n maxWidth: number,\n lineHeight: number,\n textAnchor: SymbolAnchor,\n textJustify: TextJustify,\n spacing: number,\n translate: [number, number],\n writingMode: WritingMode.horizontal | WritingMode.vertical,\n allowVerticalPlacement: boolean,\n layoutTextSize: number,\n layoutTextSizeThisZoom: number\n): Shaping | false {\n const logicalInput = TaggedString.fromFeature(text, defaultFontStack);\n\n if (writingMode === WritingMode.vertical) {\n logicalInput.verticalizePunctuation();\n }\n\n let lines: Array;\n\n const {processBidirectionalText, processStyledBidirectionalText} = rtlWorkerPlugin;\n if (processBidirectionalText && logicalInput.sections.length === 1) {\n // Bidi doesn't have to be style-aware\n lines = [];\n const untaggedLines =\n processBidirectionalText(logicalInput.toString(),\n determineLineBreaks(logicalInput, spacing, maxWidth, glyphMap, imagePositions, layoutTextSize));\n for (const line of untaggedLines) {\n const taggedLine = new TaggedString();\n taggedLine.text = line;\n taggedLine.sections = logicalInput.sections;\n for (let i = 0; i < line.length; i++) {\n taggedLine.sectionIndex.push(0);\n }\n lines.push(taggedLine);\n }\n } else if (processStyledBidirectionalText) {\n // Need version of mapbox-gl-rtl-text with style support for combining RTL text\n // with formatting\n lines = [];\n const processedLines =\n processStyledBidirectionalText(logicalInput.text,\n logicalInput.sectionIndex,\n determineLineBreaks(logicalInput, spacing, maxWidth, glyphMap, imagePositions, layoutTextSize));\n for (const line of processedLines) {\n const taggedLine = new TaggedString();\n taggedLine.text = line[0];\n taggedLine.sectionIndex = line[1];\n taggedLine.sections = logicalInput.sections;\n lines.push(taggedLine);\n }\n } else {\n lines = breakLines(logicalInput, determineLineBreaks(logicalInput, spacing, maxWidth, glyphMap, imagePositions, layoutTextSize));\n }\n\n const positionedLines = [];\n const shaping = {\n positionedLines,\n text: logicalInput.toString(),\n top: translate[1],\n bottom: translate[1],\n left: translate[0],\n right: translate[0],\n writingMode,\n iconsInText: false,\n verticalizable: false\n };\n\n shapeLines(shaping, glyphMap, glyphPositions, imagePositions, lines, lineHeight, textAnchor, textJustify, writingMode, spacing, allowVerticalPlacement, layoutTextSizeThisZoom);\n if (isEmpty(positionedLines)) return false;\n\n return shaping;\n}\n\n// using computed properties due to https://github.com/facebook/flow/issues/380\n/* eslint no-useless-computed-key: 0 */\n\nconst whitespace: {\n [_: number]: boolean;\n} = {\n [0x09]: true, // tab\n [0x0a]: true, // newline\n [0x0b]: true, // vertical tab\n [0x0c]: true, // form feed\n [0x0d]: true, // carriage return\n [0x20]: true, // space\n};\n\nconst breakable: {\n [_: number]: boolean;\n} = {\n [0x0a]: true, // newline\n [0x20]: true, // space\n [0x26]: true, // ampersand\n [0x29]: true, // right parenthesis\n [0x2b]: true, // plus sign\n [0x2d]: true, // hyphen-minus\n [0x2f]: true, // solidus\n [0xad]: true, // soft hyphen\n [0xb7]: true, // middle dot\n [0x200b]: true, // zero-width space\n [0x2010]: true, // hyphen\n [0x2013]: true, // en dash\n [0x2027]: true // interpunct\n // Many other characters may be reasonable breakpoints\n // Consider \"neutral orientation\" characters at scriptDetection.charHasNeutralVerticalOrientation\n // See https://github.com/mapbox/mapbox-gl-js/issues/3658\n};\n\n// Allow breaks depending on the following character\nconst breakableBefore: {\n [_: number]: boolean;\n} = {\n [0x28]: true, // left parenthesis\n};\n\nfunction getGlyphAdvance(\n codePoint: number,\n section: SectionOptions,\n glyphMap: {\n [_: string]: {\n [_: number]: StyleGlyph;\n };\n },\n imagePositions: {[_: string]: ImagePosition},\n spacing: number,\n layoutTextSize: number\n): number {\n if (!section.imageName) {\n const positions = glyphMap[section.fontStack];\n const glyph = positions && positions[codePoint];\n if (!glyph) return 0;\n return glyph.metrics.advance * section.scale + spacing;\n } else {\n const imagePosition = imagePositions[section.imageName];\n if (!imagePosition) return 0;\n return imagePosition.displaySize[0] * section.scale * ONE_EM / layoutTextSize + spacing;\n }\n}\n\nfunction determineAverageLineWidth(logicalInput: TaggedString,\n spacing: number,\n maxWidth: number,\n glyphMap: {\n [_: string]: {\n [_: number]: StyleGlyph;\n };\n },\n imagePositions: {[_: string]: ImagePosition},\n layoutTextSize: number) {\n let totalWidth = 0;\n\n for (let index = 0; index < logicalInput.length(); index++) {\n const section = logicalInput.getSection(index);\n totalWidth += getGlyphAdvance(logicalInput.getCharCode(index), section, glyphMap, imagePositions, spacing, layoutTextSize);\n }\n\n const lineCount = Math.max(1, Math.ceil(totalWidth / maxWidth));\n return totalWidth / lineCount;\n}\n\nfunction calculateBadness(lineWidth: number,\n targetWidth: number,\n penalty: number,\n isLastBreak: boolean) {\n const raggedness = Math.pow(lineWidth - targetWidth, 2);\n if (isLastBreak) {\n // Favor finals lines shorter than average over longer than average\n if (lineWidth < targetWidth) {\n return raggedness / 2;\n } else {\n return raggedness * 2;\n }\n }\n\n return raggedness + Math.abs(penalty) * penalty;\n}\n\nfunction calculatePenalty(codePoint: number, nextCodePoint: number, penalizableIdeographicBreak: boolean) {\n let penalty = 0;\n // Force break on newline\n if (codePoint === 0x0a) {\n penalty -= 10000;\n }\n // Penalize breaks between characters that allow ideographic breaking because\n // they are less preferable than breaks at spaces (or zero width spaces).\n if (penalizableIdeographicBreak) {\n penalty += 150;\n }\n\n // Penalize open parenthesis at end of line\n if (codePoint === 0x28 || codePoint === 0xff08) {\n penalty += 50;\n }\n\n // Penalize close parenthesis at beginning of line\n if (nextCodePoint === 0x29 || nextCodePoint === 0xff09) {\n penalty += 50;\n }\n return penalty;\n}\n\ntype Break = {\n index: number;\n x: number;\n priorBreak: Break;\n badness: number;\n};\n\nfunction evaluateBreak(\n breakIndex: number,\n breakX: number,\n targetWidth: number,\n potentialBreaks: Array,\n penalty: number,\n isLastBreak: boolean\n): Break {\n // We could skip evaluating breaks where the line length (breakX - priorBreak.x) > maxWidth\n // ...but in fact we allow lines longer than maxWidth (if there's no break points)\n // ...and when targetWidth and maxWidth are close, strictly enforcing maxWidth can give\n // more lopsided results.\n\n let bestPriorBreak: Break = null;\n let bestBreakBadness = calculateBadness(breakX, targetWidth, penalty, isLastBreak);\n\n for (const potentialBreak of potentialBreaks) {\n const lineWidth = breakX - potentialBreak.x;\n const breakBadness =\n calculateBadness(lineWidth, targetWidth, penalty, isLastBreak) + potentialBreak.badness;\n if (breakBadness <= bestBreakBadness) {\n bestPriorBreak = potentialBreak;\n bestBreakBadness = breakBadness;\n }\n }\n\n return {\n index: breakIndex,\n x: breakX,\n priorBreak: bestPriorBreak,\n badness: bestBreakBadness\n };\n}\n\nfunction leastBadBreaks(lastLineBreak?: Break | null): Array {\n if (!lastLineBreak) {\n return [];\n }\n return leastBadBreaks(lastLineBreak.priorBreak).concat(lastLineBreak.index);\n}\n\nfunction determineLineBreaks(\n logicalInput: TaggedString,\n spacing: number,\n maxWidth: number,\n glyphMap: {\n [_: string]: {\n [_: number]: StyleGlyph;\n };\n },\n imagePositions: {[_: string]: ImagePosition},\n layoutTextSize: number\n): Array {\n if (!logicalInput)\n return [];\n\n const potentialLineBreaks = [];\n const targetWidth = determineAverageLineWidth(logicalInput, spacing, maxWidth, glyphMap, imagePositions, layoutTextSize);\n\n const hasServerSuggestedBreakpoints = logicalInput.text.indexOf('\\u200b') >= 0;\n\n let currentX = 0;\n\n for (let i = 0; i < logicalInput.length(); i++) {\n const section = logicalInput.getSection(i);\n const codePoint = logicalInput.getCharCode(i);\n if (!whitespace[codePoint]) currentX += getGlyphAdvance(codePoint, section, glyphMap, imagePositions, spacing, layoutTextSize);\n\n // Ideographic characters, spaces, and word-breaking punctuation that often appear without\n // surrounding spaces.\n if ((i < logicalInput.length() - 1)) {\n const ideographicBreak = charAllowsIdeographicBreaking(codePoint);\n if (breakable[codePoint] || ideographicBreak || section.imageName || (i !== logicalInput.length() - 2 && breakableBefore[logicalInput.getCharCode(i + 1)])) {\n\n potentialLineBreaks.push(\n evaluateBreak(\n i + 1,\n currentX,\n targetWidth,\n potentialLineBreaks,\n calculatePenalty(codePoint, logicalInput.getCharCode(i + 1), ideographicBreak && hasServerSuggestedBreakpoints),\n false));\n }\n }\n }\n\n return leastBadBreaks(\n evaluateBreak(\n logicalInput.length(),\n currentX,\n targetWidth,\n potentialLineBreaks,\n 0,\n true));\n}\n\nfunction getAnchorAlignment(anchor: SymbolAnchor) {\n let horizontalAlign = 0.5, verticalAlign = 0.5;\n\n switch (anchor) {\n case 'right':\n case 'top-right':\n case 'bottom-right':\n horizontalAlign = 1;\n break;\n case 'left':\n case 'top-left':\n case 'bottom-left':\n horizontalAlign = 0;\n break;\n }\n\n switch (anchor) {\n case 'bottom':\n case 'bottom-right':\n case 'bottom-left':\n verticalAlign = 1;\n break;\n case 'top':\n case 'top-right':\n case 'top-left':\n verticalAlign = 0;\n break;\n }\n\n return {horizontalAlign, verticalAlign};\n}\n\nfunction shapeLines(shaping: Shaping,\n glyphMap: {\n [_: string]: {\n [_: number]: StyleGlyph;\n };\n },\n glyphPositions: {\n [_: string]: {\n [_: number]: GlyphPosition;\n };\n },\n imagePositions: {[_: string]: ImagePosition},\n lines: Array,\n lineHeight: number,\n textAnchor: SymbolAnchor,\n textJustify: TextJustify,\n writingMode: WritingMode.horizontal | WritingMode.vertical,\n spacing: number,\n allowVerticalPlacement: boolean,\n layoutTextSizeThisZoom: number) {\n\n let x = 0;\n let y = SHAPING_DEFAULT_OFFSET;\n\n let maxLineLength = 0;\n let maxLineHeight = 0;\n\n const justify =\n textJustify === 'right' ? 1 :\n textJustify === 'left' ? 0 : 0.5;\n\n let lineIndex = 0;\n for (const line of lines) {\n line.trim();\n\n const lineMaxScale = line.getMaxScale();\n const maxLineOffset = (lineMaxScale - 1) * ONE_EM;\n const positionedLine = {positionedGlyphs: [], lineOffset: 0};\n shaping.positionedLines[lineIndex] = positionedLine;\n const positionedGlyphs = positionedLine.positionedGlyphs;\n let lineOffset = 0.0;\n\n if (!line.length()) {\n y += lineHeight; // Still need a line feed after empty line\n ++lineIndex;\n continue;\n }\n\n for (let i = 0; i < line.length(); i++) {\n const section = line.getSection(i);\n const sectionIndex = line.getSectionIndex(i);\n const codePoint = line.getCharCode(i);\n let baselineOffset = 0.0;\n let metrics = null;\n let rect = null;\n let imageName = null;\n let verticalAdvance = ONE_EM;\n const vertical = !(writingMode === WritingMode.horizontal ||\n // Don't verticalize glyphs that have no upright orientation if vertical placement is disabled.\n (!allowVerticalPlacement && !charHasUprightVerticalOrientation(codePoint)) ||\n // If vertical placement is enabled, don't verticalize glyphs that\n // are from complex text layout script, or whitespaces.\n (allowVerticalPlacement && (whitespace[codePoint] || charInComplexShapingScript(codePoint))));\n\n if (!section.imageName) {\n const positions = glyphPositions[section.fontStack];\n const glyphPosition = positions && positions[codePoint];\n if (glyphPosition && glyphPosition.rect) {\n rect = glyphPosition.rect;\n metrics = glyphPosition.metrics;\n } else {\n const glyphs = glyphMap[section.fontStack];\n const glyph = glyphs && glyphs[codePoint];\n if (!glyph) continue;\n metrics = glyph.metrics;\n }\n\n // We don't know the baseline, but since we're laying out\n // at 24 points, we can calculate how much it will move when\n // we scale up or down.\n baselineOffset = (lineMaxScale - section.scale) * ONE_EM;\n } else {\n const imagePosition = imagePositions[section.imageName];\n if (!imagePosition) continue;\n imageName = section.imageName;\n shaping.iconsInText = shaping.iconsInText || true;\n rect = imagePosition.paddedRect;\n const size = imagePosition.displaySize;\n // If needed, allow to set scale factor for an image using\n // alias \"image-scale\" that could be alias for \"font-scale\"\n // when FormattedSection is an image section.\n section.scale = section.scale * ONE_EM / layoutTextSizeThisZoom;\n\n metrics = {width: size[0],\n height: size[1],\n left: IMAGE_PADDING,\n top: -GLYPH_PBF_BORDER,\n advance: vertical ? size[1] : size[0]};\n\n // Difference between one EM and an image size.\n // Aligns bottom of an image to a baseline level.\n const imageOffset = ONE_EM - size[1] * section.scale;\n baselineOffset = maxLineOffset + imageOffset;\n verticalAdvance = metrics.advance;\n\n // Difference between height of an image and one EM at max line scale.\n // Pushes current line down if an image size is over 1 EM at max line scale.\n const offset = vertical ? size[0] * section.scale - ONE_EM * lineMaxScale :\n size[1] * section.scale - ONE_EM * lineMaxScale;\n if (offset > 0 && offset > lineOffset) {\n lineOffset = offset;\n }\n }\n\n if (!vertical) {\n positionedGlyphs.push({glyph: codePoint, imageName, x, y: y + baselineOffset, vertical, scale: section.scale, fontStack: section.fontStack, sectionIndex, metrics, rect});\n x += metrics.advance * section.scale + spacing;\n } else {\n shaping.verticalizable = true;\n positionedGlyphs.push({glyph: codePoint, imageName, x, y: y + baselineOffset, vertical, scale: section.scale, fontStack: section.fontStack, sectionIndex, metrics, rect});\n x += verticalAdvance * section.scale + spacing;\n }\n }\n\n // Only justify if we placed at least one glyph\n if (positionedGlyphs.length !== 0) {\n const lineLength = x - spacing;\n maxLineLength = Math.max(lineLength, maxLineLength);\n justifyLine(positionedGlyphs, 0, positionedGlyphs.length - 1, justify, lineOffset);\n }\n\n x = 0;\n const currentLineHeight = lineHeight * lineMaxScale + lineOffset;\n positionedLine.lineOffset = Math.max(lineOffset, maxLineOffset);\n y += currentLineHeight;\n maxLineHeight = Math.max(currentLineHeight, maxLineHeight);\n ++lineIndex;\n }\n\n // Calculate the bounding box and justify / align text block.\n const height = y - SHAPING_DEFAULT_OFFSET;\n const {horizontalAlign, verticalAlign} = getAnchorAlignment(textAnchor);\n align(shaping.positionedLines, justify, horizontalAlign, verticalAlign, maxLineLength, maxLineHeight, lineHeight, height, lines.length);\n\n shaping.top += -verticalAlign * height;\n shaping.bottom = shaping.top + height;\n shaping.left += -horizontalAlign * maxLineLength;\n shaping.right = shaping.left + maxLineLength;\n}\n\n// justify right = 1, left = 0, center = 0.5\nfunction justifyLine(positionedGlyphs: Array,\n start: number,\n end: number,\n justify: 1 | 0 | 0.5,\n lineOffset: number) {\n if (!justify && !lineOffset)\n return;\n\n const lastPositionedGlyph = positionedGlyphs[end];\n const lastAdvance = lastPositionedGlyph.metrics.advance * lastPositionedGlyph.scale;\n const lineIndent = (positionedGlyphs[end].x + lastAdvance) * justify;\n\n for (let j = start; j <= end; j++) {\n positionedGlyphs[j].x -= lineIndent;\n positionedGlyphs[j].y += lineOffset;\n }\n}\n\nfunction align(positionedLines: Array,\n justify: number,\n horizontalAlign: number,\n verticalAlign: number,\n maxLineLength: number,\n maxLineHeight: number,\n lineHeight: number,\n blockHeight: number,\n lineCount: number) {\n const shiftX = (justify - horizontalAlign) * maxLineLength;\n let shiftY = 0;\n\n if (maxLineHeight !== lineHeight) {\n shiftY = -blockHeight * verticalAlign - SHAPING_DEFAULT_OFFSET;\n } else {\n shiftY = (-verticalAlign * lineCount + 0.5) * lineHeight;\n }\n\n for (const line of positionedLines) {\n for (const positionedGlyph of line.positionedGlyphs) {\n positionedGlyph.x += shiftX;\n positionedGlyph.y += shiftY;\n }\n }\n}\n\nexport type PositionedIcon = {\n image: ImagePosition;\n top: number;\n bottom: number;\n left: number;\n right: number;\n collisionPadding?: [number, number, number, number];\n};\n\nfunction shapeIcon(\n image: ImagePosition,\n iconOffset: [number, number],\n iconAnchor: SymbolAnchor\n): PositionedIcon {\n const {horizontalAlign, verticalAlign} = getAnchorAlignment(iconAnchor);\n const dx = iconOffset[0];\n const dy = iconOffset[1];\n const x1 = dx - image.displaySize[0] * horizontalAlign;\n const x2 = x1 + image.displaySize[0];\n const y1 = dy - image.displaySize[1] * verticalAlign;\n const y2 = y1 + image.displaySize[1];\n return {image, top: y1, bottom: y2, left: x1, right: x2};\n}\n\nexport interface Box {\n x1: number;\n y1: number;\n x2: number;\n y2: number;\n}\n\n/**\n * Called after a PositionedIcon has already been run through fitIconToText,\n * but needs further adjustment to apply textFitWidth and textFitHeight.\n * @param shapedIcon - The icon that will be adjusted.\n * @returns Extents of the shapedIcon with text fit adjustments if necessary.\n */\nfunction applyTextFit(shapedIcon: PositionedIcon): Box {\n // Assume shapedIcon.image is set or this wouldn't be called.\n // Size of the icon after it was adjusted using stretchX and Y\n let iconLeft = shapedIcon.left;\n let iconTop = shapedIcon.top;\n let iconWidth = shapedIcon.right - iconLeft;\n let iconHeight = shapedIcon.bottom - iconTop;\n // Size of the original content area\n const contentWidth = shapedIcon.image.content[2] - shapedIcon.image.content[0];\n const contentHeight = shapedIcon.image.content[3] - shapedIcon.image.content[1];\n const textFitWidth = shapedIcon.image.textFitWidth ?? TextFit.stretchOrShrink;\n const textFitHeight = shapedIcon.image.textFitHeight ?? TextFit.stretchOrShrink;\n const contentAspectRatio = contentWidth / contentHeight;\n // Scale to the proportional axis first note that height takes precedence if\n // both axes are set to proportional.\n if (textFitHeight === TextFit.proportional) {\n if ((textFitWidth === TextFit.stretchOnly && iconWidth / iconHeight < contentAspectRatio) || textFitWidth === TextFit.proportional) {\n // Push the width of the icon back out to match the content aspect ratio\n const newIconWidth = Math.ceil(iconHeight * contentAspectRatio);\n iconLeft *= newIconWidth / iconWidth;\n iconWidth = newIconWidth;\n }\n } else if (textFitWidth === TextFit.proportional) {\n if (textFitHeight === TextFit.stretchOnly && contentAspectRatio !== 0 && iconWidth / iconHeight > contentAspectRatio) {\n // Push the height of the icon back out to match the content aspect ratio\n const newIconHeight = Math.ceil(iconWidth / contentAspectRatio);\n iconTop *= newIconHeight / iconHeight;\n iconHeight = newIconHeight;\n }\n } else {\n // If neither textFitHeight nor textFitWidth are proportional then\n // there is no effect since the content rectangle should be precisely\n // matched to the content\n }\n return {x1: iconLeft, y1: iconTop, x2: iconLeft + iconWidth, y2: iconTop + iconHeight};\n}\n\nfunction fitIconToText(\n shapedIcon: PositionedIcon,\n shapedText: Shaping,\n textFit: string,\n padding: [number, number, number, number],\n iconOffset: [number, number],\n fontScale: number\n): PositionedIcon {\n\n const image = shapedIcon.image;\n\n let collisionPadding;\n if (image.content) {\n const content = image.content;\n const pixelRatio = image.pixelRatio || 1;\n collisionPadding = [\n content[0] / pixelRatio,\n content[1] / pixelRatio,\n image.displaySize[0] - content[2] / pixelRatio,\n image.displaySize[1] - content[3] / pixelRatio\n ];\n }\n\n // We don't respect the icon-anchor, because icon-text-fit is set. Instead,\n // the icon will be centered on the text, then stretched in the given\n // dimensions.\n\n const textLeft = shapedText.left * fontScale;\n const textRight = shapedText.right * fontScale;\n\n let top, right, bottom, left;\n if (textFit === 'width' || textFit === 'both') {\n // Stretched horizontally to the text width\n left = iconOffset[0] + textLeft - padding[3];\n right = iconOffset[0] + textRight + padding[1];\n } else {\n // Centered on the text\n left = iconOffset[0] + (textLeft + textRight - image.displaySize[0]) / 2;\n right = left + image.displaySize[0];\n }\n\n const textTop = shapedText.top * fontScale;\n const textBottom = shapedText.bottom * fontScale;\n if (textFit === 'height' || textFit === 'both') {\n // Stretched vertically to the text height\n top = iconOffset[1] + textTop - padding[0];\n bottom = iconOffset[1] + textBottom + padding[2];\n } else {\n // Centered on the text\n top = iconOffset[1] + (textTop + textBottom - image.displaySize[1]) / 2;\n bottom = top + image.displaySize[1];\n }\n\n return {image, top, right, bottom, left, collisionPadding};\n}\n","import {Interpolate, interpolates} from '@maplibre/maplibre-gl-style-spec';\nimport {clamp} from '../util/util';\nimport {EvaluationParameters} from '../style/evaluation_parameters';\n\nimport type {PropertyValue, PossiblyEvaluatedPropertyValue} from '../style/properties';\nimport type {InterpolationType} from '@maplibre/maplibre-gl-style-spec';\n\nconst MAX_GLYPH_ICON_SIZE = 255;\nconst SIZE_PACK_FACTOR = 128;\nconst MAX_PACKED_SIZE = MAX_GLYPH_ICON_SIZE * SIZE_PACK_FACTOR;\n\nexport {getSizeData, evaluateSizeForFeature, evaluateSizeForZoom, SIZE_PACK_FACTOR, MAX_GLYPH_ICON_SIZE, MAX_PACKED_SIZE};\n\nexport type SizeData = {\n kind: 'constant';\n layoutSize: number;\n} | {\n kind: 'source';\n} | {\n kind: 'camera';\n minZoom: number;\n maxZoom: number;\n minSize: number;\n maxSize: number;\n interpolationType: InterpolationType;\n} | {\n kind: 'composite';\n minZoom: number;\n maxZoom: number;\n interpolationType: InterpolationType;\n};\n\nexport type EvaluatedZoomSize = {uSizeT: number; uSize: number};\n\n// For {text,icon}-size, get the bucket-level data that will be needed by\n// the painter to set symbol-size-related uniforms\nfunction getSizeData(\n tileZoom: number,\n value: PropertyValue>\n): SizeData {\n const {expression} = value;\n\n if (expression.kind === 'constant') {\n const layoutSize = expression.evaluate(new EvaluationParameters(tileZoom + 1));\n return {kind: 'constant', layoutSize};\n\n } else if (expression.kind === 'source') {\n return {kind: 'source'};\n\n } else {\n const {zoomStops, interpolationType} = expression;\n\n // calculate covering zoom stops for zoom-dependent values\n let lower = 0;\n while (lower < zoomStops.length && zoomStops[lower] <= tileZoom) lower++;\n lower = Math.max(0, lower - 1);\n let upper = lower;\n while (upper < zoomStops.length && zoomStops[upper] < tileZoom + 1) upper++;\n upper = Math.min(zoomStops.length - 1, upper);\n\n const minZoom = zoomStops[lower];\n const maxZoom = zoomStops[upper];\n\n // We'd like to be able to use CameraExpression or CompositeExpression in these\n // return types rather than ExpressionSpecification, but the former are not\n // transferrable across Web Worker boundaries.\n if (expression.kind === 'composite') {\n return {kind: 'composite', minZoom, maxZoom, interpolationType};\n }\n\n // for camera functions, also save off the function values\n // evaluated at the covering zoom levels\n const minSize = expression.evaluate(new EvaluationParameters(minZoom));\n const maxSize = expression.evaluate(new EvaluationParameters(maxZoom));\n\n return {kind: 'camera', minZoom, maxZoom, minSize, maxSize, interpolationType};\n }\n}\n\nfunction evaluateSizeForFeature(sizeData: SizeData,\n {\n uSize,\n uSizeT\n }: {\n uSize: number;\n uSizeT: number;\n },\n {\n lowerSize,\n upperSize\n }: {\n lowerSize: number;\n upperSize: number;\n }): number {\n if (sizeData.kind === 'source') {\n return lowerSize / SIZE_PACK_FACTOR;\n } else if (sizeData.kind === 'composite') {\n return interpolates.number(lowerSize / SIZE_PACK_FACTOR, upperSize / SIZE_PACK_FACTOR, uSizeT);\n }\n return uSize;\n}\n\nfunction evaluateSizeForZoom(sizeData: SizeData, zoom: number): EvaluatedZoomSize {\n let uSizeT = 0;\n let uSize = 0;\n\n if (sizeData.kind === 'constant') {\n uSize = sizeData.layoutSize;\n\n } else if (sizeData.kind !== 'source') {\n const {interpolationType, minZoom, maxZoom} = sizeData;\n\n // Even though we could get the exact value of the camera function\n // at z = tr.zoom, we intentionally do not: instead, we interpolate\n // between the camera function values at a pair of zoom stops covering\n // [tileZoom, tileZoom + 1] in order to be consistent with this\n // restriction on composite functions\n const t = !interpolationType ? 0 : clamp(\n Interpolate.interpolationFactor(interpolationType, zoom, minZoom, maxZoom), 0, 1);\n\n if (sizeData.kind === 'camera') {\n uSize = interpolates.number(sizeData.minSize, sizeData.maxSize, t);\n } else {\n uSizeT = t;\n }\n }\n\n return {uSizeT, uSize};\n}\n","import {SymbolLayoutPropsPossiblyEvaluated} from './symbol_style_layer_properties.g';\nimport type {SymbolLayoutProps} from './symbol_style_layer_properties.g';\nimport {PossiblyEvaluated} from '../properties';\n\n/**\n * The overlap mode for properties like `icon-overlap`and `text-overlap`\n */\nexport type OverlapMode = 'never' | 'always' | 'cooperative';\n\nexport function getOverlapMode(layout: PossiblyEvaluated, overlapProp: 'icon-overlap', allowOverlapProp: 'icon-allow-overlap'): OverlapMode;\nexport function getOverlapMode(layout: PossiblyEvaluated, overlapProp: 'text-overlap', allowOverlapProp: 'text-allow-overlap'): OverlapMode;\nexport function getOverlapMode(layout: PossiblyEvaluated, overlapProp: 'icon-overlap' | 'text-overlap', allowOverlapProp: 'icon-allow-overlap' | 'text-allow-overlap'): OverlapMode {\n let result: OverlapMode = 'never';\n const overlap = layout.get(overlapProp);\n\n if (overlap) {\n // if -overlap is set, use it\n result = overlap;\n } else if (layout.get(allowOverlapProp)) {\n // fall back to -allow-overlap, with false='never', true='always'\n result = 'always';\n }\n\n return result;\n}\n","import {\n symbolLayoutAttributes,\n collisionVertexAttributes,\n collisionBoxLayout,\n dynamicLayoutAttributes,\n} from './symbol_attributes';\n\nimport {SymbolLayoutArray,\n SymbolDynamicLayoutArray,\n SymbolOpacityArray,\n CollisionBoxLayoutArray,\n CollisionVertexArray,\n PlacedSymbolArray,\n SymbolInstanceArray,\n GlyphOffsetArray,\n SymbolLineVertexArray,\n TextAnchorOffsetArray\n} from '../array_types.g';\n\nimport Point from '@mapbox/point-geometry';\nimport {SegmentVector} from '../segment';\nimport {ProgramConfigurationSet} from '../program_configuration';\nimport {TriangleIndexArray, LineIndexArray} from '../index_array_type';\nimport {transformText} from '../../symbol/transform_text';\nimport {mergeLines} from '../../symbol/merge_lines';\nimport {allowsVerticalWritingMode, stringContainsRTLText} from '../../util/script_detection';\nimport {WritingMode} from '../../symbol/shaping';\nimport {loadGeometry} from '../load_geometry';\nimport {toEvaluationFeature} from '../evaluation_feature';\nimport mvt from '@mapbox/vector-tile';\nconst vectorTileFeatureTypes = mvt.VectorTileFeature.types;\nimport {verticalizedCharacterMap} from '../../util/verticalize_punctuation';\nimport {Anchor} from '../../symbol/anchor';\nimport {getSizeData, MAX_PACKED_SIZE} from '../../symbol/symbol_size';\n\nimport {register} from '../../util/web_worker_transfer';\nimport {EvaluationParameters} from '../../style/evaluation_parameters';\nimport {Formatted, ResolvedImage} from '@maplibre/maplibre-gl-style-spec';\nimport {rtlWorkerPlugin} from '../../source/rtl_text_plugin_worker';\nimport {mat4} from 'gl-matrix';\nimport {getOverlapMode} from '../../style/style_layer/overlap_mode';\nimport type {CanonicalTileID} from '../../source/tile_id';\nimport type {\n Bucket,\n BucketParameters,\n IndexedFeature,\n PopulateParameters\n} from '../bucket';\nimport type {CollisionBoxArray, CollisionBox, SymbolInstance} from '../array_types.g';\nimport type {StructArray, StructArrayMember, ViewType} from '../../util/struct_array';\nimport type {SymbolStyleLayer} from '../../style/style_layer/symbol_style_layer';\nimport type {Context} from '../../gl/context';\nimport type {IndexBuffer} from '../../gl/index_buffer';\nimport type {VertexBuffer} from '../../gl/vertex_buffer';\nimport type {SymbolQuad} from '../../symbol/quads';\nimport type {SizeData} from '../../symbol/symbol_size';\nimport type {FeatureStates} from '../../source/source_state';\nimport type {ImagePosition} from '../../render/image_atlas';\nimport type {VectorTileLayer} from '@mapbox/vector-tile';\n\nexport type SingleCollisionBox = {\n x1: number;\n y1: number;\n x2: number;\n y2: number;\n anchorPointX: number;\n anchorPointY: number;\n};\n\nexport type CollisionArrays = {\n textBox?: SingleCollisionBox;\n verticalTextBox?: SingleCollisionBox;\n iconBox?: SingleCollisionBox;\n verticalIconBox?: SingleCollisionBox;\n textFeatureIndex?: number;\n verticalTextFeatureIndex?: number;\n iconFeatureIndex?: number;\n verticalIconFeatureIndex?: number;\n};\n\nexport type SymbolFeature = {\n sortKey: number | void;\n text: Formatted | void;\n icon: ResolvedImage;\n index: number;\n sourceLayerIndex: number;\n geometry: Array>;\n properties: any;\n type: 'Unknown' | 'Point' | 'LineString' | 'Polygon';\n id?: any;\n};\n\nexport type SortKeyRange = {\n sortKey: number;\n symbolInstanceStart: number;\n symbolInstanceEnd: number;\n};\n\n// Opacity arrays are frequently updated but don't contain a lot of information, so we pack them\n// tight. Each Uint32 is actually four duplicate Uint8s for the four corners of a glyph\n// 7 bits are for the current opacity, and the lowest bit is the target opacity\n\n// actually defined in symbol_attributes.js\n// const placementOpacityAttributes = [\n// { name: 'a_fade_opacity', components: 1, type: 'Uint32' }\n// ];\nconst shaderOpacityAttributes = [\n {name: 'a_fade_opacity', components: 1, type: 'Uint8' as ViewType, offset: 0}\n];\n\nfunction addVertex(\n array: StructArray,\n anchorX: number,\n anchorY: number,\n ox: number,\n oy: number,\n tx: number,\n ty: number,\n sizeVertex: number,\n isSDF: boolean,\n pixelOffsetX: number,\n pixelOffsetY: number,\n minFontScaleX: number,\n minFontScaleY: number\n) {\n const aSizeX = sizeVertex ? Math.min(MAX_PACKED_SIZE, Math.round(sizeVertex[0])) : 0;\n const aSizeY = sizeVertex ? Math.min(MAX_PACKED_SIZE, Math.round(sizeVertex[1])) : 0;\n array.emplaceBack(\n // a_pos_offset\n anchorX,\n anchorY,\n Math.round(ox * 32),\n Math.round(oy * 32),\n\n // a_data\n tx, // x coordinate of symbol on glyph atlas texture\n ty, // y coordinate of symbol on glyph atlas texture\n (aSizeX << 1) + (isSDF ? 1 : 0),\n aSizeY,\n pixelOffsetX * 16,\n pixelOffsetY * 16,\n minFontScaleX * 256,\n minFontScaleY * 256\n );\n}\n\nfunction addDynamicAttributes(dynamicLayoutVertexArray: StructArray, p: Point, angle: number) {\n dynamicLayoutVertexArray.emplaceBack(p.x, p.y, angle);\n dynamicLayoutVertexArray.emplaceBack(p.x, p.y, angle);\n dynamicLayoutVertexArray.emplaceBack(p.x, p.y, angle);\n dynamicLayoutVertexArray.emplaceBack(p.x, p.y, angle);\n}\n\nfunction containsRTLText(formattedText: Formatted): boolean {\n for (const section of formattedText.sections) {\n if (stringContainsRTLText(section.text)) {\n return true;\n }\n }\n return false;\n}\n\nexport class SymbolBuffers {\n layoutVertexArray: SymbolLayoutArray;\n layoutVertexBuffer: VertexBuffer;\n\n indexArray: TriangleIndexArray;\n indexBuffer: IndexBuffer;\n\n programConfigurations: ProgramConfigurationSet;\n segments: SegmentVector;\n\n dynamicLayoutVertexArray: SymbolDynamicLayoutArray;\n dynamicLayoutVertexBuffer: VertexBuffer;\n\n opacityVertexArray: SymbolOpacityArray;\n opacityVertexBuffer: VertexBuffer;\n hasVisibleVertices: boolean;\n\n collisionVertexArray: CollisionVertexArray;\n collisionVertexBuffer: VertexBuffer;\n\n placedSymbolArray: PlacedSymbolArray;\n\n constructor(programConfigurations: ProgramConfigurationSet) {\n this.layoutVertexArray = new SymbolLayoutArray();\n this.indexArray = new TriangleIndexArray();\n this.programConfigurations = programConfigurations;\n this.segments = new SegmentVector();\n this.dynamicLayoutVertexArray = new SymbolDynamicLayoutArray();\n this.opacityVertexArray = new SymbolOpacityArray();\n this.hasVisibleVertices = false;\n this.placedSymbolArray = new PlacedSymbolArray();\n }\n\n isEmpty() {\n return this.layoutVertexArray.length === 0 &&\n this.indexArray.length === 0 &&\n this.dynamicLayoutVertexArray.length === 0 &&\n this.opacityVertexArray.length === 0;\n }\n\n upload(context: Context, dynamicIndexBuffer: boolean, upload?: boolean, update?: boolean) {\n if (this.isEmpty()) {\n return;\n }\n\n if (upload) {\n this.layoutVertexBuffer = context.createVertexBuffer(this.layoutVertexArray, symbolLayoutAttributes.members);\n this.indexBuffer = context.createIndexBuffer(this.indexArray, dynamicIndexBuffer);\n this.dynamicLayoutVertexBuffer = context.createVertexBuffer(this.dynamicLayoutVertexArray, dynamicLayoutAttributes.members, true);\n this.opacityVertexBuffer = context.createVertexBuffer(this.opacityVertexArray, shaderOpacityAttributes, true);\n // This is a performance hack so that we can write to opacityVertexArray with uint32s\n // even though the shaders read uint8s\n this.opacityVertexBuffer.itemSize = 1;\n }\n if (upload || update) {\n this.programConfigurations.upload(context);\n }\n }\n\n destroy() {\n if (!this.layoutVertexBuffer) return;\n this.layoutVertexBuffer.destroy();\n this.indexBuffer.destroy();\n this.programConfigurations.destroy();\n this.segments.destroy();\n this.dynamicLayoutVertexBuffer.destroy();\n this.opacityVertexBuffer.destroy();\n }\n}\n\nregister('SymbolBuffers', SymbolBuffers);\n\nclass CollisionBuffers {\n layoutVertexArray: StructArray;\n layoutAttributes: Array;\n layoutVertexBuffer: VertexBuffer;\n\n indexArray: TriangleIndexArray | LineIndexArray;\n indexBuffer: IndexBuffer;\n\n segments: SegmentVector;\n\n collisionVertexArray: CollisionVertexArray;\n collisionVertexBuffer: VertexBuffer;\n\n constructor(LayoutArray: {\n new (...args: any): StructArray;\n },\n layoutAttributes: Array,\n IndexArray: {\n new (...args: any): TriangleIndexArray | LineIndexArray;\n }) {\n this.layoutVertexArray = new LayoutArray();\n this.layoutAttributes = layoutAttributes;\n this.indexArray = new IndexArray();\n this.segments = new SegmentVector();\n this.collisionVertexArray = new CollisionVertexArray();\n }\n\n upload(context: Context) {\n this.layoutVertexBuffer = context.createVertexBuffer(this.layoutVertexArray, this.layoutAttributes);\n this.indexBuffer = context.createIndexBuffer(this.indexArray);\n this.collisionVertexBuffer = context.createVertexBuffer(this.collisionVertexArray, collisionVertexAttributes.members, true);\n }\n\n destroy() {\n if (!this.layoutVertexBuffer) return;\n this.layoutVertexBuffer.destroy();\n this.indexBuffer.destroy();\n this.segments.destroy();\n this.collisionVertexBuffer.destroy();\n }\n}\n\nregister('CollisionBuffers', CollisionBuffers);\n\n/**\n * @internal\n * Unlike other buckets, which simply implement #addFeature with type-specific\n * logic for (essentially) triangulating feature geometries, SymbolBucket\n * requires specialized behavior:\n *\n * 1. WorkerTile#parse(), the logical owner of the bucket creation process,\n * calls SymbolBucket#populate(), which resolves text and icon tokens on\n * each feature, adds each glyphs and symbols needed to the passed-in\n * collections options.glyphDependencies and options.iconDependencies, and\n * stores the feature data for use in subsequent step (this.features).\n *\n * 2. WorkerTile asynchronously requests from the main thread all of the glyphs\n * and icons needed (by this bucket and any others). When glyphs and icons\n * have been received, the WorkerTile creates a CollisionIndex and invokes:\n *\n * 3. performSymbolLayout(bucket, stacks, icons) perform texts shaping and\n * layout on a Symbol Bucket. This step populates:\n * `this.symbolInstances`: metadata on generated symbols\n * `this.collisionBoxArray`: collision data for use by foreground\n * `this.text`: SymbolBuffers for text symbols\n * `this.icons`: SymbolBuffers for icons\n * `this.iconCollisionBox`: Debug SymbolBuffers for icon collision boxes\n * `this.textCollisionBox`: Debug SymbolBuffers for text collision boxes\n * The results are sent to the foreground for rendering\n *\n * 4. placement.ts is run on the foreground,\n * and uses the CollisionIndex along with current camera settings to determine\n * which symbols can actually show on the map. Collided symbols are hidden\n * using a dynamic \"OpacityVertexArray\".\n */\nexport class SymbolBucket implements Bucket {\n static MAX_GLYPHS: number;\n static addDynamicAttributes: typeof addDynamicAttributes;\n\n collisionBoxArray: CollisionBoxArray;\n zoom: number;\n overscaling: number;\n layers: Array;\n layerIds: Array;\n stateDependentLayers: Array;\n stateDependentLayerIds: Array;\n\n index: number;\n sdfIcons: boolean;\n iconsInText: boolean;\n iconsNeedLinear: boolean;\n bucketInstanceId: number;\n justReloaded: boolean;\n hasPattern: boolean;\n\n textSizeData: SizeData;\n iconSizeData: SizeData;\n\n glyphOffsetArray: GlyphOffsetArray;\n lineVertexArray: SymbolLineVertexArray;\n features: Array;\n symbolInstances: SymbolInstanceArray;\n textAnchorOffsets: TextAnchorOffsetArray;\n collisionArrays: Array;\n sortKeyRanges: Array;\n pixelRatio: number;\n tilePixelRatio: number;\n compareText: {[_: string]: Array};\n fadeStartTime: number;\n sortFeaturesByKey: boolean;\n sortFeaturesByY: boolean;\n canOverlap: boolean;\n sortedAngle: number;\n featureSortOrder: Array;\n\n collisionCircleArray: Array;\n placementInvProjMatrix: mat4;\n placementViewportMatrix: mat4;\n\n text: SymbolBuffers;\n icon: SymbolBuffers;\n textCollisionBox: CollisionBuffers;\n iconCollisionBox: CollisionBuffers;\n uploaded: boolean;\n sourceLayerIndex: number;\n sourceID: string;\n symbolInstanceIndexes: Array;\n writingModes: WritingMode[];\n allowVerticalPlacement: boolean;\n hasRTLText: boolean;\n\n constructor(options: BucketParameters) {\n this.collisionBoxArray = options.collisionBoxArray;\n this.zoom = options.zoom;\n this.overscaling = options.overscaling;\n this.layers = options.layers;\n this.layerIds = this.layers.map(layer => layer.id);\n this.index = options.index;\n this.pixelRatio = options.pixelRatio;\n this.sourceLayerIndex = options.sourceLayerIndex;\n this.hasPattern = false;\n this.hasRTLText = false;\n this.sortKeyRanges = [];\n\n this.collisionCircleArray = [];\n this.placementInvProjMatrix = mat4.identity([] as any);\n this.placementViewportMatrix = mat4.identity([] as any);\n\n const layer = this.layers[0];\n const unevaluatedLayoutValues = layer._unevaluatedLayout._values;\n\n this.textSizeData = getSizeData(this.zoom, unevaluatedLayoutValues['text-size']);\n this.iconSizeData = getSizeData(this.zoom, unevaluatedLayoutValues['icon-size']);\n\n const layout = this.layers[0].layout;\n const sortKey = layout.get('symbol-sort-key');\n const zOrder = layout.get('symbol-z-order');\n this.canOverlap =\n getOverlapMode(layout, 'text-overlap', 'text-allow-overlap') !== 'never' ||\n getOverlapMode(layout, 'icon-overlap', 'icon-allow-overlap') !== 'never' ||\n layout.get('text-ignore-placement') ||\n layout.get('icon-ignore-placement');\n this.sortFeaturesByKey = zOrder !== 'viewport-y' && !sortKey.isConstant();\n const zOrderByViewportY = zOrder === 'viewport-y' || (zOrder === 'auto' && !this.sortFeaturesByKey);\n this.sortFeaturesByY = zOrderByViewportY && this.canOverlap;\n\n if (layout.get('symbol-placement') === 'point') {\n this.writingModes = layout.get('text-writing-mode').map(wm => WritingMode[wm]);\n }\n\n this.stateDependentLayerIds = this.layers.filter((l) => l.isStateDependent()).map((l) => l.id);\n\n this.sourceID = options.sourceID;\n }\n\n createArrays() {\n this.text = new SymbolBuffers(new ProgramConfigurationSet(this.layers, this.zoom, property => /^text/.test(property)));\n this.icon = new SymbolBuffers(new ProgramConfigurationSet(this.layers, this.zoom, property => /^icon/.test(property)));\n\n this.glyphOffsetArray = new GlyphOffsetArray();\n this.lineVertexArray = new SymbolLineVertexArray();\n this.symbolInstances = new SymbolInstanceArray();\n this.textAnchorOffsets = new TextAnchorOffsetArray();\n }\n\n private calculateGlyphDependencies(\n text: string,\n stack: {[_: number]: boolean},\n textAlongLine: boolean,\n allowVerticalPlacement: boolean,\n doesAllowVerticalWritingMode: boolean) {\n\n for (let i = 0; i < text.length; i++) {\n stack[text.charCodeAt(i)] = true;\n if ((textAlongLine || allowVerticalPlacement) && doesAllowVerticalWritingMode) {\n const verticalChar = verticalizedCharacterMap[text.charAt(i)];\n if (verticalChar) {\n stack[verticalChar.charCodeAt(0)] = true;\n }\n }\n }\n }\n\n populate(features: Array, options: PopulateParameters, canonical: CanonicalTileID) {\n const layer = this.layers[0];\n const layout = layer.layout;\n\n const textFont = layout.get('text-font');\n const textField = layout.get('text-field');\n const iconImage = layout.get('icon-image');\n const hasText =\n (textField.value.kind !== 'constant' ||\n (textField.value.value instanceof Formatted && !textField.value.value.isEmpty()) ||\n textField.value.value.toString().length > 0) &&\n (textFont.value.kind !== 'constant' || textFont.value.value.length > 0);\n // we should always resolve the icon-image value if the property was defined in the style\n // this allows us to fire the styleimagemissing event if image evaluation returns null\n // the only way to distinguish between null returned from a coalesce statement with no valid images\n // and null returned because icon-image wasn't defined is to check whether or not iconImage.parameters is an empty object\n const hasIcon = iconImage.value.kind !== 'constant' || !!iconImage.value.value || Object.keys(iconImage.parameters).length > 0;\n const symbolSortKey = layout.get('symbol-sort-key');\n\n this.features = [];\n\n if (!hasText && !hasIcon) {\n return;\n }\n\n const icons = options.iconDependencies;\n const stacks = options.glyphDependencies;\n const availableImages = options.availableImages;\n const globalProperties = new EvaluationParameters(this.zoom);\n\n for (const {feature, id, index, sourceLayerIndex} of features) {\n\n const needGeometry = layer._featureFilter.needGeometry;\n const evaluationFeature = toEvaluationFeature(feature, needGeometry);\n if (!layer._featureFilter.filter(globalProperties, evaluationFeature, canonical)) {\n continue;\n }\n\n if (!needGeometry) evaluationFeature.geometry = loadGeometry(feature);\n\n let text: Formatted | void;\n if (hasText) {\n // Expression evaluation will automatically coerce to Formatted\n // but plain string token evaluation skips that pathway so do the\n // conversion here.\n const resolvedTokens = layer.getValueAndResolveTokens('text-field', evaluationFeature, canonical, availableImages);\n const formattedText = Formatted.factory(resolvedTokens);\n\n // on this instance: if hasRTLText is already true, all future calls to containsRTLText can be skipped.\n const bucketHasRTLText = this.hasRTLText = (this.hasRTLText || containsRTLText(formattedText));\n if (\n !bucketHasRTLText || // non-rtl text so can proceed safely\n rtlWorkerPlugin.getRTLTextPluginStatus() === 'unavailable' || // We don't intend to lazy-load the rtl text plugin, so proceed with incorrect shaping\n bucketHasRTLText && rtlWorkerPlugin.isParsed() // Use the rtlText plugin to shape text\n ) {\n text = transformText(formattedText, layer, evaluationFeature);\n }\n }\n\n let icon: ResolvedImage;\n if (hasIcon) {\n // Expression evaluation will automatically coerce to Image\n // but plain string token evaluation skips that pathway so do the\n // conversion here.\n const resolvedTokens = layer.getValueAndResolveTokens('icon-image', evaluationFeature, canonical, availableImages);\n if (resolvedTokens instanceof ResolvedImage) {\n icon = resolvedTokens;\n } else {\n icon = ResolvedImage.fromString(resolvedTokens);\n }\n }\n\n if (!text && !icon) {\n continue;\n }\n const sortKey = this.sortFeaturesByKey ?\n symbolSortKey.evaluate(evaluationFeature, {}, canonical) :\n undefined;\n\n const symbolFeature: SymbolFeature = {\n id,\n text,\n icon,\n index,\n sourceLayerIndex,\n geometry: evaluationFeature.geometry,\n properties: feature.properties,\n type: vectorTileFeatureTypes[feature.type],\n sortKey\n };\n this.features.push(symbolFeature);\n\n if (icon) {\n icons[icon.name] = true;\n }\n\n if (text) {\n const fontStack = textFont.evaluate(evaluationFeature, {}, canonical).join(',');\n const textAlongLine = layout.get('text-rotation-alignment') !== 'viewport' && layout.get('symbol-placement') !== 'point';\n this.allowVerticalPlacement = this.writingModes && this.writingModes.indexOf(WritingMode.vertical) >= 0;\n for (const section of text.sections) {\n if (!section.image) {\n const doesAllowVerticalWritingMode = allowsVerticalWritingMode(text.toString());\n const sectionFont = section.fontStack || fontStack;\n const sectionStack = stacks[sectionFont] = stacks[sectionFont] || {};\n this.calculateGlyphDependencies(section.text, sectionStack, textAlongLine, this.allowVerticalPlacement, doesAllowVerticalWritingMode);\n } else {\n // Add section image to the list of dependencies.\n icons[section.image.name] = true;\n }\n }\n }\n }\n\n if (layout.get('symbol-placement') === 'line') {\n // Merge adjacent lines with the same text to improve labelling.\n // It's better to place labels on one long line than on many short segments.\n this.features = mergeLines(this.features);\n }\n\n if (this.sortFeaturesByKey) {\n this.features.sort((a, b) => {\n // a.sortKey is always a number when sortFeaturesByKey is true\n return (a.sortKey as number) - (b.sortKey as number);\n });\n }\n }\n\n update(states: FeatureStates, vtLayer: VectorTileLayer, imagePositions: {[_: string]: ImagePosition}) {\n if (!this.stateDependentLayers.length) return;\n this.text.programConfigurations.updatePaintArrays(states, vtLayer, this.layers, imagePositions);\n this.icon.programConfigurations.updatePaintArrays(states, vtLayer, this.layers, imagePositions);\n }\n\n isEmpty() {\n // When the bucket encounters only rtl-text but the plugin isn't loaded, no symbol instances will be created.\n // In order for the bucket to be serialized, and not discarded as an empty bucket both checks are necessary.\n return this.symbolInstances.length === 0 && !this.hasRTLText;\n }\n\n uploadPending() {\n return !this.uploaded || this.text.programConfigurations.needsUpload || this.icon.programConfigurations.needsUpload;\n }\n\n upload(context: Context) {\n if (!this.uploaded && this.hasDebugData()) {\n this.textCollisionBox.upload(context);\n this.iconCollisionBox.upload(context);\n }\n this.text.upload(context, this.sortFeaturesByY, !this.uploaded, this.text.programConfigurations.needsUpload);\n this.icon.upload(context, this.sortFeaturesByY, !this.uploaded, this.icon.programConfigurations.needsUpload);\n this.uploaded = true;\n }\n\n destroyDebugData() {\n this.textCollisionBox.destroy();\n this.iconCollisionBox.destroy();\n }\n\n destroy() {\n this.text.destroy();\n this.icon.destroy();\n\n if (this.hasDebugData()) {\n this.destroyDebugData();\n }\n }\n\n addToLineVertexArray(anchor: Anchor, line: any) {\n const lineStartIndex = this.lineVertexArray.length;\n if (anchor.segment !== undefined) {\n let sumForwardLength = anchor.dist(line[anchor.segment + 1]);\n let sumBackwardLength = anchor.dist(line[anchor.segment]);\n const vertices = {};\n for (let i = anchor.segment + 1; i < line.length; i++) {\n vertices[i] = {x: line[i].x, y: line[i].y, tileUnitDistanceFromAnchor: sumForwardLength};\n if (i < line.length - 1) {\n sumForwardLength += line[i + 1].dist(line[i]);\n }\n }\n for (let i = anchor.segment || 0; i >= 0; i--) {\n vertices[i] = {x: line[i].x, y: line[i].y, tileUnitDistanceFromAnchor: sumBackwardLength};\n if (i > 0) {\n sumBackwardLength += line[i - 1].dist(line[i]);\n }\n }\n for (let i = 0; i < line.length; i++) {\n const vertex = vertices[i];\n this.lineVertexArray.emplaceBack(vertex.x, vertex.y, vertex.tileUnitDistanceFromAnchor);\n }\n }\n return {\n lineStartIndex,\n lineLength: this.lineVertexArray.length - lineStartIndex\n };\n }\n\n addSymbols(arrays: SymbolBuffers,\n quads: Array,\n sizeVertex: any,\n lineOffset: [number, number],\n alongLine: boolean,\n feature: SymbolFeature,\n writingMode: WritingMode,\n labelAnchor: Anchor,\n lineStartIndex: number,\n lineLength: number,\n associatedIconIndex: number,\n canonical: CanonicalTileID) {\n const indexArray = arrays.indexArray;\n const layoutVertexArray = arrays.layoutVertexArray;\n\n const segment = arrays.segments.prepareSegment(4 * quads.length, layoutVertexArray, indexArray, this.canOverlap ? feature.sortKey as number : undefined);\n const glyphOffsetArrayStart = this.glyphOffsetArray.length;\n const vertexStartIndex = segment.vertexLength;\n\n const angle = (this.allowVerticalPlacement && writingMode === WritingMode.vertical) ? Math.PI / 2 : 0;\n\n const sections = feature.text && feature.text.sections;\n\n for (let i = 0; i < quads.length; i++) {\n const {tl, tr, bl, br, tex, pixelOffsetTL, pixelOffsetBR, minFontScaleX, minFontScaleY, glyphOffset, isSDF, sectionIndex} = quads[i];\n const index = segment.vertexLength;\n\n const y = glyphOffset[1];\n addVertex(layoutVertexArray, labelAnchor.x, labelAnchor.y, tl.x, y + tl.y, tex.x, tex.y, sizeVertex, isSDF, pixelOffsetTL.x, pixelOffsetTL.y, minFontScaleX, minFontScaleY);\n addVertex(layoutVertexArray, labelAnchor.x, labelAnchor.y, tr.x, y + tr.y, tex.x + tex.w, tex.y, sizeVertex, isSDF, pixelOffsetBR.x, pixelOffsetTL.y, minFontScaleX, minFontScaleY);\n addVertex(layoutVertexArray, labelAnchor.x, labelAnchor.y, bl.x, y + bl.y, tex.x, tex.y + tex.h, sizeVertex, isSDF, pixelOffsetTL.x, pixelOffsetBR.y, minFontScaleX, minFontScaleY);\n addVertex(layoutVertexArray, labelAnchor.x, labelAnchor.y, br.x, y + br.y, tex.x + tex.w, tex.y + tex.h, sizeVertex, isSDF, pixelOffsetBR.x, pixelOffsetBR.y, minFontScaleX, minFontScaleY);\n\n addDynamicAttributes(arrays.dynamicLayoutVertexArray, labelAnchor, angle);\n\n indexArray.emplaceBack(index, index + 1, index + 2);\n indexArray.emplaceBack(index + 1, index + 2, index + 3);\n\n segment.vertexLength += 4;\n segment.primitiveLength += 2;\n\n this.glyphOffsetArray.emplaceBack(glyphOffset[0]);\n\n if (i === quads.length - 1 || sectionIndex !== quads[i + 1].sectionIndex) {\n arrays.programConfigurations.populatePaintArrays(layoutVertexArray.length, feature, feature.index, {}, canonical, sections && sections[sectionIndex]);\n }\n }\n\n arrays.placedSymbolArray.emplaceBack(\n labelAnchor.x, labelAnchor.y,\n glyphOffsetArrayStart,\n this.glyphOffsetArray.length - glyphOffsetArrayStart,\n vertexStartIndex,\n lineStartIndex,\n lineLength,\n labelAnchor.segment,\n sizeVertex ? sizeVertex[0] : 0,\n sizeVertex ? sizeVertex[1] : 0,\n lineOffset[0], lineOffset[1],\n writingMode,\n // placedOrientation is null initially; will be updated to horizontal(1)/vertical(2) if placed\n 0,\n false as unknown as number,\n // The crossTileID is only filled/used on the foreground for dynamic text anchors\n 0,\n associatedIconIndex\n );\n }\n\n _addCollisionDebugVertex(layoutVertexArray: StructArray, collisionVertexArray: StructArray, point: Point, anchorX: number, anchorY: number, extrude: Point) {\n collisionVertexArray.emplaceBack(0, 0);\n return layoutVertexArray.emplaceBack(\n // pos\n point.x,\n point.y,\n // a_anchor_pos\n anchorX,\n anchorY,\n // extrude\n Math.round(extrude.x),\n Math.round(extrude.y));\n }\n\n addCollisionDebugVertices(x1: number, y1: number, x2: number, y2: number, arrays: CollisionBuffers, boxAnchorPoint: Point, symbolInstance: SymbolInstance) {\n const segment = arrays.segments.prepareSegment(4, arrays.layoutVertexArray, arrays.indexArray);\n const index = segment.vertexLength;\n\n const layoutVertexArray = arrays.layoutVertexArray;\n const collisionVertexArray = arrays.collisionVertexArray;\n\n const anchorX = symbolInstance.anchorX;\n const anchorY = symbolInstance.anchorY;\n\n this._addCollisionDebugVertex(layoutVertexArray, collisionVertexArray, boxAnchorPoint, anchorX, anchorY, new Point(x1, y1));\n this._addCollisionDebugVertex(layoutVertexArray, collisionVertexArray, boxAnchorPoint, anchorX, anchorY, new Point(x2, y1));\n this._addCollisionDebugVertex(layoutVertexArray, collisionVertexArray, boxAnchorPoint, anchorX, anchorY, new Point(x2, y2));\n this._addCollisionDebugVertex(layoutVertexArray, collisionVertexArray, boxAnchorPoint, anchorX, anchorY, new Point(x1, y2));\n\n segment.vertexLength += 4;\n\n const indexArray = arrays.indexArray as LineIndexArray;\n indexArray.emplaceBack(index, index + 1);\n indexArray.emplaceBack(index + 1, index + 2);\n indexArray.emplaceBack(index + 2, index + 3);\n indexArray.emplaceBack(index + 3, index);\n\n segment.primitiveLength += 4;\n }\n\n addDebugCollisionBoxes(startIndex: number, endIndex: number, symbolInstance: SymbolInstance, isText: boolean) {\n for (let b = startIndex; b < endIndex; b++) {\n const box: CollisionBox = this.collisionBoxArray.get(b);\n const x1 = box.x1;\n const y1 = box.y1;\n const x2 = box.x2;\n const y2 = box.y2;\n\n this.addCollisionDebugVertices(x1, y1, x2, y2,\n isText ? this.textCollisionBox : this.iconCollisionBox,\n box.anchorPoint, symbolInstance);\n }\n }\n\n generateCollisionDebugBuffers() {\n if (this.hasDebugData()) {\n this.destroyDebugData();\n }\n\n this.textCollisionBox = new CollisionBuffers(CollisionBoxLayoutArray, collisionBoxLayout.members, LineIndexArray);\n this.iconCollisionBox = new CollisionBuffers(CollisionBoxLayoutArray, collisionBoxLayout.members, LineIndexArray);\n\n for (let i = 0; i < this.symbolInstances.length; i++) {\n const symbolInstance = this.symbolInstances.get(i);\n this.addDebugCollisionBoxes(symbolInstance.textBoxStartIndex, symbolInstance.textBoxEndIndex, symbolInstance, true);\n this.addDebugCollisionBoxes(symbolInstance.verticalTextBoxStartIndex, symbolInstance.verticalTextBoxEndIndex, symbolInstance, true);\n this.addDebugCollisionBoxes(symbolInstance.iconBoxStartIndex, symbolInstance.iconBoxEndIndex, symbolInstance, false);\n this.addDebugCollisionBoxes(symbolInstance.verticalIconBoxStartIndex, symbolInstance.verticalIconBoxEndIndex, symbolInstance, false);\n }\n }\n\n // These flat arrays are meant to be quicker to iterate over than the source\n // CollisionBoxArray\n _deserializeCollisionBoxesForSymbol(\n collisionBoxArray: CollisionBoxArray,\n textStartIndex: number,\n textEndIndex: number,\n verticalTextStartIndex: number,\n verticalTextEndIndex: number,\n iconStartIndex: number,\n iconEndIndex: number,\n verticalIconStartIndex: number,\n verticalIconEndIndex: number\n ): CollisionArrays {\n\n const collisionArrays = {} as CollisionArrays;\n for (let k = textStartIndex; k < textEndIndex; k++) {\n const box: CollisionBox = collisionBoxArray.get(k);\n collisionArrays.textBox = {x1: box.x1, y1: box.y1, x2: box.x2, y2: box.y2, anchorPointX: box.anchorPointX, anchorPointY: box.anchorPointY};\n collisionArrays.textFeatureIndex = box.featureIndex;\n break; // Only one box allowed per instance\n }\n for (let k = verticalTextStartIndex; k < verticalTextEndIndex; k++) {\n const box: CollisionBox = collisionBoxArray.get(k);\n collisionArrays.verticalTextBox = {x1: box.x1, y1: box.y1, x2: box.x2, y2: box.y2, anchorPointX: box.anchorPointX, anchorPointY: box.anchorPointY};\n collisionArrays.verticalTextFeatureIndex = box.featureIndex;\n break; // Only one box allowed per instance\n }\n for (let k = iconStartIndex; k < iconEndIndex; k++) {\n // An icon can only have one box now, so this indexing is a bit vestigial...\n const box: CollisionBox = collisionBoxArray.get(k);\n collisionArrays.iconBox = {x1: box.x1, y1: box.y1, x2: box.x2, y2: box.y2, anchorPointX: box.anchorPointX, anchorPointY: box.anchorPointY};\n collisionArrays.iconFeatureIndex = box.featureIndex;\n break; // Only one box allowed per instance\n }\n for (let k = verticalIconStartIndex; k < verticalIconEndIndex; k++) {\n // An icon can only have one box now, so this indexing is a bit vestigial...\n const box: CollisionBox = collisionBoxArray.get(k);\n collisionArrays.verticalIconBox = {x1: box.x1, y1: box.y1, x2: box.x2, y2: box.y2, anchorPointX: box.anchorPointX, anchorPointY: box.anchorPointY};\n collisionArrays.verticalIconFeatureIndex = box.featureIndex;\n break; // Only one box allowed per instance\n }\n return collisionArrays;\n }\n\n deserializeCollisionBoxes(collisionBoxArray: CollisionBoxArray) {\n this.collisionArrays = [];\n for (let i = 0; i < this.symbolInstances.length; i++) {\n const symbolInstance = this.symbolInstances.get(i);\n this.collisionArrays.push(this._deserializeCollisionBoxesForSymbol(\n collisionBoxArray,\n symbolInstance.textBoxStartIndex,\n symbolInstance.textBoxEndIndex,\n symbolInstance.verticalTextBoxStartIndex,\n symbolInstance.verticalTextBoxEndIndex,\n symbolInstance.iconBoxStartIndex,\n symbolInstance.iconBoxEndIndex,\n symbolInstance.verticalIconBoxStartIndex,\n symbolInstance.verticalIconBoxEndIndex\n ));\n }\n }\n\n hasTextData() {\n return this.text.segments.get().length > 0;\n }\n\n hasIconData() {\n return this.icon.segments.get().length > 0;\n }\n\n hasDebugData() {\n return this.textCollisionBox && this.iconCollisionBox;\n }\n\n hasTextCollisionBoxData() {\n return this.hasDebugData() && this.textCollisionBox.segments.get().length > 0;\n }\n\n hasIconCollisionBoxData() {\n return this.hasDebugData() && this.iconCollisionBox.segments.get().length > 0;\n }\n\n addIndicesForPlacedSymbol(iconOrText: SymbolBuffers, placedSymbolIndex: number) {\n const placedSymbol = iconOrText.placedSymbolArray.get(placedSymbolIndex);\n\n const endIndex = placedSymbol.vertexStartIndex + placedSymbol.numGlyphs * 4;\n for (let vertexIndex = placedSymbol.vertexStartIndex; vertexIndex < endIndex; vertexIndex += 4) {\n iconOrText.indexArray.emplaceBack(vertexIndex, vertexIndex + 1, vertexIndex + 2);\n iconOrText.indexArray.emplaceBack(vertexIndex + 1, vertexIndex + 2, vertexIndex + 3);\n }\n }\n\n getSortedSymbolIndexes(angle: number) {\n if (this.sortedAngle === angle && this.symbolInstanceIndexes !== undefined) {\n return this.symbolInstanceIndexes;\n }\n const sin = Math.sin(angle);\n const cos = Math.cos(angle);\n const rotatedYs = [];\n const featureIndexes = [];\n const result = [];\n\n for (let i = 0; i < this.symbolInstances.length; ++i) {\n result.push(i);\n const symbolInstance = this.symbolInstances.get(i);\n rotatedYs.push(Math.round(sin * symbolInstance.anchorX + cos * symbolInstance.anchorY) | 0);\n featureIndexes.push(symbolInstance.featureIndex);\n }\n\n result.sort((aIndex, bIndex) => {\n return (rotatedYs[aIndex] - rotatedYs[bIndex]) ||\n (featureIndexes[bIndex] - featureIndexes[aIndex]);\n });\n\n return result;\n }\n\n addToSortKeyRanges(symbolInstanceIndex: number, sortKey: number) {\n const last = this.sortKeyRanges[this.sortKeyRanges.length - 1];\n if (last && last.sortKey === sortKey) {\n last.symbolInstanceEnd = symbolInstanceIndex + 1;\n } else {\n this.sortKeyRanges.push({\n sortKey,\n symbolInstanceStart: symbolInstanceIndex,\n symbolInstanceEnd: symbolInstanceIndex + 1\n });\n }\n }\n\n sortFeatures(angle: number) {\n if (!this.sortFeaturesByY) return;\n if (this.sortedAngle === angle) return;\n\n // The current approach to sorting doesn't sort across segments so don't try.\n // Sorting within segments separately seemed not to be worth the complexity.\n if (this.text.segments.get().length > 1 || this.icon.segments.get().length > 1) return;\n\n // If the symbols are allowed to overlap sort them by their vertical screen position.\n // The index array buffer is rewritten to reference the (unchanged) vertices in the\n // sorted order.\n\n // To avoid sorting the actual symbolInstance array we sort an array of indexes.\n this.symbolInstanceIndexes = this.getSortedSymbolIndexes(angle);\n this.sortedAngle = angle;\n\n this.text.indexArray.clear();\n this.icon.indexArray.clear();\n\n this.featureSortOrder = [];\n\n for (const i of this.symbolInstanceIndexes) {\n const symbolInstance = this.symbolInstances.get(i);\n this.featureSortOrder.push(symbolInstance.featureIndex);\n\n [\n symbolInstance.rightJustifiedTextSymbolIndex,\n symbolInstance.centerJustifiedTextSymbolIndex,\n symbolInstance.leftJustifiedTextSymbolIndex\n ].forEach((index, i, array) => {\n // Only add a given index the first time it shows up,\n // to avoid duplicate opacity entries when multiple justifications\n // share the same glyphs.\n if (index >= 0 && array.indexOf(index) === i) {\n this.addIndicesForPlacedSymbol(this.text, index);\n }\n });\n\n if (symbolInstance.verticalPlacedTextSymbolIndex >= 0) {\n this.addIndicesForPlacedSymbol(this.text, symbolInstance.verticalPlacedTextSymbolIndex);\n }\n\n if (symbolInstance.placedIconSymbolIndex >= 0) {\n this.addIndicesForPlacedSymbol(this.icon, symbolInstance.placedIconSymbolIndex);\n }\n\n if (symbolInstance.verticalPlacedIconSymbolIndex >= 0) {\n this.addIndicesForPlacedSymbol(this.icon, symbolInstance.verticalPlacedIconSymbolIndex);\n }\n }\n\n if (this.text.indexBuffer) this.text.indexBuffer.updateData(this.text.indexArray);\n if (this.icon.indexBuffer) this.icon.indexBuffer.updateData(this.icon.indexArray);\n }\n}\n\nregister('SymbolBucket', SymbolBucket, {\n omit: ['layers', 'collisionBoxArray', 'features', 'compareText']\n});\n\n// this constant is based on the size of StructArray indexes used in a symbol\n// bucket--namely, glyphOffsetArrayStart\n// eg the max valid UInt16 is 65,535\n// See https://github.com/mapbox/mapbox-gl-js/issues/2907 for motivation\n// lineStartIndex and textBoxStartIndex could potentially be concerns\n// but we expect there to be many fewer boxes/lines than glyphs\nSymbolBucket.MAX_GLYPHS = 65535;\n\nSymbolBucket.addDynamicAttributes = addDynamicAttributes;\n\nexport {addDynamicAttributes};\n","/**\n * Replace tokens in a string template with values in an object\n *\n * @param properties - a key/value relationship between tokens and replacements\n * @param text - the template string\n * @returns the template with tokens replaced\n */\nexport function resolveTokens(\n properties: {\n readonly [x: string]: unknown;\n } | null,\n text: string\n): string {\n return text.replace(/{([^{}]+)}/g, (match, key: string) => {\n return properties && key in properties ? String(properties[key]) : '';\n });\n}\n","// This file is generated. Edit build/generate-style-code.ts, then run 'npm run codegen'.\n/* eslint-disable */\n\nimport {latest as styleSpec} from '@maplibre/maplibre-gl-style-spec';\n\nimport {\n Properties,\n DataConstantProperty,\n DataDrivenProperty,\n CrossFadedDataDrivenProperty,\n CrossFadedProperty,\n ColorRampProperty,\n PossiblyEvaluatedPropertyValue,\n CrossFaded\n} from '../properties';\n\nimport type {Color, Formatted, Padding, ResolvedImage, VariableAnchorOffsetCollection} from '@maplibre/maplibre-gl-style-spec';\nimport {StylePropertySpecification} from '@maplibre/maplibre-gl-style-spec';\n\nimport {\n ColorType\n } from '@maplibre/maplibre-gl-style-spec';\n \nexport type SymbolLayoutProps = {\n \"symbol-placement\": DataConstantProperty<\"point\" | \"line\" | \"line-center\">,\n \"symbol-spacing\": DataConstantProperty,\n \"symbol-avoid-edges\": DataConstantProperty,\n \"symbol-sort-key\": DataDrivenProperty,\n \"symbol-z-order\": DataConstantProperty<\"auto\" | \"viewport-y\" | \"source\">,\n \"icon-allow-overlap\": DataConstantProperty,\n \"icon-overlap\": DataConstantProperty<\"never\" | \"always\" | \"cooperative\">,\n \"icon-ignore-placement\": DataConstantProperty,\n \"icon-optional\": DataConstantProperty,\n \"icon-rotation-alignment\": DataConstantProperty<\"map\" | \"viewport\" | \"auto\">,\n \"icon-size\": DataDrivenProperty,\n \"icon-text-fit\": DataConstantProperty<\"none\" | \"width\" | \"height\" | \"both\">,\n \"icon-text-fit-padding\": DataConstantProperty<[number, number, number, number]>,\n \"icon-image\": DataDrivenProperty,\n \"icon-rotate\": DataDrivenProperty,\n \"icon-padding\": DataDrivenProperty,\n \"icon-keep-upright\": DataConstantProperty,\n \"icon-offset\": DataDrivenProperty<[number, number]>,\n \"icon-anchor\": DataDrivenProperty<\"center\" | \"left\" | \"right\" | \"top\" | \"bottom\" | \"top-left\" | \"top-right\" | \"bottom-left\" | \"bottom-right\">,\n \"icon-pitch-alignment\": DataConstantProperty<\"map\" | \"viewport\" | \"auto\">,\n \"text-pitch-alignment\": DataConstantProperty<\"map\" | \"viewport\" | \"auto\">,\n \"text-rotation-alignment\": DataConstantProperty<\"map\" | \"viewport\" | \"viewport-glyph\" | \"auto\">,\n \"text-field\": DataDrivenProperty,\n \"text-font\": DataDrivenProperty>,\n \"text-size\": DataDrivenProperty,\n \"text-max-width\": DataDrivenProperty,\n \"text-line-height\": DataConstantProperty,\n \"text-letter-spacing\": DataDrivenProperty,\n \"text-justify\": DataDrivenProperty<\"auto\" | \"left\" | \"center\" | \"right\">,\n \"text-radial-offset\": DataDrivenProperty,\n \"text-variable-anchor\": DataConstantProperty>,\n \"text-variable-anchor-offset\": DataDrivenProperty,\n \"text-anchor\": DataDrivenProperty<\"center\" | \"left\" | \"right\" | \"top\" | \"bottom\" | \"top-left\" | \"top-right\" | \"bottom-left\" | \"bottom-right\">,\n \"text-max-angle\": DataConstantProperty,\n \"text-writing-mode\": DataConstantProperty>,\n \"text-rotate\": DataDrivenProperty,\n \"text-padding\": DataConstantProperty,\n \"text-keep-upright\": DataConstantProperty,\n \"text-transform\": DataDrivenProperty<\"none\" | \"uppercase\" | \"lowercase\">,\n \"text-offset\": DataDrivenProperty<[number, number]>,\n \"text-allow-overlap\": DataConstantProperty,\n \"text-overlap\": DataConstantProperty<\"never\" | \"always\" | \"cooperative\">,\n \"text-ignore-placement\": DataConstantProperty,\n \"text-optional\": DataConstantProperty,\n};\n\nexport type SymbolLayoutPropsPossiblyEvaluated = {\n \"symbol-placement\": \"point\" | \"line\" | \"line-center\",\n \"symbol-spacing\": number,\n \"symbol-avoid-edges\": boolean,\n \"symbol-sort-key\": PossiblyEvaluatedPropertyValue,\n \"symbol-z-order\": \"auto\" | \"viewport-y\" | \"source\",\n \"icon-allow-overlap\": boolean,\n \"icon-overlap\": \"never\" | \"always\" | \"cooperative\",\n \"icon-ignore-placement\": boolean,\n \"icon-optional\": boolean,\n \"icon-rotation-alignment\": \"map\" | \"viewport\" | \"auto\",\n \"icon-size\": PossiblyEvaluatedPropertyValue,\n \"icon-text-fit\": \"none\" | \"width\" | \"height\" | \"both\",\n \"icon-text-fit-padding\": [number, number, number, number],\n \"icon-image\": PossiblyEvaluatedPropertyValue,\n \"icon-rotate\": PossiblyEvaluatedPropertyValue,\n \"icon-padding\": PossiblyEvaluatedPropertyValue,\n \"icon-keep-upright\": boolean,\n \"icon-offset\": PossiblyEvaluatedPropertyValue<[number, number]>,\n \"icon-anchor\": PossiblyEvaluatedPropertyValue<\"center\" | \"left\" | \"right\" | \"top\" | \"bottom\" | \"top-left\" | \"top-right\" | \"bottom-left\" | \"bottom-right\">,\n \"icon-pitch-alignment\": \"map\" | \"viewport\" | \"auto\",\n \"text-pitch-alignment\": \"map\" | \"viewport\" | \"auto\",\n \"text-rotation-alignment\": \"map\" | \"viewport\" | \"viewport-glyph\" | \"auto\",\n \"text-field\": PossiblyEvaluatedPropertyValue,\n \"text-font\": PossiblyEvaluatedPropertyValue>,\n \"text-size\": PossiblyEvaluatedPropertyValue,\n \"text-max-width\": PossiblyEvaluatedPropertyValue,\n \"text-line-height\": number,\n \"text-letter-spacing\": PossiblyEvaluatedPropertyValue,\n \"text-justify\": PossiblyEvaluatedPropertyValue<\"auto\" | \"left\" | \"center\" | \"right\">,\n \"text-radial-offset\": PossiblyEvaluatedPropertyValue,\n \"text-variable-anchor\": Array<\"center\" | \"left\" | \"right\" | \"top\" | \"bottom\" | \"top-left\" | \"top-right\" | \"bottom-left\" | \"bottom-right\">,\n \"text-variable-anchor-offset\": PossiblyEvaluatedPropertyValue,\n \"text-anchor\": PossiblyEvaluatedPropertyValue<\"center\" | \"left\" | \"right\" | \"top\" | \"bottom\" | \"top-left\" | \"top-right\" | \"bottom-left\" | \"bottom-right\">,\n \"text-max-angle\": number,\n \"text-writing-mode\": Array<\"horizontal\" | \"vertical\">,\n \"text-rotate\": PossiblyEvaluatedPropertyValue,\n \"text-padding\": number,\n \"text-keep-upright\": boolean,\n \"text-transform\": PossiblyEvaluatedPropertyValue<\"none\" | \"uppercase\" | \"lowercase\">,\n \"text-offset\": PossiblyEvaluatedPropertyValue<[number, number]>,\n \"text-allow-overlap\": boolean,\n \"text-overlap\": \"never\" | \"always\" | \"cooperative\",\n \"text-ignore-placement\": boolean,\n \"text-optional\": boolean,\n};\n\nlet layout: Properties;\nconst getLayout = () => layout = layout || new Properties({\n \"symbol-placement\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"symbol-placement\"] as any as StylePropertySpecification),\n \"symbol-spacing\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"symbol-spacing\"] as any as StylePropertySpecification),\n \"symbol-avoid-edges\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"symbol-avoid-edges\"] as any as StylePropertySpecification),\n \"symbol-sort-key\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"symbol-sort-key\"] as any as StylePropertySpecification),\n \"symbol-z-order\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"symbol-z-order\"] as any as StylePropertySpecification),\n \"icon-allow-overlap\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"icon-allow-overlap\"] as any as StylePropertySpecification),\n \"icon-overlap\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"icon-overlap\"] as any as StylePropertySpecification),\n \"icon-ignore-placement\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"icon-ignore-placement\"] as any as StylePropertySpecification),\n \"icon-optional\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"icon-optional\"] as any as StylePropertySpecification),\n \"icon-rotation-alignment\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"icon-rotation-alignment\"] as any as StylePropertySpecification),\n \"icon-size\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"icon-size\"] as any as StylePropertySpecification),\n \"icon-text-fit\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"icon-text-fit\"] as any as StylePropertySpecification),\n \"icon-text-fit-padding\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"icon-text-fit-padding\"] as any as StylePropertySpecification),\n \"icon-image\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"icon-image\"] as any as StylePropertySpecification),\n \"icon-rotate\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"icon-rotate\"] as any as StylePropertySpecification),\n \"icon-padding\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"icon-padding\"] as any as StylePropertySpecification),\n \"icon-keep-upright\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"icon-keep-upright\"] as any as StylePropertySpecification),\n \"icon-offset\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"icon-offset\"] as any as StylePropertySpecification),\n \"icon-anchor\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"icon-anchor\"] as any as StylePropertySpecification),\n \"icon-pitch-alignment\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"icon-pitch-alignment\"] as any as StylePropertySpecification),\n \"text-pitch-alignment\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"text-pitch-alignment\"] as any as StylePropertySpecification),\n \"text-rotation-alignment\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"text-rotation-alignment\"] as any as StylePropertySpecification),\n \"text-field\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"text-field\"] as any as StylePropertySpecification),\n \"text-font\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"text-font\"] as any as StylePropertySpecification),\n \"text-size\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"text-size\"] as any as StylePropertySpecification),\n \"text-max-width\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"text-max-width\"] as any as StylePropertySpecification),\n \"text-line-height\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"text-line-height\"] as any as StylePropertySpecification),\n \"text-letter-spacing\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"text-letter-spacing\"] as any as StylePropertySpecification),\n \"text-justify\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"text-justify\"] as any as StylePropertySpecification),\n \"text-radial-offset\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"text-radial-offset\"] as any as StylePropertySpecification),\n \"text-variable-anchor\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"text-variable-anchor\"] as any as StylePropertySpecification),\n \"text-variable-anchor-offset\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"text-variable-anchor-offset\"] as any as StylePropertySpecification),\n \"text-anchor\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"text-anchor\"] as any as StylePropertySpecification),\n \"text-max-angle\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"text-max-angle\"] as any as StylePropertySpecification),\n \"text-writing-mode\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"text-writing-mode\"] as any as StylePropertySpecification),\n \"text-rotate\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"text-rotate\"] as any as StylePropertySpecification),\n \"text-padding\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"text-padding\"] as any as StylePropertySpecification),\n \"text-keep-upright\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"text-keep-upright\"] as any as StylePropertySpecification),\n \"text-transform\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"text-transform\"] as any as StylePropertySpecification),\n \"text-offset\": new DataDrivenProperty(styleSpec[\"layout_symbol\"][\"text-offset\"] as any as StylePropertySpecification),\n \"text-allow-overlap\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"text-allow-overlap\"] as any as StylePropertySpecification),\n \"text-overlap\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"text-overlap\"] as any as StylePropertySpecification),\n \"text-ignore-placement\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"text-ignore-placement\"] as any as StylePropertySpecification),\n \"text-optional\": new DataConstantProperty(styleSpec[\"layout_symbol\"][\"text-optional\"] as any as StylePropertySpecification),\n});\n\nexport type SymbolPaintProps = {\n \"icon-opacity\": DataDrivenProperty,\n \"icon-color\": DataDrivenProperty,\n \"icon-halo-color\": DataDrivenProperty,\n \"icon-halo-width\": DataDrivenProperty,\n \"icon-halo-blur\": DataDrivenProperty,\n \"icon-translate\": DataConstantProperty<[number, number]>,\n \"icon-translate-anchor\": DataConstantProperty<\"map\" | \"viewport\">,\n \"text-opacity\": DataDrivenProperty,\n \"text-color\": DataDrivenProperty,\n \"text-halo-color\": DataDrivenProperty,\n \"text-halo-width\": DataDrivenProperty,\n \"text-halo-blur\": DataDrivenProperty,\n \"text-translate\": DataConstantProperty<[number, number]>,\n \"text-translate-anchor\": DataConstantProperty<\"map\" | \"viewport\">,\n};\n\nexport type SymbolPaintPropsPossiblyEvaluated = {\n \"icon-opacity\": PossiblyEvaluatedPropertyValue,\n \"icon-color\": PossiblyEvaluatedPropertyValue,\n \"icon-halo-color\": PossiblyEvaluatedPropertyValue,\n \"icon-halo-width\": PossiblyEvaluatedPropertyValue,\n \"icon-halo-blur\": PossiblyEvaluatedPropertyValue,\n \"icon-translate\": [number, number],\n \"icon-translate-anchor\": \"map\" | \"viewport\",\n \"text-opacity\": PossiblyEvaluatedPropertyValue,\n \"text-color\": PossiblyEvaluatedPropertyValue,\n \"text-halo-color\": PossiblyEvaluatedPropertyValue,\n \"text-halo-width\": PossiblyEvaluatedPropertyValue,\n \"text-halo-blur\": PossiblyEvaluatedPropertyValue,\n \"text-translate\": [number, number],\n \"text-translate-anchor\": \"map\" | \"viewport\",\n};\n\nlet paint: Properties;\nconst getPaint = () => paint = paint || new Properties({\n \"icon-opacity\": new DataDrivenProperty(styleSpec[\"paint_symbol\"][\"icon-opacity\"] as any as StylePropertySpecification),\n \"icon-color\": new DataDrivenProperty(styleSpec[\"paint_symbol\"][\"icon-color\"] as any as StylePropertySpecification),\n \"icon-halo-color\": new DataDrivenProperty(styleSpec[\"paint_symbol\"][\"icon-halo-color\"] as any as StylePropertySpecification),\n \"icon-halo-width\": new DataDrivenProperty(styleSpec[\"paint_symbol\"][\"icon-halo-width\"] as any as StylePropertySpecification),\n \"icon-halo-blur\": new DataDrivenProperty(styleSpec[\"paint_symbol\"][\"icon-halo-blur\"] as any as StylePropertySpecification),\n \"icon-translate\": new DataConstantProperty(styleSpec[\"paint_symbol\"][\"icon-translate\"] as any as StylePropertySpecification),\n \"icon-translate-anchor\": new DataConstantProperty(styleSpec[\"paint_symbol\"][\"icon-translate-anchor\"] as any as StylePropertySpecification),\n \"text-opacity\": new DataDrivenProperty(styleSpec[\"paint_symbol\"][\"text-opacity\"] as any as StylePropertySpecification),\n \"text-color\": new DataDrivenProperty(styleSpec[\"paint_symbol\"][\"text-color\"] as any as StylePropertySpecification, { runtimeType: ColorType, getOverride: (o) => o.textColor, hasOverride: (o) => !!o.textColor }),\n \"text-halo-color\": new DataDrivenProperty(styleSpec[\"paint_symbol\"][\"text-halo-color\"] as any as StylePropertySpecification),\n \"text-halo-width\": new DataDrivenProperty(styleSpec[\"paint_symbol\"][\"text-halo-width\"] as any as StylePropertySpecification),\n \"text-halo-blur\": new DataDrivenProperty(styleSpec[\"paint_symbol\"][\"text-halo-blur\"] as any as StylePropertySpecification),\n \"text-translate\": new DataConstantProperty(styleSpec[\"paint_symbol\"][\"text-translate\"] as any as StylePropertySpecification),\n \"text-translate-anchor\": new DataConstantProperty(styleSpec[\"paint_symbol\"][\"text-translate-anchor\"] as any as StylePropertySpecification),\n});\n\nexport default ({ get paint() { return getPaint() }, get layout() { return getLayout() } });","import type {Expression, EvaluationContext, Type, ZoomConstantExpression} from '@maplibre/maplibre-gl-style-spec';\nimport {NullType} from '@maplibre/maplibre-gl-style-spec';\nimport {PossiblyEvaluatedPropertyValue} from './properties';\nimport {register} from '../util/web_worker_transfer';\n\n// This is an internal expression class. It is only used in GL JS and\n// has GL JS dependencies which can break the standalone style-spec module\nexport class FormatSectionOverride implements Expression {\n type: Type;\n defaultValue: PossiblyEvaluatedPropertyValue;\n\n constructor(defaultValue: PossiblyEvaluatedPropertyValue) {\n if (defaultValue.property.overrides === undefined) throw new Error('overrides must be provided to instantiate FormatSectionOverride class');\n this.type = defaultValue.property.overrides ? defaultValue.property.overrides.runtimeType : NullType;\n this.defaultValue = defaultValue;\n }\n\n evaluate(ctx: EvaluationContext) {\n if (ctx.formattedSection) {\n const overrides = this.defaultValue.property.overrides;\n if (overrides && overrides.hasOverride(ctx.formattedSection)) {\n return overrides.getOverride(ctx.formattedSection);\n }\n }\n\n if (ctx.feature && ctx.featureState) {\n return this.defaultValue.evaluate(ctx.feature, ctx.featureState);\n }\n\n return this.defaultValue.property.specification.default;\n }\n\n eachChild(fn: (_: Expression) => void) {\n if (!this.defaultValue.isConstant()) {\n const expr: ZoomConstantExpression<'source'> = (this.defaultValue.value as any);\n fn(expr._styleExpression.expression);\n }\n }\n\n // Cannot be statically evaluated, as the output depends on the evaluation context.\n outputDefined() {\n return false;\n }\n\n serialize() {\n return null;\n }\n}\n\nregister('FormatSectionOverride', FormatSectionOverride, {omit: ['defaultValue']});\n","import {StyleLayer} from '../style_layer';\n\nimport {SymbolBucket, SymbolFeature} from '../../data/bucket/symbol_bucket';\nimport {resolveTokens} from '../../util/resolve_tokens';\nimport properties, {SymbolLayoutPropsPossiblyEvaluated, SymbolPaintPropsPossiblyEvaluated} from './symbol_style_layer_properties.g';\n\nimport {\n Transitionable,\n Transitioning,\n Layout,\n PossiblyEvaluated,\n PossiblyEvaluatedPropertyValue,\n PropertyValue\n} from '../properties';\n\nimport {\n isExpression,\n StyleExpression,\n ZoomConstantExpression,\n ZoomDependentExpression,\n FormattedType,\n typeOf,\n Formatted,\n FormatExpression,\n Literal} from '@maplibre/maplibre-gl-style-spec';\n\nimport type {BucketParameters} from '../../data/bucket';\nimport type {SymbolLayoutProps, SymbolPaintProps} from './symbol_style_layer_properties.g';\nimport type {EvaluationParameters} from '../evaluation_parameters';\nimport type {Expression, Feature, SourceExpression, LayerSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {CanonicalTileID} from '../../source/tile_id';\nimport {FormatSectionOverride} from '../format_section_override';\n\nexport class SymbolStyleLayer extends StyleLayer {\n _unevaluatedLayout: Layout;\n layout: PossiblyEvaluated;\n\n _transitionablePaint: Transitionable;\n _transitioningPaint: Transitioning;\n paint: PossiblyEvaluated;\n\n constructor(layer: LayerSpecification) {\n super(layer, properties);\n }\n\n recalculate(parameters: EvaluationParameters, availableImages: Array) {\n super.recalculate(parameters, availableImages);\n\n if (this.layout.get('icon-rotation-alignment') === 'auto') {\n if (this.layout.get('symbol-placement') !== 'point') {\n this.layout._values['icon-rotation-alignment'] = 'map';\n } else {\n this.layout._values['icon-rotation-alignment'] = 'viewport';\n }\n }\n\n if (this.layout.get('text-rotation-alignment') === 'auto') {\n if (this.layout.get('symbol-placement') !== 'point') {\n this.layout._values['text-rotation-alignment'] = 'map';\n } else {\n this.layout._values['text-rotation-alignment'] = 'viewport';\n }\n }\n\n // If unspecified, `*-pitch-alignment` inherits `*-rotation-alignment`\n if (this.layout.get('text-pitch-alignment') === 'auto') {\n this.layout._values['text-pitch-alignment'] = this.layout.get('text-rotation-alignment') === 'map' ? 'map' : 'viewport';\n }\n if (this.layout.get('icon-pitch-alignment') === 'auto') {\n this.layout._values['icon-pitch-alignment'] = this.layout.get('icon-rotation-alignment');\n }\n\n if (this.layout.get('symbol-placement') === 'point') {\n const writingModes = this.layout.get('text-writing-mode');\n if (writingModes) {\n // remove duplicates, preserving order\n const deduped = [];\n for (const m of writingModes) {\n if (deduped.indexOf(m) < 0) deduped.push(m);\n }\n this.layout._values['text-writing-mode'] = deduped;\n } else {\n this.layout._values['text-writing-mode'] = ['horizontal'];\n }\n }\n\n this._setPaintOverrides();\n }\n\n getValueAndResolveTokens(name: any, feature: Feature, canonical: CanonicalTileID, availableImages: Array) {\n const value = this.layout.get(name).evaluate(feature, {}, canonical, availableImages);\n const unevaluated = this._unevaluatedLayout._values[name];\n if (!unevaluated.isDataDriven() && !isExpression(unevaluated.value) && value) {\n return resolveTokens(feature.properties, value);\n }\n\n return value;\n }\n\n createBucket(parameters: BucketParameters) {\n return new SymbolBucket(parameters);\n }\n\n queryRadius(): number {\n return 0;\n }\n\n queryIntersectsFeature(): boolean {\n throw new Error('Should take a different path in FeatureIndex');\n }\n\n _setPaintOverrides() {\n for (const overridable of properties.paint.overridableProperties) {\n if (!SymbolStyleLayer.hasPaintOverride(this.layout, overridable)) {\n continue;\n }\n const overridden = this.paint.get(overridable as keyof SymbolPaintPropsPossiblyEvaluated) as PossiblyEvaluatedPropertyValue;\n const override = new FormatSectionOverride(overridden);\n const styleExpression = new StyleExpression(override, overridden.property.specification);\n let expression = null;\n if (overridden.value.kind === 'constant' || overridden.value.kind === 'source') {\n expression = new ZoomConstantExpression('source', styleExpression) as SourceExpression;\n } else {\n expression = new ZoomDependentExpression('composite',\n styleExpression,\n overridden.value.zoomStops);\n }\n this.paint._values[overridable] = new PossiblyEvaluatedPropertyValue(overridden.property,\n expression,\n overridden.parameters);\n }\n }\n\n _handleOverridablePaintPropertyUpdate(name: string, oldValue: PropertyValue, newValue: PropertyValue): boolean {\n if (!this.layout || oldValue.isDataDriven() || newValue.isDataDriven()) {\n return false;\n }\n return SymbolStyleLayer.hasPaintOverride(this.layout, name);\n }\n\n static hasPaintOverride(layout: PossiblyEvaluated, propertyName: string): boolean {\n const textField = layout.get('text-field');\n const property = properties.paint.properties[propertyName];\n let hasOverrides = false;\n\n const checkSections = (sections) => {\n for (const section of sections) {\n if (property.overrides && property.overrides.hasOverride(section)) {\n hasOverrides = true;\n return;\n }\n }\n };\n\n if (textField.value.kind === 'constant' && textField.value.value instanceof Formatted) {\n checkSections(textField.value.value.sections);\n } else if (textField.value.kind === 'source') {\n\n const checkExpression = (expression: Expression) => {\n if (hasOverrides) return;\n\n if (expression instanceof Literal && typeOf(expression.value) === FormattedType) {\n const formatted: Formatted = (expression.value as any);\n checkSections(formatted.sections);\n } else if (expression instanceof FormatExpression) {\n checkSections(expression.sections);\n } else {\n expression.eachChild(checkExpression);\n }\n };\n\n const expr: ZoomConstantExpression<'source'> = (textField.value as any);\n if (expr._styleExpression) {\n checkExpression(expr._styleExpression.expression);\n }\n }\n\n return hasOverrides;\n }\n}\n\nexport type SymbolPadding = [number, number, number, number];\n\nexport function getIconPadding(layout: PossiblyEvaluated, feature: SymbolFeature, canonical: CanonicalTileID, pixelRatio = 1): SymbolPadding {\n // Support text-padding in addition to icon-padding? Unclear how to apply asymmetric text-padding to the radius for collision circles.\n const result = layout.get('icon-padding').evaluate(feature, {}, canonical);\n const values = result && result.values;\n\n return [\n values[0] * pixelRatio,\n values[1] * pixelRatio,\n values[2] * pixelRatio,\n values[3] * pixelRatio,\n ];\n}\n","// This file is generated. Edit build/generate-style-code.ts, then run 'npm run codegen'.\n/* eslint-disable */\n\nimport {latest as styleSpec} from '@maplibre/maplibre-gl-style-spec';\n\nimport {\n Properties,\n DataConstantProperty,\n DataDrivenProperty,\n CrossFadedDataDrivenProperty,\n CrossFadedProperty,\n ColorRampProperty,\n PossiblyEvaluatedPropertyValue,\n CrossFaded\n} from '../properties';\n\nimport type {Color, Formatted, Padding, ResolvedImage, VariableAnchorOffsetCollection} from '@maplibre/maplibre-gl-style-spec';\nimport {StylePropertySpecification} from '@maplibre/maplibre-gl-style-spec';\n\n\nexport type BackgroundPaintProps = {\n \"background-color\": DataConstantProperty,\n \"background-pattern\": CrossFadedProperty,\n \"background-opacity\": DataConstantProperty,\n};\n\nexport type BackgroundPaintPropsPossiblyEvaluated = {\n \"background-color\": Color,\n \"background-pattern\": CrossFaded,\n \"background-opacity\": number,\n};\n\nlet paint: Properties;\nconst getPaint = () => paint = paint || new Properties({\n \"background-color\": new DataConstantProperty(styleSpec[\"paint_background\"][\"background-color\"] as any as StylePropertySpecification),\n \"background-pattern\": new CrossFadedProperty(styleSpec[\"paint_background\"][\"background-pattern\"] as any as StylePropertySpecification),\n \"background-opacity\": new DataConstantProperty(styleSpec[\"paint_background\"][\"background-opacity\"] as any as StylePropertySpecification),\n});\n\nexport default ({ get paint() { return getPaint() } });","import {StyleLayer} from '../style_layer';\n\nimport properties, {BackgroundPaintPropsPossiblyEvaluated} from './background_style_layer_properties.g';\nimport {Transitionable, Transitioning, PossiblyEvaluated} from '../properties';\n\nimport type {BackgroundPaintProps} from './background_style_layer_properties.g';\nimport type {LayerSpecification} from '@maplibre/maplibre-gl-style-spec';\n\nexport class BackgroundStyleLayer extends StyleLayer {\n _transitionablePaint: Transitionable;\n _transitioningPaint: Transitioning;\n paint: PossiblyEvaluated;\n\n constructor(layer: LayerSpecification) {\n super(layer, properties);\n }\n}\n","// This file is generated. Edit build/generate-style-code.ts, then run 'npm run codegen'.\n/* eslint-disable */\n\nimport {latest as styleSpec} from '@maplibre/maplibre-gl-style-spec';\n\nimport {\n Properties,\n DataConstantProperty,\n DataDrivenProperty,\n CrossFadedDataDrivenProperty,\n CrossFadedProperty,\n ColorRampProperty,\n PossiblyEvaluatedPropertyValue,\n CrossFaded\n} from '../properties';\n\nimport type {Color, Formatted, Padding, ResolvedImage, VariableAnchorOffsetCollection} from '@maplibre/maplibre-gl-style-spec';\nimport {StylePropertySpecification} from '@maplibre/maplibre-gl-style-spec';\n\n\nexport type RasterPaintProps = {\n \"raster-opacity\": DataConstantProperty,\n \"raster-hue-rotate\": DataConstantProperty,\n \"raster-brightness-min\": DataConstantProperty,\n \"raster-brightness-max\": DataConstantProperty,\n \"raster-saturation\": DataConstantProperty,\n \"raster-contrast\": DataConstantProperty,\n \"raster-resampling\": DataConstantProperty<\"linear\" | \"nearest\">,\n \"raster-fade-duration\": DataConstantProperty,\n};\n\nexport type RasterPaintPropsPossiblyEvaluated = {\n \"raster-opacity\": number,\n \"raster-hue-rotate\": number,\n \"raster-brightness-min\": number,\n \"raster-brightness-max\": number,\n \"raster-saturation\": number,\n \"raster-contrast\": number,\n \"raster-resampling\": \"linear\" | \"nearest\",\n \"raster-fade-duration\": number,\n};\n\nlet paint: Properties;\nconst getPaint = () => paint = paint || new Properties({\n \"raster-opacity\": new DataConstantProperty(styleSpec[\"paint_raster\"][\"raster-opacity\"] as any as StylePropertySpecification),\n \"raster-hue-rotate\": new DataConstantProperty(styleSpec[\"paint_raster\"][\"raster-hue-rotate\"] as any as StylePropertySpecification),\n \"raster-brightness-min\": new DataConstantProperty(styleSpec[\"paint_raster\"][\"raster-brightness-min\"] as any as StylePropertySpecification),\n \"raster-brightness-max\": new DataConstantProperty(styleSpec[\"paint_raster\"][\"raster-brightness-max\"] as any as StylePropertySpecification),\n \"raster-saturation\": new DataConstantProperty(styleSpec[\"paint_raster\"][\"raster-saturation\"] as any as StylePropertySpecification),\n \"raster-contrast\": new DataConstantProperty(styleSpec[\"paint_raster\"][\"raster-contrast\"] as any as StylePropertySpecification),\n \"raster-resampling\": new DataConstantProperty(styleSpec[\"paint_raster\"][\"raster-resampling\"] as any as StylePropertySpecification),\n \"raster-fade-duration\": new DataConstantProperty(styleSpec[\"paint_raster\"][\"raster-fade-duration\"] as any as StylePropertySpecification),\n});\n\nexport default ({ get paint() { return getPaint() } });","import {StyleLayer} from '../style_layer';\n\nimport properties, {RasterPaintPropsPossiblyEvaluated} from './raster_style_layer_properties.g';\nimport {Transitionable, Transitioning, PossiblyEvaluated} from '../properties';\n\nimport type {RasterPaintProps} from './raster_style_layer_properties.g';\nimport type {LayerSpecification} from '@maplibre/maplibre-gl-style-spec';\n\nexport class RasterStyleLayer extends StyleLayer {\n _transitionablePaint: Transitionable;\n _transitioningPaint: Transitioning;\n paint: PossiblyEvaluated;\n\n constructor(layer: LayerSpecification) {\n super(layer, properties);\n }\n}\n","import {StyleLayer} from '../style_layer';\nimport type {Map} from '../../ui/map';\nimport {mat4} from 'gl-matrix';\nimport {LayerSpecification} from '@maplibre/maplibre-gl-style-spec';\n\n/**\n* Input arguments exposed by custom render function.\n*/\ntype CustomRenderMethodInput = {\n /**\n * This value represents the distance from the camera to the far clipping plane.\n * It is used in the calculation of the projection matrix to determine which objects are visible.\n * farZ should be larger than nearZ.\n */\n farZ: number;\n /**\n * This value represents the distance from the camera to the near clipping plane.\n * It is used in the calculation of the projection matrix to determine which objects are visible.\n * nearZ should be smaller than farZ.\n */\n nearZ: number;\n /** field of view of camera **/\n fov: number;\n /**\n * model view projection matrix\n * represents the matrix converting from world space to clip space\n * https://learnopengl.com/Getting-started/Coordinate-Systems\n * **/\n modelViewProjectionMatrix: mat4;\n /**\n * projection matrix\n * represents the matrix converting from view space to clip space\n * https://learnopengl.com/Getting-started/Coordinate-Systems\n */\n projectionMatrix: mat4;\n}\n\n/**\n * @param gl - The map's gl context.\n * @param matrix - The map's camera matrix. It projects spherical mercator\n * coordinates to gl clip space coordinates. The spherical mercator coordinate `[0, 0]` represents the\n * top left corner of the mercator world and `[1, 1]` represents the bottom right corner. When\n * the `renderingMode` is `\"3d\"`, the z coordinate is conformal. A box with identical x, y, and z\n * lengths in mercator units would be rendered as a cube. {@link MercatorCoordinate.fromLngLat}\n * can be used to project a `LngLat` to a mercator coordinate.\n * @param options - Argument object with additional render inputs like camera properties.\n */\ntype CustomRenderMethod = (gl: WebGLRenderingContext|WebGL2RenderingContext, matrix: mat4, options: CustomRenderMethodInput) => void;\n\n/**\n * Interface for custom style layers. This is a specification for\n * implementers to model: it is not an exported method or class.\n *\n * Custom layers allow a user to render directly into the map's GL context using the map's camera.\n * These layers can be added between any regular layers using {@link Map#addLayer}.\n *\n * Custom layers must have a unique `id` and must have the `type` of `\"custom\"`.\n * They must implement `render` and may implement `prerender`, `onAdd` and `onRemove`.\n * They can trigger rendering using {@link Map#triggerRepaint}\n * and they should appropriately handle {@link MapContextEvent} with `webglcontextlost` and `webglcontextrestored`.\n *\n * The `renderingMode` property controls whether the layer is treated as a `\"2d\"` or `\"3d\"` map layer. Use:\n *\n * - `\"renderingMode\": \"3d\"` to use the depth buffer and share it with other layers\n * - `\"renderingMode\": \"2d\"` to add a layer with no depth. If you need to use the depth buffer for a `\"2d\"` layer you must use an offscreen\n * framebuffer and {@link CustomLayerInterface#prerender}\n *\n * @example\n * Custom layer implemented as ES6 class\n * ```ts\n * class NullIslandLayer {\n * constructor() {\n * this.id = 'null-island';\n * this.type = 'custom';\n * this.renderingMode = '2d';\n * }\n *\n * onAdd(map, gl) {\n * const vertexSource = `\n * uniform mat4 u_matrix;\n * void main() {\n * gl_Position = u_matrix * vec4(0.5, 0.5, 0.0, 1.0);\n * gl_PointSize = 20.0;\n * }`;\n *\n * const fragmentSource = `\n * void main() {\n * fragColor = vec4(1.0, 0.0, 0.0, 1.0);\n * }`;\n *\n * const vertexShader = gl.createShader(gl.VERTEX_SHADER);\n * gl.shaderSource(vertexShader, vertexSource);\n * gl.compileShader(vertexShader);\n * const fragmentShader = gl.createShader(gl.FRAGMENT_SHADER);\n * gl.shaderSource(fragmentShader, fragmentSource);\n * gl.compileShader(fragmentShader);\n *\n * this.program = gl.createProgram();\n * gl.attachShader(this.program, vertexShader);\n * gl.attachShader(this.program, fragmentShader);\n * gl.linkProgram(this.program);\n * }\n *\n * render(gl, matrix) {\n * gl.useProgram(this.program);\n * gl.uniformMatrix4fv(gl.getUniformLocation(this.program, \"u_matrix\"), false, matrix);\n * gl.drawArrays(gl.POINTS, 0, 1);\n * }\n * }\n *\n * map.on('load', () => {\n * map.addLayer(new NullIslandLayer());\n * });\n * ```\n */\nexport interface CustomLayerInterface {\n /**\n * A unique layer id.\n */\n id: string;\n /**\n * The layer's type. Must be `\"custom\"`.\n */\n type: 'custom';\n /**\n * Either `\"2d\"` or `\"3d\"`. Defaults to `\"2d\"`.\n */\n renderingMode?: '2d' | '3d';\n /**\n * Called during a render frame allowing the layer to draw into the GL context.\n *\n * The layer can assume blending and depth state is set to allow the layer to properly\n * blend and clip other layers. The layer cannot make any other assumptions about the\n * current GL state.\n *\n * If the layer needs to render to a texture, it should implement the `prerender` method\n * to do this and only use the `render` method for drawing directly into the main framebuffer.\n *\n * The blend function is set to `gl.blendFunc(gl.ONE, gl.ONE_MINUS_SRC_ALPHA)`. This expects\n * colors to be provided in premultiplied alpha form where the `r`, `g` and `b` values are already\n * multiplied by the `a` value. If you are unable to provide colors in premultiplied form you\n * may want to change the blend function to\n * `gl.blendFuncSeparate(gl.SRC_ALPHA, gl.ONE_MINUS_SRC_ALPHA, gl.ONE, gl.ONE_MINUS_SRC_ALPHA)`.\n */\n render: CustomRenderMethod;\n /**\n * Optional method called during a render frame to allow a layer to prepare resources or render into a texture.\n *\n * The layer cannot make any assumptions about the current GL state and must bind a framebuffer before rendering.\n */\n prerender?: CustomRenderMethod;\n /**\n * Optional method called when the layer has been added to the Map with {@link Map#addLayer}. This\n * gives the layer a chance to initialize gl resources and register event listeners.\n *\n * @param map - The Map this custom layer was just added to.\n * @param gl - The gl context for the map.\n */\n onAdd?(map: Map, gl: WebGLRenderingContext | WebGL2RenderingContext): void;\n /**\n * Optional method called when the layer has been removed from the Map with {@link Map#removeLayer}. This\n * gives the layer a chance to clean up gl resources and event listeners.\n *\n * @param map - The Map this custom layer was just added to.\n * @param gl - The gl context for the map.\n */\n onRemove?(map: Map, gl: WebGLRenderingContext | WebGL2RenderingContext): void;\n}\n\nexport function validateCustomStyleLayer(layerObject: CustomLayerInterface) {\n const errors = [];\n const id = layerObject.id;\n\n if (id === undefined) {\n errors.push({\n message: `layers.${id}: missing required property \"id\"`\n });\n }\n\n if (layerObject.render === undefined) {\n errors.push({\n message: `layers.${id}: missing required method \"render\"`\n });\n }\n\n if (layerObject.renderingMode &&\n layerObject.renderingMode !== '2d' &&\n layerObject.renderingMode !== '3d') {\n errors.push({\n message: `layers.${id}: property \"renderingMode\" must be either \"2d\" or \"3d\"`\n });\n }\n\n return errors;\n}\n\nexport class CustomStyleLayer extends StyleLayer {\n\n implementation: CustomLayerInterface;\n\n constructor(implementation: CustomLayerInterface) {\n super(implementation, {});\n this.implementation = implementation;\n }\n\n is3D() {\n return this.implementation.renderingMode === '3d';\n }\n\n hasOffscreenPass() {\n return this.implementation.prerender !== undefined;\n }\n\n recalculate() {}\n updateTransitions() {}\n hasTransition() { return false; }\n\n serialize(): LayerSpecification {\n throw new Error('Custom layers cannot be serialized');\n }\n\n onAdd = (map: Map) => {\n if (this.implementation.onAdd) {\n this.implementation.onAdd(map, map.painter.context.gl);\n }\n };\n\n onRemove = (map: Map) => {\n if (this.implementation.onRemove) {\n this.implementation.onRemove(map, map.painter.context.gl);\n }\n };\n}\n","import {CircleStyleLayer} from './style_layer/circle_style_layer';\nimport {HeatmapStyleLayer} from './style_layer/heatmap_style_layer';\nimport {HillshadeStyleLayer} from './style_layer/hillshade_style_layer';\nimport {FillStyleLayer} from './style_layer/fill_style_layer';\nimport {FillExtrusionStyleLayer} from './style_layer/fill_extrusion_style_layer';\nimport {LineStyleLayer} from './style_layer/line_style_layer';\nimport {SymbolStyleLayer} from './style_layer/symbol_style_layer';\nimport {BackgroundStyleLayer} from './style_layer/background_style_layer';\nimport {RasterStyleLayer} from './style_layer/raster_style_layer';\nimport {CustomStyleLayer, type CustomLayerInterface} from './style_layer/custom_style_layer';\n\nimport type {LayerSpecification} from '@maplibre/maplibre-gl-style-spec';\n\nexport function createStyleLayer(layer: LayerSpecification | CustomLayerInterface) {\n if (layer.type === 'custom') {\n return new CustomStyleLayer(layer);\n }\n switch (layer.type) {\n case 'background':\n return new BackgroundStyleLayer(layer);\n case 'circle':\n return new CircleStyleLayer(layer);\n case 'fill':\n return new FillStyleLayer(layer);\n case 'fill-extrusion':\n return new FillExtrusionStyleLayer(layer);\n case 'heatmap':\n return new HeatmapStyleLayer(layer);\n case 'hillshade':\n return new HillshadeStyleLayer(layer);\n case 'line':\n return new LineStyleLayer(layer);\n case 'raster':\n return new RasterStyleLayer(layer);\n case 'symbol':\n return new SymbolStyleLayer(layer);\n }\n}\n\n","/**\n * Invokes the wrapped function in a non-blocking way when trigger() is called.\n * Invocation requests are ignored until the function was actually invoked.\n */\nexport class ThrottledInvoker {\n _channel: MessageChannel;\n _triggered: boolean;\n _methodToThrottle: Function;\n\n constructor(methodToThrottle: Function) {\n this._methodToThrottle = methodToThrottle;\n this._triggered = false;\n if (typeof MessageChannel !== 'undefined') {\n this._channel = new MessageChannel();\n this._channel.port2.onmessage = () => {\n this._triggered = false;\n this._methodToThrottle();\n };\n }\n }\n\n trigger() {\n if (this._triggered) {\n return;\n }\n this._triggered = true;\n if (this._channel) {\n this._channel.port1.postMessage(true);\n } else {\n setTimeout(() => {\n this._triggered = false;\n this._methodToThrottle();\n }, 0);\n }\n }\n\n remove() {\n delete this._channel;\n this._methodToThrottle = () => {};\n }\n}\n","import {Subscription, isWorker, subscribe} from './util';\nimport {serialize, deserialize, Serialized} from './web_worker_transfer';\nimport {ThrottledInvoker} from './throttled_invoker';\n\nimport {\n MessageType,\n type ActorMessage,\n type RequestResponseMessageMap} from './actor_messages';\n\n/**\n * An interface to be sent to the actor in order for it to allow communication between the worker and the main thread\n */\nexport interface ActorTarget {\n addEventListener: typeof window.addEventListener;\n removeEventListener: typeof window.removeEventListener;\n postMessage: typeof window.postMessage;\n terminate?: () => void;\n}\n\n/**\n * This is used to define the parameters of the message that is sent to the worker and back\n */\ntype MessageData = {\n id: string;\n type: MessageType | '' | '';\n origin: string;\n data?: Serialized;\n targetMapId?: string | number | null;\n mustQueue?: boolean;\n error?: Serialized | null;\n sourceMapId: string | number | null;\n}\n\ntype ResolveReject = {\n resolve: (value?: RequestResponseMessageMap[MessageType][1]) => void;\n reject: (reason?: Error) => void;\n}\n\n/**\n * This interface allowing to substitute only the sendAsync method of the Actor class.\n */\nexport interface IActor {\n sendAsync(message: ActorMessage, abortController?: AbortController): Promise;\n}\n\nexport type MessageHandler = (mapId: string | number, params: RequestResponseMessageMap[T][0], abortController?: AbortController) => Promise\n\n/**\n * An implementation of the [Actor design pattern](https://en.wikipedia.org/wiki/Actor_model)\n * that maintains the relationship between asynchronous tasks and the objects\n * that spin them off - in this case, tasks like parsing parts of styles,\n * owned by the styles\n */\nexport class Actor implements IActor {\n target: ActorTarget;\n mapId: string | number | null;\n resolveRejects: { [x: string]: ResolveReject};\n name: string;\n tasks: { [x: string]: MessageData };\n taskQueue: Array;\n abortControllers: { [x: number | string]: AbortController };\n invoker: ThrottledInvoker;\n globalScope: ActorTarget;\n messageHandlers: { [x in MessageType]?: MessageHandler};\n subscription: Subscription;\n\n /**\n * @param target - The target\n * @param mapId - A unique identifier for the Map instance using this Actor.\n */\n constructor(target: ActorTarget, mapId?: string | number) {\n this.target = target;\n this.mapId = mapId;\n this.resolveRejects = {};\n this.tasks = {};\n this.taskQueue = [];\n this.abortControllers = {};\n this.messageHandlers = {};\n this.invoker = new ThrottledInvoker(() => this.process());\n this.subscription = subscribe(this.target, 'message', (message) => this.receive(message), false);\n this.globalScope = isWorker(self) ? target : window;\n }\n\n registerMessageHandler(type: T, handler: MessageHandler) {\n this.messageHandlers[type] = handler;\n }\n\n /**\n * Sends a message from a main-thread map to a Worker or from a Worker back to\n * a main-thread map instance.\n * @param message - the message to send\n * @param abortController - an optional AbortController to abort the request\n * @returns a promise that will be resolved with the response data\n */\n sendAsync(message: ActorMessage, abortController?: AbortController): Promise {\n return new Promise((resolve, reject) => {\n // We're using a string ID instead of numbers because they are being used as object keys\n // anyway, and thus stringified implicitly. We use random IDs because an actor may receive\n // message from multiple other actors which could run in different execution context. A\n // linearly increasing ID could produce collisions.\n const id = Math.round((Math.random() * 1e18)).toString(36).substring(0, 10);\n this.resolveRejects[id] = {\n resolve,\n reject\n };\n if (abortController) {\n abortController.signal.addEventListener('abort', () => {\n delete this.resolveRejects[id];\n const cancelMessage: MessageData = {\n id,\n type: '',\n origin: location.origin,\n targetMapId: message.targetMapId,\n sourceMapId: this.mapId\n };\n this.target.postMessage(cancelMessage);\n // In case of abort the current behavior is to keep the promise pending.\n }, {once: true});\n }\n const buffers: Array = [];\n const messageToPost: MessageData = {\n ...message,\n id,\n sourceMapId: this.mapId,\n origin: location.origin,\n data: serialize(message.data, buffers)\n };\n this.target.postMessage(messageToPost, {transfer: buffers});\n });\n }\n\n receive(message: {data: MessageData}) {\n const data = message.data;\n const id = data.id;\n if (data.origin !== 'file://' && location.origin !== 'file://' && data.origin !== 'resource://android' && location.origin !== 'resource://android' && data.origin !== location.origin) {\n return;\n }\n if (data.targetMapId && this.mapId !== data.targetMapId) {\n return;\n }\n if (data.type === '') {\n // Remove the original request from the queue. This is only possible if it\n // hasn't been kicked off yet. The id will remain in the queue, but because\n // there is no associated task, it will be dropped once it's time to execute it.\n delete this.tasks[id];\n const abortController = this.abortControllers[id];\n delete this.abortControllers[id];\n if (abortController) {\n abortController.abort();\n }\n return;\n }\n if (isWorker(self) || data.mustQueue) {\n // In workers, store the tasks that we need to process before actually processing them. This\n // is necessary because we want to keep receiving messages, and in particular,\n // messages. Some tasks may take a while in the worker thread, so before\n // executing the next task in our queue, postMessage preempts this and \n // messages can be processed. We're using a MessageChannel object to get throttle the\n // process() flow to one at a time.\n this.tasks[id] = data;\n this.taskQueue.push(id);\n this.invoker.trigger();\n return;\n }\n // In the main thread, process messages immediately so that other work does not slip in\n // between getting partial data back from workers.\n this.processTask(id, data);\n }\n\n process() {\n if (this.taskQueue.length === 0) {\n return;\n }\n const id = this.taskQueue.shift();\n const task = this.tasks[id];\n delete this.tasks[id];\n // Schedule another process call if we know there's more to process _before_ invoking the\n // current task. This is necessary so that processing continues even if the current task\n // doesn't execute successfully.\n if (this.taskQueue.length > 0) {\n this.invoker.trigger();\n }\n if (!task) {\n // If the task ID doesn't have associated task data anymore, it was canceled.\n return;\n }\n\n this.processTask(id, task);\n }\n\n async processTask(id: string, task: MessageData) {\n if (task.type === '') {\n // The `completeTask` function in the counterpart actor has been called, and we are now\n // resolving or rejecting the promise in the originating actor, if there is one.\n const resolveReject = this.resolveRejects[id];\n delete this.resolveRejects[id];\n if (!resolveReject) {\n // If we get a response, but don't have a resolve or reject, the request was canceled.\n return;\n }\n if (task.error) {\n resolveReject.reject(deserialize(task.error) as Error);\n } else {\n resolveReject.resolve(deserialize(task.data));\n }\n return;\n }\n if (!this.messageHandlers[task.type]) {\n this.completeTask(id, new Error(`Could not find a registered handler for ${task.type}, map ID: ${this.mapId}, available handlers: ${Object.keys(this.messageHandlers).join(', ')}`));\n return;\n }\n const params = deserialize(task.data) as RequestResponseMessageMap[MessageType][0];\n const abortController = new AbortController();\n this.abortControllers[id] = abortController;\n try {\n const data = await this.messageHandlers[task.type](task.sourceMapId, params, abortController);\n this.completeTask(id, null, data);\n } catch (err) {\n this.completeTask(id, err);\n }\n }\n\n completeTask(id: string, err: Error, data?: RequestResponseMessageMap[MessageType][1]) {\n const buffers: Array = [];\n delete this.abortControllers[id];\n const responseMessage: MessageData = {\n id,\n type: '',\n sourceMapId: this.mapId,\n origin: location.origin,\n error: err ? serialize(err) : null,\n data: serialize(data, buffers)\n };\n this.target.postMessage(responseMessage, {transfer: buffers});\n }\n\n remove() {\n this.invoker.remove();\n this.subscription.unsubscribe();\n }\n}\n","import {wrap} from '../util/util';\n\n/*\n* Approximate radius of the earth in meters.\n* Uses the WGS-84 approximation. The radius at the equator is ~6378137 and at the poles is ~6356752. https://en.wikipedia.org/wiki/World_Geodetic_System#WGS84\n* 6371008.8 is one published \"average radius\" see https://en.wikipedia.org/wiki/Earth_radius#Mean_radius, or ftp://athena.fsv.cvut.cz/ZFG/grs80-Moritz.pdf p.4\n*/\nexport const earthRadius = 6371008.8;\n\n/**\n * A {@link LngLat} object, an array of two numbers representing longitude and latitude,\n * or an object with `lng` and `lat` or `lon` and `lat` properties.\n *\n * @group Geography and Geometry\n *\n * @example\n * ```ts\n * let v1 = new LngLat(-122.420679, 37.772537);\n * let v2 = [-122.420679, 37.772537];\n * let v3 = {lon: -122.420679, lat: 37.772537};\n * ```\n */\nexport type LngLatLike = LngLat | {\n lng: number;\n lat: number;\n} | {\n lon: number;\n lat: number;\n} | [number, number];\n\n/**\n * A `LngLat` object represents a given longitude and latitude coordinate, measured in degrees.\n * These coordinates are based on the [WGS84 (EPSG:4326) standard](https://en.wikipedia.org/wiki/World_Geodetic_System#WGS84).\n *\n * MapLibre GL JS uses longitude, latitude coordinate order (as opposed to latitude, longitude) to match the\n * [GeoJSON specification](https://tools.ietf.org/html/rfc7946).\n *\n * Note that any MapLibre GL JS method that accepts a `LngLat` object as an argument or option\n * can also accept an `Array` of two numbers and will perform an implicit conversion.\n * This flexible type is documented as {@link LngLatLike}.\n *\n * @group Geography and Geometry\n *\n * @example\n * ```ts\n * let ll = new LngLat(-123.9749, 40.7736);\n * ll.lng; // = -123.9749\n * ```\n * @see [Get coordinates of the mouse pointer](https://maplibre.org/maplibre-gl-js/docs/examples/mouse-position/)\n * @see [Display a popup](https://maplibre.org/maplibre-gl-js/docs/examples/popup/)\n * @see [Create a timeline animation](https://maplibre.org/maplibre-gl-js/docs/examples/timeline-animation/)\n */\nexport class LngLat {\n lng: number;\n lat: number;\n\n /**\n * @param lng - Longitude, measured in degrees.\n * @param lat - Latitude, measured in degrees.\n */\n constructor(lng: number, lat: number) {\n if (isNaN(lng) || isNaN(lat)) {\n throw new Error(`Invalid LngLat object: (${lng}, ${lat})`);\n }\n this.lng = +lng;\n this.lat = +lat;\n if (this.lat > 90 || this.lat < -90) {\n throw new Error('Invalid LngLat latitude value: must be between -90 and 90');\n }\n }\n\n /**\n * Returns a new `LngLat` object whose longitude is wrapped to the range (-180, 180).\n *\n * @returns The wrapped `LngLat` object.\n * @example\n * ```ts\n * let ll = new LngLat(286.0251, 40.7736);\n * let wrapped = ll.wrap();\n * wrapped.lng; // = -73.9749\n * ```\n */\n wrap() {\n return new LngLat(wrap(this.lng, -180, 180), this.lat);\n }\n\n /**\n * Returns the coordinates represented as an array of two numbers.\n *\n * @returns The coordinates represented as an array of longitude and latitude.\n * @example\n * ```ts\n * let ll = new LngLat(-73.9749, 40.7736);\n * ll.toArray(); // = [-73.9749, 40.7736]\n * ```\n */\n toArray(): [number, number] {\n return [this.lng, this.lat];\n }\n\n /**\n * Returns the coordinates represent as a string.\n *\n * @returns The coordinates represented as a string of the format `'LngLat(lng, lat)'`.\n * @example\n * ```ts\n * let ll = new LngLat(-73.9749, 40.7736);\n * ll.toString(); // = \"LngLat(-73.9749, 40.7736)\"\n * ```\n */\n toString(): string {\n return `LngLat(${this.lng}, ${this.lat})`;\n }\n\n /**\n * Returns the approximate distance between a pair of coordinates in meters\n * Uses the Haversine Formula (from R.W. Sinnott, \"Virtues of the Haversine\", Sky and Telescope, vol. 68, no. 2, 1984, p. 159)\n *\n * @param lngLat - coordinates to compute the distance to\n * @returns Distance in meters between the two coordinates.\n * @example\n * ```ts\n * let new_york = new LngLat(-74.0060, 40.7128);\n * let los_angeles = new LngLat(-118.2437, 34.0522);\n * new_york.distanceTo(los_angeles); // = 3935751.690893987, \"true distance\" using a non-spherical approximation is ~3966km\n * ```\n */\n distanceTo(lngLat: LngLat): number {\n const rad = Math.PI / 180;\n const lat1 = this.lat * rad;\n const lat2 = lngLat.lat * rad;\n const a = Math.sin(lat1) * Math.sin(lat2) + Math.cos(lat1) * Math.cos(lat2) * Math.cos((lngLat.lng - this.lng) * rad);\n\n const maxMeters = earthRadius * Math.acos(Math.min(a, 1));\n return maxMeters;\n }\n\n /**\n * Converts an array of two numbers or an object with `lng` and `lat` or `lon` and `lat` properties\n * to a `LngLat` object.\n *\n * If a `LngLat` object is passed in, the function returns it unchanged.\n *\n * @param input - An array of two numbers or object to convert, or a `LngLat` object to return.\n * @returns A new `LngLat` object, if a conversion occurred, or the original `LngLat` object.\n * @example\n * ```ts\n * let arr = [-73.9749, 40.7736];\n * let ll = LngLat.convert(arr);\n * ll; // = LngLat {lng: -73.9749, lat: 40.7736}\n * ```\n */\n static convert(input: LngLatLike): LngLat {\n if (input instanceof LngLat) {\n return input;\n }\n if (Array.isArray(input) && (input.length === 2 || input.length === 3)) {\n return new LngLat(Number(input[0]), Number(input[1]));\n }\n if (!Array.isArray(input) && typeof input === 'object' && input !== null) {\n return new LngLat(\n // flow can't refine this to have one of lng or lat, so we have to cast to any\n Number('lng' in input ? (input as any).lng : (input as any).lon),\n Number(input.lat)\n );\n }\n throw new Error('`LngLatLike` argument must be specified as a LngLat instance, an object {lng: , lat: }, an object {lon: , lat: }, or an array of [, ]');\n }\n}\n","import {LngLat, earthRadius} from '../geo/lng_lat';\nimport type {LngLatLike} from '../geo/lng_lat';\nimport {IMercatorCoordinate} from '@maplibre/maplibre-gl-style-spec';\n\n/*\n * The average circumference of the world in meters.\n */\nconst earthCircumference = 2 * Math.PI * earthRadius; // meters\n\n/*\n * The circumference at a line of latitude in meters.\n */\nfunction circumferenceAtLatitude(latitude: number) {\n return earthCircumference * Math.cos(latitude * Math.PI / 180);\n}\n\nexport function mercatorXfromLng(lng: number) {\n return (180 + lng) / 360;\n}\n\nexport function mercatorYfromLat(lat: number) {\n return (180 - (180 / Math.PI * Math.log(Math.tan(Math.PI / 4 + lat * Math.PI / 360)))) / 360;\n}\n\nexport function mercatorZfromAltitude(altitude: number, lat: number) {\n return altitude / circumferenceAtLatitude(lat);\n}\n\nexport function lngFromMercatorX(x: number) {\n return x * 360 - 180;\n}\n\nexport function latFromMercatorY(y: number) {\n const y2 = 180 - y * 360;\n return 360 / Math.PI * Math.atan(Math.exp(y2 * Math.PI / 180)) - 90;\n}\n\nexport function altitudeFromMercatorZ(z: number, y: number) {\n return z * circumferenceAtLatitude(latFromMercatorY(y));\n}\n\n/**\n * Determine the Mercator scale factor for a given latitude, see\n * https://en.wikipedia.org/wiki/Mercator_projection#Scale_factor\n *\n * At the equator the scale factor will be 1, which increases at higher latitudes.\n *\n * @param lat - Latitude\n * @returns scale factor\n */\nexport function mercatorScale(lat: number) {\n return 1 / Math.cos(lat * Math.PI / 180);\n}\n\n/**\n * A `MercatorCoordinate` object represents a projected three dimensional position.\n *\n * `MercatorCoordinate` uses the web mercator projection ([EPSG:3857](https://epsg.io/3857)) with slightly different units:\n *\n * - the size of 1 unit is the width of the projected world instead of the \"mercator meter\"\n * - the origin of the coordinate space is at the north-west corner instead of the middle\n *\n * For example, `MercatorCoordinate(0, 0, 0)` is the north-west corner of the mercator world and\n * `MercatorCoordinate(1, 1, 0)` is the south-east corner. If you are familiar with\n * [vector tiles](https://github.com/mapbox/vector-tile-spec) it may be helpful to think\n * of the coordinate space as the `0/0/0` tile with an extent of `1`.\n *\n * The `z` dimension of `MercatorCoordinate` is conformal. A cube in the mercator coordinate space would be rendered as a cube.\n *\n * @group Geography and Geometry\n *\n * @example\n * ```ts\n * let nullIsland = new MercatorCoordinate(0.5, 0.5, 0);\n * ```\n * @see [Add a custom style layer](https://maplibre.org/maplibre-gl-js/docs/examples/custom-style-layer/)\n */\nexport class MercatorCoordinate implements IMercatorCoordinate {\n x: number;\n y: number;\n z: number;\n\n /**\n * @param x - The x component of the position.\n * @param y - The y component of the position.\n * @param z - The z component of the position.\n */\n constructor(x: number, y: number, z: number = 0) {\n this.x = +x;\n this.y = +y;\n this.z = +z;\n }\n\n /**\n * Project a `LngLat` to a `MercatorCoordinate`.\n *\n * @param lngLatLike - The location to project.\n * @param altitude - The altitude in meters of the position.\n * @returns The projected mercator coordinate.\n * @example\n * ```ts\n * let coord = MercatorCoordinate.fromLngLat({ lng: 0, lat: 0}, 0);\n * coord; // MercatorCoordinate(0.5, 0.5, 0)\n * ```\n */\n static fromLngLat(lngLatLike: LngLatLike, altitude: number = 0): MercatorCoordinate {\n const lngLat = LngLat.convert(lngLatLike);\n\n return new MercatorCoordinate(\n mercatorXfromLng(lngLat.lng),\n mercatorYfromLat(lngLat.lat),\n mercatorZfromAltitude(altitude, lngLat.lat));\n }\n\n /**\n * Returns the `LngLat` for the coordinate.\n *\n * @returns The `LngLat` object.\n * @example\n * ```ts\n * let coord = new MercatorCoordinate(0.5, 0.5, 0);\n * let lngLat = coord.toLngLat(); // LngLat(0, 0)\n * ```\n */\n toLngLat() {\n return new LngLat(\n lngFromMercatorX(this.x),\n latFromMercatorY(this.y));\n }\n\n /**\n * Returns the altitude in meters of the coordinate.\n *\n * @returns The altitude in meters.\n * @example\n * ```ts\n * let coord = new MercatorCoordinate(0, 0, 0.02);\n * coord.toAltitude(); // 6914.281956295339\n * ```\n */\n toAltitude(): number {\n return altitudeFromMercatorZ(this.z, this.y);\n }\n\n /**\n * Returns the distance of 1 meter in `MercatorCoordinate` units at this latitude.\n *\n * For coordinates in real world units using meters, this naturally provides the scale\n * to transform into `MercatorCoordinate`s.\n *\n * @returns Distance of 1 meter in `MercatorCoordinate` units.\n */\n meterInMercatorCoordinateUnits(): number {\n // 1 meter / circumference at equator in meters * Mercator projection scale factor at this latitude\n return 1 / earthCircumference * mercatorScale(latFromMercatorY(this.y));\n }\n}\n","export { getURL, getTileBBox, getMercCoords };\n\n\n/**\n * getURL\n *\n * @param {String} baseUrl Base url of the WMS server\n * @param {String} layer Layer name\n * @param {Number} x Tile coordinate x\n * @param {Number} y Tile coordinate y\n * @param {Number} z Tile zoom\n * @param {Object} [options]\n * @param {String} [options.format='image/png']\n * @param {String} [options.service='WMS']\n * @param {String} [options.version='1.1.1']\n * @param {String} [options.request='GetMap']\n * @param {String} [options.srs='EPSG:3857']\n * @param {Number} [options.width='256']\n * @param {Number} [options.height='256']\n * @returns {String} url\n * @example\n * var baseUrl = 'http://geodata.state.nj.us/imagerywms/Natural2015';\n * var layer = 'Natural2015';\n * var url = whoots.getURL(baseUrl, layer, 154308, 197167, 19);\n */\nfunction getURL(baseUrl, layer, x, y, z, options) {\n options = options || {};\n\n var url = baseUrl + '?' + [\n 'bbox=' + getTileBBox(x, y, z),\n 'format=' + (options.format || 'image/png'),\n 'service=' + (options.service || 'WMS'),\n 'version=' + (options.version || '1.1.1'),\n 'request=' + (options.request || 'GetMap'),\n 'srs=' + (options.srs || 'EPSG:3857'),\n 'width=' + (options.width || 256),\n 'height=' + (options.height || 256),\n 'layers=' + layer\n ].join('&');\n\n return url;\n}\n\n\n/**\n * getTileBBox\n *\n * @param {Number} x Tile coordinate x\n * @param {Number} y Tile coordinate y\n * @param {Number} z Tile zoom\n * @returns {String} String of the bounding box\n */\nfunction getTileBBox(x, y, z) {\n // for Google/OSM tile scheme we need to alter the y\n y = (Math.pow(2, z) - y - 1);\n\n var min = getMercCoords(x * 256, y * 256, z),\n max = getMercCoords((x + 1) * 256, (y + 1) * 256, z);\n\n return min[0] + ',' + min[1] + ',' + max[0] + ',' + max[1];\n}\n\n\n/**\n * getMercCoords\n *\n * @param {Number} x Pixel coordinate x\n * @param {Number} y Pixel coordinate y\n * @param {Number} z Tile zoom\n * @returns {Array} [x, y]\n */\nfunction getMercCoords(x, y, z) {\n var resolution = (2 * Math.PI * 6378137 / 256) / Math.pow(2, z),\n merc_x = (x * resolution - 2 * Math.PI * 6378137 / 2.0),\n merc_y = (y * resolution - 2 * Math.PI * 6378137 / 2.0);\n\n return [merc_x, merc_y];\n}\n","import {MAX_TILE_ZOOM, MIN_TILE_ZOOM} from './util';\nimport {LngLat} from '../geo/lng_lat';\nimport {MercatorCoordinate} from '../geo/mercator_coordinate';\n\n/**\n * Returns true if a given tile zoom (Z), X, and Y are in the bounds of the world.\n * Zoom bounds are the minimum zoom (inclusive) through the maximum zoom (inclusive).\n * X and Y bounds are 0 (inclusive) to their respective zoom-dependent maxima (exclusive).\n *\n * @param zoom - the tile zoom (Z)\n * @param x - the tile X\n * @param y - the tile Y\n * @returns `true` if a given tile zoom, X, and Y are in the bounds of the world.\n */\nexport function isInBoundsForTileZoomXY(zoom: number, x: number, y: number): boolean {\n return !(\n zoom < MIN_TILE_ZOOM ||\n zoom > MAX_TILE_ZOOM ||\n y < 0 ||\n y >= Math.pow(2, zoom) ||\n x < 0 ||\n x >= Math.pow(2, zoom)\n );\n}\n\n/**\n * Returns true if a given zoom and `LngLat` are in the bounds of the world.\n * Does not wrap `LngLat` when checking if in bounds.\n * Zoom bounds are the minimum zoom (inclusive) through the maximum zoom (inclusive).\n * `LngLat` bounds are the mercator world's north-west corner (inclusive) to its south-east corner (exclusive).\n *\n * @param zoom - the tile zoom (Z)\n * @param LngLat - the `LngLat` object containing the longitude and latitude\n * @returns `true` if a given zoom and `LngLat` are in the bounds of the world.\n */\nexport function isInBoundsForZoomLngLat(zoom: number, lnglat: LngLat): boolean {\n const {x, y} = MercatorCoordinate.fromLngLat(lnglat);\n return !(\n zoom < MIN_TILE_ZOOM ||\n zoom > MAX_TILE_ZOOM ||\n y < 0 ||\n y >= 1 ||\n x < 0 ||\n x >= 1\n );\n}\n","import {getTileBBox} from '@mapbox/whoots-js';\nimport {EXTENT} from '../data/extent';\nimport Point from '@mapbox/point-geometry';\nimport {MercatorCoordinate} from '../geo/mercator_coordinate';\nimport {register} from '../util/web_worker_transfer';\nimport {mat4} from 'gl-matrix';\nimport {ICanonicalTileID, IMercatorCoordinate} from '@maplibre/maplibre-gl-style-spec';\nimport {MAX_TILE_ZOOM, MIN_TILE_ZOOM} from '../util/util';\nimport {isInBoundsForTileZoomXY} from '../util/world_bounds';\n\n/**\n * A canonical way to define a tile ID\n */\nexport class CanonicalTileID implements ICanonicalTileID {\n z: number;\n x: number;\n y: number;\n key: string;\n\n constructor(z: number, x: number, y: number) {\n\n if (!isInBoundsForTileZoomXY(z, x, y)) {\n throw new Error(`x=${x}, y=${y}, z=${z} outside of bounds. 0<=x<${Math.pow(2, z)}, 0<=y<${Math.pow(2, z)} ${MIN_TILE_ZOOM}<=z<=${MAX_TILE_ZOOM} `);\n }\n\n this.z = z;\n this.x = x;\n this.y = y;\n this.key = calculateKey(0, z, z, x, y);\n }\n\n equals(id: ICanonicalTileID) {\n return this.z === id.z && this.x === id.x && this.y === id.y;\n }\n\n // given a list of urls, choose a url template and return a tile URL\n url(urls: Array, pixelRatio: number, scheme?: string | null) {\n const bbox = getTileBBox(this.x, this.y, this.z);\n const quadkey = getQuadkey(this.z, this.x, this.y);\n\n return urls[(this.x + this.y) % urls.length]\n .replace(/{prefix}/g, (this.x % 16).toString(16) + (this.y % 16).toString(16))\n .replace(/{z}/g, String(this.z))\n .replace(/{x}/g, String(this.x))\n .replace(/{y}/g, String(scheme === 'tms' ? (Math.pow(2, this.z) - this.y - 1) : this.y))\n .replace(/{ratio}/g, pixelRatio > 1 ? '@2x' : '')\n .replace(/{quadkey}/g, quadkey)\n .replace(/{bbox-epsg-3857}/g, bbox);\n }\n\n isChildOf(parent: ICanonicalTileID) {\n const dz = this.z - parent.z;\n return dz > 0 && parent.x === (this.x >> dz) && parent.y === (this.y >> dz);\n }\n\n getTilePoint(coord: IMercatorCoordinate) {\n const tilesAtZoom = Math.pow(2, this.z);\n return new Point(\n (coord.x * tilesAtZoom - this.x) * EXTENT,\n (coord.y * tilesAtZoom - this.y) * EXTENT);\n }\n\n toString() {\n return `${this.z}/${this.x}/${this.y}`;\n }\n}\n\n/**\n * @internal\n * An unwrapped tile identifier\n */\nexport class UnwrappedTileID {\n wrap: number;\n canonical: CanonicalTileID;\n key: string;\n\n constructor(wrap: number, canonical: CanonicalTileID) {\n this.wrap = wrap;\n this.canonical = canonical;\n this.key = calculateKey(wrap, canonical.z, canonical.z, canonical.x, canonical.y);\n }\n}\n\n/**\n * An overscaled tile identifier\n */\nexport class OverscaledTileID {\n overscaledZ: number;\n wrap: number;\n canonical: CanonicalTileID;\n key: string;\n posMatrix: mat4;\n\n constructor(overscaledZ: number, wrap: number, z: number, x: number, y: number) {\n if (overscaledZ < z) throw new Error(`overscaledZ should be >= z; overscaledZ = ${overscaledZ}; z = ${z}`);\n this.overscaledZ = overscaledZ;\n this.wrap = wrap;\n this.canonical = new CanonicalTileID(z, +x, +y);\n this.key = calculateKey(wrap, overscaledZ, z, x, y);\n }\n\n clone() {\n return new OverscaledTileID(this.overscaledZ, this.wrap, this.canonical.z, this.canonical.x, this.canonical.y);\n }\n\n equals(id: OverscaledTileID) {\n return this.overscaledZ === id.overscaledZ && this.wrap === id.wrap && this.canonical.equals(id.canonical);\n }\n\n scaledTo(targetZ: number) {\n if (targetZ > this.overscaledZ) throw new Error(`targetZ > this.overscaledZ; targetZ = ${targetZ}; overscaledZ = ${this.overscaledZ}`);\n const zDifference = this.canonical.z - targetZ;\n if (targetZ > this.canonical.z) {\n return new OverscaledTileID(targetZ, this.wrap, this.canonical.z, this.canonical.x, this.canonical.y);\n } else {\n return new OverscaledTileID(targetZ, this.wrap, targetZ, this.canonical.x >> zDifference, this.canonical.y >> zDifference);\n }\n }\n\n /*\n * calculateScaledKey is an optimization:\n * when withWrap == true, implements the same as this.scaledTo(z).key,\n * when withWrap == false, implements the same as this.scaledTo(z).wrapped().key.\n */\n calculateScaledKey(targetZ: number, withWrap: boolean): string {\n if (targetZ > this.overscaledZ) throw new Error(`targetZ > this.overscaledZ; targetZ = ${targetZ}; overscaledZ = ${this.overscaledZ}`);\n const zDifference = this.canonical.z - targetZ;\n if (targetZ > this.canonical.z) {\n return calculateKey(this.wrap * +withWrap, targetZ, this.canonical.z, this.canonical.x, this.canonical.y);\n } else {\n return calculateKey(this.wrap * +withWrap, targetZ, targetZ, this.canonical.x >> zDifference, this.canonical.y >> zDifference);\n }\n }\n\n isChildOf(parent: OverscaledTileID) {\n if (parent.wrap !== this.wrap) {\n // We can't be a child if we're in a different world copy\n return false;\n }\n const zDifference = this.canonical.z - parent.canonical.z;\n // We're first testing for z == 0, to avoid a 32 bit shift, which is undefined.\n return parent.overscaledZ === 0 || (\n parent.overscaledZ < this.overscaledZ &&\n parent.canonical.x === (this.canonical.x >> zDifference) &&\n parent.canonical.y === (this.canonical.y >> zDifference));\n }\n\n children(sourceMaxZoom: number) {\n if (this.overscaledZ >= sourceMaxZoom) {\n // return a single tile coord representing a an overscaled tile\n return [new OverscaledTileID(this.overscaledZ + 1, this.wrap, this.canonical.z, this.canonical.x, this.canonical.y)];\n }\n\n const z = this.canonical.z + 1;\n const x = this.canonical.x * 2;\n const y = this.canonical.y * 2;\n return [\n new OverscaledTileID(z, this.wrap, z, x, y),\n new OverscaledTileID(z, this.wrap, z, x + 1, y),\n new OverscaledTileID(z, this.wrap, z, x, y + 1),\n new OverscaledTileID(z, this.wrap, z, x + 1, y + 1)\n ];\n }\n\n isLessThan(rhs: OverscaledTileID) {\n if (this.wrap < rhs.wrap) return true;\n if (this.wrap > rhs.wrap) return false;\n\n if (this.overscaledZ < rhs.overscaledZ) return true;\n if (this.overscaledZ > rhs.overscaledZ) return false;\n\n if (this.canonical.x < rhs.canonical.x) return true;\n if (this.canonical.x > rhs.canonical.x) return false;\n\n if (this.canonical.y < rhs.canonical.y) return true;\n return false;\n }\n\n wrapped() {\n return new OverscaledTileID(this.overscaledZ, 0, this.canonical.z, this.canonical.x, this.canonical.y);\n }\n\n unwrapTo(wrap: number) {\n return new OverscaledTileID(this.overscaledZ, wrap, this.canonical.z, this.canonical.x, this.canonical.y);\n }\n\n overscaleFactor() {\n return Math.pow(2, this.overscaledZ - this.canonical.z);\n }\n\n toUnwrapped() {\n return new UnwrappedTileID(this.wrap, this.canonical);\n }\n\n toString() {\n return `${this.overscaledZ}/${this.canonical.x}/${this.canonical.y}`;\n }\n\n getTilePoint(coord: MercatorCoordinate) {\n return this.canonical.getTilePoint(new MercatorCoordinate(coord.x - this.wrap, coord.y));\n }\n}\n\nfunction calculateKey(wrap: number, overscaledZ: number, z: number, x: number, y: number): string {\n wrap *= 2;\n if (wrap < 0) wrap = wrap * -1 - 1;\n const dim = 1 << z;\n return (dim * dim * wrap + dim * y + x).toString(36) + z.toString(36) + overscaledZ.toString(36);\n}\n\nfunction getQuadkey(z, x, y) {\n let quadkey = '', mask;\n for (let i = z; i > 0; i--) {\n mask = 1 << (i - 1);\n quadkey += ((x & mask ? 1 : 0) + (y & mask ? 2 : 0));\n }\n return quadkey;\n}\n\nregister('CanonicalTileID', CanonicalTileID);\nregister('OverscaledTileID', OverscaledTileID, {omit: ['posMatrix']});\n","import {RGBAImage} from '../util/image';\n\nimport {warnOnce} from '../util/util';\nimport {register} from '../util/web_worker_transfer';\n\n/**\n * The possible DEM encoding types\n */\nexport type DEMEncoding = 'mapbox' | 'terrarium' | 'custom'\n\n/**\n * DEMData is a data structure for decoding, backfilling, and storing elevation data for processing in the hillshade shaders\n * data can be populated either from a pngraw image tile or from serialized data sent back from a worker. When data is initially\n * loaded from a image tile, we decode the pixel values using the appropriate decoding formula, but we store the\n * elevation data as an Int32 value. we add 65536 (2^16) to eliminate negative values and enable the use of\n * integer overflow when creating the texture used in the hillshadePrepare step.\n *\n * DEMData also handles the backfilling of data from a tile's neighboring tiles. This is necessary because we use a pixel's 8\n * surrounding pixel values to compute the slope at that pixel, and we cannot accurately calculate the slope at pixels on a\n * tile's edge without backfilling from neighboring tiles.\n */\nexport class DEMData {\n uid: string | number;\n data: Uint32Array;\n stride: number;\n dim: number;\n min: number;\n max: number;\n redFactor: number;\n greenFactor: number;\n blueFactor: number;\n baseShift: number;\n\n /**\n * Constructs a `DEMData` object\n * @param uid - the tile's unique id\n * @param data - RGBAImage data has uniform 1px padding on all sides: square tile edge size defines stride\n // and dim is calculated as stride - 2.\n * @param encoding - the encoding type of the data\n * @param redFactor - the red channel factor used to unpack the data, used for `custom` encoding only\n * @param greenFactor - the green channel factor used to unpack the data, used for `custom` encoding only\n * @param blueFactor - the blue channel factor used to unpack the data, used for `custom` encoding only\n * @param baseShift - the base shift used to unpack the data, used for `custom` encoding only\n */\n constructor(uid: string | number, data: RGBAImage | ImageData, encoding: DEMEncoding, redFactor = 1.0, greenFactor = 1.0, blueFactor = 1.0, baseShift = 0.0) {\n this.uid = uid;\n if (data.height !== data.width) throw new RangeError('DEM tiles must be square');\n if (encoding && !['mapbox', 'terrarium', 'custom'].includes(encoding)) {\n warnOnce(`\"${encoding}\" is not a valid encoding type. Valid types include \"mapbox\", \"terrarium\" and \"custom\".`);\n return;\n }\n this.stride = data.height;\n const dim = this.dim = data.height - 2;\n this.data = new Uint32Array(data.data.buffer);\n switch (encoding) {\n case 'terrarium':\n // unpacking formula for mapzen terrarium:\n // https://aws.amazon.com/public-datasets/terrain/\n this.redFactor = 256.0;\n this.greenFactor = 1.0;\n this.blueFactor = 1.0 / 256.0;\n this.baseShift = 32768.0;\n break;\n case 'custom':\n this.redFactor = redFactor;\n this.greenFactor = greenFactor;\n this.blueFactor = blueFactor;\n this.baseShift = baseShift;\n break;\n case 'mapbox':\n default:\n // unpacking formula for mapbox.terrain-rgb:\n // https://www.mapbox.com/help/access-elevation-data/#mapbox-terrain-rgb\n this.redFactor = 6553.6;\n this.greenFactor = 25.6;\n this.blueFactor = 0.1;\n this.baseShift = 10000.0;\n break;\n }\n\n // in order to avoid flashing seams between tiles, here we are initially populating a 1px border of pixels around the image\n // with the data of the nearest pixel from the image. this data is eventually replaced when the tile's neighboring\n // tiles are loaded and the accurate data can be backfilled using DEMData#backfillBorder\n for (let x = 0; x < dim; x++) {\n // left vertical border\n this.data[this._idx(-1, x)] = this.data[this._idx(0, x)];\n // right vertical border\n this.data[this._idx(dim, x)] = this.data[this._idx(dim - 1, x)];\n // left horizontal border\n this.data[this._idx(x, -1)] = this.data[this._idx(x, 0)];\n // right horizontal border\n this.data[this._idx(x, dim)] = this.data[this._idx(x, dim - 1)];\n }\n // corners\n this.data[this._idx(-1, -1)] = this.data[this._idx(0, 0)];\n this.data[this._idx(dim, -1)] = this.data[this._idx(dim - 1, 0)];\n this.data[this._idx(-1, dim)] = this.data[this._idx(0, dim - 1)];\n this.data[this._idx(dim, dim)] = this.data[this._idx(dim - 1, dim - 1)];\n\n // calculate min/max values\n this.min = Number.MAX_SAFE_INTEGER;\n this.max = Number.MIN_SAFE_INTEGER;\n for (let x = 0; x < dim; x++) {\n for (let y = 0; y < dim; y++) {\n const ele = this.get(x, y);\n if (ele > this.max) this.max = ele;\n if (ele < this.min) this.min = ele;\n }\n }\n }\n\n get(x: number, y: number) {\n const pixels = new Uint8Array(this.data.buffer);\n const index = this._idx(x, y) * 4;\n return this.unpack(pixels[index], pixels[index + 1], pixels[index + 2]);\n }\n\n getUnpackVector() {\n return [this.redFactor, this.greenFactor, this.blueFactor, this.baseShift];\n }\n\n _idx(x: number, y: number) {\n if (x < -1 || x >= this.dim + 1 || y < -1 || y >= this.dim + 1) throw new RangeError('out of range source coordinates for DEM data');\n return (y + 1) * this.stride + (x + 1);\n }\n\n unpack(r: number, g: number, b: number) {\n return (r * this.redFactor + g * this.greenFactor + b * this.blueFactor - this.baseShift);\n }\n\n getPixels() {\n return new RGBAImage({width: this.stride, height: this.stride}, new Uint8Array(this.data.buffer));\n }\n\n backfillBorder(borderTile: DEMData, dx: number, dy: number) {\n if (this.dim !== borderTile.dim) throw new Error('dem dimension mismatch');\n\n let xMin = dx * this.dim,\n xMax = dx * this.dim + this.dim,\n yMin = dy * this.dim,\n yMax = dy * this.dim + this.dim;\n\n switch (dx) {\n case -1:\n xMin = xMax - 1;\n break;\n case 1:\n xMax = xMin + 1;\n break;\n }\n\n switch (dy) {\n case -1:\n yMin = yMax - 1;\n break;\n case 1:\n yMax = yMin + 1;\n break;\n }\n\n const ox = -dx * this.dim;\n const oy = -dy * this.dim;\n for (let y = yMin; y < yMax; y++) {\n for (let x = xMin; x < xMax; x++) {\n this.data[this._idx(x, y)] = borderTile.data[this._idx(x + ox, y + oy)];\n }\n }\n }\n}\n\nregister('DEMData', DEMData);\n","export class DictionaryCoder {\n _stringToNumber: {[_: string]: number};\n _numberToString: Array;\n\n constructor(strings: Array) {\n this._stringToNumber = {};\n this._numberToString = [];\n for (let i = 0; i < strings.length; i++) {\n const string = strings[i];\n this._stringToNumber[string] = i;\n this._numberToString[i] = string;\n }\n }\n\n encode(string: string) {\n return this._stringToNumber[string];\n }\n\n decode(n: number) {\n if (n >= this._numberToString.length) throw new Error(`Out of bounds. Index requested n=${n} can't be >= this._numberToString.length ${this._numberToString.length}`);\n return this._numberToString[n];\n }\n}\n","import type {VectorTileFeature} from '@mapbox/vector-tile';\nimport type {LayerSpecification} from '@maplibre/maplibre-gl-style-spec';\n\n/**\n * A helper for type to omit a property from a type\n */\ntype DistributiveKeys = T extends T ? keyof T : never;\n/**\n * A helper for type to omit a property from a type\n */\ntype DistributiveOmit> = T extends unknown\n ? Omit\n : never;\n\n/**\n * An extended geojson feature used by the events to return data to the listener\n */\nexport type MapGeoJSONFeature = GeoJSONFeature & {\n layer: DistributiveOmit & {source: string};\n source: string;\n sourceLayer?: string;\n state: { [key: string]: any };\n}\n\n/**\n * A geojson feature\n */\nexport class GeoJSONFeature {\n type: 'Feature';\n _geometry: GeoJSON.Geometry;\n properties: { [name: string]: any };\n id: number | string | undefined;\n\n _vectorTileFeature: VectorTileFeature;\n\n constructor(vectorTileFeature: VectorTileFeature, z: number, x: number, y: number, id: string | number | undefined) {\n this.type = 'Feature';\n\n this._vectorTileFeature = vectorTileFeature;\n (vectorTileFeature as any)._z = z;\n (vectorTileFeature as any)._x = x;\n (vectorTileFeature as any)._y = y;\n\n this.properties = vectorTileFeature.properties;\n this.id = id;\n }\n\n get geometry(): GeoJSON.Geometry {\n if (this._geometry === undefined) {\n this._geometry = this._vectorTileFeature.toGeoJSON(\n (this._vectorTileFeature as any)._x,\n (this._vectorTileFeature as any)._y,\n (this._vectorTileFeature as any)._z).geometry;\n }\n return this._geometry;\n }\n\n set geometry(g: GeoJSON.Geometry) {\n this._geometry = g;\n }\n\n toJSON() {\n const json: any = {\n geometry: this.geometry\n };\n for (const i in this) {\n if (i === '_geometry' || i === '_vectorTileFeature') continue;\n json[i] = (this)[i];\n }\n return json;\n }\n}\n","import Point from '@mapbox/point-geometry';\nimport {loadGeometry} from './load_geometry';\nimport {toEvaluationFeature} from './evaluation_feature';\nimport {EXTENT} from './extent';\nimport {featureFilter} from '@maplibre/maplibre-gl-style-spec';\nimport {TransferableGridIndex} from '../util/transferable_grid_index';\nimport {DictionaryCoder} from '../util/dictionary_coder';\nimport vt from '@mapbox/vector-tile';\nimport Protobuf from 'pbf';\nimport {GeoJSONFeature} from '../util/vectortile_to_geojson';\nimport type {MapGeoJSONFeature} from '../util/vectortile_to_geojson';\nimport {arraysIntersect, mapObject, extend} from '../util/util';\nimport {OverscaledTileID} from '../source/tile_id';\nimport {register} from '../util/web_worker_transfer';\nimport {EvaluationParameters} from '../style/evaluation_parameters';\nimport {SourceFeatureState} from '../source/source_state';\nimport {polygonIntersectsBox} from '../util/intersection_tests';\nimport {PossiblyEvaluated} from '../style/properties';\nimport {FeatureIndexArray} from './array_types.g';\nimport {mat4} from 'gl-matrix';\n\nimport type {StyleLayer} from '../style/style_layer';\nimport type {FeatureFilter, FeatureState, FilterSpecification, PromoteIdSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {Transform} from '../geo/transform';\nimport type {VectorTileFeature, VectorTileLayer} from '@mapbox/vector-tile';\n\ntype QueryParameters = {\n scale: number;\n pixelPosMatrix: mat4;\n transform: Transform;\n tileSize: number;\n queryGeometry: Array;\n cameraQueryGeometry: Array;\n queryPadding: number;\n params: {\n filter: FilterSpecification;\n layers: Array;\n availableImages: Array;\n };\n};\n\n/**\n * An in memory index class to allow fast interaction with features\n */\nexport class FeatureIndex {\n tileID: OverscaledTileID;\n x: number;\n y: number;\n z: number;\n grid: TransferableGridIndex;\n grid3D: TransferableGridIndex;\n featureIndexArray: FeatureIndexArray;\n promoteId?: PromoteIdSpecification;\n\n rawTileData: ArrayBuffer;\n bucketLayerIDs: Array>;\n\n vtLayers: {[_: string]: VectorTileLayer};\n sourceLayerCoder: DictionaryCoder;\n\n constructor(tileID: OverscaledTileID, promoteId?: PromoteIdSpecification | null) {\n this.tileID = tileID;\n this.x = tileID.canonical.x;\n this.y = tileID.canonical.y;\n this.z = tileID.canonical.z;\n this.grid = new TransferableGridIndex(EXTENT, 16, 0);\n this.grid3D = new TransferableGridIndex(EXTENT, 16, 0);\n this.featureIndexArray = new FeatureIndexArray();\n this.promoteId = promoteId;\n }\n\n insert(feature: VectorTileFeature, geometry: Array>, featureIndex: number, sourceLayerIndex: number, bucketIndex: number, is3D?: boolean) {\n const key = this.featureIndexArray.length;\n this.featureIndexArray.emplaceBack(featureIndex, sourceLayerIndex, bucketIndex);\n\n const grid = is3D ? this.grid3D : this.grid;\n\n for (let r = 0; r < geometry.length; r++) {\n const ring = geometry[r];\n\n const bbox = [Infinity, Infinity, -Infinity, -Infinity];\n for (let i = 0; i < ring.length; i++) {\n const p = ring[i];\n bbox[0] = Math.min(bbox[0], p.x);\n bbox[1] = Math.min(bbox[1], p.y);\n bbox[2] = Math.max(bbox[2], p.x);\n bbox[3] = Math.max(bbox[3], p.y);\n }\n\n if (bbox[0] < EXTENT &&\n bbox[1] < EXTENT &&\n bbox[2] >= 0 &&\n bbox[3] >= 0) {\n grid.insert(key, bbox[0], bbox[1], bbox[2], bbox[3]);\n }\n }\n }\n\n loadVTLayers(): {[_: string]: VectorTileLayer} {\n if (!this.vtLayers) {\n this.vtLayers = new vt.VectorTile(new Protobuf(this.rawTileData)).layers;\n this.sourceLayerCoder = new DictionaryCoder(this.vtLayers ? Object.keys(this.vtLayers).sort() : ['_geojsonTileLayer']);\n }\n return this.vtLayers;\n }\n\n // Finds non-symbol features in this tile at a particular position.\n query(\n args: QueryParameters,\n styleLayers: {[_: string]: StyleLayer},\n serializedLayers: {[_: string]: any},\n sourceFeatureState: SourceFeatureState\n ): {[_: string]: Array<{featureIndex: number; feature: GeoJSONFeature}>} {\n this.loadVTLayers();\n\n const params = args.params || {} as { filter: any; layers: string[]; availableImages: string[] },\n pixelsToTileUnits = EXTENT / args.tileSize / args.scale,\n filter = featureFilter(params.filter);\n\n const queryGeometry = args.queryGeometry;\n const queryPadding = args.queryPadding * pixelsToTileUnits;\n\n const bounds = getBounds(queryGeometry);\n const matching = this.grid.query(bounds.minX - queryPadding, bounds.minY - queryPadding, bounds.maxX + queryPadding, bounds.maxY + queryPadding);\n\n const cameraBounds = getBounds(args.cameraQueryGeometry);\n const matching3D = this.grid3D.query(\n cameraBounds.minX - queryPadding, cameraBounds.minY - queryPadding, cameraBounds.maxX + queryPadding, cameraBounds.maxY + queryPadding,\n (bx1, by1, bx2, by2) => {\n return polygonIntersectsBox(args.cameraQueryGeometry, bx1 - queryPadding, by1 - queryPadding, bx2 + queryPadding, by2 + queryPadding);\n });\n\n for (const key of matching3D) {\n matching.push(key);\n }\n\n matching.sort(topDownFeatureComparator);\n\n const result = {};\n let previousIndex;\n for (let k = 0; k < matching.length; k++) {\n const index = matching[k];\n\n // don't check the same feature more than once\n if (index === previousIndex) continue;\n previousIndex = index;\n\n const match = this.featureIndexArray.get(index);\n let featureGeometry = null;\n this.loadMatchingFeature(\n result,\n match.bucketIndex,\n match.sourceLayerIndex,\n match.featureIndex,\n filter,\n params.layers,\n params.availableImages,\n styleLayers,\n serializedLayers,\n sourceFeatureState,\n (feature: VectorTileFeature, styleLayer: StyleLayer, featureState: FeatureState) => {\n if (!featureGeometry) {\n featureGeometry = loadGeometry(feature);\n }\n\n return styleLayer.queryIntersectsFeature(queryGeometry, feature, featureState, featureGeometry, this.z, args.transform, pixelsToTileUnits, args.pixelPosMatrix);\n }\n );\n }\n\n return result;\n }\n\n loadMatchingFeature(\n result: {\n [_: string]: Array<{\n featureIndex: number;\n feature: GeoJSONFeature;\n intersectionZ?: boolean | number;\n }>;\n },\n bucketIndex: number,\n sourceLayerIndex: number,\n featureIndex: number,\n filter: FeatureFilter,\n filterLayerIDs: Array,\n availableImages: Array,\n styleLayers: {[_: string]: StyleLayer},\n serializedLayers: {[_: string]: any},\n sourceFeatureState?: SourceFeatureState,\n intersectionTest?: (\n feature: VectorTileFeature,\n styleLayer: StyleLayer,\n featureState: any,\n id: string | number | void\n ) => boolean | number) {\n\n const layerIDs = this.bucketLayerIDs[bucketIndex];\n if (filterLayerIDs && !arraysIntersect(filterLayerIDs, layerIDs))\n return;\n\n const sourceLayerName = this.sourceLayerCoder.decode(sourceLayerIndex);\n const sourceLayer = this.vtLayers[sourceLayerName];\n const feature = sourceLayer.feature(featureIndex);\n\n if (filter.needGeometry) {\n const evaluationFeature = toEvaluationFeature(feature, true);\n if (!filter.filter(new EvaluationParameters(this.tileID.overscaledZ), evaluationFeature, this.tileID.canonical)) {\n return;\n }\n } else if (!filter.filter(new EvaluationParameters(this.tileID.overscaledZ), feature)) {\n return;\n }\n\n const id = this.getId(feature, sourceLayerName);\n\n for (let l = 0; l < layerIDs.length; l++) {\n const layerID = layerIDs[l];\n\n if (filterLayerIDs && filterLayerIDs.indexOf(layerID) < 0) {\n continue;\n }\n\n const styleLayer = styleLayers[layerID];\n\n if (!styleLayer) continue;\n\n let featureState = {};\n if (id && sourceFeatureState) {\n // `feature-state` expression evaluation requires feature state to be available\n featureState = sourceFeatureState.getState(styleLayer.sourceLayer || '_geojsonTileLayer', id);\n }\n\n const serializedLayer = extend({}, serializedLayers[layerID]);\n\n serializedLayer.paint = evaluateProperties(serializedLayer.paint, styleLayer.paint, feature, featureState, availableImages);\n serializedLayer.layout = evaluateProperties(serializedLayer.layout, styleLayer.layout, feature, featureState, availableImages);\n\n const intersectionZ = !intersectionTest || intersectionTest(feature, styleLayer, featureState);\n if (!intersectionZ) {\n // Only applied for non-symbol features\n continue;\n }\n\n const geojsonFeature = new GeoJSONFeature(feature, this.z, this.x, this.y, id) as MapGeoJSONFeature;\n geojsonFeature.layer = serializedLayer;\n let layerResult = result[layerID];\n if (layerResult === undefined) {\n layerResult = result[layerID] = [];\n }\n layerResult.push({featureIndex, feature: geojsonFeature, intersectionZ});\n }\n }\n\n // Given a set of symbol indexes that have already been looked up,\n // return a matching set of GeoJSONFeatures\n lookupSymbolFeatures(symbolFeatureIndexes: Array,\n serializedLayers: {[_: string]: StyleLayer},\n bucketIndex: number,\n sourceLayerIndex: number,\n filterSpec: FilterSpecification,\n filterLayerIDs: Array,\n availableImages: Array,\n styleLayers: {[_: string]: StyleLayer}) {\n const result = {};\n this.loadVTLayers();\n\n const filter = featureFilter(filterSpec);\n\n for (const symbolFeatureIndex of symbolFeatureIndexes) {\n this.loadMatchingFeature(\n result,\n bucketIndex,\n sourceLayerIndex,\n symbolFeatureIndex,\n filter,\n filterLayerIDs,\n availableImages,\n styleLayers,\n serializedLayers\n );\n\n }\n return result;\n }\n\n hasLayer(id: string) {\n for (const layerIDs of this.bucketLayerIDs) {\n for (const layerID of layerIDs) {\n if (id === layerID) return true;\n }\n }\n\n return false;\n }\n\n getId(feature: VectorTileFeature, sourceLayerId: string): string | number {\n let id: string | number = feature.id;\n if (this.promoteId) {\n const propName = typeof this.promoteId === 'string' ? this.promoteId : this.promoteId[sourceLayerId];\n id = feature.properties[propName] as string | number;\n if (typeof id === 'boolean') id = Number(id);\n }\n return id;\n }\n}\n\nregister(\n 'FeatureIndex',\n FeatureIndex,\n {omit: ['rawTileData', 'sourceLayerCoder']}\n);\n\nfunction evaluateProperties(serializedProperties, styleLayerProperties, feature, featureState, availableImages) {\n return mapObject(serializedProperties, (property, key) => {\n const prop = styleLayerProperties instanceof PossiblyEvaluated ? styleLayerProperties.get(key) : null;\n return prop && prop.evaluate ? prop.evaluate(feature, featureState, availableImages) : prop;\n });\n}\n\nfunction getBounds(geometry: Array) {\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n for (const p of geometry) {\n minX = Math.min(minX, p.x);\n minY = Math.min(minY, p.y);\n maxX = Math.max(maxX, p.x);\n maxY = Math.max(maxY, p.y);\n }\n return {minX, minY, maxX, maxY};\n}\n\nfunction topDownFeatureComparator(a, b) {\n return b - a;\n}\n","import Point from '@mapbox/point-geometry';\n\n/**\n * Returns the part of a multiline that intersects with the provided rectangular box.\n *\n * @param lines - the lines to check\n * @param x1 - the left edge of the box\n * @param y1 - the top edge of the box\n * @param x2 - the right edge of the box\n * @param y2 - the bottom edge of the box\n * @returns lines\n */\nexport function clipLine(lines: Array>, x1: number, y1: number, x2: number, y2: number): Array> {\n const clippedLines = [];\n\n for (let l = 0; l < lines.length; l++) {\n const line = lines[l];\n let clippedLine;\n\n for (let i = 0; i < line.length - 1; i++) {\n let p0 = line[i];\n let p1 = line[i + 1];\n\n if (p0.x < x1 && p1.x < x1) {\n continue;\n } else if (p0.x < x1) {\n p0 = new Point(x1, p0.y + (p1.y - p0.y) * ((x1 - p0.x) / (p1.x - p0.x)))._round();\n } else if (p1.x < x1) {\n p1 = new Point(x1, p0.y + (p1.y - p0.y) * ((x1 - p0.x) / (p1.x - p0.x)))._round();\n }\n\n if (p0.y < y1 && p1.y < y1) {\n continue;\n } else if (p0.y < y1) {\n p0 = new Point(p0.x + (p1.x - p0.x) * ((y1 - p0.y) / (p1.y - p0.y)), y1)._round();\n } else if (p1.y < y1) {\n p1 = new Point(p0.x + (p1.x - p0.x) * ((y1 - p0.y) / (p1.y - p0.y)), y1)._round();\n }\n\n if (p0.x >= x2 && p1.x >= x2) {\n continue;\n } else if (p0.x >= x2) {\n p0 = new Point(x2, p0.y + (p1.y - p0.y) * ((x2 - p0.x) / (p1.x - p0.x)))._round();\n } else if (p1.x >= x2) {\n p1 = new Point(x2, p0.y + (p1.y - p0.y) * ((x2 - p0.x) / (p1.x - p0.x)))._round();\n }\n\n if (p0.y >= y2 && p1.y >= y2) {\n continue;\n } else if (p0.y >= y2) {\n p0 = new Point(p0.x + (p1.x - p0.x) * ((y2 - p0.y) / (p1.y - p0.y)), y2)._round();\n } else if (p1.y >= y2) {\n p1 = new Point(p0.x + (p1.x - p0.x) * ((y2 - p0.y) / (p1.y - p0.y)), y2)._round();\n }\n\n if (!clippedLine || !p0.equals(clippedLine[clippedLine.length - 1])) {\n clippedLine = [p0];\n clippedLines.push(clippedLine);\n }\n\n clippedLine.push(p1);\n }\n }\n\n return clippedLines;\n}\n","import Point from '@mapbox/point-geometry';\n\nimport {register} from '../util/web_worker_transfer';\n\nexport class Anchor extends Point {\n angle: any;\n segment?: number;\n\n constructor(x: number, y: number, angle: number, segment?: number) {\n super(x, y);\n this.angle = angle;\n if (segment !== undefined) {\n this.segment = segment;\n }\n }\n\n clone() {\n return new Anchor(this.x, this.y, this.angle, this.segment);\n }\n}\n\nregister('Anchor', Anchor);\n","import type Point from '@mapbox/point-geometry';\nimport type {Anchor} from './anchor';\n\n/**\n * Labels placed around really sharp angles aren't readable. Check if any\n * part of the potential label has a combined angle that is too big.\n *\n * @param line - The line to check\n * @param anchor - The point on the line around which the label is anchored.\n * @param labelLength - The length of the label in geometry units.\n * @param windowSize - The check fails if the combined angles within a part of the line that is `windowSize` long is too big.\n * @param maxAngle - The maximum combined angle that any window along the label is allowed to have.\n *\n * @returns whether the label should be placed\n */\nexport function checkMaxAngle(line: Array, anchor: Anchor, labelLength: number, windowSize: number, maxAngle: number) {\n\n // horizontal labels and labels with length 0 always pass\n if (anchor.segment === undefined || labelLength === 0) return true;\n\n let p = anchor;\n let index = anchor.segment + 1;\n let anchorDistance = 0;\n\n // move backwards along the line to the first segment the label appears on\n while (anchorDistance > -labelLength / 2) {\n index--;\n\n // there isn't enough room for the label after the beginning of the line\n if (index < 0) return false;\n\n anchorDistance -= line[index].dist(p);\n p = line[index];\n }\n\n anchorDistance += line[index].dist(line[index + 1]);\n index++;\n\n // store recent corners and their total angle difference\n const recentCorners = [];\n let recentAngleDelta = 0;\n\n // move forwards by the length of the label and check angles along the way\n while (anchorDistance < labelLength / 2) {\n const prev = line[index - 1];\n const current = line[index];\n const next = line[index + 1];\n\n // there isn't enough room for the label before the end of the line\n if (!next) return false;\n\n let angleDelta = prev.angleTo(current) - current.angleTo(next);\n // restrict angle to -pi..pi range\n angleDelta = Math.abs(((angleDelta + 3 * Math.PI) % (Math.PI * 2)) - Math.PI);\n\n recentCorners.push({\n distance: anchorDistance,\n angleDelta\n });\n recentAngleDelta += angleDelta;\n\n // remove corners that are far enough away from the list of recent anchors\n while (anchorDistance - recentCorners[0].distance > windowSize) {\n recentAngleDelta -= recentCorners.shift().angleDelta;\n }\n\n // the sum of angles within the window area exceeds the maximum allowed value. check fails.\n if (recentAngleDelta > maxAngle) return false;\n\n index++;\n anchorDistance += current.dist(next);\n }\n\n // no part of the line had an angle greater than the maximum allowed. check passes.\n return true;\n}\n","import {interpolates} from '@maplibre/maplibre-gl-style-spec';\n\nimport {Anchor} from '../symbol/anchor';\nimport {checkMaxAngle} from './check_max_angle';\n\nimport type Point from '@mapbox/point-geometry';\nimport type {Shaping, PositionedIcon} from './shaping';\n\nexport {getAnchors, getCenterAnchor};\n\nfunction getLineLength(line: Array): number {\n let lineLength = 0;\n for (let k = 0; k < line.length - 1; k++) {\n lineLength += line[k].dist(line[k + 1]);\n }\n return lineLength;\n}\n\nfunction getAngleWindowSize(\n shapedText: Shaping,\n glyphSize: number,\n boxScale: number\n): number {\n return shapedText ?\n 3 / 5 * glyphSize * boxScale :\n 0;\n}\n\nfunction getShapedLabelLength(shapedText?: Shaping | null, shapedIcon?: PositionedIcon | null): number {\n return Math.max(\n shapedText ? shapedText.right - shapedText.left : 0,\n shapedIcon ? shapedIcon.right - shapedIcon.left : 0);\n}\n\nfunction getCenterAnchor(line: Array,\n maxAngle: number,\n shapedText: Shaping,\n shapedIcon: PositionedIcon,\n glyphSize: number,\n boxScale: number) {\n const angleWindowSize = getAngleWindowSize(shapedText, glyphSize, boxScale);\n const labelLength = getShapedLabelLength(shapedText, shapedIcon) * boxScale;\n\n let prevDistance = 0;\n const centerDistance = getLineLength(line) / 2;\n\n for (let i = 0; i < line.length - 1; i++) {\n\n const a = line[i],\n b = line[i + 1];\n\n const segmentDistance = a.dist(b);\n\n if (prevDistance + segmentDistance > centerDistance) {\n // The center is on this segment\n const t = (centerDistance - prevDistance) / segmentDistance,\n x = interpolates.number(a.x, b.x, t),\n y = interpolates.number(a.y, b.y, t);\n\n const anchor = new Anchor(x, y, b.angleTo(a), i);\n anchor._round();\n if (!angleWindowSize || checkMaxAngle(line, anchor, labelLength, angleWindowSize, maxAngle)) {\n return anchor;\n } else {\n return;\n }\n }\n\n prevDistance += segmentDistance;\n }\n}\n\nfunction getAnchors(line: Array,\n spacing: number,\n maxAngle: number,\n shapedText: Shaping,\n shapedIcon: PositionedIcon,\n glyphSize: number,\n boxScale: number,\n overscaling: number,\n tileExtent: number) {\n\n // Resample a line to get anchor points for labels and check that each\n // potential label passes text-max-angle check and has enough room to fit\n // on the line.\n\n const angleWindowSize = getAngleWindowSize(shapedText, glyphSize, boxScale);\n const shapedLabelLength = getShapedLabelLength(shapedText, shapedIcon);\n const labelLength = shapedLabelLength * boxScale;\n\n // Is the line continued from outside the tile boundary?\n const isLineContinued = line[0].x === 0 || line[0].x === tileExtent || line[0].y === 0 || line[0].y === tileExtent;\n\n // Is the label long, relative to the spacing?\n // If so, adjust the spacing so there is always a minimum space of `spacing / 4` between label edges.\n if (spacing - labelLength < spacing / 4) {\n spacing = labelLength + spacing / 4;\n }\n\n // Offset the first anchor by:\n // Either half the label length plus a fixed extra offset if the line is not continued\n // Or half the spacing if the line is continued.\n\n // For non-continued lines, add a bit of fixed extra offset to avoid collisions at T intersections.\n const fixedExtraOffset = glyphSize * 2;\n\n const offset = !isLineContinued ?\n ((shapedLabelLength / 2 + fixedExtraOffset) * boxScale * overscaling) % spacing :\n (spacing / 2 * overscaling) % spacing;\n\n return resample(line, offset, spacing, angleWindowSize, maxAngle, labelLength, isLineContinued, false, tileExtent);\n}\n\nfunction resample(line, offset, spacing, angleWindowSize, maxAngle, labelLength, isLineContinued, placeAtMiddle, tileExtent) {\n\n const halfLabelLength = labelLength / 2;\n const lineLength = getLineLength(line);\n\n let distance = 0,\n markedDistance = offset - spacing;\n\n let anchors = [];\n\n for (let i = 0; i < line.length - 1; i++) {\n\n const a = line[i],\n b = line[i + 1];\n\n const segmentDist = a.dist(b),\n angle = b.angleTo(a);\n\n while (markedDistance + spacing < distance + segmentDist) {\n markedDistance += spacing;\n\n const t = (markedDistance - distance) / segmentDist,\n x = interpolates.number(a.x, b.x, t),\n y = interpolates.number(a.y, b.y, t);\n\n // Check that the point is within the tile boundaries and that\n // the label would fit before the beginning and end of the line\n // if placed at this point.\n if (x >= 0 && x < tileExtent && y >= 0 && y < tileExtent &&\n markedDistance - halfLabelLength >= 0 &&\n markedDistance + halfLabelLength <= lineLength) {\n const anchor = new Anchor(x, y, angle, i);\n anchor._round();\n\n if (!angleWindowSize || checkMaxAngle(line, anchor, labelLength, angleWindowSize, maxAngle)) {\n anchors.push(anchor);\n }\n }\n }\n\n distance += segmentDist;\n }\n\n if (!placeAtMiddle && !anchors.length && !isLineContinued) {\n // The first attempt at finding anchors at which labels can be placed failed.\n // Try again, but this time just try placing one anchor at the middle of the line.\n // This has the most effect for short lines in overscaled tiles, since the\n // initial offset used in overscaled tiles is calculated to align labels with positions in\n // parent tiles instead of placing the label as close to the beginning as possible.\n anchors = resample(line, distance / 2, spacing, angleWindowSize, maxAngle, labelLength, isLineContinued, true, tileExtent);\n }\n\n return anchors;\n}\n","import Point from '@mapbox/point-geometry';\n\nimport {GLYPH_PBF_BORDER} from '../style/parse_glyph_pbf';\n\nimport type {Anchor} from './anchor';\nimport type {Box, PositionedIcon, Shaping} from './shaping';\nimport {SHAPING_DEFAULT_OFFSET, applyTextFit} from './shaping';\nimport {IMAGE_PADDING} from '../render/image_atlas';\nimport type {SymbolStyleLayer} from '../style/style_layer/symbol_style_layer';\nimport type {Feature} from '@maplibre/maplibre-gl-style-spec';\nimport type {StyleImage} from '../style/style_image';\nimport ONE_EM from './one_em';\nimport {Rect} from '../render/glyph_atlas';\n\n/**\n * A textured quad for rendering a single icon or glyph.\n *\n * The zoom range the glyph can be shown is defined by minScale and maxScale.\n *\n * @param tl - The offset of the top left corner from the anchor.\n * @param tr - The offset of the top right corner from the anchor.\n * @param bl - The offset of the bottom left corner from the anchor.\n * @param br - The offset of the bottom right corner from the anchor.\n * @param tex - The texture coordinates.\n */\nexport type SymbolQuad = {\n tl: Point;\n tr: Point;\n bl: Point;\n br: Point;\n tex: {\n x: number;\n y: number;\n w: number;\n h: number;\n };\n pixelOffsetTL: Point;\n pixelOffsetBR: Point;\n writingMode: any | void;\n glyphOffset: [number, number];\n sectionIndex: number;\n isSDF: boolean;\n minFontScaleX: number;\n minFontScaleY: number;\n};\n\n// If you have a 10px icon that isn't perfectly aligned to the pixel grid it will cover 11 actual\n// pixels. The quad needs to be padded to account for this, otherwise they'll look slightly clipped\n// on one edge in some cases.\nconst border = IMAGE_PADDING;\n\n/**\n * Create the quads used for rendering an icon.\n */\nexport function getIconQuads(\n shapedIcon: PositionedIcon,\n iconRotate: number,\n isSDFIcon: boolean,\n hasIconTextFit: boolean\n): Array {\n const quads = [];\n\n const image = shapedIcon.image;\n const pixelRatio = image.pixelRatio;\n const imageWidth = image.paddedRect.w - 2 * border;\n const imageHeight = image.paddedRect.h - 2 * border;\n\n let icon: Box = {\n x1: shapedIcon.left,\n y1: shapedIcon.top,\n x2: shapedIcon.right,\n y2: shapedIcon.bottom\n };\n\n const stretchX = image.stretchX || [[0, imageWidth]];\n const stretchY = image.stretchY || [[0, imageHeight]];\n\n const reduceRanges = (sum, range) => sum + range[1] - range[0];\n const stretchWidth = stretchX.reduce(reduceRanges, 0);\n const stretchHeight = stretchY.reduce(reduceRanges, 0);\n const fixedWidth = imageWidth - stretchWidth;\n const fixedHeight = imageHeight - stretchHeight;\n\n let stretchOffsetX = 0;\n let stretchContentWidth = stretchWidth;\n let stretchOffsetY = 0;\n let stretchContentHeight = stretchHeight;\n let fixedOffsetX = 0;\n let fixedContentWidth = fixedWidth;\n let fixedOffsetY = 0;\n let fixedContentHeight = fixedHeight;\n\n if (image.content && hasIconTextFit) {\n const content = image.content;\n const contentWidth = content[2] - content[0];\n const contentHeight = content[3] - content[1];\n // Constrict content area to fit target aspect ratio\n if (image.textFitWidth || image.textFitHeight) {\n icon = applyTextFit(shapedIcon);\n }\n stretchOffsetX = sumWithinRange(stretchX, 0, content[0]);\n stretchOffsetY = sumWithinRange(stretchY, 0, content[1]);\n stretchContentWidth = sumWithinRange(stretchX, content[0], content[2]);\n stretchContentHeight = sumWithinRange(stretchY, content[1], content[3]);\n fixedOffsetX = content[0] - stretchOffsetX;\n fixedOffsetY = content[1] - stretchOffsetY;\n fixedContentWidth = contentWidth - stretchContentWidth;\n fixedContentHeight = contentHeight - stretchContentHeight;\n }\n\n const iconLeft = icon.x1;\n const iconTop = icon.y1;\n const iconWidth = icon.x2 - iconLeft;\n const iconHeight = icon.y2 - iconTop;\n\n const makeBox = (left, top, right, bottom) => {\n\n const leftEm = getEmOffset(left.stretch - stretchOffsetX, stretchContentWidth, iconWidth, iconLeft);\n const leftPx = getPxOffset(left.fixed - fixedOffsetX, fixedContentWidth, left.stretch, stretchWidth);\n\n const topEm = getEmOffset(top.stretch - stretchOffsetY, stretchContentHeight, iconHeight, iconTop);\n const topPx = getPxOffset(top.fixed - fixedOffsetY, fixedContentHeight, top.stretch, stretchHeight);\n\n const rightEm = getEmOffset(right.stretch - stretchOffsetX, stretchContentWidth, iconWidth, iconLeft);\n const rightPx = getPxOffset(right.fixed - fixedOffsetX, fixedContentWidth, right.stretch, stretchWidth);\n\n const bottomEm = getEmOffset(bottom.stretch - stretchOffsetY, stretchContentHeight, iconHeight, iconTop);\n const bottomPx = getPxOffset(bottom.fixed - fixedOffsetY, fixedContentHeight, bottom.stretch, stretchHeight);\n\n const tl = new Point(leftEm, topEm);\n const tr = new Point(rightEm, topEm);\n const br = new Point(rightEm, bottomEm);\n const bl = new Point(leftEm, bottomEm);\n const pixelOffsetTL = new Point(leftPx / pixelRatio, topPx / pixelRatio);\n const pixelOffsetBR = new Point(rightPx / pixelRatio, bottomPx / pixelRatio);\n\n const angle = iconRotate * Math.PI / 180;\n\n if (angle) {\n const sin = Math.sin(angle),\n cos = Math.cos(angle),\n matrix = [cos, -sin, sin, cos];\n\n tl._matMult(matrix);\n tr._matMult(matrix);\n bl._matMult(matrix);\n br._matMult(matrix);\n }\n\n const x1 = left.stretch + left.fixed;\n const x2 = right.stretch + right.fixed;\n const y1 = top.stretch + top.fixed;\n const y2 = bottom.stretch + bottom.fixed;\n\n const subRect = {\n x: image.paddedRect.x + border + x1,\n y: image.paddedRect.y + border + y1,\n w: x2 - x1,\n h: y2 - y1\n };\n\n const minFontScaleX = fixedContentWidth / pixelRatio / iconWidth;\n const minFontScaleY = fixedContentHeight / pixelRatio / iconHeight;\n\n // Icon quad is padded, so texture coordinates also need to be padded.\n return {tl, tr, bl, br, tex: subRect, writingMode: undefined, glyphOffset: [0, 0], sectionIndex: 0, pixelOffsetTL, pixelOffsetBR, minFontScaleX, minFontScaleY, isSDF: isSDFIcon};\n };\n\n if (!hasIconTextFit || (!image.stretchX && !image.stretchY)) {\n quads.push(makeBox(\n {fixed: 0, stretch: -1},\n {fixed: 0, stretch: -1},\n {fixed: 0, stretch: imageWidth + 1},\n {fixed: 0, stretch: imageHeight + 1}));\n } else {\n const xCuts = stretchZonesToCuts(stretchX, fixedWidth, stretchWidth);\n const yCuts = stretchZonesToCuts(stretchY, fixedHeight, stretchHeight);\n\n for (let xi = 0; xi < xCuts.length - 1; xi++) {\n const x1 = xCuts[xi];\n const x2 = xCuts[xi + 1];\n for (let yi = 0; yi < yCuts.length - 1; yi++) {\n const y1 = yCuts[yi];\n const y2 = yCuts[yi + 1];\n quads.push(makeBox(x1, y1, x2, y2));\n }\n }\n }\n\n return quads;\n}\n\nfunction sumWithinRange(ranges, min, max) {\n let sum = 0;\n for (const range of ranges) {\n sum += Math.max(min, Math.min(max, range[1])) - Math.max(min, Math.min(max, range[0]));\n }\n return sum;\n}\n\nfunction stretchZonesToCuts(stretchZones, fixedSize, stretchSize) {\n const cuts = [{fixed: -border, stretch: 0}];\n\n for (const [c1, c2] of stretchZones) {\n const last = cuts[cuts.length - 1];\n cuts.push({\n fixed: c1 - last.stretch,\n stretch: last.stretch\n });\n cuts.push({\n fixed: c1 - last.stretch,\n stretch: last.stretch + (c2 - c1)\n });\n }\n cuts.push({\n fixed: fixedSize + border,\n stretch: stretchSize\n });\n return cuts;\n}\n\nfunction getEmOffset(stretchOffset, stretchSize, iconSize, iconOffset) {\n return stretchOffset / stretchSize * iconSize + iconOffset;\n}\n\nfunction getPxOffset(fixedOffset, fixedSize, stretchOffset, stretchSize) {\n return fixedOffset - fixedSize * stretchOffset / stretchSize;\n}\n\n/**\n * Create the quads used for rendering a text label.\n */\nexport function getGlyphQuads(\n anchor: Anchor,\n shaping: Shaping,\n textOffset: [number, number],\n layer: SymbolStyleLayer,\n alongLine: boolean,\n feature: Feature,\n imageMap: {[_: string]: StyleImage},\n allowVerticalPlacement: boolean\n): Array {\n\n const textRotate = layer.layout.get('text-rotate').evaluate(feature, {}) * Math.PI / 180;\n const quads = [];\n\n for (const line of shaping.positionedLines) {\n for (const positionedGlyph of line.positionedGlyphs) {\n if (!positionedGlyph.rect) continue;\n const textureRect: Rect = positionedGlyph.rect || {} as Rect;\n\n // The rects have an additional buffer that is not included in their size.\n const glyphPadding = 1.0;\n let rectBuffer = GLYPH_PBF_BORDER + glyphPadding;\n let isSDF = true;\n let pixelRatio = 1.0;\n let lineOffset = 0.0;\n\n const rotateVerticalGlyph = (alongLine || allowVerticalPlacement) && positionedGlyph.vertical;\n const halfAdvance = positionedGlyph.metrics.advance * positionedGlyph.scale / 2;\n\n // Align images and scaled glyphs in the middle of a vertical line.\n if (allowVerticalPlacement && shaping.verticalizable) {\n const scaledGlyphOffset = (positionedGlyph.scale - 1) * ONE_EM;\n const imageOffset = (ONE_EM - positionedGlyph.metrics.width * positionedGlyph.scale) / 2;\n lineOffset = line.lineOffset / 2 - (positionedGlyph.imageName ? -imageOffset : scaledGlyphOffset);\n }\n\n if (positionedGlyph.imageName) {\n const image = imageMap[positionedGlyph.imageName];\n isSDF = image.sdf;\n pixelRatio = image.pixelRatio;\n rectBuffer = IMAGE_PADDING / pixelRatio;\n }\n\n const glyphOffset = alongLine ?\n [positionedGlyph.x + halfAdvance, positionedGlyph.y] :\n [0, 0];\n\n let builtInOffset: [number, number] = alongLine ?\n [0, 0] :\n [positionedGlyph.x + halfAdvance + textOffset[0], positionedGlyph.y + textOffset[1] - lineOffset];\n\n let verticalizedLabelOffset = [0, 0] as [number, number];\n if (rotateVerticalGlyph) {\n // Vertical POI labels that are rotated 90deg CW and whose glyphs must preserve upright orientation\n // need to be rotated 90deg CCW. After a quad is rotated, it is translated to the original built-in offset.\n verticalizedLabelOffset = builtInOffset;\n builtInOffset = [0, 0];\n }\n\n const textureScale = positionedGlyph.metrics.isDoubleResolution ? 2 : 1;\n\n const x1 = (positionedGlyph.metrics.left - rectBuffer) * positionedGlyph.scale - halfAdvance + builtInOffset[0];\n const y1 = (-positionedGlyph.metrics.top - rectBuffer) * positionedGlyph.scale + builtInOffset[1];\n const x2 = x1 + textureRect.w / textureScale * positionedGlyph.scale / pixelRatio;\n const y2 = y1 + textureRect.h / textureScale * positionedGlyph.scale / pixelRatio;\n\n const tl = new Point(x1, y1);\n const tr = new Point(x2, y1);\n const bl = new Point(x1, y2);\n const br = new Point(x2, y2);\n\n if (rotateVerticalGlyph) {\n // Vertical-supporting glyphs are laid out in 24x24 point boxes (1 square em)\n // In horizontal orientation, the y values for glyphs are below the midline\n // and we use a \"yOffset\" of -17 to pull them up to the middle.\n // By rotating counter-clockwise around the point at the center of the left\n // edge of a 24x24 layout box centered below the midline, we align the center\n // of the glyphs with the horizontal midline, so the yOffset is no longer\n // necessary, but we also pull the glyph to the left along the x axis.\n // The y coordinate includes baseline yOffset, thus needs to be accounted\n // for when glyph is rotated and translated.\n const center = new Point(-halfAdvance, halfAdvance - SHAPING_DEFAULT_OFFSET);\n const verticalRotation = -Math.PI / 2;\n\n // xHalfWidthOffsetCorrection is a difference between full-width and half-width\n // advance, should be 0 for full-width glyphs and will pull up half-width glyphs.\n const xHalfWidthOffsetCorrection = ONE_EM / 2 - halfAdvance;\n const yImageOffsetCorrection = positionedGlyph.imageName ? xHalfWidthOffsetCorrection : 0.0;\n const halfWidthOffsetCorrection = new Point(5 - SHAPING_DEFAULT_OFFSET - xHalfWidthOffsetCorrection, -yImageOffsetCorrection);\n const verticalOffsetCorrection = new Point(...verticalizedLabelOffset);\n tl._rotateAround(verticalRotation, center)._add(halfWidthOffsetCorrection)._add(verticalOffsetCorrection);\n tr._rotateAround(verticalRotation, center)._add(halfWidthOffsetCorrection)._add(verticalOffsetCorrection);\n bl._rotateAround(verticalRotation, center)._add(halfWidthOffsetCorrection)._add(verticalOffsetCorrection);\n br._rotateAround(verticalRotation, center)._add(halfWidthOffsetCorrection)._add(verticalOffsetCorrection);\n }\n\n if (textRotate) {\n const sin = Math.sin(textRotate),\n cos = Math.cos(textRotate),\n matrix = [cos, -sin, sin, cos];\n\n tl._matMult(matrix);\n tr._matMult(matrix);\n bl._matMult(matrix);\n br._matMult(matrix);\n }\n\n const pixelOffsetTL = new Point(0, 0);\n const pixelOffsetBR = new Point(0, 0);\n const minFontScaleX = 0;\n const minFontScaleY = 0;\n quads.push({tl, tr, bl, br, tex: textureRect, writingMode: shaping.writingMode, glyphOffset, sectionIndex: positionedGlyph.sectionIndex, isSDF, pixelOffsetTL, pixelOffsetBR, minFontScaleX, minFontScaleY});\n }\n }\n\n return quads;\n}\n","import type {CollisionBoxArray} from '../data/array_types.g';\nimport Point from '@mapbox/point-geometry';\nimport type {Anchor} from './anchor';\nimport {SymbolPadding} from '../style/style_layer/symbol_style_layer';\nimport {applyTextFit} from './shaping';\n\n/**\n * A CollisionFeature represents the area of the tile covered by a single label.\n * It is used with CollisionIndex to check if the label overlaps with any\n * previous labels. A CollisionFeature is mostly just a set of CollisionBox\n * objects.\n */\nexport class CollisionFeature {\n boxStartIndex: number;\n boxEndIndex: number;\n circleDiameter: number;\n\n /**\n * Create a CollisionFeature, adding its collision box data to the given collisionBoxArray in the process.\n * For line aligned labels a collision circle diameter is computed instead.\n *\n * @param anchor - The point along the line around which the label is anchored.\n * @param shaped - The text or icon shaping results.\n * @param boxScale - A magic number used to convert from glyph metrics units to geometry units.\n * @param padding - The amount of padding to add around the label edges.\n * @param alignLine - Whether the label is aligned with the line or the viewport.\n */\n constructor(collisionBoxArray: CollisionBoxArray,\n anchor: Anchor,\n featureIndex: number,\n sourceLayerIndex: number,\n bucketIndex: number,\n shaped: any,\n boxScale: number,\n padding: SymbolPadding,\n alignLine: boolean,\n rotate: number) {\n\n this.boxStartIndex = collisionBoxArray.length;\n\n if (alignLine) {\n // Compute height of the shape in glyph metrics and apply collision padding.\n // Note that the pixel based 'text-padding' is applied at runtime\n let top = shaped.top;\n let bottom = shaped.bottom;\n const collisionPadding = shaped.collisionPadding;\n\n if (collisionPadding) {\n top -= collisionPadding[1];\n bottom += collisionPadding[3];\n }\n\n let height = bottom - top;\n\n if (height > 0) {\n // set minimum box height to avoid very many small labels\n height = Math.max(10, height);\n this.circleDiameter = height;\n }\n } else {\n const icon = shaped.image?.content && (shaped.image.textFitWidth || shaped.image.textFitHeight) ?\n applyTextFit(shaped) :\n {\n x1: shaped.left,\n y1: shaped.top,\n x2: shaped.right,\n y2: shaped.bottom\n };\n\n // margin is in CSS order: [top, right, bottom, left]\n icon.y1 = icon.y1 * boxScale - padding[0];\n icon.y2 = icon.y2 * boxScale + padding[2];\n icon.x1 = icon.x1 * boxScale - padding[3];\n icon.x2 = icon.x2 * boxScale + padding[1];\n\n const collisionPadding = shaped.collisionPadding;\n if (collisionPadding) {\n icon.x1 -= collisionPadding[0] * boxScale;\n icon.y1 -= collisionPadding[1] * boxScale;\n icon.x2 += collisionPadding[2] * boxScale;\n icon.y2 += collisionPadding[3] * boxScale;\n }\n\n if (rotate) {\n // Account for *-rotate in point collision boxes\n // See https://github.com/mapbox/mapbox-gl-js/issues/6075\n // Doesn't account for icon-text-fit\n\n const tl = new Point(icon.x1, icon.y1);\n const tr = new Point(icon.x2, icon.y1);\n const bl = new Point(icon.x1, icon.y2);\n const br = new Point(icon.x2, icon.y2);\n\n const rotateRadians = rotate * Math.PI / 180;\n\n tl._rotate(rotateRadians);\n tr._rotate(rotateRadians);\n bl._rotate(rotateRadians);\n br._rotate(rotateRadians);\n\n // Collision features require an \"on-axis\" geometry,\n // so take the envelope of the rotated geometry\n // (may be quite large for wide labels rotated 45 degrees)\n icon.x1 = Math.min(tl.x, tr.x, bl.x, br.x);\n icon.x2 = Math.max(tl.x, tr.x, bl.x, br.x);\n icon.y1 = Math.min(tl.y, tr.y, bl.y, br.y);\n icon.y2 = Math.max(tl.y, tr.y, bl.y, br.y);\n }\n collisionBoxArray.emplaceBack(anchor.x, anchor.y, icon.x1, icon.y1, icon.x2, icon.y2, featureIndex, sourceLayerIndex, bucketIndex);\n }\n\n this.boxEndIndex = collisionBoxArray.length;\n }\n}\n","\nexport default class TinyQueue {\n constructor(data = [], compare = (a, b) => (a < b ? -1 : a > b ? 1 : 0)) {\n this.data = data;\n this.length = this.data.length;\n this.compare = compare;\n\n if (this.length > 0) {\n for (let i = (this.length >> 1) - 1; i >= 0; i--) this._down(i);\n }\n }\n\n push(item) {\n this.data.push(item);\n this._up(this.length++);\n }\n\n pop() {\n if (this.length === 0) return undefined;\n\n const top = this.data[0];\n const bottom = this.data.pop();\n\n if (--this.length > 0) {\n this.data[0] = bottom;\n this._down(0);\n }\n\n return top;\n }\n\n peek() {\n return this.data[0];\n }\n\n _up(pos) {\n const {data, compare} = this;\n const item = data[pos];\n\n while (pos > 0) {\n const parent = (pos - 1) >> 1;\n const current = data[parent];\n if (compare(item, current) >= 0) break;\n data[pos] = current;\n pos = parent;\n }\n\n data[pos] = item;\n }\n\n _down(pos) {\n const {data, compare} = this;\n const halfLength = this.length >> 1;\n const item = data[pos];\n\n while (pos < halfLength) {\n let bestChild = (pos << 1) + 1; // initially it is the left child\n const right = bestChild + 1;\n\n if (right < this.length && compare(data[right], data[bestChild]) < 0) {\n bestChild = right;\n }\n if (compare(data[bestChild], item) >= 0) break;\n\n data[pos] = data[bestChild];\n pos = bestChild;\n }\n\n data[pos] = item;\n }\n}\n","import Queue from 'tinyqueue';\n\nimport Point from '@mapbox/point-geometry';\nimport {distToSegmentSquared} from './intersection_tests';\n\n/**\n * Finds an approximation of a polygon's Pole Of Inaccessibility https://en.wikipedia.org/wiki/Pole_of_inaccessibility\n * This is a copy of https://github.com/mapbox/polylabel adapted to use Points\n *\n * @param polygonRings - first item in array is the outer ring followed optionally by the list of holes, should be an element of the result of util/classify_rings\n * @param precision - Specified in input coordinate units. If 0 returns after first run, if `> 0` repeatedly narrows the search space until the radius of the area searched for the best pole is less than precision\n * @param debug - Print some statistics to the console during execution\n * @returns Pole of Inaccessibility.\n */\nexport function findPoleOfInaccessibility(\n polygonRings: Array>,\n precision: number = 1,\n debug: boolean = false\n): Point {\n // find the bounding box of the outer ring\n let minX = Infinity, minY = Infinity, maxX = -Infinity, maxY = -Infinity;\n const outerRing = polygonRings[0];\n for (let i = 0; i < outerRing.length; i++) {\n const p = outerRing[i];\n if (!i || p.x < minX) minX = p.x;\n if (!i || p.y < minY) minY = p.y;\n if (!i || p.x > maxX) maxX = p.x;\n if (!i || p.y > maxY) maxY = p.y;\n }\n\n const width = maxX - minX;\n const height = maxY - minY;\n const cellSize = Math.min(width, height);\n let h = cellSize / 2;\n\n // a priority queue of cells in order of their \"potential\" (max distance to polygon)\n const cellQueue = new Queue([], compareMax);\n\n if (cellSize === 0) return new Point(minX, minY);\n\n // cover polygon with initial cells\n for (let x = minX; x < maxX; x += cellSize) {\n for (let y = minY; y < maxY; y += cellSize) {\n cellQueue.push(new Cell(x + h, y + h, h, polygonRings));\n }\n }\n\n // take centroid as the first best guess\n let bestCell = getCentroidCell(polygonRings);\n let numProbes = cellQueue.length;\n\n while (cellQueue.length) {\n // pick the most promising cell from the queue\n const cell = cellQueue.pop();\n\n // update the best cell if we found a better one\n if (cell.d > bestCell.d || !bestCell.d) {\n bestCell = cell;\n if (debug) console.log('found best %d after %d probes', Math.round(1e4 * cell.d) / 1e4, numProbes);\n }\n\n // do not drill down further if there's no chance of a better solution\n if (cell.max - bestCell.d <= precision) continue;\n\n // split the cell into four cells\n h = cell.h / 2;\n cellQueue.push(new Cell(cell.p.x - h, cell.p.y - h, h, polygonRings));\n cellQueue.push(new Cell(cell.p.x + h, cell.p.y - h, h, polygonRings));\n cellQueue.push(new Cell(cell.p.x - h, cell.p.y + h, h, polygonRings));\n cellQueue.push(new Cell(cell.p.x + h, cell.p.y + h, h, polygonRings));\n numProbes += 4;\n }\n\n if (debug) {\n console.log(`num probes: ${numProbes}`);\n console.log(`best distance: ${bestCell.d}`);\n }\n\n return bestCell.p;\n}\n\nfunction compareMax(a, b) {\n return b.max - a.max;\n}\n\nfunction Cell(x, y, h, polygon) {\n this.p = new Point(x, y);\n this.h = h; // half the cell size\n this.d = pointToPolygonDist(this.p, polygon); // distance from cell center to polygon\n this.max = this.d + this.h * Math.SQRT2; // max distance to polygon within a cell\n}\n\n// signed distance from point to polygon outline (negative if point is outside)\nfunction pointToPolygonDist(p, polygon) {\n let inside = false;\n let minDistSq = Infinity;\n\n for (let k = 0; k < polygon.length; k++) {\n const ring = polygon[k];\n\n for (let i = 0, len = ring.length, j = len - 1; i < len; j = i++) {\n const a = ring[i];\n const b = ring[j];\n\n if ((a.y > p.y !== b.y > p.y) &&\n (p.x < (b.x - a.x) * (p.y - a.y) / (b.y - a.y) + a.x)) inside = !inside;\n\n minDistSq = Math.min(minDistSq, distToSegmentSquared(p, a, b));\n }\n }\n\n return (inside ? 1 : -1) * Math.sqrt(minDistSq);\n}\n\n// get polygon centroid\nfunction getCentroidCell(polygon) {\n let area = 0;\n let x = 0;\n let y = 0;\n const points = polygon[0];\n for (let i = 0, len = points.length, j = len - 1; i < len; j = i++) {\n const a = points[i];\n const b = points[j];\n const f = a.x * b.y - b.x * a.y;\n x += (a.x + b.x) * f;\n y += (a.y + b.y) * f;\n area += f * 3;\n }\n return new Cell(x / area, y / area, 0, polygon);\n}\n","import {VariableAnchorOffsetCollection, VariableAnchorOffsetCollectionSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport {SymbolFeature} from '../../data/bucket/symbol_bucket';\nimport {CanonicalTileID} from '../../source/tile_id';\nimport ONE_EM from '../../symbol/one_em';\nimport {SymbolStyleLayer} from './symbol_style_layer';\n\nexport enum TextAnchorEnum {\n 'center' = 1,\n 'left' = 2,\n 'right' = 3,\n 'top' = 4,\n 'bottom' = 5,\n 'top-left' = 6,\n 'top-right' = 7,\n 'bottom-left' = 8,\n 'bottom-right' = 9\n}\n\nexport type TextAnchor = keyof typeof TextAnchorEnum;\n\n// The radial offset is to the edge of the text box\n// In the horizontal direction, the edge of the text box is where glyphs start\n// But in the vertical direction, the glyphs appear to \"start\" at the baseline\n// We don't actually load baseline data, but we assume an offset of ONE_EM - 17\n// (see \"yOffset\" in shaping.js)\nconst baselineOffset = 7;\nexport const INVALID_TEXT_OFFSET = Number.POSITIVE_INFINITY;\n\nexport function evaluateVariableOffset(anchor: TextAnchor, offset: [number, number]): [number, number] {\n\n function fromRadialOffset(anchor: TextAnchor, radialOffset: number): [number, number] {\n let x = 0, y = 0;\n if (radialOffset < 0) radialOffset = 0; // Ignore negative offset.\n // solve for r where r^2 + r^2 = radialOffset^2\n const hypotenuse = radialOffset / Math.SQRT2;\n switch (anchor) {\n case 'top-right':\n case 'top-left':\n y = hypotenuse - baselineOffset;\n break;\n case 'bottom-right':\n case 'bottom-left':\n y = -hypotenuse + baselineOffset;\n break;\n case 'bottom':\n y = -radialOffset + baselineOffset;\n break;\n case 'top':\n y = radialOffset - baselineOffset;\n break;\n }\n\n switch (anchor) {\n case 'top-right':\n case 'bottom-right':\n x = -hypotenuse;\n break;\n case 'top-left':\n case 'bottom-left':\n x = hypotenuse;\n break;\n case 'left':\n x = radialOffset;\n break;\n case 'right':\n x = -radialOffset;\n break;\n }\n\n return [x, y];\n }\n\n function fromTextOffset(anchor: TextAnchor, offsetX: number, offsetY: number): [number, number] {\n let x = 0, y = 0;\n // Use absolute offset values.\n offsetX = Math.abs(offsetX);\n offsetY = Math.abs(offsetY);\n\n switch (anchor) {\n case 'top-right':\n case 'top-left':\n case 'top':\n y = offsetY - baselineOffset;\n break;\n case 'bottom-right':\n case 'bottom-left':\n case 'bottom':\n y = -offsetY + baselineOffset;\n break;\n }\n\n switch (anchor) {\n case 'top-right':\n case 'bottom-right':\n case 'right':\n x = -offsetX;\n break;\n case 'top-left':\n case 'bottom-left':\n case 'left':\n x = offsetX;\n break;\n }\n\n return [x, y];\n }\n\n return (offset[1] !== INVALID_TEXT_OFFSET) ? fromTextOffset(anchor, offset[0], offset[1]) : fromRadialOffset(anchor, offset[0]);\n}\n\n// Helper to support both text-variable-anchor and text-variable-anchor-offset. Offset values converted from EMs to PXs\nexport function getTextVariableAnchorOffset(layer: SymbolStyleLayer, feature: SymbolFeature, canonical: CanonicalTileID): VariableAnchorOffsetCollection | null {\n const layout = layer.layout;\n // If style specifies text-variable-anchor-offset, just return it\n const variableAnchorOffset = layout.get('text-variable-anchor-offset')?.evaluate(feature, {}, canonical);\n\n if (variableAnchorOffset) {\n const sourceValues = variableAnchorOffset.values;\n const destValues: VariableAnchorOffsetCollectionSpecification = [];\n\n // Convert offsets from EM to PX, and apply baseline shift\n for (let i = 0; i < sourceValues.length; i += 2) {\n const anchor = destValues[i] = sourceValues[i] as TextAnchor;\n const offset = (sourceValues[i + 1] as [number, number]).map(t => t * ONE_EM) as [number, number];\n\n if (anchor.startsWith('top')) {\n offset[1] -= baselineOffset;\n } else if (anchor.startsWith('bottom')) {\n offset[1] += baselineOffset;\n }\n\n destValues[i + 1] = offset;\n }\n\n return new VariableAnchorOffsetCollection(destValues);\n }\n\n // If style specifies text-variable-anchor, convert to the new format\n const variableAnchor = layout.get('text-variable-anchor');\n\n if (variableAnchor) {\n let textOffset: [number, number];\n const unevaluatedLayout = layer._unevaluatedLayout;\n\n // The style spec says don't use `text-offset` and `text-radial-offset` together\n // but doesn't actually specify what happens if you use both. We go with the radial offset.\n if (unevaluatedLayout.getValue('text-radial-offset') !== undefined) {\n textOffset = [layout.get('text-radial-offset').evaluate(feature, {}, canonical) * ONE_EM, INVALID_TEXT_OFFSET];\n } else {\n textOffset = layout.get('text-offset').evaluate(feature, {}, canonical).map(t => t * ONE_EM) as [number, number];\n }\n\n const anchorOffsets: VariableAnchorOffsetCollectionSpecification = [];\n\n for (const anchor of variableAnchor) {\n anchorOffsets.push(anchor, evaluateVariableOffset(anchor, textOffset));\n }\n\n return new VariableAnchorOffsetCollection(anchorOffsets);\n }\n\n return null;\n}\n","import {Anchor} from './anchor';\n\nimport {getAnchors, getCenterAnchor} from './get_anchors';\nimport {clipLine} from './clip_line';\nimport {shapeText, shapeIcon, WritingMode, fitIconToText} from './shaping';\nimport {getGlyphQuads, getIconQuads} from './quads';\nimport {CollisionFeature} from './collision_feature';\nimport {warnOnce} from '../util/util';\nimport {\n allowsVerticalWritingMode,\n allowsLetterSpacing\n} from '../util/script_detection';\nimport {findPoleOfInaccessibility} from '../util/find_pole_of_inaccessibility';\nimport {EXTENT} from '../data/extent';\nimport {SymbolBucket} from '../data/bucket/symbol_bucket';\nimport {EvaluationParameters} from '../style/evaluation_parameters';\nimport {SIZE_PACK_FACTOR, MAX_PACKED_SIZE, MAX_GLYPH_ICON_SIZE} from './symbol_size';\nimport ONE_EM from './one_em';\nimport type {CanonicalTileID} from '../source/tile_id';\nimport type {Shaping, PositionedIcon, TextJustify} from './shaping';\nimport type {CollisionBoxArray, TextAnchorOffsetArray} from '../data/array_types.g';\nimport type {SymbolFeature} from '../data/bucket/symbol_bucket';\nimport type {StyleImage} from '../style/style_image';\nimport type {StyleGlyph} from '../style/style_glyph';\nimport type {SymbolStyleLayer} from '../style/style_layer/symbol_style_layer';\nimport type {ImagePosition} from '../render/image_atlas';\nimport type {GlyphPosition} from '../render/glyph_atlas';\nimport type {PossiblyEvaluatedPropertyValue} from '../style/properties';\n\nimport Point from '@mapbox/point-geometry';\nimport murmur3 from 'murmurhash-js';\nimport {getIconPadding, SymbolPadding} from '../style/style_layer/symbol_style_layer';\nimport {VariableAnchorOffsetCollection, classifyRings} from '@maplibre/maplibre-gl-style-spec';\nimport {getTextVariableAnchorOffset, evaluateVariableOffset, INVALID_TEXT_OFFSET, TextAnchor, TextAnchorEnum} from '../style/style_layer/variable_text_anchor';\n\n// The symbol layout process needs `text-size` evaluated at up to five different zoom levels, and\n// `icon-size` at up to three:\n//\n// 1. `text-size` at the zoom level of the bucket. Used to calculate a per-feature size for source `text-size`\n// expressions, and to calculate the box dimensions for icon-text-fit.\n// 2. `icon-size` at the zoom level of the bucket. Used to calculate a per-feature size for source `icon-size`\n// expressions.\n// 3. `text-size` and `icon-size` at the zoom level of the bucket, plus one. Used to calculate collision boxes.\n// 4. `text-size` at zoom level 18. Used for something line-symbol-placement-related.\n// 5. For composite `*-size` expressions: two zoom levels of curve stops that \"cover\" the zoom level of the\n// bucket. These go into a vertex buffer and are used by the shader to interpolate the size at render time.\n//\n// (1) and (2) are stored in `bucket.layers[0].layout`. The remainder are below.\n//\ntype Sizes = {\n layoutTextSize: PossiblyEvaluatedPropertyValue; // (3),\n layoutIconSize: PossiblyEvaluatedPropertyValue; // (3),\n textMaxSize: PossiblyEvaluatedPropertyValue; // (4),\n compositeTextSizes: [PossiblyEvaluatedPropertyValue, PossiblyEvaluatedPropertyValue]; // (5),\n compositeIconSizes: [PossiblyEvaluatedPropertyValue, PossiblyEvaluatedPropertyValue]; // (5)\n};\n\ntype ShapedTextOrientations = {\n vertical: Shaping | false;\n horizontal: Record;\n};\n\nexport function performSymbolLayout(args: {\n bucket: SymbolBucket;\n glyphMap: {\n [_: string]: {\n [x: number]: StyleGlyph;\n };\n };\n glyphPositions: {\n [_: string]: {\n [x: number]: GlyphPosition;\n };\n };\n imageMap: {[_: string]: StyleImage};\n imagePositions: {[_: string]: ImagePosition};\n showCollisionBoxes: boolean;\n canonical: CanonicalTileID;\n}) {\n args.bucket.createArrays();\n\n const tileSize = 512 * args.bucket.overscaling;\n args.bucket.tilePixelRatio = EXTENT / tileSize;\n args.bucket.compareText = {};\n args.bucket.iconsNeedLinear = false;\n\n const layer = args.bucket.layers[0];\n const layout = layer.layout;\n const unevaluatedLayoutValues = layer._unevaluatedLayout._values;\n\n const sizes: Sizes = {\n // Filled in below, if *SizeData.kind is 'composite'\n // compositeIconSizes: undefined,\n // compositeTextSizes: undefined,\n layoutIconSize: unevaluatedLayoutValues['icon-size'].possiblyEvaluate(new EvaluationParameters(args.bucket.zoom + 1), args.canonical),\n layoutTextSize: unevaluatedLayoutValues['text-size'].possiblyEvaluate(new EvaluationParameters(args.bucket.zoom + 1), args.canonical),\n textMaxSize: unevaluatedLayoutValues['text-size'].possiblyEvaluate(new EvaluationParameters(18))\n } as Sizes;\n\n if (args.bucket.textSizeData.kind === 'composite') {\n const {minZoom, maxZoom} = args.bucket.textSizeData;\n sizes.compositeTextSizes = [\n unevaluatedLayoutValues['text-size'].possiblyEvaluate(new EvaluationParameters(minZoom), args.canonical),\n unevaluatedLayoutValues['text-size'].possiblyEvaluate(new EvaluationParameters(maxZoom), args.canonical)\n ];\n }\n\n if (args.bucket.iconSizeData.kind === 'composite') {\n const {minZoom, maxZoom} = args.bucket.iconSizeData;\n sizes.compositeIconSizes = [\n unevaluatedLayoutValues['icon-size'].possiblyEvaluate(new EvaluationParameters(minZoom), args.canonical),\n unevaluatedLayoutValues['icon-size'].possiblyEvaluate(new EvaluationParameters(maxZoom), args.canonical)\n ];\n }\n\n const lineHeight = layout.get('text-line-height') * ONE_EM;\n const textAlongLine = layout.get('text-rotation-alignment') !== 'viewport' && layout.get('symbol-placement') !== 'point';\n const keepUpright = layout.get('text-keep-upright');\n const textSize = layout.get('text-size');\n\n for (const feature of args.bucket.features) {\n const fontstack = layout.get('text-font').evaluate(feature, {}, args.canonical).join(',');\n const layoutTextSizeThisZoom = textSize.evaluate(feature, {}, args.canonical);\n const layoutTextSize = sizes.layoutTextSize.evaluate(feature, {}, args.canonical);\n const layoutIconSize = sizes.layoutIconSize.evaluate(feature, {}, args.canonical);\n\n const shapedTextOrientations: ShapedTextOrientations = {\n horizontal: {} as Record,\n vertical: undefined\n };\n const text = feature.text;\n let textOffset: [number, number] = [0, 0];\n if (text) {\n const unformattedText = text.toString();\n const spacing = layout.get('text-letter-spacing').evaluate(feature, {}, args.canonical) * ONE_EM;\n const spacingIfAllowed = allowsLetterSpacing(unformattedText) ? spacing : 0;\n\n const textAnchor = layout.get('text-anchor').evaluate(feature, {}, args.canonical);\n const variableAnchorOffset = getTextVariableAnchorOffset(layer, feature, args.canonical);\n\n if (!variableAnchorOffset) {\n const radialOffset = layout.get('text-radial-offset').evaluate(feature, {}, args.canonical);\n // Layers with variable anchors use the `text-radial-offset` property and the [x, y] offset vector\n // is calculated at placement time instead of layout time\n if (radialOffset) {\n // The style spec says don't use `text-offset` and `text-radial-offset` together\n // but doesn't actually specify what happens if you use both. We go with the radial offset.\n textOffset = evaluateVariableOffset(textAnchor, [radialOffset * ONE_EM, INVALID_TEXT_OFFSET]);\n } else {\n textOffset = (layout.get('text-offset').evaluate(feature, {}, args.canonical).map(t => t * ONE_EM) as [number, number]);\n }\n }\n\n let textJustify = textAlongLine ?\n 'center' :\n layout.get('text-justify').evaluate(feature, {}, args.canonical);\n\n const symbolPlacement = layout.get('symbol-placement');\n const maxWidth = symbolPlacement === 'point' ?\n layout.get('text-max-width').evaluate(feature, {}, args.canonical) * ONE_EM :\n Infinity;\n\n const addVerticalShapingForPointLabelIfNeeded = () => {\n if (args.bucket.allowVerticalPlacement && allowsVerticalWritingMode(unformattedText)) {\n // Vertical POI label placement is meant to be used for scripts that support vertical\n // writing mode, thus, default left justification is used. If Latin\n // scripts would need to be supported, this should take into account other justifications.\n shapedTextOrientations.vertical = shapeText(text, args.glyphMap, args.glyphPositions, args.imagePositions, fontstack, maxWidth, lineHeight, textAnchor,\n 'left', spacingIfAllowed, textOffset, WritingMode.vertical, true, layoutTextSize, layoutTextSizeThisZoom);\n }\n };\n\n // If this layer uses text-variable-anchor, generate shapings for all justification possibilities.\n if (!textAlongLine && variableAnchorOffset) {\n const justifications = new Set();\n\n if (textJustify === 'auto') {\n for (let i = 0; i < variableAnchorOffset.values.length; i += 2) {\n justifications.add(getAnchorJustification(variableAnchorOffset.values[i] as TextAnchor));\n }\n } else {\n justifications.add(textJustify);\n }\n\n let singleLine = false;\n for (const justification of justifications) {\n if (shapedTextOrientations.horizontal[justification]) continue;\n if (singleLine) {\n // If the shaping for the first justification was only a single line, we\n // can re-use it for the other justifications\n shapedTextOrientations.horizontal[justification] = shapedTextOrientations.horizontal[0];\n } else {\n // If using text-variable-anchor for the layer, we use a center anchor for all shapings and apply\n // the offsets for the anchor in the placement step.\n const shaping = shapeText(text, args.glyphMap, args.glyphPositions, args.imagePositions, fontstack, maxWidth, lineHeight, 'center',\n justification, spacingIfAllowed, textOffset, WritingMode.horizontal, false, layoutTextSize, layoutTextSizeThisZoom);\n if (shaping) {\n shapedTextOrientations.horizontal[justification] = shaping;\n singleLine = shaping.positionedLines.length === 1;\n }\n }\n }\n\n addVerticalShapingForPointLabelIfNeeded();\n } else {\n if (textJustify === 'auto') {\n textJustify = getAnchorJustification(textAnchor);\n }\n\n // Horizontal point or line label.\n const shaping = shapeText(text, args.glyphMap, args.glyphPositions, args.imagePositions, fontstack, maxWidth, lineHeight, textAnchor, textJustify, spacingIfAllowed,\n textOffset, WritingMode.horizontal, false, layoutTextSize, layoutTextSizeThisZoom);\n if (shaping) shapedTextOrientations.horizontal[textJustify] = shaping;\n\n // Vertical point label (if allowVerticalPlacement is enabled).\n addVerticalShapingForPointLabelIfNeeded();\n\n // Verticalized line label.\n if (allowsVerticalWritingMode(unformattedText) && textAlongLine && keepUpright) {\n shapedTextOrientations.vertical = shapeText(text, args.glyphMap, args.glyphPositions, args.imagePositions, fontstack, maxWidth, lineHeight, textAnchor, textJustify,\n spacingIfAllowed, textOffset, WritingMode.vertical, false, layoutTextSize, layoutTextSizeThisZoom);\n }\n }\n }\n\n let shapedIcon;\n let isSDFIcon = false;\n if (feature.icon && feature.icon.name) {\n const image = args.imageMap[feature.icon.name];\n if (image) {\n shapedIcon = shapeIcon(\n args.imagePositions[feature.icon.name],\n layout.get('icon-offset').evaluate(feature, {}, args.canonical),\n layout.get('icon-anchor').evaluate(feature, {}, args.canonical));\n // null/undefined SDF property treated same as default (false)\n isSDFIcon = !!image.sdf;\n if (args.bucket.sdfIcons === undefined) {\n args.bucket.sdfIcons = isSDFIcon;\n } else if (args.bucket.sdfIcons !== isSDFIcon) {\n warnOnce('Style sheet warning: Cannot mix SDF and non-SDF icons in one buffer');\n }\n if (image.pixelRatio !== args.bucket.pixelRatio) {\n args.bucket.iconsNeedLinear = true;\n } else if (layout.get('icon-rotate').constantOr(1) !== 0) {\n args.bucket.iconsNeedLinear = true;\n }\n }\n }\n\n const shapedText = getDefaultHorizontalShaping(shapedTextOrientations.horizontal) || shapedTextOrientations.vertical;\n args.bucket.iconsInText = shapedText ? shapedText.iconsInText : false;\n if (shapedText || shapedIcon) {\n addFeature(args.bucket, feature, shapedTextOrientations, shapedIcon, args.imageMap, sizes, layoutTextSize, layoutIconSize, textOffset, isSDFIcon, args.canonical);\n }\n }\n\n if (args.showCollisionBoxes) {\n args.bucket.generateCollisionDebugBuffers();\n }\n}\n\n// Choose the justification that matches the direction of the TextAnchor\nexport function getAnchorJustification(anchor: TextAnchor): TextJustify {\n switch (anchor) {\n case 'right':\n case 'top-right':\n case 'bottom-right':\n return 'right';\n case 'left':\n case 'top-left':\n case 'bottom-left':\n return 'left';\n }\n return 'center';\n}\n\n/**\n * Given a feature and its shaped text and icon data, add a 'symbol\n * instance' for each _possible_ placement of the symbol feature.\n * (At render timePlaceSymbols#place() selects which of these instances to\n * show or hide based on collisions with symbols in other layers.)\n */\nfunction addFeature(bucket: SymbolBucket,\n feature: SymbolFeature,\n shapedTextOrientations: ShapedTextOrientations,\n shapedIcon: PositionedIcon,\n imageMap: {[_: string]: StyleImage},\n sizes: Sizes,\n layoutTextSize: number,\n layoutIconSize: number,\n textOffset: [number, number],\n isSDFIcon: boolean,\n canonical: CanonicalTileID) {\n // To reduce the number of labels that jump around when zooming we need\n // to use a text-size value that is the same for all zoom levels.\n // bucket calculates text-size at a high zoom level so that all tiles can\n // use the same value when calculating anchor positions.\n let textMaxSize = sizes.textMaxSize.evaluate(feature, {});\n if (textMaxSize === undefined) {\n textMaxSize = layoutTextSize;\n }\n const layout = bucket.layers[0].layout;\n const iconOffset = layout.get('icon-offset').evaluate(feature, {}, canonical);\n const defaultHorizontalShaping = getDefaultHorizontalShaping(shapedTextOrientations.horizontal);\n const glyphSize = 24,\n fontScale = layoutTextSize / glyphSize,\n textBoxScale = bucket.tilePixelRatio * fontScale,\n textMaxBoxScale = bucket.tilePixelRatio * textMaxSize / glyphSize,\n iconBoxScale = bucket.tilePixelRatio * layoutIconSize,\n symbolMinDistance = bucket.tilePixelRatio * layout.get('symbol-spacing'),\n textPadding = layout.get('text-padding') * bucket.tilePixelRatio,\n iconPadding = getIconPadding(layout, feature, canonical, bucket.tilePixelRatio),\n textMaxAngle = layout.get('text-max-angle') / 180 * Math.PI,\n textAlongLine = layout.get('text-rotation-alignment') !== 'viewport' && layout.get('symbol-placement') !== 'point',\n iconAlongLine = layout.get('icon-rotation-alignment') === 'map' && layout.get('symbol-placement') !== 'point',\n symbolPlacement = layout.get('symbol-placement'),\n textRepeatDistance = symbolMinDistance / 2;\n\n const iconTextFit = layout.get('icon-text-fit');\n let verticallyShapedIcon;\n // Adjust shaped icon size when icon-text-fit is used.\n if (shapedIcon && iconTextFit !== 'none') {\n if (bucket.allowVerticalPlacement && shapedTextOrientations.vertical) {\n verticallyShapedIcon = fitIconToText(shapedIcon, shapedTextOrientations.vertical, iconTextFit,\n layout.get('icon-text-fit-padding'), iconOffset, fontScale);\n }\n if (defaultHorizontalShaping) {\n shapedIcon = fitIconToText(shapedIcon, defaultHorizontalShaping, iconTextFit,\n layout.get('icon-text-fit-padding'), iconOffset, fontScale);\n }\n }\n\n const addSymbolAtAnchor = (line, anchor) => {\n if (anchor.x < 0 || anchor.x >= EXTENT || anchor.y < 0 || anchor.y >= EXTENT) {\n // Symbol layers are drawn across tile boundaries, We filter out symbols\n // outside our tile boundaries (which may be included in vector tile buffers)\n // to prevent double-drawing symbols.\n return;\n }\n addSymbol(bucket, anchor, line, shapedTextOrientations, shapedIcon, imageMap, verticallyShapedIcon, bucket.layers[0],\n bucket.collisionBoxArray, feature.index, feature.sourceLayerIndex, bucket.index,\n textBoxScale, [textPadding, textPadding, textPadding, textPadding], textAlongLine, textOffset,\n iconBoxScale, iconPadding, iconAlongLine, iconOffset,\n feature, sizes, isSDFIcon, canonical, layoutTextSize);\n };\n\n if (symbolPlacement === 'line') {\n for (const line of clipLine(feature.geometry, 0, 0, EXTENT, EXTENT)) {\n const anchors = getAnchors(\n line,\n symbolMinDistance,\n textMaxAngle,\n shapedTextOrientations.vertical || defaultHorizontalShaping,\n shapedIcon,\n glyphSize,\n textMaxBoxScale,\n bucket.overscaling,\n EXTENT\n );\n for (const anchor of anchors) {\n const shapedText = defaultHorizontalShaping;\n if (!shapedText || !anchorIsTooClose(bucket, shapedText.text, textRepeatDistance, anchor)) {\n addSymbolAtAnchor(line, anchor);\n }\n }\n }\n } else if (symbolPlacement === 'line-center') {\n // No clipping, multiple lines per feature are allowed\n // \"lines\" with only one point are ignored as in clipLines\n for (const line of feature.geometry) {\n if (line.length > 1) {\n const anchor = getCenterAnchor(\n line,\n textMaxAngle,\n shapedTextOrientations.vertical || defaultHorizontalShaping,\n shapedIcon,\n glyphSize,\n textMaxBoxScale);\n if (anchor) {\n addSymbolAtAnchor(line, anchor);\n }\n }\n }\n } else if (feature.type === 'Polygon') {\n for (const polygon of classifyRings(feature.geometry, 0)) {\n // 16 here represents 2 pixels\n const poi = findPoleOfInaccessibility(polygon, 16);\n addSymbolAtAnchor(polygon[0], new Anchor(poi.x, poi.y, 0));\n }\n } else if (feature.type === 'LineString') {\n // https://github.com/mapbox/mapbox-gl-js/issues/3808\n for (const line of feature.geometry) {\n addSymbolAtAnchor(line, new Anchor(line[0].x, line[0].y, 0));\n }\n } else if (feature.type === 'Point') {\n for (const points of feature.geometry) {\n for (const point of points) {\n addSymbolAtAnchor([point], new Anchor(point.x, point.y, 0));\n }\n }\n }\n}\n\nfunction addTextVariableAnchorOffsets(textAnchorOffsets: TextAnchorOffsetArray, variableAnchorOffset: VariableAnchorOffsetCollection): [number, number] {\n const startIndex = textAnchorOffsets.length;\n const values = variableAnchorOffset?.values;\n\n if (values?.length > 0) {\n for (let i = 0; i < values.length; i += 2) {\n const anchor = TextAnchorEnum[values[i] as TextAnchor];\n const offset = values[i + 1] as [number, number];\n\n textAnchorOffsets.emplaceBack(anchor, offset[0], offset[1]);\n }\n }\n\n return [startIndex, textAnchorOffsets.length];\n}\n\nfunction addTextVertices(bucket: SymbolBucket,\n anchor: Point,\n shapedText: Shaping,\n imageMap: {[_: string]: StyleImage},\n layer: SymbolStyleLayer,\n textAlongLine: boolean,\n feature: SymbolFeature,\n textOffset: [number, number],\n lineArray: {\n lineStartIndex: number;\n lineLength: number;\n },\n writingMode: WritingMode,\n placementTypes: Array<'vertical' | 'center' | 'left' | 'right'>,\n placedTextSymbolIndices: {[_: string]: number},\n placedIconIndex: number,\n sizes: Sizes,\n canonical: CanonicalTileID) {\n const glyphQuads = getGlyphQuads(anchor, shapedText, textOffset,\n layer, textAlongLine, feature, imageMap, bucket.allowVerticalPlacement);\n\n const sizeData = bucket.textSizeData;\n let textSizeData = null;\n\n if (sizeData.kind === 'source') {\n textSizeData = [\n SIZE_PACK_FACTOR * layer.layout.get('text-size').evaluate(feature, {})\n ];\n if (textSizeData[0] > MAX_PACKED_SIZE) {\n warnOnce(`${bucket.layerIds[0]}: Value for \"text-size\" is >= ${MAX_GLYPH_ICON_SIZE}. Reduce your \"text-size\".`);\n }\n } else if (sizeData.kind === 'composite') {\n textSizeData = [\n SIZE_PACK_FACTOR * sizes.compositeTextSizes[0].evaluate(feature, {}, canonical),\n SIZE_PACK_FACTOR * sizes.compositeTextSizes[1].evaluate(feature, {}, canonical)\n ];\n if (textSizeData[0] > MAX_PACKED_SIZE || textSizeData[1] > MAX_PACKED_SIZE) {\n warnOnce(`${bucket.layerIds[0]}: Value for \"text-size\" is >= ${MAX_GLYPH_ICON_SIZE}. Reduce your \"text-size\".`);\n }\n }\n\n bucket.addSymbols(\n bucket.text,\n glyphQuads,\n textSizeData,\n textOffset,\n textAlongLine,\n feature,\n writingMode,\n anchor,\n lineArray.lineStartIndex,\n lineArray.lineLength,\n placedIconIndex,\n canonical);\n\n // The placedSymbolArray is used at render time in drawTileSymbols\n // These indices allow access to the array at collision detection time\n for (const placementType of placementTypes) {\n placedTextSymbolIndices[placementType] = bucket.text.placedSymbolArray.length - 1;\n }\n\n return glyphQuads.length * 4;\n}\n\nfunction getDefaultHorizontalShaping(\n horizontalShaping: Record\n): Shaping | null {\n // We don't care which shaping we get because this is used for collision purposes\n // and all the justifications have the same collision box\n for (const justification in horizontalShaping) {\n return horizontalShaping[justification];\n }\n return null;\n}\n\n/**\n * Add a single label & icon placement.\n */\nfunction addSymbol(bucket: SymbolBucket,\n anchor: Anchor,\n line: Array,\n shapedTextOrientations: ShapedTextOrientations,\n shapedIcon: PositionedIcon | void,\n imageMap: {[_: string]: StyleImage},\n verticallyShapedIcon: PositionedIcon | void,\n layer: SymbolStyleLayer,\n collisionBoxArray: CollisionBoxArray,\n featureIndex: number,\n sourceLayerIndex: number,\n bucketIndex: number,\n textBoxScale: number,\n textPadding: SymbolPadding,\n textAlongLine: boolean,\n textOffset: [number, number],\n iconBoxScale: number,\n iconPadding: SymbolPadding,\n iconAlongLine: boolean,\n iconOffset: [number, number],\n feature: SymbolFeature,\n sizes: Sizes,\n isSDFIcon: boolean,\n canonical: CanonicalTileID,\n layoutTextSize: number) {\n\n const lineArray = bucket.addToLineVertexArray(anchor, line);\n\n let textCollisionFeature, iconCollisionFeature, verticalTextCollisionFeature, verticalIconCollisionFeature;\n\n let numIconVertices = 0;\n let numVerticalIconVertices = 0;\n let numHorizontalGlyphVertices = 0;\n let numVerticalGlyphVertices = 0;\n let placedIconSymbolIndex = -1;\n let verticalPlacedIconSymbolIndex = -1;\n const placedTextSymbolIndices: {[k: string]: number} = {};\n let key = murmur3('');\n\n if (bucket.allowVerticalPlacement && shapedTextOrientations.vertical) {\n const textRotation = layer.layout.get('text-rotate').evaluate(feature, {}, canonical);\n const verticalTextRotation = textRotation + 90.0;\n const verticalShaping = shapedTextOrientations.vertical;\n verticalTextCollisionFeature = new CollisionFeature(collisionBoxArray, anchor, featureIndex, sourceLayerIndex, bucketIndex, verticalShaping, textBoxScale, textPadding, textAlongLine, verticalTextRotation);\n\n if (verticallyShapedIcon) {\n verticalIconCollisionFeature = new CollisionFeature(collisionBoxArray, anchor, featureIndex, sourceLayerIndex, bucketIndex, verticallyShapedIcon, iconBoxScale, iconPadding, textAlongLine, verticalTextRotation);\n }\n }\n\n //Place icon first, so text can have a reference to its index in the placed symbol array.\n //Text symbols can lazily shift at render-time because of variable anchor placement.\n //If the style specifies an `icon-text-fit` then the icon would have to shift along with it.\n // For more info check `updateVariableAnchors` in `draw_symbol.js` .\n if (shapedIcon) {\n const iconRotate = layer.layout.get('icon-rotate').evaluate(feature, {});\n const hasIconTextFit = layer.layout.get('icon-text-fit') !== 'none';\n const iconQuads = getIconQuads(shapedIcon, iconRotate, isSDFIcon, hasIconTextFit);\n const verticalIconQuads = verticallyShapedIcon ? getIconQuads(verticallyShapedIcon, iconRotate, isSDFIcon, hasIconTextFit) : undefined;\n iconCollisionFeature = new CollisionFeature(collisionBoxArray, anchor, featureIndex, sourceLayerIndex, bucketIndex, shapedIcon, iconBoxScale, iconPadding, /*align boxes to line*/false, iconRotate);\n\n numIconVertices = iconQuads.length * 4;\n\n const sizeData = bucket.iconSizeData;\n let iconSizeData = null;\n\n if (sizeData.kind === 'source') {\n iconSizeData = [\n SIZE_PACK_FACTOR * layer.layout.get('icon-size').evaluate(feature, {})\n ];\n if (iconSizeData[0] > MAX_PACKED_SIZE) {\n warnOnce(`${bucket.layerIds[0]}: Value for \"icon-size\" is >= ${MAX_GLYPH_ICON_SIZE}. Reduce your \"icon-size\".`);\n }\n } else if (sizeData.kind === 'composite') {\n iconSizeData = [\n SIZE_PACK_FACTOR * sizes.compositeIconSizes[0].evaluate(feature, {}, canonical),\n SIZE_PACK_FACTOR * sizes.compositeIconSizes[1].evaluate(feature, {}, canonical)\n ];\n if (iconSizeData[0] > MAX_PACKED_SIZE || iconSizeData[1] > MAX_PACKED_SIZE) {\n warnOnce(`${bucket.layerIds[0]}: Value for \"icon-size\" is >= ${MAX_GLYPH_ICON_SIZE}. Reduce your \"icon-size\".`);\n }\n }\n\n bucket.addSymbols(\n bucket.icon,\n iconQuads,\n iconSizeData,\n iconOffset,\n iconAlongLine,\n feature,\n WritingMode.none,\n anchor,\n lineArray.lineStartIndex,\n lineArray.lineLength,\n // The icon itself does not have an associated symbol since the text isn't placed yet\n -1, canonical);\n\n placedIconSymbolIndex = bucket.icon.placedSymbolArray.length - 1;\n\n if (verticalIconQuads) {\n numVerticalIconVertices = verticalIconQuads.length * 4;\n\n bucket.addSymbols(\n bucket.icon,\n verticalIconQuads,\n iconSizeData,\n iconOffset,\n iconAlongLine,\n feature,\n WritingMode.vertical,\n anchor,\n lineArray.lineStartIndex,\n lineArray.lineLength,\n // The icon itself does not have an associated symbol since the text isn't placed yet\n -1, canonical);\n\n verticalPlacedIconSymbolIndex = bucket.icon.placedSymbolArray.length - 1;\n }\n }\n\n const justifications = Object.keys(shapedTextOrientations.horizontal) as TextJustify[];\n for (const justification of justifications) {\n const shaping = shapedTextOrientations.horizontal[justification];\n\n if (!textCollisionFeature) {\n key = murmur3(shaping.text);\n const textRotate = layer.layout.get('text-rotate').evaluate(feature, {}, canonical);\n // As a collision approximation, we can use either the vertical or any of the horizontal versions of the feature\n // We're counting on all versions having similar dimensions\n textCollisionFeature = new CollisionFeature(collisionBoxArray, anchor, featureIndex, sourceLayerIndex, bucketIndex, shaping, textBoxScale, textPadding, textAlongLine, textRotate);\n }\n\n const singleLine = shaping.positionedLines.length === 1;\n numHorizontalGlyphVertices += addTextVertices(\n bucket, anchor, shaping, imageMap, layer, textAlongLine, feature, textOffset, lineArray,\n shapedTextOrientations.vertical ? WritingMode.horizontal : WritingMode.horizontalOnly,\n singleLine ? justifications : [justification],\n placedTextSymbolIndices, placedIconSymbolIndex, sizes, canonical);\n\n if (singleLine) {\n break;\n }\n }\n\n if (shapedTextOrientations.vertical) {\n numVerticalGlyphVertices += addTextVertices(\n bucket, anchor, shapedTextOrientations.vertical, imageMap, layer, textAlongLine, feature,\n textOffset, lineArray, WritingMode.vertical, ['vertical'], placedTextSymbolIndices, verticalPlacedIconSymbolIndex, sizes, canonical);\n }\n\n const textBoxStartIndex = textCollisionFeature ? textCollisionFeature.boxStartIndex : bucket.collisionBoxArray.length;\n const textBoxEndIndex = textCollisionFeature ? textCollisionFeature.boxEndIndex : bucket.collisionBoxArray.length;\n\n const verticalTextBoxStartIndex = verticalTextCollisionFeature ? verticalTextCollisionFeature.boxStartIndex : bucket.collisionBoxArray.length;\n const verticalTextBoxEndIndex = verticalTextCollisionFeature ? verticalTextCollisionFeature.boxEndIndex : bucket.collisionBoxArray.length;\n\n const iconBoxStartIndex = iconCollisionFeature ? iconCollisionFeature.boxStartIndex : bucket.collisionBoxArray.length;\n const iconBoxEndIndex = iconCollisionFeature ? iconCollisionFeature.boxEndIndex : bucket.collisionBoxArray.length;\n\n const verticalIconBoxStartIndex = verticalIconCollisionFeature ? verticalIconCollisionFeature.boxStartIndex : bucket.collisionBoxArray.length;\n const verticalIconBoxEndIndex = verticalIconCollisionFeature ? verticalIconCollisionFeature.boxEndIndex : bucket.collisionBoxArray.length;\n\n // Check if runtime collision circles should be used for any of the collision features.\n // It is enough to choose the tallest feature shape as circles are always placed on a line.\n // All measurements are in glyph metrics and later converted into pixels using proper font size \"layoutTextSize\"\n let collisionCircleDiameter = -1;\n\n const getCollisionCircleHeight = (feature: CollisionFeature, prevHeight: number): number => {\n if (feature && feature.circleDiameter)\n return Math.max(feature.circleDiameter, prevHeight);\n return prevHeight;\n };\n\n collisionCircleDiameter = getCollisionCircleHeight(textCollisionFeature, collisionCircleDiameter);\n collisionCircleDiameter = getCollisionCircleHeight(verticalTextCollisionFeature, collisionCircleDiameter);\n collisionCircleDiameter = getCollisionCircleHeight(iconCollisionFeature, collisionCircleDiameter);\n collisionCircleDiameter = getCollisionCircleHeight(verticalIconCollisionFeature, collisionCircleDiameter);\n const useRuntimeCollisionCircles = (collisionCircleDiameter > -1) ? 1 : 0;\n\n // Convert circle collision height into pixels\n if (useRuntimeCollisionCircles)\n collisionCircleDiameter *= layoutTextSize / ONE_EM;\n\n if (bucket.glyphOffsetArray.length >= SymbolBucket.MAX_GLYPHS) warnOnce(\n 'Too many glyphs being rendered in a tile. See https://github.com/mapbox/mapbox-gl-js/issues/2907'\n );\n\n if (feature.sortKey !== undefined) {\n bucket.addToSortKeyRanges(bucket.symbolInstances.length, feature.sortKey as number);\n }\n\n const variableAnchorOffset = getTextVariableAnchorOffset(layer, feature, canonical);\n const [textAnchorOffsetStartIndex, textAnchorOffsetEndIndex] = addTextVariableAnchorOffsets(bucket.textAnchorOffsets, variableAnchorOffset);\n\n bucket.symbolInstances.emplaceBack(\n anchor.x,\n anchor.y,\n placedTextSymbolIndices.right >= 0 ? placedTextSymbolIndices.right : -1,\n placedTextSymbolIndices.center >= 0 ? placedTextSymbolIndices.center : -1,\n placedTextSymbolIndices.left >= 0 ? placedTextSymbolIndices.left : -1,\n placedTextSymbolIndices.vertical || -1,\n placedIconSymbolIndex,\n verticalPlacedIconSymbolIndex,\n key,\n textBoxStartIndex,\n textBoxEndIndex,\n verticalTextBoxStartIndex,\n verticalTextBoxEndIndex,\n iconBoxStartIndex,\n iconBoxEndIndex,\n verticalIconBoxStartIndex,\n verticalIconBoxEndIndex,\n featureIndex,\n numHorizontalGlyphVertices,\n numVerticalGlyphVertices,\n numIconVertices,\n numVerticalIconVertices,\n useRuntimeCollisionCircles,\n 0,\n textBoxScale,\n collisionCircleDiameter,\n textAnchorOffsetStartIndex,\n textAnchorOffsetEndIndex);\n}\n\nfunction anchorIsTooClose(bucket: SymbolBucket, text: string, repeatDistance: number, anchor: Point) {\n const compareText = bucket.compareText;\n if (!(text in compareText)) {\n compareText[text] = [];\n } else {\n const otherAnchors = compareText[text];\n for (let k = otherAnchors.length - 1; k >= 0; k--) {\n if (anchor.dist(otherAnchors[k]) < repeatDistance) {\n // If it's within repeatDistance of one anchor, stop looking\n return true;\n }\n }\n }\n // If anchor is not within repeatDistance of any other anchor, add to array\n compareText[text].push(anchor);\n return false;\n}\n","\nconst ARRAY_TYPES = [\n Int8Array, Uint8Array, Uint8ClampedArray, Int16Array, Uint16Array,\n Int32Array, Uint32Array, Float32Array, Float64Array\n];\n\n/** @typedef {Int8ArrayConstructor | Uint8ArrayConstructor | Uint8ClampedArrayConstructor | Int16ArrayConstructor | Uint16ArrayConstructor | Int32ArrayConstructor | Uint32ArrayConstructor | Float32ArrayConstructor | Float64ArrayConstructor} TypedArrayConstructor */\n\nconst VERSION = 1; // serialized format version\nconst HEADER_SIZE = 8;\n\nexport default class KDBush {\n\n /**\n * Creates an index from raw `ArrayBuffer` data.\n * @param {ArrayBuffer} data\n */\n static from(data) {\n if (!(data instanceof ArrayBuffer)) {\n throw new Error('Data must be an instance of ArrayBuffer.');\n }\n const [magic, versionAndType] = new Uint8Array(data, 0, 2);\n if (magic !== 0xdb) {\n throw new Error('Data does not appear to be in a KDBush format.');\n }\n const version = versionAndType >> 4;\n if (version !== VERSION) {\n throw new Error(`Got v${version} data when expected v${VERSION}.`);\n }\n const ArrayType = ARRAY_TYPES[versionAndType & 0x0f];\n if (!ArrayType) {\n throw new Error('Unrecognized array type.');\n }\n const [nodeSize] = new Uint16Array(data, 2, 1);\n const [numItems] = new Uint32Array(data, 4, 1);\n\n return new KDBush(numItems, nodeSize, ArrayType, data);\n }\n\n /**\n * Creates an index that will hold a given number of items.\n * @param {number} numItems\n * @param {number} [nodeSize=64] Size of the KD-tree node (64 by default).\n * @param {TypedArrayConstructor} [ArrayType=Float64Array] The array type used for coordinates storage (`Float64Array` by default).\n * @param {ArrayBuffer} [data] (For internal use only)\n */\n constructor(numItems, nodeSize = 64, ArrayType = Float64Array, data) {\n if (isNaN(numItems) || numItems < 0) throw new Error(`Unpexpected numItems value: ${numItems}.`);\n\n this.numItems = +numItems;\n this.nodeSize = Math.min(Math.max(+nodeSize, 2), 65535);\n this.ArrayType = ArrayType;\n this.IndexArrayType = numItems < 65536 ? Uint16Array : Uint32Array;\n\n const arrayTypeIndex = ARRAY_TYPES.indexOf(this.ArrayType);\n const coordsByteSize = numItems * 2 * this.ArrayType.BYTES_PER_ELEMENT;\n const idsByteSize = numItems * this.IndexArrayType.BYTES_PER_ELEMENT;\n const padCoords = (8 - idsByteSize % 8) % 8;\n\n if (arrayTypeIndex < 0) {\n throw new Error(`Unexpected typed array class: ${ArrayType}.`);\n }\n\n if (data && (data instanceof ArrayBuffer)) { // reconstruct an index from a buffer\n this.data = data;\n this.ids = new this.IndexArrayType(this.data, HEADER_SIZE, numItems);\n this.coords = new this.ArrayType(this.data, HEADER_SIZE + idsByteSize + padCoords, numItems * 2);\n this._pos = numItems * 2;\n this._finished = true;\n } else { // initialize a new index\n this.data = new ArrayBuffer(HEADER_SIZE + coordsByteSize + idsByteSize + padCoords);\n this.ids = new this.IndexArrayType(this.data, HEADER_SIZE, numItems);\n this.coords = new this.ArrayType(this.data, HEADER_SIZE + idsByteSize + padCoords, numItems * 2);\n this._pos = 0;\n this._finished = false;\n\n // set header\n new Uint8Array(this.data, 0, 2).set([0xdb, (VERSION << 4) + arrayTypeIndex]);\n new Uint16Array(this.data, 2, 1)[0] = nodeSize;\n new Uint32Array(this.data, 4, 1)[0] = numItems;\n }\n }\n\n /**\n * Add a point to the index.\n * @param {number} x\n * @param {number} y\n * @returns {number} An incremental index associated with the added item (starting from `0`).\n */\n add(x, y) {\n const index = this._pos >> 1;\n this.ids[index] = index;\n this.coords[this._pos++] = x;\n this.coords[this._pos++] = y;\n return index;\n }\n\n /**\n * Perform indexing of the added points.\n */\n finish() {\n const numAdded = this._pos >> 1;\n if (numAdded !== this.numItems) {\n throw new Error(`Added ${numAdded} items when expected ${this.numItems}.`);\n }\n // kd-sort both arrays for efficient search\n sort(this.ids, this.coords, this.nodeSize, 0, this.numItems - 1, 0);\n\n this._finished = true;\n return this;\n }\n\n /**\n * Search the index for items within a given bounding box.\n * @param {number} minX\n * @param {number} minY\n * @param {number} maxX\n * @param {number} maxY\n * @returns {number[]} An array of indices correponding to the found items.\n */\n range(minX, minY, maxX, maxY) {\n if (!this._finished) throw new Error('Data not yet indexed - call index.finish().');\n\n const {ids, coords, nodeSize} = this;\n const stack = [0, ids.length - 1, 0];\n const result = [];\n\n // recursively search for items in range in the kd-sorted arrays\n while (stack.length) {\n const axis = stack.pop() || 0;\n const right = stack.pop() || 0;\n const left = stack.pop() || 0;\n\n // if we reached \"tree node\", search linearly\n if (right - left <= nodeSize) {\n for (let i = left; i <= right; i++) {\n const x = coords[2 * i];\n const y = coords[2 * i + 1];\n if (x >= minX && x <= maxX && y >= minY && y <= maxY) result.push(ids[i]);\n }\n continue;\n }\n\n // otherwise find the middle index\n const m = (left + right) >> 1;\n\n // include the middle item if it's in range\n const x = coords[2 * m];\n const y = coords[2 * m + 1];\n if (x >= minX && x <= maxX && y >= minY && y <= maxY) result.push(ids[m]);\n\n // queue search in halves that intersect the query\n if (axis === 0 ? minX <= x : minY <= y) {\n stack.push(left);\n stack.push(m - 1);\n stack.push(1 - axis);\n }\n if (axis === 0 ? maxX >= x : maxY >= y) {\n stack.push(m + 1);\n stack.push(right);\n stack.push(1 - axis);\n }\n }\n\n return result;\n }\n\n /**\n * Search the index for items within a given radius.\n * @param {number} qx\n * @param {number} qy\n * @param {number} r Query radius.\n * @returns {number[]} An array of indices correponding to the found items.\n */\n within(qx, qy, r) {\n if (!this._finished) throw new Error('Data not yet indexed - call index.finish().');\n\n const {ids, coords, nodeSize} = this;\n const stack = [0, ids.length - 1, 0];\n const result = [];\n const r2 = r * r;\n\n // recursively search for items within radius in the kd-sorted arrays\n while (stack.length) {\n const axis = stack.pop() || 0;\n const right = stack.pop() || 0;\n const left = stack.pop() || 0;\n\n // if we reached \"tree node\", search linearly\n if (right - left <= nodeSize) {\n for (let i = left; i <= right; i++) {\n if (sqDist(coords[2 * i], coords[2 * i + 1], qx, qy) <= r2) result.push(ids[i]);\n }\n continue;\n }\n\n // otherwise find the middle index\n const m = (left + right) >> 1;\n\n // include the middle item if it's in range\n const x = coords[2 * m];\n const y = coords[2 * m + 1];\n if (sqDist(x, y, qx, qy) <= r2) result.push(ids[m]);\n\n // queue search in halves that intersect the query\n if (axis === 0 ? qx - r <= x : qy - r <= y) {\n stack.push(left);\n stack.push(m - 1);\n stack.push(1 - axis);\n }\n if (axis === 0 ? qx + r >= x : qy + r >= y) {\n stack.push(m + 1);\n stack.push(right);\n stack.push(1 - axis);\n }\n }\n\n return result;\n }\n}\n\n/**\n * @param {Uint16Array | Uint32Array} ids\n * @param {InstanceType} coords\n * @param {number} nodeSize\n * @param {number} left\n * @param {number} right\n * @param {number} axis\n */\nfunction sort(ids, coords, nodeSize, left, right, axis) {\n if (right - left <= nodeSize) return;\n\n const m = (left + right) >> 1; // middle index\n\n // sort ids and coords around the middle index so that the halves lie\n // either left/right or top/bottom correspondingly (taking turns)\n select(ids, coords, m, left, right, axis);\n\n // recursively kd-sort first half and second half on the opposite axis\n sort(ids, coords, nodeSize, left, m - 1, 1 - axis);\n sort(ids, coords, nodeSize, m + 1, right, 1 - axis);\n}\n\n/**\n * Custom Floyd-Rivest selection algorithm: sort ids and coords so that\n * [left..k-1] items are smaller than k-th item (on either x or y axis)\n * @param {Uint16Array | Uint32Array} ids\n * @param {InstanceType} coords\n * @param {number} k\n * @param {number} left\n * @param {number} right\n * @param {number} axis\n */\nfunction select(ids, coords, k, left, right, axis) {\n\n while (right > left) {\n if (right - left > 600) {\n const n = right - left + 1;\n const m = k - left + 1;\n const z = Math.log(n);\n const s = 0.5 * Math.exp(2 * z / 3);\n const sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n const newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n const newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n select(ids, coords, k, newLeft, newRight, axis);\n }\n\n const t = coords[2 * k + axis];\n let i = left;\n let j = right;\n\n swapItem(ids, coords, left, k);\n if (coords[2 * right + axis] > t) swapItem(ids, coords, left, right);\n\n while (i < j) {\n swapItem(ids, coords, i, j);\n i++;\n j--;\n while (coords[2 * i + axis] < t) i++;\n while (coords[2 * j + axis] > t) j--;\n }\n\n if (coords[2 * left + axis] === t) swapItem(ids, coords, left, j);\n else {\n j++;\n swapItem(ids, coords, j, right);\n }\n\n if (j <= k) left = j + 1;\n if (k <= j) right = j - 1;\n }\n}\n\n/**\n * @param {Uint16Array | Uint32Array} ids\n * @param {InstanceType} coords\n * @param {number} i\n * @param {number} j\n */\nfunction swapItem(ids, coords, i, j) {\n swap(ids, i, j);\n swap(coords, 2 * i, 2 * j);\n swap(coords, 2 * i + 1, 2 * j + 1);\n}\n\n/**\n * @param {InstanceType} arr\n * @param {number} i\n * @param {number} j\n */\nfunction swap(arr, i, j) {\n const tmp = arr[i];\n arr[i] = arr[j];\n arr[j] = tmp;\n}\n\n/**\n * @param {number} ax\n * @param {number} ay\n * @param {number} bx\n * @param {number} by\n */\nfunction sqDist(ax, ay, bx, by) {\n const dx = ax - bx;\n const dy = ay - by;\n return dx * dx + dy * dy;\n}\n","import type {RequestParameters} from '../util/ajax';\n\nexport type PerformanceMetrics = {\n loadTime: number;\n fullLoadTime: number;\n fps: number;\n percentDroppedFrames: number;\n totalFrames: number;\n};\n\nexport enum PerformanceMarkers {\n create = 'create',\n load = 'load',\n fullLoad = 'fullLoad'\n}\n\nlet lastFrameTime = null;\nlet frameTimes = [];\n\nconst minFramerateTarget = 60;\nconst frameTimeTarget = 1000 / minFramerateTarget;\n\nconst loadTimeKey = 'loadTime';\nconst fullLoadTimeKey = 'fullLoadTime';\n\nexport const PerformanceUtils = {\n mark(marker: PerformanceMarkers) {\n performance.mark(marker);\n },\n frame(timestamp: number) {\n const currTimestamp = timestamp;\n if (lastFrameTime != null) {\n const frameTime = currTimestamp - lastFrameTime;\n frameTimes.push(frameTime);\n }\n lastFrameTime = currTimestamp;\n },\n clearMetrics() {\n lastFrameTime = null;\n frameTimes = [];\n performance.clearMeasures(loadTimeKey);\n performance.clearMeasures(fullLoadTimeKey);\n\n for (const marker in PerformanceMarkers) {\n performance.clearMarks(PerformanceMarkers[marker]);\n }\n },\n\n getPerformanceMetrics(): PerformanceMetrics {\n performance.measure(loadTimeKey, PerformanceMarkers.create, PerformanceMarkers.load);\n performance.measure(fullLoadTimeKey, PerformanceMarkers.create, PerformanceMarkers.fullLoad);\n const loadTime = performance.getEntriesByName(loadTimeKey)[0].duration;\n const fullLoadTime = performance.getEntriesByName(fullLoadTimeKey)[0].duration;\n const totalFrames = frameTimes.length;\n\n const avgFrameTime = frameTimes.reduce((prev, curr) => prev + curr, 0) / totalFrames / 1000;\n const fps = 1 / avgFrameTime;\n\n // count frames that missed our framerate target\n const droppedFrames = frameTimes\n .filter((frameTime) => frameTime > frameTimeTarget)\n .reduce((acc, curr) => {\n return acc + (curr - frameTimeTarget) / frameTimeTarget;\n }, 0);\n const percentDroppedFrames = (droppedFrames / (totalFrames + droppedFrames)) * 100;\n\n return {\n loadTime,\n fullLoadTime,\n fps,\n percentDroppedFrames,\n totalFrames\n };\n }\n};\n\n/**\n * @internal\n * Safe wrapper for the performance resource timing API in web workers with graceful degradation\n */\nexport class RequestPerformance {\n _marks: {\n start: string;\n end: string;\n measure: string;\n };\n\n constructor (request: RequestParameters) {\n this._marks = {\n start: [request.url, 'start'].join('#'),\n end: [request.url, 'end'].join('#'),\n measure: request.url.toString()\n };\n\n performance.mark(this._marks.start);\n }\n\n finish() {\n performance.mark(this._marks.end);\n let resourceTimingData = performance.getEntriesByName(this._marks.measure);\n\n // fallback if web worker implementation of perf.getEntriesByName returns empty\n if (resourceTimingData.length === 0) {\n performance.measure(this._marks.measure, this._marks.start, this._marks.end);\n resourceTimingData = performance.getEntriesByName(this._marks.measure);\n\n // cleanup\n performance.clearMarks(this._marks.start);\n performance.clearMarks(this._marks.end);\n performance.clearMeasures(this._marks.measure);\n }\n\n return resourceTimingData;\n }\n}\n\nexport default performance;\n","import {StyleLayer} from './style_layer';\nimport {createStyleLayer} from './create_style_layer';\n\nimport {featureFilter, groupByLayout} from '@maplibre/maplibre-gl-style-spec';\n\nimport type {TypedStyleLayer} from './style_layer/typed_style_layer';\nimport type {LayerSpecification} from '@maplibre/maplibre-gl-style-spec';\n\nexport type LayerConfigs = {[_: string]: LayerSpecification};\nexport type Family = Array;\n\nexport class StyleLayerIndex {\n familiesBySource: {\n [source: string]: {\n [sourceLayer: string]: Array>;\n };\n };\n keyCache: {[source: string]: string};\n\n _layerConfigs: LayerConfigs;\n _layers: {[_: string]: StyleLayer};\n\n constructor(layerConfigs?: Array | null) {\n this.keyCache = {};\n if (layerConfigs) {\n this.replace(layerConfigs);\n }\n }\n\n replace(layerConfigs: Array) {\n this._layerConfigs = {};\n this._layers = {};\n this.update(layerConfigs, []);\n }\n\n update(layerConfigs: Array, removedIds: Array) {\n for (const layerConfig of layerConfigs) {\n this._layerConfigs[layerConfig.id] = layerConfig;\n\n const layer = this._layers[layerConfig.id] = createStyleLayer(layerConfig);\n layer._featureFilter = featureFilter(layer.filter);\n if (this.keyCache[layerConfig.id])\n delete this.keyCache[layerConfig.id];\n }\n for (const id of removedIds) {\n delete this.keyCache[id];\n delete this._layerConfigs[id];\n delete this._layers[id];\n }\n\n this.familiesBySource = {};\n\n const groups = groupByLayout(Object.values(this._layerConfigs), this.keyCache);\n\n for (const layerConfigs of groups) {\n const layers = layerConfigs.map((layerConfig) => this._layers[layerConfig.id]);\n\n const layer = layers[0];\n if (layer.visibility === 'none') {\n continue;\n }\n\n const sourceId = layer.source || '';\n let sourceGroup = this.familiesBySource[sourceId];\n if (!sourceGroup) {\n sourceGroup = this.familiesBySource[sourceId] = {};\n }\n\n const sourceLayerId = layer.sourceLayer || '_geojsonTileLayer';\n let sourceLayerFamilies = sourceGroup[sourceLayerId];\n if (!sourceLayerFamilies) {\n sourceLayerFamilies = sourceGroup[sourceLayerId] = [];\n }\n\n sourceLayerFamilies.push(layers);\n }\n }\n}\n","import {AlphaImage} from '../util/image';\nimport {register} from '../util/web_worker_transfer';\nimport potpack from 'potpack';\n\nimport type {GlyphMetrics} from '../style/style_glyph';\nimport type {GetGlyphsResponse} from '../util/actor_messages';\n\nconst padding = 1;\n\n/**\n * A rectangle type with postion, width and height.\n */\nexport type Rect = {\n x: number;\n y: number;\n w: number;\n h: number;\n};\n\n/**\n * The glyph's position\n */\nexport type GlyphPosition = {\n rect: Rect;\n metrics: GlyphMetrics;\n};\n\n/**\n * The glyphs' positions\n */\nexport type GlyphPositions = {\n [_: string]: {\n [_: number]: GlyphPosition;\n };\n};\n\nexport class GlyphAtlas {\n image: AlphaImage;\n positions: GlyphPositions;\n\n constructor(stacks: GetGlyphsResponse) {\n const positions = {};\n const bins = [];\n\n for (const stack in stacks) {\n const glyphs = stacks[stack];\n const stackPositions = positions[stack] = {};\n\n for (const id in glyphs) {\n const src = glyphs[+id];\n if (!src || src.bitmap.width === 0 || src.bitmap.height === 0) continue;\n\n const bin = {\n x: 0,\n y: 0,\n w: src.bitmap.width + 2 * padding,\n h: src.bitmap.height + 2 * padding\n };\n bins.push(bin);\n stackPositions[id] = {rect: bin, metrics: src.metrics};\n }\n }\n\n const {w, h} = potpack(bins);\n const image = new AlphaImage({width: w || 1, height: h || 1});\n\n for (const stack in stacks) {\n const glyphs = stacks[stack];\n\n for (const id in glyphs) {\n const src = glyphs[+id];\n if (!src || src.bitmap.width === 0 || src.bitmap.height === 0) continue;\n const bin = positions[stack][id].rect;\n AlphaImage.copy(src.bitmap, image, {x: 0, y: 0}, {x: bin.x + padding, y: bin.y + padding}, src.bitmap);\n }\n }\n\n this.image = image;\n this.positions = positions;\n }\n}\n\nregister('GlyphAtlas', GlyphAtlas);\n","import {FeatureIndex} from '../data/feature_index';\nimport {performSymbolLayout} from '../symbol/symbol_layout';\nimport {CollisionBoxArray} from '../data/array_types.g';\nimport {DictionaryCoder} from '../util/dictionary_coder';\nimport {SymbolBucket} from '../data/bucket/symbol_bucket';\nimport {LineBucket} from '../data/bucket/line_bucket';\nimport {FillBucket} from '../data/bucket/fill_bucket';\nimport {FillExtrusionBucket} from '../data/bucket/fill_extrusion_bucket';\nimport {warnOnce, mapObject} from '../util/util';\nimport {ImageAtlas} from '../render/image_atlas';\nimport {GlyphAtlas} from '../render/glyph_atlas';\nimport {EvaluationParameters} from '../style/evaluation_parameters';\nimport {OverscaledTileID} from './tile_id';\n\nimport type {Bucket} from '../data/bucket';\nimport type {IActor} from '../util/actor';\nimport type {StyleLayer} from '../style/style_layer';\nimport type {StyleLayerIndex} from '../style/style_layer_index';\nimport type {\n WorkerTileParameters,\n WorkerTileResult,\n} from '../source/worker_source';\nimport type {PromoteIdSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {VectorTile} from '@mapbox/vector-tile';\nimport {MessageType, type GetGlyphsResponse, type GetImagesResponse} from '../util/actor_messages';\n\nexport class WorkerTile {\n tileID: OverscaledTileID;\n uid: string | number;\n zoom: number;\n pixelRatio: number;\n tileSize: number;\n source: string;\n promoteId: PromoteIdSpecification;\n overscaling: number;\n showCollisionBoxes: boolean;\n collectResourceTiming: boolean;\n returnDependencies: boolean;\n\n status: 'parsing' | 'done';\n data: VectorTile;\n collisionBoxArray: CollisionBoxArray;\n\n abort: AbortController;\n vectorTile: VectorTile;\n inFlightDependencies: AbortController[];\n\n constructor(params: WorkerTileParameters) {\n this.tileID = new OverscaledTileID(params.tileID.overscaledZ, params.tileID.wrap, params.tileID.canonical.z, params.tileID.canonical.x, params.tileID.canonical.y);\n this.uid = params.uid;\n this.zoom = params.zoom;\n this.pixelRatio = params.pixelRatio;\n this.tileSize = params.tileSize;\n this.source = params.source;\n this.overscaling = this.tileID.overscaleFactor();\n this.showCollisionBoxes = params.showCollisionBoxes;\n this.collectResourceTiming = !!params.collectResourceTiming;\n this.returnDependencies = !!params.returnDependencies;\n this.promoteId = params.promoteId;\n this.inFlightDependencies = [];\n }\n\n async parse(data: VectorTile, layerIndex: StyleLayerIndex, availableImages: Array, actor: IActor): Promise {\n this.status = 'parsing';\n this.data = data;\n\n this.collisionBoxArray = new CollisionBoxArray();\n const sourceLayerCoder = new DictionaryCoder(Object.keys(data.layers).sort());\n\n const featureIndex = new FeatureIndex(this.tileID, this.promoteId);\n featureIndex.bucketLayerIDs = [];\n\n const buckets: {[_: string]: Bucket} = {};\n\n const options = {\n featureIndex,\n iconDependencies: {},\n patternDependencies: {},\n glyphDependencies: {},\n availableImages\n };\n\n const layerFamilies = layerIndex.familiesBySource[this.source];\n for (const sourceLayerId in layerFamilies) {\n const sourceLayer = data.layers[sourceLayerId];\n if (!sourceLayer) {\n continue;\n }\n\n if (sourceLayer.version === 1) {\n warnOnce(`Vector tile source \"${this.source}\" layer \"${sourceLayerId}\" ` +\n 'does not use vector tile spec v2 and therefore may have some rendering errors.');\n }\n\n const sourceLayerIndex = sourceLayerCoder.encode(sourceLayerId);\n const features = [];\n for (let index = 0; index < sourceLayer.length; index++) {\n const feature = sourceLayer.feature(index);\n const id = featureIndex.getId(feature, sourceLayerId);\n features.push({feature, id, index, sourceLayerIndex});\n }\n\n for (const family of layerFamilies[sourceLayerId]) {\n const layer = family[0];\n\n if (layer.source !== this.source) {\n warnOnce(`layer.source = ${layer.source} does not equal this.source = ${this.source}`);\n }\n if (layer.minzoom && this.zoom < Math.floor(layer.minzoom)) continue;\n if (layer.maxzoom && this.zoom >= layer.maxzoom) continue;\n if (layer.visibility === 'none') continue;\n\n recalculateLayers(family, this.zoom, availableImages);\n\n const bucket: Bucket = buckets[layer.id] = layer.createBucket({\n index: featureIndex.bucketLayerIDs.length,\n layers: family,\n zoom: this.zoom,\n pixelRatio: this.pixelRatio,\n overscaling: this.overscaling,\n collisionBoxArray: this.collisionBoxArray,\n sourceLayerIndex,\n sourceID: this.source\n });\n\n bucket.populate(features, options, this.tileID.canonical);\n featureIndex.bucketLayerIDs.push(family.map((l) => l.id));\n }\n }\n\n // options.glyphDependencies looks like: {\"SomeFontName\":{\"10\":true,\"32\":true}}\n // this line makes an object like: {\"SomeFontName\":[10,32]}\n const stacks: {[_: string]: Array} = mapObject(options.glyphDependencies, (glyphs) => Object.keys(glyphs).map(Number));\n\n this.inFlightDependencies.forEach((request) => request?.abort());\n this.inFlightDependencies = [];\n\n let getGlyphsPromise = Promise.resolve({});\n if (Object.keys(stacks).length) {\n const abortController = new AbortController();\n this.inFlightDependencies.push(abortController);\n getGlyphsPromise = actor.sendAsync({type: MessageType.getGlyphs, data: {stacks, source: this.source, tileID: this.tileID, type: 'glyphs'}}, abortController);\n }\n\n const icons = Object.keys(options.iconDependencies);\n let getIconsPromise = Promise.resolve({});\n if (icons.length) {\n const abortController = new AbortController();\n this.inFlightDependencies.push(abortController);\n getIconsPromise = actor.sendAsync({type: MessageType.getImages, data: {icons, source: this.source, tileID: this.tileID, type: 'icons'}}, abortController);\n }\n\n const patterns = Object.keys(options.patternDependencies);\n let getPatternsPromise = Promise.resolve({});\n if (patterns.length) {\n const abortController = new AbortController();\n this.inFlightDependencies.push(abortController);\n getPatternsPromise = actor.sendAsync({type: MessageType.getImages, data: {icons: patterns, source: this.source, tileID: this.tileID, type: 'patterns'}}, abortController);\n }\n\n const [glyphMap, iconMap, patternMap] = await Promise.all([getGlyphsPromise, getIconsPromise, getPatternsPromise]);\n const glyphAtlas = new GlyphAtlas(glyphMap);\n const imageAtlas = new ImageAtlas(iconMap, patternMap);\n\n for (const key in buckets) {\n const bucket = buckets[key];\n if (bucket instanceof SymbolBucket) {\n recalculateLayers(bucket.layers, this.zoom, availableImages);\n performSymbolLayout({\n bucket,\n glyphMap,\n glyphPositions: glyphAtlas.positions,\n imageMap: iconMap,\n imagePositions: imageAtlas.iconPositions,\n showCollisionBoxes: this.showCollisionBoxes,\n canonical: this.tileID.canonical\n });\n } else if (bucket.hasPattern &&\n (bucket instanceof LineBucket ||\n bucket instanceof FillBucket ||\n bucket instanceof FillExtrusionBucket)) {\n recalculateLayers(bucket.layers, this.zoom, availableImages);\n bucket.addFeatures(options, this.tileID.canonical, imageAtlas.patternPositions);\n }\n }\n\n this.status = 'done';\n return {\n buckets: Object.values(buckets).filter(b => !b.isEmpty()),\n featureIndex,\n collisionBoxArray: this.collisionBoxArray,\n glyphAtlasImage: glyphAtlas.image,\n imageAtlas,\n // Only used for benchmarking:\n glyphMap: this.returnDependencies ? glyphMap : null,\n iconMap: this.returnDependencies ? iconMap : null,\n glyphPositions: this.returnDependencies ? glyphAtlas.positions : null\n };\n }\n}\n\nfunction recalculateLayers(layers: ReadonlyArray, zoom: number, availableImages: Array) {\n // Layers are shared and may have been used by a WorkerTile with a different zoom.\n const parameters = new EvaluationParameters(zoom);\n for (const layer of layers) {\n layer.recalculate(parameters, availableImages);\n }\n}\n","import {ExpiryData, getArrayBuffer} from '../util/ajax';\n\nimport vt from '@mapbox/vector-tile';\nimport Protobuf from 'pbf';\nimport {WorkerTile} from './worker_tile';\nimport {extend} from '../util/util';\nimport {RequestPerformance} from '../util/performance';\n\nimport type {\n WorkerSource,\n WorkerTileParameters,\n TileParameters,\n WorkerTileResult\n} from '../source/worker_source';\n\nimport type {IActor} from '../util/actor';\nimport type {StyleLayerIndex} from '../style/style_layer_index';\nimport type {VectorTile} from '@mapbox/vector-tile';\n\nexport type LoadVectorTileResult = {\n vectorTile: VectorTile;\n rawData: ArrayBuffer;\n resourceTiming?: Array;\n} & ExpiryData;\n\ntype FetchingState = {\n rawTileData: ArrayBuffer;\n cacheControl: ExpiryData;\n resourceTiming: any;\n}\n\nexport type AbortVectorData = () => void;\nexport type LoadVectorData = (params: WorkerTileParameters, abortController: AbortController) => Promise;\n\n/**\n * The {@link WorkerSource} implementation that supports {@link VectorTileSource}.\n * This class is designed to be easily reused to support custom source types\n * for data formats that can be parsed/converted into an in-memory VectorTile\n * representation. To do so, override its `loadVectorTile` method.\n */\nexport class VectorTileWorkerSource implements WorkerSource {\n actor: IActor;\n layerIndex: StyleLayerIndex;\n availableImages: Array;\n fetching: {[_: string]: FetchingState };\n loading: {[_: string]: WorkerTile};\n loaded: {[_: string]: WorkerTile};\n\n /**\n * @param loadVectorData - Optional method for custom loading of a VectorTile\n * object based on parameters passed from the main-thread Source. See\n * {@link VectorTileWorkerSource#loadTile}. The default implementation simply\n * loads the pbf at `params.url`.\n */\n constructor(actor: IActor, layerIndex: StyleLayerIndex, availableImages: Array) {\n this.actor = actor;\n this.layerIndex = layerIndex;\n this.availableImages = availableImages;\n this.fetching = {};\n this.loading = {};\n this.loaded = {};\n }\n\n /**\n * Loads a vector tile\n */\n async loadVectorTile(params: WorkerTileParameters, abortController: AbortController): Promise {\n const response = await getArrayBuffer(params.request, abortController);\n try {\n const vectorTile = new vt.VectorTile(new Protobuf(response.data));\n return {\n vectorTile,\n rawData: response.data,\n cacheControl: response.cacheControl,\n expires: response.expires\n };\n } catch (ex) {\n const bytes = new Uint8Array(response.data);\n const isGzipped = bytes[0] === 0x1f && bytes[1] === 0x8b;\n let errorMessage = `Unable to parse the tile at ${params.request.url}, `;\n if (isGzipped) {\n errorMessage += 'please make sure the data is not gzipped and that you have configured the relevant header in the server';\n } else {\n errorMessage += `got error: ${ex.message}`;\n }\n throw new Error(errorMessage);\n }\n }\n\n /**\n * Implements {@link WorkerSource#loadTile}. Delegates to\n * {@link VectorTileWorkerSource#loadVectorData} (which by default expects\n * a `params.url` property) for fetching and producing a VectorTile object.\n */\n async loadTile(params: WorkerTileParameters): Promise {\n const tileUid = params.uid;\n\n const perf = (params && params.request && params.request.collectResourceTiming) ?\n new RequestPerformance(params.request) : false;\n\n const workerTile = new WorkerTile(params);\n this.loading[tileUid] = workerTile;\n\n const abortController = new AbortController();\n workerTile.abort = abortController;\n try {\n const response = await this.loadVectorTile(params, abortController);\n delete this.loading[tileUid];\n if (!response) {\n return null;\n }\n\n const rawTileData = response.rawData;\n const cacheControl = {} as ExpiryData;\n if (response.expires) cacheControl.expires = response.expires;\n if (response.cacheControl) cacheControl.cacheControl = response.cacheControl;\n\n const resourceTiming = {} as {resourceTiming: any};\n if (perf) {\n const resourceTimingData = perf.finish();\n // it's necessary to eval the result of getEntriesByName() here via parse/stringify\n // late evaluation in the main thread causes TypeError: illegal invocation\n if (resourceTimingData)\n resourceTiming.resourceTiming = JSON.parse(JSON.stringify(resourceTimingData));\n }\n\n workerTile.vectorTile = response.vectorTile;\n const parsePromise = workerTile.parse(response.vectorTile, this.layerIndex, this.availableImages, this.actor);\n this.loaded[tileUid] = workerTile;\n // keep the original fetching state so that reload tile can pick it up if the original parse is cancelled by reloads' parse\n this.fetching[tileUid] = {rawTileData, cacheControl, resourceTiming};\n\n try {\n const result = await parsePromise;\n // Transferring a copy of rawTileData because the worker needs to retain its copy.\n return extend({rawTileData: rawTileData.slice(0)}, result, cacheControl, resourceTiming);\n } finally {\n delete this.fetching[tileUid];\n }\n } catch (err) {\n delete this.loading[tileUid];\n workerTile.status = 'done';\n this.loaded[tileUid] = workerTile;\n throw err;\n }\n }\n\n /**\n * Implements {@link WorkerSource#reloadTile}.\n */\n async reloadTile(params: WorkerTileParameters): Promise {\n const uid = params.uid;\n if (!this.loaded || !this.loaded[uid]) {\n throw new Error('Should not be trying to reload a tile that was never loaded or has been removed');\n }\n const workerTile = this.loaded[uid];\n workerTile.showCollisionBoxes = params.showCollisionBoxes;\n if (workerTile.status === 'parsing') {\n const result = await workerTile.parse(workerTile.vectorTile, this.layerIndex, this.availableImages, this.actor);\n // if we have cancelled the original parse, make sure to pass the rawTileData from the original fetch\n let parseResult: WorkerTileResult;\n if (this.fetching[uid]) {\n const {rawTileData, cacheControl, resourceTiming} = this.fetching[uid];\n delete this.fetching[uid];\n parseResult = extend({rawTileData: rawTileData.slice(0)}, result, cacheControl, resourceTiming);\n } else {\n parseResult = result;\n }\n return parseResult;\n\n }\n // if there was no vector tile data on the initial load, don't try and re-parse tile\n if (workerTile.status === 'done' && workerTile.vectorTile) {\n // this seems like a missing case where cache control is lost? see #3309\n return workerTile.parse(workerTile.vectorTile, this.layerIndex, this.availableImages, this.actor);\n }\n }\n\n /**\n * Implements {@link WorkerSource#abortTile}.\n */\n async abortTile(params: TileParameters): Promise {\n const loading = this.loading;\n const uid = params.uid;\n if (loading && loading[uid] && loading[uid].abort) {\n loading[uid].abort.abort();\n delete loading[uid];\n }\n }\n\n /**\n * Implements {@link WorkerSource#removeTile}.\n */\n async removeTile(params: TileParameters): Promise {\n if (this.loaded && this.loaded[params.uid]) {\n delete this.loaded[params.uid];\n }\n }\n}\n","import {DEMData} from '../data/dem_data';\nimport {RGBAImage} from '../util/image';\nimport type {Actor} from '../util/actor';\nimport type {\n WorkerDEMTileParameters,\n TileParameters\n} from './worker_source';\nimport {getImageData, isImageBitmap} from '../util/util';\n\nexport class RasterDEMTileWorkerSource {\n actor: Actor;\n loaded: {[_: string]: DEMData};\n\n constructor() {\n this.loaded = {};\n }\n\n async loadTile(params: WorkerDEMTileParameters): Promise {\n const {uid, encoding, rawImageData, redFactor, greenFactor, blueFactor, baseShift} = params;\n const width = rawImageData.width + 2;\n const height = rawImageData.height + 2;\n const imagePixels: RGBAImage | ImageData = isImageBitmap(rawImageData) ?\n new RGBAImage({width, height}, await getImageData(rawImageData, -1, -1, width, height)) :\n rawImageData;\n const dem = new DEMData(uid, imagePixels, encoding, redFactor, greenFactor, blueFactor, baseShift);\n this.loaded = this.loaded || {};\n this.loaded[uid] = dem;\n return dem;\n }\n\n removeTile(params: TileParameters) {\n const loaded = this.loaded,\n uid = params.uid;\n if (loaded && loaded[uid]) {\n delete loaded[uid];\n }\n }\n}\n","\nmodule.exports = rewind;\n\nfunction rewind(gj, outer) {\n var type = gj && gj.type, i;\n\n if (type === 'FeatureCollection') {\n for (i = 0; i < gj.features.length; i++) rewind(gj.features[i], outer);\n\n } else if (type === 'GeometryCollection') {\n for (i = 0; i < gj.geometries.length; i++) rewind(gj.geometries[i], outer);\n\n } else if (type === 'Feature') {\n rewind(gj.geometry, outer);\n\n } else if (type === 'Polygon') {\n rewindRings(gj.coordinates, outer);\n\n } else if (type === 'MultiPolygon') {\n for (i = 0; i < gj.coordinates.length; i++) rewindRings(gj.coordinates[i], outer);\n }\n\n return gj;\n}\n\nfunction rewindRings(rings, outer) {\n if (rings.length === 0) return;\n\n rewindRing(rings[0], outer);\n for (var i = 1; i < rings.length; i++) {\n rewindRing(rings[i], !outer);\n }\n}\n\nfunction rewindRing(ring, dir) {\n var area = 0, err = 0;\n for (var i = 0, len = ring.length, j = len - 1; i < len; j = i++) {\n var k = (ring[i][0] - ring[j][0]) * (ring[j][1] + ring[i][1]);\n var m = area + k;\n err += Math.abs(area) >= Math.abs(k) ? area - m + k : k - m + area;\n area = m;\n }\n if (area + err >= 0 !== !!dir) ring.reverse();\n}\n","import Point from '@mapbox/point-geometry';\n\nimport mvt from '@mapbox/vector-tile';\nimport type {VectorTileFeature, VectorTileLayer, VectorTile} from '@mapbox/vector-tile';\nconst toGeoJSON = mvt.VectorTileFeature.prototype.toGeoJSON;\nimport {EXTENT} from '../data/extent';\nimport type {TileFeature, AnyProps} from 'supercluster';\nimport type {Feature as GeoJSONVTFeature} from 'geojson-vt';\n\nexport type Feature = TileFeature | GeoJSONVTFeature;\n\nclass FeatureWrapper implements VectorTileFeature {\n _feature: Feature;\n\n extent: number;\n type: Feature['type'];\n id: number;\n properties: {[_: string]: string | number | boolean};\n\n constructor(feature: Feature) {\n this._feature = feature;\n\n this.extent = EXTENT;\n this.type = feature.type;\n this.properties = feature.tags;\n\n // If the feature has a top-level `id` property, copy it over, but only\n // if it can be coerced to an integer, because this wrapper is used for\n // serializing geojson feature data into vector tile PBF data, and the\n // vector tile spec only supports integer values for feature ids --\n // allowing non-integer values here results in a non-compliant PBF\n // that causes an exception when it is parsed with vector-tile-js\n if ('id' in feature && !isNaN(feature.id as any)) {\n this.id = parseInt(feature.id, 10);\n }\n }\n\n loadGeometry() {\n if (this._feature.type === 1) {\n const geometry = [];\n for (const point of this._feature.geometry) {\n geometry.push([new Point(point[0], point[1])]);\n }\n return geometry;\n } else {\n const geometry = [];\n for (const ring of this._feature.geometry) {\n const newRing = [];\n for (const point of ring) {\n newRing.push(new Point(point[0], point[1]));\n }\n geometry.push(newRing);\n }\n return geometry;\n }\n }\n\n toGeoJSON(x: number, y: number, z: number) {\n return toGeoJSON.call(this, x, y, z);\n }\n}\n\nexport class GeoJSONWrapper implements VectorTile, VectorTileLayer {\n layers: {[_: string]: VectorTileLayer};\n name: string;\n extent: number;\n length: number;\n _features: Array;\n\n constructor(features: Array) {\n this.layers = {'_geojsonTileLayer': this};\n this.name = '_geojsonTileLayer';\n this.extent = EXTENT;\n this.length = features.length;\n this._features = features;\n }\n\n feature(i: number): VectorTileFeature {\n return new FeatureWrapper(this._features[i]);\n }\n}\n","'use strict'\n\nvar Point = require('@mapbox/point-geometry')\nvar VectorTileFeature = require('@mapbox/vector-tile').VectorTileFeature\n\nmodule.exports = GeoJSONWrapper\n\n// conform to vectortile api\nfunction GeoJSONWrapper (features, options) {\n this.options = options || {}\n this.features = features\n this.length = features.length\n}\n\nGeoJSONWrapper.prototype.feature = function (i) {\n return new FeatureWrapper(this.features[i], this.options.extent)\n}\n\nfunction FeatureWrapper (feature, extent) {\n this.id = typeof feature.id === 'number' ? feature.id : undefined\n this.type = feature.type\n this.rawGeometry = feature.type === 1 ? [feature.geometry] : feature.geometry\n this.properties = feature.tags\n this.extent = extent || 4096\n}\n\nFeatureWrapper.prototype.loadGeometry = function () {\n var rings = this.rawGeometry\n this.geometry = []\n\n for (var i = 0; i < rings.length; i++) {\n var ring = rings[i]\n var newRing = []\n for (var j = 0; j < ring.length; j++) {\n newRing.push(new Point(ring[j][0], ring[j][1]))\n }\n this.geometry.push(newRing)\n }\n return this.geometry\n}\n\nFeatureWrapper.prototype.bbox = function () {\n if (!this.geometry) this.loadGeometry()\n\n var rings = this.geometry\n var x1 = Infinity\n var x2 = -Infinity\n var y1 = Infinity\n var y2 = -Infinity\n\n for (var i = 0; i < rings.length; i++) {\n var ring = rings[i]\n\n for (var j = 0; j < ring.length; j++) {\n var coord = ring[j]\n\n x1 = Math.min(x1, coord.x)\n x2 = Math.max(x2, coord.x)\n y1 = Math.min(y1, coord.y)\n y2 = Math.max(y2, coord.y)\n }\n }\n\n return [x1, y1, x2, y2]\n}\n\nFeatureWrapper.prototype.toGeoJSON = VectorTileFeature.prototype.toGeoJSON\n","var Pbf = require('pbf')\nvar GeoJSONWrapper = require('./lib/geojson_wrapper')\n\nmodule.exports = fromVectorTileJs\nmodule.exports.fromVectorTileJs = fromVectorTileJs\nmodule.exports.fromGeojsonVt = fromGeojsonVt\nmodule.exports.GeoJSONWrapper = GeoJSONWrapper\n\n/**\n * Serialize a vector-tile-js-created tile to pbf\n *\n * @param {Object} tile\n * @return {Buffer} uncompressed, pbf-serialized tile data\n */\nfunction fromVectorTileJs (tile) {\n var out = new Pbf()\n writeTile(tile, out)\n return out.finish()\n}\n\n/**\n * Serialized a geojson-vt-created tile to pbf.\n *\n * @param {Object} layers - An object mapping layer names to geojson-vt-created vector tile objects\n * @param {Object} [options] - An object specifying the vector-tile specification version and extent that were used to create `layers`.\n * @param {Number} [options.version=1] - Version of vector-tile spec used\n * @param {Number} [options.extent=4096] - Extent of the vector tile\n * @return {Buffer} uncompressed, pbf-serialized tile data\n */\nfunction fromGeojsonVt (layers, options) {\n options = options || {}\n var l = {}\n for (var k in layers) {\n l[k] = new GeoJSONWrapper(layers[k].features, options)\n l[k].name = k\n l[k].version = options.version\n l[k].extent = options.extent\n }\n return fromVectorTileJs({ layers: l })\n}\n\nfunction writeTile (tile, pbf) {\n for (var key in tile.layers) {\n pbf.writeMessage(3, writeLayer, tile.layers[key])\n }\n}\n\nfunction writeLayer (layer, pbf) {\n pbf.writeVarintField(15, layer.version || 1)\n pbf.writeStringField(1, layer.name || '')\n pbf.writeVarintField(5, layer.extent || 4096)\n\n var i\n var context = {\n keys: [],\n values: [],\n keycache: {},\n valuecache: {}\n }\n\n for (i = 0; i < layer.length; i++) {\n context.feature = layer.feature(i)\n pbf.writeMessage(2, writeFeature, context)\n }\n\n var keys = context.keys\n for (i = 0; i < keys.length; i++) {\n pbf.writeStringField(3, keys[i])\n }\n\n var values = context.values\n for (i = 0; i < values.length; i++) {\n pbf.writeMessage(4, writeValue, values[i])\n }\n}\n\nfunction writeFeature (context, pbf) {\n var feature = context.feature\n\n if (feature.id !== undefined) {\n pbf.writeVarintField(1, feature.id)\n }\n\n pbf.writeMessage(2, writeProperties, context)\n pbf.writeVarintField(3, feature.type)\n pbf.writeMessage(4, writeGeometry, feature)\n}\n\nfunction writeProperties (context, pbf) {\n var feature = context.feature\n var keys = context.keys\n var values = context.values\n var keycache = context.keycache\n var valuecache = context.valuecache\n\n for (var key in feature.properties) {\n var value = feature.properties[key]\n\n var keyIndex = keycache[key]\n if (value === null) continue // don't encode null value properties\n\n if (typeof keyIndex === 'undefined') {\n keys.push(key)\n keyIndex = keys.length - 1\n keycache[key] = keyIndex\n }\n pbf.writeVarint(keyIndex)\n\n var type = typeof value\n if (type !== 'string' && type !== 'boolean' && type !== 'number') {\n value = JSON.stringify(value)\n }\n var valueKey = type + ':' + value\n var valueIndex = valuecache[valueKey]\n if (typeof valueIndex === 'undefined') {\n values.push(value)\n valueIndex = values.length - 1\n valuecache[valueKey] = valueIndex\n }\n pbf.writeVarint(valueIndex)\n }\n}\n\nfunction command (cmd, length) {\n return (length << 3) + (cmd & 0x7)\n}\n\nfunction zigzag (num) {\n return (num << 1) ^ (num >> 31)\n}\n\nfunction writeGeometry (feature, pbf) {\n var geometry = feature.loadGeometry()\n var type = feature.type\n var x = 0\n var y = 0\n var rings = geometry.length\n for (var r = 0; r < rings; r++) {\n var ring = geometry[r]\n var count = 1\n if (type === 1) {\n count = ring.length\n }\n pbf.writeVarint(command(1, count)) // moveto\n // do not write polygon closing path as lineto\n var lineCount = type === 3 ? ring.length - 1 : ring.length\n for (var i = 0; i < lineCount; i++) {\n if (i === 1 && type !== 1) {\n pbf.writeVarint(command(2, lineCount - 1)) // lineto\n }\n var dx = ring[i].x - x\n var dy = ring[i].y - y\n pbf.writeVarint(zigzag(dx))\n pbf.writeVarint(zigzag(dy))\n x += dx\n y += dy\n }\n if (type === 3) {\n pbf.writeVarint(command(7, 1)) // closepath\n }\n }\n}\n\nfunction writeValue (value, pbf) {\n var type = typeof value\n if (type === 'string') {\n pbf.writeStringField(1, value)\n } else if (type === 'boolean') {\n pbf.writeBooleanField(7, value)\n } else if (type === 'number') {\n if (value % 1 !== 0) {\n pbf.writeDoubleField(3, value)\n } else if (value < 0) {\n pbf.writeSVarintField(6, value)\n } else {\n pbf.writeVarintField(5, value)\n }\n }\n}\n","\nimport KDBush from 'kdbush';\n\nconst defaultOptions = {\n minZoom: 0, // min zoom to generate clusters on\n maxZoom: 16, // max zoom level to cluster the points on\n minPoints: 2, // minimum points to form a cluster\n radius: 40, // cluster radius in pixels\n extent: 512, // tile extent (radius is calculated relative to it)\n nodeSize: 64, // size of the KD-tree leaf node, affects performance\n log: false, // whether to log timing info\n\n // whether to generate numeric ids for input features (in vector tiles)\n generateId: false,\n\n // a reduce function for calculating custom cluster properties\n reduce: null, // (accumulated, props) => { accumulated.sum += props.sum; }\n\n // properties to use for individual points when running the reducer\n map: props => props // props => ({sum: props.my_value})\n};\n\nconst fround = Math.fround || (tmp => ((x) => { tmp[0] = +x; return tmp[0]; }))(new Float32Array(1));\n\nconst OFFSET_ZOOM = 2;\nconst OFFSET_ID = 3;\nconst OFFSET_PARENT = 4;\nconst OFFSET_NUM = 5;\nconst OFFSET_PROP = 6;\n\nexport default class Supercluster {\n constructor(options) {\n this.options = Object.assign(Object.create(defaultOptions), options);\n this.trees = new Array(this.options.maxZoom + 1);\n this.stride = this.options.reduce ? 7 : 6;\n this.clusterProps = [];\n }\n\n load(points) {\n const {log, minZoom, maxZoom} = this.options;\n\n if (log) console.time('total time');\n\n const timerId = `prepare ${ points.length } points`;\n if (log) console.time(timerId);\n\n this.points = points;\n\n // generate a cluster object for each point and index input points into a KD-tree\n const data = [];\n\n for (let i = 0; i < points.length; i++) {\n const p = points[i];\n if (!p.geometry) continue;\n\n const [lng, lat] = p.geometry.coordinates;\n const x = fround(lngX(lng));\n const y = fround(latY(lat));\n // store internal point/cluster data in flat numeric arrays for performance\n data.push(\n x, y, // projected point coordinates\n Infinity, // the last zoom the point was processed at\n i, // index of the source feature in the original input array\n -1, // parent cluster id\n 1 // number of points in a cluster\n );\n if (this.options.reduce) data.push(0); // noop\n }\n let tree = this.trees[maxZoom + 1] = this._createTree(data);\n\n if (log) console.timeEnd(timerId);\n\n // cluster points on max zoom, then cluster the results on previous zoom, etc.;\n // results in a cluster hierarchy across zoom levels\n for (let z = maxZoom; z >= minZoom; z--) {\n const now = +Date.now();\n\n // create a new set of clusters for the zoom and index them with a KD-tree\n tree = this.trees[z] = this._createTree(this._cluster(tree, z));\n\n if (log) console.log('z%d: %d clusters in %dms', z, tree.numItems, +Date.now() - now);\n }\n\n if (log) console.timeEnd('total time');\n\n return this;\n }\n\n getClusters(bbox, zoom) {\n let minLng = ((bbox[0] + 180) % 360 + 360) % 360 - 180;\n const minLat = Math.max(-90, Math.min(90, bbox[1]));\n let maxLng = bbox[2] === 180 ? 180 : ((bbox[2] + 180) % 360 + 360) % 360 - 180;\n const maxLat = Math.max(-90, Math.min(90, bbox[3]));\n\n if (bbox[2] - bbox[0] >= 360) {\n minLng = -180;\n maxLng = 180;\n } else if (minLng > maxLng) {\n const easternHem = this.getClusters([minLng, minLat, 180, maxLat], zoom);\n const westernHem = this.getClusters([-180, minLat, maxLng, maxLat], zoom);\n return easternHem.concat(westernHem);\n }\n\n const tree = this.trees[this._limitZoom(zoom)];\n const ids = tree.range(lngX(minLng), latY(maxLat), lngX(maxLng), latY(minLat));\n const data = tree.data;\n const clusters = [];\n for (const id of ids) {\n const k = this.stride * id;\n clusters.push(data[k + OFFSET_NUM] > 1 ? getClusterJSON(data, k, this.clusterProps) : this.points[data[k + OFFSET_ID]]);\n }\n return clusters;\n }\n\n getChildren(clusterId) {\n const originId = this._getOriginId(clusterId);\n const originZoom = this._getOriginZoom(clusterId);\n const errorMsg = 'No cluster with the specified id.';\n\n const tree = this.trees[originZoom];\n if (!tree) throw new Error(errorMsg);\n\n const data = tree.data;\n if (originId * this.stride >= data.length) throw new Error(errorMsg);\n\n const r = this.options.radius / (this.options.extent * Math.pow(2, originZoom - 1));\n const x = data[originId * this.stride];\n const y = data[originId * this.stride + 1];\n const ids = tree.within(x, y, r);\n const children = [];\n for (const id of ids) {\n const k = id * this.stride;\n if (data[k + OFFSET_PARENT] === clusterId) {\n children.push(data[k + OFFSET_NUM] > 1 ? getClusterJSON(data, k, this.clusterProps) : this.points[data[k + OFFSET_ID]]);\n }\n }\n\n if (children.length === 0) throw new Error(errorMsg);\n\n return children;\n }\n\n getLeaves(clusterId, limit, offset) {\n limit = limit || 10;\n offset = offset || 0;\n\n const leaves = [];\n this._appendLeaves(leaves, clusterId, limit, offset, 0);\n\n return leaves;\n }\n\n getTile(z, x, y) {\n const tree = this.trees[this._limitZoom(z)];\n const z2 = Math.pow(2, z);\n const {extent, radius} = this.options;\n const p = radius / extent;\n const top = (y - p) / z2;\n const bottom = (y + 1 + p) / z2;\n\n const tile = {\n features: []\n };\n\n this._addTileFeatures(\n tree.range((x - p) / z2, top, (x + 1 + p) / z2, bottom),\n tree.data, x, y, z2, tile);\n\n if (x === 0) {\n this._addTileFeatures(\n tree.range(1 - p / z2, top, 1, bottom),\n tree.data, z2, y, z2, tile);\n }\n if (x === z2 - 1) {\n this._addTileFeatures(\n tree.range(0, top, p / z2, bottom),\n tree.data, -1, y, z2, tile);\n }\n\n return tile.features.length ? tile : null;\n }\n\n getClusterExpansionZoom(clusterId) {\n let expansionZoom = this._getOriginZoom(clusterId) - 1;\n while (expansionZoom <= this.options.maxZoom) {\n const children = this.getChildren(clusterId);\n expansionZoom++;\n if (children.length !== 1) break;\n clusterId = children[0].properties.cluster_id;\n }\n return expansionZoom;\n }\n\n _appendLeaves(result, clusterId, limit, offset, skipped) {\n const children = this.getChildren(clusterId);\n\n for (const child of children) {\n const props = child.properties;\n\n if (props && props.cluster) {\n if (skipped + props.point_count <= offset) {\n // skip the whole cluster\n skipped += props.point_count;\n } else {\n // enter the cluster\n skipped = this._appendLeaves(result, props.cluster_id, limit, offset, skipped);\n // exit the cluster\n }\n } else if (skipped < offset) {\n // skip a single point\n skipped++;\n } else {\n // add a single point\n result.push(child);\n }\n if (result.length === limit) break;\n }\n\n return skipped;\n }\n\n _createTree(data) {\n const tree = new KDBush(data.length / this.stride | 0, this.options.nodeSize, Float32Array);\n for (let i = 0; i < data.length; i += this.stride) tree.add(data[i], data[i + 1]);\n tree.finish();\n tree.data = data;\n return tree;\n }\n\n _addTileFeatures(ids, data, x, y, z2, tile) {\n for (const i of ids) {\n const k = i * this.stride;\n const isCluster = data[k + OFFSET_NUM] > 1;\n\n let tags, px, py;\n if (isCluster) {\n tags = getClusterProperties(data, k, this.clusterProps);\n px = data[k];\n py = data[k + 1];\n } else {\n const p = this.points[data[k + OFFSET_ID]];\n tags = p.properties;\n const [lng, lat] = p.geometry.coordinates;\n px = lngX(lng);\n py = latY(lat);\n }\n\n const f = {\n type: 1,\n geometry: [[\n Math.round(this.options.extent * (px * z2 - x)),\n Math.round(this.options.extent * (py * z2 - y))\n ]],\n tags\n };\n\n // assign id\n let id;\n if (isCluster || this.options.generateId) {\n // optionally generate id for points\n id = data[k + OFFSET_ID];\n } else {\n // keep id if already assigned\n id = this.points[data[k + OFFSET_ID]].id;\n }\n\n if (id !== undefined) f.id = id;\n\n tile.features.push(f);\n }\n }\n\n _limitZoom(z) {\n return Math.max(this.options.minZoom, Math.min(Math.floor(+z), this.options.maxZoom + 1));\n }\n\n _cluster(tree, zoom) {\n const {radius, extent, reduce, minPoints} = this.options;\n const r = radius / (extent * Math.pow(2, zoom));\n const data = tree.data;\n const nextData = [];\n const stride = this.stride;\n\n // loop through each point\n for (let i = 0; i < data.length; i += stride) {\n // if we've already visited the point at this zoom level, skip it\n if (data[i + OFFSET_ZOOM] <= zoom) continue;\n data[i + OFFSET_ZOOM] = zoom;\n\n // find all nearby points\n const x = data[i];\n const y = data[i + 1];\n const neighborIds = tree.within(data[i], data[i + 1], r);\n\n const numPointsOrigin = data[i + OFFSET_NUM];\n let numPoints = numPointsOrigin;\n\n // count the number of points in a potential cluster\n for (const neighborId of neighborIds) {\n const k = neighborId * stride;\n // filter out neighbors that are already processed\n if (data[k + OFFSET_ZOOM] > zoom) numPoints += data[k + OFFSET_NUM];\n }\n\n // if there were neighbors to merge, and there are enough points to form a cluster\n if (numPoints > numPointsOrigin && numPoints >= minPoints) {\n let wx = x * numPointsOrigin;\n let wy = y * numPointsOrigin;\n\n let clusterProperties;\n let clusterPropIndex = -1;\n\n // encode both zoom and point index on which the cluster originated -- offset by total length of features\n const id = ((i / stride | 0) << 5) + (zoom + 1) + this.points.length;\n\n for (const neighborId of neighborIds) {\n const k = neighborId * stride;\n\n if (data[k + OFFSET_ZOOM] <= zoom) continue;\n data[k + OFFSET_ZOOM] = zoom; // save the zoom (so it doesn't get processed twice)\n\n const numPoints2 = data[k + OFFSET_NUM];\n wx += data[k] * numPoints2; // accumulate coordinates for calculating weighted center\n wy += data[k + 1] * numPoints2;\n\n data[k + OFFSET_PARENT] = id;\n\n if (reduce) {\n if (!clusterProperties) {\n clusterProperties = this._map(data, i, true);\n clusterPropIndex = this.clusterProps.length;\n this.clusterProps.push(clusterProperties);\n }\n reduce(clusterProperties, this._map(data, k));\n }\n }\n\n data[i + OFFSET_PARENT] = id;\n nextData.push(wx / numPoints, wy / numPoints, Infinity, id, -1, numPoints);\n if (reduce) nextData.push(clusterPropIndex);\n\n } else { // left points as unclustered\n for (let j = 0; j < stride; j++) nextData.push(data[i + j]);\n\n if (numPoints > 1) {\n for (const neighborId of neighborIds) {\n const k = neighborId * stride;\n if (data[k + OFFSET_ZOOM] <= zoom) continue;\n data[k + OFFSET_ZOOM] = zoom;\n for (let j = 0; j < stride; j++) nextData.push(data[k + j]);\n }\n }\n }\n }\n\n return nextData;\n }\n\n // get index of the point from which the cluster originated\n _getOriginId(clusterId) {\n return (clusterId - this.points.length) >> 5;\n }\n\n // get zoom of the point from which the cluster originated\n _getOriginZoom(clusterId) {\n return (clusterId - this.points.length) % 32;\n }\n\n _map(data, i, clone) {\n if (data[i + OFFSET_NUM] > 1) {\n const props = this.clusterProps[data[i + OFFSET_PROP]];\n return clone ? Object.assign({}, props) : props;\n }\n const original = this.points[data[i + OFFSET_ID]].properties;\n const result = this.options.map(original);\n return clone && result === original ? Object.assign({}, result) : result;\n }\n}\n\nfunction getClusterJSON(data, i, clusterProps) {\n return {\n type: 'Feature',\n id: data[i + OFFSET_ID],\n properties: getClusterProperties(data, i, clusterProps),\n geometry: {\n type: 'Point',\n coordinates: [xLng(data[i]), yLat(data[i + 1])]\n }\n };\n}\n\nfunction getClusterProperties(data, i, clusterProps) {\n const count = data[i + OFFSET_NUM];\n const abbrev =\n count >= 10000 ? `${Math.round(count / 1000) }k` :\n count >= 1000 ? `${Math.round(count / 100) / 10 }k` : count;\n const propIndex = data[i + OFFSET_PROP];\n const properties = propIndex === -1 ? {} : Object.assign({}, clusterProps[propIndex]);\n return Object.assign(properties, {\n cluster: true,\n cluster_id: data[i + OFFSET_ID],\n point_count: count,\n point_count_abbreviated: abbrev\n });\n}\n\n// longitude/latitude to spherical mercator in [0..1] range\nfunction lngX(lng) {\n return lng / 360 + 0.5;\n}\nfunction latY(lat) {\n const sin = Math.sin(lat * Math.PI / 180);\n const y = (0.5 - 0.25 * Math.log((1 + sin) / (1 - sin)) / Math.PI);\n return y < 0 ? 0 : y > 1 ? 1 : y;\n}\n\n// spherical mercator to longitude/latitude\nfunction xLng(x) {\n return (x - 0.5) * 360;\n}\nfunction yLat(y) {\n const y2 = (180 - y * 360) * Math.PI / 180;\n return 360 * Math.atan(Math.exp(y2)) / Math.PI - 90;\n}\n","\n// calculate simplification data using optimized Douglas-Peucker algorithm\n\nexport default function simplify(coords, first, last, sqTolerance) {\n let maxSqDist = sqTolerance;\n const mid = first + ((last - first) >> 1);\n let minPosToMid = last - first;\n let index;\n\n const ax = coords[first];\n const ay = coords[first + 1];\n const bx = coords[last];\n const by = coords[last + 1];\n\n for (let i = first + 3; i < last; i += 3) {\n const d = getSqSegDist(coords[i], coords[i + 1], ax, ay, bx, by);\n\n if (d > maxSqDist) {\n index = i;\n maxSqDist = d;\n\n } else if (d === maxSqDist) {\n // a workaround to ensure we choose a pivot close to the middle of the list,\n // reducing recursion depth, for certain degenerate inputs\n // https://github.com/mapbox/geojson-vt/issues/104\n const posToMid = Math.abs(i - mid);\n if (posToMid < minPosToMid) {\n index = i;\n minPosToMid = posToMid;\n }\n }\n }\n\n if (maxSqDist > sqTolerance) {\n if (index - first > 3) simplify(coords, first, index, sqTolerance);\n coords[index + 2] = maxSqDist;\n if (last - index > 3) simplify(coords, index, last, sqTolerance);\n }\n}\n\n// square distance from a point to a segment\nfunction getSqSegDist(px, py, x, y, bx, by) {\n\n let dx = bx - x;\n let dy = by - y;\n\n if (dx !== 0 || dy !== 0) {\n\n const t = ((px - x) * dx + (py - y) * dy) / (dx * dx + dy * dy);\n\n if (t > 1) {\n x = bx;\n y = by;\n\n } else if (t > 0) {\n x += dx * t;\n y += dy * t;\n }\n }\n\n dx = px - x;\n dy = py - y;\n\n return dx * dx + dy * dy;\n}\n","\nexport default function createFeature(id, type, geom, tags) {\n const feature = {\n id: id == null ? null : id,\n type,\n geometry: geom,\n tags,\n minX: Infinity,\n minY: Infinity,\n maxX: -Infinity,\n maxY: -Infinity\n };\n\n if (type === 'Point' || type === 'MultiPoint' || type === 'LineString') {\n calcLineBBox(feature, geom);\n\n } else if (type === 'Polygon') {\n // the outer ring (ie [0]) contains all inner rings\n calcLineBBox(feature, geom[0]);\n\n } else if (type === 'MultiLineString') {\n for (const line of geom) {\n calcLineBBox(feature, line);\n }\n\n } else if (type === 'MultiPolygon') {\n for (const polygon of geom) {\n // the outer ring (ie [0]) contains all inner rings\n calcLineBBox(feature, polygon[0]);\n }\n }\n\n return feature;\n}\n\nfunction calcLineBBox(feature, geom) {\n for (let i = 0; i < geom.length; i += 3) {\n feature.minX = Math.min(feature.minX, geom[i]);\n feature.minY = Math.min(feature.minY, geom[i + 1]);\n feature.maxX = Math.max(feature.maxX, geom[i]);\n feature.maxY = Math.max(feature.maxY, geom[i + 1]);\n }\n}\n","\nimport simplify from './simplify.js';\nimport createFeature from './feature.js';\n\n// converts GeoJSON feature into an intermediate projected JSON vector format with simplification data\n\nexport default function convert(data, options) {\n const features = [];\n if (data.type === 'FeatureCollection') {\n for (let i = 0; i < data.features.length; i++) {\n convertFeature(features, data.features[i], options, i);\n }\n\n } else if (data.type === 'Feature') {\n convertFeature(features, data, options);\n\n } else {\n // single geometry or a geometry collection\n convertFeature(features, {geometry: data}, options);\n }\n\n return features;\n}\n\nfunction convertFeature(features, geojson, options, index) {\n if (!geojson.geometry) return;\n\n const coords = geojson.geometry.coordinates;\n if (coords && coords.length === 0) return;\n\n const type = geojson.geometry.type;\n const tolerance = Math.pow(options.tolerance / ((1 << options.maxZoom) * options.extent), 2);\n let geometry = [];\n let id = geojson.id;\n if (options.promoteId) {\n id = geojson.properties[options.promoteId];\n } else if (options.generateId) {\n id = index || 0;\n }\n if (type === 'Point') {\n convertPoint(coords, geometry);\n\n } else if (type === 'MultiPoint') {\n for (const p of coords) {\n convertPoint(p, geometry);\n }\n\n } else if (type === 'LineString') {\n convertLine(coords, geometry, tolerance, false);\n\n } else if (type === 'MultiLineString') {\n if (options.lineMetrics) {\n // explode into linestrings to be able to track metrics\n for (const line of coords) {\n geometry = [];\n convertLine(line, geometry, tolerance, false);\n features.push(createFeature(id, 'LineString', geometry, geojson.properties));\n }\n return;\n } else {\n convertLines(coords, geometry, tolerance, false);\n }\n\n } else if (type === 'Polygon') {\n convertLines(coords, geometry, tolerance, true);\n\n } else if (type === 'MultiPolygon') {\n for (const polygon of coords) {\n const newPolygon = [];\n convertLines(polygon, newPolygon, tolerance, true);\n geometry.push(newPolygon);\n }\n } else if (type === 'GeometryCollection') {\n for (const singleGeometry of geojson.geometry.geometries) {\n convertFeature(features, {\n id,\n geometry: singleGeometry,\n properties: geojson.properties\n }, options, index);\n }\n return;\n } else {\n throw new Error('Input data is not a valid GeoJSON object.');\n }\n\n features.push(createFeature(id, type, geometry, geojson.properties));\n}\n\nfunction convertPoint(coords, out) {\n out.push(projectX(coords[0]), projectY(coords[1]), 0);\n}\n\nfunction convertLine(ring, out, tolerance, isPolygon) {\n let x0, y0;\n let size = 0;\n\n for (let j = 0; j < ring.length; j++) {\n const x = projectX(ring[j][0]);\n const y = projectY(ring[j][1]);\n\n out.push(x, y, 0);\n\n if (j > 0) {\n if (isPolygon) {\n size += (x0 * y - x * y0) / 2; // area\n } else {\n size += Math.sqrt(Math.pow(x - x0, 2) + Math.pow(y - y0, 2)); // length\n }\n }\n x0 = x;\n y0 = y;\n }\n\n const last = out.length - 3;\n out[2] = 1;\n simplify(out, 0, last, tolerance);\n out[last + 2] = 1;\n\n out.size = Math.abs(size);\n out.start = 0;\n out.end = out.size;\n}\n\nfunction convertLines(rings, out, tolerance, isPolygon) {\n for (let i = 0; i < rings.length; i++) {\n const geom = [];\n convertLine(rings[i], geom, tolerance, isPolygon);\n out.push(geom);\n }\n}\n\nfunction projectX(x) {\n return x / 360 + 0.5;\n}\n\nfunction projectY(y) {\n const sin = Math.sin(y * Math.PI / 180);\n const y2 = 0.5 - 0.25 * Math.log((1 + sin) / (1 - sin)) / Math.PI;\n return y2 < 0 ? 0 : y2 > 1 ? 1 : y2;\n}\n","\nimport createFeature from './feature.js';\n\n/* clip features between two vertical or horizontal axis-parallel lines:\n * | |\n * ___|___ | /\n * / | \\____|____/\n * | |\n *\n * k1 and k2 are the line coordinates\n * axis: 0 for x, 1 for y\n * minAll and maxAll: minimum and maximum coordinate value for all features\n */\nexport default function clip(features, scale, k1, k2, axis, minAll, maxAll, options) {\n k1 /= scale;\n k2 /= scale;\n\n if (minAll >= k1 && maxAll < k2) return features; // trivial accept\n else if (maxAll < k1 || minAll >= k2) return null; // trivial reject\n\n const clipped = [];\n\n for (const feature of features) {\n const geometry = feature.geometry;\n let type = feature.type;\n\n const min = axis === 0 ? feature.minX : feature.minY;\n const max = axis === 0 ? feature.maxX : feature.maxY;\n\n if (min >= k1 && max < k2) { // trivial accept\n clipped.push(feature);\n continue;\n } else if (max < k1 || min >= k2) { // trivial reject\n continue;\n }\n\n let newGeometry = [];\n\n if (type === 'Point' || type === 'MultiPoint') {\n clipPoints(geometry, newGeometry, k1, k2, axis);\n\n } else if (type === 'LineString') {\n clipLine(geometry, newGeometry, k1, k2, axis, false, options.lineMetrics);\n\n } else if (type === 'MultiLineString') {\n clipLines(geometry, newGeometry, k1, k2, axis, false);\n\n } else if (type === 'Polygon') {\n clipLines(geometry, newGeometry, k1, k2, axis, true);\n\n } else if (type === 'MultiPolygon') {\n for (const polygon of geometry) {\n const newPolygon = [];\n clipLines(polygon, newPolygon, k1, k2, axis, true);\n if (newPolygon.length) {\n newGeometry.push(newPolygon);\n }\n }\n }\n\n if (newGeometry.length) {\n if (options.lineMetrics && type === 'LineString') {\n for (const line of newGeometry) {\n clipped.push(createFeature(feature.id, type, line, feature.tags));\n }\n continue;\n }\n\n if (type === 'LineString' || type === 'MultiLineString') {\n if (newGeometry.length === 1) {\n type = 'LineString';\n newGeometry = newGeometry[0];\n } else {\n type = 'MultiLineString';\n }\n }\n if (type === 'Point' || type === 'MultiPoint') {\n type = newGeometry.length === 3 ? 'Point' : 'MultiPoint';\n }\n\n clipped.push(createFeature(feature.id, type, newGeometry, feature.tags));\n }\n }\n\n return clipped.length ? clipped : null;\n}\n\nfunction clipPoints(geom, newGeom, k1, k2, axis) {\n for (let i = 0; i < geom.length; i += 3) {\n const a = geom[i + axis];\n\n if (a >= k1 && a <= k2) {\n addPoint(newGeom, geom[i], geom[i + 1], geom[i + 2]);\n }\n }\n}\n\nfunction clipLine(geom, newGeom, k1, k2, axis, isPolygon, trackMetrics) {\n\n let slice = newSlice(geom);\n const intersect = axis === 0 ? intersectX : intersectY;\n let len = geom.start;\n let segLen, t;\n\n for (let i = 0; i < geom.length - 3; i += 3) {\n const ax = geom[i];\n const ay = geom[i + 1];\n const az = geom[i + 2];\n const bx = geom[i + 3];\n const by = geom[i + 4];\n const a = axis === 0 ? ax : ay;\n const b = axis === 0 ? bx : by;\n let exited = false;\n\n if (trackMetrics) segLen = Math.sqrt(Math.pow(ax - bx, 2) + Math.pow(ay - by, 2));\n\n if (a < k1) {\n // ---|--> | (line enters the clip region from the left)\n if (b > k1) {\n t = intersect(slice, ax, ay, bx, by, k1);\n if (trackMetrics) slice.start = len + segLen * t;\n }\n } else if (a > k2) {\n // | <--|--- (line enters the clip region from the right)\n if (b < k2) {\n t = intersect(slice, ax, ay, bx, by, k2);\n if (trackMetrics) slice.start = len + segLen * t;\n }\n } else {\n addPoint(slice, ax, ay, az);\n }\n if (b < k1 && a >= k1) {\n // <--|--- | or <--|-----|--- (line exits the clip region on the left)\n t = intersect(slice, ax, ay, bx, by, k1);\n exited = true;\n }\n if (b > k2 && a <= k2) {\n // | ---|--> or ---|-----|--> (line exits the clip region on the right)\n t = intersect(slice, ax, ay, bx, by, k2);\n exited = true;\n }\n\n if (!isPolygon && exited) {\n if (trackMetrics) slice.end = len + segLen * t;\n newGeom.push(slice);\n slice = newSlice(geom);\n }\n\n if (trackMetrics) len += segLen;\n }\n\n // add the last point\n let last = geom.length - 3;\n const ax = geom[last];\n const ay = geom[last + 1];\n const az = geom[last + 2];\n const a = axis === 0 ? ax : ay;\n if (a >= k1 && a <= k2) addPoint(slice, ax, ay, az);\n\n // close the polygon if its endpoints are not the same after clipping\n last = slice.length - 3;\n if (isPolygon && last >= 3 && (slice[last] !== slice[0] || slice[last + 1] !== slice[1])) {\n addPoint(slice, slice[0], slice[1], slice[2]);\n }\n\n // add the final slice\n if (slice.length) {\n newGeom.push(slice);\n }\n}\n\nfunction newSlice(line) {\n const slice = [];\n slice.size = line.size;\n slice.start = line.start;\n slice.end = line.end;\n return slice;\n}\n\nfunction clipLines(geom, newGeom, k1, k2, axis, isPolygon) {\n for (const line of geom) {\n clipLine(line, newGeom, k1, k2, axis, isPolygon, false);\n }\n}\n\nfunction addPoint(out, x, y, z) {\n out.push(x, y, z);\n}\n\nfunction intersectX(out, ax, ay, bx, by, x) {\n const t = (x - ax) / (bx - ax);\n addPoint(out, x, ay + (by - ay) * t, 1);\n return t;\n}\n\nfunction intersectY(out, ax, ay, bx, by, y) {\n const t = (y - ay) / (by - ay);\n addPoint(out, ax + (bx - ax) * t, y, 1);\n return t;\n}\n","\nimport clip from './clip.js';\nimport createFeature from './feature.js';\n\nexport default function wrap(features, options) {\n const buffer = options.buffer / options.extent;\n let merged = features;\n const left = clip(features, 1, -1 - buffer, buffer, 0, -1, 2, options); // left world copy\n const right = clip(features, 1, 1 - buffer, 2 + buffer, 0, -1, 2, options); // right world copy\n\n if (left || right) {\n merged = clip(features, 1, -buffer, 1 + buffer, 0, -1, 2, options) || []; // center world copy\n\n if (left) merged = shiftFeatureCoords(left, 1).concat(merged); // merge left into center\n if (right) merged = merged.concat(shiftFeatureCoords(right, -1)); // merge right into center\n }\n\n return merged;\n}\n\nfunction shiftFeatureCoords(features, offset) {\n const newFeatures = [];\n\n for (let i = 0; i < features.length; i++) {\n const feature = features[i];\n const type = feature.type;\n\n let newGeometry;\n\n if (type === 'Point' || type === 'MultiPoint' || type === 'LineString') {\n newGeometry = shiftCoords(feature.geometry, offset);\n\n } else if (type === 'MultiLineString' || type === 'Polygon') {\n newGeometry = [];\n for (const line of feature.geometry) {\n newGeometry.push(shiftCoords(line, offset));\n }\n } else if (type === 'MultiPolygon') {\n newGeometry = [];\n for (const polygon of feature.geometry) {\n const newPolygon = [];\n for (const line of polygon) {\n newPolygon.push(shiftCoords(line, offset));\n }\n newGeometry.push(newPolygon);\n }\n }\n\n newFeatures.push(createFeature(feature.id, type, newGeometry, feature.tags));\n }\n\n return newFeatures;\n}\n\nfunction shiftCoords(points, offset) {\n const newPoints = [];\n newPoints.size = points.size;\n\n if (points.start !== undefined) {\n newPoints.start = points.start;\n newPoints.end = points.end;\n }\n\n for (let i = 0; i < points.length; i += 3) {\n newPoints.push(points[i] + offset, points[i + 1], points[i + 2]);\n }\n return newPoints;\n}\n","\n// Transforms the coordinates of each feature in the given tile from\n// mercator-projected space into (extent x extent) tile space.\nexport default function transformTile(tile, extent) {\n if (tile.transformed) return tile;\n\n const z2 = 1 << tile.z;\n const tx = tile.x;\n const ty = tile.y;\n\n for (const feature of tile.features) {\n const geom = feature.geometry;\n const type = feature.type;\n\n feature.geometry = [];\n\n if (type === 1) {\n for (let j = 0; j < geom.length; j += 2) {\n feature.geometry.push(transformPoint(geom[j], geom[j + 1], extent, z2, tx, ty));\n }\n } else {\n for (let j = 0; j < geom.length; j++) {\n const ring = [];\n for (let k = 0; k < geom[j].length; k += 2) {\n ring.push(transformPoint(geom[j][k], geom[j][k + 1], extent, z2, tx, ty));\n }\n feature.geometry.push(ring);\n }\n }\n }\n\n tile.transformed = true;\n\n return tile;\n}\n\nfunction transformPoint(x, y, extent, z2, tx, ty) {\n return [\n Math.round(extent * (x * z2 - tx)),\n Math.round(extent * (y * z2 - ty))];\n}\n","\nexport default function createTile(features, z, tx, ty, options) {\n const tolerance = z === options.maxZoom ? 0 : options.tolerance / ((1 << z) * options.extent);\n const tile = {\n features: [],\n numPoints: 0,\n numSimplified: 0,\n numFeatures: features.length,\n source: null,\n x: tx,\n y: ty,\n z,\n transformed: false,\n minX: 2,\n minY: 1,\n maxX: -1,\n maxY: 0\n };\n for (const feature of features) {\n addFeature(tile, feature, tolerance, options);\n }\n return tile;\n}\n\nfunction addFeature(tile, feature, tolerance, options) {\n const geom = feature.geometry;\n const type = feature.type;\n const simplified = [];\n\n tile.minX = Math.min(tile.minX, feature.minX);\n tile.minY = Math.min(tile.minY, feature.minY);\n tile.maxX = Math.max(tile.maxX, feature.maxX);\n tile.maxY = Math.max(tile.maxY, feature.maxY);\n\n if (type === 'Point' || type === 'MultiPoint') {\n for (let i = 0; i < geom.length; i += 3) {\n simplified.push(geom[i], geom[i + 1]);\n tile.numPoints++;\n tile.numSimplified++;\n }\n\n } else if (type === 'LineString') {\n addLine(simplified, geom, tile, tolerance, false, false);\n\n } else if (type === 'MultiLineString' || type === 'Polygon') {\n for (let i = 0; i < geom.length; i++) {\n addLine(simplified, geom[i], tile, tolerance, type === 'Polygon', i === 0);\n }\n\n } else if (type === 'MultiPolygon') {\n\n for (let k = 0; k < geom.length; k++) {\n const polygon = geom[k];\n for (let i = 0; i < polygon.length; i++) {\n addLine(simplified, polygon[i], tile, tolerance, true, i === 0);\n }\n }\n }\n\n if (simplified.length) {\n let tags = feature.tags || null;\n\n if (type === 'LineString' && options.lineMetrics) {\n tags = {};\n for (const key in feature.tags) tags[key] = feature.tags[key];\n tags['mapbox_clip_start'] = geom.start / geom.size;\n tags['mapbox_clip_end'] = geom.end / geom.size;\n }\n\n const tileFeature = {\n geometry: simplified,\n type: type === 'Polygon' || type === 'MultiPolygon' ? 3 :\n (type === 'LineString' || type === 'MultiLineString' ? 2 : 1),\n tags\n };\n if (feature.id !== null) {\n tileFeature.id = feature.id;\n }\n tile.features.push(tileFeature);\n }\n}\n\nfunction addLine(result, geom, tile, tolerance, isPolygon, isOuter) {\n const sqTolerance = tolerance * tolerance;\n\n if (tolerance > 0 && (geom.size < (isPolygon ? sqTolerance : tolerance))) {\n tile.numPoints += geom.length / 3;\n return;\n }\n\n const ring = [];\n\n for (let i = 0; i < geom.length; i += 3) {\n if (tolerance === 0 || geom[i + 2] > sqTolerance) {\n tile.numSimplified++;\n ring.push(geom[i], geom[i + 1]);\n }\n tile.numPoints++;\n }\n\n if (isPolygon) rewind(ring, isOuter);\n\n result.push(ring);\n}\n\nfunction rewind(ring, clockwise) {\n let area = 0;\n for (let i = 0, len = ring.length, j = len - 2; i < len; j = i, i += 2) {\n area += (ring[i] - ring[j]) * (ring[i + 1] + ring[j + 1]);\n }\n if (area > 0 === clockwise) {\n for (let i = 0, len = ring.length; i < len / 2; i += 2) {\n const x = ring[i];\n const y = ring[i + 1];\n ring[i] = ring[len - 2 - i];\n ring[i + 1] = ring[len - 1 - i];\n ring[len - 2 - i] = x;\n ring[len - 1 - i] = y;\n }\n }\n}\n","\nimport convert from './convert.js'; // GeoJSON conversion and preprocessing\nimport clip from './clip.js'; // stripe clipping algorithm\nimport wrap from './wrap.js'; // date line processing\nimport transform from './transform.js'; // coordinate transformation\nimport createTile from './tile.js'; // final simplified tile generation\n\nconst defaultOptions = {\n maxZoom: 14, // max zoom to preserve detail on\n indexMaxZoom: 5, // max zoom in the tile index\n indexMaxPoints: 100000, // max number of points per tile in the tile index\n tolerance: 3, // simplification tolerance (higher means simpler)\n extent: 4096, // tile extent\n buffer: 64, // tile buffer on each side\n lineMetrics: false, // whether to calculate line metrics\n promoteId: null, // name of a feature property to be promoted to feature.id\n generateId: false, // whether to generate feature ids. Cannot be used with promoteId\n debug: 0 // logging level (0, 1 or 2)\n};\n\nclass GeoJSONVT {\n constructor(data, options) {\n options = this.options = extend(Object.create(defaultOptions), options);\n\n const debug = options.debug;\n\n if (debug) console.time('preprocess data');\n\n if (options.maxZoom < 0 || options.maxZoom > 24) throw new Error('maxZoom should be in the 0-24 range');\n if (options.promoteId && options.generateId) throw new Error('promoteId and generateId cannot be used together.');\n\n // projects and adds simplification info\n let features = convert(data, options);\n\n // tiles and tileCoords are part of the public API\n this.tiles = {};\n this.tileCoords = [];\n\n if (debug) {\n console.timeEnd('preprocess data');\n console.log('index: maxZoom: %d, maxPoints: %d', options.indexMaxZoom, options.indexMaxPoints);\n console.time('generate tiles');\n this.stats = {};\n this.total = 0;\n }\n\n // wraps features (ie extreme west and extreme east)\n features = wrap(features, options);\n\n // start slicing from the top tile down\n if (features.length) this.splitTile(features, 0, 0, 0);\n\n if (debug) {\n if (features.length) console.log('features: %d, points: %d', this.tiles[0].numFeatures, this.tiles[0].numPoints);\n console.timeEnd('generate tiles');\n console.log('tiles generated:', this.total, JSON.stringify(this.stats));\n }\n }\n\n // splits features from a parent tile to sub-tiles.\n // z, x, and y are the coordinates of the parent tile\n // cz, cx, and cy are the coordinates of the target tile\n //\n // If no target tile is specified, splitting stops when we reach the maximum\n // zoom or the number of points is low as specified in the options.\n splitTile(features, z, x, y, cz, cx, cy) {\n\n const stack = [features, z, x, y];\n const options = this.options;\n const debug = options.debug;\n\n // avoid recursion by using a processing queue\n while (stack.length) {\n y = stack.pop();\n x = stack.pop();\n z = stack.pop();\n features = stack.pop();\n\n const z2 = 1 << z;\n const id = toID(z, x, y);\n let tile = this.tiles[id];\n\n if (!tile) {\n if (debug > 1) console.time('creation');\n\n tile = this.tiles[id] = createTile(features, z, x, y, options);\n this.tileCoords.push({z, x, y});\n\n if (debug) {\n if (debug > 1) {\n console.log('tile z%d-%d-%d (features: %d, points: %d, simplified: %d)',\n z, x, y, tile.numFeatures, tile.numPoints, tile.numSimplified);\n console.timeEnd('creation');\n }\n const key = `z${ z}`;\n this.stats[key] = (this.stats[key] || 0) + 1;\n this.total++;\n }\n }\n\n // save reference to original geometry in tile so that we can drill down later if we stop now\n tile.source = features;\n\n // if it's the first-pass tiling\n if (cz == null) {\n // stop tiling if we reached max zoom, or if the tile is too simple\n if (z === options.indexMaxZoom || tile.numPoints <= options.indexMaxPoints) continue;\n // if a drilldown to a specific tile\n } else if (z === options.maxZoom || z === cz) {\n // stop tiling if we reached base zoom or our target tile zoom\n continue;\n } else if (cz != null) {\n // stop tiling if it's not an ancestor of the target tile\n const zoomSteps = cz - z;\n if (x !== cx >> zoomSteps || y !== cy >> zoomSteps) continue;\n }\n\n // if we slice further down, no need to keep source geometry\n tile.source = null;\n\n if (features.length === 0) continue;\n\n if (debug > 1) console.time('clipping');\n\n // values we'll use for clipping\n const k1 = 0.5 * options.buffer / options.extent;\n const k2 = 0.5 - k1;\n const k3 = 0.5 + k1;\n const k4 = 1 + k1;\n\n let tl = null;\n let bl = null;\n let tr = null;\n let br = null;\n\n let left = clip(features, z2, x - k1, x + k3, 0, tile.minX, tile.maxX, options);\n let right = clip(features, z2, x + k2, x + k4, 0, tile.minX, tile.maxX, options);\n features = null;\n\n if (left) {\n tl = clip(left, z2, y - k1, y + k3, 1, tile.minY, tile.maxY, options);\n bl = clip(left, z2, y + k2, y + k4, 1, tile.minY, tile.maxY, options);\n left = null;\n }\n\n if (right) {\n tr = clip(right, z2, y - k1, y + k3, 1, tile.minY, tile.maxY, options);\n br = clip(right, z2, y + k2, y + k4, 1, tile.minY, tile.maxY, options);\n right = null;\n }\n\n if (debug > 1) console.timeEnd('clipping');\n\n stack.push(tl || [], z + 1, x * 2, y * 2);\n stack.push(bl || [], z + 1, x * 2, y * 2 + 1);\n stack.push(tr || [], z + 1, x * 2 + 1, y * 2);\n stack.push(br || [], z + 1, x * 2 + 1, y * 2 + 1);\n }\n }\n\n getTile(z, x, y) {\n z = +z;\n x = +x;\n y = +y;\n\n const options = this.options;\n const {extent, debug} = options;\n\n if (z < 0 || z > 24) return null;\n\n const z2 = 1 << z;\n x = (x + z2) & (z2 - 1); // wrap tile x coordinate\n\n const id = toID(z, x, y);\n if (this.tiles[id]) return transform(this.tiles[id], extent);\n\n if (debug > 1) console.log('drilling down to z%d-%d-%d', z, x, y);\n\n let z0 = z;\n let x0 = x;\n let y0 = y;\n let parent;\n\n while (!parent && z0 > 0) {\n z0--;\n x0 = x0 >> 1;\n y0 = y0 >> 1;\n parent = this.tiles[toID(z0, x0, y0)];\n }\n\n if (!parent || !parent.source) return null;\n\n // if we found a parent tile containing the original geometry, we can drill down from it\n if (debug > 1) {\n console.log('found parent tile z%d-%d-%d', z0, x0, y0);\n console.time('drilling down');\n }\n this.splitTile(parent.source, z0, x0, y0, z, x, y);\n if (debug > 1) console.timeEnd('drilling down');\n\n return this.tiles[id] ? transform(this.tiles[id], extent) : null;\n }\n}\n\nfunction toID(z, x, y) {\n return (((1 << z) * y + x) * 32) + z;\n}\n\nfunction extend(dest, src) {\n for (const i in src) dest[i] = src[i];\n return dest;\n}\n\nexport default function geojsonvt(data, options) {\n return new GeoJSONVT(data, options);\n}\n","/**\n * A way to identify a feature, either by string or by number\n */\nexport type GeoJSONFeatureId = number | string;\n\n/**\n * The geojson source diff object\n */\nexport type GeoJSONSourceDiff = {\n /**\n * When set to `true` it will remove all features\n */\n removeAll?: boolean;\n /**\n * An array of features IDs to remove\n */\n remove?: Array;\n /**\n * An array of features to add\n */\n add?: Array;\n /**\n * An array of update objects\n */\n update?: Array;\n}\n\n/**\n * A geojson feature diff object\n */\nexport type GeoJSONFeatureDiff = {\n /**\n * The feature ID\n */\n id: GeoJSONFeatureId;\n /**\n * If it's a new geometry, place it here\n */\n newGeometry?: GeoJSON.Geometry;\n /**\n * Setting to `true` will remove all preperties\n */\n removeAllProperties?: boolean;\n /**\n * The properties keys to remove\n */\n removeProperties?: Array;\n /**\n * The properties to add or update along side their values\n */\n addOrUpdateProperties?: Array<{key: string; value: any}>;\n}\n\nexport type UpdateableGeoJSON = GeoJSON.Feature | GeoJSON.FeatureCollection | undefined;\n\nfunction getFeatureId(feature: GeoJSON.Feature, promoteId?: string): GeoJSONFeatureId | undefined {\n return promoteId ? feature.properties[promoteId] : feature.id;\n}\n\nexport function isUpdateableGeoJSON(data: GeoJSON.GeoJSON | undefined, promoteId?: string): data is UpdateableGeoJSON {\n // null can be updated\n if (data == null) {\n return true;\n }\n\n // a single feature with an id can be updated, need to explicitly check against null because 0 is a valid feature id that is falsy\n if (data.type === 'Feature') {\n return getFeatureId(data, promoteId) != null;\n }\n\n // a feature collection can be updated if every feature has an id, and the ids are all unique\n // this prevents us from silently dropping features if ids get reused\n if (data.type === 'FeatureCollection') {\n const seenIds = new Set();\n for (const feature of data.features) {\n const id = getFeatureId(feature, promoteId);\n if (id == null) {\n return false;\n }\n\n if (seenIds.has(id)) {\n return false;\n }\n\n seenIds.add(id);\n }\n\n return true;\n }\n\n return false;\n}\n\nexport function toUpdateable(data: UpdateableGeoJSON, promoteId?: string) {\n const result = new Map();\n if (data == null) {\n // empty result\n } else if (data.type === 'Feature') {\n result.set(getFeatureId(data, promoteId)!, data);\n } else {\n for (const feature of data.features) {\n result.set(getFeatureId(feature, promoteId)!, feature);\n }\n }\n\n return result;\n}\n\n// mutates updateable\nexport function applySourceDiff(updateable: Map, diff: GeoJSONSourceDiff, promoteId?: string): void {\n if (diff.removeAll) {\n updateable.clear();\n }\n\n if (diff.remove) {\n for (const id of diff.remove) {\n updateable.delete(id);\n }\n }\n\n if (diff.add) {\n for (const feature of diff.add) {\n const id = getFeatureId(feature, promoteId);\n\n if (id != null) {\n updateable.set(id, feature);\n }\n }\n }\n\n if (diff.update) {\n for (const update of diff.update) {\n let feature = updateable.get(update.id);\n\n if (feature == null) {\n continue;\n }\n\n // be careful to clone the feature and/or properties objects to avoid mutating our input\n const cloneFeature = update.newGeometry || update.removeAllProperties;\n // note: removeAllProperties gives us a new properties object, so we can skip the clone step\n const cloneProperties = !update.removeAllProperties && (update.removeProperties?.length > 0 || update.addOrUpdateProperties?.length > 0);\n if (cloneFeature || cloneProperties) {\n feature = {...feature};\n updateable.set(update.id, feature);\n if (cloneProperties) {\n feature.properties = {...feature.properties};\n }\n }\n\n if (update.newGeometry) {\n feature.geometry = update.newGeometry;\n }\n\n if (update.removeAllProperties) {\n feature.properties = {};\n } else if (update.removeProperties?.length > 0) {\n for (const prop of update.removeProperties) {\n if (Object.prototype.hasOwnProperty.call(feature.properties, prop)) {\n delete feature.properties[prop];\n }\n }\n }\n\n if (update.addOrUpdateProperties?.length > 0) {\n for (const {key, value} of update.addOrUpdateProperties) {\n feature.properties[key] = value;\n }\n }\n }\n }\n}\n","import {getJSON} from '../util/ajax';\nimport {RequestPerformance} from '../util/performance';\nimport rewind from '@mapbox/geojson-rewind';\nimport {GeoJSONWrapper} from './geojson_wrapper';\nimport vtpbf from 'vt-pbf';\nimport Supercluster, {type Options as SuperclusterOptions, type ClusterProperties} from 'supercluster';\nimport geojsonvt, {type Options as GeoJSONVTOptions} from 'geojson-vt';\nimport {VectorTileWorkerSource} from './vector_tile_worker_source';\nimport {createExpression} from '@maplibre/maplibre-gl-style-spec';\nimport {isAbortError} from '../util/abort_error';\n\nimport type {\n WorkerTileParameters,\n WorkerTileResult,\n} from '../source/worker_source';\n\nimport type {LoadVectorTileResult} from './vector_tile_worker_source';\nimport type {RequestParameters} from '../util/ajax';\nimport {isUpdateableGeoJSON, type GeoJSONSourceDiff, applySourceDiff, toUpdateable, GeoJSONFeatureId} from './geojson_source_diff';\nimport type {ClusterIDAndSource, GeoJSONWorkerSourceLoadDataResult, RemoveSourceParams} from '../util/actor_messages';\n\n/**\n * The geojson worker options that can be passed to the worker\n */\nexport type GeoJSONWorkerOptions = {\n source?: string;\n cluster?: boolean;\n geojsonVtOptions?: GeoJSONVTOptions;\n superclusterOptions?: SuperclusterOptions;\n clusterProperties?: ClusterProperties;\n filter?: Array;\n promoteId?: string;\n collectResourceTiming?: boolean;\n}\n\n/**\n * Parameters needed to load a geojson to the worker\n */\nexport type LoadGeoJSONParameters = GeoJSONWorkerOptions & {\n type: 'geojson';\n request?: RequestParameters;\n /**\n * Literal GeoJSON data. Must be provided if `request.url` is not.\n */\n data?: string;\n dataDiff?: GeoJSONSourceDiff;\n};\n\nexport type LoadGeoJSON = (params: LoadGeoJSONParameters, abortController: AbortController) => Promise;\n\ntype GeoJSONIndex = ReturnType | Supercluster;\n\n/**\n * The {@link WorkerSource} implementation that supports {@link GeoJSONSource}.\n * This class is designed to be easily reused to support custom source types\n * for data formats that can be parsed/converted into an in-memory GeoJSON\n * representation. To do so, create it with\n * `new GeoJSONWorkerSource(actor, layerIndex, customLoadGeoJSONFunction)`.\n * For a full example, see [mapbox-gl-topojson](https://github.com/developmentseed/mapbox-gl-topojson).\n */\nexport class GeoJSONWorkerSource extends VectorTileWorkerSource {\n /**\n * The actual GeoJSON takes some time to load (as there may be a need to parse a diff, or to apply filters, or the\n * data may even need to be loaded via a URL). This promise resolves with a ready-to-be-consumed GeoJSON which is\n * ready to be returned by the `getData` method.\n */\n _pendingData: Promise;\n _pendingRequest: AbortController;\n _geoJSONIndex: GeoJSONIndex;\n _dataUpdateable = new Map();\n\n override async loadVectorTile(params: WorkerTileParameters, _abortController: AbortController): Promise {\n const canonical = params.tileID.canonical;\n\n if (!this._geoJSONIndex) {\n throw new Error('Unable to parse the data into a cluster or geojson');\n }\n\n const geoJSONTile = this._geoJSONIndex.getTile(canonical.z, canonical.x, canonical.y);\n if (!geoJSONTile) {\n return null;\n }\n\n const geojsonWrapper = new GeoJSONWrapper(geoJSONTile.features);\n // Encode the geojson-vt tile into binary vector tile form. This\n // is a convenience that allows `FeatureIndex` to operate the same way\n // across `VectorTileSource` and `GeoJSONSource` data.\n let pbf = vtpbf(geojsonWrapper);\n if (pbf.byteOffset !== 0 || pbf.byteLength !== pbf.buffer.byteLength) {\n // Compatibility with node Buffer (https://github.com/mapbox/pbf/issues/35)\n pbf = new Uint8Array(pbf);\n }\n\n return {\n vectorTile: geojsonWrapper,\n rawData: pbf.buffer\n };\n }\n\n /**\n * Fetches (if appropriate), parses, and index geojson data into tiles. This\n * preparatory method must be called before {@link GeoJSONWorkerSource#loadTile}\n * can correctly serve up tiles.\n *\n * Defers to {@link GeoJSONWorkerSource#loadAndProcessGeoJSON} for the pre-processing.\n *\n * When a `loadData` request comes in while a previous one is being processed,\n * the previous one is aborted.\n *\n * @param params - the parameters\n * @returns a promise that resolves when the data is loaded and parsed into a GeoJSON object\n */\n async loadData(params: LoadGeoJSONParameters): Promise {\n this._pendingRequest?.abort();\n const perf = (params && params.request && params.request.collectResourceTiming) ?\n new RequestPerformance(params.request) : false;\n\n this._pendingRequest = new AbortController();\n try {\n this._pendingData = this.loadAndProcessGeoJSON(params, this._pendingRequest);\n\n this._geoJSONIndex = params.cluster ?\n new Supercluster(getSuperclusterOptions(params)).load((await this._pendingData as any).features) :\n geojsonvt(await this._pendingData, params.geojsonVtOptions);\n\n this.loaded = {};\n\n const result = {} as GeoJSONWorkerSourceLoadDataResult;\n if (perf) {\n const resourceTimingData = perf.finish();\n // it's necessary to eval the result of getEntriesByName() here via parse/stringify\n // late evaluation in the main thread causes TypeError: illegal invocation\n if (resourceTimingData) {\n result.resourceTiming = {};\n result.resourceTiming[params.source] = JSON.parse(JSON.stringify(resourceTimingData));\n }\n }\n return result;\n } catch (err) {\n delete this._pendingRequest;\n if (isAbortError(err)) {\n return {abandoned: true};\n }\n throw err;\n }\n }\n\n /**\n * Allows to get the source's actual GeoJSON.\n *\n * @returns a promise which is resolved with the source's actual GeoJSON\n */\n async getData(): Promise {\n return this._pendingData;\n }\n\n /**\n * Implements {@link WorkerSource#reloadTile}.\n *\n * If the tile is loaded, uses the implementation in VectorTileWorkerSource.\n * Otherwise, such as after a setData() call, we load the tile fresh.\n *\n * @param params - the parameters\n * @returns A promise that resolves when the tile is reloaded\n */\n reloadTile(params: WorkerTileParameters): Promise {\n const loaded = this.loaded,\n uid = params.uid;\n\n if (loaded && loaded[uid]) {\n return super.reloadTile(params);\n } else {\n return this.loadTile(params);\n }\n }\n\n /**\n * Fetch, parse and process GeoJSON according to the given params.\n *\n * Defers to {@link GeoJSONWorkerSource#loadGeoJSON} for the fetching and parsing.\n *\n * @param params - the parameters\n * @param abortController - the abort controller that allows aborting this operation\n * @returns a promise that is resolved with the processes GeoJSON\n */\n async loadAndProcessGeoJSON(params: LoadGeoJSONParameters, abortController: AbortController): Promise {\n let data = await this.loadGeoJSON(params, abortController);\n\n delete this._pendingRequest;\n if (typeof data !== 'object') {\n throw new Error(`Input data given to '${params.source}' is not a valid GeoJSON object.`);\n }\n rewind(data, true);\n\n if (params.filter) {\n const compiled = createExpression(params.filter, {type: 'boolean', 'property-type': 'data-driven', overridable: false, transition: false} as any);\n if (compiled.result === 'error')\n throw new Error(compiled.value.map(err => `${err.key}: ${err.message}`).join(', '));\n\n const features = (data as any).features.filter(feature => compiled.value.evaluate({zoom: 0}, feature));\n data = {type: 'FeatureCollection', features};\n }\n\n return data;\n }\n\n /**\n * Fetch and parse GeoJSON according to the given params.\n *\n * GeoJSON is loaded and parsed from `params.url` if it exists, or else\n * expected as a literal (string or object) `params.data`.\n *\n * @param params - the parameters\n * @param abortController - the abort controller that allows aborting this operation\n * @returns a promise that resolves when the data is loaded\n */\n async loadGeoJSON(params: LoadGeoJSONParameters, abortController: AbortController): Promise {\n const {promoteId} = params;\n if (params.request) {\n const response = await getJSON(params.request, abortController);\n this._dataUpdateable = isUpdateableGeoJSON(response.data, promoteId) ? toUpdateable(response.data, promoteId) : undefined;\n return response.data;\n }\n if (typeof params.data === 'string') {\n try {\n const parsed = JSON.parse(params.data);\n this._dataUpdateable = isUpdateableGeoJSON(parsed, promoteId) ? toUpdateable(parsed, promoteId) : undefined;\n return parsed;\n } catch (e) {\n throw new Error(`Input data given to '${params.source}' is not a valid GeoJSON object.`);\n }\n }\n if (!params.dataDiff) {\n throw new Error(`Input data given to '${params.source}' is not a valid GeoJSON object.`);\n }\n if (!this._dataUpdateable) {\n throw new Error(`Cannot update existing geojson data in ${params.source}`);\n }\n applySourceDiff(this._dataUpdateable, params.dataDiff, promoteId);\n return {type: 'FeatureCollection', features: Array.from(this._dataUpdateable.values())};\n }\n\n async removeSource(_params: RemoveSourceParams): Promise {\n if (this._pendingRequest) {\n this._pendingRequest.abort();\n }\n }\n\n getClusterExpansionZoom(params: ClusterIDAndSource): number {\n return (this._geoJSONIndex as Supercluster).getClusterExpansionZoom(params.clusterId);\n }\n\n getClusterChildren(params: ClusterIDAndSource): Array {\n return (this._geoJSONIndex as Supercluster).getChildren(params.clusterId);\n }\n\n getClusterLeaves(params: {\n clusterId: number;\n limit: number;\n offset: number;\n }): Array {\n return (this._geoJSONIndex as Supercluster).getLeaves(params.clusterId, params.limit, params.offset);\n }\n}\n\nfunction getSuperclusterOptions({superclusterOptions, clusterProperties}: LoadGeoJSONParameters) {\n if (!clusterProperties || !superclusterOptions) return superclusterOptions;\n\n const mapExpressions = {};\n const reduceExpressions = {};\n const globals = {accumulated: null, zoom: 0};\n const feature = {properties: null};\n const propertyNames = Object.keys(clusterProperties);\n\n for (const key of propertyNames) {\n const [operator, mapExpression] = clusterProperties[key];\n\n const mapExpressionParsed = createExpression(mapExpression);\n const reduceExpressionParsed = createExpression(\n typeof operator === 'string' ? [operator, ['accumulated'], ['get', key]] : operator);\n\n mapExpressions[key] = mapExpressionParsed.value;\n reduceExpressions[key] = reduceExpressionParsed.value;\n }\n\n superclusterOptions.map = (pointProperties) => {\n feature.properties = pointProperties;\n const properties = {};\n for (const key of propertyNames) {\n properties[key] = mapExpressions[key].evaluate(globals, feature);\n }\n return properties;\n };\n superclusterOptions.reduce = (accumulated, clusterProperties) => {\n feature.properties = clusterProperties;\n for (const key of propertyNames) {\n globals.accumulated = accumulated[key];\n accumulated[key] = reduceExpressions[key].evaluate(globals, feature);\n }\n };\n\n return superclusterOptions;\n}\n","import {Actor, ActorTarget, IActor} from '../util/actor';\nimport {StyleLayerIndex} from '../style/style_layer_index';\nimport {VectorTileWorkerSource} from './vector_tile_worker_source';\nimport {RasterDEMTileWorkerSource} from './raster_dem_tile_worker_source';\nimport {rtlWorkerPlugin, RTLTextPlugin} from './rtl_text_plugin_worker';\nimport {GeoJSONWorkerSource, LoadGeoJSONParameters} from './geojson_worker_source';\nimport {isWorker} from '../util/util';\nimport {addProtocol, removeProtocol} from './protocol_crud';\nimport {PluginState} from './rtl_text_plugin_status';\nimport type {\n WorkerSource,\n WorkerSourceConstructor,\n WorkerTileParameters,\n WorkerDEMTileParameters,\n TileParameters\n} from '../source/worker_source';\n\nimport type {WorkerGlobalScopeInterface} from '../util/web_worker';\nimport type {LayerSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport {\n MessageType,\n type ClusterIDAndSource,\n type GetClusterLeavesParams,\n type RemoveSourceParams,\n type UpdateLayersParamaeters\n} from '../util/actor_messages';\n\n/**\n * The Worker class responsible for background thread related execution\n */\nexport default class Worker {\n self: WorkerGlobalScopeInterface & ActorTarget;\n actor: Actor;\n layerIndexes: {[_: string]: StyleLayerIndex};\n availableImages: {[_: string]: Array};\n externalWorkerSourceTypes: { [_: string]: WorkerSourceConstructor };\n /**\n * This holds a cache for the already created worker source instances.\n * The cache is build with the following hierarchy:\n * [mapId][sourceType][sourceName]: worker source instance\n * sourceType can be 'vector' for example\n */\n workerSources: {\n [_: string]: {\n [_: string]: {\n [_: string]: WorkerSource;\n };\n };\n };\n /**\n * This holds a cache for the already created DEM worker source instances.\n * The cache is build with the following hierarchy:\n * [mapId][sourceType]: DEM worker source instance\n * sourceType can be 'raster-dem' for example\n */\n demWorkerSources: {\n [_: string]: {\n [_: string]: RasterDEMTileWorkerSource;\n };\n };\n referrer: string;\n\n constructor(self: WorkerGlobalScopeInterface & ActorTarget) {\n this.self = self;\n this.actor = new Actor(self);\n\n this.layerIndexes = {};\n this.availableImages = {};\n\n this.workerSources = {};\n this.demWorkerSources = {};\n this.externalWorkerSourceTypes = {};\n\n this.self.registerWorkerSource = (name: string, WorkerSource: WorkerSourceConstructor) => {\n if (this.externalWorkerSourceTypes[name]) {\n throw new Error(`Worker source with name \"${name}\" already registered.`);\n }\n this.externalWorkerSourceTypes[name] = WorkerSource;\n };\n\n this.self.addProtocol = addProtocol;\n this.self.removeProtocol = removeProtocol;\n\n // This is invoked by the RTL text plugin when the download via the `importScripts` call has finished, and the code has been parsed.\n this.self.registerRTLTextPlugin = (rtlTextPlugin: RTLTextPlugin) => {\n if (rtlWorkerPlugin.isParsed()) {\n throw new Error('RTL text plugin already registered.');\n }\n rtlWorkerPlugin.setMethods(rtlTextPlugin);\n };\n\n this.actor.registerMessageHandler(MessageType.loadDEMTile, (mapId: string, params: WorkerDEMTileParameters) => {\n return this._getDEMWorkerSource(mapId, params.source).loadTile(params);\n });\n\n this.actor.registerMessageHandler(MessageType.removeDEMTile, async (mapId: string, params: TileParameters) => {\n this._getDEMWorkerSource(mapId, params.source).removeTile(params);\n });\n\n this.actor.registerMessageHandler(MessageType.getClusterExpansionZoom, async (mapId: string, params: ClusterIDAndSource) => {\n return (this._getWorkerSource(mapId, params.type, params.source) as GeoJSONWorkerSource).getClusterExpansionZoom(params);\n });\n\n this.actor.registerMessageHandler(MessageType.getClusterChildren, async (mapId: string, params: ClusterIDAndSource) => {\n return (this._getWorkerSource(mapId, params.type, params.source) as GeoJSONWorkerSource).getClusterChildren(params);\n });\n\n this.actor.registerMessageHandler(MessageType.getClusterLeaves, async (mapId: string, params: GetClusterLeavesParams) => {\n return (this._getWorkerSource(mapId, params.type, params.source) as GeoJSONWorkerSource).getClusterLeaves(params);\n });\n\n this.actor.registerMessageHandler(MessageType.loadData, (mapId: string, params: LoadGeoJSONParameters) => {\n return (this._getWorkerSource(mapId, params.type, params.source) as GeoJSONWorkerSource).loadData(params);\n });\n\n this.actor.registerMessageHandler(MessageType.getData, (mapId: string, params: LoadGeoJSONParameters) => {\n return (this._getWorkerSource(mapId, params.type, params.source) as GeoJSONWorkerSource).getData();\n });\n\n this.actor.registerMessageHandler(MessageType.loadTile, (mapId: string, params: WorkerTileParameters) => {\n return this._getWorkerSource(mapId, params.type, params.source).loadTile(params);\n });\n\n this.actor.registerMessageHandler(MessageType.reloadTile, (mapId: string, params: WorkerTileParameters) => {\n return this._getWorkerSource(mapId, params.type, params.source).reloadTile(params);\n });\n\n this.actor.registerMessageHandler(MessageType.abortTile, (mapId: string, params: TileParameters) => {\n return this._getWorkerSource(mapId, params.type, params.source).abortTile(params);\n });\n\n this.actor.registerMessageHandler(MessageType.removeTile, (mapId: string, params: TileParameters) => {\n return this._getWorkerSource(mapId, params.type, params.source).removeTile(params);\n });\n\n this.actor.registerMessageHandler(MessageType.removeSource, async (mapId: string, params: RemoveSourceParams) => {\n if (!this.workerSources[mapId] ||\n !this.workerSources[mapId][params.type] ||\n !this.workerSources[mapId][params.type][params.source]) {\n return;\n }\n\n const worker = this.workerSources[mapId][params.type][params.source];\n delete this.workerSources[mapId][params.type][params.source];\n\n if (worker.removeSource !== undefined) {\n worker.removeSource(params);\n }\n });\n\n this.actor.registerMessageHandler(MessageType.removeMap, async (mapId: string) => {\n delete this.layerIndexes[mapId];\n delete this.availableImages[mapId];\n delete this.workerSources[mapId];\n delete this.demWorkerSources[mapId];\n });\n\n this.actor.registerMessageHandler(MessageType.setReferrer, async (_mapId: string, params: string) => {\n this.referrer = params;\n });\n\n this.actor.registerMessageHandler(MessageType.syncRTLPluginState, (mapId: string, params: PluginState) => {\n return this._syncRTLPluginState(mapId, params);\n });\n\n this.actor.registerMessageHandler(MessageType.importScript, async (_mapId: string, params: string) => {\n this.self.importScripts(params);\n });\n\n this.actor.registerMessageHandler(MessageType.setImages, (mapId: string, params: string[]) => {\n return this._setImages(mapId, params);\n });\n\n this.actor.registerMessageHandler(MessageType.updateLayers, async (mapId: string, params: UpdateLayersParamaeters) => {\n this._getLayerIndex(mapId).update(params.layers, params.removedIds);\n });\n\n this.actor.registerMessageHandler(MessageType.setLayers, async (mapId: string, params: Array) => {\n this._getLayerIndex(mapId).replace(params);\n });\n }\n\n private async _setImages(mapId: string, images: Array): Promise {\n this.availableImages[mapId] = images;\n for (const workerSource in this.workerSources[mapId]) {\n const ws = this.workerSources[mapId][workerSource];\n for (const source in ws) {\n ws[source].availableImages = images;\n }\n }\n }\n\n private async _syncRTLPluginState(mapId: string, incomingState: PluginState): Promise {\n\n // Parsed plugin cannot be changed, so just return its current state.\n if (rtlWorkerPlugin.isParsed()) {\n return rtlWorkerPlugin.getState();\n }\n\n if (incomingState.pluginStatus !== 'loading') {\n // simply sync and done\n rtlWorkerPlugin.setState(incomingState);\n return incomingState;\n }\n const urlToLoad = incomingState.pluginURL;\n this.self.importScripts(urlToLoad);\n const complete = rtlWorkerPlugin.isParsed();\n if (complete) {\n const loadedState: PluginState = {\n pluginStatus: 'loaded',\n pluginURL: urlToLoad\n };\n rtlWorkerPlugin.setState(loadedState);\n return loadedState;\n }\n\n // error case\n rtlWorkerPlugin.setState({\n pluginStatus: 'error',\n pluginURL: ''\n });\n throw new Error(`RTL Text Plugin failed to import scripts from ${urlToLoad}`);\n }\n\n private _getAvailableImages(mapId: string) {\n let availableImages = this.availableImages[mapId];\n\n if (!availableImages) {\n availableImages = [];\n }\n\n return availableImages;\n }\n\n private _getLayerIndex(mapId: string) {\n let layerIndexes = this.layerIndexes[mapId];\n if (!layerIndexes) {\n layerIndexes = this.layerIndexes[mapId] = new StyleLayerIndex();\n }\n return layerIndexes;\n }\n\n /**\n * This is basically a lazy initialization of a worker per mapId and sourceType and sourceName\n * @param mapId - the mapId\n * @param sourceType - the source type - 'vector' for example\n * @param sourceName - the source name - 'osm' for example\n * @returns a new instance or a cached one\n */\n private _getWorkerSource(mapId: string, sourceType: string, sourceName: string): WorkerSource {\n if (!this.workerSources[mapId])\n this.workerSources[mapId] = {};\n if (!this.workerSources[mapId][sourceType])\n this.workerSources[mapId][sourceType] = {};\n\n if (!this.workerSources[mapId][sourceType][sourceName]) {\n // use a wrapped actor so that we can attach a target mapId param\n // to any messages invoked by the WorkerSource, this is very important when there are multiple maps\n const actor: IActor = {\n sendAsync: (message, abortController) => {\n message.targetMapId = mapId;\n return this.actor.sendAsync(message, abortController);\n }\n };\n switch (sourceType) {\n case 'vector':\n this.workerSources[mapId][sourceType][sourceName] = new VectorTileWorkerSource(actor, this._getLayerIndex(mapId), this._getAvailableImages(mapId));\n break;\n case 'geojson':\n this.workerSources[mapId][sourceType][sourceName] = new GeoJSONWorkerSource(actor, this._getLayerIndex(mapId), this._getAvailableImages(mapId));\n break;\n default:\n this.workerSources[mapId][sourceType][sourceName] = new (this.externalWorkerSourceTypes[sourceType])(actor, this._getLayerIndex(mapId), this._getAvailableImages(mapId));\n break;\n }\n }\n\n return this.workerSources[mapId][sourceType][sourceName];\n }\n\n /**\n * This is basically a lazy initialization of a worker per mapId and source\n * @param mapId - the mapId\n * @param sourceType - the source type - 'raster-dem' for example\n * @returns a new instance or a cached one\n */\n private _getDEMWorkerSource(mapId: string, sourceType: string) {\n if (!this.demWorkerSources[mapId])\n this.demWorkerSources[mapId] = {};\n\n if (!this.demWorkerSources[mapId][sourceType]) {\n this.demWorkerSources[mapId][sourceType] = new RasterDEMTileWorkerSource();\n }\n\n return this.demWorkerSources[mapId][sourceType];\n }\n}\n\nif (isWorker(self)) {\n self.worker = new Worker(self);\n}\n","import {createAbortError} from './abort_error';\n\nconst now = typeof performance !== 'undefined' && performance && performance.now ?\n performance.now.bind(performance) :\n Date.now.bind(Date);\n\nlet linkEl;\n\nlet reducedMotionQuery: MediaQueryList;\n\n/** */\nexport const browser = {\n /**\n * Provides a function that outputs milliseconds: either performance.now()\n * or a fallback to Date.now()\n */\n now,\n\n frameAsync(abortController: AbortController): Promise {\n return new Promise((resolve, reject) => {\n const frame = requestAnimationFrame(resolve);\n abortController.signal.addEventListener('abort', () => {\n cancelAnimationFrame(frame);\n reject(createAbortError());\n });\n });\n },\n\n getImageData(img: HTMLImageElement | ImageBitmap, padding: number = 0): ImageData {\n const context = this.getImageCanvasContext(img);\n return context.getImageData(-padding, -padding, img.width as number + 2 * padding, img.height as number + 2 * padding);\n },\n\n getImageCanvasContext(img: HTMLImageElement | ImageBitmap): CanvasRenderingContext2D {\n const canvas = window.document.createElement('canvas') as HTMLCanvasElement;\n const context = canvas.getContext('2d', {willReadFrequently: true});\n if (!context) {\n throw new Error('failed to create canvas 2d context');\n }\n canvas.width = img.width as number;\n canvas.height = img.height as number;\n context.drawImage(img, 0, 0, img.width as number, img.height as number);\n return context;\n },\n\n resolveURL(path: string) {\n if (!linkEl) linkEl = document.createElement('a');\n linkEl.href = path;\n return linkEl.href;\n },\n\n hardwareConcurrency: typeof navigator !== 'undefined' && navigator.hardwareConcurrency || 4,\n\n get prefersReducedMotion(): boolean {\n // In case your test crashes when checking matchMedia, call setMatchMedia from 'src/util/test/util'\n if (!matchMedia) return false;\n //Lazily initialize media query\n if (reducedMotionQuery == null) {\n reducedMotionQuery = matchMedia('(prefers-reduced-motion: reduce)');\n }\n return reducedMotionQuery.matches;\n },\n};\n","import Point from '@mapbox/point-geometry';\n\ntype ScaleReturnValue = {\n x: number;\n y: number;\n boundingClientRect: DOMRect;\n};\n\nexport class DOM {\n private static readonly docStyle = typeof window !== 'undefined' && window.document && window.document.documentElement.style;\n\n private static userSelect: string;\n\n private static selectProp = DOM.testProp(['userSelect', 'MozUserSelect', 'WebkitUserSelect', 'msUserSelect']);\n\n private static transformProp = DOM.testProp(['transform', 'WebkitTransform']);\n\n private static testProp(props: string[]): string {\n if (!DOM.docStyle) return props[0];\n for (let i = 0; i < props.length; i++) {\n if (props[i] in DOM.docStyle) {\n return props[i];\n }\n }\n return props[0];\n }\n\n public static create(tagName: K, className?: string, container?: HTMLElement): HTMLElementTagNameMap[K] {\n const el = window.document.createElement(tagName);\n if (className !== undefined) el.className = className;\n if (container) container.appendChild(el);\n return el;\n }\n\n public static createNS(namespaceURI: string, tagName: string) {\n const el = window.document.createElementNS(namespaceURI, tagName);\n return el;\n }\n\n public static disableDrag() {\n if (DOM.docStyle && DOM.selectProp) {\n DOM.userSelect = DOM.docStyle[DOM.selectProp];\n DOM.docStyle[DOM.selectProp] = 'none';\n }\n }\n\n public static enableDrag() {\n if (DOM.docStyle && DOM.selectProp) {\n DOM.docStyle[DOM.selectProp] = DOM.userSelect;\n }\n }\n\n public static setTransform(el: HTMLElement, value: string) {\n el.style[DOM.transformProp] = value;\n }\n\n public static addEventListener(target: HTMLElement | Window | Document, type: string, callback: EventListenerOrEventListenerObject, options: {\n passive?: boolean;\n capture?: boolean;\n } = {}) {\n if ('passive' in options) {\n target.addEventListener(type, callback, options);\n } else {\n target.addEventListener(type, callback, options.capture);\n }\n }\n\n public static removeEventListener(target: HTMLElement | Window | Document, type: string, callback: EventListenerOrEventListenerObject, options: {\n passive?: boolean;\n capture?: boolean;\n } = {}) {\n if ('passive' in options) {\n target.removeEventListener(type, callback, options);\n } else {\n target.removeEventListener(type, callback, options.capture);\n }\n }\n\n // Suppress the next click, but only if it's immediate.\n private static suppressClickInternal(e) {\n e.preventDefault();\n e.stopPropagation();\n window.removeEventListener('click', DOM.suppressClickInternal, true);\n }\n\n public static suppressClick() {\n window.addEventListener('click', DOM.suppressClickInternal, true);\n window.setTimeout(() => {\n window.removeEventListener('click', DOM.suppressClickInternal, true);\n }, 0);\n }\n\n private static getScale(element: HTMLElement): ScaleReturnValue {\n const rect = element.getBoundingClientRect();\n return {\n x: (rect.width / element.offsetWidth) || 1,\n y: (rect.height / element.offsetHeight) || 1,\n boundingClientRect: rect,\n };\n }\n\n private static getPoint(el: HTMLElement, scale: ScaleReturnValue, e: MouseEvent | Touch): Point {\n const rect = scale.boundingClientRect;\n return new Point(\n // rect.left/top values are in page scale (like clientX/Y),\n // whereas clientLeft/Top (border width) values are the original values (before CSS scale applies).\n ((e.clientX - rect.left) / scale.x) - el.clientLeft,\n ((e.clientY - rect.top) / scale.y) - el.clientTop\n );\n }\n\n public static mousePos(el: HTMLElement, e: MouseEvent | Touch): Point {\n const scale = DOM.getScale(el);\n return DOM.getPoint(el, scale, e);\n }\n\n public static touchPos(el: HTMLElement, touches: TouchList) {\n const points: Point[] = [];\n const scale = DOM.getScale(el);\n for (let i = 0; i < touches.length; i++) {\n points.push(DOM.getPoint(el, scale, touches[i]));\n }\n return points;\n }\n\n public static mouseButton(e: MouseEvent) {\n return e.button;\n }\n\n public static remove(node: HTMLElement) {\n if (node.parentNode) {\n node.parentNode.removeChild(node);\n }\n }\n}\n","export const webpSupported = {\n supported: false,\n testSupport\n};\n\nlet glForTesting: WebGLRenderingContext|WebGL2RenderingContext;\nlet webpCheckComplete = false;\nlet webpImgTest;\nlet webpImgTestOnloadComplete = false;\n\nif (typeof document !== 'undefined') {\n webpImgTest = document.createElement('img');\n webpImgTest.onload = () => {\n if (glForTesting) testWebpTextureUpload(glForTesting);\n glForTesting = null;\n webpImgTestOnloadComplete = true;\n };\n webpImgTest.onerror = () => {\n webpCheckComplete = true;\n glForTesting = null;\n };\n webpImgTest.src = 'data:image/webp;base64,UklGRh4AAABXRUJQVlA4TBEAAAAvAQAAAAfQ//73v/+BiOh/AAA=';\n}\n\nfunction testSupport(gl: WebGLRenderingContext | WebGL2RenderingContext) {\n if (webpCheckComplete || !webpImgTest) return;\n\n // HTMLImageElement.complete is set when an image is done loading it's source\n // regardless of whether the load was successful or not.\n // It's possible for an error to set HTMLImageElement.complete to true which would trigger\n // testWebpTextureUpload and mistakenly set exported.supported to true in browsers which don't support webp\n // To avoid this, we set a flag in the image's onload handler and only call testWebpTextureUpload\n // after a successful image load event.\n if (webpImgTestOnloadComplete) {\n testWebpTextureUpload(gl);\n } else {\n glForTesting = gl;\n\n }\n}\n\nfunction testWebpTextureUpload(gl: WebGLRenderingContext|WebGL2RenderingContext) {\n // Edge 18 supports WebP but not uploading a WebP image to a gl texture\n // Test support for this before allowing WebP images.\n // https://github.com/mapbox/mapbox-gl-js/issues/7671\n const texture = gl.createTexture();\n gl.bindTexture(gl.TEXTURE_2D, texture);\n\n try {\n gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, webpImgTest);\n\n // The error does not get triggered in Edge if the context is lost\n if (gl.isContextLost()) return;\n\n webpSupported.supported = true;\n } catch (e) {\n // Catch \"Unspecified Error.\" in Edge 18.\n }\n\n gl.deleteTexture(texture);\n\n webpCheckComplete = true;\n}\n","import {RequestParameters, makeRequest, sameOrigin, GetResourceResponse} from './ajax';\nimport {arrayBufferToImageBitmap, arrayBufferToImage, extend, isWorker, isImageBitmap} from './util';\nimport {webpSupported} from './webp_supported';\nimport {config} from './config';\nimport {createAbortError} from './abort_error';\nimport {getProtocol} from '../source/protocol_crud';\n\ntype ImageQueueThrottleControlCallback = () => boolean;\n\nexport type ImageRequestQueueItem = {\n requestParameters: RequestParameters;\n supportImageRefresh: boolean;\n state: 'queued' | 'running' | 'completed';\n abortController: AbortController;\n onError: (error: Error) => void;\n onSuccess: (response: GetResourceResponse) => void;\n}\n\ntype ImageQueueThrottleCallbackDictionary = {\n [Key: number]: ImageQueueThrottleControlCallback;\n}\n\ntype HTMLImageElementWithPriority = HTMLImageElement &\n{\n // fetchPriority is experimental property supported on Chromium browsers from Version 102\n // By default images are downloaded with priority low, whereas fetch request downloads with priority high\n // https://developer.mozilla.org/en-US/docs/Web/API/HTMLImageElement/fetchPriority\n fetchPriority?: 'auto' | 'high' | 'low';\n};\n\n/**\n * By default, the image queue is self driven, meaning as soon as one requested item is processed,\n * it will move on to next one as quickly as it can while limiting\n * the number of concurrent requests to MAX_PARALLEL_IMAGE_REQUESTS. The default behavior\n * ensures that static views of the map can be rendered with minimal delay.\n *\n * However, the default behavior can prevent dynamic views of the map from rendering\n * smoothly in that many requests can finish in one render frame, putting too much pressure on GPU.\n *\n * When the view of the map is moving dynamically, smoother frame rates can be achieved\n * by throttling the number of items processed by the queue per frame. This can be\n * accomplished by using {@link addThrottleControl} to allow the caller to\n * use a lambda function to determine when the queue should be throttled (e.g. when isMoving())\n * and manually calling {@link processQueue} in the render loop.\n */\nexport namespace ImageRequest {\n let imageRequestQueue : ImageRequestQueueItem[];\n let currentParallelImageRequests:number;\n\n let throttleControlCallbackHandleCounter: number;\n let throttleControlCallbacks: ImageQueueThrottleCallbackDictionary;\n\n /**\n * Reset the image request queue, removing all pending requests.\n */\n export const resetRequestQueue = (): void => {\n imageRequestQueue = [];\n currentParallelImageRequests = 0;\n throttleControlCallbackHandleCounter = 0;\n throttleControlCallbacks = {};\n };\n\n /**\n * Install a callback to control when image queue throttling is desired.\n * (e.g. when the map view is moving)\n * @param callback - The callback function to install\n * @returns handle that identifies the installed callback.\n */\n export const addThrottleControl = (callback: ImageQueueThrottleControlCallback): number => {\n const handle = throttleControlCallbackHandleCounter++;\n throttleControlCallbacks[handle] = callback;\n return handle;\n };\n\n /**\n * Remove a previously installed callback by passing in the handle returned\n * by {@link addThrottleControl}.\n * @param callbackHandle - The handle for the callback to remove.\n */\n export const removeThrottleControl = (callbackHandle: number): void => {\n delete throttleControlCallbacks[callbackHandle];\n // Try updating the queue\n processQueue();\n };\n\n /**\n * Check to see if any of the installed callbacks are requesting the queue\n * to be throttled.\n * @returns `true` if any callback is causing the queue to be throttled.\n */\n const isThrottled = (): boolean => {\n for (const key of Object.keys(throttleControlCallbacks)) {\n if (throttleControlCallbacks[key]()) {\n return true;\n }\n }\n return false;\n };\n\n /**\n * Request to load an image.\n * @param requestParameters - Request parameters.\n * @param abortController - allows to abort the request.\n * @param supportImageRefresh - `true`, if the image request need to support refresh based on cache headers.\n * @returns - A promise resolved when the image is loaded.\n */\n export const getImage = (requestParameters: RequestParameters, abortController: AbortController, supportImageRefresh: boolean = true): Promise> => {\n return new Promise>((resolve, reject) => {\n if (webpSupported.supported) {\n if (!requestParameters.headers) {\n requestParameters.headers = {};\n }\n requestParameters.headers.accept = 'image/webp,*/*';\n }\n extend(requestParameters, {type: 'image'});\n const request: ImageRequestQueueItem = {\n abortController,\n requestParameters,\n supportImageRefresh,\n state: 'queued',\n onError: (error: Error) => {\n reject(error);\n },\n onSuccess: (response) => {\n resolve(response);\n }\n };\n\n imageRequestQueue.push(request);\n processQueue();\n });\n };\n\n const arrayBufferToCanvasImageSource = (data: ArrayBuffer): Promise => {\n const imageBitmapSupported = typeof createImageBitmap === 'function';\n if (imageBitmapSupported) {\n return arrayBufferToImageBitmap(data);\n } else {\n return arrayBufferToImage(data);\n }\n };\n\n const doImageRequest = async (itemInQueue: ImageRequestQueueItem) => {\n itemInQueue.state = 'running';\n const {requestParameters, supportImageRefresh, onError, onSuccess, abortController} = itemInQueue;\n // - If refreshExpiredTiles is false, then we can use HTMLImageElement to download raster images.\n // - Fetch/XHR (via MakeRequest API) will be used to download images for following scenarios:\n // 1. Style image sprite will had a issue with HTMLImageElement as described\n // here: https://github.com/mapbox/mapbox-gl-js/issues/1470\n // 2. If refreshExpiredTiles is true (default), then in order to read the image cache header,\n // fetch/XHR request will be required\n // - For any special case handling like use of AddProtocol, worker initiated request or additional headers\n // let makeRequest handle it.\n // - HtmlImageElement request automatically adds accept header for all the browser supported images\n const canUseHTMLImageElement = supportImageRefresh === false &&\n !isWorker(self) &&\n !getProtocol(requestParameters.url) &&\n (!requestParameters.headers ||\n Object.keys(requestParameters.headers).reduce((acc, item) => acc && item === 'accept', true));\n\n currentParallelImageRequests++;\n\n const getImagePromise = canUseHTMLImageElement ?\n getImageUsingHtmlImage(requestParameters, abortController) :\n makeRequest(requestParameters, abortController);\n\n try {\n const response = await getImagePromise;\n delete itemInQueue.abortController;\n itemInQueue.state = 'completed';\n if (response.data instanceof HTMLImageElement || isImageBitmap(response.data)) {\n // User using addProtocol can directly return HTMLImageElement/ImageBitmap type\n // If HtmlImageElement is used to get image then response type will be HTMLImageElement\n onSuccess(response as GetResourceResponse);\n } else if (response.data) {\n const img = await arrayBufferToCanvasImageSource(response.data);\n onSuccess({data: img, cacheControl: response.cacheControl, expires: response.expires});\n }\n } catch (err) {\n delete itemInQueue.abortController;\n onError(err);\n } finally {\n currentParallelImageRequests--;\n processQueue();\n }\n };\n\n /**\n * Process some number of items in the image request queue.\n */\n const processQueue = (): void => {\n\n const maxImageRequests = isThrottled() ?\n config.MAX_PARALLEL_IMAGE_REQUESTS_PER_FRAME :\n config.MAX_PARALLEL_IMAGE_REQUESTS;\n\n // limit concurrent image loads to help with raster sources performance on big screens\n for (let numImageRequests = currentParallelImageRequests;\n numImageRequests < maxImageRequests && imageRequestQueue.length > 0;\n numImageRequests++) {\n\n const topItemInQueue: ImageRequestQueueItem = imageRequestQueue.shift();\n if (topItemInQueue.abortController.signal.aborted) {\n numImageRequests--;\n continue;\n }\n doImageRequest(topItemInQueue);\n }\n };\n\n const getImageUsingHtmlImage = (requestParameters: RequestParameters, abortController: AbortController): Promise> => {\n return new Promise>((resolve, reject) => {\n\n const image = new Image() as HTMLImageElementWithPriority;\n const url = requestParameters.url;\n const credentials = requestParameters.credentials;\n if (credentials && credentials === 'include') {\n image.crossOrigin = 'use-credentials';\n } else if ((credentials && credentials === 'same-origin') || !sameOrigin(url)) {\n image.crossOrigin = 'anonymous';\n }\n\n abortController.signal.addEventListener('abort', () => {\n // Set src to '' to actually cancel the request\n image.src = '';\n reject(createAbortError());\n });\n\n image.fetchPriority = 'high';\n image.onload = () => {\n image.onerror = image.onload = null;\n resolve({data: image});\n };\n image.onerror = () => {\n image.onerror = image.onload = null;\n if (abortController.signal.aborted) {\n return;\n }\n reject(new Error('Could not load image. Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported.'));\n };\n image.src = url;\n });\n };\n}\n\nImageRequest.resetRequestQueue();\n","import type {RequestParameters} from './ajax';\n\n/**\n * A type of MapLibre resource.\n */\nexport const enum ResourceType {\n Glyphs = 'Glyphs',\n Image = 'Image',\n Source = 'Source',\n SpriteImage = 'SpriteImage',\n SpriteJSON = 'SpriteJSON',\n Style = 'Style',\n Tile = 'Tile',\n Unknown = 'Unknown',\n}\n\n/**\n * This function is used to tranform a request.\n * It is used just before executing the relevant request.\n */\nexport type RequestTransformFunction = (url: string, resourceType?: ResourceType) => RequestParameters | undefined;\n\nexport class RequestManager {\n _transformRequestFn: RequestTransformFunction;\n\n constructor(transformRequestFn?: RequestTransformFunction) {\n this._transformRequestFn = transformRequestFn;\n }\n\n transformRequest(url: string, type: ResourceType) {\n if (this._transformRequestFn) {\n return this._transformRequestFn(url, type) || {url};\n }\n\n return {url};\n }\n\n setTransformRequest(transformRequest: RequestTransformFunction) {\n this._transformRequestFn = transformRequest;\n }\n}\n\n","import * as glMatrix from \"./common.js\";\n/**\n * 2x2 Matrix\n * @module mat2\n */\n\n/**\n * Creates a new identity mat2\n *\n * @returns {mat2} a new 2x2 matrix\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(4);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n }\n\n out[0] = 1;\n out[3] = 1;\n return out;\n}\n/**\n * Creates a new mat2 initialized with values from an existing matrix\n *\n * @param {ReadonlyMat2} a matrix to clone\n * @returns {mat2} a new 2x2 matrix\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(4);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n return out;\n}\n/**\n * Copy the values from one mat2 to another\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the source matrix\n * @returns {mat2} out\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n return out;\n}\n/**\n * Set a mat2 to the identity matrix\n *\n * @param {mat2} out the receiving matrix\n * @returns {mat2} out\n */\n\nexport function identity(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n return out;\n}\n/**\n * Create a new mat2 with the given values\n *\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m10 Component in column 1, row 0 position (index 2)\n * @param {Number} m11 Component in column 1, row 1 position (index 3)\n * @returns {mat2} out A new 2x2 matrix\n */\n\nexport function fromValues(m00, m01, m10, m11) {\n var out = new glMatrix.ARRAY_TYPE(4);\n out[0] = m00;\n out[1] = m01;\n out[2] = m10;\n out[3] = m11;\n return out;\n}\n/**\n * Set the components of a mat2 to the given values\n *\n * @param {mat2} out the receiving matrix\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m10 Component in column 1, row 0 position (index 2)\n * @param {Number} m11 Component in column 1, row 1 position (index 3)\n * @returns {mat2} out\n */\n\nexport function set(out, m00, m01, m10, m11) {\n out[0] = m00;\n out[1] = m01;\n out[2] = m10;\n out[3] = m11;\n return out;\n}\n/**\n * Transpose the values of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the source matrix\n * @returns {mat2} out\n */\n\nexport function transpose(out, a) {\n // If we are transposing ourselves we can skip a few steps but have to cache\n // some values\n if (out === a) {\n var a1 = a[1];\n out[1] = a[2];\n out[2] = a1;\n } else {\n out[0] = a[0];\n out[1] = a[2];\n out[2] = a[1];\n out[3] = a[3];\n }\n\n return out;\n}\n/**\n * Inverts a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the source matrix\n * @returns {mat2} out\n */\n\nexport function invert(out, a) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3]; // Calculate the determinant\n\n var det = a0 * a3 - a2 * a1;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = a3 * det;\n out[1] = -a1 * det;\n out[2] = -a2 * det;\n out[3] = a0 * det;\n return out;\n}\n/**\n * Calculates the adjugate of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the source matrix\n * @returns {mat2} out\n */\n\nexport function adjoint(out, a) {\n // Caching this value is nessecary if out == a\n var a0 = a[0];\n out[0] = a[3];\n out[1] = -a[1];\n out[2] = -a[2];\n out[3] = a0;\n return out;\n}\n/**\n * Calculates the determinant of a mat2\n *\n * @param {ReadonlyMat2} a the source matrix\n * @returns {Number} determinant of a\n */\n\nexport function determinant(a) {\n return a[0] * a[3] - a[2] * a[1];\n}\n/**\n * Multiplies two mat2's\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the first operand\n * @param {ReadonlyMat2} b the second operand\n * @returns {mat2} out\n */\n\nexport function multiply(out, a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n out[0] = a0 * b0 + a2 * b1;\n out[1] = a1 * b0 + a3 * b1;\n out[2] = a0 * b2 + a2 * b3;\n out[3] = a1 * b2 + a3 * b3;\n return out;\n}\n/**\n * Rotates a mat2 by the given angle\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2} out\n */\n\nexport function rotate(out, a, rad) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n out[0] = a0 * c + a2 * s;\n out[1] = a1 * c + a3 * s;\n out[2] = a0 * -s + a2 * c;\n out[3] = a1 * -s + a3 * c;\n return out;\n}\n/**\n * Scales the mat2 by the dimensions in the given vec2\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the matrix to rotate\n * @param {ReadonlyVec2} v the vec2 to scale the matrix by\n * @returns {mat2} out\n **/\n\nexport function scale(out, a, v) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var v0 = v[0],\n v1 = v[1];\n out[0] = a0 * v0;\n out[1] = a1 * v0;\n out[2] = a2 * v1;\n out[3] = a3 * v1;\n return out;\n}\n/**\n * Creates a matrix from a given angle\n * This is equivalent to (but much faster than):\n *\n * mat2.identity(dest);\n * mat2.rotate(dest, dest, rad);\n *\n * @param {mat2} out mat2 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2} out\n */\n\nexport function fromRotation(out, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n out[0] = c;\n out[1] = s;\n out[2] = -s;\n out[3] = c;\n return out;\n}\n/**\n * Creates a matrix from a vector scaling\n * This is equivalent to (but much faster than):\n *\n * mat2.identity(dest);\n * mat2.scale(dest, dest, vec);\n *\n * @param {mat2} out mat2 receiving operation result\n * @param {ReadonlyVec2} v Scaling vector\n * @returns {mat2} out\n */\n\nexport function fromScaling(out, v) {\n out[0] = v[0];\n out[1] = 0;\n out[2] = 0;\n out[3] = v[1];\n return out;\n}\n/**\n * Returns a string representation of a mat2\n *\n * @param {ReadonlyMat2} a matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\n\nexport function str(a) {\n return \"mat2(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \")\";\n}\n/**\n * Returns Frobenius norm of a mat2\n *\n * @param {ReadonlyMat2} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\n\nexport function frob(a) {\n return Math.hypot(a[0], a[1], a[2], a[3]);\n}\n/**\n * Returns L, D and U matrices (Lower triangular, Diagonal and Upper triangular) by factorizing the input matrix\n * @param {ReadonlyMat2} L the lower triangular matrix\n * @param {ReadonlyMat2} D the diagonal matrix\n * @param {ReadonlyMat2} U the upper triangular matrix\n * @param {ReadonlyMat2} a the input matrix to factorize\n */\n\nexport function LDU(L, D, U, a) {\n L[2] = a[2] / a[0];\n U[0] = a[0];\n U[1] = a[1];\n U[3] = a[3] - L[2] * U[1];\n return [L, D, U];\n}\n/**\n * Adds two mat2's\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the first operand\n * @param {ReadonlyMat2} b the second operand\n * @returns {mat2} out\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n return out;\n}\n/**\n * Subtracts matrix b from matrix a\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the first operand\n * @param {ReadonlyMat2} b the second operand\n * @returns {mat2} out\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n return out;\n}\n/**\n * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyMat2} a The first matrix.\n * @param {ReadonlyMat2} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3];\n}\n/**\n * Returns whether or not the matrices have approximately the same elements in the same position.\n *\n * @param {ReadonlyMat2} a The first matrix.\n * @param {ReadonlyMat2} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3));\n}\n/**\n * Multiply each element of the matrix by a scalar.\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the matrix to scale\n * @param {Number} b amount to scale the matrix's elements by\n * @returns {mat2} out\n */\n\nexport function multiplyScalar(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n return out;\n}\n/**\n * Adds two mat2's after multiplying each element of the second operand by a scalar value.\n *\n * @param {mat2} out the receiving vector\n * @param {ReadonlyMat2} a the first operand\n * @param {ReadonlyMat2} b the second operand\n * @param {Number} scale the amount to scale b's elements by before adding\n * @returns {mat2} out\n */\n\nexport function multiplyScalarAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n return out;\n}\n/**\n * Alias for {@link mat2.multiply}\n * @function\n */\n\nexport var mul = multiply;\n/**\n * Alias for {@link mat2.subtract}\n * @function\n */\n\nexport var sub = subtract;","import * as glMatrix from \"./common.js\";\n/**\n * 3x3 Matrix\n * @module mat3\n */\n\n/**\n * Creates a new identity mat3\n *\n * @returns {mat3} a new 3x3 matrix\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(9);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n }\n\n out[0] = 1;\n out[4] = 1;\n out[8] = 1;\n return out;\n}\n/**\n * Copies the upper-left 3x3 values into the given mat3.\n *\n * @param {mat3} out the receiving 3x3 matrix\n * @param {ReadonlyMat4} a the source 4x4 matrix\n * @returns {mat3} out\n */\n\nexport function fromMat4(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[4];\n out[4] = a[5];\n out[5] = a[6];\n out[6] = a[8];\n out[7] = a[9];\n out[8] = a[10];\n return out;\n}\n/**\n * Creates a new mat3 initialized with values from an existing matrix\n *\n * @param {ReadonlyMat3} a matrix to clone\n * @returns {mat3} a new 3x3 matrix\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(9);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\n * Copy the values from one mat3 to another\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the source matrix\n * @returns {mat3} out\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\n * Create a new mat3 with the given values\n *\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\n * @param {Number} m10 Component in column 1, row 0 position (index 3)\n * @param {Number} m11 Component in column 1, row 1 position (index 4)\n * @param {Number} m12 Component in column 1, row 2 position (index 5)\n * @param {Number} m20 Component in column 2, row 0 position (index 6)\n * @param {Number} m21 Component in column 2, row 1 position (index 7)\n * @param {Number} m22 Component in column 2, row 2 position (index 8)\n * @returns {mat3} A new mat3\n */\n\nexport function fromValues(m00, m01, m02, m10, m11, m12, m20, m21, m22) {\n var out = new glMatrix.ARRAY_TYPE(9);\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m10;\n out[4] = m11;\n out[5] = m12;\n out[6] = m20;\n out[7] = m21;\n out[8] = m22;\n return out;\n}\n/**\n * Set the components of a mat3 to the given values\n *\n * @param {mat3} out the receiving matrix\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\n * @param {Number} m10 Component in column 1, row 0 position (index 3)\n * @param {Number} m11 Component in column 1, row 1 position (index 4)\n * @param {Number} m12 Component in column 1, row 2 position (index 5)\n * @param {Number} m20 Component in column 2, row 0 position (index 6)\n * @param {Number} m21 Component in column 2, row 1 position (index 7)\n * @param {Number} m22 Component in column 2, row 2 position (index 8)\n * @returns {mat3} out\n */\n\nexport function set(out, m00, m01, m02, m10, m11, m12, m20, m21, m22) {\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m10;\n out[4] = m11;\n out[5] = m12;\n out[6] = m20;\n out[7] = m21;\n out[8] = m22;\n return out;\n}\n/**\n * Set a mat3 to the identity matrix\n *\n * @param {mat3} out the receiving matrix\n * @returns {mat3} out\n */\n\nexport function identity(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 1;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\n * Transpose the values of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the source matrix\n * @returns {mat3} out\n */\n\nexport function transpose(out, a) {\n // If we are transposing ourselves we can skip a few steps but have to cache some values\n if (out === a) {\n var a01 = a[1],\n a02 = a[2],\n a12 = a[5];\n out[1] = a[3];\n out[2] = a[6];\n out[3] = a01;\n out[5] = a[7];\n out[6] = a02;\n out[7] = a12;\n } else {\n out[0] = a[0];\n out[1] = a[3];\n out[2] = a[6];\n out[3] = a[1];\n out[4] = a[4];\n out[5] = a[7];\n out[6] = a[2];\n out[7] = a[5];\n out[8] = a[8];\n }\n\n return out;\n}\n/**\n * Inverts a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the source matrix\n * @returns {mat3} out\n */\n\nexport function invert(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n var b01 = a22 * a11 - a12 * a21;\n var b11 = -a22 * a10 + a12 * a20;\n var b21 = a21 * a10 - a11 * a20; // Calculate the determinant\n\n var det = a00 * b01 + a01 * b11 + a02 * b21;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = b01 * det;\n out[1] = (-a22 * a01 + a02 * a21) * det;\n out[2] = (a12 * a01 - a02 * a11) * det;\n out[3] = b11 * det;\n out[4] = (a22 * a00 - a02 * a20) * det;\n out[5] = (-a12 * a00 + a02 * a10) * det;\n out[6] = b21 * det;\n out[7] = (-a21 * a00 + a01 * a20) * det;\n out[8] = (a11 * a00 - a01 * a10) * det;\n return out;\n}\n/**\n * Calculates the adjugate of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the source matrix\n * @returns {mat3} out\n */\n\nexport function adjoint(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n out[0] = a11 * a22 - a12 * a21;\n out[1] = a02 * a21 - a01 * a22;\n out[2] = a01 * a12 - a02 * a11;\n out[3] = a12 * a20 - a10 * a22;\n out[4] = a00 * a22 - a02 * a20;\n out[5] = a02 * a10 - a00 * a12;\n out[6] = a10 * a21 - a11 * a20;\n out[7] = a01 * a20 - a00 * a21;\n out[8] = a00 * a11 - a01 * a10;\n return out;\n}\n/**\n * Calculates the determinant of a mat3\n *\n * @param {ReadonlyMat3} a the source matrix\n * @returns {Number} determinant of a\n */\n\nexport function determinant(a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n return a00 * (a22 * a11 - a12 * a21) + a01 * (-a22 * a10 + a12 * a20) + a02 * (a21 * a10 - a11 * a20);\n}\n/**\n * Multiplies two mat3's\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the first operand\n * @param {ReadonlyMat3} b the second operand\n * @returns {mat3} out\n */\n\nexport function multiply(out, a, b) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n var b00 = b[0],\n b01 = b[1],\n b02 = b[2];\n var b10 = b[3],\n b11 = b[4],\n b12 = b[5];\n var b20 = b[6],\n b21 = b[7],\n b22 = b[8];\n out[0] = b00 * a00 + b01 * a10 + b02 * a20;\n out[1] = b00 * a01 + b01 * a11 + b02 * a21;\n out[2] = b00 * a02 + b01 * a12 + b02 * a22;\n out[3] = b10 * a00 + b11 * a10 + b12 * a20;\n out[4] = b10 * a01 + b11 * a11 + b12 * a21;\n out[5] = b10 * a02 + b11 * a12 + b12 * a22;\n out[6] = b20 * a00 + b21 * a10 + b22 * a20;\n out[7] = b20 * a01 + b21 * a11 + b22 * a21;\n out[8] = b20 * a02 + b21 * a12 + b22 * a22;\n return out;\n}\n/**\n * Translate a mat3 by the given vector\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the matrix to translate\n * @param {ReadonlyVec2} v vector to translate by\n * @returns {mat3} out\n */\n\nexport function translate(out, a, v) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a10 = a[3],\n a11 = a[4],\n a12 = a[5],\n a20 = a[6],\n a21 = a[7],\n a22 = a[8],\n x = v[0],\n y = v[1];\n out[0] = a00;\n out[1] = a01;\n out[2] = a02;\n out[3] = a10;\n out[4] = a11;\n out[5] = a12;\n out[6] = x * a00 + y * a10 + a20;\n out[7] = x * a01 + y * a11 + a21;\n out[8] = x * a02 + y * a12 + a22;\n return out;\n}\n/**\n * Rotates a mat3 by the given angle\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat3} out\n */\n\nexport function rotate(out, a, rad) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a10 = a[3],\n a11 = a[4],\n a12 = a[5],\n a20 = a[6],\n a21 = a[7],\n a22 = a[8],\n s = Math.sin(rad),\n c = Math.cos(rad);\n out[0] = c * a00 + s * a10;\n out[1] = c * a01 + s * a11;\n out[2] = c * a02 + s * a12;\n out[3] = c * a10 - s * a00;\n out[4] = c * a11 - s * a01;\n out[5] = c * a12 - s * a02;\n out[6] = a20;\n out[7] = a21;\n out[8] = a22;\n return out;\n}\n/**\n * Scales the mat3 by the dimensions in the given vec2\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the matrix to rotate\n * @param {ReadonlyVec2} v the vec2 to scale the matrix by\n * @returns {mat3} out\n **/\n\nexport function scale(out, a, v) {\n var x = v[0],\n y = v[1];\n out[0] = x * a[0];\n out[1] = x * a[1];\n out[2] = x * a[2];\n out[3] = y * a[3];\n out[4] = y * a[4];\n out[5] = y * a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\n * Creates a matrix from a vector translation\n * This is equivalent to (but much faster than):\n *\n * mat3.identity(dest);\n * mat3.translate(dest, dest, vec);\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {ReadonlyVec2} v Translation vector\n * @returns {mat3} out\n */\n\nexport function fromTranslation(out, v) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 1;\n out[5] = 0;\n out[6] = v[0];\n out[7] = v[1];\n out[8] = 1;\n return out;\n}\n/**\n * Creates a matrix from a given angle\n * This is equivalent to (but much faster than):\n *\n * mat3.identity(dest);\n * mat3.rotate(dest, dest, rad);\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat3} out\n */\n\nexport function fromRotation(out, rad) {\n var s = Math.sin(rad),\n c = Math.cos(rad);\n out[0] = c;\n out[1] = s;\n out[2] = 0;\n out[3] = -s;\n out[4] = c;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\n * Creates a matrix from a vector scaling\n * This is equivalent to (but much faster than):\n *\n * mat3.identity(dest);\n * mat3.scale(dest, dest, vec);\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {ReadonlyVec2} v Scaling vector\n * @returns {mat3} out\n */\n\nexport function fromScaling(out, v) {\n out[0] = v[0];\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = v[1];\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\n * Copies the values from a mat2d into a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat2d} a the matrix to copy\n * @returns {mat3} out\n **/\n\nexport function fromMat2d(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = 0;\n out[3] = a[2];\n out[4] = a[3];\n out[5] = 0;\n out[6] = a[4];\n out[7] = a[5];\n out[8] = 1;\n return out;\n}\n/**\n * Calculates a 3x3 matrix from the given quaternion\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {ReadonlyQuat} q Quaternion to create matrix from\n *\n * @returns {mat3} out\n */\n\nexport function fromQuat(out, q) {\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var yx = y * x2;\n var yy = y * y2;\n var zx = z * x2;\n var zy = z * y2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n out[0] = 1 - yy - zz;\n out[3] = yx - wz;\n out[6] = zx + wy;\n out[1] = yx + wz;\n out[4] = 1 - xx - zz;\n out[7] = zy - wx;\n out[2] = zx - wy;\n out[5] = zy + wx;\n out[8] = 1 - xx - yy;\n return out;\n}\n/**\n * Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {ReadonlyMat4} a Mat4 to derive the normal matrix from\n *\n * @returns {mat3} out\n */\n\nexport function normalFromMat4(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n var b00 = a00 * a11 - a01 * a10;\n var b01 = a00 * a12 - a02 * a10;\n var b02 = a00 * a13 - a03 * a10;\n var b03 = a01 * a12 - a02 * a11;\n var b04 = a01 * a13 - a03 * a11;\n var b05 = a02 * a13 - a03 * a12;\n var b06 = a20 * a31 - a21 * a30;\n var b07 = a20 * a32 - a22 * a30;\n var b08 = a20 * a33 - a23 * a30;\n var b09 = a21 * a32 - a22 * a31;\n var b10 = a21 * a33 - a23 * a31;\n var b11 = a22 * a33 - a23 * a32; // Calculate the determinant\n\n var det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n out[1] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n out[2] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n out[3] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n out[4] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n out[5] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n out[6] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n out[7] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n out[8] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n return out;\n}\n/**\n * Generates a 2D projection matrix with the given bounds\n *\n * @param {mat3} out mat3 frustum matrix will be written into\n * @param {number} width Width of your gl context\n * @param {number} height Height of gl context\n * @returns {mat3} out\n */\n\nexport function projection(out, width, height) {\n out[0] = 2 / width;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = -2 / height;\n out[5] = 0;\n out[6] = -1;\n out[7] = 1;\n out[8] = 1;\n return out;\n}\n/**\n * Returns a string representation of a mat3\n *\n * @param {ReadonlyMat3} a matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\n\nexport function str(a) {\n return \"mat3(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \", \" + a[4] + \", \" + a[5] + \", \" + a[6] + \", \" + a[7] + \", \" + a[8] + \")\";\n}\n/**\n * Returns Frobenius norm of a mat3\n *\n * @param {ReadonlyMat3} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\n\nexport function frob(a) {\n return Math.hypot(a[0], a[1], a[2], a[3], a[4], a[5], a[6], a[7], a[8]);\n}\n/**\n * Adds two mat3's\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the first operand\n * @param {ReadonlyMat3} b the second operand\n * @returns {mat3} out\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n out[4] = a[4] + b[4];\n out[5] = a[5] + b[5];\n out[6] = a[6] + b[6];\n out[7] = a[7] + b[7];\n out[8] = a[8] + b[8];\n return out;\n}\n/**\n * Subtracts matrix b from matrix a\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the first operand\n * @param {ReadonlyMat3} b the second operand\n * @returns {mat3} out\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n out[4] = a[4] - b[4];\n out[5] = a[5] - b[5];\n out[6] = a[6] - b[6];\n out[7] = a[7] - b[7];\n out[8] = a[8] - b[8];\n return out;\n}\n/**\n * Multiply each element of the matrix by a scalar.\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the matrix to scale\n * @param {Number} b amount to scale the matrix's elements by\n * @returns {mat3} out\n */\n\nexport function multiplyScalar(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n out[4] = a[4] * b;\n out[5] = a[5] * b;\n out[6] = a[6] * b;\n out[7] = a[7] * b;\n out[8] = a[8] * b;\n return out;\n}\n/**\n * Adds two mat3's after multiplying each element of the second operand by a scalar value.\n *\n * @param {mat3} out the receiving vector\n * @param {ReadonlyMat3} a the first operand\n * @param {ReadonlyMat3} b the second operand\n * @param {Number} scale the amount to scale b's elements by before adding\n * @returns {mat3} out\n */\n\nexport function multiplyScalarAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n out[4] = a[4] + b[4] * scale;\n out[5] = a[5] + b[5] * scale;\n out[6] = a[6] + b[6] * scale;\n out[7] = a[7] + b[7] * scale;\n out[8] = a[8] + b[8] * scale;\n return out;\n}\n/**\n * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyMat3} a The first matrix.\n * @param {ReadonlyMat3} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3] && a[4] === b[4] && a[5] === b[5] && a[6] === b[6] && a[7] === b[7] && a[8] === b[8];\n}\n/**\n * Returns whether or not the matrices have approximately the same elements in the same position.\n *\n * @param {ReadonlyMat3} a The first matrix.\n * @param {ReadonlyMat3} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3],\n a4 = a[4],\n a5 = a[5],\n a6 = a[6],\n a7 = a[7],\n a8 = a[8];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3],\n b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7],\n b8 = b[8];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3)) && Math.abs(a4 - b4) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a4), Math.abs(b4)) && Math.abs(a5 - b5) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a5), Math.abs(b5)) && Math.abs(a6 - b6) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a6), Math.abs(b6)) && Math.abs(a7 - b7) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a7), Math.abs(b7)) && Math.abs(a8 - b8) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a8), Math.abs(b8));\n}\n/**\n * Alias for {@link mat3.multiply}\n * @function\n */\n\nexport var mul = multiply;\n/**\n * Alias for {@link mat3.subtract}\n * @function\n */\n\nexport var sub = subtract;","import * as glMatrix from \"./common.js\";\n/**\n * 3 Dimensional Vector\n * @module vec3\n */\n\n/**\n * Creates a new, empty vec3\n *\n * @returns {vec3} a new 3D vector\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(3);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n }\n\n return out;\n}\n/**\n * Creates a new vec3 initialized with values from an existing vector\n *\n * @param {ReadonlyVec3} a vector to clone\n * @returns {vec3} a new 3D vector\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(3);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n return out;\n}\n/**\n * Calculates the length of a vec3\n *\n * @param {ReadonlyVec3} a vector to calculate length of\n * @returns {Number} length of a\n */\n\nexport function length(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n return Math.hypot(x, y, z);\n}\n/**\n * Creates a new vec3 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} a new 3D vector\n */\n\nexport function fromValues(x, y, z) {\n var out = new glMatrix.ARRAY_TYPE(3);\n out[0] = x;\n out[1] = y;\n out[2] = z;\n return out;\n}\n/**\n * Copy the values from one vec3 to another\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the source vector\n * @returns {vec3} out\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n return out;\n}\n/**\n * Set the components of a vec3 to the given values\n *\n * @param {vec3} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} out\n */\n\nexport function set(out, x, y, z) {\n out[0] = x;\n out[1] = y;\n out[2] = z;\n return out;\n}\n/**\n * Adds two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n return out;\n}\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n return out;\n}\n/**\n * Multiplies two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\n\nexport function multiply(out, a, b) {\n out[0] = a[0] * b[0];\n out[1] = a[1] * b[1];\n out[2] = a[2] * b[2];\n return out;\n}\n/**\n * Divides two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\n\nexport function divide(out, a, b) {\n out[0] = a[0] / b[0];\n out[1] = a[1] / b[1];\n out[2] = a[2] / b[2];\n return out;\n}\n/**\n * Math.ceil the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to ceil\n * @returns {vec3} out\n */\n\nexport function ceil(out, a) {\n out[0] = Math.ceil(a[0]);\n out[1] = Math.ceil(a[1]);\n out[2] = Math.ceil(a[2]);\n return out;\n}\n/**\n * Math.floor the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to floor\n * @returns {vec3} out\n */\n\nexport function floor(out, a) {\n out[0] = Math.floor(a[0]);\n out[1] = Math.floor(a[1]);\n out[2] = Math.floor(a[2]);\n return out;\n}\n/**\n * Returns the minimum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\n\nexport function min(out, a, b) {\n out[0] = Math.min(a[0], b[0]);\n out[1] = Math.min(a[1], b[1]);\n out[2] = Math.min(a[2], b[2]);\n return out;\n}\n/**\n * Returns the maximum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\n\nexport function max(out, a, b) {\n out[0] = Math.max(a[0], b[0]);\n out[1] = Math.max(a[1], b[1]);\n out[2] = Math.max(a[2], b[2]);\n return out;\n}\n/**\n * Math.round the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to round\n * @returns {vec3} out\n */\n\nexport function round(out, a) {\n out[0] = Math.round(a[0]);\n out[1] = Math.round(a[1]);\n out[2] = Math.round(a[2]);\n return out;\n}\n/**\n * Scales a vec3 by a scalar number\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec3} out\n */\n\nexport function scale(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n return out;\n}\n/**\n * Adds two vec3's after scaling the second operand by a scalar value\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec3} out\n */\n\nexport function scaleAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n return out;\n}\n/**\n * Calculates the euclidian distance between two vec3's\n *\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {Number} distance between a and b\n */\n\nexport function distance(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n return Math.hypot(x, y, z);\n}\n/**\n * Calculates the squared euclidian distance between two vec3's\n *\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {Number} squared distance between a and b\n */\n\nexport function squaredDistance(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n return x * x + y * y + z * z;\n}\n/**\n * Calculates the squared length of a vec3\n *\n * @param {ReadonlyVec3} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\n\nexport function squaredLength(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n return x * x + y * y + z * z;\n}\n/**\n * Negates the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to negate\n * @returns {vec3} out\n */\n\nexport function negate(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n out[2] = -a[2];\n return out;\n}\n/**\n * Returns the inverse of the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to invert\n * @returns {vec3} out\n */\n\nexport function inverse(out, a) {\n out[0] = 1.0 / a[0];\n out[1] = 1.0 / a[1];\n out[2] = 1.0 / a[2];\n return out;\n}\n/**\n * Normalize a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to normalize\n * @returns {vec3} out\n */\n\nexport function normalize(out, a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var len = x * x + y * y + z * z;\n\n if (len > 0) {\n //TODO: evaluate use of glm_invsqrt here?\n len = 1 / Math.sqrt(len);\n }\n\n out[0] = a[0] * len;\n out[1] = a[1] * len;\n out[2] = a[2] * len;\n return out;\n}\n/**\n * Calculates the dot product of two vec3's\n *\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {Number} dot product of a and b\n */\n\nexport function dot(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n}\n/**\n * Computes the cross product of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\n\nexport function cross(out, a, b) {\n var ax = a[0],\n ay = a[1],\n az = a[2];\n var bx = b[0],\n by = b[1],\n bz = b[2];\n out[0] = ay * bz - az * by;\n out[1] = az * bx - ax * bz;\n out[2] = ax * by - ay * bx;\n return out;\n}\n/**\n * Performs a linear interpolation between two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec3} out\n */\n\nexport function lerp(out, a, b, t) {\n var ax = a[0];\n var ay = a[1];\n var az = a[2];\n out[0] = ax + t * (b[0] - ax);\n out[1] = ay + t * (b[1] - ay);\n out[2] = az + t * (b[2] - az);\n return out;\n}\n/**\n * Performs a hermite interpolation with two control points\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @param {ReadonlyVec3} c the third operand\n * @param {ReadonlyVec3} d the fourth operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec3} out\n */\n\nexport function hermite(out, a, b, c, d, t) {\n var factorTimes2 = t * t;\n var factor1 = factorTimes2 * (2 * t - 3) + 1;\n var factor2 = factorTimes2 * (t - 2) + t;\n var factor3 = factorTimes2 * (t - 1);\n var factor4 = factorTimes2 * (3 - 2 * t);\n out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4;\n out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4;\n out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4;\n return out;\n}\n/**\n * Performs a bezier interpolation with two control points\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @param {ReadonlyVec3} c the third operand\n * @param {ReadonlyVec3} d the fourth operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec3} out\n */\n\nexport function bezier(out, a, b, c, d, t) {\n var inverseFactor = 1 - t;\n var inverseFactorTimesTwo = inverseFactor * inverseFactor;\n var factorTimes2 = t * t;\n var factor1 = inverseFactorTimesTwo * inverseFactor;\n var factor2 = 3 * t * inverseFactorTimesTwo;\n var factor3 = 3 * factorTimes2 * inverseFactor;\n var factor4 = factorTimes2 * t;\n out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4;\n out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4;\n out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4;\n return out;\n}\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec3} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec3} out\n */\n\nexport function random(out, scale) {\n scale = scale || 1.0;\n var r = glMatrix.RANDOM() * 2.0 * Math.PI;\n var z = glMatrix.RANDOM() * 2.0 - 1.0;\n var zScale = Math.sqrt(1.0 - z * z) * scale;\n out[0] = Math.cos(r) * zScale;\n out[1] = Math.sin(r) * zScale;\n out[2] = z * scale;\n return out;\n}\n/**\n * Transforms the vec3 with a mat4.\n * 4th vector component is implicitly '1'\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the vector to transform\n * @param {ReadonlyMat4} m matrix to transform with\n * @returns {vec3} out\n */\n\nexport function transformMat4(out, a, m) {\n var x = a[0],\n y = a[1],\n z = a[2];\n var w = m[3] * x + m[7] * y + m[11] * z + m[15];\n w = w || 1.0;\n out[0] = (m[0] * x + m[4] * y + m[8] * z + m[12]) / w;\n out[1] = (m[1] * x + m[5] * y + m[9] * z + m[13]) / w;\n out[2] = (m[2] * x + m[6] * y + m[10] * z + m[14]) / w;\n return out;\n}\n/**\n * Transforms the vec3 with a mat3.\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the vector to transform\n * @param {ReadonlyMat3} m the 3x3 matrix to transform with\n * @returns {vec3} out\n */\n\nexport function transformMat3(out, a, m) {\n var x = a[0],\n y = a[1],\n z = a[2];\n out[0] = x * m[0] + y * m[3] + z * m[6];\n out[1] = x * m[1] + y * m[4] + z * m[7];\n out[2] = x * m[2] + y * m[5] + z * m[8];\n return out;\n}\n/**\n * Transforms the vec3 with a quat\n * Can also be used for dual quaternions. (Multiply it with the real part)\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the vector to transform\n * @param {ReadonlyQuat} q quaternion to transform with\n * @returns {vec3} out\n */\n\nexport function transformQuat(out, a, q) {\n // benchmarks: https://jsperf.com/quaternion-transform-vec3-implementations-fixed\n var qx = q[0],\n qy = q[1],\n qz = q[2],\n qw = q[3];\n var x = a[0],\n y = a[1],\n z = a[2]; // var qvec = [qx, qy, qz];\n // var uv = vec3.cross([], qvec, a);\n\n var uvx = qy * z - qz * y,\n uvy = qz * x - qx * z,\n uvz = qx * y - qy * x; // var uuv = vec3.cross([], qvec, uv);\n\n var uuvx = qy * uvz - qz * uvy,\n uuvy = qz * uvx - qx * uvz,\n uuvz = qx * uvy - qy * uvx; // vec3.scale(uv, uv, 2 * w);\n\n var w2 = qw * 2;\n uvx *= w2;\n uvy *= w2;\n uvz *= w2; // vec3.scale(uuv, uuv, 2);\n\n uuvx *= 2;\n uuvy *= 2;\n uuvz *= 2; // return vec3.add(out, a, vec3.add(out, uv, uuv));\n\n out[0] = x + uvx + uuvx;\n out[1] = y + uvy + uuvy;\n out[2] = z + uvz + uuvz;\n return out;\n}\n/**\n * Rotate a 3D vector around the x-axis\n * @param {vec3} out The receiving vec3\n * @param {ReadonlyVec3} a The vec3 point to rotate\n * @param {ReadonlyVec3} b The origin of the rotation\n * @param {Number} rad The angle of rotation in radians\n * @returns {vec3} out\n */\n\nexport function rotateX(out, a, b, rad) {\n var p = [],\n r = []; //Translate point to the origin\n\n p[0] = a[0] - b[0];\n p[1] = a[1] - b[1];\n p[2] = a[2] - b[2]; //perform rotation\n\n r[0] = p[0];\n r[1] = p[1] * Math.cos(rad) - p[2] * Math.sin(rad);\n r[2] = p[1] * Math.sin(rad) + p[2] * Math.cos(rad); //translate to correct position\n\n out[0] = r[0] + b[0];\n out[1] = r[1] + b[1];\n out[2] = r[2] + b[2];\n return out;\n}\n/**\n * Rotate a 3D vector around the y-axis\n * @param {vec3} out The receiving vec3\n * @param {ReadonlyVec3} a The vec3 point to rotate\n * @param {ReadonlyVec3} b The origin of the rotation\n * @param {Number} rad The angle of rotation in radians\n * @returns {vec3} out\n */\n\nexport function rotateY(out, a, b, rad) {\n var p = [],\n r = []; //Translate point to the origin\n\n p[0] = a[0] - b[0];\n p[1] = a[1] - b[1];\n p[2] = a[2] - b[2]; //perform rotation\n\n r[0] = p[2] * Math.sin(rad) + p[0] * Math.cos(rad);\n r[1] = p[1];\n r[2] = p[2] * Math.cos(rad) - p[0] * Math.sin(rad); //translate to correct position\n\n out[0] = r[0] + b[0];\n out[1] = r[1] + b[1];\n out[2] = r[2] + b[2];\n return out;\n}\n/**\n * Rotate a 3D vector around the z-axis\n * @param {vec3} out The receiving vec3\n * @param {ReadonlyVec3} a The vec3 point to rotate\n * @param {ReadonlyVec3} b The origin of the rotation\n * @param {Number} rad The angle of rotation in radians\n * @returns {vec3} out\n */\n\nexport function rotateZ(out, a, b, rad) {\n var p = [],\n r = []; //Translate point to the origin\n\n p[0] = a[0] - b[0];\n p[1] = a[1] - b[1];\n p[2] = a[2] - b[2]; //perform rotation\n\n r[0] = p[0] * Math.cos(rad) - p[1] * Math.sin(rad);\n r[1] = p[0] * Math.sin(rad) + p[1] * Math.cos(rad);\n r[2] = p[2]; //translate to correct position\n\n out[0] = r[0] + b[0];\n out[1] = r[1] + b[1];\n out[2] = r[2] + b[2];\n return out;\n}\n/**\n * Get the angle between two 3D vectors\n * @param {ReadonlyVec3} a The first operand\n * @param {ReadonlyVec3} b The second operand\n * @returns {Number} The angle in radians\n */\n\nexport function angle(a, b) {\n var ax = a[0],\n ay = a[1],\n az = a[2],\n bx = b[0],\n by = b[1],\n bz = b[2],\n mag1 = Math.sqrt(ax * ax + ay * ay + az * az),\n mag2 = Math.sqrt(bx * bx + by * by + bz * bz),\n mag = mag1 * mag2,\n cosine = mag && dot(a, b) / mag;\n return Math.acos(Math.min(Math.max(cosine, -1), 1));\n}\n/**\n * Set the components of a vec3 to zero\n *\n * @param {vec3} out the receiving vector\n * @returns {vec3} out\n */\n\nexport function zero(out) {\n out[0] = 0.0;\n out[1] = 0.0;\n out[2] = 0.0;\n return out;\n}\n/**\n * Returns a string representation of a vector\n *\n * @param {ReadonlyVec3} a vector to represent as a string\n * @returns {String} string representation of the vector\n */\n\nexport function str(a) {\n return \"vec3(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \")\";\n}\n/**\n * Returns whether or not the vectors have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyVec3} a The first vector.\n * @param {ReadonlyVec3} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2];\n}\n/**\n * Returns whether or not the vectors have approximately the same elements in the same position.\n *\n * @param {ReadonlyVec3} a The first vector.\n * @param {ReadonlyVec3} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2));\n}\n/**\n * Alias for {@link vec3.subtract}\n * @function\n */\n\nexport var sub = subtract;\n/**\n * Alias for {@link vec3.multiply}\n * @function\n */\n\nexport var mul = multiply;\n/**\n * Alias for {@link vec3.divide}\n * @function\n */\n\nexport var div = divide;\n/**\n * Alias for {@link vec3.distance}\n * @function\n */\n\nexport var dist = distance;\n/**\n * Alias for {@link vec3.squaredDistance}\n * @function\n */\n\nexport var sqrDist = squaredDistance;\n/**\n * Alias for {@link vec3.length}\n * @function\n */\n\nexport var len = length;\n/**\n * Alias for {@link vec3.squaredLength}\n * @function\n */\n\nexport var sqrLen = squaredLength;\n/**\n * Perform some operation over an array of vec3s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec3. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec3s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\n\nexport var forEach = function () {\n var vec = create();\n return function (a, stride, offset, count, fn, arg) {\n var i, l;\n\n if (!stride) {\n stride = 3;\n }\n\n if (!offset) {\n offset = 0;\n }\n\n if (count) {\n l = Math.min(count * stride + offset, a.length);\n } else {\n l = a.length;\n }\n\n for (i = offset; i < l; i += stride) {\n vec[0] = a[i];\n vec[1] = a[i + 1];\n vec[2] = a[i + 2];\n fn(vec, vec, arg);\n a[i] = vec[0];\n a[i + 1] = vec[1];\n a[i + 2] = vec[2];\n }\n\n return a;\n };\n}();","import * as glMatrix from \"./common.js\";\n/**\n * 2 Dimensional Vector\n * @module vec2\n */\n\n/**\n * Creates a new, empty vec2\n *\n * @returns {vec2} a new 2D vector\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(2);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n }\n\n return out;\n}\n/**\n * Creates a new vec2 initialized with values from an existing vector\n *\n * @param {ReadonlyVec2} a vector to clone\n * @returns {vec2} a new 2D vector\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(2);\n out[0] = a[0];\n out[1] = a[1];\n return out;\n}\n/**\n * Creates a new vec2 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} a new 2D vector\n */\n\nexport function fromValues(x, y) {\n var out = new glMatrix.ARRAY_TYPE(2);\n out[0] = x;\n out[1] = y;\n return out;\n}\n/**\n * Copy the values from one vec2 to another\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the source vector\n * @returns {vec2} out\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n return out;\n}\n/**\n * Set the components of a vec2 to the given values\n *\n * @param {vec2} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} out\n */\n\nexport function set(out, x, y) {\n out[0] = x;\n out[1] = y;\n return out;\n}\n/**\n * Adds two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n return out;\n}\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n return out;\n}\n/**\n * Multiplies two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\n\nexport function multiply(out, a, b) {\n out[0] = a[0] * b[0];\n out[1] = a[1] * b[1];\n return out;\n}\n/**\n * Divides two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\n\nexport function divide(out, a, b) {\n out[0] = a[0] / b[0];\n out[1] = a[1] / b[1];\n return out;\n}\n/**\n * Math.ceil the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to ceil\n * @returns {vec2} out\n */\n\nexport function ceil(out, a) {\n out[0] = Math.ceil(a[0]);\n out[1] = Math.ceil(a[1]);\n return out;\n}\n/**\n * Math.floor the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to floor\n * @returns {vec2} out\n */\n\nexport function floor(out, a) {\n out[0] = Math.floor(a[0]);\n out[1] = Math.floor(a[1]);\n return out;\n}\n/**\n * Returns the minimum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\n\nexport function min(out, a, b) {\n out[0] = Math.min(a[0], b[0]);\n out[1] = Math.min(a[1], b[1]);\n return out;\n}\n/**\n * Returns the maximum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\n\nexport function max(out, a, b) {\n out[0] = Math.max(a[0], b[0]);\n out[1] = Math.max(a[1], b[1]);\n return out;\n}\n/**\n * Math.round the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to round\n * @returns {vec2} out\n */\n\nexport function round(out, a) {\n out[0] = Math.round(a[0]);\n out[1] = Math.round(a[1]);\n return out;\n}\n/**\n * Scales a vec2 by a scalar number\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec2} out\n */\n\nexport function scale(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n return out;\n}\n/**\n * Adds two vec2's after scaling the second operand by a scalar value\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec2} out\n */\n\nexport function scaleAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n return out;\n}\n/**\n * Calculates the euclidian distance between two vec2's\n *\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {Number} distance between a and b\n */\n\nexport function distance(a, b) {\n var x = b[0] - a[0],\n y = b[1] - a[1];\n return Math.hypot(x, y);\n}\n/**\n * Calculates the squared euclidian distance between two vec2's\n *\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {Number} squared distance between a and b\n */\n\nexport function squaredDistance(a, b) {\n var x = b[0] - a[0],\n y = b[1] - a[1];\n return x * x + y * y;\n}\n/**\n * Calculates the length of a vec2\n *\n * @param {ReadonlyVec2} a vector to calculate length of\n * @returns {Number} length of a\n */\n\nexport function length(a) {\n var x = a[0],\n y = a[1];\n return Math.hypot(x, y);\n}\n/**\n * Calculates the squared length of a vec2\n *\n * @param {ReadonlyVec2} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\n\nexport function squaredLength(a) {\n var x = a[0],\n y = a[1];\n return x * x + y * y;\n}\n/**\n * Negates the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to negate\n * @returns {vec2} out\n */\n\nexport function negate(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n return out;\n}\n/**\n * Returns the inverse of the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to invert\n * @returns {vec2} out\n */\n\nexport function inverse(out, a) {\n out[0] = 1.0 / a[0];\n out[1] = 1.0 / a[1];\n return out;\n}\n/**\n * Normalize a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to normalize\n * @returns {vec2} out\n */\n\nexport function normalize(out, a) {\n var x = a[0],\n y = a[1];\n var len = x * x + y * y;\n\n if (len > 0) {\n //TODO: evaluate use of glm_invsqrt here?\n len = 1 / Math.sqrt(len);\n }\n\n out[0] = a[0] * len;\n out[1] = a[1] * len;\n return out;\n}\n/**\n * Calculates the dot product of two vec2's\n *\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {Number} dot product of a and b\n */\n\nexport function dot(a, b) {\n return a[0] * b[0] + a[1] * b[1];\n}\n/**\n * Computes the cross product of two vec2's\n * Note that the cross product must by definition produce a 3D vector\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec3} out\n */\n\nexport function cross(out, a, b) {\n var z = a[0] * b[1] - a[1] * b[0];\n out[0] = out[1] = 0;\n out[2] = z;\n return out;\n}\n/**\n * Performs a linear interpolation between two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec2} out\n */\n\nexport function lerp(out, a, b, t) {\n var ax = a[0],\n ay = a[1];\n out[0] = ax + t * (b[0] - ax);\n out[1] = ay + t * (b[1] - ay);\n return out;\n}\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec2} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec2} out\n */\n\nexport function random(out, scale) {\n scale = scale || 1.0;\n var r = glMatrix.RANDOM() * 2.0 * Math.PI;\n out[0] = Math.cos(r) * scale;\n out[1] = Math.sin(r) * scale;\n return out;\n}\n/**\n * Transforms the vec2 with a mat2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to transform\n * @param {ReadonlyMat2} m matrix to transform with\n * @returns {vec2} out\n */\n\nexport function transformMat2(out, a, m) {\n var x = a[0],\n y = a[1];\n out[0] = m[0] * x + m[2] * y;\n out[1] = m[1] * x + m[3] * y;\n return out;\n}\n/**\n * Transforms the vec2 with a mat2d\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to transform\n * @param {ReadonlyMat2d} m matrix to transform with\n * @returns {vec2} out\n */\n\nexport function transformMat2d(out, a, m) {\n var x = a[0],\n y = a[1];\n out[0] = m[0] * x + m[2] * y + m[4];\n out[1] = m[1] * x + m[3] * y + m[5];\n return out;\n}\n/**\n * Transforms the vec2 with a mat3\n * 3rd vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to transform\n * @param {ReadonlyMat3} m matrix to transform with\n * @returns {vec2} out\n */\n\nexport function transformMat3(out, a, m) {\n var x = a[0],\n y = a[1];\n out[0] = m[0] * x + m[3] * y + m[6];\n out[1] = m[1] * x + m[4] * y + m[7];\n return out;\n}\n/**\n * Transforms the vec2 with a mat4\n * 3rd vector component is implicitly '0'\n * 4th vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to transform\n * @param {ReadonlyMat4} m matrix to transform with\n * @returns {vec2} out\n */\n\nexport function transformMat4(out, a, m) {\n var x = a[0];\n var y = a[1];\n out[0] = m[0] * x + m[4] * y + m[12];\n out[1] = m[1] * x + m[5] * y + m[13];\n return out;\n}\n/**\n * Rotate a 2D vector\n * @param {vec2} out The receiving vec2\n * @param {ReadonlyVec2} a The vec2 point to rotate\n * @param {ReadonlyVec2} b The origin of the rotation\n * @param {Number} rad The angle of rotation in radians\n * @returns {vec2} out\n */\n\nexport function rotate(out, a, b, rad) {\n //Translate point to the origin\n var p0 = a[0] - b[0],\n p1 = a[1] - b[1],\n sinC = Math.sin(rad),\n cosC = Math.cos(rad); //perform rotation and translate to correct position\n\n out[0] = p0 * cosC - p1 * sinC + b[0];\n out[1] = p0 * sinC + p1 * cosC + b[1];\n return out;\n}\n/**\n * Get the angle between two 2D vectors\n * @param {ReadonlyVec2} a The first operand\n * @param {ReadonlyVec2} b The second operand\n * @returns {Number} The angle in radians\n */\n\nexport function angle(a, b) {\n var x1 = a[0],\n y1 = a[1],\n x2 = b[0],\n y2 = b[1],\n // mag is the product of the magnitudes of a and b\n mag = Math.sqrt(x1 * x1 + y1 * y1) * Math.sqrt(x2 * x2 + y2 * y2),\n // mag &&.. short circuits if mag == 0\n cosine = mag && (x1 * x2 + y1 * y2) / mag; // Math.min(Math.max(cosine, -1), 1) clamps the cosine between -1 and 1\n\n return Math.acos(Math.min(Math.max(cosine, -1), 1));\n}\n/**\n * Set the components of a vec2 to zero\n *\n * @param {vec2} out the receiving vector\n * @returns {vec2} out\n */\n\nexport function zero(out) {\n out[0] = 0.0;\n out[1] = 0.0;\n return out;\n}\n/**\n * Returns a string representation of a vector\n *\n * @param {ReadonlyVec2} a vector to represent as a string\n * @returns {String} string representation of the vector\n */\n\nexport function str(a) {\n return \"vec2(\" + a[0] + \", \" + a[1] + \")\";\n}\n/**\n * Returns whether or not the vectors exactly have the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyVec2} a The first vector.\n * @param {ReadonlyVec2} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1];\n}\n/**\n * Returns whether or not the vectors have approximately the same elements in the same position.\n *\n * @param {ReadonlyVec2} a The first vector.\n * @param {ReadonlyVec2} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1];\n var b0 = b[0],\n b1 = b[1];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1));\n}\n/**\n * Alias for {@link vec2.length}\n * @function\n */\n\nexport var len = length;\n/**\n * Alias for {@link vec2.subtract}\n * @function\n */\n\nexport var sub = subtract;\n/**\n * Alias for {@link vec2.multiply}\n * @function\n */\n\nexport var mul = multiply;\n/**\n * Alias for {@link vec2.divide}\n * @function\n */\n\nexport var div = divide;\n/**\n * Alias for {@link vec2.distance}\n * @function\n */\n\nexport var dist = distance;\n/**\n * Alias for {@link vec2.squaredDistance}\n * @function\n */\n\nexport var sqrDist = squaredDistance;\n/**\n * Alias for {@link vec2.squaredLength}\n * @function\n */\n\nexport var sqrLen = squaredLength;\n/**\n * Perform some operation over an array of vec2s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec2. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\n\nexport var forEach = function () {\n var vec = create();\n return function (a, stride, offset, count, fn, arg) {\n var i, l;\n\n if (!stride) {\n stride = 2;\n }\n\n if (!offset) {\n offset = 0;\n }\n\n if (count) {\n l = Math.min(count * stride + offset, a.length);\n } else {\n l = a.length;\n }\n\n for (i = offset; i < l; i += stride) {\n vec[0] = a[i];\n vec[1] = a[i + 1];\n fn(vec, vec, arg);\n a[i] = vec[0];\n a[i + 1] = vec[1];\n }\n\n return a;\n };\n}();","import type {SpriteSpecification} from '@maplibre/maplibre-gl-style-spec';\n\n/**\n * Takes a SpriteSpecification value and returns it in its array form. If `undefined` is passed as an input value, an\n * empty array is returned.\n * duplicated entries with identical id/url will be removed in returned array\n * @param sprite - optional sprite to coerce\n * @returns an empty array in case `undefined` is passed; id-url pairs otherwise\n */\nexport function coerceSpriteToArray(sprite?: SpriteSpecification): {id: string; url: string}[] {\n const resultArray: {id: string; url: string}[] = [];\n\n if (typeof sprite === 'string') {\n resultArray.push({id: 'default', url: sprite});\n } else if (sprite && sprite.length > 0) {\n const dedupArray: string[] = [];\n for (const {id, url} of sprite) {\n const key = `${id}${url}`;\n if (dedupArray.indexOf(key) === -1) {\n dedupArray.push(key);\n resultArray.push({id, url});\n }\n }\n }\n\n return resultArray;\n\n}\n","import {GetResourceResponse, getJSON} from '../util/ajax';\nimport {ImageRequest} from '../util/image_request';\nimport {ResourceType} from '../util/request_manager';\n\nimport {browser} from '../util/browser';\nimport {coerceSpriteToArray} from '../util/style';\n\nimport type {SpriteSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {SpriteJSON, StyleImage} from './style_image';\nimport type {RequestManager} from '../util/request_manager';\n\nexport type LoadSpriteResult = {\n [spriteName: string]: {\n [id: string]: StyleImage;\n };\n}\n\nexport function normalizeSpriteURL(url: string, format: string, extension: string): string {\n const split = url.split('?');\n split[0] += `${format}${extension}`;\n return split.join('?');\n}\n\nexport async function loadSprite(\n originalSprite: SpriteSpecification,\n requestManager: RequestManager,\n pixelRatio: number,\n abortController: AbortController,\n): Promise {\n const spriteArray = coerceSpriteToArray(originalSprite);\n const format = pixelRatio > 1 ? '@2x' : '';\n\n const jsonsMap: {[id: string]: Promise>} = {};\n const imagesMap: {[id: string]: Promise>} = {};\n\n for (const {id, url} of spriteArray) {\n const jsonRequestParameters = requestManager.transformRequest(normalizeSpriteURL(url, format, '.json'), ResourceType.SpriteJSON);\n jsonsMap[id] = getJSON(jsonRequestParameters, abortController);\n\n const imageRequestParameters = requestManager.transformRequest(normalizeSpriteURL(url, format, '.png'), ResourceType.SpriteImage);\n imagesMap[id] = ImageRequest.getImage(imageRequestParameters, abortController);\n }\n\n await Promise.all([...Object.values(jsonsMap), ...Object.values(imagesMap)]);\n return doOnceCompleted(jsonsMap, imagesMap);\n}\n\n/**\n * @param jsonsMap - JSON data map\n * @param imagesMap - image data map\n */\nasync function doOnceCompleted(\n jsonsMap:{[id: string]: Promise>},\n imagesMap:{[id: string]: Promise>}): Promise {\n\n const result = {} as {[spriteName: string]: {[id: string]: StyleImage}};\n for (const spriteName in jsonsMap) {\n result[spriteName] = {};\n\n const context = browser.getImageCanvasContext((await imagesMap[spriteName]).data);\n const json = (await jsonsMap[spriteName]).data;\n\n for (const id in json) {\n const {width, height, x, y, sdf, pixelRatio, stretchX, stretchY, content, textFitWidth, textFitHeight} = json[id];\n const spriteData = {width, height, x, y, context};\n result[spriteName][id] = {data: null, pixelRatio, sdf, stretchX, stretchY, content, textFitWidth, textFitHeight, spriteData};\n }\n }\n\n return result;\n}\n","import type {Context} from '../gl/context';\nimport type {RGBAImage, AlphaImage} from '../util/image';\nimport {isImageBitmap} from '../util/util';\n\nexport type TextureFormat = WebGLRenderingContextBase['RGBA'] | WebGLRenderingContextBase['ALPHA'];\nexport type TextureFilter = WebGLRenderingContextBase['LINEAR'] | WebGLRenderingContextBase['LINEAR_MIPMAP_NEAREST'] | WebGLRenderingContextBase['NEAREST'];\nexport type TextureWrap = WebGLRenderingContextBase['REPEAT'] | WebGLRenderingContextBase['CLAMP_TO_EDGE'] | WebGLRenderingContextBase['MIRRORED_REPEAT'];\n\ntype EmptyImage = {\n width: number;\n height: number;\n data: null;\n};\n\ntype DataTextureImage = RGBAImage | AlphaImage | EmptyImage;\nexport type TextureImage = TexImageSource | DataTextureImage;\n\n/**\n * @internal\n * A `Texture` GL related object\n */\nexport class Texture {\n context: Context;\n size: [number, number];\n texture: WebGLTexture;\n format: TextureFormat;\n filter: TextureFilter;\n wrap: TextureWrap;\n useMipmap: boolean;\n\n constructor(context: Context, image: TextureImage, format: TextureFormat, options?: {\n premultiply?: boolean;\n useMipmap?: boolean;\n } | null) {\n this.context = context;\n this.format = format;\n this.texture = context.gl.createTexture();\n this.update(image, options);\n }\n\n update(image: TextureImage, options?: {\n premultiply?: boolean;\n useMipmap?: boolean;\n } | null, position?: {\n x: number;\n y: number;\n }) {\n const {width, height} = image as {width: number; height: number};\n const resize = (!this.size || this.size[0] !== width || this.size[1] !== height) && !position;\n const {context} = this;\n const {gl} = context;\n\n this.useMipmap = Boolean(options && options.useMipmap);\n gl.bindTexture(gl.TEXTURE_2D, this.texture);\n\n context.pixelStoreUnpackFlipY.set(false);\n context.pixelStoreUnpack.set(1);\n context.pixelStoreUnpackPremultiplyAlpha.set(this.format === gl.RGBA && (!options || options.premultiply !== false));\n\n if (resize) {\n this.size = [width, height];\n\n if (image instanceof HTMLImageElement || image instanceof HTMLCanvasElement || image instanceof HTMLVideoElement || image instanceof ImageData || isImageBitmap(image)) {\n gl.texImage2D(gl.TEXTURE_2D, 0, this.format, this.format, gl.UNSIGNED_BYTE, image);\n } else {\n gl.texImage2D(gl.TEXTURE_2D, 0, this.format, width, height, 0, this.format, gl.UNSIGNED_BYTE, (image as DataTextureImage).data);\n }\n\n } else {\n const {x, y} = position || {x: 0, y: 0};\n if (image instanceof HTMLImageElement || image instanceof HTMLCanvasElement || image instanceof HTMLVideoElement || image instanceof ImageData || isImageBitmap(image)) {\n gl.texSubImage2D(gl.TEXTURE_2D, 0, x, y, gl.RGBA, gl.UNSIGNED_BYTE, image);\n } else {\n gl.texSubImage2D(gl.TEXTURE_2D, 0, x, y, width, height, gl.RGBA, gl.UNSIGNED_BYTE, (image as DataTextureImage).data);\n }\n }\n\n if (this.useMipmap && this.isSizePowerOfTwo()) {\n gl.generateMipmap(gl.TEXTURE_2D);\n }\n }\n\n bind(filter: TextureFilter, wrap: TextureWrap, minFilter?: TextureFilter | null) {\n const {context} = this;\n const {gl} = context;\n gl.bindTexture(gl.TEXTURE_2D, this.texture);\n\n if (minFilter === gl.LINEAR_MIPMAP_NEAREST && !this.isSizePowerOfTwo()) {\n minFilter = gl.LINEAR;\n }\n\n if (filter !== this.filter) {\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, filter);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, minFilter || filter);\n this.filter = filter;\n }\n\n if (wrap !== this.wrap) {\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, wrap);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, wrap);\n this.wrap = wrap;\n }\n }\n\n isSizePowerOfTwo() {\n return this.size[0] === this.size[1] && (Math.log(this.size[0]) / Math.LN2) % 1 === 0;\n }\n\n destroy() {\n const {gl} = this.context;\n gl.deleteTexture(this.texture);\n this.texture = null;\n }\n}\n","import {RGBAImage} from '../util/image';\n\nimport type {Map} from '../ui/map';\n\nexport type SpriteJSON = {[id: string]: StyleImageMetadata & {\n width: number;\n height: number;\n x: number;\n y: number;\n};}\n\n/**\n * The sprite data\n */\nexport type SpriteOnDemandStyleImage = {\n width: number;\n height: number;\n x: number;\n y: number;\n context: CanvasRenderingContext2D;\n};\n\n/**\n * The style's image metadata\n */\nexport type StyleImageData = {\n data: RGBAImage;\n version?: number;\n hasRenderCallback?: boolean;\n userImage?: StyleImageInterface;\n spriteData?: SpriteOnDemandStyleImage;\n};\n\n/**\n * Enumeration of possible values for StyleImageMetadata.textFitWidth and textFitHeight.\n */\nexport const enum TextFit {\n /**\n * The image will be resized on the specified axis to tightly fit the content rectangle to target text.\n * This is the same as not being defined.\n */\n stretchOrShrink = 'stretchOrShrink',\n /**\n * The image will be resized on the specified axis to fit the content rectangle to the target text, but will not\n * fall below the aspect ratio of the original content rectangle if the other axis is set to proportional.\n */\n stretchOnly = 'stretchOnly',\n /**\n * The image will be resized on the specified axis to fit the content rectangle to the target text and\n * will resize the other axis to maintain the aspect ratio of the content rectangle.\n */\n proportional = 'proportional'\n}\n\n/**\n * The style's image metadata\n */\nexport type StyleImageMetadata = {\n /**\n * The ratio of pixels in the image to physical pixels on the screen\n */\n pixelRatio: number;\n /**\n * Whether the image should be interpreted as an SDF image\n */\n sdf: boolean;\n /**\n * If `icon-text-fit` is used in a layer with this image, this option defines the part(s) of the image that can be stretched horizontally.\n */\n stretchX?: Array<[number, number]>;\n /**\n * If `icon-text-fit` is used in a layer with this image, this option defines the part(s) of the image that can be stretched vertically.\n */\n stretchY?: Array<[number, number]>;\n /**\n * If `icon-text-fit` is used in a layer with this image, this option defines the part of the image that can be covered by the content in `text-field`.\n */\n content?: [number, number, number, number];\n /**\n * If `icon-text-fit` is used in a layer with this image, this option defines constraints on the horizontal scaling of the image.\n */\n textFitWidth?: TextFit;\n /**\n * If `icon-text-fit` is used in a layer with this image, this option defines constraints on the vertical scaling of the image.\n */\n textFitHeight?: TextFit;\n};\n\n/**\n * the style's image, including data and metedata\n */\nexport type StyleImage = StyleImageData & StyleImageMetadata;\n\n/**\n * Interface for dynamically generated style images. This is a specification for\n * implementers to model: it is not an exported method or class.\n *\n * Images implementing this interface can be redrawn for every frame. They can be used to animate\n * icons and patterns or make them respond to user input. Style images can implement a\n * {@link StyleImageInterface#render} method. The method is called every frame and\n * can be used to update the image.\n *\n * @see [Add an animated icon to the map.](https://maplibre.org/maplibre-gl-js/docs/examples/add-image-animated/)\n *\n * @example\n * ```ts\n * let flashingSquare = {\n * width: 64,\n * height: 64,\n * data: new Uint8Array(64 * 64 * 4),\n *\n * onAdd: function(map) {\n * this.map = map;\n * },\n *\n * render: function() {\n * // keep repainting while the icon is on the map\n * this.map.triggerRepaint();\n *\n * // alternate between black and white based on the time\n * let value = Math.round(Date.now() / 1000) % 2 === 0 ? 255 : 0;\n *\n * // check if image needs to be changed\n * if (value !== this.previousValue) {\n * this.previousValue = value;\n *\n * let bytesPerPixel = 4;\n * for (let x = 0; x < this.width; x++) {\n * for (let y = 0; y < this.height; y++) {\n * let offset = (y * this.width + x) * bytesPerPixel;\n * this.data[offset + 0] = value;\n * this.data[offset + 1] = value;\n * this.data[offset + 2] = value;\n * this.data[offset + 3] = 255;\n * }\n * }\n *\n * // return true to indicate that the image changed\n * return true;\n * }\n * }\n * }\n *\n * map.addImage('flashing_square', flashingSquare);\n * ```\n */\n\nexport interface StyleImageInterface {\n width: number;\n height: number;\n data: Uint8Array | Uint8ClampedArray;\n /**\n * This method is called once before every frame where the icon will be used.\n * The method can optionally update the image's `data` member with a new image.\n *\n * If the method updates the image it must return `true` to commit the change.\n * If the method returns `false` or nothing the image is assumed to not have changed.\n *\n * If updates are infrequent it maybe easier to use {@link Map#updateImage} to update\n * the image instead of implementing this method.\n *\n * @returns `true` if this method updated the image. `false` if the image was not changed.\n */\n render?: () => boolean;\n /**\n * Optional method called when the layer has been added to the Map with {@link Map#addImage}.\n *\n * @param map - The Map this custom layer was just added to.\n */\n onAdd?: (map: Map, id: string) => void;\n /**\n * Optional method called when the icon is removed from the map with {@link Map#removeImage}.\n * This gives the image a chance to clean up resources and event listeners.\n */\n onRemove?: () => void;\n}\n\nexport function renderStyleImage(image: StyleImage) {\n const {userImage} = image;\n if (userImage && userImage.render) {\n const updated = userImage.render();\n if (updated) {\n image.data.replace(new Uint8Array(userImage.data.buffer));\n return true;\n }\n }\n return false;\n}\n","/* eslint-disable key-spacing */\nimport potpack from 'potpack';\n\nimport {Event, ErrorEvent, Evented} from '../util/evented';\nimport {RGBAImage} from '../util/image';\nimport {ImagePosition} from './image_atlas';\nimport {Texture} from './texture';\nimport {renderStyleImage} from '../style/style_image';\nimport {warnOnce} from '../util/util';\n\nimport type {StyleImage} from '../style/style_image';\nimport type {Context} from '../gl/context';\nimport type {PotpackBox} from 'potpack';\nimport type {GetImagesResponse} from '../util/actor_messages';\n\ntype Pattern = {\n bin: PotpackBox;\n position: ImagePosition;\n};\n\n/**\n * When copied into the atlas texture, image data is padded by one pixel on each side. Icon\n * images are padded with fully transparent pixels, while pattern images are padded with a\n * copy of the image data wrapped from the opposite side. In both cases, this ensures the\n * correct behavior of GL_LINEAR texture sampling mode.\n */\nconst padding = 1;\n\n/**\n * ImageManager does three things:\n *\n * 1. Tracks requests for icon images from tile workers and sends responses when the requests are fulfilled.\n * 2. Builds a texture atlas for pattern images.\n * 3. Rerenders renderable images once per frame\n *\n * These are disparate responsibilities and should eventually be handled by different classes. When we implement\n * data-driven support for `*-pattern`, we'll likely use per-bucket pattern atlases, and that would be a good time\n * to refactor this.\n*/\nexport class ImageManager extends Evented {\n images: {[_: string]: StyleImage};\n updatedImages: {[_: string]: boolean};\n callbackDispatchedThisFrame: {[_: string]: boolean};\n loaded: boolean;\n /**\n * This is used to track requests for images that are not yet available. When the image is loaded,\n * the requestors will be notified.\n */\n requestors: Array<{\n ids: Array;\n promiseResolve: (value: GetImagesResponse) => void;\n }>;\n\n patterns: {[_: string]: Pattern};\n atlasImage: RGBAImage;\n atlasTexture: Texture;\n dirty: boolean;\n\n constructor() {\n super();\n this.images = {};\n this.updatedImages = {};\n this.callbackDispatchedThisFrame = {};\n this.loaded = false;\n this.requestors = [];\n\n this.patterns = {};\n this.atlasImage = new RGBAImage({width: 1, height: 1});\n this.dirty = true;\n }\n\n isLoaded() {\n return this.loaded;\n }\n\n setLoaded(loaded: boolean) {\n if (this.loaded === loaded) {\n return;\n }\n\n this.loaded = loaded;\n\n if (loaded) {\n for (const {ids, promiseResolve} of this.requestors) {\n promiseResolve(this._getImagesForIds(ids));\n }\n this.requestors = [];\n }\n }\n\n getImage(id: string): StyleImage {\n const image = this.images[id];\n\n // Extract sprite image data on demand\n if (image && !image.data && image.spriteData) {\n const spriteData = image.spriteData;\n image.data = new RGBAImage({\n width: spriteData.width,\n height: spriteData.height\n }, spriteData.context.getImageData(\n spriteData.x,\n spriteData.y,\n spriteData.width,\n spriteData.height).data);\n image.spriteData = null;\n }\n\n return image;\n }\n\n addImage(id: string, image: StyleImage) {\n if (this.images[id]) throw new Error(`Image id ${id} already exist, use updateImage instead`);\n if (this._validate(id, image)) {\n this.images[id] = image;\n }\n }\n\n _validate(id: string, image: StyleImage) {\n let valid = true;\n const data = image.data || image.spriteData;\n if (!this._validateStretch(image.stretchX, data && data.width)) {\n this.fire(new ErrorEvent(new Error(`Image \"${id}\" has invalid \"stretchX\" value`)));\n valid = false;\n }\n if (!this._validateStretch(image.stretchY, data && data.height)) {\n this.fire(new ErrorEvent(new Error(`Image \"${id}\" has invalid \"stretchY\" value`)));\n valid = false;\n }\n if (!this._validateContent(image.content, image)) {\n this.fire(new ErrorEvent(new Error(`Image \"${id}\" has invalid \"content\" value`)));\n valid = false;\n }\n return valid;\n }\n\n _validateStretch(stretch: Array<[number, number]>, size: number) {\n if (!stretch) return true;\n let last = 0;\n for (const part of stretch) {\n if (part[0] < last || part[1] < part[0] || size < part[1]) return false;\n last = part[1];\n }\n return true;\n }\n\n _validateContent(content: [number, number, number, number], image: StyleImage) {\n if (!content) return true;\n if (content.length !== 4) return false;\n const spriteData = image.spriteData;\n const width = (spriteData && spriteData.width) || image.data.width;\n const height = (spriteData && spriteData.height) || image.data.height;\n if (content[0] < 0 || width < content[0]) return false;\n if (content[1] < 0 || height < content[1]) return false;\n if (content[2] < 0 || width < content[2]) return false;\n if (content[3] < 0 || height < content[3]) return false;\n if (content[2] < content[0]) return false;\n if (content[3] < content[1]) return false;\n return true;\n }\n\n updateImage(id: string, image: StyleImage, validate = true) {\n const oldImage = this.getImage(id);\n if (validate && (oldImage.data.width !== image.data.width || oldImage.data.height !== image.data.height)) {\n throw new Error(`size mismatch between old image (${oldImage.data.width}x${oldImage.data.height}) and new image (${image.data.width}x${image.data.height}).`);\n }\n image.version = oldImage.version + 1;\n this.images[id] = image;\n this.updatedImages[id] = true;\n }\n\n removeImage(id: string) {\n const image = this.images[id];\n delete this.images[id];\n delete this.patterns[id];\n\n if (image.userImage && image.userImage.onRemove) {\n image.userImage.onRemove();\n }\n }\n\n listImages(): Array {\n return Object.keys(this.images);\n }\n\n getImages(ids: Array): Promise {\n return new Promise((resolve, _reject) => {\n // If the sprite has been loaded, or if all the icon dependencies are already present\n // (i.e. if they've been added via runtime styling), then notify the requestor immediately.\n // Otherwise, delay notification until the sprite is loaded. At that point, if any of the\n // dependencies are still unavailable, we'll just assume they are permanently missing.\n let hasAllDependencies = true;\n if (!this.isLoaded()) {\n for (const id of ids) {\n if (!this.images[id]) {\n hasAllDependencies = false;\n }\n }\n }\n if (this.isLoaded() || hasAllDependencies) {\n resolve(this._getImagesForIds(ids));\n } else {\n this.requestors.push({ids, promiseResolve: resolve});\n }\n });\n }\n\n _getImagesForIds(ids: Array): GetImagesResponse {\n const response: GetImagesResponse = {};\n\n for (const id of ids) {\n let image = this.getImage(id);\n\n if (!image) {\n this.fire(new Event('styleimagemissing', {id}));\n //Try to acquire image again in case styleimagemissing has populated it\n image = this.getImage(id);\n }\n\n if (image) {\n // Clone the image so that our own copy of its ArrayBuffer doesn't get transferred.\n response[id] = {\n data: image.data.clone(),\n pixelRatio: image.pixelRatio,\n sdf: image.sdf,\n version: image.version,\n stretchX: image.stretchX,\n stretchY: image.stretchY,\n content: image.content,\n textFitWidth: image.textFitWidth,\n textFitHeight: image.textFitHeight,\n hasRenderCallback: Boolean(image.userImage && image.userImage.render)\n };\n } else {\n warnOnce(`Image \"${id}\" could not be loaded. Please make sure you have added the image with map.addImage() or a \"sprite\" property in your style. You can provide missing images by listening for the \"styleimagemissing\" map event.`);\n }\n }\n return response;\n }\n\n // Pattern stuff\n\n getPixelSize() {\n const {width, height} = this.atlasImage;\n return {width, height};\n }\n\n getPattern(id: string): ImagePosition {\n const pattern = this.patterns[id];\n\n const image = this.getImage(id);\n if (!image) {\n return null;\n }\n\n if (pattern && pattern.position.version === image.version) {\n return pattern.position;\n }\n\n if (!pattern) {\n const w = image.data.width + padding * 2;\n const h = image.data.height + padding * 2;\n const bin = {w, h, x: 0, y: 0};\n const position = new ImagePosition(bin, image);\n this.patterns[id] = {bin, position};\n } else {\n pattern.position.version = image.version;\n }\n\n this._updatePatternAtlas();\n\n return this.patterns[id].position;\n }\n\n bind(context: Context) {\n const gl = context.gl;\n if (!this.atlasTexture) {\n this.atlasTexture = new Texture(context, this.atlasImage, gl.RGBA);\n } else if (this.dirty) {\n this.atlasTexture.update(this.atlasImage);\n this.dirty = false;\n }\n\n this.atlasTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n }\n\n _updatePatternAtlas() {\n const bins = [];\n for (const id in this.patterns) {\n bins.push(this.patterns[id].bin);\n }\n\n const {w, h} = potpack(bins);\n\n const dst = this.atlasImage;\n dst.resize({width: w || 1, height: h || 1});\n\n for (const id in this.patterns) {\n const {bin} = this.patterns[id];\n const x = bin.x + padding;\n const y = bin.y + padding;\n const src = this.getImage(id).data;\n const w = src.width;\n const h = src.height;\n\n RGBAImage.copy(src, dst, {x: 0, y: 0}, {x, y}, {width: w, height: h});\n\n // Add 1 pixel wrapped padding on each side of the image.\n RGBAImage.copy(src, dst, {x: 0, y: h - 1}, {x, y: y - 1}, {width: w, height: 1}); // T\n RGBAImage.copy(src, dst, {x: 0, y: 0}, {x, y: y + h}, {width: w, height: 1}); // B\n RGBAImage.copy(src, dst, {x: w - 1, y: 0}, {x: x - 1, y}, {width: 1, height: h}); // L\n RGBAImage.copy(src, dst, {x: 0, y: 0}, {x: x + w, y}, {width: 1, height: h}); // R\n }\n\n this.dirty = true;\n }\n\n beginFrame() {\n this.callbackDispatchedThisFrame = {};\n }\n\n dispatchRenderCallbacks(ids: Array) {\n for (const id of ids) {\n\n // the callback for the image was already dispatched for a different frame\n if (this.callbackDispatchedThisFrame[id]) continue;\n this.callbackDispatchedThisFrame[id] = true;\n\n const image = this.getImage(id);\n if (!image) warnOnce(`Image with ID: \"${id}\" was not found`);\n\n const updated = renderStyleImage(image);\n if (updated) {\n this.updateImage(id, image);\n }\n }\n }\n}\n","import {getArrayBuffer} from '../util/ajax';\nimport {ResourceType} from '../util/request_manager';\n\nimport {parseGlyphPbf} from './parse_glyph_pbf';\n\nimport type {StyleGlyph} from './style_glyph';\nimport type {RequestManager} from '../util/request_manager';\n\nexport async function loadGlyphRange(fontstack: string,\n range: number,\n urlTemplate: string,\n requestManager: RequestManager): Promise<{[_: number]: StyleGlyph | null}> {\n const begin = range * 256;\n const end = begin + 255;\n\n const request = requestManager.transformRequest(\n urlTemplate.replace('{fontstack}', fontstack).replace('{range}', `${begin}-${end}`),\n ResourceType.Glyphs\n );\n\n const response = await getArrayBuffer(request, new AbortController());\n if (!response || !response.data) {\n throw new Error(`Could not load glyph range. range: ${range}, ${begin}-${end}`);\n }\n const glyphs = {};\n\n for (const glyph of parseGlyphPbf(response.data)) {\n glyphs[glyph.id] = glyph;\n }\n\n return glyphs;\n}\n","const INF = 1e20;\n\nexport default class TinySDF {\n constructor({\n fontSize = 24,\n buffer = 3,\n radius = 8,\n cutoff = 0.25,\n fontFamily = 'sans-serif',\n fontWeight = 'normal',\n fontStyle = 'normal'\n } = {}) {\n this.buffer = buffer;\n this.cutoff = cutoff;\n this.radius = radius;\n\n // make the canvas size big enough to both have the specified buffer around the glyph\n // for \"halo\", and account for some glyphs possibly being larger than their font size\n const size = this.size = fontSize + buffer * 4;\n\n const canvas = this._createCanvas(size);\n const ctx = this.ctx = canvas.getContext('2d', {willReadFrequently: true});\n ctx.font = `${fontStyle} ${fontWeight} ${fontSize}px ${fontFamily}`;\n\n ctx.textBaseline = 'alphabetic';\n ctx.textAlign = 'left'; // Necessary so that RTL text doesn't have different alignment\n ctx.fillStyle = 'black';\n\n // temporary arrays for the distance transform\n this.gridOuter = new Float64Array(size * size);\n this.gridInner = new Float64Array(size * size);\n this.f = new Float64Array(size);\n this.z = new Float64Array(size + 1);\n this.v = new Uint16Array(size);\n }\n\n _createCanvas(size) {\n const canvas = document.createElement('canvas');\n canvas.width = canvas.height = size;\n return canvas;\n }\n\n draw(char) {\n const {\n width: glyphAdvance,\n actualBoundingBoxAscent,\n actualBoundingBoxDescent,\n actualBoundingBoxLeft,\n actualBoundingBoxRight\n } = this.ctx.measureText(char);\n\n // The integer/pixel part of the top alignment is encoded in metrics.glyphTop\n // The remainder is implicitly encoded in the rasterization\n const glyphTop = Math.ceil(actualBoundingBoxAscent);\n const glyphLeft = 0;\n\n // If the glyph overflows the canvas size, it will be clipped at the bottom/right\n const glyphWidth = Math.max(0, Math.min(this.size - this.buffer, Math.ceil(actualBoundingBoxRight - actualBoundingBoxLeft)));\n const glyphHeight = Math.min(this.size - this.buffer, glyphTop + Math.ceil(actualBoundingBoxDescent));\n\n const width = glyphWidth + 2 * this.buffer;\n const height = glyphHeight + 2 * this.buffer;\n\n const len = Math.max(width * height, 0);\n const data = new Uint8ClampedArray(len);\n const glyph = {data, width, height, glyphWidth, glyphHeight, glyphTop, glyphLeft, glyphAdvance};\n if (glyphWidth === 0 || glyphHeight === 0) return glyph;\n\n const {ctx, buffer, gridInner, gridOuter} = this;\n ctx.clearRect(buffer, buffer, glyphWidth, glyphHeight);\n ctx.fillText(char, buffer, buffer + glyphTop);\n const imgData = ctx.getImageData(buffer, buffer, glyphWidth, glyphHeight);\n\n // Initialize grids outside the glyph range to alpha 0\n gridOuter.fill(INF, 0, len);\n gridInner.fill(0, 0, len);\n\n for (let y = 0; y < glyphHeight; y++) {\n for (let x = 0; x < glyphWidth; x++) {\n const a = imgData.data[4 * (y * glyphWidth + x) + 3] / 255; // alpha value\n if (a === 0) continue; // empty pixels\n\n const j = (y + buffer) * width + x + buffer;\n\n if (a === 1) { // fully drawn pixels\n gridOuter[j] = 0;\n gridInner[j] = INF;\n\n } else { // aliased pixels\n const d = 0.5 - a;\n gridOuter[j] = d > 0 ? d * d : 0;\n gridInner[j] = d < 0 ? d * d : 0;\n }\n }\n }\n\n edt(gridOuter, 0, 0, width, height, width, this.f, this.v, this.z);\n edt(gridInner, buffer, buffer, glyphWidth, glyphHeight, width, this.f, this.v, this.z);\n\n for (let i = 0; i < len; i++) {\n const d = Math.sqrt(gridOuter[i]) - Math.sqrt(gridInner[i]);\n data[i] = Math.round(255 - 255 * (d / this.radius + this.cutoff));\n }\n\n return glyph;\n }\n}\n\n// 2D Euclidean squared distance transform by Felzenszwalb & Huttenlocher https://cs.brown.edu/~pff/papers/dt-final.pdf\nfunction edt(data, x0, y0, width, height, gridSize, f, v, z) {\n for (let x = x0; x < x0 + width; x++) edt1d(data, y0 * gridSize + x, gridSize, height, f, v, z);\n for (let y = y0; y < y0 + height; y++) edt1d(data, y * gridSize + x0, 1, width, f, v, z);\n}\n\n// 1D squared distance transform\nfunction edt1d(grid, offset, stride, length, f, v, z) {\n v[0] = 0;\n z[0] = -INF;\n z[1] = INF;\n f[0] = grid[offset];\n\n for (let q = 1, k = 0, s = 0; q < length; q++) {\n f[q] = grid[offset + q * stride];\n const q2 = q * q;\n do {\n const r = v[k];\n s = (f[q] - f[r] + q2 - r * r) / (q - r) / 2;\n } while (s <= z[k] && --k > -1);\n\n k++;\n v[k] = q;\n z[k] = s;\n z[k + 1] = INF;\n }\n\n for (let q = 0, k = 0; q < length; q++) {\n while (z[k + 1] < q) k++;\n const r = v[k];\n const qr = q - r;\n grid[offset + q * stride] = f[r] + qr * qr;\n }\n}\n","import {loadGlyphRange} from '../style/load_glyph_range';\n\nimport TinySDF from '@mapbox/tiny-sdf';\nimport {AlphaImage} from '../util/image';\n\nimport type {StyleGlyph} from '../style/style_glyph';\nimport type {RequestManager} from '../util/request_manager';\nimport type {GetGlyphsResponse} from '../util/actor_messages';\n\ntype Entry = {\n // null means we've requested the range, but the glyph wasn't included in the result.\n glyphs: {\n [id: number]: StyleGlyph | null;\n };\n requests: {\n [range: number]: Promise<{[_: number]: StyleGlyph | null}>;\n };\n ranges: {\n [range: number]: boolean | null;\n };\n tinySDF?: TinySDF;\n};\n\nexport class GlyphManager {\n requestManager: RequestManager;\n localIdeographFontFamily: string | false;\n entries: {[stack: string]: Entry};\n url: string;\n\n // exposed as statics to enable stubbing in unit tests\n static loadGlyphRange = loadGlyphRange;\n static TinySDF = TinySDF;\n\n constructor(requestManager: RequestManager, localIdeographFontFamily?: string | false) {\n this.requestManager = requestManager;\n this.localIdeographFontFamily = localIdeographFontFamily;\n this.entries = {};\n }\n\n setURL(url?: string | null) {\n this.url = url;\n }\n\n async getGlyphs(glyphs: {[stack: string]: Array}): Promise {\n const glyphsPromises: Promise<{stack: string; id: number; glyph: StyleGlyph}>[] = [];\n\n for (const stack in glyphs) {\n for (const id of glyphs[stack]) {\n glyphsPromises.push(this._getAndCacheGlyphsPromise(stack, id));\n }\n }\n\n const updatedGlyphs = await Promise.all(glyphsPromises);\n\n const result: GetGlyphsResponse = {};\n\n for (const {stack, id, glyph} of updatedGlyphs) {\n if (!result[stack]) {\n result[stack] = {};\n }\n // Clone the glyph so that our own copy of its ArrayBuffer doesn't get transferred.\n result[stack][id] = glyph && {\n id: glyph.id,\n bitmap: glyph.bitmap.clone(),\n metrics: glyph.metrics\n };\n }\n\n return result;\n }\n\n async _getAndCacheGlyphsPromise(stack: string, id: number): Promise<{stack: string; id: number; glyph: StyleGlyph}> {\n let entry = this.entries[stack];\n if (!entry) {\n entry = this.entries[stack] = {\n glyphs: {},\n requests: {},\n ranges: {}\n };\n }\n\n let glyph = entry.glyphs[id];\n if (glyph !== undefined) {\n return {stack, id, glyph};\n }\n\n glyph = this._tinySDF(entry, stack, id);\n if (glyph) {\n entry.glyphs[id] = glyph;\n return {stack, id, glyph};\n }\n\n const range = Math.floor(id / 256);\n if (range * 256 > 65535) {\n throw new Error('glyphs > 65535 not supported');\n }\n\n if (entry.ranges[range]) {\n return {stack, id, glyph};\n }\n\n if (!this.url) {\n throw new Error('glyphsUrl is not set');\n }\n\n if (!entry.requests[range]) {\n const promise = GlyphManager.loadGlyphRange(stack, range, this.url, this.requestManager);\n entry.requests[range] = promise;\n }\n\n const response = await entry.requests[range];\n for (const id in response) {\n if (!this._doesCharSupportLocalGlyph(+id)) {\n entry.glyphs[+id] = response[+id];\n }\n }\n entry.ranges[range] = true;\n return {stack, id, glyph: response[id] || null};\n }\n\n _doesCharSupportLocalGlyph(id: number): boolean {\n // The CJK Unified Ideographs blocks and Hangul Syllables blocks are\n // spread across many glyph PBFs and are typically accessed very\n // randomly. Preferring local rendering for these blocks reduces\n // wasteful bandwidth consumption. For visual consistency within CJKV\n // text, also include any other CJKV or siniform ideograph or hangul,\n // hiragana, or katakana character.\n return !!this.localIdeographFontFamily &&\n /\\p{Ideo}|\\p{sc=Hang}|\\p{sc=Hira}|\\p{sc=Kana}/u.test(String.fromCodePoint(id));\n }\n\n _tinySDF(entry: Entry, stack: string, id: number): StyleGlyph {\n const fontFamily = this.localIdeographFontFamily;\n if (!fontFamily) {\n return;\n }\n\n if (!this._doesCharSupportLocalGlyph(id)) {\n return;\n }\n\n // Client-generated glyphs are rendered at 2x texture scale,\n // because CJK glyphs are more detailed than others.\n const textureScale = 2;\n\n let tinySDF = entry.tinySDF;\n if (!tinySDF) {\n let fontWeight = '400';\n if (/bold/i.test(stack)) {\n fontWeight = '900';\n } else if (/medium/i.test(stack)) {\n fontWeight = '500';\n } else if (/light/i.test(stack)) {\n fontWeight = '200';\n }\n tinySDF = entry.tinySDF = new GlyphManager.TinySDF({\n fontSize: 24 * textureScale,\n buffer: 3 * textureScale,\n radius: 8 * textureScale,\n cutoff: 0.25,\n fontFamily,\n fontWeight\n });\n }\n\n const char = tinySDF.draw(String.fromCharCode(id));\n\n /**\n * TinySDF's \"top\" is the distance from the alphabetic baseline to the top of the glyph.\n * Server-generated fonts specify \"top\" relative to an origin above the em box (the origin\n * comes from FreeType, but I'm unclear on exactly how it's derived)\n * ref: https://github.com/mapbox/sdf-glyph-foundry\n *\n * Server fonts don't yet include baseline information, so we can't line up exactly with them\n * (and they don't line up with each other)\n * ref: https://github.com/mapbox/node-fontnik/pull/160\n *\n * To approximately align TinySDF glyphs with server-provided glyphs, we use this baseline adjustment\n * factor calibrated to be in between DIN Pro and Arial Unicode (but closer to Arial Unicode)\n */\n const topAdjustment = 27.5;\n\n const leftAdjustment = 0.5;\n\n return {\n id,\n bitmap: new AlphaImage({width: char.width || 30 * textureScale, height: char.height || 30 * textureScale}, char.data),\n metrics: {\n width: char.glyphWidth / textureScale || 24,\n height: char.glyphHeight / textureScale || 24,\n left: (char.glyphLeft / textureScale + leftAdjustment) || 0,\n top: char.glyphTop / textureScale - topAdjustment || -8,\n advance: char.glyphAdvance / textureScale || 24,\n isDoubleResolution: true\n }\n };\n }\n}\n","import {interpolates, Color, latest as styleSpec} from '@maplibre/maplibre-gl-style-spec';\n\nimport {sphericalToCartesian} from '../util/util';\nimport {Evented} from '../util/evented';\nimport {\n validateStyle,\n validateLight,\n emitValidationErrors\n} from './validate_style';\n\nimport type {StylePropertySpecification, LightSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {EvaluationParameters} from './evaluation_parameters';\nimport type {StyleSetterOptions} from '../style/style';\nimport {Properties, Transitionable, Transitioning, PossiblyEvaluated, DataConstantProperty} from './properties';\n\nimport type {\n Property,\n PropertyValue,\n TransitionParameters\n} from './properties';\n\ntype LightPosition = {\n x: number;\n y: number;\n z: number;\n};\n\nclass LightPositionProperty implements Property<[number, number, number], LightPosition> {\n specification: StylePropertySpecification;\n\n constructor() {\n this.specification = styleSpec.light.position as StylePropertySpecification;\n }\n\n possiblyEvaluate(\n value: PropertyValue<[number, number, number], LightPosition>,\n parameters: EvaluationParameters\n ): LightPosition {\n return sphericalToCartesian(value.expression.evaluate(parameters));\n }\n\n interpolate(a: LightPosition, b: LightPosition, t: number): LightPosition {\n return {\n x: interpolates.number(a.x, b.x, t),\n y: interpolates.number(a.y, b.y, t),\n z: interpolates.number(a.z, b.z, t),\n };\n }\n}\n\ntype LightProps = {\n 'anchor': DataConstantProperty<'map' | 'viewport'>;\n 'position': LightPositionProperty;\n 'color': DataConstantProperty;\n 'intensity': DataConstantProperty;\n};\n\ntype LightPropsPossiblyEvaluated = {\n 'anchor': 'map' | 'viewport';\n 'position': LightPosition;\n 'color': Color;\n 'intensity': number;\n};\n\nconst TRANSITION_SUFFIX = '-transition';\n\nlet lightProperties: Properties;\n\n/*\n * Represents the light used to light extruded features.\n */\nexport class Light extends Evented {\n _transitionable: Transitionable;\n _transitioning: Transitioning;\n properties: PossiblyEvaluated;\n\n constructor(lightOptions?: LightSpecification) {\n super();\n lightProperties = lightProperties || new Properties({\n 'anchor': new DataConstantProperty(styleSpec.light.anchor as StylePropertySpecification),\n 'position': new LightPositionProperty(),\n 'color': new DataConstantProperty(styleSpec.light.color as StylePropertySpecification),\n 'intensity': new DataConstantProperty(styleSpec.light.intensity as StylePropertySpecification),\n });\n this._transitionable = new Transitionable(lightProperties);\n this.setLight(lightOptions);\n this._transitioning = this._transitionable.untransitioned();\n }\n\n getLight(): LightSpecification {\n return this._transitionable.serialize();\n }\n\n setLight(light?: LightSpecification, options: StyleSetterOptions = {}) {\n if (this._validate(validateLight, light, options)) {\n return;\n }\n\n for (const name in light) {\n const value = light[name];\n if (name.endsWith(TRANSITION_SUFFIX)) {\n this._transitionable.setTransition(name.slice(0, -TRANSITION_SUFFIX.length) as keyof LightProps, value);\n } else {\n this._transitionable.setValue(name as keyof LightProps, value);\n }\n }\n }\n\n updateTransitions(parameters: TransitionParameters) {\n this._transitioning = this._transitionable.transitioned(parameters, this._transitioning);\n }\n\n hasTransition() {\n return this._transitioning.hasTransition();\n }\n\n recalculate(parameters: EvaluationParameters) {\n this.properties = this._transitioning.possiblyEvaluate(parameters);\n }\n\n _validate(validate: Function, value: unknown, options?: {\n validate?: boolean;\n }) {\n if (options && options.validate === false) {\n return false;\n }\n\n return emitValidationErrors(this, validate.call(validateStyle, {\n value,\n // Workaround for https://github.com/mapbox/mapbox-gl-js/issues/2407\n style: {glyphs: true, sprite: true},\n styleSpec\n }));\n }\n}\n","import {DataConstantProperty, PossiblyEvaluated, Properties, Transitionable, Transitioning, TransitionParameters} from './properties';\nimport {Evented} from '../util/evented';\nimport {EvaluationParameters} from './evaluation_parameters';\nimport {emitValidationErrors, validateSky, validateStyle} from './validate_style';\nimport {extend} from '../util/util';\nimport {Color, latest as styleSpec} from '@maplibre/maplibre-gl-style-spec';\nimport {Mesh} from '../render/mesh';\nimport type {StylePropertySpecification, SkySpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {StyleSetterOptions} from './style';\n\ntype SkyProps = {\n 'sky-color': DataConstantProperty;\n 'horizon-color': DataConstantProperty;\n 'fog-color': DataConstantProperty;\n 'fog-ground-blend': DataConstantProperty;\n 'horizon-fog-blend': DataConstantProperty;\n 'sky-horizon-blend': DataConstantProperty;\n 'atmosphere-blend': DataConstantProperty;\n};\n\ntype SkyPropsPossiblyEvaluated = {\n 'sky-color': Color;\n 'horizon-color': Color;\n 'fog-color': Color;\n 'fog-ground-blend': number;\n 'horizon-fog-blend': number;\n 'sky-horizon-blend': number;\n 'atmosphere-blend': number;\n};\n\nconst properties: Properties = new Properties({\n 'sky-color': new DataConstantProperty(styleSpec.sky['sky-color'] as StylePropertySpecification),\n 'horizon-color': new DataConstantProperty(styleSpec.sky['horizon-color'] as StylePropertySpecification),\n 'fog-color': new DataConstantProperty(styleSpec.sky['fog-color'] as StylePropertySpecification),\n 'fog-ground-blend': new DataConstantProperty(styleSpec.sky['fog-ground-blend'] as StylePropertySpecification),\n 'horizon-fog-blend': new DataConstantProperty(styleSpec.sky['horizon-fog-blend'] as StylePropertySpecification),\n 'sky-horizon-blend': new DataConstantProperty(styleSpec.sky['sky-horizon-blend'] as StylePropertySpecification),\n 'atmosphere-blend': new DataConstantProperty(styleSpec.sky['atmosphere-blend'] as StylePropertySpecification)\n});\n\nconst TRANSITION_SUFFIX = '-transition';\n\nexport class Sky extends Evented {\n properties: PossiblyEvaluated;\n\n /**\n * This is used to cache the gl mesh for the sky, it should be initialized only once.\n */\n mesh: Mesh | undefined;\n _transitionable: Transitionable;\n _transitioning: Transitioning;\n\n constructor(sky?: SkySpecification) {\n super();\n this._transitionable = new Transitionable(properties);\n this.setSky(sky);\n this._transitioning = this._transitionable.untransitioned();\n this.recalculate(new EvaluationParameters(0));\n }\n\n setSky(sky?: SkySpecification, options: StyleSetterOptions = {}) {\n if (this._validate(validateSky, sky, options)) return;\n\n if (!sky) {\n sky = {\n 'sky-color': 'transparent',\n 'horizon-color': 'transparent',\n 'fog-color': 'transparent',\n 'fog-ground-blend': 1,\n 'atmosphere-blend': 0,\n };\n }\n\n for (const name in sky) {\n const value = sky[name];\n if (name.endsWith(TRANSITION_SUFFIX)) {\n this._transitionable.setTransition(name.slice(0, -TRANSITION_SUFFIX.length) as keyof SkyProps, value);\n } else {\n this._transitionable.setValue(name as keyof SkyProps, value);\n }\n }\n }\n\n getSky(): SkySpecification {\n return this._transitionable.serialize();\n }\n\n updateTransitions(parameters: TransitionParameters) {\n this._transitioning = this._transitionable.transitioned(parameters, this._transitioning);\n }\n\n hasTransition() {\n return this._transitioning.hasTransition();\n }\n\n recalculate(parameters: EvaluationParameters) {\n this.properties = this._transitioning.possiblyEvaluate(parameters);\n }\n\n _validate(validate: Function, value: unknown, options: StyleSetterOptions = {}) {\n if (options?.validate === false) {\n return false;\n }\n return emitValidationErrors(this, validate.call(validateStyle, extend({\n value,\n // Workaround for https://github.com/mapbox/mapbox-gl-js/issues/2407\n style: {glyphs: true, sprite: true},\n styleSpec\n })));\n }\n\n /**\n * Currently fog is a very simple implementation, and should only used\n * to create an atmosphere near the horizon.\n * But because the fog is drawn from the far-clipping-plane to\n * map-center, and because the fog does nothing know about the horizon,\n * this method does a fadeout in respect of pitch. So, when the horizon\n * gets out of view, which is at about pitch 70, this methods calculates\n * the corresponding opacity values. Below pitch 60 the fog is completely\n * invisible.\n */\n calculateFogBlendOpacity(pitch: number) {\n if (pitch < 60) return 0; // disable\n if (pitch < 70) return (pitch - 60) / 10; // fade in\n return 1;\n }\n}\n","import {warnOnce} from '../util/util';\n\nimport type {Context} from '../gl/context';\n\n/**\n * A dash entry\n */\ntype DashEntry = {\n y: number;\n height: number;\n width: number;\n}\n\n/**\n * @internal\n * A LineAtlas lets us reuse rendered dashed lines\n * by writing many of them to a texture and then fetching their positions\n * using {@link LineAtlas#getDash}.\n *\n * @param width - the width\n * @param height - the height\n */\nexport class LineAtlas {\n width: number;\n height: number;\n nextRow: number;\n bytes: number;\n data: Uint8Array;\n dashEntry: {[_: string]: DashEntry};\n dirty: boolean;\n texture: WebGLTexture;\n\n constructor(width: number, height: number) {\n this.width = width;\n this.height = height;\n this.nextRow = 0;\n\n this.data = new Uint8Array(this.width * this.height);\n\n this.dashEntry = {};\n }\n\n /**\n * Get or create a dash line pattern.\n *\n * @param dasharray - the key (represented by numbers) to get the dash texture\n * @param round - whether to add circle caps in between dash segments\n * @returns position of dash texture in {@link DashEntry}\n */\n getDash(dasharray: Array, round: boolean) {\n const key = dasharray.join(',') + String(round);\n\n if (!this.dashEntry[key]) {\n this.dashEntry[key] = this.addDash(dasharray, round);\n }\n return this.dashEntry[key];\n }\n\n getDashRanges(dasharray: Array, lineAtlasWidth: number, stretch: number) {\n // If dasharray has an odd length, both the first and last parts\n // are dashes and should be joined seamlessly.\n const oddDashArray = dasharray.length % 2 === 1;\n\n const ranges = [];\n\n let left = oddDashArray ? -dasharray[dasharray.length - 1] * stretch : 0;\n let right = dasharray[0] * stretch;\n let isDash = true;\n\n ranges.push({left, right, isDash, zeroLength: dasharray[0] === 0});\n\n let currentDashLength = dasharray[0];\n for (let i = 1; i < dasharray.length; i++) {\n isDash = !isDash;\n\n const dashLength = dasharray[i];\n left = currentDashLength * stretch;\n currentDashLength += dashLength;\n right = currentDashLength * stretch;\n\n ranges.push({left, right, isDash, zeroLength: dashLength === 0});\n }\n\n return ranges;\n }\n\n addRoundDash(ranges: any, stretch: number, n: number) {\n const halfStretch = stretch / 2;\n\n for (let y = -n; y <= n; y++) {\n const row = this.nextRow + n + y;\n const index = this.width * row;\n let currIndex = 0;\n let range = ranges[currIndex];\n\n for (let x = 0; x < this.width; x++) {\n if (x / range.right > 1) { range = ranges[++currIndex]; }\n\n const distLeft = Math.abs(x - range.left);\n const distRight = Math.abs(x - range.right);\n const minDist = Math.min(distLeft, distRight);\n let signedDistance;\n\n const distMiddle = y / n * (halfStretch + 1);\n if (range.isDash) {\n const distEdge = halfStretch - Math.abs(distMiddle);\n signedDistance = Math.sqrt(minDist * minDist + distEdge * distEdge);\n } else {\n signedDistance = halfStretch - Math.sqrt(minDist * minDist + distMiddle * distMiddle);\n }\n\n this.data[index + x] = Math.max(0, Math.min(255, signedDistance + 128));\n }\n }\n }\n\n addRegularDash(ranges: any) {\n\n // Collapse any zero-length range\n // Collapse neighbouring same-type parts into a single part\n for (let i = ranges.length - 1; i >= 0; --i) {\n const part = ranges[i];\n const next = ranges[i + 1];\n if (part.zeroLength) {\n ranges.splice(i, 1);\n } else if (next && next.isDash === part.isDash) {\n next.left = part.left;\n ranges.splice(i, 1);\n }\n }\n\n // Combine the first and last parts if possible\n const first = ranges[0];\n const last = ranges[ranges.length - 1];\n if (first.isDash === last.isDash) {\n first.left = last.left - this.width;\n last.right = first.right + this.width;\n }\n\n const index = this.width * this.nextRow;\n let currIndex = 0;\n let range = ranges[currIndex];\n\n for (let x = 0; x < this.width; x++) {\n if (x / range.right > 1) {\n range = ranges[++currIndex];\n }\n\n const distLeft = Math.abs(x - range.left);\n const distRight = Math.abs(x - range.right);\n\n const minDist = Math.min(distLeft, distRight);\n const signedDistance = range.isDash ? minDist : -minDist;\n\n this.data[index + x] = Math.max(0, Math.min(255, signedDistance + 128));\n }\n }\n\n addDash(dasharray: Array, round: boolean): DashEntry {\n const n = round ? 7 : 0;\n const height = 2 * n + 1;\n\n if (this.nextRow + height > this.height) {\n warnOnce('LineAtlas out of space');\n return null;\n }\n\n let length = 0;\n for (let i = 0; i < dasharray.length; i++) { length += dasharray[i]; }\n\n if (length !== 0) {\n const stretch = this.width / length;\n const ranges = this.getDashRanges(dasharray, this.width, stretch);\n\n if (round) {\n this.addRoundDash(ranges, stretch, n);\n } else {\n this.addRegularDash(ranges);\n }\n }\n\n const dashEntry = {\n y: (this.nextRow + n + 0.5) / this.height,\n height: 2 * n / this.height,\n width: length\n };\n\n this.nextRow += height;\n this.dirty = true;\n\n return dashEntry;\n }\n\n bind(context: Context) {\n const gl = context.gl;\n if (!this.texture) {\n this.texture = gl.createTexture();\n gl.bindTexture(gl.TEXTURE_2D, this.texture);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.REPEAT);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.REPEAT);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n gl.texImage2D(gl.TEXTURE_2D, 0, gl.ALPHA, this.width, this.height, 0, gl.ALPHA, gl.UNSIGNED_BYTE, this.data);\n\n } else {\n gl.bindTexture(gl.TEXTURE_2D, this.texture);\n\n if (this.dirty) {\n this.dirty = false;\n gl.texSubImage2D(gl.TEXTURE_2D, 0, 0, 0, this.width, this.height, gl.ALPHA, gl.UNSIGNED_BYTE, this.data);\n }\n }\n }\n}\n","import {AddProtocolAction, config} from './config';\nimport type {default as MaplibreWorker} from '../source/worker';\nimport type {WorkerSourceConstructor} from '../source/worker_source';\n\nexport interface WorkerGlobalScopeInterface {\n importScripts(...urls: Array): void;\n registerWorkerSource: (sourceName: string, sourceConstructor: WorkerSourceConstructor) => void;\n registerRTLTextPlugin: (_: any) => void;\n addProtocol: (customProtocol: string, loadFn: AddProtocolAction) => void;\n removeProtocol: (customProtocol: string) => void;\n worker: MaplibreWorker;\n}\n\nexport function workerFactory() {\n return new Worker(config.WORKER_URL);\n}\n","import {workerFactory} from './web_worker';\nimport {browser} from './browser';\nimport {isSafari} from './util';\nimport {ActorTarget} from './actor';\n\nexport const PRELOAD_POOL_ID = 'maplibre_preloaded_worker_pool';\n\n/**\n * Constructs a worker pool.\n */\nexport class WorkerPool {\n static workerCount: number;\n\n active: {\n [_ in number | string]: boolean;\n };\n workers: Array;\n\n constructor() {\n this.active = {};\n }\n\n acquire(mapId: number | string): Array {\n if (!this.workers) {\n // Lazily look up the value of getWorkerCount so that\n // client code has had a chance to set it.\n this.workers = [];\n while (this.workers.length < WorkerPool.workerCount) {\n this.workers.push(workerFactory());\n }\n }\n\n this.active[mapId] = true;\n return this.workers.slice();\n }\n\n release(mapId: number | string) {\n delete this.active[mapId];\n if (this.numActive() === 0) {\n this.workers.forEach((w) => {\n w.terminate();\n });\n this.workers = null;\n }\n }\n\n isPreloaded(): boolean {\n return !!this.active[PRELOAD_POOL_ID];\n }\n\n numActive(): number {\n return Object.keys(this.active).length;\n }\n}\n\n// Based on results from A/B testing: https://github.com/maplibre/maplibre-gl-js/pull/2354\nconst availableLogicalProcessors = Math.floor(browser.hardwareConcurrency / 2);\nWorkerPool.workerCount = isSafari(globalThis) ? Math.max(Math.min(availableLogicalProcessors, 3), 1) : 1;\n","import {WorkerPool, PRELOAD_POOL_ID} from './worker_pool';\n\nlet globalWorkerPool;\n\n/**\n * Creates (if necessary) and returns the single, global WorkerPool instance\n * to be shared across each Map\n */\nexport function getGlobalWorkerPool() {\n if (!globalWorkerPool) {\n globalWorkerPool = new WorkerPool();\n }\n return globalWorkerPool;\n}\n\n/**\n * Initializes resources like WebWorkers that can be shared across maps to lower load\n * times in some situations. `setWorkerUrl()` and `setWorkerCount()`, if being\n * used, must be set before `prewarm()` is called to have an effect.\n *\n * By default, the lifecycle of these resources is managed automatically, and they are\n * lazily initialized when a Map is first created. By invoking `prewarm()`, these\n * resources will be created ahead of time, and will not be cleared when the last Map\n * is removed from the page. This allows them to be re-used by new Map instances that\n * are created later. They can be manually cleared by calling\n * `clearPrewarmedResources()`. This is only necessary if your web page remains\n * active but stops using maps altogether.\n *\n * This is primarily useful when using GL-JS maps in a single page app, wherein a user\n * would navigate between various views that can cause Map instances to constantly be\n * created and destroyed.\n *\n * @example\n * ```ts\n * prewarm()\n * ```\n */\nexport function prewarm() {\n const workerPool = getGlobalWorkerPool();\n workerPool.acquire(PRELOAD_POOL_ID);\n}\n\n/**\n * Clears up resources that have previously been created by `prewarm()`.\n * Note that this is typically not necessary. You should only call this function\n * if you expect the user of your app to not return to a Map view at any point\n * in your application.\n *\n * @example\n * ```ts\n * clearPrewarmedResources()\n * ```\n */\nexport function clearPrewarmedResources() {\n const pool = globalWorkerPool;\n if (pool) {\n // Remove the pool only if all maps that referenced the preloaded global worker pool have been removed.\n if (pool.isPreloaded() && pool.numActive() === 1) {\n pool.release(PRELOAD_POOL_ID);\n globalWorkerPool = null;\n } else {\n console.warn('Could not clear WebWorkers since there are active Map instances that still reference it. The pre-warmed WebWorker pool can only be cleared when all map instances have been removed with map.remove()');\n }\n }\n}\n","import {Actor, MessageHandler} from './actor';\nimport {getGlobalWorkerPool} from './global_worker_pool';\nimport {GLOBAL_DISPATCHER_ID, makeRequest} from './ajax';\n\nimport type {WorkerPool} from './worker_pool';\nimport type {WorkerSource} from '../source/worker_source'; /* eslint-disable-line */ // this is used for the docs' import\nimport type {RequestResponseMessageMap} from './actor_messages';\nimport {MessageType} from './actor_messages';\n\n/**\n * Responsible for sending messages from a {@link Source} to an associated\n * {@link WorkerSource}.\n */\nexport class Dispatcher {\n workerPool: WorkerPool;\n actors: Array;\n currentActor: number;\n id: string | number;\n\n constructor(workerPool: WorkerPool, mapId: string | number) {\n this.workerPool = workerPool;\n this.actors = [];\n this.currentActor = 0;\n this.id = mapId;\n const workers = this.workerPool.acquire(mapId);\n for (let i = 0; i < workers.length; i++) {\n const worker = workers[i];\n const actor = new Actor(worker, mapId);\n actor.name = `Worker ${i}`;\n this.actors.push(actor);\n }\n if (!this.actors.length) throw new Error('No actors found');\n }\n\n /**\n * Broadcast a message to all Workers.\n */\n broadcast(type: T, data: RequestResponseMessageMap[T][0]): Promise {\n const promises: Promise[] = [];\n for (const actor of this.actors) {\n promises.push(actor.sendAsync({type, data}));\n }\n return Promise.all(promises);\n }\n\n /**\n * Acquires an actor to dispatch messages to. The actors are distributed in round-robin fashion.\n * @returns An actor object backed by a web worker for processing messages.\n */\n getActor(): Actor {\n this.currentActor = (this.currentActor + 1) % this.actors.length;\n return this.actors[this.currentActor];\n }\n\n remove(mapRemoved: boolean = true) {\n this.actors.forEach((actor) => { actor.remove(); });\n this.actors = [];\n if (mapRemoved) this.workerPool.release(this.id);\n }\n\n public registerMessageHandler(type: T, handler: MessageHandler) {\n for (const actor of this.actors) {\n actor.registerMessageHandler(type, handler);\n }\n }\n}\n\nlet globalDispatcher: Dispatcher;\n\nexport function getGlobalDispatcher(): Dispatcher {\n if (!globalDispatcher) {\n globalDispatcher = new Dispatcher(getGlobalWorkerPool(), GLOBAL_DISPATCHER_ID);\n globalDispatcher.registerMessageHandler(MessageType.getResource, (_mapId, params, abortController) => {\n return makeRequest(params, abortController);\n });\n }\n return globalDispatcher;\n}\n","import type {SourceCache} from './source_cache';\nimport type {StyleLayer} from '../style/style_layer';\nimport type {CollisionIndex} from '../symbol/collision_index';\nimport type {Transform} from '../geo/transform';\nimport type {RetainedQueryData} from '../symbol/placement';\nimport type {FilterSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {MapGeoJSONFeature} from '../util/vectortile_to_geojson';\nimport type Point from '@mapbox/point-geometry';\nimport {mat4} from 'gl-matrix';\n\n/**\n * Options to pass to query the map for the rendered features\n */\nexport type QueryRenderedFeaturesOptions = {\n /**\n * An array of [style layer IDs](https://maplibre.org/maplibre-style-spec/#layer-id) for the query to inspect.\n * Only features within these layers will be returned. If this parameter is undefined, all layers will be checked.\n */\n layers?: Array;\n /**\n * A [filter](https://maplibre.org/maplibre-style-spec/layers/#filter) to limit query results.\n */\n filter?: FilterSpecification;\n /**\n * An array of string representing the available images\n */\n availableImages?: Array;\n /**\n * Whether to check if the [options.filter] conforms to the MapLibre Style Specification. Disabling validation is a performance optimization that should only be used if you have previously validated the values you will be passing to this function.\n */\n validate?: boolean;\n};\n\n/**\n * The options object related to the {@link Map#querySourceFeatures} method\n */\nexport type QuerySourceFeatureOptions = {\n /**\n * The name of the source layer to query. *For vector tile sources, this parameter is required.* For GeoJSON sources, it is ignored.\n */\n sourceLayer?: string;\n /**\n * A [filter](https://maplibre.org/maplibre-style-spec/layers/#filter)\n * to limit query results.\n */\n filter?: FilterSpecification;\n /**\n * Whether to check if the [parameters.filter] conforms to the MapLibre Style Specification. Disabling validation is a performance optimization that should only be used if you have previously validated the values you will be passing to this function.\n * @defaultValue true\n */\n validate?: boolean;\n}\n\n/*\n * Returns a matrix that can be used to convert from tile coordinates to viewport pixel coordinates.\n */\nfunction getPixelPosMatrix(transform, tileID) {\n const t = mat4.create();\n mat4.translate(t, t, [1, 1, 0]);\n mat4.scale(t, t, [transform.width * 0.5, transform.height * 0.5, 1]);\n return mat4.multiply(t, t, transform.calculatePosMatrix(tileID.toUnwrapped()));\n}\n\nfunction queryIncludes3DLayer(layers: Array, styleLayers: {[_: string]: StyleLayer}, sourceID: string) {\n if (layers) {\n for (const layerID of layers) {\n const layer = styleLayers[layerID];\n if (layer && layer.source === sourceID && layer.type === 'fill-extrusion') {\n return true;\n }\n }\n } else {\n for (const key in styleLayers) {\n const layer = styleLayers[key];\n if (layer.source === sourceID && layer.type === 'fill-extrusion') {\n return true;\n }\n }\n }\n return false;\n}\n\nexport function queryRenderedFeatures(\n sourceCache: SourceCache,\n styleLayers: {[_: string]: StyleLayer},\n serializedLayers: {[_: string]: any},\n queryGeometry: Array,\n params: QueryRenderedFeaturesOptions,\n transform: Transform\n): { [key: string]: Array<{featureIndex: number; feature: MapGeoJSONFeature}> } {\n\n const has3DLayer = queryIncludes3DLayer(params && params.layers, styleLayers, sourceCache.id);\n const maxPitchScaleFactor = transform.maxPitchScaleFactor();\n const tilesIn = sourceCache.tilesIn(queryGeometry, maxPitchScaleFactor, has3DLayer);\n\n tilesIn.sort(sortTilesIn);\n const renderedFeatureLayers = [];\n for (const tileIn of tilesIn) {\n renderedFeatureLayers.push({\n wrappedTileID: tileIn.tileID.wrapped().key,\n queryResults: tileIn.tile.queryRenderedFeatures(\n styleLayers,\n serializedLayers,\n sourceCache._state,\n tileIn.queryGeometry,\n tileIn.cameraQueryGeometry,\n tileIn.scale,\n params,\n transform,\n maxPitchScaleFactor,\n getPixelPosMatrix(sourceCache.transform, tileIn.tileID))\n });\n }\n\n const result = mergeRenderedFeatureLayers(renderedFeatureLayers);\n\n // Merge state from SourceCache into the results\n for (const layerID in result) {\n result[layerID].forEach((featureWrapper) => {\n const feature = featureWrapper.feature as MapGeoJSONFeature;\n const state = sourceCache.getFeatureState(feature.layer['source-layer'], feature.id);\n feature.source = feature.layer.source;\n if (feature.layer['source-layer']) {\n feature.sourceLayer = feature.layer['source-layer'];\n }\n feature.state = state;\n });\n }\n return result;\n}\n\nexport function queryRenderedSymbols(styleLayers: {[_: string]: StyleLayer},\n serializedLayers: {[_: string]: StyleLayer},\n sourceCaches: {[_: string]: SourceCache},\n queryGeometry: Array,\n params: QueryRenderedFeaturesOptions,\n collisionIndex: CollisionIndex,\n retainedQueryData: {\n [_: number]: RetainedQueryData;\n }) {\n const result = {};\n const renderedSymbols = collisionIndex.queryRenderedSymbols(queryGeometry);\n const bucketQueryData = [];\n for (const bucketInstanceId of Object.keys(renderedSymbols).map(Number)) {\n bucketQueryData.push(retainedQueryData[bucketInstanceId]);\n }\n bucketQueryData.sort(sortTilesIn);\n\n for (const queryData of bucketQueryData) {\n const bucketSymbols = queryData.featureIndex.lookupSymbolFeatures(\n renderedSymbols[queryData.bucketInstanceId],\n serializedLayers,\n queryData.bucketIndex,\n queryData.sourceLayerIndex,\n params.filter,\n params.layers,\n params.availableImages,\n styleLayers);\n\n for (const layerID in bucketSymbols) {\n const resultFeatures = result[layerID] = result[layerID] || [];\n const layerSymbols = bucketSymbols[layerID];\n layerSymbols.sort((a, b) => {\n // Match topDownFeatureComparator from FeatureIndex, but using\n // most recent sorting of features from bucket.sortFeatures\n const featureSortOrder = queryData.featureSortOrder;\n if (featureSortOrder) {\n // queryRenderedSymbols documentation says we'll return features in\n // \"top-to-bottom\" rendering order (aka last-to-first).\n // Actually there can be multiple symbol instances per feature, so\n // we sort each feature based on the first matching symbol instance.\n const sortedA = featureSortOrder.indexOf(a.featureIndex);\n const sortedB = featureSortOrder.indexOf(b.featureIndex);\n return sortedB - sortedA;\n } else {\n // Bucket hasn't been re-sorted based on angle, so use the\n // reverse of the order the features appeared in the data.\n return b.featureIndex - a.featureIndex;\n }\n });\n for (const symbolFeature of layerSymbols) {\n resultFeatures.push(symbolFeature);\n }\n }\n }\n\n // Merge state from SourceCache into the results\n for (const layerName in result) {\n result[layerName].forEach((featureWrapper) => {\n const feature = featureWrapper.feature;\n const layer = styleLayers[layerName];\n const sourceCache = sourceCaches[layer.source];\n const state = sourceCache.getFeatureState(feature.layer['source-layer'], feature.id);\n feature.source = feature.layer.source;\n if (feature.layer['source-layer']) {\n feature.sourceLayer = feature.layer['source-layer'];\n }\n feature.state = state;\n });\n }\n return result;\n}\n\nexport function querySourceFeatures(sourceCache: SourceCache, params: QuerySourceFeatureOptions) {\n const tiles = sourceCache.getRenderableIds().map((id) => {\n return sourceCache.getTileByID(id);\n });\n\n const result = [];\n\n const dataTiles = {};\n for (let i = 0; i < tiles.length; i++) {\n const tile = tiles[i];\n const dataID = tile.tileID.canonical.key;\n if (!dataTiles[dataID]) {\n dataTiles[dataID] = true;\n tile.querySourceFeatures(result, params);\n }\n }\n\n return result;\n}\n\nfunction sortTilesIn(a, b) {\n const idA = a.tileID;\n const idB = b.tileID;\n return (idA.overscaledZ - idB.overscaledZ) || (idA.canonical.y - idB.canonical.y) || (idA.wrap - idB.wrap) || (idA.canonical.x - idB.canonical.x);\n}\n\nfunction mergeRenderedFeatureLayers(tiles) {\n // Merge results from all tiles, but if two tiles share the same\n // wrapped ID, don't duplicate features between the two tiles\n const result = {};\n const wrappedIDLayerMap = {};\n for (const tile of tiles) {\n const queryResults = tile.queryResults;\n const wrappedID = tile.wrappedTileID;\n const wrappedIDLayers = wrappedIDLayerMap[wrappedID] = wrappedIDLayerMap[wrappedID] || {};\n for (const layerID in queryResults) {\n const tileFeatures = queryResults[layerID];\n const wrappedIDFeatures = wrappedIDLayers[layerID] = wrappedIDLayers[layerID] || {};\n const resultFeatures = result[layerID] = result[layerID] || [];\n for (const tileFeature of tileFeatures) {\n if (!wrappedIDFeatures[tileFeature.featureIndex]) {\n wrappedIDFeatures[tileFeature.featureIndex] = true;\n resultFeatures.push(tileFeature);\n }\n }\n }\n }\n return result;\n}\n","import {pick, extend, TileJSON} from '../util/util';\nimport {getJSON} from '../util/ajax';\nimport {ResourceType} from '../util/request_manager';\nimport {browser} from '../util/browser';\n\nimport type {RequestManager} from '../util/request_manager';\nimport type {RasterDEMSourceSpecification, RasterSourceSpecification, VectorSourceSpecification} from '@maplibre/maplibre-gl-style-spec';\n\nexport type LoadTileJsonResponse = {\n tiles: Array;\n minzoom: number;\n maxzoom: number;\n attribution: string;\n bounds: RasterSourceSpecification['bounds'];\n scheme: RasterSourceSpecification['scheme'];\n tileSize: number;\n encoding: RasterDEMSourceSpecification['encoding'];\n vectorLayerIds?: Array;\n}\n\nexport async function loadTileJson(\n options: RasterSourceSpecification | RasterDEMSourceSpecification | VectorSourceSpecification,\n requestManager: RequestManager,\n abortController: AbortController,\n): Promise {\n let tileJSON: TileJSON | typeof options = options;\n if (options.url) {\n const response = await getJSON(requestManager.transformRequest(options.url, ResourceType.Source), abortController);\n tileJSON = response.data;\n } else {\n await browser.frameAsync(abortController);\n }\n if (!tileJSON) {\n return null;\n }\n const result = pick(\n // explicit source options take precedence over TileJSON\n extend(tileJSON, options),\n ['tiles', 'minzoom', 'maxzoom', 'attribution', 'bounds', 'scheme', 'tileSize', 'encoding']\n ) as LoadTileJsonResponse;\n\n if ('vector_layers' in tileJSON && tileJSON.vector_layers) {\n result.vectorLayerIds = tileJSON.vector_layers.map((layer) => { return layer.id; });\n }\n\n return result;\n}\n","import {LngLat} from './lng_lat';\nimport type {LngLatLike} from './lng_lat';\n\n/**\n * A {@link LngLatBounds} object, an array of {@link LngLatLike} objects in [sw, ne] order,\n * or an array of numbers in [west, south, east, north] order.\n *\n * @group Geography and Geometry\n *\n * @example\n * ```ts\n * let v1 = new LngLatBounds(\n * new LngLat(-73.9876, 40.7661),\n * new LngLat(-73.9397, 40.8002)\n * );\n * let v2 = new LngLatBounds([-73.9876, 40.7661], [-73.9397, 40.8002])\n * let v3 = [[-73.9876, 40.7661], [-73.9397, 40.8002]];\n * ```\n */\nexport type LngLatBoundsLike = LngLatBounds | [LngLatLike, LngLatLike] | [number, number, number, number];\n\n/**\n * A `LngLatBounds` object represents a geographical bounding box,\n * defined by its southwest and northeast points in longitude and latitude.\n *\n * If no arguments are provided to the constructor, a `null` bounding box is created.\n *\n * Note that any Mapbox GL method that accepts a `LngLatBounds` object as an argument or option\n * can also accept an `Array` of two {@link LngLatLike} constructs and will perform an implicit conversion.\n * This flexible type is documented as {@link LngLatBoundsLike}.\n *\n * @group Geography and Geometry\n *\n * @example\n * ```ts\n * let sw = new LngLat(-73.9876, 40.7661);\n * let ne = new LngLat(-73.9397, 40.8002);\n * let llb = new LngLatBounds(sw, ne);\n * ```\n */\nexport class LngLatBounds {\n _ne: LngLat;\n _sw: LngLat;\n\n /**\n * @param sw - The southwest corner of the bounding box.\n * OR array of 4 numbers in the order of west, south, east, north\n * OR array of 2 LngLatLike: [sw,ne]\n * @param ne - The northeast corner of the bounding box.\n * @example\n * ```ts\n * let sw = new LngLat(-73.9876, 40.7661);\n * let ne = new LngLat(-73.9397, 40.8002);\n * let llb = new LngLatBounds(sw, ne);\n * ```\n * OR\n * ```ts\n * let llb = new LngLatBounds([-73.9876, 40.7661, -73.9397, 40.8002]);\n * ```\n * OR\n * ```ts\n * let llb = new LngLatBounds([sw, ne]);\n * ```\n */\n constructor(sw?: LngLatLike | [number, number, number, number] | [LngLatLike, LngLatLike], ne?: LngLatLike) {\n if (!sw) {\n // noop\n } else if (ne) {\n this.setSouthWest(sw).setNorthEast(ne);\n } else if (Array.isArray(sw)) {\n if (sw.length === 4) {\n // 4 element array: west, south, east, north\n this.setSouthWest([sw[0], sw[1]]).setNorthEast([sw[2], sw[3]]);\n } else {\n this.setSouthWest(sw[0] as LngLatLike).setNorthEast(sw[1] as LngLatLike);\n }\n }\n }\n\n /**\n * Set the northeast corner of the bounding box\n *\n * @param ne - a {@link LngLatLike} object describing the northeast corner of the bounding box.\n */\n setNorthEast(ne: LngLatLike): this {\n this._ne = ne instanceof LngLat ? new LngLat(ne.lng, ne.lat) : LngLat.convert(ne);\n return this;\n }\n\n /**\n * Set the southwest corner of the bounding box\n *\n * @param sw - a {@link LngLatLike} object describing the southwest corner of the bounding box.\n */\n setSouthWest(sw: LngLatLike): this {\n this._sw = sw instanceof LngLat ? new LngLat(sw.lng, sw.lat) : LngLat.convert(sw);\n return this;\n }\n\n /**\n * Extend the bounds to include a given LngLatLike or LngLatBoundsLike.\n *\n * @param obj - object to extend to\n */\n extend(obj: LngLatLike | LngLatBoundsLike): this {\n const sw = this._sw,\n ne = this._ne;\n let sw2, ne2;\n\n if (obj instanceof LngLat) {\n sw2 = obj;\n ne2 = obj;\n\n } else if (obj instanceof LngLatBounds) {\n sw2 = obj._sw;\n ne2 = obj._ne;\n\n if (!sw2 || !ne2) return this;\n\n } else {\n if (Array.isArray(obj)) {\n if (obj.length === 4 || (obj as any[]).every(Array.isArray)) {\n const lngLatBoundsObj = (obj as any as LngLatBoundsLike);\n return this.extend(LngLatBounds.convert(lngLatBoundsObj));\n } else {\n const lngLatObj = (obj as any as LngLatLike);\n return this.extend(LngLat.convert(lngLatObj));\n }\n\n } else if (obj && ('lng' in obj || 'lon' in obj) && 'lat' in obj) {\n return this.extend(LngLat.convert(obj));\n }\n\n return this;\n }\n\n if (!sw && !ne) {\n this._sw = new LngLat(sw2.lng, sw2.lat);\n this._ne = new LngLat(ne2.lng, ne2.lat);\n\n } else {\n sw.lng = Math.min(sw2.lng, sw.lng);\n sw.lat = Math.min(sw2.lat, sw.lat);\n ne.lng = Math.max(ne2.lng, ne.lng);\n ne.lat = Math.max(ne2.lat, ne.lat);\n }\n\n return this;\n }\n\n /**\n * Returns the geographical coordinate equidistant from the bounding box's corners.\n *\n * @returns The bounding box's center.\n * @example\n * ```ts\n * let llb = new LngLatBounds([-73.9876, 40.7661], [-73.9397, 40.8002]);\n * llb.getCenter(); // = LngLat {lng: -73.96365, lat: 40.78315}\n * ```\n */\n getCenter(): LngLat {\n return new LngLat((this._sw.lng + this._ne.lng) / 2, (this._sw.lat + this._ne.lat) / 2);\n }\n\n /**\n * Returns the southwest corner of the bounding box.\n *\n * @returns The southwest corner of the bounding box.\n */\n getSouthWest(): LngLat { return this._sw; }\n\n /**\n * Returns the northeast corner of the bounding box.\n *\n * @returns The northeast corner of the bounding box.\n */\n getNorthEast(): LngLat { return this._ne; }\n\n /**\n * Returns the northwest corner of the bounding box.\n *\n * @returns The northwest corner of the bounding box.\n */\n getNorthWest(): LngLat { return new LngLat(this.getWest(), this.getNorth()); }\n\n /**\n * Returns the southeast corner of the bounding box.\n *\n * @returns The southeast corner of the bounding box.\n */\n getSouthEast(): LngLat { return new LngLat(this.getEast(), this.getSouth()); }\n\n /**\n * Returns the west edge of the bounding box.\n *\n * @returns The west edge of the bounding box.\n */\n getWest(): number { return this._sw.lng; }\n\n /**\n * Returns the south edge of the bounding box.\n *\n * @returns The south edge of the bounding box.\n */\n getSouth(): number { return this._sw.lat; }\n\n /**\n * Returns the east edge of the bounding box.\n *\n * @returns The east edge of the bounding box.\n */\n getEast(): number { return this._ne.lng; }\n\n /**\n * Returns the north edge of the bounding box.\n *\n * @returns The north edge of the bounding box.\n */\n getNorth(): number { return this._ne.lat; }\n\n /**\n * Returns the bounding box represented as an array.\n *\n * @returns The bounding box represented as an array, consisting of the\n * southwest and northeast coordinates of the bounding represented as arrays of numbers.\n * @example\n * ```ts\n * let llb = new LngLatBounds([-73.9876, 40.7661], [-73.9397, 40.8002]);\n * llb.toArray(); // = [[-73.9876, 40.7661], [-73.9397, 40.8002]]\n * ```\n */\n toArray() {\n return [this._sw.toArray(), this._ne.toArray()];\n }\n\n /**\n * Return the bounding box represented as a string.\n *\n * @returns The bounding box represents as a string of the format\n * `'LngLatBounds(LngLat(lng, lat), LngLat(lng, lat))'`.\n * @example\n * ```ts\n * let llb = new LngLatBounds([-73.9876, 40.7661], [-73.9397, 40.8002]);\n * llb.toString(); // = \"LngLatBounds(LngLat(-73.9876, 40.7661), LngLat(-73.9397, 40.8002))\"\n * ```\n */\n toString() {\n return `LngLatBounds(${this._sw.toString()}, ${this._ne.toString()})`;\n }\n\n /**\n * Check if the bounding box is an empty/`null`-type box.\n *\n * @returns True if bounds have been defined, otherwise false.\n */\n isEmpty() {\n return !(this._sw && this._ne);\n }\n\n /**\n * Check if the point is within the bounding box.\n *\n * @param lnglat - geographic point to check against.\n * @returns `true` if the point is within the bounding box.\n * @example\n * ```ts\n * let llb = new LngLatBounds(\n * new LngLat(-73.9876, 40.7661),\n * new LngLat(-73.9397, 40.8002)\n * );\n *\n * let ll = new LngLat(-73.9567, 40.7789);\n *\n * console.log(llb.contains(ll)); // = true\n * ```\n */\n contains(lnglat: LngLatLike) {\n const {lng, lat} = LngLat.convert(lnglat);\n\n const containsLatitude = this._sw.lat <= lat && lat <= this._ne.lat;\n let containsLongitude = this._sw.lng <= lng && lng <= this._ne.lng;\n if (this._sw.lng > this._ne.lng) { // wrapped coordinates\n containsLongitude = this._sw.lng >= lng && lng >= this._ne.lng;\n }\n\n return containsLatitude && containsLongitude;\n }\n\n /**\n * Converts an array to a `LngLatBounds` object.\n *\n * If a `LngLatBounds` object is passed in, the function returns it unchanged.\n *\n * Internally, the function calls `LngLat#convert` to convert arrays to `LngLat` values.\n *\n * @param input - An array of two coordinates to convert, or a `LngLatBounds` object to return.\n * @returns A new `LngLatBounds` object, if a conversion occurred, or the original `LngLatBounds` object.\n * @example\n * ```ts\n * let arr = [[-73.9876, 40.7661], [-73.9397, 40.8002]];\n * let llb = LngLatBounds.convert(arr); // = LngLatBounds {_sw: LngLat {lng: -73.9876, lat: 40.7661}, _ne: LngLat {lng: -73.9397, lat: 40.8002}}\n * ```\n */\n static convert(input: LngLatBoundsLike | null): LngLatBounds {\n if (input instanceof LngLatBounds) return input;\n if (!input) return input as null;\n return new LngLatBounds(input);\n }\n\n /**\n * Returns a `LngLatBounds` from the coordinates extended by a given `radius`. The returned `LngLatBounds` completely contains the `radius`.\n *\n * @param center - center coordinates of the new bounds.\n * @param radius - Distance in meters from the coordinates to extend the bounds.\n * @returns A new `LngLatBounds` object representing the coordinates extended by the `radius`.\n * @example\n * ```ts\n * let center = new LngLat(-73.9749, 40.7736);\n * LngLatBounds.fromLngLat(100).toArray(); // = [[-73.97501862141328, 40.77351016847229], [-73.97478137858673, 40.77368983152771]]\n * ```\n */\n static fromLngLat(center: LngLat, radius:number = 0): LngLatBounds {\n const earthCircumferenceInMetersAtEquator = 40075017;\n const latAccuracy = 360 * radius / earthCircumferenceInMetersAtEquator,\n lngAccuracy = latAccuracy / Math.cos((Math.PI / 180) * center.lat);\n\n return new LngLatBounds(new LngLat(center.lng - lngAccuracy, center.lat - latAccuracy),\n new LngLat(center.lng + lngAccuracy, center.lat + latAccuracy));\n }\n\n /**\n * Adjusts the given bounds to handle the case where the bounds cross the 180th meridian (antimeridian).\n *\n * @returns The adjusted LngLatBounds\n * @example\n * ```ts\n * let bounds = new LngLatBounds([175.813127, -20.157768], [-178. 340903, -15.449124]);\n * let adjustedBounds = bounds.adjustAntiMeridian();\n * // adjustedBounds will be: [[175.813127, -20.157768], [181.659097, -15.449124]]\n * ```\n */\n adjustAntiMeridian(): LngLatBounds {\n const sw = new LngLat(this._sw.lng, this._sw.lat);\n const ne = new LngLat(this._ne.lng, this._ne.lat);\n\n if (sw.lng > ne.lng) {\n return new LngLatBounds(\n sw,\n new LngLat(ne.lng + 360, ne.lat)\n );\n }\n\n return new LngLatBounds(sw, ne);\n }\n\n}\n","import {LngLatBounds, LngLatBoundsLike} from '../geo/lng_lat_bounds';\nimport {mercatorXfromLng, mercatorYfromLat} from '../geo/mercator_coordinate';\n\nimport type {CanonicalTileID} from './tile_id';\n\nexport class TileBounds {\n bounds: LngLatBounds;\n minzoom: number;\n maxzoom: number;\n\n constructor(bounds: [number, number, number, number], minzoom?: number | null, maxzoom?: number | null) {\n this.bounds = LngLatBounds.convert(this.validateBounds(bounds));\n this.minzoom = minzoom || 0;\n this.maxzoom = maxzoom || 24;\n }\n\n validateBounds(bounds: [number, number, number, number]): LngLatBoundsLike {\n // make sure the bounds property contains valid longitude and latitudes\n if (!Array.isArray(bounds) || bounds.length !== 4) return [-180, -90, 180, 90];\n return [Math.max(-180, bounds[0]), Math.max(-90, bounds[1]), Math.min(180, bounds[2]), Math.min(90, bounds[3])];\n }\n\n contains(tileID: CanonicalTileID) {\n const worldSize = Math.pow(2, tileID.z);\n const level = {\n minX: Math.floor(mercatorXfromLng(this.bounds.getWest()) * worldSize),\n minY: Math.floor(mercatorYfromLat(this.bounds.getNorth()) * worldSize),\n maxX: Math.ceil(mercatorXfromLng(this.bounds.getEast()) * worldSize),\n maxY: Math.ceil(mercatorYfromLat(this.bounds.getSouth()) * worldSize)\n };\n const hit = tileID.x >= level.minX && tileID.x < level.maxX && tileID.y >= level.minY && tileID.y < level.maxY;\n return hit;\n }\n}\n","import {Event, ErrorEvent, Evented} from '../util/evented';\n\nimport {extend, pick} from '../util/util';\nimport {loadTileJson} from './load_tilejson';\nimport {TileBounds} from './tile_bounds';\nimport {ResourceType} from '../util/request_manager';\n\nimport type {Source} from './source';\nimport type {OverscaledTileID} from './tile_id';\nimport type {Map} from '../ui/map';\nimport type {Dispatcher} from '../util/dispatcher';\nimport type {Tile} from './tile';\nimport type {VectorSourceSpecification, PromoteIdSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {WorkerTileResult} from './worker_source';\nimport {MessageType} from '../util/actor_messages';\n\nexport type VectorTileSourceOptions = VectorSourceSpecification & {\n collectResourceTiming?: boolean;\n tileSize?: number;\n}\n\n/**\n * A source containing vector tiles in [Mapbox Vector Tile format](https://docs.mapbox.com/vector-tiles/reference/).\n * (See the [Style Specification](https://maplibre.org/maplibre-style-spec/) for detailed documentation of options.)\n *\n * @group Sources\n *\n * @example\n * ```ts\n * map.addSource('some id', {\n * type: 'vector',\n * url: 'https://demotiles.maplibre.org/tiles/tiles.json'\n * });\n * ```\n *\n * @example\n * ```ts\n * map.addSource('some id', {\n * type: 'vector',\n * tiles: ['https://d25uarhxywzl1j.cloudfront.net/v0.1/{z}/{x}/{y}.mvt'],\n * minzoom: 6,\n * maxzoom: 14\n * });\n * ```\n *\n * @example\n * ```ts\n * map.getSource('some id').setUrl(\"https://demotiles.maplibre.org/tiles/tiles.json\");\n * ```\n *\n * @example\n * ```ts\n * map.getSource('some id').setTiles(['https://d25uarhxywzl1j.cloudfront.net/v0.1/{z}/{x}/{y}.mvt']);\n * ```\n * @see [Add a vector tile source](https://maplibre.org/maplibre-gl-js/docs/examples/vector-source/)\n */\nexport class VectorTileSource extends Evented implements Source {\n type: 'vector';\n id: string;\n minzoom: number;\n maxzoom: number;\n url: string;\n scheme: string;\n tileSize: number;\n promoteId: PromoteIdSpecification;\n\n _options: VectorSourceSpecification;\n _collectResourceTiming: boolean;\n dispatcher: Dispatcher;\n map: Map;\n bounds: [number, number, number, number];\n tiles: Array;\n tileBounds: TileBounds;\n reparseOverscaled: boolean;\n isTileClipped: boolean;\n _tileJSONRequest: AbortController;\n _loaded: boolean;\n\n constructor(id: string, options: VectorTileSourceOptions, dispatcher: Dispatcher, eventedParent: Evented) {\n super();\n this.id = id;\n this.dispatcher = dispatcher;\n\n this.type = 'vector';\n this.minzoom = 0;\n this.maxzoom = 22;\n this.scheme = 'xyz';\n this.tileSize = 512;\n this.reparseOverscaled = true;\n this.isTileClipped = true;\n this._loaded = false;\n\n extend(this, pick(options, ['url', 'scheme', 'tileSize', 'promoteId']));\n this._options = extend({type: 'vector'}, options);\n\n this._collectResourceTiming = options.collectResourceTiming;\n\n if (this.tileSize !== 512) {\n throw new Error('vector tile sources must have a tileSize of 512');\n }\n\n this.setEventedParent(eventedParent);\n }\n\n async load() {\n this._loaded = false;\n this.fire(new Event('dataloading', {dataType: 'source'}));\n this._tileJSONRequest = new AbortController();\n try {\n const tileJSON = await loadTileJson(this._options, this.map._requestManager, this._tileJSONRequest);\n this._tileJSONRequest = null;\n this._loaded = true;\n this.map.style.sourceCaches[this.id].clearTiles();\n if (tileJSON) {\n extend(this, tileJSON);\n if (tileJSON.bounds) this.tileBounds = new TileBounds(tileJSON.bounds, this.minzoom, this.maxzoom);\n\n // `content` is included here to prevent a race condition where `Style#_updateSources` is called\n // before the TileJSON arrives. this makes sure the tiles needed are loaded once TileJSON arrives\n // ref: https://github.com/mapbox/mapbox-gl-js/pull/4347#discussion_r104418088\n this.fire(new Event('data', {dataType: 'source', sourceDataType: 'metadata'}));\n this.fire(new Event('data', {dataType: 'source', sourceDataType: 'content'}));\n }\n } catch (err) {\n this._tileJSONRequest = null;\n this.fire(new ErrorEvent(err));\n }\n }\n\n loaded(): boolean {\n return this._loaded;\n }\n\n hasTile(tileID: OverscaledTileID) {\n return !this.tileBounds || this.tileBounds.contains(tileID.canonical);\n }\n\n onAdd(map: Map) {\n this.map = map;\n this.load();\n }\n\n setSourceProperty(callback: Function) {\n if (this._tileJSONRequest) {\n this._tileJSONRequest.abort();\n }\n\n callback();\n\n this.load();\n }\n\n /**\n * Sets the source `tiles` property and re-renders the map.\n *\n * @param tiles - An array of one or more tile source URLs, as in the TileJSON spec.\n */\n setTiles(tiles: Array): this {\n this.setSourceProperty(() => {\n this._options.tiles = tiles;\n });\n\n return this;\n }\n\n /**\n * Sets the source `url` property and re-renders the map.\n *\n * @param url - A URL to a TileJSON resource. Supported protocols are `http:` and `https:`.\n */\n setUrl(url: string): this {\n this.setSourceProperty(() => {\n this.url = url;\n this._options.url = url;\n });\n\n return this;\n }\n\n onRemove() {\n if (this._tileJSONRequest) {\n this._tileJSONRequest.abort();\n this._tileJSONRequest = null;\n }\n }\n\n serialize(): VectorSourceSpecification {\n return extend({}, this._options);\n }\n\n async loadTile(tile: Tile): Promise {\n const url = tile.tileID.canonical.url(this.tiles, this.map.getPixelRatio(), this.scheme);\n const params = {\n request: this.map._requestManager.transformRequest(url, ResourceType.Tile),\n uid: tile.uid,\n tileID: tile.tileID,\n zoom: tile.tileID.overscaledZ,\n tileSize: this.tileSize * tile.tileID.overscaleFactor(),\n type: this.type,\n source: this.id,\n pixelRatio: this.map.getPixelRatio(),\n showCollisionBoxes: this.map.showCollisionBoxes,\n promoteId: this.promoteId\n };\n params.request.collectResourceTiming = this._collectResourceTiming;\n let messageType: MessageType.loadTile | MessageType.reloadTile = MessageType.reloadTile;\n if (!tile.actor || tile.state === 'expired') {\n tile.actor = this.dispatcher.getActor();\n messageType = MessageType.loadTile;\n } else if (tile.state === 'loading') {\n return new Promise((resolve, reject) => {\n tile.reloadPromise = {resolve, reject};\n });\n }\n tile.abortController = new AbortController();\n try {\n const data = await tile.actor.sendAsync({type: messageType, data: params}, tile.abortController);\n delete tile.abortController;\n\n if (tile.aborted) {\n return;\n }\n this._afterTileLoadWorkerResponse(tile, data);\n } catch (err) {\n delete tile.abortController;\n\n if (tile.aborted) {\n return;\n }\n if (err && err.status !== 404) {\n throw err;\n }\n this._afterTileLoadWorkerResponse(tile, null);\n }\n }\n\n private _afterTileLoadWorkerResponse(tile: Tile, data: WorkerTileResult) {\n if (data && data.resourceTiming) {\n tile.resourceTiming = data.resourceTiming;\n }\n\n if (data && this.map._refreshExpiredTiles) {\n tile.setExpiryData(data);\n }\n tile.loadVectorData(data, this.map.painter);\n\n if (tile.reloadPromise) {\n const reloadPromise = tile.reloadPromise;\n tile.reloadPromise = null;\n this.loadTile(tile).then(reloadPromise.resolve).catch(reloadPromise.reject);\n }\n }\n\n async abortTile(tile: Tile): Promise {\n if (tile.abortController) {\n tile.abortController.abort();\n delete tile.abortController;\n }\n if (tile.actor) {\n await tile.actor.sendAsync({\n type: MessageType.abortTile,\n data: {uid: tile.uid, type: this.type, source: this.id}\n });\n }\n }\n\n async unloadTile(tile: Tile): Promise {\n tile.unloadVectorData();\n if (tile.actor) {\n await tile.actor.sendAsync({\n type: MessageType.removeTile,\n data: {\n uid: tile.uid,\n type: this.type,\n source: this.id}\n });\n }\n }\n\n hasTransition() {\n return false;\n }\n}\n","import {extend, pick} from '../util/util';\n\nimport {ImageRequest} from '../util/image_request';\n\nimport {ResourceType} from '../util/request_manager';\nimport {Event, ErrorEvent, Evented} from '../util/evented';\nimport {loadTileJson} from './load_tilejson';\nimport {TileBounds} from './tile_bounds';\nimport {Texture} from '../render/texture';\n\nimport type {Source} from './source';\nimport type {OverscaledTileID} from './tile_id';\nimport type {Map} from '../ui/map';\nimport type {Dispatcher} from '../util/dispatcher';\nimport type {Tile} from './tile';\nimport type {\n RasterSourceSpecification,\n RasterDEMSourceSpecification\n} from '@maplibre/maplibre-gl-style-spec';\n\n/**\n * A source containing raster tiles (See the [Style Specification](https://maplibre.org/maplibre-style-spec/) for detailed documentation of options.)\n *\n * @group Sources\n *\n * @example\n * ```ts\n * map.addSource('raster-source', {\n * 'type': 'raster',\n * 'tiles': ['https://tiles.stadiamaps.com/tiles/stamen_watercolor/{z}/{x}/{y}.jpg'],\n * 'tileSize': 256,\n * });\n * ```\n *\n * @example\n * ```ts\n * map.addSource('wms-test-source', {\n * 'type': 'raster',\n * // use the tiles option to specify a WMS tile source URL\n * 'tiles': [\n * 'https://img.nj.gov/imagerywms/Natural2015?bbox={bbox-epsg-3857}&format=image/png&service=WMS&version=1.1.1&request=GetMap&srs=EPSG:3857&transparent=true&width=256&height=256&layers=Natural2015'\n * ],\n * 'tileSize': 256\n * });\n * ```\n * @see [Add a raster tile source](https://maplibre.org/maplibre-gl-js/docs/examples/map-tiles/)\n * @see [Add a WMS source](https://maplibre.org/maplibre-gl-js/docs/examples/wms/)\n * @see [Display a satellite map](https://maplibre.org/maplibre-gl-js/docs/examples/satellite-map/)\n */\nexport class RasterTileSource extends Evented implements Source {\n type: 'raster' | 'raster-dem';\n id: string;\n minzoom: number;\n maxzoom: number;\n url: string;\n scheme: string;\n tileSize: number;\n\n bounds: [number, number, number, number];\n tileBounds: TileBounds;\n roundZoom: boolean;\n dispatcher: Dispatcher;\n map: Map;\n tiles: Array;\n\n _loaded: boolean;\n _options: RasterSourceSpecification | RasterDEMSourceSpecification;\n _tileJSONRequest: AbortController;\n\n constructor(id: string, options: RasterSourceSpecification | RasterDEMSourceSpecification, dispatcher: Dispatcher, eventedParent: Evented) {\n super();\n this.id = id;\n this.dispatcher = dispatcher;\n this.setEventedParent(eventedParent);\n\n this.type = 'raster';\n this.minzoom = 0;\n this.maxzoom = 22;\n this.roundZoom = true;\n this.scheme = 'xyz';\n this.tileSize = 512;\n this._loaded = false;\n\n this._options = extend({type: 'raster'}, options);\n extend(this, pick(options, ['url', 'scheme', 'tileSize']));\n }\n\n async load() {\n this._loaded = false;\n this.fire(new Event('dataloading', {dataType: 'source'}));\n this._tileJSONRequest = new AbortController();\n try {\n const tileJSON = await loadTileJson(this._options, this.map._requestManager, this._tileJSONRequest);\n this._tileJSONRequest = null;\n this._loaded = true;\n if (tileJSON) {\n extend(this, tileJSON);\n if (tileJSON.bounds) this.tileBounds = new TileBounds(tileJSON.bounds, this.minzoom, this.maxzoom);\n\n // `content` is included here to prevent a race condition where `Style#_updateSources` is called\n // before the TileJSON arrives. this makes sure the tiles needed are loaded once TileJSON arrives\n // ref: https://github.com/mapbox/mapbox-gl-js/pull/4347#discussion_r104418088\n this.fire(new Event('data', {dataType: 'source', sourceDataType: 'metadata'}));\n this.fire(new Event('data', {dataType: 'source', sourceDataType: 'content'}));\n }\n } catch (err) {\n this._tileJSONRequest = null;\n this.fire(new ErrorEvent(err));\n }\n }\n\n loaded(): boolean {\n return this._loaded;\n }\n\n onAdd(map: Map) {\n this.map = map;\n this.load();\n }\n\n onRemove() {\n if (this._tileJSONRequest) {\n this._tileJSONRequest.abort();\n this._tileJSONRequest = null;\n }\n }\n\n setSourceProperty(callback: Function) {\n if (this._tileJSONRequest) {\n this._tileJSONRequest.abort();\n this._tileJSONRequest = null;\n }\n\n callback();\n\n this.load();\n }\n\n /**\n * Sets the source `tiles` property and re-renders the map.\n *\n * @param tiles - An array of one or more tile source URLs, as in the raster tiles spec (See the [Style Specification](https://maplibre.org/maplibre-style-spec/)\n */\n setTiles(tiles: Array): this {\n this.setSourceProperty(() => {\n this._options.tiles = tiles;\n });\n\n return this;\n }\n\n /**\n * Sets the source `url` property and re-renders the map.\n *\n * @param url - A URL to a TileJSON resource. Supported protocols are `http:` and `https:`.\n */\n setUrl(url: string): this {\n this.setSourceProperty(() => {\n this.url = url;\n this._options.url = url;\n });\n\n return this;\n }\n\n serialize() {\n return extend({}, this._options);\n }\n\n hasTile(tileID: OverscaledTileID) {\n return !this.tileBounds || this.tileBounds.contains(tileID.canonical);\n }\n\n async loadTile(tile: Tile): Promise {\n const url = tile.tileID.canonical.url(this.tiles, this.map.getPixelRatio(), this.scheme);\n tile.abortController = new AbortController();\n try {\n const response = await ImageRequest.getImage(this.map._requestManager.transformRequest(url, ResourceType.Tile), tile.abortController, this.map._refreshExpiredTiles);\n delete tile.abortController;\n if (tile.aborted) {\n tile.state = 'unloaded';\n return;\n }\n if (response && response.data) {\n if (this.map._refreshExpiredTiles && response.cacheControl && response.expires) {\n tile.setExpiryData({cacheControl: response.cacheControl, expires: response.expires});\n }\n const context = this.map.painter.context;\n const gl = context.gl;\n const img = response.data;\n tile.texture = this.map.painter.getTileTexture(img.width);\n if (tile.texture) {\n tile.texture.update(img, {useMipmap: true});\n } else {\n tile.texture = new Texture(context, img, gl.RGBA, {useMipmap: true});\n tile.texture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE, gl.LINEAR_MIPMAP_NEAREST);\n }\n tile.state = 'loaded';\n }\n } catch (err) {\n delete tile.abortController;\n if (tile.aborted) {\n tile.state = 'unloaded';\n } else if (err) {\n tile.state = 'errored';\n throw err;\n }\n }\n }\n\n async abortTile(tile: Tile) {\n if (tile.abortController) {\n tile.abortController.abort();\n delete tile.abortController;\n }\n }\n\n async unloadTile(tile: Tile) {\n if (tile.texture) {\n this.map.painter.saveTileTexture(tile.texture);\n }\n }\n\n hasTransition() {\n return false;\n }\n}\n","import {ImageRequest} from '../util/image_request';\nimport {ResourceType} from '../util/request_manager';\nimport {extend, isImageBitmap, readImageUsingVideoFrame} from '../util/util';\nimport {Evented} from '../util/evented';\nimport {browser} from '../util/browser';\nimport {offscreenCanvasSupported} from '../util/offscreen_canvas_supported';\nimport {OverscaledTileID} from './tile_id';\nimport {RasterTileSource} from './raster_tile_source';\n// ensure DEMData is registered for worker transfer on main thread:\nimport '../data/dem_data';\nimport type {DEMEncoding} from '../data/dem_data';\n\nimport type {Source} from './source';\nimport type {Dispatcher} from '../util/dispatcher';\nimport type {Tile} from './tile';\nimport type {RasterDEMSourceSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport {isOffscreenCanvasDistorted} from '../util/offscreen_canvas_distorted';\nimport {RGBAImage} from '../util/image';\nimport {MessageType} from '../util/actor_messages';\n\n/**\n * A source containing raster DEM tiles (See the [Style Specification](https://maplibre.org/maplibre-style-spec/) for detailed documentation of options.)\n * This source can be used to show hillshading and 3D terrain\n *\n * @group Sources\n *\n * @example\n * ```ts\n * map.addSource('raster-dem-source', {\n * type: 'raster-dem',\n * url: 'https://demotiles.maplibre.org/terrain-tiles/tiles.json',\n * tileSize: 256\n * });\n * ```\n * @see [3D Terrain](https://maplibre.org/maplibre-gl-js/docs/examples/3d-terrain/)\n */\nexport class RasterDEMTileSource extends RasterTileSource implements Source {\n encoding: DEMEncoding;\n redFactor?: number;\n greenFactor?: number;\n blueFactor?: number;\n baseShift?: number;\n\n constructor(id: string, options: RasterDEMSourceSpecification, dispatcher: Dispatcher, eventedParent: Evented) {\n super(id, options, dispatcher, eventedParent);\n this.type = 'raster-dem';\n this.maxzoom = 22;\n this._options = extend({type: 'raster-dem'}, options);\n this.encoding = options.encoding || 'mapbox';\n this.redFactor = options.redFactor;\n this.greenFactor = options.greenFactor;\n this.blueFactor = options.blueFactor;\n this.baseShift = options.baseShift;\n }\n\n override async loadTile(tile: Tile): Promise {\n const url = tile.tileID.canonical.url(this.tiles, this.map.getPixelRatio(), this.scheme);\n const request = this.map._requestManager.transformRequest(url, ResourceType.Tile);\n tile.neighboringTiles = this._getNeighboringTiles(tile.tileID);\n tile.abortController = new AbortController();\n try {\n const response = await ImageRequest.getImage(request, tile.abortController, this.map._refreshExpiredTiles);\n delete tile.abortController;\n if (tile.aborted) {\n tile.state = 'unloaded';\n return;\n }\n if (response && response.data) {\n const img = response.data;\n if (this.map._refreshExpiredTiles && response.cacheControl && response.expires) {\n tile.setExpiryData({cacheControl: response.cacheControl, expires: response.expires});\n }\n const transfer = isImageBitmap(img) && offscreenCanvasSupported();\n const rawImageData = transfer ? img : await this.readImageNow(img);\n const params = {\n type: this.type,\n uid: tile.uid,\n source: this.id,\n rawImageData,\n encoding: this.encoding,\n redFactor: this.redFactor,\n greenFactor: this.greenFactor,\n blueFactor: this.blueFactor,\n baseShift: this.baseShift\n };\n\n if (!tile.actor || tile.state === 'expired') {\n tile.actor = this.dispatcher.getActor();\n /* eslint-disable require-atomic-updates */\n const data = await tile.actor.sendAsync({type: MessageType.loadDEMTile, data: params});\n tile.dem = data;\n tile.needsHillshadePrepare = true;\n tile.needsTerrainPrepare = true;\n tile.state = 'loaded';\n /* eslint-enable require-atomic-updates */\n }\n }\n } catch (err) {\n delete tile.abortController;\n if (tile.aborted) {\n tile.state = 'unloaded';\n } else if (err) {\n tile.state = 'errored';\n throw err;\n }\n }\n }\n\n async readImageNow(img: ImageBitmap | HTMLImageElement): Promise {\n if (typeof VideoFrame !== 'undefined' && isOffscreenCanvasDistorted()) {\n const width = img.width + 2;\n const height = img.height + 2;\n try {\n return new RGBAImage({width, height}, await readImageUsingVideoFrame(img, -1, -1, width, height));\n } catch (e) {\n // fall-back to browser canvas decoding\n }\n }\n return browser.getImageData(img, 1);\n }\n\n _getNeighboringTiles(tileID: OverscaledTileID) {\n const canonical = tileID.canonical;\n const dim = Math.pow(2, canonical.z);\n\n const px = (canonical.x - 1 + dim) % dim;\n const pxw = canonical.x === 0 ? tileID.wrap - 1 : tileID.wrap;\n const nx = (canonical.x + 1 + dim) % dim;\n const nxw = canonical.x + 1 === dim ? tileID.wrap + 1 : tileID.wrap;\n\n const neighboringTiles = {};\n // add adjacent tiles\n neighboringTiles[new OverscaledTileID(tileID.overscaledZ, pxw, canonical.z, px, canonical.y).key] = {backfilled: false};\n neighboringTiles[new OverscaledTileID(tileID.overscaledZ, nxw, canonical.z, nx, canonical.y).key] = {backfilled: false};\n\n // Add upper neighboringTiles\n if (canonical.y > 0) {\n neighboringTiles[new OverscaledTileID(tileID.overscaledZ, pxw, canonical.z, px, canonical.y - 1).key] = {backfilled: false};\n neighboringTiles[new OverscaledTileID(tileID.overscaledZ, tileID.wrap, canonical.z, canonical.x, canonical.y - 1).key] = {backfilled: false};\n neighboringTiles[new OverscaledTileID(tileID.overscaledZ, nxw, canonical.z, nx, canonical.y - 1).key] = {backfilled: false};\n }\n // Add lower neighboringTiles\n if (canonical.y + 1 < dim) {\n neighboringTiles[new OverscaledTileID(tileID.overscaledZ, pxw, canonical.z, px, canonical.y + 1).key] = {backfilled: false};\n neighboringTiles[new OverscaledTileID(tileID.overscaledZ, tileID.wrap, canonical.z, canonical.x, canonical.y + 1).key] = {backfilled: false};\n neighboringTiles[new OverscaledTileID(tileID.overscaledZ, nxw, canonical.z, nx, canonical.y + 1).key] = {backfilled: false};\n }\n\n return neighboringTiles;\n }\n\n async unloadTile(tile: Tile) {\n if (tile.demTexture) this.map.painter.saveTileTexture(tile.demTexture);\n if (tile.fbo) {\n tile.fbo.destroy();\n delete tile.fbo;\n }\n if (tile.dem) delete tile.dem;\n delete tile.neighboringTiles;\n\n tile.state = 'unloaded';\n if (tile.actor) {\n await tile.actor.sendAsync({type: MessageType.removeDEMTile, data: {type: this.type, uid: tile.uid, source: this.id}});\n }\n }\n}\n","import {Event, ErrorEvent, Evented} from '../util/evented';\n\nimport {extend, warnOnce} from '../util/util';\nimport {EXTENT} from '../data/extent';\nimport {ResourceType} from '../util/request_manager';\nimport {browser} from '../util/browser';\n\nimport type {Source} from './source';\nimport type {Map} from '../ui/map';\nimport type {Dispatcher} from '../util/dispatcher';\nimport type {Tile} from './tile';\nimport type {Actor} from '../util/actor';\nimport type {GeoJSONSourceSpecification, PromoteIdSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {GeoJSONSourceDiff} from './geojson_source_diff';\nimport type {GeoJSONWorkerOptions, LoadGeoJSONParameters} from './geojson_worker_source';\nimport {MessageType} from '../util/actor_messages';\n\n/**\n * Options object for GeoJSONSource.\n */\nexport type GeoJSONSourceOptions = GeoJSONSourceSpecification & {\n workerOptions?: GeoJSONWorkerOptions;\n collectResourceTiming?: boolean;\n data: GeoJSON.GeoJSON | string;\n}\n\nexport type GeoJSONSourceInternalOptions = {\n data?: GeoJSON.GeoJSON | string | undefined;\n cluster?: boolean;\n clusterMaxZoom?: number;\n clusterRadius?: number;\n clusterMinPoints?: number;\n generateId?: boolean;\n}\n\n/**\n * The cluster options to set\n */\nexport type SetClusterOptions = {\n /**\n * Whether or not to cluster\n */\n cluster?: boolean;\n /**\n * The cluster's max zoom\n */\n clusterMaxZoom?: number;\n /**\n * The cluster's radius\n */\n clusterRadius?: number;\n}\n\n/**\n * A source containing GeoJSON.\n * (See the [Style Specification](https://maplibre.org/maplibre-style-spec/#sources-geojson) for detailed documentation of options.)\n *\n * @group Sources\n *\n * @example\n * ```ts\n * map.addSource('some id', {\n * type: 'geojson',\n * data: 'https://d2ad6b4ur7yvpq.cloudfront.net/naturalearth-3.3.0/ne_10m_ports.geojson'\n * });\n * ```\n *\n * @example\n * ```ts\n * map.addSource('some id', {\n * type: 'geojson',\n * data: {\n * \"type\": \"FeatureCollection\",\n * \"features\": [{\n * \"type\": \"Feature\",\n * \"properties\": {},\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [\n * -76.53063297271729,\n * 39.18174077994108\n * ]\n * }\n * }]\n * }\n * });\n * ```\n *\n * @example\n * ```ts\n * map.getSource('some id').setData({\n * \"type\": \"FeatureCollection\",\n * \"features\": [{\n * \"type\": \"Feature\",\n * \"properties\": { \"name\": \"Null Island\" },\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [ 0, 0 ]\n * }\n * }]\n * });\n * ```\n * @see [Draw GeoJSON points](https://maplibre.org/maplibre-gl-js/docs/examples/geojson-markers/)\n * @see [Add a GeoJSON line](https://maplibre.org/maplibre-gl-js/docs/examples/geojson-line/)\n * @see [Create a heatmap from points](https://maplibre.org/maplibre-gl-js/docs/examples/heatmap-layer/)\n * @see [Create and style clusters](https://maplibre.org/maplibre-gl-js/docs/examples/cluster/)\n */\nexport class GeoJSONSource extends Evented implements Source {\n type: 'geojson';\n id: string;\n minzoom: number;\n maxzoom: number;\n tileSize: number;\n attribution: string;\n promoteId: PromoteIdSpecification;\n\n isTileClipped: boolean;\n reparseOverscaled: boolean;\n _data: GeoJSON.GeoJSON | string | undefined;\n _options: GeoJSONSourceInternalOptions;\n workerOptions: GeoJSONWorkerOptions;\n map: Map;\n actor: Actor;\n _pendingLoads: number;\n _collectResourceTiming: boolean;\n _removed: boolean;\n\n /** @internal */\n constructor(id: string, options: GeoJSONSourceOptions, dispatcher: Dispatcher, eventedParent: Evented) {\n super();\n\n this.id = id;\n\n // `type` is a property rather than a constant to make it easy for 3rd\n // parties to use GeoJSONSource to build their own source types.\n this.type = 'geojson';\n\n this.minzoom = 0;\n this.maxzoom = 18;\n this.tileSize = 512;\n this.isTileClipped = true;\n this.reparseOverscaled = true;\n this._removed = false;\n this._pendingLoads = 0;\n\n this.actor = dispatcher.getActor();\n this.setEventedParent(eventedParent);\n\n this._data = (options.data as any);\n this._options = extend({}, options);\n\n this._collectResourceTiming = options.collectResourceTiming;\n\n if (options.maxzoom !== undefined) this.maxzoom = options.maxzoom;\n if (options.type) this.type = options.type;\n if (options.attribution) this.attribution = options.attribution;\n this.promoteId = options.promoteId;\n\n const scale = EXTENT / this.tileSize;\n\n if (options.clusterMaxZoom !== undefined && this.maxzoom <= options.clusterMaxZoom) {\n warnOnce(`The maxzoom value \"${this.maxzoom}\" is expected to be greater than the clusterMaxZoom value \"${options.clusterMaxZoom}\".`);\n }\n\n // sent to the worker, along with `url: ...` or `data: literal geojson`,\n // so that it can load/parse/index the geojson data\n // extending with `options.workerOptions` helps to make it easy for\n // third-party sources to hack/reuse GeoJSONSource.\n this.workerOptions = extend({\n source: this.id,\n cluster: options.cluster || false,\n geojsonVtOptions: {\n buffer: (options.buffer !== undefined ? options.buffer : 128) * scale,\n tolerance: (options.tolerance !== undefined ? options.tolerance : 0.375) * scale,\n extent: EXTENT,\n maxZoom: this.maxzoom,\n lineMetrics: options.lineMetrics || false,\n generateId: options.generateId || false\n },\n superclusterOptions: {\n maxZoom: options.clusterMaxZoom !== undefined ? options.clusterMaxZoom : this.maxzoom - 1,\n minPoints: Math.max(2, options.clusterMinPoints || 2),\n extent: EXTENT,\n radius: (options.clusterRadius || 50) * scale,\n log: false,\n generateId: options.generateId || false\n },\n clusterProperties: options.clusterProperties,\n filter: options.filter\n }, options.workerOptions);\n\n // send the promoteId to the worker to have more flexible updates, but only if it is a string\n if (typeof this.promoteId === 'string') {\n this.workerOptions.promoteId = this.promoteId;\n }\n }\n\n async load() {\n await this._updateWorkerData();\n }\n\n onAdd(map: Map) {\n this.map = map;\n this.load();\n }\n\n /**\n * Sets the GeoJSON data and re-renders the map.\n *\n * @param data - A GeoJSON data object or a URL to one. The latter is preferable in the case of large GeoJSON files.\n */\n setData(data: GeoJSON.GeoJSON | string): this {\n this._data = data;\n this._updateWorkerData();\n\n return this;\n }\n\n /**\n * Updates the source's GeoJSON, and re-renders the map.\n *\n * For sources with lots of features, this method can be used to make updates more quickly.\n *\n * This approach requires unique IDs for every feature in the source. The IDs can either be specified on the feature,\n * or by using the promoteId option to specify which property should be used as the ID.\n *\n * It is an error to call updateData on a source that did not have unique IDs for each of its features already.\n *\n * Updates are applied on a best-effort basis, updating an ID that does not exist will not result in an error.\n *\n * @param diff - The changes that need to be applied.\n */\n updateData(diff: GeoJSONSourceDiff): this {\n this._updateWorkerData(diff);\n\n return this;\n }\n\n /**\n * Allows to get the source's actual GeoJSON data.\n *\n * @returns a promise which resolves to the source's actual GeoJSON data\n */\n async getData(): Promise {\n const options: LoadGeoJSONParameters = extend({type: this.type}, this.workerOptions);\n return this.actor.sendAsync({type: MessageType.getData, data: options});\n }\n\n /**\n * To disable/enable clustering on the source options\n * @param options - The options to set\n * @example\n * ```ts\n * map.getSource('some id').setClusterOptions({cluster: false});\n * map.getSource('some id').setClusterOptions({cluster: false, clusterRadius: 50, clusterMaxZoom: 14});\n * ```\n */\n setClusterOptions(options: SetClusterOptions): this {\n this.workerOptions.cluster = options.cluster;\n if (options) {\n if (options.clusterRadius !== undefined) this.workerOptions.superclusterOptions.radius = options.clusterRadius;\n if (options.clusterMaxZoom !== undefined) this.workerOptions.superclusterOptions.maxZoom = options.clusterMaxZoom;\n }\n this._updateWorkerData();\n return this;\n }\n\n /**\n * For clustered sources, fetches the zoom at which the given cluster expands.\n *\n * @param clusterId - The value of the cluster's `cluster_id` property.\n * @returns a promise that is resolved with the zoom number\n */\n getClusterExpansionZoom(clusterId: number): Promise {\n return this.actor.sendAsync({type: MessageType.getClusterExpansionZoom, data: {type: this.type, clusterId, source: this.id}});\n }\n\n /**\n * For clustered sources, fetches the children of the given cluster on the next zoom level (as an array of GeoJSON features).\n *\n * @param clusterId - The value of the cluster's `cluster_id` property.\n * @returns a promise that is resolved when the features are retrieved\n */\n getClusterChildren(clusterId: number): Promise> {\n return this.actor.sendAsync({type: MessageType.getClusterChildren, data: {type: this.type, clusterId, source: this.id}});\n }\n\n /**\n * For clustered sources, fetches the original points that belong to the cluster (as an array of GeoJSON features).\n *\n * @param clusterId - The value of the cluster's `cluster_id` property.\n * @param limit - The maximum number of features to return.\n * @param offset - The number of features to skip (e.g. for pagination).\n * @returns a promise that is resolved when the features are retrieved\n * @example\n * Retrieve cluster leaves on click\n * ```ts\n * map.on('click', 'clusters', (e) => {\n * let features = map.queryRenderedFeatures(e.point, {\n * layers: ['clusters']\n * });\n *\n * let clusterId = features[0].properties.cluster_id;\n * let pointCount = features[0].properties.point_count;\n * let clusterSource = map.getSource('clusters');\n *\n * const features = await clusterSource.getClusterLeaves(clusterId, pointCount);\n * // Print cluster leaves in the console\n * console.log('Cluster leaves:', features);\n * });\n * ```\n */\n getClusterLeaves(clusterId: number, limit: number, offset: number): Promise> {\n return this.actor.sendAsync({type: MessageType.getClusterLeaves, data: {\n type: this.type,\n source: this.id,\n clusterId,\n limit,\n offset\n }});\n }\n\n /**\n * Responsible for invoking WorkerSource's geojson.loadData target, which\n * handles loading the geojson data and preparing to serve it up as tiles,\n * using geojson-vt or supercluster as appropriate.\n * @param diff - the diff object\n */\n async _updateWorkerData(diff?: GeoJSONSourceDiff) {\n const options: LoadGeoJSONParameters = extend({type: this.type}, this.workerOptions);\n if (diff) {\n options.dataDiff = diff;\n } else if (typeof this._data === 'string') {\n options.request = this.map._requestManager.transformRequest(browser.resolveURL(this._data as string), ResourceType.Source);\n options.request.collectResourceTiming = this._collectResourceTiming;\n } else {\n options.data = JSON.stringify(this._data);\n }\n this._pendingLoads++;\n this.fire(new Event('dataloading', {dataType: 'source'}));\n try {\n const result = await this.actor.sendAsync({type: MessageType.loadData, data: options});\n this._pendingLoads--;\n if (this._removed || result.abandoned) {\n this.fire(new Event('dataabort', {dataType: 'source'}));\n return;\n }\n\n let resourceTiming: PerformanceResourceTiming[] = null;\n if (result.resourceTiming && result.resourceTiming[this.id]) {\n resourceTiming = result.resourceTiming[this.id].slice(0);\n }\n\n const data: any = {dataType: 'source'};\n if (this._collectResourceTiming && resourceTiming && resourceTiming.length > 0) {\n extend(data, {resourceTiming});\n }\n\n // although GeoJSON sources contain no metadata, we fire this event to let the SourceCache\n // know its ok to start requesting tiles.\n this.fire(new Event('data', {...data, sourceDataType: 'metadata'}));\n this.fire(new Event('data', {...data, sourceDataType: 'content'}));\n } catch (err) {\n this._pendingLoads--;\n if (this._removed) {\n this.fire(new Event('dataabort', {dataType: 'source'}));\n return;\n }\n this.fire(new ErrorEvent(err));\n }\n }\n\n loaded(): boolean {\n return this._pendingLoads === 0;\n }\n\n async loadTile(tile: Tile): Promise {\n const message = !tile.actor ? MessageType.loadTile : MessageType.reloadTile;\n tile.actor = this.actor;\n const params = {\n type: this.type,\n uid: tile.uid,\n tileID: tile.tileID,\n zoom: tile.tileID.overscaledZ,\n maxZoom: this.maxzoom,\n tileSize: this.tileSize,\n source: this.id,\n pixelRatio: this.map.getPixelRatio(),\n showCollisionBoxes: this.map.showCollisionBoxes,\n promoteId: this.promoteId\n };\n\n tile.abortController = new AbortController();\n const data = await this.actor.sendAsync({type: message, data: params}, tile.abortController);\n delete tile.abortController;\n tile.unloadVectorData();\n\n if (!tile.aborted) {\n tile.loadVectorData(data, this.map.painter, message === MessageType.reloadTile);\n }\n }\n\n async abortTile(tile: Tile) {\n if (tile.abortController) {\n tile.abortController.abort();\n delete tile.abortController;\n }\n tile.aborted = true;\n }\n\n async unloadTile(tile: Tile) {\n tile.unloadVectorData();\n await this.actor.sendAsync({type: MessageType.removeTile, data: {uid: tile.uid, type: this.type, source: this.id}});\n }\n\n onRemove() {\n this._removed = true;\n this.actor.sendAsync({type: MessageType.removeSource, data: {type: this.type, source: this.id}});\n }\n\n serialize(): GeoJSONSourceSpecification {\n return extend({}, this._options, {\n type: this.type,\n data: this._data\n });\n }\n\n hasTransition() {\n return false;\n }\n}\n","import {createLayout} from '../util/struct_array';\n\nexport default createLayout([\n {name: 'a_pos', type: 'Int16', components: 2},\n {name: 'a_texture_pos', type: 'Int16', components: 2}\n]);\n","import {CanonicalTileID} from './tile_id';\nimport {Event, ErrorEvent, Evented} from '../util/evented';\nimport {ImageRequest} from '../util/image_request';\nimport {ResourceType} from '../util/request_manager';\nimport {EXTENT} from '../data/extent';\nimport {RasterBoundsArray} from '../data/array_types.g';\nimport rasterBoundsAttributes from '../data/raster_bounds_attributes';\nimport {SegmentVector} from '../data/segment';\nimport {Texture} from '../render/texture';\nimport {MercatorCoordinate} from '../geo/mercator_coordinate';\n\nimport type {Source} from './source';\nimport type {CanvasSourceSpecification} from './canvas_source';\nimport type {Map} from '../ui/map';\nimport type {Dispatcher} from '../util/dispatcher';\nimport type {Tile} from './tile';\nimport type {VertexBuffer} from '../gl/vertex_buffer';\nimport type {\n ImageSourceSpecification,\n VideoSourceSpecification\n} from '@maplibre/maplibre-gl-style-spec';\n\n/**\n * Four geographical coordinates,\n * represented as arrays of longitude and latitude numbers, which define the corners of the image.\n * The coordinates start at the top left corner of the image and proceed in clockwise order.\n * They do not have to represent a rectangle.\n */\nexport type Coordinates = [[number, number], [number, number], [number, number], [number, number]];\n\n/**\n * The options object for the {@link ImageSource#updateImage} method\n */\nexport type UpdateImageOptions = {\n /**\n * Required image URL.\n */\n url: string;\n /**\n * The image coordinates\n */\n coordinates?: Coordinates;\n}\n\n/**\n * A data source containing an image.\n * (See the [Style Specification](https://maplibre.org/maplibre-style-spec/#sources-image) for detailed documentation of options.)\n *\n * @group Sources\n *\n * @example\n * ```ts\n * // add to map\n * map.addSource('some id', {\n * type: 'image',\n * url: 'https://www.maplibre.org/images/foo.png',\n * coordinates: [\n * [-76.54, 39.18],\n * [-76.52, 39.18],\n * [-76.52, 39.17],\n * [-76.54, 39.17]\n * ]\n * });\n *\n * // update coordinates\n * let mySource = map.getSource('some id');\n * mySource.setCoordinates([\n * [-76.54335737228394, 39.18579907229748],\n * [-76.52803659439087, 39.1838364847587],\n * [-76.5295386314392, 39.17683392507606],\n * [-76.54520273208618, 39.17876344106642]\n * ]);\n *\n * // update url and coordinates simultaneously\n * mySource.updateImage({\n * url: 'https://www.maplibre.org/images/bar.png',\n * coordinates: [\n * [-76.54335737228394, 39.18579907229748],\n * [-76.52803659439087, 39.1838364847587],\n * [-76.5295386314392, 39.17683392507606],\n * [-76.54520273208618, 39.17876344106642]\n * ]\n * })\n *\n * map.removeSource('some id'); // remove\n * ```\n */\nexport class ImageSource extends Evented implements Source {\n type: string;\n id: string;\n minzoom: number;\n maxzoom: number;\n tileSize: number;\n url: string;\n\n coordinates: Coordinates;\n tiles: {[_: string]: Tile};\n options: any;\n dispatcher: Dispatcher;\n map: Map;\n texture: Texture | null;\n image: HTMLImageElement | ImageBitmap;\n tileID: CanonicalTileID;\n _boundsArray: RasterBoundsArray;\n boundsBuffer: VertexBuffer;\n boundsSegments: SegmentVector;\n _loaded: boolean;\n _request: AbortController;\n\n /** @internal */\n constructor(id: string, options: ImageSourceSpecification | VideoSourceSpecification | CanvasSourceSpecification, dispatcher: Dispatcher, eventedParent: Evented) {\n super();\n this.id = id;\n this.dispatcher = dispatcher;\n this.coordinates = options.coordinates;\n\n this.type = 'image';\n this.minzoom = 0;\n this.maxzoom = 22;\n this.tileSize = 512;\n this.tiles = {};\n this._loaded = false;\n\n this.setEventedParent(eventedParent);\n\n this.options = options;\n }\n\n async load(newCoordinates?: Coordinates): Promise {\n this._loaded = false;\n this.fire(new Event('dataloading', {dataType: 'source'}));\n\n this.url = this.options.url;\n\n this._request = new AbortController();\n try {\n const image = await ImageRequest.getImage(this.map._requestManager.transformRequest(this.url, ResourceType.Image), this._request);\n this._request = null;\n this._loaded = true;\n\n if (image && image.data) {\n this.image = image.data;\n if (newCoordinates) {\n this.coordinates = newCoordinates;\n }\n this._finishLoading();\n }\n } catch (err) {\n this._request = null;\n this._loaded = true;\n this.fire(new ErrorEvent(err));\n }\n }\n\n loaded(): boolean {\n return this._loaded;\n }\n\n /**\n * Updates the image URL and, optionally, the coordinates. To avoid having the image flash after changing,\n * set the `raster-fade-duration` paint property on the raster layer to 0.\n *\n * @param options - The options object.\n */\n updateImage(options: UpdateImageOptions): this {\n if (!options.url) {\n return this;\n }\n\n if (this._request) {\n this._request.abort();\n this._request = null;\n }\n\n this.options.url = options.url;\n this.load(options.coordinates).finally(() => { this.texture = null; });\n return this;\n }\n\n _finishLoading() {\n if (this.map) {\n this.setCoordinates(this.coordinates);\n this.fire(new Event('data', {dataType: 'source', sourceDataType: 'metadata'}));\n }\n }\n\n onAdd(map: Map) {\n this.map = map;\n this.load();\n }\n\n onRemove() {\n if (this._request) {\n this._request.abort();\n this._request = null;\n }\n }\n\n /**\n * Sets the image's coordinates and re-renders the map.\n *\n * @param coordinates - Four geographical coordinates,\n * represented as arrays of longitude and latitude numbers, which define the corners of the image.\n * The coordinates start at the top left corner of the image and proceed in clockwise order.\n * They do not have to represent a rectangle.\n */\n setCoordinates(coordinates: Coordinates): this {\n this.coordinates = coordinates;\n\n // Calculate which mercator tile is suitable for rendering the video in\n // and create a buffer with the corner coordinates. These coordinates\n // may be outside the tile, because raster tiles aren't clipped when rendering.\n\n // transform the geo coordinates into (zoom 0) tile space coordinates\n const cornerCoords = coordinates.map(MercatorCoordinate.fromLngLat);\n\n // Compute the coordinates of the tile we'll use to hold this image's\n // render data\n this.tileID = getCoordinatesCenterTileID(cornerCoords);\n\n // Constrain min/max zoom to our tile's zoom level in order to force\n // SourceCache to request this tile (no matter what the map's zoom\n // level)\n this.minzoom = this.maxzoom = this.tileID.z;\n\n // Transform the corner coordinates into the coordinate space of our\n // tile.\n const tileCoords = cornerCoords.map((coord) => this.tileID.getTilePoint(coord)._round());\n\n this._boundsArray = new RasterBoundsArray();\n this._boundsArray.emplaceBack(tileCoords[0].x, tileCoords[0].y, 0, 0);\n this._boundsArray.emplaceBack(tileCoords[1].x, tileCoords[1].y, EXTENT, 0);\n this._boundsArray.emplaceBack(tileCoords[3].x, tileCoords[3].y, 0, EXTENT);\n this._boundsArray.emplaceBack(tileCoords[2].x, tileCoords[2].y, EXTENT, EXTENT);\n\n if (this.boundsBuffer) {\n this.boundsBuffer.destroy();\n delete this.boundsBuffer;\n }\n\n this.fire(new Event('data', {dataType: 'source', sourceDataType: 'content'}));\n return this;\n }\n\n prepare() {\n if (Object.keys(this.tiles).length === 0 || !this.image) {\n return;\n }\n\n const context = this.map.painter.context;\n const gl = context.gl;\n\n if (!this.boundsBuffer) {\n this.boundsBuffer = context.createVertexBuffer(this._boundsArray, rasterBoundsAttributes.members);\n }\n\n if (!this.boundsSegments) {\n this.boundsSegments = SegmentVector.simpleSegment(0, 0, 4, 2);\n }\n\n if (!this.texture) {\n this.texture = new Texture(context, this.image, gl.RGBA);\n this.texture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n }\n\n let newTilesLoaded = false;\n for (const w in this.tiles) {\n const tile = this.tiles[w];\n if (tile.state !== 'loaded') {\n tile.state = 'loaded';\n tile.texture = this.texture;\n newTilesLoaded = true;\n }\n }\n\n if (newTilesLoaded) {\n this.fire(new Event('data', {dataType: 'source', sourceDataType: 'idle', sourceId: this.id}));\n }\n }\n\n async loadTile(tile: Tile): Promise {\n // We have a single tile -- whose coordinates are this.tileID -- that\n // covers the image we want to render. If that's the one being\n // requested, set it up with the image; otherwise, mark the tile as\n // `errored` to indicate that we have no data for it.\n // If the world wraps, we may have multiple \"wrapped\" copies of the\n // single tile.\n if (this.tileID && this.tileID.equals(tile.tileID.canonical)) {\n this.tiles[String(tile.tileID.wrap)] = tile;\n tile.buckets = {};\n } else {\n tile.state = 'errored';\n }\n }\n\n serialize(): ImageSourceSpecification | VideoSourceSpecification | CanvasSourceSpecification {\n return {\n type: 'image',\n url: this.options.url,\n coordinates: this.coordinates\n };\n }\n\n hasTransition() {\n return false;\n }\n}\n\n/**\n * Given a list of coordinates, get their center as a coordinate.\n *\n * @returns centerpoint\n * @internal\n */\nexport function getCoordinatesCenterTileID(coords: Array) {\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for (const coord of coords) {\n minX = Math.min(minX, coord.x);\n minY = Math.min(minY, coord.y);\n maxX = Math.max(maxX, coord.x);\n maxY = Math.max(maxY, coord.y);\n }\n\n const dx = maxX - minX;\n const dy = maxY - minY;\n const dMax = Math.max(dx, dy);\n const zoom = Math.max(0, Math.floor(-Math.log(dMax) / Math.LN2));\n const tilesAtZoom = Math.pow(2, zoom);\n\n return new CanonicalTileID(\n zoom,\n Math.floor((minX + maxX) / 2 * tilesAtZoom),\n Math.floor((minY + maxY) / 2 * tilesAtZoom));\n}\n","import {getVideo} from '../util/ajax';\nimport {ResourceType} from '../util/request_manager';\n\nimport {ImageSource} from './image_source';\nimport rasterBoundsAttributes from '../data/raster_bounds_attributes';\nimport {SegmentVector} from '../data/segment';\nimport {Texture} from '../render/texture';\nimport {Event, ErrorEvent} from '../util/evented';\nimport {ValidationError} from '@maplibre/maplibre-gl-style-spec';\n\nimport type {Map} from '../ui/map';\nimport type {Dispatcher} from '../util/dispatcher';\nimport type {Evented} from '../util/evented';\nimport type {VideoSourceSpecification} from '@maplibre/maplibre-gl-style-spec';\n\n/**\n * A data source containing video.\n * (See the [Style Specification](https://maplibre.org/maplibre-style-spec/#sources-video) for detailed documentation of options.)\n *\n * @group Sources\n *\n * @example\n * ```ts\n * // add to map\n * map.addSource('some id', {\n * type: 'video',\n * url: [\n * 'https://www.mapbox.com/blog/assets/baltimore-smoke.mp4',\n * 'https://www.mapbox.com/blog/assets/baltimore-smoke.webm'\n * ],\n * coordinates: [\n * [-76.54, 39.18],\n * [-76.52, 39.18],\n * [-76.52, 39.17],\n * [-76.54, 39.17]\n * ]\n * });\n *\n * // update\n * let mySource = map.getSource('some id');\n * mySource.setCoordinates([\n * [-76.54335737228394, 39.18579907229748],\n * [-76.52803659439087, 39.1838364847587],\n * [-76.5295386314392, 39.17683392507606],\n * [-76.54520273208618, 39.17876344106642]\n * ]);\n *\n * map.removeSource('some id'); // remove\n * ```\n * @see [Add a video](https://maplibre.org/maplibre-gl-js/docs/examples/video-on-a-map/)\n *\n * Note that when rendered as a raster layer, the layer's `raster-fade-duration` property will cause the video to fade in.\n * This happens when playback is started, paused and resumed, or when the video's coordinates are updated. To avoid this behavior,\n * set the layer's `raster-fade-duration` property to `0`.\n */\nexport class VideoSource extends ImageSource {\n options: VideoSourceSpecification;\n urls: Array;\n video: HTMLVideoElement;\n roundZoom: boolean;\n\n constructor(id: string, options: VideoSourceSpecification, dispatcher: Dispatcher, eventedParent: Evented) {\n super(id, options, dispatcher, eventedParent);\n this.roundZoom = true;\n this.type = 'video';\n this.options = options;\n }\n\n async load() {\n this._loaded = false;\n const options = this.options;\n\n this.urls = [];\n for (const url of options.urls) {\n this.urls.push(this.map._requestManager.transformRequest(url, ResourceType.Source).url);\n }\n try {\n const video = await getVideo(this.urls);\n this._loaded = true;\n if (!video) {\n return;\n }\n this.video = video;\n this.video.loop = true;\n\n // Start repainting when video starts playing. hasTransition() will then return\n // true to trigger additional frames as long as the videos continues playing.\n this.video.addEventListener('playing', () => {\n this.map.triggerRepaint();\n });\n\n if (this.map) {\n this.video.play();\n }\n\n this._finishLoading();\n } catch (err) {\n this.fire(new ErrorEvent(err));\n }\n }\n\n /**\n * Pauses the video.\n */\n pause() {\n if (this.video) {\n this.video.pause();\n }\n }\n\n /**\n * Plays the video.\n */\n play() {\n if (this.video) {\n this.video.play();\n }\n }\n\n /**\n * Sets playback to a timestamp, in seconds.\n */\n seek(seconds: number) {\n if (this.video) {\n const seekableRange = this.video.seekable;\n if (seconds < seekableRange.start(0) || seconds > seekableRange.end(0)) {\n this.fire(new ErrorEvent(new ValidationError(`sources.${this.id}`, null, `Playback for this video can be set only between the ${seekableRange.start(0)} and ${seekableRange.end(0)}-second mark.`)));\n } else this.video.currentTime = seconds;\n }\n }\n\n /**\n * Returns the HTML `video` element.\n *\n * @returns The HTML `video` element.\n */\n getVideo(): HTMLVideoElement {\n return this.video;\n }\n\n onAdd(map: Map) {\n if (this.map) return;\n this.map = map;\n this.load();\n if (this.video) {\n this.video.play();\n this.setCoordinates(this.coordinates);\n }\n }\n\n /**\n * Sets the video's coordinates and re-renders the map.\n */\n prepare(): this {\n if (Object.keys(this.tiles).length === 0 || this.video.readyState < 2) {\n return; // not enough data for current position\n }\n\n const context = this.map.painter.context;\n const gl = context.gl;\n\n if (!this.boundsBuffer) {\n this.boundsBuffer = context.createVertexBuffer(this._boundsArray, rasterBoundsAttributes.members);\n }\n\n if (!this.boundsSegments) {\n this.boundsSegments = SegmentVector.simpleSegment(0, 0, 4, 2);\n }\n\n if (!this.texture) {\n this.texture = new Texture(context, this.video, gl.RGBA);\n this.texture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n } else if (!this.video.paused) {\n this.texture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n gl.texSubImage2D(gl.TEXTURE_2D, 0, 0, 0, gl.RGBA, gl.UNSIGNED_BYTE, this.video);\n }\n\n let newTilesLoaded = false;\n for (const w in this.tiles) {\n const tile = this.tiles[w];\n if (tile.state !== 'loaded') {\n tile.state = 'loaded';\n tile.texture = this.texture;\n newTilesLoaded = true;\n }\n }\n\n if (newTilesLoaded) {\n this.fire(new Event('data', {dataType: 'source', sourceDataType: 'idle', sourceId: this.id}));\n }\n }\n\n serialize(): VideoSourceSpecification {\n return {\n type: 'video',\n urls: this.urls,\n coordinates: this.coordinates\n };\n }\n\n hasTransition() {\n return this.video && !this.video.paused;\n }\n}\n","import {ImageSource} from './image_source';\n\nimport rasterBoundsAttributes from '../data/raster_bounds_attributes';\nimport {SegmentVector} from '../data/segment';\nimport {Texture} from '../render/texture';\nimport {Event, ErrorEvent} from '../util/evented';\nimport {ValidationError} from '@maplibre/maplibre-gl-style-spec';\n\nimport type {Map} from '../ui/map';\nimport type {Dispatcher} from '../util/dispatcher';\nimport type {Evented} from '../util/evented';\n\n/**\n * Options to add a canvas source type to the map.\n */\nexport type CanvasSourceSpecification = {\n /**\n * Source type. Must be `\"canvas\"`.\n */\n type: 'canvas';\n /**\n * Four geographical coordinates denoting where to place the corners of the canvas, specified in `[longitude, latitude]` pairs.\n */\n coordinates: [[number, number], [number, number], [number, number], [number, number]];\n /**\n * Whether the canvas source is animated. If the canvas is static (i.e. pixels do not need to be re-read on every frame), `animate` should be set to `false` to improve performance.\n * @defaultValue true\n */\n animate?: boolean;\n /**\n * Canvas source from which to read pixels. Can be a string representing the ID of the canvas element, or the `HTMLCanvasElement` itself.\n */\n canvas?: string | HTMLCanvasElement;\n};\n\n/**\n * A data source containing the contents of an HTML canvas. See {@link CanvasSourceSpecification} for detailed documentation of options.\n *\n * @group Sources\n *\n * @example\n * ```ts\n * // add to map\n * map.addSource('some id', {\n * type: 'canvas',\n * canvas: 'idOfMyHTMLCanvas',\n * animate: true,\n * coordinates: [\n * [-76.54, 39.18],\n * [-76.52, 39.18],\n * [-76.52, 39.17],\n * [-76.54, 39.17]\n * ]\n * });\n *\n * // update\n * let mySource = map.getSource('some id');\n * mySource.setCoordinates([\n * [-76.54335737228394, 39.18579907229748],\n * [-76.52803659439087, 39.1838364847587],\n * [-76.5295386314392, 39.17683392507606],\n * [-76.54520273208618, 39.17876344106642]\n * ]);\n *\n * map.removeSource('some id'); // remove\n * ```\n */\nexport class CanvasSource extends ImageSource {\n options: CanvasSourceSpecification;\n animate: boolean;\n canvas: HTMLCanvasElement;\n width: number;\n height: number;\n /**\n * Enables animation. The image will be copied from the canvas to the map on each frame.\n */\n play: () => void;\n /**\n * Disables animation. The map will display a static copy of the canvas image.\n */\n pause: () => void;\n _playing: boolean;\n\n /** @internal */\n constructor(id: string, options: CanvasSourceSpecification, dispatcher: Dispatcher, eventedParent: Evented) {\n super(id, options, dispatcher, eventedParent);\n\n // We build in some validation here, since canvas sources aren't included in the style spec:\n if (!options.coordinates) {\n this.fire(new ErrorEvent(new ValidationError(`sources.${id}`, null, 'missing required property \"coordinates\"')));\n } else if (!Array.isArray(options.coordinates) || options.coordinates.length !== 4 ||\n options.coordinates.some(c => !Array.isArray(c) || c.length !== 2 || c.some(l => typeof l !== 'number'))) {\n this.fire(new ErrorEvent(new ValidationError(`sources.${id}`, null, '\"coordinates\" property must be an array of 4 longitude/latitude array pairs')));\n }\n\n if (options.animate && typeof options.animate !== 'boolean') {\n this.fire(new ErrorEvent(new ValidationError(`sources.${id}`, null, 'optional \"animate\" property must be a boolean value')));\n }\n\n if (!options.canvas) {\n this.fire(new ErrorEvent(new ValidationError(`sources.${id}`, null, 'missing required property \"canvas\"')));\n } else if (typeof options.canvas !== 'string' && !(options.canvas instanceof HTMLCanvasElement)) {\n this.fire(new ErrorEvent(new ValidationError(`sources.${id}`, null, '\"canvas\" must be either a string representing the ID of the canvas element from which to read, or an HTMLCanvasElement instance')));\n }\n\n this.options = options;\n this.animate = options.animate !== undefined ? options.animate : true;\n }\n\n async load() {\n this._loaded = true;\n if (!this.canvas) {\n this.canvas = (this.options.canvas instanceof HTMLCanvasElement) ?\n this.options.canvas :\n document.getElementById(this.options.canvas) as HTMLCanvasElement;\n // cast to HTMLCanvasElement in else of ternary\n // should we do a safety check and throw if it's not actually HTMLCanvasElement?\n }\n this.width = this.canvas.width;\n this.height = this.canvas.height;\n\n if (this._hasInvalidDimensions()) {\n this.fire(new ErrorEvent(new Error('Canvas dimensions cannot be less than or equal to zero.')));\n return;\n }\n\n this.play = function() {\n this._playing = true;\n this.map.triggerRepaint();\n };\n\n this.pause = function() {\n if (this._playing) {\n this.prepare();\n this._playing = false;\n }\n };\n\n this._finishLoading();\n }\n\n /**\n * Returns the HTML `canvas` element.\n *\n * @returns The HTML `canvas` element.\n */\n getCanvas(): HTMLCanvasElement {\n return this.canvas;\n }\n\n onAdd(map: Map) {\n this.map = map;\n this.load();\n if (this.canvas) {\n if (this.animate) this.play();\n }\n }\n\n onRemove() {\n this.pause();\n }\n\n prepare() {\n let resize = false;\n if (this.canvas.width !== this.width) {\n this.width = this.canvas.width;\n resize = true;\n }\n if (this.canvas.height !== this.height) {\n this.height = this.canvas.height;\n resize = true;\n }\n\n if (this._hasInvalidDimensions()) return;\n\n if (Object.keys(this.tiles).length === 0) return; // not enough data for current position\n\n const context = this.map.painter.context;\n const gl = context.gl;\n\n if (!this.boundsBuffer) {\n this.boundsBuffer = context.createVertexBuffer(this._boundsArray, rasterBoundsAttributes.members);\n }\n\n if (!this.boundsSegments) {\n this.boundsSegments = SegmentVector.simpleSegment(0, 0, 4, 2);\n }\n\n if (!this.texture) {\n this.texture = new Texture(context, this.canvas, gl.RGBA, {premultiply: true});\n } else if (resize || this._playing) {\n this.texture.update(this.canvas, {premultiply: true});\n }\n\n let newTilesLoaded = false;\n for (const w in this.tiles) {\n const tile = this.tiles[w];\n if (tile.state !== 'loaded') {\n tile.state = 'loaded';\n tile.texture = this.texture;\n newTilesLoaded = true;\n }\n }\n\n if (newTilesLoaded) {\n this.fire(new Event('data', {dataType: 'source', sourceDataType: 'idle', sourceId: this.id}));\n }\n }\n\n serialize(): CanvasSourceSpecification {\n return {\n type: 'canvas',\n coordinates: this.coordinates\n };\n }\n\n hasTransition() {\n return this._playing;\n }\n\n _hasInvalidDimensions() {\n for (const x of [this.canvas.width, this.canvas.height]) {\n if (isNaN(x) || x <= 0) return true;\n }\n return false;\n }\n}\n","import {VectorTileSource} from '../source/vector_tile_source';\nimport {RasterTileSource} from '../source/raster_tile_source';\nimport {RasterDEMTileSource} from '../source/raster_dem_tile_source';\nimport {GeoJSONSource} from '../source/geojson_source';\nimport {VideoSource} from '../source/video_source';\nimport {ImageSource} from '../source/image_source';\nimport {CanvasSource} from '../source/canvas_source';\nimport {Dispatcher} from '../util/dispatcher';\n\nimport type {SourceSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {Event, Evented} from '../util/evented';\nimport type {Map} from '../ui/map';\nimport type {Tile} from './tile';\nimport type {OverscaledTileID, CanonicalTileID} from './tile_id';\nimport type {CanvasSourceSpecification} from '../source/canvas_source';\n\nconst registeredSources = {} as {[key:string]: SourceClass};\n\n/**\n * The `Source` interface must be implemented by each source type, including \"core\" types (`vector`, `raster`,\n * `video`, etc.) and all custom, third-party types.\n *\n * **Event** `data` - Fired with `{dataType: 'source', sourceDataType: 'metadata'}` to indicate that any necessary metadata\n * has been loaded so that it's okay to call `loadTile`; and with `{dataType: 'source', sourceDataType: 'content'}`\n * to indicate that the source data has changed, so that any current caches should be flushed.\n *\n * @group Sources\n */\nexport interface Source {\n readonly type: string;\n /**\n * The id for the source. Must not be used by any existing source.\n */\n id: string;\n /**\n * The minimum zoom level for the source.\n */\n minzoom: number;\n /**\n * The maximum zoom level for the source.\n */\n maxzoom: number;\n /**\n * The tile size for the source.\n */\n tileSize: number;\n /**\n * The attribution for the source.\n */\n attribution?: string;\n /**\n * `true` if zoom levels are rounded to the nearest integer in the source data, `false` if they are floor-ed to the nearest integer.\n */\n roundZoom?: boolean;\n /**\n * `false` if tiles can be drawn outside their boundaries, `true` if they cannot.\n */\n isTileClipped?: boolean;\n tileID?: CanonicalTileID;\n /**\n * `true` if tiles should be sent back to the worker for each overzoomed zoom level, `false` if not.\n */\n reparseOverscaled?: boolean;\n vectorLayerIds?: Array;\n /**\n * True if the source has transition, false otherwise.\n */\n hasTransition(): boolean;\n /**\n * True if the source is loaded, false otherwise.\n */\n loaded(): boolean;\n /**\n * An ability to fire an event to all the listeners, see {@link Evented}\n * @param event - The event to fire\n */\n fire(event: Event): unknown;\n /**\n * This method is called when the source is added to the map.\n * @param map - The map instance\n */\n onAdd?(map: Map): void;\n /**\n * This method is called when the source is removed from the map.\n * @param map - The map instance\n */\n onRemove?(map: Map): void;\n /**\n * This method does the heavy lifting of loading a tile.\n * In most cases it will defer the work to the relevant worker source.\n * @param tile - The tile to load\n */\n loadTile(tile: Tile): Promise;\n /**\n * True is the tile is part of the source, false otherwise.\n * @param tileID - The tile ID\n */\n hasTile?(tileID: OverscaledTileID): boolean;\n /**\n * Allows to abort a tile loading.\n * @param tile - The tile to abort\n */\n abortTile?(tile: Tile): Promise;\n /**\n * Allows to unload a tile.\n * @param tile - The tile to unload\n */\n unloadTile?(tile: Tile): Promise;\n /**\n * @returns A plain (stringifiable) JS object representing the current state of the source.\n * Creating a source using the returned object as the `options` should result in a Source that is\n * equivalent to this one.\n */\n serialize(): any;\n /**\n * Allows to execute a prepare step before the source is used.\n */\n prepare?(): void;\n}\n\n/**\n * A general definition of a {@link Source} class for factory usage\n */\nexport type SourceClass = {\n new (id: string, specification: SourceSpecification | CanvasSourceSpecification, dispatcher: Dispatcher, eventedParent: Evented): Source;\n}\n\n/**\n * Creates a tiled data source instance given an options object.\n *\n * @param id - The id for the source. Must not be used by any existing source.\n * @param specification - Source options, specific to the source type (except for `options.type`, which is always required).\n * @param source - A source definition object compliant with\n * [`maplibre-gl-style-spec`](https://maplibre.org/maplibre-style-spec/#sources) or, for a third-party source type,\n * with that type's requirements.\n * @param dispatcher - A {@link Dispatcher} instance, which can be used to send messages to the workers.\n * @returns a newly created source\n */\nexport const create = (id: string, specification: SourceSpecification | CanvasSourceSpecification, dispatcher: Dispatcher, eventedParent: Evented): Source => {\n\n const Class = getSourceType(specification.type);\n const source = new Class(id, specification, dispatcher, eventedParent);\n\n if (source.id !== id) {\n throw new Error(`Expected Source id to be ${id} instead of ${source.id}`);\n }\n\n return source;\n};\n\nconst getSourceType = (name: string): SourceClass => {\n switch (name) {\n case 'geojson':\n return GeoJSONSource;\n case 'image':\n return ImageSource;\n case 'raster':\n return RasterTileSource;\n case 'raster-dem':\n return RasterDEMTileSource;\n case 'vector':\n return VectorTileSource;\n case 'video':\n return VideoSource;\n case 'canvas':\n return CanvasSource;\n }\n return registeredSources[name];\n};\n\nconst setSourceType = (name: string, type: SourceClass) => {\n registeredSources[name] = type;\n};\n\n/**\n * Adds a custom source type, making it available for use with {@link Map#addSource}.\n * @param name - The name of the source type; source definition objects use this name in the `{type: ...}` field.\n * @param SourceType - A {@link SourceClass} - which is a constructor for the `Source` interface.\n * @returns a promise that is resolved when the source type is ready or rejected with an error.\n */\nexport const addSourceType = async (name: string, SourceType: SourceClass): Promise => {\n if (getSourceType(name)) {\n throw new Error(`A source type called \"${name}\" already exists.`);\n }\n setSourceType(name, SourceType);\n};\n","import type {CollisionBoxArray} from './array_types.g';\nimport type {Style} from '../style/style';\nimport type {TypedStyleLayer} from '../style/style_layer/typed_style_layer';\nimport type {FeatureIndex} from './feature_index';\nimport type {Context} from '../gl/context';\nimport type {FeatureStates} from '../source/source_state';\nimport type {ImagePosition} from '../render/image_atlas';\nimport type {CanonicalTileID} from '../source/tile_id';\nimport type {VectorTileFeature, VectorTileLayer} from '@mapbox/vector-tile';\nimport Point from '@mapbox/point-geometry';\n\nexport type BucketParameters = {\n index: number;\n layers: Array;\n zoom: number;\n pixelRatio: number;\n overscaling: number;\n collisionBoxArray: CollisionBoxArray;\n sourceLayerIndex: number;\n sourceID: string;\n};\n\nexport type PopulateParameters = {\n featureIndex: FeatureIndex;\n iconDependencies: {};\n patternDependencies: {};\n glyphDependencies: {};\n availableImages: Array;\n};\n\nexport type IndexedFeature = {\n feature: VectorTileFeature;\n id: number | string;\n index: number;\n sourceLayerIndex: number;\n};\n\nexport type BucketFeature = {\n index: number;\n sourceLayerIndex: number;\n geometry: Array>;\n properties: any;\n type: 0 | 1 | 2 | 3;\n id?: any;\n readonly patterns: {\n [_: string]: {\n 'min': string;\n 'mid': string;\n 'max': string;\n };\n };\n sortKey?: number;\n};\n\n/**\n * The `Bucket` interface is the single point of knowledge about turning vector\n * tiles into WebGL buffers.\n *\n * `Bucket` is an abstract interface. An implementation exists for each style layer type.\n * Create a bucket via the `StyleLayer#createBucket` method.\n *\n * The concrete bucket types, using layout options from the style layer,\n * transform feature geometries into vertex and index data for use by the\n * vertex shader. They also (via `ProgramConfiguration`) use feature\n * properties and the zoom level to populate the attributes needed for\n * data-driven styling.\n *\n * Buckets are designed to be built on a worker thread and then serialized and\n * transferred back to the main thread for rendering. On the worker side, a\n * bucket's vertex, index, and attribute data is stored in `bucket.arrays: ArrayGroup`.\n * When a bucket's data is serialized and sent back to the main thread,\n * is gets deserialized (using `new Bucket(serializedBucketData)`, with\n * the array data now stored in `bucket.buffers: BufferGroup`. BufferGroups\n * hold the same data as ArrayGroups, but are tuned for consumption by WebGL.\n */\nexport interface Bucket {\n layerIds: Array;\n hasPattern: boolean;\n readonly layers: Array;\n readonly stateDependentLayers: Array;\n readonly stateDependentLayerIds: Array;\n populate(features: Array, options: PopulateParameters, canonical: CanonicalTileID): void;\n update(states: FeatureStates, vtLayer: VectorTileLayer, imagePositions: {[_: string]: ImagePosition}): void;\n isEmpty(): boolean;\n upload(context: Context): void;\n uploadPending(): boolean;\n /**\n * Release the WebGL resources associated with the buffers. Note that because\n * buckets are shared between layers having the same layout properties, they\n * must be destroyed in groups (all buckets for a tile, or all symbol buckets).\n */\n destroy(): void;\n}\n\nexport function deserialize(input: Array, style: Style): {[_: string]: Bucket} {\n const output = {};\n\n // Guard against the case where the map's style has been set to null while\n // this bucket has been parsing.\n if (!style) return output;\n\n for (const bucket of input) {\n const layers = bucket.layerIds\n .map((id) => style.getLayer(id))\n .filter(Boolean);\n\n if (layers.length === 0) {\n continue;\n }\n\n // look up StyleLayer objects from layer ids (since we don't\n // want to waste time serializing/copying them from the worker)\n (bucket as any).layers = layers;\n if (bucket.stateDependentLayerIds) {\n (bucket as any).stateDependentLayers = bucket.stateDependentLayerIds.map((lId) => layers.filter((l) => l.id === lId)[0]);\n }\n for (const layer of layers) {\n output[layer.id] = bucket;\n }\n }\n\n return output;\n}\n","/**\n * The possible option of the plugin's status\n *\n * `unavailable`: Not loaded.\n *\n * `deferred`: The plugin URL has been specified, but loading has been deferred.\n *\n * `requested`: at least one tile needs RTL to render, but the plugin has not been set\n *\n * `loading`: RTL is in the process of being loaded by worker.\n *\n * `loaded`: The plugin is now loaded\n *\n * `error`: The plugin failed to load\n */\nexport type RTLPluginStatus =\n 'unavailable' |\n 'deferred' |\n 'requested' |\n 'loading' |\n 'loaded' |\n 'error';\n\n/**\n * The RTL plugin state\n */\nexport type PluginState = {\n pluginStatus: RTLPluginStatus;\n pluginURL: string;\n};\n\nexport const RTLPluginLoadedEventName = 'RTLPluginLoaded';\n\n","\nimport {browser} from '../util/browser';\nimport {Event, Evented} from '../util/evented';\nimport {RTLPluginStatus, RTLPluginLoadedEventName, PluginState} from './rtl_text_plugin_status';\nimport {Dispatcher, getGlobalDispatcher} from '../util/dispatcher';\nimport {MessageType} from '../util/actor_messages';\n\nclass RTLMainThreadPlugin extends Evented {\n status: RTLPluginStatus = 'unavailable';\n url: string = null;\n dispatcher: Dispatcher = getGlobalDispatcher();\n\n /** Sync RTL plugin state by broadcasting a message to the worker */\n _syncState(statusToSend: RTLPluginStatus): Promise {\n this.status = statusToSend;\n return this.dispatcher.broadcast(MessageType.syncRTLPluginState, {pluginStatus: statusToSend, pluginURL: this.url})\n .catch((e: any) => {\n this.status = 'error';\n throw e;\n });\n }\n\n /** This one is exposed to outside */\n getRTLTextPluginStatus(): RTLPluginStatus {\n return this.status;\n }\n\n clearRTLTextPlugin(): void {\n this.status = 'unavailable';\n this.url = null;\n }\n\n async setRTLTextPlugin(url: string, deferred: boolean = false): Promise {\n if (this.url) {\n // error\n throw new Error('setRTLTextPlugin cannot be called multiple times.');\n }\n\n this.url = browser.resolveURL(url);\n if (!this.url) {\n throw new Error(`requested url ${url} is invalid`);\n }\n if (this.status === 'unavailable') {\n\n // from initial state:\n if (deferred) {\n\n this.status = 'deferred';\n // fire and forget: in this case it does not need wait for the broadcasting result\n // it is important to sync the deferred status once because\n // symbol_bucket will be checking it in worker\n this._syncState(this.status);\n\n } else {\n return this._requestImport();\n }\n\n } else if (this.status === 'requested') {\n return this._requestImport();\n }\n }\n\n /** Send a message to worker which will import the RTL plugin script */\n async _requestImport() : Promise {\n\n // all errors/exceptions will be handled by _syncState\n await this._syncState('loading');\n this.status = 'loaded';\n this.fire(new Event(RTLPluginLoadedEventName));\n }\n\n /** Start a lazy loading process of RTL plugin */\n lazyLoad(): void {\n if (this.status === 'unavailable') {\n this.status = 'requested';\n } else if (this.status === 'deferred') {\n this._requestImport();\n }\n }\n}\n\nlet rtlMainThreadPlugin: RTLMainThreadPlugin = null;\n\nexport function rtlMainThreadPluginFactory(): RTLMainThreadPlugin {\n if (!rtlMainThreadPlugin) {\n rtlMainThreadPlugin = new RTLMainThreadPlugin();\n }\n return rtlMainThreadPlugin;\n}\n","import {uniqueId, parseCacheControl} from '../util/util';\nimport {deserialize as deserializeBucket} from '../data/bucket';\nimport '../data/feature_index';\nimport type {FeatureIndex} from '../data/feature_index';\nimport {GeoJSONFeature} from '../util/vectortile_to_geojson';\nimport {featureFilter} from '@maplibre/maplibre-gl-style-spec';\nimport {SymbolBucket} from '../data/bucket/symbol_bucket';\nimport {CollisionBoxArray} from '../data/array_types.g';\nimport {Texture} from '../render/texture';\nimport {browser} from '../util/browser';\nimport {toEvaluationFeature} from '../data/evaluation_feature';\nimport {EvaluationParameters} from '../style/evaluation_parameters';\nimport {SourceFeatureState} from '../source/source_state';\nimport {rtlMainThreadPluginFactory} from './rtl_text_plugin_main_thread';\n\nconst CLOCK_SKEW_RETRY_TIMEOUT = 30000;\n\nimport type {Bucket} from '../data/bucket';\nimport type {StyleLayer} from '../style/style_layer';\nimport type {WorkerTileResult} from './worker_source';\nimport type {Actor} from '../util/actor';\nimport type {DEMData} from '../data/dem_data';\nimport type {AlphaImage} from '../util/image';\nimport type {ImageAtlas} from '../render/image_atlas';\nimport type {ImageManager} from '../render/image_manager';\nimport type {Context} from '../gl/context';\nimport type {OverscaledTileID} from './tile_id';\nimport type {Framebuffer} from '../gl/framebuffer';\nimport type {Transform} from '../geo/transform';\nimport type {LayerFeatureStates} from './source_state';\nimport type {FilterSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type Point from '@mapbox/point-geometry';\nimport {mat4} from 'gl-matrix';\nimport type {VectorTileLayer} from '@mapbox/vector-tile';\nimport {ExpiryData} from '../util/ajax';\n\n/**\n * The tile's state, can be:\n *\n * - `loading` Tile data is in the process of loading.\n * - `loaded` Tile data has been loaded. Tile can be rendered.\n * - `reloading` Tile data has been loaded and is being updated. Tile can be rendered.\n * - `unloaded` Tile data has been deleted.\n * - `errored` Tile data was not loaded because of an error.\n * - `expired` Tile data was previously loaded, but has expired per its HTTP headers and is in the process of refreshing.\n */\nexport type TileState = 'loading' | 'loaded' | 'reloading' | 'unloaded' | 'errored' | 'expired';\n\n/**\n * A tile object is the combination of a Coordinate, which defines\n * its place, as well as a unique ID and data tracking for its content\n */\nexport class Tile {\n tileID: OverscaledTileID;\n uid: number;\n uses: number;\n tileSize: number;\n buckets: {[_: string]: Bucket};\n latestFeatureIndex: FeatureIndex;\n latestRawTileData: ArrayBuffer;\n imageAtlas: ImageAtlas;\n imageAtlasTexture: Texture;\n glyphAtlasImage: AlphaImage;\n glyphAtlasTexture: Texture;\n expirationTime: any;\n expiredRequestCount: number;\n state: TileState;\n timeAdded: number = 0;\n fadeEndTime: number = 0;\n collisionBoxArray: CollisionBoxArray;\n redoWhenDone: boolean;\n showCollisionBoxes: boolean;\n placementSource: any;\n actor: Actor;\n vtLayers: {[_: string]: VectorTileLayer};\n\n neighboringTiles: any;\n dem: DEMData;\n demMatrix: mat4;\n aborted: boolean;\n needsHillshadePrepare: boolean;\n needsTerrainPrepare: boolean;\n abortController: AbortController;\n texture: any;\n fbo: Framebuffer;\n demTexture: Texture;\n refreshedUponExpiration: boolean;\n reloadPromise: {resolve: () => void; reject: () => void};\n resourceTiming: Array;\n queryPadding: number;\n\n symbolFadeHoldUntil: number;\n hasSymbolBuckets: boolean;\n hasRTLText: boolean;\n dependencies: any;\n rtt: Array<{id: number; stamp: number}>;\n rttCoords: {[_:string]: string};\n\n /**\n * @param tileID - the tile ID\n * @param size - The tile size\n */\n constructor(tileID: OverscaledTileID, size: number) {\n this.tileID = tileID;\n this.uid = uniqueId();\n this.uses = 0;\n this.tileSize = size;\n this.buckets = {};\n this.expirationTime = null;\n this.queryPadding = 0;\n this.hasSymbolBuckets = false;\n this.hasRTLText = false;\n this.dependencies = {};\n this.rtt = [];\n this.rttCoords = {};\n\n // Counts the number of times a response was already expired when\n // received. We're using this to add a delay when making a new request\n // so we don't have to keep retrying immediately in case of a server\n // serving expired tiles.\n this.expiredRequestCount = 0;\n\n this.state = 'loading';\n }\n\n registerFadeDuration(duration: number) {\n const fadeEndTime = duration + this.timeAdded;\n\n if (fadeEndTime < this.fadeEndTime) {\n return;\n }\n\n this.fadeEndTime = fadeEndTime;\n }\n\n wasRequested() {\n return this.state === 'errored' || this.state === 'loaded' || this.state === 'reloading';\n }\n\n clearTextures(painter: any) {\n if (this.demTexture) painter.saveTileTexture(this.demTexture);\n this.demTexture = null;\n }\n\n /**\n * Given a data object with a 'buffers' property, load it into\n * this tile's elementGroups and buffers properties and set loaded\n * to true. If the data is null, like in the case of an empty\n * GeoJSON tile, no-op but still set loaded to true.\n * @param data - The data from the worker\n * @param painter - the painter\n * @param justReloaded - `true` to just reload\n */\n loadVectorData(data: WorkerTileResult, painter: any, justReloaded?: boolean | null) {\n if (this.hasData()) {\n this.unloadVectorData();\n }\n\n this.state = 'loaded';\n\n // empty GeoJSON tile\n if (!data) {\n this.collisionBoxArray = new CollisionBoxArray();\n return;\n }\n\n if (data.featureIndex) {\n this.latestFeatureIndex = data.featureIndex;\n if (data.rawTileData) {\n // Only vector tiles have rawTileData, and they won't update it for\n // 'reloadTile'\n this.latestRawTileData = data.rawTileData;\n this.latestFeatureIndex.rawTileData = data.rawTileData;\n } else if (this.latestRawTileData) {\n // If rawTileData hasn't updated, hold onto a pointer to the last\n // one we received\n this.latestFeatureIndex.rawTileData = this.latestRawTileData;\n }\n }\n this.collisionBoxArray = data.collisionBoxArray;\n this.buckets = deserializeBucket(data.buckets, painter.style);\n\n this.hasSymbolBuckets = false;\n for (const id in this.buckets) {\n const bucket = this.buckets[id];\n if (bucket instanceof SymbolBucket) {\n this.hasSymbolBuckets = true;\n if (justReloaded) {\n bucket.justReloaded = true;\n } else {\n break;\n }\n }\n }\n\n this.hasRTLText = false;\n if (this.hasSymbolBuckets) {\n for (const id in this.buckets) {\n const bucket = this.buckets[id];\n if (bucket instanceof SymbolBucket) {\n if (bucket.hasRTLText) {\n this.hasRTLText = true;\n rtlMainThreadPluginFactory().lazyLoad();\n break;\n }\n }\n }\n }\n\n this.queryPadding = 0;\n for (const id in this.buckets) {\n const bucket = this.buckets[id];\n this.queryPadding = Math.max(this.queryPadding, painter.style.getLayer(id).queryRadius(bucket));\n }\n\n if (data.imageAtlas) {\n this.imageAtlas = data.imageAtlas;\n }\n if (data.glyphAtlasImage) {\n this.glyphAtlasImage = data.glyphAtlasImage;\n }\n }\n\n /**\n * Release any data or WebGL resources referenced by this tile.\n */\n unloadVectorData() {\n for (const id in this.buckets) {\n this.buckets[id].destroy();\n }\n this.buckets = {};\n\n if (this.imageAtlasTexture) {\n this.imageAtlasTexture.destroy();\n }\n\n if (this.imageAtlas) {\n this.imageAtlas = null;\n }\n\n if (this.glyphAtlasTexture) {\n this.glyphAtlasTexture.destroy();\n }\n\n this.latestFeatureIndex = null;\n this.state = 'unloaded';\n }\n\n getBucket(layer: StyleLayer) {\n return this.buckets[layer.id];\n }\n\n upload(context: Context) {\n for (const id in this.buckets) {\n const bucket = this.buckets[id];\n if (bucket.uploadPending()) {\n bucket.upload(context);\n }\n }\n\n const gl = context.gl;\n if (this.imageAtlas && !this.imageAtlas.uploaded) {\n this.imageAtlasTexture = new Texture(context, this.imageAtlas.image, gl.RGBA);\n this.imageAtlas.uploaded = true;\n }\n\n if (this.glyphAtlasImage) {\n this.glyphAtlasTexture = new Texture(context, this.glyphAtlasImage, gl.ALPHA);\n this.glyphAtlasImage = null;\n }\n }\n\n prepare(imageManager: ImageManager) {\n if (this.imageAtlas) {\n this.imageAtlas.patchUpdatedImages(imageManager, this.imageAtlasTexture);\n }\n }\n\n // Queries non-symbol features rendered for this tile.\n // Symbol features are queried globally\n queryRenderedFeatures(\n layers: {[_: string]: StyleLayer},\n serializedLayers: {[_: string]: any},\n sourceFeatureState: SourceFeatureState,\n queryGeometry: Array,\n cameraQueryGeometry: Array,\n scale: number,\n params: {\n filter: FilterSpecification;\n layers: Array;\n availableImages: Array;\n },\n transform: Transform,\n maxPitchScaleFactor: number,\n pixelPosMatrix: mat4\n ): {[_: string]: Array<{featureIndex: number; feature: GeoJSONFeature}>} {\n if (!this.latestFeatureIndex || !this.latestFeatureIndex.rawTileData)\n return {};\n\n return this.latestFeatureIndex.query({\n queryGeometry,\n cameraQueryGeometry,\n scale,\n tileSize: this.tileSize,\n pixelPosMatrix,\n transform,\n params,\n queryPadding: this.queryPadding * maxPitchScaleFactor\n }, layers, serializedLayers, sourceFeatureState);\n }\n\n querySourceFeatures(result: Array, params?: {\n sourceLayer?: string;\n filter?: FilterSpecification;\n validate?: boolean;\n }) {\n const featureIndex = this.latestFeatureIndex;\n if (!featureIndex || !featureIndex.rawTileData) return;\n\n const vtLayers = featureIndex.loadVTLayers();\n\n const sourceLayer = params && params.sourceLayer ? params.sourceLayer : '';\n const layer = vtLayers._geojsonTileLayer || vtLayers[sourceLayer];\n\n if (!layer) return;\n\n const filter = featureFilter(params && params.filter);\n const {z, x, y} = this.tileID.canonical;\n const coord = {z, x, y};\n\n for (let i = 0; i < layer.length; i++) {\n const feature = layer.feature(i);\n if (filter.needGeometry) {\n const evaluationFeature = toEvaluationFeature(feature, true);\n if (!filter.filter(new EvaluationParameters(this.tileID.overscaledZ), evaluationFeature, this.tileID.canonical)) continue;\n } else if (!filter.filter(new EvaluationParameters(this.tileID.overscaledZ), feature)) {\n continue;\n }\n const id = featureIndex.getId(feature, sourceLayer);\n const geojsonFeature = new GeoJSONFeature(feature, z, x, y, id);\n (geojsonFeature as any).tile = coord;\n result.push(geojsonFeature);\n }\n }\n\n hasData() {\n return this.state === 'loaded' || this.state === 'reloading' || this.state === 'expired';\n }\n\n patternsLoaded() {\n return this.imageAtlas && !!Object.keys(this.imageAtlas.patternPositions).length;\n }\n\n setExpiryData(data: ExpiryData) {\n const prior = this.expirationTime;\n\n if (data.cacheControl) {\n const parsedCC = parseCacheControl(data.cacheControl);\n if (parsedCC['max-age']) this.expirationTime = Date.now() + parsedCC['max-age'] * 1000;\n } else if (data.expires) {\n this.expirationTime = new Date(data.expires).getTime();\n }\n\n if (this.expirationTime) {\n const now = Date.now();\n let isExpired = false;\n\n if (this.expirationTime > now) {\n isExpired = false;\n } else if (!prior) {\n isExpired = true;\n } else if (this.expirationTime < prior) {\n // Expiring date is going backwards:\n // fall back to exponential backoff\n isExpired = true;\n\n } else {\n const delta = this.expirationTime - prior;\n\n if (!delta) {\n // Server is serving the same expired resource over and over: fall\n // back to exponential backoff.\n isExpired = true;\n\n } else {\n // Assume that either the client or the server clock is wrong and\n // try to interpolate a valid expiration date (from the client POV)\n // observing a minimum timeout.\n this.expirationTime = now + Math.max(delta, CLOCK_SKEW_RETRY_TIMEOUT);\n\n }\n }\n\n if (isExpired) {\n this.expiredRequestCount++;\n this.state = 'expired';\n } else {\n this.expiredRequestCount = 0;\n }\n }\n }\n\n getExpiryTimeout() {\n if (this.expirationTime) {\n if (this.expiredRequestCount) {\n return 1000 * (1 << Math.min(this.expiredRequestCount - 1, 31));\n } else {\n // Max value for `setTimeout` implementations is a 32 bit integer; cap this accordingly\n return Math.min(this.expirationTime - new Date().getTime(), Math.pow(2, 31) - 1);\n }\n }\n }\n\n setFeatureState(states: LayerFeatureStates, painter: any) {\n if (!this.latestFeatureIndex ||\n !this.latestFeatureIndex.rawTileData ||\n Object.keys(states).length === 0) {\n return;\n }\n\n const vtLayers = this.latestFeatureIndex.loadVTLayers();\n\n for (const id in this.buckets) {\n if (!painter.style.hasLayer(id)) continue;\n\n const bucket = this.buckets[id];\n // Buckets are grouped by common source-layer\n const sourceLayerId = bucket.layers[0]['sourceLayer'] || '_geojsonTileLayer';\n const sourceLayer = vtLayers[sourceLayerId];\n const sourceLayerStates = states[sourceLayerId];\n if (!sourceLayer || !sourceLayerStates || Object.keys(sourceLayerStates).length === 0) continue;\n\n bucket.update(sourceLayerStates, sourceLayer, this.imageAtlas && this.imageAtlas.patternPositions || {});\n const layer = painter && painter.style && painter.style.getLayer(id);\n if (layer) {\n this.queryPadding = Math.max(this.queryPadding, layer.queryRadius(bucket));\n }\n }\n }\n\n holdingForFade(): boolean {\n return this.symbolFadeHoldUntil !== undefined;\n }\n\n symbolFadeFinished(): boolean {\n return !this.symbolFadeHoldUntil || this.symbolFadeHoldUntil < browser.now();\n }\n\n clearFadeHold() {\n this.symbolFadeHoldUntil = undefined;\n }\n\n setHoldDuration(duration: number) {\n this.symbolFadeHoldUntil = browser.now() + duration;\n }\n\n setDependencies(namespace: string, dependencies: Array) {\n const index = {};\n for (const dep of dependencies) {\n index[dep] = true;\n }\n this.dependencies[namespace] = index;\n }\n\n hasDependency(namespaces: Array, keys: Array) {\n for (const namespace of namespaces) {\n const dependencies = this.dependencies[namespace];\n if (dependencies) {\n for (const key of keys) {\n if (dependencies[key]) {\n return true;\n }\n }\n }\n }\n return false;\n }\n}\n","import {OverscaledTileID} from './tile_id';\nimport type {Tile} from './tile';\n\n/**\n * @internal\n * A [least-recently-used cache](https://en.wikipedia.org/wiki/Cache_algorithms)\n * with hash lookup made possible by keeping a list of keys in parallel to\n * an array of dictionary of values\n */\nexport class TileCache {\n max: number;\n data: {\n [key: string]: Array<{\n value: Tile;\n timeout: ReturnType;\n }>;\n };\n order: Array;\n onRemove: (element: Tile) => void;\n /**\n * @param max - number of permitted values\n * @param onRemove - callback called with items when they expire\n */\n constructor(max: number, onRemove: (element: Tile) => void) {\n this.max = max;\n this.onRemove = onRemove;\n this.reset();\n }\n\n /**\n * Clear the cache\n *\n * @returns this cache\n */\n reset() {\n for (const key in this.data) {\n for (const removedData of this.data[key]) {\n if (removedData.timeout) clearTimeout(removedData.timeout);\n this.onRemove(removedData.value);\n }\n }\n\n this.data = {};\n this.order = [];\n\n return this;\n }\n\n /**\n * Add a key, value combination to the cache, trimming its size if this pushes\n * it over max length.\n *\n * @param tileID - lookup key for the item\n * @param data - tile data\n *\n * @returns this cache\n */\n add(tileID: OverscaledTileID, data: Tile, expiryTimeout: number | void) {\n const key = tileID.wrapped().key;\n if (this.data[key] === undefined) {\n this.data[key] = [];\n }\n\n const dataWrapper = {\n value: data,\n timeout: undefined\n };\n\n if (expiryTimeout !== undefined) {\n dataWrapper.timeout = setTimeout(() => {\n this.remove(tileID, dataWrapper);\n }, expiryTimeout as number);\n }\n\n this.data[key].push(dataWrapper);\n this.order.push(key);\n\n if (this.order.length > this.max) {\n const removedData = this._getAndRemoveByKey(this.order[0]);\n if (removedData) this.onRemove(removedData);\n }\n\n return this;\n }\n\n /**\n * Determine whether the value attached to `key` is present\n *\n * @param tileID - the key to be looked-up\n * @returns whether the cache has this value\n */\n has(tileID: OverscaledTileID): boolean {\n return tileID.wrapped().key in this.data;\n }\n\n /**\n * Get the value attached to a specific key and remove data from cache.\n * If the key is not found, returns `null`\n *\n * @param tileID - the key to look up\n * @returns the tile data, or null if it isn't found\n */\n getAndRemove(tileID: OverscaledTileID): Tile {\n if (!this.has(tileID)) { return null; }\n return this._getAndRemoveByKey(tileID.wrapped().key);\n }\n\n /*\n * Get and remove the value with the specified key.\n */\n _getAndRemoveByKey(key: string): Tile {\n const data = this.data[key].shift();\n if (data.timeout) clearTimeout(data.timeout);\n\n if (this.data[key].length === 0) {\n delete this.data[key];\n }\n this.order.splice(this.order.indexOf(key), 1);\n\n return data.value;\n }\n\n /*\n * Get the value with the specified (wrapped tile) key.\n */\n getByKey(key: string): Tile {\n const data = this.data[key];\n return data ? data[0].value : null;\n }\n\n /**\n * Get the value attached to a specific key without removing data\n * from the cache. If the key is not found, returns `null`\n *\n * @param tileID - the key to look up\n * @returns the tile data, or null if it isn't found\n */\n get(tileID: OverscaledTileID): Tile {\n if (!this.has(tileID)) { return null; }\n\n const data = this.data[tileID.wrapped().key][0];\n return data.value;\n }\n\n /**\n * Remove a key/value combination from the cache.\n *\n * @param tileID - the key for the pair to delete\n * @param value - If a value is provided, remove that exact version of the value.\n * @returns this cache\n */\n remove(tileID: OverscaledTileID, value?: {\n value: Tile;\n timeout: ReturnType;\n }) {\n if (!this.has(tileID)) { return this; }\n const key = tileID.wrapped().key;\n\n const dataIndex = value === undefined ? 0 : this.data[key].indexOf(value);\n const data = this.data[key][dataIndex];\n this.data[key].splice(dataIndex, 1);\n if (data.timeout) clearTimeout(data.timeout);\n if (this.data[key].length === 0) {\n delete this.data[key];\n }\n this.onRemove(data.value);\n this.order.splice(this.order.indexOf(key), 1);\n\n return this;\n }\n\n /**\n * Change the max size of the cache.\n *\n * @param max - the max size of the cache\n * @returns this cache\n */\n setMaxSize(max: number): TileCache {\n this.max = max;\n\n while (this.order.length > this.max) {\n const removedData = this._getAndRemoveByKey(this.order[0]);\n if (removedData) this.onRemove(removedData);\n }\n\n return this;\n }\n\n /**\n * Remove entries that do not pass a filter function. Used for removing\n * stale tiles from the cache.\n *\n * @param filterFn - Determines whether the tile is filtered. If the supplied function returns false, the tile will be filtered out.\n */\n filter(filterFn: (tile: Tile) => boolean) {\n const removed = [];\n for (const key in this.data) {\n for (const entry of this.data[key]) {\n if (!filterFn(entry.value)) {\n removed.push(entry);\n }\n }\n }\n for (const r of removed) {\n this.remove(r.value.tileID, r);\n }\n }\n}\n","import {extend} from '../util/util';\nimport {Tile} from './tile';\nimport type {FeatureState} from '@maplibre/maplibre-gl-style-spec';\n\nexport type FeatureStates = {[featureId: string]: FeatureState};\nexport type LayerFeatureStates = {[layer: string]: FeatureStates};\n\n/**\n * @internal\n * SourceFeatureState manages the state and pending changes\n * to features in a source, separated by source layer.\n * stateChanges and deletedStates batch all changes to the tile (updates and removes, respectively)\n * between coalesce() events. addFeatureState() and removeFeatureState() also update their counterpart's\n * list of changes, such that coalesce() can apply the proper state changes while agnostic to the order of operations.\n * In deletedStates, all null's denote complete removal of state at that scope\n*/\nexport class SourceFeatureState {\n state: LayerFeatureStates;\n stateChanges: LayerFeatureStates;\n deletedStates: {};\n\n constructor() {\n this.state = {};\n this.stateChanges = {};\n this.deletedStates = {};\n }\n\n updateState(sourceLayer: string, featureId: number | string, newState: any) {\n const feature = String(featureId);\n this.stateChanges[sourceLayer] = this.stateChanges[sourceLayer] || {};\n this.stateChanges[sourceLayer][feature] = this.stateChanges[sourceLayer][feature] || {};\n extend(this.stateChanges[sourceLayer][feature], newState);\n\n if (this.deletedStates[sourceLayer] === null) {\n this.deletedStates[sourceLayer] = {};\n for (const ft in this.state[sourceLayer]) {\n if (ft !== feature) this.deletedStates[sourceLayer][ft] = null;\n }\n } else {\n const featureDeletionQueued = this.deletedStates[sourceLayer] && this.deletedStates[sourceLayer][feature] === null;\n if (featureDeletionQueued) {\n this.deletedStates[sourceLayer][feature] = {};\n for (const prop in this.state[sourceLayer][feature]) {\n if (!newState[prop]) this.deletedStates[sourceLayer][feature][prop] = null;\n }\n } else {\n for (const key in newState) {\n const deletionInQueue = this.deletedStates[sourceLayer] && this.deletedStates[sourceLayer][feature] && this.deletedStates[sourceLayer][feature][key] === null;\n if (deletionInQueue) delete this.deletedStates[sourceLayer][feature][key];\n }\n }\n }\n }\n\n removeFeatureState(sourceLayer: string, featureId?: number | string, key?: string) {\n const sourceLayerDeleted = this.deletedStates[sourceLayer] === null;\n if (sourceLayerDeleted) return;\n\n const feature = String(featureId);\n\n this.deletedStates[sourceLayer] = this.deletedStates[sourceLayer] || {};\n\n if (key && featureId !== undefined) {\n if (this.deletedStates[sourceLayer][feature] !== null) {\n this.deletedStates[sourceLayer][feature] = this.deletedStates[sourceLayer][feature] || {};\n this.deletedStates[sourceLayer][feature][key] = null;\n }\n } else if (featureId !== undefined) {\n const updateInQueue = this.stateChanges[sourceLayer] && this.stateChanges[sourceLayer][feature];\n if (updateInQueue) {\n this.deletedStates[sourceLayer][feature] = {};\n for (key in this.stateChanges[sourceLayer][feature]) this.deletedStates[sourceLayer][feature][key] = null;\n\n } else {\n this.deletedStates[sourceLayer][feature] = null;\n }\n } else {\n this.deletedStates[sourceLayer] = null;\n }\n\n }\n\n getState(sourceLayer: string, featureId: number | string) {\n const feature = String(featureId);\n const base = this.state[sourceLayer] || {};\n const changes = this.stateChanges[sourceLayer] || {};\n\n const reconciledState = extend({}, base[feature], changes[feature]);\n\n //return empty object if the whole source layer is awaiting deletion\n if (this.deletedStates[sourceLayer] === null) return {};\n else if (this.deletedStates[sourceLayer]) {\n const featureDeletions = this.deletedStates[sourceLayer][featureId];\n if (featureDeletions === null) return {};\n for (const prop in featureDeletions) delete reconciledState[prop];\n }\n return reconciledState;\n }\n\n initializeTileState(tile: Tile, painter: any) {\n tile.setFeatureState(this.state, painter);\n }\n\n coalesceChanges(tiles: {\n [_ in any]: Tile;\n }, painter: any) {\n //track changes with full state objects, but only for features that got modified\n const featuresChanged: LayerFeatureStates = {};\n\n for (const sourceLayer in this.stateChanges) {\n this.state[sourceLayer] = this.state[sourceLayer] || {};\n const layerStates = {};\n for (const feature in this.stateChanges[sourceLayer]) {\n if (!this.state[sourceLayer][feature]) this.state[sourceLayer][feature] = {};\n extend(this.state[sourceLayer][feature], this.stateChanges[sourceLayer][feature]);\n layerStates[feature] = this.state[sourceLayer][feature];\n }\n featuresChanged[sourceLayer] = layerStates;\n }\n\n for (const sourceLayer in this.deletedStates) {\n this.state[sourceLayer] = this.state[sourceLayer] || {};\n const layerStates = {};\n\n if (this.deletedStates[sourceLayer] === null) {\n for (const ft in this.state[sourceLayer]) {\n layerStates[ft] = {};\n this.state[sourceLayer][ft] = {};\n }\n } else {\n for (const feature in this.deletedStates[sourceLayer]) {\n const deleteWholeFeatureState = this.deletedStates[sourceLayer][feature] === null;\n if (deleteWholeFeatureState) this.state[sourceLayer][feature] = {};\n else {\n for (const key of Object.keys(this.deletedStates[sourceLayer][feature])) {\n delete this.state[sourceLayer][feature][key];\n }\n }\n layerStates[feature] = this.state[sourceLayer][feature];\n }\n }\n\n featuresChanged[sourceLayer] = featuresChanged[sourceLayer] || {};\n extend(featuresChanged[sourceLayer], layerStates);\n }\n\n this.stateChanges = {};\n this.deletedStates = {};\n\n if (Object.keys(featuresChanged).length === 0) return;\n\n for (const id in tiles) {\n const tile = tiles[id];\n tile.setFeatureState(featuresChanged, painter);\n }\n }\n}\n","import {create as createSource} from './source';\n\nimport {Tile} from './tile';\nimport {Event, ErrorEvent, Evented} from '../util/evented';\nimport {TileCache} from './tile_cache';\nimport {MercatorCoordinate} from '../geo/mercator_coordinate';\nimport {keysDifference} from '../util/util';\nimport {EXTENT} from '../data/extent';\nimport {Context} from '../gl/context';\nimport Point from '@mapbox/point-geometry';\nimport {browser} from '../util/browser';\nimport {OverscaledTileID} from './tile_id';\nimport {SourceFeatureState} from './source_state';\nimport {config} from '../util/config';\n\nimport type {Source} from './source';\nimport type {Map} from '../ui/map';\nimport type {Style} from '../style/style';\nimport type {Dispatcher} from '../util/dispatcher';\nimport type {Transform} from '../geo/transform';\nimport type {TileState} from './tile';\nimport type {SourceSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {MapSourceDataEvent} from '../ui/events';\nimport type {Terrain} from '../render/terrain';\nimport type {CanvasSourceSpecification} from './canvas_source';\n\n/**\n * @internal\n * `SourceCache` is responsible for\n *\n * - creating an instance of `Source`\n * - forwarding events from `Source`\n * - caching tiles loaded from an instance of `Source`\n * - loading the tiles needed to render a given viewport\n * - unloading the cached tiles not needed to render a given viewport\n */\nexport class SourceCache extends Evented {\n id: string;\n dispatcher: Dispatcher;\n map: Map;\n style: Style;\n\n _source: Source;\n\n /**\n * @internal\n * signifies that the TileJSON is loaded if applicable.\n * if the source type does not come with a TileJSON, the flag signifies the\n * source data has loaded (i.e geojson has been tiled on the worker and is ready)\n */\n _sourceLoaded: boolean;\n\n _sourceErrored: boolean;\n _tiles: {[_: string]: Tile};\n _prevLng: number;\n _cache: TileCache;\n _timers: {\n [_ in any]: ReturnType;\n };\n _cacheTimers: {\n [_ in any]: ReturnType;\n };\n _maxTileCacheSize: number;\n _maxTileCacheZoomLevels: number;\n _paused: boolean;\n _shouldReloadOnResume: boolean;\n _coveredTiles: {[_: string]: boolean};\n transform: Transform;\n terrain: Terrain;\n used: boolean;\n usedForTerrain: boolean;\n tileSize: number;\n _state: SourceFeatureState;\n _loadedParentTiles: {[_: string]: Tile};\n _loadedSiblingTiles: {[_: string]: Tile};\n _didEmitContent: boolean;\n _updated: boolean;\n\n static maxUnderzooming: number;\n static maxOverzooming: number;\n\n constructor(id: string, options: SourceSpecification | CanvasSourceSpecification, dispatcher: Dispatcher) {\n super();\n this.id = id;\n this.dispatcher = dispatcher;\n\n this.on('data', (e: MapSourceDataEvent) => this._dataHandler(e));\n\n this.on('dataloading', () => {\n this._sourceErrored = false;\n });\n\n this.on('error', () => {\n // Only set _sourceErrored if the source does not have pending loads.\n this._sourceErrored = this._source.loaded();\n });\n\n this._source = createSource(id, options, dispatcher, this);\n\n this._tiles = {};\n this._cache = new TileCache(0, (tile) => this._unloadTile(tile));\n this._timers = {};\n this._cacheTimers = {};\n this._maxTileCacheSize = null;\n this._maxTileCacheZoomLevels = null;\n this._loadedParentTiles = {};\n\n this._coveredTiles = {};\n this._state = new SourceFeatureState();\n this._didEmitContent = false;\n this._updated = false;\n }\n\n onAdd(map: Map) {\n this.map = map;\n this._maxTileCacheSize = map ? map._maxTileCacheSize : null;\n this._maxTileCacheZoomLevels = map ? map._maxTileCacheZoomLevels : null;\n if (this._source && this._source.onAdd) {\n this._source.onAdd(map);\n }\n }\n\n onRemove(map: Map) {\n this.clearTiles();\n if (this._source && this._source.onRemove) {\n this._source.onRemove(map);\n }\n }\n\n /**\n * Return true if no tile data is pending, tiles will not change unless\n * an additional API call is received.\n */\n loaded(): boolean {\n if (this._sourceErrored) { return true; }\n if (!this._sourceLoaded) { return false; }\n if (!this._source.loaded()) { return false; }\n if ((this.used !== undefined || this.usedForTerrain !== undefined) && !this.used && !this.usedForTerrain) { return true; }\n // do not consider as loaded if the update hasn't been called yet (we do not know if we will have any tiles to fetch)\n if (!this._updated) { return false; }\n\n for (const t in this._tiles) {\n const tile = this._tiles[t];\n if (tile.state !== 'loaded' && tile.state !== 'errored')\n return false;\n }\n return true;\n }\n\n getSource(): Source {\n return this._source;\n }\n\n pause() {\n this._paused = true;\n }\n\n resume() {\n if (!this._paused) return;\n const shouldReload = this._shouldReloadOnResume;\n this._paused = false;\n this._shouldReloadOnResume = false;\n if (shouldReload) this.reload();\n if (this.transform) this.update(this.transform, this.terrain);\n }\n\n async _loadTile(tile: Tile, id: string, state: TileState): Promise {\n try {\n await this._source.loadTile(tile);\n this._tileLoaded(tile, id, state);\n } catch (err) {\n tile.state = 'errored';\n if ((err as any).status !== 404) {\n this._source.fire(new ErrorEvent(err, {tile}));\n } else {\n // continue to try loading parent/children tiles if a tile doesn't exist (404)\n this.update(this.transform, this.terrain);\n }\n }\n }\n\n _unloadTile(tile: Tile) {\n if (this._source.unloadTile)\n this._source.unloadTile(tile);\n }\n\n _abortTile(tile: Tile) {\n if (this._source.abortTile)\n this._source.abortTile(tile);\n\n this._source.fire(new Event('dataabort', {tile, coord: tile.tileID, dataType: 'source'}));\n }\n\n serialize() {\n return this._source.serialize();\n }\n\n prepare(context: Context) {\n if (this._source.prepare) {\n this._source.prepare();\n }\n\n this._state.coalesceChanges(this._tiles, this.map ? this.map.painter : null);\n for (const i in this._tiles) {\n const tile = this._tiles[i];\n tile.upload(context);\n tile.prepare(this.map.style.imageManager);\n }\n }\n\n /**\n * Return all tile ids ordered with z-order, and cast to numbers\n */\n getIds(): Array {\n return (Object.values(this._tiles) as any).map((tile: Tile) => tile.tileID).sort(compareTileId).map(id => id.key);\n }\n\n getRenderableIds(symbolLayer?: boolean): Array {\n const renderables: Array = [];\n for (const id in this._tiles) {\n if (this._isIdRenderable(id, symbolLayer)) renderables.push(this._tiles[id]);\n }\n if (symbolLayer) {\n return renderables.sort((a_: Tile, b_: Tile) => {\n const a = a_.tileID;\n const b = b_.tileID;\n const rotatedA = (new Point(a.canonical.x, a.canonical.y))._rotate(this.transform.angle);\n const rotatedB = (new Point(b.canonical.x, b.canonical.y))._rotate(this.transform.angle);\n return a.overscaledZ - b.overscaledZ || rotatedB.y - rotatedA.y || rotatedB.x - rotatedA.x;\n }).map(tile => tile.tileID.key);\n }\n return renderables.map(tile => tile.tileID).sort(compareTileId).map(id => id.key);\n }\n\n hasRenderableParent(tileID: OverscaledTileID) {\n const parentTile = this.findLoadedParent(tileID, 0);\n if (parentTile) {\n return this._isIdRenderable(parentTile.tileID.key);\n }\n return false;\n }\n\n _isIdRenderable(id: string, symbolLayer?: boolean) {\n return this._tiles[id] && this._tiles[id].hasData() &&\n !this._coveredTiles[id] && (symbolLayer || !this._tiles[id].holdingForFade());\n }\n\n reload() {\n if (this._paused) {\n this._shouldReloadOnResume = true;\n return;\n }\n\n this._cache.reset();\n\n for (const i in this._tiles) {\n if (this._tiles[i].state !== 'errored') this._reloadTile(i, 'reloading');\n }\n }\n\n async _reloadTile(id: string, state: TileState) {\n const tile = this._tiles[id];\n\n // this potentially does not address all underlying\n // issues https://github.com/mapbox/mapbox-gl-js/issues/4252\n // - hard to tell without repro steps\n if (!tile) return;\n\n // The difference between \"loading\" tiles and \"reloading\" or \"expired\"\n // tiles is that \"reloading\"/\"expired\" tiles are \"renderable\".\n // Therefore, a \"loading\" tile cannot become a \"reloading\" tile without\n // first becoming a \"loaded\" tile.\n if (tile.state !== 'loading') {\n tile.state = state;\n }\n await this._loadTile(tile, id, state);\n }\n\n _tileLoaded(tile: Tile, id: string, previousState: TileState) {\n tile.timeAdded = browser.now();\n if (previousState === 'expired') tile.refreshedUponExpiration = true;\n this._setTileReloadTimer(id, tile);\n if (this.getSource().type === 'raster-dem' && tile.dem) this._backfillDEM(tile);\n this._state.initializeTileState(tile, this.map ? this.map.painter : null);\n\n if (!tile.aborted) {\n this._source.fire(new Event('data', {dataType: 'source', tile, coord: tile.tileID}));\n }\n }\n\n /**\n * For raster terrain source, backfill DEM to eliminate visible tile boundaries\n */\n _backfillDEM(tile: Tile) {\n const renderables = this.getRenderableIds();\n for (let i = 0; i < renderables.length; i++) {\n const borderId = renderables[i];\n if (tile.neighboringTiles && tile.neighboringTiles[borderId]) {\n const borderTile = this.getTileByID(borderId);\n fillBorder(tile, borderTile);\n fillBorder(borderTile, tile);\n }\n }\n\n function fillBorder(tile, borderTile) {\n tile.needsHillshadePrepare = true;\n tile.needsTerrainPrepare = true;\n let dx = borderTile.tileID.canonical.x - tile.tileID.canonical.x;\n const dy = borderTile.tileID.canonical.y - tile.tileID.canonical.y;\n const dim = Math.pow(2, tile.tileID.canonical.z);\n const borderId = borderTile.tileID.key;\n if (dx === 0 && dy === 0) return;\n\n if (Math.abs(dy) > 1) {\n return;\n }\n if (Math.abs(dx) > 1) {\n // Adjust the delta coordinate for world wraparound.\n if (Math.abs(dx + dim) === 1) {\n dx += dim;\n } else if (Math.abs(dx - dim) === 1) {\n dx -= dim;\n }\n }\n if (!borderTile.dem || !tile.dem) return;\n tile.dem.backfillBorder(borderTile.dem, dx, dy);\n if (tile.neighboringTiles && tile.neighboringTiles[borderId])\n tile.neighboringTiles[borderId].backfilled = true;\n }\n }\n /**\n * Get a specific tile by TileID\n */\n getTile(tileID: OverscaledTileID): Tile {\n return this.getTileByID(tileID.key);\n }\n\n /**\n * Get a specific tile by id\n */\n getTileByID(id: string): Tile {\n return this._tiles[id];\n }\n\n /**\n * For a given set of tiles, retain children that are loaded and have a zoom\n * between `zoom` (exclusive) and `maxCoveringZoom` (inclusive)\n */\n _retainLoadedChildren(\n idealTiles: {\n [_ in any]: OverscaledTileID;\n },\n zoom: number,\n maxCoveringZoom: number,\n retain: {\n [_ in any]: OverscaledTileID;\n }\n ) {\n for (const id in this._tiles) {\n let tile = this._tiles[id];\n\n // only consider renderable tiles up to maxCoveringZoom\n if (retain[id] ||\n !tile.hasData() ||\n tile.tileID.overscaledZ <= zoom ||\n tile.tileID.overscaledZ > maxCoveringZoom\n ) continue;\n\n // loop through parents and retain the topmost loaded one if found\n let topmostLoadedID = tile.tileID;\n while (tile && tile.tileID.overscaledZ > zoom + 1) {\n const parentID = tile.tileID.scaledTo(tile.tileID.overscaledZ - 1);\n\n tile = this._tiles[parentID.key];\n\n if (tile && tile.hasData()) {\n topmostLoadedID = parentID;\n }\n }\n\n // loop through ancestors of the topmost loaded child to see if there's one that needed it\n let tileID = topmostLoadedID;\n while (tileID.overscaledZ > zoom) {\n tileID = tileID.scaledTo(tileID.overscaledZ - 1);\n\n if (idealTiles[tileID.key]) {\n // found a parent that needed a loaded child; retain that child\n retain[topmostLoadedID.key] = topmostLoadedID;\n break;\n }\n }\n }\n }\n\n /**\n * Find a loaded parent of the given tile (up to minCoveringZoom)\n */\n findLoadedParent(tileID: OverscaledTileID, minCoveringZoom: number): Tile {\n if (tileID.key in this._loadedParentTiles) {\n const parent = this._loadedParentTiles[tileID.key];\n if (parent && parent.tileID.overscaledZ >= minCoveringZoom) {\n return parent;\n } else {\n return null;\n }\n }\n for (let z = tileID.overscaledZ - 1; z >= minCoveringZoom; z--) {\n const parentTileID = tileID.scaledTo(z);\n const tile = this._getLoadedTile(parentTileID);\n if (tile) {\n return tile;\n }\n }\n }\n\n /**\n * Find a loaded sibling of the given tile\n */\n findLoadedSibling(tileID: OverscaledTileID): Tile {\n // If a tile with this ID already exists, return it\n return this._getLoadedTile(tileID);\n }\n\n _getLoadedTile(tileID: OverscaledTileID): Tile {\n const tile = this._tiles[tileID.key];\n if (tile && tile.hasData()) {\n return tile;\n }\n // TileCache ignores wrap in lookup.\n const cachedTile = this._cache.getByKey(tileID.wrapped().key);\n return cachedTile;\n }\n\n /**\n * Resizes the tile cache based on the current viewport's size\n * or the maxTileCacheSize option passed during map creation\n *\n * Larger viewports use more tiles and need larger caches. Larger viewports\n * are more likely to be found on devices with more memory and on pages where\n * the map is more important.\n */\n updateCacheSize(transform: Transform) {\n const widthInTiles = Math.ceil(transform.width / this._source.tileSize) + 1;\n const heightInTiles = Math.ceil(transform.height / this._source.tileSize) + 1;\n const approxTilesInView = widthInTiles * heightInTiles;\n const commonZoomRange = this._maxTileCacheZoomLevels === null ?\n config.MAX_TILE_CACHE_ZOOM_LEVELS : this._maxTileCacheZoomLevels;\n const viewDependentMaxSize = Math.floor(approxTilesInView * commonZoomRange);\n const maxSize = typeof this._maxTileCacheSize === 'number' ?\n Math.min(this._maxTileCacheSize, viewDependentMaxSize) : viewDependentMaxSize;\n\n this._cache.setMaxSize(maxSize);\n }\n\n handleWrapJump(lng: number) {\n // On top of the regular z/x/y values, TileIDs have a `wrap` value that specify\n // which copy of the world the tile belongs to. For example, at `lng: 10` you\n // might render z/x/y/0 while at `lng: 370` you would render z/x/y/1.\n //\n // When lng values get wrapped (going from `lng: 370` to `long: 10`) you expect\n // to see the same thing on the screen (370 degrees and 10 degrees is the same\n // place in the world) but all the TileIDs will have different wrap values.\n //\n // In order to make this transition seamless, we calculate the rounded difference of\n // \"worlds\" between the last frame and the current frame. If the map panned by\n // a world, then we can assign all the tiles new TileIDs with updated wrap values.\n // For example, assign z/x/y/1 a new id: z/x/y/0. It is the same tile, just rendered\n // in a different position.\n //\n // This enables us to reuse the tiles at more ideal locations and prevent flickering.\n const prevLng = this._prevLng === undefined ? lng : this._prevLng;\n const lngDifference = lng - prevLng;\n const worldDifference = lngDifference / 360;\n const wrapDelta = Math.round(worldDifference);\n this._prevLng = lng;\n\n if (wrapDelta) {\n const tiles: {[_: string]: Tile} = {};\n for (const key in this._tiles) {\n const tile = this._tiles[key];\n tile.tileID = tile.tileID.unwrapTo(tile.tileID.wrap + wrapDelta);\n tiles[tile.tileID.key] = tile;\n }\n this._tiles = tiles;\n\n // Reset tile reload timers\n for (const id in this._timers) {\n clearTimeout(this._timers[id]);\n delete this._timers[id];\n }\n for (const id in this._tiles) {\n const tile = this._tiles[id];\n this._setTileReloadTimer(id, tile);\n }\n }\n }\n\n _updateCoveredAndRetainedTiles(\n retain: { [_: string]: OverscaledTileID },\n minCoveringZoom: number,\n maxCoveringZoom: number,\n zoom: number,\n idealTileIDs: OverscaledTileID[],\n terrain?: Terrain\n ) {\n const tilesForFading: { [_: string]: OverscaledTileID } = {};\n const fadingTiles = {};\n const ids = Object.keys(retain);\n const now = browser.now();\n for (const id of ids) {\n const tileID = retain[id];\n\n const tile = this._tiles[id];\n\n // when fadeEndTime is 0, the tile is created but registerFadeDuration\n // has not been called, therefore must be kept in fadingTiles dictionary\n // for next round of rendering\n if (!tile || (tile.fadeEndTime !== 0 && tile.fadeEndTime <= now)) {\n continue;\n }\n\n // if the tile is loaded but still fading in, find parents to cross-fade with it\n const parentTile = this.findLoadedParent(tileID, minCoveringZoom);\n const siblingTile = this.findLoadedSibling(tileID);\n const fadeTileRef = parentTile || siblingTile || null;\n if (fadeTileRef) {\n this._addTile(fadeTileRef.tileID);\n tilesForFading[fadeTileRef.tileID.key] = fadeTileRef.tileID;\n }\n\n fadingTiles[id] = tileID;\n }\n\n // for tiles that are still fading in, also find children to cross-fade with\n this._retainLoadedChildren(fadingTiles, zoom, maxCoveringZoom, retain);\n\n for (const id in tilesForFading) {\n if (!retain[id]) {\n // If a tile is only needed for fading, mark it as covered so that it isn't rendered on it's own.\n this._coveredTiles[id] = true;\n retain[id] = tilesForFading[id];\n }\n }\n\n // disable fading logic in terrain3D mode to avoid rendering two tiles on the same place\n if (terrain) {\n const idealRasterTileIDs: { [_: string]: OverscaledTileID } = {};\n const missingTileIDs: { [_: string]: OverscaledTileID } = {};\n for (const tileID of idealTileIDs) {\n if (this._tiles[tileID.key].hasData())\n idealRasterTileIDs[tileID.key] = tileID;\n else\n missingTileIDs[tileID.key] = tileID;\n }\n // search for a complete set of children for each missing tile\n for (const key in missingTileIDs) {\n const children = missingTileIDs[key].children(this._source.maxzoom);\n if (this._tiles[children[0].key] && this._tiles[children[1].key] && this._tiles[children[2].key] && this._tiles[children[3].key]) {\n idealRasterTileIDs[children[0].key] = retain[children[0].key] = children[0];\n idealRasterTileIDs[children[1].key] = retain[children[1].key] = children[1];\n idealRasterTileIDs[children[2].key] = retain[children[2].key] = children[2];\n idealRasterTileIDs[children[3].key] = retain[children[3].key] = children[3];\n delete missingTileIDs[key];\n }\n }\n // search for parent or sibling for each missing tile\n for (const key in missingTileIDs) {\n const tileID = missingTileIDs[key];\n const parentTile = this.findLoadedParent(tileID, this._source.minzoom);\n const siblingTile = this.findLoadedSibling(tileID);\n const fadeTileRef = parentTile || siblingTile || null;\n if (fadeTileRef) {\n idealRasterTileIDs[fadeTileRef.tileID.key] = retain[fadeTileRef.tileID.key] = fadeTileRef.tileID;\n // remove idealTiles which would be rendered twice\n for (const key in idealRasterTileIDs) {\n if (idealRasterTileIDs[key].isChildOf(fadeTileRef.tileID)) delete idealRasterTileIDs[key];\n }\n }\n }\n // cover all tiles which are not needed\n for (const key in this._tiles) {\n if (!idealRasterTileIDs[key]) this._coveredTiles[key] = true;\n }\n }\n }\n\n /**\n * Removes tiles that are outside the viewport and adds new tiles that\n * are inside the viewport.\n */\n update(transform: Transform, terrain?: Terrain) {\n if (!this._sourceLoaded || this._paused) {\n return;\n }\n this.transform = transform;\n this.terrain = terrain;\n\n this.updateCacheSize(transform);\n this.handleWrapJump(this.transform.center.lng);\n\n // Covered is a list of retained tiles who's areas are fully covered by other,\n // better, retained tiles. They are not drawn separately.\n this._coveredTiles = {};\n\n let idealTileIDs: OverscaledTileID[];\n\n if (!this.used && !this.usedForTerrain) {\n idealTileIDs = [];\n } else if (this._source.tileID) {\n idealTileIDs = transform.getVisibleUnwrappedCoordinates(this._source.tileID)\n .map((unwrapped) => new OverscaledTileID(unwrapped.canonical.z, unwrapped.wrap, unwrapped.canonical.z, unwrapped.canonical.x, unwrapped.canonical.y));\n } else {\n idealTileIDs = transform.coveringTiles({\n tileSize: this.usedForTerrain ? this.tileSize : this._source.tileSize,\n minzoom: this._source.minzoom,\n maxzoom: this._source.maxzoom,\n roundZoom: this.usedForTerrain ? false : this._source.roundZoom,\n reparseOverscaled: this._source.reparseOverscaled,\n terrain\n });\n\n if (this._source.hasTile) {\n idealTileIDs = idealTileIDs.filter((coord) => (this._source.hasTile as any)(coord));\n }\n }\n\n // Determine the overzooming/underzooming amounts.\n const zoom = transform.coveringZoomLevel(this._source);\n const minCoveringZoom = Math.max(zoom - SourceCache.maxOverzooming, this._source.minzoom);\n const maxCoveringZoom = Math.max(zoom + SourceCache.maxUnderzooming, this._source.minzoom);\n\n // When sourcecache is used for terrain also load parent tiles to avoid flickering when zooming out\n if (this.usedForTerrain) {\n const parents = {};\n for (const tileID of idealTileIDs) {\n if (tileID.canonical.z > this._source.minzoom) {\n const parent = tileID.scaledTo(tileID.canonical.z - 1);\n parents[parent.key] = parent;\n // load very low zoom to calculate tile visibility in transform.coveringTiles and high zoomlevels correct\n const parent2 = tileID.scaledTo(Math.max(this._source.minzoom, Math.min(tileID.canonical.z, 5)));\n parents[parent2.key] = parent2;\n }\n }\n idealTileIDs = idealTileIDs.concat(Object.values(parents));\n }\n\n const noPendingDataEmissions = idealTileIDs.length === 0 && !this._updated && this._didEmitContent;\n this._updated = true;\n // if we won't have any tiles to fetch and content is already emitted\n // there will be no more data emissions, so we need to emit the event with isSourceLoaded = true\n if (noPendingDataEmissions) {\n this.fire(new Event('data', {sourceDataType: 'idle', dataType: 'source', sourceId: this.id}));\n }\n\n // Retain is a list of tiles that we shouldn't delete, even if they are not\n // the most ideal tile for the current viewport. This may include tiles like\n // parent or child tiles that are *already* loaded.\n const retain = this._updateRetainedTiles(idealTileIDs, zoom);\n\n if (isRasterType(this._source.type)) {\n this._updateCoveredAndRetainedTiles(retain, minCoveringZoom, maxCoveringZoom, zoom, idealTileIDs, terrain);\n }\n\n for (const retainedId in retain) {\n // Make sure retained tiles always clear any existing fade holds\n // so that if they're removed again their fade timer starts fresh.\n this._tiles[retainedId].clearFadeHold();\n }\n\n // Remove the tiles we don't need anymore.\n const remove = keysDifference(this._tiles, retain);\n for (const tileID of remove) {\n const tile = this._tiles[tileID];\n if (tile.hasSymbolBuckets && !tile.holdingForFade()) {\n tile.setHoldDuration(this.map._fadeDuration);\n } else if (!tile.hasSymbolBuckets || tile.symbolFadeFinished()) {\n this._removeTile(tileID);\n }\n }\n\n // Construct caches of loaded parents & siblings\n this._updateLoadedParentTileCache();\n this._updateLoadedSiblingTileCache();\n }\n\n releaseSymbolFadeTiles() {\n for (const id in this._tiles) {\n if (this._tiles[id].holdingForFade()) {\n this._removeTile(id);\n }\n }\n }\n\n _updateRetainedTiles(idealTileIDs: Array, zoom: number): {[_: string]: OverscaledTileID} {\n const retain: {[_: string]: OverscaledTileID} = {};\n const checked: {[_: string]: boolean} = {};\n const minCoveringZoom = Math.max(zoom - SourceCache.maxOverzooming, this._source.minzoom);\n const maxCoveringZoom = Math.max(zoom + SourceCache.maxUnderzooming, this._source.minzoom);\n\n const missingTiles = {};\n for (const tileID of idealTileIDs) {\n const tile = this._addTile(tileID);\n\n // retain the tile even if it's not loaded because it's an ideal tile.\n retain[tileID.key] = tileID;\n\n if (tile.hasData()) continue;\n\n if (zoom < this._source.maxzoom) {\n // save missing tiles that potentially have loaded children\n missingTiles[tileID.key] = tileID;\n }\n }\n\n // retain any loaded children of ideal tiles up to maxCoveringZoom\n this._retainLoadedChildren(missingTiles, zoom, maxCoveringZoom, retain);\n\n for (const tileID of idealTileIDs) {\n let tile = this._tiles[tileID.key];\n\n if (tile.hasData()) continue;\n\n // The tile we require is not yet loaded or does not exist;\n // Attempt to find children that fully cover it.\n\n if (zoom + 1 > this._source.maxzoom) {\n // We're looking for an overzoomed child tile.\n const childCoord = tileID.children(this._source.maxzoom)[0];\n const childTile = this.getTile(childCoord);\n if (!!childTile && childTile.hasData()) {\n retain[childCoord.key] = childCoord;\n continue; // tile is covered by overzoomed child\n }\n } else {\n // check if all 4 immediate children are loaded (i.e. the missing ideal tile is covered)\n const children = tileID.children(this._source.maxzoom);\n\n if (retain[children[0].key] &&\n retain[children[1].key] &&\n retain[children[2].key] &&\n retain[children[3].key]) continue; // tile is covered by children\n }\n\n // We couldn't find child tiles that entirely cover the ideal tile; look for parents now.\n\n // As we ascend up the tile pyramid of the ideal tile, we check whether the parent\n // tile has been previously requested (and errored because we only loop over tiles with no data)\n // in order to determine if we need to request its parent.\n let parentWasRequested = tile.wasRequested();\n\n for (let overscaledZ = tileID.overscaledZ - 1; overscaledZ >= minCoveringZoom; --overscaledZ) {\n const parentId = tileID.scaledTo(overscaledZ);\n\n // Break parent tile ascent if this route has been previously checked by another child.\n if (checked[parentId.key]) break;\n checked[parentId.key] = true;\n\n tile = this.getTile(parentId);\n if (!tile && parentWasRequested) {\n tile = this._addTile(parentId);\n }\n if (tile) {\n const hasData = tile.hasData();\n if (hasData || !this.map?.cancelPendingTileRequestsWhileZooming || parentWasRequested) {\n retain[parentId.key] = parentId;\n }\n // Save the current values, since they're the parent of the next iteration\n // of the parent tile ascent loop.\n parentWasRequested = tile.wasRequested();\n if (hasData) break;\n }\n }\n }\n\n return retain;\n }\n\n _updateLoadedParentTileCache() {\n this._loadedParentTiles = {};\n\n for (const tileKey in this._tiles) {\n const path = [];\n let parentTile: Tile;\n let currentId = this._tiles[tileKey].tileID;\n\n // Find the closest loaded ancestor by traversing the tile tree towards the root and\n // caching results along the way\n while (currentId.overscaledZ > 0) {\n\n // Do we have a cached result from previous traversals?\n if (currentId.key in this._loadedParentTiles) {\n parentTile = this._loadedParentTiles[currentId.key];\n break;\n }\n\n path.push(currentId.key);\n\n // Is the parent loaded?\n const parentId = currentId.scaledTo(currentId.overscaledZ - 1);\n parentTile = this._getLoadedTile(parentId);\n if (parentTile) {\n break;\n }\n\n currentId = parentId;\n }\n\n // Cache the result of this traversal to all newly visited tiles\n for (const key of path) {\n this._loadedParentTiles[key] = parentTile;\n }\n }\n }\n\n /**\n * Update the cache of loaded sibling tiles\n *\n * Sibling tiles are tiles that share the same zoom level and\n * x/y position but have different wrap values\n * Maintaining sibling tile cache allows fading from old to new tiles\n * of the same position and zoom level\n */\n _updateLoadedSiblingTileCache() {\n this._loadedSiblingTiles = {};\n\n for (const tileKey in this._tiles) {\n const currentId = this._tiles[tileKey].tileID;\n const siblingTile: Tile = this._getLoadedTile(currentId);\n this._loadedSiblingTiles[currentId.key] = siblingTile;\n }\n }\n\n /**\n * Add a tile, given its coordinate, to the pyramid.\n */\n _addTile(tileID: OverscaledTileID): Tile {\n let tile = this._tiles[tileID.key];\n if (tile)\n return tile;\n\n tile = this._cache.getAndRemove(tileID);\n if (tile) {\n this._setTileReloadTimer(tileID.key, tile);\n // set the tileID because the cached tile could have had a different wrap value\n tile.tileID = tileID;\n this._state.initializeTileState(tile, this.map ? this.map.painter : null);\n if (this._cacheTimers[tileID.key]) {\n clearTimeout(this._cacheTimers[tileID.key]);\n delete this._cacheTimers[tileID.key];\n this._setTileReloadTimer(tileID.key, tile);\n }\n }\n\n const cached = tile;\n\n if (!tile) {\n tile = new Tile(tileID, this._source.tileSize * tileID.overscaleFactor());\n this._loadTile(tile, tileID.key, tile.state);\n }\n\n tile.uses++;\n this._tiles[tileID.key] = tile;\n if (!cached) {\n this._source.fire(new Event('dataloading', {tile, coord: tile.tileID, dataType: 'source'}));\n }\n\n return tile;\n }\n\n _setTileReloadTimer(id: string, tile: Tile) {\n if (id in this._timers) {\n clearTimeout(this._timers[id]);\n delete this._timers[id];\n }\n\n const expiryTimeout = tile.getExpiryTimeout();\n if (expiryTimeout) {\n this._timers[id] = setTimeout(() => {\n this._reloadTile(id, 'expired');\n delete this._timers[id];\n }, expiryTimeout);\n }\n }\n\n /**\n * Remove a tile, given its id, from the pyramid\n */\n _removeTile(id: string) {\n const tile = this._tiles[id];\n if (!tile)\n return;\n\n tile.uses--;\n delete this._tiles[id];\n if (this._timers[id]) {\n clearTimeout(this._timers[id]);\n delete this._timers[id];\n }\n\n if (tile.uses > 0)\n return;\n\n if (tile.hasData() && tile.state !== 'reloading') {\n this._cache.add(tile.tileID, tile, tile.getExpiryTimeout());\n } else {\n tile.aborted = true;\n this._abortTile(tile);\n this._unloadTile(tile);\n }\n }\n\n /** @internal */\n private _dataHandler(e: MapSourceDataEvent) {\n\n const eventSourceDataType = e.sourceDataType;\n if (e.dataType === 'source' && eventSourceDataType === 'metadata') {\n this._sourceLoaded = true;\n }\n\n // for sources with mutable data, this event fires when the underlying data\n // to a source is changed. (i.e. GeoJSONSource#setData and ImageSource#serCoordinates)\n if (this._sourceLoaded && !this._paused && e.dataType === 'source' && eventSourceDataType === 'content') {\n this.reload();\n if (this.transform) {\n this.update(this.transform, this.terrain);\n }\n\n this._didEmitContent = true;\n }\n }\n\n /**\n * Remove all tiles from this pyramid\n */\n clearTiles() {\n this._shouldReloadOnResume = false;\n this._paused = false;\n\n for (const id in this._tiles)\n this._removeTile(id);\n\n this._cache.reset();\n }\n\n /**\n * Search through our current tiles and attempt to find the tiles that\n * cover the given bounds.\n * @param pointQueryGeometry - coordinates of the corners of bounding rectangle\n * @returns result items have `{tile, minX, maxX, minY, maxY}`, where min/max bounding values are the given bounds transformed in into the coordinate space of this tile.\n */\n tilesIn(pointQueryGeometry: Array, maxPitchScaleFactor: number, has3DLayer: boolean): any[] {\n\n const tileResults = [];\n\n const transform = this.transform;\n if (!transform) return tileResults;\n\n const cameraPointQueryGeometry = has3DLayer ?\n transform.getCameraQueryGeometry(pointQueryGeometry) :\n pointQueryGeometry;\n\n const queryGeometry = pointQueryGeometry.map((p: Point) => transform.pointCoordinate(p, this.terrain));\n const cameraQueryGeometry = cameraPointQueryGeometry.map((p: Point) => transform.pointCoordinate(p, this.terrain));\n\n const ids = this.getIds();\n\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for (const p of cameraQueryGeometry) {\n minX = Math.min(minX, p.x);\n minY = Math.min(minY, p.y);\n maxX = Math.max(maxX, p.x);\n maxY = Math.max(maxY, p.y);\n }\n\n for (let i = 0; i < ids.length; i++) {\n const tile = this._tiles[ids[i]];\n if (tile.holdingForFade()) {\n // Tiles held for fading are covered by tiles that are closer to ideal\n continue;\n }\n const tileID = tile.tileID;\n const scale = Math.pow(2, transform.zoom - tile.tileID.overscaledZ);\n const queryPadding = maxPitchScaleFactor * tile.queryPadding * EXTENT / tile.tileSize / scale;\n\n const tileSpaceBounds = [\n tileID.getTilePoint(new MercatorCoordinate(minX, minY)),\n tileID.getTilePoint(new MercatorCoordinate(maxX, maxY))\n ];\n\n if (tileSpaceBounds[0].x - queryPadding < EXTENT && tileSpaceBounds[0].y - queryPadding < EXTENT &&\n tileSpaceBounds[1].x + queryPadding >= 0 && tileSpaceBounds[1].y + queryPadding >= 0) {\n\n const tileSpaceQueryGeometry: Array = queryGeometry.map((c) => tileID.getTilePoint(c));\n const tileSpaceCameraQueryGeometry = cameraQueryGeometry.map((c) => tileID.getTilePoint(c));\n\n tileResults.push({\n tile,\n tileID,\n queryGeometry: tileSpaceQueryGeometry,\n cameraQueryGeometry: tileSpaceCameraQueryGeometry,\n scale\n });\n }\n }\n\n return tileResults;\n }\n\n getVisibleCoordinates(symbolLayer?: boolean): Array {\n const coords = this.getRenderableIds(symbolLayer).map((id) => this._tiles[id].tileID);\n for (const coord of coords) {\n coord.posMatrix = this.transform.calculatePosMatrix(coord.toUnwrapped());\n }\n return coords;\n }\n\n hasTransition() {\n if (this._source.hasTransition()) {\n return true;\n }\n\n if (isRasterType(this._source.type)) {\n const now = browser.now();\n for (const id in this._tiles) {\n const tile = this._tiles[id];\n if (tile.fadeEndTime >= now) {\n return true;\n }\n }\n }\n\n return false;\n }\n\n /**\n * Set the value of a particular state for a feature\n */\n setFeatureState(sourceLayer: string, featureId: number | string, state: any) {\n sourceLayer = sourceLayer || '_geojsonTileLayer';\n this._state.updateState(sourceLayer, featureId, state);\n }\n\n /**\n * Resets the value of a particular state key for a feature\n */\n removeFeatureState(sourceLayer?: string, featureId?: number | string, key?: string) {\n sourceLayer = sourceLayer || '_geojsonTileLayer';\n this._state.removeFeatureState(sourceLayer, featureId, key);\n }\n\n /**\n * Get the entire state object for a feature\n */\n getFeatureState(sourceLayer: string, featureId: number | string) {\n sourceLayer = sourceLayer || '_geojsonTileLayer';\n return this._state.getState(sourceLayer, featureId);\n }\n\n /**\n * Sets the set of keys that the tile depends on. This allows tiles to\n * be reloaded when their dependencies change.\n */\n setDependencies(tileKey: string, namespace: string, dependencies: Array) {\n const tile = this._tiles[tileKey];\n if (tile) {\n tile.setDependencies(namespace, dependencies);\n }\n }\n\n /**\n * Reloads all tiles that depend on the given keys.\n */\n reloadTilesForDependencies(namespaces: Array, keys: Array) {\n for (const id in this._tiles) {\n const tile = this._tiles[id];\n if (tile.hasDependency(namespaces, keys)) {\n this._reloadTile(id, 'reloading');\n }\n }\n this._cache.filter(tile => !tile.hasDependency(namespaces, keys));\n }\n}\n\nSourceCache.maxOverzooming = 10;\nSourceCache.maxUnderzooming = 3;\n\nfunction compareTileId(a: OverscaledTileID, b: OverscaledTileID): number {\n // Different copies of the world are sorted based on their distance to the center.\n // Wrap values are converted to unsigned distances by reserving odd number for copies\n // with negative wrap and even numbers for copies with positive wrap.\n const aWrap = Math.abs(a.wrap * 2) - +(a.wrap < 0);\n const bWrap = Math.abs(b.wrap * 2) - +(b.wrap < 0);\n return a.overscaledZ - b.overscaledZ || bWrap - aWrap || b.canonical.y - a.canonical.y || b.canonical.x - a.canonical.x;\n}\n\nfunction isRasterType(type) {\n return type === 'raster' || type === 'image' || type === 'video';\n}\n","import {clamp} from '../util/util';\nimport Point from '@mapbox/point-geometry';\n\nexport class PathInterpolator {\n points: Array;\n length: number;\n paddedLength: number;\n padding: number;\n _distances: Array;\n\n constructor(points_?: Array | null, padding_?: number | null) {\n this.reset(points_, padding_);\n }\n\n reset(points_?: Array | null, padding_?: number | null) {\n this.points = points_ || [];\n\n // Compute cumulative distance from first point to every other point in the segment.\n // Last entry in the array is total length of the path\n this._distances = [0.0];\n\n for (let i = 1; i < this.points.length; i++) {\n this._distances[i] = this._distances[i - 1] + this.points[i].dist(this.points[i - 1]);\n }\n\n this.length = this._distances[this._distances.length - 1];\n this.padding = Math.min(padding_ || 0, this.length * 0.5);\n this.paddedLength = this.length - this.padding * 2.0;\n }\n\n lerp(t: number): Point {\n if (this.points.length === 1) {\n return this.points[0];\n }\n\n t = clamp(t, 0, 1);\n\n // Find the correct segment [p0, p1] where p0 <= x < p1\n let currentIndex = 1;\n let distOfCurrentIdx = this._distances[currentIndex];\n const distToTarget = t * this.paddedLength + this.padding;\n\n while (distOfCurrentIdx < distToTarget && currentIndex < this._distances.length) {\n distOfCurrentIdx = this._distances[++currentIndex];\n }\n\n // Interpolate between the two points of the segment\n const idxOfPrevPoint = currentIndex - 1;\n const distOfPrevIdx = this._distances[idxOfPrevPoint];\n const segmentLength = distOfCurrentIdx - distOfPrevIdx;\n const segmentT = segmentLength > 0 ? (distToTarget - distOfPrevIdx) / segmentLength : 0;\n\n return this.points[idxOfPrevPoint].mult(1.0 - segmentT).add(this.points[currentIndex].mult(segmentT));\n }\n}\n","import type {OverlapMode} from '../style/style_layer/overlap_mode';\n\ntype QueryArgs = {\n hitTest: boolean;\n overlapMode?: OverlapMode;\n circle?: {\n x: number;\n y: number;\n radius: number;\n };\n seenUids: {\n box: {\n [_: number]: boolean;\n };\n circle: {\n [_: number]: boolean;\n };\n };\n};\n\ntype QueryResult = {\n key: T;\n x1: number;\n y1: number;\n x2: number;\n y2: number;\n};\n\n/**\n * A key for the grid\n */\nexport type GridKey = {\n overlapMode?: OverlapMode;\n}\n\nfunction overlapAllowed(overlapA: OverlapMode, overlapB: OverlapMode): boolean {\n let allowed = true;\n\n if (overlapA === 'always') {\n // symbol A using 'always' overlap - allowed to overlap anything.\n } else if (overlapA === 'never' || overlapB === 'never') {\n // symbol A using 'never' overlap - can't overlap anything\n // symbol A using 'cooperative' overlap - can overlap 'always' or 'cooperative' symbol; can't overlap 'never'\n allowed = false;\n }\n\n return allowed;\n}\n\n/**\n * @internal\n * GridIndex is a data structure for testing the intersection of\n * circles and rectangles in a 2d plane.\n * It is optimized for rapid insertion and querying.\n * GridIndex splits the plane into a set of \"cells\" and keeps track\n * of which geometries intersect with each cell. At query time,\n * full geometry comparisons are only done for items that share\n * at least one cell. As long as the geometries are relatively\n * uniformly distributed across the plane, this greatly reduces\n * the number of comparisons necessary.\n */\nexport class GridIndex {\n circleKeys: Array;\n boxKeys: Array;\n boxCells: Array>;\n circleCells: Array>;\n bboxes: Array;\n circles: Array;\n xCellCount: number;\n yCellCount: number;\n width: number;\n height: number;\n xScale: number;\n yScale: number;\n boxUid: number;\n circleUid: number;\n\n constructor (width: number, height: number, cellSize: number) {\n const boxCells = this.boxCells = [];\n const circleCells = this.circleCells = [];\n\n // More cells -> fewer geometries to check per cell, but items tend\n // to be split across more cells.\n // Sweet spot allows most small items to fit in one cell\n this.xCellCount = Math.ceil(width / cellSize);\n this.yCellCount = Math.ceil(height / cellSize);\n\n for (let i = 0; i < this.xCellCount * this.yCellCount; i++) {\n boxCells.push([]);\n circleCells.push([]);\n }\n this.circleKeys = [];\n this.boxKeys = [];\n this.bboxes = [];\n this.circles = [];\n\n this.width = width;\n this.height = height;\n this.xScale = this.xCellCount / width;\n this.yScale = this.yCellCount / height;\n this.boxUid = 0;\n this.circleUid = 0;\n }\n\n keysLength() {\n return this.boxKeys.length + this.circleKeys.length;\n }\n\n insert(key: T, x1: number, y1: number, x2: number, y2: number) {\n this._forEachCell(x1, y1, x2, y2, this._insertBoxCell, this.boxUid++);\n this.boxKeys.push(key);\n this.bboxes.push(x1);\n this.bboxes.push(y1);\n this.bboxes.push(x2);\n this.bboxes.push(y2);\n }\n\n insertCircle(key: T, x: number, y: number, radius: number) {\n // Insert circle into grid for all cells in the circumscribing square\n // It's more than necessary (by a factor of 4/PI), but fast to insert\n this._forEachCell(x - radius, y - radius, x + radius, y + radius, this._insertCircleCell, this.circleUid++);\n this.circleKeys.push(key);\n this.circles.push(x);\n this.circles.push(y);\n this.circles.push(radius);\n }\n\n private _insertBoxCell(x1: number, y1: number, x2: number, y2: number, cellIndex: number, uid: number) {\n this.boxCells[cellIndex].push(uid);\n }\n\n private _insertCircleCell(x1: number, y1: number, x2: number, y2: number, cellIndex: number, uid: number) {\n this.circleCells[cellIndex].push(uid);\n }\n\n private _query(x1: number, y1: number, x2: number, y2: number, hitTest: boolean, overlapMode: OverlapMode, predicate?: (key: T) => boolean): Array> {\n if (x2 < 0 || x1 > this.width || y2 < 0 || y1 > this.height) {\n return [];\n }\n const result: Array> = [];\n if (x1 <= 0 && y1 <= 0 && this.width <= x2 && this.height <= y2) {\n if (hitTest) {\n // Covers the entire grid, so collides with everything\n return [{\n key: null,\n x1,\n y1,\n x2,\n y2\n }];\n }\n for (let boxUid = 0; boxUid < this.boxKeys.length; boxUid++) {\n result.push({\n key: this.boxKeys[boxUid],\n x1: this.bboxes[boxUid * 4],\n y1: this.bboxes[boxUid * 4 + 1],\n x2: this.bboxes[boxUid * 4 + 2],\n y2: this.bboxes[boxUid * 4 + 3]\n });\n }\n for (let circleUid = 0; circleUid < this.circleKeys.length; circleUid++) {\n const x = this.circles[circleUid * 3];\n const y = this.circles[circleUid * 3 + 1];\n const radius = this.circles[circleUid * 3 + 2];\n result.push({\n key: this.circleKeys[circleUid],\n x1: x - radius,\n y1: y - radius,\n x2: x + radius,\n y2: y + radius\n });\n }\n } else {\n const queryArgs: QueryArgs = {\n hitTest,\n overlapMode,\n seenUids: {box: {}, circle: {}}\n };\n this._forEachCell(x1, y1, x2, y2, this._queryCell, result, queryArgs, predicate);\n }\n\n return result;\n }\n\n query(x1: number, y1: number, x2: number, y2: number): Array> {\n return this._query(x1, y1, x2, y2, false, null);\n }\n\n hitTest(x1: number, y1: number, x2: number, y2: number, overlapMode: OverlapMode, predicate?: (key: T) => boolean): boolean {\n return this._query(x1, y1, x2, y2, true, overlapMode, predicate).length > 0;\n }\n\n hitTestCircle(x: number, y: number, radius: number, overlapMode: OverlapMode, predicate?: (key: T) => boolean): boolean {\n // Insert circle into grid for all cells in the circumscribing square\n // It's more than necessary (by a factor of 4/PI), but fast to insert\n const x1 = x - radius;\n const x2 = x + radius;\n const y1 = y - radius;\n const y2 = y + radius;\n if (x2 < 0 || x1 > this.width || y2 < 0 || y1 > this.height) {\n return false;\n }\n\n // Box query early exits if the bounding box is larger than the grid, but we don't do\n // the equivalent calculation for circle queries because early exit is less likely\n // and the calculation is more expensive\n const result: boolean[] = [];\n const queryArgs: QueryArgs = {\n hitTest: true,\n overlapMode,\n circle: {x, y, radius},\n seenUids: {box: {}, circle: {}}\n };\n this._forEachCell(x1, y1, x2, y2, this._queryCellCircle, result, queryArgs, predicate);\n return result.length > 0;\n }\n\n private _queryCell(x1: number, y1: number, x2: number, y2: number, cellIndex: number, result: Array>, queryArgs: QueryArgs, predicate?: (key: T) => boolean): boolean {\n const {seenUids, hitTest, overlapMode} = queryArgs;\n const boxCell = this.boxCells[cellIndex];\n\n if (boxCell !== null) {\n const bboxes = this.bboxes;\n for (const boxUid of boxCell) {\n if (!seenUids.box[boxUid]) {\n seenUids.box[boxUid] = true;\n const offset = boxUid * 4;\n const key = this.boxKeys[boxUid];\n\n if ((x1 <= bboxes[offset + 2]) &&\n (y1 <= bboxes[offset + 3]) &&\n (x2 >= bboxes[offset + 0]) &&\n (y2 >= bboxes[offset + 1]) &&\n (!predicate || predicate(key))) {\n if (!hitTest || !overlapAllowed(overlapMode, key.overlapMode)) {\n result.push({\n key,\n x1: bboxes[offset],\n y1: bboxes[offset + 1],\n x2: bboxes[offset + 2],\n y2: bboxes[offset + 3]\n });\n if (hitTest) {\n // true return value stops the query after first match\n return true;\n }\n }\n }\n }\n }\n }\n const circleCell = this.circleCells[cellIndex];\n if (circleCell !== null) {\n const circles = this.circles;\n for (const circleUid of circleCell) {\n if (!seenUids.circle[circleUid]) {\n seenUids.circle[circleUid] = true;\n const offset = circleUid * 3;\n const key = this.circleKeys[circleUid];\n\n if (this._circleAndRectCollide(\n circles[offset],\n circles[offset + 1],\n circles[offset + 2],\n x1,\n y1,\n x2,\n y2) &&\n (!predicate || predicate(key))) {\n if (!hitTest || !overlapAllowed(overlapMode, key.overlapMode)) {\n const x = circles[offset];\n const y = circles[offset + 1];\n const radius = circles[offset + 2];\n result.push({\n key,\n x1: x - radius,\n y1: y - radius,\n x2: x + radius,\n y2: y + radius\n });\n if (hitTest) {\n // true return value stops the query after first match\n return true;\n }\n }\n }\n }\n }\n }\n\n // false return to continue query\n return false;\n }\n\n private _queryCellCircle(x1: number, y1: number, x2: number, y2: number, cellIndex: number, result: Array, queryArgs: QueryArgs, predicate?: (key: T) => boolean): boolean {\n const {circle, seenUids, overlapMode} = queryArgs;\n const boxCell = this.boxCells[cellIndex];\n\n if (boxCell !== null) {\n const bboxes = this.bboxes;\n for (const boxUid of boxCell) {\n if (!seenUids.box[boxUid]) {\n seenUids.box[boxUid] = true;\n const offset = boxUid * 4;\n const key = this.boxKeys[boxUid];\n if (this._circleAndRectCollide(\n circle.x,\n circle.y,\n circle.radius,\n bboxes[offset + 0],\n bboxes[offset + 1],\n bboxes[offset + 2],\n bboxes[offset + 3]) &&\n (!predicate || predicate(key)) &&\n !overlapAllowed(overlapMode, key.overlapMode)) {\n result.push(true);\n return true;\n }\n }\n }\n }\n\n const circleCell = this.circleCells[cellIndex];\n if (circleCell !== null) {\n const circles = this.circles;\n for (const circleUid of circleCell) {\n if (!seenUids.circle[circleUid]) {\n seenUids.circle[circleUid] = true;\n const offset = circleUid * 3;\n const key = this.circleKeys[circleUid];\n if (this._circlesCollide(\n circles[offset],\n circles[offset + 1],\n circles[offset + 2],\n circle.x,\n circle.y,\n circle.radius) &&\n (!predicate || predicate(key)) &&\n !overlapAllowed(overlapMode, key.overlapMode)) {\n result.push(true);\n return true;\n }\n }\n }\n }\n }\n\n private _forEachCell(\n x1: number,\n y1: number,\n x2: number,\n y2: number,\n fn: (x1: number, y1: number, x2: number, y2: number, cellIndex: number, arg1: TArg, arg2?: QueryArgs, predicate?: (key: T) => boolean) => boolean | void,\n arg1: TArg,\n arg2?: QueryArgs,\n predicate?: (key: T) => boolean) {\n const cx1 = this._convertToXCellCoord(x1);\n const cy1 = this._convertToYCellCoord(y1);\n const cx2 = this._convertToXCellCoord(x2);\n const cy2 = this._convertToYCellCoord(y2);\n\n for (let x = cx1; x <= cx2; x++) {\n for (let y = cy1; y <= cy2; y++) {\n const cellIndex = this.xCellCount * y + x;\n if (fn.call(this, x1, y1, x2, y2, cellIndex, arg1, arg2, predicate)) return;\n }\n }\n }\n\n private _convertToXCellCoord(x: number) {\n return Math.max(0, Math.min(this.xCellCount - 1, Math.floor(x * this.xScale)));\n }\n\n private _convertToYCellCoord(y: number) {\n return Math.max(0, Math.min(this.yCellCount - 1, Math.floor(y * this.yScale)));\n }\n\n private _circlesCollide(x1: number, y1: number, r1: number, x2: number, y2: number, r2: number): boolean {\n const dx = x2 - x1;\n const dy = y2 - y1;\n const bothRadii = r1 + r2;\n return (bothRadii * bothRadii) > (dx * dx + dy * dy);\n }\n\n private _circleAndRectCollide(\n circleX: number,\n circleY: number,\n radius: number,\n x1: number,\n y1: number,\n x2: number,\n y2: number\n ): boolean {\n const halfRectWidth = (x2 - x1) / 2;\n const distX = Math.abs(circleX - (x1 + halfRectWidth));\n if (distX > (halfRectWidth + radius)) {\n return false;\n }\n\n const halfRectHeight = (y2 - y1) / 2;\n const distY = Math.abs(circleY - (y1 + halfRectHeight));\n if (distY > (halfRectHeight + radius)) {\n return false;\n }\n\n if (distX <= halfRectWidth || distY <= halfRectHeight) {\n return true;\n }\n\n const dx = distX - halfRectWidth;\n const dy = distY - halfRectHeight;\n return (dx * dx + dy * dy <= (radius * radius));\n }\n}\n","import Point from '@mapbox/point-geometry';\n\nimport {mat4, vec4} from 'gl-matrix';\nimport * as symbolSize from './symbol_size';\nimport {addDynamicAttributes} from '../data/bucket/symbol_bucket';\n\nimport type {Painter} from '../render/painter';\nimport type {Transform} from '../geo/transform';\nimport type {SymbolBucket} from '../data/bucket/symbol_bucket';\nimport type {\n GlyphOffsetArray,\n SymbolLineVertexArray,\n SymbolDynamicLayoutArray\n} from '../data/array_types.g';\nimport {WritingMode} from '../symbol/shaping';\nimport {findLineIntersection} from '../util/util';\nimport {UnwrappedTileID} from '../source/tile_id';\nimport {Projection} from '../geo/projection/projection';\n\nexport {\n updateLineLabels,\n hideGlyphs,\n getLabelPlaneMatrix,\n getGlCoordMatrix,\n project,\n getPerspectiveRatio,\n placeFirstAndLastGlyph,\n placeGlyphAlongLine,\n xyTransformMat4,\n projectLineVertexToViewport as projectVertexToViewport,\n projectTileCoordinatesToViewport,\n findOffsetIntersectionPoint,\n transformToOffsetNormal,\n};\n\n/**\n * The result of projecting a point to the screen, with some additional information about the projection.\n */\nexport type PointProjection = {\n /**\n * The projected point.\n */\n point: Point;\n /**\n * The original W component of the projection.\n */\n signedDistanceFromCamera: number;\n /**\n * For complex projections (such as globe), true if the point is occluded by the projection, such as by being on the backfacing side of the globe.\n */\n isOccluded: boolean;\n};\n\n/*\n * # Overview of coordinate spaces\n *\n * ## Tile coordinate spaces\n * Each label has an anchor. Some labels have corresponding line geometries.\n * The points for both anchors and lines are stored in tile units. Each tile has it's own\n * coordinate space going from (0, 0) at the top left to (EXTENT, EXTENT) at the bottom right.\n *\n * ## Clip space (GL coordinate space)\n * At the end of everything, the vertex shader needs to produce a position in clip space,\n * which is (-1, 1) at the top left and (1, -1) in the bottom right.\n * In the depth buffer, values are between 0 (near plane) to 1 (far plane).\n *\n * ## Map pixel coordinate spaces\n * Each tile has a pixel coordinate space. It's just the tile units scaled so that one unit is\n * whatever counts as 1 pixel at the current zoom.\n * This space is used for pitch-alignment=map, rotation-alignment=map\n *\n * ## Rotated map pixel coordinate spaces\n * Like the above, but rotated so axis of the space are aligned with the viewport instead of the tile.\n * This space is used for pitch-alignment=map, rotation-alignment=viewport\n *\n * ## Viewport pixel coordinate space\n * (0, 0) is at the top left of the canvas and (pixelWidth, pixelHeight) is at the bottom right corner\n * of the canvas. This space is used for pitch-alignment=viewport\n *\n *\n * # Vertex projection\n * It goes roughly like this:\n * 1. project the anchor and line from tile units into the correct label coordinate space\n * - map pixel space pitch-alignment=map rotation-alignment=map\n * - rotated map pixel space pitch-alignment=map rotation-alignment=viewport\n * - viewport pixel space pitch-alignment=viewport rotation-alignment=*\n * 2. if the label follows a line, find the point along the line that is the correct distance from the anchor.\n * 3. add the glyph's corner offset to the point from step 3\n * 4. convert from the label coordinate space to clip space\n *\n * For horizontal labels we want to do step 1 in the shader for performance reasons (no cpu work).\n * This is what `u_label_plane_matrix` is used for.\n * For labels aligned with lines we have to steps 1 and 2 on the cpu since we need access to the line geometry.\n * This is what `updateLineLabels(...)` does.\n * Since the conversion is handled on the cpu we just set `u_label_plane_matrix` to an identity matrix.\n *\n * Steps 3 and 4 are done in the shaders for all labels.\n */\n\n/*\n * Returns a matrix for converting from tile units to the correct label coordinate space.\n */\nfunction getLabelPlaneMatrix(posMatrix: mat4,\n pitchWithMap: boolean,\n rotateWithMap: boolean,\n transform: Transform,\n pixelsToTileUnits: number) {\n const m = mat4.create();\n if (pitchWithMap) {\n mat4.scale(m, m, [1 / pixelsToTileUnits, 1 / pixelsToTileUnits, 1]);\n if (!rotateWithMap) {\n mat4.rotateZ(m, m, transform.angle);\n }\n } else {\n mat4.multiply(m, transform.labelPlaneMatrix, posMatrix);\n }\n return m;\n}\n\n/*\n * Returns a matrix for converting from the correct label coordinate space to clip space.\n */\nfunction getGlCoordMatrix(posMatrix: mat4,\n pitchWithMap: boolean,\n rotateWithMap: boolean,\n transform: Transform,\n pixelsToTileUnits: number) {\n if (pitchWithMap) {\n const m = mat4.clone(posMatrix);\n mat4.scale(m, m, [pixelsToTileUnits, pixelsToTileUnits, 1]);\n if (!rotateWithMap) {\n mat4.rotateZ(m, m, -transform.angle);\n }\n return m;\n } else {\n return transform.glCoordMatrix;\n }\n}\n\nfunction project(x: number, y: number, matrix: mat4, getElevation?: (x: number, y: number) => number): PointProjection {\n let pos;\n if (getElevation) { // slow because of handle z-index\n pos = [x, y, getElevation(x, y), 1] as vec4;\n vec4.transformMat4(pos, pos, matrix);\n } else { // fast because of ignore z-index\n pos = [x, y, 0, 1] as vec4;\n xyTransformMat4(pos, pos, matrix);\n }\n const w = pos[3];\n return {\n point: new Point(pos[0] / w, pos[1] / w),\n signedDistanceFromCamera: w,\n isOccluded: false\n };\n}\n\nfunction getPerspectiveRatio(cameraToCenterDistance: number, signedDistanceFromCamera: number): number {\n return 0.5 + 0.5 * (cameraToCenterDistance / signedDistanceFromCamera);\n}\n\nfunction isVisible(p: Point,\n clippingBuffer: [number, number]) {\n const inPaddedViewport = (\n p.x >= -clippingBuffer[0] &&\n p.x <= clippingBuffer[0] &&\n p.y >= -clippingBuffer[1] &&\n p.y <= clippingBuffer[1]);\n return inPaddedViewport;\n}\n\n/*\n * Update the `dynamicLayoutVertexBuffer` for the buffer with the correct glyph positions for the current map view.\n * This is only run on labels that are aligned with lines. Horizontal labels are handled entirely in the shader.\n */\nfunction updateLineLabels(bucket: SymbolBucket,\n posMatrix: mat4,\n painter: Painter,\n isText: boolean,\n labelPlaneMatrix: mat4,\n glCoordMatrix: mat4,\n pitchWithMap: boolean,\n keepUpright: boolean,\n rotateToLine: boolean,\n projection: Projection,\n unwrappedTileID: UnwrappedTileID,\n viewportWidth: number,\n viewportHeight: number,\n translation: [number, number],\n getElevation: (x: number, y: number) => number) {\n\n const sizeData = isText ? bucket.textSizeData : bucket.iconSizeData;\n const partiallyEvaluatedSize = symbolSize.evaluateSizeForZoom(sizeData, painter.transform.zoom);\n\n const clippingBuffer: [number, number] = [256 / painter.width * 2 + 1, 256 / painter.height * 2 + 1];\n\n const dynamicLayoutVertexArray = isText ?\n bucket.text.dynamicLayoutVertexArray :\n bucket.icon.dynamicLayoutVertexArray;\n dynamicLayoutVertexArray.clear();\n\n const lineVertexArray = bucket.lineVertexArray;\n const placedSymbols = isText ? bucket.text.placedSymbolArray : bucket.icon.placedSymbolArray;\n\n const aspectRatio = painter.transform.width / painter.transform.height;\n\n let useVertical = false;\n\n for (let s = 0; s < placedSymbols.length; s++) {\n const symbol = placedSymbols.get(s);\n\n // Don't do calculations for vertical glyphs unless the previous symbol was horizontal\n // and we determined that vertical glyphs were necessary.\n // Also don't do calculations for symbols that are collided and fully faded out\n if (symbol.hidden || symbol.writingMode === WritingMode.vertical && !useVertical) {\n hideGlyphs(symbol.numGlyphs, dynamicLayoutVertexArray);\n continue;\n }\n // Awkward... but we're counting on the paired \"vertical\" symbol coming immediately after its horizontal counterpart\n useVertical = false;\n\n const anchorPos = project(symbol.anchorX, symbol.anchorY, posMatrix, getElevation);\n\n // Don't bother calculating the correct point for invisible labels.\n if (!isVisible(anchorPos.point, clippingBuffer)) {\n hideGlyphs(symbol.numGlyphs, dynamicLayoutVertexArray);\n continue;\n }\n\n const cameraToAnchorDistance = anchorPos.signedDistanceFromCamera;\n const perspectiveRatio = getPerspectiveRatio(painter.transform.cameraToCenterDistance, cameraToAnchorDistance);\n\n const fontSize = symbolSize.evaluateSizeForFeature(sizeData, partiallyEvaluatedSize, symbol);\n const pitchScaledFontSize = pitchWithMap ? fontSize / perspectiveRatio : fontSize * perspectiveRatio;\n\n const tileAnchorPoint = new Point(symbol.anchorX, symbol.anchorY);\n const projectionCache: ProjectionCache = {projections: {}, offsets: {}, cachedAnchorPoint: undefined, anyProjectionOccluded: false};\n\n const projectionContext: SymbolProjectionContext = {\n getElevation,\n labelPlaneMatrix,\n lineVertexArray,\n pitchWithMap,\n projectionCache,\n projection,\n tileAnchorPoint,\n unwrappedTileID,\n width: viewportWidth,\n height: viewportHeight,\n translation\n };\n\n const placeUnflipped: any = placeGlyphsAlongLine(projectionContext, symbol, pitchScaledFontSize, false /*unflipped*/, keepUpright, posMatrix, glCoordMatrix,\n bucket.glyphOffsetArray, dynamicLayoutVertexArray, aspectRatio, rotateToLine);\n\n useVertical = placeUnflipped.useVertical;\n\n if (placeUnflipped.notEnoughRoom || useVertical ||\n (placeUnflipped.needsFlipping &&\n (placeGlyphsAlongLine(projectionContext, symbol, pitchScaledFontSize, true /*flipped*/, keepUpright, posMatrix, glCoordMatrix,\n bucket.glyphOffsetArray, dynamicLayoutVertexArray, aspectRatio, rotateToLine) as any).notEnoughRoom)) {\n hideGlyphs(symbol.numGlyphs, dynamicLayoutVertexArray);\n }\n }\n\n if (isText) {\n bucket.text.dynamicLayoutVertexBuffer.updateData(dynamicLayoutVertexArray);\n } else {\n bucket.icon.dynamicLayoutVertexBuffer.updateData(dynamicLayoutVertexArray);\n }\n}\n\ntype FirstAndLastGlyphPlacement = {\n first: PlacedGlyph;\n last: PlacedGlyph;\n} | null;\n\n/*\n * Place the first and last glyph of a line label, projected to the label plane.\n * This function is called both during collision detection (to determine the label's size)\n * and during line label rendering (to make sure the label fits on the line geometry with\n * the current camera position, which may differ from the position used during collision detection).\n *\n * Calling this function has the effect of populating the \"projectionCache\" with all projected\n * vertex locations the label will need, making future calls to placeGlyphAlongLine (for all the\n * intermediate glyphs) much cheaper.\n *\n * Returns null if the label can't fit on the geometry\n */\nfunction placeFirstAndLastGlyph(\n fontScale: number,\n glyphOffsetArray: GlyphOffsetArray,\n lineOffsetX: number,\n lineOffsetY: number,\n flip: boolean,\n symbol: any,\n rotateToLine: boolean,\n projectionContext: SymbolProjectionContext): FirstAndLastGlyphPlacement {\n const glyphEndIndex = symbol.glyphStartIndex + symbol.numGlyphs;\n const lineStartIndex = symbol.lineStartIndex;\n const lineEndIndex = symbol.lineStartIndex + symbol.lineLength;\n\n const firstGlyphOffset = glyphOffsetArray.getoffsetX(symbol.glyphStartIndex);\n const lastGlyphOffset = glyphOffsetArray.getoffsetX(glyphEndIndex - 1);\n\n const firstPlacedGlyph = placeGlyphAlongLine(fontScale * firstGlyphOffset, lineOffsetX, lineOffsetY, flip, symbol.segment,\n lineStartIndex, lineEndIndex, projectionContext, rotateToLine);\n if (!firstPlacedGlyph)\n return null;\n\n const lastPlacedGlyph = placeGlyphAlongLine(fontScale * lastGlyphOffset, lineOffsetX, lineOffsetY, flip, symbol.segment,\n lineStartIndex, lineEndIndex, projectionContext, rotateToLine);\n if (!lastPlacedGlyph)\n return null;\n\n if (projectionContext.projectionCache.anyProjectionOccluded) {\n return null;\n }\n\n return {first: firstPlacedGlyph, last: lastPlacedGlyph};\n}\n\nfunction requiresOrientationChange(writingMode, firstPoint, lastPoint, aspectRatio) {\n if (writingMode === WritingMode.horizontal) {\n // On top of choosing whether to flip, choose whether to render this version of the glyphs or the alternate\n // vertical glyphs. We can't just filter out vertical glyphs in the horizontal range because the horizontal\n // and vertical versions can have slightly different projections which could lead to angles where both or\n // neither showed.\n const rise = Math.abs(lastPoint.y - firstPoint.y);\n const run = Math.abs(lastPoint.x - firstPoint.x) * aspectRatio;\n if (rise > run) {\n return {useVertical: true};\n }\n }\n\n if (writingMode === WritingMode.vertical ? firstPoint.y < lastPoint.y : firstPoint.x > lastPoint.x) {\n // Includes \"horizontalOnly\" case for labels without vertical glyphs\n return {needsFlipping: true};\n }\n\n return null;\n}\n\n/*\n* Place first and last glyph along the line projected to label plane, and if they fit\n* iterate through all the intermediate glyphs, calculating their label plane positions\n* from the projected line.\n*\n* Finally, add resulting glyph position calculations to dynamicLayoutVertexArray for\n* upload to the GPU\n*/\nfunction placeGlyphsAlongLine(projectionContext: SymbolProjectionContext, symbol, fontSize, flip, keepUpright, posMatrix, glCoordMatrix, glyphOffsetArray, dynamicLayoutVertexArray, aspectRatio, rotateToLine) {\n const fontScale = fontSize / 24;\n const lineOffsetX = symbol.lineOffsetX * fontScale;\n const lineOffsetY = symbol.lineOffsetY * fontScale;\n\n let placedGlyphs;\n if (symbol.numGlyphs > 1) {\n const glyphEndIndex = symbol.glyphStartIndex + symbol.numGlyphs;\n const lineStartIndex = symbol.lineStartIndex;\n const lineEndIndex = symbol.lineStartIndex + symbol.lineLength;\n\n // Place the first and the last glyph in the label first, so we can figure out\n // the overall orientation of the label and determine whether it needs to be flipped in keepUpright mode\n const firstAndLastGlyph = placeFirstAndLastGlyph(fontScale, glyphOffsetArray, lineOffsetX, lineOffsetY, flip, symbol, rotateToLine, projectionContext);\n if (!firstAndLastGlyph) {\n return {notEnoughRoom: true};\n }\n const firstPoint = project(firstAndLastGlyph.first.point.x, firstAndLastGlyph.first.point.y, glCoordMatrix, projectionContext.getElevation).point;\n const lastPoint = project(firstAndLastGlyph.last.point.x, firstAndLastGlyph.last.point.y, glCoordMatrix, projectionContext.getElevation).point;\n\n if (keepUpright && !flip) {\n const orientationChange = requiresOrientationChange(symbol.writingMode, firstPoint, lastPoint, aspectRatio);\n if (orientationChange) {\n return orientationChange;\n }\n }\n\n placedGlyphs = [firstAndLastGlyph.first];\n for (let glyphIndex = symbol.glyphStartIndex + 1; glyphIndex < glyphEndIndex - 1; glyphIndex++) {\n // Since first and last glyph fit on the line, we're sure that the rest of the glyphs can be placed\n placedGlyphs.push(placeGlyphAlongLine(fontScale * glyphOffsetArray.getoffsetX(glyphIndex), lineOffsetX, lineOffsetY, flip, symbol.segment,\n lineStartIndex, lineEndIndex, projectionContext, rotateToLine));\n }\n placedGlyphs.push(firstAndLastGlyph.last);\n } else {\n // Only a single glyph to place\n // So, determine whether to flip based on projected angle of the line segment it's on\n if (keepUpright && !flip) {\n const a = project(projectionContext.tileAnchorPoint.x, projectionContext.tileAnchorPoint.y, posMatrix, projectionContext.getElevation).point;\n const tileVertexIndex = (symbol.lineStartIndex + symbol.segment + 1);\n const tileSegmentEnd = new Point(projectionContext.lineVertexArray.getx(tileVertexIndex), projectionContext.lineVertexArray.gety(tileVertexIndex));\n const projectedVertex = project(tileSegmentEnd.x, tileSegmentEnd.y, posMatrix, projectionContext.getElevation);\n // We know the anchor will be in the viewport, but the end of the line segment may be\n // behind the plane of the camera, in which case we can use a point at any arbitrary (closer)\n // point on the segment.\n const b = (projectedVertex.signedDistanceFromCamera > 0) ?\n projectedVertex.point :\n projectTruncatedLineSegmentToLabelPlane(projectionContext.tileAnchorPoint, tileSegmentEnd, a, 1, posMatrix, projectionContext);\n\n const orientationChange = requiresOrientationChange(symbol.writingMode, a, b, aspectRatio);\n if (orientationChange) {\n return orientationChange;\n }\n }\n const singleGlyph = placeGlyphAlongLine(fontScale * glyphOffsetArray.getoffsetX(symbol.glyphStartIndex), lineOffsetX, lineOffsetY, flip, symbol.segment,\n symbol.lineStartIndex, symbol.lineStartIndex + symbol.lineLength, projectionContext, rotateToLine);\n if (!singleGlyph || projectionContext.projectionCache.anyProjectionOccluded)\n return {notEnoughRoom: true};\n\n placedGlyphs = [singleGlyph];\n }\n\n for (const glyph of placedGlyphs) {\n addDynamicAttributes(dynamicLayoutVertexArray, glyph.point, glyph.angle);\n }\n return {};\n}\n\n/**\n * Takes a line and direction from `previousTilePoint` to `currentTilePoint`,\n * projects it to *label plane*,\n * and returns a projected point along this projected line that is `minimumLength` distance away from `previousProjectedPoint`.\n * @param previousTilePoint - Line start point, in tile coordinates.\n * @param currentTilePoint - Line end point, in tile coordinates.\n * @param previousProjectedPoint - Projection of `previousTilePoint` into *label plane*.\n * @param minimumLength - Distance in the projected space along the line for the returned point.\n * @param projectionMatrix - Matrix to use during projection.\n * @param projectionContext - Projection context, used only for terrain's `getElevation`.\n */\nfunction projectTruncatedLineSegmentToLabelPlane(previousTilePoint: Point, currentTilePoint: Point, previousProjectedPoint: Point, minimumLength: number, projectionMatrix: mat4, projectionContext: SymbolProjectionContext) {\n return _projectTruncatedLineSegment(previousTilePoint, currentTilePoint, previousProjectedPoint, minimumLength, projectionMatrix, projectionContext);\n}\n\n/**\n * Takes a line and direction from `previousTilePoint` to `currentTilePoint`,\n * projects it to *viewport*,\n * and returns a projected point along this projected line that is `minimumLength` distance away from `previousProjectedPoint`.\n * @param previousTilePoint - Line start point, in tile coordinates.\n * @param currentTilePoint - Line end point, in tile coordinates.\n * @param previousProjectedPoint - Projection of `previousTilePoint` into *viewport*.\n * @param minimumLength - Distance in the projected space along the line for the returned point.\n * @param projectionContext - Projection context, used for terrain's `getElevation`, and either the `labelPlaneMatrix` or the map's special projection (mostly for globe).\n */\nfunction projectTruncatedLineSegmentToViewport(previousTilePoint: Point, currentTilePoint: Point, previousProjectedPoint: Point, minimumLength: number, projectionContext: SymbolProjectionContext) {\n return _projectTruncatedLineSegment(previousTilePoint, currentTilePoint, previousProjectedPoint, minimumLength, undefined, projectionContext);\n}\n\n/**\n * Do not use directly, use {@link projectTruncatedLineSegmentToLabelPlane} or {@link projectTruncatedLineSegmentToViewport} instead,\n * depending on the target space.\n *\n * Projects a \"virtual\" vertex along a line segment.\n * If `projectionMatrix` is not undefined, does a simple projection using this matrix.\n * Otherwise, either projects to label plane using the `labelPlaneMatrix`\n * or projects to viewport using the special map projection (mostly for globe) by calling {@link projectTileCoordinatesToViewport}.\n */\nfunction _projectTruncatedLineSegment(previousTilePoint: Point, currentTilePoint: Point, previousProjectedPoint: Point, minimumLength: number, projectionMatrix: mat4 | undefined, projectionContext: SymbolProjectionContext) {\n // We are assuming \"previousTilePoint\" won't project to a point within one unit of the camera plane\n // If it did, that would mean our label extended all the way out from within the viewport to a (very distant)\n // point near the plane of the camera. We wouldn't be able to render the label anyway once it crossed the\n // plane of the camera.\n const unitVertexToBeProjected = previousTilePoint.add(previousTilePoint.sub(currentTilePoint)._unit());\n const projectedUnitVertex = projectionMatrix !== undefined ?\n project(unitVertexToBeProjected.x, unitVertexToBeProjected.y, projectionMatrix, projectionContext.getElevation).point :\n projectTileCoordinatesToViewport(unitVertexToBeProjected.x, unitVertexToBeProjected.y, projectionContext).point;\n const projectedUnitSegment = previousProjectedPoint.sub(projectedUnitVertex);\n return previousProjectedPoint.add(projectedUnitSegment._mult(minimumLength / projectedUnitSegment.mag()));\n}\n\ntype IndexToPointCache = { [lineIndex: number]: Point };\n\n/**\n * @internal\n * We calculate label-plane projected points for line vertices as we place glyphs along the line\n * Since we will use the same vertices for potentially many glyphs, cache the results for this bucket\n * over the course of the render. Each vertex location also potentially has one offset equivalent\n * for us to hold onto. The vertex indices are per-symbol-bucket.\n */\ntype ProjectionCache = {\n /**\n * tile-unit vertices projected into label-plane units\n */\n projections: IndexToPointCache;\n /**\n * label-plane vertices which have been shifted to follow an offset line\n */\n offsets: IndexToPointCache;\n /**\n * Cached projected anchor point.\n */\n cachedAnchorPoint: Point | undefined;\n /**\n * Was any projected point occluded by the map itself (eg. occluded by the planet when using globe projection).\n *\n * Viewport-pitched line-following texts where *any* of the line points is hidden behind the planet curve becomes entirely hidden.\n * This is perhaps not the most ideal behavior, but it works, it is simple and planetary-scale texts such as this seem to be a rare edge case.\n */\n anyProjectionOccluded: boolean;\n};\n\n/**\n * @internal\n * Arguments necessary to project a vertex to the label plane\n */\nexport type SymbolProjectionContext = {\n /**\n * Used to cache results, save cost if projecting the same vertex multiple times\n */\n projectionCache: ProjectionCache;\n /**\n * The array of tile-unit vertices transferred from worker\n */\n lineVertexArray: SymbolLineVertexArray;\n /**\n * Label plane projection matrix\n */\n labelPlaneMatrix: mat4;\n /**\n * Function to get elevation at a point\n * @param x - the x coordinate\n * @param y - the y coordinate\n */\n getElevation: (x: number, y: number) => number;\n /**\n * Only for creating synthetic vertices if vertex would otherwise project behind plane of camera,\n * but still convenient to pass it inside this type.\n */\n tileAnchorPoint: Point;\n /**\n * True when line glyphs are projected onto the map, instead of onto the viewport.\n */\n pitchWithMap: boolean;\n projection: Projection;\n unwrappedTileID: UnwrappedTileID;\n /**\n * Viewport width.\n */\n width: number;\n /**\n * Viewport height.\n */\n height: number;\n /**\n * Translation in tile units, computed using text-translate and text-translate-anchor paint style properties.\n */\n translation: [number, number];\n};\n\n/**\n * Only for creating synthetic vertices if vertex would otherwise project behind plane of camera\n */\nexport type ProjectionSyntheticVertexArgs = {\n distanceFromAnchor: number;\n previousVertex: Point;\n direction: number;\n absOffsetX: number;\n};\n\n/**\n * Transform a vertex from tile coordinates to label plane coordinates\n * @param index - index of vertex to project\n * @param projectionContext - necessary data to project a vertex\n * @returns the vertex projected to the label plane\n */\nfunction projectLineVertexToViewport(index: number, projectionContext: SymbolProjectionContext, syntheticVertexArgs: ProjectionSyntheticVertexArgs): Point {\n const cache = projectionContext.projectionCache;\n\n if (cache.projections[index]) {\n return cache.projections[index];\n }\n const currentVertex = new Point(\n projectionContext.lineVertexArray.getx(index),\n projectionContext.lineVertexArray.gety(index));\n\n const projection = projectTileCoordinatesToViewport(currentVertex.x, currentVertex.y, projectionContext);\n\n if (projection.signedDistanceFromCamera > 0) {\n cache.projections[index] = projection.point;\n cache.anyProjectionOccluded = cache.anyProjectionOccluded || projection.isOccluded;\n return projection.point;\n }\n\n // The vertex is behind the plane of the camera, so we can't project it\n // Instead, we'll create a vertex along the line that's far enough to include the glyph\n const previousLineVertexIndex = index - syntheticVertexArgs.direction;\n const previousTilePoint = syntheticVertexArgs.distanceFromAnchor === 0 ?\n projectionContext.tileAnchorPoint :\n new Point(projectionContext.lineVertexArray.getx(previousLineVertexIndex), projectionContext.lineVertexArray.gety(previousLineVertexIndex));\n\n // Don't cache because the new vertex might not be far enough out for future glyphs on the same segment\n const minimumLength = syntheticVertexArgs.absOffsetX - syntheticVertexArgs.distanceFromAnchor + 1;\n return projectTruncatedLineSegmentToViewport(previousTilePoint, currentVertex, syntheticVertexArgs.previousVertex, minimumLength, projectionContext);\n}\n\nfunction projectTileCoordinatesToViewport(x: number, y: number, projectionContext: SymbolProjectionContext): PointProjection {\n const translatedX = x + projectionContext.translation[0];\n const translatedY = y + projectionContext.translation[1];\n let projection;\n if (!projectionContext.pitchWithMap && projectionContext.projection.useSpecialProjectionForSymbols) {\n projection = projectionContext.projection.projectTileCoordinates(translatedX, translatedY, projectionContext.unwrappedTileID, projectionContext.getElevation);\n projection.point.x = (projection.point.x * 0.5 + 0.5) * projectionContext.width;\n projection.point.y = (-projection.point.y * 0.5 + 0.5) * projectionContext.height;\n } else {\n projection = project(translatedX, translatedY, projectionContext.labelPlaneMatrix, projectionContext.getElevation);\n projection.isOccluded = false;\n }\n return projection;\n}\n\n/**\n * Calculate the normal vector for a line segment\n * @param segmentVector - will be mutated as a tiny optimization\n * @param offset - magnitude of resulting vector\n * @param direction - direction of line traversal\n * @returns a normal vector from the segment, with magnitude equal to offset amount\n */\nfunction transformToOffsetNormal(segmentVector: Point, offset: number, direction: number): Point {\n return segmentVector._unit()._perp()._mult(offset * direction);\n}\n\n/**\n * Construct offset line segments for the current segment and the next segment, then extend/shrink\n * the segments until they intersect. If the segments are parallel, then they will touch with no modification.\n *\n * @param index - Index of the current vertex\n * @param prevToCurrentOffsetNormal - Normal vector of the line segment from the previous vertex to the current vertex\n * @param currentVertex - Current (non-offset) vertex projected to the label plane\n * @param lineStartIndex - Beginning index for the line this label is on\n * @param lineEndIndex - End index for the line this label is on\n * @param offsetPreviousVertex - The previous vertex projected to the label plane, and then offset along the previous segments normal\n * @param lineOffsetY - Magnitude of the offset\n * @param projectionContext - Necessary data for tile-to-label-plane projection\n * @returns The point at which the current and next line segments intersect, once offset and extended/shrunk to their meeting point\n */\nfunction findOffsetIntersectionPoint(\n index: number,\n prevToCurrentOffsetNormal: Point,\n currentVertex: Point,\n lineStartIndex: number,\n lineEndIndex: number,\n offsetPreviousVertex: Point,\n lineOffsetY: number,\n projectionContext: SymbolProjectionContext,\n syntheticVertexArgs: ProjectionSyntheticVertexArgs) {\n if (projectionContext.projectionCache.offsets[index]) {\n return projectionContext.projectionCache.offsets[index];\n }\n\n const offsetCurrentVertex = currentVertex.add(prevToCurrentOffsetNormal);\n\n if (index + syntheticVertexArgs.direction < lineStartIndex || index + syntheticVertexArgs.direction >= lineEndIndex) {\n // This is the end of the line, no intersection to calculate\n projectionContext.projectionCache.offsets[index] = offsetCurrentVertex;\n return offsetCurrentVertex;\n }\n // Offset the vertices for the next segment\n const nextVertex = projectLineVertexToViewport(index + syntheticVertexArgs.direction, projectionContext, syntheticVertexArgs);\n const currentToNextOffsetNormal = transformToOffsetNormal(nextVertex.sub(currentVertex), lineOffsetY, syntheticVertexArgs.direction);\n const offsetNextSegmentBegin = currentVertex.add(currentToNextOffsetNormal);\n const offsetNextSegmentEnd = nextVertex.add(currentToNextOffsetNormal);\n\n // find the intersection of these two lines\n // if the lines are parallel, offsetCurrent/offsetNextBegin will touch\n projectionContext.projectionCache.offsets[index] = findLineIntersection(offsetPreviousVertex, offsetCurrentVertex, offsetNextSegmentBegin, offsetNextSegmentEnd) || offsetCurrentVertex;\n\n return projectionContext.projectionCache.offsets[index];\n}\n\n/**\n * Placed Glyph type\n */\ntype PlacedGlyph = {\n /**\n * The point at which the glyph should be placed, in label plane coordinates\n */\n point: Point;\n /**\n * The angle at which the glyph should be placed\n */\n angle: number;\n /**\n * The label-plane path used to reach this glyph: used only for collision detection\n */\n path: Array;\n};\n\n/*\n * Place a single glyph along its line, projected into the label plane, by iterating outward\n * from the anchor point until the distance traversed in the label plane equals the glyph's\n * offsetX. Returns null if the glyph can't fit on the line geometry.\n */\nfunction placeGlyphAlongLine(\n offsetX: number,\n lineOffsetX: number,\n lineOffsetY: number,\n flip: boolean,\n anchorSegment: number,\n lineStartIndex: number,\n lineEndIndex: number,\n projectionContext: SymbolProjectionContext,\n rotateToLine: boolean): PlacedGlyph | null {\n\n const combinedOffsetX = flip ?\n offsetX - lineOffsetX :\n offsetX + lineOffsetX;\n\n let direction = combinedOffsetX > 0 ? 1 : -1;\n\n let angle = 0;\n if (flip) {\n // The label needs to be flipped to keep text upright.\n // Iterate in the reverse direction.\n direction *= -1;\n angle = Math.PI;\n }\n\n if (direction < 0) angle += Math.PI;\n\n let currentIndex = direction > 0 ?\n lineStartIndex + anchorSegment :\n lineStartIndex + anchorSegment + 1;\n\n // Project anchor point to proper label plane and cache it\n let anchorPoint: Point;\n\n if (projectionContext.projectionCache.cachedAnchorPoint) {\n anchorPoint = projectionContext.projectionCache.cachedAnchorPoint;\n } else {\n anchorPoint = projectTileCoordinatesToViewport(projectionContext.tileAnchorPoint.x, projectionContext.tileAnchorPoint.y, projectionContext).point;\n projectionContext.projectionCache.cachedAnchorPoint = anchorPoint;\n }\n\n let currentVertex = anchorPoint;\n let previousVertex = anchorPoint;\n\n // offsetPrev and intersectionPoint are analogous to previousVertex and currentVertex\n // but if there's a line offset they are calculated in parallel as projection happens\n let offsetIntersectionPoint: Point;\n let offsetPreviousVertex: Point;\n\n let distanceFromAnchor = 0;\n let currentSegmentDistance = 0;\n const absOffsetX = Math.abs(combinedOffsetX);\n const pathVertices: Array = [];\n\n let currentLineSegment: Point;\n while (distanceFromAnchor + currentSegmentDistance <= absOffsetX) {\n currentIndex += direction;\n\n // offset does not fit on the projected line\n if (currentIndex < lineStartIndex || currentIndex >= lineEndIndex)\n return null;\n\n // accumulate values from last iteration\n distanceFromAnchor += currentSegmentDistance;\n previousVertex = currentVertex;\n offsetPreviousVertex = offsetIntersectionPoint;\n\n const syntheticVertexArgs: ProjectionSyntheticVertexArgs = {\n absOffsetX,\n direction,\n distanceFromAnchor,\n previousVertex\n };\n\n // find next vertex in viewport space\n currentVertex = projectLineVertexToViewport(currentIndex, projectionContext, syntheticVertexArgs);\n if (lineOffsetY === 0) {\n // Store vertices for collision detection and update current segment geometry\n pathVertices.push(previousVertex);\n currentLineSegment = currentVertex.sub(previousVertex);\n } else {\n // Calculate the offset for this section\n let prevToCurrentOffsetNormal;\n const prevToCurrent = currentVertex.sub(previousVertex);\n if (prevToCurrent.mag() === 0) {\n // We are starting with our anchor point directly on the vertex, so look one vertex ahead\n // to calculate a normal\n const nextVertex = projectLineVertexToViewport(currentIndex + direction, projectionContext, syntheticVertexArgs);\n prevToCurrentOffsetNormal = transformToOffsetNormal(nextVertex.sub(currentVertex), lineOffsetY, direction);\n } else {\n prevToCurrentOffsetNormal = transformToOffsetNormal(prevToCurrent, lineOffsetY, direction);\n }\n // Initialize offsetPrev on our first iteration, after that it will be pre-calculated\n if (!offsetPreviousVertex)\n offsetPreviousVertex = previousVertex.add(prevToCurrentOffsetNormal);\n\n offsetIntersectionPoint = findOffsetIntersectionPoint(currentIndex, prevToCurrentOffsetNormal, currentVertex, lineStartIndex, lineEndIndex, offsetPreviousVertex, lineOffsetY, projectionContext, syntheticVertexArgs);\n\n pathVertices.push(offsetPreviousVertex);\n currentLineSegment = offsetIntersectionPoint.sub(offsetPreviousVertex);\n }\n currentSegmentDistance = currentLineSegment.mag();\n }\n\n // The point is on the current segment. Interpolate to find it.\n const segmentInterpolationT = (absOffsetX - distanceFromAnchor) / currentSegmentDistance;\n const p = currentLineSegment._mult(segmentInterpolationT)._add(offsetPreviousVertex || previousVertex);\n\n const segmentAngle = angle + Math.atan2(currentVertex.y - previousVertex.y, currentVertex.x - previousVertex.x);\n\n pathVertices.push(p);\n\n return {\n point: p,\n angle: rotateToLine ? segmentAngle : 0.0,\n path: pathVertices\n };\n}\n\nconst hiddenGlyphAttributes = new Float32Array([-Infinity, -Infinity, 0, -Infinity, -Infinity, 0, -Infinity, -Infinity, 0, -Infinity, -Infinity, 0]);\n\n// Hide them by moving them offscreen. We still need to add them to the buffer\n// because the dynamic buffer is paired with a static buffer that doesn't get updated.\nfunction hideGlyphs(num: number, dynamicLayoutVertexArray: SymbolDynamicLayoutArray) {\n for (let i = 0; i < num; i++) {\n const offset = dynamicLayoutVertexArray.length;\n dynamicLayoutVertexArray.resize(offset + 4);\n // Since all hidden glyphs have the same attributes, we can build up the array faster with a single call to Float32Array.set\n // for each set of four vertices, instead of calling addDynamicAttributes for each vertex.\n dynamicLayoutVertexArray.float32.set(hiddenGlyphAttributes, offset * 3);\n }\n}\n\n// For line label layout, we're not using z output and our w input is always 1\n// This custom matrix transformation ignores those components to make projection faster\nfunction xyTransformMat4(out: vec4, a: vec4, m: mat4) {\n const x = a[0], y = a[1];\n out[0] = m[0] * x + m[4] * y + m[12];\n out[1] = m[1] * x + m[5] * y + m[13];\n out[3] = m[3] * x + m[7] * y + m[15];\n return out;\n}\n","import Point from '@mapbox/point-geometry';\nimport {clipLine} from './clip_line';\nimport {PathInterpolator} from './path_interpolator';\n\nimport * as intersectionTests from '../util/intersection_tests';\nimport {GridIndex} from './grid_index';\nimport {mat4, vec4} from 'gl-matrix';\nimport ONE_EM from '../symbol/one_em';\n\nimport * as projection from '../symbol/projection';\n\nimport type {Transform} from '../geo/transform';\nimport type {SingleCollisionBox} from '../data/bucket/symbol_bucket';\nimport type {\n GlyphOffsetArray,\n SymbolLineVertexArray\n} from '../data/array_types.g';\nimport type {OverlapMode} from '../style/style_layer/overlap_mode';\nimport {UnwrappedTileID} from '../source/tile_id';\nimport {SymbolProjectionContext} from '../symbol/projection';\nimport {Projection} from '../geo/projection/projection';\nimport {clamp, getAABB} from '../util/util';\n\n// When a symbol crosses the edge that causes it to be included in\n// collision detection, it will cause changes in the symbols around\n// it. This constant specifies how many pixels to pad the edge of\n// the viewport for collision detection so that the bulk of the changes\n// occur offscreen. Making this constant greater increases label\n// stability, but it's expensive.\nexport const viewportPadding = 100;\n\nexport type PlacedCircles = {\n circles: Array;\n offscreen: boolean;\n collisionDetected: boolean;\n};\n\nexport type PlacedBox = {\n box: Array;\n placeable: boolean;\n offscreen: boolean;\n};\n\nexport type FeatureKey = {\n bucketInstanceId: number;\n featureIndex: number;\n collisionGroupID: number;\n overlapMode: OverlapMode;\n};\n\ntype ProjectedBox = {\n /**\n * The AABB in the format [minX, minY, maxX, maxY].\n */\n box: [number, number, number, number];\n allPointsOccluded: boolean;\n};\n\n/**\n * @internal\n * A collision index used to prevent symbols from overlapping. It keep tracks of\n * where previous symbols have been placed and is used to check if a new\n * symbol overlaps with any previously added symbols.\n *\n * There are two steps to insertion: first placeCollisionBox/Circles checks if\n * there's room for a symbol, then insertCollisionBox/Circles actually puts the\n * symbol in the index. The two step process allows paired symbols to be inserted\n * together even if they overlap.\n */\nexport class CollisionIndex {\n grid: GridIndex;\n ignoredGrid: GridIndex;\n transform: Transform;\n pitchFactor: number;\n screenRightBoundary: number;\n screenBottomBoundary: number;\n gridRightBoundary: number;\n gridBottomBoundary: number;\n mapProjection: Projection;\n\n // With perspectiveRatio the fontsize is calculated for tilted maps (near = bigger, far = smaller).\n // The cutoff defines a threshold to no longer render labels near the horizon.\n perspectiveRatioCutoff: number;\n\n constructor(\n transform: Transform,\n projection: Projection,\n grid = new GridIndex(transform.width + 2 * viewportPadding, transform.height + 2 * viewportPadding, 25),\n ignoredGrid = new GridIndex(transform.width + 2 * viewportPadding, transform.height + 2 * viewportPadding, 25)\n ) {\n this.transform = transform;\n this.mapProjection = projection;\n\n this.grid = grid;\n this.ignoredGrid = ignoredGrid;\n this.pitchFactor = Math.cos(transform._pitch) * transform.cameraToCenterDistance;\n\n this.screenRightBoundary = transform.width + viewportPadding;\n this.screenBottomBoundary = transform.height + viewportPadding;\n this.gridRightBoundary = transform.width + 2 * viewportPadding;\n this.gridBottomBoundary = transform.height + 2 * viewportPadding;\n\n this.perspectiveRatioCutoff = 0.6;\n }\n\n placeCollisionBox(\n collisionBox: SingleCollisionBox,\n overlapMode: OverlapMode,\n textPixelRatio: number,\n posMatrix: mat4,\n unwrappedTileID: UnwrappedTileID,\n pitchWithMap: boolean,\n rotateWithMap: boolean,\n translation: [number, number],\n collisionGroupPredicate?: (key: FeatureKey) => boolean,\n getElevation?: (x: number, y: number) => number,\n shift?: Point\n ): PlacedBox {\n const x = collisionBox.anchorPointX + translation[0];\n const y = collisionBox.anchorPointY + translation[1];\n const projectedPoint = this.projectAndGetPerspectiveRatio(\n posMatrix,\n x,\n y,\n unwrappedTileID,\n getElevation\n );\n\n const tileToViewport = textPixelRatio * projectedPoint.perspectiveRatio;\n\n let projectedBox: ProjectedBox;\n\n if (!pitchWithMap && !rotateWithMap) {\n // Fast path for common symbols\n const pointX = projectedPoint.point.x + (shift ? shift.x * tileToViewport : 0);\n const pointY = projectedPoint.point.y + (shift ? shift.y * tileToViewport : 0);\n projectedBox = {\n allPointsOccluded: false,\n box: [\n pointX + collisionBox.x1 * tileToViewport,\n pointY + collisionBox.y1 * tileToViewport,\n pointX + collisionBox.x2 * tileToViewport,\n pointY + collisionBox.y2 * tileToViewport,\n ]\n };\n } else {\n projectedBox = this._projectCollisionBox(\n collisionBox,\n tileToViewport,\n posMatrix,\n unwrappedTileID,\n pitchWithMap,\n rotateWithMap,\n translation,\n projectedPoint,\n getElevation,\n shift\n );\n }\n\n const [tlX, tlY, brX, brY] = projectedBox.box;\n\n const projectionOccluded = this.mapProjection.useSpecialProjectionForSymbols ? (pitchWithMap ? projectedBox.allPointsOccluded : this.mapProjection.isOccluded(x, y, unwrappedTileID)) : false;\n\n if (projectionOccluded || projectedPoint.perspectiveRatio < this.perspectiveRatioCutoff || !this.isInsideGrid(tlX, tlY, brX, brY) ||\n (overlapMode !== 'always' && this.grid.hitTest(tlX, tlY, brX, brY, overlapMode, collisionGroupPredicate))) {\n return {\n box: [tlX, tlY, brX, brY],\n placeable: false,\n offscreen: false\n };\n }\n\n return {\n box: [tlX, tlY, brX, brY],\n placeable: true,\n offscreen: this.isOffscreen(tlX, tlY, brX, brY)\n };\n }\n\n placeCollisionCircles(\n overlapMode: OverlapMode,\n symbol: any,\n lineVertexArray: SymbolLineVertexArray,\n glyphOffsetArray: GlyphOffsetArray,\n fontSize: number,\n posMatrix: mat4,\n unwrappedTileID: UnwrappedTileID,\n labelPlaneMatrix: mat4,\n labelToScreenMatrix: mat4,\n showCollisionCircles: boolean,\n pitchWithMap: boolean,\n collisionGroupPredicate: (key: FeatureKey) => boolean,\n circlePixelDiameter: number,\n textPixelPadding: number,\n translation: [number, number],\n getElevation: (x: number, y: number) => number\n ): PlacedCircles {\n const placedCollisionCircles = [];\n\n const tileUnitAnchorPoint = new Point(symbol.anchorX, symbol.anchorY);\n const perspectiveRatio = this.getPerspectiveRatio(posMatrix, tileUnitAnchorPoint.x, tileUnitAnchorPoint.y, unwrappedTileID, getElevation);\n const labelPlaneFontSize = pitchWithMap ? fontSize / perspectiveRatio : fontSize * perspectiveRatio;\n const labelPlaneFontScale = labelPlaneFontSize / ONE_EM;\n\n const projectionCache = {projections: {}, offsets: {}, cachedAnchorPoint: undefined, anyProjectionOccluded: false};\n const lineOffsetX = symbol.lineOffsetX * labelPlaneFontScale;\n const lineOffsetY = symbol.lineOffsetY * labelPlaneFontScale;\n\n const projectionContext: SymbolProjectionContext = {\n getElevation,\n labelPlaneMatrix,\n lineVertexArray,\n pitchWithMap,\n projectionCache,\n projection: this.mapProjection,\n tileAnchorPoint: tileUnitAnchorPoint,\n unwrappedTileID,\n width: this.transform.width,\n height: this.transform.height,\n translation\n };\n\n const firstAndLastGlyph = projection.placeFirstAndLastGlyph(\n labelPlaneFontScale,\n glyphOffsetArray,\n lineOffsetX,\n lineOffsetY,\n /*flip*/ false,\n symbol,\n false,\n projectionContext);\n\n let collisionDetected = false;\n let inGrid = false;\n let entirelyOffscreen = true;\n\n if (firstAndLastGlyph) {\n const radius = circlePixelDiameter * 0.5 * perspectiveRatio + textPixelPadding;\n const screenPlaneMin = new Point(-viewportPadding, -viewportPadding);\n const screenPlaneMax = new Point(this.screenRightBoundary, this.screenBottomBoundary);\n const interpolator = new PathInterpolator();\n\n // Construct a projected path from projected line vertices. Anchor points are ignored and removed\n const first = firstAndLastGlyph.first;\n const last = firstAndLastGlyph.last;\n\n let projectedPath: Array = [];\n for (let i = first.path.length - 1; i >= 1; i--) {\n projectedPath.push(first.path[i]);\n }\n for (let i = 1; i < last.path.length; i++) {\n projectedPath.push(last.path[i]);\n }\n\n // Tolerate a slightly longer distance than one diameter between two adjacent circles\n const circleDist = radius * 2.5;\n\n // The path might need to be converted into screen space if a pitched map is used as the label space\n if (labelToScreenMatrix) {\n const screenSpacePath = this.projectPathToScreenSpace(projectedPath, projectionContext, labelToScreenMatrix);\n // Do not try to place collision circles if even one of the points is behind the camera.\n // This is a plausible scenario with big camera pitch angles\n if (screenSpacePath.some(point => point.signedDistanceFromCamera <= 0)) {\n projectedPath = [];\n } else {\n projectedPath = screenSpacePath.map(p => p.point);\n }\n }\n\n let segments = [];\n\n if (projectedPath.length > 0) {\n // Quickly check if the path is fully inside or outside of the padded collision region.\n // For overlapping paths we'll only create collision circles for the visible segments\n const minPoint = projectedPath[0].clone();\n const maxPoint = projectedPath[0].clone();\n\n for (let i = 1; i < projectedPath.length; i++) {\n minPoint.x = Math.min(minPoint.x, projectedPath[i].x);\n minPoint.y = Math.min(minPoint.y, projectedPath[i].y);\n maxPoint.x = Math.max(maxPoint.x, projectedPath[i].x);\n maxPoint.y = Math.max(maxPoint.y, projectedPath[i].y);\n }\n\n if (minPoint.x >= screenPlaneMin.x && maxPoint.x <= screenPlaneMax.x &&\n minPoint.y >= screenPlaneMin.y && maxPoint.y <= screenPlaneMax.y) {\n // Quad fully visible\n segments = [projectedPath];\n } else if (maxPoint.x < screenPlaneMin.x || minPoint.x > screenPlaneMax.x ||\n maxPoint.y < screenPlaneMin.y || minPoint.y > screenPlaneMax.y) {\n // Not visible\n segments = [];\n } else {\n segments = clipLine([projectedPath], screenPlaneMin.x, screenPlaneMin.y, screenPlaneMax.x, screenPlaneMax.y);\n }\n }\n\n for (const seg of segments) {\n // interpolate positions for collision circles. Add a small padding to both ends of the segment\n interpolator.reset(seg, radius * 0.25);\n\n let numCircles = 0;\n\n if (interpolator.length <= 0.5 * radius) {\n numCircles = 1;\n } else {\n numCircles = Math.ceil(interpolator.paddedLength / circleDist) + 1;\n }\n\n for (let i = 0; i < numCircles; i++) {\n const t = i / Math.max(numCircles - 1, 1);\n const circlePosition = interpolator.lerp(t);\n\n // add viewport padding to the position and perform initial collision check\n const centerX = circlePosition.x + viewportPadding;\n const centerY = circlePosition.y + viewportPadding;\n\n placedCollisionCircles.push(centerX, centerY, radius, 0);\n\n const x1 = centerX - radius;\n const y1 = centerY - radius;\n const x2 = centerX + radius;\n const y2 = centerY + radius;\n\n entirelyOffscreen = entirelyOffscreen && this.isOffscreen(x1, y1, x2, y2);\n inGrid = inGrid || this.isInsideGrid(x1, y1, x2, y2);\n\n if (overlapMode !== 'always' && this.grid.hitTestCircle(centerX, centerY, radius, overlapMode, collisionGroupPredicate)) {\n // Don't early exit if we're showing the debug circles because we still want to calculate\n // which circles are in use\n collisionDetected = true;\n if (!showCollisionCircles) {\n return {\n circles: [],\n offscreen: false,\n collisionDetected\n };\n }\n }\n }\n }\n }\n\n return {\n circles: ((!showCollisionCircles && collisionDetected) || !inGrid || perspectiveRatio < this.perspectiveRatioCutoff) ? [] : placedCollisionCircles,\n offscreen: entirelyOffscreen,\n collisionDetected\n };\n }\n\n projectPathToScreenSpace(projectedPath: Array, projectionContext: SymbolProjectionContext, labelToScreenMatrix: mat4) {\n return projectedPath.map(p => projection.project(p.x, p.y, labelToScreenMatrix, projectionContext.getElevation));\n }\n\n /**\n * Because the geometries in the CollisionIndex are an approximation of the shape of\n * symbols on the map, we use the CollisionIndex to look up the symbol part of\n * `queryRenderedFeatures`.\n */\n queryRenderedSymbols(viewportQueryGeometry: Array) {\n if (viewportQueryGeometry.length === 0 || (this.grid.keysLength() === 0 && this.ignoredGrid.keysLength() === 0)) {\n return {};\n }\n\n const query = [];\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n for (const point of viewportQueryGeometry) {\n const gridPoint = new Point(point.x + viewportPadding, point.y + viewportPadding);\n minX = Math.min(minX, gridPoint.x);\n minY = Math.min(minY, gridPoint.y);\n maxX = Math.max(maxX, gridPoint.x);\n maxY = Math.max(maxY, gridPoint.y);\n query.push(gridPoint);\n }\n\n const features = this.grid.query(minX, minY, maxX, maxY)\n .concat(this.ignoredGrid.query(minX, minY, maxX, maxY));\n\n const seenFeatures = {};\n const result = {};\n\n for (const feature of features) {\n const featureKey = feature.key;\n // Skip already seen features.\n if (seenFeatures[featureKey.bucketInstanceId] === undefined) {\n seenFeatures[featureKey.bucketInstanceId] = {};\n }\n if (seenFeatures[featureKey.bucketInstanceId][featureKey.featureIndex]) {\n continue;\n }\n\n // Check if query intersects with the feature box\n // \"Collision Circles\" for line labels are treated as boxes here\n // Since there's no actual collision taking place, the circle vs. square\n // distinction doesn't matter as much, and box geometry is easier\n // to work with.\n const bbox = [\n new Point(feature.x1, feature.y1),\n new Point(feature.x2, feature.y1),\n new Point(feature.x2, feature.y2),\n new Point(feature.x1, feature.y2)\n ];\n if (!intersectionTests.polygonIntersectsPolygon(query, bbox)) {\n continue;\n }\n\n seenFeatures[featureKey.bucketInstanceId][featureKey.featureIndex] = true;\n if (result[featureKey.bucketInstanceId] === undefined) {\n result[featureKey.bucketInstanceId] = [];\n }\n result[featureKey.bucketInstanceId].push(featureKey.featureIndex);\n }\n\n return result;\n }\n\n insertCollisionBox(collisionBox: Array, overlapMode: OverlapMode, ignorePlacement: boolean, bucketInstanceId: number, featureIndex: number, collisionGroupID: number) {\n const grid = ignorePlacement ? this.ignoredGrid : this.grid;\n\n const key = {bucketInstanceId, featureIndex, collisionGroupID, overlapMode};\n grid.insert(key, collisionBox[0], collisionBox[1], collisionBox[2], collisionBox[3]);\n }\n\n insertCollisionCircles(collisionCircles: Array, overlapMode: OverlapMode, ignorePlacement: boolean, bucketInstanceId: number, featureIndex: number, collisionGroupID: number) {\n const grid = ignorePlacement ? this.ignoredGrid : this.grid;\n\n const key = {bucketInstanceId, featureIndex, collisionGroupID, overlapMode};\n for (let k = 0; k < collisionCircles.length; k += 4) {\n grid.insertCircle(key, collisionCircles[k], collisionCircles[k + 1], collisionCircles[k + 2]);\n }\n }\n\n projectAndGetPerspectiveRatio(posMatrix: mat4, x: number, y: number, _unwrappedTileID: UnwrappedTileID, getElevation?: (x: number, y: number) => number) {\n // The code here is duplicated from \"projection.ts\" for performance.\n // Code here is subject to change once globe is merged.\n let pos;\n if (getElevation) { // slow because of handle z-index\n pos = [x, y, getElevation(x, y), 1] as vec4;\n vec4.transformMat4(pos, pos, posMatrix);\n } else { // fast because of ignore z-index\n pos = [x, y, 0, 1] as vec4;\n projection.xyTransformMat4(pos, pos, posMatrix);\n }\n const w = pos[3];\n return {\n point: new Point(\n (((pos[0] / w + 1) / 2) * this.transform.width) + viewportPadding,\n (((-pos[1] / w + 1) / 2) * this.transform.height) + viewportPadding\n ),\n // See perspective ratio comment in symbol_sdf.vertex\n // We're doing collision detection in viewport space so we need\n // to scale down boxes in the distance\n perspectiveRatio: 0.5 + 0.5 * (this.transform.cameraToCenterDistance / w),\n isOccluded: false,\n signedDistanceFromCamera: w\n };\n }\n\n getPerspectiveRatio(posMatrix: mat4, x: number, y: number, unwrappedTileID: UnwrappedTileID, getElevation?: (x: number, y: number) => number): number {\n // We don't care about the actual projected point, just its W component.\n const projected = this.mapProjection.useSpecialProjectionForSymbols ?\n this.mapProjection.projectTileCoordinates(x, y, unwrappedTileID, getElevation) :\n projection.project(x, y, posMatrix, getElevation);\n return 0.5 + 0.5 * (this.transform.cameraToCenterDistance / projected.signedDistanceFromCamera);\n }\n\n isOffscreen(x1: number, y1: number, x2: number, y2: number) {\n return x2 < viewportPadding || x1 >= this.screenRightBoundary || y2 < viewportPadding || y1 > this.screenBottomBoundary;\n }\n\n isInsideGrid(x1: number, y1: number, x2: number, y2: number) {\n return x2 >= 0 && x1 < this.gridRightBoundary && y2 >= 0 && y1 < this.gridBottomBoundary;\n }\n\n /*\n * Returns a matrix for transforming collision shapes to viewport coordinate space.\n * Use this function to render e.g. collision circles on the screen.\n * example transformation: clipPos = glCoordMatrix * viewportMatrix * circle_pos\n */\n getViewportMatrix() {\n const m = mat4.identity([] as any);\n mat4.translate(m, m, [-viewportPadding, -viewportPadding, 0.0]);\n return m;\n }\n\n /**\n * Applies all layout+paint properties of the given box in order to find as good approximation of its screen-space bounding box as possible.\n */\n private _projectCollisionBox(\n collisionBox: SingleCollisionBox,\n tileToViewport: number,\n posMatrix: mat4,\n unwrappedTileID: UnwrappedTileID,\n pitchWithMap: boolean,\n rotateWithMap: boolean,\n translation: [number, number],\n projectedPoint: {point: Point; perspectiveRatio: number; signedDistanceFromCamera: number},\n getElevation?: (x: number, y: number) => number,\n shift?: Point\n ): ProjectedBox {\n\n // These vectors are valid both for screen space viewport-rotation-aligned texts and for pitch-align: map texts that are map-rotation-aligned.\n let vecEast = new Point(1, 0);\n let vecSouth = new Point(0, 1);\n\n const translatedAnchor = new Point(collisionBox.anchorPointX + translation[0], collisionBox.anchorPointY + translation[1]);\n\n if (rotateWithMap && !pitchWithMap) {\n // Handles screen space texts that are always aligned east-west.\n const projectedEast = this.projectAndGetPerspectiveRatio(\n posMatrix,\n translatedAnchor.x + 1,\n translatedAnchor.y,\n unwrappedTileID,\n getElevation\n ).point;\n const toEast = projectedEast.sub(projectedPoint.point).unit();\n const angle = Math.atan(toEast.y / toEast.x) + (toEast.x < 0 ? Math.PI : 0);\n const sin = Math.sin(angle);\n const cos = Math.cos(angle);\n vecEast = new Point(cos, sin);\n vecSouth = new Point(-sin, cos);\n } else if (!rotateWithMap && pitchWithMap) {\n // Handles pitch-align: map texts that are always aligned with the viewport's X axis.\n const angle = -this.transform.angle;\n const sin = Math.sin(angle);\n const cos = Math.cos(angle);\n vecEast = new Point(cos, sin);\n vecSouth = new Point(-sin, cos);\n }\n\n // Configuration for screen space offsets\n let basePoint = projectedPoint.point;\n let distanceMultiplier = tileToViewport;\n\n if (pitchWithMap) {\n // Configuration for tile space (map-pitch-aligned) offsets\n basePoint = translatedAnchor;\n\n const zoomFraction = this.transform.zoom - Math.floor(this.transform.zoom);\n distanceMultiplier = Math.pow(2, -zoomFraction);\n distanceMultiplier *= this.mapProjection.getPitchedTextCorrection(this.transform, translatedAnchor, unwrappedTileID);\n\n // This next correction can't be applied when variable anchors are in use.\n if (!shift) {\n // Shader applies a perspective size correction, we need to apply the same correction.\n // For non-pitchWithMap texts, this is handled above by multiplying `textPixelRatio` with `projectedPoint.perspectiveRatio`,\n // which is equivalent to the non-pitchWithMap branch of the GLSL code.\n // Here, we compute and apply the pitchWithMap branch.\n // See the computation of `perspective_ratio` in the symbol vertex shaders for the GLSL code.\n const distanceRatio = projectedPoint.signedDistanceFromCamera / this.transform.cameraToCenterDistance;\n const perspectiveRatio = clamp(0.5 + 0.5 * distanceRatio, 0.0, 4.0); // Same clamp as what is used in the shader.\n distanceMultiplier *= perspectiveRatio;\n }\n }\n\n if (shift) {\n // Variable anchors are in use\n basePoint = basePoint.add(vecEast.mult(shift.x * distanceMultiplier)).add(vecSouth.mult(shift.y * distanceMultiplier));\n }\n\n const offsetXmin = collisionBox.x1 * distanceMultiplier;\n const offsetXmax = collisionBox.x2 * distanceMultiplier;\n const offsetXhalf = (offsetXmin + offsetXmax) / 2;\n const offsetYmin = collisionBox.y1 * distanceMultiplier;\n const offsetYmax = collisionBox.y2 * distanceMultiplier;\n const offsetYhalf = (offsetYmin + offsetYmax) / 2;\n\n // 0--1--2\n // | |\n // 7 3\n // | |\n // 6--5--4\n const offsetsArray: Array<{offsetX: number; offsetY: number}> = [\n {offsetX: offsetXmin, offsetY: offsetYmin},\n {offsetX: offsetXhalf, offsetY: offsetYmin},\n {offsetX: offsetXmax, offsetY: offsetYmin},\n {offsetX: offsetXmax, offsetY: offsetYhalf},\n {offsetX: offsetXmax, offsetY: offsetYmax},\n {offsetX: offsetXhalf, offsetY: offsetYmax},\n {offsetX: offsetXmin, offsetY: offsetYmax},\n {offsetX: offsetXmin, offsetY: offsetYhalf}\n ];\n\n let points: Array = [];\n\n for (const {offsetX, offsetY} of offsetsArray) {\n points.push(new Point(\n basePoint.x + vecEast.x * offsetX + vecSouth.x * offsetY,\n basePoint.y + vecEast.y * offsetX + vecSouth.y * offsetY\n ));\n }\n\n // Is any point of the collision shape visible on the globe (on beyond horizon)?\n let anyPointVisible = false;\n\n if (pitchWithMap) {\n const projected = points.map(p => this.projectAndGetPerspectiveRatio(posMatrix, p.x, p.y, unwrappedTileID, getElevation));\n\n // Is at least one of the projected points NOT behind the horizon?\n anyPointVisible = projected.some(p => !p.isOccluded);\n\n points = projected.map(p => p.point);\n } else {\n // Labels that are not pitchWithMap cannot ever hide behind the horizon.\n anyPointVisible = true;\n }\n\n return {\n box: getAABB(points),\n allPointsOccluded: !anyPointVisible\n };\n }\n}\n","import {EXTENT} from '../data/extent';\n\nimport type {OverscaledTileID} from './tile_id';\n\n/**\n * Converts a pixel value at a the given zoom level to tile units.\n *\n * The shaders mostly calculate everything in tile units so style\n * properties need to be converted from pixels to tile units using this.\n *\n * For example, a translation by 30 pixels at zoom 6.5 will be a\n * translation by pixelsToTileUnits(30, 6.5) tile units.\n *\n * @returns value in tile units\n */\nexport function pixelsToTileUnits(\n tile: {\n tileID: OverscaledTileID;\n tileSize: number;\n },\n pixelValue: number,\n z: number\n): number {\n return pixelValue * (EXTENT / (tile.tileSize * Math.pow(2, z - tile.tileID.overscaledZ)));\n}\n","import {CollisionIndex, viewportPadding} from './collision_index';\nimport type {FeatureKey, PlacedBox, PlacedCircles} from './collision_index';\nimport {EXTENT} from '../data/extent';\nimport * as symbolSize from './symbol_size';\nimport * as projection from './projection';\nimport {getAnchorJustification} from './symbol_layout';\nimport {getAnchorAlignment, WritingMode} from './shaping';\nimport {mat4} from 'gl-matrix';\nimport {pixelsToTileUnits} from '../source/pixels_to_tile_units';\nimport Point from '@mapbox/point-geometry';\nimport type {Transform} from '../geo/transform';\nimport type {StyleLayer} from '../style/style_layer';\nimport {PossiblyEvaluated} from '../style/properties';\nimport type {SymbolLayoutProps, SymbolLayoutPropsPossiblyEvaluated} from '../style/style_layer/symbol_style_layer_properties.g';\nimport {getOverlapMode, OverlapMode} from '../style/style_layer/overlap_mode';\n\nimport type {Tile} from '../source/tile';\nimport {SymbolBucket, CollisionArrays, SingleCollisionBox} from '../data/bucket/symbol_bucket';\n\nimport type {CollisionBoxArray, CollisionVertexArray, SymbolInstance, TextAnchorOffset} from '../data/array_types.g';\nimport type {FeatureIndex} from '../data/feature_index';\nimport type {OverscaledTileID, UnwrappedTileID} from '../source/tile_id';\nimport {Terrain} from '../render/terrain';\nimport {warnOnce} from '../util/util';\nimport {TextAnchor, TextAnchorEnum} from '../style/style_layer/variable_text_anchor';\nimport {Projection} from '../geo/projection/projection';\n\nclass OpacityState {\n opacity: number;\n placed: boolean;\n constructor(prevState: OpacityState, increment: number, placed: boolean, skipFade?: boolean | null) {\n if (prevState) {\n this.opacity = Math.max(0, Math.min(1, prevState.opacity + (prevState.placed ? increment : -increment)));\n } else {\n this.opacity = (skipFade && placed) ? 1 : 0;\n }\n this.placed = placed;\n }\n isHidden() {\n return this.opacity === 0 && !this.placed;\n }\n}\n\nclass JointOpacityState {\n text: OpacityState;\n icon: OpacityState;\n constructor(prevState: JointOpacityState, increment: number, placedText: boolean, placedIcon: boolean, skipFade?: boolean | null) {\n this.text = new OpacityState(prevState ? prevState.text : null, increment, placedText, skipFade);\n this.icon = new OpacityState(prevState ? prevState.icon : null, increment, placedIcon, skipFade);\n }\n isHidden() {\n return this.text.isHidden() && this.icon.isHidden();\n }\n}\n\nclass JointPlacement {\n text: boolean;\n icon: boolean;\n // skipFade = outside viewport, but within CollisionIndex::viewportPadding px of the edge\n // Because these symbols aren't onscreen yet, we can skip the \"fade in\" animation,\n // and if a subsequent viewport change brings them into view, they'll be fully\n // visible right away.\n skipFade: boolean;\n constructor(text: boolean, icon: boolean, skipFade: boolean) {\n this.text = text;\n this.icon = icon;\n this.skipFade = skipFade;\n }\n}\n\nclass CollisionCircleArray {\n // Stores collision circles and placement matrices of a bucket for debug rendering.\n invProjMatrix: mat4;\n viewportMatrix: mat4;\n circles: Array;\n\n constructor() {\n this.invProjMatrix = mat4.create();\n this.viewportMatrix = mat4.create();\n this.circles = [];\n }\n}\n\nexport class RetainedQueryData {\n bucketInstanceId: number;\n featureIndex: FeatureIndex;\n sourceLayerIndex: number;\n bucketIndex: number;\n tileID: OverscaledTileID;\n featureSortOrder: Array;\n constructor(bucketInstanceId: number,\n featureIndex: FeatureIndex,\n sourceLayerIndex: number,\n bucketIndex: number,\n tileID: OverscaledTileID) {\n this.bucketInstanceId = bucketInstanceId;\n this.featureIndex = featureIndex;\n this.sourceLayerIndex = sourceLayerIndex;\n this.bucketIndex = bucketIndex;\n this.tileID = tileID;\n }\n}\n\ntype CollisionGroup = {\n ID: number;\n predicate?: (key: FeatureKey) => boolean;\n};\n\nclass CollisionGroups {\n collisionGroups: {[groupName: string]: CollisionGroup};\n maxGroupID: number;\n crossSourceCollisions: boolean;\n\n constructor(crossSourceCollisions: boolean) {\n this.crossSourceCollisions = crossSourceCollisions;\n this.maxGroupID = 0;\n this.collisionGroups = {};\n }\n\n get(sourceID: string) {\n // The predicate/groupID mechanism allows for arbitrary grouping,\n // but the current interface defines one source == one group when\n // crossSourceCollisions == true.\n if (!this.crossSourceCollisions) {\n if (!this.collisionGroups[sourceID]) {\n const nextGroupID = ++this.maxGroupID;\n this.collisionGroups[sourceID] = {\n ID: nextGroupID,\n predicate: (key) => {\n return key.collisionGroupID === nextGroupID;\n }\n };\n }\n return this.collisionGroups[sourceID];\n } else {\n return {ID: 0, predicate: null};\n }\n }\n}\n\nfunction calculateVariableLayoutShift(\n anchor: TextAnchor,\n width: number,\n height: number,\n textOffset: [number, number],\n textBoxScale: number\n): Point {\n const {horizontalAlign, verticalAlign} = getAnchorAlignment(anchor);\n const shiftX = -(horizontalAlign - 0.5) * width;\n const shiftY = -(verticalAlign - 0.5) * height;\n return new Point(\n shiftX + textOffset[0] * textBoxScale,\n shiftY + textOffset[1] * textBoxScale\n );\n}\n\nexport type VariableOffset = {\n textOffset: [number, number];\n width: number;\n height: number;\n anchor: TextAnchor;\n textBoxScale: number;\n prevAnchor?: TextAnchor;\n};\n\ntype TileLayerParameters = {\n bucket: SymbolBucket;\n layout: PossiblyEvaluated;\n translationText: [number, number];\n translationIcon: [number, number];\n unwrappedTileID: UnwrappedTileID;\n posMatrix: mat4;\n textLabelPlaneMatrix: mat4;\n labelToScreenMatrix: mat4;\n scale: number;\n textPixelRatio: number;\n holdingForFade: boolean;\n collisionBoxArray: CollisionBoxArray;\n partiallyEvaluatedTextSize: {\n uSize: number;\n uSizeT: number;\n };\n collisionGroup: CollisionGroup;\n};\n\nexport type BucketPart = {\n sortKey?: number | void;\n symbolInstanceStart: number;\n symbolInstanceEnd: number;\n parameters: TileLayerParameters;\n};\n\nexport type CrossTileID = string | number;\n\nexport class Placement {\n transform: Transform;\n terrain: Terrain;\n collisionIndex: CollisionIndex;\n placements: {\n [_ in CrossTileID]: JointPlacement;\n };\n opacities: {\n [_ in CrossTileID]: JointOpacityState;\n };\n variableOffsets: {\n [_ in CrossTileID]: VariableOffset;\n };\n placedOrientations: {\n [_ in CrossTileID]: number;\n };\n commitTime: number;\n prevZoomAdjustment: number;\n lastPlacementChangeTime: number;\n stale: boolean;\n fadeDuration: number;\n retainedQueryData: {\n [_: number]: RetainedQueryData;\n };\n collisionGroups: CollisionGroups;\n prevPlacement: Placement;\n zoomAtLastRecencyCheck: number;\n collisionCircleArrays: {\n [k in any]: CollisionCircleArray;\n };\n collisionBoxArrays: Map>;\n\n constructor(transform: Transform, projection: Projection, terrain: Terrain, fadeDuration: number, crossSourceCollisions: boolean, prevPlacement?: Placement) {\n this.transform = transform.clone();\n this.terrain = terrain;\n this.collisionIndex = new CollisionIndex(this.transform, projection);\n this.placements = {};\n this.opacities = {};\n this.variableOffsets = {};\n this.stale = false;\n this.commitTime = 0;\n this.fadeDuration = fadeDuration;\n this.retainedQueryData = {};\n this.collisionGroups = new CollisionGroups(crossSourceCollisions);\n this.collisionCircleArrays = {};\n this.collisionBoxArrays = new Map>();\n\n this.prevPlacement = prevPlacement;\n if (prevPlacement) {\n prevPlacement.prevPlacement = undefined; // Only hold on to one placement back\n }\n\n this.placedOrientations = {};\n }\n\n private _getTerrainElevationFunc(tileID: OverscaledTileID) {\n const terrain = this.terrain;\n return terrain ? (x: number, y: number) => terrain.getElevation(tileID, x, y) : null;\n }\n\n getBucketParts(results: Array, styleLayer: StyleLayer, tile: Tile, sortAcrossTiles: boolean) {\n const symbolBucket = (tile.getBucket(styleLayer) as SymbolBucket);\n const bucketFeatureIndex = tile.latestFeatureIndex;\n if (!symbolBucket || !bucketFeatureIndex || styleLayer.id !== symbolBucket.layerIds[0])\n return;\n\n const collisionBoxArray = tile.collisionBoxArray;\n\n const layout = symbolBucket.layers[0].layout;\n const paint = symbolBucket.layers[0].paint;\n\n const scale = Math.pow(2, this.transform.zoom - tile.tileID.overscaledZ);\n const textPixelRatio = tile.tileSize / EXTENT;\n\n const unwrappedTileID = tile.tileID.toUnwrapped();\n\n const posMatrix = this.transform.calculatePosMatrix(unwrappedTileID);\n\n const pitchWithMap = layout.get('text-pitch-alignment') === 'map';\n const rotateWithMap = layout.get('text-rotation-alignment') === 'map';\n const pixelsToTiles = pixelsToTileUnits(tile, 1, this.transform.zoom);\n\n const translationText = this.collisionIndex.mapProjection.translatePosition(\n this.transform,\n tile,\n paint.get('text-translate'),\n paint.get('text-translate-anchor'),);\n\n const translationIcon = this.collisionIndex.mapProjection.translatePosition(\n this.transform,\n tile,\n paint.get('icon-translate'),\n paint.get('icon-translate-anchor'),);\n\n const textLabelPlaneMatrix = projection.getLabelPlaneMatrix(posMatrix,\n pitchWithMap,\n rotateWithMap,\n this.transform,\n pixelsToTiles);\n\n let labelToScreenMatrix = null;\n\n if (pitchWithMap) {\n const glMatrix = projection.getGlCoordMatrix(\n posMatrix,\n pitchWithMap,\n rotateWithMap,\n this.transform,\n pixelsToTiles);\n\n labelToScreenMatrix = mat4.multiply([] as any, this.transform.labelPlaneMatrix, glMatrix);\n }\n\n // As long as this placement lives, we have to hold onto this bucket's\n // matching FeatureIndex/data for querying purposes\n this.retainedQueryData[symbolBucket.bucketInstanceId] = new RetainedQueryData(\n symbolBucket.bucketInstanceId,\n bucketFeatureIndex,\n symbolBucket.sourceLayerIndex,\n symbolBucket.index,\n tile.tileID\n );\n\n const parameters: TileLayerParameters = {\n bucket: symbolBucket,\n layout,\n translationText,\n translationIcon,\n posMatrix,\n unwrappedTileID,\n textLabelPlaneMatrix,\n labelToScreenMatrix,\n scale,\n textPixelRatio,\n holdingForFade: tile.holdingForFade(),\n collisionBoxArray,\n partiallyEvaluatedTextSize: symbolSize.evaluateSizeForZoom(symbolBucket.textSizeData, this.transform.zoom),\n collisionGroup: this.collisionGroups.get(symbolBucket.sourceID)\n };\n\n if (sortAcrossTiles) {\n for (const range of symbolBucket.sortKeyRanges) {\n const {sortKey, symbolInstanceStart, symbolInstanceEnd} = range;\n results.push({sortKey, symbolInstanceStart, symbolInstanceEnd, parameters});\n }\n } else {\n results.push({\n symbolInstanceStart: 0,\n symbolInstanceEnd: symbolBucket.symbolInstances.length,\n parameters\n });\n }\n }\n\n attemptAnchorPlacement(\n textAnchorOffset: TextAnchorOffset,\n textBox: SingleCollisionBox,\n width: number,\n height: number,\n textBoxScale: number,\n rotateWithMap: boolean,\n pitchWithMap: boolean,\n textPixelRatio: number,\n posMatrix: mat4,\n unwrappedTileID,\n collisionGroup: CollisionGroup,\n textOverlapMode: OverlapMode,\n symbolInstance: SymbolInstance,\n bucket: SymbolBucket,\n orientation: number,\n translationText: [number, number],\n translationIcon: [number, number],\n iconBox?: SingleCollisionBox | null,\n getElevation?: (x: number, y: number) => number\n ): {\n shift: Point;\n placedGlyphBoxes: PlacedBox;\n } {\n\n const anchor = TextAnchorEnum[textAnchorOffset.textAnchor] as TextAnchor;\n const textOffset = [textAnchorOffset.textOffset0, textAnchorOffset.textOffset1] as [number, number];\n const shift = calculateVariableLayoutShift(anchor, width, height, textOffset, textBoxScale);\n\n const placedGlyphBoxes = this.collisionIndex.placeCollisionBox(\n textBox,\n textOverlapMode,\n textPixelRatio,\n posMatrix,\n unwrappedTileID,\n pitchWithMap,\n rotateWithMap,\n translationText,\n collisionGroup.predicate,\n getElevation,\n shift\n );\n\n if (iconBox) {\n const placedIconBoxes = this.collisionIndex.placeCollisionBox(\n iconBox,\n textOverlapMode,\n textPixelRatio,\n posMatrix,\n unwrappedTileID,\n pitchWithMap,\n rotateWithMap,\n translationIcon,\n collisionGroup.predicate,\n getElevation,\n shift\n );\n if (!placedIconBoxes.placeable) return;\n }\n\n if (placedGlyphBoxes.placeable) {\n let prevAnchor;\n // If this label was placed in the previous placement, record the anchor position\n // to allow us to animate the transition\n if (this.prevPlacement &&\n this.prevPlacement.variableOffsets[symbolInstance.crossTileID] &&\n this.prevPlacement.placements[symbolInstance.crossTileID] &&\n this.prevPlacement.placements[symbolInstance.crossTileID].text) {\n prevAnchor = this.prevPlacement.variableOffsets[symbolInstance.crossTileID].anchor;\n }\n if (symbolInstance.crossTileID === 0) throw new Error('symbolInstance.crossTileID can\\'t be 0');\n this.variableOffsets[symbolInstance.crossTileID] = {\n textOffset,\n width,\n height,\n anchor,\n textBoxScale,\n prevAnchor\n };\n this.markUsedJustification(bucket, anchor, symbolInstance, orientation);\n\n if (bucket.allowVerticalPlacement) {\n this.markUsedOrientation(bucket, orientation, symbolInstance);\n this.placedOrientations[symbolInstance.crossTileID] = orientation;\n }\n\n return {shift, placedGlyphBoxes};\n }\n }\n\n placeLayerBucketPart(bucketPart: BucketPart, seenCrossTileIDs: {\n [k in string | number]: boolean;\n }, showCollisionBoxes: boolean) {\n\n const {\n bucket,\n layout,\n translationText,\n translationIcon,\n posMatrix,\n unwrappedTileID,\n textLabelPlaneMatrix,\n labelToScreenMatrix,\n textPixelRatio,\n holdingForFade,\n collisionBoxArray,\n partiallyEvaluatedTextSize,\n collisionGroup\n } = bucketPart.parameters;\n\n const textOptional = layout.get('text-optional');\n const iconOptional = layout.get('icon-optional');\n const textOverlapMode = getOverlapMode(layout, 'text-overlap', 'text-allow-overlap');\n const textAlwaysOverlap = textOverlapMode === 'always';\n const iconOverlapMode = getOverlapMode(layout, 'icon-overlap', 'icon-allow-overlap');\n const iconAlwaysOverlap = iconOverlapMode === 'always';\n const rotateWithMap = layout.get('text-rotation-alignment') === 'map';\n const pitchWithMap = layout.get('text-pitch-alignment') === 'map';\n const hasIconTextFit = layout.get('icon-text-fit') !== 'none';\n const zOrderByViewportY = layout.get('symbol-z-order') === 'viewport-y';\n\n // This logic is similar to the \"defaultOpacityState\" logic below in updateBucketOpacities\n // If we know a symbol is always supposed to show, force it to be marked visible even if\n // it wasn't placed into the collision index (because some or all of it was outside the range\n // of the collision grid).\n // There is a subtle edge case here we're accepting:\n // Symbol A has text-allow-overlap: true, icon-allow-overlap: true, icon-optional: false\n // A's icon is outside the grid, so doesn't get placed\n // A's text would be inside grid, but doesn't get placed because of icon-optional: false\n // We still show A because of the allow-overlap settings.\n // Symbol B has allow-overlap: false, and gets placed where A's text would be\n // On panning in, there is a short period when Symbol B and Symbol A will overlap\n // This is the reverse of our normal policy of \"fade in on pan\", but should look like any other\n // collision and hopefully not be too noticeable.\n // See https://github.com/mapbox/mapbox-gl-js/issues/7172\n const alwaysShowText = textAlwaysOverlap && (iconAlwaysOverlap || !bucket.hasIconData() || iconOptional);\n const alwaysShowIcon = iconAlwaysOverlap && (textAlwaysOverlap || !bucket.hasTextData() || textOptional);\n\n if (!bucket.collisionArrays && collisionBoxArray) {\n bucket.deserializeCollisionBoxes(collisionBoxArray);\n }\n\n const tileID = this.retainedQueryData[bucket.bucketInstanceId].tileID;\n const getElevation = this._getTerrainElevationFunc(tileID);\n\n const placeSymbol = (symbolInstance: SymbolInstance, collisionArrays: CollisionArrays, symbolIndex: number) => {\n if (seenCrossTileIDs[symbolInstance.crossTileID]) return;\n if (holdingForFade) {\n // Mark all symbols from this tile as \"not placed\", but don't add to seenCrossTileIDs, because we don't\n // know yet if we have a duplicate in a parent tile that _should_ be placed.\n this.placements[symbolInstance.crossTileID] = new JointPlacement(false, false, false);\n return;\n }\n\n let placeText = false;\n let placeIcon = false;\n let offscreen = true;\n let shift = null;\n\n let placed: PlacedBox = {box: null, placeable: false, offscreen: null};\n let placedVerticalText = {box: null, placeable: false, offscreen: null};\n\n let placedGlyphBoxes: PlacedBox = null;\n let placedGlyphCircles: PlacedCircles = null;\n let placedIconBoxes: PlacedBox = null;\n let textFeatureIndex = 0;\n let verticalTextFeatureIndex = 0;\n let iconFeatureIndex = 0;\n\n if (collisionArrays.textFeatureIndex) {\n textFeatureIndex = collisionArrays.textFeatureIndex;\n } else if (symbolInstance.useRuntimeCollisionCircles) {\n textFeatureIndex = symbolInstance.featureIndex;\n }\n if (collisionArrays.verticalTextFeatureIndex) {\n verticalTextFeatureIndex = collisionArrays.verticalTextFeatureIndex;\n }\n\n const textBox = collisionArrays.textBox;\n if (textBox) {\n\n const updatePreviousOrientationIfNotPlaced = (isPlaced) => {\n let previousOrientation = WritingMode.horizontal;\n if (bucket.allowVerticalPlacement && !isPlaced && this.prevPlacement) {\n const prevPlacedOrientation = this.prevPlacement.placedOrientations[symbolInstance.crossTileID];\n if (prevPlacedOrientation) {\n this.placedOrientations[symbolInstance.crossTileID] = prevPlacedOrientation;\n previousOrientation = prevPlacedOrientation;\n this.markUsedOrientation(bucket, previousOrientation, symbolInstance);\n }\n }\n return previousOrientation;\n };\n\n const placeTextForPlacementModes = (placeHorizontalFn, placeVerticalFn) => {\n if (bucket.allowVerticalPlacement && symbolInstance.numVerticalGlyphVertices > 0 && collisionArrays.verticalTextBox) {\n for (const placementMode of bucket.writingModes) {\n if (placementMode === WritingMode.vertical) {\n placed = placeVerticalFn();\n placedVerticalText = placed;\n } else {\n placed = placeHorizontalFn();\n }\n if (placed && placed.placeable) break;\n }\n } else {\n placed = placeHorizontalFn();\n }\n };\n\n const textAnchorOffsetStart = symbolInstance.textAnchorOffsetStartIndex;\n const textAnchorOffsetEnd = symbolInstance.textAnchorOffsetEndIndex;\n\n // If start+end indices match, text-variable-anchor is not in play.\n if (textAnchorOffsetEnd === textAnchorOffsetStart) {\n const placeBox = (collisionTextBox, orientation) => {\n const placedFeature = this.collisionIndex.placeCollisionBox(\n collisionTextBox,\n textOverlapMode,\n textPixelRatio,\n posMatrix,\n unwrappedTileID,\n pitchWithMap,\n rotateWithMap,\n translationText,\n collisionGroup.predicate,\n getElevation\n );\n if (placedFeature && placedFeature.placeable) {\n this.markUsedOrientation(bucket, orientation, symbolInstance);\n this.placedOrientations[symbolInstance.crossTileID] = orientation;\n }\n return placedFeature;\n };\n\n const placeHorizontal = () => {\n return placeBox(textBox, WritingMode.horizontal);\n };\n\n const placeVertical = () => {\n const verticalTextBox = collisionArrays.verticalTextBox;\n if (bucket.allowVerticalPlacement && symbolInstance.numVerticalGlyphVertices > 0 && verticalTextBox) {\n return placeBox(verticalTextBox, WritingMode.vertical);\n }\n return {box: null, offscreen: null};\n };\n\n placeTextForPlacementModes(placeHorizontal, placeVertical);\n updatePreviousOrientationIfNotPlaced(placed && placed.placeable);\n\n } else {\n // If this symbol was in the last placement, prefer placement using same anchor, if it's still available\n let prevAnchor = TextAnchorEnum[this.prevPlacement?.variableOffsets[symbolInstance.crossTileID]?.anchor];\n\n const placeBoxForVariableAnchors = (collisionTextBox, collisionIconBox, orientation) => {\n const width = collisionTextBox.x2 - collisionTextBox.x1;\n const height = collisionTextBox.y2 - collisionTextBox.y1;\n const textBoxScale = symbolInstance.textBoxScale;\n const variableIconBox = hasIconTextFit && (iconOverlapMode === 'never') ? collisionIconBox : null;\n\n let placedBox: PlacedBox = null;\n let placementPasses = (textOverlapMode === 'never') ? 1 : 2;\n let overlapMode: OverlapMode = 'never';\n\n if (prevAnchor) {\n placementPasses++;\n }\n\n for (let pass = 0; pass < placementPasses; pass++) {\n for (let i = textAnchorOffsetStart; i < textAnchorOffsetEnd; i++) {\n const textAnchorOffset = bucket.textAnchorOffsets.get(i);\n\n if (prevAnchor && textAnchorOffset.textAnchor !== prevAnchor) {\n continue;\n }\n\n const result = this.attemptAnchorPlacement(\n textAnchorOffset, collisionTextBox, width, height,\n textBoxScale, rotateWithMap, pitchWithMap, textPixelRatio, posMatrix, unwrappedTileID,\n collisionGroup, overlapMode, symbolInstance, bucket, orientation, translationText, translationIcon, variableIconBox, getElevation);\n\n if (result) {\n placedBox = result.placedGlyphBoxes;\n if (placedBox && placedBox.placeable) {\n placeText = true;\n shift = result.shift;\n return placedBox;\n }\n }\n }\n\n if (prevAnchor) {\n prevAnchor = null;\n } else {\n overlapMode = textOverlapMode;\n }\n }\n\n if (showCollisionBoxes && !placedBox) {\n // No box was successfully placed\n // Generate bounds for a fake centered box, so that we can at least display something for collision debug.\n const placedFakeGlyphBox = this.collisionIndex.placeCollisionBox(\n textBox,\n 'always', // Skips expensive collision check with already placed boxes\n textPixelRatio,\n posMatrix,\n unwrappedTileID,\n pitchWithMap,\n rotateWithMap,\n translationText,\n collisionGroup.predicate,\n getElevation,\n new Point(0, 0)\n );\n placedBox = {\n box: placedFakeGlyphBox.box,\n offscreen: false,\n placeable: false\n };\n }\n\n return placedBox;\n };\n\n const placeHorizontal = () => {\n return placeBoxForVariableAnchors(textBox, collisionArrays.iconBox, WritingMode.horizontal);\n };\n\n const placeVertical = () => {\n const verticalTextBox = collisionArrays.verticalTextBox;\n const wasPlaced = placed && placed.placeable;\n if (bucket.allowVerticalPlacement && !wasPlaced && symbolInstance.numVerticalGlyphVertices > 0 && verticalTextBox) {\n return placeBoxForVariableAnchors(verticalTextBox, collisionArrays.verticalIconBox, WritingMode.vertical);\n }\n return {box: null, occluded: true, offscreen: null};\n };\n\n placeTextForPlacementModes(placeHorizontal, placeVertical);\n\n if (placed) {\n placeText = placed.placeable;\n offscreen = placed.offscreen;\n }\n\n const prevOrientation = updatePreviousOrientationIfNotPlaced(placed && placed.placeable);\n\n // If we didn't get placed, we still need to copy our position from the last placement for\n // fade animations\n if (!placeText && this.prevPlacement) {\n const prevOffset = this.prevPlacement.variableOffsets[symbolInstance.crossTileID];\n if (prevOffset) {\n this.variableOffsets[symbolInstance.crossTileID] = prevOffset;\n this.markUsedJustification(bucket, prevOffset.anchor, symbolInstance, prevOrientation);\n }\n }\n\n }\n }\n\n placedGlyphBoxes = placed;\n placeText = placedGlyphBoxes && placedGlyphBoxes.placeable;\n\n offscreen = placedGlyphBoxes && placedGlyphBoxes.offscreen;\n\n if (symbolInstance.useRuntimeCollisionCircles) {\n const placedSymbol = bucket.text.placedSymbolArray.get(symbolInstance.centerJustifiedTextSymbolIndex);\n const fontSize = symbolSize.evaluateSizeForFeature(bucket.textSizeData, partiallyEvaluatedTextSize, placedSymbol);\n\n const textPixelPadding = layout.get('text-padding');\n const circlePixelDiameter = symbolInstance.collisionCircleDiameter;\n\n placedGlyphCircles = this.collisionIndex.placeCollisionCircles(\n textOverlapMode,\n placedSymbol,\n bucket.lineVertexArray,\n bucket.glyphOffsetArray,\n fontSize,\n posMatrix,\n unwrappedTileID,\n textLabelPlaneMatrix,\n labelToScreenMatrix,\n showCollisionBoxes,\n pitchWithMap,\n collisionGroup.predicate,\n circlePixelDiameter,\n textPixelPadding,\n translationText,\n getElevation\n );\n\n if (placedGlyphCircles.circles.length && placedGlyphCircles.collisionDetected && !showCollisionBoxes) {\n warnOnce('Collisions detected, but collision boxes are not shown');\n }\n\n // If text-overlap is set to 'always', force \"placedCircles\" to true\n // In theory there should always be at least one circle placed\n // in this case, but for now quirks in text-anchor\n // and text-offset may prevent that from being true.\n placeText = textAlwaysOverlap || (placedGlyphCircles.circles.length > 0 && !placedGlyphCircles.collisionDetected);\n offscreen = offscreen && placedGlyphCircles.offscreen;\n }\n\n if (collisionArrays.iconFeatureIndex) {\n iconFeatureIndex = collisionArrays.iconFeatureIndex;\n }\n\n if (collisionArrays.iconBox) {\n const placeIconFeature = iconBox => {\n return this.collisionIndex.placeCollisionBox(\n iconBox,\n iconOverlapMode,\n textPixelRatio,\n posMatrix,\n unwrappedTileID,\n pitchWithMap,\n rotateWithMap,\n translationIcon,\n collisionGroup.predicate,\n getElevation,\n (hasIconTextFit && shift) ? shift : undefined,\n );\n };\n\n if (placedVerticalText && placedVerticalText.placeable && collisionArrays.verticalIconBox) {\n placedIconBoxes = placeIconFeature(collisionArrays.verticalIconBox);\n placeIcon = placedIconBoxes.placeable;\n } else {\n placedIconBoxes = placeIconFeature(collisionArrays.iconBox);\n placeIcon = placedIconBoxes.placeable;\n }\n offscreen = offscreen && placedIconBoxes.offscreen;\n }\n\n const iconWithoutText = textOptional ||\n (symbolInstance.numHorizontalGlyphVertices === 0 && symbolInstance.numVerticalGlyphVertices === 0);\n const textWithoutIcon = iconOptional || symbolInstance.numIconVertices === 0;\n\n // Combine the scales for icons and text.\n if (!iconWithoutText && !textWithoutIcon) {\n placeIcon = placeText = placeIcon && placeText;\n } else if (!textWithoutIcon) {\n placeText = placeIcon && placeText;\n } else if (!iconWithoutText) {\n placeIcon = placeIcon && placeText;\n }\n\n const hasTextBox = placeText && placedGlyphBoxes.placeable;\n const hasIconBox = placeIcon && placedIconBoxes.placeable;\n\n if (hasTextBox) {\n if (placedVerticalText && placedVerticalText.placeable && verticalTextFeatureIndex) {\n this.collisionIndex.insertCollisionBox(\n placedGlyphBoxes.box,\n textOverlapMode,\n layout.get('text-ignore-placement'),\n bucket.bucketInstanceId,\n verticalTextFeatureIndex,\n collisionGroup.ID);\n } else {\n this.collisionIndex.insertCollisionBox(\n placedGlyphBoxes.box,\n textOverlapMode,\n layout.get('text-ignore-placement'),\n bucket.bucketInstanceId,\n textFeatureIndex,\n collisionGroup.ID);\n }\n\n }\n if (hasIconBox) {\n this.collisionIndex.insertCollisionBox(\n placedIconBoxes.box,\n iconOverlapMode,\n layout.get('icon-ignore-placement'),\n bucket.bucketInstanceId,\n iconFeatureIndex,\n collisionGroup.ID);\n }\n if (placedGlyphCircles) {\n if (placeText) {\n this.collisionIndex.insertCollisionCircles(\n placedGlyphCircles.circles,\n textOverlapMode,\n layout.get('text-ignore-placement'),\n bucket.bucketInstanceId,\n textFeatureIndex,\n collisionGroup.ID);\n }\n }\n\n if (showCollisionBoxes) {\n this.storeCollisionData(bucket.bucketInstanceId, symbolIndex, collisionArrays, placedGlyphBoxes, placedIconBoxes, placedGlyphCircles);\n }\n\n if (symbolInstance.crossTileID === 0) throw new Error('symbolInstance.crossTileID can\\'t be 0');\n if (bucket.bucketInstanceId === 0) throw new Error('bucket.bucketInstanceId can\\'t be 0');\n\n this.placements[symbolInstance.crossTileID] = new JointPlacement(placeText || alwaysShowText, placeIcon || alwaysShowIcon, offscreen || bucket.justReloaded);\n seenCrossTileIDs[symbolInstance.crossTileID] = true;\n };\n\n if (zOrderByViewportY) {\n if (bucketPart.symbolInstanceStart !== 0) throw new Error('bucket.bucketInstanceId should be 0');\n const symbolIndexes = bucket.getSortedSymbolIndexes(this.transform.angle);\n for (let i = symbolIndexes.length - 1; i >= 0; --i) {\n const symbolIndex = symbolIndexes[i];\n placeSymbol(bucket.symbolInstances.get(symbolIndex), bucket.collisionArrays[symbolIndex], symbolIndex);\n }\n } else {\n for (let i = bucketPart.symbolInstanceStart; i < bucketPart.symbolInstanceEnd; i++) {\n placeSymbol(bucket.symbolInstances.get(i), bucket.collisionArrays[i], i);\n }\n }\n\n if (showCollisionBoxes && bucket.bucketInstanceId in this.collisionCircleArrays) {\n const circleArray = this.collisionCircleArrays[bucket.bucketInstanceId];\n\n // Store viewport and inverse projection matrices per bucket\n mat4.invert(circleArray.invProjMatrix, posMatrix);\n circleArray.viewportMatrix = this.collisionIndex.getViewportMatrix();\n }\n\n bucket.justReloaded = false;\n }\n\n storeCollisionData(bucketInstanceId: number, symbolIndex: number, collisionArrays: CollisionArrays, placedGlyphBoxes: PlacedBox, placedIconBoxes: PlacedBox, placedGlyphCircles: PlacedCircles): void {\n if (collisionArrays.textBox || collisionArrays.iconBox) {\n // Store the actually used collision box for debug draw\n let boxArray: Map;\n\n if (this.collisionBoxArrays.has(bucketInstanceId)) {\n boxArray = this.collisionBoxArrays.get(bucketInstanceId);\n } else {\n boxArray = new Map();\n this.collisionBoxArrays.set(bucketInstanceId, boxArray);\n }\n let realCollisionBox: {\n text: number[];\n icon: number[];\n };\n\n if (boxArray.has(symbolIndex)) {\n realCollisionBox = boxArray.get(symbolIndex);\n } else {\n realCollisionBox = {\n text: null,\n icon: null\n };\n boxArray.set(symbolIndex, realCollisionBox);\n }\n\n if (collisionArrays.textBox) {\n realCollisionBox.text = placedGlyphBoxes.box;\n }\n if (collisionArrays.iconBox) {\n realCollisionBox.icon = placedIconBoxes.box;\n }\n }\n\n if (placedGlyphCircles) {\n let circleArray = this.collisionCircleArrays[bucketInstanceId];\n\n // Group collision circles together by bucket. Circles can't be pushed forward for rendering yet as the symbol placement\n // for a bucket is not guaranteed to be complete before the commit-function has been called\n if (circleArray === undefined)\n circleArray = this.collisionCircleArrays[bucketInstanceId] = new CollisionCircleArray();\n\n for (let i = 0; i < placedGlyphCircles.circles.length; i += 4) {\n circleArray.circles.push(placedGlyphCircles.circles[i + 0]); // x\n circleArray.circles.push(placedGlyphCircles.circles[i + 1]); // y\n circleArray.circles.push(placedGlyphCircles.circles[i + 2]); // radius\n circleArray.circles.push(placedGlyphCircles.collisionDetected ? 1 : 0); // collisionDetected-flag\n }\n }\n }\n\n markUsedJustification(bucket: SymbolBucket, placedAnchor: TextAnchor, symbolInstance: SymbolInstance, orientation: number) {\n const justifications = {\n 'left': symbolInstance.leftJustifiedTextSymbolIndex,\n 'center': symbolInstance.centerJustifiedTextSymbolIndex,\n 'right': symbolInstance.rightJustifiedTextSymbolIndex\n };\n\n let autoIndex;\n if (orientation === WritingMode.vertical) {\n autoIndex = symbolInstance.verticalPlacedTextSymbolIndex;\n } else {\n autoIndex = justifications[getAnchorJustification(placedAnchor)];\n }\n\n const indexes = [\n symbolInstance.leftJustifiedTextSymbolIndex,\n symbolInstance.centerJustifiedTextSymbolIndex,\n symbolInstance.rightJustifiedTextSymbolIndex,\n symbolInstance.verticalPlacedTextSymbolIndex\n ];\n\n for (const index of indexes) {\n if (index >= 0) {\n if (autoIndex >= 0 && index !== autoIndex) {\n // There are multiple justifications and this one isn't it: shift offscreen\n bucket.text.placedSymbolArray.get(index).crossTileID = 0;\n } else {\n // Either this is the chosen justification or the justification is hardwired: use this one\n bucket.text.placedSymbolArray.get(index).crossTileID = symbolInstance.crossTileID;\n }\n }\n }\n }\n\n markUsedOrientation(bucket: SymbolBucket, orientation: number, symbolInstance: SymbolInstance) {\n const horizontal = (orientation === WritingMode.horizontal || orientation === WritingMode.horizontalOnly) ? orientation : 0;\n const vertical = orientation === WritingMode.vertical ? orientation : 0;\n\n const horizontalIndexes = [\n symbolInstance.leftJustifiedTextSymbolIndex,\n symbolInstance.centerJustifiedTextSymbolIndex,\n symbolInstance.rightJustifiedTextSymbolIndex\n ];\n\n for (const index of horizontalIndexes) {\n bucket.text.placedSymbolArray.get(index).placedOrientation = horizontal;\n }\n\n if (symbolInstance.verticalPlacedTextSymbolIndex) {\n bucket.text.placedSymbolArray.get(symbolInstance.verticalPlacedTextSymbolIndex).placedOrientation = vertical;\n }\n }\n\n commit(now: number): void {\n this.commitTime = now;\n this.zoomAtLastRecencyCheck = this.transform.zoom;\n\n const prevPlacement = this.prevPlacement;\n let placementChanged = false;\n\n this.prevZoomAdjustment = prevPlacement ? prevPlacement.zoomAdjustment(this.transform.zoom) : 0;\n const increment = prevPlacement ? prevPlacement.symbolFadeChange(now) : 1;\n\n const prevOpacities = prevPlacement ? prevPlacement.opacities : {};\n const prevOffsets = prevPlacement ? prevPlacement.variableOffsets : {};\n const prevOrientations = prevPlacement ? prevPlacement.placedOrientations : {};\n\n // add the opacities from the current placement, and copy their current values from the previous placement\n for (const crossTileID in this.placements) {\n const jointPlacement = this.placements[crossTileID];\n const prevOpacity = prevOpacities[crossTileID];\n if (prevOpacity) {\n this.opacities[crossTileID] = new JointOpacityState(prevOpacity, increment, jointPlacement.text, jointPlacement.icon);\n placementChanged = placementChanged ||\n jointPlacement.text !== prevOpacity.text.placed ||\n jointPlacement.icon !== prevOpacity.icon.placed;\n } else {\n this.opacities[crossTileID] = new JointOpacityState(null, increment, jointPlacement.text, jointPlacement.icon, jointPlacement.skipFade);\n placementChanged = placementChanged || jointPlacement.text || jointPlacement.icon;\n }\n }\n\n // copy and update values from the previous placement that aren't in the current placement but haven't finished fading\n for (const crossTileID in prevOpacities) {\n const prevOpacity = prevOpacities[crossTileID];\n if (!this.opacities[crossTileID]) {\n const jointOpacity = new JointOpacityState(prevOpacity, increment, false, false);\n if (!jointOpacity.isHidden()) {\n this.opacities[crossTileID] = jointOpacity;\n placementChanged = placementChanged || prevOpacity.text.placed || prevOpacity.icon.placed;\n }\n }\n }\n for (const crossTileID in prevOffsets) {\n if (!this.variableOffsets[crossTileID] && this.opacities[crossTileID] && !this.opacities[crossTileID].isHidden()) {\n this.variableOffsets[crossTileID] = prevOffsets[crossTileID];\n }\n }\n\n for (const crossTileID in prevOrientations) {\n if (!this.placedOrientations[crossTileID] && this.opacities[crossTileID] && !this.opacities[crossTileID].isHidden()) {\n this.placedOrientations[crossTileID] = prevOrientations[crossTileID];\n }\n }\n\n // this.lastPlacementChangeTime is the time of the last commit() that\n // resulted in a placement change -- in other words, the start time of\n // the last symbol fade animation\n if (prevPlacement && prevPlacement.lastPlacementChangeTime === undefined) {\n throw new Error('Last placement time for previous placement is not defined');\n }\n if (placementChanged) {\n this.lastPlacementChangeTime = now;\n } else if (typeof this.lastPlacementChangeTime !== 'number') {\n this.lastPlacementChangeTime = prevPlacement ? prevPlacement.lastPlacementChangeTime : now;\n }\n }\n\n updateLayerOpacities(styleLayer: StyleLayer, tiles: Array) {\n const seenCrossTileIDs = {};\n for (const tile of tiles) {\n const symbolBucket = tile.getBucket(styleLayer) as SymbolBucket;\n if (symbolBucket && tile.latestFeatureIndex && styleLayer.id === symbolBucket.layerIds[0]) {\n this.updateBucketOpacities(symbolBucket, tile.tileID, seenCrossTileIDs, tile.collisionBoxArray);\n }\n }\n }\n\n updateBucketOpacities(bucket: SymbolBucket, tileID: OverscaledTileID, seenCrossTileIDs: {\n [k in string | number]: boolean;\n }, collisionBoxArray?: CollisionBoxArray | null) {\n if (bucket.hasTextData()) {\n bucket.text.opacityVertexArray.clear();\n bucket.text.hasVisibleVertices = false;\n }\n if (bucket.hasIconData()) {\n bucket.icon.opacityVertexArray.clear();\n bucket.icon.hasVisibleVertices = false;\n }\n if (bucket.hasIconCollisionBoxData()) bucket.iconCollisionBox.collisionVertexArray.clear();\n if (bucket.hasTextCollisionBoxData()) bucket.textCollisionBox.collisionVertexArray.clear();\n\n const layer = bucket.layers[0];\n const layout = layer.layout;\n const duplicateOpacityState = new JointOpacityState(null, 0, false, false, true);\n const textAllowOverlap = layout.get('text-allow-overlap');\n const iconAllowOverlap = layout.get('icon-allow-overlap');\n const hasVariablePlacement = layer._unevaluatedLayout.hasValue('text-variable-anchor') || layer._unevaluatedLayout.hasValue('text-variable-anchor-offset');\n const rotateWithMap = layout.get('text-rotation-alignment') === 'map';\n const pitchWithMap = layout.get('text-pitch-alignment') === 'map';\n const hasIconTextFit = layout.get('icon-text-fit') !== 'none';\n // If allow-overlap is true, we can show symbols before placement runs on them\n // But we have to wait for placement if we potentially depend on a paired icon/text\n // with allow-overlap: false.\n // See https://github.com/mapbox/mapbox-gl-js/issues/7032\n const defaultOpacityState = new JointOpacityState(null, 0,\n textAllowOverlap && (iconAllowOverlap || !bucket.hasIconData() || layout.get('icon-optional')),\n iconAllowOverlap && (textAllowOverlap || !bucket.hasTextData() || layout.get('text-optional')),\n true);\n\n if (!bucket.collisionArrays && collisionBoxArray && ((bucket.hasIconCollisionBoxData() || bucket.hasTextCollisionBoxData()))) {\n bucket.deserializeCollisionBoxes(collisionBoxArray);\n }\n\n const addOpacities = (iconOrText, numVertices: number, opacity: number) => {\n for (let i = 0; i < numVertices / 4; i++) {\n iconOrText.opacityVertexArray.emplaceBack(opacity);\n }\n iconOrText.hasVisibleVertices = iconOrText.hasVisibleVertices || (opacity !== PACKED_HIDDEN_OPACITY);\n };\n\n const boxArrays = this.collisionBoxArrays.get(bucket.bucketInstanceId);\n\n for (let s = 0; s < bucket.symbolInstances.length; s++) {\n const symbolInstance = bucket.symbolInstances.get(s);\n const {\n numHorizontalGlyphVertices,\n numVerticalGlyphVertices,\n crossTileID\n } = symbolInstance;\n\n const isDuplicate = seenCrossTileIDs[crossTileID];\n\n let opacityState = this.opacities[crossTileID];\n if (isDuplicate) {\n opacityState = duplicateOpacityState;\n } else if (!opacityState) {\n opacityState = defaultOpacityState;\n // store the state so that future placements use it as a starting point\n this.opacities[crossTileID] = opacityState;\n }\n\n seenCrossTileIDs[crossTileID] = true;\n\n const hasText = numHorizontalGlyphVertices > 0 || numVerticalGlyphVertices > 0;\n const hasIcon = symbolInstance.numIconVertices > 0;\n\n const placedOrientation = this.placedOrientations[symbolInstance.crossTileID];\n const horizontalHidden = placedOrientation === WritingMode.vertical;\n const verticalHidden = placedOrientation === WritingMode.horizontal || placedOrientation === WritingMode.horizontalOnly;\n\n if (hasText) {\n const packedOpacity = packOpacity(opacityState.text);\n // Vertical text fades in/out on collision the same way as corresponding\n // horizontal text. Switch between vertical/horizontal should be instantaneous\n const horizontalOpacity = horizontalHidden ? PACKED_HIDDEN_OPACITY : packedOpacity;\n addOpacities(bucket.text, numHorizontalGlyphVertices, horizontalOpacity);\n const verticalOpacity = verticalHidden ? PACKED_HIDDEN_OPACITY : packedOpacity;\n addOpacities(bucket.text, numVerticalGlyphVertices, verticalOpacity);\n\n // If this label is completely faded, mark it so that we don't have to calculate\n // its position at render time. If this layer has variable placement, shift the various\n // symbol instances appropriately so that symbols from buckets that have yet to be placed\n // offset appropriately.\n const symbolHidden = opacityState.text.isHidden();\n [\n symbolInstance.rightJustifiedTextSymbolIndex,\n symbolInstance.centerJustifiedTextSymbolIndex,\n symbolInstance.leftJustifiedTextSymbolIndex\n ].forEach(index => {\n if (index >= 0) {\n bucket.text.placedSymbolArray.get(index).hidden = symbolHidden || horizontalHidden ? 1 : 0;\n }\n });\n\n if (symbolInstance.verticalPlacedTextSymbolIndex >= 0) {\n bucket.text.placedSymbolArray.get(symbolInstance.verticalPlacedTextSymbolIndex).hidden = symbolHidden || verticalHidden ? 1 : 0;\n }\n\n const prevOffset = this.variableOffsets[symbolInstance.crossTileID];\n if (prevOffset) {\n this.markUsedJustification(bucket, prevOffset.anchor, symbolInstance, placedOrientation);\n }\n\n const prevOrientation = this.placedOrientations[symbolInstance.crossTileID];\n if (prevOrientation) {\n this.markUsedJustification(bucket, 'left', symbolInstance, prevOrientation);\n this.markUsedOrientation(bucket, prevOrientation, symbolInstance);\n }\n }\n\n if (hasIcon) {\n const packedOpacity = packOpacity(opacityState.icon);\n\n const useHorizontal = !(hasIconTextFit && symbolInstance.verticalPlacedIconSymbolIndex && horizontalHidden);\n\n if (symbolInstance.placedIconSymbolIndex >= 0) {\n const horizontalOpacity = useHorizontal ? packedOpacity : PACKED_HIDDEN_OPACITY;\n addOpacities(bucket.icon, symbolInstance.numIconVertices, horizontalOpacity);\n bucket.icon.placedSymbolArray.get(symbolInstance.placedIconSymbolIndex).hidden =\n (opacityState.icon.isHidden() as any);\n }\n\n if (symbolInstance.verticalPlacedIconSymbolIndex >= 0) {\n const verticalOpacity = !useHorizontal ? packedOpacity : PACKED_HIDDEN_OPACITY;\n addOpacities(bucket.icon, symbolInstance.numVerticalIconVertices, verticalOpacity);\n bucket.icon.placedSymbolArray.get(symbolInstance.verticalPlacedIconSymbolIndex).hidden =\n (opacityState.icon.isHidden() as any);\n }\n }\n\n const realBoxes = (boxArrays && boxArrays.has(s)) ? boxArrays.get(s) : {\n text: null,\n icon: null\n };\n\n if (bucket.hasIconCollisionBoxData() || bucket.hasTextCollisionBoxData()) {\n const collisionArrays = bucket.collisionArrays[s];\n if (collisionArrays) {\n let shift = new Point(0, 0);\n if (collisionArrays.textBox || collisionArrays.verticalTextBox) {\n let used = true;\n if (hasVariablePlacement) {\n const variableOffset = this.variableOffsets[crossTileID];\n if (variableOffset) {\n // This will show either the currently placed position or the last\n // successfully placed position (so you can visualize what collision\n // just made the symbol disappear, and the most likely place for the\n // symbol to come back)\n shift = calculateVariableLayoutShift(variableOffset.anchor,\n variableOffset.width,\n variableOffset.height,\n variableOffset.textOffset,\n variableOffset.textBoxScale);\n if (rotateWithMap) {\n shift._rotate(pitchWithMap ? this.transform.angle : -this.transform.angle);\n }\n } else {\n // No offset -> this symbol hasn't been placed since coming on-screen\n // No single box is particularly meaningful and all of them would be too noisy\n // Use the center box just to show something's there, but mark it \"not used\"\n used = false;\n }\n }\n\n if (collisionArrays.textBox || collisionArrays.verticalTextBox) {\n let hidden: boolean;\n if (collisionArrays.textBox) {\n hidden = horizontalHidden;\n }\n if (collisionArrays.verticalTextBox) {\n hidden = verticalHidden;\n }\n updateCollisionVertices(bucket.textCollisionBox.collisionVertexArray, opacityState.text.placed, !used || hidden, realBoxes.text, shift.x, shift.y);\n }\n }\n\n if (collisionArrays.iconBox || collisionArrays.verticalIconBox) {\n const verticalIconUsed = Boolean(!verticalHidden && collisionArrays.verticalIconBox);\n let hidden: boolean;\n if (collisionArrays.iconBox) {\n hidden = verticalIconUsed;\n }\n if (collisionArrays.verticalIconBox) {\n hidden = !verticalIconUsed;\n }\n updateCollisionVertices(bucket.iconCollisionBox.collisionVertexArray, opacityState.icon.placed, hidden, realBoxes.icon,\n hasIconTextFit ? shift.x : 0,\n hasIconTextFit ? shift.y : 0);\n }\n }\n }\n }\n\n bucket.sortFeatures(this.transform.angle);\n if (this.retainedQueryData[bucket.bucketInstanceId]) {\n this.retainedQueryData[bucket.bucketInstanceId].featureSortOrder = bucket.featureSortOrder;\n }\n\n if (bucket.hasTextData() && bucket.text.opacityVertexBuffer) {\n bucket.text.opacityVertexBuffer.updateData(bucket.text.opacityVertexArray);\n }\n if (bucket.hasIconData() && bucket.icon.opacityVertexBuffer) {\n bucket.icon.opacityVertexBuffer.updateData(bucket.icon.opacityVertexArray);\n }\n if (bucket.hasIconCollisionBoxData() && bucket.iconCollisionBox.collisionVertexBuffer) {\n bucket.iconCollisionBox.collisionVertexBuffer.updateData(bucket.iconCollisionBox.collisionVertexArray);\n }\n if (bucket.hasTextCollisionBoxData() && bucket.textCollisionBox.collisionVertexBuffer) {\n bucket.textCollisionBox.collisionVertexBuffer.updateData(bucket.textCollisionBox.collisionVertexArray);\n }\n\n if (bucket.text.opacityVertexArray.length !== bucket.text.layoutVertexArray.length / 4) throw new Error(`bucket.text.opacityVertexArray.length (= ${bucket.text.opacityVertexArray.length}) !== bucket.text.layoutVertexArray.length (= ${bucket.text.layoutVertexArray.length}) / 4`);\n if (bucket.icon.opacityVertexArray.length !== bucket.icon.layoutVertexArray.length / 4) throw new Error(`bucket.icon.opacityVertexArray.length (= ${bucket.icon.opacityVertexArray.length}) !== bucket.icon.layoutVertexArray.length (= ${bucket.icon.layoutVertexArray.length}) / 4`);\n\n // Push generated collision circles to the bucket for debug rendering\n if (bucket.bucketInstanceId in this.collisionCircleArrays) {\n const instance = this.collisionCircleArrays[bucket.bucketInstanceId];\n\n bucket.placementInvProjMatrix = instance.invProjMatrix;\n bucket.placementViewportMatrix = instance.viewportMatrix;\n bucket.collisionCircleArray = instance.circles;\n\n delete this.collisionCircleArrays[bucket.bucketInstanceId];\n }\n }\n\n symbolFadeChange(now: number) {\n return this.fadeDuration === 0 ?\n 1 :\n ((now - this.commitTime) / this.fadeDuration + this.prevZoomAdjustment);\n }\n\n zoomAdjustment(zoom: number) {\n // When zooming out quickly, labels can overlap each other. This\n // adjustment is used to reduce the interval between placement calculations\n // and to reduce the fade duration when zooming out quickly. Discovering the\n // collisions more quickly and fading them more quickly reduces the unwanted effect.\n return Math.max(0, (this.transform.zoom - zoom) / 1.5);\n }\n\n hasTransitions(now: number) {\n return this.stale ||\n now - this.lastPlacementChangeTime < this.fadeDuration;\n }\n\n stillRecent(now: number, zoom: number) {\n // The adjustment makes placement more frequent when zooming.\n // This condition applies the adjustment only after the map has\n // stopped zooming. This avoids adding extra jank while zooming.\n const durationAdjustment = this.zoomAtLastRecencyCheck === zoom ?\n (1 - this.zoomAdjustment(zoom)) :\n 1;\n this.zoomAtLastRecencyCheck = zoom;\n\n return this.commitTime + this.fadeDuration * durationAdjustment > now;\n }\n\n setStale() {\n this.stale = true;\n }\n}\n\nfunction updateCollisionVertices(collisionVertexArray: CollisionVertexArray, placed: boolean, notUsed: boolean | number, realBox: Array, shiftX?: number, shiftY?: number) {\n if (!realBox || realBox.length === 0) {\n realBox = [0, 0, 0, 0];\n }\n\n const tlX = realBox[0] - viewportPadding;\n const tlY = realBox[1] - viewportPadding;\n const brX = realBox[2] - viewportPadding;\n const brY = realBox[3] - viewportPadding;\n\n collisionVertexArray.emplaceBack(placed ? 1 : 0, notUsed ? 1 : 0, shiftX || 0, shiftY || 0, tlX, tlY);\n collisionVertexArray.emplaceBack(placed ? 1 : 0, notUsed ? 1 : 0, shiftX || 0, shiftY || 0, brX, tlY);\n collisionVertexArray.emplaceBack(placed ? 1 : 0, notUsed ? 1 : 0, shiftX || 0, shiftY || 0, brX, brY);\n collisionVertexArray.emplaceBack(placed ? 1 : 0, notUsed ? 1 : 0, shiftX || 0, shiftY || 0, tlX, brY);\n}\n\n// All four vertices for a glyph will have the same opacity state\n// So we pack the opacity into a uint8, and then repeat it four times\n// to make a single uint32 that we can upload for each glyph in the\n// label.\nconst shift25 = Math.pow(2, 25);\nconst shift24 = Math.pow(2, 24);\nconst shift17 = Math.pow(2, 17);\nconst shift16 = Math.pow(2, 16);\nconst shift9 = Math.pow(2, 9);\nconst shift8 = Math.pow(2, 8);\nconst shift1 = Math.pow(2, 1);\nfunction packOpacity(opacityState: OpacityState): number {\n if (opacityState.opacity === 0 && !opacityState.placed) {\n return 0;\n } else if (opacityState.opacity === 1 && opacityState.placed) {\n return 4294967295;\n }\n const targetBit = opacityState.placed ? 1 : 0;\n const opacityBits = Math.floor(opacityState.opacity * 127);\n return opacityBits * shift25 + targetBit * shift24 +\n opacityBits * shift17 + targetBit * shift16 +\n opacityBits * shift9 + targetBit * shift8 +\n opacityBits * shift1 + targetBit;\n}\n\nconst PACKED_HIDDEN_OPACITY = 0;\n","import type {Tile} from '../../source/tile';\nimport {pixelsToTileUnits} from '../../source/pixels_to_tile_units';\nimport type {PointProjection} from '../../symbol/projection';\n\n/**\n * A greatly reduced version of the `Projection` interface from the globe branch,\n * used to port symbol bugfixes over to the main branch. Will be replaced with\n * the proper interface once globe is merged.\n */\nexport type Projection = {\n useSpecialProjectionForSymbols: boolean;\n isOccluded(_x, _y, _t): boolean;\n projectTileCoordinates(_x, _y, _t, _ele): PointProjection;\n getPitchedTextCorrection(_transform, _anchor, _tile): number;\n translatePosition(transform: { angle: number; zoom: number }, tile: Tile, translate: [number, number], translateAnchor: 'map' | 'viewport'): [number, number];\n getCircleRadiusCorrection(tr: any): number;\n};\n\nexport function createProjection(): Projection {\n return {\n isOccluded(_x: any, _y: any, _t: any) {\n return false;\n },\n getPitchedTextCorrection(_transform: any, _anchor: any, _tile: any) {\n return 1.0;\n },\n get useSpecialProjectionForSymbols() { return false; },\n projectTileCoordinates(_x, _y, _t, _ele) {\n // This function should only be used when useSpecialProjectionForSymbols is set to true.\n throw new Error('Not implemented.');\n },\n translatePosition(transform, tile, translate, translateAnchor) {\n return translatePosition(transform, tile, translate, translateAnchor);\n },\n getCircleRadiusCorrection(_: any) {\n return 1.0;\n }\n };\n}\n\n/**\n * Returns a translation in tile units that correctly incorporates the view angle and the *-translate and *-translate-anchor properties.\n * @param inViewportPixelUnitsUnits - True when the units accepted by the matrix are in viewport pixels instead of tile units.\n *\n * Temporarily imported from globe branch.\n */\nfunction translatePosition(\n transform: { angle: number; zoom: number },\n tile: Tile,\n translate: [number, number],\n translateAnchor: 'map' | 'viewport',\n inViewportPixelUnitsUnits: boolean = false\n): [number, number] {\n if (!translate[0] && !translate[1]) return [0, 0];\n\n const angle = inViewportPixelUnitsUnits ?\n (translateAnchor === 'map' ? transform.angle : 0) :\n (translateAnchor === 'viewport' ? -transform.angle : 0);\n\n if (angle) {\n const sinA = Math.sin(angle);\n const cosA = Math.cos(angle);\n translate = [\n translate[0] * cosA - translate[1] * sinA,\n translate[0] * sinA + translate[1] * cosA\n ];\n }\n\n return [\n inViewportPixelUnitsUnits ? translate[0] : pixelsToTileUnits(tile, translate[0], transform.zoom),\n inViewportPixelUnitsUnits ? translate[1] : pixelsToTileUnits(tile, translate[1], transform.zoom)];\n}\n","import {browser} from '../util/browser';\n\nimport {Placement} from '../symbol/placement';\n\nimport type {Transform} from '../geo/transform';\nimport type {StyleLayer} from './style_layer';\nimport type {SymbolStyleLayer} from './style_layer/symbol_style_layer';\nimport type {Tile} from '../source/tile';\nimport type {BucketPart} from '../symbol/placement';\nimport {Terrain} from '../render/terrain';\nimport {createProjection} from '../geo/projection/projection';\n\nclass LayerPlacement {\n _sortAcrossTiles: boolean;\n _currentTileIndex: number;\n _currentPartIndex: number;\n _seenCrossTileIDs: {\n [k in string | number]: boolean;\n };\n _bucketParts: Array;\n\n constructor(styleLayer: SymbolStyleLayer) {\n this._sortAcrossTiles = styleLayer.layout.get('symbol-z-order') !== 'viewport-y' &&\n !styleLayer.layout.get('symbol-sort-key').isConstant();\n\n this._currentTileIndex = 0;\n this._currentPartIndex = 0;\n this._seenCrossTileIDs = {};\n this._bucketParts = [];\n }\n\n continuePlacement(tiles: Array, placement: Placement, showCollisionBoxes: boolean, styleLayer: StyleLayer, shouldPausePlacement: () => boolean) {\n\n const bucketParts = this._bucketParts;\n\n while (this._currentTileIndex < tiles.length) {\n const tile = tiles[this._currentTileIndex];\n placement.getBucketParts(bucketParts, styleLayer, tile, this._sortAcrossTiles);\n\n this._currentTileIndex++;\n if (shouldPausePlacement()) {\n return true;\n }\n }\n\n if (this._sortAcrossTiles) {\n this._sortAcrossTiles = false;\n bucketParts.sort((a, b) => (a.sortKey as any as number) - (b.sortKey as any as number));\n }\n\n while (this._currentPartIndex < bucketParts.length) {\n const bucketPart = bucketParts[this._currentPartIndex];\n placement.placeLayerBucketPart(bucketPart, this._seenCrossTileIDs, showCollisionBoxes);\n\n this._currentPartIndex++;\n if (shouldPausePlacement()) {\n return true;\n }\n }\n return false;\n }\n}\n\nexport class PauseablePlacement {\n placement: Placement;\n _done: boolean;\n _currentPlacementIndex: number;\n _forceFullPlacement: boolean;\n _showCollisionBoxes: boolean;\n _inProgressLayer: LayerPlacement;\n\n constructor(\n transform: Transform,\n terrain: Terrain,\n order: Array,\n forceFullPlacement: boolean,\n showCollisionBoxes: boolean,\n fadeDuration: number,\n crossSourceCollisions: boolean,\n prevPlacement?: Placement\n ) {\n this.placement = new Placement(transform, createProjection(), terrain, fadeDuration, crossSourceCollisions, prevPlacement);\n this._currentPlacementIndex = order.length - 1;\n this._forceFullPlacement = forceFullPlacement;\n this._showCollisionBoxes = showCollisionBoxes;\n this._done = false;\n }\n\n isDone() {\n return this._done;\n }\n\n continuePlacement(\n order: Array,\n layers: {[_: string]: StyleLayer},\n layerTiles: {[_: string]: Array}\n ) {\n const startTime = browser.now();\n\n const shouldPausePlacement = () => {\n return this._forceFullPlacement ? false : (browser.now() - startTime) > 2;\n };\n\n while (this._currentPlacementIndex >= 0) {\n const layerId = order[this._currentPlacementIndex];\n const layer = layers[layerId];\n const placementZoom = this.placement.collisionIndex.transform.zoom;\n if (layer.type === 'symbol' &&\n (!layer.minzoom || layer.minzoom <= placementZoom) &&\n (!layer.maxzoom || layer.maxzoom > placementZoom)) {\n\n if (!this._inProgressLayer) {\n this._inProgressLayer = new LayerPlacement(layer as any as SymbolStyleLayer);\n }\n\n const pausePlacement = this._inProgressLayer.continuePlacement(layerTiles[layer.source], this.placement, this._showCollisionBoxes, layer, shouldPausePlacement);\n\n if (pausePlacement) {\n // We didn't finish placing all layers within 2ms,\n // but we can keep rendering with a partial placement\n // We'll resume here on the next frame\n return;\n }\n\n delete this._inProgressLayer;\n }\n\n this._currentPlacementIndex--;\n }\n\n this._done = true;\n }\n\n commit(now: number) {\n this.placement.commit(now);\n return this.placement;\n }\n}\n","import KDBush from 'kdbush';\nimport {EXTENT} from '../data/extent';\n\nimport {SymbolInstanceArray} from '../data/array_types.g';\n\nimport type {SymbolInstance} from '../data/array_types.g';\nimport type {OverscaledTileID} from '../source/tile_id';\nimport type {SymbolBucket} from '../data/bucket/symbol_bucket';\nimport type {StyleLayer} from '../style/style_layer';\nimport type {Tile} from '../source/tile';\n\n/*\n The CrossTileSymbolIndex generally works on the assumption that\n a conceptual \"unique symbol\" can be identified by the text of\n the label combined with the anchor point. The goal is to assign\n these conceptual \"unique symbols\" a shared crossTileID that can be\n used by Placement to keep fading opacity states consistent and to\n deduplicate labels.\n\n The CrossTileSymbolIndex indexes all the current symbol instances and\n their crossTileIDs. When a symbol bucket gets added or updated, the\n index assigns a crossTileID to each of it's symbol instances by either\n matching it with an existing id or assigning a new one.\n*/\n\n// Round anchor positions to roughly 4 pixel grid\nconst roundingFactor = 512 / EXTENT / 2;\n\nexport const KDBUSH_THRESHHOLD = 128;\n\ninterface SymbolsByKeyEntry {\n index?: KDBush;\n positions?: {x: number; y: number}[];\n crossTileIDs: number[];\n}\n\nclass TileLayerIndex {\n _symbolsByKey: Record = {};\n\n constructor(public tileID: OverscaledTileID, symbolInstances: SymbolInstanceArray, public bucketInstanceId: number) {\n // group the symbolInstances by key\n const symbolInstancesByKey = new Map();\n for (let i = 0; i < symbolInstances.length; i++) {\n const symbolInstance = symbolInstances.get(i);\n const key = symbolInstance.key;\n const instances = symbolInstancesByKey.get(key);\n if (instances) {\n // This tile may have multiple symbol instances with the same key\n // Store each one along with its coordinates\n instances.push(symbolInstance);\n } else {\n symbolInstancesByKey.set(key, [symbolInstance]);\n }\n }\n\n // index the SymbolInstances in this each bucket\n for (const [key, symbols] of symbolInstancesByKey) {\n const positions = symbols.map(symbolInstance => ({x: Math.floor(symbolInstance.anchorX * roundingFactor), y: Math.floor(symbolInstance.anchorY * roundingFactor)}));\n const crossTileIDs = symbols.map(v => v.crossTileID);\n const entry: SymbolsByKeyEntry = {positions, crossTileIDs};\n\n // once we get too many symbols for a given key, it becomes much faster to index it before queries\n if (entry.positions.length > KDBUSH_THRESHHOLD) {\n\n const index = new KDBush(entry.positions.length, 16, Uint16Array);\n for (const {x, y} of entry.positions) index.add(x, y);\n index.finish();\n\n // clear all references to the original positions data\n delete entry.positions;\n entry.index = index;\n }\n\n this._symbolsByKey[key] = entry;\n }\n }\n\n // Converts the coordinates of the input symbol instance into coordinates that be can compared\n // against other symbols in this index. Coordinates are:\n // (1) local-tile-based (so after correction we get x,y values relative to our local anchorX/Y)\n // (2) converted to the z-scale of this TileLayerIndex\n // (3) down-sampled by \"roundingFactor\" from tile coordinate precision in order to be\n // more tolerant of small differences between tiles.\n getScaledCoordinates(symbolInstance: SymbolInstance, childTileID: OverscaledTileID): {x: number; y: number} {\n const {x: localX, y: localY, z: localZ} = this.tileID.canonical;\n const {x, y, z} = childTileID.canonical;\n\n const zDifference = z - localZ;\n const scale = roundingFactor / Math.pow(2, zDifference);\n const xWorld = (x * EXTENT + symbolInstance.anchorX) * scale;\n const yWorld = (y * EXTENT + symbolInstance.anchorY) * scale;\n const xOffset = localX * EXTENT * roundingFactor;\n const yOffset = localY * EXTENT * roundingFactor;\n const result = {\n x: Math.floor(xWorld - xOffset),\n y: Math.floor(yWorld - yOffset)\n };\n\n return result;\n }\n\n findMatches(symbolInstances: SymbolInstanceArray, newTileID: OverscaledTileID, zoomCrossTileIDs: {\n [crossTileID: number]: boolean;\n }) {\n const tolerance = this.tileID.canonical.z < newTileID.canonical.z ? 1 : Math.pow(2, this.tileID.canonical.z - newTileID.canonical.z);\n\n for (let i = 0; i < symbolInstances.length; i++) {\n const symbolInstance = symbolInstances.get(i);\n if (symbolInstance.crossTileID) {\n // already has a match, skip\n continue;\n }\n\n const entry = this._symbolsByKey[symbolInstance.key];\n if (!entry) {\n // No symbol with this key in this bucket\n continue;\n }\n\n const scaledSymbolCoord = this.getScaledCoordinates(symbolInstance, newTileID);\n\n if (entry.index) {\n // Return any symbol with the same keys whose coordinates are within 1\n // grid unit. (with a 4px grid, this covers a 12px by 12px area)\n const indexes = entry.index.range(\n scaledSymbolCoord.x - tolerance,\n scaledSymbolCoord.y - tolerance,\n scaledSymbolCoord.x + tolerance,\n scaledSymbolCoord.y + tolerance).sort();\n\n for (const i of indexes) {\n const crossTileID = entry.crossTileIDs[i];\n\n if (!zoomCrossTileIDs[crossTileID]) {\n // Once we've marked ourselves duplicate against this parent symbol,\n // don't let any other symbols at the same zoom level duplicate against\n // the same parent (see issue #5993)\n zoomCrossTileIDs[crossTileID] = true;\n symbolInstance.crossTileID = crossTileID;\n break;\n }\n }\n } else if (entry.positions) {\n for (let i = 0; i < entry.positions.length; i++) {\n const thisTileSymbol = entry.positions[i];\n const crossTileID = entry.crossTileIDs[i];\n\n // Return any symbol with the same keys whose coordinates are within 1\n // grid unit. (with a 4px grid, this covers a 12px by 12px area)\n if (Math.abs(thisTileSymbol.x - scaledSymbolCoord.x) <= tolerance &&\n Math.abs(thisTileSymbol.y - scaledSymbolCoord.y) <= tolerance &&\n !zoomCrossTileIDs[crossTileID]) {\n // Once we've marked ourselves duplicate against this parent symbol,\n // don't let any other symbols at the same zoom level duplicate against\n // the same parent (see issue #5993)\n zoomCrossTileIDs[crossTileID] = true;\n symbolInstance.crossTileID = crossTileID;\n break;\n }\n }\n }\n }\n }\n\n getCrossTileIDsLists() {\n return Object.values(this._symbolsByKey).map(({crossTileIDs}) => crossTileIDs);\n }\n}\n\nclass CrossTileIDs {\n maxCrossTileID: number;\n constructor() {\n this.maxCrossTileID = 0;\n }\n generate() {\n return ++this.maxCrossTileID;\n }\n}\n\nclass CrossTileSymbolLayerIndex {\n indexes: {\n [zoom in string | number]: {\n [tileId in string | number]: TileLayerIndex;\n };\n };\n usedCrossTileIDs: {\n [zoom in string | number]: {\n [crossTileID: number]: boolean;\n };\n };\n lng: number;\n\n constructor() {\n this.indexes = {};\n this.usedCrossTileIDs = {};\n this.lng = 0;\n }\n\n /*\n * Sometimes when a user pans across the antimeridian the longitude value gets wrapped.\n * To prevent labels from flashing out and in we adjust the tileID values in the indexes\n * so that they match the new wrapped version of the map.\n */\n handleWrapJump(lng: number) {\n const wrapDelta = Math.round((lng - this.lng) / 360);\n if (wrapDelta !== 0) {\n for (const zoom in this.indexes) {\n const zoomIndexes = this.indexes[zoom];\n const newZoomIndex = {};\n for (const key in zoomIndexes) {\n // change the tileID's wrap and add it to a new index\n const index = zoomIndexes[key];\n index.tileID = index.tileID.unwrapTo(index.tileID.wrap + wrapDelta);\n newZoomIndex[index.tileID.key] = index;\n }\n this.indexes[zoom] = newZoomIndex;\n }\n }\n this.lng = lng;\n }\n\n addBucket(tileID: OverscaledTileID, bucket: SymbolBucket, crossTileIDs: CrossTileIDs) {\n if (this.indexes[tileID.overscaledZ] &&\n this.indexes[tileID.overscaledZ][tileID.key]) {\n if (this.indexes[tileID.overscaledZ][tileID.key].bucketInstanceId ===\n bucket.bucketInstanceId) {\n return false;\n } else {\n // We're replacing this bucket with an updated version\n // Remove the old bucket's \"used crossTileIDs\" now so that\n // the new bucket can claim them.\n // The old index entries themselves stick around until\n // 'removeStaleBuckets' is called.\n this.removeBucketCrossTileIDs(tileID.overscaledZ,\n this.indexes[tileID.overscaledZ][tileID.key]);\n }\n }\n\n for (let i = 0; i < bucket.symbolInstances.length; i++) {\n const symbolInstance = bucket.symbolInstances.get(i);\n symbolInstance.crossTileID = 0;\n }\n\n if (!this.usedCrossTileIDs[tileID.overscaledZ]) {\n this.usedCrossTileIDs[tileID.overscaledZ] = {};\n }\n const zoomCrossTileIDs = this.usedCrossTileIDs[tileID.overscaledZ];\n\n for (const zoom in this.indexes) {\n const zoomIndexes = this.indexes[zoom];\n if (Number(zoom) > tileID.overscaledZ) {\n for (const id in zoomIndexes) {\n const childIndex = zoomIndexes[id];\n if (childIndex.tileID.isChildOf(tileID)) {\n childIndex.findMatches(bucket.symbolInstances, tileID, zoomCrossTileIDs);\n }\n }\n } else {\n const parentCoord = tileID.scaledTo(Number(zoom));\n const parentIndex = zoomIndexes[parentCoord.key];\n if (parentIndex) {\n parentIndex.findMatches(bucket.symbolInstances, tileID, zoomCrossTileIDs);\n }\n }\n }\n\n for (let i = 0; i < bucket.symbolInstances.length; i++) {\n const symbolInstance = bucket.symbolInstances.get(i);\n if (!symbolInstance.crossTileID) {\n // symbol did not match any known symbol, assign a new id\n symbolInstance.crossTileID = crossTileIDs.generate();\n zoomCrossTileIDs[symbolInstance.crossTileID] = true;\n }\n }\n\n if (this.indexes[tileID.overscaledZ] === undefined) {\n this.indexes[tileID.overscaledZ] = {};\n }\n this.indexes[tileID.overscaledZ][tileID.key] = new TileLayerIndex(tileID, bucket.symbolInstances, bucket.bucketInstanceId);\n\n return true;\n }\n\n removeBucketCrossTileIDs(zoom: string | number, removedBucket: TileLayerIndex) {\n for (const crossTileIDs of removedBucket.getCrossTileIDsLists()) {\n for (const crossTileID of crossTileIDs) {\n delete this.usedCrossTileIDs[zoom][crossTileID];\n }\n }\n }\n\n removeStaleBuckets(currentIDs: {\n [k in string | number]: boolean;\n }) {\n let tilesChanged = false;\n for (const z in this.indexes) {\n const zoomIndexes = this.indexes[z];\n for (const tileKey in zoomIndexes) {\n if (!currentIDs[zoomIndexes[tileKey].bucketInstanceId]) {\n this.removeBucketCrossTileIDs(z, zoomIndexes[tileKey]);\n delete zoomIndexes[tileKey];\n tilesChanged = true;\n }\n }\n }\n return tilesChanged;\n }\n}\n\nexport class CrossTileSymbolIndex {\n layerIndexes: {[layerId: string]: CrossTileSymbolLayerIndex};\n crossTileIDs: CrossTileIDs;\n maxBucketInstanceId: number;\n bucketsInCurrentPlacement: {[_: number]: boolean};\n\n constructor() {\n this.layerIndexes = {};\n this.crossTileIDs = new CrossTileIDs();\n this.maxBucketInstanceId = 0;\n this.bucketsInCurrentPlacement = {};\n }\n\n addLayer(styleLayer: StyleLayer, tiles: Array, lng: number) {\n let layerIndex = this.layerIndexes[styleLayer.id];\n if (layerIndex === undefined) {\n layerIndex = this.layerIndexes[styleLayer.id] = new CrossTileSymbolLayerIndex();\n }\n\n let symbolBucketsChanged = false;\n const currentBucketIDs = {};\n\n layerIndex.handleWrapJump(lng);\n\n for (const tile of tiles) {\n const symbolBucket = (tile.getBucket(styleLayer) as any as SymbolBucket);\n if (!symbolBucket || styleLayer.id !== symbolBucket.layerIds[0])\n continue;\n\n if (!symbolBucket.bucketInstanceId) {\n symbolBucket.bucketInstanceId = ++this.maxBucketInstanceId;\n }\n\n if (layerIndex.addBucket(tile.tileID, symbolBucket, this.crossTileIDs)) {\n symbolBucketsChanged = true;\n }\n currentBucketIDs[symbolBucket.bucketInstanceId] = true;\n }\n\n if (layerIndex.removeStaleBuckets(currentBucketIDs)) {\n symbolBucketsChanged = true;\n }\n\n return symbolBucketsChanged;\n }\n\n pruneUnusedLayers(usedLayers: Array) {\n const usedLayerMap = {};\n usedLayers.forEach((usedLayer) => {\n usedLayerMap[usedLayer] = true;\n });\n for (const layerId in this.layerIndexes) {\n if (!usedLayerMap[layerId]) {\n delete this.layerIndexes[layerId];\n }\n }\n }\n}\n","import {Event, ErrorEvent, Evented} from '../util/evented';\nimport {StyleLayer} from './style_layer';\nimport {createStyleLayer} from './create_style_layer';\nimport {loadSprite} from './load_sprite';\nimport {ImageManager} from '../render/image_manager';\nimport {GlyphManager} from '../render/glyph_manager';\nimport {Light} from './light';\nimport {Sky} from './sky';\nimport {LineAtlas} from '../render/line_atlas';\nimport {clone, extend, deepEqual, filterObject, mapObject} from '../util/util';\nimport {coerceSpriteToArray} from '../util/style';\nimport {getJSON, getReferrer} from '../util/ajax';\nimport {ResourceType} from '../util/request_manager';\nimport {browser} from '../util/browser';\nimport {Dispatcher} from '../util/dispatcher';\nimport {validateStyle, emitValidationErrors as _emitValidationErrors} from './validate_style';\nimport {Source} from '../source/source';\nimport {QueryRenderedFeaturesOptions, QuerySourceFeatureOptions, queryRenderedFeatures, queryRenderedSymbols, querySourceFeatures} from '../source/query_features';\nimport {SourceCache} from '../source/source_cache';\nimport {GeoJSONSource} from '../source/geojson_source';\nimport {latest as styleSpec, derefLayers as deref, emptyStyle, diff as diffStyles, DiffCommand} from '@maplibre/maplibre-gl-style-spec';\nimport {getGlobalWorkerPool} from '../util/global_worker_pool';\nimport {rtlMainThreadPluginFactory} from '../source/rtl_text_plugin_main_thread';\nimport {RTLPluginLoadedEventName} from '../source/rtl_text_plugin_status';\nimport {PauseablePlacement} from './pauseable_placement';\nimport {ZoomHistory} from './zoom_history';\nimport {CrossTileSymbolIndex} from '../symbol/cross_tile_symbol_index';\nimport {validateCustomStyleLayer} from './style_layer/custom_style_layer';\nimport type {MapGeoJSONFeature} from '../util/vectortile_to_geojson';\n\n// We're skipping validation errors with the `source.canvas` identifier in order\n// to continue to allow canvas sources to be added at runtime/updated in\n// smart setStyle (see https://github.com/mapbox/mapbox-gl-js/pull/6424):\nconst emitValidationErrors = (evented: Evented, errors?: ReadonlyArray<{\n message: string;\n identifier?: string;\n}> | null) =>\n _emitValidationErrors(evented, errors && errors.filter(error => error.identifier !== 'source.canvas'));\n\nimport type {Map} from '../ui/map';\nimport type {Transform} from '../geo/transform';\nimport type {StyleImage} from './style_image';\nimport type {EvaluationParameters} from './evaluation_parameters';\nimport type {Placement} from '../symbol/placement';\nimport type {\n LayerSpecification,\n FilterSpecification,\n StyleSpecification,\n LightSpecification,\n SourceSpecification,\n SpriteSpecification,\n DiffOperations,\n SkySpecification\n} from '@maplibre/maplibre-gl-style-spec';\nimport type {CanvasSourceSpecification} from '../source/canvas_source';\nimport type {CustomLayerInterface} from './style_layer/custom_style_layer';\nimport type {Validator} from './validate_style';\nimport {\n MessageType,\n type GetGlyphsParameters,\n type GetGlyphsResponse,\n type GetImagesParameters,\n type GetImagesResponse\n} from '../util/actor_messages';\n\nconst empty = emptyStyle() as StyleSpecification;\n/**\n * A feature identifier that is bound to a source\n */\nexport type FeatureIdentifier = {\n /**\n * Unique id of the feature.\n */\n id?: string | number | undefined;\n /**\n * The id of the vector or GeoJSON source for the feature.\n */\n source: string;\n /**\n * *For vector tile sources, `sourceLayer` is required.*\n */\n sourceLayer?: string | undefined;\n};\n\n/**\n * The options object related to the {@link Map}'s style related methods\n */\nexport type StyleOptions = {\n /**\n * If false, style validation will be skipped. Useful in production environment.\n */\n validate?: boolean;\n /**\n * Defines a CSS\n * font-family for locally overriding generation of Chinese, Japanese, and Korean characters.\n * For these characters, font settings from the map's style will be ignored, except for font-weight keywords (light/regular/medium/bold).\n * Set to `false`, to enable font settings from the map's style for these glyph ranges.\n * Forces a full update.\n */\n localIdeographFontFamily?: string | false;\n};\n\n/**\n * Supporting type to add validation to another style related type\n */\nexport type StyleSetterOptions = {\n /**\n * Whether to check if the filter conforms to the MapLibre Style Specification. Disabling validation is a performance optimization that should only be used if you have previously validated the values you will be passing to this function.\n */\n validate?: boolean;\n};\n\n/**\n * Part of {@link Map#setStyle} options, transformStyle is a convenience function that allows to modify a style after it is fetched but before it is committed to the map state.\n *\n * This function exposes previous and next styles, it can be commonly used to support a range of functionalities like:\n *\n * - when previous style carries certain 'state' that needs to be carried over to a new style gracefully;\n * - when a desired style is a certain combination of previous and incoming style;\n * - when an incoming style requires modification based on external state.\n *\n * @param previous - The current style.\n * @param next - The next style.\n * @returns resulting style that will to be applied to the map\n *\n * @example\n * ```ts\n * map.setStyle('https://demotiles.maplibre.org/style.json', {\n * transformStyle: (previousStyle, nextStyle) => ({\n * ...nextStyle,\n * sources: {\n * ...nextStyle.sources,\n * // copy a source from previous style\n * 'osm': previousStyle.sources.osm\n * },\n * layers: [\n * // background layer\n * nextStyle.layers[0],\n * // copy a layer from previous style\n * previousStyle.layers[0],\n * // other layers from the next style\n * ...nextStyle.layers.slice(1).map(layer => {\n * // hide the layers we don't need from demotiles style\n * if (layer.id.startsWith('geolines')) {\n * layer.layout = {...layer.layout || {}, visibility: 'none'};\n * // filter out US polygons\n * } else if (layer.id.startsWith('coastline') || layer.id.startsWith('countries')) {\n * layer.filter = ['!=', ['get', 'ADM0_A3'], 'USA'];\n * }\n * return layer;\n * })\n * ]\n * })\n * });\n * ```\n */\nexport type TransformStyleFunction = (previous: StyleSpecification | undefined, next: StyleSpecification) => StyleSpecification;\n\n/**\n * The options object related to the {@link Map}'s style related methods\n */\nexport type StyleSwapOptions = {\n /**\n * If false, force a 'full' update, removing the current style\n * and building the given one instead of attempting a diff-based update.\n */\n diff?: boolean;\n /**\n * TransformStyleFunction is a convenience function\n * that allows to modify a style after it is fetched but before it is committed to the map state. Refer to {@link TransformStyleFunction}.\n */\n transformStyle?: TransformStyleFunction;\n}\n\n/**\n * Specifies a layer to be added to a {@link Style}. In addition to a standard {@link LayerSpecification}\n * or a {@link CustomLayerInterface}, a {@link LayerSpecification} with an embedded {@link SourceSpecification} can also be provided.\n */\nexport type AddLayerObject = LayerSpecification | (Omit & {source: SourceSpecification}) | CustomLayerInterface;\n\n/**\n * The Style base class\n */\nexport class Style extends Evented {\n map: Map;\n stylesheet: StyleSpecification;\n dispatcher: Dispatcher;\n imageManager: ImageManager;\n glyphManager: GlyphManager;\n lineAtlas: LineAtlas;\n light: Light;\n sky: Sky;\n\n _frameRequest: AbortController;\n _loadStyleRequest: AbortController;\n _spriteRequest: AbortController;\n _layers: {[_: string]: StyleLayer};\n _serializedLayers: {[_: string]: LayerSpecification};\n _order: Array;\n sourceCaches: {[_: string]: SourceCache};\n zoomHistory: ZoomHistory;\n _loaded: boolean;\n _changed: boolean;\n _updatedSources: {[_: string]: 'clear' | 'reload'};\n _updatedLayers: {[_: string]: true};\n _removedLayers: {[_: string]: StyleLayer};\n _changedImages: {[_: string]: true};\n _glyphsDidChange: boolean;\n _updatedPaintProps: {[layer: string]: true};\n _layerOrderChanged: boolean;\n // image ids of images loaded from style's sprite\n _spritesImagesIds: {[spriteId: string]: string[]};\n // image ids of all images loaded (sprite + user)\n _availableImages: Array;\n\n crossTileSymbolIndex: CrossTileSymbolIndex;\n pauseablePlacement: PauseablePlacement;\n placement: Placement;\n z: number;\n\n constructor(map: Map, options: StyleOptions = {}) {\n super();\n\n this.map = map;\n this.dispatcher = new Dispatcher(getGlobalWorkerPool(), map._getMapId());\n this.dispatcher.registerMessageHandler(MessageType.getGlyphs, (mapId, params) => {\n return this.getGlyphs(mapId, params);\n });\n this.dispatcher.registerMessageHandler(MessageType.getImages, (mapId, params) => {\n return this.getImages(mapId, params);\n });\n this.imageManager = new ImageManager();\n this.imageManager.setEventedParent(this);\n this.glyphManager = new GlyphManager(map._requestManager, options.localIdeographFontFamily);\n this.lineAtlas = new LineAtlas(256, 512);\n this.crossTileSymbolIndex = new CrossTileSymbolIndex();\n\n this._spritesImagesIds = {};\n this._layers = {};\n\n this._order = [];\n this.sourceCaches = {};\n this.zoomHistory = new ZoomHistory();\n this._loaded = false;\n this._availableImages = [];\n\n this._resetUpdates();\n\n this.dispatcher.broadcast(MessageType.setReferrer, getReferrer());\n rtlMainThreadPluginFactory().on(RTLPluginLoadedEventName, this._rtlPluginLoaded);\n\n this.on('data', (event) => {\n if (event.dataType !== 'source' || event.sourceDataType !== 'metadata') {\n return;\n }\n\n const sourceCache = this.sourceCaches[event.sourceId];\n if (!sourceCache) {\n return;\n }\n\n const source = sourceCache.getSource();\n if (!source || !source.vectorLayerIds) {\n return;\n }\n\n for (const layerId in this._layers) {\n const layer = this._layers[layerId];\n if (layer.source === source.id) {\n this._validateLayer(layer);\n }\n }\n });\n }\n\n _rtlPluginLoaded = () => {\n for (const id in this.sourceCaches) {\n const sourceType = this.sourceCaches[id].getSource().type;\n if (sourceType === 'vector' || sourceType === 'geojson') {\n // Non-vector sources don't have any symbols buckets to reload when the RTL text plugin loads\n // They also load more quickly, so they're more likely to have already displaying tiles\n // that would be unnecessarily booted by the plugin load event\n this.sourceCaches[id].reload(); // Should be a no-op if the plugin loads before any tiles load\n }\n }\n };\n\n loadURL(url: string, options: StyleSwapOptions & StyleSetterOptions = {}, previousStyle?: StyleSpecification) {\n this.fire(new Event('dataloading', {dataType: 'style'}));\n\n options.validate = typeof options.validate === 'boolean' ?\n options.validate : true;\n\n const request = this.map._requestManager.transformRequest(url, ResourceType.Style);\n this._loadStyleRequest = new AbortController();\n const abortController = this._loadStyleRequest;\n getJSON(request, this._loadStyleRequest).then((response) => {\n this._loadStyleRequest = null;\n this._load(response.data, options, previousStyle);\n }).catch((error) => {\n this._loadStyleRequest = null;\n if (error && !abortController.signal.aborted) { // ignore abort\n this.fire(new ErrorEvent(error));\n }\n });\n }\n\n loadJSON(json: StyleSpecification, options: StyleSetterOptions & StyleSwapOptions = {}, previousStyle?: StyleSpecification) {\n this.fire(new Event('dataloading', {dataType: 'style'}));\n\n this._frameRequest = new AbortController();\n browser.frameAsync(this._frameRequest).then(() => {\n this._frameRequest = null;\n options.validate = options.validate !== false;\n this._load(json, options, previousStyle);\n }).catch(() => {}); // ignore abort\n }\n\n loadEmpty() {\n this.fire(new Event('dataloading', {dataType: 'style'}));\n this._load(empty, {validate: false});\n }\n\n _load(json: StyleSpecification, options: StyleSwapOptions & StyleSetterOptions, previousStyle?: StyleSpecification) {\n const nextState = options.transformStyle ? options.transformStyle(previousStyle, json) : json;\n if (options.validate && emitValidationErrors(this, validateStyle(nextState))) {\n return;\n }\n\n this._loaded = true;\n this.stylesheet = nextState;\n\n for (const id in nextState.sources) {\n this.addSource(id, nextState.sources[id], {validate: false});\n }\n\n if (nextState.sprite) {\n this._loadSprite(nextState.sprite);\n } else {\n this.imageManager.setLoaded(true);\n }\n\n this.glyphManager.setURL(nextState.glyphs);\n this._createLayers();\n\n this.light = new Light(this.stylesheet.light);\n this.sky = new Sky(this.stylesheet.sky);\n\n this.map.setTerrain(this.stylesheet.terrain ?? null);\n\n this.fire(new Event('data', {dataType: 'style'}));\n this.fire(new Event('style.load'));\n }\n\n private _createLayers() {\n const dereferencedLayers = deref(this.stylesheet.layers);\n\n // Broadcast layers to workers first, so that expensive style processing (createStyleLayer)\n // can happen in parallel on both main and worker threads.\n this.dispatcher.broadcast(MessageType.setLayers, dereferencedLayers);\n\n this._order = dereferencedLayers.map((layer) => layer.id);\n this._layers = {};\n\n // reset serialization field, to be populated only when needed\n this._serializedLayers = null;\n for (const layer of dereferencedLayers) {\n const styledLayer = createStyleLayer(layer);\n styledLayer.setEventedParent(this, {layer: {id: layer.id}});\n this._layers[layer.id] = styledLayer;\n }\n }\n\n _loadSprite(sprite: SpriteSpecification, isUpdate: boolean = false, completion: (err: Error) => void = undefined) {\n this.imageManager.setLoaded(false);\n\n this._spriteRequest = new AbortController();\n let err: Error;\n loadSprite(sprite, this.map._requestManager, this.map.getPixelRatio(), this._spriteRequest).then((images) => {\n this._spriteRequest = null;\n if (images) {\n for (const spriteId in images) {\n this._spritesImagesIds[spriteId] = [];\n\n // remove old sprite's loaded images (for the same sprite id) that are not in new sprite\n const imagesToRemove = this._spritesImagesIds[spriteId] ? this._spritesImagesIds[spriteId].filter(id => !(id in images)) : [];\n for (const id of imagesToRemove) {\n this.imageManager.removeImage(id);\n this._changedImages[id] = true;\n }\n\n for (const id in images[spriteId]) {\n // don't prefix images of the \"default\" sprite\n const imageId = spriteId === 'default' ? id : `${spriteId}:${id}`;\n // save all the sprite's images' ids to be able to delete them in `removeSprite`\n this._spritesImagesIds[spriteId].push(imageId);\n if (imageId in this.imageManager.images) {\n this.imageManager.updateImage(imageId, images[spriteId][id], false);\n } else {\n this.imageManager.addImage(imageId, images[spriteId][id]);\n }\n\n if (isUpdate) {\n this._changedImages[imageId] = true;\n }\n }\n }\n }\n }).catch((error) => {\n this._spriteRequest = null;\n err = error;\n this.fire(new ErrorEvent(err));\n }).finally(() => {\n this.imageManager.setLoaded(true);\n this._availableImages = this.imageManager.listImages();\n\n if (isUpdate) {\n this._changed = true;\n }\n\n this.dispatcher.broadcast(MessageType.setImages, this._availableImages);\n this.fire(new Event('data', {dataType: 'style'}));\n\n if (completion) {\n completion(err);\n }\n });\n }\n\n _unloadSprite() {\n for (const id of Object.values(this._spritesImagesIds).flat()) {\n this.imageManager.removeImage(id);\n this._changedImages[id] = true;\n }\n\n this._spritesImagesIds = {};\n this._availableImages = this.imageManager.listImages();\n this._changed = true;\n this.dispatcher.broadcast(MessageType.setImages, this._availableImages);\n this.fire(new Event('data', {dataType: 'style'}));\n }\n\n _validateLayer(layer: StyleLayer) {\n const sourceCache = this.sourceCaches[layer.source];\n if (!sourceCache) {\n return;\n }\n\n const sourceLayer = layer.sourceLayer;\n if (!sourceLayer) {\n return;\n }\n\n const source = sourceCache.getSource();\n if (source.type === 'geojson' || (source.vectorLayerIds && source.vectorLayerIds.indexOf(sourceLayer) === -1)) {\n this.fire(new ErrorEvent(new Error(\n `Source layer \"${sourceLayer}\" ` +\n `does not exist on source \"${source.id}\" ` +\n `as specified by style layer \"${layer.id}\".`\n )));\n }\n }\n\n loaded() {\n if (!this._loaded)\n return false;\n\n if (Object.keys(this._updatedSources).length)\n return false;\n\n for (const id in this.sourceCaches)\n if (!this.sourceCaches[id].loaded())\n return false;\n\n if (!this.imageManager.isLoaded())\n return false;\n\n return true;\n }\n\n /**\n * @hidden\n * take an array of string IDs, and based on this._layers, generate an array of LayerSpecification\n * @param ids - an array of string IDs, for which serialized layers will be generated. If omitted, all serialized layers will be returned\n * @param returnClose - if true, return a clone of the layer object\n * @returns generated result\n */\n private _serializeByIds(ids: Array, returnClone: boolean = false): Array {\n\n const serializedLayersDictionary = this._serializedAllLayers();\n if (!ids || ids.length === 0) {\n return returnClone ? Object.values(clone(serializedLayersDictionary)) : Object.values(serializedLayersDictionary);\n }\n\n const serializedLayers = [];\n for (const id of ids) {\n // this check will skip all custom layers\n if (serializedLayersDictionary[id]) {\n const toPush = returnClone ? clone(serializedLayersDictionary[id]) : serializedLayersDictionary[id];\n serializedLayers.push(toPush);\n }\n }\n\n return serializedLayers;\n }\n\n /**\n * @hidden\n * Lazy initialization of this._serializedLayers dictionary and return it\n * @returns this._serializedLayers dictionary\n */\n private _serializedAllLayers(): {[_: string]: LayerSpecification} {\n let serializedLayers = this._serializedLayers;\n if (serializedLayers) {\n return serializedLayers;\n }\n\n serializedLayers = this._serializedLayers = {};\n const allLayerIds: string [] = Object.keys(this._layers);\n for (const layerId of allLayerIds) {\n const layer = this._layers[layerId];\n if (layer.type !== 'custom') {\n serializedLayers[layerId] = layer.serialize();\n }\n }\n\n return serializedLayers;\n }\n\n hasTransitions() {\n if (this.light && this.light.hasTransition()) {\n return true;\n }\n\n if (this.sky && this.sky.hasTransition()) {\n return true;\n }\n\n for (const id in this.sourceCaches) {\n if (this.sourceCaches[id].hasTransition()) {\n return true;\n }\n }\n\n for (const id in this._layers) {\n if (this._layers[id].hasTransition()) {\n return true;\n }\n }\n\n return false;\n }\n\n _checkLoaded() {\n if (!this._loaded) {\n throw new Error('Style is not done loading.');\n }\n }\n\n /**\n * @internal\n * Apply queued style updates in a batch and recalculate zoom-dependent paint properties.\n */\n update(parameters: EvaluationParameters) {\n if (!this._loaded) {\n return;\n }\n\n const changed = this._changed;\n if (changed) {\n const updatedIds = Object.keys(this._updatedLayers);\n const removedIds = Object.keys(this._removedLayers);\n\n if (updatedIds.length || removedIds.length) {\n this._updateWorkerLayers(updatedIds, removedIds);\n }\n for (const id in this._updatedSources) {\n const action = this._updatedSources[id];\n\n if (action === 'reload') {\n this._reloadSource(id);\n } else if (action === 'clear') {\n this._clearSource(id);\n } else {\n throw new Error(`Invalid action ${action}`);\n }\n }\n\n this._updateTilesForChangedImages();\n this._updateTilesForChangedGlyphs();\n\n for (const id in this._updatedPaintProps) {\n this._layers[id].updateTransitions(parameters);\n }\n\n this.light.updateTransitions(parameters);\n this.sky.updateTransitions(parameters);\n\n this._resetUpdates();\n }\n\n const sourcesUsedBefore = {};\n\n // save 'used' status to sourcesUsedBefore object and reset all sourceCaches 'used' field to false\n for (const sourceCacheId in this.sourceCaches) {\n const sourceCache = this.sourceCaches[sourceCacheId];\n\n // sourceCache.used could be undefined, and sourcesUsedBefore[sourceCacheId] is also 'undefined'\n sourcesUsedBefore[sourceCacheId] = sourceCache.used;\n sourceCache.used = false;\n }\n\n // loop all layers and find layers that are not hidden at parameters.zoom\n // and set used to true in sourceCaches dictionary for the sources of these layers\n for (const layerId of this._order) {\n const layer = this._layers[layerId];\n\n layer.recalculate(parameters, this._availableImages);\n if (!layer.isHidden(parameters.zoom) && layer.source) {\n this.sourceCaches[layer.source].used = true;\n }\n }\n\n // cross check sourcesUsedBefore against updated this.sourceCaches dictionary\n // if \"used\" field is different fire visibility event\n for (const sourcesUsedBeforeId in sourcesUsedBefore) {\n const sourceCache = this.sourceCaches[sourcesUsedBeforeId];\n\n // (undefine !== false) will evaluate to true and fire an useless visibility event\n // need force \"falsy\" values to boolean to avoid the case above\n if (!!sourcesUsedBefore[sourcesUsedBeforeId] !== !!sourceCache.used) {\n sourceCache.fire(new Event('data',\n {\n sourceDataType: 'visibility',\n dataType: 'source',\n sourceId: sourcesUsedBeforeId\n }));\n }\n }\n\n this.light.recalculate(parameters);\n this.sky.recalculate(parameters);\n this.z = parameters.zoom;\n\n if (changed) {\n this.fire(new Event('data', {dataType: 'style'}));\n }\n }\n\n /*\n * Apply any queued image changes.\n */\n _updateTilesForChangedImages() {\n const changedImages = Object.keys(this._changedImages);\n if (changedImages.length) {\n for (const name in this.sourceCaches) {\n this.sourceCaches[name].reloadTilesForDependencies(['icons', 'patterns'], changedImages);\n }\n this._changedImages = {};\n }\n }\n\n _updateTilesForChangedGlyphs() {\n if (this._glyphsDidChange) {\n for (const name in this.sourceCaches) {\n this.sourceCaches[name].reloadTilesForDependencies(['glyphs'], ['']);\n }\n this._glyphsDidChange = false;\n }\n }\n\n _updateWorkerLayers(updatedIds: Array, removedIds: Array) {\n this.dispatcher.broadcast(MessageType.updateLayers, {\n layers: this._serializeByIds(updatedIds, false),\n removedIds\n });\n }\n\n _resetUpdates() {\n this._changed = false;\n\n this._updatedLayers = {};\n this._removedLayers = {};\n\n this._updatedSources = {};\n this._updatedPaintProps = {};\n\n this._changedImages = {};\n this._glyphsDidChange = false;\n }\n\n /**\n * Update this style's state to match the given style JSON, performing only\n * the necessary mutations.\n *\n * May throw an Error ('Unimplemented: METHOD') if the mapbox-gl-style-spec\n * diff algorithm produces an operation that is not supported.\n *\n * @returns true if any changes were made; false otherwise\n */\n setState(nextState: StyleSpecification, options: StyleSwapOptions & StyleSetterOptions = {}) {\n this._checkLoaded();\n\n const serializedStyle = this.serialize();\n nextState = options.transformStyle ? options.transformStyle(serializedStyle, nextState) : nextState;\n const validate = options.validate ?? true;\n if (validate && emitValidationErrors(this, validateStyle(nextState))) return false;\n\n nextState = clone(nextState);\n nextState.layers = deref(nextState.layers);\n\n const changes = diffStyles(serializedStyle, nextState);\n const operations = this._getOperationsToPerform(changes);\n\n if (operations.unimplemented.length > 0) {\n throw new Error(`Unimplemented: ${operations.unimplemented.join(', ')}.`);\n }\n\n if (operations.operations.length === 0) {\n return false;\n }\n\n for (const styleChangeOperation of operations.operations) {\n styleChangeOperation();\n }\n\n this.stylesheet = nextState;\n\n // reset serialization field, to be populated only when needed\n this._serializedLayers = null;\n\n return true;\n }\n\n _getOperationsToPerform(diff: DiffCommand[]) {\n const operations: Function[] = [];\n const unimplemented: string[] = [];\n for (const op of diff) {\n switch (op.command) {\n case 'setCenter':\n case 'setZoom':\n case 'setBearing':\n case 'setPitch':\n continue;\n case 'addLayer':\n operations.push(() => this.addLayer.apply(this, op.args));\n break;\n case 'removeLayer':\n operations.push(() => this.removeLayer.apply(this, op.args));\n break;\n case 'setPaintProperty':\n operations.push(() => this.setPaintProperty.apply(this, op.args));\n break;\n case 'setLayoutProperty':\n operations.push(() => this.setLayoutProperty.apply(this, op.args));\n break;\n case 'setFilter':\n operations.push(() => this.setFilter.apply(this, op.args));\n break;\n case 'addSource':\n operations.push(() => this.addSource.apply(this, op.args));\n break;\n case 'removeSource':\n operations.push(() => this.removeSource.apply(this, op.args));\n break;\n case 'setLayerZoomRange':\n operations.push(() => this.setLayerZoomRange.apply(this, op.args));\n break;\n case 'setLight':\n operations.push(() => this.setLight.apply(this, op.args));\n break;\n case 'setGeoJSONSourceData':\n operations.push(() => this.setGeoJSONSourceData.apply(this, op.args));\n break;\n case 'setGlyphs':\n operations.push(() => this.setGlyphs.apply(this, op.args));\n break;\n case 'setSprite':\n operations.push(() => this.setSprite.apply(this, op.args));\n break;\n case 'setSky':\n operations.push(() => this.setSky.apply(this, op.args));\n break;\n case 'setTerrain':\n operations.push(() => this.map.setTerrain.apply(this, op.args));\n break;\n case 'setTransition':\n operations.push(() => {});\n break;\n default:\n unimplemented.push(op.command);\n break;\n }\n }\n return {\n operations,\n unimplemented\n };\n }\n\n addImage(id: string, image: StyleImage) {\n if (this.getImage(id)) {\n return this.fire(new ErrorEvent(new Error(`An image named \"${id}\" already exists.`)));\n }\n this.imageManager.addImage(id, image);\n this._afterImageUpdated(id);\n }\n\n updateImage(id: string, image: StyleImage) {\n this.imageManager.updateImage(id, image);\n }\n\n getImage(id: string): StyleImage {\n return this.imageManager.getImage(id);\n }\n\n removeImage(id: string) {\n if (!this.getImage(id)) {\n return this.fire(new ErrorEvent(new Error(`An image named \"${id}\" does not exist.`)));\n }\n this.imageManager.removeImage(id);\n this._afterImageUpdated(id);\n }\n\n _afterImageUpdated(id: string) {\n this._availableImages = this.imageManager.listImages();\n this._changedImages[id] = true;\n this._changed = true;\n this.dispatcher.broadcast(MessageType.setImages, this._availableImages);\n this.fire(new Event('data', {dataType: 'style'}));\n }\n\n listImages() {\n this._checkLoaded();\n\n return this.imageManager.listImages();\n }\n\n addSource(id: string, source: SourceSpecification | CanvasSourceSpecification, options: StyleSetterOptions = {}) {\n this._checkLoaded();\n\n if (this.sourceCaches[id] !== undefined) {\n throw new Error(`Source \"${id}\" already exists.`);\n }\n\n if (!source.type) {\n throw new Error(`The type property must be defined, but only the following properties were given: ${Object.keys(source).join(', ')}.`);\n }\n\n const builtIns = ['vector', 'raster', 'geojson', 'video', 'image'];\n const shouldValidate = builtIns.indexOf(source.type) >= 0;\n if (shouldValidate && this._validate(validateStyle.source, `sources.${id}`, source, null, options)) return;\n if (this.map && this.map._collectResourceTiming) (source as any).collectResourceTiming = true;\n const sourceCache = this.sourceCaches[id] = new SourceCache(id, source, this.dispatcher);\n sourceCache.style = this;\n sourceCache.setEventedParent(this, () => ({\n isSourceLoaded: sourceCache.loaded(),\n source: sourceCache.serialize(),\n sourceId: id\n }));\n\n sourceCache.onAdd(this.map);\n this._changed = true;\n }\n\n /**\n * Remove a source from this stylesheet, given its id.\n * @param id - id of the source to remove\n * @throws if no source is found with the given ID\n */\n removeSource(id: string): this {\n this._checkLoaded();\n\n if (this.sourceCaches[id] === undefined) {\n throw new Error('There is no source with this ID');\n }\n for (const layerId in this._layers) {\n if (this._layers[layerId].source === id) {\n return this.fire(new ErrorEvent(new Error(`Source \"${id}\" cannot be removed while layer \"${layerId}\" is using it.`)));\n }\n }\n\n const sourceCache = this.sourceCaches[id];\n delete this.sourceCaches[id];\n delete this._updatedSources[id];\n sourceCache.fire(new Event('data', {sourceDataType: 'metadata', dataType: 'source', sourceId: id}));\n sourceCache.setEventedParent(null);\n sourceCache.onRemove(this.map);\n this._changed = true;\n }\n\n /**\n * Set the data of a GeoJSON source, given its id.\n * @param id - id of the source\n * @param data - GeoJSON source\n */\n setGeoJSONSourceData(id: string, data: GeoJSON.GeoJSON | string) {\n this._checkLoaded();\n\n if (this.sourceCaches[id] === undefined) throw new Error(`There is no source with this ID=${id}`);\n const geojsonSource: GeoJSONSource = (this.sourceCaches[id].getSource() as any);\n if (geojsonSource.type !== 'geojson') throw new Error(`geojsonSource.type is ${geojsonSource.type}, which is !== 'geojson`);\n\n geojsonSource.setData(data);\n this._changed = true;\n }\n\n /**\n * Get a source by ID.\n * @param id - ID of the desired source\n * @returns source\n */\n getSource(id: string): Source | undefined {\n return this.sourceCaches[id] && this.sourceCaches[id].getSource();\n }\n\n /**\n * Add a layer to the map style. The layer will be inserted before the layer with\n * ID `before`, or appended if `before` is omitted.\n * @param layerObject - The style layer to add.\n * @param before - ID of an existing layer to insert before\n * @param options - Style setter options.\n */\n addLayer(layerObject: AddLayerObject, before?: string, options: StyleSetterOptions = {}): this {\n this._checkLoaded();\n\n const id = layerObject.id;\n\n if (this.getLayer(id)) {\n this.fire(new ErrorEvent(new Error(`Layer \"${id}\" already exists on this map.`)));\n return;\n }\n\n let layer: ReturnType;\n if (layerObject.type === 'custom') {\n\n if (emitValidationErrors(this, validateCustomStyleLayer(layerObject))) return;\n\n layer = createStyleLayer(layerObject);\n\n } else {\n if ('source' in layerObject && typeof layerObject.source === 'object') {\n this.addSource(id, layerObject.source);\n layerObject = clone(layerObject);\n layerObject = extend(layerObject, {source: id});\n }\n\n // this layer is not in the style.layers array, so we pass an impossible array index\n if (this._validate(validateStyle.layer,\n `layers.${id}`, layerObject, {arrayIndex: -1}, options)) return;\n\n layer = createStyleLayer(layerObject as LayerSpecification | CustomLayerInterface);\n this._validateLayer(layer);\n\n layer.setEventedParent(this, {layer: {id}});\n }\n\n const index = before ? this._order.indexOf(before) : this._order.length;\n if (before && index === -1) {\n this.fire(new ErrorEvent(new Error(`Cannot add layer \"${id}\" before non-existing layer \"${before}\".`)));\n return;\n }\n\n this._order.splice(index, 0, id);\n this._layerOrderChanged = true;\n\n this._layers[id] = layer;\n\n if (this._removedLayers[id] && layer.source && layer.type !== 'custom') {\n // If, in the current batch, we have already removed this layer\n // and we are now re-adding it with a different `type`, then we\n // need to clear (rather than just reload) the underlying source's\n // tiles. Otherwise, tiles marked 'reloading' will have buckets /\n // buffers that are set up for the _previous_ version of this\n // layer, causing, e.g.:\n // https://github.com/mapbox/mapbox-gl-js/issues/3633\n const removed = this._removedLayers[id];\n delete this._removedLayers[id];\n if (removed.type !== layer.type) {\n this._updatedSources[layer.source] = 'clear';\n } else {\n this._updatedSources[layer.source] = 'reload';\n this.sourceCaches[layer.source].pause();\n }\n }\n this._updateLayer(layer);\n\n if (layer.onAdd) {\n layer.onAdd(this.map);\n }\n }\n\n /**\n * Moves a layer to a different z-position. The layer will be inserted before the layer with\n * ID `before`, or appended if `before` is omitted.\n * @param id - ID of the layer to move\n * @param before - ID of an existing layer to insert before\n */\n moveLayer(id: string, before?: string) {\n this._checkLoaded();\n this._changed = true;\n\n const layer = this._layers[id];\n if (!layer) {\n this.fire(new ErrorEvent(new Error(`The layer '${id}' does not exist in the map's style and cannot be moved.`)));\n return;\n }\n\n if (id === before) {\n return;\n }\n\n const index = this._order.indexOf(id);\n this._order.splice(index, 1);\n\n const newIndex = before ? this._order.indexOf(before) : this._order.length;\n if (before && newIndex === -1) {\n this.fire(new ErrorEvent(new Error(`Cannot move layer \"${id}\" before non-existing layer \"${before}\".`)));\n return;\n }\n this._order.splice(newIndex, 0, id);\n\n this._layerOrderChanged = true;\n }\n\n /**\n * Remove the layer with the given id from the style.\n * A {@link ErrorEvent} event will be fired if no such layer exists.\n *\n * @param id - id of the layer to remove\n */\n removeLayer(id: string) {\n this._checkLoaded();\n\n const layer = this._layers[id];\n if (!layer) {\n this.fire(new ErrorEvent(new Error(`Cannot remove non-existing layer \"${id}\".`)));\n return;\n }\n\n layer.setEventedParent(null);\n\n const index = this._order.indexOf(id);\n this._order.splice(index, 1);\n\n this._layerOrderChanged = true;\n this._changed = true;\n this._removedLayers[id] = layer;\n delete this._layers[id];\n\n if (this._serializedLayers) {\n delete this._serializedLayers[id];\n }\n delete this._updatedLayers[id];\n delete this._updatedPaintProps[id];\n\n if (layer.onRemove) {\n layer.onRemove(this.map);\n }\n }\n\n /**\n * Return the style layer object with the given `id`.\n *\n * @param id - id of the desired layer\n * @returns a layer, if one with the given `id` exists\n */\n getLayer(id: string): StyleLayer | undefined {\n return this._layers[id];\n }\n\n /**\n * Return the ids of all layers currently in the style, including custom layers, in order.\n *\n * @returns ids of layers, in order\n */\n getLayersOrder(): string[] {\n return [...this._order];\n }\n\n /**\n * Checks if a specific layer is present within the style.\n *\n * @param id - the id of the desired layer\n * @returns a boolean specifying if the given layer is present\n */\n hasLayer(id: string): boolean {\n return id in this._layers;\n }\n\n setLayerZoomRange(layerId: string, minzoom?: number | null, maxzoom?: number | null) {\n this._checkLoaded();\n\n const layer = this.getLayer(layerId);\n if (!layer) {\n this.fire(new ErrorEvent(new Error(`Cannot set the zoom range of non-existing layer \"${layerId}\".`)));\n return;\n }\n\n if (layer.minzoom === minzoom && layer.maxzoom === maxzoom) return;\n\n if (minzoom != null) {\n layer.minzoom = minzoom;\n }\n if (maxzoom != null) {\n layer.maxzoom = maxzoom;\n }\n this._updateLayer(layer);\n }\n\n setFilter(layerId: string, filter?: FilterSpecification | null, options: StyleSetterOptions = {}) {\n this._checkLoaded();\n\n const layer = this.getLayer(layerId);\n if (!layer) {\n this.fire(new ErrorEvent(new Error(`Cannot filter non-existing layer \"${layerId}\".`)));\n return;\n }\n\n if (deepEqual(layer.filter, filter)) {\n return;\n }\n\n if (filter === null || filter === undefined) {\n layer.filter = undefined;\n this._updateLayer(layer);\n return;\n }\n\n if (this._validate(validateStyle.filter, `layers.${layer.id}.filter`, filter, null, options)) {\n return;\n }\n\n layer.filter = clone(filter);\n this._updateLayer(layer);\n }\n\n /**\n * Get a layer's filter object\n * @param layer - the layer to inspect\n * @returns the layer's filter, if any\n */\n getFilter(layer: string): FilterSpecification | void {\n return clone(this.getLayer(layer).filter);\n }\n\n setLayoutProperty(layerId: string, name: string, value: any, options: StyleSetterOptions = {}) {\n this._checkLoaded();\n\n const layer = this.getLayer(layerId);\n if (!layer) {\n this.fire(new ErrorEvent(new Error(`Cannot style non-existing layer \"${layerId}\".`)));\n return;\n }\n\n if (deepEqual(layer.getLayoutProperty(name), value)) return;\n\n layer.setLayoutProperty(name, value, options);\n this._updateLayer(layer);\n }\n\n /**\n * Get a layout property's value from a given layer\n * @param layerId - the layer to inspect\n * @param name - the name of the layout property\n * @returns the property value\n */\n getLayoutProperty(layerId: string, name: string) {\n const layer = this.getLayer(layerId);\n if (!layer) {\n this.fire(new ErrorEvent(new Error(`Cannot get style of non-existing layer \"${layerId}\".`)));\n return;\n }\n\n return layer.getLayoutProperty(name);\n }\n\n setPaintProperty(layerId: string, name: string, value: any, options: StyleSetterOptions = {}) {\n this._checkLoaded();\n\n const layer = this.getLayer(layerId);\n if (!layer) {\n this.fire(new ErrorEvent(new Error(`Cannot style non-existing layer \"${layerId}\".`)));\n return;\n }\n\n if (deepEqual(layer.getPaintProperty(name), value)) return;\n\n const requiresRelayout = layer.setPaintProperty(name, value, options);\n if (requiresRelayout) {\n this._updateLayer(layer);\n }\n\n this._changed = true;\n this._updatedPaintProps[layerId] = true;\n // reset serialization field, to be populated only when needed\n this._serializedLayers = null;\n }\n\n getPaintProperty(layer: string, name: string) {\n return this.getLayer(layer).getPaintProperty(name);\n }\n\n setFeatureState(target: FeatureIdentifier, state: any) {\n this._checkLoaded();\n const sourceId = target.source;\n const sourceLayer = target.sourceLayer;\n const sourceCache = this.sourceCaches[sourceId];\n\n if (sourceCache === undefined) {\n this.fire(new ErrorEvent(new Error(`The source '${sourceId}' does not exist in the map's style.`)));\n return;\n }\n const sourceType = sourceCache.getSource().type;\n if (sourceType === 'geojson' && sourceLayer) {\n this.fire(new ErrorEvent(new Error('GeoJSON sources cannot have a sourceLayer parameter.')));\n return;\n }\n if (sourceType === 'vector' && !sourceLayer) {\n this.fire(new ErrorEvent(new Error('The sourceLayer parameter must be provided for vector source types.')));\n return;\n }\n if (target.id === undefined) {\n this.fire(new ErrorEvent(new Error('The feature id parameter must be provided.')));\n }\n\n sourceCache.setFeatureState(sourceLayer, target.id, state);\n }\n\n removeFeatureState(target: FeatureIdentifier, key?: string) {\n this._checkLoaded();\n const sourceId = target.source;\n const sourceCache = this.sourceCaches[sourceId];\n\n if (sourceCache === undefined) {\n this.fire(new ErrorEvent(new Error(`The source '${sourceId}' does not exist in the map's style.`)));\n return;\n }\n\n const sourceType = sourceCache.getSource().type;\n const sourceLayer = sourceType === 'vector' ? target.sourceLayer : undefined;\n\n if (sourceType === 'vector' && !sourceLayer) {\n this.fire(new ErrorEvent(new Error('The sourceLayer parameter must be provided for vector source types.')));\n return;\n }\n\n if (key && (typeof target.id !== 'string' && typeof target.id !== 'number')) {\n this.fire(new ErrorEvent(new Error('A feature id is required to remove its specific state property.')));\n return;\n }\n\n sourceCache.removeFeatureState(sourceLayer, target.id, key);\n }\n\n getFeatureState(target: FeatureIdentifier) {\n this._checkLoaded();\n const sourceId = target.source;\n const sourceLayer = target.sourceLayer;\n const sourceCache = this.sourceCaches[sourceId];\n\n if (sourceCache === undefined) {\n this.fire(new ErrorEvent(new Error(`The source '${sourceId}' does not exist in the map's style.`)));\n return;\n }\n const sourceType = sourceCache.getSource().type;\n if (sourceType === 'vector' && !sourceLayer) {\n this.fire(new ErrorEvent(new Error('The sourceLayer parameter must be provided for vector source types.')));\n return;\n }\n if (target.id === undefined) {\n this.fire(new ErrorEvent(new Error('The feature id parameter must be provided.')));\n }\n\n return sourceCache.getFeatureState(sourceLayer, target.id);\n }\n\n getTransition() {\n return extend({duration: 300, delay: 0}, this.stylesheet && this.stylesheet.transition);\n }\n\n serialize(): StyleSpecification | undefined {\n // We return undefined before we're loaded, following the pattern of Map.getStyle() before\n // the Style object is initialized.\n // Internally, Style._validate() calls Style.serialize() but callers are responsible for\n // calling Style._checkLoaded() first if their validation requires the style to be loaded.\n if (!this._loaded) return;\n\n const sources = mapObject(this.sourceCaches, (source) => source.serialize());\n const layers = this._serializeByIds(this._order, true);\n const terrain = this.map.getTerrain() || undefined;\n const myStyleSheet = this.stylesheet;\n\n return filterObject({\n version: myStyleSheet.version,\n name: myStyleSheet.name,\n metadata: myStyleSheet.metadata,\n light: myStyleSheet.light,\n sky: myStyleSheet.sky,\n center: myStyleSheet.center,\n zoom: myStyleSheet.zoom,\n bearing: myStyleSheet.bearing,\n pitch: myStyleSheet.pitch,\n sprite: myStyleSheet.sprite,\n glyphs: myStyleSheet.glyphs,\n transition: myStyleSheet.transition,\n sources,\n layers,\n terrain\n },\n (value) => { return value !== undefined; });\n }\n\n _updateLayer(layer: StyleLayer) {\n this._updatedLayers[layer.id] = true;\n if (layer.source && !this._updatedSources[layer.source] &&\n //Skip for raster layers (https://github.com/mapbox/mapbox-gl-js/issues/7865)\n this.sourceCaches[layer.source].getSource().type !== 'raster') {\n this._updatedSources[layer.source] = 'reload';\n this.sourceCaches[layer.source].pause();\n }\n\n // upon updating, serialized layer dictionary should be reset.\n // When needed, it will be populated with the correct copy again.\n this._serializedLayers = null;\n this._changed = true;\n }\n\n _flattenAndSortRenderedFeatures(sourceResults: Array<{ [key: string]: Array<{featureIndex: number; feature: MapGeoJSONFeature}> }>) {\n // Feature order is complicated.\n // The order between features in two 2D layers is always determined by layer order.\n // The order between features in two 3D layers is always determined by depth.\n // The order between a feature in a 2D layer and a 3D layer is tricky:\n // Most often layer order determines the feature order in this case. If\n // a line layer is above a extrusion layer the line feature will be rendered\n // above the extrusion. If the line layer is below the extrusion layer,\n // it will be rendered below it.\n //\n // There is a weird case though.\n // You have layers in this order: extrusion_layer_a, line_layer, extrusion_layer_b\n // Each layer has a feature that overlaps the other features.\n // The feature in extrusion_layer_a is closer than the feature in extrusion_layer_b so it is rendered above.\n // The feature in line_layer is rendered above extrusion_layer_a.\n // This means that that the line_layer feature is above the extrusion_layer_b feature despite\n // it being in an earlier layer.\n\n const isLayer3D = layerId => this._layers[layerId].type === 'fill-extrusion';\n\n const layerIndex = {};\n const features3D = [];\n for (let l = this._order.length - 1; l >= 0; l--) {\n const layerId = this._order[l];\n if (isLayer3D(layerId)) {\n layerIndex[layerId] = l;\n for (const sourceResult of sourceResults) {\n const layerFeatures = sourceResult[layerId];\n if (layerFeatures) {\n for (const featureWrapper of layerFeatures) {\n features3D.push(featureWrapper);\n }\n }\n }\n }\n }\n\n features3D.sort((a, b) => {\n return b.intersectionZ - a.intersectionZ;\n });\n\n const features = [];\n for (let l = this._order.length - 1; l >= 0; l--) {\n const layerId = this._order[l];\n\n if (isLayer3D(layerId)) {\n // add all 3D features that are in or above the current layer\n for (let i = features3D.length - 1; i >= 0; i--) {\n const topmost3D = features3D[i].feature;\n if (layerIndex[topmost3D.layer.id] < l) break;\n features.push(topmost3D);\n features3D.pop();\n }\n } else {\n for (const sourceResult of sourceResults) {\n const layerFeatures = sourceResult[layerId];\n if (layerFeatures) {\n for (const featureWrapper of layerFeatures) {\n features.push(featureWrapper.feature);\n }\n }\n }\n }\n }\n\n return features;\n }\n\n queryRenderedFeatures(queryGeometry: any, params: QueryRenderedFeaturesOptions, transform: Transform) {\n if (params && params.filter) {\n this._validate(validateStyle.filter, 'queryRenderedFeatures.filter', params.filter, null, params);\n }\n\n const includedSources = {};\n if (params && params.layers) {\n if (!Array.isArray(params.layers)) {\n this.fire(new ErrorEvent(new Error('parameters.layers must be an Array.')));\n return [];\n }\n for (const layerId of params.layers) {\n const layer = this._layers[layerId];\n if (!layer) {\n // this layer is not in the style.layers array\n this.fire(new ErrorEvent(new Error(`The layer '${layerId}' does not exist in the map's style and cannot be queried for features.`)));\n return [];\n }\n includedSources[layer.source] = true;\n }\n }\n\n const sourceResults = [];\n\n params.availableImages = this._availableImages;\n\n // LayerSpecification is serialized StyleLayer, and this casting is safe.\n const serializedLayers = this._serializedAllLayers() as {[_: string]: StyleLayer};\n\n for (const id in this.sourceCaches) {\n if (params.layers && !includedSources[id]) continue;\n sourceResults.push(\n queryRenderedFeatures(\n this.sourceCaches[id],\n this._layers,\n serializedLayers,\n queryGeometry,\n params,\n transform)\n );\n }\n\n if (this.placement) {\n // If a placement has run, query against its CollisionIndex\n // for symbol results, and treat it as an extra source to merge\n sourceResults.push(\n queryRenderedSymbols(\n this._layers,\n serializedLayers,\n this.sourceCaches,\n queryGeometry,\n params,\n this.placement.collisionIndex,\n this.placement.retainedQueryData)\n );\n }\n\n return this._flattenAndSortRenderedFeatures(sourceResults);\n }\n\n querySourceFeatures(\n sourceID: string,\n params?: QuerySourceFeatureOptions\n ) {\n if (params && params.filter) {\n this._validate(validateStyle.filter, 'querySourceFeatures.filter', params.filter, null, params);\n }\n const sourceCache = this.sourceCaches[sourceID];\n return sourceCache ? querySourceFeatures(sourceCache, params) : [];\n }\n\n getLight() {\n return this.light.getLight();\n }\n\n setLight(lightOptions: LightSpecification, options: StyleSetterOptions = {}) {\n this._checkLoaded();\n\n const light = this.light.getLight();\n let _update = false;\n for (const key in lightOptions) {\n if (!deepEqual(lightOptions[key], light[key])) {\n _update = true;\n break;\n }\n }\n if (!_update) return;\n\n const parameters = {\n now: browser.now(),\n transition: extend({\n duration: 300,\n delay: 0\n }, this.stylesheet.transition)\n };\n\n this.light.setLight(lightOptions, options);\n this.light.updateTransitions(parameters);\n }\n\n getSky(): SkySpecification {\n return this.stylesheet?.sky;\n }\n\n setSky(skyOptions?: SkySpecification, options: StyleSetterOptions = {}) {\n const sky = this.getSky();\n let update = false;\n if (!skyOptions && !sky) return;\n\n if (skyOptions && !sky) {\n update = true;\n } else if (!skyOptions && sky) {\n update = true;\n } else {\n for (const key in skyOptions) {\n if (!deepEqual(skyOptions[key], sky[key])) {\n update = true;\n break;\n }\n }\n }\n if (!update) return;\n\n const parameters = {\n now: browser.now(),\n transition: extend({\n duration: 300,\n delay: 0\n }, this.stylesheet.transition)\n };\n\n this.stylesheet.sky = skyOptions;\n this.sky.setSky(skyOptions, options);\n this.sky.updateTransitions(parameters);\n }\n\n _validate(validate: Validator, key: string, value: any, props: any, options: {\n validate?: boolean;\n } = {}) {\n if (options && options.validate === false) {\n return false;\n }\n return emitValidationErrors(this, validate.call(validateStyle, extend({\n key,\n style: this.serialize(),\n value,\n styleSpec\n }, props)));\n }\n\n _remove(mapRemoved: boolean = true) {\n if (this._frameRequest) {\n this._frameRequest.abort();\n this._frameRequest = null;\n }\n if (this._loadStyleRequest) {\n this._loadStyleRequest.abort();\n this._loadStyleRequest = null;\n }\n if (this._spriteRequest) {\n this._spriteRequest.abort();\n this._spriteRequest = null;\n }\n rtlMainThreadPluginFactory().off(RTLPluginLoadedEventName, this._rtlPluginLoaded);\n for (const layerId in this._layers) {\n const layer: StyleLayer = this._layers[layerId];\n layer.setEventedParent(null);\n }\n for (const id in this.sourceCaches) {\n const sourceCache = this.sourceCaches[id];\n sourceCache.setEventedParent(null);\n sourceCache.onRemove(this.map);\n }\n this.imageManager.setEventedParent(null);\n this.setEventedParent(null);\n if (mapRemoved) {\n this.dispatcher.broadcast(MessageType.removeMap, undefined);\n }\n this.dispatcher.remove(mapRemoved);\n }\n\n _clearSource(id: string) {\n this.sourceCaches[id].clearTiles();\n }\n\n _reloadSource(id: string) {\n this.sourceCaches[id].resume();\n this.sourceCaches[id].reload();\n }\n\n _updateSources(transform: Transform) {\n for (const id in this.sourceCaches) {\n this.sourceCaches[id].update(transform, this.map.terrain);\n }\n }\n\n _generateCollisionBoxes() {\n for (const id in this.sourceCaches) {\n this._reloadSource(id);\n }\n }\n\n _updatePlacement(transform: Transform, showCollisionBoxes: boolean, fadeDuration: number, crossSourceCollisions: boolean, forceFullPlacement: boolean = false) {\n let symbolBucketsChanged = false;\n let placementCommitted = false;\n\n const layerTiles = {};\n\n for (const layerID of this._order) {\n const styleLayer = this._layers[layerID];\n if (styleLayer.type !== 'symbol') continue;\n\n if (!layerTiles[styleLayer.source]) {\n const sourceCache = this.sourceCaches[styleLayer.source];\n layerTiles[styleLayer.source] = sourceCache.getRenderableIds(true)\n .map((id) => sourceCache.getTileByID(id))\n .sort((a, b) => (b.tileID.overscaledZ - a.tileID.overscaledZ) || (a.tileID.isLessThan(b.tileID) ? -1 : 1));\n }\n\n const layerBucketsChanged = this.crossTileSymbolIndex.addLayer(styleLayer, layerTiles[styleLayer.source], transform.center.lng);\n symbolBucketsChanged = symbolBucketsChanged || layerBucketsChanged;\n }\n this.crossTileSymbolIndex.pruneUnusedLayers(this._order);\n\n // Anything that changes our \"in progress\" layer and tile indices requires us\n // to start over. When we start over, we do a full placement instead of incremental\n // to prevent starvation.\n // We need to restart placement to keep layer indices in sync.\n // Also force full placement when fadeDuration === 0 to ensure that newly loaded\n // tiles will fully display symbols in their first frame\n forceFullPlacement = forceFullPlacement || this._layerOrderChanged || fadeDuration === 0;\n\n if (forceFullPlacement || !this.pauseablePlacement || (this.pauseablePlacement.isDone() && !this.placement.stillRecent(browser.now(), transform.zoom))) {\n this.pauseablePlacement = new PauseablePlacement(transform, this.map.terrain, this._order, forceFullPlacement, showCollisionBoxes, fadeDuration, crossSourceCollisions, this.placement);\n this._layerOrderChanged = false;\n }\n\n if (this.pauseablePlacement.isDone()) {\n // the last placement finished running, but the next one hasn’t\n // started yet because of the `stillRecent` check immediately\n // above, so mark it stale to ensure that we request another\n // render frame\n this.placement.setStale();\n } else {\n this.pauseablePlacement.continuePlacement(this._order, this._layers, layerTiles);\n\n if (this.pauseablePlacement.isDone()) {\n this.placement = this.pauseablePlacement.commit(browser.now());\n placementCommitted = true;\n }\n\n if (symbolBucketsChanged) {\n // since the placement gets split over multiple frames it is possible\n // these buckets were processed before they were changed and so the\n // placement is already stale while it is in progress\n this.pauseablePlacement.placement.setStale();\n }\n }\n\n if (placementCommitted || symbolBucketsChanged) {\n for (const layerID of this._order) {\n const styleLayer = this._layers[layerID];\n if (styleLayer.type !== 'symbol') continue;\n this.placement.updateLayerOpacities(styleLayer, layerTiles[styleLayer.source]);\n }\n }\n\n // needsRender is false when we have just finished a placement that didn't change the visibility of any symbols\n const needsRerender = !this.pauseablePlacement.isDone() || this.placement.hasTransitions(browser.now());\n return needsRerender;\n }\n\n _releaseSymbolFadeTiles() {\n for (const id in this.sourceCaches) {\n this.sourceCaches[id].releaseSymbolFadeTiles();\n }\n }\n\n // Callbacks from web workers\n\n async getImages(mapId: string | number, params: GetImagesParameters): Promise {\n const images = await this.imageManager.getImages(params.icons);\n\n // Apply queued image changes before setting the tile's dependencies so that the tile\n // is not reloaded unnecessarily. Without this forced update the reload could happen in cases\n // like this one:\n // - icons contains \"my-image\"\n // - imageManager.getImages(...) triggers `onstyleimagemissing`\n // - the user adds \"my-image\" within the callback\n // - addImage adds \"my-image\" to this._changedImages\n // - the next frame triggers a reload of this tile even though it already has the latest version\n this._updateTilesForChangedImages();\n\n const sourceCache = this.sourceCaches[params.source];\n if (sourceCache) {\n sourceCache.setDependencies(params.tileID.key, params.type, params.icons);\n }\n return images;\n }\n\n async getGlyphs(mapId: string | number, params: GetGlyphsParameters): Promise {\n const glypgs = await this.glyphManager.getGlyphs(params.stacks);\n const sourceCache = this.sourceCaches[params.source];\n if (sourceCache) {\n // we are not setting stacks as dependencies since for now\n // we just need to know which tiles have glyph dependencies\n sourceCache.setDependencies(params.tileID.key, params.type, ['']);\n }\n return glypgs;\n }\n\n getGlyphsUrl() {\n return this.stylesheet.glyphs || null;\n }\n\n setGlyphs(glyphsUrl: string | null, options: StyleSetterOptions = {}) {\n this._checkLoaded();\n if (glyphsUrl && this._validate(validateStyle.glyphs, 'glyphs', glyphsUrl, null, options)) {\n return;\n }\n\n this._glyphsDidChange = true;\n this.stylesheet.glyphs = glyphsUrl;\n this.glyphManager.entries = {};\n this.glyphManager.setURL(glyphsUrl);\n }\n\n /**\n * Add a sprite.\n *\n * @param id - The id of the desired sprite\n * @param url - The url to load the desired sprite from\n * @param options - The style setter options\n * @param completion - The completion handler\n */\n addSprite(id: string, url: string, options: StyleSetterOptions = {}, completion?: (err: Error) => void) {\n this._checkLoaded();\n\n const spriteToAdd = [{id, url}];\n const updatedSprite = [\n ...coerceSpriteToArray(this.stylesheet.sprite),\n ...spriteToAdd\n ];\n\n if (this._validate(validateStyle.sprite, 'sprite', updatedSprite, null, options)) return;\n\n this.stylesheet.sprite = updatedSprite;\n this._loadSprite(spriteToAdd, true, completion);\n }\n\n /**\n * Remove a sprite by its id. When the last sprite is removed, the whole `this.stylesheet.sprite` object becomes\n * `undefined`. This falsy `undefined` value later prevents attempts to load the sprite when it's absent.\n *\n * @param id - the id of the sprite to remove\n */\n removeSprite(id: string) {\n this._checkLoaded();\n\n const internalSpriteRepresentation = coerceSpriteToArray(this.stylesheet.sprite);\n\n if (!internalSpriteRepresentation.find(sprite => sprite.id === id)) {\n this.fire(new ErrorEvent(new Error(`Sprite \"${id}\" doesn't exists on this map.`)));\n return;\n }\n\n if (this._spritesImagesIds[id]) {\n for (const imageId of this._spritesImagesIds[id]) {\n this.imageManager.removeImage(imageId);\n this._changedImages[imageId] = true;\n }\n }\n\n internalSpriteRepresentation.splice(internalSpriteRepresentation.findIndex(sprite => sprite.id === id), 1);\n this.stylesheet.sprite = internalSpriteRepresentation.length > 0 ? internalSpriteRepresentation : undefined;\n\n delete this._spritesImagesIds[id];\n this._availableImages = this.imageManager.listImages();\n this._changed = true;\n this.dispatcher.broadcast(MessageType.setImages, this._availableImages);\n this.fire(new Event('data', {dataType: 'style'}));\n }\n\n /**\n * Get the current sprite value.\n *\n * @returns empty array when no sprite is set; id-url pairs otherwise\n */\n getSprite() {\n return coerceSpriteToArray(this.stylesheet.sprite);\n }\n\n /**\n * Set a new value for the style's sprite.\n *\n * @param sprite - new sprite value\n * @param options - style setter options\n * @param completion - the completion handler\n */\n setSprite(sprite: SpriteSpecification, options: StyleSetterOptions = {}, completion?: (err: Error) => void) {\n this._checkLoaded();\n\n if (sprite && this._validate(validateStyle.sprite, 'sprite', sprite, null, options)) {\n return;\n }\n\n this.stylesheet.sprite = sprite;\n\n if (sprite) {\n this._loadSprite(sprite, true, completion);\n } else {\n this._unloadSprite();\n if (completion) {\n completion(null);\n }\n }\n }\n}\n","import {createLayout} from '../util/struct_array';\n\nexport default createLayout([\n {name: 'a_pos', type: 'Int16', components: 2}\n]);\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform vec4 u_color;uniform float u_opacity;void main() {gl_FragColor=u_color*u_opacity;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'attribute vec2 a_pos;uniform mat4 u_matrix;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform vec2 u_pattern_tl_a;uniform vec2 u_pattern_br_a;uniform vec2 u_pattern_tl_b;uniform vec2 u_pattern_br_b;uniform vec2 u_texsize;uniform float u_mix;uniform float u_opacity;uniform sampler2D u_image;varying vec2 v_pos_a;varying vec2 v_pos_b;void main() {vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(u_pattern_tl_a/u_texsize,u_pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(u_pattern_tl_b/u_texsize,u_pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);gl_FragColor=mix(color1,color2,u_mix)*u_opacity;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform mat4 u_matrix;uniform vec2 u_pattern_size_a;uniform vec2 u_pattern_size_b;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform float u_scale_a;uniform float u_scale_b;uniform float u_tile_units_to_pixels;attribute vec2 a_pos;varying vec2 v_pos_a;varying vec2 v_pos_b;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,u_scale_a*u_pattern_size_a,u_tile_units_to_pixels,a_pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,u_scale_b*u_pattern_size_b,u_tile_units_to_pixels,a_pos);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'varying vec3 v_data;varying float v_visibility;\\n#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define mediump float radius\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define highp vec4 stroke_color\\n#pragma mapbox: define mediump float stroke_width\\n#pragma mapbox: define lowp float stroke_opacity\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize mediump float radius\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize highp vec4 stroke_color\\n#pragma mapbox: initialize mediump float stroke_width\\n#pragma mapbox: initialize lowp float stroke_opacity\\nvec2 extrude=v_data.xy;float extrude_length=length(extrude);float antialiased_blur=v_data.z;float opacity_t=smoothstep(0.0,antialiased_blur,extrude_length-1.0);float color_t=stroke_width < 0.01 ? 0.0 : smoothstep(antialiased_blur,0.0,extrude_length-radius/(radius+stroke_width));gl_FragColor=v_visibility*opacity_t*mix(color*opacity,stroke_color*stroke_opacity,color_t);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform mat4 u_matrix;uniform bool u_scale_with_map;uniform bool u_pitch_with_map;uniform vec2 u_extrude_scale;uniform lowp float u_device_pixel_ratio;uniform highp float u_camera_to_center_distance;attribute vec2 a_pos;varying vec3 v_data;varying float v_visibility;\\n#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define mediump float radius\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define highp vec4 stroke_color\\n#pragma mapbox: define mediump float stroke_width\\n#pragma mapbox: define lowp float stroke_opacity\\nvoid main(void) {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize mediump float radius\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize highp vec4 stroke_color\\n#pragma mapbox: initialize mediump float stroke_width\\n#pragma mapbox: initialize lowp float stroke_opacity\\nvec2 extrude=vec2(mod(a_pos,2.0)*2.0-1.0);vec2 circle_center=floor(a_pos*0.5);float ele=get_elevation(circle_center);v_visibility=calculate_visibility(u_matrix*vec4(circle_center,ele,1.0));if (u_pitch_with_map) {vec2 corner_position=circle_center;if (u_scale_with_map) {corner_position+=extrude*(radius+stroke_width)*u_extrude_scale;} else {vec4 projected_center=u_matrix*vec4(circle_center,0,1);corner_position+=extrude*(radius+stroke_width)*u_extrude_scale*(projected_center.w/u_camera_to_center_distance);}gl_Position=u_matrix*vec4(corner_position,ele,1);} else {gl_Position=u_matrix*vec4(circle_center,ele,1);if (u_scale_with_map) {gl_Position.xy+=extrude*(radius+stroke_width)*u_extrude_scale*u_camera_to_center_distance;} else {gl_Position.xy+=extrude*(radius+stroke_width)*u_extrude_scale*gl_Position.w;}}float antialiasblur=-max(1.0/u_device_pixel_ratio/(radius+stroke_width),blur);v_data=vec3(extrude.x,extrude.y,antialiasblur);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'void main() {gl_FragColor=vec4(1.0);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'attribute vec2 a_pos;uniform mat4 u_matrix;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform highp float u_intensity;varying vec2 v_extrude;\\n#pragma mapbox: define highp float weight\\n#define GAUSS_COEF 0.3989422804014327\\nvoid main() {\\n#pragma mapbox: initialize highp float weight\\nfloat d=-0.5*3.0*3.0*dot(v_extrude,v_extrude);float val=weight*u_intensity*GAUSS_COEF*exp(d);gl_FragColor=vec4(val,1.0,1.0,1.0);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform mat4 u_matrix;uniform float u_extrude_scale;uniform float u_opacity;uniform float u_intensity;attribute vec2 a_pos;varying vec2 v_extrude;\\n#pragma mapbox: define highp float weight\\n#pragma mapbox: define mediump float radius\\nconst highp float ZERO=1.0/255.0/16.0;\\n#define GAUSS_COEF 0.3989422804014327\\nvoid main(void) {\\n#pragma mapbox: initialize highp float weight\\n#pragma mapbox: initialize mediump float radius\\nvec2 unscaled_extrude=vec2(mod(a_pos,2.0)*2.0-1.0);float S=sqrt(-2.0*log(ZERO/weight/u_intensity/GAUSS_COEF))/3.0;v_extrude=S*unscaled_extrude;vec2 extrude=v_extrude*radius*u_extrude_scale;vec4 pos=vec4(floor(a_pos*0.5)+extrude,get_elevation(floor(a_pos*0.5)),1);gl_Position=u_matrix*pos;}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform sampler2D u_image;uniform sampler2D u_color_ramp;uniform float u_opacity;varying vec2 v_pos;void main() {float t=texture2D(u_image,v_pos).r;vec4 color=texture2D(u_color_ramp,vec2(t,0.5));gl_FragColor=color*u_opacity;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(0.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform mat4 u_matrix;uniform vec2 u_world;attribute vec2 a_pos;varying vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos*u_world,0,1);v_pos.x=a_pos.x;v_pos.y=1.0-a_pos.y;}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'varying float v_placed;varying float v_notUsed;void main() {float alpha=0.5;gl_FragColor=vec4(1.0,0.0,0.0,1.0)*alpha;if (v_placed > 0.5) {gl_FragColor=vec4(0.0,0.0,1.0,0.5)*alpha;}if (v_notUsed > 0.5) {gl_FragColor*=.1;}}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'attribute vec2 a_anchor_pos;attribute vec2 a_placed;attribute vec2 a_box_real;uniform mat4 u_matrix;uniform vec2 u_pixel_extrude_scale;varying float v_placed;varying float v_notUsed;vec4 projectTileWithElevation(vec2 posInTile,float elevation) {return u_matrix*vec4(posInTile,elevation,1.0);}void main() {gl_Position=projectTileWithElevation(a_anchor_pos,get_elevation(a_anchor_pos));gl_Position.xy=((a_box_real+0.5)*u_pixel_extrude_scale*2.0-1.0)*vec2(1.0,-1.0)*gl_Position.w;if (gl_Position.z/gl_Position.w < 1.1) {gl_Position.z=0.5;}v_placed=a_placed.x;v_notUsed=a_placed.y;}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'varying float v_radius;varying vec2 v_extrude;varying float v_perspective_ratio;varying float v_collision;void main() {float alpha=0.5*min(v_perspective_ratio,1.0);float stroke_radius=0.9*max(v_perspective_ratio,1.0);float distance_to_center=length(v_extrude);float distance_to_edge=abs(distance_to_center-v_radius);float opacity_t=smoothstep(-stroke_radius,0.0,-distance_to_edge);vec4 color=mix(vec4(0.0,0.0,1.0,0.5),vec4(1.0,0.0,0.0,1.0),v_collision);gl_FragColor=color*alpha*opacity_t;}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'attribute vec2 a_pos;attribute float a_radius;attribute vec2 a_flags;uniform mat4 u_matrix;uniform mat4 u_inv_matrix;uniform vec2 u_viewport_size;uniform float u_camera_to_center_distance;varying float v_radius;varying vec2 v_extrude;varying float v_perspective_ratio;varying float v_collision;vec3 toTilePosition(vec2 screenPos) {vec4 rayStart=u_inv_matrix*vec4(screenPos,-1.0,1.0);vec4 rayEnd =u_inv_matrix*vec4(screenPos, 1.0,1.0);rayStart.xyz/=rayStart.w;rayEnd.xyz /=rayEnd.w;highp float t=(0.0-rayStart.z)/(rayEnd.z-rayStart.z);return mix(rayStart.xyz,rayEnd.xyz,t);}void main() {vec2 quadCenterPos=a_pos;float radius=a_radius;float collision=a_flags.x;float vertexIdx=a_flags.y;vec2 quadVertexOffset=vec2(mix(-1.0,1.0,float(vertexIdx >=2.0)),mix(-1.0,1.0,float(vertexIdx >=1.0 && vertexIdx <=2.0)));vec2 quadVertexExtent=quadVertexOffset*radius;vec3 tilePos=toTilePosition(quadCenterPos);vec4 clipPos=u_matrix*vec4(tilePos,1.0);highp float camera_to_anchor_distance=clipPos.w;highp float collision_perspective_ratio=clamp(0.5+0.5*(u_camera_to_center_distance/camera_to_anchor_distance),0.0,4.0);float padding_factor=1.2;v_radius=radius;v_extrude=quadVertexExtent*padding_factor;v_perspective_ratio=collision_perspective_ratio;v_collision=collision;gl_Position=vec4(clipPos.xyz/clipPos.w,1.0)+vec4(quadVertexExtent*padding_factor/u_viewport_size*2.0,0.0,0.0);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform highp vec4 u_color;uniform sampler2D u_overlay;varying vec2 v_uv;void main() {vec4 overlay_color=texture2D(u_overlay,v_uv);gl_FragColor=mix(u_color,overlay_color,overlay_color.a);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'attribute vec2 a_pos;varying vec2 v_uv;uniform mat4 u_matrix;uniform float u_overlay_scale;void main() {v_uv=a_pos/8192.0;gl_Position=u_matrix*vec4(a_pos*u_overlay_scale,get_elevation(a_pos),1);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default '#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize lowp float opacity\\ngl_FragColor=color*opacity;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'attribute vec2 a_pos;uniform mat4 u_matrix;\\n#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize lowp float opacity\\ngl_Position=u_matrix*vec4(a_pos,0,1);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'varying vec2 v_pos;\\n#pragma mapbox: define highp vec4 outline_color\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 outline_color\\n#pragma mapbox: initialize lowp float opacity\\nfloat dist=length(v_pos-gl_FragCoord.xy);float alpha=1.0-smoothstep(0.0,1.0,dist);gl_FragColor=outline_color*(alpha*opacity);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'attribute vec2 a_pos;uniform mat4 u_matrix;uniform vec2 u_world;varying vec2 v_pos;\\n#pragma mapbox: define highp vec4 outline_color\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 outline_color\\n#pragma mapbox: initialize lowp float opacity\\ngl_Position=u_matrix*vec4(a_pos,0,1);v_pos=(gl_Position.xy/gl_Position.w+1.0)/2.0*u_world;}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform vec2 u_texsize;uniform sampler2D u_image;uniform float u_fade;varying vec2 v_pos_a;varying vec2 v_pos_b;varying vec2 v_pos;\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\nvoid main() {\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(pattern_tl_a/u_texsize,pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(pattern_tl_b/u_texsize,pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);float dist=length(v_pos-gl_FragCoord.xy);float alpha=1.0-smoothstep(0.0,1.0,dist);gl_FragColor=mix(color1,color2,u_fade)*alpha*opacity;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform mat4 u_matrix;uniform vec2 u_world;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform vec3 u_scale;attribute vec2 a_pos;varying vec2 v_pos_a;varying vec2 v_pos_b;varying vec2 v_pos;\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\n#pragma mapbox: define lowp float pixel_ratio_from\\n#pragma mapbox: define lowp float pixel_ratio_to\\nvoid main() {\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\n#pragma mapbox: initialize lowp float pixel_ratio_from\\n#pragma mapbox: initialize lowp float pixel_ratio_to\\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;gl_Position=u_matrix*vec4(a_pos,0,1);vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,fromScale*display_size_a,tileRatio,a_pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,toScale*display_size_b,tileRatio,a_pos);v_pos=(gl_Position.xy/gl_Position.w+1.0)/2.0*u_world;}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default '#ifdef GL_ES\\nprecision highp float;\\n#endif\\nuniform vec2 u_texsize;uniform float u_fade;uniform sampler2D u_image;varying vec2 v_pos_a;varying vec2 v_pos_b;\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\nvoid main() {\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(pattern_tl_a/u_texsize,pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(pattern_tl_b/u_texsize,pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);gl_FragColor=mix(color1,color2,u_fade)*opacity;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform mat4 u_matrix;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform vec3 u_scale;attribute vec2 a_pos;varying vec2 v_pos_a;varying vec2 v_pos_b;\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\n#pragma mapbox: define lowp float pixel_ratio_from\\n#pragma mapbox: define lowp float pixel_ratio_to\\nvoid main() {\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\n#pragma mapbox: initialize lowp float pixel_ratio_from\\n#pragma mapbox: initialize lowp float pixel_ratio_to\\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileZoomRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;gl_Position=u_matrix*vec4(a_pos,0,1);v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,fromScale*display_size_a,tileZoomRatio,a_pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,toScale*display_size_b,tileZoomRatio,a_pos);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'varying vec4 v_color;void main() {gl_FragColor=v_color;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform mat4 u_matrix;uniform vec3 u_lightcolor;uniform lowp vec3 u_lightpos;uniform lowp float u_lightintensity;uniform float u_vertical_gradient;uniform lowp float u_opacity;attribute vec2 a_pos;attribute vec4 a_normal_ed;\\n#ifdef TERRAIN3D\\nattribute vec2 a_centroid;\\n#endif\\nvarying vec4 v_color;\\n#pragma mapbox: define highp float base\\n#pragma mapbox: define highp float height\\n#pragma mapbox: define highp vec4 color\\nvoid main() {\\n#pragma mapbox: initialize highp float base\\n#pragma mapbox: initialize highp float height\\n#pragma mapbox: initialize highp vec4 color\\nvec3 normal=a_normal_ed.xyz;\\n#ifdef TERRAIN3D\\nfloat height_terrain3d_offset=get_elevation(a_centroid);float base_terrain3d_offset=height_terrain3d_offset-(base > 0.0 ? 0.0 : 10.0);\\n#else\\nfloat height_terrain3d_offset=0.0;float base_terrain3d_offset=0.0;\\n#endif\\nbase=max(0.0,base)+base_terrain3d_offset;height=max(0.0,height)+height_terrain3d_offset;float t=mod(normal.x,2.0);gl_Position=u_matrix*vec4(a_pos,t > 0.0 ? height : base,1);float colorvalue=color.r*0.2126+color.g*0.7152+color.b*0.0722;v_color=vec4(0.0,0.0,0.0,1.0);vec4 ambientlight=vec4(0.03,0.03,0.03,1.0);color+=ambientlight;float directional=clamp(dot(normal/16384.0,u_lightpos),0.0,1.0);directional=mix((1.0-u_lightintensity),max((1.0-colorvalue+u_lightintensity),1.0),directional);if (normal.y !=0.0) {directional*=((1.0-u_vertical_gradient)+(u_vertical_gradient*clamp((t+base)*pow(height/150.0,0.5),mix(0.7,0.98,1.0-u_lightintensity),1.0)));}v_color.r+=clamp(color.r*directional*u_lightcolor.r,mix(0.0,0.3,1.0-u_lightcolor.r),1.0);v_color.g+=clamp(color.g*directional*u_lightcolor.g,mix(0.0,0.3,1.0-u_lightcolor.g),1.0);v_color.b+=clamp(color.b*directional*u_lightcolor.b,mix(0.0,0.3,1.0-u_lightcolor.b),1.0);v_color*=u_opacity;}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform vec2 u_texsize;uniform float u_fade;uniform sampler2D u_image;varying vec2 v_pos_a;varying vec2 v_pos_b;varying vec4 v_lighting;\\n#pragma mapbox: define lowp float base\\n#pragma mapbox: define lowp float height\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\n#pragma mapbox: define lowp float pixel_ratio_from\\n#pragma mapbox: define lowp float pixel_ratio_to\\nvoid main() {\\n#pragma mapbox: initialize lowp float base\\n#pragma mapbox: initialize lowp float height\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\n#pragma mapbox: initialize lowp float pixel_ratio_from\\n#pragma mapbox: initialize lowp float pixel_ratio_to\\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(pattern_tl_a/u_texsize,pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(pattern_tl_b/u_texsize,pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);vec4 mixedColor=mix(color1,color2,u_fade);gl_FragColor=mixedColor*v_lighting;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform mat4 u_matrix;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform float u_height_factor;uniform vec3 u_scale;uniform float u_vertical_gradient;uniform lowp float u_opacity;uniform vec3 u_lightcolor;uniform lowp vec3 u_lightpos;uniform lowp float u_lightintensity;attribute vec2 a_pos;attribute vec4 a_normal_ed;\\n#ifdef TERRAIN3D\\nattribute vec2 a_centroid;\\n#endif\\nvarying vec2 v_pos_a;varying vec2 v_pos_b;varying vec4 v_lighting;\\n#pragma mapbox: define lowp float base\\n#pragma mapbox: define lowp float height\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\n#pragma mapbox: define lowp float pixel_ratio_from\\n#pragma mapbox: define lowp float pixel_ratio_to\\nvoid main() {\\n#pragma mapbox: initialize lowp float base\\n#pragma mapbox: initialize lowp float height\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\n#pragma mapbox: initialize lowp float pixel_ratio_from\\n#pragma mapbox: initialize lowp float pixel_ratio_to\\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;vec3 normal=a_normal_ed.xyz;float edgedistance=a_normal_ed.w;vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;\\n#ifdef TERRAIN3D\\nfloat height_terrain3d_offset=get_elevation(a_centroid);float base_terrain3d_offset=height_terrain3d_offset-(base > 0.0 ? 0.0 : 10.0);\\n#else\\nfloat height_terrain3d_offset=0.0;float base_terrain3d_offset=0.0;\\n#endif\\nbase=max(0.0,base)+base_terrain3d_offset;height=max(0.0,height)+height_terrain3d_offset;float t=mod(normal.x,2.0);float z=t > 0.0 ? height : base;gl_Position=u_matrix*vec4(a_pos,z,1);vec2 pos=normal.x==1.0 && normal.y==0.0 && normal.z==16384.0\\n? a_pos\\n: vec2(edgedistance,z*u_height_factor);v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,fromScale*display_size_a,tileRatio,pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,toScale*display_size_b,tileRatio,pos);v_lighting=vec4(0.0,0.0,0.0,1.0);float directional=clamp(dot(normal/16383.0,u_lightpos),0.0,1.0);directional=mix((1.0-u_lightintensity),max((0.5+u_lightintensity),1.0),directional);if (normal.y !=0.0) {directional*=((1.0-u_vertical_gradient)+(u_vertical_gradient*clamp((t+base)*pow(height/150.0,0.5),mix(0.7,0.98,1.0-u_lightintensity),1.0)));}v_lighting.rgb+=clamp(directional*u_lightcolor,mix(vec3(0.0),vec3(0.3),1.0-u_lightcolor),vec3(1.0));v_lighting*=u_opacity;}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default '#ifdef GL_ES\\nprecision highp float;\\n#endif\\nuniform sampler2D u_image;varying vec2 v_pos;uniform vec2 u_dimension;uniform float u_zoom;uniform vec4 u_unpack;float getElevation(vec2 coord,float bias) {vec4 data=texture2D(u_image,coord)*255.0;data.a=-1.0;return dot(data,u_unpack)/4.0;}void main() {vec2 epsilon=1.0/u_dimension;float a=getElevation(v_pos+vec2(-epsilon.x,-epsilon.y),0.0);float b=getElevation(v_pos+vec2(0,-epsilon.y),0.0);float c=getElevation(v_pos+vec2(epsilon.x,-epsilon.y),0.0);float d=getElevation(v_pos+vec2(-epsilon.x,0),0.0);float e=getElevation(v_pos,0.0);float f=getElevation(v_pos+vec2(epsilon.x,0),0.0);float g=getElevation(v_pos+vec2(-epsilon.x,epsilon.y),0.0);float h=getElevation(v_pos+vec2(0,epsilon.y),0.0);float i=getElevation(v_pos+vec2(epsilon.x,epsilon.y),0.0);float exaggerationFactor=u_zoom < 2.0 ? 0.4 : u_zoom < 4.5 ? 0.35 : 0.3;float exaggeration=u_zoom < 15.0 ? (u_zoom-15.0)*exaggerationFactor : 0.0;vec2 deriv=vec2((c+f+f+i)-(a+d+d+g),(g+h+h+i)-(a+b+b+c))/pow(2.0,exaggeration+(19.2562-u_zoom));gl_FragColor=clamp(vec4(deriv.x/2.0+0.5,deriv.y/2.0+0.5,1.0,1.0),0.0,1.0);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform mat4 u_matrix;uniform vec2 u_dimension;attribute vec2 a_pos;attribute vec2 a_texture_pos;varying vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);highp vec2 epsilon=1.0/u_dimension;float scale=(u_dimension.x-2.0)/u_dimension.x;v_pos=(a_texture_pos/8192.0)*scale+epsilon;}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform sampler2D u_image;varying vec2 v_pos;uniform vec2 u_latrange;uniform vec2 u_light;uniform vec4 u_shadow;uniform vec4 u_highlight;uniform vec4 u_accent;\\n#define PI 3.141592653589793\\nvoid main() {vec4 pixel=texture2D(u_image,v_pos);vec2 deriv=((pixel.rg*2.0)-1.0);float scaleFactor=cos(radians((u_latrange[0]-u_latrange[1])*(1.0-v_pos.y)+u_latrange[1]));float slope=atan(1.25*length(deriv)/scaleFactor);float aspect=deriv.x !=0.0 ? atan(deriv.y,-deriv.x) : PI/2.0*(deriv.y > 0.0 ? 1.0 :-1.0);float intensity=u_light.x;float azimuth=u_light.y+PI;float base=1.875-intensity*1.75;float maxValue=0.5*PI;float scaledSlope=intensity !=0.5 ? ((pow(base,slope)-1.0)/(pow(base,maxValue)-1.0))*maxValue : slope;float accent=cos(scaledSlope);vec4 accent_color=(1.0-accent)*u_accent*clamp(intensity*2.0,0.0,1.0);float shade=abs(mod((aspect+azimuth)/PI+0.5,2.0)-1.0);vec4 shade_color=mix(u_shadow,u_highlight,shade)*sin(scaledSlope)*clamp(intensity*2.0,0.0,1.0);gl_FragColor=accent_color*(1.0-shade_color.a)+shade_color;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform mat4 u_matrix;attribute vec2 a_pos;attribute vec2 a_texture_pos;varying vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);v_pos=a_texture_pos/8192.0;}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform lowp float u_device_pixel_ratio;varying vec2 v_width2;varying vec2 v_normal;varying float v_gamma_scale;\\n#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\nfloat dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);gl_FragColor=color*(alpha*opacity);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default '\\n#define scale 0.015873016\\nattribute vec2 a_pos_normal;attribute vec4 a_data;uniform mat4 u_matrix;uniform mediump float u_ratio;uniform vec2 u_units_to_pixels;uniform lowp float u_device_pixel_ratio;varying vec2 v_normal;varying vec2 v_width2;varying float v_gamma_scale;varying highp float v_linesofar;\\n#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define mediump float gapwidth\\n#pragma mapbox: define lowp float offset\\n#pragma mapbox: define mediump float width\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump float gapwidth\\n#pragma mapbox: initialize lowp float offset\\n#pragma mapbox: initialize mediump float width\\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;v_linesofar=(floor(a_data.z/4.0)+a_data.w*64.0)*2.0;vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;\\n#ifdef TERRAIN3D\\nv_gamma_scale=1.0;\\n#else\\nfloat extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;\\n#endif\\nv_width2=vec2(outset,inset);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform lowp float u_device_pixel_ratio;uniform sampler2D u_image;varying vec2 v_width2;varying vec2 v_normal;varying float v_gamma_scale;varying highp vec2 v_uv;\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\nfloat dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);vec4 color=texture2D(u_image,v_uv);gl_FragColor=color*(alpha*opacity);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default '\\n#define scale 0.015873016\\nattribute vec2 a_pos_normal;attribute vec4 a_data;attribute float a_uv_x;attribute float a_split_index;uniform mat4 u_matrix;uniform mediump float u_ratio;uniform lowp float u_device_pixel_ratio;uniform vec2 u_units_to_pixels;uniform float u_image_height;varying vec2 v_normal;varying vec2 v_width2;varying float v_gamma_scale;varying highp vec2 v_uv;\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define mediump float gapwidth\\n#pragma mapbox: define lowp float offset\\n#pragma mapbox: define mediump float width\\nvoid main() {\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump float gapwidth\\n#pragma mapbox: initialize lowp float offset\\n#pragma mapbox: initialize mediump float width\\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;highp float texel_height=1.0/u_image_height;highp float half_texel_height=0.5*texel_height;v_uv=vec2(a_uv_x,a_split_index*texel_height-half_texel_height);vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;\\n#ifdef TERRAIN3D\\nv_gamma_scale=1.0;\\n#else\\nfloat extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;\\n#endif\\nv_width2=vec2(outset,inset);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default '#ifdef GL_ES\\nprecision highp float;\\n#endif\\nuniform lowp float u_device_pixel_ratio;uniform vec2 u_texsize;uniform float u_fade;uniform mediump vec3 u_scale;uniform sampler2D u_image;varying vec2 v_normal;varying vec2 v_width2;varying float v_linesofar;varying float v_gamma_scale;varying float v_width;\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\n#pragma mapbox: define lowp float pixel_ratio_from\\n#pragma mapbox: define lowp float pixel_ratio_to\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\n#pragma mapbox: initialize lowp float pixel_ratio_from\\n#pragma mapbox: initialize lowp float pixel_ratio_to\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileZoomRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;vec2 pattern_size_a=vec2(display_size_a.x*fromScale/tileZoomRatio,display_size_a.y);vec2 pattern_size_b=vec2(display_size_b.x*toScale/tileZoomRatio,display_size_b.y);float aspect_a=display_size_a.y/v_width;float aspect_b=display_size_b.y/v_width;float dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);float x_a=mod(v_linesofar/pattern_size_a.x*aspect_a,1.0);float x_b=mod(v_linesofar/pattern_size_b.x*aspect_b,1.0);float y=0.5*v_normal.y+0.5;vec2 texel_size=1.0/u_texsize;vec2 pos_a=mix(pattern_tl_a*texel_size-texel_size,pattern_br_a*texel_size+texel_size,vec2(x_a,y));vec2 pos_b=mix(pattern_tl_b*texel_size-texel_size,pattern_br_b*texel_size+texel_size,vec2(x_b,y));vec4 color=mix(texture2D(u_image,pos_a),texture2D(u_image,pos_b),u_fade);gl_FragColor=color*alpha*opacity;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default '\\n#define scale 0.015873016\\n#define LINE_DISTANCE_SCALE 2.0\\nattribute vec2 a_pos_normal;attribute vec4 a_data;uniform mat4 u_matrix;uniform vec2 u_units_to_pixels;uniform mediump float u_ratio;uniform lowp float u_device_pixel_ratio;varying vec2 v_normal;varying vec2 v_width2;varying float v_linesofar;varying float v_gamma_scale;varying float v_width;\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp float offset\\n#pragma mapbox: define mediump float gapwidth\\n#pragma mapbox: define mediump float width\\n#pragma mapbox: define lowp float floorwidth\\n#pragma mapbox: define lowp vec4 pattern_from\\n#pragma mapbox: define lowp vec4 pattern_to\\n#pragma mapbox: define lowp float pixel_ratio_from\\n#pragma mapbox: define lowp float pixel_ratio_to\\nvoid main() {\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize lowp float offset\\n#pragma mapbox: initialize mediump float gapwidth\\n#pragma mapbox: initialize mediump float width\\n#pragma mapbox: initialize lowp float floorwidth\\n#pragma mapbox: initialize mediump vec4 pattern_from\\n#pragma mapbox: initialize mediump vec4 pattern_to\\n#pragma mapbox: initialize lowp float pixel_ratio_from\\n#pragma mapbox: initialize lowp float pixel_ratio_to\\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;float a_linesofar=(floor(a_data.z/4.0)+a_data.w*64.0)*LINE_DISTANCE_SCALE;vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;\\n#ifdef TERRAIN3D\\nv_gamma_scale=1.0;\\n#else\\nfloat extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;\\n#endif\\nv_linesofar=a_linesofar;v_width2=vec2(outset,inset);v_width=floorwidth;}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform lowp float u_device_pixel_ratio;uniform sampler2D u_image;uniform float u_sdfgamma;uniform float u_mix;varying vec2 v_normal;varying vec2 v_width2;varying vec2 v_tex_a;varying vec2 v_tex_b;varying float v_gamma_scale;\\n#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define mediump float width\\n#pragma mapbox: define lowp float floorwidth\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump float width\\n#pragma mapbox: initialize lowp float floorwidth\\nfloat dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);float sdfdist_a=texture2D(u_image,v_tex_a).a;float sdfdist_b=texture2D(u_image,v_tex_b).a;float sdfdist=mix(sdfdist_a,sdfdist_b,u_mix);alpha*=smoothstep(0.5-u_sdfgamma/floorwidth,0.5+u_sdfgamma/floorwidth,sdfdist);gl_FragColor=color*(alpha*opacity);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default '\\n#define scale 0.015873016\\n#define LINE_DISTANCE_SCALE 2.0\\nattribute vec2 a_pos_normal;attribute vec4 a_data;uniform mat4 u_matrix;uniform mediump float u_ratio;uniform lowp float u_device_pixel_ratio;uniform vec2 u_patternscale_a;uniform float u_tex_y_a;uniform vec2 u_patternscale_b;uniform float u_tex_y_b;uniform vec2 u_units_to_pixels;varying vec2 v_normal;varying vec2 v_width2;varying vec2 v_tex_a;varying vec2 v_tex_b;varying float v_gamma_scale;\\n#pragma mapbox: define highp vec4 color\\n#pragma mapbox: define lowp float blur\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define mediump float gapwidth\\n#pragma mapbox: define lowp float offset\\n#pragma mapbox: define mediump float width\\n#pragma mapbox: define lowp float floorwidth\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 color\\n#pragma mapbox: initialize lowp float blur\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize mediump float gapwidth\\n#pragma mapbox: initialize lowp float offset\\n#pragma mapbox: initialize mediump float width\\n#pragma mapbox: initialize lowp float floorwidth\\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;float a_linesofar=(floor(a_data.z/4.0)+a_data.w*64.0)*LINE_DISTANCE_SCALE;vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;\\n#ifdef TERRAIN3D\\nv_gamma_scale=1.0;\\n#else\\nfloat extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;\\n#endif\\nv_tex_a=vec2(a_linesofar*u_patternscale_a.x/floorwidth,normal.y*u_patternscale_a.y+u_tex_y_a);v_tex_b=vec2(a_linesofar*u_patternscale_b.x/floorwidth,normal.y*u_patternscale_b.y+u_tex_y_b);v_width2=vec2(outset,inset);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform float u_fade_t;uniform float u_opacity;uniform sampler2D u_image0;uniform sampler2D u_image1;varying vec2 v_pos0;varying vec2 v_pos1;uniform float u_brightness_low;uniform float u_brightness_high;uniform float u_saturation_factor;uniform float u_contrast_factor;uniform vec3 u_spin_weights;void main() {vec4 color0=texture2D(u_image0,v_pos0);vec4 color1=texture2D(u_image1,v_pos1);if (color0.a > 0.0) {color0.rgb=color0.rgb/color0.a;}if (color1.a > 0.0) {color1.rgb=color1.rgb/color1.a;}vec4 color=mix(color0,color1,u_fade_t);color.a*=u_opacity;vec3 rgb=color.rgb;rgb=vec3(dot(rgb,u_spin_weights.xyz),dot(rgb,u_spin_weights.zxy),dot(rgb,u_spin_weights.yzx));float average=(color.r+color.g+color.b)/3.0;rgb+=(average-rgb)*u_saturation_factor;rgb=(rgb-0.5)*u_contrast_factor+0.5;vec3 u_high_vec=vec3(u_brightness_low,u_brightness_low,u_brightness_low);vec3 u_low_vec=vec3(u_brightness_high,u_brightness_high,u_brightness_high);gl_FragColor=vec4(mix(u_high_vec,u_low_vec,rgb)*color.a,color.a);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform mat4 u_matrix;uniform vec2 u_tl_parent;uniform float u_scale_parent;uniform float u_buffer_scale;attribute vec2 a_pos;attribute vec2 a_texture_pos;varying vec2 v_pos0;varying vec2 v_pos1;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);v_pos0=(((a_texture_pos/8192.0)-0.5)/u_buffer_scale )+0.5;v_pos1=(v_pos0*u_scale_parent)+u_tl_parent;}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform sampler2D u_texture;varying vec2 v_tex;varying float v_fade_opacity;\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize lowp float opacity\\nlowp float alpha=opacity*v_fade_opacity;gl_FragColor=texture2D(u_texture,v_tex)*alpha;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'attribute vec4 a_pos_offset;attribute vec4 a_data;attribute vec4 a_pixeloffset;attribute vec3 a_projected_pos;attribute float a_fade_opacity;uniform bool u_is_size_zoom_constant;uniform bool u_is_size_feature_constant;uniform highp float u_size_t;uniform highp float u_size;uniform highp float u_camera_to_center_distance;uniform highp float u_pitch;uniform bool u_rotate_symbol;uniform highp float u_aspect_ratio;uniform float u_fade_change;uniform mat4 u_matrix;uniform mat4 u_label_plane_matrix;uniform mat4 u_coord_matrix;uniform bool u_is_text;uniform bool u_pitch_with_map;uniform vec2 u_texsize;uniform bool u_is_along_line;uniform bool u_is_variable_anchor;uniform vec2 u_translation;uniform float u_pitched_scale;varying vec2 v_tex;varying float v_fade_opacity;vec4 projectTileWithElevation(vec2 posInTile,float elevation) {return u_matrix*vec4(posInTile,elevation,1.0);}\\n#pragma mapbox: define lowp float opacity\\nvoid main() {\\n#pragma mapbox: initialize lowp float opacity\\nvec2 a_pos=a_pos_offset.xy;vec2 a_offset=a_pos_offset.zw;vec2 a_tex=a_data.xy;vec2 a_size=a_data.zw;float a_size_min=floor(a_size[0]*0.5);vec2 a_pxoffset=a_pixeloffset.xy;vec2 a_minFontScale=a_pixeloffset.zw/256.0;float ele=get_elevation(a_pos);highp float segment_angle=-a_projected_pos[2];float size;if (!u_is_size_zoom_constant && !u_is_size_feature_constant) {size=mix(a_size_min,a_size[1],u_size_t)/128.0;} else if (u_is_size_zoom_constant && !u_is_size_feature_constant) {size=a_size_min/128.0;} else {size=u_size;}vec2 translated_a_pos=a_pos+u_translation;vec4 projectedPoint=projectTileWithElevation(translated_a_pos,ele);highp float camera_to_anchor_distance=projectedPoint.w;highp float distance_ratio=u_pitch_with_map ?\\ncamera_to_anchor_distance/u_camera_to_center_distance :\\nu_camera_to_center_distance/camera_to_anchor_distance;highp float perspective_ratio=clamp(0.5+0.5*distance_ratio,0.0,4.0);size*=perspective_ratio;float fontScale=u_is_text ? size/24.0 : size;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetProjectedPoint=projectTileWithElevation(translated_a_pos+vec2(1,0),ele);vec2 a=projectedPoint.xy/projectedPoint.w;vec2 b=offsetProjectedPoint.xy/offsetProjectedPoint.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}highp float angle_sin=sin(segment_angle+symbol_rotation);highp float angle_cos=cos(segment_angle+symbol_rotation);mat2 rotation_matrix=mat2(angle_cos,-1.0*angle_sin,angle_sin,angle_cos);vec4 projected_pos;if (u_is_along_line || u_is_variable_anchor) {projected_pos=vec4(a_projected_pos.xy,ele,1.0);} else if (u_pitch_with_map) {projected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy+u_translation,ele,1.0);} else {projected_pos=u_label_plane_matrix*projectTileWithElevation(a_projected_pos.xy+u_translation,ele);}float z=float(u_pitch_with_map)*projected_pos.z/projected_pos.w;float projectionScaling=1.0;vec4 finalPos=u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+rotation_matrix*(a_offset/32.0*max(a_minFontScale,fontScale)+a_pxoffset/16.0)*projectionScaling,z,1.0);if(u_pitch_with_map) {finalPos=projectTileWithElevation(finalPos.xy,finalPos.z);}gl_Position=finalPos;v_tex=a_tex/u_texsize;vec2 fade_opacity=unpack_opacity(a_fade_opacity);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;float visibility=calculate_visibility(projectedPoint);v_fade_opacity=max(0.0,min(visibility,fade_opacity[0]+fade_change));}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default '#define SDF_PX 8.0\\nuniform bool u_is_halo;uniform sampler2D u_texture;uniform highp float u_gamma_scale;uniform lowp float u_device_pixel_ratio;uniform bool u_is_text;varying vec2 v_data0;varying vec3 v_data1;\\n#pragma mapbox: define highp vec4 fill_color\\n#pragma mapbox: define highp vec4 halo_color\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp float halo_width\\n#pragma mapbox: define lowp float halo_blur\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 fill_color\\n#pragma mapbox: initialize highp vec4 halo_color\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize lowp float halo_width\\n#pragma mapbox: initialize lowp float halo_blur\\nfloat EDGE_GAMMA=0.105/u_device_pixel_ratio;vec2 tex=v_data0.xy;float gamma_scale=v_data1.x;float size=v_data1.y;float fade_opacity=v_data1[2];float fontScale=u_is_text ? size/24.0 : size;lowp vec4 color=fill_color;highp float gamma=EDGE_GAMMA/(fontScale*u_gamma_scale);lowp float inner_edge=(256.0-64.0)/256.0;if (u_is_halo) {color=halo_color;gamma=(halo_blur*1.19/SDF_PX+EDGE_GAMMA)/(fontScale*u_gamma_scale);inner_edge=inner_edge+gamma*gamma_scale;}lowp float dist=texture2D(u_texture,tex).a;highp float gamma_scaled=gamma*gamma_scale;highp float alpha=smoothstep(inner_edge-gamma_scaled,inner_edge+gamma_scaled,dist);if (u_is_halo) {lowp float halo_edge=(6.0-halo_width/fontScale)/SDF_PX;alpha=min(smoothstep(halo_edge-gamma_scaled,halo_edge+gamma_scaled,dist),1.0-alpha);}gl_FragColor=color*(alpha*opacity*fade_opacity);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'attribute vec4 a_pos_offset;attribute vec4 a_data;attribute vec4 a_pixeloffset;attribute vec3 a_projected_pos;attribute float a_fade_opacity;uniform bool u_is_size_zoom_constant;uniform bool u_is_size_feature_constant;uniform highp float u_size_t;uniform highp float u_size;uniform mat4 u_matrix;uniform mat4 u_label_plane_matrix;uniform mat4 u_coord_matrix;uniform bool u_is_text;uniform bool u_pitch_with_map;uniform bool u_is_along_line;uniform bool u_is_variable_anchor;uniform highp float u_pitch;uniform bool u_rotate_symbol;uniform highp float u_aspect_ratio;uniform highp float u_camera_to_center_distance;uniform float u_fade_change;uniform vec2 u_texsize;uniform vec2 u_translation;uniform float u_pitched_scale;varying vec2 v_data0;varying vec3 v_data1;vec4 projectTileWithElevation(vec2 posInTile,float elevation) {return u_matrix*vec4(posInTile,elevation,1.0);}\\n#pragma mapbox: define highp vec4 fill_color\\n#pragma mapbox: define highp vec4 halo_color\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp float halo_width\\n#pragma mapbox: define lowp float halo_blur\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 fill_color\\n#pragma mapbox: initialize highp vec4 halo_color\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize lowp float halo_width\\n#pragma mapbox: initialize lowp float halo_blur\\nvec2 a_pos=a_pos_offset.xy;vec2 a_offset=a_pos_offset.zw;vec2 a_tex=a_data.xy;vec2 a_size=a_data.zw;float a_size_min=floor(a_size[0]*0.5);vec2 a_pxoffset=a_pixeloffset.xy;float ele=get_elevation(a_pos);highp float segment_angle=-a_projected_pos[2];float size;if (!u_is_size_zoom_constant && !u_is_size_feature_constant) {size=mix(a_size_min,a_size[1],u_size_t)/128.0;} else if (u_is_size_zoom_constant && !u_is_size_feature_constant) {size=a_size_min/128.0;} else {size=u_size;}vec2 translated_a_pos=a_pos+u_translation;vec4 projectedPoint=projectTileWithElevation(translated_a_pos,ele);highp float camera_to_anchor_distance=projectedPoint.w;highp float distance_ratio=u_pitch_with_map ?\\ncamera_to_anchor_distance/u_camera_to_center_distance :\\nu_camera_to_center_distance/camera_to_anchor_distance;highp float perspective_ratio=clamp(0.5+0.5*distance_ratio,0.0,4.0);size*=perspective_ratio;float fontScale=u_is_text ? size/24.0 : size;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetProjectedPoint=projectTileWithElevation(translated_a_pos+vec2(1,0),ele);vec2 a=projectedPoint.xy/projectedPoint.w;vec2 b=offsetProjectedPoint.xy/offsetProjectedPoint.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}highp float angle_sin=sin(segment_angle+symbol_rotation);highp float angle_cos=cos(segment_angle+symbol_rotation);mat2 rotation_matrix=mat2(angle_cos,-1.0*angle_sin,angle_sin,angle_cos);vec4 projected_pos;if (u_is_along_line || u_is_variable_anchor) {projected_pos=vec4(a_projected_pos.xy,ele,1.0);} else if (u_pitch_with_map) {projected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy+u_translation,ele,1.0);} else {projected_pos=u_label_plane_matrix*projectTileWithElevation(a_projected_pos.xy+u_translation,ele);}float z=float(u_pitch_with_map)*projected_pos.z/projected_pos.w;float projectionScaling=1.0;vec4 finalPos=u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+rotation_matrix*(a_offset/32.0*fontScale+a_pxoffset)*projectionScaling,z,1.0);if(u_pitch_with_map) {finalPos=projectTileWithElevation(finalPos.xy,finalPos.z);}float gamma_scale=finalPos.w;gl_Position=finalPos;vec2 fade_opacity=unpack_opacity(a_fade_opacity);float visibility=calculate_visibility(projectedPoint);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;float interpolated_fade_opacity=max(0.0,min(visibility,fade_opacity[0]+fade_change));v_data0=a_tex/u_texsize;v_data1=vec3(gamma_scale,size,interpolated_fade_opacity);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default '#define SDF_PX 8.0\\n#define SDF 1.0\\n#define ICON 0.0\\nuniform bool u_is_halo;uniform sampler2D u_texture;uniform sampler2D u_texture_icon;uniform highp float u_gamma_scale;uniform lowp float u_device_pixel_ratio;varying vec4 v_data0;varying vec4 v_data1;\\n#pragma mapbox: define highp vec4 fill_color\\n#pragma mapbox: define highp vec4 halo_color\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp float halo_width\\n#pragma mapbox: define lowp float halo_blur\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 fill_color\\n#pragma mapbox: initialize highp vec4 halo_color\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize lowp float halo_width\\n#pragma mapbox: initialize lowp float halo_blur\\nfloat fade_opacity=v_data1[2];if (v_data1.w==ICON) {vec2 tex_icon=v_data0.zw;lowp float alpha=opacity*fade_opacity;gl_FragColor=texture2D(u_texture_icon,tex_icon)*alpha;\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\nreturn;}vec2 tex=v_data0.xy;float EDGE_GAMMA=0.105/u_device_pixel_ratio;float gamma_scale=v_data1.x;float size=v_data1.y;float fontScale=size/24.0;lowp vec4 color=fill_color;highp float gamma=EDGE_GAMMA/(fontScale*u_gamma_scale);lowp float buff=(256.0-64.0)/256.0;if (u_is_halo) {color=halo_color;gamma=(halo_blur*1.19/SDF_PX+EDGE_GAMMA)/(fontScale*u_gamma_scale);buff=(6.0-halo_width/fontScale)/SDF_PX;}lowp float dist=texture2D(u_texture,tex).a;highp float gamma_scaled=gamma*gamma_scale;highp float alpha=smoothstep(buff-gamma_scaled,buff+gamma_scaled,dist);gl_FragColor=color*(alpha*opacity*fade_opacity);\\n#ifdef OVERDRAW_INSPECTOR\\ngl_FragColor=vec4(1.0);\\n#endif\\n}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'attribute vec4 a_pos_offset;attribute vec4 a_data;attribute vec3 a_projected_pos;attribute float a_fade_opacity;uniform bool u_is_size_zoom_constant;uniform bool u_is_size_feature_constant;uniform highp float u_size_t;uniform highp float u_size;uniform mat4 u_matrix;uniform mat4 u_label_plane_matrix;uniform mat4 u_coord_matrix;uniform bool u_is_text;uniform bool u_pitch_with_map;uniform highp float u_pitch;uniform bool u_rotate_symbol;uniform highp float u_aspect_ratio;uniform highp float u_camera_to_center_distance;uniform float u_fade_change;uniform vec2 u_texsize;uniform vec2 u_texsize_icon;uniform bool u_is_along_line;uniform bool u_is_variable_anchor;uniform vec2 u_translation;uniform float u_pitched_scale;varying vec4 v_data0;varying vec4 v_data1;vec4 projectTileWithElevation(vec2 posInTile,float elevation) {return u_matrix*vec4(posInTile,elevation,1.0);}\\n#pragma mapbox: define highp vec4 fill_color\\n#pragma mapbox: define highp vec4 halo_color\\n#pragma mapbox: define lowp float opacity\\n#pragma mapbox: define lowp float halo_width\\n#pragma mapbox: define lowp float halo_blur\\nvoid main() {\\n#pragma mapbox: initialize highp vec4 fill_color\\n#pragma mapbox: initialize highp vec4 halo_color\\n#pragma mapbox: initialize lowp float opacity\\n#pragma mapbox: initialize lowp float halo_width\\n#pragma mapbox: initialize lowp float halo_blur\\nvec2 a_pos=a_pos_offset.xy;vec2 a_offset=a_pos_offset.zw;vec2 a_tex=a_data.xy;vec2 a_size=a_data.zw;float a_size_min=floor(a_size[0]*0.5);float is_sdf=a_size[0]-2.0*a_size_min;float ele=get_elevation(a_pos);highp float segment_angle=-a_projected_pos[2];float size;if (!u_is_size_zoom_constant && !u_is_size_feature_constant) {size=mix(a_size_min,a_size[1],u_size_t)/128.0;} else if (u_is_size_zoom_constant && !u_is_size_feature_constant) {size=a_size_min/128.0;} else {size=u_size;}vec2 translated_a_pos=a_pos+u_translation;vec4 projectedPoint=projectTileWithElevation(translated_a_pos,ele);highp float camera_to_anchor_distance=projectedPoint.w;highp float distance_ratio=u_pitch_with_map ?\\ncamera_to_anchor_distance/u_camera_to_center_distance :\\nu_camera_to_center_distance/camera_to_anchor_distance;highp float perspective_ratio=clamp(0.5+0.5*distance_ratio,0.0,4.0);size*=perspective_ratio;float fontScale=size/24.0;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetProjectedPoint=projectTileWithElevation(translated_a_pos+vec2(1,0),ele);vec2 a=projectedPoint.xy/projectedPoint.w;vec2 b=offsetProjectedPoint.xy/offsetProjectedPoint.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}highp float angle_sin=sin(segment_angle+symbol_rotation);highp float angle_cos=cos(segment_angle+symbol_rotation);mat2 rotation_matrix=mat2(angle_cos,-1.0*angle_sin,angle_sin,angle_cos);vec4 projected_pos;if (u_is_along_line || u_is_variable_anchor) {projected_pos=vec4(a_projected_pos.xy,ele,1.0);} else if (u_pitch_with_map) {projected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy+u_translation,ele,1.0);} else {projected_pos=u_label_plane_matrix*projectTileWithElevation(a_projected_pos.xy+u_translation,ele);}float z=float(u_pitch_with_map)*projected_pos.z/projected_pos.w;float projectionScaling=1.0;vec4 finalPos=u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+rotation_matrix*(a_offset/32.0*fontScale)*projectionScaling,z,1.0);if(u_pitch_with_map) {finalPos=projectTileWithElevation(finalPos.xy,finalPos.z);}float gamma_scale=finalPos.w;gl_Position=finalPos;vec2 fade_opacity=unpack_opacity(a_fade_opacity);float visibility=calculate_visibility(projectedPoint);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;float interpolated_fade_opacity=max(0.0,min(visibility,fade_opacity[0]+fade_change));v_data0.xy=a_tex/u_texsize;v_data0.zw=a_tex/u_texsize_icon;v_data1=vec4(gamma_scale,size,interpolated_fade_opacity,is_sdf);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'varying float v_depth;const highp vec4 bitSh=vec4(256.*256.*256.,256.*256.,256.,1.);const highp vec4 bitMsk=vec4(0.,vec3(1./256.0));highp vec4 pack(highp float value) {highp vec4 comp=fract(value*bitSh);comp-=comp.xxyz*bitMsk;return comp;}void main() {gl_FragColor=pack(v_depth);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'precision mediump float;uniform sampler2D u_texture;uniform float u_terrain_coords_id;varying vec2 v_texture_pos;void main() {vec4 rgba=texture2D(u_texture,v_texture_pos);gl_FragColor=vec4(rgba.r,rgba.g,rgba.b,u_terrain_coords_id);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform sampler2D u_texture;uniform vec4 u_fog_color;uniform vec4 u_horizon_color;uniform float u_fog_ground_blend;uniform float u_fog_ground_blend_opacity;uniform float u_horizon_fog_blend;varying vec2 v_texture_pos;varying float v_fog_depth;const float gamma=2.2;vec4 gammaToLinear(vec4 color) {return pow(color,vec4(gamma));}vec4 linearToGamma(vec4 color) {return pow(color,vec4(1.0/gamma));}void main() {vec4 surface_color=texture2D(u_texture,v_texture_pos);if (v_fog_depth > u_fog_ground_blend) {vec4 surface_color_linear=gammaToLinear(surface_color);float blend_color=smoothstep(0.0,1.0,max((v_fog_depth-u_horizon_fog_blend)/(1.0-u_horizon_fog_blend),0.0));vec4 fog_horizon_color_linear=mix(gammaToLinear(u_fog_color),gammaToLinear(u_horizon_color),blend_color);float factor_fog=max(v_fog_depth-u_fog_ground_blend,0.0)/(1.0-u_fog_ground_blend);gl_FragColor=linearToGamma(mix(surface_color_linear,fog_horizon_color_linear,pow(factor_fog,2.0)*u_fog_ground_blend_opacity));} else {gl_FragColor=surface_color;}}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'attribute vec3 a_pos3d;uniform mat4 u_matrix;uniform float u_ele_delta;varying float v_depth;void main() {float ele=get_elevation(a_pos3d.xy);float ele_delta=a_pos3d.z==1.0 ? u_ele_delta : 0.0;gl_Position=u_matrix*vec4(a_pos3d.xy,ele-ele_delta,1.0);v_depth=gl_Position.z/gl_Position.w;}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'attribute vec3 a_pos3d;uniform mat4 u_matrix;uniform float u_ele_delta;varying vec2 v_texture_pos;void main() {float ele=get_elevation(a_pos3d.xy);float ele_delta=a_pos3d.z==1.0 ? u_ele_delta : 0.0;v_texture_pos=a_pos3d.xy/8192.0;gl_Position=u_matrix*vec4(a_pos3d.xy,ele-ele_delta,1.0);}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'attribute vec3 a_pos3d;uniform mat4 u_matrix;uniform mat4 u_fog_matrix;uniform float u_ele_delta;varying vec2 v_texture_pos;varying float v_fog_depth;void main() {float ele=get_elevation(a_pos3d.xy);float ele_delta=a_pos3d.z==1.0 ? u_ele_delta : 0.0;v_texture_pos=a_pos3d.xy/8192.0;gl_Position=u_matrix*vec4(a_pos3d.xy,ele-ele_delta,1.0);vec4 pos=u_fog_matrix*vec4(a_pos3d.xy,ele,1.0);v_fog_depth=pos.z/pos.w*0.5+0.5;}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'uniform vec4 u_sky_color;uniform vec4 u_horizon_color;uniform float u_horizon;uniform float u_sky_horizon_blend;void main() {float y=gl_FragCoord.y;if (y > u_horizon) {float blend=y-u_horizon;if (blend < u_sky_horizon_blend) {gl_FragColor=mix(u_sky_color,u_horizon_color,pow(1.0-blend/u_sky_horizon_blend,2.0));} else {gl_FragColor=u_sky_color;}}}';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default 'attribute vec2 a_pos;void main() {gl_Position=vec4(a_pos,1.0,1.0);}';\n","\n// Disable Flow annotations here because Flow doesn't support importing GLSL files\n\nimport preludeFrag from './_prelude.fragment.glsl.g';\nimport preludeVert from './_prelude.vertex.glsl.g';\nimport backgroundFrag from './background.fragment.glsl.g';\nimport backgroundVert from './background.vertex.glsl.g';\nimport backgroundPatternFrag from './background_pattern.fragment.glsl.g';\nimport backgroundPatternVert from './background_pattern.vertex.glsl.g';\nimport circleFrag from './circle.fragment.glsl.g';\nimport circleVert from './circle.vertex.glsl.g';\nimport clippingMaskFrag from './clipping_mask.fragment.glsl.g';\nimport clippingMaskVert from './clipping_mask.vertex.glsl.g';\nimport heatmapFrag from './heatmap.fragment.glsl.g';\nimport heatmapVert from './heatmap.vertex.glsl.g';\nimport heatmapTextureFrag from './heatmap_texture.fragment.glsl.g';\nimport heatmapTextureVert from './heatmap_texture.vertex.glsl.g';\nimport collisionBoxFrag from './collision_box.fragment.glsl.g';\nimport collisionBoxVert from './collision_box.vertex.glsl.g';\nimport collisionCircleFrag from './collision_circle.fragment.glsl.g';\nimport collisionCircleVert from './collision_circle.vertex.glsl.g';\nimport debugFrag from './debug.fragment.glsl.g';\nimport debugVert from './debug.vertex.glsl.g';\nimport fillFrag from './fill.fragment.glsl.g';\nimport fillVert from './fill.vertex.glsl.g';\nimport fillOutlineFrag from './fill_outline.fragment.glsl.g';\nimport fillOutlineVert from './fill_outline.vertex.glsl.g';\nimport fillOutlinePatternFrag from './fill_outline_pattern.fragment.glsl.g';\nimport fillOutlinePatternVert from './fill_outline_pattern.vertex.glsl.g';\nimport fillPatternFrag from './fill_pattern.fragment.glsl.g';\nimport fillPatternVert from './fill_pattern.vertex.glsl.g';\nimport fillExtrusionFrag from './fill_extrusion.fragment.glsl.g';\nimport fillExtrusionVert from './fill_extrusion.vertex.glsl.g';\nimport fillExtrusionPatternFrag from './fill_extrusion_pattern.fragment.glsl.g';\nimport fillExtrusionPatternVert from './fill_extrusion_pattern.vertex.glsl.g';\nimport hillshadePrepareFrag from './hillshade_prepare.fragment.glsl.g';\nimport hillshadePrepareVert from './hillshade_prepare.vertex.glsl.g';\nimport hillshadeFrag from './hillshade.fragment.glsl.g';\nimport hillshadeVert from './hillshade.vertex.glsl.g';\nimport lineFrag from './line.fragment.glsl.g';\nimport lineVert from './line.vertex.glsl.g';\nimport lineGradientFrag from './line_gradient.fragment.glsl.g';\nimport lineGradientVert from './line_gradient.vertex.glsl.g';\nimport linePatternFrag from './line_pattern.fragment.glsl.g';\nimport linePatternVert from './line_pattern.vertex.glsl.g';\nimport lineSDFFrag from './line_sdf.fragment.glsl.g';\nimport lineSDFVert from './line_sdf.vertex.glsl.g';\nimport rasterFrag from './raster.fragment.glsl.g';\nimport rasterVert from './raster.vertex.glsl.g';\nimport symbolIconFrag from './symbol_icon.fragment.glsl.g';\nimport symbolIconVert from './symbol_icon.vertex.glsl.g';\nimport symbolSDFFrag from './symbol_sdf.fragment.glsl.g';\nimport symbolSDFVert from './symbol_sdf.vertex.glsl.g';\nimport symbolTextAndIconFrag from './symbol_text_and_icon.fragment.glsl.g';\nimport symbolTextAndIconVert from './symbol_text_and_icon.vertex.glsl.g';\nimport terrainDepthFrag from './terrain_depth.fragment.glsl.g';\nimport terrainCoordsFrag from './terrain_coords.fragment.glsl.g';\nimport terrainFrag from './terrain.fragment.glsl.g';\nimport terrainDepthVert from './terrain_depth.vertex.glsl.g';\nimport terrainCoordsVert from './terrain_coords.vertex.glsl.g';\nimport terrainVert from './terrain.vertex.glsl.g';\nimport skyFrag from './sky.fragment.glsl.g';\nimport skyVert from './sky.vertex.glsl.g';\n\nexport const shaders = {\n prelude: compile(preludeFrag, preludeVert),\n background: compile(backgroundFrag, backgroundVert),\n backgroundPattern: compile(backgroundPatternFrag, backgroundPatternVert),\n circle: compile(circleFrag, circleVert),\n clippingMask: compile(clippingMaskFrag, clippingMaskVert),\n heatmap: compile(heatmapFrag, heatmapVert),\n heatmapTexture: compile(heatmapTextureFrag, heatmapTextureVert),\n collisionBox: compile(collisionBoxFrag, collisionBoxVert),\n collisionCircle: compile(collisionCircleFrag, collisionCircleVert),\n debug: compile(debugFrag, debugVert),\n fill: compile(fillFrag, fillVert),\n fillOutline: compile(fillOutlineFrag, fillOutlineVert),\n fillOutlinePattern: compile(fillOutlinePatternFrag, fillOutlinePatternVert),\n fillPattern: compile(fillPatternFrag, fillPatternVert),\n fillExtrusion: compile(fillExtrusionFrag, fillExtrusionVert),\n fillExtrusionPattern: compile(fillExtrusionPatternFrag, fillExtrusionPatternVert),\n hillshadePrepare: compile(hillshadePrepareFrag, hillshadePrepareVert),\n hillshade: compile(hillshadeFrag, hillshadeVert),\n line: compile(lineFrag, lineVert),\n lineGradient: compile(lineGradientFrag, lineGradientVert),\n linePattern: compile(linePatternFrag, linePatternVert),\n lineSDF: compile(lineSDFFrag, lineSDFVert),\n raster: compile(rasterFrag, rasterVert),\n symbolIcon: compile(symbolIconFrag, symbolIconVert),\n symbolSDF: compile(symbolSDFFrag, symbolSDFVert),\n symbolTextAndIcon: compile(symbolTextAndIconFrag, symbolTextAndIconVert),\n terrain: compile(terrainFrag, terrainVert),\n terrainDepth: compile(terrainDepthFrag, terrainDepthVert),\n terrainCoords: compile(terrainCoordsFrag, terrainCoordsVert),\n sky: compile(skyFrag, skyVert)};\n\n// Expand #pragmas to #ifdefs.\n\nfunction compile(fragmentSource, vertexSource) {\n const re = /#pragma mapbox: ([\\w]+) ([\\w]+) ([\\w]+) ([\\w]+)/g;\n\n const staticAttributes = vertexSource.match(/attribute ([\\w]+) ([\\w]+)/g);\n const fragmentUniforms = fragmentSource.match(/uniform ([\\w]+) ([\\w]+)([\\s]*)([\\w]*)/g);\n const vertexUniforms = vertexSource.match(/uniform ([\\w]+) ([\\w]+)([\\s]*)([\\w]*)/g);\n const staticUniforms = vertexUniforms ? vertexUniforms.concat(fragmentUniforms) : fragmentUniforms;\n\n const fragmentPragmas = {};\n\n fragmentSource = fragmentSource.replace(re, (match, operation, precision, type, name) => {\n fragmentPragmas[name] = true;\n if (operation === 'define') {\n return `\n#ifndef HAS_UNIFORM_u_${name}\nvarying ${precision} ${type} ${name};\n#else\nuniform ${precision} ${type} u_${name};\n#endif\n`;\n } else /* if (operation === 'initialize') */ {\n return `\n#ifdef HAS_UNIFORM_u_${name}\n ${precision} ${type} ${name} = u_${name};\n#endif\n`;\n }\n });\n\n vertexSource = vertexSource.replace(re, (match, operation, precision, type, name) => {\n const attrType = type === 'float' ? 'vec2' : 'vec4';\n const unpackType = name.match(/color/) ? 'color' : attrType;\n\n if (fragmentPragmas[name]) {\n if (operation === 'define') {\n return `\n#ifndef HAS_UNIFORM_u_${name}\nuniform lowp float u_${name}_t;\nattribute ${precision} ${attrType} a_${name};\nvarying ${precision} ${type} ${name};\n#else\nuniform ${precision} ${type} u_${name};\n#endif\n`;\n } else /* if (operation === 'initialize') */ {\n if (unpackType === 'vec4') {\n // vec4 attributes are only used for cross-faded properties, and are not packed\n return `\n#ifndef HAS_UNIFORM_u_${name}\n ${name} = a_${name};\n#else\n ${precision} ${type} ${name} = u_${name};\n#endif\n`;\n } else {\n return `\n#ifndef HAS_UNIFORM_u_${name}\n ${name} = unpack_mix_${unpackType}(a_${name}, u_${name}_t);\n#else\n ${precision} ${type} ${name} = u_${name};\n#endif\n`;\n }\n }\n } else {\n if (operation === 'define') {\n return `\n#ifndef HAS_UNIFORM_u_${name}\nuniform lowp float u_${name}_t;\nattribute ${precision} ${attrType} a_${name};\n#else\nuniform ${precision} ${type} u_${name};\n#endif\n`;\n } else /* if (operation === 'initialize') */ {\n if (unpackType === 'vec4') {\n // vec4 attributes are only used for cross-faded properties, and are not packed\n return `\n#ifndef HAS_UNIFORM_u_${name}\n ${precision} ${type} ${name} = a_${name};\n#else\n ${precision} ${type} ${name} = u_${name};\n#endif\n`;\n } else /* */ {\n return `\n#ifndef HAS_UNIFORM_u_${name}\n ${precision} ${type} ${name} = unpack_mix_${unpackType}(a_${name}, u_${name}_t);\n#else\n ${precision} ${type} ${name} = u_${name};\n#endif\n`;\n }\n }\n }\n });\n\n return {fragmentSource, vertexSource, staticAttributes, staticUniforms};\n}\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default '#ifdef GL_ES\\nprecision mediump float;\\n#else\\n#if !defined(lowp)\\n#define lowp\\n#endif\\n#if !defined(mediump)\\n#define mediump\\n#endif\\n#if !defined(highp)\\n#define highp\\n#endif\\n#endif\\n';\n","// This file is generated. Edit build/generate-shaders.ts, then run `npm run codegen`.\nexport default '#ifdef GL_ES\\nprecision highp float;\\n#else\\n#if !defined(lowp)\\n#define lowp\\n#endif\\n#if !defined(mediump)\\n#define mediump\\n#endif\\n#if !defined(highp)\\n#define highp\\n#endif\\n#endif\\nvec2 unpack_float(const float packedValue) {int packedIntValue=int(packedValue);int v0=packedIntValue/256;return vec2(v0,packedIntValue-v0*256);}vec2 unpack_opacity(const float packedOpacity) {int intOpacity=int(packedOpacity)/2;return vec2(float(intOpacity)/127.0,mod(packedOpacity,2.0));}vec4 decode_color(const vec2 encodedColor) {return vec4(unpack_float(encodedColor[0])/255.0,unpack_float(encodedColor[1])/255.0\\n);}float unpack_mix_vec2(const vec2 packedValue,const float t) {return mix(packedValue[0],packedValue[1],t);}vec4 unpack_mix_color(const vec4 packedColors,const float t) {vec4 minColor=decode_color(vec2(packedColors[0],packedColors[1]));vec4 maxColor=decode_color(vec2(packedColors[2],packedColors[3]));return mix(minColor,maxColor,t);}vec2 get_pattern_pos(const vec2 pixel_coord_upper,const vec2 pixel_coord_lower,const vec2 pattern_size,const float tile_units_to_pixels,const vec2 pos) {vec2 offset=mod(mod(mod(pixel_coord_upper,pattern_size)*256.0,pattern_size)*256.0+pixel_coord_lower,pattern_size);return (tile_units_to_pixels*pos+offset)/pattern_size;}\\n#ifdef TERRAIN3D\\nuniform sampler2D u_terrain;uniform float u_terrain_dim;uniform mat4 u_terrain_matrix;uniform vec4 u_terrain_unpack;uniform float u_terrain_exaggeration;uniform highp sampler2D u_depth;\\n#endif\\nconst highp vec4 bitSh=vec4(256.*256.*256.,256.*256.,256.,1.);const highp vec4 bitShifts=vec4(1.)/bitSh;highp float unpack(highp vec4 color) {return dot(color,bitShifts);}highp float depthOpacity(vec3 frag) {\\n#ifdef TERRAIN3D\\nhighp float d=unpack(texture2D(u_depth,frag.xy*0.5+0.5))+0.0001-frag.z;return 1.0-max(0.0,min(1.0,-d*500.0));\\n#else\\nreturn 1.0;\\n#endif\\n}float calculate_visibility(vec4 pos) {\\n#ifdef TERRAIN3D\\nvec3 frag=pos.xyz/pos.w;highp float d=depthOpacity(frag);if (d > 0.95) return 1.0;return (d+depthOpacity(frag+vec3(0.0,0.01,0.0)))/2.0;\\n#else\\nreturn 1.0;\\n#endif\\n}float ele(vec2 pos) {\\n#ifdef TERRAIN3D\\nvec4 rgb=(texture2D(u_terrain,pos)*255.0)*u_terrain_unpack;return rgb.r+rgb.g+rgb.b-u_terrain_unpack.a;\\n#else\\nreturn 0.0;\\n#endif\\n}float get_elevation(vec2 pos) {\\n#ifdef TERRAIN3D\\nvec2 coord=(u_terrain_matrix*vec4(pos,0.0,1.0)).xy*u_terrain_dim+1.0;vec2 f=fract(coord);vec2 c=(floor(coord)+0.5)/(u_terrain_dim+2.0);float d=1.0/(u_terrain_dim+2.0);float tl=ele(c);float tr=ele(c+vec2(d,0.0));float bl=ele(c+vec2(0.0,d));float br=ele(c+vec2(d,d));float elevation=mix(mix(tl,tr,f.x),mix(bl,br,f.x),f.y);return elevation*u_terrain_exaggeration;\\n#else\\nreturn 0.0;\\n#endif\\n}';\n","\nimport type {Program} from './program';\nimport type {VertexBuffer} from '../gl/vertex_buffer';\nimport type {IndexBuffer} from '../gl/index_buffer';\nimport type {Context} from '../gl/context';\n\n/**\n * @internal\n * A vertex array object used to pass data to the webgl code\n */\nexport class VertexArrayObject {\n context: Context;\n boundProgram: Program;\n boundLayoutVertexBuffer: VertexBuffer;\n boundPaintVertexBuffers: Array;\n boundIndexBuffer: IndexBuffer;\n boundVertexOffset: number;\n boundDynamicVertexBuffer: VertexBuffer;\n boundDynamicVertexBuffer2: VertexBuffer;\n boundDynamicVertexBuffer3: VertexBuffer;\n vao: any;\n\n constructor() {\n this.boundProgram = null;\n this.boundLayoutVertexBuffer = null;\n this.boundPaintVertexBuffers = [];\n this.boundIndexBuffer = null;\n this.boundVertexOffset = null;\n this.boundDynamicVertexBuffer = null;\n this.vao = null;\n }\n\n bind(context: Context,\n program: Program,\n layoutVertexBuffer: VertexBuffer,\n paintVertexBuffers: Array,\n indexBuffer?: IndexBuffer | null,\n vertexOffset?: number | null,\n dynamicVertexBuffer?: VertexBuffer | null,\n dynamicVertexBuffer2?: VertexBuffer | null,\n dynamicVertexBuffer3?: VertexBuffer | null) {\n\n this.context = context;\n\n let paintBuffersDiffer = this.boundPaintVertexBuffers.length !== paintVertexBuffers.length;\n for (let i = 0; !paintBuffersDiffer && i < paintVertexBuffers.length; i++) {\n if (this.boundPaintVertexBuffers[i] !== paintVertexBuffers[i]) {\n paintBuffersDiffer = true;\n }\n }\n\n const isFreshBindRequired = (\n !this.vao ||\n this.boundProgram !== program ||\n this.boundLayoutVertexBuffer !== layoutVertexBuffer ||\n paintBuffersDiffer ||\n this.boundIndexBuffer !== indexBuffer ||\n this.boundVertexOffset !== vertexOffset ||\n this.boundDynamicVertexBuffer !== dynamicVertexBuffer ||\n this.boundDynamicVertexBuffer2 !== dynamicVertexBuffer2 ||\n this.boundDynamicVertexBuffer3 !== dynamicVertexBuffer3\n );\n\n if (isFreshBindRequired) {\n this.freshBind(program, layoutVertexBuffer, paintVertexBuffers, indexBuffer, vertexOffset, dynamicVertexBuffer, dynamicVertexBuffer2, dynamicVertexBuffer3);\n } else {\n context.bindVertexArray.set(this.vao);\n\n if (dynamicVertexBuffer) {\n // The buffer may have been updated. Rebind to upload data.\n dynamicVertexBuffer.bind();\n }\n\n if (indexBuffer && indexBuffer.dynamicDraw) {\n indexBuffer.bind();\n }\n\n if (dynamicVertexBuffer2) {\n dynamicVertexBuffer2.bind();\n }\n\n if (dynamicVertexBuffer3) {\n dynamicVertexBuffer3.bind();\n }\n }\n }\n\n freshBind(program: Program,\n layoutVertexBuffer: VertexBuffer,\n paintVertexBuffers: Array,\n indexBuffer?: IndexBuffer | null,\n vertexOffset?: number | null,\n dynamicVertexBuffer?: VertexBuffer | null,\n dynamicVertexBuffer2?: VertexBuffer | null,\n dynamicVertexBuffer3?: VertexBuffer | null) {\n\n const numNextAttributes = program.numAttributes;\n\n const context = this.context;\n const gl = context.gl;\n\n if (this.vao) this.destroy();\n this.vao = context.createVertexArray();\n context.bindVertexArray.set(this.vao);\n\n // store the arguments so that we can verify them when the vao is bound again\n this.boundProgram = program;\n this.boundLayoutVertexBuffer = layoutVertexBuffer;\n this.boundPaintVertexBuffers = paintVertexBuffers;\n this.boundIndexBuffer = indexBuffer;\n this.boundVertexOffset = vertexOffset;\n this.boundDynamicVertexBuffer = dynamicVertexBuffer;\n this.boundDynamicVertexBuffer2 = dynamicVertexBuffer2;\n this.boundDynamicVertexBuffer3 = dynamicVertexBuffer3;\n\n layoutVertexBuffer.enableAttributes(gl, program);\n for (const vertexBuffer of paintVertexBuffers) {\n vertexBuffer.enableAttributes(gl, program);\n }\n\n if (dynamicVertexBuffer) {\n dynamicVertexBuffer.enableAttributes(gl, program);\n }\n if (dynamicVertexBuffer2) {\n dynamicVertexBuffer2.enableAttributes(gl, program);\n }\n if (dynamicVertexBuffer3) {\n dynamicVertexBuffer3.enableAttributes(gl, program);\n }\n\n layoutVertexBuffer.bind();\n layoutVertexBuffer.setVertexAttribPointers(gl, program, vertexOffset);\n for (const vertexBuffer of paintVertexBuffers) {\n vertexBuffer.bind();\n vertexBuffer.setVertexAttribPointers(gl, program, vertexOffset);\n }\n\n if (dynamicVertexBuffer) {\n dynamicVertexBuffer.bind();\n dynamicVertexBuffer.setVertexAttribPointers(gl, program, vertexOffset);\n }\n if (indexBuffer) {\n indexBuffer.bind();\n }\n if (dynamicVertexBuffer2) {\n dynamicVertexBuffer2.bind();\n dynamicVertexBuffer2.setVertexAttribPointers(gl, program, vertexOffset);\n }\n if (dynamicVertexBuffer3) {\n dynamicVertexBuffer3.bind();\n dynamicVertexBuffer3.setVertexAttribPointers(gl, program, vertexOffset);\n }\n\n context.currentNumAttributes = numNextAttributes;\n }\n\n destroy() {\n if (this.vao) {\n this.context.deleteVertexArray(this.vao);\n this.vao = null;\n }\n }\n}\n","import {\n Uniform1i,\n Uniform1f,\n Uniform4f,\n UniformMatrix4f,\n UniformColor\n} from '../uniform_binding';\nimport type {Context} from '../../gl/context';\nimport type {UniformValues, UniformLocations} from '../../render/uniform_binding';\nimport {mat4} from 'gl-matrix';\nimport {Sky} from '../../style/sky';\nimport {Color} from '@maplibre/maplibre-gl-style-spec';\n\nexport type TerrainPreludeUniformsType = {\n 'u_depth': Uniform1i;\n 'u_terrain': Uniform1i;\n 'u_terrain_dim': Uniform1f;\n 'u_terrain_matrix': UniformMatrix4f;\n 'u_terrain_unpack': Uniform4f;\n 'u_terrain_exaggeration': Uniform1f;\n};\n\nexport type TerrainUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_texture': Uniform1i;\n 'u_ele_delta': Uniform1f;\n 'u_fog_matrix': UniformMatrix4f;\n 'u_fog_color': UniformColor;\n 'u_fog_ground_blend': Uniform1f;\n 'u_fog_ground_blend_opacity': Uniform1f;\n 'u_horizon_color': UniformColor;\n 'u_horizon_fog_blend': Uniform1f;\n};\n\nexport type TerrainDepthUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_ele_delta': Uniform1f;\n};\n\nexport type TerrainCoordsUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_texture': Uniform1i;\n 'u_terrain_coords_id': Uniform1f;\n 'u_ele_delta': Uniform1f;\n};\n\nconst terrainPreludeUniforms = (context: Context, locations: UniformLocations): TerrainPreludeUniformsType => ({\n 'u_depth': new Uniform1i(context, locations.u_depth),\n 'u_terrain': new Uniform1i(context, locations.u_terrain),\n 'u_terrain_dim': new Uniform1f(context, locations.u_terrain_dim),\n 'u_terrain_matrix': new UniformMatrix4f(context, locations.u_terrain_matrix),\n 'u_terrain_unpack': new Uniform4f(context, locations.u_terrain_unpack),\n 'u_terrain_exaggeration': new Uniform1f(context, locations.u_terrain_exaggeration)\n});\n\nconst terrainUniforms = (context: Context, locations: UniformLocations): TerrainUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_texture': new Uniform1i(context, locations.u_texture),\n 'u_ele_delta': new Uniform1f(context, locations.u_ele_delta),\n 'u_fog_matrix': new UniformMatrix4f(context, locations.u_fog_matrix),\n 'u_fog_color': new UniformColor(context, locations.u_fog_color),\n 'u_fog_ground_blend': new Uniform1f(context, locations.u_fog_ground_blend),\n 'u_fog_ground_blend_opacity': new Uniform1f(context, locations.u_fog_ground_blend_opacity),\n 'u_horizon_color': new UniformColor(context, locations.u_horizon_color),\n 'u_horizon_fog_blend': new Uniform1f(context, locations.u_horizon_fog_blend)\n});\n\nconst terrainDepthUniforms = (context: Context, locations: UniformLocations): TerrainDepthUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_ele_delta': new Uniform1f(context, locations.u_ele_delta)\n});\n\nconst terrainCoordsUniforms = (context: Context, locations: UniformLocations): TerrainCoordsUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_texture': new Uniform1i(context, locations.u_texture),\n 'u_terrain_coords_id': new Uniform1f(context, locations.u_terrain_coords_id),\n 'u_ele_delta': new Uniform1f(context, locations.u_ele_delta)\n});\n\nconst terrainUniformValues = (\n matrix: mat4,\n eleDelta: number,\n fogMatrix: mat4,\n sky: Sky,\n pitch: number): UniformValues => ({\n 'u_matrix': matrix,\n 'u_texture': 0,\n 'u_ele_delta': eleDelta,\n 'u_fog_matrix': fogMatrix,\n 'u_fog_color': sky ? sky.properties.get('fog-color') : Color.white,\n 'u_fog_ground_blend': sky ? sky.properties.get('fog-ground-blend') : 1,\n 'u_fog_ground_blend_opacity': sky ? sky.calculateFogBlendOpacity(pitch) : 0,\n 'u_horizon_color': sky ? sky.properties.get('horizon-color') : Color.white,\n 'u_horizon_fog_blend': sky ? sky.properties.get('horizon-fog-blend') : 1\n});\n\nconst terrainDepthUniformValues = (\n matrix: mat4,\n eleDelta: number\n): UniformValues => ({\n 'u_matrix': matrix,\n 'u_ele_delta': eleDelta\n});\n\nconst terrainCoordsUniformValues = (\n matrix: mat4,\n coordsId: number,\n eleDelta: number\n): UniformValues => ({\n 'u_matrix': matrix,\n 'u_terrain_coords_id': coordsId / 255,\n 'u_texture': 0,\n 'u_ele_delta': eleDelta\n});\n\nexport {terrainUniforms, terrainDepthUniforms, terrainCoordsUniforms, terrainPreludeUniforms, terrainUniformValues, terrainDepthUniformValues, terrainCoordsUniformValues};\n","import {shaders} from '../shaders/shaders';\nimport {ProgramConfiguration} from '../data/program_configuration';\nimport {VertexArrayObject} from './vertex_array_object';\nimport {Context} from '../gl/context';\n\nimport type {SegmentVector} from '../data/segment';\nimport type {VertexBuffer} from '../gl/vertex_buffer';\nimport type {IndexBuffer} from '../gl/index_buffer';\nimport type {DepthMode} from '../gl/depth_mode';\nimport type {StencilMode} from '../gl/stencil_mode';\nimport type {ColorMode} from '../gl/color_mode';\nimport type {CullFaceMode} from '../gl/cull_face_mode';\nimport type {UniformBindings, UniformValues, UniformLocations} from './uniform_binding';\nimport type {BinderUniform} from '../data/program_configuration';\nimport {terrainPreludeUniforms, TerrainPreludeUniformsType} from './program/terrain_program';\nimport type {TerrainData} from '../render/terrain';\nimport {Terrain} from '../render/terrain';\n\nexport type DrawMode = WebGLRenderingContextBase['LINES'] | WebGLRenderingContextBase['TRIANGLES'] | WebGL2RenderingContext['LINE_STRIP'];\n\nfunction getTokenizedAttributesAndUniforms(array: Array): Array {\n const result = [];\n\n for (let i = 0; i < array.length; i++) {\n if (array[i] === null) continue;\n const token = array[i].split(' ');\n result.push(token.pop());\n }\n return result;\n}\n\n/**\n * @internal\n * A webgl program to execute in the GPU space\n */\nexport class Program {\n program: WebGLProgram;\n attributes: {[_: string]: number};\n numAttributes: number;\n fixedUniforms: Us;\n terrainUniforms: TerrainPreludeUniformsType;\n binderUniforms: Array;\n failedToCreate: boolean;\n\n constructor(context: Context,\n source: {\n fragmentSource: string;\n vertexSource: string;\n staticAttributes: Array;\n staticUniforms: Array;\n },\n configuration: ProgramConfiguration,\n fixedUniforms: (b: Context, a: UniformLocations) => Us,\n showOverdrawInspector: boolean,\n terrain: Terrain) {\n\n const gl = context.gl;\n this.program = gl.createProgram();\n\n const staticAttrInfo = getTokenizedAttributesAndUniforms(source.staticAttributes);\n const dynamicAttrInfo = configuration ? configuration.getBinderAttributes() : [];\n const allAttrInfo = staticAttrInfo.concat(dynamicAttrInfo);\n\n const preludeUniformsInfo = shaders.prelude.staticUniforms ? getTokenizedAttributesAndUniforms(shaders.prelude.staticUniforms) : [];\n const staticUniformsInfo = source.staticUniforms ? getTokenizedAttributesAndUniforms(source.staticUniforms) : [];\n const dynamicUniformsInfo = configuration ? configuration.getBinderUniforms() : [];\n // remove duplicate uniforms\n const uniformList = preludeUniformsInfo.concat(staticUniformsInfo).concat(dynamicUniformsInfo);\n const allUniformsInfo = [];\n for (const uniform of uniformList) {\n if (allUniformsInfo.indexOf(uniform) < 0) allUniformsInfo.push(uniform);\n }\n\n const defines = configuration ? configuration.defines() : [];\n if (showOverdrawInspector) {\n defines.push('#define OVERDRAW_INSPECTOR;');\n }\n if (terrain) {\n defines.push('#define TERRAIN3D;');\n }\n\n const fragmentSource = defines.concat(shaders.prelude.fragmentSource, source.fragmentSource).join('\\n');\n const vertexSource = defines.concat(shaders.prelude.vertexSource, source.vertexSource).join('\\n');\n\n const fragmentShader = gl.createShader(gl.FRAGMENT_SHADER);\n if (gl.isContextLost()) {\n this.failedToCreate = true;\n return;\n }\n gl.shaderSource(fragmentShader, fragmentSource);\n gl.compileShader(fragmentShader);\n\n if (!gl.getShaderParameter(fragmentShader, gl.COMPILE_STATUS)) {\n throw new Error(`Could not compile fragment shader: ${gl.getShaderInfoLog(fragmentShader)}`);\n }\n\n gl.attachShader(this.program, fragmentShader);\n\n const vertexShader = gl.createShader(gl.VERTEX_SHADER);\n if (gl.isContextLost()) {\n this.failedToCreate = true;\n return;\n }\n gl.shaderSource(vertexShader, vertexSource);\n gl.compileShader(vertexShader);\n\n if (!gl.getShaderParameter(vertexShader, gl.COMPILE_STATUS)) {\n throw new Error(`Could not compile vertex shader: ${gl.getShaderInfoLog(vertexShader)}`);\n }\n\n gl.attachShader(this.program, vertexShader);\n\n this.attributes = {};\n const uniformLocations = {};\n\n this.numAttributes = allAttrInfo.length;\n\n for (let i = 0; i < this.numAttributes; i++) {\n if (allAttrInfo[i]) {\n gl.bindAttribLocation(this.program, i, allAttrInfo[i]);\n this.attributes[allAttrInfo[i]] = i;\n }\n }\n\n gl.linkProgram(this.program);\n\n if (!gl.getProgramParameter(this.program, gl.LINK_STATUS)) {\n throw new Error(`Program failed to link: ${gl.getProgramInfoLog(this.program)}`);\n }\n\n gl.deleteShader(vertexShader);\n gl.deleteShader(fragmentShader);\n\n for (let it = 0; it < allUniformsInfo.length; it++) {\n const uniform = allUniformsInfo[it];\n if (uniform && !uniformLocations[uniform]) {\n const uniformLocation = gl.getUniformLocation(this.program, uniform);\n if (uniformLocation) {\n uniformLocations[uniform] = uniformLocation;\n }\n }\n }\n\n this.fixedUniforms = fixedUniforms(context, uniformLocations);\n this.terrainUniforms = terrainPreludeUniforms(context, uniformLocations);\n this.binderUniforms = configuration ? configuration.getUniforms(context, uniformLocations) : [];\n }\n\n draw(context: Context,\n drawMode: DrawMode,\n depthMode: Readonly,\n stencilMode: Readonly,\n colorMode: Readonly,\n cullFaceMode: Readonly,\n uniformValues: UniformValues,\n terrain: TerrainData,\n layerID: string,\n layoutVertexBuffer: VertexBuffer,\n indexBuffer: IndexBuffer,\n segments: SegmentVector,\n currentProperties?: any,\n zoom?: number | null,\n configuration?: ProgramConfiguration | null,\n dynamicLayoutBuffer?: VertexBuffer | null,\n dynamicLayoutBuffer2?: VertexBuffer | null,\n dynamicLayoutBuffer3?: VertexBuffer | null) {\n\n const gl = context.gl;\n\n if (this.failedToCreate) return;\n\n context.program.set(this.program);\n context.setDepthMode(depthMode);\n context.setStencilMode(stencilMode);\n context.setColorMode(colorMode);\n context.setCullFace(cullFaceMode);\n\n // set variables used by the 3d functions defined in _prelude.vertex.glsl\n if (terrain) {\n context.activeTexture.set(gl.TEXTURE2);\n gl.bindTexture(gl.TEXTURE_2D, terrain.depthTexture);\n context.activeTexture.set(gl.TEXTURE3);\n gl.bindTexture(gl.TEXTURE_2D, terrain.texture);\n for (const name in this.terrainUniforms) {\n this.terrainUniforms[name].set(terrain[name]);\n }\n }\n\n for (const name in this.fixedUniforms) {\n this.fixedUniforms[name].set(uniformValues[name]);\n }\n\n if (configuration) {\n configuration.setUniforms(context, this.binderUniforms, currentProperties, {zoom: (zoom as any)});\n }\n\n let primitiveSize = 0;\n switch (drawMode) {\n case gl.LINES:\n primitiveSize = 2;\n break;\n case gl.TRIANGLES:\n primitiveSize = 3;\n break;\n case gl.LINE_STRIP:\n primitiveSize = 1;\n break;\n }\n\n for (const segment of segments.get()) {\n const vaos = segment.vaos || (segment.vaos = {});\n const vao: VertexArrayObject = vaos[layerID] || (vaos[layerID] = new VertexArrayObject());\n\n vao.bind(\n context,\n this,\n layoutVertexBuffer,\n configuration ? configuration.getPaintVertexBuffers() : [],\n indexBuffer,\n segment.vertexOffset,\n dynamicLayoutBuffer,\n dynamicLayoutBuffer2,\n dynamicLayoutBuffer3\n );\n\n gl.drawElements(\n drawMode,\n segment.primitiveLength * primitiveSize,\n gl.UNSIGNED_SHORT,\n segment.primitiveOffset * primitiveSize * 2);\n }\n }\n}\n","import {\n Uniform1i,\n Uniform1f,\n Uniform2f,\n Uniform3f\n} from '../uniform_binding';\nimport {pixelsToTileUnits} from '../../source/pixels_to_tile_units';\n\nimport type {Painter} from '../painter';\nimport type {OverscaledTileID} from '../../source/tile_id';\nimport type {CrossFaded} from '../../style/properties';\nimport type {CrossfadeParameters} from '../../style/evaluation_parameters';\nimport type {UniformValues} from '../uniform_binding';\nimport type {Tile} from '../../source/tile';\nimport type {ResolvedImage} from '@maplibre/maplibre-gl-style-spec';\n\ntype BackgroundPatternUniformsType = {\n 'u_image': Uniform1i;\n 'u_pattern_tl_a': Uniform2f;\n 'u_pattern_br_a': Uniform2f;\n 'u_pattern_tl_b': Uniform2f;\n 'u_pattern_br_b': Uniform2f;\n 'u_texsize': Uniform2f;\n 'u_mix': Uniform1f;\n 'u_pattern_size_a': Uniform2f;\n 'u_pattern_size_b': Uniform2f;\n 'u_scale_a': Uniform1f;\n 'u_scale_b': Uniform1f;\n 'u_pixel_coord_upper': Uniform2f;\n 'u_pixel_coord_lower': Uniform2f;\n 'u_tile_units_to_pixels': Uniform1f;\n};\n\nexport type PatternUniformsType = {\n // pattern uniforms:\n 'u_image': Uniform1i;\n 'u_texsize': Uniform2f;\n 'u_scale': Uniform3f;\n 'u_fade': Uniform1f;\n 'u_pixel_coord_upper': Uniform2f;\n 'u_pixel_coord_lower': Uniform2f;\n};\n\nfunction patternUniformValues(crossfade: CrossfadeParameters, painter: Painter, tile: Tile): UniformValues {\n\n const tileRatio = 1 / pixelsToTileUnits(tile, 1, painter.transform.tileZoom);\n\n const numTiles = Math.pow(2, tile.tileID.overscaledZ);\n const tileSizeAtNearestZoom = tile.tileSize * Math.pow(2, painter.transform.tileZoom) / numTiles;\n\n const pixelX = tileSizeAtNearestZoom * (tile.tileID.canonical.x + tile.tileID.wrap * numTiles);\n const pixelY = tileSizeAtNearestZoom * tile.tileID.canonical.y;\n\n return {\n 'u_image': 0,\n 'u_texsize': tile.imageAtlasTexture.size,\n 'u_scale': [tileRatio, crossfade.fromScale, crossfade.toScale],\n 'u_fade': crossfade.t,\n // split the pixel coord into two pairs of 16 bit numbers. The glsl spec only guarantees 16 bits of precision.\n 'u_pixel_coord_upper': [pixelX >> 16, pixelY >> 16],\n 'u_pixel_coord_lower': [pixelX & 0xFFFF, pixelY & 0xFFFF]\n };\n}\n\nfunction bgPatternUniformValues(\n image: CrossFaded,\n crossfade: CrossfadeParameters,\n painter: Painter,\n tile: {\n tileID: OverscaledTileID;\n tileSize: number;\n }\n): UniformValues {\n const imagePosA = painter.imageManager.getPattern(image.from.toString());\n const imagePosB = painter.imageManager.getPattern(image.to.toString());\n const {width, height} = painter.imageManager.getPixelSize();\n\n const numTiles = Math.pow(2, tile.tileID.overscaledZ);\n const tileSizeAtNearestZoom = tile.tileSize * Math.pow(2, painter.transform.tileZoom) / numTiles;\n\n const pixelX = tileSizeAtNearestZoom * (tile.tileID.canonical.x + tile.tileID.wrap * numTiles);\n const pixelY = tileSizeAtNearestZoom * tile.tileID.canonical.y;\n\n return {\n 'u_image': 0,\n 'u_pattern_tl_a': (imagePosA as any).tl,\n 'u_pattern_br_a': (imagePosA as any).br,\n 'u_pattern_tl_b': (imagePosB as any).tl,\n 'u_pattern_br_b': (imagePosB as any).br,\n 'u_texsize': [width, height],\n 'u_mix': crossfade.t,\n 'u_pattern_size_a': (imagePosA as any).displaySize,\n 'u_pattern_size_b': (imagePosB as any).displaySize,\n 'u_scale_a': crossfade.fromScale,\n 'u_scale_b': crossfade.toScale,\n 'u_tile_units_to_pixels': 1 / pixelsToTileUnits(tile, 1, painter.transform.tileZoom),\n // split the pixel coord into two pairs of 16 bit numbers. The glsl spec only guarantees 16 bits of precision.\n 'u_pixel_coord_upper': [pixelX >> 16, pixelY >> 16],\n 'u_pixel_coord_lower': [pixelX & 0xFFFF, pixelY & 0xFFFF]\n };\n}\nexport {bgPatternUniformValues, patternUniformValues};\n","import {patternUniformValues} from './pattern';\nimport {\n Uniform1i,\n Uniform1f,\n Uniform2f,\n Uniform3f,\n UniformMatrix4f\n} from '../uniform_binding';\n\nimport {mat3, mat4, vec3} from 'gl-matrix';\nimport {extend} from '../../util/util';\n\nimport type {Context} from '../../gl/context';\nimport type {Painter} from '../painter';\nimport type {OverscaledTileID} from '../../source/tile_id';\nimport type {UniformValues, UniformLocations} from '../uniform_binding';\nimport type {CrossfadeParameters} from '../../style/evaluation_parameters';\nimport type {Tile} from '../../source/tile';\n\nexport type FillExtrusionUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_lightpos': Uniform3f;\n 'u_lightintensity': Uniform1f;\n 'u_lightcolor': Uniform3f;\n 'u_vertical_gradient': Uniform1f;\n 'u_opacity': Uniform1f;\n};\n\nexport type FillExtrusionPatternUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_lightpos': Uniform3f;\n 'u_lightintensity': Uniform1f;\n 'u_lightcolor': Uniform3f;\n 'u_height_factor': Uniform1f;\n 'u_vertical_gradient': Uniform1f;\n // pattern uniforms:\n 'u_texsize': Uniform2f;\n 'u_image': Uniform1i;\n 'u_pixel_coord_upper': Uniform2f;\n 'u_pixel_coord_lower': Uniform2f;\n 'u_scale': Uniform3f;\n 'u_fade': Uniform1f;\n 'u_opacity': Uniform1f;\n};\n\nconst fillExtrusionUniforms = (context: Context, locations: UniformLocations): FillExtrusionUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_lightpos': new Uniform3f(context, locations.u_lightpos),\n 'u_lightintensity': new Uniform1f(context, locations.u_lightintensity),\n 'u_lightcolor': new Uniform3f(context, locations.u_lightcolor),\n 'u_vertical_gradient': new Uniform1f(context, locations.u_vertical_gradient),\n 'u_opacity': new Uniform1f(context, locations.u_opacity)\n});\n\nconst fillExtrusionPatternUniforms = (context: Context, locations: UniformLocations): FillExtrusionPatternUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_lightpos': new Uniform3f(context, locations.u_lightpos),\n 'u_lightintensity': new Uniform1f(context, locations.u_lightintensity),\n 'u_lightcolor': new Uniform3f(context, locations.u_lightcolor),\n 'u_vertical_gradient': new Uniform1f(context, locations.u_vertical_gradient),\n 'u_height_factor': new Uniform1f(context, locations.u_height_factor),\n // pattern uniforms\n 'u_image': new Uniform1i(context, locations.u_image),\n 'u_texsize': new Uniform2f(context, locations.u_texsize),\n 'u_pixel_coord_upper': new Uniform2f(context, locations.u_pixel_coord_upper),\n 'u_pixel_coord_lower': new Uniform2f(context, locations.u_pixel_coord_lower),\n 'u_scale': new Uniform3f(context, locations.u_scale),\n 'u_fade': new Uniform1f(context, locations.u_fade),\n 'u_opacity': new Uniform1f(context, locations.u_opacity)\n});\n\nconst fillExtrusionUniformValues = (\n matrix: mat4,\n painter: Painter,\n shouldUseVerticalGradient: boolean,\n opacity: number\n): UniformValues => {\n const light = painter.style.light;\n const _lp = light.properties.get('position');\n const lightPos = [_lp.x, _lp.y, _lp.z] as vec3;\n const lightMat = mat3.create();\n if (light.properties.get('anchor') === 'viewport') {\n mat3.fromRotation(lightMat, -painter.transform.angle);\n }\n vec3.transformMat3(lightPos, lightPos, lightMat);\n\n const lightColor = light.properties.get('color');\n\n return {\n 'u_matrix': matrix,\n 'u_lightpos': lightPos,\n 'u_lightintensity': light.properties.get('intensity'),\n 'u_lightcolor': [lightColor.r, lightColor.g, lightColor.b],\n 'u_vertical_gradient': +shouldUseVerticalGradient,\n 'u_opacity': opacity\n };\n};\n\nconst fillExtrusionPatternUniformValues = (\n matrix: mat4,\n painter: Painter,\n shouldUseVerticalGradient: boolean,\n opacity: number,\n coord: OverscaledTileID,\n crossfade: CrossfadeParameters,\n tile: Tile\n): UniformValues => {\n return extend(fillExtrusionUniformValues(matrix, painter, shouldUseVerticalGradient, opacity),\n patternUniformValues(crossfade, painter, tile),\n {\n 'u_height_factor': -Math.pow(2, coord.overscaledZ) / tile.tileSize / 8\n });\n};\n\nexport {\n fillExtrusionUniforms,\n fillExtrusionPatternUniforms,\n fillExtrusionUniformValues,\n fillExtrusionPatternUniformValues\n};\n","import {patternUniformValues} from './pattern';\nimport {\n Uniform1i,\n Uniform1f,\n Uniform2f,\n Uniform3f,\n UniformMatrix4f\n} from '../uniform_binding';\nimport {extend} from '../../util/util';\n\nimport type {Painter} from '../painter';\nimport type {UniformValues, UniformLocations} from '../uniform_binding';\nimport type {Context} from '../../gl/context';\nimport type {CrossfadeParameters} from '../../style/evaluation_parameters';\nimport type {Tile} from '../../source/tile';\nimport {mat4} from 'gl-matrix';\n\nexport type FillUniformsType = {\n 'u_matrix': UniformMatrix4f;\n};\n\nexport type FillOutlineUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_world': Uniform2f;\n};\n\nexport type FillPatternUniformsType = {\n 'u_matrix': UniformMatrix4f;\n // pattern uniforms:\n 'u_texsize': Uniform2f;\n 'u_image': Uniform1i;\n 'u_pixel_coord_upper': Uniform2f;\n 'u_pixel_coord_lower': Uniform2f;\n 'u_scale': Uniform3f;\n 'u_fade': Uniform1f;\n};\n\nexport type FillOutlinePatternUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_world': Uniform2f;\n // pattern uniforms:\n 'u_texsize': Uniform2f;\n 'u_image': Uniform1i;\n 'u_pixel_coord_upper': Uniform2f;\n 'u_pixel_coord_lower': Uniform2f;\n 'u_scale': Uniform3f;\n 'u_fade': Uniform1f;\n};\n\nconst fillUniforms = (context: Context, locations: UniformLocations): FillUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix)\n});\n\nconst fillPatternUniforms = (context: Context, locations: UniformLocations): FillPatternUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_image': new Uniform1i(context, locations.u_image),\n 'u_texsize': new Uniform2f(context, locations.u_texsize),\n 'u_pixel_coord_upper': new Uniform2f(context, locations.u_pixel_coord_upper),\n 'u_pixel_coord_lower': new Uniform2f(context, locations.u_pixel_coord_lower),\n 'u_scale': new Uniform3f(context, locations.u_scale),\n 'u_fade': new Uniform1f(context, locations.u_fade)\n});\n\nconst fillOutlineUniforms = (context: Context, locations: UniformLocations): FillOutlineUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_world': new Uniform2f(context, locations.u_world)\n});\n\nconst fillOutlinePatternUniforms = (context: Context, locations: UniformLocations): FillOutlinePatternUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_world': new Uniform2f(context, locations.u_world),\n 'u_image': new Uniform1i(context, locations.u_image),\n 'u_texsize': new Uniform2f(context, locations.u_texsize),\n 'u_pixel_coord_upper': new Uniform2f(context, locations.u_pixel_coord_upper),\n 'u_pixel_coord_lower': new Uniform2f(context, locations.u_pixel_coord_lower),\n 'u_scale': new Uniform3f(context, locations.u_scale),\n 'u_fade': new Uniform1f(context, locations.u_fade)\n});\n\nconst fillUniformValues = (matrix: mat4): UniformValues => ({\n 'u_matrix': matrix\n});\n\nconst fillPatternUniformValues = (\n matrix: mat4,\n painter: Painter,\n crossfade: CrossfadeParameters,\n tile: Tile\n): UniformValues => extend(\n fillUniformValues(matrix),\n patternUniformValues(crossfade, painter, tile)\n);\n\nconst fillOutlineUniformValues = (matrix: mat4, drawingBufferSize: [number, number]): UniformValues => ({\n 'u_matrix': matrix,\n 'u_world': drawingBufferSize\n});\n\nconst fillOutlinePatternUniformValues = (\n matrix: mat4,\n painter: Painter,\n crossfade: CrossfadeParameters,\n tile: Tile,\n drawingBufferSize: [number, number]\n): UniformValues => extend(\n fillPatternUniformValues(matrix, painter, crossfade, tile),\n {\n 'u_world': drawingBufferSize\n }\n);\n\nexport {\n fillUniforms,\n fillPatternUniforms,\n fillOutlineUniforms,\n fillOutlinePatternUniforms,\n fillUniformValues,\n fillPatternUniformValues,\n fillOutlineUniformValues,\n fillOutlinePatternUniformValues\n};\n","import {Uniform1i, Uniform1f, Uniform2f, UniformMatrix4f} from '../uniform_binding';\nimport {pixelsToTileUnits} from '../../source/pixels_to_tile_units';\n\nimport type {Context} from '../../gl/context';\nimport type {UniformValues, UniformLocations} from '../uniform_binding';\nimport type {OverscaledTileID} from '../../source/tile_id';\nimport type {Tile} from '../../source/tile';\nimport type {CircleStyleLayer} from '../../style/style_layer/circle_style_layer';\nimport type {Painter} from '../painter';\n\nexport type CircleUniformsType = {\n 'u_camera_to_center_distance': Uniform1f;\n 'u_scale_with_map': Uniform1i;\n 'u_pitch_with_map': Uniform1i;\n 'u_extrude_scale': Uniform2f;\n 'u_device_pixel_ratio': Uniform1f;\n 'u_matrix': UniformMatrix4f;\n};\n\nconst circleUniforms = (context: Context, locations: UniformLocations): CircleUniformsType => ({\n 'u_camera_to_center_distance': new Uniform1f(context, locations.u_camera_to_center_distance),\n 'u_scale_with_map': new Uniform1i(context, locations.u_scale_with_map),\n 'u_pitch_with_map': new Uniform1i(context, locations.u_pitch_with_map),\n 'u_extrude_scale': new Uniform2f(context, locations.u_extrude_scale),\n 'u_device_pixel_ratio': new Uniform1f(context, locations.u_device_pixel_ratio),\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix)\n});\n\nconst circleUniformValues = (\n painter: Painter,\n coord: OverscaledTileID,\n tile: Tile,\n layer: CircleStyleLayer\n): UniformValues => {\n const transform = painter.transform;\n\n let pitchWithMap: boolean, extrudeScale: [number, number];\n if (layer.paint.get('circle-pitch-alignment') === 'map') {\n const pixelRatio = pixelsToTileUnits(tile, 1, transform.zoom);\n pitchWithMap = true;\n extrudeScale = [pixelRatio, pixelRatio];\n } else {\n pitchWithMap = false;\n extrudeScale = transform.pixelsToGLUnits;\n }\n\n return {\n 'u_camera_to_center_distance': transform.cameraToCenterDistance,\n 'u_scale_with_map': +(layer.paint.get('circle-pitch-scale') === 'map'),\n 'u_matrix': painter.translatePosMatrix(\n coord.posMatrix,\n tile,\n layer.paint.get('circle-translate'),\n layer.paint.get('circle-translate-anchor')),\n 'u_pitch_with_map': +(pitchWithMap),\n 'u_device_pixel_ratio': painter.pixelRatio,\n 'u_extrude_scale': extrudeScale\n };\n};\n\nexport {circleUniforms, circleUniformValues};\n","import {Uniform1f, Uniform2f, UniformMatrix4f} from '../uniform_binding';\nimport type {Context} from '../../gl/context';\nimport type {UniformValues, UniformLocations} from '../uniform_binding';\nimport type {Transform} from '../../geo/transform';\nimport {mat4} from 'gl-matrix';\n\nexport type CollisionUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_pixel_extrude_scale': Uniform2f;\n};\n\nexport type CollisionCircleUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_inv_matrix': UniformMatrix4f;\n 'u_camera_to_center_distance': Uniform1f;\n 'u_viewport_size': Uniform2f;\n};\n\nconst collisionUniforms = (context: Context, locations: UniformLocations): CollisionUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_pixel_extrude_scale': new Uniform2f(context, locations.u_pixel_extrude_scale)\n});\n\nconst collisionCircleUniforms = (context: Context, locations: UniformLocations): CollisionCircleUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_inv_matrix': new UniformMatrix4f(context, locations.u_inv_matrix),\n 'u_camera_to_center_distance': new Uniform1f(context, locations.u_camera_to_center_distance),\n 'u_viewport_size': new Uniform2f(context, locations.u_viewport_size)\n});\n\nconst collisionUniformValues = (transform: {width: number; height: number}, matrix: mat4): UniformValues => {\n return {\n 'u_matrix': matrix,\n 'u_pixel_extrude_scale': [1.0 / transform.width, 1.0 / transform.height],\n };\n};\n\nconst collisionCircleUniformValues = (matrix: mat4, invMatrix: mat4, transform: Transform): UniformValues => {\n return {\n 'u_matrix': matrix,\n 'u_inv_matrix': invMatrix,\n 'u_camera_to_center_distance': transform.cameraToCenterDistance,\n 'u_viewport_size': [transform.width, transform.height]\n };\n};\n\nexport {collisionUniforms, collisionUniformValues, collisionCircleUniforms, collisionCircleUniformValues};\n","import {UniformColor, UniformMatrix4f, Uniform1i, Uniform1f} from '../uniform_binding';\n\nimport type {Context} from '../../gl/context';\nimport type {UniformValues, UniformLocations} from '../uniform_binding';\nimport type {Color} from '@maplibre/maplibre-gl-style-spec';\nimport {mat4} from 'gl-matrix';\n\nexport type DebugUniformsType = {\n 'u_color': UniformColor;\n 'u_matrix': UniformMatrix4f;\n 'u_overlay': Uniform1i;\n 'u_overlay_scale': Uniform1f;\n};\n\nconst debugUniforms = (context: Context, locations: UniformLocations): DebugUniformsType => ({\n 'u_color': new UniformColor(context, locations.u_color),\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_overlay': new Uniform1i(context, locations.u_overlay),\n 'u_overlay_scale': new Uniform1f(context, locations.u_overlay_scale)\n});\n\nconst debugUniformValues = (matrix: mat4, color: Color, scaleRatio: number = 1): UniformValues => ({\n 'u_matrix': matrix,\n 'u_color': color,\n 'u_overlay': 0,\n 'u_overlay_scale': scaleRatio\n});\n\nexport {debugUniforms, debugUniformValues};\n","import {UniformMatrix4f} from '../uniform_binding';\n\nimport type {Context} from '../../gl/context';\nimport type {UniformValues, UniformLocations} from '../uniform_binding';\nimport {mat4} from 'gl-matrix';\n\nexport type ClippingMaskUniformsType = {\n 'u_matrix': UniformMatrix4f;\n};\n\nconst clippingMaskUniforms = (context: Context, locations: UniformLocations): ClippingMaskUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix)\n});\n\nconst clippingMaskUniformValues = (matrix: mat4): UniformValues => ({\n 'u_matrix': matrix\n});\n\nexport {clippingMaskUniforms, clippingMaskUniformValues};\n","import {mat4} from 'gl-matrix';\n\nimport {\n Uniform1i,\n Uniform1f,\n Uniform2f,\n UniformMatrix4f\n} from '../uniform_binding';\nimport {pixelsToTileUnits} from '../../source/pixels_to_tile_units';\n\nimport type {Context} from '../../gl/context';\nimport type {Tile} from '../../source/tile';\nimport type {UniformValues, UniformLocations} from '../uniform_binding';\nimport type {Painter} from '../painter';\nimport type {HeatmapStyleLayer} from '../../style/style_layer/heatmap_style_layer';\n\nexport type HeatmapUniformsType = {\n 'u_extrude_scale': Uniform1f;\n 'u_intensity': Uniform1f;\n 'u_matrix': UniformMatrix4f;\n};\n\nexport type HeatmapTextureUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_world': Uniform2f;\n 'u_image': Uniform1i;\n 'u_color_ramp': Uniform1i;\n 'u_opacity': Uniform1f;\n};\n\nconst heatmapUniforms = (context: Context, locations: UniformLocations): HeatmapUniformsType => ({\n 'u_extrude_scale': new Uniform1f(context, locations.u_extrude_scale),\n 'u_intensity': new Uniform1f(context, locations.u_intensity),\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix)\n});\n\nconst heatmapTextureUniforms = (context: Context, locations: UniformLocations): HeatmapTextureUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_world': new Uniform2f(context, locations.u_world),\n 'u_image': new Uniform1i(context, locations.u_image),\n 'u_color_ramp': new Uniform1i(context, locations.u_color_ramp),\n 'u_opacity': new Uniform1f(context, locations.u_opacity)\n});\n\nconst heatmapUniformValues = (matrix: mat4, tile: Tile, zoom: number, intensity: number): UniformValues => ({\n 'u_matrix': matrix,\n 'u_extrude_scale': pixelsToTileUnits(tile, 1, zoom),\n 'u_intensity': intensity\n});\n\nconst heatmapTextureUniformValues = (\n painter: Painter,\n layer: HeatmapStyleLayer,\n textureUnit: number,\n colorRampUnit: number\n): UniformValues => {\n const matrix = mat4.create();\n mat4.ortho(matrix, 0, painter.width, painter.height, 0, 0, 1);\n\n const gl = painter.context.gl;\n\n return {\n 'u_matrix': matrix,\n 'u_world': [gl.drawingBufferWidth, gl.drawingBufferHeight],\n 'u_image': textureUnit,\n 'u_color_ramp': colorRampUnit,\n 'u_opacity': layer.paint.get('heatmap-opacity')\n };\n};\n\nexport {\n heatmapUniforms,\n heatmapTextureUniforms,\n heatmapUniformValues,\n heatmapTextureUniformValues\n};\n","import {mat4} from 'gl-matrix';\n\nimport {\n Uniform1i,\n Uniform1f,\n Uniform2f,\n UniformColor,\n UniformMatrix4f,\n Uniform4f\n} from '../uniform_binding';\nimport {EXTENT} from '../../data/extent';\nimport {MercatorCoordinate} from '../../geo/mercator_coordinate';\n\nimport type {Context} from '../../gl/context';\nimport type {UniformValues, UniformLocations} from '../uniform_binding';\nimport type {Tile} from '../../source/tile';\nimport type {Painter} from '../painter';\nimport type {HillshadeStyleLayer} from '../../style/style_layer/hillshade_style_layer';\nimport type {DEMData} from '../../data/dem_data';\nimport type {OverscaledTileID} from '../../source/tile_id';\n\nexport type HillshadeUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_image': Uniform1i;\n 'u_latrange': Uniform2f;\n 'u_light': Uniform2f;\n 'u_shadow': UniformColor;\n 'u_highlight': UniformColor;\n 'u_accent': UniformColor;\n};\n\nexport type HillshadePrepareUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_image': Uniform1i;\n 'u_dimension': Uniform2f;\n 'u_zoom': Uniform1f;\n 'u_unpack': Uniform4f;\n};\n\nconst hillshadeUniforms = (context: Context, locations: UniformLocations): HillshadeUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_image': new Uniform1i(context, locations.u_image),\n 'u_latrange': new Uniform2f(context, locations.u_latrange),\n 'u_light': new Uniform2f(context, locations.u_light),\n 'u_shadow': new UniformColor(context, locations.u_shadow),\n 'u_highlight': new UniformColor(context, locations.u_highlight),\n 'u_accent': new UniformColor(context, locations.u_accent)\n});\n\nconst hillshadePrepareUniforms = (context: Context, locations: UniformLocations): HillshadePrepareUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_image': new Uniform1i(context, locations.u_image),\n 'u_dimension': new Uniform2f(context, locations.u_dimension),\n 'u_zoom': new Uniform1f(context, locations.u_zoom),\n 'u_unpack': new Uniform4f(context, locations.u_unpack)\n});\n\nconst hillshadeUniformValues = (\n painter: Painter,\n tile: Tile,\n layer: HillshadeStyleLayer,\n coord: OverscaledTileID\n): UniformValues => {\n const shadow = layer.paint.get('hillshade-shadow-color');\n const highlight = layer.paint.get('hillshade-highlight-color');\n const accent = layer.paint.get('hillshade-accent-color');\n\n let azimuthal = layer.paint.get('hillshade-illumination-direction') * (Math.PI / 180);\n // modify azimuthal angle by map rotation if light is anchored at the viewport\n if (layer.paint.get('hillshade-illumination-anchor') === 'viewport') {\n azimuthal -= painter.transform.angle;\n }\n const align = !painter.options.moving;\n return {\n 'u_matrix': coord ? coord.posMatrix : painter.transform.calculatePosMatrix(tile.tileID.toUnwrapped(), align),\n 'u_image': 0,\n 'u_latrange': getTileLatRange(painter, tile.tileID),\n 'u_light': [layer.paint.get('hillshade-exaggeration'), azimuthal],\n 'u_shadow': shadow,\n 'u_highlight': highlight,\n 'u_accent': accent\n };\n};\n\nconst hillshadeUniformPrepareValues = (tileID: OverscaledTileID, dem: DEMData): UniformValues => {\n\n const stride = dem.stride;\n const matrix = mat4.create();\n // Flip rendering at y axis.\n mat4.ortho(matrix, 0, EXTENT, -EXTENT, 0, 0, 1);\n mat4.translate(matrix, matrix, [0, -EXTENT, 0]);\n\n return {\n 'u_matrix': matrix,\n 'u_image': 1,\n 'u_dimension': [stride, stride],\n 'u_zoom': tileID.overscaledZ,\n 'u_unpack': dem.getUnpackVector()\n };\n};\n\nfunction getTileLatRange(painter: Painter, tileID: OverscaledTileID) {\n // for scaling the magnitude of a points slope by its latitude\n const tilesAtZoom = Math.pow(2, tileID.canonical.z);\n const y = tileID.canonical.y;\n return [\n new MercatorCoordinate(0, y / tilesAtZoom).toLngLat().lat,\n new MercatorCoordinate(0, (y + 1) / tilesAtZoom).toLngLat().lat];\n}\n\nexport {\n hillshadeUniforms,\n hillshadePrepareUniforms,\n hillshadeUniformValues,\n hillshadeUniformPrepareValues\n};\n","import {Uniform1i, Uniform1f, Uniform2f, Uniform3f, UniformMatrix4f} from '../uniform_binding';\nimport {pixelsToTileUnits} from '../../source/pixels_to_tile_units';\nimport {extend} from '../../util/util';\n\nimport type {Context} from '../../gl/context';\nimport type {UniformValues, UniformLocations} from '../uniform_binding';\nimport type {Transform} from '../../geo/transform';\nimport type {Tile} from '../../source/tile';\nimport type {CrossFaded} from '../../style/properties';\nimport type {LineStyleLayer} from '../../style/style_layer/line_style_layer';\nimport type {Painter} from '../painter';\nimport type {CrossfadeParameters} from '../../style/evaluation_parameters';\nimport {OverscaledTileID} from '../../source/tile_id';\n\nexport type LineUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_ratio': Uniform1f;\n 'u_device_pixel_ratio': Uniform1f;\n 'u_units_to_pixels': Uniform2f;\n};\n\nexport type LineGradientUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_ratio': Uniform1f;\n 'u_device_pixel_ratio': Uniform1f;\n 'u_units_to_pixels': Uniform2f;\n 'u_image': Uniform1i;\n 'u_image_height': Uniform1f;\n};\n\nexport type LinePatternUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_texsize': Uniform2f;\n 'u_ratio': Uniform1f;\n 'u_device_pixel_ratio': Uniform1f;\n 'u_units_to_pixels': Uniform2f;\n 'u_image': Uniform1i;\n 'u_scale': Uniform3f;\n 'u_fade': Uniform1f;\n};\n\nexport type LineSDFUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_ratio': Uniform1f;\n 'u_device_pixel_ratio': Uniform1f;\n 'u_units_to_pixels': Uniform2f;\n 'u_patternscale_a': Uniform2f;\n 'u_patternscale_b': Uniform2f;\n 'u_sdfgamma': Uniform1f;\n 'u_image': Uniform1i;\n 'u_tex_y_a': Uniform1f;\n 'u_tex_y_b': Uniform1f;\n 'u_mix': Uniform1f;\n};\n\nconst lineUniforms = (context: Context, locations: UniformLocations): LineUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_ratio': new Uniform1f(context, locations.u_ratio),\n 'u_device_pixel_ratio': new Uniform1f(context, locations.u_device_pixel_ratio),\n 'u_units_to_pixels': new Uniform2f(context, locations.u_units_to_pixels)\n});\n\nconst lineGradientUniforms = (context: Context, locations: UniformLocations): LineGradientUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_ratio': new Uniform1f(context, locations.u_ratio),\n 'u_device_pixel_ratio': new Uniform1f(context, locations.u_device_pixel_ratio),\n 'u_units_to_pixels': new Uniform2f(context, locations.u_units_to_pixels),\n 'u_image': new Uniform1i(context, locations.u_image),\n 'u_image_height': new Uniform1f(context, locations.u_image_height)\n});\n\nconst linePatternUniforms = (context: Context, locations: UniformLocations): LinePatternUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_texsize': new Uniform2f(context, locations.u_texsize),\n 'u_ratio': new Uniform1f(context, locations.u_ratio),\n 'u_device_pixel_ratio': new Uniform1f(context, locations.u_device_pixel_ratio),\n 'u_image': new Uniform1i(context, locations.u_image),\n 'u_units_to_pixels': new Uniform2f(context, locations.u_units_to_pixels),\n 'u_scale': new Uniform3f(context, locations.u_scale),\n 'u_fade': new Uniform1f(context, locations.u_fade)\n});\n\nconst lineSDFUniforms = (context: Context, locations: UniformLocations): LineSDFUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_ratio': new Uniform1f(context, locations.u_ratio),\n 'u_device_pixel_ratio': new Uniform1f(context, locations.u_device_pixel_ratio),\n 'u_units_to_pixels': new Uniform2f(context, locations.u_units_to_pixels),\n 'u_patternscale_a': new Uniform2f(context, locations.u_patternscale_a),\n 'u_patternscale_b': new Uniform2f(context, locations.u_patternscale_b),\n 'u_sdfgamma': new Uniform1f(context, locations.u_sdfgamma),\n 'u_image': new Uniform1i(context, locations.u_image),\n 'u_tex_y_a': new Uniform1f(context, locations.u_tex_y_a),\n 'u_tex_y_b': new Uniform1f(context, locations.u_tex_y_b),\n 'u_mix': new Uniform1f(context, locations.u_mix)\n});\n\nconst lineUniformValues = (\n painter: Painter,\n tile: Tile,\n layer: LineStyleLayer,\n coord: OverscaledTileID\n): UniformValues => {\n const transform = painter.transform;\n\n return {\n 'u_matrix': calculateMatrix(painter, tile, layer, coord),\n 'u_ratio': 1 / pixelsToTileUnits(tile, 1, transform.zoom),\n 'u_device_pixel_ratio': painter.pixelRatio,\n 'u_units_to_pixels': [\n 1 / transform.pixelsToGLUnits[0],\n 1 / transform.pixelsToGLUnits[1]\n ]\n };\n};\n\nconst lineGradientUniformValues = (\n painter: Painter,\n tile: Tile,\n layer: LineStyleLayer,\n imageHeight: number,\n coord: OverscaledTileID\n): UniformValues => {\n return extend(lineUniformValues(painter, tile, layer, coord), {\n 'u_image': 0,\n 'u_image_height': imageHeight,\n });\n};\n\nconst linePatternUniformValues = (\n painter: Painter,\n tile: Tile,\n layer: LineStyleLayer,\n crossfade: CrossfadeParameters,\n coord: OverscaledTileID\n): UniformValues => {\n const transform = painter.transform;\n const tileZoomRatio = calculateTileRatio(tile, transform);\n return {\n 'u_matrix': calculateMatrix(painter, tile, layer, coord),\n 'u_texsize': tile.imageAtlasTexture.size,\n // camera zoom ratio\n 'u_ratio': 1 / pixelsToTileUnits(tile, 1, transform.zoom),\n 'u_device_pixel_ratio': painter.pixelRatio,\n 'u_image': 0,\n 'u_scale': [tileZoomRatio, crossfade.fromScale, crossfade.toScale],\n 'u_fade': crossfade.t,\n 'u_units_to_pixels': [\n 1 / transform.pixelsToGLUnits[0],\n 1 / transform.pixelsToGLUnits[1]\n ]\n };\n};\n\nconst lineSDFUniformValues = (\n painter: Painter,\n tile: Tile,\n layer: LineStyleLayer,\n dasharray: CrossFaded>,\n crossfade: CrossfadeParameters,\n coord: OverscaledTileID\n): UniformValues => {\n const transform = painter.transform;\n const lineAtlas = painter.lineAtlas;\n const tileRatio = calculateTileRatio(tile, transform);\n\n const round = layer.layout.get('line-cap') === 'round';\n\n const posA = lineAtlas.getDash(dasharray.from, round);\n const posB = lineAtlas.getDash(dasharray.to, round);\n\n const widthA = posA.width * crossfade.fromScale;\n const widthB = posB.width * crossfade.toScale;\n\n return extend(lineUniformValues(painter, tile, layer, coord), {\n 'u_patternscale_a': [tileRatio / widthA, -posA.height / 2],\n 'u_patternscale_b': [tileRatio / widthB, -posB.height / 2],\n 'u_sdfgamma': lineAtlas.width / (Math.min(widthA, widthB) * 256 * painter.pixelRatio) / 2,\n 'u_image': 0,\n 'u_tex_y_a': posA.y,\n 'u_tex_y_b': posB.y,\n 'u_mix': crossfade.t\n });\n};\n\nfunction calculateTileRatio(tile: Tile, transform: Transform) {\n return 1 / pixelsToTileUnits(tile, 1, transform.tileZoom);\n}\n\nfunction calculateMatrix(painter: Painter, tile: Tile, layer: LineStyleLayer, coord: OverscaledTileID) {\n return painter.translatePosMatrix(\n coord ? coord.posMatrix : tile.tileID.posMatrix,\n tile,\n layer.paint.get('line-translate'),\n layer.paint.get('line-translate-anchor')\n );\n}\n\nexport {\n lineUniforms,\n lineGradientUniforms,\n linePatternUniforms,\n lineSDFUniforms,\n lineUniformValues,\n lineGradientUniformValues,\n linePatternUniformValues,\n lineSDFUniformValues\n};\n","import {Uniform1i, Uniform1f, Uniform2f, Uniform3f, UniformMatrix4f} from '../uniform_binding';\n\nimport type {Context} from '../../gl/context';\nimport type {UniformValues, UniformLocations} from '../uniform_binding';\nimport type {RasterStyleLayer} from '../../style/style_layer/raster_style_layer';\nimport {mat4} from 'gl-matrix';\n\nexport type RasterUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_tl_parent': Uniform2f;\n 'u_scale_parent': Uniform1f;\n 'u_buffer_scale': Uniform1f;\n 'u_fade_t': Uniform1f;\n 'u_opacity': Uniform1f;\n 'u_image0': Uniform1i;\n 'u_image1': Uniform1i;\n 'u_brightness_low': Uniform1f;\n 'u_brightness_high': Uniform1f;\n 'u_saturation_factor': Uniform1f;\n 'u_contrast_factor': Uniform1f;\n 'u_spin_weights': Uniform3f;\n};\n\nconst rasterUniforms = (context: Context, locations: UniformLocations): RasterUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_tl_parent': new Uniform2f(context, locations.u_tl_parent),\n 'u_scale_parent': new Uniform1f(context, locations.u_scale_parent),\n 'u_buffer_scale': new Uniform1f(context, locations.u_buffer_scale),\n 'u_fade_t': new Uniform1f(context, locations.u_fade_t),\n 'u_opacity': new Uniform1f(context, locations.u_opacity),\n 'u_image0': new Uniform1i(context, locations.u_image0),\n 'u_image1': new Uniform1i(context, locations.u_image1),\n 'u_brightness_low': new Uniform1f(context, locations.u_brightness_low),\n 'u_brightness_high': new Uniform1f(context, locations.u_brightness_high),\n 'u_saturation_factor': new Uniform1f(context, locations.u_saturation_factor),\n 'u_contrast_factor': new Uniform1f(context, locations.u_contrast_factor),\n 'u_spin_weights': new Uniform3f(context, locations.u_spin_weights)\n});\n\nconst rasterUniformValues = (\n matrix: mat4,\n parentTL: [number, number],\n parentScaleBy: number,\n fade: {\n mix: number;\n opacity: number;\n },\n layer: RasterStyleLayer\n): UniformValues => ({\n 'u_matrix': matrix,\n 'u_tl_parent': parentTL,\n 'u_scale_parent': parentScaleBy,\n 'u_buffer_scale': 1,\n 'u_fade_t': fade.mix,\n 'u_opacity': fade.opacity * layer.paint.get('raster-opacity'),\n 'u_image0': 0,\n 'u_image1': 1,\n 'u_brightness_low': layer.paint.get('raster-brightness-min'),\n 'u_brightness_high': layer.paint.get('raster-brightness-max'),\n 'u_saturation_factor': saturationFactor(layer.paint.get('raster-saturation')),\n 'u_contrast_factor': contrastFactor(layer.paint.get('raster-contrast')),\n 'u_spin_weights': spinWeights(layer.paint.get('raster-hue-rotate'))\n});\n\nfunction spinWeights(angle) {\n angle *= Math.PI / 180;\n const s = Math.sin(angle);\n const c = Math.cos(angle);\n return [\n (2 * c + 1) / 3,\n (-Math.sqrt(3) * s - c + 1) / 3,\n (Math.sqrt(3) * s - c + 1) / 3\n ];\n}\n\nfunction contrastFactor(contrast) {\n return contrast > 0 ?\n 1 / (1 - contrast) :\n 1 + contrast;\n}\n\nfunction saturationFactor(saturation) {\n return saturation > 0 ?\n 1 - 1 / (1.001 - saturation) :\n -saturation;\n}\n\nexport {rasterUniforms, rasterUniformValues};\n","import {Uniform1i, Uniform1f, Uniform2f, UniformMatrix4f} from '../uniform_binding';\nimport {extend} from '../../util/util';\n\nimport type {Context} from '../../gl/context';\nimport type {Painter} from '../painter';\nimport type {UniformValues, UniformLocations} from '../uniform_binding';\nimport {mat4} from 'gl-matrix';\n\nexport type SymbolIconUniformsType = {\n 'u_is_size_zoom_constant': Uniform1i;\n 'u_is_size_feature_constant': Uniform1i;\n 'u_size_t': Uniform1f;\n 'u_size': Uniform1f;\n 'u_camera_to_center_distance': Uniform1f;\n 'u_pitch': Uniform1f;\n 'u_rotate_symbol': Uniform1i;\n 'u_aspect_ratio': Uniform1f;\n 'u_fade_change': Uniform1f;\n 'u_matrix': UniformMatrix4f;\n 'u_label_plane_matrix': UniformMatrix4f;\n 'u_coord_matrix': UniformMatrix4f;\n 'u_is_text': Uniform1i;\n 'u_pitch_with_map': Uniform1i;\n 'u_is_along_line': Uniform1i;\n 'u_is_variable_anchor': Uniform1i;\n 'u_texsize': Uniform2f;\n 'u_texture': Uniform1i;\n 'u_translation': Uniform2f;\n 'u_pitched_scale': Uniform1f;\n};\n\nexport type SymbolSDFUniformsType = {\n 'u_is_size_zoom_constant': Uniform1i;\n 'u_is_size_feature_constant': Uniform1i;\n 'u_size_t': Uniform1f;\n 'u_size': Uniform1f;\n 'u_camera_to_center_distance': Uniform1f;\n 'u_pitch': Uniform1f;\n 'u_rotate_symbol': Uniform1i;\n 'u_aspect_ratio': Uniform1f;\n 'u_fade_change': Uniform1f;\n 'u_matrix': UniformMatrix4f;\n 'u_label_plane_matrix': UniformMatrix4f;\n 'u_coord_matrix': UniformMatrix4f;\n 'u_is_text': Uniform1i;\n 'u_pitch_with_map': Uniform1i;\n 'u_is_along_line': Uniform1i;\n 'u_is_variable_anchor': Uniform1i;\n 'u_texsize': Uniform2f;\n 'u_texture': Uniform1i;\n 'u_gamma_scale': Uniform1f;\n 'u_device_pixel_ratio': Uniform1f;\n 'u_is_halo': Uniform1i;\n 'u_translation': Uniform2f;\n 'u_pitched_scale': Uniform1f;\n};\n\nexport type symbolTextAndIconUniformsType = {\n 'u_is_size_zoom_constant': Uniform1i;\n 'u_is_size_feature_constant': Uniform1i;\n 'u_size_t': Uniform1f;\n 'u_size': Uniform1f;\n 'u_camera_to_center_distance': Uniform1f;\n 'u_pitch': Uniform1f;\n 'u_rotate_symbol': Uniform1i;\n 'u_aspect_ratio': Uniform1f;\n 'u_fade_change': Uniform1f;\n 'u_matrix': UniformMatrix4f;\n 'u_label_plane_matrix': UniformMatrix4f;\n 'u_coord_matrix': UniformMatrix4f;\n 'u_is_text': Uniform1i;\n 'u_pitch_with_map': Uniform1i;\n 'u_is_along_line': Uniform1i;\n 'u_is_variable_anchor': Uniform1i;\n 'u_texsize': Uniform2f;\n 'u_texsize_icon': Uniform2f;\n 'u_texture': Uniform1i;\n 'u_texture_icon': Uniform1i;\n 'u_gamma_scale': Uniform1f;\n 'u_device_pixel_ratio': Uniform1f;\n 'u_is_halo': Uniform1i;\n 'u_translation': Uniform2f;\n 'u_pitched_scale': Uniform1f;\n};\n\nconst symbolIconUniforms = (context: Context, locations: UniformLocations): SymbolIconUniformsType => ({\n 'u_is_size_zoom_constant': new Uniform1i(context, locations.u_is_size_zoom_constant),\n 'u_is_size_feature_constant': new Uniform1i(context, locations.u_is_size_feature_constant),\n 'u_size_t': new Uniform1f(context, locations.u_size_t),\n 'u_size': new Uniform1f(context, locations.u_size),\n 'u_camera_to_center_distance': new Uniform1f(context, locations.u_camera_to_center_distance),\n 'u_pitch': new Uniform1f(context, locations.u_pitch),\n 'u_rotate_symbol': new Uniform1i(context, locations.u_rotate_symbol),\n 'u_aspect_ratio': new Uniform1f(context, locations.u_aspect_ratio),\n 'u_fade_change': new Uniform1f(context, locations.u_fade_change),\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_label_plane_matrix': new UniformMatrix4f(context, locations.u_label_plane_matrix),\n 'u_coord_matrix': new UniformMatrix4f(context, locations.u_coord_matrix),\n 'u_is_text': new Uniform1i(context, locations.u_is_text),\n 'u_pitch_with_map': new Uniform1i(context, locations.u_pitch_with_map),\n 'u_is_along_line': new Uniform1i(context, locations.u_is_along_line),\n 'u_is_variable_anchor': new Uniform1i(context, locations.u_is_variable_anchor),\n 'u_texsize': new Uniform2f(context, locations.u_texsize),\n 'u_texture': new Uniform1i(context, locations.u_texture),\n 'u_translation': new Uniform2f(context, locations.u_translation),\n 'u_pitched_scale': new Uniform1f(context, locations.u_pitched_scale),\n});\n\nconst symbolSDFUniforms = (context: Context, locations: UniformLocations): SymbolSDFUniformsType => ({\n 'u_is_size_zoom_constant': new Uniform1i(context, locations.u_is_size_zoom_constant),\n 'u_is_size_feature_constant': new Uniform1i(context, locations.u_is_size_feature_constant),\n 'u_size_t': new Uniform1f(context, locations.u_size_t),\n 'u_size': new Uniform1f(context, locations.u_size),\n 'u_camera_to_center_distance': new Uniform1f(context, locations.u_camera_to_center_distance),\n 'u_pitch': new Uniform1f(context, locations.u_pitch),\n 'u_rotate_symbol': new Uniform1i(context, locations.u_rotate_symbol),\n 'u_aspect_ratio': new Uniform1f(context, locations.u_aspect_ratio),\n 'u_fade_change': new Uniform1f(context, locations.u_fade_change),\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_label_plane_matrix': new UniformMatrix4f(context, locations.u_label_plane_matrix),\n 'u_coord_matrix': new UniformMatrix4f(context, locations.u_coord_matrix),\n 'u_is_text': new Uniform1i(context, locations.u_is_text),\n 'u_pitch_with_map': new Uniform1i(context, locations.u_pitch_with_map),\n 'u_is_along_line': new Uniform1i(context, locations.u_is_along_line),\n 'u_is_variable_anchor': new Uniform1i(context, locations.u_is_variable_anchor),\n 'u_texsize': new Uniform2f(context, locations.u_texsize),\n 'u_texture': new Uniform1i(context, locations.u_texture),\n 'u_gamma_scale': new Uniform1f(context, locations.u_gamma_scale),\n 'u_device_pixel_ratio': new Uniform1f(context, locations.u_device_pixel_ratio),\n 'u_is_halo': new Uniform1i(context, locations.u_is_halo),\n 'u_translation': new Uniform2f(context, locations.u_translation),\n 'u_pitched_scale': new Uniform1f(context, locations.u_pitched_scale),\n});\n\nconst symbolTextAndIconUniforms = (context: Context, locations: UniformLocations): symbolTextAndIconUniformsType => ({\n 'u_is_size_zoom_constant': new Uniform1i(context, locations.u_is_size_zoom_constant),\n 'u_is_size_feature_constant': new Uniform1i(context, locations.u_is_size_feature_constant),\n 'u_size_t': new Uniform1f(context, locations.u_size_t),\n 'u_size': new Uniform1f(context, locations.u_size),\n 'u_camera_to_center_distance': new Uniform1f(context, locations.u_camera_to_center_distance),\n 'u_pitch': new Uniform1f(context, locations.u_pitch),\n 'u_rotate_symbol': new Uniform1i(context, locations.u_rotate_symbol),\n 'u_aspect_ratio': new Uniform1f(context, locations.u_aspect_ratio),\n 'u_fade_change': new Uniform1f(context, locations.u_fade_change),\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_label_plane_matrix': new UniformMatrix4f(context, locations.u_label_plane_matrix),\n 'u_coord_matrix': new UniformMatrix4f(context, locations.u_coord_matrix),\n 'u_is_text': new Uniform1i(context, locations.u_is_text),\n 'u_pitch_with_map': new Uniform1i(context, locations.u_pitch_with_map),\n 'u_is_along_line': new Uniform1i(context, locations.u_is_along_line),\n 'u_is_variable_anchor': new Uniform1i(context, locations.u_is_variable_anchor),\n 'u_texsize': new Uniform2f(context, locations.u_texsize),\n 'u_texsize_icon': new Uniform2f(context, locations.u_texsize_icon),\n 'u_texture': new Uniform1i(context, locations.u_texture),\n 'u_texture_icon': new Uniform1i(context, locations.u_texture_icon),\n 'u_gamma_scale': new Uniform1f(context, locations.u_gamma_scale),\n 'u_device_pixel_ratio': new Uniform1f(context, locations.u_device_pixel_ratio),\n 'u_is_halo': new Uniform1i(context, locations.u_is_halo),\n 'u_translation': new Uniform2f(context, locations.u_translation),\n 'u_pitched_scale': new Uniform1f(context, locations.u_pitched_scale),\n});\n\nconst symbolIconUniformValues = (\n functionType: string,\n size: {\n uSizeT: number;\n uSize: number;\n },\n rotateInShader: boolean,\n pitchWithMap: boolean,\n isAlongLine: boolean,\n isVariableAnchor: boolean,\n painter: Painter,\n matrix: mat4,\n labelPlaneMatrix: mat4,\n glCoordMatrix: mat4,\n translation: [number, number],\n isText: boolean,\n texSize: [number, number],\n pitchedScale: number\n): UniformValues => {\n const transform = painter.transform;\n\n return {\n 'u_is_size_zoom_constant': +(functionType === 'constant' || functionType === 'source'),\n 'u_is_size_feature_constant': +(functionType === 'constant' || functionType === 'camera'),\n 'u_size_t': size ? size.uSizeT : 0,\n 'u_size': size ? size.uSize : 0,\n 'u_camera_to_center_distance': transform.cameraToCenterDistance,\n 'u_pitch': transform.pitch / 360 * 2 * Math.PI,\n 'u_rotate_symbol': +rotateInShader,\n 'u_aspect_ratio': transform.width / transform.height,\n 'u_fade_change': painter.options.fadeDuration ? painter.symbolFadeChange : 1,\n 'u_matrix': matrix,\n 'u_label_plane_matrix': labelPlaneMatrix,\n 'u_coord_matrix': glCoordMatrix,\n 'u_is_text': +isText,\n 'u_pitch_with_map': +pitchWithMap,\n 'u_is_along_line': isAlongLine,\n 'u_is_variable_anchor': isVariableAnchor,\n 'u_texsize': texSize,\n 'u_texture': 0,\n 'u_translation': translation,\n 'u_pitched_scale': pitchedScale\n };\n};\n\nconst symbolSDFUniformValues = (\n functionType: string,\n size: {\n uSizeT: number;\n uSize: number;\n },\n rotateInShader: boolean,\n pitchWithMap: boolean,\n isAlongLine: boolean,\n isVariableAnchor: boolean,\n painter: Painter,\n matrix: mat4,\n labelPlaneMatrix: mat4,\n glCoordMatrix: mat4,\n translation: [number, number],\n isText: boolean,\n texSize: [number, number],\n isHalo: boolean,\n pitchedScale: number\n): UniformValues => {\n const transform = painter.transform;\n\n return extend(symbolIconUniformValues(functionType, size,\n rotateInShader, pitchWithMap, isAlongLine, isVariableAnchor, painter, matrix, labelPlaneMatrix,\n glCoordMatrix, translation, isText, texSize, pitchedScale), {\n 'u_gamma_scale': (pitchWithMap ? Math.cos(transform._pitch) * transform.cameraToCenterDistance : 1),\n 'u_device_pixel_ratio': painter.pixelRatio,\n 'u_is_halo': +isHalo\n });\n};\n\nconst symbolTextAndIconUniformValues = (\n functionType: string,\n size: {\n uSizeT: number;\n uSize: number;\n },\n rotateInShader: boolean,\n pitchWithMap: boolean,\n isAlongLine: boolean,\n isVariableAnchor: boolean,\n painter: Painter,\n matrix: mat4,\n labelPlaneMatrix: mat4,\n glCoordMatrix: mat4,\n translation: [number, number],\n texSizeSDF: [number, number],\n texSizeIcon: [number, number],\n pitchedScale: number\n): UniformValues => {\n return extend(symbolSDFUniformValues(functionType, size,\n rotateInShader, pitchWithMap, isAlongLine, isVariableAnchor, painter, matrix, labelPlaneMatrix,\n glCoordMatrix, translation, true, texSizeSDF, true, pitchedScale), {\n 'u_texsize_icon': texSizeIcon,\n 'u_texture_icon': 1\n });\n};\n\nexport {symbolIconUniforms, symbolSDFUniforms, symbolIconUniformValues, symbolSDFUniformValues, symbolTextAndIconUniformValues, symbolTextAndIconUniforms};\n","import {bgPatternUniformValues} from './pattern';\nimport {\n Uniform1i,\n Uniform1f,\n Uniform2f,\n UniformColor,\n UniformMatrix4f\n} from '../uniform_binding';\nimport {extend} from '../../util/util';\n\nimport type {Painter} from '../painter';\nimport type {UniformValues, UniformLocations} from '../uniform_binding';\nimport type {Context} from '../../gl/context';\nimport type {Color, ResolvedImage} from '@maplibre/maplibre-gl-style-spec';\nimport type {CrossFaded} from '../../style/properties';\nimport type {CrossfadeParameters} from '../../style/evaluation_parameters';\nimport type {OverscaledTileID} from '../../source/tile_id';\nimport {mat4} from 'gl-matrix';\n\nexport type BackgroundUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_opacity': Uniform1f;\n 'u_color': UniformColor;\n};\n\nexport type BackgroundPatternUniformsType = {\n 'u_matrix': UniformMatrix4f;\n 'u_opacity': Uniform1f;\n // pattern uniforms:\n 'u_image': Uniform1i;\n 'u_pattern_tl_a': Uniform2f;\n 'u_pattern_br_a': Uniform2f;\n 'u_pattern_tl_b': Uniform2f;\n 'u_pattern_br_b': Uniform2f;\n 'u_texsize': Uniform2f;\n 'u_mix': Uniform1f;\n 'u_pattern_size_a': Uniform2f;\n 'u_pattern_size_b': Uniform2f;\n 'u_scale_a': Uniform1f;\n 'u_scale_b': Uniform1f;\n 'u_pixel_coord_upper': Uniform2f;\n 'u_pixel_coord_lower': Uniform2f;\n 'u_tile_units_to_pixels': Uniform1f;\n};\n\nconst backgroundUniforms = (context: Context, locations: UniformLocations): BackgroundUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_opacity': new Uniform1f(context, locations.u_opacity),\n 'u_color': new UniformColor(context, locations.u_color)\n});\n\nconst backgroundPatternUniforms = (context: Context, locations: UniformLocations): BackgroundPatternUniformsType => ({\n 'u_matrix': new UniformMatrix4f(context, locations.u_matrix),\n 'u_opacity': new Uniform1f(context, locations.u_opacity),\n 'u_image': new Uniform1i(context, locations.u_image),\n 'u_pattern_tl_a': new Uniform2f(context, locations.u_pattern_tl_a),\n 'u_pattern_br_a': new Uniform2f(context, locations.u_pattern_br_a),\n 'u_pattern_tl_b': new Uniform2f(context, locations.u_pattern_tl_b),\n 'u_pattern_br_b': new Uniform2f(context, locations.u_pattern_br_b),\n 'u_texsize': new Uniform2f(context, locations.u_texsize),\n 'u_mix': new Uniform1f(context, locations.u_mix),\n 'u_pattern_size_a': new Uniform2f(context, locations.u_pattern_size_a),\n 'u_pattern_size_b': new Uniform2f(context, locations.u_pattern_size_b),\n 'u_scale_a': new Uniform1f(context, locations.u_scale_a),\n 'u_scale_b': new Uniform1f(context, locations.u_scale_b),\n 'u_pixel_coord_upper': new Uniform2f(context, locations.u_pixel_coord_upper),\n 'u_pixel_coord_lower': new Uniform2f(context, locations.u_pixel_coord_lower),\n 'u_tile_units_to_pixels': new Uniform1f(context, locations.u_tile_units_to_pixels)\n});\n\nconst backgroundUniformValues = (matrix: mat4, opacity: number, color: Color): UniformValues => ({\n 'u_matrix': matrix,\n 'u_opacity': opacity,\n 'u_color': color\n});\n\nconst backgroundPatternUniformValues = (\n matrix: mat4,\n opacity: number,\n painter: Painter,\n image: CrossFaded,\n tile: {\n tileID: OverscaledTileID;\n tileSize: number;\n },\n crossfade: CrossfadeParameters\n): UniformValues => extend(\n bgPatternUniformValues(image, crossfade, painter, tile),\n {\n 'u_matrix': matrix,\n 'u_opacity': opacity\n }\n);\n\nexport {\n backgroundUniforms,\n backgroundPatternUniforms,\n backgroundUniformValues,\n backgroundPatternUniformValues\n};\n","import {UniformColor, Uniform1f} from '../uniform_binding';\nimport type {Context} from '../../gl/context';\nimport type {UniformValues, UniformLocations} from '../uniform_binding';\nimport {Transform} from '../../geo/transform';\nimport {Sky} from '../../style/sky';\n\nexport type SkyUniformsType = {\n 'u_sky_color': UniformColor;\n 'u_horizon_color': UniformColor;\n 'u_horizon': Uniform1f;\n 'u_sky_horizon_blend': Uniform1f;\n};\n\nconst skyUniforms = (context: Context, locations: UniformLocations): SkyUniformsType => ({\n 'u_sky_color': new UniformColor(context, locations.u_sky_color),\n 'u_horizon_color': new UniformColor(context, locations.u_horizon_color),\n 'u_horizon': new Uniform1f(context, locations.u_horizon),\n 'u_sky_horizon_blend': new Uniform1f(context, locations.u_sky_horizon_blend),\n});\n\nconst skyUniformValues = (sky: Sky, transform: Transform, pixelRatio: number): UniformValues => ({\n 'u_sky_color': sky.properties.get('sky-color'),\n 'u_horizon_color': sky.properties.get('horizon-color'),\n 'u_horizon': (transform.height / 2 + transform.getHorizon()) * pixelRatio,\n 'u_sky_horizon_blend': (sky.properties.get('sky-horizon-blend') * transform.height / 2) * pixelRatio,\n});\n\nexport {skyUniforms, skyUniformValues};\n","import {fillExtrusionUniforms, fillExtrusionPatternUniforms} from './fill_extrusion_program';\nimport {fillUniforms, fillPatternUniforms, fillOutlineUniforms, fillOutlinePatternUniforms} from './fill_program';\nimport {circleUniforms} from './circle_program';\nimport {collisionUniforms, collisionCircleUniforms} from './collision_program';\nimport {debugUniforms} from './debug_program';\nimport {clippingMaskUniforms} from './clipping_mask_program';\nimport {heatmapUniforms, heatmapTextureUniforms} from './heatmap_program';\nimport {hillshadeUniforms, hillshadePrepareUniforms} from './hillshade_program';\nimport {lineUniforms, lineGradientUniforms, linePatternUniforms, lineSDFUniforms} from './line_program';\nimport {rasterUniforms} from './raster_program';\nimport {symbolIconUniforms, symbolSDFUniforms, symbolTextAndIconUniforms} from './symbol_program';\nimport {backgroundUniforms, backgroundPatternUniforms} from './background_program';\nimport {terrainUniforms, terrainDepthUniforms, terrainCoordsUniforms} from './terrain_program';\nimport {skyUniforms} from './sky_program';\n\nexport const programUniforms = {\n fillExtrusion: fillExtrusionUniforms,\n fillExtrusionPattern: fillExtrusionPatternUniforms,\n fill: fillUniforms,\n fillPattern: fillPatternUniforms,\n fillOutline: fillOutlineUniforms,\n fillOutlinePattern: fillOutlinePatternUniforms,\n circle: circleUniforms,\n collisionBox: collisionUniforms,\n collisionCircle: collisionCircleUniforms,\n debug: debugUniforms,\n clippingMask: clippingMaskUniforms,\n heatmap: heatmapUniforms,\n heatmapTexture: heatmapTextureUniforms,\n hillshade: hillshadeUniforms,\n hillshadePrepare: hillshadePrepareUniforms,\n line: lineUniforms,\n lineGradient: lineGradientUniforms,\n linePattern: linePatternUniforms,\n lineSDF: lineSDFUniforms,\n raster: rasterUniforms,\n symbolIcon: symbolIconUniforms,\n symbolSDF: symbolSDFUniforms,\n symbolTextAndIcon: symbolTextAndIconUniforms,\n background: backgroundUniforms,\n backgroundPattern: backgroundPatternUniforms,\n terrain: terrainUniforms,\n terrainDepth: terrainDepthUniforms,\n terrainCoords: terrainCoordsUniforms,\n sky: skyUniforms\n};\n","\nimport type {StructArray} from '../util/struct_array';\nimport type {TriangleIndexArray, LineIndexArray, LineStripIndexArray} from '../data/index_array_type';\nimport type {Context} from '../gl/context';\n\n/**\n * @internal\n * an index buffer class\n */\nexport class IndexBuffer {\n context: Context;\n buffer: WebGLBuffer;\n dynamicDraw: boolean;\n\n constructor(context: Context, array: TriangleIndexArray | LineIndexArray | LineStripIndexArray, dynamicDraw?: boolean) {\n this.context = context;\n const gl = context.gl;\n this.buffer = gl.createBuffer();\n this.dynamicDraw = Boolean(dynamicDraw);\n\n // The bound index buffer is part of vertex array object state. We don't want to\n // modify whatever VAO happens to be currently bound, so make sure the default\n // vertex array provided by the context is bound instead.\n this.context.unbindVAO();\n\n context.bindElementBuffer.set(this.buffer);\n gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, array.arrayBuffer, this.dynamicDraw ? gl.DYNAMIC_DRAW : gl.STATIC_DRAW);\n\n if (!this.dynamicDraw) {\n delete array.arrayBuffer;\n }\n }\n\n bind() {\n this.context.bindElementBuffer.set(this.buffer);\n }\n\n updateData(array: StructArray) {\n const gl = this.context.gl;\n if (!this.dynamicDraw) throw new Error('Attempted to update data while not in dynamic mode.');\n // The right VAO will get this buffer re-bound later in VertexArrayObject#bind\n // See https://github.com/mapbox/mapbox-gl-js/issues/5620\n this.context.unbindVAO();\n this.bind();\n gl.bufferSubData(gl.ELEMENT_ARRAY_BUFFER, 0, array.arrayBuffer);\n }\n\n destroy() {\n const gl = this.context.gl;\n if (this.buffer) {\n gl.deleteBuffer(this.buffer);\n delete this.buffer;\n }\n }\n}\n","\nimport type {\n StructArray,\n StructArrayMember\n} from '../util/struct_array';\n\nimport type {Program} from '../render/program';\nimport type {Context} from '../gl/context';\n\n/**\n * An Enum for AttributeType\n */\nconst AttributeType = {\n Int8: 'BYTE',\n Uint8: 'UNSIGNED_BYTE',\n Int16: 'SHORT',\n Uint16: 'UNSIGNED_SHORT',\n Int32: 'INT',\n Uint32: 'UNSIGNED_INT',\n Float32: 'FLOAT'\n};\n\n/**\n * @internal\n * The `VertexBuffer` class turns a `StructArray` into a WebGL buffer. Each member of the StructArray's\n * Struct type is converted to a WebGL attribute.\n */\nexport class VertexBuffer {\n length: number;\n attributes: ReadonlyArray;\n itemSize: number;\n dynamicDraw: boolean;\n context: Context;\n buffer: WebGLBuffer;\n\n /**\n * @param dynamicDraw - Whether this buffer will be repeatedly updated.\n */\n constructor(context: Context, array: StructArray, attributes: ReadonlyArray, dynamicDraw?: boolean) {\n this.length = array.length;\n this.attributes = attributes;\n this.itemSize = array.bytesPerElement;\n this.dynamicDraw = dynamicDraw;\n\n this.context = context;\n const gl = context.gl;\n this.buffer = gl.createBuffer();\n context.bindVertexBuffer.set(this.buffer);\n gl.bufferData(gl.ARRAY_BUFFER, array.arrayBuffer, this.dynamicDraw ? gl.DYNAMIC_DRAW : gl.STATIC_DRAW);\n\n if (!this.dynamicDraw) {\n delete array.arrayBuffer;\n }\n }\n\n bind() {\n this.context.bindVertexBuffer.set(this.buffer);\n }\n\n updateData(array: StructArray) {\n if (array.length !== this.length) throw new Error(`Length of new data is ${array.length}, which doesn't match current length of ${this.length}`);\n const gl = this.context.gl;\n this.bind();\n gl.bufferSubData(gl.ARRAY_BUFFER, 0, array.arrayBuffer);\n }\n\n enableAttributes(gl: WebGLRenderingContext|WebGL2RenderingContext, program: Program) {\n for (let j = 0; j < this.attributes.length; j++) {\n const member = this.attributes[j];\n const attribIndex: number | void = program.attributes[member.name];\n if (attribIndex !== undefined) {\n gl.enableVertexAttribArray(attribIndex);\n }\n }\n }\n\n /**\n * Set the attribute pointers in a WebGL context\n * @param gl - The WebGL context\n * @param program - The active WebGL program\n * @param vertexOffset - Index of the starting vertex of the segment\n */\n setVertexAttribPointers(gl: WebGLRenderingContext|WebGL2RenderingContext, program: Program, vertexOffset?: number | null) {\n for (let j = 0; j < this.attributes.length; j++) {\n const member = this.attributes[j];\n const attribIndex: number | void = program.attributes[member.name];\n\n if (attribIndex !== undefined) {\n gl.vertexAttribPointer(\n attribIndex,\n member.components,\n (gl as any)[AttributeType[member.type]],\n false,\n this.itemSize,\n member.offset + (this.itemSize * (vertexOffset || 0))\n );\n }\n }\n }\n\n /**\n * Destroy the GL buffer bound to the given WebGL context\n */\n destroy() {\n const gl = this.context.gl;\n if (this.buffer) {\n gl.deleteBuffer(this.buffer);\n delete this.buffer;\n }\n }\n}\n","const cache = new WeakMap();\nexport function isWebGL2(\n gl: WebGLRenderingContext | WebGL2RenderingContext\n): gl is WebGL2RenderingContext {\n if (cache.has(gl)) {\n return cache.get(gl);\n } else {\n const value = gl.getParameter(gl.VERSION)?.startsWith('WebGL 2.0');\n cache.set(gl, value);\n return value;\n }\n}\n","import {Color} from '@maplibre/maplibre-gl-style-spec';\nimport {isWebGL2} from './webgl2';\n\nimport type {Context} from './context';\nimport type {\n BlendFuncType,\n BlendEquationType,\n ColorMaskType,\n DepthRangeType,\n DepthMaskType,\n StencilFuncType,\n StencilOpType,\n DepthFuncType,\n TextureUnitType,\n ViewportType,\n CullFaceModeType,\n FrontFaceType,\n} from './types';\n\nexport interface IValue {\n current: T;\n default: T;\n dirty: boolean;\n get(): T;\n setDefault(): void;\n set(value: T): void;\n}\n\nclass BaseValue implements IValue {\n gl: WebGLRenderingContext|WebGL2RenderingContext;\n current: T;\n default: T;\n dirty: boolean;\n\n constructor(context: Context) {\n this.gl = context.gl;\n this.default = this.getDefault();\n this.current = this.default;\n this.dirty = false;\n }\n\n get(): T {\n return this.current;\n }\n set(value: T) { // eslint-disable-line\n // overridden in child classes;\n }\n\n getDefault(): T {\n return this.default; // overridden in child classes\n }\n setDefault() {\n this.set(this.default);\n }\n}\n\nexport class ClearColor extends BaseValue {\n getDefault(): Color {\n return Color.transparent;\n }\n set(v: Color) {\n const c = this.current;\n if (v.r === c.r && v.g === c.g && v.b === c.b && v.a === c.a && !this.dirty) return;\n this.gl.clearColor(v.r, v.g, v.b, v.a);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class ClearDepth extends BaseValue {\n getDefault(): number {\n return 1;\n }\n set(v: number) {\n if (v === this.current && !this.dirty) return;\n this.gl.clearDepth(v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class ClearStencil extends BaseValue {\n getDefault(): number {\n return 0;\n }\n set(v: number) {\n if (v === this.current && !this.dirty) return;\n this.gl.clearStencil(v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class ColorMask extends BaseValue {\n getDefault(): ColorMaskType {\n return [true, true, true, true];\n }\n set(v: ColorMaskType) {\n const c = this.current;\n if (v[0] === c[0] && v[1] === c[1] && v[2] === c[2] && v[3] === c[3] && !this.dirty) return;\n this.gl.colorMask(v[0], v[1], v[2], v[3]);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class DepthMask extends BaseValue {\n getDefault(): DepthMaskType {\n return true;\n }\n set(v: DepthMaskType): void {\n if (v === this.current && !this.dirty) return;\n this.gl.depthMask(v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class StencilMask extends BaseValue {\n getDefault(): number {\n return 0xFF;\n }\n set(v: number): void {\n if (v === this.current && !this.dirty) return;\n this.gl.stencilMask(v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class StencilFunc extends BaseValue {\n getDefault(): StencilFuncType {\n return {\n func: this.gl.ALWAYS,\n ref: 0,\n mask: 0xFF\n };\n }\n set(v: StencilFuncType): void {\n const c = this.current;\n if (v.func === c.func && v.ref === c.ref && v.mask === c.mask && !this.dirty) return;\n this.gl.stencilFunc(v.func, v.ref, v.mask);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class StencilOp extends BaseValue {\n getDefault(): StencilOpType {\n const gl = this.gl;\n return [gl.KEEP, gl.KEEP, gl.KEEP];\n }\n set(v: StencilOpType) {\n const c = this.current;\n if (v[0] === c[0] && v[1] === c[1] && v[2] === c[2] && !this.dirty) return;\n this.gl.stencilOp(v[0], v[1], v[2]);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class StencilTest extends BaseValue {\n getDefault(): boolean {\n return false;\n }\n set(v: boolean) {\n if (v === this.current && !this.dirty) return;\n const gl = this.gl;\n if (v) {\n gl.enable(gl.STENCIL_TEST);\n } else {\n gl.disable(gl.STENCIL_TEST);\n }\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class DepthRange extends BaseValue {\n getDefault(): DepthRangeType {\n return [0, 1];\n }\n set(v: DepthRangeType) {\n const c = this.current;\n if (v[0] === c[0] && v[1] === c[1] && !this.dirty) return;\n this.gl.depthRange(v[0], v[1]);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class DepthTest extends BaseValue {\n getDefault(): boolean {\n return false;\n }\n set(v: boolean) {\n if (v === this.current && !this.dirty) return;\n const gl = this.gl;\n if (v) {\n gl.enable(gl.DEPTH_TEST);\n } else {\n gl.disable(gl.DEPTH_TEST);\n }\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class DepthFunc extends BaseValue {\n getDefault(): DepthFuncType {\n return this.gl.LESS;\n }\n set(v: DepthFuncType) {\n if (v === this.current && !this.dirty) return;\n this.gl.depthFunc(v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class Blend extends BaseValue {\n getDefault(): boolean {\n return false;\n }\n set(v: boolean) {\n if (v === this.current && !this.dirty) return;\n const gl = this.gl;\n if (v) {\n gl.enable(gl.BLEND);\n } else {\n gl.disable(gl.BLEND);\n }\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class BlendFunc extends BaseValue {\n getDefault(): BlendFuncType {\n const gl = this.gl;\n return [gl.ONE, gl.ZERO];\n }\n set(v: BlendFuncType) {\n const c = this.current;\n if (v[0] === c[0] && v[1] === c[1] && !this.dirty) return;\n this.gl.blendFunc(v[0], v[1]);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class BlendColor extends BaseValue {\n getDefault(): Color {\n return Color.transparent;\n }\n set(v: Color) {\n const c = this.current;\n if (v.r === c.r && v.g === c.g && v.b === c.b && v.a === c.a && !this.dirty) return;\n this.gl.blendColor(v.r, v.g, v.b, v.a);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class BlendEquation extends BaseValue {\n getDefault(): BlendEquationType {\n return this.gl.FUNC_ADD;\n }\n set(v: BlendEquationType) {\n if (v === this.current && !this.dirty) return;\n this.gl.blendEquation(v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class CullFace extends BaseValue {\n getDefault(): boolean {\n return false;\n }\n set(v: boolean) {\n if (v === this.current && !this.dirty) return;\n const gl = this.gl;\n if (v) {\n gl.enable(gl.CULL_FACE);\n } else {\n gl.disable(gl.CULL_FACE);\n }\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class CullFaceSide extends BaseValue {\n getDefault(): CullFaceModeType {\n return this.gl.BACK;\n }\n set(v: CullFaceModeType) {\n if (v === this.current && !this.dirty) return;\n this.gl.cullFace(v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class FrontFace extends BaseValue {\n getDefault(): FrontFaceType {\n return this.gl.CCW;\n }\n set(v: FrontFaceType) {\n if (v === this.current && !this.dirty) return;\n this.gl.frontFace(v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class ProgramValue extends BaseValue {\n getDefault(): WebGLProgram {\n return null;\n }\n set(v?: WebGLProgram | null) {\n if (v === this.current && !this.dirty) return;\n this.gl.useProgram(v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class ActiveTextureUnit extends BaseValue {\n getDefault(): TextureUnitType {\n return this.gl.TEXTURE0;\n }\n set(v: TextureUnitType) {\n if (v === this.current && !this.dirty) return;\n this.gl.activeTexture(v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class Viewport extends BaseValue {\n getDefault(): ViewportType {\n const gl = this.gl;\n return [0, 0, gl.drawingBufferWidth, gl.drawingBufferHeight];\n }\n set(v: ViewportType) {\n const c = this.current;\n if (v[0] === c[0] && v[1] === c[1] && v[2] === c[2] && v[3] === c[3] && !this.dirty) return;\n this.gl.viewport(v[0], v[1], v[2], v[3]);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class BindFramebuffer extends BaseValue {\n getDefault(): WebGLFramebuffer {\n return null;\n }\n set(v?: WebGLFramebuffer | null) {\n if (v === this.current && !this.dirty) return;\n const gl = this.gl;\n gl.bindFramebuffer(gl.FRAMEBUFFER, v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class BindRenderbuffer extends BaseValue {\n getDefault(): WebGLRenderbuffer {\n return null;\n }\n set(v?: WebGLRenderbuffer | null) {\n if (v === this.current && !this.dirty) return;\n const gl = this.gl;\n gl.bindRenderbuffer(gl.RENDERBUFFER, v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class BindTexture extends BaseValue {\n getDefault(): WebGLTexture {\n return null;\n }\n set(v?: WebGLTexture | null) {\n if (v === this.current && !this.dirty) return;\n const gl = this.gl;\n gl.bindTexture(gl.TEXTURE_2D, v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class BindVertexBuffer extends BaseValue {\n getDefault(): WebGLBuffer {\n return null;\n }\n set(v?: WebGLBuffer | null) {\n if (v === this.current && !this.dirty) return;\n const gl = this.gl;\n gl.bindBuffer(gl.ARRAY_BUFFER, v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class BindElementBuffer extends BaseValue {\n getDefault(): WebGLBuffer {\n return null;\n }\n set(v?: WebGLBuffer | null) {\n // Always rebind\n const gl = this.gl;\n gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class BindVertexArray extends BaseValue {\n getDefault(): WebGLVertexArrayObject | null {\n return null;\n }\n set(v: WebGLVertexArrayObject | null) {\n if (v === this.current && !this.dirty) return;\n const gl = this.gl;\n\n if (isWebGL2(gl)) {\n gl.bindVertexArray(v);\n } else {\n gl.getExtension('OES_vertex_array_object')?.bindVertexArrayOES(v);\n }\n\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class PixelStoreUnpack extends BaseValue {\n getDefault(): number {\n return 4;\n }\n set(v: number) {\n if (v === this.current && !this.dirty) return;\n const gl = this.gl;\n gl.pixelStorei(gl.UNPACK_ALIGNMENT, v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class PixelStoreUnpackPremultiplyAlpha extends BaseValue {\n getDefault(): boolean {\n return false;\n }\n set(v: boolean): void {\n if (v === this.current && !this.dirty) return;\n const gl = this.gl;\n gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, ((v as any)));\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class PixelStoreUnpackFlipY extends BaseValue {\n getDefault(): boolean {\n return false;\n }\n set(v: boolean): void {\n if (v === this.current && !this.dirty) return;\n const gl = this.gl;\n gl.pixelStorei(gl.UNPACK_FLIP_Y_WEBGL, ((v as any)));\n this.current = v;\n this.dirty = false;\n }\n}\n\nclass FramebufferAttachment extends BaseValue {\n parent: WebGLFramebuffer;\n context: Context;\n\n constructor(context: Context, parent: WebGLFramebuffer) {\n super(context);\n this.context = context;\n this.parent = parent;\n }\n getDefault() {\n return null;\n }\n}\n\nexport class ColorAttachment extends FramebufferAttachment {\n setDirty() {\n this.dirty = true;\n }\n set(v?: WebGLTexture | null): void {\n if (v === this.current && !this.dirty) return;\n this.context.bindFramebuffer.set(this.parent);\n // note: it's possible to attach a renderbuffer to the color\n // attachment point, but thus far MBGL only uses textures for color\n const gl = this.gl;\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, v, 0);\n\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class DepthAttachment extends FramebufferAttachment {\n set(v?: WebGLRenderbuffer | null): void {\n if (v === this.current && !this.dirty) return;\n this.context.bindFramebuffer.set(this.parent);\n // note: it's possible to attach a texture to the depth attachment\n // point, but thus far MBGL only uses renderbuffers for depth\n const gl = this.gl;\n gl.framebufferRenderbuffer(gl.FRAMEBUFFER, gl.DEPTH_ATTACHMENT, gl.RENDERBUFFER, v);\n this.current = v;\n this.dirty = false;\n }\n}\n\nexport class DepthStencilAttachment extends FramebufferAttachment {\n set(v?: WebGLRenderbuffer | null): void {\n if (v === this.current && !this.dirty) return;\n this.context.bindFramebuffer.set(this.parent);\n // note: it's possible to attach a texture to the depth attachment\n // point, but thus far MBGL only uses renderbuffers for depth\n const gl = this.gl;\n gl.framebufferRenderbuffer(gl.FRAMEBUFFER, gl.DEPTH_STENCIL_ATTACHMENT, gl.RENDERBUFFER, v);\n this.current = v;\n this.dirty = false;\n }\n}\n","import {ColorAttachment, DepthAttachment, DepthStencilAttachment} from './value';\n\nimport type {Context} from './context';\n\n/**\n * @internal\n * A framebuffer holder object\n */\nexport class Framebuffer {\n context: Context;\n width: number;\n height: number;\n framebuffer: WebGLFramebuffer;\n colorAttachment: ColorAttachment;\n depthAttachment: DepthAttachment;\n\n constructor(context: Context, width: number, height: number, hasDepth: boolean, hasStencil: boolean) {\n this.context = context;\n this.width = width;\n this.height = height;\n const gl = context.gl;\n const fbo = this.framebuffer = gl.createFramebuffer();\n\n this.colorAttachment = new ColorAttachment(context, fbo);\n if (hasDepth) {\n this.depthAttachment = hasStencil ? new DepthStencilAttachment(context, fbo) : new DepthAttachment(context, fbo);\n } else if (hasStencil) {\n throw new Error('Stencil cannot be set without depth');\n }\n if (gl.checkFramebufferStatus(gl.FRAMEBUFFER) !== gl.FRAMEBUFFER_COMPLETE) {\n throw new Error('Framebuffer is not complete');\n }\n }\n\n destroy() {\n const gl = this.context.gl;\n\n const texture = this.colorAttachment.get();\n if (texture) gl.deleteTexture(texture);\n\n if (this.depthAttachment) {\n const renderbuffer = this.depthAttachment.get();\n if (renderbuffer) gl.deleteRenderbuffer(renderbuffer);\n }\n\n gl.deleteFramebuffer(this.framebuffer);\n }\n}\n","import {Color} from '@maplibre/maplibre-gl-style-spec';\n\nimport type {BlendFuncType, ColorMaskType} from './types';\n\nconst ZERO = 0x0000;\nconst ONE = 0x0001;\nconst ONE_MINUS_SRC_ALPHA = 0x0303;\n\nexport class ColorMode {\n blendFunction: BlendFuncType;\n blendColor: Color;\n mask: ColorMaskType;\n\n constructor(blendFunction: BlendFuncType, blendColor: Color, mask: ColorMaskType) {\n this.blendFunction = blendFunction;\n this.blendColor = blendColor;\n this.mask = mask;\n }\n\n static Replace: BlendFuncType;\n\n static disabled: Readonly;\n static unblended: Readonly;\n static alphaBlended: Readonly;\n}\n\nColorMode.Replace = [ONE, ZERO];\n\nColorMode.disabled = new ColorMode(ColorMode.Replace, Color.transparent, [false, false, false, false]);\nColorMode.unblended = new ColorMode(ColorMode.Replace, Color.transparent, [true, true, true, true]);\nColorMode.alphaBlended = new ColorMode([ONE, ONE_MINUS_SRC_ALPHA], Color.transparent, [true, true, true, true]);\n","import {IndexBuffer} from './index_buffer';\n\nimport {VertexBuffer} from './vertex_buffer';\nimport {Framebuffer} from './framebuffer';\nimport {DepthMode} from './depth_mode';\nimport {StencilMode} from './stencil_mode';\nimport {ColorMode} from './color_mode';\nimport {CullFaceMode} from './cull_face_mode';\nimport {deepEqual} from '../util/util';\nimport {ClearColor, ClearDepth, ClearStencil, ColorMask, DepthMask, StencilMask, StencilFunc, StencilOp, StencilTest, DepthRange, DepthTest, DepthFunc, Blend, BlendFunc, BlendColor, BlendEquation, CullFace, CullFaceSide, FrontFace, ProgramValue, ActiveTextureUnit, Viewport, BindFramebuffer, BindRenderbuffer, BindTexture, BindVertexBuffer, BindElementBuffer, BindVertexArray, PixelStoreUnpack, PixelStoreUnpackPremultiplyAlpha, PixelStoreUnpackFlipY} from './value';\n\nimport type {TriangleIndexArray, LineIndexArray, LineStripIndexArray} from '../data/index_array_type';\nimport type {\n StructArray,\n StructArrayMember\n} from '../util/struct_array';\nimport type {Color} from '@maplibre/maplibre-gl-style-spec';\nimport {isWebGL2} from './webgl2';\n\ntype ClearArgs = {\n color?: Color;\n depth?: number;\n stencil?: number;\n};\n\n/**\n * @internal\n * A webgl wrapper class to allow injection, mocking and abstaction\n */\nexport class Context {\n gl: WebGLRenderingContext | WebGL2RenderingContext;\n\n currentNumAttributes: number;\n maxTextureSize: number;\n\n clearColor: ClearColor;\n clearDepth: ClearDepth;\n clearStencil: ClearStencil;\n colorMask: ColorMask;\n depthMask: DepthMask;\n stencilMask: StencilMask;\n stencilFunc: StencilFunc;\n stencilOp: StencilOp;\n stencilTest: StencilTest;\n depthRange: DepthRange;\n depthTest: DepthTest;\n depthFunc: DepthFunc;\n blend: Blend;\n blendFunc: BlendFunc;\n blendColor: BlendColor;\n blendEquation: BlendEquation;\n cullFace: CullFace;\n cullFaceSide: CullFaceSide;\n frontFace: FrontFace;\n program: ProgramValue;\n activeTexture: ActiveTextureUnit;\n viewport: Viewport;\n bindFramebuffer: BindFramebuffer;\n bindRenderbuffer: BindRenderbuffer;\n bindTexture: BindTexture;\n bindVertexBuffer: BindVertexBuffer;\n bindElementBuffer: BindElementBuffer;\n bindVertexArray: BindVertexArray;\n pixelStoreUnpack: PixelStoreUnpack;\n pixelStoreUnpackPremultiplyAlpha: PixelStoreUnpackPremultiplyAlpha;\n pixelStoreUnpackFlipY: PixelStoreUnpackFlipY;\n\n // eslint-disable-next-line camelcase\n extTextureFilterAnisotropic: EXT_texture_filter_anisotropic | null;\n extTextureFilterAnisotropicMax?: GLfloat;\n HALF_FLOAT?: GLenum;\n RGBA16F?: GLenum;\n RGB16F?: GLenum;\n\n constructor(gl: WebGLRenderingContext | WebGL2RenderingContext) {\n this.gl = gl;\n this.clearColor = new ClearColor(this);\n this.clearDepth = new ClearDepth(this);\n this.clearStencil = new ClearStencil(this);\n this.colorMask = new ColorMask(this);\n this.depthMask = new DepthMask(this);\n this.stencilMask = new StencilMask(this);\n this.stencilFunc = new StencilFunc(this);\n this.stencilOp = new StencilOp(this);\n this.stencilTest = new StencilTest(this);\n this.depthRange = new DepthRange(this);\n this.depthTest = new DepthTest(this);\n this.depthFunc = new DepthFunc(this);\n this.blend = new Blend(this);\n this.blendFunc = new BlendFunc(this);\n this.blendColor = new BlendColor(this);\n this.blendEquation = new BlendEquation(this);\n this.cullFace = new CullFace(this);\n this.cullFaceSide = new CullFaceSide(this);\n this.frontFace = new FrontFace(this);\n this.program = new ProgramValue(this);\n this.activeTexture = new ActiveTextureUnit(this);\n this.viewport = new Viewport(this);\n this.bindFramebuffer = new BindFramebuffer(this);\n this.bindRenderbuffer = new BindRenderbuffer(this);\n this.bindTexture = new BindTexture(this);\n this.bindVertexBuffer = new BindVertexBuffer(this);\n this.bindElementBuffer = new BindElementBuffer(this);\n this.bindVertexArray = new BindVertexArray(this);\n this.pixelStoreUnpack = new PixelStoreUnpack(this);\n this.pixelStoreUnpackPremultiplyAlpha = new PixelStoreUnpackPremultiplyAlpha(this);\n this.pixelStoreUnpackFlipY = new PixelStoreUnpackFlipY(this);\n\n this.extTextureFilterAnisotropic = (\n gl.getExtension('EXT_texture_filter_anisotropic') ||\n gl.getExtension('MOZ_EXT_texture_filter_anisotropic') ||\n gl.getExtension('WEBKIT_EXT_texture_filter_anisotropic')\n );\n\n if (this.extTextureFilterAnisotropic) {\n this.extTextureFilterAnisotropicMax = gl.getParameter(this.extTextureFilterAnisotropic.MAX_TEXTURE_MAX_ANISOTROPY_EXT);\n }\n\n this.maxTextureSize = gl.getParameter(gl.MAX_TEXTURE_SIZE);\n\n if (isWebGL2(gl)) {\n this.HALF_FLOAT = gl.HALF_FLOAT;\n const extColorBufferHalfFloat = gl.getExtension('EXT_color_buffer_half_float');\n this.RGBA16F = gl.RGBA16F ?? extColorBufferHalfFloat?.RGBA16F_EXT;\n this.RGB16F = gl.RGB16F ?? extColorBufferHalfFloat?.RGB16F_EXT;\n gl.getExtension('EXT_color_buffer_float');\n } else {\n gl.getExtension('EXT_color_buffer_half_float');\n gl.getExtension('OES_texture_half_float_linear');\n const extTextureHalfFloat = gl.getExtension('OES_texture_half_float');\n this.HALF_FLOAT = extTextureHalfFloat?.HALF_FLOAT_OES;\n }\n }\n\n setDefault() {\n this.unbindVAO();\n\n this.clearColor.setDefault();\n this.clearDepth.setDefault();\n this.clearStencil.setDefault();\n this.colorMask.setDefault();\n this.depthMask.setDefault();\n this.stencilMask.setDefault();\n this.stencilFunc.setDefault();\n this.stencilOp.setDefault();\n this.stencilTest.setDefault();\n this.depthRange.setDefault();\n this.depthTest.setDefault();\n this.depthFunc.setDefault();\n this.blend.setDefault();\n this.blendFunc.setDefault();\n this.blendColor.setDefault();\n this.blendEquation.setDefault();\n this.cullFace.setDefault();\n this.cullFaceSide.setDefault();\n this.frontFace.setDefault();\n this.program.setDefault();\n this.activeTexture.setDefault();\n this.bindFramebuffer.setDefault();\n this.pixelStoreUnpack.setDefault();\n this.pixelStoreUnpackPremultiplyAlpha.setDefault();\n this.pixelStoreUnpackFlipY.setDefault();\n }\n\n setDirty() {\n this.clearColor.dirty = true;\n this.clearDepth.dirty = true;\n this.clearStencil.dirty = true;\n this.colorMask.dirty = true;\n this.depthMask.dirty = true;\n this.stencilMask.dirty = true;\n this.stencilFunc.dirty = true;\n this.stencilOp.dirty = true;\n this.stencilTest.dirty = true;\n this.depthRange.dirty = true;\n this.depthTest.dirty = true;\n this.depthFunc.dirty = true;\n this.blend.dirty = true;\n this.blendFunc.dirty = true;\n this.blendColor.dirty = true;\n this.blendEquation.dirty = true;\n this.cullFace.dirty = true;\n this.cullFaceSide.dirty = true;\n this.frontFace.dirty = true;\n this.program.dirty = true;\n this.activeTexture.dirty = true;\n this.viewport.dirty = true;\n this.bindFramebuffer.dirty = true;\n this.bindRenderbuffer.dirty = true;\n this.bindTexture.dirty = true;\n this.bindVertexBuffer.dirty = true;\n this.bindElementBuffer.dirty = true;\n this.bindVertexArray.dirty = true;\n this.pixelStoreUnpack.dirty = true;\n this.pixelStoreUnpackPremultiplyAlpha.dirty = true;\n this.pixelStoreUnpackFlipY.dirty = true;\n }\n\n createIndexBuffer(array: TriangleIndexArray | LineIndexArray | LineStripIndexArray, dynamicDraw?: boolean) {\n return new IndexBuffer(this, array, dynamicDraw);\n }\n\n createVertexBuffer(array: StructArray, attributes: ReadonlyArray, dynamicDraw?: boolean) {\n return new VertexBuffer(this, array, attributes, dynamicDraw);\n }\n\n createRenderbuffer(storageFormat: number, width: number, height: number) {\n const gl = this.gl;\n\n const rbo = gl.createRenderbuffer();\n this.bindRenderbuffer.set(rbo);\n gl.renderbufferStorage(gl.RENDERBUFFER, storageFormat, width, height);\n this.bindRenderbuffer.set(null);\n\n return rbo;\n }\n\n createFramebuffer(width: number, height: number, hasDepth: boolean, hasStencil: boolean) {\n return new Framebuffer(this, width, height, hasDepth, hasStencil);\n }\n\n clear({\n color,\n depth,\n stencil\n }: ClearArgs) {\n const gl = this.gl;\n let mask = 0;\n\n if (color) {\n mask |= gl.COLOR_BUFFER_BIT;\n this.clearColor.set(color);\n this.colorMask.set([true, true, true, true]);\n }\n\n if (typeof depth !== 'undefined') {\n mask |= gl.DEPTH_BUFFER_BIT;\n\n // Workaround for platforms where clearDepth doesn't seem to work\n // without resetting the depthRange. See https://github.com/mapbox/mapbox-gl-js/issues/3437\n this.depthRange.set([0, 1]);\n\n this.clearDepth.set(depth);\n this.depthMask.set(true);\n }\n\n if (typeof stencil !== 'undefined') {\n mask |= gl.STENCIL_BUFFER_BIT;\n this.clearStencil.set(stencil);\n this.stencilMask.set(0xFF);\n }\n\n gl.clear(mask);\n }\n\n setCullFace(cullFaceMode: Readonly) {\n if (cullFaceMode.enable === false) {\n this.cullFace.set(false);\n } else {\n this.cullFace.set(true);\n this.cullFaceSide.set(cullFaceMode.mode);\n this.frontFace.set(cullFaceMode.frontFace);\n }\n }\n\n setDepthMode(depthMode: Readonly) {\n if (depthMode.func === this.gl.ALWAYS && !depthMode.mask) {\n this.depthTest.set(false);\n } else {\n this.depthTest.set(true);\n this.depthFunc.set(depthMode.func);\n this.depthMask.set(depthMode.mask);\n this.depthRange.set(depthMode.range);\n }\n }\n\n setStencilMode(stencilMode: Readonly) {\n if (stencilMode.test.func === this.gl.ALWAYS && !stencilMode.mask) {\n this.stencilTest.set(false);\n } else {\n this.stencilTest.set(true);\n this.stencilMask.set(stencilMode.mask);\n this.stencilOp.set([stencilMode.fail, stencilMode.depthFail, stencilMode.pass]);\n this.stencilFunc.set({\n func: stencilMode.test.func,\n ref: stencilMode.ref,\n mask: stencilMode.test.mask\n });\n }\n }\n\n setColorMode(colorMode: Readonly) {\n if (deepEqual(colorMode.blendFunction, ColorMode.Replace)) {\n this.blend.set(false);\n } else {\n this.blend.set(true);\n this.blendFunc.set(colorMode.blendFunction);\n this.blendColor.set(colorMode.blendColor);\n }\n\n this.colorMask.set(colorMode.mask);\n }\n\n createVertexArray(): WebGLVertexArrayObject | undefined {\n if (isWebGL2(this.gl))\n return this.gl.createVertexArray();\n return this.gl.getExtension('OES_vertex_array_object')?.createVertexArrayOES();\n }\n\n deleteVertexArray(x: WebGLVertexArrayObject | undefined) {\n if (isWebGL2(this.gl))\n return this.gl.deleteVertexArray(x);\n return this.gl.getExtension('OES_vertex_array_object')?.deleteVertexArrayOES(x);\n }\n\n unbindVAO() {\n // Unbinding the VAO prevents other things (custom layers, new buffer creation) from\n // unintentionally changing the state of the last VAO used.\n this.bindVertexArray.set(null);\n }\n}\n","import type {DepthFuncType, DepthMaskType, DepthRangeType} from './types';\n\nconst ALWAYS = 0x0207;\n\nexport class DepthMode {\n func: DepthFuncType;\n mask: DepthMaskType;\n range: DepthRangeType;\n\n // DepthMask enums\n static ReadOnly: boolean;\n static ReadWrite: boolean;\n\n constructor(depthFunc: DepthFuncType, depthMask: DepthMaskType, depthRange: DepthRangeType) {\n this.func = depthFunc;\n this.mask = depthMask;\n this.range = depthRange;\n }\n\n static disabled: Readonly;\n}\n\nDepthMode.ReadOnly = false;\nDepthMode.ReadWrite = true;\n\nDepthMode.disabled = new DepthMode(ALWAYS, DepthMode.ReadOnly, [0, 1]);\n","import type {StencilOpConstant, StencilTestGL} from './types';\n\nconst ALWAYS = 0x0207;\nconst KEEP = 0x1E00;\n\nexport class StencilMode {\n test: StencilTestGL;\n ref: number;\n mask: number;\n fail: StencilOpConstant;\n depthFail: StencilOpConstant;\n pass: StencilOpConstant;\n\n constructor(test: StencilTestGL, ref: number, mask: number, fail: StencilOpConstant,\n depthFail: StencilOpConstant, pass: StencilOpConstant) {\n this.test = test;\n this.ref = ref;\n this.mask = mask;\n this.fail = fail;\n this.depthFail = depthFail;\n this.pass = pass;\n }\n\n static disabled: Readonly;\n}\n\nStencilMode.disabled = new StencilMode({func: ALWAYS, mask: 0}, 0, 0, KEEP, KEEP, KEEP);\n","import type {CullFaceModeType, FrontFaceType} from './types';\n\nconst BACK = 0x0405;\nconst CCW = 0x0901;\n\nexport class CullFaceMode {\n enable: boolean;\n mode: CullFaceModeType;\n frontFace: FrontFaceType;\n\n constructor(enable: boolean, mode: CullFaceModeType, frontFace: FrontFaceType) {\n this.enable = enable;\n this.mode = mode;\n this.frontFace = frontFace;\n }\n\n static disabled: Readonly;\n static backCCW: Readonly;\n}\n\nCullFaceMode.disabled = new CullFaceMode(false, BACK, CCW);\nCullFaceMode.backCCW = new CullFaceMode(true, BACK, CCW);\n","import type {Painter} from './painter';\nimport type {SourceCache} from '../source/source_cache';\nimport type {StyleLayer} from '../style/style_layer';\nimport type {OverscaledTileID} from '../source/tile_id';\nimport type {SymbolBucket} from '../data/bucket/symbol_bucket';\nimport {DepthMode} from '../gl/depth_mode';\nimport {StencilMode} from '../gl/stencil_mode';\nimport {CullFaceMode} from '../gl/cull_face_mode';\nimport {collisionUniformValues, collisionCircleUniformValues} from './program/collision_program';\nimport {QuadTriangleArray, CollisionCircleLayoutArray} from '../data/array_types.g';\nimport {collisionCircleLayout} from '../data/bucket/symbol_attributes';\nimport {SegmentVector} from '../data/segment';\nimport {mat4} from 'gl-matrix';\nimport {VertexBuffer} from '../gl/vertex_buffer';\nimport {IndexBuffer} from '../gl/index_buffer';\n\ntype TileBatch = {\n circleArray: Array;\n circleOffset: number;\n transform: mat4;\n invTransform: mat4;\n coord: OverscaledTileID;\n};\n\nlet quadTriangles: QuadTriangleArray;\n\nexport function drawCollisionDebug(painter: Painter, sourceCache: SourceCache, layer: StyleLayer, coords: Array, isText: boolean) {\n const context = painter.context;\n const gl = context.gl;\n const program = painter.useProgram('collisionBox');\n const tileBatches: Array = [];\n let circleCount = 0;\n let circleOffset = 0;\n\n for (let i = 0; i < coords.length; i++) {\n const coord = coords[i];\n const tile = sourceCache.getTile(coord);\n const bucket: SymbolBucket = (tile.getBucket(layer) as any);\n if (!bucket) continue;\n const buffers = isText ? bucket.textCollisionBox : bucket.iconCollisionBox;\n // Get collision circle data of this bucket\n const circleArray: Array = bucket.collisionCircleArray;\n if (circleArray.length > 0) {\n // We need to know the projection matrix that was used for projecting collision circles to the screen.\n // This might vary between buckets as the symbol placement is a continuous process. This matrix is\n // required for transforming points from previous screen space to the current one\n const invTransform = mat4.create();\n\n mat4.mul(invTransform, bucket.placementInvProjMatrix, painter.transform.glCoordMatrix);\n mat4.mul(invTransform, invTransform, bucket.placementViewportMatrix);\n\n tileBatches.push({\n circleArray,\n circleOffset,\n transform: coord.posMatrix, // Ignore translation\n invTransform,\n coord\n });\n\n circleCount += circleArray.length / 4; // 4 values per circle\n circleOffset = circleCount;\n }\n\n // Draw collision boxes\n if (!buffers) {\n continue;\n }\n\n program.draw(context, gl.LINES,\n DepthMode.disabled, StencilMode.disabled,\n painter.colorModeForRenderPass(),\n CullFaceMode.disabled,\n collisionUniformValues(painter.transform, coord.posMatrix),\n painter.style.map.terrain && painter.style.map.terrain.getTerrainData(coord),\n layer.id, buffers.layoutVertexBuffer, buffers.indexBuffer,\n buffers.segments, null, painter.transform.zoom, null, null,\n buffers.collisionVertexBuffer);\n }\n\n if (!isText || !tileBatches.length) {\n return;\n }\n\n // Render collision circles\n const circleProgram = painter.useProgram('collisionCircle');\n\n // Construct vertex data\n const vertexData = new CollisionCircleLayoutArray();\n vertexData.resize(circleCount * 4);\n vertexData._trim();\n\n let vertexOffset = 0;\n\n for (const batch of tileBatches) {\n for (let i = 0; i < batch.circleArray.length / 4; i++) {\n const circleIdx = i * 4;\n const x = batch.circleArray[circleIdx + 0];\n const y = batch.circleArray[circleIdx + 1];\n const radius = batch.circleArray[circleIdx + 2];\n const collision = batch.circleArray[circleIdx + 3];\n\n // 4 floats per vertex, 4 vertices per quad\n vertexData.emplace(vertexOffset++, x, y, radius, collision, 0);\n vertexData.emplace(vertexOffset++, x, y, radius, collision, 1);\n vertexData.emplace(vertexOffset++, x, y, radius, collision, 2);\n vertexData.emplace(vertexOffset++, x, y, radius, collision, 3);\n }\n }\n if (!quadTriangles || quadTriangles.length < circleCount * 2) {\n quadTriangles = createQuadTriangles(circleCount);\n }\n\n const indexBuffer: IndexBuffer = context.createIndexBuffer(quadTriangles, true);\n const vertexBuffer: VertexBuffer = context.createVertexBuffer(vertexData, collisionCircleLayout.members, true);\n\n // Render batches\n for (const batch of tileBatches) {\n const uniforms = collisionCircleUniformValues(\n batch.transform,\n batch.invTransform,\n painter.transform\n );\n\n circleProgram.draw(\n context,\n gl.TRIANGLES,\n DepthMode.disabled,\n StencilMode.disabled,\n painter.colorModeForRenderPass(),\n CullFaceMode.disabled,\n uniforms,\n painter.style.map.terrain && painter.style.map.terrain.getTerrainData(batch.coord),\n layer.id,\n vertexBuffer,\n indexBuffer,\n SegmentVector.simpleSegment(0, batch.circleOffset * 2, batch.circleArray.length, batch.circleArray.length / 2),\n null,\n painter.transform.zoom,\n null,\n null,\n null);\n }\n\n vertexBuffer.destroy();\n indexBuffer.destroy();\n}\n\nfunction createQuadTriangles(quadCount: number): QuadTriangleArray {\n const triCount = quadCount * 2;\n const array = new QuadTriangleArray();\n\n array.resize(triCount);\n array._trim();\n\n // Two triangles and 4 vertices per quad.\n for (let i = 0; i < triCount; i++) {\n const idx = i * 6;\n\n array.uint16[idx + 0] = i * 4 + 0;\n array.uint16[idx + 1] = i * 4 + 1;\n array.uint16[idx + 2] = i * 4 + 2;\n array.uint16[idx + 3] = i * 4 + 2;\n array.uint16[idx + 4] = i * 4 + 3;\n array.uint16[idx + 5] = i * 4 + 0;\n }\n\n return array;\n}\n","import Point from '@mapbox/point-geometry';\nimport {drawCollisionDebug} from './draw_collision_debug';\n\nimport {SegmentVector} from '../data/segment';\nimport {pixelsToTileUnits} from '../source/pixels_to_tile_units';\nimport * as symbolProjection from '../symbol/projection';\nimport {EvaluatedZoomSize, evaluateSizeForFeature, evaluateSizeForZoom} from '../symbol/symbol_size';\nimport {mat4} from 'gl-matrix';\nimport {StencilMode} from '../gl/stencil_mode';\nimport {DepthMode} from '../gl/depth_mode';\nimport {CullFaceMode} from '../gl/cull_face_mode';\nimport {addDynamicAttributes} from '../data/bucket/symbol_bucket';\n\nimport {getAnchorAlignment, WritingMode} from '../symbol/shaping';\nimport ONE_EM from '../symbol/one_em';\n\nimport {\n SymbolIconUniformsType,\n symbolIconUniformValues,\n symbolSDFUniformValues,\n symbolTextAndIconUniformValues\n} from './program/symbol_program';\n\nimport type {Painter} from './painter';\nimport type {SourceCache} from '../source/source_cache';\nimport type {SymbolStyleLayer} from '../style/style_layer/symbol_style_layer';\n\nimport type {Texture, TextureFilter} from '../render/texture';\nimport type {OverscaledTileID, UnwrappedTileID} from '../source/tile_id';\nimport type {UniformValues} from './uniform_binding';\nimport type {SymbolSDFUniformsType} from '../render/program/symbol_program';\nimport type {CrossTileID, VariableOffset} from '../symbol/placement';\nimport type {SymbolBucket, SymbolBuffers} from '../data/bucket/symbol_bucket';\nimport type {TerrainData} from '../render/terrain';\nimport type {SymbolLayerSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport type {Transform} from '../geo/transform';\nimport type {ColorMode} from '../gl/color_mode';\nimport type {Program} from './program';\nimport type {TextAnchor} from '../style/style_layer/variable_text_anchor';\nimport {createProjection, Projection} from '../geo/projection/projection';\n\ntype SymbolTileRenderState = {\n segments: SegmentVector;\n sortKey: number;\n terrainData: TerrainData;\n state: {\n program: Program;\n buffers: SymbolBuffers;\n uniformValues: UniformValues;\n atlasTexture: Texture;\n atlasTextureIcon: Texture | null;\n atlasInterpolation: TextureFilter;\n atlasInterpolationIcon: TextureFilter;\n isSDF: boolean;\n hasHalo: boolean;\n };\n};\n\nconst identityMat4 = mat4.identity(new Float32Array(16));\n\nexport function drawSymbols(painter: Painter, sourceCache: SourceCache, layer: SymbolStyleLayer, coords: Array, variableOffsets: {\n [_ in CrossTileID]: VariableOffset;\n}) {\n if (painter.renderPass !== 'translucent') return;\n\n // Disable the stencil test so that labels aren't clipped to tile boundaries.\n const stencilMode = StencilMode.disabled;\n const colorMode = painter.colorModeForRenderPass();\n const hasVariablePlacement = layer._unevaluatedLayout.hasValue('text-variable-anchor') || layer._unevaluatedLayout.hasValue('text-variable-anchor-offset');\n\n //Compute variable-offsets before painting since icons and text data positioning\n //depend on each other in this case.\n if (hasVariablePlacement) {\n updateVariableAnchors(coords, painter, layer, sourceCache,\n layer.layout.get('text-rotation-alignment'),\n layer.layout.get('text-pitch-alignment'),\n layer.paint.get('text-translate'),\n layer.paint.get('text-translate-anchor'),\n variableOffsets\n );\n }\n\n if (layer.paint.get('icon-opacity').constantOr(1) !== 0) {\n drawLayerSymbols(painter, sourceCache, layer, coords, false,\n layer.paint.get('icon-translate'),\n layer.paint.get('icon-translate-anchor'),\n layer.layout.get('icon-rotation-alignment'),\n layer.layout.get('icon-pitch-alignment'),\n layer.layout.get('icon-keep-upright'),\n stencilMode, colorMode\n );\n }\n\n if (layer.paint.get('text-opacity').constantOr(1) !== 0) {\n drawLayerSymbols(painter, sourceCache, layer, coords, true,\n layer.paint.get('text-translate'),\n layer.paint.get('text-translate-anchor'),\n layer.layout.get('text-rotation-alignment'),\n layer.layout.get('text-pitch-alignment'),\n layer.layout.get('text-keep-upright'),\n stencilMode, colorMode\n );\n }\n\n if (sourceCache.map.showCollisionBoxes) {\n drawCollisionDebug(painter, sourceCache, layer, coords, true);\n drawCollisionDebug(painter, sourceCache, layer, coords, false);\n }\n}\n\nfunction calculateVariableRenderShift(\n anchor: TextAnchor,\n width: number,\n height: number,\n textOffset: [number, number],\n textBoxScale: number,\n renderTextSize: number): Point {\n const {horizontalAlign, verticalAlign} = getAnchorAlignment(anchor);\n const shiftX = -(horizontalAlign - 0.5) * width;\n const shiftY = -(verticalAlign - 0.5) * height;\n return new Point(\n (shiftX / textBoxScale + textOffset[0]) * renderTextSize,\n (shiftY / textBoxScale + textOffset[1]) * renderTextSize\n );\n}\n\nfunction updateVariableAnchors(coords: Array,\n painter: Painter,\n layer:SymbolStyleLayer, sourceCache: SourceCache,\n rotationAlignment: SymbolLayerSpecification['layout']['text-rotation-alignment'],\n pitchAlignment: SymbolLayerSpecification['layout']['text-pitch-alignment'],\n translate: [number, number],\n translateAnchor: 'map' | 'viewport',\n variableOffsets: {[_ in CrossTileID]: VariableOffset}) {\n const transform = painter.transform;\n const projection = createProjection();\n const rotateWithMap = rotationAlignment === 'map';\n const pitchWithMap = pitchAlignment === 'map';\n\n for (const coord of coords) {\n const tile = sourceCache.getTile(coord);\n const bucket = tile.getBucket(layer) as SymbolBucket;\n if (!bucket || !bucket.text || !bucket.text.segments.get().length) continue;\n\n const sizeData = bucket.textSizeData;\n const size = evaluateSizeForZoom(sizeData, transform.zoom);\n\n const pixelToTileScale = pixelsToTileUnits(tile, 1, painter.transform.zoom);\n const labelPlaneMatrix = symbolProjection.getLabelPlaneMatrix(coord.posMatrix, pitchWithMap, rotateWithMap, painter.transform, pixelToTileScale);\n const updateTextFitIcon = layer.layout.get('icon-text-fit') !== 'none' && bucket.hasIconData();\n\n if (size) {\n const tileScale = Math.pow(2, transform.zoom - tile.tileID.overscaledZ);\n const getElevation = painter.style.map.terrain ? (x: number, y: number) => painter.style.map.terrain.getElevation(coord, x, y) : null;\n const translation = projection.translatePosition(transform, tile, translate, translateAnchor);\n updateVariableAnchorsForBucket(bucket, rotateWithMap, pitchWithMap, variableOffsets,\n transform, labelPlaneMatrix, coord.posMatrix, tileScale, size, updateTextFitIcon, projection, translation, coord.toUnwrapped(), getElevation);\n }\n }\n}\n\nfunction getShiftedAnchor(projectedAnchorPoint: Point, projectionContext: symbolProjection.SymbolProjectionContext, rotateWithMap, shift: Point, transformAngle: number, pitchedTextShiftCorrection: number) {\n // Usual case is that we take the projected anchor and add the pixel-based shift\n // calculated earlier. In the (somewhat weird) case of pitch-aligned text, we add an equivalent\n // tile-unit based shift to the anchor before projecting to the label plane.\n const translatedAnchor = projectionContext.tileAnchorPoint.add(new Point(projectionContext.translation[0], projectionContext.translation[1]));\n if (projectionContext.pitchWithMap) {\n let adjustedShift = shift.mult(pitchedTextShiftCorrection);\n if (!rotateWithMap) {\n adjustedShift = adjustedShift.rotate(-transformAngle);\n }\n const tileAnchorShifted = translatedAnchor.add(adjustedShift);\n return symbolProjection.project(tileAnchorShifted.x, tileAnchorShifted.y, projectionContext.labelPlaneMatrix, projectionContext.getElevation).point;\n } else {\n if (rotateWithMap) {\n // Compute the angle with which to rotate the anchor, so that it is aligned with\n // the map's actual east-west axis. Very similar to what is done in the shader.\n const projectedAnchorRight = symbolProjection.projectTileCoordinatesToViewport(projectionContext.tileAnchorPoint.x + 1, projectionContext.tileAnchorPoint.y, projectionContext);\n const east = projectedAnchorRight.point.sub(projectedAnchorPoint);\n const angle = Math.atan(east.y / east.x) + (east.x < 0 ? Math.PI : 0);\n return projectedAnchorPoint.add(shift.rotate(angle));\n } else {\n return projectedAnchorPoint.add(shift);\n }\n }\n}\n\nfunction updateVariableAnchorsForBucket(\n bucket: SymbolBucket,\n rotateWithMap: boolean,\n pitchWithMap: boolean,\n variableOffsets: {[_ in CrossTileID]: VariableOffset},\n transform: Transform,\n labelPlaneMatrix: mat4,\n posMatrix: mat4,\n tileScale: number,\n size: EvaluatedZoomSize,\n updateTextFitIcon: boolean,\n projection: Projection,\n translation: [number, number],\n unwrappedTileID: UnwrappedTileID,\n getElevation: (x: number, y: number) => number) {\n const placedSymbols = bucket.text.placedSymbolArray;\n const dynamicTextLayoutVertexArray = bucket.text.dynamicLayoutVertexArray;\n const dynamicIconLayoutVertexArray = bucket.icon.dynamicLayoutVertexArray;\n const placedTextShifts = {};\n\n dynamicTextLayoutVertexArray.clear();\n for (let s = 0; s < placedSymbols.length; s++) {\n const symbol = placedSymbols.get(s);\n const skipOrientation = bucket.allowVerticalPlacement && !symbol.placedOrientation;\n const variableOffset = (!symbol.hidden && symbol.crossTileID && !skipOrientation) ? variableOffsets[symbol.crossTileID] : null;\n\n if (!variableOffset) {\n // These symbols are from a justification that is not being used, or a label that wasn't placed\n // so we don't need to do the extra math to figure out what incremental shift to apply.\n symbolProjection.hideGlyphs(symbol.numGlyphs, dynamicTextLayoutVertexArray);\n } else {\n const tileAnchor = new Point(symbol.anchorX, symbol.anchorY);\n const projectionContext = {\n getElevation,\n width: transform.width,\n height: transform.height,\n labelPlaneMatrix,\n lineVertexArray: null,\n pitchWithMap,\n projection,\n projectionCache: null,\n tileAnchorPoint: tileAnchor,\n translation,\n unwrappedTileID\n };\n const projectedAnchor = pitchWithMap ?\n symbolProjection.project(tileAnchor.x, tileAnchor.y, posMatrix, getElevation) :\n symbolProjection.projectTileCoordinatesToViewport(tileAnchor.x, tileAnchor.y, projectionContext);\n const perspectiveRatio = symbolProjection.getPerspectiveRatio(transform.cameraToCenterDistance, projectedAnchor.signedDistanceFromCamera);\n let renderTextSize = evaluateSizeForFeature(bucket.textSizeData, size, symbol) * perspectiveRatio / ONE_EM;\n if (pitchWithMap) {\n // Go from size in pixels to equivalent size in tile units\n renderTextSize *= bucket.tilePixelRatio / tileScale;\n }\n\n const {width, height, anchor, textOffset, textBoxScale} = variableOffset;\n const shift = calculateVariableRenderShift(anchor, width, height, textOffset, textBoxScale, renderTextSize);\n\n const pitchedTextCorrection = projection.getPitchedTextCorrection(transform, tileAnchor.add(new Point(translation[0], translation[1])), unwrappedTileID);\n const shiftedAnchor = getShiftedAnchor(projectedAnchor.point, projectionContext, rotateWithMap, shift, transform.angle, pitchedTextCorrection);\n\n const angle = (bucket.allowVerticalPlacement && symbol.placedOrientation === WritingMode.vertical) ? Math.PI / 2 : 0;\n for (let g = 0; g < symbol.numGlyphs; g++) {\n addDynamicAttributes(dynamicTextLayoutVertexArray, shiftedAnchor, angle);\n }\n //Only offset horizontal text icons\n if (updateTextFitIcon && symbol.associatedIconIndex >= 0) {\n placedTextShifts[symbol.associatedIconIndex] = {shiftedAnchor, angle};\n }\n }\n }\n\n if (updateTextFitIcon) {\n dynamicIconLayoutVertexArray.clear();\n const placedIcons = bucket.icon.placedSymbolArray;\n for (let i = 0; i < placedIcons.length; i++) {\n const placedIcon = placedIcons.get(i);\n if (placedIcon.hidden) {\n symbolProjection.hideGlyphs(placedIcon.numGlyphs, dynamicIconLayoutVertexArray);\n } else {\n const shift = placedTextShifts[i];\n if (!shift) {\n symbolProjection.hideGlyphs(placedIcon.numGlyphs, dynamicIconLayoutVertexArray);\n } else {\n for (let g = 0; g < placedIcon.numGlyphs; g++) {\n addDynamicAttributes(dynamicIconLayoutVertexArray, shift.shiftedAnchor, shift.angle);\n }\n }\n }\n }\n bucket.icon.dynamicLayoutVertexBuffer.updateData(dynamicIconLayoutVertexArray);\n }\n bucket.text.dynamicLayoutVertexBuffer.updateData(dynamicTextLayoutVertexArray);\n}\n\nfunction getSymbolProgramName(isSDF: boolean, isText: boolean, bucket: SymbolBucket) {\n if (bucket.iconsInText && isText) {\n return 'symbolTextAndIcon';\n } else if (isSDF) {\n return 'symbolSDF';\n } else {\n return 'symbolIcon';\n }\n}\n\nfunction drawLayerSymbols(\n painter: Painter,\n sourceCache: SourceCache,\n layer: SymbolStyleLayer,\n coords: Array,\n isText: boolean,\n translate: [number, number],\n translateAnchor: 'map' | 'viewport',\n rotationAlignment: SymbolLayerSpecification['layout']['text-rotation-alignment'],\n pitchAlignment: SymbolLayerSpecification['layout']['text-pitch-alignment'],\n keepUpright: boolean,\n stencilMode: StencilMode,\n colorMode: Readonly) {\n\n const context = painter.context;\n const gl = context.gl;\n const tr = painter.transform;\n const projection = createProjection();\n\n const rotateWithMap = rotationAlignment === 'map';\n const pitchWithMap = pitchAlignment === 'map';\n const alongLine = rotationAlignment !== 'viewport' && layer.layout.get('symbol-placement') !== 'point';\n // Line label rotation happens in `updateLineLabels`\n // Pitched point labels are automatically rotated by the labelPlaneMatrix projection\n // Unpitched point labels need to have their rotation applied after projection\n const rotateInShader = rotateWithMap && !pitchWithMap && !alongLine;\n\n const isViewportLine = !pitchWithMap && alongLine;\n\n const hasSortKey = !layer.layout.get('symbol-sort-key').isConstant();\n let sortFeaturesByKey = false;\n\n const depthMode = painter.depthModeForSublayer(0, DepthMode.ReadOnly);\n\n const hasVariablePlacement = layer._unevaluatedLayout.hasValue('text-variable-anchor') || layer._unevaluatedLayout.hasValue('text-variable-anchor-offset');\n\n const tileRenderState: Array = [];\n\n const pitchedTextRescaling = projection.getCircleRadiusCorrection(tr);\n\n for (const coord of coords) {\n const tile = sourceCache.getTile(coord);\n const bucket = tile.getBucket(layer) as SymbolBucket;\n if (!bucket) continue;\n const buffers = isText ? bucket.text : bucket.icon;\n\n if (!buffers || !buffers.segments.get().length || !buffers.hasVisibleVertices) continue;\n const programConfiguration = buffers.programConfigurations.get(layer.id);\n\n const isSDF = isText || bucket.sdfIcons;\n\n const sizeData = isText ? bucket.textSizeData : bucket.iconSizeData;\n const transformed = pitchWithMap || tr.pitch !== 0;\n\n const program = painter.useProgram(getSymbolProgramName(isSDF, isText, bucket), programConfiguration);\n const size = evaluateSizeForZoom(sizeData, tr.zoom);\n const terrainData = painter.style.map.terrain && painter.style.map.terrain.getTerrainData(coord);\n\n let texSize: [number, number];\n let texSizeIcon: [number, number] = [0, 0];\n let atlasTexture: Texture;\n let atlasInterpolation: TextureFilter;\n let atlasTextureIcon = null;\n let atlasInterpolationIcon: TextureFilter;\n if (isText) {\n atlasTexture = tile.glyphAtlasTexture;\n atlasInterpolation = gl.LINEAR;\n texSize = tile.glyphAtlasTexture.size;\n if (bucket.iconsInText) {\n texSizeIcon = tile.imageAtlasTexture.size;\n atlasTextureIcon = tile.imageAtlasTexture;\n const zoomDependentSize = sizeData.kind === 'composite' || sizeData.kind === 'camera';\n atlasInterpolationIcon = transformed || painter.options.rotating || painter.options.zooming || zoomDependentSize ? gl.LINEAR : gl.NEAREST;\n }\n } else {\n const iconScaled = layer.layout.get('icon-size').constantOr(0) !== 1 || bucket.iconsNeedLinear;\n atlasTexture = tile.imageAtlasTexture;\n atlasInterpolation = isSDF || painter.options.rotating || painter.options.zooming || iconScaled || transformed ?\n gl.LINEAR :\n gl.NEAREST;\n texSize = tile.imageAtlasTexture.size;\n }\n\n const s = pixelsToTileUnits(tile, 1, painter.transform.zoom);\n const baseMatrix = isViewportLine ? coord.posMatrix : identityMat4;\n const labelPlaneMatrix = symbolProjection.getLabelPlaneMatrix(baseMatrix, pitchWithMap, rotateWithMap, painter.transform, s);\n const glCoordMatrixForShader = symbolProjection.getGlCoordMatrix(baseMatrix, pitchWithMap, rotateWithMap, painter.transform, s);\n const glCoordMatrixForSymbolPlacement = symbolProjection.getGlCoordMatrix(coord.posMatrix, pitchWithMap, rotateWithMap, painter.transform, s);\n\n const translation = projection.translatePosition(painter.transform, tile, translate, translateAnchor);\n\n const hasVariableAnchors = hasVariablePlacement && bucket.hasTextData();\n const updateTextFitIcon = layer.layout.get('icon-text-fit') !== 'none' &&\n hasVariableAnchors &&\n bucket.hasIconData();\n\n if (alongLine) {\n const getElevation = painter.style.map.terrain ? (x: number, y: number) => painter.style.map.terrain.getElevation(coord, x, y) : null;\n const rotateToLine = layer.layout.get('text-rotation-alignment') === 'map';\n symbolProjection.updateLineLabels(bucket, coord.posMatrix, painter, isText, labelPlaneMatrix, glCoordMatrixForSymbolPlacement, pitchWithMap, keepUpright, rotateToLine, projection, coord.toUnwrapped(), tr.width, tr.height, translation, getElevation);\n }\n\n const matrix = coord.posMatrix; // formerly also incorporated translate and translate-anchor\n const shaderVariableAnchor = (isText && hasVariablePlacement) || updateTextFitIcon;\n const noLabelPlane = (alongLine || shaderVariableAnchor);\n const uLabelPlaneMatrix = noLabelPlane ? identityMat4 : labelPlaneMatrix;\n const uglCoordMatrix = glCoordMatrixForShader; // formerly also incorporated translate and translate-anchor\n\n const hasHalo = isSDF && layer.paint.get(isText ? 'text-halo-width' : 'icon-halo-width').constantOr(1) !== 0;\n\n let uniformValues: UniformValues;\n if (isSDF) {\n if (!bucket.iconsInText) {\n uniformValues = symbolSDFUniformValues(sizeData.kind,\n size, rotateInShader, pitchWithMap, alongLine, shaderVariableAnchor, painter, matrix,\n uLabelPlaneMatrix, uglCoordMatrix, translation, isText, texSize, true, pitchedTextRescaling);\n } else {\n uniformValues = symbolTextAndIconUniformValues(sizeData.kind,\n size, rotateInShader, pitchWithMap, alongLine, shaderVariableAnchor, painter, matrix,\n uLabelPlaneMatrix, uglCoordMatrix, translation, texSize, texSizeIcon, pitchedTextRescaling);\n }\n } else {\n uniformValues = symbolIconUniformValues(sizeData.kind,\n size, rotateInShader, pitchWithMap, alongLine, shaderVariableAnchor, painter, matrix,\n uLabelPlaneMatrix, uglCoordMatrix, translation, isText, texSize, pitchedTextRescaling);\n }\n\n const state = {\n program,\n buffers,\n uniformValues,\n atlasTexture,\n atlasTextureIcon,\n atlasInterpolation,\n atlasInterpolationIcon,\n isSDF,\n hasHalo\n };\n\n if (hasSortKey && bucket.canOverlap) {\n sortFeaturesByKey = true;\n const oldSegments = buffers.segments.get();\n for (const segment of oldSegments) {\n tileRenderState.push({\n segments: new SegmentVector([segment]),\n sortKey: segment.sortKey,\n state,\n terrainData\n });\n }\n } else {\n tileRenderState.push({\n segments: buffers.segments,\n sortKey: 0,\n state,\n terrainData\n });\n }\n }\n\n if (sortFeaturesByKey) {\n tileRenderState.sort((a, b) => a.sortKey - b.sortKey);\n }\n\n for (const segmentState of tileRenderState) {\n const state = segmentState.state;\n\n context.activeTexture.set(gl.TEXTURE0);\n state.atlasTexture.bind(state.atlasInterpolation, gl.CLAMP_TO_EDGE);\n if (state.atlasTextureIcon) {\n context.activeTexture.set(gl.TEXTURE1);\n if (state.atlasTextureIcon) {\n state.atlasTextureIcon.bind(state.atlasInterpolationIcon, gl.CLAMP_TO_EDGE);\n }\n }\n\n if (state.isSDF) {\n const uniformValues = state.uniformValues;\n if (state.hasHalo) {\n uniformValues['u_is_halo'] = 1;\n drawSymbolElements(state.buffers, segmentState.segments, layer, painter, state.program, depthMode, stencilMode, colorMode, uniformValues, segmentState.terrainData);\n }\n uniformValues['u_is_halo'] = 0;\n }\n drawSymbolElements(state.buffers, segmentState.segments, layer, painter, state.program, depthMode, stencilMode, colorMode, state.uniformValues, segmentState.terrainData);\n }\n}\n\nfunction drawSymbolElements(\n buffers: SymbolBuffers,\n segments: SegmentVector,\n layer: SymbolStyleLayer,\n painter: Painter,\n program: Program,\n depthMode: Readonly,\n stencilMode: StencilMode,\n colorMode: Readonly,\n uniformValues: UniformValues,\n terrainData: TerrainData) {\n const context = painter.context;\n const gl = context.gl;\n program.draw(context, gl.TRIANGLES, depthMode, stencilMode, colorMode, CullFaceMode.disabled,\n uniformValues, terrainData, layer.id, buffers.layoutVertexBuffer,\n buffers.indexBuffer, segments, layer.paint,\n painter.transform.zoom, buffers.programConfigurations.get(layer.id),\n buffers.dynamicLayoutVertexBuffer, buffers.opacityVertexBuffer);\n}\n","import {StencilMode} from '../gl/stencil_mode';\nimport {DepthMode} from '../gl/depth_mode';\nimport {CullFaceMode} from '../gl/cull_face_mode';\nimport {Program} from './program';\nimport {circleUniformValues} from './program/circle_program';\nimport {SegmentVector} from '../data/segment';\nimport {OverscaledTileID} from '../source/tile_id';\n\nimport type {Painter} from './painter';\nimport type {SourceCache} from '../source/source_cache';\nimport type {CircleStyleLayer} from '../style/style_layer/circle_style_layer';\nimport type {CircleBucket} from '../data/bucket/circle_bucket';\nimport type {ProgramConfiguration} from '../data/program_configuration';\nimport type {VertexBuffer} from '../gl/vertex_buffer';\nimport type {IndexBuffer} from '../gl/index_buffer';\nimport type {UniformValues} from './uniform_binding';\nimport type {CircleUniformsType} from './program/circle_program';\nimport type {TerrainData} from '../render/terrain';\n\ntype TileRenderState = {\n programConfiguration: ProgramConfiguration;\n program: Program;\n layoutVertexBuffer: VertexBuffer;\n indexBuffer: IndexBuffer;\n uniformValues: UniformValues;\n terrainData: TerrainData;\n};\n\ntype SegmentsTileRenderState = {\n segments: SegmentVector;\n sortKey: number;\n state: TileRenderState;\n};\n\nexport function drawCircles(painter: Painter, sourceCache: SourceCache, layer: CircleStyleLayer, coords: Array) {\n if (painter.renderPass !== 'translucent') return;\n\n const opacity = layer.paint.get('circle-opacity');\n const strokeWidth = layer.paint.get('circle-stroke-width');\n const strokeOpacity = layer.paint.get('circle-stroke-opacity');\n const sortFeaturesByKey = !layer.layout.get('circle-sort-key').isConstant();\n\n if (opacity.constantOr(1) === 0 && (strokeWidth.constantOr(1) === 0 || strokeOpacity.constantOr(1) === 0)) {\n return;\n }\n\n const context = painter.context;\n const gl = context.gl;\n\n const depthMode = painter.depthModeForSublayer(0, DepthMode.ReadOnly);\n // Turn off stencil testing to allow circles to be drawn across boundaries,\n // so that large circles are not clipped to tiles\n const stencilMode = StencilMode.disabled;\n const colorMode = painter.colorModeForRenderPass();\n\n const segmentsRenderStates: Array = [];\n\n for (let i = 0; i < coords.length; i++) {\n const coord = coords[i];\n\n const tile = sourceCache.getTile(coord);\n const bucket: CircleBucket = (tile.getBucket(layer) as any);\n if (!bucket) continue;\n\n const programConfiguration = bucket.programConfigurations.get(layer.id);\n const program = painter.useProgram('circle', programConfiguration);\n const layoutVertexBuffer = bucket.layoutVertexBuffer;\n const indexBuffer = bucket.indexBuffer;\n const terrainData = painter.style.map.terrain && painter.style.map.terrain.getTerrainData(coord);\n const uniformValues = circleUniformValues(painter, coord, tile, layer);\n\n const state: TileRenderState = {\n programConfiguration,\n program,\n layoutVertexBuffer,\n indexBuffer,\n uniformValues,\n terrainData\n };\n\n if (sortFeaturesByKey) {\n const oldSegments = bucket.segments.get();\n for (const segment of oldSegments) {\n segmentsRenderStates.push({\n segments: new SegmentVector([segment]),\n sortKey: (segment.sortKey as any as number),\n state\n });\n }\n } else {\n segmentsRenderStates.push({\n segments: bucket.segments,\n sortKey: 0,\n state\n });\n }\n\n }\n\n if (sortFeaturesByKey) {\n segmentsRenderStates.sort((a, b) => a.sortKey - b.sortKey);\n }\n\n for (const segmentsState of segmentsRenderStates) {\n const {programConfiguration, program, layoutVertexBuffer, indexBuffer, uniformValues, terrainData} = segmentsState.state;\n const segments = segmentsState.segments;\n\n program.draw(context, gl.TRIANGLES, depthMode, stencilMode, colorMode, CullFaceMode.disabled,\n uniformValues, terrainData, layer.id,\n layoutVertexBuffer, indexBuffer, segments,\n layer.paint, painter.transform.zoom, programConfiguration);\n }\n}\n","import {Texture} from './texture';\nimport {Color} from '@maplibre/maplibre-gl-style-spec';\nimport {DepthMode} from '../gl/depth_mode';\nimport {StencilMode} from '../gl/stencil_mode';\nimport {ColorMode} from '../gl/color_mode';\nimport {CullFaceMode} from '../gl/cull_face_mode';\nimport {Context} from '../gl/context';\nimport {Framebuffer} from '../gl/framebuffer';\nimport {Tile} from '../source/tile';\nimport {\n heatmapUniformValues,\n heatmapTextureUniformValues\n} from './program/heatmap_program';\nimport {HEATMAP_FULL_RENDER_FBO_KEY} from '../style/style_layer/heatmap_style_layer';\n\nimport type {Painter} from './painter';\nimport type {SourceCache} from '../source/source_cache';\nimport type {HeatmapStyleLayer} from '../style/style_layer/heatmap_style_layer';\nimport type {HeatmapBucket} from '../data/bucket/heatmap_bucket';\nimport type {OverscaledTileID} from '../source/tile_id';\n\nexport function drawHeatmap(painter: Painter, sourceCache: SourceCache, layer: HeatmapStyleLayer, tileIDs: Array) {\n if (layer.paint.get('heatmap-opacity') === 0) {\n return;\n }\n const context = painter.context;\n\n if (painter.style.map.terrain) {\n for (const coord of tileIDs) {\n const tile = sourceCache.getTile(coord);\n // Skip tiles that have uncovered parents to avoid flickering; we don't need\n // to use complex tile masking here because the change between zoom levels is subtle,\n // so it's fine to simply render the parent until all its 4 children are loaded\n if (sourceCache.hasRenderableParent(coord)) continue;\n if (painter.renderPass === 'offscreen') {\n prepareHeatmapTerrain(painter, tile, layer, coord);\n } else if (painter.renderPass === 'translucent') {\n renderHeatmapTerrain(painter, layer, coord);\n }\n }\n context.viewport.set([0, 0, painter.width, painter.height]);\n } else {\n if (painter.renderPass === 'offscreen') {\n prepareHeatmapFlat(painter, sourceCache, layer, tileIDs);\n } else if (painter.renderPass === 'translucent') {\n renderHeatmapFlat(painter, layer);\n }\n\n }\n}\n\nfunction prepareHeatmapFlat(painter: Painter, sourceCache: SourceCache, layer: HeatmapStyleLayer, coords: Array) {\n const context = painter.context;\n const gl = context.gl;\n\n // Allow kernels to be drawn across boundaries, so that\n // large kernels are not clipped to tiles\n const stencilMode = StencilMode.disabled;\n // Turn on additive blending for kernels, which is a key aspect of kernel density estimation formula\n const colorMode = new ColorMode([gl.ONE, gl.ONE], Color.transparent, [true, true, true, true]);\n\n bindFramebuffer(context, painter, layer);\n\n context.clear({color: Color.transparent});\n\n for (let i = 0; i < coords.length; i++) {\n const coord = coords[i];\n\n // Skip tiles that have uncovered parents to avoid flickering; we don't need\n // to use complex tile masking here because the change between zoom levels is subtle,\n // so it's fine to simply render the parent until all its 4 children are loaded\n if (sourceCache.hasRenderableParent(coord)) continue;\n\n const tile = sourceCache.getTile(coord);\n const bucket: HeatmapBucket = (tile.getBucket(layer) as any);\n if (!bucket) continue;\n\n const programConfiguration = bucket.programConfigurations.get(layer.id);\n const program = painter.useProgram('heatmap', programConfiguration);\n const {zoom} = painter.transform;\n\n program.draw(context, gl.TRIANGLES, DepthMode.disabled, stencilMode, colorMode, CullFaceMode.disabled,\n heatmapUniformValues(coord.posMatrix, tile, zoom, layer.paint.get('heatmap-intensity')), null,\n layer.id, bucket.layoutVertexBuffer, bucket.indexBuffer,\n bucket.segments, layer.paint, painter.transform.zoom,\n programConfiguration);\n }\n\n context.viewport.set([0, 0, painter.width, painter.height]);\n}\n\nfunction renderHeatmapFlat(painter: Painter, layer: HeatmapStyleLayer) {\n const context = painter.context;\n const gl = context.gl;\n\n context.setColorMode(painter.colorModeForRenderPass());\n\n // Here we bind two different textures from which we'll sample in drawing\n // heatmaps: the kernel texture, prepared in the offscreen pass, and a\n // color ramp texture.\n const fbo = layer.heatmapFbos.get(HEATMAP_FULL_RENDER_FBO_KEY);\n if (!fbo) return;\n context.activeTexture.set(gl.TEXTURE0);\n gl.bindTexture(gl.TEXTURE_2D, fbo.colorAttachment.get());\n\n context.activeTexture.set(gl.TEXTURE1);\n const colorRampTexture = getColorRampTexture(context, layer);\n colorRampTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n\n painter.useProgram('heatmapTexture').draw(context, gl.TRIANGLES,\n DepthMode.disabled, StencilMode.disabled, painter.colorModeForRenderPass(), CullFaceMode.disabled,\n heatmapTextureUniformValues(painter, layer, 0, 1), null,\n layer.id, painter.viewportBuffer, painter.quadTriangleIndexBuffer,\n painter.viewportSegments, layer.paint, painter.transform.zoom);\n}\n\nfunction prepareHeatmapTerrain(painter: Painter, tile: Tile, layer: HeatmapStyleLayer, coord: OverscaledTileID) {\n const context = painter.context;\n const gl = context.gl;\n\n const stencilMode = StencilMode.disabled;\n // Turn on additive blending for kernels, which is a key aspect of kernel density estimation formula\n const colorMode = new ColorMode([gl.ONE, gl.ONE], Color.transparent, [true, true, true, true]);\n\n const bucket: HeatmapBucket = (tile.getBucket(layer) as any);\n if (!bucket) return;\n\n const tileKey = coord.key;\n let fbo = layer.heatmapFbos.get(tileKey);\n if (!fbo) {\n fbo = createHeatmapFbo(context, tile.tileSize, tile.tileSize);\n layer.heatmapFbos.set(tileKey, fbo);\n }\n\n context.bindFramebuffer.set(fbo.framebuffer);\n context.viewport.set([0, 0, tile.tileSize, tile.tileSize]);\n\n context.clear({color: Color.transparent});\n\n const programConfiguration = bucket.programConfigurations.get(layer.id);\n const program = painter.useProgram('heatmap', programConfiguration);\n\n const terrainData = painter.style.map.terrain.getTerrainData(coord);\n program.draw(context, gl.TRIANGLES, DepthMode.disabled, stencilMode, colorMode, CullFaceMode.disabled,\n heatmapUniformValues(coord.posMatrix, tile, painter.transform.zoom, layer.paint.get('heatmap-intensity')), terrainData,\n layer.id, bucket.layoutVertexBuffer, bucket.indexBuffer,\n bucket.segments, layer.paint, painter.transform.zoom,\n programConfiguration);\n}\n\nfunction renderHeatmapTerrain(painter: Painter, layer: HeatmapStyleLayer, coord: OverscaledTileID) {\n const context = painter.context;\n const gl = context.gl;\n\n context.setColorMode(painter.colorModeForRenderPass());\n\n const colorRampTexture = getColorRampTexture(context, layer);\n\n // Here we bind two different textures from which we'll sample in drawing\n // heatmaps: the kernel texture, prepared in the offscreen pass, and a\n // color ramp texture.\n const tileKey = coord.key;\n const fbo = layer.heatmapFbos.get(tileKey);\n if (!fbo) return;\n\n context.activeTexture.set(gl.TEXTURE0);\n gl.bindTexture(gl.TEXTURE_2D, fbo.colorAttachment.get());\n\n context.activeTexture.set(gl.TEXTURE1);\n colorRampTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n\n painter.useProgram('heatmapTexture').draw(context, gl.TRIANGLES,\n DepthMode.disabled, StencilMode.disabled, painter.colorModeForRenderPass(), CullFaceMode.disabled,\n heatmapTextureUniformValues(painter, layer, 0, 1), null,\n layer.id, painter.rasterBoundsBuffer, painter.quadTriangleIndexBuffer,\n painter.rasterBoundsSegments, layer.paint, painter.transform.zoom);\n\n // destroy the FBO after rendering\n fbo.destroy();\n layer.heatmapFbos.delete(tileKey);\n}\n\nfunction bindFramebuffer(context: Context, painter: Painter, layer: HeatmapStyleLayer) {\n const gl = context.gl;\n context.activeTexture.set(gl.TEXTURE1);\n\n // Use a 4x downscaled screen texture for better performance\n context.viewport.set([0, 0, painter.width / 4, painter.height / 4]);\n\n let fbo = layer.heatmapFbos.get(HEATMAP_FULL_RENDER_FBO_KEY);\n\n if (!fbo) {\n fbo = createHeatmapFbo(context, painter.width / 4, painter.height / 4);\n layer.heatmapFbos.set(HEATMAP_FULL_RENDER_FBO_KEY, fbo);\n } else {\n gl.bindTexture(gl.TEXTURE_2D, fbo.colorAttachment.get());\n context.bindFramebuffer.set(fbo.framebuffer);\n }\n}\n\nfunction createHeatmapFbo(context: Context, width: number, height: number): Framebuffer {\n const gl = context.gl;\n const texture = gl.createTexture();\n gl.bindTexture(gl.TEXTURE_2D, texture);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n\n // Use the higher precision half-float texture where available (producing much smoother looking heatmaps);\n // Otherwise, fall back to a low precision texture\n const numType = context.HALF_FLOAT ?? gl.UNSIGNED_BYTE;\n const internalFormat = context.RGBA16F ?? gl.RGBA;\n\n gl.texImage2D(gl.TEXTURE_2D, 0, internalFormat, width, height, 0, gl.RGBA, numType, null);\n\n const fbo = context.createFramebuffer(width, height, false, false);\n fbo.colorAttachment.set(texture);\n\n return fbo;\n}\n\nfunction getColorRampTexture(context: Context, layer: HeatmapStyleLayer): Texture {\n if (!layer.colorRampTexture) {\n layer.colorRampTexture = new Texture(context, layer.colorRamp, context.gl.RGBA);\n }\n return layer.colorRampTexture;\n}\n","import {DepthMode} from '../gl/depth_mode';\nimport {CullFaceMode} from '../gl/cull_face_mode';\nimport {Texture} from './texture';\nimport {\n lineUniformValues,\n linePatternUniformValues,\n lineSDFUniformValues,\n lineGradientUniformValues\n} from './program/line_program';\n\nimport type {Painter} from './painter';\nimport type {SourceCache} from '../source/source_cache';\nimport type {LineStyleLayer} from '../style/style_layer/line_style_layer';\nimport type {LineBucket} from '../data/bucket/line_bucket';\nimport type {OverscaledTileID} from '../source/tile_id';\nimport {clamp, nextPowerOfTwo} from '../util/util';\nimport {renderColorRamp} from '../util/color_ramp';\nimport {EXTENT} from '../data/extent';\n\nexport function drawLine(painter: Painter, sourceCache: SourceCache, layer: LineStyleLayer, coords: Array) {\n if (painter.renderPass !== 'translucent') return;\n\n const opacity = layer.paint.get('line-opacity');\n const width = layer.paint.get('line-width');\n if (opacity.constantOr(1) === 0 || width.constantOr(1) === 0) return;\n\n const depthMode = painter.depthModeForSublayer(0, DepthMode.ReadOnly);\n const colorMode = painter.colorModeForRenderPass();\n\n const dasharray = layer.paint.get('line-dasharray');\n const patternProperty = layer.paint.get('line-pattern');\n const image = patternProperty.constantOr(1 as any);\n\n const gradient = layer.paint.get('line-gradient');\n const crossfade = layer.getCrossfadeParameters();\n\n const programId =\n image ? 'linePattern' :\n dasharray ? 'lineSDF' :\n gradient ? 'lineGradient' : 'line';\n\n const context = painter.context;\n const gl = context.gl;\n\n let firstTile = true;\n\n for (const coord of coords) {\n const tile = sourceCache.getTile(coord);\n\n if (image && !tile.patternsLoaded()) continue;\n\n const bucket: LineBucket = (tile.getBucket(layer) as any);\n if (!bucket) continue;\n\n const programConfiguration = bucket.programConfigurations.get(layer.id);\n const prevProgram = painter.context.program.get();\n const program = painter.useProgram(programId, programConfiguration);\n const programChanged = firstTile || program.program !== prevProgram;\n const terrainData = painter.style.map.terrain && painter.style.map.terrain.getTerrainData(coord);\n\n const constantPattern = patternProperty.constantOr(null);\n if (constantPattern && tile.imageAtlas) {\n const atlas = tile.imageAtlas;\n const posTo = atlas.patternPositions[constantPattern.to.toString()];\n const posFrom = atlas.patternPositions[constantPattern.from.toString()];\n if (posTo && posFrom) programConfiguration.setConstantPatternPositions(posTo, posFrom);\n }\n\n const terrainCoord = terrainData ? coord : null;\n const uniformValues = image ? linePatternUniformValues(painter, tile, layer, crossfade, terrainCoord) :\n dasharray ? lineSDFUniformValues(painter, tile, layer, dasharray, crossfade, terrainCoord) :\n gradient ? lineGradientUniformValues(painter, tile, layer, bucket.lineClipsArray.length, terrainCoord) :\n lineUniformValues(painter, tile, layer, terrainCoord);\n\n if (image) {\n context.activeTexture.set(gl.TEXTURE0);\n tile.imageAtlasTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n programConfiguration.updatePaintBuffers(crossfade);\n } else if (dasharray && (programChanged || painter.lineAtlas.dirty)) {\n context.activeTexture.set(gl.TEXTURE0);\n painter.lineAtlas.bind(context);\n } else if (gradient) {\n const layerGradient = bucket.gradients[layer.id];\n let gradientTexture = layerGradient.texture;\n if (layer.gradientVersion !== layerGradient.version) {\n let textureResolution = 256;\n if (layer.stepInterpolant) {\n const sourceMaxZoom = sourceCache.getSource().maxzoom;\n const potentialOverzoom = coord.canonical.z === sourceMaxZoom ?\n Math.ceil(1 << (painter.transform.maxZoom - coord.canonical.z)) : 1;\n const lineLength = bucket.maxLineLength / EXTENT;\n // Logical pixel tile size is 512px, and 1024px right before current zoom + 1\n const maxTilePixelSize = 1024;\n // Maximum possible texture coverage heuristic, bound by hardware max texture size\n const maxTextureCoverage = lineLength * maxTilePixelSize * potentialOverzoom;\n textureResolution = clamp(nextPowerOfTwo(maxTextureCoverage), 256, context.maxTextureSize);\n }\n layerGradient.gradient = renderColorRamp({\n expression: layer.gradientExpression(),\n evaluationKey: 'lineProgress',\n resolution: textureResolution,\n image: layerGradient.gradient || undefined,\n clips: bucket.lineClipsArray\n });\n if (layerGradient.texture) {\n layerGradient.texture.update(layerGradient.gradient);\n } else {\n layerGradient.texture = new Texture(context, layerGradient.gradient, gl.RGBA);\n }\n layerGradient.version = layer.gradientVersion;\n gradientTexture = layerGradient.texture;\n }\n context.activeTexture.set(gl.TEXTURE0);\n gradientTexture.bind(layer.stepInterpolant ? gl.NEAREST : gl.LINEAR, gl.CLAMP_TO_EDGE);\n }\n\n program.draw(context, gl.TRIANGLES, depthMode,\n painter.stencilModeForClipping(coord), colorMode, CullFaceMode.disabled, uniformValues, terrainData,\n layer.id, bucket.layoutVertexBuffer, bucket.indexBuffer, bucket.segments,\n layer.paint, painter.transform.zoom, programConfiguration, bucket.layoutVertexBuffer2);\n\n firstTile = false;\n // once refactored so that bound texture state is managed, we'll also be able to remove this firstTile/programChanged logic\n }\n}\n","import type {CrossFaded} from '../style/properties';\nimport type {ResolvedImage} from '@maplibre/maplibre-gl-style-spec';\nimport type {Tile} from '../source/tile';\nimport type {ProgramConfiguration} from '../data/program_configuration';\nimport type {FillExtrusionStyleLayer} from '../style/style_layer/fill_extrusion_style_layer';\nimport type {FillStyleLayer} from '../style/style_layer/fill_style_layer';\n\n/**\n * A simple helper shared by draw_fill and draw_fill_extrusions to find the correct pattern positions AND update program.\n * For transitionable properties, especially 'fill-pattern' and 'fill-extrusion-pattern', while rendering certain frames\n * tile.imageAtlas has been updated by worker to hold the new pattern only, but rendering code is still looking for the previous image.\n * The mismatch was causing setConstantPatternPositions method not being called and pixelRatio was always the\n * default of 1, instead of actual values set by original map.addImage.\n *\n * @param programConfiguration - to be used to set pattern position and device pixel ratio.\n * @param propertyName - 'fill-pattern' or 'fill-extrusion-pattern' property key\n * @param constantPattern - either 'fill-pattern' or 'fill-extrusion-pattern' property value\n * @param tile - current tile being drawn\n * @param layer - current layer being rendered\n */\nexport function updatePatternPositionsInProgram(\n programConfiguration: ProgramConfiguration,\n propertyName: 'fill-pattern' | 'fill-extrusion-pattern',\n constantPattern: CrossFaded,\n tile: Tile,\n layer: FillStyleLayer | FillExtrusionStyleLayer): void {\n\n if (!constantPattern || !tile || !tile.imageAtlas) {\n return;\n }\n\n const patternPositions = tile.imageAtlas.patternPositions;\n let posTo = patternPositions[constantPattern.to.toString()];\n let posFrom = patternPositions[constantPattern.from.toString()];\n\n // https://github.com/maplibre/maplibre-gl-js/issues/3377\n if (!posTo && posFrom) posTo = posFrom;\n if (!posFrom && posTo) posFrom = posTo;\n\n // try again in case patternPositions has been updated by worker\n if (!posTo || !posFrom) {\n const transitioned = layer.getPaintProperty(propertyName) as string;\n posTo = patternPositions[transitioned];\n posFrom = patternPositions[transitioned];\n }\n\n if (posTo && posFrom) {\n programConfiguration.setConstantPatternPositions(posTo, posFrom);\n }\n}\n","import {Color} from '@maplibre/maplibre-gl-style-spec';\nimport {DepthMode} from '../gl/depth_mode';\nimport {CullFaceMode} from '../gl/cull_face_mode';\nimport {ColorMode} from '../gl/color_mode';\nimport {\n fillUniformValues,\n fillPatternUniformValues,\n fillOutlineUniformValues,\n fillOutlinePatternUniformValues\n} from './program/fill_program';\n\nimport type {Painter} from './painter';\nimport type {SourceCache} from '../source/source_cache';\nimport type {FillStyleLayer} from '../style/style_layer/fill_style_layer';\nimport type {FillBucket} from '../data/bucket/fill_bucket';\nimport type {OverscaledTileID} from '../source/tile_id';\nimport {updatePatternPositionsInProgram} from './update_pattern_positions_in_program';\n\nexport function drawFill(painter: Painter, sourceCache: SourceCache, layer: FillStyleLayer, coords: Array) {\n const color = layer.paint.get('fill-color');\n const opacity = layer.paint.get('fill-opacity');\n\n if (opacity.constantOr(1) === 0) {\n return;\n }\n\n const colorMode = painter.colorModeForRenderPass();\n\n const pattern = layer.paint.get('fill-pattern');\n const pass = painter.opaquePassEnabledForLayer() &&\n (!pattern.constantOr(1 as any) &&\n color.constantOr(Color.transparent).a === 1 &&\n opacity.constantOr(0) === 1) ? 'opaque' : 'translucent';\n\n // Draw fill\n if (painter.renderPass === pass) {\n const depthMode = painter.depthModeForSublayer(\n 1, painter.renderPass === 'opaque' ? DepthMode.ReadWrite : DepthMode.ReadOnly);\n drawFillTiles(painter, sourceCache, layer, coords, depthMode, colorMode, false);\n }\n\n // Draw stroke\n if (painter.renderPass === 'translucent' && layer.paint.get('fill-antialias')) {\n\n // If we defined a different color for the fill outline, we are\n // going to ignore the bits in 0x07 and just care about the global\n // clipping mask.\n // Otherwise, we only want to drawFill the antialiased parts that are\n // *outside* the current shape. This is important in case the fill\n // or stroke color is translucent. If we wouldn't clip to outside\n // the current shape, some pixels from the outline stroke overlapped\n // the (non-antialiased) fill.\n const depthMode = painter.depthModeForSublayer(\n layer.getPaintProperty('fill-outline-color') ? 2 : 0, DepthMode.ReadOnly);\n drawFillTiles(painter, sourceCache, layer, coords, depthMode, colorMode, true);\n }\n}\n\nfunction drawFillTiles(\n painter: Painter,\n sourceCache: SourceCache,\n layer: FillStyleLayer,\n coords: Array,\n depthMode: Readonly,\n colorMode: Readonly,\n isOutline: boolean) {\n const gl = painter.context.gl;\n const fillPropertyName = 'fill-pattern';\n const patternProperty = layer.paint.get(fillPropertyName);\n const image = patternProperty && patternProperty.constantOr(1 as any);\n const crossfade = layer.getCrossfadeParameters();\n let drawMode, programName, uniformValues, indexBuffer, segments;\n\n if (!isOutline) {\n programName = image ? 'fillPattern' : 'fill';\n drawMode = gl.TRIANGLES;\n } else {\n programName = image && !layer.getPaintProperty('fill-outline-color') ? 'fillOutlinePattern' : 'fillOutline';\n drawMode = gl.LINES;\n }\n\n const constantPattern = patternProperty.constantOr(null);\n\n for (const coord of coords) {\n const tile = sourceCache.getTile(coord);\n if (image && !tile.patternsLoaded()) continue;\n\n const bucket: FillBucket = (tile.getBucket(layer) as any);\n if (!bucket) continue;\n\n const programConfiguration = bucket.programConfigurations.get(layer.id);\n const program = painter.useProgram(programName, programConfiguration);\n const terrainData = painter.style.map.terrain && painter.style.map.terrain.getTerrainData(coord);\n\n if (image) {\n painter.context.activeTexture.set(gl.TEXTURE0);\n tile.imageAtlasTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n programConfiguration.updatePaintBuffers(crossfade);\n }\n\n updatePatternPositionsInProgram(programConfiguration, fillPropertyName, constantPattern, tile, layer);\n\n const terrainCoord = terrainData ? coord : null;\n const posMatrix = terrainCoord ? terrainCoord.posMatrix : coord.posMatrix;\n const tileMatrix = painter.translatePosMatrix(posMatrix, tile,\n layer.paint.get('fill-translate'), layer.paint.get('fill-translate-anchor'));\n\n if (!isOutline) {\n indexBuffer = bucket.indexBuffer;\n segments = bucket.segments;\n uniformValues = image ?\n fillPatternUniformValues(tileMatrix, painter, crossfade, tile) :\n fillUniformValues(tileMatrix);\n } else {\n indexBuffer = bucket.indexBuffer2;\n segments = bucket.segments2;\n const drawingBufferSize = [gl.drawingBufferWidth, gl.drawingBufferHeight] as [number, number];\n uniformValues = (programName === 'fillOutlinePattern' && image) ?\n fillOutlinePatternUniformValues(tileMatrix, painter, crossfade, tile, drawingBufferSize) :\n fillOutlineUniformValues(tileMatrix, drawingBufferSize);\n }\n\n program.draw(painter.context, drawMode, depthMode,\n painter.stencilModeForClipping(coord), colorMode, CullFaceMode.disabled, uniformValues, terrainData,\n layer.id, bucket.layoutVertexBuffer, indexBuffer, segments,\n layer.paint, painter.transform.zoom, programConfiguration);\n }\n}\n","import {DepthMode} from '../gl/depth_mode';\nimport {StencilMode} from '../gl/stencil_mode';\nimport {ColorMode} from '../gl/color_mode';\nimport {CullFaceMode} from '../gl/cull_face_mode';\nimport {\n fillExtrusionUniformValues,\n fillExtrusionPatternUniformValues,\n} from './program/fill_extrusion_program';\n\nimport type {Painter} from './painter';\nimport type {SourceCache} from '../source/source_cache';\nimport type {FillExtrusionStyleLayer} from '../style/style_layer/fill_extrusion_style_layer';\nimport type {FillExtrusionBucket} from '../data/bucket/fill_extrusion_bucket';\nimport type {OverscaledTileID} from '../source/tile_id';\n\nimport {updatePatternPositionsInProgram} from './update_pattern_positions_in_program';\n\nexport function drawFillExtrusion(painter: Painter, source: SourceCache, layer: FillExtrusionStyleLayer, coords: Array) {\n const opacity = layer.paint.get('fill-extrusion-opacity');\n if (opacity === 0) {\n return;\n }\n\n if (painter.renderPass === 'translucent') {\n const depthMode = new DepthMode(painter.context.gl.LEQUAL, DepthMode.ReadWrite, painter.depthRangeFor3D);\n\n if (opacity === 1 && !layer.paint.get('fill-extrusion-pattern').constantOr(1 as any)) {\n const colorMode = painter.colorModeForRenderPass();\n drawExtrusionTiles(painter, source, layer, coords, depthMode, StencilMode.disabled, colorMode);\n\n } else {\n // Draw transparent buildings in two passes so that only the closest surface is drawn.\n // First draw all the extrusions into only the depth buffer. No colors are drawn.\n drawExtrusionTiles(painter, source, layer, coords, depthMode,\n StencilMode.disabled,\n ColorMode.disabled);\n\n // Then draw all the extrusions a second type, only coloring fragments if they have the\n // same depth value as the closest fragment in the previous pass. Use the stencil buffer\n // to prevent the second draw in cases where we have coincident polygons.\n drawExtrusionTiles(painter, source, layer, coords, depthMode,\n painter.stencilModeFor3D(),\n painter.colorModeForRenderPass());\n }\n }\n}\n\nfunction drawExtrusionTiles(\n painter: Painter,\n source: SourceCache,\n layer: FillExtrusionStyleLayer,\n coords: OverscaledTileID[],\n depthMode: DepthMode,\n stencilMode: Readonly,\n colorMode: Readonly) {\n const context = painter.context;\n const gl = context.gl;\n const fillPropertyName = 'fill-extrusion-pattern';\n const patternProperty = layer.paint.get(fillPropertyName);\n const image = patternProperty.constantOr(1 as any);\n const crossfade = layer.getCrossfadeParameters();\n const opacity = layer.paint.get('fill-extrusion-opacity');\n const constantPattern = patternProperty.constantOr(null);\n for (const coord of coords) {\n const tile = source.getTile(coord);\n const bucket: FillExtrusionBucket = (tile.getBucket(layer) as any);\n if (!bucket) continue;\n\n const terrainData = painter.style.map.terrain && painter.style.map.terrain.getTerrainData(coord);\n const programConfiguration = bucket.programConfigurations.get(layer.id);\n const program = painter.useProgram(image ? 'fillExtrusionPattern' : 'fillExtrusion', programConfiguration);\n\n if (image) {\n painter.context.activeTexture.set(gl.TEXTURE0);\n tile.imageAtlasTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n programConfiguration.updatePaintBuffers(crossfade);\n }\n\n updatePatternPositionsInProgram(programConfiguration, fillPropertyName, constantPattern, tile, layer);\n\n const matrix = painter.translatePosMatrix(\n coord.posMatrix,\n tile,\n layer.paint.get('fill-extrusion-translate'),\n layer.paint.get('fill-extrusion-translate-anchor'));\n\n const shouldUseVerticalGradient = layer.paint.get('fill-extrusion-vertical-gradient');\n const uniformValues = image ?\n fillExtrusionPatternUniformValues(matrix, painter, shouldUseVerticalGradient, opacity, coord, crossfade, tile) :\n fillExtrusionUniformValues(matrix, painter, shouldUseVerticalGradient, opacity);\n\n program.draw(context, context.gl.TRIANGLES, depthMode, stencilMode, colorMode, CullFaceMode.backCCW,\n uniformValues, terrainData, layer.id, bucket.layoutVertexBuffer, bucket.indexBuffer,\n bucket.segments, layer.paint, painter.transform.zoom,\n programConfiguration, painter.style.map.terrain && bucket.centroidVertexBuffer);\n }\n}\n","import {Texture} from './texture';\nimport {StencilMode} from '../gl/stencil_mode';\nimport {DepthMode} from '../gl/depth_mode';\nimport {CullFaceMode} from '../gl/cull_face_mode';\nimport {ColorMode} from '../gl/color_mode';\nimport {Tile} from '../source/tile';\nimport {\n hillshadeUniformValues,\n hillshadeUniformPrepareValues\n} from './program/hillshade_program';\n\nimport type {Painter} from './painter';\nimport type {SourceCache} from '../source/source_cache';\nimport type {HillshadeStyleLayer} from '../style/style_layer/hillshade_style_layer';\nimport type {OverscaledTileID} from '../source/tile_id';\n\nexport function drawHillshade(painter: Painter, sourceCache: SourceCache, layer: HillshadeStyleLayer, tileIDs: Array) {\n if (painter.renderPass !== 'offscreen' && painter.renderPass !== 'translucent') return;\n\n const context = painter.context;\n\n const depthMode = painter.depthModeForSublayer(0, DepthMode.ReadOnly);\n const colorMode = painter.colorModeForRenderPass();\n\n const [stencilModes, coords] = painter.renderPass === 'translucent' ?\n painter.stencilConfigForOverlap(tileIDs) : [{}, tileIDs];\n\n for (const coord of coords) {\n const tile = sourceCache.getTile(coord);\n if (typeof tile.needsHillshadePrepare !== 'undefined' && tile.needsHillshadePrepare && painter.renderPass === 'offscreen') {\n prepareHillshade(painter, tile, layer, depthMode, StencilMode.disabled, colorMode);\n } else if (painter.renderPass === 'translucent') {\n renderHillshade(painter, coord, tile, layer, depthMode, stencilModes[coord.overscaledZ], colorMode);\n }\n }\n\n context.viewport.set([0, 0, painter.width, painter.height]);\n}\n\nfunction renderHillshade(\n painter: Painter,\n coord: OverscaledTileID,\n tile: Tile,\n layer: HillshadeStyleLayer,\n depthMode: Readonly,\n stencilMode: Readonly,\n colorMode: Readonly) {\n const context = painter.context;\n const gl = context.gl;\n const fbo = tile.fbo;\n if (!fbo) return;\n\n const program = painter.useProgram('hillshade');\n const terrainData = painter.style.map.terrain && painter.style.map.terrain.getTerrainData(coord);\n\n context.activeTexture.set(gl.TEXTURE0);\n gl.bindTexture(gl.TEXTURE_2D, fbo.colorAttachment.get());\n\n const terrainCoord = terrainData ? coord : null;\n program.draw(context, gl.TRIANGLES, depthMode, stencilMode, colorMode, CullFaceMode.disabled,\n hillshadeUniformValues(painter, tile, layer, terrainCoord), terrainData, layer.id, painter.rasterBoundsBuffer,\n painter.quadTriangleIndexBuffer, painter.rasterBoundsSegments);\n\n}\n\n// hillshade rendering is done in two steps. the prepare step first calculates the slope of the terrain in the x and y\n// directions for each pixel, and saves those values to a framebuffer texture in the r and g channels.\nfunction prepareHillshade(\n painter: Painter,\n tile: Tile,\n layer: HillshadeStyleLayer,\n depthMode: Readonly,\n stencilMode: Readonly,\n colorMode: Readonly) {\n const context = painter.context;\n const gl = context.gl;\n const dem = tile.dem;\n if (dem && dem.data) {\n const tileSize = dem.dim;\n const textureStride = dem.stride;\n\n const pixelData = dem.getPixels();\n context.activeTexture.set(gl.TEXTURE1);\n\n context.pixelStoreUnpackPremultiplyAlpha.set(false);\n tile.demTexture = tile.demTexture || painter.getTileTexture(textureStride);\n if (tile.demTexture) {\n const demTexture = tile.demTexture;\n demTexture.update(pixelData, {premultiply: false});\n demTexture.bind(gl.NEAREST, gl.CLAMP_TO_EDGE);\n } else {\n tile.demTexture = new Texture(context, pixelData, gl.RGBA, {premultiply: false});\n tile.demTexture.bind(gl.NEAREST, gl.CLAMP_TO_EDGE);\n }\n\n context.activeTexture.set(gl.TEXTURE0);\n\n let fbo = tile.fbo;\n\n if (!fbo) {\n const renderTexture = new Texture(context, {width: tileSize, height: tileSize, data: null}, gl.RGBA);\n renderTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n\n fbo = tile.fbo = context.createFramebuffer(tileSize, tileSize, true, false);\n fbo.colorAttachment.set(renderTexture.texture);\n }\n\n context.bindFramebuffer.set(fbo.framebuffer);\n context.viewport.set([0, 0, tileSize, tileSize]);\n\n painter.useProgram('hillshadePrepare').draw(context, gl.TRIANGLES,\n depthMode, stencilMode, colorMode, CullFaceMode.disabled,\n hillshadeUniformPrepareValues(tile.tileID, dem),\n null, layer.id, painter.rasterBoundsBuffer,\n painter.quadTriangleIndexBuffer, painter.rasterBoundsSegments);\n\n tile.needsHillshadePrepare = false;\n }\n}\n","import {clamp} from '../util/util';\n\nimport {ImageSource} from '../source/image_source';\nimport {browser} from '../util/browser';\nimport {StencilMode} from '../gl/stencil_mode';\nimport {DepthMode} from '../gl/depth_mode';\nimport {CullFaceMode} from '../gl/cull_face_mode';\nimport {rasterUniformValues} from './program/raster_program';\n\nimport type {Painter} from './painter';\nimport type {SourceCache} from '../source/source_cache';\nimport type {RasterStyleLayer} from '../style/style_layer/raster_style_layer';\nimport type {OverscaledTileID} from '../source/tile_id';\n\nexport function drawRaster(painter: Painter, sourceCache: SourceCache, layer: RasterStyleLayer, tileIDs: Array) {\n if (painter.renderPass !== 'translucent') return;\n if (layer.paint.get('raster-opacity') === 0) return;\n if (!tileIDs.length) return;\n\n const context = painter.context;\n const gl = context.gl;\n const source = sourceCache.getSource();\n const program = painter.useProgram('raster');\n\n const colorMode = painter.colorModeForRenderPass();\n\n const [stencilModes, coords] = source instanceof ImageSource ? [{}, tileIDs] :\n painter.stencilConfigForOverlap(tileIDs);\n\n const minTileZ = coords[coords.length - 1].overscaledZ;\n\n const align = !painter.options.moving;\n for (const coord of coords) {\n // Set the lower zoom level to sublayer 0, and higher zoom levels to higher sublayers\n // Use gl.LESS to prevent double drawing in areas where tiles overlap.\n const depthMode = painter.depthModeForSublayer(coord.overscaledZ - minTileZ,\n layer.paint.get('raster-opacity') === 1 ? DepthMode.ReadWrite : DepthMode.ReadOnly, gl.LESS);\n\n const tile = sourceCache.getTile(coord);\n\n tile.registerFadeDuration(layer.paint.get('raster-fade-duration'));\n\n const parentTile = sourceCache.findLoadedParent(coord, 0);\n const siblingTile = sourceCache.findLoadedSibling(coord);\n // Prefer parent tile if present\n const fadeTileReference = parentTile || siblingTile || null;\n const fade = getFadeValues(tile, fadeTileReference, sourceCache, layer, painter.transform, painter.style.map.terrain);\n\n let parentScaleBy, parentTL;\n\n const textureFilter = layer.paint.get('raster-resampling') === 'nearest' ? gl.NEAREST : gl.LINEAR;\n\n context.activeTexture.set(gl.TEXTURE0);\n tile.texture.bind(textureFilter, gl.CLAMP_TO_EDGE, gl.LINEAR_MIPMAP_NEAREST);\n\n context.activeTexture.set(gl.TEXTURE1);\n\n if (parentTile) {\n parentTile.texture.bind(textureFilter, gl.CLAMP_TO_EDGE, gl.LINEAR_MIPMAP_NEAREST);\n parentScaleBy = Math.pow(2, parentTile.tileID.overscaledZ - tile.tileID.overscaledZ);\n parentTL = [tile.tileID.canonical.x * parentScaleBy % 1, tile.tileID.canonical.y * parentScaleBy % 1];\n\n } else {\n tile.texture.bind(textureFilter, gl.CLAMP_TO_EDGE, gl.LINEAR_MIPMAP_NEAREST);\n }\n\n // Enable anisotropic filtering only when the pitch is greater than 20 degrees\n // to preserve image sharpness on flat or slightly tilted maps.\n if (tile.texture.useMipmap && context.extTextureFilterAnisotropic && painter.transform.pitch > 20) {\n gl.texParameterf(gl.TEXTURE_2D, context.extTextureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT,\n context.extTextureFilterAnisotropicMax);\n }\n\n const terrainData = painter.style.map.terrain && painter.style.map.terrain.getTerrainData(coord);\n const terrainCoord = terrainData ? coord : null;\n const posMatrix = terrainCoord ? terrainCoord.posMatrix : painter.transform.calculatePosMatrix(coord.toUnwrapped(), align);\n const uniformValues = rasterUniformValues(posMatrix, parentTL || [0, 0], parentScaleBy || 1, fade, layer);\n\n if (source instanceof ImageSource) {\n program.draw(context, gl.TRIANGLES, depthMode, StencilMode.disabled, colorMode, CullFaceMode.disabled,\n uniformValues, terrainData, layer.id, source.boundsBuffer,\n painter.quadTriangleIndexBuffer, source.boundsSegments);\n } else {\n program.draw(context, gl.TRIANGLES, depthMode, stencilModes[coord.overscaledZ], colorMode, CullFaceMode.disabled,\n uniformValues, terrainData, layer.id, painter.rasterBoundsBuffer,\n painter.quadTriangleIndexBuffer, painter.rasterBoundsSegments);\n }\n }\n}\n\nfunction getFadeValues(tile, parentTile, sourceCache, layer, transform, terrain) {\n const fadeDuration = layer.paint.get('raster-fade-duration');\n\n if (!terrain && fadeDuration > 0) {\n const now = browser.now();\n const sinceTile = (now - tile.timeAdded) / fadeDuration;\n const sinceParent = parentTile ? (now - parentTile.timeAdded) / fadeDuration : -1;\n\n const source = sourceCache.getSource();\n const idealZ = transform.coveringZoomLevel({\n tileSize: source.tileSize,\n roundZoom: source.roundZoom\n });\n\n // if no parent or parent is older, fade in; if parent is younger, fade out\n const fadeIn = !parentTile || Math.abs(parentTile.tileID.overscaledZ - idealZ) > Math.abs(tile.tileID.overscaledZ - idealZ);\n\n const childOpacity = (fadeIn && tile.refreshedUponExpiration) ? 1 : clamp(fadeIn ? sinceTile : 1 - sinceParent, 0, 1);\n\n // we don't crossfade tiles that were just refreshed upon expiring:\n // once they're old enough to pass the crossfading threshold\n // (fadeDuration), unset the `refreshedUponExpiration` flag so we don't\n // incorrectly fail to crossfade them when zooming\n if (tile.refreshedUponExpiration && sinceTile >= 1) tile.refreshedUponExpiration = false;\n\n if (parentTile) {\n return {\n opacity: 1,\n mix: 1 - childOpacity\n };\n } else {\n return {\n opacity: childOpacity,\n mix: 0\n };\n }\n } else {\n return {\n opacity: 1,\n mix: 0\n };\n }\n}\n","import {StencilMode} from '../gl/stencil_mode';\nimport {DepthMode} from '../gl/depth_mode';\nimport {CullFaceMode} from '../gl/cull_face_mode';\nimport {\n backgroundUniformValues,\n backgroundPatternUniformValues\n} from './program/background_program';\n\nimport type {Painter} from './painter';\nimport type {SourceCache} from '../source/source_cache';\nimport type {BackgroundStyleLayer} from '../style/style_layer/background_style_layer';\nimport {OverscaledTileID} from '../source/tile_id';\n\nexport function drawBackground(painter: Painter, sourceCache: SourceCache, layer: BackgroundStyleLayer, coords?: Array) {\n const color = layer.paint.get('background-color');\n const opacity = layer.paint.get('background-opacity');\n\n if (opacity === 0) return;\n\n const context = painter.context;\n const gl = context.gl;\n const transform = painter.transform;\n const tileSize = transform.tileSize;\n const image = layer.paint.get('background-pattern');\n if (painter.isPatternMissing(image)) return;\n\n const pass = (!image && color.a === 1 && opacity === 1 && painter.opaquePassEnabledForLayer()) ? 'opaque' : 'translucent';\n if (painter.renderPass !== pass) return;\n\n const stencilMode = StencilMode.disabled;\n const depthMode = painter.depthModeForSublayer(0, pass === 'opaque' ? DepthMode.ReadWrite : DepthMode.ReadOnly);\n const colorMode = painter.colorModeForRenderPass();\n const program = painter.useProgram(image ? 'backgroundPattern' : 'background');\n const tileIDs = coords ? coords : transform.coveringTiles({tileSize, terrain: painter.style.map.terrain});\n\n if (image) {\n context.activeTexture.set(gl.TEXTURE0);\n painter.imageManager.bind(painter.context);\n }\n\n const crossfade = layer.getCrossfadeParameters();\n for (const tileID of tileIDs) {\n const matrix = coords ? tileID.posMatrix : painter.transform.calculatePosMatrix(tileID.toUnwrapped());\n const uniformValues = image ?\n backgroundPatternUniformValues(matrix, opacity, painter, image, {tileID, tileSize}, crossfade) :\n backgroundUniformValues(matrix, opacity, color);\n const terrainData = painter.style.map.terrain && painter.style.map.terrain.getTerrainData(tileID);\n\n program.draw(context, gl.TRIANGLES, depthMode, stencilMode, colorMode, CullFaceMode.disabled,\n uniformValues, terrainData, layer.id, painter.tileExtentBuffer,\n painter.quadTriangleIndexBuffer, painter.tileExtentSegments);\n }\n}\n","import {DepthMode} from '../gl/depth_mode';\nimport {StencilMode} from '../gl/stencil_mode';\nimport {CullFaceMode} from '../gl/cull_face_mode';\nimport {debugUniformValues} from './program/debug_program';\nimport {Color} from '@maplibre/maplibre-gl-style-spec';\nimport {ColorMode} from '../gl/color_mode';\n\nimport type {Painter} from './painter';\nimport type {SourceCache} from '../source/source_cache';\nimport type {OverscaledTileID} from '../source/tile_id';\nimport {Style} from '../style/style';\n\nconst topColor = new Color(1, 0, 0, 1);\nconst btmColor = new Color(0, 1, 0, 1);\nconst leftColor = new Color(0, 0, 1, 1);\nconst rightColor = new Color(1, 0, 1, 1);\nconst centerColor = new Color(0, 1, 1, 1);\n\nexport function drawDebugPadding(painter: Painter) {\n const padding = painter.transform.padding;\n const lineWidth = 3;\n // Top\n drawHorizontalLine(painter, painter.transform.height - (padding.top || 0), lineWidth, topColor);\n // Bottom\n drawHorizontalLine(painter, padding.bottom || 0, lineWidth, btmColor);\n // Left\n drawVerticalLine(painter, padding.left || 0, lineWidth, leftColor);\n // Right\n drawVerticalLine(painter, painter.transform.width - (padding.right || 0), lineWidth, rightColor);\n // Center\n const center = painter.transform.centerPoint;\n drawCrosshair(painter, center.x, painter.transform.height - center.y, centerColor);\n}\n\nfunction drawCrosshair(painter: Painter, x: number, y: number, color: Color) {\n const size = 20;\n const lineWidth = 2;\n //Vertical line\n drawDebugSSRect(painter, x - lineWidth / 2, y - size / 2, lineWidth, size, color);\n //Horizontal line\n drawDebugSSRect(painter, x - size / 2, y - lineWidth / 2, size, lineWidth, color);\n}\n\nfunction drawHorizontalLine(painter: Painter, y: number, lineWidth: number, color: Color) {\n drawDebugSSRect(painter, 0, y + lineWidth / 2, painter.transform.width, lineWidth, color);\n}\n\nfunction drawVerticalLine(painter: Painter, x: number, lineWidth: number, color: Color) {\n drawDebugSSRect(painter, x - lineWidth / 2, 0, lineWidth, painter.transform.height, color);\n}\n\nfunction drawDebugSSRect(painter: Painter, x: number, y: number, width: number, height: number, color: Color) {\n const context = painter.context;\n const gl = context.gl;\n\n gl.enable(gl.SCISSOR_TEST);\n gl.scissor(x * painter.pixelRatio, y * painter.pixelRatio, width * painter.pixelRatio, height * painter.pixelRatio);\n context.clear({color});\n gl.disable(gl.SCISSOR_TEST);\n}\n\nexport function drawDebug(painter: Painter, sourceCache: SourceCache, coords: Array) {\n for (let i = 0; i < coords.length; i++) {\n drawDebugTile(painter, sourceCache, coords[i]);\n }\n}\n\nfunction drawDebugTile(painter: Painter, sourceCache: SourceCache, coord: OverscaledTileID) {\n const context = painter.context;\n const gl = context.gl;\n\n const posMatrix = coord.posMatrix;\n const program = painter.useProgram('debug');\n\n const depthMode = DepthMode.disabled;\n const stencilMode = StencilMode.disabled;\n const colorMode = painter.colorModeForRenderPass();\n const id = '$debug';\n const terrainData = painter.style.map.terrain && painter.style.map.terrain.getTerrainData(coord);\n\n context.activeTexture.set(gl.TEXTURE0);\n\n const tileRawData = sourceCache.getTileByID(coord.key).latestRawTileData;\n const tileByteLength = (tileRawData && tileRawData.byteLength) || 0;\n const tileSizeKb = Math.floor(tileByteLength / 1024);\n const tileSize = sourceCache.getTile(coord).tileSize;\n const scaleRatio = (512 / Math.min(tileSize, 512) * (coord.overscaledZ / painter.transform.zoom)) * 0.5;\n let tileIdText = coord.canonical.toString();\n if (coord.overscaledZ !== coord.canonical.z) {\n tileIdText += ` => ${coord.overscaledZ}`;\n }\n const tileLabel = `${tileIdText} ${tileSizeKb}kB`;\n drawTextToOverlay(painter, tileLabel);\n\n program.draw(context, gl.TRIANGLES, depthMode, stencilMode, ColorMode.alphaBlended, CullFaceMode.disabled,\n debugUniformValues(posMatrix, Color.transparent, scaleRatio), null, id,\n painter.debugBuffer, painter.quadTriangleIndexBuffer, painter.debugSegments);\n program.draw(context, gl.LINE_STRIP, depthMode, stencilMode, colorMode, CullFaceMode.disabled,\n debugUniformValues(posMatrix, Color.red), terrainData, id,\n painter.debugBuffer, painter.tileBorderIndexBuffer, painter.debugSegments);\n}\n\nfunction drawTextToOverlay(painter: Painter, text: string) {\n painter.initDebugOverlayCanvas();\n const canvas = painter.debugOverlayCanvas;\n const gl = painter.context.gl;\n const ctx2d = painter.debugOverlayCanvas.getContext('2d');\n ctx2d.clearRect(0, 0, canvas.width, canvas.height);\n\n ctx2d.shadowColor = 'white';\n ctx2d.shadowBlur = 2;\n ctx2d.lineWidth = 1.5;\n ctx2d.strokeStyle = 'white';\n ctx2d.textBaseline = 'top';\n ctx2d.font = `bold ${36}px Open Sans, sans-serif`;\n ctx2d.fillText(text, 5, 5);\n ctx2d.strokeText(text, 5, 5);\n\n painter.debugOverlayTexture.update(canvas);\n painter.debugOverlayTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);\n}\n\nexport function selectDebugSource(style: Style, zoom: number): SourceCache | null {\n // Use vector source with highest maxzoom\n // Else use source with highest maxzoom of any type\n let selectedSource: SourceCache = null;\n const layers = Object.values(style._layers);\n const sources = layers.flatMap((layer) => {\n if (layer.source && !layer.isHidden(zoom)) {\n const sourceCache = style.sourceCaches[layer.source];\n return [sourceCache];\n } else {\n return [];\n }\n });\n const vectorSources = sources.filter((source) => source.getSource().type === 'vector');\n const otherSources = sources.filter((source) => source.getSource().type !== 'vector');\n const considerSource = (source: SourceCache) => {\n if (!selectedSource || (selectedSource.getSource().maxzoom < source.getSource().maxzoom)) {\n selectedSource = source;\n }\n };\n vectorSources.forEach((source) => considerSource(source));\n if (!selectedSource) {\n otherSources.forEach((source) => considerSource(source));\n }\n return selectedSource;\n}\n","import {DepthMode} from '../gl/depth_mode';\nimport {StencilMode} from '../gl/stencil_mode';\n\nimport type {Painter} from './painter';\nimport type {SourceCache} from '../source/source_cache';\nimport type {CustomStyleLayer} from '../style/style_layer/custom_style_layer';\n\nexport function drawCustom(painter: Painter, sourceCache: SourceCache, layer: CustomStyleLayer) {\n\n const context = painter.context;\n const implementation = layer.implementation;\n\n if (painter.renderPass === 'offscreen') {\n\n const prerender = implementation.prerender;\n if (prerender) {\n painter.setCustomLayerDefaults();\n context.setColorMode(painter.colorModeForRenderPass());\n\n prerender.call(implementation, context.gl, painter.transform.customLayerMatrix());\n\n context.setDirty();\n painter.setBaseState();\n }\n\n } else if (painter.renderPass === 'translucent') {\n\n painter.setCustomLayerDefaults();\n\n context.setColorMode(painter.colorModeForRenderPass());\n context.setStencilMode(StencilMode.disabled);\n\n const depthMode = implementation.renderingMode === '3d' ?\n new DepthMode(painter.context.gl.LEQUAL, DepthMode.ReadWrite, painter.depthRangeFor3D) :\n painter.depthModeForSublayer(0, DepthMode.ReadOnly);\n\n context.setDepthMode(depthMode);\n\n implementation.render(context.gl, painter.transform.customLayerMatrix(), {farZ: painter.transform.farZ, nearZ: painter.transform.nearZ, fov: painter.transform._fov, modelViewProjectionMatrix: painter.transform.modelViewProjectionMatrix, projectionMatrix: painter.transform.projectionMatrix});\n\n context.setDirty();\n painter.setBaseState();\n context.bindFramebuffer.set(null);\n }\n}\n","import {StencilMode} from '../gl/stencil_mode';\nimport {DepthMode} from '../gl/depth_mode';\nimport {terrainUniformValues, terrainDepthUniformValues, terrainCoordsUniformValues} from './program/terrain_program';\nimport type {Painter} from './painter';\nimport type {Tile} from '../source/tile';\nimport {CullFaceMode} from '../gl/cull_face_mode';\nimport {Color} from '@maplibre/maplibre-gl-style-spec';\nimport {ColorMode} from '../gl/color_mode';\nimport {Terrain} from './terrain';\n\n/**\n * Redraw the Depth Framebuffer\n * @param painter - the painter\n * @param terrain - the terrain\n */\nfunction drawDepth(painter: Painter, terrain: Terrain) {\n const context = painter.context;\n const gl = context.gl;\n const colorMode = ColorMode.unblended;\n const depthMode = new DepthMode(gl.LEQUAL, DepthMode.ReadWrite, [0, 1]);\n const mesh = terrain.getTerrainMesh();\n const tiles = terrain.sourceCache.getRenderableTiles();\n const program = painter.useProgram('terrainDepth');\n context.bindFramebuffer.set(terrain.getFramebuffer('depth').framebuffer);\n context.viewport.set([0, 0, painter.width / devicePixelRatio, painter.height / devicePixelRatio]);\n context.clear({color: Color.transparent, depth: 1});\n for (const tile of tiles) {\n const terrainData = terrain.getTerrainData(tile.tileID);\n const posMatrix = painter.transform.calculatePosMatrix(tile.tileID.toUnwrapped());\n const uniformValues = terrainDepthUniformValues(posMatrix, terrain.getMeshFrameDelta(painter.transform.zoom));\n program.draw(context, gl.TRIANGLES, depthMode, StencilMode.disabled, colorMode, CullFaceMode.backCCW, uniformValues, terrainData, 'terrain', mesh.vertexBuffer, mesh.indexBuffer, mesh.segments);\n }\n context.bindFramebuffer.set(null);\n context.viewport.set([0, 0, painter.width, painter.height]);\n}\n\n/**\n * Redraw the Coords Framebuffers\n * @param painter - the painter\n * @param terrain - the terrain\n */\nfunction drawCoords(painter: Painter, terrain: Terrain) {\n const context = painter.context;\n const gl = context.gl;\n const colorMode = ColorMode.unblended;\n const depthMode = new DepthMode(gl.LEQUAL, DepthMode.ReadWrite, [0, 1]);\n const mesh = terrain.getTerrainMesh();\n const coords = terrain.getCoordsTexture();\n const tiles = terrain.sourceCache.getRenderableTiles();\n\n // draw tile-coords into framebuffer\n const program = painter.useProgram('terrainCoords');\n context.bindFramebuffer.set(terrain.getFramebuffer('coords').framebuffer);\n context.viewport.set([0, 0, painter.width / devicePixelRatio, painter.height / devicePixelRatio]);\n context.clear({color: Color.transparent, depth: 1});\n terrain.coordsIndex = [];\n for (const tile of tiles) {\n const terrainData = terrain.getTerrainData(tile.tileID);\n context.activeTexture.set(gl.TEXTURE0);\n gl.bindTexture(gl.TEXTURE_2D, coords.texture);\n const posMatrix = painter.transform.calculatePosMatrix(tile.tileID.toUnwrapped());\n const uniformValues = terrainCoordsUniformValues(posMatrix, 255 - terrain.coordsIndex.length, terrain.getMeshFrameDelta(painter.transform.zoom));\n program.draw(context, gl.TRIANGLES, depthMode, StencilMode.disabled, colorMode, CullFaceMode.backCCW, uniformValues, terrainData, 'terrain', mesh.vertexBuffer, mesh.indexBuffer, mesh.segments);\n terrain.coordsIndex.push(tile.tileID.key);\n }\n context.bindFramebuffer.set(null);\n context.viewport.set([0, 0, painter.width, painter.height]);\n}\n\nfunction drawTerrain(painter: Painter, terrain: Terrain, tiles: Array) {\n const context = painter.context;\n const gl = context.gl;\n const colorMode = painter.colorModeForRenderPass();\n const depthMode = new DepthMode(gl.LEQUAL, DepthMode.ReadWrite, painter.depthRangeFor3D);\n const program = painter.useProgram('terrain');\n const mesh = terrain.getTerrainMesh();\n\n context.bindFramebuffer.set(null);\n context.viewport.set([0, 0, painter.width, painter.height]);\n\n for (const tile of tiles) {\n const texture = painter.renderToTexture.getTexture(tile);\n const terrainData = terrain.getTerrainData(tile.tileID);\n context.activeTexture.set(gl.TEXTURE0);\n gl.bindTexture(gl.TEXTURE_2D, texture.texture);\n const posMatrix = painter.transform.calculatePosMatrix(tile.tileID.toUnwrapped());\n const eleDelta = terrain.getMeshFrameDelta(painter.transform.zoom);\n const fogMatrix = painter.transform.calculateFogMatrix(tile.tileID.toUnwrapped());\n const uniformValues = terrainUniformValues(posMatrix, eleDelta, fogMatrix, painter.style.sky, painter.transform.pitch);\n program.draw(context, gl.TRIANGLES, depthMode, StencilMode.disabled, colorMode, CullFaceMode.backCCW, uniformValues, terrainData, 'terrain', mesh.vertexBuffer, mesh.indexBuffer, mesh.segments);\n }\n\n}\n\nexport {\n drawTerrain,\n drawDepth,\n drawCoords\n};\n","import {SegmentVector} from '../data/segment';\nimport {VertexBuffer} from '../gl/vertex_buffer';\nimport {IndexBuffer} from '../gl/index_buffer';\n\nexport class Mesh {\n vertexBuffer: VertexBuffer;\n indexBuffer: IndexBuffer;\n segments: SegmentVector;\n\n constructor(vertexBuffer: VertexBuffer, indexBuffer: IndexBuffer, segments: SegmentVector) {\n this.vertexBuffer = vertexBuffer;\n this.indexBuffer = indexBuffer;\n this.segments = segments;\n }\n\n destroy(): void {\n this.vertexBuffer.destroy();\n this.indexBuffer.destroy();\n this.segments.destroy();\n\n this.vertexBuffer = null;\n this.indexBuffer = null;\n this.segments = null;\n }\n}\n","import {StencilMode} from '../gl/stencil_mode';\nimport {DepthMode} from '../gl/depth_mode';\nimport {CullFaceMode} from '../gl/cull_face_mode';\nimport {PosArray, TriangleIndexArray} from '../data/array_types.g';\nimport posAttributes from '../data/pos_attributes';\nimport {SegmentVector} from '../data/segment';\nimport {skyUniformValues} from './program/sky_program';\nimport {Sky} from '../style/sky';\nimport {Mesh} from './mesh';\nimport type {Painter} from './painter';\n\nexport function drawSky(painter: Painter, sky: Sky) {\n const context = painter.context;\n const gl = context.gl;\n\n const skyUniforms = skyUniformValues(sky, painter.style.map.transform, painter.pixelRatio);\n\n const depthMode = new DepthMode(gl.LEQUAL, DepthMode.ReadWrite, [0, 1]);\n const stencilMode = StencilMode.disabled;\n const colorMode = painter.colorModeForRenderPass();\n const program = painter.useProgram('sky');\n\n if (!sky.mesh) {\n const vertexArray = new PosArray();\n vertexArray.emplaceBack(-1, -1);\n vertexArray.emplaceBack(1, -1);\n vertexArray.emplaceBack(1, 1);\n vertexArray.emplaceBack(-1, 1);\n\n const indexArray = new TriangleIndexArray();\n indexArray.emplaceBack(0, 1, 2);\n indexArray.emplaceBack(0, 2, 3);\n\n sky.mesh = new Mesh(\n context.createVertexBuffer(vertexArray, posAttributes.members),\n context.createIndexBuffer(indexArray),\n SegmentVector.simpleSegment(0, 0, vertexArray.length, indexArray.length)\n );\n }\n\n program.draw(context, gl.TRIANGLES, depthMode, stencilMode, colorMode,\n CullFaceMode.disabled, skyUniforms, undefined, 'sky', sky.mesh.vertexBuffer,\n sky.mesh.indexBuffer, sky.mesh.segments);\n}\n","import {browser} from '../util/browser';\nimport {mat4, vec3} from 'gl-matrix';\nimport {SourceCache} from '../source/source_cache';\nimport {EXTENT} from '../data/extent';\nimport {pixelsToTileUnits} from '../source/pixels_to_tile_units';\nimport {SegmentVector} from '../data/segment';\nimport {RasterBoundsArray, PosArray, TriangleIndexArray, LineStripIndexArray} from '../data/array_types.g';\nimport rasterBoundsAttributes from '../data/raster_bounds_attributes';\nimport posAttributes from '../data/pos_attributes';\nimport {ProgramConfiguration} from '../data/program_configuration';\nimport {CrossTileSymbolIndex} from '../symbol/cross_tile_symbol_index';\nimport {shaders} from '../shaders/shaders';\nimport {Program} from './program';\nimport {programUniforms} from './program/program_uniforms';\nimport {Context} from '../gl/context';\nimport {DepthMode} from '../gl/depth_mode';\nimport {StencilMode} from '../gl/stencil_mode';\nimport {ColorMode} from '../gl/color_mode';\nimport {CullFaceMode} from '../gl/cull_face_mode';\nimport {Texture} from './texture';\nimport {clippingMaskUniformValues} from './program/clipping_mask_program';\nimport {Color} from '@maplibre/maplibre-gl-style-spec';\nimport {drawSymbols} from './draw_symbol';\nimport {drawCircles} from './draw_circle';\nimport {drawHeatmap} from './draw_heatmap';\nimport {drawLine} from './draw_line';\nimport {drawFill} from './draw_fill';\nimport {drawFillExtrusion} from './draw_fill_extrusion';\nimport {drawHillshade} from './draw_hillshade';\nimport {drawRaster} from './draw_raster';\nimport {drawBackground} from './draw_background';\nimport {drawDebug, drawDebugPadding, selectDebugSource} from './draw_debug';\nimport {drawCustom} from './draw_custom';\nimport {drawDepth, drawCoords} from './draw_terrain';\nimport {OverscaledTileID} from '../source/tile_id';\nimport {RenderToTexture} from './render_to_texture';\nimport {drawSky} from './draw_sky';\n\nimport type {Transform} from '../geo/transform';\nimport type {Tile} from '../source/tile';\nimport type {Style} from '../style/style';\nimport type {StyleLayer} from '../style/style_layer';\nimport type {CrossFaded} from '../style/properties';\nimport type {LineAtlas} from './line_atlas';\nimport type {ImageManager} from './image_manager';\nimport type {GlyphManager} from './glyph_manager';\nimport type {VertexBuffer} from '../gl/vertex_buffer';\nimport type {IndexBuffer} from '../gl/index_buffer';\nimport type {DepthRangeType, DepthMaskType, DepthFuncType} from '../gl/types';\nimport type {ResolvedImage} from '@maplibre/maplibre-gl-style-spec';\n\nexport type RenderPass = 'offscreen' | 'opaque' | 'translucent';\n\ntype PainterOptions = {\n showOverdrawInspector: boolean;\n showTileBoundaries: boolean;\n showPadding: boolean;\n rotating: boolean;\n zooming: boolean;\n moving: boolean;\n fadeDuration: number;\n};\n\n/**\n * @internal\n * Initialize a new painter object.\n */\nexport class Painter {\n context: Context;\n transform: Transform;\n renderToTexture: RenderToTexture;\n _tileTextures: {\n [_: number]: Array;\n };\n numSublayers: number;\n depthEpsilon: number;\n emptyProgramConfiguration: ProgramConfiguration;\n width: number;\n height: number;\n pixelRatio: number;\n tileExtentBuffer: VertexBuffer;\n tileExtentSegments: SegmentVector;\n debugBuffer: VertexBuffer;\n debugSegments: SegmentVector;\n rasterBoundsBuffer: VertexBuffer;\n rasterBoundsSegments: SegmentVector;\n viewportBuffer: VertexBuffer;\n viewportSegments: SegmentVector;\n quadTriangleIndexBuffer: IndexBuffer;\n tileBorderIndexBuffer: IndexBuffer;\n _tileClippingMaskIDs: {[_: string]: number};\n stencilClearMode: StencilMode;\n style: Style;\n options: PainterOptions;\n lineAtlas: LineAtlas;\n imageManager: ImageManager;\n glyphManager: GlyphManager;\n depthRangeFor3D: DepthRangeType;\n opaquePassCutoff: number;\n renderPass: RenderPass;\n currentLayer: number;\n currentStencilSource: string;\n nextStencilID: number;\n id: string;\n _showOverdrawInspector: boolean;\n cache: {[_: string]: Program};\n crossTileSymbolIndex: CrossTileSymbolIndex;\n symbolFadeChange: number;\n debugOverlayTexture: Texture;\n debugOverlayCanvas: HTMLCanvasElement;\n // this object stores the current camera-matrix and the last render time\n // of the terrain-facilitators. e.g. depth & coords framebuffers\n // every time the camera-matrix changes the terrain-facilitators will be redrawn.\n terrainFacilitator: {dirty: boolean; matrix: mat4; renderTime: number};\n\n constructor(gl: WebGLRenderingContext | WebGL2RenderingContext, transform: Transform) {\n this.context = new Context(gl);\n this.transform = transform;\n this._tileTextures = {};\n this.terrainFacilitator = {dirty: true, matrix: mat4.identity(new Float64Array(16) as any), renderTime: 0};\n\n this.setup();\n\n // Within each layer there are multiple distinct z-planes that can be drawn to.\n // This is implemented using the WebGL depth buffer.\n this.numSublayers = SourceCache.maxUnderzooming + SourceCache.maxOverzooming + 1;\n this.depthEpsilon = 1 / Math.pow(2, 16);\n\n this.crossTileSymbolIndex = new CrossTileSymbolIndex();\n }\n\n /*\n * Update the GL viewport, projection matrix, and transforms to compensate\n * for a new width and height value.\n */\n resize(width: number, height: number, pixelRatio: number) {\n this.width = Math.floor(width * pixelRatio);\n this.height = Math.floor(height * pixelRatio);\n this.pixelRatio = pixelRatio;\n this.context.viewport.set([0, 0, this.width, this.height]);\n\n if (this.style) {\n for (const layerId of this.style._order) {\n this.style._layers[layerId].resize();\n }\n }\n }\n\n setup() {\n const context = this.context;\n\n const tileExtentArray = new PosArray();\n tileExtentArray.emplaceBack(0, 0);\n tileExtentArray.emplaceBack(EXTENT, 0);\n tileExtentArray.emplaceBack(0, EXTENT);\n tileExtentArray.emplaceBack(EXTENT, EXTENT);\n this.tileExtentBuffer = context.createVertexBuffer(tileExtentArray, posAttributes.members);\n this.tileExtentSegments = SegmentVector.simpleSegment(0, 0, 4, 2);\n\n const debugArray = new PosArray();\n debugArray.emplaceBack(0, 0);\n debugArray.emplaceBack(EXTENT, 0);\n debugArray.emplaceBack(0, EXTENT);\n debugArray.emplaceBack(EXTENT, EXTENT);\n this.debugBuffer = context.createVertexBuffer(debugArray, posAttributes.members);\n this.debugSegments = SegmentVector.simpleSegment(0, 0, 4, 5);\n\n const rasterBoundsArray = new RasterBoundsArray();\n rasterBoundsArray.emplaceBack(0, 0, 0, 0);\n rasterBoundsArray.emplaceBack(EXTENT, 0, EXTENT, 0);\n rasterBoundsArray.emplaceBack(0, EXTENT, 0, EXTENT);\n rasterBoundsArray.emplaceBack(EXTENT, EXTENT, EXTENT, EXTENT);\n this.rasterBoundsBuffer = context.createVertexBuffer(rasterBoundsArray, rasterBoundsAttributes.members);\n this.rasterBoundsSegments = SegmentVector.simpleSegment(0, 0, 4, 2);\n\n const viewportArray = new PosArray();\n viewportArray.emplaceBack(0, 0);\n viewportArray.emplaceBack(1, 0);\n viewportArray.emplaceBack(0, 1);\n viewportArray.emplaceBack(1, 1);\n this.viewportBuffer = context.createVertexBuffer(viewportArray, posAttributes.members);\n this.viewportSegments = SegmentVector.simpleSegment(0, 0, 4, 2);\n\n const tileLineStripIndices = new LineStripIndexArray();\n tileLineStripIndices.emplaceBack(0);\n tileLineStripIndices.emplaceBack(1);\n tileLineStripIndices.emplaceBack(3);\n tileLineStripIndices.emplaceBack(2);\n tileLineStripIndices.emplaceBack(0);\n this.tileBorderIndexBuffer = context.createIndexBuffer(tileLineStripIndices);\n\n const quadTriangleIndices = new TriangleIndexArray();\n quadTriangleIndices.emplaceBack(0, 1, 2);\n quadTriangleIndices.emplaceBack(2, 1, 3);\n this.quadTriangleIndexBuffer = context.createIndexBuffer(quadTriangleIndices);\n\n const gl = this.context.gl;\n this.stencilClearMode = new StencilMode({func: gl.ALWAYS, mask: 0}, 0x0, 0xFF, gl.ZERO, gl.ZERO, gl.ZERO);\n }\n\n /*\n * Reset the drawing canvas by clearing the stencil buffer so that we can draw\n * new tiles at the same location, while retaining previously drawn pixels.\n */\n clearStencil() {\n const context = this.context;\n const gl = context.gl;\n\n this.nextStencilID = 1;\n this.currentStencilSource = undefined;\n\n // As a temporary workaround for https://github.com/mapbox/mapbox-gl-js/issues/5490,\n // pending an upstream fix, we draw a fullscreen stencil=0 clipping mask here,\n // effectively clearing the stencil buffer: once an upstream patch lands, remove\n // this function in favor of context.clear({ stencil: 0x0 })\n\n const matrix = mat4.create();\n mat4.ortho(matrix, 0, this.width, this.height, 0, 0, 1);\n mat4.scale(matrix, matrix, [gl.drawingBufferWidth, gl.drawingBufferHeight, 0]);\n\n this.useProgram('clippingMask').draw(context, gl.TRIANGLES,\n DepthMode.disabled, this.stencilClearMode, ColorMode.disabled, CullFaceMode.disabled,\n clippingMaskUniformValues(matrix), null,\n '$clipping', this.viewportBuffer,\n this.quadTriangleIndexBuffer, this.viewportSegments);\n }\n\n _renderTileClippingMasks(layer: StyleLayer, tileIDs: Array) {\n if (this.currentStencilSource === layer.source || !layer.isTileClipped() || !tileIDs || !tileIDs.length) return;\n\n this.currentStencilSource = layer.source;\n\n const context = this.context;\n const gl = context.gl;\n\n if (this.nextStencilID + tileIDs.length > 256) {\n // we'll run out of fresh IDs so we need to clear and start from scratch\n this.clearStencil();\n }\n\n context.setColorMode(ColorMode.disabled);\n context.setDepthMode(DepthMode.disabled);\n\n const program = this.useProgram('clippingMask');\n\n this._tileClippingMaskIDs = {};\n\n for (const tileID of tileIDs) {\n const id = this._tileClippingMaskIDs[tileID.key] = this.nextStencilID++;\n const terrainData = this.style.map.terrain && this.style.map.terrain.getTerrainData(tileID);\n\n program.draw(context, gl.TRIANGLES, DepthMode.disabled,\n // Tests will always pass, and ref value will be written to stencil buffer.\n new StencilMode({func: gl.ALWAYS, mask: 0}, id, 0xFF, gl.KEEP, gl.KEEP, gl.REPLACE),\n ColorMode.disabled, CullFaceMode.disabled, clippingMaskUniformValues(tileID.posMatrix),\n terrainData, '$clipping', this.tileExtentBuffer,\n this.quadTriangleIndexBuffer, this.tileExtentSegments);\n }\n }\n\n stencilModeFor3D(): StencilMode {\n this.currentStencilSource = undefined;\n\n if (this.nextStencilID + 1 > 256) {\n this.clearStencil();\n }\n\n const id = this.nextStencilID++;\n const gl = this.context.gl;\n return new StencilMode({func: gl.NOTEQUAL, mask: 0xFF}, id, 0xFF, gl.KEEP, gl.KEEP, gl.REPLACE);\n }\n\n stencilModeForClipping(tileID: OverscaledTileID): StencilMode {\n const gl = this.context.gl;\n return new StencilMode({func: gl.EQUAL, mask: 0xFF}, this._tileClippingMaskIDs[tileID.key], 0x00, gl.KEEP, gl.KEEP, gl.REPLACE);\n }\n\n /*\n * Sort coordinates by Z as drawing tiles is done in Z-descending order.\n * All children with the same Z write the same stencil value. Children\n * stencil values are greater than parent's. This is used only for raster\n * and raster-dem tiles, which are already clipped to tile boundaries, to\n * mask area of tile overlapped by children tiles.\n * Stencil ref values continue range used in _tileClippingMaskIDs.\n *\n * Returns [StencilMode for tile overscaleZ map, sortedCoords].\n */\n stencilConfigForOverlap(tileIDs: Array): [{\n [_: number]: Readonly;\n }, Array] {\n const gl = this.context.gl;\n const coords = tileIDs.sort((a, b) => b.overscaledZ - a.overscaledZ);\n const minTileZ = coords[coords.length - 1].overscaledZ;\n const stencilValues = coords[0].overscaledZ - minTileZ + 1;\n if (stencilValues > 1) {\n this.currentStencilSource = undefined;\n if (this.nextStencilID + stencilValues > 256) {\n this.clearStencil();\n }\n const zToStencilMode = {};\n for (let i = 0; i < stencilValues; i++) {\n zToStencilMode[i + minTileZ] = new StencilMode({func: gl.GEQUAL, mask: 0xFF}, i + this.nextStencilID, 0xFF, gl.KEEP, gl.KEEP, gl.REPLACE);\n }\n this.nextStencilID += stencilValues;\n return [zToStencilMode, coords];\n }\n return [{[minTileZ]: StencilMode.disabled}, coords];\n }\n\n colorModeForRenderPass(): Readonly {\n const gl = this.context.gl;\n if (this._showOverdrawInspector) {\n const numOverdrawSteps = 8;\n const a = 1 / numOverdrawSteps;\n\n return new ColorMode([gl.CONSTANT_COLOR, gl.ONE], new Color(a, a, a, 0), [true, true, true, true]);\n } else if (this.renderPass === 'opaque') {\n return ColorMode.unblended;\n } else {\n return ColorMode.alphaBlended;\n }\n }\n\n depthModeForSublayer(n: number, mask: DepthMaskType, func?: DepthFuncType | null): Readonly {\n if (!this.opaquePassEnabledForLayer()) return DepthMode.disabled;\n const depth = 1 - ((1 + this.currentLayer) * this.numSublayers + n) * this.depthEpsilon;\n return new DepthMode(func || this.context.gl.LEQUAL, mask, [depth, depth]);\n }\n\n /*\n * The opaque pass and 3D layers both use the depth buffer.\n * Layers drawn above 3D layers need to be drawn using the\n * painter's algorithm so that they appear above 3D features.\n * This returns true for layers that can be drawn using the\n * opaque pass.\n */\n opaquePassEnabledForLayer() {\n return this.currentLayer < this.opaquePassCutoff;\n }\n\n render(style: Style, options: PainterOptions) {\n this.style = style;\n this.options = options;\n\n this.lineAtlas = style.lineAtlas;\n this.imageManager = style.imageManager;\n this.glyphManager = style.glyphManager;\n\n this.symbolFadeChange = style.placement.symbolFadeChange(browser.now());\n\n this.imageManager.beginFrame();\n\n const layerIds = this.style._order;\n const sourceCaches = this.style.sourceCaches;\n\n const coordsAscending: {[_: string]: Array} = {};\n const coordsDescending: {[_: string]: Array} = {};\n const coordsDescendingSymbol: {[_: string]: Array} = {};\n\n for (const id in sourceCaches) {\n const sourceCache = sourceCaches[id];\n if (sourceCache.used) {\n sourceCache.prepare(this.context);\n }\n\n coordsAscending[id] = sourceCache.getVisibleCoordinates();\n coordsDescending[id] = coordsAscending[id].slice().reverse();\n coordsDescendingSymbol[id] = sourceCache.getVisibleCoordinates(true).reverse();\n }\n\n this.opaquePassCutoff = Infinity;\n for (let i = 0; i < layerIds.length; i++) {\n const layerId = layerIds[i];\n if (this.style._layers[layerId].is3D()) {\n this.opaquePassCutoff = i;\n break;\n }\n }\n\n this.maybeDrawDepthAndCoords(false);\n\n if (this.renderToTexture) {\n this.renderToTexture.prepareForRender(this.style, this.transform.zoom);\n // this is disabled, because render-to-texture is rendering all layers from bottom to top.\n this.opaquePassCutoff = 0;\n }\n\n // Offscreen pass ===============================================\n // We first do all rendering that requires rendering to a separate\n // framebuffer, and then save those for rendering back to the map\n // later: in doing this we avoid doing expensive framebuffer restores.\n this.renderPass = 'offscreen';\n\n for (const layerId of layerIds) {\n const layer = this.style._layers[layerId];\n if (!layer.hasOffscreenPass() || layer.isHidden(this.transform.zoom)) continue;\n\n const coords = coordsDescending[layer.source];\n if (layer.type !== 'custom' && !coords.length) continue;\n\n this.renderLayer(this, sourceCaches[layer.source], layer, coords);\n }\n\n // Rebind the main framebuffer now that all offscreen layers have been rendered:\n this.context.bindFramebuffer.set(null);\n\n // Clear buffers in preparation for drawing to the main framebuffer\n this.context.clear({color: options.showOverdrawInspector ? Color.black : Color.transparent, depth: 1});\n this.clearStencil();\n\n // draw sky first to not overwrite symbols\n if (this.style.sky) drawSky(this, this.style.sky);\n\n this._showOverdrawInspector = options.showOverdrawInspector;\n this.depthRangeFor3D = [0, 1 - ((style._order.length + 2) * this.numSublayers * this.depthEpsilon)];\n\n // Opaque pass ===============================================\n // Draw opaque layers top-to-bottom first.\n if (!this.renderToTexture) {\n this.renderPass = 'opaque';\n\n for (this.currentLayer = layerIds.length - 1; this.currentLayer >= 0; this.currentLayer--) {\n const layer = this.style._layers[layerIds[this.currentLayer]];\n const sourceCache = sourceCaches[layer.source];\n const coords = coordsAscending[layer.source];\n\n this._renderTileClippingMasks(layer, coords);\n this.renderLayer(this, sourceCache, layer, coords);\n }\n }\n\n // Translucent pass ===============================================\n // Draw all other layers bottom-to-top.\n this.renderPass = 'translucent';\n\n for (this.currentLayer = 0; this.currentLayer < layerIds.length; this.currentLayer++) {\n const layer = this.style._layers[layerIds[this.currentLayer]];\n const sourceCache = sourceCaches[layer.source];\n\n if (this.renderToTexture && this.renderToTexture.renderLayer(layer)) continue;\n\n // For symbol layers in the translucent pass, we add extra tiles to the renderable set\n // for cross-tile symbol fading. Symbol layers don't use tile clipping, so no need to render\n // separate clipping masks\n const coords = (layer.type === 'symbol' ? coordsDescendingSymbol : coordsDescending)[layer.source];\n\n this._renderTileClippingMasks(layer, coordsAscending[layer.source]);\n this.renderLayer(this, sourceCache, layer, coords);\n }\n\n if (this.options.showTileBoundaries) {\n const selectedSource = selectDebugSource(this.style, this.transform.zoom);\n if (selectedSource) {\n drawDebug(this, selectedSource, selectedSource.getVisibleCoordinates());\n }\n }\n\n if (this.options.showPadding) {\n drawDebugPadding(this);\n }\n\n // Set defaults for most GL values so that anyone using the state after the render\n // encounters more expected values.\n this.context.setDefault();\n }\n\n /**\n * Update the depth and coords framebuffers, if the contents of those frame buffers is out of date.\n * If requireExact is false, then the contents of those frame buffers is not updated if it is close\n * to accurate (that is, the camera has not moved much since it was updated last).\n */\n maybeDrawDepthAndCoords(requireExact: boolean) {\n if (!this.style || !this.style.map || !this.style.map.terrain) {\n return;\n }\n const prevMatrix = this.terrainFacilitator.matrix;\n const currMatrix = this.transform.modelViewProjectionMatrix;\n\n // Update coords/depth-framebuffer on camera movement, or tile reloading\n let doUpdate = this.terrainFacilitator.dirty;\n doUpdate ||= requireExact ? !mat4.exactEquals(prevMatrix, currMatrix) : !mat4.equals(prevMatrix, currMatrix);\n doUpdate ||= this.style.map.terrain.sourceCache.tilesAfterTime(this.terrainFacilitator.renderTime).length > 0;\n\n if (!doUpdate) {\n return;\n }\n\n mat4.copy(prevMatrix, currMatrix);\n this.terrainFacilitator.renderTime = Date.now();\n this.terrainFacilitator.dirty = false;\n drawDepth(this, this.style.map.terrain);\n drawCoords(this, this.style.map.terrain);\n }\n\n renderLayer(painter: Painter, sourceCache: SourceCache, layer: StyleLayer, coords: Array) {\n if (layer.isHidden(this.transform.zoom)) return;\n if (layer.type !== 'background' && layer.type !== 'custom' && !(coords || []).length) return;\n this.id = layer.id;\n\n switch (layer.type) {\n case 'symbol':\n drawSymbols(painter, sourceCache, layer as any, coords, this.style.placement.variableOffsets);\n break;\n case 'circle':\n drawCircles(painter, sourceCache, layer as any, coords);\n break;\n case 'heatmap':\n drawHeatmap(painter, sourceCache, layer as any, coords);\n break;\n case 'line':\n drawLine(painter, sourceCache, layer as any, coords);\n break;\n case 'fill':\n drawFill(painter, sourceCache, layer as any, coords);\n break;\n case 'fill-extrusion':\n drawFillExtrusion(painter, sourceCache, layer as any, coords);\n break;\n case 'hillshade':\n drawHillshade(painter, sourceCache, layer as any, coords);\n break;\n case 'raster':\n drawRaster(painter, sourceCache, layer as any, coords);\n break;\n case 'background':\n drawBackground(painter, sourceCache, layer as any, coords);\n break;\n case 'custom':\n drawCustom(painter, sourceCache, layer as any);\n break;\n }\n }\n\n /**\n * Transform a matrix to incorporate the *-translate and *-translate-anchor properties into it.\n * @param inViewportPixelUnitsUnits - True when the units accepted by the matrix are in viewport pixels instead of tile units.\n * @returns matrix\n */\n translatePosMatrix(matrix: mat4, tile: Tile, translate: [number, number], translateAnchor: 'map' | 'viewport', inViewportPixelUnitsUnits?: boolean): mat4 {\n if (!translate[0] && !translate[1]) return matrix;\n\n const angle = inViewportPixelUnitsUnits ?\n (translateAnchor === 'map' ? this.transform.angle : 0) :\n (translateAnchor === 'viewport' ? -this.transform.angle : 0);\n\n if (angle) {\n const sinA = Math.sin(angle);\n const cosA = Math.cos(angle);\n translate = [\n translate[0] * cosA - translate[1] * sinA,\n translate[0] * sinA + translate[1] * cosA\n ];\n }\n\n const translation = [\n inViewportPixelUnitsUnits ? translate[0] : pixelsToTileUnits(tile, translate[0], this.transform.zoom),\n inViewportPixelUnitsUnits ? translate[1] : pixelsToTileUnits(tile, translate[1], this.transform.zoom),\n 0\n ] as vec3;\n\n const translatedMatrix = new Float32Array(16);\n mat4.translate(translatedMatrix, matrix, translation);\n return translatedMatrix;\n }\n\n saveTileTexture(texture: Texture) {\n const textures = this._tileTextures[texture.size[0]];\n if (!textures) {\n this._tileTextures[texture.size[0]] = [texture];\n } else {\n textures.push(texture);\n }\n }\n\n getTileTexture(size: number) {\n const textures = this._tileTextures[size];\n return textures && textures.length > 0 ? textures.pop() : null;\n }\n\n /**\n * Checks whether a pattern image is needed, and if it is, whether it is not loaded.\n *\n * @returns true if a needed image is missing and rendering needs to be skipped.\n */\n isPatternMissing(image?: CrossFaded | null): boolean {\n if (!image) return false;\n if (!image.from || !image.to) return true;\n const imagePosA = this.imageManager.getPattern(image.from.toString());\n const imagePosB = this.imageManager.getPattern(image.to.toString());\n return !imagePosA || !imagePosB;\n }\n\n useProgram(name: string, programConfiguration?: ProgramConfiguration | null): Program {\n this.cache = this.cache || {};\n const key = name +\n (programConfiguration ? programConfiguration.cacheKey : '') +\n (this._showOverdrawInspector ? '/overdraw' : '') +\n (this.style.map.terrain ? '/terrain' : '');\n if (!this.cache[key]) {\n this.cache[key] = new Program(\n this.context,\n shaders[name],\n programConfiguration,\n programUniforms[name],\n this._showOverdrawInspector,\n this.style.map.terrain\n );\n }\n return this.cache[key];\n }\n\n /*\n * Reset some GL state to default values to avoid hard-to-debug bugs\n * in custom layers.\n */\n setCustomLayerDefaults() {\n // Prevent custom layers from unintentionally modify the last VAO used.\n // All other state is state is restored on it's own, but for VAOs it's\n // simpler to unbind so that we don't have to track the state of VAOs.\n this.context.unbindVAO();\n\n // The default values for this state is meaningful and often expected.\n // Leaving this state dirty could cause a lot of confusion for users.\n this.context.cullFace.setDefault();\n this.context.activeTexture.setDefault();\n this.context.pixelStoreUnpack.setDefault();\n this.context.pixelStoreUnpackPremultiplyAlpha.setDefault();\n this.context.pixelStoreUnpackFlipY.setDefault();\n }\n\n /*\n * Set GL state that is shared by all layers.\n */\n setBaseState() {\n const gl = this.context.gl;\n this.context.cullFace.set(false);\n this.context.viewport.set([0, 0, this.width, this.height]);\n this.context.blendEquation.set(gl.FUNC_ADD);\n }\n\n initDebugOverlayCanvas() {\n if (this.debugOverlayCanvas == null) {\n this.debugOverlayCanvas = document.createElement('canvas');\n this.debugOverlayCanvas.width = 512;\n this.debugOverlayCanvas.height = 512;\n const gl = this.context.gl;\n this.debugOverlayTexture = new Texture(this.context, this.debugOverlayCanvas, gl.RGBA);\n }\n }\n\n destroy() {\n if (this.debugOverlayTexture) {\n this.debugOverlayTexture.destroy();\n }\n }\n\n /*\n * Return true if drawing buffer size is != from requested size.\n * That means that we've reached GL limits somehow.\n * Note: drawing buffer size changes only when canvas size changes\n */\n overLimit() {\n const {drawingBufferWidth, drawingBufferHeight} = this.context.gl;\n return this.width !== drawingBufferWidth || this.height !== drawingBufferHeight;\n }\n}\n","import {mat4, vec3, vec4} from 'gl-matrix';\n\nclass Frustum {\n\n constructor(public points: vec4[], public planes: vec4[]) { }\n\n public static fromInvProjectionMatrix(invProj: mat4, worldSize: number, zoom: number): Frustum {\n const clipSpaceCorners = [\n [-1, 1, -1, 1],\n [1, 1, -1, 1],\n [1, -1, -1, 1],\n [-1, -1, -1, 1],\n [-1, 1, 1, 1],\n [1, 1, 1, 1],\n [1, -1, 1, 1],\n [-1, -1, 1, 1]\n ];\n\n const scale = Math.pow(2, zoom);\n\n // Transform frustum corner points from clip space to tile space, Z to meters\n const frustumCoords = clipSpaceCorners.map(v => {\n v = vec4.transformMat4([] as any, v as any, invProj) as any;\n const s = 1.0 / v[3] / worldSize * scale;\n return vec4.mul(v as any, v as any, [s, s, 1.0 / v[3], s] as vec4);\n });\n\n const frustumPlanePointIndices = [\n [0, 1, 2], // near\n [6, 5, 4], // far\n [0, 3, 7], // left\n [2, 1, 5], // right\n [3, 2, 6], // bottom\n [0, 4, 5] // top\n ];\n\n const frustumPlanes = frustumPlanePointIndices.map((p: number[]) => {\n const a = vec3.sub([] as any, frustumCoords[p[0]] as vec3, frustumCoords[p[1]] as vec3);\n const b = vec3.sub([] as any, frustumCoords[p[2]] as vec3, frustumCoords[p[1]] as vec3);\n const n = vec3.normalize([] as any, vec3.cross([] as any, a, b)) as any;\n const d = -vec3.dot(n, frustumCoords[p[1]] as vec3);\n return n.concat(d);\n });\n\n return new Frustum(frustumCoords, frustumPlanes);\n }\n}\n\nclass Aabb {\n min: vec3;\n max: vec3;\n center: vec3;\n\n constructor(min_: vec3, max_: vec3) {\n this.min = min_;\n this.max = max_;\n this.center = vec3.scale([] as any, vec3.add([] as any, this.min, this.max), 0.5);\n }\n\n quadrant(index: number): Aabb {\n const split = [(index % 2) === 0, index < 2];\n const qMin = vec3.clone(this.min);\n const qMax = vec3.clone(this.max);\n for (let axis = 0; axis < split.length; axis++) {\n qMin[axis] = split[axis] ? this.min[axis] : this.center[axis];\n qMax[axis] = split[axis] ? this.center[axis] : this.max[axis];\n }\n // Elevation is always constant, hence quadrant.max.z = this.max.z\n qMax[2] = this.max[2];\n return new Aabb(qMin, qMax);\n }\n\n distanceX(point: Array): number {\n const pointOnAabb = Math.max(Math.min(this.max[0], point[0]), this.min[0]);\n return pointOnAabb - point[0];\n }\n\n distanceY(point: Array): number {\n const pointOnAabb = Math.max(Math.min(this.max[1], point[1]), this.min[1]);\n return pointOnAabb - point[1];\n }\n\n // Performs a frustum-aabb intersection test. Returns 0 if there's no intersection,\n // 1 if shapes are intersecting and 2 if the aabb if fully inside the frustum.\n intersects(frustum: Frustum): number {\n // Execute separating axis test between two convex objects to find intersections\n // Each frustum plane together with 3 major axes define the separating axes\n\n const aabbPoints = [\n [this.min[0], this.min[1], this.min[2], 1],\n [this.max[0], this.min[1], this.min[2], 1],\n [this.max[0], this.max[1], this.min[2], 1],\n [this.min[0], this.max[1], this.min[2], 1],\n [this.min[0], this.min[1], this.max[2], 1],\n [this.max[0], this.min[1], this.max[2], 1],\n [this.max[0], this.max[1], this.max[2], 1],\n [this.min[0], this.max[1], this.max[2], 1]\n ];\n\n let fullyInside = true;\n\n for (let p = 0; p < frustum.planes.length; p++) {\n const plane = frustum.planes[p];\n let pointsInside = 0;\n\n for (let i = 0; i < aabbPoints.length; i++) {\n if (vec4.dot(plane, aabbPoints[i] as any) >= 0) {\n pointsInside++;\n }\n }\n\n if (pointsInside === 0)\n return 0;\n\n if (pointsInside !== aabbPoints.length)\n fullyInside = false;\n }\n\n if (fullyInside)\n return 2;\n\n for (let axis = 0; axis < 3; axis++) {\n let projMin = Number.MAX_VALUE;\n let projMax = -Number.MAX_VALUE;\n\n for (let p = 0; p < frustum.points.length; p++) {\n const projectedPoint = frustum.points[p][axis] - this.min[axis];\n\n projMin = Math.min(projMin, projectedPoint);\n projMax = Math.max(projMax, projectedPoint);\n }\n\n if (projMax < 0 || projMin > this.max[axis] - this.min[axis])\n return 0;\n }\n\n return 1;\n }\n}\nexport {\n Aabb,\n Frustum\n};\n","import {interpolates} from '@maplibre/maplibre-gl-style-spec';\nimport Point from '@mapbox/point-geometry';\nimport {clamp} from '../util/util';\n\n/**\n * An `EdgeInset` object represents screen space padding applied to the edges of the viewport.\n * This shifts the apprent center or the vanishing point of the map. This is useful for adding floating UI elements\n * on top of the map and having the vanishing point shift as UI elements resize.\n *\n * @group Geography and Geometry\n */\nexport class EdgeInsets {\n /**\n * @defaultValue 0\n */\n top: number;\n /**\n * @defaultValue 0\n */\n bottom: number;\n /**\n * @defaultValue 0\n */\n left: number;\n /**\n * @defaultValue 0\n */\n right: number;\n\n constructor(top: number = 0, bottom: number = 0, left: number = 0, right: number = 0) {\n if (isNaN(top) || top < 0 ||\n isNaN(bottom) || bottom < 0 ||\n isNaN(left) || left < 0 ||\n isNaN(right) || right < 0\n ) {\n throw new Error('Invalid value for edge-insets, top, bottom, left and right must all be numbers');\n }\n\n this.top = top;\n this.bottom = bottom;\n this.left = left;\n this.right = right;\n }\n\n /**\n * Interpolates the inset in-place.\n * This maintains the current inset value for any inset not present in `target`.\n * @param start - interpolation start\n * @param target - interpolation target\n * @param t - interpolation step/weight\n * @returns the insets\n */\n interpolate(start: PaddingOptions | EdgeInsets, target: PaddingOptions, t: number): EdgeInsets {\n if (target.top != null && start.top != null) this.top = interpolates.number(start.top, target.top, t);\n if (target.bottom != null && start.bottom != null) this.bottom = interpolates.number(start.bottom, target.bottom, t);\n if (target.left != null && start.left != null) this.left = interpolates.number(start.left, target.left, t);\n if (target.right != null && start.right != null) this.right = interpolates.number(start.right, target.right, t);\n\n return this;\n }\n\n /**\n * Utility method that computes the new apprent center or vanishing point after applying insets.\n * This is in pixels and with the top left being (0.0) and +y being downwards.\n *\n * @param width - the width\n * @param height - the height\n * @returns the point\n */\n getCenter(width: number, height: number): Point {\n // Clamp insets so they never overflow width/height and always calculate a valid center\n const x = clamp((this.left + width - this.right) / 2, 0, width);\n const y = clamp((this.top + height - this.bottom) / 2, 0, height);\n\n return new Point(x, y);\n }\n\n equals(other: PaddingOptions): boolean {\n return this.top === other.top &&\n this.bottom === other.bottom &&\n this.left === other.left &&\n this.right === other.right;\n }\n\n clone(): EdgeInsets {\n return new EdgeInsets(this.top, this.bottom, this.left, this.right);\n }\n\n /**\n * Returns the current state as json, useful when you want to have a\n * read-only representation of the inset.\n *\n * @returns state as json\n */\n toJSON(): PaddingOptions {\n return {\n top: this.top,\n bottom: this.bottom,\n left: this.left,\n right: this.right\n };\n }\n}\n\n/**\n * Options for setting padding on calls to methods such as {@link Map#fitBounds}, {@link Map#fitScreenCoordinates}, and {@link Map#setPadding}. Adjust these options to set the amount of padding in pixels added to the edges of the canvas. Set a uniform padding on all edges or individual values for each edge. All properties of this object must be\n * non-negative integers.\n *\n * @group Geography and Geometry\n *\n * @example\n * ```ts\n * let bbox = [[-79, 43], [-73, 45]];\n * map.fitBounds(bbox, {\n * padding: {top: 10, bottom:25, left: 15, right: 5}\n * });\n * ```\n *\n * @example\n * ```ts\n * let bbox = [[-79, 43], [-73, 45]];\n * map.fitBounds(bbox, {\n * padding: 20\n * });\n * ```\n * @see [Fit to the bounds of a LineString](https://maplibre.org/maplibre-gl-js/docs/examples/zoomto-linestring/)\n * @see [Fit a map to a bounding box](https://maplibre.org/maplibre-gl-js/docs/examples/fitbounds/)\n */\nexport type PaddingOptions = {\n /**\n * Padding in pixels from the top of the map canvas.\n */\n top: number;\n /**\n * Padding in pixels from the bottom of the map canvas.\n */\n bottom: number;\n /**\n * Padding in pixels from the left of the map canvas.\n */\n right: number;\n /**\n * Padding in pixels from the right of the map canvas.\n */\n left: number;\n};\n","import {LngLat} from './lng_lat';\nimport {LngLatBounds} from './lng_lat_bounds';\nimport {MercatorCoordinate, mercatorXfromLng, mercatorYfromLat, mercatorZfromAltitude} from './mercator_coordinate';\nimport Point from '@mapbox/point-geometry';\nimport {wrap, clamp} from '../util/util';\nimport {interpolates} from '@maplibre/maplibre-gl-style-spec';\nimport {EXTENT} from '../data/extent';\nimport {vec3, vec4, mat4, mat2, vec2} from 'gl-matrix';\nimport {Aabb, Frustum} from '../util/primitives';\nimport {EdgeInsets} from './edge_insets';\n\nimport {UnwrappedTileID, OverscaledTileID, CanonicalTileID} from '../source/tile_id';\nimport type {PaddingOptions} from './edge_insets';\nimport {Terrain} from '../render/terrain';\n\nexport const MAX_VALID_LATITUDE = 85.051129;\n\n/**\n * @internal\n * A single transform, generally used for a single tile to be\n * scaled, rotated, and zoomed.\n */\nexport class Transform {\n tileSize: number;\n tileZoom: number;\n lngRange: [number, number];\n latRange: [number, number];\n scale: number;\n width: number;\n height: number;\n angle: number;\n rotationMatrix: mat2;\n pixelsToGLUnits: [number, number];\n cameraToCenterDistance: number;\n mercatorMatrix: mat4;\n projectionMatrix: mat4;\n modelViewProjectionMatrix: mat4;\n invModelViewProjectionMatrix: mat4;\n alignedModelViewProjectionMatrix: mat4;\n fogMatrix: mat4;\n pixelMatrix: mat4;\n pixelMatrix3D: mat4;\n pixelMatrixInverse: mat4;\n glCoordMatrix: mat4;\n labelPlaneMatrix: mat4;\n minElevationForCurrentTile: number;\n _fov: number;\n _pitch: number;\n _zoom: number;\n _unmodified: boolean;\n _renderWorldCopies: boolean;\n _minZoom: number;\n _maxZoom: number;\n _minPitch: number;\n _maxPitch: number;\n _center: LngLat;\n _elevation: number;\n _pixelPerMeter: number;\n _edgeInsets: EdgeInsets;\n _constraining: boolean;\n _posMatrixCache: {[_: string]: mat4};\n _alignedPosMatrixCache: {[_: string]: mat4};\n _fogMatrixCache: {[_: string]: mat4};\n /**\n * This value represents the distance from the camera to the far clipping plane.\n * It is used in the calculation of the projection matrix to determine which objects are visible.\n * farZ should be larger than nearZ.\n */\n farZ: number;\n /**\n * This value represents the distance from the camera to the near clipping plane.\n * It is used in the calculation of the projection matrix to determine which objects are visible.\n * nearZ should be smaller than farZ.\n */\n nearZ: number;\n\n constructor(minZoom?: number, maxZoom?: number, minPitch?: number, maxPitch?: number, renderWorldCopies?: boolean) {\n this.tileSize = 512; // constant\n\n this._renderWorldCopies = renderWorldCopies === undefined ? true : !!renderWorldCopies;\n this._minZoom = minZoom || 0;\n this._maxZoom = maxZoom || 22;\n\n this._minPitch = (minPitch === undefined || minPitch === null) ? 0 : minPitch;\n this._maxPitch = (maxPitch === undefined || maxPitch === null) ? 60 : maxPitch;\n\n this.setMaxBounds();\n\n this.width = 0;\n this.height = 0;\n this._center = new LngLat(0, 0);\n this._elevation = 0;\n this.zoom = 0;\n this.angle = 0;\n this._fov = 0.6435011087932844;\n this._pitch = 0;\n this._unmodified = true;\n this._edgeInsets = new EdgeInsets();\n this._posMatrixCache = {};\n this._alignedPosMatrixCache = {};\n this._fogMatrixCache = {};\n this.minElevationForCurrentTile = 0;\n }\n\n clone(): Transform {\n const clone = new Transform(this._minZoom, this._maxZoom, this._minPitch, this.maxPitch, this._renderWorldCopies);\n clone.apply(this);\n return clone;\n }\n\n apply(that: Transform) {\n this.tileSize = that.tileSize;\n this.latRange = that.latRange;\n this.lngRange = that.lngRange;\n this.width = that.width;\n this.height = that.height;\n this._center = that._center;\n this._elevation = that._elevation;\n this.minElevationForCurrentTile = that.minElevationForCurrentTile;\n this.zoom = that.zoom;\n this.angle = that.angle;\n this._fov = that._fov;\n this._pitch = that._pitch;\n this._unmodified = that._unmodified;\n this._edgeInsets = that._edgeInsets.clone();\n this._calcMatrices();\n }\n\n get minZoom(): number { return this._minZoom; }\n set minZoom(zoom: number) {\n if (this._minZoom === zoom) return;\n this._minZoom = zoom;\n this.zoom = Math.max(this.zoom, zoom);\n }\n\n get maxZoom(): number { return this._maxZoom; }\n set maxZoom(zoom: number) {\n if (this._maxZoom === zoom) return;\n this._maxZoom = zoom;\n this.zoom = Math.min(this.zoom, zoom);\n }\n\n get minPitch(): number { return this._minPitch; }\n set minPitch(pitch: number) {\n if (this._minPitch === pitch) return;\n this._minPitch = pitch;\n this.pitch = Math.max(this.pitch, pitch);\n }\n\n get maxPitch(): number { return this._maxPitch; }\n set maxPitch(pitch: number) {\n if (this._maxPitch === pitch) return;\n this._maxPitch = pitch;\n this.pitch = Math.min(this.pitch, pitch);\n }\n\n get renderWorldCopies(): boolean { return this._renderWorldCopies; }\n set renderWorldCopies(renderWorldCopies: boolean) {\n if (renderWorldCopies === undefined) {\n renderWorldCopies = true;\n } else if (renderWorldCopies === null) {\n renderWorldCopies = false;\n }\n\n this._renderWorldCopies = renderWorldCopies;\n }\n\n get worldSize(): number {\n return this.tileSize * this.scale;\n }\n\n get centerOffset(): Point {\n return this.centerPoint._sub(this.size._div(2));\n }\n\n get size(): Point {\n return new Point(this.width, this.height);\n }\n\n get bearing(): number {\n return -this.angle / Math.PI * 180;\n }\n set bearing(bearing: number) {\n const b = -wrap(bearing, -180, 180) * Math.PI / 180;\n if (this.angle === b) return;\n this._unmodified = false;\n this.angle = b;\n this._calcMatrices();\n\n // 2x2 matrix for rotating points\n this.rotationMatrix = mat2.create();\n mat2.rotate(this.rotationMatrix, this.rotationMatrix, this.angle);\n }\n\n get pitch(): number {\n return this._pitch / Math.PI * 180;\n }\n set pitch(pitch: number) {\n const p = clamp(pitch, this.minPitch, this.maxPitch) / 180 * Math.PI;\n if (this._pitch === p) return;\n this._unmodified = false;\n this._pitch = p;\n this._calcMatrices();\n }\n\n get fov(): number {\n return this._fov / Math.PI * 180;\n }\n set fov(fov: number) {\n fov = Math.max(0.01, Math.min(60, fov));\n if (this._fov === fov) return;\n this._unmodified = false;\n this._fov = fov / 180 * Math.PI;\n this._calcMatrices();\n }\n\n get zoom(): number { return this._zoom; }\n set zoom(zoom: number) {\n const constrainedZoom = Math.min(Math.max(zoom, this.minZoom), this.maxZoom);\n if (this._zoom === constrainedZoom) return;\n this._unmodified = false;\n this._zoom = constrainedZoom;\n this.tileZoom = Math.max(0, Math.floor(constrainedZoom));\n this.scale = this.zoomScale(constrainedZoom);\n this._constrain();\n this._calcMatrices();\n }\n\n get center(): LngLat { return this._center; }\n set center(center: LngLat) {\n if (center.lat === this._center.lat && center.lng === this._center.lng) return;\n this._unmodified = false;\n this._center = center;\n this._constrain();\n this._calcMatrices();\n }\n\n /**\n * Elevation at current center point, meters above sea level\n */\n get elevation(): number { return this._elevation; }\n set elevation(elevation: number) {\n if (elevation === this._elevation) return;\n this._elevation = elevation;\n this._constrain();\n this._calcMatrices();\n }\n\n get padding(): PaddingOptions { return this._edgeInsets.toJSON(); }\n set padding(padding: PaddingOptions) {\n if (this._edgeInsets.equals(padding)) return;\n this._unmodified = false;\n //Update edge-insets in place\n this._edgeInsets.interpolate(this._edgeInsets, padding, 1);\n this._calcMatrices();\n }\n\n /**\n * The center of the screen in pixels with the top-left corner being (0,0)\n * and +y axis pointing downwards. This accounts for padding.\n */\n get centerPoint(): Point {\n return this._edgeInsets.getCenter(this.width, this.height);\n }\n\n /**\n * Returns if the padding params match\n *\n * @param padding - the padding to check against\n * @returns true if they are equal, false otherwise\n */\n isPaddingEqual(padding: PaddingOptions): boolean {\n return this._edgeInsets.equals(padding);\n }\n\n /**\n * Helper method to update edge-insets in place\n *\n * @param start - the starting padding\n * @param target - the target padding\n * @param t - the step/weight\n */\n interpolatePadding(start: PaddingOptions, target: PaddingOptions, t: number) {\n this._unmodified = false;\n this._edgeInsets.interpolate(start, target, t);\n this._constrain();\n this._calcMatrices();\n }\n\n /**\n * Return a zoom level that will cover all tiles the transform\n * @param options - the options\n * @returns zoom level An integer zoom level at which all tiles will be visible.\n */\n coveringZoomLevel(options: {\n /**\n * Target zoom level. If true, the value will be rounded to the closest integer. Otherwise the value will be floored.\n */\n roundZoom?: boolean;\n /**\n * Tile size, expressed in screen pixels.\n */\n tileSize: number;\n }): number {\n const z = (options.roundZoom ? Math.round : Math.floor)(\n this.zoom + this.scaleZoom(this.tileSize / options.tileSize)\n );\n // At negative zoom levels load tiles from z0 because negative tile zoom levels don't exist.\n return Math.max(0, z);\n }\n\n /**\n * Return any \"wrapped\" copies of a given tile coordinate that are visible\n * in the current view.\n */\n getVisibleUnwrappedCoordinates(tileID: CanonicalTileID) {\n const result = [new UnwrappedTileID(0, tileID)];\n if (this._renderWorldCopies) {\n const utl = this.pointCoordinate(new Point(0, 0));\n const utr = this.pointCoordinate(new Point(this.width, 0));\n const ubl = this.pointCoordinate(new Point(this.width, this.height));\n const ubr = this.pointCoordinate(new Point(0, this.height));\n const w0 = Math.floor(Math.min(utl.x, utr.x, ubl.x, ubr.x));\n const w1 = Math.floor(Math.max(utl.x, utr.x, ubl.x, ubr.x));\n\n // Add an extra copy of the world on each side to properly render ImageSources and CanvasSources.\n // Both sources draw outside the tile boundaries of the tile that \"contains them\" so we need\n // to add extra copies on both sides in case offscreen tiles need to draw into on-screen ones.\n const extraWorldCopy = 1;\n\n for (let w = w0 - extraWorldCopy; w <= w1 + extraWorldCopy; w++) {\n if (w === 0) continue;\n result.push(new UnwrappedTileID(w, tileID));\n }\n }\n return result;\n }\n\n /**\n * Return all coordinates that could cover this transform for a covering\n * zoom level.\n * @param options - the options\n * @returns OverscaledTileIDs\n */\n coveringTiles(\n options: {\n tileSize: number;\n minzoom?: number;\n maxzoom?: number;\n roundZoom?: boolean;\n reparseOverscaled?: boolean;\n renderWorldCopies?: boolean;\n terrain?: Terrain;\n }\n ): Array {\n let z = this.coveringZoomLevel(options);\n const actualZ = z;\n\n if (options.minzoom !== undefined && z < options.minzoom) return [];\n if (options.maxzoom !== undefined && z > options.maxzoom) z = options.maxzoom;\n\n const cameraCoord = this.pointCoordinate(this.getCameraPoint());\n const centerCoord = MercatorCoordinate.fromLngLat(this.center);\n const numTiles = Math.pow(2, z);\n const cameraPoint = [numTiles * cameraCoord.x, numTiles * cameraCoord.y, 0];\n const centerPoint = [numTiles * centerCoord.x, numTiles * centerCoord.y, 0];\n const cameraFrustum = Frustum.fromInvProjectionMatrix(this.invModelViewProjectionMatrix, this.worldSize, z);\n\n // No change of LOD behavior for pitch lower than 60 and when there is no top padding: return only tile ids from the requested zoom level\n let minZoom = options.minzoom || 0;\n // Use 0.1 as an epsilon to avoid for explicit == 0.0 floating point checks\n if (!options.terrain && this.pitch <= 60.0 && this._edgeInsets.top < 0.1)\n minZoom = z;\n\n // There should always be a certain number of maximum zoom level tiles surrounding the center location in 2D or in front of the camera in 3D\n const radiusOfMaxLvlLodInTiles = options.terrain ? 2 / Math.min(this.tileSize, options.tileSize) * this.tileSize : 3;\n\n const newRootTile = (wrap: number): any => {\n return {\n aabb: new Aabb([wrap * numTiles, 0, 0], [(wrap + 1) * numTiles, numTiles, 0]),\n zoom: 0,\n x: 0,\n y: 0,\n wrap,\n fullyVisible: false\n };\n };\n\n // Do a depth-first traversal to find visible tiles and proper levels of detail\n const stack = [];\n const result = [];\n const maxZoom = z;\n const overscaledZ = options.reparseOverscaled ? actualZ : z;\n\n if (this._renderWorldCopies) {\n // Render copy of the globe thrice on both sides\n for (let i = 1; i <= 3; i++) {\n stack.push(newRootTile(-i));\n stack.push(newRootTile(i));\n }\n }\n\n stack.push(newRootTile(0));\n\n while (stack.length > 0) {\n const it = stack.pop();\n const x = it.x;\n const y = it.y;\n let fullyVisible = it.fullyVisible;\n\n // Visibility of a tile is not required if any of its ancestor if fully inside the frustum\n if (!fullyVisible) {\n const intersectResult = it.aabb.intersects(cameraFrustum);\n\n if (intersectResult === 0)\n continue;\n\n fullyVisible = intersectResult === 2;\n }\n\n const refPoint = options.terrain ? cameraPoint : centerPoint;\n const distanceX = it.aabb.distanceX(refPoint);\n const distanceY = it.aabb.distanceY(refPoint);\n const longestDim = Math.max(Math.abs(distanceX), Math.abs(distanceY));\n\n // We're using distance based heuristics to determine if a tile should be split into quadrants or not.\n // radiusOfMaxLvlLodInTiles defines that there's always a certain number of maxLevel tiles next to the map center.\n // Using the fact that a parent node in quadtree is twice the size of its children (per dimension)\n // we can define distance thresholds for each relative level:\n // f(k) = offset + 2 + 4 + 8 + 16 + ... + 2^k. This is the same as \"offset+2^(k+1)-2\"\n const distToSplit = radiusOfMaxLvlLodInTiles + (1 << (maxZoom - it.zoom)) - 2;\n\n // Have we reached the target depth or is the tile too far away to be any split further?\n if (it.zoom === maxZoom || (longestDim > distToSplit && it.zoom >= minZoom)) {\n const dz = maxZoom - it.zoom, dx = cameraPoint[0] - 0.5 - (x << dz), dy = cameraPoint[1] - 0.5 - (y << dz);\n result.push({\n tileID: new OverscaledTileID(it.zoom === maxZoom ? overscaledZ : it.zoom, it.wrap, it.zoom, x, y),\n distanceSq: vec2.sqrLen([centerPoint[0] - 0.5 - x, centerPoint[1] - 0.5 - y]),\n // this variable is currently not used, but may be important to reduce the amount of loaded tiles\n tileDistanceToCamera: Math.sqrt(dx * dx + dy * dy)\n });\n continue;\n }\n\n for (let i = 0; i < 4; i++) {\n const childX = (x << 1) + (i % 2);\n const childY = (y << 1) + (i >> 1);\n const childZ = it.zoom + 1;\n let quadrant = it.aabb.quadrant(i);\n if (options.terrain) {\n const tileID = new OverscaledTileID(childZ, it.wrap, childZ, childX, childY);\n const minMax = options.terrain.getMinMaxElevation(tileID);\n const minElevation = minMax.minElevation ?? this.elevation;\n const maxElevation = minMax.maxElevation ?? this.elevation;\n quadrant = new Aabb(\n [quadrant.min[0], quadrant.min[1], minElevation] as vec3,\n [quadrant.max[0], quadrant.max[1], maxElevation] as vec3\n );\n }\n stack.push({aabb: quadrant, zoom: childZ, x: childX, y: childY, wrap: it.wrap, fullyVisible});\n }\n }\n\n return result.sort((a, b) => a.distanceSq - b.distanceSq).map(a => a.tileID);\n }\n\n resize(width: number, height: number) {\n this.width = width;\n this.height = height;\n\n this.pixelsToGLUnits = [2 / width, -2 / height];\n this._constrain();\n this._calcMatrices();\n }\n\n get unmodified(): boolean { return this._unmodified; }\n\n zoomScale(zoom: number) { return Math.pow(2, zoom); }\n scaleZoom(scale: number) { return Math.log(scale) / Math.LN2; }\n\n /**\n * Convert from LngLat to world coordinates (Mercator coordinates scaled by 512)\n * @param lnglat - the lngLat\n * @returns Point\n */\n project(lnglat: LngLat) {\n const lat = clamp(lnglat.lat, -MAX_VALID_LATITUDE, MAX_VALID_LATITUDE);\n return new Point(\n mercatorXfromLng(lnglat.lng) * this.worldSize,\n mercatorYfromLat(lat) * this.worldSize);\n }\n\n /**\n * Convert from world coordinates ([0, 512],[0, 512]) to LngLat ([-180, 180], [-90, 90])\n * @param point - world coordinate\n * @returns LngLat\n */\n unproject(point: Point): LngLat {\n return new MercatorCoordinate(point.x / this.worldSize, point.y / this.worldSize).toLngLat();\n }\n\n get point(): Point { return this.project(this.center); }\n\n /**\n * get the camera position in LngLat and altitudes in meter\n * @returns An object with lngLat & altitude.\n */\n getCameraPosition(): {\n lngLat: LngLat;\n altitude: number;\n } {\n const lngLat = this.pointLocation(this.getCameraPoint());\n const altitude = Math.cos(this._pitch) * this.cameraToCenterDistance / this._pixelPerMeter;\n return {lngLat, altitude: altitude + this.elevation};\n }\n\n /**\n * This method works in combination with freezeElevation activated.\n * freezeElevation is enabled during map-panning because during this the camera should sit in constant height.\n * After panning finished, call this method to recalculate the zoomlevel for the current camera-height in current terrain.\n * @param terrain - the terrain\n */\n recalculateZoom(terrain: Terrain) {\n const origElevation = this.elevation;\n const origAltitude = Math.cos(this._pitch) * this.cameraToCenterDistance / this._pixelPerMeter;\n\n // find position the camera is looking on\n const center = this.pointLocation(this.centerPoint, terrain);\n const elevation = terrain.getElevationForLngLatZoom(center, this.tileZoom);\n const deltaElevation = this.elevation - elevation;\n if (!deltaElevation) return;\n\n // The camera's altitude off the ground + the ground's elevation = a constant:\n // this means the camera stays at the same total height.\n const requiredAltitude = origAltitude + origElevation - elevation;\n // Since altitude = Math.cos(this._pitch) * this.cameraToCenterDistance / pixelPerMeter:\n const requiredPixelPerMeter = Math.cos(this._pitch) * this.cameraToCenterDistance / requiredAltitude;\n // Since pixelPerMeter = mercatorZfromAltitude(1, center.lat) * worldSize:\n const requiredWorldSize = requiredPixelPerMeter / mercatorZfromAltitude(1, center.lat);\n // Since worldSize = this.tileSize * scale:\n const requiredScale = requiredWorldSize / this.tileSize;\n const zoom = this.scaleZoom(requiredScale);\n\n // update matrices\n this._elevation = elevation;\n this._center = center;\n this.zoom = zoom;\n }\n\n setLocationAtPoint(lnglat: LngLat, point: Point) {\n const a = this.pointCoordinate(point);\n const b = this.pointCoordinate(this.centerPoint);\n const loc = this.locationCoordinate(lnglat);\n const newCenter = new MercatorCoordinate(\n loc.x - (a.x - b.x),\n loc.y - (a.y - b.y));\n this.center = this.coordinateLocation(newCenter);\n if (this._renderWorldCopies) {\n this.center = this.center.wrap();\n }\n }\n\n /**\n * Given a LngLat location, return the screen point that corresponds to it\n * @param lnglat - location\n * @param terrain - optional terrain\n * @returns screen point\n */\n locationPoint(lnglat: LngLat, terrain?: Terrain): Point {\n return terrain ?\n this.coordinatePoint(this.locationCoordinate(lnglat), terrain.getElevationForLngLatZoom(lnglat, this.tileZoom), this.pixelMatrix3D) :\n this.coordinatePoint(this.locationCoordinate(lnglat));\n }\n\n /**\n * Given a point on screen, return its lnglat\n * @param p - screen point\n * @param terrain - optional terrain\n * @returns lnglat location\n */\n pointLocation(p: Point, terrain?: Terrain): LngLat {\n return this.coordinateLocation(this.pointCoordinate(p, terrain));\n }\n\n /**\n * Given a geographical lnglat, return an unrounded\n * coordinate that represents it at low zoom level.\n * @param lnglat - the location\n * @returns The mercator coordinate\n */\n locationCoordinate(lnglat: LngLat): MercatorCoordinate {\n return MercatorCoordinate.fromLngLat(lnglat);\n }\n\n /**\n * Given a Coordinate, return its geographical position.\n * @param coord - mercator coordinates\n * @returns lng and lat\n */\n coordinateLocation(coord: MercatorCoordinate): LngLat {\n return coord && coord.toLngLat();\n }\n\n /**\n * Given a Point, return its mercator coordinate.\n * @param p - the point\n * @param terrain - optional terrain\n * @returns lnglat\n */\n pointCoordinate(p: Point, terrain?: Terrain): MercatorCoordinate {\n // get point-coordinate from terrain coordinates framebuffer\n if (terrain) {\n const coordinate = terrain.pointCoordinate(p);\n if (coordinate != null) {\n return coordinate;\n }\n }\n\n // calculate point-coordinate on flat earth\n const targetZ = 0;\n // since we don't know the correct projected z value for the point,\n // unproject two points to get a line and then find the point on that\n // line with z=0\n\n const coord0 = [p.x, p.y, 0, 1] as vec4;\n const coord1 = [p.x, p.y, 1, 1] as vec4;\n\n vec4.transformMat4(coord0, coord0, this.pixelMatrixInverse);\n vec4.transformMat4(coord1, coord1, this.pixelMatrixInverse);\n\n const w0 = coord0[3];\n const w1 = coord1[3];\n const x0 = coord0[0] / w0;\n const x1 = coord1[0] / w1;\n const y0 = coord0[1] / w0;\n const y1 = coord1[1] / w1;\n const z0 = coord0[2] / w0;\n const z1 = coord1[2] / w1;\n\n const t = z0 === z1 ? 0 : (targetZ - z0) / (z1 - z0);\n\n return new MercatorCoordinate(\n interpolates.number(x0, x1, t) / this.worldSize,\n interpolates.number(y0, y1, t) / this.worldSize);\n }\n\n /**\n * Given a coordinate, return the screen point that corresponds to it\n * @param coord - the coordinates\n * @param elevation - the elevation\n * @param pixelMatrix - the pixel matrix\n * @returns screen point\n */\n coordinatePoint(coord: MercatorCoordinate, elevation: number = 0, pixelMatrix = this.pixelMatrix): Point {\n const p = [coord.x * this.worldSize, coord.y * this.worldSize, elevation, 1] as vec4;\n vec4.transformMat4(p, p, pixelMatrix);\n return new Point(p[0] / p[3], p[1] / p[3]);\n }\n\n /**\n * Returns the map's geographical bounds. When the bearing or pitch is non-zero, the visible region is not\n * an axis-aligned rectangle, and the result is the smallest bounds that encompasses the visible region.\n * @returns Returns a {@link LngLatBounds} object describing the map's geographical bounds.\n */\n getBounds(): LngLatBounds {\n const top = Math.max(0, this.height / 2 - this.getHorizon());\n return new LngLatBounds()\n .extend(this.pointLocation(new Point(0, top)))\n .extend(this.pointLocation(new Point(this.width, top)))\n .extend(this.pointLocation(new Point(this.width, this.height)))\n .extend(this.pointLocation(new Point(0, this.height)));\n }\n\n /**\n * Returns the maximum geographical bounds the map is constrained to, or `null` if none set.\n * @returns max bounds\n */\n getMaxBounds(): LngLatBounds | null {\n if (!this.latRange || this.latRange.length !== 2 ||\n !this.lngRange || this.lngRange.length !== 2) return null;\n\n return new LngLatBounds([this.lngRange[0], this.latRange[0]], [this.lngRange[1], this.latRange[1]]);\n }\n\n /**\n * Calculate pixel height of the visible horizon in relation to map-center (e.g. height/2),\n * multiplied by a static factor to simulate the earth-radius.\n * The calculated value is the horizontal line from the camera-height to sea-level.\n * @returns Horizon above center in pixels.\n */\n getHorizon(): number {\n return Math.tan(Math.PI / 2 - this._pitch) * this.cameraToCenterDistance * 0.85;\n }\n\n /**\n * Sets or clears the map's geographical constraints.\n * @param bounds - A {@link LngLatBounds} object describing the new geographic boundaries of the map.\n */\n setMaxBounds(bounds?: LngLatBounds | null) {\n if (bounds) {\n this.lngRange = [bounds.getWest(), bounds.getEast()];\n this.latRange = [bounds.getSouth(), bounds.getNorth()];\n this._constrain();\n } else {\n this.lngRange = null;\n this.latRange = [-MAX_VALID_LATITUDE, MAX_VALID_LATITUDE];\n }\n }\n\n calculateTileMatrix(unwrappedTileID: UnwrappedTileID): mat4 {\n const canonical = unwrappedTileID.canonical;\n const scale = this.worldSize / this.zoomScale(canonical.z);\n const unwrappedX = canonical.x + Math.pow(2, canonical.z) * unwrappedTileID.wrap;\n\n const worldMatrix = mat4.identity(new Float64Array(16) as any);\n mat4.translate(worldMatrix, worldMatrix, [unwrappedX * scale, canonical.y * scale, 0]);\n mat4.scale(worldMatrix, worldMatrix, [scale / EXTENT, scale / EXTENT, 1]);\n return worldMatrix;\n }\n\n /**\n * Calculate the posMatrix that, given a tile coordinate, would be used to display the tile on a map.\n * @param unwrappedTileID - the tile ID\n */\n calculatePosMatrix(unwrappedTileID: UnwrappedTileID, aligned: boolean = false): mat4 {\n const posMatrixKey = unwrappedTileID.key;\n const cache = aligned ? this._alignedPosMatrixCache : this._posMatrixCache;\n if (cache[posMatrixKey]) {\n return cache[posMatrixKey];\n }\n\n const posMatrix = this.calculateTileMatrix(unwrappedTileID);\n mat4.multiply(posMatrix, aligned ? this.alignedModelViewProjectionMatrix : this.modelViewProjectionMatrix, posMatrix);\n\n cache[posMatrixKey] = new Float32Array(posMatrix);\n return cache[posMatrixKey];\n }\n\n /**\n * Calculate the fogMatrix that, given a tile coordinate, would be used to calculate fog on the map.\n * @param unwrappedTileID - the tile ID\n * @private\n */\n calculateFogMatrix(unwrappedTileID: UnwrappedTileID): mat4 {\n const posMatrixKey = unwrappedTileID.key;\n const cache = this._fogMatrixCache;\n if (cache[posMatrixKey]) {\n return cache[posMatrixKey];\n }\n\n const fogMatrix = this.calculateTileMatrix(unwrappedTileID);\n mat4.multiply(fogMatrix, this.fogMatrix, fogMatrix);\n\n cache[posMatrixKey] = new Float32Array(fogMatrix);\n return cache[posMatrixKey];\n }\n\n customLayerMatrix(): mat4 {\n return this.mercatorMatrix.slice() as any;\n }\n\n /**\n * Get center lngLat and zoom to ensure that\n * 1) everything beyond the bounds is excluded\n * 2) a given lngLat is as near the center as possible\n * Bounds are those set by maxBounds or North & South \"Poles\" and, if only 1 globe is displayed, antimeridian.\n */\n getConstrained(lngLat: LngLat, zoom: number): {center: LngLat; zoom: number} {\n zoom = clamp(+zoom, this.minZoom, this.maxZoom);\n const result = {\n center: new LngLat(lngLat.lng, lngLat.lat),\n zoom\n };\n\n let lngRange = this.lngRange;\n\n if (!this._renderWorldCopies && lngRange === null) {\n const almost180 = 180 - 1e-10;\n lngRange = [-almost180, almost180];\n }\n\n const worldSize = this.tileSize * this.zoomScale(result.zoom); // A world size for the requested zoom level, not the current world size\n let minY = 0;\n let maxY = worldSize;\n let minX = 0;\n let maxX = worldSize;\n let scaleY = 0;\n let scaleX = 0;\n const {x: screenWidth, y: screenHeight} = this.size;\n\n if (this.latRange) {\n const latRange = this.latRange;\n minY = mercatorYfromLat(latRange[1]) * worldSize;\n maxY = mercatorYfromLat(latRange[0]) * worldSize;\n const shouldZoomIn = maxY - minY < screenHeight;\n if (shouldZoomIn) scaleY = screenHeight / (maxY - minY);\n }\n\n if (lngRange) {\n minX = wrap(\n mercatorXfromLng(lngRange[0]) * worldSize,\n 0,\n worldSize\n );\n maxX = wrap(\n mercatorXfromLng(lngRange[1]) * worldSize,\n 0,\n worldSize\n );\n\n if (maxX < minX) maxX += worldSize;\n\n const shouldZoomIn = maxX - minX < screenWidth;\n if (shouldZoomIn) scaleX = screenWidth / (maxX - minX);\n }\n\n const {x: originalX, y: originalY} = this.project.call({worldSize}, lngLat);\n let modifiedX, modifiedY;\n\n const scale = Math.max(scaleX || 0, scaleY || 0);\n\n if (scale) {\n // zoom in to exclude all beyond the given lng/lat ranges\n const newPoint = new Point(\n scaleX ? (maxX + minX) / 2 : originalX,\n scaleY ? (maxY + minY) / 2 : originalY);\n result.center = this.unproject.call({worldSize}, newPoint).wrap();\n result.zoom += this.scaleZoom(scale);\n return result;\n }\n\n if (this.latRange) {\n const h2 = screenHeight / 2;\n if (originalY - h2 < minY) modifiedY = minY + h2;\n if (originalY + h2 > maxY) modifiedY = maxY - h2;\n }\n\n if (lngRange) {\n const centerX = (minX + maxX) / 2;\n let wrappedX = originalX;\n if (this._renderWorldCopies) {\n wrappedX = wrap(originalX, centerX - worldSize / 2, centerX + worldSize / 2);\n }\n const w2 = screenWidth / 2;\n\n if (wrappedX - w2 < minX) modifiedX = minX + w2;\n if (wrappedX + w2 > maxX) modifiedX = maxX - w2;\n }\n\n // pan the map if the screen goes off the range\n if (modifiedX !== undefined || modifiedY !== undefined) {\n const newPoint = new Point(modifiedX ?? originalX, modifiedY ?? originalY);\n result.center = this.unproject.call({worldSize}, newPoint).wrap();\n }\n\n return result;\n }\n\n _constrain() {\n if (!this.center || !this.width || !this.height || this._constraining) return;\n this._constraining = true;\n const unmodified = this._unmodified;\n const {center, zoom} = this.getConstrained(this.center, this.zoom);\n this.center = center;\n this.zoom = zoom;\n this._unmodified = unmodified;\n this._constraining = false;\n }\n\n _calcMatrices() {\n if (!this.height) return;\n\n const halfFov = this._fov / 2;\n const offset = this.centerOffset;\n const x = this.point.x, y = this.point.y;\n this.cameraToCenterDistance = 0.5 / Math.tan(halfFov) * this.height;\n this._pixelPerMeter = mercatorZfromAltitude(1, this.center.lat) * this.worldSize;\n\n let m = mat4.identity(new Float64Array(16) as any);\n mat4.scale(m, m, [this.width / 2, -this.height / 2, 1]);\n mat4.translate(m, m, [1, -1, 0]);\n this.labelPlaneMatrix = m;\n\n m = mat4.identity(new Float64Array(16) as any);\n mat4.scale(m, m, [1, -1, 1]);\n mat4.translate(m, m, [-1, -1, 0]);\n mat4.scale(m, m, [2 / this.width, 2 / this.height, 1]);\n this.glCoordMatrix = m;\n\n // Calculate the camera to sea-level distance in pixel in respect of terrain\n const cameraToSeaLevelDistance = this.cameraToCenterDistance + this._elevation * this._pixelPerMeter / Math.cos(this._pitch);\n // In case of negative minimum elevation (e.g. the dead see, under the sea maps) use a lower plane for calculation\n const minElevation = Math.min(this.elevation, this.minElevationForCurrentTile);\n const cameraToLowestPointDistance = cameraToSeaLevelDistance - minElevation * this._pixelPerMeter / Math.cos(this._pitch);\n const lowestPlane = minElevation < 0 ? cameraToLowestPointDistance : cameraToSeaLevelDistance;\n\n // Find the distance from the center point [width/2 + offset.x, height/2 + offset.y] to the\n // center top point [width/2 + offset.x, 0] in Z units, using the law of sines.\n // 1 Z unit is equivalent to 1 horizontal px at the center of the map\n // (the distance between[width/2, height/2] and [width/2 + 1, height/2])\n const groundAngle = Math.PI / 2 + this._pitch;\n const fovAboveCenter = this._fov * (0.5 + offset.y / this.height);\n const topHalfSurfaceDistance = Math.sin(fovAboveCenter) * lowestPlane / Math.sin(clamp(Math.PI - groundAngle - fovAboveCenter, 0.01, Math.PI - 0.01));\n\n // Find the distance from the center point to the horizon\n const horizon = this.getHorizon();\n const horizonAngle = Math.atan(horizon / this.cameraToCenterDistance);\n const fovCenterToHorizon = 2 * horizonAngle * (0.5 + offset.y / (horizon * 2));\n const topHalfSurfaceDistanceHorizon = Math.sin(fovCenterToHorizon) * lowestPlane / Math.sin(clamp(Math.PI - groundAngle - fovCenterToHorizon, 0.01, Math.PI - 0.01));\n\n // Calculate z distance of the farthest fragment that should be rendered.\n // Add a bit extra to avoid precision problems when a fragment's distance is exactly `furthestDistance`\n const topHalfMinDistance = Math.min(topHalfSurfaceDistance, topHalfSurfaceDistanceHorizon);\n this.farZ = (Math.cos(Math.PI / 2 - this._pitch) * topHalfMinDistance + lowestPlane) * 1.01;\n\n // The larger the value of nearZ is\n // - the more depth precision is available for features (good)\n // - clipping starts appearing sooner when the camera is close to 3d features (bad)\n //\n // Other values work for mapbox-gl-js but deck.gl was encountering precision issues\n // when rendering custom layers. This value was experimentally chosen and\n // seems to solve z-fighting issues in deck.gl while not clipping buildings too close to the camera.\n this.nearZ = this.height / 50;\n\n // matrix for conversion from location to clip space(-1 .. 1)\n m = new Float64Array(16) as any;\n mat4.perspective(m, this._fov, this.width / this.height, this.nearZ, this.farZ);\n\n // Apply center of perspective offset\n m[8] = -offset.x * 2 / this.width;\n m[9] = offset.y * 2 / this.height;\n this.projectionMatrix = mat4.clone(m);\n\n mat4.scale(m, m, [1, -1, 1]);\n mat4.translate(m, m, [0, 0, -this.cameraToCenterDistance]);\n mat4.rotateX(m, m, this._pitch);\n mat4.rotateZ(m, m, this.angle);\n mat4.translate(m, m, [-x, -y, 0]);\n\n // The mercatorMatrix can be used to transform points from mercator coordinates\n // ([0, 0] nw, [1, 1] se) to clip space.\n this.mercatorMatrix = mat4.scale([] as any, m, [this.worldSize, this.worldSize, this.worldSize]);\n\n // scale vertically to meters per pixel (inverse of ground resolution):\n mat4.scale(m, m, [1, 1, this._pixelPerMeter]);\n\n // matrix for conversion from world space to screen coordinates in 2D\n this.pixelMatrix = mat4.multiply(new Float64Array(16) as any, this.labelPlaneMatrix, m);\n\n // matrix for conversion from world space to clip space (-1 .. 1)\n mat4.translate(m, m, [0, 0, -this.elevation]); // elevate camera over terrain\n this.modelViewProjectionMatrix = m;\n this.invModelViewProjectionMatrix = mat4.invert([] as any, m);\n\n // create a fog matrix, same es proj-matrix but with near clipping-plane in mapcenter\n // needed to calculate a correct z-value for fog calculation, because projMatrix z value is not\n this.fogMatrix = new Float64Array(16) as any;\n mat4.perspective(this.fogMatrix, this._fov, this.width / this.height, cameraToSeaLevelDistance, this.farZ);\n this.fogMatrix[8] = -offset.x * 2 / this.width;\n this.fogMatrix[9] = offset.y * 2 / this.height;\n mat4.scale(this.fogMatrix, this.fogMatrix, [1, -1, 1]);\n mat4.translate(this.fogMatrix, this.fogMatrix, [0, 0, -this.cameraToCenterDistance]);\n mat4.rotateX(this.fogMatrix, this.fogMatrix, this._pitch);\n mat4.rotateZ(this.fogMatrix, this.fogMatrix, this.angle);\n mat4.translate(this.fogMatrix, this.fogMatrix, [-x, -y, 0]);\n mat4.scale(this.fogMatrix, this.fogMatrix, [1, 1, this._pixelPerMeter]);\n mat4.translate(this.fogMatrix, this.fogMatrix, [0, 0, -this.elevation]); // elevate camera over terrain\n\n // matrix for conversion from world space to screen coordinates in 3D\n this.pixelMatrix3D = mat4.multiply(new Float64Array(16) as any, this.labelPlaneMatrix, m);\n\n // Make a second projection matrix that is aligned to a pixel grid for rendering raster tiles.\n // We're rounding the (floating point) x/y values to achieve to avoid rendering raster images to fractional\n // coordinates. Additionally, we adjust by half a pixel in either direction in case that viewport dimension\n // is an odd integer to preserve rendering to the pixel grid. We're rotating this shift based on the angle\n // of the transformation so that 0°, 90°, 180°, and 270° rasters are crisp, and adjust the shift so that\n // it is always <= 0.5 pixels.\n const xShift = (this.width % 2) / 2, yShift = (this.height % 2) / 2,\n angleCos = Math.cos(this.angle), angleSin = Math.sin(this.angle),\n dx = x - Math.round(x) + angleCos * xShift + angleSin * yShift,\n dy = y - Math.round(y) + angleCos * yShift + angleSin * xShift;\n const alignedM = new Float64Array(m) as any as mat4;\n mat4.translate(alignedM, alignedM, [dx > 0.5 ? dx - 1 : dx, dy > 0.5 ? dy - 1 : dy, 0]);\n this.alignedModelViewProjectionMatrix = alignedM;\n\n // inverse matrix for conversion from screen coordinates to location\n m = mat4.invert(new Float64Array(16) as any, this.pixelMatrix);\n if (!m) throw new Error('failed to invert matrix');\n this.pixelMatrixInverse = m;\n\n this._posMatrixCache = {};\n this._alignedPosMatrixCache = {};\n this._fogMatrixCache = {};\n }\n\n maxPitchScaleFactor() {\n // calcMatrices hasn't run yet\n if (!this.pixelMatrixInverse) return 1;\n\n const coord = this.pointCoordinate(new Point(0, 0));\n const p = [coord.x * this.worldSize, coord.y * this.worldSize, 0, 1] as vec4;\n const topPoint = vec4.transformMat4(p, p, this.pixelMatrix);\n return topPoint[3] / this.cameraToCenterDistance;\n }\n\n /**\n * The camera looks at the map from a 3D (lng, lat, altitude) location. Let's use `cameraLocation`\n * as the name for the location under the camera and on the surface of the earth (lng, lat, 0).\n * `cameraPoint` is the projected position of the `cameraLocation`.\n *\n * This point is useful to us because only fill-extrusions that are between `cameraPoint` and\n * the query point on the surface of the earth can extend and intersect the query.\n *\n * When the map is not pitched the `cameraPoint` is equivalent to the center of the map because\n * the camera is right above the center of the map.\n */\n getCameraPoint() {\n const pitch = this._pitch;\n const yOffset = Math.tan(pitch) * (this.cameraToCenterDistance || 1);\n return this.centerPoint.add(new Point(0, yOffset));\n }\n\n /**\n * When the map is pitched, some of the 3D features that intersect a query will not intersect\n * the query at the surface of the earth. Instead the feature may be closer and only intersect\n * the query because it extrudes into the air.\n * @param queryGeometry - For point queries, the line from the query point to the \"camera point\",\n * for other geometries, the envelope of the query geometry and the \"camera point\"\n * @returns a geometry that includes all of the original query as well as all possible ares of the\n * screen where the *base* of a visible extrusion could be.\n *\n */\n getCameraQueryGeometry(queryGeometry: Array): Array {\n const c = this.getCameraPoint();\n\n if (queryGeometry.length === 1) {\n return [queryGeometry[0], c];\n } else {\n let minX = c.x;\n let minY = c.y;\n let maxX = c.x;\n let maxY = c.y;\n for (const p of queryGeometry) {\n minX = Math.min(minX, p.x);\n minY = Math.min(minY, p.y);\n maxX = Math.max(maxX, p.x);\n maxY = Math.max(maxY, p.y);\n }\n return [\n new Point(minX, minY),\n new Point(maxX, minY),\n new Point(maxX, maxY),\n new Point(minX, maxY),\n new Point(minX, minY)\n ];\n }\n }\n /**\n * Return the distance to the camera in clip space from a LngLat.\n * This can be compared to the value from the depth buffer (terrain.depthAtPoint)\n * to determine whether a point is occluded.\n * @param lngLat - the point\n * @param elevation - the point's elevation\n * @returns depth value in clip space (between 0 and 1)\n */\n lngLatToCameraDepth(lngLat: LngLat, elevation: number) {\n const coord = this.locationCoordinate(lngLat);\n const p = [coord.x * this.worldSize, coord.y * this.worldSize, elevation, 1] as vec4;\n vec4.transformMat4(p, p, this.modelViewProjectionMatrix);\n return (p[2] / p[3]);\n }\n}\n","/**\n * Throttle the given function to run at most every `period` milliseconds.\n */\nexport function throttle void>(fn: T, time: number): (...args: Parameters) => ReturnType {\n let pending = false;\n let timerId: ReturnType = null;\n let lastCallContext = null;\n let lastCallArgs: Parameters;\n\n const later = () => {\n timerId = null;\n if (pending) {\n fn.apply(lastCallContext, lastCallArgs);\n timerId = setTimeout(later, time);\n pending = false;\n }\n };\n\n return (...args: Parameters) => {\n pending = true;\n lastCallContext = this;\n lastCallArgs = args;\n if (!timerId) {\n later();\n }\n return timerId;\n };\n}\n","import {throttle} from '../util/throttle';\n\nimport type {Map} from './map';\n\n/**\n * Adds the map's position to its page's location hash.\n * Passed as an option to the map object.\n *\n * @group Markers and Controls\n */\nexport class Hash {\n _map: Map;\n _hashName: string;\n\n constructor(hashName?: string | null) {\n this._hashName = hashName && encodeURIComponent(hashName);\n }\n\n /**\n * Map element to listen for coordinate changes\n *\n * @param map - The map object\n */\n addTo(map: Map) {\n this._map = map;\n addEventListener('hashchange', this._onHashChange, false);\n this._map.on('moveend', this._updateHash);\n return this;\n }\n\n /**\n * Removes hash\n */\n remove() {\n removeEventListener('hashchange', this._onHashChange, false);\n this._map.off('moveend', this._updateHash);\n clearTimeout(this._updateHash());\n this._removeHash();\n\n delete this._map;\n return this;\n }\n\n getHashString(mapFeedback?: boolean) {\n const center = this._map.getCenter(),\n zoom = Math.round(this._map.getZoom() * 100) / 100,\n // derived from equation: 512px * 2^z / 360 / 10^d < 0.5px\n precision = Math.ceil((zoom * Math.LN2 + Math.log(512 / 360 / 0.5)) / Math.LN10),\n m = Math.pow(10, precision),\n lng = Math.round(center.lng * m) / m,\n lat = Math.round(center.lat * m) / m,\n bearing = this._map.getBearing(),\n pitch = this._map.getPitch();\n let hash = '';\n if (mapFeedback) {\n // new map feedback site has some constraints that don't allow\n // us to use the same hash format as we do for the Map hash option.\n hash += `/${lng}/${lat}/${zoom}`;\n } else {\n hash += `${zoom}/${lat}/${lng}`;\n }\n\n if (bearing || pitch) hash += (`/${Math.round(bearing * 10) / 10}`);\n if (pitch) hash += (`/${Math.round(pitch)}`);\n\n if (this._hashName) {\n const hashName = this._hashName;\n let found = false;\n const parts = window.location.hash.slice(1).split('&').map(part => {\n const key = part.split('=')[0];\n if (key === hashName) {\n found = true;\n return `${key}=${hash}`;\n }\n return part;\n }).filter(a => a);\n if (!found) {\n parts.push(`${hashName}=${hash}`);\n }\n return `#${parts.join('&')}`;\n }\n\n return `#${hash}`;\n }\n\n _getCurrentHash = () => {\n // Get the current hash from location, stripped from its number sign\n const hash = window.location.hash.replace('#', '');\n if (this._hashName) {\n // Split the parameter-styled hash into parts and find the value we need\n let keyval;\n hash.split('&').map(\n part => part.split('=')\n ).forEach(part => {\n if (part[0] === this._hashName) {\n keyval = part;\n }\n });\n return (keyval ? keyval[1] || '' : '').split('/');\n }\n return hash.split('/');\n };\n\n _onHashChange = () => {\n const loc = this._getCurrentHash();\n if (loc.length >= 3 && !loc.some(v => isNaN(v))) {\n const bearing = this._map.dragRotate.isEnabled() && this._map.touchZoomRotate.isEnabled() ? +(loc[3] || 0) : this._map.getBearing();\n this._map.jumpTo({\n center: [+loc[2], +loc[1]],\n zoom: +loc[0],\n bearing,\n pitch: +(loc[4] || 0)\n });\n return true;\n }\n return false;\n };\n\n _updateHashUnthrottled = () => {\n // Replace if already present, else append the updated hash string\n const location = window.location.href.replace(/(#.*)?$/, this.getHashString());\n window.history.replaceState(window.history.state, null, location);\n };\n\n _removeHash = () => {\n const currentHash = this._getCurrentHash();\n if (currentHash.length === 0) {\n return;\n }\n const baseHash = currentHash.join('/');\n let targetHash = baseHash;\n if (targetHash.split('&').length > 0) {\n targetHash = targetHash.split('&')[0]; // #3/1/2&foo=bar -> #3/1/2\n }\n if (this._hashName) {\n targetHash = `${this._hashName}=${baseHash}`;\n }\n let replaceString = window.location.hash.replace(targetHash, '');\n if (replaceString.startsWith('#&')) {\n replaceString = replaceString.slice(0, 1) + replaceString.slice(2);\n } else if (replaceString === '#') {\n replaceString = '';\n }\n let location = window.location.href.replace(/(#.+)?$/, replaceString);\n location = location.replace('&&', '&');\n window.history.replaceState(window.history.state, null, location);\n };\n\n /**\n * Mobile Safari doesn't allow updating the hash more than 100 times per 30 seconds.\n */\n _updateHash: () => ReturnType = throttle(this._updateHashUnthrottled, 30 * 1000 / 100);\n}\n","import {browser} from '../util/browser';\nimport type {Map} from './map';\nimport {bezier, clamp, extend} from '../util/util';\nimport Point from '@mapbox/point-geometry';\nimport type {DragPanOptions} from './handler/shim/drag_pan';\n\nconst defaultInertiaOptions = {\n linearity: 0.3,\n easing: bezier(0, 0, 0.3, 1),\n};\n\nconst defaultPanInertiaOptions = extend({\n deceleration: 2500,\n maxSpeed: 1400\n}, defaultInertiaOptions);\n\nconst defaultZoomInertiaOptions = extend({\n deceleration: 20,\n maxSpeed: 1400\n}, defaultInertiaOptions);\n\nconst defaultBearingInertiaOptions = extend({\n deceleration: 1000,\n maxSpeed: 360\n}, defaultInertiaOptions);\n\nconst defaultPitchInertiaOptions = extend({\n deceleration: 1000,\n maxSpeed: 90\n}, defaultInertiaOptions);\n\nexport type InertiaOptions = {\n linearity: number;\n easing: (t: number) => number;\n deceleration: number;\n maxSpeed: number;\n};\n\nexport class HandlerInertia {\n _map: Map;\n _inertiaBuffer: Array<{\n time: number;\n settings: any;\n }>;\n\n constructor(map: Map) {\n this._map = map;\n this.clear();\n }\n\n clear() {\n this._inertiaBuffer = [];\n }\n\n record(settings: any) {\n this._drainInertiaBuffer();\n this._inertiaBuffer.push({time: browser.now(), settings});\n }\n\n _drainInertiaBuffer() {\n const inertia = this._inertiaBuffer,\n now = browser.now(),\n cutoff = 160; //msec\n\n while (inertia.length > 0 && now - inertia[0].time > cutoff)\n inertia.shift();\n }\n\n _onMoveEnd(panInertiaOptions?: DragPanOptions | boolean) {\n this._drainInertiaBuffer();\n if (this._inertiaBuffer.length < 2) {\n return;\n }\n\n const deltas = {\n zoom: 0,\n bearing: 0,\n pitch: 0,\n pan: new Point(0, 0),\n pinchAround: undefined,\n around: undefined\n };\n\n for (const {settings} of this._inertiaBuffer) {\n deltas.zoom += settings.zoomDelta || 0;\n deltas.bearing += settings.bearingDelta || 0;\n deltas.pitch += settings.pitchDelta || 0;\n if (settings.panDelta) deltas.pan._add(settings.panDelta);\n if (settings.around) deltas.around = settings.around;\n if (settings.pinchAround) deltas.pinchAround = settings.pinchAround;\n }\n\n const lastEntry = this._inertiaBuffer[this._inertiaBuffer.length - 1];\n const duration = (lastEntry.time - this._inertiaBuffer[0].time);\n\n const easeOptions = {} as any;\n\n if (deltas.pan.mag()) {\n const result = calculateEasing(deltas.pan.mag(), duration, extend({}, defaultPanInertiaOptions, panInertiaOptions || {}));\n easeOptions.offset = deltas.pan.mult(result.amount / deltas.pan.mag());\n easeOptions.center = this._map.transform.center;\n extendDuration(easeOptions, result);\n }\n\n if (deltas.zoom) {\n const result = calculateEasing(deltas.zoom, duration, defaultZoomInertiaOptions);\n easeOptions.zoom = this._map.transform.zoom + result.amount;\n extendDuration(easeOptions, result);\n }\n\n if (deltas.bearing) {\n const result = calculateEasing(deltas.bearing, duration, defaultBearingInertiaOptions);\n easeOptions.bearing = this._map.transform.bearing + clamp(result.amount, -179, 179);\n extendDuration(easeOptions, result);\n }\n\n if (deltas.pitch) {\n const result = calculateEasing(deltas.pitch, duration, defaultPitchInertiaOptions);\n easeOptions.pitch = this._map.transform.pitch + result.amount;\n extendDuration(easeOptions, result);\n }\n\n if (easeOptions.zoom || easeOptions.bearing) {\n const last = deltas.pinchAround === undefined ? deltas.around : deltas.pinchAround;\n easeOptions.around = last ? this._map.unproject(last) : this._map.getCenter();\n }\n\n this.clear();\n return extend(easeOptions, {\n noMoveStart: true\n });\n\n }\n}\n\n// Unfortunately zoom, bearing, etc can't have different durations and easings so\n// we need to choose one. We use the longest duration and it's corresponding easing.\nfunction extendDuration(easeOptions, result) {\n if (!easeOptions.duration || easeOptions.duration < result.duration) {\n easeOptions.duration = result.duration;\n easeOptions.easing = result.easing;\n }\n}\n\nfunction calculateEasing(amount, inertiaDuration: number, inertiaOptions) {\n const {maxSpeed, linearity, deceleration} = inertiaOptions;\n const speed = clamp(\n amount * linearity / (inertiaDuration / 1000),\n -maxSpeed,\n maxSpeed);\n const duration = Math.abs(speed) / (deceleration * linearity);\n return {\n easing: inertiaOptions.easing,\n duration: duration * 1000,\n amount: speed * (duration / 2)\n };\n}\n","import {Event} from '../util/evented';\n\nimport {DOM} from '../util/dom';\nimport Point from '@mapbox/point-geometry';\nimport {extend} from '../util/util';\nimport type {MapGeoJSONFeature} from '../util/vectortile_to_geojson';\n\nimport type {Map} from './map';\nimport type {LngLat} from '../geo/lng_lat';\nimport type {SourceSpecification} from '@maplibre/maplibre-gl-style-spec';\n\n/**\n * An event from the mouse relevant to a specific layer.\n *\n * @group Event Related\n */\nexport type MapLayerMouseEvent = MapMouseEvent & { features?: MapGeoJSONFeature[] };\n\n/**\n * An event from a touch device relevant to a specific layer.\n *\n * @group Event Related\n */\nexport type MapLayerTouchEvent = MapTouchEvent & { features?: MapGeoJSONFeature[] };\n\n/**\n * The source event data type\n */\nexport type MapSourceDataType = 'content' | 'metadata' | 'visibility' | 'idle';\n\n/**\n * `MapLayerEventType` - a mapping between the event name and the event.\n * **Note:** These events are compatible with the optional `layerId` parameter.\n * If `layerId` is included as the second argument in {@link Map#on}, the event listener will fire only when the\n * event action contains a visible portion of the specified layer.\n * The following example can be used for all the events.\n *\n * @group Event Related\n * @example\n * ```ts\n * // Initialize the map\n * let map = new Map({ // map options });\n * // Set an event listener for a specific layer\n * map.on('the-event-name', 'poi-label', (e) => {\n * console.log('An event has occurred on a visible portion of the poi-label layer');\n * });\n * ```\n */\nexport type MapLayerEventType = {\n /**\n * Fired when a pointing device (usually a mouse) is pressed and released contains a visible portion of the specified layer.\n *\n * @see [Measure distances](https://maplibre.org/maplibre-gl-js/docs/examples/measure/)\n * @see [Center the map on a clicked symbol](https://maplibre.org/maplibre-gl-js/docs/examples/center-on-symbol/)\n */\n click: MapLayerMouseEvent;\n /**\n * Fired when a pointing device (usually a mouse) is pressed and released twice contains a visible portion of the specified layer.\n *\n * **Note:** Under normal conditions, this event will be preceded by two `click` events.\n */\n dblclick: MapLayerMouseEvent;\n /**\n * Fired when a pointing device (usually a mouse) is pressed while inside a visible portion of the specified layer.\n * @see [Create a draggable point](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-point/)\n */\n mousedown: MapLayerMouseEvent;\n /**\n * Fired when a pointing device (usually a mouse) is released while inside a visible portion of the specified layer.\n * @see [Create a draggable point](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-point/)\n */\n mouseup: MapLayerMouseEvent;\n /**\n * Fired when a pointing device (usually a mouse) is moved while the cursor is inside a visible portion of the specified layer.\n * As you move the cursor across the layer, the event will fire every time the cursor changes position within that layer.\n *\n * @see [Get coordinates of the mouse pointer](https://maplibre.org/maplibre-gl-js/docs/examples/mouse-position/)\n * @see [Highlight features under the mouse pointer](https://maplibre.org/maplibre-gl-js/docs/examples/hover-styles/)\n * @see [Display a popup on over](https://maplibre.org/maplibre-gl-js/docs/examples/popup-on-hover/)\n */\n mousemove: MapLayerMouseEvent;\n /**\n * Fired when a pointing device (usually a mouse) enters a visible portion of a specified layer from\n * outside that layer or outside the map canvas.\n *\n * @see [Center the map on a clicked symbol](https://maplibre.org/maplibre-gl-js/docs/examples/center-on-symbol/)\n * @see [Display a popup on click](https://maplibre.org/maplibre-gl-js/docs/examples/popup-on-click/)\n */\n mouseenter: MapLayerMouseEvent;\n /**\n * Fired when a pointing device (usually a mouse) leaves a visible portion of a specified layer, or leaves\n * the map canvas.\n *\n * @see [Highlight features under the mouse pointer](https://maplibre.org/maplibre-gl-js/docs/examples/hover-styles/)\n * @see [Display a popup on click](https://maplibre.org/maplibre-gl-js/docs/examples/popup-on-click/)\n */\n mouseleave: MapLayerMouseEvent;\n /**\n * Fired when a pointing device (usually a mouse) is moved inside a visible portion of the specified layer.\n *\n * @see [Get coordinates of the mouse pointer](https://maplibre.org/maplibre-gl-js/docs/examples/mouse-position/)\n * @see [Highlight features under the mouse pointer](https://maplibre.org/maplibre-gl-js/docs/examples/hover-styles/)\n * @see [Display a popup on hover](https://maplibre.org/maplibre-gl-js/docs/examples/popup-on-hover/)\n */\n mouseover: MapLayerMouseEvent;\n /**\n * Fired when a point device (usually a mouse) leaves the visible portion of the specified layer.\n */\n mouseout: MapLayerMouseEvent;\n /**\n * Fired when the right button of the mouse is clicked or the context menu key is pressed within visible portion of the specified layer.\n */\n contextmenu: MapLayerMouseEvent;\n /**\n * Fired when a [`touchstart`](https://developer.mozilla.org/en-US/docs/Web/Events/touchstart) event occurs within the visible portion of the specified layer.\n * @see [Create a draggable point](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-point/)\n */\n touchstart: MapLayerTouchEvent;\n /**\n * Fired when a [`touchend`](https://developer.mozilla.org/en-US/docs/Web/Events/touchend) event occurs within the visible portion of the specified layer.\n * @see [Create a draggable point](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-point/)\n */\n touchend: MapLayerTouchEvent;\n /**\n * Fired when a [`touchstart`](https://developer.mozilla.org/en-US/docs/Web/Events/touchstart) event occurs within the visible portion of the specified layer.\n * @see [Create a draggable point](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-point/)\n */\n touchcancel: MapLayerTouchEvent;\n};\n\n/**\n * `MapEventType` - a mapping between the event name and the event value.\n * These events are used with the {@link Map#on} method.\n * When using a `layerId` with {@link Map#on} method, please refer to {@link MapLayerEventType}.\n * The following example can be used for all the events.\n *\n * @group Event Related\n * @example\n * ```ts\n * // Initialize the map\n * let map = new Map({ // map options });\n * // Set an event listener\n * map.on('the-event-name', () => {\n * console.log('An event has occurred!');\n * });\n * ```\n */\nexport type MapEventType = {\n /**\n * Fired when an error occurs. This is GL JS's primary error reporting\n * mechanism. We use an event instead of `throw` to better accommodate\n * asynchronous operations. If no listeners are bound to the `error` event, the\n * error will be printed to the console.\n */\n error: ErrorEvent;\n /**\n * Fired immediately after all necessary resources have been downloaded\n * and the first visually complete rendering of the map has occurred.\n *\n * @see [Draw GeoJSON points](https://maplibre.org/maplibre-gl-js/docs/examples/geojson-markers/)\n * @see [Add live realtime data](https://maplibre.org/maplibre-gl-js/docs/examples/live-geojson/)\n * @see [Animate a point](https://maplibre.org/maplibre-gl-js/docs/examples/animate-point-along-line/)\n */\n load: MapLibreEvent;\n /**\n * Fired after the last frame rendered before the map enters an\n * \"idle\" state:\n *\n * - No camera transitions are in progress\n * - All currently requested tiles have loaded\n * - All fade/transition animations have completed\n */\n idle: MapLibreEvent;\n /**\n * Fired immediately after the map has been removed with {@link Map#remove}.\n */\n remove: MapLibreEvent;\n /**\n * Fired whenever the map is drawn to the screen, as the result of\n *\n * - a change to the map's position, zoom, pitch, or bearing\n * - a change to the map's style\n * - a change to a GeoJSON source\n * - the loading of a vector tile, GeoJSON file, glyph, or sprite\n */\n render: MapLibreEvent;\n /**\n * Fired immediately after the map has been resized.\n */\n resize: MapLibreEvent;\n /**\n * Fired when the WebGL context is lost.\n */\n webglcontextlost: MapContextEvent;\n /**\n * Fired when the WebGL context is restored.\n */\n webglcontextrestored: MapContextEvent;\n /**\n * Fired when any map data (style, source, tile, etc) begins loading or\n * changing asynchronously. All `dataloading` events are followed by a `data`,\n * `dataabort` or `error` event.\n */\n dataloading: MapDataEvent;\n /**\n * Fired when any map data loads or changes. See {@link MapDataEvent} for more information.\n * @see [Display HTML clusters with custom properties](https://maplibre.org/maplibre-gl-js/docs/examples/cluster-html/)\n */\n data: MapDataEvent;\n tiledataloading: MapDataEvent;\n /**\n * Fired when one of the map's sources begins loading or changing asynchronously.\n * All `sourcedataloading` events are followed by a `sourcedata`, `sourcedataabort` or `error` event.\n */\n sourcedataloading: MapSourceDataEvent;\n /**\n * Fired when the map's style begins loading or changing asynchronously.\n * All `styledataloading` events are followed by a `styledata`\n * or `error` event.\n */\n styledataloading: MapStyleDataEvent;\n /**\n * Fired when one of the map's sources loads or changes, including if a tile belonging\n * to a source loads or changes.\n */\n sourcedata: MapSourceDataEvent;\n /**\n * Fired when the map's style loads or changes.\n */\n styledata: MapStyleDataEvent;\n /**\n * Fired when an icon or pattern needed by the style is missing. The missing image can\n * be added with {@link Map#addImage} within this event listener callback to prevent the image from\n * being skipped. This event can be used to dynamically generate icons and patterns.\n * @see [Generate and add a missing icon to the map](https://maplibre.org/maplibre-gl-js/docs/examples/add-image-missing-generated/)\n */\n styleimagemissing: MapStyleImageMissingEvent;\n /**\n * Fired when a request for one of the map's sources' tiles or data is aborted.\n */\n dataabort: MapDataEvent;\n /**\n * Fired when a request for one of the map's sources' data is aborted.\n */\n sourcedataabort: MapSourceDataEvent;\n /**\n * Fired when the user cancels a \"box zoom\" interaction, or when the bounding box does not meet the minimum size threshold.\n * See {@link BoxZoomHandler}.\n */\n boxzoomcancel: MapLibreZoomEvent;\n /**\n * Fired when a \"box zoom\" interaction starts. See {@link BoxZoomHandler}.\n */\n boxzoomstart: MapLibreZoomEvent;\n /**\n * Fired when a \"box zoom\" interaction ends. See {@link BoxZoomHandler}.\n */\n boxzoomend: MapLibreZoomEvent;\n /**\n * Fired when a [`touchcancel`](https://developer.mozilla.org/en-US/docs/Web/Events/touchcancel) event occurs within the map.\n */\n touchcancel: MapTouchEvent;\n /**\n * Fired when a [`touchmove`](https://developer.mozilla.org/en-US/docs/Web/Events/touchmove) event occurs within the map.\n * @see [Create a draggable point](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-point/)\n */\n touchmove: MapTouchEvent;\n /**\n * Fired when a [`touchend`](https://developer.mozilla.org/en-US/docs/Web/Events/touchend) event occurs within the map.\n * @see [Create a draggable point](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-point/)\n */\n touchend: MapTouchEvent;\n /**\n * Fired when a [`touchstart`](https://developer.mozilla.org/en-US/docs/Web/Events/touchstart) event occurs within the map.\n * @see [Create a draggable point](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-point/)\n */\n touchstart: MapTouchEvent;\n /**\n * Fired when a pointing device (usually a mouse) is pressed and released at the same point on the map.\n *\n * @see [Measure distances](https://maplibre.org/maplibre-gl-js/docs/examples/measure/)\n * @see [Center the map on a clicked symbol](https://maplibre.org/maplibre-gl-js/docs/examples/center-on-symbol/)\n */\n click: MapMouseEvent;\n /**\n * Fired when the right button of the mouse is clicked or the context menu key is pressed within the map.\n */\n contextmenu: MapMouseEvent;\n /**\n * Fired when a pointing device (usually a mouse) is pressed and released twice at the same point on the map in rapid succession.\n *\n * **Note:** Under normal conditions, this event will be preceded by two `click` events.\n */\n dblclick: MapMouseEvent;\n /**\n * Fired when a pointing device (usually a mouse) is moved while the cursor is inside the map.\n * As you move the cursor across the map, the event will fire every time the cursor changes position within the map.\n *\n * @see [Get coordinates of the mouse pointer](https://maplibre.org/maplibre-gl-js/docs/examples/mouse-position/)\n * @see [Highlight features under the mouse pointer](https://maplibre.org/maplibre-gl-js/docs/examples/hover-styles/)\n * @see [Display a popup on over](https://maplibre.org/maplibre-gl-js/docs/examples/popup-on-hover/)\n */\n mousemove: MapMouseEvent;\n /**\n * Fired when a pointing device (usually a mouse) is released within the map.\n *\n * @see [Create a draggable point](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-point/)\n */\n mouseup: MapMouseEvent;\n /**\n * Fired when a pointing device (usually a mouse) is pressed within the map.\n *\n * @see [Create a draggable point](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-point/)\n */\n mousedown: MapMouseEvent;\n /**\n * Fired when a point device (usually a mouse) leaves the map's canvas.\n */\n mouseout: MapMouseEvent;\n /**\n * Fired when a pointing device (usually a mouse) is moved within the map.\n * As you move the cursor across a web page containing a map,\n * the event will fire each time it enters the map or any child elements.\n *\n * @see [Get coordinates of the mouse pointer](https://maplibre.org/maplibre-gl-js/docs/examples/mouse-position/)\n * @see [Highlight features under the mouse pointer](https://maplibre.org/maplibre-gl-js/docs/examples/hover-styles/)\n * @see [Display a popup on hover](https://maplibre.org/maplibre-gl-js/docs/examples/popup-on-hover/)\n */\n mouseover: MapMouseEvent;\n /**\n * Fired just before the map begins a transition from one\n * view to another, as the result of either user interaction or methods such as {@link Map#jumpTo}.\n *\n */\n movestart: MapLibreEvent;\n /**\n * Fired repeatedly during an animated transition from one view to\n * another, as the result of either user interaction or methods such as {@link Map#flyTo}.\n *\n * @see [Display HTML clusters with custom properties](https://maplibre.org/maplibre-gl-js/docs/examples/cluster-html/)\n */\n move: MapLibreEvent;\n /**\n * Fired just after the map completes a transition from one\n * view to another, as the result of either user interaction or methods such as {@link Map#jumpTo}.\n *\n * @see [Display HTML clusters with custom properties](https://maplibre.org/maplibre-gl-js/docs/examples/cluster-html/)\n */\n moveend: MapLibreEvent;\n /**\n * Fired just before the map begins a transition from one zoom level to another,\n * as the result of either user interaction or methods such as {@link Map#flyTo}.\n */\n zoomstart: MapLibreEvent;\n /**\n * Fired repeatedly during an animated transition from one zoom level to another,\n * as the result of either user interaction or methods such as {@link Map#flyTo}.\n */\n zoom: MapLibreEvent;\n /**\n * Fired just after the map completes a transition from one zoom level to another,\n * as the result of either user interaction or methods such as {@link Map#flyTo}.\n */\n zoomend: MapLibreEvent;\n /**\n * Fired when a \"drag to rotate\" interaction starts. See {@link DragRotateHandler}.\n */\n rotatestart: MapLibreEvent;\n /**\n * Fired repeatedly during a \"drag to rotate\" interaction. See {@link DragRotateHandler}.\n */\n rotate: MapLibreEvent;\n /**\n * Fired when a \"drag to rotate\" interaction ends. See {@link DragRotateHandler}.\n */\n rotateend: MapLibreEvent;\n /**\n * Fired when a \"drag to pan\" interaction starts. See {@link DragPanHandler}.\n */\n dragstart: MapLibreEvent;\n /**\n * Fired repeatedly during a \"drag to pan\" interaction. See {@link DragPanHandler}.\n */\n drag: MapLibreEvent;\n /**\n * Fired when a \"drag to pan\" interaction ends. See {@link DragPanHandler}.\n * @see [Create a draggable marker](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-marker/)\n */\n dragend: MapLibreEvent;\n /**\n * Fired whenever the map's pitch (tilt) begins a change as\n * the result of either user interaction or methods such as {@link Map#flyTo} .\n */\n pitchstart: MapLibreEvent;\n /**\n * Fired repeatedly during the map's pitch (tilt) animation between\n * one state and another as the result of either user interaction\n * or methods such as {@link Map#flyTo}.\n */\n pitch: MapLibreEvent;\n /**\n * Fired immediately after the map's pitch (tilt) finishes changing as\n * the result of either user interaction or methods such as {@link Map#flyTo}.\n */\n pitchend: MapLibreEvent;\n /**\n * Fired when a [`wheel`](https://developer.mozilla.org/en-US/docs/Web/Events/wheel) event occurs within the map.\n */\n wheel: MapWheelEvent;\n /**\n * Fired when terrain is changed\n */\n terrain: MapTerrainEvent;\n /**\n * Fired whenever the cooperativeGestures option prevents a gesture from being handled by the map.\n * This is useful for showing your own UI when this happens.\n */\n cooperativegestureprevented: MapLibreEvent & {\n gestureType: 'wheel_zoom' | 'touch_pan';\n };\n};\n\n/**\n * The base event for MapLibre\n *\n * @group Event Related\n */\nexport type MapLibreEvent = {\n type: keyof MapEventType | keyof MapLayerEventType;\n target: Map;\n originalEvent: TOrig;\n}\n\n/**\n * The style data event\n *\n * @group Event Related\n */\nexport type MapStyleDataEvent = MapLibreEvent & {\n dataType: 'style';\n}\n\n/**\n * The source data event interface\n *\n * @group Event Related\n */\nexport type MapSourceDataEvent = MapLibreEvent & {\n dataType: 'source';\n /**\n * True if the event has a `dataType` of `source` and the source has no outstanding network requests.\n */\n isSourceLoaded: boolean;\n /**\n * The [style spec representation of the source](https://maplibre.org/maplibre-style-spec/#sources) if the event has a `dataType` of `source`.\n */\n source: SourceSpecification;\n sourceId: string;\n sourceDataType: MapSourceDataType;\n /**\n * The tile being loaded or changed, if the event has a `dataType` of `source` and\n * the event is related to loading of a tile.\n */\n tile: any;\n}\n/**\n * `MapMouseEvent` is the event type for mouse-related map events.\n *\n * @group Event Related\n *\n * @example\n * ```ts\n * // The `click` event is an example of a `MapMouseEvent`.\n * // Set up an event listener on the map.\n * map.on('click', (e) => {\n * // The event object (e) contains information like the\n * // coordinates of the point on the map that was clicked.\n * console.log('A click event has occurred at ' + e.lngLat);\n * });\n * ```\n */\nexport class MapMouseEvent extends Event implements MapLibreEvent {\n /**\n * The event type\n */\n type: 'mousedown' | 'mouseup' | 'click' | 'dblclick' | 'mousemove' | 'mouseover' | 'mouseenter' | 'mouseleave' | 'mouseout' | 'contextmenu';\n\n /**\n * The `Map` object that fired the event.\n */\n target: Map;\n\n /**\n * The DOM event which caused the map event.\n */\n originalEvent: MouseEvent;\n\n /**\n * The pixel coordinates of the mouse cursor, relative to the map and measured from the top left corner.\n */\n point: Point;\n\n /**\n * The geographic location on the map of the mouse cursor.\n */\n lngLat: LngLat;\n\n /**\n * Prevents subsequent default processing of the event by the map.\n *\n * Calling this method will prevent the following default map behaviors:\n *\n * * On `mousedown` events, the behavior of {@link DragPanHandler}\n * * On `mousedown` events, the behavior of {@link DragRotateHandler}\n * * On `mousedown` events, the behavior of {@link BoxZoomHandler}\n * * On `dblclick` events, the behavior of {@link DoubleClickZoomHandler}\n *\n */\n preventDefault() {\n this._defaultPrevented = true;\n }\n\n /**\n * `true` if `preventDefault` has been called.\n */\n get defaultPrevented(): boolean {\n return this._defaultPrevented;\n }\n\n _defaultPrevented: boolean;\n\n constructor(type: string, map: Map, originalEvent: MouseEvent, data: any = {}) {\n const point = DOM.mousePos(map.getCanvas(), originalEvent);\n const lngLat = map.unproject(point);\n super(type, extend({point, lngLat, originalEvent}, data));\n this._defaultPrevented = false;\n this.target = map;\n }\n}\n\n/**\n * `MapTouchEvent` is the event type for touch-related map events.\n *\n * @group Event Related\n */\nexport class MapTouchEvent extends Event implements MapLibreEvent {\n /**\n * The event type.\n */\n type: 'touchstart' | 'touchmove' | 'touchend' | 'touchcancel';\n\n /**\n * The `Map` object that fired the event.\n */\n target: Map;\n\n /**\n * The DOM event which caused the map event.\n */\n originalEvent: TouchEvent;\n\n /**\n * The geographic location on the map of the center of the touch event points.\n */\n lngLat: LngLat;\n\n /**\n * The pixel coordinates of the center of the touch event points, relative to the map and measured from the top left\n * corner.\n */\n point: Point;\n\n /**\n * The array of pixel coordinates corresponding to a\n * [touch event's `touches`](https://developer.mozilla.org/en-US/docs/Web/API/TouchEvent/touches) property.\n */\n points: Array;\n\n /**\n * The geographical locations on the map corresponding to a\n * [touch event's `touches`](https://developer.mozilla.org/en-US/docs/Web/API/TouchEvent/touches) property.\n */\n lngLats: Array;\n\n /**\n * Prevents subsequent default processing of the event by the map.\n *\n * Calling this method will prevent the following default map behaviors:\n *\n * * On `touchstart` events, the behavior of {@link DragPanHandler}\n * * On `touchstart` events, the behavior of {@link TwoFingersTouchZoomRotateHandler}\n *\n */\n preventDefault() {\n this._defaultPrevented = true;\n }\n\n /**\n * `true` if `preventDefault` has been called.\n */\n get defaultPrevented(): boolean {\n return this._defaultPrevented;\n }\n\n _defaultPrevented: boolean;\n\n constructor(type: string, map: Map, originalEvent: TouchEvent) {\n const touches = type === 'touchend' ? originalEvent.changedTouches : originalEvent.touches;\n const points = DOM.touchPos(map.getCanvasContainer(), touches);\n const lngLats = points.map((t) => map.unproject(t));\n const point = points.reduce((prev, curr, i, arr) => {\n return prev.add(curr.div(arr.length));\n }, new Point(0, 0));\n const lngLat = map.unproject(point);\n super(type, {points, point, lngLats, lngLat, originalEvent});\n this._defaultPrevented = false;\n }\n}\n\n/**\n * `MapWheelEvent` is the event type for the `wheel` map event.\n *\n * @group Event Related\n */\nexport class MapWheelEvent extends Event {\n /**\n * The event type.\n */\n type: 'wheel';\n\n /**\n * The `Map` object that fired the event.\n */\n target: Map;\n\n /**\n * The DOM event which caused the map event.\n */\n originalEvent: WheelEvent;\n\n /**\n * Prevents subsequent default processing of the event by the map.\n *\n * Calling this method will prevent the behavior of {@link ScrollZoomHandler}.\n */\n preventDefault() {\n this._defaultPrevented = true;\n }\n\n /**\n * `true` if `preventDefault` has been called.\n */\n get defaultPrevented(): boolean {\n return this._defaultPrevented;\n }\n\n _defaultPrevented: boolean;\n\n /** */\n constructor(type: string, map: Map, originalEvent: WheelEvent) {\n super(type, {originalEvent});\n this._defaultPrevented = false;\n }\n}\n\n/**\n * A `MapLibreZoomEvent` is the event type for the boxzoom-related map events emitted by the {@link BoxZoomHandler}.\n *\n * @group Event Related\n */\nexport type MapLibreZoomEvent = {\n /**\n * The type of boxzoom event. One of `boxzoomstart`, `boxzoomend` or `boxzoomcancel`\n */\n type: 'boxzoomstart' | 'boxzoomend' | 'boxzoomcancel';\n /**\n * The `Map` instance that triggered the event\n */\n target: Map;\n /**\n * The DOM event that triggered the boxzoom event. Can be a `MouseEvent` or `KeyboardEvent`\n */\n originalEvent: MouseEvent;\n};\n\n/**\n * A `MapDataEvent` object is emitted with the `data`\n * and `dataloading` events. Possible values for\n * `dataType`s are:\n *\n * - `'source'`: The non-tile data associated with any source\n * - `'style'`: The [style](https://maplibre.org/maplibre-style-spec/) used by the map\n *\n * Possible values for `sourceDataType`s are:\n *\n * - `'metadata'`: indicates that any necessary source metadata has been loaded (such as TileJSON) and it is ok to start loading tiles\n * - `'content'`: indicates the source data has changed (such as when source.setData() has been called on GeoJSONSource)\n * - `'visibility'`: send when the source becomes used when at least one of its layers becomes visible in style sense (inside the layer's zoom range and with layout.visibility set to 'visible')\n * - `'idle'`: indicates that no new source data has been fetched (but the source has done loading)\n *\n * @group Event Related\n *\n * @example\n * ```ts\n * // The sourcedata event is an example of MapDataEvent.\n * // Set up an event listener on the map.\n * map.on('sourcedata', (e) => {\n * if (e.isSourceLoaded) {\n * // Do something when the source has finished loading\n * }\n * });\n * ```\n */\nexport type MapDataEvent = {\n /**\n * The event type.\n */\n type: string;\n /**\n * The type of data that has changed. One of `'source'`, `'style'`.\n */\n dataType: string;\n /**\n * Included if the event has a `dataType` of `source` and the event signals that internal data has been received or changed. Possible values are `metadata`, `content`, `visibility` and `idle`.\n */\n sourceDataType: MapSourceDataType;\n};\n\n/**\n * The terrain event\n *\n * @group Event Related\n */\nexport type MapTerrainEvent = {\n type: 'terrain';\n};\n\n/**\n * An event related to the web gl context\n *\n * @group Event Related\n */\nexport type MapContextEvent = {\n type: 'webglcontextlost' | 'webglcontextrestored';\n originalEvent: WebGLContextEvent;\n};\n\n/**\n * The style image missing event\n *\n * @group Event Related\n *\n * @see [Generate and add a missing icon to the map](https://maplibre.org/maplibre-gl-js/docs/examples/add-image-missing-generated/)\n */\nexport type MapStyleImageMissingEvent = MapLibreEvent & {\n type: 'styleimagemissing';\n id: string;\n}\n","import {MapMouseEvent, MapTouchEvent, MapWheelEvent} from '../events';\nimport {Handler} from '../handler_manager';\nimport type {Map} from '../map';\nimport type Point from '@mapbox/point-geometry';\n\nexport class MapEventHandler implements Handler {\n\n _mousedownPos: Point;\n _clickTolerance: number;\n _map: Map;\n\n constructor(map: Map, options: {\n clickTolerance: number;\n }) {\n this._map = map;\n this._clickTolerance = options.clickTolerance;\n }\n\n reset() {\n delete this._mousedownPos;\n }\n\n wheel(e: WheelEvent) {\n // If mapEvent.preventDefault() is called by the user, prevent handlers such as:\n // - ScrollZoom\n return this._firePreventable(new MapWheelEvent(e.type, this._map, e));\n }\n\n mousedown(e: MouseEvent, point: Point) {\n this._mousedownPos = point;\n // If mapEvent.preventDefault() is called by the user, prevent handlers such as:\n // - MousePan\n // - MouseRotate\n // - MousePitch\n // - DblclickHandler\n return this._firePreventable(new MapMouseEvent(e.type, this._map, e));\n }\n\n mouseup(e: MouseEvent) {\n this._map.fire(new MapMouseEvent(e.type, this._map, e));\n }\n\n click(e: MouseEvent, point: Point) {\n if (this._mousedownPos && this._mousedownPos.dist(point) >= this._clickTolerance) return;\n this._map.fire(new MapMouseEvent(e.type, this._map, e));\n }\n\n dblclick(e: MouseEvent) {\n // If mapEvent.preventDefault() is called by the user, prevent handlers such as:\n // - DblClickZoom\n return this._firePreventable(new MapMouseEvent(e.type, this._map, e));\n }\n\n mouseover(e: MouseEvent) {\n this._map.fire(new MapMouseEvent(e.type, this._map, e));\n }\n\n mouseout(e: MouseEvent) {\n this._map.fire(new MapMouseEvent(e.type, this._map, e));\n }\n\n touchstart(e: TouchEvent) {\n // If mapEvent.preventDefault() is called by the user, prevent handlers such as:\n // - TouchPan\n // - TouchZoom\n // - TouchRotate\n // - TouchPitch\n // - TapZoom\n // - SwipeZoom\n return this._firePreventable(new MapTouchEvent(e.type, this._map, e));\n }\n\n touchmove(e: TouchEvent) {\n this._map.fire(new MapTouchEvent(e.type, this._map, e));\n }\n\n touchend(e: TouchEvent) {\n this._map.fire(new MapTouchEvent(e.type, this._map, e));\n }\n\n touchcancel(e: TouchEvent) {\n this._map.fire(new MapTouchEvent(e.type, this._map, e));\n }\n\n _firePreventable(mapEvent: MapMouseEvent | MapTouchEvent | MapWheelEvent) {\n this._map.fire(mapEvent);\n if (mapEvent.defaultPrevented) {\n // returning an object marks the handler as active and resets other handlers\n return {};\n }\n }\n\n isEnabled() {\n return true;\n }\n\n isActive() {\n return false;\n }\n enable() {}\n disable() {}\n}\n\nexport class BlockableMapEventHandler {\n _map: Map;\n _delayContextMenu: boolean;\n _ignoreContextMenu: boolean;\n _contextMenuEvent: MouseEvent;\n\n constructor(map: Map) {\n this._map = map;\n }\n\n reset() {\n this._delayContextMenu = false;\n this._ignoreContextMenu = true;\n delete this._contextMenuEvent;\n }\n\n mousemove(e: MouseEvent) {\n // mousemove map events should not be fired when interaction handlers (pan, rotate, etc) are active\n this._map.fire(new MapMouseEvent(e.type, this._map, e));\n }\n\n mousedown() {\n this._delayContextMenu = true;\n this._ignoreContextMenu = false;\n }\n\n mouseup() {\n this._delayContextMenu = false;\n if (this._contextMenuEvent) {\n this._map.fire(new MapMouseEvent('contextmenu', this._map, this._contextMenuEvent));\n delete this._contextMenuEvent;\n }\n }\n contextmenu(e: MouseEvent) {\n if (this._delayContextMenu) {\n // Mac: contextmenu fired on mousedown; we save it until mouseup for consistency's sake\n this._contextMenuEvent = e;\n } else if (!this._ignoreContextMenu) {\n // Windows: contextmenu fired on mouseup, so fire event now\n this._map.fire(new MapMouseEvent(e.type, this._map, e));\n }\n\n // prevent browser context menu when necessary\n if (this._map.listens('contextmenu')) {\n e.preventDefault();\n }\n }\n\n isEnabled() {\n return true;\n }\n\n isActive() {\n return false;\n }\n enable() {}\n disable() {}\n}\n","import type {Map} from '../map';\nimport type {PointLike} from '../camera';\nimport type {Transform} from '../../geo/transform';\nimport Point from '@mapbox/point-geometry';\nimport {LngLat} from '../../geo/lng_lat';\n\n/**\n * @internal\n * Shared utilities for the Handler classes to access the correct camera state.\n * If Camera.transformCameraUpdate is specified or terrain is enabled, the\n * \"desired state\" of camera may differ from the state used for rendering. The\n * handlers need the \"desired state\" to track accumulated changes.\n */\nexport class TransformProvider {\n _map: Map;\n\n constructor(map: Map) {\n this._map = map;\n }\n\n get transform(): Transform {\n return this._map._requestedCameraState || this._map.transform;\n }\n\n get center() {\n return {lng: this.transform.center.lng, lat: this.transform.center.lat};\n }\n\n get zoom() {\n return this.transform.zoom;\n }\n\n get pitch() {\n return this.transform.pitch;\n }\n\n get bearing() {\n return this.transform.bearing;\n }\n\n unproject(point: PointLike): LngLat {\n return this.transform.pointLocation(Point.convert(point), this._map.terrain);\n }\n}\n","import {DOM} from '../../util/dom';\n\nimport {Event} from '../../util/evented';\nimport {TransformProvider} from './transform-provider';\n\nimport type {Map} from '../map';\nimport type Point from '@mapbox/point-geometry';\nimport {Handler} from '../handler_manager';\n\n/**\n * The `BoxZoomHandler` allows the user to zoom the map to fit within a bounding box.\n * The bounding box is defined by clicking and holding `shift` while dragging the cursor.\n *\n * @group Handlers\n */\nexport class BoxZoomHandler implements Handler {\n _map: Map;\n _tr: TransformProvider;\n _el: HTMLElement;\n _container: HTMLElement;\n _enabled: boolean;\n _active: boolean;\n _startPos: Point;\n _lastPos: Point;\n _box: HTMLElement;\n _clickTolerance: number;\n\n /** @internal */\n constructor(map: Map, options: {\n clickTolerance: number;\n }) {\n this._map = map;\n this._tr = new TransformProvider(map);\n this._el = map.getCanvasContainer();\n this._container = map.getContainer();\n this._clickTolerance = options.clickTolerance || 1;\n }\n\n /**\n * Returns a Boolean indicating whether the \"box zoom\" interaction is enabled.\n *\n * @returns `true` if the \"box zoom\" interaction is enabled.\n */\n isEnabled() {\n return !!this._enabled;\n }\n\n /**\n * Returns a Boolean indicating whether the \"box zoom\" interaction is active, i.e. currently being used.\n *\n * @returns `true` if the \"box zoom\" interaction is active.\n */\n isActive() {\n return !!this._active;\n }\n\n /**\n * Enables the \"box zoom\" interaction.\n *\n * @example\n * ```ts\n * map.boxZoom.enable();\n * ```\n */\n enable() {\n if (this.isEnabled()) return;\n this._enabled = true;\n }\n\n /**\n * Disables the \"box zoom\" interaction.\n *\n * @example\n * ```ts\n * map.boxZoom.disable();\n * ```\n */\n disable() {\n if (!this.isEnabled()) return;\n this._enabled = false;\n }\n\n mousedown(e: MouseEvent, point: Point) {\n if (!this.isEnabled()) return;\n if (!(e.shiftKey && e.button === 0)) return;\n\n DOM.disableDrag();\n this._startPos = this._lastPos = point;\n this._active = true;\n }\n\n mousemoveWindow(e: MouseEvent, point: Point) {\n if (!this._active) return;\n\n const pos = point;\n\n if (this._lastPos.equals(pos) || (!this._box && pos.dist(this._startPos) < this._clickTolerance)) {\n return;\n }\n\n const p0 = this._startPos;\n this._lastPos = pos;\n\n if (!this._box) {\n this._box = DOM.create('div', 'maplibregl-boxzoom', this._container);\n this._container.classList.add('maplibregl-crosshair');\n this._fireEvent('boxzoomstart', e);\n }\n\n const minX = Math.min(p0.x, pos.x),\n maxX = Math.max(p0.x, pos.x),\n minY = Math.min(p0.y, pos.y),\n maxY = Math.max(p0.y, pos.y);\n\n DOM.setTransform(this._box, `translate(${minX}px,${minY}px)`);\n\n this._box.style.width = `${maxX - minX}px`;\n this._box.style.height = `${maxY - minY}px`;\n }\n\n mouseupWindow(e: MouseEvent, point: Point) {\n if (!this._active) return;\n\n if (e.button !== 0) return;\n\n const p0 = this._startPos,\n p1 = point;\n\n this.reset();\n\n DOM.suppressClick();\n\n if (p0.x === p1.x && p0.y === p1.y) {\n this._fireEvent('boxzoomcancel', e);\n } else {\n this._map.fire(new Event('boxzoomend', {originalEvent: e}));\n return {\n cameraAnimation: map => map.fitScreenCoordinates(p0, p1, this._tr.bearing, {linear: true})\n };\n }\n }\n\n keydown(e: KeyboardEvent) {\n if (!this._active) return;\n\n if (e.keyCode === 27) {\n this.reset();\n this._fireEvent('boxzoomcancel', e);\n }\n }\n\n reset() {\n this._active = false;\n\n this._container.classList.remove('maplibregl-crosshair');\n\n if (this._box) {\n DOM.remove(this._box);\n this._box = null;\n }\n\n DOM.enableDrag();\n\n delete this._startPos;\n delete this._lastPos;\n }\n\n _fireEvent(type: string, e: any) {\n return this._map.fire(new Event(type, {originalEvent: e}));\n }\n}\n","import Point from '@mapbox/point-geometry';\n\nexport function indexTouches(touches: Array, points: Array) {\n if (touches.length !== points.length) throw new Error(`The number of touches and points are not equal - touches ${touches.length}, points ${points.length}`);\n const obj = {};\n for (let i = 0; i < touches.length; i++) {\n obj[touches[i].identifier] = points[i];\n }\n return obj;\n}\n","import Point from '@mapbox/point-geometry';\nimport {indexTouches} from './handler_util';\n\nfunction getCentroid(points: Array) {\n const sum = new Point(0, 0);\n for (const point of points) {\n sum._add(point);\n }\n return sum.div(points.length);\n}\n\nexport const MAX_TAP_INTERVAL = 500;\nconst MAX_TOUCH_TIME = 500;\nexport const MAX_DIST = 30;\n\nexport class SingleTapRecognizer {\n\n numTouches: number;\n centroid: Point;\n startTime: number;\n aborted: boolean;\n touches: {\n [k in number | string]: Point;\n };\n\n constructor(options: {\n numTouches: number;\n }) {\n this.reset();\n this.numTouches = options.numTouches;\n }\n\n reset() {\n delete this.centroid;\n delete this.startTime;\n delete this.touches;\n this.aborted = false;\n }\n\n touchstart(e: TouchEvent, points: Array, mapTouches: Array) {\n\n if (this.centroid || mapTouches.length > this.numTouches) {\n this.aborted = true;\n }\n if (this.aborted) {\n return;\n }\n\n if (this.startTime === undefined) {\n this.startTime = e.timeStamp;\n }\n\n if (mapTouches.length === this.numTouches) {\n this.centroid = getCentroid(points);\n this.touches = indexTouches(mapTouches, points);\n }\n }\n\n touchmove(e: TouchEvent, points: Array, mapTouches: Array) {\n if (this.aborted || !this.centroid) return;\n\n const newTouches = indexTouches(mapTouches, points);\n for (const id in this.touches) {\n const prevPos = this.touches[id];\n const pos = newTouches[id];\n if (!pos || pos.dist(prevPos) > MAX_DIST) {\n this.aborted = true;\n }\n }\n }\n\n touchend(e: TouchEvent, points: Array, mapTouches: Array) {\n if (!this.centroid || e.timeStamp - this.startTime > MAX_TOUCH_TIME) {\n this.aborted = true;\n }\n\n if (mapTouches.length === 0) {\n const centroid = !this.aborted && this.centroid;\n this.reset();\n if (centroid) return centroid;\n }\n }\n\n}\n\nexport class TapRecognizer {\n\n singleTap: SingleTapRecognizer;\n numTaps: number;\n lastTime: number;\n lastTap: Point;\n count: number;\n\n constructor(options: {\n numTaps: number;\n numTouches: number;\n }) {\n this.singleTap = new SingleTapRecognizer(options);\n this.numTaps = options.numTaps;\n this.reset();\n }\n\n reset() {\n this.lastTime = Infinity;\n delete this.lastTap;\n this.count = 0;\n this.singleTap.reset();\n }\n\n touchstart(e: TouchEvent, points: Array, mapTouches: Array) {\n this.singleTap.touchstart(e, points, mapTouches);\n }\n\n touchmove(e: TouchEvent, points: Array, mapTouches: Array) {\n this.singleTap.touchmove(e, points, mapTouches);\n }\n\n touchend(e: TouchEvent, points: Array, mapTouches: Array) {\n const tap = this.singleTap.touchend(e, points, mapTouches);\n if (tap) {\n const soonEnough = e.timeStamp - this.lastTime < MAX_TAP_INTERVAL;\n const closeEnough = !this.lastTap || this.lastTap.dist(tap) < MAX_DIST;\n\n if (!soonEnough || !closeEnough) {\n this.reset();\n }\n\n this.count++;\n this.lastTime = e.timeStamp;\n this.lastTap = tap;\n\n if (this.count === this.numTaps) {\n this.reset();\n return tap;\n }\n }\n }\n}\n","import {TapRecognizer} from './tap_recognizer';\nimport type Point from '@mapbox/point-geometry';\nimport type {Map} from '../map';\nimport {TransformProvider} from './transform-provider';\nimport {Handler} from '../handler_manager';\n\n/**\n * A `TapZoomHandler` allows the user to zoom the map at a point by double tapping\n */\nexport class TapZoomHandler implements Handler {\n _tr: TransformProvider;\n _enabled: boolean;\n _active: boolean;\n _zoomIn: TapRecognizer;\n _zoomOut: TapRecognizer;\n\n constructor(map: Map) {\n this._tr = new TransformProvider(map);\n this._zoomIn = new TapRecognizer({\n numTouches: 1,\n numTaps: 2\n });\n\n this._zoomOut = new TapRecognizer({\n numTouches: 2,\n numTaps: 1\n });\n\n this.reset();\n }\n\n reset() {\n this._active = false;\n this._zoomIn.reset();\n this._zoomOut.reset();\n }\n\n touchstart(e: TouchEvent, points: Array, mapTouches: Array) {\n this._zoomIn.touchstart(e, points, mapTouches);\n this._zoomOut.touchstart(e, points, mapTouches);\n }\n\n touchmove(e: TouchEvent, points: Array, mapTouches: Array) {\n this._zoomIn.touchmove(e, points, mapTouches);\n this._zoomOut.touchmove(e, points, mapTouches);\n }\n\n touchend(e: TouchEvent, points: Array, mapTouches: Array) {\n const zoomInPoint = this._zoomIn.touchend(e, points, mapTouches);\n const zoomOutPoint = this._zoomOut.touchend(e, points, mapTouches);\n const tr = this._tr;\n\n if (zoomInPoint) {\n this._active = true;\n e.preventDefault();\n setTimeout(() => this.reset(), 0);\n return {\n cameraAnimation: (map: Map) => map.easeTo({\n duration: 300,\n zoom: tr.zoom + 1,\n around: tr.unproject(zoomInPoint)\n }, {originalEvent: e})\n };\n } else if (zoomOutPoint) {\n this._active = true;\n e.preventDefault();\n setTimeout(() => this.reset(), 0);\n return {\n cameraAnimation: (map: Map) => map.easeTo({\n duration: 300,\n zoom: tr.zoom - 1,\n around: tr.unproject(zoomOutPoint)\n }, {originalEvent: e})\n };\n }\n }\n\n touchcancel() {\n this.reset();\n }\n\n enable() {\n this._enabled = true;\n }\n\n disable() {\n this._enabled = false;\n this.reset();\n }\n\n isEnabled() {\n return this._enabled;\n }\n\n isActive() {\n return this._active;\n }\n}\n","import {DOM} from '../../util/dom';\nimport type Point from '@mapbox/point-geometry';\nimport {DragMoveStateManager} from './drag_move_state_manager';\nimport {Handler} from '../handler_manager';\n\ninterface DragMovementResult {\n bearingDelta?: number;\n pitchDelta?: number;\n around?: Point;\n panDelta?: Point;\n}\n\nexport interface DragPanResult extends DragMovementResult {\n around: Point;\n panDelta: Point;\n}\n\nexport interface DragRotateResult extends DragMovementResult {\n bearingDelta: number;\n}\n\nexport interface DragPitchResult extends DragMovementResult {\n pitchDelta: number;\n}\n\ntype DragMoveFunction = (lastPoint: Point, point: Point) => T;\n\nexport interface DragMoveHandler extends Handler {\n dragStart: (e: E, point: Point) => void;\n dragMove: (e: E, point: Point) => T | void;\n dragEnd: (e: E) => void;\n getClickTolerance: () => number;\n}\n\nexport type DragMoveHandlerOptions = {\n /**\n * If the movement is shorter than this value, consider it a click.\n */\n clickTolerance: number;\n /**\n * The move function to run on a valid movement.\n */\n move: DragMoveFunction;\n /**\n * A class used to manage the state of the drag event - start, checking valid moves, end. See the class documentation for more details.\n */\n moveStateManager: DragMoveStateManager;\n /**\n * A method used to assign the dragStart, dragMove, and dragEnd methods to the relevant event handlers, as well as assigning the contextmenu handler\n * @param handler - the handler\n */\n assignEvents: (handler: DragMoveHandler) => void;\n /**\n * Should the move start on the \"start\" event, or should it start on the first valid move.\n */\n activateOnStart?: boolean;\n /**\n * If true, handler will be enabled during construction\n */\n enable?: boolean;\n}\n\n/**\n * A generic class to create handlers for drag events, from both mouse and touch events.\n */\nexport class DragHandler implements DragMoveHandler {\n // Event handlers that may be assigned by the implementations of this class\n contextmenu?: Handler['contextmenu'];\n mousedown?: Handler['mousedown'];\n mousemoveWindow?: Handler['mousemoveWindow'];\n mouseup?: Handler['mouseup'];\n touchstart?: Handler['touchstart'];\n touchmoveWindow?: Handler['touchmoveWindow'];\n touchend?: Handler['touchend'];\n\n _clickTolerance: number;\n _moveFunction: DragMoveFunction;\n _activateOnStart: boolean;\n _active: boolean;\n _enabled: boolean;\n _moved: boolean;\n _lastPoint: Point | null;\n _moveStateManager: DragMoveStateManager;\n\n constructor(options: DragMoveHandlerOptions) {\n this._enabled = !!options.enable;\n this._moveStateManager = options.moveStateManager;\n this._clickTolerance = options.clickTolerance || 1;\n this._moveFunction = options.move;\n this._activateOnStart = !!options.activateOnStart;\n\n options.assignEvents(this);\n\n this.reset();\n }\n\n reset(e?: E) {\n this._active = false;\n this._moved = false;\n delete this._lastPoint;\n this._moveStateManager.endMove(e);\n }\n\n _move(...params: Parameters>) {\n const move = this._moveFunction(...params);\n if (move.bearingDelta || move.pitchDelta || move.around || move.panDelta) {\n this._active = true;\n return move;\n }\n }\n\n dragStart(e: E, point: Point);\n dragStart(e: E, point: Point[]);\n dragStart(e: E, point: Point | Point[]) {\n if (!this.isEnabled() || this._lastPoint) return;\n\n if (!this._moveStateManager.isValidStartEvent(e)) return;\n this._moveStateManager.startMove(e);\n\n this._lastPoint = point['length'] ? point[0] : point;\n\n if (this._activateOnStart && this._lastPoint) this._active = true;\n }\n\n dragMove(e: E, point: Point);\n dragMove(e: E, point: Point[]);\n dragMove(e: E, point: Point | Point[]) {\n if (!this.isEnabled()) return;\n const lastPoint = this._lastPoint;\n if (!lastPoint) return;\n e.preventDefault();\n\n if (!this._moveStateManager.isValidMoveEvent(e)) {\n this.reset(e);\n return;\n }\n\n const movePoint = point['length'] ? point[0] : point;\n\n if (!this._moved && movePoint.dist(lastPoint) < this._clickTolerance) return;\n this._moved = true;\n this._lastPoint = movePoint;\n\n return this._move(lastPoint, movePoint);\n }\n\n dragEnd(e: E) {\n if (!this.isEnabled() || !this._lastPoint) return;\n if (!this._moveStateManager.isValidEndEvent(e)) return;\n if (this._moved) DOM.suppressClick();\n this.reset(e);\n }\n\n enable() {\n this._enabled = true;\n }\n\n disable() {\n this._enabled = false;\n this.reset();\n }\n\n isEnabled() {\n return this._enabled;\n }\n\n isActive() {\n return this._active;\n }\n\n getClickTolerance() {\n return this._clickTolerance;\n }\n}\n","import {DOM} from '../../util/dom';\n\nconst LEFT_BUTTON = 0;\nconst RIGHT_BUTTON = 2;\n\n// the values for each button in MouseEvent.buttons\nconst BUTTONS_FLAGS = {\n [LEFT_BUTTON]: 1,\n [RIGHT_BUTTON]: 2\n};\n\nfunction buttonNoLongerPressed(e: MouseEvent, button: number) {\n const flag = BUTTONS_FLAGS[button];\n return e.buttons === undefined || (e.buttons & flag) !== flag;\n}\n\n/*\n * Drag events are initiated by specific interaction which needs to be tracked until it ends.\n * This requires some state management:\n * 1. registering the initiating event,\n * 2. tracking that it was not canceled / not confusing it with another event firing.\n * 3. recognizing the ending event and cleaning up any internal state\n *\n * Concretely, we implement two state managers:\n * 1. MouseMoveStateManager\n * Receives a functions that is used to recognize mouse events that should be registered as the\n * relevant drag interactions - i.e. dragging with the right mouse button, or while CTRL is pressed.\n * 2. OneFingerTouchMoveStateManager\n * Checks if a drag event is using one finger, and continuously tracking that this is the same event\n * (i.e. to make sure not additional finger has started interacting with the screen before raising\n * the first finger).\n */\nexport interface DragMoveStateManager {\n startMove: (e: E) => void;\n endMove: (e?: E) => void;\n isValidStartEvent: (e: E) => boolean;\n isValidMoveEvent: (e: E) => boolean;\n isValidEndEvent: (e?: E) => boolean;\n}\n\nexport class MouseMoveStateManager implements DragMoveStateManager {\n _eventButton: number | undefined;\n _correctEvent: (e: MouseEvent) => boolean;\n\n constructor(options: {\n checkCorrectEvent: (e: MouseEvent) => boolean;\n }) {\n this._correctEvent = options.checkCorrectEvent;\n }\n\n startMove(e: MouseEvent) {\n const eventButton = DOM.mouseButton(e);\n this._eventButton = eventButton;\n }\n\n endMove(_e?: MouseEvent) {\n delete this._eventButton;\n }\n\n isValidStartEvent(e: MouseEvent) {\n return this._correctEvent(e);\n }\n\n isValidMoveEvent(e: MouseEvent) {\n // Some browsers don't fire a `mouseup` when the mouseup occurs outside\n // the window or iframe:\n // https://github.com/mapbox/mapbox-gl-js/issues/4622\n //\n // If the button is no longer pressed during this `mousemove` it may have\n // been released outside of the window or iframe.\n return !buttonNoLongerPressed(e, this._eventButton);\n }\n\n isValidEndEvent(e: MouseEvent) {\n const eventButton = DOM.mouseButton(e);\n return eventButton === this._eventButton;\n }\n}\n\nexport class OneFingerTouchMoveStateManager implements DragMoveStateManager {\n _firstTouch: number | undefined;\n\n constructor() {\n this._firstTouch = undefined;\n }\n\n _isOneFingerTouch(e: TouchEvent) {\n return e.targetTouches.length === 1;\n }\n\n _isSameTouchEvent(e: TouchEvent) {\n return e.targetTouches[0].identifier === this._firstTouch;\n }\n\n startMove(e: TouchEvent) {\n const firstTouch = e.targetTouches[0].identifier;\n this._firstTouch = firstTouch;\n }\n\n endMove(_e?: TouchEvent) {\n delete this._firstTouch;\n }\n\n isValidStartEvent(e: TouchEvent) {\n return this._isOneFingerTouch(e);\n }\n\n isValidMoveEvent(e: TouchEvent) {\n return this._isOneFingerTouch(e) && this._isSameTouchEvent(e);\n }\n\n isValidEndEvent(e: TouchEvent) {\n return this._isOneFingerTouch(e) && this._isSameTouchEvent(e);\n }\n}\n","import type Point from '@mapbox/point-geometry';\n\nimport {DOM} from '../../util/dom';\nimport {DragMoveHandler, DragPanResult, DragRotateResult, DragPitchResult, DragHandler} from './drag_handler';\nimport {MouseMoveStateManager} from './drag_move_state_manager';\n\n/**\n * `MousePanHandler` allows the user to pan the map by clicking and dragging\n */\nexport interface MousePanHandler extends DragMoveHandler {}\n/**\n * `MouseRotateHandler` allows the user to rotate the map by clicking and dragging\n */\nexport interface MouseRotateHandler extends DragMoveHandler {}\n/**\n * `MousePitchHandler` allows the user to zoom the map by pitching\n */\nexport interface MousePitchHandler extends DragMoveHandler {}\n\nconst LEFT_BUTTON = 0;\nconst RIGHT_BUTTON = 2;\n\nconst assignEvents = (handler: DragHandler) => {\n handler.mousedown = handler.dragStart;\n handler.mousemoveWindow = handler.dragMove;\n handler.mouseup = handler.dragEnd;\n handler.contextmenu = (e: MouseEvent) => {\n e.preventDefault();\n };\n};\n\nexport const generateMousePanHandler = ({enable, clickTolerance,}: {\n clickTolerance: number;\n enable?: boolean;\n}): MousePanHandler => {\n const mouseMoveStateManager = new MouseMoveStateManager({\n checkCorrectEvent: (e: MouseEvent) => DOM.mouseButton(e) === LEFT_BUTTON && !e.ctrlKey,\n });\n return new DragHandler({\n clickTolerance,\n move: (lastPoint: Point, point: Point) =>\n ({around: point, panDelta: point.sub(lastPoint)}),\n activateOnStart: true,\n moveStateManager: mouseMoveStateManager,\n enable,\n assignEvents,\n });\n};\n\nexport const generateMouseRotationHandler = ({enable, clickTolerance, bearingDegreesPerPixelMoved = 0.8}: {\n clickTolerance: number;\n bearingDegreesPerPixelMoved?: number;\n enable?: boolean;\n}): MouseRotateHandler => {\n const mouseMoveStateManager = new MouseMoveStateManager({\n checkCorrectEvent: (e: MouseEvent): boolean =>\n (DOM.mouseButton(e) === LEFT_BUTTON && e.ctrlKey) ||\n (DOM.mouseButton(e) === RIGHT_BUTTON),\n });\n return new DragHandler({\n clickTolerance,\n move: (lastPoint: Point, point: Point) =>\n ({bearingDelta: (point.x - lastPoint.x) * bearingDegreesPerPixelMoved}),\n // prevent browser context menu when necessary; we don't allow it with rotation\n // because we can't discern rotation gesture start from contextmenu on Mac\n moveStateManager: mouseMoveStateManager,\n enable,\n assignEvents,\n });\n};\n\nexport const generateMousePitchHandler = ({enable, clickTolerance, pitchDegreesPerPixelMoved = -0.5}: {\n clickTolerance: number;\n pitchDegreesPerPixelMoved?: number;\n enable?: boolean;\n}): MousePitchHandler => {\n const mouseMoveStateManager = new MouseMoveStateManager({\n checkCorrectEvent: (e: MouseEvent): boolean =>\n (DOM.mouseButton(e) === LEFT_BUTTON && e.ctrlKey) ||\n (DOM.mouseButton(e) === RIGHT_BUTTON),\n });\n return new DragHandler({\n clickTolerance,\n move: (lastPoint: Point, point: Point) =>\n ({pitchDelta: (point.y - lastPoint.y) * pitchDegreesPerPixelMoved}),\n // prevent browser context menu when necessary; we don't allow it with rotation\n // because we can't discern rotation gesture start from contextmenu on Mac\n moveStateManager: mouseMoveStateManager,\n enable,\n assignEvents,\n });\n};\n","import Point from '@mapbox/point-geometry';\nimport {indexTouches} from './handler_util';\nimport {Handler} from '../handler_manager';\nimport type {Map} from '../map';\n\n/**\n * A `TouchPanHandler` allows the user to pan the map using touch gestures.\n */\nexport class TouchPanHandler implements Handler {\n\n _enabled: boolean;\n _active: boolean;\n _touches: {\n [k in string | number]: Point;\n };\n _clickTolerance: number;\n _sum: Point;\n _map: Map;\n\n constructor(options: {clickTolerance: number}, map: Map) {\n this._clickTolerance = options.clickTolerance || 1;\n this._map = map;\n this.reset();\n }\n\n reset() {\n this._active = false;\n this._touches = {};\n this._sum = new Point(0, 0);\n }\n\n _shouldBePrevented(touchesCount: number) {\n const minTouches = this._map.cooperativeGestures.isEnabled() ? 2 : 1;\n return touchesCount < minTouches;\n }\n\n touchstart(e: TouchEvent, points: Array, mapTouches: Array) {\n return this._calculateTransform(e, points, mapTouches);\n }\n\n touchmove(e: TouchEvent, points: Array, mapTouches: Array) {\n if (!this._active) return;\n if (this._shouldBePrevented(mapTouches.length)) {\n this._map.cooperativeGestures.notifyGestureBlocked('touch_pan', e);\n return;\n }\n e.preventDefault();\n return this._calculateTransform(e, points, mapTouches);\n }\n\n touchend(e: TouchEvent, points: Array, mapTouches: Array) {\n this._calculateTransform(e, points, mapTouches);\n\n if (this._active && this._shouldBePrevented(mapTouches.length)) {\n this.reset();\n }\n }\n\n touchcancel() {\n this.reset();\n }\n\n _calculateTransform(e: TouchEvent, points: Array, mapTouches: Array) {\n if (mapTouches.length > 0) this._active = true;\n\n const touches = indexTouches(mapTouches, points);\n\n const touchPointSum = new Point(0, 0);\n const touchDeltaSum = new Point(0, 0);\n let touchDeltaCount = 0;\n\n for (const identifier in touches) {\n const point = touches[identifier];\n const prevPoint = this._touches[identifier];\n if (prevPoint) {\n touchPointSum._add(point);\n touchDeltaSum._add(point.sub(prevPoint));\n touchDeltaCount++;\n touches[identifier] = point;\n }\n }\n\n this._touches = touches;\n\n if (this._shouldBePrevented(touchDeltaCount) || !touchDeltaSum.mag()) return;\n\n const panDelta = touchDeltaSum.div(touchDeltaCount);\n this._sum._add(panDelta);\n if (this._sum.mag() < this._clickTolerance) return;\n\n const around = touchPointSum.div(touchDeltaCount);\n\n return {\n around,\n panDelta\n };\n }\n\n enable() {\n this._enabled = true;\n }\n\n disable() {\n this._enabled = false;\n this.reset();\n }\n\n isEnabled() {\n return this._enabled;\n }\n\n isActive() {\n return this._active;\n }\n}\n","import Point from '@mapbox/point-geometry';\nimport {DOM} from '../../util/dom';\nimport type {Map} from '../map';\nimport {Handler, HandlerResult} from '../handler_manager';\n\n/**\n * An options object sent to the enable function of some of the handlers\n */\nexport type AroundCenterOptions = {\n /**\n * If \"center\" is passed, map will zoom around the center of map\n */\n around: 'center';\n}\n\n/**\n * The `TwoFingersTouchHandler`s allows the user to zoom, pitch and rotate the map using two fingers\n *\n */\nabstract class TwoFingersTouchHandler implements Handler {\n\n _enabled?: boolean;\n _active?: boolean;\n _firstTwoTouches?: [number, number];\n _vector?: Point;\n _startVector?: Point;\n _aroundCenter?: boolean;\n\n /** @internal */\n constructor() {\n this.reset();\n }\n\n reset(): void {\n this._active = false;\n delete this._firstTwoTouches;\n }\n\n abstract _start(points: [Point, Point]): void;\n abstract _move(points: [Point, Point], pinchAround: Point | null, e: TouchEvent): HandlerResult | void;\n\n touchstart(e: TouchEvent, points: Array, mapTouches: Array): void {\n //log('touchstart', points, e.target.innerHTML, e.targetTouches.length ? e.targetTouches[0].target.innerHTML: undefined);\n if (this._firstTwoTouches || mapTouches.length < 2) return;\n\n this._firstTwoTouches = [\n mapTouches[0].identifier,\n mapTouches[1].identifier\n ];\n\n // implemented by child classes\n this._start([points[0], points[1]]);\n }\n\n touchmove(e: TouchEvent, points: Array, mapTouches: Array): HandlerResult | void {\n if (!this._firstTwoTouches) return;\n\n e.preventDefault();\n\n const [idA, idB] = this._firstTwoTouches;\n const a = getTouchById(mapTouches, points, idA);\n const b = getTouchById(mapTouches, points, idB);\n if (!a || !b) return;\n const pinchAround = this._aroundCenter ? null : a.add(b).div(2);\n\n // implemented by child classes\n return this._move([a, b], pinchAround, e);\n\n }\n\n touchend(e: TouchEvent, points: Array, mapTouches: Array): void {\n if (!this._firstTwoTouches) return;\n\n const [idA, idB] = this._firstTwoTouches;\n const a = getTouchById(mapTouches, points, idA);\n const b = getTouchById(mapTouches, points, idB);\n if (a && b) return;\n\n if (this._active) DOM.suppressClick();\n\n this.reset();\n }\n\n touchcancel(): void {\n this.reset();\n }\n\n /**\n * Enables the \"drag to pitch\" interaction.\n *\n * @example\n * ```ts\n * map.touchPitch.enable();\n * ```\n */\n enable(options?: AroundCenterOptions | boolean | null): void {\n this._enabled = true;\n this._aroundCenter = !!options && (options as AroundCenterOptions).around === 'center';\n }\n\n /**\n * Disables the \"drag to pitch\" interaction.\n *\n * @example\n * ```ts\n * map.touchPitch.disable();\n * ```\n */\n disable(): void {\n this._enabled = false;\n this.reset();\n }\n\n /**\n * Returns a Boolean indicating whether the \"drag to pitch\" interaction is enabled.\n *\n * @returns `true` if the \"drag to pitch\" interaction is enabled.\n */\n isEnabled(): boolean {\n return !!this._enabled;\n }\n\n /**\n * Returns a Boolean indicating whether the \"drag to pitch\" interaction is active, i.e. currently being used.\n *\n * @returns `true` if the \"drag to pitch\" interaction is active.\n */\n isActive(): boolean {\n return !!this._active;\n }\n}\n\nfunction getTouchById(mapTouches: Array, points: Array, identifier: number): Point | undefined {\n for (let i = 0; i < mapTouches.length; i++) {\n if (mapTouches[i].identifier === identifier) return points[i];\n }\n return undefined;\n}\n\n/* ZOOM */\n\nconst ZOOM_THRESHOLD = 0.1;\n\nfunction getZoomDelta(distance: number, lastDistance: number): number {\n return Math.log(distance / lastDistance) / Math.LN2;\n}\n\n/**\n * The `TwoFingersTouchHandler`s allows the user to zoom the map two fingers\n *\n * @group Handlers\n */\nexport class TwoFingersTouchZoomHandler extends TwoFingersTouchHandler {\n\n _distance?: number;\n _startDistance?: number;\n\n reset() {\n super.reset();\n delete this._distance;\n delete this._startDistance;\n }\n\n _start(points: [Point, Point]): void {\n this._startDistance = this._distance = points[0].dist(points[1]);\n }\n\n _move(points: [Point, Point], pinchAround: Point | null): HandlerResult | void {\n const lastDistance = this._distance!;\n this._distance = points[0].dist(points[1]);\n if (!this._active && Math.abs(getZoomDelta(this._distance, this._startDistance!)) < ZOOM_THRESHOLD) return;\n this._active = true;\n return {\n zoomDelta: getZoomDelta(this._distance, lastDistance),\n pinchAround\n };\n }\n}\n\n/* ROTATE */\n\nconst ROTATION_THRESHOLD = 25; // pixels along circumference of touch circle\n\nfunction getBearingDelta(a: Point, b: Point): number {\n return a.angleWith(b) * 180 / Math.PI;\n}\n\n/**\n * The `TwoFingersTouchHandler`s allows the user to rotate the map two fingers\n *\n * @group Handlers\n */\nexport class TwoFingersTouchRotateHandler extends TwoFingersTouchHandler {\n _minDiameter?: number;\n\n reset(): void {\n super.reset();\n delete this._minDiameter;\n delete this._startVector;\n delete this._vector;\n }\n\n _start(points: [Point, Point]): void {\n this._startVector = this._vector = points[0].sub(points[1]);\n this._minDiameter = points[0].dist(points[1]);\n }\n\n _move(points: [Point, Point], pinchAround: Point | null, _e: TouchEvent): HandlerResult | void {\n const lastVector = this._vector!;\n this._vector = points[0].sub(points[1]);\n\n if (!this._active && this._isBelowThreshold(this._vector)) return;\n this._active = true;\n\n return {\n bearingDelta: getBearingDelta(this._vector, lastVector),\n pinchAround\n };\n }\n\n _isBelowThreshold(vector: Point): boolean {\n /*\n * The threshold before a rotation actually happens is configured in\n * pixels along the circumference of the circle formed by the two fingers.\n * This makes the threshold in degrees larger when the fingers are close\n * together and smaller when the fingers are far apart.\n *\n * Use the smallest diameter from the whole gesture to reduce sensitivity\n * when pinching in and out.\n */\n\n this._minDiameter = Math.min(this._minDiameter!, vector.mag());\n const circumference = Math.PI * this._minDiameter;\n const threshold = ROTATION_THRESHOLD / circumference * 360;\n\n const bearingDeltaSinceStart = getBearingDelta(vector, this._startVector!);\n return Math.abs(bearingDeltaSinceStart) < threshold;\n }\n}\n\n/* PITCH */\n\nfunction isVertical(vector: Point): boolean {\n return Math.abs(vector.y) > Math.abs(vector.x);\n}\n\nconst ALLOWED_SINGLE_TOUCH_TIME = 100;\n\n/**\n * The `TwoFingersTouchPitchHandler` allows the user to pitch the map by dragging up and down with two fingers.\n *\n * @group Handlers\n */\nexport class TwoFingersTouchPitchHandler extends TwoFingersTouchHandler {\n\n _valid?: boolean;\n _firstMove?: number;\n _lastPoints?: [Point, Point];\n _map: Map;\n _currentTouchCount: number = 0;\n\n constructor(map: Map) {\n super();\n this._map = map;\n }\n\n reset(): void {\n super.reset();\n this._valid = undefined;\n delete this._firstMove;\n delete this._lastPoints;\n }\n\n touchstart(e: TouchEvent, points: Array, mapTouches: Array): void {\n super.touchstart(e, points, mapTouches);\n this._currentTouchCount = mapTouches.length;\n }\n\n _start(points: [Point, Point]): void {\n this._lastPoints = points;\n if (isVertical(points[0].sub(points[1]))) {\n // fingers are more horizontal than vertical\n this._valid = false;\n }\n }\n\n _move(points: [Point, Point], center: Point | null, e: TouchEvent): HandlerResult | void {\n // If cooperative gestures is enabled, we need a 3-finger minimum for this gesture to register\n if (this._map.cooperativeGestures.isEnabled() && this._currentTouchCount < 3) {\n return;\n }\n\n const vectorA = points[0].sub(this._lastPoints![0]);\n const vectorB = points[1].sub(this._lastPoints![1]);\n\n this._valid = this.gestureBeginsVertically(vectorA, vectorB, e.timeStamp);\n if (!this._valid) return;\n\n this._lastPoints = points;\n this._active = true;\n const yDeltaAverage = (vectorA.y + vectorB.y) / 2;\n const degreesPerPixelMoved = -0.5;\n return {\n pitchDelta: yDeltaAverage * degreesPerPixelMoved\n };\n }\n\n gestureBeginsVertically(vectorA: Point, vectorB: Point, timeStamp: number): boolean | undefined {\n if (this._valid !== undefined) return this._valid;\n\n const threshold = 2;\n const movedA = vectorA.mag() >= threshold;\n const movedB = vectorB.mag() >= threshold;\n\n // neither finger has moved a meaningful amount, wait\n if (!movedA && !movedB) return;\n\n // One finger has moved and the other has not.\n // If enough time has passed, decide it is not a pitch.\n if (!movedA || !movedB) {\n if (this._firstMove === undefined) {\n this._firstMove = timeStamp;\n }\n\n if (timeStamp - this._firstMove < ALLOWED_SINGLE_TOUCH_TIME) {\n // still waiting for a movement from the second finger\n return undefined;\n } else {\n return false;\n }\n }\n\n const isSameDirection = vectorA.y > 0 === vectorB.y > 0;\n return isVertical(vectorA) && isVertical(vectorB) && isSameDirection;\n }\n}\n","import {Handler} from '../handler_manager';\nimport type {Map} from '../map';\nimport {TransformProvider} from './transform-provider';\n\nconst defaultOptions = {\n panStep: 100,\n bearingStep: 15,\n pitchStep: 10\n};\n\n/**\n * The `KeyboardHandler` allows the user to zoom, rotate, and pan the map using\n * the following keyboard shortcuts:\n *\n * - `=` / `+`: Increase the zoom level by 1.\n * - `Shift-=` / `Shift-+`: Increase the zoom level by 2.\n * - `-`: Decrease the zoom level by 1.\n * - `Shift--`: Decrease the zoom level by 2.\n * - Arrow keys: Pan by 100 pixels.\n * - `Shift+⇢`: Increase the rotation by 15 degrees.\n * - `Shift+⇠`: Decrease the rotation by 15 degrees.\n * - `Shift+⇡`: Increase the pitch by 10 degrees.\n * - `Shift+⇣`: Decrease the pitch by 10 degrees.\n *\n * @group Handlers\n */\nexport class KeyboardHandler implements Handler {\n _tr: TransformProvider;\n _enabled: boolean;\n _active: boolean;\n _panStep: number;\n _bearingStep: number;\n _pitchStep: number;\n _rotationDisabled: boolean;\n\n /** @internal */\n constructor(map: Map) {\n this._tr = new TransformProvider(map);\n const stepOptions = defaultOptions;\n this._panStep = stepOptions.panStep;\n this._bearingStep = stepOptions.bearingStep;\n this._pitchStep = stepOptions.pitchStep;\n this._rotationDisabled = false;\n }\n\n reset() {\n this._active = false;\n }\n\n keydown(e: KeyboardEvent) {\n if (e.altKey || e.ctrlKey || e.metaKey) return;\n\n let zoomDir = 0;\n let bearingDir = 0;\n let pitchDir = 0;\n let xDir = 0;\n let yDir = 0;\n\n switch (e.keyCode) {\n case 61:\n case 107:\n case 171:\n case 187:\n zoomDir = 1;\n break;\n\n case 189:\n case 109:\n case 173:\n zoomDir = -1;\n break;\n\n case 37:\n if (e.shiftKey) {\n bearingDir = -1;\n } else {\n e.preventDefault();\n xDir = -1;\n }\n break;\n\n case 39:\n if (e.shiftKey) {\n bearingDir = 1;\n } else {\n e.preventDefault();\n xDir = 1;\n }\n break;\n\n case 38:\n if (e.shiftKey) {\n pitchDir = 1;\n } else {\n e.preventDefault();\n yDir = -1;\n }\n break;\n\n case 40:\n if (e.shiftKey) {\n pitchDir = -1;\n } else {\n e.preventDefault();\n yDir = 1;\n }\n break;\n\n default:\n return;\n }\n\n if (this._rotationDisabled) {\n bearingDir = 0;\n pitchDir = 0;\n }\n\n return {\n cameraAnimation: (map: Map) => {\n const tr = this._tr;\n map.easeTo({\n duration: 300,\n easeId: 'keyboardHandler',\n easing: easeOut,\n\n zoom: zoomDir ? Math.round(tr.zoom) + zoomDir * (e.shiftKey ? 2 : 1) : tr.zoom,\n bearing: tr.bearing + bearingDir * this._bearingStep,\n pitch: tr.pitch + pitchDir * this._pitchStep,\n offset: [-xDir * this._panStep, -yDir * this._panStep],\n center: tr.center\n }, {originalEvent: e});\n }\n };\n }\n\n /**\n * Enables the \"keyboard rotate and zoom\" interaction.\n *\n * @example\n * ```ts\n * map.keyboard.enable();\n * ```\n */\n enable() {\n this._enabled = true;\n }\n\n /**\n * Disables the \"keyboard rotate and zoom\" interaction.\n *\n * @example\n * ```ts\n * map.keyboard.disable();\n * ```\n */\n disable() {\n this._enabled = false;\n this.reset();\n }\n\n /**\n * Returns a Boolean indicating whether the \"keyboard rotate and zoom\"\n * interaction is enabled.\n *\n * @returns `true` if the \"keyboard rotate and zoom\"\n * interaction is enabled.\n */\n isEnabled() {\n return this._enabled;\n }\n\n /**\n * Returns true if the handler is enabled and has detected the start of a\n * zoom/rotate gesture.\n *\n * @returns `true` if the handler is enabled and has detected the\n * start of a zoom/rotate gesture.\n */\n isActive() {\n return this._active;\n }\n\n /**\n * Disables the \"keyboard pan/rotate\" interaction, leaving the\n * \"keyboard zoom\" interaction enabled.\n *\n * @example\n * ```ts\n * map.keyboard.disableRotation();\n * ```\n */\n disableRotation() {\n this._rotationDisabled = true;\n }\n\n /**\n * Enables the \"keyboard pan/rotate\" interaction.\n *\n * @example\n * ```ts\n * map.keyboard.enable();\n * map.keyboard.enableRotation();\n * ```\n */\n enableRotation() {\n this._rotationDisabled = false;\n }\n}\n\nfunction easeOut(t: number) {\n return t * (2 - t);\n}\n","import {DOM} from '../../util/dom';\n\nimport {defaultEasing, bezier} from '../../util/util';\nimport {browser} from '../../util/browser';\nimport {interpolates} from '@maplibre/maplibre-gl-style-spec';\nimport {LngLat} from '../../geo/lng_lat';\nimport {TransformProvider} from './transform-provider';\n\nimport type {Map} from '../map';\nimport type Point from '@mapbox/point-geometry';\nimport type {AroundCenterOptions} from './two_fingers_touch';\nimport {Handler} from '../handler_manager';\n\n// deltaY value for mouse scroll wheel identification\nconst wheelZoomDelta = 4.000244140625;\n\n// These magic numbers control the rate of zoom. Trackpad events fire at a greater\n// frequency than mouse scroll wheel, so reduce the zoom rate per wheel tick\nconst defaultZoomRate = 1 / 100;\nconst wheelZoomRate = 1 / 450;\n\n// upper bound on how much we scale the map in any single render frame; this\n// is used to limit zoom rate in the case of very fast scrolling\nconst maxScalePerFrame = 2;\n\n/**\n * The `ScrollZoomHandler` allows the user to zoom the map by scrolling.\n *\n * @group Handlers\n */\nexport class ScrollZoomHandler implements Handler {\n _map: Map;\n _tr: TransformProvider;\n _enabled: boolean;\n _active: boolean;\n _zooming: boolean;\n _aroundCenter: boolean;\n _around: LngLat;\n _aroundPoint: Point;\n _type: 'wheel' | 'trackpad' | null;\n _lastValue: number;\n _timeout: ReturnType; // used for delayed-handling of a single wheel movement\n _finishTimeout: ReturnType; // used to delay final '{move,zoom}end' events\n\n _lastWheelEvent: any;\n _lastWheelEventTime: number;\n\n _startZoom: number;\n _targetZoom: number;\n _delta: number;\n _easing: ((a: number) => number);\n _prevEase: {\n start: number;\n duration: number;\n easing: (_: number) => number;\n };\n\n _frameId: boolean;\n _triggerRenderFrame: () => void;\n\n _defaultZoomRate: number;\n _wheelZoomRate: number;\n\n /** @internal */\n constructor(map: Map, triggerRenderFrame: () => void) {\n this._map = map;\n this._tr = new TransformProvider(map);\n this._triggerRenderFrame = triggerRenderFrame;\n\n this._delta = 0;\n\n this._defaultZoomRate = defaultZoomRate;\n this._wheelZoomRate = wheelZoomRate;\n }\n\n /**\n * Set the zoom rate of a trackpad\n * @param zoomRate - 1/100 The rate used to scale trackpad movement to a zoom value.\n * @example\n * Speed up trackpad zoom\n * ```ts\n * map.scrollZoom.setZoomRate(1/25);\n * ```\n */\n setZoomRate(zoomRate: number) {\n this._defaultZoomRate = zoomRate;\n }\n\n /**\n * Set the zoom rate of a mouse wheel\n * @param wheelZoomRate - 1/450 The rate used to scale mouse wheel movement to a zoom value.\n * @example\n * Slow down zoom of mouse wheel\n * ```ts\n * map.scrollZoom.setWheelZoomRate(1/600);\n * ```\n */\n setWheelZoomRate(wheelZoomRate: number) {\n this._wheelZoomRate = wheelZoomRate;\n }\n\n /**\n * Returns a Boolean indicating whether the \"scroll to zoom\" interaction is enabled.\n * @returns `true` if the \"scroll to zoom\" interaction is enabled.\n */\n isEnabled() {\n return !!this._enabled;\n }\n\n /*\n * Active state is turned on and off with every scroll wheel event and is set back to false before the map\n * render is called, so _active is not a good candidate for determining if a scroll zoom animation is in\n * progress.\n */\n isActive() {\n return !!this._active || this._finishTimeout !== undefined;\n }\n\n isZooming() {\n return !!this._zooming;\n }\n\n /**\n * Enables the \"scroll to zoom\" interaction.\n *\n * @param options - Options object.\n * @example\n * ```ts\n * map.scrollZoom.enable();\n * map.scrollZoom.enable({ around: 'center' })\n * ```\n */\n enable(options?: AroundCenterOptions | boolean) {\n if (this.isEnabled()) return;\n this._enabled = true;\n this._aroundCenter = !!options && (options as AroundCenterOptions).around === 'center';\n }\n\n /**\n * Disables the \"scroll to zoom\" interaction.\n *\n * @example\n * ```ts\n * map.scrollZoom.disable();\n * ```\n */\n disable() {\n if (!this.isEnabled()) return;\n this._enabled = false;\n }\n\n /**\n * Determines whether or not the gesture is blocked due to cooperativeGestures.\n */\n _shouldBePrevented(e: WheelEvent) {\n if (!this._map.cooperativeGestures.isEnabled()) {\n return false;\n }\n\n const isTrackpadPinch = e.ctrlKey;\n const isBypassed = isTrackpadPinch || this._map.cooperativeGestures.isBypassed(e);\n\n return !isBypassed;\n }\n\n wheel(e: WheelEvent) {\n if (!this.isEnabled()) return;\n if (this._shouldBePrevented(e)) {\n this._map.cooperativeGestures.notifyGestureBlocked('wheel_zoom', e);\n return;\n }\n let value = e.deltaMode === WheelEvent.DOM_DELTA_LINE ? e.deltaY * 40 : e.deltaY;\n const now = browser.now(),\n timeDelta = now - (this._lastWheelEventTime || 0);\n\n this._lastWheelEventTime = now;\n\n if (value !== 0 && (value % wheelZoomDelta) === 0) {\n // This one is definitely a mouse wheel event.\n this._type = 'wheel';\n\n } else if (value !== 0 && Math.abs(value) < 4) {\n // This one is definitely a trackpad event because it is so small.\n this._type = 'trackpad';\n\n } else if (timeDelta > 400) {\n // This is likely a new scroll action.\n this._type = null;\n this._lastValue = value;\n\n // Start a timeout in case this was a singular event, and delay it by up to 40ms.\n this._timeout = setTimeout(this._onTimeout, 40, e);\n\n } else if (!this._type) {\n // This is a repeating event, but we don't know the type of event just yet.\n // If the delta per time is small, we assume it's a fast trackpad; otherwise we switch into wheel mode.\n this._type = (Math.abs(timeDelta * value) < 200) ? 'trackpad' : 'wheel';\n\n // Make sure our delayed event isn't fired again, because we accumulate\n // the previous event (which was less than 40ms ago) into this event.\n if (this._timeout) {\n clearTimeout(this._timeout);\n this._timeout = null;\n value += this._lastValue;\n }\n }\n\n // Slow down zoom if shift key is held for more precise zooming\n if (e.shiftKey && value) value = value / 4;\n\n // Only fire the callback if we actually know what type of scrolling device the user uses.\n if (this._type) {\n this._lastWheelEvent = e;\n this._delta -= value;\n if (!this._active) {\n this._start(e);\n }\n }\n\n e.preventDefault();\n }\n\n _onTimeout = (initialEvent: MouseEvent) => {\n this._type = 'wheel';\n this._delta -= this._lastValue;\n if (!this._active) {\n this._start(initialEvent);\n }\n };\n\n _start(e: MouseEvent) {\n if (!this._delta) return;\n\n if (this._frameId) {\n this._frameId = null;\n }\n\n this._active = true;\n if (!this.isZooming()) {\n this._zooming = true;\n }\n\n if (this._finishTimeout) {\n clearTimeout(this._finishTimeout);\n delete this._finishTimeout;\n }\n\n const pos = DOM.mousePos(this._map.getCanvas(), e);\n const tr = this._tr;\n\n if (pos.y > tr.transform.height / 2 - tr.transform.getHorizon()) {\n this._around = LngLat.convert(this._aroundCenter ? tr.center : tr.unproject(pos));\n } else {\n // Do not use current cursor position if above the horizon to avoid 'unproject' this point\n // as it is not mapped into 'coords' framebuffer or inversible with 'pixelMatrixInverse'.\n this._around = LngLat.convert(tr.center);\n }\n\n this._aroundPoint = tr.transform.locationPoint(this._around);\n if (!this._frameId) {\n this._frameId = true;\n this._triggerRenderFrame();\n }\n }\n\n renderFrame() {\n if (!this._frameId) return;\n this._frameId = null;\n\n if (!this.isActive()) return;\n const tr = this._tr.transform;\n\n // if we've had scroll events since the last render frame, consume the\n // accumulated delta, and update the target zoom level accordingly\n if (this._delta !== 0) {\n // For trackpad events and single mouse wheel ticks, use the default zoom rate\n const zoomRate = (this._type === 'wheel' && Math.abs(this._delta) > wheelZoomDelta) ? this._wheelZoomRate : this._defaultZoomRate;\n // Scale by sigmoid of scroll wheel delta.\n let scale = maxScalePerFrame / (1 + Math.exp(-Math.abs(this._delta * zoomRate)));\n\n if (this._delta < 0 && scale !== 0) {\n scale = 1 / scale;\n }\n\n const fromScale = typeof this._targetZoom === 'number' ? tr.zoomScale(this._targetZoom) : tr.scale;\n this._targetZoom = Math.min(tr.maxZoom, Math.max(tr.minZoom, tr.scaleZoom(fromScale * scale)));\n\n // if this is a mouse wheel, refresh the starting zoom and easing\n // function we're using to smooth out the zooming between wheel\n // events\n if (this._type === 'wheel') {\n this._startZoom = tr.zoom;\n this._easing = this._smoothOutEasing(200);\n }\n\n this._delta = 0;\n }\n\n const targetZoom = typeof this._targetZoom === 'number' ?\n this._targetZoom : tr.zoom;\n const startZoom = this._startZoom;\n const easing = this._easing;\n\n let finished = false;\n let zoom;\n\n const lastWheelEventTimeDiff = browser.now() - this._lastWheelEventTime;\n if (this._type === 'wheel' && startZoom && easing && lastWheelEventTimeDiff) {\n const t = Math.min(lastWheelEventTimeDiff / 200, 1);\n\n const k = easing(t);\n zoom = interpolates.number(startZoom, targetZoom, k);\n if (t < 1) {\n if (!this._frameId) {\n this._frameId = true;\n }\n } else {\n finished = true;\n }\n } else {\n zoom = targetZoom;\n finished = true;\n }\n\n this._active = true;\n\n if (finished) {\n this._active = false;\n this._finishTimeout = setTimeout(() => {\n this._zooming = false;\n this._triggerRenderFrame();\n delete this._targetZoom;\n delete this._finishTimeout;\n }, 200);\n }\n\n return {\n noInertia: true,\n needsRenderFrame: !finished,\n zoomDelta: zoom - tr.zoom,\n around: this._aroundPoint,\n originalEvent: this._lastWheelEvent\n };\n }\n\n _smoothOutEasing(duration: number) {\n let easing = defaultEasing;\n\n if (this._prevEase) {\n const currentEase = this._prevEase;\n const t = (browser.now() - currentEase.start) / currentEase.duration;\n const speed = currentEase.easing(t + 0.01) - currentEase.easing(t);\n\n // Quick hack to make new bezier that is continuous with last\n const x = 0.27 / Math.sqrt(speed * speed + 0.0001) * 0.01;\n const y = Math.sqrt(0.27 * 0.27 - x * x);\n\n easing = bezier(x, y, 0.25, 1);\n }\n\n this._prevEase = {\n start: browser.now(),\n duration,\n easing\n };\n\n return easing;\n }\n\n reset() {\n this._active = false;\n this._zooming = false;\n delete this._targetZoom;\n if (this._finishTimeout) {\n clearTimeout(this._finishTimeout);\n delete this._finishTimeout;\n }\n }\n}\n","import type {ClickZoomHandler} from '../click_zoom';\nimport type {TapZoomHandler} from './../tap_zoom';\n\n/**\n * The `DoubleClickZoomHandler` allows the user to zoom the map at a point by\n * double clicking or double tapping.\n *\n * @group Handlers\n */\nexport class DoubleClickZoomHandler {\n\n _clickZoom: ClickZoomHandler;\n _tapZoom: TapZoomHandler;\n\n /** @internal */\n constructor(clickZoom: ClickZoomHandler, TapZoom: TapZoomHandler) {\n this._clickZoom = clickZoom;\n this._tapZoom = TapZoom;\n }\n\n /**\n * Enables the \"double click to zoom\" interaction.\n *\n * @example\n * ```ts\n * map.doubleClickZoom.enable();\n * ```\n */\n enable() {\n this._clickZoom.enable();\n this._tapZoom.enable();\n }\n\n /**\n * Disables the \"double click to zoom\" interaction.\n *\n * @example\n * ```ts\n * map.doubleClickZoom.disable();\n * ```\n */\n disable() {\n this._clickZoom.disable();\n this._tapZoom.disable();\n }\n\n /**\n * Returns a Boolean indicating whether the \"double click to zoom\" interaction is enabled.\n *\n * @returns `true` if the \"double click to zoom\" interaction is enabled.\n */\n isEnabled() {\n return this._clickZoom.isEnabled() && this._tapZoom.isEnabled();\n }\n\n /**\n * Returns a Boolean indicating whether the \"double click to zoom\" interaction is active, i.e. currently being used.\n *\n * @returns `true` if the \"double click to zoom\" interaction is active.\n */\n isActive() {\n return this._clickZoom.isActive() || this._tapZoom.isActive();\n }\n}\n","import type Point from '@mapbox/point-geometry';\nimport type {Map} from '../map';\nimport {TransformProvider} from './transform-provider';\nimport {Handler} from '../handler_manager';\n\n/**\n * The `ClickZoomHandler` allows the user to zoom the map at a point by double clicking\n * It is used by other handlers\n */\nexport class ClickZoomHandler implements Handler {\n\n _tr: TransformProvider;\n _enabled: boolean;\n _active: boolean;\n\n /** @internal */\n constructor(map: Map) {\n this._tr = new TransformProvider(map);\n this.reset();\n }\n\n reset() {\n this._active = false;\n }\n\n dblclick(e: MouseEvent, point: Point) {\n e.preventDefault();\n return {\n cameraAnimation: (map: Map) => {\n map.easeTo({\n duration: 300,\n zoom: this._tr.zoom + (e.shiftKey ? -1 : 1),\n around: this._tr.unproject(point)\n }, {originalEvent: e});\n }\n };\n }\n\n enable() {\n this._enabled = true;\n }\n\n disable() {\n this._enabled = false;\n this.reset();\n }\n\n isEnabled() {\n return this._enabled;\n }\n\n isActive() {\n return this._active;\n }\n}\n","import {Handler} from '../handler_manager';\nimport {TapRecognizer, MAX_TAP_INTERVAL, MAX_DIST} from './tap_recognizer';\nimport type Point from '@mapbox/point-geometry';\n\n/**\n * A `TapDragZoomHandler` allows the user to zoom the map at a point by double tapping. It also allows the user pan the map by dragging.\n */\nexport class TapDragZoomHandler implements Handler {\n\n _enabled: boolean;\n _active: boolean;\n _swipePoint: Point;\n _swipeTouch: number;\n _tapTime: number;\n _tapPoint: Point;\n _tap: TapRecognizer;\n\n constructor() {\n\n this._tap = new TapRecognizer({\n numTouches: 1,\n numTaps: 1\n });\n\n this.reset();\n }\n\n reset() {\n this._active = false;\n delete this._swipePoint;\n delete this._swipeTouch;\n delete this._tapTime;\n delete this._tapPoint;\n this._tap.reset();\n }\n\n touchstart(e: TouchEvent, points: Array, mapTouches: Array) {\n if (this._swipePoint) return;\n\n if (!this._tapTime) {\n this._tap.touchstart(e, points, mapTouches);\n } else {\n const swipePoint = points[0];\n\n const soonEnough = e.timeStamp - this._tapTime < MAX_TAP_INTERVAL;\n const closeEnough = this._tapPoint.dist(swipePoint) < MAX_DIST;\n\n if (!soonEnough || !closeEnough) {\n this.reset();\n } else if (mapTouches.length > 0) {\n this._swipePoint = swipePoint;\n this._swipeTouch = mapTouches[0].identifier;\n }\n }\n }\n\n touchmove(e: TouchEvent, points: Array, mapTouches: Array) {\n if (!this._tapTime) {\n this._tap.touchmove(e, points, mapTouches);\n } else if (this._swipePoint) {\n if (mapTouches[0].identifier !== this._swipeTouch) {\n return;\n }\n\n const newSwipePoint = points[0];\n const dist = newSwipePoint.y - this._swipePoint.y;\n this._swipePoint = newSwipePoint;\n\n e.preventDefault();\n this._active = true;\n\n return {\n zoomDelta: dist / 128\n };\n }\n }\n\n touchend(e: TouchEvent, points: Array, mapTouches: Array) {\n if (!this._tapTime) {\n const point = this._tap.touchend(e, points, mapTouches);\n if (point) {\n this._tapTime = e.timeStamp;\n this._tapPoint = point;\n }\n } else if (this._swipePoint) {\n if (mapTouches.length === 0) {\n this.reset();\n }\n }\n }\n\n touchcancel() {\n this.reset();\n }\n\n enable() {\n this._enabled = true;\n }\n\n disable() {\n this._enabled = false;\n this.reset();\n }\n\n isEnabled() {\n return this._enabled;\n }\n\n isActive() {\n return this._active;\n }\n}\n","import type {MousePanHandler} from '../mouse';\nimport type {TouchPanHandler} from './../touch_pan';\n\n/**\n * A {@link DragPanHandler} options object\n */\nexport type DragPanOptions = {\n /**\n * factor used to scale the drag velocity\n * @defaultValue 0\n */\n linearity?: number;\n /**\n * easing function applied to `map.panTo` when applying the drag.\n * @param t - the easing function\n * @defaultValue bezier(0, 0, 0.3, 1)\n */\n easing?: (t: number) => number;\n /**\n * the maximum value of the drag velocity.\n * @defaultValue 1400\n */\n deceleration?: number;\n /**\n * the rate at which the speed reduces after the pan ends.\n * @defaultValue 2500\n */\n maxSpeed?: number;\n};\n\n/**\n * The `DragPanHandler` allows the user to pan the map by clicking and dragging\n * the cursor.\n *\n * @group Handlers\n */\nexport class DragPanHandler {\n\n _el: HTMLElement;\n _mousePan: MousePanHandler;\n _touchPan: TouchPanHandler;\n _inertiaOptions: DragPanOptions | boolean;\n\n /** @internal */\n constructor(el: HTMLElement, mousePan: MousePanHandler, touchPan: TouchPanHandler) {\n this._el = el;\n this._mousePan = mousePan;\n this._touchPan = touchPan;\n }\n\n /**\n * Enables the \"drag to pan\" interaction.\n *\n * @param options - Options object\n * @example\n * ```ts\n * map.dragPan.enable();\n * map.dragPan.enable({\n * linearity: 0.3,\n * easing: bezier(0, 0, 0.3, 1),\n * maxSpeed: 1400,\n * deceleration: 2500,\n * });\n * ```\n */\n enable(options?: DragPanOptions | boolean) {\n this._inertiaOptions = options || {};\n this._mousePan.enable();\n this._touchPan.enable();\n this._el.classList.add('maplibregl-touch-drag-pan');\n }\n\n /**\n * Disables the \"drag to pan\" interaction.\n *\n * @example\n * ```ts\n * map.dragPan.disable();\n * ```\n */\n disable() {\n this._mousePan.disable();\n this._touchPan.disable();\n this._el.classList.remove('maplibregl-touch-drag-pan');\n }\n\n /**\n * Returns a Boolean indicating whether the \"drag to pan\" interaction is enabled.\n *\n * @returns `true` if the \"drag to pan\" interaction is enabled.\n */\n isEnabled() {\n return this._mousePan.isEnabled() && this._touchPan.isEnabled();\n }\n\n /**\n * Returns a Boolean indicating whether the \"drag to pan\" interaction is active, i.e. currently being used.\n *\n * @returns `true` if the \"drag to pan\" interaction is active.\n */\n isActive() {\n return this._mousePan.isActive() || this._touchPan.isActive();\n }\n}\n","import type {MousePitchHandler, MouseRotateHandler} from '../mouse';\n\n/**\n * Options object for `DragRotateHandler`.\n */\nexport type DragRotateHandlerOptions = {\n /**\n * Control the map pitch in addition to the bearing\n * @defaultValue true\n */\n pitchWithRotate: boolean;\n}\n\n/**\n * The `DragRotateHandler` allows the user to rotate the map by clicking and\n * dragging the cursor while holding the right mouse button or `ctrl` key.\n *\n * @group Handlers\n */\nexport class DragRotateHandler {\n\n _mouseRotate: MouseRotateHandler;\n _mousePitch: MousePitchHandler;\n _pitchWithRotate: boolean;\n\n /** @internal */\n constructor(options: DragRotateHandlerOptions, mouseRotate: MouseRotateHandler, mousePitch: MousePitchHandler) {\n this._pitchWithRotate = options.pitchWithRotate;\n this._mouseRotate = mouseRotate;\n this._mousePitch = mousePitch;\n }\n\n /**\n * Enables the \"drag to rotate\" interaction.\n *\n * @example\n * ```ts\n * map.dragRotate.enable();\n * ```\n */\n enable() {\n this._mouseRotate.enable();\n if (this._pitchWithRotate) this._mousePitch.enable();\n }\n\n /**\n * Disables the \"drag to rotate\" interaction.\n *\n * @example\n * ```ts\n * map.dragRotate.disable();\n * ```\n */\n disable() {\n this._mouseRotate.disable();\n this._mousePitch.disable();\n }\n\n /**\n * Returns a Boolean indicating whether the \"drag to rotate\" interaction is enabled.\n *\n * @returns `true` if the \"drag to rotate\" interaction is enabled.\n */\n isEnabled() {\n return this._mouseRotate.isEnabled() && (!this._pitchWithRotate || this._mousePitch.isEnabled());\n }\n\n /**\n * Returns a Boolean indicating whether the \"drag to rotate\" interaction is active, i.e. currently being used.\n *\n * @returns `true` if the \"drag to rotate\" interaction is active.\n */\n isActive() {\n return this._mouseRotate.isActive() || this._mousePitch.isActive();\n }\n}\n","import type {TwoFingersTouchZoomHandler, TwoFingersTouchRotateHandler, AroundCenterOptions} from '../two_fingers_touch';\nimport type {TapDragZoomHandler} from '../tap_drag_zoom';\n\n/**\n * The `TwoFingersTouchZoomRotateHandler` allows the user to zoom and rotate the map by\n * pinching on a touchscreen.\n *\n * They can zoom with one finger by double tapping and dragging. On the second tap,\n * hold the finger down and drag up or down to zoom in or out.\n *\n * @group Handlers\n */\nexport class TwoFingersTouchZoomRotateHandler {\n\n _el: HTMLElement;\n _touchZoom: TwoFingersTouchZoomHandler;\n _touchRotate: TwoFingersTouchRotateHandler;\n _tapDragZoom: TapDragZoomHandler;\n _rotationDisabled: boolean;\n _enabled: boolean;\n\n /** @internal */\n constructor(el: HTMLElement, touchZoom: TwoFingersTouchZoomHandler, touchRotate: TwoFingersTouchRotateHandler, tapDragZoom: TapDragZoomHandler) {\n this._el = el;\n this._touchZoom = touchZoom;\n this._touchRotate = touchRotate;\n this._tapDragZoom = tapDragZoom;\n this._rotationDisabled = false;\n this._enabled = true;\n }\n\n /**\n * Enables the \"pinch to rotate and zoom\" interaction.\n *\n * @param options - Options object.\n *\n * @example\n * ```ts\n * map.touchZoomRotate.enable();\n * map.touchZoomRotate.enable({ around: 'center' });\n * ```\n */\n enable(options?: AroundCenterOptions | boolean | null) {\n this._touchZoom.enable(options);\n if (!this._rotationDisabled) this._touchRotate.enable(options);\n this._tapDragZoom.enable();\n this._el.classList.add('maplibregl-touch-zoom-rotate');\n }\n\n /**\n * Disables the \"pinch to rotate and zoom\" interaction.\n *\n * @example\n * ```ts\n * map.touchZoomRotate.disable();\n * ```\n */\n disable() {\n this._touchZoom.disable();\n this._touchRotate.disable();\n this._tapDragZoom.disable();\n this._el.classList.remove('maplibregl-touch-zoom-rotate');\n }\n\n /**\n * Returns a Boolean indicating whether the \"pinch to rotate and zoom\" interaction is enabled.\n *\n * @returns `true` if the \"pinch to rotate and zoom\" interaction is enabled.\n */\n isEnabled() {\n return this._touchZoom.isEnabled() &&\n (this._rotationDisabled || this._touchRotate.isEnabled()) &&\n this._tapDragZoom.isEnabled();\n }\n\n /**\n * Returns true if the handler is enabled and has detected the start of a zoom/rotate gesture.\n *\n * @returns `true` if the handler is active, `false` otherwise\n */\n isActive() {\n return this._touchZoom.isActive() || this._touchRotate.isActive() || this._tapDragZoom.isActive();\n }\n\n /**\n * Disables the \"pinch to rotate\" interaction, leaving the \"pinch to zoom\"\n * interaction enabled.\n *\n * @example\n * ```ts\n * map.touchZoomRotate.disableRotation();\n * ```\n */\n disableRotation() {\n this._rotationDisabled = true;\n this._touchRotate.disable();\n }\n\n /**\n * Enables the \"pinch to rotate\" interaction.\n *\n * @example\n * ```ts\n * map.touchZoomRotate.enable();\n * map.touchZoomRotate.enableRotation();\n * ```\n */\n enableRotation() {\n this._rotationDisabled = false;\n if (this._touchZoom.isEnabled()) this._touchRotate.enable();\n }\n}\n","import {DOM} from '../../util/dom';\nimport {Event} from '../../util/evented';\nimport {Handler} from '../handler_manager';\n\nimport type {Map} from '../map';\n\n/**\n * The {@link CooperativeGesturesHandler} options object for the gesture settings\n */\nexport type GestureOptions = boolean;\n\n/**\n * A `CooperativeGestureHandler` is a control that adds cooperative gesture info when user tries to zoom in/out.\n *\n * When the CooperativeGestureHandler blocks a gesture, it will emit a `cooperativegestureprevented` event.\n *\n * @group Handlers\n *\n * @example\n * ```ts\n * const map = new Map({\n * cooperativeGestures: true\n * });\n * ```\n * @see [Example: cooperative gestures](https://maplibre.org/maplibre-gl-js/docs/examples/cooperative-gestures/)\n **/\nexport class CooperativeGesturesHandler implements Handler {\n _options: GestureOptions;\n _map: Map;\n _container: HTMLElement;\n /**\n * This is the key that will allow to bypass the cooperative gesture protection\n */\n _bypassKey: 'metaKey' | 'ctrlKey' = navigator.userAgent.indexOf('Mac') !== -1 ? 'metaKey' : 'ctrlKey';\n _enabled: boolean;\n\n constructor(map: Map, options: GestureOptions) {\n this._map = map;\n this._options = options;\n this._enabled = false;\n }\n isActive(): boolean {\n return false;\n }\n reset(): void {}\n\n _setupUI() {\n if (this._container) return;\n const mapCanvasContainer = this._map.getCanvasContainer();\n // Add a cooperative gestures class (enable touch-action: pan-x pan-y;)\n mapCanvasContainer.classList.add('maplibregl-cooperative-gestures');\n this._container = DOM.create('div', 'maplibregl-cooperative-gesture-screen', mapCanvasContainer);\n let desktopMessage = this._map._getUIString('CooperativeGesturesHandler.WindowsHelpText');\n if (this._bypassKey === 'metaKey') {\n desktopMessage = this._map._getUIString('CooperativeGesturesHandler.MacHelpText');\n }\n const mobileMessage = this._map._getUIString('CooperativeGesturesHandler.MobileHelpText');\n // Create and append the desktop message div\n const desktopDiv = document.createElement('div');\n desktopDiv.className = 'maplibregl-desktop-message';\n desktopDiv.textContent = desktopMessage;\n this._container.appendChild(desktopDiv);\n // Create and append the mobile message div\n const mobileDiv = document.createElement('div');\n mobileDiv.className = 'maplibregl-mobile-message';\n mobileDiv.textContent = mobileMessage;\n this._container.appendChild(mobileDiv);\n // Remove cooperative gesture screen from the accessibility tree since screenreaders cannot interact with the map using gestures\n this._container.setAttribute('aria-hidden', 'true');\n }\n\n _destroyUI() {\n if (this._container) {\n DOM.remove(this._container);\n const mapCanvasContainer = this._map.getCanvasContainer();\n mapCanvasContainer.classList.remove('maplibregl-cooperative-gestures');\n }\n delete this._container;\n }\n\n enable() {\n this._setupUI();\n this._enabled = true;\n }\n\n disable() {\n this._enabled = false;\n this._destroyUI();\n }\n\n isEnabled() {\n return this._enabled;\n }\n\n isBypassed(event: MouseEvent | WheelEvent | PointerEvent) {\n return event[this._bypassKey];\n }\n\n notifyGestureBlocked(gestureType: 'wheel_zoom' | 'touch_pan', originalEvent: Event) {\n if (!this._enabled) return;\n\n // notify subscribers that a cooperative gesture was prevented\n this._map.fire(new Event('cooperativegestureprevented', {gestureType, originalEvent}));\n\n // Alert user how to scroll/pan\n this._container.classList.add('maplibregl-show');\n setTimeout(() => {\n this._container.classList.remove('maplibregl-show');\n }, 100);\n }\n}\n","import {Event} from '../util/evented';\nimport {DOM} from '../util/dom';\nimport {Map, CompleteMapOptions} from './map';\nimport {HandlerInertia} from './handler_inertia';\nimport {MapEventHandler, BlockableMapEventHandler} from './handler/map_event';\nimport {BoxZoomHandler} from './handler/box_zoom';\nimport {TapZoomHandler} from './handler/tap_zoom';\nimport {generateMouseRotationHandler, generateMousePitchHandler, generateMousePanHandler} from './handler/mouse';\nimport {TouchPanHandler} from './handler/touch_pan';\nimport {TwoFingersTouchZoomHandler, TwoFingersTouchRotateHandler, TwoFingersTouchPitchHandler} from './handler/two_fingers_touch';\nimport {KeyboardHandler} from './handler/keyboard';\nimport {ScrollZoomHandler} from './handler/scroll_zoom';\nimport {DoubleClickZoomHandler} from './handler/shim/dblclick_zoom';\nimport {ClickZoomHandler} from './handler/click_zoom';\nimport {TapDragZoomHandler} from './handler/tap_drag_zoom';\nimport {DragPanHandler} from './handler/shim/drag_pan';\nimport {DragRotateHandler} from './handler/shim/drag_rotate';\nimport {TwoFingersTouchZoomRotateHandler} from './handler/shim/two_fingers_touch';\nimport {CooperativeGesturesHandler} from './handler/cooperative_gestures';\nimport {extend} from '../util/util';\nimport {browser} from '../util/browser';\nimport Point from '@mapbox/point-geometry';\n\nconst isMoving = (p: EventsInProgress) => p.zoom || p.drag || p.pitch || p.rotate;\n\nclass RenderFrameEvent extends Event {\n type: 'renderFrame';\n timeStamp: number;\n}\n\n/**\n * Handlers interpret dom events and return camera changes that should be\n * applied to the map (`HandlerResult`s). The camera changes are all deltas.\n * The handler itself should have no knowledge of the map's current state.\n * This makes it easier to merge multiple results and keeps handlers simpler.\n * For example, if there is a mousedown and mousemove, the mousePan handler\n * would return a `panDelta` on the mousemove.\n */\nexport interface Handler {\n enable(): void;\n disable(): void;\n isEnabled(): boolean;\n /**\n * This is used to indicate if the handler is currently active or not.\n * In case a handler is active, it will block other handlers from getting the relevant events.\n * There is an allow list of handlers that can be active at the same time, which is configured when adding a handler.\n */\n isActive(): boolean;\n /**\n * `reset` can be called by the manager at any time and must reset everything to it's original state\n */\n reset(): void;\n // Handlers can optionally implement these methods.\n // They are called with dom events whenever those dom evens are received.\n readonly touchstart?: (e: TouchEvent, points: Array, mapTouches: Array) => HandlerResult | void;\n readonly touchmove?: (e: TouchEvent, points: Array, mapTouches: Array) => HandlerResult | void;\n readonly touchmoveWindow?: (e: TouchEvent, points: Array, mapTouches: Array) => HandlerResult | void;\n readonly touchend?: (e: TouchEvent, points: Array, mapTouches: Array) => HandlerResult | void;\n readonly touchcancel?: (e: TouchEvent, points: Array, mapTouches: Array) => HandlerResult | void;\n readonly mousedown?: (e: MouseEvent, point: Point) => HandlerResult | void;\n readonly mousemove?: (e: MouseEvent, point: Point) => HandlerResult | void;\n readonly mousemoveWindow?: (e: MouseEvent, point: Point) => HandlerResult | void;\n readonly mouseup?: (e: MouseEvent, point: Point) => HandlerResult | void;\n readonly mouseupWindow?: (e: MouseEvent, point: Point) => HandlerResult | void;\n readonly dblclick?: (e: MouseEvent, point: Point) => HandlerResult | void;\n readonly contextmenu?: (e: MouseEvent) => HandlerResult | void;\n readonly wheel?: (e: WheelEvent, point: Point) => HandlerResult | void;\n readonly keydown?: (e: KeyboardEvent) => HandlerResult | void;\n readonly keyup?: (e: KeyboardEvent) => HandlerResult | void;\n /**\n * `renderFrame` is the only non-dom event. It is called during render\n * frames and can be used to smooth camera changes (see scroll handler).\n */\n readonly renderFrame?: () => HandlerResult | void;\n}\n\n/**\n * All handler methods that are called with events can optionally return a `HandlerResult`.\n */\nexport type HandlerResult = {\n panDelta?: Point;\n zoomDelta?: number;\n bearingDelta?: number;\n pitchDelta?: number;\n /**\n * the point to not move when changing the camera\n */\n around?: Point | null;\n /**\n * same as above, except for pinch actions, which are given higher priority\n */\n pinchAround?: Point | null;\n /**\n * A method that can fire a one-off easing by directly changing the map's camera.\n */\n cameraAnimation?: (map: Map) => any;\n /**\n * The last three properties are needed by only one handler: scrollzoom.\n * The DOM event to be used as the `originalEvent` on any camera change events.\n */\n originalEvent?: Event;\n /**\n * Makes the manager trigger a frame, allowing the handler to return multiple results over time (see scrollzoom).\n */\n needsRenderFrame?: boolean;\n /**\n * The camera changes won't get recorded for inertial zooming.\n */\n noInertia?: boolean;\n};\n\nexport type EventInProgress = {\n handlerName: string;\n originalEvent: Event;\n}\n\nexport type EventsInProgress = {\n zoom?: EventInProgress;\n pitch?: EventInProgress;\n rotate?: EventInProgress;\n drag?: EventInProgress;\n}\n\nfunction hasChange(result: HandlerResult) {\n return (result.panDelta && result.panDelta.mag()) || result.zoomDelta || result.bearingDelta || result.pitchDelta;\n}\n\nexport class HandlerManager {\n _map: Map;\n _el: HTMLElement;\n _handlers: Array<{\n handlerName: string;\n handler: Handler;\n allowed: Array;\n }>;\n _eventsInProgress: EventsInProgress;\n _frameId: number;\n _inertia: HandlerInertia;\n _bearingSnap: number;\n _handlersById: {[x: string]: Handler};\n _updatingCamera: boolean;\n _changes: Array<[HandlerResult, EventsInProgress, {[handlerName: string]: Event}]>;\n _terrainMovement: boolean;\n _zoom: {handlerName: string};\n _previousActiveHandlers: {[x: string]: Handler};\n _listeners: Array<[Window | Document | HTMLElement, string, {\n passive?: boolean;\n capture?: boolean;\n } | undefined]>;\n\n constructor(map: Map, options: CompleteMapOptions) {\n this._map = map;\n this._el = this._map.getCanvasContainer();\n this._handlers = [];\n this._handlersById = {};\n this._changes = [];\n\n this._inertia = new HandlerInertia(map);\n this._bearingSnap = options.bearingSnap;\n this._previousActiveHandlers = {};\n\n // Track whether map is currently moving, to compute start/move/end events\n this._eventsInProgress = {};\n\n this._addDefaultHandlers(options);\n\n const el = this._el;\n\n this._listeners = [\n // This needs to be `passive: true` so that a double tap fires two\n // pairs of touchstart/end events in iOS Safari 13. If this is set to\n // `passive: false` then the second pair of events is only fired if\n // preventDefault() is called on the first touchstart. Calling preventDefault()\n // undesirably prevents click events.\n [el, 'touchstart', {passive: true}],\n // This needs to be `passive: false` so that scrolls and pinches can be\n // prevented in browsers that don't support `touch-actions: none`, for example iOS Safari 12.\n [el, 'touchmove', {passive: false}],\n [el, 'touchend', undefined],\n [el, 'touchcancel', undefined],\n\n [el, 'mousedown', undefined],\n [el, 'mousemove', undefined],\n [el, 'mouseup', undefined],\n\n // Bind window-level event listeners for move and up/end events. In the absence of\n // the pointer capture API, which is not supported by all necessary platforms,\n // window-level event listeners give us the best shot at capturing events that\n // fall outside the map canvas element. Use `{capture: true}` for the move event\n // to prevent map move events from being fired during a drag.\n [document, 'mousemove', {capture: true}],\n [document, 'mouseup', undefined],\n\n [el, 'mouseover', undefined],\n [el, 'mouseout', undefined],\n [el, 'dblclick', undefined],\n [el, 'click', undefined],\n\n [el, 'keydown', {capture: false}],\n [el, 'keyup', undefined],\n\n [el, 'wheel', {passive: false}],\n [el, 'contextmenu', undefined],\n\n [window, 'blur', undefined]\n ];\n\n for (const [target, type, listenerOptions] of this._listeners) {\n DOM.addEventListener(target, type, target === document ? this.handleWindowEvent : this.handleEvent, listenerOptions);\n }\n }\n\n destroy() {\n for (const [target, type, listenerOptions] of this._listeners) {\n DOM.removeEventListener(target, type, target === document ? this.handleWindowEvent : this.handleEvent, listenerOptions);\n }\n }\n\n _addDefaultHandlers(options: CompleteMapOptions) {\n const map = this._map;\n const el = map.getCanvasContainer();\n this._add('mapEvent', new MapEventHandler(map, options));\n\n const boxZoom = map.boxZoom = new BoxZoomHandler(map, options);\n this._add('boxZoom', boxZoom);\n if (options.interactive && options.boxZoom) {\n boxZoom.enable();\n }\n\n const cooperativeGestures = map.cooperativeGestures = new CooperativeGesturesHandler(map, options.cooperativeGestures);\n this._add('cooperativeGestures', cooperativeGestures);\n if (options.cooperativeGestures) {\n cooperativeGestures.enable();\n }\n\n const tapZoom = new TapZoomHandler(map);\n const clickZoom = new ClickZoomHandler(map);\n map.doubleClickZoom = new DoubleClickZoomHandler(clickZoom, tapZoom);\n this._add('tapZoom', tapZoom);\n this._add('clickZoom', clickZoom);\n if (options.interactive && options.doubleClickZoom) {\n map.doubleClickZoom.enable();\n }\n\n const tapDragZoom = new TapDragZoomHandler();\n this._add('tapDragZoom', tapDragZoom);\n\n const touchPitch = map.touchPitch = new TwoFingersTouchPitchHandler(map);\n this._add('touchPitch', touchPitch);\n if (options.interactive && options.touchPitch) {\n map.touchPitch.enable(options.touchPitch);\n }\n\n const mouseRotate = generateMouseRotationHandler(options);\n const mousePitch = generateMousePitchHandler(options);\n map.dragRotate = new DragRotateHandler(options, mouseRotate, mousePitch);\n this._add('mouseRotate', mouseRotate, ['mousePitch']);\n this._add('mousePitch', mousePitch, ['mouseRotate']);\n if (options.interactive && options.dragRotate) {\n map.dragRotate.enable();\n }\n\n const mousePan = generateMousePanHandler(options);\n const touchPan = new TouchPanHandler(options, map);\n map.dragPan = new DragPanHandler(el, mousePan, touchPan);\n this._add('mousePan', mousePan);\n this._add('touchPan', touchPan, ['touchZoom', 'touchRotate']);\n if (options.interactive && options.dragPan) {\n map.dragPan.enable(options.dragPan);\n }\n\n const touchRotate = new TwoFingersTouchRotateHandler();\n const touchZoom = new TwoFingersTouchZoomHandler();\n map.touchZoomRotate = new TwoFingersTouchZoomRotateHandler(el, touchZoom, touchRotate, tapDragZoom);\n this._add('touchRotate', touchRotate, ['touchPan', 'touchZoom']);\n this._add('touchZoom', touchZoom, ['touchPan', 'touchRotate']);\n if (options.interactive && options.touchZoomRotate) {\n map.touchZoomRotate.enable(options.touchZoomRotate);\n }\n\n const scrollZoom = map.scrollZoom = new ScrollZoomHandler(map, () => this._triggerRenderFrame());\n this._add('scrollZoom', scrollZoom, ['mousePan']);\n if (options.interactive && options.scrollZoom) {\n map.scrollZoom.enable(options.scrollZoom);\n }\n\n const keyboard = map.keyboard = new KeyboardHandler(map);\n this._add('keyboard', keyboard);\n if (options.interactive && options.keyboard) {\n map.keyboard.enable();\n }\n\n this._add('blockableMapEvent', new BlockableMapEventHandler(map));\n }\n\n _add(handlerName: string, handler: Handler, allowed?: Array) {\n this._handlers.push({handlerName, handler, allowed});\n this._handlersById[handlerName] = handler;\n }\n\n stop(allowEndAnimation: boolean) {\n // do nothing if this method was triggered by a gesture update\n if (this._updatingCamera) return;\n\n for (const {handler} of this._handlers) {\n handler.reset();\n }\n this._inertia.clear();\n this._fireEvents({}, {}, allowEndAnimation);\n this._changes = [];\n }\n\n isActive() {\n for (const {handler} of this._handlers) {\n if (handler.isActive()) return true;\n }\n return false;\n }\n\n isZooming() {\n return !!this._eventsInProgress.zoom || this._map.scrollZoom.isZooming();\n }\n isRotating() {\n return !!this._eventsInProgress.rotate;\n }\n\n isMoving() {\n return Boolean(isMoving(this._eventsInProgress)) || this.isZooming();\n }\n\n _blockedByActive(activeHandlers: {[x: string]: Handler}, allowed: Array, myName: string) {\n for (const name in activeHandlers) {\n if (name === myName) continue;\n if (!allowed || allowed.indexOf(name) < 0) {\n return true;\n }\n }\n return false;\n }\n\n handleWindowEvent = (e: { type: 'mousemove' | 'mouseup' | 'touchmove'}) => {\n this.handleEvent(e, `${e.type}Window`);\n };\n\n _getMapTouches(touches: TouchList) {\n const mapTouches = [];\n for (const t of touches) {\n const target = (t.target as any as Node);\n if (this._el.contains(target)) {\n mapTouches.push(t);\n }\n }\n return mapTouches as any as TouchList;\n }\n\n handleEvent = (e: Event, eventName?: keyof Handler) => {\n\n if (e.type === 'blur') {\n this.stop(true);\n return;\n }\n\n this._updatingCamera = true;\n\n const inputEvent = e.type === 'renderFrame' ? undefined : e as UIEvent;\n\n /*\n * We don't call e.preventDefault() for any events by default.\n * Handlers are responsible for calling it where necessary.\n */\n\n const mergedHandlerResult: HandlerResult = {needsRenderFrame: false};\n const eventsInProgress: EventsInProgress = {};\n const activeHandlers = {};\n const eventTouches = (e as TouchEvent).touches;\n\n const mapTouches = eventTouches ? this._getMapTouches(eventTouches) : undefined;\n const points = mapTouches ?\n DOM.touchPos(this._map.getCanvas(), mapTouches) :\n DOM.mousePos(this._map.getCanvas(), ((e as MouseEvent)));\n\n for (const {handlerName, handler, allowed} of this._handlers) {\n if (!handler.isEnabled()) continue;\n\n let data: HandlerResult;\n if (this._blockedByActive(activeHandlers, allowed, handlerName)) {\n handler.reset();\n\n } else {\n if (handler[eventName || e.type]) {\n data = handler[eventName || e.type](e, points, mapTouches);\n this.mergeHandlerResult(mergedHandlerResult, eventsInProgress, data, handlerName, inputEvent);\n if (data && data.needsRenderFrame) {\n this._triggerRenderFrame();\n }\n }\n }\n\n if (data || handler.isActive()) {\n activeHandlers[handlerName] = handler;\n }\n }\n\n const deactivatedHandlers: {[handlerName: string]: Event} = {};\n for (const name in this._previousActiveHandlers) {\n if (!activeHandlers[name]) {\n deactivatedHandlers[name] = inputEvent;\n }\n }\n this._previousActiveHandlers = activeHandlers;\n\n if (Object.keys(deactivatedHandlers).length || hasChange(mergedHandlerResult)) {\n this._changes.push([mergedHandlerResult, eventsInProgress, deactivatedHandlers]);\n this._triggerRenderFrame();\n }\n\n if (Object.keys(activeHandlers).length || hasChange(mergedHandlerResult)) {\n this._map._stop(true);\n }\n\n this._updatingCamera = false;\n\n const {cameraAnimation} = mergedHandlerResult;\n if (cameraAnimation) {\n this._inertia.clear();\n this._fireEvents({}, {}, true);\n this._changes = [];\n cameraAnimation(this._map);\n }\n };\n\n mergeHandlerResult(mergedHandlerResult: HandlerResult,\n eventsInProgress: EventsInProgress,\n handlerResult: HandlerResult,\n name: string,\n e?: UIEvent) {\n if (!handlerResult) return;\n\n extend(mergedHandlerResult, handlerResult);\n\n const eventData = {handlerName: name, originalEvent: handlerResult.originalEvent || e};\n\n // track which handler changed which camera property\n if (handlerResult.zoomDelta !== undefined) {\n eventsInProgress.zoom = eventData;\n }\n if (handlerResult.panDelta !== undefined) {\n eventsInProgress.drag = eventData;\n }\n if (handlerResult.pitchDelta !== undefined) {\n eventsInProgress.pitch = eventData;\n }\n if (handlerResult.bearingDelta !== undefined) {\n eventsInProgress.rotate = eventData;\n }\n\n }\n\n _applyChanges() {\n const combined: HandlerResult = {};\n const combinedEventsInProgress: EventsInProgress = {};\n const combinedDeactivatedHandlers = {};\n\n for (const [change, eventsInProgress, deactivatedHandlers] of this._changes) {\n\n if (change.panDelta) combined.panDelta = (combined.panDelta || new Point(0, 0))._add(change.panDelta);\n if (change.zoomDelta) combined.zoomDelta = (combined.zoomDelta || 0) + change.zoomDelta;\n if (change.bearingDelta) combined.bearingDelta = (combined.bearingDelta || 0) + change.bearingDelta;\n if (change.pitchDelta) combined.pitchDelta = (combined.pitchDelta || 0) + change.pitchDelta;\n if (change.around !== undefined) combined.around = change.around;\n if (change.pinchAround !== undefined) combined.pinchAround = change.pinchAround;\n if (change.noInertia) combined.noInertia = change.noInertia;\n\n extend(combinedEventsInProgress, eventsInProgress);\n extend(combinedDeactivatedHandlers, deactivatedHandlers);\n }\n\n this._updateMapTransform(combined, combinedEventsInProgress, combinedDeactivatedHandlers);\n this._changes = [];\n }\n\n _updateMapTransform(combinedResult: HandlerResult,\n combinedEventsInProgress: EventsInProgress,\n deactivatedHandlers: {[handlerName: string]: Event}) {\n const map = this._map;\n const tr = map._getTransformForUpdate();\n const terrain = map.terrain;\n\n if (!hasChange(combinedResult) && !(terrain && this._terrainMovement)) {\n return this._fireEvents(combinedEventsInProgress, deactivatedHandlers, true);\n }\n\n let {panDelta, zoomDelta, bearingDelta, pitchDelta, around, pinchAround} = combinedResult;\n\n if (pinchAround !== undefined) {\n around = pinchAround;\n }\n\n // stop any ongoing camera animations (easeTo, flyTo)\n map._stop(true);\n\n around = around || map.transform.centerPoint;\n const loc = tr.pointLocation(panDelta ? around.sub(panDelta) : around);\n if (bearingDelta) tr.bearing += bearingDelta;\n if (pitchDelta) tr.pitch += pitchDelta;\n if (zoomDelta) tr.zoom += zoomDelta;\n\n if (!terrain) {\n tr.setLocationAtPoint(loc, around);\n } else {\n // when 3d-terrain is enabled act a little different:\n // - dragging do not drag the picked point itself, instead it drags the map by pixel-delta.\n // With this approach it is no longer possible to pick a point from somewhere near\n // the horizon to the center in one move.\n // So this logic avoids the problem, that in such cases you easily loose orientation.\n if (!this._terrainMovement &&\n (combinedEventsInProgress.drag || combinedEventsInProgress.zoom)) {\n // When starting to drag or move, flag it and register moveend to clear flagging\n this._terrainMovement = true;\n this._map._elevationFreeze = true;\n tr.setLocationAtPoint(loc, around);\n } else if (combinedEventsInProgress.drag && this._terrainMovement) {\n // drag map\n tr.center = tr.pointLocation(tr.centerPoint.sub(panDelta));\n } else {\n tr.setLocationAtPoint(loc, around);\n }\n }\n\n map._applyUpdatedTransform(tr);\n\n this._map._update();\n if (!combinedResult.noInertia) this._inertia.record(combinedResult);\n this._fireEvents(combinedEventsInProgress, deactivatedHandlers, true);\n\n }\n\n _fireEvents(newEventsInProgress: EventsInProgress, deactivatedHandlers: {[handlerName: string]: Event}, allowEndAnimation: boolean) {\n\n const wasMoving = isMoving(this._eventsInProgress);\n const nowMoving = isMoving(newEventsInProgress);\n\n const startEvents = {};\n\n for (const eventName in newEventsInProgress) {\n const {originalEvent} = newEventsInProgress[eventName];\n if (!this._eventsInProgress[eventName]) {\n startEvents[`${eventName}start`] = originalEvent;\n }\n this._eventsInProgress[eventName] = newEventsInProgress[eventName];\n }\n\n // fire start events only after this._eventsInProgress has been updated\n if (!wasMoving && nowMoving) {\n this._fireEvent('movestart', nowMoving.originalEvent);\n }\n\n for (const name in startEvents) {\n this._fireEvent(name, startEvents[name]);\n }\n\n if (nowMoving) {\n this._fireEvent('move', nowMoving.originalEvent);\n }\n\n for (const eventName in newEventsInProgress) {\n const {originalEvent} = newEventsInProgress[eventName];\n this._fireEvent(eventName, originalEvent);\n }\n\n const endEvents = {};\n\n let originalEndEvent;\n for (const eventName in this._eventsInProgress) {\n const {handlerName, originalEvent} = this._eventsInProgress[eventName];\n if (!this._handlersById[handlerName].isActive()) {\n delete this._eventsInProgress[eventName];\n originalEndEvent = deactivatedHandlers[handlerName] || originalEvent;\n endEvents[`${eventName}end`] = originalEndEvent;\n }\n }\n\n for (const name in endEvents) {\n this._fireEvent(name, endEvents[name]);\n }\n\n const stillMoving = isMoving(this._eventsInProgress);\n const finishedMoving = (wasMoving || nowMoving) && !stillMoving;\n if (finishedMoving && this._terrainMovement) {\n this._map._elevationFreeze = false;\n this._terrainMovement = false;\n const tr = this._map._getTransformForUpdate();\n tr.recalculateZoom(this._map.terrain);\n this._map._applyUpdatedTransform(tr);\n }\n if (allowEndAnimation && finishedMoving) {\n this._updatingCamera = true;\n const inertialEase = this._inertia._onMoveEnd(this._map.dragPan._inertiaOptions);\n\n const shouldSnapToNorth = bearing => bearing !== 0 && -this._bearingSnap < bearing && bearing < this._bearingSnap;\n\n if (inertialEase && (inertialEase.essential || !browser.prefersReducedMotion)) {\n if (shouldSnapToNorth(inertialEase.bearing || this._map.getBearing())) {\n inertialEase.bearing = 0;\n }\n inertialEase.freezeElevation = true;\n this._map.easeTo(inertialEase, {originalEvent: originalEndEvent});\n } else {\n this._map.fire(new Event('moveend', {originalEvent: originalEndEvent}));\n if (shouldSnapToNorth(this._map.getBearing())) {\n this._map.resetNorth();\n }\n }\n this._updatingCamera = false;\n }\n\n }\n\n _fireEvent(type: string, e?: Event) {\n this._map.fire(new Event(type, e ? {originalEvent: e} : {}));\n }\n\n _requestFrame() {\n this._map.triggerRepaint();\n return this._map._renderTaskQueue.add(timeStamp => {\n delete this._frameId;\n this.handleEvent(new RenderFrameEvent('renderFrame', {timeStamp}));\n this._applyChanges();\n });\n }\n\n _triggerRenderFrame() {\n if (this._frameId === undefined) {\n this._frameId = this._requestFrame();\n }\n }\n}\n","import {extend, warnOnce, clamp, wrap, defaultEasing, pick, degreesToRadians} from '../util/util';\nimport {interpolates} from '@maplibre/maplibre-gl-style-spec';\nimport {browser} from '../util/browser';\nimport {LngLat} from '../geo/lng_lat';\nimport {LngLatBounds} from '../geo/lng_lat_bounds';\nimport Point from '@mapbox/point-geometry';\nimport {Event, Evented} from '../util/evented';\nimport {Terrain} from '../render/terrain';\nimport {MercatorCoordinate} from '../geo/mercator_coordinate';\n\nimport type {Transform} from '../geo/transform';\nimport type {LngLatLike} from '../geo/lng_lat';\nimport type {LngLatBoundsLike} from '../geo/lng_lat_bounds';\nimport type {TaskID} from '../util/task_queue';\nimport type {PaddingOptions} from '../geo/edge_insets';\nimport type {HandlerManager} from './handler_manager';\n/**\n * A [Point](https://github.com/mapbox/point-geometry) or an array of two numbers representing `x` and `y` screen coordinates in pixels.\n *\n * @group Geography and Geometry\n *\n * @example\n * ```ts\n * let p1 = new Point(-77, 38); // a PointLike which is a Point\n * let p2 = [-77, 38]; // a PointLike which is an array of two numbers\n * ```\n */\nexport type PointLike = Point | [number, number];\n\n/**\n * A helper to allow require of at least one property\n */\nexport type RequireAtLeastOne = { [K in keyof T]-?: Required> & Partial>>; }[keyof T];\n\n/**\n * Options common to {@link Map#jumpTo}, {@link Map#easeTo}, and {@link Map#flyTo}, controlling the desired location,\n * zoom, bearing, and pitch of the camera. All properties are optional, and when a property is omitted, the current\n * camera value for that property will remain unchanged.\n *\n * @example\n * Set the map's initial perspective with CameraOptions\n * ```ts\n * let map = new Map({\n * container: 'map',\n * style: 'https://demotiles.maplibre.org/style.json',\n * center: [-73.5804, 45.53483],\n * pitch: 60,\n * bearing: -60,\n * zoom: 10\n * });\n * ```\n * @see [Set pitch and bearing](https://maplibre.org/maplibre-gl-js/docs/examples/set-perspective/)\n * @see [Jump to a series of locations](https://maplibre.org/maplibre-gl-js/docs/examples/jump-to/)\n * @see [Fly to a location](https://maplibre.org/maplibre-gl-js/docs/examples/flyto/)\n * @see [Display buildings in 3D](https://maplibre.org/maplibre-gl-js/docs/examples/3d-buildings/)\n */\nexport type CameraOptions = CenterZoomBearing & {\n /**\n * The desired pitch in degrees. The pitch is the angle towards the horizon\n * measured in degrees with a range between 0 and 60 degrees. For example, pitch: 0 provides the appearance\n * of looking straight down at the map, while pitch: 60 tilts the user's perspective towards the horizon.\n * Increasing the pitch value is often used to display 3D objects.\n */\n pitch?: number;\n /**\n * If `zoom` is specified, `around` determines the point around which the zoom is centered.\n */\n around?: LngLatLike;\n};\n\n/**\n * Holds center, zoom and bearing properties\n */\nexport type CenterZoomBearing = {\n /**\n * The desired center.\n */\n center?: LngLatLike;\n /**\n * The desired zoom level.\n */\n zoom?: number;\n /**\n * The desired bearing in degrees. The bearing is the compass direction that\n * is \"up\". For example, `bearing: 90` orients the map so that east is up.\n */\n bearing?: number;\n}\n\n/**\n * The options object related to the {@link Map#jumpTo} method\n */\nexport type JumpToOptions = CameraOptions & {\n /**\n * Dimensions in pixels applied on each side of the viewport for shifting the vanishing point.\n */\n padding?: PaddingOptions;\n}\n\n/**\n * A options object for the {@link Map#cameraForBounds} method\n */\nexport type CameraForBoundsOptions = CameraOptions & {\n /**\n * The amount of padding in pixels to add to the given bounds.\n */\n padding?: number | RequireAtLeastOne;\n /**\n * The center of the given bounds relative to the map's center, measured in pixels.\n * @defaultValue [0, 0]\n */\n offset?: PointLike;\n /**\n * The maximum zoom level to allow when the camera would transition to the specified bounds.\n */\n maxZoom?: number;\n}\n\n/**\n * The {@link Map#flyTo} options object\n */\nexport type FlyToOptions = AnimationOptions & CameraOptions & {\n /**\n * The zooming \"curve\" that will occur along the\n * flight path. A high value maximizes zooming for an exaggerated animation, while a low\n * value minimizes zooming for an effect closer to {@link Map#easeTo}. 1.42 is the average\n * value selected by participants in the user study discussed in\n * [van Wijk (2003)](https://www.win.tue.nl/~vanwijk/zoompan.pdf). A value of\n * `Math.pow(6, 0.25)` would be equivalent to the root mean squared average velocity. A\n * value of 1 would produce a circular motion.\n * @defaultValue 1.42\n */\n curve?: number;\n /**\n * The zero-based zoom level at the peak of the flight path. If\n * `options.curve` is specified, this option is ignored.\n */\n minZoom?: number;\n /**\n * The average speed of the animation defined in relation to\n * `options.curve`. A speed of 1.2 means that the map appears to move along the flight path\n * by 1.2 times `options.curve` screenfuls every second. A _screenful_ is the map's visible span.\n * It does not correspond to a fixed physical distance, but varies by zoom level.\n * @defaultValue 1.2\n */\n speed?: number;\n /**\n * The average speed of the animation measured in screenfuls\n * per second, assuming a linear timing curve. If `options.speed` is specified, this option is ignored.\n */\n screenSpeed?: number;\n /**\n * The animation's maximum duration, measured in milliseconds.\n * If duration exceeds maximum duration, it resets to 0.\n */\n maxDuration?: number;\n /**\n * The amount of padding in pixels to add to the given bounds.\n */\n padding?: number | RequireAtLeastOne;\n}\n\nexport type EaseToOptions = AnimationOptions & CameraOptions & {\n delayEndEvents?: number;\n padding?: number | RequireAtLeastOne;\n}\n\n/**\n * Options for {@link Map#fitBounds} method\n */\nexport type FitBoundsOptions = FlyToOptions & {\n /**\n * If `true`, the map transitions using {@link Map#easeTo}. If `false`, the map transitions using {@link Map#flyTo}.\n * See those functions and {@link AnimationOptions} for information about options available.\n * @defaultValue false\n */\n linear?: boolean;\n /**\n * The center of the given bounds relative to the map's center, measured in pixels.\n * @defaultValue [0, 0]\n */\n offset?: PointLike;\n /**\n * The maximum zoom level to allow when the map view transitions to the specified bounds.\n */\n maxZoom?: number;\n}\n\n/**\n * Options common to map movement methods that involve animation, such as {@link Map#panBy} and\n * {@link Map#easeTo}, controlling the duration and easing function of the animation. All properties\n * are optional.\n *\n */\nexport type AnimationOptions = {\n /**\n * The animation's duration, measured in milliseconds.\n */\n duration?: number;\n /**\n * A function taking a time in the range 0..1 and returning a number where 0 is\n * the initial state and 1 is the final state.\n */\n easing?: (_: number) => number;\n /**\n * of the target center relative to real map container center at the end of animation.\n */\n offset?: PointLike;\n /**\n * If `false`, no animation will occur.\n */\n animate?: boolean;\n /**\n * If `true`, then the animation is considered essential and will not be affected by\n * [`prefers-reduced-motion`](https://developer.mozilla.org/en-US/docs/Web/CSS/\\@media/prefers-reduced-motion).\n */\n essential?: boolean;\n /**\n * Default false. Needed in 3D maps to let the camera stay in a constant\n * height based on sea-level. After the animation finished the zoom-level will be recalculated in respect of\n * the distance from the camera to the center-coordinate-altitude.\n */\n freezeElevation?: boolean;\n};\n\n/**\n * A callback hook that allows manipulating the camera and being notified about camera updates before they happen\n */\nexport type CameraUpdateTransformFunction = (next: {\n center: LngLat;\n zoom: number;\n pitch: number;\n bearing: number;\n elevation: number;\n}) => {\n center?: LngLat;\n zoom?: number;\n pitch?: number;\n bearing?: number;\n elevation?: number;\n};\n\nexport abstract class Camera extends Evented {\n transform: Transform;\n terrain: Terrain;\n handlers: HandlerManager;\n\n _moving: boolean;\n _zooming: boolean;\n _rotating: boolean;\n _pitching: boolean;\n _padding: boolean;\n\n _bearingSnap: number;\n _easeStart: number;\n _easeOptions: {\n duration?: number;\n easing?: (_: number) => number;\n };\n _easeId: string | void;\n\n _onEaseFrame: (_: number) => void;\n _onEaseEnd: (easeId?: string) => void;\n _easeFrameId: TaskID;\n\n /**\n * @internal\n * holds the geographical coordinate of the target\n */\n _elevationCenter: LngLat;\n /**\n * @internal\n * holds the targ altitude value, = center elevation of the target.\n * This value may changes during flight, because new terrain-tiles loads during flight.\n */\n _elevationTarget: number;\n /**\n * @internal\n * holds the start altitude value, = center elevation before animation begins\n * this value will recalculated during flight in respect of changing _elevationTarget values,\n * so the linear interpolation between start and target keeps smooth and without jumps.\n */\n _elevationStart: number;\n /**\n * @internal\n * Saves the current state of the elevation freeze - this is used during map movement to prevent \"rocky\" camera movement.\n */\n _elevationFreeze: boolean;\n /**\n * @internal\n * Used to track accumulated changes during continuous interaction\n */\n _requestedCameraState?: Transform;\n /**\n * A callback used to defer camera updates or apply arbitrary constraints.\n * If specified, this Camera instance can be used as a stateless component in React etc.\n */\n transformCameraUpdate: CameraUpdateTransformFunction | null;\n\n abstract _requestRenderFrame(a: () => void): TaskID;\n abstract _cancelRenderFrame(_: TaskID): void;\n\n constructor(transform: Transform, options: {\n bearingSnap: number;\n }) {\n super();\n this._moving = false;\n this._zooming = false;\n this.transform = transform;\n this._bearingSnap = options.bearingSnap;\n\n this.on('moveend', () => {\n delete this._requestedCameraState;\n });\n }\n\n /**\n * Returns the map's geographical centerpoint.\n *\n * @returns The map's geographical centerpoint.\n * @example\n * Return a LngLat object such as `{lng: 0, lat: 0}`\n * ```ts\n * let center = map.getCenter();\n * // access longitude and latitude values directly\n * let {lng, lat} = map.getCenter();\n * ```\n */\n getCenter(): LngLat { return new LngLat(this.transform.center.lng, this.transform.center.lat); }\n\n /**\n * Sets the map's geographical centerpoint. Equivalent to `jumpTo({center: center})`.\n *\n * Triggers the following events: `movestart` and `moveend`.\n *\n * @param center - The centerpoint to set.\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n * @example\n * ```ts\n * map.setCenter([-74, 38]);\n * ```\n */\n setCenter(center: LngLatLike, eventData?: any) {\n return this.jumpTo({center}, eventData);\n }\n\n /**\n * Pans the map by the specified offset.\n *\n * Triggers the following events: `movestart` and `moveend`.\n *\n * @param offset - `x` and `y` coordinates by which to pan the map.\n * @param options - Options object\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n * @see [Navigate the map with game-like controls](https://maplibre.org/maplibre-gl-js/docs/examples/game-controls/)\n */\n panBy(offset: PointLike, options?: AnimationOptions, eventData?: any): this {\n offset = Point.convert(offset).mult(-1);\n return this.panTo(this.transform.center, extend({offset}, options), eventData);\n }\n\n /**\n * Pans the map to the specified location with an animated transition.\n *\n * Triggers the following events: `movestart` and `moveend`.\n *\n * @param lnglat - The location to pan the map to.\n * @param options - Options describing the destination and animation of the transition.\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n * @example\n * ```ts\n * map.panTo([-74, 38]);\n * // Specify that the panTo animation should last 5000 milliseconds.\n * map.panTo([-74, 38], {duration: 5000});\n * ```\n * @see [Update a feature in realtime](https://maplibre.org/maplibre-gl-js/docs/examples/live-update-feature/)\n */\n panTo(lnglat: LngLatLike, options?: AnimationOptions, eventData?: any): this {\n return this.easeTo(extend({\n center: lnglat\n }, options), eventData);\n }\n\n /**\n * Returns the map's current zoom level.\n *\n * @returns The map's current zoom level.\n * @example\n * ```ts\n * map.getZoom();\n * ```\n */\n getZoom(): number { return this.transform.zoom; }\n\n /**\n * Sets the map's zoom level. Equivalent to `jumpTo({zoom: zoom})`.\n *\n * Triggers the following events: `movestart`, `move`, `moveend`, `zoomstart`, `zoom`, and `zoomend`.\n *\n * @param zoom - The zoom level to set (0-20).\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n * @example\n * Zoom to the zoom level 5 without an animated transition\n * ```ts\n * map.setZoom(5);\n * ```\n */\n setZoom(zoom: number, eventData?: any): this {\n this.jumpTo({zoom}, eventData);\n return this;\n }\n\n /**\n * Zooms the map to the specified zoom level, with an animated transition.\n *\n * Triggers the following events: `movestart`, `move`, `moveend`, `zoomstart`, `zoom`, and `zoomend`.\n *\n * @param zoom - The zoom level to transition to.\n * @param options - Options object\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n * @example\n * ```ts\n * // Zoom to the zoom level 5 without an animated transition\n * map.zoomTo(5);\n * // Zoom to the zoom level 8 with an animated transition\n * map.zoomTo(8, {\n * duration: 2000,\n * offset: [100, 50]\n * });\n * ```\n */\n zoomTo(zoom: number, options?: AnimationOptions | null, eventData?: any): this {\n return this.easeTo(extend({\n zoom\n }, options), eventData);\n }\n\n /**\n * Increases the map's zoom level by 1.\n *\n * Triggers the following events: `movestart`, `move`, `moveend`, `zoomstart`, `zoom`, and `zoomend`.\n *\n * @param options - Options object\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n * @example\n * Zoom the map in one level with a custom animation duration\n * ```ts\n * map.zoomIn({duration: 1000});\n * ```\n */\n zoomIn(options?: AnimationOptions, eventData?: any): this {\n this.zoomTo(this.getZoom() + 1, options, eventData);\n return this;\n }\n\n /**\n * Decreases the map's zoom level by 1.\n *\n * Triggers the following events: `movestart`, `move`, `moveend`, `zoomstart`, `zoom`, and `zoomend`.\n *\n * @param options - Options object\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n * @example\n * Zoom the map out one level with a custom animation offset\n * ```ts\n * map.zoomOut({offset: [80, 60]});\n * ```\n */\n zoomOut(options?: AnimationOptions, eventData?: any): this {\n this.zoomTo(this.getZoom() - 1, options, eventData);\n return this;\n }\n\n /**\n * Returns the map's current bearing. The bearing is the compass direction that is \"up\"; for example, a bearing\n * of 90° orients the map so that east is up.\n *\n * @returns The map's current bearing.\n * @see [Navigate the map with game-like controls](https://maplibre.org/maplibre-gl-js/docs/examples/game-controls/)\n */\n getBearing(): number { return this.transform.bearing; }\n\n /**\n * Sets the map's bearing (rotation). The bearing is the compass direction that is \"up\"; for example, a bearing\n * of 90° orients the map so that east is up.\n *\n * Equivalent to `jumpTo({bearing: bearing})`.\n *\n * Triggers the following events: `movestart`, `moveend`, and `rotate`.\n *\n * @param bearing - The desired bearing.\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n * @example\n * Rotate the map to 90 degrees\n * ```ts\n * map.setBearing(90);\n * ```\n */\n setBearing(bearing: number, eventData?: any): this {\n this.jumpTo({bearing}, eventData);\n return this;\n }\n\n /**\n * Returns the current padding applied around the map viewport.\n *\n * @returns The current padding around the map viewport.\n */\n getPadding(): PaddingOptions { return this.transform.padding; }\n\n /**\n * Sets the padding in pixels around the viewport.\n *\n * Equivalent to `jumpTo({padding: padding})`.\n *\n * Triggers the following events: `movestart` and `moveend`.\n *\n * @param padding - The desired padding.\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n * @example\n * Sets a left padding of 300px, and a top padding of 50px\n * ```ts\n * map.setPadding({ left: 300, top: 50 });\n * ```\n */\n setPadding(padding: PaddingOptions, eventData?: any): this {\n this.jumpTo({padding}, eventData);\n return this;\n }\n\n /**\n * Rotates the map to the specified bearing, with an animated transition. The bearing is the compass direction\n * that is \"up\"; for example, a bearing of 90° orients the map so that east is up.\n *\n * Triggers the following events: `movestart`, `moveend`, and `rotate`.\n *\n * @param bearing - The desired bearing.\n * @param options - Options object\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n */\n rotateTo(bearing: number, options?: AnimationOptions, eventData?: any): this {\n return this.easeTo(extend({\n bearing\n }, options), eventData);\n }\n\n /**\n * Rotates the map so that north is up (0° bearing), with an animated transition.\n *\n * Triggers the following events: `movestart`, `moveend`, and `rotate`.\n *\n * @param options - Options object\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n */\n resetNorth(options?: AnimationOptions, eventData?: any): this {\n this.rotateTo(0, extend({duration: 1000}, options), eventData);\n return this;\n }\n\n /**\n * Rotates and pitches the map so that north is up (0° bearing) and pitch is 0°, with an animated transition.\n *\n * Triggers the following events: `movestart`, `move`, `moveend`, `pitchstart`, `pitch`, `pitchend`, and `rotate`.\n *\n * @param options - Options object\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n */\n resetNorthPitch(options?: AnimationOptions, eventData?: any): this {\n this.easeTo(extend({\n bearing: 0,\n pitch: 0,\n duration: 1000\n }, options), eventData);\n return this;\n }\n\n /**\n * Snaps the map so that north is up (0° bearing), if the current bearing is close enough to it (i.e. within the\n * `bearingSnap` threshold).\n *\n * Triggers the following events: `movestart`, `moveend`, and `rotate`.\n *\n * @param options - Options object\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n */\n snapToNorth(options?: AnimationOptions, eventData?: any): this {\n if (Math.abs(this.getBearing()) < this._bearingSnap) {\n return this.resetNorth(options, eventData);\n }\n return this;\n }\n\n /**\n * Returns the map's current pitch (tilt).\n *\n * @returns The map's current pitch, measured in degrees away from the plane of the screen.\n */\n getPitch(): number { return this.transform.pitch; }\n\n /**\n * Sets the map's pitch (tilt). Equivalent to `jumpTo({pitch: pitch})`.\n *\n * Triggers the following events: `movestart`, `moveend`, `pitchstart`, and `pitchend`.\n *\n * @param pitch - The pitch to set, measured in degrees away from the plane of the screen (0-60).\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n */\n setPitch(pitch: number, eventData?: any): this {\n this.jumpTo({pitch}, eventData);\n return this;\n }\n\n /**\n * @param bounds - Calculate the center for these bounds in the viewport and use\n * the highest zoom level up to and including `Map#getMaxZoom()` that fits\n * in the viewport. LngLatBounds represent a box that is always axis-aligned with bearing 0.\n * Bounds will be taken in [sw, ne] order. Southwest point will always be to the left of the northeast point.\n * @param options - Options object\n * @returns If map is able to fit to provided bounds, returns `center`, `zoom`, and `bearing`.\n * If map is unable to fit, method will warn and return undefined.\n * @example\n * ```ts\n * let bbox = [[-79, 43], [-73, 45]];\n * let newCameraTransform = map.cameraForBounds(bbox, {\n * padding: {top: 10, bottom:25, left: 15, right: 5}\n * });\n * ```\n */\n cameraForBounds(bounds: LngLatBoundsLike, options?: CameraForBoundsOptions): CenterZoomBearing | undefined {\n bounds = LngLatBounds.convert(bounds).adjustAntiMeridian();\n const bearing = options && options.bearing || 0;\n\n return this._cameraForBoxAndBearing(bounds.getNorthWest(), bounds.getSouthEast(), bearing, options);\n }\n\n /**\n * @internal\n * Calculate the center of these two points in the viewport and use\n * the highest zoom level up to and including `Map#getMaxZoom()` that fits\n * the points in the viewport at the specified bearing.\n * @param p0 - First point\n * @param p1 - Second point\n * @param bearing - Desired map bearing at end of animation, in degrees\n * @param options - the camera options\n * @returns If map is able to fit to provided bounds, returns `center`, `zoom`, and `bearing`.\n * If map is unable to fit, method will warn and return undefined.\n * @example\n * ```ts\n * let p0 = [-79, 43];\n * let p1 = [-73, 45];\n * let bearing = 90;\n * let newCameraTransform = map._cameraForBoxAndBearing(p0, p1, bearing, {\n * padding: {top: 10, bottom:25, left: 15, right: 5}\n * });\n * ```\n */\n _cameraForBoxAndBearing(p0: LngLatLike, p1: LngLatLike, bearing: number, options?: CameraForBoundsOptions): CenterZoomBearing | undefined {\n const defaultPadding = {\n top: 0,\n bottom: 0,\n right: 0,\n left: 0\n };\n options = extend({\n padding: defaultPadding,\n offset: [0, 0],\n maxZoom: this.transform.maxZoom\n }, options);\n\n if (typeof options.padding === 'number') {\n const p = options.padding;\n options.padding = {\n top: p,\n bottom: p,\n right: p,\n left: p\n };\n }\n\n options.padding = extend(defaultPadding, options.padding) as PaddingOptions;\n const tr = this.transform;\n const edgePadding = tr.padding;\n\n // Consider all corners of the rotated bounding box derived from the given points\n // when find the camera position that fits the given points.\n const bounds = new LngLatBounds(p0, p1);\n const nwWorld = tr.project(bounds.getNorthWest());\n const neWorld = tr.project(bounds.getNorthEast());\n const seWorld = tr.project(bounds.getSouthEast());\n const swWorld = tr.project(bounds.getSouthWest());\n\n const bearingRadians = degreesToRadians(-bearing);\n\n const nwRotatedWorld = nwWorld.rotate(bearingRadians);\n const neRotatedWorld = neWorld.rotate(bearingRadians);\n const seRotatedWorld = seWorld.rotate(bearingRadians);\n const swRotatedWorld = swWorld.rotate(bearingRadians);\n\n const upperRight = new Point(\n Math.max(nwRotatedWorld.x, neRotatedWorld.x, swRotatedWorld.x, seRotatedWorld.x),\n Math.max(nwRotatedWorld.y, neRotatedWorld.y, swRotatedWorld.y, seRotatedWorld.y)\n );\n\n const lowerLeft = new Point(\n Math.min(nwRotatedWorld.x, neRotatedWorld.x, swRotatedWorld.x, seRotatedWorld.x),\n Math.min(nwRotatedWorld.y, neRotatedWorld.y, swRotatedWorld.y, seRotatedWorld.y)\n );\n\n // Calculate zoom: consider the original bbox and padding.\n const size = upperRight.sub(lowerLeft);\n const scaleX = (tr.width - (edgePadding.left + edgePadding.right + options.padding.left + options.padding.right)) / size.x;\n const scaleY = (tr.height - (edgePadding.top + edgePadding.bottom + options.padding.top + options.padding.bottom)) / size.y;\n\n if (scaleY < 0 || scaleX < 0) {\n warnOnce(\n 'Map cannot fit within canvas with the given bounds, padding, and/or offset.'\n );\n return undefined;\n }\n\n const zoom = Math.min(tr.scaleZoom(tr.scale * Math.min(scaleX, scaleY)), options.maxZoom);\n\n // Calculate center: apply the zoom, the configured offset, as well as offset that exists as a result of padding.\n const offset = Point.convert(options.offset);\n const paddingOffsetX = (options.padding.left - options.padding.right) / 2;\n const paddingOffsetY = (options.padding.top - options.padding.bottom) / 2;\n const paddingOffset = new Point(paddingOffsetX, paddingOffsetY);\n const rotatedPaddingOffset = paddingOffset.rotate(degreesToRadians(bearing));\n const offsetAtInitialZoom = offset.add(rotatedPaddingOffset);\n const offsetAtFinalZoom = offsetAtInitialZoom.mult(tr.scale / tr.zoomScale(zoom));\n\n const center = tr.unproject(\n // either world diagonal can be used (NW-SE or NE-SW)\n nwWorld.add(seWorld).div(2).sub(offsetAtFinalZoom)\n );\n\n return {\n center,\n zoom,\n bearing\n };\n }\n\n /**\n * Pans and zooms the map to contain its visible area within the specified geographical bounds.\n * This function will also reset the map's bearing to 0 if bearing is nonzero.\n *\n * Triggers the following events: `movestart` and `moveend`.\n *\n * @param bounds - Center these bounds in the viewport and use the highest\n * zoom level up to and including `Map#getMaxZoom()` that fits them in the viewport.\n * Bounds will be taken in [sw, ne] order. Southwest point will always be to the left of the northeast point.\n * @param options - Options supports all properties from {@link AnimationOptions} and {@link CameraOptions} in addition to the fields below.\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n * @example\n * ```ts\n * let bbox = [[-79, 43], [-73, 45]];\n * map.fitBounds(bbox, {\n * padding: {top: 10, bottom:25, left: 15, right: 5}\n * });\n * ```\n * @see [Fit a map to a bounding box](https://maplibre.org/maplibre-gl-js/docs/examples/fitbounds/)\n */\n fitBounds(bounds: LngLatBoundsLike, options?: FitBoundsOptions, eventData?: any): this {\n return this._fitInternal(\n this.cameraForBounds(bounds, options),\n options,\n eventData);\n }\n\n /**\n * Pans, rotates and zooms the map to to fit the box made by points p0 and p1\n * once the map is rotated to the specified bearing. To zoom without rotating,\n * pass in the current map bearing.\n *\n * Triggers the following events: `movestart`, `move`, `moveend`, `zoomstart`, `zoom`, `zoomend` and `rotate`.\n *\n * @param p0 - First point on screen, in pixel coordinates\n * @param p1 - Second point on screen, in pixel coordinates\n * @param bearing - Desired map bearing at end of animation, in degrees\n * @param options - Options object\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n * @example\n * ```ts\n * let p0 = [220, 400];\n * let p1 = [500, 900];\n * map.fitScreenCoordinates(p0, p1, map.getBearing(), {\n * padding: {top: 10, bottom:25, left: 15, right: 5}\n * });\n * ```\n * @see Used by {@link BoxZoomHandler}\n */\n fitScreenCoordinates(p0: PointLike, p1: PointLike, bearing: number, options?: FitBoundsOptions, eventData?: any): this {\n return this._fitInternal(\n this._cameraForBoxAndBearing(\n this.transform.pointLocation(Point.convert(p0)),\n this.transform.pointLocation(Point.convert(p1)),\n bearing,\n options),\n options,\n eventData);\n }\n\n _fitInternal(calculatedOptions?: CenterZoomBearing, options?: FitBoundsOptions, eventData?: any): this {\n // cameraForBounds warns + returns undefined if unable to fit:\n if (!calculatedOptions) return this;\n\n options = extend(calculatedOptions, options);\n // Explicitly remove the padding field because, calculatedOptions already accounts for padding by setting zoom and center accordingly.\n delete options.padding;\n\n return options.linear ?\n this.easeTo(options, eventData) :\n this.flyTo(options, eventData);\n }\n\n /**\n * Changes any combination of center, zoom, bearing, and pitch, without\n * an animated transition. The map will retain its current values for any\n * details not specified in `options`.\n *\n * Triggers the following events: `movestart`, `move`, `moveend`, `zoomstart`, `zoom`, `zoomend`, `pitchstart`,\n * `pitch`, `pitchend`, and `rotate`.\n *\n * @param options - Options object\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n * @example\n * ```ts\n * // jump to coordinates at current zoom\n * map.jumpTo({center: [0, 0]});\n * // jump with zoom, pitch, and bearing options\n * map.jumpTo({\n * center: [0, 0],\n * zoom: 8,\n * pitch: 45,\n * bearing: 90\n * });\n * ```\n * @see [Jump to a series of locations](https://maplibre.org/maplibre-gl-js/docs/examples/jump-to/)\n * @see [Update a feature in realtime](https://maplibre.org/maplibre-gl-js/docs/examples/live-update-feature/)\n */\n jumpTo(options: JumpToOptions, eventData?: any): this {\n this.stop();\n\n const tr = this._getTransformForUpdate();\n let zoomChanged = false,\n bearingChanged = false,\n pitchChanged = false;\n\n if ('zoom' in options && tr.zoom !== +options.zoom) {\n zoomChanged = true;\n tr.zoom = +options.zoom;\n }\n\n if (options.center !== undefined) {\n tr.center = LngLat.convert(options.center);\n }\n\n if ('bearing' in options && tr.bearing !== +options.bearing) {\n bearingChanged = true;\n tr.bearing = +options.bearing;\n }\n\n if ('pitch' in options && tr.pitch !== +options.pitch) {\n pitchChanged = true;\n tr.pitch = +options.pitch;\n }\n\n if (options.padding != null && !tr.isPaddingEqual(options.padding)) {\n tr.padding = options.padding;\n }\n this._applyUpdatedTransform(tr);\n\n this.fire(new Event('movestart', eventData))\n .fire(new Event('move', eventData));\n\n if (zoomChanged) {\n this.fire(new Event('zoomstart', eventData))\n .fire(new Event('zoom', eventData))\n .fire(new Event('zoomend', eventData));\n }\n\n if (bearingChanged) {\n this.fire(new Event('rotatestart', eventData))\n .fire(new Event('rotate', eventData))\n .fire(new Event('rotateend', eventData));\n }\n\n if (pitchChanged) {\n this.fire(new Event('pitchstart', eventData))\n .fire(new Event('pitch', eventData))\n .fire(new Event('pitchend', eventData));\n }\n\n return this.fire(new Event('moveend', eventData));\n }\n\n /**\n * Calculates pitch, zoom and bearing for looking at `newCenter` with the camera position being `newCenter`\n * and returns them as {@link CameraOptions}.\n * @param from - The camera to look from\n * @param altitudeFrom - The altitude of the camera to look from\n * @param to - The center to look at\n * @param altitudeTo - Optional altitude of the center to look at. If none given the ground height will be used.\n * @returns the calculated camera options\n */\n calculateCameraOptionsFromTo(from: LngLat, altitudeFrom: number, to: LngLat, altitudeTo: number = 0): CameraOptions {\n const fromMerc = MercatorCoordinate.fromLngLat(from, altitudeFrom);\n const toMerc = MercatorCoordinate.fromLngLat(to, altitudeTo);\n const dx = toMerc.x - fromMerc.x;\n const dy = toMerc.y - fromMerc.y;\n const dz = toMerc.z - fromMerc.z;\n\n const distance3D = Math.hypot(dx, dy, dz);\n if (distance3D === 0) throw new Error('Can\\'t calculate camera options with same From and To');\n\n const groundDistance = Math.hypot(dx, dy);\n\n const zoom = this.transform.scaleZoom(this.transform.cameraToCenterDistance / distance3D / this.transform.tileSize);\n const bearing = (Math.atan2(dx, -dy) * 180) / Math.PI;\n let pitch = (Math.acos(groundDistance / distance3D) * 180) / Math.PI;\n pitch = dz < 0 ? 90 - pitch : 90 + pitch;\n\n return {\n center: toMerc.toLngLat(),\n zoom,\n pitch,\n bearing\n };\n }\n\n /**\n * Changes any combination of `center`, `zoom`, `bearing`, `pitch`, and `padding` with an animated transition\n * between old and new values. The map will retain its current values for any\n * details not specified in `options`.\n *\n * Note: The transition will happen instantly if the user has enabled\n * the `reduced motion` accessibility feature enabled in their operating system,\n * unless `options` includes `essential: true`.\n *\n * Triggers the following events: `movestart`, `move`, `moveend`, `zoomstart`, `zoom`, `zoomend`, `pitchstart`,\n * `pitch`, `pitchend`, and `rotate`.\n *\n * @param options - Options describing the destination and animation of the transition.\n * Accepts {@link CameraOptions} and {@link AnimationOptions}.\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n * @see [Navigate the map with game-like controls](https://maplibre.org/maplibre-gl-js/docs/examples/game-controls/)\n */\n easeTo(options: EaseToOptions & {\n easeId?: string;\n noMoveStart?: boolean;\n }, eventData?: any): this {\n this._stop(false, options.easeId);\n\n options = extend({\n offset: [0, 0],\n duration: 500,\n easing: defaultEasing\n }, options);\n\n if (options.animate === false || (!options.essential && browser.prefersReducedMotion)) options.duration = 0;\n\n const tr = this._getTransformForUpdate(),\n startZoom = tr.zoom,\n startBearing = tr.bearing,\n startPitch = tr.pitch,\n startPadding = tr.padding,\n\n bearing = 'bearing' in options ? this._normalizeBearing(options.bearing, startBearing) : startBearing,\n pitch = 'pitch' in options ? +options.pitch : startPitch,\n padding = 'padding' in options ? options.padding : tr.padding;\n\n const offsetAsPoint = Point.convert(options.offset);\n let pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n const locationAtOffset = tr.pointLocation(pointAtOffset);\n\n const {center, zoom} = tr.getConstrained(\n LngLat.convert(options.center || locationAtOffset),\n options.zoom ?? startZoom\n );\n this._normalizeCenter(center, tr);\n\n const from = tr.project(locationAtOffset);\n const delta = tr.project(center).sub(from);\n const finalScale = tr.zoomScale(zoom - startZoom);\n\n let around, aroundPoint;\n\n if (options.around) {\n around = LngLat.convert(options.around);\n aroundPoint = tr.locationPoint(around);\n }\n\n const currently = {\n moving: this._moving,\n zooming: this._zooming,\n rotating: this._rotating,\n pitching: this._pitching\n };\n\n this._zooming = this._zooming || (zoom !== startZoom);\n this._rotating = this._rotating || (startBearing !== bearing);\n this._pitching = this._pitching || (pitch !== startPitch);\n this._padding = !tr.isPaddingEqual(padding as PaddingOptions);\n\n this._easeId = options.easeId;\n this._prepareEase(eventData, options.noMoveStart, currently);\n if (this.terrain) this._prepareElevation(center);\n\n this._ease((k) => {\n if (this._zooming) {\n tr.zoom = interpolates.number(startZoom, zoom, k);\n }\n if (this._rotating) {\n tr.bearing = interpolates.number(startBearing, bearing, k);\n }\n if (this._pitching) {\n tr.pitch = interpolates.number(startPitch, pitch, k);\n }\n if (this._padding) {\n tr.interpolatePadding(startPadding, padding as PaddingOptions, k);\n // When padding is being applied, Transform#centerPoint is changing continuously,\n // thus we need to recalculate offsetPoint every frame\n pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n }\n\n if (this.terrain && !options.freezeElevation) this._updateElevation(k);\n\n if (around) {\n tr.setLocationAtPoint(around, aroundPoint);\n } else {\n const scale = tr.zoomScale(tr.zoom - startZoom);\n const base = zoom > startZoom ?\n Math.min(2, finalScale) :\n Math.max(0.5, finalScale);\n const speedup = Math.pow(base, 1 - k);\n const newCenter = tr.unproject(from.add(delta.mult(k * speedup)).mult(scale));\n tr.setLocationAtPoint(tr.renderWorldCopies ? newCenter.wrap() : newCenter, pointAtOffset);\n }\n\n this._applyUpdatedTransform(tr);\n\n this._fireMoveEvents(eventData);\n\n }, (interruptingEaseId?: string) => {\n if (this.terrain && options.freezeElevation) this._finalizeElevation();\n this._afterEase(eventData, interruptingEaseId);\n }, options as any);\n\n return this;\n }\n\n _prepareEase(eventData: any, noMoveStart: boolean, currently: any = {}) {\n this._moving = true;\n if (!noMoveStart && !currently.moving) {\n this.fire(new Event('movestart', eventData));\n }\n if (this._zooming && !currently.zooming) {\n this.fire(new Event('zoomstart', eventData));\n }\n if (this._rotating && !currently.rotating) {\n this.fire(new Event('rotatestart', eventData));\n }\n if (this._pitching && !currently.pitching) {\n this.fire(new Event('pitchstart', eventData));\n }\n }\n\n _prepareElevation(center: LngLat) {\n this._elevationCenter = center;\n this._elevationStart = this.transform.elevation;\n this._elevationTarget = this.terrain.getElevationForLngLatZoom(center, this.transform.tileZoom);\n this._elevationFreeze = true;\n }\n\n _updateElevation(k: number) {\n this.transform.minElevationForCurrentTile = this.terrain.getMinTileElevationForLngLatZoom(this._elevationCenter, this.transform.tileZoom);\n const elevation = this.terrain.getElevationForLngLatZoom(this._elevationCenter, this.transform.tileZoom);\n // target terrain updated during flight, slowly move camera to new height\n if (k < 1 && elevation !== this._elevationTarget) {\n const pitch1 = this._elevationTarget - this._elevationStart;\n const pitch2 = (elevation - (pitch1 * k + this._elevationStart)) / (1 - k);\n this._elevationStart += k * (pitch1 - pitch2);\n this._elevationTarget = elevation;\n }\n this.transform.elevation = interpolates.number(this._elevationStart, this._elevationTarget, k);\n }\n\n _finalizeElevation() {\n this._elevationFreeze = false;\n this.transform.recalculateZoom(this.terrain);\n }\n\n /**\n * @internal\n * Called when the camera is about to be manipulated.\n * If `transformCameraUpdate` is specified or terrain is enabled, a copy of\n * the current transform is created to track the accumulated changes.\n * This underlying transform represents the \"desired state\" proposed by input handlers / animations / UI controls.\n * It may differ from the state used for rendering (`this.transform`).\n * @returns Transform to apply changes to\n */\n _getTransformForUpdate(): Transform {\n if (!this.transformCameraUpdate && !this.terrain) return this.transform;\n\n if (!this._requestedCameraState) {\n this._requestedCameraState = this.transform.clone();\n }\n return this._requestedCameraState;\n }\n\n /**\n * @internal\n * Checks the given transform for the camera being below terrain surface and\n * returns new pitch and zoom to fix that.\n *\n * With the new pitch and zoom, the camera will be at the same ground\n * position but at higher altitude. It will still point to the same spot on\n * the map.\n *\n * @param tr - The transform to check.\n */\n _elevateCameraIfInsideTerrain(tr: Transform) : { pitch?: number; zoom?: number } {\n const camera = tr.getCameraPosition();\n const minAltitude = this.terrain.getElevationForLngLatZoom(camera.lngLat, tr.zoom);\n if (camera.altitude < minAltitude) {\n const newCamera = this.calculateCameraOptionsFromTo(\n camera.lngLat, minAltitude, tr.center, tr.elevation);\n return {\n pitch: newCamera.pitch,\n zoom: newCamera.zoom,\n };\n }\n return {};\n }\n\n /**\n * @internal\n * Called after the camera is done being manipulated.\n * @param tr - the requested camera end state\n * If the camera is inside terrain, it gets elevated.\n * Call `transformCameraUpdate` if present, and then apply the \"approved\" changes.\n */\n _applyUpdatedTransform(tr: Transform) {\n const modifiers : ((tr: Transform) => ReturnType)[] = [];\n if (this.terrain) {\n modifiers.push(tr => this._elevateCameraIfInsideTerrain(tr));\n }\n if (this.transformCameraUpdate) {\n modifiers.push(tr => this.transformCameraUpdate(tr));\n }\n if (!modifiers.length) {\n return;\n }\n const finalTransform = tr.clone();\n for (const modifier of modifiers) {\n const nextTransform = finalTransform.clone();\n const {\n center,\n zoom,\n pitch,\n bearing,\n elevation\n } = modifier(nextTransform);\n if (center) nextTransform.center = center;\n if (zoom !== undefined) nextTransform.zoom = zoom;\n if (pitch !== undefined) nextTransform.pitch = pitch;\n if (bearing !== undefined) nextTransform.bearing = bearing;\n if (elevation !== undefined) nextTransform.elevation = elevation;\n finalTransform.apply(nextTransform);\n }\n this.transform.apply(finalTransform);\n }\n\n _fireMoveEvents(eventData?: any) {\n this.fire(new Event('move', eventData));\n if (this._zooming) {\n this.fire(new Event('zoom', eventData));\n }\n if (this._rotating) {\n this.fire(new Event('rotate', eventData));\n }\n if (this._pitching) {\n this.fire(new Event('pitch', eventData));\n }\n }\n\n _afterEase(eventData?: any, easeId?: string) {\n // if this easing is being stopped to start another easing with\n // the same id then don't fire any events to avoid extra start/stop events\n if (this._easeId && easeId && this._easeId === easeId) {\n return;\n }\n delete this._easeId;\n\n const wasZooming = this._zooming;\n const wasRotating = this._rotating;\n const wasPitching = this._pitching;\n this._moving = false;\n this._zooming = false;\n this._rotating = false;\n this._pitching = false;\n this._padding = false;\n\n if (wasZooming) {\n this.fire(new Event('zoomend', eventData));\n }\n if (wasRotating) {\n this.fire(new Event('rotateend', eventData));\n }\n if (wasPitching) {\n this.fire(new Event('pitchend', eventData));\n }\n this.fire(new Event('moveend', eventData));\n }\n\n /**\n * Changes any combination of center, zoom, bearing, and pitch, animating the transition along a curve that\n * evokes flight. The animation seamlessly incorporates zooming and panning to help\n * the user maintain her bearings even after traversing a great distance.\n *\n * Note: The animation will be skipped, and this will behave equivalently to `jumpTo`\n * if the user has the `reduced motion` accessibility feature enabled in their operating system,\n * unless 'options' includes `essential: true`.\n *\n * Triggers the following events: `movestart`, `move`, `moveend`, `zoomstart`, `zoom`, `zoomend`, `pitchstart`,\n * `pitch`, `pitchend`, and `rotate`.\n *\n * @param options - Options describing the destination and animation of the transition.\n * Accepts {@link CameraOptions}, {@link AnimationOptions},\n * and the following additional options.\n * @param eventData - Additional properties to be added to event objects of events triggered by this method.\n * @example\n * ```ts\n * // fly with default options to null island\n * map.flyTo({center: [0, 0], zoom: 9});\n * // using flyTo options\n * map.flyTo({\n * center: [0, 0],\n * zoom: 9,\n * speed: 0.2,\n * curve: 1,\n * easing(t) {\n * return t;\n * }\n * });\n * ```\n * @see [Fly to a location](https://maplibre.org/maplibre-gl-js/docs/examples/flyto/)\n * @see [Slowly fly to a location](https://maplibre.org/maplibre-gl-js/docs/examples/flyto-options/)\n * @see [Fly to a location based on scroll position](https://maplibre.org/maplibre-gl-js/docs/examples/scroll-fly-to/)\n */\n flyTo(options: FlyToOptions, eventData?: any): this {\n // Fall through to jumpTo if user has set prefers-reduced-motion\n if (!options.essential && browser.prefersReducedMotion) {\n const coercedOptions = pick(options, ['center', 'zoom', 'bearing', 'pitch', 'around']) as CameraOptions;\n return this.jumpTo(coercedOptions, eventData);\n }\n\n // This method implements an “optimal path” animation, as detailed in:\n //\n // Van Wijk, Jarke J.; Nuij, Wim A. A. “Smooth and efficient zooming and panning.” INFOVIS\n // ’03. pp. 15–22. .\n //\n // Where applicable, local variable documentation begins with the associated variable or\n // function in van Wijk (2003).\n\n this.stop();\n\n options = extend({\n offset: [0, 0],\n speed: 1.2,\n curve: 1.42,\n easing: defaultEasing\n }, options);\n\n const tr = this._getTransformForUpdate(),\n startZoom = tr.zoom,\n startBearing = tr.bearing,\n startPitch = tr.pitch,\n startPadding = tr.padding;\n\n const bearing = 'bearing' in options ? this._normalizeBearing(options.bearing, startBearing) : startBearing;\n const pitch = 'pitch' in options ? +options.pitch : startPitch;\n const padding = 'padding' in options ? options.padding : tr.padding;\n\n const offsetAsPoint = Point.convert(options.offset);\n let pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n const locationAtOffset = tr.pointLocation(pointAtOffset);\n\n const {center, zoom} = tr.getConstrained(\n LngLat.convert(options.center || locationAtOffset),\n options.zoom ?? startZoom\n );\n this._normalizeCenter(center, tr);\n const scale = tr.zoomScale(zoom - startZoom);\n\n const from = tr.project(locationAtOffset);\n const delta = tr.project(center).sub(from);\n\n let rho = options.curve;\n\n // w₀: Initial visible span, measured in pixels at the initial scale.\n const w0 = Math.max(tr.width, tr.height),\n // w₁: Final visible span, measured in pixels with respect to the initial scale.\n w1 = w0 / scale,\n // Length of the flight path as projected onto the ground plane, measured in pixels from\n // the world image origin at the initial scale.\n u1 = delta.mag();\n\n if ('minZoom' in options) {\n const minZoom = clamp(Math.min(options.minZoom, startZoom, zoom), tr.minZoom, tr.maxZoom);\n // wm: Maximum visible span, measured in pixels with respect to the initial\n // scale.\n const wMax = w0 / tr.zoomScale(minZoom - startZoom);\n rho = Math.sqrt(wMax / u1 * 2);\n }\n\n // ρ²\n const rho2 = rho * rho;\n\n /**\n * rᵢ: Returns the zoom-out factor at one end of the animation.\n *\n * @param descent - `true` for the descent, `false` for the ascent\n */\n function zoomOutFactor(descent: boolean) {\n const b = (w1 * w1 - w0 * w0 + (descent ? -1 : 1) * rho2 * rho2 * u1 * u1) / (2 * (descent ? w1 : w0) * rho2 * u1);\n return Math.log(Math.sqrt(b * b + 1) - b);\n }\n\n function sinh(n) { return (Math.exp(n) - Math.exp(-n)) / 2; }\n function cosh(n) { return (Math.exp(n) + Math.exp(-n)) / 2; }\n function tanh(n) { return sinh(n) / cosh(n); }\n\n // r₀: Zoom-out factor during ascent.\n const r0 = zoomOutFactor(false);\n\n // w(s): Returns the visible span on the ground, measured in pixels with respect to the\n // initial scale. Assumes an angular field of view of 2 arctan ½ ≈ 53°.\n let w: (_: number) => number = function (s) {\n return (cosh(r0) / cosh(r0 + rho * s));\n };\n\n // u(s): Returns the distance along the flight path as projected onto the ground plane,\n // measured in pixels from the world image origin at the initial scale.\n let u: (_: number) => number = function (s) {\n return w0 * ((cosh(r0) * tanh(r0 + rho * s) - sinh(r0)) / rho2) / u1;\n };\n\n // S: Total length of the flight path, measured in ρ-screenfuls.\n let S = (zoomOutFactor(true) - r0) / rho;\n\n // When u₀ = u₁, the optimal path doesn’t require both ascent and descent.\n if (Math.abs(u1) < 0.000001 || !isFinite(S)) {\n // Perform a more or less instantaneous transition if the path is too short.\n if (Math.abs(w0 - w1) < 0.000001) return this.easeTo(options, eventData);\n\n const k = w1 < w0 ? -1 : 1;\n S = Math.abs(Math.log(w1 / w0)) / rho;\n\n u = () => 0;\n w = (s) => Math.exp(k * rho * s);\n }\n\n if ('duration' in options) {\n options.duration = +options.duration;\n } else {\n const V = 'screenSpeed' in options ? +options.screenSpeed / rho : +options.speed;\n options.duration = 1000 * S / V;\n }\n\n if (options.maxDuration && options.duration > options.maxDuration) {\n options.duration = 0;\n }\n\n this._zooming = true;\n this._rotating = (startBearing !== bearing);\n this._pitching = (pitch !== startPitch);\n this._padding = !tr.isPaddingEqual(padding as PaddingOptions);\n\n this._prepareEase(eventData, false);\n if (this.terrain) this._prepareElevation(center);\n\n this._ease((k) => {\n // s: The distance traveled along the flight path, measured in ρ-screenfuls.\n const s = k * S;\n const scale = 1 / w(s);\n tr.zoom = k === 1 ? zoom : startZoom + tr.scaleZoom(scale);\n\n if (this._rotating) {\n tr.bearing = interpolates.number(startBearing, bearing, k);\n }\n if (this._pitching) {\n tr.pitch = interpolates.number(startPitch, pitch, k);\n }\n if (this._padding) {\n tr.interpolatePadding(startPadding, padding as PaddingOptions, k);\n // When padding is being applied, Transform#centerPoint is changing continuously,\n // thus we need to recalculate offsetPoint every frame\n pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n }\n\n if (this.terrain && !options.freezeElevation) this._updateElevation(k);\n\n const newCenter = k === 1 ? center : tr.unproject(from.add(delta.mult(u(s))).mult(scale));\n tr.setLocationAtPoint(tr.renderWorldCopies ? newCenter.wrap() : newCenter, pointAtOffset);\n\n this._applyUpdatedTransform(tr);\n\n this._fireMoveEvents(eventData);\n\n }, () => {\n if (this.terrain && options.freezeElevation) this._finalizeElevation();\n this._afterEase(eventData);\n }, options);\n\n return this;\n }\n\n isEasing() {\n return !!this._easeFrameId;\n }\n\n /**\n * Stops any animated transition underway.\n */\n stop(): this {\n return this._stop();\n }\n\n _stop(allowGestures?: boolean, easeId?: string): this {\n if (this._easeFrameId) {\n this._cancelRenderFrame(this._easeFrameId);\n delete this._easeFrameId;\n delete this._onEaseFrame;\n }\n\n if (this._onEaseEnd) {\n // The _onEaseEnd function might emit events which trigger new\n // animation, which sets a new _onEaseEnd. Ensure we don't delete\n // it unintentionally.\n const onEaseEnd = this._onEaseEnd;\n delete this._onEaseEnd;\n onEaseEnd.call(this, easeId);\n }\n if (!allowGestures) {\n this.handlers?.stop(false);\n }\n return this;\n }\n\n _ease(frame: (_: number) => void,\n finish: () => void,\n options: {\n animate?: boolean;\n duration?: number;\n easing?: (_: number) => number;\n }) {\n if (options.animate === false || options.duration === 0) {\n frame(1);\n finish();\n } else {\n this._easeStart = browser.now();\n this._easeOptions = options;\n this._onEaseFrame = frame;\n this._onEaseEnd = finish;\n this._easeFrameId = this._requestRenderFrame(this._renderFrameCallback);\n }\n }\n\n // Callback for map._requestRenderFrame\n _renderFrameCallback = () => {\n const t = Math.min((browser.now() - this._easeStart) / this._easeOptions.duration, 1);\n this._onEaseFrame(this._easeOptions.easing(t));\n\n // if _stop is called during _onEaseFrame from _fireMoveEvents we should avoid a new _requestRenderFrame, checking it by ensuring _easeFrameId was not deleted\n if (t < 1 && this._easeFrameId) {\n this._easeFrameId = this._requestRenderFrame(this._renderFrameCallback);\n } else {\n this.stop();\n }\n };\n\n // convert bearing so that it's numerically close to the current one so that it interpolates properly\n _normalizeBearing(bearing: number, currentBearing: number) {\n bearing = wrap(bearing, -180, 180);\n const diff = Math.abs(bearing - currentBearing);\n if (Math.abs(bearing - 360 - currentBearing) < diff) bearing -= 360;\n if (Math.abs(bearing + 360 - currentBearing) < diff) bearing += 360;\n return bearing;\n }\n\n // If a path crossing the antimeridian would be shorter, extend the final coordinate so that\n // interpolating between the two endpoints will cross it.\n _normalizeCenter(center: LngLat, tr: Transform) {\n if (!tr.renderWorldCopies || tr.lngRange) return;\n\n const delta = center.lng - tr.center.lng;\n center.lng +=\n delta > 180 ? -360 :\n delta < -180 ? 360 : 0;\n }\n\n /**\n * Get the elevation difference between a given point\n * and a point that is currently in the middle of the screen.\n * This method should be used for proper positioning of custom 3d objects, as explained [here](https://maplibre.org/maplibre-gl-js/docs/examples/add-3d-model-with-terrain/)\n * Returns null if terrain is not enabled.\n * This method is subject to change in Maplibre GL JS v5.\n * @param lngLatLike - [x,y] or LngLat coordinates of the location\n * @returns elevation offset in meters\n */\n queryTerrainElevation(lngLatLike: LngLatLike): number | null {\n if (!this.terrain) {\n return null;\n }\n const elevation = this.terrain.getElevationForLngLatZoom(LngLat.convert(lngLatLike), this.transform.tileZoom);\n return elevation - this.transform.elevation;\n }\n}\n","import {DOM} from '../../util/dom';\n\nimport type {Map} from '../map';\nimport type {ControlPosition, IControl} from './control';\nimport type {MapDataEvent} from '../events';\nimport type {StyleSpecification} from '@maplibre/maplibre-gl-style-spec';\n/**\n * The {@link AttributionControl} options object\n */\nexport type AttributionControlOptions = {\n /**\n * If `true`, the attribution control will always collapse when moving the map. If `false`,\n * force the expanded attribution control. The default is a responsive attribution that collapses when the user moves the map on maps less than 640 pixels wide.\n * **Attribution should not be collapsed if it can comfortably fit on the map. `compact` should only be used to modify default attribution when map size makes it impossible to fit default attribution and when the automatic compact resizing for default settings are not sufficient.**\n */\n compact?: boolean;\n /**\n * Attributions to show in addition to any other attributions.\n */\n customAttribution?: string | Array;\n};\n\nexport const defaultAttributionControlOptions: AttributionControlOptions = {\n compact: true,\n customAttribution: 'MapLibre'\n};\n\n/**\n * An `AttributionControl` control presents the map's attribution information. By default, the attribution control is expanded (regardless of map width).\n * @group Markers and Controls\n * @example\n * ```ts\n * let map = new Map({attributionControl: false})\n * .addControl(new AttributionControl({\n * compact: true\n * }));\n * ```\n */\nexport class AttributionControl implements IControl {\n options: AttributionControlOptions;\n _map: Map;\n _compact: boolean | undefined;\n _container: HTMLElement;\n _innerContainer: HTMLElement;\n _compactButton: HTMLElement;\n _editLink: HTMLAnchorElement;\n _attribHTML: string;\n styleId: string;\n styleOwner: string;\n\n /**\n * @param options - the attribution options\n */\n constructor(options: AttributionControlOptions = defaultAttributionControlOptions) {\n this.options = options;\n }\n\n getDefaultPosition(): ControlPosition {\n return 'bottom-right';\n }\n\n /** {@inheritDoc IControl.onAdd} */\n onAdd(map: Map) {\n this._map = map;\n this._compact = this.options.compact;\n this._container = DOM.create('details', 'maplibregl-ctrl maplibregl-ctrl-attrib');\n this._compactButton = DOM.create('summary', 'maplibregl-ctrl-attrib-button', this._container);\n this._compactButton.addEventListener('click', this._toggleAttribution);\n this._setElementTitle(this._compactButton, 'ToggleAttribution');\n this._innerContainer = DOM.create('div', 'maplibregl-ctrl-attrib-inner', this._container);\n\n this._updateAttributions();\n this._updateCompact();\n\n this._map.on('styledata', this._updateData);\n this._map.on('sourcedata', this._updateData);\n this._map.on('terrain', this._updateData);\n this._map.on('resize', this._updateCompact);\n this._map.on('drag', this._updateCompactMinimize);\n\n return this._container;\n }\n\n /** {@inheritDoc IControl.onRemove} */\n onRemove() {\n DOM.remove(this._container);\n\n this._map.off('styledata', this._updateData);\n this._map.off('sourcedata', this._updateData);\n this._map.off('terrain', this._updateData);\n this._map.off('resize', this._updateCompact);\n this._map.off('drag', this._updateCompactMinimize);\n\n this._map = undefined;\n this._compact = undefined;\n this._attribHTML = undefined;\n }\n\n _setElementTitle(element: HTMLElement, title: 'ToggleAttribution' | 'MapFeedback') {\n const str = this._map._getUIString(`AttributionControl.${title}`);\n element.title = str;\n element.setAttribute('aria-label', str);\n }\n\n _toggleAttribution = () => {\n if (this._container.classList.contains('maplibregl-compact')) {\n if (this._container.classList.contains('maplibregl-compact-show')) {\n this._container.setAttribute('open', '');\n this._container.classList.remove('maplibregl-compact-show');\n } else {\n this._container.classList.add('maplibregl-compact-show');\n this._container.removeAttribute('open');\n }\n }\n };\n\n _updateData = (e: MapDataEvent) => {\n if (e && (e.sourceDataType === 'metadata' || e.sourceDataType === 'visibility' || e.dataType === 'style' || e.type === 'terrain')) {\n this._updateAttributions();\n }\n };\n\n _updateAttributions() {\n if (!this._map.style) return;\n let attributions: Array = [];\n if (this.options.customAttribution) {\n if (Array.isArray(this.options.customAttribution)) {\n attributions = attributions.concat(\n this.options.customAttribution.map(attribution => {\n if (typeof attribution !== 'string') return '';\n return attribution;\n })\n );\n } else if (typeof this.options.customAttribution === 'string') {\n attributions.push(this.options.customAttribution);\n }\n }\n\n if (this._map.style.stylesheet) {\n const stylesheet = this._map.style.stylesheet as StyleSpecification & { owner: string; id: string };\n this.styleOwner = stylesheet.owner;\n this.styleId = stylesheet.id;\n }\n\n const sourceCaches = this._map.style.sourceCaches;\n for (const id in sourceCaches) {\n const sourceCache = sourceCaches[id];\n if (sourceCache.used || sourceCache.usedForTerrain) {\n const source = sourceCache.getSource();\n if (source.attribution && attributions.indexOf(source.attribution) < 0) {\n attributions.push(source.attribution);\n }\n }\n }\n\n // remove any entries that are whitespace\n attributions = attributions.filter(e => String(e).trim());\n\n // remove any entries that are substrings of another entry.\n // first sort by length so that substrings come first\n attributions.sort((a, b) => a.length - b.length);\n attributions = attributions.filter((attrib, i) => {\n for (let j = i + 1; j < attributions.length; j++) {\n if (attributions[j].indexOf(attrib) >= 0) { return false; }\n }\n return true;\n });\n\n // check if attribution string is different to minimize DOM changes\n const attribHTML = attributions.join(' | ');\n if (attribHTML === this._attribHTML) return;\n\n this._attribHTML = attribHTML;\n\n if (attributions.length) {\n this._innerContainer.innerHTML = attribHTML;\n this._container.classList.remove('maplibregl-attrib-empty');\n } else {\n this._container.classList.add('maplibregl-attrib-empty');\n }\n this._updateCompact();\n // remove old DOM node from _editLink\n this._editLink = null;\n }\n\n _updateCompact = () => {\n if (this._map.getCanvasContainer().offsetWidth <= 640 || this._compact) {\n if (this._compact === false) {\n this._container.setAttribute('open', '');\n } else if (!this._container.classList.contains('maplibregl-compact') && !this._container.classList.contains('maplibregl-attrib-empty')) {\n this._container.setAttribute('open', '');\n this._container.classList.add('maplibregl-compact', 'maplibregl-compact-show');\n }\n } else {\n this._container.setAttribute('open', '');\n if (this._container.classList.contains('maplibregl-compact')) {\n this._container.classList.remove('maplibregl-compact', 'maplibregl-compact-show');\n }\n }\n };\n\n _updateCompactMinimize = () => {\n if (this._container.classList.contains('maplibregl-compact')) {\n if (this._container.classList.contains('maplibregl-compact-show')) {\n this._container.classList.remove('maplibregl-compact-show');\n }\n }\n };\n}\n","import {DOM} from '../../util/dom';\n\nimport type {Map} from '../map';\nimport type {ControlPosition, IControl} from './control';\n\n/**\n * The {@link LogoControl} options object\n */\ntype LogoControlOptions = {\n /**\n * If `true`, force a compact logo.\n * If `false`, force the full logo. The default is a responsive logo that collapses when the map is less than 640 pixels wide.\n */\n compact?: boolean;\n};\n\n/**\n * A `LogoControl` is a control that adds the watermark.\n *\n * @group Markers and Controls\n *\n * @example\n * ```ts\n * map.addControl(new LogoControl({compact: false}));\n * ```\n **/\nexport class LogoControl implements IControl {\n options: LogoControlOptions;\n _map: Map;\n _compact: boolean;\n _container: HTMLElement;\n\n /**\n * @param options - the control's options\n */\n constructor(options: LogoControlOptions = {}) {\n this.options = options;\n }\n\n getDefaultPosition(): ControlPosition {\n return 'bottom-left';\n }\n\n /** {@inheritDoc IControl.onAdd} */\n onAdd(map: Map) {\n this._map = map;\n this._compact = this.options && this.options.compact;\n this._container = DOM.create('div', 'maplibregl-ctrl');\n const anchor = DOM.create('a', 'maplibregl-ctrl-logo');\n anchor.target = '_blank';\n anchor.rel = 'noopener nofollow';\n anchor.href = 'https://maplibre.org/';\n anchor.setAttribute('aria-label', this._map._getUIString('LogoControl.Title'));\n anchor.setAttribute('rel', 'noopener nofollow');\n this._container.appendChild(anchor);\n this._container.style.display = 'block';\n\n this._map.on('resize', this._updateCompact);\n this._updateCompact();\n\n return this._container;\n }\n\n /** {@inheritDoc IControl.onRemove} */\n onRemove() {\n DOM.remove(this._container);\n this._map.off('resize', this._updateCompact);\n this._map = undefined;\n this._compact = undefined;\n }\n\n _updateCompact = () => {\n const containerChildren = this._container.children;\n if (containerChildren.length) {\n const anchor = containerChildren[0];\n if (this._map.getCanvasContainer().offsetWidth <= 640 || this._compact) {\n if (this._compact !== false) {\n anchor.classList.add('maplibregl-compact');\n }\n } else {\n anchor.classList.remove('maplibregl-compact');\n }\n }\n };\n\n}\n","export type TaskID = number;\n\ntype Task = {\n callback: (timeStamp: number) => void;\n id: TaskID;\n cancelled: boolean;\n};\n\nexport class TaskQueue {\n _queue: Array;\n _id: TaskID;\n _cleared: boolean;\n _currentlyRunning: Array | false;\n\n constructor() {\n this._queue = [];\n this._id = 0;\n this._cleared = false;\n this._currentlyRunning = false;\n }\n\n add(callback: (timeStamp: number) => void): TaskID {\n const id = ++this._id;\n const queue = this._queue;\n queue.push({callback, id, cancelled: false});\n return id;\n }\n\n remove(id: TaskID) {\n const running = this._currentlyRunning;\n const queue = running ? this._queue.concat(running) : this._queue;\n for (const task of queue) {\n if (task.id === id) {\n task.cancelled = true;\n return;\n }\n }\n }\n\n run(timeStamp: number = 0) {\n if (this._currentlyRunning) throw new Error('Attempting to run(), but is already running.');\n const queue = this._currentlyRunning = this._queue;\n\n // Tasks queued by callbacks in the current queue should be executed\n // on the next run, not the current run.\n this._queue = [];\n\n for (const task of queue) {\n if (task.cancelled) continue;\n task.callback(timeStamp);\n if (this._cleared) break;\n }\n\n this._cleared = false;\n this._currentlyRunning = false;\n }\n\n clear() {\n if (this._currentlyRunning) {\n this._cleared = true;\n }\n this._queue = [];\n }\n}\n","import {createLayout} from '../util/struct_array';\n\nexport default createLayout([\n {name: 'a_pos3d', type: 'Int16', components: 3}\n]);\n","import {OverscaledTileID} from './tile_id';\nimport {Tile} from './tile';\nimport {EXTENT} from '../data/extent';\nimport {mat4} from 'gl-matrix';\nimport {Evented} from '../util/evented';\nimport type {Transform} from '../geo/transform';\nimport type {SourceCache} from '../source/source_cache';\nimport {Terrain} from '../render/terrain';\n\n/**\n * @internal\n * This class is a helper for the Terrain-class, it:\n *\n * - loads raster-dem tiles\n * - manages all renderToTexture tiles.\n * - caches previous rendered tiles.\n * - finds all necessary renderToTexture tiles for a OverscaledTileID area\n * - finds the corresponding raster-dem tile for OverscaledTileID\n */\nexport class TerrainSourceCache extends Evented {\n /**\n * source-cache for the raster-dem source.\n */\n sourceCache: SourceCache;\n /**\n * stores all render-to-texture tiles.\n */\n _tiles: {[_: string]: Tile};\n /**\n * contains a list of tileID-keys for the current scene. (only for performance)\n */\n _renderableTilesKeys: Array;\n /**\n * raster-dem-tile for a TileID cache.\n */\n _sourceTileCache: {[_: string]: string};\n /**\n * minimum zoomlevel to render the terrain.\n */\n minzoom: number;\n /**\n * maximum zoomlevel to render the terrain.\n */\n maxzoom: number;\n /**\n * render-to-texture tileSize in scene.\n */\n tileSize: number;\n /**\n * raster-dem tiles will load for performance the actualZoom - deltaZoom zoom-level.\n */\n deltaZoom: number;\n\n constructor(sourceCache: SourceCache) {\n super();\n this.sourceCache = sourceCache;\n this._tiles = {};\n this._renderableTilesKeys = [];\n this._sourceTileCache = {};\n this.minzoom = 0;\n this.maxzoom = 22;\n this.tileSize = 512;\n this.deltaZoom = 1;\n sourceCache.usedForTerrain = true;\n sourceCache.tileSize = this.tileSize * 2 ** this.deltaZoom;\n }\n\n destruct() {\n this.sourceCache.usedForTerrain = false;\n this.sourceCache.tileSize = null;\n }\n\n /**\n * Load Terrain Tiles, create internal render-to-texture tiles, free GPU memory.\n * @param transform - the operation to do\n * @param terrain - the terrain\n */\n update(transform: Transform, terrain: Terrain): void {\n // load raster-dem tiles for the current scene.\n this.sourceCache.update(transform, terrain);\n // create internal render-to-texture tiles for the current scene.\n this._renderableTilesKeys = [];\n const keys = {};\n for (const tileID of transform.coveringTiles({\n tileSize: this.tileSize,\n minzoom: this.minzoom,\n maxzoom: this.maxzoom,\n reparseOverscaled: false,\n terrain\n })) {\n keys[tileID.key] = true;\n this._renderableTilesKeys.push(tileID.key);\n if (!this._tiles[tileID.key]) {\n tileID.posMatrix = new Float64Array(16) as any;\n mat4.ortho(tileID.posMatrix, 0, EXTENT, 0, EXTENT, 0, 1);\n this._tiles[tileID.key] = new Tile(tileID, this.tileSize);\n }\n }\n // free unused tiles\n for (const key in this._tiles) {\n if (!keys[key]) delete this._tiles[key];\n }\n }\n\n /**\n * Free render to texture cache\n * @param tileID - optional, free only corresponding to tileID.\n */\n freeRtt(tileID?: OverscaledTileID) {\n for (const key in this._tiles) {\n const tile = this._tiles[key];\n if (!tileID || tile.tileID.equals(tileID) || tile.tileID.isChildOf(tileID) || tileID.isChildOf(tile.tileID))\n tile.rtt = [];\n }\n }\n\n /**\n * get a list of tiles, which are loaded and should be rendered in the current scene\n * @returns the renderable tiles\n */\n getRenderableTiles(): Array {\n return this._renderableTilesKeys.map(key => this.getTileByID(key));\n }\n\n /**\n * get terrain tile by the TileID key\n * @param id - the tile id\n * @returns the tile\n */\n getTileByID(id: string): Tile {\n return this._tiles[id];\n }\n\n /**\n * Searches for the corresponding current renderable terrain-tiles\n * @param tileID - the tile to look for\n * @returns the tiles that were found\n */\n getTerrainCoords(tileID: OverscaledTileID): Record {\n const coords = {};\n for (const key of this._renderableTilesKeys) {\n const _tileID = this._tiles[key].tileID;\n if (_tileID.canonical.equals(tileID.canonical)) {\n const coord = tileID.clone();\n coord.posMatrix = new Float64Array(16) as any;\n mat4.ortho(coord.posMatrix, 0, EXTENT, 0, EXTENT, 0, 1);\n coords[key] = coord;\n } else if (_tileID.canonical.isChildOf(tileID.canonical)) {\n const coord = tileID.clone();\n coord.posMatrix = new Float64Array(16) as any;\n const dz = _tileID.canonical.z - tileID.canonical.z;\n const dx = _tileID.canonical.x - (_tileID.canonical.x >> dz << dz);\n const dy = _tileID.canonical.y - (_tileID.canonical.y >> dz << dz);\n const size = EXTENT >> dz;\n mat4.ortho(coord.posMatrix, 0, size, 0, size, 0, 1);\n mat4.translate(coord.posMatrix, coord.posMatrix, [-dx * size, -dy * size, 0]);\n coords[key] = coord;\n } else if (tileID.canonical.isChildOf(_tileID.canonical)) {\n const coord = tileID.clone();\n coord.posMatrix = new Float64Array(16) as any;\n const dz = tileID.canonical.z - _tileID.canonical.z;\n const dx = tileID.canonical.x - (tileID.canonical.x >> dz << dz);\n const dy = tileID.canonical.y - (tileID.canonical.y >> dz << dz);\n const size = EXTENT >> dz;\n mat4.ortho(coord.posMatrix, 0, EXTENT, 0, EXTENT, 0, 1);\n mat4.translate(coord.posMatrix, coord.posMatrix, [dx * size, dy * size, 0]);\n mat4.scale(coord.posMatrix, coord.posMatrix, [1 / (2 ** dz), 1 / (2 ** dz), 0]);\n coords[key] = coord;\n }\n }\n return coords;\n }\n\n /**\n * find the covering raster-dem tile\n * @param tileID - the tile to look for\n * @param searchForDEM - Optional parameter to search for (parent) sourcetiles with loaded dem.\n * @returns the tile\n */\n getSourceTile(tileID: OverscaledTileID, searchForDEM?: boolean): Tile {\n const source = this.sourceCache._source;\n let z = tileID.overscaledZ - this.deltaZoom;\n if (z > source.maxzoom) z = source.maxzoom;\n if (z < source.minzoom) return null;\n // cache for tileID to terrain-tileID\n if (!this._sourceTileCache[tileID.key])\n this._sourceTileCache[tileID.key] = tileID.scaledTo(z).key;\n let tile = this.sourceCache.getTileByID(this._sourceTileCache[tileID.key]);\n // during tile-loading phase look if parent tiles (with loaded dem) are available.\n if (!(tile && tile.dem) && searchForDEM)\n while (z >= source.minzoom && !(tile && tile.dem))\n tile = this.sourceCache.getTileByID(tileID.scaledTo(z--).key);\n return tile;\n }\n\n /**\n * get a list of tiles, loaded after a specific time. This is used to update depth & coords framebuffers.\n * @param time - the time\n * @returns the relevant tiles\n */\n tilesAfterTime(time = Date.now()): Array {\n return Object.values(this._tiles).filter(t => t.timeAdded >= time);\n }\n}\n","\nimport {Tile} from '../source/tile';\nimport {mat4, vec2} from 'gl-matrix';\nimport {OverscaledTileID} from '../source/tile_id';\nimport {RGBAImage} from '../util/image';\nimport {warnOnce} from '../util/util';\nimport {Pos3dArray, TriangleIndexArray} from '../data/array_types.g';\nimport pos3dAttributes from '../data/pos3d_attributes';\nimport {SegmentVector} from '../data/segment';\nimport {Painter} from './painter';\nimport {Texture} from '../render/texture';\nimport type {Framebuffer} from '../gl/framebuffer';\nimport Point from '@mapbox/point-geometry';\nimport {MercatorCoordinate} from '../geo/mercator_coordinate';\nimport {TerrainSourceCache} from '../source/terrain_source_cache';\nimport {SourceCache} from '../source/source_cache';\nimport {EXTENT} from '../data/extent';\nimport type {TerrainSpecification} from '@maplibre/maplibre-gl-style-spec';\nimport {LngLat, earthRadius} from '../geo/lng_lat';\nimport {Mesh} from './mesh';\nimport {isInBoundsForZoomLngLat} from '../util/world_bounds';\n\n/**\n * @internal\n * A terrain GPU related object\n */\nexport type TerrainData = {\n 'u_depth': number;\n 'u_terrain': number;\n 'u_terrain_dim': number;\n 'u_terrain_matrix': mat4;\n 'u_terrain_unpack': number[];\n 'u_terrain_exaggeration': number;\n texture: WebGLTexture;\n depthTexture: WebGLTexture;\n tile: Tile;\n}\n\n/**\n * @internal\n * This is the main class which handles most of the 3D Terrain logic. It has the following topics:\n *\n * 1. loads raster-dem tiles via the internal sourceCache this.sourceCache\n * 2. creates a depth-framebuffer, which is used to calculate the visibility of coordinates\n * 3. creates a coords-framebuffer, which is used the get to tile-coordinate for a screen-pixel\n * 4. stores all render-to-texture tiles in the this.sourceCache._tiles\n * 5. calculates the elevation for a specific tile-coordinate\n * 6. creates a terrain-mesh\n *\n * A note about the GPU resource-usage:\n *\n * Framebuffers:\n *\n * - one for the depth & coords framebuffer with the size of the map-div.\n * - one for rendering a tile to texture with the size of tileSize (= 512x512).\n *\n * Textures:\n *\n * - one texture for an empty raster-dem tile with size 1x1\n * - one texture for an empty depth-buffer, when terrain is disabled with size 1x1\n * - one texture for an each loaded raster-dem with size of the source.tileSize\n * - one texture for the coords-framebuffer with the size of the map-div.\n * - one texture for the depth-framebuffer with the size of the map-div.\n * - one texture for the encoded tile-coords with the size 2*tileSize (=1024x1024)\n * - finally for each render-to-texture tile (= this._tiles) a set of textures\n * for each render stack (The stack-concept is documented in painter.ts).\n *\n * Normally there exists 1-3 Textures per tile, depending on the stylesheet.\n * Each Textures has the size 2*tileSize (= 1024x1024). Also there exists a\n * cache of the last 150 newest rendered tiles.\n *\n */\nexport class Terrain {\n /**\n * The style this terrain corresponds to\n */\n painter: Painter;\n /**\n * the sourcecache this terrain is based on\n */\n sourceCache: TerrainSourceCache;\n /**\n * the TerrainSpecification object passed to this instance\n */\n options: TerrainSpecification;\n /**\n * define the meshSize per tile.\n */\n meshSize: number;\n /**\n * multiplicator for the elevation. Used to make terrain more \"extreme\".\n */\n exaggeration: number;\n /**\n * to not see pixels in the render-to-texture tiles it is good to render them bigger\n * this number is the multiplicator (must be a power of 2) for the current tileSize.\n * So to get good results with not too much memory footprint a value of 2 should be fine.\n */\n qualityFactor: number;\n /**\n * holds the framebuffer object in size of the screen to render the coords & depth into a texture.\n */\n _fbo: Framebuffer;\n _fboCoordsTexture: Texture;\n _fboDepthTexture: Texture;\n _emptyDepthTexture: Texture;\n /**\n * GL Objects for the terrain-mesh\n * The mesh is a regular mesh, which has the advantage that it can be reused for all tiles.\n */\n _mesh: Mesh;\n /**\n * coords index contains a list of tileID.keys. This index is used to identify\n * the tile via the alpha-cannel in the coords-texture.\n * As the alpha-channel has 1 Byte a max of 255 tiles can rendered without an error.\n */\n coordsIndex: Array;\n /**\n * tile-coords encoded in the rgb channel, _coordsIndex is in the alpha-channel.\n */\n _coordsTexture: Texture;\n /**\n * accuracy of the coords. 2 * tileSize should be enough.\n */\n _coordsTextureSize: number;\n /**\n * variables for an empty dem texture, which is used while the raster-dem tile is loading.\n */\n _emptyDemUnpack: number[];\n _emptyDemTexture: Texture;\n _emptyDemMatrix: mat4;\n /**\n * as of overzooming of raster-dem tiles in high zoomlevels, this cache contains\n * matrices to transform from vector-tile coords to raster-dem-tile coords.\n */\n _demMatrixCache: {[_: string]: { matrix: mat4; coord: OverscaledTileID }};\n\n constructor(painter: Painter, sourceCache: SourceCache, options: TerrainSpecification) {\n this.painter = painter;\n this.sourceCache = new TerrainSourceCache(sourceCache);\n this.options = options;\n this.exaggeration = typeof options.exaggeration === 'number' ? options.exaggeration : 1.0;\n this.qualityFactor = 2;\n this.meshSize = 128;\n this._demMatrixCache = {};\n this.coordsIndex = [];\n this._coordsTextureSize = 1024;\n }\n\n /**\n * get the elevation-value from original dem-data for a given tile-coordinate\n * @param tileID - the tile to get elevation for\n * @param x - between 0 .. EXTENT\n * @param y - between 0 .. EXTENT\n * @param extent - optional, default 8192\n * @returns the elevation\n */\n getDEMElevation(tileID: OverscaledTileID, x: number, y: number, extent: number = EXTENT): number {\n if (!(x >= 0 && x < extent && y >= 0 && y < extent)) return 0;\n const terrain = this.getTerrainData(tileID);\n const dem = terrain.tile?.dem;\n if (!dem)\n return 0;\n\n const pos = vec2.transformMat4([] as any, [x / extent * EXTENT, y / extent * EXTENT], terrain.u_terrain_matrix);\n const coord = [pos[0] * dem.dim, pos[1] * dem.dim];\n\n // bilinear interpolation\n const cx = Math.floor(coord[0]),\n cy = Math.floor(coord[1]),\n tx = coord[0] - cx,\n ty = coord[1] - cy;\n return (\n dem.get(cx, cy) * (1 - tx) * (1 - ty) +\n dem.get(cx + 1, cy) * (tx) * (1 - ty) +\n dem.get(cx, cy + 1) * (1 - tx) * (ty) +\n dem.get(cx + 1, cy + 1) * (tx) * (ty)\n );\n }\n\n /**\n * Get the elevation for given {@link LngLat} in respect of exaggeration.\n * @param lnglat - the location\n * @param zoom - the zoom\n * @returns the elevation\n */\n getElevationForLngLatZoom(lnglat: LngLat, zoom: number) {\n if (!isInBoundsForZoomLngLat(zoom, lnglat.wrap())) return 0;\n const {tileID, mercatorX, mercatorY} = this._getOverscaledTileIDFromLngLatZoom(lnglat, zoom);\n return this.getElevation(tileID, mercatorX % EXTENT, mercatorY % EXTENT, EXTENT);\n }\n\n /**\n * Get the elevation for given coordinate in respect of exaggeration.\n * @param tileID - the tile id\n * @param x - between 0 .. EXTENT\n * @param y - between 0 .. EXTENT\n * @param extent - optional, default 8192\n * @returns the elevation\n */\n getElevation(tileID: OverscaledTileID, x: number, y: number, extent: number = EXTENT): number {\n return this.getDEMElevation(tileID, x, y, extent) * this.exaggeration;\n }\n\n /**\n * returns a Terrain Object for a tile. Unless the tile corresponds to data (e.g. tile is loading), return a flat dem object\n * @param tileID - the tile to get the terrain for\n * @returns the terrain data to use in the program\n */\n getTerrainData(tileID: OverscaledTileID): TerrainData {\n // create empty DEM Objects, which will used while raster-dem tiles are loading.\n // creates an empty depth-buffer texture which is needed, during the initialization process of the 3d mesh..\n if (!this._emptyDemTexture) {\n const context = this.painter.context;\n const image = new RGBAImage({width: 1, height: 1}, new Uint8Array(1 * 4));\n this._emptyDepthTexture = new Texture(context, image, context.gl.RGBA, {premultiply: false});\n this._emptyDemUnpack = [0, 0, 0, 0];\n this._emptyDemTexture = new Texture(context, new RGBAImage({width: 1, height: 1}), context.gl.RGBA, {premultiply: false});\n this._emptyDemTexture.bind(context.gl.NEAREST, context.gl.CLAMP_TO_EDGE);\n this._emptyDemMatrix = mat4.identity([] as any);\n }\n // find covering dem tile and prepare demTexture\n const sourceTile = this.sourceCache.getSourceTile(tileID, true);\n if (sourceTile && sourceTile.dem && (!sourceTile.demTexture || sourceTile.needsTerrainPrepare)) {\n const context = this.painter.context;\n sourceTile.demTexture = this.painter.getTileTexture(sourceTile.dem.stride);\n if (sourceTile.demTexture) sourceTile.demTexture.update(sourceTile.dem.getPixels(), {premultiply: false});\n else sourceTile.demTexture = new Texture(context, sourceTile.dem.getPixels(), context.gl.RGBA, {premultiply: false});\n sourceTile.demTexture.bind(context.gl.NEAREST, context.gl.CLAMP_TO_EDGE);\n sourceTile.needsTerrainPrepare = false;\n }\n // create matrix for lookup in dem data\n const matrixKey = sourceTile && (sourceTile + sourceTile.tileID.key) + tileID.key;\n if (matrixKey && !this._demMatrixCache[matrixKey]) {\n const maxzoom = this.sourceCache.sourceCache._source.maxzoom;\n let dz = tileID.canonical.z - sourceTile.tileID.canonical.z;\n if (tileID.overscaledZ > tileID.canonical.z) {\n if (tileID.canonical.z >= maxzoom) dz = tileID.canonical.z - maxzoom;\n else warnOnce('cannot calculate elevation if elevation maxzoom > source.maxzoom');\n }\n const dx = tileID.canonical.x - (tileID.canonical.x >> dz << dz);\n const dy = tileID.canonical.y - (tileID.canonical.y >> dz << dz);\n const demMatrix = mat4.fromScaling(new Float64Array(16) as any, [1 / (EXTENT << dz), 1 / (EXTENT << dz), 0]);\n mat4.translate(demMatrix, demMatrix, [dx * EXTENT, dy * EXTENT, 0]);\n this._demMatrixCache[tileID.key] = {matrix: demMatrix, coord: tileID};\n }\n // return uniform values & textures\n return {\n 'u_depth': 2,\n 'u_terrain': 3,\n 'u_terrain_dim': sourceTile && sourceTile.dem && sourceTile.dem.dim || 1,\n 'u_terrain_matrix': matrixKey ? this._demMatrixCache[tileID.key].matrix : this._emptyDemMatrix,\n 'u_terrain_unpack': sourceTile && sourceTile.dem && sourceTile.dem.getUnpackVector() || this._emptyDemUnpack,\n 'u_terrain_exaggeration': this.exaggeration,\n texture: (sourceTile && sourceTile.demTexture || this._emptyDemTexture).texture,\n depthTexture: (this._fboDepthTexture || this._emptyDepthTexture).texture,\n tile: sourceTile\n };\n }\n\n /**\n * get a framebuffer as big as the map-div, which will be used to render depth & coords into a texture\n * @param texture - the texture\n * @returns the frame buffer\n */\n getFramebuffer(texture: string): Framebuffer {\n const painter = this.painter;\n const width = painter.width / devicePixelRatio;\n const height = painter.height / devicePixelRatio;\n if (this._fbo && (this._fbo.width !== width || this._fbo.height !== height)) {\n this._fbo.destroy();\n this._fboCoordsTexture.destroy();\n this._fboDepthTexture.destroy();\n delete this._fbo;\n delete this._fboDepthTexture;\n delete this._fboCoordsTexture;\n }\n if (!this._fboCoordsTexture) {\n this._fboCoordsTexture = new Texture(painter.context, {width, height, data: null}, painter.context.gl.RGBA, {premultiply: false});\n this._fboCoordsTexture.bind(painter.context.gl.NEAREST, painter.context.gl.CLAMP_TO_EDGE);\n }\n if (!this._fboDepthTexture) {\n this._fboDepthTexture = new Texture(painter.context, {width, height, data: null}, painter.context.gl.RGBA, {premultiply: false});\n this._fboDepthTexture.bind(painter.context.gl.NEAREST, painter.context.gl.CLAMP_TO_EDGE);\n }\n if (!this._fbo) {\n this._fbo = painter.context.createFramebuffer(width, height, true, false);\n this._fbo.depthAttachment.set(painter.context.createRenderbuffer(painter.context.gl.DEPTH_COMPONENT16, width, height));\n }\n this._fbo.colorAttachment.set(texture === 'coords' ? this._fboCoordsTexture.texture : this._fboDepthTexture.texture);\n return this._fbo;\n }\n\n /**\n * create coords texture, needed to grab coordinates from canvas\n * encode coords coordinate into 4 bytes:\n * - 8 lower bits for x\n * - 8 lower bits for y\n * - 4 higher bits for x\n * - 4 higher bits for y\n * - 8 bits for coordsIndex (1 .. 255) (= number of terraintile), is later setted in draw_terrain uniform value\n * @returns the texture\n */\n getCoordsTexture(): Texture {\n const context = this.painter.context;\n if (this._coordsTexture) return this._coordsTexture;\n const data = new Uint8Array(this._coordsTextureSize * this._coordsTextureSize * 4);\n for (let y = 0, i = 0; y < this._coordsTextureSize; y++) for (let x = 0; x < this._coordsTextureSize; x++, i += 4) {\n data[i + 0] = x & 255;\n data[i + 1] = y & 255;\n data[i + 2] = ((x >> 8) << 4) | (y >> 8);\n data[i + 3] = 0;\n }\n const image = new RGBAImage({width: this._coordsTextureSize, height: this._coordsTextureSize}, new Uint8Array(data.buffer));\n const texture = new Texture(context, image, context.gl.RGBA, {premultiply: false});\n texture.bind(context.gl.NEAREST, context.gl.CLAMP_TO_EDGE);\n this._coordsTexture = texture;\n return texture;\n }\n\n /**\n * Reads a pixel from the coords-framebuffer and translate this to mercator.\n * @param p - Screen-Coordinate\n * @returns mercator coordinate for a screen pixel\n */\n pointCoordinate(p: Point): MercatorCoordinate {\n // First, ensure the coords framebuffer is up to date.\n this.painter.maybeDrawDepthAndCoords(true);\n\n const rgba = new Uint8Array(4);\n const context = this.painter.context, gl = context.gl;\n const px = Math.round(p.x * this.painter.pixelRatio / devicePixelRatio);\n const py = Math.round(p.y * this.painter.pixelRatio / devicePixelRatio);\n const fbHeight = Math.round(this.painter.height / devicePixelRatio);\n // grab coordinate pixel from coordinates framebuffer\n context.bindFramebuffer.set(this.getFramebuffer('coords').framebuffer);\n gl.readPixels(px, fbHeight - py - 1, 1, 1, gl.RGBA, gl.UNSIGNED_BYTE, rgba);\n context.bindFramebuffer.set(null);\n // decode coordinates (encoding see getCoordsTexture)\n const x = rgba[0] + ((rgba[2] >> 4) << 8);\n const y = rgba[1] + ((rgba[2] & 15) << 8);\n const tileID = this.coordsIndex[255 - rgba[3]];\n const tile = tileID && this.sourceCache.getTileByID(tileID);\n if (!tile) return null;\n const coordsSize = this._coordsTextureSize;\n const worldSize = (1 << tile.tileID.canonical.z) * coordsSize;\n return new MercatorCoordinate(\n (tile.tileID.canonical.x * coordsSize + x) / worldSize + tile.tileID.wrap,\n (tile.tileID.canonical.y * coordsSize + y) / worldSize,\n this.getElevation(tile.tileID, x, y, coordsSize)\n );\n }\n\n /**\n * Reads the depth value from the depth-framebuffer at a given screen pixel\n * @param p - Screen coordinate\n * @returns depth value in clip space (between 0 and 1)\n */\n\n depthAtPoint(p: Point): number {\n const rgba = new Uint8Array(4);\n const context = this.painter.context, gl = context.gl;\n context.bindFramebuffer.set(this.getFramebuffer('depth').framebuffer);\n gl.readPixels(p.x, this.painter.height / devicePixelRatio - p.y - 1, 1, 1, gl.RGBA, gl.UNSIGNED_BYTE, rgba);\n context.bindFramebuffer.set(null);\n // decode coordinates (encoding see terran_depth.fragment.glsl)\n const depthValue = (rgba[0] / (256 * 256 * 256) + rgba[1] / (256 * 256) + rgba[2] / 256 + rgba[3]) / 256;\n return depthValue;\n }\n\n /**\n * create a regular mesh which will be used by all terrain-tiles\n * @returns the created regular mesh\n */\n getTerrainMesh(): Mesh {\n if (this._mesh) return this._mesh;\n const context = this.painter.context;\n const vertexArray = new Pos3dArray();\n const indexArray = new TriangleIndexArray();\n const meshSize = this.meshSize;\n const delta = EXTENT / meshSize;\n const meshSize2 = meshSize * meshSize;\n for (let y = 0; y <= meshSize; y++) for (let x = 0; x <= meshSize; x++)\n vertexArray.emplaceBack(x * delta, y * delta, 0);\n for (let y = 0; y < meshSize2; y += meshSize + 1) for (let x = 0; x < meshSize; x++) {\n indexArray.emplaceBack(x + y, meshSize + x + y + 1, meshSize + x + y + 2);\n indexArray.emplaceBack(x + y, meshSize + x + y + 2, x + y + 1);\n }\n // add an extra frame around the mesh to avoid stiching on tile boundaries with different zoomlevels\n // first code-block is for top-bottom frame and second for left-right frame\n const offsetTop = vertexArray.length, offsetBottom = offsetTop + (meshSize + 1) * 2;\n for (const y of [0, 1]) for (let x = 0; x <= meshSize; x++) for (const z of [0, 1])\n vertexArray.emplaceBack(x * delta, y * EXTENT, z);\n for (let x = 0; x < meshSize * 2; x += 2) {\n indexArray.emplaceBack(offsetBottom + x, offsetBottom + x + 1, offsetBottom + x + 3);\n indexArray.emplaceBack(offsetBottom + x, offsetBottom + x + 3, offsetBottom + x + 2);\n indexArray.emplaceBack(offsetTop + x, offsetTop + x + 3, offsetTop + x + 1);\n indexArray.emplaceBack(offsetTop + x, offsetTop + x + 2, offsetTop + x + 3);\n }\n const offsetLeft = vertexArray.length, offsetRight = offsetLeft + (meshSize + 1) * 2;\n for (const x of [0, 1]) for (let y = 0; y <= meshSize; y++) for (const z of [0, 1])\n vertexArray.emplaceBack(x * EXTENT, y * delta, z);\n for (let y = 0; y < meshSize * 2; y += 2) {\n indexArray.emplaceBack(offsetLeft + y, offsetLeft + y + 1, offsetLeft + y + 3);\n indexArray.emplaceBack(offsetLeft + y, offsetLeft + y + 3, offsetLeft + y + 2);\n indexArray.emplaceBack(offsetRight + y, offsetRight + y + 3, offsetRight + y + 1);\n indexArray.emplaceBack(offsetRight + y, offsetRight + y + 2, offsetRight + y + 3);\n }\n this._mesh = new Mesh(\n context.createVertexBuffer(vertexArray, pos3dAttributes.members),\n context.createIndexBuffer(indexArray),\n SegmentVector.simpleSegment(0, 0, vertexArray.length, indexArray.length)\n );\n return this._mesh;\n }\n\n /**\n * Calculates a height of the frame around the terrain-mesh to avoid stiching between\n * tile boundaries in different zoomlevels.\n * @param zoom - current zoomlevel\n * @returns the elevation delta in meters\n */\n getMeshFrameDelta(zoom: number): number {\n // divide by 5 is evaluated by trial & error to get a frame in the right height\n return 2 * Math.PI * earthRadius / Math.pow(2, zoom) / 5;\n }\n\n getMinTileElevationForLngLatZoom(lnglat: LngLat, zoom: number) {\n const {tileID} = this._getOverscaledTileIDFromLngLatZoom(lnglat, zoom);\n return this.getMinMaxElevation(tileID).minElevation ?? 0;\n }\n\n /**\n * Get the minimum and maximum elevation contained in a tile. This includes any\n * exaggeration included in the terrain.\n *\n * @param tileID - ID of the tile to be used as a source for the min/max elevation\n * @returns the minimum and maximum elevation found in the tile, including the terrain's\n * exaggeration\n */\n getMinMaxElevation(tileID: OverscaledTileID): {minElevation: number | null; maxElevation: number | null} {\n const tile = this.getTerrainData(tileID).tile;\n const minMax = {minElevation: null, maxElevation: null};\n if (tile && tile.dem) {\n minMax.minElevation = tile.dem.min * this.exaggeration;\n minMax.maxElevation = tile.dem.max * this.exaggeration;\n }\n return minMax;\n }\n\n _getOverscaledTileIDFromLngLatZoom(lnglat: LngLat, zoom: number): { tileID: OverscaledTileID; mercatorX: number; mercatorY: number} {\n const mercatorCoordinate = MercatorCoordinate.fromLngLat(lnglat.wrap());\n const worldSize = (1 << zoom) * EXTENT;\n const mercatorX = mercatorCoordinate.x * worldSize;\n const mercatorY = mercatorCoordinate.y * worldSize;\n const tileX = Math.floor(mercatorX / EXTENT), tileY = Math.floor(mercatorY / EXTENT);\n const tileID = new OverscaledTileID(zoom, 0, zoom, tileX, tileY);\n return {\n tileID,\n mercatorX,\n mercatorY\n };\n }\n}\n","import {Texture} from '../render/texture';\nimport {Context} from './context';\nimport {Framebuffer} from './framebuffer';\n\nexport type PoolObject = {\n id: number;\n fbo: Framebuffer;\n texture: Texture;\n stamp: number;\n inUse: boolean;\n};\n/**\n * @internal\n * `RenderPool` is a resource pool for textures and framebuffers\n */\nexport class RenderPool {\n private _objects: Array;\n /**\n * An index array of recently used pool objects.\n * Items that are used recently are last in the array\n */\n private _recentlyUsed: Array;\n private _stamp: number;\n\n constructor(\n private readonly _context: Context,\n private readonly _size: number,\n private readonly _tileSize: number) {\n this._objects = [];\n this._recentlyUsed = [];\n this._stamp = 0;\n }\n\n public destruct() {\n for (const obj of this._objects) {\n obj.texture.destroy();\n obj.fbo.destroy();\n }\n }\n\n private _createObject(id: number): PoolObject {\n const fbo = this._context.createFramebuffer(this._tileSize, this._tileSize, true, true);\n const texture = new Texture(this._context, {width: this._tileSize, height: this._tileSize, data: null}, this._context.gl.RGBA);\n texture.bind(this._context.gl.LINEAR, this._context.gl.CLAMP_TO_EDGE);\n fbo.depthAttachment.set(this._context.createRenderbuffer(this._context.gl.DEPTH_STENCIL, this._tileSize, this._tileSize));\n fbo.colorAttachment.set(texture.texture);\n return {id, fbo, texture, stamp: -1, inUse: false};\n }\n\n public getObjectForId(id: number): PoolObject {\n return this._objects[id];\n }\n\n public useObject(obj: PoolObject) {\n obj.inUse = true;\n this._recentlyUsed = this._recentlyUsed.filter(id => obj.id !== id);\n this._recentlyUsed.push(obj.id);\n }\n\n public stampObject(obj: PoolObject) {\n obj.stamp = ++this._stamp;\n }\n\n public getOrCreateFreeObject(): PoolObject {\n // check for free existing object\n for (const id of this._recentlyUsed) {\n if (!this._objects[id].inUse)\n return this._objects[id];\n }\n if (this._objects.length >= this._size)\n throw new Error('No free RenderPool available, call freeAllObjects() required!');\n // create new object\n const obj = this._createObject(this._objects.length);\n this._objects.push(obj);\n return obj;\n }\n\n public freeObject(obj: PoolObject) {\n obj.inUse = false;\n }\n\n public freeAllObjects() {\n for (const obj of this._objects)\n this.freeObject(obj);\n }\n\n public isFull(): boolean {\n if (this._objects.length < this._size) {\n return false;\n }\n return this._objects.some(o => !o.inUse) === false;\n }\n}\n","import {Painter} from './painter';\nimport {Tile} from '../source/tile';\nimport {Color} from '@maplibre/maplibre-gl-style-spec';\nimport {OverscaledTileID} from '../source/tile_id';\nimport {drawTerrain} from './draw_terrain';\nimport {Style} from '../style/style';\nimport {Terrain} from './terrain';\nimport {RenderPool} from '../gl/render_pool';\nimport {Texture} from './texture';\nimport type {StyleLayer} from '../style/style_layer';\n\n/**\n * lookup table which layers should rendered to texture\n */\nconst LAYERS: { [keyof in StyleLayer['type']]?: boolean } = {\n background: true,\n fill: true,\n line: true,\n raster: true,\n hillshade: true\n};\n\n/**\n * @internal\n * A helper class to help define what should be rendered to texture and how\n */\nexport class RenderToTexture {\n painter: Painter;\n terrain: Terrain;\n pool: RenderPool;\n /**\n * coordsDescendingInv contains a list of all tiles which should be rendered for one render-to-texture tile\n * e.g. render 4 raster-tiles with size 256px to the 512px render-to-texture tile\n */\n _coordsDescendingInv: {[_: string]: {[_:string]: Array}};\n /**\n * create a string representation of all to tiles rendered to render-to-texture tiles\n * this string representation is used to check if tile should be re-rendered.\n */\n _coordsDescendingInvStr: {[_: string]: {[_:string]: string}};\n /**\n * store for render-stacks\n * a render stack is a set of layers which should be rendered into one texture\n * every stylesheet can have multiple stacks. A new stack is created if layers which should\n * not rendered to texture sit between layers which should rendered to texture. e.g. hillshading or symbols\n */\n _stacks: Array>;\n /**\n * remember the previous processed layer to check if a new stack is needed\n */\n _prevType: string;\n /**\n * a list of tiles that can potentially rendered\n */\n _renderableTiles: Array;\n /**\n * a list of tiles that should be rendered to screen in the next render-call\n */\n _rttTiles: Array;\n /**\n * a list of all layer-ids which should be rendered\n */\n _renderableLayerIds: Array;\n\n constructor(painter: Painter, terrain: Terrain) {\n this.painter = painter;\n this.terrain = terrain;\n this.pool = new RenderPool(painter.context, 30, terrain.sourceCache.tileSize * terrain.qualityFactor);\n }\n\n destruct() {\n this.pool.destruct();\n }\n\n getTexture(tile: Tile): Texture {\n return this.pool.getObjectForId(tile.rtt[this._stacks.length - 1].id).texture;\n }\n\n prepareForRender(style: Style, zoom: number) {\n this._stacks = [];\n this._prevType = null;\n this._rttTiles = [];\n this._renderableTiles = this.terrain.sourceCache.getRenderableTiles();\n this._renderableLayerIds = style._order.filter(id => !style._layers[id].isHidden(zoom));\n\n this._coordsDescendingInv = {};\n for (const id in style.sourceCaches) {\n this._coordsDescendingInv[id] = {};\n const tileIDs = style.sourceCaches[id].getVisibleCoordinates();\n for (const tileID of tileIDs) {\n const keys = this.terrain.sourceCache.getTerrainCoords(tileID);\n for (const key in keys) {\n if (!this._coordsDescendingInv[id][key]) this._coordsDescendingInv[id][key] = [];\n this._coordsDescendingInv[id][key].push(keys[key]);\n }\n }\n }\n\n this._coordsDescendingInvStr = {};\n for (const id of style._order) {\n const layer = style._layers[id], source = layer.source;\n if (LAYERS[layer.type]) {\n if (!this._coordsDescendingInvStr[source]) {\n this._coordsDescendingInvStr[source] = {};\n for (const key in this._coordsDescendingInv[source])\n this._coordsDescendingInvStr[source][key] = this._coordsDescendingInv[source][key].map(c => c.key).sort().join();\n }\n }\n }\n\n // check tiles to render\n for (const tile of this._renderableTiles) {\n for (const source in this._coordsDescendingInvStr) {\n // rerender if there are more coords to render than in the last rendering\n const coords = this._coordsDescendingInvStr[source][tile.tileID.key];\n if (coords && coords !== tile.rttCoords[source]) tile.rtt = [];\n }\n }\n }\n\n /**\n * due that switching textures is relatively slow, the render\n * layer-by-layer context is not practicable. To bypass this problem\n * this lines of code stack all layers and later render all at once.\n * Because of the stylesheet possibility to mixing render-to-texture layers\n * and 'live'-layers (f.e. symbols) it is necessary to create more stacks. For example\n * a symbol-layer is in between of fill-layers.\n * @param layer - the layer to render\n * @returns if true layer is rendered to texture, otherwise false\n */\n renderLayer(layer: StyleLayer): boolean {\n if (layer.isHidden(this.painter.transform.zoom)) return false;\n\n const type = layer.type;\n const painter = this.painter;\n const isLastLayer = this._renderableLayerIds[this._renderableLayerIds.length - 1] === layer.id;\n\n // remember background, fill, line & raster layer to render into a stack\n if (LAYERS[type]) {\n // create a new stack if previous layer was not rendered to texture (f.e. symbols)\n if (!this._prevType || !LAYERS[this._prevType]) this._stacks.push([]);\n // push current render-to-texture layer to render-stack\n this._prevType = type;\n this._stacks[this._stacks.length - 1].push(layer.id);\n // rendering is done later, all in once\n if (!isLastLayer) return true;\n }\n\n // in case a stack is finished render all collected stack-layers into a texture\n if (LAYERS[this._prevType] || (LAYERS[type] && isLastLayer)) {\n this._prevType = type;\n const stack = this._stacks.length - 1, layers = this._stacks[stack] || [];\n for (const tile of this._renderableTiles) {\n // if render pool is full draw current tiles to screen and free pool\n if (this.pool.isFull()) {\n drawTerrain(this.painter, this.terrain, this._rttTiles);\n this._rttTiles = [];\n this.pool.freeAllObjects();\n }\n this._rttTiles.push(tile);\n // check for cached PoolObject\n if (tile.rtt[stack]) {\n const obj = this.pool.getObjectForId(tile.rtt[stack].id);\n if (obj.stamp === tile.rtt[stack].stamp) {\n this.pool.useObject(obj);\n continue;\n }\n }\n // get free PoolObject\n const obj = this.pool.getOrCreateFreeObject();\n this.pool.useObject(obj);\n this.pool.stampObject(obj);\n tile.rtt[stack] = {id: obj.id, stamp: obj.stamp};\n // prepare PoolObject for rendering\n painter.context.bindFramebuffer.set(obj.fbo.framebuffer);\n painter.context.clear({color: Color.transparent, stencil: 0});\n painter.currentStencilSource = undefined;\n for (let l = 0; l < layers.length; l++) {\n const layer = painter.style._layers[layers[l]];\n const coords = layer.source ? this._coordsDescendingInv[layer.source][tile.tileID.key] : [tile.tileID];\n painter.context.viewport.set([0, 0, obj.fbo.width, obj.fbo.height]);\n painter._renderTileClippingMasks(layer, coords);\n painter.renderLayer(painter, painter.style.sourceCaches[layer.source], layer, coords);\n if (layer.source) tile.rttCoords[layer.source] = this._coordsDescendingInvStr[layer.source][tile.tileID.key];\n }\n }\n drawTerrain(this.painter, this.terrain, this._rttTiles);\n this._rttTiles = [];\n this.pool.freeAllObjects();\n\n return LAYERS[type];\n }\n\n return false;\n }\n\n}\n","export const defaultLocale = {\n 'AttributionControl.ToggleAttribution': 'Toggle attribution',\n 'AttributionControl.MapFeedback': 'Map feedback',\n 'FullscreenControl.Enter': 'Enter fullscreen',\n 'FullscreenControl.Exit': 'Exit fullscreen',\n 'GeolocateControl.FindMyLocation': 'Find my location',\n 'GeolocateControl.LocationNotAvailable': 'Location not available',\n 'LogoControl.Title': 'MapLibre logo',\n 'Map.Title': 'Map',\n 'Marker.Title': 'Map marker',\n 'NavigationControl.ResetBearing': 'Reset bearing to north',\n 'NavigationControl.ZoomIn': 'Zoom in',\n 'NavigationControl.ZoomOut': 'Zoom out',\n 'Popup.Close': 'Close popup',\n 'ScaleControl.Feet': 'ft',\n 'ScaleControl.Meters': 'm',\n 'ScaleControl.Kilometers': 'km',\n 'ScaleControl.Miles': 'mi',\n 'ScaleControl.NauticalMiles': 'nm',\n 'TerrainControl.Enable': 'Enable terrain',\n 'TerrainControl.Disable': 'Disable terrain',\n 'CooperativeGesturesHandler.WindowsHelpText': 'Use Ctrl + scroll to zoom the map',\n 'CooperativeGesturesHandler.MacHelpText': 'Use ⌘ + scroll to zoom the map',\n 'CooperativeGesturesHandler.MobileHelpText': 'Use two fingers to move the map',\n};\n","import {extend, warnOnce, uniqueId, isImageBitmap, Complete} from '../util/util';\nimport {browser} from '../util/browser';\nimport {DOM} from '../util/dom';\nimport packageJSON from '../../package.json' with {type: 'json'};\nimport {GetResourceResponse, getJSON} from '../util/ajax';\nimport {ImageRequest} from '../util/image_request';\nimport {RequestManager, ResourceType} from '../util/request_manager';\nimport {Style, StyleSwapOptions} from '../style/style';\nimport {EvaluationParameters} from '../style/evaluation_parameters';\nimport {Painter} from '../render/painter';\nimport {Transform} from '../geo/transform';\nimport {Hash} from './hash';\nimport {HandlerManager} from './handler_manager';\nimport {Camera, CameraOptions, CameraUpdateTransformFunction, FitBoundsOptions} from './camera';\nimport {LngLat} from '../geo/lng_lat';\nimport {LngLatBounds} from '../geo/lng_lat_bounds';\nimport Point from '@mapbox/point-geometry';\nimport {AttributionControl, AttributionControlOptions, defaultAttributionControlOptions} from './control/attribution_control';\nimport {LogoControl} from './control/logo_control';\nimport {RGBAImage} from '../util/image';\nimport {Event, ErrorEvent, Listener} from '../util/evented';\nimport {MapEventType, MapLayerEventType, MapMouseEvent, MapSourceDataEvent, MapStyleDataEvent} from './events';\nimport {TaskQueue} from '../util/task_queue';\nimport {throttle} from '../util/throttle';\nimport {webpSupported} from '../util/webp_supported';\nimport {PerformanceMarkers, PerformanceUtils} from '../util/performance';\nimport {Source} from '../source/source';\nimport {StyleLayer} from '../style/style_layer';\nimport {Terrain} from '../render/terrain';\nimport {RenderToTexture} from '../render/render_to_texture';\nimport {config} from '../util/config';\nimport {defaultLocale} from './default_locale';\n\nimport type {RequestTransformFunction} from '../util/request_manager';\nimport type {LngLatLike} from '../geo/lng_lat';\nimport type {LngLatBoundsLike} from '../geo/lng_lat_bounds';\nimport type {AddLayerObject, FeatureIdentifier, StyleOptions, StyleSetterOptions} from '../style/style';\nimport type {MapDataEvent} from './events';\nimport type {StyleImage, StyleImageInterface, StyleImageMetadata} from '../style/style_image';\nimport type {PointLike} from './camera';\nimport type {ScrollZoomHandler} from './handler/scroll_zoom';\nimport type {BoxZoomHandler} from './handler/box_zoom';\nimport type {AroundCenterOptions, TwoFingersTouchPitchHandler} from './handler/two_fingers_touch';\nimport type {DragRotateHandler} from './handler/shim/drag_rotate';\nimport type {DragPanHandler, DragPanOptions} from './handler/shim/drag_pan';\nimport type {CooperativeGesturesHandler, GestureOptions} from './handler/cooperative_gestures';\nimport type {KeyboardHandler} from './handler/keyboard';\nimport type {DoubleClickZoomHandler} from './handler/shim/dblclick_zoom';\nimport type {TwoFingersTouchZoomRotateHandler} from './handler/shim/two_fingers_touch';\nimport type {TaskID} from '../util/task_queue';\nimport type {\n FilterSpecification,\n StyleSpecification,\n LightSpecification,\n SourceSpecification,\n TerrainSpecification,\n SkySpecification\n} from '@maplibre/maplibre-gl-style-spec';\nimport type {CanvasSourceSpecification} from '../source/canvas_source';\nimport type {MapGeoJSONFeature} from '../util/vectortile_to_geojson';\nimport type {ControlPosition, IControl} from './control/control';\nimport type {QueryRenderedFeaturesOptions, QuerySourceFeatureOptions} from '../source/query_features';\n\nconst version = packageJSON.version;\n\n/**\n * The {@link Map} options object.\n */\nexport type MapOptions = {\n /**\n * If `true`, the map's position (zoom, center latitude, center longitude, bearing, and pitch) will be synced with the hash fragment of the page's URL.\n * For example, `http://path/to/my/page.html#2.59/39.26/53.07/-24.1/60`.\n * An additional string may optionally be provided to indicate a parameter-styled hash,\n * e.g. http://path/to/my/page.html#map=2.59/39.26/53.07/-24.1/60&foo=bar, where foo\n * is a custom parameter and bar is an arbitrary hash distinct from the map hash.\n * @defaultValue false\n */\n hash?: boolean | string;\n /**\n * If `false`, no mouse, touch, or keyboard listeners will be attached to the map, so it will not respond to interaction.\n * @defaultValue true\n */\n interactive?: boolean;\n /**\n * The HTML element in which MapLibre GL JS will render the map, or the element's string `id`. The specified element must have no children.\n */\n container: HTMLElement | string;\n /**\n * The threshold, measured in degrees, that determines when the map's\n * bearing will snap to north. For example, with a `bearingSnap` of 7, if the user rotates\n * the map within 7 degrees of north, the map will automatically snap to exact north.\n * @defaultValue 7\n */\n bearingSnap?: number;\n /**\n * If set, an {@link AttributionControl} will be added to the map with the provided options.\n * To disable the attribution control, pass `false`.\n * Note: showing the logo of MapLibre is not required for using MapLibre.\n * @defaultValue compact: true, customAttribution: \"MapLibre ...\".\n */\n attributionControl?: false | AttributionControlOptions;\n /**\n * If `true`, the MapLibre logo will be shown.\n */\n maplibreLogo?: boolean;\n /**\n * A string representing the position of the MapLibre wordmark on the map. Valid options are `top-left`,`top-right`, `bottom-left`, or `bottom-right`.\n * @defaultValue 'bottom-left'\n */\n logoPosition?: ControlPosition;\n /**\n * If `true`, map creation will fail if the performance of MapLibre GL JS would be dramatically worse than expected\n * (i.e. a software renderer would be used).\n * @defaultValue false\n */\n failIfMajorPerformanceCaveat?: boolean;\n /**\n * If `true`, the map's canvas can be exported to a PNG using `map.getCanvas().toDataURL()`. This is `false` by default as a performance optimization.\n * @defaultValue false\n */\n preserveDrawingBuffer?: boolean;\n /**\n * If `true`, the gl context will be created with MSAA antialiasing, which can be useful for antialiasing custom layers.\n * Disabled by default as a performance optimization.\n */\n antialias?: boolean;\n /**\n * If `false`, the map won't attempt to re-request tiles once they expire per their HTTP `cacheControl`/`expires` headers.\n * @defaultValue true\n */\n refreshExpiredTiles?: boolean;\n /**\n * If set, the map will be constrained to the given bounds.\n */\n maxBounds?: LngLatBoundsLike;\n /**\n * If `true`, the \"scroll to zoom\" interaction is enabled. {@link AroundCenterOptions} are passed as options to {@link ScrollZoomHandler#enable}.\n * @defaultValue true\n */\n scrollZoom?: boolean | AroundCenterOptions;\n /**\n * The minimum zoom level of the map (0-24).\n * @defaultValue 0\n */\n minZoom?: number | null;\n /**\n * The maximum zoom level of the map (0-24).\n * @defaultValue 22\n */\n maxZoom?: number | null;\n /**\n * The minimum pitch of the map (0-85). Values greater than 60 degrees are experimental and may result in rendering issues. If you encounter any, please raise an issue with details in the MapLibre project.\n * @defaultValue 0\n */\n minPitch?: number | null;\n /**\n * The maximum pitch of the map (0-85). Values greater than 60 degrees are experimental and may result in rendering issues. If you encounter any, please raise an issue with details in the MapLibre project.\n * @defaultValue 60\n */\n maxPitch?: number | null;\n /**\n * If `true`, the \"box zoom\" interaction is enabled (see {@link BoxZoomHandler}).\n * @defaultValue true\n */\n boxZoom?: boolean;\n /**\n * If `true`, the \"drag to rotate\" interaction is enabled (see {@link DragRotateHandler}).\n * @defaultValue true\n */\n dragRotate?: boolean;\n /**\n * If `true`, the \"drag to pan\" interaction is enabled. An `Object` value is passed as options to {@link DragPanHandler#enable}.\n * @defaultValue true\n */\n dragPan?: boolean | DragPanOptions;\n /**\n * If `true`, keyboard shortcuts are enabled (see {@link KeyboardHandler}).\n * @defaultValue true\n */\n keyboard?: boolean;\n /**\n * If `true`, the \"double click to zoom\" interaction is enabled (see {@link DoubleClickZoomHandler}).\n * @defaultValue true\n */\n doubleClickZoom?: boolean;\n /**\n * If `true`, the \"pinch to rotate and zoom\" interaction is enabled. An `Object` value is passed as options to {@link TwoFingersTouchZoomRotateHandler#enable}.\n * @defaultValue true\n */\n touchZoomRotate?: boolean | AroundCenterOptions;\n /**\n * If `true`, the \"drag to pitch\" interaction is enabled. An `Object` value is passed as options to {@link TwoFingersTouchPitchHandler#enable}.\n * @defaultValue true\n */\n touchPitch?: boolean | AroundCenterOptions;\n /**\n * If `true` or set to an options object, the map is only accessible on desktop while holding Command/Ctrl and only accessible on mobile with two fingers. Interacting with the map using normal gestures will trigger an informational screen. With this option enabled, \"drag to pitch\" requires a three-finger gesture. Cooperative gestures are disabled when a map enters fullscreen using {@link FullscreenControl}.\n * @defaultValue false\n */\n cooperativeGestures?: GestureOptions;\n /**\n * If `true`, the map will automatically resize when the browser window resizes.\n * @defaultValue true\n */\n trackResize?: boolean;\n /**\n * The initial geographical centerpoint of the map. If `center` is not specified in the constructor options, MapLibre GL JS will look for it in the map's style object. If it is not specified in the style, either, it will default to `[0, 0]` Note: MapLibre GL JS uses longitude, latitude coordinate order (as opposed to latitude, longitude) to match GeoJSON.\n * @defaultValue [0, 0]\n */\n center?: LngLatLike;\n /**\n * The initial zoom level of the map. If `zoom` is not specified in the constructor options, MapLibre GL JS will look for it in the map's style object. If it is not specified in the style, either, it will default to `0`.\n * @defaultValue 0\n */\n zoom?: number;\n /**\n * The initial bearing (rotation) of the map, measured in degrees counter-clockwise from north. If `bearing` is not specified in the constructor options, MapLibre GL JS will look for it in the map's style object. If it is not specified in the style, either, it will default to `0`.\n * @defaultValue 0\n */\n bearing?: number;\n /**\n * The initial pitch (tilt) of the map, measured in degrees away from the plane of the screen (0-85). If `pitch` is not specified in the constructor options, MapLibre GL JS will look for it in the map's style object. If it is not specified in the style, either, it will default to `0`. Values greater than 60 degrees are experimental and may result in rendering issues. If you encounter any, please raise an issue with details in the MapLibre project.\n * @defaultValue 0\n */\n pitch?: number;\n /**\n * If `true`, multiple copies of the world will be rendered side by side beyond -180 and 180 degrees longitude. If set to `false`:\n *\n * - When the map is zoomed out far enough that a single representation of the world does not fill the map's entire\n * container, there will be blank space beyond 180 and -180 degrees longitude.\n * - Features that cross 180 and -180 degrees longitude will be cut in two (with one portion on the right edge of the\n * map and the other on the left edge of the map) at every zoom level.\n * @defaultValue true\n */\n renderWorldCopies?: boolean;\n /**\n * The maximum number of tiles stored in the tile cache for a given source. If omitted, the cache will be dynamically sized based on the current viewport which can be set using `maxTileCacheZoomLevels` constructor options.\n * @defaultValue null\n */\n maxTileCacheSize?: number | null;\n /**\n * The maximum number of zoom levels for which to store tiles for a given source. Tile cache dynamic size is calculated by multiplying `maxTileCacheZoomLevels` with the approximate number of tiles in the viewport for a given source.\n * @defaultValue 5\n */\n maxTileCacheZoomLevels?: number;\n /**\n * A callback run before the Map makes a request for an external URL. The callback can be used to modify the url, set headers, or set the credentials property for cross-origin requests.\n * Expected to return an object with a `url` property and optionally `headers` and `credentials` properties.\n * @defaultValue null\n */\n transformRequest?: RequestTransformFunction | null;\n /**\n * A callback run before the map's camera is moved due to user input or animation. The callback can be used to modify the new center, zoom, pitch and bearing.\n * Expected to return an object containing center, zoom, pitch or bearing values to overwrite.\n * @defaultValue null\n */\n transformCameraUpdate?: CameraUpdateTransformFunction | null;\n /**\n * A patch to apply to the default localization table for UI strings, e.g. control tooltips. The `locale` object maps namespaced UI string IDs to translated strings in the target language; see `src/ui/default_locale.js` for an example with all supported string IDs. The object may specify all UI strings (thereby adding support for a new translation) or only a subset of strings (thereby patching the default translation table).\n * @defaultValue null\n */\n locale?: any;\n /**\n * Controls the duration of the fade-in/fade-out animation for label collisions after initial map load, in milliseconds. This setting affects all symbol layers. This setting does not affect the duration of runtime styling transitions or raster tile cross-fading.\n * @defaultValue 300\n */\n fadeDuration?: number;\n /**\n * If `true`, symbols from multiple sources can collide with each other during collision detection. If `false`, collision detection is run separately for the symbols in each source.\n * @defaultValue true\n */\n crossSourceCollisions?: boolean;\n /**\n * If `true`, Resource Timing API information will be collected for requests made by GeoJSON and Vector Tile web workers (this information is normally inaccessible from the main Javascript thread). Information will be returned in a `resourceTiming` property of relevant `data` events.\n * @defaultValue false\n */\n collectResourceTiming?: boolean;\n /**\n * The max number of pixels a user can shift the mouse pointer during a click for it to be considered a valid click (as opposed to a mouse drag).\n * @defaultValue 3\n */\n clickTolerance?: number;\n /**\n * The initial bounds of the map. If `bounds` is specified, it overrides `center` and `zoom` constructor options.\n */\n bounds?: LngLatBoundsLike;\n /**\n * A {@link FitBoundsOptions} options object to use _only_ when fitting the initial `bounds` provided above.\n */\n fitBoundsOptions?: FitBoundsOptions;\n /**\n * Defines a CSS\n * font-family for locally overriding generation of Chinese, Japanese, and Korean characters.\n * For these characters, font settings from the map's style will be ignored, except for font-weight keywords (light/regular/medium/bold).\n * Set to `false`, to enable font settings from the map's style for these glyph ranges.\n * The purpose of this option is to avoid bandwidth-intensive glyph server requests. (See [Use locally generated ideographs](https://maplibre.org/maplibre-gl-js/docs/examples/local-ideographs).)\n * @defaultValue 'sans-serif'\n */\n localIdeographFontFamily?: string | false;\n /**\n * The map's MapLibre style. This must be a JSON object conforming to\n * the schema described in the [MapLibre Style Specification](https://maplibre.org/maplibre-style-spec/),\n * or a URL to such JSON.\n * When the style is not specified, calling {@link Map#setStyle} is required to render the map.\n */\n style?: StyleSpecification | string;\n /**\n * If `false`, the map's pitch (tilt) control with \"drag to rotate\" interaction will be disabled.\n * @defaultValue true\n */\n pitchWithRotate?: boolean;\n /**\n * The pixel ratio.\n * The canvas' `width` attribute will be `container.clientWidth * pixelRatio` and its `height` attribute will be `container.clientHeight * pixelRatio`. Defaults to `devicePixelRatio` if not specified.\n */\n pixelRatio?: number;\n /**\n * If false, style validation will be skipped. Useful in production environment.\n * @defaultValue true\n */\n validateStyle?: boolean;\n /**\n * The canvas' `width` and `height` max size. The values are passed as an array where the first element is max width and the second element is max height.\n * You shouldn't set this above WebGl `MAX_TEXTURE_SIZE`.\n * @defaultValue [4096, 4096].\n */\n maxCanvasSize?: [number, number];\n /**\n * Determines whether to cancel, or retain, tiles from the current viewport which are still loading but which belong to a farther (smaller) zoom level than the current one.\n * * If `true`, when zooming in, tiles which didn't manage to load for previous zoom levels will become canceled. This might save some computing resources for slower devices, but the map details might appear more abruptly at the end of the zoom.\n * * If `false`, when zooming in, the previous zoom level(s) tiles will progressively appear, giving a smoother map details experience. However, more tiles will be rendered in a short period of time.\n * @defaultValue true\n */\n cancelPendingTileRequestsWhileZooming?: boolean;\n};\n\nexport type AddImageOptions = {\n\n}\n\n// This type is used inside map since all properties are assigned a default value.\nexport type CompleteMapOptions = Complete;\n\ntype DelegatedListener = {\n layers: string[];\n listener: Listener;\n delegates: {[E in keyof MapEventType]?: Delegate};\n}\n\ntype Delegate = (e: E) => void;\n\nconst defaultMinZoom = -2;\nconst defaultMaxZoom = 22;\n\n// the default values, but also the valid range\nconst defaultMinPitch = 0;\nconst defaultMaxPitch = 60;\n\n// use this variable to check maxPitch for validity\nconst maxPitchThreshold = 85;\n\nconst defaultOptions: Readonly> = {\n hash: false,\n interactive: true,\n bearingSnap: 7,\n attributionControl: defaultAttributionControlOptions,\n maplibreLogo: false,\n failIfMajorPerformanceCaveat: false,\n preserveDrawingBuffer: false,\n refreshExpiredTiles: true,\n\n scrollZoom: true,\n minZoom: defaultMinZoom,\n maxZoom: defaultMaxZoom,\n minPitch: defaultMinPitch,\n maxPitch: defaultMaxPitch,\n\n boxZoom: true,\n dragRotate: true,\n dragPan: true,\n keyboard: true,\n doubleClickZoom: true,\n touchZoomRotate: true,\n touchPitch: true,\n cooperativeGestures: false,\n\n trackResize: true,\n\n center: [0, 0],\n zoom: 0,\n bearing: 0,\n pitch: 0,\n\n renderWorldCopies: true,\n maxTileCacheSize: null,\n maxTileCacheZoomLevels: config.MAX_TILE_CACHE_ZOOM_LEVELS,\n transformRequest: null,\n transformCameraUpdate: null,\n fadeDuration: 300,\n crossSourceCollisions: true,\n clickTolerance: 3,\n localIdeographFontFamily: 'sans-serif',\n pitchWithRotate: true,\n validateStyle: true,\n /**Because GL MAX_TEXTURE_SIZE is usually at least 4096px. */\n maxCanvasSize: [4096, 4096],\n cancelPendingTileRequestsWhileZooming: true\n};\n\n/**\n * The `Map` object represents the map on your page. It exposes methods\n * and properties that enable you to programmatically change the map,\n * and fires events as users interact with it.\n *\n * You create a `Map` by specifying a `container` and other options, see {@link MapOptions} for the full list.\n * Then MapLibre GL JS initializes the map on the page and returns your `Map` object.\n *\n * @group Main\n *\n * @example\n * ```ts\n * let map = new Map({\n * container: 'map',\n * center: [-122.420679, 37.772537],\n * zoom: 13,\n * style: style_object,\n * hash: true,\n * transformRequest: (url, resourceType)=> {\n * if(resourceType === 'Source' && url.startsWith('http://myHost')) {\n * return {\n * url: url.replace('http', 'https'),\n * headers: { 'my-custom-header': true},\n * credentials: 'include' // Include cookies for cross-origin requests\n * }\n * }\n * }\n * });\n * ```\n * @see [Display a map](https://maplibre.org/maplibre-gl-js/docs/examples/simple-map/)\n */\nexport class Map extends Camera {\n style: Style;\n painter: Painter;\n\n _container: HTMLElement;\n _canvasContainer: HTMLElement;\n _controlContainer: HTMLElement;\n _controlPositions: Record;\n _interactive: boolean;\n _showTileBoundaries: boolean;\n _showCollisionBoxes: boolean;\n _showPadding: boolean;\n _showOverdrawInspector: boolean;\n _repaint: boolean;\n _vertices: boolean;\n _canvas: HTMLCanvasElement;\n _maxTileCacheSize: number | null;\n _maxTileCacheZoomLevels: number;\n _frameRequest: AbortController;\n _styleDirty: boolean;\n _sourcesDirty: boolean;\n _placementDirty: boolean;\n\n _loaded: boolean;\n _idleTriggered = false;\n // accounts for placement finishing as well\n _fullyLoaded: boolean;\n _trackResize: boolean;\n _resizeObserver: ResizeObserver;\n _preserveDrawingBuffer: boolean;\n _failIfMajorPerformanceCaveat: boolean;\n _antialias: boolean;\n _refreshExpiredTiles: boolean;\n _hash: Hash;\n _delegatedListeners: Record;\n _fadeDuration: number;\n _crossSourceCollisions: boolean;\n _crossFadingFactor = 1;\n _collectResourceTiming: boolean;\n _renderTaskQueue = new TaskQueue();\n _controls: Array = [];\n _mapId = uniqueId();\n _localIdeographFontFamily: string | false;\n _validateStyle: boolean;\n _requestManager: RequestManager;\n _locale: typeof defaultLocale;\n _removed: boolean;\n _clickTolerance: number;\n _overridePixelRatio: number | null | undefined;\n _maxCanvasSize: [number, number];\n _terrainDataCallback: (e: MapStyleDataEvent | MapSourceDataEvent) => void;\n\n /**\n * @internal\n * image queue throttling handle. To be used later when clean up\n */\n _imageQueueHandle: number;\n\n /**\n * The map's {@link ScrollZoomHandler}, which implements zooming in and out with a scroll wheel or trackpad.\n * Find more details and examples using `scrollZoom` in the {@link ScrollZoomHandler} section.\n */\n scrollZoom: ScrollZoomHandler;\n\n /**\n * The map's {@link BoxZoomHandler}, which implements zooming using a drag gesture with the Shift key pressed.\n * Find more details and examples using `boxZoom` in the {@link BoxZoomHandler} section.\n */\n boxZoom: BoxZoomHandler;\n\n /**\n * The map's {@link DragRotateHandler}, which implements rotating the map while dragging with the right\n * mouse button or with the Control key pressed. Find more details and examples using `dragRotate`\n * in the {@link DragRotateHandler} section.\n */\n dragRotate: DragRotateHandler;\n\n /**\n * The map's {@link DragPanHandler}, which implements dragging the map with a mouse or touch gesture.\n * Find more details and examples using `dragPan` in the {@link DragPanHandler} section.\n */\n dragPan: DragPanHandler;\n\n /**\n * The map's {@link KeyboardHandler}, which allows the user to zoom, rotate, and pan the map using keyboard\n * shortcuts. Find more details and examples using `keyboard` in the {@link KeyboardHandler} section.\n */\n keyboard: KeyboardHandler;\n\n /**\n * The map's {@link DoubleClickZoomHandler}, which allows the user to zoom by double clicking.\n * Find more details and examples using `doubleClickZoom` in the {@link DoubleClickZoomHandler} section.\n */\n doubleClickZoom: DoubleClickZoomHandler;\n\n /**\n * The map's {@link TwoFingersTouchZoomRotateHandler}, which allows the user to zoom or rotate the map with touch gestures.\n * Find more details and examples using `touchZoomRotate` in the {@link TwoFingersTouchZoomRotateHandler} section.\n */\n touchZoomRotate: TwoFingersTouchZoomRotateHandler;\n\n /**\n * The map's {@link TwoFingersTouchPitchHandler}, which allows the user to pitch the map with touch gestures.\n * Find more details and examples using `touchPitch` in the {@link TwoFingersTouchPitchHandler} section.\n */\n touchPitch: TwoFingersTouchPitchHandler;\n\n /**\n * The map's {@link CooperativeGesturesHandler}, which allows the user to see cooperative gesture info when user tries to zoom in/out.\n * Find more details and examples using `cooperativeGestures` in the {@link CooperativeGesturesHandler} section.\n */\n cooperativeGestures: CooperativeGesturesHandler;\n\n /**\n * The map's property which determines whether to cancel, or retain, tiles from the current viewport which are still loading but which belong to a farther (smaller) zoom level than the current one.\n * * If `true`, when zooming in, tiles which didn't manage to load for previous zoom levels will become canceled. This might save some computing resources for slower devices, but the map details might appear more abruptly at the end of the zoom.\n * * If `false`, when zooming in, the previous zoom level(s) tiles will progressively appear, giving a smoother map details experience. However, more tiles will be rendered in a short period of time.\n * @defaultValue true\n */\n cancelPendingTileRequestsWhileZooming: boolean;\n\n constructor(options: MapOptions) {\n PerformanceUtils.mark(PerformanceMarkers.create);\n\n const resolvedOptions = {...defaultOptions, ...options} as CompleteMapOptions;\n\n if (resolvedOptions.minZoom != null && resolvedOptions.maxZoom != null && resolvedOptions.minZoom > resolvedOptions.maxZoom) {\n throw new Error('maxZoom must be greater than or equal to minZoom');\n }\n\n if (resolvedOptions.minPitch != null && resolvedOptions.maxPitch != null && resolvedOptions.minPitch > resolvedOptions.maxPitch) {\n throw new Error('maxPitch must be greater than or equal to minPitch');\n }\n\n if (resolvedOptions.minPitch != null && resolvedOptions.minPitch < defaultMinPitch) {\n throw new Error(`minPitch must be greater than or equal to ${defaultMinPitch}`);\n }\n\n if (resolvedOptions.maxPitch != null && resolvedOptions.maxPitch > maxPitchThreshold) {\n throw new Error(`maxPitch must be less than or equal to ${maxPitchThreshold}`);\n }\n\n const transform = new Transform(resolvedOptions.minZoom, resolvedOptions.maxZoom, resolvedOptions.minPitch, resolvedOptions.maxPitch, resolvedOptions.renderWorldCopies);\n super(transform, {bearingSnap: resolvedOptions.bearingSnap});\n\n this._interactive = resolvedOptions.interactive;\n this._maxTileCacheSize = resolvedOptions.maxTileCacheSize;\n this._maxTileCacheZoomLevels = resolvedOptions.maxTileCacheZoomLevels;\n this._failIfMajorPerformanceCaveat = resolvedOptions.failIfMajorPerformanceCaveat === true;\n this._preserveDrawingBuffer = resolvedOptions.preserveDrawingBuffer === true;\n this._antialias = resolvedOptions.antialias === true;\n this._trackResize = resolvedOptions.trackResize === true;\n this._bearingSnap = resolvedOptions.bearingSnap;\n this._refreshExpiredTiles = resolvedOptions.refreshExpiredTiles === true;\n this._fadeDuration = resolvedOptions.fadeDuration;\n this._crossSourceCollisions = resolvedOptions.crossSourceCollisions === true;\n this._collectResourceTiming = resolvedOptions.collectResourceTiming === true;\n this._locale = {...defaultLocale, ...resolvedOptions.locale};\n this._clickTolerance = resolvedOptions.clickTolerance;\n this._overridePixelRatio = resolvedOptions.pixelRatio;\n this._maxCanvasSize = resolvedOptions.maxCanvasSize;\n this.transformCameraUpdate = resolvedOptions.transformCameraUpdate;\n this.cancelPendingTileRequestsWhileZooming = resolvedOptions.cancelPendingTileRequestsWhileZooming === true;\n\n this._imageQueueHandle = ImageRequest.addThrottleControl(() => this.isMoving());\n\n this._requestManager = new RequestManager(resolvedOptions.transformRequest);\n\n if (typeof resolvedOptions.container === 'string') {\n this._container = document.getElementById(resolvedOptions.container);\n if (!this._container) {\n throw new Error(`Container '${resolvedOptions.container}' not found.`);\n }\n } else if (resolvedOptions.container instanceof HTMLElement) {\n this._container = resolvedOptions.container;\n } else {\n throw new Error('Invalid type: \\'container\\' must be a String or HTMLElement.');\n }\n\n if (resolvedOptions.maxBounds) {\n this.setMaxBounds(resolvedOptions.maxBounds);\n }\n\n this._setupContainer();\n this._setupPainter();\n\n this.on('move', () => this._update(false))\n .on('moveend', () => this._update(false))\n .on('zoom', () => this._update(true))\n .on('terrain', () => {\n this.painter.terrainFacilitator.dirty = true;\n this._update(true);\n })\n .once('idle', () => { this._idleTriggered = true; });\n\n if (typeof window !== 'undefined') {\n addEventListener('online', this._onWindowOnline, false);\n let initialResizeEventCaptured = false;\n const throttledResizeCallback = throttle((entries: ResizeObserverEntry[]) => {\n if (this._trackResize && !this._removed) {\n this.resize(entries);\n this.redraw();\n }\n }, 50);\n this._resizeObserver = new ResizeObserver((entries) => {\n if (!initialResizeEventCaptured) {\n initialResizeEventCaptured = true;\n return;\n }\n throttledResizeCallback(entries);\n });\n this._resizeObserver.observe(this._container);\n }\n\n this.handlers = new HandlerManager(this, resolvedOptions);\n\n const hashName = (typeof resolvedOptions.hash === 'string' && resolvedOptions.hash) || undefined;\n this._hash = resolvedOptions.hash && (new Hash(hashName)).addTo(this);\n // don't set position from options if set through hash\n if (!this._hash || !this._hash._onHashChange()) {\n this.jumpTo({\n center: resolvedOptions.center,\n zoom: resolvedOptions.zoom,\n bearing: resolvedOptions.bearing,\n pitch: resolvedOptions.pitch\n });\n\n if (resolvedOptions.bounds) {\n this.resize();\n this.fitBounds(resolvedOptions.bounds, extend({}, resolvedOptions.fitBoundsOptions, {duration: 0}));\n }\n }\n\n this.resize();\n\n this._localIdeographFontFamily = resolvedOptions.localIdeographFontFamily;\n this._validateStyle = resolvedOptions.validateStyle;\n\n if (resolvedOptions.style) this.setStyle(resolvedOptions.style, {localIdeographFontFamily: resolvedOptions.localIdeographFontFamily});\n\n if (resolvedOptions.attributionControl)\n this.addControl(new AttributionControl(typeof resolvedOptions.attributionControl === 'boolean' ? undefined : resolvedOptions.attributionControl));\n\n if (resolvedOptions.maplibreLogo)\n this.addControl(new LogoControl(), resolvedOptions.logoPosition);\n\n this.on('style.load', () => {\n if (this.transform.unmodified) {\n this.jumpTo(this.style.stylesheet as any);\n }\n });\n this.on('data', (event: MapDataEvent) => {\n this._update(event.dataType === 'style');\n this.fire(new Event(`${event.dataType}data`, event));\n });\n this.on('dataloading', (event: MapDataEvent) => {\n this.fire(new Event(`${event.dataType}dataloading`, event));\n });\n this.on('dataabort', (event: MapDataEvent) => {\n this.fire(new Event('sourcedataabort', event));\n });\n }\n\n /**\n * @internal\n * Returns a unique number for this map instance which is used for the MapLoadEvent\n * to make sure we only fire one event per instantiated map object.\n * @returns the uniq map ID\n */\n _getMapId() {\n return this._mapId;\n }\n\n /**\n * Adds an {@link IControl} to the map, calling `control.onAdd(this)`.\n *\n * An {@link ErrorEvent} will be fired if the image parameter is invald.\n *\n * @param control - The {@link IControl} to add.\n * @param position - position on the map to which the control will be added.\n * Valid values are `'top-left'`, `'top-right'`, `'bottom-left'`, and `'bottom-right'`. Defaults to `'top-right'`.\n * @example\n * Add zoom and rotation controls to the map.\n * ```ts\n * map.addControl(new NavigationControl());\n * ```\n * @see [Display map navigation controls](https://maplibre.org/maplibre-gl-js/docs/examples/navigation/)\n */\n addControl(control: IControl, position?: ControlPosition): Map {\n if (position === undefined) {\n if (control.getDefaultPosition) {\n position = control.getDefaultPosition();\n } else {\n position = 'top-right';\n }\n }\n if (!control || !control.onAdd) {\n return this.fire(new ErrorEvent(new Error(\n 'Invalid argument to map.addControl(). Argument must be a control with onAdd and onRemove methods.')));\n }\n const controlElement = control.onAdd(this);\n this._controls.push(control);\n\n const positionContainer = this._controlPositions[position];\n if (position.indexOf('bottom') !== -1) {\n positionContainer.insertBefore(controlElement, positionContainer.firstChild);\n } else {\n positionContainer.appendChild(controlElement);\n }\n return this;\n }\n\n /**\n * Removes the control from the map.\n *\n * An {@link ErrorEvent} will be fired if the image parameter is invald.\n *\n * @param control - The {@link IControl} to remove.\n * @example\n * ```ts\n * // Define a new navigation control.\n * let navigation = new NavigationControl();\n * // Add zoom and rotation controls to the map.\n * map.addControl(navigation);\n * // Remove zoom and rotation controls from the map.\n * map.removeControl(navigation);\n * ```\n */\n removeControl(control: IControl): Map {\n if (!control || !control.onRemove) {\n return this.fire(new ErrorEvent(new Error(\n 'Invalid argument to map.removeControl(). Argument must be a control with onAdd and onRemove methods.')));\n }\n const ci = this._controls.indexOf(control);\n if (ci > -1) this._controls.splice(ci, 1);\n control.onRemove(this);\n return this;\n }\n\n /**\n * Checks if a control exists on the map.\n *\n * @param control - The {@link IControl} to check.\n * @returns true if map contains control.\n * @example\n * ```ts\n * // Define a new navigation control.\n * let navigation = new NavigationControl();\n * // Add zoom and rotation controls to the map.\n * map.addControl(navigation);\n * // Check that the navigation control exists on the map.\n * map.hasControl(navigation);\n * ```\n */\n hasControl(control: IControl): boolean {\n return this._controls.indexOf(control) > -1;\n }\n\n calculateCameraOptionsFromTo(from: LngLat, altitudeFrom: number, to: LngLat, altitudeTo?: number): CameraOptions {\n if (altitudeTo == null && this.terrain) {\n altitudeTo = this.terrain.getElevationForLngLatZoom(to, this.transform.tileZoom);\n }\n return super.calculateCameraOptionsFromTo(from, altitudeFrom, to, altitudeTo);\n }\n\n /**\n * Resizes the map according to the dimensions of its\n * `container` element.\n *\n * Checks if the map container size changed and updates the map if it has changed.\n * This method must be called after the map's `container` is resized programmatically\n * or when the map is shown after being initially hidden with CSS.\n *\n * Triggers the following events: `movestart`, `move`, `moveend`, and `resize`.\n *\n * @param eventData - Additional properties to be passed to `movestart`, `move`, `resize`, and `moveend`\n * events that get triggered as a result of resize. This can be useful for differentiating the\n * source of an event (for example, user-initiated or programmatically-triggered events).\n * @example\n * Resize the map when the map container is shown after being initially hidden with CSS.\n * ```ts\n * let mapDiv = document.getElementById('map');\n * if (mapDiv.style.visibility === true) map.resize();\n * ```\n */\n resize(eventData?: any): Map {\n const dimensions = this._containerDimensions();\n const width = dimensions[0];\n const height = dimensions[1];\n\n const clampedPixelRatio = this._getClampedPixelRatio(width, height);\n this._resizeCanvas(width, height, clampedPixelRatio);\n this.painter.resize(width, height, clampedPixelRatio);\n\n // check if we've reached GL limits, in that case further clamps pixelRatio\n if (this.painter.overLimit()) {\n const gl = this.painter.context.gl;\n // store updated _maxCanvasSize value\n this._maxCanvasSize = [gl.drawingBufferWidth, gl.drawingBufferHeight];\n const clampedPixelRatio = this._getClampedPixelRatio(width, height);\n this._resizeCanvas(width, height, clampedPixelRatio);\n this.painter.resize(width, height, clampedPixelRatio);\n }\n\n this.transform.resize(width, height);\n this._requestedCameraState?.resize(width, height);\n\n const fireMoving = !this._moving;\n if (fireMoving) {\n this.stop();\n this.fire(new Event('movestart', eventData))\n .fire(new Event('move', eventData));\n }\n\n this.fire(new Event('resize', eventData));\n\n if (fireMoving) this.fire(new Event('moveend', eventData));\n\n return this;\n }\n\n /**\n * @internal\n * Return the map's pixel ratio eventually scaled down to respect maxCanvasSize.\n * Internally you should use this and not getPixelRatio().\n */\n _getClampedPixelRatio(width: number, height: number): number {\n const {0: maxCanvasWidth, 1: maxCanvasHeight} = this._maxCanvasSize;\n const pixelRatio = this.getPixelRatio();\n\n const canvasWidth = width * pixelRatio;\n const canvasHeight = height * pixelRatio;\n\n const widthScaleFactor = canvasWidth > maxCanvasWidth ? (maxCanvasWidth / canvasWidth) : 1;\n const heightScaleFactor = canvasHeight > maxCanvasHeight ? (maxCanvasHeight / canvasHeight) : 1;\n\n return Math.min(widthScaleFactor, heightScaleFactor) * pixelRatio;\n }\n\n /**\n * Returns the map's pixel ratio.\n * Note that the pixel ratio actually applied may be lower to respect maxCanvasSize.\n * @returns The pixel ratio.\n */\n getPixelRatio(): number {\n return this._overridePixelRatio ?? devicePixelRatio;\n }\n\n /**\n * Sets the map's pixel ratio. This allows to override `devicePixelRatio`.\n * After this call, the canvas' `width` attribute will be `container.clientWidth * pixelRatio`\n * and its height attribute will be `container.clientHeight * pixelRatio`.\n * Set this to null to disable `devicePixelRatio` override.\n * Note that the pixel ratio actually applied may be lower to respect maxCanvasSize.\n * @param pixelRatio - The pixel ratio.\n */\n setPixelRatio(pixelRatio: number) {\n this._overridePixelRatio = pixelRatio;\n this.resize();\n }\n\n /**\n * Returns the map's geographical bounds. When the bearing or pitch is non-zero, the visible region is not\n * an axis-aligned rectangle, and the result is the smallest bounds that encompasses the visible region.\n * @returns The geographical bounds of the map as {@link LngLatBounds}.\n * @example\n * ```ts\n * let bounds = map.getBounds();\n * ```\n */\n getBounds(): LngLatBounds {\n return this.transform.getBounds();\n }\n\n /**\n * Returns the maximum geographical bounds the map is constrained to, or `null` if none set.\n * @returns The map object.\n * @example\n * ```ts\n * let maxBounds = map.getMaxBounds();\n * ```\n */\n getMaxBounds(): LngLatBounds | null {\n return this.transform.getMaxBounds();\n }\n\n /**\n * Sets or clears the map's geographical bounds.\n *\n * Pan and zoom operations are constrained within these bounds.\n * If a pan or zoom is performed that would\n * display regions outside these bounds, the map will\n * instead display a position and zoom level\n * as close as possible to the operation's request while still\n * remaining within the bounds.\n *\n * @param bounds - The maximum bounds to set. If `null` or `undefined` is provided, the function removes the map's maximum bounds.\n * @example\n * Define bounds that conform to the `LngLatBoundsLike` object as set the max bounds.\n * ```ts\n * let bounds = [\n * [-74.04728, 40.68392], // [west, south]\n * [-73.91058, 40.87764] // [east, north]\n * ];\n * map.setMaxBounds(bounds);\n * ```\n */\n setMaxBounds(bounds?: LngLatBoundsLike | null): Map {\n this.transform.setMaxBounds(LngLatBounds.convert(bounds));\n return this._update();\n }\n\n /**\n * Sets or clears the map's minimum zoom level.\n * If the map's current zoom level is lower than the new minimum,\n * the map will zoom to the new minimum.\n *\n * It is not always possible to zoom out and reach the set `minZoom`.\n * Other factors such as map height may restrict zooming. For example,\n * if the map is 512px tall it will not be possible to zoom below zoom 0\n * no matter what the `minZoom` is set to.\n *\n * A {@link ErrorEvent} event will be fired if minZoom is out of bounds.\n *\n * @param minZoom - The minimum zoom level to set (-2 - 24).\n * If `null` or `undefined` is provided, the function removes the current minimum zoom (i.e. sets it to -2).\n * @example\n * ```ts\n * map.setMinZoom(12.25);\n * ```\n */\n setMinZoom(minZoom?: number | null): Map {\n\n minZoom = minZoom === null || minZoom === undefined ? defaultMinZoom : minZoom;\n\n if (minZoom >= defaultMinZoom && minZoom <= this.transform.maxZoom) {\n this.transform.minZoom = minZoom;\n this._update();\n\n if (this.getZoom() < minZoom) this.setZoom(minZoom);\n\n return this;\n\n } else throw new Error(`minZoom must be between ${defaultMinZoom} and the current maxZoom, inclusive`);\n }\n\n /**\n * Returns the map's minimum allowable zoom level.\n *\n * @returns minZoom\n * @example\n * ```ts\n * let minZoom = map.getMinZoom();\n * ```\n */\n getMinZoom(): number { return this.transform.minZoom; }\n\n /**\n * Sets or clears the map's maximum zoom level.\n * If the map's current zoom level is higher than the new maximum,\n * the map will zoom to the new maximum.\n *\n * A {@link ErrorEvent} event will be fired if minZoom is out of bounds.\n *\n * @param maxZoom - The maximum zoom level to set.\n * If `null` or `undefined` is provided, the function removes the current maximum zoom (sets it to 22).\n * @example\n * ```ts\n * map.setMaxZoom(18.75);\n * ```\n */\n setMaxZoom(maxZoom?: number | null): Map {\n\n maxZoom = maxZoom === null || maxZoom === undefined ? defaultMaxZoom : maxZoom;\n\n if (maxZoom >= this.transform.minZoom) {\n this.transform.maxZoom = maxZoom;\n this._update();\n\n if (this.getZoom() > maxZoom) this.setZoom(maxZoom);\n\n return this;\n\n } else throw new Error('maxZoom must be greater than the current minZoom');\n }\n\n /**\n * Returns the map's maximum allowable zoom level.\n *\n * @returns The maxZoom\n * @example\n * ```ts\n * let maxZoom = map.getMaxZoom();\n * ```\n */\n getMaxZoom(): number { return this.transform.maxZoom; }\n\n /**\n * Sets or clears the map's minimum pitch.\n * If the map's current pitch is lower than the new minimum,\n * the map will pitch to the new minimum.\n *\n * A {@link ErrorEvent} event will be fired if minPitch is out of bounds.\n *\n * @param minPitch - The minimum pitch to set (0-85). Values greater than 60 degrees are experimental and may result in rendering issues. If you encounter any, please raise an issue with details in the MapLibre project.\n * If `null` or `undefined` is provided, the function removes the current minimum pitch (i.e. sets it to 0).\n */\n setMinPitch(minPitch?: number | null): Map {\n\n minPitch = minPitch === null || minPitch === undefined ? defaultMinPitch : minPitch;\n\n if (minPitch < defaultMinPitch) {\n throw new Error(`minPitch must be greater than or equal to ${defaultMinPitch}`);\n }\n\n if (minPitch >= defaultMinPitch && minPitch <= this.transform.maxPitch) {\n this.transform.minPitch = minPitch;\n this._update();\n\n if (this.getPitch() < minPitch) this.setPitch(minPitch);\n\n return this;\n\n } else throw new Error(`minPitch must be between ${defaultMinPitch} and the current maxPitch, inclusive`);\n }\n\n /**\n * Returns the map's minimum allowable pitch.\n *\n * @returns The minPitch\n */\n getMinPitch(): number { return this.transform.minPitch; }\n\n /**\n * Sets or clears the map's maximum pitch.\n * If the map's current pitch is higher than the new maximum,\n * the map will pitch to the new maximum.\n *\n * A {@link ErrorEvent} event will be fired if maxPitch is out of bounds.\n *\n * @param maxPitch - The maximum pitch to set (0-85). Values greater than 60 degrees are experimental and may result in rendering issues. If you encounter any, please raise an issue with details in the MapLibre project.\n * If `null` or `undefined` is provided, the function removes the current maximum pitch (sets it to 60).\n */\n setMaxPitch(maxPitch?: number | null): Map {\n\n maxPitch = maxPitch === null || maxPitch === undefined ? defaultMaxPitch : maxPitch;\n\n if (maxPitch > maxPitchThreshold) {\n throw new Error(`maxPitch must be less than or equal to ${maxPitchThreshold}`);\n }\n\n if (maxPitch >= this.transform.minPitch) {\n this.transform.maxPitch = maxPitch;\n this._update();\n\n if (this.getPitch() > maxPitch) this.setPitch(maxPitch);\n\n return this;\n\n } else throw new Error('maxPitch must be greater than the current minPitch');\n }\n\n /**\n * Returns the map's maximum allowable pitch.\n *\n * @returns The maxPitch\n */\n getMaxPitch(): number { return this.transform.maxPitch; }\n\n /**\n * Returns the state of `renderWorldCopies`. If `true`, multiple copies of the world will be rendered side by side beyond -180 and 180 degrees longitude. If set to `false`:\n *\n * - When the map is zoomed out far enough that a single representation of the world does not fill the map's entire\n * container, there will be blank space beyond 180 and -180 degrees longitude.\n * - Features that cross 180 and -180 degrees longitude will be cut in two (with one portion on the right edge of the\n * map and the other on the left edge of the map) at every zoom level.\n * @returns The renderWorldCopies\n * @example\n * ```ts\n * let worldCopiesRendered = map.getRenderWorldCopies();\n * ```\n * @see [Render world copies](https://maplibre.org/maplibre-gl-js/docs/examples/render-world-copies/)\n */\n getRenderWorldCopies(): boolean { return this.transform.renderWorldCopies; }\n\n /**\n * Sets the state of `renderWorldCopies`.\n *\n * @param renderWorldCopies - If `true`, multiple copies of the world will be rendered side by side beyond -180 and 180 degrees longitude. If set to `false`:\n *\n * - When the map is zoomed out far enough that a single representation of the world does not fill the map's entire\n * container, there will be blank space beyond 180 and -180 degrees longitude.\n * - Features that cross 180 and -180 degrees longitude will be cut in two (with one portion on the right edge of the\n * map and the other on the left edge of the map) at every zoom level.\n *\n * `undefined` is treated as `true`, `null` is treated as `false`.\n * @example\n * ```ts\n * map.setRenderWorldCopies(true);\n * ```\n * @see [Render world copies](https://maplibre.org/maplibre-gl-js/docs/examples/render-world-copies/)\n */\n setRenderWorldCopies(renderWorldCopies?: boolean | null): Map {\n this.transform.renderWorldCopies = renderWorldCopies;\n return this._update();\n }\n\n /**\n * Returns a [Point](https://github.com/mapbox/point-geometry) representing pixel coordinates, relative to the map's `container`,\n * that correspond to the specified geographical location.\n *\n * @param lnglat - The geographical location to project.\n * @returns The [Point](https://github.com/mapbox/point-geometry) corresponding to `lnglat`, relative to the map's `container`.\n * @example\n * ```ts\n * let coordinate = [-122.420679, 37.772537];\n * let point = map.project(coordinate);\n * ```\n */\n project(lnglat: LngLatLike): Point {\n return this.transform.locationPoint(LngLat.convert(lnglat), this.style && this.terrain);\n }\n\n /**\n * Returns a {@link LngLat} representing geographical coordinates that correspond\n * to the specified pixel coordinates.\n *\n * @param point - The pixel coordinates to unproject.\n * @returns The {@link LngLat} corresponding to `point`.\n * @example\n * ```ts\n * map.on('click', (e) => {\n * // When the map is clicked, get the geographic coordinate.\n * let coordinate = map.unproject(e.point);\n * });\n * ```\n */\n unproject(point: PointLike): LngLat {\n return this.transform.pointLocation(Point.convert(point), this.terrain);\n }\n\n /**\n * Returns true if the map is panning, zooming, rotating, or pitching due to a camera animation or user gesture.\n * @returns true if the map is moving.\n * @example\n * ```ts\n * let isMoving = map.isMoving();\n * ```\n */\n isMoving(): boolean {\n return this._moving || this.handlers?.isMoving();\n }\n\n /**\n * Returns true if the map is zooming due to a camera animation or user gesture.\n * @returns true if the map is zooming.\n * @example\n * ```ts\n * let isZooming = map.isZooming();\n * ```\n */\n isZooming(): boolean {\n return this._zooming || this.handlers?.isZooming();\n }\n\n /**\n * Returns true if the map is rotating due to a camera animation or user gesture.\n * @returns true if the map is rotating.\n * @example\n * ```ts\n * map.isRotating();\n * ```\n */\n isRotating(): boolean {\n return this._rotating || this.handlers?.isRotating();\n }\n\n _createDelegatedListener(type: keyof MapEventType | string, layerIds: string[], listener: Listener): DelegatedListener {\n if (type === 'mouseenter' || type === 'mouseover') {\n let mousein = false;\n const mousemove = (e) => {\n const existingLayers = layerIds.filter((layerId) => this.getLayer(layerId));\n const features = existingLayers.length !== 0 ? this.queryRenderedFeatures(e.point, {layers: existingLayers}) : [];\n if (!features.length) {\n mousein = false;\n } else if (!mousein) {\n mousein = true;\n listener.call(this, new MapMouseEvent(type, this, e.originalEvent, {features}));\n }\n };\n const mouseout = () => {\n mousein = false;\n };\n return {layers: layerIds, listener, delegates: {mousemove, mouseout}};\n } else if (type === 'mouseleave' || type === 'mouseout') {\n let mousein = false;\n const mousemove = (e) => {\n const existingLayers = layerIds.filter((layerId) => this.getLayer(layerId));\n const features = existingLayers.length !== 0 ? this.queryRenderedFeatures(e.point, {layers: existingLayers}) : [];\n if (features.length) {\n mousein = true;\n } else if (mousein) {\n mousein = false;\n listener.call(this, new MapMouseEvent(type, this, e.originalEvent));\n }\n };\n const mouseout = (e) => {\n if (mousein) {\n mousein = false;\n listener.call(this, new MapMouseEvent(type, this, e.originalEvent));\n }\n };\n return {layers: layerIds, listener, delegates: {mousemove, mouseout}};\n } else {\n const delegate = (e) => {\n const existingLayers = layerIds.filter((layerId) => this.getLayer(layerId));\n const features = existingLayers.length !== 0 ? this.queryRenderedFeatures(e.point, {layers: existingLayers}) : [];\n if (features.length) {\n // Here we need to mutate the original event, so that preventDefault works as expected.\n e.features = features;\n listener.call(this, e);\n delete e.features;\n }\n };\n return {layers: layerIds, listener, delegates: {[type]: delegate}};\n }\n }\n\n _saveDelegatedListener(type: keyof MapEventType | string, delegatedListener: DelegatedListener): void {\n this._delegatedListeners = this._delegatedListeners || {};\n this._delegatedListeners[type] = this._delegatedListeners[type] || [];\n this._delegatedListeners[type].push(delegatedListener);\n }\n\n _removeDelegatedListener(type: string, layerIds: string[], listener: Listener) {\n if (!this._delegatedListeners || !this._delegatedListeners[type]) {\n return;\n }\n\n const listeners = this._delegatedListeners[type];\n for (let i = 0; i < listeners.length; i++) {\n const delegatedListener = listeners[i];\n if (\n delegatedListener.listener === listener &&\n delegatedListener.layers.length === layerIds.length &&\n delegatedListener.layers.every((layerId: string) => layerIds.includes(layerId))\n ) {\n for (const event in delegatedListener.delegates) {\n this.off(event, delegatedListener.delegates[event]);\n }\n listeners.splice(i, 1);\n return;\n }\n }\n }\n\n /**\n * @event\n * Adds a listener for events of a specified type, optionally limited to features in a specified style layer(s).\n * See {@link MapEventType} and {@link MapLayerEventType} for a full list of events and their description.\n *\n * | Event | Compatible with `layerId` |\n * |------------------------|---------------------------|\n * | `mousedown` | yes |\n * | `mouseup` | yes |\n * | `mouseover` | yes |\n * | `mouseout` | yes |\n * | `mousemove` | yes |\n * | `mouseenter` | yes (required) |\n * | `mouseleave` | yes (required) |\n * | `click` | yes |\n * | `dblclick` | yes |\n * | `contextmenu` | yes |\n * | `touchstart` | yes |\n * | `touchend` | yes |\n * | `touchcancel` | yes |\n * | `wheel` | |\n * | `resize` | |\n * | `remove` | |\n * | `touchmove` | |\n * | `movestart` | |\n * | `move` | |\n * | `moveend` | |\n * | `dragstart` | |\n * | `drag` | |\n * | `dragend` | |\n * | `zoomstart` | |\n * | `zoom` | |\n * | `zoomend` | |\n * | `rotatestart` | |\n * | `rotate` | |\n * | `rotateend` | |\n * | `pitchstart` | |\n * | `pitch` | |\n * | `pitchend` | |\n * | `boxzoomstart` | |\n * | `boxzoomend` | |\n * | `boxzoomcancel` | |\n * | `webglcontextlost` | |\n * | `webglcontextrestored` | |\n * | `load` | |\n * | `render` | |\n * | `idle` | |\n * | `error` | |\n * | `data` | |\n * | `styledata` | |\n * | `sourcedata` | |\n * | `dataloading` | |\n * | `styledataloading` | |\n * | `sourcedataloading` | |\n * | `styleimagemissing` | |\n * | `dataabort` | |\n * | `sourcedataabort` | |\n *\n * @param type - The event type to listen for. Events compatible with the optional `layerId` parameter are triggered\n * when the cursor enters a visible portion of the specified layer from outside that layer or outside the map canvas.\n * @param layer - The ID of a style layer or a listener if no ID is provided. Event will only be triggered if its location\n * is within a visible feature in this layer. The event will have a `features` property containing\n * an array of the matching features. If `layer` is not supplied, the event will not have a `features` property.\n * Please note that many event types are not compatible with the optional `layer` parameter.\n * @param listener - The function to be called when the event is fired.\n * @example\n * ```ts\n * // Set an event listener that will fire\n * // when the map has finished loading\n * map.on('load', () => {\n * // Once the map has finished loading,\n * // add a new layer\n * map.addLayer({\n * id: 'points-of-interest',\n * source: {\n * type: 'vector',\n * url: 'https://maplibre.org/maplibre-style-spec/'\n * },\n * 'source-layer': 'poi_label',\n * type: 'circle',\n * paint: {\n * // MapLibre Style Specification paint properties\n * },\n * layout: {\n * // MapLibre Style Specification layout properties\n * }\n * });\n * });\n * ```\n * @example\n * ```ts\n * // Set an event listener that will fire\n * // when a feature on the countries layer of the map is clicked\n * map.on('click', 'countries', (e) => {\n * new Popup()\n * .setLngLat(e.lngLat)\n * .setHTML(`Country name: ${e.features[0].properties.name}`)\n * .addTo(map);\n * });\n * ```\n * @see [Display popup on click](https://maplibre.org/maplibre-gl-js/docs/examples/popup-on-click/)\n * @see [Center the map on a clicked symbol](https://maplibre.org/maplibre-gl-js/docs/examples/center-on-symbol/)\n * @see [Create a hover effect](https://maplibre.org/maplibre-gl-js/docs/examples/hover-styles/)\n * @see [Create a draggable marker](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-point/)\n */\n on(\n type: T,\n layer: string,\n listener: (ev: MapLayerEventType[T] & Object) => void,\n ): Map;\n /**\n * Overload of the `on` method that allows to listen to events specifying multiple layers.\n * @event\n * @param type - The type of the event.\n * @param layerIds - The array of style layer IDs.\n * @param listener - The listener callback.\n */\n on(\n type: T,\n layerIds: string[],\n listener: (ev: MapLayerEventType[T] & Object) => void\n ): this;\n /**\n * Overload of the `on` method that allows to listen to events without specifying a layer.\n * @event\n * @param type - The type of the event.\n * @param listener - The listener callback.\n */\n on(type: T, listener: (ev: MapEventType[T] & Object) => void): this;\n /**\n * Overload of the `on` method that allows to listen to events without specifying a layer.\n * @event\n * @param type - The type of the event.\n * @param listener - The listener callback.\n */\n on(type: keyof MapEventType | string, listener: Listener): this;\n on(type: keyof MapEventType | string, layerIdsOrListener: string | string[] | Listener, listener?: Listener): this {\n if (listener === undefined) {\n return super.on(type, layerIdsOrListener as Listener);\n }\n\n const layerIds = typeof layerIdsOrListener === 'string' ? [layerIdsOrListener] : layerIdsOrListener as string[];\n\n const delegatedListener = this._createDelegatedListener(type, layerIds, listener);\n\n this._saveDelegatedListener(type, delegatedListener);\n\n for (const event in delegatedListener.delegates) {\n this.on(event, delegatedListener.delegates[event]);\n }\n\n return this;\n }\n\n /**\n * Adds a listener that will be called only once to a specified event type, optionally limited to features in a specified style layer.\n *\n * @event\n * @param type - The event type to listen for; one of `'mousedown'`, `'mouseup'`, `'click'`, `'dblclick'`,\n * `'mousemove'`, `'mouseenter'`, `'mouseleave'`, `'mouseover'`, `'mouseout'`, `'contextmenu'`, `'touchstart'`,\n * `'touchend'`, or `'touchcancel'`. `mouseenter` and `mouseover` events are triggered when the cursor enters\n * a visible portion of the specified layer from outside that layer or outside the map canvas. `mouseleave`\n * and `mouseout` events are triggered when the cursor leaves a visible portion of the specified layer, or leaves\n * the map canvas.\n * @param layer - The ID of a style layer or a listener if no ID is provided. Only events whose location is within a visible\n * feature in this layer will trigger the listener. The event will have a `features` property containing\n * an array of the matching features.\n * @param listener - The function to be called when the event is fired.\n * @returns `this` if listener is provided, promise otherwise to allow easier usage of async/await\n */\n once(\n type: T,\n layer: string,\n listener?: (ev: MapLayerEventType[T] & Object) => void,\n ): this | Promise;\n /**\n * Overload of the `once` method that allows to listen to events specifying multiple layers.\n * @event\n * @param type - The type of the event.\n * @param layerIds - The array of style layer IDs.\n * @param listener - The listener callback.\n */\n once(\n type: T,\n layerIds: string[],\n listener?: (ev: MapLayerEventType[T] & Object) => void\n ): this | Promise;\n /**\n * Overload of the `once` method that allows to listen to events without specifying a layer.\n * @event\n * @param type - The type of the event.\n * @param listener - The listener callback.\n */\n once(type: T, listener?: (ev: MapEventType[T] & Object) => void): this | Promise;\n /**\n * Overload of the `once` method that allows to listen to events without specifying a layer.\n * @event\n * @param type - The type of the event.\n * @param listener - The listener callback.\n */\n once(type: keyof MapEventType | string, listener?: Listener): this | Promise;\n once(type: keyof MapEventType | string, layerIdsOrListener: string | string[] | Listener, listener?: Listener): this | Promise {\n if (listener === undefined) {\n return super.once(type, layerIdsOrListener as Listener);\n }\n\n const layerIds = typeof layerIdsOrListener === 'string' ? [layerIdsOrListener] : layerIdsOrListener as string[];\n\n const delegatedListener = this._createDelegatedListener(type, layerIds, listener);\n\n for (const key in delegatedListener.delegates) {\n const delegate: Delegate = delegatedListener.delegates[key];\n delegatedListener.delegates[key] = (...args: Parameters) => {\n this._removeDelegatedListener(type, layerIds, listener);\n delegate(...args);\n };\n }\n\n this._saveDelegatedListener(type, delegatedListener);\n\n for (const event in delegatedListener.delegates) {\n this.once(event, delegatedListener.delegates[event]);\n }\n\n return this;\n }\n\n /**\n * Removes an event listener for events previously added with `Map#on`.\n *\n * @event\n * @param type - The event type previously used to install the listener.\n * @param layer - The layer ID or listener previously used to install the listener.\n * @param listener - The function previously installed as a listener.\n */\n off(\n type: T,\n layer: string,\n listener: (ev: MapLayerEventType[T] & Object) => void,\n ): this;\n /**\n * Overload of the `off` method that allows to remove an event created with multiple layers.\n * Provide the same layer IDs as to `on` or `once`, when the listener was registered.\n * @event\n * @param type - The type of the event.\n * @param layers - The layer IDs previously used to install the listener.\n * @param listener - The function previously installed as a listener.\n */\n off(\n type: T,\n layers: string[],\n listener: (ev: MapLayerEventType[T] & Object) => void,\n ): this;\n /**\n * Overload of the `off` method that allows to remove an event created without specifying a layer.\n * @event\n * @param type - The type of the event.\n * @param listener - The function previously installed as a listener.\n */\n off(type: T, listener: (ev: MapEventType[T] & Object) => void): this;\n /**\n * Overload of the `off` method that allows to remove an event created without specifying a layer.\n * @event\n * @param type - The type of the event.\n * @param listener - The function previously installed as a listener.\n */\n off(type: keyof MapEventType | string, listener: Listener): this;\n off(type: keyof MapEventType | string, layerIdsOrListener: string | string[] | Listener, listener?: Listener): this {\n if (listener === undefined) {\n return super.off(type, layerIdsOrListener as Listener);\n }\n\n const layerIds = typeof layerIdsOrListener === 'string' ? [layerIdsOrListener] : layerIdsOrListener as string[];\n this._removeDelegatedListener(type, layerIds, listener);\n\n return this;\n }\n\n /**\n * Returns an array of MapGeoJSONFeature objects\n * representing visible features that satisfy the query parameters.\n *\n * @param geometryOrOptions - (optional) The geometry of the query region:\n * either a single point or southwest and northeast points describing a bounding box.\n * Omitting this parameter (i.e. calling {@link Map#queryRenderedFeatures} with zero arguments,\n * or with only a `options` argument) is equivalent to passing a bounding box encompassing the entire\n * map viewport.\n * The geometryOrOptions can receive a {@link QueryRenderedFeaturesOptions} only to support a situation where the function receives only one parameter which is the options parameter.\n * @param options - (optional) Options object.\n *\n * @returns An array of MapGeoJSONFeature objects.\n *\n * The `properties` value of each returned feature object contains the properties of its source feature. For GeoJSON sources, only\n * string and numeric property values are supported (i.e. `null`, `Array`, and `Object` values are not supported).\n *\n * Each feature includes top-level `layer`, `source`, and `sourceLayer` properties. The `layer` property is an object\n * representing the style layer to which the feature belongs. Layout and paint properties in this object contain values\n * which are fully evaluated for the given zoom level and feature.\n *\n * Only features that are currently rendered are included. Some features will **not** be included, like:\n *\n * - Features from layers whose `visibility` property is `\"none\"`.\n * - Features from layers whose zoom range excludes the current zoom level.\n * - Symbol features that have been hidden due to text or icon collision.\n *\n * Features from all other layers are included, including features that may have no visible\n * contribution to the rendered result; for example, because the layer's opacity or color alpha component is set to\n * 0.\n *\n * The topmost rendered feature appears first in the returned array, and subsequent features are sorted by\n * descending z-order. Features that are rendered multiple times (due to wrapping across the antemeridian at low\n * zoom levels) are returned only once (though subject to the following caveat).\n *\n * Because features come from tiled vector data or GeoJSON data that is converted to tiles internally, feature\n * geometries may be split or duplicated across tile boundaries and, as a result, features may appear multiple\n * times in query results. For example, suppose there is a highway running through the bounding rectangle of a query.\n * The results of the query will be those parts of the highway that lie within the map tiles covering the bounding\n * rectangle, even if the highway extends into other tiles, and the portion of the highway within each map tile\n * will be returned as a separate feature. Similarly, a point feature near a tile boundary may appear in multiple\n * tiles due to tile buffering.\n *\n * @example\n * Find all features at a point\n * ```ts\n * let features = map.queryRenderedFeatures(\n * [20, 35],\n * { layers: ['my-layer-name'] }\n * );\n * ```\n *\n * @example\n * Find all features within a static bounding box\n * ```ts\n * let features = map.queryRenderedFeatures(\n * [[10, 20], [30, 50]],\n * { layers: ['my-layer-name'] }\n * );\n * ```\n *\n * @example\n * Find all features within a bounding box around a point\n * ```ts\n * let width = 10;\n * let height = 20;\n * let features = map.queryRenderedFeatures([\n * [point.x - width / 2, point.y - height / 2],\n * [point.x + width / 2, point.y + height / 2]\n * ], { layers: ['my-layer-name'] });\n * ```\n *\n * @example\n * Query all rendered features from a single layer\n * ```ts\n * let features = map.queryRenderedFeatures({ layers: ['my-layer-name'] });\n * ```\n * @see [Get features under the mouse pointer](https://maplibre.org/maplibre-gl-js/docs/examples/queryrenderedfeatures/)\n */\n queryRenderedFeatures(geometryOrOptions?: PointLike | [PointLike, PointLike] | QueryRenderedFeaturesOptions, options?: QueryRenderedFeaturesOptions): MapGeoJSONFeature[] {\n if (!this.style) {\n return [];\n }\n let queryGeometry;\n const isGeometry = geometryOrOptions instanceof Point || Array.isArray(geometryOrOptions);\n const geometry = isGeometry ? geometryOrOptions : [[0, 0], [this.transform.width, this.transform.height]];\n options = options || (isGeometry ? {} : geometryOrOptions) || {};\n\n if (geometry instanceof Point || typeof geometry[0] === 'number') {\n queryGeometry = [Point.convert(geometry as PointLike)];\n } else {\n const tl = Point.convert(geometry[0] as PointLike);\n const br = Point.convert(geometry[1] as PointLike);\n queryGeometry = [tl, new Point(br.x, tl.y), br, new Point(tl.x, br.y), tl];\n }\n\n return this.style.queryRenderedFeatures(queryGeometry, options, this.transform);\n }\n\n /**\n * Returns an array of MapGeoJSONFeature objects\n * representing features within the specified vector tile or GeoJSON source that satisfy the query parameters.\n *\n * @param sourceId - The ID of the vector tile or GeoJSON source to query.\n * @param parameters - The options object.\n * @returns An array of MapGeoJSONFeature objects.\n *\n * In contrast to {@link Map#queryRenderedFeatures}, this function returns all features matching the query parameters,\n * whether or not they are rendered by the current style (i.e. visible). The domain of the query includes all currently-loaded\n * vector tiles and GeoJSON source tiles: this function does not check tiles outside the currently\n * visible viewport.\n *\n * Because features come from tiled vector data or GeoJSON data that is converted to tiles internally, feature\n * geometries may be split or duplicated across tile boundaries and, as a result, features may appear multiple\n * times in query results. For example, suppose there is a highway running through the bounding rectangle of a query.\n * The results of the query will be those parts of the highway that lie within the map tiles covering the bounding\n * rectangle, even if the highway extends into other tiles, and the portion of the highway within each map tile\n * will be returned as a separate feature. Similarly, a point feature near a tile boundary may appear in multiple\n * tiles due to tile buffering.\n *\n * @example\n * Find all features in one source layer in a vector source\n * ```ts\n * let features = map.querySourceFeatures('your-source-id', {\n * sourceLayer: 'your-source-layer'\n * });\n * ```\n *\n */\n querySourceFeatures(sourceId: string, parameters?: QuerySourceFeatureOptions | null): MapGeoJSONFeature[] {\n return this.style.querySourceFeatures(sourceId, parameters);\n }\n\n /**\n * Updates the map's MapLibre style object with a new value.\n *\n * If a style is already set when this is used and options.diff is set to true, the map renderer will attempt to compare the given style\n * against the map's current state and perform only the changes necessary to make the map style match the desired state. Changes in sprites\n * (images used for icons and patterns) and glyphs (fonts for label text) **cannot** be diffed. If the sprites or fonts used in the current\n * style and the given style are different in any way, the map renderer will force a full update, removing the current style and building\n * the given one from scratch.\n *\n *\n * @param style - A JSON object conforming to the schema described in the\n * [MapLibre Style Specification](https://maplibre.org/maplibre-style-spec/), or a URL to such JSON.\n * @param options - The options object.\n *\n * @example\n * ```ts\n * map.setStyle(\"https://demotiles.maplibre.org/style.json\");\n *\n * map.setStyle('https://demotiles.maplibre.org/style.json', {\n * transformStyle: (previousStyle, nextStyle) => ({\n * ...nextStyle,\n * sources: {\n * ...nextStyle.sources,\n * // copy a source from previous style\n * 'osm': previousStyle.sources.osm\n * },\n * layers: [\n * // background layer\n * nextStyle.layers[0],\n * // copy a layer from previous style\n * previousStyle.layers[0],\n * // other layers from the next style\n * ...nextStyle.layers.slice(1).map(layer => {\n * // hide the layers we don't need from demotiles style\n * if (layer.id.startsWith('geolines')) {\n * layer.layout = {...layer.layout || {}, visibility: 'none'};\n * // filter out US polygons\n * } else if (layer.id.startsWith('coastline') || layer.id.startsWith('countries')) {\n * layer.filter = ['!=', ['get', 'ADM0_A3'], 'USA'];\n * }\n * return layer;\n * })\n * ]\n * })\n * });\n * ```\n */\n setStyle(style: StyleSpecification | string | null, options?: StyleSwapOptions & StyleOptions): this {\n options = extend({},\n {\n localIdeographFontFamily: this._localIdeographFontFamily,\n validate: this._validateStyle\n }, options);\n\n if ((options.diff !== false && options.localIdeographFontFamily === this._localIdeographFontFamily) && this.style && style) {\n this._diffStyle(style, options);\n return this;\n } else {\n this._localIdeographFontFamily = options.localIdeographFontFamily;\n return this._updateStyle(style, options);\n }\n }\n\n /**\n * Updates the requestManager's transform request with a new function\n *\n * @param transformRequest - A callback run before the Map makes a request for an external URL. The callback can be used to modify the url, set headers, or set the credentials property for cross-origin requests.\n * Expected to return an object with a `url` property and optionally `headers` and `credentials` properties\n *\n * @example\n * ```ts\n * map.setTransformRequest((url: string, resourceType: string) => {});\n * ```\n */\n setTransformRequest(transformRequest: RequestTransformFunction): this {\n this._requestManager.setTransformRequest(transformRequest);\n return this;\n }\n\n _getUIString(key: keyof typeof defaultLocale) {\n const str = this._locale[key];\n if (str == null) {\n throw new Error(`Missing UI string '${key}'`);\n }\n\n return str;\n }\n\n _updateStyle(style: StyleSpecification | string | null, options?: StyleSwapOptions & StyleOptions) {\n // transformStyle relies on having previous style serialized, if it is not loaded yet, delay _updateStyle until previous style is loaded\n if (options.transformStyle && this.style && !this.style._loaded) {\n this.style.once('style.load', () => this._updateStyle(style, options));\n return;\n }\n\n const previousStyle = this.style && options.transformStyle ? this.style.serialize() : undefined;\n if (this.style) {\n this.style.setEventedParent(null);\n\n // Only release workers when map is getting disposed\n this.style._remove(!style);\n }\n\n if (!style) {\n delete this.style;\n return this;\n } else {\n this.style = new Style(this, options || {});\n }\n\n this.style.setEventedParent(this, {style: this.style});\n\n if (typeof style === 'string') {\n this.style.loadURL(style, options, previousStyle);\n } else {\n this.style.loadJSON(style, options, previousStyle);\n }\n\n return this;\n }\n\n _lazyInitEmptyStyle() {\n if (!this.style) {\n this.style = new Style(this, {});\n this.style.setEventedParent(this, {style: this.style});\n this.style.loadEmpty();\n }\n }\n\n _diffStyle(style: StyleSpecification | string, options?: StyleSwapOptions & StyleOptions) {\n if (typeof style === 'string') {\n const url = style;\n const request = this._requestManager.transformRequest(url, ResourceType.Style);\n getJSON(request, new AbortController()).then((response) => {\n this._updateDiff(response.data, options);\n }).catch((error) => {\n if (error) {\n this.fire(new ErrorEvent(error));\n }\n });\n } else if (typeof style === 'object') {\n this._updateDiff(style, options);\n }\n }\n\n _updateDiff(style: StyleSpecification, options?: StyleSwapOptions & StyleOptions) {\n try {\n if (this.style.setState(style, options)) {\n this._update(true);\n }\n } catch (e) {\n warnOnce(\n `Unable to perform style diff: ${e.message || e.error || e}. Rebuilding the style from scratch.`\n );\n this._updateStyle(style, options);\n }\n }\n\n /**\n * Returns the map's MapLibre style object, a JSON object which can be used to recreate the map's style.\n *\n * @returns The map's style JSON object.\n *\n * @example\n * ```ts\n * let styleJson = map.getStyle();\n * ```\n *\n */\n getStyle(): StyleSpecification {\n if (this.style) {\n return this.style.serialize();\n }\n }\n\n /**\n * Returns a Boolean indicating whether the map's style is fully loaded.\n *\n * @returns A Boolean indicating whether the style is fully loaded.\n *\n * @example\n * ```ts\n * let styleLoadStatus = map.isStyleLoaded();\n * ```\n */\n isStyleLoaded(): boolean | void {\n if (!this.style) return warnOnce('There is no style added to the map.');\n return this.style.loaded();\n }\n\n /**\n * Adds a source to the map's style.\n *\n * Events triggered:\n *\n * Triggers the `source.add` event.\n *\n * @param id - The ID of the source to add. Must not conflict with existing sources.\n * @param source - The source object, conforming to the\n * MapLibre Style Specification's [source definition](https://maplibre.org/maplibre-style-spec/sources) or\n * {@link CanvasSourceSpecification}.\n * @example\n * ```ts\n * map.addSource('my-data', {\n * type: 'vector',\n * url: 'https://demotiles.maplibre.org/tiles/tiles.json'\n * });\n * ```\n * @example\n * ```ts\n * map.addSource('my-data', {\n * \"type\": \"geojson\",\n * \"data\": {\n * \"type\": \"Feature\",\n * \"geometry\": {\n * \"type\": \"Point\",\n * \"coordinates\": [-77.0323, 38.9131]\n * },\n * \"properties\": {\n * \"title\": \"Mapbox DC\",\n * \"marker-symbol\": \"monument\"\n * }\n * }\n * });\n * ```\n * @see GeoJSON source: [Add live realtime data](https://maplibre.org/maplibre-gl-js/docs/examples/live-geojson/)\n */\n addSource(id: string, source: SourceSpecification | CanvasSourceSpecification): this {\n this._lazyInitEmptyStyle();\n this.style.addSource(id, source);\n return this._update(true);\n }\n\n /**\n * Returns a Boolean indicating whether the source is loaded. Returns `true` if the source with\n * the given ID in the map's style has no outstanding network requests, otherwise `false`.\n *\n * A {@link ErrorEvent} event will be fired if there is no source wit the specified ID.\n *\n * @param id - The ID of the source to be checked.\n * @returns A Boolean indicating whether the source is loaded.\n * @example\n * ```ts\n * let sourceLoaded = map.isSourceLoaded('bathymetry-data');\n * ```\n */\n isSourceLoaded(id: string): boolean {\n const source = this.style && this.style.sourceCaches[id];\n if (source === undefined) {\n this.fire(new ErrorEvent(new Error(`There is no source with ID '${id}'`)));\n return;\n }\n return source.loaded();\n }\n\n /**\n * Loads a 3D terrain mesh, based on a \"raster-dem\" source.\n *\n * Triggers the `terrain` event.\n *\n * @param options - Options object.\n * @example\n * ```ts\n * map.setTerrain({ source: 'terrain' });\n * ```\n */\n setTerrain(options: TerrainSpecification | null): this {\n this.style._checkLoaded();\n\n // clear event handlers\n if (this._terrainDataCallback) this.style.off('data', this._terrainDataCallback);\n\n if (!options) {\n // remove terrain\n if (this.terrain) this.terrain.sourceCache.destruct();\n this.terrain = null;\n if (this.painter.renderToTexture) this.painter.renderToTexture.destruct();\n this.painter.renderToTexture = null;\n this.transform.minElevationForCurrentTile = 0;\n this.transform.elevation = 0;\n } else {\n // add terrain\n const sourceCache = this.style.sourceCaches[options.source];\n if (!sourceCache) throw new Error(`cannot load terrain, because there exists no source with ID: ${options.source}`);\n // Update terrain tiles when adding new terrain\n if (this.terrain === null) sourceCache.reload();\n // Warn once if user is using the same source for hillshade and terrain\n for (const index in this.style._layers) {\n const thisLayer = this.style._layers[index];\n if (thisLayer.type === 'hillshade' && thisLayer.source === options.source) {\n warnOnce('You are using the same source for a hillshade layer and for 3D terrain. Please consider using two separate sources to improve rendering quality.');\n }\n }\n this.terrain = new Terrain(this.painter, sourceCache, options);\n this.painter.renderToTexture = new RenderToTexture(this.painter, this.terrain);\n this.transform.minElevationForCurrentTile = this.terrain.getMinTileElevationForLngLatZoom(this.transform.center, this.transform.tileZoom);\n this.transform.elevation = this.terrain.getElevationForLngLatZoom(this.transform.center, this.transform.tileZoom);\n this._terrainDataCallback = e => {\n if (e.dataType === 'style') {\n this.terrain.sourceCache.freeRtt();\n } else if (e.dataType === 'source' && e.tile) {\n if (e.sourceId === options.source && !this._elevationFreeze) {\n this.transform.minElevationForCurrentTile = this.terrain.getMinTileElevationForLngLatZoom(this.transform.center, this.transform.tileZoom);\n this.transform.elevation = this.terrain.getElevationForLngLatZoom(this.transform.center, this.transform.tileZoom);\n }\n this.terrain.sourceCache.freeRtt(e.tile.tileID);\n }\n };\n this.style.on('data', this._terrainDataCallback);\n }\n\n this.fire(new Event('terrain', {terrain: options}));\n return this;\n }\n\n /**\n * Get the terrain-options if terrain is loaded\n * @returns the TerrainSpecification passed to setTerrain\n * @example\n * ```ts\n * map.getTerrain(); // { source: 'terrain' };\n * ```\n */\n getTerrain(): TerrainSpecification | null {\n return this.terrain?.options ?? null;\n }\n\n /**\n * Returns a Boolean indicating whether all tiles in the viewport from all sources on\n * the style are loaded.\n *\n * @returns A Boolean indicating whether all tiles are loaded.\n * @example\n * ```ts\n * let tilesLoaded = map.areTilesLoaded();\n * ```\n */\n areTilesLoaded(): boolean {\n const sources = this.style && this.style.sourceCaches;\n for (const id in sources) {\n const source = sources[id];\n const tiles = source._tiles;\n for (const t in tiles) {\n const tile = tiles[t];\n if (!(tile.state === 'loaded' || tile.state === 'errored')) return false;\n }\n }\n return true;\n }\n\n /**\n * Removes a source from the map's style.\n *\n * @param id - The ID of the source to remove.\n * @example\n * ```ts\n * map.removeSource('bathymetry-data');\n * ```\n */\n removeSource(id: string): Map {\n this.style.removeSource(id);\n return this._update(true);\n }\n\n /**\n * Returns the source with the specified ID in the map's style.\n *\n * This method is often used to update a source using the instance members for the relevant\n * source type as defined in classes that derive from {@link Source}.\n * For example, setting the `data` for a GeoJSON source or updating the `url` and `coordinates`\n * of an image source.\n *\n * @param id - The ID of the source to get.\n * @returns The style source with the specified ID or `undefined` if the ID\n * corresponds to no existing sources.\n * The shape of the object varies by source type.\n * A list of options for each source type is available on the MapLibre Style Specification's\n * [Sources](https://maplibre.org/maplibre-style-spec/sources/) page.\n * @example\n * ```ts\n * let sourceObject = map.getSource('points');\n * ```\n * @see [Create a draggable point](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-point/)\n * @see [Animate a point](https://maplibre.org/maplibre-gl-js/docs/examples/animate-point-along-line/)\n * @see [Add live realtime data](https://maplibre.org/maplibre-gl-js/docs/examples/live-geojson/)\n */\n getSource(id: string): TSource | undefined {\n return this.style.getSource(id) as TSource;\n }\n\n /**\n * Add an image to the style. This image can be displayed on the map like any other icon in the style's\n * sprite using the image's ID with\n * [`icon-image`](https://maplibre.org/maplibre-style-spec/layers/#layout-symbol-icon-image),\n * [`background-pattern`](https://maplibre.org/maplibre-style-spec/layers/#paint-background-background-pattern),\n * [`fill-pattern`](https://maplibre.org/maplibre-style-spec/layers/#paint-fill-fill-pattern),\n * or [`line-pattern`](https://maplibre.org/maplibre-style-spec/layers/#paint-line-line-pattern).\n *\n * A {@link ErrorEvent} event will be fired if the image parameter is invalid or there is not enough space in the sprite to add this image.\n *\n * @param id - The ID of the image.\n * @param image - The image as an `HTMLImageElement`, `ImageData`, `ImageBitmap` or object with `width`, `height`, and `data`\n * properties with the same format as `ImageData`.\n * @param options - Options object.\n * @example\n * ```ts\n * // If the style's sprite does not already contain an image with ID 'cat',\n * // add the image 'cat-icon.png' to the style's sprite with the ID 'cat'.\n * const image = await map.loadImage('https://upload.wikimedia.org/wikipedia/commons/thumb/6/60/Cat_silhouette.svg/400px-Cat_silhouette.svg.png');\n * if (!map.hasImage('cat')) map.addImage('cat', image.data);\n *\n * // Add a stretchable image that can be used with `icon-text-fit`\n * // In this example, the image is 600px wide by 400px high.\n * const image = await map.loadImage('https://upload.wikimedia.org/wikipedia/commons/8/89/Black_and_White_Boxed_%28bordered%29.png');\n * if (map.hasImage('border-image')) return;\n * map.addImage('border-image', image.data, {\n * content: [16, 16, 300, 384], // place text over left half of image, avoiding the 16px border\n * stretchX: [[16, 584]], // stretch everything horizontally except the 16px border\n * stretchY: [[16, 384]], // stretch everything vertically except the 16px border\n * });\n * ```\n * @see Use `HTMLImageElement`: [Add an icon to the map](https://maplibre.org/maplibre-gl-js/docs/examples/add-image/)\n * @see Use `ImageData`: [Add a generated icon to the map](https://maplibre.org/maplibre-gl-js/docs/examples/add-image-generated/)\n */\n addImage(id: string,\n image: HTMLImageElement | ImageBitmap | ImageData | {\n width: number;\n height: number;\n data: Uint8Array | Uint8ClampedArray;\n } | StyleImageInterface,\n options: Partial = {}): this {\n const {\n pixelRatio = 1,\n sdf = false,\n stretchX,\n stretchY,\n content,\n textFitWidth,\n textFitHeight\n } = options;\n this._lazyInitEmptyStyle();\n const version = 0;\n\n if (image instanceof HTMLImageElement || isImageBitmap(image)) {\n const {width, height, data} = browser.getImageData(image);\n this.style.addImage(id, {data: new RGBAImage({width, height}, data), pixelRatio, stretchX, stretchY, content, textFitWidth, textFitHeight, sdf, version});\n } else if (image.width === undefined || image.height === undefined) {\n return this.fire(new ErrorEvent(new Error(\n 'Invalid arguments to map.addImage(). The second argument must be an `HTMLImageElement`, `ImageData`, `ImageBitmap`, ' +\n 'or object with `width`, `height`, and `data` properties with the same format as `ImageData`')));\n } else {\n const {width, height, data} = image as ImageData;\n const userImage = (image as any as StyleImageInterface);\n\n this.style.addImage(id, {\n data: new RGBAImage({width, height}, new Uint8Array(data)),\n pixelRatio,\n stretchX,\n stretchY,\n content,\n textFitWidth,\n textFitHeight,\n sdf,\n version,\n userImage\n });\n\n if (userImage.onAdd) {\n userImage.onAdd(this, id);\n }\n return this;\n }\n }\n\n /**\n * Update an existing image in a style. This image can be displayed on the map like any other icon in the style's\n * sprite using the image's ID with\n * [`icon-image`](https://maplibre.org/maplibre-style-spec/layers/#layout-symbol-icon-image),\n * [`background-pattern`](https://maplibre.org/maplibre-style-spec/layers/#paint-background-background-pattern),\n * [`fill-pattern`](https://maplibre.org/maplibre-style-spec/layers/#paint-fill-fill-pattern),\n * or [`line-pattern`](https://maplibre.org/maplibre-style-spec/layers/#paint-line-line-pattern).\n *\n * An {@link ErrorEvent} will be fired if the image parameter is invald.\n *\n * @param id - The ID of the image.\n * @param image - The image as an `HTMLImageElement`, `ImageData`, `ImageBitmap` or object with `width`, `height`, and `data`\n * properties with the same format as `ImageData`.\n * @example\n * ```ts\n * // If an image with the ID 'cat' already exists in the style's sprite,\n * // replace that image with a new image, 'other-cat-icon.png'.\n * if (map.hasImage('cat')) map.updateImage('cat', './other-cat-icon.png');\n * ```\n */\n updateImage(id: string,\n image: HTMLImageElement | ImageBitmap | ImageData | {\n width: number;\n height: number;\n data: Uint8Array | Uint8ClampedArray;\n } | StyleImageInterface): this {\n\n const existingImage = this.style.getImage(id);\n if (!existingImage) {\n return this.fire(new ErrorEvent(new Error(\n 'The map has no image with that id. If you are adding a new image use `map.addImage(...)` instead.')));\n }\n const imageData = (image instanceof HTMLImageElement || isImageBitmap(image)) ?\n browser.getImageData(image) :\n image;\n const {width, height, data} = imageData;\n\n if (width === undefined || height === undefined) {\n return this.fire(new ErrorEvent(new Error(\n 'Invalid arguments to map.updateImage(). The second argument must be an `HTMLImageElement`, `ImageData`, `ImageBitmap`, ' +\n 'or object with `width`, `height`, and `data` properties with the same format as `ImageData`')));\n }\n\n if (width !== existingImage.data.width || height !== existingImage.data.height) {\n return this.fire(new ErrorEvent(new Error(\n 'The width and height of the updated image must be that same as the previous version of the image')));\n }\n\n const copy = !(image instanceof HTMLImageElement || isImageBitmap(image));\n existingImage.data.replace(data, copy);\n\n this.style.updateImage(id, existingImage);\n return this;\n }\n\n /**\n * Returns an image, specified by ID, currently available in the map.\n * This includes both images from the style's original sprite\n * and any images that have been added at runtime using {@link Map#addImage}.\n *\n * @param id - The ID of the image.\n * @returns An image in the map with the specified ID.\n *\n * @example\n * ```ts\n * let coffeeShopIcon = map.getImage(\"coffee_cup\");\n * ```\n */\n getImage(id: string): StyleImage {\n return this.style.getImage(id);\n }\n\n /**\n * Check whether or not an image with a specific ID exists in the style. This checks both images\n * in the style's original sprite and any images\n * that have been added at runtime using {@link Map#addImage}.\n *\n * An {@link ErrorEvent} will be fired if the image parameter is invald.\n *\n * @param id - The ID of the image.\n *\n * @returns A Boolean indicating whether the image exists.\n * @example\n * Check if an image with the ID 'cat' exists in the style's sprite.\n * ```ts\n * let catIconExists = map.hasImage('cat');\n * ```\n */\n hasImage(id: string): boolean {\n if (!id) {\n this.fire(new ErrorEvent(new Error('Missing required image id')));\n return false;\n }\n\n return !!this.style.getImage(id);\n }\n\n /**\n * Remove an image from a style. This can be an image from the style's original\n * sprite or any images\n * that have been added at runtime using {@link Map#addImage}.\n *\n * @param id - The ID of the image.\n *\n * @example\n * ```ts\n * // If an image with the ID 'cat' exists in\n * // the style's sprite, remove it.\n * if (map.hasImage('cat')) map.removeImage('cat');\n * ```\n */\n removeImage(id: string) {\n this.style.removeImage(id);\n }\n\n /**\n * Load an image from an external URL to be used with {@link Map#addImage}. External\n * domains must support [CORS](https://developer.mozilla.org/en-US/docs/Web/HTTP/Access_control_CORS).\n *\n * @param url - The URL of the image file. Image file must be in png, webp, or jpg format.\n * @returns a promise that is resolved when the image is loaded\n *\n * @example\n * Load an image from an external URL.\n * ```ts\n * const response = await map.loadImage('https://picsum.photos/50/50');\n * // Add the loaded image to the style's sprite with the ID 'photo'.\n * map.addImage('photo', response.data);\n * ```\n * @see [Add an icon to the map](https://maplibre.org/maplibre-gl-js/docs/examples/add-image/)\n */\n loadImage(url: string): Promise> {\n return ImageRequest.getImage(this._requestManager.transformRequest(url, ResourceType.Image), new AbortController());\n }\n\n /**\n * Returns an Array of strings containing the IDs of all images currently available in the map.\n * This includes both images from the style's original sprite\n * and any images that have been added at runtime using {@link Map#addImage}.\n *\n * @returns An Array of strings containing the names of all sprites/images currently available in the map.\n *\n * @example\n * ```ts\n * let allImages = map.listImages();\n * ```\n */\n listImages(): Array {\n return this.style.listImages();\n }\n\n /**\n * Adds a [MapLibre style layer](https://maplibre.org/maplibre-style-spec/layers)\n * to the map's style.\n *\n * A layer defines how data from a specified source will be styled. Read more about layer types\n * and available paint and layout properties in the [MapLibre Style Specification](https://maplibre.org/maplibre-style-spec/layers).\n *\n * @param layer - The layer to add,\n * conforming to either the MapLibre Style Specification's [layer definition](https://maplibre.org/maplibre-style-spec/layers) or,\n * less commonly, the {@link CustomLayerInterface} specification. Can also be a layer definition with an embedded source definition.\n * The MapLibre Style Specification's layer definition is appropriate for most layers.\n *\n * @param beforeId - The ID of an existing layer to insert the new layer before,\n * resulting in the new layer appearing visually beneath the existing layer.\n * If this argument is not specified, the layer will be appended to the end of the layers array\n * and appear visually above all other layers.\n *\n * @example\n * Add a circle layer with a vector source\n * ```ts\n * map.addLayer({\n * id: 'points-of-interest',\n * source: {\n * type: 'vector',\n * url: 'https://demotiles.maplibre.org/tiles/tiles.json'\n * },\n * 'source-layer': 'poi_label',\n * type: 'circle',\n * paint: {\n * // MapLibre Style Specification paint properties\n * },\n * layout: {\n * // MapLibre Style Specification layout properties\n * }\n * });\n * ```\n *\n * @example\n * Define a source before using it to create a new layer\n * ```ts\n * map.addSource('state-data', {\n * type: 'geojson',\n * data: 'path/to/data.geojson'\n * });\n *\n * map.addLayer({\n * id: 'states',\n * // References the GeoJSON source defined above\n * // and does not require a `source-layer`\n * source: 'state-data',\n * type: 'symbol',\n * layout: {\n * // Set the label content to the\n * // feature's `name` property\n * text-field: ['get', 'name']\n * }\n * });\n * ```\n *\n * @example\n * Add a new symbol layer before an existing layer\n * ```ts\n * map.addLayer({\n * id: 'states',\n * // References a source that's already been defined\n * source: 'state-data',\n * type: 'symbol',\n * layout: {\n * // Set the label content to the\n * // feature's `name` property\n * text-field: ['get', 'name']\n * }\n * // Add the layer before the existing `cities` layer\n * }, 'cities');\n * ```\n * @see [Create and style clusters](https://maplibre.org/maplibre-gl-js/docs/examples/cluster/)\n * @see [Add a vector tile source](https://maplibre.org/maplibre-gl-js/docs/examples/vector-source/)\n * @see [Add a WMS source](https://maplibre.org/maplibre-gl-js/docs/examples/wms/)\n */\n addLayer(layer: AddLayerObject, beforeId?: string) {\n this._lazyInitEmptyStyle();\n this.style.addLayer(layer, beforeId);\n return this._update(true);\n }\n\n /**\n * Moves a layer to a different z-position.\n *\n * @param id - The ID of the layer to move.\n * @param beforeId - The ID of an existing layer to insert the new layer before. When viewing the map, the `id` layer will appear beneath the `beforeId` layer. If `beforeId` is omitted, the layer will be appended to the end of the layers array and appear above all other layers on the map.\n *\n * @example\n * Move a layer with ID 'polygon' before the layer with ID 'country-label'. The `polygon` layer will appear beneath the `country-label` layer on the map.\n * ```ts\n * map.moveLayer('polygon', 'country-label');\n * ```\n */\n moveLayer(id: string, beforeId?: string): this {\n this.style.moveLayer(id, beforeId);\n return this._update(true);\n }\n\n /**\n * Removes the layer with the given ID from the map's style.\n *\n * An {@link ErrorEvent} will be fired if the image parameter is invald.\n *\n * @param id - The ID of the layer to remove\n *\n * @example\n * If a layer with ID 'state-data' exists, remove it.\n * ```ts\n * if (map.getLayer('state-data')) map.removeLayer('state-data');\n * ```\n */\n removeLayer(id: string): this {\n this.style.removeLayer(id);\n return this._update(true);\n }\n\n /**\n * Returns the layer with the specified ID in the map's style.\n *\n * @param id - The ID of the layer to get.\n * @returns The layer with the specified ID, or `undefined`\n * if the ID corresponds to no existing layers.\n *\n * @example\n * ```ts\n * let stateDataLayer = map.getLayer('state-data');\n * ```\n * @see [Filter symbols by toggling a list](https://maplibre.org/maplibre-gl-js/docs/examples/filter-markers/)\n * @see [Filter symbols by text input](https://maplibre.org/maplibre-gl-js/docs/examples/filter-markers-by-input/)\n */\n getLayer(id: string): StyleLayer | undefined {\n return this.style.getLayer(id);\n }\n\n /**\n * Return the ids of all layers currently in the style, including custom layers, in order.\n *\n * @returns ids of layers, in order\n *\n * @example\n * ```ts\n * const orderedLayerIds = map.getLayersOrder();\n * ```\n */\n getLayersOrder(): string[] {\n return this.style.getLayersOrder();\n }\n\n /**\n * Sets the zoom extent for the specified style layer. The zoom extent includes the\n * [minimum zoom level](https://maplibre.org/maplibre-style-spec/layers/#minzoom)\n * and [maximum zoom level](https://maplibre.org/maplibre-style-spec/layers/#maxzoom))\n * at which the layer will be rendered.\n *\n * Note: For style layers using vector sources, style layers cannot be rendered at zoom levels lower than the\n * minimum zoom level of the _source layer_ because the data does not exist at those zoom levels. If the minimum\n * zoom level of the source layer is higher than the minimum zoom level defined in the style layer, the style\n * layer will not be rendered at all zoom levels in the zoom range.\n *\n * @param layerId - The ID of the layer to which the zoom extent will be applied.\n * @param minzoom - The minimum zoom to set (0-24).\n * @param maxzoom - The maximum zoom to set (0-24).\n *\n * @example\n * ```ts\n * map.setLayerZoomRange('my-layer', 2, 5);\n * ```\n */\n setLayerZoomRange(layerId: string, minzoom: number, maxzoom: number): this {\n this.style.setLayerZoomRange(layerId, minzoom, maxzoom);\n return this._update(true);\n }\n\n /**\n * Sets the filter for the specified style layer.\n *\n * Filters control which features a style layer renders from its source.\n * Any feature for which the filter expression evaluates to `true` will be\n * rendered on the map. Those that are false will be hidden.\n *\n * Use `setFilter` to show a subset of your source data.\n *\n * To clear the filter, pass `null` or `undefined` as the second parameter.\n *\n * @param layerId - The ID of the layer to which the filter will be applied.\n * @param filter - The filter, conforming to the MapLibre Style Specification's\n * [filter definition](https://maplibre.org/maplibre-style-spec/layers/#filter). If `null` or `undefined` is provided, the function removes any existing filter from the layer.\n * @param options - Options object.\n *\n * @example\n * Display only features with the 'name' property 'USA'\n * ```ts\n * map.setFilter('my-layer', ['==', ['get', 'name'], 'USA']);\n * ```\n * @example\n * Display only features with five or more 'available-spots'\n * ```ts\n * map.setFilter('bike-docks', ['>=', ['get', 'available-spots'], 5]);\n * ```\n * @example\n * Remove the filter for the 'bike-docks' style layer\n * ```ts\n * map.setFilter('bike-docks', null);\n * ```\n * @see [Create a timeline animation](https://maplibre.org/maplibre-gl-js/docs/examples/timeline-animation/)\n */\n setFilter(layerId: string, filter?: FilterSpecification | null, options: StyleSetterOptions = {}) {\n this.style.setFilter(layerId, filter, options);\n return this._update(true);\n }\n\n /**\n * Returns the filter applied to the specified style layer.\n *\n * @param layerId - The ID of the style layer whose filter to get.\n * @returns The layer's filter.\n */\n getFilter(layerId: string): FilterSpecification | void {\n return this.style.getFilter(layerId);\n }\n\n /**\n * Sets the value of a paint property in the specified style layer.\n *\n * @param layerId - The ID of the layer to set the paint property in.\n * @param name - The name of the paint property to set.\n * @param value - The value of the paint property to set.\n * Must be of a type appropriate for the property, as defined in the [MapLibre Style Specification](https://maplibre.org/maplibre-style-spec/).\n * Pass `null` to unset the existing value.\n * @param options - Options object.\n * @example\n * ```ts\n * map.setPaintProperty('my-layer', 'fill-color', '#faafee');\n * ```\n * @see [Change a layer's color with buttons](https://maplibre.org/maplibre-gl-js/docs/examples/color-switcher/)\n * @see [Create a draggable point](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-point/)\n */\n setPaintProperty(layerId: string, name: string, value: any, options: StyleSetterOptions = {}): this {\n this.style.setPaintProperty(layerId, name, value, options);\n return this._update(true);\n }\n\n /**\n * Returns the value of a paint property in the specified style layer.\n *\n * @param layerId - The ID of the layer to get the paint property from.\n * @param name - The name of a paint property to get.\n * @returns The value of the specified paint property.\n */\n getPaintProperty(layerId: string, name: string) {\n return this.style.getPaintProperty(layerId, name);\n }\n\n /**\n * Sets the value of a layout property in the specified style layer.\n *\n * @param layerId - The ID of the layer to set the layout property in.\n * @param name - The name of the layout property to set.\n * @param value - The value of the layout property. Must be of a type appropriate for the property, as defined in the [MapLibre Style Specification](https://maplibre.org/maplibre-style-spec/).\n * @param options - The options object.\n * @example\n * ```ts\n * map.setLayoutProperty('my-layer', 'visibility', 'none');\n * ```\n */\n setLayoutProperty(layerId: string, name: string, value: any, options: StyleSetterOptions = {}): this {\n this.style.setLayoutProperty(layerId, name, value, options);\n return this._update(true);\n }\n\n /**\n * Returns the value of a layout property in the specified style layer.\n *\n * @param layerId - The ID of the layer to get the layout property from.\n * @param name - The name of the layout property to get.\n * @returns The value of the specified layout property.\n */\n getLayoutProperty(layerId: string, name: string) {\n return this.style.getLayoutProperty(layerId, name);\n }\n\n /**\n * Sets the value of the style's glyphs property.\n *\n * @param glyphsUrl - Glyph URL to set. Must conform to the [MapLibre Style Specification](https://maplibre.org/maplibre-style-spec/glyphs/).\n * @param options - Options object.\n * @example\n * ```ts\n * map.setGlyphs('https://demotiles.maplibre.org/font/{fontstack}/{range}.pbf');\n * ```\n */\n setGlyphs(glyphsUrl: string | null, options: StyleSetterOptions = {}): this {\n this._lazyInitEmptyStyle();\n this.style.setGlyphs(glyphsUrl, options);\n return this._update(true);\n }\n\n /**\n * Returns the value of the style's glyphs URL\n *\n * @returns glyphs Style's glyphs url\n */\n getGlyphs(): string | null {\n return this.style.getGlyphsUrl();\n }\n\n /**\n * Adds a sprite to the map's style. Fires the `style` event.\n *\n * @param id - The ID of the sprite to add. Must not conflict with existing sprites.\n * @param url - The URL to load the sprite from\n * @param options - Options object.\n * @example\n * ```ts\n * map.addSprite('sprite-two', 'http://example.com/sprite-two');\n * ```\n */\n addSprite(id: string, url: string, options: StyleSetterOptions = {}): this {\n this._lazyInitEmptyStyle();\n this.style.addSprite(id, url, options, (err) => {\n if (!err) {\n this._update(true);\n }\n });\n return this;\n }\n\n /**\n * Removes the sprite from the map's style. Fires the `style` event.\n *\n * @param id - The ID of the sprite to remove. If the sprite is declared as a single URL, the ID must be \"default\".\n * @example\n * ```ts\n * map.removeSprite('sprite-two');\n * map.removeSprite('default');\n * ```\n */\n removeSprite(id: string) {\n this._lazyInitEmptyStyle();\n this.style.removeSprite(id);\n return this._update(true);\n }\n\n /**\n * Returns the as-is value of the style's sprite.\n *\n * @returns style's sprite list of id-url pairs\n */\n getSprite(): {id: string; url: string}[] {\n return this.style.getSprite();\n }\n\n /**\n * Sets the value of the style's sprite property.\n *\n * @param spriteUrl - Sprite URL to set.\n * @param options - Options object.\n * @example\n * ```ts\n * map.setSprite('YOUR_SPRITE_URL');\n * ```\n */\n setSprite(spriteUrl: string | null, options: StyleSetterOptions = {}) {\n this._lazyInitEmptyStyle();\n this.style.setSprite(spriteUrl, options, (err) => {\n if (!err) {\n this._update(true);\n }\n });\n return this;\n }\n\n /**\n * Sets the any combination of light values.\n *\n * @param light - Light properties to set. Must conform to the [MapLibre Style Specification](https://maplibre.org/maplibre-style-spec/light).\n * @param options - Options object.\n *\n * @example\n * ```ts\n * let layerVisibility = map.getLayoutProperty('my-layer', 'visibility');\n * ```\n */\n setLight(light: LightSpecification, options: StyleSetterOptions = {}) {\n this._lazyInitEmptyStyle();\n this.style.setLight(light, options);\n return this._update(true);\n }\n\n /**\n * Returns the value of the light object.\n *\n * @returns light Light properties of the style.\n */\n getLight(): LightSpecification {\n return this.style.getLight();\n }\n\n /**\n * Loads sky and fog defined by {@link SkySpecification} onto the map.\n * Note: The fog only shows when using the terrain 3D feature.\n * @param sky - Sky properties to set. Must conform to the [MapLibre Style Specification](https://maplibre.org/maplibre-style-spec/sky/).\n * @returns `this`\n * @example\n * ```ts\n * map.setSky({ 'sky-color': '#00f' });\n * ```\n */\n setSky(sky: SkySpecification) {\n this._lazyInitEmptyStyle();\n this.style.setSky(sky);\n return this._update(true);\n }\n\n /**\n * Returns the value of the sky object.\n *\n * @returns the sky properties of the style.\n * @example\n * ```ts\n * map.getSky();\n * ```\n */\n getSky() {\n return this.style.getSky();\n }\n\n /**\n * Sets the `state` of a feature.\n * A feature's `state` is a set of user-defined key-value pairs that are assigned to a feature at runtime.\n * When using this method, the `state` object is merged with any existing key-value pairs in the feature's state.\n * Features are identified by their `feature.id` attribute, which can be any number or string.\n *\n * This method can only be used with sources that have a `feature.id` attribute. The `feature.id` attribute can be defined in three ways:\n *\n * - For vector or GeoJSON sources, including an `id` attribute in the original data file.\n * - For vector or GeoJSON sources, using the [`promoteId`](https://maplibre.org/maplibre-style-spec/sources/#vector-promoteId) option at the time the source is defined.\n * - For GeoJSON sources, using the [`generateId`](https://maplibre.org/maplibre-style-spec/sources/#geojson-generateId) option to auto-assign an `id` based on the feature's index in the source data. If you change feature data using `map.getSource('some id').setData(..)`, you may need to re-apply state taking into account updated `id` values.\n *\n * _Note: You can use the [`feature-state` expression](https://maplibre.org/maplibre-style-spec/expressions/#feature-state) to access the values in a feature's state object for the purposes of styling._\n *\n * @param feature - Feature identifier. Feature objects returned from\n * {@link Map#queryRenderedFeatures} or event handlers can be used as feature identifiers.\n * @param state - A set of key-value pairs. The values should be valid JSON types.\n *\n * @example\n * ```ts\n * // When the mouse moves over the `my-layer` layer, update\n * // the feature state for the feature under the mouse\n * map.on('mousemove', 'my-layer', (e) => {\n * if (e.features.length > 0) {\n * map.setFeatureState({\n * source: 'my-source',\n * sourceLayer: 'my-source-layer',\n * id: e.features[0].id,\n * }, {\n * hover: true\n * });\n * }\n * });\n * ```\n * @see [Create a hover effect](https://maplibre.org/maplibre-gl-js/docs/examples/hover-styles/)\n */\n setFeatureState(feature: FeatureIdentifier, state: any): this {\n this.style.setFeatureState(feature, state);\n return this._update();\n }\n\n /**\n * Removes the `state` of a feature, setting it back to the default behavior.\n * If only a `target.source` is specified, it will remove the state for all features from that source.\n * If `target.id` is also specified, it will remove all keys for that feature's state.\n * If `key` is also specified, it removes only that key from that feature's state.\n * Features are identified by their `feature.id` attribute, which can be any number or string.\n *\n * @param target - Identifier of where to remove state. It can be a source, a feature, or a specific key of feature.\n * Feature objects returned from {@link Map#queryRenderedFeatures} or event handlers can be used as feature identifiers.\n * @param key - (optional) The key in the feature state to reset.\n * @example\n * Reset the entire state object for all features in the `my-source` source\n * ```ts\n * map.removeFeatureState({\n * source: 'my-source'\n * });\n * ```\n *\n * @example\n * When the mouse leaves the `my-layer` layer,\n * reset the entire state object for the\n * feature under the mouse\n * ```ts\n * map.on('mouseleave', 'my-layer', (e) => {\n * map.removeFeatureState({\n * source: 'my-source',\n * sourceLayer: 'my-source-layer',\n * id: e.features[0].id\n * });\n * });\n * ```\n *\n * @example\n * When the mouse leaves the `my-layer` layer,\n * reset only the `hover` key-value pair in the\n * state for the feature under the mouse\n * ```ts\n * map.on('mouseleave', 'my-layer', (e) => {\n * map.removeFeatureState({\n * source: 'my-source',\n * sourceLayer: 'my-source-layer',\n * id: e.features[0].id\n * }, 'hover');\n * });\n * ```\n */\n removeFeatureState(target: FeatureIdentifier, key?: string): this {\n this.style.removeFeatureState(target, key);\n return this._update();\n }\n\n /**\n * Gets the `state` of a feature.\n * A feature's `state` is a set of user-defined key-value pairs that are assigned to a feature at runtime.\n * Features are identified by their `feature.id` attribute, which can be any number or string.\n *\n * _Note: To access the values in a feature's state object for the purposes of styling the feature, use the [`feature-state` expression](https://maplibre.org/maplibre-style-spec/expressions/#feature-state)._\n *\n * @param feature - Feature identifier. Feature objects returned from\n * {@link Map#queryRenderedFeatures} or event handlers can be used as feature identifiers.\n * @returns The state of the feature: a set of key-value pairs that was assigned to the feature at runtime.\n *\n * @example\n * When the mouse moves over the `my-layer` layer,\n * get the feature state for the feature under the mouse\n * ```ts\n * map.on('mousemove', 'my-layer', (e) => {\n * if (e.features.length > 0) {\n * map.getFeatureState({\n * source: 'my-source',\n * sourceLayer: 'my-source-layer',\n * id: e.features[0].id\n * });\n * }\n * });\n * ```\n */\n getFeatureState(feature: FeatureIdentifier): any {\n return this.style.getFeatureState(feature);\n }\n\n /**\n * Returns the map's containing HTML element.\n *\n * @returns The map's container.\n */\n getContainer(): HTMLElement {\n return this._container;\n }\n\n /**\n * Returns the HTML element containing the map's `` element.\n *\n * If you want to add non-GL overlays to the map, you should append them to this element.\n *\n * This is the element to which event bindings for map interactivity (such as panning and zooming) are\n * attached. It will receive bubbled events from child elements such as the ``, but not from\n * map controls.\n *\n * @returns The container of the map's ``.\n * @see [Create a draggable point](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-point/)\n */\n getCanvasContainer(): HTMLElement {\n return this._canvasContainer;\n }\n\n /**\n * Returns the map's `` element.\n *\n * @returns The map's `` element.\n * @see [Measure distances](https://maplibre.org/maplibre-gl-js/docs/examples/measure/)\n * @see [Display a popup on hover](https://maplibre.org/maplibre-gl-js/docs/examples/popup-on-hover/)\n * @see [Center the map on a clicked symbol](https://maplibre.org/maplibre-gl-js/docs/examples/center-on-symbol/)\n */\n getCanvas(): HTMLCanvasElement {\n return this._canvas;\n }\n\n _containerDimensions() {\n let width = 0;\n let height = 0;\n\n if (this._container) {\n width = this._container.clientWidth || 400;\n height = this._container.clientHeight || 300;\n }\n\n return [width, height];\n }\n\n _setupContainer() {\n const container = this._container;\n container.classList.add('maplibregl-map');\n\n const canvasContainer = this._canvasContainer = DOM.create('div', 'maplibregl-canvas-container', container);\n if (this._interactive) {\n canvasContainer.classList.add('maplibregl-interactive');\n }\n\n this._canvas = DOM.create('canvas', 'maplibregl-canvas', canvasContainer);\n this._canvas.addEventListener('webglcontextlost', this._contextLost, false);\n this._canvas.addEventListener('webglcontextrestored', this._contextRestored, false);\n this._canvas.setAttribute('tabindex', this._interactive ? '0' : '-1');\n this._canvas.setAttribute('aria-label', this._getUIString('Map.Title'));\n this._canvas.setAttribute('role', 'region');\n\n const dimensions = this._containerDimensions();\n const clampedPixelRatio = this._getClampedPixelRatio(dimensions[0], dimensions[1]);\n this._resizeCanvas(dimensions[0], dimensions[1], clampedPixelRatio);\n\n const controlContainer = this._controlContainer = DOM.create('div', 'maplibregl-control-container', container);\n const positions = this._controlPositions = {};\n ['top-left', 'top-right', 'bottom-left', 'bottom-right'].forEach((positionName) => {\n positions[positionName] = DOM.create('div', `maplibregl-ctrl-${positionName} `, controlContainer);\n });\n\n this._container.addEventListener('scroll', this._onMapScroll, false);\n }\n\n _resizeCanvas(width: number, height: number, pixelRatio: number) {\n // Request the required canvas size taking the pixelratio into account.\n this._canvas.width = Math.floor(pixelRatio * width);\n this._canvas.height = Math.floor(pixelRatio * height);\n\n // Maintain the same canvas size, potentially downscaling it for HiDPI displays\n this._canvas.style.width = `${width}px`;\n this._canvas.style.height = `${height}px`;\n }\n\n _setupPainter() {\n\n const attributes = {\n alpha: true,\n stencil: true,\n depth: true,\n failIfMajorPerformanceCaveat: this._failIfMajorPerformanceCaveat,\n preserveDrawingBuffer: this._preserveDrawingBuffer,\n antialias: this._antialias || false\n };\n\n let webglcontextcreationerrorDetailObject: any = null;\n this._canvas.addEventListener('webglcontextcreationerror', (args: WebGLContextEvent) => {\n webglcontextcreationerrorDetailObject = {requestedAttributes: attributes};\n if (args) {\n webglcontextcreationerrorDetailObject.statusMessage = args.statusMessage;\n webglcontextcreationerrorDetailObject.type = args.type;\n }\n }, {once: true});\n\n const gl =\n this._canvas.getContext('webgl2', attributes) as WebGL2RenderingContext ||\n this._canvas.getContext('webgl', attributes) as WebGLRenderingContext;\n\n if (!gl) {\n const msg = 'Failed to initialize WebGL';\n if (webglcontextcreationerrorDetailObject) {\n webglcontextcreationerrorDetailObject.message = msg;\n throw new Error(JSON.stringify(webglcontextcreationerrorDetailObject));\n } else {\n throw new Error(msg);\n }\n }\n\n this.painter = new Painter(gl, this.transform);\n\n webpSupported.testSupport(gl);\n }\n\n _contextLost = (event: any) => {\n event.preventDefault();\n if (this._frameRequest) {\n this._frameRequest.abort();\n this._frameRequest = null;\n }\n this.fire(new Event('webglcontextlost', {originalEvent: event}));\n };\n\n _contextRestored = (event: any) => {\n this._setupPainter();\n this.resize();\n this._update();\n this.fire(new Event('webglcontextrestored', {originalEvent: event}));\n };\n\n _onMapScroll = (event: any) => {\n if (event.target !== this._container) return;\n\n // Revert any scroll which would move the canvas outside of the view\n this._container.scrollTop = 0;\n this._container.scrollLeft = 0;\n return false;\n };\n\n /**\n * Returns a Boolean indicating whether the map is fully loaded.\n *\n * Returns `false` if the style is not yet fully loaded,\n * or if there has been a change to the sources or style that\n * has not yet fully loaded.\n *\n * @returns A Boolean indicating whether the map is fully loaded.\n */\n loaded(): boolean {\n return !this._styleDirty && !this._sourcesDirty && !!this.style && this.style.loaded();\n }\n\n /**\n * @internal\n * Update this map's style and sources, and re-render the map.\n *\n * @param updateStyle - mark the map's style for reprocessing as\n * well as its sources\n */\n _update(updateStyle?: boolean) {\n if (!this.style || !this.style._loaded) return this;\n\n this._styleDirty = this._styleDirty || updateStyle;\n this._sourcesDirty = true;\n this.triggerRepaint();\n\n return this;\n }\n\n /**\n * @internal\n * Request that the given callback be executed during the next render\n * frame. Schedule a render frame if one is not already scheduled.\n *\n * @returns An id that can be used to cancel the callback\n */\n _requestRenderFrame(callback: () => void): TaskID {\n this._update();\n return this._renderTaskQueue.add(callback);\n }\n\n _cancelRenderFrame(id: TaskID) {\n this._renderTaskQueue.remove(id);\n }\n\n /**\n * @internal\n * Call when a (re-)render of the map is required:\n *\n * - The style has changed (`setPaintProperty()`, etc.)\n * - Source data has changed (e.g. tiles have finished loading)\n * - The map has is moving (or just finished moving)\n * - A transition is in progress\n *\n * @param paintStartTimeStamp - The time when the animation frame began executing.\n */\n _render(paintStartTimeStamp: number) {\n const fadeDuration = this._idleTriggered ? this._fadeDuration : 0;\n\n // A custom layer may have used the context asynchronously. Mark the state as dirty.\n this.painter.context.setDirty();\n this.painter.setBaseState();\n\n this._renderTaskQueue.run(paintStartTimeStamp);\n // A task queue callback may have fired a user event which may have removed the map\n if (this._removed) return;\n\n let crossFading = false;\n\n // If the style has changed, the map is being zoomed, or a transition or fade is in progress:\n // - Apply style changes (in a batch)\n // - Recalculate paint properties.\n if (this.style && this._styleDirty) {\n this._styleDirty = false;\n\n const zoom = this.transform.zoom;\n const now = browser.now();\n this.style.zoomHistory.update(zoom, now);\n\n const parameters = new EvaluationParameters(zoom, {\n now,\n fadeDuration,\n zoomHistory: this.style.zoomHistory,\n transition: this.style.getTransition()\n });\n\n const factor = parameters.crossFadingFactor();\n if (factor !== 1 || factor !== this._crossFadingFactor) {\n crossFading = true;\n this._crossFadingFactor = factor;\n }\n\n this.style.update(parameters);\n }\n\n // If we are in _render for any reason other than an in-progress paint\n // transition, update source caches to check for and load any tiles we\n // need for the current transform\n if (this.style && this._sourcesDirty) {\n this._sourcesDirty = false;\n this.style._updateSources(this.transform);\n }\n\n // update terrain stuff\n if (this.terrain) {\n this.terrain.sourceCache.update(this.transform, this.terrain);\n this.transform.minElevationForCurrentTile = this.terrain.getMinTileElevationForLngLatZoom(this.transform.center, this.transform.tileZoom);\n if (!this._elevationFreeze) {\n this.transform.elevation = this.terrain.getElevationForLngLatZoom(this.transform.center, this.transform.tileZoom);\n }\n } else {\n this.transform.minElevationForCurrentTile = 0;\n this.transform.elevation = 0;\n }\n\n this._placementDirty = this.style && this.style._updatePlacement(this.painter.transform, this.showCollisionBoxes, fadeDuration, this._crossSourceCollisions);\n\n // Actually draw\n this.painter.render(this.style, {\n showTileBoundaries: this.showTileBoundaries,\n showOverdrawInspector: this._showOverdrawInspector,\n rotating: this.isRotating(),\n zooming: this.isZooming(),\n moving: this.isMoving(),\n fadeDuration,\n showPadding: this.showPadding,\n });\n\n this.fire(new Event('render'));\n\n if (this.loaded() && !this._loaded) {\n this._loaded = true;\n PerformanceUtils.mark(PerformanceMarkers.load);\n this.fire(new Event('load'));\n }\n\n if (this.style && (this.style.hasTransitions() || crossFading)) {\n this._styleDirty = true;\n }\n\n if (this.style && !this._placementDirty) {\n // Since no fade operations are in progress, we can release\n // all tiles held for fading. If we didn't do this, the tiles\n // would just sit in the SourceCaches until the next render\n this.style._releaseSymbolFadeTiles();\n }\n\n // Schedule another render frame if it's needed.\n //\n // Even though `_styleDirty` and `_sourcesDirty` are reset in this\n // method, synchronous events fired during Style#update or\n // Style#_updateSources could have caused them to be set again.\n const somethingDirty = this._sourcesDirty || this._styleDirty || this._placementDirty;\n if (somethingDirty || this._repaint) {\n this.triggerRepaint();\n } else if (!this.isMoving() && this.loaded()) {\n this.fire(new Event('idle'));\n }\n\n if (this._loaded && !this._fullyLoaded && !somethingDirty) {\n this._fullyLoaded = true;\n PerformanceUtils.mark(PerformanceMarkers.fullLoad);\n }\n\n return this;\n }\n\n /**\n * Force a synchronous redraw of the map.\n * @example\n * ```ts\n * map.redraw();\n * ```\n */\n redraw(): this {\n if (this.style) {\n // cancel the scheduled update\n if (this._frameRequest) {\n this._frameRequest.abort();\n this._frameRequest = null;\n }\n this._render(0);\n }\n return this;\n }\n\n /**\n * Clean up and release all internal resources associated with this map.\n *\n * This includes DOM elements, event bindings, web workers, and WebGL resources.\n *\n * Use this method when you are done using the map and wish to ensure that it no\n * longer consumes browser resources. Afterwards, you must not call any other\n * methods on the map.\n */\n remove() {\n if (this._hash) this._hash.remove();\n\n for (const control of this._controls) control.onRemove(this);\n this._controls = [];\n\n if (this._frameRequest) {\n this._frameRequest.abort();\n this._frameRequest = null;\n }\n this._renderTaskQueue.clear();\n this.painter.destroy();\n this.handlers.destroy();\n delete this.handlers;\n this.setStyle(null);\n if (typeof window !== 'undefined') {\n removeEventListener('online', this._onWindowOnline, false);\n }\n\n ImageRequest.removeThrottleControl(this._imageQueueHandle);\n\n this._resizeObserver?.disconnect();\n const extension = this.painter.context.gl.getExtension('WEBGL_lose_context');\n if (extension?.loseContext) extension.loseContext();\n this._canvas.removeEventListener('webglcontextrestored', this._contextRestored, false);\n this._canvas.removeEventListener('webglcontextlost', this._contextLost, false);\n DOM.remove(this._canvasContainer);\n DOM.remove(this._controlContainer);\n this._container.classList.remove('maplibregl-map');\n\n PerformanceUtils.clearMetrics();\n\n this._removed = true;\n this.fire(new Event('remove'));\n }\n\n /**\n * Trigger the rendering of a single frame. Use this method with custom layers to\n * repaint the map when the layer changes. Calling this multiple times before the\n * next frame is rendered will still result in only a single frame being rendered.\n * @example\n * ```ts\n * map.triggerRepaint();\n * ```\n * @see [Add a 3D model](https://maplibre.org/maplibre-gl-js/docs/examples/add-3d-model/)\n * @see [Add an animated icon to the map](https://maplibre.org/maplibre-gl-js/docs/examples/add-image-animated/)\n */\n triggerRepaint() {\n if (this.style && !this._frameRequest) {\n this._frameRequest = new AbortController();\n browser.frameAsync(this._frameRequest).then((paintStartTimeStamp: number) => {\n PerformanceUtils.frame(paintStartTimeStamp);\n this._frameRequest = null;\n this._render(paintStartTimeStamp);\n }).catch(() => {}); // ignore abort error\n }\n }\n\n _onWindowOnline = () => {\n this._update();\n };\n\n /**\n * Gets and sets a Boolean indicating whether the map will render an outline\n * around each tile and the tile ID. These tile boundaries are useful for\n * debugging.\n *\n * The uncompressed file size of the first vector source is drawn in the top left\n * corner of each tile, next to the tile ID.\n *\n * @example\n * ```ts\n * map.showTileBoundaries = true;\n * ```\n */\n get showTileBoundaries(): boolean { return !!this._showTileBoundaries; }\n set showTileBoundaries(value: boolean) {\n if (this._showTileBoundaries === value) return;\n this._showTileBoundaries = value;\n this._update();\n }\n\n /**\n * Gets and sets a Boolean indicating whether the map will visualize\n * the padding offsets.\n */\n get showPadding(): boolean { return !!this._showPadding; }\n set showPadding(value: boolean) {\n if (this._showPadding === value) return;\n this._showPadding = value;\n this._update();\n }\n\n /**\n * Gets and sets a Boolean indicating whether the map will render boxes\n * around all symbols in the data source, revealing which symbols\n * were rendered or which were hidden due to collisions.\n * This information is useful for debugging.\n */\n get showCollisionBoxes(): boolean { return !!this._showCollisionBoxes; }\n set showCollisionBoxes(value: boolean) {\n if (this._showCollisionBoxes === value) return;\n this._showCollisionBoxes = value;\n if (value) {\n // When we turn collision boxes on we have to generate them for existing tiles\n // When we turn them off, there's no cost to leaving existing boxes in place\n this.style._generateCollisionBoxes();\n } else {\n // Otherwise, call an update to remove collision boxes\n this._update();\n }\n }\n\n /**\n * Gets and sets a Boolean indicating whether the map should color-code\n * each fragment to show how many times it has been shaded.\n * White fragments have been shaded 8 or more times.\n * Black fragments have been shaded 0 times.\n * This information is useful for debugging.\n */\n get showOverdrawInspector(): boolean { return !!this._showOverdrawInspector; }\n set showOverdrawInspector(value: boolean) {\n if (this._showOverdrawInspector === value) return;\n this._showOverdrawInspector = value;\n this._update();\n }\n\n /**\n * Gets and sets a Boolean indicating whether the map will\n * continuously repaint. This information is useful for analyzing performance.\n */\n get repaint(): boolean { return !!this._repaint; }\n set repaint(value: boolean) {\n if (this._repaint !== value) {\n this._repaint = value;\n this.triggerRepaint();\n }\n }\n // show vertices\n get vertices(): boolean { return !!this._vertices; }\n set vertices(value: boolean) { this._vertices = value; this._update(); }\n\n /**\n * Returns the package version of the library\n * @returns Package version of the library\n */\n get version(): string {\n return version;\n }\n\n /**\n * Returns the elevation for the point where the camera is looking.\n * This value corresponds to:\n * \"meters above sea level\" * \"exaggeration\"\n * @returns The elevation.\n */\n getCameraTargetElevation(): number {\n return this.transform.elevation;\n }\n}\n","import type Point from '@mapbox/point-geometry';\n\nimport {DragMoveHandler, DragRotateResult, DragPitchResult, DragHandler} from './drag_handler';\nimport {OneFingerTouchMoveStateManager} from './drag_move_state_manager';\n\nexport interface OneFingerTouchRotateHandler extends DragMoveHandler {}\nexport interface OneFingerTouchPitchHandler extends DragMoveHandler {}\n\nconst assignEvents = (handler: DragHandler) => {\n handler.touchstart = handler.dragStart;\n handler.touchmoveWindow = handler.dragMove;\n handler.touchend = handler.dragEnd;\n};\n\nexport const generateOneFingerTouchRotationHandler = ({enable, clickTolerance, bearingDegreesPerPixelMoved = 0.8}: {\n clickTolerance: number;\n bearingDegreesPerPixelMoved?: number;\n enable?: boolean;\n}): OneFingerTouchRotateHandler => {\n const touchMoveStateManager = new OneFingerTouchMoveStateManager();\n return new DragHandler({\n clickTolerance,\n move: (lastPoint: Point, point: Point) =>\n ({bearingDelta: (point.x - lastPoint.x) * bearingDegreesPerPixelMoved}),\n moveStateManager: touchMoveStateManager,\n enable,\n assignEvents,\n });\n};\n\nexport const generateOneFingerTouchPitchHandler = ({enable, clickTolerance, pitchDegreesPerPixelMoved = -0.5}: {\n clickTolerance: number;\n pitchDegreesPerPixelMoved?: number;\n enable?: boolean;\n}): OneFingerTouchPitchHandler => {\n const touchMoveStateManager = new OneFingerTouchMoveStateManager();\n return new DragHandler({\n clickTolerance,\n move: (lastPoint: Point, point: Point) =>\n ({pitchDelta: (point.y - lastPoint.y) * pitchDegreesPerPixelMoved}),\n moveStateManager: touchMoveStateManager,\n enable,\n assignEvents,\n });\n};\n","import Point from '@mapbox/point-geometry';\n\nimport {DOM} from '../../util/dom';\nimport {extend} from '../../util/util';\nimport {generateMousePitchHandler, generateMouseRotationHandler, MousePitchHandler, MouseRotateHandler} from '../handler/mouse';\nimport {generateOneFingerTouchPitchHandler, generateOneFingerTouchRotationHandler, OneFingerTouchPitchHandler, OneFingerTouchRotateHandler} from '../handler/one_finger_touch_drag';\n\nimport type {Map} from '../map';\nimport type {IControl} from './control';\n\n/**\n * The {@link NavigationControl} options object\n */\ntype NavigationControlOptions = {\n /**\n * If `true` the compass button is included.\n */\n showCompass?: boolean;\n /**\n * If `true` the zoom-in and zoom-out buttons are included.\n */\n showZoom?: boolean;\n /**\n * If `true` the pitch is visualized by rotating X-axis of compass.\n */\n visualizePitch?: boolean;\n};\n\nconst defaultOptions: NavigationControlOptions = {\n showCompass: true,\n showZoom: true,\n visualizePitch: false\n};\n\n/**\n * A `NavigationControl` control contains zoom buttons and a compass.\n *\n * @group Markers and Controls\n *\n * @example\n * ```ts\n * let nav = new NavigationControl();\n * map.addControl(nav, 'top-left');\n * ```\n * @see [Display map navigation controls](https://maplibre.org/maplibre-gl-js/docs/examples/navigation/)\n */\nexport class NavigationControl implements IControl {\n _map: Map;\n options: NavigationControlOptions;\n _container: HTMLElement;\n _zoomInButton: HTMLButtonElement;\n _zoomOutButton: HTMLButtonElement;\n _compass: HTMLButtonElement;\n _compassIcon: HTMLElement;\n _handler: MouseRotateWrapper;\n\n /**\n * @param options - the control's options\n */\n constructor(options?: NavigationControlOptions) {\n this.options = extend({}, defaultOptions, options);\n\n this._container = DOM.create('div', 'maplibregl-ctrl maplibregl-ctrl-group');\n this._container.addEventListener('contextmenu', (e) => e.preventDefault());\n\n if (this.options.showZoom) {\n this._zoomInButton = this._createButton('maplibregl-ctrl-zoom-in', (e) => this._map.zoomIn({}, {originalEvent: e}));\n DOM.create('span', 'maplibregl-ctrl-icon', this._zoomInButton).setAttribute('aria-hidden', 'true');\n this._zoomOutButton = this._createButton('maplibregl-ctrl-zoom-out', (e) => this._map.zoomOut({}, {originalEvent: e}));\n DOM.create('span', 'maplibregl-ctrl-icon', this._zoomOutButton).setAttribute('aria-hidden', 'true');\n }\n if (this.options.showCompass) {\n this._compass = this._createButton('maplibregl-ctrl-compass', (e) => {\n if (this.options.visualizePitch) {\n this._map.resetNorthPitch({}, {originalEvent: e});\n } else {\n this._map.resetNorth({}, {originalEvent: e});\n }\n });\n this._compassIcon = DOM.create('span', 'maplibregl-ctrl-icon', this._compass);\n this._compassIcon.setAttribute('aria-hidden', 'true');\n }\n }\n\n _updateZoomButtons = () => {\n const zoom = this._map.getZoom();\n const isMax = zoom === this._map.getMaxZoom();\n const isMin = zoom === this._map.getMinZoom();\n this._zoomInButton.disabled = isMax;\n this._zoomOutButton.disabled = isMin;\n this._zoomInButton.setAttribute('aria-disabled', isMax.toString());\n this._zoomOutButton.setAttribute('aria-disabled', isMin.toString());\n };\n\n _rotateCompassArrow = () => {\n const rotate = this.options.visualizePitch ?\n `scale(${1 / Math.pow(Math.cos(this._map.transform.pitch * (Math.PI / 180)), 0.5)}) rotateX(${this._map.transform.pitch}deg) rotateZ(${this._map.transform.angle * (180 / Math.PI)}deg)` :\n `rotate(${this._map.transform.angle * (180 / Math.PI)}deg)`;\n\n this._compassIcon.style.transform = rotate;\n };\n\n /** {@inheritDoc IControl.onAdd} */\n onAdd(map: Map) {\n this._map = map;\n if (this.options.showZoom) {\n this._setButtonTitle(this._zoomInButton, 'ZoomIn');\n this._setButtonTitle(this._zoomOutButton, 'ZoomOut');\n this._map.on('zoom', this._updateZoomButtons);\n this._updateZoomButtons();\n }\n if (this.options.showCompass) {\n this._setButtonTitle(this._compass, 'ResetBearing');\n if (this.options.visualizePitch) {\n this._map.on('pitch', this._rotateCompassArrow);\n }\n this._map.on('rotate', this._rotateCompassArrow);\n this._rotateCompassArrow();\n this._handler = new MouseRotateWrapper(this._map, this._compass, this.options.visualizePitch);\n }\n return this._container;\n }\n\n /** {@inheritDoc IControl.onRemove} */\n onRemove() {\n DOM.remove(this._container);\n if (this.options.showZoom) {\n this._map.off('zoom', this._updateZoomButtons);\n }\n if (this.options.showCompass) {\n if (this.options.visualizePitch) {\n this._map.off('pitch', this._rotateCompassArrow);\n }\n this._map.off('rotate', this._rotateCompassArrow);\n this._handler.off();\n delete this._handler;\n }\n\n delete this._map;\n }\n\n _createButton(className: string, fn: (e?: any) => unknown) {\n const a = DOM.create('button', className, this._container) as HTMLButtonElement;\n a.type = 'button';\n a.addEventListener('click', fn);\n return a;\n }\n\n _setButtonTitle = (button: HTMLButtonElement, title: 'ZoomIn' | 'ZoomOut' | 'ResetBearing') => {\n const str = this._map._getUIString(`NavigationControl.${title}`);\n button.title = str;\n button.setAttribute('aria-label', str);\n };\n}\n\nclass MouseRotateWrapper {\n\n map: Map;\n _clickTolerance: number;\n element: HTMLElement;\n // Rotation and pitch handlers are separated due to different _clickTolerance values\n mouseRotate: MouseRotateHandler;\n touchRotate: OneFingerTouchRotateHandler;\n mousePitch: MousePitchHandler;\n touchPitch: OneFingerTouchPitchHandler;\n _startPos: Point;\n _lastPos: Point;\n\n constructor(map: Map, element: HTMLElement, pitch: boolean = false) {\n this._clickTolerance = 10;\n const mapRotateTolerance = map.dragRotate._mouseRotate.getClickTolerance();\n const mapPitchTolerance = map.dragRotate._mousePitch.getClickTolerance();\n this.element = element;\n this.mouseRotate = generateMouseRotationHandler({clickTolerance: mapRotateTolerance, enable: true});\n this.touchRotate = generateOneFingerTouchRotationHandler({clickTolerance: mapRotateTolerance, enable: true});\n this.map = map;\n if (pitch) {\n this.mousePitch = generateMousePitchHandler({clickTolerance: mapPitchTolerance, enable: true});\n this.touchPitch = generateOneFingerTouchPitchHandler({clickTolerance: mapPitchTolerance, enable: true});\n }\n\n DOM.addEventListener(element, 'mousedown', this.mousedown);\n DOM.addEventListener(element, 'touchstart', this.touchstart, {passive: false});\n DOM.addEventListener(element, 'touchcancel', this.reset);\n }\n\n startMouse(e: MouseEvent, point: Point) {\n this.mouseRotate.dragStart(e, point);\n if (this.mousePitch) this.mousePitch.dragStart(e, point);\n DOM.disableDrag();\n }\n\n startTouch(e: TouchEvent, point: Point) {\n this.touchRotate.dragStart(e, point);\n if (this.touchPitch) this.touchPitch.dragStart(e, point);\n DOM.disableDrag();\n }\n\n moveMouse(e: MouseEvent, point: Point) {\n const map = this.map;\n const {bearingDelta} = this.mouseRotate.dragMove(e, point) || {};\n if (bearingDelta) map.setBearing(map.getBearing() + bearingDelta);\n if (this.mousePitch) {\n const {pitchDelta} = this.mousePitch.dragMove(e, point) || {};\n if (pitchDelta) map.setPitch(map.getPitch() + pitchDelta);\n }\n }\n\n moveTouch(e: TouchEvent, point: Point) {\n const map = this.map;\n const {bearingDelta} = this.touchRotate.dragMove(e, point) || {};\n if (bearingDelta) map.setBearing(map.getBearing() + bearingDelta);\n if (this.touchPitch) {\n const {pitchDelta} = this.touchPitch.dragMove(e, point) || {};\n if (pitchDelta) map.setPitch(map.getPitch() + pitchDelta);\n }\n }\n\n off() {\n const element = this.element;\n DOM.removeEventListener(element, 'mousedown', this.mousedown);\n DOM.removeEventListener(element, 'touchstart', this.touchstart, {passive: false});\n DOM.removeEventListener(window, 'touchmove', this.touchmove, {passive: false});\n DOM.removeEventListener(window, 'touchend', this.touchend);\n DOM.removeEventListener(element, 'touchcancel', this.reset);\n this.offTemp();\n }\n\n offTemp() {\n DOM.enableDrag();\n DOM.removeEventListener(window, 'mousemove', this.mousemove);\n DOM.removeEventListener(window, 'mouseup', this.mouseup);\n DOM.removeEventListener(window, 'touchmove', this.touchmove, {passive: false});\n DOM.removeEventListener(window, 'touchend', this.touchend);\n }\n\n mousedown = (e: MouseEvent) => {\n this.startMouse(extend({}, e, {ctrlKey: true, preventDefault: () => e.preventDefault()}), DOM.mousePos(this.element, e));\n DOM.addEventListener(window, 'mousemove', this.mousemove);\n DOM.addEventListener(window, 'mouseup', this.mouseup);\n };\n\n mousemove = (e: MouseEvent) => {\n this.moveMouse(e, DOM.mousePos(this.element, e));\n };\n\n mouseup = (e: MouseEvent) => {\n this.mouseRotate.dragEnd(e);\n if (this.mousePitch) this.mousePitch.dragEnd(e);\n this.offTemp();\n };\n\n touchstart = (e: TouchEvent) => {\n if (e.targetTouches.length !== 1) {\n this.reset();\n } else {\n this._startPos = this._lastPos = DOM.touchPos(this.element, e.targetTouches)[0];\n this.startTouch(e, this._startPos);\n DOM.addEventListener(window, 'touchmove', this.touchmove, {passive: false});\n DOM.addEventListener(window, 'touchend', this.touchend);\n }\n };\n\n touchmove = (e: TouchEvent) => {\n if (e.targetTouches.length !== 1) {\n this.reset();\n } else {\n this._lastPos = DOM.touchPos(this.element, e.targetTouches)[0];\n this.moveTouch(e, this._lastPos);\n }\n };\n\n touchend = (e: TouchEvent) => {\n if (e.targetTouches.length === 0 &&\n this._startPos &&\n this._lastPos &&\n this._startPos.dist(this._lastPos) < this._clickTolerance) {\n this.element.click();\n }\n delete this._startPos;\n delete this._lastPos;\n this.offTemp();\n };\n\n reset = () => {\n this.mouseRotate.reset();\n if (this.mousePitch) this.mousePitch.reset();\n this.touchRotate.reset();\n if (this.touchPitch) this.touchPitch.reset();\n delete this._startPos;\n delete this._lastPos;\n this.offTemp();\n };\n}\n","let supportsGeolocation;\n\nexport async function checkGeolocationSupport(forceRecalculation = false): Promise {\n if (supportsGeolocation !== undefined && !forceRecalculation) {\n return supportsGeolocation;\n }\n if (window.navigator.permissions === undefined) {\n supportsGeolocation = !!window.navigator.geolocation;\n return supportsGeolocation;\n }\n // navigator.permissions has incomplete browser support\n // https://caniuse.com/#feat=permissions-api\n // Test for the case where a browser disables Geolocation because of an\n // insecure origin\n try {\n const permissions = await window.navigator.permissions.query({name: 'geolocation'});\n supportsGeolocation = permissions.state !== 'denied'; // eslint-disable-line require-atomic-updates\n } catch {\n // Fix for iOS16 which rejects query but still supports geolocation\n supportsGeolocation = !!window.navigator.geolocation; // eslint-disable-line require-atomic-updates\n }\n return supportsGeolocation;\n}\n","import {LngLat} from '../geo/lng_lat';\n\nimport type Point from '@mapbox/point-geometry';\nimport type {Transform} from '../geo/transform';\n\n/**\n * Given a LngLat, prior projected position, and a transform, return a new LngLat shifted\n * n × 360° east or west for some n ≥ 0 such that:\n *\n * * the projected location of the result is on screen, if possible, and secondarily:\n * * the difference between the projected location of the result and the prior position\n * is minimized.\n *\n * The object is to preserve perceived object constancy for Popups and Markers as much as\n * possible; they should avoid shifting large distances across the screen, even when the\n * map center changes by ±360° due to automatic wrapping, and when about to go off screen,\n * should wrap just enough to avoid doing so.\n */\nexport function smartWrap(lngLat: LngLat, priorPos: Point, transform: Transform): LngLat {\n const originalLngLat = new LngLat(lngLat.lng, lngLat.lat);\n lngLat = new LngLat(lngLat.lng, lngLat.lat);\n\n // First, try shifting one world in either direction, and see if either is closer to the\n // prior position. This preserves object constancy when the map center is auto-wrapped\n // during animations.\n if (priorPos) {\n const left = new LngLat(lngLat.lng - 360, lngLat.lat);\n const right = new LngLat(lngLat.lng + 360, lngLat.lat);\n const delta = transform.locationPoint(lngLat).distSqr(priorPos);\n if (transform.locationPoint(left).distSqr(priorPos) < delta) {\n lngLat = left;\n } else if (transform.locationPoint(right).distSqr(priorPos) < delta) {\n lngLat = right;\n }\n }\n\n // Second, wrap toward the center until the new position is on screen, or we can't get\n // any closer.\n while (Math.abs(lngLat.lng - transform.center.lng) > 180) {\n const pos = transform.locationPoint(lngLat);\n if (pos.x >= 0 && pos.y >= 0 && pos.x <= transform.width && pos.y <= transform.height) {\n break;\n }\n if (lngLat.lng > transform.center.lng) {\n lngLat.lng -= 360;\n } else {\n lngLat.lng += 360;\n }\n }\n\n // Apply the change only if new coord is below horizon\n if (lngLat.lng !== originalLngLat.lng &&\n transform.locationPoint(lngLat).y > (transform.height / 2 - transform.getHorizon())) {\n return lngLat;\n }\n\n return originalLngLat;\n}\n","/**\n * Where to position the anchor.\n * Used by a popup and a marker.\n */\nexport type PositionAnchor = 'center' | 'top' | 'bottom' | 'left' | 'right' | 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right';\n\nexport const anchorTranslate: {\n [_ in PositionAnchor]: string;\n} = {\n 'center': 'translate(-50%,-50%)',\n 'top': 'translate(-50%,0)',\n 'top-left': 'translate(0,0)',\n 'top-right': 'translate(-100%,0)',\n 'bottom': 'translate(-50%,-100%)',\n 'bottom-left': 'translate(0,-100%)',\n 'bottom-right': 'translate(-100%,-100%)',\n 'left': 'translate(0,-50%)',\n 'right': 'translate(-100%,-50%)'\n};\n\nexport function applyAnchorClass(element: HTMLElement, anchor: PositionAnchor, prefix: string) {\n const classList = element.classList;\n for (const key in anchorTranslate) {\n classList.remove(`maplibregl-${prefix}-anchor-${key}`);\n }\n classList.add(`maplibregl-${prefix}-anchor-${anchor}`);\n}\n","import {DOM} from '../util/dom';\nimport {browser} from '../util/browser';\nimport {LngLat} from '../geo/lng_lat';\nimport Point from '@mapbox/point-geometry';\nimport {smartWrap} from '../util/smart_wrap';\nimport {anchorTranslate, applyAnchorClass} from './anchor';\nimport type {PositionAnchor} from './anchor';\nimport {Event, Evented} from '../util/evented';\nimport type {Map} from './map';\nimport {Popup, Offset} from './popup';\nimport type {LngLatLike} from '../geo/lng_lat';\nimport type {MapMouseEvent, MapTouchEvent} from './events';\nimport type {PointLike} from './camera';\n\n/**\n * Alignment options of rotation and pitch\n */\ntype Alignment = 'map' | 'viewport' | 'auto';\n\n/**\n * The {@link Marker} options object\n */\ntype MarkerOptions = {\n /**\n * DOM element to use as a marker. The default is a light blue, droplet-shaped SVG marker.\n */\n element?: HTMLElement;\n /**\n * Space-separated CSS class names to add to marker element.\n */\n className?: string;\n /**\n * The offset in pixels as a {@link PointLike} object to apply relative to the element's center. Negatives indicate left and up.\n */\n offset?: PointLike;\n /**\n * A string indicating the part of the Marker that should be positioned closest to the coordinate set via {@link Marker#setLngLat}.\n * Options are `'center'`, `'top'`, `'bottom'`, `'left'`, `'right'`, `'top-left'`, `'top-right'`, `'bottom-left'`, and `'bottom-right'`.\n * @defaultValue 'center'\n * */\n anchor?: PositionAnchor;\n /**\n * The color to use for the default marker if options.element is not provided. The default is light blue.\n * @defaultValue '#3FB1CE'\n */\n color?: string;\n /**\n * The scale to use for the default marker if options.element is not provided. The default scale corresponds to a height of `41px` and a width of `27px`.\n * @defaultValue 1\n */\n scale?: number;\n /**\n * A boolean indicating whether or not a marker is able to be dragged to a new position on the map.\n * @defaultValue false\n */\n draggable?: boolean;\n /**\n * The max number of pixels a user can shift the mouse pointer during a click on the marker for it to be considered a valid click (as opposed to a marker drag). The default is to inherit map's clickTolerance.\n * @defaultValue 0\n */\n clickTolerance?: number;\n /**\n * The rotation angle of the marker in degrees, relative to its respective `rotationAlignment` setting. A positive value will rotate the marker clockwise.\n * @defaultValue 0\n */\n rotation?: number;\n /**\n * `map` aligns the `Marker`'s rotation relative to the map, maintaining a bearing as the map rotates. `viewport` aligns the `Marker`'s rotation relative to the viewport, agnostic to map rotations. `auto` is equivalent to `viewport`.\n * @defaultValue 'auto'\n */\n rotationAlignment?: Alignment;\n /**\n * `map` aligns the `Marker` to the plane of the map. `viewport` aligns the `Marker` to the plane of the viewport. `auto` automatically matches the value of `rotationAlignment`.\n * @defaultValue 'auto'\n */\n pitchAlignment?: Alignment;\n /**\n * Marker's opacity when it's in clear view (not behind 3d terrain)\n * @defaultValue 1\n */\n opacity?: string;\n /**\n * Marker's opacity when it's behind 3d terrain\n * @defaultValue 0.2\n */\n opacityWhenCovered?: string;\n /**\n * If `true`, rounding is disabled for placement of the marker, allowing for\n * subpixel positioning and smoother movement when the marker is translated.\n * @defaultValue false\n */\n subpixelPositioning?: boolean;\n};\n\n/**\n * Creates a marker component\n *\n * @group Markers and Controls\n *\n * @example\n * ```ts\n * let marker = new Marker()\n * .setLngLat([30.5, 50.5])\n * .addTo(map);\n * ```\n *\n * @example\n * Set options\n * ```ts\n * let marker = new Marker({\n * color: \"#FFFFFF\",\n * draggable: true\n * }).setLngLat([30.5, 50.5])\n * .addTo(map);\n * ```\n * @see [Add custom icons with Markers](https://maplibre.org/maplibre-gl-js/docs/examples/custom-marker-icons/)\n * @see [Create a draggable Marker](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-marker/)\n *\n * ## Events\n *\n * **Event** `dragstart` of type {@link Event} will be fired when dragging starts.\n *\n * **Event** `drag` of type {@link Event} will be fired while dragging.\n *\n * **Event** `dragend` of type {@link Event} will be fired when the marker is finished being dragged.\n */\nexport class Marker extends Evented {\n _map: Map;\n _anchor: PositionAnchor;\n _offset: Point;\n _element: HTMLElement;\n _popup: Popup;\n _lngLat: LngLat;\n _pos: Point;\n _flatPos: Point;\n _color: string;\n _scale: number;\n _defaultMarker: boolean;\n _draggable: boolean;\n _clickTolerance: number;\n _isDragging: boolean;\n _state: 'inactive' | 'pending' | 'active'; // used for handling drag events\n _positionDelta: Point;\n _pointerdownPos: Point;\n _rotation: number;\n _pitchAlignment: Alignment;\n _rotationAlignment: Alignment;\n _originalTabIndex: string; // original tabindex of _element\n _opacity: string;\n _opacityWhenCovered: string;\n _opacityTimeout: ReturnType;\n _subpixelPositioning: boolean;\n\n /**\n * @param options - the options\n */\n constructor(options?: MarkerOptions) {\n super();\n\n this._anchor = options && options.anchor || 'center';\n this._color = options && options.color || '#3FB1CE';\n this._scale = options && options.scale || 1;\n this._draggable = options && options.draggable || false;\n this._clickTolerance = options && options.clickTolerance || 0;\n this._subpixelPositioning = options && options.subpixelPositioning || false;\n this._isDragging = false;\n this._state = 'inactive';\n this._rotation = options && options.rotation || 0;\n this._rotationAlignment = options && options.rotationAlignment || 'auto';\n this._pitchAlignment = options && options.pitchAlignment && options.pitchAlignment !== 'auto' ? options.pitchAlignment : this._rotationAlignment;\n this.setOpacity(); // set default opacity\n this.setOpacity(options?.opacity, options?.opacityWhenCovered);\n\n if (!options || !options.element) {\n this._defaultMarker = true;\n this._element = DOM.create('div');\n\n // create default map marker SVG\n const svg = DOM.createNS('http://www.w3.org/2000/svg', 'svg');\n const defaultHeight = 41;\n const defaultWidth = 27;\n svg.setAttributeNS(null, 'display', 'block');\n svg.setAttributeNS(null, 'height', `${defaultHeight}px`);\n svg.setAttributeNS(null, 'width', `${defaultWidth}px`);\n svg.setAttributeNS(null, 'viewBox', `0 0 ${defaultWidth} ${defaultHeight}`);\n\n const markerLarge = DOM.createNS('http://www.w3.org/2000/svg', 'g');\n markerLarge.setAttributeNS(null, 'stroke', 'none');\n markerLarge.setAttributeNS(null, 'stroke-width', '1');\n markerLarge.setAttributeNS(null, 'fill', 'none');\n markerLarge.setAttributeNS(null, 'fill-rule', 'evenodd');\n\n const page1 = DOM.createNS('http://www.w3.org/2000/svg', 'g');\n page1.setAttributeNS(null, 'fill-rule', 'nonzero');\n\n const shadow = DOM.createNS('http://www.w3.org/2000/svg', 'g');\n shadow.setAttributeNS(null, 'transform', 'translate(3.0, 29.0)');\n shadow.setAttributeNS(null, 'fill', '#000000');\n\n const ellipses = [\n {'rx': '10.5', 'ry': '5.25002273'},\n {'rx': '10.5', 'ry': '5.25002273'},\n {'rx': '9.5', 'ry': '4.77275007'},\n {'rx': '8.5', 'ry': '4.29549936'},\n {'rx': '7.5', 'ry': '3.81822308'},\n {'rx': '6.5', 'ry': '3.34094679'},\n {'rx': '5.5', 'ry': '2.86367051'},\n {'rx': '4.5', 'ry': '2.38636864'}\n ];\n\n for (const data of ellipses) {\n const ellipse = DOM.createNS('http://www.w3.org/2000/svg', 'ellipse');\n ellipse.setAttributeNS(null, 'opacity', '0.04');\n ellipse.setAttributeNS(null, 'cx', '10.5');\n ellipse.setAttributeNS(null, 'cy', '5.80029008');\n ellipse.setAttributeNS(null, 'rx', data['rx']);\n ellipse.setAttributeNS(null, 'ry', data['ry']);\n shadow.appendChild(ellipse);\n }\n\n const background = DOM.createNS('http://www.w3.org/2000/svg', 'g');\n background.setAttributeNS(null, 'fill', this._color);\n\n const bgPath = DOM.createNS('http://www.w3.org/2000/svg', 'path');\n bgPath.setAttributeNS(null, 'd', 'M27,13.5 C27,19.074644 20.250001,27.000002 14.75,34.500002 C14.016665,35.500004 12.983335,35.500004 12.25,34.500002 C6.7499993,27.000002 0,19.222562 0,13.5 C0,6.0441559 6.0441559,0 13.5,0 C20.955844,0 27,6.0441559 27,13.5 Z');\n\n background.appendChild(bgPath);\n\n const border = DOM.createNS('http://www.w3.org/2000/svg', 'g');\n border.setAttributeNS(null, 'opacity', '0.25');\n border.setAttributeNS(null, 'fill', '#000000');\n\n const borderPath = DOM.createNS('http://www.w3.org/2000/svg', 'path');\n borderPath.setAttributeNS(null, 'd', 'M13.5,0 C6.0441559,0 0,6.0441559 0,13.5 C0,19.222562 6.7499993,27 12.25,34.5 C13,35.522727 14.016664,35.500004 14.75,34.5 C20.250001,27 27,19.074644 27,13.5 C27,6.0441559 20.955844,0 13.5,0 Z M13.5,1 C20.415404,1 26,6.584596 26,13.5 C26,15.898657 24.495584,19.181431 22.220703,22.738281 C19.945823,26.295132 16.705119,30.142167 13.943359,33.908203 C13.743445,34.180814 13.612715,34.322738 13.5,34.441406 C13.387285,34.322738 13.256555,34.180814 13.056641,33.908203 C10.284481,30.127985 7.4148684,26.314159 5.015625,22.773438 C2.6163816,19.232715 1,15.953538 1,13.5 C1,6.584596 6.584596,1 13.5,1 Z');\n\n border.appendChild(borderPath);\n\n const maki = DOM.createNS('http://www.w3.org/2000/svg', 'g');\n maki.setAttributeNS(null, 'transform', 'translate(6.0, 7.0)');\n maki.setAttributeNS(null, 'fill', '#FFFFFF');\n\n const circleContainer = DOM.createNS('http://www.w3.org/2000/svg', 'g');\n circleContainer.setAttributeNS(null, 'transform', 'translate(8.0, 8.0)');\n\n const circle1 = DOM.createNS('http://www.w3.org/2000/svg', 'circle');\n circle1.setAttributeNS(null, 'fill', '#000000');\n circle1.setAttributeNS(null, 'opacity', '0.25');\n circle1.setAttributeNS(null, 'cx', '5.5');\n circle1.setAttributeNS(null, 'cy', '5.5');\n circle1.setAttributeNS(null, 'r', '5.4999962');\n\n const circle2 = DOM.createNS('http://www.w3.org/2000/svg', 'circle');\n circle2.setAttributeNS(null, 'fill', '#FFFFFF');\n circle2.setAttributeNS(null, 'cx', '5.5');\n circle2.setAttributeNS(null, 'cy', '5.5');\n circle2.setAttributeNS(null, 'r', '5.4999962');\n\n circleContainer.appendChild(circle1);\n circleContainer.appendChild(circle2);\n\n page1.appendChild(shadow);\n page1.appendChild(background);\n page1.appendChild(border);\n page1.appendChild(maki);\n page1.appendChild(circleContainer);\n\n svg.appendChild(page1);\n\n svg.setAttributeNS(null, 'height', `${defaultHeight * this._scale}px`);\n svg.setAttributeNS(null, 'width', `${defaultWidth * this._scale}px`);\n\n this._element.appendChild(svg);\n\n // if no element and no offset option given apply an offset for the default marker\n // the -14 as the y value of the default marker offset was determined as follows\n //\n // the marker tip is at the center of the shadow ellipse from the default svg\n // the y value of the center of the shadow ellipse relative to the svg top left is \"shadow transform translate-y (29.0) + ellipse cy (5.80029008)\"\n // offset to the svg center \"height (41 / 2)\" gives (29.0 + 5.80029008) - (41 / 2) and rounded for an integer pixel offset gives 14\n // negative is used to move the marker up from the center so the tip is at the Marker lngLat\n this._offset = Point.convert(options && options.offset || [0, -14]);\n } else {\n this._element = options.element;\n this._offset = Point.convert(options && options.offset || [0, 0]);\n }\n\n this._element.classList.add('maplibregl-marker');\n this._element.addEventListener('dragstart', (e: DragEvent) => {\n e.preventDefault();\n });\n this._element.addEventListener('mousedown', (e: MouseEvent) => {\n // prevent focusing on click\n e.preventDefault();\n });\n applyAnchorClass(this._element, this._anchor, 'marker');\n\n if (options && options.className) {\n for (const name of options.className.split(' ')) {\n this._element.classList.add(name);\n }\n }\n\n this._popup = null;\n }\n\n /**\n * Attaches the `Marker` to a `Map` object.\n * @param map - The MapLibre GL JS map to add the marker to.\n * @example\n * ```ts\n * let marker = new Marker()\n * .setLngLat([30.5, 50.5])\n * .addTo(map); // add the marker to the map\n * ```\n */\n addTo(map: Map): this {\n this.remove();\n this._map = map;\n this._element.setAttribute('aria-label', map._getUIString('Marker.Title'));\n\n map.getCanvasContainer().appendChild(this._element);\n map.on('move', this._update);\n map.on('moveend', this._update);\n map.on('terrain', this._update);\n\n this.setDraggable(this._draggable);\n this._update();\n\n // If we attached the `click` listener to the marker element, the popup\n // would close once the event propagated to `map` due to the\n // `Popup#_onClickClose` listener.\n this._map.on('click', this._onMapClick);\n\n return this;\n }\n\n /**\n * Removes the marker from a map\n * @example\n * ```ts\n * let marker = new Marker().addTo(map);\n * marker.remove();\n * ```\n */\n remove(): this {\n if (this._opacityTimeout) {\n clearTimeout(this._opacityTimeout);\n delete this._opacityTimeout;\n }\n if (this._map) {\n this._map.off('click', this._onMapClick);\n this._map.off('move', this._update);\n this._map.off('moveend', this._update);\n this._map.off('terrain', this._update);\n this._map.off('mousedown', this._addDragHandler);\n this._map.off('touchstart', this._addDragHandler);\n this._map.off('mouseup', this._onUp);\n this._map.off('touchend', this._onUp);\n this._map.off('mousemove', this._onMove);\n this._map.off('touchmove', this._onMove);\n delete this._map;\n }\n DOM.remove(this._element);\n if (this._popup) this._popup.remove();\n return this;\n }\n\n /**\n * Get the marker's geographical location.\n *\n * The longitude of the result may differ by a multiple of 360 degrees from the longitude previously\n * set by `setLngLat` because `Marker` wraps the anchor longitude across copies of the world to keep\n * the marker on screen.\n *\n * @returns A {@link LngLat} describing the marker's location.\n * @example\n * ```ts\n * // Store the marker's longitude and latitude coordinates in a variable\n * let lngLat = marker.getLngLat();\n * // Print the marker's longitude and latitude values in the console\n * console.log('Longitude: ' + lngLat.lng + ', Latitude: ' + lngLat.lat )\n * ```\n * @see [Create a draggable Marker](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-marker/)\n */\n getLngLat(): LngLat {\n return this._lngLat;\n }\n\n /**\n * Set the marker's geographical position and move it.\n * @param lnglat - A {@link LngLat} describing where the marker should be located.\n * @example\n * Create a new marker, set the longitude and latitude, and add it to the map\n * ```ts\n * new Marker()\n * .setLngLat([-65.017, -16.457])\n * .addTo(map);\n * ```\n * @see [Add custom icons with Markers](https://maplibre.org/maplibre-gl-js/docs/examples/custom-marker-icons/)\n * @see [Create a draggable Marker](https://maplibre.org/maplibre-gl-js/docs/examples/drag-a-marker/)\n */\n setLngLat(lnglat: LngLatLike): this {\n this._lngLat = LngLat.convert(lnglat);\n this._pos = null;\n if (this._popup) this._popup.setLngLat(this._lngLat);\n this._update();\n return this;\n }\n\n /**\n * Returns the `Marker`'s HTML element.\n * @returns element\n */\n getElement(): HTMLElement {\n return this._element;\n }\n\n /**\n * Binds a {@link Popup} to the {@link Marker}.\n * @param popup - An instance of the {@link Popup} class. If undefined or null, any popup\n * set on this {@link Marker} instance is unset.\n * @example\n * ```ts\n * let marker = new Marker()\n * .setLngLat([0, 0])\n * .setPopup(new Popup().setHTML(\"

Hello World!

\")) // add popup\n * .addTo(map);\n * ```\n * @see [Attach a popup to a marker instance](https://maplibre.org/maplibre-gl-js/docs/examples/set-popup/)\n */\n setPopup(popup?: Popup | null): this {\n if (this._popup) {\n this._popup.remove();\n this._popup = null;\n this._element.removeEventListener('keypress', this._onKeyPress);\n\n if (!this._originalTabIndex) {\n this._element.removeAttribute('tabindex');\n }\n }\n\n if (popup) {\n if (!('offset' in popup.options)) {\n const markerHeight = 41 - (5.8 / 2);\n const markerRadius = 13.5;\n const linearOffset = Math.abs(markerRadius) / Math.SQRT2;\n popup.options.offset = this._defaultMarker ? {\n 'top': [0, 0],\n 'top-left': [0, 0],\n 'top-right': [0, 0],\n 'bottom': [0, -markerHeight],\n 'bottom-left': [linearOffset, (markerHeight - markerRadius + linearOffset) * -1],\n 'bottom-right': [-linearOffset, (markerHeight - markerRadius + linearOffset) * -1],\n 'left': [markerRadius, (markerHeight - markerRadius) * -1],\n 'right': [-markerRadius, (markerHeight - markerRadius) * -1]\n } as Offset : this._offset;\n }\n this._popup = popup;\n\n this._originalTabIndex = this._element.getAttribute('tabindex');\n if (!this._originalTabIndex) {\n this._element.setAttribute('tabindex', '0');\n }\n this._element.addEventListener('keypress', this._onKeyPress);\n }\n\n return this;\n }\n\n /**\n * Set the option to allow subpixel positioning of the marker by passing a boolean\n *\n * @param value - when set to `true`, subpixel positioning is enabled for the marker.\n *\n * @example\n * ```ts\n * let marker = new Marker()\n * marker.setSubpixelPositioning(true);\n * ```\n */\n setSubpixelPositioning(value: boolean) {\n this._subpixelPositioning = value;\n return this;\n }\n\n _onKeyPress = (e: KeyboardEvent) => {\n const code = e.code;\n const legacyCode = e.charCode || e.keyCode;\n\n if (\n (code === 'Space') || (code === 'Enter') ||\n (legacyCode === 32) || (legacyCode === 13) // space or enter\n ) {\n this.togglePopup();\n }\n };\n\n _onMapClick = (e: MapMouseEvent) => {\n const targetElement = e.originalEvent.target;\n const element = this._element;\n\n if (this._popup && (targetElement === element || element.contains(targetElement as any))) {\n this.togglePopup();\n }\n };\n\n /**\n * Returns the {@link Popup} instance that is bound to the {@link Marker}.\n * @returns popup\n * @example\n * ```ts\n * let marker = new Marker()\n * .setLngLat([0, 0])\n * .setPopup(new Popup().setHTML(\"

Hello World!

\"))\n * .addTo(map);\n *\n * console.log(marker.getPopup()); // return the popup instance\n * ```\n */\n getPopup(): Popup {\n return this._popup;\n }\n\n /**\n * Opens or closes the {@link Popup} instance that is bound to the {@link Marker}, depending on the current state of the {@link Popup}.\n * @example\n * ```ts\n * let marker = new Marker()\n * .setLngLat([0, 0])\n * .setPopup(new Popup().setHTML(\"

Hello World!

\"))\n * .addTo(map);\n *\n * marker.togglePopup(); // toggle popup open or closed\n * ```\n */\n togglePopup(): this {\n const popup = this._popup;\n\n if (this._element.style.opacity === this._opacityWhenCovered) return this;\n\n if (!popup) return this;\n else if (popup.isOpen()) popup.remove();\n else {\n popup.setLngLat(this._lngLat);\n popup.addTo(this._map);\n }\n return this;\n }\n\n _updateOpacity(force: boolean = false) {\n const terrain = this._map?.terrain;\n if (!terrain) {\n if (this._element.style.opacity !== this._opacity) { this._element.style.opacity = this._opacity; }\n return;\n }\n if (force) {\n this._opacityTimeout = null;\n } else {\n if (this._opacityTimeout) { return; }\n this._opacityTimeout = setTimeout(() => {\n this._opacityTimeout = null;\n }, 100);\n }\n\n const map = this._map;\n\n // Read depth framebuffer, getting position of terrain in line of sight to marker\n const terrainDistance = map.terrain.depthAtPoint(this._pos);\n // Transform marker position to clip space\n const elevation = map.terrain.getElevationForLngLatZoom(this._lngLat, map.transform.tileZoom);\n const markerDistance = map.transform.lngLatToCameraDepth(this._lngLat, elevation);\n\n const forgiveness = .006;\n if (markerDistance - terrainDistance < forgiveness) {\n this._element.style.opacity = this._opacity;\n return;\n }\n // If the base is obscured, use the offset to check if the marker's center is obscured.\n const metersToCenter = -this._offset.y / map.transform._pixelPerMeter;\n const elevationToCenter = Math.sin(map.getPitch() * Math.PI / 180) * metersToCenter;\n const terrainDistanceCenter = map.terrain.depthAtPoint(new Point(this._pos.x, this._pos.y - this._offset.y));\n const markerDistanceCenter = map.transform.lngLatToCameraDepth(this._lngLat, elevation + elevationToCenter);\n // Display at full opacity if center is visible.\n const centerIsInvisible = markerDistanceCenter - terrainDistanceCenter > forgiveness;\n\n if (this._popup?.isOpen() && centerIsInvisible) this._popup.remove();\n this._element.style.opacity = centerIsInvisible ? this._opacityWhenCovered : this._opacity;\n }\n\n _update = (e?: { type: 'move' | 'moveend' | 'terrain' | 'render' }) => {\n if (!this._map) return;\n\n const isFullyLoaded = this._map.loaded() && !this._map.isMoving();\n if (e?.type === 'terrain' || (e?.type === 'render' && !isFullyLoaded)) {\n this._map.once('render', this._update);\n }\n\n if (this._map.transform.renderWorldCopies) {\n this._lngLat = smartWrap(this._lngLat, this._flatPos, this._map.transform);\n } else {\n this._lngLat = this._lngLat?.wrap();\n }\n\n this._flatPos = this._pos = this._map.project(this._lngLat)._add(this._offset);\n if (this._map.terrain) {\n // flat position is saved because smartWrap needs non-elevated points\n this._flatPos = this._map.transform.locationPoint(this._lngLat)._add(this._offset);\n }\n\n let rotation = '';\n if (this._rotationAlignment === 'viewport' || this._rotationAlignment === 'auto') {\n rotation = `rotateZ(${this._rotation}deg)`;\n } else if (this._rotationAlignment === 'map') {\n rotation = `rotateZ(${this._rotation - this._map.getBearing()}deg)`;\n }\n\n let pitch = '';\n if (this._pitchAlignment === 'viewport' || this._pitchAlignment === 'auto') {\n pitch = 'rotateX(0deg)';\n } else if (this._pitchAlignment === 'map') {\n pitch = `rotateX(${this._map.getPitch()}deg)`;\n }\n\n // because rounding the coordinates at every `move` event causes stuttered zooming\n // we only round them when _update is called with `moveend` or when its called with\n // no arguments (when the Marker is initialized or Marker#setLngLat is invoked).\n if (!this._subpixelPositioning && (!e || e.type === 'moveend')) {\n this._pos = this._pos.round();\n }\n\n DOM.setTransform(this._element, `${anchorTranslate[this._anchor]} translate(${this._pos.x}px, ${this._pos.y}px) ${pitch} ${rotation}`);\n\n browser.frameAsync(new AbortController()).then(() => { // Run _updateOpacity only after painter.render and drawDepth\n this._updateOpacity(e && e.type === 'moveend');\n }).catch(() => {});\n };\n\n /**\n * Get the marker's offset.\n * @returns The marker's screen coordinates in pixels.\n */\n getOffset(): Point {\n return this._offset;\n }\n\n /**\n * Sets the offset of the marker\n * @param offset - The offset in pixels as a {@link PointLike} object to apply relative to the element's center. Negatives indicate left and up.\n */\n setOffset(offset: PointLike): this {\n this._offset = Point.convert(offset);\n this._update();\n return this;\n }\n\n /**\n * Adds a CSS class to the marker element.\n *\n * @param className - on-empty string with CSS class name to add to marker element\n *\n * @example\n * ```\n * let marker = new Marker()\n * marker.addClassName('some-class')\n * ```\n */\n addClassName(className: string) {\n this._element.classList.add(className);\n }\n\n /**\n * Removes a CSS class from the marker element.\n *\n * @param className - Non-empty string with CSS class name to remove from marker element\n *\n * @example\n * ```ts\n * let marker = new Marker()\n * marker.removeClassName('some-class')\n * ```\n */\n removeClassName(className: string) {\n this._element.classList.remove(className);\n }\n\n /**\n * Add or remove the given CSS class on the marker element, depending on whether the element currently has that class.\n *\n * @param className - Non-empty string with CSS class name to add/remove\n *\n * @returns if the class was removed return false, if class was added, then return true\n *\n * @example\n * ```ts\n * let marker = new Marker()\n * marker.toggleClassName('toggleClass')\n * ```\n */\n toggleClassName(className: string): boolean {\n return this._element.classList.toggle(className);\n }\n\n _onMove = (e: MapMouseEvent | MapTouchEvent) => {\n if (!this._isDragging) {\n const clickTolerance = this._clickTolerance || this._map._clickTolerance;\n this._isDragging = e.point.dist(this._pointerdownPos) >= clickTolerance;\n }\n if (!this._isDragging) return;\n\n this._pos = e.point.sub(this._positionDelta);\n this._lngLat = this._map.unproject(this._pos);\n this.setLngLat(this._lngLat);\n // suppress click event so that popups don't toggle on drag\n this._element.style.pointerEvents = 'none';\n\n // make sure dragstart only fires on the first move event after mousedown.\n // this can't be on mousedown because that event doesn't necessarily\n // imply that a drag is about to happen.\n if (this._state === 'pending') {\n this._state = 'active';\n this.fire(new Event('dragstart'));\n }\n this.fire(new Event('drag'));\n };\n\n _onUp = () => {\n // revert to normal pointer event handling\n this._element.style.pointerEvents = 'auto';\n this._positionDelta = null;\n this._pointerdownPos = null;\n this._isDragging = false;\n this._map.off('mousemove', this._onMove);\n this._map.off('touchmove', this._onMove);\n\n // only fire dragend if it was preceded by at least one drag event\n if (this._state === 'active') {\n this.fire(new Event('dragend'));\n }\n\n this._state = 'inactive';\n };\n\n _addDragHandler = (e: MapMouseEvent | MapTouchEvent) => {\n if (this._element.contains(e.originalEvent.target as any)) {\n e.preventDefault();\n\n // We need to calculate the pixel distance between the click point\n // and the marker position, with the offset accounted for. Then we\n // can subtract this distance from the mousemove event's position\n // to calculate the new marker position.\n // If we don't do this, the marker 'jumps' to the click position\n // creating a jarring UX effect.\n this._positionDelta = e.point.sub(this._pos).add(this._offset);\n\n this._pointerdownPos = e.point;\n\n this._state = 'pending';\n this._map.on('mousemove', this._onMove);\n this._map.on('touchmove', this._onMove);\n this._map.once('mouseup', this._onUp);\n this._map.once('touchend', this._onUp);\n }\n };\n\n /**\n * Sets the `draggable` property and functionality of the marker\n * @param shouldBeDraggable - Turns drag functionality on/off\n */\n setDraggable(shouldBeDraggable?: boolean): this {\n this._draggable = !!shouldBeDraggable; // convert possible undefined value to false\n\n // handle case where map may not exist yet\n // e.g. when setDraggable is called before addTo\n if (this._map) {\n if (shouldBeDraggable) {\n this._map.on('mousedown', this._addDragHandler);\n this._map.on('touchstart', this._addDragHandler);\n } else {\n this._map.off('mousedown', this._addDragHandler);\n this._map.off('touchstart', this._addDragHandler);\n }\n }\n\n return this;\n }\n\n /**\n * Returns true if the marker can be dragged\n * @returns True if the marker is draggable.\n */\n isDraggable(): boolean {\n return this._draggable;\n }\n\n /**\n * Sets the `rotation` property of the marker.\n * @param rotation - The rotation angle of the marker (clockwise, in degrees), relative to its respective {@link Marker#setRotationAlignment} setting.\n */\n setRotation(rotation?: number): this {\n this._rotation = rotation || 0;\n this._update();\n return this;\n }\n\n /**\n * Returns the current rotation angle of the marker (in degrees).\n * @returns The current rotation angle of the marker.\n */\n getRotation(): number {\n return this._rotation;\n }\n\n /**\n * Sets the `rotationAlignment` property of the marker.\n * @param alignment - Sets the `rotationAlignment` property of the marker. defaults to 'auto'\n */\n setRotationAlignment(alignment?: Alignment): this {\n this._rotationAlignment = alignment || 'auto';\n this._update();\n return this;\n }\n\n /**\n * Returns the current `rotationAlignment` property of the marker.\n * @returns The current rotational alignment of the marker.\n */\n getRotationAlignment(): Alignment {\n return this._rotationAlignment;\n }\n\n /**\n * Sets the `pitchAlignment` property of the marker.\n * @param alignment - Sets the `pitchAlignment` property of the marker. If alignment is 'auto', it will automatically match `rotationAlignment`.\n */\n setPitchAlignment(alignment?: Alignment): this {\n this._pitchAlignment = alignment && alignment !== 'auto' ? alignment : this._rotationAlignment;\n this._update();\n return this;\n }\n\n /**\n * Returns the current `pitchAlignment` property of the marker.\n * @returns The current pitch alignment of the marker in degrees.\n */\n getPitchAlignment(): Alignment {\n return this._pitchAlignment;\n }\n\n /**\n * Sets the `opacity` and `opacityWhenCovered` properties of the marker.\n * When called without arguments, resets opacity and opacityWhenCovered to defaults\n * @param opacity - Sets the `opacity` property of the marker.\n * @param opacityWhenCovered - Sets the `opacityWhenCovered` property of the marker.\n */\n setOpacity(opacity?: string, opacityWhenCovered?: string): this {\n if (opacity === undefined && opacityWhenCovered === undefined) {\n this._opacity = '1';\n this._opacityWhenCovered = '0.2';\n }\n if (opacity !== undefined) {\n this._opacity = opacity;\n }\n if (opacityWhenCovered !== undefined) {\n this._opacityWhenCovered = opacityWhenCovered;\n }\n if (this._map) {\n this._updateOpacity(true);\n }\n return this;\n }\n}\n","import {Event, Evented} from '../../util/evented';\nimport {DOM} from '../../util/dom';\nimport {extend, warnOnce} from '../../util/util';\nimport {checkGeolocationSupport} from '../../util/geolocation_support';\nimport {LngLat} from '../../geo/lng_lat';\nimport {Marker} from '../marker';\n\nimport type {Map} from '../map';\nimport type {FitBoundsOptions} from '../camera';\nimport type {IControl} from './control';\nimport {LngLatBounds} from '../../geo/lng_lat_bounds';\n\n/**\n * The {@link GeolocateControl} options object\n */\ntype GeolocateControlOptions = {\n /**\n * A Geolocation API [PositionOptions](https://developer.mozilla.org/en-US/docs/Web/API/PositionOptions) object.\n * @defaultValue `{enableHighAccuracy: false, timeout: 6000}`\n */\n positionOptions?: PositionOptions;\n /**\n * A options object to use when the map is panned and zoomed to the user's location. The default is to use a `maxZoom` of 15 to limit how far the map will zoom in for very accurate locations.\n */\n fitBoundsOptions?: FitBoundsOptions;\n /**\n * If `true` the `GeolocateControl` becomes a toggle button and when active the map will receive updates to the user's location as it changes.\n * @defaultValue false\n */\n trackUserLocation?: boolean;\n /**\n * By default, if `showUserLocation` is `true`, a transparent circle will be drawn around the user location indicating the accuracy (95% confidence level) of the user's location. Set to `false` to disable. Always disabled when `showUserLocation` is `false`.\n * @defaultValue true\n */\n showAccuracyCircle?: boolean;\n /**\n * By default a dot will be shown on the map at the user's location. Set to `false` to disable.\n * @defaultValue true\n */\n showUserLocation?: boolean;\n};\n\nconst defaultOptions: GeolocateControlOptions = {\n positionOptions: {\n enableHighAccuracy: false,\n maximumAge: 0,\n timeout: 6000 /* 6 sec */\n },\n fitBoundsOptions: {\n maxZoom: 15\n },\n trackUserLocation: false,\n showAccuracyCircle: true,\n showUserLocation: true\n};\n\nlet numberOfWatches = 0;\nlet noTimeout = false;\n\n/**\n * A `GeolocateControl` control provides a button that uses the browser's geolocation\n * API to locate the user on the map.\n *\n * Not all browsers support geolocation,\n * and some users may disable the feature. Geolocation support for modern\n * browsers including Chrome requires sites to be served over HTTPS. If\n * geolocation support is not available, the `GeolocateControl` will show\n * as disabled.\n *\n * The zoom level applied will depend on the accuracy of the geolocation provided by the device.\n *\n * The `GeolocateControl` has two modes. If `trackUserLocation` is `false` (default) the control acts as a button, which when pressed will set the map's camera to target the user location. If the user moves, the map won't update. This is most suited for the desktop. If `trackUserLocation` is `true` the control acts as a toggle button that when active the user's location is actively monitored for changes. In this mode the `GeolocateControl` has three interaction states:\n * * active - the map's camera automatically updates as the user's location changes, keeping the location dot in the center. Initial state and upon clicking the `GeolocateControl` button.\n * * passive - the user's location dot automatically updates, but the map's camera does not. Occurs upon the user initiating a map movement.\n * * disabled - occurs if Geolocation is not available, disabled or denied.\n *\n * These interaction states can't be controlled programmatically, rather they are set based on user interactions.\n *\n * ## State Diagram\n * ![GeolocateControl state diagram](https://github.com/maplibre/maplibre-gl-js/assets/3269297/78e720e5-d781-4da8-9803-a7a0e6aaaa9f)\n *\n * @group Markers and Controls\n *\n * @example\n * ```ts\n * map.addControl(new GeolocateControl({\n * positionOptions: {\n * enableHighAccuracy: true\n * },\n * trackUserLocation: true\n * }));\n * ```\n * @see [Locate the user](https://maplibre.org/maplibre-gl-js/docs/examples/locate-user/)\n *\n * ## Events\n *\n * **Event** `trackuserlocationend` of type {@link Event} will be fired when the `GeolocateControl` changes to the background state, which happens when a user changes the camera during an active position lock. This only applies when `trackUserLocation` is `true`. In the background state, the dot on the map will update with location updates but the camera will not.\n *\n * **Event** `trackuserlocationstart` of type {@link Event} will be fired when the `GeolocateControl` changes to the active lock state, which happens either upon first obtaining a successful Geolocation API position for the user (a `geolocate` event will follow), or the user clicks the geolocate button when in the background state which uses the last known position to recenter the map and enter active lock state (no `geolocate` event will follow unless the users's location changes).\n *\n * **Event** `userlocationlostfocus` of type {@link Event} will be fired when the `GeolocateControl` changes to the background state, which happens when a user changes the camera during an active position lock. This only applies when `trackUserLocation` is `true`. In the background state, the dot on the map will update with location updates but the camera will not.\n *\n * **Event** `userlocationfocus` of type {@link Event} will be fired when the `GeolocateControl` changes to the active lock state, which happens upon the user clicks the geolocate button when in the background state which uses the last known position to recenter the map and enter active lock state.\n *\n * **Event** `geolocate` of type {@link Event} will be fired on each Geolocation API position update which returned as success.\n * `data` - The returned [Position](https://developer.mozilla.org/en-US/docs/Web/API/Position) object from the callback in [Geolocation.getCurrentPosition()](https://developer.mozilla.org/en-US/docs/Web/API/Geolocation/getCurrentPosition) or [Geolocation.watchPosition()](https://developer.mozilla.org/en-US/docs/Web/API/Geolocation/watchPosition).\n *\n * **Event** `error` of type {@link Event} will be fired on each Geolocation API position update which returned as an error.\n * `data` - The returned [PositionError](https://developer.mozilla.org/en-US/docs/Web/API/PositionError) object from the callback in [Geolocation.getCurrentPosition()](https://developer.mozilla.org/en-US/docs/Web/API/Geolocation/getCurrentPosition) or [Geolocation.watchPosition()](https://developer.mozilla.org/en-US/docs/Web/API/Geolocation/watchPosition).\n *\n * **Event** `outofmaxbounds` of type {@link Event} will be fired on each Geolocation API position update which returned as success but user position is out of map `maxBounds`.\n * `data` - The returned [Position](https://developer.mozilla.org/en-US/docs/Web/API/Position) object from the callback in [Geolocation.getCurrentPosition()](https://developer.mozilla.org/en-US/docs/Web/API/Geolocation/getCurrentPosition) or [Geolocation.watchPosition()](https://developer.mozilla.org/en-US/docs/Web/API/Geolocation/watchPosition).\n *\n * @example\n * ```ts\n * // Initialize the geolocate control.\n * let geolocate = new GeolocateControl({\n * positionOptions: {\n * enableHighAccuracy: true\n * },\n * trackUserLocation: true\n * });\n * // Add the control to the map.\n * map.addControl(geolocate);\n * // Set an event listener that fires\n * // when a trackuserlocationend event occurs.\n * geolocate.on('trackuserlocationend', () => {\n * console.log('A trackuserlocationend event has occurred.')\n * });\n * ```\n *\n * @example\n * ```ts\n * // Initialize the geolocate control.\n * let geolocate = new GeolocateControl({\n * positionOptions: {\n * enableHighAccuracy: true\n * },\n * trackUserLocation: true\n * });\n * // Add the control to the map.\n * map.addControl(geolocate);\n * // Set an event listener that fires\n * // when a trackuserlocationstart event occurs.\n * geolocate.on('trackuserlocationstart', () => {\n * console.log('A trackuserlocationstart event has occurred.')\n * });\n * ```\n *\n * @example\n * ```ts\n * // Initialize the geolocate control.\n * let geolocate = new GeolocateControl({\n * positionOptions: {\n * enableHighAccuracy: true\n * },\n * trackUserLocation: true\n * });\n * // Add the control to the map.\n * map.addControl(geolocate);\n * // Set an event listener that fires\n * // when an userlocationlostfocus event occurs.\n * geolocate.on('userlocationlostfocus', function() {\n * console.log('An userlocationlostfocus event has occurred.')\n * });\n * ```\n *\n * @example\n * ```ts\n * // Initialize the geolocate control.\n * let geolocate = new GeolocateControl({\n * positionOptions: {\n * enableHighAccuracy: true\n * },\n * trackUserLocation: true\n * });\n * // Add the control to the map.\n * map.addControl(geolocate);\n * // Set an event listener that fires\n * // when an userlocationfocus event occurs.\n * geolocate.on('userlocationfocus', function() {\n * console.log('An userlocationfocus event has occurred.')\n * });\n * ```\n *\n * @example\n * ```ts\n * // Initialize the geolocate control.\n * let geolocate = new GeolocateControl({\n * positionOptions: {\n * enableHighAccuracy: true\n * },\n * trackUserLocation: true\n * });\n * // Add the control to the map.\n * map.addControl(geolocate);\n * // Set an event listener that fires\n * // when a geolocate event occurs.\n * geolocate.on('geolocate', () => {\n * console.log('A geolocate event has occurred.')\n * });\n * ```\n *\n * @example\n * ```ts\n * // Initialize the geolocate control.\n * let geolocate = new GeolocateControl({\n * positionOptions: {\n * enableHighAccuracy: true\n * },\n * trackUserLocation: true\n * });\n * // Add the control to the map.\n * map.addControl(geolocate);\n * // Set an event listener that fires\n * // when an error event occurs.\n * geolocate.on('error', () => {\n * console.log('An error event has occurred.')\n * });\n * ```\n *\n * @example\n * ```ts\n * // Initialize the geolocate control.\n * let geolocate = new GeolocateControl({\n * positionOptions: {\n * enableHighAccuracy: true\n * },\n * trackUserLocation: true\n * });\n * // Add the control to the map.\n * map.addControl(geolocate);\n * // Set an event listener that fires\n * // when an outofmaxbounds event occurs.\n * geolocate.on('outofmaxbounds', () => {\n * console.log('An outofmaxbounds event has occurred.')\n * });\n * ```\n */\nexport class GeolocateControl extends Evented implements IControl {\n _map: Map;\n options: GeolocateControlOptions;\n _container: HTMLElement;\n _dotElement: HTMLElement;\n _circleElement: HTMLElement;\n _geolocateButton: HTMLButtonElement;\n _geolocationWatchID: number;\n _timeoutId: ReturnType;\n /* Geolocate Control Watch States\n * This is the private state of the control.\n *\n * OFF\n * off/inactive\n * WAITING_ACTIVE\n * Geolocate Control was clicked but still waiting for Geolocation API response with user location\n * ACTIVE_LOCK\n * Showing the user location as a dot AND tracking the camera to be fixed to their location. If their location changes the map moves to follow.\n * ACTIVE_ERROR\n * There was en error from the Geolocation API while trying to show and track the user location.\n * BACKGROUND\n * Showing the user location as a dot but the camera doesn't follow their location as it changes.\n * BACKGROUND_ERROR\n * There was an error from the Geolocation API while trying to show (but not track) the user location.\n */\n _watchState: 'OFF' | 'ACTIVE_LOCK' | 'WAITING_ACTIVE' | 'ACTIVE_ERROR' | 'BACKGROUND' | 'BACKGROUND_ERROR';\n _lastKnownPosition: any;\n _userLocationDotMarker: Marker;\n _accuracyCircleMarker: Marker;\n _accuracy: number;\n _setup: boolean; // set to true once the control has been setup\n\n /**\n * @param options - the control's options\n */\n constructor(options: GeolocateControlOptions) {\n super();\n this.options = extend({}, defaultOptions, options);\n }\n\n /** {@inheritDoc IControl.onAdd} */\n onAdd(map: Map) {\n this._map = map;\n this._container = DOM.create('div', 'maplibregl-ctrl maplibregl-ctrl-group');\n this._setupUI();\n checkGeolocationSupport().then((supported) => this._finishSetupUI(supported));\n return this._container;\n }\n\n /** {@inheritDoc IControl.onRemove} */\n onRemove() {\n // clear the geolocation watch if exists\n if (this._geolocationWatchID !== undefined) {\n window.navigator.geolocation.clearWatch(this._geolocationWatchID);\n this._geolocationWatchID = undefined;\n }\n\n // clear the markers from the map\n if (this.options.showUserLocation && this._userLocationDotMarker) {\n this._userLocationDotMarker.remove();\n }\n if (this.options.showAccuracyCircle && this._accuracyCircleMarker) {\n this._accuracyCircleMarker.remove();\n }\n\n DOM.remove(this._container);\n this._map.off('zoom', this._onZoom);\n this._map = undefined;\n numberOfWatches = 0;\n noTimeout = false;\n }\n\n /**\n * Check if the Geolocation API Position is outside the map's `maxBounds`.\n *\n * @param position - the Geolocation API Position\n * @returns `true` if position is outside the map's `maxBounds`, otherwise returns `false`.\n */\n _isOutOfMapMaxBounds(position: GeolocationPosition) {\n const bounds = this._map.getMaxBounds();\n const coordinates = position.coords;\n\n return bounds && (\n coordinates.longitude < bounds.getWest() ||\n coordinates.longitude > bounds.getEast() ||\n coordinates.latitude < bounds.getSouth() ||\n coordinates.latitude > bounds.getNorth()\n );\n }\n\n _setErrorState() {\n switch (this._watchState) {\n case 'WAITING_ACTIVE':\n this._watchState = 'ACTIVE_ERROR';\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-active');\n this._geolocateButton.classList.add('maplibregl-ctrl-geolocate-active-error');\n break;\n case 'ACTIVE_LOCK':\n this._watchState = 'ACTIVE_ERROR';\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-active');\n this._geolocateButton.classList.add('maplibregl-ctrl-geolocate-active-error');\n this._geolocateButton.classList.add('maplibregl-ctrl-geolocate-waiting');\n // turn marker grey\n break;\n case 'BACKGROUND':\n this._watchState = 'BACKGROUND_ERROR';\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-background');\n this._geolocateButton.classList.add('maplibregl-ctrl-geolocate-background-error');\n this._geolocateButton.classList.add('maplibregl-ctrl-geolocate-waiting');\n // turn marker grey\n break;\n case 'ACTIVE_ERROR':\n break;\n default:\n throw new Error(`Unexpected watchState ${this._watchState}`);\n }\n }\n\n /**\n * When the Geolocation API returns a new location, update the `GeolocateControl`.\n *\n * @param position - the Geolocation API Position\n */\n _onSuccess = (position: GeolocationPosition) => {\n if (!this._map) {\n // control has since been removed\n return;\n }\n\n if (this._isOutOfMapMaxBounds(position)) {\n this._setErrorState();\n\n this.fire(new Event('outofmaxbounds', position));\n this._updateMarker();\n this._finish();\n\n return;\n }\n\n if (this.options.trackUserLocation) {\n // keep a record of the position so that if the state is BACKGROUND and the user\n // clicks the button, we can move to ACTIVE_LOCK immediately without waiting for\n // watchPosition to trigger _onSuccess\n this._lastKnownPosition = position;\n\n switch (this._watchState) {\n case 'WAITING_ACTIVE':\n case 'ACTIVE_LOCK':\n case 'ACTIVE_ERROR':\n this._watchState = 'ACTIVE_LOCK';\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-waiting');\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-active-error');\n this._geolocateButton.classList.add('maplibregl-ctrl-geolocate-active');\n break;\n case 'BACKGROUND':\n case 'BACKGROUND_ERROR':\n this._watchState = 'BACKGROUND';\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-waiting');\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-background-error');\n this._geolocateButton.classList.add('maplibregl-ctrl-geolocate-background');\n break;\n default:\n throw new Error(`Unexpected watchState ${this._watchState}`);\n }\n }\n\n // if showUserLocation and the watch state isn't off then update the marker location\n if (this.options.showUserLocation && this._watchState !== 'OFF') {\n this._updateMarker(position);\n }\n\n // if in normal mode (not watch mode), or if in watch mode and the state is active watch\n // then update the camera\n if (!this.options.trackUserLocation || this._watchState === 'ACTIVE_LOCK') {\n this._updateCamera(position);\n }\n\n if (this.options.showUserLocation) {\n this._dotElement.classList.remove('maplibregl-user-location-dot-stale');\n }\n\n this.fire(new Event('geolocate', position));\n this._finish();\n };\n\n /**\n * Update the camera location to center on the current position\n *\n * @param position - the Geolocation API Position\n */\n _updateCamera = (position: GeolocationPosition) => {\n const center = new LngLat(position.coords.longitude, position.coords.latitude);\n const radius = position.coords.accuracy;\n const bearing = this._map.getBearing();\n const options = extend({bearing}, this.options.fitBoundsOptions);\n const newBounds = LngLatBounds.fromLngLat(center, radius);\n\n this._map.fitBounds(newBounds, options, {\n geolocateSource: true // tag this camera change so it won't cause the control to change to background state\n });\n };\n\n /**\n * Update the user location dot Marker to the current position\n *\n * @param position - the Geolocation API Position\n */\n _updateMarker = (position?: GeolocationPosition | null) => {\n if (position) {\n const center = new LngLat(position.coords.longitude, position.coords.latitude);\n this._accuracyCircleMarker.setLngLat(center).addTo(this._map);\n this._userLocationDotMarker.setLngLat(center).addTo(this._map);\n this._accuracy = position.coords.accuracy;\n if (this.options.showUserLocation && this.options.showAccuracyCircle) {\n this._updateCircleRadius();\n }\n } else {\n this._userLocationDotMarker.remove();\n this._accuracyCircleMarker.remove();\n }\n };\n\n _updateCircleRadius() {\n const bounds = this._map.getBounds();\n const southEastPoint = bounds.getSouthEast();\n const northEastPoint = bounds.getNorthEast();\n const mapHeightInMeters = southEastPoint.distanceTo(northEastPoint);\n const mapHeightInPixels = this._map._container.clientHeight;\n const circleDiameter = Math.ceil(2 * (this._accuracy / (mapHeightInMeters / mapHeightInPixels)));\n this._circleElement.style.width = `${circleDiameter}px`;\n this._circleElement.style.height = `${circleDiameter}px`;\n }\n\n _onZoom = () => {\n if (this.options.showUserLocation && this.options.showAccuracyCircle) {\n this._updateCircleRadius();\n }\n };\n\n _onError = (error: GeolocationPositionError) => {\n if (!this._map) {\n // control has since been removed\n return;\n }\n\n if (this.options.trackUserLocation) {\n if (error.code === 1) {\n // PERMISSION_DENIED\n this._watchState = 'OFF';\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-waiting');\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-active');\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-active-error');\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-background');\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-background-error');\n this._geolocateButton.disabled = true;\n const title = this._map._getUIString('GeolocateControl.LocationNotAvailable');\n this._geolocateButton.title = title;\n this._geolocateButton.setAttribute('aria-label', title);\n\n if (this._geolocationWatchID !== undefined) {\n this._clearWatch();\n }\n } else if (error.code === 3 && noTimeout) {\n // this represents a forced error state\n // this was triggered to force immediate geolocation when a watch is already present\n // see https://github.com/mapbox/mapbox-gl-js/issues/8214\n // and https://w3c.github.io/geolocation-api/#example-5-forcing-the-user-agent-to-return-a-fresh-cached-position\n return;\n } else {\n this._setErrorState();\n }\n }\n\n if (this._watchState !== 'OFF' && this.options.showUserLocation) {\n this._dotElement.classList.add('maplibregl-user-location-dot-stale');\n }\n\n this.fire(new Event('error', error));\n\n this._finish();\n };\n\n _finish = () => {\n if (this._timeoutId) { clearTimeout(this._timeoutId); }\n this._timeoutId = undefined;\n };\n\n _setupUI = () => {\n // the control could have been removed before reaching here\n if (!this._map) {\n return;\n }\n\n this._container.addEventListener('contextmenu', (e: MouseEvent) => e.preventDefault());\n this._geolocateButton = DOM.create('button', 'maplibregl-ctrl-geolocate', this._container);\n DOM.create('span', 'maplibregl-ctrl-icon', this._geolocateButton).setAttribute('aria-hidden', 'true');\n this._geolocateButton.type = 'button';\n this._geolocateButton.disabled = true;\n };\n\n _finishSetupUI = (supported: boolean) => {\n // this method is called asynchronously during onAdd\n if (!this._map) {\n // control has since been removed\n return;\n }\n\n if (supported === false) {\n warnOnce('Geolocation support is not available so the GeolocateControl will be disabled.');\n const title = this._map._getUIString('GeolocateControl.LocationNotAvailable');\n this._geolocateButton.disabled = true;\n this._geolocateButton.title = title;\n this._geolocateButton.setAttribute('aria-label', title);\n } else {\n const title = this._map._getUIString('GeolocateControl.FindMyLocation');\n this._geolocateButton.disabled = false;\n this._geolocateButton.title = title;\n this._geolocateButton.setAttribute('aria-label', title);\n }\n\n if (this.options.trackUserLocation) {\n this._geolocateButton.setAttribute('aria-pressed', 'false');\n this._watchState = 'OFF';\n }\n\n // when showUserLocation is enabled, keep the Geolocate button disabled until the device location marker is setup on the map\n if (this.options.showUserLocation) {\n this._dotElement = DOM.create('div', 'maplibregl-user-location-dot');\n\n this._userLocationDotMarker = new Marker({element: this._dotElement});\n\n this._circleElement = DOM.create('div', 'maplibregl-user-location-accuracy-circle');\n this._accuracyCircleMarker = new Marker({element: this._circleElement, pitchAlignment: 'map'});\n\n if (this.options.trackUserLocation) this._watchState = 'OFF';\n\n this._map.on('zoom', this._onZoom);\n }\n\n this._geolocateButton.addEventListener('click', () => this.trigger());\n\n this._setup = true;\n\n // when the camera is changed (and it's not as a result of the Geolocation Control) change\n // the watch mode to background watch, so that the marker is updated but not the camera.\n if (this.options.trackUserLocation) {\n this._map.on('movestart', (event: any) => {\n const fromResize = event.originalEvent && event.originalEvent.type === 'resize';\n if (!event.geolocateSource && this._watchState === 'ACTIVE_LOCK' && !fromResize) {\n this._watchState = 'BACKGROUND';\n this._geolocateButton.classList.add('maplibregl-ctrl-geolocate-background');\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-active');\n\n this.fire(new Event('trackuserlocationend'));\n this.fire(new Event('userlocationlostfocus'));\n }\n });\n }\n };\n\n /**\n * Programmatically request and move the map to the user's location.\n *\n * @returns `false` if called before control was added to a map, otherwise returns `true`.\n * @example\n * ```ts\n * // Initialize the geolocate control.\n * let geolocate = new GeolocateControl({\n * positionOptions: {\n * enableHighAccuracy: true\n * },\n * trackUserLocation: true\n * });\n * // Add the control to the map.\n * map.addControl(geolocate);\n * map.on('load', () => {\n * geolocate.trigger();\n * });\n * ```\n */\n trigger(): boolean {\n if (!this._setup) {\n warnOnce('Geolocate control triggered before added to a map');\n return false;\n }\n if (this.options.trackUserLocation) {\n // update watchState and do any outgoing state cleanup\n switch (this._watchState) {\n case 'OFF':\n // turn on the Geolocate Control\n this._watchState = 'WAITING_ACTIVE';\n\n this.fire(new Event('trackuserlocationstart'));\n break;\n case 'WAITING_ACTIVE':\n case 'ACTIVE_LOCK':\n case 'ACTIVE_ERROR':\n case 'BACKGROUND_ERROR':\n // turn off the Geolocate Control\n numberOfWatches--;\n noTimeout = false;\n this._watchState = 'OFF';\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-waiting');\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-active');\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-active-error');\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-background');\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-background-error');\n\n this.fire(new Event('trackuserlocationend'));\n break;\n case 'BACKGROUND':\n this._watchState = 'ACTIVE_LOCK';\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-background');\n // set camera to last known location\n if (this._lastKnownPosition) this._updateCamera(this._lastKnownPosition);\n\n this.fire(new Event('trackuserlocationstart'));\n this.fire(new Event('userlocationfocus'));\n break;\n default:\n throw new Error(`Unexpected watchState ${this._watchState}`);\n }\n\n // incoming state setup\n switch (this._watchState) {\n case 'WAITING_ACTIVE':\n this._geolocateButton.classList.add('maplibregl-ctrl-geolocate-waiting');\n this._geolocateButton.classList.add('maplibregl-ctrl-geolocate-active');\n break;\n case 'ACTIVE_LOCK':\n this._geolocateButton.classList.add('maplibregl-ctrl-geolocate-active');\n break;\n case 'OFF':\n break;\n default:\n throw new Error(`Unexpected watchState ${this._watchState}`);\n }\n\n // manage geolocation.watchPosition / geolocation.clearWatch\n if (this._watchState === 'OFF' && this._geolocationWatchID !== undefined) {\n // clear watchPosition as we've changed to an OFF state\n this._clearWatch();\n } else if (this._geolocationWatchID === undefined) {\n // enable watchPosition since watchState is not OFF and there is no watchPosition already running\n\n this._geolocateButton.classList.add('maplibregl-ctrl-geolocate-waiting');\n this._geolocateButton.setAttribute('aria-pressed', 'true');\n\n numberOfWatches++;\n let positionOptions;\n if (numberOfWatches > 1) {\n positionOptions = {maximumAge: 600000, timeout: 0};\n noTimeout = true;\n } else {\n positionOptions = this.options.positionOptions;\n noTimeout = false;\n }\n\n this._geolocationWatchID = window.navigator.geolocation.watchPosition(\n this._onSuccess, this._onError, positionOptions);\n }\n } else {\n window.navigator.geolocation.getCurrentPosition(\n this._onSuccess, this._onError, this.options.positionOptions);\n\n // This timeout ensures that we still call finish() even if\n // the user declines to share their location in Firefox\n this._timeoutId = setTimeout(this._finish, 10000 /* 10sec */);\n }\n\n return true;\n }\n\n _clearWatch() {\n window.navigator.geolocation.clearWatch(this._geolocationWatchID);\n\n this._geolocationWatchID = undefined;\n this._geolocateButton.classList.remove('maplibregl-ctrl-geolocate-waiting');\n this._geolocateButton.setAttribute('aria-pressed', 'false');\n\n if (this.options.showUserLocation) {\n this._updateMarker(null);\n }\n }\n}\n\n","import {DOM} from '../../util/dom';\n\nimport type {Map} from '../map';\nimport type {ControlPosition, IControl} from './control';\n\n/**\n * The unit type for length to use for the {@link ScaleControl}\n */\nexport type Unit = 'imperial' | 'metric' | 'nautical';\n\n/**\n * The {@link ScaleControl} options object\n */\ntype ScaleControlOptions = {\n /**\n * The maximum length of the scale control in pixels.\n * @defaultValue 100\n */\n maxWidth?: number;\n /**\n * Unit of the distance (`'imperial'`, `'metric'` or `'nautical'`).\n * @defaultValue 'metric'\n */\n unit?: Unit;\n};\n\nconst defaultOptions: ScaleControlOptions = {\n maxWidth: 100,\n unit: 'metric'\n};\n\n/**\n * A `ScaleControl` control displays the ratio of a distance on the map to the corresponding distance on the ground.\n *\n * @group Markers and Controls\n *\n * @example\n * ```ts\n * let scale = new ScaleControl({\n * maxWidth: 80,\n * unit: 'imperial'\n * });\n * map.addControl(scale);\n *\n * scale.setUnit('metric');\n * ```\n */\nexport class ScaleControl implements IControl {\n _map: Map;\n _container: HTMLElement;\n options: ScaleControlOptions;\n\n /**\n * @param options - the control's options\n */\n constructor(options?: ScaleControlOptions) {\n this.options = {...defaultOptions, ...options};\n }\n\n getDefaultPosition(): ControlPosition {\n return 'bottom-left';\n }\n\n _onMove = () => {\n updateScale(this._map, this._container, this.options);\n };\n\n /** {@inheritDoc IControl.onAdd} */\n onAdd(map: Map) {\n this._map = map;\n this._container = DOM.create('div', 'maplibregl-ctrl maplibregl-ctrl-scale', map.getContainer());\n\n this._map.on('move', this._onMove);\n this._onMove();\n\n return this._container;\n }\n\n /** {@inheritDoc IControl.onRemove} */\n onRemove() {\n DOM.remove(this._container);\n this._map.off('move', this._onMove);\n this._map = undefined;\n }\n\n /**\n * Set the scale's unit of the distance\n *\n * @param unit - Unit of the distance (`'imperial'`, `'metric'` or `'nautical'`).\n */\n setUnit = (unit: Unit) => {\n this.options.unit = unit;\n updateScale(this._map, this._container, this.options);\n };\n}\n\nfunction updateScale(map, container, options) {\n // A horizontal scale is imagined to be present at center of the map\n // container with maximum length (Default) as 100px.\n // Using spherical law of cosines approximation, the real distance is\n // found between the two coordinates.\n const maxWidth = options && options.maxWidth || 100;\n\n const y = map._container.clientHeight / 2;\n const left = map.unproject([0, y]);\n const right = map.unproject([maxWidth, y]);\n const maxMeters = left.distanceTo(right);\n // The real distance corresponding to 100px scale length is rounded off to\n // near pretty number and the scale length for the same is found out.\n // Default unit of the scale is based on User's locale.\n if (options && options.unit === 'imperial') {\n const maxFeet = 3.2808 * maxMeters;\n if (maxFeet > 5280) {\n const maxMiles = maxFeet / 5280;\n setScale(container, maxWidth, maxMiles, map._getUIString('ScaleControl.Miles'));\n } else {\n setScale(container, maxWidth, maxFeet, map._getUIString('ScaleControl.Feet'));\n }\n } else if (options && options.unit === 'nautical') {\n const maxNauticals = maxMeters / 1852;\n setScale(container, maxWidth, maxNauticals, map._getUIString('ScaleControl.NauticalMiles'));\n } else if (maxMeters >= 1000) {\n setScale(container, maxWidth, maxMeters / 1000, map._getUIString('ScaleControl.Kilometers'));\n } else {\n setScale(container, maxWidth, maxMeters, map._getUIString('ScaleControl.Meters'));\n }\n}\n\nfunction setScale(container, maxWidth, maxDistance, unit) {\n const distance = getRoundNum(maxDistance);\n const ratio = distance / maxDistance;\n container.style.width = `${maxWidth * ratio}px`;\n container.innerHTML = `${distance} ${unit}`;\n}\n\nfunction getDecimalRoundNum(d) {\n const multiplier = Math.pow(10, Math.ceil(-Math.log(d) / Math.LN10));\n return Math.round(d * multiplier) / multiplier;\n}\n\nfunction getRoundNum(num) {\n const pow10 = Math.pow(10, (`${Math.floor(num)}`).length - 1);\n let d = num / pow10;\n\n d = d >= 10 ? 10 :\n d >= 5 ? 5 :\n d >= 3 ? 3 :\n d >= 2 ? 2 :\n d >= 1 ? 1 : getDecimalRoundNum(d);\n\n return pow10 * d;\n}\n","import {DOM} from '../../util/dom';\n\nimport {warnOnce} from '../../util/util';\n\nimport {Event, Evented} from '../../util/evented';\nimport type {Map} from '../map';\nimport type {IControl} from './control';\n\n/**\n * The {@link FullscreenControl} options object\n */\ntype FullscreenControlOptions = {\n /**\n * `container` is the [compatible DOM element](https://developer.mozilla.org/en-US/docs/Web/API/Element/requestFullScreen#Compatible_elements) which should be made full screen. By default, the map container element will be made full screen.\n */\n container?: HTMLElement;\n};\n\n/**\n * A `FullscreenControl` control contains a button for toggling the map in and out of fullscreen mode.\n * When [requestFullscreen](https://developer.mozilla.org/en-US/docs/Web/API/Element/requestFullscreen) is not supported, fullscreen is handled via CSS properties.\n * The map's `cooperativeGestures` option is temporarily disabled while the map\n * is in fullscreen mode, and is restored when the map exist fullscreen mode.\n *\n * @group Markers and Controls\n * @param options - the full screen control options\n *\n * @example\n * ```ts\n * map.addControl(new FullscreenControl({container: document.querySelector('body')}));\n * ```\n * @see [View a fullscreen map](https://maplibre.org/maplibre-gl-js/docs/examples/fullscreen/)\n *\n * ## Events\n *\n * **Event** `fullscreenstart` of type {@link Event} will be fired when fullscreen mode has started.\n *\n * **Event** `fullscreenend` of type {@link Event} will be fired when fullscreen mode has ended.\n */\nexport class FullscreenControl extends Evented implements IControl {\n _map: Map;\n _controlContainer: HTMLElement;\n _fullscreen: boolean;\n _fullscreenchange: string;\n _fullscreenButton: HTMLButtonElement;\n _container: HTMLElement;\n _prevCooperativeGesturesEnabled: boolean;\n\n /**\n * @param options - the control's options\n */\n constructor(options: FullscreenControlOptions = {}) {\n super();\n this._fullscreen = false;\n\n if (options && options.container) {\n if (options.container instanceof HTMLElement) {\n this._container = options.container;\n } else {\n warnOnce('Full screen control \\'container\\' must be a DOM element.');\n }\n }\n\n if ('onfullscreenchange' in document) {\n this._fullscreenchange = 'fullscreenchange';\n } else if ('onmozfullscreenchange' in document) {\n this._fullscreenchange = 'mozfullscreenchange';\n } else if ('onwebkitfullscreenchange' in document) {\n this._fullscreenchange = 'webkitfullscreenchange';\n } else if ('onmsfullscreenchange' in document) {\n this._fullscreenchange = 'MSFullscreenChange';\n }\n }\n\n /** {@inheritDoc IControl.onAdd} */\n onAdd(map: Map): HTMLElement {\n this._map = map;\n if (!this._container) this._container = this._map.getContainer();\n this._controlContainer = DOM.create('div', 'maplibregl-ctrl maplibregl-ctrl-group');\n this._setupUI();\n return this._controlContainer;\n }\n\n /** {@inheritDoc IControl.onRemove} */\n onRemove() {\n DOM.remove(this._controlContainer);\n this._map = null;\n window.document.removeEventListener(this._fullscreenchange, this._onFullscreenChange);\n }\n\n _setupUI() {\n const button = this._fullscreenButton = DOM.create('button', (('maplibregl-ctrl-fullscreen')), this._controlContainer);\n DOM.create('span', 'maplibregl-ctrl-icon', button).setAttribute('aria-hidden', 'true');\n button.type = 'button';\n this._updateTitle();\n this._fullscreenButton.addEventListener('click', this._onClickFullscreen);\n window.document.addEventListener(this._fullscreenchange, this._onFullscreenChange);\n }\n\n _updateTitle() {\n const title = this._getTitle();\n this._fullscreenButton.setAttribute('aria-label', title);\n this._fullscreenButton.title = title;\n }\n\n _getTitle() {\n return this._map._getUIString(this._isFullscreen() ? 'FullscreenControl.Exit' : 'FullscreenControl.Enter');\n }\n\n _isFullscreen() {\n return this._fullscreen;\n }\n\n _onFullscreenChange = () => {\n let fullscreenElement =\n window.document.fullscreenElement ||\n (window.document as any).mozFullScreenElement ||\n (window.document as any).webkitFullscreenElement ||\n (window.document as any).msFullscreenElement;\n\n while (fullscreenElement?.shadowRoot?.fullscreenElement) {\n fullscreenElement = fullscreenElement.shadowRoot.fullscreenElement;\n }\n\n if ((fullscreenElement === this._container) !== this._fullscreen) {\n this._handleFullscreenChange();\n }\n };\n\n _handleFullscreenChange() {\n this._fullscreen = !this._fullscreen;\n this._fullscreenButton.classList.toggle('maplibregl-ctrl-shrink');\n this._fullscreenButton.classList.toggle('maplibregl-ctrl-fullscreen');\n this._updateTitle();\n\n if (this._fullscreen) {\n this.fire(new Event('fullscreenstart'));\n this._prevCooperativeGesturesEnabled = this._map.cooperativeGestures.isEnabled();\n this._map.cooperativeGestures.disable();\n } else {\n this.fire(new Event('fullscreenend'));\n if (this._prevCooperativeGesturesEnabled) {\n this._map.cooperativeGestures.enable();\n }\n }\n }\n\n _onClickFullscreen = () => {\n if (this._isFullscreen()) {\n this._exitFullscreen();\n } else {\n this._requestFullscreen();\n }\n };\n\n _exitFullscreen() {\n if (window.document.exitFullscreen) {\n (window.document as any).exitFullscreen();\n } else if ((window.document as any).mozCancelFullScreen) {\n (window.document as any).mozCancelFullScreen();\n } else if ((window.document as any).msExitFullscreen) {\n (window.document as any).msExitFullscreen();\n } else if ((window.document as any).webkitCancelFullScreen) {\n (window.document as any).webkitCancelFullScreen();\n } else {\n this._togglePseudoFullScreen();\n }\n }\n\n _requestFullscreen() {\n if (this._container.requestFullscreen) {\n this._container.requestFullscreen();\n } else if ((this._container as any).mozRequestFullScreen) {\n (this._container as any).mozRequestFullScreen();\n } else if ((this._container as any).msRequestFullscreen) {\n (this._container as any).msRequestFullscreen();\n } else if ((this._container as any).webkitRequestFullscreen) {\n (this._container as any).webkitRequestFullscreen();\n } else {\n this._togglePseudoFullScreen();\n }\n }\n\n _togglePseudoFullScreen() {\n this._container.classList.toggle('maplibregl-pseudo-fullscreen');\n this._handleFullscreenChange();\n this._map.resize();\n }\n}\n","import {DOM} from '../../util/dom';\n\nimport type {Map} from '../map';\nimport type {IControl} from './control';\nimport type {TerrainSpecification} from '@maplibre/maplibre-gl-style-spec';\n\n/**\n * A `TerrainControl` control contains a button for turning the terrain on and off.\n *\n * @group Markers and Controls\n *\n * @example\n * ```ts\n * let map = new Map({TerrainControl: false})\n * .addControl(new TerrainControl({\n * source: \"terrain\"\n * }));\n * ```\n */\nexport class TerrainControl implements IControl {\n options: TerrainSpecification;\n _map: Map;\n _container: HTMLElement;\n _terrainButton: HTMLButtonElement;\n\n /**\n * @param options - the control's options\n */\n constructor(options: TerrainSpecification) {\n this.options = options;\n }\n\n /** {@inheritDoc IControl.onAdd} */\n onAdd(map: Map) {\n this._map = map;\n this._container = DOM.create('div', 'maplibregl-ctrl maplibregl-ctrl-group');\n this._terrainButton = DOM.create('button', 'maplibregl-ctrl-terrain', this._container);\n DOM.create('span', 'maplibregl-ctrl-icon', this._terrainButton).setAttribute('aria-hidden', 'true');\n this._terrainButton.type = 'button';\n this._terrainButton.addEventListener('click', this._toggleTerrain);\n\n this._updateTerrainIcon();\n this._map.on('terrain', this._updateTerrainIcon);\n return this._container;\n }\n\n /** {@inheritDoc IControl.onRemove} */\n onRemove() {\n DOM.remove(this._container);\n this._map.off('terrain', this._updateTerrainIcon);\n this._map = undefined;\n }\n\n _toggleTerrain = () => {\n if (this._map.getTerrain()) {\n this._map.setTerrain(null);\n } else {\n this._map.setTerrain(this.options);\n }\n this._updateTerrainIcon();\n };\n\n _updateTerrainIcon = () => {\n this._terrainButton.classList.remove('maplibregl-ctrl-terrain');\n this._terrainButton.classList.remove('maplibregl-ctrl-terrain-enabled');\n if (this._map.terrain) {\n this._terrainButton.classList.add('maplibregl-ctrl-terrain-enabled');\n this._terrainButton.title = this._map._getUIString('TerrainControl.Disable');\n } else {\n this._terrainButton.classList.add('maplibregl-ctrl-terrain');\n this._terrainButton.title = this._map._getUIString('TerrainControl.Enable');\n }\n };\n}\n","import {extend} from '../util/util';\nimport {Event, Evented} from '../util/evented';\nimport {MapMouseEvent} from '../ui/events';\nimport {DOM} from '../util/dom';\nimport {LngLat} from '../geo/lng_lat';\nimport Point from '@mapbox/point-geometry';\nimport {smartWrap} from '../util/smart_wrap';\nimport {anchorTranslate, applyAnchorClass} from './anchor';\n\nimport type {PositionAnchor} from './anchor';\nimport type {Map} from './map';\nimport type {LngLatLike} from '../geo/lng_lat';\nimport type {PointLike} from './camera';\n\nconst defaultOptions = {\n closeButton: true,\n closeOnClick: true,\n focusAfterOpen: true,\n className: '',\n maxWidth: '240px',\n subpixelPositioning: false\n};\n\n/**\n * A pixel offset specified as:\n *\n * - a single number specifying a distance from the location\n * - a {@link PointLike} specifying a constant offset\n * - an object of {@link Point}s specifying an offset for each anchor position\n *\n * Negative offsets indicate left and up.\n */\nexport type Offset = number | PointLike | {\n [_ in PositionAnchor]: PointLike;\n};\n\n/**\n * The {@link Popup} options object\n */\nexport type PopupOptions = {\n /**\n * If `true`, a close button will appear in the top right corner of the popup.\n * @defaultValue true\n */\n closeButton?: boolean;\n /**\n * If `true`, the popup will closed when the map is clicked.\n * @defaultValue true\n */\n closeOnClick?: boolean;\n /**\n * If `true`, the popup will closed when the map moves.\n * @defaultValue false\n */\n closeOnMove?: boolean;\n /**\n * If `true`, the popup will try to focus the first focusable element inside the popup.\n * @defaultValue true\n */\n focusAfterOpen?: boolean;\n /**\n * A string indicating the part of the Popup that should\n * be positioned closest to the coordinate set via {@link Popup#setLngLat}.\n * Options are `'center'`, `'top'`, `'bottom'`, `'left'`, `'right'`, `'top-left'`,\n * `'top-right'`, `'bottom-left'`, and `'bottom-right'`. If unset the anchor will be\n * dynamically set to ensure the popup falls within the map container with a preference\n * for `'bottom'`.\n */\n anchor?: PositionAnchor;\n /**\n * A pixel offset applied to the popup's location\n */\n offset?: Offset;\n /**\n * Space-separated CSS class names to add to popup container\n */\n className?: string;\n /**\n * A string that sets the CSS property of the popup's maximum width, eg `'300px'`.\n * To ensure the popup resizes to fit its content, set this property to `'none'`.\n * Available values can be found here: https://developer.mozilla.org/en-US/docs/Web/CSS/max-width\n * @defaultValue '240px'\n */\n maxWidth?: string;\n /**\n * If `true`, rounding is disabled for placement of the popup, allowing for\n * subpixel positioning and smoother movement when the popup is translated.\n * @defaultValue false\n */\n subpixelPositioning?: boolean;\n};\n\nconst focusQuerySelector = [\n 'a[href]',\n '[tabindex]:not([tabindex=\\'-1\\'])',\n '[contenteditable]:not([contenteditable=\\'false\\'])',\n 'button:not([disabled])',\n 'input:not([disabled])',\n 'select:not([disabled])',\n 'textarea:not([disabled])',\n].join(', ');\n\n/**\n * A popup component.\n *\n * @group Markers and Controls\n *\n *\n * @example\n * Create a popup\n * ```ts\n * let popup = new Popup();\n * // Set an event listener that will fire\n * // any time the popup is opened\n * popup.on('open', () => {\n * console.log('popup was opened');\n * });\n * ```\n *\n * @example\n * Create a popup\n * ```ts\n * let popup = new Popup();\n * // Set an event listener that will fire\n * // any time the popup is closed\n * popup.on('close', () => {\n * console.log('popup was closed');\n * });\n * ```\n *\n * @example\n * ```ts\n * let markerHeight = 50, markerRadius = 10, linearOffset = 25;\n * let popupOffsets = {\n * 'top': [0, 0],\n * 'top-left': [0,0],\n * 'top-right': [0,0],\n * 'bottom': [0, -markerHeight],\n * 'bottom-left': [linearOffset, (markerHeight - markerRadius + linearOffset) * -1],\n * 'bottom-right': [-linearOffset, (markerHeight - markerRadius + linearOffset) * -1],\n * 'left': [markerRadius, (markerHeight - markerRadius) * -1],\n * 'right': [-markerRadius, (markerHeight - markerRadius) * -1]\n * };\n * let popup = new Popup({offset: popupOffsets, className: 'my-class'})\n * .setLngLat(e.lngLat)\n * .setHTML(\"

Hello World!

\")\n * .setMaxWidth(\"300px\")\n * .addTo(map);\n * ```\n * @see [Display a popup](https://maplibre.org/maplibre-gl-js/docs/examples/popup/)\n * @see [Display a popup on hover](https://maplibre.org/maplibre-gl-js/docs/examples/popup-on-hover/)\n * @see [Display a popup on click](https://maplibre.org/maplibre-gl-js/docs/examples/popup-on-click/)\n * @see [Attach a popup to a marker instance](https://maplibre.org/maplibre-gl-js/docs/examples/set-popup/)\n *\n * ## Events\n *\n * **Event** `open` of type {@link Event} will be fired when the popup is opened manually or programmatically.\n *\n * **Event** `close` of type {@link Event} will be fired when the popup is closed manually or programmatically.\n */\nexport class Popup extends Evented {\n _map: Map;\n options: PopupOptions;\n _content: HTMLElement;\n _container: HTMLElement;\n _closeButton: HTMLButtonElement;\n _tip: HTMLElement;\n _lngLat: LngLat;\n _trackPointer: boolean;\n _pos: Point;\n _flatPos: Point;\n\n /**\n * @param options - the options\n */\n constructor(options?: PopupOptions) {\n super();\n this.options = extend(Object.create(defaultOptions), options);\n }\n\n /**\n * Adds the popup to a map.\n *\n * @param map - The MapLibre GL JS map to add the popup to.\n * @example\n * ```ts\n * new Popup()\n * .setLngLat([0, 0])\n * .setHTML(\"

Null Island

\")\n * .addTo(map);\n * ```\n * @see [Display a popup](https://maplibre.org/maplibre-gl-js/docs/examples/popup/)\n * @see [Display a popup on hover](https://maplibre.org/maplibre-gl-js/docs/examples/popup-on-hover/)\n * @see [Display a popup on click](https://maplibre.org/maplibre-gl-js/docs/examples/popup-on-click/)\n * @see [Show polygon information on click](https://maplibre.org/maplibre-gl-js/docs/examples/polygon-popup-on-click/)\n */\n addTo(map: Map): this {\n if (this._map) this.remove();\n\n this._map = map;\n if (this.options.closeOnClick) {\n this._map.on('click', this._onClose);\n }\n\n if (this.options.closeOnMove) {\n this._map.on('move', this._onClose);\n }\n\n this._map.on('remove', this.remove);\n this._update();\n this._focusFirstElement();\n\n if (this._trackPointer) {\n this._map.on('mousemove', this._onMouseMove);\n this._map.on('mouseup', this._onMouseUp);\n if (this._container) {\n this._container.classList.add('maplibregl-popup-track-pointer');\n }\n this._map._canvasContainer.classList.add('maplibregl-track-pointer');\n } else {\n this._map.on('move', this._update);\n }\n\n this.fire(new Event('open'));\n\n return this;\n }\n\n /**\n * @returns `true` if the popup is open, `false` if it is closed.\n */\n isOpen() {\n return !!this._map;\n }\n\n /**\n * Removes the popup from the map it has been added to.\n *\n * @example\n * ```ts\n * let popup = new Popup().addTo(map);\n * popup.remove();\n * ```\n */\n remove = (): this => {\n if (this._content) {\n DOM.remove(this._content);\n }\n\n if (this._container) {\n DOM.remove(this._container);\n delete this._container;\n }\n\n if (this._map) {\n this._map.off('move', this._update);\n this._map.off('move', this._onClose);\n this._map.off('click', this._onClose);\n this._map.off('remove', this.remove);\n this._map.off('mousemove', this._onMouseMove);\n this._map.off('mouseup', this._onMouseUp);\n this._map.off('drag', this._onDrag);\n this._map._canvasContainer.classList.remove('maplibregl-track-pointer');\n delete this._map;\n this.fire(new Event('close'));\n }\n\n return this;\n };\n\n /**\n * Returns the geographical location of the popup's anchor.\n *\n * The longitude of the result may differ by a multiple of 360 degrees from the longitude previously\n * set by `setLngLat` because `Popup` wraps the anchor longitude across copies of the world to keep\n * the popup on screen.\n *\n * @returns The geographical location of the popup's anchor.\n */\n getLngLat(): LngLat {\n return this._lngLat;\n }\n\n /**\n * Sets the geographical location of the popup's anchor, and moves the popup to it. Replaces trackPointer() behavior.\n *\n * @param lnglat - The geographical location to set as the popup's anchor.\n */\n setLngLat(lnglat: LngLatLike): this {\n this._lngLat = LngLat.convert(lnglat);\n this._pos = null;\n this._flatPos = null;\n\n this._trackPointer = false;\n\n this._update();\n\n if (this._map) {\n this._map.on('move', this._update);\n this._map.off('mousemove', this._onMouseMove);\n if (this._container) {\n this._container.classList.remove('maplibregl-popup-track-pointer');\n }\n this._map._canvasContainer.classList.remove('maplibregl-track-pointer');\n }\n\n return this;\n }\n\n /**\n * Tracks the popup anchor to the cursor position on screens with a pointer device (it will be hidden on touchscreens). Replaces the `setLngLat` behavior.\n * For most use cases, set `closeOnClick` and `closeButton` to `false`.\n * @example\n * ```ts\n * let popup = new Popup({ closeOnClick: false, closeButton: false })\n * .setHTML(\"

Hello World!

\")\n * .trackPointer()\n * .addTo(map);\n * ```\n */\n trackPointer(): this {\n this._trackPointer = true;\n this._pos = null;\n this._flatPos = null;\n this._update();\n if (this._map) {\n this._map.off('move', this._update);\n this._map.on('mousemove', this._onMouseMove);\n this._map.on('drag', this._onDrag);\n if (this._container) {\n this._container.classList.add('maplibregl-popup-track-pointer');\n }\n this._map._canvasContainer.classList.add('maplibregl-track-pointer');\n }\n\n return this;\n\n }\n\n /**\n * Returns the `Popup`'s HTML element.\n * @example\n * Change the `Popup` element's font size\n * ```ts\n * let popup = new Popup()\n * .setLngLat([-96, 37.8])\n * .setHTML(\"

Hello World!

\")\n * .addTo(map);\n * let popupElem = popup.getElement();\n * popupElem.style.fontSize = \"25px\";\n * ```\n * @returns element\n */\n getElement(): HTMLElement {\n return this._container;\n }\n\n /**\n * Sets the popup's content to a string of text.\n *\n * This function creates a [Text](https://developer.mozilla.org/en-US/docs/Web/API/Text) node in the DOM,\n * so it cannot insert raw HTML. Use this method for security against XSS\n * if the popup content is user-provided.\n *\n * @param text - Textual content for the popup.\n * @example\n * ```ts\n * let popup = new Popup()\n * .setLngLat(e.lngLat)\n * .setText('Hello, world!')\n * .addTo(map);\n * ```\n */\n setText(text: string): this {\n return this.setDOMContent(document.createTextNode(text));\n }\n\n /**\n * Sets the popup's content to the HTML provided as a string.\n *\n * This method does not perform HTML filtering or sanitization, and must be\n * used only with trusted content. Consider {@link Popup#setText} if\n * the content is an untrusted text string.\n *\n * @param html - A string representing HTML content for the popup.\n * @example\n * ```ts\n * let popup = new Popup()\n * .setLngLat(e.lngLat)\n * .setHTML(\"

Hello World!

\")\n * .addTo(map);\n * ```\n * @see [Display a popup](https://maplibre.org/maplibre-gl-js/docs/examples/popup/)\n * @see [Display a popup on hover](https://maplibre.org/maplibre-gl-js/docs/examples/popup-on-hover/)\n * @see [Display a popup on click](https://maplibre.org/maplibre-gl-js/docs/examples/popup-on-click/)\n * @see [Attach a popup to a marker instance](https://maplibre.org/maplibre-gl-js/docs/examples/set-popup/)\n */\n setHTML(html: string): this {\n const frag = document.createDocumentFragment();\n const temp = document.createElement('body');\n let child;\n temp.innerHTML = html;\n while (true) {\n child = temp.firstChild;\n if (!child) break;\n frag.appendChild(child);\n }\n\n return this.setDOMContent(frag);\n }\n\n /**\n * Returns the popup's maximum width.\n *\n * @returns The maximum width of the popup.\n */\n getMaxWidth(): string {\n return this._container?.style.maxWidth;\n }\n\n /**\n * Sets the popup's maximum width. This is setting the CSS property `max-width`.\n * Available values can be found here: https://developer.mozilla.org/en-US/docs/Web/CSS/max-width\n *\n * @param maxWidth - A string representing the value for the maximum width.\n */\n setMaxWidth(maxWidth: string): this {\n this.options.maxWidth = maxWidth;\n this._update();\n return this;\n }\n\n /**\n * Sets the popup's content to the element provided as a DOM node.\n *\n * @param htmlNode - A DOM node to be used as content for the popup.\n * @example\n * Create an element with the popup content\n * ```ts\n * let div = document.createElement('div');\n * div.innerHTML = 'Hello, world!';\n * let popup = new Popup()\n * .setLngLat(e.lngLat)\n * .setDOMContent(div)\n * .addTo(map);\n * ```\n */\n setDOMContent(htmlNode: Node): this {\n if (this._content) {\n // Clear out children first.\n while (this._content.hasChildNodes()) {\n if (this._content.firstChild) {\n this._content.removeChild(this._content.firstChild);\n }\n }\n } else {\n this._content = DOM.create('div', 'maplibregl-popup-content', this._container);\n }\n\n // The close button should be the last tabbable element inside the popup for a good keyboard UX.\n this._content.appendChild(htmlNode);\n this._createCloseButton();\n this._update();\n this._focusFirstElement();\n return this;\n }\n\n /**\n * Adds a CSS class to the popup container element.\n *\n * @param className - Non-empty string with CSS class name to add to popup container\n *\n * @example\n * ```ts\n * let popup = new Popup()\n * popup.addClassName('some-class')\n * ```\n */\n addClassName(className: string) {\n if (this._container) {\n this._container.classList.add(className);\n }\n return this;\n }\n\n /**\n * Removes a CSS class from the popup container element.\n *\n * @param className - Non-empty string with CSS class name to remove from popup container\n *\n * @example\n * ```ts\n * let popup = new Popup()\n * popup.removeClassName('some-class')\n * ```\n */\n removeClassName(className: string) {\n if (this._container) {\n this._container.classList.remove(className);\n }\n return this;\n }\n\n /**\n * Sets the popup's offset.\n *\n * @param offset - Sets the popup's offset.\n */\n setOffset (offset?: Offset): this {\n this.options.offset = offset;\n this._update();\n return this;\n }\n\n /**\n * Add or remove the given CSS class on the popup container, depending on whether the container currently has that class.\n *\n * @param className - Non-empty string with CSS class name to add/remove\n *\n * @returns if the class was removed return false, if class was added, then return true, undefined if there is no container\n *\n * @example\n * ```ts\n * let popup = new Popup()\n * popup.toggleClassName('toggleClass')\n * ```\n */\n toggleClassName(className: string): boolean | undefined {\n if (this._container) {\n return this._container.classList.toggle(className);\n }\n }\n\n /**\n * Set the option to allow subpixel positioning of the popup by passing a boolean\n *\n * @param value - When boolean is true, subpixel positioning is enabled for the popup.\n *\n * @example\n * ```ts\n * let popup = new Popup()\n * popup.setSubpixelPositioning(true);\n * ```\n */\n setSubpixelPositioning(value: boolean) {\n this.options.subpixelPositioning = value;\n }\n\n _createCloseButton() {\n if (this.options.closeButton) {\n this._closeButton = DOM.create('button', 'maplibregl-popup-close-button', this._content);\n this._closeButton.type = 'button';\n this._closeButton.innerHTML = '×';\n this._closeButton.addEventListener('click', this._onClose);\n }\n }\n\n _onMouseUp = (event: MapMouseEvent) => {\n this._update(event.point);\n };\n\n _onMouseMove = (event: MapMouseEvent) => {\n this._update(event.point);\n };\n\n _onDrag = (event: MapMouseEvent) => {\n this._update(event.point);\n };\n\n _update = (cursor?: Point) => {\n const hasPosition = this._lngLat || this._trackPointer;\n\n if (!this._map || !hasPosition || !this._content) { return; }\n\n if (!this._container) {\n this._container = DOM.create('div', 'maplibregl-popup', this._map.getContainer());\n this._tip = DOM.create('div', 'maplibregl-popup-tip', this._container);\n this._container.appendChild(this._content);\n if (this.options.className) {\n for (const name of this.options.className.split(' ')) {\n this._container.classList.add(name);\n }\n }\n\n if (this._closeButton) {\n this._closeButton.setAttribute('aria-label', this._map._getUIString('Popup.Close'));\n }\n\n if (this._trackPointer) {\n this._container.classList.add('maplibregl-popup-track-pointer');\n }\n }\n\n if (this.options.maxWidth && this._container.style.maxWidth !== this.options.maxWidth) {\n this._container.style.maxWidth = this.options.maxWidth;\n }\n\n if (this._map.transform.renderWorldCopies && !this._trackPointer) {\n this._lngLat = smartWrap(this._lngLat, this._flatPos, this._map.transform);\n } else {\n this._lngLat = this._lngLat?.wrap();\n }\n\n if (this._trackPointer && !cursor) return;\n\n const pos = this._flatPos = this._pos = this._trackPointer && cursor ? cursor : this._map.project(this._lngLat);\n if (this._map.terrain) {\n // flat position is saved because smartWrap needs non-elevated points\n this._flatPos = this._trackPointer && cursor ? cursor : this._map.transform.locationPoint(this._lngLat);\n }\n\n let anchor = this.options.anchor;\n const offset = normalizeOffset(this.options.offset);\n\n if (!anchor) {\n const width = this._container.offsetWidth;\n const height = this._container.offsetHeight;\n let anchorComponents;\n\n if (pos.y + offset.bottom.y < height) {\n anchorComponents = ['top'];\n } else if (pos.y > this._map.transform.height - height) {\n anchorComponents = ['bottom'];\n } else {\n anchorComponents = [];\n }\n\n if (pos.x < width / 2) {\n anchorComponents.push('left');\n } else if (pos.x > this._map.transform.width - width / 2) {\n anchorComponents.push('right');\n }\n\n if (anchorComponents.length === 0) {\n anchor = 'bottom';\n } else {\n anchor = (anchorComponents.join('-') as any);\n }\n }\n\n let offsetedPos = pos.add(offset[anchor]);\n\n if (!this.options.subpixelPositioning) {\n offsetedPos = offsetedPos.round();\n }\n\n DOM.setTransform(this._container, `${anchorTranslate[anchor]} translate(${offsetedPos.x}px,${offsetedPos.y}px)`);\n applyAnchorClass(this._container, anchor, 'popup');\n };\n\n _focusFirstElement() {\n if (!this.options.focusAfterOpen || !this._container) return;\n\n const firstFocusable = this._container.querySelector(focusQuerySelector) as HTMLElement;\n\n if (firstFocusable) firstFocusable.focus();\n }\n\n _onClose = () => {\n this.remove();\n };\n}\n\nfunction normalizeOffset(offset?: Offset | null) {\n if (!offset) {\n return normalizeOffset(new Point(0, 0));\n\n } else if (typeof offset === 'number') {\n // input specifies a radius from which to calculate offsets at all positions\n const cornerOffset = Math.round(Math.abs(offset) / Math.SQRT2);\n return {\n 'center': new Point(0, 0),\n 'top': new Point(0, offset),\n 'top-left': new Point(cornerOffset, cornerOffset),\n 'top-right': new Point(-cornerOffset, cornerOffset),\n 'bottom': new Point(0, -offset),\n 'bottom-left': new Point(cornerOffset, -cornerOffset),\n 'bottom-right': new Point(-cornerOffset, -cornerOffset),\n 'left': new Point(offset, 0),\n 'right': new Point(-offset, 0)\n };\n\n } else if (offset instanceof Point || Array.isArray(offset)) {\n // input specifies a single offset to be applied to all positions\n const convertedOffset = Point.convert(offset);\n return {\n 'center': convertedOffset,\n 'top': convertedOffset,\n 'top-left': convertedOffset,\n 'top-right': convertedOffset,\n 'bottom': convertedOffset,\n 'bottom-left': convertedOffset,\n 'bottom-right': convertedOffset,\n 'left': convertedOffset,\n 'right': convertedOffset\n };\n\n } else {\n // input specifies an offset per position\n return {\n 'center': Point.convert(offset['center'] || [0, 0]),\n 'top': Point.convert(offset['top'] || [0, 0]),\n 'top-left': Point.convert(offset['top-left'] || [0, 0]),\n 'top-right': Point.convert(offset['top-right'] || [0, 0]),\n 'bottom': Point.convert(offset['bottom'] || [0, 0]),\n 'bottom-left': Point.convert(offset['bottom-left'] || [0, 0]),\n 'bottom-right': Point.convert(offset['bottom-right'] || [0, 0]),\n 'left': Point.convert(offset['left'] || [0, 0]),\n 'right': Point.convert(offset['right'] || [0, 0])\n };\n }\n}\n","import packageJSON from '../package.json' with {type: 'json'};\nimport {Map} from './ui/map';\nimport {NavigationControl} from './ui/control/navigation_control';\nimport {GeolocateControl} from './ui/control/geolocate_control';\nimport {AttributionControl} from './ui/control/attribution_control';\nimport {LogoControl} from './ui/control/logo_control';\nimport {ScaleControl} from './ui/control/scale_control';\nimport {FullscreenControl} from './ui/control/fullscreen_control';\nimport {TerrainControl} from './ui/control/terrain_control';\nimport {Popup} from './ui/popup';\nimport {Marker} from './ui/marker';\nimport {Style} from './style/style';\nimport {LngLat, LngLatLike} from './geo/lng_lat';\nimport {LngLatBounds, LngLatBoundsLike} from './geo/lng_lat_bounds';\nimport Point from '@mapbox/point-geometry';\nimport {MercatorCoordinate} from './geo/mercator_coordinate';\nimport {Evented} from './util/evented';\nimport {config} from './util/config';\nimport {rtlMainThreadPluginFactory} from './source/rtl_text_plugin_main_thread';\nimport {WorkerPool} from './util/worker_pool';\nimport {prewarm, clearPrewarmedResources} from './util/global_worker_pool';\nimport {AJAXError} from './util/ajax';\nimport {GeoJSONSource} from './source/geojson_source';\nimport {CanvasSource, CanvasSourceSpecification} from './source/canvas_source';\nimport {ImageSource} from './source/image_source';\nimport {RasterDEMTileSource} from './source/raster_dem_tile_source';\nimport {RasterTileSource} from './source/raster_tile_source';\nimport {VectorTileSource} from './source/vector_tile_source';\nimport {VideoSource} from './source/video_source';\nimport {Source, addSourceType} from './source/source';\nimport {addProtocol, removeProtocol} from './source/protocol_crud';\nimport {getGlobalDispatcher} from './util/dispatcher';\nimport {IControl} from './ui/control/control';\nimport {EdgeInsets, PaddingOptions} from './geo/edge_insets';\nimport {MapTerrainEvent, MapStyleImageMissingEvent, MapStyleDataEvent, MapSourceDataEvent, MapLibreZoomEvent, MapLibreEvent, MapLayerTouchEvent, MapLayerMouseEvent, MapLayerEventType, MapEventType, MapDataEvent, MapContextEvent, MapWheelEvent, MapTouchEvent, MapMouseEvent} from './ui/events';\nimport {BoxZoomHandler} from './ui/handler/box_zoom';\nimport {DragRotateHandler} from './ui/handler/shim/drag_rotate';\nimport {DragPanHandler} from './ui/handler/shim/drag_pan';\nimport {ScrollZoomHandler} from './ui/handler/scroll_zoom';\nimport {TwoFingersTouchZoomRotateHandler} from './ui/handler/shim/two_fingers_touch';\nimport {CustomLayerInterface} from './style/style_layer/custom_style_layer';\nimport {PointLike} from './ui/camera';\nimport {Hash} from './ui/hash';\nimport {CooperativeGesturesHandler} from './ui/handler/cooperative_gestures';\nimport {DoubleClickZoomHandler} from './ui/handler/shim/dblclick_zoom';\nimport {KeyboardHandler} from './ui/handler/keyboard';\nimport {TwoFingersTouchPitchHandler, TwoFingersTouchRotateHandler, TwoFingersTouchZoomHandler} from './ui/handler/two_fingers_touch';\nimport {MessageType} from './util/actor_messages';\nconst version = packageJSON.version;\n\nexport type * from '@maplibre/maplibre-gl-style-spec';\n\n/**\n * Sets the map's [RTL text plugin](https://www.mapbox.com/mapbox-gl-js/plugins/#mapbox-gl-rtl-text).\n * Necessary for supporting the Arabic and Hebrew languages, which are written right-to-left.\n *\n * @param pluginURL - URL pointing to the Mapbox RTL text plugin source.\n * @param lazy - If set to `true`, maplibre will defer loading the plugin until rtl text is encountered,\n * rtl text will then be rendered only after the plugin finishes loading.\n * @example\n * ```ts\n * setRTLTextPlugin('https://unpkg.com/@mapbox/mapbox-gl-rtl-text@0.2.3/mapbox-gl-rtl-text.js', false);\n * ```\n * @see [Add support for right-to-left scripts](https://maplibre.org/maplibre-gl-js/docs/examples/mapbox-gl-rtl-text/)\n */\nfunction setRTLTextPlugin(pluginURL: string, lazy: boolean): Promise {\n return rtlMainThreadPluginFactory().setRTLTextPlugin(pluginURL, lazy);\n}\n/**\n * Gets the map's [RTL text plugin](https://www.mapbox.com/mapbox-gl-js/plugins/#mapbox-gl-rtl-text) status.\n * The status can be `unavailable` (i.e. not requested or removed), `loading`, `loaded` or `error`.\n * If the status is `loaded` and the plugin is requested again, an error will be thrown.\n *\n * @example\n * ```ts\n * const pluginStatus = getRTLTextPluginStatus();\n * ```\n */\nfunction getRTLTextPluginStatus(): string {\n return rtlMainThreadPluginFactory().getRTLTextPluginStatus();\n}\n/**\n * Returns the package version of the library\n * @returns Package version of the library\n */\nfunction getVersion() { return version; }\n/**\n * Gets the number of web workers instantiated on a page with GL JS maps.\n * By default, workerCount is 1 except for Safari browser where it is set to half the number of CPU cores (capped at 3).\n * Make sure to set this property before creating any map instances for it to have effect.\n *\n * @returns Number of workers currently configured.\n * @example\n * ```ts\n * const workerCount = getWorkerCount()\n * ```\n */\nfunction getWorkerCount() { return WorkerPool.workerCount; }\n/**\n * Sets the number of web workers instantiated on a page with GL JS maps.\n * By default, workerCount is 1 except for Safari browser where it is set to half the number of CPU cores (capped at 3).\n * Make sure to set this property before creating any map instances for it to have effect.\n *\n * @example\n * ```ts\n * setWorkerCount(2);\n * ```\n */\nfunction setWorkerCount(count: number) { WorkerPool.workerCount = count; }\n/**\n * Gets and sets the maximum number of images (raster tiles, sprites, icons) to load in parallel,\n * which affects performance in raster-heavy maps. 16 by default.\n *\n * @returns Number of parallel requests currently configured.\n * @example\n * ```ts\n * getMaxParallelImageRequests();\n * ```\n */\nfunction getMaxParallelImageRequests() { return config.MAX_PARALLEL_IMAGE_REQUESTS; }\n/**\n * Sets the maximum number of images (raster tiles, sprites, icons) to load in parallel,\n * which affects performance in raster-heavy maps. 16 by default.\n *\n * @example\n * ```ts\n * setMaxParallelImageRequests(10);\n * ```\n */\nfunction setMaxParallelImageRequests(numRequests: number) { config.MAX_PARALLEL_IMAGE_REQUESTS = numRequests; }\n/**\n * Gets the worker url\n * @returns The worker url\n */\nfunction getWorkerUrl() { return config.WORKER_URL; }\n/**\n * Sets the worker url\n */\nfunction setWorkerUrl(value: string) { config.WORKER_URL = value; }\n/**\n * Allows loading javascript code in the worker thread.\n * *Note* that since this is using some very internal classes and flows it is considered experimental and can break at any point.\n *\n * It can be useful for the following examples:\n * 1. Using `self.addProtocol` in the worker thread - note that you might need to also register the protocol on the main thread.\n * 2. Using `self.registerWorkerSource(workerSource: WorkerSource)` to register a worker source, which should come with `addSourceType` usually.\n * 3. using `self.actor.registerMessageHandler` to override some internal worker operations\n * @param workerUrl - the worker url e.g. a url of a javascript file to load in the worker\n * @returns\n *\n * @example\n * ```ts\n * // below is an example of sending a js file to the worker to load the method there\n * // Note that you'll need to call the global function `addProtocol` in the worker to register the protocol there.\n * // add-protocol-worker.js\n * async function loadFn(params, abortController) {\n * const t = await fetch(`https://${params.url.split(\"://\")[1]}`);\n * if (t.status == 200) {\n * const buffer = await t.arrayBuffer();\n * return {data: buffer}\n * } else {\n * throw new Error(`Tile fetch error: ${t.statusText}`);\n * }\n * }\n * self.addProtocol('custom', loadFn);\n *\n * // main.js\n * importScriptInWorkers('add-protocol-worker.js');\n * ```\n */\nfunction importScriptInWorkers(workerUrl: string) { return getGlobalDispatcher().broadcast(MessageType.importScript, workerUrl); }\n\nexport {\n Map,\n NavigationControl,\n GeolocateControl,\n AttributionControl,\n LogoControl,\n ScaleControl,\n FullscreenControl,\n TerrainControl,\n Hash,\n Popup,\n Marker,\n Style,\n LngLat,\n LngLatBounds,\n Point,\n MercatorCoordinate,\n Evented,\n AJAXError,\n config,\n CanvasSource,\n GeoJSONSource,\n ImageSource,\n RasterDEMTileSource,\n RasterTileSource,\n VectorTileSource,\n VideoSource,\n EdgeInsets,\n BoxZoomHandler,\n DragRotateHandler,\n DragPanHandler,\n ScrollZoomHandler,\n TwoFingersTouchZoomRotateHandler,\n CooperativeGesturesHandler,\n DoubleClickZoomHandler,\n KeyboardHandler,\n TwoFingersTouchZoomHandler,\n TwoFingersTouchRotateHandler,\n TwoFingersTouchPitchHandler,\n MapWheelEvent,\n MapTouchEvent,\n MapMouseEvent,\n type IControl,\n type CustomLayerInterface,\n type CanvasSourceSpecification,\n type PaddingOptions,\n type LngLatLike,\n type PointLike,\n type LngLatBoundsLike,\n type Source,\n type MapTerrainEvent,\n type MapStyleImageMissingEvent,\n type MapStyleDataEvent,\n type MapSourceDataEvent,\n type MapLibreZoomEvent,\n type MapLibreEvent,\n type MapLayerTouchEvent,\n type MapLayerMouseEvent,\n type MapLayerEventType,\n type MapEventType,\n type MapDataEvent,\n type MapContextEvent,\n setRTLTextPlugin,\n getRTLTextPluginStatus,\n prewarm,\n clearPrewarmedResources,\n getVersion,\n getWorkerCount,\n setWorkerCount,\n getMaxParallelImageRequests,\n setMaxParallelImageRequests,\n getWorkerUrl,\n setWorkerUrl,\n addProtocol,\n removeProtocol,\n addSourceType,\n importScriptInWorkers\n};\n","//\n// Our custom intro provides a specialized \"define()\" function, called by the\n// AMD modules below, that sets up the worker blob URL and then executes the\n// main module, storing its exported value as 'maplibregl'\n\n// The three \"chunks\" imported here are produced by a first Rollup pass,\n// which outputs them as AMD modules.\n\n// Shared dependencies\nimport '../../staging/maplibregl/shared';\n\n// Worker and its unique dependencies\n// When this wrapper function is passed to our custom define() in build/rollup/bundle_prelude.js,\n// it gets stringified, together with the shared wrapper (using\n// Function.toString()), and the resulting string of code is made into a\n// Blob URL that gets used by the main module to create the web workers.\nimport '../../staging/maplibregl/worker';\n\n// Main module and its dependencies\nimport '../../staging/maplibregl/index';\n\nexport default maplibregl;\n","// This file is autogenerated. It's used to publish CJS to npm.\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.tinycolor = factory());\n})(this, (function () { 'use strict';\n\n function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, _typeof(obj);\n }\n\n // https://github.com/bgrins/TinyColor\n // Brian Grinstead, MIT License\n\n var trimLeft = /^\\s+/;\n var trimRight = /\\s+$/;\n function tinycolor(color, opts) {\n color = color ? color : \"\";\n opts = opts || {};\n\n // If input is already a tinycolor, return itself\n if (color instanceof tinycolor) {\n return color;\n }\n // If we are called as a function, call using new instead\n if (!(this instanceof tinycolor)) {\n return new tinycolor(color, opts);\n }\n var rgb = inputToRGB(color);\n this._originalInput = color, this._r = rgb.r, this._g = rgb.g, this._b = rgb.b, this._a = rgb.a, this._roundA = Math.round(100 * this._a) / 100, this._format = opts.format || rgb.format;\n this._gradientType = opts.gradientType;\n\n // Don't let the range of [0,255] come back in [0,1].\n // Potentially lose a little bit of precision here, but will fix issues where\n // .5 gets interpreted as half of the total, instead of half of 1\n // If it was supposed to be 128, this was already taken care of by `inputToRgb`\n if (this._r < 1) this._r = Math.round(this._r);\n if (this._g < 1) this._g = Math.round(this._g);\n if (this._b < 1) this._b = Math.round(this._b);\n this._ok = rgb.ok;\n }\n tinycolor.prototype = {\n isDark: function isDark() {\n return this.getBrightness() < 128;\n },\n isLight: function isLight() {\n return !this.isDark();\n },\n isValid: function isValid() {\n return this._ok;\n },\n getOriginalInput: function getOriginalInput() {\n return this._originalInput;\n },\n getFormat: function getFormat() {\n return this._format;\n },\n getAlpha: function getAlpha() {\n return this._a;\n },\n getBrightness: function getBrightness() {\n //http://www.w3.org/TR/AERT#color-contrast\n var rgb = this.toRgb();\n return (rgb.r * 299 + rgb.g * 587 + rgb.b * 114) / 1000;\n },\n getLuminance: function getLuminance() {\n //http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef\n var rgb = this.toRgb();\n var RsRGB, GsRGB, BsRGB, R, G, B;\n RsRGB = rgb.r / 255;\n GsRGB = rgb.g / 255;\n BsRGB = rgb.b / 255;\n if (RsRGB <= 0.03928) R = RsRGB / 12.92;else R = Math.pow((RsRGB + 0.055) / 1.055, 2.4);\n if (GsRGB <= 0.03928) G = GsRGB / 12.92;else G = Math.pow((GsRGB + 0.055) / 1.055, 2.4);\n if (BsRGB <= 0.03928) B = BsRGB / 12.92;else B = Math.pow((BsRGB + 0.055) / 1.055, 2.4);\n return 0.2126 * R + 0.7152 * G + 0.0722 * B;\n },\n setAlpha: function setAlpha(value) {\n this._a = boundAlpha(value);\n this._roundA = Math.round(100 * this._a) / 100;\n return this;\n },\n toHsv: function toHsv() {\n var hsv = rgbToHsv(this._r, this._g, this._b);\n return {\n h: hsv.h * 360,\n s: hsv.s,\n v: hsv.v,\n a: this._a\n };\n },\n toHsvString: function toHsvString() {\n var hsv = rgbToHsv(this._r, this._g, this._b);\n var h = Math.round(hsv.h * 360),\n s = Math.round(hsv.s * 100),\n v = Math.round(hsv.v * 100);\n return this._a == 1 ? \"hsv(\" + h + \", \" + s + \"%, \" + v + \"%)\" : \"hsva(\" + h + \", \" + s + \"%, \" + v + \"%, \" + this._roundA + \")\";\n },\n toHsl: function toHsl() {\n var hsl = rgbToHsl(this._r, this._g, this._b);\n return {\n h: hsl.h * 360,\n s: hsl.s,\n l: hsl.l,\n a: this._a\n };\n },\n toHslString: function toHslString() {\n var hsl = rgbToHsl(this._r, this._g, this._b);\n var h = Math.round(hsl.h * 360),\n s = Math.round(hsl.s * 100),\n l = Math.round(hsl.l * 100);\n return this._a == 1 ? \"hsl(\" + h + \", \" + s + \"%, \" + l + \"%)\" : \"hsla(\" + h + \", \" + s + \"%, \" + l + \"%, \" + this._roundA + \")\";\n },\n toHex: function toHex(allow3Char) {\n return rgbToHex(this._r, this._g, this._b, allow3Char);\n },\n toHexString: function toHexString(allow3Char) {\n return \"#\" + this.toHex(allow3Char);\n },\n toHex8: function toHex8(allow4Char) {\n return rgbaToHex(this._r, this._g, this._b, this._a, allow4Char);\n },\n toHex8String: function toHex8String(allow4Char) {\n return \"#\" + this.toHex8(allow4Char);\n },\n toRgb: function toRgb() {\n return {\n r: Math.round(this._r),\n g: Math.round(this._g),\n b: Math.round(this._b),\n a: this._a\n };\n },\n toRgbString: function toRgbString() {\n return this._a == 1 ? \"rgb(\" + Math.round(this._r) + \", \" + Math.round(this._g) + \", \" + Math.round(this._b) + \")\" : \"rgba(\" + Math.round(this._r) + \", \" + Math.round(this._g) + \", \" + Math.round(this._b) + \", \" + this._roundA + \")\";\n },\n toPercentageRgb: function toPercentageRgb() {\n return {\n r: Math.round(bound01(this._r, 255) * 100) + \"%\",\n g: Math.round(bound01(this._g, 255) * 100) + \"%\",\n b: Math.round(bound01(this._b, 255) * 100) + \"%\",\n a: this._a\n };\n },\n toPercentageRgbString: function toPercentageRgbString() {\n return this._a == 1 ? \"rgb(\" + Math.round(bound01(this._r, 255) * 100) + \"%, \" + Math.round(bound01(this._g, 255) * 100) + \"%, \" + Math.round(bound01(this._b, 255) * 100) + \"%)\" : \"rgba(\" + Math.round(bound01(this._r, 255) * 100) + \"%, \" + Math.round(bound01(this._g, 255) * 100) + \"%, \" + Math.round(bound01(this._b, 255) * 100) + \"%, \" + this._roundA + \")\";\n },\n toName: function toName() {\n if (this._a === 0) {\n return \"transparent\";\n }\n if (this._a < 1) {\n return false;\n }\n return hexNames[rgbToHex(this._r, this._g, this._b, true)] || false;\n },\n toFilter: function toFilter(secondColor) {\n var hex8String = \"#\" + rgbaToArgbHex(this._r, this._g, this._b, this._a);\n var secondHex8String = hex8String;\n var gradientType = this._gradientType ? \"GradientType = 1, \" : \"\";\n if (secondColor) {\n var s = tinycolor(secondColor);\n secondHex8String = \"#\" + rgbaToArgbHex(s._r, s._g, s._b, s._a);\n }\n return \"progid:DXImageTransform.Microsoft.gradient(\" + gradientType + \"startColorstr=\" + hex8String + \",endColorstr=\" + secondHex8String + \")\";\n },\n toString: function toString(format) {\n var formatSet = !!format;\n format = format || this._format;\n var formattedString = false;\n var hasAlpha = this._a < 1 && this._a >= 0;\n var needsAlphaFormat = !formatSet && hasAlpha && (format === \"hex\" || format === \"hex6\" || format === \"hex3\" || format === \"hex4\" || format === \"hex8\" || format === \"name\");\n if (needsAlphaFormat) {\n // Special case for \"transparent\", all other non-alpha formats\n // will return rgba when there is transparency.\n if (format === \"name\" && this._a === 0) {\n return this.toName();\n }\n return this.toRgbString();\n }\n if (format === \"rgb\") {\n formattedString = this.toRgbString();\n }\n if (format === \"prgb\") {\n formattedString = this.toPercentageRgbString();\n }\n if (format === \"hex\" || format === \"hex6\") {\n formattedString = this.toHexString();\n }\n if (format === \"hex3\") {\n formattedString = this.toHexString(true);\n }\n if (format === \"hex4\") {\n formattedString = this.toHex8String(true);\n }\n if (format === \"hex8\") {\n formattedString = this.toHex8String();\n }\n if (format === \"name\") {\n formattedString = this.toName();\n }\n if (format === \"hsl\") {\n formattedString = this.toHslString();\n }\n if (format === \"hsv\") {\n formattedString = this.toHsvString();\n }\n return formattedString || this.toHexString();\n },\n clone: function clone() {\n return tinycolor(this.toString());\n },\n _applyModification: function _applyModification(fn, args) {\n var color = fn.apply(null, [this].concat([].slice.call(args)));\n this._r = color._r;\n this._g = color._g;\n this._b = color._b;\n this.setAlpha(color._a);\n return this;\n },\n lighten: function lighten() {\n return this._applyModification(_lighten, arguments);\n },\n brighten: function brighten() {\n return this._applyModification(_brighten, arguments);\n },\n darken: function darken() {\n return this._applyModification(_darken, arguments);\n },\n desaturate: function desaturate() {\n return this._applyModification(_desaturate, arguments);\n },\n saturate: function saturate() {\n return this._applyModification(_saturate, arguments);\n },\n greyscale: function greyscale() {\n return this._applyModification(_greyscale, arguments);\n },\n spin: function spin() {\n return this._applyModification(_spin, arguments);\n },\n _applyCombination: function _applyCombination(fn, args) {\n return fn.apply(null, [this].concat([].slice.call(args)));\n },\n analogous: function analogous() {\n return this._applyCombination(_analogous, arguments);\n },\n complement: function complement() {\n return this._applyCombination(_complement, arguments);\n },\n monochromatic: function monochromatic() {\n return this._applyCombination(_monochromatic, arguments);\n },\n splitcomplement: function splitcomplement() {\n return this._applyCombination(_splitcomplement, arguments);\n },\n // Disabled until https://github.com/bgrins/TinyColor/issues/254\n // polyad: function (number) {\n // return this._applyCombination(polyad, [number]);\n // },\n triad: function triad() {\n return this._applyCombination(polyad, [3]);\n },\n tetrad: function tetrad() {\n return this._applyCombination(polyad, [4]);\n }\n };\n\n // If input is an object, force 1 into \"1.0\" to handle ratios properly\n // String input requires \"1.0\" as input, so 1 will be treated as 1\n tinycolor.fromRatio = function (color, opts) {\n if (_typeof(color) == \"object\") {\n var newColor = {};\n for (var i in color) {\n if (color.hasOwnProperty(i)) {\n if (i === \"a\") {\n newColor[i] = color[i];\n } else {\n newColor[i] = convertToPercentage(color[i]);\n }\n }\n }\n color = newColor;\n }\n return tinycolor(color, opts);\n };\n\n // Given a string or object, convert that input to RGB\n // Possible string inputs:\n //\n // \"red\"\n // \"#f00\" or \"f00\"\n // \"#ff0000\" or \"ff0000\"\n // \"#ff000000\" or \"ff000000\"\n // \"rgb 255 0 0\" or \"rgb (255, 0, 0)\"\n // \"rgb 1.0 0 0\" or \"rgb (1, 0, 0)\"\n // \"rgba (255, 0, 0, 1)\" or \"rgba 255, 0, 0, 1\"\n // \"rgba (1.0, 0, 0, 1)\" or \"rgba 1.0, 0, 0, 1\"\n // \"hsl(0, 100%, 50%)\" or \"hsl 0 100% 50%\"\n // \"hsla(0, 100%, 50%, 1)\" or \"hsla 0 100% 50%, 1\"\n // \"hsv(0, 100%, 100%)\" or \"hsv 0 100% 100%\"\n //\n function inputToRGB(color) {\n var rgb = {\n r: 0,\n g: 0,\n b: 0\n };\n var a = 1;\n var s = null;\n var v = null;\n var l = null;\n var ok = false;\n var format = false;\n if (typeof color == \"string\") {\n color = stringInputToObject(color);\n }\n if (_typeof(color) == \"object\") {\n if (isValidCSSUnit(color.r) && isValidCSSUnit(color.g) && isValidCSSUnit(color.b)) {\n rgb = rgbToRgb(color.r, color.g, color.b);\n ok = true;\n format = String(color.r).substr(-1) === \"%\" ? \"prgb\" : \"rgb\";\n } else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.v)) {\n s = convertToPercentage(color.s);\n v = convertToPercentage(color.v);\n rgb = hsvToRgb(color.h, s, v);\n ok = true;\n format = \"hsv\";\n } else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.l)) {\n s = convertToPercentage(color.s);\n l = convertToPercentage(color.l);\n rgb = hslToRgb(color.h, s, l);\n ok = true;\n format = \"hsl\";\n }\n if (color.hasOwnProperty(\"a\")) {\n a = color.a;\n }\n }\n a = boundAlpha(a);\n return {\n ok: ok,\n format: color.format || format,\n r: Math.min(255, Math.max(rgb.r, 0)),\n g: Math.min(255, Math.max(rgb.g, 0)),\n b: Math.min(255, Math.max(rgb.b, 0)),\n a: a\n };\n }\n\n // Conversion Functions\n // --------------------\n\n // `rgbToHsl`, `rgbToHsv`, `hslToRgb`, `hsvToRgb` modified from:\n // \n\n // `rgbToRgb`\n // Handle bounds / percentage checking to conform to CSS color spec\n // \n // *Assumes:* r, g, b in [0, 255] or [0, 1]\n // *Returns:* { r, g, b } in [0, 255]\n function rgbToRgb(r, g, b) {\n return {\n r: bound01(r, 255) * 255,\n g: bound01(g, 255) * 255,\n b: bound01(b, 255) * 255\n };\n }\n\n // `rgbToHsl`\n // Converts an RGB color value to HSL.\n // *Assumes:* r, g, and b are contained in [0, 255] or [0, 1]\n // *Returns:* { h, s, l } in [0,1]\n function rgbToHsl(r, g, b) {\n r = bound01(r, 255);\n g = bound01(g, 255);\n b = bound01(b, 255);\n var max = Math.max(r, g, b),\n min = Math.min(r, g, b);\n var h,\n s,\n l = (max + min) / 2;\n if (max == min) {\n h = s = 0; // achromatic\n } else {\n var d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n switch (max) {\n case r:\n h = (g - b) / d + (g < b ? 6 : 0);\n break;\n case g:\n h = (b - r) / d + 2;\n break;\n case b:\n h = (r - g) / d + 4;\n break;\n }\n h /= 6;\n }\n return {\n h: h,\n s: s,\n l: l\n };\n }\n\n // `hslToRgb`\n // Converts an HSL color value to RGB.\n // *Assumes:* h is contained in [0, 1] or [0, 360] and s and l are contained [0, 1] or [0, 100]\n // *Returns:* { r, g, b } in the set [0, 255]\n function hslToRgb(h, s, l) {\n var r, g, b;\n h = bound01(h, 360);\n s = bound01(s, 100);\n l = bound01(l, 100);\n function hue2rgb(p, q, t) {\n if (t < 0) t += 1;\n if (t > 1) t -= 1;\n if (t < 1 / 6) return p + (q - p) * 6 * t;\n if (t < 1 / 2) return q;\n if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n }\n if (s === 0) {\n r = g = b = l; // achromatic\n } else {\n var q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n var p = 2 * l - q;\n r = hue2rgb(p, q, h + 1 / 3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1 / 3);\n }\n return {\n r: r * 255,\n g: g * 255,\n b: b * 255\n };\n }\n\n // `rgbToHsv`\n // Converts an RGB color value to HSV\n // *Assumes:* r, g, and b are contained in the set [0, 255] or [0, 1]\n // *Returns:* { h, s, v } in [0,1]\n function rgbToHsv(r, g, b) {\n r = bound01(r, 255);\n g = bound01(g, 255);\n b = bound01(b, 255);\n var max = Math.max(r, g, b),\n min = Math.min(r, g, b);\n var h,\n s,\n v = max;\n var d = max - min;\n s = max === 0 ? 0 : d / max;\n if (max == min) {\n h = 0; // achromatic\n } else {\n switch (max) {\n case r:\n h = (g - b) / d + (g < b ? 6 : 0);\n break;\n case g:\n h = (b - r) / d + 2;\n break;\n case b:\n h = (r - g) / d + 4;\n break;\n }\n h /= 6;\n }\n return {\n h: h,\n s: s,\n v: v\n };\n }\n\n // `hsvToRgb`\n // Converts an HSV color value to RGB.\n // *Assumes:* h is contained in [0, 1] or [0, 360] and s and v are contained in [0, 1] or [0, 100]\n // *Returns:* { r, g, b } in the set [0, 255]\n function hsvToRgb(h, s, v) {\n h = bound01(h, 360) * 6;\n s = bound01(s, 100);\n v = bound01(v, 100);\n var i = Math.floor(h),\n f = h - i,\n p = v * (1 - s),\n q = v * (1 - f * s),\n t = v * (1 - (1 - f) * s),\n mod = i % 6,\n r = [v, q, p, p, t, v][mod],\n g = [t, v, v, q, p, p][mod],\n b = [p, p, t, v, v, q][mod];\n return {\n r: r * 255,\n g: g * 255,\n b: b * 255\n };\n }\n\n // `rgbToHex`\n // Converts an RGB color to hex\n // Assumes r, g, and b are contained in the set [0, 255]\n // Returns a 3 or 6 character hex\n function rgbToHex(r, g, b, allow3Char) {\n var hex = [pad2(Math.round(r).toString(16)), pad2(Math.round(g).toString(16)), pad2(Math.round(b).toString(16))];\n\n // Return a 3 character hex if possible\n if (allow3Char && hex[0].charAt(0) == hex[0].charAt(1) && hex[1].charAt(0) == hex[1].charAt(1) && hex[2].charAt(0) == hex[2].charAt(1)) {\n return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0);\n }\n return hex.join(\"\");\n }\n\n // `rgbaToHex`\n // Converts an RGBA color plus alpha transparency to hex\n // Assumes r, g, b are contained in the set [0, 255] and\n // a in [0, 1]. Returns a 4 or 8 character rgba hex\n function rgbaToHex(r, g, b, a, allow4Char) {\n var hex = [pad2(Math.round(r).toString(16)), pad2(Math.round(g).toString(16)), pad2(Math.round(b).toString(16)), pad2(convertDecimalToHex(a))];\n\n // Return a 4 character hex if possible\n if (allow4Char && hex[0].charAt(0) == hex[0].charAt(1) && hex[1].charAt(0) == hex[1].charAt(1) && hex[2].charAt(0) == hex[2].charAt(1) && hex[3].charAt(0) == hex[3].charAt(1)) {\n return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0) + hex[3].charAt(0);\n }\n return hex.join(\"\");\n }\n\n // `rgbaToArgbHex`\n // Converts an RGBA color to an ARGB Hex8 string\n // Rarely used, but required for \"toFilter()\"\n function rgbaToArgbHex(r, g, b, a) {\n var hex = [pad2(convertDecimalToHex(a)), pad2(Math.round(r).toString(16)), pad2(Math.round(g).toString(16)), pad2(Math.round(b).toString(16))];\n return hex.join(\"\");\n }\n\n // `equals`\n // Can be called with any tinycolor input\n tinycolor.equals = function (color1, color2) {\n if (!color1 || !color2) return false;\n return tinycolor(color1).toRgbString() == tinycolor(color2).toRgbString();\n };\n tinycolor.random = function () {\n return tinycolor.fromRatio({\n r: Math.random(),\n g: Math.random(),\n b: Math.random()\n });\n };\n\n // Modification Functions\n // ----------------------\n // Thanks to less.js for some of the basics here\n // \n\n function _desaturate(color, amount) {\n amount = amount === 0 ? 0 : amount || 10;\n var hsl = tinycolor(color).toHsl();\n hsl.s -= amount / 100;\n hsl.s = clamp01(hsl.s);\n return tinycolor(hsl);\n }\n function _saturate(color, amount) {\n amount = amount === 0 ? 0 : amount || 10;\n var hsl = tinycolor(color).toHsl();\n hsl.s += amount / 100;\n hsl.s = clamp01(hsl.s);\n return tinycolor(hsl);\n }\n function _greyscale(color) {\n return tinycolor(color).desaturate(100);\n }\n function _lighten(color, amount) {\n amount = amount === 0 ? 0 : amount || 10;\n var hsl = tinycolor(color).toHsl();\n hsl.l += amount / 100;\n hsl.l = clamp01(hsl.l);\n return tinycolor(hsl);\n }\n function _brighten(color, amount) {\n amount = amount === 0 ? 0 : amount || 10;\n var rgb = tinycolor(color).toRgb();\n rgb.r = Math.max(0, Math.min(255, rgb.r - Math.round(255 * -(amount / 100))));\n rgb.g = Math.max(0, Math.min(255, rgb.g - Math.round(255 * -(amount / 100))));\n rgb.b = Math.max(0, Math.min(255, rgb.b - Math.round(255 * -(amount / 100))));\n return tinycolor(rgb);\n }\n function _darken(color, amount) {\n amount = amount === 0 ? 0 : amount || 10;\n var hsl = tinycolor(color).toHsl();\n hsl.l -= amount / 100;\n hsl.l = clamp01(hsl.l);\n return tinycolor(hsl);\n }\n\n // Spin takes a positive or negative amount within [-360, 360] indicating the change of hue.\n // Values outside of this range will be wrapped into this range.\n function _spin(color, amount) {\n var hsl = tinycolor(color).toHsl();\n var hue = (hsl.h + amount) % 360;\n hsl.h = hue < 0 ? 360 + hue : hue;\n return tinycolor(hsl);\n }\n\n // Combination Functions\n // ---------------------\n // Thanks to jQuery xColor for some of the ideas behind these\n // \n\n function _complement(color) {\n var hsl = tinycolor(color).toHsl();\n hsl.h = (hsl.h + 180) % 360;\n return tinycolor(hsl);\n }\n function polyad(color, number) {\n if (isNaN(number) || number <= 0) {\n throw new Error(\"Argument to polyad must be a positive number\");\n }\n var hsl = tinycolor(color).toHsl();\n var result = [tinycolor(color)];\n var step = 360 / number;\n for (var i = 1; i < number; i++) {\n result.push(tinycolor({\n h: (hsl.h + i * step) % 360,\n s: hsl.s,\n l: hsl.l\n }));\n }\n return result;\n }\n function _splitcomplement(color) {\n var hsl = tinycolor(color).toHsl();\n var h = hsl.h;\n return [tinycolor(color), tinycolor({\n h: (h + 72) % 360,\n s: hsl.s,\n l: hsl.l\n }), tinycolor({\n h: (h + 216) % 360,\n s: hsl.s,\n l: hsl.l\n })];\n }\n function _analogous(color, results, slices) {\n results = results || 6;\n slices = slices || 30;\n var hsl = tinycolor(color).toHsl();\n var part = 360 / slices;\n var ret = [tinycolor(color)];\n for (hsl.h = (hsl.h - (part * results >> 1) + 720) % 360; --results;) {\n hsl.h = (hsl.h + part) % 360;\n ret.push(tinycolor(hsl));\n }\n return ret;\n }\n function _monochromatic(color, results) {\n results = results || 6;\n var hsv = tinycolor(color).toHsv();\n var h = hsv.h,\n s = hsv.s,\n v = hsv.v;\n var ret = [];\n var modification = 1 / results;\n while (results--) {\n ret.push(tinycolor({\n h: h,\n s: s,\n v: v\n }));\n v = (v + modification) % 1;\n }\n return ret;\n }\n\n // Utility Functions\n // ---------------------\n\n tinycolor.mix = function (color1, color2, amount) {\n amount = amount === 0 ? 0 : amount || 50;\n var rgb1 = tinycolor(color1).toRgb();\n var rgb2 = tinycolor(color2).toRgb();\n var p = amount / 100;\n var rgba = {\n r: (rgb2.r - rgb1.r) * p + rgb1.r,\n g: (rgb2.g - rgb1.g) * p + rgb1.g,\n b: (rgb2.b - rgb1.b) * p + rgb1.b,\n a: (rgb2.a - rgb1.a) * p + rgb1.a\n };\n return tinycolor(rgba);\n };\n\n // Readability Functions\n // ---------------------\n // false\n // tinycolor.isReadable(\"#000\", \"#111\",{level:\"AA\",size:\"large\"}) => false\n tinycolor.isReadable = function (color1, color2, wcag2) {\n var readability = tinycolor.readability(color1, color2);\n var wcag2Parms, out;\n out = false;\n wcag2Parms = validateWCAG2Parms(wcag2);\n switch (wcag2Parms.level + wcag2Parms.size) {\n case \"AAsmall\":\n case \"AAAlarge\":\n out = readability >= 4.5;\n break;\n case \"AAlarge\":\n out = readability >= 3;\n break;\n case \"AAAsmall\":\n out = readability >= 7;\n break;\n }\n return out;\n };\n\n // `mostReadable`\n // Given a base color and a list of possible foreground or background\n // colors for that base, returns the most readable color.\n // Optionally returns Black or White if the most readable color is unreadable.\n // *Example*\n // tinycolor.mostReadable(tinycolor.mostReadable(\"#123\", [\"#124\", \"#125\"],{includeFallbackColors:false}).toHexString(); // \"#112255\"\n // tinycolor.mostReadable(tinycolor.mostReadable(\"#123\", [\"#124\", \"#125\"],{includeFallbackColors:true}).toHexString(); // \"#ffffff\"\n // tinycolor.mostReadable(\"#a8015a\", [\"#faf3f3\"],{includeFallbackColors:true,level:\"AAA\",size:\"large\"}).toHexString(); // \"#faf3f3\"\n // tinycolor.mostReadable(\"#a8015a\", [\"#faf3f3\"],{includeFallbackColors:true,level:\"AAA\",size:\"small\"}).toHexString(); // \"#ffffff\"\n tinycolor.mostReadable = function (baseColor, colorList, args) {\n var bestColor = null;\n var bestScore = 0;\n var readability;\n var includeFallbackColors, level, size;\n args = args || {};\n includeFallbackColors = args.includeFallbackColors;\n level = args.level;\n size = args.size;\n for (var i = 0; i < colorList.length; i++) {\n readability = tinycolor.readability(baseColor, colorList[i]);\n if (readability > bestScore) {\n bestScore = readability;\n bestColor = tinycolor(colorList[i]);\n }\n }\n if (tinycolor.isReadable(baseColor, bestColor, {\n level: level,\n size: size\n }) || !includeFallbackColors) {\n return bestColor;\n } else {\n args.includeFallbackColors = false;\n return tinycolor.mostReadable(baseColor, [\"#fff\", \"#000\"], args);\n }\n };\n\n // Big List of Colors\n // ------------------\n // \n var names = tinycolor.names = {\n aliceblue: \"f0f8ff\",\n antiquewhite: \"faebd7\",\n aqua: \"0ff\",\n aquamarine: \"7fffd4\",\n azure: \"f0ffff\",\n beige: \"f5f5dc\",\n bisque: \"ffe4c4\",\n black: \"000\",\n blanchedalmond: \"ffebcd\",\n blue: \"00f\",\n blueviolet: \"8a2be2\",\n brown: \"a52a2a\",\n burlywood: \"deb887\",\n burntsienna: \"ea7e5d\",\n cadetblue: \"5f9ea0\",\n chartreuse: \"7fff00\",\n chocolate: \"d2691e\",\n coral: \"ff7f50\",\n cornflowerblue: \"6495ed\",\n cornsilk: \"fff8dc\",\n crimson: \"dc143c\",\n cyan: \"0ff\",\n darkblue: \"00008b\",\n darkcyan: \"008b8b\",\n darkgoldenrod: \"b8860b\",\n darkgray: \"a9a9a9\",\n darkgreen: \"006400\",\n darkgrey: \"a9a9a9\",\n darkkhaki: \"bdb76b\",\n darkmagenta: \"8b008b\",\n darkolivegreen: \"556b2f\",\n darkorange: \"ff8c00\",\n darkorchid: \"9932cc\",\n darkred: \"8b0000\",\n darksalmon: \"e9967a\",\n darkseagreen: \"8fbc8f\",\n darkslateblue: \"483d8b\",\n darkslategray: \"2f4f4f\",\n darkslategrey: \"2f4f4f\",\n darkturquoise: \"00ced1\",\n darkviolet: \"9400d3\",\n deeppink: \"ff1493\",\n deepskyblue: \"00bfff\",\n dimgray: \"696969\",\n dimgrey: \"696969\",\n dodgerblue: \"1e90ff\",\n firebrick: \"b22222\",\n floralwhite: \"fffaf0\",\n forestgreen: \"228b22\",\n fuchsia: \"f0f\",\n gainsboro: \"dcdcdc\",\n ghostwhite: \"f8f8ff\",\n gold: \"ffd700\",\n goldenrod: \"daa520\",\n gray: \"808080\",\n green: \"008000\",\n greenyellow: \"adff2f\",\n grey: \"808080\",\n honeydew: \"f0fff0\",\n hotpink: \"ff69b4\",\n indianred: \"cd5c5c\",\n indigo: \"4b0082\",\n ivory: \"fffff0\",\n khaki: \"f0e68c\",\n lavender: \"e6e6fa\",\n lavenderblush: \"fff0f5\",\n lawngreen: \"7cfc00\",\n lemonchiffon: \"fffacd\",\n lightblue: \"add8e6\",\n lightcoral: \"f08080\",\n lightcyan: \"e0ffff\",\n lightgoldenrodyellow: \"fafad2\",\n lightgray: \"d3d3d3\",\n lightgreen: \"90ee90\",\n lightgrey: \"d3d3d3\",\n lightpink: \"ffb6c1\",\n lightsalmon: \"ffa07a\",\n lightseagreen: \"20b2aa\",\n lightskyblue: \"87cefa\",\n lightslategray: \"789\",\n lightslategrey: \"789\",\n lightsteelblue: \"b0c4de\",\n lightyellow: \"ffffe0\",\n lime: \"0f0\",\n limegreen: \"32cd32\",\n linen: \"faf0e6\",\n magenta: \"f0f\",\n maroon: \"800000\",\n mediumaquamarine: \"66cdaa\",\n mediumblue: \"0000cd\",\n mediumorchid: \"ba55d3\",\n mediumpurple: \"9370db\",\n mediumseagreen: \"3cb371\",\n mediumslateblue: \"7b68ee\",\n mediumspringgreen: \"00fa9a\",\n mediumturquoise: \"48d1cc\",\n mediumvioletred: \"c71585\",\n midnightblue: \"191970\",\n mintcream: \"f5fffa\",\n mistyrose: \"ffe4e1\",\n moccasin: \"ffe4b5\",\n navajowhite: \"ffdead\",\n navy: \"000080\",\n oldlace: \"fdf5e6\",\n olive: \"808000\",\n olivedrab: \"6b8e23\",\n orange: \"ffa500\",\n orangered: \"ff4500\",\n orchid: \"da70d6\",\n palegoldenrod: \"eee8aa\",\n palegreen: \"98fb98\",\n paleturquoise: \"afeeee\",\n palevioletred: \"db7093\",\n papayawhip: \"ffefd5\",\n peachpuff: \"ffdab9\",\n peru: \"cd853f\",\n pink: \"ffc0cb\",\n plum: \"dda0dd\",\n powderblue: \"b0e0e6\",\n purple: \"800080\",\n rebeccapurple: \"663399\",\n red: \"f00\",\n rosybrown: \"bc8f8f\",\n royalblue: \"4169e1\",\n saddlebrown: \"8b4513\",\n salmon: \"fa8072\",\n sandybrown: \"f4a460\",\n seagreen: \"2e8b57\",\n seashell: \"fff5ee\",\n sienna: \"a0522d\",\n silver: \"c0c0c0\",\n skyblue: \"87ceeb\",\n slateblue: \"6a5acd\",\n slategray: \"708090\",\n slategrey: \"708090\",\n snow: \"fffafa\",\n springgreen: \"00ff7f\",\n steelblue: \"4682b4\",\n tan: \"d2b48c\",\n teal: \"008080\",\n thistle: \"d8bfd8\",\n tomato: \"ff6347\",\n turquoise: \"40e0d0\",\n violet: \"ee82ee\",\n wheat: \"f5deb3\",\n white: \"fff\",\n whitesmoke: \"f5f5f5\",\n yellow: \"ff0\",\n yellowgreen: \"9acd32\"\n };\n\n // Make it easy to access colors via `hexNames[hex]`\n var hexNames = tinycolor.hexNames = flip(names);\n\n // Utilities\n // ---------\n\n // `{ 'name1': 'val1' }` becomes `{ 'val1': 'name1' }`\n function flip(o) {\n var flipped = {};\n for (var i in o) {\n if (o.hasOwnProperty(i)) {\n flipped[o[i]] = i;\n }\n }\n return flipped;\n }\n\n // Return a valid alpha value [0,1] with all invalid values being set to 1\n function boundAlpha(a) {\n a = parseFloat(a);\n if (isNaN(a) || a < 0 || a > 1) {\n a = 1;\n }\n return a;\n }\n\n // Take input from [0, n] and return it as [0, 1]\n function bound01(n, max) {\n if (isOnePointZero(n)) n = \"100%\";\n var processPercent = isPercentage(n);\n n = Math.min(max, Math.max(0, parseFloat(n)));\n\n // Automatically convert percentage into number\n if (processPercent) {\n n = parseInt(n * max, 10) / 100;\n }\n\n // Handle floating point rounding errors\n if (Math.abs(n - max) < 0.000001) {\n return 1;\n }\n\n // Convert into [0, 1] range if it isn't already\n return n % max / parseFloat(max);\n }\n\n // Force a number between 0 and 1\n function clamp01(val) {\n return Math.min(1, Math.max(0, val));\n }\n\n // Parse a base-16 hex value into a base-10 integer\n function parseIntFromHex(val) {\n return parseInt(val, 16);\n }\n\n // Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1\n // \n function isOnePointZero(n) {\n return typeof n == \"string\" && n.indexOf(\".\") != -1 && parseFloat(n) === 1;\n }\n\n // Check to see if string passed in is a percentage\n function isPercentage(n) {\n return typeof n === \"string\" && n.indexOf(\"%\") != -1;\n }\n\n // Force a hex value to have 2 characters\n function pad2(c) {\n return c.length == 1 ? \"0\" + c : \"\" + c;\n }\n\n // Replace a decimal with it's percentage value\n function convertToPercentage(n) {\n if (n <= 1) {\n n = n * 100 + \"%\";\n }\n return n;\n }\n\n // Converts a decimal to a hex value\n function convertDecimalToHex(d) {\n return Math.round(parseFloat(d) * 255).toString(16);\n }\n // Converts a hex value to a decimal\n function convertHexToDecimal(h) {\n return parseIntFromHex(h) / 255;\n }\n var matchers = function () {\n // \n var CSS_INTEGER = \"[-\\\\+]?\\\\d+%?\";\n\n // \n var CSS_NUMBER = \"[-\\\\+]?\\\\d*\\\\.\\\\d+%?\";\n\n // Allow positive/negative integer/number. Don't capture the either/or, just the entire outcome.\n var CSS_UNIT = \"(?:\" + CSS_NUMBER + \")|(?:\" + CSS_INTEGER + \")\";\n\n // Actual matching.\n // Parentheses and commas are optional, but not required.\n // Whitespace can take the place of commas or opening paren\n var PERMISSIVE_MATCH3 = \"[\\\\s|\\\\(]+(\" + CSS_UNIT + \")[,|\\\\s]+(\" + CSS_UNIT + \")[,|\\\\s]+(\" + CSS_UNIT + \")\\\\s*\\\\)?\";\n var PERMISSIVE_MATCH4 = \"[\\\\s|\\\\(]+(\" + CSS_UNIT + \")[,|\\\\s]+(\" + CSS_UNIT + \")[,|\\\\s]+(\" + CSS_UNIT + \")[,|\\\\s]+(\" + CSS_UNIT + \")\\\\s*\\\\)?\";\n return {\n CSS_UNIT: new RegExp(CSS_UNIT),\n rgb: new RegExp(\"rgb\" + PERMISSIVE_MATCH3),\n rgba: new RegExp(\"rgba\" + PERMISSIVE_MATCH4),\n hsl: new RegExp(\"hsl\" + PERMISSIVE_MATCH3),\n hsla: new RegExp(\"hsla\" + PERMISSIVE_MATCH4),\n hsv: new RegExp(\"hsv\" + PERMISSIVE_MATCH3),\n hsva: new RegExp(\"hsva\" + PERMISSIVE_MATCH4),\n hex3: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex6: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,\n hex4: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex8: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/\n };\n }();\n\n // `isValidCSSUnit`\n // Take in a single string / number and check to see if it looks like a CSS unit\n // (see `matchers` above for definition).\n function isValidCSSUnit(color) {\n return !!matchers.CSS_UNIT.exec(color);\n }\n\n // `stringInputToObject`\n // Permissive string parsing. Take in a number of formats, and output an object\n // based on detected format. Returns `{ r, g, b }` or `{ h, s, l }` or `{ h, s, v}`\n function stringInputToObject(color) {\n color = color.replace(trimLeft, \"\").replace(trimRight, \"\").toLowerCase();\n var named = false;\n if (names[color]) {\n color = names[color];\n named = true;\n } else if (color == \"transparent\") {\n return {\n r: 0,\n g: 0,\n b: 0,\n a: 0,\n format: \"name\"\n };\n }\n\n // Try to match string input using regular expressions.\n // Keep most of the number bounding out of this function - don't worry about [0,1] or [0,100] or [0,360]\n // Just return an object and let the conversion functions handle that.\n // This way the result will be the same whether the tinycolor is initialized with string or object.\n var match;\n if (match = matchers.rgb.exec(color)) {\n return {\n r: match[1],\n g: match[2],\n b: match[3]\n };\n }\n if (match = matchers.rgba.exec(color)) {\n return {\n r: match[1],\n g: match[2],\n b: match[3],\n a: match[4]\n };\n }\n if (match = matchers.hsl.exec(color)) {\n return {\n h: match[1],\n s: match[2],\n l: match[3]\n };\n }\n if (match = matchers.hsla.exec(color)) {\n return {\n h: match[1],\n s: match[2],\n l: match[3],\n a: match[4]\n };\n }\n if (match = matchers.hsv.exec(color)) {\n return {\n h: match[1],\n s: match[2],\n v: match[3]\n };\n }\n if (match = matchers.hsva.exec(color)) {\n return {\n h: match[1],\n s: match[2],\n v: match[3],\n a: match[4]\n };\n }\n if (match = matchers.hex8.exec(color)) {\n return {\n r: parseIntFromHex(match[1]),\n g: parseIntFromHex(match[2]),\n b: parseIntFromHex(match[3]),\n a: convertHexToDecimal(match[4]),\n format: named ? \"name\" : \"hex8\"\n };\n }\n if (match = matchers.hex6.exec(color)) {\n return {\n r: parseIntFromHex(match[1]),\n g: parseIntFromHex(match[2]),\n b: parseIntFromHex(match[3]),\n format: named ? \"name\" : \"hex\"\n };\n }\n if (match = matchers.hex4.exec(color)) {\n return {\n r: parseIntFromHex(match[1] + \"\" + match[1]),\n g: parseIntFromHex(match[2] + \"\" + match[2]),\n b: parseIntFromHex(match[3] + \"\" + match[3]),\n a: convertHexToDecimal(match[4] + \"\" + match[4]),\n format: named ? \"name\" : \"hex8\"\n };\n }\n if (match = matchers.hex3.exec(color)) {\n return {\n r: parseIntFromHex(match[1] + \"\" + match[1]),\n g: parseIntFromHex(match[2] + \"\" + match[2]),\n b: parseIntFromHex(match[3] + \"\" + match[3]),\n format: named ? \"name\" : \"hex\"\n };\n }\n return false;\n }\n function validateWCAG2Parms(parms) {\n // return valid WCAG2 parms for isReadable.\n // If input parms are invalid, return {\"level\":\"AA\", \"size\":\"small\"}\n var level, size;\n parms = parms || {\n level: \"AA\",\n size: \"small\"\n };\n level = (parms.level || \"AA\").toUpperCase();\n size = (parms.size || \"small\").toLowerCase();\n if (level !== \"AA\" && level !== \"AAA\") {\n level = \"AA\";\n }\n if (size !== \"small\" && size !== \"large\") {\n size = \"small\";\n }\n return {\n level: level,\n size: size\n };\n }\n\n return tinycolor;\n\n}));\n","function _extends() {\n return _extends = Object.assign ? Object.assign.bind() : function (n) {\n for (var e = 1; e < arguments.length; e++) {\n var t = arguments[e];\n for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]);\n }\n return n;\n }, _extends.apply(null, arguments);\n}\nexport { _extends as default };","function _objectWithoutPropertiesLoose(r, e) {\n if (null == r) return {};\n var t = {};\n for (var n in r) if ({}.hasOwnProperty.call(r, n)) {\n if (e.includes(n)) continue;\n t[n] = r[n];\n }\n return t;\n}\nexport { _objectWithoutPropertiesLoose as default };","function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t> 8 & 0xf) | (m >> 4 & 0xf0), (m >> 4 & 0xf) | (m & 0xf0), ((m & 0xf) << 4) | (m & 0xf), 1) // #f00\n : l === 8 ? rgba(m >> 24 & 0xff, m >> 16 & 0xff, m >> 8 & 0xff, (m & 0xff) / 0xff) // #ff000000\n : l === 4 ? rgba((m >> 12 & 0xf) | (m >> 8 & 0xf0), (m >> 8 & 0xf) | (m >> 4 & 0xf0), (m >> 4 & 0xf) | (m & 0xf0), (((m & 0xf) << 4) | (m & 0xf)) / 0xff) // #f000\n : null) // invalid hex\n : (m = reRgbInteger.exec(format)) ? new Rgb(m[1], m[2], m[3], 1) // rgb(255, 0, 0)\n : (m = reRgbPercent.exec(format)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) // rgb(100%, 0%, 0%)\n : (m = reRgbaInteger.exec(format)) ? rgba(m[1], m[2], m[3], m[4]) // rgba(255, 0, 0, 1)\n : (m = reRgbaPercent.exec(format)) ? rgba(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) // rgb(100%, 0%, 0%, 1)\n : (m = reHslPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) // hsl(120, 50%, 50%)\n : (m = reHslaPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) // hsla(120, 50%, 50%, 1)\n : named.hasOwnProperty(format) ? rgbn(named[format]) // eslint-disable-line no-prototype-builtins\n : format === \"transparent\" ? new Rgb(NaN, NaN, NaN, 0)\n : null;\n}\n\nfunction rgbn(n) {\n return new Rgb(n >> 16 & 0xff, n >> 8 & 0xff, n & 0xff, 1);\n}\n\nfunction rgba(r, g, b, a) {\n if (a <= 0) r = g = b = NaN;\n return new Rgb(r, g, b, a);\n}\n\nexport function rgbConvert(o) {\n if (!(o instanceof Color)) o = color(o);\n if (!o) return new Rgb;\n o = o.rgb();\n return new Rgb(o.r, o.g, o.b, o.opacity);\n}\n\nexport function rgb(r, g, b, opacity) {\n return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity);\n}\n\nexport function Rgb(r, g, b, opacity) {\n this.r = +r;\n this.g = +g;\n this.b = +b;\n this.opacity = +opacity;\n}\n\ndefine(Rgb, rgb, extend(Color, {\n brighter(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n },\n darker(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n },\n rgb() {\n return this;\n },\n clamp() {\n return new Rgb(clampi(this.r), clampi(this.g), clampi(this.b), clampa(this.opacity));\n },\n displayable() {\n return (-0.5 <= this.r && this.r < 255.5)\n && (-0.5 <= this.g && this.g < 255.5)\n && (-0.5 <= this.b && this.b < 255.5)\n && (0 <= this.opacity && this.opacity <= 1);\n },\n hex: rgb_formatHex, // Deprecated! Use color.formatHex.\n formatHex: rgb_formatHex,\n formatHex8: rgb_formatHex8,\n formatRgb: rgb_formatRgb,\n toString: rgb_formatRgb\n}));\n\nfunction rgb_formatHex() {\n return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}`;\n}\n\nfunction rgb_formatHex8() {\n return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}${hex((isNaN(this.opacity) ? 1 : this.opacity) * 255)}`;\n}\n\nfunction rgb_formatRgb() {\n const a = clampa(this.opacity);\n return `${a === 1 ? \"rgb(\" : \"rgba(\"}${clampi(this.r)}, ${clampi(this.g)}, ${clampi(this.b)}${a === 1 ? \")\" : `, ${a})`}`;\n}\n\nfunction clampa(opacity) {\n return isNaN(opacity) ? 1 : Math.max(0, Math.min(1, opacity));\n}\n\nfunction clampi(value) {\n return Math.max(0, Math.min(255, Math.round(value) || 0));\n}\n\nfunction hex(value) {\n value = clampi(value);\n return (value < 16 ? \"0\" : \"\") + value.toString(16);\n}\n\nfunction hsla(h, s, l, a) {\n if (a <= 0) h = s = l = NaN;\n else if (l <= 0 || l >= 1) h = s = NaN;\n else if (s <= 0) h = NaN;\n return new Hsl(h, s, l, a);\n}\n\nexport function hslConvert(o) {\n if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);\n if (!(o instanceof Color)) o = color(o);\n if (!o) return new Hsl;\n if (o instanceof Hsl) return o;\n o = o.rgb();\n var r = o.r / 255,\n g = o.g / 255,\n b = o.b / 255,\n min = Math.min(r, g, b),\n max = Math.max(r, g, b),\n h = NaN,\n s = max - min,\n l = (max + min) / 2;\n if (s) {\n if (r === max) h = (g - b) / s + (g < b) * 6;\n else if (g === max) h = (b - r) / s + 2;\n else h = (r - g) / s + 4;\n s /= l < 0.5 ? max + min : 2 - max - min;\n h *= 60;\n } else {\n s = l > 0 && l < 1 ? 0 : h;\n }\n return new Hsl(h, s, l, o.opacity);\n}\n\nexport function hsl(h, s, l, opacity) {\n return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity);\n}\n\nfunction Hsl(h, s, l, opacity) {\n this.h = +h;\n this.s = +s;\n this.l = +l;\n this.opacity = +opacity;\n}\n\ndefine(Hsl, hsl, extend(Color, {\n brighter(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Hsl(this.h, this.s, this.l * k, this.opacity);\n },\n darker(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Hsl(this.h, this.s, this.l * k, this.opacity);\n },\n rgb() {\n var h = this.h % 360 + (this.h < 0) * 360,\n s = isNaN(h) || isNaN(this.s) ? 0 : this.s,\n l = this.l,\n m2 = l + (l < 0.5 ? l : 1 - l) * s,\n m1 = 2 * l - m2;\n return new Rgb(\n hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2),\n hsl2rgb(h, m1, m2),\n hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2),\n this.opacity\n );\n },\n clamp() {\n return new Hsl(clamph(this.h), clampt(this.s), clampt(this.l), clampa(this.opacity));\n },\n displayable() {\n return (0 <= this.s && this.s <= 1 || isNaN(this.s))\n && (0 <= this.l && this.l <= 1)\n && (0 <= this.opacity && this.opacity <= 1);\n },\n formatHsl() {\n const a = clampa(this.opacity);\n return `${a === 1 ? \"hsl(\" : \"hsla(\"}${clamph(this.h)}, ${clampt(this.s) * 100}%, ${clampt(this.l) * 100}%${a === 1 ? \")\" : `, ${a})`}`;\n }\n}));\n\nfunction clamph(value) {\n value = (value || 0) % 360;\n return value < 0 ? value + 360 : value;\n}\n\nfunction clampt(value) {\n return Math.max(0, Math.min(1, value || 0));\n}\n\n/* From FvD 13.37, CSS Color Module Level 3 */\nfunction hsl2rgb(h, m1, m2) {\n return (h < 60 ? m1 + (m2 - m1) * h / 60\n : h < 180 ? m2\n : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60\n : m1) * 255;\n}\n","export default x => () => x;\n","import value from \"./value.js\";\nimport numberArray, {isNumberArray} from \"./numberArray.js\";\n\nexport default function(a, b) {\n return (isNumberArray(b) ? numberArray : genericArray)(a, b);\n}\n\nexport function genericArray(a, b) {\n var nb = b ? b.length : 0,\n na = a ? Math.min(nb, a.length) : 0,\n x = new Array(na),\n c = new Array(nb),\n i;\n\n for (i = 0; i < na; ++i) x[i] = value(a[i], b[i]);\n for (; i < nb; ++i) c[i] = b[i];\n\n return function(t) {\n for (i = 0; i < na; ++i) c[i] = x[i](t);\n return c;\n };\n}\n","export default function(a, b) {\n var d = new Date;\n return a = +a, b = +b, function(t) {\n return d.setTime(a * (1 - t) + b * t), d;\n };\n}\n","import value from \"./value.js\";\n\nexport default function(a, b) {\n var i = {},\n c = {},\n k;\n\n if (a === null || typeof a !== \"object\") a = {};\n if (b === null || typeof b !== \"object\") b = {};\n\n for (k in b) {\n if (k in a) {\n i[k] = value(a[k], b[k]);\n } else {\n c[k] = b[k];\n }\n }\n\n return function(t) {\n for (k in i) c[k] = i[k](t);\n return c;\n };\n}\n","export default function(a, b) {\n if (!b) b = [];\n var n = a ? Math.min(b.length, a.length) : 0,\n c = b.slice(),\n i;\n return function(t) {\n for (i = 0; i < n; ++i) c[i] = a[i] * (1 - t) + b[i] * t;\n return c;\n };\n}\n\nexport function isNumberArray(x) {\n return ArrayBuffer.isView(x) && !(x instanceof DataView);\n}\n","import {color} from \"d3-color\";\nimport rgb from \"./rgb.js\";\nimport {genericArray} from \"./array.js\";\nimport date from \"./date.js\";\nimport number from \"./number.js\";\nimport object from \"./object.js\";\nimport string from \"./string.js\";\nimport constant from \"./constant.js\";\nimport numberArray, {isNumberArray} from \"./numberArray.js\";\n\nexport default function(a, b) {\n var t = typeof b, c;\n return b == null || t === \"boolean\" ? constant(b)\n : (t === \"number\" ? number\n : t === \"string\" ? ((c = color(b)) ? (b = c, rgb) : string)\n : b instanceof color ? rgb\n : b instanceof Date ? date\n : isNumberArray(b) ? numberArray\n : Array.isArray(b) ? genericArray\n : typeof b.valueOf !== \"function\" && typeof b.toString !== \"function\" || isNaN(b) ? object\n : number)(a, b);\n}\n","export default function(a, b) {\n return a = +a, b = +b, function(t) {\n return a * (1 - t) + b * t;\n };\n}\n","export function basis(t1, v0, v1, v2, v3) {\n var t2 = t1 * t1, t3 = t2 * t1;\n return ((1 - 3 * t1 + 3 * t2 - t3) * v0\n + (4 - 6 * t2 + 3 * t3) * v1\n + (1 + 3 * t1 + 3 * t2 - 3 * t3) * v2\n + t3 * v3) / 6;\n}\n\nexport default function(values) {\n var n = values.length - 1;\n return function(t) {\n var i = t <= 0 ? (t = 0) : t >= 1 ? (t = 1, n - 1) : Math.floor(t * n),\n v1 = values[i],\n v2 = values[i + 1],\n v0 = i > 0 ? values[i - 1] : 2 * v1 - v2,\n v3 = i < n - 1 ? values[i + 2] : 2 * v2 - v1;\n return basis((t - i / n) * n, v0, v1, v2, v3);\n };\n}\n","import constant from \"./constant.js\";\n\nfunction linear(a, d) {\n return function(t) {\n return a + t * d;\n };\n}\n\nfunction exponential(a, b, y) {\n return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function(t) {\n return Math.pow(a + t * b, y);\n };\n}\n\nexport function hue(a, b) {\n var d = b - a;\n return d ? linear(a, d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d) : constant(isNaN(a) ? b : a);\n}\n\nexport function gamma(y) {\n return (y = +y) === 1 ? nogamma : function(a, b) {\n return b - a ? exponential(a, b, y) : constant(isNaN(a) ? b : a);\n };\n}\n\nexport default function nogamma(a, b) {\n var d = b - a;\n return d ? linear(a, d) : constant(isNaN(a) ? b : a);\n}\n","import {rgb as colorRgb} from \"d3-color\";\nimport basis from \"./basis.js\";\nimport basisClosed from \"./basisClosed.js\";\nimport nogamma, {gamma} from \"./color.js\";\n\nexport default (function rgbGamma(y) {\n var color = gamma(y);\n\n function rgb(start, end) {\n var r = color((start = colorRgb(start)).r, (end = colorRgb(end)).r),\n g = color(start.g, end.g),\n b = color(start.b, end.b),\n opacity = nogamma(start.opacity, end.opacity);\n return function(t) {\n start.r = r(t);\n start.g = g(t);\n start.b = b(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n\n rgb.gamma = rgbGamma;\n\n return rgb;\n})(1);\n\nfunction rgbSpline(spline) {\n return function(colors) {\n var n = colors.length,\n r = new Array(n),\n g = new Array(n),\n b = new Array(n),\n i, color;\n for (i = 0; i < n; ++i) {\n color = colorRgb(colors[i]);\n r[i] = color.r || 0;\n g[i] = color.g || 0;\n b[i] = color.b || 0;\n }\n r = spline(r);\n g = spline(g);\n b = spline(b);\n color.opacity = 1;\n return function(t) {\n color.r = r(t);\n color.g = g(t);\n color.b = b(t);\n return color + \"\";\n };\n };\n}\n\nexport var rgbBasis = rgbSpline(basis);\nexport var rgbBasisClosed = rgbSpline(basisClosed);\n","import {basis} from \"./basis.js\";\n\nexport default function(values) {\n var n = values.length;\n return function(t) {\n var i = Math.floor(((t %= 1) < 0 ? ++t : t) * n),\n v0 = values[(i + n - 1) % n],\n v1 = values[i % n],\n v2 = values[(i + 1) % n],\n v3 = values[(i + 2) % n];\n return basis((t - i / n) * n, v0, v1, v2, v3);\n };\n}\n","import number from \"./number.js\";\n\nvar reA = /[-+]?(?:\\d+\\.?\\d*|\\.?\\d+)(?:[eE][-+]?\\d+)?/g,\n reB = new RegExp(reA.source, \"g\");\n\nfunction zero(b) {\n return function() {\n return b;\n };\n}\n\nfunction one(b) {\n return function(t) {\n return b(t) + \"\";\n };\n}\n\nexport default function(a, b) {\n var bi = reA.lastIndex = reB.lastIndex = 0, // scan index for next number in b\n am, // current match in a\n bm, // current match in b\n bs, // string preceding current number in b, if any\n i = -1, // index in s\n s = [], // string constants and placeholders\n q = []; // number interpolators\n\n // Coerce inputs to strings.\n a = a + \"\", b = b + \"\";\n\n // Interpolate pairs of numbers in a & b.\n while ((am = reA.exec(a))\n && (bm = reB.exec(b))) {\n if ((bs = bm.index) > bi) { // a string precedes the next number in b\n bs = b.slice(bi, bs);\n if (s[i]) s[i] += bs; // coalesce with previous string\n else s[++i] = bs;\n }\n if ((am = am[0]) === (bm = bm[0])) { // numbers in a & b match\n if (s[i]) s[i] += bm; // coalesce with previous string\n else s[++i] = bm;\n } else { // interpolate non-matching numbers\n s[++i] = null;\n q.push({i: i, x: number(am, bm)});\n }\n bi = reB.lastIndex;\n }\n\n // Add remains of b.\n if (bi < b.length) {\n bs = b.slice(bi);\n if (s[i]) s[i] += bs; // coalesce with previous string\n else s[++i] = bs;\n }\n\n // Special optimization for only a single match.\n // Otherwise, interpolate each of the numbers and rejoin the string.\n return s.length < 2 ? (q[0]\n ? one(q[0].x)\n : zero(b))\n : (b = q.length, function(t) {\n for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);\n return s.join(\"\");\n });\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","var getProto = Object.getPrototypeOf ? (obj) => (Object.getPrototypeOf(obj)) : (obj) => (obj.__proto__);\nvar leafPrototypes;\n// create a fake namespace object\n// mode & 1: value is a module id, require it\n// mode & 2: merge all properties of value into the ns\n// mode & 4: return value when already ns object\n// mode & 16: return value when it's Promise-like\n// mode & 8|1: behave like require\n__webpack_require__.t = function(value, mode) {\n\tif(mode & 1) value = this(value);\n\tif(mode & 8) return value;\n\tif(typeof value === 'object' && value) {\n\t\tif((mode & 4) && value.__esModule) return value;\n\t\tif((mode & 16) && typeof value.then === 'function') return value;\n\t}\n\tvar ns = Object.create(null);\n\t__webpack_require__.r(ns);\n\tvar def = {};\n\tleafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)];\n\tfor(var current = mode & 2 && value; typeof current == 'object' && !~leafPrototypes.indexOf(current); current = getProto(current)) {\n\t\tObject.getOwnPropertyNames(current).forEach((key) => (def[key] = () => (value[key])));\n\t}\n\tdef['default'] = () => (value);\n\t__webpack_require__.d(ns, def);\n\treturn ns;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = (chunkId) => {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn \"static/js/\" + chunkId + \".\" + \"8edbc83a\" + \".chunk.js\";\n};","// This function allow to reference async chunks\n__webpack_require__.miniCssF = (chunkId) => {\n\t// return url for filenames based on template\n\treturn undefined;\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","var inProgress = {};\nvar dataWebpackPrefix = \"optinist:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = (url, done, key, chunkId) => {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tscript.timeout = 120;\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = (prev, event) => {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach((fn) => (fn(event)));\n\t\tif(prev) return prev(event);\n\t}\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.nmd = (module) => {\n\tmodule.paths = [];\n\tif (!module.children) module.children = [];\n\treturn module;\n};","__webpack_require__.p = \"/\";","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t792: 0\n};\n\n__webpack_require__.f.j = (chunkId, promises) => {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(true) { // all chunks have JS\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise((resolve, reject) => (installedChunkData = installedChunks[chunkId] = [resolve, reject]));\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = (event) => {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n// no on chunks loaded\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = (parentChunkLoadingFunction, data) => {\n\tvar chunkIds = data[0];\n\tvar moreModules = data[1];\n\tvar runtime = data[2];\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some((id) => (installedChunks[id] !== 0))) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunkoptinist\"] = self[\"webpackChunkoptinist\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","// Default to a dummy \"batch\" implementation that just runs the callback\nfunction defaultNoopBatch(callback) {\n callback();\n}\n\nlet batch = defaultNoopBatch; // Allow injecting another batching function later\n\nexport const setBatch = newBatch => batch = newBatch; // Supply a getter just to skip dealing with ESM bindings\n\nexport const getBatch = () => batch;","import * as React from 'react';\nconst ContextKey = Symbol.for(`react-redux-context`);\nconst gT = typeof globalThis !== \"undefined\" ? globalThis :\n/* fall back to a per-module scope (pre-8.1 behaviour) if `globalThis` is not available */\n{};\n\nfunction getContext() {\n var _gT$ContextKey;\n\n if (!React.createContext) return {};\n const contextMap = (_gT$ContextKey = gT[ContextKey]) != null ? _gT$ContextKey : gT[ContextKey] = new Map();\n let realContext = contextMap.get(React.createContext);\n\n if (!realContext) {\n realContext = React.createContext(null);\n\n if (process.env.NODE_ENV !== 'production') {\n realContext.displayName = 'ReactRedux';\n }\n\n contextMap.set(React.createContext, realContext);\n }\n\n return realContext;\n}\n\nexport const ReactReduxContext = /*#__PURE__*/getContext();\nexport default ReactReduxContext;","import { useContext } from 'react';\nimport { ReactReduxContext } from '../components/Context';\n\n/**\r\n * Hook factory, which creates a `useReduxContext` hook bound to a given context. This is a low-level\r\n * hook that you should usually not need to call directly.\r\n *\r\n * @param {React.Context} [context=ReactReduxContext] Context passed to your ``.\r\n * @returns {Function} A `useReduxContext` hook bound to the specified context.\r\n */\nexport function createReduxContextHook(context = ReactReduxContext) {\n return function useReduxContext() {\n const contextValue = useContext(context);\n\n if (process.env.NODE_ENV !== 'production' && !contextValue) {\n throw new Error('could not find react-redux context value; please ensure the component is wrapped in a ');\n }\n\n return contextValue;\n };\n}\n/**\r\n * A hook to access the value of the `ReactReduxContext`. This is a low-level\r\n * hook that you should usually not need to call directly.\r\n *\r\n * @returns {any} the value of the `ReactReduxContext`\r\n *\r\n * @example\r\n *\r\n * import React from 'react'\r\n * import { useReduxContext } from 'react-redux'\r\n *\r\n * export const CounterComponent = () => {\r\n * const { store } = useReduxContext()\r\n * return
{store.getState()}
\r\n * }\r\n */\n\nexport const useReduxContext = /*#__PURE__*/createReduxContextHook();","import { useCallback, useDebugValue, useRef } from 'react';\nimport { createReduxContextHook, useReduxContext as useDefaultReduxContext } from './useReduxContext';\nimport { ReactReduxContext } from '../components/Context';\nimport { notInitialized } from '../utils/useSyncExternalStore';\nlet useSyncExternalStoreWithSelector = notInitialized;\nexport const initializeUseSelector = fn => {\n useSyncExternalStoreWithSelector = fn;\n};\n\nconst refEquality = (a, b) => a === b;\n/**\r\n * Hook factory, which creates a `useSelector` hook bound to a given context.\r\n *\r\n * @param {React.Context} [context=ReactReduxContext] Context passed to your ``.\r\n * @returns {Function} A `useSelector` hook bound to the specified context.\r\n */\n\n\nexport function createSelectorHook(context = ReactReduxContext) {\n const useReduxContext = context === ReactReduxContext ? useDefaultReduxContext : createReduxContextHook(context);\n return function useSelector(selector, equalityFnOrOptions = {}) {\n const {\n equalityFn = refEquality,\n stabilityCheck = undefined,\n noopCheck = undefined\n } = typeof equalityFnOrOptions === 'function' ? {\n equalityFn: equalityFnOrOptions\n } : equalityFnOrOptions;\n\n if (process.env.NODE_ENV !== 'production') {\n if (!selector) {\n throw new Error(`You must pass a selector to useSelector`);\n }\n\n if (typeof selector !== 'function') {\n throw new Error(`You must pass a function as a selector to useSelector`);\n }\n\n if (typeof equalityFn !== 'function') {\n throw new Error(`You must pass a function as an equality function to useSelector`);\n }\n }\n\n const {\n store,\n subscription,\n getServerState,\n stabilityCheck: globalStabilityCheck,\n noopCheck: globalNoopCheck\n } = useReduxContext();\n const firstRun = useRef(true);\n const wrappedSelector = useCallback({\n [selector.name](state) {\n const selected = selector(state);\n\n if (process.env.NODE_ENV !== 'production') {\n const finalStabilityCheck = typeof stabilityCheck === 'undefined' ? globalStabilityCheck : stabilityCheck;\n\n if (finalStabilityCheck === 'always' || finalStabilityCheck === 'once' && firstRun.current) {\n const toCompare = selector(state);\n\n if (!equalityFn(selected, toCompare)) {\n let stack = undefined;\n\n try {\n throw new Error();\n } catch (e) {\n ;\n ({\n stack\n } = e);\n }\n\n console.warn('Selector ' + (selector.name || 'unknown') + ' returned a different result when called with the same parameters. This can lead to unnecessary rerenders.' + '\\nSelectors that return a new reference (such as an object or an array) should be memoized: https://redux.js.org/usage/deriving-data-selectors#optimizing-selectors-with-memoization', {\n state,\n selected,\n selected2: toCompare,\n stack\n });\n }\n }\n\n const finalNoopCheck = typeof noopCheck === 'undefined' ? globalNoopCheck : noopCheck;\n\n if (finalNoopCheck === 'always' || finalNoopCheck === 'once' && firstRun.current) {\n // @ts-ignore\n if (selected === state) {\n let stack = undefined;\n\n try {\n throw new Error();\n } catch (e) {\n ;\n ({\n stack\n } = e);\n }\n\n console.warn('Selector ' + (selector.name || 'unknown') + ' returned the root state when called. This can lead to unnecessary rerenders.' + '\\nSelectors that return the entire state are almost certainly a mistake, as they will cause a rerender whenever *anything* in state changes.', {\n stack\n });\n }\n }\n\n if (firstRun.current) firstRun.current = false;\n }\n\n return selected;\n }\n\n }[selector.name], [selector, globalStabilityCheck, stabilityCheck]);\n const selectedState = useSyncExternalStoreWithSelector(subscription.addNestedSub, store.getState, getServerState || store.getState, wrappedSelector, equalityFn);\n useDebugValue(selectedState);\n return selectedState;\n };\n}\n/**\r\n * A hook to access the redux store's state. This hook takes a selector function\r\n * as an argument. The selector is called with the store state.\r\n *\r\n * This hook takes an optional equality comparison function as the second parameter\r\n * that allows you to customize the way the selected state is compared to determine\r\n * whether the component needs to be re-rendered.\r\n *\r\n * @param {Function} selector the selector function\r\n * @param {Function=} equalityFn the function that will be used to determine equality\r\n *\r\n * @returns {any} the selected state\r\n *\r\n * @example\r\n *\r\n * import React from 'react'\r\n * import { useSelector } from 'react-redux'\r\n *\r\n * export const CounterComponent = () => {\r\n * const counter = useSelector(state => state.counter)\r\n * return
{counter}
\r\n * }\r\n */\n\nexport const useSelector = /*#__PURE__*/createSelectorHook();","export const notInitialized = () => {\n throw new Error('uSES not initialized!');\n};","import { getBatch } from './batch'; // encapsulates the subscription logic for connecting a component to the redux store, as\n// well as nesting subscriptions of descendant components, so that we can ensure the\n// ancestor components re-render before descendants\n\nfunction createListenerCollection() {\n const batch = getBatch();\n let first = null;\n let last = null;\n return {\n clear() {\n first = null;\n last = null;\n },\n\n notify() {\n batch(() => {\n let listener = first;\n\n while (listener) {\n listener.callback();\n listener = listener.next;\n }\n });\n },\n\n get() {\n let listeners = [];\n let listener = first;\n\n while (listener) {\n listeners.push(listener);\n listener = listener.next;\n }\n\n return listeners;\n },\n\n subscribe(callback) {\n let isSubscribed = true;\n let listener = last = {\n callback,\n next: null,\n prev: last\n };\n\n if (listener.prev) {\n listener.prev.next = listener;\n } else {\n first = listener;\n }\n\n return function unsubscribe() {\n if (!isSubscribed || first === null) return;\n isSubscribed = false;\n\n if (listener.next) {\n listener.next.prev = listener.prev;\n } else {\n last = listener.prev;\n }\n\n if (listener.prev) {\n listener.prev.next = listener.next;\n } else {\n first = listener.next;\n }\n };\n }\n\n };\n}\n\nconst nullListeners = {\n notify() {},\n\n get: () => []\n};\nexport function createSubscription(store, parentSub) {\n let unsubscribe;\n let listeners = nullListeners; // Reasons to keep the subscription active\n\n let subscriptionsAmount = 0; // Is this specific subscription subscribed (or only nested ones?)\n\n let selfSubscribed = false;\n\n function addNestedSub(listener) {\n trySubscribe();\n const cleanupListener = listeners.subscribe(listener); // cleanup nested sub\n\n let removed = false;\n return () => {\n if (!removed) {\n removed = true;\n cleanupListener();\n tryUnsubscribe();\n }\n };\n }\n\n function notifyNestedSubs() {\n listeners.notify();\n }\n\n function handleChangeWrapper() {\n if (subscription.onStateChange) {\n subscription.onStateChange();\n }\n }\n\n function isSubscribed() {\n return selfSubscribed;\n }\n\n function trySubscribe() {\n subscriptionsAmount++;\n\n if (!unsubscribe) {\n unsubscribe = parentSub ? parentSub.addNestedSub(handleChangeWrapper) : store.subscribe(handleChangeWrapper);\n listeners = createListenerCollection();\n }\n }\n\n function tryUnsubscribe() {\n subscriptionsAmount--;\n\n if (unsubscribe && subscriptionsAmount === 0) {\n unsubscribe();\n unsubscribe = undefined;\n listeners.clear();\n listeners = nullListeners;\n }\n }\n\n function trySubscribeSelf() {\n if (!selfSubscribed) {\n selfSubscribed = true;\n trySubscribe();\n }\n }\n\n function tryUnsubscribeSelf() {\n if (selfSubscribed) {\n selfSubscribed = false;\n tryUnsubscribe();\n }\n }\n\n const subscription = {\n addNestedSub,\n notifyNestedSubs,\n handleChangeWrapper,\n isSubscribed,\n trySubscribe: trySubscribeSelf,\n tryUnsubscribe: tryUnsubscribeSelf,\n getListeners: () => listeners\n };\n return subscription;\n}","import * as React from 'react'; // React currently throws a warning when using useLayoutEffect on the server.\n// To get around it, we can conditionally useEffect on the server (no-op) and\n// useLayoutEffect in the browser. We need useLayoutEffect to ensure the store\n// subscription callback always has the selector from the latest render commit\n// available, otherwise a store update may happen between render and the effect,\n// which may cause missed updates; we also must ensure the store subscription\n// is created synchronously, otherwise a store update may occur before the\n// subscription is created and an inconsistent state may be observed\n// Matches logic in React's `shared/ExecutionEnvironment` file\n\nexport const canUseDOM = !!(typeof window !== 'undefined' && typeof window.document !== 'undefined' && typeof window.document.createElement !== 'undefined');\nexport const useIsomorphicLayoutEffect = canUseDOM ? React.useLayoutEffect : React.useEffect;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"reactReduxForwardedRef\"];\n\n/* eslint-disable valid-jsdoc, @typescript-eslint/no-unused-vars */\nimport hoistStatics from 'hoist-non-react-statics';\nimport * as React from 'react';\nimport { isValidElementType, isContextConsumer } from 'react-is';\nimport defaultSelectorFactory from '../connect/selectorFactory';\nimport { mapDispatchToPropsFactory } from '../connect/mapDispatchToProps';\nimport { mapStateToPropsFactory } from '../connect/mapStateToProps';\nimport { mergePropsFactory } from '../connect/mergeProps';\nimport { createSubscription } from '../utils/Subscription';\nimport { useIsomorphicLayoutEffect } from '../utils/useIsomorphicLayoutEffect';\nimport shallowEqual from '../utils/shallowEqual';\nimport warning from '../utils/warning';\nimport { ReactReduxContext } from './Context';\nimport { notInitialized } from '../utils/useSyncExternalStore';\nlet useSyncExternalStore = notInitialized;\nexport const initializeConnect = fn => {\n useSyncExternalStore = fn;\n}; // Define some constant arrays just to avoid re-creating these\n\nconst EMPTY_ARRAY = [null, 0];\nconst NO_SUBSCRIPTION_ARRAY = [null, null]; // Attempts to stringify whatever not-really-a-component value we were given\n// for logging in an error message\n\nconst stringifyComponent = Comp => {\n try {\n return JSON.stringify(Comp);\n } catch (err) {\n return String(Comp);\n }\n};\n\n// This is \"just\" a `useLayoutEffect`, but with two modifications:\n// - we need to fall back to `useEffect` in SSR to avoid annoying warnings\n// - we extract this to a separate function to avoid closing over values\n// and causing memory leaks\nfunction useIsomorphicLayoutEffectWithArgs(effectFunc, effectArgs, dependencies) {\n useIsomorphicLayoutEffect(() => effectFunc(...effectArgs), dependencies);\n} // Effect callback, extracted: assign the latest props values to refs for later usage\n\n\nfunction captureWrapperProps(lastWrapperProps, lastChildProps, renderIsScheduled, wrapperProps, // actualChildProps: unknown,\nchildPropsFromStoreUpdate, notifyNestedSubs) {\n // We want to capture the wrapper props and child props we used for later comparisons\n lastWrapperProps.current = wrapperProps;\n renderIsScheduled.current = false; // If the render was from a store update, clear out that reference and cascade the subscriber update\n\n if (childPropsFromStoreUpdate.current) {\n childPropsFromStoreUpdate.current = null;\n notifyNestedSubs();\n }\n} // Effect callback, extracted: subscribe to the Redux store or nearest connected ancestor,\n// check for updates after dispatched actions, and trigger re-renders.\n\n\nfunction subscribeUpdates(shouldHandleStateChanges, store, subscription, childPropsSelector, lastWrapperProps, lastChildProps, renderIsScheduled, isMounted, childPropsFromStoreUpdate, notifyNestedSubs, // forceComponentUpdateDispatch: React.Dispatch,\nadditionalSubscribeListener) {\n // If we're not subscribed to the store, nothing to do here\n if (!shouldHandleStateChanges) return () => {}; // Capture values for checking if and when this component unmounts\n\n let didUnsubscribe = false;\n let lastThrownError = null; // We'll run this callback every time a store subscription update propagates to this component\n\n const checkForUpdates = () => {\n if (didUnsubscribe || !isMounted.current) {\n // Don't run stale listeners.\n // Redux doesn't guarantee unsubscriptions happen until next dispatch.\n return;\n } // TODO We're currently calling getState ourselves here, rather than letting `uSES` do it\n\n\n const latestStoreState = store.getState();\n let newChildProps, error;\n\n try {\n // Actually run the selector with the most recent store state and wrapper props\n // to determine what the child props should be\n newChildProps = childPropsSelector(latestStoreState, lastWrapperProps.current);\n } catch (e) {\n error = e;\n lastThrownError = e;\n }\n\n if (!error) {\n lastThrownError = null;\n } // If the child props haven't changed, nothing to do here - cascade the subscription update\n\n\n if (newChildProps === lastChildProps.current) {\n if (!renderIsScheduled.current) {\n notifyNestedSubs();\n }\n } else {\n // Save references to the new child props. Note that we track the \"child props from store update\"\n // as a ref instead of a useState/useReducer because we need a way to determine if that value has\n // been processed. If this went into useState/useReducer, we couldn't clear out the value without\n // forcing another re-render, which we don't want.\n lastChildProps.current = newChildProps;\n childPropsFromStoreUpdate.current = newChildProps;\n renderIsScheduled.current = true; // TODO This is hacky and not how `uSES` is meant to be used\n // Trigger the React `useSyncExternalStore` subscriber\n\n additionalSubscribeListener();\n }\n }; // Actually subscribe to the nearest connected ancestor (or store)\n\n\n subscription.onStateChange = checkForUpdates;\n subscription.trySubscribe(); // Pull data from the store after first render in case the store has\n // changed since we began.\n\n checkForUpdates();\n\n const unsubscribeWrapper = () => {\n didUnsubscribe = true;\n subscription.tryUnsubscribe();\n subscription.onStateChange = null;\n\n if (lastThrownError) {\n // It's possible that we caught an error due to a bad mapState function, but the\n // parent re-rendered without this component and we're about to unmount.\n // This shouldn't happen as long as we do top-down subscriptions correctly, but\n // if we ever do those wrong, this throw will surface the error in our tests.\n // In that case, throw the error from here so it doesn't get lost.\n throw lastThrownError;\n }\n };\n\n return unsubscribeWrapper;\n} // Reducer initial state creation for our update reducer\n\n\nconst initStateUpdates = () => EMPTY_ARRAY;\n\nfunction strictEqual(a, b) {\n return a === b;\n}\n/**\r\n * Infers the type of props that a connector will inject into a component.\r\n */\n\n\nlet hasWarnedAboutDeprecatedPureOption = false;\n/**\r\n * Connects a React component to a Redux store.\r\n *\r\n * - Without arguments, just wraps the component, without changing the behavior / props\r\n *\r\n * - If 2 params are passed (3rd param, mergeProps, is skipped), default behavior\r\n * is to override ownProps (as stated in the docs), so what remains is everything that's\r\n * not a state or dispatch prop\r\n *\r\n * - When 3rd param is passed, we don't know if ownProps propagate and whether they\r\n * should be valid component props, because it depends on mergeProps implementation.\r\n * As such, it is the user's responsibility to extend ownProps interface from state or\r\n * dispatch props or both when applicable\r\n *\r\n * @param mapStateToProps A function that extracts values from state\r\n * @param mapDispatchToProps Setup for dispatching actions\r\n * @param mergeProps Optional callback to merge state and dispatch props together\r\n * @param options Options for configuring the connection\r\n *\r\n */\n\nfunction connect(mapStateToProps, mapDispatchToProps, mergeProps, {\n // The `pure` option has been removed, so TS doesn't like us destructuring this to check its existence.\n // @ts-ignore\n pure,\n areStatesEqual = strictEqual,\n areOwnPropsEqual = shallowEqual,\n areStatePropsEqual = shallowEqual,\n areMergedPropsEqual = shallowEqual,\n // use React's forwardRef to expose a ref of the wrapped component\n forwardRef = false,\n // the context consumer to use\n context = ReactReduxContext\n} = {}) {\n if (process.env.NODE_ENV !== 'production') {\n if (pure !== undefined && !hasWarnedAboutDeprecatedPureOption) {\n hasWarnedAboutDeprecatedPureOption = true;\n warning('The `pure` option has been removed. `connect` is now always a \"pure/memoized\" component');\n }\n }\n\n const Context = context;\n const initMapStateToProps = mapStateToPropsFactory(mapStateToProps);\n const initMapDispatchToProps = mapDispatchToPropsFactory(mapDispatchToProps);\n const initMergeProps = mergePropsFactory(mergeProps);\n const shouldHandleStateChanges = Boolean(mapStateToProps);\n\n const wrapWithConnect = WrappedComponent => {\n if (process.env.NODE_ENV !== 'production' && !isValidElementType(WrappedComponent)) {\n throw new Error(`You must pass a component to the function returned by connect. Instead received ${stringifyComponent(WrappedComponent)}`);\n }\n\n const wrappedComponentName = WrappedComponent.displayName || WrappedComponent.name || 'Component';\n const displayName = `Connect(${wrappedComponentName})`;\n const selectorFactoryOptions = {\n shouldHandleStateChanges,\n displayName,\n wrappedComponentName,\n WrappedComponent,\n // @ts-ignore\n initMapStateToProps,\n // @ts-ignore\n initMapDispatchToProps,\n initMergeProps,\n areStatesEqual,\n areStatePropsEqual,\n areOwnPropsEqual,\n areMergedPropsEqual\n };\n\n function ConnectFunction(props) {\n const [propsContext, reactReduxForwardedRef, wrapperProps] = React.useMemo(() => {\n // Distinguish between actual \"data\" props that were passed to the wrapper component,\n // and values needed to control behavior (forwarded refs, alternate context instances).\n // To maintain the wrapperProps object reference, memoize this destructuring.\n const {\n reactReduxForwardedRef\n } = props,\n wrapperProps = _objectWithoutPropertiesLoose(props, _excluded);\n\n return [props.context, reactReduxForwardedRef, wrapperProps];\n }, [props]);\n const ContextToUse = React.useMemo(() => {\n // Users may optionally pass in a custom context instance to use instead of our ReactReduxContext.\n // Memoize the check that determines which context instance we should use.\n return propsContext && propsContext.Consumer && // @ts-ignore\n isContextConsumer( /*#__PURE__*/React.createElement(propsContext.Consumer, null)) ? propsContext : Context;\n }, [propsContext, Context]); // Retrieve the store and ancestor subscription via context, if available\n\n const contextValue = React.useContext(ContextToUse); // The store _must_ exist as either a prop or in context.\n // We'll check to see if it _looks_ like a Redux store first.\n // This allows us to pass through a `store` prop that is just a plain value.\n\n const didStoreComeFromProps = Boolean(props.store) && Boolean(props.store.getState) && Boolean(props.store.dispatch);\n const didStoreComeFromContext = Boolean(contextValue) && Boolean(contextValue.store);\n\n if (process.env.NODE_ENV !== 'production' && !didStoreComeFromProps && !didStoreComeFromContext) {\n throw new Error(`Could not find \"store\" in the context of ` + `\"${displayName}\". Either wrap the root component in a , ` + `or pass a custom React context provider to and the corresponding ` + `React context consumer to ${displayName} in connect options.`);\n } // Based on the previous check, one of these must be true\n\n\n const store = didStoreComeFromProps ? props.store : contextValue.store;\n const getServerState = didStoreComeFromContext ? contextValue.getServerState : store.getState;\n const childPropsSelector = React.useMemo(() => {\n // The child props selector needs the store reference as an input.\n // Re-create this selector whenever the store changes.\n return defaultSelectorFactory(store.dispatch, selectorFactoryOptions);\n }, [store]);\n const [subscription, notifyNestedSubs] = React.useMemo(() => {\n if (!shouldHandleStateChanges) return NO_SUBSCRIPTION_ARRAY; // This Subscription's source should match where store came from: props vs. context. A component\n // connected to the store via props shouldn't use subscription from context, or vice versa.\n\n const subscription = createSubscription(store, didStoreComeFromProps ? undefined : contextValue.subscription); // `notifyNestedSubs` is duplicated to handle the case where the component is unmounted in\n // the middle of the notification loop, where `subscription` will then be null. This can\n // probably be avoided if Subscription's listeners logic is changed to not call listeners\n // that have been unsubscribed in the middle of the notification loop.\n\n const notifyNestedSubs = subscription.notifyNestedSubs.bind(subscription);\n return [subscription, notifyNestedSubs];\n }, [store, didStoreComeFromProps, contextValue]); // Determine what {store, subscription} value should be put into nested context, if necessary,\n // and memoize that value to avoid unnecessary context updates.\n\n const overriddenContextValue = React.useMemo(() => {\n if (didStoreComeFromProps) {\n // This component is directly subscribed to a store from props.\n // We don't want descendants reading from this store - pass down whatever\n // the existing context value is from the nearest connected ancestor.\n return contextValue;\n } // Otherwise, put this component's subscription instance into context, so that\n // connected descendants won't update until after this component is done\n\n\n return _extends({}, contextValue, {\n subscription\n });\n }, [didStoreComeFromProps, contextValue, subscription]); // Set up refs to coordinate values between the subscription effect and the render logic\n\n const lastChildProps = React.useRef();\n const lastWrapperProps = React.useRef(wrapperProps);\n const childPropsFromStoreUpdate = React.useRef();\n const renderIsScheduled = React.useRef(false);\n const isProcessingDispatch = React.useRef(false);\n const isMounted = React.useRef(false);\n const latestSubscriptionCallbackError = React.useRef();\n useIsomorphicLayoutEffect(() => {\n isMounted.current = true;\n return () => {\n isMounted.current = false;\n };\n }, []);\n const actualChildPropsSelector = React.useMemo(() => {\n const selector = () => {\n // Tricky logic here:\n // - This render may have been triggered by a Redux store update that produced new child props\n // - However, we may have gotten new wrapper props after that\n // If we have new child props, and the same wrapper props, we know we should use the new child props as-is.\n // But, if we have new wrapper props, those might change the child props, so we have to recalculate things.\n // So, we'll use the child props from store update only if the wrapper props are the same as last time.\n if (childPropsFromStoreUpdate.current && wrapperProps === lastWrapperProps.current) {\n return childPropsFromStoreUpdate.current;\n } // TODO We're reading the store directly in render() here. Bad idea?\n // This will likely cause Bad Things (TM) to happen in Concurrent Mode.\n // Note that we do this because on renders _not_ caused by store updates, we need the latest store state\n // to determine what the child props should be.\n\n\n return childPropsSelector(store.getState(), wrapperProps);\n };\n\n return selector;\n }, [store, wrapperProps]); // We need this to execute synchronously every time we re-render. However, React warns\n // about useLayoutEffect in SSR, so we try to detect environment and fall back to\n // just useEffect instead to avoid the warning, since neither will run anyway.\n\n const subscribeForReact = React.useMemo(() => {\n const subscribe = reactListener => {\n if (!subscription) {\n return () => {};\n }\n\n return subscribeUpdates(shouldHandleStateChanges, store, subscription, // @ts-ignore\n childPropsSelector, lastWrapperProps, lastChildProps, renderIsScheduled, isMounted, childPropsFromStoreUpdate, notifyNestedSubs, reactListener);\n };\n\n return subscribe;\n }, [subscription]);\n useIsomorphicLayoutEffectWithArgs(captureWrapperProps, [lastWrapperProps, lastChildProps, renderIsScheduled, wrapperProps, childPropsFromStoreUpdate, notifyNestedSubs]);\n let actualChildProps;\n\n try {\n actualChildProps = useSyncExternalStore( // TODO We're passing through a big wrapper that does a bunch of extra side effects besides subscribing\n subscribeForReact, // TODO This is incredibly hacky. We've already processed the store update and calculated new child props,\n // TODO and we're just passing that through so it triggers a re-render for us rather than relying on `uSES`.\n actualChildPropsSelector, getServerState ? () => childPropsSelector(getServerState(), wrapperProps) : actualChildPropsSelector);\n } catch (err) {\n if (latestSubscriptionCallbackError.current) {\n ;\n err.message += `\\nThe error may be correlated with this previous error:\\n${latestSubscriptionCallbackError.current.stack}\\n\\n`;\n }\n\n throw err;\n }\n\n useIsomorphicLayoutEffect(() => {\n latestSubscriptionCallbackError.current = undefined;\n childPropsFromStoreUpdate.current = undefined;\n lastChildProps.current = actualChildProps;\n }); // Now that all that's done, we can finally try to actually render the child component.\n // We memoize the elements for the rendered child component as an optimization.\n\n const renderedWrappedComponent = React.useMemo(() => {\n return (\n /*#__PURE__*/\n // @ts-ignore\n React.createElement(WrappedComponent, _extends({}, actualChildProps, {\n ref: reactReduxForwardedRef\n }))\n );\n }, [reactReduxForwardedRef, WrappedComponent, actualChildProps]); // If React sees the exact same element reference as last time, it bails out of re-rendering\n // that child, same as if it was wrapped in React.memo() or returned false from shouldComponentUpdate.\n\n const renderedChild = React.useMemo(() => {\n if (shouldHandleStateChanges) {\n // If this component is subscribed to store updates, we need to pass its own\n // subscription instance down to our descendants. That means rendering the same\n // Context instance, and putting a different value into the context.\n return /*#__PURE__*/React.createElement(ContextToUse.Provider, {\n value: overriddenContextValue\n }, renderedWrappedComponent);\n }\n\n return renderedWrappedComponent;\n }, [ContextToUse, renderedWrappedComponent, overriddenContextValue]);\n return renderedChild;\n }\n\n const _Connect = React.memo(ConnectFunction);\n\n // Add a hacky cast to get the right output type\n const Connect = _Connect;\n Connect.WrappedComponent = WrappedComponent;\n Connect.displayName = ConnectFunction.displayName = displayName;\n\n if (forwardRef) {\n const _forwarded = React.forwardRef(function forwardConnectRef(props, ref) {\n // @ts-ignore\n return /*#__PURE__*/React.createElement(Connect, _extends({}, props, {\n reactReduxForwardedRef: ref\n }));\n });\n\n const forwarded = _forwarded;\n forwarded.displayName = displayName;\n forwarded.WrappedComponent = WrappedComponent;\n return hoistStatics(forwarded, WrappedComponent);\n }\n\n return hoistStatics(Connect, WrappedComponent);\n };\n\n return wrapWithConnect;\n}\n\nexport default connect;","import * as React from 'react';\nimport { ReactReduxContext } from './Context';\nimport { createSubscription } from '../utils/Subscription';\nimport { useIsomorphicLayoutEffect } from '../utils/useIsomorphicLayoutEffect';\n\nfunction Provider({\n store,\n context,\n children,\n serverState,\n stabilityCheck = 'once',\n noopCheck = 'once'\n}) {\n const contextValue = React.useMemo(() => {\n const subscription = createSubscription(store);\n return {\n store,\n subscription,\n getServerState: serverState ? () => serverState : undefined,\n stabilityCheck,\n noopCheck\n };\n }, [store, serverState, stabilityCheck, noopCheck]);\n const previousState = React.useMemo(() => store.getState(), [store]);\n useIsomorphicLayoutEffect(() => {\n const {\n subscription\n } = contextValue;\n subscription.onStateChange = subscription.notifyNestedSubs;\n subscription.trySubscribe();\n\n if (previousState !== store.getState()) {\n subscription.notifyNestedSubs();\n }\n\n return () => {\n subscription.tryUnsubscribe();\n subscription.onStateChange = undefined;\n };\n }, [contextValue, previousState]);\n const Context = context || ReactReduxContext; // @ts-ignore 'AnyAction' is assignable to the constraint of type 'A', but 'A' could be instantiated with a different subtype\n\n return /*#__PURE__*/React.createElement(Context.Provider, {\n value: contextValue\n }, children);\n}\n\nexport default Provider;","import { ReactReduxContext } from '../components/Context';\nimport { useReduxContext as useDefaultReduxContext, createReduxContextHook } from './useReduxContext';\n/**\r\n * Hook factory, which creates a `useStore` hook bound to a given context.\r\n *\r\n * @param {React.Context} [context=ReactReduxContext] Context passed to your ``.\r\n * @returns {Function} A `useStore` hook bound to the specified context.\r\n */\n\nexport function createStoreHook(context = ReactReduxContext) {\n const useReduxContext = // @ts-ignore\n context === ReactReduxContext ? useDefaultReduxContext : // @ts-ignore\n createReduxContextHook(context);\n return function useStore() {\n const {\n store\n } = useReduxContext(); // @ts-ignore\n\n return store;\n };\n}\n/**\r\n * A hook to access the redux store.\r\n *\r\n * @returns {any} the redux store\r\n *\r\n * @example\r\n *\r\n * import React from 'react'\r\n * import { useStore } from 'react-redux'\r\n *\r\n * export const ExampleComponent = () => {\r\n * const store = useStore()\r\n * return
{store.getState()}
\r\n * }\r\n */\n\nexport const useStore = /*#__PURE__*/createStoreHook();","import { ReactReduxContext } from '../components/Context';\nimport { useStore as useDefaultStore, createStoreHook } from './useStore';\n/**\r\n * Hook factory, which creates a `useDispatch` hook bound to a given context.\r\n *\r\n * @param {React.Context} [context=ReactReduxContext] Context passed to your ``.\r\n * @returns {Function} A `useDispatch` hook bound to the specified context.\r\n */\n\nexport function createDispatchHook(context = ReactReduxContext) {\n const useStore = // @ts-ignore\n context === ReactReduxContext ? useDefaultStore : createStoreHook(context);\n return function useDispatch() {\n const store = useStore(); // @ts-ignore\n\n return store.dispatch;\n };\n}\n/**\r\n * A hook to access the redux `dispatch` function.\r\n *\r\n * @returns {any|function} redux store's `dispatch` function\r\n *\r\n * @example\r\n *\r\n * import React, { useCallback } from 'react'\r\n * import { useDispatch } from 'react-redux'\r\n *\r\n * export const CounterComponent = ({ value }) => {\r\n * const dispatch = useDispatch()\r\n * const increaseCounter = useCallback(() => dispatch({ type: 'increase-counter' }), [])\r\n * return (\r\n *
\r\n * {value}\r\n * \r\n *
\r\n * )\r\n * }\r\n */\n\nexport const useDispatch = /*#__PURE__*/createDispatchHook();","// The primary entry point assumes we're working with standard ReactDOM/RN, but\n// older versions that do not include `useSyncExternalStore` (React 16.9 - 17.x).\n// Because of that, the useSyncExternalStore compat shim is needed.\nimport { useSyncExternalStore } from 'use-sync-external-store/shim';\nimport { useSyncExternalStoreWithSelector } from 'use-sync-external-store/shim/with-selector';\nimport { unstable_batchedUpdates as batch } from './utils/reactBatchedUpdates';\nimport { setBatch } from './utils/batch';\nimport { initializeUseSelector } from './hooks/useSelector';\nimport { initializeConnect } from './components/connect';\ninitializeUseSelector(useSyncExternalStoreWithSelector);\ninitializeConnect(useSyncExternalStore); // Enable batched updates in our subscriptions for use\n// with standard React renderers (ReactDOM, React Native)\n\nsetBatch(batch);\nexport { batch };\nexport * from './exports';","import * as React from 'react';\nconst ThemeContext = /*#__PURE__*/React.createContext(null);\nif (process.env.NODE_ENV !== 'production') {\n ThemeContext.displayName = 'ThemeContext';\n}\nexport default ThemeContext;","import * as React from 'react';\nimport ThemeContext from './ThemeContext';\nexport default function useTheme() {\n const theme = React.useContext(ThemeContext);\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useDebugValue(theme);\n }\n return theme;\n}","const hasSymbol = typeof Symbol === 'function' && Symbol.for;\nexport default hasSymbol ? Symbol.for('mui.nested') : '__THEME_NESTED__';","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { exactProp } from '@mui/utils';\nimport ThemeContext from '../useTheme/ThemeContext';\nimport useTheme from '../useTheme';\nimport nested from './nested';\n\n// To support composition of theme.\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nfunction mergeOuterLocalTheme(outerTheme, localTheme) {\n if (typeof localTheme === 'function') {\n const mergedTheme = localTheme(outerTheme);\n if (process.env.NODE_ENV !== 'production') {\n if (!mergedTheme) {\n console.error(['MUI: You should return an object from your theme function, i.e.', ' ({})} />'].join('\\n'));\n }\n }\n return mergedTheme;\n }\n return _extends({}, outerTheme, localTheme);\n}\n\n/**\n * This component takes a `theme` prop.\n * It makes the `theme` available down the React tree thanks to React context.\n * This component should preferably be used at **the root of your component tree**.\n */\nfunction ThemeProvider(props) {\n const {\n children,\n theme: localTheme\n } = props;\n const outerTheme = useTheme();\n if (process.env.NODE_ENV !== 'production') {\n if (outerTheme === null && typeof localTheme === 'function') {\n console.error(['MUI: You are providing a theme function prop to the ThemeProvider component:', ' outerTheme} />', '', 'However, no outer theme is present.', 'Make sure a theme is already injected higher in the React tree ' + 'or provide a theme object.'].join('\\n'));\n }\n }\n const theme = React.useMemo(() => {\n const output = outerTheme === null ? localTheme : mergeOuterLocalTheme(outerTheme, localTheme);\n if (output != null) {\n output[nested] = outerTheme !== null;\n }\n return output;\n }, [localTheme, outerTheme]);\n return /*#__PURE__*/_jsx(ThemeContext.Provider, {\n value: theme,\n children: children\n });\n}\nprocess.env.NODE_ENV !== \"production\" ? ThemeProvider.propTypes = {\n /**\n * Your component tree.\n */\n children: PropTypes.node,\n /**\n * A theme object. You can provide a function to extend the outer theme.\n */\n theme: PropTypes.oneOfType([PropTypes.object, PropTypes.func]).isRequired\n} : void 0;\nif (process.env.NODE_ENV !== 'production') {\n process.env.NODE_ENV !== \"production\" ? ThemeProvider.propTypes = exactProp(ThemeProvider.propTypes) : void 0;\n}\nexport default ThemeProvider;","'use client';\n\nimport * as React from 'react';\nimport { ThemeContext } from '@mui/styled-engine';\nfunction isObjectEmpty(obj) {\n return Object.keys(obj).length === 0;\n}\nfunction useTheme(defaultTheme = null) {\n const contextTheme = React.useContext(ThemeContext);\n return !contextTheme || isObjectEmpty(contextTheme) ? defaultTheme : contextTheme;\n}\nexport default useTheme;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"value\"];\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst RtlContext = /*#__PURE__*/React.createContext();\nfunction RtlProvider(_ref) {\n let {\n value\n } = _ref,\n props = _objectWithoutPropertiesLoose(_ref, _excluded);\n return /*#__PURE__*/_jsx(RtlContext.Provider, _extends({\n value: value != null ? value : true\n }, props));\n}\nprocess.env.NODE_ENV !== \"production\" ? RtlProvider.propTypes = {\n children: PropTypes.node,\n value: PropTypes.bool\n} : void 0;\nexport const useRtl = () => {\n const value = React.useContext(RtlContext);\n return value != null ? value : false;\n};\nexport default RtlProvider;","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { ThemeProvider as MuiThemeProvider, useTheme as usePrivateTheme } from '@mui/private-theming';\nimport exactProp from '@mui/utils/exactProp';\nimport { ThemeContext as StyledEngineThemeContext } from '@mui/styled-engine';\nimport useThemeWithoutDefault from '../useThemeWithoutDefault';\nimport RtlProvider from '../RtlProvider';\nimport DefaultPropsProvider from '../DefaultPropsProvider';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst EMPTY_THEME = {};\nfunction useThemeScoping(themeId, upperTheme, localTheme, isPrivate = false) {\n return React.useMemo(() => {\n const resolvedTheme = themeId ? upperTheme[themeId] || upperTheme : upperTheme;\n if (typeof localTheme === 'function') {\n const mergedTheme = localTheme(resolvedTheme);\n const result = themeId ? _extends({}, upperTheme, {\n [themeId]: mergedTheme\n }) : mergedTheme;\n // must return a function for the private theme to NOT merge with the upper theme.\n // see the test case \"use provided theme from a callback\" in ThemeProvider.test.js\n if (isPrivate) {\n return () => result;\n }\n return result;\n }\n return themeId ? _extends({}, upperTheme, {\n [themeId]: localTheme\n }) : _extends({}, upperTheme, localTheme);\n }, [themeId, upperTheme, localTheme, isPrivate]);\n}\n\n/**\n * This component makes the `theme` available down the React tree.\n * It should preferably be used at **the root of your component tree**.\n *\n * // existing use case\n * // theme scoping\n */\nfunction ThemeProvider(props) {\n const {\n children,\n theme: localTheme,\n themeId\n } = props;\n const upperTheme = useThemeWithoutDefault(EMPTY_THEME);\n const upperPrivateTheme = usePrivateTheme() || EMPTY_THEME;\n if (process.env.NODE_ENV !== 'production') {\n if (upperTheme === null && typeof localTheme === 'function' || themeId && upperTheme && !upperTheme[themeId] && typeof localTheme === 'function') {\n console.error(['MUI: You are providing a theme function prop to the ThemeProvider component:', ' outerTheme} />', '', 'However, no outer theme is present.', 'Make sure a theme is already injected higher in the React tree ' + 'or provide a theme object.'].join('\\n'));\n }\n }\n const engineTheme = useThemeScoping(themeId, upperTheme, localTheme);\n const privateTheme = useThemeScoping(themeId, upperPrivateTheme, localTheme, true);\n const rtlValue = engineTheme.direction === 'rtl';\n return /*#__PURE__*/_jsx(MuiThemeProvider, {\n theme: privateTheme,\n children: /*#__PURE__*/_jsx(StyledEngineThemeContext.Provider, {\n value: engineTheme,\n children: /*#__PURE__*/_jsx(RtlProvider, {\n value: rtlValue,\n children: /*#__PURE__*/_jsx(DefaultPropsProvider, {\n value: engineTheme == null ? void 0 : engineTheme.components,\n children: children\n })\n })\n })\n });\n}\nprocess.env.NODE_ENV !== \"production\" ? ThemeProvider.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * Your component tree.\n */\n children: PropTypes.node,\n /**\n * A theme object. You can provide a function to extend the outer theme.\n */\n theme: PropTypes.oneOfType([PropTypes.func, PropTypes.object]).isRequired,\n /**\n * The design system's unique id for getting the corresponded theme when there are multiple design systems.\n */\n themeId: PropTypes.string\n} : void 0;\nif (process.env.NODE_ENV !== 'production') {\n process.env.NODE_ENV !== \"production\" ? ThemeProvider.propTypes = exactProp(ThemeProvider.propTypes) : void 0;\n}\nexport default ThemeProvider;","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"theme\"];\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { ThemeProvider as SystemThemeProvider } from '@mui/system';\nimport THEME_ID from './identifier';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default function ThemeProvider(_ref) {\n let {\n theme: themeInput\n } = _ref,\n props = _objectWithoutPropertiesLoose(_ref, _excluded);\n const scopedTheme = themeInput[THEME_ID];\n return /*#__PURE__*/_jsx(SystemThemeProvider, _extends({}, props, {\n themeId: scopedTheme ? THEME_ID : undefined,\n theme: scopedTheme || themeInput\n }));\n}\nprocess.env.NODE_ENV !== \"production\" ? ThemeProvider.propTypes = {\n /**\n * Your component tree.\n */\n children: PropTypes.node,\n /**\n * A theme object. You can provide a function to extend the outer theme.\n */\n theme: PropTypes.oneOfType([PropTypes.object, PropTypes.func]).isRequired\n} : void 0;","////////////////////////////////////////////////////////////////////////////////\n//#region Types and Constants\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * Actions represent the type of change to a location value.\n */\nexport enum Action {\n /**\n * A POP indicates a change to an arbitrary index in the history stack, such\n * as a back or forward navigation. It does not describe the direction of the\n * navigation, only that the current index changed.\n *\n * Note: This is the default action for newly created history objects.\n */\n Pop = \"POP\",\n\n /**\n * A PUSH indicates a new entry being added to the history stack, such as when\n * a link is clicked and a new page loads. When this happens, all subsequent\n * entries in the stack are lost.\n */\n Push = \"PUSH\",\n\n /**\n * A REPLACE indicates the entry at the current index in the history stack\n * being replaced by a new one.\n */\n Replace = \"REPLACE\",\n}\n\n/**\n * The pathname, search, and hash values of a URL.\n */\nexport interface Path {\n /**\n * A URL pathname, beginning with a /.\n */\n pathname: string;\n\n /**\n * A URL search string, beginning with a ?.\n */\n search: string;\n\n /**\n * A URL fragment identifier, beginning with a #.\n */\n hash: string;\n}\n\n// TODO: (v7) Change the Location generic default from `any` to `unknown` and\n// remove Remix `useLocation` wrapper.\n\n/**\n * An entry in a history stack. A location contains information about the\n * URL path, as well as possibly some arbitrary state and a key.\n */\nexport interface Location extends Path {\n /**\n * A value of arbitrary data associated with this location.\n */\n state: State;\n\n /**\n * A unique string associated with this location. May be used to safely store\n * and retrieve data in some other storage API, like `localStorage`.\n *\n * Note: This value is always \"default\" on the initial location.\n */\n key: string;\n}\n\n/**\n * A change to the current location.\n */\nexport interface Update {\n /**\n * The action that triggered the change.\n */\n action: Action;\n\n /**\n * The new location.\n */\n location: Location;\n\n /**\n * The delta between this location and the former location in the history stack\n */\n delta: number | null;\n}\n\n/**\n * A function that receives notifications about location changes.\n */\nexport interface Listener {\n (update: Update): void;\n}\n\n/**\n * Describes a location that is the destination of some navigation, either via\n * `history.push` or `history.replace`. This may be either a URL or the pieces\n * of a URL path.\n */\nexport type To = string | Partial;\n\n/**\n * A history is an interface to the navigation stack. The history serves as the\n * source of truth for the current location, as well as provides a set of\n * methods that may be used to change it.\n *\n * It is similar to the DOM's `window.history` object, but with a smaller, more\n * focused API.\n */\nexport interface History {\n /**\n * The last action that modified the current location. This will always be\n * Action.Pop when a history instance is first created. This value is mutable.\n */\n readonly action: Action;\n\n /**\n * The current location. This value is mutable.\n */\n readonly location: Location;\n\n /**\n * Returns a valid href for the given `to` value that may be used as\n * the value of an attribute.\n *\n * @param to - The destination URL\n */\n createHref(to: To): string;\n\n /**\n * Returns a URL for the given `to` value\n *\n * @param to - The destination URL\n */\n createURL(to: To): URL;\n\n /**\n * Encode a location the same way window.history would do (no-op for memory\n * history) so we ensure our PUSH/REPLACE navigations for data routers\n * behave the same as POP\n *\n * @param to Unencoded path\n */\n encodeLocation(to: To): Path;\n\n /**\n * Pushes a new location onto the history stack, increasing its length by one.\n * If there were any entries in the stack after the current one, they are\n * lost.\n *\n * @param to - The new URL\n * @param state - Data to associate with the new location\n */\n push(to: To, state?: any): void;\n\n /**\n * Replaces the current location in the history stack with a new one. The\n * location that was replaced will no longer be available.\n *\n * @param to - The new URL\n * @param state - Data to associate with the new location\n */\n replace(to: To, state?: any): void;\n\n /**\n * Navigates `n` entries backward/forward in the history stack relative to the\n * current index. For example, a \"back\" navigation would use go(-1).\n *\n * @param delta - The delta in the stack index\n */\n go(delta: number): void;\n\n /**\n * Sets up a listener that will be called whenever the current location\n * changes.\n *\n * @param listener - A function that will be called when the location changes\n * @returns unlisten - A function that may be used to stop listening\n */\n listen(listener: Listener): () => void;\n}\n\ntype HistoryState = {\n usr: any;\n key?: string;\n idx: number;\n};\n\nconst PopStateEventType = \"popstate\";\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Memory History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A user-supplied object that describes a location. Used when providing\n * entries to `createMemoryHistory` via its `initialEntries` option.\n */\nexport type InitialEntry = string | Partial;\n\nexport type MemoryHistoryOptions = {\n initialEntries?: InitialEntry[];\n initialIndex?: number;\n v5Compat?: boolean;\n};\n\n/**\n * A memory history stores locations in memory. This is useful in stateful\n * environments where there is no web browser, such as node tests or React\n * Native.\n */\nexport interface MemoryHistory extends History {\n /**\n * The current index in the history stack.\n */\n readonly index: number;\n}\n\n/**\n * Memory history stores the current location in memory. It is designed for use\n * in stateful non-browser environments like tests and React Native.\n */\nexport function createMemoryHistory(\n options: MemoryHistoryOptions = {}\n): MemoryHistory {\n let { initialEntries = [\"/\"], initialIndex, v5Compat = false } = options;\n let entries: Location[]; // Declare so we can access from createMemoryLocation\n entries = initialEntries.map((entry, index) =>\n createMemoryLocation(\n entry,\n typeof entry === \"string\" ? null : entry.state,\n index === 0 ? \"default\" : undefined\n )\n );\n let index = clampIndex(\n initialIndex == null ? entries.length - 1 : initialIndex\n );\n let action = Action.Pop;\n let listener: Listener | null = null;\n\n function clampIndex(n: number): number {\n return Math.min(Math.max(n, 0), entries.length - 1);\n }\n function getCurrentLocation(): Location {\n return entries[index];\n }\n function createMemoryLocation(\n to: To,\n state: any = null,\n key?: string\n ): Location {\n let location = createLocation(\n entries ? getCurrentLocation().pathname : \"/\",\n to,\n state,\n key\n );\n warning(\n location.pathname.charAt(0) === \"/\",\n `relative pathnames are not supported in memory history: ${JSON.stringify(\n to\n )}`\n );\n return location;\n }\n\n function createHref(to: To) {\n return typeof to === \"string\" ? to : createPath(to);\n }\n\n let history: MemoryHistory = {\n get index() {\n return index;\n },\n get action() {\n return action;\n },\n get location() {\n return getCurrentLocation();\n },\n createHref,\n createURL(to) {\n return new URL(createHref(to), \"http://localhost\");\n },\n encodeLocation(to: To) {\n let path = typeof to === \"string\" ? parsePath(to) : to;\n return {\n pathname: path.pathname || \"\",\n search: path.search || \"\",\n hash: path.hash || \"\",\n };\n },\n push(to, state) {\n action = Action.Push;\n let nextLocation = createMemoryLocation(to, state);\n index += 1;\n entries.splice(index, entries.length, nextLocation);\n if (v5Compat && listener) {\n listener({ action, location: nextLocation, delta: 1 });\n }\n },\n replace(to, state) {\n action = Action.Replace;\n let nextLocation = createMemoryLocation(to, state);\n entries[index] = nextLocation;\n if (v5Compat && listener) {\n listener({ action, location: nextLocation, delta: 0 });\n }\n },\n go(delta) {\n action = Action.Pop;\n let nextIndex = clampIndex(index + delta);\n let nextLocation = entries[nextIndex];\n index = nextIndex;\n if (listener) {\n listener({ action, location: nextLocation, delta });\n }\n },\n listen(fn: Listener) {\n listener = fn;\n return () => {\n listener = null;\n };\n },\n };\n\n return history;\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Browser History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A browser history stores the current location in regular URLs in a web\n * browser environment. This is the standard for most web apps and provides the\n * cleanest URLs the browser's address bar.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#browserhistory\n */\nexport interface BrowserHistory extends UrlHistory {}\n\nexport type BrowserHistoryOptions = UrlHistoryOptions;\n\n/**\n * Browser history stores the location in regular URLs. This is the standard for\n * most web apps, but it requires some configuration on the server to ensure you\n * serve the same app at multiple URLs.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#createbrowserhistory\n */\nexport function createBrowserHistory(\n options: BrowserHistoryOptions = {}\n): BrowserHistory {\n function createBrowserLocation(\n window: Window,\n globalHistory: Window[\"history\"]\n ) {\n let { pathname, search, hash } = window.location;\n return createLocation(\n \"\",\n { pathname, search, hash },\n // state defaults to `null` because `window.history.state` does\n (globalHistory.state && globalHistory.state.usr) || null,\n (globalHistory.state && globalHistory.state.key) || \"default\"\n );\n }\n\n function createBrowserHref(window: Window, to: To) {\n return typeof to === \"string\" ? to : createPath(to);\n }\n\n return getUrlBasedHistory(\n createBrowserLocation,\n createBrowserHref,\n null,\n options\n );\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Hash History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A hash history stores the current location in the fragment identifier portion\n * of the URL in a web browser environment.\n *\n * This is ideal for apps that do not control the server for some reason\n * (because the fragment identifier is never sent to the server), including some\n * shared hosting environments that do not provide fine-grained controls over\n * which pages are served at which URLs.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#hashhistory\n */\nexport interface HashHistory extends UrlHistory {}\n\nexport type HashHistoryOptions = UrlHistoryOptions;\n\n/**\n * Hash history stores the location in window.location.hash. This makes it ideal\n * for situations where you don't want to send the location to the server for\n * some reason, either because you do cannot configure it or the URL space is\n * reserved for something else.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#createhashhistory\n */\nexport function createHashHistory(\n options: HashHistoryOptions = {}\n): HashHistory {\n function createHashLocation(\n window: Window,\n globalHistory: Window[\"history\"]\n ) {\n let {\n pathname = \"/\",\n search = \"\",\n hash = \"\",\n } = parsePath(window.location.hash.substr(1));\n\n // Hash URL should always have a leading / just like window.location.pathname\n // does, so if an app ends up at a route like /#something then we add a\n // leading slash so all of our path-matching behaves the same as if it would\n // in a browser router. This is particularly important when there exists a\n // root splat route () since that matches internally against\n // \"/*\" and we'd expect /#something to 404 in a hash router app.\n if (!pathname.startsWith(\"/\") && !pathname.startsWith(\".\")) {\n pathname = \"/\" + pathname;\n }\n\n return createLocation(\n \"\",\n { pathname, search, hash },\n // state defaults to `null` because `window.history.state` does\n (globalHistory.state && globalHistory.state.usr) || null,\n (globalHistory.state && globalHistory.state.key) || \"default\"\n );\n }\n\n function createHashHref(window: Window, to: To) {\n let base = window.document.querySelector(\"base\");\n let href = \"\";\n\n if (base && base.getAttribute(\"href\")) {\n let url = window.location.href;\n let hashIndex = url.indexOf(\"#\");\n href = hashIndex === -1 ? url : url.slice(0, hashIndex);\n }\n\n return href + \"#\" + (typeof to === \"string\" ? to : createPath(to));\n }\n\n function validateHashLocation(location: Location, to: To) {\n warning(\n location.pathname.charAt(0) === \"/\",\n `relative pathnames are not supported in hash history.push(${JSON.stringify(\n to\n )})`\n );\n }\n\n return getUrlBasedHistory(\n createHashLocation,\n createHashHref,\n validateHashLocation,\n options\n );\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region UTILS\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * @private\n */\nexport function invariant(value: boolean, message?: string): asserts value;\nexport function invariant(\n value: T | null | undefined,\n message?: string\n): asserts value is T;\nexport function invariant(value: any, message?: string) {\n if (value === false || value === null || typeof value === \"undefined\") {\n throw new Error(message);\n }\n}\n\nexport function warning(cond: any, message: string) {\n if (!cond) {\n // eslint-disable-next-line no-console\n if (typeof console !== \"undefined\") console.warn(message);\n\n try {\n // Welcome to debugging history!\n //\n // This error is thrown as a convenience, so you can more easily\n // find the source for a warning that appears in the console by\n // enabling \"pause on exceptions\" in your JavaScript debugger.\n throw new Error(message);\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n}\n\nfunction createKey() {\n return Math.random().toString(36).substr(2, 8);\n}\n\n/**\n * For browser-based histories, we combine the state and key into an object\n */\nfunction getHistoryState(location: Location, index: number): HistoryState {\n return {\n usr: location.state,\n key: location.key,\n idx: index,\n };\n}\n\n/**\n * Creates a Location object with a unique key from the given Path\n */\nexport function createLocation(\n current: string | Location,\n to: To,\n state: any = null,\n key?: string\n): Readonly {\n let location: Readonly = {\n pathname: typeof current === \"string\" ? current : current.pathname,\n search: \"\",\n hash: \"\",\n ...(typeof to === \"string\" ? parsePath(to) : to),\n state,\n // TODO: This could be cleaned up. push/replace should probably just take\n // full Locations now and avoid the need to run through this flow at all\n // But that's a pretty big refactor to the current test suite so going to\n // keep as is for the time being and just let any incoming keys take precedence\n key: (to && (to as Location).key) || key || createKey(),\n };\n return location;\n}\n\n/**\n * Creates a string URL path from the given pathname, search, and hash components.\n */\nexport function createPath({\n pathname = \"/\",\n search = \"\",\n hash = \"\",\n}: Partial) {\n if (search && search !== \"?\")\n pathname += search.charAt(0) === \"?\" ? search : \"?\" + search;\n if (hash && hash !== \"#\")\n pathname += hash.charAt(0) === \"#\" ? hash : \"#\" + hash;\n return pathname;\n}\n\n/**\n * Parses a string URL path into its separate pathname, search, and hash components.\n */\nexport function parsePath(path: string): Partial {\n let parsedPath: Partial = {};\n\n if (path) {\n let hashIndex = path.indexOf(\"#\");\n if (hashIndex >= 0) {\n parsedPath.hash = path.substr(hashIndex);\n path = path.substr(0, hashIndex);\n }\n\n let searchIndex = path.indexOf(\"?\");\n if (searchIndex >= 0) {\n parsedPath.search = path.substr(searchIndex);\n path = path.substr(0, searchIndex);\n }\n\n if (path) {\n parsedPath.pathname = path;\n }\n }\n\n return parsedPath;\n}\n\nexport interface UrlHistory extends History {}\n\nexport type UrlHistoryOptions = {\n window?: Window;\n v5Compat?: boolean;\n};\n\nfunction getUrlBasedHistory(\n getLocation: (window: Window, globalHistory: Window[\"history\"]) => Location,\n createHref: (window: Window, to: To) => string,\n validateLocation: ((location: Location, to: To) => void) | null,\n options: UrlHistoryOptions = {}\n): UrlHistory {\n let { window = document.defaultView!, v5Compat = false } = options;\n let globalHistory = window.history;\n let action = Action.Pop;\n let listener: Listener | null = null;\n\n let index = getIndex()!;\n // Index should only be null when we initialize. If not, it's because the\n // user called history.pushState or history.replaceState directly, in which\n // case we should log a warning as it will result in bugs.\n if (index == null) {\n index = 0;\n globalHistory.replaceState({ ...globalHistory.state, idx: index }, \"\");\n }\n\n function getIndex(): number {\n let state = globalHistory.state || { idx: null };\n return state.idx;\n }\n\n function handlePop() {\n action = Action.Pop;\n let nextIndex = getIndex();\n let delta = nextIndex == null ? null : nextIndex - index;\n index = nextIndex;\n if (listener) {\n listener({ action, location: history.location, delta });\n }\n }\n\n function push(to: To, state?: any) {\n action = Action.Push;\n let location = createLocation(history.location, to, state);\n if (validateLocation) validateLocation(location, to);\n\n index = getIndex() + 1;\n let historyState = getHistoryState(location, index);\n let url = history.createHref(location);\n\n // try...catch because iOS limits us to 100 pushState calls :/\n try {\n globalHistory.pushState(historyState, \"\", url);\n } catch (error) {\n // If the exception is because `state` can't be serialized, let that throw\n // outwards just like a replace call would so the dev knows the cause\n // https://html.spec.whatwg.org/multipage/nav-history-apis.html#shared-history-push/replace-state-steps\n // https://html.spec.whatwg.org/multipage/structured-data.html#structuredserializeinternal\n if (error instanceof DOMException && error.name === \"DataCloneError\") {\n throw error;\n }\n // They are going to lose state here, but there is no real\n // way to warn them about it since the page will refresh...\n window.location.assign(url);\n }\n\n if (v5Compat && listener) {\n listener({ action, location: history.location, delta: 1 });\n }\n }\n\n function replace(to: To, state?: any) {\n action = Action.Replace;\n let location = createLocation(history.location, to, state);\n if (validateLocation) validateLocation(location, to);\n\n index = getIndex();\n let historyState = getHistoryState(location, index);\n let url = history.createHref(location);\n globalHistory.replaceState(historyState, \"\", url);\n\n if (v5Compat && listener) {\n listener({ action, location: history.location, delta: 0 });\n }\n }\n\n function createURL(to: To): URL {\n // window.location.origin is \"null\" (the literal string value) in Firefox\n // under certain conditions, notably when serving from a local HTML file\n // See https://bugzilla.mozilla.org/show_bug.cgi?id=878297\n let base =\n window.location.origin !== \"null\"\n ? window.location.origin\n : window.location.href;\n\n let href = typeof to === \"string\" ? to : createPath(to);\n // Treating this as a full URL will strip any trailing spaces so we need to\n // pre-encode them since they might be part of a matching splat param from\n // an ancestor route\n href = href.replace(/ $/, \"%20\");\n invariant(\n base,\n `No window.location.(origin|href) available to create URL for href: ${href}`\n );\n return new URL(href, base);\n }\n\n let history: History = {\n get action() {\n return action;\n },\n get location() {\n return getLocation(window, globalHistory);\n },\n listen(fn: Listener) {\n if (listener) {\n throw new Error(\"A history only accepts one active listener\");\n }\n window.addEventListener(PopStateEventType, handlePop);\n listener = fn;\n\n return () => {\n window.removeEventListener(PopStateEventType, handlePop);\n listener = null;\n };\n },\n createHref(to) {\n return createHref(window, to);\n },\n createURL,\n encodeLocation(to) {\n // Encode a Location the same way window.location would\n let url = createURL(to);\n return {\n pathname: url.pathname,\n search: url.search,\n hash: url.hash,\n };\n },\n push,\n replace,\n go(n) {\n return globalHistory.go(n);\n },\n };\n\n return history;\n}\n\n//#endregion\n","import type { Location, Path, To } from \"./history\";\nimport { invariant, parsePath, warning } from \"./history\";\n\n/**\n * Map of routeId -> data returned from a loader/action/error\n */\nexport interface RouteData {\n [routeId: string]: any;\n}\n\nexport enum ResultType {\n data = \"data\",\n deferred = \"deferred\",\n redirect = \"redirect\",\n error = \"error\",\n}\n\n/**\n * Successful result from a loader or action\n */\nexport interface SuccessResult {\n type: ResultType.data;\n data: unknown;\n statusCode?: number;\n headers?: Headers;\n}\n\n/**\n * Successful defer() result from a loader or action\n */\nexport interface DeferredResult {\n type: ResultType.deferred;\n deferredData: DeferredData;\n statusCode?: number;\n headers?: Headers;\n}\n\n/**\n * Redirect result from a loader or action\n */\nexport interface RedirectResult {\n type: ResultType.redirect;\n // We keep the raw Response for redirects so we can return it verbatim\n response: Response;\n}\n\n/**\n * Unsuccessful result from a loader or action\n */\nexport interface ErrorResult {\n type: ResultType.error;\n error: unknown;\n statusCode?: number;\n headers?: Headers;\n}\n\n/**\n * Result from a loader or action - potentially successful or unsuccessful\n */\nexport type DataResult =\n | SuccessResult\n | DeferredResult\n | RedirectResult\n | ErrorResult;\n\ntype LowerCaseFormMethod = \"get\" | \"post\" | \"put\" | \"patch\" | \"delete\";\ntype UpperCaseFormMethod = Uppercase;\n\n/**\n * Users can specify either lowercase or uppercase form methods on `
`,\n * useSubmit(), ``, etc.\n */\nexport type HTMLFormMethod = LowerCaseFormMethod | UpperCaseFormMethod;\n\n/**\n * Active navigation/fetcher form methods are exposed in lowercase on the\n * RouterState\n */\nexport type FormMethod = LowerCaseFormMethod;\nexport type MutationFormMethod = Exclude;\n\n/**\n * In v7, active navigation/fetcher form methods are exposed in uppercase on the\n * RouterState. This is to align with the normalization done via fetch().\n */\nexport type V7_FormMethod = UpperCaseFormMethod;\nexport type V7_MutationFormMethod = Exclude;\n\nexport type FormEncType =\n | \"application/x-www-form-urlencoded\"\n | \"multipart/form-data\"\n | \"application/json\"\n | \"text/plain\";\n\n// Thanks https://github.com/sindresorhus/type-fest!\ntype JsonObject = { [Key in string]: JsonValue } & {\n [Key in string]?: JsonValue | undefined;\n};\ntype JsonArray = JsonValue[] | readonly JsonValue[];\ntype JsonPrimitive = string | number | boolean | null;\ntype JsonValue = JsonPrimitive | JsonObject | JsonArray;\n\n/**\n * @private\n * Internal interface to pass around for action submissions, not intended for\n * external consumption\n */\nexport type Submission =\n | {\n formMethod: FormMethod | V7_FormMethod;\n formAction: string;\n formEncType: FormEncType;\n formData: FormData;\n json: undefined;\n text: undefined;\n }\n | {\n formMethod: FormMethod | V7_FormMethod;\n formAction: string;\n formEncType: FormEncType;\n formData: undefined;\n json: JsonValue;\n text: undefined;\n }\n | {\n formMethod: FormMethod | V7_FormMethod;\n formAction: string;\n formEncType: FormEncType;\n formData: undefined;\n json: undefined;\n text: string;\n };\n\n/**\n * @private\n * Arguments passed to route loader/action functions. Same for now but we keep\n * this as a private implementation detail in case they diverge in the future.\n */\ninterface DataFunctionArgs {\n request: Request;\n params: Params;\n context?: Context;\n}\n\n// TODO: (v7) Change the defaults from any to unknown in and remove Remix wrappers:\n// ActionFunction, ActionFunctionArgs, LoaderFunction, LoaderFunctionArgs\n// Also, make them a type alias instead of an interface\n\n/**\n * Arguments passed to loader functions\n */\nexport interface LoaderFunctionArgs\n extends DataFunctionArgs {}\n\n/**\n * Arguments passed to action functions\n */\nexport interface ActionFunctionArgs\n extends DataFunctionArgs {}\n\n/**\n * Loaders and actions can return anything except `undefined` (`null` is a\n * valid return value if there is no data to return). Responses are preferred\n * and will ease any future migration to Remix\n */\ntype DataFunctionValue = Response | NonNullable | null;\n\ntype DataFunctionReturnValue = Promise | DataFunctionValue;\n\n/**\n * Route loader function signature\n */\nexport type LoaderFunction = {\n (\n args: LoaderFunctionArgs,\n handlerCtx?: unknown\n ): DataFunctionReturnValue;\n} & { hydrate?: boolean };\n\n/**\n * Route action function signature\n */\nexport interface ActionFunction {\n (\n args: ActionFunctionArgs,\n handlerCtx?: unknown\n ): DataFunctionReturnValue;\n}\n\n/**\n * Arguments passed to shouldRevalidate function\n */\nexport interface ShouldRevalidateFunctionArgs {\n currentUrl: URL;\n currentParams: AgnosticDataRouteMatch[\"params\"];\n nextUrl: URL;\n nextParams: AgnosticDataRouteMatch[\"params\"];\n formMethod?: Submission[\"formMethod\"];\n formAction?: Submission[\"formAction\"];\n formEncType?: Submission[\"formEncType\"];\n text?: Submission[\"text\"];\n formData?: Submission[\"formData\"];\n json?: Submission[\"json\"];\n actionStatus?: number;\n actionResult?: any;\n defaultShouldRevalidate: boolean;\n}\n\n/**\n * Route shouldRevalidate function signature. This runs after any submission\n * (navigation or fetcher), so we flatten the navigation/fetcher submission\n * onto the arguments. It shouldn't matter whether it came from a navigation\n * or a fetcher, what really matters is the URLs and the formData since loaders\n * have to re-run based on the data models that were potentially mutated.\n */\nexport interface ShouldRevalidateFunction {\n (args: ShouldRevalidateFunctionArgs): boolean;\n}\n\n/**\n * Function provided by the framework-aware layers to set `hasErrorBoundary`\n * from the framework-aware `errorElement` prop\n *\n * @deprecated Use `mapRouteProperties` instead\n */\nexport interface DetectErrorBoundaryFunction {\n (route: AgnosticRouteObject): boolean;\n}\n\nexport interface DataStrategyMatch\n extends AgnosticRouteMatch {\n shouldLoad: boolean;\n resolve: (\n handlerOverride?: (\n handler: (ctx?: unknown) => DataFunctionReturnValue\n ) => DataFunctionReturnValue\n ) => Promise;\n}\n\nexport interface DataStrategyFunctionArgs\n extends DataFunctionArgs {\n matches: DataStrategyMatch[];\n fetcherKey: string | null;\n}\n\n/**\n * Result from a loader or action called via dataStrategy\n */\nexport interface DataStrategyResult {\n type: \"data\" | \"error\";\n result: unknown; // data, Error, Response, DeferredData, DataWithResponseInit\n}\n\nexport interface DataStrategyFunction {\n (args: DataStrategyFunctionArgs): Promise>;\n}\n\nexport type AgnosticPatchRoutesOnNavigationFunctionArgs<\n O extends AgnosticRouteObject = AgnosticRouteObject,\n M extends AgnosticRouteMatch = AgnosticRouteMatch\n> = {\n path: string;\n matches: M[];\n patch: (routeId: string | null, children: O[]) => void;\n};\n\nexport type AgnosticPatchRoutesOnNavigationFunction<\n O extends AgnosticRouteObject = AgnosticRouteObject,\n M extends AgnosticRouteMatch = AgnosticRouteMatch\n> = (\n opts: AgnosticPatchRoutesOnNavigationFunctionArgs\n) => void | Promise;\n\n/**\n * Function provided by the framework-aware layers to set any framework-specific\n * properties from framework-agnostic properties\n */\nexport interface MapRoutePropertiesFunction {\n (route: AgnosticRouteObject): {\n hasErrorBoundary: boolean;\n } & Record;\n}\n\n/**\n * Keys we cannot change from within a lazy() function. We spread all other keys\n * onto the route. Either they're meaningful to the router, or they'll get\n * ignored.\n */\nexport type ImmutableRouteKey =\n | \"lazy\"\n | \"caseSensitive\"\n | \"path\"\n | \"id\"\n | \"index\"\n | \"children\";\n\nexport const immutableRouteKeys = new Set([\n \"lazy\",\n \"caseSensitive\",\n \"path\",\n \"id\",\n \"index\",\n \"children\",\n]);\n\ntype RequireOne = Exclude<\n {\n [K in keyof T]: K extends Key ? Omit & Required> : never;\n }[keyof T],\n undefined\n>;\n\n/**\n * lazy() function to load a route definition, which can add non-matching\n * related properties to a route\n */\nexport interface LazyRouteFunction {\n (): Promise>>;\n}\n\n/**\n * Base RouteObject with common props shared by all types of routes\n */\ntype AgnosticBaseRouteObject = {\n caseSensitive?: boolean;\n path?: string;\n id?: string;\n loader?: LoaderFunction | boolean;\n action?: ActionFunction | boolean;\n hasErrorBoundary?: boolean;\n shouldRevalidate?: ShouldRevalidateFunction;\n handle?: any;\n lazy?: LazyRouteFunction;\n};\n\n/**\n * Index routes must not have children\n */\nexport type AgnosticIndexRouteObject = AgnosticBaseRouteObject & {\n children?: undefined;\n index: true;\n};\n\n/**\n * Non-index routes may have children, but cannot have index\n */\nexport type AgnosticNonIndexRouteObject = AgnosticBaseRouteObject & {\n children?: AgnosticRouteObject[];\n index?: false;\n};\n\n/**\n * A route object represents a logical route, with (optionally) its child\n * routes organized in a tree-like structure.\n */\nexport type AgnosticRouteObject =\n | AgnosticIndexRouteObject\n | AgnosticNonIndexRouteObject;\n\nexport type AgnosticDataIndexRouteObject = AgnosticIndexRouteObject & {\n id: string;\n};\n\nexport type AgnosticDataNonIndexRouteObject = AgnosticNonIndexRouteObject & {\n children?: AgnosticDataRouteObject[];\n id: string;\n};\n\n/**\n * A data route object, which is just a RouteObject with a required unique ID\n */\nexport type AgnosticDataRouteObject =\n | AgnosticDataIndexRouteObject\n | AgnosticDataNonIndexRouteObject;\n\nexport type RouteManifest = Record;\n\n// Recursive helper for finding path parameters in the absence of wildcards\ntype _PathParam =\n // split path into individual path segments\n Path extends `${infer L}/${infer R}`\n ? _PathParam | _PathParam\n : // find params after `:`\n Path extends `:${infer Param}`\n ? Param extends `${infer Optional}?`\n ? Optional\n : Param\n : // otherwise, there aren't any params present\n never;\n\n/**\n * Examples:\n * \"/a/b/*\" -> \"*\"\n * \":a\" -> \"a\"\n * \"/a/:b\" -> \"b\"\n * \"/a/blahblahblah:b\" -> \"b\"\n * \"/:a/:b\" -> \"a\" | \"b\"\n * \"/:a/b/:c/*\" -> \"a\" | \"c\" | \"*\"\n */\nexport type PathParam =\n // check if path is just a wildcard\n Path extends \"*\" | \"/*\"\n ? \"*\"\n : // look for wildcard at the end of the path\n Path extends `${infer Rest}/*`\n ? \"*\" | _PathParam\n : // look for params in the absence of wildcards\n _PathParam;\n\n// Attempt to parse the given string segment. If it fails, then just return the\n// plain string type as a default fallback. Otherwise, return the union of the\n// parsed string literals that were referenced as dynamic segments in the route.\nexport type ParamParseKey =\n // if you could not find path params, fallback to `string`\n [PathParam] extends [never] ? string : PathParam;\n\n/**\n * The parameters that were parsed from the URL path.\n */\nexport type Params = {\n readonly [key in Key]: string | undefined;\n};\n\n/**\n * A RouteMatch contains info about how a route matched a URL.\n */\nexport interface AgnosticRouteMatch<\n ParamKey extends string = string,\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n> {\n /**\n * The names and values of dynamic parameters in the URL.\n */\n params: Params;\n /**\n * The portion of the URL pathname that was matched.\n */\n pathname: string;\n /**\n * The portion of the URL pathname that was matched before child routes.\n */\n pathnameBase: string;\n /**\n * The route object that was used to match.\n */\n route: RouteObjectType;\n}\n\nexport interface AgnosticDataRouteMatch\n extends AgnosticRouteMatch {}\n\nfunction isIndexRoute(\n route: AgnosticRouteObject\n): route is AgnosticIndexRouteObject {\n return route.index === true;\n}\n\n// Walk the route tree generating unique IDs where necessary, so we are working\n// solely with AgnosticDataRouteObject's within the Router\nexport function convertRoutesToDataRoutes(\n routes: AgnosticRouteObject[],\n mapRouteProperties: MapRoutePropertiesFunction,\n parentPath: string[] = [],\n manifest: RouteManifest = {}\n): AgnosticDataRouteObject[] {\n return routes.map((route, index) => {\n let treePath = [...parentPath, String(index)];\n let id = typeof route.id === \"string\" ? route.id : treePath.join(\"-\");\n invariant(\n route.index !== true || !route.children,\n `Cannot specify children on an index route`\n );\n invariant(\n !manifest[id],\n `Found a route id collision on id \"${id}\". Route ` +\n \"id's must be globally unique within Data Router usages\"\n );\n\n if (isIndexRoute(route)) {\n let indexRoute: AgnosticDataIndexRouteObject = {\n ...route,\n ...mapRouteProperties(route),\n id,\n };\n manifest[id] = indexRoute;\n return indexRoute;\n } else {\n let pathOrLayoutRoute: AgnosticDataNonIndexRouteObject = {\n ...route,\n ...mapRouteProperties(route),\n id,\n children: undefined,\n };\n manifest[id] = pathOrLayoutRoute;\n\n if (route.children) {\n pathOrLayoutRoute.children = convertRoutesToDataRoutes(\n route.children,\n mapRouteProperties,\n treePath,\n manifest\n );\n }\n\n return pathOrLayoutRoute;\n }\n });\n}\n\n/**\n * Matches the given routes to a location and returns the match data.\n *\n * @see https://reactrouter.com/v6/utils/match-routes\n */\nexport function matchRoutes<\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n>(\n routes: RouteObjectType[],\n locationArg: Partial | string,\n basename = \"/\"\n): AgnosticRouteMatch[] | null {\n return matchRoutesImpl(routes, locationArg, basename, false);\n}\n\nexport function matchRoutesImpl<\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n>(\n routes: RouteObjectType[],\n locationArg: Partial | string,\n basename: string,\n allowPartial: boolean\n): AgnosticRouteMatch[] | null {\n let location =\n typeof locationArg === \"string\" ? parsePath(locationArg) : locationArg;\n\n let pathname = stripBasename(location.pathname || \"/\", basename);\n\n if (pathname == null) {\n return null;\n }\n\n let branches = flattenRoutes(routes);\n rankRouteBranches(branches);\n\n let matches = null;\n for (let i = 0; matches == null && i < branches.length; ++i) {\n // Incoming pathnames are generally encoded from either window.location\n // or from router.navigate, but we want to match against the unencoded\n // paths in the route definitions. Memory router locations won't be\n // encoded here but there also shouldn't be anything to decode so this\n // should be a safe operation. This avoids needing matchRoutes to be\n // history-aware.\n let decoded = decodePath(pathname);\n matches = matchRouteBranch(\n branches[i],\n decoded,\n allowPartial\n );\n }\n\n return matches;\n}\n\nexport interface UIMatch {\n id: string;\n pathname: string;\n params: AgnosticRouteMatch[\"params\"];\n data: Data;\n handle: Handle;\n}\n\nexport function convertRouteMatchToUiMatch(\n match: AgnosticDataRouteMatch,\n loaderData: RouteData\n): UIMatch {\n let { route, pathname, params } = match;\n return {\n id: route.id,\n pathname,\n params,\n data: loaderData[route.id],\n handle: route.handle,\n };\n}\n\ninterface RouteMeta<\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n> {\n relativePath: string;\n caseSensitive: boolean;\n childrenIndex: number;\n route: RouteObjectType;\n}\n\ninterface RouteBranch<\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n> {\n path: string;\n score: number;\n routesMeta: RouteMeta[];\n}\n\nfunction flattenRoutes<\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n>(\n routes: RouteObjectType[],\n branches: RouteBranch[] = [],\n parentsMeta: RouteMeta[] = [],\n parentPath = \"\"\n): RouteBranch[] {\n let flattenRoute = (\n route: RouteObjectType,\n index: number,\n relativePath?: string\n ) => {\n let meta: RouteMeta = {\n relativePath:\n relativePath === undefined ? route.path || \"\" : relativePath,\n caseSensitive: route.caseSensitive === true,\n childrenIndex: index,\n route,\n };\n\n if (meta.relativePath.startsWith(\"/\")) {\n invariant(\n meta.relativePath.startsWith(parentPath),\n `Absolute route path \"${meta.relativePath}\" nested under path ` +\n `\"${parentPath}\" is not valid. An absolute child route path ` +\n `must start with the combined path of all its parent routes.`\n );\n\n meta.relativePath = meta.relativePath.slice(parentPath.length);\n }\n\n let path = joinPaths([parentPath, meta.relativePath]);\n let routesMeta = parentsMeta.concat(meta);\n\n // Add the children before adding this route to the array, so we traverse the\n // route tree depth-first and child routes appear before their parents in\n // the \"flattened\" version.\n if (route.children && route.children.length > 0) {\n invariant(\n // Our types know better, but runtime JS may not!\n // @ts-expect-error\n route.index !== true,\n `Index routes must not have child routes. Please remove ` +\n `all child routes from route path \"${path}\".`\n );\n flattenRoutes(route.children, branches, routesMeta, path);\n }\n\n // Routes without a path shouldn't ever match by themselves unless they are\n // index routes, so don't add them to the list of possible branches.\n if (route.path == null && !route.index) {\n return;\n }\n\n branches.push({\n path,\n score: computeScore(path, route.index),\n routesMeta,\n });\n };\n routes.forEach((route, index) => {\n // coarse-grain check for optional params\n if (route.path === \"\" || !route.path?.includes(\"?\")) {\n flattenRoute(route, index);\n } else {\n for (let exploded of explodeOptionalSegments(route.path)) {\n flattenRoute(route, index, exploded);\n }\n }\n });\n\n return branches;\n}\n\n/**\n * Computes all combinations of optional path segments for a given path,\n * excluding combinations that are ambiguous and of lower priority.\n *\n * For example, `/one/:two?/three/:four?/:five?` explodes to:\n * - `/one/three`\n * - `/one/:two/three`\n * - `/one/three/:four`\n * - `/one/three/:five`\n * - `/one/:two/three/:four`\n * - `/one/:two/three/:five`\n * - `/one/three/:four/:five`\n * - `/one/:two/three/:four/:five`\n */\nfunction explodeOptionalSegments(path: string): string[] {\n let segments = path.split(\"/\");\n if (segments.length === 0) return [];\n\n let [first, ...rest] = segments;\n\n // Optional path segments are denoted by a trailing `?`\n let isOptional = first.endsWith(\"?\");\n // Compute the corresponding required segment: `foo?` -> `foo`\n let required = first.replace(/\\?$/, \"\");\n\n if (rest.length === 0) {\n // Intepret empty string as omitting an optional segment\n // `[\"one\", \"\", \"three\"]` corresponds to omitting `:two` from `/one/:two?/three` -> `/one/three`\n return isOptional ? [required, \"\"] : [required];\n }\n\n let restExploded = explodeOptionalSegments(rest.join(\"/\"));\n\n let result: string[] = [];\n\n // All child paths with the prefix. Do this for all children before the\n // optional version for all children, so we get consistent ordering where the\n // parent optional aspect is preferred as required. Otherwise, we can get\n // child sections interspersed where deeper optional segments are higher than\n // parent optional segments, where for example, /:two would explode _earlier_\n // then /:one. By always including the parent as required _for all children_\n // first, we avoid this issue\n result.push(\n ...restExploded.map((subpath) =>\n subpath === \"\" ? required : [required, subpath].join(\"/\")\n )\n );\n\n // Then, if this is an optional value, add all child versions without\n if (isOptional) {\n result.push(...restExploded);\n }\n\n // for absolute paths, ensure `/` instead of empty segment\n return result.map((exploded) =>\n path.startsWith(\"/\") && exploded === \"\" ? \"/\" : exploded\n );\n}\n\nfunction rankRouteBranches(branches: RouteBranch[]): void {\n branches.sort((a, b) =>\n a.score !== b.score\n ? b.score - a.score // Higher score first\n : compareIndexes(\n a.routesMeta.map((meta) => meta.childrenIndex),\n b.routesMeta.map((meta) => meta.childrenIndex)\n )\n );\n}\n\nconst paramRe = /^:[\\w-]+$/;\nconst dynamicSegmentValue = 3;\nconst indexRouteValue = 2;\nconst emptySegmentValue = 1;\nconst staticSegmentValue = 10;\nconst splatPenalty = -2;\nconst isSplat = (s: string) => s === \"*\";\n\nfunction computeScore(path: string, index: boolean | undefined): number {\n let segments = path.split(\"/\");\n let initialScore = segments.length;\n if (segments.some(isSplat)) {\n initialScore += splatPenalty;\n }\n\n if (index) {\n initialScore += indexRouteValue;\n }\n\n return segments\n .filter((s) => !isSplat(s))\n .reduce(\n (score, segment) =>\n score +\n (paramRe.test(segment)\n ? dynamicSegmentValue\n : segment === \"\"\n ? emptySegmentValue\n : staticSegmentValue),\n initialScore\n );\n}\n\nfunction compareIndexes(a: number[], b: number[]): number {\n let siblings =\n a.length === b.length && a.slice(0, -1).every((n, i) => n === b[i]);\n\n return siblings\n ? // If two routes are siblings, we should try to match the earlier sibling\n // first. This allows people to have fine-grained control over the matching\n // behavior by simply putting routes with identical paths in the order they\n // want them tried.\n a[a.length - 1] - b[b.length - 1]\n : // Otherwise, it doesn't really make sense to rank non-siblings by index,\n // so they sort equally.\n 0;\n}\n\nfunction matchRouteBranch<\n ParamKey extends string = string,\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n>(\n branch: RouteBranch,\n pathname: string,\n allowPartial = false\n): AgnosticRouteMatch[] | null {\n let { routesMeta } = branch;\n\n let matchedParams = {};\n let matchedPathname = \"/\";\n let matches: AgnosticRouteMatch[] = [];\n for (let i = 0; i < routesMeta.length; ++i) {\n let meta = routesMeta[i];\n let end = i === routesMeta.length - 1;\n let remainingPathname =\n matchedPathname === \"/\"\n ? pathname\n : pathname.slice(matchedPathname.length) || \"/\";\n let match = matchPath(\n { path: meta.relativePath, caseSensitive: meta.caseSensitive, end },\n remainingPathname\n );\n\n let route = meta.route;\n\n if (\n !match &&\n end &&\n allowPartial &&\n !routesMeta[routesMeta.length - 1].route.index\n ) {\n match = matchPath(\n {\n path: meta.relativePath,\n caseSensitive: meta.caseSensitive,\n end: false,\n },\n remainingPathname\n );\n }\n\n if (!match) {\n return null;\n }\n\n Object.assign(matchedParams, match.params);\n\n matches.push({\n // TODO: Can this as be avoided?\n params: matchedParams as Params,\n pathname: joinPaths([matchedPathname, match.pathname]),\n pathnameBase: normalizePathname(\n joinPaths([matchedPathname, match.pathnameBase])\n ),\n route,\n });\n\n if (match.pathnameBase !== \"/\") {\n matchedPathname = joinPaths([matchedPathname, match.pathnameBase]);\n }\n }\n\n return matches;\n}\n\n/**\n * Returns a path with params interpolated.\n *\n * @see https://reactrouter.com/v6/utils/generate-path\n */\nexport function generatePath(\n originalPath: Path,\n params: {\n [key in PathParam]: string | null;\n } = {} as any\n): string {\n let path: string = originalPath;\n if (path.endsWith(\"*\") && path !== \"*\" && !path.endsWith(\"/*\")) {\n warning(\n false,\n `Route path \"${path}\" will be treated as if it were ` +\n `\"${path.replace(/\\*$/, \"/*\")}\" because the \\`*\\` character must ` +\n `always follow a \\`/\\` in the pattern. To get rid of this warning, ` +\n `please change the route path to \"${path.replace(/\\*$/, \"/*\")}\".`\n );\n path = path.replace(/\\*$/, \"/*\") as Path;\n }\n\n // ensure `/` is added at the beginning if the path is absolute\n const prefix = path.startsWith(\"/\") ? \"/\" : \"\";\n\n const stringify = (p: any) =>\n p == null ? \"\" : typeof p === \"string\" ? p : String(p);\n\n const segments = path\n .split(/\\/+/)\n .map((segment, index, array) => {\n const isLastSegment = index === array.length - 1;\n\n // only apply the splat if it's the last segment\n if (isLastSegment && segment === \"*\") {\n const star = \"*\" as PathParam;\n // Apply the splat\n return stringify(params[star]);\n }\n\n const keyMatch = segment.match(/^:([\\w-]+)(\\??)$/);\n if (keyMatch) {\n const [, key, optional] = keyMatch;\n let param = params[key as PathParam];\n invariant(optional === \"?\" || param != null, `Missing \":${key}\" param`);\n return stringify(param);\n }\n\n // Remove any optional markers from optional static segments\n return segment.replace(/\\?$/g, \"\");\n })\n // Remove empty segments\n .filter((segment) => !!segment);\n\n return prefix + segments.join(\"/\");\n}\n\n/**\n * A PathPattern is used to match on some portion of a URL pathname.\n */\nexport interface PathPattern {\n /**\n * A string to match against a URL pathname. May contain `:id`-style segments\n * to indicate placeholders for dynamic parameters. May also end with `/*` to\n * indicate matching the rest of the URL pathname.\n */\n path: Path;\n /**\n * Should be `true` if the static portions of the `path` should be matched in\n * the same case.\n */\n caseSensitive?: boolean;\n /**\n * Should be `true` if this pattern should match the entire URL pathname.\n */\n end?: boolean;\n}\n\n/**\n * A PathMatch contains info about how a PathPattern matched on a URL pathname.\n */\nexport interface PathMatch {\n /**\n * The names and values of dynamic parameters in the URL.\n */\n params: Params;\n /**\n * The portion of the URL pathname that was matched.\n */\n pathname: string;\n /**\n * The portion of the URL pathname that was matched before child routes.\n */\n pathnameBase: string;\n /**\n * The pattern that was used to match.\n */\n pattern: PathPattern;\n}\n\ntype Mutable = {\n -readonly [P in keyof T]: T[P];\n};\n\n/**\n * Performs pattern matching on a URL pathname and returns information about\n * the match.\n *\n * @see https://reactrouter.com/v6/utils/match-path\n */\nexport function matchPath<\n ParamKey extends ParamParseKey,\n Path extends string\n>(\n pattern: PathPattern | Path,\n pathname: string\n): PathMatch | null {\n if (typeof pattern === \"string\") {\n pattern = { path: pattern, caseSensitive: false, end: true };\n }\n\n let [matcher, compiledParams] = compilePath(\n pattern.path,\n pattern.caseSensitive,\n pattern.end\n );\n\n let match = pathname.match(matcher);\n if (!match) return null;\n\n let matchedPathname = match[0];\n let pathnameBase = matchedPathname.replace(/(.)\\/+$/, \"$1\");\n let captureGroups = match.slice(1);\n let params: Params = compiledParams.reduce>(\n (memo, { paramName, isOptional }, index) => {\n // We need to compute the pathnameBase here using the raw splat value\n // instead of using params[\"*\"] later because it will be decoded then\n if (paramName === \"*\") {\n let splatValue = captureGroups[index] || \"\";\n pathnameBase = matchedPathname\n .slice(0, matchedPathname.length - splatValue.length)\n .replace(/(.)\\/+$/, \"$1\");\n }\n\n const value = captureGroups[index];\n if (isOptional && !value) {\n memo[paramName] = undefined;\n } else {\n memo[paramName] = (value || \"\").replace(/%2F/g, \"/\");\n }\n return memo;\n },\n {}\n );\n\n return {\n params,\n pathname: matchedPathname,\n pathnameBase,\n pattern,\n };\n}\n\ntype CompiledPathParam = { paramName: string; isOptional?: boolean };\n\nfunction compilePath(\n path: string,\n caseSensitive = false,\n end = true\n): [RegExp, CompiledPathParam[]] {\n warning(\n path === \"*\" || !path.endsWith(\"*\") || path.endsWith(\"/*\"),\n `Route path \"${path}\" will be treated as if it were ` +\n `\"${path.replace(/\\*$/, \"/*\")}\" because the \\`*\\` character must ` +\n `always follow a \\`/\\` in the pattern. To get rid of this warning, ` +\n `please change the route path to \"${path.replace(/\\*$/, \"/*\")}\".`\n );\n\n let params: CompiledPathParam[] = [];\n let regexpSource =\n \"^\" +\n path\n .replace(/\\/*\\*?$/, \"\") // Ignore trailing / and /*, we'll handle it below\n .replace(/^\\/*/, \"/\") // Make sure it has a leading /\n .replace(/[\\\\.*+^${}|()[\\]]/g, \"\\\\$&\") // Escape special regex chars\n .replace(\n /\\/:([\\w-]+)(\\?)?/g,\n (_: string, paramName: string, isOptional) => {\n params.push({ paramName, isOptional: isOptional != null });\n return isOptional ? \"/?([^\\\\/]+)?\" : \"/([^\\\\/]+)\";\n }\n );\n\n if (path.endsWith(\"*\")) {\n params.push({ paramName: \"*\" });\n regexpSource +=\n path === \"*\" || path === \"/*\"\n ? \"(.*)$\" // Already matched the initial /, just match the rest\n : \"(?:\\\\/(.+)|\\\\/*)$\"; // Don't include the / in params[\"*\"]\n } else if (end) {\n // When matching to the end, ignore trailing slashes\n regexpSource += \"\\\\/*$\";\n } else if (path !== \"\" && path !== \"/\") {\n // If our path is non-empty and contains anything beyond an initial slash,\n // then we have _some_ form of path in our regex, so we should expect to\n // match only if we find the end of this path segment. Look for an optional\n // non-captured trailing slash (to match a portion of the URL) or the end\n // of the path (if we've matched to the end). We used to do this with a\n // word boundary but that gives false positives on routes like\n // /user-preferences since `-` counts as a word boundary.\n regexpSource += \"(?:(?=\\\\/|$))\";\n } else {\n // Nothing to match for \"\" or \"/\"\n }\n\n let matcher = new RegExp(regexpSource, caseSensitive ? undefined : \"i\");\n\n return [matcher, params];\n}\n\nexport function decodePath(value: string) {\n try {\n return value\n .split(\"/\")\n .map((v) => decodeURIComponent(v).replace(/\\//g, \"%2F\"))\n .join(\"/\");\n } catch (error) {\n warning(\n false,\n `The URL path \"${value}\" could not be decoded because it is is a ` +\n `malformed URL segment. This is probably due to a bad percent ` +\n `encoding (${error}).`\n );\n\n return value;\n }\n}\n\n/**\n * @private\n */\nexport function stripBasename(\n pathname: string,\n basename: string\n): string | null {\n if (basename === \"/\") return pathname;\n\n if (!pathname.toLowerCase().startsWith(basename.toLowerCase())) {\n return null;\n }\n\n // We want to leave trailing slash behavior in the user's control, so if they\n // specify a basename with a trailing slash, we should support it\n let startIndex = basename.endsWith(\"/\")\n ? basename.length - 1\n : basename.length;\n let nextChar = pathname.charAt(startIndex);\n if (nextChar && nextChar !== \"/\") {\n // pathname does not start with basename/\n return null;\n }\n\n return pathname.slice(startIndex) || \"/\";\n}\n\n/**\n * Returns a resolved path object relative to the given pathname.\n *\n * @see https://reactrouter.com/v6/utils/resolve-path\n */\nexport function resolvePath(to: To, fromPathname = \"/\"): Path {\n let {\n pathname: toPathname,\n search = \"\",\n hash = \"\",\n } = typeof to === \"string\" ? parsePath(to) : to;\n\n let pathname = toPathname\n ? toPathname.startsWith(\"/\")\n ? toPathname\n : resolvePathname(toPathname, fromPathname)\n : fromPathname;\n\n return {\n pathname,\n search: normalizeSearch(search),\n hash: normalizeHash(hash),\n };\n}\n\nfunction resolvePathname(relativePath: string, fromPathname: string): string {\n let segments = fromPathname.replace(/\\/+$/, \"\").split(\"/\");\n let relativeSegments = relativePath.split(\"/\");\n\n relativeSegments.forEach((segment) => {\n if (segment === \"..\") {\n // Keep the root \"\" segment so the pathname starts at /\n if (segments.length > 1) segments.pop();\n } else if (segment !== \".\") {\n segments.push(segment);\n }\n });\n\n return segments.length > 1 ? segments.join(\"/\") : \"/\";\n}\n\nfunction getInvalidPathError(\n char: string,\n field: string,\n dest: string,\n path: Partial\n) {\n return (\n `Cannot include a '${char}' character in a manually specified ` +\n `\\`to.${field}\\` field [${JSON.stringify(\n path\n )}]. Please separate it out to the ` +\n `\\`to.${dest}\\` field. Alternatively you may provide the full path as ` +\n `a string in and the router will parse it for you.`\n );\n}\n\n/**\n * @private\n *\n * When processing relative navigation we want to ignore ancestor routes that\n * do not contribute to the path, such that index/pathless layout routes don't\n * interfere.\n *\n * For example, when moving a route element into an index route and/or a\n * pathless layout route, relative link behavior contained within should stay\n * the same. Both of the following examples should link back to the root:\n *\n * \n * \n * \n *\n * \n * \n * }> // <-- Does not contribute\n * // <-- Does not contribute\n * \n * \n */\nexport function getPathContributingMatches<\n T extends AgnosticRouteMatch = AgnosticRouteMatch\n>(matches: T[]) {\n return matches.filter(\n (match, index) =>\n index === 0 || (match.route.path && match.route.path.length > 0)\n );\n}\n\n// Return the array of pathnames for the current route matches - used to\n// generate the routePathnames input for resolveTo()\nexport function getResolveToMatches<\n T extends AgnosticRouteMatch = AgnosticRouteMatch\n>(matches: T[], v7_relativeSplatPath: boolean) {\n let pathMatches = getPathContributingMatches(matches);\n\n // When v7_relativeSplatPath is enabled, use the full pathname for the leaf\n // match so we include splat values for \".\" links. See:\n // https://github.com/remix-run/react-router/issues/11052#issuecomment-1836589329\n if (v7_relativeSplatPath) {\n return pathMatches.map((match, idx) =>\n idx === pathMatches.length - 1 ? match.pathname : match.pathnameBase\n );\n }\n\n return pathMatches.map((match) => match.pathnameBase);\n}\n\n/**\n * @private\n */\nexport function resolveTo(\n toArg: To,\n routePathnames: string[],\n locationPathname: string,\n isPathRelative = false\n): Path {\n let to: Partial;\n if (typeof toArg === \"string\") {\n to = parsePath(toArg);\n } else {\n to = { ...toArg };\n\n invariant(\n !to.pathname || !to.pathname.includes(\"?\"),\n getInvalidPathError(\"?\", \"pathname\", \"search\", to)\n );\n invariant(\n !to.pathname || !to.pathname.includes(\"#\"),\n getInvalidPathError(\"#\", \"pathname\", \"hash\", to)\n );\n invariant(\n !to.search || !to.search.includes(\"#\"),\n getInvalidPathError(\"#\", \"search\", \"hash\", to)\n );\n }\n\n let isEmptyPath = toArg === \"\" || to.pathname === \"\";\n let toPathname = isEmptyPath ? \"/\" : to.pathname;\n\n let from: string;\n\n // Routing is relative to the current pathname if explicitly requested.\n //\n // If a pathname is explicitly provided in `to`, it should be relative to the\n // route context. This is explained in `Note on `` values` in our\n // migration guide from v5 as a means of disambiguation between `to` values\n // that begin with `/` and those that do not. However, this is problematic for\n // `to` values that do not provide a pathname. `to` can simply be a search or\n // hash string, in which case we should assume that the navigation is relative\n // to the current location's pathname and *not* the route pathname.\n if (toPathname == null) {\n from = locationPathname;\n } else {\n let routePathnameIndex = routePathnames.length - 1;\n\n // With relative=\"route\" (the default), each leading .. segment means\n // \"go up one route\" instead of \"go up one URL segment\". This is a key\n // difference from how works and a major reason we call this a\n // \"to\" value instead of a \"href\".\n if (!isPathRelative && toPathname.startsWith(\"..\")) {\n let toSegments = toPathname.split(\"/\");\n\n while (toSegments[0] === \"..\") {\n toSegments.shift();\n routePathnameIndex -= 1;\n }\n\n to.pathname = toSegments.join(\"/\");\n }\n\n from = routePathnameIndex >= 0 ? routePathnames[routePathnameIndex] : \"/\";\n }\n\n let path = resolvePath(to, from);\n\n // Ensure the pathname has a trailing slash if the original \"to\" had one\n let hasExplicitTrailingSlash =\n toPathname && toPathname !== \"/\" && toPathname.endsWith(\"/\");\n // Or if this was a link to the current path which has a trailing slash\n let hasCurrentTrailingSlash =\n (isEmptyPath || toPathname === \".\") && locationPathname.endsWith(\"/\");\n if (\n !path.pathname.endsWith(\"/\") &&\n (hasExplicitTrailingSlash || hasCurrentTrailingSlash)\n ) {\n path.pathname += \"/\";\n }\n\n return path;\n}\n\n/**\n * @private\n */\nexport function getToPathname(to: To): string | undefined {\n // Empty strings should be treated the same as / paths\n return to === \"\" || (to as Path).pathname === \"\"\n ? \"/\"\n : typeof to === \"string\"\n ? parsePath(to).pathname\n : to.pathname;\n}\n\n/**\n * @private\n */\nexport const joinPaths = (paths: string[]): string =>\n paths.join(\"/\").replace(/\\/\\/+/g, \"/\");\n\n/**\n * @private\n */\nexport const normalizePathname = (pathname: string): string =>\n pathname.replace(/\\/+$/, \"\").replace(/^\\/*/, \"/\");\n\n/**\n * @private\n */\nexport const normalizeSearch = (search: string): string =>\n !search || search === \"?\"\n ? \"\"\n : search.startsWith(\"?\")\n ? search\n : \"?\" + search;\n\n/**\n * @private\n */\nexport const normalizeHash = (hash: string): string =>\n !hash || hash === \"#\" ? \"\" : hash.startsWith(\"#\") ? hash : \"#\" + hash;\n\nexport type JsonFunction = (\n data: Data,\n init?: number | ResponseInit\n) => Response;\n\n/**\n * This is a shortcut for creating `application/json` responses. Converts `data`\n * to JSON and sets the `Content-Type` header.\n *\n * @deprecated The `json` method is deprecated in favor of returning raw objects.\n * This method will be removed in v7.\n */\nexport const json: JsonFunction = (data, init = {}) => {\n let responseInit = typeof init === \"number\" ? { status: init } : init;\n\n let headers = new Headers(responseInit.headers);\n if (!headers.has(\"Content-Type\")) {\n headers.set(\"Content-Type\", \"application/json; charset=utf-8\");\n }\n\n return new Response(JSON.stringify(data), {\n ...responseInit,\n headers,\n });\n};\n\nexport class DataWithResponseInit {\n type: string = \"DataWithResponseInit\";\n data: D;\n init: ResponseInit | null;\n\n constructor(data: D, init?: ResponseInit) {\n this.data = data;\n this.init = init || null;\n }\n}\n\n/**\n * Create \"responses\" that contain `status`/`headers` without forcing\n * serialization into an actual `Response` - used by Remix single fetch\n */\nexport function data(data: D, init?: number | ResponseInit) {\n return new DataWithResponseInit(\n data,\n typeof init === \"number\" ? { status: init } : init\n );\n}\n\nexport interface TrackedPromise extends Promise {\n _tracked?: boolean;\n _data?: any;\n _error?: any;\n}\n\nexport class AbortedDeferredError extends Error {}\n\nexport class DeferredData {\n private pendingKeysSet: Set = new Set();\n private controller: AbortController;\n private abortPromise: Promise;\n private unlistenAbortSignal: () => void;\n private subscribers: Set<(aborted: boolean, settledKey?: string) => void> =\n new Set();\n data: Record;\n init?: ResponseInit;\n deferredKeys: string[] = [];\n\n constructor(data: Record, responseInit?: ResponseInit) {\n invariant(\n data && typeof data === \"object\" && !Array.isArray(data),\n \"defer() only accepts plain objects\"\n );\n\n // Set up an AbortController + Promise we can race against to exit early\n // cancellation\n let reject: (e: AbortedDeferredError) => void;\n this.abortPromise = new Promise((_, r) => (reject = r));\n this.controller = new AbortController();\n let onAbort = () =>\n reject(new AbortedDeferredError(\"Deferred data aborted\"));\n this.unlistenAbortSignal = () =>\n this.controller.signal.removeEventListener(\"abort\", onAbort);\n this.controller.signal.addEventListener(\"abort\", onAbort);\n\n this.data = Object.entries(data).reduce(\n (acc, [key, value]) =>\n Object.assign(acc, {\n [key]: this.trackPromise(key, value),\n }),\n {}\n );\n\n if (this.done) {\n // All incoming values were resolved\n this.unlistenAbortSignal();\n }\n\n this.init = responseInit;\n }\n\n private trackPromise(\n key: string,\n value: Promise | unknown\n ): TrackedPromise | unknown {\n if (!(value instanceof Promise)) {\n return value;\n }\n\n this.deferredKeys.push(key);\n this.pendingKeysSet.add(key);\n\n // We store a little wrapper promise that will be extended with\n // _data/_error props upon resolve/reject\n let promise: TrackedPromise = Promise.race([value, this.abortPromise]).then(\n (data) => this.onSettle(promise, key, undefined, data as unknown),\n (error) => this.onSettle(promise, key, error as unknown)\n );\n\n // Register rejection listeners to avoid uncaught promise rejections on\n // errors or aborted deferred values\n promise.catch(() => {});\n\n Object.defineProperty(promise, \"_tracked\", { get: () => true });\n return promise;\n }\n\n private onSettle(\n promise: TrackedPromise,\n key: string,\n error: unknown,\n data?: unknown\n ): unknown {\n if (\n this.controller.signal.aborted &&\n error instanceof AbortedDeferredError\n ) {\n this.unlistenAbortSignal();\n Object.defineProperty(promise, \"_error\", { get: () => error });\n return Promise.reject(error);\n }\n\n this.pendingKeysSet.delete(key);\n\n if (this.done) {\n // Nothing left to abort!\n this.unlistenAbortSignal();\n }\n\n // If the promise was resolved/rejected with undefined, we'll throw an error as you\n // should always resolve with a value or null\n if (error === undefined && data === undefined) {\n let undefinedError = new Error(\n `Deferred data for key \"${key}\" resolved/rejected with \\`undefined\\`, ` +\n `you must resolve/reject with a value or \\`null\\`.`\n );\n Object.defineProperty(promise, \"_error\", { get: () => undefinedError });\n this.emit(false, key);\n return Promise.reject(undefinedError);\n }\n\n if (data === undefined) {\n Object.defineProperty(promise, \"_error\", { get: () => error });\n this.emit(false, key);\n return Promise.reject(error);\n }\n\n Object.defineProperty(promise, \"_data\", { get: () => data });\n this.emit(false, key);\n return data;\n }\n\n private emit(aborted: boolean, settledKey?: string) {\n this.subscribers.forEach((subscriber) => subscriber(aborted, settledKey));\n }\n\n subscribe(fn: (aborted: boolean, settledKey?: string) => void) {\n this.subscribers.add(fn);\n return () => this.subscribers.delete(fn);\n }\n\n cancel() {\n this.controller.abort();\n this.pendingKeysSet.forEach((v, k) => this.pendingKeysSet.delete(k));\n this.emit(true);\n }\n\n async resolveData(signal: AbortSignal) {\n let aborted = false;\n if (!this.done) {\n let onAbort = () => this.cancel();\n signal.addEventListener(\"abort\", onAbort);\n aborted = await new Promise((resolve) => {\n this.subscribe((aborted) => {\n signal.removeEventListener(\"abort\", onAbort);\n if (aborted || this.done) {\n resolve(aborted);\n }\n });\n });\n }\n return aborted;\n }\n\n get done() {\n return this.pendingKeysSet.size === 0;\n }\n\n get unwrappedData() {\n invariant(\n this.data !== null && this.done,\n \"Can only unwrap data on initialized and settled deferreds\"\n );\n\n return Object.entries(this.data).reduce(\n (acc, [key, value]) =>\n Object.assign(acc, {\n [key]: unwrapTrackedPromise(value),\n }),\n {}\n );\n }\n\n get pendingKeys() {\n return Array.from(this.pendingKeysSet);\n }\n}\n\nfunction isTrackedPromise(value: any): value is TrackedPromise {\n return (\n value instanceof Promise && (value as TrackedPromise)._tracked === true\n );\n}\n\nfunction unwrapTrackedPromise(value: any) {\n if (!isTrackedPromise(value)) {\n return value;\n }\n\n if (value._error) {\n throw value._error;\n }\n return value._data;\n}\n\nexport type DeferFunction = (\n data: Record,\n init?: number | ResponseInit\n) => DeferredData;\n\n/**\n * @deprecated The `defer` method is deprecated in favor of returning raw\n * objects. This method will be removed in v7.\n */\nexport const defer: DeferFunction = (data, init = {}) => {\n let responseInit = typeof init === \"number\" ? { status: init } : init;\n\n return new DeferredData(data, responseInit);\n};\n\nexport type RedirectFunction = (\n url: string,\n init?: number | ResponseInit\n) => Response;\n\n/**\n * A redirect response. Sets the status code and the `Location` header.\n * Defaults to \"302 Found\".\n */\nexport const redirect: RedirectFunction = (url, init = 302) => {\n let responseInit = init;\n if (typeof responseInit === \"number\") {\n responseInit = { status: responseInit };\n } else if (typeof responseInit.status === \"undefined\") {\n responseInit.status = 302;\n }\n\n let headers = new Headers(responseInit.headers);\n headers.set(\"Location\", url);\n\n return new Response(null, {\n ...responseInit,\n headers,\n });\n};\n\n/**\n * A redirect response that will force a document reload to the new location.\n * Sets the status code and the `Location` header.\n * Defaults to \"302 Found\".\n */\nexport const redirectDocument: RedirectFunction = (url, init) => {\n let response = redirect(url, init);\n response.headers.set(\"X-Remix-Reload-Document\", \"true\");\n return response;\n};\n\n/**\n * A redirect response that will perform a `history.replaceState` instead of a\n * `history.pushState` for client-side navigation redirects.\n * Sets the status code and the `Location` header.\n * Defaults to \"302 Found\".\n */\nexport const replace: RedirectFunction = (url, init) => {\n let response = redirect(url, init);\n response.headers.set(\"X-Remix-Replace\", \"true\");\n return response;\n};\n\nexport type ErrorResponse = {\n status: number;\n statusText: string;\n data: any;\n};\n\n/**\n * @private\n * Utility class we use to hold auto-unwrapped 4xx/5xx Response bodies\n *\n * We don't export the class for public use since it's an implementation\n * detail, but we export the interface above so folks can build their own\n * abstractions around instances via isRouteErrorResponse()\n */\nexport class ErrorResponseImpl implements ErrorResponse {\n status: number;\n statusText: string;\n data: any;\n private error?: Error;\n private internal: boolean;\n\n constructor(\n status: number,\n statusText: string | undefined,\n data: any,\n internal = false\n ) {\n this.status = status;\n this.statusText = statusText || \"\";\n this.internal = internal;\n if (data instanceof Error) {\n this.data = data.toString();\n this.error = data;\n } else {\n this.data = data;\n }\n }\n}\n\n/**\n * Check if the given error is an ErrorResponse generated from a 4xx/5xx\n * Response thrown from an action/loader\n */\nexport function isRouteErrorResponse(error: any): error is ErrorResponse {\n return (\n error != null &&\n typeof error.status === \"number\" &&\n typeof error.statusText === \"string\" &&\n typeof error.internal === \"boolean\" &&\n \"data\" in error\n );\n}\n","import type { History, Location, Path, To } from \"./history\";\nimport {\n Action as HistoryAction,\n createLocation,\n createPath,\n invariant,\n parsePath,\n warning,\n} from \"./history\";\nimport type {\n AgnosticDataRouteMatch,\n AgnosticDataRouteObject,\n DataStrategyMatch,\n AgnosticRouteObject,\n DataResult,\n DataStrategyFunction,\n DataStrategyFunctionArgs,\n DeferredData,\n DeferredResult,\n DetectErrorBoundaryFunction,\n ErrorResult,\n FormEncType,\n FormMethod,\n HTMLFormMethod,\n DataStrategyResult,\n ImmutableRouteKey,\n MapRoutePropertiesFunction,\n MutationFormMethod,\n RedirectResult,\n RouteData,\n RouteManifest,\n ShouldRevalidateFunctionArgs,\n Submission,\n SuccessResult,\n UIMatch,\n V7_FormMethod,\n V7_MutationFormMethod,\n AgnosticPatchRoutesOnNavigationFunction,\n DataWithResponseInit,\n} from \"./utils\";\nimport {\n ErrorResponseImpl,\n ResultType,\n convertRouteMatchToUiMatch,\n convertRoutesToDataRoutes,\n getPathContributingMatches,\n getResolveToMatches,\n immutableRouteKeys,\n isRouteErrorResponse,\n joinPaths,\n matchRoutes,\n matchRoutesImpl,\n resolveTo,\n stripBasename,\n} from \"./utils\";\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Types and Constants\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A Router instance manages all navigation and data loading/mutations\n */\nexport interface Router {\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Return the basename for the router\n */\n get basename(): RouterInit[\"basename\"];\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Return the future config for the router\n */\n get future(): FutureConfig;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Return the current state of the router\n */\n get state(): RouterState;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Return the routes for this router instance\n */\n get routes(): AgnosticDataRouteObject[];\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Return the window associated with the router\n */\n get window(): RouterInit[\"window\"];\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Initialize the router, including adding history listeners and kicking off\n * initial data fetches. Returns a function to cleanup listeners and abort\n * any in-progress loads\n */\n initialize(): Router;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Subscribe to router.state updates\n *\n * @param fn function to call with the new state\n */\n subscribe(fn: RouterSubscriber): () => void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Enable scroll restoration behavior in the router\n *\n * @param savedScrollPositions Object that will manage positions, in case\n * it's being restored from sessionStorage\n * @param getScrollPosition Function to get the active Y scroll position\n * @param getKey Function to get the key to use for restoration\n */\n enableScrollRestoration(\n savedScrollPositions: Record,\n getScrollPosition: GetScrollPositionFunction,\n getKey?: GetScrollRestorationKeyFunction\n ): () => void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Navigate forward/backward in the history stack\n * @param to Delta to move in the history stack\n */\n navigate(to: number): Promise;\n\n /**\n * Navigate to the given path\n * @param to Path to navigate to\n * @param opts Navigation options (method, submission, etc.)\n */\n navigate(to: To | null, opts?: RouterNavigateOptions): Promise;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Trigger a fetcher load/submission\n *\n * @param key Fetcher key\n * @param routeId Route that owns the fetcher\n * @param href href to fetch\n * @param opts Fetcher options, (method, submission, etc.)\n */\n fetch(\n key: string,\n routeId: string,\n href: string | null,\n opts?: RouterFetchOptions\n ): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Trigger a revalidation of all current route loaders and fetcher loads\n */\n revalidate(): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Utility function to create an href for the given location\n * @param location\n */\n createHref(location: Location | URL): string;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Utility function to URL encode a destination path according to the internal\n * history implementation\n * @param to\n */\n encodeLocation(to: To): Path;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Get/create a fetcher for the given key\n * @param key\n */\n getFetcher(key: string): Fetcher;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Delete the fetcher for a given key\n * @param key\n */\n deleteFetcher(key: string): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Cleanup listeners and abort any in-progress loads\n */\n dispose(): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Get a navigation blocker\n * @param key The identifier for the blocker\n * @param fn The blocker function implementation\n */\n getBlocker(key: string, fn: BlockerFunction): Blocker;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Delete a navigation blocker\n * @param key The identifier for the blocker\n */\n deleteBlocker(key: string): void;\n\n /**\n * @internal\n * PRIVATE DO NOT USE\n *\n * Patch additional children routes into an existing parent route\n * @param routeId The parent route id or a callback function accepting `patch`\n * to perform batch patching\n * @param children The additional children routes\n */\n patchRoutes(routeId: string | null, children: AgnosticRouteObject[]): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * HMR needs to pass in-flight route updates to React Router\n * TODO: Replace this with granular route update APIs (addRoute, updateRoute, deleteRoute)\n */\n _internalSetRoutes(routes: AgnosticRouteObject[]): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Internal fetch AbortControllers accessed by unit tests\n */\n _internalFetchControllers: Map;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Internal pending DeferredData instances accessed by unit tests\n */\n _internalActiveDeferreds: Map;\n}\n\n/**\n * State maintained internally by the router. During a navigation, all states\n * reflect the the \"old\" location unless otherwise noted.\n */\nexport interface RouterState {\n /**\n * The action of the most recent navigation\n */\n historyAction: HistoryAction;\n\n /**\n * The current location reflected by the router\n */\n location: Location;\n\n /**\n * The current set of route matches\n */\n matches: AgnosticDataRouteMatch[];\n\n /**\n * Tracks whether we've completed our initial data load\n */\n initialized: boolean;\n\n /**\n * Current scroll position we should start at for a new view\n * - number -> scroll position to restore to\n * - false -> do not restore scroll at all (used during submissions)\n * - null -> don't have a saved position, scroll to hash or top of page\n */\n restoreScrollPosition: number | false | null;\n\n /**\n * Indicate whether this navigation should skip resetting the scroll position\n * if we are unable to restore the scroll position\n */\n preventScrollReset: boolean;\n\n /**\n * Tracks the state of the current navigation\n */\n navigation: Navigation;\n\n /**\n * Tracks any in-progress revalidations\n */\n revalidation: RevalidationState;\n\n /**\n * Data from the loaders for the current matches\n */\n loaderData: RouteData;\n\n /**\n * Data from the action for the current matches\n */\n actionData: RouteData | null;\n\n /**\n * Errors caught from loaders for the current matches\n */\n errors: RouteData | null;\n\n /**\n * Map of current fetchers\n */\n fetchers: Map;\n\n /**\n * Map of current blockers\n */\n blockers: Map;\n}\n\n/**\n * Data that can be passed into hydrate a Router from SSR\n */\nexport type HydrationState = Partial<\n Pick\n>;\n\n/**\n * Future flags to toggle new feature behavior\n */\nexport interface FutureConfig {\n v7_fetcherPersist: boolean;\n v7_normalizeFormMethod: boolean;\n v7_partialHydration: boolean;\n v7_prependBasename: boolean;\n v7_relativeSplatPath: boolean;\n v7_skipActionErrorRevalidation: boolean;\n}\n\n/**\n * Initialization options for createRouter\n */\nexport interface RouterInit {\n routes: AgnosticRouteObject[];\n history: History;\n basename?: string;\n /**\n * @deprecated Use `mapRouteProperties` instead\n */\n detectErrorBoundary?: DetectErrorBoundaryFunction;\n mapRouteProperties?: MapRoutePropertiesFunction;\n future?: Partial;\n hydrationData?: HydrationState;\n window?: Window;\n dataStrategy?: DataStrategyFunction;\n patchRoutesOnNavigation?: AgnosticPatchRoutesOnNavigationFunction;\n}\n\n/**\n * State returned from a server-side query() call\n */\nexport interface StaticHandlerContext {\n basename: Router[\"basename\"];\n location: RouterState[\"location\"];\n matches: RouterState[\"matches\"];\n loaderData: RouterState[\"loaderData\"];\n actionData: RouterState[\"actionData\"];\n errors: RouterState[\"errors\"];\n statusCode: number;\n loaderHeaders: Record;\n actionHeaders: Record;\n activeDeferreds: Record | null;\n _deepestRenderedBoundaryId?: string | null;\n}\n\n/**\n * A StaticHandler instance manages a singular SSR navigation/fetch event\n */\nexport interface StaticHandler {\n dataRoutes: AgnosticDataRouteObject[];\n query(\n request: Request,\n opts?: {\n requestContext?: unknown;\n skipLoaderErrorBubbling?: boolean;\n dataStrategy?: DataStrategyFunction;\n }\n ): Promise;\n queryRoute(\n request: Request,\n opts?: {\n routeId?: string;\n requestContext?: unknown;\n dataStrategy?: DataStrategyFunction;\n }\n ): Promise;\n}\n\ntype ViewTransitionOpts = {\n currentLocation: Location;\n nextLocation: Location;\n};\n\n/**\n * Subscriber function signature for changes to router state\n */\nexport interface RouterSubscriber {\n (\n state: RouterState,\n opts: {\n deletedFetchers: string[];\n viewTransitionOpts?: ViewTransitionOpts;\n flushSync: boolean;\n }\n ): void;\n}\n\n/**\n * Function signature for determining the key to be used in scroll restoration\n * for a given location\n */\nexport interface GetScrollRestorationKeyFunction {\n (location: Location, matches: UIMatch[]): string | null;\n}\n\n/**\n * Function signature for determining the current scroll position\n */\nexport interface GetScrollPositionFunction {\n (): number;\n}\n\nexport type RelativeRoutingType = \"route\" | \"path\";\n\n// Allowed for any navigation or fetch\ntype BaseNavigateOrFetchOptions = {\n preventScrollReset?: boolean;\n relative?: RelativeRoutingType;\n flushSync?: boolean;\n};\n\n// Only allowed for navigations\ntype BaseNavigateOptions = BaseNavigateOrFetchOptions & {\n replace?: boolean;\n state?: any;\n fromRouteId?: string;\n viewTransition?: boolean;\n};\n\n// Only allowed for submission navigations\ntype BaseSubmissionOptions = {\n formMethod?: HTMLFormMethod;\n formEncType?: FormEncType;\n} & (\n | { formData: FormData; body?: undefined }\n | { formData?: undefined; body: any }\n);\n\n/**\n * Options for a navigate() call for a normal (non-submission) navigation\n */\ntype LinkNavigateOptions = BaseNavigateOptions;\n\n/**\n * Options for a navigate() call for a submission navigation\n */\ntype SubmissionNavigateOptions = BaseNavigateOptions & BaseSubmissionOptions;\n\n/**\n * Options to pass to navigate() for a navigation\n */\nexport type RouterNavigateOptions =\n | LinkNavigateOptions\n | SubmissionNavigateOptions;\n\n/**\n * Options for a fetch() load\n */\ntype LoadFetchOptions = BaseNavigateOrFetchOptions;\n\n/**\n * Options for a fetch() submission\n */\ntype SubmitFetchOptions = BaseNavigateOrFetchOptions & BaseSubmissionOptions;\n\n/**\n * Options to pass to fetch()\n */\nexport type RouterFetchOptions = LoadFetchOptions | SubmitFetchOptions;\n\n/**\n * Potential states for state.navigation\n */\nexport type NavigationStates = {\n Idle: {\n state: \"idle\";\n location: undefined;\n formMethod: undefined;\n formAction: undefined;\n formEncType: undefined;\n formData: undefined;\n json: undefined;\n text: undefined;\n };\n Loading: {\n state: \"loading\";\n location: Location;\n formMethod: Submission[\"formMethod\"] | undefined;\n formAction: Submission[\"formAction\"] | undefined;\n formEncType: Submission[\"formEncType\"] | undefined;\n formData: Submission[\"formData\"] | undefined;\n json: Submission[\"json\"] | undefined;\n text: Submission[\"text\"] | undefined;\n };\n Submitting: {\n state: \"submitting\";\n location: Location;\n formMethod: Submission[\"formMethod\"];\n formAction: Submission[\"formAction\"];\n formEncType: Submission[\"formEncType\"];\n formData: Submission[\"formData\"];\n json: Submission[\"json\"];\n text: Submission[\"text\"];\n };\n};\n\nexport type Navigation = NavigationStates[keyof NavigationStates];\n\nexport type RevalidationState = \"idle\" | \"loading\";\n\n/**\n * Potential states for fetchers\n */\ntype FetcherStates = {\n Idle: {\n state: \"idle\";\n formMethod: undefined;\n formAction: undefined;\n formEncType: undefined;\n text: undefined;\n formData: undefined;\n json: undefined;\n data: TData | undefined;\n };\n Loading: {\n state: \"loading\";\n formMethod: Submission[\"formMethod\"] | undefined;\n formAction: Submission[\"formAction\"] | undefined;\n formEncType: Submission[\"formEncType\"] | undefined;\n text: Submission[\"text\"] | undefined;\n formData: Submission[\"formData\"] | undefined;\n json: Submission[\"json\"] | undefined;\n data: TData | undefined;\n };\n Submitting: {\n state: \"submitting\";\n formMethod: Submission[\"formMethod\"];\n formAction: Submission[\"formAction\"];\n formEncType: Submission[\"formEncType\"];\n text: Submission[\"text\"];\n formData: Submission[\"formData\"];\n json: Submission[\"json\"];\n data: TData | undefined;\n };\n};\n\nexport type Fetcher =\n FetcherStates[keyof FetcherStates];\n\ninterface BlockerBlocked {\n state: \"blocked\";\n reset(): void;\n proceed(): void;\n location: Location;\n}\n\ninterface BlockerUnblocked {\n state: \"unblocked\";\n reset: undefined;\n proceed: undefined;\n location: undefined;\n}\n\ninterface BlockerProceeding {\n state: \"proceeding\";\n reset: undefined;\n proceed: undefined;\n location: Location;\n}\n\nexport type Blocker = BlockerUnblocked | BlockerBlocked | BlockerProceeding;\n\nexport type BlockerFunction = (args: {\n currentLocation: Location;\n nextLocation: Location;\n historyAction: HistoryAction;\n}) => boolean;\n\ninterface ShortCircuitable {\n /**\n * startNavigation does not need to complete the navigation because we\n * redirected or got interrupted\n */\n shortCircuited?: boolean;\n}\n\ntype PendingActionResult = [string, SuccessResult | ErrorResult];\n\ninterface HandleActionResult extends ShortCircuitable {\n /**\n * Route matches which may have been updated from fog of war discovery\n */\n matches?: RouterState[\"matches\"];\n /**\n * Tuple for the returned or thrown value from the current action. The routeId\n * is the action route for success and the bubbled boundary route for errors.\n */\n pendingActionResult?: PendingActionResult;\n}\n\ninterface HandleLoadersResult extends ShortCircuitable {\n /**\n * Route matches which may have been updated from fog of war discovery\n */\n matches?: RouterState[\"matches\"];\n /**\n * loaderData returned from the current set of loaders\n */\n loaderData?: RouterState[\"loaderData\"];\n /**\n * errors thrown from the current set of loaders\n */\n errors?: RouterState[\"errors\"];\n}\n\n/**\n * Cached info for active fetcher.load() instances so they can participate\n * in revalidation\n */\ninterface FetchLoadMatch {\n routeId: string;\n path: string;\n}\n\n/**\n * Identified fetcher.load() calls that need to be revalidated\n */\ninterface RevalidatingFetcher extends FetchLoadMatch {\n key: string;\n match: AgnosticDataRouteMatch | null;\n matches: AgnosticDataRouteMatch[] | null;\n controller: AbortController | null;\n}\n\nconst validMutationMethodsArr: MutationFormMethod[] = [\n \"post\",\n \"put\",\n \"patch\",\n \"delete\",\n];\nconst validMutationMethods = new Set(\n validMutationMethodsArr\n);\n\nconst validRequestMethodsArr: FormMethod[] = [\n \"get\",\n ...validMutationMethodsArr,\n];\nconst validRequestMethods = new Set(validRequestMethodsArr);\n\nconst redirectStatusCodes = new Set([301, 302, 303, 307, 308]);\nconst redirectPreserveMethodStatusCodes = new Set([307, 308]);\n\nexport const IDLE_NAVIGATION: NavigationStates[\"Idle\"] = {\n state: \"idle\",\n location: undefined,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined,\n};\n\nexport const IDLE_FETCHER: FetcherStates[\"Idle\"] = {\n state: \"idle\",\n data: undefined,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined,\n};\n\nexport const IDLE_BLOCKER: BlockerUnblocked = {\n state: \"unblocked\",\n proceed: undefined,\n reset: undefined,\n location: undefined,\n};\n\nconst ABSOLUTE_URL_REGEX = /^(?:[a-z][a-z0-9+.-]*:|\\/\\/)/i;\n\nconst defaultMapRouteProperties: MapRoutePropertiesFunction = (route) => ({\n hasErrorBoundary: Boolean(route.hasErrorBoundary),\n});\n\nconst TRANSITIONS_STORAGE_KEY = \"remix-router-transitions\";\n\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region createRouter\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * Create a router and listen to history POP navigations\n */\nexport function createRouter(init: RouterInit): Router {\n const routerWindow = init.window\n ? init.window\n : typeof window !== \"undefined\"\n ? window\n : undefined;\n const isBrowser =\n typeof routerWindow !== \"undefined\" &&\n typeof routerWindow.document !== \"undefined\" &&\n typeof routerWindow.document.createElement !== \"undefined\";\n const isServer = !isBrowser;\n\n invariant(\n init.routes.length > 0,\n \"You must provide a non-empty routes array to createRouter\"\n );\n\n let mapRouteProperties: MapRoutePropertiesFunction;\n if (init.mapRouteProperties) {\n mapRouteProperties = init.mapRouteProperties;\n } else if (init.detectErrorBoundary) {\n // If they are still using the deprecated version, wrap it with the new API\n let detectErrorBoundary = init.detectErrorBoundary;\n mapRouteProperties = (route) => ({\n hasErrorBoundary: detectErrorBoundary(route),\n });\n } else {\n mapRouteProperties = defaultMapRouteProperties;\n }\n\n // Routes keyed by ID\n let manifest: RouteManifest = {};\n // Routes in tree format for matching\n let dataRoutes = convertRoutesToDataRoutes(\n init.routes,\n mapRouteProperties,\n undefined,\n manifest\n );\n let inFlightDataRoutes: AgnosticDataRouteObject[] | undefined;\n let basename = init.basename || \"/\";\n let dataStrategyImpl = init.dataStrategy || defaultDataStrategy;\n let patchRoutesOnNavigationImpl = init.patchRoutesOnNavigation;\n\n // Config driven behavior flags\n let future: FutureConfig = {\n v7_fetcherPersist: false,\n v7_normalizeFormMethod: false,\n v7_partialHydration: false,\n v7_prependBasename: false,\n v7_relativeSplatPath: false,\n v7_skipActionErrorRevalidation: false,\n ...init.future,\n };\n // Cleanup function for history\n let unlistenHistory: (() => void) | null = null;\n // Externally-provided functions to call on all state changes\n let subscribers = new Set();\n // Externally-provided object to hold scroll restoration locations during routing\n let savedScrollPositions: Record | null = null;\n // Externally-provided function to get scroll restoration keys\n let getScrollRestorationKey: GetScrollRestorationKeyFunction | null = null;\n // Externally-provided function to get current scroll position\n let getScrollPosition: GetScrollPositionFunction | null = null;\n // One-time flag to control the initial hydration scroll restoration. Because\n // we don't get the saved positions from until _after_\n // the initial render, we need to manually trigger a separate updateState to\n // send along the restoreScrollPosition\n // Set to true if we have `hydrationData` since we assume we were SSR'd and that\n // SSR did the initial scroll restoration.\n let initialScrollRestored = init.hydrationData != null;\n\n let initialMatches = matchRoutes(dataRoutes, init.history.location, basename);\n let initialErrors: RouteData | null = null;\n\n if (initialMatches == null && !patchRoutesOnNavigationImpl) {\n // If we do not match a user-provided-route, fall back to the root\n // to allow the error boundary to take over\n let error = getInternalRouterError(404, {\n pathname: init.history.location.pathname,\n });\n let { matches, route } = getShortCircuitMatches(dataRoutes);\n initialMatches = matches;\n initialErrors = { [route.id]: error };\n }\n\n // In SPA apps, if the user provided a patchRoutesOnNavigation implementation and\n // our initial match is a splat route, clear them out so we run through lazy\n // discovery on hydration in case there's a more accurate lazy route match.\n // In SSR apps (with `hydrationData`), we expect that the server will send\n // up the proper matched routes so we don't want to run lazy discovery on\n // initial hydration and want to hydrate into the splat route.\n if (initialMatches && !init.hydrationData) {\n let fogOfWar = checkFogOfWar(\n initialMatches,\n dataRoutes,\n init.history.location.pathname\n );\n if (fogOfWar.active) {\n initialMatches = null;\n }\n }\n\n let initialized: boolean;\n if (!initialMatches) {\n initialized = false;\n initialMatches = [];\n\n // If partial hydration and fog of war is enabled, we will be running\n // `patchRoutesOnNavigation` during hydration so include any partial matches as\n // the initial matches so we can properly render `HydrateFallback`'s\n if (future.v7_partialHydration) {\n let fogOfWar = checkFogOfWar(\n null,\n dataRoutes,\n init.history.location.pathname\n );\n if (fogOfWar.active && fogOfWar.matches) {\n initialMatches = fogOfWar.matches;\n }\n }\n } else if (initialMatches.some((m) => m.route.lazy)) {\n // All initialMatches need to be loaded before we're ready. If we have lazy\n // functions around still then we'll need to run them in initialize()\n initialized = false;\n } else if (!initialMatches.some((m) => m.route.loader)) {\n // If we've got no loaders to run, then we're good to go\n initialized = true;\n } else if (future.v7_partialHydration) {\n // If partial hydration is enabled, we're initialized so long as we were\n // provided with hydrationData for every route with a loader, and no loaders\n // were marked for explicit hydration\n let loaderData = init.hydrationData ? init.hydrationData.loaderData : null;\n let errors = init.hydrationData ? init.hydrationData.errors : null;\n // If errors exist, don't consider routes below the boundary\n if (errors) {\n let idx = initialMatches.findIndex(\n (m) => errors![m.route.id] !== undefined\n );\n initialized = initialMatches\n .slice(0, idx + 1)\n .every((m) => !shouldLoadRouteOnHydration(m.route, loaderData, errors));\n } else {\n initialized = initialMatches.every(\n (m) => !shouldLoadRouteOnHydration(m.route, loaderData, errors)\n );\n }\n } else {\n // Without partial hydration - we're initialized if we were provided any\n // hydrationData - which is expected to be complete\n initialized = init.hydrationData != null;\n }\n\n let router: Router;\n let state: RouterState = {\n historyAction: init.history.action,\n location: init.history.location,\n matches: initialMatches,\n initialized,\n navigation: IDLE_NAVIGATION,\n // Don't restore on initial updateState() if we were SSR'd\n restoreScrollPosition: init.hydrationData != null ? false : null,\n preventScrollReset: false,\n revalidation: \"idle\",\n loaderData: (init.hydrationData && init.hydrationData.loaderData) || {},\n actionData: (init.hydrationData && init.hydrationData.actionData) || null,\n errors: (init.hydrationData && init.hydrationData.errors) || initialErrors,\n fetchers: new Map(),\n blockers: new Map(),\n };\n\n // -- Stateful internal variables to manage navigations --\n // Current navigation in progress (to be committed in completeNavigation)\n let pendingAction: HistoryAction = HistoryAction.Pop;\n\n // Should the current navigation prevent the scroll reset if scroll cannot\n // be restored?\n let pendingPreventScrollReset = false;\n\n // AbortController for the active navigation\n let pendingNavigationController: AbortController | null;\n\n // Should the current navigation enable document.startViewTransition?\n let pendingViewTransitionEnabled = false;\n\n // Store applied view transitions so we can apply them on POP\n let appliedViewTransitions: Map> = new Map<\n string,\n Set\n >();\n\n // Cleanup function for persisting applied transitions to sessionStorage\n let removePageHideEventListener: (() => void) | null = null;\n\n // We use this to avoid touching history in completeNavigation if a\n // revalidation is entirely uninterrupted\n let isUninterruptedRevalidation = false;\n\n // Use this internal flag to force revalidation of all loaders:\n // - submissions (completed or interrupted)\n // - useRevalidator()\n // - X-Remix-Revalidate (from redirect)\n let isRevalidationRequired = false;\n\n // Use this internal array to capture routes that require revalidation due\n // to a cancelled deferred on action submission\n let cancelledDeferredRoutes: string[] = [];\n\n // Use this internal array to capture fetcher loads that were cancelled by an\n // action navigation and require revalidation\n let cancelledFetcherLoads: Set = new Set();\n\n // AbortControllers for any in-flight fetchers\n let fetchControllers = new Map();\n\n // Track loads based on the order in which they started\n let incrementingLoadId = 0;\n\n // Track the outstanding pending navigation data load to be compared against\n // the globally incrementing load when a fetcher load lands after a completed\n // navigation\n let pendingNavigationLoadId = -1;\n\n // Fetchers that triggered data reloads as a result of their actions\n let fetchReloadIds = new Map();\n\n // Fetchers that triggered redirect navigations\n let fetchRedirectIds = new Set();\n\n // Most recent href/match for fetcher.load calls for fetchers\n let fetchLoadMatches = new Map();\n\n // Ref-count mounted fetchers so we know when it's ok to clean them up\n let activeFetchers = new Map();\n\n // Fetchers that have requested a delete when using v7_fetcherPersist,\n // they'll be officially removed after they return to idle\n let deletedFetchers = new Set();\n\n // Store DeferredData instances for active route matches. When a\n // route loader returns defer() we stick one in here. Then, when a nested\n // promise resolves we update loaderData. If a new navigation starts we\n // cancel active deferreds for eliminated routes.\n let activeDeferreds = new Map();\n\n // Store blocker functions in a separate Map outside of router state since\n // we don't need to update UI state if they change\n let blockerFunctions = new Map();\n\n // Map of pending patchRoutesOnNavigation() promises (keyed by path/matches) so\n // that we only kick them off once for a given combo\n let pendingPatchRoutes = new Map<\n string,\n ReturnType\n >();\n\n // Flag to ignore the next history update, so we can revert the URL change on\n // a POP navigation that was blocked by the user without touching router state\n let unblockBlockerHistoryUpdate: (() => void) | undefined = undefined;\n\n // Initialize the router, all side effects should be kicked off from here.\n // Implemented as a Fluent API for ease of:\n // let router = createRouter(init).initialize();\n function initialize() {\n // If history informs us of a POP navigation, start the navigation but do not update\n // state. We'll update our own state once the navigation completes\n unlistenHistory = init.history.listen(\n ({ action: historyAction, location, delta }) => {\n // Ignore this event if it was just us resetting the URL from a\n // blocked POP navigation\n if (unblockBlockerHistoryUpdate) {\n unblockBlockerHistoryUpdate();\n unblockBlockerHistoryUpdate = undefined;\n return;\n }\n\n warning(\n blockerFunctions.size === 0 || delta != null,\n \"You are trying to use a blocker on a POP navigation to a location \" +\n \"that was not created by @remix-run/router. This will fail silently in \" +\n \"production. This can happen if you are navigating outside the router \" +\n \"via `window.history.pushState`/`window.location.hash` instead of using \" +\n \"router navigation APIs. This can also happen if you are using \" +\n \"createHashRouter and the user manually changes the URL.\"\n );\n\n let blockerKey = shouldBlockNavigation({\n currentLocation: state.location,\n nextLocation: location,\n historyAction,\n });\n\n if (blockerKey && delta != null) {\n // Restore the URL to match the current UI, but don't update router state\n let nextHistoryUpdatePromise = new Promise((resolve) => {\n unblockBlockerHistoryUpdate = resolve;\n });\n init.history.go(delta * -1);\n\n // Put the blocker into a blocked state\n updateBlocker(blockerKey, {\n state: \"blocked\",\n location,\n proceed() {\n updateBlocker(blockerKey!, {\n state: \"proceeding\",\n proceed: undefined,\n reset: undefined,\n location,\n });\n // Re-do the same POP navigation we just blocked, after the url\n // restoration is also complete. See:\n // https://github.com/remix-run/react-router/issues/11613\n nextHistoryUpdatePromise.then(() => init.history.go(delta));\n },\n reset() {\n let blockers = new Map(state.blockers);\n blockers.set(blockerKey!, IDLE_BLOCKER);\n updateState({ blockers });\n },\n });\n return;\n }\n\n return startNavigation(historyAction, location);\n }\n );\n\n if (isBrowser) {\n // FIXME: This feels gross. How can we cleanup the lines between\n // scrollRestoration/appliedTransitions persistance?\n restoreAppliedTransitions(routerWindow, appliedViewTransitions);\n let _saveAppliedTransitions = () =>\n persistAppliedTransitions(routerWindow, appliedViewTransitions);\n routerWindow.addEventListener(\"pagehide\", _saveAppliedTransitions);\n removePageHideEventListener = () =>\n routerWindow.removeEventListener(\"pagehide\", _saveAppliedTransitions);\n }\n\n // Kick off initial data load if needed. Use Pop to avoid modifying history\n // Note we don't do any handling of lazy here. For SPA's it'll get handled\n // in the normal navigation flow. For SSR it's expected that lazy modules are\n // resolved prior to router creation since we can't go into a fallbackElement\n // UI for SSR'd apps\n if (!state.initialized) {\n startNavigation(HistoryAction.Pop, state.location, {\n initialHydration: true,\n });\n }\n\n return router;\n }\n\n // Clean up a router and it's side effects\n function dispose() {\n if (unlistenHistory) {\n unlistenHistory();\n }\n if (removePageHideEventListener) {\n removePageHideEventListener();\n }\n subscribers.clear();\n pendingNavigationController && pendingNavigationController.abort();\n state.fetchers.forEach((_, key) => deleteFetcher(key));\n state.blockers.forEach((_, key) => deleteBlocker(key));\n }\n\n // Subscribe to state updates for the router\n function subscribe(fn: RouterSubscriber) {\n subscribers.add(fn);\n return () => subscribers.delete(fn);\n }\n\n // Update our state and notify the calling context of the change\n function updateState(\n newState: Partial,\n opts: {\n flushSync?: boolean;\n viewTransitionOpts?: ViewTransitionOpts;\n } = {}\n ): void {\n state = {\n ...state,\n ...newState,\n };\n\n // Prep fetcher cleanup so we can tell the UI which fetcher data entries\n // can be removed\n let completedFetchers: string[] = [];\n let deletedFetchersKeys: string[] = [];\n\n if (future.v7_fetcherPersist) {\n state.fetchers.forEach((fetcher, key) => {\n if (fetcher.state === \"idle\") {\n if (deletedFetchers.has(key)) {\n // Unmounted from the UI and can be totally removed\n deletedFetchersKeys.push(key);\n } else {\n // Returned to idle but still mounted in the UI, so semi-remains for\n // revalidations and such\n completedFetchers.push(key);\n }\n }\n });\n }\n\n // Iterate over a local copy so that if flushSync is used and we end up\n // removing and adding a new subscriber due to the useCallback dependencies,\n // we don't get ourselves into a loop calling the new subscriber immediately\n [...subscribers].forEach((subscriber) =>\n subscriber(state, {\n deletedFetchers: deletedFetchersKeys,\n viewTransitionOpts: opts.viewTransitionOpts,\n flushSync: opts.flushSync === true,\n })\n );\n\n // Remove idle fetchers from state since we only care about in-flight fetchers.\n if (future.v7_fetcherPersist) {\n completedFetchers.forEach((key) => state.fetchers.delete(key));\n deletedFetchersKeys.forEach((key) => deleteFetcher(key));\n }\n }\n\n // Complete a navigation returning the state.navigation back to the IDLE_NAVIGATION\n // and setting state.[historyAction/location/matches] to the new route.\n // - Location is a required param\n // - Navigation will always be set to IDLE_NAVIGATION\n // - Can pass any other state in newState\n function completeNavigation(\n location: Location,\n newState: Partial>,\n { flushSync }: { flushSync?: boolean } = {}\n ): void {\n // Deduce if we're in a loading/actionReload state:\n // - We have committed actionData in the store\n // - The current navigation was a mutation submission\n // - We're past the submitting state and into the loading state\n // - The location being loaded is not the result of a redirect\n let isActionReload =\n state.actionData != null &&\n state.navigation.formMethod != null &&\n isMutationMethod(state.navigation.formMethod) &&\n state.navigation.state === \"loading\" &&\n location.state?._isRedirect !== true;\n\n let actionData: RouteData | null;\n if (newState.actionData) {\n if (Object.keys(newState.actionData).length > 0) {\n actionData = newState.actionData;\n } else {\n // Empty actionData -> clear prior actionData due to an action error\n actionData = null;\n }\n } else if (isActionReload) {\n // Keep the current data if we're wrapping up the action reload\n actionData = state.actionData;\n } else {\n // Clear actionData on any other completed navigations\n actionData = null;\n }\n\n // Always preserve any existing loaderData from re-used routes\n let loaderData = newState.loaderData\n ? mergeLoaderData(\n state.loaderData,\n newState.loaderData,\n newState.matches || [],\n newState.errors\n )\n : state.loaderData;\n\n // On a successful navigation we can assume we got through all blockers\n // so we can start fresh\n let blockers = state.blockers;\n if (blockers.size > 0) {\n blockers = new Map(blockers);\n blockers.forEach((_, k) => blockers.set(k, IDLE_BLOCKER));\n }\n\n // Always respect the user flag. Otherwise don't reset on mutation\n // submission navigations unless they redirect\n let preventScrollReset =\n pendingPreventScrollReset === true ||\n (state.navigation.formMethod != null &&\n isMutationMethod(state.navigation.formMethod) &&\n location.state?._isRedirect !== true);\n\n // Commit any in-flight routes at the end of the HMR revalidation \"navigation\"\n if (inFlightDataRoutes) {\n dataRoutes = inFlightDataRoutes;\n inFlightDataRoutes = undefined;\n }\n\n if (isUninterruptedRevalidation) {\n // If this was an uninterrupted revalidation then do not touch history\n } else if (pendingAction === HistoryAction.Pop) {\n // Do nothing for POP - URL has already been updated\n } else if (pendingAction === HistoryAction.Push) {\n init.history.push(location, location.state);\n } else if (pendingAction === HistoryAction.Replace) {\n init.history.replace(location, location.state);\n }\n\n let viewTransitionOpts: ViewTransitionOpts | undefined;\n\n // On POP, enable transitions if they were enabled on the original navigation\n if (pendingAction === HistoryAction.Pop) {\n // Forward takes precedence so they behave like the original navigation\n let priorPaths = appliedViewTransitions.get(state.location.pathname);\n if (priorPaths && priorPaths.has(location.pathname)) {\n viewTransitionOpts = {\n currentLocation: state.location,\n nextLocation: location,\n };\n } else if (appliedViewTransitions.has(location.pathname)) {\n // If we don't have a previous forward nav, assume we're popping back to\n // the new location and enable if that location previously enabled\n viewTransitionOpts = {\n currentLocation: location,\n nextLocation: state.location,\n };\n }\n } else if (pendingViewTransitionEnabled) {\n // Store the applied transition on PUSH/REPLACE\n let toPaths = appliedViewTransitions.get(state.location.pathname);\n if (toPaths) {\n toPaths.add(location.pathname);\n } else {\n toPaths = new Set([location.pathname]);\n appliedViewTransitions.set(state.location.pathname, toPaths);\n }\n viewTransitionOpts = {\n currentLocation: state.location,\n nextLocation: location,\n };\n }\n\n updateState(\n {\n ...newState, // matches, errors, fetchers go through as-is\n actionData,\n loaderData,\n historyAction: pendingAction,\n location,\n initialized: true,\n navigation: IDLE_NAVIGATION,\n revalidation: \"idle\",\n restoreScrollPosition: getSavedScrollPosition(\n location,\n newState.matches || state.matches\n ),\n preventScrollReset,\n blockers,\n },\n {\n viewTransitionOpts,\n flushSync: flushSync === true,\n }\n );\n\n // Reset stateful navigation vars\n pendingAction = HistoryAction.Pop;\n pendingPreventScrollReset = false;\n pendingViewTransitionEnabled = false;\n isUninterruptedRevalidation = false;\n isRevalidationRequired = false;\n cancelledDeferredRoutes = [];\n }\n\n // Trigger a navigation event, which can either be a numerical POP or a PUSH\n // replace with an optional submission\n async function navigate(\n to: number | To | null,\n opts?: RouterNavigateOptions\n ): Promise {\n if (typeof to === \"number\") {\n init.history.go(to);\n return;\n }\n\n let normalizedPath = normalizeTo(\n state.location,\n state.matches,\n basename,\n future.v7_prependBasename,\n to,\n future.v7_relativeSplatPath,\n opts?.fromRouteId,\n opts?.relative\n );\n let { path, submission, error } = normalizeNavigateOptions(\n future.v7_normalizeFormMethod,\n false,\n normalizedPath,\n opts\n );\n\n let currentLocation = state.location;\n let nextLocation = createLocation(state.location, path, opts && opts.state);\n\n // When using navigate as a PUSH/REPLACE we aren't reading an already-encoded\n // URL from window.location, so we need to encode it here so the behavior\n // remains the same as POP and non-data-router usages. new URL() does all\n // the same encoding we'd get from a history.pushState/window.location read\n // without having to touch history\n nextLocation = {\n ...nextLocation,\n ...init.history.encodeLocation(nextLocation),\n };\n\n let userReplace = opts && opts.replace != null ? opts.replace : undefined;\n\n let historyAction = HistoryAction.Push;\n\n if (userReplace === true) {\n historyAction = HistoryAction.Replace;\n } else if (userReplace === false) {\n // no-op\n } else if (\n submission != null &&\n isMutationMethod(submission.formMethod) &&\n submission.formAction === state.location.pathname + state.location.search\n ) {\n // By default on submissions to the current location we REPLACE so that\n // users don't have to double-click the back button to get to the prior\n // location. If the user redirects to a different location from the\n // action/loader this will be ignored and the redirect will be a PUSH\n historyAction = HistoryAction.Replace;\n }\n\n let preventScrollReset =\n opts && \"preventScrollReset\" in opts\n ? opts.preventScrollReset === true\n : undefined;\n\n let flushSync = (opts && opts.flushSync) === true;\n\n let blockerKey = shouldBlockNavigation({\n currentLocation,\n nextLocation,\n historyAction,\n });\n\n if (blockerKey) {\n // Put the blocker into a blocked state\n updateBlocker(blockerKey, {\n state: \"blocked\",\n location: nextLocation,\n proceed() {\n updateBlocker(blockerKey!, {\n state: \"proceeding\",\n proceed: undefined,\n reset: undefined,\n location: nextLocation,\n });\n // Send the same navigation through\n navigate(to, opts);\n },\n reset() {\n let blockers = new Map(state.blockers);\n blockers.set(blockerKey!, IDLE_BLOCKER);\n updateState({ blockers });\n },\n });\n return;\n }\n\n return await startNavigation(historyAction, nextLocation, {\n submission,\n // Send through the formData serialization error if we have one so we can\n // render at the right error boundary after we match routes\n pendingError: error,\n preventScrollReset,\n replace: opts && opts.replace,\n enableViewTransition: opts && opts.viewTransition,\n flushSync,\n });\n }\n\n // Revalidate all current loaders. If a navigation is in progress or if this\n // is interrupted by a navigation, allow this to \"succeed\" by calling all\n // loaders during the next loader round\n function revalidate() {\n interruptActiveLoads();\n updateState({ revalidation: \"loading\" });\n\n // If we're currently submitting an action, we don't need to start a new\n // navigation, we'll just let the follow up loader execution call all loaders\n if (state.navigation.state === \"submitting\") {\n return;\n }\n\n // If we're currently in an idle state, start a new navigation for the current\n // action/location and mark it as uninterrupted, which will skip the history\n // update in completeNavigation\n if (state.navigation.state === \"idle\") {\n startNavigation(state.historyAction, state.location, {\n startUninterruptedRevalidation: true,\n });\n return;\n }\n\n // Otherwise, if we're currently in a loading state, just start a new\n // navigation to the navigation.location but do not trigger an uninterrupted\n // revalidation so that history correctly updates once the navigation completes\n startNavigation(\n pendingAction || state.historyAction,\n state.navigation.location,\n {\n overrideNavigation: state.navigation,\n // Proxy through any rending view transition\n enableViewTransition: pendingViewTransitionEnabled === true,\n }\n );\n }\n\n // Start a navigation to the given action/location. Can optionally provide a\n // overrideNavigation which will override the normalLoad in the case of a redirect\n // navigation\n async function startNavigation(\n historyAction: HistoryAction,\n location: Location,\n opts?: {\n initialHydration?: boolean;\n submission?: Submission;\n fetcherSubmission?: Submission;\n overrideNavigation?: Navigation;\n pendingError?: ErrorResponseImpl;\n startUninterruptedRevalidation?: boolean;\n preventScrollReset?: boolean;\n replace?: boolean;\n enableViewTransition?: boolean;\n flushSync?: boolean;\n }\n ): Promise {\n // Abort any in-progress navigations and start a new one. Unset any ongoing\n // uninterrupted revalidations unless told otherwise, since we want this\n // new navigation to update history normally\n pendingNavigationController && pendingNavigationController.abort();\n pendingNavigationController = null;\n pendingAction = historyAction;\n isUninterruptedRevalidation =\n (opts && opts.startUninterruptedRevalidation) === true;\n\n // Save the current scroll position every time we start a new navigation,\n // and track whether we should reset scroll on completion\n saveScrollPosition(state.location, state.matches);\n pendingPreventScrollReset = (opts && opts.preventScrollReset) === true;\n\n pendingViewTransitionEnabled = (opts && opts.enableViewTransition) === true;\n\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let loadingNavigation = opts && opts.overrideNavigation;\n let matches = matchRoutes(routesToUse, location, basename);\n let flushSync = (opts && opts.flushSync) === true;\n\n let fogOfWar = checkFogOfWar(matches, routesToUse, location.pathname);\n if (fogOfWar.active && fogOfWar.matches) {\n matches = fogOfWar.matches;\n }\n\n // Short circuit with a 404 on the root error boundary if we match nothing\n if (!matches) {\n let { error, notFoundMatches, route } = handleNavigational404(\n location.pathname\n );\n completeNavigation(\n location,\n {\n matches: notFoundMatches,\n loaderData: {},\n errors: {\n [route.id]: error,\n },\n },\n { flushSync }\n );\n return;\n }\n\n // Short circuit if it's only a hash change and not a revalidation or\n // mutation submission.\n //\n // Ignore on initial page loads because since the initial hydration will always\n // be \"same hash\". For example, on /page#hash and submit a \n // which will default to a navigation to /page\n if (\n state.initialized &&\n !isRevalidationRequired &&\n isHashChangeOnly(state.location, location) &&\n !(opts && opts.submission && isMutationMethod(opts.submission.formMethod))\n ) {\n completeNavigation(location, { matches }, { flushSync });\n return;\n }\n\n // Create a controller/Request for this navigation\n pendingNavigationController = new AbortController();\n let request = createClientSideRequest(\n init.history,\n location,\n pendingNavigationController.signal,\n opts && opts.submission\n );\n let pendingActionResult: PendingActionResult | undefined;\n\n if (opts && opts.pendingError) {\n // If we have a pendingError, it means the user attempted a GET submission\n // with binary FormData so assign here and skip to handleLoaders. That\n // way we handle calling loaders above the boundary etc. It's not really\n // different from an actionError in that sense.\n pendingActionResult = [\n findNearestBoundary(matches).route.id,\n { type: ResultType.error, error: opts.pendingError },\n ];\n } else if (\n opts &&\n opts.submission &&\n isMutationMethod(opts.submission.formMethod)\n ) {\n // Call action if we received an action submission\n let actionResult = await handleAction(\n request,\n location,\n opts.submission,\n matches,\n fogOfWar.active,\n { replace: opts.replace, flushSync }\n );\n\n if (actionResult.shortCircuited) {\n return;\n }\n\n // If we received a 404 from handleAction, it's because we couldn't lazily\n // discover the destination route so we don't want to call loaders\n if (actionResult.pendingActionResult) {\n let [routeId, result] = actionResult.pendingActionResult;\n if (\n isErrorResult(result) &&\n isRouteErrorResponse(result.error) &&\n result.error.status === 404\n ) {\n pendingNavigationController = null;\n\n completeNavigation(location, {\n matches: actionResult.matches,\n loaderData: {},\n errors: {\n [routeId]: result.error,\n },\n });\n return;\n }\n }\n\n matches = actionResult.matches || matches;\n pendingActionResult = actionResult.pendingActionResult;\n loadingNavigation = getLoadingNavigation(location, opts.submission);\n flushSync = false;\n // No need to do fog of war matching again on loader execution\n fogOfWar.active = false;\n\n // Create a GET request for the loaders\n request = createClientSideRequest(\n init.history,\n request.url,\n request.signal\n );\n }\n\n // Call loaders\n let {\n shortCircuited,\n matches: updatedMatches,\n loaderData,\n errors,\n } = await handleLoaders(\n request,\n location,\n matches,\n fogOfWar.active,\n loadingNavigation,\n opts && opts.submission,\n opts && opts.fetcherSubmission,\n opts && opts.replace,\n opts && opts.initialHydration === true,\n flushSync,\n pendingActionResult\n );\n\n if (shortCircuited) {\n return;\n }\n\n // Clean up now that the action/loaders have completed. Don't clean up if\n // we short circuited because pendingNavigationController will have already\n // been assigned to a new controller for the next navigation\n pendingNavigationController = null;\n\n completeNavigation(location, {\n matches: updatedMatches || matches,\n ...getActionDataForCommit(pendingActionResult),\n loaderData,\n errors,\n });\n }\n\n // Call the action matched by the leaf route for this navigation and handle\n // redirects/errors\n async function handleAction(\n request: Request,\n location: Location,\n submission: Submission,\n matches: AgnosticDataRouteMatch[],\n isFogOfWar: boolean,\n opts: { replace?: boolean; flushSync?: boolean } = {}\n ): Promise {\n interruptActiveLoads();\n\n // Put us in a submitting state\n let navigation = getSubmittingNavigation(location, submission);\n updateState({ navigation }, { flushSync: opts.flushSync === true });\n\n if (isFogOfWar) {\n let discoverResult = await discoverRoutes(\n matches,\n location.pathname,\n request.signal\n );\n if (discoverResult.type === \"aborted\") {\n return { shortCircuited: true };\n } else if (discoverResult.type === \"error\") {\n let boundaryId = findNearestBoundary(discoverResult.partialMatches)\n .route.id;\n return {\n matches: discoverResult.partialMatches,\n pendingActionResult: [\n boundaryId,\n {\n type: ResultType.error,\n error: discoverResult.error,\n },\n ],\n };\n } else if (!discoverResult.matches) {\n let { notFoundMatches, error, route } = handleNavigational404(\n location.pathname\n );\n return {\n matches: notFoundMatches,\n pendingActionResult: [\n route.id,\n {\n type: ResultType.error,\n error,\n },\n ],\n };\n } else {\n matches = discoverResult.matches;\n }\n }\n\n // Call our action and get the result\n let result: DataResult;\n let actionMatch = getTargetMatch(matches, location);\n\n if (!actionMatch.route.action && !actionMatch.route.lazy) {\n result = {\n type: ResultType.error,\n error: getInternalRouterError(405, {\n method: request.method,\n pathname: location.pathname,\n routeId: actionMatch.route.id,\n }),\n };\n } else {\n let results = await callDataStrategy(\n \"action\",\n state,\n request,\n [actionMatch],\n matches,\n null\n );\n result = results[actionMatch.route.id];\n\n if (request.signal.aborted) {\n return { shortCircuited: true };\n }\n }\n\n if (isRedirectResult(result)) {\n let replace: boolean;\n if (opts && opts.replace != null) {\n replace = opts.replace;\n } else {\n // If the user didn't explicity indicate replace behavior, replace if\n // we redirected to the exact same location we're currently at to avoid\n // double back-buttons\n let location = normalizeRedirectLocation(\n result.response.headers.get(\"Location\")!,\n new URL(request.url),\n basename\n );\n replace = location === state.location.pathname + state.location.search;\n }\n await startRedirectNavigation(request, result, true, {\n submission,\n replace,\n });\n return { shortCircuited: true };\n }\n\n if (isDeferredResult(result)) {\n throw getInternalRouterError(400, { type: \"defer-action\" });\n }\n\n if (isErrorResult(result)) {\n // Store off the pending error - we use it to determine which loaders\n // to call and will commit it when we complete the navigation\n let boundaryMatch = findNearestBoundary(matches, actionMatch.route.id);\n\n // By default, all submissions to the current location are REPLACE\n // navigations, but if the action threw an error that'll be rendered in\n // an errorElement, we fall back to PUSH so that the user can use the\n // back button to get back to the pre-submission form location to try\n // again\n if ((opts && opts.replace) !== true) {\n pendingAction = HistoryAction.Push;\n }\n\n return {\n matches,\n pendingActionResult: [boundaryMatch.route.id, result],\n };\n }\n\n return {\n matches,\n pendingActionResult: [actionMatch.route.id, result],\n };\n }\n\n // Call all applicable loaders for the given matches, handling redirects,\n // errors, etc.\n async function handleLoaders(\n request: Request,\n location: Location,\n matches: AgnosticDataRouteMatch[],\n isFogOfWar: boolean,\n overrideNavigation?: Navigation,\n submission?: Submission,\n fetcherSubmission?: Submission,\n replace?: boolean,\n initialHydration?: boolean,\n flushSync?: boolean,\n pendingActionResult?: PendingActionResult\n ): Promise {\n // Figure out the right navigation we want to use for data loading\n let loadingNavigation =\n overrideNavigation || getLoadingNavigation(location, submission);\n\n // If this was a redirect from an action we don't have a \"submission\" but\n // we have it on the loading navigation so use that if available\n let activeSubmission =\n submission ||\n fetcherSubmission ||\n getSubmissionFromNavigation(loadingNavigation);\n\n // If this is an uninterrupted revalidation, we remain in our current idle\n // state. If not, we need to switch to our loading state and load data,\n // preserving any new action data or existing action data (in the case of\n // a revalidation interrupting an actionReload)\n // If we have partialHydration enabled, then don't update the state for the\n // initial data load since it's not a \"navigation\"\n let shouldUpdateNavigationState =\n !isUninterruptedRevalidation &&\n (!future.v7_partialHydration || !initialHydration);\n\n // When fog of war is enabled, we enter our `loading` state earlier so we\n // can discover new routes during the `loading` state. We skip this if\n // we've already run actions since we would have done our matching already.\n // If the children() function threw then, we want to proceed with the\n // partial matches it discovered.\n if (isFogOfWar) {\n if (shouldUpdateNavigationState) {\n let actionData = getUpdatedActionData(pendingActionResult);\n updateState(\n {\n navigation: loadingNavigation,\n ...(actionData !== undefined ? { actionData } : {}),\n },\n {\n flushSync,\n }\n );\n }\n\n let discoverResult = await discoverRoutes(\n matches,\n location.pathname,\n request.signal\n );\n\n if (discoverResult.type === \"aborted\") {\n return { shortCircuited: true };\n } else if (discoverResult.type === \"error\") {\n let boundaryId = findNearestBoundary(discoverResult.partialMatches)\n .route.id;\n return {\n matches: discoverResult.partialMatches,\n loaderData: {},\n errors: {\n [boundaryId]: discoverResult.error,\n },\n };\n } else if (!discoverResult.matches) {\n let { error, notFoundMatches, route } = handleNavigational404(\n location.pathname\n );\n return {\n matches: notFoundMatches,\n loaderData: {},\n errors: {\n [route.id]: error,\n },\n };\n } else {\n matches = discoverResult.matches;\n }\n }\n\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let [matchesToLoad, revalidatingFetchers] = getMatchesToLoad(\n init.history,\n state,\n matches,\n activeSubmission,\n location,\n future.v7_partialHydration && initialHydration === true,\n future.v7_skipActionErrorRevalidation,\n isRevalidationRequired,\n cancelledDeferredRoutes,\n cancelledFetcherLoads,\n deletedFetchers,\n fetchLoadMatches,\n fetchRedirectIds,\n routesToUse,\n basename,\n pendingActionResult\n );\n\n // Cancel pending deferreds for no-longer-matched routes or routes we're\n // about to reload. Note that if this is an action reload we would have\n // already cancelled all pending deferreds so this would be a no-op\n cancelActiveDeferreds(\n (routeId) =>\n !(matches && matches.some((m) => m.route.id === routeId)) ||\n (matchesToLoad && matchesToLoad.some((m) => m.route.id === routeId))\n );\n\n pendingNavigationLoadId = ++incrementingLoadId;\n\n // Short circuit if we have no loaders to run\n if (matchesToLoad.length === 0 && revalidatingFetchers.length === 0) {\n let updatedFetchers = markFetchRedirectsDone();\n completeNavigation(\n location,\n {\n matches,\n loaderData: {},\n // Commit pending error if we're short circuiting\n errors:\n pendingActionResult && isErrorResult(pendingActionResult[1])\n ? { [pendingActionResult[0]]: pendingActionResult[1].error }\n : null,\n ...getActionDataForCommit(pendingActionResult),\n ...(updatedFetchers ? { fetchers: new Map(state.fetchers) } : {}),\n },\n { flushSync }\n );\n return { shortCircuited: true };\n }\n\n if (shouldUpdateNavigationState) {\n let updates: Partial = {};\n if (!isFogOfWar) {\n // Only update navigation/actionNData if we didn't already do it above\n updates.navigation = loadingNavigation;\n let actionData = getUpdatedActionData(pendingActionResult);\n if (actionData !== undefined) {\n updates.actionData = actionData;\n }\n }\n if (revalidatingFetchers.length > 0) {\n updates.fetchers = getUpdatedRevalidatingFetchers(revalidatingFetchers);\n }\n updateState(updates, { flushSync });\n }\n\n revalidatingFetchers.forEach((rf) => {\n abortFetcher(rf.key);\n if (rf.controller) {\n // Fetchers use an independent AbortController so that aborting a fetcher\n // (via deleteFetcher) does not abort the triggering navigation that\n // triggered the revalidation\n fetchControllers.set(rf.key, rf.controller);\n }\n });\n\n // Proxy navigation abort through to revalidation fetchers\n let abortPendingFetchRevalidations = () =>\n revalidatingFetchers.forEach((f) => abortFetcher(f.key));\n if (pendingNavigationController) {\n pendingNavigationController.signal.addEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n }\n\n let { loaderResults, fetcherResults } =\n await callLoadersAndMaybeResolveData(\n state,\n matches,\n matchesToLoad,\n revalidatingFetchers,\n request\n );\n\n if (request.signal.aborted) {\n return { shortCircuited: true };\n }\n\n // Clean up _after_ loaders have completed. Don't clean up if we short\n // circuited because fetchControllers would have been aborted and\n // reassigned to new controllers for the next navigation\n if (pendingNavigationController) {\n pendingNavigationController.signal.removeEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n }\n\n revalidatingFetchers.forEach((rf) => fetchControllers.delete(rf.key));\n\n // If any loaders returned a redirect Response, start a new REPLACE navigation\n let redirect = findRedirect(loaderResults);\n if (redirect) {\n await startRedirectNavigation(request, redirect.result, true, {\n replace,\n });\n return { shortCircuited: true };\n }\n\n redirect = findRedirect(fetcherResults);\n if (redirect) {\n // If this redirect came from a fetcher make sure we mark it in\n // fetchRedirectIds so it doesn't get revalidated on the next set of\n // loader executions\n fetchRedirectIds.add(redirect.key);\n await startRedirectNavigation(request, redirect.result, true, {\n replace,\n });\n return { shortCircuited: true };\n }\n\n // Process and commit output from loaders\n let { loaderData, errors } = processLoaderData(\n state,\n matches,\n loaderResults,\n pendingActionResult,\n revalidatingFetchers,\n fetcherResults,\n activeDeferreds\n );\n\n // Wire up subscribers to update loaderData as promises settle\n activeDeferreds.forEach((deferredData, routeId) => {\n deferredData.subscribe((aborted) => {\n // Note: No need to updateState here since the TrackedPromise on\n // loaderData is stable across resolve/reject\n // Remove this instance if we were aborted or if promises have settled\n if (aborted || deferredData.done) {\n activeDeferreds.delete(routeId);\n }\n });\n });\n\n // Preserve SSR errors during partial hydration\n if (future.v7_partialHydration && initialHydration && state.errors) {\n errors = { ...state.errors, ...errors };\n }\n\n let updatedFetchers = markFetchRedirectsDone();\n let didAbortFetchLoads = abortStaleFetchLoads(pendingNavigationLoadId);\n let shouldUpdateFetchers =\n updatedFetchers || didAbortFetchLoads || revalidatingFetchers.length > 0;\n\n return {\n matches,\n loaderData,\n errors,\n ...(shouldUpdateFetchers ? { fetchers: new Map(state.fetchers) } : {}),\n };\n }\n\n function getUpdatedActionData(\n pendingActionResult: PendingActionResult | undefined\n ): Record | null | undefined {\n if (pendingActionResult && !isErrorResult(pendingActionResult[1])) {\n // This is cast to `any` currently because `RouteData`uses any and it\n // would be a breaking change to use any.\n // TODO: v7 - change `RouteData` to use `unknown` instead of `any`\n return {\n [pendingActionResult[0]]: pendingActionResult[1].data as any,\n };\n } else if (state.actionData) {\n if (Object.keys(state.actionData).length === 0) {\n return null;\n } else {\n return state.actionData;\n }\n }\n }\n\n function getUpdatedRevalidatingFetchers(\n revalidatingFetchers: RevalidatingFetcher[]\n ) {\n revalidatingFetchers.forEach((rf) => {\n let fetcher = state.fetchers.get(rf.key);\n let revalidatingFetcher = getLoadingFetcher(\n undefined,\n fetcher ? fetcher.data : undefined\n );\n state.fetchers.set(rf.key, revalidatingFetcher);\n });\n return new Map(state.fetchers);\n }\n\n // Trigger a fetcher load/submit for the given fetcher key\n function fetch(\n key: string,\n routeId: string,\n href: string | null,\n opts?: RouterFetchOptions\n ) {\n if (isServer) {\n throw new Error(\n \"router.fetch() was called during the server render, but it shouldn't be. \" +\n \"You are likely calling a useFetcher() method in the body of your component. \" +\n \"Try moving it to a useEffect or a callback.\"\n );\n }\n\n abortFetcher(key);\n\n let flushSync = (opts && opts.flushSync) === true;\n\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let normalizedPath = normalizeTo(\n state.location,\n state.matches,\n basename,\n future.v7_prependBasename,\n href,\n future.v7_relativeSplatPath,\n routeId,\n opts?.relative\n );\n let matches = matchRoutes(routesToUse, normalizedPath, basename);\n\n let fogOfWar = checkFogOfWar(matches, routesToUse, normalizedPath);\n if (fogOfWar.active && fogOfWar.matches) {\n matches = fogOfWar.matches;\n }\n\n if (!matches) {\n setFetcherError(\n key,\n routeId,\n getInternalRouterError(404, { pathname: normalizedPath }),\n { flushSync }\n );\n return;\n }\n\n let { path, submission, error } = normalizeNavigateOptions(\n future.v7_normalizeFormMethod,\n true,\n normalizedPath,\n opts\n );\n\n if (error) {\n setFetcherError(key, routeId, error, { flushSync });\n return;\n }\n\n let match = getTargetMatch(matches, path);\n\n let preventScrollReset = (opts && opts.preventScrollReset) === true;\n\n if (submission && isMutationMethod(submission.formMethod)) {\n handleFetcherAction(\n key,\n routeId,\n path,\n match,\n matches,\n fogOfWar.active,\n flushSync,\n preventScrollReset,\n submission\n );\n return;\n }\n\n // Store off the match so we can call it's shouldRevalidate on subsequent\n // revalidations\n fetchLoadMatches.set(key, { routeId, path });\n handleFetcherLoader(\n key,\n routeId,\n path,\n match,\n matches,\n fogOfWar.active,\n flushSync,\n preventScrollReset,\n submission\n );\n }\n\n // Call the action for the matched fetcher.submit(), and then handle redirects,\n // errors, and revalidation\n async function handleFetcherAction(\n key: string,\n routeId: string,\n path: string,\n match: AgnosticDataRouteMatch,\n requestMatches: AgnosticDataRouteMatch[],\n isFogOfWar: boolean,\n flushSync: boolean,\n preventScrollReset: boolean,\n submission: Submission\n ) {\n interruptActiveLoads();\n fetchLoadMatches.delete(key);\n\n function detectAndHandle405Error(m: AgnosticDataRouteMatch) {\n if (!m.route.action && !m.route.lazy) {\n let error = getInternalRouterError(405, {\n method: submission.formMethod,\n pathname: path,\n routeId: routeId,\n });\n setFetcherError(key, routeId, error, { flushSync });\n return true;\n }\n return false;\n }\n\n if (!isFogOfWar && detectAndHandle405Error(match)) {\n return;\n }\n\n // Put this fetcher into it's submitting state\n let existingFetcher = state.fetchers.get(key);\n updateFetcherState(key, getSubmittingFetcher(submission, existingFetcher), {\n flushSync,\n });\n\n let abortController = new AbortController();\n let fetchRequest = createClientSideRequest(\n init.history,\n path,\n abortController.signal,\n submission\n );\n\n if (isFogOfWar) {\n let discoverResult = await discoverRoutes(\n requestMatches,\n path,\n fetchRequest.signal\n );\n\n if (discoverResult.type === \"aborted\") {\n return;\n } else if (discoverResult.type === \"error\") {\n setFetcherError(key, routeId, discoverResult.error, { flushSync });\n return;\n } else if (!discoverResult.matches) {\n setFetcherError(\n key,\n routeId,\n getInternalRouterError(404, { pathname: path }),\n { flushSync }\n );\n return;\n } else {\n requestMatches = discoverResult.matches;\n match = getTargetMatch(requestMatches, path);\n\n if (detectAndHandle405Error(match)) {\n return;\n }\n }\n }\n\n // Call the action for the fetcher\n fetchControllers.set(key, abortController);\n\n let originatingLoadId = incrementingLoadId;\n let actionResults = await callDataStrategy(\n \"action\",\n state,\n fetchRequest,\n [match],\n requestMatches,\n key\n );\n let actionResult = actionResults[match.route.id];\n\n if (fetchRequest.signal.aborted) {\n // We can delete this so long as we weren't aborted by our own fetcher\n // re-submit which would have put _new_ controller is in fetchControllers\n if (fetchControllers.get(key) === abortController) {\n fetchControllers.delete(key);\n }\n return;\n }\n\n // When using v7_fetcherPersist, we don't want errors bubbling up to the UI\n // or redirects processed for unmounted fetchers so we just revert them to\n // idle\n if (future.v7_fetcherPersist && deletedFetchers.has(key)) {\n if (isRedirectResult(actionResult) || isErrorResult(actionResult)) {\n updateFetcherState(key, getDoneFetcher(undefined));\n return;\n }\n // Let SuccessResult's fall through for revalidation\n } else {\n if (isRedirectResult(actionResult)) {\n fetchControllers.delete(key);\n if (pendingNavigationLoadId > originatingLoadId) {\n // A new navigation was kicked off after our action started, so that\n // should take precedence over this redirect navigation. We already\n // set isRevalidationRequired so all loaders for the new route should\n // fire unless opted out via shouldRevalidate\n updateFetcherState(key, getDoneFetcher(undefined));\n return;\n } else {\n fetchRedirectIds.add(key);\n updateFetcherState(key, getLoadingFetcher(submission));\n return startRedirectNavigation(fetchRequest, actionResult, false, {\n fetcherSubmission: submission,\n preventScrollReset,\n });\n }\n }\n\n // Process any non-redirect errors thrown\n if (isErrorResult(actionResult)) {\n setFetcherError(key, routeId, actionResult.error);\n return;\n }\n }\n\n if (isDeferredResult(actionResult)) {\n throw getInternalRouterError(400, { type: \"defer-action\" });\n }\n\n // Start the data load for current matches, or the next location if we're\n // in the middle of a navigation\n let nextLocation = state.navigation.location || state.location;\n let revalidationRequest = createClientSideRequest(\n init.history,\n nextLocation,\n abortController.signal\n );\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let matches =\n state.navigation.state !== \"idle\"\n ? matchRoutes(routesToUse, state.navigation.location, basename)\n : state.matches;\n\n invariant(matches, \"Didn't find any matches after fetcher action\");\n\n let loadId = ++incrementingLoadId;\n fetchReloadIds.set(key, loadId);\n\n let loadFetcher = getLoadingFetcher(submission, actionResult.data);\n state.fetchers.set(key, loadFetcher);\n\n let [matchesToLoad, revalidatingFetchers] = getMatchesToLoad(\n init.history,\n state,\n matches,\n submission,\n nextLocation,\n false,\n future.v7_skipActionErrorRevalidation,\n isRevalidationRequired,\n cancelledDeferredRoutes,\n cancelledFetcherLoads,\n deletedFetchers,\n fetchLoadMatches,\n fetchRedirectIds,\n routesToUse,\n basename,\n [match.route.id, actionResult]\n );\n\n // Put all revalidating fetchers into the loading state, except for the\n // current fetcher which we want to keep in it's current loading state which\n // contains it's action submission info + action data\n revalidatingFetchers\n .filter((rf) => rf.key !== key)\n .forEach((rf) => {\n let staleKey = rf.key;\n let existingFetcher = state.fetchers.get(staleKey);\n let revalidatingFetcher = getLoadingFetcher(\n undefined,\n existingFetcher ? existingFetcher.data : undefined\n );\n state.fetchers.set(staleKey, revalidatingFetcher);\n abortFetcher(staleKey);\n if (rf.controller) {\n fetchControllers.set(staleKey, rf.controller);\n }\n });\n\n updateState({ fetchers: new Map(state.fetchers) });\n\n let abortPendingFetchRevalidations = () =>\n revalidatingFetchers.forEach((rf) => abortFetcher(rf.key));\n\n abortController.signal.addEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n\n let { loaderResults, fetcherResults } =\n await callLoadersAndMaybeResolveData(\n state,\n matches,\n matchesToLoad,\n revalidatingFetchers,\n revalidationRequest\n );\n\n if (abortController.signal.aborted) {\n return;\n }\n\n abortController.signal.removeEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n\n fetchReloadIds.delete(key);\n fetchControllers.delete(key);\n revalidatingFetchers.forEach((r) => fetchControllers.delete(r.key));\n\n let redirect = findRedirect(loaderResults);\n if (redirect) {\n return startRedirectNavigation(\n revalidationRequest,\n redirect.result,\n false,\n { preventScrollReset }\n );\n }\n\n redirect = findRedirect(fetcherResults);\n if (redirect) {\n // If this redirect came from a fetcher make sure we mark it in\n // fetchRedirectIds so it doesn't get revalidated on the next set of\n // loader executions\n fetchRedirectIds.add(redirect.key);\n return startRedirectNavigation(\n revalidationRequest,\n redirect.result,\n false,\n { preventScrollReset }\n );\n }\n\n // Process and commit output from loaders\n let { loaderData, errors } = processLoaderData(\n state,\n matches,\n loaderResults,\n undefined,\n revalidatingFetchers,\n fetcherResults,\n activeDeferreds\n );\n\n // Since we let revalidations complete even if the submitting fetcher was\n // deleted, only put it back to idle if it hasn't been deleted\n if (state.fetchers.has(key)) {\n let doneFetcher = getDoneFetcher(actionResult.data);\n state.fetchers.set(key, doneFetcher);\n }\n\n abortStaleFetchLoads(loadId);\n\n // If we are currently in a navigation loading state and this fetcher is\n // more recent than the navigation, we want the newer data so abort the\n // navigation and complete it with the fetcher data\n if (\n state.navigation.state === \"loading\" &&\n loadId > pendingNavigationLoadId\n ) {\n invariant(pendingAction, \"Expected pending action\");\n pendingNavigationController && pendingNavigationController.abort();\n\n completeNavigation(state.navigation.location, {\n matches,\n loaderData,\n errors,\n fetchers: new Map(state.fetchers),\n });\n } else {\n // otherwise just update with the fetcher data, preserving any existing\n // loaderData for loaders that did not need to reload. We have to\n // manually merge here since we aren't going through completeNavigation\n updateState({\n errors,\n loaderData: mergeLoaderData(\n state.loaderData,\n loaderData,\n matches,\n errors\n ),\n fetchers: new Map(state.fetchers),\n });\n isRevalidationRequired = false;\n }\n }\n\n // Call the matched loader for fetcher.load(), handling redirects, errors, etc.\n async function handleFetcherLoader(\n key: string,\n routeId: string,\n path: string,\n match: AgnosticDataRouteMatch,\n matches: AgnosticDataRouteMatch[],\n isFogOfWar: boolean,\n flushSync: boolean,\n preventScrollReset: boolean,\n submission?: Submission\n ) {\n let existingFetcher = state.fetchers.get(key);\n updateFetcherState(\n key,\n getLoadingFetcher(\n submission,\n existingFetcher ? existingFetcher.data : undefined\n ),\n { flushSync }\n );\n\n let abortController = new AbortController();\n let fetchRequest = createClientSideRequest(\n init.history,\n path,\n abortController.signal\n );\n\n if (isFogOfWar) {\n let discoverResult = await discoverRoutes(\n matches,\n path,\n fetchRequest.signal\n );\n\n if (discoverResult.type === \"aborted\") {\n return;\n } else if (discoverResult.type === \"error\") {\n setFetcherError(key, routeId, discoverResult.error, { flushSync });\n return;\n } else if (!discoverResult.matches) {\n setFetcherError(\n key,\n routeId,\n getInternalRouterError(404, { pathname: path }),\n { flushSync }\n );\n return;\n } else {\n matches = discoverResult.matches;\n match = getTargetMatch(matches, path);\n }\n }\n\n // Call the loader for this fetcher route match\n fetchControllers.set(key, abortController);\n\n let originatingLoadId = incrementingLoadId;\n let results = await callDataStrategy(\n \"loader\",\n state,\n fetchRequest,\n [match],\n matches,\n key\n );\n let result = results[match.route.id];\n\n // Deferred isn't supported for fetcher loads, await everything and treat it\n // as a normal load. resolveDeferredData will return undefined if this\n // fetcher gets aborted, so we just leave result untouched and short circuit\n // below if that happens\n if (isDeferredResult(result)) {\n result =\n (await resolveDeferredData(result, fetchRequest.signal, true)) ||\n result;\n }\n\n // We can delete this so long as we weren't aborted by our our own fetcher\n // re-load which would have put _new_ controller is in fetchControllers\n if (fetchControllers.get(key) === abortController) {\n fetchControllers.delete(key);\n }\n\n if (fetchRequest.signal.aborted) {\n return;\n }\n\n // We don't want errors bubbling up or redirects followed for unmounted\n // fetchers, so short circuit here if it was removed from the UI\n if (deletedFetchers.has(key)) {\n updateFetcherState(key, getDoneFetcher(undefined));\n return;\n }\n\n // If the loader threw a redirect Response, start a new REPLACE navigation\n if (isRedirectResult(result)) {\n if (pendingNavigationLoadId > originatingLoadId) {\n // A new navigation was kicked off after our loader started, so that\n // should take precedence over this redirect navigation\n updateFetcherState(key, getDoneFetcher(undefined));\n return;\n } else {\n fetchRedirectIds.add(key);\n await startRedirectNavigation(fetchRequest, result, false, {\n preventScrollReset,\n });\n return;\n }\n }\n\n // Process any non-redirect errors thrown\n if (isErrorResult(result)) {\n setFetcherError(key, routeId, result.error);\n return;\n }\n\n invariant(!isDeferredResult(result), \"Unhandled fetcher deferred data\");\n\n // Put the fetcher back into an idle state\n updateFetcherState(key, getDoneFetcher(result.data));\n }\n\n /**\n * Utility function to handle redirects returned from an action or loader.\n * Normally, a redirect \"replaces\" the navigation that triggered it. So, for\n * example:\n *\n * - user is on /a\n * - user clicks a link to /b\n * - loader for /b redirects to /c\n *\n * In a non-JS app the browser would track the in-flight navigation to /b and\n * then replace it with /c when it encountered the redirect response. In\n * the end it would only ever update the URL bar with /c.\n *\n * In client-side routing using pushState/replaceState, we aim to emulate\n * this behavior and we also do not update history until the end of the\n * navigation (including processed redirects). This means that we never\n * actually touch history until we've processed redirects, so we just use\n * the history action from the original navigation (PUSH or REPLACE).\n */\n async function startRedirectNavigation(\n request: Request,\n redirect: RedirectResult,\n isNavigation: boolean,\n {\n submission,\n fetcherSubmission,\n preventScrollReset,\n replace,\n }: {\n submission?: Submission;\n fetcherSubmission?: Submission;\n preventScrollReset?: boolean;\n replace?: boolean;\n } = {}\n ) {\n if (redirect.response.headers.has(\"X-Remix-Revalidate\")) {\n isRevalidationRequired = true;\n }\n\n let location = redirect.response.headers.get(\"Location\");\n invariant(location, \"Expected a Location header on the redirect Response\");\n location = normalizeRedirectLocation(\n location,\n new URL(request.url),\n basename\n );\n let redirectLocation = createLocation(state.location, location, {\n _isRedirect: true,\n });\n\n if (isBrowser) {\n let isDocumentReload = false;\n\n if (redirect.response.headers.has(\"X-Remix-Reload-Document\")) {\n // Hard reload if the response contained X-Remix-Reload-Document\n isDocumentReload = true;\n } else if (ABSOLUTE_URL_REGEX.test(location)) {\n const url = init.history.createURL(location);\n isDocumentReload =\n // Hard reload if it's an absolute URL to a new origin\n url.origin !== routerWindow.location.origin ||\n // Hard reload if it's an absolute URL that does not match our basename\n stripBasename(url.pathname, basename) == null;\n }\n\n if (isDocumentReload) {\n if (replace) {\n routerWindow.location.replace(location);\n } else {\n routerWindow.location.assign(location);\n }\n return;\n }\n }\n\n // There's no need to abort on redirects, since we don't detect the\n // redirect until the action/loaders have settled\n pendingNavigationController = null;\n\n let redirectHistoryAction =\n replace === true || redirect.response.headers.has(\"X-Remix-Replace\")\n ? HistoryAction.Replace\n : HistoryAction.Push;\n\n // Use the incoming submission if provided, fallback on the active one in\n // state.navigation\n let { formMethod, formAction, formEncType } = state.navigation;\n if (\n !submission &&\n !fetcherSubmission &&\n formMethod &&\n formAction &&\n formEncType\n ) {\n submission = getSubmissionFromNavigation(state.navigation);\n }\n\n // If this was a 307/308 submission we want to preserve the HTTP method and\n // re-submit the GET/POST/PUT/PATCH/DELETE as a submission navigation to the\n // redirected location\n let activeSubmission = submission || fetcherSubmission;\n if (\n redirectPreserveMethodStatusCodes.has(redirect.response.status) &&\n activeSubmission &&\n isMutationMethod(activeSubmission.formMethod)\n ) {\n await startNavigation(redirectHistoryAction, redirectLocation, {\n submission: {\n ...activeSubmission,\n formAction: location,\n },\n // Preserve these flags across redirects\n preventScrollReset: preventScrollReset || pendingPreventScrollReset,\n enableViewTransition: isNavigation\n ? pendingViewTransitionEnabled\n : undefined,\n });\n } else {\n // If we have a navigation submission, we will preserve it through the\n // redirect navigation\n let overrideNavigation = getLoadingNavigation(\n redirectLocation,\n submission\n );\n await startNavigation(redirectHistoryAction, redirectLocation, {\n overrideNavigation,\n // Send fetcher submissions through for shouldRevalidate\n fetcherSubmission,\n // Preserve these flags across redirects\n preventScrollReset: preventScrollReset || pendingPreventScrollReset,\n enableViewTransition: isNavigation\n ? pendingViewTransitionEnabled\n : undefined,\n });\n }\n }\n\n // Utility wrapper for calling dataStrategy client-side without having to\n // pass around the manifest, mapRouteProperties, etc.\n async function callDataStrategy(\n type: \"loader\" | \"action\",\n state: RouterState,\n request: Request,\n matchesToLoad: AgnosticDataRouteMatch[],\n matches: AgnosticDataRouteMatch[],\n fetcherKey: string | null\n ): Promise> {\n let results: Record;\n let dataResults: Record = {};\n try {\n results = await callDataStrategyImpl(\n dataStrategyImpl,\n type,\n state,\n request,\n matchesToLoad,\n matches,\n fetcherKey,\n manifest,\n mapRouteProperties\n );\n } catch (e) {\n // If the outer dataStrategy method throws, just return the error for all\n // matches - and it'll naturally bubble to the root\n matchesToLoad.forEach((m) => {\n dataResults[m.route.id] = {\n type: ResultType.error,\n error: e,\n };\n });\n return dataResults;\n }\n\n for (let [routeId, result] of Object.entries(results)) {\n if (isRedirectDataStrategyResultResult(result)) {\n let response = result.result as Response;\n dataResults[routeId] = {\n type: ResultType.redirect,\n response: normalizeRelativeRoutingRedirectResponse(\n response,\n request,\n routeId,\n matches,\n basename,\n future.v7_relativeSplatPath\n ),\n };\n } else {\n dataResults[routeId] = await convertDataStrategyResultToDataResult(\n result\n );\n }\n }\n\n return dataResults;\n }\n\n async function callLoadersAndMaybeResolveData(\n state: RouterState,\n matches: AgnosticDataRouteMatch[],\n matchesToLoad: AgnosticDataRouteMatch[],\n fetchersToLoad: RevalidatingFetcher[],\n request: Request\n ) {\n let currentMatches = state.matches;\n\n // Kick off loaders and fetchers in parallel\n let loaderResultsPromise = callDataStrategy(\n \"loader\",\n state,\n request,\n matchesToLoad,\n matches,\n null\n );\n\n let fetcherResultsPromise = Promise.all(\n fetchersToLoad.map(async (f) => {\n if (f.matches && f.match && f.controller) {\n let results = await callDataStrategy(\n \"loader\",\n state,\n createClientSideRequest(init.history, f.path, f.controller.signal),\n [f.match],\n f.matches,\n f.key\n );\n let result = results[f.match.route.id];\n // Fetcher results are keyed by fetcher key from here on out, not routeId\n return { [f.key]: result };\n } else {\n return Promise.resolve({\n [f.key]: {\n type: ResultType.error,\n error: getInternalRouterError(404, {\n pathname: f.path,\n }),\n } as ErrorResult,\n });\n }\n })\n );\n\n let loaderResults = await loaderResultsPromise;\n let fetcherResults = (await fetcherResultsPromise).reduce(\n (acc, r) => Object.assign(acc, r),\n {}\n );\n\n await Promise.all([\n resolveNavigationDeferredResults(\n matches,\n loaderResults,\n request.signal,\n currentMatches,\n state.loaderData\n ),\n resolveFetcherDeferredResults(matches, fetcherResults, fetchersToLoad),\n ]);\n\n return {\n loaderResults,\n fetcherResults,\n };\n }\n\n function interruptActiveLoads() {\n // Every interruption triggers a revalidation\n isRevalidationRequired = true;\n\n // Cancel pending route-level deferreds and mark cancelled routes for\n // revalidation\n cancelledDeferredRoutes.push(...cancelActiveDeferreds());\n\n // Abort in-flight fetcher loads\n fetchLoadMatches.forEach((_, key) => {\n if (fetchControllers.has(key)) {\n cancelledFetcherLoads.add(key);\n }\n abortFetcher(key);\n });\n }\n\n function updateFetcherState(\n key: string,\n fetcher: Fetcher,\n opts: { flushSync?: boolean } = {}\n ) {\n state.fetchers.set(key, fetcher);\n updateState(\n { fetchers: new Map(state.fetchers) },\n { flushSync: (opts && opts.flushSync) === true }\n );\n }\n\n function setFetcherError(\n key: string,\n routeId: string,\n error: any,\n opts: { flushSync?: boolean } = {}\n ) {\n let boundaryMatch = findNearestBoundary(state.matches, routeId);\n deleteFetcher(key);\n updateState(\n {\n errors: {\n [boundaryMatch.route.id]: error,\n },\n fetchers: new Map(state.fetchers),\n },\n { flushSync: (opts && opts.flushSync) === true }\n );\n }\n\n function getFetcher(key: string): Fetcher {\n if (future.v7_fetcherPersist) {\n activeFetchers.set(key, (activeFetchers.get(key) || 0) + 1);\n // If this fetcher was previously marked for deletion, unmark it since we\n // have a new instance\n if (deletedFetchers.has(key)) {\n deletedFetchers.delete(key);\n }\n }\n return state.fetchers.get(key) || IDLE_FETCHER;\n }\n\n function deleteFetcher(key: string): void {\n let fetcher = state.fetchers.get(key);\n // Don't abort the controller if this is a deletion of a fetcher.submit()\n // in it's loading phase since - we don't want to abort the corresponding\n // revalidation and want them to complete and land\n if (\n fetchControllers.has(key) &&\n !(fetcher && fetcher.state === \"loading\" && fetchReloadIds.has(key))\n ) {\n abortFetcher(key);\n }\n fetchLoadMatches.delete(key);\n fetchReloadIds.delete(key);\n fetchRedirectIds.delete(key);\n deletedFetchers.delete(key);\n cancelledFetcherLoads.delete(key);\n state.fetchers.delete(key);\n }\n\n function deleteFetcherAndUpdateState(key: string): void {\n if (future.v7_fetcherPersist) {\n let count = (activeFetchers.get(key) || 0) - 1;\n if (count <= 0) {\n activeFetchers.delete(key);\n deletedFetchers.add(key);\n } else {\n activeFetchers.set(key, count);\n }\n } else {\n deleteFetcher(key);\n }\n updateState({ fetchers: new Map(state.fetchers) });\n }\n\n function abortFetcher(key: string) {\n let controller = fetchControllers.get(key);\n if (controller) {\n controller.abort();\n fetchControllers.delete(key);\n }\n }\n\n function markFetchersDone(keys: string[]) {\n for (let key of keys) {\n let fetcher = getFetcher(key);\n let doneFetcher = getDoneFetcher(fetcher.data);\n state.fetchers.set(key, doneFetcher);\n }\n }\n\n function markFetchRedirectsDone(): boolean {\n let doneKeys = [];\n let updatedFetchers = false;\n for (let key of fetchRedirectIds) {\n let fetcher = state.fetchers.get(key);\n invariant(fetcher, `Expected fetcher: ${key}`);\n if (fetcher.state === \"loading\") {\n fetchRedirectIds.delete(key);\n doneKeys.push(key);\n updatedFetchers = true;\n }\n }\n markFetchersDone(doneKeys);\n return updatedFetchers;\n }\n\n function abortStaleFetchLoads(landedId: number): boolean {\n let yeetedKeys = [];\n for (let [key, id] of fetchReloadIds) {\n if (id < landedId) {\n let fetcher = state.fetchers.get(key);\n invariant(fetcher, `Expected fetcher: ${key}`);\n if (fetcher.state === \"loading\") {\n abortFetcher(key);\n fetchReloadIds.delete(key);\n yeetedKeys.push(key);\n }\n }\n }\n markFetchersDone(yeetedKeys);\n return yeetedKeys.length > 0;\n }\n\n function getBlocker(key: string, fn: BlockerFunction) {\n let blocker: Blocker = state.blockers.get(key) || IDLE_BLOCKER;\n\n if (blockerFunctions.get(key) !== fn) {\n blockerFunctions.set(key, fn);\n }\n\n return blocker;\n }\n\n function deleteBlocker(key: string) {\n state.blockers.delete(key);\n blockerFunctions.delete(key);\n }\n\n // Utility function to update blockers, ensuring valid state transitions\n function updateBlocker(key: string, newBlocker: Blocker) {\n let blocker = state.blockers.get(key) || IDLE_BLOCKER;\n\n // Poor mans state machine :)\n // https://mermaid.live/edit#pako:eNqVkc9OwzAMxl8l8nnjAYrEtDIOHEBIgwvKJTReGy3_lDpIqO27k6awMG0XcrLlnz87nwdonESogKXXBuE79rq75XZO3-yHds0RJVuv70YrPlUrCEe2HfrORS3rubqZfuhtpg5C9wk5tZ4VKcRUq88q9Z8RS0-48cE1iHJkL0ugbHuFLus9L6spZy8nX9MP2CNdomVaposqu3fGayT8T8-jJQwhepo_UtpgBQaDEUom04dZhAN1aJBDlUKJBxE1ceB2Smj0Mln-IBW5AFU2dwUiktt_2Qaq2dBfaKdEup85UV7Yd-dKjlnkabl2Pvr0DTkTreM\n invariant(\n (blocker.state === \"unblocked\" && newBlocker.state === \"blocked\") ||\n (blocker.state === \"blocked\" && newBlocker.state === \"blocked\") ||\n (blocker.state === \"blocked\" && newBlocker.state === \"proceeding\") ||\n (blocker.state === \"blocked\" && newBlocker.state === \"unblocked\") ||\n (blocker.state === \"proceeding\" && newBlocker.state === \"unblocked\"),\n `Invalid blocker state transition: ${blocker.state} -> ${newBlocker.state}`\n );\n\n let blockers = new Map(state.blockers);\n blockers.set(key, newBlocker);\n updateState({ blockers });\n }\n\n function shouldBlockNavigation({\n currentLocation,\n nextLocation,\n historyAction,\n }: {\n currentLocation: Location;\n nextLocation: Location;\n historyAction: HistoryAction;\n }): string | undefined {\n if (blockerFunctions.size === 0) {\n return;\n }\n\n // We ony support a single active blocker at the moment since we don't have\n // any compelling use cases for multi-blocker yet\n if (blockerFunctions.size > 1) {\n warning(false, \"A router only supports one blocker at a time\");\n }\n\n let entries = Array.from(blockerFunctions.entries());\n let [blockerKey, blockerFunction] = entries[entries.length - 1];\n let blocker = state.blockers.get(blockerKey);\n\n if (blocker && blocker.state === \"proceeding\") {\n // If the blocker is currently proceeding, we don't need to re-check\n // it and can let this navigation continue\n return;\n }\n\n // At this point, we know we're unblocked/blocked so we need to check the\n // user-provided blocker function\n if (blockerFunction({ currentLocation, nextLocation, historyAction })) {\n return blockerKey;\n }\n }\n\n function handleNavigational404(pathname: string) {\n let error = getInternalRouterError(404, { pathname });\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let { matches, route } = getShortCircuitMatches(routesToUse);\n\n // Cancel all pending deferred on 404s since we don't keep any routes\n cancelActiveDeferreds();\n\n return { notFoundMatches: matches, route, error };\n }\n\n function cancelActiveDeferreds(\n predicate?: (routeId: string) => boolean\n ): string[] {\n let cancelledRouteIds: string[] = [];\n activeDeferreds.forEach((dfd, routeId) => {\n if (!predicate || predicate(routeId)) {\n // Cancel the deferred - but do not remove from activeDeferreds here -\n // we rely on the subscribers to do that so our tests can assert proper\n // cleanup via _internalActiveDeferreds\n dfd.cancel();\n cancelledRouteIds.push(routeId);\n activeDeferreds.delete(routeId);\n }\n });\n return cancelledRouteIds;\n }\n\n // Opt in to capturing and reporting scroll positions during navigations,\n // used by the component\n function enableScrollRestoration(\n positions: Record,\n getPosition: GetScrollPositionFunction,\n getKey?: GetScrollRestorationKeyFunction\n ) {\n savedScrollPositions = positions;\n getScrollPosition = getPosition;\n getScrollRestorationKey = getKey || null;\n\n // Perform initial hydration scroll restoration, since we miss the boat on\n // the initial updateState() because we've not yet rendered \n // and therefore have no savedScrollPositions available\n if (!initialScrollRestored && state.navigation === IDLE_NAVIGATION) {\n initialScrollRestored = true;\n let y = getSavedScrollPosition(state.location, state.matches);\n if (y != null) {\n updateState({ restoreScrollPosition: y });\n }\n }\n\n return () => {\n savedScrollPositions = null;\n getScrollPosition = null;\n getScrollRestorationKey = null;\n };\n }\n\n function getScrollKey(location: Location, matches: AgnosticDataRouteMatch[]) {\n if (getScrollRestorationKey) {\n let key = getScrollRestorationKey(\n location,\n matches.map((m) => convertRouteMatchToUiMatch(m, state.loaderData))\n );\n return key || location.key;\n }\n return location.key;\n }\n\n function saveScrollPosition(\n location: Location,\n matches: AgnosticDataRouteMatch[]\n ): void {\n if (savedScrollPositions && getScrollPosition) {\n let key = getScrollKey(location, matches);\n savedScrollPositions[key] = getScrollPosition();\n }\n }\n\n function getSavedScrollPosition(\n location: Location,\n matches: AgnosticDataRouteMatch[]\n ): number | null {\n if (savedScrollPositions) {\n let key = getScrollKey(location, matches);\n let y = savedScrollPositions[key];\n if (typeof y === \"number\") {\n return y;\n }\n }\n return null;\n }\n\n function checkFogOfWar(\n matches: AgnosticDataRouteMatch[] | null,\n routesToUse: AgnosticDataRouteObject[],\n pathname: string\n ): { active: boolean; matches: AgnosticDataRouteMatch[] | null } {\n if (patchRoutesOnNavigationImpl) {\n if (!matches) {\n let fogMatches = matchRoutesImpl(\n routesToUse,\n pathname,\n basename,\n true\n );\n\n return { active: true, matches: fogMatches || [] };\n } else {\n if (Object.keys(matches[0].params).length > 0) {\n // If we matched a dynamic param or a splat, it might only be because\n // we haven't yet discovered other routes that would match with a\n // higher score. Call patchRoutesOnNavigation just to be sure\n let partialMatches = matchRoutesImpl(\n routesToUse,\n pathname,\n basename,\n true\n );\n return { active: true, matches: partialMatches };\n }\n }\n }\n\n return { active: false, matches: null };\n }\n\n type DiscoverRoutesSuccessResult = {\n type: \"success\";\n matches: AgnosticDataRouteMatch[] | null;\n };\n type DiscoverRoutesErrorResult = {\n type: \"error\";\n error: any;\n partialMatches: AgnosticDataRouteMatch[];\n };\n type DiscoverRoutesAbortedResult = { type: \"aborted\" };\n type DiscoverRoutesResult =\n | DiscoverRoutesSuccessResult\n | DiscoverRoutesErrorResult\n | DiscoverRoutesAbortedResult;\n\n async function discoverRoutes(\n matches: AgnosticDataRouteMatch[],\n pathname: string,\n signal: AbortSignal\n ): Promise {\n if (!patchRoutesOnNavigationImpl) {\n return { type: \"success\", matches };\n }\n\n let partialMatches: AgnosticDataRouteMatch[] | null = matches;\n while (true) {\n let isNonHMR = inFlightDataRoutes == null;\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let localManifest = manifest;\n try {\n await patchRoutesOnNavigationImpl({\n path: pathname,\n matches: partialMatches,\n patch: (routeId, children) => {\n if (signal.aborted) return;\n patchRoutesImpl(\n routeId,\n children,\n routesToUse,\n localManifest,\n mapRouteProperties\n );\n },\n });\n } catch (e) {\n return { type: \"error\", error: e, partialMatches };\n } finally {\n // If we are not in the middle of an HMR revalidation and we changed the\n // routes, provide a new identity so when we `updateState` at the end of\n // this navigation/fetch `router.routes` will be a new identity and\n // trigger a re-run of memoized `router.routes` dependencies.\n // HMR will already update the identity and reflow when it lands\n // `inFlightDataRoutes` in `completeNavigation`\n if (isNonHMR && !signal.aborted) {\n dataRoutes = [...dataRoutes];\n }\n }\n\n if (signal.aborted) {\n return { type: \"aborted\" };\n }\n\n let newMatches = matchRoutes(routesToUse, pathname, basename);\n if (newMatches) {\n return { type: \"success\", matches: newMatches };\n }\n\n let newPartialMatches = matchRoutesImpl(\n routesToUse,\n pathname,\n basename,\n true\n );\n\n // Avoid loops if the second pass results in the same partial matches\n if (\n !newPartialMatches ||\n (partialMatches.length === newPartialMatches.length &&\n partialMatches.every(\n (m, i) => m.route.id === newPartialMatches![i].route.id\n ))\n ) {\n return { type: \"success\", matches: null };\n }\n\n partialMatches = newPartialMatches;\n }\n }\n\n function _internalSetRoutes(newRoutes: AgnosticDataRouteObject[]) {\n manifest = {};\n inFlightDataRoutes = convertRoutesToDataRoutes(\n newRoutes,\n mapRouteProperties,\n undefined,\n manifest\n );\n }\n\n function patchRoutes(\n routeId: string | null,\n children: AgnosticRouteObject[]\n ): void {\n let isNonHMR = inFlightDataRoutes == null;\n let routesToUse = inFlightDataRoutes || dataRoutes;\n patchRoutesImpl(\n routeId,\n children,\n routesToUse,\n manifest,\n mapRouteProperties\n );\n\n // If we are not in the middle of an HMR revalidation and we changed the\n // routes, provide a new identity and trigger a reflow via `updateState`\n // to re-run memoized `router.routes` dependencies.\n // HMR will already update the identity and reflow when it lands\n // `inFlightDataRoutes` in `completeNavigation`\n if (isNonHMR) {\n dataRoutes = [...dataRoutes];\n updateState({});\n }\n }\n\n router = {\n get basename() {\n return basename;\n },\n get future() {\n return future;\n },\n get state() {\n return state;\n },\n get routes() {\n return dataRoutes;\n },\n get window() {\n return routerWindow;\n },\n initialize,\n subscribe,\n enableScrollRestoration,\n navigate,\n fetch,\n revalidate,\n // Passthrough to history-aware createHref used by useHref so we get proper\n // hash-aware URLs in DOM paths\n createHref: (to: To) => init.history.createHref(to),\n encodeLocation: (to: To) => init.history.encodeLocation(to),\n getFetcher,\n deleteFetcher: deleteFetcherAndUpdateState,\n dispose,\n getBlocker,\n deleteBlocker,\n patchRoutes,\n _internalFetchControllers: fetchControllers,\n _internalActiveDeferreds: activeDeferreds,\n // TODO: Remove setRoutes, it's temporary to avoid dealing with\n // updating the tree while validating the update algorithm.\n _internalSetRoutes,\n };\n\n return router;\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region createStaticHandler\n////////////////////////////////////////////////////////////////////////////////\n\nexport const UNSAFE_DEFERRED_SYMBOL = Symbol(\"deferred\");\n\n/**\n * Future flags to toggle new feature behavior\n */\nexport interface StaticHandlerFutureConfig {\n v7_relativeSplatPath: boolean;\n v7_throwAbortReason: boolean;\n}\n\nexport interface CreateStaticHandlerOptions {\n basename?: string;\n /**\n * @deprecated Use `mapRouteProperties` instead\n */\n detectErrorBoundary?: DetectErrorBoundaryFunction;\n mapRouteProperties?: MapRoutePropertiesFunction;\n future?: Partial;\n}\n\nexport function createStaticHandler(\n routes: AgnosticRouteObject[],\n opts?: CreateStaticHandlerOptions\n): StaticHandler {\n invariant(\n routes.length > 0,\n \"You must provide a non-empty routes array to createStaticHandler\"\n );\n\n let manifest: RouteManifest = {};\n let basename = (opts ? opts.basename : null) || \"/\";\n let mapRouteProperties: MapRoutePropertiesFunction;\n if (opts?.mapRouteProperties) {\n mapRouteProperties = opts.mapRouteProperties;\n } else if (opts?.detectErrorBoundary) {\n // If they are still using the deprecated version, wrap it with the new API\n let detectErrorBoundary = opts.detectErrorBoundary;\n mapRouteProperties = (route) => ({\n hasErrorBoundary: detectErrorBoundary(route),\n });\n } else {\n mapRouteProperties = defaultMapRouteProperties;\n }\n // Config driven behavior flags\n let future: StaticHandlerFutureConfig = {\n v7_relativeSplatPath: false,\n v7_throwAbortReason: false,\n ...(opts ? opts.future : null),\n };\n\n let dataRoutes = convertRoutesToDataRoutes(\n routes,\n mapRouteProperties,\n undefined,\n manifest\n );\n\n /**\n * The query() method is intended for document requests, in which we want to\n * call an optional action and potentially multiple loaders for all nested\n * routes. It returns a StaticHandlerContext object, which is very similar\n * to the router state (location, loaderData, actionData, errors, etc.) and\n * also adds SSR-specific information such as the statusCode and headers\n * from action/loaders Responses.\n *\n * It _should_ never throw and should report all errors through the\n * returned context.errors object, properly associating errors to their error\n * boundary. Additionally, it tracks _deepestRenderedBoundaryId which can be\n * used to emulate React error boundaries during SSr by performing a second\n * pass only down to the boundaryId.\n *\n * The one exception where we do not return a StaticHandlerContext is when a\n * redirect response is returned or thrown from any action/loader. We\n * propagate that out and return the raw Response so the HTTP server can\n * return it directly.\n *\n * - `opts.requestContext` is an optional server context that will be passed\n * to actions/loaders in the `context` parameter\n * - `opts.skipLoaderErrorBubbling` is an optional parameter that will prevent\n * the bubbling of errors which allows single-fetch-type implementations\n * where the client will handle the bubbling and we may need to return data\n * for the handling route\n */\n async function query(\n request: Request,\n {\n requestContext,\n skipLoaderErrorBubbling,\n dataStrategy,\n }: {\n requestContext?: unknown;\n skipLoaderErrorBubbling?: boolean;\n dataStrategy?: DataStrategyFunction;\n } = {}\n ): Promise {\n let url = new URL(request.url);\n let method = request.method;\n let location = createLocation(\"\", createPath(url), null, \"default\");\n let matches = matchRoutes(dataRoutes, location, basename);\n\n // SSR supports HEAD requests while SPA doesn't\n if (!isValidMethod(method) && method !== \"HEAD\") {\n let error = getInternalRouterError(405, { method });\n let { matches: methodNotAllowedMatches, route } =\n getShortCircuitMatches(dataRoutes);\n return {\n basename,\n location,\n matches: methodNotAllowedMatches,\n loaderData: {},\n actionData: null,\n errors: {\n [route.id]: error,\n },\n statusCode: error.status,\n loaderHeaders: {},\n actionHeaders: {},\n activeDeferreds: null,\n };\n } else if (!matches) {\n let error = getInternalRouterError(404, { pathname: location.pathname });\n let { matches: notFoundMatches, route } =\n getShortCircuitMatches(dataRoutes);\n return {\n basename,\n location,\n matches: notFoundMatches,\n loaderData: {},\n actionData: null,\n errors: {\n [route.id]: error,\n },\n statusCode: error.status,\n loaderHeaders: {},\n actionHeaders: {},\n activeDeferreds: null,\n };\n }\n\n let result = await queryImpl(\n request,\n location,\n matches,\n requestContext,\n dataStrategy || null,\n skipLoaderErrorBubbling === true,\n null\n );\n if (isResponse(result)) {\n return result;\n }\n\n // When returning StaticHandlerContext, we patch back in the location here\n // since we need it for React Context. But this helps keep our submit and\n // loadRouteData operating on a Request instead of a Location\n return { location, basename, ...result };\n }\n\n /**\n * The queryRoute() method is intended for targeted route requests, either\n * for fetch ?_data requests or resource route requests. In this case, we\n * are only ever calling a single action or loader, and we are returning the\n * returned value directly. In most cases, this will be a Response returned\n * from the action/loader, but it may be a primitive or other value as well -\n * and in such cases the calling context should handle that accordingly.\n *\n * We do respect the throw/return differentiation, so if an action/loader\n * throws, then this method will throw the value. This is important so we\n * can do proper boundary identification in Remix where a thrown Response\n * must go to the Catch Boundary but a returned Response is happy-path.\n *\n * One thing to note is that any Router-initiated Errors that make sense\n * to associate with a status code will be thrown as an ErrorResponse\n * instance which include the raw Error, such that the calling context can\n * serialize the error as they see fit while including the proper response\n * code. Examples here are 404 and 405 errors that occur prior to reaching\n * any user-defined loaders.\n *\n * - `opts.routeId` allows you to specify the specific route handler to call.\n * If not provided the handler will determine the proper route by matching\n * against `request.url`\n * - `opts.requestContext` is an optional server context that will be passed\n * to actions/loaders in the `context` parameter\n */\n async function queryRoute(\n request: Request,\n {\n routeId,\n requestContext,\n dataStrategy,\n }: {\n requestContext?: unknown;\n routeId?: string;\n dataStrategy?: DataStrategyFunction;\n } = {}\n ): Promise {\n let url = new URL(request.url);\n let method = request.method;\n let location = createLocation(\"\", createPath(url), null, \"default\");\n let matches = matchRoutes(dataRoutes, location, basename);\n\n // SSR supports HEAD requests while SPA doesn't\n if (!isValidMethod(method) && method !== \"HEAD\" && method !== \"OPTIONS\") {\n throw getInternalRouterError(405, { method });\n } else if (!matches) {\n throw getInternalRouterError(404, { pathname: location.pathname });\n }\n\n let match = routeId\n ? matches.find((m) => m.route.id === routeId)\n : getTargetMatch(matches, location);\n\n if (routeId && !match) {\n throw getInternalRouterError(403, {\n pathname: location.pathname,\n routeId,\n });\n } else if (!match) {\n // This should never hit I don't think?\n throw getInternalRouterError(404, { pathname: location.pathname });\n }\n\n let result = await queryImpl(\n request,\n location,\n matches,\n requestContext,\n dataStrategy || null,\n false,\n match\n );\n\n if (isResponse(result)) {\n return result;\n }\n\n let error = result.errors ? Object.values(result.errors)[0] : undefined;\n if (error !== undefined) {\n // If we got back result.errors, that means the loader/action threw\n // _something_ that wasn't a Response, but it's not guaranteed/required\n // to be an `instanceof Error` either, so we have to use throw here to\n // preserve the \"error\" state outside of queryImpl.\n throw error;\n }\n\n // Pick off the right state value to return\n if (result.actionData) {\n return Object.values(result.actionData)[0];\n }\n\n if (result.loaderData) {\n let data = Object.values(result.loaderData)[0];\n if (result.activeDeferreds?.[match.route.id]) {\n data[UNSAFE_DEFERRED_SYMBOL] = result.activeDeferreds[match.route.id];\n }\n return data;\n }\n\n return undefined;\n }\n\n async function queryImpl(\n request: Request,\n location: Location,\n matches: AgnosticDataRouteMatch[],\n requestContext: unknown,\n dataStrategy: DataStrategyFunction | null,\n skipLoaderErrorBubbling: boolean,\n routeMatch: AgnosticDataRouteMatch | null\n ): Promise | Response> {\n invariant(\n request.signal,\n \"query()/queryRoute() requests must contain an AbortController signal\"\n );\n\n try {\n if (isMutationMethod(request.method.toLowerCase())) {\n let result = await submit(\n request,\n matches,\n routeMatch || getTargetMatch(matches, location),\n requestContext,\n dataStrategy,\n skipLoaderErrorBubbling,\n routeMatch != null\n );\n return result;\n }\n\n let result = await loadRouteData(\n request,\n matches,\n requestContext,\n dataStrategy,\n skipLoaderErrorBubbling,\n routeMatch\n );\n return isResponse(result)\n ? result\n : {\n ...result,\n actionData: null,\n actionHeaders: {},\n };\n } catch (e) {\n // If the user threw/returned a Response in callLoaderOrAction for a\n // `queryRoute` call, we throw the `DataStrategyResult` to bail out early\n // and then return or throw the raw Response here accordingly\n if (isDataStrategyResult(e) && isResponse(e.result)) {\n if (e.type === ResultType.error) {\n throw e.result;\n }\n return e.result;\n }\n // Redirects are always returned since they don't propagate to catch\n // boundaries\n if (isRedirectResponse(e)) {\n return e;\n }\n throw e;\n }\n }\n\n async function submit(\n request: Request,\n matches: AgnosticDataRouteMatch[],\n actionMatch: AgnosticDataRouteMatch,\n requestContext: unknown,\n dataStrategy: DataStrategyFunction | null,\n skipLoaderErrorBubbling: boolean,\n isRouteRequest: boolean\n ): Promise | Response> {\n let result: DataResult;\n\n if (!actionMatch.route.action && !actionMatch.route.lazy) {\n let error = getInternalRouterError(405, {\n method: request.method,\n pathname: new URL(request.url).pathname,\n routeId: actionMatch.route.id,\n });\n if (isRouteRequest) {\n throw error;\n }\n result = {\n type: ResultType.error,\n error,\n };\n } else {\n let results = await callDataStrategy(\n \"action\",\n request,\n [actionMatch],\n matches,\n isRouteRequest,\n requestContext,\n dataStrategy\n );\n result = results[actionMatch.route.id];\n\n if (request.signal.aborted) {\n throwStaticHandlerAbortedError(request, isRouteRequest, future);\n }\n }\n\n if (isRedirectResult(result)) {\n // Uhhhh - this should never happen, we should always throw these from\n // callLoaderOrAction, but the type narrowing here keeps TS happy and we\n // can get back on the \"throw all redirect responses\" train here should\n // this ever happen :/\n throw new Response(null, {\n status: result.response.status,\n headers: {\n Location: result.response.headers.get(\"Location\")!,\n },\n });\n }\n\n if (isDeferredResult(result)) {\n let error = getInternalRouterError(400, { type: \"defer-action\" });\n if (isRouteRequest) {\n throw error;\n }\n result = {\n type: ResultType.error,\n error,\n };\n }\n\n if (isRouteRequest) {\n // Note: This should only be non-Response values if we get here, since\n // isRouteRequest should throw any Response received in callLoaderOrAction\n if (isErrorResult(result)) {\n throw result.error;\n }\n\n return {\n matches: [actionMatch],\n loaderData: {},\n actionData: { [actionMatch.route.id]: result.data },\n errors: null,\n // Note: statusCode + headers are unused here since queryRoute will\n // return the raw Response or value\n statusCode: 200,\n loaderHeaders: {},\n actionHeaders: {},\n activeDeferreds: null,\n };\n }\n\n // Create a GET request for the loaders\n let loaderRequest = new Request(request.url, {\n headers: request.headers,\n redirect: request.redirect,\n signal: request.signal,\n });\n\n if (isErrorResult(result)) {\n // Store off the pending error - we use it to determine which loaders\n // to call and will commit it when we complete the navigation\n let boundaryMatch = skipLoaderErrorBubbling\n ? actionMatch\n : findNearestBoundary(matches, actionMatch.route.id);\n\n let context = await loadRouteData(\n loaderRequest,\n matches,\n requestContext,\n dataStrategy,\n skipLoaderErrorBubbling,\n null,\n [boundaryMatch.route.id, result]\n );\n\n // action status codes take precedence over loader status codes\n return {\n ...context,\n statusCode: isRouteErrorResponse(result.error)\n ? result.error.status\n : result.statusCode != null\n ? result.statusCode\n : 500,\n actionData: null,\n actionHeaders: {\n ...(result.headers ? { [actionMatch.route.id]: result.headers } : {}),\n },\n };\n }\n\n let context = await loadRouteData(\n loaderRequest,\n matches,\n requestContext,\n dataStrategy,\n skipLoaderErrorBubbling,\n null\n );\n\n return {\n ...context,\n actionData: {\n [actionMatch.route.id]: result.data,\n },\n // action status codes take precedence over loader status codes\n ...(result.statusCode ? { statusCode: result.statusCode } : {}),\n actionHeaders: result.headers\n ? { [actionMatch.route.id]: result.headers }\n : {},\n };\n }\n\n async function loadRouteData(\n request: Request,\n matches: AgnosticDataRouteMatch[],\n requestContext: unknown,\n dataStrategy: DataStrategyFunction | null,\n skipLoaderErrorBubbling: boolean,\n routeMatch: AgnosticDataRouteMatch | null,\n pendingActionResult?: PendingActionResult\n ): Promise<\n | Omit<\n StaticHandlerContext,\n \"location\" | \"basename\" | \"actionData\" | \"actionHeaders\"\n >\n | Response\n > {\n let isRouteRequest = routeMatch != null;\n\n // Short circuit if we have no loaders to run (queryRoute())\n if (\n isRouteRequest &&\n !routeMatch?.route.loader &&\n !routeMatch?.route.lazy\n ) {\n throw getInternalRouterError(400, {\n method: request.method,\n pathname: new URL(request.url).pathname,\n routeId: routeMatch?.route.id,\n });\n }\n\n let requestMatches = routeMatch\n ? [routeMatch]\n : pendingActionResult && isErrorResult(pendingActionResult[1])\n ? getLoaderMatchesUntilBoundary(matches, pendingActionResult[0])\n : matches;\n let matchesToLoad = requestMatches.filter(\n (m) => m.route.loader || m.route.lazy\n );\n\n // Short circuit if we have no loaders to run (query())\n if (matchesToLoad.length === 0) {\n return {\n matches,\n // Add a null for all matched routes for proper revalidation on the client\n loaderData: matches.reduce(\n (acc, m) => Object.assign(acc, { [m.route.id]: null }),\n {}\n ),\n errors:\n pendingActionResult && isErrorResult(pendingActionResult[1])\n ? {\n [pendingActionResult[0]]: pendingActionResult[1].error,\n }\n : null,\n statusCode: 200,\n loaderHeaders: {},\n activeDeferreds: null,\n };\n }\n\n let results = await callDataStrategy(\n \"loader\",\n request,\n matchesToLoad,\n matches,\n isRouteRequest,\n requestContext,\n dataStrategy\n );\n\n if (request.signal.aborted) {\n throwStaticHandlerAbortedError(request, isRouteRequest, future);\n }\n\n // Process and commit output from loaders\n let activeDeferreds = new Map();\n let context = processRouteLoaderData(\n matches,\n results,\n pendingActionResult,\n activeDeferreds,\n skipLoaderErrorBubbling\n );\n\n // Add a null for any non-loader matches for proper revalidation on the client\n let executedLoaders = new Set(\n matchesToLoad.map((match) => match.route.id)\n );\n matches.forEach((match) => {\n if (!executedLoaders.has(match.route.id)) {\n context.loaderData[match.route.id] = null;\n }\n });\n\n return {\n ...context,\n matches,\n activeDeferreds:\n activeDeferreds.size > 0\n ? Object.fromEntries(activeDeferreds.entries())\n : null,\n };\n }\n\n // Utility wrapper for calling dataStrategy server-side without having to\n // pass around the manifest, mapRouteProperties, etc.\n async function callDataStrategy(\n type: \"loader\" | \"action\",\n request: Request,\n matchesToLoad: AgnosticDataRouteMatch[],\n matches: AgnosticDataRouteMatch[],\n isRouteRequest: boolean,\n requestContext: unknown,\n dataStrategy: DataStrategyFunction | null\n ): Promise> {\n let results = await callDataStrategyImpl(\n dataStrategy || defaultDataStrategy,\n type,\n null,\n request,\n matchesToLoad,\n matches,\n null,\n manifest,\n mapRouteProperties,\n requestContext\n );\n\n let dataResults: Record = {};\n await Promise.all(\n matches.map(async (match) => {\n if (!(match.route.id in results)) {\n return;\n }\n let result = results[match.route.id];\n if (isRedirectDataStrategyResultResult(result)) {\n let response = result.result as Response;\n // Throw redirects and let the server handle them with an HTTP redirect\n throw normalizeRelativeRoutingRedirectResponse(\n response,\n request,\n match.route.id,\n matches,\n basename,\n future.v7_relativeSplatPath\n );\n }\n if (isResponse(result.result) && isRouteRequest) {\n // For SSR single-route requests, we want to hand Responses back\n // directly without unwrapping\n throw result;\n }\n\n dataResults[match.route.id] =\n await convertDataStrategyResultToDataResult(result);\n })\n );\n return dataResults;\n }\n\n return {\n dataRoutes,\n query,\n queryRoute,\n };\n}\n\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Helpers\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * Given an existing StaticHandlerContext and an error thrown at render time,\n * provide an updated StaticHandlerContext suitable for a second SSR render\n */\nexport function getStaticContextFromError(\n routes: AgnosticDataRouteObject[],\n context: StaticHandlerContext,\n error: any\n) {\n let newContext: StaticHandlerContext = {\n ...context,\n statusCode: isRouteErrorResponse(error) ? error.status : 500,\n errors: {\n [context._deepestRenderedBoundaryId || routes[0].id]: error,\n },\n };\n return newContext;\n}\n\nfunction throwStaticHandlerAbortedError(\n request: Request,\n isRouteRequest: boolean,\n future: StaticHandlerFutureConfig\n) {\n if (future.v7_throwAbortReason && request.signal.reason !== undefined) {\n throw request.signal.reason;\n }\n\n let method = isRouteRequest ? \"queryRoute\" : \"query\";\n throw new Error(`${method}() call aborted: ${request.method} ${request.url}`);\n}\n\nfunction isSubmissionNavigation(\n opts: BaseNavigateOrFetchOptions\n): opts is SubmissionNavigateOptions {\n return (\n opts != null &&\n ((\"formData\" in opts && opts.formData != null) ||\n (\"body\" in opts && opts.body !== undefined))\n );\n}\n\nfunction normalizeTo(\n location: Path,\n matches: AgnosticDataRouteMatch[],\n basename: string,\n prependBasename: boolean,\n to: To | null,\n v7_relativeSplatPath: boolean,\n fromRouteId?: string,\n relative?: RelativeRoutingType\n) {\n let contextualMatches: AgnosticDataRouteMatch[];\n let activeRouteMatch: AgnosticDataRouteMatch | undefined;\n if (fromRouteId) {\n // Grab matches up to the calling route so our route-relative logic is\n // relative to the correct source route\n contextualMatches = [];\n for (let match of matches) {\n contextualMatches.push(match);\n if (match.route.id === fromRouteId) {\n activeRouteMatch = match;\n break;\n }\n }\n } else {\n contextualMatches = matches;\n activeRouteMatch = matches[matches.length - 1];\n }\n\n // Resolve the relative path\n let path = resolveTo(\n to ? to : \".\",\n getResolveToMatches(contextualMatches, v7_relativeSplatPath),\n stripBasename(location.pathname, basename) || location.pathname,\n relative === \"path\"\n );\n\n // When `to` is not specified we inherit search/hash from the current\n // location, unlike when to=\".\" and we just inherit the path.\n // See https://github.com/remix-run/remix/issues/927\n if (to == null) {\n path.search = location.search;\n path.hash = location.hash;\n }\n\n // Account for `?index` params when routing to the current location\n if ((to == null || to === \"\" || to === \".\") && activeRouteMatch) {\n let nakedIndex = hasNakedIndexQuery(path.search);\n if (activeRouteMatch.route.index && !nakedIndex) {\n // Add one when we're targeting an index route\n path.search = path.search\n ? path.search.replace(/^\\?/, \"?index&\")\n : \"?index\";\n } else if (!activeRouteMatch.route.index && nakedIndex) {\n // Remove existing ones when we're not\n let params = new URLSearchParams(path.search);\n let indexValues = params.getAll(\"index\");\n params.delete(\"index\");\n indexValues.filter((v) => v).forEach((v) => params.append(\"index\", v));\n let qs = params.toString();\n path.search = qs ? `?${qs}` : \"\";\n }\n }\n\n // If we're operating within a basename, prepend it to the pathname. If\n // this is a root navigation, then just use the raw basename which allows\n // the basename to have full control over the presence of a trailing slash\n // on root actions\n if (prependBasename && basename !== \"/\") {\n path.pathname =\n path.pathname === \"/\" ? basename : joinPaths([basename, path.pathname]);\n }\n\n return createPath(path);\n}\n\n// Normalize navigation options by converting formMethod=GET formData objects to\n// URLSearchParams so they behave identically to links with query params\nfunction normalizeNavigateOptions(\n normalizeFormMethod: boolean,\n isFetcher: boolean,\n path: string,\n opts?: BaseNavigateOrFetchOptions\n): {\n path: string;\n submission?: Submission;\n error?: ErrorResponseImpl;\n} {\n // Return location verbatim on non-submission navigations\n if (!opts || !isSubmissionNavigation(opts)) {\n return { path };\n }\n\n if (opts.formMethod && !isValidMethod(opts.formMethod)) {\n return {\n path,\n error: getInternalRouterError(405, { method: opts.formMethod }),\n };\n }\n\n let getInvalidBodyError = () => ({\n path,\n error: getInternalRouterError(400, { type: \"invalid-body\" }),\n });\n\n // Create a Submission on non-GET navigations\n let rawFormMethod = opts.formMethod || \"get\";\n let formMethod = normalizeFormMethod\n ? (rawFormMethod.toUpperCase() as V7_FormMethod)\n : (rawFormMethod.toLowerCase() as FormMethod);\n let formAction = stripHashFromPath(path);\n\n if (opts.body !== undefined) {\n if (opts.formEncType === \"text/plain\") {\n // text only support POST/PUT/PATCH/DELETE submissions\n if (!isMutationMethod(formMethod)) {\n return getInvalidBodyError();\n }\n\n let text =\n typeof opts.body === \"string\"\n ? opts.body\n : opts.body instanceof FormData ||\n opts.body instanceof URLSearchParams\n ? // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#plain-text-form-data\n Array.from(opts.body.entries()).reduce(\n (acc, [name, value]) => `${acc}${name}=${value}\\n`,\n \"\"\n )\n : String(opts.body);\n\n return {\n path,\n submission: {\n formMethod,\n formAction,\n formEncType: opts.formEncType,\n formData: undefined,\n json: undefined,\n text,\n },\n };\n } else if (opts.formEncType === \"application/json\") {\n // json only supports POST/PUT/PATCH/DELETE submissions\n if (!isMutationMethod(formMethod)) {\n return getInvalidBodyError();\n }\n\n try {\n let json =\n typeof opts.body === \"string\" ? JSON.parse(opts.body) : opts.body;\n\n return {\n path,\n submission: {\n formMethod,\n formAction,\n formEncType: opts.formEncType,\n formData: undefined,\n json,\n text: undefined,\n },\n };\n } catch (e) {\n return getInvalidBodyError();\n }\n }\n }\n\n invariant(\n typeof FormData === \"function\",\n \"FormData is not available in this environment\"\n );\n\n let searchParams: URLSearchParams;\n let formData: FormData;\n\n if (opts.formData) {\n searchParams = convertFormDataToSearchParams(opts.formData);\n formData = opts.formData;\n } else if (opts.body instanceof FormData) {\n searchParams = convertFormDataToSearchParams(opts.body);\n formData = opts.body;\n } else if (opts.body instanceof URLSearchParams) {\n searchParams = opts.body;\n formData = convertSearchParamsToFormData(searchParams);\n } else if (opts.body == null) {\n searchParams = new URLSearchParams();\n formData = new FormData();\n } else {\n try {\n searchParams = new URLSearchParams(opts.body);\n formData = convertSearchParamsToFormData(searchParams);\n } catch (e) {\n return getInvalidBodyError();\n }\n }\n\n let submission: Submission = {\n formMethod,\n formAction,\n formEncType:\n (opts && opts.formEncType) || \"application/x-www-form-urlencoded\",\n formData,\n json: undefined,\n text: undefined,\n };\n\n if (isMutationMethod(submission.formMethod)) {\n return { path, submission };\n }\n\n // Flatten submission onto URLSearchParams for GET submissions\n let parsedPath = parsePath(path);\n // On GET navigation submissions we can drop the ?index param from the\n // resulting location since all loaders will run. But fetcher GET submissions\n // only run a single loader so we need to preserve any incoming ?index params\n if (isFetcher && parsedPath.search && hasNakedIndexQuery(parsedPath.search)) {\n searchParams.append(\"index\", \"\");\n }\n parsedPath.search = `?${searchParams}`;\n\n return { path: createPath(parsedPath), submission };\n}\n\n// Filter out all routes at/below any caught error as they aren't going to\n// render so we don't need to load them\nfunction getLoaderMatchesUntilBoundary(\n matches: AgnosticDataRouteMatch[],\n boundaryId: string,\n includeBoundary = false\n) {\n let index = matches.findIndex((m) => m.route.id === boundaryId);\n if (index >= 0) {\n return matches.slice(0, includeBoundary ? index + 1 : index);\n }\n return matches;\n}\n\nfunction getMatchesToLoad(\n history: History,\n state: RouterState,\n matches: AgnosticDataRouteMatch[],\n submission: Submission | undefined,\n location: Location,\n initialHydration: boolean,\n skipActionErrorRevalidation: boolean,\n isRevalidationRequired: boolean,\n cancelledDeferredRoutes: string[],\n cancelledFetcherLoads: Set,\n deletedFetchers: Set,\n fetchLoadMatches: Map,\n fetchRedirectIds: Set,\n routesToUse: AgnosticDataRouteObject[],\n basename: string | undefined,\n pendingActionResult?: PendingActionResult\n): [AgnosticDataRouteMatch[], RevalidatingFetcher[]] {\n let actionResult = pendingActionResult\n ? isErrorResult(pendingActionResult[1])\n ? pendingActionResult[1].error\n : pendingActionResult[1].data\n : undefined;\n let currentUrl = history.createURL(state.location);\n let nextUrl = history.createURL(location);\n\n // Pick navigation matches that are net-new or qualify for revalidation\n let boundaryMatches = matches;\n if (initialHydration && state.errors) {\n // On initial hydration, only consider matches up to _and including_ the boundary.\n // This is inclusive to handle cases where a server loader ran successfully,\n // a child server loader bubbled up to this route, but this route has\n // `clientLoader.hydrate` so we want to still run the `clientLoader` so that\n // we have a complete version of `loaderData`\n boundaryMatches = getLoaderMatchesUntilBoundary(\n matches,\n Object.keys(state.errors)[0],\n true\n );\n } else if (pendingActionResult && isErrorResult(pendingActionResult[1])) {\n // If an action threw an error, we call loaders up to, but not including the\n // boundary\n boundaryMatches = getLoaderMatchesUntilBoundary(\n matches,\n pendingActionResult[0]\n );\n }\n\n // Don't revalidate loaders by default after action 4xx/5xx responses\n // when the flag is enabled. They can still opt-into revalidation via\n // `shouldRevalidate` via `actionResult`\n let actionStatus = pendingActionResult\n ? pendingActionResult[1].statusCode\n : undefined;\n let shouldSkipRevalidation =\n skipActionErrorRevalidation && actionStatus && actionStatus >= 400;\n\n let navigationMatches = boundaryMatches.filter((match, index) => {\n let { route } = match;\n if (route.lazy) {\n // We haven't loaded this route yet so we don't know if it's got a loader!\n return true;\n }\n\n if (route.loader == null) {\n return false;\n }\n\n if (initialHydration) {\n return shouldLoadRouteOnHydration(route, state.loaderData, state.errors);\n }\n\n // Always call the loader on new route instances and pending defer cancellations\n if (\n isNewLoader(state.loaderData, state.matches[index], match) ||\n cancelledDeferredRoutes.some((id) => id === match.route.id)\n ) {\n return true;\n }\n\n // This is the default implementation for when we revalidate. If the route\n // provides it's own implementation, then we give them full control but\n // provide this value so they can leverage it if needed after they check\n // their own specific use cases\n let currentRouteMatch = state.matches[index];\n let nextRouteMatch = match;\n\n return shouldRevalidateLoader(match, {\n currentUrl,\n currentParams: currentRouteMatch.params,\n nextUrl,\n nextParams: nextRouteMatch.params,\n ...submission,\n actionResult,\n actionStatus,\n defaultShouldRevalidate: shouldSkipRevalidation\n ? false\n : // Forced revalidation due to submission, useRevalidator, or X-Remix-Revalidate\n isRevalidationRequired ||\n currentUrl.pathname + currentUrl.search ===\n nextUrl.pathname + nextUrl.search ||\n // Search params affect all loaders\n currentUrl.search !== nextUrl.search ||\n isNewRouteInstance(currentRouteMatch, nextRouteMatch),\n });\n });\n\n // Pick fetcher.loads that need to be revalidated\n let revalidatingFetchers: RevalidatingFetcher[] = [];\n fetchLoadMatches.forEach((f, key) => {\n // Don't revalidate:\n // - on initial hydration (shouldn't be any fetchers then anyway)\n // - if fetcher won't be present in the subsequent render\n // - no longer matches the URL (v7_fetcherPersist=false)\n // - was unmounted but persisted due to v7_fetcherPersist=true\n if (\n initialHydration ||\n !matches.some((m) => m.route.id === f.routeId) ||\n deletedFetchers.has(key)\n ) {\n return;\n }\n\n let fetcherMatches = matchRoutes(routesToUse, f.path, basename);\n\n // If the fetcher path no longer matches, push it in with null matches so\n // we can trigger a 404 in callLoadersAndMaybeResolveData. Note this is\n // currently only a use-case for Remix HMR where the route tree can change\n // at runtime and remove a route previously loaded via a fetcher\n if (!fetcherMatches) {\n revalidatingFetchers.push({\n key,\n routeId: f.routeId,\n path: f.path,\n matches: null,\n match: null,\n controller: null,\n });\n return;\n }\n\n // Revalidating fetchers are decoupled from the route matches since they\n // load from a static href. They revalidate based on explicit revalidation\n // (submission, useRevalidator, or X-Remix-Revalidate)\n let fetcher = state.fetchers.get(key);\n let fetcherMatch = getTargetMatch(fetcherMatches, f.path);\n\n let shouldRevalidate = false;\n if (fetchRedirectIds.has(key)) {\n // Never trigger a revalidation of an actively redirecting fetcher\n shouldRevalidate = false;\n } else if (cancelledFetcherLoads.has(key)) {\n // Always mark for revalidation if the fetcher was cancelled\n cancelledFetcherLoads.delete(key);\n shouldRevalidate = true;\n } else if (\n fetcher &&\n fetcher.state !== \"idle\" &&\n fetcher.data === undefined\n ) {\n // If the fetcher hasn't ever completed loading yet, then this isn't a\n // revalidation, it would just be a brand new load if an explicit\n // revalidation is required\n shouldRevalidate = isRevalidationRequired;\n } else {\n // Otherwise fall back on any user-defined shouldRevalidate, defaulting\n // to explicit revalidations only\n shouldRevalidate = shouldRevalidateLoader(fetcherMatch, {\n currentUrl,\n currentParams: state.matches[state.matches.length - 1].params,\n nextUrl,\n nextParams: matches[matches.length - 1].params,\n ...submission,\n actionResult,\n actionStatus,\n defaultShouldRevalidate: shouldSkipRevalidation\n ? false\n : isRevalidationRequired,\n });\n }\n\n if (shouldRevalidate) {\n revalidatingFetchers.push({\n key,\n routeId: f.routeId,\n path: f.path,\n matches: fetcherMatches,\n match: fetcherMatch,\n controller: new AbortController(),\n });\n }\n });\n\n return [navigationMatches, revalidatingFetchers];\n}\n\nfunction shouldLoadRouteOnHydration(\n route: AgnosticDataRouteObject,\n loaderData: RouteData | null | undefined,\n errors: RouteData | null | undefined\n) {\n // We dunno if we have a loader - gotta find out!\n if (route.lazy) {\n return true;\n }\n\n // No loader, nothing to initialize\n if (!route.loader) {\n return false;\n }\n\n let hasData = loaderData != null && loaderData[route.id] !== undefined;\n let hasError = errors != null && errors[route.id] !== undefined;\n\n // Don't run if we error'd during SSR\n if (!hasData && hasError) {\n return false;\n }\n\n // Explicitly opting-in to running on hydration\n if (typeof route.loader === \"function\" && route.loader.hydrate === true) {\n return true;\n }\n\n // Otherwise, run if we're not yet initialized with anything\n return !hasData && !hasError;\n}\n\nfunction isNewLoader(\n currentLoaderData: RouteData,\n currentMatch: AgnosticDataRouteMatch,\n match: AgnosticDataRouteMatch\n) {\n let isNew =\n // [a] -> [a, b]\n !currentMatch ||\n // [a, b] -> [a, c]\n match.route.id !== currentMatch.route.id;\n\n // Handle the case that we don't have data for a re-used route, potentially\n // from a prior error or from a cancelled pending deferred\n let isMissingData = currentLoaderData[match.route.id] === undefined;\n\n // Always load if this is a net-new route or we don't yet have data\n return isNew || isMissingData;\n}\n\nfunction isNewRouteInstance(\n currentMatch: AgnosticDataRouteMatch,\n match: AgnosticDataRouteMatch\n) {\n let currentPath = currentMatch.route.path;\n return (\n // param change for this match, /users/123 -> /users/456\n currentMatch.pathname !== match.pathname ||\n // splat param changed, which is not present in match.path\n // e.g. /files/images/avatar.jpg -> files/finances.xls\n (currentPath != null &&\n currentPath.endsWith(\"*\") &&\n currentMatch.params[\"*\"] !== match.params[\"*\"])\n );\n}\n\nfunction shouldRevalidateLoader(\n loaderMatch: AgnosticDataRouteMatch,\n arg: ShouldRevalidateFunctionArgs\n) {\n if (loaderMatch.route.shouldRevalidate) {\n let routeChoice = loaderMatch.route.shouldRevalidate(arg);\n if (typeof routeChoice === \"boolean\") {\n return routeChoice;\n }\n }\n\n return arg.defaultShouldRevalidate;\n}\n\nfunction patchRoutesImpl(\n routeId: string | null,\n children: AgnosticRouteObject[],\n routesToUse: AgnosticDataRouteObject[],\n manifest: RouteManifest,\n mapRouteProperties: MapRoutePropertiesFunction\n) {\n let childrenToPatch: AgnosticDataRouteObject[];\n if (routeId) {\n let route = manifest[routeId];\n invariant(\n route,\n `No route found to patch children into: routeId = ${routeId}`\n );\n if (!route.children) {\n route.children = [];\n }\n childrenToPatch = route.children;\n } else {\n childrenToPatch = routesToUse;\n }\n\n // Don't patch in routes we already know about so that `patch` is idempotent\n // to simplify user-land code. This is useful because we re-call the\n // `patchRoutesOnNavigation` function for matched routes with params.\n let uniqueChildren = children.filter(\n (newRoute) =>\n !childrenToPatch.some((existingRoute) =>\n isSameRoute(newRoute, existingRoute)\n )\n );\n\n let newRoutes = convertRoutesToDataRoutes(\n uniqueChildren,\n mapRouteProperties,\n [routeId || \"_\", \"patch\", String(childrenToPatch?.length || \"0\")],\n manifest\n );\n\n childrenToPatch.push(...newRoutes);\n}\n\nfunction isSameRoute(\n newRoute: AgnosticRouteObject,\n existingRoute: AgnosticRouteObject\n): boolean {\n // Most optimal check is by id\n if (\n \"id\" in newRoute &&\n \"id\" in existingRoute &&\n newRoute.id === existingRoute.id\n ) {\n return true;\n }\n\n // Second is by pathing differences\n if (\n !(\n newRoute.index === existingRoute.index &&\n newRoute.path === existingRoute.path &&\n newRoute.caseSensitive === existingRoute.caseSensitive\n )\n ) {\n return false;\n }\n\n // Pathless layout routes are trickier since we need to check children.\n // If they have no children then they're the same as far as we can tell\n if (\n (!newRoute.children || newRoute.children.length === 0) &&\n (!existingRoute.children || existingRoute.children.length === 0)\n ) {\n return true;\n }\n\n // Otherwise, we look to see if every child in the new route is already\n // represented in the existing route's children\n return newRoute.children!.every((aChild, i) =>\n existingRoute.children?.some((bChild) => isSameRoute(aChild, bChild))\n );\n}\n\n/**\n * Execute route.lazy() methods to lazily load route modules (loader, action,\n * shouldRevalidate) and update the routeManifest in place which shares objects\n * with dataRoutes so those get updated as well.\n */\nasync function loadLazyRouteModule(\n route: AgnosticDataRouteObject,\n mapRouteProperties: MapRoutePropertiesFunction,\n manifest: RouteManifest\n) {\n if (!route.lazy) {\n return;\n }\n\n let lazyRoute = await route.lazy();\n\n // If the lazy route function was executed and removed by another parallel\n // call then we can return - first lazy() to finish wins because the return\n // value of lazy is expected to be static\n if (!route.lazy) {\n return;\n }\n\n let routeToUpdate = manifest[route.id];\n invariant(routeToUpdate, \"No route found in manifest\");\n\n // Update the route in place. This should be safe because there's no way\n // we could yet be sitting on this route as we can't get there without\n // resolving lazy() first.\n //\n // This is different than the HMR \"update\" use-case where we may actively be\n // on the route being updated. The main concern boils down to \"does this\n // mutation affect any ongoing navigations or any current state.matches\n // values?\". If not, it should be safe to update in place.\n let routeUpdates: Record = {};\n for (let lazyRouteProperty in lazyRoute) {\n let staticRouteValue =\n routeToUpdate[lazyRouteProperty as keyof typeof routeToUpdate];\n\n let isPropertyStaticallyDefined =\n staticRouteValue !== undefined &&\n // This property isn't static since it should always be updated based\n // on the route updates\n lazyRouteProperty !== \"hasErrorBoundary\";\n\n warning(\n !isPropertyStaticallyDefined,\n `Route \"${routeToUpdate.id}\" has a static property \"${lazyRouteProperty}\" ` +\n `defined but its lazy function is also returning a value for this property. ` +\n `The lazy route property \"${lazyRouteProperty}\" will be ignored.`\n );\n\n if (\n !isPropertyStaticallyDefined &&\n !immutableRouteKeys.has(lazyRouteProperty as ImmutableRouteKey)\n ) {\n routeUpdates[lazyRouteProperty] =\n lazyRoute[lazyRouteProperty as keyof typeof lazyRoute];\n }\n }\n\n // Mutate the route with the provided updates. Do this first so we pass\n // the updated version to mapRouteProperties\n Object.assign(routeToUpdate, routeUpdates);\n\n // Mutate the `hasErrorBoundary` property on the route based on the route\n // updates and remove the `lazy` function so we don't resolve the lazy\n // route again.\n Object.assign(routeToUpdate, {\n // To keep things framework agnostic, we use the provided\n // `mapRouteProperties` (or wrapped `detectErrorBoundary`) function to\n // set the framework-aware properties (`element`/`hasErrorBoundary`) since\n // the logic will differ between frameworks.\n ...mapRouteProperties(routeToUpdate),\n lazy: undefined,\n });\n}\n\n// Default implementation of `dataStrategy` which fetches all loaders in parallel\nasync function defaultDataStrategy({\n matches,\n}: DataStrategyFunctionArgs): ReturnType {\n let matchesToLoad = matches.filter((m) => m.shouldLoad);\n let results = await Promise.all(matchesToLoad.map((m) => m.resolve()));\n return results.reduce(\n (acc, result, i) =>\n Object.assign(acc, { [matchesToLoad[i].route.id]: result }),\n {}\n );\n}\n\nasync function callDataStrategyImpl(\n dataStrategyImpl: DataStrategyFunction,\n type: \"loader\" | \"action\",\n state: RouterState | null,\n request: Request,\n matchesToLoad: AgnosticDataRouteMatch[],\n matches: AgnosticDataRouteMatch[],\n fetcherKey: string | null,\n manifest: RouteManifest,\n mapRouteProperties: MapRoutePropertiesFunction,\n requestContext?: unknown\n): Promise> {\n let loadRouteDefinitionsPromises = matches.map((m) =>\n m.route.lazy\n ? loadLazyRouteModule(m.route, mapRouteProperties, manifest)\n : undefined\n );\n\n let dsMatches = matches.map((match, i) => {\n let loadRoutePromise = loadRouteDefinitionsPromises[i];\n let shouldLoad = matchesToLoad.some((m) => m.route.id === match.route.id);\n // `resolve` encapsulates route.lazy(), executing the loader/action,\n // and mapping return values/thrown errors to a `DataStrategyResult`. Users\n // can pass a callback to take fine-grained control over the execution\n // of the loader/action\n let resolve: DataStrategyMatch[\"resolve\"] = async (handlerOverride) => {\n if (\n handlerOverride &&\n request.method === \"GET\" &&\n (match.route.lazy || match.route.loader)\n ) {\n shouldLoad = true;\n }\n return shouldLoad\n ? callLoaderOrAction(\n type,\n request,\n match,\n loadRoutePromise,\n handlerOverride,\n requestContext\n )\n : Promise.resolve({ type: ResultType.data, result: undefined });\n };\n\n return {\n ...match,\n shouldLoad,\n resolve,\n };\n });\n\n // Send all matches here to allow for a middleware-type implementation.\n // handler will be a no-op for unneeded routes and we filter those results\n // back out below.\n let results = await dataStrategyImpl({\n matches: dsMatches,\n request,\n params: matches[0].params,\n fetcherKey,\n context: requestContext,\n });\n\n // Wait for all routes to load here but 'swallow the error since we want\n // it to bubble up from the `await loadRoutePromise` in `callLoaderOrAction` -\n // called from `match.resolve()`\n try {\n await Promise.all(loadRouteDefinitionsPromises);\n } catch (e) {\n // No-op\n }\n\n return results;\n}\n\n// Default logic for calling a loader/action is the user has no specified a dataStrategy\nasync function callLoaderOrAction(\n type: \"loader\" | \"action\",\n request: Request,\n match: AgnosticDataRouteMatch,\n loadRoutePromise: Promise | undefined,\n handlerOverride: Parameters[0],\n staticContext?: unknown\n): Promise {\n let result: DataStrategyResult;\n let onReject: (() => void) | undefined;\n\n let runHandler = (\n handler: AgnosticRouteObject[\"loader\"] | AgnosticRouteObject[\"action\"]\n ): Promise => {\n // Setup a promise we can race against so that abort signals short circuit\n let reject: () => void;\n // This will never resolve so safe to type it as Promise to\n // satisfy the function return value\n let abortPromise = new Promise((_, r) => (reject = r));\n onReject = () => reject();\n request.signal.addEventListener(\"abort\", onReject);\n\n let actualHandler = (ctx?: unknown) => {\n if (typeof handler !== \"function\") {\n return Promise.reject(\n new Error(\n `You cannot call the handler for a route which defines a boolean ` +\n `\"${type}\" [routeId: ${match.route.id}]`\n )\n );\n }\n return handler(\n {\n request,\n params: match.params,\n context: staticContext,\n },\n ...(ctx !== undefined ? [ctx] : [])\n );\n };\n\n let handlerPromise: Promise = (async () => {\n try {\n let val = await (handlerOverride\n ? handlerOverride((ctx: unknown) => actualHandler(ctx))\n : actualHandler());\n return { type: \"data\", result: val };\n } catch (e) {\n return { type: \"error\", result: e };\n }\n })();\n\n return Promise.race([handlerPromise, abortPromise]);\n };\n\n try {\n let handler = match.route[type];\n\n // If we have a route.lazy promise, await that first\n if (loadRoutePromise) {\n if (handler) {\n // Run statically defined handler in parallel with lazy()\n let handlerError;\n let [value] = await Promise.all([\n // If the handler throws, don't let it immediately bubble out,\n // since we need to let the lazy() execution finish so we know if this\n // route has a boundary that can handle the error\n runHandler(handler).catch((e) => {\n handlerError = e;\n }),\n loadRoutePromise,\n ]);\n if (handlerError !== undefined) {\n throw handlerError;\n }\n result = value!;\n } else {\n // Load lazy route module, then run any returned handler\n await loadRoutePromise;\n\n handler = match.route[type];\n if (handler) {\n // Handler still runs even if we got interrupted to maintain consistency\n // with un-abortable behavior of handler execution on non-lazy or\n // previously-lazy-loaded routes\n result = await runHandler(handler);\n } else if (type === \"action\") {\n let url = new URL(request.url);\n let pathname = url.pathname + url.search;\n throw getInternalRouterError(405, {\n method: request.method,\n pathname,\n routeId: match.route.id,\n });\n } else {\n // lazy() route has no loader to run. Short circuit here so we don't\n // hit the invariant below that errors on returning undefined.\n return { type: ResultType.data, result: undefined };\n }\n }\n } else if (!handler) {\n let url = new URL(request.url);\n let pathname = url.pathname + url.search;\n throw getInternalRouterError(404, {\n pathname,\n });\n } else {\n result = await runHandler(handler);\n }\n\n invariant(\n result.result !== undefined,\n `You defined ${type === \"action\" ? \"an action\" : \"a loader\"} for route ` +\n `\"${match.route.id}\" but didn't return anything from your \\`${type}\\` ` +\n `function. Please return a value or \\`null\\`.`\n );\n } catch (e) {\n // We should already be catching and converting normal handler executions to\n // DataStrategyResults and returning them, so anything that throws here is an\n // unexpected error we still need to wrap\n return { type: ResultType.error, result: e };\n } finally {\n if (onReject) {\n request.signal.removeEventListener(\"abort\", onReject);\n }\n }\n\n return result;\n}\n\nasync function convertDataStrategyResultToDataResult(\n dataStrategyResult: DataStrategyResult\n): Promise {\n let { result, type } = dataStrategyResult;\n\n if (isResponse(result)) {\n let data: any;\n\n try {\n let contentType = result.headers.get(\"Content-Type\");\n // Check between word boundaries instead of startsWith() due to the last\n // paragraph of https://httpwg.org/specs/rfc9110.html#field.content-type\n if (contentType && /\\bapplication\\/json\\b/.test(contentType)) {\n if (result.body == null) {\n data = null;\n } else {\n data = await result.json();\n }\n } else {\n data = await result.text();\n }\n } catch (e) {\n return { type: ResultType.error, error: e };\n }\n\n if (type === ResultType.error) {\n return {\n type: ResultType.error,\n error: new ErrorResponseImpl(result.status, result.statusText, data),\n statusCode: result.status,\n headers: result.headers,\n };\n }\n\n return {\n type: ResultType.data,\n data,\n statusCode: result.status,\n headers: result.headers,\n };\n }\n\n if (type === ResultType.error) {\n if (isDataWithResponseInit(result)) {\n if (result.data instanceof Error) {\n return {\n type: ResultType.error,\n error: result.data,\n statusCode: result.init?.status,\n };\n }\n\n // Convert thrown data() to ErrorResponse instances\n result = new ErrorResponseImpl(\n result.init?.status || 500,\n undefined,\n result.data\n );\n }\n return {\n type: ResultType.error,\n error: result,\n statusCode: isRouteErrorResponse(result) ? result.status : undefined,\n };\n }\n\n if (isDeferredData(result)) {\n return {\n type: ResultType.deferred,\n deferredData: result,\n statusCode: result.init?.status,\n headers: result.init?.headers && new Headers(result.init.headers),\n };\n }\n\n if (isDataWithResponseInit(result)) {\n return {\n type: ResultType.data,\n data: result.data,\n statusCode: result.init?.status,\n headers: result.init?.headers\n ? new Headers(result.init.headers)\n : undefined,\n };\n }\n\n return { type: ResultType.data, data: result };\n}\n\n// Support relative routing in internal redirects\nfunction normalizeRelativeRoutingRedirectResponse(\n response: Response,\n request: Request,\n routeId: string,\n matches: AgnosticDataRouteMatch[],\n basename: string,\n v7_relativeSplatPath: boolean\n) {\n let location = response.headers.get(\"Location\");\n invariant(\n location,\n \"Redirects returned/thrown from loaders/actions must have a Location header\"\n );\n\n if (!ABSOLUTE_URL_REGEX.test(location)) {\n let trimmedMatches = matches.slice(\n 0,\n matches.findIndex((m) => m.route.id === routeId) + 1\n );\n location = normalizeTo(\n new URL(request.url),\n trimmedMatches,\n basename,\n true,\n location,\n v7_relativeSplatPath\n );\n response.headers.set(\"Location\", location);\n }\n\n return response;\n}\n\nfunction normalizeRedirectLocation(\n location: string,\n currentUrl: URL,\n basename: string\n): string {\n if (ABSOLUTE_URL_REGEX.test(location)) {\n // Strip off the protocol+origin for same-origin + same-basename absolute redirects\n let normalizedLocation = location;\n let url = normalizedLocation.startsWith(\"//\")\n ? new URL(currentUrl.protocol + normalizedLocation)\n : new URL(normalizedLocation);\n let isSameBasename = stripBasename(url.pathname, basename) != null;\n if (url.origin === currentUrl.origin && isSameBasename) {\n return url.pathname + url.search + url.hash;\n }\n }\n return location;\n}\n\n// Utility method for creating the Request instances for loaders/actions during\n// client-side navigations and fetches. During SSR we will always have a\n// Request instance from the static handler (query/queryRoute)\nfunction createClientSideRequest(\n history: History,\n location: string | Location,\n signal: AbortSignal,\n submission?: Submission\n): Request {\n let url = history.createURL(stripHashFromPath(location)).toString();\n let init: RequestInit = { signal };\n\n if (submission && isMutationMethod(submission.formMethod)) {\n let { formMethod, formEncType } = submission;\n // Didn't think we needed this but it turns out unlike other methods, patch\n // won't be properly normalized to uppercase and results in a 405 error.\n // See: https://fetch.spec.whatwg.org/#concept-method\n init.method = formMethod.toUpperCase();\n\n if (formEncType === \"application/json\") {\n init.headers = new Headers({ \"Content-Type\": formEncType });\n init.body = JSON.stringify(submission.json);\n } else if (formEncType === \"text/plain\") {\n // Content-Type is inferred (https://fetch.spec.whatwg.org/#dom-request)\n init.body = submission.text;\n } else if (\n formEncType === \"application/x-www-form-urlencoded\" &&\n submission.formData\n ) {\n // Content-Type is inferred (https://fetch.spec.whatwg.org/#dom-request)\n init.body = convertFormDataToSearchParams(submission.formData);\n } else {\n // Content-Type is inferred (https://fetch.spec.whatwg.org/#dom-request)\n init.body = submission.formData;\n }\n }\n\n return new Request(url, init);\n}\n\nfunction convertFormDataToSearchParams(formData: FormData): URLSearchParams {\n let searchParams = new URLSearchParams();\n\n for (let [key, value] of formData.entries()) {\n // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#converting-an-entry-list-to-a-list-of-name-value-pairs\n searchParams.append(key, typeof value === \"string\" ? value : value.name);\n }\n\n return searchParams;\n}\n\nfunction convertSearchParamsToFormData(\n searchParams: URLSearchParams\n): FormData {\n let formData = new FormData();\n for (let [key, value] of searchParams.entries()) {\n formData.append(key, value);\n }\n return formData;\n}\n\nfunction processRouteLoaderData(\n matches: AgnosticDataRouteMatch[],\n results: Record,\n pendingActionResult: PendingActionResult | undefined,\n activeDeferreds: Map,\n skipLoaderErrorBubbling: boolean\n): {\n loaderData: RouterState[\"loaderData\"];\n errors: RouterState[\"errors\"] | null;\n statusCode: number;\n loaderHeaders: Record;\n} {\n // Fill in loaderData/errors from our loaders\n let loaderData: RouterState[\"loaderData\"] = {};\n let errors: RouterState[\"errors\"] | null = null;\n let statusCode: number | undefined;\n let foundError = false;\n let loaderHeaders: Record = {};\n let pendingError =\n pendingActionResult && isErrorResult(pendingActionResult[1])\n ? pendingActionResult[1].error\n : undefined;\n\n // Process loader results into state.loaderData/state.errors\n matches.forEach((match) => {\n if (!(match.route.id in results)) {\n return;\n }\n let id = match.route.id;\n let result = results[id];\n invariant(\n !isRedirectResult(result),\n \"Cannot handle redirect results in processLoaderData\"\n );\n if (isErrorResult(result)) {\n let error = result.error;\n // If we have a pending action error, we report it at the highest-route\n // that throws a loader error, and then clear it out to indicate that\n // it was consumed\n if (pendingError !== undefined) {\n error = pendingError;\n pendingError = undefined;\n }\n\n errors = errors || {};\n\n if (skipLoaderErrorBubbling) {\n errors[id] = error;\n } else {\n // Look upwards from the matched route for the closest ancestor error\n // boundary, defaulting to the root match. Prefer higher error values\n // if lower errors bubble to the same boundary\n let boundaryMatch = findNearestBoundary(matches, id);\n if (errors[boundaryMatch.route.id] == null) {\n errors[boundaryMatch.route.id] = error;\n }\n }\n\n // Clear our any prior loaderData for the throwing route\n loaderData[id] = undefined;\n\n // Once we find our first (highest) error, we set the status code and\n // prevent deeper status codes from overriding\n if (!foundError) {\n foundError = true;\n statusCode = isRouteErrorResponse(result.error)\n ? result.error.status\n : 500;\n }\n if (result.headers) {\n loaderHeaders[id] = result.headers;\n }\n } else {\n if (isDeferredResult(result)) {\n activeDeferreds.set(id, result.deferredData);\n loaderData[id] = result.deferredData.data;\n // Error status codes always override success status codes, but if all\n // loaders are successful we take the deepest status code.\n if (\n result.statusCode != null &&\n result.statusCode !== 200 &&\n !foundError\n ) {\n statusCode = result.statusCode;\n }\n if (result.headers) {\n loaderHeaders[id] = result.headers;\n }\n } else {\n loaderData[id] = result.data;\n // Error status codes always override success status codes, but if all\n // loaders are successful we take the deepest status code.\n if (result.statusCode && result.statusCode !== 200 && !foundError) {\n statusCode = result.statusCode;\n }\n if (result.headers) {\n loaderHeaders[id] = result.headers;\n }\n }\n }\n });\n\n // If we didn't consume the pending action error (i.e., all loaders\n // resolved), then consume it here. Also clear out any loaderData for the\n // throwing route\n if (pendingError !== undefined && pendingActionResult) {\n errors = { [pendingActionResult[0]]: pendingError };\n loaderData[pendingActionResult[0]] = undefined;\n }\n\n return {\n loaderData,\n errors,\n statusCode: statusCode || 200,\n loaderHeaders,\n };\n}\n\nfunction processLoaderData(\n state: RouterState,\n matches: AgnosticDataRouteMatch[],\n results: Record,\n pendingActionResult: PendingActionResult | undefined,\n revalidatingFetchers: RevalidatingFetcher[],\n fetcherResults: Record,\n activeDeferreds: Map\n): {\n loaderData: RouterState[\"loaderData\"];\n errors?: RouterState[\"errors\"];\n} {\n let { loaderData, errors } = processRouteLoaderData(\n matches,\n results,\n pendingActionResult,\n activeDeferreds,\n false // This method is only called client side so we always want to bubble\n );\n\n // Process results from our revalidating fetchers\n revalidatingFetchers.forEach((rf) => {\n let { key, match, controller } = rf;\n let result = fetcherResults[key];\n invariant(result, \"Did not find corresponding fetcher result\");\n\n // Process fetcher non-redirect errors\n if (controller && controller.signal.aborted) {\n // Nothing to do for aborted fetchers\n return;\n } else if (isErrorResult(result)) {\n let boundaryMatch = findNearestBoundary(state.matches, match?.route.id);\n if (!(errors && errors[boundaryMatch.route.id])) {\n errors = {\n ...errors,\n [boundaryMatch.route.id]: result.error,\n };\n }\n state.fetchers.delete(key);\n } else if (isRedirectResult(result)) {\n // Should never get here, redirects should get processed above, but we\n // keep this to type narrow to a success result in the else\n invariant(false, \"Unhandled fetcher revalidation redirect\");\n } else if (isDeferredResult(result)) {\n // Should never get here, deferred data should be awaited for fetchers\n // in resolveDeferredResults\n invariant(false, \"Unhandled fetcher deferred data\");\n } else {\n let doneFetcher = getDoneFetcher(result.data);\n state.fetchers.set(key, doneFetcher);\n }\n });\n\n return { loaderData, errors };\n}\n\nfunction mergeLoaderData(\n loaderData: RouteData,\n newLoaderData: RouteData,\n matches: AgnosticDataRouteMatch[],\n errors: RouteData | null | undefined\n): RouteData {\n let mergedLoaderData = { ...newLoaderData };\n for (let match of matches) {\n let id = match.route.id;\n if (newLoaderData.hasOwnProperty(id)) {\n if (newLoaderData[id] !== undefined) {\n mergedLoaderData[id] = newLoaderData[id];\n } else {\n // No-op - this is so we ignore existing data if we have a key in the\n // incoming object with an undefined value, which is how we unset a prior\n // loaderData if we encounter a loader error\n }\n } else if (loaderData[id] !== undefined && match.route.loader) {\n // Preserve existing keys not included in newLoaderData and where a loader\n // wasn't removed by HMR\n mergedLoaderData[id] = loaderData[id];\n }\n\n if (errors && errors.hasOwnProperty(id)) {\n // Don't keep any loader data below the boundary\n break;\n }\n }\n return mergedLoaderData;\n}\n\nfunction getActionDataForCommit(\n pendingActionResult: PendingActionResult | undefined\n) {\n if (!pendingActionResult) {\n return {};\n }\n return isErrorResult(pendingActionResult[1])\n ? {\n // Clear out prior actionData on errors\n actionData: {},\n }\n : {\n actionData: {\n [pendingActionResult[0]]: pendingActionResult[1].data,\n },\n };\n}\n\n// Find the nearest error boundary, looking upwards from the leaf route (or the\n// route specified by routeId) for the closest ancestor error boundary,\n// defaulting to the root match\nfunction findNearestBoundary(\n matches: AgnosticDataRouteMatch[],\n routeId?: string\n): AgnosticDataRouteMatch {\n let eligibleMatches = routeId\n ? matches.slice(0, matches.findIndex((m) => m.route.id === routeId) + 1)\n : [...matches];\n return (\n eligibleMatches.reverse().find((m) => m.route.hasErrorBoundary === true) ||\n matches[0]\n );\n}\n\nfunction getShortCircuitMatches(routes: AgnosticDataRouteObject[]): {\n matches: AgnosticDataRouteMatch[];\n route: AgnosticDataRouteObject;\n} {\n // Prefer a root layout route if present, otherwise shim in a route object\n let route =\n routes.length === 1\n ? routes[0]\n : routes.find((r) => r.index || !r.path || r.path === \"/\") || {\n id: `__shim-error-route__`,\n };\n\n return {\n matches: [\n {\n params: {},\n pathname: \"\",\n pathnameBase: \"\",\n route,\n },\n ],\n route,\n };\n}\n\nfunction getInternalRouterError(\n status: number,\n {\n pathname,\n routeId,\n method,\n type,\n message,\n }: {\n pathname?: string;\n routeId?: string;\n method?: string;\n type?: \"defer-action\" | \"invalid-body\";\n message?: string;\n } = {}\n) {\n let statusText = \"Unknown Server Error\";\n let errorMessage = \"Unknown @remix-run/router error\";\n\n if (status === 400) {\n statusText = \"Bad Request\";\n if (method && pathname && routeId) {\n errorMessage =\n `You made a ${method} request to \"${pathname}\" but ` +\n `did not provide a \\`loader\\` for route \"${routeId}\", ` +\n `so there is no way to handle the request.`;\n } else if (type === \"defer-action\") {\n errorMessage = \"defer() is not supported in actions\";\n } else if (type === \"invalid-body\") {\n errorMessage = \"Unable to encode submission body\";\n }\n } else if (status === 403) {\n statusText = \"Forbidden\";\n errorMessage = `Route \"${routeId}\" does not match URL \"${pathname}\"`;\n } else if (status === 404) {\n statusText = \"Not Found\";\n errorMessage = `No route matches URL \"${pathname}\"`;\n } else if (status === 405) {\n statusText = \"Method Not Allowed\";\n if (method && pathname && routeId) {\n errorMessage =\n `You made a ${method.toUpperCase()} request to \"${pathname}\" but ` +\n `did not provide an \\`action\\` for route \"${routeId}\", ` +\n `so there is no way to handle the request.`;\n } else if (method) {\n errorMessage = `Invalid request method \"${method.toUpperCase()}\"`;\n }\n }\n\n return new ErrorResponseImpl(\n status || 500,\n statusText,\n new Error(errorMessage),\n true\n );\n}\n\n// Find any returned redirect errors, starting from the lowest match\nfunction findRedirect(\n results: Record\n): { key: string; result: RedirectResult } | undefined {\n let entries = Object.entries(results);\n for (let i = entries.length - 1; i >= 0; i--) {\n let [key, result] = entries[i];\n if (isRedirectResult(result)) {\n return { key, result };\n }\n }\n}\n\nfunction stripHashFromPath(path: To) {\n let parsedPath = typeof path === \"string\" ? parsePath(path) : path;\n return createPath({ ...parsedPath, hash: \"\" });\n}\n\nfunction isHashChangeOnly(a: Location, b: Location): boolean {\n if (a.pathname !== b.pathname || a.search !== b.search) {\n return false;\n }\n\n if (a.hash === \"\") {\n // /page -> /page#hash\n return b.hash !== \"\";\n } else if (a.hash === b.hash) {\n // /page#hash -> /page#hash\n return true;\n } else if (b.hash !== \"\") {\n // /page#hash -> /page#other\n return true;\n }\n\n // If the hash is removed the browser will re-perform a request to the server\n // /page#hash -> /page\n return false;\n}\n\nfunction isPromise(val: unknown): val is Promise {\n return typeof val === \"object\" && val != null && \"then\" in val;\n}\n\nfunction isDataStrategyResult(result: unknown): result is DataStrategyResult {\n return (\n result != null &&\n typeof result === \"object\" &&\n \"type\" in result &&\n \"result\" in result &&\n (result.type === ResultType.data || result.type === ResultType.error)\n );\n}\n\nfunction isRedirectDataStrategyResultResult(result: DataStrategyResult) {\n return (\n isResponse(result.result) && redirectStatusCodes.has(result.result.status)\n );\n}\n\nfunction isDeferredResult(result: DataResult): result is DeferredResult {\n return result.type === ResultType.deferred;\n}\n\nfunction isErrorResult(result: DataResult): result is ErrorResult {\n return result.type === ResultType.error;\n}\n\nfunction isRedirectResult(result?: DataResult): result is RedirectResult {\n return (result && result.type) === ResultType.redirect;\n}\n\nexport function isDataWithResponseInit(\n value: any\n): value is DataWithResponseInit {\n return (\n typeof value === \"object\" &&\n value != null &&\n \"type\" in value &&\n \"data\" in value &&\n \"init\" in value &&\n value.type === \"DataWithResponseInit\"\n );\n}\n\nexport function isDeferredData(value: any): value is DeferredData {\n let deferred: DeferredData = value;\n return (\n deferred &&\n typeof deferred === \"object\" &&\n typeof deferred.data === \"object\" &&\n typeof deferred.subscribe === \"function\" &&\n typeof deferred.cancel === \"function\" &&\n typeof deferred.resolveData === \"function\"\n );\n}\n\nfunction isResponse(value: any): value is Response {\n return (\n value != null &&\n typeof value.status === \"number\" &&\n typeof value.statusText === \"string\" &&\n typeof value.headers === \"object\" &&\n typeof value.body !== \"undefined\"\n );\n}\n\nfunction isRedirectResponse(result: any): result is Response {\n if (!isResponse(result)) {\n return false;\n }\n\n let status = result.status;\n let location = result.headers.get(\"Location\");\n return status >= 300 && status <= 399 && location != null;\n}\n\nfunction isValidMethod(method: string): method is FormMethod | V7_FormMethod {\n return validRequestMethods.has(method.toLowerCase() as FormMethod);\n}\n\nfunction isMutationMethod(\n method: string\n): method is MutationFormMethod | V7_MutationFormMethod {\n return validMutationMethods.has(method.toLowerCase() as MutationFormMethod);\n}\n\nasync function resolveNavigationDeferredResults(\n matches: (AgnosticDataRouteMatch | null)[],\n results: Record,\n signal: AbortSignal,\n currentMatches: AgnosticDataRouteMatch[],\n currentLoaderData: RouteData\n) {\n let entries = Object.entries(results);\n for (let index = 0; index < entries.length; index++) {\n let [routeId, result] = entries[index];\n let match = matches.find((m) => m?.route.id === routeId);\n // If we don't have a match, then we can have a deferred result to do\n // anything with. This is for revalidating fetchers where the route was\n // removed during HMR\n if (!match) {\n continue;\n }\n\n let currentMatch = currentMatches.find(\n (m) => m.route.id === match!.route.id\n );\n let isRevalidatingLoader =\n currentMatch != null &&\n !isNewRouteInstance(currentMatch, match) &&\n (currentLoaderData && currentLoaderData[match.route.id]) !== undefined;\n\n if (isDeferredResult(result) && isRevalidatingLoader) {\n // Note: we do not have to touch activeDeferreds here since we race them\n // against the signal in resolveDeferredData and they'll get aborted\n // there if needed\n await resolveDeferredData(result, signal, false).then((result) => {\n if (result) {\n results[routeId] = result;\n }\n });\n }\n }\n}\n\nasync function resolveFetcherDeferredResults(\n matches: (AgnosticDataRouteMatch | null)[],\n results: Record,\n revalidatingFetchers: RevalidatingFetcher[]\n) {\n for (let index = 0; index < revalidatingFetchers.length; index++) {\n let { key, routeId, controller } = revalidatingFetchers[index];\n let result = results[key];\n let match = matches.find((m) => m?.route.id === routeId);\n // If we don't have a match, then we can have a deferred result to do\n // anything with. This is for revalidating fetchers where the route was\n // removed during HMR\n if (!match) {\n continue;\n }\n\n if (isDeferredResult(result)) {\n // Note: we do not have to touch activeDeferreds here since we race them\n // against the signal in resolveDeferredData and they'll get aborted\n // there if needed\n invariant(\n controller,\n \"Expected an AbortController for revalidating fetcher deferred result\"\n );\n await resolveDeferredData(result, controller.signal, true).then(\n (result) => {\n if (result) {\n results[key] = result;\n }\n }\n );\n }\n }\n}\n\nasync function resolveDeferredData(\n result: DeferredResult,\n signal: AbortSignal,\n unwrap = false\n): Promise {\n let aborted = await result.deferredData.resolveData(signal);\n if (aborted) {\n return;\n }\n\n if (unwrap) {\n try {\n return {\n type: ResultType.data,\n data: result.deferredData.unwrappedData,\n };\n } catch (e) {\n // Handle any TrackedPromise._error values encountered while unwrapping\n return {\n type: ResultType.error,\n error: e,\n };\n }\n }\n\n return {\n type: ResultType.data,\n data: result.deferredData.data,\n };\n}\n\nfunction hasNakedIndexQuery(search: string): boolean {\n return new URLSearchParams(search).getAll(\"index\").some((v) => v === \"\");\n}\n\nfunction getTargetMatch(\n matches: AgnosticDataRouteMatch[],\n location: Location | string\n) {\n let search =\n typeof location === \"string\" ? parsePath(location).search : location.search;\n if (\n matches[matches.length - 1].route.index &&\n hasNakedIndexQuery(search || \"\")\n ) {\n // Return the leaf index route when index is present\n return matches[matches.length - 1];\n }\n // Otherwise grab the deepest \"path contributing\" match (ignoring index and\n // pathless layout routes)\n let pathMatches = getPathContributingMatches(matches);\n return pathMatches[pathMatches.length - 1];\n}\n\nfunction getSubmissionFromNavigation(\n navigation: Navigation\n): Submission | undefined {\n let { formMethod, formAction, formEncType, text, formData, json } =\n navigation;\n if (!formMethod || !formAction || !formEncType) {\n return;\n }\n\n if (text != null) {\n return {\n formMethod,\n formAction,\n formEncType,\n formData: undefined,\n json: undefined,\n text,\n };\n } else if (formData != null) {\n return {\n formMethod,\n formAction,\n formEncType,\n formData,\n json: undefined,\n text: undefined,\n };\n } else if (json !== undefined) {\n return {\n formMethod,\n formAction,\n formEncType,\n formData: undefined,\n json,\n text: undefined,\n };\n }\n}\n\nfunction getLoadingNavigation(\n location: Location,\n submission?: Submission\n): NavigationStates[\"Loading\"] {\n if (submission) {\n let navigation: NavigationStates[\"Loading\"] = {\n state: \"loading\",\n location,\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text,\n };\n return navigation;\n } else {\n let navigation: NavigationStates[\"Loading\"] = {\n state: \"loading\",\n location,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined,\n };\n return navigation;\n }\n}\n\nfunction getSubmittingNavigation(\n location: Location,\n submission: Submission\n): NavigationStates[\"Submitting\"] {\n let navigation: NavigationStates[\"Submitting\"] = {\n state: \"submitting\",\n location,\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text,\n };\n return navigation;\n}\n\nfunction getLoadingFetcher(\n submission?: Submission,\n data?: Fetcher[\"data\"]\n): FetcherStates[\"Loading\"] {\n if (submission) {\n let fetcher: FetcherStates[\"Loading\"] = {\n state: \"loading\",\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text,\n data,\n };\n return fetcher;\n } else {\n let fetcher: FetcherStates[\"Loading\"] = {\n state: \"loading\",\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined,\n data,\n };\n return fetcher;\n }\n}\n\nfunction getSubmittingFetcher(\n submission: Submission,\n existingFetcher?: Fetcher\n): FetcherStates[\"Submitting\"] {\n let fetcher: FetcherStates[\"Submitting\"] = {\n state: \"submitting\",\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text,\n data: existingFetcher ? existingFetcher.data : undefined,\n };\n return fetcher;\n}\n\nfunction getDoneFetcher(data: Fetcher[\"data\"]): FetcherStates[\"Idle\"] {\n let fetcher: FetcherStates[\"Idle\"] = {\n state: \"idle\",\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined,\n data,\n };\n return fetcher;\n}\n\nfunction restoreAppliedTransitions(\n _window: Window,\n transitions: Map>\n) {\n try {\n let sessionPositions = _window.sessionStorage.getItem(\n TRANSITIONS_STORAGE_KEY\n );\n if (sessionPositions) {\n let json = JSON.parse(sessionPositions);\n for (let [k, v] of Object.entries(json || {})) {\n if (v && Array.isArray(v)) {\n transitions.set(k, new Set(v || []));\n }\n }\n }\n } catch (e) {\n // no-op, use default empty object\n }\n}\n\nfunction persistAppliedTransitions(\n _window: Window,\n transitions: Map>\n) {\n if (transitions.size > 0) {\n let json: Record = {};\n for (let [k, v] of transitions) {\n json[k] = [...v];\n }\n try {\n _window.sessionStorage.setItem(\n TRANSITIONS_STORAGE_KEY,\n JSON.stringify(json)\n );\n } catch (error) {\n warning(\n false,\n `Failed to save applied view transitions in sessionStorage (${error}).`\n );\n }\n }\n}\n//#endregion\n","import * as React from \"react\";\nimport type {\n AgnosticIndexRouteObject,\n AgnosticNonIndexRouteObject,\n AgnosticRouteMatch,\n History,\n LazyRouteFunction,\n Location,\n Action as NavigationType,\n RelativeRoutingType,\n Router,\n StaticHandlerContext,\n To,\n TrackedPromise,\n} from \"@remix-run/router\";\n\n// Create react-specific types from the agnostic types in @remix-run/router to\n// export from react-router\nexport interface IndexRouteObject {\n caseSensitive?: AgnosticIndexRouteObject[\"caseSensitive\"];\n path?: AgnosticIndexRouteObject[\"path\"];\n id?: AgnosticIndexRouteObject[\"id\"];\n loader?: AgnosticIndexRouteObject[\"loader\"];\n action?: AgnosticIndexRouteObject[\"action\"];\n hasErrorBoundary?: AgnosticIndexRouteObject[\"hasErrorBoundary\"];\n shouldRevalidate?: AgnosticIndexRouteObject[\"shouldRevalidate\"];\n handle?: AgnosticIndexRouteObject[\"handle\"];\n index: true;\n children?: undefined;\n element?: React.ReactNode | null;\n hydrateFallbackElement?: React.ReactNode | null;\n errorElement?: React.ReactNode | null;\n Component?: React.ComponentType | null;\n HydrateFallback?: React.ComponentType | null;\n ErrorBoundary?: React.ComponentType | null;\n lazy?: LazyRouteFunction;\n}\n\nexport interface NonIndexRouteObject {\n caseSensitive?: AgnosticNonIndexRouteObject[\"caseSensitive\"];\n path?: AgnosticNonIndexRouteObject[\"path\"];\n id?: AgnosticNonIndexRouteObject[\"id\"];\n loader?: AgnosticNonIndexRouteObject[\"loader\"];\n action?: AgnosticNonIndexRouteObject[\"action\"];\n hasErrorBoundary?: AgnosticNonIndexRouteObject[\"hasErrorBoundary\"];\n shouldRevalidate?: AgnosticNonIndexRouteObject[\"shouldRevalidate\"];\n handle?: AgnosticNonIndexRouteObject[\"handle\"];\n index?: false;\n children?: RouteObject[];\n element?: React.ReactNode | null;\n hydrateFallbackElement?: React.ReactNode | null;\n errorElement?: React.ReactNode | null;\n Component?: React.ComponentType | null;\n HydrateFallback?: React.ComponentType | null;\n ErrorBoundary?: React.ComponentType | null;\n lazy?: LazyRouteFunction;\n}\n\nexport type RouteObject = IndexRouteObject | NonIndexRouteObject;\n\nexport type DataRouteObject = RouteObject & {\n children?: DataRouteObject[];\n id: string;\n};\n\nexport interface RouteMatch<\n ParamKey extends string = string,\n RouteObjectType extends RouteObject = RouteObject\n> extends AgnosticRouteMatch {}\n\nexport interface DataRouteMatch extends RouteMatch {}\n\nexport interface DataRouterContextObject\n // Omit `future` since those can be pulled from the `router`\n // `NavigationContext` needs future since it doesn't have a `router` in all cases\n extends Omit {\n router: Router;\n staticContext?: StaticHandlerContext;\n}\n\nexport const DataRouterContext =\n React.createContext(null);\nif (__DEV__) {\n DataRouterContext.displayName = \"DataRouter\";\n}\n\nexport const DataRouterStateContext = React.createContext<\n Router[\"state\"] | null\n>(null);\nif (__DEV__) {\n DataRouterStateContext.displayName = \"DataRouterState\";\n}\n\nexport const AwaitContext = React.createContext(null);\nif (__DEV__) {\n AwaitContext.displayName = \"Await\";\n}\n\nexport interface NavigateOptions {\n replace?: boolean;\n state?: any;\n preventScrollReset?: boolean;\n relative?: RelativeRoutingType;\n flushSync?: boolean;\n viewTransition?: boolean;\n}\n\n/**\n * A Navigator is a \"location changer\"; it's how you get to different locations.\n *\n * Every history instance conforms to the Navigator interface, but the\n * distinction is useful primarily when it comes to the low-level `` API\n * where both the location and a navigator must be provided separately in order\n * to avoid \"tearing\" that may occur in a suspense-enabled app if the action\n * and/or location were to be read directly from the history instance.\n */\nexport interface Navigator {\n createHref: History[\"createHref\"];\n // Optional for backwards-compat with Router/HistoryRouter usage (edge case)\n encodeLocation?: History[\"encodeLocation\"];\n go: History[\"go\"];\n push(to: To, state?: any, opts?: NavigateOptions): void;\n replace(to: To, state?: any, opts?: NavigateOptions): void;\n}\n\ninterface NavigationContextObject {\n basename: string;\n navigator: Navigator;\n static: boolean;\n future: {\n v7_relativeSplatPath: boolean;\n };\n}\n\nexport const NavigationContext = React.createContext(\n null!\n);\n\nif (__DEV__) {\n NavigationContext.displayName = \"Navigation\";\n}\n\ninterface LocationContextObject {\n location: Location;\n navigationType: NavigationType;\n}\n\nexport const LocationContext = React.createContext(\n null!\n);\n\nif (__DEV__) {\n LocationContext.displayName = \"Location\";\n}\n\nexport interface RouteContextObject {\n outlet: React.ReactElement | null;\n matches: RouteMatch[];\n isDataRoute: boolean;\n}\n\nexport const RouteContext = React.createContext({\n outlet: null,\n matches: [],\n isDataRoute: false,\n});\n\nif (__DEV__) {\n RouteContext.displayName = \"Route\";\n}\n\nexport const RouteErrorContext = React.createContext(null);\n\nif (__DEV__) {\n RouteErrorContext.displayName = \"RouteError\";\n}\n","import * as React from \"react\";\nimport type {\n Blocker,\n BlockerFunction,\n Location,\n ParamParseKey,\n Params,\n Path,\n PathMatch,\n PathPattern,\n RelativeRoutingType,\n Router as RemixRouter,\n RevalidationState,\n To,\n UIMatch,\n} from \"@remix-run/router\";\nimport {\n IDLE_BLOCKER,\n Action as NavigationType,\n UNSAFE_convertRouteMatchToUiMatch as convertRouteMatchToUiMatch,\n UNSAFE_decodePath as decodePath,\n UNSAFE_getResolveToMatches as getResolveToMatches,\n UNSAFE_invariant as invariant,\n isRouteErrorResponse,\n joinPaths,\n matchPath,\n matchRoutes,\n parsePath,\n resolveTo,\n stripBasename,\n UNSAFE_warning as warning,\n} from \"@remix-run/router\";\n\nimport type {\n DataRouteMatch,\n NavigateOptions,\n RouteContextObject,\n RouteMatch,\n RouteObject,\n} from \"./context\";\nimport {\n AwaitContext,\n DataRouterContext,\n DataRouterStateContext,\n LocationContext,\n NavigationContext,\n RouteContext,\n RouteErrorContext,\n} from \"./context\";\n\n/**\n * Returns the full href for the given \"to\" value. This is useful for building\n * custom links that are also accessible and preserve right-click behavior.\n *\n * @see https://reactrouter.com/v6/hooks/use-href\n */\nexport function useHref(\n to: To,\n { relative }: { relative?: RelativeRoutingType } = {}\n): string {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useHref() may be used only in the context of a component.`\n );\n\n let { basename, navigator } = React.useContext(NavigationContext);\n let { hash, pathname, search } = useResolvedPath(to, { relative });\n\n let joinedPathname = pathname;\n\n // If we're operating within a basename, prepend it to the pathname prior\n // to creating the href. If this is a root navigation, then just use the raw\n // basename which allows the basename to have full control over the presence\n // of a trailing slash on root links\n if (basename !== \"/\") {\n joinedPathname =\n pathname === \"/\" ? basename : joinPaths([basename, pathname]);\n }\n\n return navigator.createHref({ pathname: joinedPathname, search, hash });\n}\n\n/**\n * Returns true if this component is a descendant of a ``.\n *\n * @see https://reactrouter.com/v6/hooks/use-in-router-context\n */\nexport function useInRouterContext(): boolean {\n return React.useContext(LocationContext) != null;\n}\n\n/**\n * Returns the current location object, which represents the current URL in web\n * browsers.\n *\n * Note: If you're using this it may mean you're doing some of your own\n * \"routing\" in your app, and we'd like to know what your use case is. We may\n * be able to provide something higher-level to better suit your needs.\n *\n * @see https://reactrouter.com/v6/hooks/use-location\n */\nexport function useLocation(): Location {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useLocation() may be used only in the context of a component.`\n );\n\n return React.useContext(LocationContext).location;\n}\n\n/**\n * Returns the current navigation action which describes how the router came to\n * the current location, either by a pop, push, or replace on the history stack.\n *\n * @see https://reactrouter.com/v6/hooks/use-navigation-type\n */\nexport function useNavigationType(): NavigationType {\n return React.useContext(LocationContext).navigationType;\n}\n\n/**\n * Returns a PathMatch object if the given pattern matches the current URL.\n * This is useful for components that need to know \"active\" state, e.g.\n * ``.\n *\n * @see https://reactrouter.com/v6/hooks/use-match\n */\nexport function useMatch<\n ParamKey extends ParamParseKey,\n Path extends string\n>(pattern: PathPattern | Path): PathMatch | null {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useMatch() may be used only in the context of a component.`\n );\n\n let { pathname } = useLocation();\n return React.useMemo(\n () => matchPath(pattern, decodePath(pathname)),\n [pathname, pattern]\n );\n}\n\n/**\n * The interface for the navigate() function returned from useNavigate().\n */\nexport interface NavigateFunction {\n (to: To, options?: NavigateOptions): void;\n (delta: number): void;\n}\n\nconst navigateEffectWarning =\n `You should call navigate() in a React.useEffect(), not when ` +\n `your component is first rendered.`;\n\n// Mute warnings for calls to useNavigate in SSR environments\nfunction useIsomorphicLayoutEffect(\n cb: Parameters[0]\n) {\n let isStatic = React.useContext(NavigationContext).static;\n if (!isStatic) {\n // We should be able to get rid of this once react 18.3 is released\n // See: https://github.com/facebook/react/pull/26395\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useLayoutEffect(cb);\n }\n}\n\n/**\n * Returns an imperative method for changing the location. Used by ``s, but\n * may also be used by other elements to change the location.\n *\n * @see https://reactrouter.com/v6/hooks/use-navigate\n */\nexport function useNavigate(): NavigateFunction {\n let { isDataRoute } = React.useContext(RouteContext);\n // Conditional usage is OK here because the usage of a data router is static\n // eslint-disable-next-line react-hooks/rules-of-hooks\n return isDataRoute ? useNavigateStable() : useNavigateUnstable();\n}\n\nfunction useNavigateUnstable(): NavigateFunction {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useNavigate() may be used only in the context of a component.`\n );\n\n let dataRouterContext = React.useContext(DataRouterContext);\n let { basename, future, navigator } = React.useContext(NavigationContext);\n let { matches } = React.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n\n let routePathnamesJson = JSON.stringify(\n getResolveToMatches(matches, future.v7_relativeSplatPath)\n );\n\n let activeRef = React.useRef(false);\n useIsomorphicLayoutEffect(() => {\n activeRef.current = true;\n });\n\n let navigate: NavigateFunction = React.useCallback(\n (to: To | number, options: NavigateOptions = {}) => {\n warning(activeRef.current, navigateEffectWarning);\n\n // Short circuit here since if this happens on first render the navigate\n // is useless because we haven't wired up our history listener yet\n if (!activeRef.current) return;\n\n if (typeof to === \"number\") {\n navigator.go(to);\n return;\n }\n\n let path = resolveTo(\n to,\n JSON.parse(routePathnamesJson),\n locationPathname,\n options.relative === \"path\"\n );\n\n // If we're operating within a basename, prepend it to the pathname prior\n // to handing off to history (but only if we're not in a data router,\n // otherwise it'll prepend the basename inside of the router).\n // If this is a root navigation, then we navigate to the raw basename\n // which allows the basename to have full control over the presence of a\n // trailing slash on root links\n if (dataRouterContext == null && basename !== \"/\") {\n path.pathname =\n path.pathname === \"/\"\n ? basename\n : joinPaths([basename, path.pathname]);\n }\n\n (!!options.replace ? navigator.replace : navigator.push)(\n path,\n options.state,\n options\n );\n },\n [\n basename,\n navigator,\n routePathnamesJson,\n locationPathname,\n dataRouterContext,\n ]\n );\n\n return navigate;\n}\n\nconst OutletContext = React.createContext(null);\n\n/**\n * Returns the context (if provided) for the child route at this level of the route\n * hierarchy.\n * @see https://reactrouter.com/v6/hooks/use-outlet-context\n */\nexport function useOutletContext(): Context {\n return React.useContext(OutletContext) as Context;\n}\n\n/**\n * Returns the element for the child route at this level of the route\n * hierarchy. Used internally by `` to render child routes.\n *\n * @see https://reactrouter.com/v6/hooks/use-outlet\n */\nexport function useOutlet(context?: unknown): React.ReactElement | null {\n let outlet = React.useContext(RouteContext).outlet;\n if (outlet) {\n return (\n {outlet}\n );\n }\n return outlet;\n}\n\n/**\n * Returns an object of key/value pairs of the dynamic params from the current\n * URL that were matched by the route path.\n *\n * @see https://reactrouter.com/v6/hooks/use-params\n */\nexport function useParams<\n ParamsOrKey extends string | Record = string\n>(): Readonly<\n [ParamsOrKey] extends [string] ? Params : Partial\n> {\n let { matches } = React.useContext(RouteContext);\n let routeMatch = matches[matches.length - 1];\n return routeMatch ? (routeMatch.params as any) : {};\n}\n\n/**\n * Resolves the pathname of the given `to` value against the current location.\n *\n * @see https://reactrouter.com/v6/hooks/use-resolved-path\n */\nexport function useResolvedPath(\n to: To,\n { relative }: { relative?: RelativeRoutingType } = {}\n): Path {\n let { future } = React.useContext(NavigationContext);\n let { matches } = React.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n let routePathnamesJson = JSON.stringify(\n getResolveToMatches(matches, future.v7_relativeSplatPath)\n );\n\n return React.useMemo(\n () =>\n resolveTo(\n to,\n JSON.parse(routePathnamesJson),\n locationPathname,\n relative === \"path\"\n ),\n [to, routePathnamesJson, locationPathname, relative]\n );\n}\n\n/**\n * Returns the element of the route that matched the current location, prepared\n * with the correct context to render the remainder of the route tree. Route\n * elements in the tree must render an `` to render their child route's\n * element.\n *\n * @see https://reactrouter.com/v6/hooks/use-routes\n */\nexport function useRoutes(\n routes: RouteObject[],\n locationArg?: Partial | string\n): React.ReactElement | null {\n return useRoutesImpl(routes, locationArg);\n}\n\n// Internal implementation with accept optional param for RouterProvider usage\nexport function useRoutesImpl(\n routes: RouteObject[],\n locationArg?: Partial | string,\n dataRouterState?: RemixRouter[\"state\"],\n future?: RemixRouter[\"future\"]\n): React.ReactElement | null {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useRoutes() may be used only in the context of a component.`\n );\n\n let { navigator } = React.useContext(NavigationContext);\n let { matches: parentMatches } = React.useContext(RouteContext);\n let routeMatch = parentMatches[parentMatches.length - 1];\n let parentParams = routeMatch ? routeMatch.params : {};\n let parentPathname = routeMatch ? routeMatch.pathname : \"/\";\n let parentPathnameBase = routeMatch ? routeMatch.pathnameBase : \"/\";\n let parentRoute = routeMatch && routeMatch.route;\n\n if (__DEV__) {\n // You won't get a warning about 2 different under a \n // without a trailing *, but this is a best-effort warning anyway since we\n // cannot even give the warning unless they land at the parent route.\n //\n // Example:\n //\n // \n // {/* This route path MUST end with /* because otherwise\n // it will never match /blog/post/123 */}\n // } />\n // } />\n // \n //\n // function Blog() {\n // return (\n // \n // } />\n // \n // );\n // }\n let parentPath = (parentRoute && parentRoute.path) || \"\";\n warningOnce(\n parentPathname,\n !parentRoute || parentPath.endsWith(\"*\"),\n `You rendered descendant (or called \\`useRoutes()\\`) at ` +\n `\"${parentPathname}\" (under ) but the ` +\n `parent route path has no trailing \"*\". This means if you navigate ` +\n `deeper, the parent won't match anymore and therefore the child ` +\n `routes will never render.\\n\\n` +\n `Please change the parent to .`\n );\n }\n\n let locationFromContext = useLocation();\n\n let location;\n if (locationArg) {\n let parsedLocationArg =\n typeof locationArg === \"string\" ? parsePath(locationArg) : locationArg;\n\n invariant(\n parentPathnameBase === \"/\" ||\n parsedLocationArg.pathname?.startsWith(parentPathnameBase),\n `When overriding the location using \\`\\` or \\`useRoutes(routes, location)\\`, ` +\n `the location pathname must begin with the portion of the URL pathname that was ` +\n `matched by all parent routes. The current pathname base is \"${parentPathnameBase}\" ` +\n `but pathname \"${parsedLocationArg.pathname}\" was given in the \\`location\\` prop.`\n );\n\n location = parsedLocationArg;\n } else {\n location = locationFromContext;\n }\n\n let pathname = location.pathname || \"/\";\n\n let remainingPathname = pathname;\n if (parentPathnameBase !== \"/\") {\n // Determine the remaining pathname by removing the # of URL segments the\n // parentPathnameBase has, instead of removing based on character count.\n // This is because we can't guarantee that incoming/outgoing encodings/\n // decodings will match exactly.\n // We decode paths before matching on a per-segment basis with\n // decodeURIComponent(), but we re-encode pathnames via `new URL()` so they\n // match what `window.location.pathname` would reflect. Those don't 100%\n // align when it comes to encoded URI characters such as % and &.\n //\n // So we may end up with:\n // pathname: \"/descendant/a%25b/match\"\n // parentPathnameBase: \"/descendant/a%b\"\n //\n // And the direct substring removal approach won't work :/\n let parentSegments = parentPathnameBase.replace(/^\\//, \"\").split(\"/\");\n let segments = pathname.replace(/^\\//, \"\").split(\"/\");\n remainingPathname = \"/\" + segments.slice(parentSegments.length).join(\"/\");\n }\n\n let matches = matchRoutes(routes, { pathname: remainingPathname });\n\n if (__DEV__) {\n warning(\n parentRoute || matches != null,\n `No routes matched location \"${location.pathname}${location.search}${location.hash}\" `\n );\n\n warning(\n matches == null ||\n matches[matches.length - 1].route.element !== undefined ||\n matches[matches.length - 1].route.Component !== undefined ||\n matches[matches.length - 1].route.lazy !== undefined,\n `Matched leaf route at location \"${location.pathname}${location.search}${location.hash}\" ` +\n `does not have an element or Component. This means it will render an with a ` +\n `null value by default resulting in an \"empty\" page.`\n );\n }\n\n let renderedMatches = _renderMatches(\n matches &&\n matches.map((match) =>\n Object.assign({}, match, {\n params: Object.assign({}, parentParams, match.params),\n pathname: joinPaths([\n parentPathnameBase,\n // Re-encode pathnames that were decoded inside matchRoutes\n navigator.encodeLocation\n ? navigator.encodeLocation(match.pathname).pathname\n : match.pathname,\n ]),\n pathnameBase:\n match.pathnameBase === \"/\"\n ? parentPathnameBase\n : joinPaths([\n parentPathnameBase,\n // Re-encode pathnames that were decoded inside matchRoutes\n navigator.encodeLocation\n ? navigator.encodeLocation(match.pathnameBase).pathname\n : match.pathnameBase,\n ]),\n })\n ),\n parentMatches,\n dataRouterState,\n future\n );\n\n // When a user passes in a `locationArg`, the associated routes need to\n // be wrapped in a new `LocationContext.Provider` in order for `useLocation`\n // to use the scoped location instead of the global location.\n if (locationArg && renderedMatches) {\n return (\n \n {renderedMatches}\n \n );\n }\n\n return renderedMatches;\n}\n\nfunction DefaultErrorComponent() {\n let error = useRouteError();\n let message = isRouteErrorResponse(error)\n ? `${error.status} ${error.statusText}`\n : error instanceof Error\n ? error.message\n : JSON.stringify(error);\n let stack = error instanceof Error ? error.stack : null;\n let lightgrey = \"rgba(200,200,200, 0.5)\";\n let preStyles = { padding: \"0.5rem\", backgroundColor: lightgrey };\n let codeStyles = { padding: \"2px 4px\", backgroundColor: lightgrey };\n\n let devInfo = null;\n if (__DEV__) {\n console.error(\n \"Error handled by React Router default ErrorBoundary:\",\n error\n );\n\n devInfo = (\n <>\n

💿 Hey developer 👋

\n

\n You can provide a way better UX than this when your app throws errors\n by providing your own ErrorBoundary or{\" \"}\n errorElement prop on your route.\n

\n \n );\n }\n\n return (\n <>\n

Unexpected Application Error!

\n

{message}

\n {stack ?
{stack}
: null}\n {devInfo}\n \n );\n}\n\nconst defaultErrorElement = ;\n\ntype RenderErrorBoundaryProps = React.PropsWithChildren<{\n location: Location;\n revalidation: RevalidationState;\n error: any;\n component: React.ReactNode;\n routeContext: RouteContextObject;\n}>;\n\ntype RenderErrorBoundaryState = {\n location: Location;\n revalidation: RevalidationState;\n error: any;\n};\n\nexport class RenderErrorBoundary extends React.Component<\n RenderErrorBoundaryProps,\n RenderErrorBoundaryState\n> {\n constructor(props: RenderErrorBoundaryProps) {\n super(props);\n this.state = {\n location: props.location,\n revalidation: props.revalidation,\n error: props.error,\n };\n }\n\n static getDerivedStateFromError(error: any) {\n return { error: error };\n }\n\n static getDerivedStateFromProps(\n props: RenderErrorBoundaryProps,\n state: RenderErrorBoundaryState\n ) {\n // When we get into an error state, the user will likely click \"back\" to the\n // previous page that didn't have an error. Because this wraps the entire\n // application, that will have no effect--the error page continues to display.\n // This gives us a mechanism to recover from the error when the location changes.\n //\n // Whether we're in an error state or not, we update the location in state\n // so that when we are in an error state, it gets reset when a new location\n // comes in and the user recovers from the error.\n if (\n state.location !== props.location ||\n (state.revalidation !== \"idle\" && props.revalidation === \"idle\")\n ) {\n return {\n error: props.error,\n location: props.location,\n revalidation: props.revalidation,\n };\n }\n\n // If we're not changing locations, preserve the location but still surface\n // any new errors that may come through. We retain the existing error, we do\n // this because the error provided from the app state may be cleared without\n // the location changing.\n return {\n error: props.error !== undefined ? props.error : state.error,\n location: state.location,\n revalidation: props.revalidation || state.revalidation,\n };\n }\n\n componentDidCatch(error: any, errorInfo: any) {\n console.error(\n \"React Router caught the following error during render\",\n error,\n errorInfo\n );\n }\n\n render() {\n return this.state.error !== undefined ? (\n \n \n \n ) : (\n this.props.children\n );\n }\n}\n\ninterface RenderedRouteProps {\n routeContext: RouteContextObject;\n match: RouteMatch;\n children: React.ReactNode | null;\n}\n\nfunction RenderedRoute({ routeContext, match, children }: RenderedRouteProps) {\n let dataRouterContext = React.useContext(DataRouterContext);\n\n // Track how deep we got in our render pass to emulate SSR componentDidCatch\n // in a DataStaticRouter\n if (\n dataRouterContext &&\n dataRouterContext.static &&\n dataRouterContext.staticContext &&\n (match.route.errorElement || match.route.ErrorBoundary)\n ) {\n dataRouterContext.staticContext._deepestRenderedBoundaryId = match.route.id;\n }\n\n return (\n \n {children}\n \n );\n}\n\nexport function _renderMatches(\n matches: RouteMatch[] | null,\n parentMatches: RouteMatch[] = [],\n dataRouterState: RemixRouter[\"state\"] | null = null,\n future: RemixRouter[\"future\"] | null = null\n): React.ReactElement | null {\n if (matches == null) {\n if (!dataRouterState) {\n return null;\n }\n\n if (dataRouterState.errors) {\n // Don't bail if we have data router errors so we can render them in the\n // boundary. Use the pre-matched (or shimmed) matches\n matches = dataRouterState.matches as DataRouteMatch[];\n } else if (\n future?.v7_partialHydration &&\n parentMatches.length === 0 &&\n !dataRouterState.initialized &&\n dataRouterState.matches.length > 0\n ) {\n // Don't bail if we're initializing with partial hydration and we have\n // router matches. That means we're actively running `patchRoutesOnNavigation`\n // so we should render down the partial matches to the appropriate\n // `HydrateFallback`. We only do this if `parentMatches` is empty so it\n // only impacts the root matches for `RouterProvider` and no descendant\n // ``\n matches = dataRouterState.matches as DataRouteMatch[];\n } else {\n return null;\n }\n }\n\n let renderedMatches = matches;\n\n // If we have data errors, trim matches to the highest error boundary\n let errors = dataRouterState?.errors;\n if (errors != null) {\n let errorIndex = renderedMatches.findIndex(\n (m) => m.route.id && errors?.[m.route.id] !== undefined\n );\n invariant(\n errorIndex >= 0,\n `Could not find a matching route for errors on route IDs: ${Object.keys(\n errors\n ).join(\",\")}`\n );\n renderedMatches = renderedMatches.slice(\n 0,\n Math.min(renderedMatches.length, errorIndex + 1)\n );\n }\n\n // If we're in a partial hydration mode, detect if we need to render down to\n // a given HydrateFallback while we load the rest of the hydration data\n let renderFallback = false;\n let fallbackIndex = -1;\n if (dataRouterState && future && future.v7_partialHydration) {\n for (let i = 0; i < renderedMatches.length; i++) {\n let match = renderedMatches[i];\n // Track the deepest fallback up until the first route without data\n if (match.route.HydrateFallback || match.route.hydrateFallbackElement) {\n fallbackIndex = i;\n }\n\n if (match.route.id) {\n let { loaderData, errors } = dataRouterState;\n let needsToRunLoader =\n match.route.loader &&\n loaderData[match.route.id] === undefined &&\n (!errors || errors[match.route.id] === undefined);\n if (match.route.lazy || needsToRunLoader) {\n // We found the first route that's not ready to render (waiting on\n // lazy, or has a loader that hasn't run yet). Flag that we need to\n // render a fallback and render up until the appropriate fallback\n renderFallback = true;\n if (fallbackIndex >= 0) {\n renderedMatches = renderedMatches.slice(0, fallbackIndex + 1);\n } else {\n renderedMatches = [renderedMatches[0]];\n }\n break;\n }\n }\n }\n }\n\n return renderedMatches.reduceRight((outlet, match, index) => {\n // Only data routers handle errors/fallbacks\n let error: any;\n let shouldRenderHydrateFallback = false;\n let errorElement: React.ReactNode | null = null;\n let hydrateFallbackElement: React.ReactNode | null = null;\n if (dataRouterState) {\n error = errors && match.route.id ? errors[match.route.id] : undefined;\n errorElement = match.route.errorElement || defaultErrorElement;\n\n if (renderFallback) {\n if (fallbackIndex < 0 && index === 0) {\n warningOnce(\n \"route-fallback\",\n false,\n \"No `HydrateFallback` element provided to render during initial hydration\"\n );\n shouldRenderHydrateFallback = true;\n hydrateFallbackElement = null;\n } else if (fallbackIndex === index) {\n shouldRenderHydrateFallback = true;\n hydrateFallbackElement = match.route.hydrateFallbackElement || null;\n }\n }\n }\n\n let matches = parentMatches.concat(renderedMatches.slice(0, index + 1));\n let getChildren = () => {\n let children: React.ReactNode;\n if (error) {\n children = errorElement;\n } else if (shouldRenderHydrateFallback) {\n children = hydrateFallbackElement;\n } else if (match.route.Component) {\n // Note: This is a de-optimized path since React won't re-use the\n // ReactElement since it's identity changes with each new\n // React.createElement call. We keep this so folks can use\n // `` in `` but generally `Component`\n // usage is only advised in `RouterProvider` when we can convert it to\n // `element` ahead of time.\n children = ;\n } else if (match.route.element) {\n children = match.route.element;\n } else {\n children = outlet;\n }\n return (\n \n );\n };\n // Only wrap in an error boundary within data router usages when we have an\n // ErrorBoundary/errorElement on this route. Otherwise let it bubble up to\n // an ancestor ErrorBoundary/errorElement\n return dataRouterState &&\n (match.route.ErrorBoundary || match.route.errorElement || index === 0) ? (\n \n ) : (\n getChildren()\n );\n }, null as React.ReactElement | null);\n}\n\nenum DataRouterHook {\n UseBlocker = \"useBlocker\",\n UseRevalidator = \"useRevalidator\",\n UseNavigateStable = \"useNavigate\",\n}\n\nenum DataRouterStateHook {\n UseBlocker = \"useBlocker\",\n UseLoaderData = \"useLoaderData\",\n UseActionData = \"useActionData\",\n UseRouteError = \"useRouteError\",\n UseNavigation = \"useNavigation\",\n UseRouteLoaderData = \"useRouteLoaderData\",\n UseMatches = \"useMatches\",\n UseRevalidator = \"useRevalidator\",\n UseNavigateStable = \"useNavigate\",\n UseRouteId = \"useRouteId\",\n}\n\nfunction getDataRouterConsoleError(\n hookName: DataRouterHook | DataRouterStateHook\n) {\n return `${hookName} must be used within a data router. See https://reactrouter.com/v6/routers/picking-a-router.`;\n}\n\nfunction useDataRouterContext(hookName: DataRouterHook) {\n let ctx = React.useContext(DataRouterContext);\n invariant(ctx, getDataRouterConsoleError(hookName));\n return ctx;\n}\n\nfunction useDataRouterState(hookName: DataRouterStateHook) {\n let state = React.useContext(DataRouterStateContext);\n invariant(state, getDataRouterConsoleError(hookName));\n return state;\n}\n\nfunction useRouteContext(hookName: DataRouterStateHook) {\n let route = React.useContext(RouteContext);\n invariant(route, getDataRouterConsoleError(hookName));\n return route;\n}\n\n// Internal version with hookName-aware debugging\nfunction useCurrentRouteId(hookName: DataRouterStateHook) {\n let route = useRouteContext(hookName);\n let thisRoute = route.matches[route.matches.length - 1];\n invariant(\n thisRoute.route.id,\n `${hookName} can only be used on routes that contain a unique \"id\"`\n );\n return thisRoute.route.id;\n}\n\n/**\n * Returns the ID for the nearest contextual route\n */\nexport function useRouteId() {\n return useCurrentRouteId(DataRouterStateHook.UseRouteId);\n}\n\n/**\n * Returns the current navigation, defaulting to an \"idle\" navigation when\n * no navigation is in progress\n */\nexport function useNavigation() {\n let state = useDataRouterState(DataRouterStateHook.UseNavigation);\n return state.navigation;\n}\n\n/**\n * Returns a revalidate function for manually triggering revalidation, as well\n * as the current state of any manual revalidations\n */\nexport function useRevalidator() {\n let dataRouterContext = useDataRouterContext(DataRouterHook.UseRevalidator);\n let state = useDataRouterState(DataRouterStateHook.UseRevalidator);\n return React.useMemo(\n () => ({\n revalidate: dataRouterContext.router.revalidate,\n state: state.revalidation,\n }),\n [dataRouterContext.router.revalidate, state.revalidation]\n );\n}\n\n/**\n * Returns the active route matches, useful for accessing loaderData for\n * parent/child routes or the route \"handle\" property\n */\nexport function useMatches(): UIMatch[] {\n let { matches, loaderData } = useDataRouterState(\n DataRouterStateHook.UseMatches\n );\n return React.useMemo(\n () => matches.map((m) => convertRouteMatchToUiMatch(m, loaderData)),\n [matches, loaderData]\n );\n}\n\n/**\n * Returns the loader data for the nearest ancestor Route loader\n */\nexport function useLoaderData(): unknown {\n let state = useDataRouterState(DataRouterStateHook.UseLoaderData);\n let routeId = useCurrentRouteId(DataRouterStateHook.UseLoaderData);\n\n if (state.errors && state.errors[routeId] != null) {\n console.error(\n `You cannot \\`useLoaderData\\` in an errorElement (routeId: ${routeId})`\n );\n return undefined;\n }\n return state.loaderData[routeId];\n}\n\n/**\n * Returns the loaderData for the given routeId\n */\nexport function useRouteLoaderData(routeId: string): unknown {\n let state = useDataRouterState(DataRouterStateHook.UseRouteLoaderData);\n return state.loaderData[routeId];\n}\n\n/**\n * Returns the action data for the nearest ancestor Route action\n */\nexport function useActionData(): unknown {\n let state = useDataRouterState(DataRouterStateHook.UseActionData);\n let routeId = useCurrentRouteId(DataRouterStateHook.UseLoaderData);\n return state.actionData ? state.actionData[routeId] : undefined;\n}\n\n/**\n * Returns the nearest ancestor Route error, which could be a loader/action\n * error or a render error. This is intended to be called from your\n * ErrorBoundary/errorElement to display a proper error message.\n */\nexport function useRouteError(): unknown {\n let error = React.useContext(RouteErrorContext);\n let state = useDataRouterState(DataRouterStateHook.UseRouteError);\n let routeId = useCurrentRouteId(DataRouterStateHook.UseRouteError);\n\n // If this was a render error, we put it in a RouteError context inside\n // of RenderErrorBoundary\n if (error !== undefined) {\n return error;\n }\n\n // Otherwise look for errors from our data router state\n return state.errors?.[routeId];\n}\n\n/**\n * Returns the happy-path data from the nearest ancestor `` value\n */\nexport function useAsyncValue(): unknown {\n let value = React.useContext(AwaitContext);\n return value?._data;\n}\n\n/**\n * Returns the error from the nearest ancestor `` value\n */\nexport function useAsyncError(): unknown {\n let value = React.useContext(AwaitContext);\n return value?._error;\n}\n\nlet blockerId = 0;\n\n/**\n * Allow the application to block navigations within the SPA and present the\n * user a confirmation dialog to confirm the navigation. Mostly used to avoid\n * using half-filled form data. This does not handle hard-reloads or\n * cross-origin navigations.\n */\nexport function useBlocker(shouldBlock: boolean | BlockerFunction): Blocker {\n let { router, basename } = useDataRouterContext(DataRouterHook.UseBlocker);\n let state = useDataRouterState(DataRouterStateHook.UseBlocker);\n\n let [blockerKey, setBlockerKey] = React.useState(\"\");\n let blockerFunction = React.useCallback(\n (arg) => {\n if (typeof shouldBlock !== \"function\") {\n return !!shouldBlock;\n }\n if (basename === \"/\") {\n return shouldBlock(arg);\n }\n\n // If they provided us a function and we've got an active basename, strip\n // it from the locations we expose to the user to match the behavior of\n // useLocation\n let { currentLocation, nextLocation, historyAction } = arg;\n return shouldBlock({\n currentLocation: {\n ...currentLocation,\n pathname:\n stripBasename(currentLocation.pathname, basename) ||\n currentLocation.pathname,\n },\n nextLocation: {\n ...nextLocation,\n pathname:\n stripBasename(nextLocation.pathname, basename) ||\n nextLocation.pathname,\n },\n historyAction,\n });\n },\n [basename, shouldBlock]\n );\n\n // This effect is in charge of blocker key assignment and deletion (which is\n // tightly coupled to the key)\n React.useEffect(() => {\n let key = String(++blockerId);\n setBlockerKey(key);\n return () => router.deleteBlocker(key);\n }, [router]);\n\n // This effect handles assigning the blockerFunction. This is to handle\n // unstable blocker function identities, and happens only after the prior\n // effect so we don't get an orphaned blockerFunction in the router with a\n // key of \"\". Until then we just have the IDLE_BLOCKER.\n React.useEffect(() => {\n if (blockerKey !== \"\") {\n router.getBlocker(blockerKey, blockerFunction);\n }\n }, [router, blockerKey, blockerFunction]);\n\n // Prefer the blocker from `state` not `router.state` since DataRouterContext\n // is memoized so this ensures we update on blocker state updates\n return blockerKey && state.blockers.has(blockerKey)\n ? state.blockers.get(blockerKey)!\n : IDLE_BLOCKER;\n}\n\n/**\n * Stable version of useNavigate that is used when we are in the context of\n * a RouterProvider.\n */\nfunction useNavigateStable(): NavigateFunction {\n let { router } = useDataRouterContext(DataRouterHook.UseNavigateStable);\n let id = useCurrentRouteId(DataRouterStateHook.UseNavigateStable);\n\n let activeRef = React.useRef(false);\n useIsomorphicLayoutEffect(() => {\n activeRef.current = true;\n });\n\n let navigate: NavigateFunction = React.useCallback(\n (to: To | number, options: NavigateOptions = {}) => {\n warning(activeRef.current, navigateEffectWarning);\n\n // Short circuit here since if this happens on first render the navigate\n // is useless because we haven't wired up our router subscriber yet\n if (!activeRef.current) return;\n\n if (typeof to === \"number\") {\n router.navigate(to);\n } else {\n router.navigate(to, { fromRouteId: id, ...options });\n }\n },\n [router, id]\n );\n\n return navigate;\n}\n\nconst alreadyWarned: Record = {};\n\nfunction warningOnce(key: string, cond: boolean, message: string) {\n if (!cond && !alreadyWarned[key]) {\n alreadyWarned[key] = true;\n warning(false, message);\n }\n}\n","import type { FutureConfig as RouterFutureConfig } from \"@remix-run/router\";\nimport type { FutureConfig as RenderFutureConfig } from \"./components\";\n\nconst alreadyWarned: { [key: string]: boolean } = {};\n\nexport function warnOnce(key: string, message: string): void {\n if (!alreadyWarned[message]) {\n alreadyWarned[message] = true;\n console.warn(message);\n }\n}\n\nconst logDeprecation = (flag: string, msg: string, link: string) =>\n warnOnce(\n flag,\n `⚠️ React Router Future Flag Warning: ${msg}. ` +\n `You can use the \\`${flag}\\` future flag to opt-in early. ` +\n `For more information, see ${link}.`\n );\n\nexport function logV6DeprecationWarnings(\n renderFuture: Partial | undefined,\n routerFuture?: Omit\n) {\n if (!renderFuture?.v7_startTransition) {\n logDeprecation(\n \"v7_startTransition\",\n \"React Router will begin wrapping state updates in `React.startTransition` in v7\",\n \"https://reactrouter.com/v6/upgrading/future#v7_starttransition\"\n );\n }\n\n if (\n !renderFuture?.v7_relativeSplatPath &&\n (!routerFuture || !routerFuture.v7_relativeSplatPath)\n ) {\n logDeprecation(\n \"v7_relativeSplatPath\",\n \"Relative route resolution within Splat routes is changing in v7\",\n \"https://reactrouter.com/v6/upgrading/future#v7_relativesplatpath\"\n );\n }\n\n if (routerFuture) {\n if (!routerFuture.v7_fetcherPersist) {\n logDeprecation(\n \"v7_fetcherPersist\",\n \"The persistence behavior of fetchers is changing in v7\",\n \"https://reactrouter.com/v6/upgrading/future#v7_fetcherpersist\"\n );\n }\n\n if (!routerFuture.v7_normalizeFormMethod) {\n logDeprecation(\n \"v7_normalizeFormMethod\",\n \"Casing of `formMethod` fields is being normalized to uppercase in v7\",\n \"https://reactrouter.com/v6/upgrading/future#v7_normalizeformmethod\"\n );\n }\n\n if (!routerFuture.v7_partialHydration) {\n logDeprecation(\n \"v7_partialHydration\",\n \"`RouterProvider` hydration behavior is changing in v7\",\n \"https://reactrouter.com/v6/upgrading/future#v7_partialhydration\"\n );\n }\n\n if (!routerFuture.v7_skipActionErrorRevalidation) {\n logDeprecation(\n \"v7_skipActionErrorRevalidation\",\n \"The revalidation behavior after 4xx/5xx `action` responses is changing in v7\",\n \"https://reactrouter.com/v6/upgrading/future#v7_skipactionerrorrevalidation\"\n );\n }\n }\n}\n","import type {\n InitialEntry,\n LazyRouteFunction,\n Location,\n MemoryHistory,\n RelativeRoutingType,\n Router as RemixRouter,\n RouterState,\n RouterSubscriber,\n To,\n TrackedPromise,\n} from \"@remix-run/router\";\nimport {\n AbortedDeferredError,\n Action as NavigationType,\n createMemoryHistory,\n UNSAFE_getResolveToMatches as getResolveToMatches,\n UNSAFE_invariant as invariant,\n parsePath,\n resolveTo,\n stripBasename,\n UNSAFE_warning as warning,\n} from \"@remix-run/router\";\nimport * as React from \"react\";\n\nimport type {\n DataRouteObject,\n IndexRouteObject,\n Navigator,\n NonIndexRouteObject,\n RouteMatch,\n RouteObject,\n} from \"./context\";\nimport {\n AwaitContext,\n DataRouterContext,\n DataRouterStateContext,\n LocationContext,\n NavigationContext,\n RouteContext,\n} from \"./context\";\nimport {\n _renderMatches,\n useAsyncValue,\n useInRouterContext,\n useLocation,\n useNavigate,\n useOutlet,\n useRoutes,\n useRoutesImpl,\n} from \"./hooks\";\nimport { logV6DeprecationWarnings } from \"./deprecations\";\n\nexport interface FutureConfig {\n v7_relativeSplatPath: boolean;\n v7_startTransition: boolean;\n}\n\nexport interface RouterProviderProps {\n fallbackElement?: React.ReactNode;\n router: RemixRouter;\n // Only accept future flags relevant to rendering behavior\n // routing flags should be accessed via router.future\n future?: Partial>;\n}\n\n/**\n Webpack + React 17 fails to compile on any of the following because webpack\n complains that `startTransition` doesn't exist in `React`:\n * import { startTransition } from \"react\"\n * import * as React from from \"react\";\n \"startTransition\" in React ? React.startTransition(() => setState()) : setState()\n * import * as React from from \"react\";\n \"startTransition\" in React ? React[\"startTransition\"](() => setState()) : setState()\n\n Moving it to a constant such as the following solves the Webpack/React 17 issue:\n * import * as React from from \"react\";\n const START_TRANSITION = \"startTransition\";\n START_TRANSITION in React ? React[START_TRANSITION](() => setState()) : setState()\n\n However, that introduces webpack/terser minification issues in production builds\n in React 18 where minification/obfuscation ends up removing the call of\n React.startTransition entirely from the first half of the ternary. Grabbing\n this exported reference once up front resolves that issue.\n\n See https://github.com/remix-run/react-router/issues/10579\n*/\nconst START_TRANSITION = \"startTransition\";\nconst startTransitionImpl = React[START_TRANSITION];\n\n/**\n * Given a Remix Router instance, render the appropriate UI\n */\nexport function RouterProvider({\n fallbackElement,\n router,\n future,\n}: RouterProviderProps): React.ReactElement {\n let [state, setStateImpl] = React.useState(router.state);\n let { v7_startTransition } = future || {};\n\n let setState = React.useCallback(\n (newState: RouterState) => {\n if (v7_startTransition && startTransitionImpl) {\n startTransitionImpl(() => setStateImpl(newState));\n } else {\n setStateImpl(newState);\n }\n },\n [setStateImpl, v7_startTransition]\n );\n\n // Need to use a layout effect here so we are subscribed early enough to\n // pick up on any render-driven redirects/navigations (useEffect/)\n React.useLayoutEffect(() => router.subscribe(setState), [router, setState]);\n\n React.useEffect(() => {\n warning(\n fallbackElement == null || !router.future.v7_partialHydration,\n \"`` is deprecated when using \" +\n \"`v7_partialHydration`, use a `HydrateFallback` component instead\"\n );\n // Only log this once on initial mount\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n let navigator = React.useMemo((): Navigator => {\n return {\n createHref: router.createHref,\n encodeLocation: router.encodeLocation,\n go: (n) => router.navigate(n),\n push: (to, state, opts) =>\n router.navigate(to, {\n state,\n preventScrollReset: opts?.preventScrollReset,\n }),\n replace: (to, state, opts) =>\n router.navigate(to, {\n replace: true,\n state,\n preventScrollReset: opts?.preventScrollReset,\n }),\n };\n }, [router]);\n\n let basename = router.basename || \"/\";\n\n let dataRouterContext = React.useMemo(\n () => ({\n router,\n navigator,\n static: false,\n basename,\n }),\n [router, navigator, basename]\n );\n\n React.useEffect(\n () => logV6DeprecationWarnings(future, router.future),\n [router, future]\n );\n\n // The fragment and {null} here are important! We need them to keep React 18's\n // useId happy when we are server-rendering since we may have a